@angular/compiler-cli 9.0.0-rc.6 → 9.0.0

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 (255) hide show
  1. package/ngcc/src/analysis/decoration_analyzer.d.ts +13 -26
  2. package/ngcc/src/analysis/decoration_analyzer.js +100 -134
  3. package/ngcc/src/analysis/migration_host.d.ts +5 -16
  4. package/ngcc/src/analysis/migration_host.js +20 -91
  5. package/ngcc/src/analysis/module_with_providers_analyzer.js +2 -2
  6. package/ngcc/src/analysis/ngcc_trait_compiler.d.ts +42 -0
  7. package/ngcc/src/analysis/ngcc_trait_compiler.js +107 -0
  8. package/ngcc/src/analysis/private_declarations_analyzer.d.ts +0 -1
  9. package/ngcc/src/analysis/private_declarations_analyzer.js +4 -35
  10. package/ngcc/src/analysis/types.d.ts +6 -21
  11. package/ngcc/src/analysis/types.js +1 -1
  12. package/ngcc/src/analysis/util.d.ts +2 -5
  13. package/ngcc/src/analysis/util.js +11 -94
  14. package/ngcc/src/dependencies/commonjs_dependency_host.d.ts +1 -1
  15. package/ngcc/src/dependencies/commonjs_dependency_host.js +90 -39
  16. package/ngcc/src/dependencies/dependency_host.d.ts +7 -5
  17. package/ngcc/src/dependencies/dependency_host.js +12 -10
  18. package/ngcc/src/dependencies/dependency_resolver.d.ts +2 -1
  19. package/ngcc/src/dependencies/dependency_resolver.js +9 -4
  20. package/ngcc/src/dependencies/dts_dependency_host.d.ts +21 -0
  21. package/ngcc/src/dependencies/dts_dependency_host.js +34 -0
  22. package/ngcc/src/dependencies/esm_dependency_host.d.ts +8 -1
  23. package/ngcc/src/dependencies/esm_dependency_host.js +30 -22
  24. package/ngcc/src/dependencies/module_resolver.d.ts +1 -1
  25. package/ngcc/src/dependencies/module_resolver.js +1 -1
  26. package/ngcc/src/dependencies/umd_dependency_host.d.ts +1 -1
  27. package/ngcc/src/dependencies/umd_dependency_host.js +3 -3
  28. package/ngcc/src/entry_point_finder/targeted_entry_point_finder.d.ts +2 -0
  29. package/ngcc/src/entry_point_finder/targeted_entry_point_finder.js +49 -9
  30. package/ngcc/src/execution/cluster/executor.d.ts +3 -1
  31. package/ngcc/src/execution/cluster/executor.js +12 -7
  32. package/ngcc/src/execution/cluster/package_json_updater.js +3 -2
  33. package/ngcc/src/execution/cluster/worker.d.ts +3 -1
  34. package/ngcc/src/execution/cluster/worker.js +10 -7
  35. package/ngcc/src/execution/lock_file.d.ts +43 -0
  36. package/ngcc/src/execution/lock_file.js +129 -0
  37. package/ngcc/src/execution/single_process_executor.d.ts +3 -1
  38. package/ngcc/src/execution/single_process_executor.js +18 -15
  39. package/ngcc/src/execution/task_selection/base_task_queue.d.ts +1 -1
  40. package/ngcc/src/host/commonjs_host.d.ts +6 -18
  41. package/ngcc/src/host/commonjs_host.js +45 -81
  42. package/ngcc/src/host/commonjs_umd_utils.d.ts +73 -0
  43. package/ngcc/src/host/commonjs_umd_utils.js +109 -0
  44. package/ngcc/src/host/esm2015_host.d.ts +46 -14
  45. package/ngcc/src/host/esm2015_host.js +182 -55
  46. package/ngcc/src/host/esm5_host.js +3 -1
  47. package/ngcc/src/host/umd_host.d.ts +12 -5
  48. package/ngcc/src/host/umd_host.js +144 -92
  49. package/ngcc/src/main.js +65 -122
  50. package/ngcc/src/migrations/migration.d.ts +1 -0
  51. package/ngcc/src/migrations/migration.js +1 -1
  52. package/ngcc/src/packages/build_marker.d.ts +17 -8
  53. package/ngcc/src/packages/build_marker.js +61 -32
  54. package/ngcc/src/packages/entry_point_bundle.js +2 -2
  55. package/ngcc/src/packages/transformer.js +5 -6
  56. package/ngcc/src/rendering/commonjs_rendering_formatter.js +9 -5
  57. package/ngcc/src/rendering/dts_renderer.js +8 -5
  58. package/ngcc/src/rendering/esm_rendering_formatter.js +17 -5
  59. package/ngcc/src/rendering/renderer.js +4 -4
  60. package/ngcc/src/rendering/umd_rendering_formatter.d.ts +18 -1
  61. package/ngcc/src/rendering/umd_rendering_formatter.js +69 -16
  62. package/ngcc/src/utils.d.ts +14 -0
  63. package/ngcc/src/utils.js +29 -1
  64. package/ngcc/src/writing/cleaning/cleaning_strategies.d.ts +45 -0
  65. package/ngcc/src/writing/cleaning/cleaning_strategies.js +77 -0
  66. package/ngcc/src/writing/cleaning/package_cleaner.d.ts +39 -0
  67. package/ngcc/src/writing/cleaning/package_cleaner.js +125 -0
  68. package/ngcc/src/writing/cleaning/utils.d.ts +16 -0
  69. package/ngcc/src/writing/cleaning/utils.js +29 -0
  70. package/ngcc/src/writing/in_place_file_writer.d.ts +1 -0
  71. package/ngcc/src/writing/in_place_file_writer.js +3 -2
  72. package/ngcc/src/writing/new_entry_point_file_writer.d.ts +2 -0
  73. package/ngcc/src/writing/new_entry_point_file_writer.js +5 -4
  74. package/ngcc/src/writing/package_json_updater.d.ts +24 -10
  75. package/ngcc/src/writing/package_json_updater.js +53 -10
  76. package/package.json +6 -5
  77. package/src/main.d.ts +2 -2
  78. package/src/metadata/symbols.d.ts +1 -1
  79. package/src/ngtsc/annotations/src/component.d.ts +58 -20
  80. package/src/ngtsc/annotations/src/component.js +149 -97
  81. package/src/ngtsc/annotations/src/diagnostics.d.ts +23 -0
  82. package/src/ngtsc/annotations/src/diagnostics.js +123 -0
  83. package/src/ngtsc/annotations/src/directive.d.ts +19 -8
  84. package/src/ngtsc/annotations/src/directive.js +41 -18
  85. package/src/ngtsc/annotations/src/injectable.d.ts +8 -4
  86. package/src/ngtsc/annotations/src/injectable.js +7 -3
  87. package/src/ngtsc/annotations/src/ng_module.d.ts +22 -7
  88. package/src/ngtsc/annotations/src/ng_module.js +115 -52
  89. package/src/ngtsc/annotations/src/pipe.d.ts +12 -6
  90. package/src/ngtsc/annotations/src/pipe.js +22 -5
  91. package/src/ngtsc/annotations/src/util.d.ts +22 -0
  92. package/src/ngtsc/annotations/src/util.js +92 -3
  93. package/src/ngtsc/core/api.d.ts +368 -0
  94. package/src/ngtsc/core/api.js +20 -0
  95. package/src/ngtsc/core/index.d.ts +10 -0
  96. package/src/ngtsc/core/index.js +24 -0
  97. package/src/ngtsc/core/src/compiler.d.ts +120 -0
  98. package/src/ngtsc/core/src/compiler.js +769 -0
  99. package/src/ngtsc/core/src/host.d.ts +85 -0
  100. package/src/ngtsc/core/src/host.js +208 -0
  101. package/src/ngtsc/cycles/src/imports.js +2 -2
  102. package/src/ngtsc/diagnostics/index.d.ts +1 -1
  103. package/src/ngtsc/diagnostics/index.js +5 -5
  104. package/src/ngtsc/diagnostics/src/error.d.ts +1 -1
  105. package/src/ngtsc/diagnostics/src/error.js +1 -1
  106. package/src/ngtsc/diagnostics/src/{code.d.ts → error_code.d.ts} +27 -4
  107. package/src/ngtsc/diagnostics/src/error_code.js +128 -0
  108. package/src/ngtsc/file_system/src/cached_file_system.d.ts +3 -1
  109. package/src/ngtsc/file_system/src/cached_file_system.js +48 -4
  110. package/src/ngtsc/file_system/src/invalid_file_system.d.ts +3 -1
  111. package/src/ngtsc/file_system/src/invalid_file_system.js +4 -2
  112. package/src/ngtsc/file_system/src/node_js_file_system.d.ts +3 -1
  113. package/src/ngtsc/file_system/src/node_js_file_system.js +8 -4
  114. package/src/ngtsc/file_system/src/types.d.ts +3 -1
  115. package/src/ngtsc/file_system/src/types.js +1 -1
  116. package/src/ngtsc/imports/index.d.ts +3 -3
  117. package/src/ngtsc/imports/index.js +4 -4
  118. package/src/ngtsc/imports/src/alias.d.ts +12 -11
  119. package/src/ngtsc/imports/src/alias.js +21 -16
  120. package/src/ngtsc/imports/src/emitter.d.ts +40 -19
  121. package/src/ngtsc/imports/src/emitter.js +54 -26
  122. package/src/ngtsc/imports/src/references.d.ts +30 -8
  123. package/src/ngtsc/imports/src/references.js +41 -6
  124. package/src/ngtsc/imports/src/resolver.d.ts +3 -6
  125. package/src/ngtsc/imports/src/resolver.js +5 -4
  126. package/src/ngtsc/incremental/api.d.ts +51 -0
  127. package/src/ngtsc/incremental/api.js +20 -0
  128. package/src/ngtsc/incremental/index.d.ts +1 -0
  129. package/src/ngtsc/incremental/index.js +4 -2
  130. package/src/ngtsc/incremental/src/dependency_tracking.d.ts +56 -0
  131. package/src/ngtsc/incremental/src/dependency_tracking.js +186 -0
  132. package/src/ngtsc/incremental/src/noop.d.ts +10 -0
  133. package/src/ngtsc/incremental/src/noop.js +23 -0
  134. package/src/ngtsc/incremental/src/state.d.ts +8 -14
  135. package/src/ngtsc/incremental/src/state.js +83 -80
  136. package/src/ngtsc/indexer/index.d.ts +1 -0
  137. package/src/ngtsc/indexer/index.js +4 -2
  138. package/src/ngtsc/metadata/index.d.ts +1 -1
  139. package/src/ngtsc/metadata/index.js +2 -1
  140. package/src/ngtsc/metadata/src/api.d.ts +8 -0
  141. package/src/ngtsc/metadata/src/api.js +1 -1
  142. package/src/ngtsc/metadata/src/dts.js +2 -1
  143. package/src/ngtsc/metadata/src/registry.d.ts +12 -1
  144. package/src/ngtsc/metadata/src/registry.js +22 -2
  145. package/src/ngtsc/metadata/src/util.d.ts +2 -0
  146. package/src/ngtsc/metadata/src/util.js +10 -1
  147. package/src/ngtsc/modulewithproviders/src/scanner.js +2 -2
  148. package/src/ngtsc/partial_evaluator/index.d.ts +1 -1
  149. package/src/ngtsc/partial_evaluator/index.js +1 -1
  150. package/src/ngtsc/partial_evaluator/src/builtin.d.ts +7 -6
  151. package/src/ngtsc/partial_evaluator/src/builtin.js +54 -9
  152. package/src/ngtsc/partial_evaluator/src/interface.d.ts +3 -9
  153. package/src/ngtsc/partial_evaluator/src/interface.js +4 -3
  154. package/src/ngtsc/partial_evaluator/src/interpreter.d.ts +4 -3
  155. package/src/ngtsc/partial_evaluator/src/interpreter.js +11 -7
  156. package/src/ngtsc/partial_evaluator/src/known_declaration.d.ts +19 -0
  157. package/src/ngtsc/partial_evaluator/src/known_declaration.js +38 -0
  158. package/src/ngtsc/partial_evaluator/src/result.d.ts +1 -1
  159. package/src/ngtsc/partial_evaluator/src/result.js +1 -1
  160. package/src/ngtsc/partial_evaluator/src/ts_helpers.d.ts +1 -1
  161. package/src/ngtsc/partial_evaluator/src/ts_helpers.js +13 -3
  162. package/src/ngtsc/program.d.ts +46 -57
  163. package/src/ngtsc/program.js +68 -574
  164. package/src/ngtsc/reflection/src/host.d.ts +19 -2
  165. package/src/ngtsc/reflection/src/host.js +17 -3
  166. package/src/ngtsc/reflection/src/typescript.js +11 -7
  167. package/src/ngtsc/resource/index.d.ts +9 -0
  168. package/src/ngtsc/resource/index.js +22 -0
  169. package/src/ngtsc/{resource_loader.d.ts → resource/src/loader.d.ts} +4 -4
  170. package/src/ngtsc/resource/src/loader.js +193 -0
  171. package/src/ngtsc/routing/src/route.js +2 -2
  172. package/src/ngtsc/scope/index.d.ts +1 -1
  173. package/src/ngtsc/scope/index.js +1 -1
  174. package/src/ngtsc/scope/src/component_scope.d.ts +2 -2
  175. package/src/ngtsc/scope/src/component_scope.js +1 -1
  176. package/src/ngtsc/scope/src/dependency.js +10 -8
  177. package/src/ngtsc/scope/src/local.d.ts +31 -4
  178. package/src/ngtsc/scope/src/local.js +83 -15
  179. package/src/ngtsc/shims/index.d.ts +2 -1
  180. package/src/ngtsc/shims/index.js +4 -5
  181. package/src/ngtsc/shims/src/api.d.ts +25 -0
  182. package/src/ngtsc/shims/src/api.js +13 -0
  183. package/src/ngtsc/shims/src/factory_generator.d.ts +2 -2
  184. package/src/ngtsc/shims/src/factory_generator.js +1 -1
  185. package/src/ngtsc/shims/src/factory_tracker.d.ts +24 -0
  186. package/src/ngtsc/shims/src/factory_tracker.js +47 -0
  187. package/src/ngtsc/shims/src/summary_generator.d.ts +1 -1
  188. package/src/ngtsc/shims/src/summary_generator.js +1 -1
  189. package/src/ngtsc/shims/src/typecheck_shim.d.ts +1 -1
  190. package/src/ngtsc/shims/src/typecheck_shim.js +1 -1
  191. package/src/ngtsc/synthetic_files_compiler_host.d.ts +1 -1
  192. package/src/ngtsc/transform/index.d.ts +3 -1
  193. package/src/ngtsc/transform/index.js +8 -3
  194. package/src/ngtsc/transform/src/alias.d.ts +1 -1
  195. package/src/ngtsc/transform/src/alias.js +1 -1
  196. package/src/ngtsc/transform/src/api.d.ts +52 -17
  197. package/src/ngtsc/transform/src/api.js +1 -1
  198. package/src/ngtsc/transform/src/compilation.d.ts +68 -47
  199. package/src/ngtsc/transform/src/compilation.js +498 -313
  200. package/src/ngtsc/transform/src/declaration.d.ts +1 -1
  201. package/src/ngtsc/transform/src/declaration.js +6 -1
  202. package/src/ngtsc/transform/src/trait.d.ts +169 -0
  203. package/src/ngtsc/transform/src/trait.js +114 -0
  204. package/src/ngtsc/transform/src/transform.d.ts +2 -2
  205. package/src/ngtsc/transform/src/transform.js +4 -4
  206. package/src/ngtsc/translator/src/translator.d.ts +11 -9
  207. package/src/ngtsc/translator/src/translator.js +51 -18
  208. package/src/ngtsc/typecheck/index.d.ts +1 -0
  209. package/src/ngtsc/typecheck/index.js +4 -2
  210. package/src/ngtsc/typecheck/src/api.d.ts +12 -1
  211. package/src/ngtsc/typecheck/src/api.js +1 -1
  212. package/src/ngtsc/typecheck/src/context.d.ts +3 -2
  213. package/src/ngtsc/typecheck/src/context.js +10 -8
  214. package/src/ngtsc/typecheck/src/diagnostics.d.ts +30 -31
  215. package/src/ngtsc/typecheck/src/diagnostics.js +108 -70
  216. package/src/ngtsc/typecheck/src/dom.d.ts +6 -5
  217. package/src/ngtsc/typecheck/src/dom.js +3 -3
  218. package/src/ngtsc/typecheck/src/environment.d.ts +5 -3
  219. package/src/ngtsc/typecheck/src/environment.js +20 -8
  220. package/src/ngtsc/typecheck/src/expression.d.ts +2 -3
  221. package/src/ngtsc/typecheck/src/expression.js +26 -23
  222. package/src/ngtsc/typecheck/src/host.d.ts +1 -0
  223. package/src/ngtsc/typecheck/src/host.js +4 -1
  224. package/src/ngtsc/typecheck/src/oob.d.ts +11 -11
  225. package/src/ngtsc/typecheck/src/oob.js +15 -4
  226. package/src/ngtsc/typecheck/src/source.d.ts +9 -9
  227. package/src/ngtsc/typecheck/src/source.js +15 -15
  228. package/src/ngtsc/typecheck/src/template_semantics.d.ts +22 -0
  229. package/src/ngtsc/typecheck/src/template_semantics.js +51 -0
  230. package/src/ngtsc/typecheck/src/ts_util.js +36 -1
  231. package/src/ngtsc/typecheck/src/type_check_block.d.ts +3 -3
  232. package/src/ngtsc/typecheck/src/type_check_block.js +70 -43
  233. package/src/ngtsc/typecheck/src/type_check_file.d.ts +2 -2
  234. package/src/ngtsc/typecheck/src/type_check_file.js +3 -3
  235. package/src/ngtsc/typecheck/src/type_constructor.d.ts +4 -4
  236. package/src/ngtsc/typecheck/src/type_constructor.js +15 -10
  237. package/src/ngtsc/typecheck/src/type_emitter.d.ts +72 -0
  238. package/src/ngtsc/typecheck/src/type_emitter.js +150 -0
  239. package/src/ngtsc/typecheck/src/type_parameter_emitter.d.ts +31 -0
  240. package/src/ngtsc/typecheck/src/type_parameter_emitter.js +96 -0
  241. package/src/ngtsc/util/src/typescript.d.ts +7 -1
  242. package/src/ngtsc/util/src/typescript.js +15 -5
  243. package/src/perform_watch.js +6 -5
  244. package/src/transformers/api.d.ts +3 -204
  245. package/src/transformers/api.js +1 -1
  246. package/src/transformers/compiler_host.js +2 -2
  247. package/src/transformers/program.js +1 -1
  248. package/src/typescript_support.js +2 -2
  249. package/src/version.js +1 -1
  250. package/src/ngtsc/diagnostics/src/code.js +0 -101
  251. package/src/ngtsc/resource_loader.js +0 -193
  252. package/src/ngtsc/shims/src/host.d.ts +0 -46
  253. package/src/ngtsc/shims/src/host.js +0 -82
  254. package/src/ngtsc/util/src/resource_recorder.d.ts +0 -18
  255. package/src/ngtsc/util/src/resource_recorder.js +0 -20
