UNPKG

27.6 kBJavaScriptView Raw
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/entry_point_finder/directory_walker_entry_point_finder", ["require", "exports", "tslib", "@angular/compiler-cli/ngcc/src/packages/entry_point", "@angular/compiler-cli/ngcc/src/writing/new_entry_point_file_writer", "@angular/compiler-cli/ngcc/src/entry_point_finder/utils"], factory);
8 }
9})(function (require, exports) {
10 "use strict";
11 Object.defineProperty(exports, "__esModule", { value: true });
12 var tslib_1 = require("tslib");
13 var entry_point_1 = require("@angular/compiler-cli/ngcc/src/packages/entry_point");
14 var new_entry_point_file_writer_1 = require("@angular/compiler-cli/ngcc/src/writing/new_entry_point_file_writer");
15 var utils_1 = require("@angular/compiler-cli/ngcc/src/entry_point_finder/utils");
16 /**
17 * An EntryPointFinder that searches for all entry-points that can be found given a `basePath` and
18 * `pathMappings`.
19 */
20 var DirectoryWalkerEntryPointFinder = /** @class */ (function () {
21 function DirectoryWalkerEntryPointFinder(fs, config, logger, resolver, entryPointManifest, sourceDirectory, pathMappings) {
22 this.fs = fs;
23 this.config = config;
24 this.logger = logger;
25 this.resolver = resolver;
26 this.entryPointManifest = entryPointManifest;
27 this.sourceDirectory = sourceDirectory;
28 this.pathMappings = pathMappings;
29 this.basePaths = utils_1.getBasePaths(this.logger, this.sourceDirectory, this.pathMappings);
30 }
31 /**
32 * Search the `sourceDirectory`, and sub-directories, using `pathMappings` as necessary, to find
33 * all package entry-points.
34 */
35 DirectoryWalkerEntryPointFinder.prototype.findEntryPoints = function () {
36 var e_1, _a;
37 var unsortedEntryPoints = [];
38 try {
39 for (var _b = tslib_1.__values(this.basePaths), _c = _b.next(); !_c.done; _c = _b.next()) {
40 var basePath = _c.value;
41 var entryPoints = this.entryPointManifest.readEntryPointsUsingManifest(basePath) ||
42 this.walkBasePathForPackages(basePath);
43 unsortedEntryPoints.push.apply(unsortedEntryPoints, tslib_1.__spread(entryPoints));
44 }
45 }
46 catch (e_1_1) { e_1 = { error: e_1_1 }; }
47 finally {
48 try {
49 if (_c && !_c.done && (_a = _b.return)) _a.call(_b);
50 }
51 finally { if (e_1) throw e_1.error; }
52 }
53 return this.resolver.sortEntryPointsByDependency(unsortedEntryPoints);
54 };
55 /**
56 * Search the `basePath` for possible Angular packages and entry-points.
57 *
58 * @param basePath The path at which to start the search
59 * @returns an array of `EntryPoint`s that were found within `basePath`.
60 */
61 DirectoryWalkerEntryPointFinder.prototype.walkBasePathForPackages = function (basePath) {
62 var _this = this;
63 this.logger.debug("No manifest found for " + basePath + " so walking the directories for entry-points.");
64 var entryPoints = utils_1.trackDuration(function () { return _this.walkDirectoryForPackages(basePath); }, function (duration) { return _this.logger.debug("Walking " + basePath + " for entry-points took " + duration + "s."); });
65 this.entryPointManifest.writeEntryPointManifest(basePath, entryPoints);
66 return entryPoints;
67 };
68 /**
69 * Look for Angular packages that need to be compiled, starting at the source directory.
70 * The function will recurse into directories that start with `@...`, e.g. `@angular/...`.
71 *
72 * @param sourceDirectory An absolute path to the root directory where searching begins.
73 * @returns an array of `EntryPoint`s that were found within `sourceDirectory`.
74 */
75 DirectoryWalkerEntryPointFinder.prototype.walkDirectoryForPackages = function (sourceDirectory) {
76 var e_2, _a;
77 // Try to get a primary entry point from this directory
78 var primaryEntryPoint = entry_point_1.getEntryPointInfo(this.fs, this.config, this.logger, sourceDirectory, sourceDirectory);
79 // If there is an entry-point but it is not compatible with ngcc (it has a bad package.json or
80 // invalid typings) then exit. It is unlikely that such an entry point has a dependency on an
81 // Angular library.
82 if (primaryEntryPoint === entry_point_1.INCOMPATIBLE_ENTRY_POINT) {
83 return [];
84 }
85 var entryPoints = [];
86 if (primaryEntryPoint !== entry_point_1.NO_ENTRY_POINT) {
87 entryPoints.push(primaryEntryPoint);
88 this.collectSecondaryEntryPoints(entryPoints, sourceDirectory, sourceDirectory, this.fs.readdir(sourceDirectory));
89 // Also check for any nested node_modules in this package but only if at least one of the
90 // entry-points was compiled by Angular.
91 if (entryPoints.some(function (e) { return e.compiledByAngular; })) {
92 var nestedNodeModulesPath = this.fs.join(sourceDirectory, 'node_modules');
93 if (this.fs.exists(nestedNodeModulesPath)) {
94 entryPoints.push.apply(entryPoints, tslib_1.__spread(this.walkDirectoryForPackages(nestedNodeModulesPath)));
95 }
96 }
97 return entryPoints;
98 }
99 try {
100 // The `sourceDirectory` was not a package (i.e. there was no package.json)
101 // So search its sub-directories for Angular packages and entry-points
102 for (var _b = tslib_1.__values(this.fs.readdir(sourceDirectory)), _c = _b.next(); !_c.done; _c = _b.next()) {
103 var path = _c.value;
104 if (isIgnorablePath(path)) {
105 // Ignore hidden files, node_modules and ngcc directory
106 continue;
107 }
108 var absolutePath = this.fs.resolve(sourceDirectory, path);
109 var stat = this.fs.lstat(absolutePath);
110 if (stat.isSymbolicLink() || !stat.isDirectory()) {
111 // Ignore symbolic links and non-directories
112 continue;
113 }
114 entryPoints.push.apply(entryPoints, tslib_1.__spread(this.walkDirectoryForPackages(this.fs.join(sourceDirectory, path))));
115 }
116 }
117 catch (e_2_1) { e_2 = { error: e_2_1 }; }
118 finally {
119 try {
120 if (_c && !_c.done && (_a = _b.return)) _a.call(_b);
121 }
122 finally { if (e_2) throw e_2.error; }
123 }
124 return entryPoints;
125 };
126 /**
127 * Search the `directory` looking for any secondary entry-points for a package, adding any that
128 * are found to the `entryPoints` array.
129 *
130 * @param entryPoints An array where we will add any entry-points found in this directory
131 * @param packagePath The absolute path to the package that may contain entry-points
132 * @param directory The current directory being searched
133 * @param paths The paths contained in the current `directory`.
134 */
135 DirectoryWalkerEntryPointFinder.prototype.collectSecondaryEntryPoints = function (entryPoints, packagePath, directory, paths) {
136 var e_3, _a;
137 var _this = this;
138 var _loop_1 = function (path) {
139 if (isIgnorablePath(path)) {
140 return "continue";
141 }
142 var absolutePath = this_1.fs.resolve(directory, path);
143 var stat = this_1.fs.lstat(absolutePath);
144 if (stat.isSymbolicLink()) {
145 return "continue";
146 }
147 var isDirectory = stat.isDirectory();
148 if (!path.endsWith('.js') && !isDirectory) {
149 return "continue";
150 }
151 // If the path is a JS file then strip its extension and see if we can match an
152 // entry-point.
153 var possibleEntryPointPath = isDirectory ? absolutePath : stripJsExtension(absolutePath);
154 var isEntryPoint = false;
155 var subEntryPoint = entry_point_1.getEntryPointInfo(this_1.fs, this_1.config, this_1.logger, packagePath, possibleEntryPointPath);
156 if (subEntryPoint !== entry_point_1.NO_ENTRY_POINT && subEntryPoint !== entry_point_1.INCOMPATIBLE_ENTRY_POINT) {
157 entryPoints.push(subEntryPoint);
158 isEntryPoint = true;
159 }
160 if (!isDirectory) {
161 return "continue";
162 }
163 // This directory may contain entry-points of its own.
164 var childPaths = this_1.fs.readdir(absolutePath);
165 if (!isEntryPoint &&
166 childPaths.some(function (childPath) { return childPath.endsWith('.js') &&
167 _this.fs.stat(_this.fs.resolve(absolutePath, childPath)).isFile(); })) {
168 return "continue";
169 }
170 this_1.collectSecondaryEntryPoints(entryPoints, packagePath, absolutePath, childPaths);
171 };
172 var this_1 = this;
173 try {
174 for (var paths_1 = tslib_1.__values(paths), paths_1_1 = paths_1.next(); !paths_1_1.done; paths_1_1 = paths_1.next()) {
175 var path = paths_1_1.value;
176 _loop_1(path);
177 }
178 }
179 catch (e_3_1) { e_3 = { error: e_3_1 }; }
180 finally {
181 try {
182 if (paths_1_1 && !paths_1_1.done && (_a = paths_1.return)) _a.call(paths_1);
183 }
184 finally { if (e_3) throw e_3.error; }
185 }
186 };
187 return DirectoryWalkerEntryPointFinder;
188 }());
189 exports.DirectoryWalkerEntryPointFinder = DirectoryWalkerEntryPointFinder;
190 function stripJsExtension(filePath) {
191 return filePath.replace(/\.js$/, '');
192 }
193 function isIgnorablePath(path) {
194 return path.startsWith('.') || path === 'node_modules' || path === new_entry_point_file_writer_1.NGCC_DIRECTORY;
195 }
196});
197//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"directory_walker_entry_point_finder.js","sourceRoot":"","sources":["../../../../../../../../packages/compiler-cli/ngcc/src/entry_point_finder/directory_walker_entry_point_finder.ts"],"names":[],"mappings":"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","sourcesContent":["/**\n * @license\n * Copyright Google Inc. 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 {AbsoluteFsPath, FileSystem, PathSegment} from '../../../src/ngtsc/file_system';\nimport {DependencyResolver, SortedEntryPointsInfo} from '../dependencies/dependency_resolver';\nimport {Logger} from '../logging/logger';\nimport {NgccConfiguration} from '../packages/configuration';\nimport {EntryPoint, getEntryPointInfo, INCOMPATIBLE_ENTRY_POINT, NO_ENTRY_POINT} from '../packages/entry_point';\nimport {EntryPointManifest} from '../packages/entry_point_manifest';\nimport {PathMappings} from '../utils';\nimport {NGCC_DIRECTORY} from '../writing/new_entry_point_file_writer';\n\nimport {EntryPointFinder} from './interface';\nimport {getBasePaths, trackDuration} from './utils';\n\n/**\n * An EntryPointFinder that searches for all entry-points that can be found given a `basePath` and\n * `pathMappings`.\n */\nexport class DirectoryWalkerEntryPointFinder implements EntryPointFinder {\n  private basePaths = getBasePaths(this.logger, this.sourceDirectory, this.pathMappings);\n  constructor(\n      private fs: FileSystem, private config: NgccConfiguration, private logger: Logger,\n      private resolver: DependencyResolver, private entryPointManifest: EntryPointManifest,\n      private sourceDirectory: AbsoluteFsPath, private pathMappings: PathMappings|undefined) {}\n  /**\n   * Search the `sourceDirectory`, and sub-directories, using `pathMappings` as necessary, to find\n   * all package entry-points.\n   */\n  findEntryPoints(): SortedEntryPointsInfo {\n    const unsortedEntryPoints: EntryPoint[] = [];\n    for (const basePath of this.basePaths) {\n      const entryPoints = this.entryPointManifest.readEntryPointsUsingManifest(basePath) ||\n          this.walkBasePathForPackages(basePath);\n      unsortedEntryPoints.push(...entryPoints);\n    }\n    return this.resolver.sortEntryPointsByDependency(unsortedEntryPoints);\n  }\n\n  /**\n   * Search the `basePath` for possible Angular packages and entry-points.\n   *\n   * @param basePath The path at which to start the search\n   * @returns an array of `EntryPoint`s that were found within `basePath`.\n   */\n  walkBasePathForPackages(basePath: AbsoluteFsPath): EntryPoint[] {\n    this.logger.debug(\n        `No manifest found for ${basePath} so walking the directories for entry-points.`);\n    const entryPoints: EntryPoint[] = trackDuration(\n        () => this.walkDirectoryForPackages(basePath),\n        duration => this.logger.debug(`Walking ${basePath} for entry-points took ${duration}s.`));\n    this.entryPointManifest.writeEntryPointManifest(basePath, entryPoints);\n    return entryPoints;\n  }\n\n  /**\n   * Look for Angular packages that need to be compiled, starting at the source directory.\n   * The function will recurse into directories that start with `@...`, e.g. `@angular/...`.\n   *\n   * @param sourceDirectory An absolute path to the root directory where searching begins.\n   * @returns an array of `EntryPoint`s that were found within `sourceDirectory`.\n   */\n  walkDirectoryForPackages(sourceDirectory: AbsoluteFsPath): EntryPoint[] {\n    // Try to get a primary entry point from this directory\n    const primaryEntryPoint =\n        getEntryPointInfo(this.fs, this.config, this.logger, sourceDirectory, sourceDirectory);\n\n    // If there is an entry-point but it is not compatible with ngcc (it has a bad package.json or\n    // invalid typings) then exit. It is unlikely that such an entry point has a dependency on an\n    // Angular library.\n    if (primaryEntryPoint === INCOMPATIBLE_ENTRY_POINT) {\n      return [];\n    }\n\n    const entryPoints: EntryPoint[] = [];\n    if (primaryEntryPoint !== NO_ENTRY_POINT) {\n      entryPoints.push(primaryEntryPoint);\n      this.collectSecondaryEntryPoints(\n          entryPoints, sourceDirectory, sourceDirectory, this.fs.readdir(sourceDirectory));\n\n      // Also check for any nested node_modules in this package but only if at least one of the\n      // entry-points was compiled by Angular.\n      if (entryPoints.some(e => e.compiledByAngular)) {\n        const nestedNodeModulesPath = this.fs.join(sourceDirectory, 'node_modules');\n        if (this.fs.exists(nestedNodeModulesPath)) {\n          entryPoints.push(...this.walkDirectoryForPackages(nestedNodeModulesPath));\n        }\n      }\n\n      return entryPoints;\n    }\n\n    // The `sourceDirectory` was not a package (i.e. there was no package.json)\n    // So search its sub-directories for Angular packages and entry-points\n    for (const path of this.fs.readdir(sourceDirectory)) {\n      if (isIgnorablePath(path)) {\n        // Ignore hidden files, node_modules and ngcc directory\n        continue;\n      }\n\n      const absolutePath = this.fs.resolve(sourceDirectory, path);\n      const stat = this.fs.lstat(absolutePath);\n      if (stat.isSymbolicLink() || !stat.isDirectory()) {\n        // Ignore symbolic links and non-directories\n        continue;\n      }\n\n      entryPoints.push(...this.walkDirectoryForPackages(this.fs.join(sourceDirectory, path)));\n    }\n\n    return entryPoints;\n  }\n\n  /**\n   * Search the `directory` looking for any secondary entry-points for a package, adding any that\n   * are found to the `entryPoints` array.\n   *\n   * @param entryPoints An array where we will add any entry-points found in this directory\n   * @param packagePath The absolute path to the package that may contain entry-points\n   * @param directory The current directory being searched\n   * @param paths The paths contained in the current `directory`.\n   */\n  private collectSecondaryEntryPoints(\n      entryPoints: EntryPoint[], packagePath: AbsoluteFsPath, directory: AbsoluteFsPath,\n      paths: PathSegment[]): void {\n    for (const path of paths) {\n      if (isIgnorablePath(path)) {\n        // Ignore hidden files, node_modules and ngcc directory\n        continue;\n      }\n\n      const absolutePath = this.fs.resolve(directory, path);\n      const stat = this.fs.lstat(absolutePath);\n      if (stat.isSymbolicLink()) {\n        // Ignore symbolic links\n        continue;\n      }\n\n      const isDirectory = stat.isDirectory();\n      if (!path.endsWith('.js') && !isDirectory) {\n        // Ignore files that do not end in `.js`\n        continue;\n      }\n\n      // If the path is a JS file then strip its extension and see if we can match an\n      // entry-point.\n      const possibleEntryPointPath = isDirectory ? absolutePath : stripJsExtension(absolutePath);\n      let isEntryPoint = false;\n      const subEntryPoint =\n          getEntryPointInfo(this.fs, this.config, this.logger, packagePath, possibleEntryPointPath);\n      if (subEntryPoint !== NO_ENTRY_POINT && subEntryPoint !== INCOMPATIBLE_ENTRY_POINT) {\n        entryPoints.push(subEntryPoint);\n        isEntryPoint = true;\n      }\n\n      if (!isDirectory) {\n        // This path is not a directory so we are done.\n        continue;\n      }\n\n      // This directory may contain entry-points of its own.\n      const childPaths = this.fs.readdir(absolutePath);\n      if (!isEntryPoint &&\n          childPaths.some(\n              childPath => childPath.endsWith('.js') &&\n                  this.fs.stat(this.fs.resolve(absolutePath, childPath)).isFile())) {\n        // We do not consider non-entry-point directories that contain JS files as they are very\n        // unlikely to be containers for sub-entry-points.\n        continue;\n      }\n      this.collectSecondaryEntryPoints(entryPoints, packagePath, absolutePath, childPaths);\n    }\n  }\n}\n\nfunction stripJsExtension<T extends string>(filePath: T): T {\n  return filePath.replace(/\\.js$/, '') as T;\n}\n\nfunction isIgnorablePath(path: PathSegment): boolean {\n  return path.startsWith('.') || path === 'node_modules' || path === NGCC_DIRECTORY;\n}\n"]}
\No newline at end of file