@angular/compiler-cli 9.1.3 → 9.1.7
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/ngcc/index.d.ts +2 -1
- package/ngcc/index.js +1 -1
- package/ngcc/src/analysis/module_with_providers_analyzer.d.ts +35 -9
- package/ngcc/src/analysis/module_with_providers_analyzer.js +101 -16
- package/ngcc/src/dependencies/dts_dependency_host.d.ts +1 -1
- package/ngcc/src/dependencies/dts_dependency_host.js +1 -1
- package/ngcc/src/dependencies/module_resolver.d.ts +1 -1
- package/ngcc/src/dependencies/module_resolver.js +1 -1
- package/ngcc/src/entry_point_finder/directory_walker_entry_point_finder.d.ts +1 -1
- package/ngcc/src/entry_point_finder/directory_walker_entry_point_finder.js +1 -1
- package/ngcc/src/entry_point_finder/targeted_entry_point_finder.d.ts +15 -8
- package/ngcc/src/entry_point_finder/targeted_entry_point_finder.js +86 -54
- package/ngcc/src/entry_point_finder/utils.d.ts +10 -1
- package/ngcc/src/entry_point_finder/utils.js +78 -28
- package/ngcc/src/execution/api.d.ts +3 -2
- package/ngcc/src/execution/api.js +1 -1
- package/ngcc/src/execution/cluster/api.d.ts +6 -1
- package/ngcc/src/execution/cluster/api.js +1 -1
- package/ngcc/src/execution/cluster/executor.d.ts +3 -1
- package/ngcc/src/execution/cluster/executor.js +4 -3
- package/ngcc/src/execution/cluster/master.d.ts +6 -1
- package/ngcc/src/execution/cluster/master.js +63 -19
- package/ngcc/src/execution/cluster/utils.d.ts +4 -2
- package/ngcc/src/execution/cluster/utils.js +13 -7
- package/ngcc/src/execution/cluster/worker.js +59 -29
- package/ngcc/src/execution/create_compile_function.d.ts +3 -3
- package/ngcc/src/execution/create_compile_function.js +14 -16
- package/ngcc/src/execution/single_process_executor.js +3 -3
- package/ngcc/src/execution/tasks/api.d.ts +10 -1
- package/ngcc/src/execution/tasks/api.js +1 -1
- package/ngcc/src/execution/tasks/queues/base_task_queue.d.ts +2 -1
- package/ngcc/src/execution/tasks/queues/base_task_queue.js +11 -4
- package/ngcc/src/execution/tasks/queues/parallel_task_queue.d.ts +1 -1
- package/ngcc/src/execution/tasks/queues/parallel_task_queue.js +3 -3
- package/ngcc/src/host/commonjs_host.js +6 -3
- package/ngcc/src/host/delegating_host.d.ts +1 -2
- package/ngcc/src/host/delegating_host.js +1 -4
- package/ngcc/src/host/esm2015_host.d.ts +96 -24
- package/ngcc/src/host/esm2015_host.js +320 -110
- package/ngcc/src/host/esm5_host.d.ts +0 -14
- package/ngcc/src/host/esm5_host.js +3 -35
- package/ngcc/src/host/ngcc_host.d.ts +1 -32
- package/ngcc/src/host/ngcc_host.js +1 -1
- package/ngcc/src/host/umd_host.js +14 -5
- package/ngcc/src/host/utils.d.ts +10 -0
- package/ngcc/src/host/utils.js +25 -0
- package/ngcc/src/main.js +13 -10
- package/ngcc/src/ngcc_options.d.ts +4 -10
- package/ngcc/src/ngcc_options.js +10 -18
- package/ngcc/src/packages/build_marker.d.ts +1 -1
- package/ngcc/src/packages/build_marker.js +1 -1
- package/ngcc/src/packages/entry_point_bundle.d.ts +1 -1
- package/ngcc/src/packages/entry_point_bundle.js +1 -1
- package/ngcc/src/packages/transformer.js +2 -2
- package/ngcc/src/path_mappings.d.ts +20 -0
- package/ngcc/src/path_mappings.js +34 -0
- package/ngcc/src/rendering/esm_rendering_formatter.js +2 -2
- package/ngcc/src/writing/file_writer.d.ts +13 -1
- package/ngcc/src/writing/file_writer.js +1 -1
- package/ngcc/src/writing/in_place_file_writer.d.ts +4 -2
- package/ngcc/src/writing/in_place_file_writer.js +28 -2
- package/ngcc/src/writing/new_entry_point_file_writer.d.ts +3 -0
- package/ngcc/src/writing/new_entry_point_file_writer.js +69 -4
- package/package.json +2 -2
- package/src/ngtsc/partial_evaluator/src/interpreter.d.ts +1 -0
- package/src/ngtsc/partial_evaluator/src/interpreter.js +25 -1
- package/src/ngtsc/partial_evaluator/src/result.d.ts +2 -2
- package/src/ngtsc/partial_evaluator/src/result.js +1 -1
- package/src/ngtsc/reflection/src/host.d.ts +32 -0
- package/src/ngtsc/reflection/src/host.js +1 -1
- package/src/ngtsc/reflection/src/typescript.js +3 -1
- package/src/ngtsc/typecheck/src/expression.js +18 -5
- package/src/ngtsc/typecheck/src/type_check_block.js +4 -2
- package/src/version.js +1 -1
|
@@ -12,7 +12,7 @@
|
|
|
12
12
|
if (v !== undefined) module.exports = v;
|
|
13
13
|
}
|
|
14
14
|
else if (typeof define === "function" && define.amd) {
|
|
15
|
-
define("@angular/compiler-cli/ngcc/src/execution/cluster/worker", ["require", "exports", "tslib", "cluster", "@angular/compiler-cli/ngcc/src/command_line_options", "@angular/compiler-cli/ngcc/src/
|
|
15
|
+
define("@angular/compiler-cli/ngcc/src/execution/cluster/worker", ["require", "exports", "tslib", "cluster", "@angular/compiler-cli/ngcc/src/command_line_options", "@angular/compiler-cli/ngcc/src/ngcc_options", "@angular/compiler-cli/ngcc/src/execution/create_compile_function", "@angular/compiler-cli/ngcc/src/execution/tasks/utils", "@angular/compiler-cli/ngcc/src/execution/cluster/package_json_updater", "@angular/compiler-cli/ngcc/src/execution/cluster/utils"], factory);
|
|
16
16
|
}
|
|
17
17
|
})(function (require, exports) {
|
|
18
18
|
"use strict";
|
|
@@ -20,8 +20,6 @@
|
|
|
20
20
|
var tslib_1 = require("tslib");
|
|
21
21
|
var cluster = require("cluster");
|
|
22
22
|
var command_line_options_1 = require("@angular/compiler-cli/ngcc/src/command_line_options");
|
|
23
|
-
var console_logger_1 = require("@angular/compiler-cli/ngcc/src/logging/console_logger");
|
|
24
|
-
var logger_1 = require("@angular/compiler-cli/ngcc/src/logging/logger");
|
|
25
23
|
var ngcc_options_1 = require("@angular/compiler-cli/ngcc/src/ngcc_options");
|
|
26
24
|
var create_compile_function_1 = require("@angular/compiler-cli/ngcc/src/execution/create_compile_function");
|
|
27
25
|
var utils_1 = require("@angular/compiler-cli/ngcc/src/execution/tasks/utils");
|
|
@@ -30,24 +28,25 @@
|
|
|
30
28
|
// Cluster worker entry point
|
|
31
29
|
if (require.main === module) {
|
|
32
30
|
(function () { return tslib_1.__awaiter(void 0, void 0, void 0, function () {
|
|
33
|
-
var _a,
|
|
34
|
-
return tslib_1.__generator(this, function (
|
|
35
|
-
switch (
|
|
31
|
+
var _a, logger, pathMappings, enableI18nLegacyMessageIdFormat, fileSystem, tsConfig, getFileWriter, pkgJsonUpdater, fileWriter, createCompileFn, e_1;
|
|
32
|
+
return tslib_1.__generator(this, function (_b) {
|
|
33
|
+
switch (_b.label) {
|
|
36
34
|
case 0:
|
|
37
35
|
process.title = 'ngcc (worker)';
|
|
38
|
-
|
|
36
|
+
_b.label = 1;
|
|
39
37
|
case 1:
|
|
40
|
-
|
|
41
|
-
_a = ngcc_options_1.getSharedSetup(command_line_options_1.parseCommandLineOptions(process.argv.slice(2))),
|
|
38
|
+
_b.trys.push([1, 3, , 4]);
|
|
39
|
+
_a = ngcc_options_1.getSharedSetup(command_line_options_1.parseCommandLineOptions(process.argv.slice(2))), logger = _a.logger, pathMappings = _a.pathMappings, enableI18nLegacyMessageIdFormat = _a.enableI18nLegacyMessageIdFormat, fileSystem = _a.fileSystem, tsConfig = _a.tsConfig, getFileWriter = _a.getFileWriter;
|
|
42
40
|
pkgJsonUpdater = new package_json_updater_1.ClusterWorkerPackageJsonUpdater();
|
|
43
|
-
|
|
41
|
+
fileWriter = getFileWriter(pkgJsonUpdater);
|
|
42
|
+
createCompileFn = create_compile_function_1.getCreateCompileFn(fileSystem, logger, fileWriter, enableI18nLegacyMessageIdFormat, tsConfig, pathMappings);
|
|
44
43
|
return [4 /*yield*/, startWorker(logger, createCompileFn)];
|
|
45
44
|
case 2:
|
|
46
|
-
|
|
45
|
+
_b.sent();
|
|
47
46
|
process.exitCode = 0;
|
|
48
47
|
return [3 /*break*/, 4];
|
|
49
48
|
case 3:
|
|
50
|
-
e_1 =
|
|
49
|
+
e_1 = _b.sent();
|
|
51
50
|
console.error(e_1.stack || e_1.message);
|
|
52
51
|
process.exit(1);
|
|
53
52
|
return [3 /*break*/, 4];
|
|
@@ -59,29 +58,60 @@
|
|
|
59
58
|
function startWorker(logger, createCompileFn) {
|
|
60
59
|
return tslib_1.__awaiter(this, void 0, void 0, function () {
|
|
61
60
|
var compile;
|
|
61
|
+
var _this = this;
|
|
62
62
|
return tslib_1.__generator(this, function (_a) {
|
|
63
63
|
if (cluster.isMaster) {
|
|
64
64
|
throw new Error('Tried to run cluster worker on the master process.');
|
|
65
65
|
}
|
|
66
|
-
compile = createCompileFn(function (
|
|
66
|
+
compile = createCompileFn(function (transformedFiles) { return utils_2.sendMessageToMaster({
|
|
67
|
+
type: 'transformed-files',
|
|
68
|
+
files: transformedFiles.map(function (f) { return f.path; }),
|
|
69
|
+
}); }, function (_task, outcome, message) { return utils_2.sendMessageToMaster({ type: 'task-completed', outcome: outcome, message: message }); });
|
|
67
70
|
// Listen for `ProcessTaskMessage`s and process tasks.
|
|
68
|
-
cluster.worker.on('message', function (msg) {
|
|
69
|
-
|
|
70
|
-
|
|
71
|
-
|
|
71
|
+
cluster.worker.on('message', function (msg) { return tslib_1.__awaiter(_this, void 0, void 0, function () {
|
|
72
|
+
var _a, err_1, _b;
|
|
73
|
+
return tslib_1.__generator(this, function (_c) {
|
|
74
|
+
switch (_c.label) {
|
|
75
|
+
case 0:
|
|
76
|
+
_c.trys.push([0, 5, , 10]);
|
|
77
|
+
_a = msg.type;
|
|
78
|
+
switch (_a) {
|
|
79
|
+
case 'process-task': return [3 /*break*/, 1];
|
|
80
|
+
}
|
|
81
|
+
return [3 /*break*/, 3];
|
|
82
|
+
case 1:
|
|
72
83
|
logger.debug("[Worker #" + cluster.worker.id + "] Processing task: " + utils_1.stringifyTask(msg.task));
|
|
73
|
-
return compile(msg.task);
|
|
74
|
-
|
|
75
|
-
|
|
84
|
+
return [4 /*yield*/, compile(msg.task)];
|
|
85
|
+
case 2: return [2 /*return*/, _c.sent()];
|
|
86
|
+
case 3: throw new Error("[Worker #" + cluster.worker.id + "] Invalid message received: " + JSON.stringify(msg));
|
|
87
|
+
case 4: return [3 /*break*/, 10];
|
|
88
|
+
case 5:
|
|
89
|
+
err_1 = _c.sent();
|
|
90
|
+
_b = err_1 && err_1.code;
|
|
91
|
+
switch (_b) {
|
|
92
|
+
case 'ENOMEM': return [3 /*break*/, 6];
|
|
93
|
+
}
|
|
94
|
+
return [3 /*break*/, 7];
|
|
95
|
+
case 6:
|
|
96
|
+
// Not being able to allocate enough memory is not necessarily a problem with processing
|
|
97
|
+
// the current task. It could just mean that there are too many tasks being processed
|
|
98
|
+
// simultaneously.
|
|
99
|
+
//
|
|
100
|
+
// Exit with an error and let the cluster master decide how to handle this.
|
|
101
|
+
logger.warn("[Worker #" + cluster.worker.id + "] " + (err_1.stack || err_1.message));
|
|
102
|
+
return [2 /*return*/, process.exit(1)];
|
|
103
|
+
case 7: return [4 /*yield*/, utils_2.sendMessageToMaster({
|
|
104
|
+
type: 'error',
|
|
105
|
+
error: (err_1 instanceof Error) ? (err_1.stack || err_1.message) : err_1,
|
|
106
|
+
})];
|
|
107
|
+
case 8:
|
|
108
|
+
_c.sent();
|
|
109
|
+
_c.label = 9;
|
|
110
|
+
case 9: return [3 /*break*/, 10];
|
|
111
|
+
case 10: return [2 /*return*/];
|
|
76
112
|
}
|
|
77
|
-
}
|
|
78
|
-
|
|
79
|
-
utils_2.sendMessageToMaster({
|
|
80
|
-
type: 'error',
|
|
81
|
-
error: (err instanceof Error) ? (err.stack || err.message) : err,
|
|
82
|
-
});
|
|
83
|
-
}
|
|
84
|
-
});
|
|
113
|
+
});
|
|
114
|
+
}); });
|
|
85
115
|
// Return a promise that is never resolved.
|
|
86
116
|
return [2 /*return*/, new Promise(function () { return undefined; })];
|
|
87
117
|
});
|
|
@@ -89,4 +119,4 @@
|
|
|
89
119
|
}
|
|
90
120
|
exports.startWorker = startWorker;
|
|
91
121
|
});
|
|
92
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
122
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"worker.js","sourceRoot":"","sources":["../../../../../../../../../packages/compiler-cli/ngcc/src/execution/cluster/worker.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 */\n/// <reference types=\"node\" />\n\nimport * as cluster from 'cluster';\n\nimport {parseCommandLineOptions} from '../../command_line_options';\nimport {ConsoleLogger} from '../../logging/console_logger';\nimport {Logger, LogLevel} from '../../logging/logger';\nimport {getSharedSetup} from '../../ngcc_options';\nimport {CreateCompileFn} from '../api';\nimport {getCreateCompileFn} from '../create_compile_function';\nimport {stringifyTask} from '../tasks/utils';\n\nimport {MessageToWorker} from './api';\nimport {ClusterWorkerPackageJsonUpdater} from './package_json_updater';\nimport {sendMessageToMaster} from './utils';\n\n// Cluster worker entry point\nif (require.main === module) {\n  (async () => {\n    process.title = 'ngcc (worker)';\n\n    try {\n      const {\n        logger,\n        pathMappings,\n        enableI18nLegacyMessageIdFormat,\n        fileSystem,\n        tsConfig,\n        getFileWriter,\n      } = getSharedSetup(parseCommandLineOptions(process.argv.slice(2)));\n\n      // NOTE: To avoid file corruption, `ngcc` invocation only creates _one_ instance of\n      // `PackageJsonUpdater` that actually writes to disk (across all processes).\n      // In cluster workers we use a `PackageJsonUpdater` that delegates to the cluster master.\n      const pkgJsonUpdater = new ClusterWorkerPackageJsonUpdater();\n      const fileWriter = getFileWriter(pkgJsonUpdater);\n\n      // The function for creating the `compile()` function.\n      const createCompileFn = getCreateCompileFn(\n          fileSystem, logger, fileWriter, enableI18nLegacyMessageIdFormat, tsConfig, pathMappings);\n\n      await startWorker(logger, createCompileFn);\n      process.exitCode = 0;\n    } catch (e) {\n      console.error(e.stack || e.message);\n      process.exit(1);\n    }\n  })();\n}\n\nexport async function startWorker(logger: Logger, createCompileFn: CreateCompileFn): Promise<void> {\n  if (cluster.isMaster) {\n    throw new Error('Tried to run cluster worker on the master process.');\n  }\n\n  const compile = createCompileFn(\n      transformedFiles => sendMessageToMaster({\n        type: 'transformed-files',\n        files: transformedFiles.map(f => f.path),\n      }),\n      (_task, outcome, message) => sendMessageToMaster({type: 'task-completed', outcome, message}));\n\n\n  // Listen for `ProcessTaskMessage`s and process tasks.\n  cluster.worker.on('message', async (msg: MessageToWorker) => {\n    try {\n      switch (msg.type) {\n        case 'process-task':\n          logger.debug(\n              `[Worker #${cluster.worker.id}] Processing task: ${stringifyTask(msg.task)}`);\n          return await compile(msg.task);\n        default:\n          throw new Error(\n              `[Worker #${cluster.worker.id}] Invalid message received: ${JSON.stringify(msg)}`);\n      }\n    } catch (err) {\n      switch (err && err.code) {\n        case 'ENOMEM':\n          // Not being able to allocate enough memory is not necessarily a problem with processing\n          // the current task. It could just mean that there are too many tasks being processed\n          // simultaneously.\n          //\n          // Exit with an error and let the cluster master decide how to handle this.\n          logger.warn(`[Worker #${cluster.worker.id}] ${err.stack || err.message}`);\n          return process.exit(1);\n        default:\n          await sendMessageToMaster({\n            type: 'error',\n            error: (err instanceof Error) ? (err.stack || err.message) : err,\n          });\n      }\n    }\n  });\n\n  // Return a promise that is never resolved.\n  return new Promise(() => undefined);\n}\n"]}
|
|
@@ -2,10 +2,10 @@
|
|
|
2
2
|
import { FileSystem } from '../../../src/ngtsc/file_system';
|
|
3
3
|
import { ParsedConfiguration } from '../../../src/perform_compile';
|
|
4
4
|
import { Logger } from '../logging/logger';
|
|
5
|
-
import { PathMappings } from '../
|
|
6
|
-
import {
|
|
5
|
+
import { PathMappings } from '../path_mappings';
|
|
6
|
+
import { FileWriter } from '../writing/file_writer';
|
|
7
7
|
import { CreateCompileFn } from './api';
|
|
8
8
|
/**
|
|
9
9
|
* The function for creating the `compile()` function.
|
|
10
10
|
*/
|
|
11
|
-
export declare function getCreateCompileFn(fileSystem: FileSystem, logger: Logger,
|
|
11
|
+
export declare function getCreateCompileFn(fileSystem: FileSystem, logger: Logger, fileWriter: FileWriter, enableI18nLegacyMessageIdFormat: boolean, tsConfig: ParsedConfiguration | null, pathMappings: PathMappings | undefined): CreateCompileFn;
|
|
@@ -4,7 +4,7 @@
|
|
|
4
4
|
if (v !== undefined) module.exports = v;
|
|
5
5
|
}
|
|
6
6
|
else if (typeof define === "function" && define.amd) {
|
|
7
|
-
define("@angular/compiler-cli/ngcc/src/execution/create_compile_function", ["require", "exports", "typescript", "@angular/compiler-cli/src/ngtsc/diagnostics", "@angular/compiler-cli/ngcc/src/packages/entry_point", "@angular/compiler-cli/ngcc/src/packages/entry_point_bundle"
|
|
7
|
+
define("@angular/compiler-cli/ngcc/src/execution/create_compile_function", ["require", "exports", "typescript", "@angular/compiler-cli/src/ngtsc/diagnostics", "@angular/compiler-cli/ngcc/src/packages/entry_point", "@angular/compiler-cli/ngcc/src/packages/entry_point_bundle"], factory);
|
|
8
8
|
}
|
|
9
9
|
})(function (require, exports) {
|
|
10
10
|
"use strict";
|
|
@@ -20,14 +20,11 @@
|
|
|
20
20
|
var diagnostics_1 = require("@angular/compiler-cli/src/ngtsc/diagnostics");
|
|
21
21
|
var entry_point_1 = require("@angular/compiler-cli/ngcc/src/packages/entry_point");
|
|
22
22
|
var entry_point_bundle_1 = require("@angular/compiler-cli/ngcc/src/packages/entry_point_bundle");
|
|
23
|
-
var in_place_file_writer_1 = require("@angular/compiler-cli/ngcc/src/writing/in_place_file_writer");
|
|
24
|
-
var new_entry_point_file_writer_1 = require("@angular/compiler-cli/ngcc/src/writing/new_entry_point_file_writer");
|
|
25
23
|
/**
|
|
26
24
|
* The function for creating the `compile()` function.
|
|
27
25
|
*/
|
|
28
|
-
function getCreateCompileFn(fileSystem, logger,
|
|
29
|
-
return function (onTaskCompleted) {
|
|
30
|
-
var fileWriter = getFileWriter(fileSystem, logger, pkgJsonUpdater, createNewEntryPointFormats, errorOnFailedEntryPoint);
|
|
26
|
+
function getCreateCompileFn(fileSystem, logger, fileWriter, enableI18nLegacyMessageIdFormat, tsConfig, pathMappings) {
|
|
27
|
+
return function (beforeWritingFiles, onTaskCompleted) {
|
|
31
28
|
var Transformer = require('../packages/transformer').Transformer;
|
|
32
29
|
var transformer = new Transformer(fileSystem, logger, tsConfig);
|
|
33
30
|
return function (task) {
|
|
@@ -46,16 +43,22 @@
|
|
|
46
43
|
throw new Error("Invariant violated: No format-path or format for " + entryPoint.path + " : " +
|
|
47
44
|
(formatProperty + " (formatPath: " + formatPath + " | format: " + format + ")"));
|
|
48
45
|
}
|
|
49
|
-
var bundle = entry_point_bundle_1.makeEntryPointBundle(fileSystem, entryPoint, formatPath, isCore, format, processDts, pathMappings, true, enableI18nLegacyMessageIdFormat);
|
|
50
46
|
logger.info("Compiling " + entryPoint.name + " : " + formatProperty + " as " + format);
|
|
47
|
+
var bundle = entry_point_bundle_1.makeEntryPointBundle(fileSystem, entryPoint, formatPath, isCore, format, processDts, pathMappings, true, enableI18nLegacyMessageIdFormat);
|
|
51
48
|
var result = transformer.transform(bundle);
|
|
52
49
|
if (result.success) {
|
|
53
50
|
if (result.diagnostics.length > 0) {
|
|
54
51
|
logger.warn(diagnostics_1.replaceTsWithNgInErrors(ts.formatDiagnosticsWithColorAndContext(result.diagnostics, bundle.src.host)));
|
|
55
52
|
}
|
|
56
|
-
|
|
57
|
-
|
|
58
|
-
|
|
53
|
+
var writeBundle = function () {
|
|
54
|
+
fileWriter.writeBundle(bundle, result.transformedFiles, formatPropertiesToMarkAsProcessed);
|
|
55
|
+
logger.debug(" Successfully compiled " + entryPoint.name + " : " + formatProperty);
|
|
56
|
+
onTaskCompleted(task, 0 /* Processed */, null);
|
|
57
|
+
};
|
|
58
|
+
var beforeWritingResult = beforeWritingFiles(result.transformedFiles);
|
|
59
|
+
return (beforeWritingResult instanceof Promise) ?
|
|
60
|
+
beforeWritingResult.then(writeBundle) :
|
|
61
|
+
writeBundle();
|
|
59
62
|
}
|
|
60
63
|
else {
|
|
61
64
|
var errors = diagnostics_1.replaceTsWithNgInErrors(ts.formatDiagnosticsWithColorAndContext(result.diagnostics, bundle.src.host));
|
|
@@ -65,10 +68,5 @@
|
|
|
65
68
|
};
|
|
66
69
|
}
|
|
67
70
|
exports.getCreateCompileFn = getCreateCompileFn;
|
|
68
|
-
function getFileWriter(fs, logger, pkgJsonUpdater, createNewEntryPointFormats, errorOnFailedEntryPoint) {
|
|
69
|
-
return createNewEntryPointFormats ?
|
|
70
|
-
new new_entry_point_file_writer_1.NewEntryPointFileWriter(fs, logger, errorOnFailedEntryPoint, pkgJsonUpdater) :
|
|
71
|
-
new in_place_file_writer_1.InPlaceFileWriter(fs, logger, errorOnFailedEntryPoint);
|
|
72
|
-
}
|
|
73
71
|
});
|
|
74
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
72
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"create_compile_function.js","sourceRoot":"","sources":["../../../../../../../../packages/compiler-cli/ngcc/src/execution/create_compile_function.ts"],"names":[],"mappings":";;;;;;;;;;;IACA;;;;;;OAMG;IACH,+BAAiC;IAEjC,2EAAuE;IAIvE,mFAA4D;IAC5D,iGAAoE;IAOpE;;OAEG;IACH,SAAgB,kBAAkB,CAC9B,UAAsB,EAAE,MAAc,EAAE,UAAsB,EAC9D,+BAAwC,EAAE,QAAkC,EAC5E,YAAoC;QACtC,OAAO,UAAC,kBAAkB,EAAE,eAAe;YAClC,IAAA,4DAAW,CAAuC;YACzD,IAAM,WAAW,GAAG,IAAI,WAAW,CAAC,UAAU,EAAE,MAAM,EAAE,QAAQ,CAAC,CAAC;YAElE,OAAO,UAAC,IAAU;gBACT,IAAA,4BAAU,EAAE,oCAAc,EAAE,0EAAiC,EAAE,4BAAU,CAAS;gBAEzF,IAAM,MAAM,GAAG,UAAU,CAAC,IAAI,KAAK,eAAe,CAAC,CAAE,qCAAqC;gBAC1F,IAAM,WAAW,GAAG,UAAU,CAAC,WAAW,CAAC;gBAC3C,IAAM,UAAU,GAAG,WAAW,CAAC,cAAc,CAAC,CAAC;gBAC/C,IAAM,MAAM,GAAG,iCAAmB,CAAC,UAAU,EAAE,UAAU,EAAE,cAAc,CAAC,CAAC;gBAE3E,0FAA0F;gBAC1F,6FAA6F;gBAC7F,6CAA6C;gBAC7C,wFAAwF;gBACxF,4DAA4D;gBAC5D,IAAI,CAAC,UAAU,IAAI,CAAC,MAAM,EAAE;oBAC1B,4BAA4B;oBAC5B,MAAM,IAAI,KAAK,CACX,sDAAoD,UAAU,CAAC,IAAI,QAAK;yBACrE,cAAc,sBAAiB,UAAU,mBAAc,MAAM,MAAG,CAAA,CAAC,CAAC;iBAC1E;gBAED,MAAM,CAAC,IAAI,CAAC,eAAa,UAAU,CAAC,IAAI,WAAM,cAAc,YAAO,MAAQ,CAAC,CAAC;gBAE7E,IAAM,MAAM,GAAG,yCAAoB,CAC/B,UAAU,EAAE,UAAU,EAAE,UAAU,EAAE,MAAM,EAAE,MAAM,EAAE,UAAU,EAAE,YAAY,EAAE,IAAI,EAClF,+BAA+B,CAAC,CAAC;gBAErC,IAAM,MAAM,GAAG,WAAW,CAAC,SAAS,CAAC,MAAM,CAAC,CAAC;gBAC7C,IAAI,MAAM,CAAC,OAAO,EAAE;oBAClB,IAAI,MAAM,CAAC,WAAW,CAAC,MAAM,GAAG,CAAC,EAAE;wBACjC,MAAM,CAAC,IAAI,CAAC,qCAAuB,CAC/B,EAAE,CAAC,oCAAoC,CAAC,MAAM,CAAC,WAAW,EAAE,MAAM,CAAC,GAAG,CAAC,IAAI,CAAC,CAAC,CAAC,CAAC;qBACpF;oBAED,IAAM,WAAW,GAAG;wBAClB,UAAU,CAAC,WAAW,CAClB,MAAM,EAAE,MAAM,CAAC,gBAAgB,EAAE,iCAAiC,CAAC,CAAC;wBAExE,MAAM,CAAC,KAAK,CAAC,6BAA2B,UAAU,CAAC,IAAI,WAAM,cAAgB,CAAC,CAAC;wBAC/E,eAAe,CAAC,IAAI,qBAAmC,IAAI,CAAC,CAAC;oBAC/D,CAAC,CAAC;oBAEF,IAAM,mBAAmB,GAAG,kBAAkB,CAAC,MAAM,CAAC,gBAAgB,CAAC,CAAC;oBAExE,OAAO,CAAC,mBAAmB,YAAY,OAAO,CAAC,CAAC,CAAC;wBAC7C,mBAAmB,CAAC,IAAI,CAAC,WAAW,CAA0C,CAAA,CAAC;wBAC/E,WAAW,EAAE,CAAC;iBACnB;qBAAM;oBACL,IAAM,MAAM,GAAG,qCAAuB,CAClC,EAAE,CAAC,oCAAoC,CAAC,MAAM,CAAC,WAAW,EAAE,MAAM,CAAC,GAAG,CAAC,IAAI,CAAC,CAAC,CAAC;oBAClF,eAAe,CAAC,IAAI,kBAAgC,0BAAwB,MAAQ,CAAC,CAAC;iBACvF;YACH,CAAC,CAAC;QACJ,CAAC,CAAC;IACJ,CAAC;IA7DD,gDA6DC","sourcesContent":["\n/**\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 * as ts from 'typescript';\n\nimport {replaceTsWithNgInErrors} from '../../../src/ngtsc/diagnostics';\nimport {FileSystem} from '../../../src/ngtsc/file_system';\nimport {ParsedConfiguration} from '../../../src/perform_compile';\nimport {Logger} from '../logging/logger';\nimport {getEntryPointFormat} from '../packages/entry_point';\nimport {makeEntryPointBundle} from '../packages/entry_point_bundle';\nimport {PathMappings} from '../path_mappings';\nimport {FileWriter} from '../writing/file_writer';\n\nimport {CreateCompileFn} from './api';\nimport {Task, TaskProcessingOutcome} from './tasks/api';\n\n/**\n * The function for creating the `compile()` function.\n */\nexport function getCreateCompileFn(\n    fileSystem: FileSystem, logger: Logger, fileWriter: FileWriter,\n    enableI18nLegacyMessageIdFormat: boolean, tsConfig: ParsedConfiguration|null,\n    pathMappings: PathMappings|undefined): CreateCompileFn {\n  return (beforeWritingFiles, onTaskCompleted) => {\n    const {Transformer} = require('../packages/transformer');\n    const transformer = new Transformer(fileSystem, logger, tsConfig);\n\n    return (task: Task) => {\n      const {entryPoint, formatProperty, formatPropertiesToMarkAsProcessed, processDts} = task;\n\n      const isCore = entryPoint.name === '@angular/core';  // Are we compiling the Angular core?\n      const packageJson = entryPoint.packageJson;\n      const formatPath = packageJson[formatProperty];\n      const format = getEntryPointFormat(fileSystem, entryPoint, formatProperty);\n\n      // All properties listed in `propertiesToProcess` are guaranteed to point to a format-path\n      // (i.e. they are defined in `entryPoint.packageJson`). Furthermore, they are also guaranteed\n      // to be among `SUPPORTED_FORMAT_PROPERTIES`.\n      // Based on the above, `formatPath` should always be defined and `getEntryPointFormat()`\n      // should always return a format here (and not `undefined`).\n      if (!formatPath || !format) {\n        // This should never happen.\n        throw new Error(\n            `Invariant violated: No format-path or format for ${entryPoint.path} : ` +\n            `${formatProperty} (formatPath: ${formatPath} | format: ${format})`);\n      }\n\n      logger.info(`Compiling ${entryPoint.name} : ${formatProperty} as ${format}`);\n\n      const bundle = makeEntryPointBundle(\n          fileSystem, entryPoint, formatPath, isCore, format, processDts, pathMappings, true,\n          enableI18nLegacyMessageIdFormat);\n\n      const result = transformer.transform(bundle);\n      if (result.success) {\n        if (result.diagnostics.length > 0) {\n          logger.warn(replaceTsWithNgInErrors(\n              ts.formatDiagnosticsWithColorAndContext(result.diagnostics, bundle.src.host)));\n        }\n\n        const writeBundle = () => {\n          fileWriter.writeBundle(\n              bundle, result.transformedFiles, formatPropertiesToMarkAsProcessed);\n\n          logger.debug(`  Successfully compiled ${entryPoint.name} : ${formatProperty}`);\n          onTaskCompleted(task, TaskProcessingOutcome.Processed, null);\n        };\n\n        const beforeWritingResult = beforeWritingFiles(result.transformedFiles);\n\n        return (beforeWritingResult instanceof Promise) ?\n            beforeWritingResult.then(writeBundle) as ReturnType<typeof beforeWritingFiles>:\n            writeBundle();\n      } else {\n        const errors = replaceTsWithNgInErrors(\n            ts.formatDiagnosticsWithColorAndContext(result.diagnostics, bundle.src.host));\n        onTaskCompleted(task, TaskProcessingOutcome.Failed, `compilation errors:\\n${errors}`);\n      }\n    };\n  };\n}\n"]}
|
|
@@ -26,14 +26,14 @@
|
|
|
26
26
|
this.logger.debug("Running ngcc on " + this.constructor.name + ".");
|
|
27
27
|
var taskQueue = analyzeEntryPoints();
|
|
28
28
|
var onTaskCompleted = this.createTaskCompletedCallback(taskQueue);
|
|
29
|
-
var compile = createCompileFn(onTaskCompleted);
|
|
29
|
+
var compile = createCompileFn(function () { }, onTaskCompleted);
|
|
30
30
|
// Process all tasks.
|
|
31
31
|
this.logger.debug('Processing tasks...');
|
|
32
32
|
var startTime = Date.now();
|
|
33
33
|
while (!taskQueue.allTasksCompleted) {
|
|
34
34
|
var task = taskQueue.getNextTask();
|
|
35
35
|
compile(task);
|
|
36
|
-
taskQueue.
|
|
36
|
+
taskQueue.markAsCompleted(task);
|
|
37
37
|
}
|
|
38
38
|
var duration = Math.round((Date.now() - startTime) / 1000);
|
|
39
39
|
this.logger.debug("Processed tasks in " + duration + "s.");
|
|
@@ -87,4 +87,4 @@
|
|
|
87
87
|
}(SingleProcessorExecutorBase));
|
|
88
88
|
exports.SingleProcessExecutorAsync = SingleProcessExecutorAsync;
|
|
89
89
|
});
|
|
90
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
90
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoic2luZ2xlX3Byb2Nlc3NfZXhlY3V0b3IuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi8uLi8uLi8uLi9wYWNrYWdlcy9jb21waWxlci1jbGkvbmdjYy9zcmMvZXhlY3V0aW9uL3NpbmdsZV9wcm9jZXNzX2V4ZWN1dG9yLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBOzs7Ozs7R0FNRzs7Ozs7Ozs7Ozs7OztJQVNIO1FBQ0UscUNBQ1ksTUFBYyxFQUFVLDJCQUF3RDtZQUFoRixXQUFNLEdBQU4sTUFBTSxDQUFRO1lBQVUsZ0NBQTJCLEdBQTNCLDJCQUEyQixDQUE2QjtRQUFHLENBQUM7UUFFaEcsK0NBQVMsR0FBVCxVQUFVLGtCQUF3QyxFQUFFLGVBQWdDO1lBRWxGLElBQUksQ0FBQyxNQUFNLENBQUMsS0FBSyxDQUFDLHFCQUFtQixJQUFJLENBQUMsV0FBVyxDQUFDLElBQUksTUFBRyxDQUFDLENBQUM7WUFFL0QsSUFBTSxTQUFTLEdBQUcsa0JBQWtCLEVBQUUsQ0FBQztZQUN2QyxJQUFNLGVBQWUsR0FBRyxJQUFJLENBQUMsMkJBQTJCLENBQUMsU0FBUyxDQUFDLENBQUM7WUFDcEUsSUFBTSxPQUFPLEdBQUcsZUFBZSxDQUFDLGNBQU8sQ0FBQyxFQUFFLGVBQWUsQ0FBQyxDQUFDO1lBRTNELHFCQUFxQjtZQUNyQixJQUFJLENBQUMsTUFBTSxDQUFDLEtBQUssQ0FBQyxxQkFBcUIsQ0FBQyxDQUFDO1lBQ3pDLElBQU0sU0FBUyxHQUFHLElBQUksQ0FBQyxHQUFHLEVBQUUsQ0FBQztZQUU3QixPQUFPLENBQUMsU0FBUyxDQUFDLGlCQUFpQixFQUFFO2dCQUNuQyxJQUFNLElBQUksR0FBRyxTQUFTLENBQUMsV0FBVyxFQUFHLENBQUM7Z0JBQ3RDLE9BQU8sQ0FBQyxJQUFJLENBQUMsQ0FBQztnQkFDZCxTQUFTLENBQUMsZUFBZSxDQUFDLElBQUksQ0FBQyxDQUFDO2FBQ2pDO1lBRUQsSUFBTSxRQUFRLEdBQUcsSUFBSSxDQUFDLEtBQUssQ0FBQyxDQUFDLElBQUksQ0FBQyxHQUFHLEVBQUUsR0FBRyxTQUFTLENBQUMsR0FBRyxJQUFJLENBQUMsQ0FBQztZQUM3RCxJQUFJLENBQUMsTUFBTSxDQUFDLEtBQUssQ0FBQyx3QkFBc0IsUUFBUSxPQUFJLENBQUMsQ0FBQztRQUN4RCxDQUFDO1FBQ0gsa0NBQUM7SUFBRCxDQUFDLEFBekJELElBeUJDO0lBekJxQixrRUFBMkI7SUEyQmpEOztPQUVHO0lBQ0g7UUFBK0MscURBQTJCO1FBQ3hFLG1DQUNJLE1BQWMsRUFBVSxRQUFvQixFQUM1QywyQkFBd0Q7WUFGNUQsWUFHRSxrQkFBTSxNQUFNLEVBQUUsMkJBQTJCLENBQUMsU0FDM0M7WUFIMkIsY0FBUSxHQUFSLFFBQVEsQ0FBWTs7UUFHaEQsQ0FBQztRQUNELDJDQUFPLEdBQVAsVUFBUSxrQkFBd0MsRUFBRSxlQUFnQztZQUFsRixpQkFFQztZQURDLElBQUksQ0FBQyxRQUFRLENBQUMsSUFBSSxDQUFDLGNBQU0sT0FBQSxLQUFJLENBQUMsU0FBUyxDQUFDLGtCQUFrQixFQUFFLGVBQWUsQ0FBQyxFQUFuRCxDQUFtRCxDQUFDLENBQUM7UUFDaEYsQ0FBQztRQUNILGdDQUFDO0lBQUQsQ0FBQyxBQVRELENBQStDLDJCQUEyQixHQVN6RTtJQVRZLDhEQUF5QjtJQVd0Qzs7T0FFRztJQUNIO1FBQWdELHNEQUEyQjtRQUN6RSxvQ0FDSSxNQUFjLEVBQVUsUUFBcUIsRUFDN0MsMkJBQXdEO1lBRjVELFlBR0Usa0JBQU0sTUFBTSxFQUFFLDJCQUEyQixDQUFDLFNBQzNDO1lBSDJCLGNBQVEsR0FBUixRQUFRLENBQWE7O1FBR2pELENBQUM7UUFDSyw0Q0FBTyxHQUFiLFVBQWMsa0JBQXdDLEVBQUUsZUFBZ0M7Ozs7O2dDQUV0RixxQkFBTSxJQUFJLENBQUMsUUFBUSxDQUFDLElBQUksQ0FBQztnQ0FBWSxzQkFBQSxJQUFJLENBQUMsU0FBUyxDQUFDLGtCQUFrQixFQUFFLGVBQWUsQ0FBQyxFQUFBO3FDQUFBLENBQUMsRUFBQTs7NEJBQXpGLFNBQXlGLENBQUM7Ozs7O1NBQzNGO1FBQ0gsaUNBQUM7SUFBRCxDQUFDLEFBVkQsQ0FBZ0QsMkJBQTJCLEdBVTFFO0lBVlksZ0VBQTBCIiwic291cmNlc0NvbnRlbnQiOlsiLyoqXG4gKiBAbGljZW5zZVxuICogQ29weXJpZ2h0IEdvb2dsZSBJbmMuIEFsbCBSaWdodHMgUmVzZXJ2ZWQuXG4gKlxuICogVXNlIG9mIHRoaXMgc291cmNlIGNvZGUgaXMgZ292ZXJuZWQgYnkgYW4gTUlULXN0eWxlIGxpY2Vuc2UgdGhhdCBjYW4gYmVcbiAqIGZvdW5kIGluIHRoZSBMSUNFTlNFIGZpbGUgYXQgaHR0cHM6Ly9hbmd1bGFyLmlvL2xpY2Vuc2VcbiAqL1xuXG5pbXBvcnQge0FzeW5jTG9ja2VyfSBmcm9tICcuLi9sb2NraW5nL2FzeW5jX2xvY2tlcic7XG5pbXBvcnQge1N5bmNMb2NrZXJ9IGZyb20gJy4uL2xvY2tpbmcvc3luY19sb2NrZXInO1xuaW1wb3J0IHtMb2dnZXJ9IGZyb20gJy4uL2xvZ2dpbmcvbG9nZ2VyJztcblxuaW1wb3J0IHtBbmFseXplRW50cnlQb2ludHNGbiwgQ3JlYXRlQ29tcGlsZUZuLCBFeGVjdXRvcn0gZnJvbSAnLi9hcGknO1xuaW1wb3J0IHtDcmVhdGVUYXNrQ29tcGxldGVkQ2FsbGJhY2t9IGZyb20gJy4vdGFza3MvYXBpJztcblxuZXhwb3J0IGFic3RyYWN0IGNsYXNzIFNpbmdsZVByb2Nlc3NvckV4ZWN1dG9yQmFzZSB7XG4gIGNvbnN0cnVjdG9yKFxuICAgICAgcHJpdmF0ZSBsb2dnZXI6IExvZ2dlciwgcHJpdmF0ZSBjcmVhdGVUYXNrQ29tcGxldGVkQ2FsbGJhY2s6IENyZWF0ZVRhc2tDb21wbGV0ZWRDYWxsYmFjaykge31cblxuICBkb0V4ZWN1dGUoYW5hbHl6ZUVudHJ5UG9pbnRzOiBBbmFseXplRW50cnlQb2ludHNGbiwgY3JlYXRlQ29tcGlsZUZuOiBDcmVhdGVDb21waWxlRm4pOlxuICAgICAgdm9pZHxQcm9taXNlPHZvaWQ+IHtcbiAgICB0aGlzLmxvZ2dlci5kZWJ1ZyhgUnVubmluZyBuZ2NjIG9uICR7dGhpcy5jb25zdHJ1Y3Rvci5uYW1lfS5gKTtcblxuICAgIGNvbnN0IHRhc2tRdWV1ZSA9IGFuYWx5emVFbnRyeVBvaW50cygpO1xuICAgIGNvbnN0IG9uVGFza0NvbXBsZXRlZCA9IHRoaXMuY3JlYXRlVGFza0NvbXBsZXRlZENhbGxiYWNrKHRhc2tRdWV1ZSk7XG4gICAgY29uc3QgY29tcGlsZSA9IGNyZWF0ZUNvbXBpbGVGbigoKSA9PiB7fSwgb25UYXNrQ29tcGxldGVkKTtcblxuICAgIC8vIFByb2Nlc3MgYWxsIHRhc2tzLlxuICAgIHRoaXMubG9nZ2VyLmRlYnVnKCdQcm9jZXNzaW5nIHRhc2tzLi4uJyk7XG4gICAgY29uc3Qgc3RhcnRUaW1lID0gRGF0ZS5ub3coKTtcblxuICAgIHdoaWxlICghdGFza1F1ZXVlLmFsbFRhc2tzQ29tcGxldGVkKSB7XG4gICAgICBjb25zdCB0YXNrID0gdGFza1F1ZXVlLmdldE5leHRUYXNrKCkhO1xuICAgICAgY29tcGlsZSh0YXNrKTtcbiAgICAgIHRhc2tRdWV1ZS5tYXJrQXNDb21wbGV0ZWQodGFzayk7XG4gICAgfVxuXG4gICAgY29uc3QgZHVyYXRpb24gPSBNYXRoLnJvdW5kKChEYXRlLm5vdygpIC0gc3RhcnRUaW1lKSAvIDEwMDApO1xuICAgIHRoaXMubG9nZ2VyLmRlYnVnKGBQcm9jZXNzZWQgdGFza3MgaW4gJHtkdXJhdGlvbn1zLmApO1xuICB9XG59XG5cbi8qKlxuICogQW4gYEV4ZWN1dG9yYCB0aGF0IHByb2Nlc3NlcyBhbGwgdGFza3Mgc2VyaWFsbHkgYW5kIGNvbXBsZXRlcyBzeW5jaHJvbm91c2x5LlxuICovXG5leHBvcnQgY2xhc3MgU2luZ2xlUHJvY2Vzc0V4ZWN1dG9yU3luYyBleHRlbmRzIFNpbmdsZVByb2Nlc3NvckV4ZWN1dG9yQmFzZSBpbXBsZW1lbnRzIEV4ZWN1dG9yIHtcbiAgY29uc3RydWN0b3IoXG4gICAgICBsb2dnZXI6IExvZ2dlciwgcHJpdmF0ZSBsb2NrRmlsZTogU3luY0xvY2tlcixcbiAgICAgIGNyZWF0ZVRhc2tDb21wbGV0ZWRDYWxsYmFjazogQ3JlYXRlVGFza0NvbXBsZXRlZENhbGxiYWNrKSB7XG4gICAgc3VwZXIobG9nZ2VyLCBjcmVhdGVUYXNrQ29tcGxldGVkQ2FsbGJhY2spO1xuICB9XG4gIGV4ZWN1dGUoYW5hbHl6ZUVudHJ5UG9pbnRzOiBBbmFseXplRW50cnlQb2ludHNGbiwgY3JlYXRlQ29tcGlsZUZuOiBDcmVhdGVDb21waWxlRm4pOiB2b2lkIHtcbiAgICB0aGlzLmxvY2tGaWxlLmxvY2soKCkgPT4gdGhpcy5kb0V4ZWN1dGUoYW5hbHl6ZUVudHJ5UG9pbnRzLCBjcmVhdGVDb21waWxlRm4pKTtcbiAgfVxufVxuXG4vKipcbiAqIEFuIGBFeGVjdXRvcmAgdGhhdCBwcm9jZXNzZXMgYWxsIHRhc2tzIHNlcmlhbGx5LCBidXQgc3RpbGwgY29tcGxldGVzIGFzeW5jaHJvbm91c2x5LlxuICovXG5leHBvcnQgY2xhc3MgU2luZ2xlUHJvY2Vzc0V4ZWN1dG9yQXN5bmMgZXh0ZW5kcyBTaW5nbGVQcm9jZXNzb3JFeGVjdXRvckJhc2UgaW1wbGVtZW50cyBFeGVjdXRvciB7XG4gIGNvbnN0cnVjdG9yKFxuICAgICAgbG9nZ2VyOiBMb2dnZXIsIHByaXZhdGUgbG9ja0ZpbGU6IEFzeW5jTG9ja2VyLFxuICAgICAgY3JlYXRlVGFza0NvbXBsZXRlZENhbGxiYWNrOiBDcmVhdGVUYXNrQ29tcGxldGVkQ2FsbGJhY2spIHtcbiAgICBzdXBlcihsb2dnZXIsIGNyZWF0ZVRhc2tDb21wbGV0ZWRDYWxsYmFjayk7XG4gIH1cbiAgYXN5bmMgZXhlY3V0ZShhbmFseXplRW50cnlQb2ludHM6IEFuYWx5emVFbnRyeVBvaW50c0ZuLCBjcmVhdGVDb21waWxlRm46IENyZWF0ZUNvbXBpbGVGbik6XG4gICAgICBQcm9taXNlPHZvaWQ+IHtcbiAgICBhd2FpdCB0aGlzLmxvY2tGaWxlLmxvY2soYXN5bmMgKCkgPT4gdGhpcy5kb0V4ZWN1dGUoYW5hbHl6ZUVudHJ5UG9pbnRzLCBjcmVhdGVDb21waWxlRm4pKTtcbiAgfVxufVxuIl19
|
|
@@ -96,13 +96,22 @@ export interface TaskQueue {
|
|
|
96
96
|
*
|
|
97
97
|
* @param task The task to mark as completed.
|
|
98
98
|
*/
|
|
99
|
-
|
|
99
|
+
markAsCompleted(task: Task): void;
|
|
100
100
|
/**
|
|
101
101
|
* Mark a task as failed.
|
|
102
102
|
*
|
|
103
103
|
* Do not process the tasks that depend upon the given task.
|
|
104
104
|
*/
|
|
105
105
|
markAsFailed(task: Task): void;
|
|
106
|
+
/**
|
|
107
|
+
* Mark a task as not processed (i.e. add an in-progress task back to the queue).
|
|
108
|
+
*
|
|
109
|
+
* This removes the task from the internal list of in-progress tasks and adds it back to the list
|
|
110
|
+
* of pending tasks.
|
|
111
|
+
*
|
|
112
|
+
* @param task The task to mark as not processed.
|
|
113
|
+
*/
|
|
114
|
+
markAsUnprocessed(task: Task): void;
|
|
106
115
|
/**
|
|
107
116
|
* Return a string representation of the task queue (for debugging purposes).
|
|
108
117
|
*
|
|
@@ -11,4 +11,4 @@
|
|
|
11
11
|
Object.defineProperty(exports, "__esModule", { value: true });
|
|
12
12
|
exports.TaskDependencies = Map;
|
|
13
13
|
});
|
|
14
|
-
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiYXBpLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vLi4vLi4vLi4vLi4vLi4vcGFja2FnZXMvY29tcGlsZXItY2xpL25nY2Mvc3JjL2V4ZWN1dGlvbi90YXNrcy9hcGkudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6Ijs7Ozs7Ozs7Ozs7SUF5RGEsUUFBQSxnQkFBZ0IsR0FBRyxHQUFHLENBQUMiLCJzb3VyY2VzQ29udGVudCI6WyIvKipcbiAqIEBsaWNlbnNlXG4gKiBDb3B5cmlnaHQgR29vZ2xlIEluYy4gQWxsIFJpZ2h0cyBSZXNlcnZlZC5cbiAqXG4gKiBVc2Ugb2YgdGhpcyBzb3VyY2UgY29kZSBpcyBnb3Zlcm5lZCBieSBhbiBNSVQtc3R5bGUgbGljZW5zZSB0aGF0IGNhbiBiZVxuICogZm91bmQgaW4gdGhlIExJQ0VOU0UgZmlsZSBhdCBodHRwczovL2FuZ3VsYXIuaW8vbGljZW5zZVxuICovXG5pbXBvcnQge0VudHJ5UG9pbnQsIEVudHJ5UG9pbnRKc29uUHJvcGVydHksIEpzb25PYmplY3R9IGZyb20gJy4uLy4uL3BhY2thZ2VzL2VudHJ5X3BvaW50JztcbmltcG9ydCB7UGFydGlhbGx5T3JkZXJlZExpc3R9IGZyb20gJy4uLy4uL3V0aWxzJztcblxuLyoqXG4gKiBSZXByZXNlbnRzIGEgdW5pdCBvZiB3b3JrIHRvIGJlIHVuZGVydGFrZW4gYnkgYW4gYEV4ZWN1dG9yYC5cbiAqXG4gKiBBIHRhc2sgY29uc2lzdHMgb2YgcHJvY2Vzc2luZyBhIHNwZWNpZmljIGZvcm1hdCBwcm9wZXJ0eSBvZiBhbiBlbnRyeS1wb2ludC5cbiAqIFRoaXMgbWF5IG9yIG1heSBub3QgYWxzbyBpbmNsdWRlIHByb2Nlc3NpbmcgdGhlIHR5cGluZ3MgZm9yIHRoYXQgZW50cnktcG9pbnQsIHdoaWNoIG9ubHkgbmVlZHMgdG9cbiAqIGhhcHBlbiBvbmNlIGFjcm9zcyBhbGwgdGhlIGZvcm1hdHMuXG4gKi9cbmV4cG9ydCBpbnRlcmZhY2UgVGFzayBleHRlbmRzIEpzb25PYmplY3Qge1xuICAvKiogVGhlIGBFbnRyeVBvaW50YCB3aGljaCBuZWVkcyB0byBiZSBwcm9jZXNzZWQgYXMgcGFydCBvZiB0aGUgdGFzay4gKi9cbiAgZW50cnlQb2ludDogRW50cnlQb2ludDtcblxuICAvKipcbiAgICogVGhlIGBwYWNrYWdlLmpzb25gIGZvcm1hdCBwcm9wZXJ0eSB0byBwcm9jZXNzIChpLmUuIHRoZSBwcm9wZXJ0eSB3aGljaCBwb2ludHMgdG8gdGhlIGZpbGUgdGhhdFxuICAgKiBpcyB0aGUgcHJvZ3JhbSBlbnRyeS1wb2ludCkuXG4gICAqL1xuICBmb3JtYXRQcm9wZXJ0eTogRW50cnlQb2ludEpzb25Qcm9wZXJ0eTtcblxuICAvKipcbiAgICogVGhlIGxpc3Qgb2YgYWxsIGZvcm1hdCBwcm9wZXJ0aWVzIChpbmNsdWRpbmcgYHRhc2suZm9ybWF0UHJvcGVydHlgKSB0aGF0IHNob3VsZCBiZSBtYXJrZWQgYXNcbiAgICogcHJvY2Vzc2VkIG9uY2UgdGhlIHRhc2sgaGFzIGJlZW4gY29tcGxldGVkLCBiZWNhdXNlIHRoZXkgcG9pbnQgdG8gdGhlIGZvcm1hdC1wYXRoIHRoYXQgd2lsbCBiZVxuICAgKiBwcm9jZXNzZWQgYXMgcGFydCBvZiB0aGUgdGFzay5cbiAgICovXG4gIGZvcm1hdFByb3BlcnRpZXNUb01hcmtBc1Byb2Nlc3NlZDogRW50cnlQb2ludEpzb25Qcm9wZXJ0eVtdO1xuXG4gIC8qKiBXaGV0aGVyIHRvIGFsc28gcHJvY2VzcyB0eXBpbmdzIGZvciB0aGlzIGVudHJ5LXBvaW50IGFzIHBhcnQgb2YgdGhlIHRhc2suICovXG4gIHByb2Nlc3NEdHM6IGJvb2xlYW47XG59XG5cbi8qKlxuICogUmVwcmVzZW50cyBhIHBhcnRpYWxseSBvcmRlcmVkIGxpc3Qgb2YgdGFza3MuXG4gKlxuICogVGhlIG9yZGVyaW5nL3ByZWNlZGVuY2Ugb2YgdGFza3MgaXMgZGV0ZXJtaW5lZCBieSB0aGUgaW50ZXItZGVwZW5kZW5jaWVzIGJldHdlZW4gdGhlaXIgYXNzb2NpYXRlZFxuICogZW50cnktcG9pbnRzLiBTcGVjaWZpY2FsbHksIHRoZSB0YXNrcycgb3JkZXIvcHJlY2VkZW5jZSBpcyBzdWNoIHRoYXQgdGFza3MgYXNzb2NpYXRlZCB0b1xuICogZGVwZW5kZW50IGVudHJ5LXBvaW50cyBhbHdheXMgY29tZSBhZnRlciB0YXNrcyBhc3NvY2lhdGVkIHdpdGggdGhlaXIgZGVwZW5kZW5jaWVzLlxuICpcbiAqIEFzIHJlc3VsdCBvZiB0aGlzIG9yZGVyaW5nLCBpdCBpcyBndWFyYW50ZWVkIHRoYXQgLSBieSBwcm9jZXNzaW5nIHRhc2tzIGluIHRoZSBvcmRlciBpbiB3aGljaFxuICogdGhleSBhcHBlYXIgaW4gdGhlIGxpc3QgLSBhIHRhc2sncyBkZXBlbmRlbmNpZXMgd2lsbCBhbHdheXMgaGF2ZSBiZWVuIHByb2Nlc3NlZCBiZWZvcmUgcHJvY2Vzc2luZ1xuICogdGhlIHRhc2sgaXRzZWxmLlxuICpcbiAqIFNlZSBgRGVwZW5kZW5jeVJlc29sdmVyI3NvcnRFbnRyeVBvaW50c0J5RGVwZW5kZW5jeSgpYC5cbiAqL1xuZXhwb3J0IHR5cGUgUGFydGlhbGx5T3JkZXJlZFRhc2tzID0gUGFydGlhbGx5T3JkZXJlZExpc3Q8VGFzaz47XG5cbi8qKlxuICogQSBtYXBwaW5nIGZyb20gVGFza3MgdG8gdGhlIFRhc2tzIHRoYXQgZGVwZW5kIHVwb24gdGhlbSAoZGVwZW5kZW50cykuXG4gKi9cbmV4cG9ydCB0eXBlIFRhc2tEZXBlbmRlbmNpZXMgPSBNYXA8VGFzaywgU2V0PFRhc2s+PjtcbmV4cG9ydCBjb25zdCBUYXNrRGVwZW5kZW5jaWVzID0gTWFwO1xuXG4vKipcbiAqIEEgZnVuY3Rpb24gdG8gY3JlYXRlIGEgVGFza0NvbXBsZXRlZENhbGxiYWNrIGZ1bmN0aW9uLlxuICovXG5leHBvcnQgdHlwZSBDcmVhdGVUYXNrQ29tcGxldGVkQ2FsbGJhY2sgPSAodGFza1F1ZXVlOiBUYXNrUXVldWUpID0+IFRhc2tDb21wbGV0ZWRDYWxsYmFjaztcblxuLyoqXG4gKiBBIGZ1bmN0aW9uIHRvIGJlIGNhbGxlZCBvbmNlIGEgdGFzayBoYXMgYmVlbiBwcm9jZXNzZWQuXG4gKi9cbmV4cG9ydCB0eXBlIFRhc2tDb21wbGV0ZWRDYWxsYmFjayA9XG4gICAgKHRhc2s6IFRhc2ssIG91dGNvbWU6IFRhc2tQcm9jZXNzaW5nT3V0Y29tZSwgbWVzc2FnZTogc3RyaW5nfG51bGwpID0+
|
|
14
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiYXBpLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vLi4vLi4vLi4vLi4vLi4vcGFja2FnZXMvY29tcGlsZXItY2xpL25nY2Mvc3JjL2V4ZWN1dGlvbi90YXNrcy9hcGkudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6Ijs7Ozs7Ozs7Ozs7SUF5RGEsUUFBQSxnQkFBZ0IsR0FBRyxHQUFHLENBQUMiLCJzb3VyY2VzQ29udGVudCI6WyIvKipcbiAqIEBsaWNlbnNlXG4gKiBDb3B5cmlnaHQgR29vZ2xlIEluYy4gQWxsIFJpZ2h0cyBSZXNlcnZlZC5cbiAqXG4gKiBVc2Ugb2YgdGhpcyBzb3VyY2UgY29kZSBpcyBnb3Zlcm5lZCBieSBhbiBNSVQtc3R5bGUgbGljZW5zZSB0aGF0IGNhbiBiZVxuICogZm91bmQgaW4gdGhlIExJQ0VOU0UgZmlsZSBhdCBodHRwczovL2FuZ3VsYXIuaW8vbGljZW5zZVxuICovXG5pbXBvcnQge0VudHJ5UG9pbnQsIEVudHJ5UG9pbnRKc29uUHJvcGVydHksIEpzb25PYmplY3R9IGZyb20gJy4uLy4uL3BhY2thZ2VzL2VudHJ5X3BvaW50JztcbmltcG9ydCB7UGFydGlhbGx5T3JkZXJlZExpc3R9IGZyb20gJy4uLy4uL3V0aWxzJztcblxuLyoqXG4gKiBSZXByZXNlbnRzIGEgdW5pdCBvZiB3b3JrIHRvIGJlIHVuZGVydGFrZW4gYnkgYW4gYEV4ZWN1dG9yYC5cbiAqXG4gKiBBIHRhc2sgY29uc2lzdHMgb2YgcHJvY2Vzc2luZyBhIHNwZWNpZmljIGZvcm1hdCBwcm9wZXJ0eSBvZiBhbiBlbnRyeS1wb2ludC5cbiAqIFRoaXMgbWF5IG9yIG1heSBub3QgYWxzbyBpbmNsdWRlIHByb2Nlc3NpbmcgdGhlIHR5cGluZ3MgZm9yIHRoYXQgZW50cnktcG9pbnQsIHdoaWNoIG9ubHkgbmVlZHMgdG9cbiAqIGhhcHBlbiBvbmNlIGFjcm9zcyBhbGwgdGhlIGZvcm1hdHMuXG4gKi9cbmV4cG9ydCBpbnRlcmZhY2UgVGFzayBleHRlbmRzIEpzb25PYmplY3Qge1xuICAvKiogVGhlIGBFbnRyeVBvaW50YCB3aGljaCBuZWVkcyB0byBiZSBwcm9jZXNzZWQgYXMgcGFydCBvZiB0aGUgdGFzay4gKi9cbiAgZW50cnlQb2ludDogRW50cnlQb2ludDtcblxuICAvKipcbiAgICogVGhlIGBwYWNrYWdlLmpzb25gIGZvcm1hdCBwcm9wZXJ0eSB0byBwcm9jZXNzIChpLmUuIHRoZSBwcm9wZXJ0eSB3aGljaCBwb2ludHMgdG8gdGhlIGZpbGUgdGhhdFxuICAgKiBpcyB0aGUgcHJvZ3JhbSBlbnRyeS1wb2ludCkuXG4gICAqL1xuICBmb3JtYXRQcm9wZXJ0eTogRW50cnlQb2ludEpzb25Qcm9wZXJ0eTtcblxuICAvKipcbiAgICogVGhlIGxpc3Qgb2YgYWxsIGZvcm1hdCBwcm9wZXJ0aWVzIChpbmNsdWRpbmcgYHRhc2suZm9ybWF0UHJvcGVydHlgKSB0aGF0IHNob3VsZCBiZSBtYXJrZWQgYXNcbiAgICogcHJvY2Vzc2VkIG9uY2UgdGhlIHRhc2sgaGFzIGJlZW4gY29tcGxldGVkLCBiZWNhdXNlIHRoZXkgcG9pbnQgdG8gdGhlIGZvcm1hdC1wYXRoIHRoYXQgd2lsbCBiZVxuICAgKiBwcm9jZXNzZWQgYXMgcGFydCBvZiB0aGUgdGFzay5cbiAgICovXG4gIGZvcm1hdFByb3BlcnRpZXNUb01hcmtBc1Byb2Nlc3NlZDogRW50cnlQb2ludEpzb25Qcm9wZXJ0eVtdO1xuXG4gIC8qKiBXaGV0aGVyIHRvIGFsc28gcHJvY2VzcyB0eXBpbmdzIGZvciB0aGlzIGVudHJ5LXBvaW50IGFzIHBhcnQgb2YgdGhlIHRhc2suICovXG4gIHByb2Nlc3NEdHM6IGJvb2xlYW47XG59XG5cbi8qKlxuICogUmVwcmVzZW50cyBhIHBhcnRpYWxseSBvcmRlcmVkIGxpc3Qgb2YgdGFza3MuXG4gKlxuICogVGhlIG9yZGVyaW5nL3ByZWNlZGVuY2Ugb2YgdGFza3MgaXMgZGV0ZXJtaW5lZCBieSB0aGUgaW50ZXItZGVwZW5kZW5jaWVzIGJldHdlZW4gdGhlaXIgYXNzb2NpYXRlZFxuICogZW50cnktcG9pbnRzLiBTcGVjaWZpY2FsbHksIHRoZSB0YXNrcycgb3JkZXIvcHJlY2VkZW5jZSBpcyBzdWNoIHRoYXQgdGFza3MgYXNzb2NpYXRlZCB0b1xuICogZGVwZW5kZW50IGVudHJ5LXBvaW50cyBhbHdheXMgY29tZSBhZnRlciB0YXNrcyBhc3NvY2lhdGVkIHdpdGggdGhlaXIgZGVwZW5kZW5jaWVzLlxuICpcbiAqIEFzIHJlc3VsdCBvZiB0aGlzIG9yZGVyaW5nLCBpdCBpcyBndWFyYW50ZWVkIHRoYXQgLSBieSBwcm9jZXNzaW5nIHRhc2tzIGluIHRoZSBvcmRlciBpbiB3aGljaFxuICogdGhleSBhcHBlYXIgaW4gdGhlIGxpc3QgLSBhIHRhc2sncyBkZXBlbmRlbmNpZXMgd2lsbCBhbHdheXMgaGF2ZSBiZWVuIHByb2Nlc3NlZCBiZWZvcmUgcHJvY2Vzc2luZ1xuICogdGhlIHRhc2sgaXRzZWxmLlxuICpcbiAqIFNlZSBgRGVwZW5kZW5jeVJlc29sdmVyI3NvcnRFbnRyeVBvaW50c0J5RGVwZW5kZW5jeSgpYC5cbiAqL1xuZXhwb3J0IHR5cGUgUGFydGlhbGx5T3JkZXJlZFRhc2tzID0gUGFydGlhbGx5T3JkZXJlZExpc3Q8VGFzaz47XG5cbi8qKlxuICogQSBtYXBwaW5nIGZyb20gVGFza3MgdG8gdGhlIFRhc2tzIHRoYXQgZGVwZW5kIHVwb24gdGhlbSAoZGVwZW5kZW50cykuXG4gKi9cbmV4cG9ydCB0eXBlIFRhc2tEZXBlbmRlbmNpZXMgPSBNYXA8VGFzaywgU2V0PFRhc2s+PjtcbmV4cG9ydCBjb25zdCBUYXNrRGVwZW5kZW5jaWVzID0gTWFwO1xuXG4vKipcbiAqIEEgZnVuY3Rpb24gdG8gY3JlYXRlIGEgVGFza0NvbXBsZXRlZENhbGxiYWNrIGZ1bmN0aW9uLlxuICovXG5leHBvcnQgdHlwZSBDcmVhdGVUYXNrQ29tcGxldGVkQ2FsbGJhY2sgPSAodGFza1F1ZXVlOiBUYXNrUXVldWUpID0+IFRhc2tDb21wbGV0ZWRDYWxsYmFjaztcblxuLyoqXG4gKiBBIGZ1bmN0aW9uIHRvIGJlIGNhbGxlZCBvbmNlIGEgdGFzayBoYXMgYmVlbiBwcm9jZXNzZWQuXG4gKi9cbmV4cG9ydCB0eXBlIFRhc2tDb21wbGV0ZWRDYWxsYmFjayA9XG4gICAgKHRhc2s6IFRhc2ssIG91dGNvbWU6IFRhc2tQcm9jZXNzaW5nT3V0Y29tZSwgbWVzc2FnZTogc3RyaW5nfG51bGwpID0+IHZvaWQ7XG5cbi8qKlxuICogUmVwcmVzZW50cyB0aGUgb3V0Y29tZSBvZiBwcm9jZXNzaW5nIGEgYFRhc2tgLlxuICovXG5leHBvcnQgY29uc3QgZW51bSBUYXNrUHJvY2Vzc2luZ091dGNvbWUge1xuICAvKiogU3VjY2Vzc2Z1bGx5IHByb2Nlc3NlZCB0aGUgdGFyZ2V0IGZvcm1hdCBwcm9wZXJ0eS4gKi9cbiAgUHJvY2Vzc2VkLFxuICAvKiogRmFpbGVkIHRvIHByb2Nlc3MgdGhlIHRhcmdldCBmb3JtYXQuICovXG4gIEZhaWxlZCxcbn1cblxuLyoqXG4gKiBBIHdyYXBwZXIgYXJvdW5kIGEgbGlzdCBvZiB0YXNrcyBhbmQgcHJvdmlkaW5nIHV0aWxpdHkgbWV0aG9kcyBmb3IgZ2V0dGluZyB0aGUgbmV4dCB0YXNrIG9mXG4gKiBpbnRlcmVzdCBhbmQgZGV0ZXJtaW5pbmcgd2hlbiBhbGwgdGFza3MgaGF2ZSBiZWVuIGNvbXBsZXRlZC5cbiAqXG4gKiAoVGhpcyBhbGxvd3MgZGlmZmVyZW50IGltcGxlbWVudGF0aW9ucyB0byBpbXBvc2UgZGlmZmVyZW50IGNvbnN0cmFpbnRzIG9uIHdoZW4gYSB0YXNrJ3NcbiAqIHByb2Nlc3NpbmcgY2FuIHN0YXJ0LilcbiAqL1xuZXhwb3J0IGludGVyZmFjZSBUYXNrUXVldWUge1xuICAvKiogV2hldGhlciBhbGwgdGFza3MgaGF2ZSBiZWVuIGNvbXBsZXRlZC4gKi9cbiAgYWxsVGFza3NDb21wbGV0ZWQ6IGJvb2xlYW47XG5cbiAgLyoqXG4gICAqIEdldCB0aGUgbmV4dCB0YXNrIHdob3NlIHByb2Nlc3NpbmcgY2FuIHN0YXJ0IChpZiBhbnkpLlxuICAgKlxuICAgKiBUaGlzIGltcGxpY2l0bHkgbWFya3MgdGhlIHRhc2sgYXMgaW4tcHJvZ3Jlc3MuXG4gICAqIChUaGlzIGluZm9ybWF0aW9uIGlzIHVzZWQgdG8gZGV0ZXJtaW5lIHdoZXRoZXIgYWxsIHRhc2tzIGhhdmUgYmVlbiBjb21wbGV0ZWQuKVxuICAgKlxuICAgKiBAcmV0dXJuIFRoZSBuZXh0IHRhc2sgYXZhaWxhYmxlIGZvciBwcm9jZXNzaW5nIG9yIGBudWxsYCwgaWYgbm8gdGFzayBjYW4gYmUgcHJvY2Vzc2VkIGF0IHRoZVxuICAgKiAgICAgICAgIG1vbWVudCAoaW5jbHVkaW5nIGlmIHRoZXJlIGFyZSBubyBtb3JlIHVucHJvY2Vzc2VkIHRhc2tzKS5cbiAgICovXG4gIGdldE5leHRUYXNrKCk6IFRhc2t8bnVsbDtcblxuICAvKipcbiAgICogTWFyayBhIHRhc2sgYXMgY29tcGxldGVkLlxuICAgKlxuICAgKiBUaGlzIHJlbW92ZXMgdGhlIHRhc2sgZnJvbSB0aGUgaW50ZXJuYWwgbGlzdCBvZiBpbi1wcm9ncmVzcyB0YXNrcy5cbiAgICogKFRoaXMgaW5mb3JtYXRpb24gaXMgdXNlZCB0byBkZXRlcm1pbmUgd2hldGhlciBhbGwgdGFza3MgaGF2ZSBiZWVuIGNvbXBsZXRlZC4pXG4gICAqXG4gICAqIEBwYXJhbSB0YXNrIFRoZSB0YXNrIHRvIG1hcmsgYXMgY29tcGxldGVkLlxuICAgKi9cbiAgbWFya0FzQ29tcGxldGVkKHRhc2s6IFRhc2spOiB2b2lkO1xuXG4gIC8qKlxuICAgKiBNYXJrIGEgdGFzayBhcyBmYWlsZWQuXG4gICAqXG4gICAqIERvIG5vdCBwcm9jZXNzIHRoZSB0YXNrcyB0aGF0IGRlcGVuZCB1cG9uIHRoZSBnaXZlbiB0YXNrLlxuICAgKi9cbiAgbWFya0FzRmFpbGVkKHRhc2s6IFRhc2spOiB2b2lkO1xuXG4gIC8qKlxuICAgKiBNYXJrIGEgdGFzayBhcyBub3QgcHJvY2Vzc2VkIChpLmUuIGFkZCBhbiBpbi1wcm9ncmVzcyB0YXNrIGJhY2sgdG8gdGhlIHF1ZXVlKS5cbiAgICpcbiAgICogVGhpcyByZW1vdmVzIHRoZSB0YXNrIGZyb20gdGhlIGludGVybmFsIGxpc3Qgb2YgaW4tcHJvZ3Jlc3MgdGFza3MgYW5kIGFkZHMgaXQgYmFjayB0byB0aGUgbGlzdFxuICAgKiBvZiBwZW5kaW5nIHRhc2tzLlxuICAgKlxuICAgKiBAcGFyYW0gdGFzayBUaGUgdGFzayB0byBtYXJrIGFzIG5vdCBwcm9jZXNzZWQuXG4gICAqL1xuICBtYXJrQXNVbnByb2Nlc3NlZCh0YXNrOiBUYXNrKTogdm9pZDtcblxuICAvKipcbiAgICogUmV0dXJuIGEgc3RyaW5nIHJlcHJlc2VudGF0aW9uIG9mIHRoZSB0YXNrIHF1ZXVlIChmb3IgZGVidWdnaW5nIHB1cnBvc2VzKS5cbiAgICpcbiAgICogQHJldHVybiBBIHN0cmluZyByZXByZXNlbnRhdGlvbiBvZiB0aGUgdGFzayBxdWV1ZS5cbiAgICovXG4gIHRvU3RyaW5nKCk6IHN0cmluZztcbn1cbiJdfQ==
|
|
@@ -24,8 +24,9 @@ export declare abstract class BaseTaskQueue implements TaskQueue {
|
|
|
24
24
|
constructor(logger: Logger, tasks: PartiallyOrderedTasks, dependencies: TaskDependencies);
|
|
25
25
|
protected abstract computeNextTask(): Task | null;
|
|
26
26
|
getNextTask(): Task | null;
|
|
27
|
+
markAsCompleted(task: Task): void;
|
|
27
28
|
markAsFailed(task: Task): void;
|
|
28
|
-
|
|
29
|
+
markAsUnprocessed(task: Task): void;
|
|
29
30
|
toString(): string;
|
|
30
31
|
/**
|
|
31
32
|
* Mark the given `task` as to be skipped, then recursive skip all its dependents.
|
|
@@ -39,13 +39,19 @@
|
|
|
39
39
|
break;
|
|
40
40
|
}
|
|
41
41
|
// We are skipping this task so mark it as complete
|
|
42
|
-
this.
|
|
42
|
+
this.markAsCompleted(nextTask);
|
|
43
43
|
var failedTask = this.tasksToSkip.get(nextTask);
|
|
44
44
|
this.logger.warn("Skipping processing of " + nextTask.entryPoint.name + " because its dependency " + failedTask.entryPoint.name + " failed to compile.");
|
|
45
45
|
nextTask = this.computeNextTask();
|
|
46
46
|
}
|
|
47
47
|
return nextTask;
|
|
48
48
|
};
|
|
49
|
+
BaseTaskQueue.prototype.markAsCompleted = function (task) {
|
|
50
|
+
if (!this.inProgressTasks.has(task)) {
|
|
51
|
+
throw new Error("Trying to mark task that was not in progress as completed: " + utils_1.stringifyTask(task));
|
|
52
|
+
}
|
|
53
|
+
this.inProgressTasks.delete(task);
|
|
54
|
+
};
|
|
49
55
|
BaseTaskQueue.prototype.markAsFailed = function (task) {
|
|
50
56
|
var e_1, _a;
|
|
51
57
|
if (this.dependencies.has(task)) {
|
|
@@ -64,11 +70,12 @@
|
|
|
64
70
|
}
|
|
65
71
|
}
|
|
66
72
|
};
|
|
67
|
-
BaseTaskQueue.prototype.
|
|
73
|
+
BaseTaskQueue.prototype.markAsUnprocessed = function (task) {
|
|
68
74
|
if (!this.inProgressTasks.has(task)) {
|
|
69
|
-
throw new Error("Trying to mark task that was not in progress as
|
|
75
|
+
throw new Error("Trying to mark task that was not in progress as unprocessed: " + utils_1.stringifyTask(task));
|
|
70
76
|
}
|
|
71
77
|
this.inProgressTasks.delete(task);
|
|
78
|
+
this.tasks.unshift(task);
|
|
72
79
|
};
|
|
73
80
|
BaseTaskQueue.prototype.toString = function () {
|
|
74
81
|
var inProgTasks = Array.from(this.inProgressTasks);
|
|
@@ -109,4 +116,4 @@
|
|
|
109
116
|
}());
|
|
110
117
|
exports.BaseTaskQueue = BaseTaskQueue;
|
|
111
118
|
});
|
|
112
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
119
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"base_task_queue.js","sourceRoot":"","sources":["../../../../../../../../../../packages/compiler-cli/ngcc/src/execution/tasks/queues/base_task_queue.ts"],"names":[],"mappings":";;;;;;;;;;;;IASA,8EAAuC;IAGvC;;OAEG;IACH;QAWE,uBACc,MAAc,EAAY,KAA4B,EACtD,YAA8B;YAD9B,WAAM,GAAN,MAAM,CAAQ;YAAY,UAAK,GAAL,KAAK,CAAuB;YACtD,iBAAY,GAAZ,YAAY,CAAkB;YATlC,oBAAe,GAAG,IAAI,GAAG,EAAQ,CAAC;YAE5C;;eAEG;YACK,gBAAW,GAAG,IAAI,GAAG,EAAc,CAAC;QAIG,CAAC;QAZhD,sBAAI,4CAAiB;iBAArB;gBACE,OAAO,CAAC,IAAI,CAAC,KAAK,CAAC,MAAM,KAAK,CAAC,CAAC,IAAI,CAAC,IAAI,CAAC,eAAe,CAAC,IAAI,KAAK,CAAC,CAAC,CAAC;YACxE,CAAC;;;WAAA;QAcD,mCAAW,GAAX;YACE,IAAI,QAAQ,GAAG,IAAI,CAAC,eAAe,EAAE,CAAC;YACtC,OAAO,QAAQ,KAAK,IAAI,EAAE;gBACxB,IAAI,CAAC,IAAI,CAAC,WAAW,CAAC,GAAG,CAAC,QAAQ,CAAC,EAAE;oBACnC,MAAM;iBACP;gBACD,mDAAmD;gBACnD,IAAI,CAAC,eAAe,CAAC,QAAQ,CAAC,CAAC;gBAC/B,IAAM,UAAU,GAAG,IAAI,CAAC,WAAW,CAAC,GAAG,CAAC,QAAQ,CAAE,CAAC;gBACnD,IAAI,CAAC,MAAM,CAAC,IAAI,CAAC,4BAA0B,QAAQ,CAAC,UAAU,CAAC,IAAI,gCAC/D,UAAU,CAAC,UAAU,CAAC,IAAI,wBAAqB,CAAC,CAAC;gBACrD,QAAQ,GAAG,IAAI,CAAC,eAAe,EAAE,CAAC;aACnC;YACD,OAAO,QAAQ,CAAC;QAClB,CAAC;QAED,uCAAe,GAAf,UAAgB,IAAU;YACxB,IAAI,CAAC,IAAI,CAAC,eAAe,CAAC,GAAG,CAAC,IAAI,CAAC,EAAE;gBACnC,MAAM,IAAI,KAAK,CACX,gEAA8D,qBAAa,CAAC,IAAI,CAAG,CAAC,CAAC;aAC1F;YAED,IAAI,CAAC,eAAe,CAAC,MAAM,CAAC,IAAI,CAAC,CAAC;QACpC,CAAC;QAED,oCAAY,GAAZ,UAAa,IAAU;;YACrB,IAAI,IAAI,CAAC,YAAY,CAAC,GAAG,CAAC,IAAI,CAAC,EAAE;;oBAC/B,KAA4B,IAAA,KAAA,iBAAA,IAAI,CAAC,YAAY,CAAC,GAAG,CAAC,IAAI,CAAE,CAAA,gBAAA,4BAAE;wBAArD,IAAM,aAAa,WAAA;wBACtB,IAAI,CAAC,kBAAkB,CAAC,aAAa,EAAE,IAAI,CAAC,CAAC;qBAC9C;;;;;;;;;aACF;QACH,CAAC;QAED,yCAAiB,GAAjB,UAAkB,IAAU;YAC1B,IAAI,CAAC,IAAI,CAAC,eAAe,CAAC,GAAG,CAAC,IAAI,CAAC,EAAE;gBACnC,MAAM,IAAI,KAAK,CACX,kEAAgE,qBAAa,CAAC,IAAI,CAAG,CAAC,CAAC;aAC5F;YAED,IAAI,CAAC,eAAe,CAAC,MAAM,CAAC,IAAI,CAAC,CAAC;YAClC,IAAI,CAAC,KAAK,CAAC,OAAO,CAAC,IAAI,CAAC,CAAC;QAC3B,CAAC;QAED,gCAAQ,GAAR;YACE,IAAM,WAAW,GAAG,KAAK,CAAC,IAAI,CAAC,IAAI,CAAC,eAAe,CAAC,CAAC;YAErD,OAAU,IAAI,CAAC,WAAW,CAAC,IAAI,OAAI;iBAC/B,4BAA0B,IAAI,CAAC,iBAAiB,OAAI,CAAA;iBACpD,0BAAwB,IAAI,CAAC,KAAK,CAAC,MAAM,WAAM,IAAI,CAAC,cAAc,CAAC,IAAI,CAAC,KAAK,EAAE,MAAM,CAAC,OAAI,CAAA;iBAC1F,0BAAwB,WAAW,CAAC,MAAM,WAAM,IAAI,CAAC,cAAc,CAAC,WAAW,EAAE,MAAM,CAAG,CAAA,CAAC;QACjG,CAAC;QAED;;;;;WAKG;QACO,0CAAkB,GAA5B,UAA6B,IAAU,EAAE,UAAgB;;YACvD,IAAI,CAAC,WAAW,CAAC,GAAG,CAAC,IAAI,EAAE,UAAU,CAAC,CAAC;YACvC,IAAI,IAAI,CAAC,YAAY,CAAC,GAAG,CAAC,IAAI,CAAC,EAAE;;oBAC/B,KAA4B,IAAA,KAAA,iBAAA,IAAI,CAAC,YAAY,CAAC,GAAG,CAAC,IAAI,CAAE,CAAA,gBAAA,4BAAE;wBAArD,IAAM,aAAa,WAAA;wBACtB,IAAI,CAAC,kBAAkB,CAAC,aAAa,EAAE,UAAU,CAAC,CAAC;qBACpD;;;;;;;;;aACF;QACH,CAAC;QAES,sCAAc,GAAxB,UAAyB,KAAa,EAAE,WAAmB;YACzD,OAAO,KAAK,CAAC,GAAG,CAAC,UAAA,IAAI,IAAI,OAAA,OAAK,WAAW,UAAK,qBAAa,CAAC,IAAI,CAAG,EAA1C,CAA0C,CAAC,CAAC,IAAI,CAAC,EAAE,CAAC,CAAC;QAChF,CAAC;QACH,oBAAC;IAAD,CAAC,AAvFD,IAuFC;IAvFqB,sCAAa","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 {Logger} from '../../../logging/logger';\nimport {PartiallyOrderedTasks, Task, TaskDependencies, TaskQueue} from '../api';\nimport {stringifyTask} from '../utils';\n\n\n/**\n * A base `TaskQueue` implementation to be used as base for concrete implementations.\n */\nexport abstract class BaseTaskQueue implements TaskQueue {\n  get allTasksCompleted(): boolean {\n    return (this.tasks.length === 0) && (this.inProgressTasks.size === 0);\n  }\n  protected inProgressTasks = new Set<Task>();\n\n  /**\n   * A map of tasks that should be skipped, mapped to the task that caused them to be skipped.\n   */\n  private tasksToSkip = new Map<Task, Task>();\n\n  constructor(\n      protected logger: Logger, protected tasks: PartiallyOrderedTasks,\n      protected dependencies: TaskDependencies) {}\n\n  protected abstract computeNextTask(): Task|null;\n\n  getNextTask(): Task|null {\n    let nextTask = this.computeNextTask();\n    while (nextTask !== null) {\n      if (!this.tasksToSkip.has(nextTask)) {\n        break;\n      }\n      // We are skipping this task so mark it as complete\n      this.markAsCompleted(nextTask);\n      const failedTask = this.tasksToSkip.get(nextTask)!;\n      this.logger.warn(`Skipping processing of ${nextTask.entryPoint.name} because its dependency ${\n          failedTask.entryPoint.name} failed to compile.`);\n      nextTask = this.computeNextTask();\n    }\n    return nextTask;\n  }\n\n  markAsCompleted(task: Task): void {\n    if (!this.inProgressTasks.has(task)) {\n      throw new Error(\n          `Trying to mark task that was not in progress as completed: ${stringifyTask(task)}`);\n    }\n\n    this.inProgressTasks.delete(task);\n  }\n\n  markAsFailed(task: Task): void {\n    if (this.dependencies.has(task)) {\n      for (const dependentTask of this.dependencies.get(task)!) {\n        this.skipDependentTasks(dependentTask, task);\n      }\n    }\n  }\n\n  markAsUnprocessed(task: Task): void {\n    if (!this.inProgressTasks.has(task)) {\n      throw new Error(\n          `Trying to mark task that was not in progress as unprocessed: ${stringifyTask(task)}`);\n    }\n\n    this.inProgressTasks.delete(task);\n    this.tasks.unshift(task);\n  }\n\n  toString(): string {\n    const inProgTasks = Array.from(this.inProgressTasks);\n\n    return `${this.constructor.name}\\n` +\n        `  All tasks completed: ${this.allTasksCompleted}\\n` +\n        `  Unprocessed tasks (${this.tasks.length}): ${this.stringifyTasks(this.tasks, '    ')}\\n` +\n        `  In-progress tasks (${inProgTasks.length}): ${this.stringifyTasks(inProgTasks, '    ')}`;\n  }\n\n  /**\n   * Mark the given `task` as to be skipped, then recursive skip all its dependents.\n   *\n   * @param task The task to skip\n   * @param failedTask The task that failed, causing this task to be skipped\n   */\n  protected skipDependentTasks(task: Task, failedTask: Task) {\n    this.tasksToSkip.set(task, failedTask);\n    if (this.dependencies.has(task)) {\n      for (const dependentTask of this.dependencies.get(task)!) {\n        this.skipDependentTasks(dependentTask, failedTask);\n      }\n    }\n  }\n\n  protected stringifyTasks(tasks: Task[], indentation: string): string {\n    return tasks.map(task => `\\n${indentation}- ${stringifyTask(task)}`).join('');\n  }\n}\n"]}
|
|
@@ -22,7 +22,7 @@ export declare class ParallelTaskQueue extends BaseTaskQueue {
|
|
|
22
22
|
private blockedTasks;
|
|
23
23
|
constructor(logger: Logger, tasks: PartiallyOrderedTasks, dependencies: TaskDependencies);
|
|
24
24
|
computeNextTask(): Task | null;
|
|
25
|
-
|
|
25
|
+
markAsCompleted(task: Task): void;
|
|
26
26
|
toString(): string;
|
|
27
27
|
private stringifyBlockedTasks;
|
|
28
28
|
}
|
|
@@ -36,9 +36,9 @@
|
|
|
36
36
|
this.inProgressTasks.add(nextTask);
|
|
37
37
|
return nextTask;
|
|
38
38
|
};
|
|
39
|
-
ParallelTaskQueue.prototype.
|
|
39
|
+
ParallelTaskQueue.prototype.markAsCompleted = function (task) {
|
|
40
40
|
var e_1, _a;
|
|
41
|
-
_super.prototype.
|
|
41
|
+
_super.prototype.markAsCompleted.call(this, task);
|
|
42
42
|
if (!this.dependencies.has(task)) {
|
|
43
43
|
return;
|
|
44
44
|
}
|
|
@@ -83,4 +83,4 @@
|
|
|
83
83
|
}(base_task_queue_1.BaseTaskQueue));
|
|
84
84
|
exports.ParallelTaskQueue = ParallelTaskQueue;
|
|
85
85
|
});
|
|
86
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
86
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoicGFyYWxsZWxfdGFza19xdWV1ZS5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uLy4uLy4uLy4uLy4uLy4uL3BhY2thZ2VzL2NvbXBpbGVyLWNsaS9uZ2NjL3NyYy9leGVjdXRpb24vdGFza3MvcXVldWVzL3BhcmFsbGVsX3Rhc2tfcXVldWUudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6Ijs7Ozs7Ozs7Ozs7O0lBU0EsOEVBQTZFO0lBQzdFLHlHQUFnRDtJQUVoRDs7O09BR0c7SUFDSDtRQUF1Qyw2Q0FBYTtRQVFsRCwyQkFBWSxNQUFjLEVBQUUsS0FBNEIsRUFBRSxZQUE4QjtZQUF4RixZQUNFLGtCQUFNLE1BQU0sRUFBRSwyQkFBbUIsQ0FBQyxLQUFLLEVBQUUsWUFBWSxDQUFDLEVBQUUsWUFBWSxDQUFDLFNBRXRFO1lBREMsS0FBSSxDQUFDLFlBQVksR0FBRyx1QkFBZSxDQUFDLFlBQVksQ0FBQyxDQUFDOztRQUNwRCxDQUFDO1FBRUQsMkNBQWUsR0FBZjtZQUFBLGlCQVlDO1lBWEMsd0RBQXdEO1lBQ3hELDBGQUEwRjtZQUMxRixJQUFNLFdBQVcsR0FBRyxJQUFJLENBQUMsS0FBSyxDQUFDLFNBQVMsQ0FBQyxVQUFBLElBQUksSUFBSSxPQUFBLENBQUMsS0FBSSxDQUFDLFlBQVksQ0FBQyxHQUFHLENBQUMsSUFBSSxDQUFDLEVBQTVCLENBQTRCLENBQUMsQ0FBQztZQUMvRSxJQUFJLFdBQVcsS0FBSyxDQUFDLENBQUM7Z0JBQUUsT0FBTyxJQUFJLENBQUM7WUFFcEMsZ0dBQWdHO1lBQ2hHLElBQU0sUUFBUSxHQUFHLElBQUksQ0FBQyxLQUFLLENBQUMsV0FBVyxDQUFDLENBQUM7WUFDekMsSUFBSSxDQUFDLEtBQUssQ0FBQyxNQUFNLENBQUMsV0FBVyxFQUFFLENBQUMsQ0FBQyxDQUFDO1lBQ2xDLElBQUksQ0FBQyxlQUFlLENBQUMsR0FBRyxDQUFDLFFBQVEsQ0FBQyxDQUFDO1lBRW5DLE9BQU8sUUFBUSxDQUFDO1FBQ2xCLENBQUM7UUFFRCwyQ0FBZSxHQUFmLFVBQWdCLElBQVU7O1lBQ3hCLGlCQUFNLGVBQWUsWUFBQyxJQUFJLENBQUMsQ0FBQztZQUU1QixJQUFJLENBQUMsSUFBSSxDQUFDLFlBQVksQ0FBQyxHQUFHLENBQUMsSUFBSSxDQUFDLEVBQUU7Z0JBQ2hDLE9BQU87YUFDUjs7Z0JBRUQsbURBQW1EO2dCQUNuRCxLQUE0QixJQUFBLEtBQUEsaUJBQUEsSUFBSSxDQUFDLFlBQVksQ0FBQyxHQUFHLENBQUMsSUFBSSxDQUFFLENBQUEsZ0JBQUEsNEJBQUU7b0JBQXJELElBQU0sYUFBYSxXQUFBO29CQUN0QixJQUFJLElBQUksQ0FBQyxZQUFZLENBQUMsR0FBRyxDQUFDLGFBQWEsQ0FBQyxFQUFFO3dCQUN4QyxJQUFNLGFBQWEsR0FBRyxJQUFJLENBQUMsWUFBWSxDQUFDLEdBQUcsQ0FBQyxhQUFhLENBQUUsQ0FBQzt3QkFDNUQsMEVBQTBFO3dCQUMxRSxhQUFhLENBQUMsTUFBTSxDQUFDLElBQUksQ0FBQyxDQUFDO3dCQUMzQixJQUFJLGFBQWEsQ0FBQyxJQUFJLEtBQUssQ0FBQyxFQUFFOzRCQUM1Qix5RUFBeUU7NEJBQ3pFLElBQUksQ0FBQyxZQUFZLENBQUMsTUFBTSxDQUFDLGFBQWEsQ0FBQyxDQUFDO3lCQUN6QztxQkFDRjtpQkFDRjs7Ozs7Ozs7O1FBQ0gsQ0FBQztRQUVELG9DQUFRLEdBQVI7WUFDRSxPQUFVLGlCQUFNLFFBQVEsV0FBRSxPQUFJO2lCQUMxQixzQkFBb0IsSUFBSSxDQUFDLFlBQVksQ0FBQyxJQUFJLFdBQU0sSUFBSSxDQUFDLHFCQUFxQixDQUFDLE1BQU0sQ0FBRyxDQUFBLENBQUM7UUFDM0YsQ0FBQztRQUVPLGlEQUFxQixHQUE3QixVQUE4QixXQUFtQjtZQUFqRCxpQkFPQztZQU5DLE9BQU8sS0FBSyxDQUFDLElBQUksQ0FBQyxJQUFJLENBQUMsWUFBWSxDQUFDO2lCQUMvQixHQUFHLENBQ0EsVUFBQyxFQUFxQjtvQkFBckIsMEJBQXFCLEVBQXBCLFlBQUksRUFBRSxxQkFBYTtnQkFDakIsT0FBQSxPQUFLLFdBQVcsVUFBSyxxQkFBYSxDQUFDLElBQUksQ0FBQyxVQUFLLGFBQWEsQ0FBQyxJQUFJLFFBQUs7b0JBQ3BFLEtBQUksQ0FBQyxjQUFjLENBQUMsS0FBSyxDQUFDLElBQUksQ0FBQyxhQUFhLENBQUMsRUFBSyxXQUFXLFNBQU0sQ0FBQztZQURwRSxDQUNvRSxDQUFDO2lCQUM1RSxJQUFJLENBQUMsRUFBRSxDQUFDLENBQUM7UUFDaEIsQ0FBQztRQUNILHdCQUFDO0lBQUQsQ0FBQyxBQTdERCxDQUF1QywrQkFBYSxHQTZEbkQ7SUE3RFksOENBQWlCIiwic291cmNlc0NvbnRlbnQiOlsiLyoqXG4gKiBAbGljZW5zZVxuICogQ29weXJpZ2h0IEdvb2dsZSBJbmMuIEFsbCBSaWdodHMgUmVzZXJ2ZWQuXG4gKlxuICogVXNlIG9mIHRoaXMgc291cmNlIGNvZGUgaXMgZ292ZXJuZWQgYnkgYW4gTUlULXN0eWxlIGxpY2Vuc2UgdGhhdCBjYW4gYmVcbiAqIGZvdW5kIGluIHRoZSBMSUNFTlNFIGZpbGUgYXQgaHR0cHM6Ly9hbmd1bGFyLmlvL2xpY2Vuc2VcbiAqL1xuaW1wb3J0IHtMb2dnZXJ9IGZyb20gJy4uLy4uLy4uL2xvZ2dpbmcvbG9nZ2VyJztcbmltcG9ydCB7UGFydGlhbGx5T3JkZXJlZFRhc2tzLCBUYXNrLCBUYXNrRGVwZW5kZW5jaWVzfSBmcm9tICcuLi9hcGknO1xuaW1wb3J0IHtnZXRCbG9ja2VkVGFza3MsIHNvcnRUYXNrc0J5UHJpb3JpdHksIHN0cmluZ2lmeVRhc2t9IGZyb20gJy4uL3V0aWxzJztcbmltcG9ydCB7QmFzZVRhc2tRdWV1ZX0gZnJvbSAnLi9iYXNlX3Rhc2tfcXVldWUnO1xuXG4vKipcbiAqIEEgYFRhc2tRdWV1ZWAgaW1wbGVtZW50YXRpb24gdGhhdCBhc3N1bWVzIHRhc2tzIGFyZSBwcm9jZXNzZWQgaW4gcGFyYWxsZWwsIHRodXMgaGFzIHRvIGVuc3VyZSBhXG4gKiB0YXNrJ3MgZGVwZW5kZW5jaWVzIGhhdmUgYmVlbiBwcm9jZXNzZWQgYmVmb3JlIHByb2Nlc3NpbmcgdGhlIHRhc2suXG4gKi9cbmV4cG9ydCBjbGFzcyBQYXJhbGxlbFRhc2tRdWV1ZSBleHRlbmRzIEJhc2VUYXNrUXVldWUge1xuICAvKipcbiAgICogQSBtYXAgZnJvbSBUYXNrcyB0byB0aGUgVGFza3MgdGhhdCBpdCBkZXBlbmRzIHVwb24uXG4gICAqXG4gICAqIFRoaXMgaXMgdGhlIHJldmVyc2UgbWFwcGluZyBvZiBgVGFza0RlcGVuZGVuY2llc2AuXG4gICAqL1xuICBwcml2YXRlIGJsb2NrZWRUYXNrczogTWFwPFRhc2ssIFNldDxUYXNrPj47XG5cbiAgY29uc3RydWN0b3IobG9nZ2VyOiBMb2dnZXIsIHRhc2tzOiBQYXJ0aWFsbHlPcmRlcmVkVGFza3MsIGRlcGVuZGVuY2llczogVGFza0RlcGVuZGVuY2llcykge1xuICAgIHN1cGVyKGxvZ2dlciwgc29ydFRhc2tzQnlQcmlvcml0eSh0YXNrcywgZGVwZW5kZW5jaWVzKSwgZGVwZW5kZW5jaWVzKTtcbiAgICB0aGlzLmJsb2NrZWRUYXNrcyA9IGdldEJsb2NrZWRUYXNrcyhkZXBlbmRlbmNpZXMpO1xuICB9XG5cbiAgY29tcHV0ZU5leHRUYXNrKCk6IFRhc2t8bnVsbCB7XG4gICAgLy8gTG9vayBmb3IgdGhlIGZpcnN0IGF2YWlsYWJsZSAoaS5lLiBub3QgYmxvY2tlZCkgdGFzay5cbiAgICAvLyAoTk9URTogU2luY2UgdGFza3MgYXJlIHNvcnRlZCBieSBwcmlvcml0eSwgdGhlIGZpcnN0IGF2YWlsYWJsZSBvbmUgaXMgdGhlIGJlc3QgY2hvaWNlLilcbiAgICBjb25zdCBuZXh0VGFza0lkeCA9IHRoaXMudGFza3MuZmluZEluZGV4KHRhc2sgPT4gIXRoaXMuYmxvY2tlZFRhc2tzLmhhcyh0YXNrKSk7XG4gICAgaWYgKG5leHRUYXNrSWR4ID09PSAtMSkgcmV0dXJuIG51bGw7XG5cbiAgICAvLyBSZW1vdmUgdGhlIHRhc2sgZnJvbSB0aGUgbGlzdCBvZiBhdmFpbGFibGUgdGFza3MgYW5kIGFkZCBpdCB0byB0aGUgbGlzdCBvZiBpbi1wcm9ncmVzcyB0YXNrcy5cbiAgICBjb25zdCBuZXh0VGFzayA9IHRoaXMudGFza3NbbmV4dFRhc2tJZHhdO1xuICAgIHRoaXMudGFza3Muc3BsaWNlKG5leHRUYXNrSWR4LCAxKTtcbiAgICB0aGlzLmluUHJvZ3Jlc3NUYXNrcy5hZGQobmV4dFRhc2spO1xuXG4gICAgcmV0dXJuIG5leHRUYXNrO1xuICB9XG5cbiAgbWFya0FzQ29tcGxldGVkKHRhc2s6IFRhc2spOiB2b2lkIHtcbiAgICBzdXBlci5tYXJrQXNDb21wbGV0ZWQodGFzayk7XG5cbiAgICBpZiAoIXRoaXMuZGVwZW5kZW5jaWVzLmhhcyh0YXNrKSkge1xuICAgICAgcmV0dXJuO1xuICAgIH1cblxuICAgIC8vIFVuYmxvY2sgdGhlIHRhc2tzIHRoYXQgYXJlIGRlcGVuZGVudCB1cG9uIGB0YXNrYFxuICAgIGZvciAoY29uc3QgZGVwZW5kZW50VGFzayBvZiB0aGlzLmRlcGVuZGVuY2llcy5nZXQodGFzaykhKSB7XG4gICAgICBpZiAodGhpcy5ibG9ja2VkVGFza3MuaGFzKGRlcGVuZGVudFRhc2spKSB7XG4gICAgICAgIGNvbnN0IGJsb2NraW5nVGFza3MgPSB0aGlzLmJsb2NrZWRUYXNrcy5nZXQoZGVwZW5kZW50VGFzaykhO1xuICAgICAgICAvLyBSZW1vdmUgdGhlIGNvbXBsZXRlZCB0YXNrIGZyb20gdGhlIGxpc3RzIG9mIHRhc2tzIGJsb2NraW5nIG90aGVyIHRhc2tzLlxuICAgICAgICBibG9ja2luZ1Rhc2tzLmRlbGV0ZSh0YXNrKTtcbiAgICAgICAgaWYgKGJsb2NraW5nVGFza3Muc2l6ZSA9PT0gMCkge1xuICAgICAgICAgIC8vIElmIHRoZSBkZXBlbmRlbnQgdGFzayBpcyBub3QgYmxvY2tlZCBhbnkgbW9yZSwgbWFyayBpdCBmb3IgdW5ibG9ja2luZy5cbiAgICAgICAgICB0aGlzLmJsb2NrZWRUYXNrcy5kZWxldGUoZGVwZW5kZW50VGFzayk7XG4gICAgICAgIH1cbiAgICAgIH1cbiAgICB9XG4gIH1cblxuICB0b1N0cmluZygpOiBzdHJpbmcge1xuICAgIHJldHVybiBgJHtzdXBlci50b1N0cmluZygpfVxcbmAgK1xuICAgICAgICBgICBCbG9ja2VkIHRhc2tzICgke3RoaXMuYmxvY2tlZFRhc2tzLnNpemV9KTogJHt0aGlzLnN0cmluZ2lmeUJsb2NrZWRUYXNrcygnICAgICcpfWA7XG4gIH1cblxuICBwcml2YXRlIHN0cmluZ2lmeUJsb2NrZWRUYXNrcyhpbmRlbnRhdGlvbjogc3RyaW5nKTogc3RyaW5nIHtcbiAgICByZXR1cm4gQXJyYXkuZnJvbSh0aGlzLmJsb2NrZWRUYXNrcylcbiAgICAgICAgLm1hcChcbiAgICAgICAgICAgIChbdGFzaywgYmxvY2tpbmdUYXNrc10pID0+XG4gICAgICAgICAgICAgICAgYFxcbiR7aW5kZW50YXRpb259LSAke3N0cmluZ2lmeVRhc2sodGFzayl9ICgke2Jsb2NraW5nVGFza3Muc2l6ZX0pOiBgICtcbiAgICAgICAgICAgICAgICB0aGlzLnN0cmluZ2lmeVRhc2tzKEFycmF5LmZyb20oYmxvY2tpbmdUYXNrcyksIGAke2luZGVudGF0aW9ufSAgICBgKSlcbiAgICAgICAgLmpvaW4oJycpO1xuICB9XG59XG4iXX0=
|