[6a3a178] | 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/transformers/program", ["require", "exports", "tslib", "@angular/compiler", "fs", "path", "typescript", "@angular/compiler-cli/src/diagnostics/translate_diagnostics", "@angular/compiler-cli/src/metadata/index", "@angular/compiler-cli/src/ngtsc/core/src/compiler", "@angular/compiler-cli/src/ngtsc/program", "@angular/compiler-cli/src/ngtsc/reflection", "@angular/compiler-cli/src/typescript_support", "@angular/compiler-cli/src/transformers/api", "@angular/compiler-cli/src/transformers/compiler_host", "@angular/compiler-cli/src/transformers/downlevel_decorators_transform", "@angular/compiler-cli/src/transformers/i18n", "@angular/compiler-cli/src/transformers/inline_resources", "@angular/compiler-cli/src/transformers/lower_expressions", "@angular/compiler-cli/src/transformers/metadata_cache", "@angular/compiler-cli/src/transformers/node_emitter_transform", "@angular/compiler-cli/src/transformers/r3_metadata_transform", "@angular/compiler-cli/src/transformers/r3_transform", "@angular/compiler-cli/src/transformers/util"], factory);
|
---|
| 15 | }
|
---|
| 16 | })(function (require, exports) {
|
---|
| 17 | "use strict";
|
---|
| 18 | Object.defineProperty(exports, "__esModule", { value: true });
|
---|
| 19 | exports.createSrcToOutPathMapper = exports.createProgram = exports.resetTempProgramHandlerForTest = exports.setTempProgramHandlerForTest = void 0;
|
---|
| 20 | var tslib_1 = require("tslib");
|
---|
| 21 | var compiler_1 = require("@angular/compiler");
|
---|
| 22 | var fs = require("fs");
|
---|
| 23 | var path = require("path");
|
---|
| 24 | var ts = require("typescript");
|
---|
| 25 | var translate_diagnostics_1 = require("@angular/compiler-cli/src/diagnostics/translate_diagnostics");
|
---|
| 26 | var metadata_1 = require("@angular/compiler-cli/src/metadata/index");
|
---|
| 27 | var compiler_2 = require("@angular/compiler-cli/src/ngtsc/core/src/compiler");
|
---|
| 28 | var program_1 = require("@angular/compiler-cli/src/ngtsc/program");
|
---|
| 29 | var reflection_1 = require("@angular/compiler-cli/src/ngtsc/reflection");
|
---|
| 30 | var typescript_support_1 = require("@angular/compiler-cli/src/typescript_support");
|
---|
| 31 | var api_1 = require("@angular/compiler-cli/src/transformers/api");
|
---|
| 32 | var compiler_host_1 = require("@angular/compiler-cli/src/transformers/compiler_host");
|
---|
| 33 | var downlevel_decorators_transform_1 = require("@angular/compiler-cli/src/transformers/downlevel_decorators_transform");
|
---|
| 34 | var i18n_1 = require("@angular/compiler-cli/src/transformers/i18n");
|
---|
| 35 | var inline_resources_1 = require("@angular/compiler-cli/src/transformers/inline_resources");
|
---|
| 36 | var lower_expressions_1 = require("@angular/compiler-cli/src/transformers/lower_expressions");
|
---|
| 37 | var metadata_cache_1 = require("@angular/compiler-cli/src/transformers/metadata_cache");
|
---|
| 38 | var node_emitter_transform_1 = require("@angular/compiler-cli/src/transformers/node_emitter_transform");
|
---|
| 39 | var r3_metadata_transform_1 = require("@angular/compiler-cli/src/transformers/r3_metadata_transform");
|
---|
| 40 | var r3_transform_1 = require("@angular/compiler-cli/src/transformers/r3_transform");
|
---|
| 41 | var util_1 = require("@angular/compiler-cli/src/transformers/util");
|
---|
| 42 | /**
|
---|
| 43 | * Maximum number of files that are emitable via calling ts.Program.emit
|
---|
| 44 | * passing individual targetSourceFiles.
|
---|
| 45 | */
|
---|
| 46 | var MAX_FILE_COUNT_FOR_SINGLE_FILE_EMIT = 20;
|
---|
| 47 | /**
|
---|
| 48 | * Fields to lower within metadata in render2 mode.
|
---|
| 49 | */
|
---|
| 50 | var LOWER_FIELDS = ['useValue', 'useFactory', 'data', 'id', 'loadChildren'];
|
---|
| 51 | /**
|
---|
| 52 | * Fields to lower within metadata in render3 mode.
|
---|
| 53 | */
|
---|
| 54 | var R3_LOWER_FIELDS = tslib_1.__spreadArray(tslib_1.__spreadArray([], tslib_1.__read(LOWER_FIELDS)), ['providers', 'imports', 'exports']);
|
---|
| 55 | /**
|
---|
| 56 | * Installs a handler for testing purposes to allow inspection of the temporary program.
|
---|
| 57 | */
|
---|
| 58 | var tempProgramHandlerForTest = null;
|
---|
| 59 | function setTempProgramHandlerForTest(handler) {
|
---|
| 60 | tempProgramHandlerForTest = handler;
|
---|
| 61 | }
|
---|
| 62 | exports.setTempProgramHandlerForTest = setTempProgramHandlerForTest;
|
---|
| 63 | function resetTempProgramHandlerForTest() {
|
---|
| 64 | tempProgramHandlerForTest = null;
|
---|
| 65 | }
|
---|
| 66 | exports.resetTempProgramHandlerForTest = resetTempProgramHandlerForTest;
|
---|
| 67 | var emptyModules = {
|
---|
| 68 | ngModules: [],
|
---|
| 69 | ngModuleByPipeOrDirective: new Map(),
|
---|
| 70 | files: []
|
---|
| 71 | };
|
---|
| 72 | var defaultEmitCallback = function (_a) {
|
---|
| 73 | var program = _a.program, targetSourceFile = _a.targetSourceFile, writeFile = _a.writeFile, cancellationToken = _a.cancellationToken, emitOnlyDtsFiles = _a.emitOnlyDtsFiles, customTransformers = _a.customTransformers;
|
---|
| 74 | return program.emit(targetSourceFile, writeFile, cancellationToken, emitOnlyDtsFiles, customTransformers);
|
---|
| 75 | };
|
---|
| 76 | var AngularCompilerProgram = /** @class */ (function () {
|
---|
| 77 | function AngularCompilerProgram(rootNames, options, host, oldProgram) {
|
---|
| 78 | var _a;
|
---|
| 79 | var _this = this;
|
---|
| 80 | this.options = options;
|
---|
| 81 | this.host = host;
|
---|
| 82 | this._optionsDiagnostics = [];
|
---|
| 83 | this._transformTsDiagnostics = [];
|
---|
| 84 | this._isCompilingAngularCore = null;
|
---|
| 85 | this.rootNames = tslib_1.__spreadArray([], tslib_1.__read(rootNames));
|
---|
| 86 | if (!options.disableTypeScriptVersionCheck) {
|
---|
| 87 | typescript_support_1.verifySupportedTypeScriptVersion();
|
---|
| 88 | }
|
---|
| 89 | this.oldTsProgram = oldProgram ? oldProgram.getTsProgram() : undefined;
|
---|
| 90 | if (oldProgram) {
|
---|
| 91 | this.oldProgramLibrarySummaries = oldProgram.getLibrarySummaries();
|
---|
| 92 | this.oldProgramEmittedGeneratedFiles = oldProgram.getEmittedGeneratedFiles();
|
---|
| 93 | this.oldProgramEmittedSourceFiles = oldProgram.getEmittedSourceFiles();
|
---|
| 94 | }
|
---|
| 95 | if (options.flatModuleOutFile) {
|
---|
| 96 | var _b = metadata_1.createBundleIndexHost(options, this.rootNames, host, function () { return _this.flatModuleMetadataCache; }), bundleHost = _b.host, indexName = _b.indexName, errors = _b.errors;
|
---|
| 97 | if (errors) {
|
---|
| 98 | (_a = this._optionsDiagnostics).push.apply(_a, tslib_1.__spreadArray([], tslib_1.__read(errors.map(function (e) { return ({
|
---|
| 99 | category: e.category,
|
---|
| 100 | messageText: e.messageText,
|
---|
| 101 | source: api_1.SOURCE,
|
---|
| 102 | code: api_1.DEFAULT_ERROR_CODE
|
---|
| 103 | }); }))));
|
---|
| 104 | }
|
---|
| 105 | else {
|
---|
| 106 | this.rootNames.push(indexName);
|
---|
| 107 | this.host = bundleHost;
|
---|
| 108 | }
|
---|
| 109 | }
|
---|
| 110 | this.loweringMetadataTransform =
|
---|
| 111 | new lower_expressions_1.LowerMetadataTransform(options.enableIvy !== false ? R3_LOWER_FIELDS : LOWER_FIELDS);
|
---|
| 112 | this.metadataCache = this.createMetadataCache([this.loweringMetadataTransform]);
|
---|
| 113 | }
|
---|
| 114 | AngularCompilerProgram.prototype.createMetadataCache = function (transformers) {
|
---|
| 115 | return new metadata_cache_1.MetadataCache(new metadata_1.MetadataCollector({ quotedNames: true }), !!this.options.strictMetadataEmit, transformers);
|
---|
| 116 | };
|
---|
| 117 | AngularCompilerProgram.prototype.getLibrarySummaries = function () {
|
---|
| 118 | var result = new Map();
|
---|
| 119 | if (this.oldProgramLibrarySummaries) {
|
---|
| 120 | this.oldProgramLibrarySummaries.forEach(function (summary, fileName) { return result.set(fileName, summary); });
|
---|
| 121 | }
|
---|
| 122 | if (this.emittedLibrarySummaries) {
|
---|
| 123 | this.emittedLibrarySummaries.forEach(function (summary, fileName) { return result.set(summary.fileName, summary); });
|
---|
| 124 | }
|
---|
| 125 | return result;
|
---|
| 126 | };
|
---|
| 127 | AngularCompilerProgram.prototype.getEmittedGeneratedFiles = function () {
|
---|
| 128 | var result = new Map();
|
---|
| 129 | if (this.oldProgramEmittedGeneratedFiles) {
|
---|
| 130 | this.oldProgramEmittedGeneratedFiles.forEach(function (genFile, fileName) { return result.set(fileName, genFile); });
|
---|
| 131 | }
|
---|
| 132 | if (this.emittedGeneratedFiles) {
|
---|
| 133 | this.emittedGeneratedFiles.forEach(function (genFile) { return result.set(genFile.genFileUrl, genFile); });
|
---|
| 134 | }
|
---|
| 135 | return result;
|
---|
| 136 | };
|
---|
| 137 | AngularCompilerProgram.prototype.getEmittedSourceFiles = function () {
|
---|
| 138 | var result = new Map();
|
---|
| 139 | if (this.oldProgramEmittedSourceFiles) {
|
---|
| 140 | this.oldProgramEmittedSourceFiles.forEach(function (sf, fileName) { return result.set(fileName, sf); });
|
---|
| 141 | }
|
---|
| 142 | if (this.emittedSourceFiles) {
|
---|
| 143 | this.emittedSourceFiles.forEach(function (sf) { return result.set(sf.fileName, sf); });
|
---|
| 144 | }
|
---|
| 145 | return result;
|
---|
| 146 | };
|
---|
| 147 | AngularCompilerProgram.prototype.getTsProgram = function () {
|
---|
| 148 | return this.tsProgram;
|
---|
| 149 | };
|
---|
| 150 | AngularCompilerProgram.prototype.getTsOptionDiagnostics = function (cancellationToken) {
|
---|
| 151 | return this.tsProgram.getOptionsDiagnostics(cancellationToken);
|
---|
| 152 | };
|
---|
| 153 | AngularCompilerProgram.prototype.getNgOptionDiagnostics = function (cancellationToken) {
|
---|
| 154 | return tslib_1.__spreadArray(tslib_1.__spreadArray([], tslib_1.__read(this._optionsDiagnostics)), tslib_1.__read(getNgOptionDiagnostics(this.options)));
|
---|
| 155 | };
|
---|
| 156 | AngularCompilerProgram.prototype.getTsSyntacticDiagnostics = function (sourceFile, cancellationToken) {
|
---|
| 157 | return this.tsProgram.getSyntacticDiagnostics(sourceFile, cancellationToken);
|
---|
| 158 | };
|
---|
| 159 | AngularCompilerProgram.prototype.getNgStructuralDiagnostics = function (cancellationToken) {
|
---|
| 160 | return this.structuralDiagnostics;
|
---|
| 161 | };
|
---|
| 162 | AngularCompilerProgram.prototype.getTsSemanticDiagnostics = function (sourceFile, cancellationToken) {
|
---|
| 163 | var _this = this;
|
---|
| 164 | var sourceFiles = sourceFile ? [sourceFile] : this.tsProgram.getSourceFiles();
|
---|
| 165 | var diags = [];
|
---|
| 166 | sourceFiles.forEach(function (sf) {
|
---|
| 167 | if (!util_1.GENERATED_FILES.test(sf.fileName)) {
|
---|
| 168 | diags.push.apply(diags, tslib_1.__spreadArray([], tslib_1.__read(_this.tsProgram.getSemanticDiagnostics(sf, cancellationToken))));
|
---|
| 169 | }
|
---|
| 170 | });
|
---|
| 171 | return diags;
|
---|
| 172 | };
|
---|
| 173 | AngularCompilerProgram.prototype.getNgSemanticDiagnostics = function (fileName, cancellationToken) {
|
---|
| 174 | var _this = this;
|
---|
| 175 | var diags = [];
|
---|
| 176 | this.tsProgram.getSourceFiles().forEach(function (sf) {
|
---|
| 177 | if (util_1.GENERATED_FILES.test(sf.fileName) && !sf.isDeclarationFile) {
|
---|
| 178 | diags.push.apply(diags, tslib_1.__spreadArray([], tslib_1.__read(_this.tsProgram.getSemanticDiagnostics(sf, cancellationToken))));
|
---|
| 179 | }
|
---|
| 180 | });
|
---|
| 181 | var ng = translate_diagnostics_1.translateDiagnostics(this.hostAdapter, diags).ng;
|
---|
| 182 | return ng;
|
---|
| 183 | };
|
---|
| 184 | AngularCompilerProgram.prototype.loadNgStructureAsync = function () {
|
---|
| 185 | var _this = this;
|
---|
| 186 | if (this._analyzedModules) {
|
---|
| 187 | throw new Error('Angular structure already loaded');
|
---|
| 188 | }
|
---|
| 189 | return Promise.resolve()
|
---|
| 190 | .then(function () {
|
---|
| 191 | var _a = _this._createProgramWithBasicStubs(), tmpProgram = _a.tmpProgram, sourceFiles = _a.sourceFiles, tsFiles = _a.tsFiles, rootNames = _a.rootNames;
|
---|
| 192 | return _this.compiler.loadFilesAsync(sourceFiles, tsFiles)
|
---|
| 193 | .then(function (_a) {
|
---|
| 194 | var analyzedModules = _a.analyzedModules, analyzedInjectables = _a.analyzedInjectables;
|
---|
| 195 | if (_this._analyzedModules) {
|
---|
| 196 | throw new Error('Angular structure loaded both synchronously and asynchronously');
|
---|
| 197 | }
|
---|
| 198 | _this._updateProgramWithTypeCheckStubs(tmpProgram, analyzedModules, analyzedInjectables, rootNames);
|
---|
| 199 | });
|
---|
| 200 | })
|
---|
| 201 | .catch(function (e) { return _this._createProgramOnError(e); });
|
---|
| 202 | };
|
---|
| 203 | AngularCompilerProgram.prototype.listLazyRoutes = function (route) {
|
---|
| 204 | // Note: Don't analyzedModules if a route is given
|
---|
| 205 | // to be fast enough.
|
---|
| 206 | return this.compiler.listLazyRoutes(route, route ? undefined : this.analyzedModules);
|
---|
| 207 | };
|
---|
| 208 | AngularCompilerProgram.prototype.emit = function (parameters) {
|
---|
| 209 | if (parameters === void 0) { parameters = {}; }
|
---|
| 210 | if (this.options.enableIvy !== false) {
|
---|
| 211 | throw new Error('Cannot run legacy compiler in ngtsc mode');
|
---|
| 212 | }
|
---|
| 213 | return this._emitRender2(parameters);
|
---|
| 214 | };
|
---|
| 215 | AngularCompilerProgram.prototype._emitRender2 = function (_a) {
|
---|
| 216 | var e_1, _b, e_2, _c;
|
---|
| 217 | var _this = this;
|
---|
| 218 | var _d = _a === void 0 ? {} : _a, _e = _d.emitFlags, emitFlags = _e === void 0 ? api_1.EmitFlags.Default : _e, cancellationToken = _d.cancellationToken, customTransformers = _d.customTransformers, _f = _d.emitCallback, emitCallback = _f === void 0 ? defaultEmitCallback : _f, _g = _d.mergeEmitResultsCallback, mergeEmitResultsCallback = _g === void 0 ? mergeEmitResults : _g;
|
---|
| 219 | var emitStart = Date.now();
|
---|
| 220 | if (emitFlags & api_1.EmitFlags.I18nBundle) {
|
---|
| 221 | var locale = this.options.i18nOutLocale || null;
|
---|
| 222 | var file = this.options.i18nOutFile || null;
|
---|
| 223 | var format = this.options.i18nOutFormat || null;
|
---|
| 224 | var bundle = this.compiler.emitMessageBundle(this.analyzedModules, locale);
|
---|
| 225 | i18n_1.i18nExtract(format, file, this.host, this.options, bundle);
|
---|
| 226 | }
|
---|
| 227 | if ((emitFlags & (api_1.EmitFlags.JS | api_1.EmitFlags.DTS | api_1.EmitFlags.Metadata | api_1.EmitFlags.Codegen)) ===
|
---|
| 228 | 0) {
|
---|
| 229 | return { emitSkipped: true, diagnostics: [], emittedFiles: [] };
|
---|
| 230 | }
|
---|
| 231 | var _h = this.generateFilesForEmit(emitFlags), genFiles = _h.genFiles, genDiags = _h.genDiags;
|
---|
| 232 | if (genDiags.length) {
|
---|
| 233 | return {
|
---|
| 234 | diagnostics: genDiags,
|
---|
| 235 | emitSkipped: true,
|
---|
| 236 | emittedFiles: [],
|
---|
| 237 | };
|
---|
| 238 | }
|
---|
| 239 | this.emittedGeneratedFiles = genFiles;
|
---|
| 240 | var outSrcMapping = [];
|
---|
| 241 | var genFileByFileName = new Map();
|
---|
| 242 | genFiles.forEach(function (genFile) { return genFileByFileName.set(genFile.genFileUrl, genFile); });
|
---|
| 243 | this.emittedLibrarySummaries = [];
|
---|
| 244 | this._transformTsDiagnostics = [];
|
---|
| 245 | var emittedSourceFiles = [];
|
---|
| 246 | var writeTsFile = function (outFileName, outData, writeByteOrderMark, onError, sourceFiles) {
|
---|
| 247 | var sourceFile = sourceFiles && sourceFiles.length == 1 ? sourceFiles[0] : null;
|
---|
| 248 | var genFile;
|
---|
| 249 | if (sourceFile) {
|
---|
| 250 | outSrcMapping.push({ outFileName: outFileName, sourceFile: sourceFile });
|
---|
| 251 | genFile = genFileByFileName.get(sourceFile.fileName);
|
---|
| 252 | if (!sourceFile.isDeclarationFile && !util_1.GENERATED_FILES.test(sourceFile.fileName)) {
|
---|
| 253 | // Note: sourceFile is the transformed sourcefile, not the original one!
|
---|
| 254 | var originalFile = _this.tsProgram.getSourceFile(sourceFile.fileName);
|
---|
| 255 | if (originalFile) {
|
---|
| 256 | emittedSourceFiles.push(originalFile);
|
---|
| 257 | }
|
---|
| 258 | }
|
---|
| 259 | }
|
---|
| 260 | _this.writeFile(outFileName, outData, writeByteOrderMark, onError, genFile, sourceFiles);
|
---|
| 261 | };
|
---|
| 262 | var modules = this._analyzedInjectables &&
|
---|
| 263 | this.compiler.emitAllPartialModules2(this._analyzedInjectables);
|
---|
| 264 | var tsCustomTransformers = this.calculateTransforms(genFileByFileName, modules, customTransformers);
|
---|
| 265 | var emitOnlyDtsFiles = (emitFlags & (api_1.EmitFlags.DTS | api_1.EmitFlags.JS)) == api_1.EmitFlags.DTS;
|
---|
| 266 | // Restore the original references before we emit so TypeScript doesn't emit
|
---|
| 267 | // a reference to the .d.ts file.
|
---|
| 268 | var augmentedReferences = new Map();
|
---|
| 269 | try {
|
---|
| 270 | for (var _j = tslib_1.__values(this.tsProgram.getSourceFiles()), _k = _j.next(); !_k.done; _k = _j.next()) {
|
---|
| 271 | var sourceFile = _k.value;
|
---|
| 272 | var originalReferences = compiler_host_1.getOriginalReferences(sourceFile);
|
---|
| 273 | if (originalReferences) {
|
---|
| 274 | augmentedReferences.set(sourceFile, sourceFile.referencedFiles);
|
---|
| 275 | sourceFile.referencedFiles = originalReferences;
|
---|
| 276 | }
|
---|
| 277 | }
|
---|
| 278 | }
|
---|
| 279 | catch (e_1_1) { e_1 = { error: e_1_1 }; }
|
---|
| 280 | finally {
|
---|
| 281 | try {
|
---|
| 282 | if (_k && !_k.done && (_b = _j.return)) _b.call(_j);
|
---|
| 283 | }
|
---|
| 284 | finally { if (e_1) throw e_1.error; }
|
---|
| 285 | }
|
---|
| 286 | var genTsFiles = [];
|
---|
| 287 | var genJsonFiles = [];
|
---|
| 288 | genFiles.forEach(function (gf) {
|
---|
| 289 | if (gf.stmts) {
|
---|
| 290 | genTsFiles.push(gf);
|
---|
| 291 | }
|
---|
| 292 | if (gf.source) {
|
---|
| 293 | genJsonFiles.push(gf);
|
---|
| 294 | }
|
---|
| 295 | });
|
---|
| 296 | var emitResult;
|
---|
| 297 | var emittedUserTsCount;
|
---|
| 298 | try {
|
---|
| 299 | var sourceFilesToEmit = this.getSourceFilesForEmit();
|
---|
| 300 | if (sourceFilesToEmit &&
|
---|
| 301 | (sourceFilesToEmit.length + genTsFiles.length) < MAX_FILE_COUNT_FOR_SINGLE_FILE_EMIT) {
|
---|
| 302 | var fileNamesToEmit = tslib_1.__spreadArray(tslib_1.__spreadArray([], tslib_1.__read(sourceFilesToEmit.map(function (sf) { return sf.fileName; }))), tslib_1.__read(genTsFiles.map(function (gf) { return gf.genFileUrl; })));
|
---|
| 303 | emitResult = mergeEmitResultsCallback(fileNamesToEmit.map(function (fileName) { return emitResult = emitCallback({
|
---|
| 304 | program: _this.tsProgram,
|
---|
| 305 | host: _this.host,
|
---|
| 306 | options: _this.options,
|
---|
| 307 | writeFile: writeTsFile,
|
---|
| 308 | emitOnlyDtsFiles: emitOnlyDtsFiles,
|
---|
| 309 | customTransformers: tsCustomTransformers,
|
---|
| 310 | targetSourceFile: _this.tsProgram.getSourceFile(fileName),
|
---|
| 311 | }); }));
|
---|
| 312 | emittedUserTsCount = sourceFilesToEmit.length;
|
---|
| 313 | }
|
---|
| 314 | else {
|
---|
| 315 | emitResult = emitCallback({
|
---|
| 316 | program: this.tsProgram,
|
---|
| 317 | host: this.host,
|
---|
| 318 | options: this.options,
|
---|
| 319 | writeFile: writeTsFile,
|
---|
| 320 | emitOnlyDtsFiles: emitOnlyDtsFiles,
|
---|
| 321 | customTransformers: tsCustomTransformers
|
---|
| 322 | });
|
---|
| 323 | emittedUserTsCount = this.tsProgram.getSourceFiles().length - genTsFiles.length;
|
---|
| 324 | }
|
---|
| 325 | }
|
---|
| 326 | finally {
|
---|
| 327 | try {
|
---|
| 328 | // Restore the references back to the augmented value to ensure that the
|
---|
| 329 | // checks that TypeScript makes for project structure reuse will succeed.
|
---|
| 330 | for (var _l = tslib_1.__values(Array.from(augmentedReferences)), _m = _l.next(); !_m.done; _m = _l.next()) {
|
---|
| 331 | var _o = tslib_1.__read(_m.value, 2), sourceFile = _o[0], references = _o[1];
|
---|
| 332 | // TODO(chuckj): Remove any cast after updating build to 2.6
|
---|
| 333 | sourceFile.referencedFiles = references;
|
---|
| 334 | }
|
---|
| 335 | }
|
---|
| 336 | catch (e_2_1) { e_2 = { error: e_2_1 }; }
|
---|
| 337 | finally {
|
---|
| 338 | try {
|
---|
| 339 | if (_m && !_m.done && (_c = _l.return)) _c.call(_l);
|
---|
| 340 | }
|
---|
| 341 | finally { if (e_2) throw e_2.error; }
|
---|
| 342 | }
|
---|
| 343 | }
|
---|
| 344 | this.emittedSourceFiles = emittedSourceFiles;
|
---|
| 345 | // Match behavior of tsc: only produce emit diagnostics if it would block
|
---|
| 346 | // emit. If noEmitOnError is false, the emit will happen in spite of any
|
---|
| 347 | // errors, so we should not report them.
|
---|
| 348 | if (emitResult && this.options.noEmitOnError === true) {
|
---|
| 349 | // translate the diagnostics in the emitResult as well.
|
---|
| 350 | var translatedEmitDiags = translate_diagnostics_1.translateDiagnostics(this.hostAdapter, emitResult.diagnostics);
|
---|
| 351 | emitResult.diagnostics = translatedEmitDiags.ts.concat(this.structuralDiagnostics.concat(translatedEmitDiags.ng).map(util_1.ngToTsDiagnostic));
|
---|
| 352 | }
|
---|
| 353 | if (emitResult && !outSrcMapping.length) {
|
---|
| 354 | // if no files were emitted by TypeScript, also don't emit .json files
|
---|
| 355 | emitResult.diagnostics =
|
---|
| 356 | emitResult.diagnostics.concat([util_1.createMessageDiagnostic("Emitted no files.")]);
|
---|
| 357 | return emitResult;
|
---|
| 358 | }
|
---|
| 359 | var sampleSrcFileName;
|
---|
| 360 | var sampleOutFileName;
|
---|
| 361 | if (outSrcMapping.length) {
|
---|
| 362 | sampleSrcFileName = outSrcMapping[0].sourceFile.fileName;
|
---|
| 363 | sampleOutFileName = outSrcMapping[0].outFileName;
|
---|
| 364 | }
|
---|
| 365 | var srcToOutPath = createSrcToOutPathMapper(this.options.outDir, sampleSrcFileName, sampleOutFileName);
|
---|
| 366 | if (emitFlags & api_1.EmitFlags.Codegen) {
|
---|
| 367 | genJsonFiles.forEach(function (gf) {
|
---|
| 368 | var outFileName = srcToOutPath(gf.genFileUrl);
|
---|
| 369 | _this.writeFile(outFileName, gf.source, false, undefined, gf);
|
---|
| 370 | });
|
---|
| 371 | }
|
---|
| 372 | var metadataJsonCount = 0;
|
---|
| 373 | if (emitFlags & api_1.EmitFlags.Metadata) {
|
---|
| 374 | this.tsProgram.getSourceFiles().forEach(function (sf) {
|
---|
| 375 | if (!sf.isDeclarationFile && !util_1.GENERATED_FILES.test(sf.fileName)) {
|
---|
| 376 | metadataJsonCount++;
|
---|
| 377 | var metadata = _this.metadataCache.getMetadata(sf);
|
---|
| 378 | if (metadata) {
|
---|
| 379 | var metadataText = JSON.stringify([metadata]);
|
---|
| 380 | var outFileName = srcToOutPath(sf.fileName.replace(/\.tsx?$/, '.metadata.json'));
|
---|
| 381 | _this.writeFile(outFileName, metadataText, false, undefined, undefined, [sf]);
|
---|
| 382 | }
|
---|
| 383 | }
|
---|
| 384 | });
|
---|
| 385 | }
|
---|
| 386 | var emitEnd = Date.now();
|
---|
| 387 | if (emitResult && this.options.diagnostics) {
|
---|
| 388 | emitResult.diagnostics = emitResult.diagnostics.concat([util_1.createMessageDiagnostic([
|
---|
| 389 | "Emitted in " + (emitEnd - emitStart) + "ms",
|
---|
| 390 | "- " + emittedUserTsCount + " user ts files",
|
---|
| 391 | "- " + genTsFiles.length + " generated ts files",
|
---|
| 392 | "- " + (genJsonFiles.length + metadataJsonCount) + " generated json files",
|
---|
| 393 | ].join('\n'))]);
|
---|
| 394 | }
|
---|
| 395 | return emitResult;
|
---|
| 396 | };
|
---|
| 397 | Object.defineProperty(AngularCompilerProgram.prototype, "compiler", {
|
---|
| 398 | // Private members
|
---|
| 399 | get: function () {
|
---|
| 400 | if (!this._compiler) {
|
---|
| 401 | this._createCompiler();
|
---|
| 402 | }
|
---|
| 403 | return this._compiler;
|
---|
| 404 | },
|
---|
| 405 | enumerable: false,
|
---|
| 406 | configurable: true
|
---|
| 407 | });
|
---|
| 408 | Object.defineProperty(AngularCompilerProgram.prototype, "hostAdapter", {
|
---|
| 409 | get: function () {
|
---|
| 410 | if (!this._hostAdapter) {
|
---|
| 411 | this._createCompiler();
|
---|
| 412 | }
|
---|
| 413 | return this._hostAdapter;
|
---|
| 414 | },
|
---|
| 415 | enumerable: false,
|
---|
| 416 | configurable: true
|
---|
| 417 | });
|
---|
| 418 | Object.defineProperty(AngularCompilerProgram.prototype, "analyzedModules", {
|
---|
| 419 | get: function () {
|
---|
| 420 | if (!this._analyzedModules) {
|
---|
| 421 | this.initSync();
|
---|
| 422 | }
|
---|
| 423 | return this._analyzedModules;
|
---|
| 424 | },
|
---|
| 425 | enumerable: false,
|
---|
| 426 | configurable: true
|
---|
| 427 | });
|
---|
| 428 | Object.defineProperty(AngularCompilerProgram.prototype, "structuralDiagnostics", {
|
---|
| 429 | get: function () {
|
---|
| 430 | var diagnostics = this._structuralDiagnostics;
|
---|
| 431 | if (!diagnostics) {
|
---|
| 432 | this.initSync();
|
---|
| 433 | diagnostics = (this._structuralDiagnostics = this._structuralDiagnostics || []);
|
---|
| 434 | }
|
---|
| 435 | return diagnostics;
|
---|
| 436 | },
|
---|
| 437 | enumerable: false,
|
---|
| 438 | configurable: true
|
---|
| 439 | });
|
---|
| 440 | Object.defineProperty(AngularCompilerProgram.prototype, "tsProgram", {
|
---|
| 441 | get: function () {
|
---|
| 442 | if (!this._tsProgram) {
|
---|
| 443 | this.initSync();
|
---|
| 444 | }
|
---|
| 445 | return this._tsProgram;
|
---|
| 446 | },
|
---|
| 447 | enumerable: false,
|
---|
| 448 | configurable: true
|
---|
| 449 | });
|
---|
| 450 | Object.defineProperty(AngularCompilerProgram.prototype, "isCompilingAngularCore", {
|
---|
| 451 | /** Whether the program is compiling the Angular core package. */
|
---|
| 452 | get: function () {
|
---|
| 453 | if (this._isCompilingAngularCore !== null) {
|
---|
| 454 | return this._isCompilingAngularCore;
|
---|
| 455 | }
|
---|
| 456 | return this._isCompilingAngularCore = compiler_2.isAngularCorePackage(this.tsProgram);
|
---|
| 457 | },
|
---|
| 458 | enumerable: false,
|
---|
| 459 | configurable: true
|
---|
| 460 | });
|
---|
| 461 | AngularCompilerProgram.prototype.calculateTransforms = function (genFiles, partialModules, customTransformers) {
|
---|
| 462 | var beforeTs = [];
|
---|
| 463 | var metadataTransforms = [];
|
---|
| 464 | var flatModuleMetadataTransforms = [];
|
---|
| 465 | var annotateForClosureCompiler = this.options.annotateForClosureCompiler || false;
|
---|
| 466 | if (this.options.enableResourceInlining) {
|
---|
| 467 | beforeTs.push(inline_resources_1.getInlineResourcesTransformFactory(this.tsProgram, this.hostAdapter));
|
---|
| 468 | var transformer = new inline_resources_1.InlineResourcesMetadataTransformer(this.hostAdapter);
|
---|
| 469 | metadataTransforms.push(transformer);
|
---|
| 470 | flatModuleMetadataTransforms.push(transformer);
|
---|
| 471 | }
|
---|
| 472 | if (!this.options.disableExpressionLowering) {
|
---|
| 473 | beforeTs.push(lower_expressions_1.getExpressionLoweringTransformFactory(this.loweringMetadataTransform, this.tsProgram));
|
---|
| 474 | metadataTransforms.push(this.loweringMetadataTransform);
|
---|
| 475 | }
|
---|
| 476 | if (genFiles) {
|
---|
| 477 | beforeTs.push(node_emitter_transform_1.getAngularEmitterTransformFactory(genFiles, this.getTsProgram(), annotateForClosureCompiler));
|
---|
| 478 | }
|
---|
| 479 | if (partialModules) {
|
---|
| 480 | beforeTs.push(r3_transform_1.getAngularClassTransformerFactory(partialModules, annotateForClosureCompiler));
|
---|
| 481 | // If we have partial modules, the cached metadata might be incorrect as it doesn't reflect
|
---|
| 482 | // the partial module transforms.
|
---|
| 483 | var transformer = new r3_metadata_transform_1.PartialModuleMetadataTransformer(partialModules);
|
---|
| 484 | metadataTransforms.push(transformer);
|
---|
| 485 | flatModuleMetadataTransforms.push(transformer);
|
---|
| 486 | }
|
---|
| 487 | if (customTransformers && customTransformers.beforeTs) {
|
---|
| 488 | beforeTs.push.apply(beforeTs, tslib_1.__spreadArray([], tslib_1.__read(customTransformers.beforeTs)));
|
---|
| 489 | }
|
---|
| 490 | // If decorators should be converted to static fields (enabled by default), we set up
|
---|
| 491 | // the decorator downlevel transform. Note that we set it up as last transform as that
|
---|
| 492 | // allows custom transformers to strip Angular decorators without having to deal with
|
---|
| 493 | // identifying static properties. e.g. it's more difficult handling `<..>.decorators`
|
---|
| 494 | // or `<..>.ctorParameters` compared to the `ts.Decorator` AST nodes.
|
---|
| 495 | if (this.options.annotationsAs !== 'decorators') {
|
---|
| 496 | var typeChecker = this.getTsProgram().getTypeChecker();
|
---|
| 497 | var reflectionHost = new reflection_1.TypeScriptReflectionHost(typeChecker);
|
---|
| 498 | // Similarly to how we handled tsickle decorator downleveling in the past, we just
|
---|
| 499 | // ignore diagnostics that have been collected by the transformer. These are
|
---|
| 500 | // non-significant failures that shouldn't prevent apps from compiling.
|
---|
| 501 | beforeTs.push(downlevel_decorators_transform_1.getDownlevelDecoratorsTransform(typeChecker, reflectionHost, [], this.isCompilingAngularCore, annotateForClosureCompiler,
|
---|
| 502 | /* skipClassDecorators */ false));
|
---|
| 503 | }
|
---|
| 504 | if (metadataTransforms.length > 0) {
|
---|
| 505 | this.metadataCache = this.createMetadataCache(metadataTransforms);
|
---|
| 506 | }
|
---|
| 507 | if (flatModuleMetadataTransforms.length > 0) {
|
---|
| 508 | this.flatModuleMetadataCache = this.createMetadataCache(flatModuleMetadataTransforms);
|
---|
| 509 | }
|
---|
| 510 | var afterTs = customTransformers ? customTransformers.afterTs : undefined;
|
---|
| 511 | return { before: beforeTs, after: afterTs };
|
---|
| 512 | };
|
---|
| 513 | AngularCompilerProgram.prototype.initSync = function () {
|
---|
| 514 | if (this._analyzedModules) {
|
---|
| 515 | return;
|
---|
| 516 | }
|
---|
| 517 | try {
|
---|
| 518 | var _a = this._createProgramWithBasicStubs(), tmpProgram = _a.tmpProgram, sourceFiles = _a.sourceFiles, tsFiles = _a.tsFiles, rootNames = _a.rootNames;
|
---|
| 519 | var _b = this.compiler.loadFilesSync(sourceFiles, tsFiles), analyzedModules = _b.analyzedModules, analyzedInjectables = _b.analyzedInjectables;
|
---|
| 520 | this._updateProgramWithTypeCheckStubs(tmpProgram, analyzedModules, analyzedInjectables, rootNames);
|
---|
| 521 | }
|
---|
| 522 | catch (e) {
|
---|
| 523 | this._createProgramOnError(e);
|
---|
| 524 | }
|
---|
| 525 | };
|
---|
| 526 | AngularCompilerProgram.prototype._createCompiler = function () {
|
---|
| 527 | var _this = this;
|
---|
| 528 | var codegen = {
|
---|
| 529 | generateFile: function (genFileName, baseFileName) {
|
---|
| 530 | return _this._compiler.emitBasicStub(genFileName, baseFileName);
|
---|
| 531 | },
|
---|
| 532 | findGeneratedFileNames: function (fileName) { return _this._compiler.findGeneratedFileNames(fileName); },
|
---|
| 533 | };
|
---|
| 534 | this._hostAdapter = new compiler_host_1.TsCompilerAotCompilerTypeCheckHostAdapter(this.rootNames, this.options, this.host, this.metadataCache, codegen, this.oldProgramLibrarySummaries);
|
---|
| 535 | var aotOptions = getAotCompilerOptions(this.options);
|
---|
| 536 | var errorCollector = (this.options.collectAllErrors || this.options.fullTemplateTypeCheck) ?
|
---|
| 537 | function (err) { return _this._addStructuralDiagnostics(err); } :
|
---|
| 538 | undefined;
|
---|
| 539 | this._compiler = compiler_1.createAotCompiler(this._hostAdapter, aotOptions, errorCollector).compiler;
|
---|
| 540 | };
|
---|
| 541 | AngularCompilerProgram.prototype._createProgramWithBasicStubs = function () {
|
---|
| 542 | var _this = this;
|
---|
| 543 | if (this._analyzedModules) {
|
---|
| 544 | throw new Error("Internal Error: already initialized!");
|
---|
| 545 | }
|
---|
| 546 | // Note: This is important to not produce a memory leak!
|
---|
| 547 | var oldTsProgram = this.oldTsProgram;
|
---|
| 548 | this.oldTsProgram = undefined;
|
---|
| 549 | var codegen = {
|
---|
| 550 | generateFile: function (genFileName, baseFileName) {
|
---|
| 551 | return _this.compiler.emitBasicStub(genFileName, baseFileName);
|
---|
| 552 | },
|
---|
| 553 | findGeneratedFileNames: function (fileName) { return _this.compiler.findGeneratedFileNames(fileName); },
|
---|
| 554 | };
|
---|
| 555 | var rootNames = tslib_1.__spreadArray([], tslib_1.__read(this.rootNames));
|
---|
| 556 | if (this.options.generateCodeForLibraries !== false) {
|
---|
| 557 | // if we should generateCodeForLibraries, never include
|
---|
| 558 | // generated files in the program as otherwise we will
|
---|
| 559 | // overwrite them and typescript will report the error
|
---|
| 560 | // TS5055: Cannot write file ... because it would overwrite input file.
|
---|
| 561 | rootNames = rootNames.filter(function (fn) { return !util_1.GENERATED_FILES.test(fn); });
|
---|
| 562 | }
|
---|
| 563 | if (this.options.noResolve) {
|
---|
| 564 | this.rootNames.forEach(function (rootName) {
|
---|
| 565 | if (_this.hostAdapter.shouldGenerateFilesFor(rootName)) {
|
---|
| 566 | rootNames.push.apply(rootNames, tslib_1.__spreadArray([], tslib_1.__read(_this.compiler.findGeneratedFileNames(rootName))));
|
---|
| 567 | }
|
---|
| 568 | });
|
---|
| 569 | }
|
---|
| 570 | var tmpProgram = ts.createProgram(rootNames, this.options, this.hostAdapter, oldTsProgram);
|
---|
| 571 | if (tempProgramHandlerForTest !== null) {
|
---|
| 572 | tempProgramHandlerForTest(tmpProgram);
|
---|
| 573 | }
|
---|
| 574 | var sourceFiles = [];
|
---|
| 575 | var tsFiles = [];
|
---|
| 576 | tmpProgram.getSourceFiles().forEach(function (sf) {
|
---|
| 577 | if (_this.hostAdapter.isSourceFile(sf.fileName)) {
|
---|
| 578 | sourceFiles.push(sf.fileName);
|
---|
| 579 | }
|
---|
| 580 | if (util_1.TS.test(sf.fileName) && !util_1.DTS.test(sf.fileName)) {
|
---|
| 581 | tsFiles.push(sf.fileName);
|
---|
| 582 | }
|
---|
| 583 | });
|
---|
| 584 | return { tmpProgram: tmpProgram, sourceFiles: sourceFiles, tsFiles: tsFiles, rootNames: rootNames };
|
---|
| 585 | };
|
---|
| 586 | AngularCompilerProgram.prototype._updateProgramWithTypeCheckStubs = function (tmpProgram, analyzedModules, analyzedInjectables, rootNames) {
|
---|
| 587 | var _this = this;
|
---|
| 588 | this._analyzedModules = analyzedModules;
|
---|
| 589 | this._analyzedInjectables = analyzedInjectables;
|
---|
| 590 | tmpProgram.getSourceFiles().forEach(function (sf) {
|
---|
| 591 | if (sf.fileName.endsWith('.ngfactory.ts')) {
|
---|
| 592 | var _a = _this.hostAdapter.shouldGenerateFile(sf.fileName), generate = _a.generate, baseFileName = _a.baseFileName;
|
---|
| 593 | if (generate) {
|
---|
| 594 | // Note: ! is ok as hostAdapter.shouldGenerateFile will always return a baseFileName
|
---|
| 595 | // for .ngfactory.ts files.
|
---|
| 596 | var genFile = _this.compiler.emitTypeCheckStub(sf.fileName, baseFileName);
|
---|
| 597 | if (genFile) {
|
---|
| 598 | _this.hostAdapter.updateGeneratedFile(genFile);
|
---|
| 599 | }
|
---|
| 600 | }
|
---|
| 601 | }
|
---|
| 602 | });
|
---|
| 603 | this._tsProgram = ts.createProgram(rootNames, this.options, this.hostAdapter, tmpProgram);
|
---|
| 604 | // Note: the new ts program should be completely reusable by TypeScript as:
|
---|
| 605 | // - we cache all the files in the hostAdapter
|
---|
| 606 | // - new new stubs use the exactly same imports/exports as the old once (we assert that in
|
---|
| 607 | // hostAdapter.updateGeneratedFile).
|
---|
| 608 | if (util_1.tsStructureIsReused(this._tsProgram) !== 2 /* Completely */) {
|
---|
| 609 | throw new Error("Internal Error: The structure of the program changed during codegen.");
|
---|
| 610 | }
|
---|
| 611 | };
|
---|
| 612 | AngularCompilerProgram.prototype._createProgramOnError = function (e) {
|
---|
| 613 | // Still fill the analyzedModules and the tsProgram
|
---|
| 614 | // so that we don't cause other errors for users who e.g. want to emit the ngProgram.
|
---|
| 615 | this._analyzedModules = emptyModules;
|
---|
| 616 | this.oldTsProgram = undefined;
|
---|
| 617 | this._hostAdapter.isSourceFile = function () { return false; };
|
---|
| 618 | this._tsProgram = ts.createProgram(this.rootNames, this.options, this.hostAdapter);
|
---|
| 619 | if (compiler_1.isSyntaxError(e)) {
|
---|
| 620 | this._addStructuralDiagnostics(e);
|
---|
| 621 | return;
|
---|
| 622 | }
|
---|
| 623 | throw e;
|
---|
| 624 | };
|
---|
| 625 | AngularCompilerProgram.prototype._addStructuralDiagnostics = function (error) {
|
---|
| 626 | var diagnostics = this._structuralDiagnostics || (this._structuralDiagnostics = []);
|
---|
| 627 | if (compiler_1.isSyntaxError(error)) {
|
---|
| 628 | diagnostics.push.apply(diagnostics, tslib_1.__spreadArray([], tslib_1.__read(syntaxErrorToDiagnostics(error, this.tsProgram))));
|
---|
| 629 | }
|
---|
| 630 | else {
|
---|
| 631 | diagnostics.push({
|
---|
| 632 | messageText: error.toString(),
|
---|
| 633 | category: ts.DiagnosticCategory.Error,
|
---|
| 634 | source: api_1.SOURCE,
|
---|
| 635 | code: api_1.DEFAULT_ERROR_CODE
|
---|
| 636 | });
|
---|
| 637 | }
|
---|
| 638 | };
|
---|
| 639 | // Note: this returns a ts.Diagnostic so that we
|
---|
| 640 | // can return errors in a ts.EmitResult
|
---|
| 641 | AngularCompilerProgram.prototype.generateFilesForEmit = function (emitFlags) {
|
---|
| 642 | var _this = this;
|
---|
| 643 | try {
|
---|
| 644 | if (!(emitFlags & api_1.EmitFlags.Codegen)) {
|
---|
| 645 | return { genFiles: [], genDiags: [] };
|
---|
| 646 | }
|
---|
| 647 | // TODO(tbosch): allow generating files that are not in the rootDir
|
---|
| 648 | // See https://github.com/angular/angular/issues/19337
|
---|
| 649 | var genFiles = this.compiler.emitAllImpls(this.analyzedModules)
|
---|
| 650 | .filter(function (genFile) { return util_1.isInRootDir(genFile.genFileUrl, _this.options); });
|
---|
| 651 | if (this.oldProgramEmittedGeneratedFiles) {
|
---|
| 652 | var oldProgramEmittedGeneratedFiles_1 = this.oldProgramEmittedGeneratedFiles;
|
---|
| 653 | genFiles = genFiles.filter(function (genFile) {
|
---|
| 654 | var oldGenFile = oldProgramEmittedGeneratedFiles_1.get(genFile.genFileUrl);
|
---|
| 655 | return !oldGenFile || !genFile.isEquivalent(oldGenFile);
|
---|
| 656 | });
|
---|
| 657 | }
|
---|
| 658 | return { genFiles: genFiles, genDiags: [] };
|
---|
| 659 | }
|
---|
| 660 | catch (e) {
|
---|
| 661 | // TODO(tbosch): check whether we can actually have syntax errors here,
|
---|
| 662 | // as we already parsed the metadata and templates before to create the type check block.
|
---|
| 663 | if (compiler_1.isSyntaxError(e)) {
|
---|
| 664 | var genDiags = [{
|
---|
| 665 | file: undefined,
|
---|
| 666 | start: undefined,
|
---|
| 667 | length: undefined,
|
---|
| 668 | messageText: e.message,
|
---|
| 669 | category: ts.DiagnosticCategory.Error,
|
---|
| 670 | source: api_1.SOURCE,
|
---|
| 671 | code: api_1.DEFAULT_ERROR_CODE
|
---|
| 672 | }];
|
---|
| 673 | return { genFiles: [], genDiags: genDiags };
|
---|
| 674 | }
|
---|
| 675 | throw e;
|
---|
| 676 | }
|
---|
| 677 | };
|
---|
| 678 | /**
|
---|
| 679 | * Returns undefined if all files should be emitted.
|
---|
| 680 | */
|
---|
| 681 | AngularCompilerProgram.prototype.getSourceFilesForEmit = function () {
|
---|
| 682 | var _this = this;
|
---|
| 683 | // TODO(tbosch): if one of the files contains a `const enum`
|
---|
| 684 | // always emit all files -> return undefined!
|
---|
| 685 | var sourceFilesToEmit = this.tsProgram.getSourceFiles().filter(function (sf) {
|
---|
| 686 | return !sf.isDeclarationFile && !util_1.GENERATED_FILES.test(sf.fileName);
|
---|
| 687 | });
|
---|
| 688 | if (this.oldProgramEmittedSourceFiles) {
|
---|
| 689 | sourceFilesToEmit = sourceFilesToEmit.filter(function (sf) {
|
---|
| 690 | var oldFile = _this.oldProgramEmittedSourceFiles.get(sf.fileName);
|
---|
| 691 | return sf !== oldFile;
|
---|
| 692 | });
|
---|
| 693 | }
|
---|
| 694 | return sourceFilesToEmit;
|
---|
| 695 | };
|
---|
| 696 | AngularCompilerProgram.prototype.writeFile = function (outFileName, outData, writeByteOrderMark, onError, genFile, sourceFiles) {
|
---|
| 697 | // collect emittedLibrarySummaries
|
---|
| 698 | var baseFile;
|
---|
| 699 | if (genFile) {
|
---|
| 700 | baseFile = this.tsProgram.getSourceFile(genFile.srcFileUrl);
|
---|
| 701 | if (baseFile) {
|
---|
| 702 | if (!this.emittedLibrarySummaries) {
|
---|
| 703 | this.emittedLibrarySummaries = [];
|
---|
| 704 | }
|
---|
| 705 | if (genFile.genFileUrl.endsWith('.ngsummary.json') && baseFile.fileName.endsWith('.d.ts')) {
|
---|
| 706 | this.emittedLibrarySummaries.push({
|
---|
| 707 | fileName: baseFile.fileName,
|
---|
| 708 | text: baseFile.text,
|
---|
| 709 | sourceFile: baseFile,
|
---|
| 710 | });
|
---|
| 711 | this.emittedLibrarySummaries.push({ fileName: genFile.genFileUrl, text: outData });
|
---|
| 712 | if (!this.options.declaration) {
|
---|
| 713 | // If we don't emit declarations, still record an empty .ngfactory.d.ts file,
|
---|
| 714 | // as we might need it later on for resolving module names from summaries.
|
---|
| 715 | var ngFactoryDts = genFile.genFileUrl.substring(0, genFile.genFileUrl.length - 15) + '.ngfactory.d.ts';
|
---|
| 716 | this.emittedLibrarySummaries.push({ fileName: ngFactoryDts, text: '' });
|
---|
| 717 | }
|
---|
| 718 | }
|
---|
| 719 | else if (outFileName.endsWith('.d.ts') && baseFile.fileName.endsWith('.d.ts')) {
|
---|
| 720 | var dtsSourceFilePath = genFile.genFileUrl.replace(/\.ts$/, '.d.ts');
|
---|
| 721 | // Note: Don't use sourceFiles here as the created .d.ts has a path in the outDir,
|
---|
| 722 | // but we need one that is next to the .ts file
|
---|
| 723 | this.emittedLibrarySummaries.push({ fileName: dtsSourceFilePath, text: outData });
|
---|
| 724 | }
|
---|
| 725 | }
|
---|
| 726 | }
|
---|
| 727 | // Filter out generated files for which we didn't generate code.
|
---|
| 728 | // This can happen as the stub calculation is not completely exact.
|
---|
| 729 | // Note: sourceFile refers to the .ngfactory.ts / .ngsummary.ts file
|
---|
| 730 | // node_emitter_transform already set the file contents to be empty,
|
---|
| 731 | // so this code only needs to skip the file if !allowEmptyCodegenFiles.
|
---|
| 732 | var isGenerated = util_1.GENERATED_FILES.test(outFileName);
|
---|
| 733 | if (isGenerated && !this.options.allowEmptyCodegenFiles &&
|
---|
| 734 | (!genFile || !genFile.stmts || genFile.stmts.length === 0)) {
|
---|
| 735 | return;
|
---|
| 736 | }
|
---|
| 737 | if (baseFile) {
|
---|
| 738 | sourceFiles = sourceFiles ? tslib_1.__spreadArray(tslib_1.__spreadArray([], tslib_1.__read(sourceFiles)), [baseFile]) : [baseFile];
|
---|
| 739 | }
|
---|
| 740 | // TODO: remove any when TS 2.4 support is removed.
|
---|
| 741 | this.host.writeFile(outFileName, outData, writeByteOrderMark, onError, sourceFiles);
|
---|
| 742 | };
|
---|
| 743 | return AngularCompilerProgram;
|
---|
| 744 | }());
|
---|
| 745 | function createProgram(_a) {
|
---|
| 746 | var rootNames = _a.rootNames, options = _a.options, host = _a.host, oldProgram = _a.oldProgram;
|
---|
| 747 | if (options.enableIvy !== false) {
|
---|
| 748 | return new program_1.NgtscProgram(rootNames, options, host, oldProgram);
|
---|
| 749 | }
|
---|
| 750 | else {
|
---|
| 751 | return new AngularCompilerProgram(rootNames, options, host, oldProgram);
|
---|
| 752 | }
|
---|
| 753 | }
|
---|
| 754 | exports.createProgram = createProgram;
|
---|
| 755 | // Compute the AotCompiler options
|
---|
| 756 | function getAotCompilerOptions(options) {
|
---|
| 757 | var missingTranslation = compiler_1.core.MissingTranslationStrategy.Warning;
|
---|
| 758 | switch (options.i18nInMissingTranslations) {
|
---|
| 759 | case 'ignore':
|
---|
| 760 | missingTranslation = compiler_1.core.MissingTranslationStrategy.Ignore;
|
---|
| 761 | break;
|
---|
| 762 | case 'error':
|
---|
| 763 | missingTranslation = compiler_1.core.MissingTranslationStrategy.Error;
|
---|
| 764 | break;
|
---|
| 765 | }
|
---|
| 766 | var translations = '';
|
---|
| 767 | if (options.i18nInFile) {
|
---|
| 768 | if (!options.i18nInLocale) {
|
---|
| 769 | throw new Error("The translation file (" + options.i18nInFile + ") locale must be provided.");
|
---|
| 770 | }
|
---|
| 771 | translations = fs.readFileSync(options.i18nInFile, 'utf8');
|
---|
| 772 | }
|
---|
| 773 | else {
|
---|
| 774 | // No translations are provided, ignore any errors
|
---|
| 775 | // We still go through i18n to remove i18n attributes
|
---|
| 776 | missingTranslation = compiler_1.core.MissingTranslationStrategy.Ignore;
|
---|
| 777 | }
|
---|
| 778 | return {
|
---|
| 779 | locale: options.i18nInLocale,
|
---|
| 780 | i18nFormat: options.i18nInFormat || options.i18nOutFormat,
|
---|
| 781 | i18nUseExternalIds: options.i18nUseExternalIds,
|
---|
| 782 | translations: translations,
|
---|
| 783 | missingTranslation: missingTranslation,
|
---|
| 784 | enableSummariesForJit: options.enableSummariesForJit,
|
---|
| 785 | preserveWhitespaces: options.preserveWhitespaces,
|
---|
| 786 | fullTemplateTypeCheck: options.fullTemplateTypeCheck,
|
---|
| 787 | allowEmptyCodegenFiles: options.allowEmptyCodegenFiles,
|
---|
| 788 | enableIvy: options.enableIvy,
|
---|
| 789 | createExternalSymbolFactoryReexports: options.createExternalSymbolFactoryReexports,
|
---|
| 790 | };
|
---|
| 791 | }
|
---|
| 792 | function getNgOptionDiagnostics(options) {
|
---|
| 793 | if (options.annotationsAs) {
|
---|
| 794 | switch (options.annotationsAs) {
|
---|
| 795 | case 'decorators':
|
---|
| 796 | case 'static fields':
|
---|
| 797 | break;
|
---|
| 798 | default:
|
---|
| 799 | return [{
|
---|
| 800 | messageText: 'Angular compiler options "annotationsAs" only supports "static fields" and "decorators"',
|
---|
| 801 | category: ts.DiagnosticCategory.Error,
|
---|
| 802 | source: api_1.SOURCE,
|
---|
| 803 | code: api_1.DEFAULT_ERROR_CODE
|
---|
| 804 | }];
|
---|
| 805 | }
|
---|
| 806 | }
|
---|
| 807 | return [];
|
---|
| 808 | }
|
---|
| 809 | function normalizeSeparators(path) {
|
---|
| 810 | return path.replace(/\\/g, '/');
|
---|
| 811 | }
|
---|
| 812 | /**
|
---|
| 813 | * Returns a function that can adjust a path from source path to out path,
|
---|
| 814 | * based on an existing mapping from source to out path.
|
---|
| 815 | *
|
---|
| 816 | * TODO(tbosch): talk to the TypeScript team to expose their logic for calculating the `rootDir`
|
---|
| 817 | * if none was specified.
|
---|
| 818 | *
|
---|
| 819 | * Note: This function works on normalized paths from typescript but should always return
|
---|
| 820 | * POSIX normalized paths for output paths.
|
---|
| 821 | */
|
---|
| 822 | function createSrcToOutPathMapper(outDir, sampleSrcFileName, sampleOutFileName, host) {
|
---|
| 823 | if (host === void 0) { host = path; }
|
---|
| 824 | if (outDir) {
|
---|
| 825 | var path_1 = {}; // Ensure we error if we use `path` instead of `host`.
|
---|
| 826 | if (sampleSrcFileName == null || sampleOutFileName == null) {
|
---|
| 827 | throw new Error("Can't calculate the rootDir without a sample srcFileName / outFileName. ");
|
---|
| 828 | }
|
---|
| 829 | var srcFileDir = normalizeSeparators(host.dirname(sampleSrcFileName));
|
---|
| 830 | var outFileDir = normalizeSeparators(host.dirname(sampleOutFileName));
|
---|
| 831 | if (srcFileDir === outFileDir) {
|
---|
| 832 | return function (srcFileName) { return srcFileName; };
|
---|
| 833 | }
|
---|
| 834 | // calculate the common suffix, stopping
|
---|
| 835 | // at `outDir`.
|
---|
| 836 | var srcDirParts = srcFileDir.split('/');
|
---|
| 837 | var outDirParts = normalizeSeparators(host.relative(outDir, outFileDir)).split('/');
|
---|
| 838 | var i = 0;
|
---|
| 839 | while (i < Math.min(srcDirParts.length, outDirParts.length) &&
|
---|
| 840 | srcDirParts[srcDirParts.length - 1 - i] === outDirParts[outDirParts.length - 1 - i])
|
---|
| 841 | i++;
|
---|
| 842 | var rootDir_1 = srcDirParts.slice(0, srcDirParts.length - i).join('/');
|
---|
| 843 | return function (srcFileName) {
|
---|
| 844 | // Note: Before we return the mapped output path, we need to normalize the path delimiters
|
---|
| 845 | // because the output path is usually passed to TypeScript which sometimes only expects
|
---|
| 846 | // posix normalized paths (e.g. if a custom compiler host is used)
|
---|
| 847 | return normalizeSeparators(host.resolve(outDir, host.relative(rootDir_1, srcFileName)));
|
---|
| 848 | };
|
---|
| 849 | }
|
---|
| 850 | else {
|
---|
| 851 | // Note: Before we return the output path, we need to normalize the path delimiters because
|
---|
| 852 | // the output path is usually passed to TypeScript which only passes around posix
|
---|
| 853 | // normalized paths (e.g. if a custom compiler host is used)
|
---|
| 854 | return function (srcFileName) { return normalizeSeparators(srcFileName); };
|
---|
| 855 | }
|
---|
| 856 | }
|
---|
| 857 | exports.createSrcToOutPathMapper = createSrcToOutPathMapper;
|
---|
| 858 | function mergeEmitResults(emitResults) {
|
---|
| 859 | var e_3, _a;
|
---|
| 860 | var diagnostics = [];
|
---|
| 861 | var emitSkipped = false;
|
---|
| 862 | var emittedFiles = [];
|
---|
| 863 | try {
|
---|
| 864 | for (var emitResults_1 = tslib_1.__values(emitResults), emitResults_1_1 = emitResults_1.next(); !emitResults_1_1.done; emitResults_1_1 = emitResults_1.next()) {
|
---|
| 865 | var er = emitResults_1_1.value;
|
---|
| 866 | diagnostics.push.apply(diagnostics, tslib_1.__spreadArray([], tslib_1.__read(er.diagnostics)));
|
---|
| 867 | emitSkipped = emitSkipped || er.emitSkipped;
|
---|
| 868 | emittedFiles.push.apply(emittedFiles, tslib_1.__spreadArray([], tslib_1.__read((er.emittedFiles || []))));
|
---|
| 869 | }
|
---|
| 870 | }
|
---|
| 871 | catch (e_3_1) { e_3 = { error: e_3_1 }; }
|
---|
| 872 | finally {
|
---|
| 873 | try {
|
---|
| 874 | if (emitResults_1_1 && !emitResults_1_1.done && (_a = emitResults_1.return)) _a.call(emitResults_1);
|
---|
| 875 | }
|
---|
| 876 | finally { if (e_3) throw e_3.error; }
|
---|
| 877 | }
|
---|
| 878 | return { diagnostics: diagnostics, emitSkipped: emitSkipped, emittedFiles: emittedFiles };
|
---|
| 879 | }
|
---|
| 880 | function diagnosticSourceOfSpan(span) {
|
---|
| 881 | // For diagnostics, TypeScript only uses the fileName and text properties.
|
---|
| 882 | // The redundant '()' are here is to avoid having clang-format breaking the line incorrectly.
|
---|
| 883 | return { fileName: span.start.file.url, text: span.start.file.content };
|
---|
| 884 | }
|
---|
| 885 | function diagnosticSourceOfFileName(fileName, program) {
|
---|
| 886 | var sourceFile = program.getSourceFile(fileName);
|
---|
| 887 | if (sourceFile)
|
---|
| 888 | return sourceFile;
|
---|
| 889 | // If we are reporting diagnostics for a source file that is not in the project then we need
|
---|
| 890 | // to fake a source file so the diagnostic formatting routines can emit the file name.
|
---|
| 891 | // The redundant '()' are here is to avoid having clang-format breaking the line incorrectly.
|
---|
| 892 | return { fileName: fileName, text: '' };
|
---|
| 893 | }
|
---|
| 894 | function diagnosticChainFromFormattedDiagnosticChain(chain) {
|
---|
| 895 | return {
|
---|
| 896 | messageText: chain.message,
|
---|
| 897 | next: chain.next && chain.next.map(diagnosticChainFromFormattedDiagnosticChain),
|
---|
| 898 | position: chain.position
|
---|
| 899 | };
|
---|
| 900 | }
|
---|
| 901 | function syntaxErrorToDiagnostics(error, program) {
|
---|
| 902 | var parserErrors = compiler_1.getParseErrors(error);
|
---|
| 903 | if (parserErrors && parserErrors.length) {
|
---|
| 904 | return parserErrors.map(function (e) { return ({
|
---|
| 905 | messageText: e.contextualMessage(),
|
---|
| 906 | file: diagnosticSourceOfSpan(e.span),
|
---|
| 907 | start: e.span.start.offset,
|
---|
| 908 | length: e.span.end.offset - e.span.start.offset,
|
---|
| 909 | category: ts.DiagnosticCategory.Error,
|
---|
| 910 | source: api_1.SOURCE,
|
---|
| 911 | code: api_1.DEFAULT_ERROR_CODE
|
---|
| 912 | }); });
|
---|
| 913 | }
|
---|
| 914 | else if (compiler_1.isFormattedError(error)) {
|
---|
| 915 | return [{
|
---|
| 916 | messageText: error.message,
|
---|
| 917 | chain: error.chain && diagnosticChainFromFormattedDiagnosticChain(error.chain),
|
---|
| 918 | category: ts.DiagnosticCategory.Error,
|
---|
| 919 | source: api_1.SOURCE,
|
---|
| 920 | code: api_1.DEFAULT_ERROR_CODE,
|
---|
| 921 | position: error.position
|
---|
| 922 | }];
|
---|
| 923 | }
|
---|
| 924 | var ngModuleErrorData = compiler_1.getMissingNgModuleMetadataErrorData(error);
|
---|
| 925 | if (ngModuleErrorData !== null) {
|
---|
| 926 | // This error represents the import or export of an `NgModule` that didn't have valid metadata.
|
---|
| 927 | // This _might_ happen because the NgModule in question is an Ivy-compiled library, and we want
|
---|
| 928 | // to show a more useful error if that's the case.
|
---|
| 929 | var ngModuleClass = getDtsClass(program, ngModuleErrorData.fileName, ngModuleErrorData.className);
|
---|
| 930 | if (ngModuleClass !== null && isIvyNgModule(ngModuleClass)) {
|
---|
| 931 | return [{
|
---|
| 932 | messageText: "The NgModule '" + ngModuleErrorData.className + "' in '" + ngModuleErrorData
|
---|
| 933 | .fileName + "' is imported by this compilation, but appears to be part of a library compiled for Angular Ivy. This may occur because:\n\n 1) the library was processed with 'ngcc'. Removing and reinstalling node_modules may fix this problem.\n\n 2) the library was published for Angular Ivy and v12+ applications only. Check its peer dependencies carefully and ensure that you're using a compatible version of Angular.\n\nSee https://angular.io/errors/NG6999 for more information.\n",
|
---|
| 934 | category: ts.DiagnosticCategory.Error,
|
---|
| 935 | code: api_1.DEFAULT_ERROR_CODE,
|
---|
| 936 | source: api_1.SOURCE,
|
---|
| 937 | }];
|
---|
| 938 | }
|
---|
| 939 | }
|
---|
| 940 | // Produce a Diagnostic anyway since we know for sure `error` is a SyntaxError
|
---|
| 941 | return [{
|
---|
| 942 | messageText: error.message,
|
---|
| 943 | category: ts.DiagnosticCategory.Error,
|
---|
| 944 | code: api_1.DEFAULT_ERROR_CODE,
|
---|
| 945 | source: api_1.SOURCE,
|
---|
| 946 | }];
|
---|
| 947 | }
|
---|
| 948 | function getDtsClass(program, fileName, className) {
|
---|
| 949 | var e_4, _a;
|
---|
| 950 | var sf = program.getSourceFile(fileName);
|
---|
| 951 | if (sf === undefined || !sf.isDeclarationFile) {
|
---|
| 952 | return null;
|
---|
| 953 | }
|
---|
| 954 | try {
|
---|
| 955 | for (var _b = tslib_1.__values(sf.statements), _c = _b.next(); !_c.done; _c = _b.next()) {
|
---|
| 956 | var stmt = _c.value;
|
---|
| 957 | if (!ts.isClassDeclaration(stmt)) {
|
---|
| 958 | continue;
|
---|
| 959 | }
|
---|
| 960 | if (stmt.name === undefined || stmt.name.text !== className) {
|
---|
| 961 | continue;
|
---|
| 962 | }
|
---|
| 963 | return stmt;
|
---|
| 964 | }
|
---|
| 965 | }
|
---|
| 966 | catch (e_4_1) { e_4 = { error: e_4_1 }; }
|
---|
| 967 | finally {
|
---|
| 968 | try {
|
---|
| 969 | if (_c && !_c.done && (_a = _b.return)) _a.call(_b);
|
---|
| 970 | }
|
---|
| 971 | finally { if (e_4) throw e_4.error; }
|
---|
| 972 | }
|
---|
| 973 | // No classes found that matched the given name.
|
---|
| 974 | return null;
|
---|
| 975 | }
|
---|
| 976 | function isIvyNgModule(clazz) {
|
---|
| 977 | var e_5, _a;
|
---|
| 978 | try {
|
---|
| 979 | for (var _b = tslib_1.__values(clazz.members), _c = _b.next(); !_c.done; _c = _b.next()) {
|
---|
| 980 | var member = _c.value;
|
---|
| 981 | if (!ts.isPropertyDeclaration(member)) {
|
---|
| 982 | continue;
|
---|
| 983 | }
|
---|
| 984 | if (ts.isIdentifier(member.name) && member.name.text === 'ɵmod') {
|
---|
| 985 | return true;
|
---|
| 986 | }
|
---|
| 987 | }
|
---|
| 988 | }
|
---|
| 989 | catch (e_5_1) { e_5 = { error: e_5_1 }; }
|
---|
| 990 | finally {
|
---|
| 991 | try {
|
---|
| 992 | if (_c && !_c.done && (_a = _b.return)) _a.call(_b);
|
---|
| 993 | }
|
---|
| 994 | finally { if (e_5) throw e_5.error; }
|
---|
| 995 | }
|
---|
| 996 | // No Ivy 'ɵmod' property found.
|
---|
| 997 | return false;
|
---|
| 998 | }
|
---|
| 999 | });
|
---|
| 1000 | //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"program.js","sourceRoot":"","sources":["../../../../../../../packages/compiler-cli/src/transformers/program.ts"],"names":[],"mappings":"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","sourcesContent":["\n/**\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 {AotCompiler, AotCompilerOptions, core, createAotCompiler, FormattedMessageChain, GeneratedFile, getMissingNgModuleMetadataErrorData, getParseErrors, isFormattedError, isSyntaxError, MessageBundle, NgAnalyzedFileWithInjectables, NgAnalyzedModules, ParseSourceSpan, PartialModule} from '@angular/compiler';\nimport * as fs from 'fs';\nimport * as path from 'path';\nimport * as ts from 'typescript';\n\nimport {translateDiagnostics} from '../diagnostics/translate_diagnostics';\nimport {createBundleIndexHost, MetadataCollector} from '../metadata';\nimport {isAngularCorePackage} from '../ngtsc/core/src/compiler';\nimport {NgtscProgram} from '../ngtsc/program';\nimport {TypeScriptReflectionHost} from '../ngtsc/reflection';\nimport {verifySupportedTypeScriptVersion} from '../typescript_support';\n\nimport {CompilerHost, CompilerOptions, CustomTransformers, DEFAULT_ERROR_CODE, Diagnostic, DiagnosticMessageChain, EmitFlags, LazyRoute, LibrarySummary, Program, SOURCE, TsEmitCallback, TsMergeEmitResultsCallback} from './api';\nimport {CodeGenerator, getOriginalReferences, TsCompilerAotCompilerTypeCheckHostAdapter} from './compiler_host';\nimport {getDownlevelDecoratorsTransform} from './downlevel_decorators_transform';\nimport {i18nExtract} from './i18n';\nimport {getInlineResourcesTransformFactory, InlineResourcesMetadataTransformer} from './inline_resources';\nimport {getExpressionLoweringTransformFactory, LowerMetadataTransform} from './lower_expressions';\nimport {MetadataCache, MetadataTransformer} from './metadata_cache';\nimport {getAngularEmitterTransformFactory} from './node_emitter_transform';\nimport {PartialModuleMetadataTransformer} from './r3_metadata_transform';\nimport {getAngularClassTransformerFactory} from './r3_transform';\nimport {createMessageDiagnostic, DTS, GENERATED_FILES, isInRootDir, ngToTsDiagnostic, StructureIsReused, TS, tsStructureIsReused} from './util';\n\n\n/**\n * Maximum number of files that are emitable via calling ts.Program.emit\n * passing individual targetSourceFiles.\n */\nconst MAX_FILE_COUNT_FOR_SINGLE_FILE_EMIT = 20;\n\n\n/**\n * Fields to lower within metadata in render2 mode.\n */\nconst LOWER_FIELDS = ['useValue', 'useFactory', 'data', 'id', 'loadChildren'];\n\n/**\n * Fields to lower within metadata in render3 mode.\n */\nconst R3_LOWER_FIELDS = [...LOWER_FIELDS, 'providers', 'imports', 'exports'];\n\n/**\n * Installs a handler for testing purposes to allow inspection of the temporary program.\n */\nlet tempProgramHandlerForTest: ((program: ts.Program) => void)|null = null;\nexport function setTempProgramHandlerForTest(handler: (program: ts.Program) => void): void {\n  tempProgramHandlerForTest = handler;\n}\nexport function resetTempProgramHandlerForTest(): void {\n  tempProgramHandlerForTest = null;\n}\n\nconst emptyModules: NgAnalyzedModules = {\n  ngModules: [],\n  ngModuleByPipeOrDirective: new Map(),\n  files: []\n};\n\nconst defaultEmitCallback: TsEmitCallback = ({\n  program,\n  targetSourceFile,\n  writeFile,\n  cancellationToken,\n  emitOnlyDtsFiles,\n  customTransformers\n}) =>\n    program.emit(\n        targetSourceFile, writeFile, cancellationToken, emitOnlyDtsFiles, customTransformers);\n\nclass AngularCompilerProgram implements Program {\n  private rootNames: string[];\n  private metadataCache: MetadataCache;\n  // Metadata cache used exclusively for the flat module index\n  // TODO(issue/24571): remove '!'.\n  private flatModuleMetadataCache!: MetadataCache;\n  private loweringMetadataTransform: LowerMetadataTransform;\n  private oldProgramLibrarySummaries: Map<string, LibrarySummary>|undefined;\n  private oldProgramEmittedGeneratedFiles: Map<string, GeneratedFile>|undefined;\n  private oldProgramEmittedSourceFiles: Map<string, ts.SourceFile>|undefined;\n  // Note: This will be cleared out as soon as we create the _tsProgram\n  private oldTsProgram: ts.Program|undefined;\n  private emittedLibrarySummaries: LibrarySummary[]|undefined;\n  private emittedGeneratedFiles: GeneratedFile[]|undefined;\n  private emittedSourceFiles: ts.SourceFile[]|undefined;\n\n  // Lazily initialized fields\n  // TODO(issue/24571): remove '!'.\n  private _compiler!: AotCompiler;\n  // TODO(issue/24571): remove '!'.\n  private _hostAdapter!: TsCompilerAotCompilerTypeCheckHostAdapter;\n  // TODO(issue/24571): remove '!'.\n  private _tsProgram!: ts.Program;\n  private _analyzedModules: NgAnalyzedModules|undefined;\n  private _analyzedInjectables: NgAnalyzedFileWithInjectables[]|undefined;\n  private _structuralDiagnostics: Diagnostic[]|undefined;\n  private _programWithStubs: ts.Program|undefined;\n  private _optionsDiagnostics: Diagnostic[] = [];\n  private _transformTsDiagnostics: ts.Diagnostic[] = [];\n\n  constructor(\n      rootNames: ReadonlyArray<string>, private options: CompilerOptions,\n      private host: CompilerHost, oldProgram?: Program) {\n    this.rootNames = [...rootNames];\n\n    if (!options.disableTypeScriptVersionCheck) {\n      verifySupportedTypeScriptVersion();\n    }\n\n    this.oldTsProgram = oldProgram ? oldProgram.getTsProgram() : undefined;\n    if (oldProgram) {\n      this.oldProgramLibrarySummaries = oldProgram.getLibrarySummaries();\n      this.oldProgramEmittedGeneratedFiles = oldProgram.getEmittedGeneratedFiles();\n      this.oldProgramEmittedSourceFiles = oldProgram.getEmittedSourceFiles();\n    }\n\n    if (options.flatModuleOutFile) {\n      const {host: bundleHost, indexName, errors} =\n          createBundleIndexHost(options, this.rootNames, host, () => this.flatModuleMetadataCache);\n      if (errors) {\n        this._optionsDiagnostics.push(...errors.map(e => ({\n                                                      category: e.category,\n                                                      messageText: e.messageText as string,\n                                                      source: SOURCE,\n                                                      code: DEFAULT_ERROR_CODE\n                                                    })));\n      } else {\n        this.rootNames.push(indexName!);\n        this.host = bundleHost;\n      }\n    }\n\n    this.loweringMetadataTransform =\n        new LowerMetadataTransform(options.enableIvy !== false ? R3_LOWER_FIELDS : LOWER_FIELDS);\n    this.metadataCache = this.createMetadataCache([this.loweringMetadataTransform]);\n  }\n\n  private createMetadataCache(transformers: MetadataTransformer[]) {\n    return new MetadataCache(\n        new MetadataCollector({quotedNames: true}), !!this.options.strictMetadataEmit,\n        transformers);\n  }\n\n  getLibrarySummaries(): Map<string, LibrarySummary> {\n    const result = new Map<string, LibrarySummary>();\n    if (this.oldProgramLibrarySummaries) {\n      this.oldProgramLibrarySummaries.forEach((summary, fileName) => result.set(fileName, summary));\n    }\n    if (this.emittedLibrarySummaries) {\n      this.emittedLibrarySummaries.forEach(\n          (summary, fileName) => result.set(summary.fileName, summary));\n    }\n    return result;\n  }\n\n  getEmittedGeneratedFiles(): Map<string, GeneratedFile> {\n    const result = new Map<string, GeneratedFile>();\n    if (this.oldProgramEmittedGeneratedFiles) {\n      this.oldProgramEmittedGeneratedFiles.forEach(\n          (genFile, fileName) => result.set(fileName, genFile));\n    }\n    if (this.emittedGeneratedFiles) {\n      this.emittedGeneratedFiles.forEach((genFile) => result.set(genFile.genFileUrl, genFile));\n    }\n    return result;\n  }\n\n  getEmittedSourceFiles(): Map<string, ts.SourceFile> {\n    const result = new Map<string, ts.SourceFile>();\n    if (this.oldProgramEmittedSourceFiles) {\n      this.oldProgramEmittedSourceFiles.forEach((sf, fileName) => result.set(fileName, sf));\n    }\n    if (this.emittedSourceFiles) {\n      this.emittedSourceFiles.forEach((sf) => result.set(sf.fileName, sf));\n    }\n    return result;\n  }\n\n  getTsProgram(): ts.Program {\n    return this.tsProgram;\n  }\n\n  getTsOptionDiagnostics(cancellationToken?: ts.CancellationToken) {\n    return this.tsProgram.getOptionsDiagnostics(cancellationToken);\n  }\n\n  getNgOptionDiagnostics(cancellationToken?: ts.CancellationToken): ReadonlyArray<Diagnostic> {\n    return [...this._optionsDiagnostics, ...getNgOptionDiagnostics(this.options)];\n  }\n\n  getTsSyntacticDiagnostics(sourceFile?: ts.SourceFile, cancellationToken?: ts.CancellationToken):\n      ReadonlyArray<ts.Diagnostic> {\n    return this.tsProgram.getSyntacticDiagnostics(sourceFile, cancellationToken);\n  }\n\n  getNgStructuralDiagnostics(cancellationToken?: ts.CancellationToken): ReadonlyArray<Diagnostic> {\n    return this.structuralDiagnostics;\n  }\n\n  getTsSemanticDiagnostics(sourceFile?: ts.SourceFile, cancellationToken?: ts.CancellationToken):\n      ReadonlyArray<ts.Diagnostic> {\n    const sourceFiles = sourceFile ? [sourceFile] : this.tsProgram.getSourceFiles();\n    let diags: ts.Diagnostic[] = [];\n    sourceFiles.forEach(sf => {\n      if (!GENERATED_FILES.test(sf.fileName)) {\n        diags.push(...this.tsProgram.getSemanticDiagnostics(sf, cancellationToken));\n      }\n    });\n    return diags;\n  }\n\n  getNgSemanticDiagnostics(fileName?: string, cancellationToken?: ts.CancellationToken):\n      ReadonlyArray<Diagnostic> {\n    let diags: ts.Diagnostic[] = [];\n    this.tsProgram.getSourceFiles().forEach(sf => {\n      if (GENERATED_FILES.test(sf.fileName) && !sf.isDeclarationFile) {\n        diags.push(...this.tsProgram.getSemanticDiagnostics(sf, cancellationToken));\n      }\n    });\n    const {ng} = translateDiagnostics(this.hostAdapter, diags);\n    return ng;\n  }\n\n  loadNgStructureAsync(): Promise<void> {\n    if (this._analyzedModules) {\n      throw new Error('Angular structure already loaded');\n    }\n    return Promise.resolve()\n        .then(() => {\n          const {tmpProgram, sourceFiles, tsFiles, rootNames} = this._createProgramWithBasicStubs();\n          return this.compiler.loadFilesAsync(sourceFiles, tsFiles)\n              .then(({analyzedModules, analyzedInjectables}) => {\n                if (this._analyzedModules) {\n                  throw new Error('Angular structure loaded both synchronously and asynchronously');\n                }\n                this._updateProgramWithTypeCheckStubs(\n                    tmpProgram, analyzedModules, analyzedInjectables, rootNames);\n              });\n        })\n        .catch(e => this._createProgramOnError(e));\n  }\n\n  listLazyRoutes(route?: string): LazyRoute[] {\n    // Note: Don't analyzedModules if a route is given\n    // to be fast enough.\n    return this.compiler.listLazyRoutes(route, route ? undefined : this.analyzedModules);\n  }\n\n  emit(parameters: {\n    emitFlags?: EmitFlags,\n    cancellationToken?: ts.CancellationToken,\n    customTransformers?: CustomTransformers,\n    emitCallback?: TsEmitCallback,\n    mergeEmitResultsCallback?: TsMergeEmitResultsCallback,\n  } = {}): ts.EmitResult {\n    if (this.options.enableIvy !== false) {\n      throw new Error('Cannot run legacy compiler in ngtsc mode');\n    }\n    return this._emitRender2(parameters);\n  }\n\n  private _emitRender2({\n    emitFlags = EmitFlags.Default,\n    cancellationToken,\n    customTransformers,\n    emitCallback = defaultEmitCallback,\n    mergeEmitResultsCallback = mergeEmitResults,\n  }: {\n    emitFlags?: EmitFlags,\n    cancellationToken?: ts.CancellationToken,\n    customTransformers?: CustomTransformers,\n    emitCallback?: TsEmitCallback,\n    mergeEmitResultsCallback?: TsMergeEmitResultsCallback,\n  } = {}): ts.EmitResult {\n    const emitStart = Date.now();\n    if (emitFlags & EmitFlags.I18nBundle) {\n      const locale = this.options.i18nOutLocale || null;\n      const file = this.options.i18nOutFile || null;\n      const format = this.options.i18nOutFormat || null;\n      const bundle = this.compiler.emitMessageBundle(this.analyzedModules, locale);\n      i18nExtract(format, file, this.host, this.options, bundle);\n    }\n    if ((emitFlags & (EmitFlags.JS | EmitFlags.DTS | EmitFlags.Metadata | EmitFlags.Codegen)) ===\n        0) {\n      return {emitSkipped: true, diagnostics: [], emittedFiles: []};\n    }\n    let {genFiles, genDiags} = this.generateFilesForEmit(emitFlags);\n    if (genDiags.length) {\n      return {\n        diagnostics: genDiags,\n        emitSkipped: true,\n        emittedFiles: [],\n      };\n    }\n    this.emittedGeneratedFiles = genFiles;\n    const outSrcMapping: Array<{sourceFile: ts.SourceFile, outFileName: string}> = [];\n    const genFileByFileName = new Map<string, GeneratedFile>();\n    genFiles.forEach(genFile => genFileByFileName.set(genFile.genFileUrl, genFile));\n    this.emittedLibrarySummaries = [];\n    this._transformTsDiagnostics = [];\n    const emittedSourceFiles = [] as ts.SourceFile[];\n    const writeTsFile: ts.WriteFileCallback =\n        (outFileName, outData, writeByteOrderMark, onError?, sourceFiles?) => {\n          const sourceFile = sourceFiles && sourceFiles.length == 1 ? sourceFiles[0] : null;\n          let genFile: GeneratedFile|undefined;\n          if (sourceFile) {\n            outSrcMapping.push({outFileName: outFileName, sourceFile});\n            genFile = genFileByFileName.get(sourceFile.fileName);\n            if (!sourceFile.isDeclarationFile && !GENERATED_FILES.test(sourceFile.fileName)) {\n              // Note: sourceFile is the transformed sourcefile, not the original one!\n              const originalFile = this.tsProgram.getSourceFile(sourceFile.fileName);\n              if (originalFile) {\n                emittedSourceFiles.push(originalFile);\n              }\n            }\n          }\n          this.writeFile(outFileName, outData, writeByteOrderMark, onError, genFile, sourceFiles);\n        };\n\n    const modules = this._analyzedInjectables &&\n        this.compiler.emitAllPartialModules2(this._analyzedInjectables);\n\n    const tsCustomTransformers =\n        this.calculateTransforms(genFileByFileName, modules, customTransformers);\n    const emitOnlyDtsFiles = (emitFlags & (EmitFlags.DTS | EmitFlags.JS)) == EmitFlags.DTS;\n    // Restore the original references before we emit so TypeScript doesn't emit\n    // a reference to the .d.ts file.\n    const augmentedReferences = new Map<ts.SourceFile, ReadonlyArray<ts.FileReference>>();\n    for (const sourceFile of this.tsProgram.getSourceFiles()) {\n      const originalReferences = getOriginalReferences(sourceFile);\n      if (originalReferences) {\n        augmentedReferences.set(sourceFile, sourceFile.referencedFiles);\n        sourceFile.referencedFiles = originalReferences;\n      }\n    }\n    const genTsFiles: GeneratedFile[] = [];\n    const genJsonFiles: GeneratedFile[] = [];\n    genFiles.forEach(gf => {\n      if (gf.stmts) {\n        genTsFiles.push(gf);\n      }\n      if (gf.source) {\n        genJsonFiles.push(gf);\n      }\n    });\n    let emitResult: ts.EmitResult;\n    let emittedUserTsCount: number;\n    try {\n      const sourceFilesToEmit = this.getSourceFilesForEmit();\n      if (sourceFilesToEmit &&\n          (sourceFilesToEmit.length + genTsFiles.length) < MAX_FILE_COUNT_FOR_SINGLE_FILE_EMIT) {\n        const fileNamesToEmit =\n            [...sourceFilesToEmit.map(sf => sf.fileName), ...genTsFiles.map(gf => gf.genFileUrl)];\n        emitResult = mergeEmitResultsCallback(\n            fileNamesToEmit.map((fileName) => emitResult = emitCallback({\n                                  program: this.tsProgram,\n                                  host: this.host,\n                                  options: this.options,\n                                  writeFile: writeTsFile,\n                                  emitOnlyDtsFiles,\n                                  customTransformers: tsCustomTransformers,\n                                  targetSourceFile: this.tsProgram.getSourceFile(fileName),\n                                })));\n        emittedUserTsCount = sourceFilesToEmit.length;\n      } else {\n        emitResult = emitCallback({\n          program: this.tsProgram,\n          host: this.host,\n          options: this.options,\n          writeFile: writeTsFile,\n          emitOnlyDtsFiles,\n          customTransformers: tsCustomTransformers\n        });\n        emittedUserTsCount = this.tsProgram.getSourceFiles().length - genTsFiles.length;\n      }\n    } finally {\n      // Restore the references back to the augmented value to ensure that the\n      // checks that TypeScript makes for project structure reuse will succeed.\n      for (const [sourceFile, references] of Array.from(augmentedReferences)) {\n        // TODO(chuckj): Remove any cast after updating build to 2.6\n        (sourceFile as any).referencedFiles = references;\n      }\n    }\n    this.emittedSourceFiles = emittedSourceFiles;\n\n    // Match behavior of tsc: only produce emit diagnostics if it would block\n    // emit. If noEmitOnError is false, the emit will happen in spite of any\n    // errors, so we should not report them.\n    if (emitResult && this.options.noEmitOnError === true) {\n      // translate the diagnostics in the emitResult as well.\n      const translatedEmitDiags = translateDiagnostics(this.hostAdapter, emitResult.diagnostics);\n      emitResult.diagnostics = translatedEmitDiags.ts.concat(\n          this.structuralDiagnostics.concat(translatedEmitDiags.ng).map(ngToTsDiagnostic));\n    }\n\n    if (emitResult && !outSrcMapping.length) {\n      // if no files were emitted by TypeScript, also don't emit .json files\n      emitResult.diagnostics =\n          emitResult.diagnostics.concat([createMessageDiagnostic(`Emitted no files.`)]);\n      return emitResult;\n    }\n\n    let sampleSrcFileName: string|undefined;\n    let sampleOutFileName: string|undefined;\n    if (outSrcMapping.length) {\n      sampleSrcFileName = outSrcMapping[0].sourceFile.fileName;\n      sampleOutFileName = outSrcMapping[0].outFileName;\n    }\n    const srcToOutPath =\n        createSrcToOutPathMapper(this.options.outDir, sampleSrcFileName, sampleOutFileName);\n    if (emitFlags & EmitFlags.Codegen) {\n      genJsonFiles.forEach(gf => {\n        const outFileName = srcToOutPath(gf.genFileUrl);\n        this.writeFile(outFileName, gf.source!, false, undefined, gf);\n      });\n    }\n    let metadataJsonCount = 0;\n    if (emitFlags & EmitFlags.Metadata) {\n      this.tsProgram.getSourceFiles().forEach(sf => {\n        if (!sf.isDeclarationFile && !GENERATED_FILES.test(sf.fileName)) {\n          metadataJsonCount++;\n          const metadata = this.metadataCache.getMetadata(sf);\n          if (metadata) {\n            const metadataText = JSON.stringify([metadata]);\n            const outFileName = srcToOutPath(sf.fileName.replace(/\\.tsx?$/, '.metadata.json'));\n            this.writeFile(outFileName, metadataText, false, undefined, undefined, [sf]);\n          }\n        }\n      });\n    }\n    const emitEnd = Date.now();\n    if (emitResult && this.options.diagnostics) {\n      emitResult.diagnostics = emitResult.diagnostics.concat([createMessageDiagnostic([\n        `Emitted in ${emitEnd - emitStart}ms`,\n        `- ${emittedUserTsCount} user ts files`,\n        `- ${genTsFiles.length} generated ts files`,\n        `- ${genJsonFiles.length + metadataJsonCount} generated json files`,\n      ].join('\\n'))]);\n    }\n\n    return emitResult;\n  }\n\n  // Private members\n  private get compiler(): AotCompiler {\n    if (!this._compiler) {\n      this._createCompiler();\n    }\n    return this._compiler!;\n  }\n\n  private get hostAdapter(): TsCompilerAotCompilerTypeCheckHostAdapter {\n    if (!this._hostAdapter) {\n      this._createCompiler();\n    }\n    return this._hostAdapter!;\n  }\n\n  private get analyzedModules(): NgAnalyzedModules {\n    if (!this._analyzedModules) {\n      this.initSync();\n    }\n    return this._analyzedModules!;\n  }\n\n  private get structuralDiagnostics(): ReadonlyArray<Diagnostic> {\n    let diagnostics = this._structuralDiagnostics;\n    if (!diagnostics) {\n      this.initSync();\n      diagnostics = (this._structuralDiagnostics = this._structuralDiagnostics || []);\n    }\n    return diagnostics;\n  }\n\n  private get tsProgram(): ts.Program {\n    if (!this._tsProgram) {\n      this.initSync();\n    }\n    return this._tsProgram!;\n  }\n\n  /** Whether the program is compiling the Angular core package. */\n  private get isCompilingAngularCore(): boolean {\n    if (this._isCompilingAngularCore !== null) {\n      return this._isCompilingAngularCore;\n    }\n    return this._isCompilingAngularCore = isAngularCorePackage(this.tsProgram);\n  }\n  private _isCompilingAngularCore: boolean|null = null;\n\n  private calculateTransforms(\n      genFiles: Map<string, GeneratedFile>|undefined, partialModules: PartialModule[]|undefined,\n      customTransformers?: CustomTransformers): ts.CustomTransformers {\n    const beforeTs: Array<ts.TransformerFactory<ts.SourceFile>> = [];\n    const metadataTransforms: MetadataTransformer[] = [];\n    const flatModuleMetadataTransforms: MetadataTransformer[] = [];\n    const annotateForClosureCompiler = this.options.annotateForClosureCompiler || false;\n\n    if (this.options.enableResourceInlining) {\n      beforeTs.push(getInlineResourcesTransformFactory(this.tsProgram, this.hostAdapter));\n      const transformer = new InlineResourcesMetadataTransformer(this.hostAdapter);\n      metadataTransforms.push(transformer);\n      flatModuleMetadataTransforms.push(transformer);\n    }\n\n    if (!this.options.disableExpressionLowering) {\n      beforeTs.push(\n          getExpressionLoweringTransformFactory(this.loweringMetadataTransform, this.tsProgram));\n      metadataTransforms.push(this.loweringMetadataTransform);\n    }\n    if (genFiles) {\n      beforeTs.push(getAngularEmitterTransformFactory(\n          genFiles, this.getTsProgram(), annotateForClosureCompiler));\n    }\n    if (partialModules) {\n      beforeTs.push(getAngularClassTransformerFactory(partialModules, annotateForClosureCompiler));\n\n      // If we have partial modules, the cached metadata might be incorrect as it doesn't reflect\n      // the partial module transforms.\n      const transformer = new PartialModuleMetadataTransformer(partialModules);\n      metadataTransforms.push(transformer);\n      flatModuleMetadataTransforms.push(transformer);\n    }\n\n    if (customTransformers && customTransformers.beforeTs) {\n      beforeTs.push(...customTransformers.beforeTs);\n    }\n\n    // If decorators should be converted to static fields (enabled by default), we set up\n    // the decorator downlevel transform. Note that we set it up as last transform as that\n    // allows custom transformers to strip Angular decorators without having to deal with\n    // identifying static properties. e.g. it's more difficult handling `<..>.decorators`\n    // or `<..>.ctorParameters` compared to the `ts.Decorator` AST nodes.\n    if (this.options.annotationsAs !== 'decorators') {\n      const typeChecker = this.getTsProgram().getTypeChecker();\n      const reflectionHost = new TypeScriptReflectionHost(typeChecker);\n      // Similarly to how we handled tsickle decorator downleveling in the past, we just\n      // ignore diagnostics that have been collected by the transformer. These are\n      // non-significant failures that shouldn't prevent apps from compiling.\n      beforeTs.push(getDownlevelDecoratorsTransform(\n          typeChecker, reflectionHost, [], this.isCompilingAngularCore, annotateForClosureCompiler,\n          /* skipClassDecorators */ false));\n    }\n\n    if (metadataTransforms.length > 0) {\n      this.metadataCache = this.createMetadataCache(metadataTransforms);\n    }\n    if (flatModuleMetadataTransforms.length > 0) {\n      this.flatModuleMetadataCache = this.createMetadataCache(flatModuleMetadataTransforms);\n    }\n    const afterTs = customTransformers ? customTransformers.afterTs : undefined;\n    return {before: beforeTs, after: afterTs};\n  }\n\n  private initSync() {\n    if (this._analyzedModules) {\n      return;\n    }\n    try {\n      const {tmpProgram, sourceFiles, tsFiles, rootNames} = this._createProgramWithBasicStubs();\n      const {analyzedModules, analyzedInjectables} =\n          this.compiler.loadFilesSync(sourceFiles, tsFiles);\n      this._updateProgramWithTypeCheckStubs(\n          tmpProgram, analyzedModules, analyzedInjectables, rootNames);\n    } catch (e) {\n      this._createProgramOnError(e);\n    }\n  }\n\n  private _createCompiler() {\n    const codegen: CodeGenerator = {\n      generateFile: (genFileName, baseFileName) =>\n          this._compiler.emitBasicStub(genFileName, baseFileName),\n      findGeneratedFileNames: (fileName) => this._compiler.findGeneratedFileNames(fileName),\n    };\n\n    this._hostAdapter = new TsCompilerAotCompilerTypeCheckHostAdapter(\n        this.rootNames, this.options, this.host, this.metadataCache, codegen,\n        this.oldProgramLibrarySummaries);\n    const aotOptions = getAotCompilerOptions(this.options);\n    const errorCollector = (this.options.collectAllErrors || this.options.fullTemplateTypeCheck) ?\n        (err: any) => this._addStructuralDiagnostics(err) :\n        undefined;\n    this._compiler = createAotCompiler(this._hostAdapter, aotOptions, errorCollector).compiler;\n  }\n\n  private _createProgramWithBasicStubs(): {\n    tmpProgram: ts.Program,\n    rootNames: string[],\n    sourceFiles: string[],\n    tsFiles: string[],\n  } {\n    if (this._analyzedModules) {\n      throw new Error(`Internal Error: already initialized!`);\n    }\n    // Note: This is important to not produce a memory leak!\n    const oldTsProgram = this.oldTsProgram;\n    this.oldTsProgram = undefined;\n\n    const codegen: CodeGenerator = {\n      generateFile: (genFileName, baseFileName) =>\n          this.compiler.emitBasicStub(genFileName, baseFileName),\n      findGeneratedFileNames: (fileName) => this.compiler.findGeneratedFileNames(fileName),\n    };\n\n\n    let rootNames = [...this.rootNames];\n    if (this.options.generateCodeForLibraries !== false) {\n      // if we should generateCodeForLibraries, never include\n      // generated files in the program as otherwise we will\n      // overwrite them and typescript will report the error\n      // TS5055: Cannot write file ... because it would overwrite input file.\n      rootNames = rootNames.filter(fn => !GENERATED_FILES.test(fn));\n    }\n    if (this.options.noResolve) {\n      this.rootNames.forEach(rootName => {\n        if (this.hostAdapter.shouldGenerateFilesFor(rootName)) {\n          rootNames.push(...this.compiler.findGeneratedFileNames(rootName));\n        }\n      });\n    }\n\n    const tmpProgram = ts.createProgram(rootNames, this.options, this.hostAdapter, oldTsProgram);\n    if (tempProgramHandlerForTest !== null) {\n      tempProgramHandlerForTest(tmpProgram);\n    }\n    const sourceFiles: string[] = [];\n    const tsFiles: string[] = [];\n    tmpProgram.getSourceFiles().forEach(sf => {\n      if (this.hostAdapter.isSourceFile(sf.fileName)) {\n        sourceFiles.push(sf.fileName);\n      }\n      if (TS.test(sf.fileName) && !DTS.test(sf.fileName)) {\n        tsFiles.push(sf.fileName);\n      }\n    });\n    return {tmpProgram, sourceFiles, tsFiles, rootNames};\n  }\n\n  private _updateProgramWithTypeCheckStubs(\n      tmpProgram: ts.Program, analyzedModules: NgAnalyzedModules,\n      analyzedInjectables: NgAnalyzedFileWithInjectables[], rootNames: string[]) {\n    this._analyzedModules = analyzedModules;\n    this._analyzedInjectables = analyzedInjectables;\n    tmpProgram.getSourceFiles().forEach(sf => {\n      if (sf.fileName.endsWith('.ngfactory.ts')) {\n        const {generate, baseFileName} = this.hostAdapter.shouldGenerateFile(sf.fileName);\n        if (generate) {\n          // Note: ! is ok as hostAdapter.shouldGenerateFile will always return a baseFileName\n          // for .ngfactory.ts files.\n          const genFile = this.compiler.emitTypeCheckStub(sf.fileName, baseFileName!);\n          if (genFile) {\n            this.hostAdapter.updateGeneratedFile(genFile);\n          }\n        }\n      }\n    });\n    this._tsProgram = ts.createProgram(rootNames, this.options, this.hostAdapter, tmpProgram);\n    // Note: the new ts program should be completely reusable by TypeScript as:\n    // - we cache all the files in the hostAdapter\n    // - new new stubs use the exactly same imports/exports as the old once (we assert that in\n    // hostAdapter.updateGeneratedFile).\n    if (tsStructureIsReused(this._tsProgram) !== StructureIsReused.Completely) {\n      throw new Error(`Internal Error: The structure of the program changed during codegen.`);\n    }\n  }\n\n  private _createProgramOnError(e: any) {\n    // Still fill the analyzedModules and the tsProgram\n    // so that we don't cause other errors for users who e.g. want to emit the ngProgram.\n    this._analyzedModules = emptyModules;\n    this.oldTsProgram = undefined;\n    this._hostAdapter.isSourceFile = () => false;\n    this._tsProgram = ts.createProgram(this.rootNames, this.options, this.hostAdapter);\n    if (isSyntaxError(e)) {\n      this._addStructuralDiagnostics(e);\n      return;\n    }\n    throw e;\n  }\n\n  private _addStructuralDiagnostics(error: Error) {\n    const diagnostics = this._structuralDiagnostics || (this._structuralDiagnostics = []);\n    if (isSyntaxError(error)) {\n      diagnostics.push(...syntaxErrorToDiagnostics(error, this.tsProgram));\n    } else {\n      diagnostics.push({\n        messageText: error.toString(),\n        category: ts.DiagnosticCategory.Error,\n        source: SOURCE,\n        code: DEFAULT_ERROR_CODE\n      });\n    }\n  }\n\n  // Note: this returns a ts.Diagnostic so that we\n  // can return errors in a ts.EmitResult\n  private generateFilesForEmit(emitFlags: EmitFlags):\n      {genFiles: GeneratedFile[], genDiags: ts.Diagnostic[]} {\n    try {\n      if (!(emitFlags & EmitFlags.Codegen)) {\n        return {genFiles: [], genDiags: []};\n      }\n      // TODO(tbosch): allow generating files that are not in the rootDir\n      // See https://github.com/angular/angular/issues/19337\n      let genFiles = this.compiler.emitAllImpls(this.analyzedModules)\n                         .filter(genFile => isInRootDir(genFile.genFileUrl, this.options));\n      if (this.oldProgramEmittedGeneratedFiles) {\n        const oldProgramEmittedGeneratedFiles = this.oldProgramEmittedGeneratedFiles;\n        genFiles = genFiles.filter(genFile => {\n          const oldGenFile = oldProgramEmittedGeneratedFiles.get(genFile.genFileUrl);\n          return !oldGenFile || !genFile.isEquivalent(oldGenFile);\n        });\n      }\n      return {genFiles, genDiags: []};\n    } catch (e) {\n      // TODO(tbosch): check whether we can actually have syntax errors here,\n      // as we already parsed the metadata and templates before to create the type check block.\n      if (isSyntaxError(e)) {\n        const genDiags: ts.Diagnostic[] = [{\n          file: undefined,\n          start: undefined,\n          length: undefined,\n          messageText: e.message,\n          category: ts.DiagnosticCategory.Error,\n          source: SOURCE,\n          code: DEFAULT_ERROR_CODE\n        }];\n        return {genFiles: [], genDiags};\n      }\n      throw e;\n    }\n  }\n\n  /**\n   * Returns undefined if all files should be emitted.\n   */\n  private getSourceFilesForEmit(): ts.SourceFile[]|undefined {\n    // TODO(tbosch): if one of the files contains a `const enum`\n    // always emit all files -> return undefined!\n    let sourceFilesToEmit = this.tsProgram.getSourceFiles().filter(sf => {\n      return !sf.isDeclarationFile && !GENERATED_FILES.test(sf.fileName);\n    });\n    if (this.oldProgramEmittedSourceFiles) {\n      sourceFilesToEmit = sourceFilesToEmit.filter(sf => {\n        const oldFile = this.oldProgramEmittedSourceFiles!.get(sf.fileName);\n        return sf !== oldFile;\n      });\n    }\n    return sourceFilesToEmit;\n  }\n\n  private writeFile(\n      outFileName: string, outData: string, writeByteOrderMark: boolean,\n      onError?: (message: string) => void, genFile?: GeneratedFile,\n      sourceFiles?: ReadonlyArray<ts.SourceFile>) {\n    // collect emittedLibrarySummaries\n    let baseFile: ts.SourceFile|undefined;\n    if (genFile) {\n      baseFile = this.tsProgram.getSourceFile(genFile.srcFileUrl);\n      if (baseFile) {\n        if (!this.emittedLibrarySummaries) {\n          this.emittedLibrarySummaries = [];\n        }\n        if (genFile.genFileUrl.endsWith('.ngsummary.json') && baseFile.fileName.endsWith('.d.ts')) {\n          this.emittedLibrarySummaries.push({\n            fileName: baseFile.fileName,\n            text: baseFile.text,\n            sourceFile: baseFile,\n          });\n          this.emittedLibrarySummaries.push({fileName: genFile.genFileUrl, text: outData});\n          if (!this.options.declaration) {\n            // If we don't emit declarations, still record an empty .ngfactory.d.ts file,\n            // as we might need it later on for resolving module names from summaries.\n            const ngFactoryDts =\n                genFile.genFileUrl.substring(0, genFile.genFileUrl.length - 15) + '.ngfactory.d.ts';\n            this.emittedLibrarySummaries.push({fileName: ngFactoryDts, text: ''});\n          }\n        } else if (outFileName.endsWith('.d.ts') && baseFile.fileName.endsWith('.d.ts')) {\n          const dtsSourceFilePath = genFile.genFileUrl.replace(/\\.ts$/, '.d.ts');\n          // Note: Don't use sourceFiles here as the created .d.ts has a path in the outDir,\n          // but we need one that is next to the .ts file\n          this.emittedLibrarySummaries.push({fileName: dtsSourceFilePath, text: outData});\n        }\n      }\n    }\n    // Filter out generated files for which we didn't generate code.\n    // This can happen as the stub calculation is not completely exact.\n    // Note: sourceFile refers to the .ngfactory.ts / .ngsummary.ts file\n    // node_emitter_transform already set the file contents to be empty,\n    //  so this code only needs to skip the file if !allowEmptyCodegenFiles.\n    const isGenerated = GENERATED_FILES.test(outFileName);\n    if (isGenerated && !this.options.allowEmptyCodegenFiles &&\n        (!genFile || !genFile.stmts || genFile.stmts.length === 0)) {\n      return;\n    }\n    if (baseFile) {\n      sourceFiles = sourceFiles ? [...sourceFiles, baseFile] : [baseFile];\n    }\n    // TODO: remove any when TS 2.4 support is removed.\n    this.host.writeFile(outFileName, outData, writeByteOrderMark, onError, sourceFiles as any);\n  }\n}\n\n\nexport function createProgram({rootNames, options, host, oldProgram}: {\n  rootNames: ReadonlyArray<string>,\n  options: CompilerOptions,\n  host: CompilerHost,\n  oldProgram?: Program\n}): Program {\n  if (options.enableIvy !== false) {\n    return new NgtscProgram(rootNames, options, host, oldProgram as NgtscProgram | undefined);\n  } else {\n    return new AngularCompilerProgram(rootNames, options, host, oldProgram);\n  }\n}\n\n// Compute the AotCompiler options\nfunction getAotCompilerOptions(options: CompilerOptions): AotCompilerOptions {\n  let missingTranslation = core.MissingTranslationStrategy.Warning;\n\n  switch (options.i18nInMissingTranslations) {\n    case 'ignore':\n      missingTranslation = core.MissingTranslationStrategy.Ignore;\n      break;\n    case 'error':\n      missingTranslation = core.MissingTranslationStrategy.Error;\n      break;\n  }\n\n  let translations: string = '';\n\n  if (options.i18nInFile) {\n    if (!options.i18nInLocale) {\n      throw new Error(`The translation file (${options.i18nInFile}) locale must be provided.`);\n    }\n    translations = fs.readFileSync(options.i18nInFile, 'utf8');\n  } else {\n    // No translations are provided, ignore any errors\n    // We still go through i18n to remove i18n attributes\n    missingTranslation = core.MissingTranslationStrategy.Ignore;\n  }\n\n  return {\n    locale: options.i18nInLocale,\n    i18nFormat: options.i18nInFormat || options.i18nOutFormat,\n    i18nUseExternalIds: options.i18nUseExternalIds,\n    translations,\n    missingTranslation,\n    enableSummariesForJit: options.enableSummariesForJit,\n    preserveWhitespaces: options.preserveWhitespaces,\n    fullTemplateTypeCheck: options.fullTemplateTypeCheck,\n    allowEmptyCodegenFiles: options.allowEmptyCodegenFiles,\n    enableIvy: options.enableIvy,\n    createExternalSymbolFactoryReexports: options.createExternalSymbolFactoryReexports,\n  };\n}\n\nfunction getNgOptionDiagnostics(options: CompilerOptions): ReadonlyArray<Diagnostic> {\n  if (options.annotationsAs) {\n    switch (options.annotationsAs) {\n      case 'decorators':\n      case 'static fields':\n        break;\n      default:\n        return [{\n          messageText:\n              'Angular compiler options \"annotationsAs\" only supports \"static fields\" and \"decorators\"',\n          category: ts.DiagnosticCategory.Error,\n          source: SOURCE,\n          code: DEFAULT_ERROR_CODE\n        }];\n    }\n  }\n  return [];\n}\n\nfunction normalizeSeparators(path: string): string {\n  return path.replace(/\\\\/g, '/');\n}\n\n/**\n * Returns a function that can adjust a path from source path to out path,\n * based on an existing mapping from source to out path.\n *\n * TODO(tbosch): talk to the TypeScript team to expose their logic for calculating the `rootDir`\n * if none was specified.\n *\n * Note: This function works on normalized paths from typescript but should always return\n * POSIX normalized paths for output paths.\n */\nexport function createSrcToOutPathMapper(\n    outDir: string|undefined, sampleSrcFileName: string|undefined,\n    sampleOutFileName: string|undefined, host: {\n      dirname: typeof path.dirname,\n      resolve: typeof path.resolve,\n      relative: typeof path.relative\n    } = path): (srcFileName: string) => string {\n  if (outDir) {\n    let path: {} = {};  // Ensure we error if we use `path` instead of `host`.\n    if (sampleSrcFileName == null || sampleOutFileName == null) {\n      throw new Error(`Can't calculate the rootDir without a sample srcFileName / outFileName. `);\n    }\n    const srcFileDir = normalizeSeparators(host.dirname(sampleSrcFileName));\n    const outFileDir = normalizeSeparators(host.dirname(sampleOutFileName));\n    if (srcFileDir === outFileDir) {\n      return (srcFileName) => srcFileName;\n    }\n    // calculate the common suffix, stopping\n    // at `outDir`.\n    const srcDirParts = srcFileDir.split('/');\n    const outDirParts = normalizeSeparators(host.relative(outDir, outFileDir)).split('/');\n    let i = 0;\n    while (i < Math.min(srcDirParts.length, outDirParts.length) &&\n           srcDirParts[srcDirParts.length - 1 - i] === outDirParts[outDirParts.length - 1 - i])\n      i++;\n    const rootDir = srcDirParts.slice(0, srcDirParts.length - i).join('/');\n    return (srcFileName) => {\n      // Note: Before we return the mapped output path, we need to normalize the path delimiters\n      // because the output path is usually passed to TypeScript which sometimes only expects\n      // posix normalized paths (e.g. if a custom compiler host is used)\n      return normalizeSeparators(host.resolve(outDir, host.relative(rootDir, srcFileName)));\n    };\n  } else {\n    // Note: Before we return the output path, we need to normalize the path delimiters because\n    // the output path is usually passed to TypeScript which only passes around posix\n    // normalized paths (e.g. if a custom compiler host is used)\n    return (srcFileName) => normalizeSeparators(srcFileName);\n  }\n}\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  return {diagnostics, emitSkipped, emittedFiles};\n}\n\nfunction diagnosticSourceOfSpan(span: ParseSourceSpan): ts.SourceFile {\n  // For diagnostics, TypeScript only uses the fileName and text properties.\n  // The redundant '()' are here is to avoid having clang-format breaking the line incorrectly.\n  return ({fileName: span.start.file.url, text: span.start.file.content} as any);\n}\n\nfunction diagnosticSourceOfFileName(fileName: string, program: ts.Program): ts.SourceFile {\n  const sourceFile = program.getSourceFile(fileName);\n  if (sourceFile) return sourceFile;\n\n  // If we are reporting diagnostics for a source file that is not in the project then we need\n  // to fake a source file so the diagnostic formatting routines can emit the file name.\n  // The redundant '()' are here is to avoid having clang-format breaking the line incorrectly.\n  return ({fileName, text: ''} as any);\n}\n\n\nfunction diagnosticChainFromFormattedDiagnosticChain(chain: FormattedMessageChain):\n    DiagnosticMessageChain {\n  return {\n    messageText: chain.message,\n    next: chain.next && chain.next.map(diagnosticChainFromFormattedDiagnosticChain),\n    position: chain.position\n  };\n}\n\nfunction syntaxErrorToDiagnostics(error: Error, program: ts.Program): Diagnostic[] {\n  const parserErrors = getParseErrors(error);\n  if (parserErrors && parserErrors.length) {\n    return parserErrors.map<Diagnostic>(e => ({\n                                          messageText: e.contextualMessage(),\n                                          file: diagnosticSourceOfSpan(e.span),\n                                          start: e.span.start.offset,\n                                          length: e.span.end.offset - e.span.start.offset,\n                                          category: ts.DiagnosticCategory.Error,\n                                          source: SOURCE,\n                                          code: DEFAULT_ERROR_CODE\n                                        }));\n  } else if (isFormattedError(error)) {\n    return [{\n      messageText: error.message,\n      chain: error.chain && diagnosticChainFromFormattedDiagnosticChain(error.chain),\n      category: ts.DiagnosticCategory.Error,\n      source: SOURCE,\n      code: DEFAULT_ERROR_CODE,\n      position: error.position\n    }];\n  }\n\n  const ngModuleErrorData = getMissingNgModuleMetadataErrorData(error);\n  if (ngModuleErrorData !== null) {\n    // This error represents the import or export of an `NgModule` that didn't have valid metadata.\n    // This _might_ happen because the NgModule in question is an Ivy-compiled library, and we want\n    // to show a more useful error if that's the case.\n    const ngModuleClass =\n        getDtsClass(program, ngModuleErrorData.fileName, ngModuleErrorData.className);\n    if (ngModuleClass !== null && isIvyNgModule(ngModuleClass)) {\n      return [{\n        messageText: `The NgModule '${ngModuleErrorData.className}' in '${\n            ngModuleErrorData\n                .fileName}' is imported by this compilation, but appears to be part of a library compiled for Angular Ivy. This may occur because:\n\n  1) the library was processed with 'ngcc'. Removing and reinstalling node_modules may fix this problem.\n\n  2) the library was published for Angular Ivy and v12+ applications only. Check its peer dependencies carefully and ensure that you're using a compatible version of Angular.\n\nSee https://angular.io/errors/NG6999 for more information.\n`,\n        category: ts.DiagnosticCategory.Error,\n        code: DEFAULT_ERROR_CODE,\n        source: SOURCE,\n      }];\n    }\n  }\n\n  // Produce a Diagnostic anyway since we know for sure `error` is a SyntaxError\n  return [{\n    messageText: error.message,\n    category: ts.DiagnosticCategory.Error,\n    code: DEFAULT_ERROR_CODE,\n    source: SOURCE,\n  }];\n}\n\nfunction getDtsClass(program: ts.Program, fileName: string, className: string): ts.ClassDeclaration|\n    null {\n  const sf = program.getSourceFile(fileName);\n  if (sf === undefined || !sf.isDeclarationFile) {\n    return null;\n  }\n  for (const stmt of sf.statements) {\n    if (!ts.isClassDeclaration(stmt)) {\n      continue;\n    }\n    if (stmt.name === undefined || stmt.name.text !== className) {\n      continue;\n    }\n\n    return stmt;\n  }\n\n  // No classes found that matched the given name.\n  return null;\n}\n\nfunction isIvyNgModule(clazz: ts.ClassDeclaration): boolean {\n  for (const member of clazz.members) {\n    if (!ts.isPropertyDeclaration(member)) {\n      continue;\n    }\n    if (ts.isIdentifier(member.name) && member.name.text === 'ɵmod') {\n      return true;\n    }\n  }\n\n  // No Ivy 'ɵmod' property found.\n  return false;\n}\n"]} |
---|