1 | /**
|
---|
2 | * @license
|
---|
3 | * Copyright Google LLC All Rights Reserved.
|
---|
4 | *
|
---|
5 | * Use of this source code is governed by an MIT-style license that can be
|
---|
6 | * found in the LICENSE file at https://angular.io/license
|
---|
7 | */
|
---|
8 | /// <reference types="node" />
|
---|
9 | (function (factory) {
|
---|
10 | if (typeof module === "object" && typeof module.exports === "object") {
|
---|
11 | var v = factory(require, exports);
|
---|
12 | if (v !== undefined) module.exports = v;
|
---|
13 | }
|
---|
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/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 | }
|
---|
17 | })(function (require, exports) {
|
---|
18 | "use strict";
|
---|
19 | Object.defineProperty(exports, "__esModule", { value: true });
|
---|
20 | exports.startWorker = void 0;
|
---|
21 | var tslib_1 = require("tslib");
|
---|
22 | var cluster = require("cluster");
|
---|
23 | var command_line_options_1 = require("@angular/compiler-cli/ngcc/src/command_line_options");
|
---|
24 | var ngcc_options_1 = require("@angular/compiler-cli/ngcc/src/ngcc_options");
|
---|
25 | var create_compile_function_1 = require("@angular/compiler-cli/ngcc/src/execution/create_compile_function");
|
---|
26 | var utils_1 = require("@angular/compiler-cli/ngcc/src/execution/tasks/utils");
|
---|
27 | var package_json_updater_1 = require("@angular/compiler-cli/ngcc/src/execution/cluster/package_json_updater");
|
---|
28 | var utils_2 = require("@angular/compiler-cli/ngcc/src/execution/cluster/utils");
|
---|
29 | // Cluster worker entry point
|
---|
30 | if (require.main === module) {
|
---|
31 | (function () { return tslib_1.__awaiter(void 0, void 0, void 0, function () {
|
---|
32 | var _a, logger, pathMappings, enableI18nLegacyMessageIdFormat, fileSystem, tsConfig, getFileWriter, pkgJsonUpdater, fileWriter, createCompileFn, e_1;
|
---|
33 | return tslib_1.__generator(this, function (_b) {
|
---|
34 | switch (_b.label) {
|
---|
35 | case 0:
|
---|
36 | process.title = 'ngcc (worker)';
|
---|
37 | _b.label = 1;
|
---|
38 | case 1:
|
---|
39 | _b.trys.push([1, 3, , 4]);
|
---|
40 | _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;
|
---|
41 | pkgJsonUpdater = new package_json_updater_1.ClusterWorkerPackageJsonUpdater();
|
---|
42 | fileWriter = getFileWriter(pkgJsonUpdater);
|
---|
43 | createCompileFn = create_compile_function_1.getCreateCompileFn(fileSystem, logger, fileWriter, enableI18nLegacyMessageIdFormat, tsConfig, pathMappings);
|
---|
44 | return [4 /*yield*/, startWorker(logger, createCompileFn)];
|
---|
45 | case 2:
|
---|
46 | _b.sent();
|
---|
47 | process.exitCode = 0;
|
---|
48 | return [3 /*break*/, 4];
|
---|
49 | case 3:
|
---|
50 | e_1 = _b.sent();
|
---|
51 | console.error(e_1.stack || e_1.message);
|
---|
52 | process.exit(1);
|
---|
53 | return [3 /*break*/, 4];
|
---|
54 | case 4: return [2 /*return*/];
|
---|
55 | }
|
---|
56 | });
|
---|
57 | }); })();
|
---|
58 | }
|
---|
59 | function startWorker(logger, createCompileFn) {
|
---|
60 | return tslib_1.__awaiter(this, void 0, void 0, function () {
|
---|
61 | var compile;
|
---|
62 | var _this = this;
|
---|
63 | return tslib_1.__generator(this, function (_a) {
|
---|
64 | if (cluster.isMaster) {
|
---|
65 | throw new Error('Tried to run cluster worker on the master process.');
|
---|
66 | }
|
---|
67 | compile = createCompileFn(function (transformedFiles) { return utils_2.sendMessageToMaster({
|
---|
68 | type: 'transformed-files',
|
---|
69 | files: transformedFiles.map(function (f) { return f.path; }),
|
---|
70 | }); }, function (_task, outcome, message) { return utils_2.sendMessageToMaster({ type: 'task-completed', outcome: outcome, message: message }); });
|
---|
71 | // Listen for `ProcessTaskMessage`s and process tasks.
|
---|
72 | cluster.worker.on('message', function (msg) { return tslib_1.__awaiter(_this, void 0, void 0, function () {
|
---|
73 | var _a, err_1, _b;
|
---|
74 | return tslib_1.__generator(this, function (_c) {
|
---|
75 | switch (_c.label) {
|
---|
76 | case 0:
|
---|
77 | _c.trys.push([0, 5, , 10]);
|
---|
78 | _a = msg.type;
|
---|
79 | switch (_a) {
|
---|
80 | case 'process-task': return [3 /*break*/, 1];
|
---|
81 | }
|
---|
82 | return [3 /*break*/, 3];
|
---|
83 | case 1:
|
---|
84 | logger.debug("[Worker #" + cluster.worker.id + "] Processing task: " + utils_1.stringifyTask(msg.task));
|
---|
85 | return [4 /*yield*/, compile(msg.task)];
|
---|
86 | case 2: return [2 /*return*/, _c.sent()];
|
---|
87 | case 3: throw new Error("[Worker #" + cluster.worker.id + "] Invalid message received: " + JSON.stringify(msg));
|
---|
88 | case 4: return [3 /*break*/, 10];
|
---|
89 | case 5:
|
---|
90 | err_1 = _c.sent();
|
---|
91 | _b = err_1 && err_1.code;
|
---|
92 | switch (_b) {
|
---|
93 | case 'ENOMEM': return [3 /*break*/, 6];
|
---|
94 | }
|
---|
95 | return [3 /*break*/, 7];
|
---|
96 | case 6:
|
---|
97 | // Not being able to allocate enough memory is not necessarily a problem with processing
|
---|
98 | // the current task. It could just mean that there are too many tasks being processed
|
---|
99 | // simultaneously.
|
---|
100 | //
|
---|
101 | // Exit with an error and let the cluster master decide how to handle this.
|
---|
102 | logger.warn("[Worker #" + cluster.worker.id + "] " + (err_1.stack || err_1.message));
|
---|
103 | return [2 /*return*/, process.exit(1)];
|
---|
104 | case 7: return [4 /*yield*/, utils_2.sendMessageToMaster({
|
---|
105 | type: 'error',
|
---|
106 | error: (err_1 instanceof Error) ? (err_1.stack || err_1.message) : err_1,
|
---|
107 | })];
|
---|
108 | case 8:
|
---|
109 | _c.sent();
|
---|
110 | _c.label = 9;
|
---|
111 | case 9: return [3 /*break*/, 10];
|
---|
112 | case 10: return [2 /*return*/];
|
---|
113 | }
|
---|
114 | });
|
---|
115 | }); });
|
---|
116 | // Return a promise that is never resolved.
|
---|
117 | return [2 /*return*/, new Promise(function () { return undefined; })];
|
---|
118 | });
|
---|
119 | });
|
---|
120 | }
|
---|
121 | exports.startWorker = startWorker;
|
---|
122 | });
|
---|
123 | //# 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 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 */\n/// <reference types=\"node\" />\n\nimport * as cluster from 'cluster';\n\nimport {Logger} from '../../../../src/ngtsc/logging';\nimport {parseCommandLineOptions} from '../../command_line_options';\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"]} |
---|