@xylabs/threads 4.7.0 → 4.7.1
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/dist/{types/common.d.ts → common.d.ts} +1 -5
- package/dist/common.js +16 -0
- package/dist/esm/common.js +16 -0
- package/dist/esm/index.js +26 -0
- package/dist/esm/master/get-bundle-url.browser.js +25 -0
- package/dist/esm/master/implementation.browser.js +65 -0
- package/dist/esm/master/implementation.js +43 -0
- package/dist/esm/master/implementation.node.js +205 -0
- package/dist/esm/master/index.js +14 -0
- package/dist/esm/master/invocation-proxy.js +121 -0
- package/dist/esm/master/pool-types.js +14 -0
- package/dist/esm/master/pool.js +262 -0
- package/dist/esm/master/register.js +11 -0
- package/dist/esm/master/spawn.js +114 -0
- package/dist/esm/master/thread.js +18 -0
- package/dist/esm/observable-promise.js +132 -0
- package/dist/esm/observable.js +33 -0
- package/dist/esm/ponyfills.js +20 -0
- package/dist/esm/promise.js +23 -0
- package/dist/esm/serializers.js +41 -0
- package/dist/esm/symbols.js +8 -0
- package/dist/esm/transferable.js +25 -0
- package/dist/esm/types/master.js +9 -0
- package/dist/esm/types/messages.js +16 -0
- package/dist/esm/types/worker.js +2 -0
- package/dist/esm/worker/bundle-entry.js +26 -0
- package/dist/esm/worker/implementation.browser.js +24 -0
- package/dist/esm/worker/implementation.js +19 -0
- package/dist/esm/worker/implementation.tiny-worker.js +37 -0
- package/dist/esm/worker/implementation.worker_threads.js +41 -0
- package/dist/esm/worker/index.js +174 -0
- package/dist/esm/worker_threads.js +13 -0
- package/dist/index.d.ts +7 -0
- package/dist/index.js +26 -0
- package/dist/{types/master → master}/get-bundle-url.browser.d.ts +0 -1
- package/dist/master/get-bundle-url.browser.js +25 -0
- package/dist/{types/master → master}/implementation.browser.d.ts +1 -2
- package/dist/master/implementation.browser.js +65 -0
- package/dist/{types/master → master}/implementation.d.ts +1 -4
- package/dist/master/implementation.js +43 -0
- package/dist/{types/master → master}/implementation.node.d.ts +1 -2
- package/dist/master/implementation.node.js +205 -0
- package/dist/master/index.d.ts +10 -0
- package/dist/master/index.js +14 -0
- package/dist/{types/master → master}/invocation-proxy.d.ts +1 -2
- package/dist/master/invocation-proxy.js +121 -0
- package/dist/{types/master → master}/pool-types.d.ts +1 -16
- package/dist/master/pool-types.js +14 -0
- package/dist/master/pool.d.ts +50 -0
- package/dist/master/pool.js +262 -0
- package/dist/master/register.d.ts +1 -0
- package/dist/master/register.js +11 -0
- package/dist/{types/master → master}/spawn.d.ts +2 -12
- package/dist/master/spawn.js +114 -0
- package/dist/master/thread.d.ts +8 -0
- package/dist/master/thread.js +18 -0
- package/dist/{types/observable-promise.d.ts → observable-promise.d.ts} +0 -14
- package/dist/observable-promise.js +132 -0
- package/dist/observable.d.ts +11 -0
- package/dist/observable.js +33 -0
- package/dist/{types/ponyfills.d.ts → ponyfills.d.ts} +0 -1
- package/dist/ponyfills.js +20 -0
- package/dist/promise.d.ts +1 -0
- package/dist/promise.js +23 -0
- package/dist/{types/serializers.d.ts → serializers.d.ts} +0 -1
- package/dist/serializers.js +41 -0
- package/dist/{types/symbols.d.ts → symbols.d.ts} +0 -1
- package/dist/symbols.js +8 -0
- package/dist/transferable.d.ts +9 -0
- package/dist/transferable.js +25 -0
- package/dist/types/{types/master.d.ts → master.d.ts} +3 -17
- package/dist/types/master.js +9 -0
- package/dist/types/{types/messages.d.ts → messages.d.ts} +0 -1
- package/dist/types/messages.js +16 -0
- package/dist/types/{types/worker.d.ts → worker.d.ts} +0 -1
- package/dist/types/worker.js +2 -0
- package/dist/worker/bundle-entry.d.ts +1 -0
- package/dist/worker/bundle-entry.js +26 -0
- package/dist/worker/implementation.browser.d.ts +6 -0
- package/dist/worker/implementation.browser.js +24 -0
- package/dist/worker/implementation.d.ts +3 -0
- package/dist/worker/implementation.js +19 -0
- package/dist/worker/implementation.tiny-worker.d.ts +6 -0
- package/dist/worker/implementation.tiny-worker.js +37 -0
- package/dist/worker/implementation.worker_threads.d.ts +8 -0
- package/dist/worker/implementation.worker_threads.js +41 -0
- package/dist/worker/index.d.ts +5 -0
- package/dist/worker/index.js +174 -0
- package/dist/worker_threads.d.ts +8 -0
- package/dist/worker_threads.js +13 -0
- package/observable.d.ts +2 -0
- package/observable.js +2 -0
- package/observable.mjs +4 -0
- package/package.json +77 -66
- package/register.d.ts +2 -0
- package/register.js +2 -0
- package/register.mjs +1 -0
- package/rollup.config.js +16 -0
- package/src/common.ts +6 -10
- package/src/index.ts +9 -10
- package/src/master/get-bundle-url.browser.ts +1 -2
- package/src/master/implementation.browser.ts +2 -2
- package/src/master/implementation.node.ts +96 -19
- package/src/master/implementation.ts +2 -2
- package/src/master/index.ts +7 -7
- package/src/master/invocation-proxy.ts +6 -6
- package/src/master/pool-types.ts +1 -1
- package/src/master/pool.ts +13 -14
- package/src/master/register.ts +1 -2
- package/src/master/spawn.ts +8 -8
- package/src/master/thread.ts +2 -2
- package/src/observable-promise.ts +2 -3
- package/src/serializers.ts +1 -1
- package/src/transferable.ts +1 -2
- package/src/types/master.ts +3 -3
- package/src/worker/bundle-entry.ts +10 -0
- package/src/worker/{worker.browser.ts → implementation.browser.ts} +10 -26
- package/src/worker/implementation.tiny-worker.ts +55 -0
- package/src/worker/implementation.ts +23 -0
- package/src/worker/{worker.node.ts → implementation.worker_threads.ts} +12 -30
- package/src/worker/index.ts +230 -0
- package/src/worker_threads.ts +27 -0
- package/test/lib/index.ts +1 -0
- package/test/lib/serialization.ts +38 -0
- package/test/observable-promise.test.ts +205 -0
- package/test/observable.test.ts +87 -0
- package/test/pool.test.ts +183 -0
- package/test/serialization.test.ts +23 -0
- package/test/spawn.chromium.mocha.ts +53 -0
- package/test/spawn.test.ts +87 -0
- package/test/streaming.test.ts +29 -0
- package/test/transferables.test.ts +71 -0
- package/test/workers/arraybuffer-xor.ts +10 -0
- package/test/workers/count-to-five.ts +12 -0
- package/test/workers/counter.ts +19 -0
- package/test/workers/faulty-function.ts +5 -0
- package/test/workers/hello-world.ts +5 -0
- package/test/workers/increment.ts +8 -0
- package/test/workers/minmax.ts +25 -0
- package/test/workers/serialization.ts +13 -0
- package/test/workers/top-level-throw.ts +1 -0
- package/test-tooling/rollup/app.js +21 -0
- package/test-tooling/rollup/rollup.config.ts +14 -0
- package/test-tooling/rollup/worker.js +7 -0
- package/test-tooling/tsconfig/minimal.ts +12 -0
- package/test-tooling/webpack/addition-worker.ts +9 -0
- package/test-tooling/webpack/app-with-inlined-worker.ts +28 -0
- package/test-tooling/webpack/app.ts +61 -0
- package/test-tooling/webpack/pool-worker.ts +5 -0
- package/test-tooling/webpack/raw-loader.d.ts +4 -0
- package/test-tooling/webpack/webpack.chromium.mocha.ts +21 -0
- package/test-tooling/webpack/webpack.node.config.js +29 -0
- package/test-tooling/webpack/webpack.web.config.js +28 -0
- package/types/is-observable.d.ts +1 -1
- package/types/webworker.d.ts +9 -0
- package/worker.d.ts +2 -0
- package/worker.js +2 -0
- package/worker.mjs +6 -0
- package/dist/browser/master/implementation.browser.mjs +0 -89
- package/dist/browser/master/implementation.browser.mjs.map +0 -1
- package/dist/browser/worker/worker.browser.mjs +0 -291
- package/dist/browser/worker/worker.browser.mjs.map +0 -1
- package/dist/neutral/index.mjs +0 -1022
- package/dist/neutral/index.mjs.map +0 -1
- package/dist/neutral/master/implementation.mjs +0 -264
- package/dist/neutral/master/implementation.mjs.map +0 -1
- package/dist/neutral/master/index.mjs +0 -988
- package/dist/neutral/master/index.mjs.map +0 -1
- package/dist/neutral/master/pool.mjs +0 -579
- package/dist/neutral/master/pool.mjs.map +0 -1
- package/dist/neutral/master/register.mjs +0 -272
- package/dist/neutral/master/register.mjs.map +0 -1
- package/dist/neutral/master/spawn.mjs +0 -412
- package/dist/neutral/master/spawn.mjs.map +0 -1
- package/dist/neutral/master/thread.mjs +0 -29
- package/dist/neutral/master/thread.mjs.map +0 -1
- package/dist/neutral/observable-promise.mjs +0 -132
- package/dist/neutral/observable-promise.mjs.map +0 -1
- package/dist/neutral/observable.mjs +0 -31
- package/dist/neutral/observable.mjs.map +0 -1
- package/dist/node/master/implementation.node.mjs +0 -154
- package/dist/node/master/implementation.node.mjs.map +0 -1
- package/dist/node/worker/worker.node.mjs +0 -304
- package/dist/node/worker/worker.node.mjs.map +0 -1
- package/dist/types/common.d.ts.map +0 -1
- package/dist/types/index.d.ts +0 -9
- package/dist/types/index.d.ts.map +0 -1
- package/dist/types/master/get-bundle-url.browser.d.ts.map +0 -1
- package/dist/types/master/implementation.browser.d.ts.map +0 -1
- package/dist/types/master/implementation.d.ts.map +0 -1
- package/dist/types/master/implementation.node.d.ts.map +0 -1
- package/dist/types/master/index.d.ts +0 -13
- package/dist/types/master/index.d.ts.map +0 -1
- package/dist/types/master/invocation-proxy.d.ts.map +0 -1
- package/dist/types/master/pool-types.d.ts.map +0 -1
- package/dist/types/master/pool.d.ts +0 -93
- package/dist/types/master/pool.d.ts.map +0 -1
- package/dist/types/master/register.d.ts +0 -2
- package/dist/types/master/register.d.ts.map +0 -1
- package/dist/types/master/spawn.d.ts.map +0 -1
- package/dist/types/master/thread.d.ts +0 -13
- package/dist/types/master/thread.d.ts.map +0 -1
- package/dist/types/observable-promise.d.ts.map +0 -1
- package/dist/types/observable.d.ts +0 -21
- package/dist/types/observable.d.ts.map +0 -1
- package/dist/types/ponyfills.d.ts.map +0 -1
- package/dist/types/promise.d.ts +0 -6
- package/dist/types/promise.d.ts.map +0 -1
- package/dist/types/serializers.d.ts.map +0 -1
- package/dist/types/symbols.d.ts.map +0 -1
- package/dist/types/transferable.d.ts +0 -43
- package/dist/types/transferable.d.ts.map +0 -1
- package/dist/types/types/master.d.ts.map +0 -1
- package/dist/types/types/messages.d.ts.map +0 -1
- package/dist/types/types/worker.d.ts.map +0 -1
- package/dist/types/worker/WorkerGlobalScope.d.ts +0 -6
- package/dist/types/worker/WorkerGlobalScope.d.ts.map +0 -1
- package/dist/types/worker/expose.d.ts +0 -4
- package/dist/types/worker/expose.d.ts.map +0 -1
- package/dist/types/worker/worker.browser.d.ts +0 -14
- package/dist/types/worker/worker.browser.d.ts.map +0 -1
- package/dist/types/worker/worker.node.d.ts +0 -25
- package/dist/types/worker/worker.node.d.ts.map +0 -1
- package/src/worker/WorkerGlobalScope.ts +0 -5
- package/src/worker/expose.ts +0 -234
- package/src/worker/is-observable.d.ts +0 -7
- package/xy.config.ts +0 -24
|
@@ -1,8 +1,4 @@
|
|
|
1
|
-
import type { JsonSerializable,
|
|
2
|
-
declare global {
|
|
3
|
-
var registeredSerializer: Serializer<JsonSerializable>;
|
|
4
|
-
}
|
|
1
|
+
import type { JsonSerializable, SerializerImplementation } from './serializers';
|
|
5
2
|
export declare function registerSerializer(serializer: SerializerImplementation<JsonSerializable>): void;
|
|
6
3
|
export declare function deserialize(message: JsonSerializable): any;
|
|
7
4
|
export declare function serialize(input: any): JsonSerializable;
|
|
8
|
-
//# sourceMappingURL=common.d.ts.map
|
package/dist/common.js
ADDED
|
@@ -0,0 +1,16 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
+
exports.registerSerializer = registerSerializer;
|
|
4
|
+
exports.deserialize = deserialize;
|
|
5
|
+
exports.serialize = serialize;
|
|
6
|
+
const serializers_1 = require("./serializers");
|
|
7
|
+
let registeredSerializer = serializers_1.DefaultSerializer;
|
|
8
|
+
function registerSerializer(serializer) {
|
|
9
|
+
registeredSerializer = (0, serializers_1.extendSerializer)(registeredSerializer, serializer);
|
|
10
|
+
}
|
|
11
|
+
function deserialize(message) {
|
|
12
|
+
return registeredSerializer.deserialize(message);
|
|
13
|
+
}
|
|
14
|
+
function serialize(input) {
|
|
15
|
+
return registeredSerializer.serialize(input);
|
|
16
|
+
}
|
|
@@ -0,0 +1,16 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
+
exports.registerSerializer = registerSerializer;
|
|
4
|
+
exports.deserialize = deserialize;
|
|
5
|
+
exports.serialize = serialize;
|
|
6
|
+
const serializers_1 = require("./serializers");
|
|
7
|
+
let registeredSerializer = serializers_1.DefaultSerializer;
|
|
8
|
+
function registerSerializer(serializer) {
|
|
9
|
+
registeredSerializer = (0, serializers_1.extendSerializer)(registeredSerializer, serializer);
|
|
10
|
+
}
|
|
11
|
+
function deserialize(message) {
|
|
12
|
+
return registeredSerializer.deserialize(message);
|
|
13
|
+
}
|
|
14
|
+
function serialize(input) {
|
|
15
|
+
return registeredSerializer.serialize(input);
|
|
16
|
+
}
|
|
@@ -0,0 +1,26 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
var __createBinding = (this && this.__createBinding) || (Object.create ? (function(o, m, k, k2) {
|
|
3
|
+
if (k2 === undefined) k2 = k;
|
|
4
|
+
var desc = Object.getOwnPropertyDescriptor(m, k);
|
|
5
|
+
if (!desc || ("get" in desc ? !m.__esModule : desc.writable || desc.configurable)) {
|
|
6
|
+
desc = { enumerable: true, get: function() { return m[k]; } };
|
|
7
|
+
}
|
|
8
|
+
Object.defineProperty(o, k2, desc);
|
|
9
|
+
}) : (function(o, m, k, k2) {
|
|
10
|
+
if (k2 === undefined) k2 = k;
|
|
11
|
+
o[k2] = m[k];
|
|
12
|
+
}));
|
|
13
|
+
var __exportStar = (this && this.__exportStar) || function(m, exports) {
|
|
14
|
+
for (var p in m) if (p !== "default" && !Object.prototype.hasOwnProperty.call(exports, p)) __createBinding(exports, m, p);
|
|
15
|
+
};
|
|
16
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
17
|
+
exports.expose = exports.Transfer = exports.DefaultSerializer = exports.registerSerializer = void 0;
|
|
18
|
+
var common_1 = require("./common");
|
|
19
|
+
Object.defineProperty(exports, "registerSerializer", { enumerable: true, get: function () { return common_1.registerSerializer; } });
|
|
20
|
+
__exportStar(require("./master/index"), exports);
|
|
21
|
+
var serializers_1 = require("./serializers");
|
|
22
|
+
Object.defineProperty(exports, "DefaultSerializer", { enumerable: true, get: function () { return serializers_1.DefaultSerializer; } });
|
|
23
|
+
var transferable_1 = require("./transferable");
|
|
24
|
+
Object.defineProperty(exports, "Transfer", { enumerable: true, get: function () { return transferable_1.Transfer; } });
|
|
25
|
+
var index_1 = require("./worker/index");
|
|
26
|
+
Object.defineProperty(exports, "expose", { enumerable: true, get: function () { return index_1.expose; } });
|
|
@@ -0,0 +1,25 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
+
exports.getBundleURL = getBundleURLCached;
|
|
4
|
+
let bundleURL;
|
|
5
|
+
function getBundleURLCached() {
|
|
6
|
+
if (!bundleURL) {
|
|
7
|
+
bundleURL = getBundleURL();
|
|
8
|
+
}
|
|
9
|
+
return bundleURL;
|
|
10
|
+
}
|
|
11
|
+
function getBundleURL() {
|
|
12
|
+
try {
|
|
13
|
+
throw new Error('getBundleURL failed');
|
|
14
|
+
}
|
|
15
|
+
catch (err) {
|
|
16
|
+
const matches = ('' + err.stack).match(/(https?|file|ftp|chrome-extension|moz-extension):\/\/[^\n)]+/g);
|
|
17
|
+
if (matches) {
|
|
18
|
+
return getBaseURL(matches[0]);
|
|
19
|
+
}
|
|
20
|
+
}
|
|
21
|
+
return '/';
|
|
22
|
+
}
|
|
23
|
+
function getBaseURL(url) {
|
|
24
|
+
return ('' + url).replace(/^((?:https?|file|ftp|chrome-extension|moz-extension):\/\/.+)?\/[^/]+(?:\?.*)?$/, '$1') + '/';
|
|
25
|
+
}
|
|
@@ -0,0 +1,65 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
+
exports.defaultPoolSize = void 0;
|
|
4
|
+
exports.getWorkerImplementation = getWorkerImplementation;
|
|
5
|
+
exports.isWorkerRuntime = isWorkerRuntime;
|
|
6
|
+
const get_bundle_url_browser_1 = require("./get-bundle-url.browser");
|
|
7
|
+
exports.defaultPoolSize = typeof navigator !== 'undefined' && navigator.hardwareConcurrency ? navigator.hardwareConcurrency : 4;
|
|
8
|
+
const isAbsoluteURL = (value) => /^[A-Za-z][\d+.A-Za-z\-]*:/.test(value);
|
|
9
|
+
function createSourceBlobURL(code) {
|
|
10
|
+
const blob = new Blob([code], { type: 'application/javascript' });
|
|
11
|
+
return URL.createObjectURL(blob);
|
|
12
|
+
}
|
|
13
|
+
function selectWorkerImplementation() {
|
|
14
|
+
if (typeof Worker === 'undefined') {
|
|
15
|
+
return class NoWebWorker {
|
|
16
|
+
constructor() {
|
|
17
|
+
throw new Error("No web worker implementation available. You might have tried to spawn a worker within a worker in a browser that doesn't support workers in workers.");
|
|
18
|
+
}
|
|
19
|
+
};
|
|
20
|
+
}
|
|
21
|
+
class WebWorker extends Worker {
|
|
22
|
+
constructor(url, options) {
|
|
23
|
+
if (typeof url === 'string' && options && options._baseURL) {
|
|
24
|
+
url = new URL(url, options._baseURL);
|
|
25
|
+
}
|
|
26
|
+
else if (typeof url === 'string' && !isAbsoluteURL(url) && /^file:\/\//i.test((0, get_bundle_url_browser_1.getBundleURL)())) {
|
|
27
|
+
url = new URL(url, (0, get_bundle_url_browser_1.getBundleURL)().replace(/\/[^/]+$/, '/'));
|
|
28
|
+
if (options?.CORSWorkaround ?? true) {
|
|
29
|
+
url = createSourceBlobURL(`importScripts(${JSON.stringify(url)});`);
|
|
30
|
+
}
|
|
31
|
+
}
|
|
32
|
+
if (typeof url === 'string'
|
|
33
|
+
&& isAbsoluteURL(url)
|
|
34
|
+
&& (options?.CORSWorkaround ?? true)) {
|
|
35
|
+
url = createSourceBlobURL(`importScripts(${JSON.stringify(url)});`);
|
|
36
|
+
}
|
|
37
|
+
super(url, options);
|
|
38
|
+
}
|
|
39
|
+
}
|
|
40
|
+
class BlobWorker extends WebWorker {
|
|
41
|
+
constructor(blob, options) {
|
|
42
|
+
const url = globalThis.URL.createObjectURL(blob);
|
|
43
|
+
super(url, options);
|
|
44
|
+
}
|
|
45
|
+
static fromText(source, options) {
|
|
46
|
+
const blob = new globalThis.Blob([source], { type: 'text/javascript' });
|
|
47
|
+
return new BlobWorker(blob, options);
|
|
48
|
+
}
|
|
49
|
+
}
|
|
50
|
+
return {
|
|
51
|
+
blob: BlobWorker,
|
|
52
|
+
default: WebWorker,
|
|
53
|
+
};
|
|
54
|
+
}
|
|
55
|
+
let implementation;
|
|
56
|
+
function getWorkerImplementation() {
|
|
57
|
+
if (!implementation) {
|
|
58
|
+
implementation = selectWorkerImplementation();
|
|
59
|
+
}
|
|
60
|
+
return implementation;
|
|
61
|
+
}
|
|
62
|
+
function isWorkerRuntime() {
|
|
63
|
+
const isWindowContext = typeof globalThis !== 'undefined' && typeof Window !== 'undefined' && globalThis instanceof Window;
|
|
64
|
+
return typeof globalThis !== 'undefined' && self['postMessage'] && !isWindowContext ? true : false;
|
|
65
|
+
}
|
|
@@ -0,0 +1,43 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
var __createBinding = (this && this.__createBinding) || (Object.create ? (function(o, m, k, k2) {
|
|
3
|
+
if (k2 === undefined) k2 = k;
|
|
4
|
+
var desc = Object.getOwnPropertyDescriptor(m, k);
|
|
5
|
+
if (!desc || ("get" in desc ? !m.__esModule : desc.writable || desc.configurable)) {
|
|
6
|
+
desc = { enumerable: true, get: function() { return m[k]; } };
|
|
7
|
+
}
|
|
8
|
+
Object.defineProperty(o, k2, desc);
|
|
9
|
+
}) : (function(o, m, k, k2) {
|
|
10
|
+
if (k2 === undefined) k2 = k;
|
|
11
|
+
o[k2] = m[k];
|
|
12
|
+
}));
|
|
13
|
+
var __setModuleDefault = (this && this.__setModuleDefault) || (Object.create ? (function(o, v) {
|
|
14
|
+
Object.defineProperty(o, "default", { enumerable: true, value: v });
|
|
15
|
+
}) : function(o, v) {
|
|
16
|
+
o["default"] = v;
|
|
17
|
+
});
|
|
18
|
+
var __importStar = (this && this.__importStar) || (function () {
|
|
19
|
+
var ownKeys = function(o) {
|
|
20
|
+
ownKeys = Object.getOwnPropertyNames || function (o) {
|
|
21
|
+
var ar = [];
|
|
22
|
+
for (var k in o) if (Object.prototype.hasOwnProperty.call(o, k)) ar[ar.length] = k;
|
|
23
|
+
return ar;
|
|
24
|
+
};
|
|
25
|
+
return ownKeys(o);
|
|
26
|
+
};
|
|
27
|
+
return function (mod) {
|
|
28
|
+
if (mod && mod.__esModule) return mod;
|
|
29
|
+
var result = {};
|
|
30
|
+
if (mod != null) for (var k = ownKeys(mod), i = 0; i < k.length; i++) if (k[i] !== "default") __createBinding(result, mod, k[i]);
|
|
31
|
+
__setModuleDefault(result, mod);
|
|
32
|
+
return result;
|
|
33
|
+
};
|
|
34
|
+
})();
|
|
35
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
36
|
+
exports.isWorkerRuntime = exports.getWorkerImplementation = exports.defaultPoolSize = void 0;
|
|
37
|
+
const BrowserImplementation = __importStar(require("./implementation.browser"));
|
|
38
|
+
const NodeImplementation = __importStar(require("./implementation.node"));
|
|
39
|
+
const runningInNode = typeof process !== 'undefined' && process.arch !== 'browser' && 'pid' in process;
|
|
40
|
+
const implementation = runningInNode ? NodeImplementation : BrowserImplementation;
|
|
41
|
+
exports.defaultPoolSize = implementation.defaultPoolSize;
|
|
42
|
+
exports.getWorkerImplementation = implementation.getWorkerImplementation;
|
|
43
|
+
exports.isWorkerRuntime = implementation.isWorkerRuntime;
|
|
@@ -0,0 +1,205 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
var __importDefault = (this && this.__importDefault) || function (mod) {
|
|
3
|
+
return (mod && mod.__esModule) ? mod : { "default": mod };
|
|
4
|
+
};
|
|
5
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
6
|
+
exports.defaultPoolSize = void 0;
|
|
7
|
+
exports.getWorkerImplementation = getWorkerImplementation;
|
|
8
|
+
exports.isWorkerRuntime = isWorkerRuntime;
|
|
9
|
+
const node_events_1 = require("node:events");
|
|
10
|
+
const node_os_1 = require("node:os");
|
|
11
|
+
const node_path_1 = __importDefault(require("node:path"));
|
|
12
|
+
const node_url_1 = require("node:url");
|
|
13
|
+
const callsites_3_1_0_1 = __importDefault(require("callsites-3-1-0"));
|
|
14
|
+
let tsNodeAvailable;
|
|
15
|
+
exports.defaultPoolSize = (0, node_os_1.cpus)().length;
|
|
16
|
+
function detectTsNode() {
|
|
17
|
+
if (typeof __non_webpack_require__ === 'function') {
|
|
18
|
+
return false;
|
|
19
|
+
}
|
|
20
|
+
if (tsNodeAvailable) {
|
|
21
|
+
return tsNodeAvailable;
|
|
22
|
+
}
|
|
23
|
+
try {
|
|
24
|
+
eval('require').resolve('ts-node');
|
|
25
|
+
tsNodeAvailable = true;
|
|
26
|
+
}
|
|
27
|
+
catch (error) {
|
|
28
|
+
if (error && error.code === 'MODULE_NOT_FOUND') {
|
|
29
|
+
tsNodeAvailable = false;
|
|
30
|
+
}
|
|
31
|
+
else {
|
|
32
|
+
throw error;
|
|
33
|
+
}
|
|
34
|
+
}
|
|
35
|
+
return tsNodeAvailable;
|
|
36
|
+
}
|
|
37
|
+
function createTsNodeModule(scriptPath) {
|
|
38
|
+
return `
|
|
39
|
+
require("ts-node/register/transpile-only");
|
|
40
|
+
require(${JSON.stringify(scriptPath)});
|
|
41
|
+
`;
|
|
42
|
+
}
|
|
43
|
+
function rebaseScriptPath(scriptPath, ignoreRegex) {
|
|
44
|
+
const parentCallSite = (0, callsites_3_1_0_1.default)().find((callsite) => {
|
|
45
|
+
const filename = callsite.getFileName();
|
|
46
|
+
return Boolean(filename && !filename.match(ignoreRegex) && !/[/\\]master[/\\]implementation/.test(filename) && !/^internal\/process/.test(filename));
|
|
47
|
+
});
|
|
48
|
+
const rawCallerPath = parentCallSite ? parentCallSite.getFileName() : null;
|
|
49
|
+
let callerPath = rawCallerPath ? rawCallerPath : null;
|
|
50
|
+
if (callerPath && callerPath.startsWith('file:')) {
|
|
51
|
+
callerPath = (0, node_url_1.fileURLToPath)(callerPath);
|
|
52
|
+
}
|
|
53
|
+
return callerPath ? node_path_1.default.join(node_path_1.default.dirname(callerPath), scriptPath) : scriptPath;
|
|
54
|
+
}
|
|
55
|
+
function resolveScriptPath(scriptPath, baseURL) {
|
|
56
|
+
const makeRelative = (filePath) => {
|
|
57
|
+
return node_path_1.default.isAbsolute(filePath) ? filePath : node_path_1.default.join(baseURL || eval('__dirname'), filePath);
|
|
58
|
+
};
|
|
59
|
+
return typeof __non_webpack_require__ === 'function'
|
|
60
|
+
? __non_webpack_require__.resolve(makeRelative(scriptPath))
|
|
61
|
+
: eval('require').resolve(makeRelative(rebaseScriptPath(scriptPath, /[/\\]worker_threads[/\\]/)));
|
|
62
|
+
}
|
|
63
|
+
function initWorkerThreadsWorker() {
|
|
64
|
+
const NativeWorker = typeof __non_webpack_require__ === 'function' ? __non_webpack_require__('worker_threads').Worker : eval('require')('worker_threads').Worker;
|
|
65
|
+
let allWorkers = [];
|
|
66
|
+
class Worker extends NativeWorker {
|
|
67
|
+
mappedEventListeners;
|
|
68
|
+
constructor(scriptPath, options) {
|
|
69
|
+
const resolvedScriptPath = options && options.fromSource ? null : resolveScriptPath(scriptPath, (options || {})._baseURL);
|
|
70
|
+
if (!resolvedScriptPath) {
|
|
71
|
+
const sourceCode = scriptPath;
|
|
72
|
+
super(sourceCode, { ...options, eval: true });
|
|
73
|
+
}
|
|
74
|
+
else if (/\.tsx?$/i.test(resolvedScriptPath) && detectTsNode()) {
|
|
75
|
+
super(createTsNodeModule(resolvedScriptPath), { ...options, eval: true });
|
|
76
|
+
}
|
|
77
|
+
else if (/\.asar[/\\]/.test(resolvedScriptPath)) {
|
|
78
|
+
super(resolvedScriptPath.replace(/\.asar([/\\])/, '.asar.unpacked$1'), options);
|
|
79
|
+
}
|
|
80
|
+
else {
|
|
81
|
+
super(resolvedScriptPath, options);
|
|
82
|
+
}
|
|
83
|
+
this.mappedEventListeners = new WeakMap();
|
|
84
|
+
allWorkers.push(this);
|
|
85
|
+
}
|
|
86
|
+
addEventListener(eventName, rawListener) {
|
|
87
|
+
const listener = (message) => {
|
|
88
|
+
rawListener({ data: message });
|
|
89
|
+
};
|
|
90
|
+
this.mappedEventListeners.set(rawListener, listener);
|
|
91
|
+
this.on(eventName, listener);
|
|
92
|
+
}
|
|
93
|
+
removeEventListener(eventName, rawListener) {
|
|
94
|
+
const listener = this.mappedEventListeners.get(rawListener) || rawListener;
|
|
95
|
+
this.off(eventName, listener);
|
|
96
|
+
}
|
|
97
|
+
}
|
|
98
|
+
const terminateWorkersAndMaster = () => {
|
|
99
|
+
Promise.all(allWorkers.map(worker => worker.terminate())).then(() => process.exit(0), () => process.exit(1));
|
|
100
|
+
allWorkers = [];
|
|
101
|
+
};
|
|
102
|
+
process.on('SIGINT', () => terminateWorkersAndMaster());
|
|
103
|
+
process.on('SIGTERM', () => terminateWorkersAndMaster());
|
|
104
|
+
class BlobWorker extends Worker {
|
|
105
|
+
constructor(blob, options) {
|
|
106
|
+
super(Buffer.from(blob).toString('utf-8'), { ...options, fromSource: true });
|
|
107
|
+
}
|
|
108
|
+
static fromText(source, options) {
|
|
109
|
+
return new Worker(source, { ...options, fromSource: true });
|
|
110
|
+
}
|
|
111
|
+
}
|
|
112
|
+
return {
|
|
113
|
+
blob: BlobWorker,
|
|
114
|
+
default: Worker,
|
|
115
|
+
};
|
|
116
|
+
}
|
|
117
|
+
function initTinyWorker() {
|
|
118
|
+
const TinyWorker = require('tiny-worker');
|
|
119
|
+
let allWorkers = [];
|
|
120
|
+
class Worker extends TinyWorker {
|
|
121
|
+
emitter;
|
|
122
|
+
constructor(scriptPath, options) {
|
|
123
|
+
const resolvedScriptPath = options && options.fromSource
|
|
124
|
+
? null
|
|
125
|
+
: process.platform === 'win32'
|
|
126
|
+
? `file:///${resolveScriptPath(scriptPath).replaceAll('\\', '/')}`
|
|
127
|
+
: resolveScriptPath(scriptPath);
|
|
128
|
+
if (!resolvedScriptPath) {
|
|
129
|
+
const sourceCode = scriptPath;
|
|
130
|
+
super(new Function(sourceCode), [], { esm: true });
|
|
131
|
+
}
|
|
132
|
+
else if (/\.tsx?$/i.test(resolvedScriptPath) && detectTsNode()) {
|
|
133
|
+
super(new Function(createTsNodeModule(resolveScriptPath(scriptPath))), [], { esm: true });
|
|
134
|
+
}
|
|
135
|
+
else if (/\.asar[/\\]/.test(resolvedScriptPath)) {
|
|
136
|
+
super(resolvedScriptPath.replace(/\.asar([/\\])/, '.asar.unpacked$1'), [], { esm: true });
|
|
137
|
+
}
|
|
138
|
+
else {
|
|
139
|
+
super(resolvedScriptPath, [], { esm: true });
|
|
140
|
+
}
|
|
141
|
+
allWorkers.push(this);
|
|
142
|
+
this.emitter = new node_events_1.EventEmitter();
|
|
143
|
+
this.onerror = (error) => this.emitter.emit('error', error);
|
|
144
|
+
this.onmessage = (message) => this.emitter.emit('message', message);
|
|
145
|
+
}
|
|
146
|
+
addEventListener(eventName, listener) {
|
|
147
|
+
this.emitter.addListener(eventName, listener);
|
|
148
|
+
}
|
|
149
|
+
removeEventListener(eventName, listener) {
|
|
150
|
+
this.emitter.removeListener(eventName, listener);
|
|
151
|
+
}
|
|
152
|
+
terminate() {
|
|
153
|
+
allWorkers = allWorkers.filter(worker => worker !== this);
|
|
154
|
+
return super.terminate();
|
|
155
|
+
}
|
|
156
|
+
}
|
|
157
|
+
const terminateWorkersAndMaster = () => {
|
|
158
|
+
Promise.all(allWorkers.map(worker => worker.terminate())).then(() => process.exit(0), () => process.exit(1));
|
|
159
|
+
allWorkers = [];
|
|
160
|
+
};
|
|
161
|
+
process.on('SIGINT', () => terminateWorkersAndMaster());
|
|
162
|
+
process.on('SIGTERM', () => terminateWorkersAndMaster());
|
|
163
|
+
class BlobWorker extends Worker {
|
|
164
|
+
constructor(blob, options) {
|
|
165
|
+
super(Buffer.from(blob).toString('utf-8'), { ...options, fromSource: true });
|
|
166
|
+
}
|
|
167
|
+
static fromText(source, options) {
|
|
168
|
+
return new Worker(source, { ...options, fromSource: true });
|
|
169
|
+
}
|
|
170
|
+
}
|
|
171
|
+
return {
|
|
172
|
+
blob: BlobWorker,
|
|
173
|
+
default: Worker,
|
|
174
|
+
};
|
|
175
|
+
}
|
|
176
|
+
let implementation;
|
|
177
|
+
let isTinyWorker;
|
|
178
|
+
function selectWorkerImplementation() {
|
|
179
|
+
try {
|
|
180
|
+
isTinyWorker = false;
|
|
181
|
+
return initWorkerThreadsWorker();
|
|
182
|
+
}
|
|
183
|
+
catch {
|
|
184
|
+
console.debug('Node worker_threads not available. Trying to fall back to tiny-worker polyfill...');
|
|
185
|
+
isTinyWorker = true;
|
|
186
|
+
return initTinyWorker();
|
|
187
|
+
}
|
|
188
|
+
}
|
|
189
|
+
function getWorkerImplementation() {
|
|
190
|
+
if (!implementation) {
|
|
191
|
+
implementation = selectWorkerImplementation();
|
|
192
|
+
}
|
|
193
|
+
return implementation;
|
|
194
|
+
}
|
|
195
|
+
function isWorkerRuntime() {
|
|
196
|
+
if (isTinyWorker) {
|
|
197
|
+
return self !== undefined && self['postMessage'] ? true : false;
|
|
198
|
+
}
|
|
199
|
+
else {
|
|
200
|
+
const isMainThread = typeof __non_webpack_require__ === 'function'
|
|
201
|
+
? __non_webpack_require__('worker_threads').isMainThread
|
|
202
|
+
: eval('require')('worker_threads').isMainThread;
|
|
203
|
+
return !isMainThread;
|
|
204
|
+
}
|
|
205
|
+
}
|
|
@@ -0,0 +1,14 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
+
exports.isWorkerRuntime = exports.Worker = exports.BlobWorker = exports.Thread = exports.spawn = exports.Pool = void 0;
|
|
4
|
+
const implementation_1 = require("./implementation");
|
|
5
|
+
var pool_1 = require("./pool");
|
|
6
|
+
Object.defineProperty(exports, "Pool", { enumerable: true, get: function () { return pool_1.Pool; } });
|
|
7
|
+
var spawn_1 = require("./spawn");
|
|
8
|
+
Object.defineProperty(exports, "spawn", { enumerable: true, get: function () { return spawn_1.spawn; } });
|
|
9
|
+
var thread_1 = require("./thread");
|
|
10
|
+
Object.defineProperty(exports, "Thread", { enumerable: true, get: function () { return thread_1.Thread; } });
|
|
11
|
+
exports.BlobWorker = (0, implementation_1.getWorkerImplementation)().blob;
|
|
12
|
+
exports.Worker = (0, implementation_1.getWorkerImplementation)().default;
|
|
13
|
+
var implementation_2 = require("./implementation");
|
|
14
|
+
Object.defineProperty(exports, "isWorkerRuntime", { enumerable: true, get: function () { return implementation_2.isWorkerRuntime; } });
|
|
@@ -0,0 +1,121 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
var __importDefault = (this && this.__importDefault) || function (mod) {
|
|
3
|
+
return (mod && mod.__esModule) ? mod : { "default": mod };
|
|
4
|
+
};
|
|
5
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
6
|
+
exports.createProxyFunction = createProxyFunction;
|
|
7
|
+
exports.createProxyModule = createProxyModule;
|
|
8
|
+
const debug_1 = __importDefault(require("debug"));
|
|
9
|
+
const observable_fns_1 = require("observable-fns");
|
|
10
|
+
const common_1 = require("../common");
|
|
11
|
+
const observable_promise_1 = require("../observable-promise");
|
|
12
|
+
const transferable_1 = require("../transferable");
|
|
13
|
+
const messages_1 = require("../types/messages");
|
|
14
|
+
const debugMessages = (0, debug_1.default)('threads:master:messages');
|
|
15
|
+
let nextJobUID = 1;
|
|
16
|
+
const dedupe = (array) => [...new Set(array)];
|
|
17
|
+
const isJobErrorMessage = (data) => data && data.type === messages_1.WorkerMessageType.error;
|
|
18
|
+
const isJobResultMessage = (data) => data && data.type === messages_1.WorkerMessageType.result;
|
|
19
|
+
const isJobStartMessage = (data) => data && data.type === messages_1.WorkerMessageType.running;
|
|
20
|
+
function createObservableForJob(worker, jobUID) {
|
|
21
|
+
return new observable_fns_1.Observable((observer) => {
|
|
22
|
+
let asyncType;
|
|
23
|
+
const messageHandler = ((event) => {
|
|
24
|
+
debugMessages('Message from worker:', event.data);
|
|
25
|
+
if (!event.data || event.data.uid !== jobUID)
|
|
26
|
+
return;
|
|
27
|
+
if (isJobStartMessage(event.data)) {
|
|
28
|
+
asyncType = event.data.resultType;
|
|
29
|
+
}
|
|
30
|
+
else if (isJobResultMessage(event.data)) {
|
|
31
|
+
if (asyncType === 'promise') {
|
|
32
|
+
if (event.data.payload !== undefined) {
|
|
33
|
+
observer.next((0, common_1.deserialize)(event.data.payload));
|
|
34
|
+
}
|
|
35
|
+
observer.complete();
|
|
36
|
+
worker.removeEventListener('message', messageHandler);
|
|
37
|
+
}
|
|
38
|
+
else {
|
|
39
|
+
if (event.data.payload) {
|
|
40
|
+
observer.next((0, common_1.deserialize)(event.data.payload));
|
|
41
|
+
}
|
|
42
|
+
if (event.data.complete) {
|
|
43
|
+
observer.complete();
|
|
44
|
+
worker.removeEventListener('message', messageHandler);
|
|
45
|
+
}
|
|
46
|
+
}
|
|
47
|
+
}
|
|
48
|
+
else if (isJobErrorMessage(event.data)) {
|
|
49
|
+
const error = (0, common_1.deserialize)(event.data.error);
|
|
50
|
+
if (asyncType === 'promise' || !asyncType) {
|
|
51
|
+
observer.error(error);
|
|
52
|
+
}
|
|
53
|
+
else {
|
|
54
|
+
observer.error(error);
|
|
55
|
+
}
|
|
56
|
+
worker.removeEventListener('message', messageHandler);
|
|
57
|
+
}
|
|
58
|
+
});
|
|
59
|
+
worker.addEventListener('message', messageHandler);
|
|
60
|
+
return () => {
|
|
61
|
+
if (asyncType === 'observable' || !asyncType) {
|
|
62
|
+
const cancelMessage = {
|
|
63
|
+
type: messages_1.MasterMessageType.cancel,
|
|
64
|
+
uid: jobUID,
|
|
65
|
+
};
|
|
66
|
+
worker.postMessage(cancelMessage);
|
|
67
|
+
}
|
|
68
|
+
worker.removeEventListener('message', messageHandler);
|
|
69
|
+
};
|
|
70
|
+
});
|
|
71
|
+
}
|
|
72
|
+
function prepareArguments(rawArgs) {
|
|
73
|
+
if (rawArgs.length === 0) {
|
|
74
|
+
return {
|
|
75
|
+
args: [],
|
|
76
|
+
transferables: [],
|
|
77
|
+
};
|
|
78
|
+
}
|
|
79
|
+
const args = [];
|
|
80
|
+
const transferables = [];
|
|
81
|
+
for (const arg of rawArgs) {
|
|
82
|
+
if ((0, transferable_1.isTransferDescriptor)(arg)) {
|
|
83
|
+
args.push((0, common_1.serialize)(arg.send));
|
|
84
|
+
transferables.push(...arg.transferables);
|
|
85
|
+
}
|
|
86
|
+
else {
|
|
87
|
+
args.push((0, common_1.serialize)(arg));
|
|
88
|
+
}
|
|
89
|
+
}
|
|
90
|
+
return {
|
|
91
|
+
args,
|
|
92
|
+
transferables: transferables.length === 0 ? transferables : dedupe(transferables),
|
|
93
|
+
};
|
|
94
|
+
}
|
|
95
|
+
function createProxyFunction(worker, method) {
|
|
96
|
+
return ((...rawArgs) => {
|
|
97
|
+
const uid = nextJobUID++;
|
|
98
|
+
const { args, transferables } = prepareArguments(rawArgs);
|
|
99
|
+
const runMessage = {
|
|
100
|
+
args,
|
|
101
|
+
method,
|
|
102
|
+
type: messages_1.MasterMessageType.run,
|
|
103
|
+
uid,
|
|
104
|
+
};
|
|
105
|
+
debugMessages('Sending command to run function to worker:', runMessage);
|
|
106
|
+
try {
|
|
107
|
+
worker.postMessage(runMessage, transferables);
|
|
108
|
+
}
|
|
109
|
+
catch (error) {
|
|
110
|
+
return observable_promise_1.ObservablePromise.from(Promise.reject(error));
|
|
111
|
+
}
|
|
112
|
+
return observable_promise_1.ObservablePromise.from((0, observable_fns_1.multicast)(createObservableForJob(worker, uid)));
|
|
113
|
+
});
|
|
114
|
+
}
|
|
115
|
+
function createProxyModule(worker, methodNames) {
|
|
116
|
+
const proxy = {};
|
|
117
|
+
for (const methodName of methodNames) {
|
|
118
|
+
proxy[methodName] = createProxyFunction(worker, methodName);
|
|
119
|
+
}
|
|
120
|
+
return proxy;
|
|
121
|
+
}
|
|
@@ -0,0 +1,14 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
+
exports.PoolEventType = void 0;
|
|
4
|
+
var PoolEventType;
|
|
5
|
+
(function (PoolEventType) {
|
|
6
|
+
PoolEventType["initialized"] = "initialized";
|
|
7
|
+
PoolEventType["taskCanceled"] = "taskCanceled";
|
|
8
|
+
PoolEventType["taskCompleted"] = "taskCompleted";
|
|
9
|
+
PoolEventType["taskFailed"] = "taskFailed";
|
|
10
|
+
PoolEventType["taskQueued"] = "taskQueued";
|
|
11
|
+
PoolEventType["taskQueueDrained"] = "taskQueueDrained";
|
|
12
|
+
PoolEventType["taskStart"] = "taskStart";
|
|
13
|
+
PoolEventType["terminated"] = "terminated";
|
|
14
|
+
})(PoolEventType || (exports.PoolEventType = PoolEventType = {}));
|