@@ -8,9 +8,10 @@
8
8
  /// <amd-module name="@angular/compiler-cli/src/ngtsc/imports/src/alias" />
9
9
  import { Expression } from '@angular/compiler';
10
10
  import * as ts from 'typescript';
11
+ import { UnifiedModulesHost } from '../../core/api';
11
12
  import { ClassDeclaration, ReflectionHost } from '../../reflection';
12
- import { FileToModuleHost, ReferenceEmitStrategy } from './emitter';
13
- import { ImportMode, Reference } from './references';
13
+ import { ImportFlags, ReferenceEmitStrategy } from './emitter';
14
+ import { Reference } from './references';
14
15
  /**
15
16
  * A host for the aliasing system, which allows for alternative exports/imports of directives/pipes.
16
17
  *
@@ -26,8 +27,8 @@ import { ImportMode, Reference } from './references';
26
27
  *
27
28
  * 1) It can be used to create "alias" re-exports from different files, which can be used when the
28
29
  * user hasn't exported the directive(s) from the ES module containing the NgModule. These re-
29
- * exports can also be helpful when using a `FileToModuleHost`, which overrides the import logic
30
- * described above.
30
+ * exports can also be helpful when using a `UnifiedModulesHost`, which overrides the import
31
+ * logic described above.
31
32
  *
32
33
  * 2) It can be used to get an alternative import expression for a directive or pipe, instead of
33
34
  * the import that the normal logic would apply. The alias used depends on the provenance of the
@@ -73,16 +74,16 @@ export interface AliasingHost {
73
74
  }
74
75
  /**
75
76
  * An `AliasingHost` which generates and consumes alias re-exports when module names for each file
76
- * are determined by a `FileToModuleHost`.
77
+ * are determined by a `UnifiedModulesHost`.
77
78
  *
78
- * When using a `FileToModuleHost`, aliasing prevents issues with transitive dependencies. See the
79
+ * When using a `UnifiedModulesHost`, aliasing prevents issues with transitive dependencies. See the
79
80
  * README.md for more details.
80
81
  */
