@loaders.gl/worker-utils 3.4.0-alpha.2 → 3.4.0-alpha.3

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 (94) hide show
  1. package/dist/es5/index.js +0 -1
  2. package/dist/es5/index.js.map +1 -1
  3. package/dist/es5/lib/async-queue/async-queue.js +5 -18
  4. package/dist/es5/lib/async-queue/async-queue.js.map +1 -1
  5. package/dist/es5/lib/env-utils/assert.js +0 -1
  6. package/dist/es5/lib/env-utils/assert.js.map +1 -1
  7. package/dist/es5/lib/env-utils/globals.js +1 -7
  8. package/dist/es5/lib/env-utils/globals.js.map +1 -1
  9. package/dist/es5/lib/env-utils/version.js +2 -3
  10. package/dist/es5/lib/env-utils/version.js.map +1 -1
  11. package/dist/es5/lib/library-utils/library-utils.js +70 -83
  12. package/dist/es5/lib/library-utils/library-utils.js.map +1 -1
  13. package/dist/es5/lib/node/require-utils.node.js +23 -26
  14. package/dist/es5/lib/node/require-utils.node.js.map +1 -1
  15. package/dist/es5/lib/node/worker_threads-browser.js +1 -2
  16. package/dist/es5/lib/node/worker_threads-browser.js.map +1 -1
  17. package/dist/es5/lib/node/worker_threads.js +0 -1
  18. package/dist/es5/lib/node/worker_threads.js.map +1 -1
  19. package/dist/es5/lib/process-utils/child-process-proxy.js +87 -96
  20. package/dist/es5/lib/process-utils/child-process-proxy.js.map +1 -1
  21. package/dist/es5/lib/process-utils/process-utils.js.map +1 -1
  22. package/dist/es5/lib/worker-api/create-worker.js +96 -103
  23. package/dist/es5/lib/worker-api/create-worker.js.map +1 -1
  24. package/dist/es5/lib/worker-api/get-worker-url.js +1 -8
  25. package/dist/es5/lib/worker-api/get-worker-url.js.map +1 -1
  26. package/dist/es5/lib/worker-api/process-on-worker.js +81 -87
  27. package/dist/es5/lib/worker-api/process-on-worker.js.map +1 -1
  28. package/dist/es5/lib/worker-api/validate-worker-version.js +0 -2
  29. package/dist/es5/lib/worker-api/validate-worker-version.js.map +1 -1
  30. package/dist/es5/lib/worker-farm/worker-body.js +3 -10
  31. package/dist/es5/lib/worker-farm/worker-body.js.map +1 -1
  32. package/dist/es5/lib/worker-farm/worker-farm.js +6 -18
  33. package/dist/es5/lib/worker-farm/worker-farm.js.map +1 -1
  34. package/dist/es5/lib/worker-farm/worker-job.js +3 -10
  35. package/dist/es5/lib/worker-farm/worker-job.js.map +1 -1
  36. package/dist/es5/lib/worker-farm/worker-pool.js +72 -89
  37. package/dist/es5/lib/worker-farm/worker-pool.js.map +1 -1
  38. package/dist/es5/lib/worker-farm/worker-thread.js +7 -23
  39. package/dist/es5/lib/worker-farm/worker-thread.js.map +1 -1
  40. package/dist/es5/lib/worker-utils/get-loadable-worker-url.js +0 -6
  41. package/dist/es5/lib/worker-utils/get-loadable-worker-url.js.map +1 -1
  42. package/dist/es5/lib/worker-utils/get-transfer-list.js +2 -8
  43. package/dist/es5/lib/worker-utils/get-transfer-list.js.map +1 -1
  44. package/dist/es5/lib/worker-utils/remove-nontransferable-options.js.map +1 -1
  45. package/dist/es5/workers/null-worker.js +6 -8
  46. package/dist/es5/workers/null-worker.js.map +1 -1
  47. package/dist/esm/index.js +0 -8
  48. package/dist/esm/index.js.map +1 -1
  49. package/dist/esm/lib/async-queue/async-queue.js +0 -8
  50. package/dist/esm/lib/async-queue/async-queue.js.map +1 -1
  51. package/dist/esm/lib/env-utils/assert.js +0 -2
  52. package/dist/esm/lib/env-utils/assert.js.map +1 -1
  53. package/dist/esm/lib/env-utils/globals.js +1 -9
  54. package/dist/esm/lib/env-utils/globals.js.map +1 -1
  55. package/dist/esm/lib/env-utils/version.js +2 -4
  56. package/dist/esm/lib/env-utils/version.js.map +1 -1
  57. package/dist/esm/lib/library-utils/library-utils.js +2 -14
  58. package/dist/esm/lib/library-utils/library-utils.js.map +1 -1
  59. package/dist/esm/lib/node/require-utils.node.js +0 -5
  60. package/dist/esm/lib/node/require-utils.node.js.map +1 -1
  61. package/dist/esm/lib/node/worker_threads-browser.js +0 -1
  62. package/dist/esm/lib/node/worker_threads-browser.js.map +1 -1
  63. package/dist/esm/lib/node/worker_threads.js +0 -2
  64. package/dist/esm/lib/node/worker_threads.js.map +1 -1
  65. package/dist/esm/lib/process-utils/child-process-proxy.js +0 -6
  66. package/dist/esm/lib/process-utils/child-process-proxy.js.map +1 -1
  67. package/dist/esm/lib/process-utils/process-utils.js +0 -1
  68. package/dist/esm/lib/process-utils/process-utils.js.map +1 -1
  69. package/dist/esm/lib/worker-api/create-worker.js +0 -5
  70. package/dist/esm/lib/worker-api/create-worker.js.map +1 -1
  71. package/dist/esm/lib/worker-api/get-worker-url.js +1 -9
  72. package/dist/esm/lib/worker-api/get-worker-url.js.map +1 -1
  73. package/dist/esm/lib/worker-api/process-on-worker.js +1 -5
  74. package/dist/esm/lib/worker-api/process-on-worker.js.map +1 -1
  75. package/dist/esm/lib/worker-api/validate-worker-version.js +0 -3
  76. package/dist/esm/lib/worker-api/validate-worker-version.js.map +1 -1
  77. package/dist/esm/lib/worker-farm/worker-body.js +0 -6
  78. package/dist/esm/lib/worker-farm/worker-body.js.map +1 -1
  79. package/dist/esm/lib/worker-farm/worker-farm.js +0 -8
  80. package/dist/esm/lib/worker-farm/worker-farm.js.map +1 -1
  81. package/dist/esm/lib/worker-farm/worker-job.js +0 -5
  82. package/dist/esm/lib/worker-farm/worker-job.js.map +1 -1
  83. package/dist/esm/lib/worker-farm/worker-pool.js +0 -14
  84. package/dist/esm/lib/worker-farm/worker-pool.js.map +1 -1
  85. package/dist/esm/lib/worker-farm/worker-thread.js +1 -10
  86. package/dist/esm/lib/worker-farm/worker-thread.js.map +1 -1
  87. package/dist/esm/lib/worker-utils/get-loadable-worker-url.js +0 -6
  88. package/dist/esm/lib/worker-utils/get-loadable-worker-url.js.map +1 -1
  89. package/dist/esm/lib/worker-utils/get-transfer-list.js +2 -9
  90. package/dist/esm/lib/worker-utils/get-transfer-list.js.map +1 -1
  91. package/dist/esm/lib/worker-utils/remove-nontransferable-options.js +0 -1
  92. package/dist/esm/lib/worker-utils/remove-nontransferable-options.js.map +1 -1
  93. package/dist/lib/worker-api/create-worker.js +1 -1
  94. package/package.json +2 -2
@@ -28,9 +28,7 @@ var DEFAULT_PROPS = {
28
28
  console.log("Started ".concat(processProxy.props.command));
29
29
  }
30
30
  };
