source: trip-planner-front/node_modules/@angular/compiler-cli/src/transformers/compiler_host.js@ 6a3a178

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

initial commit

  • Property mode set to 100644
File size: 98.1 KB
Line 
1/**
2 * @license
3 * Copyright Google LLC All Rights Reserved.
4 *
5 * Use of this source code is governed by an MIT-style license that can be
6 * found in the LICENSE file at https://angular.io/license
7 */
8(function (factory) {
9 if (typeof module === "object" && typeof module.exports === "object") {
10 var v = factory(require, exports);
11 if (v !== undefined) module.exports = v;
12 }
13 else if (typeof define === "function" && define.amd) {
14 define("@angular/compiler-cli/src/transformers/compiler_host", ["require", "exports", "tslib", "@angular/compiler", "path", "typescript", "@angular/compiler-cli/src/ngtsc/file_system", "@angular/compiler-cli/src/transformers/metadata_reader", "@angular/compiler-cli/src/transformers/util"], factory);
15 }
16})(function (require, exports) {
17 "use strict";
18 Object.defineProperty(exports, "__esModule", { value: true });
19 exports.getOriginalReferences = exports.TsCompilerAotCompilerTypeCheckHostAdapter = exports.createCompilerHost = exports.setWrapHostForTest = void 0;
20 var tslib_1 = require("tslib");
21 var compiler_1 = require("@angular/compiler");
22 var path = require("path");
23 var ts = require("typescript");
24 var file_system_1 = require("@angular/compiler-cli/src/ngtsc/file_system");
25 var metadata_reader_1 = require("@angular/compiler-cli/src/transformers/metadata_reader");
26 var util_1 = require("@angular/compiler-cli/src/transformers/util");
27 var NODE_MODULES_PACKAGE_NAME = /node_modules\/((\w|-|\.)+|(@(\w|-|\.)+\/(\w|-|\.)+))/;
28 var EXT = /(\.ts|\.d\.ts|\.js|\.jsx|\.tsx)$/;
29 var CSS_PREPROCESSOR_EXT = /(\.scss|\.sass|\.less|\.styl)$/;
30 var wrapHostForTest = null;
31 function setWrapHostForTest(wrapFn) {
32 wrapHostForTest = wrapFn;
33 }
34 exports.setWrapHostForTest = setWrapHostForTest;
35 function createCompilerHost(_a) {
36 var options = _a.options, _b = _a.tsHost, tsHost = _b === void 0 ? ts.createCompilerHost(options, true) : _b;
37 if (wrapHostForTest !== null) {
38 tsHost = wrapHostForTest(tsHost);
39 }
40 return tsHost;
41 }
42 exports.createCompilerHost = createCompilerHost;
43 function assert(condition) {
44 if (!condition) {
45 // TODO(chuckjaz): do the right thing
46 }
47 return condition;
48 }
49 /**
50 * Implements the following hosts based on an api.CompilerHost:
51 * - ts.CompilerHost to be consumed by a ts.Program
52 * - AotCompilerHost for @angular/compiler
53 * - TypeCheckHost for mapping ts errors to ng errors (via translateDiagnostics)
54 */
55 var TsCompilerAotCompilerTypeCheckHostAdapter = /** @class */ (function () {
56 function TsCompilerAotCompilerTypeCheckHostAdapter(rootFiles, options, context, metadataProvider, codeGenerator, librarySummaries) {
57 var _this = this;
58 if (librarySummaries === void 0) { librarySummaries = new Map(); }
59 this.rootFiles = rootFiles;
60 this.options = options;
61 this.context = context;
62 this.metadataProvider = metadataProvider;
63 this.codeGenerator = codeGenerator;
64 this.librarySummaries = librarySummaries;
65 this.metadataReaderCache = metadata_reader_1.createMetadataReaderCache();
66 this.fileNameToModuleNameCache = new Map();
67 this.flatModuleIndexCache = new Map();
68 this.flatModuleIndexNames = new Set();
69 this.flatModuleIndexRedirectNames = new Set();
70 this.originalSourceFiles = new Map();
71 this.originalFileExistsCache = new Map();
72 this.generatedSourceFiles = new Map();
73 this.generatedCodeFor = new Map();
74 this.emitter = new compiler_1.TypeScriptEmitter();
75 this.getDefaultLibFileName = function (options) {
76 return _this.context.getDefaultLibFileName(options);
77 };
78 this.getCurrentDirectory = function () { return _this.context.getCurrentDirectory(); };
79 this.getCanonicalFileName = function (fileName) { return _this.context.getCanonicalFileName(fileName); };
80 this.useCaseSensitiveFileNames = function () { return _this.context.useCaseSensitiveFileNames(); };
81 this.getNewLine = function () { return _this.context.getNewLine(); };
82 // Make sure we do not `host.realpath()` from TS as we do not want to resolve symlinks.
83 // https://github.com/Microsoft/TypeScript/issues/9552
84 this.realpath = function (p) { return p; };
85 this.writeFile = this.context.writeFile.bind(this.context);
86 this.moduleResolutionCache = ts.createModuleResolutionCache(this.context.getCurrentDirectory(), this.context.getCanonicalFileName.bind(this.context));
87 var basePath = this.options.basePath;
88 this.rootDirs =
89 (this.options.rootDirs || [this.options.basePath]).map(function (p) { return path.resolve(basePath, p); });
90 if (context.getDirectories) {
91 this.getDirectories = function (path) { return context.getDirectories(path); };
92 }
93 if (context.directoryExists) {
94 this.directoryExists = function (directoryName) { return context.directoryExists(directoryName); };
95 }
96 if (context.getCancellationToken) {
97 this.getCancellationToken = function () { return context.getCancellationToken(); };
98 }
99 if (context.getDefaultLibLocation) {
100 this.getDefaultLibLocation = function () { return context.getDefaultLibLocation(); };
101 }
102 if (context.resolveTypeReferenceDirectives) {
103 this.resolveTypeReferenceDirectives = function (names, containingFile) {
104 return context.resolveTypeReferenceDirectives(names, containingFile);
105 };
106 }
107 if (context.trace) {
108 this.trace = function (s) { return context.trace(s); };
109 }
110 if (context.fileNameToModuleName) {
111 this.fileNameToModuleName = context.fileNameToModuleName.bind(context);
112 }
113 // Note: don't copy over context.moduleNameToFileName as we first
114 // normalize undefined containingFile to a filled containingFile.
115 if (context.resourceNameToFileName) {
116 this.resourceNameToFileName = context.resourceNameToFileName.bind(context);
117 }
118 if (context.toSummaryFileName) {
119 this.toSummaryFileName = context.toSummaryFileName.bind(context);
120 }
121 if (context.fromSummaryFileName) {
122 this.fromSummaryFileName = context.fromSummaryFileName.bind(context);
123 }
124 this.metadataReaderHost = {
125 cacheMetadata: function () { return true; },
126 getSourceFileMetadata: function (filePath) {
127 var sf = _this.getOriginalSourceFile(filePath);
128 return sf ? _this.metadataProvider.getMetadata(sf) : undefined;
129 },
130 fileExists: function (filePath) { return _this.originalFileExists(filePath); },
131 readFile: function (filePath) { return assert(_this.context.readFile(filePath)); },
132 };
133 }
134 TsCompilerAotCompilerTypeCheckHostAdapter.prototype.resolveModuleName = function (moduleName, containingFile) {
135 var rm = ts.resolveModuleName(moduleName, containingFile.replace(/\\/g, '/'), this.options, this, this.moduleResolutionCache)
136 .resolvedModule;
137 if (rm && this.isSourceFile(rm.resolvedFileName) && util_1.DTS.test(rm.resolvedFileName)) {
138 // Case: generateCodeForLibraries = true and moduleName is
139 // a .d.ts file in a node_modules folder.
140 // Need to set isExternalLibraryImport to false so that generated files for that file
141 // are emitted.
142 rm.isExternalLibraryImport = false;
143 }
144 return rm;
145 };
146 // Note: We implement this method so that TypeScript and Angular share the same
147 // ts.ModuleResolutionCache
148 // and that we can tell ts.Program about our different opinion about
149 // ResolvedModule.isExternalLibraryImport
150 // (see our isSourceFile method).
151 TsCompilerAotCompilerTypeCheckHostAdapter.prototype.resolveModuleNames = function (moduleNames, containingFile) {
152 var _this = this;
153 // TODO(tbosch): this seems to be a typing error in TypeScript,
154 // as it contains assertions that the result contains the same number of entries
155 // as the given module names.
156 return moduleNames.map(function (moduleName) { return _this.resolveModuleName(moduleName, containingFile); });
157 };
158 TsCompilerAotCompilerTypeCheckHostAdapter.prototype.moduleNameToFileName = function (m, containingFile) {
159 if (!containingFile) {
160 if (m.indexOf('.') === 0) {
161 throw new Error('Resolution of relative paths requires a containing file.');
162 }
163 // Any containing file gives the same result for absolute imports
164 containingFile = this.rootFiles[0];
165 }
166 if (this.context.moduleNameToFileName) {
167 return this.context.moduleNameToFileName(m, containingFile);
168 }
169 var resolved = this.resolveModuleName(m, containingFile);
170 return resolved ? resolved.resolvedFileName : null;
171 };
172 /**
173 * We want a moduleId that will appear in import statements in the generated code
174 * which will be written to `containingFile`.
175 *
176 * Note that we also generate files for files in node_modules, as libraries
177 * only ship .metadata.json files but not the generated code.
178 *
179 * Logic:
180 * 1. if the importedFile and the containingFile are from the project sources
181 * or from the same node_modules package, use a relative path
182 * 2. if the importedFile is in a node_modules package,
183 * use a path that starts with the package name.
184 * 3. Error if the containingFile is in the node_modules package
185 * and the importedFile is in the project soures,
186 * as that is a violation of the principle that node_modules packages cannot
187 * import project sources.
188 */
189 TsCompilerAotCompilerTypeCheckHostAdapter.prototype.fileNameToModuleName = function (importedFile, containingFile) {
190 var cacheKey = importedFile + ":" + containingFile;
191 var moduleName = this.fileNameToModuleNameCache.get(cacheKey);
192 if (moduleName != null) {
193 return moduleName;
194 }
195 var originalImportedFile = importedFile;
196 if (this.options.traceResolution) {
197 console.error('fileNameToModuleName from containingFile', containingFile, 'to importedFile', importedFile);
198 }
199 // drop extension
200 importedFile = importedFile.replace(EXT, '');
201 var importedFilePackageName = getPackageName(importedFile);
202 var containingFilePackageName = getPackageName(containingFile);
203 if (importedFilePackageName === containingFilePackageName ||
204 util_1.GENERATED_FILES.test(originalImportedFile)) {
205 var rootedContainingFile = util_1.relativeToRootDirs(containingFile, this.rootDirs);
206 var rootedImportedFile = util_1.relativeToRootDirs(importedFile, this.rootDirs);
207 if (rootedContainingFile !== containingFile && rootedImportedFile !== importedFile) {
208 // if both files are contained in the `rootDirs`, then strip the rootDirs
209 containingFile = rootedContainingFile;
210 importedFile = rootedImportedFile;
211 }
212 moduleName = dotRelative(path.dirname(containingFile), importedFile);
213 }
214 else if (importedFilePackageName) {
215 moduleName = stripNodeModulesPrefix(importedFile);
216 if (originalImportedFile.endsWith('.d.ts')) {
217 // the moduleName for these typings could be shortented to the npm package name
218 // if the npm package typings matches the importedFile
219 try {
220 var modulePath = importedFile.substring(0, importedFile.length - moduleName.length) +
221 importedFilePackageName;
222 var packageJson = require(modulePath + '/package.json');
223 var packageTypings = file_system_1.join(modulePath, packageJson.typings);
224 if (packageTypings === originalImportedFile) {
225 moduleName = importedFilePackageName;
226 }
227 }
228 catch (_a) {
229 // the above require() will throw if there is no package.json file
230 // and this is safe to ignore and correct to keep the longer
231 // moduleName in this case
232 }
233 }
234 }
235 else {
236 throw new Error("Trying to import a source file from a node_modules package: import " + originalImportedFile + " from " + containingFile);
237 }
238 this.fileNameToModuleNameCache.set(cacheKey, moduleName);
239 return moduleName;
240 };
241 TsCompilerAotCompilerTypeCheckHostAdapter.prototype.resourceNameToFileName = function (resourceName, containingFile) {
242 // Note: we convert package paths into relative paths to be compatible with the the
243 // previous implementation of UrlResolver.
244 var firstChar = resourceName[0];
245 if (firstChar === '/') {
246 resourceName = resourceName.slice(1);
247 }
248 else if (firstChar !== '.') {
249 resourceName = "./" + resourceName;
250 }
251 var filePathWithNgResource = this.moduleNameToFileName(addNgResourceSuffix(resourceName), containingFile);
252 // If the user specified styleUrl pointing to *.scss, but the Sass compiler was run before
253 // Angular, then the resource may have been generated as *.css. Simply try the resolution again.
254 if (!filePathWithNgResource && CSS_PREPROCESSOR_EXT.test(resourceName)) {
255 var fallbackResourceName = resourceName.replace(CSS_PREPROCESSOR_EXT, '.css');
256 filePathWithNgResource =
257 this.moduleNameToFileName(addNgResourceSuffix(fallbackResourceName), containingFile);
258 }
259 var result = filePathWithNgResource ? stripNgResourceSuffix(filePathWithNgResource) : null;
260 // Used under Bazel to report more specific error with remediation advice
261 if (!result && this.context.reportMissingResource) {
262 this.context.reportMissingResource(resourceName);
263 }
264 return result;
265 };
266 TsCompilerAotCompilerTypeCheckHostAdapter.prototype.toSummaryFileName = function (fileName, referringSrcFileName) {
267 return this.fileNameToModuleName(fileName, referringSrcFileName);
268 };
269 TsCompilerAotCompilerTypeCheckHostAdapter.prototype.fromSummaryFileName = function (fileName, referringLibFileName) {
270 var resolved = this.moduleNameToFileName(fileName, referringLibFileName);
271 if (!resolved) {
272 throw new Error("Could not resolve " + fileName + " from " + referringLibFileName);
273 }
274 return resolved;
275 };
276 TsCompilerAotCompilerTypeCheckHostAdapter.prototype.parseSourceSpanOf = function (fileName, line, character) {
277 var data = this.generatedSourceFiles.get(fileName);
278 if (data && data.emitCtx) {
279 return data.emitCtx.spanOf(line, character);
280 }
281 return null;
282 };
283 TsCompilerAotCompilerTypeCheckHostAdapter.prototype.getOriginalSourceFile = function (filePath, languageVersion, onError) {
284 // Note: we need the explicit check via `has` as we also cache results
285 // that were null / undefined.
286 if (this.originalSourceFiles.has(filePath)) {
287 return this.originalSourceFiles.get(filePath);
288 }
289 if (!languageVersion) {
290 languageVersion = this.options.target || ts.ScriptTarget.Latest;
291 }
292 // Note: This can also return undefined,
293 // as the TS typings are not correct!
294 var sf = this.context.getSourceFile(filePath, languageVersion, onError) || null;
295 this.originalSourceFiles.set(filePath, sf);
296 return sf;
297 };
298 TsCompilerAotCompilerTypeCheckHostAdapter.prototype.updateGeneratedFile = function (genFile) {
299 if (!genFile.stmts) {
300 throw new Error("Invalid Argument: Expected a GenerateFile with statements. " + genFile.genFileUrl);
301 }
302 var oldGenFile = this.generatedSourceFiles.get(genFile.genFileUrl);
303 if (!oldGenFile) {
304 throw new Error("Illegal State: previous GeneratedFile not found for " + genFile.genFileUrl + ".");
305 }
306 var newRefs = genFileExternalReferences(genFile);
307 var oldRefs = oldGenFile.externalReferences;
308 var refsAreEqual = oldRefs.size === newRefs.size;
309 if (refsAreEqual) {
310 newRefs.forEach(function (r) { return refsAreEqual = refsAreEqual && oldRefs.has(r); });
311 }
312 if (!refsAreEqual) {
313 throw new Error("Illegal State: external references changed in " + genFile.genFileUrl + ".\nOld: " + Array.from(oldRefs) + ".\nNew: " + Array.from(newRefs));
314 }
315 return this.addGeneratedFile(genFile, newRefs);
316 };
317 TsCompilerAotCompilerTypeCheckHostAdapter.prototype.addGeneratedFile = function (genFile, externalReferences) {
318 if (!genFile.stmts) {
319 throw new Error("Invalid Argument: Expected a GenerateFile with statements. " + genFile.genFileUrl);
320 }
321 var _a = this.emitter.emitStatementsAndContext(genFile.genFileUrl, genFile.stmts, /* preamble */ '',
322 /* emitSourceMaps */ false), sourceText = _a.sourceText, context = _a.context;
323 var sf = ts.createSourceFile(genFile.genFileUrl, sourceText, this.options.target || ts.ScriptTarget.Latest);
324 if (this.options.module === ts.ModuleKind.AMD || this.options.module === ts.ModuleKind.UMD) {
325 if (this.context.amdModuleName) {
326 var moduleName = this.context.amdModuleName(sf);
327 if (moduleName)
328 sf.moduleName = moduleName;
329 }
330 else if (/node_modules/.test(genFile.genFileUrl)) {
331 // If we are generating an ngModule file under node_modules, we know the right module name
332 // We don't need the host to supply a function in this case.
333 sf.moduleName = stripNodeModulesPrefix(genFile.genFileUrl.replace(EXT, ''));
334 }
335 }
336 this.generatedSourceFiles.set(genFile.genFileUrl, {
337 sourceFile: sf,
338 emitCtx: context,
339 externalReferences: externalReferences,
340 });
341 return sf;
342 };
343 TsCompilerAotCompilerTypeCheckHostAdapter.prototype.shouldGenerateFile = function (fileName) {
344 var _this = this;
345 // TODO(tbosch): allow generating files that are not in the rootDir
346 // See https://github.com/angular/angular/issues/19337
347 if (!util_1.isInRootDir(fileName, this.options)) {
348 return { generate: false };
349 }
350 var genMatch = util_1.GENERATED_FILES.exec(fileName);
351 if (!genMatch) {
352 return { generate: false };
353 }
354 var _a = tslib_1.__read(genMatch, 4), base = _a[1], genSuffix = _a[2], suffix = _a[3];
355 if (suffix !== 'ts' && suffix !== 'tsx') {
356 return { generate: false };
357 }
358 var baseFileName;
359 if (genSuffix.indexOf('ngstyle') >= 0) {
360 // Note: ngstyle files have names like `afile.css.ngstyle.ts`
361 if (!this.originalFileExists(base)) {
362 return { generate: false };
363 }
364 }
365 else {
366 // Note: on-the-fly generated files always have a `.ts` suffix,
367 // but the file from which we generated it can be a `.ts`/ `.tsx`/ `.d.ts`
368 // (see options.generateCodeForLibraries).
369 baseFileName = [base + ".ts", base + ".tsx", base + ".d.ts"].find(function (baseFileName) { return _this.isSourceFile(baseFileName) && _this.originalFileExists(baseFileName); });
370 if (!baseFileName) {
371 return { generate: false };
372 }
373 }
374 return { generate: true, baseFileName: baseFileName };
375 };
376 TsCompilerAotCompilerTypeCheckHostAdapter.prototype.shouldGenerateFilesFor = function (fileName) {
377 // TODO(tbosch): allow generating files that are not in the rootDir
378 // See https://github.com/angular/angular/issues/19337
379 return !util_1.GENERATED_FILES.test(fileName) && this.isSourceFile(fileName) &&
380 util_1.isInRootDir(fileName, this.options);
381 };
382 TsCompilerAotCompilerTypeCheckHostAdapter.prototype.getSourceFile = function (fileName, languageVersion, onError) {
383 var _this = this;
384 // Note: Don't exit early in this method to make sure
385 // we always have up to date references on the file!
386 var genFileNames = [];
387 var sf = this.getGeneratedFile(fileName);
388 if (!sf) {
389 var summary = this.librarySummaries.get(fileName);
390 if (summary) {
391 if (!summary.sourceFile) {
392 summary.sourceFile = ts.createSourceFile(fileName, summary.text, this.options.target || ts.ScriptTarget.Latest);
393 }
394 sf = summary.sourceFile;
395 // TypeScript doesn't allow returning redirect source files. To avoid unforseen errors we
396 // return the original source file instead of the redirect target.
397 var redirectInfo = sf.redirectInfo;
398 if (redirectInfo !== undefined) {
399 sf = redirectInfo.unredirected;
400 }
401 genFileNames = [];
402 }
403 }
404 if (!sf) {
405 sf = this.getOriginalSourceFile(fileName);
406 var cachedGenFiles = this.generatedCodeFor.get(fileName);
407 if (cachedGenFiles) {
408 genFileNames = cachedGenFiles;
409 }
410 else {
411 if (!this.options.noResolve && this.shouldGenerateFilesFor(fileName)) {
412 genFileNames = this.codeGenerator.findGeneratedFileNames(fileName).filter(function (fileName) { return _this.shouldGenerateFile(fileName).generate; });
413 }
414 this.generatedCodeFor.set(fileName, genFileNames);
415 }
416 }
417 if (sf) {
418 addReferencesToSourceFile(sf, genFileNames);
419 }
420 // TODO(tbosch): TypeScript's typings for getSourceFile are incorrect,
421 // as it can very well return undefined.
422 return sf;
423 };
424 TsCompilerAotCompilerTypeCheckHostAdapter.prototype.getGeneratedFile = function (fileName) {
425 var genSrcFile = this.generatedSourceFiles.get(fileName);
426 if (genSrcFile) {
427 return genSrcFile.sourceFile;
428 }
429 var _a = this.shouldGenerateFile(fileName), generate = _a.generate, baseFileName = _a.baseFileName;
430 if (generate) {
431 var genFile = this.codeGenerator.generateFile(fileName, baseFileName);
432 return this.addGeneratedFile(genFile, genFileExternalReferences(genFile));
433 }
434 return null;
435 };
436 TsCompilerAotCompilerTypeCheckHostAdapter.prototype.originalFileExists = function (fileName) {
437 var fileExists = this.originalFileExistsCache.get(fileName);
438 if (fileExists == null) {
439 fileExists = this.context.fileExists(fileName);
440 this.originalFileExistsCache.set(fileName, fileExists);
441 }
442 return fileExists;
443 };
444 TsCompilerAotCompilerTypeCheckHostAdapter.prototype.fileExists = function (fileName) {
445 fileName = stripNgResourceSuffix(fileName);
446 if (this.librarySummaries.has(fileName) || this.generatedSourceFiles.has(fileName)) {
447 return true;
448 }
449 if (this.shouldGenerateFile(fileName).generate) {
450 return true;
451 }
452 return this.originalFileExists(fileName);
453 };
454 TsCompilerAotCompilerTypeCheckHostAdapter.prototype.loadSummary = function (filePath) {
455 var summary = this.librarySummaries.get(filePath);
456 if (summary) {
457 return summary.text;
458 }
459 if (this.originalFileExists(filePath)) {
460 return assert(this.context.readFile(filePath));
461 }
462 return null;
463 };
464 TsCompilerAotCompilerTypeCheckHostAdapter.prototype.isSourceFile = function (filePath) {
465 // Don't generate any files nor typecheck them
466 // if skipTemplateCodegen is set and fullTemplateTypeCheck is not yet set,
467 // for backwards compatibility.
468 if (this.options.skipTemplateCodegen && !this.options.fullTemplateTypeCheck) {
469 return false;
470 }
471 // If we have a summary from a previous compilation,
472 // treat the file never as a source file.
473 if (this.librarySummaries.has(filePath)) {
474 return false;
475 }
476 if (util_1.GENERATED_FILES.test(filePath)) {
477 return false;
478 }
479 if (this.options.generateCodeForLibraries === false && util_1.DTS.test(filePath)) {
480 return false;
481 }
482 if (util_1.DTS.test(filePath)) {
483 // Check for a bundle index.
484 if (this.hasBundleIndex(filePath)) {
485 var normalFilePath = path.normalize(filePath);
486 return this.flatModuleIndexNames.has(normalFilePath) ||
487 this.flatModuleIndexRedirectNames.has(normalFilePath);
488 }
489 }
490 return true;
491 };
492 TsCompilerAotCompilerTypeCheckHostAdapter.prototype.readFile = function (fileName) {
493 var summary = this.librarySummaries.get(fileName);
494 if (summary) {
495 return summary.text;
496 }
497 return this.context.readFile(fileName);
498 };
499 TsCompilerAotCompilerTypeCheckHostAdapter.prototype.getMetadataFor = function (filePath) {
500 return metadata_reader_1.readMetadata(filePath, this.metadataReaderHost, this.metadataReaderCache);
501 };
502 TsCompilerAotCompilerTypeCheckHostAdapter.prototype.loadResource = function (filePath) {
503 if (this.context.readResource)
504 return this.context.readResource(filePath);
505 if (!this.originalFileExists(filePath)) {
506 throw compiler_1.syntaxError("Error: Resource file not found: " + filePath);
507 }
508 return assert(this.context.readFile(filePath));
509 };
510 TsCompilerAotCompilerTypeCheckHostAdapter.prototype.getOutputName = function (filePath) {
511 return path.relative(this.getCurrentDirectory(), filePath);
512 };
513 TsCompilerAotCompilerTypeCheckHostAdapter.prototype.hasBundleIndex = function (filePath) {
514 var _this = this;
515 var checkBundleIndex = function (directory) {
516 var result = _this.flatModuleIndexCache.get(directory);
517 if (result == null) {
518 if (path.basename(directory) == 'node_module') {
519 // Don't look outside the node_modules this package is installed in.
520 result = false;
521 }
522 else {
523 // A bundle index exists if the typings .d.ts file has a metadata.json that has an
524 // importAs.
525 try {
526 var packageFile = path.join(directory, 'package.json');
527 if (_this.originalFileExists(packageFile)) {
528 // Once we see a package.json file, assume false until it we find the bundle index.
529 result = false;
530 var packageContent = JSON.parse(assert(_this.context.readFile(packageFile)));
531 if (packageContent.typings) {
532 var typings = path.normalize(path.join(directory, packageContent.typings));
533 if (util_1.DTS.test(typings)) {
534 var metadataFile = typings.replace(util_1.DTS, '.metadata.json');
535 if (_this.originalFileExists(metadataFile)) {
536 var metadata = JSON.parse(assert(_this.context.readFile(metadataFile)));
537 if (metadata.flatModuleIndexRedirect) {
538 _this.flatModuleIndexRedirectNames.add(typings);
539 // Note: don't set result = true,
540 // as this would mark this folder
541 // as having a bundleIndex too early without
542 // filling the bundleIndexNames.
543 }
544 else if (metadata.importAs) {
545 _this.flatModuleIndexNames.add(typings);
546 result = true;
547 }
548 }
549 }
550 }
551 }
552 else {
553 var parent = path.dirname(directory);
554 if (parent != directory) {
555 // Try the parent directory.
556 result = checkBundleIndex(parent);
557 }
558 else {
559 result = false;
560 }
561 }
562 }
563 catch (_a) {
564 // If we encounter any errors assume we this isn't a bundle index.
565 result = false;
566 }
567 }
568 _this.flatModuleIndexCache.set(directory, result);
569 }
570 return result;
571 };
572 return checkBundleIndex(path.dirname(filePath));
573 };
574 return TsCompilerAotCompilerTypeCheckHostAdapter;
575 }());
576 exports.TsCompilerAotCompilerTypeCheckHostAdapter = TsCompilerAotCompilerTypeCheckHostAdapter;
577 function genFileExternalReferences(genFile) {
578 return new Set(compiler_1.collectExternalReferences(genFile.stmts).map(function (er) { return er.moduleName; }));
579 }
580 function addReferencesToSourceFile(sf, genFileNames) {
581 // Note: as we modify ts.SourceFiles we need to keep the original
582 // value for `referencedFiles` around in cache the original host is caching ts.SourceFiles.
583 // Note: cloning the ts.SourceFile is expensive as the nodes in have parent pointers,
584 // i.e. we would also need to clone and adjust all nodes.
585 var originalReferencedFiles = sf.originalReferencedFiles;
586 if (!originalReferencedFiles) {
587 originalReferencedFiles = sf.referencedFiles;
588 sf.originalReferencedFiles = originalReferencedFiles;
589 }
590 var newReferencedFiles = tslib_1.__spreadArray([], tslib_1.__read(originalReferencedFiles));
591 genFileNames.forEach(function (gf) { return newReferencedFiles.push({ fileName: gf, pos: 0, end: 0 }); });
592 sf.referencedFiles = newReferencedFiles;
593 }
594 function getOriginalReferences(sourceFile) {
595 return sourceFile && sourceFile.originalReferencedFiles;
596 }
597 exports.getOriginalReferences = getOriginalReferences;
598 function dotRelative(from, to) {
599 var rPath = path.relative(from, to).replace(/\\/g, '/');
600 return rPath.startsWith('.') ? rPath : './' + rPath;
601 }
602 /**
603 * Moves the path into `genDir` folder while preserving the `node_modules` directory.
604 */
605 function getPackageName(filePath) {
606 var match = NODE_MODULES_PACKAGE_NAME.exec(filePath);
607 return match ? match[1] : null;
608 }
609 function stripNodeModulesPrefix(filePath) {
610 return filePath.replace(/.*node_modules\//, '');
611 }
612 function getNodeModulesPrefix(filePath) {
613 var match = /.*node_modules\//.exec(filePath);
614 return match ? match[1] : null;
615 }
616 function stripNgResourceSuffix(fileName) {
617 return fileName.replace(/\.\$ngresource\$.*/, '');
618 }
619 function addNgResourceSuffix(fileName) {
620 return fileName + ".$ngresource$";
621 }
622});
623//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"compiler_host.js","sourceRoot":"","sources":["../../../../../../../packages/compiler-cli/src/transformers/compiler_host.ts"],"names":[],"mappings":"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","sourcesContent":["/**\n * @license\n * Copyright Google LLC All Rights Reserved.\n *\n * Use of this source code is governed by an MIT-style license that can be\n * found in the LICENSE file at https://angular.io/license\n */\n\nimport {AotCompilerHost, collectExternalReferences, EmitterVisitorContext, GeneratedFile, ParseSourceSpan, syntaxError, TypeScriptEmitter} from '@angular/compiler';\nimport * as path from 'path';\nimport * as ts from 'typescript';\n\nimport {TypeCheckHost} from '../diagnostics/translate_diagnostics';\nimport {ModuleMetadata} from '../metadata/index';\nimport {join} from '../ngtsc/file_system';\n\nimport {CompilerHost, CompilerOptions, LibrarySummary} from './api';\nimport {createMetadataReaderCache, MetadataReaderHost, readMetadata} from './metadata_reader';\nimport {DTS, GENERATED_FILES, isInRootDir, relativeToRootDirs} from './util';\n\nconst NODE_MODULES_PACKAGE_NAME = /node_modules\\/((\\w|-|\\.)+|(@(\\w|-|\\.)+\\/(\\w|-|\\.)+))/;\nconst EXT = /(\\.ts|\\.d\\.ts|\\.js|\\.jsx|\\.tsx)$/;\nconst CSS_PREPROCESSOR_EXT = /(\\.scss|\\.sass|\\.less|\\.styl)$/;\n\nlet wrapHostForTest: ((host: ts.CompilerHost) => ts.CompilerHost)|null = null;\n\nexport function setWrapHostForTest(wrapFn: ((host: ts.CompilerHost) => ts.CompilerHost)|\n                                   null): void {\n  wrapHostForTest = wrapFn;\n}\n\nexport function createCompilerHost(\n    {options, tsHost = ts.createCompilerHost(options, true)}:\n        {options: CompilerOptions, tsHost?: ts.CompilerHost}): CompilerHost {\n  if (wrapHostForTest !== null) {\n    tsHost = wrapHostForTest(tsHost);\n  }\n  return tsHost;\n}\n\nexport interface MetadataProvider {\n  getMetadata(sourceFile: ts.SourceFile): ModuleMetadata|undefined;\n}\n\ninterface GenSourceFile {\n  externalReferences: Set<string>;\n  sourceFile: ts.SourceFile;\n  emitCtx: EmitterVisitorContext;\n}\n\nexport interface CodeGenerator {\n  generateFile(genFileName: string, baseFileName?: string): GeneratedFile;\n  findGeneratedFileNames(fileName: string): string[];\n}\n\nfunction assert<T>(condition: T|null|undefined) {\n  if (!condition) {\n    // TODO(chuckjaz): do the right thing\n  }\n  return condition!;\n}\n\n/**\n * Implements the following hosts based on an api.CompilerHost:\n * - ts.CompilerHost to be consumed by a ts.Program\n * - AotCompilerHost for @angular/compiler\n * - TypeCheckHost for mapping ts errors to ng errors (via translateDiagnostics)\n */\nexport class TsCompilerAotCompilerTypeCheckHostAdapter implements ts.CompilerHost, AotCompilerHost,\n                                                                  TypeCheckHost {\n  private metadataReaderCache = createMetadataReaderCache();\n  private fileNameToModuleNameCache = new Map<string, string>();\n  private flatModuleIndexCache = new Map<string, boolean>();\n  private flatModuleIndexNames = new Set<string>();\n  private flatModuleIndexRedirectNames = new Set<string>();\n  private rootDirs: string[];\n  private moduleResolutionCache: ts.ModuleResolutionCache;\n  private originalSourceFiles = new Map<string, ts.SourceFile|null>();\n  private originalFileExistsCache = new Map<string, boolean>();\n  private generatedSourceFiles = new Map<string, GenSourceFile>();\n  private generatedCodeFor = new Map<string, string[]>();\n  private emitter = new TypeScriptEmitter();\n  private metadataReaderHost: MetadataReaderHost;\n\n  // TODO(issue/24571): remove '!'.\n  getCancellationToken!: () => ts.CancellationToken;\n  // TODO(issue/24571): remove '!'.\n  getDefaultLibLocation!: () => string;\n  // TODO(issue/24571): remove '!'.\n  trace!: (s: string) => void;\n  // TODO(issue/24571): remove '!'.\n  getDirectories!: (path: string) => string[];\n  resolveTypeReferenceDirectives?:\n      (names: string[], containingFile: string) => ts.ResolvedTypeReferenceDirective[];\n  directoryExists?: (directoryName: string) => boolean;\n\n  constructor(\n      private rootFiles: ReadonlyArray<string>, private options: CompilerOptions,\n      private context: CompilerHost, private metadataProvider: MetadataProvider,\n      private codeGenerator: CodeGenerator,\n      private librarySummaries = new Map<string, LibrarySummary>()) {\n    this.moduleResolutionCache = ts.createModuleResolutionCache(\n        this.context.getCurrentDirectory!(), this.context.getCanonicalFileName.bind(this.context));\n    const basePath = this.options.basePath!;\n    this.rootDirs =\n        (this.options.rootDirs || [this.options.basePath!]).map(p => path.resolve(basePath, p));\n    if (context.getDirectories) {\n      this.getDirectories = path => context.getDirectories!(path);\n    }\n    if (context.directoryExists) {\n      this.directoryExists = directoryName => context.directoryExists!(directoryName);\n    }\n    if (context.getCancellationToken) {\n      this.getCancellationToken = () => context.getCancellationToken!();\n    }\n    if (context.getDefaultLibLocation) {\n      this.getDefaultLibLocation = () => context.getDefaultLibLocation!();\n    }\n    if (context.resolveTypeReferenceDirectives) {\n      // Backward compatibility with TypeScript 2.9 and older since return\n      // type has changed from (ts.ResolvedTypeReferenceDirective | undefined)[]\n      // to ts.ResolvedTypeReferenceDirective[] in Typescript 3.0\n      type ts3ResolveTypeReferenceDirectives = (names: string[], containingFile: string) =>\n          ts.ResolvedTypeReferenceDirective[];\n      this.resolveTypeReferenceDirectives = (names: string[], containingFile: string) =>\n          (context.resolveTypeReferenceDirectives as ts3ResolveTypeReferenceDirectives)!\n          (names, containingFile);\n    }\n    if (context.trace) {\n      this.trace = s => context.trace!(s);\n    }\n    if (context.fileNameToModuleName) {\n      this.fileNameToModuleName = context.fileNameToModuleName.bind(context);\n    }\n    // Note: don't copy over context.moduleNameToFileName as we first\n    // normalize undefined containingFile to a filled containingFile.\n    if (context.resourceNameToFileName) {\n      this.resourceNameToFileName = context.resourceNameToFileName.bind(context);\n    }\n    if (context.toSummaryFileName) {\n      this.toSummaryFileName = context.toSummaryFileName.bind(context);\n    }\n    if (context.fromSummaryFileName) {\n      this.fromSummaryFileName = context.fromSummaryFileName.bind(context);\n    }\n    this.metadataReaderHost = {\n      cacheMetadata: () => true,\n      getSourceFileMetadata: (filePath) => {\n        const sf = this.getOriginalSourceFile(filePath);\n        return sf ? this.metadataProvider.getMetadata(sf) : undefined;\n      },\n      fileExists: (filePath) => this.originalFileExists(filePath),\n      readFile: (filePath) => assert(this.context.readFile(filePath)),\n    };\n  }\n\n  private resolveModuleName(moduleName: string, containingFile: string): ts.ResolvedModule\n      |undefined {\n    const rm = ts.resolveModuleName(\n                     moduleName, containingFile.replace(/\\\\/g, '/'), this.options, this,\n                     this.moduleResolutionCache)\n                   .resolvedModule;\n    if (rm && this.isSourceFile(rm.resolvedFileName) && DTS.test(rm.resolvedFileName)) {\n      // Case: generateCodeForLibraries = true and moduleName is\n      // a .d.ts file in a node_modules folder.\n      // Need to set isExternalLibraryImport to false so that generated files for that file\n      // are emitted.\n      rm.isExternalLibraryImport = false;\n    }\n    return rm;\n  }\n\n  // Note: We implement this method so that TypeScript and Angular share the same\n  // ts.ModuleResolutionCache\n  // and that we can tell ts.Program about our different opinion about\n  // ResolvedModule.isExternalLibraryImport\n  // (see our isSourceFile method).\n  resolveModuleNames(moduleNames: string[], containingFile: string): ts.ResolvedModule[] {\n    // TODO(tbosch): this seems to be a typing error in TypeScript,\n    // as it contains assertions that the result contains the same number of entries\n    // as the given module names.\n    return <ts.ResolvedModule[]>moduleNames.map(\n        moduleName => this.resolveModuleName(moduleName, containingFile));\n  }\n\n  moduleNameToFileName(m: string, containingFile?: string): string|null {\n    if (!containingFile) {\n      if (m.indexOf('.') === 0) {\n        throw new Error('Resolution of relative paths requires a containing file.');\n      }\n      // Any containing file gives the same result for absolute imports\n      containingFile = this.rootFiles[0];\n    }\n    if (this.context.moduleNameToFileName) {\n      return this.context.moduleNameToFileName(m, containingFile);\n    }\n    const resolved = this.resolveModuleName(m, containingFile);\n    return resolved ? resolved.resolvedFileName : null;\n  }\n\n  /**\n   * We want a moduleId that will appear in import statements in the generated code\n   * which will be written to `containingFile`.\n   *\n   * Note that we also generate files for files in node_modules, as libraries\n   * only ship .metadata.json files but not the generated code.\n   *\n   * Logic:\n   * 1. if the importedFile and the containingFile are from the project sources\n   *    or from the same node_modules package, use a relative path\n   * 2. if the importedFile is in a node_modules package,\n   *    use a path that starts with the package name.\n   * 3. Error if the containingFile is in the node_modules package\n   *    and the importedFile is in the project soures,\n   *    as that is a violation of the principle that node_modules packages cannot\n   *    import project sources.\n   */\n  fileNameToModuleName(importedFile: string, containingFile: string): string {\n    const cacheKey = `${importedFile}:${containingFile}`;\n    let moduleName = this.fileNameToModuleNameCache.get(cacheKey);\n    if (moduleName != null) {\n      return moduleName;\n    }\n\n    const originalImportedFile = importedFile;\n    if (this.options.traceResolution) {\n      console.error(\n          'fileNameToModuleName from containingFile', containingFile, 'to importedFile',\n          importedFile);\n    }\n\n    // drop extension\n    importedFile = importedFile.replace(EXT, '');\n    const importedFilePackageName = getPackageName(importedFile);\n    const containingFilePackageName = getPackageName(containingFile);\n\n    if (importedFilePackageName === containingFilePackageName ||\n        GENERATED_FILES.test(originalImportedFile)) {\n      const rootedContainingFile = relativeToRootDirs(containingFile, this.rootDirs);\n      const rootedImportedFile = relativeToRootDirs(importedFile, this.rootDirs);\n\n      if (rootedContainingFile !== containingFile && rootedImportedFile !== importedFile) {\n        // if both files are contained in the `rootDirs`, then strip the rootDirs\n        containingFile = rootedContainingFile;\n        importedFile = rootedImportedFile;\n      }\n      moduleName = dotRelative(path.dirname(containingFile), importedFile);\n    } else if (importedFilePackageName) {\n      moduleName = stripNodeModulesPrefix(importedFile);\n      if (originalImportedFile.endsWith('.d.ts')) {\n        // the moduleName for these typings could be shortented to the npm package name\n        // if the npm package typings matches the importedFile\n        try {\n          const modulePath = importedFile.substring(0, importedFile.length - moduleName.length) +\n              importedFilePackageName;\n          const packageJson = require(modulePath + '/package.json');\n          const packageTypings = join(modulePath, packageJson.typings);\n          if (packageTypings === originalImportedFile) {\n            moduleName = importedFilePackageName;\n          }\n        } catch {\n          // the above require() will throw if there is no package.json file\n          // and this is safe to ignore and correct to keep the longer\n          // moduleName in this case\n        }\n      }\n    } else {\n      throw new Error(`Trying to import a source file from a node_modules package: import ${\n          originalImportedFile} from ${containingFile}`);\n    }\n\n    this.fileNameToModuleNameCache.set(cacheKey, moduleName);\n    return moduleName;\n  }\n\n  resourceNameToFileName(resourceName: string, containingFile: string): string|null {\n    // Note: we convert package paths into relative paths to be compatible with the the\n    // previous implementation of UrlResolver.\n    const firstChar = resourceName[0];\n    if (firstChar === '/') {\n      resourceName = resourceName.slice(1);\n    } else if (firstChar !== '.') {\n      resourceName = `./${resourceName}`;\n    }\n    let filePathWithNgResource =\n        this.moduleNameToFileName(addNgResourceSuffix(resourceName), containingFile);\n    // If the user specified styleUrl pointing to *.scss, but the Sass compiler was run before\n    // Angular, then the resource may have been generated as *.css. Simply try the resolution again.\n    if (!filePathWithNgResource && CSS_PREPROCESSOR_EXT.test(resourceName)) {\n      const fallbackResourceName = resourceName.replace(CSS_PREPROCESSOR_EXT, '.css');\n      filePathWithNgResource =\n          this.moduleNameToFileName(addNgResourceSuffix(fallbackResourceName), containingFile);\n    }\n    const result = filePathWithNgResource ? stripNgResourceSuffix(filePathWithNgResource) : null;\n    // Used under Bazel to report more specific error with remediation advice\n    if (!result && (this.context as any).reportMissingResource) {\n      (this.context as any).reportMissingResource(resourceName);\n    }\n    return result;\n  }\n\n  toSummaryFileName(fileName: string, referringSrcFileName: string): string {\n    return this.fileNameToModuleName(fileName, referringSrcFileName);\n  }\n\n  fromSummaryFileName(fileName: string, referringLibFileName: string): string {\n    const resolved = this.moduleNameToFileName(fileName, referringLibFileName);\n    if (!resolved) {\n      throw new Error(`Could not resolve ${fileName} from ${referringLibFileName}`);\n    }\n    return resolved;\n  }\n\n  parseSourceSpanOf(fileName: string, line: number, character: number): ParseSourceSpan|null {\n    const data = this.generatedSourceFiles.get(fileName);\n    if (data && data.emitCtx) {\n      return data.emitCtx.spanOf(line, character);\n    }\n    return null;\n  }\n\n  private getOriginalSourceFile(\n      filePath: string, languageVersion?: ts.ScriptTarget,\n      onError?: ((message: string) => void)|undefined): ts.SourceFile|null {\n    // Note: we need the explicit check via `has` as we also cache results\n    // that were null / undefined.\n    if (this.originalSourceFiles.has(filePath)) {\n      return this.originalSourceFiles.get(filePath)!;\n    }\n    if (!languageVersion) {\n      languageVersion = this.options.target || ts.ScriptTarget.Latest;\n    }\n    // Note: This can also return undefined,\n    // as the TS typings are not correct!\n    const sf = this.context.getSourceFile(filePath, languageVersion, onError) || null;\n    this.originalSourceFiles.set(filePath, sf);\n    return sf;\n  }\n\n  updateGeneratedFile(genFile: GeneratedFile): ts.SourceFile {\n    if (!genFile.stmts) {\n      throw new Error(\n          `Invalid Argument: Expected a GenerateFile with statements. ${genFile.genFileUrl}`);\n    }\n    const oldGenFile = this.generatedSourceFiles.get(genFile.genFileUrl);\n    if (!oldGenFile) {\n      throw new Error(`Illegal State: previous GeneratedFile not found for ${genFile.genFileUrl}.`);\n    }\n    const newRefs = genFileExternalReferences(genFile);\n    const oldRefs = oldGenFile.externalReferences;\n    let refsAreEqual = oldRefs.size === newRefs.size;\n    if (refsAreEqual) {\n      newRefs.forEach(r => refsAreEqual = refsAreEqual && oldRefs.has(r));\n    }\n    if (!refsAreEqual) {\n      throw new Error(`Illegal State: external references changed in ${genFile.genFileUrl}.\\nOld: ${\n          Array.from(oldRefs)}.\\nNew: ${Array.from(newRefs)}`);\n    }\n    return this.addGeneratedFile(genFile, newRefs);\n  }\n\n  private addGeneratedFile(genFile: GeneratedFile, externalReferences: Set<string>): ts.SourceFile {\n    if (!genFile.stmts) {\n      throw new Error(\n          `Invalid Argument: Expected a GenerateFile with statements. ${genFile.genFileUrl}`);\n    }\n    const {sourceText, context} = this.emitter.emitStatementsAndContext(\n        genFile.genFileUrl, genFile.stmts, /* preamble */ '',\n        /* emitSourceMaps */ false);\n    const sf = ts.createSourceFile(\n        genFile.genFileUrl, sourceText, this.options.target || ts.ScriptTarget.Latest);\n    if (this.options.module === ts.ModuleKind.AMD || this.options.module === ts.ModuleKind.UMD) {\n      if (this.context.amdModuleName) {\n        const moduleName = this.context.amdModuleName(sf);\n        if (moduleName) sf.moduleName = moduleName;\n      } else if (/node_modules/.test(genFile.genFileUrl)) {\n        // If we are generating an ngModule file under node_modules, we know the right module name\n        // We don't need the host to supply a function in this case.\n        sf.moduleName = stripNodeModulesPrefix(genFile.genFileUrl.replace(EXT, ''));\n      }\n    }\n    this.generatedSourceFiles.set(genFile.genFileUrl, {\n      sourceFile: sf,\n      emitCtx: context,\n      externalReferences,\n    });\n    return sf;\n  }\n\n  shouldGenerateFile(fileName: string): {generate: boolean, baseFileName?: string} {\n    // TODO(tbosch): allow generating files that are not in the rootDir\n    // See https://github.com/angular/angular/issues/19337\n    if (!isInRootDir(fileName, this.options)) {\n      return {generate: false};\n    }\n    const genMatch = GENERATED_FILES.exec(fileName);\n    if (!genMatch) {\n      return {generate: false};\n    }\n    const [, base, genSuffix, suffix] = genMatch;\n    if (suffix !== 'ts' && suffix !== 'tsx') {\n      return {generate: false};\n    }\n    let baseFileName: string|undefined;\n    if (genSuffix.indexOf('ngstyle') >= 0) {\n      // Note: ngstyle files have names like `afile.css.ngstyle.ts`\n      if (!this.originalFileExists(base)) {\n        return {generate: false};\n      }\n    } else {\n      // Note: on-the-fly generated files always have a `.ts` suffix,\n      // but the file from which we generated it can be a `.ts`/ `.tsx`/ `.d.ts`\n      // (see options.generateCodeForLibraries).\n      baseFileName = [`${base}.ts`, `${base}.tsx`, `${base}.d.ts`].find(\n          baseFileName => this.isSourceFile(baseFileName) && this.originalFileExists(baseFileName));\n      if (!baseFileName) {\n        return {generate: false};\n      }\n    }\n    return {generate: true, baseFileName};\n  }\n\n  shouldGenerateFilesFor(fileName: string) {\n    // TODO(tbosch): allow generating files that are not in the rootDir\n    // See https://github.com/angular/angular/issues/19337\n    return !GENERATED_FILES.test(fileName) && this.isSourceFile(fileName) &&\n        isInRootDir(fileName, this.options);\n  }\n\n  getSourceFile(\n      fileName: string, languageVersion: ts.ScriptTarget,\n      onError?: ((message: string) => void)|undefined): ts.SourceFile {\n    // Note: Don't exit early in this method to make sure\n    // we always have up to date references on the file!\n    let genFileNames: string[] = [];\n    let sf = this.getGeneratedFile(fileName);\n    if (!sf) {\n      const summary = this.librarySummaries.get(fileName);\n      if (summary) {\n        if (!summary.sourceFile) {\n          summary.sourceFile = ts.createSourceFile(\n              fileName, summary.text, this.options.target || ts.ScriptTarget.Latest);\n        }\n        sf = summary.sourceFile;\n        // TypeScript doesn't allow returning redirect source files. To avoid unforseen errors we\n        // return the original source file instead of the redirect target.\n        const redirectInfo = (sf as any).redirectInfo;\n        if (redirectInfo !== undefined) {\n          sf = redirectInfo.unredirected;\n        }\n        genFileNames = [];\n      }\n    }\n    if (!sf) {\n      sf = this.getOriginalSourceFile(fileName);\n      const cachedGenFiles = this.generatedCodeFor.get(fileName);\n      if (cachedGenFiles) {\n        genFileNames = cachedGenFiles;\n      } else {\n        if (!this.options.noResolve && this.shouldGenerateFilesFor(fileName)) {\n          genFileNames = this.codeGenerator.findGeneratedFileNames(fileName).filter(\n              fileName => this.shouldGenerateFile(fileName).generate);\n        }\n        this.generatedCodeFor.set(fileName, genFileNames);\n      }\n    }\n    if (sf) {\n      addReferencesToSourceFile(sf, genFileNames);\n    }\n    // TODO(tbosch): TypeScript's typings for getSourceFile are incorrect,\n    // as it can very well return undefined.\n    return sf!;\n  }\n\n  private getGeneratedFile(fileName: string): ts.SourceFile|null {\n    const genSrcFile = this.generatedSourceFiles.get(fileName);\n    if (genSrcFile) {\n      return genSrcFile.sourceFile;\n    }\n    const {generate, baseFileName} = this.shouldGenerateFile(fileName);\n    if (generate) {\n      const genFile = this.codeGenerator.generateFile(fileName, baseFileName);\n      return this.addGeneratedFile(genFile, genFileExternalReferences(genFile));\n    }\n    return null;\n  }\n\n  private originalFileExists(fileName: string): boolean {\n    let fileExists = this.originalFileExistsCache.get(fileName);\n    if (fileExists == null) {\n      fileExists = this.context.fileExists(fileName);\n      this.originalFileExistsCache.set(fileName, fileExists);\n    }\n    return fileExists;\n  }\n\n  fileExists(fileName: string): boolean {\n    fileName = stripNgResourceSuffix(fileName);\n    if (this.librarySummaries.has(fileName) || this.generatedSourceFiles.has(fileName)) {\n      return true;\n    }\n    if (this.shouldGenerateFile(fileName).generate) {\n      return true;\n    }\n    return this.originalFileExists(fileName);\n  }\n\n  loadSummary(filePath: string): string|null {\n    const summary = this.librarySummaries.get(filePath);\n    if (summary) {\n      return summary.text;\n    }\n    if (this.originalFileExists(filePath)) {\n      return assert(this.context.readFile(filePath));\n    }\n    return null;\n  }\n\n  isSourceFile(filePath: string): boolean {\n    // Don't generate any files nor typecheck them\n    // if skipTemplateCodegen is set and fullTemplateTypeCheck is not yet set,\n    // for backwards compatibility.\n    if (this.options.skipTemplateCodegen && !this.options.fullTemplateTypeCheck) {\n      return false;\n    }\n    // If we have a summary from a previous compilation,\n    // treat the file never as a source file.\n    if (this.librarySummaries.has(filePath)) {\n      return false;\n    }\n    if (GENERATED_FILES.test(filePath)) {\n      return false;\n    }\n    if (this.options.generateCodeForLibraries === false && DTS.test(filePath)) {\n      return false;\n    }\n    if (DTS.test(filePath)) {\n      // Check for a bundle index.\n      if (this.hasBundleIndex(filePath)) {\n        const normalFilePath = path.normalize(filePath);\n        return this.flatModuleIndexNames.has(normalFilePath) ||\n            this.flatModuleIndexRedirectNames.has(normalFilePath);\n      }\n    }\n    return true;\n  }\n\n  readFile(fileName: string) {\n    const summary = this.librarySummaries.get(fileName);\n    if (summary) {\n      return summary.text;\n    }\n    return this.context.readFile(fileName);\n  }\n\n  getMetadataFor(filePath: string): ModuleMetadata[]|undefined {\n    return readMetadata(filePath, this.metadataReaderHost, this.metadataReaderCache);\n  }\n\n  loadResource(filePath: string): Promise<string>|string {\n    if (this.context.readResource) return this.context.readResource(filePath);\n    if (!this.originalFileExists(filePath)) {\n      throw syntaxError(`Error: Resource file not found: ${filePath}`);\n    }\n    return assert(this.context.readFile(filePath));\n  }\n\n  getOutputName(filePath: string): string {\n    return path.relative(this.getCurrentDirectory(), filePath);\n  }\n\n  private hasBundleIndex(filePath: string): boolean {\n    const checkBundleIndex = (directory: string): boolean => {\n      let result = this.flatModuleIndexCache.get(directory);\n      if (result == null) {\n        if (path.basename(directory) == 'node_module') {\n          // Don't look outside the node_modules this package is installed in.\n          result = false;\n        } else {\n          // A bundle index exists if the typings .d.ts file has a metadata.json that has an\n          // importAs.\n          try {\n            const packageFile = path.join(directory, 'package.json');\n            if (this.originalFileExists(packageFile)) {\n              // Once we see a package.json file, assume false until it we find the bundle index.\n              result = false;\n              const packageContent =\n                  JSON.parse(assert(this.context.readFile(packageFile))) as {typings: string};\n              if (packageContent.typings) {\n                const typings = path.normalize(path.join(directory, packageContent.typings));\n                if (DTS.test(typings)) {\n                  const metadataFile = typings.replace(DTS, '.metadata.json');\n                  if (this.originalFileExists(metadataFile)) {\n                    const metadata = JSON.parse(assert(this.context.readFile(metadataFile))) as\n                        {flatModuleIndexRedirect: string, importAs: string};\n                    if (metadata.flatModuleIndexRedirect) {\n                      this.flatModuleIndexRedirectNames.add(typings);\n                      // Note: don't set result = true,\n                      // as this would mark this folder\n                      // as having a bundleIndex too early without\n                      // filling the bundleIndexNames.\n                    } else if (metadata.importAs) {\n                      this.flatModuleIndexNames.add(typings);\n                      result = true;\n                    }\n                  }\n                }\n              }\n            } else {\n              const parent = path.dirname(directory);\n              if (parent != directory) {\n                // Try the parent directory.\n                result = checkBundleIndex(parent);\n              } else {\n                result = false;\n              }\n            }\n          } catch {\n            // If we encounter any errors assume we this isn't a bundle index.\n            result = false;\n          }\n        }\n        this.flatModuleIndexCache.set(directory, result);\n      }\n      return result;\n    };\n\n    return checkBundleIndex(path.dirname(filePath));\n  }\n\n  getDefaultLibFileName = (options: ts.CompilerOptions) =>\n      this.context.getDefaultLibFileName(options)\n  getCurrentDirectory = () => this.context.getCurrentDirectory();\n  getCanonicalFileName = (fileName: string) => this.context.getCanonicalFileName(fileName);\n  useCaseSensitiveFileNames = () => this.context.useCaseSensitiveFileNames();\n  getNewLine = () => this.context.getNewLine();\n  // Make sure we do not `host.realpath()` from TS as we do not want to resolve symlinks.\n  // https://github.com/Microsoft/TypeScript/issues/9552\n  realpath = (p: string) => p;\n  writeFile = this.context.writeFile.bind(this.context);\n}\n\nfunction genFileExternalReferences(genFile: GeneratedFile): Set<string> {\n  return new Set(collectExternalReferences(genFile.stmts!).map(er => er.moduleName!));\n}\n\nfunction addReferencesToSourceFile(sf: ts.SourceFile, genFileNames: string[]) {\n  // Note: as we modify ts.SourceFiles we need to keep the original\n  // value for `referencedFiles` around in cache the original host is caching ts.SourceFiles.\n  // Note: cloning the ts.SourceFile is expensive as the nodes in have parent pointers,\n  // i.e. we would also need to clone and adjust all nodes.\n  let originalReferencedFiles: ReadonlyArray<ts.FileReference> =\n      (sf as any).originalReferencedFiles;\n  if (!originalReferencedFiles) {\n    originalReferencedFiles = sf.referencedFiles;\n    (sf as any).originalReferencedFiles = originalReferencedFiles;\n  }\n  const newReferencedFiles = [...originalReferencedFiles];\n  genFileNames.forEach(gf => newReferencedFiles.push({fileName: gf, pos: 0, end: 0}));\n  sf.referencedFiles = newReferencedFiles;\n}\n\nexport function getOriginalReferences(sourceFile: ts.SourceFile): ts.FileReference[]|undefined {\n  return sourceFile && (sourceFile as any).originalReferencedFiles;\n}\n\nfunction dotRelative(from: string, to: string): string {\n  const rPath: string = path.relative(from, to).replace(/\\\\/g, '/');\n  return rPath.startsWith('.') ? rPath : './' + rPath;\n}\n\n/**\n * Moves the path into `genDir` folder while preserving the `node_modules` directory.\n */\nfunction getPackageName(filePath: string): string|null {\n  const match = NODE_MODULES_PACKAGE_NAME.exec(filePath);\n  return match ? match[1] : null;\n}\n\nfunction stripNodeModulesPrefix(filePath: string): string {\n  return filePath.replace(/.*node_modules\\//, '');\n}\n\nfunction getNodeModulesPrefix(filePath: string): string|null {\n  const match = /.*node_modules\\//.exec(filePath);\n  return match ? match[1] : null;\n}\n\nfunction stripNgResourceSuffix(fileName: string): string {\n  return fileName.replace(/\\.\\$ngresource\\$.*/, '');\n}\n\nfunction addNgResourceSuffix(fileName: string): string {\n  return `${fileName}.$ngresource$`;\n}\n"]}
Note: See TracBrowser for help on using the repository browser.