@angular/compiler-cli 11.2.4 → 11.2.5

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 (60) hide show
  1. package/linker/src/file_linker/partial_linkers/partial_linker_selector.d.ts +1 -1
  2. package/linker/src/file_linker/partial_linkers/partial_linker_selector.js +4 -4
  3. package/ngcc/src/analysis/decoration_analyzer.d.ts +2 -1
  4. package/ngcc/src/analysis/decoration_analyzer.js +6 -4
  5. package/ngcc/src/analysis/ngcc_trait_compiler.d.ts +3 -2
  6. package/ngcc/src/analysis/ngcc_trait_compiler.js +3 -2
  7. package/ngcc/src/analysis/util.js +1 -3
  8. package/ngcc/src/packages/build_marker.d.ts +1 -1
  9. package/ngcc/src/packages/build_marker.js +1 -1
  10. package/package.json +2 -2
  11. package/src/ngtsc/annotations/src/component.d.ts +18 -4
  12. package/src/ngtsc/annotations/src/component.js +135 -23
  13. package/src/ngtsc/annotations/src/directive.d.ts +22 -3
  14. package/src/ngtsc/annotations/src/directive.js +122 -5
  15. package/src/ngtsc/annotations/src/injectable.d.ts +2 -1
  16. package/src/ngtsc/annotations/src/injectable.js +4 -1
  17. package/src/ngtsc/annotations/src/ng_module.d.ts +16 -5
  18. package/src/ngtsc/annotations/src/ng_module.js +121 -39
  19. package/src/ngtsc/annotations/src/pipe.d.ts +12 -1
  20. package/src/ngtsc/annotations/src/pipe.js +29 -3
  21. package/src/ngtsc/annotations/src/util.js +7 -7
  22. package/src/ngtsc/core/src/compiler.d.ts +0 -5
  23. package/src/ngtsc/core/src/compiler.js +9 -111
  24. package/src/ngtsc/core/src/host.d.ts +1 -0
  25. package/src/ngtsc/core/src/host.js +16 -1
  26. package/src/ngtsc/cycles/src/imports.d.ts +2 -3
  27. package/src/ngtsc/cycles/src/imports.js +28 -14
  28. package/src/ngtsc/imports/index.d.ts +1 -1
  29. package/src/ngtsc/imports/index.js +1 -1
  30. package/src/ngtsc/imports/src/alias.d.ts +2 -2
  31. package/src/ngtsc/imports/src/alias.js +3 -3
  32. package/src/ngtsc/imports/src/emitter.d.ts +51 -10
  33. package/src/ngtsc/imports/src/emitter.js +26 -19
  34. package/src/ngtsc/incremental/api.d.ts +0 -14
  35. package/src/ngtsc/incremental/api.js +1 -1
  36. package/src/ngtsc/incremental/semantic_graph/index.d.ts +12 -0
  37. package/src/ngtsc/incremental/semantic_graph/index.js +34 -0
  38. package/src/ngtsc/incremental/semantic_graph/src/api.d.ts +98 -0
  39. package/src/ngtsc/incremental/semantic_graph/src/api.js +51 -0
  40. package/src/ngtsc/incremental/semantic_graph/src/graph.d.ts +105 -0
  41. package/src/ngtsc/incremental/semantic_graph/src/graph.js +302 -0
  42. package/src/ngtsc/incremental/semantic_graph/src/type_parameters.d.ts +30 -0
  43. package/src/ngtsc/incremental/semantic_graph/src/type_parameters.js +55 -0
  44. package/src/ngtsc/incremental/semantic_graph/src/util.d.ts +29 -0
  45. package/src/ngtsc/incremental/semantic_graph/src/util.js +111 -0
  46. package/src/ngtsc/incremental/src/dependency_tracking.d.ts +0 -3
  47. package/src/ngtsc/incremental/src/dependency_tracking.js +9 -50
  48. package/src/ngtsc/incremental/src/state.d.ts +2 -1
  49. package/src/ngtsc/incremental/src/state.js +61 -16
  50. package/src/ngtsc/modulewithproviders/src/scanner.js +2 -2
  51. package/src/ngtsc/scope/src/local.d.ts +0 -13
  52. package/src/ngtsc/scope/src/local.js +2 -16
  53. package/src/ngtsc/transform/src/api.d.ts +16 -2
  54. package/src/ngtsc/transform/src/api.js +1 -1
  55. package/src/ngtsc/transform/src/compilation.d.ts +7 -4
  56. package/src/ngtsc/transform/src/compilation.js +25 -8
  57. package/src/ngtsc/transform/src/trait.d.ts +14 -11
  58. package/src/ngtsc/transform/src/trait.js +7 -3
  59. package/src/ngtsc/typecheck/src/environment.js +3 -3
  60. package/src/version.js +1 -1
@@ -35,7 +35,7 @@
35
35
  * class (like adding fields or type declarations).
36
36
  */
