@angular/compiler-cli 7.0.0-rc.1 → 7.0.3

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (49) hide show
  1. package/package.json +3 -3
  2. package/src/diagnostics/symbols.d.ts +10 -10
  3. package/src/diagnostics/symbols.js +2 -2
  4. package/src/ngcc/src/analysis/decoration_analyzer.d.ts +65 -0
  5. package/src/ngcc/src/analysis/decoration_analyzer.js +116 -0
  6. package/src/ngcc/src/analysis/switch_marker_analyzer.d.ts +33 -0
  7. package/src/ngcc/src/analysis/switch_marker_analyzer.js +44 -0
  8. package/src/ngcc/src/{parsing/parsed_class.d.ts → host/decorated_class.d.ts} +4 -4
  9. package/src/ngcc/src/host/decorated_class.js +40 -0
  10. package/src/ngcc/src/host/decorated_file.d.ts +21 -0
  11. package/src/ngcc/src/host/decorated_file.js +34 -0
  12. package/src/ngcc/src/host/esm5_host.d.ts +8 -0
  13. package/src/ngcc/src/host/esm5_host.js +37 -2
  14. package/src/ngcc/src/host/fesm2015_host.d.ts +2 -0
  15. package/src/ngcc/src/host/fesm2015_host.js +41 -2
  16. package/src/ngcc/src/host/ngcc_host.d.ts +8 -0
  17. package/src/ngcc/src/host/ngcc_host.js +1 -1
  18. package/src/ngcc/src/packages/build_marker.d.ts +1 -1
  19. package/src/ngcc/src/packages/build_marker.js +1 -1
  20. package/src/ngcc/src/packages/transformer.d.ts +6 -6
  21. package/src/ngcc/src/packages/transformer.js +32 -82
  22. package/src/ngcc/src/rendering/esm2015_renderer.d.ts +15 -28
  23. package/src/ngcc/src/rendering/esm2015_renderer.js +39 -81
  24. package/src/ngcc/src/rendering/esm5_renderer.d.ts +2 -2
  25. package/src/ngcc/src/rendering/esm5_renderer.js +4 -4
  26. package/src/ngcc/src/rendering/fesm2015_renderer.d.ts +38 -0
  27. package/src/ngcc/src/rendering/fesm2015_renderer.js +112 -0
  28. package/src/ngcc/src/rendering/renderer.d.ts +11 -11
  29. package/src/ngcc/src/rendering/renderer.js +49 -24
  30. package/src/ngtsc/annotations/src/component.js +2 -2
  31. package/src/ngtsc/annotations/src/directive.js +8 -1
  32. package/src/ngtsc/annotations/src/util.js +1 -4
  33. package/src/ngtsc/typecheck/src/type_check_block.js +1 -1
  34. package/src/perform_watch.js +5 -5
  35. package/src/transformers/api.d.ts +1 -1
  36. package/src/transformers/api.js +1 -1
  37. package/src/version.js +1 -1
  38. package/src/ngcc/canonical-path.d.ts +0 -14
  39. package/src/ngcc/src/analyzer.d.ts +0 -53
  40. package/src/ngcc/src/analyzer.js +0 -94
  41. package/src/ngcc/src/parsing/esm2015_parser.d.ts +0 -19
  42. package/src/ngcc/src/parsing/esm2015_parser.js +0 -64
  43. package/src/ngcc/src/parsing/esm5_parser.d.ts +0 -24
  44. package/src/ngcc/src/parsing/esm5_parser.js +0 -65
  45. package/src/ngcc/src/parsing/file_parser.d.ts +0 -35
  46. package/src/ngcc/src/parsing/file_parser.js +0 -13
  47. package/src/ngcc/src/parsing/parsed_class.js +0 -40
  48. package/src/ngcc/src/parsing/parsed_file.d.ts +0 -23
  49. package/src/ngcc/src/parsing/parsed_file.js +0 -36
