@angular/compiler 16.0.0-next.7 → 16.0.0-rc.0

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 (42) hide show
  1. package/esm2022/src/render3/partial/class_metadata.mjs +1 -1
  2. package/esm2022/src/render3/partial/directive.mjs +1 -1
  3. package/esm2022/src/render3/partial/factory.mjs +1 -1
  4. package/esm2022/src/render3/partial/injectable.mjs +1 -1
  5. package/esm2022/src/render3/partial/injector.mjs +1 -1
  6. package/esm2022/src/render3/partial/ng_module.mjs +1 -1
  7. package/esm2022/src/render3/partial/pipe.mjs +1 -1
  8. package/esm2022/src/render3/view/compiler.mjs +52 -27
  9. package/esm2022/src/render3/view/util.mjs +4 -2
  10. package/esm2022/src/template/pipeline/ir/index.mjs +17 -0
  11. package/esm2022/src/template/pipeline/ir/src/element.mjs +101 -0
  12. package/esm2022/src/template/pipeline/ir/src/enums.mjs +121 -0
  13. package/esm2022/src/template/pipeline/ir/src/expression.mjs +293 -0
  14. package/esm2022/src/template/pipeline/ir/src/operations.mjs +223 -0
  15. package/esm2022/src/template/pipeline/ir/src/ops/create.mjs +78 -0
  16. package/esm2022/src/template/pipeline/ir/src/ops/shared.mjs +43 -0
  17. package/esm2022/src/template/pipeline/ir/src/ops/update.mjs +49 -0
  18. package/esm2022/src/template/pipeline/ir/src/traits.mjs +68 -0
  19. package/esm2022/src/template/pipeline/ir/src/variable.mjs +9 -0
  20. package/esm2022/src/template/pipeline/src/compilation.mjs +122 -0
  21. package/esm2022/src/template/pipeline/src/emit.mjs +83 -0
  22. package/esm2022/src/template/pipeline/src/ingest.mjs +194 -0
  23. package/esm2022/src/template/pipeline/src/instruction.mjs +139 -0
  24. package/esm2022/src/template/pipeline/src/phases/const_collection.mjs +57 -0
  25. package/esm2022/src/template/pipeline/src/phases/empty_elements.mjs +27 -0
  26. package/esm2022/src/template/pipeline/src/phases/generate_advance.mjs +56 -0
  27. package/esm2022/src/template/pipeline/src/phases/generate_variables.mjs +146 -0
  28. package/esm2022/src/template/pipeline/src/phases/local_refs.mjs +44 -0
  29. package/esm2022/src/template/pipeline/src/phases/naming.mjs +61 -0
  30. package/esm2022/src/template/pipeline/src/phases/reify.mjs +157 -0
  31. package/esm2022/src/template/pipeline/src/phases/resolve_contexts.mjs +55 -0
  32. package/esm2022/src/template/pipeline/src/phases/resolve_names.mjs +95 -0
  33. package/esm2022/src/template/pipeline/src/phases/slot_allocation.mjs +75 -0
  34. package/esm2022/src/template/pipeline/src/phases/var_counting.mjs +60 -0
  35. package/esm2022/src/template/pipeline/switch/index.mjs +2 -0
  36. package/esm2022/src/version.mjs +1 -1
  37. package/fesm2022/compiler.mjs +2386 -231
  38. package/fesm2022/compiler.mjs.map +1 -1
  39. package/fesm2022/testing.mjs +1 -1
  40. package/index.d.ts +1 -1
  41. package/package.json +3 -3
  42. package/testing/index.d.ts +1 -1
