@angular/compiler-cli 11.2.9 → 11.2.13

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.js +6 -6
  4. package/ngcc/src/packages/build_marker.d.ts +1 -1
  5. package/ngcc/src/packages/build_marker.js +1 -1
  6. package/package.json +2 -2
  7. package/src/ngtsc/annotations/src/component.d.ts +2 -3
  8. package/src/ngtsc/annotations/src/component.js +4 -5
  9. package/src/ngtsc/annotations/src/directive.d.ts +3 -4
  10. package/src/ngtsc/annotations/src/directive.js +6 -7
  11. package/src/ngtsc/annotations/src/injectable.d.ts +1 -3
  12. package/src/ngtsc/annotations/src/injectable.js +9 -9
  13. package/src/ngtsc/annotations/src/metadata.d.ts +1 -2
  14. package/src/ngtsc/annotations/src/metadata.js +5 -5
  15. package/src/ngtsc/annotations/src/ng_module.d.ts +2 -3
  16. package/src/ngtsc/annotations/src/ng_module.js +4 -5
  17. package/src/ngtsc/annotations/src/pipe.d.ts +1 -3
  18. package/src/ngtsc/annotations/src/pipe.js +4 -5
  19. package/src/ngtsc/annotations/src/util.d.ts +5 -5
  20. package/src/ngtsc/annotations/src/util.js +12 -11
  21. package/src/ngtsc/core/api/src/interfaces.d.ts +4 -1
  22. package/src/ngtsc/core/api/src/interfaces.js +1 -1
  23. package/src/ngtsc/core/src/compiler.js +9 -10
  24. package/src/ngtsc/core/src/host.d.ts +1 -1
  25. package/src/ngtsc/diagnostics/src/error_code.d.ts +5 -0
  26. package/src/ngtsc/diagnostics/src/error_code.js +6 -1
  27. package/src/ngtsc/imports/index.d.ts +1 -1
  28. package/src/ngtsc/imports/index.js +2 -3
  29. package/src/ngtsc/imports/src/default.d.ts +10 -37
  30. package/src/ngtsc/imports/src/default.js +22 -37
  31. package/src/ngtsc/incremental/src/state.js +6 -4
  32. package/src/ngtsc/resource/src/loader.js +3 -2
  33. package/src/ngtsc/transform/src/transform.d.ts +2 -2
  34. package/src/ngtsc/transform/src/transform.js +18 -16
  35. package/src/ngtsc/translator/index.d.ts +1 -1
  36. package/src/ngtsc/translator/index.js +1 -1
  37. package/src/ngtsc/translator/src/translator.d.ts +3 -3
  38. package/src/ngtsc/translator/src/translator.js +3 -3
  39. package/src/ngtsc/typecheck/api/checker.d.ts +1 -1
  40. package/src/ngtsc/typecheck/api/checker.js +1 -1
  41. package/src/ngtsc/typecheck/api/completion.d.ts +5 -0
  42. package/src/ngtsc/typecheck/api/completion.js +1 -1
  43. package/src/ngtsc/typecheck/src/checker.d.ts +2 -2
  44. package/src/ngtsc/typecheck/src/checker.js +3 -3
  45. package/src/ngtsc/typecheck/src/completion.d.ts +17 -7
  46. package/src/ngtsc/typecheck/src/completion.js +82 -47
  47. package/src/ngtsc/typecheck/src/context.js +26 -14
  48. package/src/ngtsc/typecheck/src/expression.js +4 -2
  49. package/src/ngtsc/typecheck/src/host.js +5 -7
  50. package/src/ngtsc/typecheck/src/tcb_util.d.ts +24 -2
  51. package/src/ngtsc/typecheck/src/tcb_util.js +40 -11
  52. package/src/ngtsc/typecheck/src/type_check_block.d.ts +28 -1
  53. package/src/ngtsc/typecheck/src/type_check_block.js +61 -25
  54. package/src/ngtsc/typecheck/src/type_check_file.d.ts +2 -1
  55. package/src/ngtsc/typecheck/src/type_check_file.js +3 -3
  56. package/src/ngtsc/typecheck/src/type_constructor.js +4 -8
  57. package/src/ngtsc/util/src/typescript.d.ts +4 -0
  58. package/src/ngtsc/util/src/typescript.js +13 -2
  59. package/src/transformers/program.js +70 -3
  60. package/src/version.js +1 -1
@@ -103,6 +103,11 @@
103
103
  * Raised when a directive/pipe is part of the declarations of two or more NgModules.
104
104
  */
105
105
  ErrorCode[ErrorCode["NGMODULE_DECLARATION_NOT_UNIQUE"] = 6007] = "NGMODULE_DECLARATION_NOT_UNIQUE";
106
+ /**
107
+ * Not actually raised by the compiler, but reserved for documentation of a View Engine error when
108
+ * a View Engine build depends on an Ivy-compiled NgModule.
109
+ */
110
+ ErrorCode[ErrorCode["NGMODULE_VE_DEPENDENCY_ON_IVY_LIB"] = 6999] = "NGMODULE_VE_DEPENDENCY_ON_IVY_LIB";
106
111
  /**
107
112
  * An element name failed validation against the DOM schema.
108
113
  */
@@ -198,4 +203,4 @@
198
203
  }
199
204
  exports.ngErrorCode = ngErrorCode;
200
205
  });
