@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.
Files changed (39) hide show
  1. package/index.js +1 -1
  2. package/package.json +4 -4
  3. package/src/diagnostics/expression_diagnostics.js +98 -151
  4. package/src/diagnostics/expression_type.js +122 -139
  5. package/src/diagnostics/translate_diagnostics.js +12 -12
  6. package/src/diagnostics/typescript_symbols.js +296 -514
  7. package/src/diagnostics/typescript_version.js +8 -8
  8. package/src/extract_i18n.js +11 -13
  9. package/src/main.js +80 -78
  10. package/src/metadata/bundle_index_host.js +39 -51
  11. package/src/metadata/bundler.js +214 -256
  12. package/src/metadata/collector.js +235 -317
  13. package/src/metadata/evaluator.js +146 -162
  14. package/src/metadata/index.js +1 -1
  15. package/src/metadata/index_writer.js +25 -47
  16. package/src/metadata/symbols.js +44 -62
  17. package/src/ngcc/src/packages/build_marker.d.ts +1 -1
  18. package/src/ngcc/src/packages/build_marker.js +1 -1
  19. package/src/ngtools_api.js +29 -44
  20. package/src/ngtools_api2.js +9 -11
  21. package/src/ngtsc/program.js +122 -162
  22. package/src/ngtsc/resource_loader.js +35 -50
  23. package/src/perform_compile.js +87 -93
  24. package/src/perform_watch.js +50 -51
  25. package/src/transformers/compiler_host.js +158 -171
  26. package/src/transformers/inline_resources.js +54 -57
  27. package/src/transformers/lower_expressions.js +87 -101
  28. package/src/transformers/metadata_cache.js +21 -50
  29. package/src/transformers/metadata_reader.js +17 -18
  30. package/src/transformers/nocollapse_hack.js +9 -9
  31. package/src/transformers/node_emitter.js +214 -237
  32. package/src/transformers/node_emitter_transform.js +25 -21
  33. package/src/transformers/program.js +336 -440
  34. package/src/transformers/r3_metadata_transform.js +21 -34
  35. package/src/transformers/r3_strip_decorators.js +29 -31
  36. package/src/transformers/r3_transform.js +7 -8
  37. package/src/transformers/tsc_pass_through.js +33 -37
  38. package/src/transformers/util.js +18 -30
  39. 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", "tslib", "typescript", "@angular/compiler-cli/src/metadata/schema"], factory);
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
- var tslib_1 = require("tslib");
20
- var ts = require("typescript");
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
- var spreadElementSyntaxKind = ts.SyntaxKind.SpreadElement || ts.SyntaxKind.SpreadElementExpression;
22
+ const spreadElementSyntaxKind = ts.SyntaxKind.SpreadElement || ts.SyntaxKind.SpreadElementExpression;
24
23
  function isMethodCallOf(callExpression, memberName) {
25
- var expression = callExpression.expression;
24
+ const expression = callExpression.expression;
26
25
  if (expression.kind === ts.SyntaxKind.PropertyAccessExpression) {
27
- var propertyAccessExpression = expression;
28
- var name = propertyAccessExpression.name;
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
- var expression = callExpression.expression;
35
+ const expression = callExpression.expression;
37
36
  if (expression.kind === ts.SyntaxKind.Identifier) {
38
- var identifier = expression;
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
- var info = sourceInfo(node, sourceFile);
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, function (node) { return !cb(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
- var result = tslib_1.__assign({ __symbolic: 'error', message: message }, sourceInfo(node, sourceFile));
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
- var Evaluator = /** @class */ (function () {
106
- function Evaluator(symbols, nodeMap, options, recordExport) {
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
- Evaluator.prototype.nameOf = function (node) {
111
+ nameOf(node) {
114
112
  if (node && node.kind == ts.SyntaxKind.Identifier) {
115
113
  return node.text;
116
114
  }
117
- var result = node && this.evaluateNode(node);
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
- Evaluator.prototype.isFoldable = function (node) {
139
+ isFoldable(node) {
142
140
  return this.isFoldableWorker(node, new Map());
143
- };
144
- Evaluator.prototype.isFoldableWorker = function (node, folding) {
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, function (child) {
146
+ return everyNodeChild(node, child => {
150
147
  if (child.kind === ts.SyntaxKind.PropertyAssignment) {
151
- var propertyAssignment = child;
152
- return _this.isFoldableWorker(propertyAssignment.initializer, folding);
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, function (child) { return _this.isFoldableWorker(child, folding); });
154
+ return everyNodeChild(node, child => this.isFoldableWorker(child, folding));
158
155
  case ts.SyntaxKind.CallExpression:
159
- var callExpression = node;
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
- var arrayNode = callExpression.expression.expression;
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
- var arrayValue = this.evaluateNode(arrayNode);
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
- var parenthesizedExpression = node;
186
+ const parenthesizedExpression = node;
190
187
  return this.isFoldableWorker(parenthesizedExpression.expression, folding);
191
188
  case ts.SyntaxKind.BinaryExpression:
192
- var binaryExpression = node;
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
- var propertyAccessExpression = node;
204
+ const propertyAccessExpression = node;
208
205
  return this.isFoldableWorker(propertyAccessExpression.expression, folding);
209
206
  case ts.SyntaxKind.ElementAccessExpression:
210
- var elementAccessExpression = node;
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
- var identifier = node;
215
- var reference = this.symbols.resolve(identifier.text);
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
- var templateExpression = node;
222
- return templateExpression.templateSpans.every(function (span) { return _this.isFoldableWorker(span.expression, folding); });
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
- Evaluator.prototype.evaluateNode = function (node, preferReference) {
232
- var _this = this;
233
- var t = this;
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
- var newEntry = t.options.substituteExpression(entry, node);
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
- var resolveName = function (name, preferReference) {
249
- var reference = _this.symbols.resolve(name, preferReference);
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: name }, node);
248
+ return recordEntry({ __symbolic: 'reference', name }, node);
253
249
  }
254
250
  if (reference && schema_1.isMetadataSymbolicReferenceExpression(reference)) {
255
- return recordEntry(tslib_1.__assign({}, reference), node);
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
- var obj_1 = {};
262
- var quoted_1 = [];
263
- ts.forEachChild(node, function (child) {
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
- var assignment = child;
263
+ const assignment = child;
268
264
  if (assignment.name.kind == ts.SyntaxKind.StringLiteral) {
269
- var name_1 = assignment.name.text;
270
- quoted_1.push(name_1);
265
+ const name = assignment.name.text;
266
+ quoted.push(name);
271
267
  }
272
- var propertyName = _this.nameOf(assignment.name);
268
+ const propertyName = this.nameOf(assignment.name);
273
269
  if (isFoldableError(propertyName)) {
274
270
  error = propertyName;
275
271
  return true;
276
272
  }
277
- var propertyValue = isPropertyAssignment(assignment) ?
278
- _this.evaluateNode(assignment.initializer, /* preferReference */ true) :
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
- obj_1[propertyName] = isPropertyAssignment(assignment) ?
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 && quoted_1.length) {
294
- obj_1['$quoted$'] = quoted_1;
289
+ if (this.options.quotedNames && quoted.length) {
290
+ obj['$quoted$'] = quoted;
295
291
  }
296
- return recordEntry(obj_1, node);
292
+ return recordEntry(obj, node);
297
293
  case ts.SyntaxKind.ArrayLiteralExpression:
298
- var arr_1 = [];
299
- ts.forEachChild(node, function (child) {
300
- var e_1, _a;
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
- try {
311
- for (var _b = tslib_1.__values(value.expression), _c = _b.next(); !_c.done; _c = _b.next()) {
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
- arr_1.push(value);
311
+ arr.push(value);
327
312
  });
328
313
  if (error)
329
314
  return error;
330
- return recordEntry(arr_1, node);
315
+ return recordEntry(arr, node);
331
316
  case spreadElementSyntaxKind:
332
- var spreadExpression = this.evaluateNode(node.expression);
317
+ let spreadExpression = this.evaluateNode(node.expression);
333
318
  return recordEntry({ __symbolic: 'spread', expression: spreadExpression }, node);
334
319
  case ts.SyntaxKind.CallExpression:
335
- var callExpression = node;
320
+ const callExpression = node;
336
321
  if (isCallOf(callExpression, 'forwardRef') &&
337
322
  arrayOrEmpty(callExpression.arguments).length === 1) {
338
- var firstArgument = callExpression.arguments[0];
323
+ const firstArgument = callExpression.arguments[0];
339
324
  if (firstArgument.kind == ts.SyntaxKind.ArrowFunction) {
340
- var arrowFunction = firstArgument;
325
+ const arrowFunction = firstArgument;
341
326
  return recordEntry(this.evaluateNode(arrowFunction.body), node);
342
327
  }
343
328
  }
344
- var args = arrayOrEmpty(callExpression.arguments).map(function (arg) { return _this.evaluateNode(arg); });
329
+ const args = arrayOrEmpty(callExpression.arguments).map(arg => this.evaluateNode(arg));
345
330
  if (this.isFoldable(callExpression)) {
346
331
  if (isMethodCallOf(callExpression, 'concat')) {
347
- var arrayValue = this.evaluateNode(callExpression.expression.expression);
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
- var expression = this.evaluateNode(callExpression.expression);
343
+ const expression = this.evaluateNode(callExpression.expression);
359
344
  if (isFoldableError(expression)) {
360
345
  return recordEntry(expression, node);
361
346
  }
362
- var result = { __symbolic: 'call', expression: expression };
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
- var newExpression = node;
369
- var newArgs = arrayOrEmpty(newExpression.arguments).map(function (arg) { return _this.evaluateNode(arg); });
370
- var newTarget = this.evaluateNode(newExpression.expression);
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
- var call = { __symbolic: 'new', expression: newTarget };
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
- var propertyAccessExpression = node;
381
- var expression_1 = this.evaluateNode(propertyAccessExpression.expression);
382
- if (isFoldableError(expression_1)) {
383
- return recordEntry(expression_1, node);
365
+ const propertyAccessExpression = node;
366
+ const expression = this.evaluateNode(propertyAccessExpression.expression);
367
+ if (isFoldableError(expression)) {
368
+ return recordEntry(expression, node);
384
369
  }
385
- var member = this.nameOf(propertyAccessExpression.name);
370
+ const member = this.nameOf(propertyAccessExpression.name);
386
371
  if (isFoldableError(member)) {
387
372
  return recordEntry(member, node);
388
373
  }
389
- if (expression_1 && this.isFoldable(propertyAccessExpression.expression))
390
- return expression_1[member];
391
- if (schema_1.isMetadataModuleReferenceExpression(expression_1)) {
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: expression_1.module, name: member }, node);
379
+ return recordEntry({ __symbolic: 'reference', module: expression.module, name: member }, node);
395
380
  }
396
- return recordEntry({ __symbolic: 'select', expression: expression_1, member: member }, node);
381
+ return recordEntry({ __symbolic: 'select', expression, member }, node);
397
382
  }
398
383
  case ts.SyntaxKind.ElementAccessExpression: {
399
- var elementAccessExpression = node;
400
- var expression_2 = this.evaluateNode(elementAccessExpression.expression);
401
- if (isFoldableError(expression_2)) {
402
- return recordEntry(expression_2, node);
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
- var index = this.evaluateNode(elementAccessExpression.argumentExpression);
408
- if (isFoldableError(expression_2)) {
409
- return recordEntry(expression_2, node);
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 expression_2[index];
414
- return recordEntry({ __symbolic: 'index', expression: expression_2, index: index }, node);
398
+ return expression[index];
399
+ return recordEntry({ __symbolic: 'index', expression, index }, node);
415
400
  }
416
401
  case ts.SyntaxKind.Identifier:
417
- var identifier = node;
418
- var name = identifier.text;
402
+ const identifier = node;
403
+ const name = identifier.text;
419
404
  return resolveName(name, preferReference);
420
405
  case ts.SyntaxKind.TypeReference:
421
- var typeReferenceNode = node;
422
- var typeNameNode_1 = typeReferenceNode.typeName;
423
- var getReference = function (node) {
424
- if (typeNameNode_1.kind === ts.SyntaxKind.QualifiedName) {
425
- var qualifiedName = node;
426
- var left_1 = _this.evaluateNode(qualifiedName.left);
427
- if (schema_1.isMetadataModuleReferenceExpression(left_1)) {
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: left_1.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: left_1, member: qualifiedName.right.text };
420
+ return { __symbolic: 'select', expression: left, member: qualifiedName.right.text };
436
421
  }
437
422
  else {
438
- var identifier_1 = typeNameNode_1;
439
- var symbol = _this.symbols.resolve(identifier_1.text);
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: identifier_1.text }), node);
428
+ return recordEntry(errorSymbol('Could not resolve type', node, { typeName: identifier.text }), node);
444
429
  }
445
430
  };
446
- var typeReference = getReference(typeNameNode_1);
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
- var args_1 = typeReferenceNode.typeArguments.map(function (element) { return _this.evaluateNode(element); });
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 = args_1;
440
+ typeReference.arguments = args;
456
441
  }
457
442
  return recordEntry(typeReference, node);
458
443
  case ts.SyntaxKind.UnionType:
459
- var unionType = node;
444
+ const unionType = node;
460
445
  // Remove null and undefined from the list of unions.
461
- var references = unionType.types
462
- .filter(function (n) { return n.kind != ts.SyntaxKind.NullKeyword &&
463
- n.kind != ts.SyntaxKind.UndefinedKeyword; })
464
- .map(function (n) { return _this.evaluateNode(n); });
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
- var candidate = null;
468
- for (var i = 0; i < references.length; i++) {
469
- var reference = references[i];
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
- var arrayTypeNode = node;
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
- var parenthesizedExpression = node;
503
+ const parenthesizedExpression = node;
519
504
  return this.evaluateNode(parenthesizedExpression.expression);
520
505
  case ts.SyntaxKind.TypeAssertionExpression:
521
- var typeAssertion = node;
506
+ const typeAssertion = node;
522
507
  return this.evaluateNode(typeAssertion.expression);
523
508
  case ts.SyntaxKind.PrefixUnaryExpression:
524
- var prefixUnaryExpression = node;
525
- var operand = this.evaluateNode(prefixUnaryExpression.operand);
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
- var operatorText = void 0;
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
- var binaryExpression = node;
558
- var left = this.evaluateNode(binaryExpression.left);
559
- var right = this.evaluateNode(binaryExpression.right);
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
- var conditionalExpression = node;
616
- var condition = this.evaluateNode(conditionalExpression.condition);
617
- var thenExpression = this.evaluateNode(conditionalExpression.whenTrue);
618
- var elseExpression = this.evaluateNode(conditionalExpression.whenFalse);
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: condition, thenExpression: thenExpression, elseExpression: elseExpression }, node);
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
- var templateExpression = node;
614
+ const templateExpression = node;
630
615
  if (this.isFoldable(node)) {
631
- return templateExpression.templateSpans.reduce(function (previous, current) { return previous + _this.evaluateNode(current.expression) +
632
- _this.evaluateNode(current.literal); }, this.evaluateNode(templateExpression.head));
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(function (previous, current) {
636
- var expr = _this.evaluateNode(current.expression);
637
- var literal = _this.evaluateNode(current.literal);
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
- var result = expr;
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
- var asExpression = node;
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
- return Evaluator;
665
- }());
648
+ }
649
+ }
666
650
  exports.Evaluator = Evaluator;
667
651
  function isPropertyAssignment(node) {
668
652
  return node.kind == ts.SyntaxKind.PropertyAssignment;
669
653
  }
670
- var empty = ts.createNodeArray();
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}"]}