@effect/platform-node 0.71.4 → 0.72.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/README.md +7 -1
- package/dist/cjs/NodeWorkerRunner.js +7 -0
- package/dist/cjs/NodeWorkerRunner.js.map +1 -1
- package/dist/cjs/internal/workerRunner.js +16 -10
- package/dist/cjs/internal/workerRunner.js.map +1 -1
- package/dist/dts/NodeWorkerRunner.d.ts +6 -0
- package/dist/dts/NodeWorkerRunner.d.ts.map +1 -1
- package/dist/esm/NodeWorkerRunner.js +6 -0
- package/dist/esm/NodeWorkerRunner.js.map +1 -1
- package/dist/esm/internal/workerRunner.js +16 -10
- package/dist/esm/internal/workerRunner.js.map +1 -1
- package/package.json +4 -4
- package/src/NodeWorkerRunner.ts +8 -0
- package/src/internal/workerRunner.ts +34 -28
package/README.md
CHANGED
|
@@ -1 +1,7 @@
|
|
|
1
|
-
`@effect/platform-node`
|
|
1
|
+
# `@effect/platform-node`
|
|
2
|
+
|
|
3
|
+
Provides Node.js-specific implementations for the abstractions defined in [`@effect/platform`](https://github.com/Effect-TS/effect/tree/main/packages/platform), allowing you to write platform-independent code that integrates smoothly with Node.js.
|
|
4
|
+
|
|
5
|
+
## Documentation
|
|
6
|
+
|
|
7
|
+
- **API Reference**: [View the full documentation](https://effect-ts.github.io/effect/docs/platform-node).
|
|
@@ -3,8 +3,15 @@
|
|
|
3
3
|
Object.defineProperty(exports, "__esModule", {
|
|
4
4
|
value: true
|
|
5
5
|
});
|
|
6
|
+
Object.defineProperty(exports, "launch", {
|
|
7
|
+
enumerable: true,
|
|
8
|
+
get: function () {
|
|
9
|
+
return _WorkerRunner.launch;
|
|
10
|
+
}
|
|
11
|
+
});
|
|
6
12
|
exports.layer = void 0;
|
|
7
13
|
var internal = _interopRequireWildcard(require("./internal/workerRunner.js"));
|
|
14
|
+
var _WorkerRunner = require("@effect/platform/WorkerRunner");
|
|
8
15
|
function _getRequireWildcardCache(e) { if ("function" != typeof WeakMap) return null; var r = new WeakMap(), t = new WeakMap(); return (_getRequireWildcardCache = function (e) { return e ? t : r; })(e); }
|
|
9
16
|
function _interopRequireWildcard(e, r) { if (!r && e && e.__esModule) return e; if (null === e || "object" != typeof e && "function" != typeof e) return { default: e }; var t = _getRequireWildcardCache(r); if (t && t.has(e)) return t.get(e); var n = { __proto__: null }, a = Object.defineProperty && Object.getOwnPropertyDescriptor; for (var u in e) if ("default" !== u && {}.hasOwnProperty.call(e, u)) { var i = a ? Object.getOwnPropertyDescriptor(e, u) : null; i && (i.get || i.set) ? Object.defineProperty(n, u, i) : n[u] = e[u]; } return n.default = e, t && t.set(e, n), n; }
|
|
10
17
|
/**
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"NodeWorkerRunner.js","names":["internal","_interopRequireWildcard","require","_getRequireWildcardCache","e","WeakMap","r","t","__esModule","default","has","get","n","__proto__","a","Object","defineProperty","getOwnPropertyDescriptor","u","hasOwnProperty","call","i","set","layer","exports"],"sources":["../../src/NodeWorkerRunner.ts"],"sourcesContent":[null],"mappings":"
|
|
1
|
+
{"version":3,"file":"NodeWorkerRunner.js","names":["internal","_interopRequireWildcard","require","_WorkerRunner","_getRequireWildcardCache","e","WeakMap","r","t","__esModule","default","has","get","n","__proto__","a","Object","defineProperty","getOwnPropertyDescriptor","u","hasOwnProperty","call","i","set","layer","exports"],"sources":["../../src/NodeWorkerRunner.ts"],"sourcesContent":[null],"mappings":";;;;;;;;;;;;AAKA,IAAAA,QAAA,GAAAC,uBAAA,CAAAC,OAAA;AAEA,IAAAC,aAAA,GAAAD,OAAA;AAMsC,SAAAE,yBAAAC,CAAA,6BAAAC,OAAA,mBAAAC,CAAA,OAAAD,OAAA,IAAAE,CAAA,OAAAF,OAAA,YAAAF,wBAAA,YAAAA,CAAAC,CAAA,WAAAA,CAAA,GAAAG,CAAA,GAAAD,CAAA,KAAAF,CAAA;AAAA,SAAAJ,wBAAAI,CAAA,EAAAE,CAAA,SAAAA,CAAA,IAAAF,CAAA,IAAAA,CAAA,CAAAI,UAAA,SAAAJ,CAAA,eAAAA,CAAA,uBAAAA,CAAA,yBAAAA,CAAA,WAAAK,OAAA,EAAAL,CAAA,QAAAG,CAAA,GAAAJ,wBAAA,CAAAG,CAAA,OAAAC,CAAA,IAAAA,CAAA,CAAAG,GAAA,CAAAN,CAAA,UAAAG,CAAA,CAAAI,GAAA,CAAAP,CAAA,OAAAQ,CAAA,KAAAC,SAAA,UAAAC,CAAA,GAAAC,MAAA,CAAAC,cAAA,IAAAD,MAAA,CAAAE,wBAAA,WAAAC,CAAA,IAAAd,CAAA,oBAAAc,CAAA,OAAAC,cAAA,CAAAC,IAAA,CAAAhB,CAAA,EAAAc,CAAA,SAAAG,CAAA,GAAAP,CAAA,GAAAC,MAAA,CAAAE,wBAAA,CAAAb,CAAA,EAAAc,CAAA,UAAAG,CAAA,KAAAA,CAAA,CAAAV,GAAA,IAAAU,CAAA,CAAAC,GAAA,IAAAP,MAAA,CAAAC,cAAA,CAAAJ,CAAA,EAAAM,CAAA,EAAAG,CAAA,IAAAT,CAAA,CAAAM,CAAA,IAAAd,CAAA,CAAAc,CAAA,YAAAN,CAAA,CAAAH,OAAA,GAAAL,CAAA,EAAAG,CAAA,IAAAA,CAAA,CAAAe,GAAA,CAAAlB,CAAA,EAAAQ,CAAA,GAAAA,CAAA;AAEtC;;;;AAIO,MAAMW,KAAK,GAAAC,OAAA,CAAAD,KAAA,GAAuCxB,QAAQ,CAACwB,KAAK","ignoreList":[]}
|
|
@@ -6,11 +6,11 @@ Object.defineProperty(exports, "__esModule", {
|
|
|
6
6
|
exports.layer = void 0;
|
|
7
7
|
var _WorkerError = require("@effect/platform/WorkerError");
|
|
8
8
|
var Runner = _interopRequireWildcard(require("@effect/platform/WorkerRunner"));
|
|
9
|
+
var Cause = _interopRequireWildcard(require("effect/Cause"));
|
|
9
10
|
var Context = _interopRequireWildcard(require("effect/Context"));
|
|
10
11
|
var Deferred = _interopRequireWildcard(require("effect/Deferred"));
|
|
11
12
|
var Effect = _interopRequireWildcard(require("effect/Effect"));
|
|
12
13
|
var Exit = _interopRequireWildcard(require("effect/Exit"));
|
|
13
|
-
var FiberId = _interopRequireWildcard(require("effect/FiberId"));
|
|
14
14
|
var FiberSet = _interopRequireWildcard(require("effect/FiberSet"));
|
|
15
15
|
var Layer = _interopRequireWildcard(require("effect/Layer"));
|
|
16
16
|
var Runtime = _interopRequireWildcard(require("effect/Runtime"));
|
|
@@ -20,7 +20,7 @@ function _getRequireWildcardCache(e) { if ("function" != typeof WeakMap) return
|
|
|
20
20
|
function _interopRequireWildcard(e, r) { if (!r && e && e.__esModule) return e; if (null === e || "object" != typeof e && "function" != typeof e) return { default: e }; var t = _getRequireWildcardCache(r); if (t && t.has(e)) return t.get(e); var n = { __proto__: null }, a = Object.defineProperty && Object.getOwnPropertyDescriptor; for (var u in e) if ("default" !== u && {}.hasOwnProperty.call(e, u)) { var i = a ? Object.getOwnPropertyDescriptor(e, u) : null; i && (i.get || i.set) ? Object.defineProperty(n, u, i) : n[u] = e[u]; } return n.default = e, t && t.set(e, n), n; }
|
|
21
21
|
const platformRunnerImpl = /*#__PURE__*/Runner.PlatformRunner.of({
|
|
22
22
|
[Runner.PlatformRunnerTypeId]: Runner.PlatformRunnerTypeId,
|
|
23
|
-
start() {
|
|
23
|
+
start(closeLatch) {
|
|
24
24
|
return Effect.gen(function* () {
|
|
25
25
|
if (!WorkerThreads.parentPort) {
|
|
26
26
|
return yield* new _WorkerError.WorkerError({
|
|
@@ -30,33 +30,39 @@ const platformRunnerImpl = /*#__PURE__*/Runner.PlatformRunner.of({
|
|
|
30
30
|
}
|
|
31
31
|
const port = WorkerThreads.parentPort;
|
|
32
32
|
const send = (_portId, message, transfers) => Effect.sync(() => port.postMessage([1, message], transfers));
|
|
33
|
-
const run =
|
|
34
|
-
const runtime = (yield* Effect.runtime()).pipe(Runtime.updateContext(Context.omit(Scope.Scope)));
|
|
33
|
+
const run = Effect.fnUntraced(function* (handler) {
|
|
34
|
+
const runtime = (yield* Effect.interruptible(Effect.runtime())).pipe(Runtime.updateContext(Context.omit(Scope.Scope)));
|
|
35
35
|
const fiberSet = yield* FiberSet.make();
|
|
36
36
|
const runFork = Runtime.runFork(runtime);
|
|
37
|
+
const onExit = exit => {
|
|
38
|
+
if (exit._tag === "Failure") {
|
|
39
|
+
Deferred.unsafeDone(closeLatch, Exit.die(Cause.squash(exit.cause)));
|
|
40
|
+
}
|
|
41
|
+
};
|
|
37
42
|
port.on("message", message => {
|
|
38
43
|
if (message[0] === 0) {
|
|
39
|
-
|
|
44
|
+
const fiber = runFork(handler(0, message[1]));
|
|
45
|
+
fiber.addObserver(onExit);
|
|
46
|
+
FiberSet.unsafeAdd(fiberSet, fiber);
|
|
40
47
|
} else {
|
|
41
48
|
port.close();
|
|
42
|
-
Deferred.unsafeDone(
|
|
49
|
+
Deferred.unsafeDone(closeLatch, Exit.void);
|
|
43
50
|
}
|
|
44
51
|
});
|
|
45
52
|
port.on("messageerror", cause => {
|
|
46
|
-
Deferred.unsafeDone(
|
|
53
|
+
Deferred.unsafeDone(closeLatch, new _WorkerError.WorkerError({
|
|
47
54
|
reason: "decode",
|
|
48
55
|
cause
|
|
49
56
|
}));
|
|
50
57
|
});
|
|
51
58
|
port.on("error", cause => {
|
|
52
|
-
Deferred.unsafeDone(
|
|
59
|
+
Deferred.unsafeDone(closeLatch, new _WorkerError.WorkerError({
|
|
53
60
|
reason: "unknown",
|
|
54
61
|
cause
|
|
55
62
|
}));
|
|
56
63
|
});
|
|
57
64
|
port.postMessage([0]);
|
|
58
|
-
|
|
59
|
-
}).pipe(Effect.scoped));
|
|
65
|
+
});
|
|
60
66
|
return {
|
|
61
67
|
run,
|
|
62
68
|
send
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"workerRunner.js","names":["_WorkerError","require","Runner","_interopRequireWildcard","Context","Deferred","Effect","Exit","
|
|
1
|
+
{"version":3,"file":"workerRunner.js","names":["_WorkerError","require","Runner","_interopRequireWildcard","Cause","Context","Deferred","Effect","Exit","FiberSet","Layer","Runtime","Scope","WorkerThreads","_getRequireWildcardCache","e","WeakMap","r","t","__esModule","default","has","get","n","__proto__","a","Object","defineProperty","getOwnPropertyDescriptor","u","hasOwnProperty","call","i","set","platformRunnerImpl","PlatformRunner","of","PlatformRunnerTypeId","start","closeLatch","gen","parentPort","WorkerError","reason","cause","Error","port","send","_portId","message","transfers","sync","postMessage","run","fnUntraced","handler","runtime","interruptible","pipe","updateContext","omit","fiberSet","make","runFork","onExit","exit","_tag","unsafeDone","die","squash","on","fiber","addObserver","unsafeAdd","close","void","layer","exports","succeed"],"sources":["../../../src/internal/workerRunner.ts"],"sourcesContent":[null],"mappings":"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","ignoreList":[]}
|
|
@@ -3,6 +3,12 @@
|
|
|
3
3
|
*/
|
|
4
4
|
import type * as Runner from "@effect/platform/WorkerRunner";
|
|
5
5
|
import type * as Layer from "effect/Layer";
|
|
6
|
+
export {
|
|
7
|
+
/**
|
|
8
|
+
* @since 1.0.0
|
|
9
|
+
* @category re-exports
|
|
10
|
+
*/
|
|
11
|
+
launch } from "@effect/platform/WorkerRunner";
|
|
6
12
|
/**
|
|
7
13
|
* @since 1.0.0
|
|
8
14
|
* @category layers
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"NodeWorkerRunner.d.ts","sourceRoot":"","sources":["../../src/NodeWorkerRunner.ts"],"names":[],"mappings":"AAAA;;GAEG;AACH,OAAO,KAAK,KAAK,MAAM,MAAM,+BAA+B,CAAA;AAC5D,OAAO,KAAK,KAAK,KAAK,MAAM,cAAc,CAAA;AAG1C;;;GAGG;AACH,eAAO,MAAM,KAAK,EAAE,KAAK,CAAC,KAAK,CAAC,MAAM,CAAC,cAAc,CAAkB,CAAA"}
|
|
1
|
+
{"version":3,"file":"NodeWorkerRunner.d.ts","sourceRoot":"","sources":["../../src/NodeWorkerRunner.ts"],"names":[],"mappings":"AAAA;;GAEG;AACH,OAAO,KAAK,KAAK,MAAM,MAAM,+BAA+B,CAAA;AAC5D,OAAO,KAAK,KAAK,KAAK,MAAM,cAAc,CAAA;AAG1C,OAAO;AACL;;;GAGG;AACH,MAAM,EACP,MAAM,+BAA+B,CAAA;AAEtC;;;GAGG;AACH,eAAO,MAAM,KAAK,EAAE,KAAK,CAAC,KAAK,CAAC,MAAM,CAAC,cAAc,CAAkB,CAAA"}
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"NodeWorkerRunner.js","names":["internal","layer"],"sources":["../../src/NodeWorkerRunner.ts"],"sourcesContent":[null],"mappings":"AAKA,OAAO,KAAKA,QAAQ,MAAM,4BAA4B;AAEtD;;;;AAIA,OAAO,MAAMC,KAAK,
|
|
1
|
+
{"version":3,"file":"NodeWorkerRunner.js","names":["internal","launch","layer"],"sources":["../../src/NodeWorkerRunner.ts"],"sourcesContent":[null],"mappings":"AAKA,OAAO,KAAKA,QAAQ,MAAM,4BAA4B;AAEtD;AACE;;;;AAIAC,MAAM,QACD,+BAA+B;AAEtC;;;;AAIA,OAAO,MAAMC,KAAK,GAAuCF,QAAQ,CAACE,KAAK","ignoreList":[]}
|
|
@@ -1,10 +1,10 @@
|
|
|
1
1
|
import { WorkerError } from "@effect/platform/WorkerError";
|
|
2
2
|
import * as Runner from "@effect/platform/WorkerRunner";
|
|
3
|
+
import * as Cause from "effect/Cause";
|
|
3
4
|
import * as Context from "effect/Context";
|
|
4
5
|
import * as Deferred from "effect/Deferred";
|
|
5
6
|
import * as Effect from "effect/Effect";
|
|
6
7
|
import * as Exit from "effect/Exit";
|
|
7
|
-
import * as FiberId from "effect/FiberId";
|
|
8
8
|
import * as FiberSet from "effect/FiberSet";
|
|
9
9
|
import * as Layer from "effect/Layer";
|
|
10
10
|
import * as Runtime from "effect/Runtime";
|
|
@@ -12,7 +12,7 @@ import * as Scope from "effect/Scope";
|
|
|
12
12
|
import * as WorkerThreads from "node:worker_threads";
|
|
13
13
|
const platformRunnerImpl = /*#__PURE__*/Runner.PlatformRunner.of({
|
|
14
14
|
[Runner.PlatformRunnerTypeId]: Runner.PlatformRunnerTypeId,
|
|
15
|
-
start() {
|
|
15
|
+
start(closeLatch) {
|
|
16
16
|
return Effect.gen(function* () {
|
|
17
17
|
if (!WorkerThreads.parentPort) {
|
|
18
18
|
return yield* new WorkerError({
|
|
@@ -22,33 +22,39 @@ const platformRunnerImpl = /*#__PURE__*/Runner.PlatformRunner.of({
|
|
|
22
22
|
}
|
|
23
23
|
const port = WorkerThreads.parentPort;
|
|
24
24
|
const send = (_portId, message, transfers) => Effect.sync(() => port.postMessage([1, message], transfers));
|
|
25
|
-
const run =
|
|
26
|
-
const runtime = (yield* Effect.runtime()).pipe(Runtime.updateContext(Context.omit(Scope.Scope)));
|
|
25
|
+
const run = Effect.fnUntraced(function* (handler) {
|
|
26
|
+
const runtime = (yield* Effect.interruptible(Effect.runtime())).pipe(Runtime.updateContext(Context.omit(Scope.Scope)));
|
|
27
27
|
const fiberSet = yield* FiberSet.make();
|
|
28
28
|
const runFork = Runtime.runFork(runtime);
|
|
29
|
+
const onExit = exit => {
|
|
30
|
+
if (exit._tag === "Failure") {
|
|
31
|
+
Deferred.unsafeDone(closeLatch, Exit.die(Cause.squash(exit.cause)));
|
|
32
|
+
}
|
|
33
|
+
};
|
|
29
34
|
port.on("message", message => {
|
|
30
35
|
if (message[0] === 0) {
|
|
31
|
-
|
|
36
|
+
const fiber = runFork(handler(0, message[1]));
|
|
37
|
+
fiber.addObserver(onExit);
|
|
38
|
+
FiberSet.unsafeAdd(fiberSet, fiber);
|
|
32
39
|
} else {
|
|
33
40
|
port.close();
|
|
34
|
-
Deferred.unsafeDone(
|
|
41
|
+
Deferred.unsafeDone(closeLatch, Exit.void);
|
|
35
42
|
}
|
|
36
43
|
});
|
|
37
44
|
port.on("messageerror", cause => {
|
|
38
|
-
Deferred.unsafeDone(
|
|
45
|
+
Deferred.unsafeDone(closeLatch, new WorkerError({
|
|
39
46
|
reason: "decode",
|
|
40
47
|
cause
|
|
41
48
|
}));
|
|
42
49
|
});
|
|
43
50
|
port.on("error", cause => {
|
|
44
|
-
Deferred.unsafeDone(
|
|
51
|
+
Deferred.unsafeDone(closeLatch, new WorkerError({
|
|
45
52
|
reason: "unknown",
|
|
46
53
|
cause
|
|
47
54
|
}));
|
|
48
55
|
});
|
|
49
56
|
port.postMessage([0]);
|
|
50
|
-
|
|
51
|
-
}).pipe(Effect.scoped));
|
|
57
|
+
});
|
|
52
58
|
return {
|
|
53
59
|
run,
|
|
54
60
|
send
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"workerRunner.js","names":["WorkerError","Runner","Context","Deferred","Effect","Exit","
|
|
1
|
+
{"version":3,"file":"workerRunner.js","names":["WorkerError","Runner","Cause","Context","Deferred","Effect","Exit","FiberSet","Layer","Runtime","Scope","WorkerThreads","platformRunnerImpl","PlatformRunner","of","PlatformRunnerTypeId","start","closeLatch","gen","parentPort","reason","cause","Error","port","send","_portId","message","transfers","sync","postMessage","run","fnUntraced","handler","runtime","interruptible","pipe","updateContext","omit","fiberSet","make","runFork","onExit","exit","_tag","unsafeDone","die","squash","on","fiber","addObserver","unsafeAdd","close","void","layer","succeed"],"sources":["../../../src/internal/workerRunner.ts"],"sourcesContent":[null],"mappings":"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","ignoreList":[]}
|
package/package.json
CHANGED
|
@@ -1,6 +1,6 @@
|
|
|
1
1
|
{
|
|
2
2
|
"name": "@effect/platform-node",
|
|
3
|
-
"version": "0.
|
|
3
|
+
"version": "0.72.1",
|
|
4
4
|
"description": "Platform specific implementations for the Node.js runtime",
|
|
5
5
|
"license": "MIT",
|
|
6
6
|
"repository": {
|
|
@@ -13,11 +13,11 @@
|
|
|
13
13
|
"mime": "^3.0.0",
|
|
14
14
|
"undici": "^7.1.0",
|
|
15
15
|
"ws": "^8.18.0",
|
|
16
|
-
"@effect/platform-node-shared": "^0.
|
|
16
|
+
"@effect/platform-node-shared": "^0.26.1"
|
|
17
17
|
},
|
|
18
18
|
"peerDependencies": {
|
|
19
|
-
"@effect/platform": "^0.
|
|
20
|
-
"effect": "^3.12.
|
|
19
|
+
"@effect/platform": "^0.76.1",
|
|
20
|
+
"effect": "^3.12.12"
|
|
21
21
|
},
|
|
22
22
|
"publishConfig": {
|
|
23
23
|
"provenance": true
|
package/src/NodeWorkerRunner.ts
CHANGED
|
@@ -5,6 +5,14 @@ import type * as Runner from "@effect/platform/WorkerRunner"
|
|
|
5
5
|
import type * as Layer from "effect/Layer"
|
|
6
6
|
import * as internal from "./internal/workerRunner.js"
|
|
7
7
|
|
|
8
|
+
export {
|
|
9
|
+
/**
|
|
10
|
+
* @since 1.0.0
|
|
11
|
+
* @category re-exports
|
|
12
|
+
*/
|
|
13
|
+
launch
|
|
14
|
+
} from "@effect/platform/WorkerRunner"
|
|
15
|
+
|
|
8
16
|
/**
|
|
9
17
|
* @since 1.0.0
|
|
10
18
|
* @category layers
|
|
@@ -1,10 +1,10 @@
|
|
|
1
1
|
import { WorkerError } from "@effect/platform/WorkerError"
|
|
2
2
|
import * as Runner from "@effect/platform/WorkerRunner"
|
|
3
|
+
import * as Cause from "effect/Cause"
|
|
3
4
|
import * as Context from "effect/Context"
|
|
4
5
|
import * as Deferred from "effect/Deferred"
|
|
5
6
|
import * as Effect from "effect/Effect"
|
|
6
7
|
import * as Exit from "effect/Exit"
|
|
7
|
-
import * as FiberId from "effect/FiberId"
|
|
8
8
|
import * as FiberSet from "effect/FiberSet"
|
|
9
9
|
import * as Layer from "effect/Layer"
|
|
10
10
|
import * as Runtime from "effect/Runtime"
|
|
@@ -13,7 +13,7 @@ import * as WorkerThreads from "node:worker_threads"
|
|
|
13
13
|
|
|
14
14
|
const platformRunnerImpl = Runner.PlatformRunner.of({
|
|
15
15
|
[Runner.PlatformRunnerTypeId]: Runner.PlatformRunnerTypeId,
|
|
16
|
-
start<I, O>() {
|
|
16
|
+
start<I, O>(closeLatch: Deferred.Deferred<void, WorkerError>) {
|
|
17
17
|
return Effect.gen(function*() {
|
|
18
18
|
if (!WorkerThreads.parentPort) {
|
|
19
19
|
return yield* new WorkerError({ reason: "spawn", cause: new Error("not in a worker thread") })
|
|
@@ -21,32 +21,38 @@ const platformRunnerImpl = Runner.PlatformRunner.of({
|
|
|
21
21
|
const port = WorkerThreads.parentPort
|
|
22
22
|
const send = (_portId: number, message: O, transfers?: ReadonlyArray<unknown>) =>
|
|
23
23
|
Effect.sync(() => port.postMessage([1, message], transfers as any))
|
|
24
|
-
|
|
25
|
-
|
|
26
|
-
|
|
27
|
-
|
|
28
|
-
|
|
29
|
-
|
|
30
|
-
|
|
31
|
-
|
|
32
|
-
|
|
33
|
-
|
|
34
|
-
|
|
35
|
-
|
|
36
|
-
|
|
37
|
-
|
|
38
|
-
|
|
39
|
-
|
|
40
|
-
|
|
41
|
-
|
|
42
|
-
}
|
|
43
|
-
|
|
44
|
-
Deferred.unsafeDone(
|
|
45
|
-
}
|
|
46
|
-
|
|
47
|
-
|
|
48
|
-
|
|
49
|
-
|
|
24
|
+
|
|
25
|
+
const run = Effect.fnUntraced(
|
|
26
|
+
function*<A, E, R>(handler: (portId: number, message: I) => Effect.Effect<A, E, R>) {
|
|
27
|
+
const runtime = (yield* Effect.interruptible(Effect.runtime<R | Scope.Scope>())).pipe(
|
|
28
|
+
Runtime.updateContext(Context.omit(Scope.Scope))
|
|
29
|
+
) as Runtime.Runtime<R>
|
|
30
|
+
const fiberSet = yield* FiberSet.make<any, WorkerError | E>()
|
|
31
|
+
const runFork = Runtime.runFork(runtime)
|
|
32
|
+
const onExit = (exit: Exit.Exit<any, E>) => {
|
|
33
|
+
if (exit._tag === "Failure") {
|
|
34
|
+
Deferred.unsafeDone(closeLatch, Exit.die(Cause.squash(exit.cause)))
|
|
35
|
+
}
|
|
36
|
+
}
|
|
37
|
+
port.on("message", (message: Runner.BackingRunner.Message<I>) => {
|
|
38
|
+
if (message[0] === 0) {
|
|
39
|
+
const fiber = runFork(handler(0, message[1]))
|
|
40
|
+
fiber.addObserver(onExit)
|
|
41
|
+
FiberSet.unsafeAdd(fiberSet, fiber)
|
|
42
|
+
} else {
|
|
43
|
+
port.close()
|
|
44
|
+
Deferred.unsafeDone(closeLatch, Exit.void)
|
|
45
|
+
}
|
|
46
|
+
})
|
|
47
|
+
port.on("messageerror", (cause) => {
|
|
48
|
+
Deferred.unsafeDone(closeLatch, new WorkerError({ reason: "decode", cause }))
|
|
49
|
+
})
|
|
50
|
+
port.on("error", (cause) => {
|
|
51
|
+
Deferred.unsafeDone(closeLatch, new WorkerError({ reason: "unknown", cause }))
|
|
52
|
+
})
|
|
53
|
+
port.postMessage([0])
|
|
54
|
+
}
|
|
55
|
+
)
|
|
50
56
|
|
|
51
57
|
return { run, send }
|
|
52
58
|
})
|