201
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"error_code.js","sourceRoot":"","sources":["../../../../../../../../../packages/compiler-cli/src/ngtsc/diagnostics/src/error_code.ts"],"names":[],"mappings":"AAAA;;;;;;GAMG;;;;;;;;;;;;;IAEH;;OAEG;IACH,IAAY,SAkLX;IAlLD,WAAY,SAAS;QACnB,sFAAgC,CAAA;QAChC,8EAA4B,CAAA;QAC5B,4EAA2B,CAAA;QAC3B,4FAAmC,CAAA;QACnC,4EAA2B,CAAA;QAE3B;;WAEG;QACH,0EAA0B,CAAA;QAE1B,4EAA2B,CAAA;QAC3B,sEAAwB,CAAA;QAExB,wFAAiC,CAAA;QACjC,sEAAwB,CAAA;QACxB,0EAA0B,CAAA;QAC1B,wFAAiC,CAAA;QAEjC,8FAA8F;QAC9F,4EAA2B,CAAA;QAE3B;;;WAGG;QACH,0GAA0C,CAAA;QAE1C;;;WAGG;QACH,oHAA+C,CAAA;QAE/C;;;WAGG;QACH,4FAAmC,CAAA;QAEnC,0EAA0B,CAAA;QAC1B,4GAA2C,CAAA;QAC3C;;;WAGG;QACH,8EAA4B,CAAA;QAE5B,0FAAkC,CAAA;QAClC,kJAA8D,CAAA;QAE9D;;;WAGG;QACH,oFAA+B,CAAA;QAE/B;;WAEG;QACH,4EAA2B,CAAA;QAE3B;;WAEG;QACH,4FAAmC,CAAA;QAEnC;;WAEG;QACH,kFAA8B,CAAA;QAE9B;;WAEG;QACH,kFAA8B,CAAA;QAE9B;;;WAGG;QACH,sFAAgC,CAAA;QAEhC;;;WAGG;QACH,gIAAqD,CAAA;QAErD;;;WAGG;QACH,oGAAuC,CAAA;QAEvC;;WAEG;QACH,kGAAsC,CAAA;QAEtC;;WAEG;QACH,gFAA6B,CAAA;QAE7B;;WAEG;QACH,oFAA+B,CAAA;QAE/B;;WAEG;QACH,oFAA+B,CAAA;QAE/B;;WAEG;QACH,4DAAmB,CAAA;QAEnB;;;;;;;;;;;WAWG;QACH,0FAAkC,CAAA;QAElC;;;;;;;WAOG;QACH,gGAAqC,CAAA;QAErC;;;WAGG;QACH,0EAA0B,CAAA;QAE1B;;;WAGG;QACH,sFAAgC,CAAA;QAEhC;;WAEG;QACH,sFAAgC,CAAA;QAEhC,4EAA4E;QAC5E,iGAAiG;QACjG,sFAAsF;QAEtF;;;WAGG;QACH,qFAAgC,CAAA;QAEhC;;;;WAIG;QACH,uGAAyC,CAAA;IAC3C,CAAC,EAlLW,SAAS,GAAT,iBAAS,KAAT,iBAAS,QAkLpB;IAED;;;;;OAKG;IACU,QAAA,2BAA2B,GAAG,2BAA2B,CAAC;IAEvE;;;;OAIG;IACU,QAAA,2BAA2B,GAAG,IAAI,GAAG,CAAC;QACjD,SAAS,CAAC,yBAAyB;QACnC,SAAS,CAAC,qBAAqB;QAC/B,SAAS,CAAC,mBAAmB;QAC7B,SAAS,CAAC,sBAAsB;QAChC,SAAS,CAAC,wBAAwB;QAClC,SAAS,CAAC,wBAAwB;KACnC,CAAC,CAAC;IAEH;;OAEG;IACH,SAAgB,WAAW,CAAC,IAAe;QACzC,OAAO,QAAQ,CAAC,KAAK,GAAG,IAAI,CAAC,CAAC;IAChC,CAAC;IAFD,kCAEC","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\n/**\n * @publicApi\n */\nexport enum ErrorCode {\n  DECORATOR_ARG_NOT_LITERAL = 1001,\n  DECORATOR_ARITY_WRONG = 1002,\n  DECORATOR_NOT_CALLED = 1003,\n  DECORATOR_ON_ANONYMOUS_CLASS = 1004,\n  DECORATOR_UNEXPECTED = 1005,\n\n  /**\n   * This error code indicates that there are incompatible decorators on a type or a class field.\n   */\n  DECORATOR_COLLISION = 1006,\n\n  VALUE_HAS_WRONG_TYPE = 1010,\n  VALUE_NOT_LITERAL = 1011,\n\n  COMPONENT_MISSING_TEMPLATE = 2001,\n  PIPE_MISSING_NAME = 2002,\n  PARAM_MISSING_TOKEN = 2003,\n  DIRECTIVE_MISSING_SELECTOR = 2004,\n\n  /** Raised when an undecorated class is passed in as a provider to a module or a directive. */\n  UNDECORATED_PROVIDER = 2005,\n\n  /**\n   * Raised when a Directive inherits its constructor from a base class without an Angular\n   * decorator.\n   */\n  DIRECTIVE_INHERITS_UNDECORATED_CTOR = 2006,\n\n  /**\n   * Raised when an undecorated class that is using Angular features\n   * has been discovered.\n   */\n  UNDECORATED_CLASS_USING_ANGULAR_FEATURES = 2007,\n\n  /**\n   * Raised when an component cannot resolve an external resource, such as a template or a style\n   * sheet.\n   */\n  COMPONENT_RESOURCE_NOT_FOUND = 2008,\n\n  SYMBOL_NOT_EXPORTED = 3001,\n  SYMBOL_EXPORTED_UNDER_DIFFERENT_NAME = 3002,\n  /**\n   * Raised when a relationship between directives and/or pipes would cause a cyclic import to be\n   * created that cannot be handled, such as in partial compilation mode.\n   */\n  IMPORT_CYCLE_DETECTED = 3003,\n\n  CONFIG_FLAT_MODULE_NO_INDEX = 4001,\n  CONFIG_STRICT_TEMPLATES_IMPLIES_FULL_TEMPLATE_TYPECHECK = 4002,\n\n  /**\n   * Raised when a host expression has a parse error, such as a host listener or host binding\n   * expression containing a pipe.\n   */\n  HOST_BINDING_PARSE_ERROR = 5001,\n\n  /**\n   * Raised when the compiler cannot parse a component's template.\n   */\n  TEMPLATE_PARSE_ERROR = 5002,\n\n  /**\n   * Raised when an NgModule contains an invalid reference in `declarations`.\n   */\n  NGMODULE_INVALID_DECLARATION = 6001,\n\n  /**\n   * Raised when an NgModule contains an invalid type in `imports`.\n   */\n  NGMODULE_INVALID_IMPORT = 6002,\n\n  /**\n   * Raised when an NgModule contains an invalid type in `exports`.\n   */\n  NGMODULE_INVALID_EXPORT = 6003,\n\n  /**\n   * Raised when an NgModule contains a type in `exports` which is neither in `declarations` nor\n   * otherwise imported.\n   */\n  NGMODULE_INVALID_REEXPORT = 6004,\n\n  /**\n   * Raised when a `ModuleWithProviders` with a missing\n   * generic type argument is passed into an `NgModule`.\n   */\n  NGMODULE_MODULE_WITH_PROVIDERS_MISSING_GENERIC = 6005,\n\n  /**\n   * Raised when an NgModule exports multiple directives/pipes of the same name and the compiler\n   * attempts to generate private re-exports within the NgModule file.\n   */\n  NGMODULE_REEXPORT_NAME_COLLISION = 6006,\n\n  /**\n   * Raised when a directive/pipe is part of the declarations of two or more NgModules.\n   */\n  NGMODULE_DECLARATION_NOT_UNIQUE = 6007,\n\n  /**\n   * An element name failed validation against the DOM schema.\n   */\n  SCHEMA_INVALID_ELEMENT = 8001,\n\n  /**\n   * An element's attribute name failed validation against the DOM schema.\n   */\n  SCHEMA_INVALID_ATTRIBUTE = 8002,\n\n  /**\n   * No matching directive was found for a `#ref=\"target\"` expression.\n   */\n  MISSING_REFERENCE_TARGET = 8003,\n\n  /**\n   * No matching pipe was found for a\n   */\n  MISSING_PIPE = 8004,\n\n  /**\n   * The left-hand side of an assignment expression was a template variable. Effectively, the\n   * template looked like:\n   *\n   * ```\n   * <ng-template let-something>\n   *   <button (click)=\"something = ...\">...</button>\n   * </ng-template>\n   * ```\n   *\n   * Template variables are read-only.\n   */\n  WRITE_TO_READ_ONLY_VARIABLE = 8005,\n\n  /**\n   * A template variable was declared twice. For example:\n   *\n   * ```html\n   * <div *ngFor=\"let i of items; let i = index\">\n   * </div>\n   * ```\n   */\n  DUPLICATE_VARIABLE_DECLARATION = 8006,\n\n  /**\n   * The template type-checking engine would need to generate an inline type check block for a\n   * component, but the current type-checking environment doesn't support it.\n   */\n  INLINE_TCB_REQUIRED = 8900,\n\n  /**\n   * The template type-checking engine would need to generate an inline type constructor for a\n   * directive or component, but the current type-checking environment doesn't support it.\n   */\n  INLINE_TYPE_CTOR_REQUIRED = 8901,\n\n  /**\n   * An injectable already has a `ɵprov` property.\n   */\n  INJECTABLE_DUPLICATE_PROV = 9001,\n\n  // 10XXX error codes are reserved for diagnostics with categories other than\n  // `ts.DiagnosticCategory.Error`. These diagnostics are generated by the compiler when configured\n  // to do so by a tool such as the Language Service, or by the Language Service itself.\n\n  /**\n   * Suggest users to enable `strictTemplates` to make use of full capabilities\n   * provided by Angular language service.\n   */\n  SUGGEST_STRICT_TEMPLATES = 10001,\n\n  /**\n   * Indicates that a particular structural directive provides advanced type narrowing\n   * functionality, but the current template type-checking configuration does not allow its usage in\n   * type inference.\n   */\n  SUGGEST_SUBOPTIMAL_TYPE_INFERENCE = 10002,\n}\n\n/**\n * @internal\n * Base URL for the error details page.\n * Keep this value in sync with a similar const in\n * `packages/core/src/render3/error_code.ts`.\n */\nexport const ERROR_DETAILS_PAGE_BASE_URL = 'https://angular.io/errors';\n\n/**\n * @internal\n * Contains a set of error messages that have detailed guides at angular.io.\n * Full list of available error guides can be found at https://angular.io/errors\n */\nexport const COMPILER_ERRORS_WITH_GUIDES = new Set([\n  ErrorCode.DECORATOR_ARG_NOT_LITERAL,\n  ErrorCode.IMPORT_CYCLE_DETECTED,\n  ErrorCode.PARAM_MISSING_TOKEN,\n  ErrorCode.SCHEMA_INVALID_ELEMENT,\n  ErrorCode.SCHEMA_INVALID_ATTRIBUTE,\n  ErrorCode.MISSING_REFERENCE_TARGET,\n]);\n\n/**\n * @internal\n */\nexport function ngErrorCode(code: ErrorCode): number {\n  return parseInt('-99' + code);\n}\n"]}
206
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"error_code.js","sourceRoot":"","sources":["../../../../../../../../../packages/compiler-cli/src/ngtsc/diagnostics/src/error_code.ts"],"names":[],"mappings":"AAAA;;;;;;GAMG;;;;;;;;;;;;;IAEH;;OAEG;IACH,IAAY,SAwLX;IAxLD,WAAY,SAAS;QACnB,sFAAgC,CAAA;QAChC,8EAA4B,CAAA;QAC5B,4EAA2B,CAAA;QAC3B,4FAAmC,CAAA;QACnC,4EAA2B,CAAA;QAE3B;;WAEG;QACH,0EAA0B,CAAA;QAE1B,4EAA2B,CAAA;QAC3B,sEAAwB,CAAA;QAExB,wFAAiC,CAAA;QACjC,sEAAwB,CAAA;QACxB,0EAA0B,CAAA;QAC1B,wFAAiC,CAAA;QAEjC,8FAA8F;QAC9F,4EAA2B,CAAA;QAE3B;;;WAGG;QACH,0GAA0C,CAAA;QAE1C;;;WAGG;QACH,oHAA+C,CAAA;QAE/C;;;WAGG;QACH,4FAAmC,CAAA;QAEnC,0EAA0B,CAAA;QAC1B,4GAA2C,CAAA;QAC3C;;;WAGG;QACH,8EAA4B,CAAA;QAE5B,0FAAkC,CAAA;QAClC,kJAA8D,CAAA;QAE9D;;;WAGG;QACH,oFAA+B,CAAA;QAE/B;;WAEG;QACH,4EAA2B,CAAA;QAE3B;;WAEG;QACH,4FAAmC,CAAA;QAEnC;;WAEG;QACH,kFAA8B,CAAA;QAE9B;;WAEG;QACH,kFAA8B,CAAA;QAE9B;;;WAGG;QACH,sFAAgC,CAAA;QAEhC;;;WAGG;QACH,gIAAqD,CAAA;QAErD;;;WAGG;QACH,oGAAuC,CAAA;QAEvC;;WAEG;QACH,kGAAsC,CAAA;QAEtC;;;WAGG;QACH,sGAAwC,CAAA;QAExC;;WAEG;QACH,gFAA6B,CAAA;QAE7B;;WAEG;QACH,oFAA+B,CAAA;QAE/B;;WAEG;QACH,oFAA+B,CAAA;QAE/B;;WAEG;QACH,4DAAmB,CAAA;QAEnB;;;;;;;;;;;WAWG;QACH,0FAAkC,CAAA;QAElC;;;;;;;WAOG;QACH,gGAAqC,CAAA;QAErC;;;WAGG;QACH,0EAA0B,CAAA;QAE1B;;;WAGG;QACH,sFAAgC,CAAA;QAEhC;;WAEG;QACH,sFAAgC,CAAA;QAEhC,4EAA4E;QAC5E,iGAAiG;QACjG,sFAAsF;QAEtF;;;WAGG;QACH,qFAAgC,CAAA;QAEhC;;;;WAIG;QACH,uGAAyC,CAAA;IAC3C,CAAC,EAxLW,SAAS,GAAT,iBAAS,KAAT,iBAAS,QAwLpB;IAED;;;;;OAKG;IACU,QAAA,2BAA2B,GAAG,2BAA2B,CAAC;IAEvE;;;;OAIG;IACU,QAAA,2BAA2B,GAAG,IAAI,GAAG,CAAC;QACjD,SAAS,CAAC,yBAAyB;QACnC,SAAS,CAAC,qBAAqB;QAC/B,SAAS,CAAC,mBAAmB;QAC7B,SAAS,CAAC,sBAAsB;QAChC,SAAS,CAAC,wBAAwB;QAClC,SAAS,CAAC,wBAAwB;KACnC,CAAC,CAAC;IAEH;;OAEG;IACH,SAAgB,WAAW,CAAC,IAAe;QACzC,OAAO,QAAQ,CAAC,KAAK,GAAG,IAAI,CAAC,CAAC;IAChC,CAAC;IAFD,kCAEC","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\n/**\n * @publicApi\n */\nexport enum ErrorCode {\n  DECORATOR_ARG_NOT_LITERAL = 1001,\n  DECORATOR_ARITY_WRONG = 1002,\n  DECORATOR_NOT_CALLED = 1003,\n  DECORATOR_ON_ANONYMOUS_CLASS = 1004,\n  DECORATOR_UNEXPECTED = 1005,\n\n  /**\n   * This error code indicates that there are incompatible decorators on a type or a class field.\n   */\n  DECORATOR_COLLISION = 1006,\n\n  VALUE_HAS_WRONG_TYPE = 1010,\n  VALUE_NOT_LITERAL = 1011,\n\n  COMPONENT_MISSING_TEMPLATE = 2001,\n  PIPE_MISSING_NAME = 2002,\n  PARAM_MISSING_TOKEN = 2003,\n  DIRECTIVE_MISSING_SELECTOR = 2004,\n\n  /** Raised when an undecorated class is passed in as a provider to a module or a directive. */\n  UNDECORATED_PROVIDER = 2005,\n\n  /**\n   * Raised when a Directive inherits its constructor from a base class without an Angular\n   * decorator.\n   */\n  DIRECTIVE_INHERITS_UNDECORATED_CTOR = 2006,\n\n  /**\n   * Raised when an undecorated class that is using Angular features\n   * has been discovered.\n   */\n  UNDECORATED_CLASS_USING_ANGULAR_FEATURES = 2007,\n\n  /**\n   * Raised when an component cannot resolve an external resource, such as a template or a style\n   * sheet.\n   */\n  COMPONENT_RESOURCE_NOT_FOUND = 2008,\n\n  SYMBOL_NOT_EXPORTED = 3001,\n  SYMBOL_EXPORTED_UNDER_DIFFERENT_NAME = 3002,\n  /**\n   * Raised when a relationship between directives and/or pipes would cause a cyclic import to be\n   * created that cannot be handled, such as in partial compilation mode.\n   */\n  IMPORT_CYCLE_DETECTED = 3003,\n\n  CONFIG_FLAT_MODULE_NO_INDEX = 4001,\n  CONFIG_STRICT_TEMPLATES_IMPLIES_FULL_TEMPLATE_TYPECHECK = 4002,\n\n  /**\n   * Raised when a host expression has a parse error, such as a host listener or host binding\n   * expression containing a pipe.\n   */\n  HOST_BINDING_PARSE_ERROR = 5001,\n\n  /**\n   * Raised when the compiler cannot parse a component's template.\n   */\n  TEMPLATE_PARSE_ERROR = 5002,\n\n  /**\n   * Raised when an NgModule contains an invalid reference in `declarations`.\n   */\n  NGMODULE_INVALID_DECLARATION = 6001,\n\n  /**\n   * Raised when an NgModule contains an invalid type in `imports`.\n   */\n  NGMODULE_INVALID_IMPORT = 6002,\n\n  /**\n   * Raised when an NgModule contains an invalid type in `exports`.\n   */\n  NGMODULE_INVALID_EXPORT = 6003,\n\n  /**\n   * Raised when an NgModule contains a type in `exports` which is neither in `declarations` nor\n   * otherwise imported.\n   */\n  NGMODULE_INVALID_REEXPORT = 6004,\n\n  /**\n   * Raised when a `ModuleWithProviders` with a missing\n   * generic type argument is passed into an `NgModule`.\n   */\n  NGMODULE_MODULE_WITH_PROVIDERS_MISSING_GENERIC = 6005,\n\n  /**\n   * Raised when an NgModule exports multiple directives/pipes of the same name and the compiler\n   * attempts to generate private re-exports within the NgModule file.\n   */\n  NGMODULE_REEXPORT_NAME_COLLISION = 6006,\n\n  /**\n   * Raised when a directive/pipe is part of the declarations of two or more NgModules.\n   */\n  NGMODULE_DECLARATION_NOT_UNIQUE = 6007,\n\n  /**\n   * Not actually raised by the compiler, but reserved for documentation of a View Engine error when\n   * a View Engine build depends on an Ivy-compiled NgModule.\n   */\n  NGMODULE_VE_DEPENDENCY_ON_IVY_LIB = 6999,\n\n  /**\n   * An element name failed validation against the DOM schema.\n   */\n  SCHEMA_INVALID_ELEMENT = 8001,\n\n  /**\n   * An element's attribute name failed validation against the DOM schema.\n   */\n  SCHEMA_INVALID_ATTRIBUTE = 8002,\n\n  /**\n   * No matching directive was found for a `#ref=\"target\"` expression.\n   */\n  MISSING_REFERENCE_TARGET = 8003,\n\n  /**\n   * No matching pipe was found for a\n   */\n  MISSING_PIPE = 8004,\n\n  /**\n   * The left-hand side of an assignment expression was a template variable. Effectively, the\n   * template looked like:\n   *\n   * ```\n   * <ng-template let-something>\n   *   <button (click)=\"something = ...\">...</button>\n   * </ng-template>\n   * ```\n   *\n   * Template variables are read-only.\n   */\n  WRITE_TO_READ_ONLY_VARIABLE = 8005,\n\n  /**\n   * A template variable was declared twice. For example:\n   *\n   * ```html\n   * <div *ngFor=\"let i of items; let i = index\">\n   * </div>\n   * ```\n   */\n  DUPLICATE_VARIABLE_DECLARATION = 8006,\n\n  /**\n   * The template type-checking engine would need to generate an inline type check block for a\n   * component, but the current type-checking environment doesn't support it.\n   */\n  INLINE_TCB_REQUIRED = 8900,\n\n  /**\n   * The template type-checking engine would need to generate an inline type constructor for a\n   * directive or component, but the current type-checking environment doesn't support it.\n   */\n  INLINE_TYPE_CTOR_REQUIRED = 8901,\n\n  /**\n   * An injectable already has a `ɵprov` property.\n   */\n  INJECTABLE_DUPLICATE_PROV = 9001,\n\n  // 10XXX error codes are reserved for diagnostics with categories other than\n  // `ts.DiagnosticCategory.Error`. These diagnostics are generated by the compiler when configured\n  // to do so by a tool such as the Language Service, or by the Language Service itself.\n\n  /**\n   * Suggest users to enable `strictTemplates` to make use of full capabilities\n   * provided by Angular language service.\n   */\n  SUGGEST_STRICT_TEMPLATES = 10001,\n\n  /**\n   * Indicates that a particular structural directive provides advanced type narrowing\n   * functionality, but the current template type-checking configuration does not allow its usage in\n   * type inference.\n   */\n  SUGGEST_SUBOPTIMAL_TYPE_INFERENCE = 10002,\n}\n\n/**\n * @internal\n * Base URL for the error details page.\n * Keep this value in sync with a similar const in\n * `packages/core/src/render3/error_code.ts`.\n */\nexport const ERROR_DETAILS_PAGE_BASE_URL = 'https://angular.io/errors';\n\n/**\n * @internal\n * Contains a set of error messages that have detailed guides at angular.io.\n * Full list of available error guides can be found at https://angular.io/errors\n */\nexport const COMPILER_ERRORS_WITH_GUIDES = new Set([\n  ErrorCode.DECORATOR_ARG_NOT_LITERAL,\n  ErrorCode.IMPORT_CYCLE_DETECTED,\n  ErrorCode.PARAM_MISSING_TOKEN,\n  ErrorCode.SCHEMA_INVALID_ELEMENT,\n  ErrorCode.SCHEMA_INVALID_ATTRIBUTE,\n  ErrorCode.MISSING_REFERENCE_TARGET,\n]);\n\n/**\n * @internal\n */\nexport function ngErrorCode(code: ErrorCode): number {\n  return parseInt('-99' + code);\n}\n"]}
@@ -8,7 +8,7 @@
8
8
  /// <amd-module name="@angular/compiler-cli/src/ngtsc/imports" />
