refactor(compiler): use the new compiler everywhere
Closes #3605 BREAKING CHANGE: - we don't mark an element as bound any more if it only contains text bindings E.g. <div>{{hello}}</div> This changes the indices when using `DebugElement.componentViewChildren` / `DebugElement.children`. - `@Directive.compileChildren` was removed, `ng-non-bindable` is now builtin and not a directive any more - angular no more adds the `ng-binding` class to elements with bindings - directives are now ordered as they are listed in the View.directives regarding change detection. Previously they had an undefined order. - the `Renderer` interface has new methods `createProtoView` and `registerComponentTemplate`. See `DomRenderer` for default implementations. - reprojection with `ng-content` is now all or nothing per `ng-content` element - angular2 transformer can't be used in tests that modify directive metadata. Use `angular2/src/transform/inliner_for_test` transformer instead.
This commit is contained in:
@ -17,11 +17,7 @@ import {
|
||||
ViewMetadata
|
||||
} from 'angular2/core';
|
||||
|
||||
import {CompilerCache} from 'angular2/src/core/compiler/compiler';
|
||||
import {
|
||||
ChangeDetection,
|
||||
DynamicChangeDetection
|
||||
} from 'angular2/src/core/change_detection/change_detection';
|
||||
import {ChangeDetectorGenConfig} from 'angular2/src/core/change_detection/change_detection';
|
||||
import {ViewResolver} from 'angular2/src/core/compiler/view_resolver';
|
||||
|
||||
import {getIntParameter, bindAction} from 'angular2/src/test_lib/benchmark_util';
|
||||
@ -36,7 +32,7 @@ function _createBindings(): Binding[] {
|
||||
[]),
|
||||
// Use DynamicChangeDetector as that is the only one that Dart supports as well
|
||||
// so that we can compare the numbers between JS and Dart
|
||||
bind(ChangeDetection).toClass(DynamicChangeDetection)
|
||||
bind(ChangeDetectorGenConfig).toValue(new ChangeDetectorGenConfig(false, false, false, false))
|
||||
];
|
||||
}
|
||||
|
||||
@ -97,14 +93,14 @@ class MultiplyViewResolver extends ViewResolver {
|
||||
@Component({selector: 'app'})
|
||||
@View({directives: [], template: ``})
|
||||
class CompilerAppComponent {
|
||||
constructor(private _compiler: Compiler, private _compilerCache: CompilerCache) {}
|
||||
constructor(private _compiler: Compiler) {}
|
||||
compileNoBindings() {
|
||||
this._compilerCache.clear();
|
||||
this._compiler.clearCache();
|
||||
return this._compiler.compileInHost(BenchmarkComponentNoBindings);
|
||||
}
|
||||
|
||||
compileWithBindings() {
|
||||
this._compilerCache.clear();
|
||||
this._compiler.clearCache();
|
||||
return this._compiler.compileInHost(BenchmarkComponentWithBindings);
|
||||
}
|
||||
}
|
||||
|
Reference in New Issue
Block a user