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:
Tobias Bosch
2015-10-01 10:07:49 -07:00
parent 30ca0434a2
commit 76247b7097
124 changed files with 2013 additions and 3451 deletions

View File

@ -25,7 +25,6 @@ transformers:
- web/src/naive_infinite_scroll/index.dart
- web/src/static_tree/tree_benchmark.dart
- web/src/tree/tree_benchmark.dart
generate_change_detectors: true
- $dart2js:
minify: false
commandLineOptions:

View File

@ -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);
}
}