9
9
  export { AliasingHost, AliasStrategy, PrivateExportAliasingHost, UnifiedModulesAliasingHost } from './src/alias';
10
10
  export { ImportRewriter, NoopImportRewriter, R3SymbolsImportRewriter, validateAndRewriteCoreSymbol } from './src/core';
11
- export { DefaultImportRecorder, DefaultImportTracker, NOOP_DEFAULT_IMPORT_RECORDER } from './src/default';
11
+ export { DefaultImportTracker } from './src/default';
12
12
  export { AbsoluteModuleStrategy, EmittedReference, ImportedFile, ImportFlags, LocalIdentifierStrategy, LogicalProjectStrategy, ReferenceEmitStrategy, ReferenceEmitter, RelativePathStrategy, UnifiedModulesStrategy } from './src/emitter';
13
13
  export { Reexport } from './src/reexport';
14
14
  export { OwningModule, Reference } from './src/references';
@@ -16,7 +16,7 @@
16
16
  })(function (require, exports) {
17
17
  "use strict";
18
18
  Object.defineProperty(exports, "__esModule", { value: true });
19
- exports.ModuleResolver = exports.Reference = exports.UnifiedModulesStrategy = exports.RelativePathStrategy = exports.ReferenceEmitter = exports.LogicalProjectStrategy = exports.LocalIdentifierStrategy = exports.ImportFlags = exports.AbsoluteModuleStrategy = exports.NOOP_DEFAULT_IMPORT_RECORDER = exports.DefaultImportTracker = exports.validateAndRewriteCoreSymbol = exports.R3SymbolsImportRewriter = exports.NoopImportRewriter = exports.UnifiedModulesAliasingHost = exports.PrivateExportAliasingHost = exports.AliasStrategy = void 0;
19
+ exports.ModuleResolver = exports.Reference = exports.UnifiedModulesStrategy = exports.RelativePathStrategy = exports.ReferenceEmitter = exports.LogicalProjectStrategy = exports.LocalIdentifierStrategy = exports.ImportFlags = exports.AbsoluteModuleStrategy = exports.DefaultImportTracker = exports.validateAndRewriteCoreSymbol = exports.R3SymbolsImportRewriter = exports.NoopImportRewriter = exports.UnifiedModulesAliasingHost = exports.PrivateExportAliasingHost = exports.AliasStrategy = void 0;
20
20
  var alias_1 = require("@angular/compiler-cli/src/ngtsc/imports/src/alias");
21
21
  Object.defineProperty(exports, "AliasStrategy", { enumerable: true, get: function () { return alias_1.AliasStrategy; } });
22
22
  Object.defineProperty(exports, "PrivateExportAliasingHost", { enumerable: true, get: function () { return alias_1.PrivateExportAliasingHost; } });
@@ -27,7 +27,6 @@
27
27
  Object.defineProperty(exports, "validateAndRewriteCoreSymbol", { enumerable: true, get: function () { return core_1.validateAndRewriteCoreSymbol; } });
28
28
  var default_1 = require("@angular/compiler-cli/src/ngtsc/imports/src/default");
29
29
  Object.defineProperty(exports, "DefaultImportTracker", { enumerable: true, get: function () { return default_1.DefaultImportTracker; } });
30
- Object.defineProperty(exports, "NOOP_DEFAULT_IMPORT_RECORDER", { enumerable: true, get: function () { return default_1.NOOP_DEFAULT_IMPORT_RECORDER; } });
31
30
  var emitter_1 = require("@angular/compiler-cli/src/ngtsc/imports/src/emitter");
32
31
  Object.defineProperty(exports, "AbsoluteModuleStrategy", { enumerable: true, get: function () { return emitter_1.AbsoluteModuleStrategy; } });
33
32
  Object.defineProperty(exports, "ImportFlags", { enumerable: true, get: function () { return emitter_1.ImportFlags; } });
@@ -41,4 +40,4 @@
41
40
  var resolver_1 = require("@angular/compiler-cli/src/ngtsc/imports/src/resolver");
42
41
  Object.defineProperty(exports, "ModuleResolver", { enumerable: true, get: function () { return resolver_1.ModuleResolver; } });
43
42
  });
44
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaW5kZXguanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi8uLi8uLi8uLi9wYWNrYWdlcy9jb21waWxlci1jbGkvc3JjL25ndHNjL2ltcG9ydHMvaW5kZXgudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUE7Ozs7OztHQU1HOzs7Ozs7Ozs7Ozs7O0lBRUgsMkVBQStHO0lBQXpGLHNHQUFBLGFBQWEsT0FBQTtJQUFFLGtIQUFBLHlCQUF5QixPQUFBO0lBQUUsbUhBQUEsMEJBQTBCLE9BQUE7SUFDMUYseUVBQXFIO0lBQTdGLDBHQUFBLGtCQUFrQixPQUFBO0lBQUUsK0dBQUEsdUJBQXVCLE9BQUE7SUFBRSxvSEFBQSw0QkFBNEIsT0FBQTtJQUNqRywrRUFBd0c7SUFBekUsK0dBQUEsb0JBQW9CLE9BQUE7SUFBRSx1SEFBQSw0QkFBNEIsT0FBQTtJQUNqRiwrRUFBME87SUFBbE8saUhBQUEsc0JBQXNCLE9BQUE7SUFBa0Msc0dBQUEsV0FBVyxPQUFBO0lBQUUsa0hBQUEsdUJBQXVCLE9BQUE7SUFBRSxpSEFBQSxzQkFBc0IsT0FBQTtJQUF5QiwyR0FBQSxnQkFBZ0IsT0FBQTtJQUFFLCtHQUFBLG9CQUFvQixPQUFBO0lBQUUsaUhBQUEsc0JBQXNCLE9BQUE7SUFFbk4scUZBQXlEO0lBQW5DLHVHQUFBLFNBQVMsT0FBQTtJQUMvQixpRkFBOEM7SUFBdEMsMEdBQUEsY0FBYyxPQUFBIiwic291cmNlc0NvbnRlbnQiOlsiLyoqXG4gKiBAbGljZW5zZVxuICogQ29weXJpZ2h0IEdvb2dsZSBMTEMgQWxsIFJpZ2h0cyBSZXNlcnZlZC5cbiAqXG4gKiBVc2Ugb2YgdGhpcyBzb3VyY2UgY29kZSBpcyBnb3Zlcm5lZCBieSBhbiBNSVQtc3R5bGUgbGljZW5zZSB0aGF0IGNhbiBiZVxuICogZm91bmQgaW4gdGhlIExJQ0VOU0UgZmlsZSBhdCBodHRwczovL2FuZ3VsYXIuaW8vbGljZW5zZVxuICovXG5cbmV4cG9ydCB7QWxpYXNpbmdIb3N0LCBBbGlhc1N0cmF0ZWd5LCBQcml2YXRlRXhwb3J0QWxpYXNpbmdIb3N0LCBVbmlmaWVkTW9kdWxlc0FsaWFzaW5nSG9zdH0gZnJvbSAnLi9zcmMvYWxpYXMnO1xuZXhwb3J0IHtJbXBvcnRSZXdyaXRlciwgTm9vcEltcG9ydFJld3JpdGVyLCBSM1N5bWJvbHNJbXBvcnRSZXdyaXRlciwgdmFsaWRhdGVBbmRSZXdyaXRlQ29yZVN5bWJvbH0gZnJvbSAnLi9zcmMvY29yZSc7XG5leHBvcnQge0RlZmF1bHRJbXBvcnRSZWNvcmRlciwgRGVmYXVsdEltcG9ydFRyYWNrZXIsIE5PT1BfREVGQVVMVF9JTVBPUlRfUkVDT1JERVJ9IGZyb20gJy4vc3JjL2RlZmF1bHQnO1xuZXhwb3J0IHtBYnNvbHV0ZU1vZHVsZVN0cmF0ZWd5LCBFbWl0dGVkUmVmZXJlbmNlLCBJbXBvcnRlZEZpbGUsIEltcG9ydEZsYWdzLCBMb2NhbElkZW50aWZpZXJTdHJhdGVneSwgTG9naWNhbFByb2plY3RTdHJhdGVneSwgUmVmZXJlbmNlRW1pdFN0cmF0ZWd5LCBSZWZlcmVuY2VFbWl0dGVyLCBSZWxhdGl2ZVBhdGhTdHJhdGVneSwgVW5pZmllZE1vZHVsZXNTdHJhdGVneX0gZnJvbSAnLi9zcmMvZW1pdHRlcic7XG5leHBvcnQge1JlZXhwb3J0fSBmcm9tICcuL3NyYy9yZWV4cG9ydCc7XG5leHBvcnQge093bmluZ01vZHVsZSwgUmVmZXJlbmNlfSBmcm9tICcuL3NyYy9yZWZlcmVuY2VzJztcbmV4cG9ydCB7TW9kdWxlUmVzb2x2ZXJ9IGZyb20gJy4vc3JjL3Jlc29sdmVyJztcbiJdfQ==
43
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaW5kZXguanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi8uLi8uLi8uLi9wYWNrYWdlcy9jb21waWxlci1jbGkvc3JjL25ndHNjL2ltcG9ydHMvaW5kZXgudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUE7Ozs7OztHQU1HOzs7Ozs7Ozs7Ozs7O0lBRUgsMkVBQStHO0lBQXpGLHNHQUFBLGFBQWEsT0FBQTtJQUFFLGtIQUFBLHlCQUF5QixPQUFBO0lBQUUsbUhBQUEsMEJBQTBCLE9BQUE7SUFDMUYseUVBQXFIO0lBQTdGLDBHQUFBLGtCQUFrQixPQUFBO0lBQUUsK0dBQUEsdUJBQXVCLE9BQUE7SUFBRSxvSEFBQSw0QkFBNEIsT0FBQTtJQUNqRywrRUFBbUQ7SUFBM0MsK0dBQUEsb0JBQW9CLE9BQUE7SUFDNUIsK0VBQTBPO0lBQWxPLGlIQUFBLHNCQUFzQixPQUFBO0lBQWtDLHNHQUFBLFdBQVcsT0FBQTtJQUFFLGtIQUFBLHVCQUF1QixPQUFBO0lBQUUsaUhBQUEsc0JBQXNCLE9BQUE7SUFBeUIsMkdBQUEsZ0JBQWdCLE9BQUE7SUFBRSwrR0FBQSxvQkFBb0IsT0FBQTtJQUFFLGlIQUFBLHNCQUFzQixPQUFBO0lBRW5OLHFGQUF5RDtJQUFuQyx1R0FBQSxTQUFTLE9BQUE7SUFDL0IsaUZBQThDO0lBQXRDLDBHQUFBLGNBQWMsT0FBQSIsInNvdXJjZXNDb250ZW50IjpbIi8qKlxuICogQGxpY2Vuc2VcbiAqIENvcHlyaWdodCBHb29nbGUgTExDIEFsbCBSaWdodHMgUmVzZXJ2ZWQuXG4gKlxuICogVXNlIG9mIHRoaXMgc291cmNlIGNvZGUgaXMgZ292ZXJuZWQgYnkgYW4gTUlULXN0eWxlIGxpY2Vuc2UgdGhhdCBjYW4gYmVcbiAqIGZvdW5kIGluIHRoZSBMSUNFTlNFIGZpbGUgYXQgaHR0cHM6Ly9hbmd1bGFyLmlvL2xpY2Vuc2VcbiAqL1xuXG5leHBvcnQge0FsaWFzaW5nSG9zdCwgQWxpYXNTdHJhdGVneSwgUHJpdmF0ZUV4cG9ydEFsaWFzaW5nSG9zdCwgVW5pZmllZE1vZHVsZXNBbGlhc2luZ0hvc3R9IGZyb20gJy4vc3JjL2FsaWFzJztcbmV4cG9ydCB7SW1wb3J0UmV3cml0ZXIsIE5vb3BJbXBvcnRSZXdyaXRlciwgUjNTeW1ib2xzSW1wb3J0UmV3cml0ZXIsIHZhbGlkYXRlQW5kUmV3cml0ZUNvcmVTeW1ib2x9IGZyb20gJy4vc3JjL2NvcmUnO1xuZXhwb3J0IHtEZWZhdWx0SW1wb3J0VHJhY2tlcn0gZnJvbSAnLi9zcmMvZGVmYXVsdCc7XG5leHBvcnQge0Fic29sdXRlTW9kdWxlU3RyYXRlZ3ksIEVtaXR0ZWRSZWZlcmVuY2UsIEltcG9ydGVkRmlsZSwgSW1wb3J0RmxhZ3MsIExvY2FsSWRlbnRpZmllclN0cmF0ZWd5LCBMb2dpY2FsUHJvamVjdFN0cmF0ZWd5LCBSZWZlcmVuY2VFbWl0U3RyYXRlZ3ksIFJlZmVyZW5jZUVtaXR0ZXIsIFJlbGF0aXZlUGF0aFN0cmF0ZWd5LCBVbmlmaWVkTW9kdWxlc1N0cmF0ZWd5fSBmcm9tICcuL3NyYy9lbWl0dGVyJztcbmV4cG9ydCB7UmVleHBvcnR9IGZyb20gJy4vc3JjL3JlZXhwb3J0JztcbmV4cG9ydCB7T3duaW5nTW9kdWxlLCBSZWZlcmVuY2V9IGZyb20gJy4vc3JjL3JlZmVyZW5jZXMnO1xuZXhwb3J0IHtNb2R1bGVSZXNvbHZlcn0gZnJvbSAnLi9zcmMvcmVzb2x2ZXInO1xuIl19
@@ -6,39 +6,18 @@
6
6
  * found in the LICENSE file at https://angular.io/license
