@angular/core 13.0.0-next.7 → 13.0.0-next.8
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/bundles/core-testing.umd.js +18 -18
- package/bundles/core-testing.umd.js.map +1 -1
- package/bundles/core.umd.js +54 -53
- package/bundles/core.umd.js.map +1 -1
- package/core.d.ts +10 -9
- package/core.metadata.json +1 -1
- package/esm2015/src/i18n/locale_data_api.js +5 -4
- package/esm2015/src/i18n/tokens.js +6 -6
- package/esm2015/src/reflection/reflection_capabilities.js +3 -3
- package/esm2015/src/version.js +1 -1
- package/esm2015/testing/src/resolvers.js +1 -1
- package/fesm2015/core.js +13 -12
- package/fesm2015/core.js.map +1 -1
- package/fesm2015/testing.js +1 -1
- package/fesm2015/testing.js.map +1 -1
- package/package.json +2 -2
- package/schematics/migrations/abstract-control-parent/index.js +6 -6
- package/schematics/migrations/abstract-control-parent/util.js +6 -6
- package/schematics/migrations/activated-route-snapshot-fragment/index.js +7 -7
- package/schematics/migrations/activated-route-snapshot-fragment/util.js +4 -4
- package/schematics/migrations/can-activate-with-redirect-to/index.js +7 -7
- package/schematics/migrations/deep-shadow-piercing-selector/index.js +3 -3
- package/schematics/migrations/dynamic-queries/index.js +8 -8
- package/schematics/migrations/dynamic-queries/util.js +2 -2
- package/schematics/migrations/initial-navigation/collector.js +4 -4
- package/schematics/migrations/initial-navigation/index.js +5 -5
- package/schematics/migrations/initial-navigation/util.js +3 -3
- package/schematics/migrations/missing-injectable/definition_collector.js +5 -5
- package/schematics/migrations/missing-injectable/index.js +6 -6
- package/schematics/migrations/missing-injectable/transform.js +2 -2
- package/schematics/migrations/module-with-providers/collector.js +3 -3
- package/schematics/migrations/module-with-providers/index.js +6 -6
- package/schematics/migrations/module-with-providers/transform.js +3 -3
- package/schematics/migrations/module-with-providers/util.js +2 -2
- package/schematics/migrations/move-document/index.js +8 -8
- package/schematics/migrations/native-view-encapsulation/index.js +6 -6
- package/schematics/migrations/native-view-encapsulation/util.js +2 -2
- package/schematics/migrations/navigation-extras-omissions/index.js +7 -7
- package/schematics/migrations/navigation-extras-omissions/util.js +3 -3
- package/schematics/migrations/relative-link-resolution/collector.js +4 -4
- package/schematics/migrations/relative-link-resolution/index.js +5 -5
- package/schematics/migrations/relative-link-resolution/util.js +3 -3
- package/schematics/migrations/renderer-to-renderer2/index.js +13 -13
- package/schematics/migrations/renderer-to-renderer2/util.js +8 -8
- package/schematics/migrations/router-link-empty-expression/analyze_template.js +3 -3
- package/schematics/migrations/router-link-empty-expression/angular/html_routerlink_empty_expr_visitor.js +5 -5
- package/schematics/migrations/router-link-empty-expression/index.js +7 -7
- package/schematics/migrations/router-preserve-query-params/index.js +7 -7
- package/schematics/migrations/router-preserve-query-params/util.js +3 -3
- package/schematics/migrations/static-queries/angular/directive_inputs.js +5 -5
- package/schematics/migrations/static-queries/angular/ng_query_visitor.js +7 -7
- package/schematics/migrations/static-queries/index.js +7 -7
- package/schematics/migrations/static-queries/strategies/template_strategy/template_strategy.js +4 -4
- package/schematics/migrations/static-queries/strategies/usage_strategy/declaration_usage_visitor.js +9 -9
- package/schematics/migrations/static-queries/strategies/usage_strategy/super_class_context.js +6 -6
- package/schematics/migrations/static-queries/strategies/usage_strategy/template_usage_visitor.js +9 -9
- package/schematics/migrations/static-queries/strategies/usage_strategy/usage_strategy.js +6 -6
- package/schematics/migrations/static-queries/transform.js +2 -2
- package/schematics/migrations/template-var-assignment/analyze_template.js +3 -3
- package/schematics/migrations/template-var-assignment/angular/html_variable_assignment_visitor.js +4 -4
- package/schematics/migrations/template-var-assignment/index.js +6 -6
- package/schematics/migrations/undecorated-classes-with-decorated-fields/index.js +6 -6
- package/schematics/migrations/undecorated-classes-with-decorated-fields/transform.js +7 -7
- package/schematics/migrations/undecorated-classes-with-di/create_ngc_program.js +3 -3
- package/schematics/migrations/undecorated-classes-with-di/decorator_rewrite/decorator_rewriter.js +2 -2
- package/schematics/migrations/undecorated-classes-with-di/decorator_rewrite/import_rewrite_visitor.js +8 -8
- package/schematics/migrations/undecorated-classes-with-di/decorator_rewrite/path_format.js +2 -2
- package/schematics/migrations/undecorated-classes-with-di/decorator_rewrite/source_file_exports.js +2 -2
- package/schematics/migrations/undecorated-classes-with-di/index.js +6 -6
- package/schematics/migrations/undecorated-classes-with-di/ng_declaration_collector.js +4 -4
- package/schematics/migrations/undecorated-classes-with-di/transform.js +10 -10
- package/schematics/migrations/wait-for-async/index.js +11 -11
- package/schematics/migrations/wait-for-async/util.js +2 -2
- package/schematics/migrations/xhr-factory/index.js +2 -2
- package/schematics/utils/import_manager.js +3 -3
- package/schematics/utils/ng_component_template.js +10 -10
- package/schematics/utils/ng_decorators.js +2 -2
- package/schematics/utils/parse_html.js +2 -2
- package/schematics/utils/project_tsconfig_paths.js +3 -3
- package/schematics/utils/typescript/compiler_host.js +5 -5
- package/schematics/utils/typescript/decorators.js +2 -2
- package/schematics/utils/typescript/find_base_classes.js +2 -2
- package/src/r3_symbols.d.ts +1 -1
- package/testing/testing.d.ts +1 -1
- package/testing.d.ts +1 -1
|
@@ -30,8 +30,8 @@
|
|
|
30
30
|
!ts.isPropertyDeclaration(m) && !ts.isSetAccessor(m) && !ts.isGetAccessor(m)) {
|
|
31
31
|
return;
|
|
32
32
|
}
|
|
33
|
-
const inputDecorator = ng_decorators_1.getAngularDecorators(typeChecker, m.decorators).find(d => d.name === 'Input');
|
|
34
|
-
if (inputDecorator && property_name_1.hasPropertyNameText(m.name)) {
|
|
33
|
+
const inputDecorator = (0, ng_decorators_1.getAngularDecorators)(typeChecker, m.decorators).find(d => d.name === 'Input');
|
|
34
|
+
if (inputDecorator && (0, property_name_1.hasPropertyNameText)(m.name)) {
|
|
35
35
|
resolvedInputSetters.push(m.name.text);
|
|
36
36
|
}
|
|
37
37
|
});
|
|
@@ -53,7 +53,7 @@
|
|
|
53
53
|
if (!node.decorators || !node.decorators.length) {
|
|
54
54
|
return null;
|
|
55
55
|
}
|
|
56
|
-
const decorator = ng_decorators_1.getAngularDecorators(typeChecker, node.decorators)
|
|
56
|
+
const decorator = (0, ng_decorators_1.getAngularDecorators)(typeChecker, node.decorators)
|
|
57
57
|
.find(d => d.name === 'Directive' || d.name === 'Component');
|
|
58
58
|
// In case no directive/component decorator could be found for this class, just
|
|
59
59
|
// return null as there is no metadata where an input could be declared.
|
|
@@ -71,7 +71,7 @@
|
|
|
71
71
|
}
|
|
72
72
|
const metadata = decoratorCall.arguments[0];
|
|
73
73
|
const inputs = metadata.properties.filter(ts.isPropertyAssignment)
|
|
74
|
-
.find(p => property_name_1.getPropertyNameText(p.name) === 'inputs');
|
|
74
|
+
.find(p => (0, property_name_1.getPropertyNameText)(p.name) === 'inputs');
|
|
75
75
|
// In case there is no "inputs" property in the directive metadata,
|
|
76
76
|
// just return "null" as no inputs can be declared for this class.
|
|
77
77
|
if (!inputs || !ts.isArrayLiteralExpression(inputs.initializer)) {
|
|
@@ -81,4 +81,4 @@
|
|
|
81
81
|
.map(element => element.text.split(':')[0].trim());
|
|
82
82
|
}
|
|
83
83
|
});
|
|
84
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
84
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiZGlyZWN0aXZlX2lucHV0cy5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uLy4uLy4uLy4uLy4uL3BhY2thZ2VzL2NvcmUvc2NoZW1hdGljcy9taWdyYXRpb25zL3N0YXRpYy1xdWVyaWVzL2FuZ3VsYXIvZGlyZWN0aXZlX2lucHV0cy50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQTs7Ozs7O0dBTUc7Ozs7Ozs7Ozs7Ozs7SUFFSCxpQ0FBaUM7SUFDakMsZ0ZBQWtFO0lBQ2xFLDJGQUFpRztJQUVqRyx1RkFBdUY7SUFDdkYsU0FBZ0Isb0JBQW9CLENBQ2hDLElBQXlCLEVBQUUsV0FBMkI7UUFDeEQsTUFBTSxvQkFBb0IsR0FBYSxFQUFFLENBQUM7UUFFMUMsaUZBQWlGO1FBQ2pGLHNGQUFzRjtRQUN0RixJQUFJLENBQUMsT0FBTyxDQUFDLE9BQU8sQ0FBQyxDQUFDLENBQUMsRUFBRTtZQUN2QixJQUFJLENBQUMsQ0FBQyxDQUFDLFVBQVUsSUFBSSxDQUFDLENBQUMsQ0FBQyxVQUFVLENBQUMsTUFBTTtnQkFDckMsQ0FBQyxFQUFFLENBQUMscUJBQXFCLENBQUMsQ0FBQyxDQUFDLElBQUksQ0FBQyxFQUFFLENBQUMsYUFBYSxDQUFDLENBQUMsQ0FBQyxJQUFJLENBQUMsRUFBRSxDQUFDLGFBQWEsQ0FBQyxDQUFDLENBQUMsRUFBRTtnQkFDaEYsT0FBTzthQUNSO1lBRUQsTUFBTSxjQUFjLEdBQ2hCLElBQUEsb0NBQW9CLEVBQUMsV0FBVyxFQUFFLENBQUMsQ0FBQyxVQUFXLENBQUMsQ0FBQyxJQUFJLENBQUMsQ0FBQyxDQUFDLEVBQUUsQ0FBQyxDQUFDLENBQUMsSUFBSSxLQUFLLE9BQU8sQ0FBQyxDQUFDO1lBRW5GLElBQUksY0FBYyxJQUFJLElBQUEsbUNBQW1CLEVBQUMsQ0FBQyxDQUFDLElBQUksQ0FBQyxFQUFFO2dCQUNqRCxvQkFBb0IsQ0FBQyxJQUFJLENBQUMsQ0FBQyxDQUFDLElBQUksQ0FBQyxJQUFJLENBQUMsQ0FBQzthQUN4QztRQUNILENBQUMsQ0FBQyxDQUFDO1FBRUgscUZBQXFGO1FBQ3JGLG1GQUFtRjtRQUNuRixvRkFBb0Y7UUFDcEYsTUFBTSxjQUFjLEdBQUcseUJBQXlCLENBQUMsSUFBSSxFQUFFLFdBQVcsQ0FBQyxDQUFDO1FBRXBFLElBQUksY0FBYyxFQUFFO1lBQ2xCLG9CQUFvQixDQUFDLElBQUksQ0FBQyxHQUFHLGNBQWMsQ0FBQyxDQUFDO1NBQzlDO1FBRUQsT0FBTyxvQkFBb0IsQ0FBQztJQUM5QixDQUFDO0lBOUJELG9EQThCQztJQUVEOzs7T0FHRztJQUNILFNBQVMseUJBQXlCLENBQzlCLElBQXlCLEVBQUUsV0FBMkI7UUFDeEQsSUFBSSxDQUFDLElBQUksQ0FBQyxVQUFVLElBQUksQ0FBQyxJQUFJLENBQUMsVUFBVSxDQUFDLE1BQU0sRUFBRTtZQUMvQyxPQUFPLElBQUksQ0FBQztTQUNiO1FBRUQsTUFBTSxTQUFTLEdBQUcsSUFBQSxvQ0FBb0IsRUFBQyxXQUFXLEVBQUUsSUFBSSxDQUFDLFVBQVUsQ0FBQzthQUM3QyxJQUFJLENBQUMsQ0FBQyxDQUFDLEVBQUUsQ0FBQyxDQUFDLENBQUMsSUFBSSxLQUFLLFdBQVcsSUFBSSxDQUFDLENBQUMsSUFBSSxLQUFLLFdBQVcsQ0FBQyxDQUFDO1FBRW5GLCtFQUErRTtRQUMvRSx3RUFBd0U7UUFDeEUsSUFBSSxDQUFDLFNBQVMsRUFBRTtZQUNkLE9BQU8sSUFBSSxDQUFDO1NBQ2I7UUFFRCxNQUFNLGFBQWEsR0FBRyxTQUFTLENBQUMsSUFBSSxDQUFDLFVBQVUsQ0FBQztRQUVoRCx1RUFBdUU7UUFDdkUscUVBQXFFO1FBQ3JFLHdFQUF3RTtRQUN4RSxzREFBc0Q7UUFDdEQsSUFBSSxhQUFhLENBQUMsU0FBUyxDQUFDLE1BQU0sS0FBSyxDQUFDO1lBQ3BDLENBQUMsRUFBRSxDQUFDLHlCQUF5QixDQUFDLGFBQWEsQ0FBQyxTQUFTLENBQUMsQ0FBQyxDQUFDLENBQUMsRUFBRTtZQUM3RCxPQUFPLElBQUksQ0FBQztTQUNiO1FBRUQsTUFBTSxRQUFRLEdBQUcsYUFBYSxDQUFDLFNBQVMsQ0FBQyxDQUFDLENBQStCLENBQUM7UUFDMUUsTUFBTSxNQUFNLEdBQUcsUUFBUSxDQUFDLFVBQVUsQ0FBQyxNQUFNLENBQUMsRUFBRSxDQUFDLG9CQUFvQixDQUFDO2FBQzlDLElBQUksQ0FBQyxDQUFDLENBQUMsRUFBRSxDQUFDLElBQUEsbUNBQW1CLEVBQUMsQ0FBQyxDQUFDLElBQUksQ0FBQyxLQUFLLFFBQVEsQ0FBQyxDQUFDO1FBRXhFLG1FQUFtRTtRQUNuRSxrRUFBa0U7UUFDbEUsSUFBSSxDQUFDLE1BQU0sSUFBSSxDQUFDLEVBQUUsQ0FBQyx3QkFBd0IsQ0FBQyxNQUFNLENBQUMsV0FBVyxDQUFDLEVBQUU7WUFDL0QsT0FBTyxJQUFJLENBQUM7U0FDYjtRQUVELE9BQU8sTUFBTSxDQUFDLFdBQVcsQ0FBQyxRQUFRLENBQUMsTUFBTSxDQUFDLEVBQUUsQ0FBQyxtQkFBbUIsQ0FBQzthQUM1RCxHQUFHLENBQUMsT0FBTyxDQUFDLEVBQUUsQ0FBQyxPQUFPLENBQUMsSUFBSSxDQUFDLEtBQUssQ0FBQyxHQUFHLENBQUMsQ0FBQyxDQUFDLENBQUMsQ0FBQyxJQUFJLEVBQUUsQ0FBQyxDQUFDO0lBQ3pELENBQUMiLCJzb3VyY2VzQ29udGVudCI6WyIvKipcbiAqIEBsaWNlbnNlXG4gKiBDb3B5cmlnaHQgR29vZ2xlIExMQyBBbGwgUmlnaHRzIFJlc2VydmVkLlxuICpcbiAqIFVzZSBvZiB0aGlzIHNvdXJjZSBjb2RlIGlzIGdvdmVybmVkIGJ5IGFuIE1JVC1zdHlsZSBsaWNlbnNlIHRoYXQgY2FuIGJlXG4gKiBmb3VuZCBpbiB0aGUgTElDRU5TRSBmaWxlIGF0IGh0dHBzOi8vYW5ndWxhci5pby9saWNlbnNlXG4gKi9cblxuaW1wb3J0ICogYXMgdHMgZnJvbSAndHlwZXNjcmlwdCc7XG5pbXBvcnQge2dldEFuZ3VsYXJEZWNvcmF0b3JzfSBmcm9tICcuLi8uLi8uLi91dGlscy9uZ19kZWNvcmF0b3JzJztcbmltcG9ydCB7Z2V0UHJvcGVydHlOYW1lVGV4dCwgaGFzUHJvcGVydHlOYW1lVGV4dH0gZnJvbSAnLi4vLi4vLi4vdXRpbHMvdHlwZXNjcmlwdC9wcm9wZXJ0eV9uYW1lJztcblxuLyoqIEFuYWx5emVzIHRoZSBnaXZlbiBjbGFzcyBhbmQgcmVzb2x2ZXMgdGhlIG5hbWUgb2YgYWxsIGlucHV0cyB3aGljaCBhcmUgZGVjbGFyZWQuICovXG5leHBvcnQgZnVuY3Rpb24gZ2V0SW5wdXROYW1lc09mQ2xhc3MoXG4gICAgbm9kZTogdHMuQ2xhc3NEZWNsYXJhdGlvbiwgdHlwZUNoZWNrZXI6IHRzLlR5cGVDaGVja2VyKTogc3RyaW5nW10ge1xuICBjb25zdCByZXNvbHZlZElucHV0U2V0dGVyczogc3RyaW5nW10gPSBbXTtcblxuICAvLyBEZXRlcm1pbmVzIHRoZSBuYW1lcyBvZiBhbGwgaW5wdXRzIGRlZmluZWQgaW4gdGhlIGN1cnJlbnQgY2xhc3MgZGVjbGFyYXRpb24gYnlcbiAgLy8gY2hlY2tpbmcgd2hldGhlciBhIGdpdmVuIHByb3BlcnR5L2dldHRlci9zZXR0ZXIgaGFzIHRoZSBcIkBJbnB1dFwiIGRlY29yYXRvciBhcHBsaWVkLlxuICBub2RlLm1lbWJlcnMuZm9yRWFjaChtID0+IHtcbiAgICBpZiAoIW0uZGVjb3JhdG9ycyB8fCAhbS5kZWNvcmF0b3JzLmxlbmd0aCB8fFxuICAgICAgICAhdHMuaXNQcm9wZXJ0eURlY2xhcmF0aW9uKG0pICYmICF0cy5pc1NldEFjY2Vzc29yKG0pICYmICF0cy5pc0dldEFjY2Vzc29yKG0pKSB7XG4gICAgICByZXR1cm47XG4gICAgfVxuXG4gICAgY29uc3QgaW5wdXREZWNvcmF0b3IgPVxuICAgICAgICBnZXRBbmd1bGFyRGVjb3JhdG9ycyh0eXBlQ2hlY2tlciwgbS5kZWNvcmF0b3JzISkuZmluZChkID0+IGQubmFtZSA9PT0gJ0lucHV0Jyk7XG5cbiAgICBpZiAoaW5wdXREZWNvcmF0b3IgJiYgaGFzUHJvcGVydHlOYW1lVGV4dChtLm5hbWUpKSB7XG4gICAgICByZXNvbHZlZElucHV0U2V0dGVycy5wdXNoKG0ubmFtZS50ZXh0KTtcbiAgICB9XG4gIH0pO1xuXG4gIC8vIEJlc2lkZXMgbG9va2luZyBmb3IgaW1tZWRpYXRlIHNldHRlcnMgaW4gdGhlIGN1cnJlbnQgY2xhc3MgZGVjbGFyYXRpb24sIGRldmVsb3BlcnNcbiAgLy8gY2FuIGFsc28gZGVmaW5lIGlucHV0cyBpbiB0aGUgZGlyZWN0aXZlIG1ldGFkYXRhIHVzaW5nIHRoZSBcImlucHV0c1wiIHByb3BlcnR5LiBXZVxuICAvLyBhbHNvIG5lZWQgdG8gZGV0ZXJtaW5lIHRoZXNlIGlucHV0cyB3aGljaCBhcmUgZGVjbGFyZWQgaW4gdGhlIGRpcmVjdGl2ZSBtZXRhZGF0YS5cbiAgY29uc3QgbWV0YWRhdGFJbnB1dHMgPSBnZXRJbnB1dE5hbWVzRnJvbU1ldGFkYXRhKG5vZGUsIHR5cGVDaGVja2VyKTtcblxuICBpZiAobWV0YWRhdGFJbnB1dHMpIHtcbiAgICByZXNvbHZlZElucHV0U2V0dGVycy5wdXNoKC4uLm1ldGFkYXRhSW5wdXRzKTtcbiAgfVxuXG4gIHJldHVybiByZXNvbHZlZElucHV0U2V0dGVycztcbn1cblxuLyoqXG4gKiBEZXRlcm1pbmVzIHRoZSBuYW1lcyBvZiBhbGwgaW5wdXRzIGRlY2xhcmVkIGluIHRoZSBkaXJlY3RpdmUvY29tcG9uZW50IG1ldGFkYXRhXG4gKiBvZiB0aGUgZ2l2ZW4gY2xhc3MuXG4gKi9cbmZ1bmN0aW9uIGdldElucHV0TmFtZXNGcm9tTWV0YWRhdGEoXG4gICAgbm9kZTogdHMuQ2xhc3NEZWNsYXJhdGlvbiwgdHlwZUNoZWNrZXI6IHRzLlR5cGVDaGVja2VyKTogc3RyaW5nW118bnVsbCB7XG4gIGlmICghbm9kZS5kZWNvcmF0b3JzIHx8ICFub2RlLmRlY29yYXRvcnMubGVuZ3RoKSB7XG4gICAgcmV0dXJuIG51bGw7XG4gIH1cblxuICBjb25zdCBkZWNvcmF0b3IgPSBnZXRBbmd1bGFyRGVjb3JhdG9ycyh0eXBlQ2hlY2tlciwgbm9kZS5kZWNvcmF0b3JzKVxuICAgICAgICAgICAgICAgICAgICAgICAgLmZpbmQoZCA9PiBkLm5hbWUgPT09ICdEaXJlY3RpdmUnIHx8IGQubmFtZSA9PT0gJ0NvbXBvbmVudCcpO1xuXG4gIC8vIEluIGNhc2Ugbm8gZGlyZWN0aXZlL2NvbXBvbmVudCBkZWNvcmF0b3IgY291bGQgYmUgZm91bmQgZm9yIHRoaXMgY2xhc3MsIGp1c3RcbiAgLy8gcmV0dXJuIG51bGwgYXMgdGhlcmUgaXMgbm8gbWV0YWRhdGEgd2hlcmUgYW4gaW5wdXQgY291bGQgYmUgZGVjbGFyZWQuXG4gIGlmICghZGVjb3JhdG9yKSB7XG4gICAgcmV0dXJuIG51bGw7XG4gIH1cblxuICBjb25zdCBkZWNvcmF0b3JDYWxsID0gZGVjb3JhdG9yLm5vZGUuZXhwcmVzc2lvbjtcblxuICAvLyBJbiBjYXNlIHRoZSBkZWNvcmF0b3IgZG9lcyBkZWZpbmUgYW55IG1ldGFkYXRhLCB0aGVyZSBpcyBubyBtZXRhZGF0YVxuICAvLyB3aGVyZSBpbnB1dHMgY291bGQgYmUgZGVjbGFyZWQuIFRoaXMgaXMgYW4gZWRnZSBjYXNlIGJlY2F1c2UgdGhlcmVcbiAgLy8gYWx3YXlzIG5lZWRzIHRvIGJlIGFuIG9iamVjdCBsaXRlcmFsLCBidXQgaW4gY2FzZSB0aGVyZSBpc24ndCB3ZSBqdXN0XG4gIC8vIHdhbnQgdG8gc2tpcCB0aGUgaW52YWxpZCBkZWNvcmF0b3IgYW5kIHJldHVybiBudWxsLlxuICBpZiAoZGVjb3JhdG9yQ2FsbC5hcmd1bWVudHMubGVuZ3RoICE9PSAxIHx8XG4gICAgICAhdHMuaXNPYmplY3RMaXRlcmFsRXhwcmVzc2lvbihkZWNvcmF0b3JDYWxsLmFyZ3VtZW50c1swXSkpIHtcbiAgICByZXR1cm4gbnVsbDtcbiAgfVxuXG4gIGNvbnN0IG1ldGFkYXRhID0gZGVjb3JhdG9yQ2FsbC5hcmd1bWVudHNbMF0gYXMgdHMuT2JqZWN0TGl0ZXJhbEV4cHJlc3Npb247XG4gIGNvbnN0IGlucHV0cyA9IG1ldGFkYXRhLnByb3BlcnRpZXMuZmlsdGVyKHRzLmlzUHJvcGVydHlBc3NpZ25tZW50KVxuICAgICAgICAgICAgICAgICAgICAgLmZpbmQocCA9PiBnZXRQcm9wZXJ0eU5hbWVUZXh0KHAubmFtZSkgPT09ICdpbnB1dHMnKTtcblxuICAvLyBJbiBjYXNlIHRoZXJlIGlzIG5vIFwiaW5wdXRzXCIgcHJvcGVydHkgaW4gdGhlIGRpcmVjdGl2ZSBtZXRhZGF0YSxcbiAgLy8ganVzdCByZXR1cm4gXCJudWxsXCIgYXMgbm8gaW5wdXRzIGNhbiBiZSBkZWNsYXJlZCBmb3IgdGhpcyBjbGFzcy5cbiAgaWYgKCFpbnB1dHMgfHwgIXRzLmlzQXJyYXlMaXRlcmFsRXhwcmVzc2lvbihpbnB1dHMuaW5pdGlhbGl6ZXIpKSB7XG4gICAgcmV0dXJuIG51bGw7XG4gIH1cblxuICByZXR1cm4gaW5wdXRzLmluaXRpYWxpemVyLmVsZW1lbnRzLmZpbHRlcih0cy5pc1N0cmluZ0xpdGVyYWxMaWtlKVxuICAgICAgLm1hcChlbGVtZW50ID0+IGVsZW1lbnQudGV4dC5zcGxpdCgnOicpWzBdLnRyaW0oKSk7XG59XG4iXX0=
|
|
@@ -52,10 +52,10 @@
|
|
|
52
52
|
ts.forEachChild(node, n => this.visitNode(n));
|
|
53
53
|
}
|
|
54
54
|
visitPropertyDeclaration(node) {
|
|
55
|
-
this._recordQueryDeclaration(node, node, property_name_1.getPropertyNameText(node.name));
|
|
55
|
+
this._recordQueryDeclaration(node, node, (0, property_name_1.getPropertyNameText)(node.name));
|
|
56
56
|
}
|
|
57
57
|
visitAccessorDeclaration(node) {
|
|
58
|
-
this._recordQueryDeclaration(node, null, property_name_1.getPropertyNameText(node.name));
|
|
58
|
+
this._recordQueryDeclaration(node, null, (0, property_name_1.getPropertyNameText)(node.name));
|
|
59
59
|
}
|
|
60
60
|
visitClassDeclaration(node) {
|
|
61
61
|
this._recordClassInputSetters(node);
|
|
@@ -65,13 +65,13 @@
|
|
|
65
65
|
if (!node.decorators || !node.decorators.length) {
|
|
66
66
|
return;
|
|
67
67
|
}
|
|
68
|
-
const ngDecorators = ng_decorators_1.getAngularDecorators(this.typeChecker, node.decorators);
|
|
68
|
+
const ngDecorators = (0, ng_decorators_1.getAngularDecorators)(this.typeChecker, node.decorators);
|
|
69
69
|
const queryDecorator = ngDecorators.find(({ name }) => name === 'ViewChild' || name === 'ContentChild');
|
|
70
70
|
// Ensure that the current property declaration is defining a query.
|
|
71
71
|
if (!queryDecorator) {
|
|
72
72
|
return;
|
|
73
73
|
}
|
|
74
|
-
const queryContainer = class_declaration_1.findParentClassDeclaration(node);
|
|
74
|
+
const queryContainer = (0, class_declaration_1.findParentClassDeclaration)(node);
|
|
75
75
|
// If the query is not located within a class declaration, skip this node.
|
|
76
76
|
if (!queryContainer) {
|
|
77
77
|
return;
|
|
@@ -88,7 +88,7 @@
|
|
|
88
88
|
}));
|
|
89
89
|
}
|
|
90
90
|
_recordClassInputSetters(node) {
|
|
91
|
-
const resolvedInputNames = directive_inputs_1.getInputNamesOfClass(node, this.typeChecker);
|
|
91
|
+
const resolvedInputNames = (0, directive_inputs_1.getInputNamesOfClass)(node, this.typeChecker);
|
|
92
92
|
if (resolvedInputNames) {
|
|
93
93
|
const classMetadata = this._getClassMetadata(node);
|
|
94
94
|
classMetadata.ngInputNames = resolvedInputNames;
|
|
@@ -96,7 +96,7 @@
|
|
|
96
96
|
}
|
|
97
97
|
}
|
|
98
98
|
_recordClassInheritances(node) {
|
|
99
|
-
const baseTypes = class_declaration_1.getBaseTypeIdentifiers(node);
|
|
99
|
+
const baseTypes = (0, class_declaration_1.getBaseTypeIdentifiers)(node);
|
|
100
100
|
if (!baseTypes || baseTypes.length !== 1) {
|
|
101
101
|
return;
|
|
102
102
|
}
|
|
@@ -124,4 +124,4 @@
|
|
|
124
124
|
}
|
|
125
125
|
exports.NgQueryResolveVisitor = NgQueryResolveVisitor;
|
|
126
126
|
});
|
|
127
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"ng_query_visitor.js","sourceRoot":"","sources":["../../../../../../../../../packages/core/schematics/migrations/static-queries/angular/ng_query_visitor.ts"],"names":[],"mappings":"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","sourcesContent":["/**\n * @license\n * Copyright Google LLC All Rights Reserved.\n *\n * Use of this source code is governed by an MIT-style license that can be\n * found in the LICENSE file at https://angular.io/license\n */\n\nimport * as ts from 'typescript';\n\nimport {ResolvedTemplate} from '../../../utils/ng_component_template';\nimport {getAngularDecorators} from '../../../utils/ng_decorators';\nimport {findParentClassDeclaration, getBaseTypeIdentifiers} from '../../../utils/typescript/class_declaration';\nimport {getPropertyNameText} from '../../../utils/typescript/property_name';\n\nimport {getInputNamesOfClass} from './directive_inputs';\nimport {NgQueryDefinition, QueryType} from './query-definition';\n\n\n/** Resolved metadata of a given class. */\nexport interface ClassMetadata {\n  /** List of class declarations that derive from the given class. */\n  derivedClasses: ts.ClassDeclaration[];\n  /** Super class of the given class. */\n  superClass: ts.ClassDeclaration|null;\n  /** List of property names that declare an Angular input within the given class. */\n  ngInputNames: string[];\n  /** Component template that belongs to that class if present. */\n  template?: ResolvedTemplate;\n}\n\n/** Type that describes a map which can be used to get a class declaration's metadata. */\nexport type ClassMetadataMap = Map<ts.ClassDeclaration, ClassMetadata>;\n\n/**\n * Visitor that can be used to determine Angular queries within given TypeScript nodes.\n * Besides resolving queries, the visitor also records class relations and searches for\n * Angular input setters which can be used to analyze the timing usage of a given query.\n */\nexport class NgQueryResolveVisitor {\n  /** Resolved Angular query definitions. */\n  resolvedQueries = new Map<ts.SourceFile, NgQueryDefinition[]>();\n\n  /** Maps a class declaration to its class metadata. */\n  classMetadata: ClassMetadataMap = new Map();\n\n  constructor(public typeChecker: ts.TypeChecker) {}\n\n  visitNode(node: ts.Node) {\n    switch (node.kind) {\n      case ts.SyntaxKind.PropertyDeclaration:\n        this.visitPropertyDeclaration(node as ts.PropertyDeclaration);\n        break;\n      case ts.SyntaxKind.ClassDeclaration:\n        this.visitClassDeclaration(node as ts.ClassDeclaration);\n        break;\n      case ts.SyntaxKind.GetAccessor:\n      case ts.SyntaxKind.SetAccessor:\n        this.visitAccessorDeclaration(node as ts.AccessorDeclaration);\n        break;\n    }\n\n    ts.forEachChild(node, n => this.visitNode(n));\n  }\n\n  private visitPropertyDeclaration(node: ts.PropertyDeclaration) {\n    this._recordQueryDeclaration(node, node, getPropertyNameText(node.name));\n  }\n\n  private visitAccessorDeclaration(node: ts.AccessorDeclaration) {\n    this._recordQueryDeclaration(node, null, getPropertyNameText(node.name));\n  }\n\n  private visitClassDeclaration(node: ts.ClassDeclaration) {\n    this._recordClassInputSetters(node);\n    this._recordClassInheritances(node);\n  }\n\n  private _recordQueryDeclaration(\n      node: ts.Node, property: ts.PropertyDeclaration|null, queryName: string|null) {\n    if (!node.decorators || !node.decorators.length) {\n      return;\n    }\n\n    const ngDecorators = getAngularDecorators(this.typeChecker, node.decorators);\n    const queryDecorator =\n        ngDecorators.find(({name}) => name === 'ViewChild' || name === 'ContentChild');\n\n    // Ensure that the current property declaration is defining a query.\n    if (!queryDecorator) {\n      return;\n    }\n\n    const queryContainer = findParentClassDeclaration(node);\n\n    // If the query is not located within a class declaration, skip this node.\n    if (!queryContainer) {\n      return;\n    }\n\n    const sourceFile = node.getSourceFile();\n    const newQueries = this.resolvedQueries.get(sourceFile) || [];\n\n    this.resolvedQueries.set(sourceFile, newQueries.concat({\n      name: queryName,\n      type: queryDecorator.name === 'ViewChild' ? QueryType.ViewChild : QueryType.ContentChild,\n      node,\n      property,\n      decorator: queryDecorator,\n      container: queryContainer,\n    }));\n  }\n\n  private _recordClassInputSetters(node: ts.ClassDeclaration) {\n    const resolvedInputNames = getInputNamesOfClass(node, this.typeChecker);\n\n    if (resolvedInputNames) {\n      const classMetadata = this._getClassMetadata(node);\n\n      classMetadata.ngInputNames = resolvedInputNames;\n      this.classMetadata.set(node, classMetadata);\n    }\n  }\n\n  private _recordClassInheritances(node: ts.ClassDeclaration) {\n    const baseTypes = getBaseTypeIdentifiers(node);\n\n    if (!baseTypes || baseTypes.length !== 1) {\n      return;\n    }\n\n    const superClass = baseTypes[0];\n    const baseClassMetadata = this._getClassMetadata(node);\n\n    // We need to resolve the value declaration through the resolved type as the base\n    // class could be declared in different source files and the local symbol won't\n    // contain a value declaration as the value is not declared locally.\n    const symbol = this.typeChecker.getTypeAtLocation(superClass).getSymbol();\n\n    if (symbol && symbol.valueDeclaration && ts.isClassDeclaration(symbol.valueDeclaration)) {\n      const extendedClass = symbol.valueDeclaration;\n      const classMetadataExtended = this._getClassMetadata(extendedClass);\n\n      // Record all classes that derive from the given class. This makes it easy to\n      // determine all classes that could potentially use inherited queries statically.\n      classMetadataExtended.derivedClasses.push(node);\n      this.classMetadata.set(extendedClass, classMetadataExtended);\n\n      // Record the super class of the current class.\n      baseClassMetadata.superClass = extendedClass;\n      this.classMetadata.set(node, baseClassMetadata);\n    }\n  }\n\n  private _getClassMetadata(node: ts.ClassDeclaration): ClassMetadata {\n    return this.classMetadata.get(node) || {derivedClasses: [], superClass: null, ngInputNames: []};\n  }\n}\n"]}
|
|
127
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"ng_query_visitor.js","sourceRoot":"","sources":["../../../../../../../../../packages/core/schematics/migrations/static-queries/angular/ng_query_visitor.ts"],"names":[],"mappings":"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","sourcesContent":["/**\n * @license\n * Copyright Google LLC All Rights Reserved.\n *\n * Use of this source code is governed by an MIT-style license that can be\n * found in the LICENSE file at https://angular.io/license\n */\n\nimport * as ts from 'typescript';\n\nimport {ResolvedTemplate} from '../../../utils/ng_component_template';\nimport {getAngularDecorators} from '../../../utils/ng_decorators';\nimport {findParentClassDeclaration, getBaseTypeIdentifiers} from '../../../utils/typescript/class_declaration';\nimport {getPropertyNameText} from '../../../utils/typescript/property_name';\n\nimport {getInputNamesOfClass} from './directive_inputs';\nimport {NgQueryDefinition, QueryType} from './query-definition';\n\n\n/** Resolved metadata of a given class. */\nexport interface ClassMetadata {\n  /** List of class declarations that derive from the given class. */\n  derivedClasses: ts.ClassDeclaration[];\n  /** Super class of the given class. */\n  superClass: ts.ClassDeclaration|null;\n  /** List of property names that declare an Angular input within the given class. */\n  ngInputNames: string[];\n  /** Component template that belongs to that class if present. */\n  template?: ResolvedTemplate;\n}\n\n/** Type that describes a map which can be used to get a class declaration's metadata. */\nexport type ClassMetadataMap = Map<ts.ClassDeclaration, ClassMetadata>;\n\n/**\n * Visitor that can be used to determine Angular queries within given TypeScript nodes.\n * Besides resolving queries, the visitor also records class relations and searches for\n * Angular input setters which can be used to analyze the timing usage of a given query.\n */\nexport class NgQueryResolveVisitor {\n  /** Resolved Angular query definitions. */\n  resolvedQueries = new Map<ts.SourceFile, NgQueryDefinition[]>();\n\n  /** Maps a class declaration to its class metadata. */\n  classMetadata: ClassMetadataMap = new Map();\n\n  constructor(public typeChecker: ts.TypeChecker) {}\n\n  visitNode(node: ts.Node) {\n    switch (node.kind) {\n      case ts.SyntaxKind.PropertyDeclaration:\n        this.visitPropertyDeclaration(node as ts.PropertyDeclaration);\n        break;\n      case ts.SyntaxKind.ClassDeclaration:\n        this.visitClassDeclaration(node as ts.ClassDeclaration);\n        break;\n      case ts.SyntaxKind.GetAccessor:\n      case ts.SyntaxKind.SetAccessor:\n        this.visitAccessorDeclaration(node as ts.AccessorDeclaration);\n        break;\n    }\n\n    ts.forEachChild(node, n => this.visitNode(n));\n  }\n\n  private visitPropertyDeclaration(node: ts.PropertyDeclaration) {\n    this._recordQueryDeclaration(node, node, getPropertyNameText(node.name));\n  }\n\n  private visitAccessorDeclaration(node: ts.AccessorDeclaration) {\n    this._recordQueryDeclaration(node, null, getPropertyNameText(node.name));\n  }\n\n  private visitClassDeclaration(node: ts.ClassDeclaration) {\n    this._recordClassInputSetters(node);\n    this._recordClassInheritances(node);\n  }\n\n  private _recordQueryDeclaration(\n      node: ts.Node, property: ts.PropertyDeclaration|null, queryName: string|null) {\n    if (!node.decorators || !node.decorators.length) {\n      return;\n    }\n\n    const ngDecorators = getAngularDecorators(this.typeChecker, node.decorators);\n    const queryDecorator =\n        ngDecorators.find(({name}) => name === 'ViewChild' || name === 'ContentChild');\n\n    // Ensure that the current property declaration is defining a query.\n    if (!queryDecorator) {\n      return;\n    }\n\n    const queryContainer = findParentClassDeclaration(node);\n\n    // If the query is not located within a class declaration, skip this node.\n    if (!queryContainer) {\n      return;\n    }\n\n    const sourceFile = node.getSourceFile();\n    const newQueries = this.resolvedQueries.get(sourceFile) || [];\n\n    this.resolvedQueries.set(sourceFile, newQueries.concat({\n      name: queryName,\n      type: queryDecorator.name === 'ViewChild' ? QueryType.ViewChild : QueryType.ContentChild,\n      node,\n      property,\n      decorator: queryDecorator,\n      container: queryContainer,\n    }));\n  }\n\n  private _recordClassInputSetters(node: ts.ClassDeclaration) {\n    const resolvedInputNames = getInputNamesOfClass(node, this.typeChecker);\n\n    if (resolvedInputNames) {\n      const classMetadata = this._getClassMetadata(node);\n\n      classMetadata.ngInputNames = resolvedInputNames;\n      this.classMetadata.set(node, classMetadata);\n    }\n  }\n\n  private _recordClassInheritances(node: ts.ClassDeclaration) {\n    const baseTypes = getBaseTypeIdentifiers(node);\n\n    if (!baseTypes || baseTypes.length !== 1) {\n      return;\n    }\n\n    const superClass = baseTypes[0];\n    const baseClassMetadata = this._getClassMetadata(node);\n\n    // We need to resolve the value declaration through the resolved type as the base\n    // class could be declared in different source files and the local symbol won't\n    // contain a value declaration as the value is not declared locally.\n    const symbol = this.typeChecker.getTypeAtLocation(superClass).getSymbol();\n\n    if (symbol && symbol.valueDeclaration && ts.isClassDeclaration(symbol.valueDeclaration)) {\n      const extendedClass = symbol.valueDeclaration;\n      const classMetadataExtended = this._getClassMetadata(extendedClass);\n\n      // Record all classes that derive from the given class. This makes it easy to\n      // determine all classes that could potentially use inherited queries statically.\n      classMetadataExtended.derivedClasses.push(node);\n      this.classMetadata.set(extendedClass, classMetadataExtended);\n\n      // Record the super class of the current class.\n      baseClassMetadata.superClass = extendedClass;\n      this.classMetadata.set(node, baseClassMetadata);\n    }\n  }\n\n  private _getClassMetadata(node: ts.ClassDeclaration): ClassMetadata {\n    return this.classMetadata.get(node) || {derivedClasses: [], superClass: null, ngInputNames: []};\n  }\n}\n"]}
|
|
@@ -50,7 +50,7 @@ var __awaiter = (this && this.__awaiter) || function (thisArg, _arguments, P, ge
|
|
|
50
50
|
/** Runs the V8 migration static-query migration for all determined TypeScript projects. */
|
|
51
51
|
function runMigration(tree, context) {
|
|
52
52
|
return __awaiter(this, void 0, void 0, function* () {
|
|
53
|
-
const { buildPaths, testPaths } = yield project_tsconfig_paths_1.getProjectTsConfigPaths(tree);
|
|
53
|
+
const { buildPaths, testPaths } = yield (0, project_tsconfig_paths_1.getProjectTsConfigPaths)(tree);
|
|
54
54
|
const basePath = process.cwd();
|
|
55
55
|
const logger = context.logger;
|
|
56
56
|
if (!buildPaths.length && !testPaths.length) {
|
|
@@ -97,7 +97,7 @@ var __awaiter = (this && this.__awaiter) || function (thisArg, _arguments, P, ge
|
|
|
97
97
|
* migrated. In case there are no queries that can be migrated, null is returned.
|
|
98
98
|
*/
|
|
99
99
|
function analyzeProject(tree, tsconfigPath, basePath, analyzedFiles, logger) {
|
|
100
|
-
const { program, host } = compiler_host_1.createMigrationProgram(tree, tsconfigPath, basePath);
|
|
100
|
+
const { program, host } = (0, compiler_host_1.createMigrationProgram)(tree, tsconfigPath, basePath);
|
|
101
101
|
const syntacticDiagnostics = program.getSyntacticDiagnostics();
|
|
102
102
|
// Syntactic TypeScript errors can throw off the query analysis and therefore we want
|
|
103
103
|
// to notify the developer that we couldn't analyze parts of the project. Developers
|
|
@@ -109,12 +109,12 @@ var __awaiter = (this && this.__awaiter) || function (thisArg, _arguments, P, ge
|
|
|
109
109
|
logger.info('Migration can be rerun with: "ng update @angular/core --from 7 --to 8 --migrate-only"\n');
|
|
110
110
|
}
|
|
111
111
|
const typeChecker = program.getTypeChecker();
|
|
112
|
-
const sourceFiles = program.getSourceFiles().filter(sourceFile => compiler_host_1.canMigrateFile(basePath, sourceFile, program));
|
|
112
|
+
const sourceFiles = program.getSourceFiles().filter(sourceFile => (0, compiler_host_1.canMigrateFile)(basePath, sourceFile, program));
|
|
113
113
|
const queryVisitor = new ng_query_visitor_1.NgQueryResolveVisitor(typeChecker);
|
|
114
114
|
// Analyze all project source-files and collect all queries that
|
|
115
115
|
// need to be migrated.
|
|
116
116
|
sourceFiles.forEach(sourceFile => {
|
|
117
|
-
const relativePath = path_1.relative(basePath, sourceFile.fileName);
|
|
117
|
+
const relativePath = (0, path_1.relative)(basePath, sourceFile.fileName);
|
|
118
118
|
// Only look for queries within the current source files if the
|
|
119
119
|
// file has not been analyzed before.
|
|
120
120
|
if (!analyzedFiles.has(relativePath)) {
|
|
@@ -189,14 +189,14 @@ var __awaiter = (this && this.__awaiter) || function (thisArg, _arguments, P, ge
|
|
|
189
189
|
// within a source file within the same recorder in order to not throw off
|
|
190
190
|
// the TypeScript node offsets.
|
|
191
191
|
resolvedQueries.forEach((queries, sourceFile) => {
|
|
192
|
-
const relativePath = path_1.relative(basePath, sourceFile.fileName);
|
|
192
|
+
const relativePath = (0, path_1.relative)(basePath, sourceFile.fileName);
|
|
193
193
|
const update = tree.beginUpdate(relativePath);
|
|
194
194
|
// Compute the query timing for all resolved queries and update the
|
|
195
195
|
// query definitions to explicitly set the determined query timing.
|
|
196
196
|
queries.forEach(q => {
|
|
197
197
|
const queryExpr = q.decorator.node.expression;
|
|
198
198
|
const { timing, message } = strategy.detectTiming(q);
|
|
199
|
-
const result = transform_1.getTransformedQueryCallExpr(q, timing, !!message);
|
|
199
|
+
const result = (0, transform_1.getTransformedQueryCallExpr)(q, timing, !!message);
|
|
200
200
|
if (!result) {
|
|
201
201
|
return;
|
|
202
202
|
}
|
|
@@ -216,4 +216,4 @@ var __awaiter = (this && this.__awaiter) || function (thisArg, _arguments, P, ge
|
|
|
216
216
|
});
|
|
217
217
|
}
|
|
218
218
|
});
|
|
219
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"index.js","sourceRoot":"","sources":["../../../../../../../../packages/core/schematics/migrations/static-queries/index.ts"],"names":[],"mappings":"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","sourcesContent":["/**\n * @license\n * Copyright Google LLC All Rights Reserved.\n *\n * Use of this source code is governed by an MIT-style license that can be\n * found in the LICENSE file at https://angular.io/license\n */\n\nimport {logging} from '@angular-devkit/core';\nimport {Rule, SchematicContext, SchematicsException, Tree} from '@angular-devkit/schematics';\nimport {relative} from 'path';\nimport * as ts from 'typescript';\n\nimport {NgComponentTemplateVisitor} from '../../utils/ng_component_template';\nimport {getProjectTsConfigPaths} from '../../utils/project_tsconfig_paths';\nimport {canMigrateFile, createMigrationProgram} from '../../utils/typescript/compiler_host';\n\nimport {NgQueryResolveVisitor} from './angular/ng_query_visitor';\nimport {QueryTemplateStrategy} from './strategies/template_strategy/template_strategy';\nimport {QueryTestStrategy} from './strategies/test_strategy/test_strategy';\nimport {TimingStrategy} from './strategies/timing-strategy';\nimport {QueryUsageStrategy} from './strategies/usage_strategy/usage_strategy';\nimport {getTransformedQueryCallExpr} from './transform';\n\nenum SELECTED_STRATEGY {\n  TEMPLATE,\n  USAGE,\n  TESTS,\n}\n\ninterface AnalyzedProject {\n  program: ts.Program;\n  host: ts.CompilerHost;\n  queryVisitor: NgQueryResolveVisitor;\n  sourceFiles: ts.SourceFile[];\n  basePath: string;\n  typeChecker: ts.TypeChecker;\n  tsconfigPath: string;\n}\n\n/** Entry point for the V8 static-query migration. */\nexport default function(): Rule {\n  return runMigration;\n}\n\n/** Runs the V8 migration static-query migration for all determined TypeScript projects. */\nasync function runMigration(tree: Tree, context: SchematicContext) {\n  const {buildPaths, testPaths} = await getProjectTsConfigPaths(tree);\n  const basePath = process.cwd();\n  const logger = context.logger;\n\n  if (!buildPaths.length && !testPaths.length) {\n    throw new SchematicsException(\n        'Could not find any tsconfig file. Cannot migrate queries ' +\n        'to add static flag.');\n  }\n\n  const analyzedFiles = new Set<string>();\n  const buildProjects = new Set<AnalyzedProject>();\n  const failures = [];\n  const strategy = process.env['NG_STATIC_QUERY_USAGE_STRATEGY'] === 'true' ?\n      SELECTED_STRATEGY.USAGE :\n      SELECTED_STRATEGY.TEMPLATE;\n\n  for (const tsconfigPath of buildPaths) {\n    const project = analyzeProject(tree, tsconfigPath, basePath, analyzedFiles, logger);\n    if (project) {\n      buildProjects.add(project);\n    }\n  }\n\n  if (buildProjects.size) {\n    for (let project of Array.from(buildProjects.values())) {\n      failures.push(...await runStaticQueryMigration(tree, project, strategy, logger));\n    }\n  }\n\n  // For the \"test\" tsconfig projects we always want to use the test strategy as\n  // we can't detect the proper timing within spec files.\n  for (const tsconfigPath of testPaths) {\n    const project = await analyzeProject(tree, tsconfigPath, basePath, analyzedFiles, logger);\n    if (project) {\n      failures.push(\n          ...await runStaticQueryMigration(tree, project, SELECTED_STRATEGY.TESTS, logger));\n    }\n  }\n\n  if (failures.length) {\n    logger.info('');\n    logger.info('Some queries could not be migrated automatically. Please go');\n    logger.info('through these manually and apply the appropriate timing.');\n    logger.info('For more info on how to choose a flag, please see: ');\n    logger.info('https://v8.angular.io/guide/static-query-migration');\n    failures.forEach(failure => logger.warn(`⮑   ${failure}`));\n  }\n}\n\n/**\n * Analyzes the given TypeScript project by looking for queries that need to be\n * migrated. In case there are no queries that can be migrated, null is returned.\n */\nfunction analyzeProject(\n    tree: Tree, tsconfigPath: string, basePath: string, analyzedFiles: Set<string>,\n    logger: logging.LoggerApi): AnalyzedProject|null {\n  const {program, host} = createMigrationProgram(tree, tsconfigPath, basePath);\n  const syntacticDiagnostics = program.getSyntacticDiagnostics();\n\n  // Syntactic TypeScript errors can throw off the query analysis and therefore we want\n  // to notify the developer that we couldn't analyze parts of the project. Developers\n  // can just re-run the migration after fixing these failures.\n  if (syntacticDiagnostics.length) {\n    logger.warn(\n        `\\nTypeScript project \"${tsconfigPath}\" has syntactical errors which could cause ` +\n        `an incomplete migration. Please fix the following failures and rerun the migration:`);\n    logger.error(ts.formatDiagnostics(syntacticDiagnostics, host));\n    logger.info(\n        'Migration can be rerun with: \"ng update @angular/core --from 7 --to 8 --migrate-only\"\\n');\n  }\n\n  const typeChecker = program.getTypeChecker();\n  const sourceFiles =\n      program.getSourceFiles().filter(sourceFile => canMigrateFile(basePath, sourceFile, program));\n  const queryVisitor = new NgQueryResolveVisitor(typeChecker);\n\n  // Analyze all project source-files and collect all queries that\n  // need to be migrated.\n  sourceFiles.forEach(sourceFile => {\n    const relativePath = relative(basePath, sourceFile.fileName);\n\n    // Only look for queries within the current source files if the\n    // file has not been analyzed before.\n    if (!analyzedFiles.has(relativePath)) {\n      analyzedFiles.add(relativePath);\n      queryVisitor.visitNode(sourceFile);\n    }\n  });\n\n  if (queryVisitor.resolvedQueries.size === 0) {\n    return null;\n  }\n\n  return {program, host, tsconfigPath, typeChecker, basePath, queryVisitor, sourceFiles};\n}\n\n/**\n * Runs the static query migration for the given project. The schematic analyzes all\n * queries within the project and sets up the query timing based on the current usage\n * of the query property. e.g. a view query that is not used in any lifecycle hook does\n * not need to be static and can be set up with \"static: false\".\n */\nasync function runStaticQueryMigration(\n    tree: Tree, project: AnalyzedProject, selectedStrategy: SELECTED_STRATEGY,\n    logger: logging.LoggerApi): Promise<string[]> {\n  const {sourceFiles, typeChecker, host, queryVisitor, tsconfigPath, basePath} = project;\n  const printer = ts.createPrinter();\n  const failureMessages: string[] = [];\n  const templateVisitor = new NgComponentTemplateVisitor(typeChecker);\n\n  // If the \"usage\" strategy is selected, we also need to add the query visitor\n  // to the analysis visitors so that query usage in templates can be also checked.\n  if (selectedStrategy === SELECTED_STRATEGY.USAGE) {\n    sourceFiles.forEach(s => templateVisitor.visitNode(s));\n  }\n\n  const {resolvedQueries, classMetadata} = queryVisitor;\n  const {resolvedTemplates} = templateVisitor;\n\n  if (selectedStrategy === SELECTED_STRATEGY.USAGE) {\n    // Add all resolved templates to the class metadata if the usage strategy is used. This\n    // is necessary in order to be able to check component templates for static query usage.\n    resolvedTemplates.forEach(template => {\n      if (classMetadata.has(template.container)) {\n        classMetadata.get(template.container)!.template = template;\n      }\n    });\n  }\n\n  let strategy: TimingStrategy;\n  if (selectedStrategy === SELECTED_STRATEGY.USAGE) {\n    strategy = new QueryUsageStrategy(classMetadata, typeChecker);\n  } else if (selectedStrategy === SELECTED_STRATEGY.TESTS) {\n    strategy = new QueryTestStrategy();\n  } else {\n    strategy = new QueryTemplateStrategy(tsconfigPath, classMetadata, host);\n  }\n\n  try {\n    strategy.setup();\n  } catch (e) {\n    if (selectedStrategy === SELECTED_STRATEGY.TEMPLATE) {\n      logger.warn(\n          `\\nThe template migration strategy uses the Angular compiler ` +\n          `internally and therefore projects that no longer build successfully after ` +\n          `the update cannot use the template migration strategy. Please ensure ` +\n          `there are no AOT compilation errors.\\n`);\n    }\n    // In case the strategy could not be set up properly, we just exit the\n    // migration. We don't want to throw an exception as this could mean\n    // that other migrations are interrupted.\n    logger.warn(\n        `Could not setup migration strategy for \"${project.tsconfigPath}\". The ` +\n        `following error has been reported:\\n`);\n    logger.error(`${e.toString()}\\n`);\n    logger.info(\n        'Migration can be rerun with: \"ng update @angular/core --from 7 --to 8 --migrate-only\"\\n');\n    return [];\n  }\n\n  // Walk through all source files that contain resolved queries and update\n  // the source files if needed. Note that we need to update multiple queries\n  // within a source file within the same recorder in order to not throw off\n  // the TypeScript node offsets.\n  resolvedQueries.forEach((queries, sourceFile) => {\n    const relativePath = relative(basePath, sourceFile.fileName);\n    const update = tree.beginUpdate(relativePath);\n\n    // Compute the query timing for all resolved queries and update the\n    // query definitions to explicitly set the determined query timing.\n    queries.forEach(q => {\n      const queryExpr = q.decorator.node.expression;\n      const {timing, message} = strategy.detectTiming(q);\n      const result = getTransformedQueryCallExpr(q, timing, !!message);\n\n      if (!result) {\n        return;\n      }\n\n      const newText = printer.printNode(ts.EmitHint.Unspecified, result.node, sourceFile);\n\n      // Replace the existing query decorator call expression with the updated\n      // call expression node.\n      update.remove(queryExpr.getStart(), queryExpr.getWidth());\n      update.insertRight(queryExpr.getStart(), newText);\n\n      if (result.failureMessage || message) {\n        const {line, character} =\n            ts.getLineAndCharacterOfPosition(sourceFile, q.decorator.node.getStart());\n        failureMessages.push(\n            `${relativePath}@${line + 1}:${character + 1}: ${result.failureMessage || message}`);\n      }\n    });\n\n    tree.commitUpdate(update);\n  });\n\n  return failureMessages;\n}\n"]}
|
|
219
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"index.js","sourceRoot":"","sources":["../../../../../../../../packages/core/schematics/migrations/static-queries/index.ts"],"names":[],"mappings":"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","sourcesContent":["/**\n * @license\n * Copyright Google LLC All Rights Reserved.\n *\n * Use of this source code is governed by an MIT-style license that can be\n * found in the LICENSE file at https://angular.io/license\n */\n\nimport {logging} from '@angular-devkit/core';\nimport {Rule, SchematicContext, SchematicsException, Tree} from '@angular-devkit/schematics';\nimport {relative} from 'path';\nimport * as ts from 'typescript';\n\nimport {NgComponentTemplateVisitor} from '../../utils/ng_component_template';\nimport {getProjectTsConfigPaths} from '../../utils/project_tsconfig_paths';\nimport {canMigrateFile, createMigrationProgram} from '../../utils/typescript/compiler_host';\n\nimport {NgQueryResolveVisitor} from './angular/ng_query_visitor';\nimport {QueryTemplateStrategy} from './strategies/template_strategy/template_strategy';\nimport {QueryTestStrategy} from './strategies/test_strategy/test_strategy';\nimport {TimingStrategy} from './strategies/timing-strategy';\nimport {QueryUsageStrategy} from './strategies/usage_strategy/usage_strategy';\nimport {getTransformedQueryCallExpr} from './transform';\n\nenum SELECTED_STRATEGY {\n  TEMPLATE,\n  USAGE,\n  TESTS,\n}\n\ninterface AnalyzedProject {\n  program: ts.Program;\n  host: ts.CompilerHost;\n  queryVisitor: NgQueryResolveVisitor;\n  sourceFiles: ts.SourceFile[];\n  basePath: string;\n  typeChecker: ts.TypeChecker;\n  tsconfigPath: string;\n}\n\n/** Entry point for the V8 static-query migration. */\nexport default function(): Rule {\n  return runMigration;\n}\n\n/** Runs the V8 migration static-query migration for all determined TypeScript projects. */\nasync function runMigration(tree: Tree, context: SchematicContext) {\n  const {buildPaths, testPaths} = await getProjectTsConfigPaths(tree);\n  const basePath = process.cwd();\n  const logger = context.logger;\n\n  if (!buildPaths.length && !testPaths.length) {\n    throw new SchematicsException(\n        'Could not find any tsconfig file. Cannot migrate queries ' +\n        'to add static flag.');\n  }\n\n  const analyzedFiles = new Set<string>();\n  const buildProjects = new Set<AnalyzedProject>();\n  const failures = [];\n  const strategy = process.env['NG_STATIC_QUERY_USAGE_STRATEGY'] === 'true' ?\n      SELECTED_STRATEGY.USAGE :\n      SELECTED_STRATEGY.TEMPLATE;\n\n  for (const tsconfigPath of buildPaths) {\n    const project = analyzeProject(tree, tsconfigPath, basePath, analyzedFiles, logger);\n    if (project) {\n      buildProjects.add(project);\n    }\n  }\n\n  if (buildProjects.size) {\n    for (let project of Array.from(buildProjects.values())) {\n      failures.push(...await runStaticQueryMigration(tree, project, strategy, logger));\n    }\n  }\n\n  // For the \"test\" tsconfig projects we always want to use the test strategy as\n  // we can't detect the proper timing within spec files.\n  for (const tsconfigPath of testPaths) {\n    const project = await analyzeProject(tree, tsconfigPath, basePath, analyzedFiles, logger);\n    if (project) {\n      failures.push(\n          ...await runStaticQueryMigration(tree, project, SELECTED_STRATEGY.TESTS, logger));\n    }\n  }\n\n  if (failures.length) {\n    logger.info('');\n    logger.info('Some queries could not be migrated automatically. Please go');\n    logger.info('through these manually and apply the appropriate timing.');\n    logger.info('For more info on how to choose a flag, please see: ');\n    logger.info('https://v8.angular.io/guide/static-query-migration');\n    failures.forEach(failure => logger.warn(`⮑   ${failure}`));\n  }\n}\n\n/**\n * Analyzes the given TypeScript project by looking for queries that need to be\n * migrated. In case there are no queries that can be migrated, null is returned.\n */\nfunction analyzeProject(\n    tree: Tree, tsconfigPath: string, basePath: string, analyzedFiles: Set<string>,\n    logger: logging.LoggerApi): AnalyzedProject|null {\n  const {program, host} = createMigrationProgram(tree, tsconfigPath, basePath);\n  const syntacticDiagnostics = program.getSyntacticDiagnostics();\n\n  // Syntactic TypeScript errors can throw off the query analysis and therefore we want\n  // to notify the developer that we couldn't analyze parts of the project. Developers\n  // can just re-run the migration after fixing these failures.\n  if (syntacticDiagnostics.length) {\n    logger.warn(\n        `\\nTypeScript project \"${tsconfigPath}\" has syntactical errors which could cause ` +\n        `an incomplete migration. Please fix the following failures and rerun the migration:`);\n    logger.error(ts.formatDiagnostics(syntacticDiagnostics, host));\n    logger.info(\n        'Migration can be rerun with: \"ng update @angular/core --from 7 --to 8 --migrate-only\"\\n');\n  }\n\n  const typeChecker = program.getTypeChecker();\n  const sourceFiles =\n      program.getSourceFiles().filter(sourceFile => canMigrateFile(basePath, sourceFile, program));\n  const queryVisitor = new NgQueryResolveVisitor(typeChecker);\n\n  // Analyze all project source-files and collect all queries that\n  // need to be migrated.\n  sourceFiles.forEach(sourceFile => {\n    const relativePath = relative(basePath, sourceFile.fileName);\n\n    // Only look for queries within the current source files if the\n    // file has not been analyzed before.\n    if (!analyzedFiles.has(relativePath)) {\n      analyzedFiles.add(relativePath);\n      queryVisitor.visitNode(sourceFile);\n    }\n  });\n\n  if (queryVisitor.resolvedQueries.size === 0) {\n    return null;\n  }\n\n  return {program, host, tsconfigPath, typeChecker, basePath, queryVisitor, sourceFiles};\n}\n\n/**\n * Runs the static query migration for the given project. The schematic analyzes all\n * queries within the project and sets up the query timing based on the current usage\n * of the query property. e.g. a view query that is not used in any lifecycle hook does\n * not need to be static and can be set up with \"static: false\".\n */\nasync function runStaticQueryMigration(\n    tree: Tree, project: AnalyzedProject, selectedStrategy: SELECTED_STRATEGY,\n    logger: logging.LoggerApi): Promise<string[]> {\n  const {sourceFiles, typeChecker, host, queryVisitor, tsconfigPath, basePath} = project;\n  const printer = ts.createPrinter();\n  const failureMessages: string[] = [];\n  const templateVisitor = new NgComponentTemplateVisitor(typeChecker);\n\n  // If the \"usage\" strategy is selected, we also need to add the query visitor\n  // to the analysis visitors so that query usage in templates can be also checked.\n  if (selectedStrategy === SELECTED_STRATEGY.USAGE) {\n    sourceFiles.forEach(s => templateVisitor.visitNode(s));\n  }\n\n  const {resolvedQueries, classMetadata} = queryVisitor;\n  const {resolvedTemplates} = templateVisitor;\n\n  if (selectedStrategy === SELECTED_STRATEGY.USAGE) {\n    // Add all resolved templates to the class metadata if the usage strategy is used. This\n    // is necessary in order to be able to check component templates for static query usage.\n    resolvedTemplates.forEach(template => {\n      if (classMetadata.has(template.container)) {\n        classMetadata.get(template.container)!.template = template;\n      }\n    });\n  }\n\n  let strategy: TimingStrategy;\n  if (selectedStrategy === SELECTED_STRATEGY.USAGE) {\n    strategy = new QueryUsageStrategy(classMetadata, typeChecker);\n  } else if (selectedStrategy === SELECTED_STRATEGY.TESTS) {\n    strategy = new QueryTestStrategy();\n  } else {\n    strategy = new QueryTemplateStrategy(tsconfigPath, classMetadata, host);\n  }\n\n  try {\n    strategy.setup();\n  } catch (e) {\n    if (selectedStrategy === SELECTED_STRATEGY.TEMPLATE) {\n      logger.warn(\n          `\\nThe template migration strategy uses the Angular compiler ` +\n          `internally and therefore projects that no longer build successfully after ` +\n          `the update cannot use the template migration strategy. Please ensure ` +\n          `there are no AOT compilation errors.\\n`);\n    }\n    // In case the strategy could not be set up properly, we just exit the\n    // migration. We don't want to throw an exception as this could mean\n    // that other migrations are interrupted.\n    logger.warn(\n        `Could not setup migration strategy for \"${project.tsconfigPath}\". The ` +\n        `following error has been reported:\\n`);\n    logger.error(`${e.toString()}\\n`);\n    logger.info(\n        'Migration can be rerun with: \"ng update @angular/core --from 7 --to 8 --migrate-only\"\\n');\n    return [];\n  }\n\n  // Walk through all source files that contain resolved queries and update\n  // the source files if needed. Note that we need to update multiple queries\n  // within a source file within the same recorder in order to not throw off\n  // the TypeScript node offsets.\n  resolvedQueries.forEach((queries, sourceFile) => {\n    const relativePath = relative(basePath, sourceFile.fileName);\n    const update = tree.beginUpdate(relativePath);\n\n    // Compute the query timing for all resolved queries and update the\n    // query definitions to explicitly set the determined query timing.\n    queries.forEach(q => {\n      const queryExpr = q.decorator.node.expression;\n      const {timing, message} = strategy.detectTiming(q);\n      const result = getTransformedQueryCallExpr(q, timing, !!message);\n\n      if (!result) {\n        return;\n      }\n\n      const newText = printer.printNode(ts.EmitHint.Unspecified, result.node, sourceFile);\n\n      // Replace the existing query decorator call expression with the updated\n      // call expression node.\n      update.remove(queryExpr.getStart(), queryExpr.getWidth());\n      update.insertRight(queryExpr.getStart(), newText);\n\n      if (result.failureMessage || message) {\n        const {line, character} =\n            ts.getLineAndCharacterOfPosition(sourceFile, q.decorator.node.getStart());\n        failureMessages.push(\n            `${relativePath}@${line + 1}:${character + 1}: ${result.failureMessage || message}`);\n      }\n    });\n\n    tree.commitUpdate(update);\n  });\n\n  return failureMessages;\n}\n"]}
|
package/schematics/migrations/static-queries/strategies/template_strategy/template_strategy.js
CHANGED
|
@@ -38,13 +38,13 @@
|
|
|
38
38
|
* the AOT compiler program could not be created due to failure diagnostics.
|
|
39
39
|
*/
|
|
40
40
|
setup() {
|
|
41
|
-
const { rootNames, options } = compiler_cli_1.readConfiguration(this.projectPath);
|
|
41
|
+
const { rootNames, options } = (0, compiler_cli_1.readConfiguration)(this.projectPath);
|
|
42
42
|
// https://github.com/angular/angular/commit/ec4381dd401f03bded652665b047b6b90f2b425f made Ivy
|
|
43
43
|
// the default. This breaks the assumption that "createProgram" from compiler-cli returns the
|
|
44
44
|
// NGC program. In order to ensure that the migration runs properly, we set "enableIvy" to
|
|
45
45
|
// false.
|
|
46
46
|
options.enableIvy = false;
|
|
47
|
-
const aotProgram = compiler_cli_1.createProgram({ rootNames, options, host: this.host });
|
|
47
|
+
const aotProgram = (0, compiler_cli_1.createProgram)({ rootNames, options, host: this.host });
|
|
48
48
|
// The "AngularCompilerProgram" does not expose the "AotCompiler" instance, nor does it
|
|
49
49
|
// expose the logic that is necessary to analyze the determined modules. We work around
|
|
50
50
|
// this by just accessing the necessary private properties using the bracket notation.
|
|
@@ -163,7 +163,7 @@
|
|
|
163
163
|
return new Error(ts.formatDiagnostics(diagnostics, this.host));
|
|
164
164
|
}
|
|
165
165
|
_getViewQueryUniqueKey(filePath, className, propName) {
|
|
166
|
-
return `${path_1.resolve(filePath)}#${className}-${propName}`;
|
|
166
|
+
return `${(0, path_1.resolve)(filePath)}#${className}-${propName}`;
|
|
167
167
|
}
|
|
168
168
|
}
|
|
169
169
|
exports.QueryTemplateStrategy = QueryTemplateStrategy;
|
|
@@ -211,4 +211,4 @@
|
|
|
211
211
|
return { staticQueryIds, dynamicQueryIds };
|
|
212
212
|
}
|
|
213
213
|
});
|
|
214
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"template_strategy.js","sourceRoot":"","sources":["../../../../../../../../../../packages/core/schematics/migrations/static-queries/strategies/template_strategy/template_strategy.ts"],"names":[],"mappings":"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","sourcesContent":["/**\n * @license\n * Copyright Google LLC All Rights Reserved.\n *\n * Use of this source code is governed by an MIT-style license that can be\n * found in the LICENSE file at https://angular.io/license\n */\n\nimport {AotCompiler, CompileDirectiveMetadata, CompileMetadataResolver, CompileNgModuleMetadata, CompileStylesheetMetadata, ElementAst, EmbeddedTemplateAst, NgAnalyzedModules, QueryMatch, StaticSymbol, TemplateAst} from '@angular/compiler';\nimport {createProgram, Diagnostic, readConfiguration} from '@angular/compiler-cli';\nimport {resolve} from 'path';\nimport * as ts from 'typescript';\n\nimport {ClassMetadataMap} from '../../angular/ng_query_visitor';\nimport {NgQueryDefinition, QueryTiming, QueryType} from '../../angular/query-definition';\nimport {TimingResult, TimingStrategy} from '../timing-strategy';\n\nconst QUERY_NOT_DECLARED_IN_COMPONENT_MESSAGE = 'Timing could not be determined. This happens ' +\n    'if the query is not declared in any component.';\n\nexport class QueryTemplateStrategy implements TimingStrategy {\n  private compiler: AotCompiler|null = null;\n  private metadataResolver: CompileMetadataResolver|null = null;\n  private analyzedQueries = new Map<string, QueryTiming>();\n\n  constructor(\n      private projectPath: string, private classMetadata: ClassMetadataMap,\n      private host: ts.CompilerHost) {}\n\n  /**\n   * Sets up the template strategy by creating the AngularCompilerProgram. Returns false if\n   * the AOT compiler program could not be created due to failure diagnostics.\n   */\n  setup() {\n    const {rootNames, options} = readConfiguration(this.projectPath);\n\n    // https://github.com/angular/angular/commit/ec4381dd401f03bded652665b047b6b90f2b425f made Ivy\n    // the default. This breaks the assumption that \"createProgram\" from compiler-cli returns the\n    // NGC program. In order to ensure that the migration runs properly, we set \"enableIvy\" to\n    // false.\n    options.enableIvy = false;\n\n    const aotProgram = createProgram({rootNames, options, host: this.host});\n\n    // The \"AngularCompilerProgram\" does not expose the \"AotCompiler\" instance, nor does it\n    // expose the logic that is necessary to analyze the determined modules. We work around\n    // this by just accessing the necessary private properties using the bracket notation.\n    this.compiler = (aotProgram as any)['compiler'];\n    this.metadataResolver = this.compiler!['_metadataResolver'];\n\n    // Modify the \"DirectiveNormalizer\" to not normalize any referenced external stylesheets.\n    // This is necessary because in CLI projects preprocessor files are commonly referenced\n    // and we don't want to parse them in order to extract relative style references. This\n    // breaks the analysis of the project because we instantiate a standalone AOT compiler\n    // program which does not contain the custom logic by the Angular CLI Webpack compiler plugin.\n    const directiveNormalizer = this.metadataResolver!['_directiveNormalizer'];\n    directiveNormalizer['_normalizeStylesheet'] = function(metadata: CompileStylesheetMetadata) {\n      return new CompileStylesheetMetadata(\n          {styles: metadata.styles, styleUrls: [], moduleUrl: metadata.moduleUrl!});\n    };\n\n    // Retrieves the analyzed modules of the current program. This data can be\n    // used to determine the timing for registered queries.\n    const analyzedModules = (aotProgram as any)['analyzedModules'] as NgAnalyzedModules;\n\n    const ngStructuralDiagnostics = aotProgram.getNgStructuralDiagnostics();\n    if (ngStructuralDiagnostics.length) {\n      throw this._createDiagnosticsError(ngStructuralDiagnostics);\n    }\n\n    analyzedModules.files.forEach(file => {\n      file.directives.forEach(directive => this._analyzeDirective(directive, analyzedModules));\n    });\n  }\n\n  /** Analyzes a given directive by determining the timing of all matched view queries. */\n  private _analyzeDirective(symbol: StaticSymbol, analyzedModules: NgAnalyzedModules) {\n    const metadata = this.metadataResolver!.getDirectiveMetadata(symbol);\n    const ngModule = analyzedModules.ngModuleByPipeOrDirective.get(symbol);\n\n    if (!metadata.isComponent || !ngModule) {\n      return;\n    }\n\n    const parsedTemplate = this._parseTemplate(metadata, ngModule);\n    const queryTimingMap = findStaticQueryIds(parsedTemplate);\n    const {staticQueryIds} = staticViewQueryIds(queryTimingMap);\n\n    metadata.viewQueries.forEach((query, index) => {\n      // Query ids are computed by adding \"one\" to the index. This is done within\n      // the \"view_compiler.ts\" in order to support using a bloom filter for queries.\n      const queryId = index + 1;\n      const queryKey =\n          this._getViewQueryUniqueKey(symbol.filePath, symbol.name, query.propertyName);\n      this.analyzedQueries.set(\n          queryKey, staticQueryIds.has(queryId) ? QueryTiming.STATIC : QueryTiming.DYNAMIC);\n    });\n  }\n\n  /** Detects the timing of the query definition. */\n  detectTiming(query: NgQueryDefinition): TimingResult {\n    if (query.type === QueryType.ContentChild) {\n      return {timing: null, message: 'Content queries cannot be migrated automatically.'};\n    } else if (!query.name) {\n      // In case the query property name is not statically analyzable, we mark this\n      // query as unresolved. NGC currently skips these view queries as well.\n      return {timing: null, message: 'Query is not statically analyzable.'};\n    }\n\n    const propertyName = query.name;\n    const classMetadata = this.classMetadata.get(query.container);\n\n    // In case there is no class metadata or there are no derived classes that\n    // could access the current query, we just look for the query analysis of\n    // the class that declares the query. e.g. only the template of the class\n    // that declares the view query affects the query timing.\n    if (!classMetadata || !classMetadata.derivedClasses.length) {\n      const timing = this._getQueryTimingFromClass(query.container, propertyName);\n\n      if (timing === null) {\n        return {timing: null, message: QUERY_NOT_DECLARED_IN_COMPONENT_MESSAGE};\n      }\n\n      return {timing};\n    }\n\n    let resolvedTiming: QueryTiming|null = null;\n    let timingMismatch = false;\n\n    // In case there are multiple components that use the same query (e.g. through inheritance),\n    // we need to check if all components use the query with the same timing. If that is not\n    // the case, the query timing is ambiguous and the developer needs to fix the query manually.\n    [query.container, ...classMetadata.derivedClasses].forEach(classDecl => {\n      const classTiming = this._getQueryTimingFromClass(classDecl, propertyName);\n\n      if (classTiming === null) {\n        return;\n      }\n\n      // In case there is no resolved timing yet, save the new timing. Timings from other\n      // components that use the query with a different timing, cause the timing to be\n      // mismatched. In that case we can't detect a working timing for all components.\n      if (resolvedTiming === null) {\n        resolvedTiming = classTiming;\n      } else if (resolvedTiming !== classTiming) {\n        timingMismatch = true;\n      }\n    });\n\n    if (resolvedTiming === null) {\n      return {timing: QueryTiming.DYNAMIC, message: QUERY_NOT_DECLARED_IN_COMPONENT_MESSAGE};\n    } else if (timingMismatch) {\n      return {timing: null, message: 'Multiple components use the query with different timings.'};\n    }\n    return {timing: resolvedTiming};\n  }\n\n  /**\n   * Gets the timing that has been resolved for a given query when it's used within the\n   * specified class declaration. e.g. queries from an inherited class can be used.\n   */\n  private _getQueryTimingFromClass(classDecl: ts.ClassDeclaration, queryName: string): QueryTiming\n      |null {\n    if (!classDecl.name) {\n      return null;\n    }\n    const filePath = classDecl.getSourceFile().fileName;\n    const queryKey = this._getViewQueryUniqueKey(filePath, classDecl.name.text, queryName);\n\n    if (this.analyzedQueries.has(queryKey)) {\n      return this.analyzedQueries.get(queryKey)!;\n    }\n    return null;\n  }\n\n  private _parseTemplate(component: CompileDirectiveMetadata, ngModule: CompileNgModuleMetadata):\n      TemplateAst[] {\n    return this\n        .compiler!['_parseTemplate'](component, ngModule, ngModule.transitiveModule.directives)\n        .template;\n  }\n\n  private _createDiagnosticsError(diagnostics: ReadonlyArray<Diagnostic>) {\n    return new Error(ts.formatDiagnostics(diagnostics as ts.Diagnostic[], this.host));\n  }\n\n  private _getViewQueryUniqueKey(filePath: string, className: string, propName: string) {\n    return `${resolve(filePath)}#${className}-${propName}`;\n  }\n}\n\ninterface StaticAndDynamicQueryIds {\n  staticQueryIds: Set<number>;\n  dynamicQueryIds: Set<number>;\n}\n\n/** Figures out which queries are static and which ones are dynamic. */\nfunction findStaticQueryIds(\n    nodes: TemplateAst[], result = new Map<TemplateAst, StaticAndDynamicQueryIds>()):\n    Map<TemplateAst, StaticAndDynamicQueryIds> {\n  nodes.forEach((node) => {\n    const staticQueryIds = new Set<number>();\n    const dynamicQueryIds = new Set<number>();\n    let queryMatches: QueryMatch[] = undefined!;\n    if (node instanceof ElementAst) {\n      findStaticQueryIds(node.children, result);\n      node.children.forEach((child) => {\n        const childData = result.get(child)!;\n        childData.staticQueryIds.forEach(queryId => staticQueryIds.add(queryId));\n        childData.dynamicQueryIds.forEach(queryId => dynamicQueryIds.add(queryId));\n      });\n      queryMatches = node.queryMatches;\n    } else if (node instanceof EmbeddedTemplateAst) {\n      findStaticQueryIds(node.children, result);\n      node.children.forEach((child) => {\n        const childData = result.get(child)!;\n        childData.staticQueryIds.forEach(queryId => dynamicQueryIds.add(queryId));\n        childData.dynamicQueryIds.forEach(queryId => dynamicQueryIds.add(queryId));\n      });\n      queryMatches = node.queryMatches;\n    }\n    if (queryMatches) {\n      queryMatches.forEach((match) => staticQueryIds.add(match.queryId));\n    }\n    dynamicQueryIds.forEach(queryId => staticQueryIds.delete(queryId));\n    result.set(node, {staticQueryIds, dynamicQueryIds});\n  });\n  return result;\n}\n\n/** Splits queries into static and dynamic. */\nfunction staticViewQueryIds(nodeStaticQueryIds: Map<TemplateAst, StaticAndDynamicQueryIds>):\n    StaticAndDynamicQueryIds {\n  const staticQueryIds = new Set<number>();\n  const dynamicQueryIds = new Set<number>();\n  Array.from(nodeStaticQueryIds.values()).forEach((entry) => {\n    entry.staticQueryIds.forEach(queryId => staticQueryIds.add(queryId));\n    entry.dynamicQueryIds.forEach(queryId => dynamicQueryIds.add(queryId));\n  });\n  dynamicQueryIds.forEach(queryId => staticQueryIds.delete(queryId));\n  return {staticQueryIds, dynamicQueryIds};\n}\n"]}
|
|
214
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"template_strategy.js","sourceRoot":"","sources":["../../../../../../../../../../packages/core/schematics/migrations/static-queries/strategies/template_strategy/template_strategy.ts"],"names":[],"mappings":"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","sourcesContent":["/**\n * @license\n * Copyright Google LLC All Rights Reserved.\n *\n * Use of this source code is governed by an MIT-style license that can be\n * found in the LICENSE file at https://angular.io/license\n */\n\nimport {AotCompiler, CompileDirectiveMetadata, CompileMetadataResolver, CompileNgModuleMetadata, CompileStylesheetMetadata, ElementAst, EmbeddedTemplateAst, NgAnalyzedModules, QueryMatch, StaticSymbol, TemplateAst} from '@angular/compiler';\nimport {createProgram, Diagnostic, readConfiguration} from '@angular/compiler-cli';\nimport {resolve} from 'path';\nimport * as ts from 'typescript';\n\nimport {ClassMetadataMap} from '../../angular/ng_query_visitor';\nimport {NgQueryDefinition, QueryTiming, QueryType} from '../../angular/query-definition';\nimport {TimingResult, TimingStrategy} from '../timing-strategy';\n\nconst QUERY_NOT_DECLARED_IN_COMPONENT_MESSAGE = 'Timing could not be determined. This happens ' +\n    'if the query is not declared in any component.';\n\nexport class QueryTemplateStrategy implements TimingStrategy {\n  private compiler: AotCompiler|null = null;\n  private metadataResolver: CompileMetadataResolver|null = null;\n  private analyzedQueries = new Map<string, QueryTiming>();\n\n  constructor(\n      private projectPath: string, private classMetadata: ClassMetadataMap,\n      private host: ts.CompilerHost) {}\n\n  /**\n   * Sets up the template strategy by creating the AngularCompilerProgram. Returns false if\n   * the AOT compiler program could not be created due to failure diagnostics.\n   */\n  setup() {\n    const {rootNames, options} = readConfiguration(this.projectPath);\n\n    // https://github.com/angular/angular/commit/ec4381dd401f03bded652665b047b6b90f2b425f made Ivy\n    // the default. This breaks the assumption that \"createProgram\" from compiler-cli returns the\n    // NGC program. In order to ensure that the migration runs properly, we set \"enableIvy\" to\n    // false.\n    options.enableIvy = false;\n\n    const aotProgram = createProgram({rootNames, options, host: this.host});\n\n    // The \"AngularCompilerProgram\" does not expose the \"AotCompiler\" instance, nor does it\n    // expose the logic that is necessary to analyze the determined modules. We work around\n    // this by just accessing the necessary private properties using the bracket notation.\n    this.compiler = (aotProgram as any)['compiler'];\n    this.metadataResolver = this.compiler!['_metadataResolver'];\n\n    // Modify the \"DirectiveNormalizer\" to not normalize any referenced external stylesheets.\n    // This is necessary because in CLI projects preprocessor files are commonly referenced\n    // and we don't want to parse them in order to extract relative style references. This\n    // breaks the analysis of the project because we instantiate a standalone AOT compiler\n    // program which does not contain the custom logic by the Angular CLI Webpack compiler plugin.\n    const directiveNormalizer = this.metadataResolver!['_directiveNormalizer'];\n    directiveNormalizer['_normalizeStylesheet'] = function(metadata: CompileStylesheetMetadata) {\n      return new CompileStylesheetMetadata(\n          {styles: metadata.styles, styleUrls: [], moduleUrl: metadata.moduleUrl!});\n    };\n\n    // Retrieves the analyzed modules of the current program. This data can be\n    // used to determine the timing for registered queries.\n    const analyzedModules = (aotProgram as any)['analyzedModules'] as NgAnalyzedModules;\n\n    const ngStructuralDiagnostics = aotProgram.getNgStructuralDiagnostics();\n    if (ngStructuralDiagnostics.length) {\n      throw this._createDiagnosticsError(ngStructuralDiagnostics);\n    }\n\n    analyzedModules.files.forEach(file => {\n      file.directives.forEach(directive => this._analyzeDirective(directive, analyzedModules));\n    });\n  }\n\n  /** Analyzes a given directive by determining the timing of all matched view queries. */\n  private _analyzeDirective(symbol: StaticSymbol, analyzedModules: NgAnalyzedModules) {\n    const metadata = this.metadataResolver!.getDirectiveMetadata(symbol);\n    const ngModule = analyzedModules.ngModuleByPipeOrDirective.get(symbol);\n\n    if (!metadata.isComponent || !ngModule) {\n      return;\n    }\n\n    const parsedTemplate = this._parseTemplate(metadata, ngModule);\n    const queryTimingMap = findStaticQueryIds(parsedTemplate);\n    const {staticQueryIds} = staticViewQueryIds(queryTimingMap);\n\n    metadata.viewQueries.forEach((query, index) => {\n      // Query ids are computed by adding \"one\" to the index. This is done within\n      // the \"view_compiler.ts\" in order to support using a bloom filter for queries.\n      const queryId = index + 1;\n      const queryKey =\n          this._getViewQueryUniqueKey(symbol.filePath, symbol.name, query.propertyName);\n      this.analyzedQueries.set(\n          queryKey, staticQueryIds.has(queryId) ? QueryTiming.STATIC : QueryTiming.DYNAMIC);\n    });\n  }\n\n  /** Detects the timing of the query definition. */\n  detectTiming(query: NgQueryDefinition): TimingResult {\n    if (query.type === QueryType.ContentChild) {\n      return {timing: null, message: 'Content queries cannot be migrated automatically.'};\n    } else if (!query.name) {\n      // In case the query property name is not statically analyzable, we mark this\n      // query as unresolved. NGC currently skips these view queries as well.\n      return {timing: null, message: 'Query is not statically analyzable.'};\n    }\n\n    const propertyName = query.name;\n    const classMetadata = this.classMetadata.get(query.container);\n\n    // In case there is no class metadata or there are no derived classes that\n    // could access the current query, we just look for the query analysis of\n    // the class that declares the query. e.g. only the template of the class\n    // that declares the view query affects the query timing.\n    if (!classMetadata || !classMetadata.derivedClasses.length) {\n      const timing = this._getQueryTimingFromClass(query.container, propertyName);\n\n      if (timing === null) {\n        return {timing: null, message: QUERY_NOT_DECLARED_IN_COMPONENT_MESSAGE};\n      }\n\n      return {timing};\n    }\n\n    let resolvedTiming: QueryTiming|null = null;\n    let timingMismatch = false;\n\n    // In case there are multiple components that use the same query (e.g. through inheritance),\n    // we need to check if all components use the query with the same timing. If that is not\n    // the case, the query timing is ambiguous and the developer needs to fix the query manually.\n    [query.container, ...classMetadata.derivedClasses].forEach(classDecl => {\n      const classTiming = this._getQueryTimingFromClass(classDecl, propertyName);\n\n      if (classTiming === null) {\n        return;\n      }\n\n      // In case there is no resolved timing yet, save the new timing. Timings from other\n      // components that use the query with a different timing, cause the timing to be\n      // mismatched. In that case we can't detect a working timing for all components.\n      if (resolvedTiming === null) {\n        resolvedTiming = classTiming;\n      } else if (resolvedTiming !== classTiming) {\n        timingMismatch = true;\n      }\n    });\n\n    if (resolvedTiming === null) {\n      return {timing: QueryTiming.DYNAMIC, message: QUERY_NOT_DECLARED_IN_COMPONENT_MESSAGE};\n    } else if (timingMismatch) {\n      return {timing: null, message: 'Multiple components use the query with different timings.'};\n    }\n    return {timing: resolvedTiming};\n  }\n\n  /**\n   * Gets the timing that has been resolved for a given query when it's used within the\n   * specified class declaration. e.g. queries from an inherited class can be used.\n   */\n  private _getQueryTimingFromClass(classDecl: ts.ClassDeclaration, queryName: string): QueryTiming\n      |null {\n    if (!classDecl.name) {\n      return null;\n    }\n    const filePath = classDecl.getSourceFile().fileName;\n    const queryKey = this._getViewQueryUniqueKey(filePath, classDecl.name.text, queryName);\n\n    if (this.analyzedQueries.has(queryKey)) {\n      return this.analyzedQueries.get(queryKey)!;\n    }\n    return null;\n  }\n\n  private _parseTemplate(component: CompileDirectiveMetadata, ngModule: CompileNgModuleMetadata):\n      TemplateAst[] {\n    return this\n        .compiler!['_parseTemplate'](component, ngModule, ngModule.transitiveModule.directives)\n        .template;\n  }\n\n  private _createDiagnosticsError(diagnostics: ReadonlyArray<Diagnostic>) {\n    return new Error(ts.formatDiagnostics(diagnostics as ts.Diagnostic[], this.host));\n  }\n\n  private _getViewQueryUniqueKey(filePath: string, className: string, propName: string) {\n    return `${resolve(filePath)}#${className}-${propName}`;\n  }\n}\n\ninterface StaticAndDynamicQueryIds {\n  staticQueryIds: Set<number>;\n  dynamicQueryIds: Set<number>;\n}\n\n/** Figures out which queries are static and which ones are dynamic. */\nfunction findStaticQueryIds(\n    nodes: TemplateAst[], result = new Map<TemplateAst, StaticAndDynamicQueryIds>()):\n    Map<TemplateAst, StaticAndDynamicQueryIds> {\n  nodes.forEach((node) => {\n    const staticQueryIds = new Set<number>();\n    const dynamicQueryIds = new Set<number>();\n    let queryMatches: QueryMatch[] = undefined!;\n    if (node instanceof ElementAst) {\n      findStaticQueryIds(node.children, result);\n      node.children.forEach((child) => {\n        const childData = result.get(child)!;\n        childData.staticQueryIds.forEach(queryId => staticQueryIds.add(queryId));\n        childData.dynamicQueryIds.forEach(queryId => dynamicQueryIds.add(queryId));\n      });\n      queryMatches = node.queryMatches;\n    } else if (node instanceof EmbeddedTemplateAst) {\n      findStaticQueryIds(node.children, result);\n      node.children.forEach((child) => {\n        const childData = result.get(child)!;\n        childData.staticQueryIds.forEach(queryId => dynamicQueryIds.add(queryId));\n        childData.dynamicQueryIds.forEach(queryId => dynamicQueryIds.add(queryId));\n      });\n      queryMatches = node.queryMatches;\n    }\n    if (queryMatches) {\n      queryMatches.forEach((match) => staticQueryIds.add(match.queryId));\n    }\n    dynamicQueryIds.forEach(queryId => staticQueryIds.delete(queryId));\n    result.set(node, {staticQueryIds, dynamicQueryIds});\n  });\n  return result;\n}\n\n/** Splits queries into static and dynamic. */\nfunction staticViewQueryIds(nodeStaticQueryIds: Map<TemplateAst, StaticAndDynamicQueryIds>):\n    StaticAndDynamicQueryIds {\n  const staticQueryIds = new Set<number>();\n  const dynamicQueryIds = new Set<number>();\n  Array.from(nodeStaticQueryIds.values()).forEach((entry) => {\n    entry.staticQueryIds.forEach(queryId => staticQueryIds.add(queryId));\n    entry.dynamicQueryIds.forEach(queryId => dynamicQueryIds.add(queryId));\n  });\n  dynamicQueryIds.forEach(queryId => staticQueryIds.delete(queryId));\n  return {staticQueryIds, dynamicQueryIds};\n}\n"]}
|