1 | /**
|
---|
2 | * @license
|
---|
3 | * Copyright Google LLC All Rights Reserved.
|
---|
4 | *
|
---|
5 | * Use of this source code is governed by an MIT-style license that can be
|
---|
6 | * found in the LICENSE file at https://angular.io/license
|
---|
7 | */
|
---|
8 | (function (factory) {
|
---|
9 | if (typeof module === "object" && typeof module.exports === "object") {
|
---|
10 | var v = factory(require, exports);
|
---|
11 | if (v !== undefined) module.exports = v;
|
---|
12 | }
|
---|
13 | else if (typeof define === "function" && define.amd) {
|
---|
14 | define("@angular/compiler/src/view_compiler/type_check_compiler", ["require", "exports", "tslib", "@angular/compiler/src/aot/static_symbol", "@angular/compiler/src/compiler_util/expression_converter", "@angular/compiler/src/output/output_ast", "@angular/compiler/src/template_parser/template_ast"], factory);
|
---|
15 | }
|
---|
16 | })(function (require, exports) {
|
---|
17 | "use strict";
|
---|
18 | Object.defineProperty(exports, "__esModule", { value: true });
|
---|
19 | exports.TypeCheckCompiler = void 0;
|
---|
20 | var tslib_1 = require("tslib");
|
---|
21 | var static_symbol_1 = require("@angular/compiler/src/aot/static_symbol");
|
---|
22 | var expression_converter_1 = require("@angular/compiler/src/compiler_util/expression_converter");
|
---|
23 | var o = require("@angular/compiler/src/output/output_ast");
|
---|
24 | var template_ast_1 = require("@angular/compiler/src/template_parser/template_ast");
|
---|
25 | /**
|
---|
26 | * Generates code that is used to type check templates.
|
---|
27 | */
|
---|
28 | var TypeCheckCompiler = /** @class */ (function () {
|
---|
29 | function TypeCheckCompiler(options, reflector) {
|
---|
30 | this.options = options;
|
---|
31 | this.reflector = reflector;
|
---|
32 | }
|
---|
33 | /**
|
---|
34 | * Important notes:
|
---|
35 | * - This must not produce new `import` statements, but only refer to types outside
|
---|
36 | * of the file via the variables provided via externalReferenceVars.
|
---|
37 | * This allows Typescript to reuse the old program's structure as no imports have changed.
|
---|
38 | * - This must not produce any exports, as this would pollute the .d.ts file
|
---|
39 | * and also violate the point above.
|
---|
40 | */
|
---|
41 | TypeCheckCompiler.prototype.compileComponent = function (componentId, component, template, usedPipes, externalReferenceVars, ctx) {
|
---|
42 | var _this = this;
|
---|
43 | var pipes = new Map();
|
---|
44 | usedPipes.forEach(function (p) { return pipes.set(p.name, p.type.reference); });
|
---|
45 | var embeddedViewCount = 0;
|
---|
46 | var viewBuilderFactory = function (parent, guards) {
|
---|
47 | var embeddedViewIndex = embeddedViewCount++;
|
---|
48 | return new ViewBuilder(_this.options, _this.reflector, externalReferenceVars, parent, component.type.reference, component.isHost, embeddedViewIndex, pipes, guards, ctx, viewBuilderFactory);
|
---|
49 | };
|
---|
50 | var visitor = viewBuilderFactory(null, []);
|
---|
51 | visitor.visitAll([], template);
|
---|
52 | return visitor.build(componentId);
|
---|
53 | };
|
---|
54 | return TypeCheckCompiler;
|
---|
55 | }());
|
---|
56 | exports.TypeCheckCompiler = TypeCheckCompiler;
|
---|
57 | var DYNAMIC_VAR_NAME = '_any';
|
---|
58 | var TypeCheckLocalResolver = /** @class */ (function () {
|
---|
59 | function TypeCheckLocalResolver() {
|
---|
60 | }
|
---|
61 | TypeCheckLocalResolver.prototype.notifyImplicitReceiverUse = function () { };
|
---|
62 | TypeCheckLocalResolver.prototype.maybeRestoreView = function () { };
|
---|
63 | TypeCheckLocalResolver.prototype.getLocal = function (name) {
|
---|
64 | if (name === expression_converter_1.EventHandlerVars.event.name) {
|
---|
65 | // References to the event should not be type-checked.
|
---|
66 | // TODO(chuckj): determine a better type for the event.
|
---|
67 | return o.variable(DYNAMIC_VAR_NAME);
|
---|
68 | }
|
---|
69 | return null;
|
---|
70 | };
|
---|
71 | return TypeCheckLocalResolver;
|
---|
72 | }());
|
---|
73 | var defaultResolver = new TypeCheckLocalResolver();
|
---|
74 | var ViewBuilder = /** @class */ (function () {
|
---|
75 | function ViewBuilder(options, reflector, externalReferenceVars, parent, component, isHostComponent, embeddedViewIndex, pipes, guards, ctx, viewBuilderFactory) {
|
---|
76 | this.options = options;
|
---|
77 | this.reflector = reflector;
|
---|
78 | this.externalReferenceVars = externalReferenceVars;
|
---|
79 | this.parent = parent;
|
---|
80 | this.component = component;
|
---|
81 | this.isHostComponent = isHostComponent;
|
---|
82 | this.embeddedViewIndex = embeddedViewIndex;
|
---|
83 | this.pipes = pipes;
|
---|
84 | this.guards = guards;
|
---|
85 | this.ctx = ctx;
|
---|
86 | this.viewBuilderFactory = viewBuilderFactory;
|
---|
87 | this.refOutputVars = new Map();
|
---|
88 | this.variables = [];
|
---|
89 | this.children = [];
|
---|
90 | this.updates = [];
|
---|
91 | this.actions = [];
|
---|
92 | }
|
---|
93 | ViewBuilder.prototype.getOutputVar = function (type) {
|
---|
94 | var varName;
|
---|
95 | if (type === this.component && this.isHostComponent) {
|
---|
96 | varName = DYNAMIC_VAR_NAME;
|
---|
97 | }
|
---|
98 | else if (type instanceof static_symbol_1.StaticSymbol) {
|
---|
99 | varName = this.externalReferenceVars.get(type);
|
---|
100 | }
|
---|
101 | else {
|
---|
102 | varName = DYNAMIC_VAR_NAME;
|
---|
103 | }
|
---|
104 | if (!varName) {
|
---|
105 | throw new Error("Illegal State: referring to a type without a variable " + JSON.stringify(type));
|
---|
106 | }
|
---|
107 | return varName;
|
---|
108 | };
|
---|
109 | ViewBuilder.prototype.getTypeGuardExpressions = function (ast) {
|
---|
110 | var e_1, _a, e_2, _b;
|
---|
111 | var result = tslib_1.__spreadArray([], tslib_1.__read(this.guards));
|
---|
112 | try {
|
---|
113 | for (var _c = tslib_1.__values(ast.directives), _d = _c.next(); !_d.done; _d = _c.next()) {
|
---|
114 | var directive = _d.value;
|
---|
115 | try {
|
---|
116 | for (var _e = (e_2 = void 0, tslib_1.__values(directive.inputs)), _f = _e.next(); !_f.done; _f = _e.next()) {
|
---|
117 | var input = _f.value;
|
---|
118 | var guard = directive.directive.guards[input.directiveName];
|
---|
119 | if (guard) {
|
---|
120 | var useIf = guard === 'UseIf';
|
---|
121 | result.push({
|
---|
122 | guard: guard,
|
---|
123 | useIf: useIf,
|
---|
124 | expression: {
|
---|
125 | context: this.component,
|
---|
126 | value: input.value,
|
---|
127 | sourceSpan: input.sourceSpan,
|
---|
128 | },
|
---|
129 | });
|
---|
130 | }
|
---|
131 | }
|
---|
132 | }
|
---|
133 | catch (e_2_1) { e_2 = { error: e_2_1 }; }
|
---|
134 | finally {
|
---|
135 | try {
|
---|
136 | if (_f && !_f.done && (_b = _e.return)) _b.call(_e);
|
---|
137 | }
|
---|
138 | finally { if (e_2) throw e_2.error; }
|
---|
139 | }
|
---|
140 | }
|
---|
141 | }
|
---|
142 | catch (e_1_1) { e_1 = { error: e_1_1 }; }
|
---|
143 | finally {
|
---|
144 | try {
|
---|
145 | if (_d && !_d.done && (_a = _c.return)) _a.call(_c);
|
---|
146 | }
|
---|
147 | finally { if (e_1) throw e_1.error; }
|
---|
148 | }
|
---|
149 | return result;
|
---|
150 | };
|
---|
151 | ViewBuilder.prototype.visitAll = function (variables, astNodes) {
|
---|
152 | this.variables = variables;
|
---|
153 | template_ast_1.templateVisitAll(this, astNodes);
|
---|
154 | };
|
---|
155 | ViewBuilder.prototype.build = function (componentId, targetStatements) {
|
---|
156 | var e_3, _a;
|
---|
157 | var _this = this;
|
---|
158 | if (targetStatements === void 0) { targetStatements = []; }
|
---|
159 | this.children.forEach(function (child) { return child.build(componentId, targetStatements); });
|
---|
160 | var viewStmts = [o.variable(DYNAMIC_VAR_NAME).set(o.NULL_EXPR).toDeclStmt(o.DYNAMIC_TYPE)];
|
---|
161 | var bindingCount = 0;
|
---|
162 | this.updates.forEach(function (expression) {
|
---|
163 | var _a = _this.preprocessUpdateExpression(expression), sourceSpan = _a.sourceSpan, context = _a.context, value = _a.value;
|
---|
164 | var bindingId = "" + bindingCount++;
|
---|
165 | var nameResolver = context === _this.component ? _this : defaultResolver;
|
---|
166 | var _b = expression_converter_1.convertPropertyBinding(nameResolver, o.variable(_this.getOutputVar(context)), value, bindingId, expression_converter_1.BindingForm.General), stmts = _b.stmts, currValExpr = _b.currValExpr;
|
---|
167 | stmts.push(new o.ExpressionStatement(currValExpr));
|
---|
168 | viewStmts.push.apply(viewStmts, tslib_1.__spreadArray([], tslib_1.__read(stmts.map(function (stmt) { return o.applySourceSpanToStatementIfNeeded(stmt, sourceSpan); }))));
|
---|
169 | });
|
---|
170 | this.actions.forEach(function (_a) {
|
---|
171 | var sourceSpan = _a.sourceSpan, context = _a.context, value = _a.value;
|
---|
172 | var bindingId = "" + bindingCount++;
|
---|
173 | var nameResolver = context === _this.component ? _this : defaultResolver;
|
---|
174 | var stmts = expression_converter_1.convertActionBinding(nameResolver, o.variable(_this.getOutputVar(context)), value, bindingId).stmts;
|
---|
175 | viewStmts.push.apply(viewStmts, tslib_1.__spreadArray([], tslib_1.__read(stmts.map(function (stmt) { return o.applySourceSpanToStatementIfNeeded(stmt, sourceSpan); }))));
|
---|
176 | });
|
---|
177 | if (this.guards.length) {
|
---|
178 | var guardExpression = undefined;
|
---|
179 | try {
|
---|
180 | for (var _b = tslib_1.__values(this.guards), _c = _b.next(); !_c.done; _c = _b.next()) {
|
---|
181 | var guard = _c.value;
|
---|
182 | var _d = this.preprocessUpdateExpression(guard.expression), context = _d.context, value = _d.value;
|
---|
183 | var bindingId = "" + bindingCount++;
|
---|
184 | var nameResolver = context === this.component ? this : defaultResolver;
|
---|
185 | // We only support support simple expressions and ignore others as they
|
---|
186 | // are unlikely to affect type narrowing.
|
---|
187 | var _e = expression_converter_1.convertPropertyBinding(nameResolver, o.variable(this.getOutputVar(context)), value, bindingId, expression_converter_1.BindingForm.TrySimple), stmts = _e.stmts, currValExpr = _e.currValExpr;
|
---|
188 | if (stmts.length == 0) {
|
---|
189 | var guardClause = guard.useIf ? currValExpr : this.ctx.importExpr(guard.guard).callFn([currValExpr]);
|
---|
190 | guardExpression = guardExpression ? guardExpression.and(guardClause) : guardClause;
|
---|
191 | }
|
---|
192 | }
|
---|
193 | }
|
---|
194 | catch (e_3_1) { e_3 = { error: e_3_1 }; }
|
---|
195 | finally {
|
---|
196 | try {
|
---|
197 | if (_c && !_c.done && (_a = _b.return)) _a.call(_b);
|
---|
198 | }
|
---|
199 | finally { if (e_3) throw e_3.error; }
|
---|
200 | }
|
---|
201 | if (guardExpression) {
|
---|
202 | viewStmts = [new o.IfStmt(guardExpression, viewStmts)];
|
---|
203 | }
|
---|
204 | }
|
---|
205 | var viewName = "_View_" + componentId + "_" + this.embeddedViewIndex;
|
---|
206 | var viewFactory = new o.DeclareFunctionStmt(viewName, [], viewStmts);
|
---|
207 | targetStatements.push(viewFactory);
|
---|
208 | return targetStatements;
|
---|
209 | };
|
---|
210 | ViewBuilder.prototype.visitBoundText = function (ast, context) {
|
---|
211 | var _this = this;
|
---|
212 | var astWithSource = ast.value;
|
---|
213 | var inter = astWithSource.ast;
|
---|
214 | inter.expressions.forEach(function (expr) {
|
---|
215 | return _this.updates.push({ context: _this.component, value: expr, sourceSpan: ast.sourceSpan });
|
---|
216 | });
|
---|
217 | };
|
---|
218 | ViewBuilder.prototype.visitEmbeddedTemplate = function (ast, context) {
|
---|
219 | this.visitElementOrTemplate(ast);
|
---|
220 | // Note: The old view compiler used to use an `any` type
|
---|
221 | // for the context in any embedded view.
|
---|
222 | // We keep this behaivor behind a flag for now.
|
---|
223 | if (this.options.fullTemplateTypeCheck) {
|
---|
224 | // Find any applicable type guards. For example, NgIf has a type guard on ngIf
|
---|
225 | // (see NgIf.ngIfTypeGuard) that can be used to indicate that a template is only
|
---|
226 | // stamped out if ngIf is truthy so any bindings in the template can assume that,
|
---|
227 | // if a nullable type is used for ngIf, that expression is not null or undefined.
|
---|
228 | var guards = this.getTypeGuardExpressions(ast);
|
---|
229 | var childVisitor = this.viewBuilderFactory(this, guards);
|
---|
230 | this.children.push(childVisitor);
|
---|
231 | childVisitor.visitAll(ast.variables, ast.children);
|
---|
232 | }
|
---|
233 | };
|
---|
234 | ViewBuilder.prototype.visitElement = function (ast, context) {
|
---|
235 | var _this = this;
|
---|
236 | this.visitElementOrTemplate(ast);
|
---|
237 | var inputDefs = [];
|
---|
238 | var updateRendererExpressions = [];
|
---|
239 | var outputDefs = [];
|
---|
240 | ast.inputs.forEach(function (inputAst) {
|
---|
241 | _this.updates.push({ context: _this.component, value: inputAst.value, sourceSpan: inputAst.sourceSpan });
|
---|
242 | });
|
---|
243 | template_ast_1.templateVisitAll(this, ast.children);
|
---|
244 | };
|
---|
245 | ViewBuilder.prototype.visitElementOrTemplate = function (ast) {
|
---|
246 | var _this = this;
|
---|
247 | ast.directives.forEach(function (dirAst) {
|
---|
248 | _this.visitDirective(dirAst);
|
---|
249 | });
|
---|
250 | ast.references.forEach(function (ref) {
|
---|
251 | var outputVarType = null;
|
---|
252 | // Note: The old view compiler used to use an `any` type
|
---|
253 | // for directives exposed via `exportAs`.
|
---|
254 | // We keep this behaivor behind a flag for now.
|
---|
255 | if (ref.value && ref.value.identifier && _this.options.fullTemplateTypeCheck) {
|
---|
256 | outputVarType = ref.value.identifier.reference;
|
---|
257 | }
|
---|
258 | else {
|
---|
259 | outputVarType = o.BuiltinTypeName.Dynamic;
|
---|
260 | }
|
---|
261 | _this.refOutputVars.set(ref.name, outputVarType);
|
---|
262 | });
|
---|
263 | ast.outputs.forEach(function (outputAst) {
|
---|
264 | _this.actions.push({ context: _this.component, value: outputAst.handler, sourceSpan: outputAst.sourceSpan });
|
---|
265 | });
|
---|
266 | };
|
---|
267 | ViewBuilder.prototype.visitDirective = function (dirAst) {
|
---|
268 | var _this = this;
|
---|
269 | var dirType = dirAst.directive.type.reference;
|
---|
270 | dirAst.inputs.forEach(function (input) { return _this.updates.push({ context: _this.component, value: input.value, sourceSpan: input.sourceSpan }); });
|
---|
271 | // Note: The old view compiler used to use an `any` type
|
---|
272 | // for expressions in host properties / events.
|
---|
273 | // We keep this behaivor behind a flag for now.
|
---|
274 | if (this.options.fullTemplateTypeCheck) {
|
---|
275 | dirAst.hostProperties.forEach(function (inputAst) { return _this.updates.push({ context: dirType, value: inputAst.value, sourceSpan: inputAst.sourceSpan }); });
|
---|
276 | dirAst.hostEvents.forEach(function (hostEventAst) { return _this.actions.push({
|
---|
277 | context: dirType,
|
---|
278 | value: hostEventAst.handler,
|
---|
279 | sourceSpan: hostEventAst.sourceSpan
|
---|
280 | }); });
|
---|
281 | }
|
---|
282 | };
|
---|
283 | ViewBuilder.prototype.notifyImplicitReceiverUse = function () { };
|
---|
284 | ViewBuilder.prototype.maybeRestoreView = function () { };
|
---|
285 | ViewBuilder.prototype.getLocal = function (name) {
|
---|
286 | if (name == expression_converter_1.EventHandlerVars.event.name) {
|
---|
287 | return o.variable(this.getOutputVar(o.BuiltinTypeName.Dynamic));
|
---|
288 | }
|
---|
289 | for (var currBuilder = this; currBuilder; currBuilder = currBuilder.parent) {
|
---|
290 | var outputVarType = void 0;
|
---|
291 | // check references
|
---|
292 | outputVarType = currBuilder.refOutputVars.get(name);
|
---|
293 | if (outputVarType == null) {
|
---|
294 | // check variables
|
---|
295 | var varAst = currBuilder.variables.find(function (varAst) { return varAst.name === name; });
|
---|
296 | if (varAst) {
|
---|
297 | outputVarType = o.BuiltinTypeName.Dynamic;
|
---|
298 | }
|
---|
299 | }
|
---|
300 | if (outputVarType != null) {
|
---|
301 | return o.variable(this.getOutputVar(outputVarType));
|
---|
302 | }
|
---|
303 | }
|
---|
304 | return null;
|
---|
305 | };
|
---|
306 | ViewBuilder.prototype.pipeOutputVar = function (name) {
|
---|
307 | var pipe = this.pipes.get(name);
|
---|
308 | if (!pipe) {
|
---|
309 | throw new Error("Illegal State: Could not find pipe " + name + " in template of " + this.component);
|
---|
310 | }
|
---|
311 | return this.getOutputVar(pipe);
|
---|
312 | };
|
---|
313 | ViewBuilder.prototype.preprocessUpdateExpression = function (expression) {
|
---|
314 | var _this = this;
|
---|
315 | return {
|
---|
316 | sourceSpan: expression.sourceSpan,
|
---|
317 | context: expression.context,
|
---|
318 | value: expression_converter_1.convertPropertyBindingBuiltins({
|
---|
319 | createLiteralArrayConverter: function (argCount) { return function (args) {
|
---|
320 | var arr = o.literalArr(args);
|
---|
321 | // Note: The old view compiler used to use an `any` type
|
---|
322 | // for arrays.
|
---|
323 | return _this.options.fullTemplateTypeCheck ? arr : arr.cast(o.DYNAMIC_TYPE);
|
---|
324 | }; },
|
---|
325 | createLiteralMapConverter: function (keys) {
|
---|
326 | return function (values) {
|
---|
327 | var entries = keys.map(function (k, i) { return ({
|
---|
328 | key: k.key,
|
---|
329 | value: values[i],
|
---|
330 | quoted: k.quoted,
|
---|
331 | }); });
|
---|
332 | var map = o.literalMap(entries);
|
---|
333 | // Note: The old view compiler used to use an `any` type
|
---|
334 | // for maps.
|
---|
335 | return _this.options.fullTemplateTypeCheck ? map : map.cast(o.DYNAMIC_TYPE);
|
---|
336 | };
|
---|
337 | },
|
---|
338 | createPipeConverter: function (name, argCount) { return function (args) {
|
---|
339 | // Note: The old view compiler used to use an `any` type
|
---|
340 | // for pipes.
|
---|
341 | var pipeExpr = _this.options.fullTemplateTypeCheck ?
|
---|
342 | o.variable(_this.pipeOutputVar(name)) :
|
---|
343 | o.variable(_this.getOutputVar(o.BuiltinTypeName.Dynamic));
|
---|
344 | return pipeExpr.callMethod('transform', args);
|
---|
345 | }; },
|
---|
346 | }, expression.value)
|
---|
347 | };
|
---|
348 | };
|
---|
349 | ViewBuilder.prototype.visitNgContent = function (ast, context) { };
|
---|
350 | ViewBuilder.prototype.visitText = function (ast, context) { };
|
---|
351 | ViewBuilder.prototype.visitDirectiveProperty = function (ast, context) { };
|
---|
352 | ViewBuilder.prototype.visitReference = function (ast, context) { };
|
---|
353 | ViewBuilder.prototype.visitVariable = function (ast, context) { };
|
---|
354 | ViewBuilder.prototype.visitEvent = function (ast, context) { };
|
---|
355 | ViewBuilder.prototype.visitElementProperty = function (ast, context) { };
|
---|
356 | ViewBuilder.prototype.visitAttr = function (ast, context) { };
|
---|
357 | return ViewBuilder;
|
---|
358 | }());
|
---|
359 | });
|
---|
360 | //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"type_check_compiler.js","sourceRoot":"","sources":["../../../../../../../packages/compiler/src/view_compiler/type_check_compiler.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 {AotCompilerOptions} from '../aot/compiler_options';\nimport {StaticReflector} from '../aot/static_reflector';\nimport {StaticSymbol} from '../aot/static_symbol';\nimport {CompileDirectiveMetadata, CompilePipeSummary} from '../compile_metadata';\nimport {BindingForm, convertActionBinding, convertPropertyBinding, convertPropertyBindingBuiltins, EventHandlerVars, LocalResolver} from '../compiler_util/expression_converter';\nimport {OutputContext} from '../constant_pool';\nimport {AST, ASTWithSource, Interpolation} from '../expression_parser/ast';\nimport * as o from '../output/output_ast';\nimport {ParseSourceSpan} from '../parse_util';\nimport {AttrAst, BoundDirectivePropertyAst, BoundElementPropertyAst, BoundEventAst, BoundTextAst, DirectiveAst, ElementAst, EmbeddedTemplateAst, NgContentAst, ReferenceAst, TemplateAst, TemplateAstVisitor, templateVisitAll, TextAst, VariableAst} from '../template_parser/template_ast';\n\n\n/**\n * Generates code that is used to type check templates.\n */\nexport class TypeCheckCompiler {\n  constructor(private options: AotCompilerOptions, private reflector: StaticReflector) {}\n\n  /**\n   * Important notes:\n   * - This must not produce new `import` statements, but only refer to types outside\n   *   of the file via the variables provided via externalReferenceVars.\n   *   This allows Typescript to reuse the old program's structure as no imports have changed.\n   * - This must not produce any exports, as this would pollute the .d.ts file\n   *   and also violate the point above.\n   */\n  compileComponent(\n      componentId: string, component: CompileDirectiveMetadata, template: TemplateAst[],\n      usedPipes: CompilePipeSummary[], externalReferenceVars: Map<StaticSymbol, string>,\n      ctx: OutputContext): o.Statement[] {\n    const pipes = new Map<string, StaticSymbol>();\n    usedPipes.forEach(p => pipes.set(p.name, p.type.reference));\n    let embeddedViewCount = 0;\n    const viewBuilderFactory =\n        (parent: ViewBuilder|null, guards: GuardExpression[]): ViewBuilder => {\n          const embeddedViewIndex = embeddedViewCount++;\n          return new ViewBuilder(\n              this.options, this.reflector, externalReferenceVars, parent, component.type.reference,\n              component.isHost, embeddedViewIndex, pipes, guards, ctx, viewBuilderFactory);\n        };\n\n    const visitor = viewBuilderFactory(null, []);\n    visitor.visitAll([], template);\n\n    return visitor.build(componentId);\n  }\n}\n\ninterface GuardExpression {\n  guard: StaticSymbol;\n  useIf: boolean;\n  expression: Expression;\n}\n\ninterface ViewBuilderFactory {\n  (parent: ViewBuilder, guards: GuardExpression[]): ViewBuilder;\n}\n\n// Note: This is used as key in Map and should therefore be\n// unique per value.\ntype OutputVarType = o.BuiltinTypeName|StaticSymbol;\n\ninterface Expression {\n  context: OutputVarType;\n  sourceSpan: ParseSourceSpan;\n  value: AST;\n}\n\nconst DYNAMIC_VAR_NAME = '_any';\n\nclass TypeCheckLocalResolver implements LocalResolver {\n  notifyImplicitReceiverUse(): void {}\n  maybeRestoreView(): void {}\n  getLocal(name: string): o.Expression|null {\n    if (name === EventHandlerVars.event.name) {\n      // References to the event should not be type-checked.\n      // TODO(chuckj): determine a better type for the event.\n      return o.variable(DYNAMIC_VAR_NAME);\n    }\n    return null;\n  }\n}\n\nconst defaultResolver = new TypeCheckLocalResolver();\n\nclass ViewBuilder implements TemplateAstVisitor, LocalResolver {\n  private refOutputVars = new Map<string, OutputVarType>();\n  private variables: VariableAst[] = [];\n  private children: ViewBuilder[] = [];\n  private updates: Expression[] = [];\n  private actions: Expression[] = [];\n\n  constructor(\n      private options: AotCompilerOptions, private reflector: StaticReflector,\n      private externalReferenceVars: Map<StaticSymbol, string>, private parent: ViewBuilder|null,\n      private component: StaticSymbol, private isHostComponent: boolean,\n      private embeddedViewIndex: number, private pipes: Map<string, StaticSymbol>,\n      private guards: GuardExpression[], private ctx: OutputContext,\n      private viewBuilderFactory: ViewBuilderFactory) {}\n\n  private getOutputVar(type: o.BuiltinTypeName|StaticSymbol): string {\n    let varName: string|undefined;\n    if (type === this.component && this.isHostComponent) {\n      varName = DYNAMIC_VAR_NAME;\n    } else if (type instanceof StaticSymbol) {\n      varName = this.externalReferenceVars.get(type);\n    } else {\n      varName = DYNAMIC_VAR_NAME;\n    }\n    if (!varName) {\n      throw new Error(\n          `Illegal State: referring to a type without a variable ${JSON.stringify(type)}`);\n    }\n    return varName;\n  }\n\n  private getTypeGuardExpressions(ast: EmbeddedTemplateAst): GuardExpression[] {\n    const result = [...this.guards];\n    for (let directive of ast.directives) {\n      for (let input of directive.inputs) {\n        const guard = directive.directive.guards[input.directiveName];\n        if (guard) {\n          const useIf = guard === 'UseIf';\n          result.push({\n            guard,\n            useIf,\n            expression: {\n              context: this.component,\n              value: input.value,\n              sourceSpan: input.sourceSpan,\n            },\n          });\n        }\n      }\n    }\n    return result;\n  }\n\n  visitAll(variables: VariableAst[], astNodes: TemplateAst[]) {\n    this.variables = variables;\n    templateVisitAll(this, astNodes);\n  }\n\n  build(componentId: string, targetStatements: o.Statement[] = []): o.Statement[] {\n    this.children.forEach((child) => child.build(componentId, targetStatements));\n    let viewStmts: o.Statement[] =\n        [o.variable(DYNAMIC_VAR_NAME).set(o.NULL_EXPR).toDeclStmt(o.DYNAMIC_TYPE)];\n    let bindingCount = 0;\n    this.updates.forEach((expression) => {\n      const {sourceSpan, context, value} = this.preprocessUpdateExpression(expression);\n      const bindingId = `${bindingCount++}`;\n      const nameResolver = context === this.component ? this : defaultResolver;\n      const {stmts, currValExpr} = convertPropertyBinding(\n          nameResolver, o.variable(this.getOutputVar(context)), value, bindingId,\n          BindingForm.General);\n      stmts.push(new o.ExpressionStatement(currValExpr));\n      viewStmts.push(...stmts.map(\n          (stmt: o.Statement) => o.applySourceSpanToStatementIfNeeded(stmt, sourceSpan)));\n    });\n\n    this.actions.forEach(({sourceSpan, context, value}) => {\n      const bindingId = `${bindingCount++}`;\n      const nameResolver = context === this.component ? this : defaultResolver;\n      const {stmts} = convertActionBinding(\n          nameResolver, o.variable(this.getOutputVar(context)), value, bindingId);\n      viewStmts.push(...stmts.map(\n          (stmt: o.Statement) => o.applySourceSpanToStatementIfNeeded(stmt, sourceSpan)));\n    });\n\n    if (this.guards.length) {\n      let guardExpression: o.Expression|undefined = undefined;\n      for (const guard of this.guards) {\n        const {context, value} = this.preprocessUpdateExpression(guard.expression);\n        const bindingId = `${bindingCount++}`;\n        const nameResolver = context === this.component ? this : defaultResolver;\n        // We only support support simple expressions and ignore others as they\n        // are unlikely to affect type narrowing.\n        const {stmts, currValExpr} = convertPropertyBinding(\n            nameResolver, o.variable(this.getOutputVar(context)), value, bindingId,\n            BindingForm.TrySimple);\n        if (stmts.length == 0) {\n          const guardClause =\n              guard.useIf ? currValExpr : this.ctx.importExpr(guard.guard).callFn([currValExpr]);\n          guardExpression = guardExpression ? guardExpression.and(guardClause) : guardClause;\n        }\n      }\n      if (guardExpression) {\n        viewStmts = [new o.IfStmt(guardExpression, viewStmts)];\n      }\n    }\n\n    const viewName = `_View_${componentId}_${this.embeddedViewIndex}`;\n    const viewFactory = new o.DeclareFunctionStmt(viewName, [], viewStmts);\n    targetStatements.push(viewFactory);\n    return targetStatements;\n  }\n\n  visitBoundText(ast: BoundTextAst, context: any): any {\n    const astWithSource = <ASTWithSource>ast.value;\n    const inter = <Interpolation>astWithSource.ast;\n\n    inter.expressions.forEach(\n        (expr) =>\n            this.updates.push({context: this.component, value: expr, sourceSpan: ast.sourceSpan}));\n  }\n\n  visitEmbeddedTemplate(ast: EmbeddedTemplateAst, context: any): any {\n    this.visitElementOrTemplate(ast);\n    // Note: The old view compiler used to use an `any` type\n    // for the context in any embedded view.\n    // We keep this behaivor behind a flag for now.\n    if (this.options.fullTemplateTypeCheck) {\n      // Find any applicable type guards. For example, NgIf has a type guard on ngIf\n      // (see NgIf.ngIfTypeGuard) that can be used to indicate that a template is only\n      // stamped out if ngIf is truthy so any bindings in the template can assume that,\n      // if a nullable type is used for ngIf, that expression is not null or undefined.\n      const guards = this.getTypeGuardExpressions(ast);\n      const childVisitor = this.viewBuilderFactory(this, guards);\n      this.children.push(childVisitor);\n      childVisitor.visitAll(ast.variables, ast.children);\n    }\n  }\n\n  visitElement(ast: ElementAst, context: any): any {\n    this.visitElementOrTemplate(ast);\n\n    let inputDefs: o.Expression[] = [];\n    let updateRendererExpressions: Expression[] = [];\n    let outputDefs: o.Expression[] = [];\n    ast.inputs.forEach((inputAst) => {\n      this.updates.push(\n          {context: this.component, value: inputAst.value, sourceSpan: inputAst.sourceSpan});\n    });\n\n    templateVisitAll(this, ast.children);\n  }\n\n  private visitElementOrTemplate(ast: {\n    outputs: BoundEventAst[],\n    directives: DirectiveAst[],\n    references: ReferenceAst[],\n  }) {\n    ast.directives.forEach((dirAst) => {\n      this.visitDirective(dirAst);\n    });\n\n    ast.references.forEach((ref) => {\n      let outputVarType: OutputVarType = null!;\n      // Note: The old view compiler used to use an `any` type\n      // for directives exposed via `exportAs`.\n      // We keep this behaivor behind a flag for now.\n      if (ref.value && ref.value.identifier && this.options.fullTemplateTypeCheck) {\n        outputVarType = ref.value.identifier.reference;\n      } else {\n        outputVarType = o.BuiltinTypeName.Dynamic;\n      }\n      this.refOutputVars.set(ref.name, outputVarType);\n    });\n    ast.outputs.forEach((outputAst) => {\n      this.actions.push(\n          {context: this.component, value: outputAst.handler, sourceSpan: outputAst.sourceSpan});\n    });\n  }\n\n  visitDirective(dirAst: DirectiveAst) {\n    const dirType = dirAst.directive.type.reference;\n    dirAst.inputs.forEach(\n        (input) => this.updates.push(\n            {context: this.component, value: input.value, sourceSpan: input.sourceSpan}));\n    // Note: The old view compiler used to use an `any` type\n    // for expressions in host properties / events.\n    // We keep this behaivor behind a flag for now.\n    if (this.options.fullTemplateTypeCheck) {\n      dirAst.hostProperties.forEach(\n          (inputAst) => this.updates.push(\n              {context: dirType, value: inputAst.value, sourceSpan: inputAst.sourceSpan}));\n      dirAst.hostEvents.forEach((hostEventAst) => this.actions.push({\n        context: dirType,\n        value: hostEventAst.handler,\n        sourceSpan: hostEventAst.sourceSpan\n      }));\n    }\n  }\n\n  notifyImplicitReceiverUse(): void {}\n  maybeRestoreView(): void {}\n\n  getLocal(name: string): o.Expression|null {\n    if (name == EventHandlerVars.event.name) {\n      return o.variable(this.getOutputVar(o.BuiltinTypeName.Dynamic));\n    }\n    for (let currBuilder: ViewBuilder|null = this; currBuilder; currBuilder = currBuilder.parent) {\n      let outputVarType: OutputVarType|undefined;\n      // check references\n      outputVarType = currBuilder.refOutputVars.get(name);\n      if (outputVarType == null) {\n        // check variables\n        const varAst = currBuilder.variables.find((varAst) => varAst.name === name);\n        if (varAst) {\n          outputVarType = o.BuiltinTypeName.Dynamic;\n        }\n      }\n      if (outputVarType != null) {\n        return o.variable(this.getOutputVar(outputVarType));\n      }\n    }\n    return null;\n  }\n\n  private pipeOutputVar(name: string): string {\n    const pipe = this.pipes.get(name);\n    if (!pipe) {\n      throw new Error(\n          `Illegal State: Could not find pipe ${name} in template of ${this.component}`);\n    }\n    return this.getOutputVar(pipe);\n  }\n\n  private preprocessUpdateExpression(expression: Expression): Expression {\n    return {\n      sourceSpan: expression.sourceSpan,\n      context: expression.context,\n      value: convertPropertyBindingBuiltins(\n          {\n            createLiteralArrayConverter: (argCount: number) => (args: o.Expression[]) => {\n              const arr = o.literalArr(args);\n              // Note: The old view compiler used to use an `any` type\n              // for arrays.\n              return this.options.fullTemplateTypeCheck ? arr : arr.cast(o.DYNAMIC_TYPE);\n            },\n            createLiteralMapConverter: (keys: {key: string, quoted: boolean}[]) =>\n                (values: o.Expression[]) => {\n                  const entries = keys.map((k, i) => ({\n                                             key: k.key,\n                                             value: values[i],\n                                             quoted: k.quoted,\n                                           }));\n                  const map = o.literalMap(entries);\n                  // Note: The old view compiler used to use an `any` type\n                  // for maps.\n                  return this.options.fullTemplateTypeCheck ? map : map.cast(o.DYNAMIC_TYPE);\n                },\n            createPipeConverter: (name: string, argCount: number) => (args: o.Expression[]) => {\n              // Note: The old view compiler used to use an `any` type\n              // for pipes.\n              const pipeExpr = this.options.fullTemplateTypeCheck ?\n                  o.variable(this.pipeOutputVar(name)) :\n                  o.variable(this.getOutputVar(o.BuiltinTypeName.Dynamic));\n              return pipeExpr.callMethod('transform', args);\n            },\n          },\n          expression.value)\n    };\n  }\n\n  visitNgContent(ast: NgContentAst, context: any): any {}\n  visitText(ast: TextAst, context: any): any {}\n  visitDirectiveProperty(ast: BoundDirectivePropertyAst, context: any): any {}\n  visitReference(ast: ReferenceAst, context: any): any {}\n  visitVariable(ast: VariableAst, context: any): any {}\n  visitEvent(ast: BoundEventAst, context: any): any {}\n  visitElementProperty(ast: BoundElementPropertyAst, context: any): any {}\n  visitAttr(ast: AttrAst, context: any): any {}\n}\n"]} |
---|