7
7
  */
8
8
  /// <amd-module name="@angular/compiler-cli/src/ngtsc/imports/src/default" />
9
+ import { WrappedNodeExpr } from '@angular/compiler';
9
10
  import * as ts from 'typescript';
10
11
  /**
11
- * Registers and records usages of `ts.Identifer`s that came from default import statements.
12
- *
13
- * See `DefaultImportTracker` for details.
12
+ * Attaches a default import declaration to `expr` to indicate the dependency of `expr` on the
13
+ * default import.
14
14
  */
15
- export interface DefaultImportRecorder {
16
- /**
17
- * Record an association between a `ts.Identifier` which might be emitted and the
18
- * `ts.ImportDeclaration` from which it came.
19
- *
20
- * Alone, this method has no effect as the `ts.Identifier` might not be used in the output.
21
- * The identifier must later be marked as used with `recordUsedIdentifier` in order for its
22
- * import to be preserved.
23
- */
24
- recordImportedIdentifier(id: ts.Identifier, decl: ts.ImportDeclaration): void;
25
- /**
26
- * Record the fact that the given `ts.Identifer` will be emitted, and thus its
27
- * `ts.ImportDeclaration`, if it was a previously registered default import, must be preserved.
28
- *
29
- * This method can be called safely for any `ts.Identifer`, regardless of its origin. It will only
30
- * have an effect if the identifier came from a `ts.ImportDeclaration` default import which was
31
- * previously registered with `recordImportedIdentifier`.
32
- */
33
- recordUsedIdentifier(id: ts.Identifier): void;
34
- }
15
+ export declare function attachDefaultImportDeclaration(expr: WrappedNodeExpr<unknown>, importDecl: ts.ImportDeclaration): void;
35
16
  /**
36
- * An implementation of `DefaultImportRecorder` which does nothing.
37
- *
38
- * This is useful when default import tracking isn't required, such as when emitting .d.ts code
39
- * or for ngcc.
17
+ * Obtains the default import declaration that `expr` depends on, or `null` if there is no such
18
+ * dependency.
40
19
  */
41
- export declare const NOOP_DEFAULT_IMPORT_RECORDER: DefaultImportRecorder;
20
+ export declare function getDefaultImportDeclaration(expr: WrappedNodeExpr<unknown>): ts.ImportDeclaration | null;
42
21
  /**
43
22
  * TypeScript has trouble with generating default imports inside of transformers for some module
44
23
  * formats. The issue is that for the statement:
@@ -69,24 +48,18 @@ export declare const NOOP_DEFAULT_IMPORT_RECORDER: DefaultImportRecorder;
69
48
  * This problem does not exist for non-default imports as the compiler can easily insert
70
49
  * "import * as X" style imports for those, and the "X" identifier survives transformation.
71
50
  */
72
- export declare class DefaultImportTracker implements DefaultImportRecorder {
73
- /**
74
- * A `Map` which tracks the `Map` of default import `ts.Identifier`s to their
75
- * `ts.ImportDeclaration`s. These declarations are not guaranteed to be used.
76
- */
77
- private sourceFileToImportMap;
51
+ export declare class DefaultImportTracker {
78
52
  /**
79
53
  * A `Map` which tracks the `Set` of `ts.ImportDeclaration`s for default imports that were used in
80
54
  * a given `ts.SourceFile` and need to be preserved.
81
55
  */
82
56
  private sourceFileToUsedImports;
83
- recordImportedIdentifier(id: ts.Identifier, decl: ts.ImportDeclaration): void;
84
- recordUsedIdentifier(id: ts.Identifier): void;
57
+ recordUsedImport(importDecl: ts.ImportDeclaration): void;
85
58
  /**
86
59
  * Get a `ts.TransformerFactory` which will preserve default imports that were previously marked
87
60
  * as used.
88
61
  *
89
- * This transformer must run after any other transformers which call `recordUsedIdentifier`.
62
+ * This transformer must run after any other transformers which call `recordUsedImport`.
90
63
  */
91
64
  importPreservingTransformer(): ts.TransformerFactory<ts.SourceFile>;
92
65
  /**
@@ -16,19 +16,27 @@
16
16
  })(function (require, exports) {
17
17
  "use strict";
18
18
  Object.defineProperty(exports, "__esModule", { value: true });
19
- exports.DefaultImportTracker = exports.NOOP_DEFAULT_IMPORT_RECORDER = void 0;
19
+ exports.DefaultImportTracker = exports.getDefaultImportDeclaration = exports.attachDefaultImportDeclaration = void 0;
20
20
  var ts = require("typescript");
21
21
  var typescript_1 = require("@angular/compiler-cli/src/ngtsc/util/src/typescript");
22
+ var DefaultImportDeclaration = Symbol('DefaultImportDeclaration');
22
23
  /**
23
- * An implementation of `DefaultImportRecorder` which does nothing.
24
- *
25
- * This is useful when default import tracking isn't required, such as when emitting .d.ts code
26
- * or for ngcc.
24
+ * Attaches a default import declaration to `expr` to indicate the dependency of `expr` on the
25
+ * default import.
26
+ */
27
+ function attachDefaultImportDeclaration(expr, importDecl) {
28
+ expr[DefaultImportDeclaration] = importDecl;
29
+ }
30
+ exports.attachDefaultImportDeclaration = attachDefaultImportDeclaration;
31
+ /**
32
+ * Obtains the default import declaration that `expr` depends on, or `null` if there is no such
33
+ * dependency.
27
34
  */
28
- exports.NOOP_DEFAULT_IMPORT_RECORDER = {
29
- recordImportedIdentifier: function (id) { return void {}; },
30
- recordUsedIdentifier: function (id) { return void {}; },
31
- };
35
+ function getDefaultImportDeclaration(expr) {
36
+ var _a;
37
+ return (_a = expr[DefaultImportDeclaration]) !== null && _a !== void 0 ? _a : null;
38
+ }
39
+ exports.getDefaultImportDeclaration = getDefaultImportDeclaration;
32
40
  /**
33
41
  * TypeScript has trouble with generating default imports inside of transformers for some module
34
42
  * formats. The issue is that for the statement:
@@ -61,47 +69,25 @@
61
69
  */
62
70
  var DefaultImportTracker = /** @class */ (function () {
63
71
  function DefaultImportTracker() {
64
- /**
65
- * A `Map` which tracks the `Map` of default import `ts.Identifier`s to their
66
- * `ts.ImportDeclaration`s. These declarations are not guaranteed to be used.
67
- */
68
- this.sourceFileToImportMap = new Map();
69
72
  /**
70
73
  * A `Map` which tracks the `Set` of `ts.ImportDeclaration`s for default imports that were used in
71
74
  * a given `ts.SourceFile` and need to be preserved.
72
75
  */
73
76
  this.sourceFileToUsedImports = new Map();
74
77
  }
75
- DefaultImportTracker.prototype.recordImportedIdentifier = function (id, decl) {
76
- var sf = typescript_1.getSourceFile(id);
77
- if (!this.sourceFileToImportMap.has(sf)) {
78
- this.sourceFileToImportMap.set(sf, new Map());
79
- }
80
- this.sourceFileToImportMap.get(sf).set(id, decl);
81
- };
82
- DefaultImportTracker.prototype.recordUsedIdentifier = function (id) {
83
- var sf = typescript_1.getSourceFile(id);
84
- if (!this.sourceFileToImportMap.has(sf)) {
85
- // The identifier's source file has no registered default imports at all.
86
- return;
87
- }
88
- var identiferToDeclaration = this.sourceFileToImportMap.get(sf);
89
- if (!identiferToDeclaration.has(id)) {
90
- // The identifier isn't from a registered default import.
91
- return;
92
- }
93
- var decl = identiferToDeclaration.get(id);
78
+ DefaultImportTracker.prototype.recordUsedImport = function (importDecl) {
79
+ var sf = typescript_1.getSourceFile(importDecl);
94
80
  // Add the default import declaration to the set of used import declarations for the file.
95
81
  if (!this.sourceFileToUsedImports.has(sf)) {
96
82
  this.sourceFileToUsedImports.set(sf, new Set());
97
83
  }
98
- this.sourceFileToUsedImports.get(sf).add(decl);
84
+ this.sourceFileToUsedImports.get(sf).add(importDecl);
99
85
  };
100
86
  /**
101
87
  * Get a `ts.TransformerFactory` which will preserve default imports that were previously marked
102
88
  * as used.
103
89
  *
104
- * This transformer must run after any other transformers which call `recordUsedIdentifier`.
90
+ * This transformer must run after any other transformers which call `recordUsedImport`.
105
91
  */
106
92
  DefaultImportTracker.prototype.importPreservingTransformer = function () {
107
93
  var _this = this;
@@ -157,7 +143,6 @@
157
143
  });
158
144
  // Save memory - there's no need to keep these around once the transform has run for the given
159
145
  // file.
160
- this.sourceFileToImportMap.delete(originalSf);
161
146
  this.sourceFileToUsedImports.delete(originalSf);
162
147
  return ts.updateSourceFileNode(sf, statements);
163
148
  };
@@ -165,4 +150,4 @@
165
150
  }());
166
151
  exports.DefaultImportTracker = DefaultImportTracker;
167
152
  });