package/package.json CHANGED
@@ -1,6 +1,6 @@
1
1
  {
2
2
  "name": "@angular/compiler-cli",
3
- "version": "7.0.0-rc.1",
3
+ "version": "7.0.3",
4
4
  "description": "Angular - the compiler CLI for Node.js",
5
5
  "main": "index.js",
6
6
  "typings": "index.d.ts",
@@ -12,7 +12,7 @@
12
12
  "dependencies": {
13
13
  "reflect-metadata": "^0.1.2",
14
14
  "minimist": "^1.2.0",
15
- "canonical-path": "0.0.2",
15
+ "canonical-path": "1.0.0",
16
16
  "chokidar": "^1.4.2",
17
17
  "convert-source-map": "^1.5.1",
18
18
  "dependency-graph": "^0.7.2",
@@ -22,7 +22,7 @@
22
22
  "yargs": "9.0.1"
23
23
  },
24
24
  "peerDependencies": {
25
- "@angular/compiler": "7.0.0-rc.1",
25
+ "@angular/compiler": "7.0.3",
26
26
  "typescript": ">=3.1.1 <3.2"
27
27
  },
28
28
  "engines" : {
@@ -10,7 +10,7 @@ import { StaticSymbol } from '@angular/compiler';
10
10
  /**
11
11
  * The range of a span of text in a source file.
12
12
  *
13
- * @experimental
13
+ * @publicApi
14
14
  */
15
15
  export interface Span {
16
16
  /**
@@ -39,7 +39,7 @@ export declare type Definition = Location[] | undefined;
39
39
  * A symbol describing a language element that can be referenced by expressions
40
40
  * in an Angular template.
41
41
  *
42
- * @experimental
42
+ * @publicApi
43
43
  */
44
44
  export interface Symbol {
45
45
  /**
@@ -106,7 +106,7 @@ export interface Symbol {
106
106
  /**
107
107
  * A table of `Symbol`s accessible by name.
108
108
  *
109
- * @experimental
109
+ * @publicApi
110
110
  */
111
111
  export interface SymbolTable {
112
112
  /**
@@ -131,7 +131,7 @@ export interface SymbolTable {
131
131
  /**
132
132
  * A description of a function or method signature.
133
133
  *
134
- * @experimental
134
+ * @publicApi
135
135
  */
136
136
  export interface Signature {
137
137
  /**
@@ -147,7 +147,7 @@ export interface Signature {
147
147
  /**
148
148
  * An enumeration of basic types.
149
149
  *
150
- * @experimental
150
+ * @publicApi
151
151
  */
152
152
  export declare enum BuiltinType {
153
153
  /**
@@ -186,13 +186,13 @@ export declare enum BuiltinType {
186
186
  /**
187
187
  * The kinds of definition.
188
188
  *
189
- * @experimental
189
+ * @publicApi
190
190
  */
191
191
  export declare type DeclarationKind = 'attribute' | 'html attribute' | 'component' | 'element' | 'entity' | 'key' | 'method' | 'pipe' | 'property' | 'type' | 'reference' | 'variable';
192
192
  /**
193
193
  * Describes a symbol to type binding used to build a symbol table.
194
194
  *
195
- * @experimental
195
+ * @publicApi
196
196
  */
197
197
  export interface SymbolDeclaration {
198
198
  /**
@@ -215,7 +215,7 @@ export interface SymbolDeclaration {
215
215
  /**
216
216
  * Information about the pipes that are available for use in a template.
217
217
  *
218
- * @experimental
218
+ * @publicApi
219
219
  */
220
220
  export interface PipeInfo {
221
221
  /**
@@ -230,13 +230,13 @@ export interface PipeInfo {
230
230
  /**
231
231
  * A sequence of pipe information.
232
232
  *
233
- * @experimental
233
+ * @publicApi
234
234
  */
235
235
  export declare type Pipes = PipeInfo[] | undefined;
236
236
  /**
237
237
  * Describes the language context in which an Angular expression is evaluated.
238
238
  *
239
- * @experimental
239
+ * @publicApi
240
240
  */
241
241
  export interface SymbolQuery {
242
242
  /**
@@ -19,7 +19,7 @@
19
19
  /**
20
20
  * An enumeration of basic types.
21
21
  *
22
- * @experimental
22
+ * @publicApi
23
23
  */
24
24
  var BuiltinType;
25
25
  (function (BuiltinType) {
@@ -57,4 +57,4 @@
57
57
  BuiltinType[BuiltinType["Other"] = 7] = "Other";
58
58
  })(BuiltinType = exports.BuiltinType || (exports.BuiltinType = {}));
59
59
  });
60
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"symbols.js","sourceRoot":"","sources":["../../../../../../../packages/compiler-cli/src/diagnostics/symbols.ts"],"names":[],"mappings":"AAAA;;;;;;GAMG;;;;;;;;;;;;IAoKH;;;;OAIG;IACH,IAAY,WAwCX;IAxCD,WAAY,WAAW;QACrB;;WAEG;QACH,2CAAG,CAAA;QAEH;;WAEG;QACH,iDAAM,CAAA;QAEN;;WAEG;QACH,iDAAM,CAAA;QAEN;;WAEG;QACH,mDAAO,CAAA;QAEP;;WAEG;QACH,uDAAS,CAAA;QAET;;WAEG;QACH,6CAAI,CAAA;QAEJ;;WAEG;QACH,mDAAO,CAAA;QAEP;;WAEG;QACH,+CAAK,CAAA;IACP,CAAC,EAxCW,WAAW,GAAX,mBAAW,KAAX,mBAAW,QAwCtB","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 {StaticSymbol} from '@angular/compiler';\n\n/**\n * The range of a span of text in a source file.\n *\n * @experimental\n */\nexport interface Span {\n  /**\n   * The first code-point of the span as an offset relative to the beginning of the source assuming\n   * a UTF-16 encoding.\n   */\n  start: number;\n\n  /**\n   * The first code-point after the span as an offset relative to the beginning of the source\n   * assuming a UTF-16 encoding.\n   */\n  end: number;\n}\n\n/**\n * A file and span.\n */\nexport interface Location {\n  fileName: string;\n  span: Span;\n}\n\n/**\n * A defnition location(s).\n */\nexport type Definition = Location[] | undefined;\n\n/**\n * A symbol describing a language element that can be referenced by expressions\n * in an Angular template.\n *\n * @experimental\n */\nexport interface Symbol {\n  /**\n   * The name of the symbol as it would be referenced in an Angular expression.\n   */\n  readonly name: string;\n\n  /**\n   * The kind of completion this symbol should generate if included.\n   */\n  readonly kind: string;\n\n  /**\n   * The language of the source that defines the symbol. (e.g. typescript for TypeScript,\n   * ng-template for an Angular template, etc.)\n   */\n  readonly language: string;\n\n  /**\n   * A symbol representing type of the symbol.\n   */\n  readonly type: Symbol|undefined;\n\n  /**\n   * A symbol for the container of this symbol. For example, if this is a method, the container\n   * is the class or interface of the method. If no container is appropriate, undefined is\n   * returned.\n   */\n  readonly container: Symbol|undefined;\n\n  /**\n   * The symbol is public in the container.\n   */\n  readonly public: boolean;\n\n  /**\n   * `true` if the symbol can be the target of a call.\n   */\n  readonly callable: boolean;\n\n  /**\n   * The location of the definition of the symbol\n   */\n  readonly definition: Definition|undefined;\n\n  /**\n   * `true` if the symbol is a type that is nullable (can be null or undefined).\n   */\n  readonly nullable: boolean;\n\n  /**\n   * A table of the members of the symbol; that is, the members that can appear\n   * after a `.` in an Angular expression.\n   */\n  members(): SymbolTable;\n\n  /**\n   * The list of overloaded signatures that can be used if the symbol is the\n   * target of a call.\n   */\n  signatures(): Signature[];\n\n  /**\n   * Return which signature of returned by `signatures()` would be used selected\n   * given the `types` supplied. If no signature would match, this method should\n   * return `undefined`.\n   */\n  selectSignature(types: Symbol[]): Signature|undefined;\n\n  /**\n   * Return the type of the expression if this symbol is indexed by `argument`.\n   * If the symbol cannot be indexed, this method should return `undefined`.\n   */\n  indexed(argument: Symbol): Symbol|undefined;\n}\n\n/**\n * A table of `Symbol`s accessible by name.\n *\n * @experimental\n */\nexport interface SymbolTable {\n  /**\n   * The number of symbols in the table.\n   */\n  readonly size: number;\n\n  /**\n   * Get the symbol corresponding to `key` or `undefined` if there is no symbol in the\n   * table by the name `key`.\n   */\n  get(key: string): Symbol|undefined;\n\n  /**\n   * Returns `true` if the table contains a `Symbol` with the name `key`.\n   */\n  has(key: string): boolean;\n\n  /**\n   * Returns all the `Symbol`s in the table. The order should be, but is not required to be,\n   * in declaration order.\n   */\n  values(): Symbol[];\n}\n\n/**\n * A description of a function or method signature.\n *\n * @experimental\n */\nexport interface Signature {\n  /**\n   * The arguments of the signture. The order of `arguments.symbols()` must be in the order\n   * of argument declaration.\n   */\n  readonly arguments: SymbolTable;\n\n  /**\n   * The symbol of the signature result type.\n   */\n  readonly result: Symbol;\n}\n\n/**\n * An enumeration of basic types.\n *\n * @experimental\n */\nexport enum BuiltinType {\n  /**\n   * The type is a type that can hold any other type.\n   */\n  Any,\n\n  /**\n   * The type of a string literal.\n   */\n  String,\n\n  /**\n   * The type of a numeric literal.\n   */\n  Number,\n\n  /**\n   * The type of the `true` and `false` literals.\n   */\n  Boolean,\n\n  /**\n   * The type of the `undefined` literal.\n   */\n  Undefined,\n\n  /**\n   * the type of the `null` literal.\n   */\n  Null,\n\n  /**\n   * the type is an unbound type parameter.\n   */\n  Unbound,\n\n  /**\n   * Not a built-in type.\n   */\n  Other\n}\n\n/**\n * The kinds of definition.\n *\n * @experimental\n */\nexport type DeclarationKind = 'attribute' | 'html attribute' | 'component' | 'element' | 'entity' |\n    'key' | 'method' | 'pipe' | 'property' | 'type' | 'reference' | 'variable';\n\n/**\n * Describes a symbol to type binding used to build a symbol table.\n *\n * @experimental\n */\nexport interface SymbolDeclaration {\n  /**\n   * The name of the symbol in table.\n   */\n  readonly name: string;\n\n  /**\n   * The kind of symbol to declare.\n   */\n  readonly kind: DeclarationKind;\n\n  /**\n   * Type of the symbol. The type symbol should refer to a symbol for a type.\n   */\n  readonly type: Symbol;\n\n  /**\n   * The definion of the symbol if one exists.\n   */\n  readonly definition?: Definition;\n}\n\n/**\n * Information about the pipes that are available for use in a template.\n *\n * @experimental\n */\nexport interface PipeInfo {\n  /**\n   * The name of the pipe.\n   */\n  name: string;\n\n  /**\n   * The static symbol for the pipe's constructor.\n   */\n  symbol: StaticSymbol;\n}\n\n/**\n * A sequence of pipe information.\n *\n * @experimental\n */\nexport type Pipes = PipeInfo[] | undefined;\n\n/**\n * Describes the language context in which an Angular expression is evaluated.\n *\n * @experimental\n */\nexport interface SymbolQuery {\n  /**\n   * Return the built-in type this symbol represents or Other if it is not a built-in type.\n   */\n  getTypeKind(symbol: Symbol): BuiltinType;\n\n  /**\n   * Return a symbol representing the given built-in type.\n   */\n  getBuiltinType(kind: BuiltinType): Symbol;\n\n  /**\n   * Return the symbol for a type that represents the union of all the types given. Any value\n   * of one of the types given should be assignable to the returned type. If no one type can\n   * be constructed then this should be the Any type.\n   */\n  getTypeUnion(...types: Symbol[]): Symbol;\n\n  /**\n   * Return a symbol for an array type that has the `type` as its element type.\n   */\n  getArrayType(type: Symbol): Symbol;\n\n  /**\n   * Return element type symbol for an array type if the `type` is an array type. Otherwise return\n   * undefined.\n   */\n  getElementType(type: Symbol): Symbol|undefined;\n\n  /**\n   * Return a type that is the non-nullable version of the given type. If `type` is already\n   * non-nullable, return `type`.\n   */\n  getNonNullableType(type: Symbol): Symbol;\n\n  /**\n   * Return a symbol table for the pipes that are in scope.\n   */\n  getPipes(): SymbolTable;\n\n  /**\n   * Return the type symbol for the given static symbol.\n   */\n  getTypeSymbol(type: StaticSymbol): Symbol|undefined;\n\n  /**\n   * Return the members that are in the context of a type's template reference.\n   */\n  getTemplateContext(type: StaticSymbol): SymbolTable|undefined;\n\n  /**\n   * Produce a symbol table with the given symbols. Used to produce a symbol table\n   * for use with mergeSymbolTables().\n   */\n  createSymbolTable(symbols: SymbolDeclaration[]): SymbolTable;\n\n  /**\n   * Produce a merged symbol table. If the symbol tables contain duplicate entries\n   * the entries of the latter symbol tables will obscure the entries in the prior\n   * symbol tables.\n   *\n   * The symbol tables passed to this routine MUST be produces by the same instance\n   * of SymbolQuery that is being called.\n   */\n  mergeSymbolTable(symbolTables: SymbolTable[]): SymbolTable;\n\n  /**\n   * Return the span of the narrowest non-token node at the given location.\n   */\n  getSpanAt(line: number, column: number): Span|undefined;\n}"]}
60
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"symbols.js","sourceRoot":"","sources":["../../../../../../../packages/compiler-cli/src/diagnostics/symbols.ts"],"names":[],"mappings":"AAAA;;;;;;GAMG;;;;;;;;;;;;IAoKH;;;;OAIG;IACH,IAAY,WAwCX;IAxCD,WAAY,WAAW;QACrB;;WAEG;QACH,2CAAG,CAAA;QAEH;;WAEG;QACH,iDAAM,CAAA;QAEN;;WAEG;QACH,iDAAM,CAAA;QAEN;;WAEG;QACH,mDAAO,CAAA;QAEP;;WAEG;QACH,uDAAS,CAAA;QAET;;WAEG;QACH,6CAAI,CAAA;QAEJ;;WAEG;QACH,mDAAO,CAAA;QAEP;;WAEG;QACH,+CAAK,CAAA;IACP,CAAC,EAxCW,WAAW,GAAX,mBAAW,KAAX,mBAAW,QAwCtB","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 {StaticSymbol} from '@angular/compiler';\n\n/**\n * The range of a span of text in a source file.\n *\n * @publicApi\n */\nexport interface Span {\n  /**\n   * The first code-point of the span as an offset relative to the beginning of the source assuming\n   * a UTF-16 encoding.\n   */\n  start: number;\n\n  /**\n   * The first code-point after the span as an offset relative to the beginning of the source\n   * assuming a UTF-16 encoding.\n   */\n  end: number;\n}\n\n/**\n * A file and span.\n */\nexport interface Location {\n  fileName: string;\n  span: Span;\n}\n\n/**\n * A defnition location(s).\n */\nexport type Definition = Location[] | undefined;\n\n/**\n * A symbol describing a language element that can be referenced by expressions\n * in an Angular template.\n *\n * @publicApi\n */\nexport interface Symbol {\n  /**\n   * The name of the symbol as it would be referenced in an Angular expression.\n   */\n  readonly name: string;\n\n  /**\n   * The kind of completion this symbol should generate if included.\n   */\n  readonly kind: string;\n\n  /**\n   * The language of the source that defines the symbol. (e.g. typescript for TypeScript,\n   * ng-template for an Angular template, etc.)\n   */\n  readonly language: string;\n\n  /**\n   * A symbol representing type of the symbol.\n   */\n  readonly type: Symbol|undefined;\n\n  /**\n   * A symbol for the container of this symbol. For example, if this is a method, the container\n   * is the class or interface of the method. If no container is appropriate, undefined is\n   * returned.\n   */\n  readonly container: Symbol|undefined;\n\n  /**\n   * The symbol is public in the container.\n   */\n  readonly public: boolean;\n\n  /**\n   * `true` if the symbol can be the target of a call.\n   */\n  readonly callable: boolean;\n\n  /**\n   * The location of the definition of the symbol\n   */\n  readonly definition: Definition|undefined;\n\n  /**\n   * `true` if the symbol is a type that is nullable (can be null or undefined).\n   */\n  readonly nullable: boolean;\n\n  /**\n   * A table of the members of the symbol; that is, the members that can appear\n   * after a `.` in an Angular expression.\n   */\n  members(): SymbolTable;\n\n  /**\n   * The list of overloaded signatures that can be used if the symbol is the\n   * target of a call.\n   */\n  signatures(): Signature[];\n\n  /**\n   * Return which signature of returned by `signatures()` would be used selected\n   * given the `types` supplied. If no signature would match, this method should\n   * return `undefined`.\n   */\n  selectSignature(types: Symbol[]): Signature|undefined;\n\n  /**\n   * Return the type of the expression if this symbol is indexed by `argument`.\n   * If the symbol cannot be indexed, this method should return `undefined`.\n   */\n  indexed(argument: Symbol): Symbol|undefined;\n}\n\n/**\n * A table of `Symbol`s accessible by name.\n *\n * @publicApi\n */\nexport interface SymbolTable {\n  /**\n   * The number of symbols in the table.\n   */\n  readonly size: number;\n\n  /**\n   * Get the symbol corresponding to `key` or `undefined` if there is no symbol in the\n   * table by the name `key`.\n   */\n  get(key: string): Symbol|undefined;\n\n  /**\n   * Returns `true` if the table contains a `Symbol` with the name `key`.\n   */\n  has(key: string): boolean;\n\n  /**\n   * Returns all the `Symbol`s in the table. The order should be, but is not required to be,\n   * in declaration order.\n   */\n  values(): Symbol[];\n}\n\n/**\n * A description of a function or method signature.\n *\n * @publicApi\n */\nexport interface Signature {\n  /**\n   * The arguments of the signture. The order of `arguments.symbols()` must be in the order\n   * of argument declaration.\n   */\n  readonly arguments: SymbolTable;\n\n  /**\n   * The symbol of the signature result type.\n   */\n  readonly result: Symbol;\n}\n\n/**\n * An enumeration of basic types.\n *\n * @publicApi\n */\nexport enum BuiltinType {\n  /**\n   * The type is a type that can hold any other type.\n   */\n  Any,\n\n  /**\n   * The type of a string literal.\n   */\n  String,\n\n  /**\n   * The type of a numeric literal.\n   */\n  Number,\n\n  /**\n   * The type of the `true` and `false` literals.\n   */\n  Boolean,\n\n  /**\n   * The type of the `undefined` literal.\n   */\n  Undefined,\n\n  /**\n   * the type of the `null` literal.\n   */\n  Null,\n\n  /**\n   * the type is an unbound type parameter.\n   */\n  Unbound,\n\n  /**\n   * Not a built-in type.\n   */\n  Other\n}\n\n/**\n * The kinds of definition.\n *\n * @publicApi\n */\nexport type DeclarationKind = 'attribute' | 'html attribute' | 'component' | 'element' | 'entity' |\n    'key' | 'method' | 'pipe' | 'property' | 'type' | 'reference' | 'variable';\n\n/**\n * Describes a symbol to type binding used to build a symbol table.\n *\n * @publicApi\n */\nexport interface SymbolDeclaration {\n  /**\n   * The name of the symbol in table.\n   */\n  readonly name: string;\n\n  /**\n   * The kind of symbol to declare.\n   */\n  readonly kind: DeclarationKind;\n\n  /**\n   * Type of the symbol. The type symbol should refer to a symbol for a type.\n   */\n  readonly type: Symbol;\n\n  /**\n   * The definion of the symbol if one exists.\n   */\n  readonly definition?: Definition;\n}\n\n/**\n * Information about the pipes that are available for use in a template.\n *\n * @publicApi\n */\nexport interface PipeInfo {\n  /**\n   * The name of the pipe.\n   */\n  name: string;\n\n  /**\n   * The static symbol for the pipe's constructor.\n   */\n  symbol: StaticSymbol;\n}\n\n/**\n * A sequence of pipe information.\n *\n * @publicApi\n */\nexport type Pipes = PipeInfo[] | undefined;\n\n/**\n * Describes the language context in which an Angular expression is evaluated.\n *\n * @publicApi\n */\nexport interface SymbolQuery {\n  /**\n   * Return the built-in type this symbol represents or Other if it is not a built-in type.\n   */\n  getTypeKind(symbol: Symbol): BuiltinType;\n\n  /**\n   * Return a symbol representing the given built-in type.\n   */\n  getBuiltinType(kind: BuiltinType): Symbol;\n\n  /**\n   * Return the symbol for a type that represents the union of all the types given. Any value\n   * of one of the types given should be assignable to the returned type. If no one type can\n   * be constructed then this should be the Any type.\n   */\n  getTypeUnion(...types: Symbol[]): Symbol;\n\n  /**\n   * Return a symbol for an array type that has the `type` as its element type.\n   */\n  getArrayType(type: Symbol): Symbol;\n\n  /**\n   * Return element type symbol for an array type if the `type` is an array type. Otherwise return\n   * undefined.\n   */\n  getElementType(type: Symbol): Symbol|undefined;\n\n  /**\n   * Return a type that is the non-nullable version of the given type. If `type` is already\n   * non-nullable, return `type`.\n   */\n  getNonNullableType(type: Symbol): Symbol;\n\n  /**\n   * Return a symbol table for the pipes that are in scope.\n   */\n  getPipes(): SymbolTable;\n\n  /**\n   * Return the type symbol for the given static symbol.\n   */\n  getTypeSymbol(type: StaticSymbol): Symbol|undefined;\n\n  /**\n   * Return the members that are in the context of a type's template reference.\n   */\n  getTemplateContext(type: StaticSymbol): SymbolTable|undefined;\n\n  /**\n   * Produce a symbol table with the given symbols. Used to produce a symbol table\n   * for use with mergeSymbolTables().\n   */\n  createSymbolTable(symbols: SymbolDeclaration[]): SymbolTable;\n\n  /**\n   * Produce a merged symbol table. If the symbol tables contain duplicate entries\n   * the entries of the latter symbol tables will obscure the entries in the prior\n   * symbol tables.\n   *\n   * The symbol tables passed to this routine MUST be produces by the same instance\n   * of SymbolQuery that is being called.\n   */\n  mergeSymbolTable(symbolTables: SymbolTable[]): SymbolTable;\n\n  /**\n   * Return the span of the narrowest non-token node at the given location.\n   */\n  getSpanAt(line: number, column: number): Span|undefined;\n}"]}
@@ -0,0 +1,65 @@
1
+ /// <amd-module name="@angular/compiler-cli/src/ngcc/src/analysis/decoration_analyzer" />
2
+ /**
3
+ * @license
4
+ * Copyright Google Inc. All Rights Reserved.
5
+ *
6
+ * Use of this source code is governed by an MIT-style license that can be
7
+ * found in the LICENSE file at https://angular.io/license
8
+ */
9
+ import { ConstantPool } from '@angular/compiler';
10
+ import * as ts from 'typescript';
11
+ import { ResourceLoader, SelectorScopeRegistry } from '../../../ngtsc/annotations';
12
+ import { CompileResult, DecoratorHandler } from '../../../ngtsc/transform';
13
+ import { DecoratedClass } from '../host/decorated_class';
14
+ import { DecoratedFile } from '../host/decorated_file';
15
+ import { NgccReflectionHost } from '../host/ngcc_host';
16
+ export interface AnalyzedClass<A = any, M = any> extends DecoratedClass {
17
+ handler: DecoratorHandler<A, M>;
18
+ analysis: any;
19
+ diagnostics?: ts.Diagnostic[];
20
+ compilation: CompileResult[];
21
+ }
22
+ export interface DecorationAnalysis {
23
+ analyzedClasses: AnalyzedClass[];
24
+ sourceFile: ts.SourceFile;
25
+ constantPool: ConstantPool;
26
+ }
27
+ export declare type DecorationAnalyses = Map<ts.SourceFile, DecorationAnalysis>;
28
+ export declare const DecorationAnalyses: MapConstructor;
29
+ export interface MatchingHandler<A, M> {
30
+ handler: DecoratorHandler<A, M>;
31
+ match: M;
32
+ }
33
+ /**
34
+ * `ResourceLoader` which directly uses the filesystem to resolve resources synchronously.
35
+ */
36
+ export declare class FileResourceLoader implements ResourceLoader {
37
+ load(url: string): string;
38
+ }
39
+ /**
40
+ * This Analyzer will analyze the files that have decorated classes that need to be transformed.
41
+ */
42
+ export declare class DecorationAnalyzer {
43
+ private typeChecker;
44
+ private host;
45
+ private rootDirs;
46
+ private isCore;
47
+ resourceLoader: FileResourceLoader;
48
+ scopeRegistry: SelectorScopeRegistry;
49
+ handlers: DecoratorHandler<any, any>[];
50
+ constructor(typeChecker: ts.TypeChecker, host: NgccReflectionHost, rootDirs: string[], isCore: boolean);
51
+ /**
52
+ * Analyze a program to find all the decorated files should be transformed.
53
+ * @param program The program whose files should be analysed.
54
+ * @returns a map of the source files to the analysis for those files.
55
+ */
56
+ analyzeProgram(program: ts.Program): DecorationAnalyses;
57
+ /**
58
+ * Analyze a decorated file to generate the information about decorated classes that
59
+ * should be converted to use ivy definitions.
60
+ * @param file The file to be analysed for decorated classes.
61
+ * @returns the analysis of the file
62
+ */
63
+ protected analyzeFile(file: DecoratedFile): DecorationAnalysis;
64
+ protected analyzeClass(pool: ConstantPool, clazz: DecoratedClass): AnalyzedClass | undefined;
65
+ }
@@ -0,0 +1,116 @@
1
+ (function (factory) {
2
+ if (typeof module === "object" && typeof module.exports === "object") {
3
+ var v = factory(require, exports);
4
+ if (v !== undefined) module.exports = v;
5
+ }
6
+ else if (typeof define === "function" && define.amd) {
7
+ define("@angular/compiler-cli/src/ngcc/src/analysis/decoration_analyzer", ["require", "exports", "tslib", "@angular/compiler", "fs", "@angular/compiler-cli/src/ngtsc/annotations", "@angular/compiler-cli/src/ngcc/src/utils"], factory);
8
+ }
9
+ })(function (require, exports) {
10
+ "use strict";
11
+ Object.defineProperty(exports, "__esModule", { value: true });
12
+ var tslib_1 = require("tslib");
13
+ /**
14
+ * @license
15
+ * Copyright Google Inc. All Rights Reserved.
16
+ *
17
+ * Use of this source code is governed by an MIT-style license that can be
18
+ * found in the LICENSE file at https://angular.io/license
19
+ */
20
+ var compiler_1 = require("@angular/compiler");
21
+ var fs = require("fs");
22
+ var annotations_1 = require("@angular/compiler-cli/src/ngtsc/annotations");
23
+ var utils_1 = require("@angular/compiler-cli/src/ngcc/src/utils");
24
+ exports.DecorationAnalyses = Map;
25
+ /**
26
+ * `ResourceLoader` which directly uses the filesystem to resolve resources synchronously.
27
+ */
28
+ var FileResourceLoader = /** @class */ (function () {
29
+ function FileResourceLoader() {
30
+ }
31
+ FileResourceLoader.prototype.load = function (url) { return fs.readFileSync(url, 'utf8'); };
32
+ return FileResourceLoader;
33
+ }());
34
+ exports.FileResourceLoader = FileResourceLoader;
35
+ /**
36
+ * This Analyzer will analyze the files that have decorated classes that need to be transformed.
37
+ */
38
+ var DecorationAnalyzer = /** @class */ (function () {
39
+ function DecorationAnalyzer(typeChecker, host, rootDirs, isCore) {
40
+ this.typeChecker = typeChecker;
41
+ this.host = host;
42
+ this.rootDirs = rootDirs;
43
+ this.isCore = isCore;
44
+ this.resourceLoader = new FileResourceLoader();
45
+ this.scopeRegistry = new annotations_1.SelectorScopeRegistry(this.typeChecker, this.host);
46
+ this.handlers = [
47
+ new annotations_1.BaseDefDecoratorHandler(this.typeChecker, this.host),
48
+ new annotations_1.ComponentDecoratorHandler(this.typeChecker, this.host, this.scopeRegistry, this.isCore, this.resourceLoader, this.rootDirs),
49
+ new annotations_1.DirectiveDecoratorHandler(this.typeChecker, this.host, this.scopeRegistry, this.isCore),
50
+ new annotations_1.InjectableDecoratorHandler(this.host, this.isCore),
51
+ new annotations_1.NgModuleDecoratorHandler(this.typeChecker, this.host, this.scopeRegistry, this.isCore),
52
+ new annotations_1.PipeDecoratorHandler(this.typeChecker, this.host, this.scopeRegistry, this.isCore),
53
+ ];
54
+ }
55
+ /**
56
+ * Analyze a program to find all the decorated files should be transformed.
57
+ * @param program The program whose files should be analysed.
58
+ * @returns a map of the source files to the analysis for those files.
59
+ */
60
+ DecorationAnalyzer.prototype.analyzeProgram = function (program) {
61
+ var _this = this;
62
+ var analyzedFiles = new exports.DecorationAnalyses();
63
+ program.getRootFileNames().forEach(function (fileName) {
64
+ var entryPoint = program.getSourceFile(fileName);
65
+ var decoratedFiles = _this.host.findDecoratedFiles(entryPoint);
66
+ decoratedFiles.forEach(function (decoratedFile) {
67
+ return analyzedFiles.set(decoratedFile.sourceFile, _this.analyzeFile(decoratedFile));
68
+ });
69
+ });
70
+ return analyzedFiles;
71
+ };
72
+ /**
73
+ * Analyze a decorated file to generate the information about decorated classes that
74
+ * should be converted to use ivy definitions.
75
+ * @param file The file to be analysed for decorated classes.
76
+ * @returns the analysis of the file
77
+ */
78
+ DecorationAnalyzer.prototype.analyzeFile = function (file) {
79
+ var _this = this;
80
+ var constantPool = new compiler_1.ConstantPool();
81
+ var analyzedClasses = file.decoratedClasses.map(function (clazz) { return _this.analyzeClass(constantPool, clazz); })
82
+ .filter(utils_1.isDefined);
83
+ return {
84
+ analyzedClasses: analyzedClasses,
85
+ sourceFile: file.sourceFile, constantPool: constantPool,
86
+ };
87
+ };
88
+ DecorationAnalyzer.prototype.analyzeClass = function (pool, clazz) {
89
+ var matchingHandlers = this.handlers
90
+ .map(function (handler) { return ({
91
+ handler: handler,
92
+ match: handler.detect(clazz.declaration, clazz.decorators),
93
+ }); })
94
+ .filter(isMatchingHandler);
95
+ if (matchingHandlers.length > 1) {
96
+ throw new Error('TODO.Diagnostic: Class has multiple Angular decorators.');
97
+ }
98
+ if (matchingHandlers.length === 0) {
99
+ return undefined;
100
+ }
101
+ var _a = matchingHandlers[0], handler = _a.handler, match = _a.match;
102
+ var _b = handler.analyze(clazz.declaration, match), analysis = _b.analysis, diagnostics = _b.diagnostics;
103
+ var compilation = handler.compile(clazz.declaration, analysis, pool);
104
+ if (!Array.isArray(compilation)) {
105
+ compilation = [compilation];
106
+ }
107
+ return tslib_1.__assign({}, clazz, { handler: handler, analysis: analysis, diagnostics: diagnostics, compilation: compilation });
108
+ };
109
+ return DecorationAnalyzer;
110
+ }());
111
+ exports.DecorationAnalyzer = DecorationAnalyzer;
112
+ function isMatchingHandler(handler) {
113
+ return !!handler.match;
114
+ }
115
+ });
116
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"decoration_analyzer.js","sourceRoot":"","sources":["../../../../../../../../../packages/compiler-cli/src/ngcc/src/analysis/decoration_analyzer.ts"],"names":[],"mappings":";;;;;;;;;;;;IAAA;;;;;;OAMG;IACH,8CAA+C;IAC/C,uBAAyB;IAGzB,2EAA4O;IAM5O,kEAAmC;IAgBtB,QAAA,kBAAkB,GAAG,GAAG,CAAC;IAOtC;;OAEG;IACH;QAAA;QAEA,CAAC;QADC,iCAAI,GAAJ,UAAK,GAAW,IAAY,OAAO,EAAE,CAAC,YAAY,CAAC,GAAG,EAAE,MAAM,CAAC,CAAC,CAAC,CAAC;QACpE,yBAAC;IAAD,CAAC,AAFD,IAEC;IAFY,gDAAkB;IAI/B;;OAEG;IACH;QAcE,4BACY,WAA2B,EAAU,IAAwB,EAC7D,QAAkB,EAAU,MAAe;YAD3C,gBAAW,GAAX,WAAW,CAAgB;YAAU,SAAI,GAAJ,IAAI,CAAoB;YAC7D,aAAQ,GAAR,QAAQ,CAAU;YAAU,WAAM,GAAN,MAAM,CAAS;YAfvD,mBAAc,GAAG,IAAI,kBAAkB,EAAE,CAAC;YAC1C,kBAAa,GAAG,IAAI,mCAAqB,CAAC,IAAI,CAAC,WAAW,EAAE,IAAI,CAAC,IAAI,CAAC,CAAC;YACvE,aAAQ,GAAiC;gBACvC,IAAI,qCAAuB,CAAC,IAAI,CAAC,WAAW,EAAE,IAAI,CAAC,IAAI,CAAC;gBACxD,IAAI,uCAAyB,CACzB,IAAI,CAAC,WAAW,EAAE,IAAI,CAAC,IAAI,EAAE,IAAI,CAAC,aAAa,EAAE,IAAI,CAAC,MAAM,EAAE,IAAI,CAAC,cAAc,EACjF,IAAI,CAAC,QAAQ,CAAC;gBAClB,IAAI,uCAAyB,CAAC,IAAI,CAAC,WAAW,EAAE,IAAI,CAAC,IAAI,EAAE,IAAI,CAAC,aAAa,EAAE,IAAI,CAAC,MAAM,CAAC;gBAC3F,IAAI,wCAA0B,CAAC,IAAI,CAAC,IAAI,EAAE,IAAI,CAAC,MAAM,CAAC;gBACtD,IAAI,sCAAwB,CAAC,IAAI,CAAC,WAAW,EAAE,IAAI,CAAC,IAAI,EAAE,IAAI,CAAC,aAAa,EAAE,IAAI,CAAC,MAAM,CAAC;gBAC1F,IAAI,kCAAoB,CAAC,IAAI,CAAC,WAAW,EAAE,IAAI,CAAC,IAAI,EAAE,IAAI,CAAC,aAAa,EAAE,IAAI,CAAC,MAAM,CAAC;aACvF,CAAC;QAIwD,CAAC;QAE3D;;;;WAIG;QACH,2CAAc,GAAd,UAAe,OAAmB;YAAlC,iBAUC;YATC,IAAM,aAAa,GAAG,IAAI,0BAAkB,EAAE,CAAC;YAC/C,OAAO,CAAC,gBAAgB,EAAE,CAAC,OAAO,CAAC,UAAA,QAAQ;gBACzC,IAAM,UAAU,GAAG,OAAO,CAAC,aAAa,CAAC,QAAQ,CAAG,CAAC;gBACrD,IAAM,cAAc,GAAG,KAAI,CAAC,IAAI,CAAC,kBAAkB,CAAC,UAAU,CAAC,CAAC;gBAChE,cAAc,CAAC,OAAO,CAClB,UAAA,aAAa;oBACT,OAAA,aAAa,CAAC,GAAG,CAAC,aAAa,CAAC,UAAU,EAAE,KAAI,CAAC,WAAW,CAAC,aAAa,CAAC,CAAC;gBAA5E,CAA4E,CAAC,CAAC;YACxF,CAAC,CAAC,CAAC;YACH,OAAO,aAAa,CAAC;QACvB,CAAC;QAED;;;;;WAKG;QACO,wCAAW,GAArB,UAAsB,IAAmB;YAAzC,iBAUC;YATC,IAAM,YAAY,GAAG,IAAI,uBAAY,EAAE,CAAC;YACxC,IAAM,eAAe,GACjB,IAAI,CAAC,gBAAgB,CAAC,GAAG,CAAC,UAAA,KAAK,IAAI,OAAA,KAAI,CAAC,YAAY,CAAC,YAAY,EAAE,KAAK,CAAC,EAAtC,CAAsC,CAAC;iBACrE,MAAM,CAAC,iBAAS,CAAC,CAAC;YAE3B,OAAO;gBACL,eAAe,iBAAA;gBACf,UAAU,EAAE,IAAI,CAAC,UAAU,EAAE,YAAY,cAAA;aAC1C,CAAC;QACJ,CAAC;QAES,yCAAY,GAAtB,UAAuB,IAAkB,EAAE,KAAqB;YAC9D,IAAM,gBAAgB,GAAG,IAAI,CAAC,QAAQ;iBACR,GAAG,CAAC,UAAA,OAAO,IAAI,OAAA,CAAC;gBACV,OAAO,SAAA;gBACP,KAAK,EAAE,OAAO,CAAC,MAAM,CAAC,KAAK,CAAC,WAAW,EAAE,KAAK,CAAC,UAAU,CAAC;aAC3D,CAAC,EAHS,CAGT,CAAC;iBACP,MAAM,CAAC,iBAAiB,CAAC,CAAC;YAExD,IAAI,gBAAgB,CAAC,MAAM,GAAG,CAAC,EAAE;gBAC/B,MAAM,IAAI,KAAK,CAAC,yDAAyD,CAAC,CAAC;aAC5E;YAED,IAAI,gBAAgB,CAAC,MAAM,KAAK,CAAC,EAAE;gBACjC,OAAO,SAAS,CAAC;aAClB;YAEK,IAAA,wBAAsC,EAArC,oBAAO,EAAE,gBAA4B,CAAC;YACvC,IAAA,8CAAmE,EAAlE,sBAAQ,EAAE,4BAAwD,CAAC;YAC1E,IAAI,WAAW,GAAG,OAAO,CAAC,OAAO,CAAC,KAAK,CAAC,WAAW,EAAE,QAAQ,EAAE,IAAI,CAAC,CAAC;YACrE,IAAI,CAAC,KAAK,CAAC,OAAO,CAAC,WAAW,CAAC,EAAE;gBAC/B,WAAW,GAAG,CAAC,WAAW,CAAC,CAAC;aAC7B;YACD,4BAAW,KAAK,IAAE,OAAO,SAAA,EAAE,QAAQ,UAAA,EAAE,WAAW,aAAA,EAAE,WAAW,aAAA,IAAE;QACjE,CAAC;QACH,yBAAC;IAAD,CAAC,AA7ED,IA6EC;IA7EY,gDAAkB;IA+E/B,SAAS,iBAAiB,CAAO,OAAuC;QAEtE,OAAO,CAAC,CAAC,OAAO,CAAC,KAAK,CAAC;IACzB,CAAC","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 */\nimport {ConstantPool} from '@angular/compiler';\nimport * as fs from 'fs';\nimport * as ts from 'typescript';\n\nimport {BaseDefDecoratorHandler, ComponentDecoratorHandler, DirectiveDecoratorHandler, InjectableDecoratorHandler, NgModuleDecoratorHandler, PipeDecoratorHandler, ResourceLoader, SelectorScopeRegistry} from '../../../ngtsc/annotations';\nimport {CompileResult, DecoratorHandler} from '../../../ngtsc/transform';\n\nimport {DecoratedClass} from '../host/decorated_class';\nimport {DecoratedFile} from '../host/decorated_file';\nimport {NgccReflectionHost} from '../host/ngcc_host';\nimport {isDefined} from '../utils';\n\nexport interface AnalyzedClass<A = any, M = any> extends DecoratedClass {\n  handler: DecoratorHandler<A, M>;\n  analysis: any;\n  diagnostics?: ts.Diagnostic[];\n  compilation: CompileResult[];\n}\n\nexport interface DecorationAnalysis {\n  analyzedClasses: AnalyzedClass[];\n  sourceFile: ts.SourceFile;\n  constantPool: ConstantPool;\n}\n\nexport type DecorationAnalyses = Map<ts.SourceFile, DecorationAnalysis>;\nexport const DecorationAnalyses = Map;\n\nexport interface MatchingHandler<A, M> {\n  handler: DecoratorHandler<A, M>;\n  match: M;\n}\n\n/**\n * `ResourceLoader` which directly uses the filesystem to resolve resources synchronously.\n */\nexport class FileResourceLoader implements ResourceLoader {\n  load(url: string): string { return fs.readFileSync(url, 'utf8'); }\n}\n\n/**\n * This Analyzer will analyze the files that have decorated classes that need to be transformed.\n */\nexport class DecorationAnalyzer {\n  resourceLoader = new FileResourceLoader();\n  scopeRegistry = new SelectorScopeRegistry(this.typeChecker, this.host);\n  handlers: DecoratorHandler<any, any>[] = [\n    new BaseDefDecoratorHandler(this.typeChecker, this.host),\n    new ComponentDecoratorHandler(\n        this.typeChecker, this.host, this.scopeRegistry, this.isCore, this.resourceLoader,\n        this.rootDirs),\n    new DirectiveDecoratorHandler(this.typeChecker, this.host, this.scopeRegistry, this.isCore),\n    new InjectableDecoratorHandler(this.host, this.isCore),\n    new NgModuleDecoratorHandler(this.typeChecker, this.host, this.scopeRegistry, this.isCore),\n    new PipeDecoratorHandler(this.typeChecker, this.host, this.scopeRegistry, this.isCore),\n  ];\n\n  constructor(\n      private typeChecker: ts.TypeChecker, private host: NgccReflectionHost,\n      private rootDirs: string[], private isCore: boolean) {}\n\n  /**\n   * Analyze a program to find all the decorated files should be transformed.\n   * @param program The program whose files should be analysed.\n   * @returns a map of the source files to the analysis for those files.\n   */\n  analyzeProgram(program: ts.Program): DecorationAnalyses {\n    const analyzedFiles = new DecorationAnalyses();\n    program.getRootFileNames().forEach(fileName => {\n      const entryPoint = program.getSourceFile(fileName) !;\n      const decoratedFiles = this.host.findDecoratedFiles(entryPoint);\n      decoratedFiles.forEach(\n          decoratedFile =>\n              analyzedFiles.set(decoratedFile.sourceFile, this.analyzeFile(decoratedFile)));\n    });\n    return analyzedFiles;\n  }\n\n  /**\n   * Analyze a decorated file to generate the information about decorated classes that\n   * should be converted to use ivy definitions.\n   * @param file The file to be analysed for decorated classes.\n   * @returns the analysis of the file\n   */\n  protected analyzeFile(file: DecoratedFile): DecorationAnalysis {\n    const constantPool = new ConstantPool();\n    const analyzedClasses =\n        file.decoratedClasses.map(clazz => this.analyzeClass(constantPool, clazz))\n            .filter(isDefined);\n\n    return {\n      analyzedClasses,\n      sourceFile: file.sourceFile, constantPool,\n    };\n  }\n\n  protected analyzeClass(pool: ConstantPool, clazz: DecoratedClass): AnalyzedClass|undefined {\n    const matchingHandlers = this.handlers\n                                 .map(handler => ({\n                                        handler,\n                                        match: handler.detect(clazz.declaration, clazz.decorators),\n                                      }))\n                                 .filter(isMatchingHandler);\n\n    if (matchingHandlers.length > 1) {\n      throw new Error('TODO.Diagnostic: Class has multiple Angular decorators.');\n    }\n\n    if (matchingHandlers.length === 0) {\n      return undefined;\n    }\n\n    const {handler, match} = matchingHandlers[0];\n    const {analysis, diagnostics} = handler.analyze(clazz.declaration, match);\n    let compilation = handler.compile(clazz.declaration, analysis, pool);\n    if (!Array.isArray(compilation)) {\n      compilation = [compilation];\n    }\n    return {...clazz, handler, analysis, diagnostics, compilation};\n  }\n}\n\nfunction isMatchingHandler<A, M>(handler: Partial<MatchingHandler<A, M>>):\n    handler is MatchingHandler<A, M> {\n  return !!handler.match;\n}\n"]}
@@ -0,0 +1,33 @@
1
+ /// <amd-module name="@angular/compiler-cli/src/ngcc/src/analysis/switch_marker_analyzer" />
2
+ /**
3
+ * @license
4
+ * Copyright Google Inc. All Rights Reserved.
5
+ *
6
+ * Use of this source code is governed by an MIT-style license that can be
7
+ * found in the LICENSE file at https://angular.io/license
8
+ */
9
+ import * as ts from 'typescript';
10
+ import { NgccReflectionHost, SwitchableVariableDeclaration } from '../host/ngcc_host';
11
+ export interface SwitchMarkerAnalysis {
12
+ sourceFile: ts.SourceFile;
13
+ declarations: SwitchableVariableDeclaration[];
14
+ }
15
+ export declare type SwitchMarkerAnalyses = Map<ts.SourceFile, SwitchMarkerAnalysis>;
16
+ export declare const SwitchMarkerAnalyses: MapConstructor;
17
+ /**
18
+ * This Analyzer will analyse the files that have an NGCC switch marker in them
19
+ * that will be replaced.
20
+ */
21
+ export declare class SwitchMarkerAnalyzer {
22
+ private host;
23
+ constructor(host: NgccReflectionHost);
24
+ /**
25
+ * Analyze the files in the program to identify declarations that contain NGCC
26
+ * switch markers.
27
+ * @param program The program to analyze.
28
+ * @return A map of source files to analysis objects. The map will contain only the
29
+ * source files that had switch markers, and the analysis will contain an array of
30
+ * the declarations in that source file that contain the marker.
31
+ */
32
+ analyzeProgram(program: ts.Program): SwitchMarkerAnalyses;
33
+ }
@@ -0,0 +1,44 @@
1
+ (function (factory) {
2
+ if (typeof module === "object" && typeof module.exports === "object") {
3
+ var v = factory(require, exports);
4
+ if (v !== undefined) module.exports = v;
5
+ }
6
+ else if (typeof define === "function" && define.amd) {
7
+ define("@angular/compiler-cli/src/ngcc/src/analysis/switch_marker_analyzer", ["require", "exports"], factory);
8
+ }
9
+ })(function (require, exports) {
10
+ "use strict";
11
+ Object.defineProperty(exports, "__esModule", { value: true });
12
+ exports.SwitchMarkerAnalyses = Map;
13
+ /**
14
+ * This Analyzer will analyse the files that have an NGCC switch marker in them
15
+ * that will be replaced.
16
+ */
17
+ var SwitchMarkerAnalyzer = /** @class */ (function () {
18
+ function SwitchMarkerAnalyzer(host) {
19
+ this.host = host;
20
+ }
21
+ /**
22
+ * Analyze the files in the program to identify declarations that contain NGCC
23
+ * switch markers.
24
+ * @param program The program to analyze.
25
+ * @return A map of source files to analysis objects. The map will contain only the
26
+ * source files that had switch markers, and the analysis will contain an array of
27
+ * the declarations in that source file that contain the marker.
28
+ */
29
+ SwitchMarkerAnalyzer.prototype.analyzeProgram = function (program) {
30
+ var _this = this;
31
+ var analyzedFiles = new exports.SwitchMarkerAnalyses();
32
+ program.getSourceFiles().forEach(function (sourceFile) {
33
+ var declarations = _this.host.getSwitchableDeclarations(sourceFile);
34
+ if (declarations.length) {
35
+ analyzedFiles.set(sourceFile, { sourceFile: sourceFile, declarations: declarations });
36
+ }
37
+ });
38
+ return analyzedFiles;
39
+ };
40
+ return SwitchMarkerAnalyzer;
41
+ }());
42
+ exports.SwitchMarkerAnalyzer = SwitchMarkerAnalyzer;
43
+ });
44
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoic3dpdGNoX21hcmtlcl9hbmFseXplci5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uLy4uLy4uLy4uLy4uL3BhY2thZ2VzL2NvbXBpbGVyLWNsaS9zcmMvbmdjYy9zcmMvYW5hbHlzaXMvc3dpdGNoX21hcmtlcl9hbmFseXplci50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiOzs7Ozs7Ozs7OztJQWdCYSxRQUFBLG9CQUFvQixHQUFHLEdBQUcsQ0FBQztJQUV4Qzs7O09BR0c7SUFDSDtRQUNFLDhCQUFvQixJQUF3QjtZQUF4QixTQUFJLEdBQUosSUFBSSxDQUFvQjtRQUFHLENBQUM7UUFDaEQ7Ozs7Ozs7V0FPRztRQUNILDZDQUFjLEdBQWQsVUFBZSxPQUFtQjtZQUFsQyxpQkFTQztZQVJDLElBQU0sYUFBYSxHQUFHLElBQUksNEJBQW9CLEVBQUUsQ0FBQztZQUNqRCxPQUFPLENBQUMsY0FBYyxFQUFFLENBQUMsT0FBTyxDQUFDLFVBQUEsVUFBVTtnQkFDekMsSUFBTSxZQUFZLEdBQUcsS0FBSSxDQUFDLElBQUksQ0FBQyx5QkFBeUIsQ0FBQyxVQUFVLENBQUMsQ0FBQztnQkFDckUsSUFBSSxZQUFZLENBQUMsTUFBTSxFQUFFO29CQUN2QixhQUFhLENBQUMsR0FBRyxDQUFDLFVBQVUsRUFBRSxFQUFDLFVBQVUsWUFBQSxFQUFFLFlBQVksY0FBQSxFQUFDLENBQUMsQ0FBQztpQkFDM0Q7WUFDSCxDQUFDLENBQUMsQ0FBQztZQUNILE9BQU8sYUFBYSxDQUFDO1FBQ3ZCLENBQUM7UUFDSCwyQkFBQztJQUFELENBQUMsQUFwQkQsSUFvQkM7SUFwQlksb0RBQW9CIiwic291cmNlc0NvbnRlbnQiOlsiLyoqXG4gKiBAbGljZW5zZVxuICogQ29weXJpZ2h0IEdvb2dsZSBJbmMuIEFsbCBSaWdodHMgUmVzZXJ2ZWQuXG4gKlxuICogVXNlIG9mIHRoaXMgc291cmNlIGNvZGUgaXMgZ292ZXJuZWQgYnkgYW4gTUlULXN0eWxlIGxpY2Vuc2UgdGhhdCBjYW4gYmVcbiAqIGZvdW5kIGluIHRoZSBMSUNFTlNFIGZpbGUgYXQgaHR0cHM6Ly9hbmd1bGFyLmlvL2xpY2Vuc2VcbiAqL1xuaW1wb3J0ICogYXMgdHMgZnJvbSAndHlwZXNjcmlwdCc7XG5pbXBvcnQge05nY2NSZWZsZWN0aW9uSG9zdCwgU3dpdGNoYWJsZVZhcmlhYmxlRGVjbGFyYXRpb259IGZyb20gJy4uL2hvc3QvbmdjY19ob3N0JztcblxuZXhwb3J0IGludGVyZmFjZSBTd2l0Y2hNYXJrZXJBbmFseXNpcyB7XG4gIHNvdXJjZUZpbGU6IHRzLlNvdXJjZUZpbGU7XG4gIGRlY2xhcmF0aW9uczogU3dpdGNoYWJsZVZhcmlhYmxlRGVjbGFyYXRpb25bXTtcbn1cblxuZXhwb3J0IHR5cGUgU3dpdGNoTWFya2VyQW5hbHlzZXMgPSBNYXA8dHMuU291cmNlRmlsZSwgU3dpdGNoTWFya2VyQW5hbHlzaXM+O1xuZXhwb3J0IGNvbnN0IFN3aXRjaE1hcmtlckFuYWx5c2VzID0gTWFwO1xuXG4vKipcbiAqIFRoaXMgQW5hbHl6ZXIgd2lsbCBhbmFseXNlIHRoZSBmaWxlcyB0aGF0IGhhdmUgYW4gTkdDQyBzd2l0Y2ggbWFya2VyIGluIHRoZW1cbiAqIHRoYXQgd2lsbCBiZSByZXBsYWNlZC5cbiAqL1xuZXhwb3J0IGNsYXNzIFN3aXRjaE1hcmtlckFuYWx5emVyIHtcbiAgY29uc3RydWN0b3IocHJpdmF0ZSBob3N0OiBOZ2NjUmVmbGVjdGlvbkhvc3QpIHt9XG4gIC8qKlxuICAgKiBBbmFseXplIHRoZSBmaWxlcyBpbiB0aGUgcHJvZ3JhbSB0byBpZGVudGlmeSBkZWNsYXJhdGlvbnMgdGhhdCBjb250YWluIE5HQ0NcbiAgICogc3dpdGNoIG1hcmtlcnMuXG4gICAqIEBwYXJhbSBwcm9ncmFtIFRoZSBwcm9ncmFtIHRvIGFuYWx5emUuXG4gICAqIEByZXR1cm4gQSBtYXAgb2Ygc291cmNlIGZpbGVzIHRvIGFuYWx5c2lzIG9iamVjdHMuIFRoZSBtYXAgd2lsbCBjb250YWluIG9ubHkgdGhlXG4gICAqIHNvdXJjZSBmaWxlcyB0aGF0IGhhZCBzd2l0Y2ggbWFya2VycywgYW5kIHRoZSBhbmFseXNpcyB3aWxsIGNvbnRhaW4gYW4gYXJyYXkgb2ZcbiAgICogdGhlIGRlY2xhcmF0aW9ucyBpbiB0aGF0IHNvdXJjZSBmaWxlIHRoYXQgY29udGFpbiB0aGUgbWFya2VyLlxuICAgKi9cbiAgYW5hbHl6ZVByb2dyYW0ocHJvZ3JhbTogdHMuUHJvZ3JhbSk6IFN3aXRjaE1hcmtlckFuYWx5c2VzIHtcbiAgICBjb25zdCBhbmFseXplZEZpbGVzID0gbmV3IFN3aXRjaE1hcmtlckFuYWx5c2VzKCk7XG4gICAgcHJvZ3JhbS5nZXRTb3VyY2VGaWxlcygpLmZvckVhY2goc291cmNlRmlsZSA9PiB7XG4gICAgICBjb25zdCBkZWNsYXJhdGlvbnMgPSB0aGlzLmhvc3QuZ2V0U3dpdGNoYWJsZURlY2xhcmF0aW9ucyhzb3VyY2VGaWxlKTtcbiAgICAgIGlmIChkZWNsYXJhdGlvbnMubGVuZ3RoKSB7XG4gICAgICAgIGFuYWx5emVkRmlsZXMuc2V0KHNvdXJjZUZpbGUsIHtzb3VyY2VGaWxlLCBkZWNsYXJhdGlvbnN9KTtcbiAgICAgIH1cbiAgICB9KTtcbiAgICByZXR1cm4gYW5hbHl6ZWRGaWxlcztcbiAgfVxufVxuIl19
@@ -5,19 +5,19 @@
5
5
  * Use of this source code is governed by an MIT-style license that can be
6
6
  * found in the LICENSE file at https://angular.io/license
7
7
  */
8
- /// <amd-module name="@angular/compiler-cli/src/ngcc/src/parsing/parsed_class" />
8
+ /// <amd-module name="@angular/compiler-cli/src/ngcc/src/host/decorated_class" />
9
9
  import * as ts from 'typescript';
10
10
  import { Decorator } from '../../../ngtsc/host';
11
11
  /**
12
12
  * A simple container that holds the details of a decorated class that has been
13
- * parsed out of a package.
13
+ * found in a `DecoratedFile`.
14
14
  */
15
- export declare class ParsedClass {
15
+ export declare class DecoratedClass {
16
16
  name: string;
17
17
  declaration: ts.Declaration;
18
18
  decorators: Decorator[];
19
19
  /**
20
- * Initialize a `DecoratedClass` that was found by parsing a package.
20
+ * Initialize a `DecoratedClass` that was found in a `DecoratedFile`.
21
21
  * @param name The name of the class that has been found. This is mostly used
22
22
  * for informational purposes.
23
23
  * @param declaration The TypeScript AST node where this class is declared
@@ -0,0 +1,40 @@
1
+ /**
2
+ * @license
3
+ * Copyright Google Inc. 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/ngcc/src/host/decorated_class", ["require", "exports"], factory);
15
+ }
16
+ })(function (require, exports) {
17
+ "use strict";
18
+ Object.defineProperty(exports, "__esModule", { value: true });
19
+ /**
20
+ * A simple container that holds the details of a decorated class that has been
21
+ * found in a `DecoratedFile`.
22
+ */
23
+ var DecoratedClass = /** @class */ (function () {
24
+ /**
25
+ * Initialize a `DecoratedClass` that was found in a `DecoratedFile`.
26
+ * @param name The name of the class that has been found. This is mostly used
27
+ * for informational purposes.
28
+ * @param declaration The TypeScript AST node where this class is declared
29
+ * @param decorators The collection of decorators that have been found on this class.
30
+ */
31
+ function DecoratedClass(name, declaration, decorators) {
32
+ this.name = name;
33
+ this.declaration = declaration;
34
+ this.decorators = decorators;
35
+ }
36
+ return DecoratedClass;
37
+ }());
38
+ exports.DecoratedClass = DecoratedClass;
39
+ });
40
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiZGVjb3JhdGVkX2NsYXNzLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vLi4vLi4vLi4vLi4vLi4vcGFja2FnZXMvY29tcGlsZXItY2xpL3NyYy9uZ2NjL3NyYy9ob3N0L2RlY29yYXRlZF9jbGFzcy50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQTs7Ozs7O0dBTUc7Ozs7Ozs7Ozs7OztJQUtIOzs7T0FHRztJQUNIO1FBQ0U7Ozs7OztXQU1HO1FBQ0gsd0JBQ1csSUFBWSxFQUFTLFdBQTJCLEVBQVMsVUFBdUI7WUFBaEYsU0FBSSxHQUFKLElBQUksQ0FBUTtZQUFTLGdCQUFXLEdBQVgsV0FBVyxDQUFnQjtZQUFTLGVBQVUsR0FBVixVQUFVLENBQWE7UUFBSyxDQUFDO1FBQ25HLHFCQUFDO0lBQUQsQ0FBQyxBQVZELElBVUM7SUFWWSx3Q0FBYyIsInNvdXJjZXNDb250ZW50IjpbIi8qKlxuICogQGxpY2Vuc2VcbiAqIENvcHlyaWdodCBHb29nbGUgSW5jLiBBbGwgUmlnaHRzIFJlc2VydmVkLlxuICpcbiAqIFVzZSBvZiB0aGlzIHNvdXJjZSBjb2RlIGlzIGdvdmVybmVkIGJ5IGFuIE1JVC1zdHlsZSBsaWNlbnNlIHRoYXQgY2FuIGJlXG4gKiBmb3VuZCBpbiB0aGUgTElDRU5TRSBmaWxlIGF0IGh0dHBzOi8vYW5ndWxhci5pby9saWNlbnNlXG4gKi9cblxuaW1wb3J0ICogYXMgdHMgZnJvbSAndHlwZXNjcmlwdCc7XG5pbXBvcnQge0RlY29yYXRvcn0gZnJvbSAnLi4vLi4vLi4vbmd0c2MvaG9zdCc7XG5cbi8qKlxuICogQSBzaW1wbGUgY29udGFpbmVyIHRoYXQgaG9sZHMgdGhlIGRldGFpbHMgb2YgYSBkZWNvcmF0ZWQgY2xhc3MgdGhhdCBoYXMgYmVlblxuICogZm91bmQgaW4gYSBgRGVjb3JhdGVkRmlsZWAuXG4gKi9cbmV4cG9ydCBjbGFzcyBEZWNvcmF0ZWRDbGFzcyB7XG4gIC8qKlxuICAgKiBJbml0aWFsaXplIGEgYERlY29yYXRlZENsYXNzYCB0aGF0IHdhcyBmb3VuZCBpbiBhIGBEZWNvcmF0ZWRGaWxlYC5cbiAgICogQHBhcmFtIG5hbWUgVGhlIG5hbWUgb2YgdGhlIGNsYXNzIHRoYXQgaGFzIGJlZW4gZm91bmQuIFRoaXMgaXMgbW9zdGx5IHVzZWRcbiAgICogZm9yIGluZm9ybWF0aW9uYWwgcHVycG9zZXMuXG4gICAqIEBwYXJhbSBkZWNsYXJhdGlvbiBUaGUgVHlwZVNjcmlwdCBBU1Qgbm9kZSB3aGVyZSB0aGlzIGNsYXNzIGlzIGRlY2xhcmVkXG4gICAqIEBwYXJhbSBkZWNvcmF0b3JzIFRoZSBjb2xsZWN0aW9uIG9mIGRlY29yYXRvcnMgdGhhdCBoYXZlIGJlZW4gZm91bmQgb24gdGhpcyBjbGFzcy5cbiAgICovXG4gIGNvbnN0cnVjdG9yKFxuICAgICAgcHVibGljIG5hbWU6IHN0cmluZywgcHVibGljIGRlY2xhcmF0aW9uOiB0cy5EZWNsYXJhdGlvbiwgcHVibGljIGRlY29yYXRvcnM6IERlY29yYXRvcltdLCApIHt9XG59XG4iXX0=
@@ -0,0 +1,21 @@
1
+ /**
2
+ * @license
3
+ * Copyright Google Inc. 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
+ /// <amd-module name="@angular/compiler-cli/src/ngcc/src/host/decorated_file" />
9
+ import * as ts from 'typescript';
10
+ import { DecoratedClass } from './decorated_class';
11
+ /**
12
+ * Information about a source file that contains decorated exported classes.
13
+ */
14
+ export declare class DecoratedFile {
15
+ sourceFile: ts.SourceFile;
16
+ /**
17
+ * The decorated exported classes that have been found in the file.
18
+ */
19
+ decoratedClasses: DecoratedClass[];
20
+ constructor(sourceFile: ts.SourceFile);
21
+ }
@@ -0,0 +1,34 @@
1
+ /**
2
+ * @license
3
+ * Copyright Google Inc. 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/ngcc/src/host/decorated_file", ["require", "exports"], factory);
15
+ }
16
+ })(function (require, exports) {
17
+ "use strict";
18
+ Object.defineProperty(exports, "__esModule", { value: true });
19
+ /**
20
+ * Information about a source file that contains decorated exported classes.
21
+ */
22
+ var DecoratedFile = /** @class */ (function () {
23
+ function DecoratedFile(sourceFile) {
24
+ this.sourceFile = sourceFile;
25
+ /**
26
+ * The decorated exported classes that have been found in the file.
27
+ */
28
+ this.decoratedClasses = [];
29
+ }
30
+ return DecoratedFile;
31
+ }());
32
+ exports.DecoratedFile = DecoratedFile;
33
+ });
34
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiZGVjb3JhdGVkX2ZpbGUuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi8uLi8uLi8uLi8uLi9wYWNrYWdlcy9jb21waWxlci1jbGkvc3JjL25nY2Mvc3JjL2hvc3QvZGVjb3JhdGVkX2ZpbGUudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUE7Ozs7OztHQU1HOzs7Ozs7Ozs7Ozs7SUFLSDs7T0FFRztJQUNIO1FBS0UsdUJBQW1CLFVBQXlCO1lBQXpCLGVBQVUsR0FBVixVQUFVLENBQWU7WUFKNUM7O2VBRUc7WUFDSSxxQkFBZ0IsR0FBcUIsRUFBRSxDQUFDO1FBQ0EsQ0FBQztRQUNsRCxvQkFBQztJQUFELENBQUMsQUFORCxJQU1DO0lBTlksc0NBQWEiLCJzb3VyY2VzQ29udGVudCI6WyIvKipcbiAqIEBsaWNlbnNlXG4gKiBDb3B5cmlnaHQgR29vZ2xlIEluYy4gQWxsIFJpZ2h0cyBSZXNlcnZlZC5cbiAqXG4gKiBVc2Ugb2YgdGhpcyBzb3VyY2UgY29kZSBpcyBnb3Zlcm5lZCBieSBhbiBNSVQtc3R5bGUgbGljZW5zZSB0aGF0IGNhbiBiZVxuICogZm91bmQgaW4gdGhlIExJQ0VOU0UgZmlsZSBhdCBodHRwczovL2FuZ3VsYXIuaW8vbGljZW5zZVxuICovXG5cbmltcG9ydCAqIGFzIHRzIGZyb20gJ3R5cGVzY3JpcHQnO1xuaW1wb3J0IHtEZWNvcmF0ZWRDbGFzc30gZnJvbSAnLi9kZWNvcmF0ZWRfY2xhc3MnO1xuXG4vKipcbiAqIEluZm9ybWF0aW9uIGFib3V0IGEgc291cmNlIGZpbGUgdGhhdCBjb250YWlucyBkZWNvcmF0ZWQgZXhwb3J0ZWQgY2xhc3Nlcy5cbiAqL1xuZXhwb3J0IGNsYXNzIERlY29yYXRlZEZpbGUge1xuICAvKipcbiAgICogVGhlIGRlY29yYXRlZCBleHBvcnRlZCBjbGFzc2VzIHRoYXQgaGF2ZSBiZWVuIGZvdW5kIGluIHRoZSBmaWxlLlxuICAgKi9cbiAgcHVibGljIGRlY29yYXRlZENsYXNzZXM6IERlY29yYXRlZENsYXNzW10gPSBbXTtcbiAgY29uc3RydWN0b3IocHVibGljIHNvdXJjZUZpbGU6IHRzLlNvdXJjZUZpbGUpIHt9XG59XG4iXX0=
@@ -8,6 +8,7 @@
8
8
  /// <amd-module name="@angular/compiler-cli/src/ngcc/src/host/esm5_host" />
