source: trip-planner-front/node_modules/@angular/compiler-cli/src/metadata/collector.js

Last change on this file was 6a3a178, checked in by Ema <ema_spirova@…>, 3 years ago

initial commit

  • Property mode set to 100644
File size: 117.3 KB
Line 
1/**
2 * @license
3 * Copyright Google LLC All Rights Reserved.
4 *
5 * Use of this source code is governed by an MIT-style license that can be
6 * found in the LICENSE file at https://angular.io/license
7 */
8(function (factory) {
9 if (typeof module === "object" && typeof module.exports === "object") {
10 var v = factory(require, exports);
11 if (v !== undefined) module.exports = v;
12 }
13 else if (typeof define === "function" && define.amd) {
14 define("@angular/compiler-cli/src/metadata/collector", ["require", "exports", "tslib", "typescript", "@angular/compiler-cli/src/metadata/evaluator", "@angular/compiler-cli/src/metadata/schema", "@angular/compiler-cli/src/metadata/symbols"], factory);
15 }
16})(function (require, exports) {
17 "use strict";
18 Object.defineProperty(exports, "__esModule", { value: true });
19 exports.MetadataCollector = void 0;
20 var tslib_1 = require("tslib");
21 var ts = require("typescript");
22 var evaluator_1 = require("@angular/compiler-cli/src/metadata/evaluator");
23 var schema_1 = require("@angular/compiler-cli/src/metadata/schema");
24 var symbols_1 = require("@angular/compiler-cli/src/metadata/symbols");
25 var isStatic = function (node) {
26 return ts.getCombinedModifierFlags(node) & ts.ModifierFlags.Static;
27 };
28 /**
29 * Collect decorator metadata from a TypeScript module.
30 */
31 var MetadataCollector = /** @class */ (function () {
32 function MetadataCollector(options) {
33 if (options === void 0) { options = {}; }
34 this.options = options;
35 }
36 /**
37 * Returns a JSON.stringify friendly form describing the decorators of the exported classes from
38 * the source file that is expected to correspond to a module.
39 */
40 MetadataCollector.prototype.getMetadata = function (sourceFile, strict, substituteExpression) {
41 var _this = this;
42 if (strict === void 0) { strict = false; }
43 var locals = new symbols_1.Symbols(sourceFile);
44 var nodeMap = new Map();
45 var composedSubstituter = substituteExpression && this.options.substituteExpression ?
46 function (value, node) {
47 return _this.options.substituteExpression(substituteExpression(value, node), node);
48 } :
49 substituteExpression;
50 var evaluatorOptions = substituteExpression ? tslib_1.__assign(tslib_1.__assign({}, this.options), { substituteExpression: composedSubstituter }) :
51 this.options;
52 var metadata;
53 var evaluator = new evaluator_1.Evaluator(locals, nodeMap, evaluatorOptions, function (name, value) {
54 if (!metadata)
55 metadata = {};
56 metadata[name] = value;
57 });
58 var exports = undefined;
59 function objFromDecorator(decoratorNode) {
60 return evaluator.evaluateNode(decoratorNode.expression);
61 }
62 function recordEntry(entry, node) {
63 if (composedSubstituter) {
64 entry = composedSubstituter(entry, node);
65 }
66 return evaluator_1.recordMapEntry(entry, node, nodeMap, sourceFile);
67 }
68 function errorSym(message, node, context) {
69 return evaluator_1.errorSymbol(message, node, context, sourceFile);
70 }
71 function maybeGetSimpleFunction(functionDeclaration) {
72 if (functionDeclaration.name && functionDeclaration.name.kind == ts.SyntaxKind.Identifier) {
73 var nameNode = functionDeclaration.name;
74 var functionName = nameNode.text;
75 var functionBody = functionDeclaration.body;
76 if (functionBody && functionBody.statements.length == 1) {
77 var statement = functionBody.statements[0];
78 if (statement.kind === ts.SyntaxKind.ReturnStatement) {
79 var returnStatement = statement;
80 if (returnStatement.expression) {
81 var func = {
82 __symbolic: 'function',
83 parameters: namesOf(functionDeclaration.parameters),
84 value: evaluator.evaluateNode(returnStatement.expression)
85 };
86 if (functionDeclaration.parameters.some(function (p) { return p.initializer != null; })) {
87 func.defaults = functionDeclaration.parameters.map(function (p) { return p.initializer && evaluator.evaluateNode(p.initializer); });
88 }
89 return recordEntry({ func: func, name: functionName }, functionDeclaration);
90 }
91 }
92 }
93 }
94 }
95 function classMetadataOf(classDeclaration) {
96 var e_1, _a, e_2, _b;
97 var result = { __symbolic: 'class' };
98 function getDecorators(decorators) {
99 if (decorators && decorators.length)
100 return decorators.map(function (decorator) { return objFromDecorator(decorator); });
101 return undefined;
102 }
103 function referenceFrom(node) {
104 var result = evaluator.evaluateNode(node);
105 if (schema_1.isMetadataError(result) || schema_1.isMetadataSymbolicReferenceExpression(result) ||
106 schema_1.isMetadataSymbolicSelectExpression(result)) {
107 return result;
108 }
109 else {
110 return errorSym('Symbol reference expected', node);
111 }
112 }
113 // Add class parents
114 if (classDeclaration.heritageClauses) {
115 classDeclaration.heritageClauses.forEach(function (hc) {
116 if (hc.token === ts.SyntaxKind.ExtendsKeyword && hc.types) {
117 hc.types.forEach(function (type) { return result.extends = referenceFrom(type.expression); });
118 }
119 });
120 }
121 // Add arity if the type is generic
122 var typeParameters = classDeclaration.typeParameters;
123 if (typeParameters && typeParameters.length) {
124 result.arity = typeParameters.length;
125 }
126 // Add class decorators
127 if (classDeclaration.decorators) {
128 result.decorators = getDecorators(classDeclaration.decorators);
129 }
130 // member decorators
131 var members = null;
132 function recordMember(name, metadata) {
133 if (!members)
134 members = {};
135 var data = members.hasOwnProperty(name) ? members[name] : [];
136 data.push(metadata);
137 members[name] = data;
138 }
139 // static member
140 var statics = null;
141 function recordStaticMember(name, value) {
142 if (!statics)
143 statics = {};
144 statics[name] = value;
145 }
146 try {
147 for (var _c = tslib_1.__values(classDeclaration.members), _d = _c.next(); !_d.done; _d = _c.next()) {
148 var member = _d.value;
149 var isConstructor = false;
150 switch (member.kind) {
151 case ts.SyntaxKind.Constructor:
152 case ts.SyntaxKind.MethodDeclaration:
153 isConstructor = member.kind === ts.SyntaxKind.Constructor;
154 var method = member;
155 if (isStatic(method)) {
156 var maybeFunc = maybeGetSimpleFunction(method);
157 if (maybeFunc) {
158 recordStaticMember(maybeFunc.name, maybeFunc.func);
159 }
160 continue;
161 }
162 var methodDecorators = getDecorators(method.decorators);
163 var parameters = method.parameters;
164 var parameterDecoratorData = [];
165 var parametersData = [];
166 var hasDecoratorData = false;
167 var hasParameterData = false;
168 try {
169 for (var parameters_1 = (e_2 = void 0, tslib_1.__values(parameters)), parameters_1_1 = parameters_1.next(); !parameters_1_1.done; parameters_1_1 = parameters_1.next()) {
170 var parameter = parameters_1_1.value;
171 var parameterData = getDecorators(parameter.decorators);
172 parameterDecoratorData.push(parameterData);
173 hasDecoratorData = hasDecoratorData || !!parameterData;
174 if (isConstructor) {
175 if (parameter.type) {
176 parametersData.push(referenceFrom(parameter.type));
177 }
178 else {
179 parametersData.push(null);
180 }
181 hasParameterData = true;
182 }
183 }
184 }
185 catch (e_2_1) { e_2 = { error: e_2_1 }; }
186 finally {
187 try {
188 if (parameters_1_1 && !parameters_1_1.done && (_b = parameters_1.return)) _b.call(parameters_1);
189 }
190 finally { if (e_2) throw e_2.error; }
191 }
192 var data = { __symbolic: isConstructor ? 'constructor' : 'method' };
193 var name = isConstructor ? '__ctor__' : evaluator.nameOf(member.name);
194 if (methodDecorators) {
195 data.decorators = methodDecorators;
196 }
197 if (hasDecoratorData) {
198 data.parameterDecorators = parameterDecoratorData;
199 }
200 if (hasParameterData) {
201 data.parameters = parametersData;
202 }
203 if (!schema_1.isMetadataError(name)) {
204 recordMember(name, data);
205 }
206 break;
207 case ts.SyntaxKind.PropertyDeclaration:
208 case ts.SyntaxKind.GetAccessor:
209 case ts.SyntaxKind.SetAccessor:
210 var property = member;
211 if (isStatic(property)) {
212 var name_1 = evaluator.nameOf(property.name);
213 if (!schema_1.isMetadataError(name_1) && !shouldIgnoreStaticMember(name_1)) {
214 if (property.initializer) {
215 var value = evaluator.evaluateNode(property.initializer);
216 recordStaticMember(name_1, value);
217 }
218 else {
219 recordStaticMember(name_1, errorSym('Variable not initialized', property.name));
220 }
221 }
222 }
223 var propertyDecorators = getDecorators(property.decorators);
224 if (propertyDecorators) {
225 var name_2 = evaluator.nameOf(property.name);
226 if (!schema_1.isMetadataError(name_2)) {
227 recordMember(name_2, { __symbolic: 'property', decorators: propertyDecorators });
228 }
229 }
230 break;
231 }
232 }
233 }
234 catch (e_1_1) { e_1 = { error: e_1_1 }; }
235 finally {
236 try {
237 if (_d && !_d.done && (_a = _c.return)) _a.call(_c);
238 }
239 finally { if (e_1) throw e_1.error; }
240 }
241 if (members) {
242 result.members = members;
243 }
244 if (statics) {
245 result.statics = statics;
246 }
247 return recordEntry(result, classDeclaration);
248 }
249 // Collect all exported symbols from an exports clause.
250 var exportMap = new Map();
251 ts.forEachChild(sourceFile, function (node) {
252 switch (node.kind) {
253 case ts.SyntaxKind.ExportDeclaration:
254 var exportDeclaration = node;
255 var moduleSpecifier = exportDeclaration.moduleSpecifier, exportClause = exportDeclaration.exportClause;
256 if (!moduleSpecifier && exportClause && ts.isNamedExports(exportClause)) {
257 // If there is a module specifier there is also an exportClause
258 exportClause.elements.forEach(function (spec) {
259 var exportedAs = spec.name.text;
260 var name = (spec.propertyName || spec.name).text;
261 exportMap.set(name, exportedAs);
262 });
263 }
264 }
265 });
266 var isExport = function (node) { return sourceFile.isDeclarationFile ||
267 ts.getCombinedModifierFlags(node) & ts.ModifierFlags.Export; };
268 var isExportedIdentifier = function (identifier) {
269 return identifier && exportMap.has(identifier.text);
270 };
271 var isExported = function (node) {
272 return isExport(node) || isExportedIdentifier(node.name);
273 };
274 var exportedIdentifierName = function (identifier) {
275 return identifier && (exportMap.get(identifier.text) || identifier.text);
276 };
277 var exportedName = function (node) {
278 return exportedIdentifierName(node.name);
279 };
280 // Pre-declare classes and functions
281 ts.forEachChild(sourceFile, function (node) {
282 switch (node.kind) {
283 case ts.SyntaxKind.ClassDeclaration:
284 var classDeclaration = node;
285 if (classDeclaration.name) {
286 var className = classDeclaration.name.text;
287 if (isExported(classDeclaration)) {
288 locals.define(className, { __symbolic: 'reference', name: exportedName(classDeclaration) });
289 }
290 else {
291 locals.define(className, errorSym('Reference to non-exported class', node, { className: className }));
292 }
293 }
294 break;
295 case ts.SyntaxKind.InterfaceDeclaration:
296 var interfaceDeclaration = node;
297 if (interfaceDeclaration.name) {
298 var interfaceName = interfaceDeclaration.name.text;
299 // All references to interfaces should be converted to references to `any`.
300 locals.define(interfaceName, { __symbolic: 'reference', name: 'any' });
301 }
302 break;
303 case ts.SyntaxKind.FunctionDeclaration:
304 var functionDeclaration = node;
305 if (!isExported(functionDeclaration)) {
306 // Report references to this function as an error.
307 var nameNode = functionDeclaration.name;
308 if (nameNode && nameNode.text) {
309 locals.define(nameNode.text, errorSym('Reference to a non-exported function', nameNode, { name: nameNode.text }));
310 }
311 }
312 break;
313 }
314 });
315 ts.forEachChild(sourceFile, function (node) {
316 var e_3, _a, e_4, _b;
317 switch (node.kind) {
318 case ts.SyntaxKind.ExportDeclaration:
319 // Record export declarations
320 var exportDeclaration = node;
321 var moduleSpecifier = exportDeclaration.moduleSpecifier, exportClause = exportDeclaration.exportClause;
322 if (!moduleSpecifier) {
323 // no module specifier -> export {propName as name};
324 if (exportClause && ts.isNamedExports(exportClause)) {
325 exportClause.elements.forEach(function (spec) {
326 var name = spec.name.text;
327 // If the symbol was not already exported, export a reference since it is a
328 // reference to an import
329 if (!metadata || !metadata[name]) {
330 var propNode = spec.propertyName || spec.name;
331 var value = evaluator.evaluateNode(propNode);
332 if (!metadata)
333 metadata = {};
334 metadata[name] = recordEntry(value, node);
335 }
336 });
337 }
338 }
339 if (moduleSpecifier && moduleSpecifier.kind == ts.SyntaxKind.StringLiteral) {
340 // Ignore exports that don't have string literals as exports.
341 // This is allowed by the syntax but will be flagged as an error by the type checker.
342 var from = moduleSpecifier.text;
343 var moduleExport = { from: from };
344 if (exportClause && ts.isNamedExports(exportClause)) {
345 moduleExport.export = exportClause.elements.map(function (spec) { return spec.propertyName ? { name: spec.propertyName.text, as: spec.name.text } :
346 spec.name.text; });
347 }
348 if (!exports)
349 exports = [];
350 exports.push(moduleExport);
351 }
352 break;
353 case ts.SyntaxKind.ClassDeclaration:
354 var classDeclaration = node;
355 if (classDeclaration.name) {
356 if (isExported(classDeclaration)) {
357 var name = exportedName(classDeclaration);
358 if (name) {
359 if (!metadata)
360 metadata = {};
361 metadata[name] = classMetadataOf(classDeclaration);
362 }
363 }
364 }
365 // Otherwise don't record metadata for the class.
366 break;
367 case ts.SyntaxKind.TypeAliasDeclaration:
368 var typeDeclaration = node;
369 if (typeDeclaration.name && isExported(typeDeclaration)) {
370 var name = exportedName(typeDeclaration);
371 if (name) {
372 if (!metadata)
373 metadata = {};
374 metadata[name] = { __symbolic: 'interface' };
375 }
376 }
377 break;
378 case ts.SyntaxKind.InterfaceDeclaration:
379 var interfaceDeclaration = node;
380 if (interfaceDeclaration.name && isExported(interfaceDeclaration)) {
381 var name = exportedName(interfaceDeclaration);
382 if (name) {
383 if (!metadata)
384 metadata = {};
385 metadata[name] = { __symbolic: 'interface' };
386 }
387 }
388 break;
389 case ts.SyntaxKind.FunctionDeclaration:
390 // Record functions that return a single value. Record the parameter
391 // names substitution will be performed by the StaticReflector.
392 var functionDeclaration = node;
393 if (isExported(functionDeclaration) && functionDeclaration.name) {
394 var name = exportedName(functionDeclaration);
395 var maybeFunc = maybeGetSimpleFunction(functionDeclaration);
396 if (name) {
397 if (!metadata)
398 metadata = {};
399 // TODO(alxhub): The literal here is not valid FunctionMetadata.
400 metadata[name] =
401 maybeFunc ? recordEntry(maybeFunc.func, node) : { __symbolic: 'function' };
402 }
403 }
404 break;
405 case ts.SyntaxKind.EnumDeclaration:
406 var enumDeclaration = node;
407 if (isExported(enumDeclaration)) {
408 var enumValueHolder = {};
409 var enumName = exportedName(enumDeclaration);
410 var nextDefaultValue = 0;
411 var writtenMembers = 0;
412 try {
413 for (var _c = tslib_1.__values(enumDeclaration.members), _d = _c.next(); !_d.done; _d = _c.next()) {
414 var member = _d.value;
415 var enumValue = void 0;
416 if (!member.initializer) {
417 enumValue = nextDefaultValue;
418 }
419 else {
420 enumValue = evaluator.evaluateNode(member.initializer);
421 }
422 var name = undefined;
423 if (member.name.kind == ts.SyntaxKind.Identifier) {
424 var identifier = member.name;
425 name = identifier.text;
426 enumValueHolder[name] = enumValue;
427 writtenMembers++;
428 }
429 if (typeof enumValue === 'number') {
430 nextDefaultValue = enumValue + 1;
431 }
432 else if (name) {
433 // TODO(alxhub): 'left' here has a name propery which is not valid for
434 // MetadataSymbolicSelectExpression.
435 nextDefaultValue = {
436 __symbolic: 'binary',
437 operator: '+',
438 left: {
439 __symbolic: 'select',
440 expression: recordEntry({ __symbolic: 'reference', name: enumName }, node),
441 name: name
442 },
443 };
444 }
445 else {
446 nextDefaultValue =
447 recordEntry(errorSym('Unsupported enum member name', member.name), node);
448 }
449 }
450 }
451 catch (e_3_1) { e_3 = { error: e_3_1 }; }
452 finally {
453 try {
454 if (_d && !_d.done && (_a = _c.return)) _a.call(_c);
455 }
456 finally { if (e_3) throw e_3.error; }
457 }
458 if (writtenMembers) {
459 if (enumName) {
460 if (!metadata)
461 metadata = {};
462 metadata[enumName] = recordEntry(enumValueHolder, node);
463 }
464 }
465 }
466 break;
467 case ts.SyntaxKind.VariableStatement:
468 var variableStatement = node;
469 var _loop_1 = function (variableDeclaration) {
470 if (variableDeclaration.name.kind == ts.SyntaxKind.Identifier) {
471 var nameNode = variableDeclaration.name;
472 var varValue = void 0;
473 if (variableDeclaration.initializer) {
474 varValue = evaluator.evaluateNode(variableDeclaration.initializer);
475 }
476 else {
477 varValue = recordEntry(errorSym('Variable not initialized', nameNode), nameNode);
478 }
479 var exported = false;
480 if (isExport(variableStatement) || isExport(variableDeclaration) ||
481 isExportedIdentifier(nameNode)) {
482 var name = exportedIdentifierName(nameNode);
483 if (name) {
484 if (!metadata)
485 metadata = {};
486 metadata[name] = recordEntry(varValue, node);
487 }
488 exported = true;
489 }
490 if (typeof varValue == 'string' || typeof varValue == 'number' ||
491 typeof varValue == 'boolean') {
492 locals.define(nameNode.text, varValue);
493 if (exported) {
494 locals.defineReference(nameNode.text, { __symbolic: 'reference', name: nameNode.text });
495 }
496 }
497 else if (!exported) {
498 if (varValue && !schema_1.isMetadataError(varValue)) {
499 locals.define(nameNode.text, recordEntry(varValue, node));
500 }
501 else {
502 locals.define(nameNode.text, recordEntry(errorSym('Reference to a local symbol', nameNode, { name: nameNode.text }), node));
503 }
504 }
505 }
506 else {
507 // Destructuring (or binding) declarations are not supported,
508 // var {<identifier>[, <identifier>]+} = <expression>;
509 // or
510 // var [<identifier>[, <identifier}+] = <expression>;
511 // are not supported.
512 var report_1 = function (nameNode) {
513 switch (nameNode.kind) {
514 case ts.SyntaxKind.Identifier:
515 var name = nameNode;
516 var varValue = errorSym('Destructuring not supported', name);
517 locals.define(name.text, varValue);
518 if (isExport(node)) {
519 if (!metadata)
520 metadata = {};
521 metadata[name.text] = varValue;
522 }
523 break;
524 case ts.SyntaxKind.BindingElement:
525 var bindingElement = nameNode;
526 report_1(bindingElement.name);
527 break;
528 case ts.SyntaxKind.ObjectBindingPattern:
529 case ts.SyntaxKind.ArrayBindingPattern:
530 var bindings = nameNode;
531 bindings.elements.forEach(report_1);
532 break;
533 }
534 };
535 report_1(variableDeclaration.name);
536 }
537 };
538 try {
539 for (var _e = tslib_1.__values(variableStatement.declarationList.declarations), _f = _e.next(); !_f.done; _f = _e.next()) {
540 var variableDeclaration = _f.value;
541 _loop_1(variableDeclaration);
542 }
543 }
544 catch (e_4_1) { e_4 = { error: e_4_1 }; }
545 finally {
546 try {
547 if (_f && !_f.done && (_b = _e.return)) _b.call(_e);
548 }
549 finally { if (e_4) throw e_4.error; }
550 }
551 break;
552 }
553 });
554 if (metadata || exports) {
555 if (!metadata)
556 metadata = {};
557 else if (strict) {
558 validateMetadata(sourceFile, nodeMap, metadata);
559 }
560 var result = {
561 __symbolic: 'module',
562 version: this.options.version || schema_1.METADATA_VERSION,
563 metadata: metadata
564 };
565 if (sourceFile.moduleName)
566 result.importAs = sourceFile.moduleName;
567 if (exports)
568 result.exports = exports;
569 return result;
570 }
571 };
572 return MetadataCollector;
573 }());
574 exports.MetadataCollector = MetadataCollector;
575 // This will throw if the metadata entry given contains an error node.
576 function validateMetadata(sourceFile, nodeMap, metadata) {
577 var locals = new Set(['Array', 'Object', 'Set', 'Map', 'string', 'number', 'any']);
578 function validateExpression(expression) {
579 if (!expression) {
580 return;
581 }
582 else if (Array.isArray(expression)) {
583 expression.forEach(validateExpression);
584 }
585 else if (typeof expression === 'object' && !expression.hasOwnProperty('__symbolic')) {
586 Object.getOwnPropertyNames(expression).forEach(function (v) { return validateExpression(expression[v]); });
587 }
588 else if (schema_1.isMetadataError(expression)) {
589 reportError(expression);
590 }
591 else if (schema_1.isMetadataGlobalReferenceExpression(expression)) {
592 if (!locals.has(expression.name)) {
593 var reference = metadata[expression.name];
594 if (reference) {
595 validateExpression(reference);
596 }
597 }
598 }
599 else if (schema_1.isFunctionMetadata(expression)) {
600 validateFunction(expression);
601 }
602 else if (schema_1.isMetadataSymbolicExpression(expression)) {
603 switch (expression.__symbolic) {
604 case 'binary':
605 var binaryExpression = expression;
606 validateExpression(binaryExpression.left);
607 validateExpression(binaryExpression.right);
608 break;
609 case 'call':
610 case 'new':
611 var callExpression = expression;
612 validateExpression(callExpression.expression);
613 if (callExpression.arguments)
614 callExpression.arguments.forEach(validateExpression);
615 break;
616 case 'index':
617 var indexExpression = expression;
618 validateExpression(indexExpression.expression);
619 validateExpression(indexExpression.index);
620 break;
621 case 'pre':
622 var prefixExpression = expression;
623 validateExpression(prefixExpression.operand);
624 break;
625 case 'select':
626 var selectExpression = expression;
627 validateExpression(selectExpression.expression);
628 break;
629 case 'spread':
630 var spreadExpression = expression;
631 validateExpression(spreadExpression.expression);
632 break;
633 case 'if':
634 var ifExpression = expression;
635 validateExpression(ifExpression.condition);
636 validateExpression(ifExpression.elseExpression);
637 validateExpression(ifExpression.thenExpression);
638 break;
639 }
640 }
641 }
642 function validateMember(classData, member) {
643 if (member.decorators) {
644 member.decorators.forEach(validateExpression);
645 }
646 if (schema_1.isMethodMetadata(member) && member.parameterDecorators) {
647 member.parameterDecorators.forEach(validateExpression);
648 }
649 // Only validate parameters of classes for which we know that are used with our DI
650 if (classData.decorators && schema_1.isConstructorMetadata(member) && member.parameters) {
651 member.parameters.forEach(validateExpression);
652 }
653 }
654 function validateClass(classData) {
655 if (classData.decorators) {
656 classData.decorators.forEach(validateExpression);
657 }
658 if (classData.members) {
659 Object.getOwnPropertyNames(classData.members)
660 .forEach(function (name) { return classData.members[name].forEach(function (m) { return validateMember(classData, m); }); });
661 }
662 if (classData.statics) {
663 Object.getOwnPropertyNames(classData.statics).forEach(function (name) {
664 var staticMember = classData.statics[name];
665 if (schema_1.isFunctionMetadata(staticMember)) {
666 validateExpression(staticMember.value);
667 }
668 else {
669 validateExpression(staticMember);
670 }
671 });
672 }
673 }
674 function validateFunction(functionDeclaration) {
675 if (functionDeclaration.value) {
676 var oldLocals = locals;
677 if (functionDeclaration.parameters) {
678 locals = new Set(oldLocals.values());
679 if (functionDeclaration.parameters)
680 functionDeclaration.parameters.forEach(function (n) { return locals.add(n); });
681 }
682 validateExpression(functionDeclaration.value);
683 locals = oldLocals;
684 }
685 }
686 function shouldReportNode(node) {
687 if (node) {
688 var nodeStart = node.getStart();
689 return !(node.pos != nodeStart &&
690 sourceFile.text.substring(node.pos, nodeStart).indexOf('@dynamic') >= 0);
691 }
692 return true;
693 }
694 function reportError(error) {
695 var node = nodeMap.get(error);
696 if (shouldReportNode(node)) {
697 var lineInfo = error.line != undefined ? error.character != undefined ?
698 ":" + (error.line + 1) + ":" + (error.character + 1) :
699 ":" + (error.line + 1) :
700 '';
701 throw new Error("" + sourceFile.fileName + lineInfo + ": Metadata collected contains an error that will be reported at runtime: " + expandedMessage(error) + ".\n " + JSON.stringify(error));
702 }
703 }
704 Object.getOwnPropertyNames(metadata).forEach(function (name) {
705 var entry = metadata[name];
706 try {
707 if (schema_1.isClassMetadata(entry)) {
708 validateClass(entry);
709 }
710 }
711 catch (e) {
712 var node = nodeMap.get(entry);
713 if (shouldReportNode(node)) {
714 if (node) {
715 var _a = sourceFile.getLineAndCharacterOfPosition(node.getStart()), line = _a.line, character = _a.character;
716 throw new Error(sourceFile.fileName + ":" + (line + 1) + ":" + (character + 1) + ": Error encountered in metadata generated for exported symbol '" + name + "': \n " + e.message);
717 }
718 throw new Error("Error encountered in metadata generated for exported symbol " + name + ": \n " + e.message);
719 }
720 }
721 });
722 }
723 // Collect parameter names from a function.
724 function namesOf(parameters) {
725 var e_5, _a;
726 var result = [];
727 function addNamesOf(name) {
728 var e_6, _a;
729 if (name.kind == ts.SyntaxKind.Identifier) {
730 var identifier = name;
731 result.push(identifier.text);
732 }
733 else {
734 var bindingPattern = name;
735 try {
736 for (var _b = tslib_1.__values(bindingPattern.elements), _c = _b.next(); !_c.done; _c = _b.next()) {
737 var element = _c.value;
738 var name_3 = element.name;
739 if (name_3) {
740 addNamesOf(name_3);
741 }
742 }
743 }
744 catch (e_6_1) { e_6 = { error: e_6_1 }; }
745 finally {
746 try {
747 if (_c && !_c.done && (_a = _b.return)) _a.call(_b);
748 }
749 finally { if (e_6) throw e_6.error; }
750 }
751 }
752 }
753 try {
754 for (var parameters_2 = tslib_1.__values(parameters), parameters_2_1 = parameters_2.next(); !parameters_2_1.done; parameters_2_1 = parameters_2.next()) {
755 var parameter = parameters_2_1.value;
756 addNamesOf(parameter.name);
757 }
758 }
759 catch (e_5_1) { e_5 = { error: e_5_1 }; }
760 finally {
761 try {
762 if (parameters_2_1 && !parameters_2_1.done && (_a = parameters_2.return)) _a.call(parameters_2);
763 }
764 finally { if (e_5) throw e_5.error; }
765 }
766 return result;
767 }
768 function shouldIgnoreStaticMember(memberName) {
769 return memberName.startsWith('ngAcceptInputType_') || memberName.startsWith('ngTemplateGuard_');
770 }
771 function expandedMessage(error) {
772 switch (error.message) {
773 case 'Reference to non-exported class':
774 if (error.context && error.context.className) {
775 return "Reference to a non-exported class " + error.context.className + ". Consider exporting the class";
776 }
777 break;
778 case 'Variable not initialized':
779 return 'Only initialized variables and constants can be referenced because the value of this variable is needed by the template compiler';
780 case 'Destructuring not supported':
781 return 'Referencing an exported destructured variable or constant is not supported by the template compiler. Consider simplifying this to avoid destructuring';
782 case 'Could not resolve type':
783 if (error.context && error.context.typeName) {
784 return "Could not resolve type " + error.context.typeName;
785 }
786 break;
787 case 'Function call not supported':
788 var prefix = error.context && error.context.name ? "Calling function '" + error.context.name + "', f" : 'F';
789 return prefix +
790 'unction calls are not supported. Consider replacing the function or lambda with a reference to an exported function';
791 case 'Reference to a local symbol':
792 if (error.context && error.context.name) {
793 return "Reference to a local (non-exported) symbol '" + error.context.name + "'. Consider exporting the symbol";
794 }
795 }
796 return error.message;
797 }
798});
799//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"collector.js","sourceRoot":"","sources":["../../../../../../../packages/compiler-cli/src/metadata/collector.ts"],"names":[],"mappings":"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","sourcesContent":["/**\n * @license\n * Copyright Google LLC All Rights Reserved.\n *\n * Use of this source code is governed by an MIT-style license that can be\n * found in the LICENSE file at https://angular.io/license\n */\n\nimport * as ts from 'typescript';\n\nimport {errorSymbol, Evaluator, recordMapEntry} from './evaluator';\nimport {ClassMetadata, ConstructorMetadata, FunctionMetadata, InterfaceMetadata, isClassMetadata, isConstructorMetadata, isFunctionMetadata, isMetadataError, isMetadataGlobalReferenceExpression, isMetadataImportDefaultReference, isMetadataImportedSymbolReferenceExpression, isMetadataSymbolicExpression, isMetadataSymbolicReferenceExpression, isMetadataSymbolicSelectExpression, isMethodMetadata, MemberMetadata, METADATA_VERSION, MetadataEntry, MetadataError, MetadataMap, MetadataSymbolicBinaryExpression, MetadataSymbolicCallExpression, MetadataSymbolicExpression, MetadataSymbolicIfExpression, MetadataSymbolicIndexExpression, MetadataSymbolicPrefixExpression, MetadataSymbolicReferenceExpression, MetadataSymbolicSelectExpression, MetadataSymbolicSpreadExpression, MetadataValue, MethodMetadata, ModuleExportMetadata, ModuleMetadata} from './schema';\nimport {Symbols} from './symbols';\n\nconst isStatic = (node: ts.Declaration) =>\n    ts.getCombinedModifierFlags(node) & ts.ModifierFlags.Static;\n\n/**\n * A set of collector options to use when collecting metadata.\n */\nexport interface CollectorOptions {\n  /**\n   * Version of the metadata to collect.\n   */\n  version?: number;\n\n  /**\n   * Collect a hidden field \"$quoted$\" in objects literals that record when the key was quoted in\n   * the source.\n   */\n  quotedNames?: boolean;\n\n  /**\n   * Do not simplify invalid expressions.\n   */\n  verboseInvalidExpression?: boolean;\n\n  /**\n   * An expression substitution callback.\n   */\n  substituteExpression?: (value: MetadataValue, node: ts.Node) => MetadataValue;\n}\n\n/**\n * Collect decorator metadata from a TypeScript module.\n */\nexport class MetadataCollector {\n  constructor(private options: CollectorOptions = {}) {}\n\n  /**\n   * Returns a JSON.stringify friendly form describing the decorators of the exported classes from\n   * the source file that is expected to correspond to a module.\n   */\n  public getMetadata(\n      sourceFile: ts.SourceFile, strict: boolean = false,\n      substituteExpression?: (value: MetadataValue, node: ts.Node) => MetadataValue): ModuleMetadata\n      |undefined {\n    const locals = new Symbols(sourceFile);\n    const nodeMap =\n        new Map<MetadataValue|ClassMetadata|InterfaceMetadata|FunctionMetadata, ts.Node>();\n    const composedSubstituter = substituteExpression && this.options.substituteExpression ?\n        (value: MetadataValue, node: ts.Node) =>\n            this.options.substituteExpression!(substituteExpression(value, node), node) :\n        substituteExpression;\n    const evaluatorOptions = substituteExpression ?\n        {...this.options, substituteExpression: composedSubstituter} :\n        this.options;\n    let metadata: {[name: string]: MetadataValue|ClassMetadata|FunctionMetadata}|undefined;\n    const evaluator = new Evaluator(locals, nodeMap, evaluatorOptions, (name, value) => {\n      if (!metadata) metadata = {};\n      metadata[name] = value;\n    });\n    let exports: ModuleExportMetadata[]|undefined = undefined;\n\n    function objFromDecorator(decoratorNode: ts.Decorator): MetadataSymbolicExpression {\n      return <MetadataSymbolicExpression>evaluator.evaluateNode(decoratorNode.expression);\n    }\n\n    function recordEntry<T extends MetadataEntry>(entry: T, node: ts.Node): T {\n      if (composedSubstituter) {\n        entry = composedSubstituter(entry as MetadataValue, node) as T;\n      }\n      return recordMapEntry(entry, node, nodeMap, sourceFile);\n    }\n\n    function errorSym(\n        message: string, node?: ts.Node, context?: {[name: string]: string}): MetadataError {\n      return errorSymbol(message, node, context, sourceFile);\n    }\n\n    function maybeGetSimpleFunction(functionDeclaration: ts.FunctionDeclaration|\n                                    ts.MethodDeclaration): {func: FunctionMetadata, name: string}|\n        undefined {\n      if (functionDeclaration.name && functionDeclaration.name.kind == ts.SyntaxKind.Identifier) {\n        const nameNode = <ts.Identifier>functionDeclaration.name;\n        const functionName = nameNode.text;\n        const functionBody = functionDeclaration.body;\n        if (functionBody && functionBody.statements.length == 1) {\n          const statement = functionBody.statements[0];\n          if (statement.kind === ts.SyntaxKind.ReturnStatement) {\n            const returnStatement = <ts.ReturnStatement>statement;\n            if (returnStatement.expression) {\n              const func: FunctionMetadata = {\n                __symbolic: 'function',\n                parameters: namesOf(functionDeclaration.parameters),\n                value: evaluator.evaluateNode(returnStatement.expression)\n              };\n              if (functionDeclaration.parameters.some(p => p.initializer != null)) {\n                func.defaults = functionDeclaration.parameters.map(\n                    p => p.initializer && evaluator.evaluateNode(p.initializer));\n              }\n              return recordEntry({func, name: functionName}, functionDeclaration);\n            }\n          }\n        }\n      }\n    }\n\n    function classMetadataOf(classDeclaration: ts.ClassDeclaration): ClassMetadata {\n      const result: ClassMetadata = {__symbolic: 'class'};\n\n      function getDecorators(decorators: ReadonlyArray<ts.Decorator>|\n                             undefined): MetadataSymbolicExpression[]|undefined {\n        if (decorators && decorators.length)\n          return decorators.map(decorator => objFromDecorator(decorator));\n        return undefined;\n      }\n\n      function referenceFrom(node: ts.Node): MetadataSymbolicReferenceExpression|MetadataError|\n          MetadataSymbolicSelectExpression {\n        const result = evaluator.evaluateNode(node);\n        if (isMetadataError(result) || isMetadataSymbolicReferenceExpression(result) ||\n            isMetadataSymbolicSelectExpression(result)) {\n          return result;\n        } else {\n          return errorSym('Symbol reference expected', node);\n        }\n      }\n\n      // Add class parents\n      if (classDeclaration.heritageClauses) {\n        classDeclaration.heritageClauses.forEach((hc) => {\n          if (hc.token === ts.SyntaxKind.ExtendsKeyword && hc.types) {\n            hc.types.forEach(type => result.extends = referenceFrom(type.expression));\n          }\n        });\n      }\n\n      // Add arity if the type is generic\n      const typeParameters = classDeclaration.typeParameters;\n      if (typeParameters && typeParameters.length) {\n        result.arity = typeParameters.length;\n      }\n\n      // Add class decorators\n      if (classDeclaration.decorators) {\n        result.decorators = getDecorators(classDeclaration.decorators);\n      }\n\n      // member decorators\n      let members: MetadataMap|null = null;\n      function recordMember(name: string, metadata: MemberMetadata) {\n        if (!members) members = {};\n        const data = members.hasOwnProperty(name) ? members[name] : [];\n        data.push(metadata);\n        members[name] = data;\n      }\n\n      // static member\n      let statics: {[name: string]: MetadataValue|FunctionMetadata}|null = null;\n      function recordStaticMember(name: string, value: MetadataValue|FunctionMetadata) {\n        if (!statics) statics = {};\n        statics[name] = value;\n      }\n\n      for (const member of classDeclaration.members) {\n        let isConstructor = false;\n        switch (member.kind) {\n          case ts.SyntaxKind.Constructor:\n          case ts.SyntaxKind.MethodDeclaration:\n            isConstructor = member.kind === ts.SyntaxKind.Constructor;\n            const method = <ts.MethodDeclaration|ts.ConstructorDeclaration>member;\n            if (isStatic(method)) {\n              const maybeFunc = maybeGetSimpleFunction(<ts.MethodDeclaration>method);\n              if (maybeFunc) {\n                recordStaticMember(maybeFunc.name, maybeFunc.func);\n              }\n              continue;\n            }\n            const methodDecorators = getDecorators(method.decorators);\n            const parameters = method.parameters;\n            const parameterDecoratorData: ((MetadataSymbolicExpression | MetadataError)[]|\n                                           undefined)[] = [];\n            const parametersData: (MetadataSymbolicReferenceExpression|MetadataError|\n                                   MetadataSymbolicSelectExpression|null)[] = [];\n            let hasDecoratorData: boolean = false;\n            let hasParameterData: boolean = false;\n            for (const parameter of parameters) {\n              const parameterData = getDecorators(parameter.decorators);\n              parameterDecoratorData.push(parameterData);\n              hasDecoratorData = hasDecoratorData || !!parameterData;\n              if (isConstructor) {\n                if (parameter.type) {\n                  parametersData.push(referenceFrom(parameter.type));\n                } else {\n                  parametersData.push(null);\n                }\n                hasParameterData = true;\n              }\n            }\n            const data: MethodMetadata = {__symbolic: isConstructor ? 'constructor' : 'method'};\n            const name = isConstructor ? '__ctor__' : evaluator.nameOf(member.name);\n            if (methodDecorators) {\n              data.decorators = methodDecorators;\n            }\n            if (hasDecoratorData) {\n              data.parameterDecorators = parameterDecoratorData;\n            }\n            if (hasParameterData) {\n              (<ConstructorMetadata>data).parameters = parametersData;\n            }\n            if (!isMetadataError(name)) {\n              recordMember(name, data);\n            }\n            break;\n          case ts.SyntaxKind.PropertyDeclaration:\n          case ts.SyntaxKind.GetAccessor:\n          case ts.SyntaxKind.SetAccessor:\n            const property = <ts.PropertyDeclaration>member;\n            if (isStatic(property)) {\n              const name = evaluator.nameOf(property.name);\n              if (!isMetadataError(name) && !shouldIgnoreStaticMember(name)) {\n                if (property.initializer) {\n                  const value = evaluator.evaluateNode(property.initializer);\n                  recordStaticMember(name, value);\n                } else {\n                  recordStaticMember(name, errorSym('Variable not initialized', property.name));\n                }\n              }\n            }\n            const propertyDecorators = getDecorators(property.decorators);\n            if (propertyDecorators) {\n              const name = evaluator.nameOf(property.name);\n              if (!isMetadataError(name)) {\n                recordMember(name, {__symbolic: 'property', decorators: propertyDecorators});\n              }\n            }\n            break;\n        }\n      }\n      if (members) {\n        result.members = members;\n      }\n      if (statics) {\n        result.statics = statics;\n      }\n\n      return recordEntry(result, classDeclaration);\n    }\n\n    // Collect all exported symbols from an exports clause.\n    const exportMap = new Map<string, string>();\n    ts.forEachChild(sourceFile, node => {\n      switch (node.kind) {\n        case ts.SyntaxKind.ExportDeclaration:\n          const exportDeclaration = <ts.ExportDeclaration>node;\n          const {moduleSpecifier, exportClause} = exportDeclaration;\n\n          if (!moduleSpecifier && exportClause && ts.isNamedExports(exportClause)) {\n            // If there is a module specifier there is also an exportClause\n            exportClause.elements.forEach(spec => {\n              const exportedAs = spec.name.text;\n              const name = (spec.propertyName || spec.name).text;\n              exportMap.set(name, exportedAs);\n            });\n          }\n      }\n    });\n\n    const isExport = (node: ts.Node) => sourceFile.isDeclarationFile ||\n        ts.getCombinedModifierFlags(node as ts.Declaration) & ts.ModifierFlags.Export;\n    const isExportedIdentifier = (identifier?: ts.Identifier) =>\n        identifier && exportMap.has(identifier.text);\n    const isExported = (node: ts.FunctionDeclaration|ts.ClassDeclaration|ts.TypeAliasDeclaration|\n                        ts.InterfaceDeclaration|ts.EnumDeclaration) =>\n        isExport(node) || isExportedIdentifier(node.name);\n    const exportedIdentifierName = (identifier?: ts.Identifier) =>\n        identifier && (exportMap.get(identifier.text) || identifier.text);\n    const exportedName = (node: ts.FunctionDeclaration|ts.ClassDeclaration|\n                          ts.InterfaceDeclaration|ts.TypeAliasDeclaration|ts.EnumDeclaration) =>\n        exportedIdentifierName(node.name);\n\n\n    // Pre-declare classes and functions\n    ts.forEachChild(sourceFile, node => {\n      switch (node.kind) {\n        case ts.SyntaxKind.ClassDeclaration:\n          const classDeclaration = <ts.ClassDeclaration>node;\n          if (classDeclaration.name) {\n            const className = classDeclaration.name.text;\n            if (isExported(classDeclaration)) {\n              locals.define(\n                  className, {__symbolic: 'reference', name: exportedName(classDeclaration)});\n            } else {\n              locals.define(\n                  className, errorSym('Reference to non-exported class', node, {className}));\n            }\n          }\n          break;\n\n        case ts.SyntaxKind.InterfaceDeclaration:\n          const interfaceDeclaration = <ts.InterfaceDeclaration>node;\n          if (interfaceDeclaration.name) {\n            const interfaceName = interfaceDeclaration.name.text;\n            // All references to interfaces should be converted to references to `any`.\n            locals.define(interfaceName, {__symbolic: 'reference', name: 'any'});\n          }\n          break;\n\n        case ts.SyntaxKind.FunctionDeclaration:\n          const functionDeclaration = <ts.FunctionDeclaration>node;\n          if (!isExported(functionDeclaration)) {\n            // Report references to this function as an error.\n            const nameNode = functionDeclaration.name;\n            if (nameNode && nameNode.text) {\n              locals.define(\n                  nameNode.text,\n                  errorSym(\n                      'Reference to a non-exported function', nameNode, {name: nameNode.text}));\n            }\n          }\n          break;\n      }\n    });\n\n    ts.forEachChild(sourceFile, node => {\n      switch (node.kind) {\n        case ts.SyntaxKind.ExportDeclaration:\n          // Record export declarations\n          const exportDeclaration = <ts.ExportDeclaration>node;\n          const {moduleSpecifier, exportClause} = exportDeclaration;\n\n          if (!moduleSpecifier) {\n            // no module specifier -> export {propName as name};\n            if (exportClause && ts.isNamedExports(exportClause)) {\n              exportClause.elements.forEach(spec => {\n                const name = spec.name.text;\n                // If the symbol was not already exported, export a reference since it is a\n                // reference to an import\n                if (!metadata || !metadata[name]) {\n                  const propNode = spec.propertyName || spec.name;\n                  const value: MetadataValue = evaluator.evaluateNode(propNode);\n                  if (!metadata) metadata = {};\n                  metadata[name] = recordEntry(value, node);\n                }\n              });\n            }\n          }\n\n          if (moduleSpecifier && moduleSpecifier.kind == ts.SyntaxKind.StringLiteral) {\n            // Ignore exports that don't have string literals as exports.\n            // This is allowed by the syntax but will be flagged as an error by the type checker.\n            const from = (<ts.StringLiteral>moduleSpecifier).text;\n            const moduleExport: ModuleExportMetadata = {from};\n            if (exportClause && ts.isNamedExports(exportClause)) {\n              moduleExport.export = exportClause.elements.map(\n                  spec => spec.propertyName ? {name: spec.propertyName.text, as: spec.name.text} :\n                                              spec.name.text);\n            }\n            if (!exports) exports = [];\n            exports.push(moduleExport);\n          }\n          break;\n        case ts.SyntaxKind.ClassDeclaration:\n          const classDeclaration = <ts.ClassDeclaration>node;\n          if (classDeclaration.name) {\n            if (isExported(classDeclaration)) {\n              const name = exportedName(classDeclaration);\n              if (name) {\n                if (!metadata) metadata = {};\n                metadata[name] = classMetadataOf(classDeclaration);\n              }\n            }\n          }\n          // Otherwise don't record metadata for the class.\n          break;\n\n        case ts.SyntaxKind.TypeAliasDeclaration:\n          const typeDeclaration = <ts.TypeAliasDeclaration>node;\n          if (typeDeclaration.name && isExported(typeDeclaration)) {\n            const name = exportedName(typeDeclaration);\n            if (name) {\n              if (!metadata) metadata = {};\n              metadata[name] = {__symbolic: 'interface'};\n            }\n          }\n          break;\n\n        case ts.SyntaxKind.InterfaceDeclaration:\n          const interfaceDeclaration = <ts.InterfaceDeclaration>node;\n          if (interfaceDeclaration.name && isExported(interfaceDeclaration)) {\n            const name = exportedName(interfaceDeclaration);\n            if (name) {\n              if (!metadata) metadata = {};\n              metadata[name] = {__symbolic: 'interface'};\n            }\n          }\n          break;\n\n        case ts.SyntaxKind.FunctionDeclaration:\n          // Record functions that return a single value. Record the parameter\n          // names substitution will be performed by the StaticReflector.\n          const functionDeclaration = <ts.FunctionDeclaration>node;\n          if (isExported(functionDeclaration) && functionDeclaration.name) {\n            const name = exportedName(functionDeclaration);\n            const maybeFunc = maybeGetSimpleFunction(functionDeclaration);\n            if (name) {\n              if (!metadata) metadata = {};\n              // TODO(alxhub): The literal here is not valid FunctionMetadata.\n              metadata[name] =\n                  maybeFunc ? recordEntry(maybeFunc.func, node) : ({__symbolic: 'function'} as any);\n            }\n          }\n          break;\n\n        case ts.SyntaxKind.EnumDeclaration:\n          const enumDeclaration = <ts.EnumDeclaration>node;\n          if (isExported(enumDeclaration)) {\n            const enumValueHolder: {[name: string]: MetadataValue} = {};\n            const enumName = exportedName(enumDeclaration);\n            let nextDefaultValue: MetadataValue = 0;\n            let writtenMembers = 0;\n            for (const member of enumDeclaration.members) {\n              let enumValue: MetadataValue;\n              if (!member.initializer) {\n                enumValue = nextDefaultValue;\n              } else {\n                enumValue = evaluator.evaluateNode(member.initializer);\n              }\n              let name: string|undefined = undefined;\n              if (member.name.kind == ts.SyntaxKind.Identifier) {\n                const identifier = <ts.Identifier>member.name;\n                name = identifier.text;\n                enumValueHolder[name] = enumValue;\n                writtenMembers++;\n              }\n              if (typeof enumValue === 'number') {\n                nextDefaultValue = enumValue + 1;\n              } else if (name) {\n                // TODO(alxhub): 'left' here has a name propery which is not valid for\n                // MetadataSymbolicSelectExpression.\n                nextDefaultValue = {\n                  __symbolic: 'binary',\n                  operator: '+',\n                  left: {\n                    __symbolic: 'select',\n                    expression: recordEntry({__symbolic: 'reference', name: enumName}, node),\n                    name\n                  },\n                } as any;\n              } else {\n                nextDefaultValue =\n                    recordEntry(errorSym('Unsupported enum member name', member.name), node);\n              }\n            }\n            if (writtenMembers) {\n              if (enumName) {\n                if (!metadata) metadata = {};\n                metadata[enumName] = recordEntry(enumValueHolder, node);\n              }\n            }\n          }\n          break;\n\n        case ts.SyntaxKind.VariableStatement:\n          const variableStatement = <ts.VariableStatement>node;\n          for (const variableDeclaration of variableStatement.declarationList.declarations) {\n            if (variableDeclaration.name.kind == ts.SyntaxKind.Identifier) {\n              const nameNode = <ts.Identifier>variableDeclaration.name;\n              let varValue: MetadataValue;\n              if (variableDeclaration.initializer) {\n                varValue = evaluator.evaluateNode(variableDeclaration.initializer);\n              } else {\n                varValue = recordEntry(errorSym('Variable not initialized', nameNode), nameNode);\n              }\n              let exported = false;\n              if (isExport(variableStatement) || isExport(variableDeclaration) ||\n                  isExportedIdentifier(nameNode)) {\n                const name = exportedIdentifierName(nameNode);\n                if (name) {\n                  if (!metadata) metadata = {};\n                  metadata[name] = recordEntry(varValue, node);\n                }\n                exported = true;\n              }\n              if (typeof varValue == 'string' || typeof varValue == 'number' ||\n                  typeof varValue == 'boolean') {\n                locals.define(nameNode.text, varValue);\n                if (exported) {\n                  locals.defineReference(\n                      nameNode.text, {__symbolic: 'reference', name: nameNode.text});\n                }\n              } else if (!exported) {\n                if (varValue && !isMetadataError(varValue)) {\n                  locals.define(nameNode.text, recordEntry(varValue, node));\n                } else {\n                  locals.define(\n                      nameNode.text,\n                      recordEntry(\n                          errorSym('Reference to a local symbol', nameNode, {name: nameNode.text}),\n                          node));\n                }\n              }\n            } else {\n              // Destructuring (or binding) declarations are not supported,\n              // var {<identifier>[, <identifier>]+} = <expression>;\n              //   or\n              // var [<identifier>[, <identifier}+] = <expression>;\n              // are not supported.\n              const report: (nameNode: ts.Node) => void = (nameNode: ts.Node) => {\n                switch (nameNode.kind) {\n                  case ts.SyntaxKind.Identifier:\n                    const name = <ts.Identifier>nameNode;\n                    const varValue = errorSym('Destructuring not supported', name);\n                    locals.define(name.text, varValue);\n                    if (isExport(node)) {\n                      if (!metadata) metadata = {};\n                      metadata[name.text] = varValue;\n                    }\n                    break;\n                  case ts.SyntaxKind.BindingElement:\n                    const bindingElement = <ts.BindingElement>nameNode;\n                    report(bindingElement.name);\n                    break;\n                  case ts.SyntaxKind.ObjectBindingPattern:\n                  case ts.SyntaxKind.ArrayBindingPattern:\n                    const bindings = <ts.BindingPattern>nameNode;\n                    (bindings as any).elements.forEach(report);\n                    break;\n                }\n              };\n              report(variableDeclaration.name);\n            }\n          }\n          break;\n      }\n    });\n\n    if (metadata || exports) {\n      if (!metadata)\n        metadata = {};\n      else if (strict) {\n        validateMetadata(sourceFile, nodeMap, metadata);\n      }\n      const result: ModuleMetadata = {\n        __symbolic: 'module',\n        version: this.options.version || METADATA_VERSION,\n        metadata\n      };\n      if (sourceFile.moduleName) result.importAs = sourceFile.moduleName;\n      if (exports) result.exports = exports;\n      return result;\n    }\n  }\n}\n\n// This will throw if the metadata entry given contains an error node.\nfunction validateMetadata(\n    sourceFile: ts.SourceFile, nodeMap: Map<MetadataEntry, ts.Node>,\n    metadata: {[name: string]: MetadataEntry}) {\n  let locals: Set<string> = new Set(['Array', 'Object', 'Set', 'Map', 'string', 'number', 'any']);\n\n  function validateExpression(expression: MetadataValue|MetadataSymbolicExpression|MetadataError) {\n    if (!expression) {\n      return;\n    } else if (Array.isArray(expression)) {\n      expression.forEach(validateExpression);\n    } else if (typeof expression === 'object' && !expression.hasOwnProperty('__symbolic')) {\n      Object.getOwnPropertyNames(expression).forEach(v => validateExpression((<any>expression)[v]));\n    } else if (isMetadataError(expression)) {\n      reportError(expression);\n    } else if (isMetadataGlobalReferenceExpression(expression)) {\n      if (!locals.has(expression.name)) {\n        const reference = <MetadataValue>metadata[expression.name];\n        if (reference) {\n          validateExpression(reference);\n        }\n      }\n    } else if (isFunctionMetadata(expression)) {\n      validateFunction(<any>expression);\n    } else if (isMetadataSymbolicExpression(expression)) {\n      switch (expression.__symbolic) {\n        case 'binary':\n          const binaryExpression = <MetadataSymbolicBinaryExpression>expression;\n          validateExpression(binaryExpression.left);\n          validateExpression(binaryExpression.right);\n          break;\n        case 'call':\n        case 'new':\n          const callExpression = <MetadataSymbolicCallExpression>expression;\n          validateExpression(callExpression.expression);\n          if (callExpression.arguments) callExpression.arguments.forEach(validateExpression);\n          break;\n        case 'index':\n          const indexExpression = <MetadataSymbolicIndexExpression>expression;\n          validateExpression(indexExpression.expression);\n          validateExpression(indexExpression.index);\n          break;\n        case 'pre':\n          const prefixExpression = <MetadataSymbolicPrefixExpression>expression;\n          validateExpression(prefixExpression.operand);\n          break;\n        case 'select':\n          const selectExpression = <MetadataSymbolicSelectExpression>expression;\n          validateExpression(selectExpression.expression);\n          break;\n        case 'spread':\n          const spreadExpression = <MetadataSymbolicSpreadExpression>expression;\n          validateExpression(spreadExpression.expression);\n          break;\n        case 'if':\n          const ifExpression = <MetadataSymbolicIfExpression>expression;\n          validateExpression(ifExpression.condition);\n          validateExpression(ifExpression.elseExpression);\n          validateExpression(ifExpression.thenExpression);\n          break;\n      }\n    }\n  }\n\n  function validateMember(classData: ClassMetadata, member: MemberMetadata) {\n    if (member.decorators) {\n      member.decorators.forEach(validateExpression);\n    }\n    if (isMethodMetadata(member) && member.parameterDecorators) {\n      member.parameterDecorators.forEach(validateExpression);\n    }\n    // Only validate parameters of classes for which we know that are used with our DI\n    if (classData.decorators && isConstructorMetadata(member) && member.parameters) {\n      member.parameters.forEach(validateExpression);\n    }\n  }\n\n  function validateClass(classData: ClassMetadata) {\n    if (classData.decorators) {\n      classData.decorators.forEach(validateExpression);\n    }\n    if (classData.members) {\n      Object.getOwnPropertyNames(classData.members)\n          .forEach(name => classData.members![name].forEach((m) => validateMember(classData, m)));\n    }\n    if (classData.statics) {\n      Object.getOwnPropertyNames(classData.statics).forEach(name => {\n        const staticMember = classData.statics![name];\n        if (isFunctionMetadata(staticMember)) {\n          validateExpression(staticMember.value);\n        } else {\n          validateExpression(staticMember);\n        }\n      });\n    }\n  }\n\n  function validateFunction(functionDeclaration: FunctionMetadata) {\n    if (functionDeclaration.value) {\n      const oldLocals = locals;\n      if (functionDeclaration.parameters) {\n        locals = new Set(oldLocals.values());\n        if (functionDeclaration.parameters)\n          functionDeclaration.parameters.forEach(n => locals.add(n));\n      }\n      validateExpression(functionDeclaration.value);\n      locals = oldLocals;\n    }\n  }\n\n  function shouldReportNode(node: ts.Node|undefined) {\n    if (node) {\n      const nodeStart = node.getStart();\n      return !(\n          node.pos != nodeStart &&\n          sourceFile.text.substring(node.pos, nodeStart).indexOf('@dynamic') >= 0);\n    }\n    return true;\n  }\n\n  function reportError(error: MetadataError) {\n    const node = nodeMap.get(error);\n    if (shouldReportNode(node)) {\n      const lineInfo = error.line != undefined ? error.character != undefined ?\n                                                 `:${error.line + 1}:${error.character + 1}` :\n                                                 `:${error.line + 1}` :\n                                                 '';\n      throw new Error(`${sourceFile.fileName}${\n          lineInfo}: Metadata collected contains an error that will be reported at runtime: ${\n          expandedMessage(error)}.\\n  ${JSON.stringify(error)}`);\n    }\n  }\n\n  Object.getOwnPropertyNames(metadata).forEach(name => {\n    const entry = metadata[name];\n    try {\n      if (isClassMetadata(entry)) {\n        validateClass(entry);\n      }\n    } catch (e) {\n      const node = nodeMap.get(entry);\n      if (shouldReportNode(node)) {\n        if (node) {\n          const {line, character} = sourceFile.getLineAndCharacterOfPosition(node.getStart());\n          throw new Error(`${sourceFile.fileName}:${line + 1}:${\n              character + 1}: Error encountered in metadata generated for exported symbol '${\n              name}': \\n ${e.message}`);\n        }\n        throw new Error(\n            `Error encountered in metadata generated for exported symbol ${name}: \\n ${e.message}`);\n      }\n    }\n  });\n}\n\n// Collect parameter names from a function.\nfunction namesOf(parameters: ts.NodeArray<ts.ParameterDeclaration>): string[] {\n  const result: string[] = [];\n\n  function addNamesOf(name: ts.Identifier|ts.BindingPattern) {\n    if (name.kind == ts.SyntaxKind.Identifier) {\n      const identifier = <ts.Identifier>name;\n      result.push(identifier.text);\n    } else {\n      const bindingPattern = <ts.BindingPattern>name;\n      for (const element of bindingPattern.elements) {\n        const name = (element as any).name;\n        if (name) {\n          addNamesOf(name);\n        }\n      }\n    }\n  }\n\n  for (const parameter of parameters) {\n    addNamesOf(parameter.name);\n  }\n\n  return result;\n}\n\nfunction shouldIgnoreStaticMember(memberName: string): boolean {\n  return memberName.startsWith('ngAcceptInputType_') || memberName.startsWith('ngTemplateGuard_');\n}\n\nfunction expandedMessage(error: any): string {\n  switch (error.message) {\n    case 'Reference to non-exported class':\n      if (error.context && error.context.className) {\n        return `Reference to a non-exported class ${\n            error.context.className}. Consider exporting the class`;\n      }\n      break;\n    case 'Variable not initialized':\n      return 'Only initialized variables and constants can be referenced because the value of this variable is needed by the template compiler';\n    case 'Destructuring not supported':\n      return 'Referencing an exported destructured variable or constant is not supported by the template compiler. Consider simplifying this to avoid destructuring';\n    case 'Could not resolve type':\n      if (error.context && error.context.typeName) {\n        return `Could not resolve type ${error.context.typeName}`;\n      }\n      break;\n    case 'Function call not supported':\n      let prefix =\n          error.context && error.context.name ? `Calling function '${error.context.name}', f` : 'F';\n      return prefix +\n          'unction calls are not supported. Consider replacing the function or lambda with a reference to an exported function';\n    case 'Reference to a local symbol':\n      if (error.context && error.context.name) {\n        return `Reference to a local (non-exported) symbol '${\n            error.context.name}'. Consider exporting the symbol`;\n      }\n  }\n  return error.message;\n}\n"]}
Note: See TracBrowser for help on using the repository browser.