168
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"default.js","sourceRoot":"","sources":["../../../../../../../../../packages/compiler-cli/src/ngtsc/imports/src/default.ts"],"names":[],"mappings":"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","sourcesContent":["/**\n * @license\n * Copyright Google LLC All Rights Reserved.\n *\n * Use of this source code is governed by an MIT-style license that can be\n * found in the LICENSE file at https://angular.io/license\n */\n\nimport * as ts from 'typescript';\n\nimport {getSourceFile} from '../../util/src/typescript';\n\n/**\n * Registers and records usages of `ts.Identifer`s that came from default import statements.\n *\n * See `DefaultImportTracker` for details.\n */\nexport interface DefaultImportRecorder {\n  /**\n   * Record an association between a `ts.Identifier` which might be emitted and the\n   * `ts.ImportDeclaration` from which it came.\n   *\n   * Alone, this method has no effect as the `ts.Identifier` might not be used in the output.\n   * The identifier must later be marked as used with `recordUsedIdentifier` in order for its\n   * import to be preserved.\n   */\n  recordImportedIdentifier(id: ts.Identifier, decl: ts.ImportDeclaration): void;\n\n  /**\n   * Record the fact that the given `ts.Identifer` will be emitted, and thus its\n   * `ts.ImportDeclaration`, if it was a previously registered default import, must be preserved.\n   *\n   * This method can be called safely for any `ts.Identifer`, regardless of its origin. It will only\n   * have an effect if the identifier came from a `ts.ImportDeclaration` default import which was\n   * previously registered with `recordImportedIdentifier`.\n   */\n  recordUsedIdentifier(id: ts.Identifier): void;\n}\n\n/**\n * An implementation of `DefaultImportRecorder` which does nothing.\n *\n * This is useful when default import tracking isn't required, such as when emitting .d.ts code\n * or for ngcc.\n */\nexport const NOOP_DEFAULT_IMPORT_RECORDER: DefaultImportRecorder = {\n  recordImportedIdentifier: (id: ts.Identifier) => void{},\n  recordUsedIdentifier: (id: ts.Identifier) => void{},\n};\n\n/**\n * TypeScript has trouble with generating default imports inside of transformers for some module\n * formats. The issue is that for the statement:\n *\n * import X from 'some/module';\n * console.log(X);\n *\n * TypeScript will not use the \"X\" name in generated code. For normal user code, this is fine\n * because references to X will also be renamed. However, if both the import and any references are\n * added in a transformer, TypeScript does not associate the two, and will leave the \"X\" references\n * dangling while renaming the import variable. The generated code looks something like:\n *\n * const module_1 = require('some/module');\n * console.log(X); // now X is a dangling reference.\n *\n * Therefore, we cannot synthetically add default imports, and must reuse the imports that users\n * include. Doing this poses a challenge for imports that are only consumed in the type position in\n * the user's code. If Angular reuses the imported symbol in a value position (for example, we\n * see a constructor parameter of type Foo and try to write \"inject(Foo)\") we will also end up with\n * a dangling reference, as TS will elide the import because it was only used in the type position\n * originally.\n *\n * To avoid this, the compiler must \"touch\" the imports with `ts.getMutableClone`, and should\n * only do this for imports which are actually consumed. The `DefaultImportTracker` keeps track of\n * these imports as they're encountered and emitted, and implements a transform which can correctly\n * flag the imports as required.\n *\n * This problem does not exist for non-default imports as the compiler can easily insert\n * \"import * as X\" style imports for those, and the \"X\" identifier survives transformation.\n */\nexport class DefaultImportTracker implements DefaultImportRecorder {\n  /**\n   * A `Map` which tracks the `Map` of default import `ts.Identifier`s to their\n   * `ts.ImportDeclaration`s. These declarations are not guaranteed to be used.\n   */\n  private sourceFileToImportMap =\n      new Map<ts.SourceFile, Map<ts.Identifier, ts.ImportDeclaration>>();\n\n  /**\n   * A `Map` which tracks the `Set` of `ts.ImportDeclaration`s for default imports that were used in\n   * a given `ts.SourceFile` and need to be preserved.\n   */\n  private sourceFileToUsedImports = new Map<ts.SourceFile, Set<ts.ImportDeclaration>>();\n  recordImportedIdentifier(id: ts.Identifier, decl: ts.ImportDeclaration): void {\n    const sf = getSourceFile(id);\n    if (!this.sourceFileToImportMap.has(sf)) {\n      this.sourceFileToImportMap.set(sf, new Map<ts.Identifier, ts.ImportDeclaration>());\n    }\n    this.sourceFileToImportMap.get(sf)!.set(id, decl);\n  }\n\n  recordUsedIdentifier(id: ts.Identifier): void {\n    const sf = getSourceFile(id);\n    if (!this.sourceFileToImportMap.has(sf)) {\n      // The identifier's source file has no registered default imports at all.\n      return;\n    }\n    const identiferToDeclaration = this.sourceFileToImportMap.get(sf)!;\n    if (!identiferToDeclaration.has(id)) {\n      // The identifier isn't from a registered default import.\n      return;\n    }\n    const decl = identiferToDeclaration.get(id)!;\n\n    // Add the default import declaration to the set of used import declarations for the file.\n    if (!this.sourceFileToUsedImports.has(sf)) {\n      this.sourceFileToUsedImports.set(sf, new Set<ts.ImportDeclaration>());\n    }\n    this.sourceFileToUsedImports.get(sf)!.add(decl);\n  }\n\n  /**\n   * Get a `ts.TransformerFactory` which will preserve default imports that were previously marked\n   * as used.\n   *\n   * This transformer must run after any other transformers which call `recordUsedIdentifier`.\n   */\n  importPreservingTransformer(): ts.TransformerFactory<ts.SourceFile> {\n    return (context: ts.TransformationContext) => {\n      return (sf: ts.SourceFile) => {\n        return this.transformSourceFile(sf);\n      };\n    };\n  }\n\n  /**\n   * Process a `ts.SourceFile` and replace any `ts.ImportDeclaration`s.\n   */\n  private transformSourceFile(sf: ts.SourceFile): ts.SourceFile {\n    const originalSf = ts.getOriginalNode(sf) as ts.SourceFile;\n    // Take a fast path if no import declarations need to be preserved in the file.\n    if (!this.sourceFileToUsedImports.has(originalSf)) {\n      return sf;\n    }\n\n    // There are declarations that need to be preserved.\n    const importsToPreserve = this.sourceFileToUsedImports.get(originalSf)!;\n\n    // Generate a new statement list which preserves any imports present in `importsToPreserve`.\n    const statements = sf.statements.map(stmt => {\n      if (ts.isImportDeclaration(stmt) && importsToPreserve.has(stmt)) {\n        // Preserving an import that's marked as unreferenced (type-only) is tricky in TypeScript.\n        //\n        // Various approaches have been tried, with mixed success:\n        //\n        // 1. Using `ts.updateImportDeclaration` does not cause the import to be retained.\n        //\n        // 2. Using `ts.createImportDeclaration` with the same `ts.ImportClause` causes the import\n        //    to correctly be retained, but when emitting CommonJS module format code, references\n        //    to the imported value will not match the import variable.\n        //\n        // 3. Emitting \"import * as\" imports instead generates the correct import variable, but\n        //    references are missing the \".default\" access. This happens to work for tsickle code\n        //    with goog.module transformations as tsickle strips the \".default\" anyway.\n        //\n        // 4. It's possible to trick TypeScript by setting `ts.NodeFlag.Synthesized` on the import\n        //    declaration. This causes the import to be correctly retained and generated, but can\n        //    violate invariants elsewhere in the compiler and cause crashes.\n        //\n        // 5. Using `ts.getMutableClone` seems to correctly preserve the import and correctly\n        //    generate references to the import variable across all module types.\n        //\n        // Therefore, option 5 is the one used here. It seems to be implemented as the correct way\n        // to perform option 4, which preserves all the compiler's invariants.\n        //\n        // TODO(alxhub): discuss with the TypeScript team and determine if there's a better way to\n        // deal with this issue.\n        stmt = ts.getMutableClone(stmt);\n      }\n      return stmt;\n    });\n\n    // Save memory - there's no need to keep these around once the transform has run for the given\n    // file.\n    this.sourceFileToImportMap.delete(originalSf);\n    this.sourceFileToUsedImports.delete(originalSf);\n\n    return ts.updateSourceFileNode(sf, statements);\n  }\n}\n"]}
153
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"default.js","sourceRoot":"","sources":["../../../../../../../../../packages/compiler-cli/src/ngtsc/imports/src/default.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 {WrappedNodeExpr} from '@angular/compiler';\nimport * as ts from 'typescript';\n\nimport {getSourceFile} from '../../util/src/typescript';\n\nconst DefaultImportDeclaration = Symbol('DefaultImportDeclaration');\n\ninterface WithDefaultImportDeclaration {\n  [DefaultImportDeclaration]?: ts.ImportDeclaration;\n}\n\n/**\n * Attaches a default import declaration to `expr` to indicate the dependency of `expr` on the\n * default import.\n */\nexport function attachDefaultImportDeclaration(\n    expr: WrappedNodeExpr<unknown>, importDecl: ts.ImportDeclaration): void {\n  (expr as WithDefaultImportDeclaration)[DefaultImportDeclaration] = importDecl;\n}\n\n/**\n * Obtains the default import declaration that `expr` depends on, or `null` if there is no such\n * dependency.\n */\nexport function getDefaultImportDeclaration(expr: WrappedNodeExpr<unknown>): ts.ImportDeclaration|\n    null {\n  return (expr as WithDefaultImportDeclaration)[DefaultImportDeclaration] ?? null;\n}\n\n/**\n * TypeScript has trouble with generating default imports inside of transformers for some module\n * formats. The issue is that for the statement:\n *\n * import X from 'some/module';\n * console.log(X);\n *\n * TypeScript will not use the \"X\" name in generated code. For normal user code, this is fine\n * because references to X will also be renamed. However, if both the import and any references are\n * added in a transformer, TypeScript does not associate the two, and will leave the \"X\" references\n * dangling while renaming the import variable. The generated code looks something like:\n *\n * const module_1 = require('some/module');\n * console.log(X); // now X is a dangling reference.\n *\n * Therefore, we cannot synthetically add default imports, and must reuse the imports that users\n * include. Doing this poses a challenge for imports that are only consumed in the type position in\n * the user's code. If Angular reuses the imported symbol in a value position (for example, we\n * see a constructor parameter of type Foo and try to write \"inject(Foo)\") we will also end up with\n * a dangling reference, as TS will elide the import because it was only used in the type position\n * originally.\n *\n * To avoid this, the compiler must \"touch\" the imports with `ts.getMutableClone`, and should\n * only do this for imports which are actually consumed. The `DefaultImportTracker` keeps track of\n * these imports as they're encountered and emitted, and implements a transform which can correctly\n * flag the imports as required.\n *\n * This problem does not exist for non-default imports as the compiler can easily insert\n * \"import * as X\" style imports for those, and the \"X\" identifier survives transformation.\n */\nexport class DefaultImportTracker {\n  /**\n   * A `Map` which tracks the `Set` of `ts.ImportDeclaration`s for default imports that were used in\n   * a given `ts.SourceFile` and need to be preserved.\n   */\n  private sourceFileToUsedImports = new Map<ts.SourceFile, Set<ts.ImportDeclaration>>();\n\n  recordUsedImport(importDecl: ts.ImportDeclaration): void {\n    const sf = getSourceFile(importDecl);\n\n    // Add the default import declaration to the set of used import declarations for the file.\n    if (!this.sourceFileToUsedImports.has(sf)) {\n      this.sourceFileToUsedImports.set(sf, new Set<ts.ImportDeclaration>());\n    }\n    this.sourceFileToUsedImports.get(sf)!.add(importDecl);\n  }\n\n  /**\n   * Get a `ts.TransformerFactory` which will preserve default imports that were previously marked\n   * as used.\n   *\n   * This transformer must run after any other transformers which call `recordUsedImport`.\n   */\n  importPreservingTransformer(): ts.TransformerFactory<ts.SourceFile> {\n    return (context: ts.TransformationContext) => {\n      return (sf: ts.SourceFile) => {\n        return this.transformSourceFile(sf);\n      };\n    };\n  }\n\n  /**\n   * Process a `ts.SourceFile` and replace any `ts.ImportDeclaration`s.\n   */\n  private transformSourceFile(sf: ts.SourceFile): ts.SourceFile {\n    const originalSf = ts.getOriginalNode(sf) as ts.SourceFile;\n    // Take a fast path if no import declarations need to be preserved in the file.\n    if (!this.sourceFileToUsedImports.has(originalSf)) {\n      return sf;\n    }\n\n    // There are declarations that need to be preserved.\n    const importsToPreserve = this.sourceFileToUsedImports.get(originalSf)!;\n\n    // Generate a new statement list which preserves any imports present in `importsToPreserve`.\n    const statements = sf.statements.map(stmt => {\n      if (ts.isImportDeclaration(stmt) && importsToPreserve.has(stmt)) {\n        // Preserving an import that's marked as unreferenced (type-only) is tricky in TypeScript.\n        //\n        // Various approaches have been tried, with mixed success:\n        //\n        // 1. Using `ts.updateImportDeclaration` does not cause the import to be retained.\n        //\n        // 2. Using `ts.createImportDeclaration` with the same `ts.ImportClause` causes the import\n        //    to correctly be retained, but when emitting CommonJS module format code, references\n        //    to the imported value will not match the import variable.\n        //\n        // 3. Emitting \"import * as\" imports instead generates the correct import variable, but\n        //    references are missing the \".default\" access. This happens to work for tsickle code\n        //    with goog.module transformations as tsickle strips the \".default\" anyway.\n        //\n        // 4. It's possible to trick TypeScript by setting `ts.NodeFlag.Synthesized` on the import\n        //    declaration. This causes the import to be correctly retained and generated, but can\n        //    violate invariants elsewhere in the compiler and cause crashes.\n        //\n        // 5. Using `ts.getMutableClone` seems to correctly preserve the import and correctly\n        //    generate references to the import variable across all module types.\n        //\n        // Therefore, option 5 is the one used here. It seems to be implemented as the correct way\n        // to perform option 4, which preserves all the compiler's invariants.\n        //\n        // TODO(alxhub): discuss with the TypeScript team and determine if there's a better way to\n        // deal with this issue.\n        stmt = ts.getMutableClone(stmt);\n      }\n      return stmt;\n    });\n\n    // Save memory - there's no need to keep these around once the transform has run for the given\n    // file.\n    this.sourceFileToUsedImports.delete(originalSf);\n\n    return ts.updateSourceFileNode(sf, statements);\n  }\n}\n"]}
@@ -11,7 +11,7 @@
11
11
  if (v !== undefined) module.exports = v;
