@angular/compiler-cli 9.0.6 → 9.0.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.
Files changed (38) hide show
  1. package/ngcc/index.d.ts +2 -2
  2. package/ngcc/index.js +4 -3
  3. package/ngcc/main-ngcc.js +4 -3
  4. package/ngcc/src/execution/cluster/executor.d.ts +2 -2
  5. package/ngcc/src/execution/cluster/executor.js +1 -1
  6. package/ngcc/src/execution/single_process_executor.d.ts +13 -7
  7. package/ngcc/src/execution/single_process_executor.js +55 -38
  8. package/ngcc/src/host/commonjs_host.js +2 -7
  9. package/ngcc/src/host/delegating_host.d.ts +44 -0
  10. package/ngcc/src/host/delegating_host.js +146 -0
  11. package/ngcc/src/host/esm5_host.js +1 -7
  12. package/ngcc/src/host/umd_host.js +2 -7
  13. package/ngcc/src/locking/lock_file.d.ts +29 -0
  14. package/ngcc/src/locking/lock_file.js +17 -0
  15. package/ngcc/src/locking/lock_file_with_child_process/index.d.ts +41 -0
  16. package/ngcc/src/locking/lock_file_with_child_process/index.js +91 -0
  17. package/ngcc/src/locking/lock_file_with_child_process/unlocker.d.ts +2 -0
  18. package/ngcc/src/locking/lock_file_with_child_process/unlocker.js +44 -0
  19. package/ngcc/src/locking/lock_file_with_child_process/util.d.ts +17 -0
  20. package/ngcc/src/locking/lock_file_with_child_process/util.js +42 -0
  21. package/ngcc/src/locking/sync_locker.d.ts +36 -0
  22. package/ngcc/src/locking/sync_locker.js +67 -0
  23. package/ngcc/src/logging/console_logger.d.ts +3 -9
  24. package/ngcc/src/logging/console_logger.js +16 -15
  25. package/ngcc/src/logging/logger.d.ts +7 -0
  26. package/ngcc/src/logging/logger.js +8 -1
  27. package/ngcc/src/main.js +23 -14
  28. package/ngcc/src/packages/build_marker.d.ts +1 -1
  29. package/ngcc/src/packages/build_marker.js +1 -1
  30. package/ngcc/src/packages/transformer.js +8 -4
  31. package/ngcc/src/sourcemaps/segment_marker.d.ts +7 -15
  32. package/ngcc/src/sourcemaps/segment_marker.js +12 -41
  33. package/ngcc/src/sourcemaps/source_file.d.ts +31 -4
  34. package/ngcc/src/sourcemaps/source_file.js +117 -33
  35. package/package.json +2 -2
  36. package/src/version.js +1 -1
  37. package/ngcc/src/execution/lock_file.d.ts +0 -43
  38. package/ngcc/src/execution/lock_file.js +0 -129