9
9
  import * as ts from 'typescript';
10
10
  import { ClassMember, Decorator, FunctionDefinition } from '../../../ngtsc/host';
11
+ import { DecoratedFile } from './decorated_file';
11
12
  import { Fesm2015ReflectionHost, ParamInfo } from './fesm2015_host';
12
13
  /**
13
14
  * ESM5 packages contain ECMAScript IIFE functions that act like classes. For example:
@@ -60,6 +61,13 @@ export declare class Esm5ReflectionHost extends Fesm2015ReflectionHost {
60
61
  * @returns an object containing the node, statements and parameters of the function.
61
62
  */
62
63
  getDefinitionOfFunction<T extends ts.FunctionDeclaration | ts.MethodDeclaration | ts.FunctionExpression>(node: T): FunctionDefinition<T>;
64
+ /**
65
+ * Find all the files accessible via an entry-point, that contain decorated classes.
66
+ * @param entryPoint The starting point file for finding files that contain decorated classes.
67
+ * @returns A collection of files objects that hold info about the decorated classes and import
68
+ * information.
69
+ */
70
+ findDecoratedFiles(entryPoint: ts.SourceFile): Map<ts.SourceFile, DecoratedFile>;
63
71
  /**
64
72
  * Find the declarations of the constructor parameters of a class identified by its symbol.
65
73
  *