12
12
  }
13
13
  else if (typeof define === "function" && define.amd) {
14
- define("@angular/compiler-cli/src/ngtsc/incremental/src/state", ["require", "exports", "tslib", "@angular/compiler-cli/src/ngtsc/file_system", "@angular/compiler-cli/src/ngtsc/perf", "@angular/compiler-cli/src/ngtsc/incremental/semantic_graph", "@angular/compiler-cli/src/ngtsc/incremental/src/dependency_tracking"], factory);
14
+ define("@angular/compiler-cli/src/ngtsc/incremental/src/state", ["require", "exports", "tslib", "@angular/compiler-cli/src/ngtsc/file_system", "@angular/compiler-cli/src/ngtsc/perf", "@angular/compiler-cli/src/ngtsc/util/src/typescript", "@angular/compiler-cli/src/ngtsc/incremental/semantic_graph", "@angular/compiler-cli/src/ngtsc/incremental/src/dependency_tracking"], factory);
15
15
  }
16
16
  })(function (require, exports) {
17
17
  "use strict";
@@ -20,6 +20,7 @@
20
20
  var tslib_1 = require("tslib");
21
21
  var file_system_1 = require("@angular/compiler-cli/src/ngtsc/file_system");
22
22
  var perf_1 = require("@angular/compiler-cli/src/ngtsc/perf");
23
+ var typescript_1 = require("@angular/compiler-cli/src/ngtsc/util/src/typescript");
23
24
  var semantic_graph_1 = require("@angular/compiler-cli/src/ngtsc/incremental/semantic_graph");
24
25
  var dependency_tracking_1 = require("@angular/compiler-cli/src/ngtsc/incremental/src/dependency_tracking");
25
26
  /**
@@ -87,12 +88,13 @@
87
88
  // since the previous compilation). These need to be removed from the state tracking to
88
89
  // avoid leaking memory.
89
90
  // All files in the old program, for easy detection of changes.
90
- var oldFiles = new Set(oldProgram.getSourceFiles());
91
+ var oldFiles = new Set(oldProgram.getSourceFiles().map(typescript_1.toUnredirectedSourceFile));
91
92
  // Assume all the old files were deleted to begin with. Only TS files are tracked.
92
93
  var deletedTsPaths = new Set(tsOnlyFiles(oldProgram).map(function (sf) { return sf.fileName; }));
93
94
  try {
94
95
  for (var _f = tslib_1.__values(newProgram.getSourceFiles()), _g = _f.next(); !_g.done; _g = _f.next()) {
95
- var newFile = _g.value;
96
+ var possiblyRedirectedNewFile = _g.value;
97
+ var newFile = typescript_1.toUnredirectedSourceFile(possiblyRedirectedNewFile);
96
98
  if (!newFile.isDeclarationFile) {
97
99
  // This file exists in the new program, so remove it from `deletedTsPaths`.
98
100
  deletedTsPaths.delete(newFile.fileName);
@@ -335,4 +337,4 @@
335
337
  return program.getSourceFiles().filter(function (sf) { return !sf.isDeclarationFile; });
336
338
  }
337
339
  });
338
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"state.js","sourceRoot":"","sources":["../../../../../../../../../packages/compiler-cli/src/ngtsc/incremental/src/state.ts"],"names":[],"mappings":"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","sourcesContent":["/**\n * @license\n * Copyright Google LLC All Rights Reserved.\n *\n * Use of this source code is governed by an MIT-style license that can be\n * found in the LICENSE file at https://angular.io/license\n */\n\nimport * as ts from 'typescript';\n\nimport {absoluteFrom, absoluteFromSourceFile, AbsoluteFsPath} from '../../file_system';\nimport {PerfEvent, PerfPhase, PerfRecorder} from '../../perf';\nimport {ClassDeclaration} from '../../reflection';\nimport {ClassRecord, TraitCompiler} from '../../transform';\nimport {FileTypeCheckingData} from '../../typecheck/src/checker';\nimport {IncrementalBuild} from '../api';\nimport {SemanticDepGraph, SemanticDepGraphUpdater} from '../semantic_graph';\n\nimport {FileDependencyGraph} from './dependency_tracking';\n\n/**\n * Drives an incremental build, by tracking changes and determining which files need to be emitted.\n */\nexport class IncrementalDriver implements IncrementalBuild<ClassRecord, FileTypeCheckingData> {\n  /**\n   * State of the current build.\n   *\n   * This transitions as the compilation progresses.\n   */\n  private state: BuildState;\n\n  private constructor(\n      state: PendingBuildState, readonly depGraph: FileDependencyGraph,\n      private logicalChanges: Set<string>|null) {\n    this.state = state;\n  }\n\n  /**\n   * Construct an `IncrementalDriver` with a starting state that incorporates the results of a\n   * previous build.\n   *\n   * The previous build's `BuildState` is reconciled with the new program's changes, and the results\n   * are merged into the new build's `PendingBuildState`.\n   */\n  static reconcile(\n      oldProgram: ts.Program, oldDriver: IncrementalDriver, newProgram: ts.Program,\n      modifiedResourceFiles: Set<string>|null, perf: PerfRecorder): IncrementalDriver {\n    return perf.inPhase(PerfPhase.Reconciliation, () => {\n      // Initialize the state of the current build based on the previous one.\n      let state: PendingBuildState;\n      if (oldDriver.state.kind === BuildStateKind.Pending) {\n        // The previous build never made it past the pending state. Reuse it as the starting state\n        // for this build.\n        state = oldDriver.state;\n      } else {\n        let priorGraph: SemanticDepGraph|null = null;\n        if (oldDriver.state.lastGood !== null) {\n          priorGraph = oldDriver.state.lastGood.semanticDepGraph;\n        }\n\n        // The previous build was successfully analyzed. `pendingEmit` is the only state carried\n        // forward into this build.\n        state = {\n          kind: BuildStateKind.Pending,\n          pendingEmit: oldDriver.state.pendingEmit,\n          pendingTypeCheckEmit: oldDriver.state.pendingTypeCheckEmit,\n          changedResourcePaths: new Set<AbsoluteFsPath>(),\n          changedTsPaths: new Set<string>(),\n          lastGood: oldDriver.state.lastGood,\n          semanticDepGraphUpdater: new SemanticDepGraphUpdater(priorGraph),\n        };\n      }\n\n      // Merge the freshly modified resource files with any prior ones.\n      if (modifiedResourceFiles !== null) {\n        for (const resFile of modifiedResourceFiles) {\n          state.changedResourcePaths.add(absoluteFrom(resFile));\n        }\n      }\n\n      // Next, process the files in the new program, with a couple of goals:\n      // 1) Determine which TS files have changed, if any, and merge them into `changedTsFiles`.\n      // 2) Produce a list of TS files which no longer exist in the program (they've been deleted\n      //    since the previous compilation). These need to be removed from the state tracking to\n      //    avoid leaking memory.\n\n      // All files in the old program, for easy detection of changes.\n      const oldFiles = new Set<ts.SourceFile>(oldProgram.getSourceFiles());\n\n      // Assume all the old files were deleted to begin with. Only TS files are tracked.\n      const deletedTsPaths = new Set<string>(tsOnlyFiles(oldProgram).map(sf => sf.fileName));\n\n      for (const newFile of newProgram.getSourceFiles()) {\n        if (!newFile.isDeclarationFile) {\n          // This file exists in the new program, so remove it from `deletedTsPaths`.\n          deletedTsPaths.delete(newFile.fileName);\n        }\n\n        if (oldFiles.has(newFile)) {\n          // This file hasn't changed; no need to look at it further.\n          continue;\n        }\n\n        // The file has changed since the last successful build. The appropriate reaction depends on\n        // what kind of file it is.\n        if (!newFile.isDeclarationFile) {\n          // It's a .ts file, so track it as a change.\n          state.changedTsPaths.add(newFile.fileName);\n        } else {\n          // It's a .d.ts file. Currently the compiler does not do a great job of tracking\n          // dependencies on .d.ts files, so bail out of incremental builds here and do a full\n          // build. This usually only happens if something in node_modules changes.\n          return IncrementalDriver.fresh(newProgram);\n        }\n      }\n\n      // The next step is to remove any deleted files from the state.\n      for (const filePath of deletedTsPaths) {\n        state.pendingEmit.delete(filePath);\n        state.pendingTypeCheckEmit.delete(filePath);\n\n        // Even if the file doesn't exist in the current compilation, it still might have been\n        // changed in a previous one, so delete it from the set of changed TS files, just in case.\n        state.changedTsPaths.delete(filePath);\n      }\n\n      perf.eventCount(PerfEvent.SourceFilePhysicalChange, state.changedTsPaths.size);\n\n      // Now, changedTsPaths contains physically changed TS paths. Use the previous program's\n      // logical dependency graph to determine logically changed files.\n      const depGraph = new FileDependencyGraph();\n\n      // If a previous compilation exists, use its dependency graph to determine the set of\n      // logically changed files.\n      let logicalChanges: Set<string>|null = null;\n      if (state.lastGood !== null) {\n        // Extract the set of logically changed files. At the same time, this operation populates\n        // the current (fresh) dependency graph with information about those files which have not\n        // logically changed.\n        logicalChanges = depGraph.updateWithPhysicalChanges(\n            state.lastGood.depGraph, state.changedTsPaths, deletedTsPaths,\n            state.changedResourcePaths);\n        perf.eventCount(PerfEvent.SourceFileLogicalChange, logicalChanges.size);\n        for (const fileName of state.changedTsPaths) {\n          logicalChanges.add(fileName);\n        }\n\n        // Any logically changed files need to be re-emitted. Most of the time this would happen\n        // regardless because the new dependency graph would _also_ identify the file as stale.\n        // However there are edge cases such as removing a component from an NgModule without adding\n        // it to another one, where the previous graph identifies the file as logically changed, but\n        // the new graph (which does not have that edge) fails to identify that the file should be\n        // re-emitted.\n        for (const change of logicalChanges) {\n          state.pendingEmit.add(change);\n          state.pendingTypeCheckEmit.add(change);\n        }\n      }\n\n      // `state` now reflects the initial pending state of the current compilation.\n      return new IncrementalDriver(state, depGraph, logicalChanges);\n    });\n  }\n\n  static fresh(program: ts.Program): IncrementalDriver {\n    // Initialize the set of files which need to be emitted to the set of all TS files in the\n    // program.\n    const tsFiles = tsOnlyFiles(program);\n\n    const state: PendingBuildState = {\n      kind: BuildStateKind.Pending,\n      pendingEmit: new Set<string>(tsFiles.map(sf => sf.fileName)),\n      pendingTypeCheckEmit: new Set<string>(tsFiles.map(sf => sf.fileName)),\n      changedResourcePaths: new Set<AbsoluteFsPath>(),\n      changedTsPaths: new Set<string>(),\n      lastGood: null,\n      semanticDepGraphUpdater: new SemanticDepGraphUpdater(/* priorGraph */ null),\n    };\n\n    return new IncrementalDriver(state, new FileDependencyGraph(), /* logicalChanges */ null);\n  }\n\n  getSemanticDepGraphUpdater(): SemanticDepGraphUpdater {\n    if (this.state.kind !== BuildStateKind.Pending) {\n      throw new Error('Semantic dependency updater is only available when pending analysis');\n    }\n    return this.state.semanticDepGraphUpdater;\n  }\n\n  recordSuccessfulAnalysis(traitCompiler: TraitCompiler): void {\n    if (this.state.kind !== BuildStateKind.Pending) {\n      // Changes have already been incorporated.\n      return;\n    }\n\n    const {needsEmit, needsTypeCheckEmit, newGraph} = this.state.semanticDepGraphUpdater.finalize();\n\n    const pendingEmit = this.state.pendingEmit;\n    for (const path of needsEmit) {\n      pendingEmit.add(path);\n    }\n\n    const pendingTypeCheckEmit = this.state.pendingTypeCheckEmit;\n    for (const path of needsTypeCheckEmit) {\n      pendingTypeCheckEmit.add(path);\n    }\n\n    // Update the state to an `AnalyzedBuildState`.\n    this.state = {\n      kind: BuildStateKind.Analyzed,\n      pendingEmit,\n      pendingTypeCheckEmit,\n\n      // Since this compilation was successfully analyzed, update the \"last good\" artifacts to the\n      // ones from the current compilation.\n      lastGood: {\n        depGraph: this.depGraph,\n        semanticDepGraph: newGraph,\n        traitCompiler: traitCompiler,\n        typeCheckingResults: null,\n      },\n\n      priorTypeCheckingResults:\n          this.state.lastGood !== null ? this.state.lastGood.typeCheckingResults : null,\n    };\n  }\n\n  recordSuccessfulTypeCheck(results: Map<AbsoluteFsPath, FileTypeCheckingData>): void {\n    if (this.state.lastGood === null || this.state.kind !== BuildStateKind.Analyzed) {\n      return;\n    }\n    this.state.lastGood.typeCheckingResults = results;\n\n    // Delete the files for which type-check code was generated from the set of pending type-check\n    // files.\n    for (const fileName of results.keys()) {\n      this.state.pendingTypeCheckEmit.delete(fileName);\n    }\n  }\n\n  recordSuccessfulEmit(sf: ts.SourceFile): void {\n    this.state.pendingEmit.delete(sf.fileName);\n  }\n\n  safeToSkipEmit(sf: ts.SourceFile): boolean {\n    return !this.state.pendingEmit.has(sf.fileName);\n  }\n\n  priorWorkFor(sf: ts.SourceFile): ClassRecord[]|null {\n    if (this.state.lastGood === null || this.logicalChanges === null) {\n      // There is no previous good build, so no prior work exists.\n      return null;\n    } else if (this.logicalChanges.has(sf.fileName)) {\n      // Prior work might exist, but would be stale as the file in question has logically changed.\n      return null;\n    } else {\n      // Prior work might exist, and if it does then it's usable!\n      return this.state.lastGood.traitCompiler.recordsFor(sf);\n    }\n  }\n\n  priorTypeCheckingResultsFor(sf: ts.SourceFile): FileTypeCheckingData|null {\n    if (this.state.kind !== BuildStateKind.Analyzed ||\n        this.state.priorTypeCheckingResults === null || this.logicalChanges === null) {\n      return null;\n    }\n\n    if (this.logicalChanges.has(sf.fileName) || this.state.pendingTypeCheckEmit.has(sf.fileName)) {\n      return null;\n    }\n\n    const fileName = absoluteFromSourceFile(sf);\n    if (!this.state.priorTypeCheckingResults.has(fileName)) {\n      return null;\n    }\n    const data = this.state.priorTypeCheckingResults.get(fileName)!;\n    if (data.hasInlines) {\n      return null;\n    }\n\n    return data;\n  }\n}\n\ntype BuildState = PendingBuildState|AnalyzedBuildState;\n\nenum BuildStateKind {\n  Pending,\n  Analyzed,\n}\n\ninterface BaseBuildState {\n  kind: BuildStateKind;\n\n  /**\n   * The heart of incremental builds. This `Set` tracks the set of files which need to be emitted\n   * during the current compilation.\n   *\n   * This starts out as the set of files which are still pending from the previous program (or the\n   * full set of .ts files on a fresh build).\n   *\n   * After analysis, it's updated to include any files which might have changed and need a re-emit\n   * as a result of incremental changes.\n   *\n   * If an emit happens, any written files are removed from the `Set`, as they're no longer\n   * pending.\n   *\n   * Thus, after compilation `pendingEmit` should be empty (on a successful build) or contain the\n   * files which still need to be emitted but have not yet been (due to errors).\n   *\n   * `pendingEmit` is tracked as as `Set<string>` instead of a `Set<ts.SourceFile>`, because the\n   * contents of the file are not important here, only whether or not the current version of it\n   * needs to be emitted. The `string`s here are TS file paths.\n   *\n   * See the README.md for more information on this algorithm.\n   */\n  pendingEmit: Set<string>;\n\n  /**\n   * Similar to `pendingEmit`, but then for representing the set of files for which the type-check\n   * file should be regenerated. It behaves identically with respect to errored compilations as\n   * `pendingEmit`.\n   */\n  pendingTypeCheckEmit: Set<string>;\n\n\n  /**\n   * Specific aspects of the last compilation which successfully completed analysis, if any.\n   */\n  lastGood: {\n    /**\n     * The dependency graph from the last successfully analyzed build.\n     *\n     * This is used to determine the logical impact of physical file changes.\n     */\n    depGraph: FileDependencyGraph;\n\n    /**\n     * The semantic dependency graph from the last successfully analyzed build.\n     *\n     * This is used to perform in-depth comparison of Angular decorated classes, to determine\n     * which files have to be re-emitted and/or re-type-checked.\n     */\n    semanticDepGraph: SemanticDepGraph;\n\n    /**\n     * The `TraitCompiler` from the last successfully analyzed build.\n     *\n     * This is used to extract \"prior work\" which might be reusable in this compilation.\n     */\n    traitCompiler: TraitCompiler;\n\n    /**\n     * Type checking results which will be passed onto the next build.\n     */\n    typeCheckingResults: Map<AbsoluteFsPath, FileTypeCheckingData>| null;\n  }|null;\n}\n\n/**\n * State of a build before the Angular analysis phase completes.\n */\ninterface PendingBuildState extends BaseBuildState {\n  kind: BuildStateKind.Pending;\n\n  /**\n   * Set of files which are known to need an emit.\n   *\n   * Before the compiler's analysis phase completes, `pendingEmit` only contains files that were\n   * still pending after the previous build.\n   */\n  pendingEmit: Set<string>;\n\n  /**\n   * Set of TypeScript file paths which have changed since the last successfully analyzed build.\n   */\n  changedTsPaths: Set<string>;\n\n  /**\n   * Set of resource file paths which have changed since the last successfully analyzed build.\n   */\n  changedResourcePaths: Set<AbsoluteFsPath>;\n\n  /**\n   * In a pending state, the semantic dependency graph is available to the compilation to register\n   * the incremental symbols into.\n   */\n  semanticDepGraphUpdater: SemanticDepGraphUpdater;\n}\n\ninterface AnalyzedBuildState extends BaseBuildState {\n  kind: BuildStateKind.Analyzed;\n\n  /**\n   * Set of files which are known to need an emit.\n   *\n   * After analysis completes (that is, the state transitions to `AnalyzedBuildState`), the\n   * `pendingEmit` set takes into account any on-disk changes made since the last successfully\n   * analyzed build.\n   */\n  pendingEmit: Set<string>;\n\n  /**\n   * Type checking results from the previous compilation, which can be reused in this one.\n   */\n  priorTypeCheckingResults: Map<AbsoluteFsPath, FileTypeCheckingData>|null;\n}\n\nfunction tsOnlyFiles(program: ts.Program): ReadonlyArray<ts.SourceFile> {\n  return program.getSourceFiles().filter(sf => !sf.isDeclarationFile);\n}\n"]}
340
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"state.js","sourceRoot":"","sources":["../../../../../../../../../packages/compiler-cli/src/ngtsc/incremental/src/state.ts"],"names":[],"mappings":"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","sourcesContent":["/**\n * @license\n * Copyright Google LLC All Rights Reserved.\n *\n * Use of this source code is governed by an MIT-style license that can be\n * found in the LICENSE file at https://angular.io/license\n */\n\nimport * as ts from 'typescript';\n\nimport {absoluteFrom, absoluteFromSourceFile, AbsoluteFsPath} from '../../file_system';\nimport {PerfEvent, PerfPhase, PerfRecorder} from '../../perf';\nimport {ClassDeclaration} from '../../reflection';\nimport {ClassRecord, TraitCompiler} from '../../transform';\nimport {FileTypeCheckingData} from '../../typecheck/src/checker';\nimport {toUnredirectedSourceFile} from '../../util/src/typescript';\nimport {IncrementalBuild} from '../api';\nimport {SemanticDepGraph, SemanticDepGraphUpdater} from '../semantic_graph';\n\nimport {FileDependencyGraph} from './dependency_tracking';\n\n/**\n * Drives an incremental build, by tracking changes and determining which files need to be emitted.\n */\nexport class IncrementalDriver implements IncrementalBuild<ClassRecord, FileTypeCheckingData> {\n  /**\n   * State of the current build.\n   *\n   * This transitions as the compilation progresses.\n   */\n  private state: BuildState;\n\n  private constructor(\n      state: PendingBuildState, readonly depGraph: FileDependencyGraph,\n      private logicalChanges: Set<string>|null) {\n    this.state = state;\n  }\n\n  /**\n   * Construct an `IncrementalDriver` with a starting state that incorporates the results of a\n   * previous build.\n   *\n   * The previous build's `BuildState` is reconciled with the new program's changes, and the results\n   * are merged into the new build's `PendingBuildState`.\n   */\n  static reconcile(\n      oldProgram: ts.Program, oldDriver: IncrementalDriver, newProgram: ts.Program,\n      modifiedResourceFiles: Set<string>|null, perf: PerfRecorder): IncrementalDriver {\n    return perf.inPhase(PerfPhase.Reconciliation, () => {\n      // Initialize the state of the current build based on the previous one.\n      let state: PendingBuildState;\n      if (oldDriver.state.kind === BuildStateKind.Pending) {\n        // The previous build never made it past the pending state. Reuse it as the starting state\n        // for this build.\n        state = oldDriver.state;\n      } else {\n        let priorGraph: SemanticDepGraph|null = null;\n        if (oldDriver.state.lastGood !== null) {\n          priorGraph = oldDriver.state.lastGood.semanticDepGraph;\n        }\n\n        // The previous build was successfully analyzed. `pendingEmit` is the only state carried\n        // forward into this build.\n        state = {\n          kind: BuildStateKind.Pending,\n          pendingEmit: oldDriver.state.pendingEmit,\n          pendingTypeCheckEmit: oldDriver.state.pendingTypeCheckEmit,\n          changedResourcePaths: new Set<AbsoluteFsPath>(),\n          changedTsPaths: new Set<string>(),\n          lastGood: oldDriver.state.lastGood,\n          semanticDepGraphUpdater: new SemanticDepGraphUpdater(priorGraph),\n        };\n      }\n\n      // Merge the freshly modified resource files with any prior ones.\n      if (modifiedResourceFiles !== null) {\n        for (const resFile of modifiedResourceFiles) {\n          state.changedResourcePaths.add(absoluteFrom(resFile));\n        }\n      }\n\n      // Next, process the files in the new program, with a couple of goals:\n      // 1) Determine which TS files have changed, if any, and merge them into `changedTsFiles`.\n      // 2) Produce a list of TS files which no longer exist in the program (they've been deleted\n      //    since the previous compilation). These need to be removed from the state tracking to\n      //    avoid leaking memory.\n\n      // All files in the old program, for easy detection of changes.\n      const oldFiles =\n          new Set<ts.SourceFile>(oldProgram.getSourceFiles().map(toUnredirectedSourceFile));\n\n      // Assume all the old files were deleted to begin with. Only TS files are tracked.\n      const deletedTsPaths = new Set<string>(tsOnlyFiles(oldProgram).map(sf => sf.fileName));\n\n      for (const possiblyRedirectedNewFile of newProgram.getSourceFiles()) {\n        const newFile = toUnredirectedSourceFile(possiblyRedirectedNewFile);\n        if (!newFile.isDeclarationFile) {\n          // This file exists in the new program, so remove it from `deletedTsPaths`.\n          deletedTsPaths.delete(newFile.fileName);\n        }\n\n        if (oldFiles.has(newFile)) {\n          // This file hasn't changed; no need to look at it further.\n          continue;\n        }\n\n        // The file has changed since the last successful build. The appropriate reaction depends on\n        // what kind of file it is.\n        if (!newFile.isDeclarationFile) {\n          // It's a .ts file, so track it as a change.\n          state.changedTsPaths.add(newFile.fileName);\n        } else {\n          // It's a .d.ts file. Currently the compiler does not do a great job of tracking\n          // dependencies on .d.ts files, so bail out of incremental builds here and do a full\n          // build. This usually only happens if something in node_modules changes.\n          return IncrementalDriver.fresh(newProgram);\n        }\n      }\n\n      // The next step is to remove any deleted files from the state.\n      for (const filePath of deletedTsPaths) {\n        state.pendingEmit.delete(filePath);\n        state.pendingTypeCheckEmit.delete(filePath);\n\n        // Even if the file doesn't exist in the current compilation, it still might have been\n        // changed in a previous one, so delete it from the set of changed TS files, just in case.\n        state.changedTsPaths.delete(filePath);\n      }\n\n      perf.eventCount(PerfEvent.SourceFilePhysicalChange, state.changedTsPaths.size);\n\n      // Now, changedTsPaths contains physically changed TS paths. Use the previous program's\n      // logical dependency graph to determine logically changed files.\n      const depGraph = new FileDependencyGraph();\n\n      // If a previous compilation exists, use its dependency graph to determine the set of\n      // logically changed files.\n      let logicalChanges: Set<string>|null = null;\n      if (state.lastGood !== null) {\n        // Extract the set of logically changed files. At the same time, this operation populates\n        // the current (fresh) dependency graph with information about those files which have not\n        // logically changed.\n        logicalChanges = depGraph.updateWithPhysicalChanges(\n            state.lastGood.depGraph, state.changedTsPaths, deletedTsPaths,\n            state.changedResourcePaths);\n        perf.eventCount(PerfEvent.SourceFileLogicalChange, logicalChanges.size);\n        for (const fileName of state.changedTsPaths) {\n          logicalChanges.add(fileName);\n        }\n\n        // Any logically changed files need to be re-emitted. Most of the time this would happen\n        // regardless because the new dependency graph would _also_ identify the file as stale.\n        // However there are edge cases such as removing a component from an NgModule without adding\n        // it to another one, where the previous graph identifies the file as logically changed, but\n        // the new graph (which does not have that edge) fails to identify that the file should be\n        // re-emitted.\n        for (const change of logicalChanges) {\n          state.pendingEmit.add(change);\n          state.pendingTypeCheckEmit.add(change);\n        }\n      }\n\n      // `state` now reflects the initial pending state of the current compilation.\n      return new IncrementalDriver(state, depGraph, logicalChanges);\n    });\n  }\n\n  static fresh(program: ts.Program): IncrementalDriver {\n    // Initialize the set of files which need to be emitted to the set of all TS files in the\n    // program.\n    const tsFiles = tsOnlyFiles(program);\n\n    const state: PendingBuildState = {\n      kind: BuildStateKind.Pending,\n      pendingEmit: new Set<string>(tsFiles.map(sf => sf.fileName)),\n      pendingTypeCheckEmit: new Set<string>(tsFiles.map(sf => sf.fileName)),\n      changedResourcePaths: new Set<AbsoluteFsPath>(),\n      changedTsPaths: new Set<string>(),\n      lastGood: null,\n      semanticDepGraphUpdater: new SemanticDepGraphUpdater(/* priorGraph */ null),\n    };\n\n    return new IncrementalDriver(state, new FileDependencyGraph(), /* logicalChanges */ null);\n  }\n\n  getSemanticDepGraphUpdater(): SemanticDepGraphUpdater {\n    if (this.state.kind !== BuildStateKind.Pending) {\n      throw new Error('Semantic dependency updater is only available when pending analysis');\n    }\n    return this.state.semanticDepGraphUpdater;\n  }\n\n  recordSuccessfulAnalysis(traitCompiler: TraitCompiler): void {\n    if (this.state.kind !== BuildStateKind.Pending) {\n      // Changes have already been incorporated.\n      return;\n    }\n\n    const {needsEmit, needsTypeCheckEmit, newGraph} = this.state.semanticDepGraphUpdater.finalize();\n\n    const pendingEmit = this.state.pendingEmit;\n    for (const path of needsEmit) {\n      pendingEmit.add(path);\n    }\n\n    const pendingTypeCheckEmit = this.state.pendingTypeCheckEmit;\n    for (const path of needsTypeCheckEmit) {\n      pendingTypeCheckEmit.add(path);\n    }\n\n    // Update the state to an `AnalyzedBuildState`.\n    this.state = {\n      kind: BuildStateKind.Analyzed,\n      pendingEmit,\n      pendingTypeCheckEmit,\n\n      // Since this compilation was successfully analyzed, update the \"last good\" artifacts to the\n      // ones from the current compilation.\n      lastGood: {\n        depGraph: this.depGraph,\n        semanticDepGraph: newGraph,\n        traitCompiler: traitCompiler,\n        typeCheckingResults: null,\n      },\n\n      priorTypeCheckingResults:\n          this.state.lastGood !== null ? this.state.lastGood.typeCheckingResults : null,\n    };\n  }\n\n  recordSuccessfulTypeCheck(results: Map<AbsoluteFsPath, FileTypeCheckingData>): void {\n    if (this.state.lastGood === null || this.state.kind !== BuildStateKind.Analyzed) {\n      return;\n    }\n    this.state.lastGood.typeCheckingResults = results;\n\n    // Delete the files for which type-check code was generated from the set of pending type-check\n    // files.\n    for (const fileName of results.keys()) {\n      this.state.pendingTypeCheckEmit.delete(fileName);\n    }\n  }\n\n  recordSuccessfulEmit(sf: ts.SourceFile): void {\n    this.state.pendingEmit.delete(sf.fileName);\n  }\n\n  safeToSkipEmit(sf: ts.SourceFile): boolean {\n    return !this.state.pendingEmit.has(sf.fileName);\n  }\n\n  priorWorkFor(sf: ts.SourceFile): ClassRecord[]|null {\n    if (this.state.lastGood === null || this.logicalChanges === null) {\n      // There is no previous good build, so no prior work exists.\n      return null;\n    } else if (this.logicalChanges.has(sf.fileName)) {\n      // Prior work might exist, but would be stale as the file in question has logically changed.\n      return null;\n    } else {\n      // Prior work might exist, and if it does then it's usable!\n      return this.state.lastGood.traitCompiler.recordsFor(sf);\n    }\n  }\n\n  priorTypeCheckingResultsFor(sf: ts.SourceFile): FileTypeCheckingData|null {\n    if (this.state.kind !== BuildStateKind.Analyzed ||\n        this.state.priorTypeCheckingResults === null || this.logicalChanges === null) {\n      return null;\n    }\n\n    if (this.logicalChanges.has(sf.fileName) || this.state.pendingTypeCheckEmit.has(sf.fileName)) {\n      return null;\n    }\n\n    const fileName = absoluteFromSourceFile(sf);\n    if (!this.state.priorTypeCheckingResults.has(fileName)) {\n      return null;\n    }\n    const data = this.state.priorTypeCheckingResults.get(fileName)!;\n    if (data.hasInlines) {\n      return null;\n    }\n\n    return data;\n  }\n}\n\ntype BuildState = PendingBuildState|AnalyzedBuildState;\n\nenum BuildStateKind {\n  Pending,\n  Analyzed,\n}\n\ninterface BaseBuildState {\n  kind: BuildStateKind;\n\n  /**\n   * The heart of incremental builds. This `Set` tracks the set of files which need to be emitted\n   * during the current compilation.\n   *\n   * This starts out as the set of files which are still pending from the previous program (or the\n   * full set of .ts files on a fresh build).\n   *\n   * After analysis, it's updated to include any files which might have changed and need a re-emit\n   * as a result of incremental changes.\n   *\n   * If an emit happens, any written files are removed from the `Set`, as they're no longer\n   * pending.\n   *\n   * Thus, after compilation `pendingEmit` should be empty (on a successful build) or contain the\n   * files which still need to be emitted but have not yet been (due to errors).\n   *\n   * `pendingEmit` is tracked as as `Set<string>` instead of a `Set<ts.SourceFile>`, because the\n   * contents of the file are not important here, only whether or not the current version of it\n   * needs to be emitted. The `string`s here are TS file paths.\n   *\n   * See the README.md for more information on this algorithm.\n   */\n  pendingEmit: Set<string>;\n\n  /**\n   * Similar to `pendingEmit`, but then for representing the set of files for which the type-check\n   * file should be regenerated. It behaves identically with respect to errored compilations as\n   * `pendingEmit`.\n   */\n  pendingTypeCheckEmit: Set<string>;\n\n\n  /**\n   * Specific aspects of the last compilation which successfully completed analysis, if any.\n   */\n  lastGood: {\n    /**\n     * The dependency graph from the last successfully analyzed build.\n     *\n     * This is used to determine the logical impact of physical file changes.\n     */\n    depGraph: FileDependencyGraph;\n\n    /**\n     * The semantic dependency graph from the last successfully analyzed build.\n     *\n     * This is used to perform in-depth comparison of Angular decorated classes, to determine\n     * which files have to be re-emitted and/or re-type-checked.\n     */\n    semanticDepGraph: SemanticDepGraph;\n\n    /**\n     * The `TraitCompiler` from the last successfully analyzed build.\n     *\n     * This is used to extract \"prior work\" which might be reusable in this compilation.\n     */\n    traitCompiler: TraitCompiler;\n\n    /**\n     * Type checking results which will be passed onto the next build.\n     */\n    typeCheckingResults: Map<AbsoluteFsPath, FileTypeCheckingData>| null;\n  }|null;\n}\n\n/**\n * State of a build before the Angular analysis phase completes.\n */\ninterface PendingBuildState extends BaseBuildState {\n  kind: BuildStateKind.Pending;\n\n  /**\n   * Set of files which are known to need an emit.\n   *\n   * Before the compiler's analysis phase completes, `pendingEmit` only contains files that were\n   * still pending after the previous build.\n   */\n  pendingEmit: Set<string>;\n\n  /**\n   * Set of TypeScript file paths which have changed since the last successfully analyzed build.\n   */\n  changedTsPaths: Set<string>;\n\n  /**\n   * Set of resource file paths which have changed since the last successfully analyzed build.\n   */\n  changedResourcePaths: Set<AbsoluteFsPath>;\n\n  /**\n   * In a pending state, the semantic dependency graph is available to the compilation to register\n   * the incremental symbols into.\n   */\n  semanticDepGraphUpdater: SemanticDepGraphUpdater;\n}\n\ninterface AnalyzedBuildState extends BaseBuildState {\n  kind: BuildStateKind.Analyzed;\n\n  /**\n   * Set of files which are known to need an emit.\n   *\n   * After analysis completes (that is, the state transitions to `AnalyzedBuildState`), the\n   * `pendingEmit` set takes into account any on-disk changes made since the last successfully\n   * analyzed build.\n   */\n  pendingEmit: Set<string>;\n\n  /**\n   * Type checking results from the previous compilation, which can be reused in this one.\n   */\n  priorTypeCheckingResults: Map<AbsoluteFsPath, FileTypeCheckingData>|null;\n}\n\nfunction tsOnlyFiles(program: ts.Program): ReadonlyArray<ts.SourceFile> {\n  return program.getSourceFiles().filter(sf => !sf.isDeclarationFile);\n}\n"]}