@angular/compiler-cli 9.0.0-rc.9 → 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 (158) hide show
  1. package/ngcc/src/analysis/decoration_analyzer.d.ts +9 -23
  2. package/ngcc/src/analysis/decoration_analyzer.js +82 -144
  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/types.d.ts +6 -20
  9. package/ngcc/src/analysis/types.js +1 -1
  10. package/ngcc/src/analysis/util.d.ts +0 -5
  11. package/ngcc/src/analysis/util.js +2 -116
  12. package/ngcc/src/dependencies/dts_dependency_host.d.ts +5 -1
  13. package/ngcc/src/dependencies/dts_dependency_host.js +9 -2
  14. package/ngcc/src/dependencies/esm_dependency_host.d.ts +7 -0
  15. package/ngcc/src/dependencies/esm_dependency_host.js +29 -21
  16. package/ngcc/src/entry_point_finder/targeted_entry_point_finder.d.ts +2 -0
  17. package/ngcc/src/entry_point_finder/targeted_entry_point_finder.js +49 -9
  18. package/ngcc/src/execution/cluster/executor.d.ts +3 -1
  19. package/ngcc/src/execution/cluster/executor.js +11 -6
  20. package/ngcc/src/execution/cluster/package_json_updater.js +3 -2
  21. package/ngcc/src/execution/lock_file.d.ts +43 -0
  22. package/ngcc/src/execution/lock_file.js +129 -0
  23. package/ngcc/src/execution/single_process_executor.d.ts +3 -1
  24. package/ngcc/src/execution/single_process_executor.js +18 -15
  25. package/ngcc/src/host/commonjs_host.js +5 -4
  26. package/ngcc/src/host/esm2015_host.d.ts +3 -1
  27. package/ngcc/src/host/esm2015_host.js +40 -9
  28. package/ngcc/src/host/esm5_host.js +3 -1
  29. package/ngcc/src/host/umd_host.js +5 -4
  30. package/ngcc/src/main.js +62 -122
  31. package/ngcc/src/migrations/migration.d.ts +1 -0
  32. package/ngcc/src/migrations/migration.js +1 -1
  33. package/ngcc/src/packages/build_marker.d.ts +17 -8
  34. package/ngcc/src/packages/build_marker.js +61 -32
  35. package/ngcc/src/packages/entry_point_bundle.js +2 -2
  36. package/ngcc/src/rendering/dts_renderer.js +7 -4
  37. package/ngcc/src/rendering/renderer.js +4 -4
  38. package/ngcc/src/writing/cleaning/cleaning_strategies.d.ts +45 -0
  39. package/ngcc/src/writing/cleaning/cleaning_strategies.js +77 -0
  40. package/ngcc/src/writing/cleaning/package_cleaner.d.ts +39 -0
  41. package/ngcc/src/writing/cleaning/package_cleaner.js +125 -0
  42. package/ngcc/src/writing/cleaning/utils.d.ts +16 -0
  43. package/ngcc/src/writing/cleaning/utils.js +29 -0
  44. package/ngcc/src/writing/in_place_file_writer.d.ts +1 -0
  45. package/ngcc/src/writing/in_place_file_writer.js +3 -2
  46. package/ngcc/src/writing/new_entry_point_file_writer.d.ts +2 -0
  47. package/ngcc/src/writing/new_entry_point_file_writer.js +5 -4
  48. package/ngcc/src/writing/package_json_updater.d.ts +24 -10
  49. package/ngcc/src/writing/package_json_updater.js +53 -10
  50. package/package.json +5 -4
  51. package/src/ngtsc/annotations/src/component.d.ts +1 -1
  52. package/src/ngtsc/annotations/src/component.js +4 -3
  53. package/src/ngtsc/annotations/src/directive.js +4 -3
  54. package/src/ngtsc/annotations/src/injectable.js +2 -1
  55. package/src/ngtsc/annotations/src/ng_module.js +2 -1
  56. package/src/ngtsc/annotations/src/pipe.js +2 -1
  57. package/src/ngtsc/annotations/src/util.js +3 -3
  58. package/src/ngtsc/core/api.d.ts +368 -0
  59. package/src/ngtsc/core/api.js +20 -0
  60. package/src/ngtsc/core/index.d.ts +10 -0
  61. package/src/ngtsc/core/index.js +24 -0
  62. package/src/ngtsc/core/src/compiler.d.ts +120 -0
  63. package/src/ngtsc/core/src/compiler.js +769 -0
  64. package/src/ngtsc/core/src/host.d.ts +85 -0
  65. package/src/ngtsc/core/src/host.js +208 -0
  66. package/src/ngtsc/diagnostics/index.d.ts +1 -1
  67. package/src/ngtsc/diagnostics/index.js +5 -5
  68. package/src/ngtsc/diagnostics/src/error.d.ts +1 -1
  69. package/src/ngtsc/diagnostics/src/error.js +1 -1
  70. package/src/ngtsc/diagnostics/src/{code.d.ts → error_code.d.ts} +4 -6
  71. package/src/ngtsc/diagnostics/src/error_code.js +128 -0
  72. package/src/ngtsc/file_system/src/cached_file_system.d.ts +3 -1
  73. package/src/ngtsc/file_system/src/cached_file_system.js +48 -4
  74. package/src/ngtsc/file_system/src/invalid_file_system.d.ts +3 -1
  75. package/src/ngtsc/file_system/src/invalid_file_system.js +4 -2
  76. package/src/ngtsc/file_system/src/node_js_file_system.d.ts +3 -1
  77. package/src/ngtsc/file_system/src/node_js_file_system.js +8 -4
  78. package/src/ngtsc/file_system/src/types.d.ts +3 -1
  79. package/src/ngtsc/file_system/src/types.js +1 -1
  80. package/src/ngtsc/imports/index.d.ts +3 -3
  81. package/src/ngtsc/imports/index.js +4 -4
  82. package/src/ngtsc/imports/src/alias.d.ts +12 -11
  83. package/src/ngtsc/imports/src/alias.js +21 -16
  84. package/src/ngtsc/imports/src/emitter.d.ts +37 -16
  85. package/src/ngtsc/imports/src/emitter.js +51 -18
  86. package/src/ngtsc/imports/src/references.d.ts +0 -4
  87. package/src/ngtsc/imports/src/references.js +1 -6
  88. package/src/ngtsc/incremental/api.d.ts +2 -1
  89. package/src/ngtsc/incremental/api.js +1 -1
  90. package/src/ngtsc/incremental/src/dependency_tracking.d.ts +4 -3
  91. package/src/ngtsc/incremental/src/dependency_tracking.js +2 -2
  92. package/src/ngtsc/incremental/src/state.js +33 -13
  93. package/src/ngtsc/indexer/index.d.ts +1 -0
  94. package/src/ngtsc/indexer/index.js +4 -2
  95. package/src/ngtsc/modulewithproviders/src/scanner.js +2 -2
  96. package/src/ngtsc/partial_evaluator/src/builtin.d.ts +7 -6
  97. package/src/ngtsc/partial_evaluator/src/builtin.js +54 -9
  98. package/src/ngtsc/partial_evaluator/src/interpreter.js +9 -5
  99. package/src/ngtsc/partial_evaluator/src/known_declaration.d.ts +19 -0
  100. package/src/ngtsc/partial_evaluator/src/known_declaration.js +38 -0
  101. package/src/ngtsc/partial_evaluator/src/result.d.ts +1 -1
  102. package/src/ngtsc/partial_evaluator/src/result.js +1 -1
  103. package/src/ngtsc/partial_evaluator/src/ts_helpers.d.ts +1 -1
  104. package/src/ngtsc/partial_evaluator/src/ts_helpers.js +13 -3
  105. package/src/ngtsc/program.d.ts +46 -64
  106. package/src/ngtsc/program.js +76 -724
  107. package/src/ngtsc/reflection/src/host.d.ts +19 -2
  108. package/src/ngtsc/reflection/src/host.js +17 -3
  109. package/src/ngtsc/reflection/src/typescript.js +4 -4
  110. package/src/ngtsc/resource/index.d.ts +9 -0
  111. package/src/ngtsc/resource/index.js +22 -0
  112. package/src/ngtsc/{resource_loader.d.ts → resource/src/loader.d.ts} +4 -4
  113. package/src/ngtsc/resource/src/loader.js +193 -0
  114. package/src/ngtsc/shims/index.d.ts +1 -1
  115. package/src/ngtsc/shims/index.js +2 -5
  116. package/src/ngtsc/shims/src/api.d.ts +25 -0
  117. package/src/ngtsc/shims/src/api.js +13 -0
  118. package/src/ngtsc/shims/src/factory_generator.d.ts +1 -1
  119. package/src/ngtsc/shims/src/factory_generator.js +1 -1
  120. package/src/ngtsc/shims/src/summary_generator.d.ts +1 -1
  121. package/src/ngtsc/shims/src/summary_generator.js +1 -1
  122. package/src/ngtsc/shims/src/typecheck_shim.d.ts +1 -1
  123. package/src/ngtsc/shims/src/typecheck_shim.js +1 -1
  124. package/src/ngtsc/transform/index.d.ts +2 -0
  125. package/src/ngtsc/transform/index.js +7 -2
  126. package/src/ngtsc/transform/src/alias.d.ts +1 -1
  127. package/src/ngtsc/transform/src/alias.js +1 -1
  128. package/src/ngtsc/transform/src/api.d.ts +16 -0
  129. package/src/ngtsc/transform/src/api.js +1 -1
  130. package/src/ngtsc/transform/src/compilation.d.ts +8 -6
  131. package/src/ngtsc/transform/src/compilation.js +47 -20
  132. package/src/ngtsc/transform/src/declaration.d.ts +1 -1
  133. package/src/ngtsc/transform/src/declaration.js +1 -1
  134. package/src/ngtsc/typecheck/index.d.ts +1 -0
  135. package/src/ngtsc/typecheck/index.js +4 -2
  136. package/src/ngtsc/typecheck/src/api.d.ts +8 -0
  137. package/src/ngtsc/typecheck/src/api.js +1 -1
  138. package/src/ngtsc/typecheck/src/diagnostics.d.ts +13 -3
  139. package/src/ngtsc/typecheck/src/diagnostics.js +14 -5
  140. package/src/ngtsc/typecheck/src/dom.js +3 -3
  141. package/src/ngtsc/typecheck/src/environment.js +7 -3
  142. package/src/ngtsc/typecheck/src/host.d.ts +1 -0
  143. package/src/ngtsc/typecheck/src/host.js +4 -1
  144. package/src/ngtsc/typecheck/src/oob.js +4 -4
  145. package/src/ngtsc/typecheck/src/ts_util.js +36 -1
  146. package/src/ngtsc/typecheck/src/type_check_block.js +31 -18
  147. package/src/ngtsc/util/src/typescript.d.ts +2 -0
  148. package/src/ngtsc/util/src/typescript.js +12 -4
  149. package/src/perform_watch.js +6 -5
  150. package/src/transformers/api.d.ts +3 -206
  151. package/src/transformers/api.js +1 -1
  152. package/src/transformers/compiler_host.js +2 -2
  153. package/src/transformers/program.js +1 -1
  154. package/src/version.js +1 -1
  155. package/src/ngtsc/diagnostics/src/code.js +0 -126
  156. package/src/ngtsc/resource_loader.js +0 -193
  157. package/src/ngtsc/shims/src/host.d.ts +0 -46
  158. package/src/ngtsc/shims/src/host.js +0 -82
@@ -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/program", ["require", "exports", "tslib", "typescript", "@angular/compiler-cli/src/transformers/nocollapse_hack", "@angular/compiler-cli/src/typescript_support", "@angular/compiler-cli/src/ngtsc/annotations", "@angular/compiler-cli/src/ngtsc/cycles", "@angular/compiler-cli/src/ngtsc/diagnostics", "@angular/compiler-cli/src/ngtsc/entry_point", "@angular/compiler-cli/src/ngtsc/file_system", "@angular/compiler-cli/src/ngtsc/imports", "@angular/compiler-cli/src/ngtsc/incremental", "@angular/compiler-cli/src/ngtsc/indexer", "@angular/compiler-cli/src/ngtsc/indexer/src/transform", "@angular/compiler-cli/src/ngtsc/metadata", "@angular/compiler-cli/src/ngtsc/metadata/src/registry", "@angular/compiler-cli/src/ngtsc/modulewithproviders", "@angular/compiler-cli/src/ngtsc/partial_evaluator", "@angular/compiler-cli/src/ngtsc/perf", "@angular/compiler-cli/src/ngtsc/reflection", "@angular/compiler-cli/src/ngtsc/resource_loader", "@angular/compiler-cli/src/ngtsc/routing", "@angular/compiler-cli/src/ngtsc/scope", "@angular/compiler-cli/src/ngtsc/shims", "@angular/compiler-cli/src/ngtsc/switch", "@angular/compiler-cli/src/ngtsc/transform", "@angular/compiler-cli/src/ngtsc/transform/src/alias", "@angular/compiler-cli/src/ngtsc/typecheck", "@angular/compiler-cli/src/ngtsc/util/src/path", "@angular/compiler-cli/src/ngtsc/util/src/typescript"], factory);
14
+ define("@angular/compiler-cli/src/ngtsc/program", ["require", "exports", "tslib", "typescript", "@angular/compiler-cli/src/transformers/nocollapse_hack", "@angular/compiler-cli/src/typescript_support", "@angular/compiler-cli/src/ngtsc/core", "@angular/compiler-cli/src/ngtsc/core/src/compiler", "@angular/compiler-cli/src/ngtsc/perf"], factory);
15
15
  }