81
- export declare class FileToModuleAliasingHost implements AliasingHost {
82
- private fileToModuleHost;
83
- constructor(fileToModuleHost: FileToModuleHost);
82
+ export declare class UnifiedModulesAliasingHost implements AliasingHost {
83
+ private unifiedModulesHost;
84
+ constructor(unifiedModulesHost: UnifiedModulesHost);
84
85
  /**
85
- * With a `FileToModuleHost`, aliases are chosen automatically without the need to look through
86
+ * With a `UnifiedModulesHost`, aliases are chosen automatically without the need to look through
86
87
  * the exports present in a .d.ts file, so we can avoid cluttering the .d.ts files.
87
88
  */
88
89
  readonly aliasExportsInDts = false;
@@ -135,5 +136,5 @@ export declare class PrivateExportAliasingHost implements AliasingHost {
135
136
  * directive or pipe, if it exists.
136
137
  */
137
138
  export declare class AliasStrategy implements ReferenceEmitStrategy {
138
- emit(ref: Reference<ts.Node>, context: ts.SourceFile, importMode: ImportMode): Expression | null;
139
+ emit(ref: Reference<ts.Node>, context: ts.SourceFile, importMode: ImportFlags): Expression | null;
139
140
  }
@@ -11,33 +11,35 @@
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/imports/src/alias", ["require", "exports", "@angular/compiler"], factory);
14
+ define("@angular/compiler-cli/src/ngtsc/imports/src/alias", ["require", "exports", "@angular/compiler", "@angular/compiler-cli/src/ngtsc/imports/src/emitter"], factory);
15
15
  }
16
16
  })(function (require, exports) {
17
17
  "use strict";
18
18
  Object.defineProperty(exports, "__esModule", { value: true });
19
19
  var compiler_1 = require("@angular/compiler");
20
+ var emitter_1 = require("@angular/compiler-cli/src/ngtsc/imports/src/emitter");
20
21
  // Escape anything that isn't alphanumeric, '/' or '_'.
21
22
  var CHARS_TO_ESCAPE = /[^a-zA-Z0-9/_]/g;
22
23
  /**
23
24
  * An `AliasingHost` which generates and consumes alias re-exports when module names for each file
24
- * are determined by a `FileToModuleHost`.
25
+ * are determined by a `UnifiedModulesHost`.
25
26
  *
26
- * When using a `FileToModuleHost`, aliasing prevents issues with transitive dependencies. See the
27
+ * When using a `UnifiedModulesHost`, aliasing prevents issues with transitive dependencies. See the
27
28
  * README.md for more details.
28
29
  */
29
- var FileToModuleAliasingHost = /** @class */ (function () {
30
- function FileToModuleAliasingHost(fileToModuleHost) {
31
- this.fileToModuleHost = fileToModuleHost;
30
+ var UnifiedModulesAliasingHost = /** @class */ (function () {
31
+ function UnifiedModulesAliasingHost(unifiedModulesHost) {
32
+ this.unifiedModulesHost = unifiedModulesHost;
32
33
  /**
33
- * With a `FileToModuleHost`, aliases are chosen automatically without the need to look through
34
+ * With a `UnifiedModulesHost`, aliases are chosen automatically without the need to look through
34
35
  * the exports present in a .d.ts file, so we can avoid cluttering the .d.ts files.
35
36
  */
36
37
  this.aliasExportsInDts = false;
37
38
  }
38
- FileToModuleAliasingHost.prototype.maybeAliasSymbolAs = function (ref, context, ngModuleName, isReExport) {
39
+ UnifiedModulesAliasingHost.prototype.maybeAliasSymbolAs = function (ref, context, ngModuleName, isReExport) {
39
40
  if (!isReExport) {
40
- // Aliasing is used with a FileToModuleHost to prevent transitive dependencies. Thus, aliases
41
+ // Aliasing is used with a UnifiedModulesHost to prevent transitive dependencies. Thus,
42
+ // aliases
41
43
  // only need to be created for directives/pipes which are not direct declarations of an
42
44
  // NgModule which exports them.
43
45
  return null;
@@ -48,29 +50,29 @@
48
50
  * Generates an `Expression` to import `decl` from `via`, assuming an export was added when `via`
49
51
  * was compiled per `maybeAliasSymbolAs` above.
50
52
  */
51
- FileToModuleAliasingHost.prototype.getAliasIn = function (decl, via, isReExport) {
53
+ UnifiedModulesAliasingHost.prototype.getAliasIn = function (decl, via, isReExport) {
52
54
  if (!isReExport) {
53
55
  // Directly exported directives/pipes don't require an alias, per the logic in
54
56
  // `maybeAliasSymbolAs`.
55
57
  return null;
56
58
  }
57
59
  // viaModule is the module it'll actually be imported from.
58
- var moduleName = this.fileToModuleHost.fileNameToModuleName(via.fileName, via.fileName);
60
+ var moduleName = this.unifiedModulesHost.fileNameToModuleName(via.fileName, via.fileName);
59
61
  return new compiler_1.ExternalExpr({ moduleName: moduleName, name: this.aliasName(decl, via) });
60
62
  };
61
63
  /**
62
64
  * Generates an alias name based on the full module name of the file which declares the aliased
63
65
  * directive/pipe.
64
66
  */
65
- FileToModuleAliasingHost.prototype.aliasName = function (decl, context) {
67
+ UnifiedModulesAliasingHost.prototype.aliasName = function (decl, context) {
66
68
  // The declared module is used to get the name of the alias.
67
- var declModule = this.fileToModuleHost.fileNameToModuleName(decl.getSourceFile().fileName, context.fileName);
69
+ var declModule = this.unifiedModulesHost.fileNameToModuleName(decl.getSourceFile().fileName, context.fileName);
68
70
  var replaced = declModule.replace(CHARS_TO_ESCAPE, '_').replace(/\//g, '$');
69
71
  return 'ɵng$' + replaced + '$$' + decl.name.text;
70
72
  };
71
- return FileToModuleAliasingHost;
73
+ return UnifiedModulesAliasingHost;
72
74
  }());
73
- exports.FileToModuleAliasingHost = FileToModuleAliasingHost;
75
+ exports.UnifiedModulesAliasingHost = UnifiedModulesAliasingHost;
74
76
  /**
75
77
  * An `AliasingHost` which exports directives from any file containing an NgModule in which they're
76
78
  * declared/exported, under a private symbol name.
@@ -141,10 +143,13 @@
141
143
  function AliasStrategy() {
142
144
  }
143
145
  AliasStrategy.prototype.emit = function (ref, context, importMode) {
146
+ if (importMode & emitter_1.ImportFlags.NoAliasing) {
147
+ return null;
148
+ }
144
149
  return ref.alias;
145
150
  };
146
151
  return AliasStrategy;
147
152
  }());
148
153
  exports.AliasStrategy = AliasStrategy;
149
154
  });
150
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"alias.js","sourceRoot":"","sources":["../../../../../../../../../packages/compiler-cli/src/ngtsc/imports/src/alias.ts"],"names":[],"mappings":"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","sourcesContent":["/**\n * @license\n * Copyright Google Inc. All Rights Reserved.\n *\n * Use of this source code is governed by an MIT-style license that can be\n * found in the LICENSE file at https://angular.io/license\n */\n\nimport {Expression, ExternalExpr} from '@angular/compiler';\nimport * as ts from 'typescript';\n\nimport {ClassDeclaration, ReflectionHost, isNamedClassDeclaration} from '../../reflection';\nimport {FileToModuleHost, ReferenceEmitStrategy} from './emitter';\nimport {ImportMode, Reference} from './references';\n\n// Escape anything that isn't alphanumeric, '/' or '_'.\nconst CHARS_TO_ESCAPE = /[^a-zA-Z0-9/_]/g;\n\n/**\n * A host for the aliasing system, which allows for alternative exports/imports of directives/pipes.\n *\n * Given an import of an NgModule (e.g. `CommonModule`), the compiler must generate imports to the\n * directives and pipes exported by this module (e.g. `NgIf`) when they're used in a particular\n * template. In its default configuration, if the compiler is not directly able to import the\n * component from another file within the same project, it will attempt to import the component\n * from the same (absolute) path by which the module was imported. So in the above example if\n * `CommonModule` was imported from '@angular/common', the compiler will attempt to import `NgIf`\n * from '@angular/common' as well.\n *\n * The aliasing system interacts with the above logic in two distinct ways.\n *\n * 1) It can be used to create \"alias\" re-exports from different files, which can be used when the\n *    user hasn't exported the directive(s) from the ES module containing the NgModule. These re-\n *    exports can also be helpful when using a `FileToModuleHost`, which overrides the import logic\n *    described above.\n *\n * 2) It can be used to get an alternative import expression for a directive or pipe, instead of\n *    the import that the normal logic would apply. The alias used depends on the provenance of the\n *    `Reference` which was obtained for the directive/pipe, which is usually a property of how it\n *    came to be in a template's scope (e.g. by which NgModule).\n *\n * See the README.md for more information on how aliasing works within the compiler.\n */\nexport interface AliasingHost {\n  /**\n   * Controls whether any alias re-exports are rendered into .d.ts files.\n   *\n   * This is not always necessary for aliasing to function correctly, so this flag allows an\n   * `AliasingHost` to avoid cluttering the .d.ts files if exports are not strictly needed.\n   */\n  readonly aliasExportsInDts: boolean;\n\n  /**\n   * Determine a name by which `decl` should be re-exported from `context`, depending on the\n   * particular set of aliasing rules in place.\n   *\n   * `maybeAliasSymbolAs` can return `null`, in which case no alias export should be generated.\n   *\n   * @param ref a `Reference` to the directive/pipe to consider for aliasing.\n   * @param context the `ts.SourceFile` in which the alias re-export might need to be generated.\n   * @param ngModuleName the declared name of the `NgModule` within `context` for which the alias\n   * would be generated.\n   * @param isReExport whether the directive/pipe under consideration is re-exported from another\n   * NgModule (as opposed to being declared by it directly).\n   */\n  maybeAliasSymbolAs(\n      ref: Reference<ClassDeclaration>, context: ts.SourceFile, ngModuleName: string,\n      isReExport: boolean): string|null;\n\n  /**\n   * Determine an `Expression` by which `decl` should be imported from `via` using an alias export\n   * (which should have been previously created when compiling `via`).\n   *\n   * `getAliasIn` can return `null`, in which case no alias is needed to import `decl` from `via`\n   * (and the normal import rules should be used).\n   *\n   * @param decl the declaration of the directive/pipe which is being imported, and which might be\n   * aliased.\n   * @param via the `ts.SourceFile` which might contain an alias to the\n   */\n  getAliasIn(decl: ClassDeclaration, via: ts.SourceFile, isReExport: boolean): Expression|null;\n}\n\n/**\n * An `AliasingHost` which generates and consumes alias re-exports when module names for each file\n * are determined by a `FileToModuleHost`.\n *\n * When using a `FileToModuleHost`, aliasing prevents issues with transitive dependencies. See the\n * README.md for more details.\n */\nexport class FileToModuleAliasingHost implements AliasingHost {\n  constructor(private fileToModuleHost: FileToModuleHost) {}\n\n  /**\n   * With a `FileToModuleHost`, aliases are chosen automatically without the need to look through\n   * the exports present in a .d.ts file, so we can avoid cluttering the .d.ts files.\n   */\n  readonly aliasExportsInDts = false;\n\n  maybeAliasSymbolAs(\n      ref: Reference<ClassDeclaration>, context: ts.SourceFile, ngModuleName: string,\n      isReExport: boolean): string|null {\n    if (!isReExport) {\n      // Aliasing is used with a FileToModuleHost to prevent transitive dependencies. Thus, aliases\n      // only need to be created for directives/pipes which are not direct declarations of an\n      // NgModule which exports them.\n      return null;\n    }\n    return this.aliasName(ref.node, context);\n  }\n\n  /**\n   * Generates an `Expression` to import `decl` from `via`, assuming an export was added when `via`\n   * was compiled per `maybeAliasSymbolAs` above.\n   */\n  getAliasIn(decl: ClassDeclaration, via: ts.SourceFile, isReExport: boolean): Expression|null {\n    if (!isReExport) {\n      // Directly exported directives/pipes don't require an alias, per the logic in\n      // `maybeAliasSymbolAs`.\n      return null;\n    }\n    // viaModule is the module it'll actually be imported from.\n    const moduleName = this.fileToModuleHost.fileNameToModuleName(via.fileName, via.fileName);\n    return new ExternalExpr({moduleName, name: this.aliasName(decl, via)});\n  }\n\n  /**\n   * Generates an alias name based on the full module name of the file which declares the aliased\n   * directive/pipe.\n   */\n  private aliasName(decl: ClassDeclaration, context: ts.SourceFile): string {\n    // The declared module is used to get the name of the alias.\n    const declModule =\n        this.fileToModuleHost.fileNameToModuleName(decl.getSourceFile().fileName, context.fileName);\n\n    const replaced = declModule.replace(CHARS_TO_ESCAPE, '_').replace(/\\//g, '$');\n    return 'ɵng$' + replaced + '$$' + decl.name.text;\n  }\n}\n\n/**\n * An `AliasingHost` which exports directives from any file containing an NgModule in which they're\n * declared/exported, under a private symbol name.\n *\n * These exports support cases where an NgModule is imported deeply from an absolute module path\n * (that is, it's not part of an Angular Package Format entrypoint), and the compiler needs to\n * import any matched directives/pipes from the same path (to the NgModule file). See README.md for\n * more details.\n */\nexport class PrivateExportAliasingHost implements AliasingHost {\n  constructor(private host: ReflectionHost) {}\n\n  /**\n   * Under private export aliasing, the `AbsoluteModuleStrategy` used for emitting references will\n   * will select aliased exports that it finds in the .d.ts file for an NgModule's file. Thus,\n   * emitting these exports in .d.ts is a requirement for the `PrivateExportAliasingHost` to\n   * function correctly.\n   */\n  readonly aliasExportsInDts = true;\n\n  maybeAliasSymbolAs(\n      ref: Reference<ClassDeclaration>, context: ts.SourceFile, ngModuleName: string): string|null {\n    if (ref.hasOwningModuleGuess) {\n      // Skip nodes that already have an associated absolute module specifier, since they can be\n      // safely imported from that specifier.\n      return null;\n    }\n    // Look for a user-provided export of `decl` in `context`. If one exists, then an alias export\n    // is not needed.\n    // TODO(alxhub): maybe add a host method to check for the existence of an export without going\n    // through the entire list of exports.\n    const exports = this.host.getExportsOfModule(context);\n    if (exports === null) {\n      // Something went wrong, and no exports were available at all. Bail rather than risk creating\n      // re-exports when they're not needed.\n      throw new Error(`Could not determine the exports of: ${context.fileName}`);\n    }\n    let found: boolean = false;\n    exports.forEach(value => {\n      if (value.node === ref.node) {\n        found = true;\n      }\n    });\n    if (found) {\n      // The module exports the declared class directly, no alias is necessary.\n      return null;\n    }\n    return `ɵngExportɵ${ngModuleName}ɵ${ref.node.name.text}`;\n  }\n\n  /**\n   * A `PrivateExportAliasingHost` only generates re-exports and does not direct the compiler to\n   * directly consume the aliases it creates.\n   *\n   * Instead, they're consumed indirectly: `AbsoluteModuleStrategy` `ReferenceEmitterStrategy` will\n   * select these alias exports automatically when looking for an export of the directive/pipe from\n   * the same path as the NgModule was imported.\n   *\n   * Thus, `getAliasIn` always returns `null`.\n   */\n  getAliasIn(): null { return null; }\n}\n\n/**\n * A `ReferenceEmitStrategy` which will consume the alias attached to a particular `Reference` to a\n * directive or pipe, if it exists.\n */\nexport class AliasStrategy implements ReferenceEmitStrategy {\n  emit(ref: Reference<ts.Node>, context: ts.SourceFile, importMode: ImportMode): Expression|null {\n    return ref.alias;\n  }\n}\n"]}
155
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"alias.js","sourceRoot":"","sources":["../../../../../../../../../packages/compiler-cli/src/ngtsc/imports/src/alias.ts"],"names":[],"mappings":"AAAA;;;;;;GAMG;;;;;;;;;;;;IAEH,8CAA2D;IAM3D,+EAA6D;IAK7D,uDAAuD;IACvD,IAAM,eAAe,GAAG,iBAAiB,CAAC;IAmE1C;;;;;;OAMG;IACH;QACE,oCAAoB,kBAAsC;YAAtC,uBAAkB,GAAlB,kBAAkB,CAAoB;YAE1D;;;eAGG;YACM,sBAAiB,GAAG,KAAK,CAAC;QAN0B,CAAC;QAQ9D,uDAAkB,GAAlB,UACI,GAAgC,EAAE,OAAsB,EAAE,YAAoB,EAC9E,UAAmB;YACrB,IAAI,CAAC,UAAU,EAAE;gBACf,uFAAuF;gBACvF,UAAU;gBACV,uFAAuF;gBACvF,+BAA+B;gBAC/B,OAAO,IAAI,CAAC;aACb;YACD,OAAO,IAAI,CAAC,SAAS,CAAC,GAAG,CAAC,IAAI,EAAE,OAAO,CAAC,CAAC;QAC3C,CAAC;QAED;;;WAGG;QACH,+CAAU,GAAV,UAAW,IAAsB,EAAE,GAAkB,EAAE,UAAmB;YACxE,IAAI,CAAC,UAAU,EAAE;gBACf,8EAA8E;gBAC9E,wBAAwB;gBACxB,OAAO,IAAI,CAAC;aACb;YACD,2DAA2D;YAC3D,IAAM,UAAU,GAAG,IAAI,CAAC,kBAAkB,CAAC,oBAAoB,CAAC,GAAG,CAAC,QAAQ,EAAE,GAAG,CAAC,QAAQ,CAAC,CAAC;YAC5F,OAAO,IAAI,uBAAY,CAAC,EAAC,UAAU,YAAA,EAAE,IAAI,EAAE,IAAI,CAAC,SAAS,CAAC,IAAI,EAAE,GAAG,CAAC,EAAC,CAAC,CAAC;QACzE,CAAC;QAED;;;WAGG;QACK,8CAAS,GAAjB,UAAkB,IAAsB,EAAE,OAAsB;YAC9D,4DAA4D;YAC5D,IAAM,UAAU,GAAG,IAAI,CAAC,kBAAkB,CAAC,oBAAoB,CAC3D,IAAI,CAAC,aAAa,EAAE,CAAC,QAAQ,EAAE,OAAO,CAAC,QAAQ,CAAC,CAAC;YAErD,IAAM,QAAQ,GAAG,UAAU,CAAC,OAAO,CAAC,eAAe,EAAE,GAAG,CAAC,CAAC,OAAO,CAAC,KAAK,EAAE,GAAG,CAAC,CAAC;YAC9E,OAAO,MAAM,GAAG,QAAQ,GAAG,IAAI,GAAG,IAAI,CAAC,IAAI,CAAC,IAAI,CAAC;QACnD,CAAC;QACH,iCAAC;IAAD,CAAC,AAjDD,IAiDC;IAjDY,gEAA0B;IAmDvC;;;;;;;;OAQG;IACH;QACE,mCAAoB,IAAoB;YAApB,SAAI,GAAJ,IAAI,CAAgB;YAExC;;;;;eAKG;YACM,sBAAiB,GAAG,IAAI,CAAC;QARS,CAAC;QAU5C,sDAAkB,GAAlB,UACI,GAAgC,EAAE,OAAsB,EAAE,YAAoB;YAChF,IAAI,GAAG,CAAC,oBAAoB,EAAE;gBAC5B,0FAA0F;gBAC1F,uCAAuC;gBACvC,OAAO,IAAI,CAAC;aACb;YACD,8FAA8F;YAC9F,iBAAiB;YACjB,8FAA8F;YAC9F,sCAAsC;YACtC,IAAM,OAAO,GAAG,IAAI,CAAC,IAAI,CAAC,kBAAkB,CAAC,OAAO,CAAC,CAAC;YACtD,IAAI,OAAO,KAAK,IAAI,EAAE;gBACpB,6FAA6F;gBAC7F,sCAAsC;gBACtC,MAAM,IAAI,KAAK,CAAC,yCAAuC,OAAO,CAAC,QAAU,CAAC,CAAC;aAC5E;YACD,IAAI,KAAK,GAAY,KAAK,CAAC;YAC3B,OAAO,CAAC,OAAO,CAAC,UAAA,KAAK;gBACnB,IAAI,KAAK,CAAC,IAAI,KAAK,GAAG,CAAC,IAAI,EAAE;oBAC3B,KAAK,GAAG,IAAI,CAAC;iBACd;YACH,CAAC,CAAC,CAAC;YACH,IAAI,KAAK,EAAE;gBACT,yEAAyE;gBACzE,OAAO,IAAI,CAAC;aACb;YACD,OAAO,yBAAa,YAAY,cAAI,GAAG,CAAC,IAAI,CAAC,IAAI,CAAC,IAAM,CAAC;QAC3D,CAAC;QAED;;;;;;;;;WASG;QACH,8CAAU,GAAV,cAAqB,OAAO,IAAI,CAAC,CAAC,CAAC;QACrC,gCAAC;IAAD,CAAC,AApDD,IAoDC;IApDY,8DAAyB;IAsDtC;;;OAGG;IACH;QAAA;QAQA,CAAC;QAPC,4BAAI,GAAJ,UAAK,GAAuB,EAAE,OAAsB,EAAE,UAAuB;YAC3E,IAAI,UAAU,GAAG,qBAAW,CAAC,UAAU,EAAE;gBACvC,OAAO,IAAI,CAAC;aACb;YAED,OAAO,GAAG,CAAC,KAAK,CAAC;QACnB,CAAC;QACH,oBAAC;IAAD,CAAC,AARD,IAQC;IARY,sCAAa","sourcesContent":["/**\n * @license\n * Copyright Google Inc. All Rights Reserved.\n *\n * Use of this source code is governed by an MIT-style license that can be\n * found in the LICENSE file at https://angular.io/license\n */\n\nimport {Expression, ExternalExpr} from '@angular/compiler';\nimport * as ts from 'typescript';\n\nimport {UnifiedModulesHost} from '../../core/api';\nimport {ClassDeclaration, ReflectionHost, isNamedClassDeclaration} from '../../reflection';\n\nimport {ImportFlags, ReferenceEmitStrategy} from './emitter';\nimport {Reference} from './references';\n\n\n\n// Escape anything that isn't alphanumeric, '/' or '_'.\nconst CHARS_TO_ESCAPE = /[^a-zA-Z0-9/_]/g;\n\n/**\n * A host for the aliasing system, which allows for alternative exports/imports of directives/pipes.\n *\n * Given an import of an NgModule (e.g. `CommonModule`), the compiler must generate imports to the\n * directives and pipes exported by this module (e.g. `NgIf`) when they're used in a particular\n * template. In its default configuration, if the compiler is not directly able to import the\n * component from another file within the same project, it will attempt to import the component\n * from the same (absolute) path by which the module was imported. So in the above example if\n * `CommonModule` was imported from '@angular/common', the compiler will attempt to import `NgIf`\n * from '@angular/common' as well.\n *\n * The aliasing system interacts with the above logic in two distinct ways.\n *\n * 1) It can be used to create \"alias\" re-exports from different files, which can be used when the\n *    user hasn't exported the directive(s) from the ES module containing the NgModule. These re-\n *    exports can also be helpful when using a `UnifiedModulesHost`, which overrides the import\n *    logic described above.\n *\n * 2) It can be used to get an alternative import expression for a directive or pipe, instead of\n *    the import that the normal logic would apply. The alias used depends on the provenance of the\n *    `Reference` which was obtained for the directive/pipe, which is usually a property of how it\n *    came to be in a template's scope (e.g. by which NgModule).\n *\n * See the README.md for more information on how aliasing works within the compiler.\n */\nexport interface AliasingHost {\n  /**\n   * Controls whether any alias re-exports are rendered into .d.ts files.\n   *\n   * This is not always necessary for aliasing to function correctly, so this flag allows an\n   * `AliasingHost` to avoid cluttering the .d.ts files if exports are not strictly needed.\n   */\n  readonly aliasExportsInDts: boolean;\n\n  /**\n   * Determine a name by which `decl` should be re-exported from `context`, depending on the\n   * particular set of aliasing rules in place.\n   *\n   * `maybeAliasSymbolAs` can return `null`, in which case no alias export should be generated.\n   *\n   * @param ref a `Reference` to the directive/pipe to consider for aliasing.\n   * @param context the `ts.SourceFile` in which the alias re-export might need to be generated.\n   * @param ngModuleName the declared name of the `NgModule` within `context` for which the alias\n   * would be generated.\n   * @param isReExport whether the directive/pipe under consideration is re-exported from another\n   * NgModule (as opposed to being declared by it directly).\n   */\n  maybeAliasSymbolAs(\n      ref: Reference<ClassDeclaration>, context: ts.SourceFile, ngModuleName: string,\n      isReExport: boolean): string|null;\n\n  /**\n   * Determine an `Expression` by which `decl` should be imported from `via` using an alias export\n   * (which should have been previously created when compiling `via`).\n   *\n   * `getAliasIn` can return `null`, in which case no alias is needed to import `decl` from `via`\n   * (and the normal import rules should be used).\n   *\n   * @param decl the declaration of the directive/pipe which is being imported, and which might be\n   * aliased.\n   * @param via the `ts.SourceFile` which might contain an alias to the\n   */\n  getAliasIn(decl: ClassDeclaration, via: ts.SourceFile, isReExport: boolean): Expression|null;\n}\n\n/**\n * An `AliasingHost` which generates and consumes alias re-exports when module names for each file\n * are determined by a `UnifiedModulesHost`.\n *\n * When using a `UnifiedModulesHost`, aliasing prevents issues with transitive dependencies. See the\n * README.md for more details.\n */\nexport class UnifiedModulesAliasingHost implements AliasingHost {\n  constructor(private unifiedModulesHost: UnifiedModulesHost) {}\n\n  /**\n   * With a `UnifiedModulesHost`, aliases are chosen automatically without the need to look through\n   * the exports present in a .d.ts file, so we can avoid cluttering the .d.ts files.\n   */\n  readonly aliasExportsInDts = false;\n\n  maybeAliasSymbolAs(\n      ref: Reference<ClassDeclaration>, context: ts.SourceFile, ngModuleName: string,\n      isReExport: boolean): string|null {\n    if (!isReExport) {\n      // Aliasing is used with a UnifiedModulesHost to prevent transitive dependencies. Thus,\n      // aliases\n      // only need to be created for directives/pipes which are not direct declarations of an\n      // NgModule which exports them.\n      return null;\n    }\n    return this.aliasName(ref.node, context);\n  }\n\n  /**\n   * Generates an `Expression` to import `decl` from `via`, assuming an export was added when `via`\n   * was compiled per `maybeAliasSymbolAs` above.\n   */\n  getAliasIn(decl: ClassDeclaration, via: ts.SourceFile, isReExport: boolean): Expression|null {\n    if (!isReExport) {\n      // Directly exported directives/pipes don't require an alias, per the logic in\n      // `maybeAliasSymbolAs`.\n      return null;\n    }\n    // viaModule is the module it'll actually be imported from.\n    const moduleName = this.unifiedModulesHost.fileNameToModuleName(via.fileName, via.fileName);\n    return new ExternalExpr({moduleName, name: this.aliasName(decl, via)});\n  }\n\n  /**\n   * Generates an alias name based on the full module name of the file which declares the aliased\n   * directive/pipe.\n   */\n  private aliasName(decl: ClassDeclaration, context: ts.SourceFile): string {\n    // The declared module is used to get the name of the alias.\n    const declModule = this.unifiedModulesHost.fileNameToModuleName(\n        decl.getSourceFile().fileName, context.fileName);\n\n    const replaced = declModule.replace(CHARS_TO_ESCAPE, '_').replace(/\\//g, '$');\n    return 'ɵng$' + replaced + '$$' + decl.name.text;\n  }\n}\n\n/**\n * An `AliasingHost` which exports directives from any file containing an NgModule in which they're\n * declared/exported, under a private symbol name.\n *\n * These exports support cases where an NgModule is imported deeply from an absolute module path\n * (that is, it's not part of an Angular Package Format entrypoint), and the compiler needs to\n * import any matched directives/pipes from the same path (to the NgModule file). See README.md for\n * more details.\n */\nexport class PrivateExportAliasingHost implements AliasingHost {\n  constructor(private host: ReflectionHost) {}\n\n  /**\n   * Under private export aliasing, the `AbsoluteModuleStrategy` used for emitting references will\n   * will select aliased exports that it finds in the .d.ts file for an NgModule's file. Thus,\n   * emitting these exports in .d.ts is a requirement for the `PrivateExportAliasingHost` to\n   * function correctly.\n   */\n  readonly aliasExportsInDts = true;\n\n  maybeAliasSymbolAs(\n      ref: Reference<ClassDeclaration>, context: ts.SourceFile, ngModuleName: string): string|null {\n    if (ref.hasOwningModuleGuess) {\n      // Skip nodes that already have an associated absolute module specifier, since they can be\n      // safely imported from that specifier.\n      return null;\n    }\n    // Look for a user-provided export of `decl` in `context`. If one exists, then an alias export\n    // is not needed.\n    // TODO(alxhub): maybe add a host method to check for the existence of an export without going\n    // through the entire list of exports.\n    const exports = this.host.getExportsOfModule(context);\n    if (exports === null) {\n      // Something went wrong, and no exports were available at all. Bail rather than risk creating\n      // re-exports when they're not needed.\n      throw new Error(`Could not determine the exports of: ${context.fileName}`);\n    }\n    let found: boolean = false;\n    exports.forEach(value => {\n      if (value.node === ref.node) {\n        found = true;\n      }\n    });\n    if (found) {\n      // The module exports the declared class directly, no alias is necessary.\n      return null;\n    }\n    return `ɵngExportɵ${ngModuleName}ɵ${ref.node.name.text}`;\n  }\n\n  /**\n   * A `PrivateExportAliasingHost` only generates re-exports and does not direct the compiler to\n   * directly consume the aliases it creates.\n   *\n   * Instead, they're consumed indirectly: `AbsoluteModuleStrategy` `ReferenceEmitterStrategy` will\n   * select these alias exports automatically when looking for an export of the directive/pipe from\n   * the same path as the NgModule was imported.\n   *\n   * Thus, `getAliasIn` always returns `null`.\n   */\n  getAliasIn(): null { return null; }\n}\n\n/**\n * A `ReferenceEmitStrategy` which will consume the alias attached to a particular `Reference` to a\n * directive or pipe, if it exists.\n */\nexport class AliasStrategy implements ReferenceEmitStrategy {\n  emit(ref: Reference<ts.Node>, context: ts.SourceFile, importMode: ImportFlags): Expression|null {\n    if (importMode & ImportFlags.NoAliasing) {\n      return null;\n    }\n\n    return ref.alias;\n  }\n}\n"]}
@@ -8,17 +8,38 @@
8
8
  */
9
9
  import { Expression } from '@angular/compiler';
10
10
  import * as ts from 'typescript';
11
+ import { UnifiedModulesHost } from '../../core/api';
11
12
  import { LogicalFileSystem } from '../../file_system';
12
13
  import { ReflectionHost } from '../../reflection';
13
- import { ImportMode, Reference } from './references';
14
+ import { Reference } from './references';
15
+ import { ModuleResolver } from './resolver';
14
16
  /**
15
- * A host which supports an operation to convert a file name into a module name.
16
- *
17
- * This operation is typically implemented as part of the compiler host passed to ngtsc when running
18
- * under a build tool like Bazel or Blaze.
17
+ * Flags which alter the imports generated by the `ReferenceEmitter`.
19
18
  */
20
- export interface FileToModuleHost {
21
- fileNameToModuleName(importedFilePath: string, containingFilePath: string): string;
19
+ export declare enum ImportFlags {
20
+ None = 0,
21
+ /**
22
+ * Force the generation of a new import when generating a reference, even if an identifier already
23
+ * exists in the target file which could be used instead.
24
+ *
25
+ * This is sometimes required if there's a risk TypeScript might remove imports during emit.
26
+ */
27
+ ForceNewImport = 1,
28
+ /**
29
+ * Don't make use of any aliasing information when emitting a reference.
30
+ *
31
+ * This is sometimes required if emitting into a context where generated references will be fed
32
+ * into TypeScript and type-checked (such as in template type-checking).
33
+ */
34
+ NoAliasing = 2,
35
+ /**
36
+ * Indicates that an import to a type-only declaration is allowed.
37
+ *
38
+ * For references that occur in type-positions, the referred declaration may be a type-only
39
+ * declaration that is not retained during emit. Including this flag allows to emit references to
40
+ * type-only declarations as used in e.g. template type-checking.
41
+ */
42
+ AllowTypeImports = 4
22
43
  }
23
44
  /**
24
45
  * A particular strategy for generating an expression which refers to a `Reference`.
@@ -39,10 +60,10 @@ export interface ReferenceEmitStrategy {
39
60
  *
40
61
  * @param ref the `Reference` for which to generate an expression
41
62
  * @param context the source file in which the `Expression` must be valid
42
- * @param importMode a flag which controls whether imports should be generated or not
63
+ * @param importFlags a flag which controls whether imports should be generated or not
43
64
  * @returns an `Expression` which refers to the `Reference`, or `null` if none can be generated
44
65
  */
45
- emit(ref: Reference, context: ts.SourceFile, importMode: ImportMode): Expression | null;
66
+ emit(ref: Reference, context: ts.SourceFile, importFlags: ImportFlags): Expression | null;
46
67
  }
47
68
  /**
48
69
  * Generates `Expression`s which refer to `Reference`s in a given context.
@@ -53,14 +74,14 @@ export interface ReferenceEmitStrategy {
53
74
  export declare class ReferenceEmitter {
54
75
  private strategies;
55
76
  constructor(strategies: ReferenceEmitStrategy[]);
56
- emit(ref: Reference, context: ts.SourceFile, importMode?: ImportMode): Expression;
77
+ emit(ref: Reference, context: ts.SourceFile, importFlags?: ImportFlags): Expression;
57
78
  }
58
79
  /**
59
80
  * A `ReferenceEmitStrategy` which will refer to declarations by any local `ts.Identifier`s, if
60
81
  * such identifiers are available.
61
82
  */
62
83
  export declare class LocalIdentifierStrategy implements ReferenceEmitStrategy {
63
- emit(ref: Reference<ts.Node>, context: ts.SourceFile, importMode: ImportMode): Expression | null;
84
+ emit(ref: Reference<ts.Node>, context: ts.SourceFile, importFlags: ImportFlags): Expression | null;
64
85
  }
65
86
  /**
66
87
  * A `ReferenceEmitStrategy` which will refer to declarations that come from `node_modules` using
@@ -74,16 +95,15 @@ export declare class LocalIdentifierStrategy implements ReferenceEmitStrategy {
74
95
  export declare class AbsoluteModuleStrategy implements ReferenceEmitStrategy {
75
96
  protected program: ts.Program;
76
97
  protected checker: ts.TypeChecker;
77
- protected options: ts.CompilerOptions;
78
- protected host: ts.CompilerHost;
98
+ protected moduleResolver: ModuleResolver;
79
99
  private reflectionHost;
80
100
  /**
81
101
  * A cache of the exports of specific modules, because resolving a module to its exports is a
82
102
  * costly operation.
83
103
  */
84
104
  private moduleExportsCache;
85
- constructor(program: ts.Program, checker: ts.TypeChecker, options: ts.CompilerOptions, host: ts.CompilerHost, reflectionHost: ReflectionHost);
86
- emit(ref: Reference<ts.Node>, context: ts.SourceFile, importMode: ImportMode): Expression | null;
105
+ constructor(program: ts.Program, checker: ts.TypeChecker, moduleResolver: ModuleResolver, reflectionHost: ReflectionHost);
106
+ emit(ref: Reference<ts.Node>, context: ts.SourceFile, importFlags: ImportFlags): Expression | null;
87
107
  private resolveImportName;
88
108
  private getExportsOfModule;
89
109
  protected enumerateExportsOfModule(specifier: string, fromFile: string): Map<ts.Declaration, string> | null;
@@ -114,11 +134,12 @@ export declare class RelativePathStrategy implements ReferenceEmitStrategy {
114
134
  emit(ref: Reference<ts.Node>, context: ts.SourceFile): Expression | null;
115
135
  }
116
136
  /**
117
- * A `ReferenceEmitStrategy` which uses a `FileToModuleHost` to generate absolute import references.
137
+ * A `ReferenceEmitStrategy` which uses a `UnifiedModulesHost` to generate absolute import
138
+ * references.
118
139
  */
119
- export declare class FileToModuleStrategy implements ReferenceEmitStrategy {
140
+ export declare class UnifiedModulesStrategy implements ReferenceEmitStrategy {
120
141
  private reflector;
121
- private fileToModuleHost;
122
- constructor(reflector: ReflectionHost, fileToModuleHost: FileToModuleHost);
142
+ private unifiedModulesHost;
143
+ constructor(reflector: ReflectionHost, unifiedModulesHost: UnifiedModulesHost);
123
144
  emit(ref: Reference<ts.Node>, context: ts.SourceFile): Expression | null;
124
145
  }
@@ -4,7 +4,7 @@
4
4
  if (v !== undefined) module.exports = v;
5
5
  }
6
6
  else if (typeof define === "function" && define.amd) {
7
- define("@angular/compiler-cli/src/ngtsc/imports/src/emitter", ["require", "exports", "tslib", "@angular/compiler", "@angular/compiler-cli/src/ngtsc/file_system", "@angular/compiler-cli/src/ngtsc/file_system/src/util", "@angular/compiler-cli/src/ngtsc/util/src/typescript", "@angular/compiler-cli/src/ngtsc/imports/src/find_export", "@angular/compiler-cli/src/ngtsc/imports/src/references"], factory);
7
+ define("@angular/compiler-cli/src/ngtsc/imports/src/emitter", ["require", "exports", "tslib", "@angular/compiler", "typescript", "@angular/compiler-cli/src/ngtsc/file_system", "@angular/compiler-cli/src/ngtsc/file_system/src/util", "@angular/compiler-cli/src/ngtsc/util/src/typescript", "@angular/compiler-cli/src/ngtsc/imports/src/find_export"], factory);
8
8
  }
9
9
  })(function (require, exports) {
10
10
  "use strict";
@@ -18,11 +18,40 @@
18
18
  * found in the LICENSE file at https://angular.io/license
19
19
  */
20
20
  var compiler_1 = require("@angular/compiler");
21
+ var ts = require("typescript");
21
22
  var file_system_1 = require("@angular/compiler-cli/src/ngtsc/file_system");
22
23
  var util_1 = require("@angular/compiler-cli/src/ngtsc/file_system/src/util");
23
24
  var typescript_1 = require("@angular/compiler-cli/src/ngtsc/util/src/typescript");
24
25
  var find_export_1 = require("@angular/compiler-cli/src/ngtsc/imports/src/find_export");
25
- var references_1 = require("@angular/compiler-cli/src/ngtsc/imports/src/references");
26
+ /**
27
+ * Flags which alter the imports generated by the `ReferenceEmitter`.
28
+ */
29
+ var ImportFlags;
30
+ (function (ImportFlags) {
31
+ ImportFlags[ImportFlags["None"] = 0] = "None";
32
+ /**
33
+ * Force the generation of a new import when generating a reference, even if an identifier already
34
+ * exists in the target file which could be used instead.
35
+ *
36
+ * This is sometimes required if there's a risk TypeScript might remove imports during emit.
37
+ */
38
+ ImportFlags[ImportFlags["ForceNewImport"] = 1] = "ForceNewImport";
39
+ /**
40
+ * Don't make use of any aliasing information when emitting a reference.
41
+ *
42
+ * This is sometimes required if emitting into a context where generated references will be fed
43
+ * into TypeScript and type-checked (such as in template type-checking).
44
+ */
45
+ ImportFlags[ImportFlags["NoAliasing"] = 2] = "NoAliasing";
46
+ /**
47
+ * Indicates that an import to a type-only declaration is allowed.
48
+ *
49
+ * For references that occur in type-positions, the referred declaration may be a type-only
50
+ * declaration that is not retained during emit. Including this flag allows to emit references to
51
+ * type-only declarations as used in e.g. template type-checking.
52
+ */
53
+ ImportFlags[ImportFlags["AllowTypeImports"] = 4] = "AllowTypeImports";
54
+ })(ImportFlags = exports.ImportFlags || (exports.ImportFlags = {}));
26
55
  /**
27
56
  * Generates `Expression`s which refer to `Reference`s in a given context.
28
57
  *
@@ -33,13 +62,13 @@
33
62
  function ReferenceEmitter(strategies) {
34
63
  this.strategies = strategies;
35
64
  }
36
- ReferenceEmitter.prototype.emit = function (ref, context, importMode) {
65
+ ReferenceEmitter.prototype.emit = function (ref, context, importFlags) {
37
66
  var e_1, _a;
38
- if (importMode === void 0) { importMode = references_1.ImportMode.UseExistingImport; }
67
+ if (importFlags === void 0) { importFlags = ImportFlags.None; }
39
68
  try {
40
69
  for (var _b = tslib_1.__values(this.strategies), _c = _b.next(); !_c.done; _c = _b.next()) {
41
70
  var strategy = _c.value;
42
- var emitted = strategy.emit(ref, context, importMode);
71
+ var emitted = strategy.emit(ref, context, importFlags);
43
72
  if (emitted !== null) {
44
73
  return emitted;
45
74
  }
@@ -64,10 +93,10 @@
64
93
  var LocalIdentifierStrategy = /** @class */ (function () {
65
94
  function LocalIdentifierStrategy() {
66
95
  }
67
- LocalIdentifierStrategy.prototype.emit = function (ref, context, importMode) {
96
+ LocalIdentifierStrategy.prototype.emit = function (ref, context, importFlags) {
68
97
  // If the emitter has specified ForceNewImport, then LocalIdentifierStrategy should not use a
69
98
  // local identifier at all, *except* in the source file where the node is actually declared.
70
- if (importMode === references_1.ImportMode.ForceNewImport &&
99
+ if (importFlags & ImportFlags.ForceNewImport &&
71
100
  typescript_1.getSourceFile(ref.node) !== typescript_1.getSourceFile(context)) {
72
101
  return null;
73
102
  }
@@ -94,11 +123,10 @@
94
123
  * which maps back to the original directive, an error is thrown.
95
124
  */
96
125
  var AbsoluteModuleStrategy = /** @class */ (function () {
97
- function AbsoluteModuleStrategy(program, checker, options, host, reflectionHost) {
126
+ function AbsoluteModuleStrategy(program, checker, moduleResolver, reflectionHost) {
98
127
  this.program = program;
99
128
  this.checker = checker;
100
- this.options = options;
101
- this.host = host;
129
+ this.moduleResolver = moduleResolver;
102
130
  this.reflectionHost = reflectionHost;
103
131
  /**
104
132
  * A cache of the exports of specific modules, because resolving a module to its exports is a
@@ -106,7 +134,7 @@
106
134
  */
107
135
  this.moduleExportsCache = new Map();
108
136
  }
109
- AbsoluteModuleStrategy.prototype.emit = function (ref, context, importMode) {
137
+ AbsoluteModuleStrategy.prototype.emit = function (ref, context, importFlags) {
110
138
  if (ref.bestGuessOwningModule === null) {
111
139
  // There is no module name available for this Reference, meaning it was arrived at via a
112
140
  // relative path.
@@ -114,7 +142,10 @@
114
142
  }
115
143
  else if (!typescript_1.isDeclaration(ref.node)) {
116
144
  // It's not possible to import something which isn't a declaration.
117
- throw new Error('Debug assert: importing a Reference to non-declaration?');
145
+ throw new Error("Debug assert: unable to import a Reference to non-declaration of type " + ts.SyntaxKind[ref.node.kind] + ".");
146
+ }
147
+ else if ((importFlags & ImportFlags.AllowTypeImports) === 0 && typescript_1.isTypeDeclaration(ref.node)) {
148
+ throw new Error("Importing a type-only declaration of type " + ts.SyntaxKind[ref.node.kind] + " in a value position is not allowed.");
118
149
  }
119
150
  // Try to find the exported name of the declaration, if one is available.
120
151
  var _a = ref.bestGuessOwningModule, specifier = _a.specifier, resolutionContext = _a.resolutionContext;
@@ -143,11 +174,7 @@
143
174
  };
144
175
  AbsoluteModuleStrategy.prototype.enumerateExportsOfModule = function (specifier, fromFile) {
145
176
  // First, resolve the module specifier to its entry point, and get the ts.Symbol for it.
146
- var resolvedModule = typescript_1.resolveModuleName(specifier, fromFile, this.options, this.host);
147
- if (resolvedModule === undefined) {
148
- return null;
149
- }
150
- var entryPointFile = typescript_1.getSourceFileOrNull(this.program, file_system_1.absoluteFrom(resolvedModule.resolvedFileName));
177
+ var entryPointFile = this.moduleResolver.resolveModule(specifier, fromFile);
151
178
  if (entryPointFile === null) {
152
179
  return null;
153
180
  }
@@ -234,24 +261,25 @@
234
261
  }());
235
262
  exports.RelativePathStrategy = RelativePathStrategy;
236
263
  /**
237
- * A `ReferenceEmitStrategy` which uses a `FileToModuleHost` to generate absolute import references.
264
+ * A `ReferenceEmitStrategy` which uses a `UnifiedModulesHost` to generate absolute import
265
+ * references.
238
266
  */
239
- var FileToModuleStrategy = /** @class */ (function () {
240
- function FileToModuleStrategy(reflector, fileToModuleHost) {
267
+ var UnifiedModulesStrategy = /** @class */ (function () {
268
+ function UnifiedModulesStrategy(reflector, unifiedModulesHost) {
241
269
  this.reflector = reflector;
242
- this.fileToModuleHost = fileToModuleHost;
270
+ this.unifiedModulesHost = unifiedModulesHost;
243
271
  }
244
- FileToModuleStrategy.prototype.emit = function (ref, context) {
272
+ UnifiedModulesStrategy.prototype.emit = function (ref, context) {
245
273
  var destSf = typescript_1.getSourceFile(ref.node);
246
274
  var name = find_export_1.findExportedNameOfNode(ref.node, destSf, this.reflector);
247
275
  if (name === null) {
248
276
  return null;
249
277
  }
250
- var moduleName = this.fileToModuleHost.fileNameToModuleName(destSf.fileName, context.fileName);
278
+ var moduleName = this.unifiedModulesHost.fileNameToModuleName(destSf.fileName, context.fileName);
251
279
  return new compiler_1.ExternalExpr({ moduleName: moduleName, name: name });
252
280
  };
253
- return FileToModuleStrategy;
281
+ return UnifiedModulesStrategy;
254
282
  }());
255
- exports.FileToModuleStrategy = FileToModuleStrategy;
283
+ exports.UnifiedModulesStrategy = UnifiedModulesStrategy;
256
284
  });
257
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"emitter.js","sourceRoot":"","sources":["../../../../../../../../../packages/compiler-cli/src/ngtsc/imports/src/emitter.ts"],"names":[],"mappings":"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","sourcesContent":["/**\n * @license\n * Copyright Google Inc. All Rights Reserved.\n *\n * Use of this source code is governed by an MIT-style license that can be\n * found in the LICENSE file at https://angular.io/license\n */\nimport {Expression, ExternalExpr, ExternalReference, WrappedNodeExpr} from '@angular/compiler';\nimport * as ts from 'typescript';\n\nimport {LogicalFileSystem, LogicalProjectPath, PathSegment, absoluteFrom, absoluteFromSourceFile, basename, dirname, relative, resolve} from '../../file_system';\nimport {stripExtension} from '../../file_system/src/util';\nimport {ReflectionHost} from '../../reflection';\nimport {getSourceFile, getSourceFileOrNull, isDeclaration, nodeNameForError, resolveModuleName} from '../../util/src/typescript';\n\nimport {findExportedNameOfNode} from './find_export';\nimport {ImportMode, Reference} from './references';\n\n\n\n/**\n * A host which supports an operation to convert a file name into a module name.\n *\n * This operation is typically implemented as part of the compiler host passed to ngtsc when running\n * under a build tool like Bazel or Blaze.\n */\nexport interface FileToModuleHost {\n  fileNameToModuleName(importedFilePath: string, containingFilePath: string): string;\n}\n\n/**\n * A particular strategy for generating an expression which refers to a `Reference`.\n *\n * There are many potential ways a given `Reference` could be referred to in the context of a given\n * file. A local declaration could be available, the `Reference` could be importable via a relative\n * import within the project, or an absolute import into `node_modules` might be necessary.\n *\n * Different `ReferenceEmitStrategy` implementations implement specific logic for generating such\n * references. A single strategy (such as using a local declaration) may not always be able to\n * generate an expression for every `Reference` (for example, if no local identifier is available),\n * and may return `null` in such a case.\n */\nexport interface ReferenceEmitStrategy {\n  /**\n   * Emit an `Expression` which refers to the given `Reference` in the context of a particular\n   * source file, if possible.\n   *\n   * @param ref the `Reference` for which to generate an expression\n   * @param context the source file in which the `Expression` must be valid\n   * @param importMode a flag which controls whether imports should be generated or not\n   * @returns an `Expression` which refers to the `Reference`, or `null` if none can be generated\n   */\n  emit(ref: Reference, context: ts.SourceFile, importMode: ImportMode): Expression|null;\n}\n\n/**\n * Generates `Expression`s which refer to `Reference`s in a given context.\n *\n * A `ReferenceEmitter` uses one or more `ReferenceEmitStrategy` implementations to produce an\n * `Expression` which refers to a `Reference` in the context of a particular file.\n */\nexport class ReferenceEmitter {\n  constructor(private strategies: ReferenceEmitStrategy[]) {}\n\n  emit(\n      ref: Reference, context: ts.SourceFile,\n      importMode: ImportMode = ImportMode.UseExistingImport): Expression {\n    for (const strategy of this.strategies) {\n      const emitted = strategy.emit(ref, context, importMode);\n      if (emitted !== null) {\n        return emitted;\n      }\n    }\n    throw new Error(\n        `Unable to write a reference to ${nodeNameForError(ref.node)} in ${ref.node.getSourceFile().fileName} from ${context.fileName}`);\n  }\n}\n\n/**\n * A `ReferenceEmitStrategy` which will refer to declarations by any local `ts.Identifier`s, if\n * such identifiers are available.\n */\nexport class LocalIdentifierStrategy implements ReferenceEmitStrategy {\n  emit(ref: Reference<ts.Node>, context: ts.SourceFile, importMode: ImportMode): Expression|null {\n    // If the emitter has specified ForceNewImport, then LocalIdentifierStrategy should not use a\n    // local identifier at all, *except* in the source file where the node is actually declared.\n    if (importMode === ImportMode.ForceNewImport &&\n        getSourceFile(ref.node) !== getSourceFile(context)) {\n      return null;\n    }\n\n    // A Reference can have multiple identities in different files, so it may already have an\n    // Identifier in the requested context file.\n    const identifier = ref.getIdentityIn(context);\n    if (identifier !== null) {\n      return new WrappedNodeExpr(identifier);\n    } else {\n      return null;\n    }\n  }\n}\n\n/**\n * A `ReferenceEmitStrategy` which will refer to declarations that come from `node_modules` using\n * an absolute import.\n *\n * Part of this strategy involves looking at the target entry point and identifying the exported\n * name of the targeted declaration, as it might be different from the declared name (e.g. a\n * directive might be declared as FooDirImpl, but exported as FooDir). If no export can be found\n * which maps back to the original directive, an error is thrown.\n */\nexport class AbsoluteModuleStrategy implements ReferenceEmitStrategy {\n  /**\n   * A cache of the exports of specific modules, because resolving a module to its exports is a\n   * costly operation.\n   */\n  private moduleExportsCache = new Map<string, Map<ts.Declaration, string>|null>();\n\n  constructor(\n      protected program: ts.Program, protected checker: ts.TypeChecker,\n      protected options: ts.CompilerOptions, protected host: ts.CompilerHost,\n      private reflectionHost: ReflectionHost) {}\n\n  emit(ref: Reference<ts.Node>, context: ts.SourceFile, importMode: ImportMode): Expression|null {\n    if (ref.bestGuessOwningModule === null) {\n      // There is no module name available for this Reference, meaning it was arrived at via a\n      // relative path.\n      return null;\n    } else if (!isDeclaration(ref.node)) {\n      // It's not possible to import something which isn't a declaration.\n      throw new Error('Debug assert: importing a Reference to non-declaration?');\n    }\n\n    // Try to find the exported name of the declaration, if one is available.\n    const {specifier, resolutionContext} = ref.bestGuessOwningModule;\n    const symbolName = this.resolveImportName(specifier, ref.node, resolutionContext);\n    if (symbolName === null) {\n      // TODO(alxhub): make this error a ts.Diagnostic pointing at whatever caused this import to be\n      // triggered.\n      throw new Error(\n          `Symbol ${ref.debugName} declared in ${getSourceFile(ref.node).fileName} is not exported from ${specifier} (import into ${context.fileName})`);\n    }\n\n    return new ExternalExpr(new ExternalReference(specifier, symbolName));\n  }\n\n  private resolveImportName(moduleName: string, target: ts.Declaration, fromFile: string): string\n      |null {\n    const exports = this.getExportsOfModule(moduleName, fromFile);\n    if (exports !== null && exports.has(target)) {\n      return exports.get(target) !;\n    } else {\n      return null;\n    }\n  }\n\n  private getExportsOfModule(moduleName: string, fromFile: string):\n      Map<ts.Declaration, string>|null {\n    if (!this.moduleExportsCache.has(moduleName)) {\n      this.moduleExportsCache.set(moduleName, this.enumerateExportsOfModule(moduleName, fromFile));\n    }\n    return this.moduleExportsCache.get(moduleName) !;\n  }\n\n  protected enumerateExportsOfModule(specifier: string, fromFile: string):\n      Map<ts.Declaration, string>|null {\n    // First, resolve the module specifier to its entry point, and get the ts.Symbol for it.\n    const resolvedModule = resolveModuleName(specifier, fromFile, this.options, this.host);\n    if (resolvedModule === undefined) {\n      return null;\n    }\n\n    const entryPointFile =\n        getSourceFileOrNull(this.program, absoluteFrom(resolvedModule.resolvedFileName));\n    if (entryPointFile === null) {\n      return null;\n    }\n\n    const exports = this.reflectionHost.getExportsOfModule(entryPointFile);\n    if (exports === null) {\n      return null;\n    }\n    const exportMap = new Map<ts.Declaration, string>();\n    exports.forEach((declaration, name) => {\n      // It's okay to skip inline declarations, since by definition they're not target-able with a\n      // ts.Declaration anyway.\n      if (declaration.node !== null) {\n        exportMap.set(declaration.node, name);\n      }\n    });\n    return exportMap;\n  }\n}\n\n/**\n * A `ReferenceEmitStrategy` which will refer to declarations via relative paths, provided they're\n * both in the logical project \"space\" of paths.\n *\n * This is trickier than it sounds, as the two files may be in different root directories in the\n * project. Simply calculating a file system relative path between the two is not sufficient.\n * Instead, `LogicalProjectPath`s are used.\n */\nexport class LogicalProjectStrategy implements ReferenceEmitStrategy {\n  constructor(private reflector: ReflectionHost, private logicalFs: LogicalFileSystem) {}\n\n  emit(ref: Reference<ts.Node>, context: ts.SourceFile): Expression|null {\n    const destSf = getSourceFile(ref.node);\n\n    // Compute the relative path from the importing file to the file being imported. This is done\n    // as a logical path computation, because the two files might be in different rootDirs.\n    const destPath = this.logicalFs.logicalPathOfSf(destSf);\n    if (destPath === null) {\n      // The imported file is not within the logical project filesystem.\n      return null;\n    }\n\n    const originPath = this.logicalFs.logicalPathOfSf(context);\n    if (originPath === null) {\n      throw new Error(\n          `Debug assert: attempt to import from ${context.fileName} but it's outside the program?`);\n    }\n\n    // There's no way to emit a relative reference from a file to itself.\n    if (destPath === originPath) {\n      return null;\n    }\n\n    const name = findExportedNameOfNode(ref.node, destSf, this.reflector);\n    if (name === null) {\n      // The target declaration isn't exported from the file it's declared in. This is an issue!\n      return null;\n    }\n\n    // With both files expressed as LogicalProjectPaths, getting the module specifier as a relative\n    // path is now straightforward.\n    const moduleName = LogicalProjectPath.relativePathBetween(originPath, destPath);\n    return new ExternalExpr({moduleName, name});\n  }\n}\n\n/**\n * A `ReferenceEmitStrategy` which constructs relatives paths between `ts.SourceFile`s.\n *\n * This strategy can be used if there is no `rootDir`/`rootDirs` structure for the project which\n * necessitates the stronger logic of `LogicalProjectStrategy`.\n */\nexport class RelativePathStrategy implements ReferenceEmitStrategy {\n  constructor(private reflector: ReflectionHost) {}\n\n  emit(ref: Reference<ts.Node>, context: ts.SourceFile): Expression|null {\n    const destSf = getSourceFile(ref.node);\n    let moduleName = stripExtension(\n        relative(dirname(absoluteFromSourceFile(context)), absoluteFromSourceFile(destSf)));\n    if (!moduleName.startsWith('../')) {\n      moduleName = ('./' + moduleName) as PathSegment;\n    }\n\n    const name = findExportedNameOfNode(ref.node, destSf, this.reflector);\n    return new ExternalExpr({moduleName, name});\n  }\n}\n\n/**\n * A `ReferenceEmitStrategy` which uses a `FileToModuleHost` to generate absolute import references.\n */\nexport class FileToModuleStrategy implements ReferenceEmitStrategy {\n  constructor(private reflector: ReflectionHost, private fileToModuleHost: FileToModuleHost) {}\n\n  emit(ref: Reference<ts.Node>, context: ts.SourceFile): Expression|null {\n    const destSf = getSourceFile(ref.node);\n    const name = findExportedNameOfNode(ref.node, destSf, this.reflector);\n    if (name === null) {\n      return null;\n    }\n\n    const moduleName =\n        this.fileToModuleHost.fileNameToModuleName(destSf.fileName, context.fileName);\n\n    return new ExternalExpr({moduleName, name});\n  }\n}\n"]}
285
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"emitter.js","sourceRoot":"","sources":["../../../../../../../../../packages/compiler-cli/src/ngtsc/imports/src/emitter.ts"],"names":[],"mappings":"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","sourcesContent":["/**\n * @license\n * Copyright Google Inc. All Rights Reserved.\n *\n * Use of this source code is governed by an MIT-style license that can be\n * found in the LICENSE file at https://angular.io/license\n */\nimport {Expression, ExternalExpr, ExternalReference, WrappedNodeExpr} from '@angular/compiler';\nimport * as ts from 'typescript';\n\nimport {UnifiedModulesHost} from '../../core/api';\nimport {LogicalFileSystem, LogicalProjectPath, PathSegment, absoluteFromSourceFile, dirname, relative} from '../../file_system';\nimport {stripExtension} from '../../file_system/src/util';\nimport {ReflectionHost} from '../../reflection';\nimport {getSourceFile, isDeclaration, isTypeDeclaration, nodeNameForError} from '../../util/src/typescript';\n\nimport {findExportedNameOfNode} from './find_export';\nimport {Reference} from './references';\nimport {ModuleResolver} from './resolver';\n\n\n/**\n * Flags which alter the imports generated by the `ReferenceEmitter`.\n */\nexport enum ImportFlags {\n  None = 0x00,\n\n  /**\n   * Force the generation of a new import when generating a reference, even if an identifier already\n   * exists in the target file which could be used instead.\n   *\n   * This is sometimes required if there's a risk TypeScript might remove imports during emit.\n   */\n  ForceNewImport = 0x01,\n\n  /**\n   * Don't make use of any aliasing information when emitting a reference.\n   *\n   * This is sometimes required if emitting into a context where generated references will be fed\n   * into TypeScript and type-checked (such as in template type-checking).\n   */\n  NoAliasing = 0x02,\n\n  /**\n   * Indicates that an import to a type-only declaration is allowed.\n   *\n   * For references that occur in type-positions, the referred declaration may be a type-only\n   * declaration that is not retained during emit. Including this flag allows to emit references to\n   * type-only declarations as used in e.g. template type-checking.\n   */\n  AllowTypeImports = 0x04,\n}\n\n/**\n * A particular strategy for generating an expression which refers to a `Reference`.\n *\n * There are many potential ways a given `Reference` could be referred to in the context of a given\n * file. A local declaration could be available, the `Reference` could be importable via a relative\n * import within the project, or an absolute import into `node_modules` might be necessary.\n *\n * Different `ReferenceEmitStrategy` implementations implement specific logic for generating such\n * references. A single strategy (such as using a local declaration) may not always be able to\n * generate an expression for every `Reference` (for example, if no local identifier is available),\n * and may return `null` in such a case.\n */\nexport interface ReferenceEmitStrategy {\n  /**\n   * Emit an `Expression` which refers to the given `Reference` in the context of a particular\n   * source file, if possible.\n   *\n   * @param ref the `Reference` for which to generate an expression\n   * @param context the source file in which the `Expression` must be valid\n   * @param importFlags a flag which controls whether imports should be generated or not\n   * @returns an `Expression` which refers to the `Reference`, or `null` if none can be generated\n   */\n  emit(ref: Reference, context: ts.SourceFile, importFlags: ImportFlags): Expression|null;\n}\n\n/**\n * Generates `Expression`s which refer to `Reference`s in a given context.\n *\n * A `ReferenceEmitter` uses one or more `ReferenceEmitStrategy` implementations to produce an\n * `Expression` which refers to a `Reference` in the context of a particular file.\n */\nexport class ReferenceEmitter {\n  constructor(private strategies: ReferenceEmitStrategy[]) {}\n\n  emit(ref: Reference, context: ts.SourceFile, importFlags: ImportFlags = ImportFlags.None):\n      Expression {\n    for (const strategy of this.strategies) {\n      const emitted = strategy.emit(ref, context, importFlags);\n      if (emitted !== null) {\n        return emitted;\n      }\n    }\n    throw new Error(\n        `Unable to write a reference to ${nodeNameForError(ref.node)} in ${ref.node.getSourceFile().fileName} from ${context.fileName}`);\n  }\n}\n\n/**\n * A `ReferenceEmitStrategy` which will refer to declarations by any local `ts.Identifier`s, if\n * such identifiers are available.\n */\nexport class LocalIdentifierStrategy implements ReferenceEmitStrategy {\n  emit(ref: Reference<ts.Node>, context: ts.SourceFile, importFlags: ImportFlags): Expression|null {\n    // If the emitter has specified ForceNewImport, then LocalIdentifierStrategy should not use a\n    // local identifier at all, *except* in the source file where the node is actually declared.\n    if (importFlags & ImportFlags.ForceNewImport &&\n        getSourceFile(ref.node) !== getSourceFile(context)) {\n      return null;\n    }\n\n    // A Reference can have multiple identities in different files, so it may already have an\n    // Identifier in the requested context file.\n    const identifier = ref.getIdentityIn(context);\n    if (identifier !== null) {\n      return new WrappedNodeExpr(identifier);\n    } else {\n      return null;\n    }\n  }\n}\n\n/**\n * A `ReferenceEmitStrategy` which will refer to declarations that come from `node_modules` using\n * an absolute import.\n *\n * Part of this strategy involves looking at the target entry point and identifying the exported\n * name of the targeted declaration, as it might be different from the declared name (e.g. a\n * directive might be declared as FooDirImpl, but exported as FooDir). If no export can be found\n * which maps back to the original directive, an error is thrown.\n */\nexport class AbsoluteModuleStrategy implements ReferenceEmitStrategy {\n  /**\n   * A cache of the exports of specific modules, because resolving a module to its exports is a\n   * costly operation.\n   */\n  private moduleExportsCache = new Map<string, Map<ts.Declaration, string>|null>();\n\n  constructor(\n      protected program: ts.Program, protected checker: ts.TypeChecker,\n      protected moduleResolver: ModuleResolver, private reflectionHost: ReflectionHost) {}\n\n  emit(ref: Reference<ts.Node>, context: ts.SourceFile, importFlags: ImportFlags): Expression|null {\n    if (ref.bestGuessOwningModule === null) {\n      // There is no module name available for this Reference, meaning it was arrived at via a\n      // relative path.\n      return null;\n    } else if (!isDeclaration(ref.node)) {\n      // It's not possible to import something which isn't a declaration.\n      throw new Error(\n          `Debug assert: unable to import a Reference to non-declaration of type ${ts.SyntaxKind[ref.node.kind]}.`);\n    } else if ((importFlags & ImportFlags.AllowTypeImports) === 0 && isTypeDeclaration(ref.node)) {\n      throw new Error(\n          `Importing a type-only declaration of type ${ts.SyntaxKind[ref.node.kind]} in a value position is not allowed.`);\n    }\n\n    // Try to find the exported name of the declaration, if one is available.\n    const {specifier, resolutionContext} = ref.bestGuessOwningModule;\n    const symbolName = this.resolveImportName(specifier, ref.node, resolutionContext);\n    if (symbolName === null) {\n      // TODO(alxhub): make this error a ts.Diagnostic pointing at whatever caused this import to be\n      // triggered.\n      throw new Error(\n          `Symbol ${ref.debugName} declared in ${getSourceFile(ref.node).fileName} is not exported from ${specifier} (import into ${context.fileName})`);\n    }\n\n    return new ExternalExpr(new ExternalReference(specifier, symbolName));\n  }\n\n  private resolveImportName(moduleName: string, target: ts.Declaration, fromFile: string): string\n      |null {\n    const exports = this.getExportsOfModule(moduleName, fromFile);\n    if (exports !== null && exports.has(target)) {\n      return exports.get(target) !;\n    } else {\n      return null;\n    }\n  }\n\n  private getExportsOfModule(moduleName: string, fromFile: string):\n      Map<ts.Declaration, string>|null {\n    if (!this.moduleExportsCache.has(moduleName)) {\n      this.moduleExportsCache.set(moduleName, this.enumerateExportsOfModule(moduleName, fromFile));\n    }\n    return this.moduleExportsCache.get(moduleName) !;\n  }\n\n  protected enumerateExportsOfModule(specifier: string, fromFile: string):\n      Map<ts.Declaration, string>|null {\n    // First, resolve the module specifier to its entry point, and get the ts.Symbol for it.\n    const entryPointFile = this.moduleResolver.resolveModule(specifier, fromFile);\n    if (entryPointFile === null) {\n      return null;\n    }\n\n    const exports = this.reflectionHost.getExportsOfModule(entryPointFile);\n    if (exports === null) {\n      return null;\n    }\n    const exportMap = new Map<ts.Declaration, string>();\n    exports.forEach((declaration, name) => {\n      // It's okay to skip inline declarations, since by definition they're not target-able with a\n      // ts.Declaration anyway.\n      if (declaration.node !== null) {\n        exportMap.set(declaration.node, name);\n      }\n    });\n    return exportMap;\n  }\n}\n\n/**\n * A `ReferenceEmitStrategy` which will refer to declarations via relative paths, provided they're\n * both in the logical project \"space\" of paths.\n *\n * This is trickier than it sounds, as the two files may be in different root directories in the\n * project. Simply calculating a file system relative path between the two is not sufficient.\n * Instead, `LogicalProjectPath`s are used.\n */\nexport class LogicalProjectStrategy implements ReferenceEmitStrategy {\n  constructor(private reflector: ReflectionHost, private logicalFs: LogicalFileSystem) {}\n\n  emit(ref: Reference<ts.Node>, context: ts.SourceFile): Expression|null {\n    const destSf = getSourceFile(ref.node);\n\n    // Compute the relative path from the importing file to the file being imported. This is done\n    // as a logical path computation, because the two files might be in different rootDirs.\n    const destPath = this.logicalFs.logicalPathOfSf(destSf);\n    if (destPath === null) {\n      // The imported file is not within the logical project filesystem.\n      return null;\n    }\n\n    const originPath = this.logicalFs.logicalPathOfSf(context);\n    if (originPath === null) {\n      throw new Error(\n          `Debug assert: attempt to import from ${context.fileName} but it's outside the program?`);\n    }\n\n    // There's no way to emit a relative reference from a file to itself.\n    if (destPath === originPath) {\n      return null;\n    }\n\n    const name = findExportedNameOfNode(ref.node, destSf, this.reflector);\n    if (name === null) {\n      // The target declaration isn't exported from the file it's declared in. This is an issue!\n      return null;\n    }\n\n    // With both files expressed as LogicalProjectPaths, getting the module specifier as a relative\n    // path is now straightforward.\n    const moduleName = LogicalProjectPath.relativePathBetween(originPath, destPath);\n    return new ExternalExpr({moduleName, name});\n  }\n}\n\n/**\n * A `ReferenceEmitStrategy` which constructs relatives paths between `ts.SourceFile`s.\n *\n * This strategy can be used if there is no `rootDir`/`rootDirs` structure for the project which\n * necessitates the stronger logic of `LogicalProjectStrategy`.\n */\nexport class RelativePathStrategy implements ReferenceEmitStrategy {\n  constructor(private reflector: ReflectionHost) {}\n\n  emit(ref: Reference<ts.Node>, context: ts.SourceFile): Expression|null {\n    const destSf = getSourceFile(ref.node);\n    let moduleName = stripExtension(\n        relative(dirname(absoluteFromSourceFile(context)), absoluteFromSourceFile(destSf)));\n    if (!moduleName.startsWith('../')) {\n      moduleName = ('./' + moduleName) as PathSegment;\n    }\n\n    const name = findExportedNameOfNode(ref.node, destSf, this.reflector);\n    return new ExternalExpr({moduleName, name});\n  }\n}\n\n/**\n * A `ReferenceEmitStrategy` which uses a `UnifiedModulesHost` to generate absolute import\n * references.\n */\nexport class UnifiedModulesStrategy implements ReferenceEmitStrategy {\n  constructor(private reflector: ReflectionHost, private unifiedModulesHost: UnifiedModulesHost) {}\n\n  emit(ref: Reference<ts.Node>, context: ts.SourceFile): Expression|null {\n    const destSf = getSourceFile(ref.node);\n    const name = findExportedNameOfNode(ref.node, destSf, this.reflector);\n    if (name === null) {\n      return null;\n    }\n\n    const moduleName =\n        this.unifiedModulesHost.fileNameToModuleName(destSf.fileName, context.fileName);\n\n    return new ExternalExpr({moduleName, name});\n  }\n}\n"]}