37
37
  var TraitCompiler = /** @class */ (function () {
38
- function TraitCompiler(handlers, reflector, perf, incrementalBuild, compileNonExportedClasses, compilationMode, dtsTransforms) {
38
+ function TraitCompiler(handlers, reflector, perf, incrementalBuild, compileNonExportedClasses, compilationMode, dtsTransforms, semanticDepGraphUpdater) {
39
39
  var e_1, _a;
40
40
  this.handlers = handlers;
41
41
  this.reflector = reflector;
@@ -44,6 +44,7 @@
44
44
  this.compileNonExportedClasses = compileNonExportedClasses;
45
45
  this.compilationMode = compilationMode;
46
46
  this.dtsTransforms = dtsTransforms;
47
+ this.semanticDepGraphUpdater = semanticDepGraphUpdater;
47
48
  /**
48
49
  * Maps class declarations to their `ClassRecord`, which tracks the Ivy traits being applied to
49
50
  * those classes.
@@ -170,7 +171,8 @@
170
171
  var handler = this.handlersByName.get(priorTrait.handler.name);
171
172
  var trait = trait_1.Trait.pending(handler, priorTrait.detected);
172
173
  if (priorTrait.state === trait_1.TraitState.Analyzed || priorTrait.state === trait_1.TraitState.Resolved) {
173
- trait = trait.toAnalyzed(priorTrait.analysis, priorTrait.analysisDiagnostics);
174
+ var symbol = this.makeSymbolForTrait(handler, record.node, priorTrait.analysis);
175
+ trait = trait.toAnalyzed(priorTrait.analysis, priorTrait.analysisDiagnostics, symbol);
174
176
  if (trait.analysis !== null && trait.handler.register !== undefined) {
175
177
  trait.handler.register(record.node, trait.analysis);
176
178
  }
@@ -284,6 +286,20 @@
284
286
  }
285
287
  return foundTraits.length > 0 ? foundTraits : null;
286
288
  };
289
+ TraitCompiler.prototype.makeSymbolForTrait = function (handler, decl, analysis) {
290
+ if (analysis === null) {
291
+ return null;
292
+ }
293
+ var symbol = handler.symbol(decl, analysis);
294
+ if (symbol !== null && this.semanticDepGraphUpdater !== null) {
295
+ var isPrimary = handler.precedence === api_1.HandlerPrecedence.PRIMARY;
296
+ if (!isPrimary) {
297
+ throw new Error("AssertionError: " + handler.name + " returned a symbol but is not a primary handler.");
298
+ }
299
+ this.semanticDepGraphUpdater.registerSymbol(symbol);
300
+ }
301
+ return symbol;
302
+ };
287
303
  TraitCompiler.prototype.analyzeClass = function (clazz, preanalyzeQueue) {
288
304
  var e_6, _a;
289
305
  var _this = this;
@@ -303,7 +319,7 @@
303
319
  }
304
320
  catch (err) {
305
321
  if (err instanceof diagnostics_1.FatalDiagnosticError) {
306
- trait.toAnalyzed(null, [err.toDiagnostic()]);
322
+ trait.toAnalyzed(null, [err.toDiagnostic()], null);
307
323
  return { value: void 0 };
308
324
  }
309
325
  else {
@@ -335,7 +351,7 @@
335
351
  }
336
352
  };
337
353
  TraitCompiler.prototype.analyzeTrait = function (clazz, trait, flags) {
338
- var _a, _b;
354
+ var _a, _b, _c;
339
355
  if (trait.state !== trait_1.TraitState.Pending) {
340
356
  throw new Error("Attempt to analyze trait of " + clazz.name.text + " in state " + trait_1.TraitState[trait.state] + " (expected DETECTED)");
341
357
  }
@@ -346,17 +362,18 @@
346
362
  }
347
363
  catch (err) {
348
364
  if (err instanceof diagnostics_1.FatalDiagnosticError) {
349
- trait.toAnalyzed(null, [err.toDiagnostic()]);
365
+ trait.toAnalyzed(null, [err.toDiagnostic()], null);
350
366
  return;
351
367
  }
352
368
  else {
353
369
  throw err;
354
370
  }
355
371
  }
372
+ var symbol = this.makeSymbolForTrait(trait.handler, clazz, (_a = result.analysis) !== null && _a !== void 0 ? _a : null);
356
373
  if (result.analysis !== undefined && trait.handler.register !== undefined) {
357
374
  trait.handler.register(clazz, result.analysis);
358
375
  }
359
- trait = trait.toAnalyzed((_a = result.analysis) !== null && _a !== void 0 ? _a : null, (_b = result.diagnostics) !== null && _b !== void 0 ? _b : null);
376
+ trait = trait.toAnalyzed((_b = result.analysis) !== null && _b !== void 0 ? _b : null, (_c = result.diagnostics) !== null && _c !== void 0 ? _c : null, symbol);
360
377
  };
361
378
  TraitCompiler.prototype.resolve = function () {
362
379
  var e_7, _a, e_8, _b, e_9, _c;
@@ -389,7 +406,7 @@
389
406
  }
390
407
  var result = void 0;
391
408
  try {
392
- result = handler.resolve(clazz, trait.analysis);
409
+ result = handler.resolve(clazz, trait.analysis, trait.symbol);
393
410
  }
394
411
  catch (err) {
395
412
  if (err instanceof diagnostics_1.FatalDiagnosticError) {
@@ -704,4 +721,4 @@
704
721
  }());
705
722
  exports.TraitCompiler = TraitCompiler;
706
723
  });
707
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"compilation.js","sourceRoot":"","sources":["../../../../../../../../../packages/compiler-cli/src/ngtsc/transform/src/compilation.ts"],"names":[],"mappings":"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","sourcesContent":["/**\n * @license\n * Copyright Google LLC All Rights Reserved.\n *\n * Use of this source code is governed by an MIT-style license that can be\n * found in the LICENSE file at https://angular.io/license\n */\n\nimport {ConstantPool} from '@angular/compiler';\nimport * as ts from 'typescript';\n\nimport {ErrorCode, FatalDiagnosticError} from '../../diagnostics';\nimport {IncrementalBuild} from '../../incremental/api';\nimport {IndexingContext} from '../../indexer';\nimport {PerfRecorder} from '../../perf';\nimport {ClassDeclaration, DeclarationNode, Decorator, ReflectionHost} from '../../reflection';\nimport {ProgramTypeCheckAdapter, TypeCheckContext} from '../../typecheck/api';\nimport {getSourceFile, isExported} from '../../util/src/typescript';\n\nimport {AnalysisOutput, CompilationMode, CompileResult, DecoratorHandler, HandlerFlags, HandlerPrecedence, ResolveResult} from './api';\nimport {DtsTransformRegistry} from './declaration';\nimport {PendingTrait, Trait, TraitState} from './trait';\n\n\n/**\n * Records information about a specific class that has matched traits.\n */\nexport interface ClassRecord {\n  /**\n   * The `ClassDeclaration` of the class which has Angular traits applied.\n   */\n  node: ClassDeclaration;\n\n  /**\n   * All traits which matched on the class.\n   */\n  traits: Trait<unknown, unknown, unknown>[];\n\n  /**\n   * Meta-diagnostics about the class, which are usually related to whether certain combinations of\n   * Angular decorators are not permitted.\n   */\n  metaDiagnostics: ts.Diagnostic[]|null;\n\n  // Subsequent fields are \"internal\" and used during the matching of `DecoratorHandler`s. This is\n  // mutable state during the `detect`/`analyze` phases of compilation.\n\n  /**\n   * Whether `traits` contains traits matched from `DecoratorHandler`s marked as `WEAK`.\n   */\n  hasWeakHandlers: boolean;\n\n  /**\n   * Whether `traits` contains a trait from a `DecoratorHandler` matched as `PRIMARY`.\n   */\n  hasPrimaryHandler: boolean;\n}\n\n/**\n * The heart of Angular compilation.\n *\n * The `TraitCompiler` is responsible for processing all classes in the program. Any time a\n * `DecoratorHandler` matches a class, a \"trait\" is created to represent that Angular aspect of the\n * class (such as the class having a component definition).\n *\n * The `TraitCompiler` transitions each trait through the various phases of compilation, culminating\n * in the production of `CompileResult`s instructing the compiler to apply various mutations to the\n * class (like adding fields or type declarations).\n */\nexport class TraitCompiler implements ProgramTypeCheckAdapter {\n  /**\n   * Maps class declarations to their `ClassRecord`, which tracks the Ivy traits being applied to\n   * those classes.\n   */\n  private classes = new Map<ClassDeclaration, ClassRecord>();\n\n  /**\n   * Maps source files to any class declaration(s) within them which have been discovered to contain\n   * Ivy traits.\n   */\n  protected fileToClasses = new Map<ts.SourceFile, Set<ClassDeclaration>>();\n\n  private reexportMap = new Map<string, Map<string, [string, string]>>();\n\n  private handlersByName = new Map<string, DecoratorHandler<unknown, unknown, unknown>>();\n\n  constructor(\n      private handlers: DecoratorHandler<unknown, unknown, unknown>[],\n      private reflector: ReflectionHost, private perf: PerfRecorder,\n      private incrementalBuild: IncrementalBuild<ClassRecord, unknown>,\n      private compileNonExportedClasses: boolean, private compilationMode: CompilationMode,\n      private dtsTransforms: DtsTransformRegistry) {\n    for (const handler of handlers) {\n      this.handlersByName.set(handler.name, handler);\n    }\n  }\n\n  analyzeSync(sf: ts.SourceFile): void {\n    this.analyze(sf, false);\n  }\n\n  analyzeAsync(sf: ts.SourceFile): Promise<void>|undefined {\n    return this.analyze(sf, true);\n  }\n\n  private analyze(sf: ts.SourceFile, preanalyze: false): void;\n  private analyze(sf: ts.SourceFile, preanalyze: true): Promise<void>|undefined;\n  private analyze(sf: ts.SourceFile, preanalyze: boolean): Promise<void>|undefined {\n    // We shouldn't analyze declaration files.\n    if (sf.isDeclarationFile) {\n      return undefined;\n    }\n\n    // analyze() really wants to return `Promise<void>|void`, but TypeScript cannot narrow a return\n    // type of 'void', so `undefined` is used instead.\n    const promises: Promise<void>[] = [];\n\n    const priorWork = this.incrementalBuild.priorWorkFor(sf);\n    if (priorWork !== null) {\n      for (const priorRecord of priorWork) {\n        this.adopt(priorRecord);\n      }\n\n      // Skip the rest of analysis, as this file's prior traits are being reused.\n      return;\n    }\n\n    const visit = (node: ts.Node): void => {\n      if (this.reflector.isClass(node)) {\n        this.analyzeClass(node, preanalyze ? promises : null);\n      }\n      ts.forEachChild(node, visit);\n    };\n\n    visit(sf);\n\n    if (preanalyze && promises.length > 0) {\n      return Promise.all(promises).then(() => undefined as void);\n    } else {\n      return undefined;\n    }\n  }\n\n  recordFor(clazz: ClassDeclaration): ClassRecord|null {\n    if (this.classes.has(clazz)) {\n      return this.classes.get(clazz)!;\n    } else {\n      return null;\n    }\n  }\n\n  recordsFor(sf: ts.SourceFile): ClassRecord[]|null {\n    if (!this.fileToClasses.has(sf)) {\n      return null;\n    }\n    const records: ClassRecord[] = [];\n    for (const clazz of this.fileToClasses.get(sf)!) {\n      records.push(this.classes.get(clazz)!);\n    }\n    return records;\n  }\n\n  /**\n   * Import a `ClassRecord` from a previous compilation.\n   *\n   * Traits from the `ClassRecord` have accurate metadata, but the `handler` is from the old program\n   * and needs to be updated (matching is done by name). A new pending trait is created and then\n   * transitioned to analyzed using the previous analysis. If the trait is in the errored state,\n   * instead the errors are copied over.\n   */\n  private adopt(priorRecord: ClassRecord): void {\n    const record: ClassRecord = {\n      hasPrimaryHandler: priorRecord.hasPrimaryHandler,\n      hasWeakHandlers: priorRecord.hasWeakHandlers,\n      metaDiagnostics: priorRecord.metaDiagnostics,\n      node: priorRecord.node,\n      traits: [],\n    };\n\n    for (const priorTrait of priorRecord.traits) {\n      const handler = this.handlersByName.get(priorTrait.handler.name)!;\n      let trait: Trait<unknown, unknown, unknown> = Trait.pending(handler, priorTrait.detected);\n\n      if (priorTrait.state === TraitState.Analyzed || priorTrait.state === TraitState.Resolved) {\n        trait = trait.toAnalyzed(priorTrait.analysis, priorTrait.analysisDiagnostics);\n        if (trait.analysis !== null && trait.handler.register !== undefined) {\n          trait.handler.register(record.node, trait.analysis);\n        }\n      } else if (priorTrait.state === TraitState.Skipped) {\n        trait = trait.toSkipped();\n      }\n\n      record.traits.push(trait);\n    }\n\n    this.classes.set(record.node, record);\n    const sf = record.node.getSourceFile();\n    if (!this.fileToClasses.has(sf)) {\n      this.fileToClasses.set(sf, new Set<ClassDeclaration>());\n    }\n    this.fileToClasses.get(sf)!.add(record.node);\n  }\n\n  private scanClassForTraits(clazz: ClassDeclaration):\n      PendingTrait<unknown, unknown, unknown>[]|null {\n    if (!this.compileNonExportedClasses && !isExported(clazz)) {\n      return null;\n    }\n\n    const decorators = this.reflector.getDecoratorsOfDeclaration(clazz);\n\n    return this.detectTraits(clazz, decorators);\n  }\n\n  protected detectTraits(clazz: ClassDeclaration, decorators: Decorator[]|null):\n      PendingTrait<unknown, unknown, unknown>[]|null {\n    let record: ClassRecord|null = this.recordFor(clazz);\n    let foundTraits: PendingTrait<unknown, unknown, unknown>[] = [];\n\n    for (const handler of this.handlers) {\n      const result = handler.detect(clazz, decorators);\n      if (result === undefined) {\n        continue;\n      }\n\n      const isPrimaryHandler = handler.precedence === HandlerPrecedence.PRIMARY;\n      const isWeakHandler = handler.precedence === HandlerPrecedence.WEAK;\n      const trait = Trait.pending(handler, result);\n\n      foundTraits.push(trait);\n\n      if (record === null) {\n        // This is the first handler to match this class. This path is a fast path through which\n        // most classes will flow.\n        record = {\n          node: clazz,\n          traits: [trait],\n          metaDiagnostics: null,\n          hasPrimaryHandler: isPrimaryHandler,\n          hasWeakHandlers: isWeakHandler,\n        };\n\n        this.classes.set(clazz, record);\n        const sf = clazz.getSourceFile();\n        if (!this.fileToClasses.has(sf)) {\n          this.fileToClasses.set(sf, new Set<ClassDeclaration>());\n        }\n        this.fileToClasses.get(sf)!.add(clazz);\n      } else {\n        // This is at least the second handler to match this class. This is a slower path that some\n        // classes will go through, which validates that the set of decorators applied to the class\n        // is valid.\n\n        // Validate according to rules as follows:\n        //\n        // * WEAK handlers are removed if a non-WEAK handler matches.\n        // * Only one PRIMARY handler can match at a time. Any other PRIMARY handler matching a\n        //   class with an existing PRIMARY handler is an error.\n\n        if (!isWeakHandler && record.hasWeakHandlers) {\n          // The current handler is not a WEAK handler, but the class has other WEAK handlers.\n          // Remove them.\n          record.traits =\n              record.traits.filter(field => field.handler.precedence !== HandlerPrecedence.WEAK);\n          record.hasWeakHandlers = false;\n        } else if (isWeakHandler && !record.hasWeakHandlers) {\n          // The current handler is a WEAK handler, but the class has non-WEAK handlers already.\n          // Drop the current one.\n          continue;\n        }\n\n        if (isPrimaryHandler && record.hasPrimaryHandler) {\n          // The class already has a PRIMARY handler, and another one just matched.\n          record.metaDiagnostics = [{\n            category: ts.DiagnosticCategory.Error,\n            code: Number('-99' + ErrorCode.DECORATOR_COLLISION),\n            file: getSourceFile(clazz),\n            start: clazz.getStart(undefined, false),\n            length: clazz.getWidth(),\n            messageText: 'Two incompatible decorators on class',\n          }];\n          record.traits = foundTraits = [];\n          break;\n        }\n\n        // Otherwise, it's safe to accept the multiple decorators here. Update some of the metadata\n        // regarding this class.\n        record.traits.push(trait);\n        record.hasPrimaryHandler = record.hasPrimaryHandler || isPrimaryHandler;\n      }\n    }\n\n    return foundTraits.length > 0 ? foundTraits : null;\n  }\n\n  protected analyzeClass(clazz: ClassDeclaration, preanalyzeQueue: Promise<void>[]|null): void {\n    const traits = this.scanClassForTraits(clazz);\n\n    if (traits === null) {\n      // There are no Ivy traits on the class, so it can safely be skipped.\n      return;\n    }\n\n    for (const trait of traits) {\n      const analyze = () => this.analyzeTrait(clazz, trait);\n\n      let preanalysis: Promise<void>|null = null;\n      if (preanalyzeQueue !== null && trait.handler.preanalyze !== undefined) {\n        // Attempt to run preanalysis. This could fail with a `FatalDiagnosticError`; catch it if it\n        // does.\n        try {\n          preanalysis = trait.handler.preanalyze(clazz, trait.detected.metadata) || null;\n        } catch (err) {\n          if (err instanceof FatalDiagnosticError) {\n            trait.toAnalyzed(null, [err.toDiagnostic()]);\n            return;\n          } else {\n            throw err;\n          }\n        }\n      }\n      if (preanalysis !== null) {\n        preanalyzeQueue!.push(preanalysis.then(analyze));\n      } else {\n        analyze();\n      }\n    }\n  }\n\n  protected analyzeTrait(\n      clazz: ClassDeclaration, trait: Trait<unknown, unknown, unknown>,\n      flags?: HandlerFlags): void {\n    if (trait.state !== TraitState.Pending) {\n      throw new Error(`Attempt to analyze trait of ${clazz.name.text} in state ${\n          TraitState[trait.state]} (expected DETECTED)`);\n    }\n\n    // Attempt analysis. This could fail with a `FatalDiagnosticError`; catch it if it does.\n    let result: AnalysisOutput<unknown>;\n    try {\n      result = trait.handler.analyze(clazz, trait.detected.metadata, flags);\n    } catch (err) {\n      if (err instanceof FatalDiagnosticError) {\n        trait.toAnalyzed(null, [err.toDiagnostic()]);\n        return;\n      } else {\n        throw err;\n      }\n    }\n\n    if (result.analysis !== undefined && trait.handler.register !== undefined) {\n      trait.handler.register(clazz, result.analysis);\n    }\n\n    trait = trait.toAnalyzed(result.analysis ?? null, result.diagnostics ?? null);\n  }\n\n  resolve(): void {\n    const classes = Array.from(this.classes.keys());\n    for (const clazz of classes) {\n      const record = this.classes.get(clazz)!;\n      for (let trait of record.traits) {\n        const handler = trait.handler;\n        switch (trait.state) {\n          case TraitState.Skipped:\n            continue;\n          case TraitState.Pending:\n            throw new Error(`Resolving a trait that hasn't been analyzed: ${clazz.name.text} / ${\n                Object.getPrototypeOf(trait.handler).constructor.name}`);\n          case TraitState.Resolved:\n            throw new Error(`Resolving an already resolved trait`);\n        }\n\n        if (trait.analysis === null) {\n          // No analysis results, cannot further process this trait.\n          continue;\n        }\n\n        if (handler.resolve === undefined) {\n          // No resolution of this trait needed - it's considered successful by default.\n          trait = trait.toResolved(null, null);\n          continue;\n        }\n\n        let result: ResolveResult<unknown>;\n        try {\n          result = handler.resolve(clazz, trait.analysis as Readonly<unknown>);\n        } catch (err) {\n          if (err instanceof FatalDiagnosticError) {\n            trait = trait.toResolved(null, [err.toDiagnostic()]);\n            continue;\n          } else {\n            throw err;\n          }\n        }\n\n        trait = trait.toResolved(result.data ?? null, result.diagnostics ?? null);\n\n        if (result.reexports !== undefined) {\n          const fileName = clazz.getSourceFile().fileName;\n          if (!this.reexportMap.has(fileName)) {\n            this.reexportMap.set(fileName, new Map<string, [string, string]>());\n          }\n          const fileReexports = this.reexportMap.get(fileName)!;\n          for (const reexport of result.reexports) {\n            fileReexports.set(reexport.asAlias, [reexport.fromModule, reexport.symbolName]);\n          }\n        }\n      }\n    }\n  }\n\n  /**\n   * Generate type-checking code into the `TypeCheckContext` for any components within the given\n   * `ts.SourceFile`.\n   */\n  typeCheck(sf: ts.SourceFile, ctx: TypeCheckContext): void {\n    if (!this.fileToClasses.has(sf)) {\n      return;\n    }\n\n    for (const clazz of this.fileToClasses.get(sf)!) {\n      const record = this.classes.get(clazz)!;\n      for (const trait of record.traits) {\n        if (trait.state !== TraitState.Resolved) {\n          continue;\n        } else if (trait.handler.typeCheck === undefined) {\n          continue;\n        }\n        if (trait.resolution !== null) {\n          trait.handler.typeCheck(ctx, clazz, trait.analysis, trait.resolution);\n        }\n      }\n    }\n  }\n\n  index(ctx: IndexingContext): void {\n    for (const clazz of this.classes.keys()) {\n      const record = this.classes.get(clazz)!;\n      for (const trait of record.traits) {\n        if (trait.state !== TraitState.Resolved) {\n          // Skip traits that haven't been resolved successfully.\n          continue;\n        } else if (trait.handler.index === undefined) {\n          // Skip traits that don't affect indexing.\n          continue;\n        }\n\n        if (trait.resolution !== null) {\n          trait.handler.index(ctx, clazz, trait.analysis, trait.resolution);\n        }\n      }\n    }\n  }\n\n  updateResources(clazz: DeclarationNode): void {\n    if (!this.reflector.isClass(clazz) || !this.classes.has(clazz)) {\n      return;\n    }\n    const record = this.classes.get(clazz)!;\n    for (const trait of record.traits) {\n      if (trait.state !== TraitState.Resolved || trait.handler.updateResources === undefined) {\n        continue;\n      }\n\n      trait.handler.updateResources(clazz, trait.analysis, trait.resolution);\n    }\n  }\n\n  compile(clazz: DeclarationNode, constantPool: ConstantPool): CompileResult[]|null {\n    const original = ts.getOriginalNode(clazz) as typeof clazz;\n    if (!this.reflector.isClass(clazz) || !this.reflector.isClass(original) ||\n        !this.classes.has(original)) {\n      return null;\n    }\n\n    const record = this.classes.get(original)!;\n\n    let res: CompileResult[] = [];\n\n    for (const trait of record.traits) {\n      if (trait.state !== TraitState.Resolved || trait.analysisDiagnostics !== null ||\n          trait.resolveDiagnostics !== null) {\n        // Cannot compile a trait that is not resolved, or had any errors in its declaration.\n        continue;\n      }\n\n      const compileSpan = this.perf.start('compileClass', original);\n\n\n      // `trait.resolution` is non-null asserted here because TypeScript does not recognize that\n      // `Readonly<unknown>` is nullable (as `unknown` itself is nullable) due to the way that\n      // `Readonly` works.\n\n      let compileRes: CompileResult|CompileResult[];\n      if (this.compilationMode === CompilationMode.PARTIAL &&\n          trait.handler.compilePartial !== undefined) {\n        compileRes = trait.handler.compilePartial(clazz, trait.analysis, trait.resolution!);\n      } else {\n        compileRes =\n            trait.handler.compileFull(clazz, trait.analysis, trait.resolution!, constantPool);\n      }\n\n      const compileMatchRes = compileRes;\n      this.perf.stop(compileSpan);\n      if (Array.isArray(compileMatchRes)) {\n        for (const result of compileMatchRes) {\n          if (!res.some(r => r.name === result.name)) {\n            res.push(result);\n          }\n        }\n      } else if (!res.some(result => result.name === compileMatchRes.name)) {\n        res.push(compileMatchRes);\n      }\n    }\n\n    // Look up the .d.ts transformer for the input file and record that at least one field was\n    // generated, which will allow the .d.ts to be transformed later.\n    this.dtsTransforms.getIvyDeclarationTransform(original.getSourceFile())\n        .addFields(original, res);\n\n    // Return the instruction to the transformer so the fields will be added.\n    return res.length > 0 ? res : null;\n  }\n\n  decoratorsFor(node: ts.Declaration): ts.Decorator[] {\n    const original = ts.getOriginalNode(node) as typeof node;\n    if (!this.reflector.isClass(original) || !this.classes.has(original)) {\n      return [];\n    }\n\n    const record = this.classes.get(original)!;\n    const decorators: ts.Decorator[] = [];\n\n    for (const trait of record.traits) {\n      if (trait.state !== TraitState.Resolved) {\n        continue;\n      }\n\n      if (trait.detected.trigger !== null && ts.isDecorator(trait.detected.trigger)) {\n        decorators.push(trait.detected.trigger);\n      }\n    }\n\n    return decorators;\n  }\n\n  get diagnostics(): ReadonlyArray<ts.Diagnostic> {\n    const diagnostics: ts.Diagnostic[] = [];\n    for (const clazz of this.classes.keys()) {\n      const record = this.classes.get(clazz)!;\n      if (record.metaDiagnostics !== null) {\n        diagnostics.push(...record.metaDiagnostics);\n      }\n      for (const trait of record.traits) {\n        if ((trait.state === TraitState.Analyzed || trait.state === TraitState.Resolved) &&\n            trait.analysisDiagnostics !== null) {\n          diagnostics.push(...trait.analysisDiagnostics);\n        }\n        if (trait.state === TraitState.Resolved && trait.resolveDiagnostics !== null) {\n          diagnostics.push(...trait.resolveDiagnostics);\n        }\n      }\n    }\n    return diagnostics;\n  }\n\n  get exportStatements(): Map<string, Map<string, [string, string]>> {\n    return this.reexportMap;\n  }\n}\n"]}
724
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"compilation.js","sourceRoot":"","sources":["../../../../../../../../../packages/compiler-cli/src/ngtsc/transform/src/compilation.ts"],"names":[],"mappings":"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","sourcesContent":["/**\n * @license\n * Copyright Google LLC All Rights Reserved.\n *\n * Use of this source code is governed by an MIT-style license that can be\n * found in the LICENSE file at https://angular.io/license\n */\n\nimport {ConstantPool} from '@angular/compiler';\nimport * as ts from 'typescript';\n\nimport {ErrorCode, FatalDiagnosticError} from '../../diagnostics';\nimport {IncrementalBuild} from '../../incremental/api';\nimport {SemanticDepGraphUpdater, SemanticSymbol} from '../../incremental/semantic_graph';\nimport {IndexingContext} from '../../indexer';\nimport {PerfRecorder} from '../../perf';\nimport {ClassDeclaration, DeclarationNode, Decorator, ReflectionHost} from '../../reflection';\nimport {ProgramTypeCheckAdapter, TypeCheckContext} from '../../typecheck/api';\nimport {getSourceFile, isExported} from '../../util/src/typescript';\n\nimport {AnalysisOutput, CompilationMode, CompileResult, DecoratorHandler, HandlerFlags, HandlerPrecedence, ResolveResult} from './api';\nimport {DtsTransformRegistry} from './declaration';\nimport {PendingTrait, Trait, TraitState} from './trait';\n\n\n/**\n * Records information about a specific class that has matched traits.\n */\nexport interface ClassRecord {\n  /**\n   * The `ClassDeclaration` of the class which has Angular traits applied.\n   */\n  node: ClassDeclaration;\n\n  /**\n   * All traits which matched on the class.\n   */\n  traits: Trait<unknown, unknown, SemanticSymbol|null, unknown>[];\n\n  /**\n   * Meta-diagnostics about the class, which are usually related to whether certain combinations of\n   * Angular decorators are not permitted.\n   */\n  metaDiagnostics: ts.Diagnostic[]|null;\n\n  // Subsequent fields are \"internal\" and used during the matching of `DecoratorHandler`s. This is\n  // mutable state during the `detect`/`analyze` phases of compilation.\n\n  /**\n   * Whether `traits` contains traits matched from `DecoratorHandler`s marked as `WEAK`.\n   */\n  hasWeakHandlers: boolean;\n\n  /**\n   * Whether `traits` contains a trait from a `DecoratorHandler` matched as `PRIMARY`.\n   */\n  hasPrimaryHandler: boolean;\n}\n\n/**\n * The heart of Angular compilation.\n *\n * The `TraitCompiler` is responsible for processing all classes in the program. Any time a\n * `DecoratorHandler` matches a class, a \"trait\" is created to represent that Angular aspect of the\n * class (such as the class having a component definition).\n *\n * The `TraitCompiler` transitions each trait through the various phases of compilation, culminating\n * in the production of `CompileResult`s instructing the compiler to apply various mutations to the\n * class (like adding fields or type declarations).\n */\nexport class TraitCompiler implements ProgramTypeCheckAdapter {\n  /**\n   * Maps class declarations to their `ClassRecord`, which tracks the Ivy traits being applied to\n   * those classes.\n   */\n  private classes = new Map<ClassDeclaration, ClassRecord>();\n\n  /**\n   * Maps source files to any class declaration(s) within them which have been discovered to contain\n   * Ivy traits.\n   */\n  protected fileToClasses = new Map<ts.SourceFile, Set<ClassDeclaration>>();\n\n  private reexportMap = new Map<string, Map<string, [string, string]>>();\n\n  private handlersByName =\n      new Map<string, DecoratorHandler<unknown, unknown, SemanticSymbol|null, unknown>>();\n\n  constructor(\n      private handlers: DecoratorHandler<unknown, unknown, SemanticSymbol|null, unknown>[],\n      private reflector: ReflectionHost, private perf: PerfRecorder,\n      private incrementalBuild: IncrementalBuild<ClassRecord, unknown>,\n      private compileNonExportedClasses: boolean, private compilationMode: CompilationMode,\n      private dtsTransforms: DtsTransformRegistry,\n      private semanticDepGraphUpdater: SemanticDepGraphUpdater|null) {\n    for (const handler of handlers) {\n      this.handlersByName.set(handler.name, handler);\n    }\n  }\n\n  analyzeSync(sf: ts.SourceFile): void {\n    this.analyze(sf, false);\n  }\n\n  analyzeAsync(sf: ts.SourceFile): Promise<void>|undefined {\n    return this.analyze(sf, true);\n  }\n\n  private analyze(sf: ts.SourceFile, preanalyze: false): void;\n  private analyze(sf: ts.SourceFile, preanalyze: true): Promise<void>|undefined;\n  private analyze(sf: ts.SourceFile, preanalyze: boolean): Promise<void>|undefined {\n    // We shouldn't analyze declaration files.\n    if (sf.isDeclarationFile) {\n      return undefined;\n    }\n\n    // analyze() really wants to return `Promise<void>|void`, but TypeScript cannot narrow a return\n    // type of 'void', so `undefined` is used instead.\n    const promises: Promise<void>[] = [];\n\n    const priorWork = this.incrementalBuild.priorWorkFor(sf);\n    if (priorWork !== null) {\n      for (const priorRecord of priorWork) {\n        this.adopt(priorRecord);\n      }\n\n      // Skip the rest of analysis, as this file's prior traits are being reused.\n      return;\n    }\n\n    const visit = (node: ts.Node): void => {\n      if (this.reflector.isClass(node)) {\n        this.analyzeClass(node, preanalyze ? promises : null);\n      }\n      ts.forEachChild(node, visit);\n    };\n\n    visit(sf);\n\n    if (preanalyze && promises.length > 0) {\n      return Promise.all(promises).then(() => undefined as void);\n    } else {\n      return undefined;\n    }\n  }\n\n  recordFor(clazz: ClassDeclaration): ClassRecord|null {\n    if (this.classes.has(clazz)) {\n      return this.classes.get(clazz)!;\n    } else {\n      return null;\n    }\n  }\n\n  recordsFor(sf: ts.SourceFile): ClassRecord[]|null {\n    if (!this.fileToClasses.has(sf)) {\n      return null;\n    }\n    const records: ClassRecord[] = [];\n    for (const clazz of this.fileToClasses.get(sf)!) {\n      records.push(this.classes.get(clazz)!);\n    }\n    return records;\n  }\n\n  /**\n   * Import a `ClassRecord` from a previous compilation.\n   *\n   * Traits from the `ClassRecord` have accurate metadata, but the `handler` is from the old program\n   * and needs to be updated (matching is done by name). A new pending trait is created and then\n   * transitioned to analyzed using the previous analysis. If the trait is in the errored state,\n   * instead the errors are copied over.\n   */\n  private adopt(priorRecord: ClassRecord): void {\n    const record: ClassRecord = {\n      hasPrimaryHandler: priorRecord.hasPrimaryHandler,\n      hasWeakHandlers: priorRecord.hasWeakHandlers,\n      metaDiagnostics: priorRecord.metaDiagnostics,\n      node: priorRecord.node,\n      traits: [],\n    };\n\n    for (const priorTrait of priorRecord.traits) {\n      const handler = this.handlersByName.get(priorTrait.handler.name)!;\n      let trait: Trait<unknown, unknown, SemanticSymbol|null, unknown> =\n          Trait.pending(handler, priorTrait.detected);\n\n      if (priorTrait.state === TraitState.Analyzed || priorTrait.state === TraitState.Resolved) {\n        const symbol = this.makeSymbolForTrait(handler, record.node, priorTrait.analysis);\n        trait = trait.toAnalyzed(priorTrait.analysis, priorTrait.analysisDiagnostics, symbol);\n        if (trait.analysis !== null && trait.handler.register !== undefined) {\n          trait.handler.register(record.node, trait.analysis);\n        }\n      } else if (priorTrait.state === TraitState.Skipped) {\n        trait = trait.toSkipped();\n      }\n\n      record.traits.push(trait);\n    }\n\n    this.classes.set(record.node, record);\n    const sf = record.node.getSourceFile();\n    if (!this.fileToClasses.has(sf)) {\n      this.fileToClasses.set(sf, new Set<ClassDeclaration>());\n    }\n    this.fileToClasses.get(sf)!.add(record.node);\n  }\n\n  private scanClassForTraits(clazz: ClassDeclaration):\n      PendingTrait<unknown, unknown, SemanticSymbol|null, unknown>[]|null {\n    if (!this.compileNonExportedClasses && !isExported(clazz)) {\n      return null;\n    }\n\n    const decorators = this.reflector.getDecoratorsOfDeclaration(clazz);\n\n    return this.detectTraits(clazz, decorators);\n  }\n\n  protected detectTraits(clazz: ClassDeclaration, decorators: Decorator[]|null):\n      PendingTrait<unknown, unknown, SemanticSymbol|null, unknown>[]|null {\n    let record: ClassRecord|null = this.recordFor(clazz);\n    let foundTraits: PendingTrait<unknown, unknown, SemanticSymbol|null, unknown>[] = [];\n\n    for (const handler of this.handlers) {\n      const result = handler.detect(clazz, decorators);\n      if (result === undefined) {\n        continue;\n      }\n\n      const isPrimaryHandler = handler.precedence === HandlerPrecedence.PRIMARY;\n      const isWeakHandler = handler.precedence === HandlerPrecedence.WEAK;\n      const trait = Trait.pending(handler, result);\n\n      foundTraits.push(trait);\n\n      if (record === null) {\n        // This is the first handler to match this class. This path is a fast path through which\n        // most classes will flow.\n        record = {\n          node: clazz,\n          traits: [trait],\n          metaDiagnostics: null,\n          hasPrimaryHandler: isPrimaryHandler,\n          hasWeakHandlers: isWeakHandler,\n        };\n\n        this.classes.set(clazz, record);\n        const sf = clazz.getSourceFile();\n        if (!this.fileToClasses.has(sf)) {\n          this.fileToClasses.set(sf, new Set<ClassDeclaration>());\n        }\n        this.fileToClasses.get(sf)!.add(clazz);\n      } else {\n        // This is at least the second handler to match this class. This is a slower path that some\n        // classes will go through, which validates that the set of decorators applied to the class\n        // is valid.\n\n        // Validate according to rules as follows:\n        //\n        // * WEAK handlers are removed if a non-WEAK handler matches.\n        // * Only one PRIMARY handler can match at a time. Any other PRIMARY handler matching a\n        //   class with an existing PRIMARY handler is an error.\n\n        if (!isWeakHandler && record.hasWeakHandlers) {\n          // The current handler is not a WEAK handler, but the class has other WEAK handlers.\n          // Remove them.\n          record.traits =\n              record.traits.filter(field => field.handler.precedence !== HandlerPrecedence.WEAK);\n          record.hasWeakHandlers = false;\n        } else if (isWeakHandler && !record.hasWeakHandlers) {\n          // The current handler is a WEAK handler, but the class has non-WEAK handlers already.\n          // Drop the current one.\n          continue;\n        }\n\n        if (isPrimaryHandler && record.hasPrimaryHandler) {\n          // The class already has a PRIMARY handler, and another one just matched.\n          record.metaDiagnostics = [{\n            category: ts.DiagnosticCategory.Error,\n            code: Number('-99' + ErrorCode.DECORATOR_COLLISION),\n            file: getSourceFile(clazz),\n            start: clazz.getStart(undefined, false),\n            length: clazz.getWidth(),\n            messageText: 'Two incompatible decorators on class',\n          }];\n          record.traits = foundTraits = [];\n          break;\n        }\n\n        // Otherwise, it's safe to accept the multiple decorators here. Update some of the metadata\n        // regarding this class.\n        record.traits.push(trait);\n        record.hasPrimaryHandler = record.hasPrimaryHandler || isPrimaryHandler;\n      }\n    }\n\n    return foundTraits.length > 0 ? foundTraits : null;\n  }\n\n  private makeSymbolForTrait(\n      handler: DecoratorHandler<unknown, unknown, SemanticSymbol|null, unknown>,\n      decl: ClassDeclaration, analysis: Readonly<unknown>|null): SemanticSymbol|null {\n    if (analysis === null) {\n      return null;\n    }\n    const symbol = handler.symbol(decl, analysis);\n    if (symbol !== null && this.semanticDepGraphUpdater !== null) {\n      const isPrimary = handler.precedence === HandlerPrecedence.PRIMARY;\n      if (!isPrimary) {\n        throw new Error(\n            `AssertionError: ${handler.name} returned a symbol but is not a primary handler.`);\n      }\n      this.semanticDepGraphUpdater.registerSymbol(symbol);\n    }\n\n    return symbol;\n  }\n\n  protected analyzeClass(clazz: ClassDeclaration, preanalyzeQueue: Promise<void>[]|null): void {\n    const traits = this.scanClassForTraits(clazz);\n\n    if (traits === null) {\n      // There are no Ivy traits on the class, so it can safely be skipped.\n      return;\n    }\n\n    for (const trait of traits) {\n      const analyze = () => this.analyzeTrait(clazz, trait);\n\n      let preanalysis: Promise<void>|null = null;\n      if (preanalyzeQueue !== null && trait.handler.preanalyze !== undefined) {\n        // Attempt to run preanalysis. This could fail with a `FatalDiagnosticError`; catch it if it\n        // does.\n        try {\n          preanalysis = trait.handler.preanalyze(clazz, trait.detected.metadata) || null;\n        } catch (err) {\n          if (err instanceof FatalDiagnosticError) {\n            trait.toAnalyzed(null, [err.toDiagnostic()], null);\n            return;\n          } else {\n            throw err;\n          }\n        }\n      }\n      if (preanalysis !== null) {\n        preanalyzeQueue!.push(preanalysis.then(analyze));\n      } else {\n        analyze();\n      }\n    }\n  }\n\n  protected analyzeTrait(\n      clazz: ClassDeclaration, trait: Trait<unknown, unknown, SemanticSymbol|null, unknown>,\n      flags?: HandlerFlags): void {\n    if (trait.state !== TraitState.Pending) {\n      throw new Error(`Attempt to analyze trait of ${clazz.name.text} in state ${\n          TraitState[trait.state]} (expected DETECTED)`);\n    }\n\n    // Attempt analysis. This could fail with a `FatalDiagnosticError`; catch it if it does.\n    let result: AnalysisOutput<unknown>;\n    try {\n      result = trait.handler.analyze(clazz, trait.detected.metadata, flags);\n    } catch (err) {\n      if (err instanceof FatalDiagnosticError) {\n        trait.toAnalyzed(null, [err.toDiagnostic()], null);\n        return;\n      } else {\n        throw err;\n      }\n    }\n\n    const symbol = this.makeSymbolForTrait(trait.handler, clazz, result.analysis ?? null);\n    if (result.analysis !== undefined && trait.handler.register !== undefined) {\n      trait.handler.register(clazz, result.analysis);\n    }\n    trait = trait.toAnalyzed(result.analysis ?? null, result.diagnostics ?? null, symbol);\n  }\n\n  resolve(): void {\n    const classes = Array.from(this.classes.keys());\n    for (const clazz of classes) {\n      const record = this.classes.get(clazz)!;\n      for (let trait of record.traits) {\n        const handler = trait.handler;\n        switch (trait.state) {\n          case TraitState.Skipped:\n            continue;\n          case TraitState.Pending:\n            throw new Error(`Resolving a trait that hasn't been analyzed: ${clazz.name.text} / ${\n                Object.getPrototypeOf(trait.handler).constructor.name}`);\n          case TraitState.Resolved:\n            throw new Error(`Resolving an already resolved trait`);\n        }\n\n        if (trait.analysis === null) {\n          // No analysis results, cannot further process this trait.\n          continue;\n        }\n\n        if (handler.resolve === undefined) {\n          // No resolution of this trait needed - it's considered successful by default.\n          trait = trait.toResolved(null, null);\n          continue;\n        }\n\n        let result: ResolveResult<unknown>;\n        try {\n          result = handler.resolve(clazz, trait.analysis as Readonly<unknown>, trait.symbol);\n        } catch (err) {\n          if (err instanceof FatalDiagnosticError) {\n            trait = trait.toResolved(null, [err.toDiagnostic()]);\n            continue;\n          } else {\n            throw err;\n          }\n        }\n\n        trait = trait.toResolved(result.data ?? null, result.diagnostics ?? null);\n\n        if (result.reexports !== undefined) {\n          const fileName = clazz.getSourceFile().fileName;\n          if (!this.reexportMap.has(fileName)) {\n            this.reexportMap.set(fileName, new Map<string, [string, string]>());\n          }\n          const fileReexports = this.reexportMap.get(fileName)!;\n          for (const reexport of result.reexports) {\n            fileReexports.set(reexport.asAlias, [reexport.fromModule, reexport.symbolName]);\n          }\n        }\n      }\n    }\n  }\n\n  /**\n   * Generate type-checking code into the `TypeCheckContext` for any components within the given\n   * `ts.SourceFile`.\n   */\n  typeCheck(sf: ts.SourceFile, ctx: TypeCheckContext): void {\n    if (!this.fileToClasses.has(sf)) {\n      return;\n    }\n\n    for (const clazz of this.fileToClasses.get(sf)!) {\n      const record = this.classes.get(clazz)!;\n      for (const trait of record.traits) {\n        if (trait.state !== TraitState.Resolved) {\n          continue;\n        } else if (trait.handler.typeCheck === undefined) {\n          continue;\n        }\n        if (trait.resolution !== null) {\n          trait.handler.typeCheck(ctx, clazz, trait.analysis, trait.resolution);\n        }\n      }\n    }\n  }\n\n  index(ctx: IndexingContext): void {\n    for (const clazz of this.classes.keys()) {\n      const record = this.classes.get(clazz)!;\n      for (const trait of record.traits) {\n        if (trait.state !== TraitState.Resolved) {\n          // Skip traits that haven't been resolved successfully.\n          continue;\n        } else if (trait.handler.index === undefined) {\n          // Skip traits that don't affect indexing.\n          continue;\n        }\n\n        if (trait.resolution !== null) {\n          trait.handler.index(ctx, clazz, trait.analysis, trait.resolution);\n        }\n      }\n    }\n  }\n\n  updateResources(clazz: DeclarationNode): void {\n    if (!this.reflector.isClass(clazz) || !this.classes.has(clazz)) {\n      return;\n    }\n    const record = this.classes.get(clazz)!;\n    for (const trait of record.traits) {\n      if (trait.state !== TraitState.Resolved || trait.handler.updateResources === undefined) {\n        continue;\n      }\n\n      trait.handler.updateResources(clazz, trait.analysis, trait.resolution);\n    }\n  }\n\n  compile(clazz: DeclarationNode, constantPool: ConstantPool): CompileResult[]|null {\n    const original = ts.getOriginalNode(clazz) as typeof clazz;\n    if (!this.reflector.isClass(clazz) || !this.reflector.isClass(original) ||\n        !this.classes.has(original)) {\n      return null;\n    }\n\n    const record = this.classes.get(original)!;\n\n    let res: CompileResult[] = [];\n\n    for (const trait of record.traits) {\n      if (trait.state !== TraitState.Resolved || trait.analysisDiagnostics !== null ||\n          trait.resolveDiagnostics !== null) {\n        // Cannot compile a trait that is not resolved, or had any errors in its declaration.\n        continue;\n      }\n\n      const compileSpan = this.perf.start('compileClass', original);\n\n\n      // `trait.resolution` is non-null asserted here because TypeScript does not recognize that\n      // `Readonly<unknown>` is nullable (as `unknown` itself is nullable) due to the way that\n      // `Readonly` works.\n\n      let compileRes: CompileResult|CompileResult[];\n      if (this.compilationMode === CompilationMode.PARTIAL &&\n          trait.handler.compilePartial !== undefined) {\n        compileRes = trait.handler.compilePartial(clazz, trait.analysis, trait.resolution!);\n      } else {\n        compileRes =\n            trait.handler.compileFull(clazz, trait.analysis, trait.resolution!, constantPool);\n      }\n\n      const compileMatchRes = compileRes;\n      this.perf.stop(compileSpan);\n      if (Array.isArray(compileMatchRes)) {\n        for (const result of compileMatchRes) {\n          if (!res.some(r => r.name === result.name)) {\n            res.push(result);\n          }\n        }\n      } else if (!res.some(result => result.name === compileMatchRes.name)) {\n        res.push(compileMatchRes);\n      }\n    }\n\n    // Look up the .d.ts transformer for the input file and record that at least one field was\n    // generated, which will allow the .d.ts to be transformed later.\n    this.dtsTransforms.getIvyDeclarationTransform(original.getSourceFile())\n        .addFields(original, res);\n\n    // Return the instruction to the transformer so the fields will be added.\n    return res.length > 0 ? res : null;\n  }\n\n  decoratorsFor(node: ts.Declaration): ts.Decorator[] {\n    const original = ts.getOriginalNode(node) as typeof node;\n    if (!this.reflector.isClass(original) || !this.classes.has(original)) {\n      return [];\n    }\n\n    const record = this.classes.get(original)!;\n    const decorators: ts.Decorator[] = [];\n\n    for (const trait of record.traits) {\n      if (trait.state !== TraitState.Resolved) {\n        continue;\n      }\n\n      if (trait.detected.trigger !== null && ts.isDecorator(trait.detected.trigger)) {\n        decorators.push(trait.detected.trigger);\n      }\n    }\n\n    return decorators;\n  }\n\n  get diagnostics(): ReadonlyArray<ts.Diagnostic> {\n    const diagnostics: ts.Diagnostic[] = [];\n    for (const clazz of this.classes.keys()) {\n      const record = this.classes.get(clazz)!;\n      if (record.metaDiagnostics !== null) {\n        diagnostics.push(...record.metaDiagnostics);\n      }\n      for (const trait of record.traits) {\n        if ((trait.state === TraitState.Analyzed || trait.state === TraitState.Resolved) &&\n            trait.analysisDiagnostics !== null) {\n          diagnostics.push(...trait.analysisDiagnostics);\n        }\n        if (trait.state === TraitState.Resolved && trait.resolveDiagnostics !== null) {\n          diagnostics.push(...trait.resolveDiagnostics);\n        }\n      }\n    }\n    return diagnostics;\n  }\n\n  get exportStatements(): Map<string, Map<string, [string, string]>> {\n    return this.reexportMap;\n  }\n}\n"]}
@@ -7,6 +7,7 @@
7
7
  */
8
8
  /// <amd-module name="@angular/compiler-cli/src/ngtsc/transform/src/trait" />
9
9
  import * as ts from 'typescript';
10
+ import { SemanticSymbol } from '../../incremental/semantic_graph';
10
11
  import { DecoratorHandler, DetectResult } from './api';
11
12
  export declare enum TraitState {
12
13
  /**
@@ -39,18 +40,18 @@ export declare enum TraitState {
39
40
  * This not only simplifies the implementation, but ensures traits are monomorphic objects as
40
41
  * they're all just "views" in the type system of the same object (which never changes shape).
41
42
  */
42
- export declare type Trait<D, A, R> = PendingTrait<D, A, R> | SkippedTrait<D, A, R> | AnalyzedTrait<D, A, R> | ResolvedTrait<D, A, R>;
43
+ export declare type Trait<D, A, S extends SemanticSymbol | null, R> = PendingTrait<D, A, S, R> | SkippedTrait<D, A, S, R> | AnalyzedTrait<D, A, S, R> | ResolvedTrait<D, A, S, R>;
43
44
  /**
44
45
  * The value side of `Trait` exposes a helper to create a `Trait` in a pending state (by delegating
45
46
  * to `TraitImpl`).
46
47
  */
47
48
  export declare const Trait: {
48
- pending: <D, A, R>(handler: DecoratorHandler<D, A, R>, detected: DetectResult<D>) => PendingTrait<D, A, R>;
49
+ pending: <D, A, S extends SemanticSymbol | null, R>(handler: DecoratorHandler<D, A, S, R>, detected: DetectResult<D>) => PendingTrait<D, A, S, R>;
49
50
  };
50
51
  /**
51
52
  * The part of the `Trait` interface that's common to all trait states.
52
53
  */
53
- export interface TraitBase<D, A, R> {
54
+ export interface TraitBase<D, A, S extends SemanticSymbol | null, R> {
54
55
  /**
55
56
  * Current state of the trait.
56
57
  *
@@ -60,7 +61,7 @@ export interface TraitBase<D, A, R> {
60
61
  /**
61
62
  * The `DecoratorHandler` which matched on the class to create this trait.
62
63
  */
63
- handler: DecoratorHandler<D, A, R>;
64
+ handler: DecoratorHandler<D, A, S, R>;
64
65
  /**
65
66
  * The detection result (of `handler.detect`) which indicated that this trait applied to the
66
67
  * class.
@@ -74,18 +75,18 @@ export interface TraitBase<D, A, R> {
74
75
  *
75
76
  * Pending traits have yet to be analyzed in any way.
76
77
  */
77
- export interface PendingTrait<D, A, R> extends TraitBase<D, A, R> {
78
+ export interface PendingTrait<D, A, S extends SemanticSymbol | null, R> extends TraitBase<D, A, S, R> {
78
79
  state: TraitState.Pending;
79
80
  /**
80
81
  * This pending trait has been successfully analyzed, and should transition to the "analyzed"
81
82
  * state.
82
83
  */
83
- toAnalyzed(analysis: A | null, diagnostics: ts.Diagnostic[] | null): AnalyzedTrait<D, A, R>;
84
+ toAnalyzed(analysis: A | null, diagnostics: ts.Diagnostic[] | null, symbol: S): AnalyzedTrait<D, A, S, R>;
84
85
  /**
85
86
  * During analysis it was determined that this trait is not eligible for compilation after all,
86
87
  * and should be transitioned to the "skipped" state.
87
88
  */
88
- toSkipped(): SkippedTrait<D, A, R>;
89
+ toSkipped(): SkippedTrait<D, A, S, R>;
89
90
  }
90
91
  /**
91
92
  * A trait in the "skipped" state.
@@ -94,7 +95,7 @@ export interface PendingTrait<D, A, R> extends TraitBase<D, A, R> {
94
95
  *
95
96
  * This is a terminal state.
96
97
  */
97
- export interface SkippedTrait<D, A, R> extends TraitBase<D, A, R> {
98
+ export interface SkippedTrait<D, A, S extends SemanticSymbol | null, R> extends TraitBase<D, A, S, R> {
98
99
  state: TraitState.Skipped;
99
100
  }
100
101
  /**
@@ -102,8 +103,9 @@ export interface SkippedTrait<D, A, R> extends TraitBase<D, A, R> {
102
103
  *
103
104
  * Analyzed traits have analysis results available, and are eligible for resolution.
104
105
  */
105
- export interface AnalyzedTrait<D, A, R> extends TraitBase<D, A, R> {
106
+ export interface AnalyzedTrait<D, A, S extends SemanticSymbol | null, R> extends TraitBase<D, A, S, R> {
106
107
  state: TraitState.Analyzed;
108
+ symbol: S;
107
109
  /**
108
110
  * Analysis results of the given trait (if able to be produced), or `null` if analysis failed
109
111
  * completely.
@@ -117,7 +119,7 @@ export interface AnalyzedTrait<D, A, R> extends TraitBase<D, A, R> {
117
119
  * This analyzed trait has been successfully resolved, and should be transitioned to the
118
120
  * "resolved" state.
119
121
  */
120
- toResolved(resolution: R | null, diagnostics: ts.Diagnostic[] | null): ResolvedTrait<D, A, R>;
122
+ toResolved(resolution: R | null, diagnostics: ts.Diagnostic[] | null): ResolvedTrait<D, A, S, R>;
121
123
  }
122
124
  /**
123
125
  * A trait in the "resolved" state.
@@ -127,8 +129,9 @@ export interface AnalyzedTrait<D, A, R> extends TraitBase<D, A, R> {
127
129
  *
128
130
  * This is a terminal state.
129
131
  */
130
- export interface ResolvedTrait<D, A, R> extends TraitBase<D, A, R> {
132
+ export interface ResolvedTrait<D, A, S extends SemanticSymbol | null, R> extends TraitBase<D, A, S, R> {
131
133
  state: TraitState.Resolved;
134
+ symbol: S;
132
135
  /**
133
136
  * Resolved traits must have produced valid analysis results.
134
137
  */
@@ -41,7 +41,9 @@
41
41
  * to `TraitImpl`).
42
42
  */
43
43
  exports.Trait = {
44
- pending: function (handler, detected) { return TraitImpl.pending(handler, detected); },
44
+ pending: function (handler, detected) {
45
+ return TraitImpl.pending(handler, detected);
46
+ },
45
47
  };
46
48
  /**
47
49
  * An implementation of the `Trait` type which transitions safely between the various
@@ -51,17 +53,19 @@
51
53
  function TraitImpl(handler, detected) {
52
54
  this.state = TraitState.Pending;
53
55
  this.analysis = null;
56
+ this.symbol = null;
54
57
  this.resolution = null;
55
58
  this.analysisDiagnostics = null;
56
59
  this.resolveDiagnostics = null;
57
60
  this.handler = handler;
58
61
  this.detected = detected;
59
62
  }
60
- TraitImpl.prototype.toAnalyzed = function (analysis, diagnostics) {
63
+ TraitImpl.prototype.toAnalyzed = function (analysis, diagnostics, symbol) {
61
64
  // Only pending traits can be analyzed.
62
65
  this.assertTransitionLegal(TraitState.Pending, TraitState.Analyzed);
63
66
  this.analysis = analysis;
64
67
  this.analysisDiagnostics = diagnostics;
68
+ this.symbol = symbol;
65
69
  this.state = TraitState.Analyzed;
66
70
  return this;
67
71
  };
@@ -104,4 +108,4 @@
104
108
  return TraitImpl;
105
109
  }());
106
110
  });
107
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"trait.js","sourceRoot":"","sources":["../../../../../../../../../packages/compiler-cli/src/ngtsc/transform/src/trait.ts"],"names":[],"mappings":"AAAA;;;;;;GAMG;;;;;;;;;;;;;IAKH,IAAY,UAoBX;IApBD,WAAY,UAAU;QACpB;;WAEG;QACH,iDAAO,CAAA;QAEP;;WAEG;QACH,mDAAQ,CAAA;QAER;;WAEG;QACH,mDAAQ,CAAA;QAER;;WAEG;QACH,iDAAO,CAAA;IACT,CAAC,EApBW,UAAU,GAAV,kBAAU,KAAV,kBAAU,QAoBrB;IAkBD;;;OAGG;IACU,QAAA,KAAK,GAAG;QACnB,OAAO,EAAE,UAAU,OAAkC,EAAE,QAAyB,IACnD,OAAA,SAAS,CAAC,OAAO,CAAC,OAAO,EAAE,QAAQ,CAAC,EAApC,CAAoC;KAClE,CAAC;IAsHF;;;OAGG;IACH;QASE,mBAAY,OAAkC,EAAE,QAAyB;YARzE,UAAK,GAAe,UAAU,CAAC,OAAO,CAAC;YAGvC,aAAQ,GAAqB,IAAI,CAAC;YAClC,eAAU,GAAqB,IAAI,CAAC;YACpC,wBAAmB,GAAyB,IAAI,CAAC;YACjD,uBAAkB,GAAyB,IAAI,CAAC;YAG9C,IAAI,CAAC,OAAO,GAAG,OAAO,CAAC;YACvB,IAAI,CAAC,QAAQ,GAAG,QAAQ,CAAC;QAC3B,CAAC;QAED,8BAAU,GAAV,UAAW,QAAgB,EAAE,WAAiC;YAC5D,uCAAuC;YACvC,IAAI,CAAC,qBAAqB,CAAC,UAAU,CAAC,OAAO,EAAE,UAAU,CAAC,QAAQ,CAAC,CAAC;YACpE,IAAI,CAAC,QAAQ,GAAG,QAAQ,CAAC;YACzB,IAAI,CAAC,mBAAmB,GAAG,WAAW,CAAC;YACvC,IAAI,CAAC,KAAK,GAAG,UAAU,CAAC,QAAQ,CAAC;YACjC,OAAO,IAA8B,CAAC;QACxC,CAAC;QAED,8BAAU,GAAV,UAAW,UAAkB,EAAE,WAAiC;YAC9D,wCAAwC;YACxC,IAAI,CAAC,qBAAqB,CAAC,UAAU,CAAC,QAAQ,EAAE,UAAU,CAAC,QAAQ,CAAC,CAAC;YACrE,IAAI,IAAI,CAAC,QAAQ,KAAK,IAAI,EAAE;gBAC1B,MAAM,IAAI,KAAK,CAAC,sEAAsE,CAAC,CAAC;aACzF;YACD,IAAI,CAAC,UAAU,GAAG,UAAU,CAAC;YAC7B,IAAI,CAAC,KAAK,GAAG,UAAU,CAAC,QAAQ,CAAC;YACjC,IAAI,CAAC,kBAAkB,GAAG,WAAW,CAAC;YACtC,OAAO,IAA8B,CAAC;QACxC,CAAC;QAED,6BAAS,GAAT;YACE,sCAAsC;YACtC,IAAI,CAAC,qBAAqB,CAAC,UAAU,CAAC,OAAO,EAAE,UAAU,CAAC,OAAO,CAAC,CAAC;YACnE,IAAI,CAAC,KAAK,GAAG,UAAU,CAAC,OAAO,CAAC;YAChC,OAAO,IAA6B,CAAC;QACvC,CAAC;QAED;;;;;;;WAOG;QACK,yCAAqB,GAA7B,UAA8B,YAAwB,EAAE,YAAwB;YAC9E,IAAI,CAAC,CAAC,IAAI,CAAC,KAAK,KAAK,YAAY,CAAC,EAAE;gBAClC,MAAM,IAAI,KAAK,CAAC,+CAA6C,UAAU,CAAC,IAAI,CAAC,KAAK,CAAC,YAC/E,UAAU,CAAC,YAAY,CAAC,MAAG,CAAC,CAAC;aAClC;QACH,CAAC;QAED;;WAEG;QACI,iBAAO,GAAd,UAAwB,OAAkC,EAAE,QAAyB;YAEnF,OAAO,IAAI,SAAS,CAAC,OAAO,EAAE,QAAQ,CAA0B,CAAC;QACnE,CAAC;QACH,gBAAC;IAAD,CAAC,AAhED,IAgEC","sourcesContent":["/**\n * @license\n * Copyright Google LLC All Rights Reserved.\n *\n * Use of this source code is governed by an MIT-style license that can be\n * found in the LICENSE file at https://angular.io/license\n */\n\nimport * as ts from 'typescript';\nimport {DecoratorHandler, DetectResult} from './api';\n\nexport enum TraitState {\n  /**\n   * Pending traits are freshly created and have never been analyzed.\n   */\n  Pending,\n\n  /**\n   * Analyzed traits have successfully been analyzed, but are pending resolution.\n   */\n  Analyzed,\n\n  /**\n   * Resolved traits have successfully been analyzed and resolved and are ready for compilation.\n   */\n  Resolved,\n\n  /**\n   * Skipped traits are no longer considered for compilation.\n   */\n  Skipped,\n}\n\n/**\n * An Ivy aspect added to a class (for example, the compilation of a component definition).\n *\n * Traits are created when a `DecoratorHandler` matches a class. Each trait begins in a pending\n * state and undergoes transitions as compilation proceeds through the various steps.\n *\n * In practice, traits are instances of the private class `TraitImpl` declared below. Through the\n * various interfaces included in this union type, the legal API of a trait in any given state is\n * represented in the type system. This includes any possible transitions from one type to the next.\n *\n * This not only simplifies the implementation, but ensures traits are monomorphic objects as\n * they're all just \"views\" in the type system of the same object (which never changes shape).\n */\nexport type Trait<D, A, R> =\n    PendingTrait<D, A, R>|SkippedTrait<D, A, R>|AnalyzedTrait<D, A, R>|ResolvedTrait<D, A, R>;\n\n/**\n * The value side of `Trait` exposes a helper to create a `Trait` in a pending state (by delegating\n * to `TraitImpl`).\n */\nexport const Trait = {\n  pending: <D, A, R>(handler: DecoratorHandler<D, A, R>, detected: DetectResult<D>):\n      PendingTrait<D, A, R> => TraitImpl.pending(handler, detected),\n};\n\n/**\n * The part of the `Trait` interface that's common to all trait states.\n */\nexport interface TraitBase<D, A, R> {\n  /**\n   * Current state of the trait.\n   *\n   * This will be narrowed in the interfaces for each specific state.\n   */\n  state: TraitState;\n\n  /**\n   * The `DecoratorHandler` which matched on the class to create this trait.\n   */\n  handler: DecoratorHandler<D, A, R>;\n\n  /**\n   * The detection result (of `handler.detect`) which indicated that this trait applied to the\n   * class.\n   *\n   * This is mainly used to cache the detection between pre-analysis and analysis.\n   */\n  detected: DetectResult<D>;\n}\n\n/**\n * A trait in the pending state.\n *\n * Pending traits have yet to be analyzed in any way.\n */\nexport interface PendingTrait<D, A, R> extends TraitBase<D, A, R> {\n  state: TraitState.Pending;\n\n  /**\n   * This pending trait has been successfully analyzed, and should transition to the \"analyzed\"\n   * state.\n   */\n  toAnalyzed(analysis: A|null, diagnostics: ts.Diagnostic[]|null): AnalyzedTrait<D, A, R>;\n\n  /**\n   * During analysis it was determined that this trait is not eligible for compilation after all,\n   * and should be transitioned to the \"skipped\" state.\n   */\n  toSkipped(): SkippedTrait<D, A, R>;\n}\n\n/**\n * A trait in the \"skipped\" state.\n *\n * Skipped traits aren't considered for compilation.\n *\n * This is a terminal state.\n */\nexport interface SkippedTrait<D, A, R> extends TraitBase<D, A, R> {\n  state: TraitState.Skipped;\n}\n\n/**\n * A trait in the \"analyzed\" state.\n *\n * Analyzed traits have analysis results available, and are eligible for resolution.\n */\nexport interface AnalyzedTrait<D, A, R> extends TraitBase<D, A, R> {\n  state: TraitState.Analyzed;\n\n  /**\n   * Analysis results of the given trait (if able to be produced), or `null` if analysis failed\n   * completely.\n   */\n  analysis: Readonly<A>|null;\n\n  /**\n   * Any diagnostics that resulted from analysis, or `null` if none.\n   */\n  analysisDiagnostics: ts.Diagnostic[]|null;\n\n  /**\n   * This analyzed trait has been successfully resolved, and should be transitioned to the\n   * \"resolved\" state.\n   */\n  toResolved(resolution: R|null, diagnostics: ts.Diagnostic[]|null): ResolvedTrait<D, A, R>;\n}\n\n/**\n * A trait in the \"resolved\" state.\n *\n * Resolved traits have been successfully analyzed and resolved, contain no errors, and are ready\n * for the compilation phase.\n *\n * This is a terminal state.\n */\nexport interface ResolvedTrait<D, A, R> extends TraitBase<D, A, R> {\n  state: TraitState.Resolved;\n\n  /**\n   * Resolved traits must have produced valid analysis results.\n   */\n  analysis: Readonly<A>;\n\n  /**\n   * Analysis may have still resulted in diagnostics.\n   */\n  analysisDiagnostics: ts.Diagnostic[]|null;\n\n  /**\n   * Diagnostics resulting from resolution are tracked separately from\n   */\n  resolveDiagnostics: ts.Diagnostic[]|null;\n\n  /**\n   * The results returned by a successful resolution of the given class/`DecoratorHandler`\n   * combination.\n   */\n  resolution: Readonly<R>|null;\n}\n\n/**\n * An implementation of the `Trait` type which transitions safely between the various\n * `TraitState`s.\n */\nclass TraitImpl<D, A, R> {\n  state: TraitState = TraitState.Pending;\n  handler: DecoratorHandler<D, A, R>;\n  detected: DetectResult<D>;\n  analysis: Readonly<A>|null = null;\n  resolution: Readonly<R>|null = null;\n  analysisDiagnostics: ts.Diagnostic[]|null = null;\n  resolveDiagnostics: ts.Diagnostic[]|null = null;\n\n  constructor(handler: DecoratorHandler<D, A, R>, detected: DetectResult<D>) {\n    this.handler = handler;\n    this.detected = detected;\n  }\n\n  toAnalyzed(analysis: A|null, diagnostics: ts.Diagnostic[]|null): AnalyzedTrait<D, A, R> {\n    // Only pending traits can be analyzed.\n    this.assertTransitionLegal(TraitState.Pending, TraitState.Analyzed);\n    this.analysis = analysis;\n    this.analysisDiagnostics = diagnostics;\n    this.state = TraitState.Analyzed;\n    return this as AnalyzedTrait<D, A, R>;\n  }\n\n  toResolved(resolution: R|null, diagnostics: ts.Diagnostic[]|null): ResolvedTrait<D, A, R> {\n    // Only analyzed traits can be resolved.\n    this.assertTransitionLegal(TraitState.Analyzed, TraitState.Resolved);\n    if (this.analysis === null) {\n      throw new Error(`Cannot transition an Analyzed trait with a null analysis to Resolved`);\n    }\n    this.resolution = resolution;\n    this.state = TraitState.Resolved;\n    this.resolveDiagnostics = diagnostics;\n    return this as ResolvedTrait<D, A, R>;\n  }\n\n  toSkipped(): SkippedTrait<D, A, R> {\n    // Only pending traits can be skipped.\n    this.assertTransitionLegal(TraitState.Pending, TraitState.Skipped);\n    this.state = TraitState.Skipped;\n    return this as SkippedTrait<D, A, R>;\n  }\n\n  /**\n   * Verifies that the trait is currently in one of the `allowedState`s.\n   *\n   * If correctly used, the `Trait` type and transition methods prevent illegal transitions from\n   * occurring. However, if a reference to the `TraitImpl` instance typed with the previous\n   * interface is retained after calling one of its transition methods, it will allow for illegal\n   * transitions to take place. Hence, this assertion provides a little extra runtime protection.\n   */\n  private assertTransitionLegal(allowedState: TraitState, transitionTo: TraitState): void {\n    if (!(this.state === allowedState)) {\n      throw new Error(`Assertion failure: cannot transition from ${TraitState[this.state]} to ${\n          TraitState[transitionTo]}.`);\n    }\n  }\n\n  /**\n   * Construct a new `TraitImpl` in the pending state.\n   */\n  static pending<D, A, R>(handler: DecoratorHandler<D, A, R>, detected: DetectResult<D>):\n      PendingTrait<D, A, R> {\n    return new TraitImpl(handler, detected) as PendingTrait<D, A, R>;\n  }\n}\n"]}
111
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"trait.js","sourceRoot":"","sources":["../../../../../../../../../packages/compiler-cli/src/ngtsc/transform/src/trait.ts"],"names":[],"mappings":"AAAA;;;;;;GAMG;;;;;;;;;;;;;IAMH,IAAY,UAoBX;IApBD,WAAY,UAAU;QACpB;;WAEG;QACH,iDAAO,CAAA;QAEP;;WAEG;QACH,mDAAQ,CAAA;QAER;;WAEG;QACH,mDAAQ,CAAA;QAER;;WAEG;QACH,iDAAO,CAAA;IACT,CAAC,EApBW,UAAU,GAAV,kBAAU,KAAV,kBAAU,QAoBrB;IAkBD;;;OAGG;IACU,QAAA,KAAK,GAAG;QACnB,OAAO,EAAE,UACL,OAAqC,EAAE,QAAyB;YAChE,OAAA,SAAS,CAAC,OAAO,CAAC,OAAO,EAAE,QAAQ,CAAC;QAApC,CAAoC;KACzC,CAAC;IA6HF;;;OAGG;IACH;QAUE,mBAAY,OAAqC,EAAE,QAAyB;YAT5E,UAAK,GAAe,UAAU,CAAC,OAAO,CAAC;YAGvC,aAAQ,GAAqB,IAAI,CAAC;YAClC,WAAM,GAAW,IAAI,CAAC;YACtB,eAAU,GAAqB,IAAI,CAAC;YACpC,wBAAmB,GAAyB,IAAI,CAAC;YACjD,uBAAkB,GAAyB,IAAI,CAAC;YAG9C,IAAI,CAAC,OAAO,GAAG,OAAO,CAAC;YACvB,IAAI,CAAC,QAAQ,GAAG,QAAQ,CAAC;QAC3B,CAAC;QAED,8BAAU,GAAV,UAAW,QAAgB,EAAE,WAAiC,EAAE,MAAS;YAEvE,uCAAuC;YACvC,IAAI,CAAC,qBAAqB,CAAC,UAAU,CAAC,OAAO,EAAE,UAAU,CAAC,QAAQ,CAAC,CAAC;YACpE,IAAI,CAAC,QAAQ,GAAG,QAAQ,CAAC;YACzB,IAAI,CAAC,mBAAmB,GAAG,WAAW,CAAC;YACvC,IAAI,CAAC,MAAM,GAAG,MAAM,CAAC;YACrB,IAAI,CAAC,KAAK,GAAG,UAAU,CAAC,QAAQ,CAAC;YACjC,OAAO,IAAiC,CAAC;QAC3C,CAAC;QAED,8BAAU,GAAV,UAAW,UAAkB,EAAE,WAAiC;YAC9D,wCAAwC;YACxC,IAAI,CAAC,qBAAqB,CAAC,UAAU,CAAC,QAAQ,EAAE,UAAU,CAAC,QAAQ,CAAC,CAAC;YACrE,IAAI,IAAI,CAAC,QAAQ,KAAK,IAAI,EAAE;gBAC1B,MAAM,IAAI,KAAK,CAAC,sEAAsE,CAAC,CAAC;aACzF;YACD,IAAI,CAAC,UAAU,GAAG,UAAU,CAAC;YAC7B,IAAI,CAAC,KAAK,GAAG,UAAU,CAAC,QAAQ,CAAC;YACjC,IAAI,CAAC,kBAAkB,GAAG,WAAW,CAAC;YACtC,OAAO,IAAiC,CAAC;QAC3C,CAAC;QAED,6BAAS,GAAT;YACE,sCAAsC;YACtC,IAAI,CAAC,qBAAqB,CAAC,UAAU,CAAC,OAAO,EAAE,UAAU,CAAC,OAAO,CAAC,CAAC;YACnE,IAAI,CAAC,KAAK,GAAG,UAAU,CAAC,OAAO,CAAC;YAChC,OAAO,IAAgC,CAAC;QAC1C,CAAC;QAED;;;;;;;WAOG;QACK,yCAAqB,GAA7B,UAA8B,YAAwB,EAAE,YAAwB;YAC9E,IAAI,CAAC,CAAC,IAAI,CAAC,KAAK,KAAK,YAAY,CAAC,EAAE;gBAClC,MAAM,IAAI,KAAK,CAAC,+CAA6C,UAAU,CAAC,IAAI,CAAC,KAAK,CAAC,YAC/E,UAAU,CAAC,YAAY,CAAC,MAAG,CAAC,CAAC;aAClC;QACH,CAAC;QAED;;WAEG;QACI,iBAAO,GAAd,UACI,OAAqC,EAAE,QAAyB;YAClE,OAAO,IAAI,SAAS,CAAC,OAAO,EAAE,QAAQ,CAA6B,CAAC;QACtE,CAAC;QACH,gBAAC;IAAD,CAAC,AAnED,IAmEC","sourcesContent":["/**\n * @license\n * Copyright Google LLC All Rights Reserved.\n *\n * Use of this source code is governed by an MIT-style license that can be\n * found in the LICENSE file at https://angular.io/license\n */\n\nimport * as ts from 'typescript';\nimport {SemanticSymbol} from '../../incremental/semantic_graph';\nimport {DecoratorHandler, DetectResult} from './api';\n\nexport enum TraitState {\n  /**\n   * Pending traits are freshly created and have never been analyzed.\n   */\n  Pending,\n\n  /**\n   * Analyzed traits have successfully been analyzed, but are pending resolution.\n   */\n  Analyzed,\n\n  /**\n   * Resolved traits have successfully been analyzed and resolved and are ready for compilation.\n   */\n  Resolved,\n\n  /**\n   * Skipped traits are no longer considered for compilation.\n   */\n  Skipped,\n}\n\n/**\n * An Ivy aspect added to a class (for example, the compilation of a component definition).\n *\n * Traits are created when a `DecoratorHandler` matches a class. Each trait begins in a pending\n * state and undergoes transitions as compilation proceeds through the various steps.\n *\n * In practice, traits are instances of the private class `TraitImpl` declared below. Through the\n * various interfaces included in this union type, the legal API of a trait in any given state is\n * represented in the type system. This includes any possible transitions from one type to the next.\n *\n * This not only simplifies the implementation, but ensures traits are monomorphic objects as\n * they're all just \"views\" in the type system of the same object (which never changes shape).\n */\nexport type Trait<D, A, S extends SemanticSymbol|null, R> = PendingTrait<D, A, S, R>|\n    SkippedTrait<D, A, S, R>|AnalyzedTrait<D, A, S, R>|ResolvedTrait<D, A, S, R>;\n\n/**\n * The value side of `Trait` exposes a helper to create a `Trait` in a pending state (by delegating\n * to `TraitImpl`).\n */\nexport const Trait = {\n  pending: <D, A, S extends SemanticSymbol|null, R>(\n      handler: DecoratorHandler<D, A, S, R>, detected: DetectResult<D>): PendingTrait<D, A, S, R> =>\n      TraitImpl.pending(handler, detected),\n};\n\n/**\n * The part of the `Trait` interface that's common to all trait states.\n */\nexport interface TraitBase<D, A, S extends SemanticSymbol|null, R> {\n  /**\n   * Current state of the trait.\n   *\n   * This will be narrowed in the interfaces for each specific state.\n   */\n  state: TraitState;\n\n  /**\n   * The `DecoratorHandler` which matched on the class to create this trait.\n   */\n  handler: DecoratorHandler<D, A, S, R>;\n\n  /**\n   * The detection result (of `handler.detect`) which indicated that this trait applied to the\n   * class.\n   *\n   * This is mainly used to cache the detection between pre-analysis and analysis.\n   */\n  detected: DetectResult<D>;\n}\n\n/**\n * A trait in the pending state.\n *\n * Pending traits have yet to be analyzed in any way.\n */\nexport interface PendingTrait<D, A, S extends SemanticSymbol|null, R> extends\n    TraitBase<D, A, S, R> {\n  state: TraitState.Pending;\n\n  /**\n   * This pending trait has been successfully analyzed, and should transition to the \"analyzed\"\n   * state.\n   */\n  toAnalyzed(analysis: A|null, diagnostics: ts.Diagnostic[]|null, symbol: S):\n      AnalyzedTrait<D, A, S, R>;\n\n  /**\n   * During analysis it was determined that this trait is not eligible for compilation after all,\n   * and should be transitioned to the \"skipped\" state.\n   */\n  toSkipped(): SkippedTrait<D, A, S, R>;\n}\n\n/**\n * A trait in the \"skipped\" state.\n *\n * Skipped traits aren't considered for compilation.\n *\n * This is a terminal state.\n */\nexport interface SkippedTrait<D, A, S extends SemanticSymbol|null, R> extends\n    TraitBase<D, A, S, R> {\n  state: TraitState.Skipped;\n}\n\n/**\n * A trait in the \"analyzed\" state.\n *\n * Analyzed traits have analysis results available, and are eligible for resolution.\n */\nexport interface AnalyzedTrait<D, A, S extends SemanticSymbol|null, R> extends\n    TraitBase<D, A, S, R> {\n  state: TraitState.Analyzed;\n  symbol: S;\n\n  /**\n   * Analysis results of the given trait (if able to be produced), or `null` if analysis failed\n   * completely.\n   */\n  analysis: Readonly<A>|null;\n\n  /**\n   * Any diagnostics that resulted from analysis, or `null` if none.\n   */\n  analysisDiagnostics: ts.Diagnostic[]|null;\n\n  /**\n   * This analyzed trait has been successfully resolved, and should be transitioned to the\n   * \"resolved\" state.\n   */\n  toResolved(resolution: R|null, diagnostics: ts.Diagnostic[]|null): ResolvedTrait<D, A, S, R>;\n}\n\n/**\n * A trait in the \"resolved\" state.\n *\n * Resolved traits have been successfully analyzed and resolved, contain no errors, and are ready\n * for the compilation phase.\n *\n * This is a terminal state.\n */\nexport interface ResolvedTrait<D, A, S extends SemanticSymbol|null, R> extends\n    TraitBase<D, A, S, R> {\n  state: TraitState.Resolved;\n  symbol: S;\n\n  /**\n   * Resolved traits must have produced valid analysis results.\n   */\n  analysis: Readonly<A>;\n\n  /**\n   * Analysis may have still resulted in diagnostics.\n   */\n  analysisDiagnostics: ts.Diagnostic[]|null;\n\n  /**\n   * Diagnostics resulting from resolution are tracked separately from\n   */\n  resolveDiagnostics: ts.Diagnostic[]|null;\n\n  /**\n   * The results returned by a successful resolution of the given class/`DecoratorHandler`\n   * combination.\n   */\n  resolution: Readonly<R>|null;\n}\n\n/**\n * An implementation of the `Trait` type which transitions safely between the various\n * `TraitState`s.\n */\nclass TraitImpl<D, A, S extends SemanticSymbol|null, R> {\n  state: TraitState = TraitState.Pending;\n  handler: DecoratorHandler<D, A, S, R>;\n  detected: DetectResult<D>;\n  analysis: Readonly<A>|null = null;\n  symbol: S|null = null;\n  resolution: Readonly<R>|null = null;\n  analysisDiagnostics: ts.Diagnostic[]|null = null;\n  resolveDiagnostics: ts.Diagnostic[]|null = null;\n\n  constructor(handler: DecoratorHandler<D, A, S, R>, detected: DetectResult<D>) {\n    this.handler = handler;\n    this.detected = detected;\n  }\n\n  toAnalyzed(analysis: A|null, diagnostics: ts.Diagnostic[]|null, symbol: S):\n      AnalyzedTrait<D, A, S, R> {\n    // Only pending traits can be analyzed.\n    this.assertTransitionLegal(TraitState.Pending, TraitState.Analyzed);\n    this.analysis = analysis;\n    this.analysisDiagnostics = diagnostics;\n    this.symbol = symbol;\n    this.state = TraitState.Analyzed;\n    return this as AnalyzedTrait<D, A, S, R>;\n  }\n\n  toResolved(resolution: R|null, diagnostics: ts.Diagnostic[]|null): ResolvedTrait<D, A, S, R> {\n    // Only analyzed traits can be resolved.\n    this.assertTransitionLegal(TraitState.Analyzed, TraitState.Resolved);\n    if (this.analysis === null) {\n      throw new Error(`Cannot transition an Analyzed trait with a null analysis to Resolved`);\n    }\n    this.resolution = resolution;\n    this.state = TraitState.Resolved;\n    this.resolveDiagnostics = diagnostics;\n    return this as ResolvedTrait<D, A, S, R>;\n  }\n\n  toSkipped(): SkippedTrait<D, A, S, R> {\n    // Only pending traits can be skipped.\n    this.assertTransitionLegal(TraitState.Pending, TraitState.Skipped);\n    this.state = TraitState.Skipped;\n    return this as SkippedTrait<D, A, S, R>;\n  }\n\n  /**\n   * Verifies that the trait is currently in one of the `allowedState`s.\n   *\n   * If correctly used, the `Trait` type and transition methods prevent illegal transitions from\n   * occurring. However, if a reference to the `TraitImpl` instance typed with the previous\n   * interface is retained after calling one of its transition methods, it will allow for illegal\n   * transitions to take place. Hence, this assertion provides a little extra runtime protection.\n   */\n  private assertTransitionLegal(allowedState: TraitState, transitionTo: TraitState): void {\n    if (!(this.state === allowedState)) {\n      throw new Error(`Assertion failure: cannot transition from ${TraitState[this.state]} to ${\n          TraitState[transitionTo]}.`);\n    }\n  }\n\n  /**\n   * Construct a new `TraitImpl` in the pending state.\n   */\n  static pending<D, A, S extends SemanticSymbol|null, R>(\n      handler: DecoratorHandler<D, A, S, R>, detected: DetectResult<D>): PendingTrait<D, A, S, R> {\n    return new TraitImpl(handler, detected) as PendingTrait<D, A, S, R>;\n  }\n}\n"]}
@@ -122,7 +122,7 @@
122
122
  // pass.
123
123
  var ngExpr = this.refEmitter.emit(ref, this.contextFile, imports_1.ImportFlags.NoAliasing);
124
124
  // Use `translateExpression` to convert the `Expression` into a `ts.Expression`.
125
- return translator_1.translateExpression(ngExpr, this.importManager);
125
+ return translator_1.translateExpression(ngExpr.expression, this.importManager);
126
126
  };
127
127
  /**
128
128
  * Generate a `ts.TypeNode` that references the given node as a type.
@@ -133,7 +133,7 @@
133
133
  var ngExpr = this.refEmitter.emit(ref, this.contextFile, imports_1.ImportFlags.NoAliasing | imports_1.ImportFlags.AllowTypeImports);
134
134
  // Create an `ExpressionType` from the `Expression` and translate it via `translateType`.
135
135
  // TODO(alxhub): support references to types with generic arguments in a clean way.
136
- return translator_1.translateType(new compiler_1.ExpressionType(ngExpr), this.importManager);
136
+ return translator_1.translateType(new compiler_1.ExpressionType(ngExpr.expression), this.importManager);
137
137
  };
138
138
  Environment.prototype.emitTypeParameters = function (declaration) {
139
139
  var _this = this;
@@ -157,4 +157,4 @@
157
157
  }());
158
158
  exports.Environment = Environment;
159
159
  });
160
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"environment.js","sourceRoot":"","sources":["../../../../../../../../../packages/compiler-cli/src/ngtsc/typecheck/src/environment.ts"],"names":[],"mappings":"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","sourcesContent":["/**\n * @license\n * Copyright Google LLC All Rights Reserved.\n *\n * Use of this source code is governed by an MIT-style license that can be\n * found in the LICENSE file at https://angular.io/license\n */\n\nimport {ExpressionType, ExternalExpr, Type, WrappedNodeExpr} from '@angular/compiler';\nimport * as ts from 'typescript';\n\nimport {ImportFlags, Reference, ReferenceEmitter} from '../../imports';\nimport {ClassDeclaration, ReflectionHost} from '../../reflection';\nimport {ImportManager, translateExpression, translateType} from '../../translator';\nimport {TypeCheckableDirectiveMeta, TypeCheckingConfig, TypeCtorMetadata} from '../api';\n\nimport {tsDeclareVariable} from './ts_util';\nimport {generateTypeCtorDeclarationFn, requiresInlineTypeCtor} from './type_constructor';\nimport {TypeParameterEmitter} from './type_parameter_emitter';\n\n/**\n * A context which hosts one or more Type Check Blocks (TCBs).\n *\n * An `Environment` supports the generation of TCBs by tracking necessary imports, declarations of\n * type constructors, and other statements beyond the type-checking code within the TCB itself.\n * Through method calls on `Environment`, the TCB generator can request `ts.Expression`s which\n * reference declarations in the `Environment` for these artifacts`.\n *\n * `Environment` can be used in a standalone fashion, or can be extended to support more specialized\n * usage.\n */\nexport class Environment {\n  private nextIds = {\n    pipeInst: 1,\n    typeCtor: 1,\n  };\n\n  private typeCtors = new Map<ClassDeclaration, ts.Expression>();\n  protected typeCtorStatements: ts.Statement[] = [];\n\n  private pipeInsts = new Map<ClassDeclaration, ts.Expression>();\n  protected pipeInstStatements: ts.Statement[] = [];\n\n  constructor(\n      readonly config: TypeCheckingConfig, protected importManager: ImportManager,\n      private refEmitter: ReferenceEmitter, private reflector: ReflectionHost,\n      protected contextFile: ts.SourceFile) {}\n\n  /**\n   * Get an expression referring to a type constructor for the given directive.\n   *\n   * Depending on the shape of the directive itself, this could be either a reference to a declared\n   * type constructor, or to an inline type constructor.\n   */\n  typeCtorFor(dir: TypeCheckableDirectiveMeta): ts.Expression {\n    const dirRef = dir.ref as Reference<ClassDeclaration<ts.ClassDeclaration>>;\n    const node = dirRef.node;\n    if (this.typeCtors.has(node)) {\n      return this.typeCtors.get(node)!;\n    }\n\n    if (requiresInlineTypeCtor(node, this.reflector)) {\n      // The constructor has already been created inline, we just need to construct a reference to\n      // it.\n      const ref = this.reference(dirRef);\n      const typeCtorExpr = ts.createPropertyAccess(ref, 'ngTypeCtor');\n      this.typeCtors.set(node, typeCtorExpr);\n      return typeCtorExpr;\n    } else {\n      const fnName = `_ctor${this.nextIds.typeCtor++}`;\n      const nodeTypeRef = this.referenceType(dirRef);\n      if (!ts.isTypeReferenceNode(nodeTypeRef)) {\n        throw new Error(`Expected TypeReferenceNode from reference to ${dirRef.debugName}`);\n      }\n      const meta: TypeCtorMetadata = {\n        fnName,\n        body: true,\n        fields: {\n          inputs: dir.inputs.classPropertyNames,\n          outputs: dir.outputs.classPropertyNames,\n          // TODO: support queries\n          queries: dir.queries,\n        },\n        coercedInputFields: dir.coercedInputFields,\n      };\n      const typeParams = this.emitTypeParameters(node);\n      const typeCtor = generateTypeCtorDeclarationFn(\n          node, meta, nodeTypeRef.typeName, typeParams, this.reflector);\n      this.typeCtorStatements.push(typeCtor);\n      const fnId = ts.createIdentifier(fnName);\n      this.typeCtors.set(node, fnId);\n      return fnId;\n    }\n  }\n\n  /*\n   * Get an expression referring to an instance of the given pipe.\n   */\n  pipeInst(ref: Reference<ClassDeclaration<ts.ClassDeclaration>>): ts.Expression {\n    if (this.pipeInsts.has(ref.node)) {\n      return this.pipeInsts.get(ref.node)!;\n    }\n\n    const pipeType = this.referenceType(ref);\n    const pipeInstId = ts.createIdentifier(`_pipe${this.nextIds.pipeInst++}`);\n\n    this.pipeInstStatements.push(tsDeclareVariable(pipeInstId, pipeType));\n    this.pipeInsts.set(ref.node, pipeInstId);\n\n    return pipeInstId;\n  }\n\n  /**\n   * Generate a `ts.Expression` that references the given node.\n   *\n   * This may involve importing the node into the file if it's not declared there already.\n   */\n  reference(ref: Reference<ClassDeclaration<ts.ClassDeclaration>>): ts.Expression {\n    // Disable aliasing for imports generated in a template type-checking context, as there is no\n    // guarantee that any alias re-exports exist in the .d.ts files. It's safe to use direct imports\n    // in these cases as there is no strict dependency checking during the template type-checking\n    // pass.\n    const ngExpr = this.refEmitter.emit(ref, this.contextFile, ImportFlags.NoAliasing);\n\n    // Use `translateExpression` to convert the `Expression` into a `ts.Expression`.\n    return translateExpression(ngExpr, this.importManager);\n  }\n\n  /**\n   * Generate a `ts.TypeNode` that references the given node as a type.\n   *\n   * This may involve importing the node into the file if it's not declared there already.\n   */\n  referenceType(ref: Reference): ts.TypeNode {\n    const ngExpr = this.refEmitter.emit(\n        ref, this.contextFile, ImportFlags.NoAliasing | ImportFlags.AllowTypeImports);\n\n    // Create an `ExpressionType` from the `Expression` and translate it via `translateType`.\n    // TODO(alxhub): support references to types with generic arguments in a clean way.\n    return translateType(new ExpressionType(ngExpr), this.importManager);\n  }\n\n  private emitTypeParameters(declaration: ClassDeclaration<ts.ClassDeclaration>):\n      ts.TypeParameterDeclaration[]|undefined {\n    const emitter = new TypeParameterEmitter(declaration.typeParameters, this.reflector);\n    return emitter.emit(ref => this.referenceType(ref));\n  }\n\n  /**\n   * Generate a `ts.TypeNode` that references a given type from the provided module.\n   *\n   * This will involve importing the type into the file, and will also add type parameters if\n   * provided.\n   */\n  referenceExternalType(moduleName: string, name: string, typeParams?: Type[]): ts.TypeNode {\n    const external = new ExternalExpr({moduleName, name});\n    return translateType(\n        new ExpressionType(external, [/* modifiers */], typeParams), this.importManager);\n  }\n\n  getPreludeStatements(): ts.Statement[] {\n    return [\n      ...this.pipeInstStatements,\n      ...this.typeCtorStatements,\n    ];\n  }\n}\n"]}
160
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"environment.js","sourceRoot":"","sources":["../../../../../../../../../packages/compiler-cli/src/ngtsc/typecheck/src/environment.ts"],"names":[],"mappings":"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","sourcesContent":["/**\n * @license\n * Copyright Google LLC All Rights Reserved.\n *\n * Use of this source code is governed by an MIT-style license that can be\n * found in the LICENSE file at https://angular.io/license\n */\n\nimport {ExpressionType, ExternalExpr, Type, WrappedNodeExpr} from '@angular/compiler';\nimport * as ts from 'typescript';\n\nimport {ImportFlags, Reference, ReferenceEmitter} from '../../imports';\nimport {ClassDeclaration, ReflectionHost} from '../../reflection';\nimport {ImportManager, translateExpression, translateType} from '../../translator';\nimport {TypeCheckableDirectiveMeta, TypeCheckingConfig, TypeCtorMetadata} from '../api';\n\nimport {tsDeclareVariable} from './ts_util';\nimport {generateTypeCtorDeclarationFn, requiresInlineTypeCtor} from './type_constructor';\nimport {TypeParameterEmitter} from './type_parameter_emitter';\n\n/**\n * A context which hosts one or more Type Check Blocks (TCBs).\n *\n * An `Environment` supports the generation of TCBs by tracking necessary imports, declarations of\n * type constructors, and other statements beyond the type-checking code within the TCB itself.\n * Through method calls on `Environment`, the TCB generator can request `ts.Expression`s which\n * reference declarations in the `Environment` for these artifacts`.\n *\n * `Environment` can be used in a standalone fashion, or can be extended to support more specialized\n * usage.\n */\nexport class Environment {\n  private nextIds = {\n    pipeInst: 1,\n    typeCtor: 1,\n  };\n\n  private typeCtors = new Map<ClassDeclaration, ts.Expression>();\n  protected typeCtorStatements: ts.Statement[] = [];\n\n  private pipeInsts = new Map<ClassDeclaration, ts.Expression>();\n  protected pipeInstStatements: ts.Statement[] = [];\n\n  constructor(\n      readonly config: TypeCheckingConfig, protected importManager: ImportManager,\n      private refEmitter: ReferenceEmitter, private reflector: ReflectionHost,\n      protected contextFile: ts.SourceFile) {}\n\n  /**\n   * Get an expression referring to a type constructor for the given directive.\n   *\n   * Depending on the shape of the directive itself, this could be either a reference to a declared\n   * type constructor, or to an inline type constructor.\n   */\n  typeCtorFor(dir: TypeCheckableDirectiveMeta): ts.Expression {\n    const dirRef = dir.ref as Reference<ClassDeclaration<ts.ClassDeclaration>>;\n    const node = dirRef.node;\n    if (this.typeCtors.has(node)) {\n      return this.typeCtors.get(node)!;\n    }\n\n    if (requiresInlineTypeCtor(node, this.reflector)) {\n      // The constructor has already been created inline, we just need to construct a reference to\n      // it.\n      const ref = this.reference(dirRef);\n      const typeCtorExpr = ts.createPropertyAccess(ref, 'ngTypeCtor');\n      this.typeCtors.set(node, typeCtorExpr);\n      return typeCtorExpr;\n    } else {\n      const fnName = `_ctor${this.nextIds.typeCtor++}`;\n      const nodeTypeRef = this.referenceType(dirRef);\n      if (!ts.isTypeReferenceNode(nodeTypeRef)) {\n        throw new Error(`Expected TypeReferenceNode from reference to ${dirRef.debugName}`);\n      }\n      const meta: TypeCtorMetadata = {\n        fnName,\n        body: true,\n        fields: {\n          inputs: dir.inputs.classPropertyNames,\n          outputs: dir.outputs.classPropertyNames,\n          // TODO: support queries\n          queries: dir.queries,\n        },\n        coercedInputFields: dir.coercedInputFields,\n      };\n      const typeParams = this.emitTypeParameters(node);\n      const typeCtor = generateTypeCtorDeclarationFn(\n          node, meta, nodeTypeRef.typeName, typeParams, this.reflector);\n      this.typeCtorStatements.push(typeCtor);\n      const fnId = ts.createIdentifier(fnName);\n      this.typeCtors.set(node, fnId);\n      return fnId;\n    }\n  }\n\n  /*\n   * Get an expression referring to an instance of the given pipe.\n   */\n  pipeInst(ref: Reference<ClassDeclaration<ts.ClassDeclaration>>): ts.Expression {\n    if (this.pipeInsts.has(ref.node)) {\n      return this.pipeInsts.get(ref.node)!;\n    }\n\n    const pipeType = this.referenceType(ref);\n    const pipeInstId = ts.createIdentifier(`_pipe${this.nextIds.pipeInst++}`);\n\n    this.pipeInstStatements.push(tsDeclareVariable(pipeInstId, pipeType));\n    this.pipeInsts.set(ref.node, pipeInstId);\n\n    return pipeInstId;\n  }\n\n  /**\n   * Generate a `ts.Expression` that references the given node.\n   *\n   * This may involve importing the node into the file if it's not declared there already.\n   */\n  reference(ref: Reference<ClassDeclaration<ts.ClassDeclaration>>): ts.Expression {\n    // Disable aliasing for imports generated in a template type-checking context, as there is no\n    // guarantee that any alias re-exports exist in the .d.ts files. It's safe to use direct imports\n    // in these cases as there is no strict dependency checking during the template type-checking\n    // pass.\n    const ngExpr = this.refEmitter.emit(ref, this.contextFile, ImportFlags.NoAliasing);\n\n    // Use `translateExpression` to convert the `Expression` into a `ts.Expression`.\n    return translateExpression(ngExpr.expression, this.importManager);\n  }\n\n  /**\n   * Generate a `ts.TypeNode` that references the given node as a type.\n   *\n   * This may involve importing the node into the file if it's not declared there already.\n   */\n  referenceType(ref: Reference): ts.TypeNode {\n    const ngExpr = this.refEmitter.emit(\n        ref, this.contextFile, ImportFlags.NoAliasing | ImportFlags.AllowTypeImports);\n\n    // Create an `ExpressionType` from the `Expression` and translate it via `translateType`.\n    // TODO(alxhub): support references to types with generic arguments in a clean way.\n    return translateType(new ExpressionType(ngExpr.expression), this.importManager);\n  }\n\n  private emitTypeParameters(declaration: ClassDeclaration<ts.ClassDeclaration>):\n      ts.TypeParameterDeclaration[]|undefined {\n    const emitter = new TypeParameterEmitter(declaration.typeParameters, this.reflector);\n    return emitter.emit(ref => this.referenceType(ref));\n  }\n\n  /**\n   * Generate a `ts.TypeNode` that references a given type from the provided module.\n   *\n   * This will involve importing the type into the file, and will also add type parameters if\n   * provided.\n   */\n  referenceExternalType(moduleName: string, name: string, typeParams?: Type[]): ts.TypeNode {\n    const external = new ExternalExpr({moduleName, name});\n    return translateType(\n        new ExpressionType(external, [/* modifiers */], typeParams), this.importManager);\n  }\n\n  getPreludeStatements(): ts.Statement[] {\n    return [\n      ...this.pipeInstStatements,\n      ...this.typeCtorStatements,\n    ];\n  }\n}\n"]}