|
@@ -1,15 +1,18 @@
|
|
// Mediocre shim
|
|
// Mediocre shim
|
|
-import { Worker } from 'worker_threads';
|
|
|
|
-
|
|
|
|
|
|
+let Worker: typeof import('worker_threads').Worker;
|
|
const workerAdd = ";var __w=require('worker_threads');__w.parentPort.on('message',function(m){onmessage({data:m})}),postMessage=function(m,t){__w.parentPort.postMessage(m,t)},close=process.exit;self=global";
|
|
const workerAdd = ";var __w=require('worker_threads');__w.parentPort.on('message',function(m){onmessage({data:m})}),postMessage=function(m,t){__w.parentPort.postMessage(m,t)},close=process.exit;self=global";
|
|
|
|
|
|
-export default <T>(c: string, _: number, msg: unknown, transfer: ArrayBuffer[], cb: (err: Error, msg: T) => void) => {
|
|
|
|
|
|
+try {
|
|
|
|
+ Worker = require('worker_threads').Worker;
|
|
|
|
+} catch(e) {
|
|
|
|
+}
|
|
|
|
+export default Worker ? <T>(c: string, _: number, msg: unknown, transfer: ArrayBuffer[], cb: (err: Error, msg: T) => void) => {
|
|
let done = false;
|
|
let done = false;
|
|
const w = new Worker(c + workerAdd, { eval: true })
|
|
const w = new Worker(c + workerAdd, { eval: true })
|
|
.on('error', e => cb(e, null))
|
|
.on('error', e => cb(e, null))
|
|
.on('message', m => cb(null, m))
|
|
.on('message', m => cb(null, m))
|
|
.on('exit', c => {
|
|
.on('exit', c => {
|
|
- if (c && !done) cb(new Error('Exited with code ' + c), null);
|
|
|
|
|
|
+ if (c && !done) cb(new Error('exited with code ' + c), null);
|
|
});
|
|
});
|
|
w.postMessage(msg, transfer);
|
|
w.postMessage(msg, transfer);
|
|
w.terminate = () => {
|
|
w.terminate = () => {
|
|
@@ -17,4 +20,11 @@ export default <T>(c: string, _: number, msg: unknown, transfer: ArrayBuffer[],
|
|
return Worker.prototype.terminate.call(w);
|
|
return Worker.prototype.terminate.call(w);
|
|
}
|
|
}
|
|
return w;
|
|
return w;
|
|
|
|
+} : (_: string, __: number, ___: unknown, ____: ArrayBuffer[], cb: (err: Error, msg: null) => void) => {
|
|
|
|
+ setImmediate(() => cb(new Error('async operations unsupported - update to Node 12+ (or Node 10-11 with the --experimental-worker CLI flag)'), null));
|
|
|
|
+ const NOP = () => {};
|
|
|
|
+ return {
|
|
|
|
+ terminate: NOP,
|
|
|
|
+ postMessage: NOP
|
|
|
|
+ } as unknown as import('worker_threads').Worker;
|
|
}
|
|
}
|