@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,86 +11,83 @@
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/transformers/inline_resources", ["require", "exports", "tslib", "typescript", "@angular/compiler-cli/src/metadata/index"], factory);
14
+ define("@angular/compiler-cli/src/transformers/inline_resources", ["require", "exports", "typescript", "@angular/compiler-cli/src/metadata/index"], 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 index_1 = require("@angular/compiler-cli/src/metadata/index");
22
- var PRECONDITIONS_TEXT = 'angularCompilerOptions.enableResourceInlining requires all resources to be statically resolvable.';
19
+ const ts = require("typescript");
20
+ const index_1 = require("@angular/compiler-cli/src/metadata/index");
21
+ const PRECONDITIONS_TEXT = 'angularCompilerOptions.enableResourceInlining requires all resources to be statically resolvable.';
23
22
  function getResourceLoader(host, containingFileName) {
24
23
  return {
25
- get: function (url) {
24
+ get(url) {
26
25
  if (typeof url !== 'string') {
27
26
  throw new Error('templateUrl and stylesUrl must be string literals. ' + PRECONDITIONS_TEXT);
28
27
  }
29
- var fileName = host.resourceNameToFileName(url, containingFileName);
28
+ const fileName = host.resourceNameToFileName(url, containingFileName);
30
29
  if (fileName) {
31
- var content = host.loadResource(fileName);
30
+ const content = host.loadResource(fileName);
32
31
  if (typeof content !== 'string') {
33
32
  throw new Error('Cannot handle async resource. ' + PRECONDITIONS_TEXT);
34
33
  }
35
34
  return content;
36
35
  }
37
- throw new Error("Failed to resolve " + url + " from " + containingFileName + ". " + PRECONDITIONS_TEXT);
36
+ throw new Error(`Failed to resolve ${url} from ${containingFileName}. ${PRECONDITIONS_TEXT}`);
38
37
  }
39
38
  };
40
39
  }
41
- var InlineResourcesMetadataTransformer = /** @class */ (function () {
42
- function InlineResourcesMetadataTransformer(host) {
40
+ class InlineResourcesMetadataTransformer {
41
+ constructor(host) {
43
42
  this.host = host;
44
43
  }
45
- InlineResourcesMetadataTransformer.prototype.start = function (sourceFile) {
46
- var _this = this;
47
- var loader = getResourceLoader(this.host, sourceFile.fileName);
48
- return function (value, node) {
44
+ start(sourceFile) {
45
+ const loader = getResourceLoader(this.host, sourceFile.fileName);
46
+ return (value, node) => {
49
47
  if (index_1.isClassMetadata(value) && ts.isClassDeclaration(node) && value.decorators) {
50
- value.decorators.forEach(function (d) {
48
+ value.decorators.forEach(d => {
51
49
  if (index_1.isMetadataSymbolicCallExpression(d) &&
52
50
  index_1.isMetadataImportedSymbolReferenceExpression(d.expression) &&
53
51
  d.expression.module === '@angular/core' && d.expression.name === 'Component' &&
54
52
  d.arguments) {
55
- d.arguments = d.arguments.map(_this.updateDecoratorMetadata.bind(_this, loader));
53
+ d.arguments = d.arguments.map(this.updateDecoratorMetadata.bind(this, loader));
56
54
  }
57
55
  });
58
56
  }
59
57
  return value;
60
58
  };
61
- };
62
- InlineResourcesMetadataTransformer.prototype.updateDecoratorMetadata = function (loader, arg) {
59
+ }
60
+ updateDecoratorMetadata(loader, arg) {
63
61
  if (arg['templateUrl']) {
64
62
  arg['template'] = loader.get(arg['templateUrl']);
65
- delete arg.templateUrl;
63
+ delete arg['templateUrl'];
66
64
  }
67
- var styles = arg['styles'] || [];
68
- var styleUrls = arg['styleUrls'] || [];
65
+ const styles = arg['styles'] || [];
66
+ const styleUrls = arg['styleUrls'] || [];
69
67
  if (!Array.isArray(styles))
70
68
  throw new Error('styles should be an array');
71
69
  if (!Array.isArray(styleUrls))
72
70
  throw new Error('styleUrls should be an array');
73
- styles.push.apply(styles, tslib_1.__spread(styleUrls.map(function (styleUrl) { return loader.get(styleUrl); })));
71
+ styles.push(...styleUrls.map(styleUrl => loader.get(styleUrl)));
74
72
  if (styles.length > 0) {
75
73
  arg['styles'] = styles;
76
- delete arg.styleUrls;
74
+ delete arg['styleUrls'];
77
75
  }
78
76
  return arg;
79
- };
80
- return InlineResourcesMetadataTransformer;
81
- }());
77
+ }
78
+ }
82
79
  exports.InlineResourcesMetadataTransformer = InlineResourcesMetadataTransformer;
83
80
  function getInlineResourcesTransformFactory(program, host) {
84
- return function (context) { return function (sourceFile) {
85
- var loader = getResourceLoader(host, sourceFile.fileName);
86
- var visitor = function (node) {
81
+ return (context) => (sourceFile) => {
82
+ const loader = getResourceLoader(host, sourceFile.fileName);
83
+ const visitor = node => {
87
84
  // Components are always classes; skip any other node
88
85
  if (!ts.isClassDeclaration(node)) {
89
86
  return node;
90
87
  }
91
88
  // Decorator case - before or without decorator downleveling
92
89
  // @Component()
93
- var newDecorators = ts.visitNodes(node.decorators, function (node) {
90
+ const newDecorators = ts.visitNodes(node.decorators, (node) => {
94
91
  if (isComponentDecorator(node, program.getTypeChecker())) {
95
92
  return updateDecorator(node, loader);
96
93
  }
@@ -98,12 +95,12 @@
98
95
  });
99
96
  // Annotation case - after decorator downleveling
100
97
  // static decorators: {type: Function, args?: any[]}[]
101
- var newMembers = ts.visitNodes(node.members, function (node) { return updateAnnotations(node, loader, program.getTypeChecker()); });
98
+ const newMembers = ts.visitNodes(node.members, (node) => updateAnnotations(node, loader, program.getTypeChecker()));
102
99
  // Create a new AST subtree with our modifications
103
100
  return ts.updateClassDeclaration(node, newDecorators, node.modifiers, node.name, node.typeParameters, node.heritageClauses || [], newMembers);
104
101
  };
105
102
  return ts.visitEachChild(sourceFile, visitor, context);
106
- }; };
103
+ };
107
104
  }
108
105
  exports.getInlineResourcesTransformFactory = getInlineResourcesTransformFactory;
109
106
  /**
@@ -116,8 +113,8 @@
116
113
  // User will get an error somewhere else with bare @Component
117
114
  return node;
118
115
  }
119
- var expr = node.expression;
120
- var newArguments = updateComponentProperties(expr.arguments, loader);
116
+ const expr = node.expression;
117
+ const newArguments = updateComponentProperties(expr.arguments, loader);
121
118
  return ts.updateDecorator(node, ts.updateCall(expr, expr.expression, expr.typeArguments, newArguments));
122
119
  }
123
120
  /**
@@ -146,23 +143,23 @@
146
143
  !ts.isArrayLiteralExpression(node.initializer)) {
147
144
  return node;
148
145
  }
149
- var newAnnotations = node.initializer.elements.map(function (annotation) {
146
+ const newAnnotations = node.initializer.elements.map(annotation => {
150
147
  // No-op if there's a non-object-literal mixed in the decorators values
151
148
  if (!ts.isObjectLiteralExpression(annotation))
152
149
  return annotation;
153
- var decoratorType = annotation.properties.find(function (p) { return isIdentifierNamed(p, 'type'); });
150
+ const decoratorType = annotation.properties.find(p => isIdentifierNamed(p, 'type'));
154
151
  // No-op if there's no 'type' property, or if it's not initialized to the Component symbol
155
152
  if (!decoratorType || !ts.isPropertyAssignment(decoratorType) ||
156
153
  !ts.isIdentifier(decoratorType.initializer) ||
157
154
  !isComponentSymbol(decoratorType.initializer, typeChecker)) {
158
155
  return annotation;
159
156
  }
160
- var newAnnotation = annotation.properties.map(function (prop) {
157
+ const newAnnotation = annotation.properties.map(prop => {
161
158
  // No-op if this isn't the 'args' property or if it's not initialized to an array
162
159
  if (!isIdentifierNamed(prop, 'args') || !ts.isPropertyAssignment(prop) ||
163
160
  !ts.isArrayLiteralExpression(prop.initializer))
164
161
  return prop;
165
- var newDecoratorArgs = ts.updatePropertyAssignment(prop, prop.name, ts.createArrayLiteral(updateComponentProperties(prop.initializer.elements, loader)));
162
+ const newDecoratorArgs = ts.updatePropertyAssignment(prop, prop.name, ts.createArrayLiteral(updateComponentProperties(prop.initializer.elements, loader)));
166
163
  return newDecoratorArgs;
167
164
  });
168
165
  return ts.updateObjectLiteral(annotation, newAnnotation);
@@ -179,8 +176,8 @@
179
176
  if (!ts.isCallExpression(node.expression)) {
180
177
  return false;
181
178
  }
182
- var callExpr = node.expression;
183
- var identifier;
179
+ const callExpr = node.expression;
180
+ let identifier;
184
181
  if (ts.isIdentifier(callExpr.expression)) {
185
182
  identifier = callExpr.expression;
186
183
  }
@@ -194,19 +191,19 @@
194
191
  if (!ts.isIdentifier(identifier))
195
192
  return false;
196
193
  // NOTE: resolver.getReferencedImportDeclaration would work as well but is internal
197
- var symbol = typeChecker.getSymbolAtLocation(identifier);
194
+ const symbol = typeChecker.getSymbolAtLocation(identifier);
198
195
  if (!symbol || !symbol.declarations || !symbol.declarations.length) {
199
- console.error("Unable to resolve symbol '" + identifier.text + "' in the program, does it type-check?");
196
+ console.error(`Unable to resolve symbol '${identifier.text}' in the program, does it type-check?`);
200
197
  return false;
201
198
  }
202
- var declaration = symbol.declarations[0];
199
+ const declaration = symbol.declarations[0];
203
200
  if (!declaration || !ts.isImportSpecifier(declaration)) {
204
201
  return false;
205
202
  }
206
- var name = (declaration.propertyName || declaration.name).text;
203
+ const name = (declaration.propertyName || declaration.name).text;
207
204
  // We know that parent pointers are set because we created the SourceFile ourselves.
208
205
  // The number of parent references here match the recursion depth at this point.
209
- var moduleId = declaration.parent.parent.parent.moduleSpecifier.text;
206
+ const moduleId = declaration.parent.parent.parent.moduleSpecifier.text;
210
207
  return moduleId === '@angular/core' && name === 'Component';
211
208
  }
212
209
  /**
@@ -221,15 +218,15 @@
221
218
  // User should have gotten a type-check error because @Component takes one argument
222
219
  return args;
223
220
  }
224
- var componentArg = args[0];
221
+ const componentArg = args[0];
225
222
  if (!ts.isObjectLiteralExpression(componentArg)) {
226
223
  // User should have gotten a type-check error because @Component takes an object literal
227
224
  // argument
228
225
  return args;
229
226
  }
230
- var newProperties = [];
231
- var newStyleExprs = [];
232
- componentArg.properties.forEach(function (prop) {
227
+ const newProperties = [];
228
+ const newStyleExprs = [];
229
+ componentArg.properties.forEach(prop => {
233
230
  if (!ts.isPropertyAssignment(prop) || ts.isComputedPropertyName(prop.name)) {
234
231
  newProperties.push(prop);
235
232
  return;
@@ -239,26 +236,26 @@
239
236
  if (!ts.isArrayLiteralExpression(prop.initializer)) {
240
237
  throw new Error('styles takes an array argument');
241
238
  }
242
- newStyleExprs.push.apply(newStyleExprs, tslib_1.__spread(prop.initializer.elements));
239
+ newStyleExprs.push(...prop.initializer.elements);
243
240
  break;
244
241
  case 'styleUrls':
245
242
  if (!ts.isArrayLiteralExpression(prop.initializer)) {
246
243
  throw new Error('styleUrls takes an array argument');
247
244
  }
248
- newStyleExprs.push.apply(newStyleExprs, tslib_1.__spread(prop.initializer.elements.map(function (expr) {
245
+ newStyleExprs.push(...prop.initializer.elements.map((expr) => {
249
246
  if (!ts.isStringLiteral(expr) && !ts.isNoSubstitutionTemplateLiteral(expr)) {
250
247
  throw new Error('Can only accept string literal arguments to styleUrls. ' + PRECONDITIONS_TEXT);
251
248
  }
252
- var styles = loader.get(expr.text);
249
+ const styles = loader.get(expr.text);
253
250
  return ts.createLiteral(styles);
254
- })));
251
+ }));
255
252
  break;
256
253
  case 'templateUrl':
257
254
  if (!ts.isStringLiteral(prop.initializer) &&
258
255
  !ts.isNoSubstitutionTemplateLiteral(prop.initializer)) {
259
256
  throw new Error('Can only accept a string literal argument to templateUrl. ' + PRECONDITIONS_TEXT);
260
257
  }
261
- var template = loader.get(prop.initializer.text);
258
+ const template = loader.get(prop.initializer.text);
262
259
  newProperties.push(ts.updatePropertyAssignment(prop, ts.createIdentifier('template'), ts.createLiteral(template)));
263
260
  break;
264
261
  default:
@@ -267,10 +264,10 @@
267
264
  });
268
265
  // Add the non-inline styles
269
266
  if (newStyleExprs.length > 0) {
270
- var newStyles = ts.createPropertyAssignment(ts.createIdentifier('styles'), ts.createArrayLiteral(newStyleExprs));
267
+ const newStyles = ts.createPropertyAssignment(ts.createIdentifier('styles'), ts.createArrayLiteral(newStyleExprs));
271
268
  newProperties.push(newStyles);
272
269
  }
273
270
  return ts.createNodeArray([ts.updateObjectLiteral(componentArg, newProperties)]);
274
271
  }
275
272
  });
276
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"inline_resources.js","sourceRoot":"","sources":["../../../../../../../packages/compiler-cli/src/transformers/inline_resources.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 {MetadataObject, MetadataValue, isClassMetadata, isMetadataImportedSymbolReferenceExpression, isMetadataSymbolicCallExpression} from '../metadata/index';\n\nimport {MetadataTransformer, ValueTransform} from './metadata_cache';\n\nconst PRECONDITIONS_TEXT =\n    'angularCompilerOptions.enableResourceInlining requires all resources to be statically resolvable.';\n\n/** A subset of members from AotCompilerHost */\nexport type ResourcesHost = {\n  resourceNameToFileName(resourceName: string, containingFileName: string): string | null;\n  loadResource(path: string): Promise<string>| string;\n};\n\nexport type StaticResourceLoader = {\n  get(url: string | MetadataValue): string;\n};\n\nfunction getResourceLoader(host: ResourcesHost, containingFileName: string): StaticResourceLoader {\n  return {\n    get(url: string | MetadataValue): string{\n      if (typeof url !== 'string') {\n        throw new Error('templateUrl and stylesUrl must be string literals. ' + PRECONDITIONS_TEXT);\n      } const fileName = host.resourceNameToFileName(url, containingFileName);\n      if (fileName) {\n        const content = host.loadResource(fileName);\n        if (typeof content !== 'string') {\n          throw new Error('Cannot handle async resource. ' + PRECONDITIONS_TEXT);\n        }\n        return content;\n      } throw new Error(`Failed to resolve ${url} from ${containingFileName}. ${PRECONDITIONS_TEXT}`);\n    }\n  };\n}\n\nexport class InlineResourcesMetadataTransformer implements MetadataTransformer {\n  constructor(private host: ResourcesHost) {}\n\n  start(sourceFile: ts.SourceFile): ValueTransform|undefined {\n    const loader = getResourceLoader(this.host, sourceFile.fileName);\n    return (value: MetadataValue, node: ts.Node): MetadataValue => {\n      if (isClassMetadata(value) && ts.isClassDeclaration(node) && value.decorators) {\n        value.decorators.forEach(d => {\n          if (isMetadataSymbolicCallExpression(d) &&\n              isMetadataImportedSymbolReferenceExpression(d.expression) &&\n              d.expression.module === '@angular/core' && d.expression.name === 'Component' &&\n              d.arguments) {\n            d.arguments = d.arguments.map(this.updateDecoratorMetadata.bind(this, loader));\n          }\n        });\n      }\n      return value;\n    };\n  }\n\n  updateDecoratorMetadata(loader: StaticResourceLoader, arg: MetadataObject): MetadataObject {\n    if (arg['templateUrl']) {\n      arg['template'] = loader.get(arg['templateUrl']);\n      delete arg.templateUrl;\n    }\n\n    const styles = arg['styles'] || [];\n    const styleUrls = arg['styleUrls'] || [];\n    if (!Array.isArray(styles)) throw new Error('styles should be an array');\n    if (!Array.isArray(styleUrls)) throw new Error('styleUrls should be an array');\n\n    styles.push(...styleUrls.map(styleUrl => loader.get(styleUrl)));\n    if (styles.length > 0) {\n      arg['styles'] = styles;\n      delete arg.styleUrls;\n    }\n\n    return arg;\n  }\n}\n\nexport function getInlineResourcesTransformFactory(\n    program: ts.Program, host: ResourcesHost): ts.TransformerFactory<ts.SourceFile> {\n  return (context: ts.TransformationContext) => (sourceFile: ts.SourceFile) => {\n    const loader = getResourceLoader(host, sourceFile.fileName);\n    const visitor: ts.Visitor = node => {\n      // Components are always classes; skip any other node\n      if (!ts.isClassDeclaration(node)) {\n        return node;\n      }\n\n      // Decorator case - before or without decorator downleveling\n      // @Component()\n      const newDecorators = ts.visitNodes(node.decorators, (node: ts.Decorator) => {\n        if (isComponentDecorator(node, program.getTypeChecker())) {\n          return updateDecorator(node, loader);\n        }\n        return node;\n      });\n\n      // Annotation case - after decorator downleveling\n      // static decorators: {type: Function, args?: any[]}[]\n      const newMembers = ts.visitNodes(\n          node.members,\n          (node: ts.ClassElement) => updateAnnotations(node, loader, program.getTypeChecker()));\n\n      // Create a new AST subtree with our modifications\n      return ts.updateClassDeclaration(\n          node, newDecorators, node.modifiers, node.name, node.typeParameters,\n          node.heritageClauses || [], newMembers);\n    };\n\n    return ts.visitEachChild(sourceFile, visitor, context);\n  };\n}\n\n/**\n * Update a Decorator AST node to inline the resources\n * @param node the @Component decorator\n * @param loader provides access to load resources\n */\nfunction updateDecorator(node: ts.Decorator, loader: StaticResourceLoader): ts.Decorator {\n  if (!ts.isCallExpression(node.expression)) {\n    // User will get an error somewhere else with bare @Component\n    return node;\n  }\n  const expr = node.expression;\n  const newArguments = updateComponentProperties(expr.arguments, loader);\n  return ts.updateDecorator(\n      node, ts.updateCall(expr, expr.expression, expr.typeArguments, newArguments));\n}\n\n/**\n * Update an Annotations AST node to inline the resources\n * @param node the static decorators property\n * @param loader provides access to load resources\n * @param typeChecker provides access to symbol table\n */\nfunction updateAnnotations(\n    node: ts.ClassElement, loader: StaticResourceLoader,\n    typeChecker: ts.TypeChecker): ts.ClassElement {\n  // Looking for a member of this shape:\n  // PropertyDeclaration called decorators, with static modifier\n  // Initializer is ArrayLiteralExpression\n  // One element is the Component type, its initializer is the @angular/core Component symbol\n  // One element is the component args, its initializer is the Component arguments to change\n  // e.g.\n  //   static decorators: {type: Function, args?: any[]}[] =\n  //   [{\n  //     type: Component,\n  //     args: [{\n  //       templateUrl: './my.component.html',\n  //       styleUrls: ['./my.component.css'],\n  //     }],\n  //   }];\n  if (!ts.isPropertyDeclaration(node) ||  // ts.ModifierFlags.Static &&\n      !ts.isIdentifier(node.name) || node.name.text !== 'decorators' || !node.initializer ||\n      !ts.isArrayLiteralExpression(node.initializer)) {\n    return node;\n  }\n\n  const newAnnotations = node.initializer.elements.map(annotation => {\n    // No-op if there's a non-object-literal mixed in the decorators values\n    if (!ts.isObjectLiteralExpression(annotation)) return annotation;\n\n    const decoratorType = annotation.properties.find(p => isIdentifierNamed(p, 'type'));\n\n    // No-op if there's no 'type' property, or if it's not initialized to the Component symbol\n    if (!decoratorType || !ts.isPropertyAssignment(decoratorType) ||\n        !ts.isIdentifier(decoratorType.initializer) ||\n        !isComponentSymbol(decoratorType.initializer, typeChecker)) {\n      return annotation;\n    }\n\n    const newAnnotation = annotation.properties.map(prop => {\n      // No-op if this isn't the 'args' property or if it's not initialized to an array\n      if (!isIdentifierNamed(prop, 'args') || !ts.isPropertyAssignment(prop) ||\n          !ts.isArrayLiteralExpression(prop.initializer))\n        return prop;\n\n      const newDecoratorArgs = ts.updatePropertyAssignment(\n          prop, prop.name,\n          ts.createArrayLiteral(updateComponentProperties(prop.initializer.elements, loader)));\n\n      return newDecoratorArgs;\n    });\n\n    return ts.updateObjectLiteral(annotation, newAnnotation);\n  });\n\n  return ts.updateProperty(\n      node, node.decorators, node.modifiers, node.name, node.questionToken, node.type,\n      ts.updateArrayLiteral(node.initializer, newAnnotations));\n}\n\nfunction isIdentifierNamed(p: ts.ObjectLiteralElementLike, name: string): boolean {\n  return !!p.name && ts.isIdentifier(p.name) && p.name.text === name;\n}\n\n/**\n * Check that the node we are visiting is the actual Component decorator defined in @angular/core.\n */\nfunction isComponentDecorator(node: ts.Decorator, typeChecker: ts.TypeChecker): boolean {\n  if (!ts.isCallExpression(node.expression)) {\n    return false;\n  }\n  const callExpr = node.expression;\n\n  let identifier: ts.Node;\n\n  if (ts.isIdentifier(callExpr.expression)) {\n    identifier = callExpr.expression;\n  } else {\n    return false;\n  }\n  return isComponentSymbol(identifier, typeChecker);\n}\n\nfunction isComponentSymbol(identifier: ts.Node, typeChecker: ts.TypeChecker) {\n  // Only handle identifiers, not expressions\n  if (!ts.isIdentifier(identifier)) return false;\n\n  // NOTE: resolver.getReferencedImportDeclaration would work as well but is internal\n  const symbol = typeChecker.getSymbolAtLocation(identifier);\n\n  if (!symbol || !symbol.declarations || !symbol.declarations.length) {\n    console.error(\n        `Unable to resolve symbol '${identifier.text}' in the program, does it type-check?`);\n    return false;\n  }\n\n  const declaration = symbol.declarations[0];\n\n  if (!declaration || !ts.isImportSpecifier(declaration)) {\n    return false;\n  }\n\n  const name = (declaration.propertyName || declaration.name).text;\n  // We know that parent pointers are set because we created the SourceFile ourselves.\n  // The number of parent references here match the recursion depth at this point.\n  const moduleId =\n      (declaration.parent !.parent !.parent !.moduleSpecifier as ts.StringLiteral).text;\n  return moduleId === '@angular/core' && name === 'Component';\n}\n\n/**\n * For each property in the object literal, if it's templateUrl or styleUrls, replace it\n * with content.\n * @param node the arguments to @Component() or args property of decorators: [{type:Component}]\n * @param loader provides access to the loadResource method of the host\n * @returns updated arguments\n */\nfunction updateComponentProperties(\n    args: ts.NodeArray<ts.Expression>, loader: StaticResourceLoader): ts.NodeArray<ts.Expression> {\n  if (args.length !== 1) {\n    // User should have gotten a type-check error because @Component takes one argument\n    return args;\n  }\n  const componentArg = args[0];\n  if (!ts.isObjectLiteralExpression(componentArg)) {\n    // User should have gotten a type-check error because @Component takes an object literal\n    // argument\n    return args;\n  }\n\n  const newProperties: ts.ObjectLiteralElementLike[] = [];\n  const newStyleExprs: ts.Expression[] = [];\n  componentArg.properties.forEach(prop => {\n    if (!ts.isPropertyAssignment(prop) || ts.isComputedPropertyName(prop.name)) {\n      newProperties.push(prop);\n      return;\n    }\n\n    switch (prop.name.text) {\n      case 'styles':\n        if (!ts.isArrayLiteralExpression(prop.initializer)) {\n          throw new Error('styles takes an array argument');\n        }\n        newStyleExprs.push(...prop.initializer.elements);\n        break;\n\n      case 'styleUrls':\n        if (!ts.isArrayLiteralExpression(prop.initializer)) {\n          throw new Error('styleUrls takes an array argument');\n        }\n        newStyleExprs.push(...prop.initializer.elements.map((expr: ts.Expression) => {\n          if (!ts.isStringLiteral(expr) && !ts.isNoSubstitutionTemplateLiteral(expr)) {\n            throw new Error(\n                'Can only accept string literal arguments to styleUrls. ' + PRECONDITIONS_TEXT);\n          }\n          const styles = loader.get(expr.text);\n          return ts.createLiteral(styles);\n        }));\n        break;\n\n      case 'templateUrl':\n        if (!ts.isStringLiteral(prop.initializer) &&\n            !ts.isNoSubstitutionTemplateLiteral(prop.initializer)) {\n          throw new Error(\n              'Can only accept a string literal argument to templateUrl. ' + PRECONDITIONS_TEXT);\n        }\n        const template = loader.get(prop.initializer.text);\n        newProperties.push(ts.updatePropertyAssignment(\n            prop, ts.createIdentifier('template'), ts.createLiteral(template)));\n        break;\n\n      default:\n        newProperties.push(prop);\n    }\n  });\n\n  // Add the non-inline styles\n  if (newStyleExprs.length > 0) {\n    const newStyles = ts.createPropertyAssignment(\n        ts.createIdentifier('styles'), ts.createArrayLiteral(newStyleExprs));\n    newProperties.push(newStyles);\n  }\n\n  return ts.createNodeArray([ts.updateObjectLiteral(componentArg, newProperties)]);\n}\n"]}
273
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"inline_resources.js","sourceRoot":"","sources":["../../../../../../../packages/compiler-cli/src/transformers/inline_resources.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 {MetadataObject, MetadataValue, isClassMetadata, isMetadataImportedSymbolReferenceExpression, isMetadataSymbolicCallExpression} from '../metadata/index';\n\nimport {MetadataTransformer, ValueTransform} from './metadata_cache';\n\nconst PRECONDITIONS_TEXT =\n    'angularCompilerOptions.enableResourceInlining requires all resources to be statically resolvable.';\n\n/** A subset of members from AotCompilerHost */\nexport type ResourcesHost = {\n  resourceNameToFileName(resourceName: string, containingFileName: string): string | null;\n  loadResource(path: string): Promise<string>| string;\n};\n\nexport type StaticResourceLoader = {\n  get(url: string | MetadataValue): string;\n};\n\nfunction getResourceLoader(host: ResourcesHost, containingFileName: string): StaticResourceLoader {\n  return {\n    get(url: string | MetadataValue): string{\n      if (typeof url !== 'string') {\n        throw new Error('templateUrl and stylesUrl must be string literals. ' + PRECONDITIONS_TEXT);\n      } const fileName = host.resourceNameToFileName(url, containingFileName);\n      if (fileName) {\n        const content = host.loadResource(fileName);\n        if (typeof content !== 'string') {\n          throw new Error('Cannot handle async resource. ' + PRECONDITIONS_TEXT);\n        }\n        return content;\n      } throw new Error(`Failed to resolve ${url} from ${containingFileName}. ${PRECONDITIONS_TEXT}`);\n    }\n  };\n}\n\nexport class InlineResourcesMetadataTransformer implements MetadataTransformer {\n  constructor(private host: ResourcesHost) {}\n\n  start(sourceFile: ts.SourceFile): ValueTransform|undefined {\n    const loader = getResourceLoader(this.host, sourceFile.fileName);\n    return (value: MetadataValue, node: ts.Node): MetadataValue => {\n      if (isClassMetadata(value) && ts.isClassDeclaration(node) && value.decorators) {\n        value.decorators.forEach(d => {\n          if (isMetadataSymbolicCallExpression(d) &&\n              isMetadataImportedSymbolReferenceExpression(d.expression) &&\n              d.expression.module === '@angular/core' && d.expression.name === 'Component' &&\n              d.arguments) {\n            d.arguments = d.arguments.map(this.updateDecoratorMetadata.bind(this, loader));\n          }\n        });\n      }\n      return value;\n    };\n  }\n\n  updateDecoratorMetadata(loader: StaticResourceLoader, arg: MetadataObject): MetadataObject {\n    if (arg['templateUrl']) {\n      arg['template'] = loader.get(arg['templateUrl']);\n      delete arg['templateUrl'];\n    }\n\n    const styles = arg['styles'] || [];\n    const styleUrls = arg['styleUrls'] || [];\n    if (!Array.isArray(styles)) throw new Error('styles should be an array');\n    if (!Array.isArray(styleUrls)) throw new Error('styleUrls should be an array');\n\n    styles.push(...styleUrls.map(styleUrl => loader.get(styleUrl)));\n    if (styles.length > 0) {\n      arg['styles'] = styles;\n      delete arg['styleUrls'];\n    }\n\n    return arg;\n  }\n}\n\nexport function getInlineResourcesTransformFactory(\n    program: ts.Program, host: ResourcesHost): ts.TransformerFactory<ts.SourceFile> {\n  return (context: ts.TransformationContext) => (sourceFile: ts.SourceFile) => {\n    const loader = getResourceLoader(host, sourceFile.fileName);\n    const visitor: ts.Visitor = node => {\n      // Components are always classes; skip any other node\n      if (!ts.isClassDeclaration(node)) {\n        return node;\n      }\n\n      // Decorator case - before or without decorator downleveling\n      // @Component()\n      const newDecorators = ts.visitNodes(node.decorators, (node: ts.Decorator) => {\n        if (isComponentDecorator(node, program.getTypeChecker())) {\n          return updateDecorator(node, loader);\n        }\n        return node;\n      });\n\n      // Annotation case - after decorator downleveling\n      // static decorators: {type: Function, args?: any[]}[]\n      const newMembers = ts.visitNodes(\n          node.members,\n          (node: ts.ClassElement) => updateAnnotations(node, loader, program.getTypeChecker()));\n\n      // Create a new AST subtree with our modifications\n      return ts.updateClassDeclaration(\n          node, newDecorators, node.modifiers, node.name, node.typeParameters,\n          node.heritageClauses || [], newMembers);\n    };\n\n    return ts.visitEachChild(sourceFile, visitor, context);\n  };\n}\n\n/**\n * Update a Decorator AST node to inline the resources\n * @param node the @Component decorator\n * @param loader provides access to load resources\n */\nfunction updateDecorator(node: ts.Decorator, loader: StaticResourceLoader): ts.Decorator {\n  if (!ts.isCallExpression(node.expression)) {\n    // User will get an error somewhere else with bare @Component\n    return node;\n  }\n  const expr = node.expression;\n  const newArguments = updateComponentProperties(expr.arguments, loader);\n  return ts.updateDecorator(\n      node, ts.updateCall(expr, expr.expression, expr.typeArguments, newArguments));\n}\n\n/**\n * Update an Annotations AST node to inline the resources\n * @param node the static decorators property\n * @param loader provides access to load resources\n * @param typeChecker provides access to symbol table\n */\nfunction updateAnnotations(\n    node: ts.ClassElement, loader: StaticResourceLoader,\n    typeChecker: ts.TypeChecker): ts.ClassElement {\n  // Looking for a member of this shape:\n  // PropertyDeclaration called decorators, with static modifier\n  // Initializer is ArrayLiteralExpression\n  // One element is the Component type, its initializer is the @angular/core Component symbol\n  // One element is the component args, its initializer is the Component arguments to change\n  // e.g.\n  //   static decorators: {type: Function, args?: any[]}[] =\n  //   [{\n  //     type: Component,\n  //     args: [{\n  //       templateUrl: './my.component.html',\n  //       styleUrls: ['./my.component.css'],\n  //     }],\n  //   }];\n  if (!ts.isPropertyDeclaration(node) ||  // ts.ModifierFlags.Static &&\n      !ts.isIdentifier(node.name) || node.name.text !== 'decorators' || !node.initializer ||\n      !ts.isArrayLiteralExpression(node.initializer)) {\n    return node;\n  }\n\n  const newAnnotations = node.initializer.elements.map(annotation => {\n    // No-op if there's a non-object-literal mixed in the decorators values\n    if (!ts.isObjectLiteralExpression(annotation)) return annotation;\n\n    const decoratorType = annotation.properties.find(p => isIdentifierNamed(p, 'type'));\n\n    // No-op if there's no 'type' property, or if it's not initialized to the Component symbol\n    if (!decoratorType || !ts.isPropertyAssignment(decoratorType) ||\n        !ts.isIdentifier(decoratorType.initializer) ||\n        !isComponentSymbol(decoratorType.initializer, typeChecker)) {\n      return annotation;\n    }\n\n    const newAnnotation = annotation.properties.map(prop => {\n      // No-op if this isn't the 'args' property or if it's not initialized to an array\n      if (!isIdentifierNamed(prop, 'args') || !ts.isPropertyAssignment(prop) ||\n          !ts.isArrayLiteralExpression(prop.initializer))\n        return prop;\n\n      const newDecoratorArgs = ts.updatePropertyAssignment(\n          prop, prop.name,\n          ts.createArrayLiteral(updateComponentProperties(prop.initializer.elements, loader)));\n\n      return newDecoratorArgs;\n    });\n\n    return ts.updateObjectLiteral(annotation, newAnnotation);\n  });\n\n  return ts.updateProperty(\n      node, node.decorators, node.modifiers, node.name, node.questionToken, node.type,\n      ts.updateArrayLiteral(node.initializer, newAnnotations));\n}\n\nfunction isIdentifierNamed(p: ts.ObjectLiteralElementLike, name: string): boolean {\n  return !!p.name && ts.isIdentifier(p.name) && p.name.text === name;\n}\n\n/**\n * Check that the node we are visiting is the actual Component decorator defined in @angular/core.\n */\nfunction isComponentDecorator(node: ts.Decorator, typeChecker: ts.TypeChecker): boolean {\n  if (!ts.isCallExpression(node.expression)) {\n    return false;\n  }\n  const callExpr = node.expression;\n\n  let identifier: ts.Node;\n\n  if (ts.isIdentifier(callExpr.expression)) {\n    identifier = callExpr.expression;\n  } else {\n    return false;\n  }\n  return isComponentSymbol(identifier, typeChecker);\n}\n\nfunction isComponentSymbol(identifier: ts.Node, typeChecker: ts.TypeChecker) {\n  // Only handle identifiers, not expressions\n  if (!ts.isIdentifier(identifier)) return false;\n\n  // NOTE: resolver.getReferencedImportDeclaration would work as well but is internal\n  const symbol = typeChecker.getSymbolAtLocation(identifier);\n\n  if (!symbol || !symbol.declarations || !symbol.declarations.length) {\n    console.error(\n        `Unable to resolve symbol '${identifier.text}' in the program, does it type-check?`);\n    return false;\n  }\n\n  const declaration = symbol.declarations[0];\n\n  if (!declaration || !ts.isImportSpecifier(declaration)) {\n    return false;\n  }\n\n  const name = (declaration.propertyName || declaration.name).text;\n  // We know that parent pointers are set because we created the SourceFile ourselves.\n  // The number of parent references here match the recursion depth at this point.\n  const moduleId =\n      (declaration.parent !.parent !.parent !.moduleSpecifier as ts.StringLiteral).text;\n  return moduleId === '@angular/core' && name === 'Component';\n}\n\n/**\n * For each property in the object literal, if it's templateUrl or styleUrls, replace it\n * with content.\n * @param node the arguments to @Component() or args property of decorators: [{type:Component}]\n * @param loader provides access to the loadResource method of the host\n * @returns updated arguments\n */\nfunction updateComponentProperties(\n    args: ts.NodeArray<ts.Expression>, loader: StaticResourceLoader): ts.NodeArray<ts.Expression> {\n  if (args.length !== 1) {\n    // User should have gotten a type-check error because @Component takes one argument\n    return args;\n  }\n  const componentArg = args[0];\n  if (!ts.isObjectLiteralExpression(componentArg)) {\n    // User should have gotten a type-check error because @Component takes an object literal\n    // argument\n    return args;\n  }\n\n  const newProperties: ts.ObjectLiteralElementLike[] = [];\n  const newStyleExprs: ts.Expression[] = [];\n  componentArg.properties.forEach(prop => {\n    if (!ts.isPropertyAssignment(prop) || ts.isComputedPropertyName(prop.name)) {\n      newProperties.push(prop);\n      return;\n    }\n\n    switch (prop.name.text) {\n      case 'styles':\n        if (!ts.isArrayLiteralExpression(prop.initializer)) {\n          throw new Error('styles takes an array argument');\n        }\n        newStyleExprs.push(...prop.initializer.elements);\n        break;\n\n      case 'styleUrls':\n        if (!ts.isArrayLiteralExpression(prop.initializer)) {\n          throw new Error('styleUrls takes an array argument');\n        }\n        newStyleExprs.push(...prop.initializer.elements.map((expr: ts.Expression) => {\n          if (!ts.isStringLiteral(expr) && !ts.isNoSubstitutionTemplateLiteral(expr)) {\n            throw new Error(\n                'Can only accept string literal arguments to styleUrls. ' + PRECONDITIONS_TEXT);\n          }\n          const styles = loader.get(expr.text);\n          return ts.createLiteral(styles);\n        }));\n        break;\n\n      case 'templateUrl':\n        if (!ts.isStringLiteral(prop.initializer) &&\n            !ts.isNoSubstitutionTemplateLiteral(prop.initializer)) {\n          throw new Error(\n              'Can only accept a string literal argument to templateUrl. ' + PRECONDITIONS_TEXT);\n        }\n        const template = loader.get(prop.initializer.text);\n        newProperties.push(ts.updatePropertyAssignment(\n            prop, ts.createIdentifier('template'), ts.createLiteral(template)));\n        break;\n\n      default:\n        newProperties.push(prop);\n    }\n  });\n\n  // Add the non-inline styles\n  if (newStyleExprs.length > 0) {\n    const newStyles = ts.createPropertyAssignment(\n        ts.createIdentifier('styles'), ts.createArrayLiteral(newStyleExprs));\n    newProperties.push(newStyles);\n  }\n\n  return ts.createNodeArray([ts.updateObjectLiteral(componentArg, newProperties)]);\n}\n"]}