@angular/compiler 17.0.0-next.1 → 17.0.0-next.3
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/esm2022/src/compiler.mjs +2 -2
- package/esm2022/src/compiler_util/expression_converter.mjs +22 -2
- package/esm2022/src/constant_pool.mjs +21 -2
- package/esm2022/src/output/abstract_emitter.mjs +1 -1
- package/esm2022/src/output/abstract_js_emitter.mjs +25 -1
- package/esm2022/src/output/output_ast.mjs +49 -3
- package/esm2022/src/render3/partial/class_metadata.mjs +1 -1
- package/esm2022/src/render3/partial/directive.mjs +1 -1
- package/esm2022/src/render3/partial/factory.mjs +1 -1
- package/esm2022/src/render3/partial/injectable.mjs +1 -1
- package/esm2022/src/render3/partial/injector.mjs +1 -1
- package/esm2022/src/render3/partial/ng_module.mjs +1 -1
- package/esm2022/src/render3/partial/pipe.mjs +1 -1
- package/esm2022/src/render3/r3_ast.mjs +1 -1
- package/esm2022/src/render3/r3_control_flow.mjs +7 -2
- package/esm2022/src/render3/r3_identifiers.mjs +6 -1
- package/esm2022/src/render3/view/compiler.mjs +26 -9
- package/esm2022/src/render3/view/template.mjs +215 -31
- package/esm2022/src/render3/view/util.mjs +2 -1
- package/esm2022/src/template/pipeline/ir/src/enums.mjs +41 -17
- package/esm2022/src/template/pipeline/ir/src/expression.mjs +69 -2
- package/esm2022/src/template/pipeline/ir/src/operations.mjs +13 -1
- package/esm2022/src/template/pipeline/ir/src/ops/create.mjs +46 -25
- package/esm2022/src/template/pipeline/ir/src/ops/host.mjs +3 -2
- package/esm2022/src/template/pipeline/ir/src/ops/update.mjs +18 -2
- package/esm2022/src/template/pipeline/src/compilation.mjs +107 -87
- package/esm2022/src/template/pipeline/src/emit.mjs +69 -72
- package/esm2022/src/template/pipeline/src/ingest.mjs +93 -58
- package/esm2022/src/template/pipeline/src/instruction.mjs +27 -9
- package/esm2022/src/template/pipeline/src/phases/align_pipe_variadic_var_offset.mjs +4 -4
- package/esm2022/src/template/pipeline/src/phases/any_cast.mjs +4 -4
- package/esm2022/src/template/pipeline/src/phases/attribute_extraction.mjs +34 -12
- package/esm2022/src/template/pipeline/src/phases/binding_specialization.mjs +4 -5
- package/esm2022/src/template/pipeline/src/phases/chaining.mjs +4 -1
- package/esm2022/src/template/pipeline/src/phases/conditionals.mjs +44 -0
- package/esm2022/src/template/pipeline/src/phases/const_collection.mjs +49 -13
- package/esm2022/src/template/pipeline/src/phases/empty_elements.mjs +5 -4
- package/esm2022/src/template/pipeline/src/phases/generate_advance.mjs +5 -5
- package/esm2022/src/template/pipeline/src/phases/generate_i18n_blocks.mjs +38 -0
- package/esm2022/src/template/pipeline/src/phases/generate_variables.mjs +3 -3
- package/esm2022/src/template/pipeline/src/phases/host_style_property_parsing.mjs +10 -4
- package/esm2022/src/template/pipeline/src/phases/i18n_message_extraction.mjs +108 -0
- package/esm2022/src/template/pipeline/src/phases/i18n_text_extraction.mjs +32 -0
- package/esm2022/src/template/pipeline/src/phases/local_refs.mjs +5 -5
- package/esm2022/src/template/pipeline/src/phases/namespace.mjs +3 -3
- package/esm2022/src/template/pipeline/src/phases/naming.mjs +19 -14
- package/esm2022/src/template/pipeline/src/phases/next_context_merging.mjs +5 -5
- package/esm2022/src/template/pipeline/src/phases/ng_container.mjs +4 -4
- package/esm2022/src/template/pipeline/src/phases/nonbindable.mjs +3 -3
- package/esm2022/src/template/pipeline/src/phases/ordering.mjs +97 -0
- package/esm2022/src/template/pipeline/src/phases/parse_extracted_styles.mjs +3 -3
- package/esm2022/src/template/pipeline/src/phases/pipe_creation.mjs +9 -9
- package/esm2022/src/template/pipeline/src/phases/pipe_variadic.mjs +4 -4
- package/esm2022/src/template/pipeline/src/phases/reify.mjs +31 -3
- package/esm2022/src/template/pipeline/src/phases/resolve_dollar_event.mjs +6 -6
- package/esm2022/src/template/pipeline/src/phases/resolve_i18n_placeholders.mjs +63 -0
- package/esm2022/src/template/pipeline/src/phases/resolve_sanitizers.mjs +5 -5
- package/esm2022/src/template/pipeline/src/phases/save_restore_view.mjs +8 -8
- package/esm2022/src/template/pipeline/src/phases/slot_allocation.mjs +8 -8
- package/esm2022/src/template/pipeline/src/phases/var_counting.mjs +3 -3
- package/esm2022/src/template/pipeline/src/util/elements.mjs +3 -3
- package/esm2022/src/version.mjs +1 -1
- package/fesm2022/compiler.mjs +10287 -9431
- package/fesm2022/compiler.mjs.map +1 -1
- package/fesm2022/testing.mjs +1 -1
- package/index.d.ts +28 -5
- package/package.json +2 -2
- package/testing/index.d.ts +1 -1
- package/esm2022/src/template/pipeline/src/phases/property_ordering.mjs +0 -99
|
@@ -18,8 +18,8 @@ const compatibilityMode = ir.CompatibilityMode.TemplateDefinitionBuilder;
|
|
|
18
18
|
* Process a template AST and convert it into a `ComponentCompilation` in the intermediate
|
|
19
19
|
* representation.
|
|
20
20
|
*/
|
|
21
|
-
export function ingestComponent(componentName, template, constantPool) {
|
|
22
|
-
const cpl = new ComponentCompilationJob(componentName, constantPool, compatibilityMode);
|
|
21
|
+
export function ingestComponent(componentName, template, constantPool, relativeContextFilePath, i18nUseExternalIds) {
|
|
22
|
+
const cpl = new ComponentCompilationJob(componentName, constantPool, compatibilityMode, relativeContextFilePath, i18nUseExternalIds);
|
|
23
23
|
ingestNodes(cpl.root, template);
|
|
24
24
|
return cpl;
|
|
25
25
|
}
|
|
@@ -32,6 +32,9 @@ export function ingestHostBinding(input, bindingParser, constantPool) {
|
|
|
32
32
|
for (const property of input.properties ?? []) {
|
|
33
33
|
ingestHostProperty(job, property, false);
|
|
34
34
|
}
|
|
35
|
+
for (const [name, expr] of Object.entries(input.attributes) ?? []) {
|
|
36
|
+
ingestHostAttribute(job, name, expr);
|
|
37
|
+
}
|
|
35
38
|
for (const event of input.events ?? []) {
|
|
36
39
|
ingestHostEvent(job, event);
|
|
37
40
|
}
|
|
@@ -55,26 +58,42 @@ export function ingestHostProperty(job, property, isTextAttribute) {
|
|
|
55
58
|
property.name = property.name.substring('attr.'.length);
|
|
56
59
|
bindingKind = ir.BindingKind.Attribute;
|
|
57
60
|
}
|
|
58
|
-
|
|
61
|
+
if (property.isAnimation) {
|
|
62
|
+
bindingKind = ir.BindingKind.Animation;
|
|
63
|
+
}
|
|
64
|
+
job.root.update.push(ir.createBindingOp(job.root.xref, bindingKind, property.name, expression, null, SecurityContext
|
|
59
65
|
.NONE /* TODO: what should we pass as security context? Passing NONE for now. */, isTextAttribute, false, property.sourceSpan));
|
|
60
66
|
}
|
|
61
|
-
export function
|
|
67
|
+
export function ingestHostAttribute(job, name, value) {
|
|
68
|
+
const attrBinding = ir.createBindingOp(job.root.xref, ir.BindingKind.Attribute, name, value, null, SecurityContext.NONE, true, false,
|
|
69
|
+
/* TODO: host attribute source spans */ null);
|
|
70
|
+
job.root.update.push(attrBinding);
|
|
71
|
+
}
|
|
72
|
+
export function ingestHostEvent(job, event) {
|
|
73
|
+
const eventBinding = ir.createListenerOp(job.root.xref, event.name, null, event.targetOrPhase, true);
|
|
74
|
+
// TODO: Can this be a chain?
|
|
75
|
+
eventBinding.handlerOps.push(ir.createStatementOp(new o.ReturnStatement(convertAst(event.handler.ast, job))));
|
|
76
|
+
job.root.create.push(eventBinding);
|
|
77
|
+
}
|
|
62
78
|
/**
|
|
63
79
|
* Ingest the nodes of a template AST into the given `ViewCompilation`.
|
|
64
80
|
*/
|
|
65
|
-
function ingestNodes(
|
|
81
|
+
function ingestNodes(unit, template) {
|
|
66
82
|
for (const node of template) {
|
|
67
83
|
if (node instanceof t.Element) {
|
|
68
|
-
ingestElement(
|
|
84
|
+
ingestElement(unit, node);
|
|
69
85
|
}
|
|
70
86
|
else if (node instanceof t.Template) {
|
|
71
|
-
ingestTemplate(
|
|
87
|
+
ingestTemplate(unit, node);
|
|
72
88
|
}
|
|
73
89
|
else if (node instanceof t.Text) {
|
|
74
|
-
ingestText(
|
|
90
|
+
ingestText(unit, node);
|
|
75
91
|
}
|
|
76
92
|
else if (node instanceof t.BoundText) {
|
|
77
|
-
ingestBoundText(
|
|
93
|
+
ingestBoundText(unit, node);
|
|
94
|
+
}
|
|
95
|
+
else if (node instanceof t.SwitchBlock) {
|
|
96
|
+
ingestSwitchBlock(unit, node);
|
|
78
97
|
}
|
|
79
98
|
else {
|
|
80
99
|
throw new Error(`Unsupported template node: ${node.constructor.name}`);
|
|
@@ -84,34 +103,34 @@ function ingestNodes(view, template) {
|
|
|
84
103
|
/**
|
|
85
104
|
* Ingest an element AST from the template into the given `ViewCompilation`.
|
|
86
105
|
*/
|
|
87
|
-
function ingestElement(
|
|
106
|
+
function ingestElement(unit, element) {
|
|
88
107
|
const staticAttributes = {};
|
|
89
108
|
for (const attr of element.attributes) {
|
|
90
109
|
staticAttributes[attr.name] = attr.value;
|
|
91
110
|
}
|
|
92
|
-
const id =
|
|
111
|
+
const id = unit.job.allocateXrefId();
|
|
93
112
|
const [namespaceKey, elementName] = splitNsName(element.name);
|
|
94
|
-
const startOp = ir.createElementStartOp(elementName, id, namespaceForKey(namespaceKey), element.startSourceSpan);
|
|
95
|
-
|
|
96
|
-
ingestBindings(
|
|
113
|
+
const startOp = ir.createElementStartOp(elementName, id, namespaceForKey(namespaceKey), element.i18n, element.startSourceSpan);
|
|
114
|
+
unit.create.push(startOp);
|
|
115
|
+
ingestBindings(unit, startOp, element);
|
|
97
116
|
ingestReferences(startOp, element);
|
|
98
|
-
ingestNodes(
|
|
99
|
-
|
|
117
|
+
ingestNodes(unit, element.children);
|
|
118
|
+
unit.create.push(ir.createElementEndOp(id, element.endSourceSpan));
|
|
100
119
|
}
|
|
101
120
|
/**
|
|
102
121
|
* Ingest an `ng-template` node from the AST into the given `ViewCompilation`.
|
|
103
122
|
*/
|
|
104
|
-
function ingestTemplate(
|
|
105
|
-
const childView =
|
|
123
|
+
function ingestTemplate(unit, tmpl) {
|
|
124
|
+
const childView = unit.job.allocateView(unit.xref);
|
|
106
125
|
let tagNameWithoutNamespace = tmpl.tagName;
|
|
107
126
|
let namespacePrefix = '';
|
|
108
127
|
if (tmpl.tagName) {
|
|
109
128
|
[namespacePrefix, tagNameWithoutNamespace] = splitNsName(tmpl.tagName);
|
|
110
129
|
}
|
|
111
130
|
// TODO: validate the fallback tag name here.
|
|
112
|
-
const tplOp = ir.createTemplateOp(childView.xref, tagNameWithoutNamespace ?? 'ng-template', namespaceForKey(namespacePrefix), tmpl.startSourceSpan);
|
|
113
|
-
|
|
114
|
-
ingestBindings(
|
|
131
|
+
const tplOp = ir.createTemplateOp(childView.xref, tagNameWithoutNamespace ?? 'ng-template', namespaceForKey(namespacePrefix), tmpl.i18n, tmpl.startSourceSpan);
|
|
132
|
+
unit.create.push(tplOp);
|
|
133
|
+
ingestBindings(unit, tplOp, tmpl);
|
|
115
134
|
ingestReferences(tplOp, tmpl);
|
|
116
135
|
ingestNodes(childView, tmpl.children);
|
|
117
136
|
for (const { name, value } of tmpl.variables) {
|
|
@@ -121,13 +140,13 @@ function ingestTemplate(view, tmpl) {
|
|
|
121
140
|
/**
|
|
122
141
|
* Ingest a literal text node from the AST into the given `ViewCompilation`.
|
|
123
142
|
*/
|
|
124
|
-
function ingestText(
|
|
125
|
-
|
|
143
|
+
function ingestText(unit, text) {
|
|
144
|
+
unit.create.push(ir.createTextOp(unit.job.allocateXrefId(), text.value, text.sourceSpan));
|
|
126
145
|
}
|
|
127
146
|
/**
|
|
128
147
|
* Ingest an interpolated text node from the AST into the given `ViewCompilation`.
|
|
129
148
|
*/
|
|
130
|
-
function ingestBoundText(
|
|
149
|
+
function ingestBoundText(unit, text) {
|
|
131
150
|
let value = text.value;
|
|
132
151
|
if (value instanceof e.ASTWithSource) {
|
|
133
152
|
value = value.ast;
|
|
@@ -135,37 +154,56 @@ function ingestBoundText(view, text) {
|
|
|
135
154
|
if (!(value instanceof e.Interpolation)) {
|
|
136
155
|
throw new Error(`AssertionError: expected Interpolation for BoundText node, got ${value.constructor.name}`);
|
|
137
156
|
}
|
|
138
|
-
const textXref =
|
|
139
|
-
|
|
140
|
-
|
|
157
|
+
const textXref = unit.job.allocateXrefId();
|
|
158
|
+
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));
|
|
160
|
+
}
|
|
161
|
+
/**
|
|
162
|
+
* Ingest a `{#switch}` block into the given `ViewCompilation`.
|
|
163
|
+
*/
|
|
164
|
+
function ingestSwitchBlock(unit, switchBlock) {
|
|
165
|
+
let firstXref = null;
|
|
166
|
+
let conditions = [];
|
|
167
|
+
for (const switchCase of switchBlock.cases) {
|
|
168
|
+
const cView = unit.job.allocateView(unit.xref);
|
|
169
|
+
if (!firstXref)
|
|
170
|
+
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;
|
|
173
|
+
conditions.push([cView.xref, caseExpr]);
|
|
174
|
+
ingestNodes(cView, switchCase.children);
|
|
175
|
+
}
|
|
176
|
+
const conditional = ir.createConditionalOp(firstXref, convertAst(switchBlock.expression, unit.job), null);
|
|
177
|
+
conditional.conditions = conditions;
|
|
178
|
+
unit.update.push(conditional);
|
|
141
179
|
}
|
|
142
180
|
/**
|
|
143
181
|
* Convert a template AST expression into an output AST expression.
|
|
144
182
|
*/
|
|
145
|
-
function convertAst(ast,
|
|
183
|
+
function convertAst(ast, job) {
|
|
146
184
|
if (ast instanceof e.ASTWithSource) {
|
|
147
|
-
return convertAst(ast.ast,
|
|
185
|
+
return convertAst(ast.ast, job);
|
|
148
186
|
}
|
|
149
187
|
else if (ast instanceof e.PropertyRead) {
|
|
150
188
|
if (ast.receiver instanceof e.ImplicitReceiver && !(ast.receiver instanceof e.ThisReceiver)) {
|
|
151
189
|
return new ir.LexicalReadExpr(ast.name);
|
|
152
190
|
}
|
|
153
191
|
else {
|
|
154
|
-
return new o.ReadPropExpr(convertAst(ast.receiver,
|
|
192
|
+
return new o.ReadPropExpr(convertAst(ast.receiver, job), ast.name);
|
|
155
193
|
}
|
|
156
194
|
}
|
|
157
195
|
else if (ast instanceof e.PropertyWrite) {
|
|
158
|
-
return new o.WritePropExpr(convertAst(ast.receiver,
|
|
196
|
+
return new o.WritePropExpr(convertAst(ast.receiver, job), ast.name, convertAst(ast.value, job));
|
|
159
197
|
}
|
|
160
198
|
else if (ast instanceof e.KeyedWrite) {
|
|
161
|
-
return new o.WriteKeyExpr(convertAst(ast.receiver,
|
|
199
|
+
return new o.WriteKeyExpr(convertAst(ast.receiver, job), convertAst(ast.key, job), convertAst(ast.value, job));
|
|
162
200
|
}
|
|
163
201
|
else if (ast instanceof e.Call) {
|
|
164
202
|
if (ast.receiver instanceof e.ImplicitReceiver) {
|
|
165
203
|
throw new Error(`Unexpected ImplicitReceiver`);
|
|
166
204
|
}
|
|
167
205
|
else {
|
|
168
|
-
return new o.InvokeFunctionExpr(convertAst(ast.receiver,
|
|
206
|
+
return new o.InvokeFunctionExpr(convertAst(ast.receiver, job), ast.args.map(arg => convertAst(arg, job)));
|
|
169
207
|
}
|
|
170
208
|
}
|
|
171
209
|
else if (ast instanceof e.LiteralPrimitive) {
|
|
@@ -176,13 +214,13 @@ function convertAst(ast, cpl) {
|
|
|
176
214
|
if (operator === undefined) {
|
|
177
215
|
throw new Error(`AssertionError: unknown binary operator ${ast.operation}`);
|
|
178
216
|
}
|
|
179
|
-
return new o.BinaryOperatorExpr(operator, convertAst(ast.left,
|
|
217
|
+
return new o.BinaryOperatorExpr(operator, convertAst(ast.left, job), convertAst(ast.right, job));
|
|
180
218
|
}
|
|
181
219
|
else if (ast instanceof e.ThisReceiver) {
|
|
182
|
-
return new ir.ContextExpr(
|
|
220
|
+
return new ir.ContextExpr(job.root.xref);
|
|
183
221
|
}
|
|
184
222
|
else if (ast instanceof e.KeyedRead) {
|
|
185
|
-
return new o.ReadKeyExpr(convertAst(ast.receiver,
|
|
223
|
+
return new o.ReadKeyExpr(convertAst(ast.receiver, job), convertAst(ast.key, job));
|
|
186
224
|
}
|
|
187
225
|
else if (ast instanceof e.Chain) {
|
|
188
226
|
throw new Error(`AssertionError: Chain in unknown context`);
|
|
@@ -190,34 +228,34 @@ function convertAst(ast, cpl) {
|
|
|
190
228
|
else if (ast instanceof e.LiteralMap) {
|
|
191
229
|
const entries = ast.keys.map((key, idx) => {
|
|
192
230
|
const value = ast.values[idx];
|
|
193
|
-
return new o.LiteralMapEntry(key.key, convertAst(value,
|
|
231
|
+
return new o.LiteralMapEntry(key.key, convertAst(value, job), key.quoted);
|
|
194
232
|
});
|
|
195
233
|
return new o.LiteralMapExpr(entries);
|
|
196
234
|
}
|
|
197
235
|
else if (ast instanceof e.LiteralArray) {
|
|
198
|
-
return new o.LiteralArrayExpr(ast.expressions.map(expr => convertAst(expr,
|
|
236
|
+
return new o.LiteralArrayExpr(ast.expressions.map(expr => convertAst(expr, job)));
|
|
199
237
|
}
|
|
200
238
|
else if (ast instanceof e.Conditional) {
|
|
201
|
-
return new o.ConditionalExpr(convertAst(ast.condition,
|
|
239
|
+
return new o.ConditionalExpr(convertAst(ast.condition, job), convertAst(ast.trueExp, job), convertAst(ast.falseExp, job));
|
|
202
240
|
}
|
|
203
241
|
else if (ast instanceof e.NonNullAssert) {
|
|
204
242
|
// A non-null assertion shouldn't impact generated instructions, so we can just drop it.
|
|
205
|
-
return convertAst(ast.expression,
|
|
243
|
+
return convertAst(ast.expression, job);
|
|
206
244
|
}
|
|
207
245
|
else if (ast instanceof e.BindingPipe) {
|
|
208
|
-
return new ir.PipeBindingExpr(
|
|
209
|
-
convertAst(ast.exp,
|
|
210
|
-
...ast.args.map(arg => convertAst(arg,
|
|
246
|
+
return new ir.PipeBindingExpr(job.allocateXrefId(), ast.name, [
|
|
247
|
+
convertAst(ast.exp, job),
|
|
248
|
+
...ast.args.map(arg => convertAst(arg, job)),
|
|
211
249
|
]);
|
|
212
250
|
}
|
|
213
251
|
else if (ast instanceof e.SafeKeyedRead) {
|
|
214
|
-
return new ir.SafeKeyedReadExpr(convertAst(ast.receiver,
|
|
252
|
+
return new ir.SafeKeyedReadExpr(convertAst(ast.receiver, job), convertAst(ast.key, job));
|
|
215
253
|
}
|
|
216
254
|
else if (ast instanceof e.SafePropertyRead) {
|
|
217
|
-
return new ir.SafePropertyReadExpr(convertAst(ast.receiver,
|
|
255
|
+
return new ir.SafePropertyReadExpr(convertAst(ast.receiver, job), ast.name);
|
|
218
256
|
}
|
|
219
257
|
else if (ast instanceof e.SafeCall) {
|
|
220
|
-
return new ir.SafeInvokeFunctionExpr(convertAst(ast.receiver,
|
|
258
|
+
return new ir.SafeInvokeFunctionExpr(convertAst(ast.receiver, job), ast.args.map(a => convertAst(a, job)));
|
|
221
259
|
}
|
|
222
260
|
else if (ast instanceof e.EmptyExpr) {
|
|
223
261
|
return new ir.EmptyExpr();
|
|
@@ -230,14 +268,14 @@ function convertAst(ast, cpl) {
|
|
|
230
268
|
* Process all of the bindings on an element-like structure in the template AST and convert them
|
|
231
269
|
* to their IR representation.
|
|
232
270
|
*/
|
|
233
|
-
function ingestBindings(
|
|
271
|
+
function ingestBindings(unit, op, element) {
|
|
234
272
|
if (element instanceof t.Template) {
|
|
235
273
|
for (const attr of element.templateAttrs) {
|
|
236
274
|
if (attr instanceof t.TextAttribute) {
|
|
237
|
-
ingestBinding(
|
|
275
|
+
ingestBinding(unit, op.xref, attr.name, o.literal(attr.value), 1 /* e.BindingType.Attribute */, null, SecurityContext.NONE, attr.sourceSpan, true, true);
|
|
238
276
|
}
|
|
239
277
|
else {
|
|
240
|
-
ingestBinding(
|
|
278
|
+
ingestBinding(unit, op.xref, attr.name, attr.value, attr.type, attr.unit, attr.securityContext, attr.sourceSpan, false, true);
|
|
241
279
|
}
|
|
242
280
|
}
|
|
243
281
|
}
|
|
@@ -245,10 +283,10 @@ function ingestBindings(view, op, element) {
|
|
|
245
283
|
// This is only attribute TextLiteral bindings, such as `attr.foo="bar"`. This can never be
|
|
246
284
|
// `[attr.foo]="bar"` or `attr.foo="{{bar}}"`, both of which will be handled as inputs with
|
|
247
285
|
// `BindingType.Attribute`.
|
|
248
|
-
ingestBinding(
|
|
286
|
+
ingestBinding(unit, op.xref, attr.name, o.literal(attr.value), 1 /* e.BindingType.Attribute */, null, SecurityContext.NONE, attr.sourceSpan, true, false);
|
|
249
287
|
}
|
|
250
288
|
for (const input of element.inputs) {
|
|
251
|
-
ingestBinding(
|
|
289
|
+
ingestBinding(unit, op.xref, input.name, input.value, input.type, input.unit, input.securityContext, input.sourceSpan, false, false);
|
|
252
290
|
}
|
|
253
291
|
for (const output of element.outputs) {
|
|
254
292
|
let listenerOp;
|
|
@@ -256,11 +294,8 @@ function ingestBindings(view, op, element) {
|
|
|
256
294
|
if (output.phase === null) {
|
|
257
295
|
throw Error('Animation listener should have a phase');
|
|
258
296
|
}
|
|
259
|
-
listenerOp = ir.createListenerOpForAnimation(op.xref, output.name, output.phase, op.tag);
|
|
260
|
-
}
|
|
261
|
-
else {
|
|
262
|
-
listenerOp = ir.createListenerOp(op.xref, output.name, op.tag);
|
|
263
297
|
}
|
|
298
|
+
listenerOp = ir.createListenerOp(op.xref, output.name, op.tag, output.phase, false);
|
|
264
299
|
// if output.handler is a chain, then push each statement from the chain separately, and
|
|
265
300
|
// return the last one?
|
|
266
301
|
let inputExprs;
|
|
@@ -277,14 +312,14 @@ function ingestBindings(view, op, element) {
|
|
|
277
312
|
if (inputExprs.length === 0) {
|
|
278
313
|
throw new Error('Expected listener to have non-empty expression list.');
|
|
279
314
|
}
|
|
280
|
-
const expressions = inputExprs.map(expr => convertAst(expr,
|
|
315
|
+
const expressions = inputExprs.map(expr => convertAst(expr, unit.job));
|
|
281
316
|
const returnExpr = expressions.pop();
|
|
282
317
|
for (const expr of expressions) {
|
|
283
318
|
const stmtOp = ir.createStatementOp(new o.ExpressionStatement(expr));
|
|
284
319
|
listenerOp.handlerOps.push(stmtOp);
|
|
285
320
|
}
|
|
286
321
|
listenerOp.handlerOps.push(ir.createStatementOp(new o.ReturnStatement(returnExpr)));
|
|
287
|
-
|
|
322
|
+
unit.create.push(listenerOp);
|
|
288
323
|
}
|
|
289
324
|
}
|
|
290
325
|
const BINDING_KINDS = new Map([
|
|
@@ -332,4 +367,4 @@ function assertIsArray(value) {
|
|
|
332
367
|
throw new Error(`AssertionError: expected an array`);
|
|
333
368
|
}
|
|
334
369
|
}
|
|
335
|
-
//# 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} 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[],\n    constantPool: ConstantPool): ComponentCompilationJob {\n  const cpl = new ComponentCompilationJob(componentName, constantPool, compatibilityMode);\n  ingestNodes(cpl.root, template);\n  return cpl;\n}\n\nexport interface HostBindingInput {\n  componentName: string;\n  properties: e.ParsedProperty[]|null;\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 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  job.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 ingestHostEvent(job: HostBindingCompilationJob, event: e.ParsedEvent) {}\n\n/**\n * Ingest the nodes of a template AST into the given `ViewCompilation`.\n */\nfunction ingestNodes(view: ViewCompilationUnit, 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\n/**\n * Ingest an element AST from the template into the given `ViewCompilation`.\n */\nfunction ingestElement(view: 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 = view.job.allocateXrefId();\n\n  const [namespaceKey, elementName] = splitNsName(element.name);\n\n  const startOp = ir.createElementStartOp(\n      elementName, id, namespaceForKey(namespaceKey), element.startSourceSpan);\n  view.create.push(startOp);\n\n  ingestBindings(view, startOp, element);\n  ingestReferences(startOp, element);\n\n  ingestNodes(view, element.children);\n  view.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(view: ViewCompilationUnit, tmpl: t.Template): void {\n  const childView = view.job.allocateView(view.xref);\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.startSourceSpan);\n  view.create.push(tplOp);\n\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: ViewCompilationUnit, text: t.Text): void {\n  view.create.push(ir.createTextOp(view.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(view: 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 = view.job.allocateXrefId();\n  view.create.push(ir.createTextOp(textXref, '', text.sourceSpan));\n  view.update.push(ir.createInterpolateTextOp(\n      textXref,\n      new ir.Interpolation(\n          value.strings, value.expressions.map(expr => convertAst(expr, view.job))),\n      text.sourceSpan));\n}\n\n/**\n * Convert a template AST expression into an output AST expression.\n */\nfunction convertAst(ast: e.AST, cpl: CompilationJob): o.Expression {\n  if (ast instanceof e.ASTWithSource) {\n    return convertAst(ast.ast, cpl);\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, cpl), ast.name);\n    }\n  } else if (ast instanceof e.PropertyWrite) {\n    return new o.WritePropExpr(convertAst(ast.receiver, cpl), ast.name, convertAst(ast.value, cpl));\n  } else if (ast instanceof e.KeyedWrite) {\n    return new o.WriteKeyExpr(\n        convertAst(ast.receiver, cpl),\n        convertAst(ast.key, cpl),\n        convertAst(ast.value, cpl),\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, cpl), ast.args.map(arg => convertAst(arg, cpl)));\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, cpl), convertAst(ast.right, cpl));\n  } else if (ast instanceof e.ThisReceiver) {\n    return new ir.ContextExpr(cpl.root.xref);\n  } else if (ast instanceof e.KeyedRead) {\n    return new o.ReadKeyExpr(convertAst(ast.receiver, cpl), convertAst(ast.key, cpl));\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, cpl), 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, cpl)));\n  } else if (ast instanceof e.Conditional) {\n    return new o.ConditionalExpr(\n        convertAst(ast.condition, cpl),\n        convertAst(ast.trueExp, cpl),\n        convertAst(ast.falseExp, cpl),\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, cpl);\n  } else if (ast instanceof e.BindingPipe) {\n    return new ir.PipeBindingExpr(\n        cpl.allocateXrefId(),\n        ast.name,\n        [\n          convertAst(ast.exp, cpl),\n          ...ast.args.map(arg => convertAst(arg, cpl)),\n        ],\n    );\n  } else if (ast instanceof e.SafeKeyedRead) {\n    return new ir.SafeKeyedReadExpr(convertAst(ast.receiver, cpl), convertAst(ast.key, cpl));\n  } else if (ast instanceof e.SafePropertyRead) {\n    return new ir.SafePropertyReadExpr(convertAst(ast.receiver, cpl), ast.name);\n  } else if (ast instanceof e.SafeCall) {\n    return new ir.SafeInvokeFunctionExpr(\n        convertAst(ast.receiver, cpl), ast.args.map(a => convertAst(a, cpl)));\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    view: 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            view, op.xref, attr.name, o.literal(attr.value), e.BindingType.Attribute, null,\n            SecurityContext.NONE, attr.sourceSpan, true, true);\n      } else {\n        ingestBinding(\n            view, 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        view, 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        view, 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      listenerOp = ir.createListenerOpForAnimation(op.xref, output.name, output.phase!, op.tag);\n    } else {\n      listenerOp = ir.createListenerOp(op.xref, output.name, op.tag);\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, view.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    view.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"]}
|
|
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"]}
|