16
16
  })(function (require, exports) {
17
17
  "use strict";
@@ -20,330 +20,84 @@
20
20
  var ts = require("typescript");
21
21
  var nocollapse_hack_1 = require("@angular/compiler-cli/src/transformers/nocollapse_hack");
22
22
  var typescript_support_1 = require("@angular/compiler-cli/src/typescript_support");
23
- var annotations_1 = require("@angular/compiler-cli/src/ngtsc/annotations");
24
- var cycles_1 = require("@angular/compiler-cli/src/ngtsc/cycles");
25
- var diagnostics_1 = require("@angular/compiler-cli/src/ngtsc/diagnostics");
26
- var entry_point_1 = require("@angular/compiler-cli/src/ngtsc/entry_point");
27
- var file_system_1 = require("@angular/compiler-cli/src/ngtsc/file_system");
28
- var imports_1 = require("@angular/compiler-cli/src/ngtsc/imports");
29
- var incremental_1 = require("@angular/compiler-cli/src/ngtsc/incremental");
30
- var indexer_1 = require("@angular/compiler-cli/src/ngtsc/indexer");
31
- var transform_1 = require("@angular/compiler-cli/src/ngtsc/indexer/src/transform");
32
- var metadata_1 = require("@angular/compiler-cli/src/ngtsc/metadata");
33
- var registry_1 = require("@angular/compiler-cli/src/ngtsc/metadata/src/registry");
34
- var modulewithproviders_1 = require("@angular/compiler-cli/src/ngtsc/modulewithproviders");
35
- var partial_evaluator_1 = require("@angular/compiler-cli/src/ngtsc/partial_evaluator");
23
+ var core_1 = require("@angular/compiler-cli/src/ngtsc/core");
24
+ var compiler_1 = require("@angular/compiler-cli/src/ngtsc/core/src/compiler");
36
25
  var perf_1 = require("@angular/compiler-cli/src/ngtsc/perf");
37
- var reflection_1 = require("@angular/compiler-cli/src/ngtsc/reflection");
38
- var resource_loader_1 = require("@angular/compiler-cli/src/ngtsc/resource_loader");
39
- var routing_1 = require("@angular/compiler-cli/src/ngtsc/routing");
40
- var scope_1 = require("@angular/compiler-cli/src/ngtsc/scope");
41
- var shims_1 = require("@angular/compiler-cli/src/ngtsc/shims");
42
- var switch_1 = require("@angular/compiler-cli/src/ngtsc/switch");
43
- var transform_2 = require("@angular/compiler-cli/src/ngtsc/transform");
44
- var alias_1 = require("@angular/compiler-cli/src/ngtsc/transform/src/alias");
45
- var typecheck_1 = require("@angular/compiler-cli/src/ngtsc/typecheck");
46
- var path_1 = require("@angular/compiler-cli/src/ngtsc/util/src/path");
47
- var typescript_1 = require("@angular/compiler-cli/src/ngtsc/util/src/typescript");
26
+ /**
27
+ * Entrypoint to the Angular Compiler (Ivy+) which sits behind the `api.Program` interface, allowing
28
+ * it to be a drop-in replacement for the legacy View Engine compiler to tooling such as the
29
+ * command-line main() function or the Angular CLI.
30
+ */
48
31
  var NgtscProgram = /** @class */ (function () {
49
- function NgtscProgram(rootNames, options, host, oldProgram) {
50
- var _this = this;
32
+ function NgtscProgram(rootNames, options, delegateHost, oldProgram) {
51
33
  this.options = options;
52
- this.host = host;
53
- this.compilation = undefined;
54
- this._coreImportsFrom = undefined;
55
- this._importRewriter = undefined;
56
- this._reflector = undefined;
57
- this._isCore = undefined;
58
- this.exportReferenceGraph = null;
59
- this.flatIndexGenerator = null;
60
- this.routeAnalyzer = null;
61
- this.scopeRegistry = null;
62
- this.constructionDiagnostics = [];
63
- this.metaReader = null;
64
- this.aliasingHost = null;
65
- this.refEmitter = null;
66
- this.fileToModuleHost = null;
67
34
  this.perfRecorder = perf_1.NOOP_PERF_RECORDER;
68
35
  this.perfTracker = null;
69
- this.factoryTracker = null;
70
- this.dtsTransforms = null;
71
- this.mwpScanner = null;
36
+ // First, check whether the current TS version is supported.
72
37
  if (!options.disableTypeScriptVersionCheck) {
73
38
  typescript_support_1.verifySupportedTypeScriptVersion();
74
39
  }
75
- var incompatibleTypeCheckOptionsDiagnostic = verifyCompatibleTypeCheckOptions(options);
76
- if (incompatibleTypeCheckOptionsDiagnostic !== null) {
77
- this.constructionDiagnostics.push(incompatibleTypeCheckOptionsDiagnostic);
78
- }
79
- if (shouldEnablePerfTracing(options)) {
40
+ if (options.tracePerformance !== undefined) {
80
41
  this.perfTracker = perf_1.PerfTracker.zeroedToNow();
81
42
  this.perfRecorder = this.perfTracker;
82
43
  }
83
- this.modifiedResourceFiles =
84
- this.host.getModifiedResourceFiles && this.host.getModifiedResourceFiles() || null;
85
- this.rootDirs = typescript_1.getRootDirs(host, options);
86
44
  this.closureCompilerEnabled = !!options.annotateForClosureCompiler;
87
- this.resourceManager = new resource_loader_1.HostResourceLoader(host, options);
88
- // TODO(alxhub): remove the fallback to allowEmptyCodegenFiles after verifying that the rest of
89
- // our build tooling is no longer relying on it.
90
- var allowEmptyCodegenFiles = options.allowEmptyCodegenFiles || false;
91
- var shouldGenerateFactoryShims = options.generateNgFactoryShims !== undefined ?
92
- options.generateNgFactoryShims :
93
- allowEmptyCodegenFiles;
94
- var shouldGenerateSummaryShims = options.generateNgSummaryShims !== undefined ?
95
- options.generateNgSummaryShims :
96
- allowEmptyCodegenFiles;
97
- var normalizedRootNames = rootNames.map(function (n) { return file_system_1.absoluteFrom(n); });
98
- if (host.fileNameToModuleName !== undefined) {
99
- this.fileToModuleHost = host;
100
- }
101
- var rootFiles = tslib_1.__spread(rootNames);
102
- var generators = [];
103
- var summaryGenerator = null;
104
- if (shouldGenerateSummaryShims) {
105
- // Summary generation.
106
- summaryGenerator = shims_1.SummaryGenerator.forRootFiles(normalizedRootNames);
107
- generators.push(summaryGenerator);
108
- }
109
- if (shouldGenerateFactoryShims) {
110
- // Factory generation.
111
- var factoryGenerator = shims_1.FactoryGenerator.forRootFiles(normalizedRootNames);
112
- var factoryFileMap = factoryGenerator.factoryFileMap;
113
- var factoryFileNames = Array.from(factoryFileMap.keys());
114
- rootFiles.push.apply(rootFiles, tslib_1.__spread(factoryFileNames));
115
- generators.push(factoryGenerator);
116
- this.factoryTracker = new shims_1.FactoryTracker(factoryGenerator);
117
- }
118
- // Done separately to preserve the order of factory files before summary files in rootFiles.
119
- // TODO(alxhub): validate that this is necessary.
120
- if (shouldGenerateSummaryShims) {
121
- rootFiles.push.apply(rootFiles, tslib_1.__spread(summaryGenerator.getSummaryFileNames()));
122
- }
123
- this.typeCheckFilePath = typecheck_1.typeCheckFilePath(this.rootDirs);
124
- generators.push(new shims_1.TypeCheckShimGenerator(this.typeCheckFilePath));
125
- rootFiles.push(this.typeCheckFilePath);
126
- var entryPoint = null;
127
- if (options.flatModuleOutFile != null && options.flatModuleOutFile !== '') {
128
- entryPoint = entry_point_1.findFlatIndexEntryPoint(normalizedRootNames);
129
- if (entryPoint === null) {
130
- // This error message talks specifically about having a single .ts file in "files". However
131
- // the actual logic is a bit more permissive. If a single file exists, that will be taken,
132
- // otherwise the highest level (shortest path) "index.ts" file will be used as the flat
133
- // module entry point instead. If neither of these conditions apply, the error below is
134
- // given.
135
- //
136
- // The user is not informed about the "index.ts" option as this behavior is deprecated -
137
- // an explicit entrypoint should always be specified.
138
- this.constructionDiagnostics.push({
139
- category: ts.DiagnosticCategory.Error,
140
- code: diagnostics_1.ngErrorCode(diagnostics_1.ErrorCode.CONFIG_FLAT_MODULE_NO_INDEX),
141
- file: undefined,
142
- start: undefined,
143
- length: undefined,
144
- messageText: 'Angular compiler option "flatModuleOutFile" requires one and only one .ts file in the "files" field.',
145
- });
146
- }
147
- else {
148
- var flatModuleId = options.flatModuleId || null;
149
- var flatModuleOutFile = path_1.normalizeSeparators(options.flatModuleOutFile);
150
- this.flatIndexGenerator =
151
- new entry_point_1.FlatIndexGenerator(entryPoint, flatModuleOutFile, flatModuleId);
152
- generators.push(this.flatIndexGenerator);
153
- rootFiles.push(this.flatIndexGenerator.flatIndexPath);
154
- }
155
- }
156
- if (generators.length > 0) {
157
- // FIXME: Remove the any cast once google3 is fully on TS3.6.
158
- this.host = new shims_1.GeneratedShimsHostWrapper(host, generators);
159
- }
160
- this.tsProgram =
161
- ts.createProgram(rootFiles, options, this.host, oldProgram && oldProgram.reuseTsProgram);
45
+ this.host = core_1.NgCompilerHost.wrap(delegateHost, rootNames, options);
46
+ var reuseProgram = oldProgram && oldProgram.reuseTsProgram;
47
+ this.tsProgram = ts.createProgram(this.host.inputFiles, options, this.host, reuseProgram);
162
48
  this.reuseTsProgram = this.tsProgram;
163
- this.entryPoint = entryPoint !== null ? typescript_1.getSourceFileOrNull(this.tsProgram, entryPoint) : null;
164
- var moduleResolutionCache = ts.createModuleResolutionCache(this.host.getCurrentDirectory(), function (fileName) { return _this.host.getCanonicalFileName(fileName); });
165
- this.moduleResolver =
166
- new imports_1.ModuleResolver(this.tsProgram, options, this.host, moduleResolutionCache);
167
- this.cycleAnalyzer = new cycles_1.CycleAnalyzer(new cycles_1.ImportGraph(this.moduleResolver));
168
- this.defaultImportTracker = new imports_1.DefaultImportTracker();
169
- if (oldProgram === undefined) {
170
- this.incrementalDriver = incremental_1.IncrementalDriver.fresh(this.tsProgram);
171
- }
172
- else {
173
- this.incrementalDriver = incremental_1.IncrementalDriver.reconcile(oldProgram.reuseTsProgram, oldProgram.incrementalDriver, this.tsProgram, this.modifiedResourceFiles);
174
- }
49
+ // Create the NgCompiler which will drive the rest of the compilation.
50
+ this.compiler =
51
+ new compiler_1.NgCompiler(this.host, options, this.tsProgram, reuseProgram, this.perfRecorder);
175
52
  }
176
53
  NgtscProgram.prototype.getTsProgram = function () { return this.tsProgram; };
177
54
  NgtscProgram.prototype.getTsOptionDiagnostics = function (cancellationToken) {
178
55
  return this.tsProgram.getOptionsDiagnostics(cancellationToken);
179
56
  };
180
- NgtscProgram.prototype.getNgOptionDiagnostics = function (cancellationToken) {
181
- return this.constructionDiagnostics;
182
- };
183
57
  NgtscProgram.prototype.getTsSyntacticDiagnostics = function (sourceFile, cancellationToken) {
184
58
  return this.tsProgram.getSyntacticDiagnostics(sourceFile, cancellationToken);
185
59
  };
186
- NgtscProgram.prototype.getNgStructuralDiagnostics = function (cancellationToken) {
187
- return [];
188
- };
189
60
  NgtscProgram.prototype.getTsSemanticDiagnostics = function (sourceFile, cancellationToken) {
190
61
  return this.tsProgram.getSemanticDiagnostics(sourceFile, cancellationToken);
191
62
  };
192
- NgtscProgram.prototype.getNgSemanticDiagnostics = function (fileName, cancellationToken) {
193
- var compilation = this.ensureAnalyzed();
194
- var diagnostics = tslib_1.__spread(compilation.diagnostics, this.getTemplateDiagnostics());
195
- if (this.entryPoint !== null && this.exportReferenceGraph !== null) {
196
- diagnostics.push.apply(diagnostics, tslib_1.__spread(entry_point_1.checkForPrivateExports(this.entryPoint, this.tsProgram.getTypeChecker(), this.exportReferenceGraph)));
197
- }
198
- return diagnostics;
199
- };
200
- NgtscProgram.prototype.loadNgStructureAsync = function () {
201
- return tslib_1.__awaiter(this, void 0, void 0, function () {
202
- var analyzeSpan, promises, _loop_1, this_1, _a, _b, sf;
203
- var e_1, _c;
204
- var _this = this;
205
- return tslib_1.__generator(this, function (_d) {
206
- switch (_d.label) {
207
- case 0:
208
- if (this.compilation === undefined) {
209
- this.compilation = this.makeCompilation();
210
- }
211
- analyzeSpan = this.perfRecorder.start('analyze');
212
- promises = [];
213
- _loop_1 = function (sf) {
214
- if (sf.isDeclarationFile) {
215
- return "continue";
216
- }
217
- var analyzeFileSpan = this_1.perfRecorder.start('analyzeFile', sf);
218
- var analysisPromise = this_1.compilation.analyzeAsync(sf);
219
- this_1.scanForMwp(sf);
220
- if (analysisPromise === undefined) {
221
- this_1.perfRecorder.stop(analyzeFileSpan);
222
- }
223
- else if (this_1.perfRecorder.enabled) {
224
- analysisPromise = analysisPromise.then(function () { return _this.perfRecorder.stop(analyzeFileSpan); });
225
- }
226
- if (analysisPromise !== undefined) {
227
- promises.push(analysisPromise);
228
- }
229
- };
230
- this_1 = this;
231
- try {
232
- for (_a = tslib_1.__values(this.tsProgram.getSourceFiles()), _b = _a.next(); !_b.done; _b = _a.next()) {
233
- sf = _b.value;
234
- _loop_1(sf);
235
- }
236
- }
237
- catch (e_1_1) { e_1 = { error: e_1_1 }; }
238
- finally {
239
- try {
240
- if (_b && !_b.done && (_c = _a.return)) _c.call(_a);
241
- }
242
- finally { if (e_1) throw e_1.error; }
243
- }
244
- return [4 /*yield*/, Promise.all(promises)];
245
- case 1:
246
- _d.sent();
247
- this.perfRecorder.stop(analyzeSpan);
248
- this.resolveCompilation(this.compilation);
249
- return [2 /*return*/];
250
- }
251
- });
252
- });
253
- };
254
- NgtscProgram.prototype.listLazyRoutes = function (entryRoute) {
255
- if (entryRoute) {
256
- // Note:
257
- // This resolution step is here to match the implementation of the old `AotCompilerHost` (see
258
- // https://github.com/angular/angular/blob/50732e156/packages/compiler-cli/src/transformers/compiler_host.ts#L175-L188).
259
- //
260
- // `@angular/cli` will always call this API with an absolute path, so the resolution step is
261
- // not necessary, but keeping it backwards compatible in case someone else is using the API.
262
- // Relative entry paths are disallowed.
263
- if (entryRoute.startsWith('.')) {
264
- throw new Error("Failed to list lazy routes: Resolution of relative paths (" + entryRoute + ") is not supported.");
265
- }
266
- // Non-relative entry paths fall into one of the following categories:
267
- // - Absolute system paths (e.g. `/foo/bar/my-project/my-module`), which are unaffected by the
268
- // logic below.
269
- // - Paths to enternal modules (e.g. `some-lib`).
270
- // - Paths mapped to directories in `tsconfig.json` (e.g. `shared/my-module`).
271
- // (See https://www.typescriptlang.org/docs/handbook/module-resolution.html#path-mapping.)
272
- //
273
- // In all cases above, the `containingFile` argument is ignored, so we can just take the first
274
- // of the root files.
275
- var containingFile = this.tsProgram.getRootFileNames()[0];
276
- var _a = tslib_1.__read(entryRoute.split('#'), 2), entryPath = _a[0], moduleName = _a[1];
277
- var resolvedModule = typescript_1.resolveModuleName(entryPath, containingFile, this.options, this.host, null);
278
- if (resolvedModule) {
279
- entryRoute = routing_1.entryPointKeyFor(resolvedModule.resolvedFileName, moduleName);
280
- }
281
- }
282
- this.ensureAnalyzed();
283
- return this.routeAnalyzer.listLazyRoutes(entryRoute);
284
- };
285
- NgtscProgram.prototype.getLibrarySummaries = function () {
286
- throw new Error('Method not implemented.');
287
- };
288
- NgtscProgram.prototype.getEmittedGeneratedFiles = function () {
289
- throw new Error('Method not implemented.');
290
- };
291
- NgtscProgram.prototype.getEmittedSourceFiles = function () {
292
- throw new Error('Method not implemented.');
63
+ NgtscProgram.prototype.getNgOptionDiagnostics = function (cancellationToken) {
64
+ return this.compiler.getOptionDiagnostics();
293
65
  };
294
- NgtscProgram.prototype.scanForMwp = function (sf) {
295
- var _this = this;
296
- this.mwpScanner.scan(sf, {
297
- addTypeReplacement: function (node, type) {
298
- // Only obtain the return type transform for the source file once there's a type to replace,
299
- // so that no transform is allocated when there's nothing to do.
300
- _this.dtsTransforms.getReturnTypeTransform(sf).addTypeReplacement(node, type);
301
- }
302
- });
66
+ NgtscProgram.prototype.getNgStructuralDiagnostics = function (cancellationToken) {
67
+ return [];
303
68
  };
304
- NgtscProgram.prototype.ensureAnalyzed = function () {
305
- var e_2, _a;
306
- if (this.compilation === undefined) {
307
- var analyzeSpan = this.perfRecorder.start('analyze');
308
- this.compilation = this.makeCompilation();
309
- try {
310
- for (var _b = tslib_1.__values(this.tsProgram.getSourceFiles()), _c = _b.next(); !_c.done; _c = _b.next()) {
311
- var sf = _c.value;
312
- if (sf.isDeclarationFile) {
313
- continue;
314
- }
315
- var analyzeFileSpan = this.perfRecorder.start('analyzeFile', sf);
316
- this.compilation.analyzeSync(sf);
317
- this.scanForMwp(sf);
318
- this.perfRecorder.stop(analyzeFileSpan);
319
- }
320
- }
321
- catch (e_2_1) { e_2 = { error: e_2_1 }; }
322
- finally {
323
- try {
324
- if (_c && !_c.done && (_a = _b.return)) _a.call(_b);
325
- }
326
- finally { if (e_2) throw e_2.error; }
69
+ NgtscProgram.prototype.getNgSemanticDiagnostics = function (fileName, cancellationToken) {
70
+ var sf = undefined;
71
+ if (fileName !== undefined) {
72
+ sf = this.tsProgram.getSourceFile(fileName);
73
+ if (sf === undefined) {
74
+ // There are no diagnostics for files which don't exist in the program - maybe the caller
75
+ // has stale data?
76
+ return [];
327
77
  }
328
- this.perfRecorder.stop(analyzeSpan);
329
- this.resolveCompilation(this.compilation);
330
78
  }
331
- return this.compilation;
79
+ var diagnostics = this.compiler.getDiagnostics(sf);
80
+ this.reuseTsProgram = this.compiler.getNextProgram();
81
+ return diagnostics;
332
82
  };
333
- NgtscProgram.prototype.resolveCompilation = function (compilation) {
334
- compilation.resolve();
335
- this.recordNgModuleScopeDependencies();
336
- // At this point, analysis is complete and the compiler can now calculate which files need to
337
- // be emitted, so do that.
338
- this.incrementalDriver.recordSuccessfulAnalysis(compilation);
83
+ /**
84
+ * Ensure that the `NgCompiler` has properly analyzed the program, and allow for the asynchronous
85
+ * loading of any resources during the process.
86
+ *
87
+ * This is used by the Angular CLI to allow for spawning (async) child compilations for things
88
+ * like SASS files used in `styleUrls`.
89
+ */
90
+ NgtscProgram.prototype.loadNgStructureAsync = function () { return this.compiler.analyzeAsync(); };
91
+ NgtscProgram.prototype.listLazyRoutes = function (entryRoute) {
92
+ return this.compiler.listLazyRoutes(entryRoute);
339
93
  };
340
94
  NgtscProgram.prototype.emit = function (opts) {
341
- var e_3, _a;
95
+ var e_1, _a;
342
96
  var _this = this;
97
+ var _b = this.compiler.prepareEmit(), transformers = _b.transformers, ignoreFiles = _b.ignoreFiles;
343
98
  var emitCallback = opts && opts.emitCallback || defaultEmitCallback;
344
- var compilation = this.ensureAnalyzed();
345
99
  var writeFile = function (fileName, data, writeByteOrderMark, onError, sourceFiles) {
346
- var e_4, _a;
100
+ var e_2, _a;
347
101
  if (sourceFiles !== undefined) {
348
102
  try {
349
103
  // Record successful writes for any `ts.SourceFile` (that's not a declaration file)
@@ -353,53 +107,43 @@
353
107
  if (writtenSf.isDeclarationFile) {
354
108
  continue;
355
109
  }
356
- _this.incrementalDriver.recordSuccessfulEmit(writtenSf);
110
+ _this.compiler.incrementalDriver.recordSuccessfulEmit(writtenSf);
357
111
  }
358
112
  }
359
- catch (e_4_1) { e_4 = { error: e_4_1 }; }
113
+ catch (e_2_1) { e_2 = { error: e_2_1 }; }
360
114
  finally {
361
115
  try {
362
116
  if (sourceFiles_1_1 && !sourceFiles_1_1.done && (_a = sourceFiles_1.return)) _a.call(sourceFiles_1);
363
117
  }
364
- finally { if (e_4) throw e_4.error; }
118
+ finally { if (e_2) throw e_2.error; }
365
119
  }
366
120
  }
121
+ // If Closure annotations are being produced, tsickle should be adding `@nocollapse` to
122
+ // any static fields present. However, tsickle doesn't yet handle synthetic fields added
123
+ // during other transformations, so this hack is in place to ensure Ivy definitions get
124
+ // properly annotated, pending an upstream fix in tsickle.
125
+ //
126
+ // TODO(alxhub): remove when tsickle properly annotates synthetic fields.
367
127
  if (_this.closureCompilerEnabled && fileName.endsWith('.js')) {
368
128
  data = nocollapse_hack_1.nocollapseHack(data);
369
129
  }
370
130
  _this.host.writeFile(fileName, data, writeByteOrderMark, onError, sourceFiles);
371
131
  };
372
132
  var customTransforms = opts && opts.customTransformers;
373
- var beforeTransforms = [
374
- transform_2.ivyTransformFactory(compilation, this.reflector, this.importRewriter, this.defaultImportTracker, this.isCore, this.closureCompilerEnabled),
375
- alias_1.aliasTransformFactory(compilation.exportStatements),
376
- this.defaultImportTracker.importPreservingTransformer(),
377
- ];
378
- var afterDeclarationsTransforms = [];
379
- if (this.dtsTransforms !== null) {
380
- afterDeclarationsTransforms.push(transform_2.declarationTransformFactory(this.dtsTransforms, this.importRewriter));
381
- }
382
- // Only add aliasing re-exports to the .d.ts output if the `AliasingHost` requests it.
383
- if (this.aliasingHost !== null && this.aliasingHost.aliasExportsInDts) {
384
- afterDeclarationsTransforms.push(alias_1.aliasTransformFactory(compilation.exportStatements));
385
- }
386
- if (this.factoryTracker !== null) {
387
- beforeTransforms.push(shims_1.generatedFactoryTransform(this.factoryTracker.sourceInfo, this.importRewriter));
388
- }
389
- beforeTransforms.push(switch_1.ivySwitchTransform);
390
- if (customTransforms && customTransforms.beforeTs) {
133
+ var beforeTransforms = transformers.before || [];
134
+ var afterDeclarationsTransforms = transformers.afterDeclarations;
135
+ if (customTransforms !== undefined && customTransforms.beforeTs !== undefined) {
391
136
  beforeTransforms.push.apply(beforeTransforms, tslib_1.__spread(customTransforms.beforeTs));
392
137
  }
393
138
  var emitSpan = this.perfRecorder.start('emit');
394
139
  var emitResults = [];
395
- var typeCheckFile = typescript_1.getSourceFileOrNull(this.tsProgram, this.typeCheckFilePath);
396
140
  try {
397
- for (var _b = tslib_1.__values(this.tsProgram.getSourceFiles()), _c = _b.next(); !_c.done; _c = _b.next()) {
398
- var targetSourceFile = _c.value;
399
- if (targetSourceFile.isDeclarationFile || targetSourceFile === typeCheckFile) {
141
+ for (var _c = tslib_1.__values(this.tsProgram.getSourceFiles()), _d = _c.next(); !_d.done; _d = _c.next()) {
142
+ var targetSourceFile = _d.value;
143
+ if (targetSourceFile.isDeclarationFile || ignoreFiles.has(targetSourceFile)) {
400
144
  continue;
401
145
  }
402
- if (this.incrementalDriver.safeToSkipEmit(targetSourceFile)) {
146
+ if (this.compiler.incrementalDriver.safeToSkipEmit(targetSourceFile)) {
403
147
  continue;
404
148
  }
405
149
  var fileEmitSpan = this.perfRecorder.start('emitFile', targetSourceFile);
@@ -418,12 +162,12 @@
418
162
  this.perfRecorder.stop(fileEmitSpan);
419
163
  }
420
164
  }
421
- catch (e_3_1) { e_3 = { error: e_3_1 }; }
165
+ catch (e_1_1) { e_1 = { error: e_1_1 }; }
422
166
  finally {
423
167
  try {
424
- if (_c && !_c.done && (_a = _b.return)) _a.call(_b);
168
+ if (_d && !_d.done && (_a = _c.return)) _a.call(_c);
425
169
  }
426
- finally { if (e_3) throw e_3.error; }
170
+ finally { if (e_1) throw e_1.error; }
427
171
  }
428
172
  this.perfRecorder.stop(emitSpan);
429
173
  if (this.perfTracker !== null && this.options.tracePerformance !== undefined) {
@@ -432,314 +176,18 @@
432
176
  // Run the emit, including a custom transformer that will downlevel the Ivy decorators in code.
433
177
  return ((opts && opts.mergeEmitResultsCallback) || mergeEmitResults)(emitResults);
434
178
  };
435
- NgtscProgram.prototype.getTemplateDiagnostics = function () {
436
- // Determine the strictness level of type checking based on compiler options. As
437
- // `strictTemplates` is a superset of `fullTemplateTypeCheck`, the former implies the latter.
438
- // Also see `verifyCompatibleTypeCheckOptions` where it is verified that `fullTemplateTypeCheck`
439
- // is not disabled when `strictTemplates` is enabled.
440
- var strictTemplates = !!this.options.strictTemplates;
441
- var fullTemplateTypeCheck = strictTemplates || !!this.options.fullTemplateTypeCheck;
442
- // Skip template type-checking if it's disabled.
443
- if (this.options.ivyTemplateTypeCheck === false && !fullTemplateTypeCheck) {
444
- return [];
445
- }
446
- var compilation = this.ensureAnalyzed();
447
- // Run template type-checking.
448
- // First select a type-checking configuration, based on whether full template type-checking is
449
- // requested.
450
- var typeCheckingConfig;
451
- if (fullTemplateTypeCheck) {
452
- typeCheckingConfig = {
453
- applyTemplateContextGuards: strictTemplates,
454
- checkQueries: false,
455
- checkTemplateBodies: true,
456
- checkTypeOfInputBindings: strictTemplates,
457
- strictNullInputBindings: strictTemplates,
458
- checkTypeOfAttributes: strictTemplates,
459
- // Even in full template type-checking mode, DOM binding checks are not quite ready yet.
460
- checkTypeOfDomBindings: false,
461
- checkTypeOfOutputEvents: strictTemplates,
462
- checkTypeOfAnimationEvents: strictTemplates,
463
- // Checking of DOM events currently has an adverse effect on developer experience,
464
- // e.g. for `<input (blur)="update($event.target.value)">` enabling this check results in:
465
- // - error TS2531: Object is possibly 'null'.
466
- // - error TS2339: Property 'value' does not exist on type 'EventTarget'.
467
- checkTypeOfDomEvents: strictTemplates,
468
- checkTypeOfDomReferences: strictTemplates,
469
- // Non-DOM references have the correct type in View Engine so there is no strictness flag.
470
- checkTypeOfNonDomReferences: true,
471
- // Pipes are checked in View Engine so there is no strictness flag.
472
- checkTypeOfPipes: true,
473
- strictSafeNavigationTypes: strictTemplates,
474
- };
475
- }
476
- else {
477
- typeCheckingConfig = {
478
- applyTemplateContextGuards: false,
479
- checkQueries: false,
480
- checkTemplateBodies: false,
481
- checkTypeOfInputBindings: false,
482
- strictNullInputBindings: false,
483
- checkTypeOfAttributes: false,
484
- checkTypeOfDomBindings: false,
485
- checkTypeOfOutputEvents: false,
486
- checkTypeOfAnimationEvents: false,
487
- checkTypeOfDomEvents: false,
488
- checkTypeOfDomReferences: false,
489
- checkTypeOfNonDomReferences: false,
490
- checkTypeOfPipes: false,
491
- strictSafeNavigationTypes: false,
492
- };
493
- }
494
- // Apply explicitly configured strictness flags on top of the default configuration
495
- // based on "fullTemplateTypeCheck".
496
- if (this.options.strictInputTypes !== undefined) {
497
- typeCheckingConfig.checkTypeOfInputBindings = this.options.strictInputTypes;
498
- typeCheckingConfig.applyTemplateContextGuards = this.options.strictInputTypes;
499
- }
500
- if (this.options.strictNullInputTypes !== undefined) {
501
- typeCheckingConfig.strictNullInputBindings = this.options.strictNullInputTypes;
502
- }
503
- if (this.options.strictOutputEventTypes !== undefined) {
504
- typeCheckingConfig.checkTypeOfOutputEvents = this.options.strictOutputEventTypes;
505
- typeCheckingConfig.checkTypeOfAnimationEvents = this.options.strictOutputEventTypes;
506
- }
507
- if (this.options.strictDomEventTypes !== undefined) {
508
- typeCheckingConfig.checkTypeOfDomEvents = this.options.strictDomEventTypes;
509
- }
510
- if (this.options.strictSafeNavigationTypes !== undefined) {
511
- typeCheckingConfig.strictSafeNavigationTypes = this.options.strictSafeNavigationTypes;
512
- }
513
- if (this.options.strictDomLocalRefTypes !== undefined) {
514
- typeCheckingConfig.checkTypeOfDomReferences = this.options.strictDomLocalRefTypes;
515
- }
516
- if (this.options.strictAttributeTypes !== undefined) {
517
- typeCheckingConfig.checkTypeOfAttributes = this.options.strictAttributeTypes;
518
- }
519
- // Execute the typeCheck phase of each decorator in the program.
520
- var prepSpan = this.perfRecorder.start('typeCheckPrep');
521
- var ctx = new typecheck_1.TypeCheckContext(typeCheckingConfig, this.refEmitter, this.reflector, this.typeCheckFilePath);
522
- compilation.typeCheck(ctx);
523
- this.perfRecorder.stop(prepSpan);
524
- // Get the diagnostics.
525
- var typeCheckSpan = this.perfRecorder.start('typeCheckDiagnostics');
526
- var _a = ctx.calculateTemplateDiagnostics(this.tsProgram, this.host, this.options), diagnostics = _a.diagnostics, program = _a.program;
527
- this.perfRecorder.stop(typeCheckSpan);
528
- this.reuseTsProgram = program;
529
- return diagnostics;
530
- };
531
179
  NgtscProgram.prototype.getIndexedComponents = function () {
532
- var compilation = this.ensureAnalyzed();
533
- var context = new indexer_1.IndexingContext();
534
- compilation.index(context);
535
- return transform_1.generateAnalysis(context);
180
+ return this.compiler.getIndexedComponents();
536
181
  };
537
- NgtscProgram.prototype.makeCompilation = function () {
538
- var checker = this.tsProgram.getTypeChecker();
539
- // Construct the ReferenceEmitter.
540
- if (this.fileToModuleHost === null || !this.options._useHostForImportGeneration) {
541
- var localImportStrategy = void 0;
542
- // The strategy used for local, in-project imports depends on whether TS has been configured
543
- // with rootDirs. If so, then multiple directories may be mapped in the same "module
544
- // namespace" and the logic of `LogicalProjectStrategy` is required to generate correct
545
- // imports which may cross these multiple directories. Otherwise, plain relative imports are
546
- // sufficient.
547
- if (this.options.rootDir !== undefined ||
548
- (this.options.rootDirs !== undefined && this.options.rootDirs.length > 0)) {
549
- // rootDirs logic is in effect - use the `LogicalProjectStrategy` for in-project relative
550
- // imports.
551
- localImportStrategy =
552
- new imports_1.LogicalProjectStrategy(this.reflector, new file_system_1.LogicalFileSystem(this.rootDirs));
553
- }
554
- else {
555
- // Plain relative imports are all that's needed.
556
- localImportStrategy = new imports_1.RelativePathStrategy(this.reflector);
557
- }
558
- // The CompilerHost doesn't have fileNameToModuleName, so build an NPM-centric reference
559
- // resolution strategy.
560
- this.refEmitter = new imports_1.ReferenceEmitter([
561
- // First, try to use local identifiers if available.
562
- new imports_1.LocalIdentifierStrategy(),
563
- // Next, attempt to use an absolute import.
564
- new imports_1.AbsoluteModuleStrategy(this.tsProgram, checker, this.moduleResolver, this.reflector),
565
- // Finally, check if the reference is being written into a file within the project's .ts
566
- // sources, and use a relative import if so. If this fails, ReferenceEmitter will throw
567
- // an error.
568
- localImportStrategy,
569
- ]);
570
- // If an entrypoint is present, then all user imports should be directed through the
571
- // entrypoint and private exports are not needed. The compiler will validate that all publicly
572
- // visible directives/pipes are importable via this entrypoint.
573
- if (this.entryPoint === null && this.options.generateDeepReexports === true) {
574
- // No entrypoint is present and deep re-exports were requested, so configure the aliasing
575
- // system to generate them.
576
- this.aliasingHost = new imports_1.PrivateExportAliasingHost(this.reflector);
577
- }
578
- }
579
- else {
580
- // The CompilerHost supports fileNameToModuleName, so use that to emit imports.
581
- this.refEmitter = new imports_1.ReferenceEmitter([
582
- // First, try to use local identifiers if available.
583
- new imports_1.LocalIdentifierStrategy(),
584
- // Then use aliased references (this is a workaround to StrictDeps checks).
585
- new imports_1.AliasStrategy(),
586
- // Then use fileNameToModuleName to emit imports.
587
- new imports_1.FileToModuleStrategy(this.reflector, this.fileToModuleHost),
588
- ]);
589
- this.aliasingHost = new imports_1.FileToModuleAliasingHost(this.fileToModuleHost);
590
- }
591
- var evaluator = new partial_evaluator_1.PartialEvaluator(this.reflector, checker, this.incrementalDriver.depGraph);
592
- var dtsReader = new metadata_1.DtsMetadataReader(checker, this.reflector);
593
- var localMetaRegistry = new metadata_1.LocalMetadataRegistry();
594
- var localMetaReader = localMetaRegistry;
595
- var depScopeReader = new scope_1.MetadataDtsModuleScopeResolver(dtsReader, this.aliasingHost);
596
- this.scopeRegistry = new scope_1.LocalModuleScopeRegistry(localMetaReader, depScopeReader, this.refEmitter, this.aliasingHost);
597
- var scopeReader = this.scopeRegistry;
598
- var metaRegistry = new metadata_1.CompoundMetadataRegistry([localMetaRegistry, this.scopeRegistry]);
599
- var injectableRegistry = new registry_1.InjectableClassRegistry(this.reflector);
600
- this.metaReader = new metadata_1.CompoundMetadataReader([localMetaReader, dtsReader]);
601
- // If a flat module entrypoint was specified, then track references via a `ReferenceGraph` in
602
- // order to produce proper diagnostics for incorrectly exported directives/pipes/etc. If there
603
- // is no flat module entrypoint then don't pay the cost of tracking references.
604
- var referencesRegistry;
605
- if (this.entryPoint !== null) {
606
- this.exportReferenceGraph = new entry_point_1.ReferenceGraph();
607
- referencesRegistry = new ReferenceGraphAdapter(this.exportReferenceGraph);
608
- }
609
- else {
610
- referencesRegistry = new annotations_1.NoopReferencesRegistry();
611
- }
612
- this.routeAnalyzer = new routing_1.NgModuleRouteAnalyzer(this.moduleResolver, evaluator);
613
- this.dtsTransforms = new transform_2.DtsTransformRegistry();
614
- this.mwpScanner = new modulewithproviders_1.ModuleWithProvidersScanner(this.reflector, evaluator, this.refEmitter);
615
- // Set up the IvyCompilation, which manages state for the Ivy transformer.
616
- var handlers = [
617
- new annotations_1.ComponentDecoratorHandler(this.reflector, evaluator, metaRegistry, this.metaReader, scopeReader, this.scopeRegistry, this.isCore, this.resourceManager, this.rootDirs, this.options.preserveWhitespaces || false, this.options.i18nUseExternalIds !== false, this.options.enableI18nLegacyMessageIdFormat !== false, this.moduleResolver, this.cycleAnalyzer, this.refEmitter, this.defaultImportTracker, this.incrementalDriver.depGraph, injectableRegistry, this.closureCompilerEnabled),
618
- // TODO(alxhub): understand why the cast here is necessary (something to do with `null` not
619
- // being assignable to `unknown` when wrapped in `Readonly`).
620
- // clang-format off
621
- new annotations_1.DirectiveDecoratorHandler(this.reflector, evaluator, metaRegistry, this.scopeRegistry, this.metaReader, this.defaultImportTracker, injectableRegistry, this.isCore, this.closureCompilerEnabled),
622
- // clang-format on
623
- // Pipe handler must be before injectable handler in list so pipe factories are printed
624
- // before injectable factories (so injectable factories can delegate to them)
625
- new annotations_1.PipeDecoratorHandler(this.reflector, evaluator, metaRegistry, this.scopeRegistry, this.defaultImportTracker, injectableRegistry, this.isCore),
626
- new annotations_1.InjectableDecoratorHandler(this.reflector, this.defaultImportTracker, this.isCore, this.options.strictInjectionParameters || false, injectableRegistry),
627
- new annotations_1.NgModuleDecoratorHandler(this.reflector, evaluator, this.metaReader, metaRegistry, this.scopeRegistry, referencesRegistry, this.isCore, this.routeAnalyzer, this.refEmitter, this.factoryTracker, this.defaultImportTracker, this.closureCompilerEnabled, injectableRegistry, this.options.i18nInLocale),
628
- ];
629
- return new transform_2.TraitCompiler(handlers, this.reflector, this.perfRecorder, this.incrementalDriver, this.options.compileNonExportedClasses !== false, this.dtsTransforms);
182
+ NgtscProgram.prototype.getLibrarySummaries = function () {
183
+ throw new Error('Method not implemented.');
630
184
  };
631
- /**
632
- * Reifies the inter-dependencies of NgModules and the components within their compilation scopes
633
- * into the `IncrementalDriver`'s dependency graph.
634
- */
635
- NgtscProgram.prototype.recordNgModuleScopeDependencies = function () {
636
- var e_5, _a, e_6, _b, e_7, _c;
637
- var recordSpan = this.perfRecorder.start('recordDependencies');
638
- var depGraph = this.incrementalDriver.depGraph;
639
- try {
640
- for (var _d = tslib_1.__values(this.scopeRegistry.getCompilationScopes()), _e = _d.next(); !_e.done; _e = _d.next()) {
641
- var scope = _e.value;
642
- var file = scope.declaration.getSourceFile();
643
- var ngModuleFile = scope.ngModule.getSourceFile();
644
- // A change to any dependency of the declaration causes the declaration to be invalidated,
645
- // which requires the NgModule to be invalidated as well.
646
- depGraph.addTransitiveDependency(ngModuleFile, file);
647
- // A change to the NgModule file should cause the declaration itself to be invalidated.
648
- depGraph.addDependency(file, ngModuleFile);
649
- var meta = this.metaReader.getDirectiveMetadata(new imports_1.Reference(scope.declaration));
650
- if (meta !== null && meta.isComponent) {
651
- // If a component's template changes, it might have affected the import graph, and thus the
652
- // remote scoping feature which is activated in the event of potential import cycles. Thus,
653
- // the module depends not only on the transitive dependencies of the component, but on its
654
- // resources as well.
655
- depGraph.addTransitiveResources(ngModuleFile, file);
656
- try {
657
- // A change to any directive/pipe in the compilation scope should cause the component to be
658
- // invalidated.
659
- for (var _f = (e_6 = void 0, tslib_1.__values(scope.directives)), _g = _f.next(); !_g.done; _g = _f.next()) {
660
- var directive = _g.value;
661
- // When a directive in scope is updated, the component needs to be recompiled as e.g. a
662
- // selector may have changed.
663
- depGraph.addTransitiveDependency(file, directive.ref.node.getSourceFile());
664
- }
665
- }
666
- catch (e_6_1) { e_6 = { error: e_6_1 }; }
667
- finally {
668
- try {
669
- if (_g && !_g.done && (_b = _f.return)) _b.call(_f);
670
- }
671
- finally { if (e_6) throw e_6.error; }
672
- }
673
- try {
674
- for (var _h = (e_7 = void 0, tslib_1.__values(scope.pipes)), _j = _h.next(); !_j.done; _j = _h.next()) {
675
- var pipe = _j.value;
676
- // When a pipe in scope is updated, the component needs to be recompiled as e.g. the
677
- // pipe's name may have changed.
678
- depGraph.addTransitiveDependency(file, pipe.ref.node.getSourceFile());
679
- }
680
- }
681
- catch (e_7_1) { e_7 = { error: e_7_1 }; }
682
- finally {
683
- try {
684
- if (_j && !_j.done && (_c = _h.return)) _c.call(_h);
685
- }
686
- finally { if (e_7) throw e_7.error; }
687
- }
688
- }
689
- }
690
- }
691
- catch (e_5_1) { e_5 = { error: e_5_1 }; }
692
- finally {
693
- try {
694
- if (_e && !_e.done && (_a = _d.return)) _a.call(_d);
695
- }
696
- finally { if (e_5) throw e_5.error; }
697
- }
698
- this.perfRecorder.stop(recordSpan);
185
+ NgtscProgram.prototype.getEmittedGeneratedFiles = function () {
186
+ throw new Error('Method not implemented.');
187
+ };
188
+ NgtscProgram.prototype.getEmittedSourceFiles = function () {
189
+ throw new Error('Method not implemented.');
699
190
  };
700
- Object.defineProperty(NgtscProgram.prototype, "reflector", {
701
- get: function () {
702
- if (this._reflector === undefined) {
703
- this._reflector = new reflection_1.TypeScriptReflectionHost(this.tsProgram.getTypeChecker());
704
- }
705
- return this._reflector;
706
- },
707
- enumerable: true,
708
- configurable: true
709
- });
710
- Object.defineProperty(NgtscProgram.prototype, "coreImportsFrom", {
711
- get: function () {
712
- if (this._coreImportsFrom === undefined) {
713
- this._coreImportsFrom = this.isCore && getR3SymbolsFile(this.tsProgram) || null;
714
- }
715
- return this._coreImportsFrom;
716
- },
717
- enumerable: true,
718
- configurable: true
719
- });
720
- Object.defineProperty(NgtscProgram.prototype, "isCore", {
721
- get: function () {
722
- if (this._isCore === undefined) {
723
- this._isCore = isAngularCorePackage(this.tsProgram);
724
- }
725
- return this._isCore;
726
- },
727
- enumerable: true,
728
- configurable: true
729
- });
730
- Object.defineProperty(NgtscProgram.prototype, "importRewriter", {
731
- get: function () {
732
- if (this._importRewriter === undefined) {
733
- var coreImportsFrom = this.coreImportsFrom;
734
- this._importRewriter = coreImportsFrom !== null ?
735
- new imports_1.R3SymbolsImportRewriter(coreImportsFrom.fileName) :
736
- new imports_1.NoopImportRewriter();
737
- }
738
- return this._importRewriter;
739
- },
740
- enumerable: true,
741
- configurable: true
742
- });
743
191
  return NgtscProgram;
744
192
  }());
745
193
  exports.NgtscProgram = NgtscProgram;
@@ -748,7 +196,7 @@
748
196
  return program.emit(targetSourceFile, writeFile, cancellationToken, emitOnlyDtsFiles, customTransformers);
749
197
  };
750
198
  function mergeEmitResults(emitResults) {
751
- var e_8, _a;
199
+ var e_3, _a;
752
200
  var diagnostics = [];
753
201
  var emitSkipped = false;
754
202
  var emittedFiles = [];
@@ -760,110 +208,14 @@
760
208
  emittedFiles.push.apply(emittedFiles, tslib_1.__spread((er.emittedFiles || [])));
761
209
  }
762
210
  }
763
- catch (e_8_1) { e_8 = { error: e_8_1 }; }
211
+ catch (e_3_1) { e_3 = { error: e_3_1 }; }
764
212
  finally {
765
213
  try {
766
214
  if (emitResults_1_1 && !emitResults_1_1.done && (_a = emitResults_1.return)) _a.call(emitResults_1);
767
215
  }
768
- finally { if (e_8) throw e_8.error; }
216
+ finally { if (e_3) throw e_3.error; }
769
217
  }
770
218
  return { diagnostics: diagnostics, emitSkipped: emitSkipped, emittedFiles: emittedFiles };
771
219
  }
772
- /**
773
- * Find the 'r3_symbols.ts' file in the given `Program`, or return `null` if it wasn't there.
774
- */
775
- function getR3SymbolsFile(program) {
776
- return program.getSourceFiles().find(function (file) { return file.fileName.indexOf('r3_symbols.ts') >= 0; }) || null;
777
- }
778
- /**
779
- * Determine if the given `Program` is @angular/core.
780
- */
781
- function isAngularCorePackage(program) {
782
- // Look for its_just_angular.ts somewhere in the program.
783
- var r3Symbols = getR3SymbolsFile(program);
784
- if (r3Symbols === null) {
785
- return false;
786
- }
787
- // Look for the constant ITS_JUST_ANGULAR in that file.
788
- return r3Symbols.statements.some(function (stmt) {
789
- // The statement must be a variable declaration statement.
790
- if (!ts.isVariableStatement(stmt)) {
791
- return false;
792
- }
793
- // It must be exported.
794
- if (stmt.modifiers === undefined ||
795
- !stmt.modifiers.some(function (mod) { return mod.kind === ts.SyntaxKind.ExportKeyword; })) {
796
- return false;
797
- }
798
- // It must declare ITS_JUST_ANGULAR.
799
- return stmt.declarationList.declarations.some(function (decl) {
800
- // The declaration must match the name.
801
- if (!ts.isIdentifier(decl.name) || decl.name.text !== 'ITS_JUST_ANGULAR') {
802
- return false;
803
- }
804
- // It must initialize the variable to true.
805
- if (decl.initializer === undefined || decl.initializer.kind !== ts.SyntaxKind.TrueKeyword) {
806
- return false;
807
- }
808
- // This definition matches.
809
- return true;
810
- });
811
- });
812
- }
813
- /**
814
- * Since "strictTemplates" is a true superset of type checking capabilities compared to
815
- * "strictTemplateTypeCheck", it is required that the latter is not explicitly disabled if the
816
- * former is enabled.
817
- */
818
- function verifyCompatibleTypeCheckOptions(options) {
819
- if (options.fullTemplateTypeCheck === false && options.strictTemplates === true) {
820
- return {
821
- category: ts.DiagnosticCategory.Error,
822
- code: diagnostics_1.ngErrorCode(diagnostics_1.ErrorCode.CONFIG_STRICT_TEMPLATES_IMPLIES_FULL_TEMPLATE_TYPECHECK),
823
- file: undefined,
824
- start: undefined,
825
- length: undefined,
826
- messageText: "Angular compiler option \"strictTemplates\" is enabled, however \"fullTemplateTypeCheck\" is disabled.\n\nHaving the \"strictTemplates\" flag enabled implies that \"fullTemplateTypeCheck\" is also enabled, so\nthe latter can not be explicitly disabled.\n\nOne of the following actions is required:\n1. Remove the \"fullTemplateTypeCheck\" option.\n2. Remove \"strictTemplates\" or set it to 'false'.\n\nMore information about the template type checking compiler options can be found in the documentation:\nhttps://v9.angular.io/guide/template-typecheck#template-type-checking",
827
- };
828
- }
829
- return null;
830
- }
831
- var ReferenceGraphAdapter = /** @class */ (function () {
832
- function ReferenceGraphAdapter(graph) {
833
- this.graph = graph;
834
- }
835
- ReferenceGraphAdapter.prototype.add = function (source) {
836
- var e_9, _a;
837
- var references = [];
838
- for (var _i = 1; _i < arguments.length; _i++) {
839
- references[_i - 1] = arguments[_i];
840
- }
841
- try {
842
- for (var references_1 = tslib_1.__values(references), references_1_1 = references_1.next(); !references_1_1.done; references_1_1 = references_1.next()) {
843
- var node = references_1_1.value.node;
844
- var sourceFile = node.getSourceFile();
845
- if (sourceFile === undefined) {
846
- sourceFile = ts.getOriginalNode(node).getSourceFile();
847
- }
848
- // Only record local references (not references into .d.ts files).
849
- if (sourceFile === undefined || !typescript_1.isDtsPath(sourceFile.fileName)) {
850
- this.graph.add(source, node);
851
- }
852
- }
853
- }
854
- catch (e_9_1) { e_9 = { error: e_9_1 }; }
855
- finally {
856
- try {
857
- if (references_1_1 && !references_1_1.done && (_a = references_1.return)) _a.call(references_1);
858
- }
859
- finally { if (e_9) throw e_9.error; }
860
- }
861
- };
862
- return ReferenceGraphAdapter;
863
- }());
864
- exports.ReferenceGraphAdapter = ReferenceGraphAdapter;
865
- function shouldEnablePerfTracing(options) {
866
- return options.tracePerformance !== undefined;
867
- }
868
220
  });
869
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"program.js","sourceRoot":"","sources":["../../../../../../../packages/compiler-cli/src/ngtsc/program.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 {GeneratedFile, Type} from '@angular/compiler';\nimport * as ts from 'typescript';\n\nimport * as api from '../transformers/api';\nimport {nocollapseHack} from '../transformers/nocollapse_hack';\nimport {verifySupportedTypeScriptVersion} from '../typescript_support';\n\nimport {ComponentDecoratorHandler, DirectiveDecoratorHandler, InjectableDecoratorHandler, NgModuleDecoratorHandler, NoopReferencesRegistry, PipeDecoratorHandler, ReferencesRegistry} from './annotations';\nimport {CycleAnalyzer, ImportGraph} from './cycles';\nimport {ErrorCode, ngErrorCode} from './diagnostics';\nimport {FlatIndexGenerator, ReferenceGraph, checkForPrivateExports, findFlatIndexEntryPoint} from './entry_point';\nimport {AbsoluteFsPath, LogicalFileSystem, absoluteFrom} from './file_system';\nimport {AbsoluteModuleStrategy, AliasStrategy, AliasingHost, DefaultImportTracker, FileToModuleAliasingHost, FileToModuleHost, FileToModuleStrategy, ImportRewriter, LocalIdentifierStrategy, LogicalProjectStrategy, ModuleResolver, NoopImportRewriter, PrivateExportAliasingHost, R3SymbolsImportRewriter, Reference, ReferenceEmitStrategy, ReferenceEmitter, RelativePathStrategy} from './imports';\nimport {IncrementalDriver} from './incremental';\nimport {IndexedComponent, IndexingContext} from './indexer';\nimport {generateAnalysis} from './indexer/src/transform';\nimport {CompoundMetadataReader, CompoundMetadataRegistry, DtsMetadataReader, LocalMetadataRegistry, MetadataReader} from './metadata';\nimport {InjectableClassRegistry} from './metadata/src/registry';\nimport {ModuleWithProvidersScanner} from './modulewithproviders';\nimport {PartialEvaluator} from './partial_evaluator';\nimport {NOOP_PERF_RECORDER, PerfRecorder, PerfTracker} from './perf';\nimport {TypeScriptReflectionHost} from './reflection';\nimport {HostResourceLoader} from './resource_loader';\nimport {NgModuleRouteAnalyzer, entryPointKeyFor} from './routing';\nimport {ComponentScopeReader, CompoundComponentScopeReader, LocalModuleScopeRegistry, MetadataDtsModuleScopeResolver} from './scope';\nimport {FactoryGenerator, FactoryTracker, GeneratedShimsHostWrapper, ShimGenerator, SummaryGenerator, TypeCheckShimGenerator, generatedFactoryTransform} from './shims';\nimport {ivySwitchTransform} from './switch';\nimport {DecoratorHandler, DtsTransformRegistry, TraitCompiler, declarationTransformFactory, ivyTransformFactory} from './transform';\nimport {aliasTransformFactory} from './transform/src/alias';\nimport {TypeCheckContext, TypeCheckingConfig, typeCheckFilePath} from './typecheck';\nimport {normalizeSeparators} from './util/src/path';\nimport {getRootDirs, getSourceFileOrNull, isDtsPath, resolveModuleName} from './util/src/typescript';\n\nexport class NgtscProgram implements api.Program {\n  private tsProgram: ts.Program;\n  private reuseTsProgram: ts.Program;\n  private resourceManager: HostResourceLoader;\n  private compilation: TraitCompiler|undefined = undefined;\n  private _coreImportsFrom: ts.SourceFile|null|undefined = undefined;\n  private _importRewriter: ImportRewriter|undefined = undefined;\n  private _reflector: TypeScriptReflectionHost|undefined = undefined;\n  private _isCore: boolean|undefined = undefined;\n  private rootDirs: AbsoluteFsPath[];\n  private closureCompilerEnabled: boolean;\n  private entryPoint: ts.SourceFile|null;\n  private exportReferenceGraph: ReferenceGraph|null = null;\n  private flatIndexGenerator: FlatIndexGenerator|null = null;\n  private routeAnalyzer: NgModuleRouteAnalyzer|null = null;\n  private scopeRegistry: LocalModuleScopeRegistry|null = null;\n\n  private constructionDiagnostics: ts.Diagnostic[] = [];\n  private moduleResolver: ModuleResolver;\n  private cycleAnalyzer: CycleAnalyzer;\n  private metaReader: MetadataReader|null = null;\n\n  private aliasingHost: AliasingHost|null = null;\n  private refEmitter: ReferenceEmitter|null = null;\n  private fileToModuleHost: FileToModuleHost|null = null;\n  private defaultImportTracker: DefaultImportTracker;\n  private perfRecorder: PerfRecorder = NOOP_PERF_RECORDER;\n  private perfTracker: PerfTracker|null = null;\n  private incrementalDriver: IncrementalDriver;\n  private typeCheckFilePath: AbsoluteFsPath;\n  private factoryTracker: FactoryTracker|null = null;\n\n  private modifiedResourceFiles: Set<string>|null;\n  private dtsTransforms: DtsTransformRegistry|null = null;\n  private mwpScanner: ModuleWithProvidersScanner|null = null;\n\n  constructor(\n      rootNames: ReadonlyArray<string>, private options: api.CompilerOptions,\n      private host: api.CompilerHost, oldProgram?: NgtscProgram) {\n    if (!options.disableTypeScriptVersionCheck) {\n      verifySupportedTypeScriptVersion();\n    }\n\n    const incompatibleTypeCheckOptionsDiagnostic = verifyCompatibleTypeCheckOptions(options);\n    if (incompatibleTypeCheckOptionsDiagnostic !== null) {\n      this.constructionDiagnostics.push(incompatibleTypeCheckOptionsDiagnostic);\n    }\n\n    if (shouldEnablePerfTracing(options)) {\n      this.perfTracker = PerfTracker.zeroedToNow();\n      this.perfRecorder = this.perfTracker;\n    }\n\n    this.modifiedResourceFiles =\n        this.host.getModifiedResourceFiles && this.host.getModifiedResourceFiles() || null;\n    this.rootDirs = getRootDirs(host, options);\n    this.closureCompilerEnabled = !!options.annotateForClosureCompiler;\n    this.resourceManager = new HostResourceLoader(host, options);\n    // TODO(alxhub): remove the fallback to allowEmptyCodegenFiles after verifying that the rest of\n    // our build tooling is no longer relying on it.\n    const allowEmptyCodegenFiles = options.allowEmptyCodegenFiles || false;\n    const shouldGenerateFactoryShims = options.generateNgFactoryShims !== undefined ?\n        options.generateNgFactoryShims :\n        allowEmptyCodegenFiles;\n    const shouldGenerateSummaryShims = options.generateNgSummaryShims !== undefined ?\n        options.generateNgSummaryShims :\n        allowEmptyCodegenFiles;\n    const normalizedRootNames = rootNames.map(n => absoluteFrom(n));\n    if (host.fileNameToModuleName !== undefined) {\n      this.fileToModuleHost = host as FileToModuleHost;\n    }\n    let rootFiles = [...rootNames];\n\n    const generators: ShimGenerator[] = [];\n    let summaryGenerator: SummaryGenerator|null = null;\n    if (shouldGenerateSummaryShims) {\n      // Summary generation.\n      summaryGenerator = SummaryGenerator.forRootFiles(normalizedRootNames);\n      generators.push(summaryGenerator);\n    }\n\n    if (shouldGenerateFactoryShims) {\n      // Factory generation.\n      const factoryGenerator = FactoryGenerator.forRootFiles(normalizedRootNames);\n      const factoryFileMap = factoryGenerator.factoryFileMap;\n\n      const factoryFileNames = Array.from(factoryFileMap.keys());\n      rootFiles.push(...factoryFileNames);\n      generators.push(factoryGenerator);\n\n      this.factoryTracker = new FactoryTracker(factoryGenerator);\n    }\n\n    // Done separately to preserve the order of factory files before summary files in rootFiles.\n    // TODO(alxhub): validate that this is necessary.\n    if (shouldGenerateSummaryShims) {\n      rootFiles.push(...summaryGenerator !.getSummaryFileNames());\n    }\n\n    this.typeCheckFilePath = typeCheckFilePath(this.rootDirs);\n    generators.push(new TypeCheckShimGenerator(this.typeCheckFilePath));\n    rootFiles.push(this.typeCheckFilePath);\n\n    let entryPoint: AbsoluteFsPath|null = null;\n    if (options.flatModuleOutFile != null && options.flatModuleOutFile !== '') {\n      entryPoint = findFlatIndexEntryPoint(normalizedRootNames);\n      if (entryPoint === null) {\n        // This error message talks specifically about having a single .ts file in \"files\". However\n        // the actual logic is a bit more permissive. If a single file exists, that will be taken,\n        // otherwise the highest level (shortest path) \"index.ts\" file will be used as the flat\n        // module entry point instead. If neither of these conditions apply, the error below is\n        // given.\n        //\n        // The user is not informed about the \"index.ts\" option as this behavior is deprecated -\n        // an explicit entrypoint should always be specified.\n        this.constructionDiagnostics.push({\n          category: ts.DiagnosticCategory.Error,\n          code: ngErrorCode(ErrorCode.CONFIG_FLAT_MODULE_NO_INDEX),\n          file: undefined,\n          start: undefined,\n          length: undefined,\n          messageText:\n              'Angular compiler option \"flatModuleOutFile\" requires one and only one .ts file in the \"files\" field.',\n        });\n      } else {\n        const flatModuleId = options.flatModuleId || null;\n        const flatModuleOutFile = normalizeSeparators(options.flatModuleOutFile);\n        this.flatIndexGenerator =\n            new FlatIndexGenerator(entryPoint, flatModuleOutFile, flatModuleId);\n        generators.push(this.flatIndexGenerator);\n        rootFiles.push(this.flatIndexGenerator.flatIndexPath);\n      }\n    }\n\n    if (generators.length > 0) {\n      // FIXME: Remove the any cast once google3 is fully on TS3.6.\n      this.host = (new GeneratedShimsHostWrapper(host, generators) as any);\n    }\n\n    this.tsProgram =\n        ts.createProgram(rootFiles, options, this.host, oldProgram && oldProgram.reuseTsProgram);\n    this.reuseTsProgram = this.tsProgram;\n\n    this.entryPoint = entryPoint !== null ? getSourceFileOrNull(this.tsProgram, entryPoint) : null;\n    const moduleResolutionCache = ts.createModuleResolutionCache(\n        this.host.getCurrentDirectory(), fileName => this.host.getCanonicalFileName(fileName));\n    this.moduleResolver =\n        new ModuleResolver(this.tsProgram, options, this.host, moduleResolutionCache);\n    this.cycleAnalyzer = new CycleAnalyzer(new ImportGraph(this.moduleResolver));\n    this.defaultImportTracker = new DefaultImportTracker();\n    if (oldProgram === undefined) {\n      this.incrementalDriver = IncrementalDriver.fresh(this.tsProgram);\n    } else {\n      this.incrementalDriver = IncrementalDriver.reconcile(\n          oldProgram.reuseTsProgram, oldProgram.incrementalDriver, this.tsProgram,\n          this.modifiedResourceFiles);\n    }\n  }\n\n  getTsProgram(): ts.Program { return this.tsProgram; }\n\n  getTsOptionDiagnostics(cancellationToken?: ts.CancellationToken|\n                         undefined): ReadonlyArray<ts.Diagnostic> {\n    return this.tsProgram.getOptionsDiagnostics(cancellationToken);\n  }\n\n  getNgOptionDiagnostics(cancellationToken?: ts.CancellationToken|\n                         undefined): ReadonlyArray<ts.Diagnostic> {\n    return this.constructionDiagnostics;\n  }\n\n  getTsSyntacticDiagnostics(\n      sourceFile?: ts.SourceFile|undefined,\n      cancellationToken?: ts.CancellationToken|undefined): ReadonlyArray<ts.Diagnostic> {\n    return this.tsProgram.getSyntacticDiagnostics(sourceFile, cancellationToken);\n  }\n\n  getNgStructuralDiagnostics(cancellationToken?: ts.CancellationToken|\n                             undefined): ReadonlyArray<api.Diagnostic> {\n    return [];\n  }\n\n  getTsSemanticDiagnostics(\n      sourceFile?: ts.SourceFile|undefined,\n      cancellationToken?: ts.CancellationToken|undefined): ReadonlyArray<ts.Diagnostic> {\n    return this.tsProgram.getSemanticDiagnostics(sourceFile, cancellationToken);\n  }\n\n  getNgSemanticDiagnostics(\n      fileName?: string|undefined,\n      cancellationToken?: ts.CancellationToken|undefined): ReadonlyArray<ts.Diagnostic> {\n    const compilation = this.ensureAnalyzed();\n    const diagnostics = [...compilation.diagnostics, ...this.getTemplateDiagnostics()];\n    if (this.entryPoint !== null && this.exportReferenceGraph !== null) {\n      diagnostics.push(...checkForPrivateExports(\n          this.entryPoint, this.tsProgram.getTypeChecker(), this.exportReferenceGraph));\n    }\n    return diagnostics;\n  }\n\n  async loadNgStructureAsync(): Promise<void> {\n    if (this.compilation === undefined) {\n      this.compilation = this.makeCompilation();\n    }\n    const analyzeSpan = this.perfRecorder.start('analyze');\n    const promises: Promise<void>[] = [];\n    for (const sf of this.tsProgram.getSourceFiles()) {\n      if (sf.isDeclarationFile) {\n        continue;\n      }\n\n      const analyzeFileSpan = this.perfRecorder.start('analyzeFile', sf);\n      let analysisPromise = this.compilation !.analyzeAsync(sf);\n      this.scanForMwp(sf);\n      if (analysisPromise === undefined) {\n        this.perfRecorder.stop(analyzeFileSpan);\n      } else if (this.perfRecorder.enabled) {\n        analysisPromise = analysisPromise.then(() => this.perfRecorder.stop(analyzeFileSpan));\n      }\n      if (analysisPromise !== undefined) {\n        promises.push(analysisPromise);\n      }\n    }\n\n    await Promise.all(promises);\n\n    this.perfRecorder.stop(analyzeSpan);\n\n    this.resolveCompilation(this.compilation);\n  }\n\n  listLazyRoutes(entryRoute?: string|undefined): api.LazyRoute[] {\n    if (entryRoute) {\n      // Note:\n      // This resolution step is here to match the implementation of the old `AotCompilerHost` (see\n      // https://github.com/angular/angular/blob/50732e156/packages/compiler-cli/src/transformers/compiler_host.ts#L175-L188).\n      //\n      // `@angular/cli` will always call this API with an absolute path, so the resolution step is\n      // not necessary, but keeping it backwards compatible in case someone else is using the API.\n\n      // Relative entry paths are disallowed.\n      if (entryRoute.startsWith('.')) {\n        throw new Error(\n            `Failed to list lazy routes: Resolution of relative paths (${entryRoute}) is not supported.`);\n      }\n\n      // Non-relative entry paths fall into one of the following categories:\n      // - Absolute system paths (e.g. `/foo/bar/my-project/my-module`), which are unaffected by the\n      //   logic below.\n      // - Paths to enternal modules (e.g. `some-lib`).\n      // - Paths mapped to directories in `tsconfig.json` (e.g. `shared/my-module`).\n      //   (See https://www.typescriptlang.org/docs/handbook/module-resolution.html#path-mapping.)\n      //\n      // In all cases above, the `containingFile` argument is ignored, so we can just take the first\n      // of the root files.\n      const containingFile = this.tsProgram.getRootFileNames()[0];\n      const [entryPath, moduleName] = entryRoute.split('#');\n      const resolvedModule =\n          resolveModuleName(entryPath, containingFile, this.options, this.host, null);\n\n      if (resolvedModule) {\n        entryRoute = entryPointKeyFor(resolvedModule.resolvedFileName, moduleName);\n      }\n    }\n\n    this.ensureAnalyzed();\n    return this.routeAnalyzer !.listLazyRoutes(entryRoute);\n  }\n\n  getLibrarySummaries(): Map<string, api.LibrarySummary> {\n    throw new Error('Method not implemented.');\n  }\n\n  getEmittedGeneratedFiles(): Map<string, GeneratedFile> {\n    throw new Error('Method not implemented.');\n  }\n\n  getEmittedSourceFiles(): Map<string, ts.SourceFile> {\n    throw new Error('Method not implemented.');\n  }\n\n  private scanForMwp(sf: ts.SourceFile): void {\n    this.mwpScanner !.scan(sf, {\n      addTypeReplacement: (node: ts.Declaration, type: Type): void => {\n        // Only obtain the return type transform for the source file once there's a type to replace,\n        // so that no transform is allocated when there's nothing to do.\n        this.dtsTransforms !.getReturnTypeTransform(sf).addTypeReplacement(node, type);\n      }\n    });\n  }\n\n  private ensureAnalyzed(): TraitCompiler {\n    if (this.compilation === undefined) {\n      const analyzeSpan = this.perfRecorder.start('analyze');\n      this.compilation = this.makeCompilation();\n      for (const sf of this.tsProgram.getSourceFiles()) {\n        if (sf.isDeclarationFile) {\n          continue;\n        }\n        const analyzeFileSpan = this.perfRecorder.start('analyzeFile', sf);\n        this.compilation !.analyzeSync(sf);\n        this.scanForMwp(sf);\n        this.perfRecorder.stop(analyzeFileSpan);\n      }\n      this.perfRecorder.stop(analyzeSpan);\n\n      this.resolveCompilation(this.compilation);\n    }\n    return this.compilation;\n  }\n\n  private resolveCompilation(compilation: TraitCompiler): void {\n    compilation.resolve();\n\n    this.recordNgModuleScopeDependencies();\n\n    // At this point, analysis is complete and the compiler can now calculate which files need to\n    // be emitted, so do that.\n    this.incrementalDriver.recordSuccessfulAnalysis(compilation);\n  }\n\n  emit(opts?: {\n    emitFlags?: api.EmitFlags,\n    cancellationToken?: ts.CancellationToken,\n    customTransformers?: api.CustomTransformers,\n    emitCallback?: api.TsEmitCallback,\n    mergeEmitResultsCallback?: api.TsMergeEmitResultsCallback\n  }): ts.EmitResult {\n    const emitCallback = opts && opts.emitCallback || defaultEmitCallback;\n\n    const compilation = this.ensureAnalyzed();\n\n    const writeFile: ts.WriteFileCallback =\n        (fileName: string, data: string, writeByteOrderMark: boolean,\n         onError: ((message: string) => void) | undefined,\n         sourceFiles: ReadonlyArray<ts.SourceFile>| undefined) => {\n          if (sourceFiles !== undefined) {\n            // Record successful writes for any `ts.SourceFile` (that's not a declaration file)\n            // that's an input to this write.\n            for (const writtenSf of sourceFiles) {\n              if (writtenSf.isDeclarationFile) {\n                continue;\n              }\n\n              this.incrementalDriver.recordSuccessfulEmit(writtenSf);\n            }\n          }\n          if (this.closureCompilerEnabled && fileName.endsWith('.js')) {\n            data = nocollapseHack(data);\n          }\n          this.host.writeFile(fileName, data, writeByteOrderMark, onError, sourceFiles);\n        };\n\n    const customTransforms = opts && opts.customTransformers;\n\n    const beforeTransforms = [\n      ivyTransformFactory(\n          compilation, this.reflector, this.importRewriter, this.defaultImportTracker, this.isCore,\n          this.closureCompilerEnabled),\n      aliasTransformFactory(compilation.exportStatements) as ts.TransformerFactory<ts.SourceFile>,\n      this.defaultImportTracker.importPreservingTransformer(),\n    ];\n\n    const afterDeclarationsTransforms: ts.TransformerFactory<ts.Bundle|ts.SourceFile>[] = [];\n    if (this.dtsTransforms !== null) {\n      afterDeclarationsTransforms.push(\n          declarationTransformFactory(this.dtsTransforms, this.importRewriter));\n    }\n\n    // Only add aliasing re-exports to the .d.ts output if the `AliasingHost` requests it.\n    if (this.aliasingHost !== null && this.aliasingHost.aliasExportsInDts) {\n      afterDeclarationsTransforms.push(aliasTransformFactory(compilation.exportStatements));\n    }\n\n    if (this.factoryTracker !== null) {\n      beforeTransforms.push(\n          generatedFactoryTransform(this.factoryTracker.sourceInfo, this.importRewriter));\n    }\n    beforeTransforms.push(ivySwitchTransform);\n    if (customTransforms && customTransforms.beforeTs) {\n      beforeTransforms.push(...customTransforms.beforeTs);\n    }\n\n    const emitSpan = this.perfRecorder.start('emit');\n    const emitResults: ts.EmitResult[] = [];\n\n    const typeCheckFile = getSourceFileOrNull(this.tsProgram, this.typeCheckFilePath);\n\n    for (const targetSourceFile of this.tsProgram.getSourceFiles()) {\n      if (targetSourceFile.isDeclarationFile || targetSourceFile === typeCheckFile) {\n        continue;\n      }\n\n      if (this.incrementalDriver.safeToSkipEmit(targetSourceFile)) {\n        continue;\n      }\n\n      const fileEmitSpan = this.perfRecorder.start('emitFile', targetSourceFile);\n      emitResults.push(emitCallback({\n        targetSourceFile,\n        program: this.tsProgram,\n        host: this.host,\n        options: this.options,\n        emitOnlyDtsFiles: false, writeFile,\n        customTransformers: {\n          before: beforeTransforms,\n          after: customTransforms && customTransforms.afterTs,\n          afterDeclarations: afterDeclarationsTransforms,\n        },\n      }));\n      this.perfRecorder.stop(fileEmitSpan);\n    }\n    this.perfRecorder.stop(emitSpan);\n\n    if (this.perfTracker !== null && this.options.tracePerformance !== undefined) {\n      this.perfTracker.serializeToFile(this.options.tracePerformance, this.host);\n    }\n\n    // Run the emit, including a custom transformer that will downlevel the Ivy decorators in code.\n    return ((opts && opts.mergeEmitResultsCallback) || mergeEmitResults)(emitResults);\n  }\n\n  private getTemplateDiagnostics(): ReadonlyArray<ts.Diagnostic> {\n    // Determine the strictness level of type checking based on compiler options. As\n    // `strictTemplates` is a superset of `fullTemplateTypeCheck`, the former implies the latter.\n    // Also see `verifyCompatibleTypeCheckOptions` where it is verified that `fullTemplateTypeCheck`\n    // is not disabled when `strictTemplates` is enabled.\n    const strictTemplates = !!this.options.strictTemplates;\n    const fullTemplateTypeCheck = strictTemplates || !!this.options.fullTemplateTypeCheck;\n\n    // Skip template type-checking if it's disabled.\n    if (this.options.ivyTemplateTypeCheck === false && !fullTemplateTypeCheck) {\n      return [];\n    }\n\n    const compilation = this.ensureAnalyzed();\n\n    // Run template type-checking.\n\n    // First select a type-checking configuration, based on whether full template type-checking is\n    // requested.\n    let typeCheckingConfig: TypeCheckingConfig;\n    if (fullTemplateTypeCheck) {\n      typeCheckingConfig = {\n        applyTemplateContextGuards: strictTemplates,\n        checkQueries: false,\n        checkTemplateBodies: true,\n        checkTypeOfInputBindings: strictTemplates,\n        strictNullInputBindings: strictTemplates,\n        checkTypeOfAttributes: strictTemplates,\n        // Even in full template type-checking mode, DOM binding checks are not quite ready yet.\n        checkTypeOfDomBindings: false,\n        checkTypeOfOutputEvents: strictTemplates,\n        checkTypeOfAnimationEvents: strictTemplates,\n        // Checking of DOM events currently has an adverse effect on developer experience,\n        // e.g. for `<input (blur)=\"update($event.target.value)\">` enabling this check results in:\n        // - error TS2531: Object is possibly 'null'.\n        // - error TS2339: Property 'value' does not exist on type 'EventTarget'.\n        checkTypeOfDomEvents: strictTemplates,\n        checkTypeOfDomReferences: strictTemplates,\n        // Non-DOM references have the correct type in View Engine so there is no strictness flag.\n        checkTypeOfNonDomReferences: true,\n        // Pipes are checked in View Engine so there is no strictness flag.\n        checkTypeOfPipes: true,\n        strictSafeNavigationTypes: strictTemplates,\n      };\n    } else {\n      typeCheckingConfig = {\n        applyTemplateContextGuards: false,\n        checkQueries: false,\n        checkTemplateBodies: false,\n        checkTypeOfInputBindings: false,\n        strictNullInputBindings: false,\n        checkTypeOfAttributes: false,\n        checkTypeOfDomBindings: false,\n        checkTypeOfOutputEvents: false,\n        checkTypeOfAnimationEvents: false,\n        checkTypeOfDomEvents: false,\n        checkTypeOfDomReferences: false,\n        checkTypeOfNonDomReferences: false,\n        checkTypeOfPipes: false,\n        strictSafeNavigationTypes: false,\n      };\n    }\n\n    // Apply explicitly configured strictness flags on top of the default configuration\n    // based on \"fullTemplateTypeCheck\".\n    if (this.options.strictInputTypes !== undefined) {\n      typeCheckingConfig.checkTypeOfInputBindings = this.options.strictInputTypes;\n      typeCheckingConfig.applyTemplateContextGuards = this.options.strictInputTypes;\n    }\n    if (this.options.strictNullInputTypes !== undefined) {\n      typeCheckingConfig.strictNullInputBindings = this.options.strictNullInputTypes;\n    }\n    if (this.options.strictOutputEventTypes !== undefined) {\n      typeCheckingConfig.checkTypeOfOutputEvents = this.options.strictOutputEventTypes;\n      typeCheckingConfig.checkTypeOfAnimationEvents = this.options.strictOutputEventTypes;\n    }\n    if (this.options.strictDomEventTypes !== undefined) {\n      typeCheckingConfig.checkTypeOfDomEvents = this.options.strictDomEventTypes;\n    }\n    if (this.options.strictSafeNavigationTypes !== undefined) {\n      typeCheckingConfig.strictSafeNavigationTypes = this.options.strictSafeNavigationTypes;\n    }\n    if (this.options.strictDomLocalRefTypes !== undefined) {\n      typeCheckingConfig.checkTypeOfDomReferences = this.options.strictDomLocalRefTypes;\n    }\n    if (this.options.strictAttributeTypes !== undefined) {\n      typeCheckingConfig.checkTypeOfAttributes = this.options.strictAttributeTypes;\n    }\n\n    // Execute the typeCheck phase of each decorator in the program.\n    const prepSpan = this.perfRecorder.start('typeCheckPrep');\n    const ctx = new TypeCheckContext(\n        typeCheckingConfig, this.refEmitter !, this.reflector, this.typeCheckFilePath);\n    compilation.typeCheck(ctx);\n    this.perfRecorder.stop(prepSpan);\n\n    // Get the diagnostics.\n    const typeCheckSpan = this.perfRecorder.start('typeCheckDiagnostics');\n    const {diagnostics, program} =\n        ctx.calculateTemplateDiagnostics(this.tsProgram, this.host, this.options);\n    this.perfRecorder.stop(typeCheckSpan);\n    this.reuseTsProgram = program;\n\n    return diagnostics;\n  }\n\n  getIndexedComponents(): Map<ts.Declaration, IndexedComponent> {\n    const compilation = this.ensureAnalyzed();\n    const context = new IndexingContext();\n    compilation.index(context);\n    return generateAnalysis(context);\n  }\n\n  private makeCompilation(): TraitCompiler {\n    const checker = this.tsProgram.getTypeChecker();\n\n    // Construct the ReferenceEmitter.\n    if (this.fileToModuleHost === null || !this.options._useHostForImportGeneration) {\n      let localImportStrategy: ReferenceEmitStrategy;\n\n      // The strategy used for local, in-project imports depends on whether TS has been configured\n      // with rootDirs. If so, then multiple directories may be mapped in the same \"module\n      // namespace\" and the logic of `LogicalProjectStrategy` is required to generate correct\n      // imports which may cross these multiple directories. Otherwise, plain relative imports are\n      // sufficient.\n      if (this.options.rootDir !== undefined ||\n          (this.options.rootDirs !== undefined && this.options.rootDirs.length > 0)) {\n        // rootDirs logic is in effect - use the `LogicalProjectStrategy` for in-project relative\n        // imports.\n        localImportStrategy =\n            new LogicalProjectStrategy(this.reflector, new LogicalFileSystem(this.rootDirs));\n      } else {\n        // Plain relative imports are all that's needed.\n        localImportStrategy = new RelativePathStrategy(this.reflector);\n      }\n\n      // The CompilerHost doesn't have fileNameToModuleName, so build an NPM-centric reference\n      // resolution strategy.\n      this.refEmitter = new ReferenceEmitter([\n        // First, try to use local identifiers if available.\n        new LocalIdentifierStrategy(),\n        // Next, attempt to use an absolute import.\n        new AbsoluteModuleStrategy(this.tsProgram, checker, this.moduleResolver, this.reflector),\n        // Finally, check if the reference is being written into a file within the project's .ts\n        // sources, and use a relative import if so. If this fails, ReferenceEmitter will throw\n        // an error.\n        localImportStrategy,\n      ]);\n\n      // If an entrypoint is present, then all user imports should be directed through the\n      // entrypoint and private exports are not needed. The compiler will validate that all publicly\n      // visible directives/pipes are importable via this entrypoint.\n      if (this.entryPoint === null && this.options.generateDeepReexports === true) {\n        // No entrypoint is present and deep re-exports were requested, so configure the aliasing\n        // system to generate them.\n        this.aliasingHost = new PrivateExportAliasingHost(this.reflector);\n      }\n    } else {\n      // The CompilerHost supports fileNameToModuleName, so use that to emit imports.\n      this.refEmitter = new ReferenceEmitter([\n        // First, try to use local identifiers if available.\n        new LocalIdentifierStrategy(),\n        // Then use aliased references (this is a workaround to StrictDeps checks).\n        new AliasStrategy(),\n        // Then use fileNameToModuleName to emit imports.\n        new FileToModuleStrategy(this.reflector, this.fileToModuleHost),\n      ]);\n      this.aliasingHost = new FileToModuleAliasingHost(this.fileToModuleHost);\n    }\n\n    const evaluator =\n        new PartialEvaluator(this.reflector, checker, this.incrementalDriver.depGraph);\n    const dtsReader = new DtsMetadataReader(checker, this.reflector);\n    const localMetaRegistry = new LocalMetadataRegistry();\n    const localMetaReader: MetadataReader = localMetaRegistry;\n    const depScopeReader = new MetadataDtsModuleScopeResolver(dtsReader, this.aliasingHost);\n    this.scopeRegistry = new LocalModuleScopeRegistry(\n        localMetaReader, depScopeReader, this.refEmitter, this.aliasingHost);\n    const scopeReader: ComponentScopeReader = this.scopeRegistry;\n    const metaRegistry = new CompoundMetadataRegistry([localMetaRegistry, this.scopeRegistry]);\n    const injectableRegistry = new InjectableClassRegistry(this.reflector);\n\n    this.metaReader = new CompoundMetadataReader([localMetaReader, dtsReader]);\n\n\n    // If a flat module entrypoint was specified, then track references via a `ReferenceGraph` in\n    // order to produce proper diagnostics for incorrectly exported directives/pipes/etc. If there\n    // is no flat module entrypoint then don't pay the cost of tracking references.\n    let referencesRegistry: ReferencesRegistry;\n    if (this.entryPoint !== null) {\n      this.exportReferenceGraph = new ReferenceGraph();\n      referencesRegistry = new ReferenceGraphAdapter(this.exportReferenceGraph);\n    } else {\n      referencesRegistry = new NoopReferencesRegistry();\n    }\n\n    this.routeAnalyzer = new NgModuleRouteAnalyzer(this.moduleResolver, evaluator);\n\n    this.dtsTransforms = new DtsTransformRegistry();\n\n    this.mwpScanner = new ModuleWithProvidersScanner(this.reflector, evaluator, this.refEmitter);\n\n    // Set up the IvyCompilation, which manages state for the Ivy transformer.\n    const handlers: DecoratorHandler<unknown, unknown, unknown>[] = [\n      new ComponentDecoratorHandler(\n          this.reflector, evaluator, metaRegistry, this.metaReader !, scopeReader,\n          this.scopeRegistry, this.isCore, this.resourceManager, this.rootDirs,\n          this.options.preserveWhitespaces || false, this.options.i18nUseExternalIds !== false,\n          this.options.enableI18nLegacyMessageIdFormat !== false, this.moduleResolver,\n          this.cycleAnalyzer, this.refEmitter, this.defaultImportTracker,\n          this.incrementalDriver.depGraph, injectableRegistry, this.closureCompilerEnabled),\n      // TODO(alxhub): understand why the cast here is necessary (something to do with `null` not\n      // being assignable to `unknown` when wrapped in `Readonly`).\n      // clang-format off\n      new DirectiveDecoratorHandler(\n          this.reflector, evaluator, metaRegistry, this.scopeRegistry, this.metaReader,\n          this.defaultImportTracker, injectableRegistry, this.isCore, this.closureCompilerEnabled\n      ) as Readonly<DecoratorHandler<unknown, unknown, unknown>>,\n      // clang-format on\n      // Pipe handler must be before injectable handler in list so pipe factories are printed\n      // before injectable factories (so injectable factories can delegate to them)\n      new PipeDecoratorHandler(\n          this.reflector, evaluator, metaRegistry, this.scopeRegistry, this.defaultImportTracker,\n          injectableRegistry, this.isCore),\n      new InjectableDecoratorHandler(\n          this.reflector, this.defaultImportTracker, this.isCore,\n          this.options.strictInjectionParameters || false, injectableRegistry),\n      new NgModuleDecoratorHandler(\n          this.reflector, evaluator, this.metaReader, metaRegistry, this.scopeRegistry,\n          referencesRegistry, this.isCore, this.routeAnalyzer, this.refEmitter, this.factoryTracker,\n          this.defaultImportTracker, this.closureCompilerEnabled, injectableRegistry,\n          this.options.i18nInLocale),\n    ];\n\n    return new TraitCompiler(\n        handlers, this.reflector, this.perfRecorder, this.incrementalDriver,\n        this.options.compileNonExportedClasses !== false, this.dtsTransforms);\n  }\n\n  /**\n   * Reifies the inter-dependencies of NgModules and the components within their compilation scopes\n   * into the `IncrementalDriver`'s dependency graph.\n   */\n  private recordNgModuleScopeDependencies() {\n    const recordSpan = this.perfRecorder.start('recordDependencies');\n    const depGraph = this.incrementalDriver.depGraph;\n\n    for (const scope of this.scopeRegistry !.getCompilationScopes()) {\n      const file = scope.declaration.getSourceFile();\n      const ngModuleFile = scope.ngModule.getSourceFile();\n\n      // A change to any dependency of the declaration causes the declaration to be invalidated,\n      // which requires the NgModule to be invalidated as well.\n      depGraph.addTransitiveDependency(ngModuleFile, file);\n\n      // A change to the NgModule file should cause the declaration itself to be invalidated.\n      depGraph.addDependency(file, ngModuleFile);\n\n      const meta = this.metaReader !.getDirectiveMetadata(new Reference(scope.declaration));\n      if (meta !== null && meta.isComponent) {\n        // If a component's template changes, it might have affected the import graph, and thus the\n        // remote scoping feature which is activated in the event of potential import cycles. Thus,\n        // the module depends not only on the transitive dependencies of the component, but on its\n        // resources as well.\n        depGraph.addTransitiveResources(ngModuleFile, file);\n\n        // A change to any directive/pipe in the compilation scope should cause the component to be\n        // invalidated.\n        for (const directive of scope.directives) {\n          // When a directive in scope is updated, the component needs to be recompiled as e.g. a\n          // selector may have changed.\n          depGraph.addTransitiveDependency(file, directive.ref.node.getSourceFile());\n        }\n        for (const pipe of scope.pipes) {\n          // When a pipe in scope is updated, the component needs to be recompiled as e.g. the\n          // pipe's name may have changed.\n          depGraph.addTransitiveDependency(file, pipe.ref.node.getSourceFile());\n        }\n      }\n    }\n    this.perfRecorder.stop(recordSpan);\n  }\n\n  private get reflector(): TypeScriptReflectionHost {\n    if (this._reflector === undefined) {\n      this._reflector = new TypeScriptReflectionHost(this.tsProgram.getTypeChecker());\n    }\n    return this._reflector;\n  }\n\n  private get coreImportsFrom(): ts.SourceFile|null {\n    if (this._coreImportsFrom === undefined) {\n      this._coreImportsFrom = this.isCore && getR3SymbolsFile(this.tsProgram) || null;\n    }\n    return this._coreImportsFrom;\n  }\n\n  private get isCore(): boolean {\n    if (this._isCore === undefined) {\n      this._isCore = isAngularCorePackage(this.tsProgram);\n    }\n    return this._isCore;\n  }\n\n  private get importRewriter(): ImportRewriter {\n    if (this._importRewriter === undefined) {\n      const coreImportsFrom = this.coreImportsFrom;\n      this._importRewriter = coreImportsFrom !== null ?\n          new R3SymbolsImportRewriter(coreImportsFrom.fileName) :\n          new NoopImportRewriter();\n    }\n    return this._importRewriter;\n  }\n}\n\nconst defaultEmitCallback: api.TsEmitCallback =\n    ({program, targetSourceFile, writeFile, cancellationToken, emitOnlyDtsFiles,\n      customTransformers}) =>\n        program.emit(\n            targetSourceFile, writeFile, cancellationToken, emitOnlyDtsFiles, customTransformers);\n\nfunction mergeEmitResults(emitResults: ts.EmitResult[]): ts.EmitResult {\n  const diagnostics: ts.Diagnostic[] = [];\n  let emitSkipped = false;\n  const emittedFiles: string[] = [];\n  for (const er of emitResults) {\n    diagnostics.push(...er.diagnostics);\n    emitSkipped = emitSkipped || er.emitSkipped;\n    emittedFiles.push(...(er.emittedFiles || []));\n  }\n\n  return {diagnostics, emitSkipped, emittedFiles};\n}\n\n/**\n * Find the 'r3_symbols.ts' file in the given `Program`, or return `null` if it wasn't there.\n */\nfunction getR3SymbolsFile(program: ts.Program): ts.SourceFile|null {\n  return program.getSourceFiles().find(file => file.fileName.indexOf('r3_symbols.ts') >= 0) || null;\n}\n\n/**\n * Determine if the given `Program` is @angular/core.\n */\nfunction isAngularCorePackage(program: ts.Program): boolean {\n  // Look for its_just_angular.ts somewhere in the program.\n  const r3Symbols = getR3SymbolsFile(program);\n  if (r3Symbols === null) {\n    return false;\n  }\n\n  // Look for the constant ITS_JUST_ANGULAR in that file.\n  return r3Symbols.statements.some(stmt => {\n    // The statement must be a variable declaration statement.\n    if (!ts.isVariableStatement(stmt)) {\n      return false;\n    }\n    // It must be exported.\n    if (stmt.modifiers === undefined ||\n        !stmt.modifiers.some(mod => mod.kind === ts.SyntaxKind.ExportKeyword)) {\n      return false;\n    }\n    // It must declare ITS_JUST_ANGULAR.\n    return stmt.declarationList.declarations.some(decl => {\n      // The declaration must match the name.\n      if (!ts.isIdentifier(decl.name) || decl.name.text !== 'ITS_JUST_ANGULAR') {\n        return false;\n      }\n      // It must initialize the variable to true.\n      if (decl.initializer === undefined || decl.initializer.kind !== ts.SyntaxKind.TrueKeyword) {\n        return false;\n      }\n      // This definition matches.\n      return true;\n    });\n  });\n}\n\n/**\n * Since \"strictTemplates\" is a true superset of type checking capabilities compared to\n * \"strictTemplateTypeCheck\", it is required that the latter is not explicitly disabled if the\n * former is enabled.\n */\nfunction verifyCompatibleTypeCheckOptions(options: api.CompilerOptions): ts.Diagnostic|null {\n  if (options.fullTemplateTypeCheck === false && options.strictTemplates === true) {\n    return {\n      category: ts.DiagnosticCategory.Error,\n      code: ngErrorCode(ErrorCode.CONFIG_STRICT_TEMPLATES_IMPLIES_FULL_TEMPLATE_TYPECHECK),\n      file: undefined,\n      start: undefined,\n      length: undefined,\n      messageText:\n          `Angular compiler option \"strictTemplates\" is enabled, however \"fullTemplateTypeCheck\" is disabled.\n\nHaving the \"strictTemplates\" flag enabled implies that \"fullTemplateTypeCheck\" is also enabled, so\nthe latter can not be explicitly disabled.\n\nOne of the following actions is required:\n1. Remove the \"fullTemplateTypeCheck\" option.\n2. Remove \"strictTemplates\" or set it to 'false'.\n\nMore information about the template type checking compiler options can be found in the documentation:\nhttps://v9.angular.io/guide/template-typecheck#template-type-checking`,\n    };\n  }\n\n  return null;\n}\n\nexport class ReferenceGraphAdapter implements ReferencesRegistry {\n  constructor(private graph: ReferenceGraph) {}\n\n  add(source: ts.Declaration, ...references: Reference<ts.Declaration>[]): void {\n    for (const {node} of references) {\n      let sourceFile = node.getSourceFile();\n      if (sourceFile === undefined) {\n        sourceFile = ts.getOriginalNode(node).getSourceFile();\n      }\n\n      // Only record local references (not references into .d.ts files).\n      if (sourceFile === undefined || !isDtsPath(sourceFile.fileName)) {\n        this.graph.add(source, node);\n      }\n    }\n  }\n}\n\nfunction shouldEnablePerfTracing(options: api.CompilerOptions): boolean {\n  return options.tracePerformance !== undefined;\n}\n"]}
221
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"program.js","sourceRoot":"","sources":["../../../../../../../packages/compiler-cli/src/ngtsc/program.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 {GeneratedFile} from '@angular/compiler';\nimport * as ts from 'typescript';\n\nimport * as api from '../transformers/api';\nimport {nocollapseHack} from '../transformers/nocollapse_hack';\nimport {verifySupportedTypeScriptVersion} from '../typescript_support';\n\nimport {NgCompilerHost} from './core';\nimport {NgCompilerOptions} from './core/api';\nimport {NgCompiler} from './core/src/compiler';\nimport {IndexedComponent} from './indexer';\nimport {NOOP_PERF_RECORDER, PerfRecorder, PerfTracker} from './perf';\n\n\n\n/**\n * Entrypoint to the Angular Compiler (Ivy+) which sits behind the `api.Program` interface, allowing\n * it to be a drop-in replacement for the legacy View Engine compiler to tooling such as the\n * command-line main() function or the Angular CLI.\n */\nexport class NgtscProgram implements api.Program {\n  private compiler: NgCompiler;\n\n  /**\n   * The primary TypeScript program, which is used for analysis and emit.\n   */\n  private tsProgram: ts.Program;\n\n  /**\n   * The TypeScript program to use for the next incremental compilation.\n   *\n   * Once a TS program is used to create another (an incremental compilation operation), it can no\n   * longer be used to do so again.\n   *\n   * Since template type-checking uses the primary program to create a type-checking program, after\n   * this happens the primary program is no longer suitable for starting a subsequent compilation,\n   * and the template type-checking program should be used instead.\n   *\n   * Thus, the program which should be used for the next incremental compilation is tracked in\n   * `reuseTsProgram`, separately from the \"primary\" program which is always used for emit.\n   */\n  private reuseTsProgram: ts.Program;\n  private closureCompilerEnabled: boolean;\n  private host: NgCompilerHost;\n  private perfRecorder: PerfRecorder = NOOP_PERF_RECORDER;\n  private perfTracker: PerfTracker|null = null;\n\n  constructor(\n      rootNames: ReadonlyArray<string>, private options: NgCompilerOptions,\n      delegateHost: api.CompilerHost, oldProgram?: NgtscProgram) {\n    // First, check whether the current TS version is supported.\n    if (!options.disableTypeScriptVersionCheck) {\n      verifySupportedTypeScriptVersion();\n    }\n\n    if (options.tracePerformance !== undefined) {\n      this.perfTracker = PerfTracker.zeroedToNow();\n      this.perfRecorder = this.perfTracker;\n    }\n    this.closureCompilerEnabled = !!options.annotateForClosureCompiler;\n\n    this.host = NgCompilerHost.wrap(delegateHost, rootNames, options);\n\n    const reuseProgram = oldProgram && oldProgram.reuseTsProgram;\n    this.tsProgram = ts.createProgram(this.host.inputFiles, options, this.host, reuseProgram);\n    this.reuseTsProgram = this.tsProgram;\n\n    // Create the NgCompiler which will drive the rest of the compilation.\n    this.compiler =\n        new NgCompiler(this.host, options, this.tsProgram, reuseProgram, this.perfRecorder);\n  }\n\n  getTsProgram(): ts.Program { return this.tsProgram; }\n\n  getTsOptionDiagnostics(cancellationToken?: ts.CancellationToken|\n                         undefined): readonly ts.Diagnostic[] {\n    return this.tsProgram.getOptionsDiagnostics(cancellationToken);\n  }\n\n  getTsSyntacticDiagnostics(\n      sourceFile?: ts.SourceFile|undefined,\n      cancellationToken?: ts.CancellationToken|undefined): readonly ts.Diagnostic[] {\n    return this.tsProgram.getSyntacticDiagnostics(sourceFile, cancellationToken);\n  }\n\n  getTsSemanticDiagnostics(\n      sourceFile?: ts.SourceFile|undefined,\n      cancellationToken?: ts.CancellationToken|undefined): readonly ts.Diagnostic[] {\n    return this.tsProgram.getSemanticDiagnostics(sourceFile, cancellationToken);\n  }\n\n  getNgOptionDiagnostics(cancellationToken?: ts.CancellationToken|\n                         undefined): readonly(ts.Diagnostic|api.Diagnostic)[] {\n    return this.compiler.getOptionDiagnostics();\n  }\n\n  getNgStructuralDiagnostics(cancellationToken?: ts.CancellationToken|\n                             undefined): readonly api.Diagnostic[] {\n    return [];\n  }\n\n  getNgSemanticDiagnostics(\n      fileName?: string|undefined, cancellationToken?: ts.CancellationToken|\n                                   undefined): readonly(ts.Diagnostic|api.Diagnostic)[] {\n    let sf: ts.SourceFile|undefined = undefined;\n    if (fileName !== undefined) {\n      sf = this.tsProgram.getSourceFile(fileName);\n      if (sf === undefined) {\n        // There are no diagnostics for files which don't exist in the program - maybe the caller\n        // has stale data?\n        return [];\n      }\n    }\n\n    const diagnostics = this.compiler.getDiagnostics(sf);\n    this.reuseTsProgram = this.compiler.getNextProgram();\n    return diagnostics;\n  }\n\n  /**\n   * Ensure that the `NgCompiler` has properly analyzed the program, and allow for the asynchronous\n   * loading of any resources during the process.\n   *\n   * This is used by the Angular CLI to allow for spawning (async) child compilations for things\n   * like SASS files used in `styleUrls`.\n   */\n  loadNgStructureAsync(): Promise<void> { return this.compiler.analyzeAsync(); }\n\n  listLazyRoutes(entryRoute?: string|undefined): api.LazyRoute[] {\n    return this.compiler.listLazyRoutes(entryRoute);\n  }\n\n  emit(opts?: {\n    emitFlags?: api.EmitFlags | undefined; cancellationToken?: ts.CancellationToken | undefined;\n    customTransformers?: api.CustomTransformers | undefined;\n    emitCallback?: api.TsEmitCallback | undefined;\n    mergeEmitResultsCallback?: api.TsMergeEmitResultsCallback | undefined;\n  }|undefined): ts.EmitResult {\n    const {transformers, ignoreFiles} = this.compiler.prepareEmit();\n    const emitCallback = opts && opts.emitCallback || defaultEmitCallback;\n\n    const writeFile: ts.WriteFileCallback =\n        (fileName: string, data: string, writeByteOrderMark: boolean,\n         onError: ((message: string) => void) | undefined,\n         sourceFiles: ReadonlyArray<ts.SourceFile>| undefined) => {\n          if (sourceFiles !== undefined) {\n            // Record successful writes for any `ts.SourceFile` (that's not a declaration file)\n            // that's an input to this write.\n            for (const writtenSf of sourceFiles) {\n              if (writtenSf.isDeclarationFile) {\n                continue;\n              }\n\n              this.compiler.incrementalDriver.recordSuccessfulEmit(writtenSf);\n            }\n          }\n\n          // If Closure annotations are being produced, tsickle should be adding `@nocollapse` to\n          // any static fields present. However, tsickle doesn't yet handle synthetic fields added\n          // during other transformations, so this hack is in place to ensure Ivy definitions get\n          // properly annotated, pending an upstream fix in tsickle.\n          //\n          // TODO(alxhub): remove when tsickle properly annotates synthetic fields.\n          if (this.closureCompilerEnabled && fileName.endsWith('.js')) {\n            data = nocollapseHack(data);\n          }\n          this.host.writeFile(fileName, data, writeByteOrderMark, onError, sourceFiles);\n        };\n\n    const customTransforms = opts && opts.customTransformers;\n    const beforeTransforms = transformers.before || [];\n    const afterDeclarationsTransforms = transformers.afterDeclarations;\n\n    if (customTransforms !== undefined && customTransforms.beforeTs !== undefined) {\n      beforeTransforms.push(...customTransforms.beforeTs);\n    }\n\n    const emitSpan = this.perfRecorder.start('emit');\n    const emitResults: ts.EmitResult[] = [];\n\n    for (const targetSourceFile of this.tsProgram.getSourceFiles()) {\n      if (targetSourceFile.isDeclarationFile || ignoreFiles.has(targetSourceFile)) {\n        continue;\n      }\n\n      if (this.compiler.incrementalDriver.safeToSkipEmit(targetSourceFile)) {\n        continue;\n      }\n\n      const fileEmitSpan = this.perfRecorder.start('emitFile', targetSourceFile);\n      emitResults.push(emitCallback({\n        targetSourceFile,\n        program: this.tsProgram,\n        host: this.host,\n        options: this.options,\n        emitOnlyDtsFiles: false, writeFile,\n        customTransformers: {\n          before: beforeTransforms,\n          after: customTransforms && customTransforms.afterTs,\n          afterDeclarations: afterDeclarationsTransforms,\n        } as any,\n      }));\n      this.perfRecorder.stop(fileEmitSpan);\n    }\n    this.perfRecorder.stop(emitSpan);\n\n    if (this.perfTracker !== null && this.options.tracePerformance !== undefined) {\n      this.perfTracker.serializeToFile(this.options.tracePerformance, this.host);\n    }\n\n    // Run the emit, including a custom transformer that will downlevel the Ivy decorators in code.\n    return ((opts && opts.mergeEmitResultsCallback) || mergeEmitResults)(emitResults);\n  }\n\n  getIndexedComponents(): Map<ts.Declaration, IndexedComponent> {\n    return this.compiler.getIndexedComponents();\n  }\n\n  getLibrarySummaries(): Map<string, api.LibrarySummary> {\n    throw new Error('Method not implemented.');\n  }\n\n  getEmittedGeneratedFiles(): Map<string, GeneratedFile> {\n    throw new Error('Method not implemented.');\n  }\n\n  getEmittedSourceFiles(): Map<string, ts.SourceFile> {\n    throw new Error('Method not implemented.');\n  }\n}\n\nconst defaultEmitCallback: api.TsEmitCallback =\n    ({program, targetSourceFile, writeFile, cancellationToken, emitOnlyDtsFiles,\n      customTransformers}) =>\n        program.emit(\n            targetSourceFile, writeFile, cancellationToken, emitOnlyDtsFiles, customTransformers);\n\nfunction mergeEmitResults(emitResults: ts.EmitResult[]): ts.EmitResult {\n  const diagnostics: ts.Diagnostic[] = [];\n  let emitSkipped = false;\n  const emittedFiles: string[] = [];\n  for (const er of emitResults) {\n    diagnostics.push(...er.diagnostics);\n    emitSkipped = emitSkipped || er.emitSkipped;\n    emittedFiles.push(...(er.emittedFiles || []));\n  }\n\n  return {diagnostics, emitSkipped, emittedFiles};\n}\n"]}