@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,412 +0,0 @@
|
|
|
1
|
-
// src/master/spawn.ts
|
|
2
|
-
import DebugLogger2 from "debug";
|
|
3
|
-
import { Observable as Observable3 } from "observable-fns";
|
|
4
|
-
|
|
5
|
-
// src/serializers.ts
|
|
6
|
-
var DefaultErrorSerializer = {
|
|
7
|
-
deserialize(message) {
|
|
8
|
-
return Object.assign(new Error(message.message), {
|
|
9
|
-
name: message.name,
|
|
10
|
-
stack: message.stack
|
|
11
|
-
});
|
|
12
|
-
},
|
|
13
|
-
serialize(error) {
|
|
14
|
-
return {
|
|
15
|
-
__error_marker: "$$error",
|
|
16
|
-
message: error.message,
|
|
17
|
-
name: error.name,
|
|
18
|
-
stack: error.stack
|
|
19
|
-
};
|
|
20
|
-
}
|
|
21
|
-
};
|
|
22
|
-
var isSerializedError = (thing) => thing && typeof thing === "object" && "__error_marker" in thing && thing.__error_marker === "$$error";
|
|
23
|
-
var DefaultSerializer = {
|
|
24
|
-
deserialize(message) {
|
|
25
|
-
return isSerializedError(message) ? DefaultErrorSerializer.deserialize(message) : message;
|
|
26
|
-
},
|
|
27
|
-
serialize(input) {
|
|
28
|
-
return input instanceof Error ? DefaultErrorSerializer.serialize(input) : input;
|
|
29
|
-
}
|
|
30
|
-
};
|
|
31
|
-
|
|
32
|
-
// src/common.ts
|
|
33
|
-
globalThis.registeredSerializer = globalThis.registeredSerializer ?? DefaultSerializer;
|
|
34
|
-
function deserialize(message) {
|
|
35
|
-
return globalThis.registeredSerializer.deserialize(message);
|
|
36
|
-
}
|
|
37
|
-
function serialize(input) {
|
|
38
|
-
return globalThis.registeredSerializer.serialize(input);
|
|
39
|
-
}
|
|
40
|
-
|
|
41
|
-
// src/promise.ts
|
|
42
|
-
var doNothing = () => void 0;
|
|
43
|
-
function createPromiseWithResolver() {
|
|
44
|
-
let alreadyResolved = false;
|
|
45
|
-
let resolvedTo;
|
|
46
|
-
let resolver = doNothing;
|
|
47
|
-
const promise = new Promise((resolve) => {
|
|
48
|
-
if (alreadyResolved) {
|
|
49
|
-
resolve(resolvedTo);
|
|
50
|
-
} else {
|
|
51
|
-
resolver = resolve;
|
|
52
|
-
}
|
|
53
|
-
});
|
|
54
|
-
const exposedResolver = (value) => {
|
|
55
|
-
alreadyResolved = true;
|
|
56
|
-
resolvedTo = value;
|
|
57
|
-
resolver(resolvedTo);
|
|
58
|
-
};
|
|
59
|
-
return [promise, exposedResolver];
|
|
60
|
-
}
|
|
61
|
-
|
|
62
|
-
// src/symbols.ts
|
|
63
|
-
var $errors = Symbol("thread.errors");
|
|
64
|
-
var $events = Symbol("thread.events");
|
|
65
|
-
var $terminate = Symbol("thread.terminate");
|
|
66
|
-
var $transferable = Symbol("thread.transferable");
|
|
67
|
-
var $worker = Symbol("thread.worker");
|
|
68
|
-
|
|
69
|
-
// src/master/invocation-proxy.ts
|
|
70
|
-
import DebugLogger from "debug";
|
|
71
|
-
import { multicast, Observable as Observable2 } from "observable-fns";
|
|
72
|
-
|
|
73
|
-
// src/observable-promise.ts
|
|
74
|
-
import { Observable } from "observable-fns";
|
|
75
|
-
var doNothing2 = () => {
|
|
76
|
-
};
|
|
77
|
-
var returnInput = (input) => input;
|
|
78
|
-
var runDeferred = (fn) => Promise.resolve().then(fn);
|
|
79
|
-
function fail(error) {
|
|
80
|
-
throw error;
|
|
81
|
-
}
|
|
82
|
-
function isThenable(thing) {
|
|
83
|
-
return thing && typeof thing.then === "function";
|
|
84
|
-
}
|
|
85
|
-
var ObservablePromise = class _ObservablePromise extends Observable {
|
|
86
|
-
[Symbol.toStringTag] = "[object ObservablePromise]";
|
|
87
|
-
initHasRun = false;
|
|
88
|
-
fulfillmentCallbacks = [];
|
|
89
|
-
rejectionCallbacks = [];
|
|
90
|
-
firstValue;
|
|
91
|
-
firstValueSet = false;
|
|
92
|
-
rejection;
|
|
93
|
-
state = "pending";
|
|
94
|
-
constructor(init) {
|
|
95
|
-
super((originalObserver) => {
|
|
96
|
-
const self = this;
|
|
97
|
-
const observer = {
|
|
98
|
-
...originalObserver,
|
|
99
|
-
complete() {
|
|
100
|
-
originalObserver.complete();
|
|
101
|
-
self.onCompletion();
|
|
102
|
-
},
|
|
103
|
-
error(error) {
|
|
104
|
-
originalObserver.error(error);
|
|
105
|
-
self.onError(error);
|
|
106
|
-
},
|
|
107
|
-
next(value) {
|
|
108
|
-
originalObserver.next(value);
|
|
109
|
-
self.onNext(value);
|
|
110
|
-
}
|
|
111
|
-
};
|
|
112
|
-
try {
|
|
113
|
-
this.initHasRun = true;
|
|
114
|
-
return init(observer);
|
|
115
|
-
} catch (error) {
|
|
116
|
-
observer.error(error);
|
|
117
|
-
}
|
|
118
|
-
});
|
|
119
|
-
}
|
|
120
|
-
onNext(value) {
|
|
121
|
-
if (!this.firstValueSet) {
|
|
122
|
-
this.firstValue = value;
|
|
123
|
-
this.firstValueSet = true;
|
|
124
|
-
}
|
|
125
|
-
}
|
|
126
|
-
onError(error) {
|
|
127
|
-
this.state = "rejected";
|
|
128
|
-
this.rejection = error;
|
|
129
|
-
for (const onRejected of this.rejectionCallbacks) {
|
|
130
|
-
runDeferred(() => onRejected(error));
|
|
131
|
-
}
|
|
132
|
-
}
|
|
133
|
-
onCompletion() {
|
|
134
|
-
this.state = "fulfilled";
|
|
135
|
-
for (const onFulfilled of this.fulfillmentCallbacks) {
|
|
136
|
-
runDeferred(() => onFulfilled(this.firstValue));
|
|
137
|
-
}
|
|
138
|
-
}
|
|
139
|
-
then(onFulfilledRaw, onRejectedRaw) {
|
|
140
|
-
const onFulfilled = onFulfilledRaw || returnInput;
|
|
141
|
-
const onRejected = onRejectedRaw || fail;
|
|
142
|
-
let onRejectedCalled = false;
|
|
143
|
-
return new Promise((resolve, reject) => {
|
|
144
|
-
const rejectionCallback = (error) => {
|
|
145
|
-
if (onRejectedCalled) return;
|
|
146
|
-
onRejectedCalled = true;
|
|
147
|
-
try {
|
|
148
|
-
resolve(onRejected(error));
|
|
149
|
-
} catch (anotherError) {
|
|
150
|
-
reject(anotherError);
|
|
151
|
-
}
|
|
152
|
-
};
|
|
153
|
-
const fulfillmentCallback = (value) => {
|
|
154
|
-
try {
|
|
155
|
-
resolve(onFulfilled(value));
|
|
156
|
-
} catch (ex) {
|
|
157
|
-
const error = ex;
|
|
158
|
-
rejectionCallback(error);
|
|
159
|
-
}
|
|
160
|
-
};
|
|
161
|
-
if (!this.initHasRun) {
|
|
162
|
-
this.subscribe({ error: rejectionCallback });
|
|
163
|
-
}
|
|
164
|
-
if (this.state === "fulfilled") {
|
|
165
|
-
return resolve(onFulfilled(this.firstValue));
|
|
166
|
-
}
|
|
167
|
-
if (this.state === "rejected") {
|
|
168
|
-
onRejectedCalled = true;
|
|
169
|
-
return resolve(onRejected(this.rejection));
|
|
170
|
-
}
|
|
171
|
-
this.fulfillmentCallbacks.push(fulfillmentCallback);
|
|
172
|
-
this.rejectionCallbacks.push(rejectionCallback);
|
|
173
|
-
});
|
|
174
|
-
}
|
|
175
|
-
catch(onRejected) {
|
|
176
|
-
return this.then(void 0, onRejected);
|
|
177
|
-
}
|
|
178
|
-
finally(onCompleted) {
|
|
179
|
-
const handler = onCompleted || doNothing2;
|
|
180
|
-
return this.then(
|
|
181
|
-
(value) => {
|
|
182
|
-
handler();
|
|
183
|
-
return value;
|
|
184
|
-
},
|
|
185
|
-
() => handler()
|
|
186
|
-
);
|
|
187
|
-
}
|
|
188
|
-
static from(thing) {
|
|
189
|
-
return isThenable(thing) ? new _ObservablePromise((observer) => {
|
|
190
|
-
const onFulfilled = (value) => {
|
|
191
|
-
observer.next(value);
|
|
192
|
-
observer.complete();
|
|
193
|
-
};
|
|
194
|
-
const onRejected = (error) => {
|
|
195
|
-
observer.error(error);
|
|
196
|
-
};
|
|
197
|
-
thing.then(onFulfilled, onRejected);
|
|
198
|
-
}) : super.from(thing);
|
|
199
|
-
}
|
|
200
|
-
};
|
|
201
|
-
|
|
202
|
-
// src/transferable.ts
|
|
203
|
-
function isTransferDescriptor(thing) {
|
|
204
|
-
return thing && typeof thing === "object" && thing[$transferable];
|
|
205
|
-
}
|
|
206
|
-
|
|
207
|
-
// src/master/invocation-proxy.ts
|
|
208
|
-
var debugMessages = DebugLogger("threads:master:messages");
|
|
209
|
-
var nextJobUID = 1;
|
|
210
|
-
var dedupe = (array) => [...new Set(array)];
|
|
211
|
-
var isJobErrorMessage = (data) => data && data.type === "error" /* error */;
|
|
212
|
-
var isJobResultMessage = (data) => data && data.type === "result" /* result */;
|
|
213
|
-
var isJobStartMessage = (data) => data && data.type === "running" /* running */;
|
|
214
|
-
function createObservableForJob(worker, jobUID) {
|
|
215
|
-
return new Observable2((observer) => {
|
|
216
|
-
let asyncType;
|
|
217
|
-
const messageHandler = (event) => {
|
|
218
|
-
debugMessages("Message from worker:", event.data);
|
|
219
|
-
if (!event.data || event.data.uid !== jobUID) return;
|
|
220
|
-
if (isJobStartMessage(event.data)) {
|
|
221
|
-
asyncType = event.data.resultType;
|
|
222
|
-
} else if (isJobResultMessage(event.data)) {
|
|
223
|
-
if (asyncType === "promise") {
|
|
224
|
-
if (event.data.payload !== void 0) {
|
|
225
|
-
observer.next(deserialize(event.data.payload));
|
|
226
|
-
}
|
|
227
|
-
observer.complete();
|
|
228
|
-
worker.removeEventListener("message", messageHandler);
|
|
229
|
-
} else {
|
|
230
|
-
if (event.data.payload) {
|
|
231
|
-
observer.next(deserialize(event.data.payload));
|
|
232
|
-
}
|
|
233
|
-
if (event.data.complete) {
|
|
234
|
-
observer.complete();
|
|
235
|
-
worker.removeEventListener("message", messageHandler);
|
|
236
|
-
}
|
|
237
|
-
}
|
|
238
|
-
} else if (isJobErrorMessage(event.data)) {
|
|
239
|
-
const error = deserialize(event.data.error);
|
|
240
|
-
if (asyncType === "promise" || !asyncType) {
|
|
241
|
-
observer.error(error);
|
|
242
|
-
} else {
|
|
243
|
-
observer.error(error);
|
|
244
|
-
}
|
|
245
|
-
worker.removeEventListener("message", messageHandler);
|
|
246
|
-
}
|
|
247
|
-
};
|
|
248
|
-
worker.addEventListener("message", messageHandler);
|
|
249
|
-
return () => {
|
|
250
|
-
if (asyncType === "observable" || !asyncType) {
|
|
251
|
-
const cancelMessage = {
|
|
252
|
-
type: "cancel" /* cancel */,
|
|
253
|
-
uid: jobUID
|
|
254
|
-
};
|
|
255
|
-
worker.postMessage(cancelMessage);
|
|
256
|
-
}
|
|
257
|
-
worker.removeEventListener("message", messageHandler);
|
|
258
|
-
};
|
|
259
|
-
});
|
|
260
|
-
}
|
|
261
|
-
function prepareArguments(rawArgs) {
|
|
262
|
-
if (rawArgs.length === 0) {
|
|
263
|
-
return {
|
|
264
|
-
args: [],
|
|
265
|
-
transferables: []
|
|
266
|
-
};
|
|
267
|
-
}
|
|
268
|
-
const args = [];
|
|
269
|
-
const transferables = [];
|
|
270
|
-
for (const arg of rawArgs) {
|
|
271
|
-
if (isTransferDescriptor(arg)) {
|
|
272
|
-
args.push(serialize(arg.send));
|
|
273
|
-
transferables.push(...arg.transferables);
|
|
274
|
-
} else {
|
|
275
|
-
args.push(serialize(arg));
|
|
276
|
-
}
|
|
277
|
-
}
|
|
278
|
-
return {
|
|
279
|
-
args,
|
|
280
|
-
transferables: transferables.length === 0 ? transferables : dedupe(transferables)
|
|
281
|
-
};
|
|
282
|
-
}
|
|
283
|
-
function createProxyFunction(worker, method) {
|
|
284
|
-
return (...rawArgs) => {
|
|
285
|
-
const uid = nextJobUID++;
|
|
286
|
-
const { args, transferables } = prepareArguments(rawArgs);
|
|
287
|
-
const runMessage = {
|
|
288
|
-
args,
|
|
289
|
-
method,
|
|
290
|
-
type: "run" /* run */,
|
|
291
|
-
uid
|
|
292
|
-
};
|
|
293
|
-
debugMessages("Sending command to run function to worker:", runMessage);
|
|
294
|
-
try {
|
|
295
|
-
worker.postMessage(runMessage, transferables);
|
|
296
|
-
} catch (error) {
|
|
297
|
-
return ObservablePromise.from(Promise.reject(error));
|
|
298
|
-
}
|
|
299
|
-
return ObservablePromise.from(multicast(createObservableForJob(worker, uid)));
|
|
300
|
-
};
|
|
301
|
-
}
|
|
302
|
-
function createProxyModule(worker, methodNames) {
|
|
303
|
-
const proxy = {};
|
|
304
|
-
for (const methodName of methodNames) {
|
|
305
|
-
proxy[methodName] = createProxyFunction(worker, methodName);
|
|
306
|
-
}
|
|
307
|
-
return proxy;
|
|
308
|
-
}
|
|
309
|
-
|
|
310
|
-
// src/master/spawn.ts
|
|
311
|
-
var debugMessages2 = DebugLogger2("threads:master:messages");
|
|
312
|
-
var debugSpawn = DebugLogger2("threads:master:spawn");
|
|
313
|
-
var debugThreadUtils = DebugLogger2("threads:master:thread-utils");
|
|
314
|
-
var isInitMessage = (data) => data && data.type === "init";
|
|
315
|
-
var isUncaughtErrorMessage = (data) => data && data.type === "uncaughtError";
|
|
316
|
-
var initMessageTimeout = typeof process !== "undefined" && process.env !== void 0 && process.env.THREADS_WORKER_INIT_TIMEOUT ? Number.parseInt(process.env.THREADS_WORKER_INIT_TIMEOUT, 10) : 1e4;
|
|
317
|
-
async function withTimeout(promise, timeoutInMs, errorMessage) {
|
|
318
|
-
let timeoutHandle;
|
|
319
|
-
const timeout = new Promise((resolve, reject) => {
|
|
320
|
-
timeoutHandle = setTimeout(() => reject(new Error(errorMessage)), timeoutInMs);
|
|
321
|
-
});
|
|
322
|
-
const result = await Promise.race([promise, timeout]);
|
|
323
|
-
clearTimeout(timeoutHandle);
|
|
324
|
-
return result;
|
|
325
|
-
}
|
|
326
|
-
function receiveInitMessage(worker) {
|
|
327
|
-
return new Promise((resolve, reject) => {
|
|
328
|
-
const messageHandler = (event) => {
|
|
329
|
-
debugMessages2("Message from worker before finishing initialization:", event.data);
|
|
330
|
-
if (isInitMessage(event.data)) {
|
|
331
|
-
worker.removeEventListener("message", messageHandler);
|
|
332
|
-
resolve(event.data);
|
|
333
|
-
} else if (isUncaughtErrorMessage(event.data)) {
|
|
334
|
-
worker.removeEventListener("message", messageHandler);
|
|
335
|
-
reject(deserialize(event.data.error));
|
|
336
|
-
}
|
|
337
|
-
};
|
|
338
|
-
worker.addEventListener("message", messageHandler);
|
|
339
|
-
});
|
|
340
|
-
}
|
|
341
|
-
function createEventObservable(worker, workerTermination) {
|
|
342
|
-
return new Observable3((observer) => {
|
|
343
|
-
const messageHandler = (messageEvent) => {
|
|
344
|
-
const workerEvent = {
|
|
345
|
-
data: messageEvent.data,
|
|
346
|
-
type: "message" /* message */
|
|
347
|
-
};
|
|
348
|
-
observer.next(workerEvent);
|
|
349
|
-
};
|
|
350
|
-
const rejectionHandler = (errorEvent) => {
|
|
351
|
-
debugThreadUtils("Unhandled promise rejection event in thread:", errorEvent);
|
|
352
|
-
const workerEvent = {
|
|
353
|
-
error: new Error(errorEvent.reason),
|
|
354
|
-
type: "internalError" /* internalError */
|
|
355
|
-
};
|
|
356
|
-
observer.next(workerEvent);
|
|
357
|
-
};
|
|
358
|
-
worker.addEventListener("message", messageHandler);
|
|
359
|
-
worker.addEventListener("unhandledrejection", rejectionHandler);
|
|
360
|
-
workerTermination.then(() => {
|
|
361
|
-
const terminationEvent = { type: "termination" /* termination */ };
|
|
362
|
-
worker.removeEventListener("message", messageHandler);
|
|
363
|
-
worker.removeEventListener("unhandledrejection", rejectionHandler);
|
|
364
|
-
observer.next(terminationEvent);
|
|
365
|
-
observer.complete();
|
|
366
|
-
});
|
|
367
|
-
});
|
|
368
|
-
}
|
|
369
|
-
function createTerminator(worker) {
|
|
370
|
-
const [termination, resolver] = createPromiseWithResolver();
|
|
371
|
-
const terminate = async () => {
|
|
372
|
-
debugThreadUtils("Terminating worker");
|
|
373
|
-
await worker.terminate();
|
|
374
|
-
resolver();
|
|
375
|
-
};
|
|
376
|
-
return { terminate, termination };
|
|
377
|
-
}
|
|
378
|
-
function setPrivateThreadProps(raw, worker, workerEvents, terminate) {
|
|
379
|
-
const workerErrors = workerEvents.filter((event) => event.type === "internalError" /* internalError */).map((errorEvent) => errorEvent.error);
|
|
380
|
-
return Object.assign(raw, {
|
|
381
|
-
[$errors]: workerErrors,
|
|
382
|
-
[$events]: workerEvents,
|
|
383
|
-
[$terminate]: terminate,
|
|
384
|
-
[$worker]: worker
|
|
385
|
-
});
|
|
386
|
-
}
|
|
387
|
-
async function spawn(worker, options) {
|
|
388
|
-
debugSpawn("Initializing new thread");
|
|
389
|
-
const timeout = options && options.timeout ? options.timeout : initMessageTimeout;
|
|
390
|
-
const initMessage = await withTimeout(
|
|
391
|
-
receiveInitMessage(worker),
|
|
392
|
-
timeout,
|
|
393
|
-
`Timeout: Did not receive an init message from worker after ${timeout}ms. Make sure the worker calls expose().`
|
|
394
|
-
);
|
|
395
|
-
const exposed = initMessage.exposed;
|
|
396
|
-
const { termination, terminate } = createTerminator(worker);
|
|
397
|
-
const events = createEventObservable(worker, termination);
|
|
398
|
-
if (exposed.type === "function") {
|
|
399
|
-
const proxy = createProxyFunction(worker);
|
|
400
|
-
return setPrivateThreadProps(proxy, worker, events, terminate);
|
|
401
|
-
} else if (exposed.type === "module") {
|
|
402
|
-
const proxy = createProxyModule(worker, exposed.methods);
|
|
403
|
-
return setPrivateThreadProps(proxy, worker, events, terminate);
|
|
404
|
-
} else {
|
|
405
|
-
const type = exposed.type;
|
|
406
|
-
throw new Error(`Worker init message states unexpected type of expose(): ${type}`);
|
|
407
|
-
}
|
|
408
|
-
}
|
|
409
|
-
export {
|
|
410
|
-
spawn
|
|
411
|
-
};
|
|
412
|
-
//# sourceMappingURL=spawn.mjs.map
|
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"sources":["../../../src/master/spawn.ts","../../../src/serializers.ts","../../../src/common.ts","../../../src/promise.ts","../../../src/symbols.ts","../../../src/master/invocation-proxy.ts","../../../src/observable-promise.ts","../../../src/transferable.ts"],"sourcesContent":["/* eslint-disable import-x/no-internal-modules */\n/* eslint-disable @typescript-eslint/no-explicit-any */\n/* eslint-disable @typescript-eslint/no-floating-promises */\nimport DebugLogger from 'debug'\nimport { Observable } from 'observable-fns'\n\nimport { deserialize } from '../common.ts'\nimport { createPromiseWithResolver } from '../promise.ts'\nimport {\n $errors, $events, $terminate, $worker,\n} from '../symbols.ts'\nimport type {\n FunctionThread,\n ModuleThread,\n PrivateThreadProps,\n StripAsync,\n Worker as WorkerType,\n WorkerEvent,\n WorkerInternalErrorEvent,\n WorkerMessageEvent,\n WorkerTerminationEvent,\n} from '../types/master.ts'\nimport { WorkerEventType } from '../types/master.ts'\nimport type { WorkerInitMessage, WorkerUncaughtErrorMessage } from '../types/messages.ts'\nimport type { WorkerFunction, WorkerModule } from '../types/worker.ts'\nimport { createProxyFunction, createProxyModule } from './invocation-proxy.ts'\n\ntype ArbitraryWorkerInterface = WorkerFunction & WorkerModule<string> & { somekeythatisneverusedinproductioncode123: 'magicmarker123' }\ntype ArbitraryThreadType = FunctionThread<any, any> & ModuleThread<any>\n\nexport type ExposedToThreadType<Exposed extends WorkerFunction | WorkerModule<any>> =\n Exposed extends ArbitraryWorkerInterface ? ArbitraryThreadType\n : Exposed extends WorkerFunction ? FunctionThread<Parameters<Exposed>, StripAsync<ReturnType<Exposed>>>\n : Exposed extends WorkerModule<any> ? ModuleThread<Exposed>\n : never\n\nconst debugMessages = DebugLogger('threads:master:messages')\nconst debugSpawn = DebugLogger('threads:master:spawn')\nconst debugThreadUtils = DebugLogger('threads:master:thread-utils')\n\nconst isInitMessage = (data: any): data is WorkerInitMessage => data && data.type === ('init' as const)\nconst isUncaughtErrorMessage = (data: any): data is WorkerUncaughtErrorMessage => data && data.type === ('uncaughtError' as const)\n\nconst initMessageTimeout\n = typeof process !== 'undefined' && process.env !== undefined && process.env.THREADS_WORKER_INIT_TIMEOUT\n ? Number.parseInt(process.env.THREADS_WORKER_INIT_TIMEOUT, 10)\n : 10_000\n\nasync function withTimeout<T>(promise: Promise<T>, timeoutInMs: number, errorMessage: string): Promise<T> {\n let timeoutHandle: any\n\n const timeout = new Promise<never>((resolve, reject) => {\n timeoutHandle = setTimeout(() => reject(new Error(errorMessage)), timeoutInMs)\n })\n const result = await Promise.race([promise, timeout])\n\n clearTimeout(timeoutHandle)\n return result\n}\n\nfunction receiveInitMessage(worker: WorkerType): Promise<WorkerInitMessage> {\n return new Promise((resolve, reject) => {\n const messageHandler = ((event: MessageEvent) => {\n debugMessages('Message from worker before finishing initialization:', event.data)\n if (isInitMessage(event.data)) {\n worker.removeEventListener('message', messageHandler)\n resolve(event.data)\n } else if (isUncaughtErrorMessage(event.data)) {\n worker.removeEventListener('message', messageHandler)\n reject(deserialize(event.data.error))\n }\n }) as EventListener\n worker.addEventListener('message', messageHandler)\n })\n}\n\nfunction createEventObservable(worker: WorkerType, workerTermination: Promise<any>): Observable<WorkerEvent> {\n return new Observable<WorkerEvent>((observer) => {\n const messageHandler = ((messageEvent: MessageEvent) => {\n const workerEvent: WorkerMessageEvent<any> = {\n data: messageEvent.data,\n type: WorkerEventType.message,\n }\n observer.next(workerEvent)\n }) as EventListener\n const rejectionHandler = ((errorEvent: PromiseRejectionEvent) => {\n debugThreadUtils('Unhandled promise rejection event in thread:', errorEvent)\n const workerEvent: WorkerInternalErrorEvent = {\n error: new Error(errorEvent.reason),\n type: WorkerEventType.internalError,\n }\n observer.next(workerEvent)\n }) as EventListener\n worker.addEventListener('message', messageHandler)\n worker.addEventListener('unhandledrejection', rejectionHandler)\n\n workerTermination.then(() => {\n const terminationEvent: WorkerTerminationEvent = { type: WorkerEventType.termination }\n worker.removeEventListener('message', messageHandler)\n worker.removeEventListener('unhandledrejection', rejectionHandler)\n observer.next(terminationEvent)\n observer.complete()\n })\n })\n}\n\nfunction createTerminator(worker: WorkerType): { terminate: () => Promise<void>; termination: Promise<void> } {\n const [termination, resolver] = createPromiseWithResolver<void>()\n const terminate = async () => {\n debugThreadUtils('Terminating worker')\n // Newer versions of worker_threads workers return a promise\n await worker.terminate()\n resolver()\n }\n return { terminate, termination }\n}\n\nfunction setPrivateThreadProps<T>(\n raw: T,\n worker: WorkerType,\n workerEvents: Observable<WorkerEvent>,\n terminate: () => Promise<void>,\n): T & PrivateThreadProps {\n const workerErrors = workerEvents\n .filter(event => event.type === WorkerEventType.internalError)\n .map(errorEvent => (errorEvent as WorkerInternalErrorEvent).error)\n\n return Object.assign(raw as any, {\n [$errors]: workerErrors,\n [$events]: workerEvents,\n [$terminate]: terminate,\n [$worker]: worker,\n })\n}\n\n/**\n * Spawn a new thread. Takes a fresh worker instance, wraps it in a thin\n * abstraction layer to provide the transparent API and verifies that\n * the worker has initialized successfully.\n *\n * @param worker Instance of `Worker`. Either a web worker, `worker_threads` worker or `tiny-worker` worker.\n * @param [options]\n * @param [options.timeout] Init message timeout. Default: 10000 or set by environment variable.\n */\nexport async function spawn<Exposed extends WorkerFunction | WorkerModule<any> = ArbitraryWorkerInterface>(\n worker: WorkerType,\n options?: { timeout?: number },\n): Promise<ExposedToThreadType<Exposed>> {\n debugSpawn('Initializing new thread')\n\n const timeout = options && options.timeout ? options.timeout : initMessageTimeout\n const initMessage = await withTimeout(\n receiveInitMessage(worker),\n timeout,\n `Timeout: Did not receive an init message from worker after ${timeout}ms. Make sure the worker calls expose().`,\n )\n const exposed = initMessage.exposed\n\n const { termination, terminate } = createTerminator(worker)\n const events = createEventObservable(worker, termination)\n\n if (exposed.type === 'function') {\n const proxy = createProxyFunction(worker)\n return setPrivateThreadProps(proxy, worker, events, terminate) as ExposedToThreadType<Exposed>\n } else if (exposed.type === 'module') {\n const proxy = createProxyModule(worker, exposed.methods)\n return setPrivateThreadProps(proxy, worker, events, terminate) as ExposedToThreadType<Exposed>\n } else {\n const type = (exposed as WorkerInitMessage['exposed']).type\n throw new Error(`Worker init message states unexpected type of expose(): ${type}`)\n }\n}\n","/* eslint-disable import-x/no-internal-modules */\n/* eslint-disable @typescript-eslint/no-explicit-any */\nimport type { SerializedError } from './types/messages.ts'\n\nexport interface Serializer<Msg = JsonSerializable, Input = any> {\n deserialize(message: Msg): Input\n serialize(input: Input): Msg\n}\n\nexport interface SerializerImplementation<Msg = JsonSerializable, Input = any> {\n deserialize(message: Msg, defaultDeserialize: (msg: Msg) => Input): Input\n serialize(input: Input, defaultSerialize: (inp: Input) => Msg): Msg\n}\n\nexport function extendSerializer<MessageType, InputType = any>(\n extend: Serializer<MessageType, InputType>,\n implementation: SerializerImplementation<MessageType, InputType>,\n): Serializer<MessageType, InputType> {\n const fallbackDeserializer = extend.deserialize.bind(extend)\n const fallbackSerializer = extend.serialize.bind(extend)\n\n return {\n deserialize(message: MessageType): InputType {\n return implementation.deserialize(message, fallbackDeserializer)\n },\n\n serialize(input: InputType): MessageType {\n return implementation.serialize(input, fallbackSerializer)\n },\n }\n}\n\ntype JsonSerializablePrimitive = string | number | boolean | null\n\ntype JsonSerializableObject = {\n [key: string]: JsonSerializablePrimitive | JsonSerializablePrimitive[] | JsonSerializableObject | JsonSerializableObject[] | undefined\n}\n\nexport type JsonSerializable = JsonSerializablePrimitive | JsonSerializablePrimitive[] | JsonSerializableObject | JsonSerializableObject[]\n\nconst DefaultErrorSerializer: Serializer<SerializedError, Error> = {\n deserialize(message: SerializedError): Error {\n return Object.assign(new Error(message.message), {\n name: message.name,\n stack: message.stack,\n })\n },\n serialize(error: Error): SerializedError {\n return {\n __error_marker: '$$error',\n message: error.message,\n name: error.name,\n stack: error.stack,\n }\n },\n}\n\nconst isSerializedError = (thing: any): thing is SerializedError =>\n thing && typeof thing === 'object' && '__error_marker' in thing && thing.__error_marker === '$$error'\n\nexport const DefaultSerializer: Serializer<JsonSerializable> = {\n deserialize(message: JsonSerializable): any {\n return isSerializedError(message) ? DefaultErrorSerializer.deserialize(message) : message\n },\n serialize(input: any): JsonSerializable {\n return input instanceof Error ? (DefaultErrorSerializer.serialize(input) as any as JsonSerializable) : input\n },\n}\n","/* eslint-disable @typescript-eslint/no-explicit-any */\nimport type {\n JsonSerializable, Serializer, SerializerImplementation,\n} from './serializers.ts'\nimport { DefaultSerializer, extendSerializer } from './serializers.ts'\n\ndeclare global {\n var registeredSerializer: Serializer<JsonSerializable>\n}\n\nglobalThis.registeredSerializer = globalThis.registeredSerializer ?? DefaultSerializer\n\nexport function registerSerializer(serializer: SerializerImplementation<JsonSerializable>) {\n globalThis.registeredSerializer = extendSerializer(globalThis.registeredSerializer, serializer)\n}\n\nexport function deserialize(message: JsonSerializable): any {\n return globalThis.registeredSerializer.deserialize(message)\n}\n\nexport function serialize(input: any): JsonSerializable {\n return globalThis.registeredSerializer.serialize(input)\n}\n","// eslint-disable-next-line unicorn/no-useless-undefined\nconst doNothing = () => undefined\n\n/**\n * Creates a new promise and exposes its resolver function.\n * Use with care!\n */\nexport function createPromiseWithResolver<T>(): [Promise<T>, (result: T) => void] {\n let alreadyResolved = false\n let resolvedTo: T\n let resolver: (value: T | PromiseLike<T>) => void = doNothing\n\n const promise = new Promise<T>((resolve) => {\n if (alreadyResolved) {\n resolve(resolvedTo)\n } else {\n resolver = resolve\n }\n })\n const exposedResolver = (value: T) => {\n alreadyResolved = true\n resolvedTo = value\n resolver(resolvedTo)\n }\n return [promise, exposedResolver]\n}\n","export const $errors = Symbol('thread.errors')\nexport const $events = Symbol('thread.events')\nexport const $terminate = Symbol('thread.terminate')\nexport const $transferable = Symbol('thread.transferable')\nexport const $worker = Symbol('thread.worker')\n","/* eslint-disable import-x/no-internal-modules */\n/* eslint-disable @typescript-eslint/no-explicit-any */\n/*\n * This source file contains the code for proxying calls in the master thread to calls in the workers\n * by `.postMessage()`-ing.\n *\n * Keep in mind that this code can make or break the program's performance! Need to optimize more…\n */\n\nimport DebugLogger from 'debug'\nimport { multicast, Observable } from 'observable-fns'\n\nimport { deserialize, serialize } from '../common.ts'\nimport { ObservablePromise } from '../observable-promise.ts'\nimport { isTransferDescriptor } from '../transferable.ts'\nimport type {\n ModuleMethods, ModuleProxy, ProxyableFunction, Worker as WorkerType,\n} from '../types/master.ts'\nimport type {\n MasterJobCancelMessage,\n MasterJobRunMessage,\n WorkerJobErrorMessage,\n WorkerJobResultMessage,\n WorkerJobStartMessage,\n} from '../types/messages.ts'\nimport {\n MasterMessageType,\n WorkerMessageType,\n} from '../types/messages.ts'\n\nconst debugMessages = DebugLogger('threads:master:messages')\n\nlet nextJobUID = 1\n\nconst dedupe = <T>(array: T[]): T[] => [...new Set(array)]\n\nconst isJobErrorMessage = (data: any): data is WorkerJobErrorMessage => data && data.type === WorkerMessageType.error\nconst isJobResultMessage = (data: any): data is WorkerJobResultMessage => data && data.type === WorkerMessageType.result\nconst isJobStartMessage = (data: any): data is WorkerJobStartMessage => data && data.type === WorkerMessageType.running\n\nfunction createObservableForJob<ResultType>(worker: WorkerType, jobUID: number): Observable<ResultType> {\n return new Observable((observer) => {\n let asyncType: 'observable' | 'promise' | undefined\n\n const messageHandler = ((event: MessageEvent) => {\n debugMessages('Message from worker:', event.data)\n if (!event.data || event.data.uid !== jobUID) return\n\n if (isJobStartMessage(event.data)) {\n asyncType = event.data.resultType\n } else if (isJobResultMessage(event.data)) {\n if (asyncType === 'promise') {\n if (event.data.payload !== undefined) {\n observer.next(deserialize(event.data.payload))\n }\n observer.complete()\n worker.removeEventListener('message', messageHandler)\n } else {\n if (event.data.payload) {\n observer.next(deserialize(event.data.payload))\n }\n if (event.data.complete) {\n observer.complete()\n worker.removeEventListener('message', messageHandler)\n }\n }\n } else if (isJobErrorMessage(event.data)) {\n const error = deserialize(event.data.error as any)\n if (asyncType === 'promise' || !asyncType) {\n observer.error(error)\n } else {\n observer.error(error)\n }\n worker.removeEventListener('message', messageHandler)\n }\n }) as EventListener\n\n worker.addEventListener('message', messageHandler)\n\n return () => {\n if (asyncType === 'observable' || !asyncType) {\n const cancelMessage: MasterJobCancelMessage = {\n type: MasterMessageType.cancel,\n uid: jobUID,\n }\n worker.postMessage(cancelMessage)\n }\n worker.removeEventListener('message', messageHandler)\n }\n })\n}\n\nfunction prepareArguments(rawArgs: any[]): { args: any[]; transferables: Transferable[] } {\n if (rawArgs.length === 0) {\n // Exit early if possible\n return {\n args: [],\n transferables: [],\n }\n }\n\n const args: any[] = []\n const transferables: Transferable[] = []\n\n for (const arg of rawArgs) {\n if (isTransferDescriptor(arg)) {\n args.push(serialize(arg.send))\n transferables.push(...arg.transferables)\n } else {\n args.push(serialize(arg))\n }\n }\n\n return {\n args,\n transferables: transferables.length === 0 ? transferables : dedupe(transferables),\n }\n}\n\nexport function createProxyFunction<Args extends any[], ReturnType>(worker: WorkerType, method?: string) {\n return ((...rawArgs: Args) => {\n const uid = nextJobUID++\n const { args, transferables } = prepareArguments(rawArgs)\n const runMessage: MasterJobRunMessage = {\n args,\n method,\n type: MasterMessageType.run,\n uid,\n }\n\n debugMessages('Sending command to run function to worker:', runMessage)\n\n try {\n worker.postMessage(runMessage, transferables)\n } catch (error) {\n return ObservablePromise.from(Promise.reject(error))\n }\n\n return ObservablePromise.from(multicast(createObservableForJob<ReturnType>(worker, uid)))\n }) as any as ProxyableFunction<Args, ReturnType>\n}\n\nexport function createProxyModule<Methods extends ModuleMethods>(worker: WorkerType, methodNames: string[]): ModuleProxy<Methods> {\n const proxy: any = {}\n\n for (const methodName of methodNames) {\n proxy[methodName] = createProxyFunction(worker, methodName)\n }\n\n return proxy\n}\n","/* eslint-disable unicorn/no-thenable */\n/* eslint-disable @typescript-eslint/member-ordering */\n/* eslint-disable @typescript-eslint/no-floating-promises */\n\n/* eslint-disable @typescript-eslint/no-explicit-any */\n/* eslint-disable @typescript-eslint/no-this-alias */\n/* eslint-disable unicorn/no-this-assignment */\nimport type { ObservableLike, SubscriptionObserver } from 'observable-fns'\nimport { Observable } from 'observable-fns'\n\ntype OnFulfilled<T, Result = void> = (value: T) => Result\ntype OnRejected<Result = void> = (error: Error) => Result\n\ntype Initializer<T> = (observer: SubscriptionObserver<T>) => UnsubscribeFn | void\n\ntype Thenable<T> = { then: (onFulfilled?: (value: T) => any, onRejected?: (error: any) => any) => any }\n\ntype UnsubscribeFn = () => void\n\nconst doNothing = () => {}\nconst returnInput = <T>(input: T): T => input\nconst runDeferred = (fn: () => void) => Promise.resolve().then(fn)\n\nfunction fail(error: Error): never {\n throw error\n}\n\nfunction isThenable(thing: any): thing is Thenable<any> {\n return thing && typeof thing.then === 'function'\n}\n\n/**\n * Creates a hybrid, combining the APIs of an Observable and a Promise.\n *\n * It is used to proxy async process states when we are initially not sure\n * if that async process will yield values once (-> Promise) or multiple\n * times (-> Observable).\n *\n * Note that the observable promise inherits some of the observable's characteristics:\n * The `init` function will be called *once for every time anyone subscribes to it*.\n *\n * If this is undesired, derive a hot observable from it using `makeHot()` and\n * subscribe to that.\n */\nexport class ObservablePromise<T> extends Observable<T> implements Promise<T> {\n readonly [Symbol.toStringTag] = '[object ObservablePromise]'\n private initHasRun = false\n private fulfillmentCallbacks: Array<OnFulfilled<T>> = []\n private rejectionCallbacks: OnRejected[] = []\n\n private firstValue: T | undefined\n private firstValueSet = false\n private rejection: Error | undefined\n private state: 'fulfilled' | 'pending' | 'rejected' = 'pending'\n\n constructor(init: Initializer<T>) {\n super((originalObserver: SubscriptionObserver<T>) => {\n // tslint:disable-next-line no-this-assignment\n const self = this\n const observer: SubscriptionObserver<T> = {\n ...originalObserver,\n complete() {\n originalObserver.complete()\n self.onCompletion()\n },\n error(error: Error) {\n originalObserver.error(error)\n self.onError(error)\n },\n next(value: T) {\n originalObserver.next(value)\n self.onNext(value)\n },\n }\n\n try {\n this.initHasRun = true\n return init(observer)\n } catch (error) {\n observer.error(error)\n }\n })\n }\n\n private onNext(value: T) {\n if (!this.firstValueSet) {\n this.firstValue = value\n this.firstValueSet = true\n }\n }\n\n private onError(error: Error) {\n this.state = 'rejected'\n this.rejection = error\n\n for (const onRejected of this.rejectionCallbacks) {\n // Promisifying the call to turn errors into unhandled promise rejections\n // instead of them failing sync and cancelling the iteration\n runDeferred(() => onRejected(error))\n }\n }\n\n private onCompletion() {\n this.state = 'fulfilled'\n\n for (const onFulfilled of this.fulfillmentCallbacks) {\n // Promisifying the call to turn errors into unhandled promise rejections\n // instead of them failing sync and cancelling the iteration\n runDeferred(() => onFulfilled(this.firstValue as T))\n }\n }\n\n then<TResult1 = T, TResult2 = never>(\n onFulfilledRaw?: ((value: T) => TResult1 | PromiseLike<TResult1>) | undefined | null,\n onRejectedRaw?: ((reason: any) => TResult2 | PromiseLike<TResult2>) | undefined | null,\n ): Promise<TResult1 | TResult2> {\n const onFulfilled: OnFulfilled<T, TResult1> = onFulfilledRaw || (returnInput as any)\n const onRejected = onRejectedRaw || fail\n let onRejectedCalled = false\n\n return new Promise<TResult1 | TResult2>((resolve, reject) => {\n const rejectionCallback = (error: Error) => {\n if (onRejectedCalled) return\n onRejectedCalled = true\n\n try {\n resolve(onRejected(error))\n } catch (anotherError) {\n reject(anotherError)\n }\n }\n const fulfillmentCallback = (value: T) => {\n try {\n resolve(onFulfilled(value))\n } catch (ex) {\n const error = ex as Error\n rejectionCallback(error)\n }\n }\n if (!this.initHasRun) {\n this.subscribe({ error: rejectionCallback })\n }\n if (this.state === 'fulfilled') {\n return resolve(onFulfilled(this.firstValue as T))\n }\n if (this.state === 'rejected') {\n onRejectedCalled = true\n return resolve(onRejected(this.rejection as Error))\n }\n this.fulfillmentCallbacks.push(fulfillmentCallback)\n this.rejectionCallbacks.push(rejectionCallback)\n })\n }\n\n catch<Result = never>(onRejected: ((error: Error) => Promise<Result> | Result) | null | undefined) {\n return this.then(undefined, onRejected) as Promise<Result>\n }\n\n finally(onCompleted?: (() => void) | null | undefined) {\n const handler = onCompleted || doNothing\n return this.then(\n (value: T) => {\n handler()\n return value\n },\n () => handler(),\n ) as Promise<T>\n }\n\n static override from<T>(thing: Observable<T> | ObservableLike<T> | ArrayLike<T> | Thenable<T>): ObservablePromise<T> {\n return isThenable(thing)\n ? new ObservablePromise((observer) => {\n const onFulfilled = (value: T) => {\n observer.next(value)\n observer.complete()\n }\n const onRejected = (error: any) => {\n observer.error(error)\n }\n thing.then(onFulfilled, onRejected)\n })\n : (super.from(thing) as ObservablePromise<T>)\n }\n}\n","/* eslint-disable @typescript-eslint/no-explicit-any */\nimport { $transferable } from './symbols.ts'\n\nexport interface TransferDescriptor<T = any> {\n [$transferable]: true\n send: T\n transferables: Transferable[]\n}\n\nfunction isTransferable(thing: any): thing is Transferable {\n if (!thing || typeof thing !== 'object') return false\n // Don't check too thoroughly, since the list of transferable things in JS might grow over time\n return true\n}\n\nexport function isTransferDescriptor(thing: any): thing is TransferDescriptor {\n return thing && typeof thing === 'object' && thing[$transferable]\n}\n\n/**\n * Mark a transferable object as such, so it will no be serialized and\n * deserialized on messaging with the main thread, but to transfer\n * ownership of it to the receiving thread.\n *\n * Only works with array buffers, message ports and few more special\n * types of objects, but it's much faster than serializing and\n * deserializing them.\n *\n * Note:\n * The transferable object cannot be accessed by this thread again\n * unless the receiving thread transfers it back again!\n *\n * @param transferable Array buffer, message port or similar.\n * @see <https://developers.google.com/web/updates/2011/12/Transferable-Objects-Lightning-Fast>\n */\nexport function Transfer(transferable: Transferable): TransferDescriptor\n\n/**\n * Mark transferable objects within an arbitrary object or array as\n * being a transferable object. They will then not be serialized\n * and deserialized on messaging with the main thread, but ownership\n * of them will be tranferred to the receiving thread.\n *\n * Only array buffers, message ports and few more special types of\n * objects can be transferred, but it's much faster than serializing and\n * deserializing them.\n *\n * Note:\n * The transferable object cannot be accessed by this thread again\n * unless the receiving thread transfers it back again!\n *\n * @param transferable Array buffer, message port or similar.\n * @see <https://developers.google.com/web/updates/2011/12/Transferable-Objects-Lightning-Fast>\n */\nexport function Transfer<T>(payload: T, transferables: Transferable[]): TransferDescriptor\n\nexport function Transfer<T>(payload: T, transferables?: Transferable[]): TransferDescriptor {\n console.log('Transfer')\n if (!transferables) {\n if (!isTransferable(payload)) throw new Error('Not transferable')\n transferables = [payload]\n }\n\n return {\n [$transferable]: true,\n send: payload,\n transferables,\n }\n}\n"],"mappings":";AAGA,OAAOA,kBAAiB;AACxB,SAAS,cAAAC,mBAAkB;;;ACoC3B,IAAM,yBAA6D;AAAA,EACjE,YAAY,SAAiC;AAC3C,WAAO,OAAO,OAAO,IAAI,MAAM,QAAQ,OAAO,GAAG;AAAA,MAC/C,MAAM,QAAQ;AAAA,MACd,OAAO,QAAQ;AAAA,IACjB,CAAC;AAAA,EACH;AAAA,EACA,UAAU,OAA+B;AACvC,WAAO;AAAA,MACL,gBAAgB;AAAA,MAChB,SAAS,MAAM;AAAA,MACf,MAAM,MAAM;AAAA,MACZ,OAAO,MAAM;AAAA,IACf;AAAA,EACF;AACF;AAEA,IAAM,oBAAoB,CAAC,UACzB,SAAS,OAAO,UAAU,YAAY,oBAAoB,SAAS,MAAM,mBAAmB;AAEvF,IAAM,oBAAkD;AAAA,EAC7D,YAAY,SAAgC;AAC1C,WAAO,kBAAkB,OAAO,IAAI,uBAAuB,YAAY,OAAO,IAAI;AAAA,EACpF;AAAA,EACA,UAAU,OAA8B;AACtC,WAAO,iBAAiB,QAAS,uBAAuB,UAAU,KAAK,IAAgC;AAAA,EACzG;AACF;;;ACzDA,WAAW,uBAAuB,WAAW,wBAAwB;AAM9D,SAAS,YAAY,SAAgC;AAC1D,SAAO,WAAW,qBAAqB,YAAY,OAAO;AAC5D;AAEO,SAAS,UAAU,OAA8B;AACtD,SAAO,WAAW,qBAAqB,UAAU,KAAK;AACxD;;;ACrBA,IAAM,YAAY,MAAM;AAMjB,SAAS,4BAAkE;AAChF,MAAI,kBAAkB;AACtB,MAAI;AACJ,MAAI,WAAgD;AAEpD,QAAM,UAAU,IAAI,QAAW,CAAC,YAAY;AAC1C,QAAI,iBAAiB;AACnB,cAAQ,UAAU;AAAA,IACpB,OAAO;AACL,iBAAW;AAAA,IACb;AAAA,EACF,CAAC;AACD,QAAM,kBAAkB,CAAC,UAAa;AACpC,sBAAkB;AAClB,iBAAa;AACb,aAAS,UAAU;AAAA,EACrB;AACA,SAAO,CAAC,SAAS,eAAe;AAClC;;;ACzBO,IAAM,UAAU,OAAO,eAAe;AACtC,IAAM,UAAU,OAAO,eAAe;AACtC,IAAM,aAAa,OAAO,kBAAkB;AAC5C,IAAM,gBAAgB,OAAO,qBAAqB;AAClD,IAAM,UAAU,OAAO,eAAe;;;ACK7C,OAAO,iBAAiB;AACxB,SAAS,WAAW,cAAAC,mBAAkB;;;ACFtC,SAAS,kBAAkB;AAW3B,IAAMC,aAAY,MAAM;AAAC;AACzB,IAAM,cAAc,CAAI,UAAgB;AACxC,IAAM,cAAc,CAAC,OAAmB,QAAQ,QAAQ,EAAE,KAAK,EAAE;AAEjE,SAAS,KAAK,OAAqB;AACjC,QAAM;AACR;AAEA,SAAS,WAAW,OAAoC;AACtD,SAAO,SAAS,OAAO,MAAM,SAAS;AACxC;AAeO,IAAM,oBAAN,MAAM,2BAA6B,WAAoC;AAAA,EAC5E,CAAU,OAAO,WAAW,IAAI;AAAA,EACxB,aAAa;AAAA,EACb,uBAA8C,CAAC;AAAA,EAC/C,qBAAmC,CAAC;AAAA,EAEpC;AAAA,EACA,gBAAgB;AAAA,EAChB;AAAA,EACA,QAA8C;AAAA,EAEtD,YAAY,MAAsB;AAChC,UAAM,CAAC,qBAA8C;AAEnD,YAAM,OAAO;AACb,YAAM,WAAoC;AAAA,QACxC,GAAG;AAAA,QACH,WAAW;AACT,2BAAiB,SAAS;AAC1B,eAAK,aAAa;AAAA,QACpB;AAAA,QACA,MAAM,OAAc;AAClB,2BAAiB,MAAM,KAAK;AAC5B,eAAK,QAAQ,KAAK;AAAA,QACpB;AAAA,QACA,KAAK,OAAU;AACb,2BAAiB,KAAK,KAAK;AAC3B,eAAK,OAAO,KAAK;AAAA,QACnB;AAAA,MACF;AAEA,UAAI;AACF,aAAK,aAAa;AAClB,eAAO,KAAK,QAAQ;AAAA,MACtB,SAAS,OAAO;AACd,iBAAS,MAAM,KAAK;AAAA,MACtB;AAAA,IACF,CAAC;AAAA,EACH;AAAA,EAEQ,OAAO,OAAU;AACvB,QAAI,CAAC,KAAK,eAAe;AACvB,WAAK,aAAa;AAClB,WAAK,gBAAgB;AAAA,IACvB;AAAA,EACF;AAAA,EAEQ,QAAQ,OAAc;AAC5B,SAAK,QAAQ;AACb,SAAK,YAAY;AAEjB,eAAW,cAAc,KAAK,oBAAoB;AAGhD,kBAAY,MAAM,WAAW,KAAK,CAAC;AAAA,IACrC;AAAA,EACF;AAAA,EAEQ,eAAe;AACrB,SAAK,QAAQ;AAEb,eAAW,eAAe,KAAK,sBAAsB;AAGnD,kBAAY,MAAM,YAAY,KAAK,UAAe,CAAC;AAAA,IACrD;AAAA,EACF;AAAA,EAEA,KACE,gBACA,eAC8B;AAC9B,UAAM,cAAwC,kBAAmB;AACjE,UAAM,aAAa,iBAAiB;AACpC,QAAI,mBAAmB;AAEvB,WAAO,IAAI,QAA6B,CAAC,SAAS,WAAW;AAC3D,YAAM,oBAAoB,CAAC,UAAiB;AAC1C,YAAI,iBAAkB;AACtB,2BAAmB;AAEnB,YAAI;AACF,kBAAQ,WAAW,KAAK,CAAC;AAAA,QAC3B,SAAS,cAAc;AACrB,iBAAO,YAAY;AAAA,QACrB;AAAA,MACF;AACA,YAAM,sBAAsB,CAAC,UAAa;AACxC,YAAI;AACF,kBAAQ,YAAY,KAAK,CAAC;AAAA,QAC5B,SAAS,IAAI;AACX,gBAAM,QAAQ;AACd,4BAAkB,KAAK;AAAA,QACzB;AAAA,MACF;AACA,UAAI,CAAC,KAAK,YAAY;AACpB,aAAK,UAAU,EAAE,OAAO,kBAAkB,CAAC;AAAA,MAC7C;AACA,UAAI,KAAK,UAAU,aAAa;AAC9B,eAAO,QAAQ,YAAY,KAAK,UAAe,CAAC;AAAA,MAClD;AACA,UAAI,KAAK,UAAU,YAAY;AAC7B,2BAAmB;AACnB,eAAO,QAAQ,WAAW,KAAK,SAAkB,CAAC;AAAA,MACpD;AACA,WAAK,qBAAqB,KAAK,mBAAmB;AAClD,WAAK,mBAAmB,KAAK,iBAAiB;AAAA,IAChD,CAAC;AAAA,EACH;AAAA,EAEA,MAAsB,YAA6E;AACjG,WAAO,KAAK,KAAK,QAAW,UAAU;AAAA,EACxC;AAAA,EAEA,QAAQ,aAA+C;AACrD,UAAM,UAAU,eAAeA;AAC/B,WAAO,KAAK;AAAA,MACV,CAAC,UAAa;AACZ,gBAAQ;AACR,eAAO;AAAA,MACT;AAAA,MACA,MAAM,QAAQ;AAAA,IAChB;AAAA,EACF;AAAA,EAEA,OAAgB,KAAQ,OAA6F;AACnH,WAAO,WAAW,KAAK,IACnB,IAAI,mBAAkB,CAAC,aAAa;AACpC,YAAM,cAAc,CAAC,UAAa;AAChC,iBAAS,KAAK,KAAK;AACnB,iBAAS,SAAS;AAAA,MACpB;AACA,YAAM,aAAa,CAAC,UAAe;AACjC,iBAAS,MAAM,KAAK;AAAA,MACtB;AACA,YAAM,KAAK,aAAa,UAAU;AAAA,IACpC,CAAC,IACE,MAAM,KAAK,KAAK;AAAA,EACvB;AACF;;;ACxKO,SAAS,qBAAqB,OAAyC;AAC5E,SAAO,SAAS,OAAO,UAAU,YAAY,MAAM,aAAa;AAClE;;;AFaA,IAAM,gBAAgB,YAAY,yBAAyB;AAE3D,IAAI,aAAa;AAEjB,IAAM,SAAS,CAAI,UAAoB,CAAC,GAAG,IAAI,IAAI,KAAK,CAAC;AAEzD,IAAM,oBAAoB,CAAC,SAA6C,QAAQ,KAAK;AACrF,IAAM,qBAAqB,CAAC,SAA8C,QAAQ,KAAK;AACvF,IAAM,oBAAoB,CAAC,SAA6C,QAAQ,KAAK;AAErF,SAAS,uBAAmC,QAAoB,QAAwC;AACtG,SAAO,IAAIC,YAAW,CAAC,aAAa;AAClC,QAAI;AAEJ,UAAM,iBAAkB,CAAC,UAAwB;AAC/C,oBAAc,wBAAwB,MAAM,IAAI;AAChD,UAAI,CAAC,MAAM,QAAQ,MAAM,KAAK,QAAQ,OAAQ;AAE9C,UAAI,kBAAkB,MAAM,IAAI,GAAG;AACjC,oBAAY,MAAM,KAAK;AAAA,MACzB,WAAW,mBAAmB,MAAM,IAAI,GAAG;AACzC,YAAI,cAAc,WAAW;AAC3B,cAAI,MAAM,KAAK,YAAY,QAAW;AACpC,qBAAS,KAAK,YAAY,MAAM,KAAK,OAAO,CAAC;AAAA,UAC/C;AACA,mBAAS,SAAS;AAClB,iBAAO,oBAAoB,WAAW,cAAc;AAAA,QACtD,OAAO;AACL,cAAI,MAAM,KAAK,SAAS;AACtB,qBAAS,KAAK,YAAY,MAAM,KAAK,OAAO,CAAC;AAAA,UAC/C;AACA,cAAI,MAAM,KAAK,UAAU;AACvB,qBAAS,SAAS;AAClB,mBAAO,oBAAoB,WAAW,cAAc;AAAA,UACtD;AAAA,QACF;AAAA,MACF,WAAW,kBAAkB,MAAM,IAAI,GAAG;AACxC,cAAM,QAAQ,YAAY,MAAM,KAAK,KAAY;AACjD,YAAI,cAAc,aAAa,CAAC,WAAW;AACzC,mBAAS,MAAM,KAAK;AAAA,QACtB,OAAO;AACL,mBAAS,MAAM,KAAK;AAAA,QACtB;AACA,eAAO,oBAAoB,WAAW,cAAc;AAAA,MACtD;AAAA,IACF;AAEA,WAAO,iBAAiB,WAAW,cAAc;AAEjD,WAAO,MAAM;AACX,UAAI,cAAc,gBAAgB,CAAC,WAAW;AAC5C,cAAM,gBAAwC;AAAA,UAC5C;AAAA,UACA,KAAK;AAAA,QACP;AACA,eAAO,YAAY,aAAa;AAAA,MAClC;AACA,aAAO,oBAAoB,WAAW,cAAc;AAAA,IACtD;AAAA,EACF,CAAC;AACH;AAEA,SAAS,iBAAiB,SAAgE;AACxF,MAAI,QAAQ,WAAW,GAAG;AAExB,WAAO;AAAA,MACL,MAAM,CAAC;AAAA,MACP,eAAe,CAAC;AAAA,IAClB;AAAA,EACF;AAEA,QAAM,OAAc,CAAC;AACrB,QAAM,gBAAgC,CAAC;AAEvC,aAAW,OAAO,SAAS;AACzB,QAAI,qBAAqB,GAAG,GAAG;AAC7B,WAAK,KAAK,UAAU,IAAI,IAAI,CAAC;AAC7B,oBAAc,KAAK,GAAG,IAAI,aAAa;AAAA,IACzC,OAAO;AACL,WAAK,KAAK,UAAU,GAAG,CAAC;AAAA,IAC1B;AAAA,EACF;AAEA,SAAO;AAAA,IACL;AAAA,IACA,eAAe,cAAc,WAAW,IAAI,gBAAgB,OAAO,aAAa;AAAA,EAClF;AACF;AAEO,SAAS,oBAAoD,QAAoB,QAAiB;AACvG,SAAQ,IAAI,YAAkB;AAC5B,UAAM,MAAM;AACZ,UAAM,EAAE,MAAM,cAAc,IAAI,iBAAiB,OAAO;AACxD,UAAM,aAAkC;AAAA,MACtC;AAAA,MACA;AAAA,MACA;AAAA,MACA;AAAA,IACF;AAEA,kBAAc,8CAA8C,UAAU;AAEtE,QAAI;AACF,aAAO,YAAY,YAAY,aAAa;AAAA,IAC9C,SAAS,OAAO;AACd,aAAO,kBAAkB,KAAK,QAAQ,OAAO,KAAK,CAAC;AAAA,IACrD;AAEA,WAAO,kBAAkB,KAAK,UAAU,uBAAmC,QAAQ,GAAG,CAAC,CAAC;AAAA,EAC1F;AACF;AAEO,SAAS,kBAAiD,QAAoB,aAA6C;AAChI,QAAM,QAAa,CAAC;AAEpB,aAAW,cAAc,aAAa;AACpC,UAAM,UAAU,IAAI,oBAAoB,QAAQ,UAAU;AAAA,EAC5D;AAEA,SAAO;AACT;;;ALlHA,IAAMC,iBAAgBC,aAAY,yBAAyB;AAC3D,IAAM,aAAaA,aAAY,sBAAsB;AACrD,IAAM,mBAAmBA,aAAY,6BAA6B;AAElE,IAAM,gBAAgB,CAAC,SAAyC,QAAQ,KAAK,SAAU;AACvF,IAAM,yBAAyB,CAAC,SAAkD,QAAQ,KAAK,SAAU;AAEzG,IAAM,qBACF,OAAO,YAAY,eAAe,QAAQ,QAAQ,UAAa,QAAQ,IAAI,8BACzE,OAAO,SAAS,QAAQ,IAAI,6BAA6B,EAAE,IAC3D;AAEN,eAAe,YAAe,SAAqB,aAAqB,cAAkC;AACxG,MAAI;AAEJ,QAAM,UAAU,IAAI,QAAe,CAAC,SAAS,WAAW;AACtD,oBAAgB,WAAW,MAAM,OAAO,IAAI,MAAM,YAAY,CAAC,GAAG,WAAW;AAAA,EAC/E,CAAC;AACD,QAAM,SAAS,MAAM,QAAQ,KAAK,CAAC,SAAS,OAAO,CAAC;AAEpD,eAAa,aAAa;AAC1B,SAAO;AACT;AAEA,SAAS,mBAAmB,QAAgD;AAC1E,SAAO,IAAI,QAAQ,CAAC,SAAS,WAAW;AACtC,UAAM,iBAAkB,CAAC,UAAwB;AAC/C,MAAAD,eAAc,wDAAwD,MAAM,IAAI;AAChF,UAAI,cAAc,MAAM,IAAI,GAAG;AAC7B,eAAO,oBAAoB,WAAW,cAAc;AACpD,gBAAQ,MAAM,IAAI;AAAA,MACpB,WAAW,uBAAuB,MAAM,IAAI,GAAG;AAC7C,eAAO,oBAAoB,WAAW,cAAc;AACpD,eAAO,YAAY,MAAM,KAAK,KAAK,CAAC;AAAA,MACtC;AAAA,IACF;AACA,WAAO,iBAAiB,WAAW,cAAc;AAAA,EACnD,CAAC;AACH;AAEA,SAAS,sBAAsB,QAAoB,mBAA0D;AAC3G,SAAO,IAAIE,YAAwB,CAAC,aAAa;AAC/C,UAAM,iBAAkB,CAAC,iBAA+B;AACtD,YAAM,cAAuC;AAAA,QAC3C,MAAM,aAAa;AAAA,QACnB;AAAA,MACF;AACA,eAAS,KAAK,WAAW;AAAA,IAC3B;AACA,UAAM,mBAAoB,CAAC,eAAsC;AAC/D,uBAAiB,gDAAgD,UAAU;AAC3E,YAAM,cAAwC;AAAA,QAC5C,OAAO,IAAI,MAAM,WAAW,MAAM;AAAA,QAClC;AAAA,MACF;AACA,eAAS,KAAK,WAAW;AAAA,IAC3B;AACA,WAAO,iBAAiB,WAAW,cAAc;AACjD,WAAO,iBAAiB,sBAAsB,gBAAgB;AAE9D,sBAAkB,KAAK,MAAM;AAC3B,YAAM,mBAA2C,EAAE,sCAAkC;AACrF,aAAO,oBAAoB,WAAW,cAAc;AACpD,aAAO,oBAAoB,sBAAsB,gBAAgB;AACjE,eAAS,KAAK,gBAAgB;AAC9B,eAAS,SAAS;AAAA,IACpB,CAAC;AAAA,EACH,CAAC;AACH;AAEA,SAAS,iBAAiB,QAAoF;AAC5G,QAAM,CAAC,aAAa,QAAQ,IAAI,0BAAgC;AAChE,QAAM,YAAY,YAAY;AAC5B,qBAAiB,oBAAoB;AAErC,UAAM,OAAO,UAAU;AACvB,aAAS;AAAA,EACX;AACA,SAAO,EAAE,WAAW,YAAY;AAClC;AAEA,SAAS,sBACP,KACA,QACA,cACA,WACwB;AACxB,QAAM,eAAe,aAClB,OAAO,WAAS,MAAM,4CAAsC,EAC5D,IAAI,gBAAe,WAAwC,KAAK;AAEnE,SAAO,OAAO,OAAO,KAAY;AAAA,IAC/B,CAAC,OAAO,GAAG;AAAA,IACX,CAAC,OAAO,GAAG;AAAA,IACX,CAAC,UAAU,GAAG;AAAA,IACd,CAAC,OAAO,GAAG;AAAA,EACb,CAAC;AACH;AAWA,eAAsB,MACpB,QACA,SACuC;AACvC,aAAW,yBAAyB;AAEpC,QAAM,UAAU,WAAW,QAAQ,UAAU,QAAQ,UAAU;AAC/D,QAAM,cAAc,MAAM;AAAA,IACxB,mBAAmB,MAAM;AAAA,IACzB;AAAA,IACA,8DAA8D,OAAO;AAAA,EACvE;AACA,QAAM,UAAU,YAAY;AAE5B,QAAM,EAAE,aAAa,UAAU,IAAI,iBAAiB,MAAM;AAC1D,QAAM,SAAS,sBAAsB,QAAQ,WAAW;AAExD,MAAI,QAAQ,SAAS,YAAY;AAC/B,UAAM,QAAQ,oBAAoB,MAAM;AACxC,WAAO,sBAAsB,OAAO,QAAQ,QAAQ,SAAS;AAAA,EAC/D,WAAW,QAAQ,SAAS,UAAU;AACpC,UAAM,QAAQ,kBAAkB,QAAQ,QAAQ,OAAO;AACvD,WAAO,sBAAsB,OAAO,QAAQ,QAAQ,SAAS;AAAA,EAC/D,OAAO;AACL,UAAM,OAAQ,QAAyC;AACvD,UAAM,IAAI,MAAM,2DAA2D,IAAI,EAAE;AAAA,EACnF;AACF;","names":["DebugLogger","Observable","Observable","doNothing","Observable","debugMessages","DebugLogger","Observable"]}
|
|
@@ -1,29 +0,0 @@
|
|
|
1
|
-
// src/symbols.ts
|
|
2
|
-
var $errors = Symbol("thread.errors");
|
|
3
|
-
var $events = Symbol("thread.events");
|
|
4
|
-
var $terminate = Symbol("thread.terminate");
|
|
5
|
-
var $transferable = Symbol("thread.transferable");
|
|
6
|
-
var $worker = Symbol("thread.worker");
|
|
7
|
-
|
|
8
|
-
// src/master/thread.ts
|
|
9
|
-
function fail(message) {
|
|
10
|
-
throw new Error(message);
|
|
11
|
-
}
|
|
12
|
-
var Thread = {
|
|
13
|
-
/** Return an observable that can be used to subscribe to all errors happening in the thread. */
|
|
14
|
-
errors(thread) {
|
|
15
|
-
return thread[$errors] || fail("Error observable not found. Make sure to pass a thread instance as returned by the spawn() promise.");
|
|
16
|
-
},
|
|
17
|
-
/** Return an observable that can be used to subscribe to internal events happening in the thread. Useful for debugging. */
|
|
18
|
-
events(thread) {
|
|
19
|
-
return thread[$events] || fail("Events observable not found. Make sure to pass a thread instance as returned by the spawn() promise.");
|
|
20
|
-
},
|
|
21
|
-
/** Terminate a thread. Remember to terminate every thread when you are done using it. */
|
|
22
|
-
terminate(thread) {
|
|
23
|
-
return thread[$terminate]();
|
|
24
|
-
}
|
|
25
|
-
};
|
|
26
|
-
export {
|
|
27
|
-
Thread
|
|
28
|
-
};
|
|
29
|
-
//# sourceMappingURL=thread.mjs.map
|
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"sources":["../../../src/symbols.ts","../../../src/master/thread.ts"],"sourcesContent":["export const $errors = Symbol('thread.errors')\nexport const $events = Symbol('thread.events')\nexport const $terminate = Symbol('thread.terminate')\nexport const $transferable = Symbol('thread.transferable')\nexport const $worker = Symbol('thread.worker')\n","/* eslint-disable import-x/no-internal-modules */\nimport type { Observable } from 'observable-fns'\n\nimport {\n $errors, $events, $terminate,\n} from '../symbols.ts'\nimport type { Thread as ThreadType, WorkerEvent } from '../types/master.ts'\n\nfunction fail(message: string): never {\n throw new Error(message)\n}\n\nexport type Thread = ThreadType\n\n/** Thread utility functions. Use them to manage or inspect a `spawn()`-ed thread. */\nexport const Thread = {\n /** Return an observable that can be used to subscribe to all errors happening in the thread. */\n errors<ThreadT extends ThreadType>(thread: ThreadT): Observable<Error> {\n return thread[$errors] || fail('Error observable not found. Make sure to pass a thread instance as returned by the spawn() promise.')\n },\n /** Return an observable that can be used to subscribe to internal events happening in the thread. Useful for debugging. */\n events<ThreadT extends ThreadType>(thread: ThreadT): Observable<WorkerEvent> {\n return thread[$events] || fail('Events observable not found. Make sure to pass a thread instance as returned by the spawn() promise.')\n },\n /** Terminate a thread. Remember to terminate every thread when you are done using it. */\n terminate<ThreadT extends ThreadType>(thread: ThreadT) {\n return thread[$terminate]()\n },\n}\n"],"mappings":";AAAO,IAAM,UAAU,OAAO,eAAe;AACtC,IAAM,UAAU,OAAO,eAAe;AACtC,IAAM,aAAa,OAAO,kBAAkB;AAC5C,IAAM,gBAAgB,OAAO,qBAAqB;AAClD,IAAM,UAAU,OAAO,eAAe;;;ACI7C,SAAS,KAAK,SAAwB;AACpC,QAAM,IAAI,MAAM,OAAO;AACzB;AAKO,IAAM,SAAS;AAAA;AAAA,EAEpB,OAAmC,QAAoC;AACrE,WAAO,OAAO,OAAO,KAAK,KAAK,qGAAqG;AAAA,EACtI;AAAA;AAAA,EAEA,OAAmC,QAA0C;AAC3E,WAAO,OAAO,OAAO,KAAK,KAAK,sGAAsG;AAAA,EACvI;AAAA;AAAA,EAEA,UAAsC,QAAiB;AACrD,WAAO,OAAO,UAAU,EAAE;AAAA,EAC5B;AACF;","names":[]}
|
|
@@ -1,132 +0,0 @@
|
|
|
1
|
-
// src/observable-promise.ts
|
|
2
|
-
import { Observable } from "observable-fns";
|
|
3
|
-
var doNothing = () => {
|
|
4
|
-
};
|
|
5
|
-
var returnInput = (input) => input;
|
|
6
|
-
var runDeferred = (fn) => Promise.resolve().then(fn);
|
|
7
|
-
function fail(error) {
|
|
8
|
-
throw error;
|
|
9
|
-
}
|
|
10
|
-
function isThenable(thing) {
|
|
11
|
-
return thing && typeof thing.then === "function";
|
|
12
|
-
}
|
|
13
|
-
var ObservablePromise = class _ObservablePromise extends Observable {
|
|
14
|
-
[Symbol.toStringTag] = "[object ObservablePromise]";
|
|
15
|
-
initHasRun = false;
|
|
16
|
-
fulfillmentCallbacks = [];
|
|
17
|
-
rejectionCallbacks = [];
|
|
18
|
-
firstValue;
|
|
19
|
-
firstValueSet = false;
|
|
20
|
-
rejection;
|
|
21
|
-
state = "pending";
|
|
22
|
-
constructor(init) {
|
|
23
|
-
super((originalObserver) => {
|
|
24
|
-
const self = this;
|
|
25
|
-
const observer = {
|
|
26
|
-
...originalObserver,
|
|
27
|
-
complete() {
|
|
28
|
-
originalObserver.complete();
|
|
29
|
-
self.onCompletion();
|
|
30
|
-
},
|
|
31
|
-
error(error) {
|
|
32
|
-
originalObserver.error(error);
|
|
33
|
-
self.onError(error);
|
|
34
|
-
},
|
|
35
|
-
next(value) {
|
|
36
|
-
originalObserver.next(value);
|
|
37
|
-
self.onNext(value);
|
|
38
|
-
}
|
|
39
|
-
};
|
|
40
|
-
try {
|
|
41
|
-
this.initHasRun = true;
|
|
42
|
-
return init(observer);
|
|
43
|
-
} catch (error) {
|
|
44
|
-
observer.error(error);
|
|
45
|
-
}
|
|
46
|
-
});
|
|
47
|
-
}
|
|
48
|
-
onNext(value) {
|
|
49
|
-
if (!this.firstValueSet) {
|
|
50
|
-
this.firstValue = value;
|
|
51
|
-
this.firstValueSet = true;
|
|
52
|
-
}
|
|
53
|
-
}
|
|
54
|
-
onError(error) {
|
|
55
|
-
this.state = "rejected";
|
|
56
|
-
this.rejection = error;
|
|
57
|
-
for (const onRejected of this.rejectionCallbacks) {
|
|
58
|
-
runDeferred(() => onRejected(error));
|
|
59
|
-
}
|
|
60
|
-
}
|
|
61
|
-
onCompletion() {
|
|
62
|
-
this.state = "fulfilled";
|
|
63
|
-
for (const onFulfilled of this.fulfillmentCallbacks) {
|
|
64
|
-
runDeferred(() => onFulfilled(this.firstValue));
|
|
65
|
-
}
|
|
66
|
-
}
|
|
67
|
-
then(onFulfilledRaw, onRejectedRaw) {
|
|
68
|
-
const onFulfilled = onFulfilledRaw || returnInput;
|
|
69
|
-
const onRejected = onRejectedRaw || fail;
|
|
70
|
-
let onRejectedCalled = false;
|
|
71
|
-
return new Promise((resolve, reject) => {
|
|
72
|
-
const rejectionCallback = (error) => {
|
|
73
|
-
if (onRejectedCalled) return;
|
|
74
|
-
onRejectedCalled = true;
|
|
75
|
-
try {
|
|
76
|
-
resolve(onRejected(error));
|
|
77
|
-
} catch (anotherError) {
|
|
78
|
-
reject(anotherError);
|
|
79
|
-
}
|
|
80
|
-
};
|
|
81
|
-
const fulfillmentCallback = (value) => {
|
|
82
|
-
try {
|
|
83
|
-
resolve(onFulfilled(value));
|
|
84
|
-
} catch (ex) {
|
|
85
|
-
const error = ex;
|
|
86
|
-
rejectionCallback(error);
|
|
87
|
-
}
|
|
88
|
-
};
|
|
89
|
-
if (!this.initHasRun) {
|
|
90
|
-
this.subscribe({ error: rejectionCallback });
|
|
91
|
-
}
|
|
92
|
-
if (this.state === "fulfilled") {
|
|
93
|
-
return resolve(onFulfilled(this.firstValue));
|
|
94
|
-
}
|
|
95
|
-
if (this.state === "rejected") {
|
|
96
|
-
onRejectedCalled = true;
|
|
97
|
-
return resolve(onRejected(this.rejection));
|
|
98
|
-
}
|
|
99
|
-
this.fulfillmentCallbacks.push(fulfillmentCallback);
|
|
100
|
-
this.rejectionCallbacks.push(rejectionCallback);
|
|
101
|
-
});
|
|
102
|
-
}
|
|
103
|
-
catch(onRejected) {
|
|
104
|
-
return this.then(void 0, onRejected);
|
|
105
|
-
}
|
|
106
|
-
finally(onCompleted) {
|
|
107
|
-
const handler = onCompleted || doNothing;
|
|
108
|
-
return this.then(
|
|
109
|
-
(value) => {
|
|
110
|
-
handler();
|
|
111
|
-
return value;
|
|
112
|
-
},
|
|
113
|
-
() => handler()
|
|
114
|
-
);
|
|
115
|
-
}
|
|
116
|
-
static from(thing) {
|
|
117
|
-
return isThenable(thing) ? new _ObservablePromise((observer) => {
|
|
118
|
-
const onFulfilled = (value) => {
|
|
119
|
-
observer.next(value);
|
|
120
|
-
observer.complete();
|
|
121
|
-
};
|
|
122
|
-
const onRejected = (error) => {
|
|
123
|
-
observer.error(error);
|
|
124
|
-
};
|
|
125
|
-
thing.then(onFulfilled, onRejected);
|
|
126
|
-
}) : super.from(thing);
|
|
127
|
-
}
|
|
128
|
-
};
|
|
129
|
-
export {
|
|
130
|
-
ObservablePromise
|
|
131
|
-
};
|
|
132
|
-
//# sourceMappingURL=observable-promise.mjs.map
|