@angular/compiler 17.0.0-next.4 → 17.0.0-next.6

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.
Files changed (56) hide show
  1. package/esm2022/src/compiler.mjs +1 -1
  2. package/esm2022/src/i18n/extractor_merger.mjs +1 -4
  3. package/esm2022/src/i18n/i18n_parser.mjs +1 -6
  4. package/esm2022/src/i18n/serializers/xliff.mjs +1 -3
  5. package/esm2022/src/i18n/serializers/xliff2.mjs +1 -3
  6. package/esm2022/src/i18n/serializers/xtb.mjs +1 -3
  7. package/esm2022/src/jit_compiler_facade.mjs +33 -7
  8. package/esm2022/src/ml_parser/ast.mjs +1 -17
  9. package/esm2022/src/ml_parser/html_whitespaces.mjs +2 -5
  10. package/esm2022/src/ml_parser/icu_ast_expander.mjs +2 -5
  11. package/esm2022/src/ml_parser/lexer.mjs +59 -49
  12. package/esm2022/src/ml_parser/parser.mjs +26 -71
  13. package/esm2022/src/ml_parser/tokens.mjs +1 -1
  14. package/esm2022/src/render3/partial/class_metadata.mjs +1 -1
  15. package/esm2022/src/render3/partial/component.mjs +5 -2
  16. package/esm2022/src/render3/partial/directive.mjs +1 -1
  17. package/esm2022/src/render3/partial/factory.mjs +1 -1
  18. package/esm2022/src/render3/partial/injectable.mjs +1 -1
  19. package/esm2022/src/render3/partial/injector.mjs +1 -1
  20. package/esm2022/src/render3/partial/ng_module.mjs +1 -1
  21. package/esm2022/src/render3/partial/pipe.mjs +1 -1
  22. package/esm2022/src/render3/r3_ast.mjs +10 -3
  23. package/esm2022/src/render3/r3_class_metadata_compiler.mjs +14 -16
  24. package/esm2022/src/render3/r3_control_flow.mjs +116 -96
  25. package/esm2022/src/render3/r3_deferred_blocks.mjs +37 -39
  26. package/esm2022/src/render3/r3_deferred_triggers.mjs +30 -22
  27. package/esm2022/src/render3/r3_module_compiler.mjs +9 -11
  28. package/esm2022/src/render3/r3_template_transform.mjs +73 -31
  29. package/esm2022/src/render3/view/api.mjs +1 -1
  30. package/esm2022/src/render3/view/compiler.mjs +17 -6
  31. package/esm2022/src/render3/view/i18n/meta.mjs +1 -5
  32. package/esm2022/src/render3/view/t2_api.mjs +1 -1
  33. package/esm2022/src/render3/view/t2_binder.mjs +184 -79
  34. package/esm2022/src/render3/view/template.mjs +93 -83
  35. package/esm2022/src/template/pipeline/ir/src/enums.mjs +14 -7
  36. package/esm2022/src/template/pipeline/ir/src/expression.mjs +6 -4
  37. package/esm2022/src/template/pipeline/ir/src/ops/create.mjs +30 -4
  38. package/esm2022/src/template/pipeline/src/compilation.mjs +6 -1
  39. package/esm2022/src/template/pipeline/src/conversion.mjs +7 -1
  40. package/esm2022/src/template/pipeline/src/emit.mjs +7 -1
  41. package/esm2022/src/template/pipeline/src/ingest.mjs +91 -42
  42. package/esm2022/src/template/pipeline/src/instruction.mjs +43 -27
  43. package/esm2022/src/template/pipeline/src/phases/const_collection.mjs +22 -29
  44. package/esm2022/src/template/pipeline/src/phases/generate_projection_def.mjs +46 -0
  45. package/esm2022/src/template/pipeline/src/phases/i18n_const_collection.mjs +33 -0
  46. package/esm2022/src/template/pipeline/src/phases/i18n_message_extraction.mjs +3 -2
  47. package/esm2022/src/template/pipeline/src/phases/no_listeners_on_templates.mjs +1 -5
  48. package/esm2022/src/template/pipeline/src/phases/phase_remove_content_selectors.mjs +39 -0
  49. package/esm2022/src/template/pipeline/src/phases/reify.mjs +23 -14
  50. package/esm2022/src/version.mjs +1 -1
  51. package/fesm2022/compiler.mjs +3425 -3072
  52. package/fesm2022/compiler.mjs.map +1 -1
  53. package/fesm2022/testing.mjs +1 -1
  54. package/index.d.ts +154 -143
  55. package/package.json +3 -3
  56. package/testing/index.d.ts +1 -1
@@ -9,6 +9,7 @@ import { SecurityContext } from '../../../core';
9
9
  import * as e from '../../../expression_parser/ast';
10
10
  import { splitNsName } from '../../../ml_parser/tags';
11
11
  import * as o from '../../../output/output_ast';
12
+ import { ParseSourceSpan } from '../../../parse_util';
12
13
  import * as t from '../../../render3/r3_ast';
13
14
  import * as ir from '../ir';
14
15
  import { ComponentCompilationJob, HostBindingCompilationJob } from './compilation';
@@ -17,6 +18,7 @@ const compatibilityMode = ir.CompatibilityMode.TemplateDefinitionBuilder;
17
18
  /**
18
19
  * Process a template AST and convert it into a `ComponentCompilation` in the intermediate
19
20
  * representation.
21
+ * TODO: Refactor more of the ingestion code into phases.
20
22
  */
