source: trip-planner-front/node_modules/@angular/compiler-cli/ngcc/src/packages/ngcc_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: 15.2 KB
Line 
1(function (factory) {
2 if (typeof module === "object" && typeof module.exports === "object") {
3 var v = factory(require, exports);
4 if (v !== undefined) module.exports = v;
5 }
6 else if (typeof define === "function" && define.amd) {
7 define("@angular/compiler-cli/ngcc/src/packages/ngcc_compiler_host", ["require", "exports", "tslib", "typescript", "@angular/compiler-cli/src/ngtsc/file_system", "@angular/compiler-cli/ngcc/src/analysis/util", "@angular/compiler-cli/ngcc/src/utils"], factory);
8 }
9})(function (require, exports) {
10 "use strict";
11 Object.defineProperty(exports, "__esModule", { value: true });
12 exports.NgccDtsCompilerHost = exports.NgccSourcesCompilerHost = void 0;
13 var tslib_1 = require("tslib");
14 /**
15 * @license
16 * Copyright Google LLC All Rights Reserved.
17 *
18 * Use of this source code is governed by an MIT-style license that can be
19 * found in the LICENSE file at https://angular.io/license
20 */
21 var ts = require("typescript");
22 var file_system_1 = require("@angular/compiler-cli/src/ngtsc/file_system");
23 var util_1 = require("@angular/compiler-cli/ngcc/src/analysis/util");
24 var utils_1 = require("@angular/compiler-cli/ngcc/src/utils");
25 /**
26 * Represents a compiler host that resolves a module import as a JavaScript source file if
27 * available, instead of the .d.ts typings file that would have been resolved by TypeScript. This
28 * is necessary for packages that have their typings in the same directory as the sources, which
29 * would otherwise let TypeScript prefer the .d.ts file instead of the JavaScript source file.
30 */
31 var NgccSourcesCompilerHost = /** @class */ (function (_super) {
32 tslib_1.__extends(NgccSourcesCompilerHost, _super);
33 function NgccSourcesCompilerHost(fs, options, cache, moduleResolutionCache, packagePath) {
34 var _this = _super.call(this, fs, options) || this;
35 _this.cache = cache;
36 _this.moduleResolutionCache = moduleResolutionCache;
37 _this.packagePath = packagePath;
38 return _this;
39 }
40 NgccSourcesCompilerHost.prototype.getSourceFile = function (fileName, languageVersion) {
41 return this.cache.getCachedSourceFile(fileName, languageVersion);
42 };
43 NgccSourcesCompilerHost.prototype.resolveModuleNames = function (moduleNames, containingFile, reusedNames, redirectedReference) {
44 var _this = this;
45 return moduleNames.map(function (moduleName) {
46 var resolvedModule = ts.resolveModuleName(moduleName, containingFile, _this.options, _this, _this.moduleResolutionCache, redirectedReference).resolvedModule;
47 // If the module request originated from a relative import in a JavaScript source file,
48 // TypeScript may have resolved the module to its .d.ts declaration file if the .js source
49 // file was in the same directory. This is undesirable, as we need to have the actual
50 // JavaScript being present in the program. This logic recognizes this scenario and rewrites
51 // the resolved .d.ts declaration file to its .js counterpart, if it exists.
52 if ((resolvedModule === null || resolvedModule === void 0 ? void 0 : resolvedModule.extension) === ts.Extension.Dts && containingFile.endsWith('.js') &&
53 utils_1.isRelativePath(moduleName)) {
54 var jsFile = resolvedModule.resolvedFileName.replace(/\.d\.ts$/, '.js');
55 if (_this.fileExists(jsFile)) {
56 return tslib_1.__assign(tslib_1.__assign({}, resolvedModule), { resolvedFileName: jsFile, extension: ts.Extension.Js });
57 }
58 }
59 // Prevent loading JavaScript source files outside of the package root, which would happen for
60 // packages that don't have .d.ts files. As ngcc should only operate on the .js files
61 // contained within the package, any files outside the package are simply discarded. This does
62 // result in a partial program with error diagnostics, however ngcc won't gather diagnostics
63 // for the program it creates so these diagnostics won't be reported.
64 if ((resolvedModule === null || resolvedModule === void 0 ? void 0 : resolvedModule.extension) === ts.Extension.Js &&
65 !util_1.isWithinPackage(_this.packagePath, _this.fs.resolve(resolvedModule.resolvedFileName))) {
66 return undefined;
67 }
68 return resolvedModule;
69 });
70 };
71 return NgccSourcesCompilerHost;
72 }(file_system_1.NgtscCompilerHost));
73 exports.NgccSourcesCompilerHost = NgccSourcesCompilerHost;
74 /**
75 * A compiler host implementation that is used for the typings program. It leverages the entry-point
76 * cache for source files and module resolution, as these results can be reused across the sources
77 * program.
78 */
79 var NgccDtsCompilerHost = /** @class */ (function (_super) {
80 tslib_1.__extends(NgccDtsCompilerHost, _super);
81 function NgccDtsCompilerHost(fs, options, cache, moduleResolutionCache) {
82 var _this = _super.call(this, fs, options) || this;
83 _this.cache = cache;
84 _this.moduleResolutionCache = moduleResolutionCache;
85 return _this;
86 }
87 NgccDtsCompilerHost.prototype.getSourceFile = function (fileName, languageVersion) {
88 return this.cache.getCachedSourceFile(fileName, languageVersion);
89 };
90 NgccDtsCompilerHost.prototype.resolveModuleNames = function (moduleNames, containingFile, reusedNames, redirectedReference) {
91 var _this = this;
92 return moduleNames.map(function (moduleName) {
93 var resolvedModule = ts.resolveModuleName(moduleName, containingFile, _this.options, _this, _this.moduleResolutionCache, redirectedReference).resolvedModule;
94 return resolvedModule;
95 });
96 };
97 return NgccDtsCompilerHost;
98 }(file_system_1.NgtscCompilerHost));
99 exports.NgccDtsCompilerHost = NgccDtsCompilerHost;
100});
101//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"ngcc_compiler_host.js","sourceRoot":"","sources":["../../../../../../../../packages/compiler-cli/ngcc/src/packages/ngcc_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 */\nimport * as ts from 'typescript';\n\nimport {AbsoluteFsPath, FileSystem, NgtscCompilerHost} from '../../../src/ngtsc/file_system';\nimport {isWithinPackage} from '../analysis/util';\nimport {isRelativePath} from '../utils';\nimport {EntryPointFileCache} from './source_file_cache';\n\n/**\n * Represents a compiler host that resolves a module import as a JavaScript source file if\n * available, instead of the .d.ts typings file that would have been resolved by TypeScript. This\n * is necessary for packages that have their typings in the same directory as the sources, which\n * would otherwise let TypeScript prefer the .d.ts file instead of the JavaScript source file.\n */\nexport class NgccSourcesCompilerHost extends NgtscCompilerHost {\n  constructor(\n      fs: FileSystem, options: ts.CompilerOptions, private cache: EntryPointFileCache,\n      private moduleResolutionCache: ts.ModuleResolutionCache,\n      protected packagePath: AbsoluteFsPath) {\n    super(fs, options);\n  }\n\n  override getSourceFile(fileName: string, languageVersion: ts.ScriptTarget): ts.SourceFile\n      |undefined {\n    return this.cache.getCachedSourceFile(fileName, languageVersion);\n  }\n\n  resolveModuleNames(\n      moduleNames: string[], containingFile: string, reusedNames?: string[],\n      redirectedReference?: ts.ResolvedProjectReference): Array<ts.ResolvedModule|undefined> {\n    return moduleNames.map(moduleName => {\n      const {resolvedModule} = ts.resolveModuleName(\n          moduleName, containingFile, this.options, this, this.moduleResolutionCache,\n          redirectedReference);\n\n      // If the module request originated from a relative import in a JavaScript source file,\n      // TypeScript may have resolved the module to its .d.ts declaration file if the .js source\n      // file was in the same directory. This is undesirable, as we need to have the actual\n      // JavaScript being present in the program. This logic recognizes this scenario and rewrites\n      // the resolved .d.ts declaration file to its .js counterpart, if it exists.\n      if (resolvedModule?.extension === ts.Extension.Dts && containingFile.endsWith('.js') &&\n          isRelativePath(moduleName)) {\n        const jsFile = resolvedModule.resolvedFileName.replace(/\\.d\\.ts$/, '.js');\n        if (this.fileExists(jsFile)) {\n          return {...resolvedModule, resolvedFileName: jsFile, extension: ts.Extension.Js};\n        }\n      }\n\n      // Prevent loading JavaScript source files outside of the package root, which would happen for\n      // packages that don't have .d.ts files. As ngcc should only operate on the .js files\n      // contained within the package, any files outside the package are simply discarded. This does\n      // result in a partial program with error diagnostics, however ngcc won't gather diagnostics\n      // for the program it creates so these diagnostics won't be reported.\n      if (resolvedModule?.extension === ts.Extension.Js &&\n          !isWithinPackage(this.packagePath, this.fs.resolve(resolvedModule.resolvedFileName))) {\n        return undefined;\n      }\n\n      return resolvedModule;\n    });\n  }\n}\n\n/**\n * A compiler host implementation that is used for the typings program. It leverages the entry-point\n * cache for source files and module resolution, as these results can be reused across the sources\n * program.\n */\nexport class NgccDtsCompilerHost extends NgtscCompilerHost {\n  constructor(\n      fs: FileSystem, options: ts.CompilerOptions, private cache: EntryPointFileCache,\n      private moduleResolutionCache: ts.ModuleResolutionCache) {\n    super(fs, options);\n  }\n\n  override getSourceFile(fileName: string, languageVersion: ts.ScriptTarget): ts.SourceFile\n      |undefined {\n    return this.cache.getCachedSourceFile(fileName, languageVersion);\n  }\n\n  resolveModuleNames(\n      moduleNames: string[], containingFile: string, reusedNames?: string[],\n      redirectedReference?: ts.ResolvedProjectReference): Array<ts.ResolvedModule|undefined> {\n    return moduleNames.map(moduleName => {\n      const {resolvedModule} = ts.resolveModuleName(\n          moduleName, containingFile, this.options, this, this.moduleResolutionCache,\n          redirectedReference);\n      return resolvedModule;\n    });\n  }\n}\n"]}
Note: See TracBrowser for help on using the repository browser.