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/dependencies/dependency_host", ["require", "exports", "tslib", "@angular/compiler-cli/ngcc/src/utils", "@angular/compiler-cli/ngcc/src/dependencies/module_resolver"], factory);
|
---|
8 | }
|
---|
9 | })(function (require, exports) {
|
---|
10 | "use strict";
|
---|
11 | Object.defineProperty(exports, "__esModule", { value: true });
|
---|
12 | exports.DependencyHostBase = exports.createDependencyInfo = void 0;
|
---|
13 | var tslib_1 = require("tslib");
|
---|
14 | var utils_1 = require("@angular/compiler-cli/ngcc/src/utils");
|
---|
15 | var module_resolver_1 = require("@angular/compiler-cli/ngcc/src/dependencies/module_resolver");
|
---|
16 | function createDependencyInfo() {
|
---|
17 | return { dependencies: new Set(), missing: new Set(), deepImports: new Set() };
|
---|
18 | }
|
---|
19 | exports.createDependencyInfo = createDependencyInfo;
|
---|
20 | var DependencyHostBase = /** @class */ (function () {
|
---|
21 | function DependencyHostBase(fs, moduleResolver) {
|
---|
22 | this.fs = fs;
|
---|
23 | this.moduleResolver = moduleResolver;
|
---|
24 | }
|
---|
25 | /**
|
---|
26 | * Find all the dependencies for the entry-point at the given path.
|
---|
27 | *
|
---|
28 | * @param entryPointPath The absolute path to the JavaScript file that represents an entry-point.
|
---|
29 | * @param dependencyInfo An object containing information about the dependencies of the
|
---|
30 | * entry-point, including those that were missing or deep imports into other entry-points. The
|
---|
31 | * sets in this object will be updated with new information about the entry-point's dependencies.
|
---|
32 | */
|
---|
33 | DependencyHostBase.prototype.collectDependencies = function (entryPointPath, _a) {
|
---|
34 | var dependencies = _a.dependencies, missing = _a.missing, deepImports = _a.deepImports;
|
---|
35 | var resolvedFile = utils_1.resolveFileWithPostfixes(this.fs, entryPointPath, this.moduleResolver.relativeExtensions);
|
---|
36 | if (resolvedFile !== null) {
|
---|
37 | var alreadySeen = new Set();
|
---|
38 | this.recursivelyCollectDependencies(resolvedFile, dependencies, missing, deepImports, alreadySeen);
|
---|
39 | }
|
---|
40 | };
|
---|
41 | /**
|
---|
42 | * Find all the dependencies for the provided paths.
|
---|
43 | *
|
---|
44 | * @param files The list of absolute paths of JavaScript files to scan for dependencies.
|
---|
45 | * @param dependencyInfo An object containing information about the dependencies of the
|
---|
46 | * entry-point, including those that were missing or deep imports into other entry-points. The
|
---|
47 | * sets in this object will be updated with new information about the entry-point's dependencies.
|
---|
48 | */
|
---|
49 | DependencyHostBase.prototype.collectDependenciesInFiles = function (files, _a) {
|
---|
50 | var e_1, _b;
|
---|
51 | var dependencies = _a.dependencies, missing = _a.missing, deepImports = _a.deepImports;
|
---|
52 | var alreadySeen = new Set();
|
---|
53 | try {
|
---|
54 | for (var files_1 = tslib_1.__values(files), files_1_1 = files_1.next(); !files_1_1.done; files_1_1 = files_1.next()) {
|
---|
55 | var file = files_1_1.value;
|
---|
56 | this.processFile(file, dependencies, missing, deepImports, alreadySeen);
|
---|
57 | }
|
---|
58 | }
|
---|
59 | catch (e_1_1) { e_1 = { error: e_1_1 }; }
|
---|
60 | finally {
|
---|
61 | try {
|
---|
62 | if (files_1_1 && !files_1_1.done && (_b = files_1.return)) _b.call(files_1);
|
---|
63 | }
|
---|
64 | finally { if (e_1) throw e_1.error; }
|
---|
65 | }
|
---|
66 | };
|
---|
67 | /**
|
---|
68 | * Compute the dependencies of the given file.
|
---|
69 | *
|
---|
70 | * @param file An absolute path to the file whose dependencies we want to get.
|
---|
71 | * @param dependencies A set that will have the absolute paths of resolved entry points added to
|
---|
72 | * it.
|
---|
73 | * @param missing A set that will have the dependencies that could not be found added to it.
|
---|
74 | * @param deepImports A set that will have the import paths that exist but cannot be mapped to
|
---|
75 | * entry-points, i.e. deep-imports.
|
---|
76 | * @param alreadySeen A set that is used to track internal dependencies to prevent getting stuck
|
---|
77 | * in a circular dependency loop.
|
---|
78 | */
|
---|
79 | DependencyHostBase.prototype.recursivelyCollectDependencies = function (file, dependencies, missing, deepImports, alreadySeen) {
|
---|
80 | var e_2, _a;
|
---|
81 | var fromContents = this.fs.readFile(file);
|
---|
82 | if (this.canSkipFile(fromContents)) {
|
---|
83 | return;
|
---|
84 | }
|
---|
85 | var imports = this.extractImports(file, fromContents);
|
---|
86 | try {
|
---|
87 | for (var imports_1 = tslib_1.__values(imports), imports_1_1 = imports_1.next(); !imports_1_1.done; imports_1_1 = imports_1.next()) {
|
---|
88 | var importPath = imports_1_1.value;
|
---|
89 | var resolved = this.processImport(importPath, file, dependencies, missing, deepImports, alreadySeen);
|
---|
90 | if (!resolved) {
|
---|
91 | missing.add(importPath);
|
---|
92 | }
|
---|
93 | }
|
---|
94 | }
|
---|
95 | catch (e_2_1) { e_2 = { error: e_2_1 }; }
|
---|
96 | finally {
|
---|
97 | try {
|
---|
98 | if (imports_1_1 && !imports_1_1.done && (_a = imports_1.return)) _a.call(imports_1);
|
---|
99 | }
|
---|
100 | finally { if (e_2) throw e_2.error; }
|
---|
101 | }
|
---|
102 | };
|
---|
103 | /**
|
---|
104 | * Resolve the given `importPath` from `file` and add it to the appropriate set.
|
---|
105 | *
|
---|
106 | * If the import is local to this package then follow it by calling
|
---|
107 | * `recursivelyCollectDependencies()`.
|
---|
108 | *
|
---|
109 | * @returns `true` if the import was resolved (to an entry-point, a local import, or a
|
---|
110 | * deep-import), `false` otherwise.
|
---|
111 | */
|
---|
112 | DependencyHostBase.prototype.processImport = function (importPath, file, dependencies, missing, deepImports, alreadySeen) {
|
---|
113 | var resolvedModule = this.moduleResolver.resolveModuleImport(importPath, file);
|
---|
114 | if (resolvedModule === null) {
|
---|
115 | return false;
|
---|
116 | }
|
---|
117 | if (resolvedModule instanceof module_resolver_1.ResolvedRelativeModule) {
|
---|
118 | this.processFile(resolvedModule.modulePath, dependencies, missing, deepImports, alreadySeen);
|
---|
119 | }
|
---|
120 | else if (resolvedModule instanceof module_resolver_1.ResolvedDeepImport) {
|
---|
121 | deepImports.add(resolvedModule.importPath);
|
---|
122 | }
|
---|
123 | else {
|
---|
124 | dependencies.add(resolvedModule.entryPointPath);
|
---|
125 | }
|
---|
126 | return true;
|
---|
127 | };
|
---|
128 | /**
|
---|
129 | * Processes the file if it has not already been seen. This will also recursively process
|
---|
130 | * all files that are imported from the file, while taking the set of already seen files
|
---|
131 | * into account.
|
---|
132 | */
|
---|
133 | DependencyHostBase.prototype.processFile = function (file, dependencies, missing, deepImports, alreadySeen) {
|
---|
134 | if (!alreadySeen.has(file)) {
|
---|
135 | alreadySeen.add(file);
|
---|
136 | this.recursivelyCollectDependencies(file, dependencies, missing, deepImports, alreadySeen);
|
---|
137 | }
|
---|
138 | };
|
---|
139 | return DependencyHostBase;
|
---|
140 | }());
|
---|
141 | exports.DependencyHostBase = DependencyHostBase;
|
---|
142 | });
|
---|
143 | //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"dependency_host.js","sourceRoot":"","sources":["../../../../../../../../packages/compiler-cli/ngcc/src/dependencies/dependency_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 {AbsoluteFsPath, PathSegment, ReadonlyFileSystem} from '../../../src/ngtsc/file_system';\nimport {EntryPoint} from '../packages/entry_point';\nimport {resolveFileWithPostfixes} from '../utils';\n\nimport {ModuleResolver, ResolvedDeepImport, ResolvedRelativeModule} from './module_resolver';\n\nexport interface DependencyHost {\n  collectDependencies(\n      entryPointPath: AbsoluteFsPath, {dependencies, missing, deepImports}: DependencyInfo): void;\n}\n\nexport interface DependencyInfo {\n  dependencies: Set<AbsoluteFsPath>;\n  missing: Set<AbsoluteFsPath|PathSegment>;\n  deepImports: Set<AbsoluteFsPath>;\n}\n\nexport interface EntryPointWithDependencies {\n  entryPoint: EntryPoint;\n  depInfo: DependencyInfo;\n}\n\nexport function createDependencyInfo(): DependencyInfo {\n  return {dependencies: new Set(), missing: new Set(), deepImports: new Set()};\n}\n\nexport abstract class DependencyHostBase implements DependencyHost {\n  constructor(protected fs: ReadonlyFileSystem, protected moduleResolver: ModuleResolver) {}\n\n  /**\n   * Find all the dependencies for the entry-point at the given path.\n   *\n   * @param entryPointPath The absolute path to the JavaScript file that represents an entry-point.\n   * @param dependencyInfo An object containing information about the dependencies of the\n   * entry-point, including those that were missing or deep imports into other entry-points. The\n   * sets in this object will be updated with new information about the entry-point's dependencies.\n   */\n  collectDependencies(\n      entryPointPath: AbsoluteFsPath, {dependencies, missing, deepImports}: DependencyInfo): void {\n    const resolvedFile =\n        resolveFileWithPostfixes(this.fs, entryPointPath, this.moduleResolver.relativeExtensions);\n    if (resolvedFile !== null) {\n      const alreadySeen = new Set<AbsoluteFsPath>();\n      this.recursivelyCollectDependencies(\n          resolvedFile, dependencies, missing, deepImports, alreadySeen);\n    }\n  }\n\n  /**\n   * Find all the dependencies for the provided paths.\n   *\n   * @param files The list of absolute paths of JavaScript files to scan for dependencies.\n   * @param dependencyInfo An object containing information about the dependencies of the\n   * entry-point, including those that were missing or deep imports into other entry-points. The\n   * sets in this object will be updated with new information about the entry-point's dependencies.\n   */\n  collectDependenciesInFiles(\n      files: AbsoluteFsPath[], {dependencies, missing, deepImports}: DependencyInfo): void {\n    const alreadySeen = new Set<AbsoluteFsPath>();\n    for (const file of files) {\n      this.processFile(file, dependencies, missing, deepImports, alreadySeen);\n    }\n  }\n\n  /**\n   * Compute the dependencies of the given file.\n   *\n   * @param file An absolute path to the file whose dependencies we want to get.\n   * @param dependencies A set that will have the absolute paths of resolved entry points added to\n   * it.\n   * @param missing A set that will have the dependencies that could not be found added to it.\n   * @param deepImports A set that will have the import paths that exist but cannot be mapped to\n   * entry-points, i.e. deep-imports.\n   * @param alreadySeen A set that is used to track internal dependencies to prevent getting stuck\n   * in a circular dependency loop.\n   */\n  protected recursivelyCollectDependencies(\n      file: AbsoluteFsPath, dependencies: Set<AbsoluteFsPath>, missing: Set<string>,\n      deepImports: Set<string>, alreadySeen: Set<AbsoluteFsPath>): void {\n    const fromContents = this.fs.readFile(file);\n    if (this.canSkipFile(fromContents)) {\n      return;\n    }\n    const imports = this.extractImports(file, fromContents);\n    for (const importPath of imports) {\n      const resolved =\n          this.processImport(importPath, file, dependencies, missing, deepImports, alreadySeen);\n      if (!resolved) {\n        missing.add(importPath);\n      }\n    }\n  }\n\n  protected abstract canSkipFile(fileContents: string): boolean;\n  protected abstract extractImports(file: AbsoluteFsPath, fileContents: string): Set<string>;\n\n  /**\n   * Resolve the given `importPath` from `file` and add it to the appropriate set.\n   *\n   * If the import is local to this package then follow it by calling\n   * `recursivelyCollectDependencies()`.\n   *\n   * @returns `true` if the import was resolved (to an entry-point, a local import, or a\n   * deep-import), `false` otherwise.\n   */\n  protected processImport(\n      importPath: string, file: AbsoluteFsPath, dependencies: Set<AbsoluteFsPath>,\n      missing: Set<string>, deepImports: Set<string>, alreadySeen: Set<AbsoluteFsPath>): boolean {\n    const resolvedModule = this.moduleResolver.resolveModuleImport(importPath, file);\n    if (resolvedModule === null) {\n      return false;\n    }\n    if (resolvedModule instanceof ResolvedRelativeModule) {\n      this.processFile(resolvedModule.modulePath, dependencies, missing, deepImports, alreadySeen);\n    } else if (resolvedModule instanceof ResolvedDeepImport) {\n      deepImports.add(resolvedModule.importPath);\n    } else {\n      dependencies.add(resolvedModule.entryPointPath);\n    }\n    return true;\n  }\n\n  /**\n   * Processes the file if it has not already been seen. This will also recursively process\n   * all files that are imported from the file, while taking the set of already seen files\n   * into account.\n   */\n  protected processFile(\n      file: AbsoluteFsPath, dependencies: Set<AbsoluteFsPath>, missing: Set<string>,\n      deepImports: Set<string>, alreadySeen: Set<AbsoluteFsPath>): void {\n    if (!alreadySeen.has(file)) {\n      alreadySeen.add(file);\n      this.recursivelyCollectDependencies(file, dependencies, missing, deepImports, alreadySeen);\n    }\n  }\n}\n"]} |
---|