source: trip-planner-front/node_modules/@angular/compiler-cli/src/ngtsc/program.js@ 188ee53

Last change on this file since 188ee53 was 6a3a178, checked in by Ema <ema_spirova@…>, 3 years ago

initial commit

  • Property mode set to 100644
File size: 50.6 KB
Line 
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"]}
Note: See TracBrowser for help on using the repository browser.