@angular/compiler-cli 7.2.4 → 7.2.8
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/index.js +1 -1
- package/package.json +4 -4
- package/src/diagnostics/expression_diagnostics.js +98 -151
- package/src/diagnostics/expression_type.js +122 -139
- package/src/diagnostics/translate_diagnostics.js +12 -12
- package/src/diagnostics/typescript_symbols.js +296 -514
- package/src/diagnostics/typescript_version.js +8 -8
- package/src/extract_i18n.js +11 -13
- package/src/main.js +80 -78
- package/src/metadata/bundle_index_host.js +39 -51
- package/src/metadata/bundler.js +214 -256
- package/src/metadata/collector.js +235 -317
- package/src/metadata/evaluator.js +146 -162
- package/src/metadata/index.js +1 -1
- package/src/metadata/index_writer.js +25 -47
- package/src/metadata/symbols.js +44 -62
- package/src/ngcc/src/packages/build_marker.d.ts +1 -1
- package/src/ngcc/src/packages/build_marker.js +1 -1
- package/src/ngtools_api.js +29 -44
- package/src/ngtools_api2.js +9 -11
- package/src/ngtsc/program.js +122 -162
- package/src/ngtsc/resource_loader.js +35 -50
- package/src/perform_compile.js +87 -93
- package/src/perform_watch.js +50 -51
- package/src/transformers/compiler_host.js +158 -171
- package/src/transformers/inline_resources.js +54 -57
- package/src/transformers/lower_expressions.js +87 -101
- package/src/transformers/metadata_cache.js +21 -50
- package/src/transformers/metadata_reader.js +17 -18
- package/src/transformers/nocollapse_hack.js +9 -9
- package/src/transformers/node_emitter.js +214 -237
- package/src/transformers/node_emitter_transform.js +25 -21
- package/src/transformers/program.js +336 -440
- package/src/transformers/r3_metadata_transform.js +21 -34
- package/src/transformers/r3_strip_decorators.js +29 -31
- package/src/transformers/r3_transform.js +7 -8
- package/src/transformers/tsc_pass_through.js +33 -37
- package/src/transformers/util.js +18 -30
- package/src/version.js +3 -3
|
@@ -11,21 +11,20 @@
|
|
|
11
11
|
if (v !== undefined) module.exports = v;
|
|
12
12
|
}
|
|
13
13
|
else if (typeof define === "function" && define.amd) {
|
|
14
|
-
define("@angular/compiler-cli/src/metadata/evaluator", ["require", "exports", "
|
|
14
|
+
define("@angular/compiler-cli/src/metadata/evaluator", ["require", "exports", "typescript", "@angular/compiler-cli/src/metadata/schema"], factory);
|
|
15
15
|
}
|
|
16
16
|
})(function (require, exports) {
|
|
17
17
|
"use strict";
|
|
18
18
|
Object.defineProperty(exports, "__esModule", { value: true });
|
|
19
|
-
|
|
20
|
-
|
|
21
|
-
var schema_1 = require("@angular/compiler-cli/src/metadata/schema");
|
|
19
|
+
const ts = require("typescript");
|
|
20
|
+
const schema_1 = require("@angular/compiler-cli/src/metadata/schema");
|
|
22
21
|
// In TypeScript 2.1 the spread element kind was renamed.
|
|
23
|
-
|
|
22
|
+
const spreadElementSyntaxKind = ts.SyntaxKind.SpreadElement || ts.SyntaxKind.SpreadElementExpression;
|
|
24
23
|
function isMethodCallOf(callExpression, memberName) {
|
|
25
|
-
|
|
24
|
+
const expression = callExpression.expression;
|
|
26
25
|
if (expression.kind === ts.SyntaxKind.PropertyAccessExpression) {
|
|
27
|
-
|
|
28
|
-
|
|
26
|
+
const propertyAccessExpression = expression;
|
|
27
|
+
const name = propertyAccessExpression.name;
|
|
29
28
|
if (name.kind == ts.SyntaxKind.Identifier) {
|
|
30
29
|
return name.text === memberName;
|
|
31
30
|
}
|
|
@@ -33,9 +32,9 @@
|
|
|
33
32
|
return false;
|
|
34
33
|
}
|
|
35
34
|
function isCallOf(callExpression, ident) {
|
|
36
|
-
|
|
35
|
+
const expression = callExpression.expression;
|
|
37
36
|
if (expression.kind === ts.SyntaxKind.Identifier) {
|
|
38
|
-
|
|
37
|
+
const identifier = expression;
|
|
39
38
|
return identifier.text === ident;
|
|
40
39
|
}
|
|
41
40
|
return false;
|
|
@@ -47,7 +46,7 @@
|
|
|
47
46
|
if (node && (schema_1.isMetadataImportedSymbolReferenceExpression(entry) ||
|
|
48
47
|
schema_1.isMetadataImportDefaultReference(entry)) &&
|
|
49
48
|
entry.line == null) {
|
|
50
|
-
|
|
49
|
+
const info = sourceInfo(node, sourceFile);
|
|
51
50
|
if (info.line != null)
|
|
52
51
|
entry.line = info.line;
|
|
53
52
|
if (info.character != null)
|
|
@@ -63,7 +62,7 @@
|
|
|
63
62
|
* true if every call to `cb` returns `true`.
|
|
64
63
|
*/
|
|
65
64
|
function everyNodeChild(node, cb) {
|
|
66
|
-
return !ts.forEachChild(node,
|
|
65
|
+
return !ts.forEachChild(node, node => !cb(node));
|
|
67
66
|
}
|
|
68
67
|
function isPrimitive(value) {
|
|
69
68
|
return Object(value) !== value;
|
|
@@ -91,7 +90,7 @@
|
|
|
91
90
|
exports.sourceInfo = sourceInfo;
|
|
92
91
|
/* @internal */
|
|
93
92
|
function errorSymbol(message, node, context, sourceFile) {
|
|
94
|
-
|
|
93
|
+
const result = Object.assign({ __symbolic: 'error', message }, sourceInfo(node, sourceFile));
|
|
95
94
|
if (context) {
|
|
96
95
|
result.context = context;
|
|
97
96
|
}
|
|
@@ -102,26 +101,25 @@
|
|
|
102
101
|
* Produce a symbolic representation of an expression folding values into their final value when
|
|
103
102
|
* possible.
|
|
104
103
|
*/
|
|
105
|
-
|
|
106
|
-
|
|
107
|
-
if (options === void 0) { options = {}; }
|
|
104
|
+
class Evaluator {
|
|
105
|
+
constructor(symbols, nodeMap, options = {}, recordExport) {
|
|
108
106
|
this.symbols = symbols;
|
|
109
107
|
this.nodeMap = nodeMap;
|
|
110
108
|
this.options = options;
|
|
111
109
|
this.recordExport = recordExport;
|
|
112
110
|
}
|
|
113
|
-
|
|
111
|
+
nameOf(node) {
|
|
114
112
|
if (node && node.kind == ts.SyntaxKind.Identifier) {
|
|
115
113
|
return node.text;
|
|
116
114
|
}
|
|
117
|
-
|
|
115
|
+
const result = node && this.evaluateNode(node);
|
|
118
116
|
if (schema_1.isMetadataError(result) || typeof result === 'string') {
|
|
119
117
|
return result;
|
|
120
118
|
}
|
|
121
119
|
else {
|
|
122
120
|
return errorSymbol('Name expected', node, { received: (node && node.getText()) || '<missing>' });
|
|
123
121
|
}
|
|
124
|
-
}
|
|
122
|
+
}
|
|
125
123
|
/**
|
|
126
124
|
* Returns true if the expression represented by `node` can be folded into a literal expression.
|
|
127
125
|
*
|
|
@@ -138,33 +136,32 @@
|
|
|
138
136
|
* - An identifier is foldable if a value can be found for its symbol in the evaluator symbol
|
|
139
137
|
* table.
|
|
140
138
|
*/
|
|
141
|
-
|
|
139
|
+
isFoldable(node) {
|
|
142
140
|
return this.isFoldableWorker(node, new Map());
|
|
143
|
-
}
|
|
144
|
-
|
|
145
|
-
var _this = this;
|
|
141
|
+
}
|
|
142
|
+
isFoldableWorker(node, folding) {
|
|
146
143
|
if (node) {
|
|
147
144
|
switch (node.kind) {
|
|
148
145
|
case ts.SyntaxKind.ObjectLiteralExpression:
|
|
149
|
-
return everyNodeChild(node,
|
|
146
|
+
return everyNodeChild(node, child => {
|
|
150
147
|
if (child.kind === ts.SyntaxKind.PropertyAssignment) {
|
|
151
|
-
|
|
152
|
-
return
|
|
148
|
+
const propertyAssignment = child;
|
|
149
|
+
return this.isFoldableWorker(propertyAssignment.initializer, folding);
|
|
153
150
|
}
|
|
154
151
|
return false;
|
|
155
152
|
});
|
|
156
153
|
case ts.SyntaxKind.ArrayLiteralExpression:
|
|
157
|
-
return everyNodeChild(node,
|
|
154
|
+
return everyNodeChild(node, child => this.isFoldableWorker(child, folding));
|
|
158
155
|
case ts.SyntaxKind.CallExpression:
|
|
159
|
-
|
|
156
|
+
const callExpression = node;
|
|
160
157
|
// We can fold a <array>.concat(<v>).
|
|
161
158
|
if (isMethodCallOf(callExpression, 'concat') &&
|
|
162
159
|
arrayOrEmpty(callExpression.arguments).length === 1) {
|
|
163
|
-
|
|
160
|
+
const arrayNode = callExpression.expression.expression;
|
|
164
161
|
if (this.isFoldableWorker(arrayNode, folding) &&
|
|
165
162
|
this.isFoldableWorker(callExpression.arguments[0], folding)) {
|
|
166
163
|
// It needs to be an array.
|
|
167
|
-
|
|
164
|
+
const arrayValue = this.evaluateNode(arrayNode);
|
|
168
165
|
if (arrayValue && Array.isArray(arrayValue)) {
|
|
169
166
|
return true;
|
|
170
167
|
}
|
|
@@ -186,10 +183,10 @@
|
|
|
186
183
|
case ts.SyntaxKind.TemplateTail:
|
|
187
184
|
return true;
|
|
188
185
|
case ts.SyntaxKind.ParenthesizedExpression:
|
|
189
|
-
|
|
186
|
+
const parenthesizedExpression = node;
|
|
190
187
|
return this.isFoldableWorker(parenthesizedExpression.expression, folding);
|
|
191
188
|
case ts.SyntaxKind.BinaryExpression:
|
|
192
|
-
|
|
189
|
+
const binaryExpression = node;
|
|
193
190
|
switch (binaryExpression.operatorToken.kind) {
|
|
194
191
|
case ts.SyntaxKind.PlusToken:
|
|
195
192
|
case ts.SyntaxKind.MinusToken:
|
|
@@ -204,37 +201,36 @@
|
|
|
204
201
|
return false;
|
|
205
202
|
}
|
|
206
203
|
case ts.SyntaxKind.PropertyAccessExpression:
|
|
207
|
-
|
|
204
|
+
const propertyAccessExpression = node;
|
|
208
205
|
return this.isFoldableWorker(propertyAccessExpression.expression, folding);
|
|
209
206
|
case ts.SyntaxKind.ElementAccessExpression:
|
|
210
|
-
|
|
207
|
+
const elementAccessExpression = node;
|
|
211
208
|
return this.isFoldableWorker(elementAccessExpression.expression, folding) &&
|
|
212
209
|
this.isFoldableWorker(elementAccessExpression.argumentExpression, folding);
|
|
213
210
|
case ts.SyntaxKind.Identifier:
|
|
214
|
-
|
|
215
|
-
|
|
211
|
+
let identifier = node;
|
|
212
|
+
let reference = this.symbols.resolve(identifier.text);
|
|
216
213
|
if (reference !== undefined && isPrimitive(reference)) {
|
|
217
214
|
return true;
|
|
218
215
|
}
|
|
219
216
|
break;
|
|
220
217
|
case ts.SyntaxKind.TemplateExpression:
|
|
221
|
-
|
|
222
|
-
return templateExpression.templateSpans.every(
|
|
218
|
+
const templateExpression = node;
|
|
219
|
+
return templateExpression.templateSpans.every(span => this.isFoldableWorker(span.expression, folding));
|
|
223
220
|
}
|
|
224
221
|
}
|
|
225
222
|
return false;
|
|
226
|
-
}
|
|
223
|
+
}
|
|
227
224
|
/**
|
|
228
225
|
* Produce a JSON serialiable object representing `node`. The foldable values in the expression
|
|
229
226
|
* tree are folded. For example, a node representing `1 + 2` is folded into `3`.
|
|
230
227
|
*/
|
|
231
|
-
|
|
232
|
-
|
|
233
|
-
|
|
234
|
-
var error;
|
|
228
|
+
evaluateNode(node, preferReference) {
|
|
229
|
+
const t = this;
|
|
230
|
+
let error;
|
|
235
231
|
function recordEntry(entry, node) {
|
|
236
232
|
if (t.options.substituteExpression) {
|
|
237
|
-
|
|
233
|
+
const newEntry = t.options.substituteExpression(entry, node);
|
|
238
234
|
if (t.recordExport && newEntry != entry && schema_1.isMetadataGlobalReferenceExpression(newEntry)) {
|
|
239
235
|
t.recordExport(newEntry.name, entry);
|
|
240
236
|
}
|
|
@@ -245,44 +241,44 @@
|
|
|
245
241
|
function isFoldableError(value) {
|
|
246
242
|
return !t.options.verboseInvalidExpression && schema_1.isMetadataError(value);
|
|
247
243
|
}
|
|
248
|
-
|
|
249
|
-
|
|
244
|
+
const resolveName = (name, preferReference) => {
|
|
245
|
+
const reference = this.symbols.resolve(name, preferReference);
|
|
250
246
|
if (reference === undefined) {
|
|
251
247
|
// Encode as a global reference. StaticReflector will check the reference.
|
|
252
|
-
return recordEntry({ __symbolic: 'reference', name
|
|
248
|
+
return recordEntry({ __symbolic: 'reference', name }, node);
|
|
253
249
|
}
|
|
254
250
|
if (reference && schema_1.isMetadataSymbolicReferenceExpression(reference)) {
|
|
255
|
-
return recordEntry(
|
|
251
|
+
return recordEntry(Object.assign({}, reference), node);
|
|
256
252
|
}
|
|
257
253
|
return reference;
|
|
258
254
|
};
|
|
259
255
|
switch (node.kind) {
|
|
260
256
|
case ts.SyntaxKind.ObjectLiteralExpression:
|
|
261
|
-
|
|
262
|
-
|
|
263
|
-
ts.forEachChild(node,
|
|
257
|
+
let obj = {};
|
|
258
|
+
let quoted = [];
|
|
259
|
+
ts.forEachChild(node, child => {
|
|
264
260
|
switch (child.kind) {
|
|
265
261
|
case ts.SyntaxKind.ShorthandPropertyAssignment:
|
|
266
262
|
case ts.SyntaxKind.PropertyAssignment:
|
|
267
|
-
|
|
263
|
+
const assignment = child;
|
|
268
264
|
if (assignment.name.kind == ts.SyntaxKind.StringLiteral) {
|
|
269
|
-
|
|
270
|
-
|
|
265
|
+
const name = assignment.name.text;
|
|
266
|
+
quoted.push(name);
|
|
271
267
|
}
|
|
272
|
-
|
|
268
|
+
const propertyName = this.nameOf(assignment.name);
|
|
273
269
|
if (isFoldableError(propertyName)) {
|
|
274
270
|
error = propertyName;
|
|
275
271
|
return true;
|
|
276
272
|
}
|
|
277
|
-
|
|
278
|
-
|
|
273
|
+
const propertyValue = isPropertyAssignment(assignment) ?
|
|
274
|
+
this.evaluateNode(assignment.initializer, /* preferReference */ true) :
|
|
279
275
|
resolveName(propertyName, /* preferReference */ true);
|
|
280
276
|
if (isFoldableError(propertyValue)) {
|
|
281
277
|
error = propertyValue;
|
|
282
278
|
return true; // Stop the forEachChild.
|
|
283
279
|
}
|
|
284
280
|
else {
|
|
285
|
-
|
|
281
|
+
obj[propertyName] = isPropertyAssignment(assignment) ?
|
|
286
282
|
recordEntry(propertyValue, assignment.initializer) :
|
|
287
283
|
propertyValue;
|
|
288
284
|
}
|
|
@@ -290,15 +286,14 @@
|
|
|
290
286
|
});
|
|
291
287
|
if (error)
|
|
292
288
|
return error;
|
|
293
|
-
if (this.options.quotedNames &&
|
|
294
|
-
|
|
289
|
+
if (this.options.quotedNames && quoted.length) {
|
|
290
|
+
obj['$quoted$'] = quoted;
|
|
295
291
|
}
|
|
296
|
-
return recordEntry(
|
|
292
|
+
return recordEntry(obj, node);
|
|
297
293
|
case ts.SyntaxKind.ArrayLiteralExpression:
|
|
298
|
-
|
|
299
|
-
ts.forEachChild(node,
|
|
300
|
-
|
|
301
|
-
var value = _this.evaluateNode(child, /* preferReference */ true);
|
|
294
|
+
let arr = [];
|
|
295
|
+
ts.forEachChild(node, child => {
|
|
296
|
+
const value = this.evaluateNode(child, /* preferReference */ true);
|
|
302
297
|
// Check for error
|
|
303
298
|
if (isFoldableError(value)) {
|
|
304
299
|
error = value;
|
|
@@ -307,44 +302,34 @@
|
|
|
307
302
|
// Handle spread expressions
|
|
308
303
|
if (schema_1.isMetadataSymbolicSpreadExpression(value)) {
|
|
309
304
|
if (Array.isArray(value.expression)) {
|
|
310
|
-
|
|
311
|
-
|
|
312
|
-
var spreadValue = _c.value;
|
|
313
|
-
arr_1.push(spreadValue);
|
|
314
|
-
}
|
|
315
|
-
}
|
|
316
|
-
catch (e_1_1) { e_1 = { error: e_1_1 }; }
|
|
317
|
-
finally {
|
|
318
|
-
try {
|
|
319
|
-
if (_c && !_c.done && (_a = _b.return)) _a.call(_b);
|
|
320
|
-
}
|
|
321
|
-
finally { if (e_1) throw e_1.error; }
|
|
305
|
+
for (const spreadValue of value.expression) {
|
|
306
|
+
arr.push(spreadValue);
|
|
322
307
|
}
|
|
323
308
|
return;
|
|
324
309
|
}
|
|
325
310
|
}
|
|
326
|
-
|
|
311
|
+
arr.push(value);
|
|
327
312
|
});
|
|
328
313
|
if (error)
|
|
329
314
|
return error;
|
|
330
|
-
return recordEntry(
|
|
315
|
+
return recordEntry(arr, node);
|
|
331
316
|
case spreadElementSyntaxKind:
|
|
332
|
-
|
|
317
|
+
let spreadExpression = this.evaluateNode(node.expression);
|
|
333
318
|
return recordEntry({ __symbolic: 'spread', expression: spreadExpression }, node);
|
|
334
319
|
case ts.SyntaxKind.CallExpression:
|
|
335
|
-
|
|
320
|
+
const callExpression = node;
|
|
336
321
|
if (isCallOf(callExpression, 'forwardRef') &&
|
|
337
322
|
arrayOrEmpty(callExpression.arguments).length === 1) {
|
|
338
|
-
|
|
323
|
+
const firstArgument = callExpression.arguments[0];
|
|
339
324
|
if (firstArgument.kind == ts.SyntaxKind.ArrowFunction) {
|
|
340
|
-
|
|
325
|
+
const arrowFunction = firstArgument;
|
|
341
326
|
return recordEntry(this.evaluateNode(arrowFunction.body), node);
|
|
342
327
|
}
|
|
343
328
|
}
|
|
344
|
-
|
|
329
|
+
const args = arrayOrEmpty(callExpression.arguments).map(arg => this.evaluateNode(arg));
|
|
345
330
|
if (this.isFoldable(callExpression)) {
|
|
346
331
|
if (isMethodCallOf(callExpression, 'concat')) {
|
|
347
|
-
|
|
332
|
+
const arrayValue = this.evaluateNode(callExpression.expression.expression);
|
|
348
333
|
if (isFoldableError(arrayValue))
|
|
349
334
|
return arrayValue;
|
|
350
335
|
return arrayValue.concat(args[0]);
|
|
@@ -355,118 +340,118 @@
|
|
|
355
340
|
arrayOrEmpty(callExpression.arguments).length === 1) {
|
|
356
341
|
return recordEntry(args[0], node);
|
|
357
342
|
}
|
|
358
|
-
|
|
343
|
+
const expression = this.evaluateNode(callExpression.expression);
|
|
359
344
|
if (isFoldableError(expression)) {
|
|
360
345
|
return recordEntry(expression, node);
|
|
361
346
|
}
|
|
362
|
-
|
|
347
|
+
let result = { __symbolic: 'call', expression: expression };
|
|
363
348
|
if (args && args.length) {
|
|
364
349
|
result.arguments = args;
|
|
365
350
|
}
|
|
366
351
|
return recordEntry(result, node);
|
|
367
352
|
case ts.SyntaxKind.NewExpression:
|
|
368
|
-
|
|
369
|
-
|
|
370
|
-
|
|
353
|
+
const newExpression = node;
|
|
354
|
+
const newArgs = arrayOrEmpty(newExpression.arguments).map(arg => this.evaluateNode(arg));
|
|
355
|
+
const newTarget = this.evaluateNode(newExpression.expression);
|
|
371
356
|
if (schema_1.isMetadataError(newTarget)) {
|
|
372
357
|
return recordEntry(newTarget, node);
|
|
373
358
|
}
|
|
374
|
-
|
|
359
|
+
const call = { __symbolic: 'new', expression: newTarget };
|
|
375
360
|
if (newArgs.length) {
|
|
376
361
|
call.arguments = newArgs;
|
|
377
362
|
}
|
|
378
363
|
return recordEntry(call, node);
|
|
379
364
|
case ts.SyntaxKind.PropertyAccessExpression: {
|
|
380
|
-
|
|
381
|
-
|
|
382
|
-
if (isFoldableError(
|
|
383
|
-
return recordEntry(
|
|
365
|
+
const propertyAccessExpression = node;
|
|
366
|
+
const expression = this.evaluateNode(propertyAccessExpression.expression);
|
|
367
|
+
if (isFoldableError(expression)) {
|
|
368
|
+
return recordEntry(expression, node);
|
|
384
369
|
}
|
|
385
|
-
|
|
370
|
+
const member = this.nameOf(propertyAccessExpression.name);
|
|
386
371
|
if (isFoldableError(member)) {
|
|
387
372
|
return recordEntry(member, node);
|
|
388
373
|
}
|
|
389
|
-
if (
|
|
390
|
-
return
|
|
391
|
-
if (schema_1.isMetadataModuleReferenceExpression(
|
|
374
|
+
if (expression && this.isFoldable(propertyAccessExpression.expression))
|
|
375
|
+
return expression[member];
|
|
376
|
+
if (schema_1.isMetadataModuleReferenceExpression(expression)) {
|
|
392
377
|
// A select into a module reference and be converted into a reference to the symbol
|
|
393
378
|
// in the module
|
|
394
|
-
return recordEntry({ __symbolic: 'reference', module:
|
|
379
|
+
return recordEntry({ __symbolic: 'reference', module: expression.module, name: member }, node);
|
|
395
380
|
}
|
|
396
|
-
return recordEntry({ __symbolic: 'select', expression
|
|
381
|
+
return recordEntry({ __symbolic: 'select', expression, member }, node);
|
|
397
382
|
}
|
|
398
383
|
case ts.SyntaxKind.ElementAccessExpression: {
|
|
399
|
-
|
|
400
|
-
|
|
401
|
-
if (isFoldableError(
|
|
402
|
-
return recordEntry(
|
|
384
|
+
const elementAccessExpression = node;
|
|
385
|
+
const expression = this.evaluateNode(elementAccessExpression.expression);
|
|
386
|
+
if (isFoldableError(expression)) {
|
|
387
|
+
return recordEntry(expression, node);
|
|
403
388
|
}
|
|
404
389
|
if (!elementAccessExpression.argumentExpression) {
|
|
405
390
|
return recordEntry(errorSymbol('Expression form not supported', node), node);
|
|
406
391
|
}
|
|
407
|
-
|
|
408
|
-
if (isFoldableError(
|
|
409
|
-
return recordEntry(
|
|
392
|
+
const index = this.evaluateNode(elementAccessExpression.argumentExpression);
|
|
393
|
+
if (isFoldableError(expression)) {
|
|
394
|
+
return recordEntry(expression, node);
|
|
410
395
|
}
|
|
411
396
|
if (this.isFoldable(elementAccessExpression.expression) &&
|
|
412
397
|
this.isFoldable(elementAccessExpression.argumentExpression))
|
|
413
|
-
return
|
|
414
|
-
return recordEntry({ __symbolic: 'index', expression
|
|
398
|
+
return expression[index];
|
|
399
|
+
return recordEntry({ __symbolic: 'index', expression, index }, node);
|
|
415
400
|
}
|
|
416
401
|
case ts.SyntaxKind.Identifier:
|
|
417
|
-
|
|
418
|
-
|
|
402
|
+
const identifier = node;
|
|
403
|
+
const name = identifier.text;
|
|
419
404
|
return resolveName(name, preferReference);
|
|
420
405
|
case ts.SyntaxKind.TypeReference:
|
|
421
|
-
|
|
422
|
-
|
|
423
|
-
|
|
424
|
-
if (
|
|
425
|
-
|
|
426
|
-
|
|
427
|
-
if (schema_1.isMetadataModuleReferenceExpression(
|
|
406
|
+
const typeReferenceNode = node;
|
|
407
|
+
const typeNameNode = typeReferenceNode.typeName;
|
|
408
|
+
const getReference = node => {
|
|
409
|
+
if (typeNameNode.kind === ts.SyntaxKind.QualifiedName) {
|
|
410
|
+
const qualifiedName = node;
|
|
411
|
+
const left = this.evaluateNode(qualifiedName.left);
|
|
412
|
+
if (schema_1.isMetadataModuleReferenceExpression(left)) {
|
|
428
413
|
return recordEntry({
|
|
429
414
|
__symbolic: 'reference',
|
|
430
|
-
module:
|
|
415
|
+
module: left.module,
|
|
431
416
|
name: qualifiedName.right.text
|
|
432
417
|
}, node);
|
|
433
418
|
}
|
|
434
419
|
// Record a type reference to a declared type as a select.
|
|
435
|
-
return { __symbolic: 'select', expression:
|
|
420
|
+
return { __symbolic: 'select', expression: left, member: qualifiedName.right.text };
|
|
436
421
|
}
|
|
437
422
|
else {
|
|
438
|
-
|
|
439
|
-
|
|
423
|
+
const identifier = typeNameNode;
|
|
424
|
+
const symbol = this.symbols.resolve(identifier.text);
|
|
440
425
|
if (isFoldableError(symbol) || schema_1.isMetadataSymbolicReferenceExpression(symbol)) {
|
|
441
426
|
return recordEntry(symbol, node);
|
|
442
427
|
}
|
|
443
|
-
return recordEntry(errorSymbol('Could not resolve type', node, { typeName:
|
|
428
|
+
return recordEntry(errorSymbol('Could not resolve type', node, { typeName: identifier.text }), node);
|
|
444
429
|
}
|
|
445
430
|
};
|
|
446
|
-
|
|
431
|
+
const typeReference = getReference(typeNameNode);
|
|
447
432
|
if (isFoldableError(typeReference)) {
|
|
448
433
|
return recordEntry(typeReference, node);
|
|
449
434
|
}
|
|
450
435
|
if (!schema_1.isMetadataModuleReferenceExpression(typeReference) &&
|
|
451
436
|
typeReferenceNode.typeArguments && typeReferenceNode.typeArguments.length) {
|
|
452
|
-
|
|
437
|
+
const args = typeReferenceNode.typeArguments.map(element => this.evaluateNode(element));
|
|
453
438
|
// TODO: Remove typecast when upgraded to 2.0 as it will be correctly inferred.
|
|
454
439
|
// Some versions of 1.9 do not infer this correctly.
|
|
455
|
-
typeReference.arguments =
|
|
440
|
+
typeReference.arguments = args;
|
|
456
441
|
}
|
|
457
442
|
return recordEntry(typeReference, node);
|
|
458
443
|
case ts.SyntaxKind.UnionType:
|
|
459
|
-
|
|
444
|
+
const unionType = node;
|
|
460
445
|
// Remove null and undefined from the list of unions.
|
|
461
|
-
|
|
462
|
-
.filter(
|
|
463
|
-
n.kind != ts.SyntaxKind.UndefinedKeyword
|
|
464
|
-
.map(
|
|
446
|
+
const references = unionType.types
|
|
447
|
+
.filter(n => n.kind != ts.SyntaxKind.NullKeyword &&
|
|
448
|
+
n.kind != ts.SyntaxKind.UndefinedKeyword)
|
|
449
|
+
.map(n => this.evaluateNode(n));
|
|
465
450
|
// The remmaining reference must be the same. If two have type arguments consider them
|
|
466
451
|
// different even if the type arguments are the same.
|
|
467
|
-
|
|
468
|
-
for (
|
|
469
|
-
|
|
452
|
+
let candidate = null;
|
|
453
|
+
for (let i = 0; i < references.length; i++) {
|
|
454
|
+
const reference = references[i];
|
|
470
455
|
if (schema_1.isMetadataSymbolicReferenceExpression(reference)) {
|
|
471
456
|
if (candidate) {
|
|
472
457
|
if (reference.name == candidate.name &&
|
|
@@ -502,7 +487,7 @@
|
|
|
502
487
|
case ts.SyntaxKind.BooleanKeyword:
|
|
503
488
|
return recordEntry({ __symbolic: 'reference', name: 'boolean' }, node);
|
|
504
489
|
case ts.SyntaxKind.ArrayType:
|
|
505
|
-
|
|
490
|
+
const arrayTypeNode = node;
|
|
506
491
|
return recordEntry({
|
|
507
492
|
__symbolic: 'reference',
|
|
508
493
|
name: 'Array',
|
|
@@ -515,14 +500,14 @@
|
|
|
515
500
|
case ts.SyntaxKind.FalseKeyword:
|
|
516
501
|
return false;
|
|
517
502
|
case ts.SyntaxKind.ParenthesizedExpression:
|
|
518
|
-
|
|
503
|
+
const parenthesizedExpression = node;
|
|
519
504
|
return this.evaluateNode(parenthesizedExpression.expression);
|
|
520
505
|
case ts.SyntaxKind.TypeAssertionExpression:
|
|
521
|
-
|
|
506
|
+
const typeAssertion = node;
|
|
522
507
|
return this.evaluateNode(typeAssertion.expression);
|
|
523
508
|
case ts.SyntaxKind.PrefixUnaryExpression:
|
|
524
|
-
|
|
525
|
-
|
|
509
|
+
const prefixUnaryExpression = node;
|
|
510
|
+
const operand = this.evaluateNode(prefixUnaryExpression.operand);
|
|
526
511
|
if (isDefined(operand) && isPrimitive(operand)) {
|
|
527
512
|
switch (prefixUnaryExpression.operator) {
|
|
528
513
|
case ts.SyntaxKind.PlusToken:
|
|
@@ -535,7 +520,7 @@
|
|
|
535
520
|
return !operand;
|
|
536
521
|
}
|
|
537
522
|
}
|
|
538
|
-
|
|
523
|
+
let operatorText;
|
|
539
524
|
switch (prefixUnaryExpression.operator) {
|
|
540
525
|
case ts.SyntaxKind.PlusToken:
|
|
541
526
|
operatorText = '+';
|
|
@@ -554,9 +539,9 @@
|
|
|
554
539
|
}
|
|
555
540
|
return recordEntry({ __symbolic: 'pre', operator: operatorText, operand: operand }, node);
|
|
556
541
|
case ts.SyntaxKind.BinaryExpression:
|
|
557
|
-
|
|
558
|
-
|
|
559
|
-
|
|
542
|
+
const binaryExpression = node;
|
|
543
|
+
const left = this.evaluateNode(binaryExpression.left);
|
|
544
|
+
const right = this.evaluateNode(binaryExpression.right);
|
|
560
545
|
if (isDefined(left) && isDefined(right)) {
|
|
561
546
|
if (isPrimitive(left) && isPrimitive(right))
|
|
562
547
|
switch (binaryExpression.operatorToken.kind) {
|
|
@@ -612,29 +597,29 @@
|
|
|
612
597
|
}
|
|
613
598
|
break;
|
|
614
599
|
case ts.SyntaxKind.ConditionalExpression:
|
|
615
|
-
|
|
616
|
-
|
|
617
|
-
|
|
618
|
-
|
|
600
|
+
const conditionalExpression = node;
|
|
601
|
+
const condition = this.evaluateNode(conditionalExpression.condition);
|
|
602
|
+
const thenExpression = this.evaluateNode(conditionalExpression.whenTrue);
|
|
603
|
+
const elseExpression = this.evaluateNode(conditionalExpression.whenFalse);
|
|
619
604
|
if (isPrimitive(condition)) {
|
|
620
605
|
return condition ? thenExpression : elseExpression;
|
|
621
606
|
}
|
|
622
|
-
return recordEntry({ __symbolic: 'if', condition
|
|
607
|
+
return recordEntry({ __symbolic: 'if', condition, thenExpression, elseExpression }, node);
|
|
623
608
|
case ts.SyntaxKind.FunctionExpression:
|
|
624
609
|
case ts.SyntaxKind.ArrowFunction:
|
|
625
610
|
return recordEntry(errorSymbol('Lambda not supported', node), node);
|
|
626
611
|
case ts.SyntaxKind.TaggedTemplateExpression:
|
|
627
612
|
return recordEntry(errorSymbol('Tagged template expressions are not supported in metadata', node), node);
|
|
628
613
|
case ts.SyntaxKind.TemplateExpression:
|
|
629
|
-
|
|
614
|
+
const templateExpression = node;
|
|
630
615
|
if (this.isFoldable(node)) {
|
|
631
|
-
return templateExpression.templateSpans.reduce(
|
|
632
|
-
|
|
616
|
+
return templateExpression.templateSpans.reduce((previous, current) => previous + this.evaluateNode(current.expression) +
|
|
617
|
+
this.evaluateNode(current.literal), this.evaluateNode(templateExpression.head));
|
|
633
618
|
}
|
|
634
619
|
else {
|
|
635
|
-
return templateExpression.templateSpans.reduce(
|
|
636
|
-
|
|
637
|
-
|
|
620
|
+
return templateExpression.templateSpans.reduce((previous, current) => {
|
|
621
|
+
const expr = this.evaluateNode(current.expression);
|
|
622
|
+
const literal = this.evaluateNode(current.literal);
|
|
638
623
|
if (isFoldableError(expr))
|
|
639
624
|
return expr;
|
|
640
625
|
if (isFoldableError(literal))
|
|
@@ -643,7 +628,7 @@
|
|
|
643
628
|
typeof literal === 'string') {
|
|
644
629
|
return previous + expr + literal;
|
|
645
630
|
}
|
|
646
|
-
|
|
631
|
+
let result = expr;
|
|
647
632
|
if (previous !== '') {
|
|
648
633
|
result = { __symbolic: 'binop', operator: '+', left: previous, right: expr };
|
|
649
634
|
}
|
|
@@ -654,22 +639,21 @@
|
|
|
654
639
|
}, this.evaluateNode(templateExpression.head));
|
|
655
640
|
}
|
|
656
641
|
case ts.SyntaxKind.AsExpression:
|
|
657
|
-
|
|
642
|
+
const asExpression = node;
|
|
658
643
|
return this.evaluateNode(asExpression.expression);
|
|
659
644
|
case ts.SyntaxKind.ClassExpression:
|
|
660
645
|
return { __symbolic: 'class' };
|
|
661
646
|
}
|
|
662
647
|
return recordEntry(errorSymbol('Expression form not supported', node), node);
|
|
663
|
-
}
|
|
664
|
-
|
|
665
|
-
}());
|
|
648
|
+
}
|
|
649
|
+
}
|
|
666
650
|
exports.Evaluator = Evaluator;
|
|
667
651
|
function isPropertyAssignment(node) {
|
|
668
652
|
return node.kind == ts.SyntaxKind.PropertyAssignment;
|
|
669
653
|
}
|
|
670
|
-
|
|
654
|
+
const empty = ts.createNodeArray();
|
|
671
655
|
function arrayOrEmpty(v) {
|
|
672
656
|
return v || empty;
|
|
673
657
|
}
|
|
674
658
|
});
|
|
675
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"evaluator.js","sourceRoot":"","sources":["../../../../../../../packages/compiler-cli/src/metadata/evaluator.ts"],"names":[],"mappings":"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","sourcesContent":["/**\n * @license\n * Copyright Google Inc. All Rights Reserved.\n *\n * Use of this source code is governed by an MIT-style license that can be\n * found in the LICENSE file at https://angular.io/license\n */\n\nimport * as ts from 'typescript';\n\nimport {CollectorOptions} from './collector';\nimport {ClassMetadata, FunctionMetadata, InterfaceMetadata, MetadataEntry, MetadataError, MetadataImportedSymbolReferenceExpression, MetadataSourceLocationInfo, MetadataSymbolicCallExpression, MetadataValue, isMetadataError, isMetadataGlobalReferenceExpression, isMetadataImportDefaultReference, isMetadataImportedSymbolReferenceExpression, isMetadataModuleReferenceExpression, isMetadataSymbolicReferenceExpression, isMetadataSymbolicSpreadExpression} from './schema';\nimport {Symbols} from './symbols';\n\n\n\n// In TypeScript 2.1 the spread element kind was renamed.\nconst spreadElementSyntaxKind: ts.SyntaxKind =\n    (ts.SyntaxKind as any).SpreadElement || (ts.SyntaxKind as any).SpreadElementExpression;\n\nfunction isMethodCallOf(callExpression: ts.CallExpression, memberName: string): boolean {\n  const expression = callExpression.expression;\n  if (expression.kind === ts.SyntaxKind.PropertyAccessExpression) {\n    const propertyAccessExpression = <ts.PropertyAccessExpression>expression;\n    const name = propertyAccessExpression.name;\n    if (name.kind == ts.SyntaxKind.Identifier) {\n      return name.text === memberName;\n    }\n  }\n  return false;\n}\n\nfunction isCallOf(callExpression: ts.CallExpression, ident: string): boolean {\n  const expression = callExpression.expression;\n  if (expression.kind === ts.SyntaxKind.Identifier) {\n    const identifier = <ts.Identifier>expression;\n    return identifier.text === ident;\n  }\n  return false;\n}\n\n/* @internal */\nexport function recordMapEntry<T extends MetadataEntry>(\n    entry: T, node: ts.Node,\n    nodeMap: Map<MetadataValue|ClassMetadata|InterfaceMetadata|FunctionMetadata, ts.Node>,\n    sourceFile?: ts.SourceFile) {\n  if (!nodeMap.has(entry)) {\n    nodeMap.set(entry, node);\n    if (node && (isMetadataImportedSymbolReferenceExpression(entry) ||\n                 isMetadataImportDefaultReference(entry)) &&\n        entry.line == null) {\n      const info = sourceInfo(node, sourceFile);\n      if (info.line != null) entry.line = info.line;\n      if (info.character != null) entry.character = info.character;\n    }\n  }\n  return entry;\n}\n\n/**\n * ts.forEachChild stops iterating children when the callback return a truthy value.\n * This method inverts this to implement an `every` style iterator. It will return\n * true if every call to `cb` returns `true`.\n */\nfunction everyNodeChild(node: ts.Node, cb: (node: ts.Node) => boolean) {\n  return !ts.forEachChild(node, node => !cb(node));\n}\n\nexport function isPrimitive(value: any): boolean {\n  return Object(value) !== value;\n}\n\nfunction isDefined(obj: any): boolean {\n  return obj !== undefined;\n}\n\n// import {propertyName as name} from 'place'\n// import {name} from 'place'\nexport interface ImportSpecifierMetadata {\n  name: string;\n  propertyName?: string;\n}\nexport interface ImportMetadata {\n  defaultName?: string;                      // import d from 'place'\n  namespace?: string;                        // import * as d from 'place'\n  namedImports?: ImportSpecifierMetadata[];  // import {a} from 'place'\n  from: string;                              // from 'place'\n}\n\n\nfunction getSourceFileOfNode(node: ts.Node | undefined): ts.SourceFile {\n  while (node && node.kind != ts.SyntaxKind.SourceFile) {\n    node = node.parent;\n  }\n  return <ts.SourceFile>node;\n}\n\n/* @internal */\nexport function sourceInfo(\n    node: ts.Node | undefined, sourceFile: ts.SourceFile | undefined): MetadataSourceLocationInfo {\n  if (node) {\n    sourceFile = sourceFile || getSourceFileOfNode(node);\n    if (sourceFile) {\n      return ts.getLineAndCharacterOfPosition(sourceFile, node.getStart(sourceFile));\n    }\n  }\n  return {};\n}\n\n/* @internal */\nexport function errorSymbol(\n    message: string, node?: ts.Node, context?: {[name: string]: string},\n    sourceFile?: ts.SourceFile): MetadataError {\n  const result: MetadataError = {__symbolic: 'error', message, ...sourceInfo(node, sourceFile)};\n  if (context) {\n    result.context = context;\n  }\n  return result;\n}\n\n/**\n * Produce a symbolic representation of an expression folding values into their final value when\n * possible.\n */\nexport class Evaluator {\n  constructor(\n      private symbols: Symbols, private nodeMap: Map<MetadataEntry, ts.Node>,\n      private options: CollectorOptions = {},\n      private recordExport?: (name: string, value: MetadataValue) => void) {}\n\n  nameOf(node: ts.Node|undefined): string|MetadataError {\n    if (node && node.kind == ts.SyntaxKind.Identifier) {\n      return (<ts.Identifier>node).text;\n    }\n    const result = node && this.evaluateNode(node);\n    if (isMetadataError(result) || typeof result === 'string') {\n      return result;\n    } else {\n      return errorSymbol(\n          'Name expected', node, {received: (node && node.getText()) || '<missing>'});\n    }\n  }\n\n  /**\n   * Returns true if the expression represented by `node` can be folded into a literal expression.\n   *\n   * For example, a literal is always foldable. This means that literal expressions such as `1.2`\n   * `\"Some value\"` `true` `false` are foldable.\n   *\n   * - An object literal is foldable if all the properties in the literal are foldable.\n   * - An array literal is foldable if all the elements are foldable.\n   * - A call is foldable if it is a call to a Array.prototype.concat or a call to CONST_EXPR.\n   * - A property access is foldable if the object is foldable.\n   * - A array index is foldable if index expression is foldable and the array is foldable.\n   * - Binary operator expressions are foldable if the left and right expressions are foldable and\n   *   it is one of '+', '-', '*', '/', '%', '||', and '&&'.\n   * - An identifier is foldable if a value can be found for its symbol in the evaluator symbol\n   *   table.\n   */\n  public isFoldable(node: ts.Node): boolean {\n    return this.isFoldableWorker(node, new Map<ts.Node, boolean>());\n  }\n\n  private isFoldableWorker(node: ts.Node|undefined, folding: Map<ts.Node, boolean>): boolean {\n    if (node) {\n      switch (node.kind) {\n        case ts.SyntaxKind.ObjectLiteralExpression:\n          return everyNodeChild(node, child => {\n            if (child.kind === ts.SyntaxKind.PropertyAssignment) {\n              const propertyAssignment = <ts.PropertyAssignment>child;\n              return this.isFoldableWorker(propertyAssignment.initializer, folding);\n            }\n            return false;\n          });\n        case ts.SyntaxKind.ArrayLiteralExpression:\n          return everyNodeChild(node, child => this.isFoldableWorker(child, folding));\n        case ts.SyntaxKind.CallExpression:\n          const callExpression = <ts.CallExpression>node;\n          // We can fold a <array>.concat(<v>).\n          if (isMethodCallOf(callExpression, 'concat') &&\n              arrayOrEmpty(callExpression.arguments).length === 1) {\n            const arrayNode = (<ts.PropertyAccessExpression>callExpression.expression).expression;\n            if (this.isFoldableWorker(arrayNode, folding) &&\n                this.isFoldableWorker(callExpression.arguments[0], folding)) {\n              // It needs to be an array.\n              const arrayValue = this.evaluateNode(arrayNode);\n              if (arrayValue && Array.isArray(arrayValue)) {\n                return true;\n              }\n            }\n          }\n\n          // We can fold a call to CONST_EXPR\n          if (isCallOf(callExpression, 'CONST_EXPR') &&\n              arrayOrEmpty(callExpression.arguments).length === 1)\n            return this.isFoldableWorker(callExpression.arguments[0], folding);\n          return false;\n        case ts.SyntaxKind.NoSubstitutionTemplateLiteral:\n        case ts.SyntaxKind.StringLiteral:\n        case ts.SyntaxKind.NumericLiteral:\n        case ts.SyntaxKind.NullKeyword:\n        case ts.SyntaxKind.TrueKeyword:\n        case ts.SyntaxKind.FalseKeyword:\n        case ts.SyntaxKind.TemplateHead:\n        case ts.SyntaxKind.TemplateMiddle:\n        case ts.SyntaxKind.TemplateTail:\n          return true;\n        case ts.SyntaxKind.ParenthesizedExpression:\n          const parenthesizedExpression = <ts.ParenthesizedExpression>node;\n          return this.isFoldableWorker(parenthesizedExpression.expression, folding);\n        case ts.SyntaxKind.BinaryExpression:\n          const binaryExpression = <ts.BinaryExpression>node;\n          switch (binaryExpression.operatorToken.kind) {\n            case ts.SyntaxKind.PlusToken:\n            case ts.SyntaxKind.MinusToken:\n            case ts.SyntaxKind.AsteriskToken:\n            case ts.SyntaxKind.SlashToken:\n            case ts.SyntaxKind.PercentToken:\n            case ts.SyntaxKind.AmpersandAmpersandToken:\n            case ts.SyntaxKind.BarBarToken:\n              return this.isFoldableWorker(binaryExpression.left, folding) &&\n                  this.isFoldableWorker(binaryExpression.right, folding);\n            default:\n              return false;\n          }\n        case ts.SyntaxKind.PropertyAccessExpression:\n          const propertyAccessExpression = <ts.PropertyAccessExpression>node;\n          return this.isFoldableWorker(propertyAccessExpression.expression, folding);\n        case ts.SyntaxKind.ElementAccessExpression:\n          const elementAccessExpression = <ts.ElementAccessExpression>node;\n          return this.isFoldableWorker(elementAccessExpression.expression, folding) &&\n              this.isFoldableWorker(elementAccessExpression.argumentExpression, folding);\n        case ts.SyntaxKind.Identifier:\n          let identifier = <ts.Identifier>node;\n          let reference = this.symbols.resolve(identifier.text);\n          if (reference !== undefined && isPrimitive(reference)) {\n            return true;\n          }\n          break;\n        case ts.SyntaxKind.TemplateExpression:\n          const templateExpression = <ts.TemplateExpression>node;\n          return templateExpression.templateSpans.every(\n              span => this.isFoldableWorker(span.expression, folding));\n      }\n    }\n    return false;\n  }\n\n  /**\n   * Produce a JSON serialiable object representing `node`. The foldable values in the expression\n   * tree are folded. For example, a node representing `1 + 2` is folded into `3`.\n   */\n  public evaluateNode(node: ts.Node, preferReference?: boolean): MetadataValue {\n    const t = this;\n    let error: MetadataError|undefined;\n\n    function recordEntry(entry: MetadataValue, node: ts.Node): MetadataValue {\n      if (t.options.substituteExpression) {\n        const newEntry = t.options.substituteExpression(entry, node);\n        if (t.recordExport && newEntry != entry && isMetadataGlobalReferenceExpression(newEntry)) {\n          t.recordExport(newEntry.name, entry);\n        }\n        entry = newEntry;\n      }\n      return recordMapEntry(entry, node, t.nodeMap);\n    }\n\n    function isFoldableError(value: any): value is MetadataError {\n      return !t.options.verboseInvalidExpression && isMetadataError(value);\n    }\n\n    const resolveName = (name: string, preferReference?: boolean): MetadataValue => {\n      const reference = this.symbols.resolve(name, preferReference);\n      if (reference === undefined) {\n        // Encode as a global reference. StaticReflector will check the reference.\n        return recordEntry({__symbolic: 'reference', name}, node);\n      }\n      if (reference && isMetadataSymbolicReferenceExpression(reference)) {\n        return recordEntry({...reference}, node);\n      }\n      return reference;\n    };\n\n    switch (node.kind) {\n      case ts.SyntaxKind.ObjectLiteralExpression:\n        let obj: {[name: string]: any} = {};\n        let quoted: string[] = [];\n        ts.forEachChild(node, child => {\n          switch (child.kind) {\n            case ts.SyntaxKind.ShorthandPropertyAssignment:\n            case ts.SyntaxKind.PropertyAssignment:\n              const assignment = <ts.PropertyAssignment|ts.ShorthandPropertyAssignment>child;\n              if (assignment.name.kind == ts.SyntaxKind.StringLiteral) {\n                const name = (assignment.name as ts.StringLiteral).text;\n                quoted.push(name);\n              }\n              const propertyName = this.nameOf(assignment.name);\n              if (isFoldableError(propertyName)) {\n                error = propertyName;\n                return true;\n              }\n              const propertyValue = isPropertyAssignment(assignment) ?\n                  this.evaluateNode(assignment.initializer, /* preferReference */ true) :\n                  resolveName(propertyName, /* preferReference */ true);\n              if (isFoldableError(propertyValue)) {\n                error = propertyValue;\n                return true;  // Stop the forEachChild.\n              } else {\n                obj[<string>propertyName] = isPropertyAssignment(assignment) ?\n                    recordEntry(propertyValue, assignment.initializer) :\n                    propertyValue;\n              }\n          }\n        });\n        if (error) return error;\n        if (this.options.quotedNames && quoted.length) {\n          obj['$quoted$'] = quoted;\n        }\n        return recordEntry(obj, node);\n      case ts.SyntaxKind.ArrayLiteralExpression:\n        let arr: MetadataValue[] = [];\n        ts.forEachChild(node, child => {\n          const value = this.evaluateNode(child, /* preferReference */ true);\n\n          // Check for error\n          if (isFoldableError(value)) {\n            error = value;\n            return true;  // Stop the forEachChild.\n          }\n\n          // Handle spread expressions\n          if (isMetadataSymbolicSpreadExpression(value)) {\n            if (Array.isArray(value.expression)) {\n              for (const spreadValue of value.expression) {\n                arr.push(spreadValue);\n              }\n              return;\n            }\n          }\n\n          arr.push(value);\n        });\n        if (error) return error;\n        return recordEntry(arr, node);\n      case spreadElementSyntaxKind:\n        let spreadExpression = this.evaluateNode((node as any).expression);\n        return recordEntry({__symbolic: 'spread', expression: spreadExpression}, node);\n      case ts.SyntaxKind.CallExpression:\n        const callExpression = <ts.CallExpression>node;\n        if (isCallOf(callExpression, 'forwardRef') &&\n            arrayOrEmpty(callExpression.arguments).length === 1) {\n          const firstArgument = callExpression.arguments[0];\n          if (firstArgument.kind == ts.SyntaxKind.ArrowFunction) {\n            const arrowFunction = <ts.ArrowFunction>firstArgument;\n            return recordEntry(this.evaluateNode(arrowFunction.body), node);\n          }\n        }\n        const args = arrayOrEmpty(callExpression.arguments).map(arg => this.evaluateNode(arg));\n        if (this.isFoldable(callExpression)) {\n          if (isMethodCallOf(callExpression, 'concat')) {\n            const arrayValue = <MetadataValue[]>this.evaluateNode(\n                (<ts.PropertyAccessExpression>callExpression.expression).expression);\n            if (isFoldableError(arrayValue)) return arrayValue;\n            return arrayValue.concat(args[0]);\n          }\n        }\n        // Always fold a CONST_EXPR even if the argument is not foldable.\n        if (isCallOf(callExpression, 'CONST_EXPR') &&\n            arrayOrEmpty(callExpression.arguments).length === 1) {\n          return recordEntry(args[0], node);\n        }\n        const expression = this.evaluateNode(callExpression.expression);\n        if (isFoldableError(expression)) {\n          return recordEntry(expression, node);\n        }\n        let result: MetadataSymbolicCallExpression = {__symbolic: 'call', expression: expression};\n        if (args && args.length) {\n          result.arguments = args;\n        }\n        return recordEntry(result, node);\n      case ts.SyntaxKind.NewExpression:\n        const newExpression = <ts.NewExpression>node;\n        const newArgs = arrayOrEmpty(newExpression.arguments).map(arg => this.evaluateNode(arg));\n        const newTarget = this.evaluateNode(newExpression.expression);\n        if (isMetadataError(newTarget)) {\n          return recordEntry(newTarget, node);\n        }\n        const call: MetadataSymbolicCallExpression = {__symbolic: 'new', expression: newTarget};\n        if (newArgs.length) {\n          call.arguments = newArgs;\n        }\n        return recordEntry(call, node);\n      case ts.SyntaxKind.PropertyAccessExpression: {\n        const propertyAccessExpression = <ts.PropertyAccessExpression>node;\n        const expression = this.evaluateNode(propertyAccessExpression.expression);\n        if (isFoldableError(expression)) {\n          return recordEntry(expression, node);\n        }\n        const member = this.nameOf(propertyAccessExpression.name);\n        if (isFoldableError(member)) {\n          return recordEntry(member, node);\n        }\n        if (expression && this.isFoldable(propertyAccessExpression.expression))\n          return (<any>expression)[<string>member];\n        if (isMetadataModuleReferenceExpression(expression)) {\n          // A select into a module reference and be converted into a reference to the symbol\n          // in the module\n          return recordEntry(\n              {__symbolic: 'reference', module: expression.module, name: member}, node);\n        }\n        return recordEntry({__symbolic: 'select', expression, member}, node);\n      }\n      case ts.SyntaxKind.ElementAccessExpression: {\n        const elementAccessExpression = <ts.ElementAccessExpression>node;\n        const expression = this.evaluateNode(elementAccessExpression.expression);\n        if (isFoldableError(expression)) {\n          return recordEntry(expression, node);\n        }\n        if (!elementAccessExpression.argumentExpression) {\n          return recordEntry(errorSymbol('Expression form not supported', node), node);\n        }\n        const index = this.evaluateNode(elementAccessExpression.argumentExpression);\n        if (isFoldableError(expression)) {\n          return recordEntry(expression, node);\n        }\n        if (this.isFoldable(elementAccessExpression.expression) &&\n            this.isFoldable(elementAccessExpression.argumentExpression))\n          return (<any>expression)[<string|number>index];\n        return recordEntry({__symbolic: 'index', expression, index}, node);\n      }\n      case ts.SyntaxKind.Identifier:\n        const identifier = <ts.Identifier>node;\n        const name = identifier.text;\n        return resolveName(name, preferReference);\n      case ts.SyntaxKind.TypeReference:\n        const typeReferenceNode = <ts.TypeReferenceNode>node;\n        const typeNameNode = typeReferenceNode.typeName;\n        const getReference: (typeNameNode: ts.Identifier | ts.QualifiedName) => MetadataValue =\n            node => {\n              if (typeNameNode.kind === ts.SyntaxKind.QualifiedName) {\n                const qualifiedName = <ts.QualifiedName>node;\n                const left = this.evaluateNode(qualifiedName.left);\n                if (isMetadataModuleReferenceExpression(left)) {\n                  return recordEntry(\n                      <MetadataImportedSymbolReferenceExpression>{\n                        __symbolic: 'reference',\n                        module: left.module,\n                        name: qualifiedName.right.text\n                      },\n                      node);\n                }\n                // Record a type reference to a declared type as a select.\n                return {__symbolic: 'select', expression: left, member: qualifiedName.right.text};\n              } else {\n                const identifier = <ts.Identifier>typeNameNode;\n                const symbol = this.symbols.resolve(identifier.text);\n                if (isFoldableError(symbol) || isMetadataSymbolicReferenceExpression(symbol)) {\n                  return recordEntry(symbol, node);\n                }\n                return recordEntry(\n                    errorSymbol('Could not resolve type', node, {typeName: identifier.text}), node);\n              }\n            };\n        const typeReference = getReference(typeNameNode);\n        if (isFoldableError(typeReference)) {\n          return recordEntry(typeReference, node);\n        }\n        if (!isMetadataModuleReferenceExpression(typeReference) &&\n            typeReferenceNode.typeArguments && typeReferenceNode.typeArguments.length) {\n          const args = typeReferenceNode.typeArguments.map(element => this.evaluateNode(element));\n          // TODO: Remove typecast when upgraded to 2.0 as it will be correctly inferred.\n          // Some versions of 1.9 do not infer this correctly.\n          (<MetadataImportedSymbolReferenceExpression>typeReference).arguments = args;\n        }\n        return recordEntry(typeReference, node);\n      case ts.SyntaxKind.UnionType:\n        const unionType = <ts.UnionTypeNode>node;\n\n        // Remove null and undefined from the list of unions.\n        const references = unionType.types\n                               .filter(\n                                   n => n.kind != ts.SyntaxKind.NullKeyword &&\n                                       n.kind != ts.SyntaxKind.UndefinedKeyword)\n                               .map(n => this.evaluateNode(n));\n\n        // The remmaining reference must be the same. If two have type arguments consider them\n        // different even if the type arguments are the same.\n        let candidate: any = null;\n        for (let i = 0; i < references.length; i++) {\n          const reference = references[i];\n          if (isMetadataSymbolicReferenceExpression(reference)) {\n            if (candidate) {\n              if ((reference as any).name == candidate.name &&\n                  (reference as any).module == candidate.module && !(reference as any).arguments) {\n                candidate = reference;\n              }\n            } else {\n              candidate = reference;\n            }\n          } else {\n            return reference;\n          }\n        }\n        if (candidate) return candidate;\n        break;\n      case ts.SyntaxKind.NoSubstitutionTemplateLiteral:\n      case ts.SyntaxKind.StringLiteral:\n      case ts.SyntaxKind.TemplateHead:\n      case ts.SyntaxKind.TemplateTail:\n      case ts.SyntaxKind.TemplateMiddle:\n        return (<ts.LiteralLikeNode>node).text;\n      case ts.SyntaxKind.NumericLiteral:\n        return parseFloat((<ts.LiteralExpression>node).text);\n      case ts.SyntaxKind.AnyKeyword:\n        return recordEntry({__symbolic: 'reference', name: 'any'}, node);\n      case ts.SyntaxKind.StringKeyword:\n        return recordEntry({__symbolic: 'reference', name: 'string'}, node);\n      case ts.SyntaxKind.NumberKeyword:\n        return recordEntry({__symbolic: 'reference', name: 'number'}, node);\n      case ts.SyntaxKind.BooleanKeyword:\n        return recordEntry({__symbolic: 'reference', name: 'boolean'}, node);\n      case ts.SyntaxKind.ArrayType:\n        const arrayTypeNode = <ts.ArrayTypeNode>node;\n        return recordEntry(\n            {\n              __symbolic: 'reference',\n              name: 'Array',\n              arguments: [this.evaluateNode(arrayTypeNode.elementType)]\n            },\n            node);\n      case ts.SyntaxKind.NullKeyword:\n        return null;\n      case ts.SyntaxKind.TrueKeyword:\n        return true;\n      case ts.SyntaxKind.FalseKeyword:\n        return false;\n      case ts.SyntaxKind.ParenthesizedExpression:\n        const parenthesizedExpression = <ts.ParenthesizedExpression>node;\n        return this.evaluateNode(parenthesizedExpression.expression);\n      case ts.SyntaxKind.TypeAssertionExpression:\n        const typeAssertion = <ts.TypeAssertion>node;\n        return this.evaluateNode(typeAssertion.expression);\n      case ts.SyntaxKind.PrefixUnaryExpression:\n        const prefixUnaryExpression = <ts.PrefixUnaryExpression>node;\n        const operand = this.evaluateNode(prefixUnaryExpression.operand);\n        if (isDefined(operand) && isPrimitive(operand)) {\n          switch (prefixUnaryExpression.operator) {\n            case ts.SyntaxKind.PlusToken:\n              return +(operand as any);\n            case ts.SyntaxKind.MinusToken:\n              return -(operand as any);\n            case ts.SyntaxKind.TildeToken:\n              return ~(operand as any);\n            case ts.SyntaxKind.ExclamationToken:\n              return !operand;\n          }\n        }\n        let operatorText: string;\n        switch (prefixUnaryExpression.operator) {\n          case ts.SyntaxKind.PlusToken:\n            operatorText = '+';\n            break;\n          case ts.SyntaxKind.MinusToken:\n            operatorText = '-';\n            break;\n          case ts.SyntaxKind.TildeToken:\n            operatorText = '~';\n            break;\n          case ts.SyntaxKind.ExclamationToken:\n            operatorText = '!';\n            break;\n          default:\n            return undefined;\n        }\n        return recordEntry({__symbolic: 'pre', operator: operatorText, operand: operand}, node);\n      case ts.SyntaxKind.BinaryExpression:\n        const binaryExpression = <ts.BinaryExpression>node;\n        const left = this.evaluateNode(binaryExpression.left);\n        const right = this.evaluateNode(binaryExpression.right);\n        if (isDefined(left) && isDefined(right)) {\n          if (isPrimitive(left) && isPrimitive(right))\n            switch (binaryExpression.operatorToken.kind) {\n              case ts.SyntaxKind.BarBarToken:\n                return <any>left || <any>right;\n              case ts.SyntaxKind.AmpersandAmpersandToken:\n                return <any>left && <any>right;\n              case ts.SyntaxKind.AmpersandToken:\n                return <any>left & <any>right;\n              case ts.SyntaxKind.BarToken:\n                return <any>left | <any>right;\n              case ts.SyntaxKind.CaretToken:\n                return <any>left ^ <any>right;\n              case ts.SyntaxKind.EqualsEqualsToken:\n                return <any>left == <any>right;\n              case ts.SyntaxKind.ExclamationEqualsToken:\n                return <any>left != <any>right;\n              case ts.SyntaxKind.EqualsEqualsEqualsToken:\n                return <any>left === <any>right;\n              case ts.SyntaxKind.ExclamationEqualsEqualsToken:\n                return <any>left !== <any>right;\n              case ts.SyntaxKind.LessThanToken:\n                return <any>left < <any>right;\n              case ts.SyntaxKind.GreaterThanToken:\n                return <any>left > <any>right;\n              case ts.SyntaxKind.LessThanEqualsToken:\n                return <any>left <= <any>right;\n              case ts.SyntaxKind.GreaterThanEqualsToken:\n                return <any>left >= <any>right;\n              case ts.SyntaxKind.LessThanLessThanToken:\n                return (<any>left) << (<any>right);\n              case ts.SyntaxKind.GreaterThanGreaterThanToken:\n                return <any>left >> <any>right;\n              case ts.SyntaxKind.GreaterThanGreaterThanGreaterThanToken:\n                return <any>left >>> <any>right;\n              case ts.SyntaxKind.PlusToken:\n                return <any>left + <any>right;\n              case ts.SyntaxKind.MinusToken:\n                return <any>left - <any>right;\n              case ts.SyntaxKind.AsteriskToken:\n                return <any>left * <any>right;\n              case ts.SyntaxKind.SlashToken:\n                return <any>left / <any>right;\n              case ts.SyntaxKind.PercentToken:\n                return <any>left % <any>right;\n            }\n          return recordEntry(\n              {\n                __symbolic: 'binop',\n                operator: binaryExpression.operatorToken.getText(),\n                left: left,\n                right: right\n              },\n              node);\n        }\n        break;\n      case ts.SyntaxKind.ConditionalExpression:\n        const conditionalExpression = <ts.ConditionalExpression>node;\n        const condition = this.evaluateNode(conditionalExpression.condition);\n        const thenExpression = this.evaluateNode(conditionalExpression.whenTrue);\n        const elseExpression = this.evaluateNode(conditionalExpression.whenFalse);\n        if (isPrimitive(condition)) {\n          return condition ? thenExpression : elseExpression;\n        }\n        return recordEntry({__symbolic: 'if', condition, thenExpression, elseExpression}, node);\n      case ts.SyntaxKind.FunctionExpression:\n      case ts.SyntaxKind.ArrowFunction:\n        return recordEntry(errorSymbol('Lambda not supported', node), node);\n      case ts.SyntaxKind.TaggedTemplateExpression:\n        return recordEntry(\n            errorSymbol('Tagged template expressions are not supported in metadata', node), node);\n      case ts.SyntaxKind.TemplateExpression:\n        const templateExpression = <ts.TemplateExpression>node;\n        if (this.isFoldable(node)) {\n          return templateExpression.templateSpans.reduce(\n              (previous, current) => previous + <string>this.evaluateNode(current.expression) +\n                  <string>this.evaluateNode(current.literal),\n              this.evaluateNode(templateExpression.head));\n        } else {\n          return templateExpression.templateSpans.reduce((previous, current) => {\n            const expr = this.evaluateNode(current.expression);\n            const literal = this.evaluateNode(current.literal);\n            if (isFoldableError(expr)) return expr;\n            if (isFoldableError(literal)) return literal;\n            if (typeof previous === 'string' && typeof expr === 'string' &&\n                typeof literal === 'string') {\n              return previous + expr + literal;\n            }\n            let result = expr;\n            if (previous !== '') {\n              result = {__symbolic: 'binop', operator: '+', left: previous, right: expr};\n            }\n            if (literal != '') {\n              result = {__symbolic: 'binop', operator: '+', left: result, right: literal};\n            }\n            return result;\n          }, this.evaluateNode(templateExpression.head));\n        }\n      case ts.SyntaxKind.AsExpression:\n        const asExpression = <ts.AsExpression>node;\n        return this.evaluateNode(asExpression.expression);\n      case ts.SyntaxKind.ClassExpression:\n        return {__symbolic: 'class'};\n    }\n    return recordEntry(errorSymbol('Expression form not supported', node), node);\n  }\n}\n\nfunction isPropertyAssignment(node: ts.Node): node is ts.PropertyAssignment {\n  return node.kind == ts.SyntaxKind.PropertyAssignment;\n}\n\nconst empty = ts.createNodeArray<any>();\n\nfunction arrayOrEmpty<T extends ts.Node>(v: ts.NodeArray<T>| undefined): ts.NodeArray<T> {\n  return v || empty;\n}"]}
|
|
659
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"evaluator.js","sourceRoot":"","sources":["../../../../../../../packages/compiler-cli/src/metadata/evaluator.ts"],"names":[],"mappings":"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","sourcesContent":["/**\n * @license\n * Copyright Google Inc. All Rights Reserved.\n *\n * Use of this source code is governed by an MIT-style license that can be\n * found in the LICENSE file at https://angular.io/license\n */\n\nimport * as ts from 'typescript';\n\nimport {CollectorOptions} from './collector';\nimport {ClassMetadata, FunctionMetadata, InterfaceMetadata, MetadataEntry, MetadataError, MetadataImportedSymbolReferenceExpression, MetadataSourceLocationInfo, MetadataSymbolicCallExpression, MetadataValue, isMetadataError, isMetadataGlobalReferenceExpression, isMetadataImportDefaultReference, isMetadataImportedSymbolReferenceExpression, isMetadataModuleReferenceExpression, isMetadataSymbolicReferenceExpression, isMetadataSymbolicSpreadExpression} from './schema';\nimport {Symbols} from './symbols';\n\n\n\n// In TypeScript 2.1 the spread element kind was renamed.\nconst spreadElementSyntaxKind: ts.SyntaxKind =\n    (ts.SyntaxKind as any).SpreadElement || (ts.SyntaxKind as any).SpreadElementExpression;\n\nfunction isMethodCallOf(callExpression: ts.CallExpression, memberName: string): boolean {\n  const expression = callExpression.expression;\n  if (expression.kind === ts.SyntaxKind.PropertyAccessExpression) {\n    const propertyAccessExpression = <ts.PropertyAccessExpression>expression;\n    const name = propertyAccessExpression.name;\n    if (name.kind == ts.SyntaxKind.Identifier) {\n      return name.text === memberName;\n    }\n  }\n  return false;\n}\n\nfunction isCallOf(callExpression: ts.CallExpression, ident: string): boolean {\n  const expression = callExpression.expression;\n  if (expression.kind === ts.SyntaxKind.Identifier) {\n    const identifier = <ts.Identifier>expression;\n    return identifier.text === ident;\n  }\n  return false;\n}\n\n/* @internal */\nexport function recordMapEntry<T extends MetadataEntry>(\n    entry: T, node: ts.Node,\n    nodeMap: Map<MetadataValue|ClassMetadata|InterfaceMetadata|FunctionMetadata, ts.Node>,\n    sourceFile?: ts.SourceFile) {\n  if (!nodeMap.has(entry)) {\n    nodeMap.set(entry, node);\n    if (node && (isMetadataImportedSymbolReferenceExpression(entry) ||\n                 isMetadataImportDefaultReference(entry)) &&\n        entry.line == null) {\n      const info = sourceInfo(node, sourceFile);\n      if (info.line != null) entry.line = info.line;\n      if (info.character != null) entry.character = info.character;\n    }\n  }\n  return entry;\n}\n\n/**\n * ts.forEachChild stops iterating children when the callback return a truthy value.\n * This method inverts this to implement an `every` style iterator. It will return\n * true if every call to `cb` returns `true`.\n */\nfunction everyNodeChild(node: ts.Node, cb: (node: ts.Node) => boolean) {\n  return !ts.forEachChild(node, node => !cb(node));\n}\n\nexport function isPrimitive(value: any): boolean {\n  return Object(value) !== value;\n}\n\nfunction isDefined(obj: any): boolean {\n  return obj !== undefined;\n}\n\n// import {propertyName as name} from 'place'\n// import {name} from 'place'\nexport interface ImportSpecifierMetadata {\n  name: string;\n  propertyName?: string;\n}\nexport interface ImportMetadata {\n  defaultName?: string;                      // import d from 'place'\n  namespace?: string;                        // import * as d from 'place'\n  namedImports?: ImportSpecifierMetadata[];  // import {a} from 'place'\n  from: string;                              // from 'place'\n}\n\n\nfunction getSourceFileOfNode(node: ts.Node | undefined): ts.SourceFile {\n  while (node && node.kind != ts.SyntaxKind.SourceFile) {\n    node = node.parent;\n  }\n  return <ts.SourceFile>node;\n}\n\n/* @internal */\nexport function sourceInfo(\n    node: ts.Node | undefined, sourceFile: ts.SourceFile | undefined): MetadataSourceLocationInfo {\n  if (node) {\n    sourceFile = sourceFile || getSourceFileOfNode(node);\n    if (sourceFile) {\n      return ts.getLineAndCharacterOfPosition(sourceFile, node.getStart(sourceFile));\n    }\n  }\n  return {};\n}\n\n/* @internal */\nexport function errorSymbol(\n    message: string, node?: ts.Node, context?: {[name: string]: string},\n    sourceFile?: ts.SourceFile): MetadataError {\n  const result: MetadataError = {__symbolic: 'error', message, ...sourceInfo(node, sourceFile)};\n  if (context) {\n    result.context = context;\n  }\n  return result;\n}\n\n/**\n * Produce a symbolic representation of an expression folding values into their final value when\n * possible.\n */\nexport class Evaluator {\n  constructor(\n      private symbols: Symbols, private nodeMap: Map<MetadataEntry, ts.Node>,\n      private options: CollectorOptions = {},\n      private recordExport?: (name: string, value: MetadataValue) => void) {}\n\n  nameOf(node: ts.Node|undefined): string|MetadataError {\n    if (node && node.kind == ts.SyntaxKind.Identifier) {\n      return (<ts.Identifier>node).text;\n    }\n    const result = node && this.evaluateNode(node);\n    if (isMetadataError(result) || typeof result === 'string') {\n      return result;\n    } else {\n      return errorSymbol(\n          'Name expected', node, {received: (node && node.getText()) || '<missing>'});\n    }\n  }\n\n  /**\n   * Returns true if the expression represented by `node` can be folded into a literal expression.\n   *\n   * For example, a literal is always foldable. This means that literal expressions such as `1.2`\n   * `\"Some value\"` `true` `false` are foldable.\n   *\n   * - An object literal is foldable if all the properties in the literal are foldable.\n   * - An array literal is foldable if all the elements are foldable.\n   * - A call is foldable if it is a call to a Array.prototype.concat or a call to CONST_EXPR.\n   * - A property access is foldable if the object is foldable.\n   * - A array index is foldable if index expression is foldable and the array is foldable.\n   * - Binary operator expressions are foldable if the left and right expressions are foldable and\n   *   it is one of '+', '-', '*', '/', '%', '||', and '&&'.\n   * - An identifier is foldable if a value can be found for its symbol in the evaluator symbol\n   *   table.\n   */\n  public isFoldable(node: ts.Node): boolean {\n    return this.isFoldableWorker(node, new Map<ts.Node, boolean>());\n  }\n\n  private isFoldableWorker(node: ts.Node|undefined, folding: Map<ts.Node, boolean>): boolean {\n    if (node) {\n      switch (node.kind) {\n        case ts.SyntaxKind.ObjectLiteralExpression:\n          return everyNodeChild(node, child => {\n            if (child.kind === ts.SyntaxKind.PropertyAssignment) {\n              const propertyAssignment = <ts.PropertyAssignment>child;\n              return this.isFoldableWorker(propertyAssignment.initializer, folding);\n            }\n            return false;\n          });\n        case ts.SyntaxKind.ArrayLiteralExpression:\n          return everyNodeChild(node, child => this.isFoldableWorker(child, folding));\n        case ts.SyntaxKind.CallExpression:\n          const callExpression = <ts.CallExpression>node;\n          // We can fold a <array>.concat(<v>).\n          if (isMethodCallOf(callExpression, 'concat') &&\n              arrayOrEmpty(callExpression.arguments).length === 1) {\n            const arrayNode = (<ts.PropertyAccessExpression>callExpression.expression).expression;\n            if (this.isFoldableWorker(arrayNode, folding) &&\n                this.isFoldableWorker(callExpression.arguments[0], folding)) {\n              // It needs to be an array.\n              const arrayValue = this.evaluateNode(arrayNode);\n              if (arrayValue && Array.isArray(arrayValue)) {\n                return true;\n              }\n            }\n          }\n\n          // We can fold a call to CONST_EXPR\n          if (isCallOf(callExpression, 'CONST_EXPR') &&\n              arrayOrEmpty(callExpression.arguments).length === 1)\n            return this.isFoldableWorker(callExpression.arguments[0], folding);\n          return false;\n        case ts.SyntaxKind.NoSubstitutionTemplateLiteral:\n        case ts.SyntaxKind.StringLiteral:\n        case ts.SyntaxKind.NumericLiteral:\n        case ts.SyntaxKind.NullKeyword:\n        case ts.SyntaxKind.TrueKeyword:\n        case ts.SyntaxKind.FalseKeyword:\n        case ts.SyntaxKind.TemplateHead:\n        case ts.SyntaxKind.TemplateMiddle:\n        case ts.SyntaxKind.TemplateTail:\n          return true;\n        case ts.SyntaxKind.ParenthesizedExpression:\n          const parenthesizedExpression = <ts.ParenthesizedExpression>node;\n          return this.isFoldableWorker(parenthesizedExpression.expression, folding);\n        case ts.SyntaxKind.BinaryExpression:\n          const binaryExpression = <ts.BinaryExpression>node;\n          switch (binaryExpression.operatorToken.kind) {\n            case ts.SyntaxKind.PlusToken:\n            case ts.SyntaxKind.MinusToken:\n            case ts.SyntaxKind.AsteriskToken:\n            case ts.SyntaxKind.SlashToken:\n            case ts.SyntaxKind.PercentToken:\n            case ts.SyntaxKind.AmpersandAmpersandToken:\n            case ts.SyntaxKind.BarBarToken:\n              return this.isFoldableWorker(binaryExpression.left, folding) &&\n                  this.isFoldableWorker(binaryExpression.right, folding);\n            default:\n              return false;\n          }\n        case ts.SyntaxKind.PropertyAccessExpression:\n          const propertyAccessExpression = <ts.PropertyAccessExpression>node;\n          return this.isFoldableWorker(propertyAccessExpression.expression, folding);\n        case ts.SyntaxKind.ElementAccessExpression:\n          const elementAccessExpression = <ts.ElementAccessExpression>node;\n          return this.isFoldableWorker(elementAccessExpression.expression, folding) &&\n              this.isFoldableWorker(elementAccessExpression.argumentExpression, folding);\n        case ts.SyntaxKind.Identifier:\n          let identifier = <ts.Identifier>node;\n          let reference = this.symbols.resolve(identifier.text);\n          if (reference !== undefined && isPrimitive(reference)) {\n            return true;\n          }\n          break;\n        case ts.SyntaxKind.TemplateExpression:\n          const templateExpression = <ts.TemplateExpression>node;\n          return templateExpression.templateSpans.every(\n              span => this.isFoldableWorker(span.expression, folding));\n      }\n    }\n    return false;\n  }\n\n  /**\n   * Produce a JSON serialiable object representing `node`. The foldable values in the expression\n   * tree are folded. For example, a node representing `1 + 2` is folded into `3`.\n   */\n  public evaluateNode(node: ts.Node, preferReference?: boolean): MetadataValue {\n    const t = this;\n    let error: MetadataError|undefined;\n\n    function recordEntry(entry: MetadataValue, node: ts.Node): MetadataValue {\n      if (t.options.substituteExpression) {\n        const newEntry = t.options.substituteExpression(entry, node);\n        if (t.recordExport && newEntry != entry && isMetadataGlobalReferenceExpression(newEntry)) {\n          t.recordExport(newEntry.name, entry);\n        }\n        entry = newEntry;\n      }\n      return recordMapEntry(entry, node, t.nodeMap);\n    }\n\n    function isFoldableError(value: any): value is MetadataError {\n      return !t.options.verboseInvalidExpression && isMetadataError(value);\n    }\n\n    const resolveName = (name: string, preferReference?: boolean): MetadataValue => {\n      const reference = this.symbols.resolve(name, preferReference);\n      if (reference === undefined) {\n        // Encode as a global reference. StaticReflector will check the reference.\n        return recordEntry({__symbolic: 'reference', name}, node);\n      }\n      if (reference && isMetadataSymbolicReferenceExpression(reference)) {\n        return recordEntry({...reference}, node);\n      }\n      return reference;\n    };\n\n    switch (node.kind) {\n      case ts.SyntaxKind.ObjectLiteralExpression:\n        let obj: {[name: string]: any} = {};\n        let quoted: string[] = [];\n        ts.forEachChild(node, child => {\n          switch (child.kind) {\n            case ts.SyntaxKind.ShorthandPropertyAssignment:\n            case ts.SyntaxKind.PropertyAssignment:\n              const assignment = <ts.PropertyAssignment|ts.ShorthandPropertyAssignment>child;\n              if (assignment.name.kind == ts.SyntaxKind.StringLiteral) {\n                const name = (assignment.name as ts.StringLiteral).text;\n                quoted.push(name);\n              }\n              const propertyName = this.nameOf(assignment.name);\n              if (isFoldableError(propertyName)) {\n                error = propertyName;\n                return true;\n              }\n              const propertyValue = isPropertyAssignment(assignment) ?\n                  this.evaluateNode(assignment.initializer, /* preferReference */ true) :\n                  resolveName(propertyName, /* preferReference */ true);\n              if (isFoldableError(propertyValue)) {\n                error = propertyValue;\n                return true;  // Stop the forEachChild.\n              } else {\n                obj[<string>propertyName] = isPropertyAssignment(assignment) ?\n                    recordEntry(propertyValue, assignment.initializer) :\n                    propertyValue;\n              }\n          }\n        });\n        if (error) return error;\n        if (this.options.quotedNames && quoted.length) {\n          obj['$quoted$'] = quoted;\n        }\n        return recordEntry(obj, node);\n      case ts.SyntaxKind.ArrayLiteralExpression:\n        let arr: MetadataValue[] = [];\n        ts.forEachChild(node, child => {\n          const value = this.evaluateNode(child, /* preferReference */ true);\n\n          // Check for error\n          if (isFoldableError(value)) {\n            error = value;\n            return true;  // Stop the forEachChild.\n          }\n\n          // Handle spread expressions\n          if (isMetadataSymbolicSpreadExpression(value)) {\n            if (Array.isArray(value.expression)) {\n              for (const spreadValue of value.expression) {\n                arr.push(spreadValue);\n              }\n              return;\n            }\n          }\n\n          arr.push(value);\n        });\n        if (error) return error;\n        return recordEntry(arr, node);\n      case spreadElementSyntaxKind:\n        let spreadExpression = this.evaluateNode((node as any).expression);\n        return recordEntry({__symbolic: 'spread', expression: spreadExpression}, node);\n      case ts.SyntaxKind.CallExpression:\n        const callExpression = <ts.CallExpression>node;\n        if (isCallOf(callExpression, 'forwardRef') &&\n            arrayOrEmpty(callExpression.arguments).length === 1) {\n          const firstArgument = callExpression.arguments[0];\n          if (firstArgument.kind == ts.SyntaxKind.ArrowFunction) {\n            const arrowFunction = <ts.ArrowFunction>firstArgument;\n            return recordEntry(this.evaluateNode(arrowFunction.body), node);\n          }\n        }\n        const args = arrayOrEmpty(callExpression.arguments).map(arg => this.evaluateNode(arg));\n        if (this.isFoldable(callExpression)) {\n          if (isMethodCallOf(callExpression, 'concat')) {\n            const arrayValue = <MetadataValue[]>this.evaluateNode(\n                (<ts.PropertyAccessExpression>callExpression.expression).expression);\n            if (isFoldableError(arrayValue)) return arrayValue;\n            return arrayValue.concat(args[0]);\n          }\n        }\n        // Always fold a CONST_EXPR even if the argument is not foldable.\n        if (isCallOf(callExpression, 'CONST_EXPR') &&\n            arrayOrEmpty(callExpression.arguments).length === 1) {\n          return recordEntry(args[0], node);\n        }\n        const expression = this.evaluateNode(callExpression.expression);\n        if (isFoldableError(expression)) {\n          return recordEntry(expression, node);\n        }\n        let result: MetadataSymbolicCallExpression = {__symbolic: 'call', expression: expression};\n        if (args && args.length) {\n          result.arguments = args;\n        }\n        return recordEntry(result, node);\n      case ts.SyntaxKind.NewExpression:\n        const newExpression = <ts.NewExpression>node;\n        const newArgs = arrayOrEmpty(newExpression.arguments).map(arg => this.evaluateNode(arg));\n        const newTarget = this.evaluateNode(newExpression.expression);\n        if (isMetadataError(newTarget)) {\n          return recordEntry(newTarget, node);\n        }\n        const call: MetadataSymbolicCallExpression = {__symbolic: 'new', expression: newTarget};\n        if (newArgs.length) {\n          call.arguments = newArgs;\n        }\n        return recordEntry(call, node);\n      case ts.SyntaxKind.PropertyAccessExpression: {\n        const propertyAccessExpression = <ts.PropertyAccessExpression>node;\n        const expression = this.evaluateNode(propertyAccessExpression.expression);\n        if (isFoldableError(expression)) {\n          return recordEntry(expression, node);\n        }\n        const member = this.nameOf(propertyAccessExpression.name);\n        if (isFoldableError(member)) {\n          return recordEntry(member, node);\n        }\n        if (expression && this.isFoldable(propertyAccessExpression.expression))\n          return (<any>expression)[<string>member];\n        if (isMetadataModuleReferenceExpression(expression)) {\n          // A select into a module reference and be converted into a reference to the symbol\n          // in the module\n          return recordEntry(\n              {__symbolic: 'reference', module: expression.module, name: member}, node);\n        }\n        return recordEntry({__symbolic: 'select', expression, member}, node);\n      }\n      case ts.SyntaxKind.ElementAccessExpression: {\n        const elementAccessExpression = <ts.ElementAccessExpression>node;\n        const expression = this.evaluateNode(elementAccessExpression.expression);\n        if (isFoldableError(expression)) {\n          return recordEntry(expression, node);\n        }\n        if (!elementAccessExpression.argumentExpression) {\n          return recordEntry(errorSymbol('Expression form not supported', node), node);\n        }\n        const index = this.evaluateNode(elementAccessExpression.argumentExpression);\n        if (isFoldableError(expression)) {\n          return recordEntry(expression, node);\n        }\n        if (this.isFoldable(elementAccessExpression.expression) &&\n            this.isFoldable(elementAccessExpression.argumentExpression))\n          return (<any>expression)[<string|number>index];\n        return recordEntry({__symbolic: 'index', expression, index}, node);\n      }\n      case ts.SyntaxKind.Identifier:\n        const identifier = <ts.Identifier>node;\n        const name = identifier.text;\n        return resolveName(name, preferReference);\n      case ts.SyntaxKind.TypeReference:\n        const typeReferenceNode = <ts.TypeReferenceNode>node;\n        const typeNameNode = typeReferenceNode.typeName;\n        const getReference: (typeNameNode: ts.Identifier | ts.QualifiedName) => MetadataValue =\n            node => {\n              if (typeNameNode.kind === ts.SyntaxKind.QualifiedName) {\n                const qualifiedName = <ts.QualifiedName>node;\n                const left = this.evaluateNode(qualifiedName.left);\n                if (isMetadataModuleReferenceExpression(left)) {\n                  return recordEntry(\n                      <MetadataImportedSymbolReferenceExpression>{\n                        __symbolic: 'reference',\n                        module: left.module,\n                        name: qualifiedName.right.text\n                      },\n                      node);\n                }\n                // Record a type reference to a declared type as a select.\n                return {__symbolic: 'select', expression: left, member: qualifiedName.right.text};\n              } else {\n                const identifier = <ts.Identifier>typeNameNode;\n                const symbol = this.symbols.resolve(identifier.text);\n                if (isFoldableError(symbol) || isMetadataSymbolicReferenceExpression(symbol)) {\n                  return recordEntry(symbol, node);\n                }\n                return recordEntry(\n                    errorSymbol('Could not resolve type', node, {typeName: identifier.text}), node);\n              }\n            };\n        const typeReference = getReference(typeNameNode);\n        if (isFoldableError(typeReference)) {\n          return recordEntry(typeReference, node);\n        }\n        if (!isMetadataModuleReferenceExpression(typeReference) &&\n            typeReferenceNode.typeArguments && typeReferenceNode.typeArguments.length) {\n          const args = typeReferenceNode.typeArguments.map(element => this.evaluateNode(element));\n          // TODO: Remove typecast when upgraded to 2.0 as it will be correctly inferred.\n          // Some versions of 1.9 do not infer this correctly.\n          (<MetadataImportedSymbolReferenceExpression>typeReference).arguments = args;\n        }\n        return recordEntry(typeReference, node);\n      case ts.SyntaxKind.UnionType:\n        const unionType = <ts.UnionTypeNode>node;\n\n        // Remove null and undefined from the list of unions.\n        const references = unionType.types\n                               .filter(\n                                   n => n.kind != ts.SyntaxKind.NullKeyword &&\n                                       n.kind != ts.SyntaxKind.UndefinedKeyword)\n                               .map(n => this.evaluateNode(n));\n\n        // The remmaining reference must be the same. If two have type arguments consider them\n        // different even if the type arguments are the same.\n        let candidate: any = null;\n        for (let i = 0; i < references.length; i++) {\n          const reference = references[i];\n          if (isMetadataSymbolicReferenceExpression(reference)) {\n            if (candidate) {\n              if ((reference as any).name == candidate.name &&\n                  (reference as any).module == candidate.module && !(reference as any).arguments) {\n                candidate = reference;\n              }\n            } else {\n              candidate = reference;\n            }\n          } else {\n            return reference;\n          }\n        }\n        if (candidate) return candidate;\n        break;\n      case ts.SyntaxKind.NoSubstitutionTemplateLiteral:\n      case ts.SyntaxKind.StringLiteral:\n      case ts.SyntaxKind.TemplateHead:\n      case ts.SyntaxKind.TemplateTail:\n      case ts.SyntaxKind.TemplateMiddle:\n        return (<ts.LiteralLikeNode>node).text;\n      case ts.SyntaxKind.NumericLiteral:\n        return parseFloat((<ts.LiteralExpression>node).text);\n      case ts.SyntaxKind.AnyKeyword:\n        return recordEntry({__symbolic: 'reference', name: 'any'}, node);\n      case ts.SyntaxKind.StringKeyword:\n        return recordEntry({__symbolic: 'reference', name: 'string'}, node);\n      case ts.SyntaxKind.NumberKeyword:\n        return recordEntry({__symbolic: 'reference', name: 'number'}, node);\n      case ts.SyntaxKind.BooleanKeyword:\n        return recordEntry({__symbolic: 'reference', name: 'boolean'}, node);\n      case ts.SyntaxKind.ArrayType:\n        const arrayTypeNode = <ts.ArrayTypeNode>node;\n        return recordEntry(\n            {\n              __symbolic: 'reference',\n              name: 'Array',\n              arguments: [this.evaluateNode(arrayTypeNode.elementType)]\n            },\n            node);\n      case ts.SyntaxKind.NullKeyword:\n        return null;\n      case ts.SyntaxKind.TrueKeyword:\n        return true;\n      case ts.SyntaxKind.FalseKeyword:\n        return false;\n      case ts.SyntaxKind.ParenthesizedExpression:\n        const parenthesizedExpression = <ts.ParenthesizedExpression>node;\n        return this.evaluateNode(parenthesizedExpression.expression);\n      case ts.SyntaxKind.TypeAssertionExpression:\n        const typeAssertion = <ts.TypeAssertion>node;\n        return this.evaluateNode(typeAssertion.expression);\n      case ts.SyntaxKind.PrefixUnaryExpression:\n        const prefixUnaryExpression = <ts.PrefixUnaryExpression>node;\n        const operand = this.evaluateNode(prefixUnaryExpression.operand);\n        if (isDefined(operand) && isPrimitive(operand)) {\n          switch (prefixUnaryExpression.operator) {\n            case ts.SyntaxKind.PlusToken:\n              return +(operand as any);\n            case ts.SyntaxKind.MinusToken:\n              return -(operand as any);\n            case ts.SyntaxKind.TildeToken:\n              return ~(operand as any);\n            case ts.SyntaxKind.ExclamationToken:\n              return !operand;\n          }\n        }\n        let operatorText: string;\n        switch (prefixUnaryExpression.operator) {\n          case ts.SyntaxKind.PlusToken:\n            operatorText = '+';\n            break;\n          case ts.SyntaxKind.MinusToken:\n            operatorText = '-';\n            break;\n          case ts.SyntaxKind.TildeToken:\n            operatorText = '~';\n            break;\n          case ts.SyntaxKind.ExclamationToken:\n            operatorText = '!';\n            break;\n          default:\n            return undefined;\n        }\n        return recordEntry({__symbolic: 'pre', operator: operatorText, operand: operand}, node);\n      case ts.SyntaxKind.BinaryExpression:\n        const binaryExpression = <ts.BinaryExpression>node;\n        const left = this.evaluateNode(binaryExpression.left);\n        const right = this.evaluateNode(binaryExpression.right);\n        if (isDefined(left) && isDefined(right)) {\n          if (isPrimitive(left) && isPrimitive(right))\n            switch (binaryExpression.operatorToken.kind) {\n              case ts.SyntaxKind.BarBarToken:\n                return <any>left || <any>right;\n              case ts.SyntaxKind.AmpersandAmpersandToken:\n                return <any>left && <any>right;\n              case ts.SyntaxKind.AmpersandToken:\n                return <any>left & <any>right;\n              case ts.SyntaxKind.BarToken:\n                return <any>left | <any>right;\n              case ts.SyntaxKind.CaretToken:\n                return <any>left ^ <any>right;\n              case ts.SyntaxKind.EqualsEqualsToken:\n                return <any>left == <any>right;\n              case ts.SyntaxKind.ExclamationEqualsToken:\n                return <any>left != <any>right;\n              case ts.SyntaxKind.EqualsEqualsEqualsToken:\n                return <any>left === <any>right;\n              case ts.SyntaxKind.ExclamationEqualsEqualsToken:\n                return <any>left !== <any>right;\n              case ts.SyntaxKind.LessThanToken:\n                return <any>left < <any>right;\n              case ts.SyntaxKind.GreaterThanToken:\n                return <any>left > <any>right;\n              case ts.SyntaxKind.LessThanEqualsToken:\n                return <any>left <= <any>right;\n              case ts.SyntaxKind.GreaterThanEqualsToken:\n                return <any>left >= <any>right;\n              case ts.SyntaxKind.LessThanLessThanToken:\n                return (<any>left) << (<any>right);\n              case ts.SyntaxKind.GreaterThanGreaterThanToken:\n                return <any>left >> <any>right;\n              case ts.SyntaxKind.GreaterThanGreaterThanGreaterThanToken:\n                return <any>left >>> <any>right;\n              case ts.SyntaxKind.PlusToken:\n                return <any>left + <any>right;\n              case ts.SyntaxKind.MinusToken:\n                return <any>left - <any>right;\n              case ts.SyntaxKind.AsteriskToken:\n                return <any>left * <any>right;\n              case ts.SyntaxKind.SlashToken:\n                return <any>left / <any>right;\n              case ts.SyntaxKind.PercentToken:\n                return <any>left % <any>right;\n            }\n          return recordEntry(\n              {\n                __symbolic: 'binop',\n                operator: binaryExpression.operatorToken.getText(),\n                left: left,\n                right: right\n              },\n              node);\n        }\n        break;\n      case ts.SyntaxKind.ConditionalExpression:\n        const conditionalExpression = <ts.ConditionalExpression>node;\n        const condition = this.evaluateNode(conditionalExpression.condition);\n        const thenExpression = this.evaluateNode(conditionalExpression.whenTrue);\n        const elseExpression = this.evaluateNode(conditionalExpression.whenFalse);\n        if (isPrimitive(condition)) {\n          return condition ? thenExpression : elseExpression;\n        }\n        return recordEntry({__symbolic: 'if', condition, thenExpression, elseExpression}, node);\n      case ts.SyntaxKind.FunctionExpression:\n      case ts.SyntaxKind.ArrowFunction:\n        return recordEntry(errorSymbol('Lambda not supported', node), node);\n      case ts.SyntaxKind.TaggedTemplateExpression:\n        return recordEntry(\n            errorSymbol('Tagged template expressions are not supported in metadata', node), node);\n      case ts.SyntaxKind.TemplateExpression:\n        const templateExpression = <ts.TemplateExpression>node;\n        if (this.isFoldable(node)) {\n          return templateExpression.templateSpans.reduce(\n              (previous, current) => previous + <string>this.evaluateNode(current.expression) +\n                  <string>this.evaluateNode(current.literal),\n              this.evaluateNode(templateExpression.head));\n        } else {\n          return templateExpression.templateSpans.reduce((previous, current) => {\n            const expr = this.evaluateNode(current.expression);\n            const literal = this.evaluateNode(current.literal);\n            if (isFoldableError(expr)) return expr;\n            if (isFoldableError(literal)) return literal;\n            if (typeof previous === 'string' && typeof expr === 'string' &&\n                typeof literal === 'string') {\n              return previous + expr + literal;\n            }\n            let result = expr;\n            if (previous !== '') {\n              result = {__symbolic: 'binop', operator: '+', left: previous, right: expr};\n            }\n            if (literal != '') {\n              result = {__symbolic: 'binop', operator: '+', left: result, right: literal};\n            }\n            return result;\n          }, this.evaluateNode(templateExpression.head));\n        }\n      case ts.SyntaxKind.AsExpression:\n        const asExpression = <ts.AsExpression>node;\n        return this.evaluateNode(asExpression.expression);\n      case ts.SyntaxKind.ClassExpression:\n        return {__symbolic: 'class'};\n    }\n    return recordEntry(errorSymbol('Expression form not supported', node), node);\n  }\n}\n\nfunction isPropertyAssignment(node: ts.Node): node is ts.PropertyAssignment {\n  return node.kind == ts.SyntaxKind.PropertyAssignment;\n}\n\nconst empty = ts.createNodeArray<any>();\n\nfunction arrayOrEmpty<T extends ts.Node>(v: ts.NodeArray<T>| undefined): ts.NodeArray<T> {\n  return v || empty;\n}"]}
|