21
23
  export function ingestComponent(componentName, template, constantPool, relativeContextFilePath, i18nUseExternalIds) {
22
24
  const cpl = new ComponentCompilationJob(componentName, constantPool, compatibilityMode, relativeContextFilePath, i18nUseExternalIds);
@@ -46,11 +48,10 @@ export function ingestHostProperty(job, property, isTextAttribute) {
46
48
  let expression;
47
49
  const ast = property.expression.ast;
48
50
  if (ast instanceof e.Interpolation) {
49
- expression =
50
- new ir.Interpolation(ast.strings, ast.expressions.map(expr => convertAst(expr, job)));
51
+ expression = new ir.Interpolation(ast.strings, ast.expressions.map(expr => convertAst(expr, job, property.sourceSpan)));
51
52
  }
52
53
  else {
53
- expression = convertAst(ast, job);
54
+ expression = convertAst(ast, job, property.sourceSpan);
54
55
  }
55
56
  let bindingKind = ir.BindingKind.Property;
56
57
  // TODO: this should really be handled in the parser.
@@ -70,9 +71,9 @@ export function ingestHostAttribute(job, name, value) {
70
71
  job.root.update.push(attrBinding);
71
72
  }
72
73
  export function ingestHostEvent(job, event) {
73
- const eventBinding = ir.createListenerOp(job.root.xref, event.name, null, event.targetOrPhase, true);
74
+ const eventBinding = ir.createListenerOp(job.root.xref, event.name, null, event.targetOrPhase, true, event.sourceSpan);
74
75
  // TODO: Can this be a chain?
75
- eventBinding.handlerOps.push(ir.createStatementOp(new o.ReturnStatement(convertAst(event.handler.ast, job))));
76
+ eventBinding.handlerOps.push(ir.createStatementOp(new o.ReturnStatement(convertAst(event.handler.ast, job, event.sourceSpan), event.handlerSpan)));
76
77
  job.root.create.push(eventBinding);
77
78
  }
78
79
  /**
@@ -86,6 +87,9 @@ function ingestNodes(unit, template) {
86
87
  else if (node instanceof t.Template) {
87
88
  ingestTemplate(unit, node);
88
89
  }
90
+ else if (node instanceof t.Content) {
91
+ ingestContent(unit, node);
92
+ }
89
93
  else if (node instanceof t.Text) {
90
94
  ingestText(unit, node);
91
95
  }
@@ -128,7 +132,7 @@ function ingestTemplate(unit, tmpl) {
128
132
  [namespacePrefix, tagNameWithoutNamespace] = splitNsName(tmpl.tagName);
129
133
  }
130
134
  // TODO: validate the fallback tag name here.
131
- const tplOp = ir.createTemplateOp(childView.xref, tagNameWithoutNamespace ?? 'ng-template', namespaceForKey(namespacePrefix), tmpl.i18n, tmpl.startSourceSpan);
135
+ const tplOp = ir.createTemplateOp(childView.xref, tagNameWithoutNamespace ?? 'ng-template', namespaceForKey(namespacePrefix), false, tmpl.i18n, tmpl.startSourceSpan);
132
136
  unit.create.push(tplOp);
133
137
  ingestBindings(unit, tplOp, tmpl);
134
138
  ingestReferences(tplOp, tmpl);
@@ -137,6 +141,16 @@ function ingestTemplate(unit, tmpl) {
137
141
  childView.contextVariables.set(name, value);
138
142
  }
139
143
  }
144
+ /**
145
+ * Ingest a literal text node from the AST into the given `ViewCompilation`.
146
+ */
147
+ function ingestContent(unit, content) {
148
+ const op = ir.createProjectionOp(unit.job.allocateXrefId(), content.selector);
149
+ for (const attr of content.attributes) {
150
+ ingestBinding(unit, op.xref, attr.name, o.literal(attr.value), 1 /* e.BindingType.Attribute */, null, SecurityContext.NONE, attr.sourceSpan, true, false);
151
+ }
152
+ unit.create.push(op);
153
+ }
140
154
  /**
141
155
  * Ingest a literal text node from the AST into the given `ViewCompilation`.
142
156
  */
@@ -156,10 +170,14 @@ function ingestBoundText(unit, text) {
156
170
  }
157
171
  const textXref = unit.job.allocateXrefId();
158
172
  unit.create.push(ir.createTextOp(textXref, '', text.sourceSpan));
159
- unit.update.push(ir.createInterpolateTextOp(textXref, new ir.Interpolation(value.strings, value.expressions.map(expr => convertAst(expr, unit.job))), text.sourceSpan));
173
+ // TemplateDefinitionBuilder does not generate source maps for sub-expressions inside an
174
+ // interpolation. We copy that behavior in compatibility mode.
175
+ // TODO: is it actually correct to generate these extra maps in modern mode?
176
+ const baseSourceSpan = unit.job.compatibility ? null : text.sourceSpan;
177
+ unit.update.push(ir.createInterpolateTextOp(textXref, new ir.Interpolation(value.strings, value.expressions.map(expr => convertAst(expr, unit.job, baseSourceSpan))), text.sourceSpan));
160
178
  }
161
179
  /**
162
- * Ingest a `{#switch}` block into the given `ViewCompilation`.
180
+ * Ingest a `@switch` block into the given `ViewCompilation`.
163
181
  */
164
182
  function ingestSwitchBlock(unit, switchBlock) {
165
183
  let firstXref = null;
@@ -168,59 +186,62 @@ function ingestSwitchBlock(unit, switchBlock) {
168
186
  const cView = unit.job.allocateView(unit.xref);
169
187
  if (!firstXref)
170
188
  firstXref = cView.xref;
171
- unit.create.push(ir.createTemplateOp(cView.xref, 'Case', ir.Namespace.HTML, undefined, null));
172
- const caseExpr = switchCase.expression ? convertAst(switchCase.expression, unit.job) : null;
189
+ unit.create.push(ir.createTemplateOp(cView.xref, 'Case', ir.Namespace.HTML, true, undefined, null));
190
+ const caseExpr = switchCase.expression ?
191
+ convertAst(switchCase.expression, unit.job, switchBlock.startSourceSpan) :
192
+ null;
173
193
  conditions.push([cView.xref, caseExpr]);
174
194
  ingestNodes(cView, switchCase.children);
175
195
  }
176
- const conditional = ir.createConditionalOp(firstXref, convertAst(switchBlock.expression, unit.job), null);
196
+ const conditional = ir.createConditionalOp(firstXref, convertAst(switchBlock.expression, unit.job, switchBlock.startSourceSpan), null);
177
197
  conditional.conditions = conditions;
178
198
  unit.update.push(conditional);
179
199
  }
180
200
  /**
181
201
  * Convert a template AST expression into an output AST expression.
182
202
  */
183
- function convertAst(ast, job) {
203
+ function convertAst(ast, job, baseSourceSpan) {
184
204
  if (ast instanceof e.ASTWithSource) {
185
- return convertAst(ast.ast, job);
205
+ return convertAst(ast.ast, job, baseSourceSpan);
186
206
  }
187
207
  else if (ast instanceof e.PropertyRead) {
188
208
  if (ast.receiver instanceof e.ImplicitReceiver && !(ast.receiver instanceof e.ThisReceiver)) {
189
209
  return new ir.LexicalReadExpr(ast.name);
190
210
  }
191
211
  else {
192
- return new o.ReadPropExpr(convertAst(ast.receiver, job), ast.name);
212
+ return new o.ReadPropExpr(convertAst(ast.receiver, job, baseSourceSpan), ast.name, null, convertSourceSpan(ast.span, baseSourceSpan));
193
213
  }
194
214
  }
195
215
  else if (ast instanceof e.PropertyWrite) {
196
- return new o.WritePropExpr(convertAst(ast.receiver, job), ast.name, convertAst(ast.value, job));
216
+ return new o.WritePropExpr(convertAst(ast.receiver, job, baseSourceSpan), ast.name, convertAst(ast.value, job, baseSourceSpan), undefined, convertSourceSpan(ast.span, baseSourceSpan));
197
217
  }
198
218
  else if (ast instanceof e.KeyedWrite) {
199
- return new o.WriteKeyExpr(convertAst(ast.receiver, job), convertAst(ast.key, job), convertAst(ast.value, job));
219
+ return new o.WriteKeyExpr(convertAst(ast.receiver, job, baseSourceSpan), convertAst(ast.key, job, baseSourceSpan), convertAst(ast.value, job, baseSourceSpan), undefined, convertSourceSpan(ast.span, baseSourceSpan));
200
220
  }
201
221
  else if (ast instanceof e.Call) {
202
222
  if (ast.receiver instanceof e.ImplicitReceiver) {
203
223
  throw new Error(`Unexpected ImplicitReceiver`);
204
224
  }
205
225
  else {
206
- return new o.InvokeFunctionExpr(convertAst(ast.receiver, job), ast.args.map(arg => convertAst(arg, job)));
226
+ return new o.InvokeFunctionExpr(convertAst(ast.receiver, job, baseSourceSpan), ast.args.map(arg => convertAst(arg, job, baseSourceSpan)), undefined, convertSourceSpan(ast.span, baseSourceSpan));
207
227
  }
208
228
  }
209
229
  else if (ast instanceof e.LiteralPrimitive) {
210
- return o.literal(ast.value);
230
+ return o.literal(ast.value, undefined, convertSourceSpan(ast.span, baseSourceSpan));
211
231
  }
212
232
  else if (ast instanceof e.Binary) {
213
233
  const operator = BINARY_OPERATORS.get(ast.operation);
214
234
  if (operator === undefined) {
215
235
  throw new Error(`AssertionError: unknown binary operator ${ast.operation}`);
216
236
  }
217
- return new o.BinaryOperatorExpr(operator, convertAst(ast.left, job), convertAst(ast.right, job));
237
+ return new o.BinaryOperatorExpr(operator, convertAst(ast.left, job, baseSourceSpan), convertAst(ast.right, job, baseSourceSpan), undefined, convertSourceSpan(ast.span, baseSourceSpan));
218
238
  }
219
239
  else if (ast instanceof e.ThisReceiver) {
240
+ // TODO: should context expressions have source maps?
220
241
  return new ir.ContextExpr(job.root.xref);
221
242
  }
222
243
  else if (ast instanceof e.KeyedRead) {
223
- return new o.ReadKeyExpr(convertAst(ast.receiver, job), convertAst(ast.key, job));
244
+ return new o.ReadKeyExpr(convertAst(ast.receiver, job, baseSourceSpan), convertAst(ast.key, job, baseSourceSpan), undefined, convertSourceSpan(ast.span, baseSourceSpan));
224
245
  }
225
246
  else if (ast instanceof e.Chain) {
226
247
  throw new Error(`AssertionError: Chain in unknown context`);
@@ -228,37 +249,42 @@ function convertAst(ast, job) {
228
249
  else if (ast instanceof e.LiteralMap) {
229
250
  const entries = ast.keys.map((key, idx) => {
230
251
  const value = ast.values[idx];
231
- return new o.LiteralMapEntry(key.key, convertAst(value, job), key.quoted);
252
+ // TODO: should literals have source maps, or do we just map the whole surrounding expression?
253
+ return new o.LiteralMapEntry(key.key, convertAst(value, job, baseSourceSpan), key.quoted);
232
254
  });
233
- return new o.LiteralMapExpr(entries);
255
+ return new o.LiteralMapExpr(entries, undefined, convertSourceSpan(ast.span, baseSourceSpan));
234
256
  }
235
257
  else if (ast instanceof e.LiteralArray) {
236
- return new o.LiteralArrayExpr(ast.expressions.map(expr => convertAst(expr, job)));
258
+ // TODO: should literals have source maps, or do we just map the whole surrounding expression?
259
+ return new o.LiteralArrayExpr(ast.expressions.map(expr => convertAst(expr, job, baseSourceSpan)));
237
260
  }
238
261
  else if (ast instanceof e.Conditional) {
239
- return new o.ConditionalExpr(convertAst(ast.condition, job), convertAst(ast.trueExp, job), convertAst(ast.falseExp, job));
262
+ return new o.ConditionalExpr(convertAst(ast.condition, job, baseSourceSpan), convertAst(ast.trueExp, job, baseSourceSpan), convertAst(ast.falseExp, job, baseSourceSpan), undefined, convertSourceSpan(ast.span, baseSourceSpan));
240
263
  }
241
264
  else if (ast instanceof e.NonNullAssert) {
242
265
  // A non-null assertion shouldn't impact generated instructions, so we can just drop it.
243
- return convertAst(ast.expression, job);
266
+ return convertAst(ast.expression, job, baseSourceSpan);
244
267
  }
245
268
  else if (ast instanceof e.BindingPipe) {
269
+ // TODO: pipes should probably have source maps; figure out details.
246
270
  return new ir.PipeBindingExpr(job.allocateXrefId(), ast.name, [
247
- convertAst(ast.exp, job),
248
- ...ast.args.map(arg => convertAst(arg, job)),
271
+ convertAst(ast.exp, job, baseSourceSpan),
272
+ ...ast.args.map(arg => convertAst(arg, job, baseSourceSpan)),
249
273
  ]);
250
274
  }
251
275
  else if (ast instanceof e.SafeKeyedRead) {
252
- return new ir.SafeKeyedReadExpr(convertAst(ast.receiver, job), convertAst(ast.key, job));
276
+ return new ir.SafeKeyedReadExpr(convertAst(ast.receiver, job, baseSourceSpan), convertAst(ast.key, job, baseSourceSpan), convertSourceSpan(ast.span, baseSourceSpan));
253
277
  }
254
278
  else if (ast instanceof e.SafePropertyRead) {
255
- return new ir.SafePropertyReadExpr(convertAst(ast.receiver, job), ast.name);
279
+ // TODO: source span
280
+ return new ir.SafePropertyReadExpr(convertAst(ast.receiver, job, baseSourceSpan), ast.name);
256
281
  }
257
282
  else if (ast instanceof e.SafeCall) {
258
- return new ir.SafeInvokeFunctionExpr(convertAst(ast.receiver, job), ast.args.map(a => convertAst(a, job)));
283
+ // TODO: source span
284
+ return new ir.SafeInvokeFunctionExpr(convertAst(ast.receiver, job, baseSourceSpan), ast.args.map(a => convertAst(a, job, baseSourceSpan)));
259
285
  }
260
286
  else if (ast instanceof e.EmptyExpr) {
261
- return new ir.EmptyExpr();
287
+ return new ir.EmptyExpr(convertSourceSpan(ast.span, baseSourceSpan));
262
288
  }
263
289
  else {
264
290
  throw new Error(`Unhandled expression type: ${ast.constructor.name}`);
@@ -295,30 +321,31 @@ function ingestBindings(unit, op, element) {
295
321
  throw Error('Animation listener should have a phase');
296
322
  }
297
323
  }
298
- listenerOp = ir.createListenerOp(op.xref, output.name, op.tag, output.phase, false);
324
+ listenerOp =
325
+ ir.createListenerOp(op.xref, output.name, op.tag, output.phase, false, output.sourceSpan);
299
326
  // if output.handler is a chain, then push each statement from the chain separately, and
300
327
  // return the last one?
301
- let inputExprs;
328
+ let handlerExprs;
302
329
  let handler = output.handler;
303
330
  if (handler instanceof e.ASTWithSource) {
304
331
  handler = handler.ast;
305
332
  }
306
333
  if (handler instanceof e.Chain) {
307
- inputExprs = handler.expressions;
334
+ handlerExprs = handler.expressions;
308
335
  }
309
336
  else {
310
- inputExprs = [handler];
337
+ handlerExprs = [handler];
311
338
  }
312
- if (inputExprs.length === 0) {
339
+ if (handlerExprs.length === 0) {
313
340
  throw new Error('Expected listener to have non-empty expression list.');
314
341
  }
315
- const expressions = inputExprs.map(expr => convertAst(expr, unit.job));
342
+ const expressions = handlerExprs.map(expr => convertAst(expr, unit.job, output.handlerSpan));
316
343
  const returnExpr = expressions.pop();
317
344
  for (const expr of expressions) {
318
- const stmtOp = ir.createStatementOp(new o.ExpressionStatement(expr));
345
+ const stmtOp = ir.createStatementOp(new o.ExpressionStatement(expr, expr.sourceSpan));
319
346
  listenerOp.handlerOps.push(stmtOp);
320
347
  }
321
- listenerOp.handlerOps.push(ir.createStatementOp(new o.ReturnStatement(returnExpr)));
348
+ listenerOp.handlerOps.push(ir.createStatementOp(new o.ReturnStatement(returnExpr, returnExpr.sourceSpan)));
322
349
  unit.create.push(listenerOp);
323
350
  }
324
351
  }
@@ -334,11 +361,13 @@ function ingestBinding(view, xref, name, value, type, unit, securityContext, sou
334
361
  value = value.ast;
335
362
  }
336
363
  let expression;
364
+ // TODO: We could easily generate source maps for subexpressions in these cases, but
365
+ // TemplateDefinitionBuilder does not. Should we do so?
337
366
  if (value instanceof e.Interpolation) {
338
- expression = new ir.Interpolation(value.strings, value.expressions.map(expr => convertAst(expr, view.job)));
367
+ expression = new ir.Interpolation(value.strings, value.expressions.map(expr => convertAst(expr, view.job, null)));
339
368
  }
340
369
  else if (value instanceof e.AST) {
341
- expression = convertAst(value, view.job);
370
+ expression = convertAst(value, view.job, null);
342
371
  }
343
372
  else {
344
373
  expression = value;
@@ -367,4 +396,24 @@ function assertIsArray(value) {
367
396
  throw new Error(`AssertionError: expected an array`);
368
397
  }
369
398
  }
370
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"ingest.js","sourceRoot":"","sources":["../../../../../../../../../packages/compiler/src/template/pipeline/src/ingest.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 {ConstantPool} from '../../../constant_pool';\nimport {SecurityContext} from '../../../core';\nimport * as e from '../../../expression_parser/ast';\nimport {splitNsName} from '../../../ml_parser/tags';\nimport * as o from '../../../output/output_ast';\nimport {ParseSourceSpan} from '../../../parse_util';\nimport * as t from '../../../render3/r3_ast';\nimport {BindingParser} from '../../../template_parser/binding_parser';\nimport * as ir from '../ir';\n\nimport {ComponentCompilationJob, HostBindingCompilationJob, type CompilationJob, type ViewCompilationUnit, HostBindingCompilationUnit} from './compilation';\nimport {BINARY_OPERATORS, namespaceForKey} from './conversion';\n\nconst compatibilityMode = ir.CompatibilityMode.TemplateDefinitionBuilder;\n\n/**\n * Process a template AST and convert it into a `ComponentCompilation` in the intermediate\n * representation.\n */\nexport function ingestComponent(\n    componentName: string, template: t.Node[], constantPool: ConstantPool,\n    relativeContextFilePath: string, i18nUseExternalIds: boolean): ComponentCompilationJob {\n  const cpl = new ComponentCompilationJob(\n      componentName, constantPool, compatibilityMode, relativeContextFilePath, i18nUseExternalIds);\n  ingestNodes(cpl.root, template);\n  return cpl;\n}\n\nexport interface HostBindingInput {\n  componentName: string;\n  properties: e.ParsedProperty[]|null;\n  attributes: {[key: string]: o.Expression};\n  events: e.ParsedEvent[]|null;\n}\n\n/**\n * Process a host binding AST and convert it into a `HostBindingCompilationJob` in the intermediate\n * representation.\n */\nexport function ingestHostBinding(\n    input: HostBindingInput, bindingParser: BindingParser,\n    constantPool: ConstantPool): HostBindingCompilationJob {\n  const job = new HostBindingCompilationJob(input.componentName, constantPool, compatibilityMode);\n  for (const property of input.properties ?? []) {\n    ingestHostProperty(job, property, false);\n  }\n  for (const [name, expr] of Object.entries(input.attributes) ?? []) {\n    ingestHostAttribute(job, name, expr);\n  }\n  for (const event of input.events ?? []) {\n    ingestHostEvent(job, event);\n  }\n  return job;\n}\n\n// TODO: We should refactor the parser to use the same types and structures for host bindings as\n// with ordinary components. This would allow us to share a lot more ingestion code.\nexport function ingestHostProperty(\n    job: HostBindingCompilationJob, property: e.ParsedProperty, isTextAttribute: boolean): void {\n  let expression: o.Expression|ir.Interpolation;\n  const ast = property.expression.ast;\n  if (ast instanceof e.Interpolation) {\n    expression =\n        new ir.Interpolation(ast.strings, ast.expressions.map(expr => convertAst(expr, job)));\n  } else {\n    expression = convertAst(ast, job);\n  }\n  let bindingKind = ir.BindingKind.Property;\n  // TODO: this should really be handled in the parser.\n  if (property.name.startsWith('attr.')) {\n    property.name = property.name.substring('attr.'.length);\n    bindingKind = ir.BindingKind.Attribute;\n  }\n  if (property.isAnimation) {\n    bindingKind = ir.BindingKind.Animation;\n  }\n  job.root.update.push(ir.createBindingOp(\n      job.root.xref, bindingKind, property.name, expression, null,\n      SecurityContext\n          .NONE /* TODO: what should we pass as security context? Passing NONE for now. */,\n      isTextAttribute, false, property.sourceSpan));\n}\n\nexport function ingestHostAttribute(\n    job: HostBindingCompilationJob, name: string, value: o.Expression): void {\n  const attrBinding = ir.createBindingOp(\n      job.root.xref, ir.BindingKind.Attribute, name, value, null, SecurityContext.NONE, true, false,\n      /* TODO: host attribute source spans */ null!);\n  job.root.update.push(attrBinding);\n}\n\nexport function ingestHostEvent(job: HostBindingCompilationJob, event: e.ParsedEvent) {\n  const eventBinding =\n      ir.createListenerOp(job.root.xref, event.name, null, event.targetOrPhase, true);\n  // TODO: Can this be a chain?\n  eventBinding.handlerOps.push(\n      ir.createStatementOp(new o.ReturnStatement(convertAst(event.handler.ast, job))));\n  job.root.create.push(eventBinding);\n}\n\n/**\n * Ingest the nodes of a template AST into the given `ViewCompilation`.\n */\nfunction ingestNodes(unit: ViewCompilationUnit, template: t.Node[]): void {\n  for (const node of template) {\n    if (node instanceof t.Element) {\n      ingestElement(unit, node);\n    } else if (node instanceof t.Template) {\n      ingestTemplate(unit, node);\n    } else if (node instanceof t.Text) {\n      ingestText(unit, node);\n    } else if (node instanceof t.BoundText) {\n      ingestBoundText(unit, node);\n    } else if (node instanceof t.SwitchBlock) {\n      ingestSwitchBlock(unit, node);\n    } else {\n      throw new Error(`Unsupported template node: ${node.constructor.name}`);\n    }\n  }\n}\n\n\n\n/**\n * Ingest an element AST from the template into the given `ViewCompilation`.\n */\nfunction ingestElement(unit: ViewCompilationUnit, element: t.Element): void {\n  const staticAttributes: Record<string, string> = {};\n  for (const attr of element.attributes) {\n    staticAttributes[attr.name] = attr.value;\n  }\n  const id = unit.job.allocateXrefId();\n\n  const [namespaceKey, elementName] = splitNsName(element.name);\n\n  const startOp = ir.createElementStartOp(\n      elementName, id, namespaceForKey(namespaceKey), element.i18n, element.startSourceSpan);\n  unit.create.push(startOp);\n\n  ingestBindings(unit, startOp, element);\n  ingestReferences(startOp, element);\n  ingestNodes(unit, element.children);\n\n  unit.create.push(ir.createElementEndOp(id, element.endSourceSpan));\n}\n\n/**\n * Ingest an `ng-template` node from the AST into the given `ViewCompilation`.\n */\nfunction ingestTemplate(unit: ViewCompilationUnit, tmpl: t.Template): void {\n  const childView = unit.job.allocateView(unit.xref);\n\n\n  let tagNameWithoutNamespace = tmpl.tagName;\n  let namespacePrefix: string|null = '';\n  if (tmpl.tagName) {\n    [namespacePrefix, tagNameWithoutNamespace] = splitNsName(tmpl.tagName);\n  }\n\n  // TODO: validate the fallback tag name here.\n  const tplOp = ir.createTemplateOp(\n      childView.xref, tagNameWithoutNamespace ?? 'ng-template', namespaceForKey(namespacePrefix),\n      tmpl.i18n, tmpl.startSourceSpan);\n  unit.create.push(tplOp);\n\n  ingestBindings(unit, tplOp, tmpl);\n  ingestReferences(tplOp, tmpl);\n  ingestNodes(childView, tmpl.children);\n\n  for (const {name, value} of tmpl.variables) {\n    childView.contextVariables.set(name, value);\n  }\n}\n\n/**\n * Ingest a literal text node from the AST into the given `ViewCompilation`.\n */\nfunction ingestText(unit: ViewCompilationUnit, text: t.Text): void {\n  unit.create.push(ir.createTextOp(unit.job.allocateXrefId(), text.value, text.sourceSpan));\n}\n\n/**\n * Ingest an interpolated text node from the AST into the given `ViewCompilation`.\n */\nfunction ingestBoundText(unit: ViewCompilationUnit, text: t.BoundText): void {\n  let value = text.value;\n  if (value instanceof e.ASTWithSource) {\n    value = value.ast;\n  }\n  if (!(value instanceof e.Interpolation)) {\n    throw new Error(\n        `AssertionError: expected Interpolation for BoundText node, got ${value.constructor.name}`);\n  }\n\n  const textXref = unit.job.allocateXrefId();\n  unit.create.push(ir.createTextOp(textXref, '', text.sourceSpan));\n  unit.update.push(ir.createInterpolateTextOp(\n      textXref,\n      new ir.Interpolation(\n          value.strings, value.expressions.map(expr => convertAst(expr, unit.job))),\n      text.sourceSpan));\n}\n\n/**\n * Ingest a `{#switch}` block into the given `ViewCompilation`.\n */\nfunction ingestSwitchBlock(unit: ViewCompilationUnit, switchBlock: t.SwitchBlock): void {\n  let firstXref: ir.XrefId|null = null;\n  let conditions: Array<[ir.XrefId, o.Expression | null]> = [];\n  for (const switchCase of switchBlock.cases) {\n    const cView = unit.job.allocateView(unit.xref);\n    if (!firstXref) firstXref = cView.xref;\n    unit.create.push(ir.createTemplateOp(cView.xref, 'Case', ir.Namespace.HTML, undefined, null!));\n    const caseExpr = switchCase.expression ? convertAst(switchCase.expression, unit.job) : null;\n    conditions.push([cView.xref, caseExpr]);\n    ingestNodes(cView, switchCase.children);\n  }\n  const conditional =\n      ir.createConditionalOp(firstXref!, convertAst(switchBlock.expression, unit.job), null!);\n  conditional.conditions = conditions;\n  unit.update.push(conditional);\n}\n\n/**\n * Convert a template AST expression into an output AST expression.\n */\nfunction convertAst(ast: e.AST, job: CompilationJob): o.Expression {\n  if (ast instanceof e.ASTWithSource) {\n    return convertAst(ast.ast, job);\n  } else if (ast instanceof e.PropertyRead) {\n    if (ast.receiver instanceof e.ImplicitReceiver && !(ast.receiver instanceof e.ThisReceiver)) {\n      return new ir.LexicalReadExpr(ast.name);\n    } else {\n      return new o.ReadPropExpr(convertAst(ast.receiver, job), ast.name);\n    }\n  } else if (ast instanceof e.PropertyWrite) {\n    return new o.WritePropExpr(convertAst(ast.receiver, job), ast.name, convertAst(ast.value, job));\n  } else if (ast instanceof e.KeyedWrite) {\n    return new o.WriteKeyExpr(\n        convertAst(ast.receiver, job),\n        convertAst(ast.key, job),\n        convertAst(ast.value, job),\n    );\n  } else if (ast instanceof e.Call) {\n    if (ast.receiver instanceof e.ImplicitReceiver) {\n      throw new Error(`Unexpected ImplicitReceiver`);\n    } else {\n      return new o.InvokeFunctionExpr(\n          convertAst(ast.receiver, job), ast.args.map(arg => convertAst(arg, job)));\n    }\n  } else if (ast instanceof e.LiteralPrimitive) {\n    return o.literal(ast.value);\n  } else if (ast instanceof e.Binary) {\n    const operator = BINARY_OPERATORS.get(ast.operation);\n    if (operator === undefined) {\n      throw new Error(`AssertionError: unknown binary operator ${ast.operation}`);\n    }\n    return new o.BinaryOperatorExpr(\n        operator, convertAst(ast.left, job), convertAst(ast.right, job));\n  } else if (ast instanceof e.ThisReceiver) {\n    return new ir.ContextExpr(job.root.xref);\n  } else if (ast instanceof e.KeyedRead) {\n    return new o.ReadKeyExpr(convertAst(ast.receiver, job), convertAst(ast.key, job));\n  } else if (ast instanceof e.Chain) {\n    throw new Error(`AssertionError: Chain in unknown context`);\n  } else if (ast instanceof e.LiteralMap) {\n    const entries = ast.keys.map((key, idx) => {\n      const value = ast.values[idx];\n      return new o.LiteralMapEntry(key.key, convertAst(value, job), key.quoted);\n    });\n    return new o.LiteralMapExpr(entries);\n  } else if (ast instanceof e.LiteralArray) {\n    return new o.LiteralArrayExpr(ast.expressions.map(expr => convertAst(expr, job)));\n  } else if (ast instanceof e.Conditional) {\n    return new o.ConditionalExpr(\n        convertAst(ast.condition, job),\n        convertAst(ast.trueExp, job),\n        convertAst(ast.falseExp, job),\n    );\n  } else if (ast instanceof e.NonNullAssert) {\n    // A non-null assertion shouldn't impact generated instructions, so we can just drop it.\n    return convertAst(ast.expression, job);\n  } else if (ast instanceof e.BindingPipe) {\n    return new ir.PipeBindingExpr(\n        job.allocateXrefId(),\n        ast.name,\n        [\n          convertAst(ast.exp, job),\n          ...ast.args.map(arg => convertAst(arg, job)),\n        ],\n    );\n  } else if (ast instanceof e.SafeKeyedRead) {\n    return new ir.SafeKeyedReadExpr(convertAst(ast.receiver, job), convertAst(ast.key, job));\n  } else if (ast instanceof e.SafePropertyRead) {\n    return new ir.SafePropertyReadExpr(convertAst(ast.receiver, job), ast.name);\n  } else if (ast instanceof e.SafeCall) {\n    return new ir.SafeInvokeFunctionExpr(\n        convertAst(ast.receiver, job), ast.args.map(a => convertAst(a, job)));\n  } else if (ast instanceof e.EmptyExpr) {\n    return new ir.EmptyExpr();\n  } else {\n    throw new Error(`Unhandled expression type: ${ast.constructor.name}`);\n  }\n}\n\n/**\n * Process all of the bindings on an element-like structure in the template AST and convert them\n * to their IR representation.\n */\nfunction ingestBindings(\n    unit: ViewCompilationUnit, op: ir.ElementOpBase, element: t.Element|t.Template): void {\n  if (element instanceof t.Template) {\n    for (const attr of element.templateAttrs) {\n      if (attr instanceof t.TextAttribute) {\n        ingestBinding(\n            unit, op.xref, attr.name, o.literal(attr.value), e.BindingType.Attribute, null,\n            SecurityContext.NONE, attr.sourceSpan, true, true);\n      } else {\n        ingestBinding(\n            unit, op.xref, attr.name, attr.value, attr.type, attr.unit, attr.securityContext,\n            attr.sourceSpan, false, true);\n      }\n    }\n  }\n\n  for (const attr of element.attributes) {\n    // This is only attribute TextLiteral bindings, such as `attr.foo=\"bar\"`. This can never be\n    // `[attr.foo]=\"bar\"` or `attr.foo=\"{{bar}}\"`, both of which will be handled as inputs with\n    // `BindingType.Attribute`.\n    ingestBinding(\n        unit, op.xref, attr.name, o.literal(attr.value), e.BindingType.Attribute, null,\n        SecurityContext.NONE, attr.sourceSpan, true, false);\n  }\n\n  for (const input of element.inputs) {\n    ingestBinding(\n        unit, op.xref, input.name, input.value, input.type, input.unit, input.securityContext,\n        input.sourceSpan, false, false);\n  }\n\n  for (const output of element.outputs) {\n    let listenerOp: ir.ListenerOp;\n    if (output.type === e.ParsedEventType.Animation) {\n      if (output.phase === null) {\n        throw Error('Animation listener should have a phase');\n      }\n    }\n    listenerOp = ir.createListenerOp(op.xref, output.name, op.tag, output.phase, false);\n\n    // if output.handler is a chain, then push each statement from the chain separately, and\n    // return the last one?\n    let inputExprs: e.AST[];\n    let handler: e.AST = output.handler;\n    if (handler instanceof e.ASTWithSource) {\n      handler = handler.ast;\n    }\n\n    if (handler instanceof e.Chain) {\n      inputExprs = handler.expressions;\n    } else {\n      inputExprs = [handler];\n    }\n\n    if (inputExprs.length === 0) {\n      throw new Error('Expected listener to have non-empty expression list.');\n    }\n\n    const expressions = inputExprs.map(expr => convertAst(expr, unit.job));\n    const returnExpr = expressions.pop()!;\n\n    for (const expr of expressions) {\n      const stmtOp = ir.createStatementOp<ir.UpdateOp>(new o.ExpressionStatement(expr));\n      listenerOp.handlerOps.push(stmtOp);\n    }\n    listenerOp.handlerOps.push(ir.createStatementOp(new o.ReturnStatement(returnExpr)));\n    unit.create.push(listenerOp);\n  }\n}\n\nconst BINDING_KINDS = new Map<e.BindingType, ir.BindingKind>([\n  [e.BindingType.Property, ir.BindingKind.Property],\n  [e.BindingType.Attribute, ir.BindingKind.Attribute],\n  [e.BindingType.Class, ir.BindingKind.ClassName],\n  [e.BindingType.Style, ir.BindingKind.StyleProperty],\n  [e.BindingType.Animation, ir.BindingKind.Animation],\n]);\n\nfunction ingestBinding(\n    view: ViewCompilationUnit, xref: ir.XrefId, name: string, value: e.AST|o.Expression,\n    type: e.BindingType, unit: string|null, securityContext: SecurityContext,\n    sourceSpan: ParseSourceSpan, isTextAttribute: boolean, isTemplateBinding: boolean): void {\n  if (value instanceof e.ASTWithSource) {\n    value = value.ast;\n  }\n\n  let expression: o.Expression|ir.Interpolation;\n  if (value instanceof e.Interpolation) {\n    expression = new ir.Interpolation(\n        value.strings, value.expressions.map(expr => convertAst(expr, view.job)));\n  } else if (value instanceof e.AST) {\n    expression = convertAst(value, view.job);\n  } else {\n    expression = value;\n  }\n\n  const kind: ir.BindingKind = BINDING_KINDS.get(type)!;\n  view.update.push(ir.createBindingOp(\n      xref, kind, name, expression, unit, securityContext, isTextAttribute, isTemplateBinding,\n      sourceSpan));\n}\n\n/**\n * Process all of the local references on an element-like structure in the template AST and\n * convert them to their IR representation.\n */\nfunction ingestReferences(op: ir.ElementOpBase, element: t.Element|t.Template): void {\n  assertIsArray<ir.LocalRef>(op.localRefs);\n  for (const {name, value} of element.references) {\n    op.localRefs.push({\n      name,\n      target: value,\n    });\n  }\n}\n\n/**\n * Assert that the given value is an array.\n */\nfunction assertIsArray<T>(value: any): asserts value is Array<T> {\n  if (!Array.isArray(value)) {\n    throw new Error(`AssertionError: expected an array`);\n  }\n}\n"]}
399
+ /**
400
+ * Creates an absolute `ParseSourceSpan` from the relative `ParseSpan`.
401
+ *
402
+ * `ParseSpan` objects are relative to the start of the expression.
403
+ * This method converts these to full `ParseSourceSpan` objects that
404
+ * show where the span is within the overall source file.
405
+ *
406
+ * @param span the relative span to convert.
407
+ * @param baseSourceSpan a span corresponding to the base of the expression tree.
408
+ * @returns a `ParseSourceSpan` for the given span or null if no `baseSourceSpan` was provided.
409
+ */
410
+ function convertSourceSpan(span, baseSourceSpan) {
411
+ if (baseSourceSpan === null) {
412
+ return null;
413
+ }
414
+ const start = baseSourceSpan.start.moveBy(span.start);
415
+ const end = baseSourceSpan.start.moveBy(span.end);
416
+ const fullStart = baseSourceSpan.fullStart.moveBy(span.start);
417
+ return new ParseSourceSpan(start, end, fullStart);
418
+ }
419
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"ingest.js","sourceRoot":"","sources":["../../../../../../../../../packages/compiler/src/template/pipeline/src/ingest.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 {ConstantPool} from '../../../constant_pool';\nimport {SecurityContext} from '../../../core';\nimport * as e from '../../../expression_parser/ast';\nimport {splitNsName} from '../../../ml_parser/tags';\nimport * as o from '../../../output/output_ast';\nimport {ParseSourceSpan} from '../../../parse_util';\nimport * as t from '../../../render3/r3_ast';\nimport {BindingParser} from '../../../template_parser/binding_parser';\nimport * as ir from '../ir';\n\nimport {ComponentCompilationJob, HostBindingCompilationJob, type CompilationJob, type ViewCompilationUnit, HostBindingCompilationUnit} from './compilation';\nimport {BINARY_OPERATORS, namespaceForKey} from './conversion';\n\nconst compatibilityMode = ir.CompatibilityMode.TemplateDefinitionBuilder;\n\n/**\n * Process a template AST and convert it into a `ComponentCompilation` in the intermediate\n * representation.\n * TODO: Refactor more of the ingestion code into phases.\n */\nexport function ingestComponent(\n    componentName: string, template: t.Node[], constantPool: ConstantPool,\n    relativeContextFilePath: string, i18nUseExternalIds: boolean): ComponentCompilationJob {\n  const cpl = new ComponentCompilationJob(\n      componentName, constantPool, compatibilityMode, relativeContextFilePath, i18nUseExternalIds);\n  ingestNodes(cpl.root, template);\n  return cpl;\n}\n\nexport interface HostBindingInput {\n  componentName: string;\n  properties: e.ParsedProperty[]|null;\n  attributes: {[key: string]: o.Expression};\n  events: e.ParsedEvent[]|null;\n}\n\n/**\n * Process a host binding AST and convert it into a `HostBindingCompilationJob` in the intermediate\n * representation.\n */\nexport function ingestHostBinding(\n    input: HostBindingInput, bindingParser: BindingParser,\n    constantPool: ConstantPool): HostBindingCompilationJob {\n  const job = new HostBindingCompilationJob(input.componentName, constantPool, compatibilityMode);\n  for (const property of input.properties ?? []) {\n    ingestHostProperty(job, property, false);\n  }\n  for (const [name, expr] of Object.entries(input.attributes) ?? []) {\n    ingestHostAttribute(job, name, expr);\n  }\n  for (const event of input.events ?? []) {\n    ingestHostEvent(job, event);\n  }\n  return job;\n}\n\n// TODO: We should refactor the parser to use the same types and structures for host bindings as\n// with ordinary components. This would allow us to share a lot more ingestion code.\nexport function ingestHostProperty(\n    job: HostBindingCompilationJob, property: e.ParsedProperty, isTextAttribute: boolean): void {\n  let expression: o.Expression|ir.Interpolation;\n  const ast = property.expression.ast;\n  if (ast instanceof e.Interpolation) {\n    expression = new ir.Interpolation(\n        ast.strings, ast.expressions.map(expr => convertAst(expr, job, property.sourceSpan)));\n  } else {\n    expression = convertAst(ast, job, property.sourceSpan);\n  }\n  let bindingKind = ir.BindingKind.Property;\n  // TODO: this should really be handled in the parser.\n  if (property.name.startsWith('attr.')) {\n    property.name = property.name.substring('attr.'.length);\n    bindingKind = ir.BindingKind.Attribute;\n  }\n  if (property.isAnimation) {\n    bindingKind = ir.BindingKind.Animation;\n  }\n  job.root.update.push(ir.createBindingOp(\n      job.root.xref, bindingKind, property.name, expression, null,\n      SecurityContext\n          .NONE /* TODO: what should we pass as security context? Passing NONE for now. */,\n      isTextAttribute, false, property.sourceSpan));\n}\n\nexport function ingestHostAttribute(\n    job: HostBindingCompilationJob, name: string, value: o.Expression): void {\n  const attrBinding = ir.createBindingOp(\n      job.root.xref, ir.BindingKind.Attribute, name, value, null, SecurityContext.NONE, true, false,\n      /* TODO: host attribute source spans */ null!);\n  job.root.update.push(attrBinding);\n}\n\nexport function ingestHostEvent(job: HostBindingCompilationJob, event: e.ParsedEvent) {\n  const eventBinding = ir.createListenerOp(\n      job.root.xref, event.name, null, event.targetOrPhase, true, event.sourceSpan);\n  // TODO: Can this be a chain?\n  eventBinding.handlerOps.push(ir.createStatementOp(new o.ReturnStatement(\n      convertAst(event.handler.ast, job, event.sourceSpan), event.handlerSpan)));\n  job.root.create.push(eventBinding);\n}\n\n/**\n * Ingest the nodes of a template AST into the given `ViewCompilation`.\n */\nfunction ingestNodes(unit: ViewCompilationUnit, template: t.Node[]): void {\n  for (const node of template) {\n    if (node instanceof t.Element) {\n      ingestElement(unit, node);\n    } else if (node instanceof t.Template) {\n      ingestTemplate(unit, node);\n    } else if (node instanceof t.Content) {\n      ingestContent(unit, node);\n    } else if (node instanceof t.Text) {\n      ingestText(unit, node);\n    } else if (node instanceof t.BoundText) {\n      ingestBoundText(unit, node);\n    } else if (node instanceof t.SwitchBlock) {\n      ingestSwitchBlock(unit, node);\n    } else {\n      throw new Error(`Unsupported template node: ${node.constructor.name}`);\n    }\n  }\n}\n\n/**\n * Ingest an element AST from the template into the given `ViewCompilation`.\n */\nfunction ingestElement(unit: ViewCompilationUnit, element: t.Element): void {\n  const staticAttributes: Record<string, string> = {};\n  for (const attr of element.attributes) {\n    staticAttributes[attr.name] = attr.value;\n  }\n  const id = unit.job.allocateXrefId();\n\n  const [namespaceKey, elementName] = splitNsName(element.name);\n\n  const startOp = ir.createElementStartOp(\n      elementName, id, namespaceForKey(namespaceKey), element.i18n, element.startSourceSpan);\n  unit.create.push(startOp);\n\n  ingestBindings(unit, startOp, element);\n  ingestReferences(startOp, element);\n  ingestNodes(unit, element.children);\n\n  unit.create.push(ir.createElementEndOp(id, element.endSourceSpan));\n}\n\n/**\n * Ingest an `ng-template` node from the AST into the given `ViewCompilation`.\n */\nfunction ingestTemplate(unit: ViewCompilationUnit, tmpl: t.Template): void {\n  const childView = unit.job.allocateView(unit.xref);\n\n\n  let tagNameWithoutNamespace = tmpl.tagName;\n  let namespacePrefix: string|null = '';\n  if (tmpl.tagName) {\n    [namespacePrefix, tagNameWithoutNamespace] = splitNsName(tmpl.tagName);\n  }\n\n  // TODO: validate the fallback tag name here.\n  const tplOp = ir.createTemplateOp(\n      childView.xref, tagNameWithoutNamespace ?? 'ng-template', namespaceForKey(namespacePrefix),\n      false, tmpl.i18n, tmpl.startSourceSpan);\n  unit.create.push(tplOp);\n\n  ingestBindings(unit, tplOp, tmpl);\n  ingestReferences(tplOp, tmpl);\n  ingestNodes(childView, tmpl.children);\n\n  for (const {name, value} of tmpl.variables) {\n    childView.contextVariables.set(name, value);\n  }\n}\n\n/**\n * Ingest a literal text node from the AST into the given `ViewCompilation`.\n */\nfunction ingestContent(unit: ViewCompilationUnit, content: t.Content): void {\n  const op = ir.createProjectionOp(unit.job.allocateXrefId(), content.selector);\n  for (const attr of content.attributes) {\n    ingestBinding(\n        unit, op.xref, attr.name, o.literal(attr.value), e.BindingType.Attribute, null,\n        SecurityContext.NONE, attr.sourceSpan, true, false);\n  }\n  unit.create.push(op);\n}\n\n/**\n * Ingest a literal text node from the AST into the given `ViewCompilation`.\n */\nfunction ingestText(unit: ViewCompilationUnit, text: t.Text): void {\n  unit.create.push(ir.createTextOp(unit.job.allocateXrefId(), text.value, text.sourceSpan));\n}\n\n/**\n * Ingest an interpolated text node from the AST into the given `ViewCompilation`.\n */\nfunction ingestBoundText(unit: ViewCompilationUnit, text: t.BoundText): void {\n  let value = text.value;\n  if (value instanceof e.ASTWithSource) {\n    value = value.ast;\n  }\n  if (!(value instanceof e.Interpolation)) {\n    throw new Error(\n        `AssertionError: expected Interpolation for BoundText node, got ${value.constructor.name}`);\n  }\n\n  const textXref = unit.job.allocateXrefId();\n  unit.create.push(ir.createTextOp(textXref, '', text.sourceSpan));\n  // TemplateDefinitionBuilder does not generate source maps for sub-expressions inside an\n  // interpolation. We copy that behavior in compatibility mode.\n  // TODO: is it actually correct to generate these extra maps in modern mode?\n  const baseSourceSpan = unit.job.compatibility ? null : text.sourceSpan;\n  unit.update.push(ir.createInterpolateTextOp(\n      textXref,\n      new ir.Interpolation(\n          value.strings, value.expressions.map(expr => convertAst(expr, unit.job, baseSourceSpan))),\n      text.sourceSpan));\n}\n\n/**\n * Ingest a `@switch` block into the given `ViewCompilation`.\n */\nfunction ingestSwitchBlock(unit: ViewCompilationUnit, switchBlock: t.SwitchBlock): void {\n  let firstXref: ir.XrefId|null = null;\n  let conditions: Array<[ir.XrefId, o.Expression | null]> = [];\n  for (const switchCase of switchBlock.cases) {\n    const cView = unit.job.allocateView(unit.xref);\n    if (!firstXref) firstXref = cView.xref;\n    unit.create.push(\n        ir.createTemplateOp(cView.xref, 'Case', ir.Namespace.HTML, true, undefined, null!));\n    const caseExpr = switchCase.expression ?\n        convertAst(switchCase.expression, unit.job, switchBlock.startSourceSpan) :\n        null;\n    conditions.push([cView.xref, caseExpr]);\n    ingestNodes(cView, switchCase.children);\n  }\n  const conditional = ir.createConditionalOp(\n      firstXref!, convertAst(switchBlock.expression, unit.job, switchBlock.startSourceSpan), null!);\n  conditional.conditions = conditions;\n  unit.update.push(conditional);\n}\n\n/**\n * Convert a template AST expression into an output AST expression.\n */\nfunction convertAst(\n    ast: e.AST, job: CompilationJob, baseSourceSpan: ParseSourceSpan|null): o.Expression {\n  if (ast instanceof e.ASTWithSource) {\n    return convertAst(ast.ast, job, baseSourceSpan);\n  } else if (ast instanceof e.PropertyRead) {\n    if (ast.receiver instanceof e.ImplicitReceiver && !(ast.receiver instanceof e.ThisReceiver)) {\n      return new ir.LexicalReadExpr(ast.name);\n    } else {\n      return new o.ReadPropExpr(\n          convertAst(ast.receiver, job, baseSourceSpan), ast.name, null,\n          convertSourceSpan(ast.span, baseSourceSpan));\n    }\n  } else if (ast instanceof e.PropertyWrite) {\n    return new o.WritePropExpr(\n        convertAst(ast.receiver, job, baseSourceSpan), ast.name,\n        convertAst(ast.value, job, baseSourceSpan), undefined,\n        convertSourceSpan(ast.span, baseSourceSpan));\n  } else if (ast instanceof e.KeyedWrite) {\n    return new o.WriteKeyExpr(\n        convertAst(ast.receiver, job, baseSourceSpan), convertAst(ast.key, job, baseSourceSpan),\n        convertAst(ast.value, job, baseSourceSpan), undefined,\n        convertSourceSpan(ast.span, baseSourceSpan));\n  } else if (ast instanceof e.Call) {\n    if (ast.receiver instanceof e.ImplicitReceiver) {\n      throw new Error(`Unexpected ImplicitReceiver`);\n    } else {\n      return new o.InvokeFunctionExpr(\n          convertAst(ast.receiver, job, baseSourceSpan),\n          ast.args.map(arg => convertAst(arg, job, baseSourceSpan)), undefined,\n          convertSourceSpan(ast.span, baseSourceSpan));\n    }\n  } else if (ast instanceof e.LiteralPrimitive) {\n    return o.literal(ast.value, undefined, convertSourceSpan(ast.span, baseSourceSpan));\n  } else if (ast instanceof e.Binary) {\n    const operator = BINARY_OPERATORS.get(ast.operation);\n    if (operator === undefined) {\n      throw new Error(`AssertionError: unknown binary operator ${ast.operation}`);\n    }\n    return new o.BinaryOperatorExpr(\n        operator, convertAst(ast.left, job, baseSourceSpan),\n        convertAst(ast.right, job, baseSourceSpan), undefined,\n        convertSourceSpan(ast.span, baseSourceSpan));\n  } else if (ast instanceof e.ThisReceiver) {\n    // TODO: should context expressions have source maps?\n    return new ir.ContextExpr(job.root.xref);\n  } else if (ast instanceof e.KeyedRead) {\n    return new o.ReadKeyExpr(\n        convertAst(ast.receiver, job, baseSourceSpan), convertAst(ast.key, job, baseSourceSpan),\n        undefined, convertSourceSpan(ast.span, baseSourceSpan));\n  } else if (ast instanceof e.Chain) {\n    throw new Error(`AssertionError: Chain in unknown context`);\n  } else if (ast instanceof e.LiteralMap) {\n    const entries = ast.keys.map((key, idx) => {\n      const value = ast.values[idx];\n      // TODO: should literals have source maps, or do we just map the whole surrounding expression?\n      return new o.LiteralMapEntry(key.key, convertAst(value, job, baseSourceSpan), key.quoted);\n    });\n    return new o.LiteralMapExpr(entries, undefined, convertSourceSpan(ast.span, baseSourceSpan));\n  } else if (ast instanceof e.LiteralArray) {\n    // TODO: should literals have source maps, or do we just map the whole surrounding expression?\n    return new o.LiteralArrayExpr(\n        ast.expressions.map(expr => convertAst(expr, job, baseSourceSpan)));\n  } else if (ast instanceof e.Conditional) {\n    return new o.ConditionalExpr(\n        convertAst(ast.condition, job, baseSourceSpan),\n        convertAst(ast.trueExp, job, baseSourceSpan), convertAst(ast.falseExp, job, baseSourceSpan),\n        undefined, convertSourceSpan(ast.span, baseSourceSpan));\n  } else if (ast instanceof e.NonNullAssert) {\n    // A non-null assertion shouldn't impact generated instructions, so we can just drop it.\n    return convertAst(ast.expression, job, baseSourceSpan);\n  } else if (ast instanceof e.BindingPipe) {\n    // TODO: pipes should probably have source maps; figure out details.\n    return new ir.PipeBindingExpr(\n        job.allocateXrefId(),\n        ast.name,\n        [\n          convertAst(ast.exp, job, baseSourceSpan),\n          ...ast.args.map(arg => convertAst(arg, job, baseSourceSpan)),\n        ],\n    );\n  } else if (ast instanceof e.SafeKeyedRead) {\n    return new ir.SafeKeyedReadExpr(\n        convertAst(ast.receiver, job, baseSourceSpan), convertAst(ast.key, job, baseSourceSpan),\n        convertSourceSpan(ast.span, baseSourceSpan));\n  } else if (ast instanceof e.SafePropertyRead) {\n    // TODO: source span\n    return new ir.SafePropertyReadExpr(convertAst(ast.receiver, job, baseSourceSpan), ast.name);\n  } else if (ast instanceof e.SafeCall) {\n    // TODO: source span\n    return new ir.SafeInvokeFunctionExpr(\n        convertAst(ast.receiver, job, baseSourceSpan),\n        ast.args.map(a => convertAst(a, job, baseSourceSpan)));\n  } else if (ast instanceof e.EmptyExpr) {\n    return new ir.EmptyExpr(convertSourceSpan(ast.span, baseSourceSpan));\n  } else {\n    throw new Error(`Unhandled expression type: ${ast.constructor.name}`);\n  }\n}\n\n/**\n * Process all of the bindings on an element-like structure in the template AST and convert them\n * to their IR representation.\n */\nfunction ingestBindings(\n    unit: ViewCompilationUnit, op: ir.ElementOpBase, element: t.Element|t.Template): void {\n  if (element instanceof t.Template) {\n    for (const attr of element.templateAttrs) {\n      if (attr instanceof t.TextAttribute) {\n        ingestBinding(\n            unit, op.xref, attr.name, o.literal(attr.value), e.BindingType.Attribute, null,\n            SecurityContext.NONE, attr.sourceSpan, true, true);\n      } else {\n        ingestBinding(\n            unit, op.xref, attr.name, attr.value, attr.type, attr.unit, attr.securityContext,\n            attr.sourceSpan, false, true);\n      }\n    }\n  }\n\n  for (const attr of element.attributes) {\n    // This is only attribute TextLiteral bindings, such as `attr.foo=\"bar\"`. This can never be\n    // `[attr.foo]=\"bar\"` or `attr.foo=\"{{bar}}\"`, both of which will be handled as inputs with\n    // `BindingType.Attribute`.\n    ingestBinding(\n        unit, op.xref, attr.name, o.literal(attr.value), e.BindingType.Attribute, null,\n        SecurityContext.NONE, attr.sourceSpan, true, false);\n  }\n\n  for (const input of element.inputs) {\n    ingestBinding(\n        unit, op.xref, input.name, input.value, input.type, input.unit, input.securityContext,\n        input.sourceSpan, false, false);\n  }\n\n  for (const output of element.outputs) {\n    let listenerOp: ir.ListenerOp;\n    if (output.type === e.ParsedEventType.Animation) {\n      if (output.phase === null) {\n        throw Error('Animation listener should have a phase');\n      }\n    }\n    listenerOp =\n        ir.createListenerOp(op.xref, output.name, op.tag, output.phase, false, output.sourceSpan);\n\n    // if output.handler is a chain, then push each statement from the chain separately, and\n    // return the last one?\n    let handlerExprs: e.AST[];\n    let handler: e.AST = output.handler;\n    if (handler instanceof e.ASTWithSource) {\n      handler = handler.ast;\n    }\n\n    if (handler instanceof e.Chain) {\n      handlerExprs = handler.expressions;\n    } else {\n      handlerExprs = [handler];\n    }\n\n    if (handlerExprs.length === 0) {\n      throw new Error('Expected listener to have non-empty expression list.');\n    }\n\n    const expressions = handlerExprs.map(expr => convertAst(expr, unit.job, output.handlerSpan));\n    const returnExpr = expressions.pop()!;\n\n    for (const expr of expressions) {\n      const stmtOp =\n          ir.createStatementOp<ir.UpdateOp>(new o.ExpressionStatement(expr, expr.sourceSpan));\n      listenerOp.handlerOps.push(stmtOp);\n    }\n    listenerOp.handlerOps.push(\n        ir.createStatementOp(new o.ReturnStatement(returnExpr, returnExpr.sourceSpan)));\n    unit.create.push(listenerOp);\n  }\n}\n\nconst BINDING_KINDS = new Map<e.BindingType, ir.BindingKind>([\n  [e.BindingType.Property, ir.BindingKind.Property],\n  [e.BindingType.Attribute, ir.BindingKind.Attribute],\n  [e.BindingType.Class, ir.BindingKind.ClassName],\n  [e.BindingType.Style, ir.BindingKind.StyleProperty],\n  [e.BindingType.Animation, ir.BindingKind.Animation],\n]);\n\nfunction ingestBinding(\n    view: ViewCompilationUnit, xref: ir.XrefId, name: string, value: e.AST|o.Expression,\n    type: e.BindingType, unit: string|null, securityContext: SecurityContext,\n    sourceSpan: ParseSourceSpan, isTextAttribute: boolean, isTemplateBinding: boolean): void {\n  if (value instanceof e.ASTWithSource) {\n    value = value.ast;\n  }\n\n  let expression: o.Expression|ir.Interpolation;\n  // TODO: We could easily generate source maps for subexpressions in these cases, but\n  // TemplateDefinitionBuilder does not. Should we do so?\n  if (value instanceof e.Interpolation) {\n    expression = new ir.Interpolation(\n        value.strings, value.expressions.map(expr => convertAst(expr, view.job, null)));\n  } else if (value instanceof e.AST) {\n    expression = convertAst(value, view.job, null);\n  } else {\n    expression = value;\n  }\n\n  const kind: ir.BindingKind = BINDING_KINDS.get(type)!;\n  view.update.push(ir.createBindingOp(\n      xref, kind, name, expression, unit, securityContext, isTextAttribute, isTemplateBinding,\n      sourceSpan));\n}\n\n/**\n * Process all of the local references on an element-like structure in the template AST and\n * convert them to their IR representation.\n */\nfunction ingestReferences(op: ir.ElementOpBase, element: t.Element|t.Template): void {\n  assertIsArray<ir.LocalRef>(op.localRefs);\n  for (const {name, value} of element.references) {\n    op.localRefs.push({\n      name,\n      target: value,\n    });\n  }\n}\n\n/**\n * Assert that the given value is an array.\n */\nfunction assertIsArray<T>(value: any): asserts value is Array<T> {\n  if (!Array.isArray(value)) {\n    throw new Error(`AssertionError: expected an array`);\n  }\n}\n\n/**\n * Creates an absolute `ParseSourceSpan` from the relative `ParseSpan`.\n *\n * `ParseSpan` objects are relative to the start of the expression.\n * This method converts these to full `ParseSourceSpan` objects that\n * show where the span is within the overall source file.\n *\n * @param span the relative span to convert.\n * @param baseSourceSpan a span corresponding to the base of the expression tree.\n * @returns a `ParseSourceSpan` for the given span or null if no `baseSourceSpan` was provided.\n */\nfunction convertSourceSpan(\n    span: e.ParseSpan, baseSourceSpan: ParseSourceSpan|null): ParseSourceSpan|null {\n  if (baseSourceSpan === null) {\n    return null;\n  }\n  const start = baseSourceSpan.start.moveBy(span.start);\n  const end = baseSourceSpan.start.moveBy(span.end);\n  const fullStart = baseSourceSpan.fullStart.moveBy(span.start);\n  return new ParseSourceSpan(start, end, fullStart);\n}\n"]}