31
-
32
31
  var ChildProcessProxy = function () {
33
-
34
32
  function ChildProcessProxy() {
35
33
  var _ref = arguments.length > 0 && arguments[0] !== undefined ? arguments[0] : {},
36
34
  _ref$id = _ref.id,
@@ -43,7 +41,6 @@ var ChildProcessProxy = function () {
43
41
  (0, _defineProperty2.default)(this, "successTimer", void 0);
44
42
  this.id = id;
45
43
  }
46
-
47
44
  (0, _createClass2.default)(ChildProcessProxy, [{
48
45
  key: "start",
49
46
  value: function () {
@@ -51,69 +48,67 @@ var ChildProcessProxy = function () {
51
48
  var _this = this;
52
49
  var args;
53
50
  return _regenerator.default.wrap(function _callee$(_context) {
54
- while (1) {
55
- switch (_context.prev = _context.next) {
56
- case 0:
57
- props = _objectSpread(_objectSpread({}, DEFAULT_PROPS), props);
58
- this.props = props;
59
- args = (0, _toConsumableArray2.default)(props.arguments);
60
- this.port = Number(props.port);
61
- if (!props.portArg) {
62
- _context.next = 10;
63
- break;
64
- }
65
- if (!props.autoPort) {
66
- _context.next = 9;
67
- break;
68
- }
69
- _context.next = 8;
70
- return (0, _processUtils.getAvailablePort)(props.port);
71
- case 8:
72
- this.port = _context.sent;
73
- case 9:
74
- args.push(props.portArg, String(this.port));
75
- case 10:
76
- _context.next = 12;
77
- return new Promise(function (resolve, reject) {
78
- try {
79
- _this._setTimeout(function () {
80
- if (props.onSuccess) {
81
- props.onSuccess(_this);
82
- }
83
- resolve({});
84
- });
85
- console.log("Spawning ".concat(props.command, " ").concat(props.arguments.join(' ')));
86
- var childProcess = ChildProcess.spawn(props.command, args, props.spawn);
87
- _this.childProcess = childProcess;
88
- childProcess.stdout.on('data', function (data) {
89
- console.log(data.toString());
90
- });
91
- childProcess.stderr.on('data', function (data) {
92
- console.log("Child process wrote to stderr: \"".concat(data, "\"."));
93
- _this._clearTimeout();
94
- reject(new Error(data));
95
- });
96
- childProcess.on('error', function (error) {
97
- console.log("Child process errored with ".concat(error));
98
- _this._clearTimeout();
99
- reject(error);
100
- });
101
- childProcess.on('close', function (code) {
102
- console.log("Child process exited with ".concat(code));
103
- _this.childProcess = null;
104
- _this._clearTimeout();
105
- resolve({});
106
- });
107
- } catch (error) {
51
+ while (1) switch (_context.prev = _context.next) {
52
+ case 0:
53
+ props = _objectSpread(_objectSpread({}, DEFAULT_PROPS), props);
54
+ this.props = props;
55
+ args = (0, _toConsumableArray2.default)(props.arguments);
56
+ this.port = Number(props.port);
57
+ if (!props.portArg) {
58
+ _context.next = 10;
59
+ break;
60
+ }
61
+ if (!props.autoPort) {
62
+ _context.next = 9;
63
+ break;
64
+ }
65
+ _context.next = 8;
66
+ return (0, _processUtils.getAvailablePort)(props.port);
67
+ case 8:
68
+ this.port = _context.sent;
69
+ case 9:
70
+ args.push(props.portArg, String(this.port));
71
+ case 10:
72
+ _context.next = 12;
73
+ return new Promise(function (resolve, reject) {
74
+ try {
75
+ _this._setTimeout(function () {
76
+ if (props.onSuccess) {
77
+ props.onSuccess(_this);
78
+ }
79
+ resolve({});
80
+ });
81
+ console.log("Spawning ".concat(props.command, " ").concat(props.arguments.join(' ')));
82
+ var childProcess = ChildProcess.spawn(props.command, args, props.spawn);
83
+ _this.childProcess = childProcess;
84
+ childProcess.stdout.on('data', function (data) {
85
+ console.log(data.toString());
86
+ });
87
+ childProcess.stderr.on('data', function (data) {
88
+ console.log("Child process wrote to stderr: \"".concat(data, "\"."));
89
+ _this._clearTimeout();
90
+ reject(new Error(data));
91
+ });
92
+ childProcess.on('error', function (error) {
93
+ console.log("Child process errored with ".concat(error));
94
+ _this._clearTimeout();
108
95
  reject(error);
109
- }
110
- });
111
- case 12:
112
- return _context.abrupt("return", _context.sent);
113
- case 13:
114
- case "end":
115
- return _context.stop();
116
- }
96
+ });
97
+ childProcess.on('close', function (code) {
98
+ console.log("Child process exited with ".concat(code));
99
+ _this.childProcess = null;
100
+ _this._clearTimeout();
101
+ resolve({});
102
+ });
103
+ } catch (error) {
104
+ reject(error);
105
+ }
106
+ });
107
+ case 12:
108
+ return _context.abrupt("return", _context.sent);
109
+ case 13:
110
+ case "end":
111
+ return _context.stop();
117
112
  }
118
113
  }, _callee, this);
119
114
  }));
@@ -127,17 +122,15 @@ var ChildProcessProxy = function () {
127
122
  value: function () {
128
123
  var _stop = (0, _asyncToGenerator2.default)(_regenerator.default.mark(function _callee2() {
129
124
  return _regenerator.default.wrap(function _callee2$(_context2) {
130
- while (1) {
131
- switch (_context2.prev = _context2.next) {
132
- case 0:
133
- if (this.childProcess) {
134
- this.childProcess.kill();
135
- this.childProcess = null;
136
- }
137
- case 1:
138
- case "end":
139
- return _context2.stop();
140
- }
125
+ while (1) switch (_context2.prev = _context2.next) {
126
+ case 0:
127
+ if (this.childProcess) {
128
+ this.childProcess.kill();
129
+ this.childProcess = null;
130
+ }
131
+ case 1:
132
+ case "end":
133
+ return _context2.stop();
141
134
  }
142
135
  }, _callee2, this);
143
136
  }));
@@ -153,26 +146,24 @@ var ChildProcessProxy = function () {
153
146
  var statusCode,
154
147
  _args3 = arguments;
155
148
  return _regenerator.default.wrap(function _callee3$(_context3) {
156
- while (1) {
157
- switch (_context3.prev = _context3.next) {
158
- case 0:
159
- statusCode = _args3.length > 0 && _args3[0] !== undefined ? _args3[0] : 0;
160
- _context3.prev = 1;
161
- _context3.next = 4;
162
- return this.stop();
163
- case 4:
164
- process.exit(statusCode);
165
- _context3.next = 11;
166
- break;
167
- case 7:
168
- _context3.prev = 7;
169
- _context3.t0 = _context3["catch"](1);
170
- console.error(_context3.t0.message || _context3.t0);
171
- process.exit(1);
172
- case 11:
173
- case "end":
174
- return _context3.stop();
175
- }
149
+ while (1) switch (_context3.prev = _context3.next) {
150
+ case 0:
151
+ statusCode = _args3.length > 0 && _args3[0] !== undefined ? _args3[0] : 0;
152
+ _context3.prev = 1;
153
+ _context3.next = 4;
154
+ return this.stop();
155
+ case 4:
156
+ process.exit(statusCode);
157
+ _context3.next = 11;
158
+ break;
159
+ case 7:
160
+ _context3.prev = 7;
161
+ _context3.t0 = _context3["catch"](1);
162
+ console.error(_context3.t0.message || _context3.t0);
163
+ process.exit(1);
164
+ case 11:
165
+ case "end":
166
+ return _context3.stop();
176
167
  }
177
168
  }, _callee3, this, [[1, 7]]);
178
169
  }));
@@ -1 +1 @@
1
- {"version":3,"file":"child-process-proxy.js","names":["DEFAULT_PROPS","command","arguments","port","autoPort","wait","onSuccess","processProxy","console","log","props","ChildProcessProxy","id","args","Number","portArg","getAvailablePort","push","String","Promise","resolve","reject","_setTimeout","join","childProcess","ChildProcess","spawn","stdout","on","data","toString","stderr","_clearTimeout","Error","error","code","kill","statusCode","stop","process","exit","message","callback","successTimer","setTimeout","clearTimeout"],"sources":["../../../../src/lib/process-utils/child-process-proxy.ts"],"sourcesContent":["/* eslint-disable no-console */\n// Avoid using named imports for Node builtins to help with \"empty\" resolution\n// for bundlers targeting browser environments. Access imports & types\n// through the `ChildProcess` object (e.g. `ChildProcess.spawn`, `ChildProcess.ChildProcess`).\nimport * as ChildProcess from 'child_process';\nimport {getAvailablePort} from './process-utils';\n\nexport type ChildProcessProxyProps = {\n command: string;\n arguments: string[];\n /** Whether to add a port specified arg */\n portArg?: string;\n /** Base port number */\n port?: number;\n /** Whether to search for an available port if the base port is occupied */\n autoPort?: boolean;\n /** Number of milliseconds to wait until concluding success */\n /** wait: 0 - infinity */\n wait?: number;\n /** Options passed on to Node'.js `spawn` */\n spawn?: ChildProcess.SpawnOptionsWithoutStdio;\n /** Callback when the */\n onStart?: (proxy: ChildProcessProxy) => void;\n onSuccess?: (proxy: ChildProcessProxy) => void;\n};\n\nconst DEFAULT_PROPS: ChildProcessProxyProps = {\n command: '',\n arguments: [],\n port: 5000,\n autoPort: true,\n wait: 2000,\n onSuccess: (processProxy) => {\n console.log(`Started ${processProxy.props.command}`);\n }\n};\n\n/**\n * Manager for a Node.js child process\n * Prepares arguments, starts, stops and tracks output\n */\nexport default class ChildProcessProxy {\n id: string;\n props: ChildProcessProxyProps = {...DEFAULT_PROPS};\n private childProcess: ChildProcess.ChildProcess | null = null;\n private port: number = 0;\n private successTimer?: any; // NodeJS.Timeout;\n\n // constructor(props?: {id?: string});\n constructor({id = 'browser-driver'} = {}) {\n this.id = id;\n }\n\n /** Starts a child process with the provided props */\n async start(props: ChildProcessProxyProps): Promise<object> {\n props = {...DEFAULT_PROPS, ...props};\n this.props = props;\n\n const args = [...props.arguments];\n\n // If portArg is set, we can look up an available port\n this.port = Number(props.port);\n if (props.portArg) {\n if (props.autoPort) {\n this.port = await getAvailablePort(props.port);\n }\n args.push(props.portArg, String(this.port));\n }\n\n return await new Promise((resolve, reject) => {\n try {\n this._setTimeout(() => {\n if (props.onSuccess) {\n props.onSuccess(this);\n }\n resolve({});\n });\n\n console.log(`Spawning ${props.command} ${props.arguments.join(' ')}`);\n const childProcess = ChildProcess.spawn(props.command, args, props.spawn);\n this.childProcess = childProcess;\n\n childProcess.stdout.on('data', (data) => {\n console.log(data.toString());\n });\n // TODO - add option regarding whether stderr should be treated as data\n childProcess.stderr.on('data', (data) => {\n console.log(`Child process wrote to stderr: \"${data}\".`);\n this._clearTimeout();\n reject(new Error(data));\n });\n childProcess.on('error', (error) => {\n console.log(`Child process errored with ${error}`);\n this._clearTimeout();\n reject(error);\n });\n childProcess.on('close', (code) => {\n console.log(`Child process exited with ${code}`);\n this.childProcess = null;\n this._clearTimeout();\n resolve({});\n });\n } catch (error) {\n reject(error);\n }\n });\n }\n\n /** Stops a running child process */\n async stop(): Promise<void> {\n if (this.childProcess) {\n this.childProcess.kill();\n this.childProcess = null;\n }\n }\n\n /** Exits this process */\n async exit(statusCode: number = 0): Promise<void> {\n try {\n await this.stop();\n // eslint-disable-next-line no-process-exit\n process.exit(statusCode);\n } catch (error) {\n console.error((error as Error).message || error);\n // eslint-disable-next-line no-process-exit\n process.exit(1);\n }\n }\n\n _setTimeout(callback: (...args: any[]) => void) {\n if (Number(this.props.wait) > 0) {\n this.successTimer = setTimeout(callback, this.props.wait);\n }\n }\n\n _clearTimeout() {\n if (this.successTimer) {\n clearTimeout(this.successTimer);\n }\n }\n}\n"],"mappings":"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"}
1
+ {"version":3,"file":"child-process-proxy.js","names":["ChildProcess","_interopRequireWildcard","require","_processUtils","_getRequireWildcardCache","nodeInterop","WeakMap","cacheBabelInterop","cacheNodeInterop","obj","__esModule","_typeof","default","cache","has","get","newObj","hasPropertyDescriptor","Object","defineProperty","getOwnPropertyDescriptor","key","prototype","hasOwnProperty","call","desc","set","ownKeys","object","enumerableOnly","keys","getOwnPropertySymbols","symbols","filter","sym","enumerable","push","apply","_objectSpread","target","i","arguments","length","source","forEach","_defineProperty2","getOwnPropertyDescriptors","defineProperties","DEFAULT_PROPS","command","port","autoPort","wait","onSuccess","processProxy","console","log","concat","props","ChildProcessProxy","_ref","undefined","_ref$id","id","_classCallCheck2","_createClass2","value","_start","_asyncToGenerator2","_regenerator","mark","_callee","_this","args","wrap","_callee$","_context","prev","next","_toConsumableArray2","Number","portArg","getAvailablePort","sent","String","Promise","resolve","reject","_setTimeout","join","childProcess","spawn","stdout","on","data","toString","stderr","_clearTimeout","Error","error","code","abrupt","stop","start","_x","_stop","_callee2","_callee2$","_context2","kill","_exit","_callee3","statusCode","_args3","_callee3$","_context3","process","exit","t0","message","callback","successTimer","setTimeout","clearTimeout","exports"],"sources":["../../../../src/lib/process-utils/child-process-proxy.ts"],"sourcesContent":["/* eslint-disable no-console */\n// Avoid using named imports for Node builtins to help with \"empty\" resolution\n// for bundlers targeting browser environments. Access imports & types\n// through the `ChildProcess` object (e.g. `ChildProcess.spawn`, `ChildProcess.ChildProcess`).\nimport * as ChildProcess from 'child_process';\nimport {getAvailablePort} from './process-utils';\n\nexport type ChildProcessProxyProps = {\n command: string;\n arguments: string[];\n /** Whether to add a port specified arg */\n portArg?: string;\n /** Base port number */\n port?: number;\n /** Whether to search for an available port if the base port is occupied */\n autoPort?: boolean;\n /** Number of milliseconds to wait until concluding success */\n /** wait: 0 - infinity */\n wait?: number;\n /** Options passed on to Node'.js `spawn` */\n spawn?: ChildProcess.SpawnOptionsWithoutStdio;\n /** Callback when the */\n onStart?: (proxy: ChildProcessProxy) => void;\n onSuccess?: (proxy: ChildProcessProxy) => void;\n};\n\nconst DEFAULT_PROPS: ChildProcessProxyProps = {\n command: '',\n arguments: [],\n port: 5000,\n autoPort: true,\n wait: 2000,\n onSuccess: (processProxy) => {\n console.log(`Started ${processProxy.props.command}`);\n }\n};\n\n/**\n * Manager for a Node.js child process\n * Prepares arguments, starts, stops and tracks output\n */\nexport default class ChildProcessProxy {\n id: string;\n props: ChildProcessProxyProps = {...DEFAULT_PROPS};\n private childProcess: ChildProcess.ChildProcess | null = null;\n private port: number = 0;\n private successTimer?: any; // NodeJS.Timeout;\n\n // constructor(props?: {id?: string});\n constructor({id = 'browser-driver'} = {}) {\n this.id = id;\n }\n\n /** Starts a child process with the provided props */\n async start(props: ChildProcessProxyProps): Promise<object> {\n props = {...DEFAULT_PROPS, ...props};\n this.props = props;\n\n const args = [...props.arguments];\n\n // If portArg is set, we can look up an available port\n this.port = Number(props.port);\n if (props.portArg) {\n if (props.autoPort) {\n this.port = await getAvailablePort(props.port);\n }\n args.push(props.portArg, String(this.port));\n }\n\n return await new Promise((resolve, reject) => {\n try {\n this._setTimeout(() => {\n if (props.onSuccess) {\n props.onSuccess(this);\n }\n resolve({});\n });\n\n console.log(`Spawning ${props.command} ${props.arguments.join(' ')}`);\n const childProcess = ChildProcess.spawn(props.command, args, props.spawn);\n this.childProcess = childProcess;\n\n childProcess.stdout.on('data', (data) => {\n console.log(data.toString());\n });\n // TODO - add option regarding whether stderr should be treated as data\n childProcess.stderr.on('data', (data) => {\n console.log(`Child process wrote to stderr: \"${data}\".`);\n this._clearTimeout();\n reject(new Error(data));\n });\n childProcess.on('error', (error) => {\n console.log(`Child process errored with ${error}`);\n this._clearTimeout();\n reject(error);\n });\n childProcess.on('close', (code) => {\n console.log(`Child process exited with ${code}`);\n this.childProcess = null;\n this._clearTimeout();\n resolve({});\n });\n } catch (error) {\n reject(error);\n }\n });\n }\n\n /** Stops a running child process */\n async stop(): Promise<void> {\n if (this.childProcess) {\n this.childProcess.kill();\n this.childProcess = null;\n }\n }\n\n /** Exits this process */\n async exit(statusCode: number = 0): Promise<void> {\n try {\n await this.stop();\n // eslint-disable-next-line no-process-exit\n process.exit(statusCode);\n } catch (error) {\n console.error((error as Error).message || error);\n // eslint-disable-next-line no-process-exit\n process.exit(1);\n }\n }\n\n _setTimeout(callback: (...args: any[]) => void) {\n if (Number(this.props.wait) > 0) {\n this.successTimer = setTimeout(callback, this.props.wait);\n }\n }\n\n _clearTimeout() {\n if (this.successTimer) {\n clearTimeout(this.successTimer);\n }\n }\n}\n"],"mappings":"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"}
@@ -1 +1 @@
1
- {"version":3,"file":"process-utils.js","names":["getAvailablePort","defaultPort","Promise","resolve","ChildProcess","exec","error","stdout","portsInUse","regex","split","forEach","line","match","push","Number","port","includes"],"sources":["../../../../src/lib/process-utils/process-utils.ts"],"sourcesContent":["import ChildProcess from 'child_process';\n\n// Get an available port\n// Works on Unix systems\nexport function getAvailablePort(defaultPort: number = 3000): Promise<number> {\n return new Promise((resolve) => {\n // Get a list of all ports in use\n ChildProcess.exec('lsof -i -P -n | grep LISTEN', (error, stdout) => {\n if (error) {\n // likely no permission, e.g. CI\n resolve(defaultPort);\n return;\n }\n\n const portsInUse: number[] = [];\n const regex = /:(\\d+) \\(LISTEN\\)/;\n stdout.split('\\n').forEach((line) => {\n const match = regex.exec(line);\n if (match) {\n portsInUse.push(Number(match[1]));\n }\n });\n let port = defaultPort;\n while (portsInUse.includes(port)) {\n port++;\n }\n resolve(port);\n });\n });\n}\n"],"mappings":";;;;;;;AAAA;AAIO,SAASA,gBAAgB,GAA8C;EAAA,IAA7CC,WAAmB,uEAAG,IAAI;EACzD,OAAO,IAAIC,OAAO,CAAC,UAACC,OAAO,EAAK;IAE9BC,sBAAY,CAACC,IAAI,CAAC,6BAA6B,EAAE,UAACC,KAAK,EAAEC,MAAM,EAAK;MAClE,IAAID,KAAK,EAAE;QAETH,OAAO,CAACF,WAAW,CAAC;QACpB;MACF;MAEA,IAAMO,UAAoB,GAAG,EAAE;MAC/B,IAAMC,KAAK,GAAG,mBAAmB;MACjCF,MAAM,CAACG,KAAK,CAAC,IAAI,CAAC,CAACC,OAAO,CAAC,UAACC,IAAI,EAAK;QACnC,IAAMC,KAAK,GAAGJ,KAAK,CAACJ,IAAI,CAACO,IAAI,CAAC;QAC9B,IAAIC,KAAK,EAAE;UACTL,UAAU,CAACM,IAAI,CAACC,MAAM,CAACF,KAAK,CAAC,CAAC,CAAC,CAAC,CAAC;QACnC;MACF,CAAC,CAAC;MACF,IAAIG,IAAI,GAAGf,WAAW;MACtB,OAAOO,UAAU,CAACS,QAAQ,CAACD,IAAI,CAAC,EAAE;QAChCA,IAAI,EAAE;MACR;MACAb,OAAO,CAACa,IAAI,CAAC;IACf,CAAC,CAAC;EACJ,CAAC,CAAC;AACJ"}
1
+ {"version":3,"file":"process-utils.js","names":["_child_process","_interopRequireDefault","require","getAvailablePort","defaultPort","arguments","length","undefined","Promise","resolve","ChildProcess","exec","error","stdout","portsInUse","regex","split","forEach","line","match","push","Number","port","includes"],"sources":["../../../../src/lib/process-utils/process-utils.ts"],"sourcesContent":["import ChildProcess from 'child_process';\n\n// Get an available port\n// Works on Unix systems\nexport function getAvailablePort(defaultPort: number = 3000): Promise<number> {\n return new Promise((resolve) => {\n // Get a list of all ports in use\n ChildProcess.exec('lsof -i -P -n | grep LISTEN', (error, stdout) => {\n if (error) {\n // likely no permission, e.g. CI\n resolve(defaultPort);\n return;\n }\n\n const portsInUse: number[] = [];\n const regex = /:(\\d+) \\(LISTEN\\)/;\n stdout.split('\\n').forEach((line) => {\n const match = regex.exec(line);\n if (match) {\n portsInUse.push(Number(match[1]));\n }\n });\n let port = defaultPort;\n while (portsInUse.includes(port)) {\n port++;\n }\n resolve(port);\n });\n });\n}\n"],"mappings":";;;;;;;AAAA,IAAAA,cAAA,GAAAC,sBAAA,CAAAC,OAAA;AAIO,SAASC,gBAAgBA,CAAA,EAA8C;EAAA,IAA7CC,WAAmB,GAAAC,SAAA,CAAAC,MAAA,QAAAD,SAAA,QAAAE,SAAA,GAAAF,SAAA,MAAG,IAAI;EACzD,OAAO,IAAIG,OAAO,CAAC,UAACC,OAAO,EAAK;IAE9BC,sBAAY,CAACC,IAAI,CAAC,6BAA6B,EAAE,UAACC,KAAK,EAAEC,MAAM,EAAK;MAClE,IAAID,KAAK,EAAE;QAETH,OAAO,CAACL,WAAW,CAAC;QACpB;MACF;MAEA,IAAMU,UAAoB,GAAG,EAAE;MAC/B,IAAMC,KAAK,GAAG,mBAAmB;MACjCF,MAAM,CAACG,KAAK,CAAC,IAAI,CAAC,CAACC,OAAO,CAAC,UAACC,IAAI,EAAK;QACnC,IAAMC,KAAK,GAAGJ,KAAK,CAACJ,IAAI,CAACO,IAAI,CAAC;QAC9B,IAAIC,KAAK,EAAE;UACTL,UAAU,CAACM,IAAI,CAACC,MAAM,CAACF,KAAK,CAAC,CAAC,CAAC,CAAC,CAAC;QACnC;MACF,CAAC,CAAC;MACF,IAAIG,IAAI,GAAGlB,WAAW;MACtB,OAAOU,UAAU,CAACS,QAAQ,CAACD,IAAI,CAAC,EAAE;QAChCA,IAAI,EAAE;MACR;MACAb,OAAO,CAACa,IAAI,CAAC;IACf,CAAC,CAAC;EACJ,CAAC,CAAC;AACJ"}
@@ -11,7 +11,6 @@ var _asyncQueue = _interopRequireDefault(require("../async-queue/async-queue"));
11
11
  var _workerBody = _interopRequireDefault(require("../worker-farm/worker-body"));
12
12
  function _asyncIterator(iterable) { var method, async, sync, retry = 2; for ("undefined" != typeof Symbol && (async = Symbol.asyncIterator, sync = Symbol.iterator); retry--;) { if (async && null != (method = iterable[async])) return method.call(iterable); if (sync && null != (method = iterable[sync])) return new AsyncFromSyncIterator(method.call(iterable)); async = "@@asyncIterator", sync = "@@iterator"; } throw new TypeError("Object is not async iterable"); }
13
13
  function AsyncFromSyncIterator(s) { function AsyncFromSyncIteratorContinuation(r) { if (Object(r) !== r) return Promise.reject(new TypeError(r + " is not an object.")); var done = r.done; return Promise.resolve(r.value).then(function (value) { return { value: value, done: done }; }); } return AsyncFromSyncIterator = function AsyncFromSyncIterator(s) { this.s = s, this.n = s.next; }, AsyncFromSyncIterator.prototype = { s: null, n: null, next: function next() { return AsyncFromSyncIteratorContinuation(this.n.apply(this.s, arguments)); }, return: function _return(value) { var ret = this.s.return; return void 0 === ret ? Promise.resolve({ value: value, done: !0 }) : AsyncFromSyncIteratorContinuation(ret.apply(this.s, arguments)); }, throw: function _throw(value) { var thr = this.s.return; return void 0 === thr ? Promise.reject(value) : AsyncFromSyncIteratorContinuation(thr.apply(this.s, arguments)); } }, new AsyncFromSyncIterator(s); }
14
-
15
14
  var requestId = 0;
16
15
  var inputBatches;
17
16
  var options;
@@ -22,114 +21,111 @@ function createWorker(process, processInBatches) {
22
21
  var context = {
23
22
  process: processOnMainThread
24
23
  };
25
-
26
24
  _workerBody.default.onmessage = function () {
27
25
  var _ref = (0, _asyncToGenerator2.default)(_regenerator.default.mark(function _callee(type, payload) {
28
26
  var result, resultIterator, _iteratorAbruptCompletion, _didIteratorError, _iteratorError, _iterator, _step, batch, message;
29
27
  return _regenerator.default.wrap(function _callee$(_context) {
30
- while (1) {
31
- switch (_context.prev = _context.next) {
32
- case 0:
33
- _context.prev = 0;
34
- _context.t0 = type;
35
- _context.next = _context.t0 === 'process' ? 4 : _context.t0 === 'process-in-batches' ? 11 : _context.t0 === 'input-batch' ? 46 : _context.t0 === 'input-done' ? 48 : 50;
28
+ while (1) switch (_context.prev = _context.next) {
29
+ case 0:
30
+ _context.prev = 0;
31
+ _context.t0 = type;
32
+ _context.next = _context.t0 === 'process' ? 4 : _context.t0 === 'process-in-batches' ? 11 : _context.t0 === 'input-batch' ? 46 : _context.t0 === 'input-done' ? 48 : 50;
33
+ break;
34
+ case 4:
35
+ if (process) {
36
+ _context.next = 6;
36
37
  break;
37
- case 4:
38
- if (process) {
39
- _context.next = 6;
40
- break;
41
- }
42
- throw new Error('Worker does not support atomic processing');
43
- case 6:
44
- _context.next = 8;
45
- return process(payload.input, payload.options || {}, context);
46
- case 8:
47
- result = _context.sent;
48
- _workerBody.default.postMessage('done', {
49
- result: result
50
- });
51
- return _context.abrupt("break", 50);
52
- case 11:
53
- if (processInBatches) {
54
- _context.next = 13;
55
- break;
56
- }
57
- throw new Error('Worker does not support batched processing');
58
- case 13:
59
- inputBatches = new _asyncQueue.default();
60
- options = payload.options || {};
61
- resultIterator = processInBatches(inputBatches, options, context);
62
- _iteratorAbruptCompletion = false;
63
- _didIteratorError = false;
64
- _context.prev = 18;
65
- _iterator = _asyncIterator(resultIterator);
66
- case 20:
67
- _context.next = 22;
68
- return _iterator.next();
69
- case 22:
70
- if (!(_iteratorAbruptCompletion = !(_step = _context.sent).done)) {
71
- _context.next = 28;
72
- break;
73
- }
74
- batch = _step.value;
75
- _workerBody.default.postMessage('output-batch', {
76
- result: batch
77
- });
78
- case 25:
79
- _iteratorAbruptCompletion = false;
80
- _context.next = 20;
38
+ }
39
+ throw new Error('Worker does not support atomic processing');
40
+ case 6:
41
+ _context.next = 8;
42
+ return process(payload.input, payload.options || {}, context);
43
+ case 8:
44
+ result = _context.sent;
45
+ _workerBody.default.postMessage('done', {
46
+ result: result
47
+ });
48
+ return _context.abrupt("break", 50);
49
+ case 11:
50
+ if (processInBatches) {
51
+ _context.next = 13;
81
52
  break;
82
- case 28:
83
- _context.next = 34;
53
+ }
54
+ throw new Error('Worker does not support batched processing');
55
+ case 13:
56
+ inputBatches = new _asyncQueue.default();
57
+ options = payload.options || {};
58
+ resultIterator = processInBatches(inputBatches, options, context);
59
+ _iteratorAbruptCompletion = false;
60
+ _didIteratorError = false;
61
+ _context.prev = 18;
62
+ _iterator = _asyncIterator(resultIterator);
63
+ case 20:
64
+ _context.next = 22;
65
+ return _iterator.next();
66
+ case 22:
67
+ if (!(_iteratorAbruptCompletion = !(_step = _context.sent).done)) {
68
+ _context.next = 28;
84
69
  break;
85
- case 30:
86
- _context.prev = 30;
87
- _context.t1 = _context["catch"](18);
88
- _didIteratorError = true;
89
- _iteratorError = _context.t1;
90
- case 34:
91
- _context.prev = 34;
92
- _context.prev = 35;
93
- if (!(_iteratorAbruptCompletion && _iterator.return != null)) {
94
- _context.next = 39;
95
- break;
96
- }
70
+ }
71
+ batch = _step.value;
72
+ _workerBody.default.postMessage('output-batch', {
73
+ result: batch
74
+ });
75
+ case 25:
76
+ _iteratorAbruptCompletion = false;
77
+ _context.next = 20;
78
+ break;
79
+ case 28:
80
+ _context.next = 34;
81
+ break;
82
+ case 30:
83
+ _context.prev = 30;
84
+ _context.t1 = _context["catch"](18);
85
+ _didIteratorError = true;
86
+ _iteratorError = _context.t1;
87
+ case 34:
88
+ _context.prev = 34;
89
+ _context.prev = 35;
90
+ if (!(_iteratorAbruptCompletion && _iterator.return != null)) {
97
91
  _context.next = 39;
98
- return _iterator.return();
99
- case 39:
100
- _context.prev = 39;
101
- if (!_didIteratorError) {
102
- _context.next = 42;
103
- break;
104
- }
105
- throw _iteratorError;
106
- case 42:
107
- return _context.finish(39);
108
- case 43:
109
- return _context.finish(34);
110
- case 44:
111
- _workerBody.default.postMessage('done', {});
112
- return _context.abrupt("break", 50);
113
- case 46:
114
- inputBatches.push(payload.input);
115
- return _context.abrupt("break", 50);
116
- case 48:
117
- inputBatches.close();
118
- return _context.abrupt("break", 50);
119
- case 50:
120
- _context.next = 56;
121
92
  break;
122
- case 52:
123
- _context.prev = 52;
124
- _context.t2 = _context["catch"](0);
125
- message = _context.t2 instanceof Error ? _context.t2.message : '';
126
- _workerBody.default.postMessage('error', {
127
- error: message
128
- });
129
- case 56:
130
- case "end":
131
- return _context.stop();
132
- }
93
+ }
94
+ _context.next = 39;
95
+ return _iterator.return();
96
+ case 39:
97
+ _context.prev = 39;
98
+ if (!_didIteratorError) {
99
+ _context.next = 42;
100
+ break;
101
+ }
102
+ throw _iteratorError;
103
+ case 42:
104
+ return _context.finish(39);
105
+ case 43:
106
+ return _context.finish(34);
107
+ case 44:
108
+ _workerBody.default.postMessage('done', {});
109
+ return _context.abrupt("break", 50);
110
+ case 46:
111
+ inputBatches.push(payload.input);
112
+ return _context.abrupt("break", 50);
113
+ case 48:
114
+ inputBatches.close();
115
+ return _context.abrupt("break", 50);
116
+ case 50:
117
+ _context.next = 56;
118
+ break;
119
+ case 52:
120
+ _context.prev = 52;
121
+ _context.t2 = _context["catch"](0);
122
+ message = _context.t2 instanceof Error ? _context.t2.message : '';
123
+ _workerBody.default.postMessage('error', {
124
+ error: message
125
+ });
126
+ case 56:
127
+ case "end":
128
+ return _context.stop();
133
129
  }
134
130
  }, _callee, null, [[0, 52], [18, 30, 34, 44], [35,, 39, 43]]);
135
131
  }));
@@ -142,7 +138,6 @@ function processOnMainThread(arrayBuffer) {
142
138
  var options = arguments.length > 1 && arguments[1] !== undefined ? arguments[1] : {};
143
139
  return new Promise(function (resolve, reject) {
144
140
  var id = requestId++;
145
-
146
141
  var onMessage = function onMessage(type, payload) {
147
142
  if (payload.id !== id) {
148
143
  return;
@@ -159,9 +154,7 @@ function processOnMainThread(arrayBuffer) {
159
154
  default:
160
155
  }
161
156
  };
162
-
163
157
  _workerBody.default.addEventListener(onMessage);
164
-
165
158
  var payload = {
166
159
  id: id,
167
160
  input: arrayBuffer,
@@ -1 +1 @@
1
- {"version":3,"file":"create-worker.js","names":["requestId","inputBatches","options","createWorker","process","processInBatches","WorkerBody","inWorkerThread","context","processOnMainThread","onmessage","type","payload","Error","input","result","postMessage","AsyncQueue","resultIterator","batch","push","close","message","error","arrayBuffer","Promise","resolve","reject","id","onMessage","removeEventListener","addEventListener"],"sources":["../../../../src/lib/worker-api/create-worker.ts"],"sourcesContent":["import type {\n WorkerMessageType,\n WorkerMessagePayload,\n WorkerContext,\n Process,\n ProcessInBatches\n} from '../../types';\nimport AsyncQueue from '../async-queue/async-queue';\nimport WorkerBody from '../worker-farm/worker-body';\n// import {validateWorkerVersion} from './validate-worker-version';\n\n/** Counter for jobs */\nlet requestId = 0;\nlet inputBatches: AsyncQueue<any>;\nlet options: {[key: string]: any};\n\nexport type ProcessOnMainThread = (\n data: any,\n options?: {[key: string]: any},\n context?: WorkerContext\n) => any;\n\n/**\n * Set up a WebWorkerGlobalScope to talk with the main thread\n */\nexport function createWorker(process: Process, processInBatches?: ProcessInBatches): void {\n if (!WorkerBody.inWorkerThread()) {\n return;\n }\n\n const context: WorkerContext = {\n process: processOnMainThread\n };\n\n // eslint-disable-next-line complexity\n WorkerBody.onmessage = async (type: WorkerMessageType, payload: WorkerMessagePayload) => {\n try {\n switch (type) {\n case 'process':\n if (!process) {\n throw new Error('Worker does not support atomic processing');\n }\n const result = await process(payload.input, payload.options || {}, context);\n WorkerBody.postMessage('done', {result});\n break;\n\n case 'process-in-batches':\n if (!processInBatches) {\n throw new Error('Worker does not support batched processing');\n }\n inputBatches = new AsyncQueue<any>();\n options = payload.options || {};\n const resultIterator = processInBatches(inputBatches, options, context);\n for await (const batch of resultIterator) {\n WorkerBody.postMessage('output-batch', {result: batch});\n }\n WorkerBody.postMessage('done', {});\n break;\n\n case 'input-batch':\n inputBatches.push(payload.input);\n break;\n\n case 'input-done':\n inputBatches.close();\n break;\n\n default:\n }\n } catch (error) {\n const message = error instanceof Error ? error.message : '';\n WorkerBody.postMessage('error', {error: message});\n }\n };\n}\n\nfunction processOnMainThread(arrayBuffer: ArrayBuffer, options = {}) {\n return new Promise((resolve, reject) => {\n const id = requestId++;\n\n /**\n */\n const onMessage = (type: string, payload: WorkerMessagePayload) => {\n if (payload.id !== id) {\n // not ours\n return;\n }\n\n switch (type) {\n case 'done':\n WorkerBody.removeEventListener(onMessage);\n resolve(payload.result);\n break;\n\n case 'error':\n WorkerBody.removeEventListener(onMessage);\n reject(payload.error);\n break;\n\n default:\n // ignore\n }\n };\n\n WorkerBody.addEventListener(onMessage);\n\n // Ask the main thread to decode data\n const payload = {id, input: arrayBuffer, options};\n WorkerBody.postMessage('process', payload);\n });\n}\n"],"mappings":"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"}
1
+ {"version":3,"file":"create-worker.js","names":["_asyncQueue","_interopRequireDefault","require","_workerBody","_asyncIterator","iterable","method","async","sync","retry","Symbol","asyncIterator","iterator","call","AsyncFromSyncIterator","TypeError","s","AsyncFromSyncIteratorContinuation","r","Object","Promise","reject","done","resolve","value","then","n","next","prototype","apply","arguments","return","_return","ret","throw","_throw","thr","requestId","inputBatches","options","createWorker","process","processInBatches","WorkerBody","inWorkerThread","context","processOnMainThread","onmessage","_ref","_asyncToGenerator2","default","_regenerator","mark","_callee","type","payload","result","resultIterator","_iteratorAbruptCompletion","_didIteratorError","_iteratorError","_iterator","_step","batch","message","wrap","_callee$","_context","prev","t0","Error","input","sent","postMessage","abrupt","AsyncQueue","t1","finish","push","close","t2","error","stop","_x","_x2","arrayBuffer","length","undefined","id","onMessage","removeEventListener","addEventListener"],"sources":["../../../../src/lib/worker-api/create-worker.ts"],"sourcesContent":["import type {\n WorkerMessageType,\n WorkerMessagePayload,\n WorkerContext,\n Process,\n ProcessInBatches\n} from '../../types';\nimport AsyncQueue from '../async-queue/async-queue';\nimport WorkerBody from '../worker-farm/worker-body';\n// import {validateWorkerVersion} from './validate-worker-version';\n\n/** Counter for jobs */\nlet requestId = 0;\nlet inputBatches: AsyncQueue<any>;\nlet options: {[key: string]: any};\n\nexport type ProcessOnMainThread = (\n data: any,\n options?: {[key: string]: any},\n context?: WorkerContext\n) => any;\n\n/**\n * Set up a WebWorkerGlobalScope to talk with the main thread\n */\nexport function createWorker(process: Process, processInBatches?: ProcessInBatches): void {\n if (!WorkerBody.inWorkerThread()) {\n return;\n }\n\n const context: WorkerContext = {\n process: processOnMainThread\n };\n\n // eslint-disable-next-line complexity\n WorkerBody.onmessage = async (type: WorkerMessageType, payload: WorkerMessagePayload) => {\n try {\n switch (type) {\n case 'process':\n if (!process) {\n throw new Error('Worker does not support atomic processing');\n }\n const result = await process(payload.input, payload.options || {}, context);\n WorkerBody.postMessage('done', {result});\n break;\n\n case 'process-in-batches':\n if (!processInBatches) {\n throw new Error('Worker does not support batched processing');\n }\n inputBatches = new AsyncQueue<any>();\n options = payload.options || {};\n const resultIterator = processInBatches(inputBatches, options, context);\n for await (const batch of resultIterator) {\n WorkerBody.postMessage('output-batch', {result: batch});\n }\n WorkerBody.postMessage('done', {});\n break;\n\n case 'input-batch':\n inputBatches.push(payload.input);\n break;\n\n case 'input-done':\n inputBatches.close();\n break;\n\n default:\n }\n } catch (error) {\n const message = error instanceof Error ? error.message : '';\n WorkerBody.postMessage('error', {error: message});\n }\n };\n}\n\nfunction processOnMainThread(arrayBuffer: ArrayBuffer, options = {}) {\n return new Promise((resolve, reject) => {\n const id = requestId++;\n\n /**\n */\n const onMessage = (type: string, payload: WorkerMessagePayload) => {\n if (payload.id !== id) {\n // not ours\n return;\n }\n\n switch (type) {\n case 'done':\n WorkerBody.removeEventListener(onMessage);\n resolve(payload.result);\n break;\n\n case 'error':\n WorkerBody.removeEventListener(onMessage);\n reject(payload.error);\n break;\n\n default:\n // ignore\n }\n };\n\n WorkerBody.addEventListener(onMessage);\n\n // Ask the main thread to decode data\n const payload = {id, input: arrayBuffer, options};\n WorkerBody.postMessage('process', payload);\n });\n}\n"],"mappings":";;;;;;;;;AAOA,IAAAA,WAAA,GAAAC,sBAAA,CAAAC,OAAA;AACA,IAAAC,WAAA,GAAAF,sBAAA,CAAAC,OAAA;AAAoD,SAAAE,eAAAC,QAAA,QAAAC,MAAA,EAAAC,KAAA,EAAAC,IAAA,EAAAC,KAAA,iCAAAC,MAAA,KAAAH,KAAA,GAAAG,MAAA,CAAAC,aAAA,EAAAH,IAAA,GAAAE,MAAA,CAAAE,QAAA,GAAAH,KAAA,WAAAF,KAAA,aAAAD,MAAA,GAAAD,QAAA,CAAAE,KAAA,WAAAD,MAAA,CAAAO,IAAA,CAAAR,QAAA,OAAAG,IAAA,aAAAF,MAAA,GAAAD,QAAA,CAAAG,IAAA,eAAAM,qBAAA,CAAAR,MAAA,CAAAO,IAAA,CAAAR,QAAA,IAAAE,KAAA,sBAAAC,IAAA,6BAAAO,SAAA;AAAA,SAAAD,sBAAAE,CAAA,aAAAC,kCAAAC,CAAA,QAAAC,MAAA,CAAAD,CAAA,MAAAA,CAAA,SAAAE,OAAA,CAAAC,MAAA,KAAAN,SAAA,CAAAG,CAAA,+BAAAI,IAAA,GAAAJ,CAAA,CAAAI,IAAA,SAAAF,OAAA,CAAAG,OAAA,CAAAL,CAAA,CAAAM,KAAA,EAAAC,IAAA,WAAAD,KAAA,aAAAA,KAAA,EAAAA,KAAA,EAAAF,IAAA,EAAAA,IAAA,iBAAAR,qBAAA,YAAAA,sBAAAE,CAAA,SAAAA,CAAA,GAAAA,CAAA,OAAAU,CAAA,GAAAV,CAAA,CAAAW,IAAA,KAAAb,qBAAA,CAAAc,SAAA,KAAAZ,CAAA,QAAAU,CAAA,QAAAC,IAAA,WAAAA,KAAA,WAAAV,iCAAA,MAAAS,CAAA,CAAAG,KAAA,MAAAb,CAAA,EAAAc,SAAA,OAAAC,MAAA,WAAAC,QAAAR,KAAA,QAAAS,GAAA,QAAAjB,CAAA,CAAAe,MAAA,oBAAAE,GAAA,GAAAb,OAAA,CAAAG,OAAA,GAAAC,KAAA,EAAAA,KAAA,EAAAF,IAAA,UAAAL,iCAAA,CAAAgB,GAAA,CAAAJ,KAAA,MAAAb,CAAA,EAAAc,SAAA,OAAAI,KAAA,WAAAC,OAAAX,KAAA,QAAAY,GAAA,QAAApB,CAAA,CAAAe,MAAA,oBAAAK,GAAA,GAAAhB,OAAA,CAAAC,MAAA,CAAAG,KAAA,IAAAP,iCAAA,CAAAmB,GAAA,CAAAP,KAAA,MAAAb,CAAA,EAAAc,SAAA,aAAAhB,qBAAA,CAAAE,CAAA;AAIpD,IAAIqB,SAAS,GAAG,CAAC;AACjB,IAAIC,YAA6B;AACjC,IAAIC,OAA6B;AAW1B,SAASC,YAAYA,CAACC,OAAgB,EAAEC,gBAAmC,EAAQ;EACxF,IAAI,CAACC,mBAAU,CAACC,cAAc,EAAE,EAAE;IAChC;EACF;EAEA,IAAMC,OAAsB,GAAG;IAC7BJ,OAAO,EAAEK;EACX,CAAC;EAGDH,mBAAU,CAACI,SAAS;IAAA,IAAAC,IAAA,OAAAC,kBAAA,CAAAC,OAAA,EAAAC,YAAA,CAAAD,OAAA,CAAAE,IAAA,CAAG,SAAAC,QAAOC,IAAuB,EAAEC,OAA6B;MAAA,IAAAC,MAAA,EAAAC,cAAA,EAAAC,yBAAA,EAAAC,iBAAA,EAAAC,cAAA,EAAAC,SAAA,EAAAC,KAAA,EAAAC,KAAA,EAAAC,OAAA;MAAA,OAAAb,YAAA,CAAAD,OAAA,CAAAe,IAAA,UAAAC,SAAAC,QAAA;QAAA,kBAAAA,QAAA,CAAAC,IAAA,GAAAD,QAAA,CAAAxC,IAAA;UAAA;YAAAwC,QAAA,CAAAC,IAAA;YAAAD,QAAA,CAAAE,EAAA,GAExEf,IAAI;YAAAa,QAAA,CAAAxC,IAAA,GAAAwC,QAAA,CAAAE,EAAA,KACL,SAAS,OAAAF,QAAA,CAAAE,EAAA,KAQT,oBAAoB,QAAAF,QAAA,CAAAE,EAAA,KAapB,aAAa,QAAAF,QAAA,CAAAE,EAAA,KAIb,YAAY;YAAA;UAAA;YAAA,IAxBV5B,OAAO;cAAA0B,QAAA,CAAAxC,IAAA;cAAA;YAAA;YAAA,MACJ,IAAI2C,KAAK,CAAC,2CAA2C,CAAC;UAAA;YAAAH,QAAA,CAAAxC,IAAA;YAAA,OAEzCc,OAAO,CAACc,OAAO,CAACgB,KAAK,EAAEhB,OAAO,CAAChB,OAAO,IAAI,CAAC,CAAC,EAAEM,OAAO,CAAC;UAAA;YAArEW,MAAM,GAAAW,QAAA,CAAAK,IAAA;YACZ7B,mBAAU,CAAC8B,WAAW,CAAC,MAAM,EAAE;cAACjB,MAAM,EAANA;YAAM,CAAC,CAAC;YAAC,OAAAW,QAAA,CAAAO,MAAA;UAAA;YAAA,IAIpChC,gBAAgB;cAAAyB,QAAA,CAAAxC,IAAA;cAAA;YAAA;YAAA,MACb,IAAI2C,KAAK,CAAC,4CAA4C,CAAC;UAAA;YAE/DhC,YAAY,GAAG,IAAIqC,mBAAU,EAAO;YACpCpC,OAAO,GAAGgB,OAAO,CAAChB,OAAO,IAAI,CAAC,CAAC;YACzBkB,cAAc,GAAGf,gBAAgB,CAACJ,YAAY,EAAEC,OAAO,EAAEM,OAAO,CAAC;YAAAa,yBAAA;YAAAC,iBAAA;YAAAQ,QAAA,CAAAC,IAAA;YAAAP,SAAA,GAAAzD,cAAA,CAC7CqD,cAAc;UAAA;YAAAU,QAAA,CAAAxC,IAAA;YAAA,OAAAkC,SAAA,CAAAlC,IAAA;UAAA;YAAA,MAAA+B,yBAAA,KAAAI,KAAA,GAAAK,QAAA,CAAAK,IAAA,EAAAlD,IAAA;cAAA6C,QAAA,CAAAxC,IAAA;cAAA;YAAA;YAAvBoC,KAAK,GAAAD,KAAA,CAAAtC,KAAA;YACpBmB,mBAAU,CAAC8B,WAAW,CAAC,cAAc,EAAE;cAACjB,MAAM,EAAEO;YAAK,CAAC,CAAC;UAAC;YAAAL,yBAAA;YAAAS,QAAA,CAAAxC,IAAA;YAAA;UAAA;YAAAwC,QAAA,CAAAxC,IAAA;YAAA;UAAA;YAAAwC,QAAA,CAAAC,IAAA;YAAAD,QAAA,CAAAS,EAAA,GAAAT,QAAA;YAAAR,iBAAA;YAAAC,cAAA,GAAAO,QAAA,CAAAS,EAAA;UAAA;YAAAT,QAAA,CAAAC,IAAA;YAAAD,QAAA,CAAAC,IAAA;YAAA,MAAAV,yBAAA,IAAAG,SAAA,CAAA9B,MAAA;cAAAoC,QAAA,CAAAxC,IAAA;cAAA;YAAA;YAAAwC,QAAA,CAAAxC,IAAA;YAAA,OAAAkC,SAAA,CAAA9B,MAAA;UAAA;YAAAoC,QAAA,CAAAC,IAAA;YAAA,KAAAT,iBAAA;cAAAQ,QAAA,CAAAxC,IAAA;cAAA;YAAA;YAAA,MAAAiC,cAAA;UAAA;YAAA,OAAAO,QAAA,CAAAU,MAAA;UAAA;YAAA,OAAAV,QAAA,CAAAU,MAAA;UAAA;YAE1DlC,mBAAU,CAAC8B,WAAW,CAAC,MAAM,EAAE,CAAC,CAAC,CAAC;YAAC,OAAAN,QAAA,CAAAO,MAAA;UAAA;YAInCpC,YAAY,CAACwC,IAAI,CAACvB,OAAO,CAACgB,KAAK,CAAC;YAAC,OAAAJ,QAAA,CAAAO,MAAA;UAAA;YAIjCpC,YAAY,CAACyC,KAAK,EAAE;YAAC,OAAAZ,QAAA,CAAAO,MAAA;UAAA;YAAAP,QAAA,CAAAxC,IAAA;YAAA;UAAA;YAAAwC,QAAA,CAAAC,IAAA;YAAAD,QAAA,CAAAa,EAAA,GAAAb,QAAA;YAMnBH,OAAO,GAAGG,QAAA,CAAAa,EAAA,YAAiBV,KAAK,GAAGH,QAAA,CAAAa,EAAA,CAAMhB,OAAO,GAAG,EAAE;YAC3DrB,mBAAU,CAAC8B,WAAW,CAAC,OAAO,EAAE;cAACQ,KAAK,EAAEjB;YAAO,CAAC,CAAC;UAAC;UAAA;YAAA,OAAAG,QAAA,CAAAe,IAAA;QAAA;MAAA,GAAA7B,OAAA;IAAA,CAErD;IAAA,iBAAA8B,EAAA,EAAAC,GAAA;MAAA,OAAApC,IAAA,CAAAnB,KAAA,OAAAC,SAAA;IAAA;EAAA;AACH;AAEA,SAASgB,mBAAmBA,CAACuC,WAAwB,EAAgB;EAAA,IAAd9C,OAAO,GAAAT,SAAA,CAAAwD,MAAA,QAAAxD,SAAA,QAAAyD,SAAA,GAAAzD,SAAA,MAAG,CAAC,CAAC;EACjE,OAAO,IAAIV,OAAO,CAAC,UAACG,OAAO,EAAEF,MAAM,EAAK;IACtC,IAAMmE,EAAE,GAAGnD,SAAS,EAAE;IAItB,IAAMoD,SAAS,GAAG,SAAZA,SAASA,CAAInC,IAAY,EAAEC,OAA6B,EAAK;MACjE,IAAIA,OAAO,CAACiC,EAAE,KAAKA,EAAE,EAAE;QAErB;MACF;MAEA,QAAQlC,IAAI;QACV,KAAK,MAAM;UACTX,mBAAU,CAAC+C,mBAAmB,CAACD,SAAS,CAAC;UACzClE,OAAO,CAACgC,OAAO,CAACC,MAAM,CAAC;UACvB;QAEF,KAAK,OAAO;UACVb,mBAAU,CAAC+C,mBAAmB,CAACD,SAAS,CAAC;UACzCpE,MAAM,CAACkC,OAAO,CAAC0B,KAAK,CAAC;UACrB;QAEF;MAAQ;IAGZ,CAAC;IAEDtC,mBAAU,CAACgD,gBAAgB,CAACF,SAAS,CAAC;IAGtC,IAAMlC,OAAO,GAAG;MAACiC,EAAE,EAAFA,EAAE;MAAEjB,KAAK,EAAEc,WAAW;MAAE9C,OAAO,EAAPA;IAAO,CAAC;IACjDI,mBAAU,CAAC8B,WAAW,CAAC,SAAS,EAAElB,OAAO,CAAC;EAC5C,CAAC,CAAC;AACJ"}
@@ -7,29 +7,23 @@ exports.getWorkerName = getWorkerName;
7
7
  exports.getWorkerURL = getWorkerURL;
8
8
  var _assert = require("../env-utils/assert");
9
9
  var _version = require("../env-utils/version");
10
-
11
10
  var NPM_TAG = 'beta';
12
- var VERSION = typeof "3.4.0-alpha.2" !== 'undefined' ? "3.4.0-alpha.2" : NPM_TAG;
13
-
11
+ var VERSION = typeof "3.4.0-alpha.3" !== 'undefined' ? "3.4.0-alpha.3" : NPM_TAG;
14
12
  function getWorkerName(worker) {
15
13
  var warning = worker.version !== VERSION ? " (worker-utils@".concat(VERSION, ")") : '';
16
14
  return "".concat(worker.name, "@").concat(worker.version).concat(warning);
17
15
  }
18
-
19
16
  function getWorkerURL(worker) {
20
17
  var options = arguments.length > 1 && arguments[1] !== undefined ? arguments[1] : {};
21
18
  var workerOptions = options[worker.id] || {};
22
19
  var workerFile = "".concat(worker.id, "-worker.js");
23
20
  var url = workerOptions.workerUrl;
24
-
25
21
  if (!url && worker.id === 'compression') {
26
22
  url = options.workerUrl;
27
23
  }
28
-
29
24
  if (options._workerType === 'test') {
30
25
  url = "modules/".concat(worker.module, "/dist/").concat(workerFile);
31
26
  }
32
-
33
27
  if (!url) {
34
28
  var version = worker.version;
35
29
  if (version === 'latest') {
@@ -39,7 +33,6 @@ function getWorkerURL(worker) {
39
33
  url = "https://unpkg.com/@loaders.gl/".concat(worker.module).concat(versionTag, "/dist/").concat(workerFile);
40
34
  }
41
35
  (0, _assert.assert)(url);
42
-
43
36
  return url;
44
37
  }
45
38
  //# sourceMappingURL=get-worker-url.js.map