@@ -0,0 +1,194 @@
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
+ import * as e from '../../../expression_parser/ast';
9
+ import * as o from '../../../output/output_ast';
10
+ import * as t from '../../../render3/r3_ast';
11
+ import * as ir from '../ir';
12
+ import { ComponentCompilation } from './compilation';
13
+ /**
14
+ * Process a template AST and convert it into a `ComponentCompilation` in the intermediate
15
+ * representation.
16
+ */
17
+ export function ingest(componentName, template) {
18
+ const cpl = new ComponentCompilation(componentName);
19
+ ingestNodes(cpl.root, template);
20
+ return cpl;
21
+ }
22
+ /**
23
+ * Ingest the nodes of a template AST into the given `ViewCompilation`.
24
+ */
25
+ function ingestNodes(view, template) {
26
+ for (const node of template) {
27
+ if (node instanceof t.Element) {
28
+ ingestElement(view, node);
29
+ }
30
+ else if (node instanceof t.Template) {
31
+ ingestTemplate(view, node);
32
+ }
33
+ else if (node instanceof t.Text) {
34
+ ingestText(view, node);
35
+ }
36
+ else if (node instanceof t.BoundText) {
37
+ ingestBoundText(view, node);
38
+ }
39
+ else {
40
+ throw new Error(`Unsupported template node: ${node.constructor.name}`);
41
+ }
42
+ }
43
+ }
44
+ /**
45
+ * Ingest an element AST from the template into the given `ViewCompilation`.
46
+ */
47
+ function ingestElement(view, element) {
48
+ const staticAttributes = {};
49
+ for (const attr of element.attributes) {
50
+ staticAttributes[attr.name] = attr.value;
51
+ }
52
+ const id = view.tpl.allocateXrefId();
53
+ const startOp = ir.createElementStartOp(element.name, id);
54
+ view.create.push(startOp);
55
+ ingestAttributes(startOp, element);
56
+ ingestBindings(view, startOp, element);
57
+ ingestReferences(startOp, element);
58
+ ingestNodes(view, element.children);
59
+ view.create.push(ir.createElementEndOp(id));
60
+ }
61
+ /**
62
+ * Ingest an `ng-template` node from the AST into the given `ViewCompilation`.
63
+ */
64
+ function ingestTemplate(view, tmpl) {
65
+ const childView = view.tpl.allocateView(view.xref);
66
+ // TODO: validate the fallback tag name here.
67
+ const tplOp = ir.createTemplateOp(childView.xref, tmpl.tagName ?? 'ng-template');
68
+ view.create.push(tplOp);
69
+ ingestAttributes(tplOp, tmpl);
70
+ ingestBindings(view, tplOp, tmpl);
71
+ ingestReferences(tplOp, tmpl);
72
+ ingestNodes(childView, tmpl.children);
73
+ for (const { name, value } of tmpl.variables) {
74
+ childView.contextVariables.set(name, value);
75
+ }
76
+ }
77
+ /**
78
+ * Ingest a literal text node from the AST into the given `ViewCompilation`.
79
+ */
80
+ function ingestText(view, text) {
81
+ view.create.push(ir.createTextOp(view.tpl.allocateXrefId(), text.value));
82
+ }
83
+ /**
84
+ * Ingest an interpolated text node from the AST into the given `ViewCompilation`.
85
+ */
86
+ function ingestBoundText(view, text) {
87
+ let value = text.value;
88
+ if (value instanceof e.ASTWithSource) {
89
+ value = value.ast;
90
+ }
91
+ if (!(value instanceof e.Interpolation)) {
92
+ throw new Error(`AssertionError: expected Interpolation for BoundText node, got ${value.constructor.name}`);
93
+ }
94
+ const textXref = view.tpl.allocateXrefId();
95
+ view.create.push(ir.createTextOp(textXref, ''));
96
+ view.update.push(ir.createInterpolateTextOp(textXref, value.strings, value.expressions.map(expr => convertAst(expr))));
97
+ }
98
+ /**
99
+ * Convert a template AST expression into an output AST expression.
100
+ */
101
+ function convertAst(ast) {
102
+ if (ast instanceof e.ASTWithSource) {
103
+ return convertAst(ast.ast);
104
+ }
105
+ else if (ast instanceof e.PropertyRead) {
106
+ if (ast.receiver instanceof e.ImplicitReceiver) {
107
+ return new ir.LexicalReadExpr(ast.name);
108
+ }
109
+ else {
110
+ return new o.ReadPropExpr(convertAst(ast.receiver), ast.name);
111
+ }
112
+ }
113
+ else if (ast instanceof e.Call) {
114
+ if (ast.receiver instanceof e.ImplicitReceiver) {
115
+ throw new Error(`Unexpected ImplicitReceiver`);
116
+ }
117
+ else {
118
+ return new o.InvokeFunctionExpr(convertAst(ast.receiver), ast.args.map(arg => convertAst(arg)));
119
+ }
120
+ }
121
+ else {
122
+ throw new Error(`Unhandled expression type: ${ast.constructor.name}`);
123
+ }
124
+ }
125
+ /**
126
+ * Process all of the attributes on an element-like structure in the template AST and convert them
127
+ * to their IR representation.
128
+ */
129
+ function ingestAttributes(op, element) {
130
+ ir.assertIsElementAttributes(op.attributes);
131
+ for (const attr of element.attributes) {
132
+ op.attributes.add(ir.ElementAttributeKind.Attribute, attr.name, o.literal(attr.value));
133
+ }
134
+ for (const input of element.inputs) {
135
+ op.attributes.add(ir.ElementAttributeKind.Binding, input.name, null);
136
+ }
137
+ for (const output of element.outputs) {
138
+ op.attributes.add(ir.ElementAttributeKind.Binding, output.name, null);
139
+ }
140
+ if (element instanceof t.Template) {
141
+ for (const attr of element.templateAttrs) {
142
+ // TODO: what do we do about the value here?
143
+ op.attributes.add(ir.ElementAttributeKind.Template, attr.name, null);
144
+ }
145
+ }
146
+ }
147
+ /**
148
+ * Process all of the bindings on an element-like structure in the template AST and convert them
149
+ * to their IR representation.
150
+ */
151
+ function ingestBindings(view, op, element) {
152
+ if (element instanceof t.Template) {
153
+ for (const attr of element.templateAttrs) {
154
+ if (typeof attr.value === 'string') {
155
+ throw new Error(`TODO: unhandled static attribute bindings (is this a thing?)`);
156
+ }
157
+ else {
158
+ view.update.push(ir.createPropertyOp(op.xref, attr.name, convertAst(attr.value)));
159
+ }
160
+ }
161
+ }
162
+ else {
163
+ for (const input of element.inputs) {
164
+ view.update.push(ir.createPropertyOp(op.xref, input.name, convertAst(input.value)));
165
+ }
166
+ for (const output of element.outputs) {
167
+ const listenerOp = ir.createListenerOp(op.xref, output.name);
168
+ listenerOp.handlerOps.push(ir.createStatementOp(new o.ReturnStatement(convertAst(output.handler))));
169
+ view.create.push(listenerOp);
170
+ }
171
+ }
172
+ }
173
+ /**
174
+ * Process all of the local references on an element-like structure in the template AST and convert
175
+ * them to their IR representation.
176
+ */
177
+ function ingestReferences(op, element) {
178
+ assertIsArray(op.localRefs);
179
+ for (const { name, value } of element.references) {
180
+ op.localRefs.push({
181
+ name,
182
+ target: value,
183
+ });
184
+ }
185
+ }
186
+ /**
187
+ * Assert that the given value is an array.
188
+ */
189
+ function assertIsArray(value) {
190
+ if (!Array.isArray(value)) {
191
+ throw new Error(`AssertionError: expected an array`);
192
+ }
193
+ }
194
+ //# 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 * as e from '../../../expression_parser/ast';\nimport * as o from '../../../output/output_ast';\nimport * as t from '../../../render3/r3_ast';\nimport * as ir from '../ir';\n\nimport {ComponentCompilation, ViewCompilation} from './compilation';\n\n/**\n * Process a template AST and convert it into a `ComponentCompilation` in the intermediate\n * representation.\n */\nexport function ingest(componentName: string, template: t.Node[]): ComponentCompilation {\n  const cpl = new ComponentCompilation(componentName);\n  ingestNodes(cpl.root, template);\n  return cpl;\n}\n\n/**\n * Ingest the nodes of a template AST into the given `ViewCompilation`.\n */\nfunction ingestNodes(view: ViewCompilation, template: t.Node[]): void {\n  for (const node of template) {\n    if (node instanceof t.Element) {\n      ingestElement(view, node);\n    } else if (node instanceof t.Template) {\n      ingestTemplate(view, node);\n    } else if (node instanceof t.Text) {\n      ingestText(view, node);\n    } else if (node instanceof t.BoundText) {\n      ingestBoundText(view, 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(view: ViewCompilation, 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 = view.tpl.allocateXrefId();\n\n  const startOp = ir.createElementStartOp(element.name, id);\n  view.create.push(startOp);\n\n  ingestAttributes(startOp, element);\n  ingestBindings(view, startOp, element);\n  ingestReferences(startOp, element);\n\n  ingestNodes(view, element.children);\n  view.create.push(ir.createElementEndOp(id));\n}\n\n/**\n * Ingest an `ng-template` node from the AST into the given `ViewCompilation`.\n */\nfunction ingestTemplate(view: ViewCompilation, tmpl: t.Template): void {\n  const childView = view.tpl.allocateView(view.xref);\n\n  // TODO: validate the fallback tag name here.\n  const tplOp = ir.createTemplateOp(childView.xref, tmpl.tagName ?? 'ng-template');\n  view.create.push(tplOp);\n\n  ingestAttributes(tplOp, tmpl);\n  ingestBindings(view, tplOp, tmpl);\n  ingestReferences(tplOp, tmpl);\n\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(view: ViewCompilation, text: t.Text): void {\n  view.create.push(ir.createTextOp(view.tpl.allocateXrefId(), text.value));\n}\n\n/**\n * Ingest an interpolated text node from the AST into the given `ViewCompilation`.\n */\nfunction ingestBoundText(view: ViewCompilation, 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 = view.tpl.allocateXrefId();\n  view.create.push(ir.createTextOp(textXref, ''));\n  view.update.push(ir.createInterpolateTextOp(\n      textXref, value.strings, value.expressions.map(expr => convertAst(expr))));\n}\n\n/**\n * Convert a template AST expression into an output AST expression.\n */\nfunction convertAst(ast: e.AST): o.Expression {\n  if (ast instanceof e.ASTWithSource) {\n    return convertAst(ast.ast);\n  } else if (ast instanceof e.PropertyRead) {\n    if (ast.receiver instanceof e.ImplicitReceiver) {\n      return new ir.LexicalReadExpr(ast.name);\n    } else {\n      return new o.ReadPropExpr(convertAst(ast.receiver), ast.name);\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), ast.args.map(arg => convertAst(arg)));\n    }\n  } else {\n    throw new Error(`Unhandled expression type: ${ast.constructor.name}`);\n  }\n}\n\n/**\n * Process all of the attributes on an element-like structure in the template AST and convert them\n * to their IR representation.\n */\nfunction ingestAttributes(op: ir.ElementOpBase, element: t.Element|t.Template): void {\n  ir.assertIsElementAttributes(op.attributes);\n  for (const attr of element.attributes) {\n    op.attributes.add(ir.ElementAttributeKind.Attribute, attr.name, o.literal(attr.value));\n  }\n\n  for (const input of element.inputs) {\n    op.attributes.add(ir.ElementAttributeKind.Binding, input.name, null);\n  }\n  for (const output of element.outputs) {\n    op.attributes.add(ir.ElementAttributeKind.Binding, output.name, null);\n  }\n\n  if (element instanceof t.Template) {\n    for (const attr of element.templateAttrs) {\n      // TODO: what do we do about the value here?\n      op.attributes.add(ir.ElementAttributeKind.Template, attr.name, null);\n    }\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    view: ViewCompilation, op: ir.ElementOpBase, element: t.Element|t.Template): void {\n  if (element instanceof t.Template) {\n    for (const attr of element.templateAttrs) {\n      if (typeof attr.value === 'string') {\n        throw new Error(`TODO: unhandled static attribute bindings (is this a thing?)`);\n      } else {\n        view.update.push(ir.createPropertyOp(op.xref, attr.name, convertAst(attr.value)));\n      }\n    }\n  } else {\n    for (const input of element.inputs) {\n      view.update.push(ir.createPropertyOp(op.xref, input.name, convertAst(input.value)));\n    }\n\n    for (const output of element.outputs) {\n      const listenerOp = ir.createListenerOp(op.xref, output.name);\n      listenerOp.handlerOps.push(\n          ir.createStatementOp(new o.ReturnStatement(convertAst(output.handler))));\n      view.create.push(listenerOp);\n    }\n  }\n}\n\n/**\n * Process all of the local references on an element-like structure in the template AST and convert\n * 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"]}
@@ -0,0 +1,139 @@
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
+ import * as o from '../../../output/output_ast';
9
+ import { Identifiers } from '../../../render3/r3_identifiers';
10
+ import * as ir from '../ir';
11
+ // This file contains helpers for generating calls to Ivy instructions. In particular, each
12
+ // instruction type is represented as a function, which may select a specific instruction variant
13
+ // depending on the exact arguments.
14
+ export function element(slot, tag, constIndex, localRefIndex) {
15
+ return elementStartBase(Identifiers.element, slot, tag, constIndex, localRefIndex);
16
+ }
17
+ export function elementStart(slot, tag, constIndex, localRefIndex) {
18
+ return elementStartBase(Identifiers.elementStart, slot, tag, constIndex, localRefIndex);
19
+ }
20
+ function elementStartBase(instruction, slot, tag, constIndex, localRefIndex) {
21
+ const args = [
22
+ o.literal(slot),
23
+ o.literal(tag),
24
+ ];
25
+ if (localRefIndex !== null) {
26
+ args.push(o.literal(constIndex), // might be null, but that's okay.
27
+ o.literal(localRefIndex));
28
+ }
29
+ else if (constIndex !== null) {
30
+ args.push(o.literal(constIndex));
31
+ }
32
+ return call(instruction, args);
33
+ }
34
+ export function elementEnd() {
35
+ return call(Identifiers.elementEnd, []);
36
+ }
37
+ export function template(slot, templateFnRef, decls, vars, tag, constIndex) {
38
+ return call(Identifiers.templateCreate, [
39
+ o.literal(slot),
40
+ templateFnRef,
41
+ o.literal(decls),
42
+ o.literal(vars),
43
+ o.literal(tag),
44
+ o.literal(constIndex),
45
+ ]);
46
+ }
47
+ export function listener(name, handlerFn) {
48
+ return call(Identifiers.listener, [
49
+ o.literal(name),
50
+ handlerFn,
51
+ ]);
52
+ }
53
+ export function advance(delta) {
54
+ return call(Identifiers.advance, [
55
+ o.literal(delta),
56
+ ]);
57
+ }
58
+ export function reference(slot) {
59
+ return o.importExpr(Identifiers.reference).callFn([
60
+ o.literal(slot),
61
+ ]);
62
+ }
63
+ export function nextContext() {
64
+ return o.importExpr(Identifiers.nextContext).callFn([]);
65
+ }
66
+ export function getCurrentView() {
67
+ return o.importExpr(Identifiers.getCurrentView).callFn([]);
68
+ }
69
+ export function restoreView(savedView) {
70
+ return o.importExpr(Identifiers.restoreView).callFn([
71
+ savedView,
72
+ ]);
73
+ }
74
+ export function resetView(returnValue) {
75
+ return o.importExpr(Identifiers.reference).callFn([
76
+ returnValue,
77
+ ]);
78
+ }
79
+ export function text(slot, initialValue) {
80
+ const args = [o.literal(slot)];
81
+ if (initialValue !== '') {
82
+ args.push(o.literal(initialValue));
83
+ }
84
+ return call(Identifiers.text, args);
85
+ }
86
+ export function property(name, expression) {
87
+ return call(Identifiers.property, [
88
+ o.literal(name),
89
+ expression,
90
+ ]);
91
+ }
92
+ export function textInterpolate(strings, expressions) {
93
+ if (strings.length < 1 || expressions.length !== strings.length - 1) {
94
+ throw new Error(`AssertionError: expected specific shape of args for strings/expressions in interpolation`);
95
+ }
96
+ const interpolationArgs = [];
97
+ let idx;
98
+ for (idx = 0; idx < expressions.length; idx++) {
99
+ interpolationArgs.push(o.literal(strings[idx]), expressions[idx]);
100
+ }
101
+ // idx points at the last string.
102
+ interpolationArgs.push(o.literal(strings[idx]));
103
+ return callInterpolation(TEXT_INTERPOLATE_CONFIG, [], interpolationArgs);
104
+ }
105
+ function call(instruction, args) {
106
+ return ir.createStatementOp(o.importExpr(instruction).callFn(args).toStmt());
107
+ }
108
+ /**
109
+ * `InterpolationConfig` for the `textInterpolate` instruction.
110
+ */
111
+ const TEXT_INTERPOLATE_CONFIG = {
112
+ constant: [
113
+ Identifiers.textInterpolate,
114
+ Identifiers.textInterpolate1,
115
+ Identifiers.textInterpolate2,
116
+ Identifiers.textInterpolate3,
117
+ Identifiers.textInterpolate4,
118
+ Identifiers.textInterpolate5,
119
+ Identifiers.textInterpolate6,
120
+ Identifiers.textInterpolate7,
121
+ Identifiers.textInterpolate8,
122
+ ],
123
+ variable: Identifiers.textInterpolateV,
124
+ };
125
+ function callInterpolation(config, baseArgs, interpolationArgs) {
126
+ if (interpolationArgs.length % 2 === 0) {
127
+ throw new Error(`Expected odd number of interpolation arguments`);
128
+ }
129
+ const n = (interpolationArgs.length - 1) / 2;
130
+ if (n < config.constant.length) {
131
+ // Constant calling pattern.
132
+ return call(config.constant[n], [...baseArgs, ...interpolationArgs]);
133
+ }
134
+ else {
135
+ // Variable calling pattern.
136
+ return call(config.variable, [...baseArgs, o.literalArr(interpolationArgs)]);
137
+ }
138
+ }
139
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"instruction.js","sourceRoot":"","sources":["../../../../../../../../../packages/compiler/src/template/pipeline/src/instruction.ts"],"names":[],"mappings":"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","sourcesContent":["/**\n * @license\n * Copyright Google LLC All Rights Reserved.\n *\n * Use of this source code is governed by an MIT-style license that can be\n * found in the LICENSE file at https://angular.io/license\n */\n\nimport * as o from '../../../output/output_ast';\nimport {Identifiers} from '../../../render3/r3_identifiers';\nimport * as ir from '../ir';\n\n// This file contains helpers for generating calls to Ivy instructions. In particular, each\n// instruction type is represented as a function, which may select a specific instruction variant\n// depending on the exact arguments.\n\nexport function element(\n    slot: number, tag: string, constIndex: number|null, localRefIndex: number|null): ir.CreateOp {\n  return elementStartBase(Identifiers.element, slot, tag, constIndex, localRefIndex);\n}\n\n\nexport function elementStart(\n    slot: number, tag: string, constIndex: number|null, localRefIndex: number|null): ir.CreateOp {\n  return elementStartBase(Identifiers.elementStart, slot, tag, constIndex, localRefIndex);\n}\n\nfunction elementStartBase(\n    instruction: o.ExternalReference, slot: number, tag: string, constIndex: number|null,\n    localRefIndex: number|null): ir.CreateOp {\n  const args: o.Expression[] = [\n    o.literal(slot),\n    o.literal(tag),\n  ];\n  if (localRefIndex !== null) {\n    args.push(\n        o.literal(constIndex),  // might be null, but that's okay.\n        o.literal(localRefIndex),\n    );\n  } else if (constIndex !== null) {\n    args.push(o.literal(constIndex));\n  }\n\n  return call(instruction, args);\n}\n\nexport function elementEnd(): ir.CreateOp {\n  return call(Identifiers.elementEnd, []);\n}\n\nexport function template(\n    slot: number, templateFnRef: o.Expression, decls: number, vars: number, tag: string,\n    constIndex: number): ir.CreateOp {\n  return call(Identifiers.templateCreate, [\n    o.literal(slot),\n    templateFnRef,\n    o.literal(decls),\n    o.literal(vars),\n    o.literal(tag),\n    o.literal(constIndex),\n  ]);\n}\n\nexport function listener(name: string, handlerFn: o.Expression): ir.CreateOp {\n  return call(Identifiers.listener, [\n    o.literal(name),\n    handlerFn,\n  ]);\n}\n\nexport function advance(delta: number): ir.UpdateOp {\n  return call(Identifiers.advance, [\n    o.literal(delta),\n  ]);\n}\n\nexport function reference(slot: number): o.Expression {\n  return o.importExpr(Identifiers.reference).callFn([\n    o.literal(slot),\n  ]);\n}\n\nexport function nextContext(): o.Expression {\n  return o.importExpr(Identifiers.nextContext).callFn([]);\n}\n\n\nexport function getCurrentView(): o.Expression {\n  return o.importExpr(Identifiers.getCurrentView).callFn([]);\n}\n\n\nexport function restoreView(savedView: o.Expression): o.Expression {\n  return o.importExpr(Identifiers.restoreView).callFn([\n    savedView,\n  ]);\n}\n\n\nexport function resetView(returnValue: o.Expression): o.Expression {\n  return o.importExpr(Identifiers.reference).callFn([\n    returnValue,\n  ]);\n}\n\nexport function text(slot: number, initialValue: string): ir.CreateOp {\n  const args: o.Expression[] = [o.literal(slot)];\n  if (initialValue !== '') {\n    args.push(o.literal(initialValue));\n  }\n  return call(Identifiers.text, args);\n}\n\nexport function property(name: string, expression: o.Expression): ir.UpdateOp {\n  return call(Identifiers.property, [\n    o.literal(name),\n    expression,\n  ]);\n}\n\nexport function textInterpolate(strings: string[], expressions: o.Expression[]): ir.UpdateOp {\n  if (strings.length < 1 || expressions.length !== strings.length - 1) {\n    throw new Error(\n        `AssertionError: expected specific shape of args for strings/expressions in interpolation`);\n  }\n  const interpolationArgs: o.Expression[] = [];\n  let idx: number;\n  for (idx = 0; idx < expressions.length; idx++) {\n    interpolationArgs.push(o.literal(strings[idx]), expressions[idx]);\n  }\n  // idx points at the last string.\n  interpolationArgs.push(o.literal(strings[idx]));\n  return callInterpolation(TEXT_INTERPOLATE_CONFIG, [], interpolationArgs);\n}\n\n\n\nfunction call<OpT extends ir.CreateOp|ir.UpdateOp>(\n    instruction: o.ExternalReference, args: o.Expression[]): OpT {\n  return ir.createStatementOp(o.importExpr(instruction).callFn(args).toStmt()) as OpT;\n}\n\n/**\n * Describes a specific flavor of instruction used to represent interpolations, which have some\n * number of variants for specific argument counts.\n */\ninterface InterpolationConfig {\n  constant: o.ExternalReference[];\n  variable: o.ExternalReference;\n}\n\n/**\n * `InterpolationConfig` for the `textInterpolate` instruction.\n */\nconst TEXT_INTERPOLATE_CONFIG: InterpolationConfig = {\n  constant: [\n    Identifiers.textInterpolate,\n    Identifiers.textInterpolate1,\n    Identifiers.textInterpolate2,\n    Identifiers.textInterpolate3,\n    Identifiers.textInterpolate4,\n    Identifiers.textInterpolate5,\n    Identifiers.textInterpolate6,\n    Identifiers.textInterpolate7,\n    Identifiers.textInterpolate8,\n  ],\n  variable: Identifiers.textInterpolateV,\n};\n\nfunction callInterpolation(\n    config: InterpolationConfig, baseArgs: o.Expression[],\n    interpolationArgs: o.Expression[]): ir.UpdateOp {\n  if (interpolationArgs.length % 2 === 0) {\n    throw new Error(`Expected odd number of interpolation arguments`);\n  }\n  const n = (interpolationArgs.length - 1) / 2;\n  if (n < config.constant.length) {\n    // Constant calling pattern.\n    return call(config.constant[n], [...baseArgs, ...interpolationArgs]);\n  } else {\n    // Variable calling pattern.\n    return call(config.variable, [...baseArgs, o.literalArr(interpolationArgs)]);\n  }\n}\n"]}
@@ -0,0 +1,57 @@
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
+ import * as o from '../../../../output/output_ast';
9
+ import * as ir from '../../ir';
10
+ import { ElementAttributes } from '../../ir/src/element';
11
+ /**
12
+ * Converts the semantic attributes of element-like operations (elements, templates) into constant
13
+ * array expressions, and lifts them into the overall component `consts`.
14
+ */
15
+ export function phaseConstCollection(cpl) {
16
+ for (const [_, view] of cpl.views) {
17
+ for (const op of view.create) {
18
+ if (op.kind !== ir.OpKind.ElementStart && op.kind !== ir.OpKind.Element &&
19
+ op.kind !== ir.OpKind.Template) {
20
+ continue;
21
+ }
22
+ else if (!(op.attributes instanceof ElementAttributes)) {
23
+ continue;
24
+ }
25
+ const attrArray = serializeAttributes(op.attributes);
26
+ if (attrArray.entries.length > 0) {
27
+ op.attributes = cpl.addConst(attrArray);
28
+ }
29
+ else {
30
+ op.attributes = null;
31
+ }
32
+ }
33
+ }
34
+ }
35
+ function serializeAttributes({ attributes, bindings, classes, i18n, projectAs, styles, template }) {
36
+ const attrArray = [...attributes];
37
+ if (projectAs !== null) {
38
+ attrArray.push(o.literal(5 /* core.AttributeMarker.ProjectAs */), o.literal(projectAs));
39
+ }
40
+ if (classes.length > 0) {
41
+ attrArray.push(o.literal(1 /* core.AttributeMarker.Classes */), ...classes);
42
+ }
43
+ if (styles.length > 0) {
44
+ attrArray.push(o.literal(2 /* core.AttributeMarker.Styles */), ...styles);
45
+ }
46
+ if (bindings.length > 0) {
47
+ attrArray.push(o.literal(3 /* core.AttributeMarker.Bindings */), ...bindings);
48
+ }
49
+ if (template.length > 0) {
50
+ attrArray.push(o.literal(4 /* core.AttributeMarker.Template */), ...template);
51
+ }
52
+ if (i18n.length > 0) {
53
+ attrArray.push(o.literal(6 /* core.AttributeMarker.I18n */), ...i18n);
54
+ }
55
+ return o.literalArr(attrArray);
56
+ }
57
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiY29uc3RfY29sbGVjdGlvbi5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uLy4uLy4uLy4uLy4uLy4uL3BhY2thZ2VzL2NvbXBpbGVyL3NyYy90ZW1wbGF0ZS9waXBlbGluZS9zcmMvcGhhc2VzL2NvbnN0X2NvbGxlY3Rpb24udHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUE7Ozs7OztHQU1HO0FBR0gsT0FBTyxLQUFLLENBQUMsTUFBTSwrQkFBK0IsQ0FBQztBQUNuRCxPQUFPLEtBQUssRUFBRSxNQUFNLFVBQVUsQ0FBQztBQUMvQixPQUFPLEVBQUMsaUJBQWlCLEVBQUMsTUFBTSxzQkFBc0IsQ0FBQztBQUd2RDs7O0dBR0c7QUFDSCxNQUFNLFVBQVUsb0JBQW9CLENBQUMsR0FBeUI7SUFDNUQsS0FBSyxNQUFNLENBQUMsQ0FBQyxFQUFFLElBQUksQ0FBQyxJQUFJLEdBQUcsQ0FBQyxLQUFLLEVBQUU7UUFDakMsS0FBSyxNQUFNLEVBQUUsSUFBSSxJQUFJLENBQUMsTUFBTSxFQUFFO1lBQzVCLElBQUksRUFBRSxDQUFDLElBQUksS0FBSyxFQUFFLENBQUMsTUFBTSxDQUFDLFlBQVksSUFBSSxFQUFFLENBQUMsSUFBSSxLQUFLLEVBQUUsQ0FBQyxNQUFNLENBQUMsT0FBTztnQkFDbkUsRUFBRSxDQUFDLElBQUksS0FBSyxFQUFFLENBQUMsTUFBTSxDQUFDLFFBQVEsRUFBRTtnQkFDbEMsU0FBUzthQUNWO2lCQUFNLElBQUksQ0FBQyxDQUFDLEVBQUUsQ0FBQyxVQUFVLFlBQVksaUJBQWlCLENBQUMsRUFBRTtnQkFDeEQsU0FBUzthQUNWO1lBRUQsTUFBTSxTQUFTLEdBQUcsbUJBQW1CLENBQUMsRUFBRSxDQUFDLFVBQVUsQ0FBQyxDQUFDO1lBQ3JELElBQUksU0FBUyxDQUFDLE9BQU8sQ0FBQyxNQUFNLEdBQUcsQ0FBQyxFQUFFO2dCQUNoQyxFQUFFLENBQUMsVUFBVSxHQUFHLEdBQUcsQ0FBQyxRQUFRLENBQUMsU0FBUyxDQUFDLENBQUM7YUFDekM7aUJBQU07Z0JBQ0wsRUFBRSxDQUFDLFVBQVUsR0FBRyxJQUFJLENBQUM7YUFDdEI7U0FDRjtLQUNGO0FBQ0gsQ0FBQztBQUVELFNBQVMsbUJBQW1CLENBQUMsRUFBQyxVQUFVLEVBQUUsUUFBUSxFQUFFLE9BQU8sRUFBRSxJQUFJLEVBQUUsU0FBUyxFQUFFLE1BQU0sRUFBRSxRQUFRLEVBQzVDO0lBQ2hELE1BQU0sU0FBUyxHQUFHLENBQUMsR0FBRyxVQUFVLENBQUMsQ0FBQztJQUVsQyxJQUFJLFNBQVMsS0FBSyxJQUFJLEVBQUU7UUFDdEIsU0FBUyxDQUFDLElBQUksQ0FBQyxDQUFDLENBQUMsT0FBTyx3Q0FBZ0MsRUFBRSxDQUFDLENBQUMsT0FBTyxDQUFDLFNBQVMsQ0FBQyxDQUFDLENBQUM7S0FDakY7SUFDRCxJQUFJLE9BQU8sQ0FBQyxNQUFNLEdBQUcsQ0FBQyxFQUFFO1FBQ3RCLFNBQVMsQ0FBQyxJQUFJLENBQUMsQ0FBQyxDQUFDLE9BQU8sc0NBQThCLEVBQUUsR0FBRyxPQUFPLENBQUMsQ0FBQztLQUNyRTtJQUNELElBQUksTUFBTSxDQUFDLE1BQU0sR0FBRyxDQUFDLEVBQUU7UUFDckIsU0FBUyxDQUFDLElBQUksQ0FBQyxDQUFDLENBQUMsT0FBTyxxQ0FBNkIsRUFBRSxHQUFHLE1BQU0sQ0FBQyxDQUFDO0tBQ25FO0lBQ0QsSUFBSSxRQUFRLENBQUMsTUFBTSxHQUFHLENBQUMsRUFBRTtRQUN2QixTQUFTLENBQUMsSUFBSSxDQUFDLENBQUMsQ0FBQyxPQUFPLHVDQUErQixFQUFFLEdBQUcsUUFBUSxDQUFDLENBQUM7S0FDdkU7SUFDRCxJQUFJLFFBQVEsQ0FBQyxNQUFNLEdBQUcsQ0FBQyxFQUFFO1FBQ3ZCLFNBQVMsQ0FBQyxJQUFJLENBQUMsQ0FBQyxDQUFDLE9BQU8sdUNBQStCLEVBQUUsR0FBRyxRQUFRLENBQUMsQ0FBQztLQUN2RTtJQUNELElBQUksSUFBSSxDQUFDLE1BQU0sR0FBRyxDQUFDLEVBQUU7UUFDbkIsU0FBUyxDQUFDLElBQUksQ0FBQyxDQUFDLENBQUMsT0FBTyxtQ0FBMkIsRUFBRSxHQUFHLElBQUksQ0FBQyxDQUFDO0tBQy9EO0lBQ0QsT0FBTyxDQUFDLENBQUMsVUFBVSxDQUFDLFNBQVMsQ0FBQyxDQUFDO0FBQ2pDLENBQUMiLCJzb3VyY2VzQ29udGVudCI6WyIvKipcbiAqIEBsaWNlbnNlXG4gKiBDb3B5cmlnaHQgR29vZ2xlIExMQyBBbGwgUmlnaHRzIFJlc2VydmVkLlxuICpcbiAqIFVzZSBvZiB0aGlzIHNvdXJjZSBjb2RlIGlzIGdvdmVybmVkIGJ5IGFuIE1JVC1zdHlsZSBsaWNlbnNlIHRoYXQgY2FuIGJlXG4gKiBmb3VuZCBpbiB0aGUgTElDRU5TRSBmaWxlIGF0IGh0dHBzOi8vYW5ndWxhci5pby9saWNlbnNlXG4gKi9cblxuaW1wb3J0ICogYXMgY29yZSBmcm9tICcuLi8uLi8uLi8uLi9jb3JlJztcbmltcG9ydCAqIGFzIG8gZnJvbSAnLi4vLi4vLi4vLi4vb3V0cHV0L291dHB1dF9hc3QnO1xuaW1wb3J0ICogYXMgaXIgZnJvbSAnLi4vLi4vaXInO1xuaW1wb3J0IHtFbGVtZW50QXR0cmlidXRlc30gZnJvbSAnLi4vLi4vaXIvc3JjL2VsZW1lbnQnO1xuaW1wb3J0IHtDb21wb25lbnRDb21waWxhdGlvbn0gZnJvbSAnLi4vY29tcGlsYXRpb24nO1xuXG4vKipcbiAqIENvbnZlcnRzIHRoZSBzZW1hbnRpYyBhdHRyaWJ1dGVzIG9mIGVsZW1lbnQtbGlrZSBvcGVyYXRpb25zIChlbGVtZW50cywgdGVtcGxhdGVzKSBpbnRvIGNvbnN0YW50XG4gKiBhcnJheSBleHByZXNzaW9ucywgYW5kIGxpZnRzIHRoZW0gaW50byB0aGUgb3ZlcmFsbCBjb21wb25lbnQgYGNvbnN0c2AuXG4gKi9cbmV4cG9ydCBmdW5jdGlvbiBwaGFzZUNvbnN0Q29sbGVjdGlvbihjcGw6IENvbXBvbmVudENvbXBpbGF0aW9uKTogdm9pZCB7XG4gIGZvciAoY29uc3QgW18sIHZpZXddIG9mIGNwbC52aWV3cykge1xuICAgIGZvciAoY29uc3Qgb3Agb2Ygdmlldy5jcmVhdGUpIHtcbiAgICAgIGlmIChvcC5raW5kICE9PSBpci5PcEtpbmQuRWxlbWVudFN0YXJ0ICYmIG9wLmtpbmQgIT09IGlyLk9wS2luZC5FbGVtZW50ICYmXG4gICAgICAgICAgb3Aua2luZCAhPT0gaXIuT3BLaW5kLlRlbXBsYXRlKSB7XG4gICAgICAgIGNvbnRpbnVlO1xuICAgICAgfSBlbHNlIGlmICghKG9wLmF0dHJpYnV0ZXMgaW5zdGFuY2VvZiBFbGVtZW50QXR0cmlidXRlcykpIHtcbiAgICAgICAgY29udGludWU7XG4gICAgICB9XG5cbiAgICAgIGNvbnN0IGF0dHJBcnJheSA9IHNlcmlhbGl6ZUF0dHJpYnV0ZXMob3AuYXR0cmlidXRlcyk7XG4gICAgICBpZiAoYXR0ckFycmF5LmVudHJpZXMubGVuZ3RoID4gMCkge1xuICAgICAgICBvcC5hdHRyaWJ1dGVzID0gY3BsLmFkZENvbnN0KGF0dHJBcnJheSk7XG4gICAgICB9IGVsc2Uge1xuICAgICAgICBvcC5hdHRyaWJ1dGVzID0gbnVsbDtcbiAgICAgIH1cbiAgICB9XG4gIH1cbn1cblxuZnVuY3Rpb24gc2VyaWFsaXplQXR0cmlidXRlcyh7YXR0cmlidXRlcywgYmluZGluZ3MsIGNsYXNzZXMsIGkxOG4sIHByb2plY3RBcywgc3R5bGVzLCB0ZW1wbGF0ZX06XG4gICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICBFbGVtZW50QXR0cmlidXRlcyk6IG8uTGl0ZXJhbEFycmF5RXhwciB7XG4gIGNvbnN0IGF0dHJBcnJheSA9IFsuLi5hdHRyaWJ1dGVzXTtcblxuICBpZiAocHJvamVjdEFzICE9PSBudWxsKSB7XG4gICAgYXR0ckFycmF5LnB1c2goby5saXRlcmFsKGNvcmUuQXR0cmlidXRlTWFya2VyLlByb2plY3RBcyksIG8ubGl0ZXJhbChwcm9qZWN0QXMpKTtcbiAgfVxuICBpZiAoY2xhc3Nlcy5sZW5ndGggPiAwKSB7XG4gICAgYXR0ckFycmF5LnB1c2goby5saXRlcmFsKGNvcmUuQXR0cmlidXRlTWFya2VyLkNsYXNzZXMpLCAuLi5jbGFzc2VzKTtcbiAgfVxuICBpZiAoc3R5bGVzLmxlbmd0aCA+IDApIHtcbiAgICBhdHRyQXJyYXkucHVzaChvLmxpdGVyYWwoY29yZS5BdHRyaWJ1dGVNYXJrZXIuU3R5bGVzKSwgLi4uc3R5bGVzKTtcbiAgfVxuICBpZiAoYmluZGluZ3MubGVuZ3RoID4gMCkge1xuICAgIGF0dHJBcnJheS5wdXNoKG8ubGl0ZXJhbChjb3JlLkF0dHJpYnV0ZU1hcmtlci5CaW5kaW5ncyksIC4uLmJpbmRpbmdzKTtcbiAgfVxuICBpZiAodGVtcGxhdGUubGVuZ3RoID4gMCkge1xuICAgIGF0dHJBcnJheS5wdXNoKG8ubGl0ZXJhbChjb3JlLkF0dHJpYnV0ZU1hcmtlci5UZW1wbGF0ZSksIC4uLnRlbXBsYXRlKTtcbiAgfVxuICBpZiAoaTE4bi5sZW5ndGggPiAwKSB7XG4gICAgYXR0ckFycmF5LnB1c2goby5saXRlcmFsKGNvcmUuQXR0cmlidXRlTWFya2VyLkkxOG4pLCAuLi5pMThuKTtcbiAgfVxuICByZXR1cm4gby5saXRlcmFsQXJyKGF0dHJBcnJheSk7XG59XG4iXX0=
@@ -0,0 +1,27 @@
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
+ import * as ir from '../../ir';
9
+ /**
10
+ * Replace sequences of `ElementStart` followed by `ElementEnd` with a condensed `Element`
11
+ * instruction.
12
+ */
13
+ export function phaseEmptyElements(cpl) {
14
+ for (const [_, view] of cpl.views) {
15
+ for (const op of view.create) {
16
+ if (op.kind === ir.OpKind.ElementEnd && op.prev !== null &&
17
+ op.prev.kind === ir.OpKind.ElementStart) {
18
+ // Transmute the `ElementStart` instruction to `Element`. This is safe as they're designed
19
+ // to be identical apart from the `kind`.
20
+ op.prev.kind = ir.OpKind.Element;
21
+ // Remove the `ElementEnd` instruction.
22
+ ir.OpList.remove(op);
23
+ }
24
+ }
25
+ }
26
+ }
27
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiZW1wdHlfZWxlbWVudHMuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi8uLi8uLi8uLi8uLi8uLi9wYWNrYWdlcy9jb21waWxlci9zcmMvdGVtcGxhdGUvcGlwZWxpbmUvc3JjL3BoYXNlcy9lbXB0eV9lbGVtZW50cy50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQTs7Ozs7O0dBTUc7QUFFSCxPQUFPLEtBQUssRUFBRSxNQUFNLFVBQVUsQ0FBQztBQUcvQjs7O0dBR0c7QUFDSCxNQUFNLFVBQVUsa0JBQWtCLENBQUMsR0FBeUI7SUFDMUQsS0FBSyxNQUFNLENBQUMsQ0FBQyxFQUFFLElBQUksQ0FBQyxJQUFJLEdBQUcsQ0FBQyxLQUFLLEVBQUU7UUFDakMsS0FBSyxNQUFNLEVBQUUsSUFBSSxJQUFJLENBQUMsTUFBTSxFQUFFO1lBQzVCLElBQUksRUFBRSxDQUFDLElBQUksS0FBSyxFQUFFLENBQUMsTUFBTSxDQUFDLFVBQVUsSUFBSSxFQUFFLENBQUMsSUFBSSxLQUFLLElBQUk7Z0JBQ3BELEVBQUUsQ0FBQyxJQUFJLENBQUMsSUFBSSxLQUFLLEVBQUUsQ0FBQyxNQUFNLENBQUMsWUFBWSxFQUFFO2dCQUMzQywwRkFBMEY7Z0JBQzFGLHlDQUF5QztnQkFDeEMsRUFBRSxDQUFDLElBQWdDLENBQUMsSUFBSSxHQUFHLEVBQUUsQ0FBQyxNQUFNLENBQUMsT0FBTyxDQUFDO2dCQUU5RCx1Q0FBdUM7Z0JBQ3ZDLEVBQUUsQ0FBQyxNQUFNLENBQUMsTUFBTSxDQUFjLEVBQUUsQ0FBQyxDQUFDO2FBQ25DO1NBQ0Y7S0FDRjtBQUNILENBQUMiLCJzb3VyY2VzQ29udGVudCI6WyIvKipcbiAqIEBsaWNlbnNlXG4gKiBDb3B5cmlnaHQgR29vZ2xlIExMQyBBbGwgUmlnaHRzIFJlc2VydmVkLlxuICpcbiAqIFVzZSBvZiB0aGlzIHNvdXJjZSBjb2RlIGlzIGdvdmVybmVkIGJ5IGFuIE1JVC1zdHlsZSBsaWNlbnNlIHRoYXQgY2FuIGJlXG4gKiBmb3VuZCBpbiB0aGUgTElDRU5TRSBmaWxlIGF0IGh0dHBzOi8vYW5ndWxhci5pby9saWNlbnNlXG4gKi9cblxuaW1wb3J0ICogYXMgaXIgZnJvbSAnLi4vLi4vaXInO1xuaW1wb3J0IHtDb21wb25lbnRDb21waWxhdGlvbn0gZnJvbSAnLi4vY29tcGlsYXRpb24nO1xuXG4vKipcbiAqIFJlcGxhY2Ugc2VxdWVuY2VzIG9mIGBFbGVtZW50U3RhcnRgIGZvbGxvd2VkIGJ5IGBFbGVtZW50RW5kYCB3aXRoIGEgY29uZGVuc2VkIGBFbGVtZW50YFxuICogaW5zdHJ1Y3Rpb24uXG4gKi9cbmV4cG9ydCBmdW5jdGlvbiBwaGFzZUVtcHR5RWxlbWVudHMoY3BsOiBDb21wb25lbnRDb21waWxhdGlvbik6IHZvaWQge1xuICBmb3IgKGNvbnN0IFtfLCB2aWV3XSBvZiBjcGwudmlld3MpIHtcbiAgICBmb3IgKGNvbnN0IG9wIG9mIHZpZXcuY3JlYXRlKSB7XG4gICAgICBpZiAob3Aua2luZCA9PT0gaXIuT3BLaW5kLkVsZW1lbnRFbmQgJiYgb3AucHJldiAhPT0gbnVsbCAmJlxuICAgICAgICAgIG9wLnByZXYua2luZCA9PT0gaXIuT3BLaW5kLkVsZW1lbnRTdGFydCkge1xuICAgICAgICAvLyBUcmFuc211dGUgdGhlIGBFbGVtZW50U3RhcnRgIGluc3RydWN0aW9uIHRvIGBFbGVtZW50YC4gVGhpcyBpcyBzYWZlIGFzIHRoZXkncmUgZGVzaWduZWRcbiAgICAgICAgLy8gdG8gYmUgaWRlbnRpY2FsIGFwYXJ0IGZyb20gdGhlIGBraW5kYC5cbiAgICAgICAgKG9wLnByZXYgYXMgdW5rbm93biBhcyBpci5FbGVtZW50T3ApLmtpbmQgPSBpci5PcEtpbmQuRWxlbWVudDtcblxuICAgICAgICAvLyBSZW1vdmUgdGhlIGBFbGVtZW50RW5kYCBpbnN0cnVjdGlvbi5cbiAgICAgICAgaXIuT3BMaXN0LnJlbW92ZTxpci5DcmVhdGVPcD4ob3ApO1xuICAgICAgfVxuICAgIH1cbiAgfVxufVxuIl19
@@ -0,0 +1,56 @@
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
+ import * as ir from '../../ir';
9
+ /**
10
+ * Generate `ir.AdvanceOp`s in between `ir.UpdateOp`s that ensure the runtime's implicit slot
11
+ * context will be advanced correctly.
12
+ */
13
+ export function phaseGenerateAdvance(cpl) {
14
+ for (const [_, view] of cpl.views) {
15
+ // First build a map of all of the declarations in the view that have assigned slots.
16
+ const slotMap = new Map();
17
+ for (const op of view.create) {
18
+ if (!ir.hasConsumesSlotTrait(op)) {
19
+ continue;
20
+ }
21
+ else if (op.slot === null) {
22
+ throw new Error(`AssertionError: expected slots to have been allocated before generating advance() calls`);
23
+ }
24
+ slotMap.set(op.xref, op.slot);
25
+ }
26
+ // Next, step through the update operations and generate `ir.AdvanceOp`s as required to ensure
27
+ // the runtime's implicit slot counter will be set to the correct slot before executing each
28
+ // update operation which depends on it.
29
+ //
30
+ // To do that, we track what the runtime's slot counter will be through the update operations.
31
+ let slotContext = 0;
32
+ for (const op of view.update) {
33
+ if (!ir.hasDependsOnSlotContextTrait(op)) {
34
+ // `op` doesn't depend on the slot counter, so it can be skipped.
35
+ continue;
36
+ }
37
+ else if (!slotMap.has(op.target)) {
38
+ // We expect ops that _do_ depend on the slot counter to point at declarations that exist in
39
+ // the `slotMap`.
40
+ throw new Error(`AssertionError: reference to unknown slot for var ${op.target}`);
41
+ }
42
+ const slot = slotMap.get(op.target);
43
+ // Does the slot counter need to be adjusted?
44
+ if (slotContext !== slot) {
45
+ // If so, generate an `ir.AdvanceOp` to advance the counter.
46
+ const delta = slot - slotContext;
47
+ if (delta < 0) {
48
+ throw new Error(`AssertionError: slot counter should never need to move backwards`);
49
+ }
50
+ ir.OpList.insertBefore(op, ir.createAdvanceOp(delta));
51
+ slotContext = slot;
52
+ }
53
+ }
54
+ }
55
+ }
56
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiZ2VuZXJhdGVfYWR2YW5jZS5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uLy4uLy4uLy4uLy4uLy4uL3BhY2thZ2VzL2NvbXBpbGVyL3NyYy90ZW1wbGF0ZS9waXBlbGluZS9zcmMvcGhhc2VzL2dlbmVyYXRlX2FkdmFuY2UudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUE7Ozs7OztHQU1HO0FBRUgsT0FBTyxLQUFLLEVBQUUsTUFBTSxVQUFVLENBQUM7QUFHL0I7OztHQUdHO0FBQ0gsTUFBTSxVQUFVLG9CQUFvQixDQUFDLEdBQXlCO0lBQzVELEtBQUssTUFBTSxDQUFDLENBQUMsRUFBRSxJQUFJLENBQUMsSUFBSSxHQUFHLENBQUMsS0FBSyxFQUFFO1FBQ2pDLHFGQUFxRjtRQUNyRixNQUFNLE9BQU8sR0FBRyxJQUFJLEdBQUcsRUFBcUIsQ0FBQztRQUM3QyxLQUFLLE1BQU0sRUFBRSxJQUFJLElBQUksQ0FBQyxNQUFNLEVBQUU7WUFDNUIsSUFBSSxDQUFDLEVBQUUsQ0FBQyxvQkFBb0IsQ0FBQyxFQUFFLENBQUMsRUFBRTtnQkFDaEMsU0FBUzthQUNWO2lCQUFNLElBQUksRUFBRSxDQUFDLElBQUksS0FBSyxJQUFJLEVBQUU7Z0JBQzNCLE1BQU0sSUFBSSxLQUFLLENBQ1gseUZBQXlGLENBQUMsQ0FBQzthQUNoRztZQUVELE9BQU8sQ0FBQyxHQUFHLENBQUMsRUFBRSxDQUFDLElBQUksRUFBRSxFQUFFLENBQUMsSUFBSSxDQUFDLENBQUM7U0FDL0I7UUFFRCw4RkFBOEY7UUFDOUYsNEZBQTRGO1FBQzVGLHdDQUF3QztRQUN4QyxFQUFFO1FBQ0YsOEZBQThGO1FBQzlGLElBQUksV0FBVyxHQUFHLENBQUMsQ0FBQztRQUNwQixLQUFLLE1BQU0sRUFBRSxJQUFJLElBQUksQ0FBQyxNQUFNLEVBQUU7WUFDNUIsSUFBSSxDQUFDLEVBQUUsQ0FBQyw0QkFBNEIsQ0FBQyxFQUFFLENBQUMsRUFBRTtnQkFDeEMsaUVBQWlFO2dCQUNqRSxTQUFTO2FBQ1Y7aUJBQU0sSUFBSSxDQUFDLE9BQU8sQ0FBQyxHQUFHLENBQUMsRUFBRSxDQUFDLE1BQU0sQ0FBQyxFQUFFO2dCQUNsQyw0RkFBNEY7Z0JBQzVGLGlCQUFpQjtnQkFDakIsTUFBTSxJQUFJLEtBQUssQ0FBQyxxREFBcUQsRUFBRSxDQUFDLE1BQU0sRUFBRSxDQUFDLENBQUM7YUFDbkY7WUFFRCxNQUFNLElBQUksR0FBRyxPQUFPLENBQUMsR0FBRyxDQUFDLEVBQUUsQ0FBQyxNQUFNLENBQUUsQ0FBQztZQUVyQyw2Q0FBNkM7WUFDN0MsSUFBSSxXQUFXLEtBQUssSUFBSSxFQUFFO2dCQUN4Qiw0REFBNEQ7Z0JBQzVELE1BQU0sS0FBSyxHQUFHLElBQUksR0FBRyxXQUFXLENBQUM7Z0JBQ2pDLElBQUksS0FBSyxHQUFHLENBQUMsRUFBRTtvQkFDYixNQUFNLElBQUksS0FBSyxDQUFDLGtFQUFrRSxDQUFDLENBQUM7aUJBQ3JGO2dCQUVELEVBQUUsQ0FBQyxNQUFNLENBQUMsWUFBWSxDQUFjLEVBQUUsRUFBRSxFQUFFLENBQUMsZUFBZSxDQUFDLEtBQUssQ0FBQyxDQUFDLENBQUM7Z0JBQ25FLFdBQVcsR0FBRyxJQUFJLENBQUM7YUFDcEI7U0FDRjtLQUNGO0FBQ0gsQ0FBQyIsInNvdXJjZXNDb250ZW50IjpbIi8qKlxuICogQGxpY2Vuc2VcbiAqIENvcHlyaWdodCBHb29nbGUgTExDIEFsbCBSaWdodHMgUmVzZXJ2ZWQuXG4gKlxuICogVXNlIG9mIHRoaXMgc291cmNlIGNvZGUgaXMgZ292ZXJuZWQgYnkgYW4gTUlULXN0eWxlIGxpY2Vuc2UgdGhhdCBjYW4gYmVcbiAqIGZvdW5kIGluIHRoZSBMSUNFTlNFIGZpbGUgYXQgaHR0cHM6Ly9hbmd1bGFyLmlvL2xpY2Vuc2VcbiAqL1xuXG5pbXBvcnQgKiBhcyBpciBmcm9tICcuLi8uLi9pcic7XG5pbXBvcnQge0NvbXBvbmVudENvbXBpbGF0aW9ufSBmcm9tICcuLi9jb21waWxhdGlvbic7XG5cbi8qKlxuICogR2VuZXJhdGUgYGlyLkFkdmFuY2VPcGBzIGluIGJldHdlZW4gYGlyLlVwZGF0ZU9wYHMgdGhhdCBlbnN1cmUgdGhlIHJ1bnRpbWUncyBpbXBsaWNpdCBzbG90XG4gKiBjb250ZXh0IHdpbGwgYmUgYWR2YW5jZWQgY29ycmVjdGx5LlxuICovXG5leHBvcnQgZnVuY3Rpb24gcGhhc2VHZW5lcmF0ZUFkdmFuY2UoY3BsOiBDb21wb25lbnRDb21waWxhdGlvbik6IHZvaWQge1xuICBmb3IgKGNvbnN0IFtfLCB2aWV3XSBvZiBjcGwudmlld3MpIHtcbiAgICAvLyBGaXJzdCBidWlsZCBhIG1hcCBvZiBhbGwgb2YgdGhlIGRlY2xhcmF0aW9ucyBpbiB0aGUgdmlldyB0aGF0IGhhdmUgYXNzaWduZWQgc2xvdHMuXG4gICAgY29uc3Qgc2xvdE1hcCA9IG5ldyBNYXA8aXIuWHJlZklkLCBudW1iZXI+KCk7XG4gICAgZm9yIChjb25zdCBvcCBvZiB2aWV3LmNyZWF0ZSkge1xuICAgICAgaWYgKCFpci5oYXNDb25zdW1lc1Nsb3RUcmFpdChvcCkpIHtcbiAgICAgICAgY29udGludWU7XG4gICAgICB9IGVsc2UgaWYgKG9wLnNsb3QgPT09IG51bGwpIHtcbiAgICAgICAgdGhyb3cgbmV3IEVycm9yKFxuICAgICAgICAgICAgYEFzc2VydGlvbkVycm9yOiBleHBlY3RlZCBzbG90cyB0byBoYXZlIGJlZW4gYWxsb2NhdGVkIGJlZm9yZSBnZW5lcmF0aW5nIGFkdmFuY2UoKSBjYWxsc2ApO1xuICAgICAgfVxuXG4gICAgICBzbG90TWFwLnNldChvcC54cmVmLCBvcC5zbG90KTtcbiAgICB9XG5cbiAgICAvLyBOZXh0LCBzdGVwIHRocm91Z2ggdGhlIHVwZGF0ZSBvcGVyYXRpb25zIGFuZCBnZW5lcmF0ZSBgaXIuQWR2YW5jZU9wYHMgYXMgcmVxdWlyZWQgdG8gZW5zdXJlXG4gICAgLy8gdGhlIHJ1bnRpbWUncyBpbXBsaWNpdCBzbG90IGNvdW50ZXIgd2lsbCBiZSBzZXQgdG8gdGhlIGNvcnJlY3Qgc2xvdCBiZWZvcmUgZXhlY3V0aW5nIGVhY2hcbiAgICAvLyB1cGRhdGUgb3BlcmF0aW9uIHdoaWNoIGRlcGVuZHMgb24gaXQuXG4gICAgLy9cbiAgICAvLyBUbyBkbyB0aGF0LCB3ZSB0cmFjayB3aGF0IHRoZSBydW50aW1lJ3Mgc2xvdCBjb3VudGVyIHdpbGwgYmUgdGhyb3VnaCB0aGUgdXBkYXRlIG9wZXJhdGlvbnMuXG4gICAgbGV0IHNsb3RDb250ZXh0ID0gMDtcbiAgICBmb3IgKGNvbnN0IG9wIG9mIHZpZXcudXBkYXRlKSB7XG4gICAgICBpZiAoIWlyLmhhc0RlcGVuZHNPblNsb3RDb250ZXh0VHJhaXQob3ApKSB7XG4gICAgICAgIC8vIGBvcGAgZG9lc24ndCBkZXBlbmQgb24gdGhlIHNsb3QgY291bnRlciwgc28gaXQgY2FuIGJlIHNraXBwZWQuXG4gICAgICAgIGNvbnRpbnVlO1xuICAgICAgfSBlbHNlIGlmICghc2xvdE1hcC5oYXMob3AudGFyZ2V0KSkge1xuICAgICAgICAvLyBXZSBleHBlY3Qgb3BzIHRoYXQgX2RvXyBkZXBlbmQgb24gdGhlIHNsb3QgY291bnRlciB0byBwb2ludCBhdCBkZWNsYXJhdGlvbnMgdGhhdCBleGlzdCBpblxuICAgICAgICAvLyB0aGUgYHNsb3RNYXBgLlxuICAgICAgICB0aHJvdyBuZXcgRXJyb3IoYEFzc2VydGlvbkVycm9yOiByZWZlcmVuY2UgdG8gdW5rbm93biBzbG90IGZvciB2YXIgJHtvcC50YXJnZXR9YCk7XG4gICAgICB9XG5cbiAgICAgIGNvbnN0IHNsb3QgPSBzbG90TWFwLmdldChvcC50YXJnZXQpITtcblxuICAgICAgLy8gRG9lcyB0aGUgc2xvdCBjb3VudGVyIG5lZWQgdG8gYmUgYWRqdXN0ZWQ/XG4gICAgICBpZiAoc2xvdENvbnRleHQgIT09IHNsb3QpIHtcbiAgICAgICAgLy8gSWYgc28sIGdlbmVyYXRlIGFuIGBpci5BZHZhbmNlT3BgIHRvIGFkdmFuY2UgdGhlIGNvdW50ZXIuXG4gICAgICAgIGNvbnN0IGRlbHRhID0gc2xvdCAtIHNsb3RDb250ZXh0O1xuICAgICAgICBpZiAoZGVsdGEgPCAwKSB7XG4gICAgICAgICAgdGhyb3cgbmV3IEVycm9yKGBBc3NlcnRpb25FcnJvcjogc2xvdCBjb3VudGVyIHNob3VsZCBuZXZlciBuZWVkIHRvIG1vdmUgYmFja3dhcmRzYCk7XG4gICAgICAgIH1cblxuICAgICAgICBpci5PcExpc3QuaW5zZXJ0QmVmb3JlPGlyLlVwZGF0ZU9wPihvcCwgaXIuY3JlYXRlQWR2YW5jZU9wKGRlbHRhKSk7XG4gICAgICAgIHNsb3RDb250ZXh0ID0gc2xvdDtcbiAgICAgIH1cbiAgICB9XG4gIH1cbn1cbiJdfQ==