@@ -1,129 +0,0 @@
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/lock_file", ["require", "exports", "process"], factory);
8
- }
9
- })(function (require, exports) {
10
- "use strict";
11
- Object.defineProperty(exports, "__esModule", { value: true });
12
- /**
13
- * @license
14
- * Copyright Google Inc. All Rights Reserved.
15
- *
16
- * Use of this source code is governed by an MIT-style license that can be
17
- * found in the LICENSE file at https://angular.io/license
18
- */
19
- var process = require("process");
20
- /**
21
- * The LockFile is used to prevent more than one instance of ngcc executing at the same time.
22
- *
23
- * When ngcc starts executing, it creates a file in the `compiler-cli/ngcc` folder. If it finds one
24
- * is already there then it fails with a suitable error message.
25
- * When ngcc completes executing, it removes the file so that future ngcc executions can start.
26
- */
27
- var LockFile = /** @class */ (function () {
28
- function LockFile(fs) {
29
- var _this = this;
30
- this.fs = fs;
31
- this.lockFilePath = this.fs.resolve(require.resolve('@angular/compiler-cli/ngcc'), '../__ngcc_lock_file__');
32
- /**
33
- * This handle needs to be defined as a property rather than a method
34
- * so that it can be passed around as a bound function.
35
- */
36
- this.signalHandler = function () {
37
- _this.remove();
38
- _this.exit(1);
39
- };
40
- }
41
- /**
42
- * Run a function guarded by the lock file.
43
- *
44
- * Note that T can be a Promise. If so, we run the `remove()` call in the promise's `finally`
45
- * handler. Otherwise we run the `remove()` call in the `try...finally` block.
46
- *
47
- * @param fn The function to run.
48
- */
49
- LockFile.prototype.lock = function (fn) {
50
- var _this = this;
51
- var isAsync = false;
52
- this.create();
53
- try {
54
- var result = fn();
55
- if (result instanceof Promise) {
56
- isAsync = true;
57
- // The cast is necessary because TS cannot deduce that T is now a promise here.
58
- return result.finally(function () { return _this.remove(); });
59
- }
60
- else {
61
- return result;
62
- }
63
- }
64
- finally {
65
- if (!isAsync) {
66
- this.remove();
67
- }
68
- }
69
- };
70
- /**
71
- * Write a lock file to disk, or error if there is already one there.
72
- */
73
- LockFile.prototype.create = function () {
74
- try {
75
- this.addSignalHandlers();
76
- // To avoid race conditions, we check for existence of the lockfile
77
- // by actually trying to create it exclusively
78
- this.fs.writeFile(this.lockFilePath, process.pid.toString(), /* exclusive */ true);
79
- }
80
- catch (e) {
81
- this.removeSignalHandlers();
82
- if (e.code !== 'EEXIST') {
83
- throw e;
84
- }
85
- // The lockfile already exists so raise a helpful error.
86
- // It is feasible that the lockfile was removed between the previous check for existence
87
- // and this file-read. If so then we still error but as gracefully as possible.
88
- var pid = void 0;
89
- try {
90
- pid = this.fs.readFile(this.lockFilePath);
91
- }
92
- catch (_a) {
93
- pid = '{unknown}';
94
- }
95
- throw new Error("ngcc is already running at process with id " + pid + ".\n" +
96
- "If you are running multiple builds in parallel then you should pre-process your node_modules via the command line ngcc tool before starting the builds;\n" +
97
- "See https://v9.angular.io/guide/ivy#speeding-up-ngcc-compilation.\n" +
98
- ("(If you are sure no ngcc process is running then you should delete the lockfile at " + this.lockFilePath + ".)"));
99
- }
100
- };
101
- /**
102
- * Remove the lock file from disk.
103
- */
104
- LockFile.prototype.remove = function () {
105
- this.removeSignalHandlers();
106
- if (this.fs.exists(this.lockFilePath)) {
107
- this.fs.removeFile(this.lockFilePath);
108
- }
109
- };
110
- LockFile.prototype.addSignalHandlers = function () {
111
- process.once('SIGINT', this.signalHandler);
112
- process.once('SIGHUP', this.signalHandler);
113
- };
114
- LockFile.prototype.removeSignalHandlers = function () {
115
- process.removeListener('SIGINT', this.signalHandler);
116
- process.removeListener('SIGHUP', this.signalHandler);
117
- };
118
- /**
119
- * This function wraps `process.exit()` which makes it easier to manage in unit tests,
120
- * since it is not possible to mock out `process.exit()` when it is called from signal handlers.
121
- */
122
- LockFile.prototype.exit = function (code) {
123
- process.exit(code);
124
- };
125
- return LockFile;
126
- }());
127
- exports.LockFile = LockFile;
128
- });
129
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"lock_file.js","sourceRoot":"","sources":["../../../../../../../../packages/compiler-cli/ngcc/src/execution/lock_file.ts"],"names":[],"mappings":";;;;;;;;;;;IAAA;;;;;;OAMG;IACH,iCAAmC;IAGnC;;;;;;OAMG;IACH;QAIE,kBAAoB,EAAc;YAAlC,iBAAsC;YAAlB,OAAE,GAAF,EAAE,CAAY;YAHlC,iBAAY,GACR,IAAI,CAAC,EAAE,CAAC,OAAO,CAAC,OAAO,CAAC,OAAO,CAAC,4BAA4B,CAAC,EAAE,uBAAuB,CAAC,CAAC;YAoF5F;;;eAGG;YACO,kBAAa,GACnB;gBACE,KAAI,CAAC,MAAM,EAAE,CAAC;gBACd,KAAI,CAAC,IAAI,CAAC,CAAC,CAAC,CAAC;YACf,CAAC,CAAA;QA1FgC,CAAC;QAEtC;;;;;;;WAOG;QACH,uBAAI,GAAJ,UAAQ,EAAW;YAAnB,iBAiBC;YAhBC,IAAI,OAAO,GAAG,KAAK,CAAC;YACpB,IAAI,CAAC,MAAM,EAAE,CAAC;YACd,IAAI;gBACF,IAAM,MAAM,GAAG,EAAE,EAAE,CAAC;gBACpB,IAAI,MAAM,YAAY,OAAO,EAAE;oBAC7B,OAAO,GAAG,IAAI,CAAC;oBACf,+EAA+E;oBAC/E,OAAO,MAAM,CAAC,OAAO,CAAC,cAAM,OAAA,KAAI,CAAC,MAAM,EAAE,EAAb,CAAa,CAAiB,CAAC;iBAC5D;qBAAM;oBACL,OAAO,MAAM,CAAC;iBACf;aACF;oBAAS;gBACR,IAAI,CAAC,OAAO,EAAE;oBACZ,IAAI,CAAC,MAAM,EAAE,CAAC;iBACf;aACF;QACH,CAAC;QAED;;WAEG;QACO,yBAAM,GAAhB;YACE,IAAI;gBACF,IAAI,CAAC,iBAAiB,EAAE,CAAC;gBACzB,mEAAmE;gBACnE,8CAA8C;gBAC9C,IAAI,CAAC,EAAE,CAAC,SAAS,CAAC,IAAI,CAAC,YAAY,EAAE,OAAO,CAAC,GAAG,CAAC,QAAQ,EAAE,EAAE,eAAe,CAAC,IAAI,CAAC,CAAC;aACpF;YAAC,OAAO,CAAC,EAAE;gBACV,IAAI,CAAC,oBAAoB,EAAE,CAAC;gBAC5B,IAAI,CAAC,CAAC,IAAI,KAAK,QAAQ,EAAE;oBACvB,MAAM,CAAC,CAAC;iBACT;gBAED,wDAAwD;gBACxD,wFAAwF;gBACxF,+EAA+E;gBAC/E,IAAI,GAAG,SAAQ,CAAC;gBAChB,IAAI;oBACF,GAAG,GAAG,IAAI,CAAC,EAAE,CAAC,QAAQ,CAAC,IAAI,CAAC,YAAY,CAAC,CAAC;iBAC3C;gBAAC,WAAM;oBACN,GAAG,GAAG,WAAW,CAAC;iBACnB;gBAED,MAAM,IAAI,KAAK,CACX,gDAA8C,GAAG,QAAK;oBACtD,2JAA2J;oBAC3J,qEAAqE;qBACrE,wFAAsF,IAAI,CAAC,YAAY,OAAI,CAAA,CAAC,CAAC;aAClH;QACH,CAAC;QAED;;WAEG;QACO,yBAAM,GAAhB;YACE,IAAI,CAAC,oBAAoB,EAAE,CAAC;YAC5B,IAAI,IAAI,CAAC,EAAE,CAAC,MAAM,CAAC,IAAI,CAAC,YAAY,CAAC,EAAE;gBACrC,IAAI,CAAC,EAAE,CAAC,UAAU,CAAC,IAAI,CAAC,YAAY,CAAC,CAAC;aACvC;QACH,CAAC;QAES,oCAAiB,GAA3B;YACE,OAAO,CAAC,IAAI,CAAC,QAAQ,EAAE,IAAI,CAAC,aAAa,CAAC,CAAC;YAC3C,OAAO,CAAC,IAAI,CAAC,QAAQ,EAAE,IAAI,CAAC,aAAa,CAAC,CAAC;QAC7C,CAAC;QAES,uCAAoB,GAA9B;YACE,OAAO,CAAC,cAAc,CAAC,QAAQ,EAAE,IAAI,CAAC,aAAa,CAAC,CAAC;YACrD,OAAO,CAAC,cAAc,CAAC,QAAQ,EAAE,IAAI,CAAC,aAAa,CAAC,CAAC;QACvD,CAAC;QAYD;;;WAGG;QACO,uBAAI,GAAd,UAAe,IAAY;YACzB,OAAO,CAAC,IAAI,CAAC,IAAI,CAAC,CAAC;QACrB,CAAC;QACH,eAAC;IAAD,CAAC,AAvGD,IAuGC;IAvGY,4BAAQ","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 * as process from 'process';\nimport {FileSystem} from '../../../src/ngtsc/file_system';\n\n/**\n * The LockFile is used to prevent more than one instance of ngcc executing at the same time.\n *\n * When ngcc starts executing, it creates a file in the `compiler-cli/ngcc` folder. If it finds one\n * is already there then it fails with a suitable error message.\n * When ngcc completes executing, it removes the file so that future ngcc executions can start.\n */\nexport class LockFile {\n  lockFilePath =\n      this.fs.resolve(require.resolve('@angular/compiler-cli/ngcc'), '../__ngcc_lock_file__');\n\n  constructor(private fs: FileSystem) {}\n\n  /**\n   * Run a function guarded by the lock file.\n   *\n   * Note that T can be a Promise. If so, we run the `remove()` call in the promise's `finally`\n   * handler. Otherwise we run the `remove()` call in the `try...finally` block.\n   *\n   * @param fn The function to run.\n   */\n  lock<T>(fn: () => T): T {\n    let isAsync = false;\n    this.create();\n    try {\n      const result = fn();\n      if (result instanceof Promise) {\n        isAsync = true;\n        // The cast is necessary because TS cannot deduce that T is now a promise here.\n        return result.finally(() => this.remove()) as unknown as T;\n      } else {\n        return result;\n      }\n    } finally {\n      if (!isAsync) {\n        this.remove();\n      }\n    }\n  }\n\n  /**\n   * Write a lock file to disk, or error if there is already one there.\n   */\n  protected create() {\n    try {\n      this.addSignalHandlers();\n      // To avoid race conditions, we check for existence of the lockfile\n      // by actually trying to create it exclusively\n      this.fs.writeFile(this.lockFilePath, process.pid.toString(), /* exclusive */ true);\n    } catch (e) {\n      this.removeSignalHandlers();\n      if (e.code !== 'EEXIST') {\n        throw e;\n      }\n\n      // The lockfile already exists so raise a helpful error.\n      // It is feasible that the lockfile was removed between the previous check for existence\n      // and this file-read. If so then we still error but as gracefully as possible.\n      let pid: string;\n      try {\n        pid = this.fs.readFile(this.lockFilePath);\n      } catch {\n        pid = '{unknown}';\n      }\n\n      throw new Error(\n          `ngcc is already running at process with id ${pid}.\\n` +\n          `If you are running multiple builds in parallel then you should pre-process your node_modules via the command line ngcc tool before starting the builds;\\n` +\n          `See https://v9.angular.io/guide/ivy#speeding-up-ngcc-compilation.\\n` +\n          `(If you are sure no ngcc process is running then you should delete the lockfile at ${this.lockFilePath}.)`);\n    }\n  }\n\n  /**\n   * Remove the lock file from disk.\n   */\n  protected remove() {\n    this.removeSignalHandlers();\n    if (this.fs.exists(this.lockFilePath)) {\n      this.fs.removeFile(this.lockFilePath);\n    }\n  }\n\n  protected addSignalHandlers() {\n    process.once('SIGINT', this.signalHandler);\n    process.once('SIGHUP', this.signalHandler);\n  }\n\n  protected removeSignalHandlers() {\n    process.removeListener('SIGINT', this.signalHandler);\n    process.removeListener('SIGHUP', this.signalHandler);\n  }\n\n  /**\n   * This handle needs to be defined as a property rather than a method\n   * so that it can be passed around as a bound function.\n   */\n  protected signalHandler =\n      () => {\n        this.remove();\n        this.exit(1);\n      }\n\n  /**\n   * This function wraps `process.exit()` which makes it easier to manage in unit tests,\n   * since it is not possible to mock out `process.exit()` when it is called from signal handlers.\n   */\n  protected exit(code: number): void {\n    process.exit(code);\n  }\n}\n"]}