2015-02-05 13:08:05 -08:00
|
|
|
import {DOM, document} from 'angular2/src/facade/dom';
|
|
|
|
import {isBlank, Type} from 'angular2/src/facade/lang';
|
|
|
|
import {MapWrapper} from 'angular2/src/facade/collection';
|
|
|
|
import {DirectiveMetadata} from 'angular2/src/core/compiler/directive_metadata';
|
2014-11-14 14:03:03 -08:00
|
|
|
|
2015-02-05 13:08:05 -08:00
|
|
|
import {Parser, Lexer, ProtoRecordRange, dynamicChangeDetection} from 'angular2/change_detection';
|
2014-11-14 14:03:03 -08:00
|
|
|
|
2015-02-05 13:08:05 -08:00
|
|
|
import {Compiler, CompilerCache} from 'angular2/src/core/compiler/compiler';
|
|
|
|
import {DirectiveMetadataReader} from 'angular2/src/core/compiler/directive_metadata_reader';
|
2014-11-14 14:03:03 -08:00
|
|
|
|
2015-02-05 13:08:05 -08:00
|
|
|
import {Component} from 'angular2/src/core/annotations/annotations';
|
|
|
|
import {Decorator} from 'angular2/src/core/annotations/annotations';
|
|
|
|
import {TemplateConfig} from 'angular2/src/core/annotations/template_config';
|
2014-11-14 14:03:03 -08:00
|
|
|
|
2015-02-05 13:08:05 -08:00
|
|
|
import {reflector} from 'angular2/src/reflection/reflection';
|
|
|
|
import {getIntParameter, bindAction} from 'angular2/src/test_lib/benchmark_util';
|
2014-11-17 11:01:21 -08:00
|
|
|
|
2014-12-22 17:50:10 -08:00
|
|
|
function setupReflector() {
|
2014-11-17 20:47:05 -08:00
|
|
|
reflector.registerType(BenchmarkComponent, {
|
|
|
|
"factory": () => new BenchmarkComponent(),
|
|
|
|
"parameters": [],
|
|
|
|
"annotations" : [new Component({template: new TemplateConfig({directives: [Dir0, Dir1, Dir2, Dir3, Dir4]})})]
|
|
|
|
});
|
|
|
|
|
|
|
|
reflector.registerType(Dir0, {
|
|
|
|
"factory": () => new Dir0(),
|
|
|
|
"parameters": [],
|
|
|
|
"annotations" : [new Decorator({selector: '[dir0]', bind: {'attr0': 'prop'}})]
|
|
|
|
});
|
|
|
|
|
|
|
|
reflector.registerType(Dir1, {
|
|
|
|
"factory": (dir0) => new Dir1(dir0),
|
|
|
|
"parameters": [[Dir0]],
|
|
|
|
"annotations" : [new Decorator({selector: '[dir1]', bind: {'attr1': 'prop'}})]
|
|
|
|
});
|
|
|
|
|
|
|
|
reflector.registerType(Dir2, {
|
|
|
|
"factory": (dir1) => new Dir2(dir1),
|
|
|
|
"parameters": [[Dir1]],
|
|
|
|
"annotations" : [new Decorator({selector: '[dir2]', bind: {'attr2': 'prop'}})]
|
|
|
|
});
|
|
|
|
|
|
|
|
reflector.registerType(Dir3, {
|
|
|
|
"factory": (dir2) => new Dir3(dir2),
|
|
|
|
"parameters": [[Dir2]],
|
|
|
|
"annotations" : [new Decorator({selector: '[dir3]', bind: {'attr3': 'prop'}})]
|
|
|
|
});
|
|
|
|
|
|
|
|
reflector.registerType(Dir4, {
|
|
|
|
"factory": (dir3) => new Dir4(dir3),
|
|
|
|
"parameters": [[Dir3]],
|
|
|
|
"annotations" : [new Decorator({selector: '[dir4]', bind: {'attr4': 'prop'}})]
|
|
|
|
});
|
|
|
|
|
|
|
|
reflector.registerGetters({
|
2014-12-05 16:26:30 -08:00
|
|
|
"inter0": (a) => a.inter0, "inter1": (a) => a.inter1,
|
2014-11-17 20:47:05 -08:00
|
|
|
"inter2": (a) => a.inter2, "inter3": (a) => a.inter3, "inter4": (a) => a.inter4,
|
|
|
|
|
|
|
|
"value0": (a) => a.value0, "value1": (a) => a.value1,
|
|
|
|
"value2": (a) => a.value2, "value3": (a) => a.value3, "value4": (a) => a.value4,
|
|
|
|
|
|
|
|
"prop" : (a) => a.prop
|
|
|
|
});
|
|
|
|
|
|
|
|
reflector.registerSetters({
|
|
|
|
"inter0": (a,v) => a.inter0 = v, "inter1": (a,v) => a.inter1 = v,
|
|
|
|
"inter2": (a,v) => a.inter2 = v, "inter3": (a,v) => a.inter3 = v, "inter4": (a,v) => a.inter4 = v,
|
|
|
|
|
|
|
|
"value0": (a,v) => a.value0 = v, "value1": (a,v) => a.value1 = v,
|
|
|
|
"value2": (a,v) => a.value2 = v, "value3": (a,v) => a.value3 = v, "value4": (a,v) => a.value4 = v,
|
|
|
|
|
|
|
|
"prop": (a,v) => a.prop = v
|
|
|
|
});
|
2014-11-14 14:03:03 -08:00
|
|
|
}
|
|
|
|
|
2014-11-17 11:01:21 -08:00
|
|
|
export function main() {
|
2015-01-09 18:00:04 -08:00
|
|
|
var count = getIntParameter('elements');
|
|
|
|
|
2014-12-22 17:50:10 -08:00
|
|
|
setupReflector();
|
|
|
|
var reader = new DirectiveMetadataReader();
|
|
|
|
var cache = new CompilerCache();
|
2015-01-21 12:05:52 -08:00
|
|
|
var compiler = new Compiler(dynamicChangeDetection, null, reader, new Parser(new Lexer()), cache);
|
2014-12-23 10:45:20 -08:00
|
|
|
var annotatedComponent = reader.read(BenchmarkComponent);
|
2014-12-22 17:50:10 -08:00
|
|
|
|
2015-01-09 18:00:04 -08:00
|
|
|
var templateNoBindings = loadTemplate('templateNoBindings', count);
|
|
|
|
var templateWithBindings = loadTemplate('templateWithBindings', count);
|
2014-12-22 17:50:10 -08:00
|
|
|
|
2015-01-09 18:00:04 -08:00
|
|
|
function compileNoBindings() {
|
2014-12-22 17:50:10 -08:00
|
|
|
// Need to clone every time as the compiler might modify the template!
|
|
|
|
var cloned = DOM.clone(templateNoBindings);
|
|
|
|
cache.clear();
|
|
|
|
compiler.compileAllLoaded(null, annotatedComponent, cloned);
|
|
|
|
}
|
2014-11-17 11:01:21 -08:00
|
|
|
|
2015-01-09 18:00:04 -08:00
|
|
|
function compileWithBindings() {
|
2014-12-22 17:50:10 -08:00
|
|
|
// Need to clone every time as the compiler might modify the template!
|
|
|
|
var cloned = DOM.clone(templateWithBindings);
|
|
|
|
cache.clear();
|
|
|
|
compiler.compileAllLoaded(null, annotatedComponent, cloned);
|
|
|
|
}
|
2014-11-17 20:47:05 -08:00
|
|
|
|
2015-01-09 18:00:04 -08:00
|
|
|
bindAction('#compileNoBindings', compileNoBindings);
|
|
|
|
bindAction('#compileWithBindings', compileWithBindings);
|
2014-11-14 14:03:03 -08:00
|
|
|
}
|
|
|
|
|
2014-11-17 11:01:21 -08:00
|
|
|
function loadTemplate(templateId, repeatCount) {
|
|
|
|
var template = DOM.querySelectorAll(document, `#${templateId}`)[0];
|
|
|
|
var content = DOM.getInnerHTML(template);
|
|
|
|
var result = '';
|
|
|
|
for (var i=0; i<repeatCount; i++) {
|
|
|
|
result += content;
|
|
|
|
}
|
|
|
|
return DOM.createTemplate(result);
|
2014-11-14 14:03:03 -08:00
|
|
|
}
|
|
|
|
|
|
|
|
@Decorator({
|
|
|
|
selector: '[dir0]',
|
|
|
|
bind: {
|
|
|
|
'attr0': 'prop'
|
|
|
|
}
|
|
|
|
})
|
|
|
|
class Dir0 {}
|
|
|
|
|
|
|
|
@Decorator({
|
|
|
|
selector: '[dir1]',
|
|
|
|
bind: {
|
|
|
|
'attr1': 'prop'
|
|
|
|
}
|
|
|
|
})
|
2014-11-17 20:47:05 -08:00
|
|
|
class Dir1 {
|
|
|
|
constructor(dir0:Dir0) {}
|
|
|
|
}
|
2014-11-14 14:03:03 -08:00
|
|
|
|
|
|
|
@Decorator({
|
|
|
|
selector: '[dir2]',
|
|
|
|
bind: {
|
|
|
|
'attr2': 'prop'
|
|
|
|
}
|
|
|
|
})
|
2014-11-17 20:47:05 -08:00
|
|
|
class Dir2 {
|
|
|
|
constructor(dir1:Dir1) {}
|
|
|
|
}
|
2014-11-14 14:03:03 -08:00
|
|
|
|
|
|
|
@Decorator({
|
|
|
|
selector: '[dir3]',
|
|
|
|
bind: {
|
|
|
|
'attr3': 'prop'
|
|
|
|
}
|
|
|
|
})
|
2014-11-17 20:47:05 -08:00
|
|
|
class Dir3 {
|
|
|
|
constructor(dir2:Dir2) {}
|
|
|
|
}
|
2014-11-14 14:03:03 -08:00
|
|
|
|
|
|
|
@Decorator({
|
|
|
|
selector: '[dir4]',
|
|
|
|
bind: {
|
|
|
|
'attr4': 'prop'
|
|
|
|
}
|
|
|
|
})
|
2014-11-17 20:47:05 -08:00
|
|
|
class Dir4 {
|
|
|
|
constructor(dir3:Dir3) {}
|
|
|
|
}
|
2014-11-14 14:03:03 -08:00
|
|
|
|
|
|
|
@Component({
|
|
|
|
template: new TemplateConfig({
|
|
|
|
directives: [Dir0, Dir1, Dir2, Dir3, Dir4]
|
|
|
|
})
|
|
|
|
})
|
2014-11-17 11:01:21 -08:00
|
|
|
class BenchmarkComponent {}
|
2014-11-14 14:03:03 -08:00
|
|
|
|