1 | /**
|
---|
2 | * @license
|
---|
3 | * Copyright Google LLC All Rights Reserved.
|
---|
4 | *
|
---|
5 | * Use of this source code is governed by an MIT-style license that can be
|
---|
6 | * found in the LICENSE file at https://angular.io/license
|
---|
7 | */
|
---|
8 | (function (factory) {
|
---|
9 | if (typeof module === "object" && typeof module.exports === "object") {
|
---|
10 | var v = factory(require, exports);
|
---|
11 | if (v !== undefined) module.exports = v;
|
---|
12 | }
|
---|
13 | else if (typeof define === "function" && define.amd) {
|
---|
14 | define("@angular/compiler-cli/src/ngtsc/program", ["require", "exports", "tslib", "@angular/compiler", "typescript", "@angular/compiler-cli/src/transformers/api", "@angular/compiler-cli/src/transformers/i18n", "@angular/compiler-cli/src/typescript_support", "@angular/compiler-cli/src/ngtsc/core", "@angular/compiler-cli/src/ngtsc/file_system", "@angular/compiler-cli/src/ngtsc/incremental", "@angular/compiler-cli/src/ngtsc/perf", "@angular/compiler-cli/src/ngtsc/program_driver", "@angular/compiler-cli/src/ngtsc/shims", "@angular/compiler-cli/src/ngtsc/typecheck/api"], factory);
|
---|
15 | }
|
---|
16 | })(function (require, exports) {
|
---|
17 | "use strict";
|
---|
18 | Object.defineProperty(exports, "__esModule", { value: true });
|
---|
19 | exports.NgtscProgram = void 0;
|
---|
20 | var tslib_1 = require("tslib");
|
---|
21 | var compiler_1 = require("@angular/compiler");
|
---|
22 | var ts = require("typescript");
|
---|
23 | var api = require("@angular/compiler-cli/src/transformers/api");
|
---|
24 | var i18n_1 = require("@angular/compiler-cli/src/transformers/i18n");
|
---|
25 | var typescript_support_1 = require("@angular/compiler-cli/src/typescript_support");
|
---|
26 | var core_1 = require("@angular/compiler-cli/src/ngtsc/core");
|
---|
27 | var file_system_1 = require("@angular/compiler-cli/src/ngtsc/file_system");
|
---|
28 | var incremental_1 = require("@angular/compiler-cli/src/ngtsc/incremental");
|
---|
29 | var perf_1 = require("@angular/compiler-cli/src/ngtsc/perf");
|
---|
30 | var program_driver_1 = require("@angular/compiler-cli/src/ngtsc/program_driver");
|
---|
31 | var shims_1 = require("@angular/compiler-cli/src/ngtsc/shims");
|
---|
32 | var api_1 = require("@angular/compiler-cli/src/ngtsc/typecheck/api");
|
---|
33 | /**
|
---|
34 | * Entrypoint to the Angular Compiler (Ivy+) which sits behind the `api.Program` interface, allowing
|
---|
35 | * it to be a drop-in replacement for the legacy View Engine compiler to tooling such as the
|
---|
36 | * command-line main() function or the Angular CLI.
|
---|
37 | */
|
---|
38 | var NgtscProgram = /** @class */ (function () {
|
---|
39 | function NgtscProgram(rootNames, options, delegateHost, oldProgram) {
|
---|
40 | var e_1, _a;
|
---|
41 | var _this = this;
|
---|
42 | this.options = options;
|
---|
43 | var perfRecorder = perf_1.ActivePerfRecorder.zeroedToNow();
|
---|
44 | perfRecorder.phase(perf_1.PerfPhase.Setup);
|
---|
45 | // First, check whether the current TS version is supported.
|
---|
46 | if (!options.disableTypeScriptVersionCheck) {
|
---|
47 | typescript_support_1.verifySupportedTypeScriptVersion();
|
---|
48 | }
|
---|
49 | var reuseProgram = oldProgram === null || oldProgram === void 0 ? void 0 : oldProgram.compiler.getCurrentProgram();
|
---|
50 | this.host = core_1.NgCompilerHost.wrap(delegateHost, rootNames, options, reuseProgram !== null && reuseProgram !== void 0 ? reuseProgram : null);
|
---|
51 | if (reuseProgram !== undefined) {
|
---|
52 | // Prior to reusing the old program, restore shim tagging for all its `ts.SourceFile`s.
|
---|
53 | // TypeScript checks the `referencedFiles` of `ts.SourceFile`s for changes when evaluating
|
---|
54 | // incremental reuse of data from the old program, so it's important that these match in order
|
---|
55 | // to get the most benefit out of reuse.
|
---|
56 | shims_1.retagAllTsFiles(reuseProgram);
|
---|
57 | }
|
---|
58 | this.tsProgram = perfRecorder.inPhase(perf_1.PerfPhase.TypeScriptProgramCreate, function () { return ts.createProgram(_this.host.inputFiles, options, _this.host, reuseProgram); });
|
---|
59 | perfRecorder.phase(perf_1.PerfPhase.Unaccounted);
|
---|
60 | perfRecorder.memory(perf_1.PerfCheckpoint.TypeScriptProgramCreate);
|
---|
61 | this.host.postProgramCreationCleanup();
|
---|
62 | // Shim tagging has served its purpose, and tags can now be removed from all `ts.SourceFile`s in
|
---|
63 | // the program.
|
---|
64 | shims_1.untagAllTsFiles(this.tsProgram);
|
---|
65 | var programDriver = new program_driver_1.TsCreateProgramDriver(this.tsProgram, this.host, this.options, this.host.shimExtensionPrefixes);
|
---|
66 | this.incrementalStrategy = oldProgram !== undefined ?
|
---|
67 | oldProgram.incrementalStrategy.toNextBuildStrategy() :
|
---|
68 | new incremental_1.TrackedIncrementalBuildStrategy();
|
---|
69 | var modifiedResourceFiles = new Set();
|
---|
70 | if (this.host.getModifiedResourceFiles !== undefined) {
|
---|
71 | var strings = this.host.getModifiedResourceFiles();
|
---|
72 | if (strings !== undefined) {
|
---|
73 | try {
|
---|
74 | for (var strings_1 = tslib_1.__values(strings), strings_1_1 = strings_1.next(); !strings_1_1.done; strings_1_1 = strings_1.next()) {
|
---|
75 | var fileString = strings_1_1.value;
|
---|
76 | modifiedResourceFiles.add(file_system_1.absoluteFrom(fileString));
|
---|
77 | }
|
---|
78 | }
|
---|
79 | catch (e_1_1) { e_1 = { error: e_1_1 }; }
|
---|
80 | finally {
|
---|
81 | try {
|
---|
82 | if (strings_1_1 && !strings_1_1.done && (_a = strings_1.return)) _a.call(strings_1);
|
---|
83 | }
|
---|
84 | finally { if (e_1) throw e_1.error; }
|
---|
85 | }
|
---|
86 | }
|
---|
87 | }
|
---|
88 | var ticket;
|
---|
89 | if (oldProgram === undefined) {
|
---|
90 | ticket = core_1.freshCompilationTicket(this.tsProgram, options, this.incrementalStrategy, programDriver, perfRecorder,
|
---|
91 | /* enableTemplateTypeChecker */ false, /* usePoisonedData */ false);
|
---|
92 | }
|
---|
93 | else {
|
---|
94 | ticket = core_1.incrementalFromCompilerTicket(oldProgram.compiler, this.tsProgram, this.incrementalStrategy, programDriver, modifiedResourceFiles, perfRecorder);
|
---|
95 | }
|
---|
96 | // Create the NgCompiler which will drive the rest of the compilation.
|
---|
97 | this.compiler = core_1.NgCompiler.fromTicket(ticket, this.host);
|
---|
98 | }
|
---|
99 | NgtscProgram.prototype.getTsProgram = function () {
|
---|
100 | return this.tsProgram;
|
---|
101 | };
|
---|
102 | NgtscProgram.prototype.getReuseTsProgram = function () {
|
---|
103 | return this.compiler.getCurrentProgram();
|
---|
104 | };
|
---|
105 | NgtscProgram.prototype.getTsOptionDiagnostics = function (cancellationToken) {
|
---|
106 | var _this = this;
|
---|
107 | return this.compiler.perfRecorder.inPhase(perf_1.PerfPhase.TypeScriptDiagnostics, function () { return _this.tsProgram.getOptionsDiagnostics(cancellationToken); });
|
---|
108 | };
|
---|
109 | NgtscProgram.prototype.getTsSyntacticDiagnostics = function (sourceFile, cancellationToken) {
|
---|
110 | var _this = this;
|
---|
111 | return this.compiler.perfRecorder.inPhase(perf_1.PerfPhase.TypeScriptDiagnostics, function () {
|
---|
112 | var e_2, _a;
|
---|
113 | var ignoredFiles = _this.compiler.ignoreForDiagnostics;
|
---|
114 | var res;
|
---|
115 | if (sourceFile !== undefined) {
|
---|
116 | if (ignoredFiles.has(sourceFile)) {
|
---|
117 | return [];
|
---|
118 | }
|
---|
119 | res = _this.tsProgram.getSyntacticDiagnostics(sourceFile, cancellationToken);
|
---|
120 | }
|
---|
121 | else {
|
---|
122 | var diagnostics = [];
|
---|
123 | try {
|
---|
124 | for (var _b = tslib_1.__values(_this.tsProgram.getSourceFiles()), _c = _b.next(); !_c.done; _c = _b.next()) {
|
---|
125 | var sf = _c.value;
|
---|
126 | if (!ignoredFiles.has(sf)) {
|
---|
127 | diagnostics.push.apply(diagnostics, tslib_1.__spreadArray([], tslib_1.__read(_this.tsProgram.getSyntacticDiagnostics(sf, cancellationToken))));
|
---|
128 | }
|
---|
129 | }
|
---|
130 | }
|
---|
131 | catch (e_2_1) { e_2 = { error: e_2_1 }; }
|
---|
132 | finally {
|
---|
133 | try {
|
---|
134 | if (_c && !_c.done && (_a = _b.return)) _a.call(_b);
|
---|
135 | }
|
---|
136 | finally { if (e_2) throw e_2.error; }
|
---|
137 | }
|
---|
138 | res = diagnostics;
|
---|
139 | }
|
---|
140 | return res;
|
---|
141 | });
|
---|
142 | };
|
---|
143 | NgtscProgram.prototype.getTsSemanticDiagnostics = function (sourceFile, cancellationToken) {
|
---|
144 | var _this = this;
|
---|
145 | return this.compiler.perfRecorder.inPhase(perf_1.PerfPhase.TypeScriptDiagnostics, function () {
|
---|
146 | var e_3, _a;
|
---|
147 | var ignoredFiles = _this.compiler.ignoreForDiagnostics;
|
---|
148 | var res;
|
---|
149 | if (sourceFile !== undefined) {
|
---|
150 | if (ignoredFiles.has(sourceFile)) {
|
---|
151 | return [];
|
---|
152 | }
|
---|
153 | res = _this.tsProgram.getSemanticDiagnostics(sourceFile, cancellationToken);
|
---|
154 | }
|
---|
155 | else {
|
---|
156 | var diagnostics = [];
|
---|
157 | try {
|
---|
158 | for (var _b = tslib_1.__values(_this.tsProgram.getSourceFiles()), _c = _b.next(); !_c.done; _c = _b.next()) {
|
---|
159 | var sf = _c.value;
|
---|
160 | if (!ignoredFiles.has(sf)) {
|
---|
161 | diagnostics.push.apply(diagnostics, tslib_1.__spreadArray([], tslib_1.__read(_this.tsProgram.getSemanticDiagnostics(sf, cancellationToken))));
|
---|
162 | }
|
---|
163 | }
|
---|
164 | }
|
---|
165 | catch (e_3_1) { e_3 = { error: e_3_1 }; }
|
---|
166 | finally {
|
---|
167 | try {
|
---|
168 | if (_c && !_c.done && (_a = _b.return)) _a.call(_b);
|
---|
169 | }
|
---|
170 | finally { if (e_3) throw e_3.error; }
|
---|
171 | }
|
---|
172 | res = diagnostics;
|
---|
173 | }
|
---|
174 | return res;
|
---|
175 | });
|
---|
176 | };
|
---|
177 | NgtscProgram.prototype.getNgOptionDiagnostics = function (cancellationToken) {
|
---|
178 | return this.compiler.getOptionDiagnostics();
|
---|
179 | };
|
---|
180 | NgtscProgram.prototype.getNgStructuralDiagnostics = function (cancellationToken) {
|
---|
181 | return [];
|
---|
182 | };
|
---|
183 | NgtscProgram.prototype.getNgSemanticDiagnostics = function (fileName, cancellationToken) {
|
---|
184 | var sf = undefined;
|
---|
185 | if (fileName !== undefined) {
|
---|
186 | sf = this.tsProgram.getSourceFile(fileName);
|
---|
187 | if (sf === undefined) {
|
---|
188 | // There are no diagnostics for files which don't exist in the program - maybe the caller
|
---|
189 | // has stale data?
|
---|
190 | return [];
|
---|
191 | }
|
---|
192 | }
|
---|
193 | if (sf === undefined) {
|
---|
194 | return this.compiler.getDiagnostics();
|
---|
195 | }
|
---|
196 | else {
|
---|
197 | return this.compiler.getDiagnosticsForFile(sf, api_1.OptimizeFor.WholeProgram);
|
---|
198 | }
|
---|
199 | };
|
---|
200 | /**
|
---|
201 | * Ensure that the `NgCompiler` has properly analyzed the program, and allow for the asynchronous
|
---|
202 | * loading of any resources during the process.
|
---|
203 | *
|
---|
204 | * This is used by the Angular CLI to allow for spawning (async) child compilations for things
|
---|
205 | * like SASS files used in `styleUrls`.
|
---|
206 | */
|
---|
207 | NgtscProgram.prototype.loadNgStructureAsync = function () {
|
---|
208 | return this.compiler.analyzeAsync();
|
---|
209 | };
|
---|
210 | NgtscProgram.prototype.listLazyRoutes = function (entryRoute) {
|
---|
211 | return this.compiler.listLazyRoutes(entryRoute);
|
---|
212 | };
|
---|
213 | NgtscProgram.prototype.emitXi18n = function () {
|
---|
214 | var _a, _b, _c;
|
---|
215 | var ctx = new compiler_1.MessageBundle(new compiler_1.HtmlParser(), [], {}, (_a = this.options.i18nOutLocale) !== null && _a !== void 0 ? _a : null);
|
---|
216 | this.compiler.xi18n(ctx);
|
---|
217 | i18n_1.i18nExtract((_b = this.options.i18nOutFormat) !== null && _b !== void 0 ? _b : null, (_c = this.options.i18nOutFile) !== null && _c !== void 0 ? _c : null, this.host, this.options, ctx, file_system_1.resolve);
|
---|
218 | };
|
---|
219 | NgtscProgram.prototype.emit = function (opts) {
|
---|
220 | var _this = this;
|
---|
221 | // Check if emission of the i18n messages bundle was requested.
|
---|
222 | if (opts !== undefined && opts.emitFlags !== undefined &&
|
---|
223 | opts.emitFlags & api.EmitFlags.I18nBundle) {
|
---|
224 | this.emitXi18n();
|
---|
225 | // `api.EmitFlags` is a View Engine compiler concept. We only pay attention to the absence of
|
---|
226 | // the other flags here if i18n emit was requested (since this is usually done in the xi18n
|
---|
227 | // flow, where we don't want to emit JS at all).
|
---|
228 | if (!(opts.emitFlags & api.EmitFlags.JS)) {
|
---|
229 | return {
|
---|
230 | diagnostics: [],
|
---|
231 | emitSkipped: true,
|
---|
232 | emittedFiles: [],
|
---|
233 | };
|
---|
234 | }
|
---|
235 | }
|
---|
236 | this.compiler.perfRecorder.memory(perf_1.PerfCheckpoint.PreEmit);
|
---|
237 | var res = this.compiler.perfRecorder.inPhase(perf_1.PerfPhase.TypeScriptEmit, function () {
|
---|
238 | var e_4, _a;
|
---|
239 | var transformers = _this.compiler.prepareEmit().transformers;
|
---|
240 | var ignoreFiles = _this.compiler.ignoreForEmit;
|
---|
241 | var emitCallback = opts && opts.emitCallback || defaultEmitCallback;
|
---|
242 | var writeFile = function (fileName, data, writeByteOrderMark, onError, sourceFiles) {
|
---|
243 | var e_5, _a;
|
---|
244 | if (sourceFiles !== undefined) {
|
---|
245 | try {
|
---|
246 | // Record successful writes for any `ts.SourceFile` (that's not a declaration file)
|
---|
247 | // that's an input to this write.
|
---|
248 | for (var sourceFiles_1 = tslib_1.__values(sourceFiles), sourceFiles_1_1 = sourceFiles_1.next(); !sourceFiles_1_1.done; sourceFiles_1_1 = sourceFiles_1.next()) {
|
---|
249 | var writtenSf = sourceFiles_1_1.value;
|
---|
250 | if (writtenSf.isDeclarationFile) {
|
---|
251 | continue;
|
---|
252 | }
|
---|
253 | _this.compiler.incrementalCompilation.recordSuccessfulEmit(writtenSf);
|
---|
254 | }
|
---|
255 | }
|
---|
256 | catch (e_5_1) { e_5 = { error: e_5_1 }; }
|
---|
257 | finally {
|
---|
258 | try {
|
---|
259 | if (sourceFiles_1_1 && !sourceFiles_1_1.done && (_a = sourceFiles_1.return)) _a.call(sourceFiles_1);
|
---|
260 | }
|
---|
261 | finally { if (e_5) throw e_5.error; }
|
---|
262 | }
|
---|
263 | }
|
---|
264 | _this.host.writeFile(fileName, data, writeByteOrderMark, onError, sourceFiles);
|
---|
265 | };
|
---|
266 | var customTransforms = opts && opts.customTransformers;
|
---|
267 | var beforeTransforms = transformers.before || [];
|
---|
268 | var afterDeclarationsTransforms = transformers.afterDeclarations;
|
---|
269 | if (customTransforms !== undefined && customTransforms.beforeTs !== undefined) {
|
---|
270 | beforeTransforms.push.apply(beforeTransforms, tslib_1.__spreadArray([], tslib_1.__read(customTransforms.beforeTs)));
|
---|
271 | }
|
---|
272 | var emitResults = [];
|
---|
273 | try {
|
---|
274 | for (var _b = tslib_1.__values(_this.tsProgram.getSourceFiles()), _c = _b.next(); !_c.done; _c = _b.next()) {
|
---|
275 | var targetSourceFile = _c.value;
|
---|
276 | if (targetSourceFile.isDeclarationFile || ignoreFiles.has(targetSourceFile)) {
|
---|
277 | continue;
|
---|
278 | }
|
---|
279 | if (_this.compiler.incrementalCompilation.safeToSkipEmit(targetSourceFile)) {
|
---|
280 | _this.compiler.perfRecorder.eventCount(perf_1.PerfEvent.EmitSkipSourceFile);
|
---|
281 | continue;
|
---|
282 | }
|
---|
283 | _this.compiler.perfRecorder.eventCount(perf_1.PerfEvent.EmitSourceFile);
|
---|
284 | emitResults.push(emitCallback({
|
---|
285 | targetSourceFile: targetSourceFile,
|
---|
286 | program: _this.tsProgram,
|
---|
287 | host: _this.host,
|
---|
288 | options: _this.options,
|
---|
289 | emitOnlyDtsFiles: false,
|
---|
290 | writeFile: writeFile,
|
---|
291 | customTransformers: {
|
---|
292 | before: beforeTransforms,
|
---|
293 | after: customTransforms && customTransforms.afterTs,
|
---|
294 | afterDeclarations: afterDeclarationsTransforms,
|
---|
295 | },
|
---|
296 | }));
|
---|
297 | }
|
---|
298 | }
|
---|
299 | catch (e_4_1) { e_4 = { error: e_4_1 }; }
|
---|
300 | finally {
|
---|
301 | try {
|
---|
302 | if (_c && !_c.done && (_a = _b.return)) _a.call(_b);
|
---|
303 | }
|
---|
304 | finally { if (e_4) throw e_4.error; }
|
---|
305 | }
|
---|
306 | _this.compiler.perfRecorder.memory(perf_1.PerfCheckpoint.Emit);
|
---|
307 | // Run the emit, including a custom transformer that will downlevel the Ivy decorators in
|
---|
308 | // code.
|
---|
309 | return ((opts && opts.mergeEmitResultsCallback) || mergeEmitResults)(emitResults);
|
---|
310 | });
|
---|
311 | // Record performance analysis information to disk if we've been asked to do so.
|
---|
312 | if (this.options.tracePerformance !== undefined) {
|
---|
313 | var perf = this.compiler.perfRecorder.finalize();
|
---|
314 | file_system_1.getFileSystem().writeFile(file_system_1.getFileSystem().resolve(this.options.tracePerformance), JSON.stringify(perf, null, 2));
|
---|
315 | }
|
---|
316 | return res;
|
---|
317 | };
|
---|
318 | NgtscProgram.prototype.getIndexedComponents = function () {
|
---|
319 | return this.compiler.getIndexedComponents();
|
---|
320 | };
|
---|
321 | NgtscProgram.prototype.getLibrarySummaries = function () {
|
---|
322 | throw new Error('Method not implemented.');
|
---|
323 | };
|
---|
324 | NgtscProgram.prototype.getEmittedGeneratedFiles = function () {
|
---|
325 | throw new Error('Method not implemented.');
|
---|
326 | };
|
---|
327 | NgtscProgram.prototype.getEmittedSourceFiles = function () {
|
---|
328 | throw new Error('Method not implemented.');
|
---|
329 | };
|
---|
330 | return NgtscProgram;
|
---|
331 | }());
|
---|
332 | exports.NgtscProgram = NgtscProgram;
|
---|
333 | var defaultEmitCallback = function (_a) {
|
---|
334 | var program = _a.program, targetSourceFile = _a.targetSourceFile, writeFile = _a.writeFile, cancellationToken = _a.cancellationToken, emitOnlyDtsFiles = _a.emitOnlyDtsFiles, customTransformers = _a.customTransformers;
|
---|
335 | return program.emit(targetSourceFile, writeFile, cancellationToken, emitOnlyDtsFiles, customTransformers);
|
---|
336 | };
|
---|
337 | function mergeEmitResults(emitResults) {
|
---|
338 | var e_6, _a;
|
---|
339 | var diagnostics = [];
|
---|
340 | var emitSkipped = false;
|
---|
341 | var emittedFiles = [];
|
---|
342 | try {
|
---|
343 | for (var emitResults_1 = tslib_1.__values(emitResults), emitResults_1_1 = emitResults_1.next(); !emitResults_1_1.done; emitResults_1_1 = emitResults_1.next()) {
|
---|
344 | var er = emitResults_1_1.value;
|
---|
345 | diagnostics.push.apply(diagnostics, tslib_1.__spreadArray([], tslib_1.__read(er.diagnostics)));
|
---|
346 | emitSkipped = emitSkipped || er.emitSkipped;
|
---|
347 | emittedFiles.push.apply(emittedFiles, tslib_1.__spreadArray([], tslib_1.__read((er.emittedFiles || []))));
|
---|
348 | }
|
---|
349 | }
|
---|
350 | catch (e_6_1) { e_6 = { error: e_6_1 }; }
|
---|
351 | finally {
|
---|
352 | try {
|
---|
353 | if (emitResults_1_1 && !emitResults_1_1.done && (_a = emitResults_1.return)) _a.call(emitResults_1);
|
---|
354 | }
|
---|
355 | finally { if (e_6) throw e_6.error; }
|
---|
356 | }
|
---|
357 | return { diagnostics: diagnostics, emitSkipped: emitSkipped, emittedFiles: emittedFiles };
|
---|
358 | }
|
---|
359 | });
|
---|
360 | //# 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 LLC All Rights Reserved.\n *\n * Use of this source code is governed by an MIT-style license that can be\n * found in the LICENSE file at https://angular.io/license\n */\n\nimport {GeneratedFile, HtmlParser, MessageBundle} from '@angular/compiler';\nimport * as ts from 'typescript';\n\nimport * as api from '../transformers/api';\nimport {i18nExtract} from '../transformers/i18n';\nimport {verifySupportedTypeScriptVersion} from '../typescript_support';\n\nimport {CompilationTicket, freshCompilationTicket, incrementalFromCompilerTicket, NgCompiler, NgCompilerHost} from './core';\nimport {NgCompilerOptions} from './core/api';\nimport {absoluteFrom, AbsoluteFsPath, getFileSystem, resolve} from './file_system';\nimport {TrackedIncrementalBuildStrategy} from './incremental';\nimport {IndexedComponent} from './indexer';\nimport {ActivePerfRecorder, PerfCheckpoint as PerfCheckpoint, PerfEvent, PerfPhase} from './perf';\nimport {TsCreateProgramDriver} from './program_driver';\nimport {DeclarationNode} from './reflection';\nimport {retagAllTsFiles, untagAllTsFiles} from './shims';\nimport {OptimizeFor} from './typecheck/api';\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  readonly compiler: NgCompiler;\n\n  /**\n   * The primary TypeScript program, which is used for analysis and emit.\n   */\n  private tsProgram: ts.Program;\n\n  private host: NgCompilerHost;\n  private incrementalStrategy: TrackedIncrementalBuildStrategy;\n\n  constructor(\n      rootNames: ReadonlyArray<string>, private options: NgCompilerOptions,\n      delegateHost: api.CompilerHost, oldProgram?: NgtscProgram) {\n    const perfRecorder = ActivePerfRecorder.zeroedToNow();\n\n    perfRecorder.phase(PerfPhase.Setup);\n\n    // First, check whether the current TS version is supported.\n    if (!options.disableTypeScriptVersionCheck) {\n      verifySupportedTypeScriptVersion();\n    }\n\n    const reuseProgram = oldProgram?.compiler.getCurrentProgram();\n    this.host = NgCompilerHost.wrap(delegateHost, rootNames, options, reuseProgram ?? null);\n\n    if (reuseProgram !== undefined) {\n      // Prior to reusing the old program, restore shim tagging for all its `ts.SourceFile`s.\n      // TypeScript checks the `referencedFiles` of `ts.SourceFile`s for changes when evaluating\n      // incremental reuse of data from the old program, so it's important that these match in order\n      // to get the most benefit out of reuse.\n      retagAllTsFiles(reuseProgram);\n    }\n\n    this.tsProgram = perfRecorder.inPhase(\n        PerfPhase.TypeScriptProgramCreate,\n        () => ts.createProgram(this.host.inputFiles, options, this.host, reuseProgram));\n\n    perfRecorder.phase(PerfPhase.Unaccounted);\n    perfRecorder.memory(PerfCheckpoint.TypeScriptProgramCreate);\n\n    this.host.postProgramCreationCleanup();\n\n    // Shim tagging has served its purpose, and tags can now be removed from all `ts.SourceFile`s in\n    // the program.\n    untagAllTsFiles(this.tsProgram);\n\n    const programDriver = new TsCreateProgramDriver(\n        this.tsProgram, this.host, this.options, this.host.shimExtensionPrefixes);\n\n    this.incrementalStrategy = oldProgram !== undefined ?\n        oldProgram.incrementalStrategy.toNextBuildStrategy() :\n        new TrackedIncrementalBuildStrategy();\n    const modifiedResourceFiles = new Set<AbsoluteFsPath>();\n    if (this.host.getModifiedResourceFiles !== undefined) {\n      const strings = this.host.getModifiedResourceFiles();\n      if (strings !== undefined) {\n        for (const fileString of strings) {\n          modifiedResourceFiles.add(absoluteFrom(fileString));\n        }\n      }\n    }\n\n    let ticket: CompilationTicket;\n    if (oldProgram === undefined) {\n      ticket = freshCompilationTicket(\n          this.tsProgram, options, this.incrementalStrategy, programDriver, perfRecorder,\n          /* enableTemplateTypeChecker */ false, /* usePoisonedData */ false);\n    } else {\n      ticket = incrementalFromCompilerTicket(\n          oldProgram.compiler,\n          this.tsProgram,\n          this.incrementalStrategy,\n          programDriver,\n          modifiedResourceFiles,\n          perfRecorder,\n      );\n    }\n\n\n    // Create the NgCompiler which will drive the rest of the compilation.\n    this.compiler = NgCompiler.fromTicket(ticket, this.host);\n  }\n\n  getTsProgram(): ts.Program {\n    return this.tsProgram;\n  }\n\n  getReuseTsProgram(): ts.Program {\n    return this.compiler.getCurrentProgram();\n  }\n\n  getTsOptionDiagnostics(cancellationToken?: ts.CancellationToken|\n                         undefined): readonly ts.Diagnostic[] {\n    return this.compiler.perfRecorder.inPhase(\n        PerfPhase.TypeScriptDiagnostics,\n        () => this.tsProgram.getOptionsDiagnostics(cancellationToken));\n  }\n\n  getTsSyntacticDiagnostics(\n      sourceFile?: ts.SourceFile|undefined,\n      cancellationToken?: ts.CancellationToken|undefined): readonly ts.Diagnostic[] {\n    return this.compiler.perfRecorder.inPhase(PerfPhase.TypeScriptDiagnostics, () => {\n      const ignoredFiles = this.compiler.ignoreForDiagnostics;\n      let res: readonly ts.Diagnostic[];\n      if (sourceFile !== undefined) {\n        if (ignoredFiles.has(sourceFile)) {\n          return [];\n        }\n\n        res = this.tsProgram.getSyntacticDiagnostics(sourceFile, cancellationToken);\n      } else {\n        const diagnostics: ts.Diagnostic[] = [];\n        for (const sf of this.tsProgram.getSourceFiles()) {\n          if (!ignoredFiles.has(sf)) {\n            diagnostics.push(...this.tsProgram.getSyntacticDiagnostics(sf, cancellationToken));\n          }\n        }\n        res = diagnostics;\n      }\n      return res;\n    });\n  }\n\n  getTsSemanticDiagnostics(\n      sourceFile?: ts.SourceFile|undefined,\n      cancellationToken?: ts.CancellationToken|undefined): readonly ts.Diagnostic[] {\n    return this.compiler.perfRecorder.inPhase(PerfPhase.TypeScriptDiagnostics, () => {\n      const ignoredFiles = this.compiler.ignoreForDiagnostics;\n      let res: readonly ts.Diagnostic[];\n      if (sourceFile !== undefined) {\n        if (ignoredFiles.has(sourceFile)) {\n          return [];\n        }\n\n        res = this.tsProgram.getSemanticDiagnostics(sourceFile, cancellationToken);\n      } else {\n        const diagnostics: ts.Diagnostic[] = [];\n        for (const sf of this.tsProgram.getSourceFiles()) {\n          if (!ignoredFiles.has(sf)) {\n            diagnostics.push(...this.tsProgram.getSemanticDiagnostics(sf, cancellationToken));\n          }\n        }\n        res = diagnostics;\n      }\n      return res;\n    });\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|undefined):\n      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    if (sf === undefined) {\n      return this.compiler.getDiagnostics();\n    } else {\n      return this.compiler.getDiagnosticsForFile(sf, OptimizeFor.WholeProgram);\n    }\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> {\n    return this.compiler.analyzeAsync();\n  }\n\n  listLazyRoutes(entryRoute?: string|undefined): api.LazyRoute[] {\n    return this.compiler.listLazyRoutes(entryRoute);\n  }\n\n  private emitXi18n(): void {\n    const ctx = new MessageBundle(new HtmlParser(), [], {}, this.options.i18nOutLocale ?? null);\n    this.compiler.xi18n(ctx);\n    i18nExtract(\n        this.options.i18nOutFormat ?? null, this.options.i18nOutFile ?? null, this.host,\n        this.options, ctx, resolve);\n  }\n\n  emit(opts?: {\n    emitFlags?: api.EmitFlags|undefined;\n    cancellationToken?: ts.CancellationToken | undefined;\n    customTransformers?: api.CustomTransformers | undefined;\n    emitCallback?: api.TsEmitCallback | undefined;\n    mergeEmitResultsCallback?: api.TsMergeEmitResultsCallback | undefined;\n  }|undefined): ts.EmitResult {\n    // Check if emission of the i18n messages bundle was requested.\n    if (opts !== undefined && opts.emitFlags !== undefined &&\n        opts.emitFlags & api.EmitFlags.I18nBundle) {\n      this.emitXi18n();\n\n      // `api.EmitFlags` is a View Engine compiler concept. We only pay attention to the absence of\n      // the other flags here if i18n emit was requested (since this is usually done in the xi18n\n      // flow, where we don't want to emit JS at all).\n      if (!(opts.emitFlags & api.EmitFlags.JS)) {\n        return {\n          diagnostics: [],\n          emitSkipped: true,\n          emittedFiles: [],\n        };\n      }\n    }\n\n    this.compiler.perfRecorder.memory(PerfCheckpoint.PreEmit);\n\n    const res = this.compiler.perfRecorder.inPhase(PerfPhase.TypeScriptEmit, () => {\n      const {transformers} = this.compiler.prepareEmit();\n      const ignoreFiles = this.compiler.ignoreForEmit;\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.incrementalCompilation.recordSuccessfulEmit(writtenSf);\n              }\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 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.incrementalCompilation.safeToSkipEmit(targetSourceFile)) {\n          this.compiler.perfRecorder.eventCount(PerfEvent.EmitSkipSourceFile);\n          continue;\n        }\n\n        this.compiler.perfRecorder.eventCount(PerfEvent.EmitSourceFile);\n\n        emitResults.push(emitCallback({\n          targetSourceFile,\n          program: this.tsProgram,\n          host: this.host,\n          options: this.options,\n          emitOnlyDtsFiles: false,\n          writeFile,\n          customTransformers: {\n            before: beforeTransforms,\n            after: customTransforms && customTransforms.afterTs,\n            afterDeclarations: afterDeclarationsTransforms,\n          } as any,\n        }));\n      }\n\n      this.compiler.perfRecorder.memory(PerfCheckpoint.Emit);\n\n      // Run the emit, including a custom transformer that will downlevel the Ivy decorators in\n      // code.\n      return ((opts && opts.mergeEmitResultsCallback) || mergeEmitResults)(emitResults);\n    });\n\n    // Record performance analysis information to disk if we've been asked to do so.\n    if (this.options.tracePerformance !== undefined) {\n      const perf = this.compiler.perfRecorder.finalize();\n      getFileSystem().writeFile(\n          getFileSystem().resolve(this.options.tracePerformance), JSON.stringify(perf, null, 2));\n    }\n    return res;\n  }\n\n  getIndexedComponents(): Map<DeclarationNode, 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,\n  targetSourceFile,\n  writeFile,\n  cancellationToken,\n  emitOnlyDtsFiles,\n  customTransformers\n}) =>\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"]} |
---|