source: trip-planner-front/node_modules/@angular/compiler-cli/ngcc/src/execution/analyze_entry_points.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: 30.1 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/execution/analyze_entry_points", ["require", "exports", "tslib", "@angular/compiler-cli/ngcc/src/execution/tasks/queues/parallel_task_queue", "@angular/compiler-cli/ngcc/src/execution/tasks/queues/serial_task_queue", "@angular/compiler-cli/ngcc/src/execution/tasks/utils", "@angular/compiler-cli/ngcc/src/packages/build_marker", "@angular/compiler-cli/ngcc/src/packages/entry_point", "@angular/compiler-cli/ngcc/src/writing/cleaning/package_cleaner", "@angular/compiler-cli/ngcc/src/execution/tasks/api"], factory);
8 }
9})(function (require, exports) {
10 "use strict";
11 Object.defineProperty(exports, "__esModule", { value: true });
12 exports.getAnalyzeEntryPointsFn = void 0;
13 var tslib_1 = require("tslib");
14 var parallel_task_queue_1 = require("@angular/compiler-cli/ngcc/src/execution/tasks/queues/parallel_task_queue");
15 var serial_task_queue_1 = require("@angular/compiler-cli/ngcc/src/execution/tasks/queues/serial_task_queue");
16 var utils_1 = require("@angular/compiler-cli/ngcc/src/execution/tasks/utils");
17 var build_marker_1 = require("@angular/compiler-cli/ngcc/src/packages/build_marker");
18 var entry_point_1 = require("@angular/compiler-cli/ngcc/src/packages/entry_point");
19 var package_cleaner_1 = require("@angular/compiler-cli/ngcc/src/writing/cleaning/package_cleaner");
20 var api_1 = require("@angular/compiler-cli/ngcc/src/execution/tasks/api");
21 /**
22 * Create the function for performing the analysis of the entry-points.
23 */
24 function getAnalyzeEntryPointsFn(logger, finder, fileSystem, supportedPropertiesToConsider, typingsOnly, compileAllFormats, propertiesToConsider, inParallel) {
25 return function () {
26 var e_1, _a, e_2, _b;
27 logger.debug('Analyzing entry-points...');
28 var startTime = Date.now();
29 var entryPointInfo = finder.findEntryPoints();
30 var cleaned = package_cleaner_1.cleanOutdatedPackages(fileSystem, entryPointInfo.entryPoints);
31 if (cleaned) {
32 // If we had to clean up one or more packages then we must read in the entry-points again.
33 entryPointInfo = finder.findEntryPoints();
34 }
35 var entryPoints = entryPointInfo.entryPoints, invalidEntryPoints = entryPointInfo.invalidEntryPoints, graph = entryPointInfo.graph;
36 logInvalidEntryPoints(logger, invalidEntryPoints);
37 var unprocessableEntryPointPaths = [];
38 // The tasks are partially ordered by virtue of the entry-points being partially ordered too.
39 var tasks = [];
40 try {
41 for (var entryPoints_1 = tslib_1.__values(entryPoints), entryPoints_1_1 = entryPoints_1.next(); !entryPoints_1_1.done; entryPoints_1_1 = entryPoints_1.next()) {
42 var entryPoint = entryPoints_1_1.value;
43 var packageJson = entryPoint.packageJson;
44 var _c = getPropertiesToProcess(packageJson, supportedPropertiesToConsider, compileAllFormats, typingsOnly), propertiesToProcess = _c.propertiesToProcess, equivalentPropertiesMap = _c.equivalentPropertiesMap;
45 if (propertiesToProcess.length === 0) {
46 // This entry-point is unprocessable (i.e. there is no format property that is of interest
47 // and can be processed). This will result in an error, but continue looping over
48 // entry-points in order to collect all unprocessable ones and display a more informative
49 // error.
50 unprocessableEntryPointPaths.push(entryPoint.path);
51 continue;
52 }
53 var hasProcessedTypings = build_marker_1.hasBeenProcessed(packageJson, 'typings');
54 if (hasProcessedTypings && typingsOnly) {
55 // Typings for this entry-point have already been processed and we're in typings-only mode,
56 // so no task has to be created for this entry-point.
57 logger.debug("Skipping " + entryPoint.name + " : typings have already been processed.");
58 continue;
59 }
60 var processDts = hasProcessedTypings ? api_1.DtsProcessing.No :
61 typingsOnly ? api_1.DtsProcessing.Only : api_1.DtsProcessing.Yes;
62 try {
63 for (var propertiesToProcess_1 = (e_2 = void 0, tslib_1.__values(propertiesToProcess)), propertiesToProcess_1_1 = propertiesToProcess_1.next(); !propertiesToProcess_1_1.done; propertiesToProcess_1_1 = propertiesToProcess_1.next()) {
64 var formatProperty = propertiesToProcess_1_1.value;
65 if (build_marker_1.hasBeenProcessed(entryPoint.packageJson, formatProperty)) {
66 // The format-path which the property maps to is already processed - nothing to do.
67 logger.debug("Skipping " + entryPoint.name + " : " + formatProperty + " (already compiled).");
68 continue;
69 }
70 var formatPropertiesToMarkAsProcessed = equivalentPropertiesMap.get(formatProperty);
71 tasks.push({ entryPoint: entryPoint, formatProperty: formatProperty, formatPropertiesToMarkAsProcessed: formatPropertiesToMarkAsProcessed, processDts: processDts });
72 // Only process typings for the first property (if not already processed).
73 processDts = api_1.DtsProcessing.No;
74 }
75 }
76 catch (e_2_1) { e_2 = { error: e_2_1 }; }
77 finally {
78 try {
79 if (propertiesToProcess_1_1 && !propertiesToProcess_1_1.done && (_b = propertiesToProcess_1.return)) _b.call(propertiesToProcess_1);
80 }
81 finally { if (e_2) throw e_2.error; }
82 }
83 }
84 }
85 catch (e_1_1) { e_1 = { error: e_1_1 }; }
86 finally {
87 try {
88 if (entryPoints_1_1 && !entryPoints_1_1.done && (_a = entryPoints_1.return)) _a.call(entryPoints_1);
89 }
90 finally { if (e_1) throw e_1.error; }
91 }
92 // Check for entry-points for which we could not process any format at all.
93 if (unprocessableEntryPointPaths.length > 0) {
94 throw new Error('Unable to process any formats for the following entry-points (tried ' +
95 (propertiesToConsider.join(', ') + "): ") +
96 unprocessableEntryPointPaths.map(function (path) { return "\n - " + path; }).join(''));
97 }
98 var duration = Math.round((Date.now() - startTime) / 100) / 10;
99 logger.debug("Analyzed " + entryPoints.length + " entry-points in " + duration + "s. " +
100 ("(Total tasks: " + tasks.length + ")"));
101 return getTaskQueue(logger, inParallel, tasks, graph);
102 };
103 }
104 exports.getAnalyzeEntryPointsFn = getAnalyzeEntryPointsFn;
105 function logInvalidEntryPoints(logger, invalidEntryPoints) {
106 invalidEntryPoints.forEach(function (invalidEntryPoint) {
107 logger.debug("Invalid entry-point " + invalidEntryPoint.entryPoint.path + ".", "It is missing required dependencies:\n" +
108 invalidEntryPoint.missingDependencies.map(function (dep) { return " - " + dep; }).join('\n'));
109 });
110 }
111 /**
112 * This function computes and returns the following:
113 * - `propertiesToProcess`: An (ordered) list of properties that exist and need to be processed,
114 * based on the provided `propertiesToConsider`, the properties in `package.json` and their
115 * corresponding format-paths. NOTE: Only one property per format-path needs to be processed.
116 * - `equivalentPropertiesMap`: A mapping from each property in `propertiesToProcess` to the list of
117 * other format properties in `package.json` that need to be marked as processed as soon as the
118 * former has been processed.
119 */
120 function getPropertiesToProcess(packageJson, propertiesToConsider, compileAllFormats, typingsOnly) {
121 var e_3, _a, e_4, _b, e_5, _c;
122 var formatPathsToConsider = new Set();
123 var propertiesToProcess = [];
124 try {
125 for (var propertiesToConsider_1 = tslib_1.__values(propertiesToConsider), propertiesToConsider_1_1 = propertiesToConsider_1.next(); !propertiesToConsider_1_1.done; propertiesToConsider_1_1 = propertiesToConsider_1.next()) {
126 var prop = propertiesToConsider_1_1.value;
127 var formatPath = packageJson[prop];
128 // Ignore properties that are not defined in `package.json`.
129 if (typeof formatPath !== 'string')
130 continue;
131 // Ignore properties that map to the same format-path as a preceding property.
132 if (formatPathsToConsider.has(formatPath))
133 continue;
134 // Process this property, because it is the first one to map to this format-path.
135 formatPathsToConsider.add(formatPath);
136 propertiesToProcess.push(prop);
137 // If we only need one format processed, there is no need to process any more properties.
138 if (!compileAllFormats)
139 break;
140 }
141 }
142 catch (e_3_1) { e_3 = { error: e_3_1 }; }
143 finally {
144 try {
145 if (propertiesToConsider_1_1 && !propertiesToConsider_1_1.done && (_a = propertiesToConsider_1.return)) _a.call(propertiesToConsider_1);
146 }
147 finally { if (e_3) throw e_3.error; }
148 }
149 var formatPathToProperties = {};
150 try {
151 for (var SUPPORTED_FORMAT_PROPERTIES_1 = tslib_1.__values(entry_point_1.SUPPORTED_FORMAT_PROPERTIES), SUPPORTED_FORMAT_PROPERTIES_1_1 = SUPPORTED_FORMAT_PROPERTIES_1.next(); !SUPPORTED_FORMAT_PROPERTIES_1_1.done; SUPPORTED_FORMAT_PROPERTIES_1_1 = SUPPORTED_FORMAT_PROPERTIES_1.next()) {
152 var prop = SUPPORTED_FORMAT_PROPERTIES_1_1.value;
153 var formatPath = packageJson[prop];
154 // Ignore properties that are not defined in `package.json`.
155 if (typeof formatPath !== 'string')
156 continue;
157 // Ignore properties that do not map to a format-path that will be considered.
158 if (!formatPathsToConsider.has(formatPath))
159 continue;
160 // Add this property to the map.
161 var list = formatPathToProperties[formatPath] || (formatPathToProperties[formatPath] = []);
162 list.push(prop);
163 }
164 }
165 catch (e_4_1) { e_4 = { error: e_4_1 }; }
166 finally {
167 try {
168 if (SUPPORTED_FORMAT_PROPERTIES_1_1 && !SUPPORTED_FORMAT_PROPERTIES_1_1.done && (_b = SUPPORTED_FORMAT_PROPERTIES_1.return)) _b.call(SUPPORTED_FORMAT_PROPERTIES_1);
169 }
170 finally { if (e_4) throw e_4.error; }
171 }
172 var equivalentPropertiesMap = new Map();
173 try {
174 for (var propertiesToConsider_2 = tslib_1.__values(propertiesToConsider), propertiesToConsider_2_1 = propertiesToConsider_2.next(); !propertiesToConsider_2_1.done; propertiesToConsider_2_1 = propertiesToConsider_2.next()) {
175 var prop = propertiesToConsider_2_1.value;
176 var formatPath = packageJson[prop];
177 // If we are only processing typings then there should be no format properties to mark
178 var equivalentProperties = typingsOnly ? [] : formatPathToProperties[formatPath];
179 equivalentPropertiesMap.set(prop, equivalentProperties);
180 }
181 }
182 catch (e_5_1) { e_5 = { error: e_5_1 }; }
183 finally {
184 try {
185 if (propertiesToConsider_2_1 && !propertiesToConsider_2_1.done && (_c = propertiesToConsider_2.return)) _c.call(propertiesToConsider_2);
186 }
187 finally { if (e_5) throw e_5.error; }
188 }
189 return { propertiesToProcess: propertiesToProcess, equivalentPropertiesMap: equivalentPropertiesMap };
190 }
191 function getTaskQueue(logger, inParallel, tasks, graph) {
192 var dependencies = utils_1.computeTaskDependencies(tasks, graph);
193 return inParallel ? new parallel_task_queue_1.ParallelTaskQueue(logger, tasks, dependencies) :
194 new serial_task_queue_1.SerialTaskQueue(logger, tasks, dependencies);
195 }
196});
197//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"analyze_entry_points.js","sourceRoot":"","sources":["../../../../../../../../packages/compiler-cli/ngcc/src/execution/analyze_entry_points.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 {DepGraph} from 'dependency-graph';\n\nimport {FileSystem} from '../../../src/ngtsc/file_system';\nimport {Logger} from '../../../src/ngtsc/logging';\nimport {InvalidEntryPoint} from '../dependencies/dependency_resolver';\nimport {EntryPointFinder} from '../entry_point_finder/interface';\nimport {ParallelTaskQueue} from '../execution/tasks/queues/parallel_task_queue';\nimport {SerialTaskQueue} from '../execution/tasks/queues/serial_task_queue';\nimport {computeTaskDependencies} from '../execution/tasks/utils';\nimport {hasBeenProcessed} from '../packages/build_marker';\nimport {EntryPoint, EntryPointJsonProperty, EntryPointPackageJson, SUPPORTED_FORMAT_PROPERTIES} from '../packages/entry_point';\nimport {cleanOutdatedPackages} from '../writing/cleaning/package_cleaner';\n\nimport {AnalyzeEntryPointsFn} from './api';\nimport {DtsProcessing, PartiallyOrderedTasks, TaskQueue} from './tasks/api';\n\n/**\n * Create the function for performing the analysis of the entry-points.\n */\nexport function getAnalyzeEntryPointsFn(\n    logger: Logger, finder: EntryPointFinder, fileSystem: FileSystem,\n    supportedPropertiesToConsider: EntryPointJsonProperty[], typingsOnly: boolean,\n    compileAllFormats: boolean, propertiesToConsider: string[],\n    inParallel: boolean): AnalyzeEntryPointsFn {\n  return () => {\n    logger.debug('Analyzing entry-points...');\n    const startTime = Date.now();\n\n    let entryPointInfo = finder.findEntryPoints();\n    const cleaned = cleanOutdatedPackages(fileSystem, entryPointInfo.entryPoints);\n    if (cleaned) {\n      // If we had to clean up one or more packages then we must read in the entry-points again.\n      entryPointInfo = finder.findEntryPoints();\n    }\n\n    const {entryPoints, invalidEntryPoints, graph} = entryPointInfo;\n    logInvalidEntryPoints(logger, invalidEntryPoints);\n\n    const unprocessableEntryPointPaths: string[] = [];\n    // The tasks are partially ordered by virtue of the entry-points being partially ordered too.\n    const tasks: PartiallyOrderedTasks = [] as any;\n\n    for (const entryPoint of entryPoints) {\n      const packageJson = entryPoint.packageJson;\n      const {propertiesToProcess, equivalentPropertiesMap} = getPropertiesToProcess(\n          packageJson, supportedPropertiesToConsider, compileAllFormats, typingsOnly);\n\n      if (propertiesToProcess.length === 0) {\n        // This entry-point is unprocessable (i.e. there is no format property that is of interest\n        // and can be processed). This will result in an error, but continue looping over\n        // entry-points in order to collect all unprocessable ones and display a more informative\n        // error.\n        unprocessableEntryPointPaths.push(entryPoint.path);\n        continue;\n      }\n\n      const hasProcessedTypings = hasBeenProcessed(packageJson, 'typings');\n      if (hasProcessedTypings && typingsOnly) {\n        // Typings for this entry-point have already been processed and we're in typings-only mode,\n        // so no task has to be created for this entry-point.\n        logger.debug(`Skipping ${entryPoint.name} : typings have already been processed.`);\n        continue;\n      }\n      let processDts = hasProcessedTypings ? DtsProcessing.No :\n                                             typingsOnly ? DtsProcessing.Only : DtsProcessing.Yes;\n\n      for (const formatProperty of propertiesToProcess) {\n        if (hasBeenProcessed(entryPoint.packageJson, formatProperty)) {\n          // The format-path which the property maps to is already processed - nothing to do.\n          logger.debug(`Skipping ${entryPoint.name} : ${formatProperty} (already compiled).`);\n          continue;\n        }\n\n        const formatPropertiesToMarkAsProcessed = equivalentPropertiesMap.get(formatProperty)!;\n        tasks.push({entryPoint, formatProperty, formatPropertiesToMarkAsProcessed, processDts});\n\n        // Only process typings for the first property (if not already processed).\n        processDts = DtsProcessing.No;\n      }\n    }\n\n    // Check for entry-points for which we could not process any format at all.\n    if (unprocessableEntryPointPaths.length > 0) {\n      throw new Error(\n          'Unable to process any formats for the following entry-points (tried ' +\n          `${propertiesToConsider.join(', ')}): ` +\n          unprocessableEntryPointPaths.map(path => `\\n  - ${path}`).join(''));\n    }\n\n    const duration = Math.round((Date.now() - startTime) / 100) / 10;\n    logger.debug(\n        `Analyzed ${entryPoints.length} entry-points in ${duration}s. ` +\n        `(Total tasks: ${tasks.length})`);\n\n    return getTaskQueue(logger, inParallel, tasks, graph);\n  };\n}\n\nfunction logInvalidEntryPoints(logger: Logger, invalidEntryPoints: InvalidEntryPoint[]): void {\n  invalidEntryPoints.forEach(invalidEntryPoint => {\n    logger.debug(\n        `Invalid entry-point ${invalidEntryPoint.entryPoint.path}.`,\n        `It is missing required dependencies:\\n` +\n            invalidEntryPoint.missingDependencies.map(dep => ` - ${dep}`).join('\\n'));\n  });\n}\n\n/**\n * This function computes and returns the following:\n * - `propertiesToProcess`: An (ordered) list of properties that exist and need to be processed,\n *   based on the provided `propertiesToConsider`, the properties in `package.json` and their\n *   corresponding format-paths. NOTE: Only one property per format-path needs to be processed.\n * - `equivalentPropertiesMap`: A mapping from each property in `propertiesToProcess` to the list of\n *   other format properties in `package.json` that need to be marked as processed as soon as the\n *   former has been processed.\n */\nfunction getPropertiesToProcess(\n    packageJson: EntryPointPackageJson, propertiesToConsider: EntryPointJsonProperty[],\n    compileAllFormats: boolean, typingsOnly: boolean): {\n  propertiesToProcess: EntryPointJsonProperty[];\n  equivalentPropertiesMap: Map<EntryPointJsonProperty, EntryPointJsonProperty[]>;\n} {\n  const formatPathsToConsider = new Set<string>();\n\n  const propertiesToProcess: EntryPointJsonProperty[] = [];\n  for (const prop of propertiesToConsider) {\n    const formatPath = packageJson[prop];\n\n    // Ignore properties that are not defined in `package.json`.\n    if (typeof formatPath !== 'string') continue;\n\n    // Ignore properties that map to the same format-path as a preceding property.\n    if (formatPathsToConsider.has(formatPath)) continue;\n\n    // Process this property, because it is the first one to map to this format-path.\n    formatPathsToConsider.add(formatPath);\n    propertiesToProcess.push(prop);\n\n    // If we only need one format processed, there is no need to process any more properties.\n    if (!compileAllFormats) break;\n  }\n\n  const formatPathToProperties: {[formatPath: string]: EntryPointJsonProperty[]} = {};\n  for (const prop of SUPPORTED_FORMAT_PROPERTIES) {\n    const formatPath = packageJson[prop];\n\n    // Ignore properties that are not defined in `package.json`.\n    if (typeof formatPath !== 'string') continue;\n\n    // Ignore properties that do not map to a format-path that will be considered.\n    if (!formatPathsToConsider.has(formatPath)) continue;\n\n    // Add this property to the map.\n    const list = formatPathToProperties[formatPath] || (formatPathToProperties[formatPath] = []);\n    list.push(prop);\n  }\n\n  const equivalentPropertiesMap = new Map<EntryPointJsonProperty, EntryPointJsonProperty[]>();\n  for (const prop of propertiesToConsider) {\n    const formatPath = packageJson[prop]!;\n    // If we are only processing typings then there should be no format properties to mark\n    const equivalentProperties = typingsOnly ? [] : formatPathToProperties[formatPath];\n    equivalentPropertiesMap.set(prop, equivalentProperties);\n  }\n\n  return {propertiesToProcess, equivalentPropertiesMap};\n}\n\nfunction getTaskQueue(\n    logger: Logger, inParallel: boolean, tasks: PartiallyOrderedTasks,\n    graph: DepGraph<EntryPoint>): TaskQueue {\n  const dependencies = computeTaskDependencies(tasks, graph);\n  return inParallel ? new ParallelTaskQueue(logger, tasks, dependencies) :\n                      new SerialTaskQueue(logger, tasks, dependencies);\n}\n"]}
Note: See TracBrowser for help on using the repository browser.