source: trip-planner-front/node_modules/@angular/compiler-cli/ngcc/src/packages/source_file_cache.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: 25.9 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/source_file_cache", ["require", "exports", "typescript"], factory);
8 }
9})(function (require, exports) {
10 "use strict";
11 Object.defineProperty(exports, "__esModule", { value: true });
12 exports.createModuleResolutionCache = exports.EntryPointFileCache = exports.isAngularDts = exports.isDefaultLibrary = exports.SharedFileCache = void 0;
13 /**
14 * @license
15 * Copyright Google LLC All Rights Reserved.
16 *
17 * Use of this source code is governed by an MIT-style license that can be
18 * found in the LICENSE file at https://angular.io/license
19 */
20 var ts = require("typescript");
21 /**
22 * A cache that holds on to source files that can be shared for processing all entry-points in a
23 * single invocation of ngcc. In particular, the following files are shared across all entry-points
24 * through this cache:
25 *
26 * 1. Default library files such as `lib.dom.d.ts` and `lib.es5.d.ts`. These files don't change
27 * and some are very large, so parsing is expensive. Therefore, the parsed `ts.SourceFile`s for
28 * the default library files are cached.
29 * 2. The typings of @angular scoped packages. The typing files for @angular packages are typically
30 * used in the entry-points that ngcc processes, so benefit from a single source file cache.
31 * Especially `@angular/core/core.d.ts` is large and expensive to parse repeatedly. In contrast
32 * to default library files, we have to account for these files to be invalidated during a single
33 * invocation of ngcc, as ngcc will overwrite the .d.ts files during its processing.
34 *
35 * The lifecycle of this cache corresponds with a single invocation of ngcc. Separate invocations,
36 * e.g. the CLI's synchronous module resolution fallback will therefore all have their own cache.
37 * This allows for the source file cache to be garbage collected once ngcc processing has completed.
38 */
39 var SharedFileCache = /** @class */ (function () {
40 function SharedFileCache(fs) {
41 this.fs = fs;
42 this.sfCache = new Map();
43 }
44 /**
45 * Loads a `ts.SourceFile` if the provided `fileName` is deemed appropriate to be cached. To
46 * optimize for memory usage, only files that are generally used in all entry-points are cached.
47 * If `fileName` is not considered to benefit from caching or the requested file does not exist,
48 * then `undefined` is returned.
49 */
50 SharedFileCache.prototype.getCachedSourceFile = function (fileName) {
51 var absPath = this.fs.resolve(fileName);
52 if (isDefaultLibrary(absPath, this.fs)) {
53 return this.getStableCachedFile(absPath);
54 }
55 else if (isAngularDts(absPath, this.fs)) {
56 return this.getVolatileCachedFile(absPath);
57 }
58 else {
59 return undefined;
60 }
61 };
62 /**
63 * Attempts to load the source file from the cache, or parses the file into a `ts.SourceFile` if
64 * it's not yet cached. This method assumes that the file will not be modified for the duration
65 * that this cache is valid for. If that assumption does not hold, the `getVolatileCachedFile`
66 * method is to be used instead.
67 */
68 SharedFileCache.prototype.getStableCachedFile = function (absPath) {
69 if (!this.sfCache.has(absPath)) {
70 var content = readFile(absPath, this.fs);
71 if (content === undefined) {
72 return undefined;
73 }
74 var sf = ts.createSourceFile(absPath, content, ts.ScriptTarget.ES2015);
75 this.sfCache.set(absPath, sf);
76 }
77 return this.sfCache.get(absPath);
78 };
79 /**
80 * In contrast to `getStableCachedFile`, this method always verifies that the cached source file
81 * is the same as what's stored on disk. This is done for files that are expected to change during
82 * ngcc's processing, such as @angular scoped packages for which the .d.ts files are overwritten
83 * by ngcc. If the contents on disk have changed compared to a previously cached source file, the
84 * content from disk is re-parsed and the cache entry is replaced.
85 */
86 SharedFileCache.prototype.getVolatileCachedFile = function (absPath) {
87 var content = readFile(absPath, this.fs);
88 if (content === undefined) {
89 return undefined;
90 }
91 if (!this.sfCache.has(absPath) || this.sfCache.get(absPath).text !== content) {
92 var sf = ts.createSourceFile(absPath, content, ts.ScriptTarget.ES2015);
93 this.sfCache.set(absPath, sf);
94 }
95 return this.sfCache.get(absPath);
96 };
97 return SharedFileCache;
98 }());
99 exports.SharedFileCache = SharedFileCache;
100 var DEFAULT_LIB_PATTERN = ['node_modules', 'typescript', 'lib', /^lib\..+\.d\.ts$/];
101 /**
102 * Determines whether the provided path corresponds with a default library file inside of the
103 * typescript package.
104 *
105 * @param absPath The path for which to determine if it corresponds with a default library file.
106 * @param fs The filesystem to use for inspecting the path.
107 */
108 function isDefaultLibrary(absPath, fs) {
109 return isFile(absPath, DEFAULT_LIB_PATTERN, fs);
110 }
111 exports.isDefaultLibrary = isDefaultLibrary;
112 var ANGULAR_DTS_PATTERN = ['node_modules', '@angular', /./, /\.d\.ts$/];
113 /**
114 * Determines whether the provided path corresponds with a .d.ts file inside of an @angular
115 * scoped package. This logic only accounts for the .d.ts files in the root, which is sufficient
116 * to find the large, flattened entry-point files that benefit from caching.
117 *
118 * @param absPath The path for which to determine if it corresponds with an @angular .d.ts file.
119 * @param fs The filesystem to use for inspecting the path.
120 */
121 function isAngularDts(absPath, fs) {
122 return isFile(absPath, ANGULAR_DTS_PATTERN, fs);
123 }
124 exports.isAngularDts = isAngularDts;
125 /**
126 * Helper function to determine whether a file corresponds with a given pattern of segments.
127 *
128 * @param path The path for which to determine if it corresponds with the provided segments.
129 * @param segments Array of segments; the `path` must have ending segments that match the
130 * patterns in this array.
131 * @param fs The filesystem to use for inspecting the path.
132 */
133 function isFile(path, segments, fs) {
134 for (var i = segments.length - 1; i >= 0; i--) {
135 var pattern = segments[i];
136 var segment = fs.basename(path);
137 if (typeof pattern === 'string') {
138 if (pattern !== segment) {
139 return false;
140 }
141 }
142 else {
143 if (!pattern.test(segment)) {
144 return false;
145 }
146 }
147 path = fs.dirname(path);
148 }
149 return true;
150 }
151 /**
152 * A cache for processing a single entry-point. This exists to share `ts.SourceFile`s between the
153 * source and typing programs that are created for a single program.
154 */
155 var EntryPointFileCache = /** @class */ (function () {
156 function EntryPointFileCache(fs, sharedFileCache) {
157 this.fs = fs;
158 this.sharedFileCache = sharedFileCache;
159 this.sfCache = new Map();
160 }
161 /**
162 * Returns and caches a parsed `ts.SourceFile` for the provided `fileName`. If the `fileName` is
163 * cached in the shared file cache, that result is used. Otherwise, the source file is cached
164 * internally. This method returns `undefined` if the requested file does not exist.
165 *
166 * @param fileName The path of the file to retrieve a source file for.
167 * @param languageVersion The language version to use for parsing the file.
168 */
169 EntryPointFileCache.prototype.getCachedSourceFile = function (fileName, languageVersion) {
170 var staticSf = this.sharedFileCache.getCachedSourceFile(fileName);
171 if (staticSf !== undefined) {
172 return staticSf;
173 }
174 var absPath = this.fs.resolve(fileName);
175 if (this.sfCache.has(absPath)) {
176 return this.sfCache.get(absPath);
177 }
178 var content = readFile(absPath, this.fs);
179 if (content === undefined) {
180 return undefined;
181 }
182 var sf = ts.createSourceFile(fileName, content, languageVersion);
183 this.sfCache.set(absPath, sf);
184 return sf;
185 };
186 return EntryPointFileCache;
187 }());
188 exports.EntryPointFileCache = EntryPointFileCache;
189 function readFile(absPath, fs) {
190 if (!fs.exists(absPath) || !fs.stat(absPath).isFile()) {
191 return undefined;
192 }
193 return fs.readFile(absPath);
194 }
195 /**
196 * Creates a `ts.ModuleResolutionCache` that uses the provided filesystem for path operations.
197 *
198 * @param fs The filesystem to use for path operations.
199 */
200 function createModuleResolutionCache(fs) {
201 return ts.createModuleResolutionCache(fs.pwd(), function (fileName) {
202 return fs.isCaseSensitive() ? fileName : fileName.toLowerCase();
203 });
204 }
205 exports.createModuleResolutionCache = createModuleResolutionCache;
206});
207//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"source_file_cache.js","sourceRoot":"","sources":["../../../../../../../../packages/compiler-cli/ngcc/src/packages/source_file_cache.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';\nimport {AbsoluteFsPath, ReadonlyFileSystem} from '../../../src/ngtsc/file_system';\n\n/**\n * A cache that holds on to source files that can be shared for processing all entry-points in a\n * single invocation of ngcc. In particular, the following files are shared across all entry-points\n * through this cache:\n *\n * 1. Default library files such as `lib.dom.d.ts` and `lib.es5.d.ts`. These files don't change\n *    and some are very large, so parsing is expensive. Therefore, the parsed `ts.SourceFile`s for\n *    the default library files are cached.\n * 2. The typings of @angular scoped packages. The typing files for @angular packages are typically\n *    used in the entry-points that ngcc processes, so benefit from a single source file cache.\n *    Especially `@angular/core/core.d.ts` is large and expensive to parse repeatedly. In contrast\n *    to default library files, we have to account for these files to be invalidated during a single\n *    invocation of ngcc, as ngcc will overwrite the .d.ts files during its processing.\n *\n * The lifecycle of this cache corresponds with a single invocation of ngcc. Separate invocations,\n * e.g. the CLI's synchronous module resolution fallback will therefore all have their own cache.\n * This allows for the source file cache to be garbage collected once ngcc processing has completed.\n */\nexport class SharedFileCache {\n  private sfCache = new Map<AbsoluteFsPath, ts.SourceFile>();\n\n  constructor(private fs: ReadonlyFileSystem) {}\n\n  /**\n   * Loads a `ts.SourceFile` if the provided `fileName` is deemed appropriate to be cached. To\n   * optimize for memory usage, only files that are generally used in all entry-points are cached.\n   * If `fileName` is not considered to benefit from caching or the requested file does not exist,\n   * then `undefined` is returned.\n   */\n  getCachedSourceFile(fileName: string): ts.SourceFile|undefined {\n    const absPath = this.fs.resolve(fileName);\n    if (isDefaultLibrary(absPath, this.fs)) {\n      return this.getStableCachedFile(absPath);\n    } else if (isAngularDts(absPath, this.fs)) {\n      return this.getVolatileCachedFile(absPath);\n    } else {\n      return undefined;\n    }\n  }\n\n  /**\n   * Attempts to load the source file from the cache, or parses the file into a `ts.SourceFile` if\n   * it's not yet cached. This method assumes that the file will not be modified for the duration\n   * that this cache is valid for. If that assumption does not hold, the `getVolatileCachedFile`\n   * method is to be used instead.\n   */\n  private getStableCachedFile(absPath: AbsoluteFsPath): ts.SourceFile|undefined {\n    if (!this.sfCache.has(absPath)) {\n      const content = readFile(absPath, this.fs);\n      if (content === undefined) {\n        return undefined;\n      }\n      const sf = ts.createSourceFile(absPath, content, ts.ScriptTarget.ES2015);\n      this.sfCache.set(absPath, sf);\n    }\n    return this.sfCache.get(absPath)!;\n  }\n\n  /**\n   * In contrast to `getStableCachedFile`, this method always verifies that the cached source file\n   * is the same as what's stored on disk. This is done for files that are expected to change during\n   * ngcc's processing, such as @angular scoped packages for which the .d.ts files are overwritten\n   * by ngcc. If the contents on disk have changed compared to a previously cached source file, the\n   * content from disk is re-parsed and the cache entry is replaced.\n   */\n  private getVolatileCachedFile(absPath: AbsoluteFsPath): ts.SourceFile|undefined {\n    const content = readFile(absPath, this.fs);\n    if (content === undefined) {\n      return undefined;\n    }\n    if (!this.sfCache.has(absPath) || this.sfCache.get(absPath)!.text !== content) {\n      const sf = ts.createSourceFile(absPath, content, ts.ScriptTarget.ES2015);\n      this.sfCache.set(absPath, sf);\n    }\n    return this.sfCache.get(absPath)!;\n  }\n}\n\nconst DEFAULT_LIB_PATTERN = ['node_modules', 'typescript', 'lib', /^lib\\..+\\.d\\.ts$/];\n\n/**\n * Determines whether the provided path corresponds with a default library file inside of the\n * typescript package.\n *\n * @param absPath The path for which to determine if it corresponds with a default library file.\n * @param fs The filesystem to use for inspecting the path.\n */\nexport function isDefaultLibrary(absPath: AbsoluteFsPath, fs: ReadonlyFileSystem): boolean {\n  return isFile(absPath, DEFAULT_LIB_PATTERN, fs);\n}\n\nconst ANGULAR_DTS_PATTERN = ['node_modules', '@angular', /./, /\\.d\\.ts$/];\n\n/**\n * Determines whether the provided path corresponds with a .d.ts file inside of an @angular\n * scoped package. This logic only accounts for the .d.ts files in the root, which is sufficient\n * to find the large, flattened entry-point files that benefit from caching.\n *\n * @param absPath The path for which to determine if it corresponds with an @angular .d.ts file.\n * @param fs The filesystem to use for inspecting the path.\n */\nexport function isAngularDts(absPath: AbsoluteFsPath, fs: ReadonlyFileSystem): boolean {\n  return isFile(absPath, ANGULAR_DTS_PATTERN, fs);\n}\n\n/**\n * Helper function to determine whether a file corresponds with a given pattern of segments.\n *\n * @param path The path for which to determine if it corresponds with the provided segments.\n * @param segments Array of segments; the `path` must have ending segments that match the\n * patterns in this array.\n * @param fs The filesystem to use for inspecting the path.\n */\nfunction isFile(\n    path: AbsoluteFsPath, segments: ReadonlyArray<string|RegExp>, fs: ReadonlyFileSystem): boolean {\n  for (let i = segments.length - 1; i >= 0; i--) {\n    const pattern = segments[i];\n    const segment = fs.basename(path);\n    if (typeof pattern === 'string') {\n      if (pattern !== segment) {\n        return false;\n      }\n    } else {\n      if (!pattern.test(segment)) {\n        return false;\n      }\n    }\n    path = fs.dirname(path);\n  }\n  return true;\n}\n\n/**\n * A cache for processing a single entry-point. This exists to share `ts.SourceFile`s between the\n * source and typing programs that are created for a single program.\n */\nexport class EntryPointFileCache {\n  private readonly sfCache = new Map<AbsoluteFsPath, ts.SourceFile>();\n\n  constructor(private fs: ReadonlyFileSystem, private sharedFileCache: SharedFileCache) {}\n\n  /**\n   * Returns and caches a parsed `ts.SourceFile` for the provided `fileName`. If the `fileName` is\n   * cached in the shared file cache, that result is used. Otherwise, the source file is cached\n   * internally. This method returns `undefined` if the requested file does not exist.\n   *\n   * @param fileName The path of the file to retrieve a source file for.\n   * @param languageVersion The language version to use for parsing the file.\n   */\n  getCachedSourceFile(fileName: string, languageVersion: ts.ScriptTarget): ts.SourceFile|undefined {\n    const staticSf = this.sharedFileCache.getCachedSourceFile(fileName);\n    if (staticSf !== undefined) {\n      return staticSf;\n    }\n\n    const absPath = this.fs.resolve(fileName);\n    if (this.sfCache.has(absPath)) {\n      return this.sfCache.get(absPath);\n    }\n\n    const content = readFile(absPath, this.fs);\n    if (content === undefined) {\n      return undefined;\n    }\n    const sf = ts.createSourceFile(fileName, content, languageVersion);\n    this.sfCache.set(absPath, sf);\n    return sf;\n  }\n}\n\nfunction readFile(absPath: AbsoluteFsPath, fs: ReadonlyFileSystem): string|undefined {\n  if (!fs.exists(absPath) || !fs.stat(absPath).isFile()) {\n    return undefined;\n  }\n  return fs.readFile(absPath);\n}\n\n/**\n * Creates a `ts.ModuleResolutionCache` that uses the provided filesystem for path operations.\n *\n * @param fs The filesystem to use for path operations.\n */\nexport function createModuleResolutionCache(fs: ReadonlyFileSystem): ts.ModuleResolutionCache {\n  return ts.createModuleResolutionCache(fs.pwd(), fileName => {\n    return fs.isCaseSensitive() ? fileName : fileName.toLowerCase();\n  });\n}\n"]}
Note: See TracBrowser for help on using the repository browser.