source: trip-planner-front/node_modules/@angular/compiler-cli/ngcc/src/execution/cluster/worker.js

Last change on this file was 6a3a178, checked in by Ema <ema_spirova@…>, 3 years ago

initial commit

  • Property mode set to 100644
File size: 15.6 KB
Line 
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"]}
Note: See TracBrowser for help on using the repository browser.