@logixjs/sandbox 0.0.1 → 0.0.2
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/LICENSE +201 -0
- package/package.json +3 -1
- package/public/sandbox/chunks/chunk-2AUQRESB.js +1114 -0
- package/public/sandbox/chunks/chunk-2F72LQKW.js +194 -0
- package/public/sandbox/chunks/chunk-2PYDGDD3.js +4071 -0
- package/public/sandbox/chunks/chunk-2UGKSXDZ.js +16 -0
- package/public/sandbox/chunks/chunk-2XVE7F26.js +153 -0
- package/public/sandbox/chunks/chunk-3A7TFNZN.js +219 -0
- package/public/sandbox/chunks/chunk-3BHC6JAV.js +1070 -0
- package/public/sandbox/chunks/chunk-3U4CAKCX.js +61 -0
- package/public/sandbox/chunks/chunk-3VU3JLZO.js +272 -0
- package/public/sandbox/chunks/chunk-4CPONKWY.js +1170 -0
- package/public/sandbox/chunks/chunk-4GMUQTWH.js +850 -0
- package/public/sandbox/chunks/chunk-4KIYG5E4.js +749 -0
- package/public/sandbox/chunks/chunk-4MY35XR3.js +175 -0
- package/public/sandbox/chunks/chunk-5DNHJMHA.js +69 -0
- package/public/sandbox/chunks/chunk-5EC4S7X6.js +42 -0
- package/public/sandbox/chunks/chunk-5FB7QFSH.js +227 -0
- package/public/sandbox/chunks/chunk-5GEYCJW2.js +206 -0
- package/public/sandbox/chunks/chunk-5PT7Q5SS.js +373 -0
- package/public/sandbox/chunks/chunk-5WN5IGKA.js +166 -0
- package/public/sandbox/chunks/chunk-5XOBKSOT.js +213 -0
- package/public/sandbox/chunks/chunk-67RVISUC.js +313 -0
- package/public/sandbox/chunks/chunk-6ELJEKZS.js +12 -0
- package/public/sandbox/chunks/chunk-6FKWRVP4.js +85 -0
- package/public/sandbox/chunks/chunk-6JRP52YT.js +34 -0
- package/public/sandbox/chunks/chunk-6JYAC3G6.js +42 -0
- package/public/sandbox/chunks/chunk-6TUOP63Q.js +86 -0
- package/public/sandbox/chunks/{chunk-A6JFUNQQ.js → chunk-74C5VW7Z.js} +2 -2
- package/public/sandbox/chunks/chunk-75DQFC5M.js +16 -0
- package/public/sandbox/chunks/{chunk-UCFEP3BH.js → chunk-7GPAF2UK.js} +1 -1
- package/public/sandbox/chunks/chunk-7KQFTS2Y.js +135 -0
- package/public/sandbox/chunks/chunk-7POKWYE3.js +112 -0
- package/public/sandbox/chunks/chunk-7VUEF5F3.js +395 -0
- package/public/sandbox/chunks/chunk-7W5APZS2.js +77 -0
- package/public/sandbox/chunks/chunk-A6OFCXDQ.js +397 -0
- package/public/sandbox/chunks/chunk-A7HLOSO6.js +216 -0
- package/public/sandbox/chunks/chunk-AGF4RRCB.js +408 -0
- package/public/sandbox/chunks/chunk-ASJSJAAL.js +122 -0
- package/public/sandbox/chunks/chunk-ASVMK364.js +283 -0
- package/public/sandbox/chunks/chunk-AUDTI2BQ.js +895 -0
- package/public/sandbox/chunks/chunk-B2SZTA3M.js +16 -0
- package/public/sandbox/chunks/chunk-B6YS2UMV.js +372 -0
- package/public/sandbox/chunks/chunk-BCEO3MGD.js +244 -0
- package/public/sandbox/chunks/chunk-BCOO65D4.js +373 -0
- package/public/sandbox/chunks/chunk-BJOWSSEL.js +38 -0
- package/public/sandbox/chunks/chunk-BS2WBFW4.js +373 -0
- package/public/sandbox/chunks/chunk-BUVHG3NJ.js +439 -0
- package/public/sandbox/chunks/chunk-BVE33AN6.js +42 -0
- package/public/sandbox/chunks/chunk-BWTGJZVP.js +19 -0
- package/public/sandbox/chunks/chunk-BXD7GZC3.js +1025 -0
- package/public/sandbox/chunks/chunk-BZH4EUUD.js +164 -0
- package/public/sandbox/chunks/{chunk-HFV5GJPK.js → chunk-C2MYMMO4.js} +3 -3
- package/public/sandbox/chunks/chunk-CRE4NJJ6.js +271 -0
- package/public/sandbox/chunks/chunk-CVZPRIDB.js +706 -0
- package/public/sandbox/chunks/chunk-CWOXD5NG.js +991 -0
- package/public/sandbox/chunks/chunk-D6DOC3BJ.js +373 -0
- package/public/sandbox/chunks/chunk-DEPSGFSY.js +1698 -0
- package/public/sandbox/chunks/chunk-DM7C5NP5.js +819 -0
- package/public/sandbox/chunks/chunk-DN33LMOF.js +1112 -0
- package/public/sandbox/chunks/{chunk-S46P7MC6.js → chunk-DT7YIIWE.js} +2 -2
- package/public/sandbox/chunks/chunk-DVB5WRCI.js +260 -0
- package/public/sandbox/chunks/{chunk-TOHCFMQS.js → chunk-E3EVW7NR.js} +11 -18
- package/public/sandbox/chunks/chunk-E5BV567Q.js +417 -0
- package/public/sandbox/chunks/chunk-E7BIWMQQ.js +203 -0
- package/public/sandbox/chunks/chunk-EAKGPSOQ.js +83 -0
- package/public/sandbox/chunks/chunk-EGUYL2ER.js +75 -0
- package/public/sandbox/chunks/chunk-EP5GQYZ5.js +85 -0
- package/public/sandbox/chunks/chunk-ET6CJEHC.js +221 -0
- package/public/sandbox/chunks/chunk-EU67YZHZ.js +1070 -0
- package/public/sandbox/chunks/{chunk-PTSJJANP.js → chunk-EYNDQLSB.js} +1 -1
- package/public/sandbox/chunks/{chunk-CEGSWZ5S.js → chunk-EZTMVCJF.js} +1 -1
- package/public/sandbox/chunks/chunk-F5CLVIS6.js +907 -0
- package/public/sandbox/chunks/chunk-F743SKYD.js +85 -0
- package/public/sandbox/chunks/chunk-FEGFZ5OX.js +86 -0
- package/public/sandbox/chunks/chunk-FG5B7ZX3.js +373 -0
- package/public/sandbox/chunks/chunk-FKZPYMDG.js +373 -0
- package/public/sandbox/chunks/chunk-FNLXHWIU.js +220 -0
- package/public/sandbox/chunks/chunk-FQRUTYAD.js +1991 -0
- package/public/sandbox/chunks/{chunk-VLYP4WUS.js → chunk-FY5A73NK.js} +5 -5
- package/public/sandbox/chunks/chunk-G7FAOG3O.js +221 -0
- package/public/sandbox/chunks/chunk-GFXHUC7Y.js +73 -0
- package/public/sandbox/chunks/chunk-GIPXUIZQ.js +534 -0
- package/public/sandbox/chunks/chunk-GP37MEGJ.js +52 -0
- package/public/sandbox/chunks/chunk-GXL5QCMF.js +4511 -0
- package/public/sandbox/chunks/chunk-GZ2NSE6A.js +177 -0
- package/public/sandbox/chunks/chunk-GZATW4YD.js +69 -0
- package/public/sandbox/chunks/chunk-H4EBXROQ.js +166 -0
- package/public/sandbox/chunks/chunk-HETCPK6Z.js +153 -0
- package/public/sandbox/chunks/chunk-HGUFQ2QC.js +4431 -0
- package/public/sandbox/chunks/chunk-HGV3VNH3.js +255 -0
- package/public/sandbox/chunks/chunk-HIJ67QWR.js +5397 -0
- package/public/sandbox/chunks/chunk-IDHERBKW.js +1114 -0
- package/public/sandbox/chunks/chunk-IDTK4FIY.js +102 -0
- package/public/sandbox/chunks/chunk-ILFVY7H5.js +164 -0
- package/public/sandbox/chunks/chunk-ISGSRYGO.js +57 -0
- package/public/sandbox/chunks/chunk-J45VPU24.js +408 -0
- package/public/sandbox/chunks/chunk-JAUIM3O5.js +42 -0
- package/public/sandbox/chunks/chunk-JB7OQEM6.js +373 -0
- package/public/sandbox/chunks/chunk-JCKW6NHD.js +15 -0
- package/public/sandbox/chunks/chunk-JMA7GY7Z.js +221 -0
- package/public/sandbox/chunks/chunk-JY46J6IL.js +836 -0
- package/public/sandbox/chunks/{chunk-X72PZOFA.js → chunk-K2MQ66O7.js} +1 -1
- package/public/sandbox/chunks/chunk-KA7PZA6F.js +464 -0
- package/public/sandbox/chunks/chunk-KDEQTUID.js +102 -0
- package/public/sandbox/chunks/chunk-KDJR27JV.js +1696 -0
- package/public/sandbox/chunks/chunk-KFE3JO6N.js +77 -0
- package/public/sandbox/chunks/chunk-KLDSYWT5.js +536 -0
- package/public/sandbox/chunks/chunk-KQWWFYBF.js +203 -0
- package/public/sandbox/chunks/chunk-KTFZSXOW.js +6473 -0
- package/public/sandbox/chunks/chunk-KXVIC55U.js +108 -0
- package/public/sandbox/chunks/{chunk-HNEDTEGQ.js → chunk-L4PNO2H6.js} +1 -1
- package/public/sandbox/chunks/{chunk-WE4STGO2.js → chunk-L4ZNW5DI.js} +2 -2
- package/public/sandbox/chunks/chunk-LBUINGZ4.js +836 -0
- package/public/sandbox/chunks/chunk-LIYPPU6I.js +112 -0
- package/public/sandbox/chunks/chunk-LJHTOJXW.js +221 -0
- package/public/sandbox/chunks/{chunk-BWSNPKO5.js → chunk-LQL23SWJ.js} +2 -2
- package/public/sandbox/chunks/chunk-LTFCYZQ6.js +46 -0
- package/public/sandbox/chunks/chunk-LTWLVCKQ.js +166 -0
- package/public/sandbox/chunks/chunk-LWI7BXFN.js +395 -0
- package/public/sandbox/chunks/chunk-LYBBX6WM.js +225 -0
- package/public/sandbox/chunks/chunk-MXE7HIBM.js +474 -0
- package/public/sandbox/chunks/chunk-MYBDYNK4.js +6004 -0
- package/public/sandbox/chunks/chunk-NC2MIWZX.js +732 -0
- package/public/sandbox/chunks/chunk-NE447XAF.js +597 -0
- package/public/sandbox/chunks/chunk-NEAYV5C2.js +255 -0
- package/public/sandbox/chunks/chunk-NMGFJZ4I.js +26 -0
- package/public/sandbox/chunks/chunk-NWCJJZNQ.js +71 -0
- package/public/sandbox/chunks/chunk-O57OZBDR.js +214 -0
- package/public/sandbox/chunks/chunk-OJJT664Q.js +731 -0
- package/public/sandbox/chunks/chunk-OKTBUTCH.js +1175 -0
- package/public/sandbox/chunks/chunk-OQ4SYV5D.js +534 -0
- package/public/sandbox/chunks/chunk-OTVVIHJD.js +219 -0
- package/public/sandbox/chunks/chunk-OWTMSCF7.js +1052 -0
- package/public/sandbox/chunks/chunk-P5ZQNFC3.js +122 -0
- package/public/sandbox/chunks/chunk-PBPT2U2N.js +1698 -0
- package/public/sandbox/chunks/chunk-PHBJLCP3.js +836 -0
- package/public/sandbox/chunks/chunk-PHV4HYHB.js +397 -0
- package/public/sandbox/chunks/chunk-PIXQ6SOX.js +4071 -0
- package/public/sandbox/chunks/chunk-PKJL6YLK.js +73 -0
- package/public/sandbox/chunks/chunk-PKPOITIU.js +221 -0
- package/public/sandbox/chunks/{chunk-NQW73ACJ.js → chunk-PMXBOYQI.js} +1 -1
- package/public/sandbox/chunks/chunk-PQLZD7NR.js +836 -0
- package/public/sandbox/chunks/chunk-QEESVOZU.js +16 -0
- package/public/sandbox/chunks/chunk-QGIM3FQK.js +159 -0
- package/public/sandbox/chunks/chunk-QL5JNEDO.js +69 -0
- package/public/sandbox/chunks/chunk-QQOZ3RMH.js +867 -0
- package/public/sandbox/chunks/chunk-QUMEVT2F.js +194 -0
- package/public/sandbox/chunks/chunk-QVZBXYVY.js +102 -0
- package/public/sandbox/chunks/chunk-R5HQS6RB.js +135 -0
- package/public/sandbox/chunks/chunk-R75Q2CTT.js +900 -0
- package/public/sandbox/chunks/chunk-RBB6SHW2.js +253 -0
- package/public/sandbox/chunks/chunk-RDHNRWQP.js +383 -0
- package/public/sandbox/chunks/chunk-RIWOEI3T.js +1101 -0
- package/public/sandbox/chunks/chunk-RS5FFPUV.js +103 -0
- package/public/sandbox/chunks/chunk-RYSSJBGX.js +203 -0
- package/public/sandbox/chunks/chunk-S3KBAE5Z.js +1114 -0
- package/public/sandbox/chunks/chunk-S6ZZHV6G.js +244 -0
- package/public/sandbox/chunks/chunk-SFXJ24HY.js +499 -0
- package/public/sandbox/chunks/chunk-SH7TP5CJ.js +1109 -0
- package/public/sandbox/chunks/chunk-SI5OKFFY.js +317 -0
- package/public/sandbox/chunks/chunk-SIXNQNIR.js +86 -0
- package/public/sandbox/chunks/chunk-ST353BOX.js +42 -0
- package/public/sandbox/chunks/chunk-SYEHKMLP.js +1140 -0
- package/public/sandbox/chunks/chunk-SZ4KQUJU.js +69 -0
- package/public/sandbox/chunks/{chunk-5SOP6EKV.js → chunk-SZI65PSP.js} +5 -10
- package/public/sandbox/chunks/chunk-T7RLTSMX.js +78 -0
- package/public/sandbox/chunks/chunk-TJ2RLUTW.js +57 -0
- package/public/sandbox/chunks/chunk-TJB73XPN.js +4071 -0
- package/public/sandbox/chunks/chunk-TXJCYO56.js +4046 -0
- package/public/sandbox/chunks/chunk-U5J3LCYI.js +731 -0
- package/public/sandbox/chunks/chunk-UABFN3NH.js +208 -0
- package/public/sandbox/chunks/chunk-UBMUY7WO.js +13 -0
- package/public/sandbox/chunks/chunk-UC27CE32.js +69 -0
- package/public/sandbox/chunks/chunk-UJGVDFZN.js +147 -0
- package/public/sandbox/chunks/chunk-UNVLTK4N.js +122 -0
- package/public/sandbox/chunks/chunk-UQKQ6V3V.js +208 -0
- package/public/sandbox/chunks/chunk-UZZBHWIO.js +703 -0
- package/public/sandbox/chunks/chunk-VKZIJERL.js +1114 -0
- package/public/sandbox/chunks/chunk-VQQEAGID.js +372 -0
- package/public/sandbox/chunks/{chunk-3LX3KIQQ.js → chunk-W365QUZ5.js} +3 -5
- package/public/sandbox/chunks/chunk-WJY2LSWG.js +1052 -0
- package/public/sandbox/chunks/chunk-WNOBN3DX.js +391 -0
- package/public/sandbox/chunks/chunk-X2Z5VYG3.js +245 -0
- package/public/sandbox/chunks/chunk-X74KU74D.js +959 -0
- package/public/sandbox/chunks/chunk-XE7ULSGQ.js +46 -0
- package/public/sandbox/chunks/chunk-XRXUJZ3X.js +431 -0
- package/public/sandbox/chunks/chunk-XWHIN7CC.js +85 -0
- package/public/sandbox/chunks/chunk-Y2TVGGVL.js +527 -0
- package/public/sandbox/chunks/chunk-YMVMZA3U.js +1395 -0
- package/public/sandbox/chunks/chunk-YOBLFWDV.js +431 -0
- package/public/sandbox/chunks/chunk-YR2RFEZA.js +11 -0
- package/public/sandbox/chunks/chunk-YTD6A35P.js +836 -0
- package/public/sandbox/chunks/chunk-Z5L7EZXS.js +81 -0
- package/public/sandbox/chunks/chunk-Z65I5ET2.js +108 -0
- package/public/sandbox/chunks/chunk-Z6LV34RO.js +390 -0
- package/public/sandbox/chunks/chunk-ZAKUP6QG.js +1634 -0
- package/public/sandbox/chunks/chunk-ZHNYE2YH.js +731 -0
- package/public/sandbox/chunks/chunk-ZHQX3B3Y.js +867 -0
- package/public/sandbox/chunks/chunk-ZIXDFRHJ.js +731 -0
- package/public/sandbox/chunks/chunk-ZPZ2MZ4D.js +528 -0
- package/public/sandbox/chunks/chunk-ZQD6NZXB.js +373 -0
- package/public/sandbox/chunks/chunk-ZVVBP7ON.js +16 -0
- package/public/sandbox/chunks/chunk-ZWE3P6X2.js +11 -0
- package/public/sandbox/logix-core/Bound.js +14 -14
- package/public/sandbox/logix-core/Debug.js +12 -10
- package/public/sandbox/logix-core/EffectOp.js +3 -4
- package/public/sandbox/logix-core/Env.js +5 -2
- package/public/sandbox/logix-core/ExternalStore.js +239 -0
- package/public/sandbox/logix-core/Flow.js +7 -8
- package/public/sandbox/logix-core/Kernel.js +7 -4
- package/public/sandbox/logix-core/Link.js +33 -25
- package/public/sandbox/logix-core/Middleware.js +13 -11
- package/public/sandbox/logix-core/Module.js +93 -30
- package/public/sandbox/logix-core/ModuleTag.js +28 -25
- package/public/sandbox/logix-core/Observability.js +21 -19
- package/public/sandbox/logix-core/Process.js +27 -22
- package/public/sandbox/logix-core/ReadQuery.js +7 -11
- package/public/sandbox/logix-core/Reflection.js +173 -53
- package/public/sandbox/logix-core/Resource.js +6 -3
- package/public/sandbox/logix-core/Root.js +7 -3
- package/public/sandbox/logix-core/Runtime.js +54 -40
- package/public/sandbox/logix-core/ScopeRegistry.js +6 -3
- package/public/sandbox/logix-core/StateTrait.js +17 -14
- package/public/sandbox/logix-core/TraitLifecycle.js +8 -8
- package/public/sandbox/logix-core/Workflow.js +332 -0
- package/public/sandbox/logix-core.js +11133 -6622
- package/public/sandbox/logix-core.manifest.json +4 -2
- package/public/sandbox/worker.js +3 -3
- package/public/sandbox/chunks/chunk-4LRLOTMA.js +0 -1698
- package/public/sandbox/chunks/chunk-CDLXJHXY.js +0 -120
- package/public/sandbox/chunks/chunk-CZRI7MHA.js +0 -46
- package/public/sandbox/chunks/chunk-EJDFUZ4B.js +0 -408
- package/public/sandbox/chunks/chunk-IP63FME6.js +0 -282
- package/public/sandbox/chunks/chunk-JIXTOQXJ.js +0 -1103
- package/public/sandbox/chunks/chunk-MPUSOFJ3.js +0 -1928
- package/public/sandbox/chunks/chunk-ON2LY6HJ.js +0 -135
- package/public/sandbox/chunks/chunk-POIBXAH5.js +0 -995
- package/public/sandbox/chunks/chunk-PQ652ULI.js +0 -6359
- package/public/sandbox/chunks/chunk-RJQ4PG2F.js +0 -77
- package/public/sandbox/chunks/chunk-S4EXG3OS.js +0 -533
- package/public/sandbox/chunks/chunk-SUXDGXVE.js +0 -390
- package/public/sandbox/chunks/chunk-TOQ6SJ6O.js +0 -244
- package/public/sandbox/chunks/chunk-UKYAF3NL.js +0 -1036
- package/public/sandbox/chunks/chunk-UMVN3AWO.js +0 -395
- package/public/sandbox/chunks/chunk-WFV5PPWJ.js +0 -194
- package/public/sandbox/chunks/chunk-YF6IO732.js +0 -206
- package/public/sandbox/chunks/chunk-ZUBABAAO.js +0 -86
|
@@ -0,0 +1,439 @@
|
|
|
1
|
+
// @logixjs/core subpath bundles for @logixjs/sandbox
|
|
2
|
+
|
|
3
|
+
import {
|
|
4
|
+
ProcessRuntimeTag,
|
|
5
|
+
layer
|
|
6
|
+
} from "./chunk-KDJR27JV.js";
|
|
7
|
+
import {
|
|
8
|
+
make
|
|
9
|
+
} from "./chunk-RIWOEI3T.js";
|
|
10
|
+
import {
|
|
11
|
+
RootContextTag
|
|
12
|
+
} from "./chunk-UBMUY7WO.js";
|
|
13
|
+
import {
|
|
14
|
+
ConcurrencyPolicyTag,
|
|
15
|
+
HostSchedulerTag,
|
|
16
|
+
ReadQueryStrictGateConfigTag,
|
|
17
|
+
StateTransactionConfigTag,
|
|
18
|
+
declarativeLinkRuntimeLayer,
|
|
19
|
+
hostSchedulerLayer,
|
|
20
|
+
runtimeStoreLayer,
|
|
21
|
+
tickSchedulerLayer
|
|
22
|
+
} from "./chunk-YMVMZA3U.js";
|
|
23
|
+
import {
|
|
24
|
+
getGlobalHostScheduler
|
|
25
|
+
} from "./chunk-UJGVDFZN.js";
|
|
26
|
+
|
|
27
|
+
// ../logix-core/src/internal/runtime/core/runner/ProgramRunner.errors.ts
|
|
28
|
+
var summarizeCause = (cause) => {
|
|
29
|
+
if (cause instanceof Error) {
|
|
30
|
+
return { name: cause.name, message: cause.message };
|
|
31
|
+
}
|
|
32
|
+
return { message: typeof cause === "string" ? cause : void 0 };
|
|
33
|
+
};
|
|
34
|
+
var ProgramRunnerErrorBase = class extends Error {
|
|
35
|
+
constructor(params) {
|
|
36
|
+
super(params.message);
|
|
37
|
+
this.moduleId = params.identity.moduleId;
|
|
38
|
+
this.instanceId = params.identity.instanceId;
|
|
39
|
+
this.entrypoint = params.entrypoint;
|
|
40
|
+
this.hint = params.hint;
|
|
41
|
+
}
|
|
42
|
+
toJSON() {
|
|
43
|
+
return {
|
|
44
|
+
_tag: this._tag,
|
|
45
|
+
name: this.name,
|
|
46
|
+
message: this.message,
|
|
47
|
+
moduleId: this.moduleId,
|
|
48
|
+
instanceId: this.instanceId,
|
|
49
|
+
entrypoint: this.entrypoint,
|
|
50
|
+
hint: this.hint
|
|
51
|
+
};
|
|
52
|
+
}
|
|
53
|
+
};
|
|
54
|
+
var BootError = class extends ProgramRunnerErrorBase {
|
|
55
|
+
constructor(identity, cause) {
|
|
56
|
+
super({
|
|
57
|
+
message: "[Logix] Program boot failed",
|
|
58
|
+
identity,
|
|
59
|
+
entrypoint: "boot",
|
|
60
|
+
hint: "Check that options.layer / imports / providers are complete, and that no dependencies are missing during assembly."
|
|
61
|
+
});
|
|
62
|
+
this._tag = "BootError";
|
|
63
|
+
this.name = "BootError";
|
|
64
|
+
this.cause = summarizeCause(cause);
|
|
65
|
+
}
|
|
66
|
+
toJSON() {
|
|
67
|
+
return { ...super.toJSON(), cause: this.cause };
|
|
68
|
+
}
|
|
69
|
+
};
|
|
70
|
+
var MainError = class extends ProgramRunnerErrorBase {
|
|
71
|
+
constructor(identity, cause) {
|
|
72
|
+
super({
|
|
73
|
+
message: "[Logix] Program main failed",
|
|
74
|
+
identity,
|
|
75
|
+
entrypoint: "main",
|
|
76
|
+
hint: "Main failed: ensure main handles domain errors explicitly, and check for interruption or missing dependencies."
|
|
77
|
+
});
|
|
78
|
+
this._tag = "MainError";
|
|
79
|
+
this.name = "MainError";
|
|
80
|
+
this.cause = summarizeCause(cause);
|
|
81
|
+
}
|
|
82
|
+
toJSON() {
|
|
83
|
+
return { ...super.toJSON(), cause: this.cause };
|
|
84
|
+
}
|
|
85
|
+
};
|
|
86
|
+
var DisposeError = class extends ProgramRunnerErrorBase {
|
|
87
|
+
constructor(identity, cause) {
|
|
88
|
+
super({
|
|
89
|
+
message: "[Logix] Program dispose failed",
|
|
90
|
+
identity,
|
|
91
|
+
entrypoint: "dispose",
|
|
92
|
+
hint: "Dispose failed: a finalizer may have thrown, or scope/resource handles may be invalid; check onError/logs."
|
|
93
|
+
});
|
|
94
|
+
this._tag = "DisposeError";
|
|
95
|
+
this.name = "DisposeError";
|
|
96
|
+
this.cause = summarizeCause(cause);
|
|
97
|
+
}
|
|
98
|
+
toJSON() {
|
|
99
|
+
return { ...super.toJSON(), cause: this.cause };
|
|
100
|
+
}
|
|
101
|
+
};
|
|
102
|
+
var DisposeTimeoutError = class extends ProgramRunnerErrorBase {
|
|
103
|
+
constructor(identity, params) {
|
|
104
|
+
super({
|
|
105
|
+
message: "[Logix] Program dispose timed out",
|
|
106
|
+
identity,
|
|
107
|
+
entrypoint: "dispose",
|
|
108
|
+
hint: "Dispose timed out: if the program cannot exit naturally, resources may not be released or background fibers are still running."
|
|
109
|
+
});
|
|
110
|
+
this._tag = "DisposeTimeout";
|
|
111
|
+
this.name = "DisposeTimeoutError";
|
|
112
|
+
this.timeoutMs = params.timeoutMs;
|
|
113
|
+
this.elapsedMs = params.elapsedMs;
|
|
114
|
+
this.suggestions = [
|
|
115
|
+
"Check for event listeners that were not unregistered (e.g. process.on / emitter.on).",
|
|
116
|
+
"Check for fibers that were not joined/interrupt (long-lived watchers / Stream.run*).",
|
|
117
|
+
"Check for resource handles that were not closed (timer / socket / file handle)."
|
|
118
|
+
];
|
|
119
|
+
}
|
|
120
|
+
toJSON() {
|
|
121
|
+
return {
|
|
122
|
+
...super.toJSON(),
|
|
123
|
+
timeoutMs: this.timeoutMs,
|
|
124
|
+
elapsedMs: this.elapsedMs,
|
|
125
|
+
suggestions: this.suggestions
|
|
126
|
+
};
|
|
127
|
+
}
|
|
128
|
+
};
|
|
129
|
+
|
|
130
|
+
// ../logix-core/src/internal/runtime/AppRuntime.ts
|
|
131
|
+
import { Context, Deferred, Effect, Layer, ManagedRuntime } from "../effect.js";
|
|
132
|
+
var getTagKey = (tag) => {
|
|
133
|
+
const anyTag = tag;
|
|
134
|
+
if (typeof anyTag.key === "string") {
|
|
135
|
+
return anyTag.key;
|
|
136
|
+
}
|
|
137
|
+
if (typeof anyTag._id === "string") {
|
|
138
|
+
return anyTag._id;
|
|
139
|
+
}
|
|
140
|
+
if (typeof anyTag.toString === "function") {
|
|
141
|
+
return anyTag.toString();
|
|
142
|
+
}
|
|
143
|
+
return "[unknown-tag]";
|
|
144
|
+
};
|
|
145
|
+
var buildTagIndex = (entries) => {
|
|
146
|
+
const index = /* @__PURE__ */ new Map();
|
|
147
|
+
for (const entry of entries) {
|
|
148
|
+
const ownerId = String(entry.module.id);
|
|
149
|
+
const moduleTag = entry.module;
|
|
150
|
+
const moduleKey = getTagKey(moduleTag);
|
|
151
|
+
const moduleInfo = {
|
|
152
|
+
key: moduleKey,
|
|
153
|
+
tag: moduleTag,
|
|
154
|
+
ownerModuleId: ownerId,
|
|
155
|
+
source: "module"
|
|
156
|
+
};
|
|
157
|
+
const existingModuleInfos = index.get(moduleKey);
|
|
158
|
+
if (existingModuleInfos) {
|
|
159
|
+
existingModuleInfos.push(moduleInfo);
|
|
160
|
+
} else {
|
|
161
|
+
index.set(moduleKey, [moduleInfo]);
|
|
162
|
+
}
|
|
163
|
+
if (entry.serviceTags && entry.serviceTags.length > 0) {
|
|
164
|
+
for (const tag of entry.serviceTags) {
|
|
165
|
+
const key = getTagKey(tag);
|
|
166
|
+
const info = {
|
|
167
|
+
key,
|
|
168
|
+
tag,
|
|
169
|
+
ownerModuleId: ownerId,
|
|
170
|
+
source: "service"
|
|
171
|
+
};
|
|
172
|
+
const existingInfos = index.get(key);
|
|
173
|
+
if (existingInfos) {
|
|
174
|
+
existingInfos.push(info);
|
|
175
|
+
} else {
|
|
176
|
+
index.set(key, [info]);
|
|
177
|
+
}
|
|
178
|
+
}
|
|
179
|
+
}
|
|
180
|
+
}
|
|
181
|
+
return index;
|
|
182
|
+
};
|
|
183
|
+
var validateTags = (entries) => {
|
|
184
|
+
const index = buildTagIndex(entries);
|
|
185
|
+
const collisions = [];
|
|
186
|
+
for (const [key, infos] of index) {
|
|
187
|
+
if (infos.length <= 1) {
|
|
188
|
+
continue;
|
|
189
|
+
}
|
|
190
|
+
const owners = /* @__PURE__ */ new Set();
|
|
191
|
+
for (const info of infos) {
|
|
192
|
+
owners.add(info.ownerModuleId);
|
|
193
|
+
}
|
|
194
|
+
if (owners.size > 1) {
|
|
195
|
+
collisions.push({ key, conflicts: infos });
|
|
196
|
+
}
|
|
197
|
+
}
|
|
198
|
+
if (collisions.length === 0) {
|
|
199
|
+
return;
|
|
200
|
+
}
|
|
201
|
+
const message = "[Logix] Tag collision detected:\n" + collisions.map((c) => {
|
|
202
|
+
const header = `- key: ${c.key}`;
|
|
203
|
+
const lines = c.conflicts.map((i) => ` - owner: ${i.ownerModuleId}, source: ${i.source}`);
|
|
204
|
+
return [header, ...lines].join("\n");
|
|
205
|
+
}).join("\n");
|
|
206
|
+
const error = Object.assign(new Error(message), {
|
|
207
|
+
_tag: "TagCollisionError",
|
|
208
|
+
collisions
|
|
209
|
+
});
|
|
210
|
+
throw error;
|
|
211
|
+
};
|
|
212
|
+
var makeApp = (config) => {
|
|
213
|
+
const seenIds = /* @__PURE__ */ new Set();
|
|
214
|
+
for (const entry of config.modules) {
|
|
215
|
+
const id = String(entry.module.id);
|
|
216
|
+
if (seenIds.has(id)) {
|
|
217
|
+
throw new Error(
|
|
218
|
+
`[Logix] Duplicate Module ID/Tag detected: "${id}".
|
|
219
|
+
Ensure all modules in the application Runtime have unique IDs.`
|
|
220
|
+
);
|
|
221
|
+
}
|
|
222
|
+
seenIds.add(id);
|
|
223
|
+
}
|
|
224
|
+
validateTags(config.modules);
|
|
225
|
+
const stateTxnLayer = config.stateTransaction ? Layer.succeed(StateTransactionConfigTag, config.stateTransaction) : Layer.empty;
|
|
226
|
+
const concurrencyPolicyLayer = config.concurrencyPolicy ? Layer.succeed(ConcurrencyPolicyTag, config.concurrencyPolicy) : Layer.empty;
|
|
227
|
+
const readQueryStrictGateLayer = config.readQueryStrictGate ? Layer.succeed(ReadQueryStrictGateConfigTag, config.readQueryStrictGate) : Layer.empty;
|
|
228
|
+
const appModuleIds = config.modules.map((entry) => String(entry.module.id));
|
|
229
|
+
const appId = appModuleIds.length === 1 ? appModuleIds[0] : appModuleIds.slice().sort().join("~");
|
|
230
|
+
const pinnedHostSchedulerLayer = config.hostScheduler !== void 0 ? Layer.succeed(HostSchedulerTag, config.hostScheduler) : void 0;
|
|
231
|
+
const tickServicesLayer = Layer.provideMerge(pinnedHostSchedulerLayer ?? hostSchedulerLayer)(
|
|
232
|
+
Layer.provideMerge(runtimeStoreLayer)(Layer.provideMerge(declarativeLinkRuntimeLayer)(tickSchedulerLayer()))
|
|
233
|
+
);
|
|
234
|
+
const appLayer = config.layer.pipe(Layer.provide(tickServicesLayer));
|
|
235
|
+
const baseLayer = Layer.mergeAll(
|
|
236
|
+
tickServicesLayer,
|
|
237
|
+
appLayer,
|
|
238
|
+
// If a HostScheduler override is requested, pin it as the final HostSchedulerTag value to avoid accidental divergence.
|
|
239
|
+
// (Build-time capture is handled above by injecting it into tickServicesLayer.)
|
|
240
|
+
pinnedHostSchedulerLayer ?? Layer.empty,
|
|
241
|
+
stateTxnLayer,
|
|
242
|
+
concurrencyPolicyLayer,
|
|
243
|
+
readQueryStrictGateLayer,
|
|
244
|
+
layer(),
|
|
245
|
+
Layer.effect(
|
|
246
|
+
RootContextTag,
|
|
247
|
+
Effect.gen(function* () {
|
|
248
|
+
const ready = yield* Deferred.make();
|
|
249
|
+
return { context: void 0, ready, appId, appModuleIds };
|
|
250
|
+
})
|
|
251
|
+
)
|
|
252
|
+
);
|
|
253
|
+
const finalLayer = Layer.unwrapScoped(
|
|
254
|
+
Effect.gen(function* () {
|
|
255
|
+
const scope = yield* Effect.scope;
|
|
256
|
+
const [patch, env] = yield* Effect.diffFiberRefs(
|
|
257
|
+
Effect.gen(function* () {
|
|
258
|
+
const baseEnv = yield* Layer.buildWithScope(baseLayer, scope);
|
|
259
|
+
const moduleEnv = config.modules.length > 0 ? yield* Effect.provide(
|
|
260
|
+
Layer.buildWithScope(
|
|
261
|
+
config.modules.length === 1 ? config.modules[0].layer : config.modules.slice(1).reduce((acc, entry) => Layer.merge(acc, entry.layer), config.modules[0].layer),
|
|
262
|
+
scope
|
|
263
|
+
),
|
|
264
|
+
baseEnv
|
|
265
|
+
) : void 0;
|
|
266
|
+
const mergedEnv = moduleEnv ? Context.merge(baseEnv, moduleEnv) : baseEnv;
|
|
267
|
+
const rootContext = Context.get(mergedEnv, RootContextTag);
|
|
268
|
+
rootContext.context = mergedEnv;
|
|
269
|
+
yield* Deferred.succeed(rootContext.ready, mergedEnv);
|
|
270
|
+
const processRuntime = Context.get(
|
|
271
|
+
mergedEnv,
|
|
272
|
+
ProcessRuntimeTag
|
|
273
|
+
);
|
|
274
|
+
yield* Effect.forEach(
|
|
275
|
+
config.processes,
|
|
276
|
+
(process) => Effect.gen(function* () {
|
|
277
|
+
const installation = yield* Effect.provide(
|
|
278
|
+
processRuntime.install(process, {
|
|
279
|
+
scope: { type: "app", appId },
|
|
280
|
+
enabled: true,
|
|
281
|
+
installedAt: "appRuntime"
|
|
282
|
+
}),
|
|
283
|
+
mergedEnv
|
|
284
|
+
);
|
|
285
|
+
if (installation === void 0) {
|
|
286
|
+
yield* Effect.forkScoped(
|
|
287
|
+
Effect.provide(
|
|
288
|
+
config.onError ? Effect.catchAllCause(process, config.onError) : process,
|
|
289
|
+
mergedEnv
|
|
290
|
+
)
|
|
291
|
+
);
|
|
292
|
+
}
|
|
293
|
+
}),
|
|
294
|
+
{ discard: true }
|
|
295
|
+
);
|
|
296
|
+
return mergedEnv;
|
|
297
|
+
})
|
|
298
|
+
);
|
|
299
|
+
const fiberRefsLayer = Layer.scopedDiscard(Effect.patchFiberRefs(patch));
|
|
300
|
+
return Layer.mergeAll(Layer.succeedContext(env), fiberRefsLayer);
|
|
301
|
+
})
|
|
302
|
+
);
|
|
303
|
+
return {
|
|
304
|
+
definition: config,
|
|
305
|
+
layer: finalLayer,
|
|
306
|
+
makeRuntime: () => ManagedRuntime.make(finalLayer)
|
|
307
|
+
};
|
|
308
|
+
};
|
|
309
|
+
var provide = (module, resource) => {
|
|
310
|
+
const layer2 = isLayer(resource) ? resource : Layer.succeed(module, resource);
|
|
311
|
+
return { module, layer: layer2 };
|
|
312
|
+
};
|
|
313
|
+
var isLayer = (value) => typeof value === "object" && value !== null && Layer.LayerTypeId in value;
|
|
314
|
+
|
|
315
|
+
// ../logix-core/src/internal/runtime/core/runner/ProgramRunner.closeScope.ts
|
|
316
|
+
import { Cause, Effect as Effect2, Exit, Fiber, Option, Scope } from "../effect.js";
|
|
317
|
+
var closeProgramScope = (params) => {
|
|
318
|
+
return Effect2.gen(function* () {
|
|
319
|
+
const start = Date.now();
|
|
320
|
+
const hostSchedulerOpt = yield* Effect2.serviceOption(HostSchedulerTag);
|
|
321
|
+
const hostScheduler = Option.isSome(hostSchedulerOpt) ? hostSchedulerOpt.value : getGlobalHostScheduler();
|
|
322
|
+
const yieldMicrotask = Effect2.async((resume) => {
|
|
323
|
+
hostScheduler.scheduleMicrotask(() => resume(Effect2.void));
|
|
324
|
+
});
|
|
325
|
+
const fiber = yield* Effect2.forkDaemon(Scope.close(params.scope, Exit.void));
|
|
326
|
+
while (true) {
|
|
327
|
+
const exitOpt = yield* Fiber.poll(fiber);
|
|
328
|
+
if (Option.isSome(exitOpt)) {
|
|
329
|
+
const exit = exitOpt.value;
|
|
330
|
+
if (exit._tag === "Success") {
|
|
331
|
+
return;
|
|
332
|
+
}
|
|
333
|
+
return yield* Effect2.die(new DisposeError(params.identity, exit.cause));
|
|
334
|
+
}
|
|
335
|
+
const elapsedMs = Date.now() - start;
|
|
336
|
+
if (elapsedMs >= params.timeoutMs) {
|
|
337
|
+
const error = new DisposeTimeoutError(params.identity, {
|
|
338
|
+
timeoutMs: params.timeoutMs,
|
|
339
|
+
elapsedMs
|
|
340
|
+
});
|
|
341
|
+
if (typeof params.onError === "function") {
|
|
342
|
+
yield* params.onError(Cause.die(error)).pipe(Effect2.catchAllCause(() => Effect2.void));
|
|
343
|
+
}
|
|
344
|
+
yield* Fiber.interruptFork(fiber);
|
|
345
|
+
return yield* Effect2.die(error);
|
|
346
|
+
}
|
|
347
|
+
yield* yieldMicrotask;
|
|
348
|
+
}
|
|
349
|
+
});
|
|
350
|
+
};
|
|
351
|
+
|
|
352
|
+
// ../logix-core/src/internal/runtime/core/runner/ProgramRunner.signals.ts
|
|
353
|
+
import { Effect as Effect3, Exit as Exit2, Scope as Scope2 } from "../effect.js";
|
|
354
|
+
var getProcess = () => globalThis.process;
|
|
355
|
+
var isNodeProcess = (value) => typeof value === "object" && value !== null && typeof value.on === "function";
|
|
356
|
+
var removeListener = (proc, event, handler) => {
|
|
357
|
+
if (typeof proc.off === "function") {
|
|
358
|
+
proc.off(event, handler);
|
|
359
|
+
return;
|
|
360
|
+
}
|
|
361
|
+
if (typeof proc.removeListener === "function") {
|
|
362
|
+
proc.removeListener(event, handler);
|
|
363
|
+
}
|
|
364
|
+
};
|
|
365
|
+
var installGracefulShutdownHandlers = (params) => {
|
|
366
|
+
if (!params.enabled) {
|
|
367
|
+
return Effect3.void;
|
|
368
|
+
}
|
|
369
|
+
const proc = getProcess();
|
|
370
|
+
if (!isNodeProcess(proc)) {
|
|
371
|
+
return Effect3.void;
|
|
372
|
+
}
|
|
373
|
+
const handler = () => {
|
|
374
|
+
void Effect3.runPromise(Scope2.close(params.scope, Exit2.void));
|
|
375
|
+
};
|
|
376
|
+
return Effect3.gen(function* () {
|
|
377
|
+
yield* Scope2.addFinalizer(
|
|
378
|
+
params.scope,
|
|
379
|
+
Effect3.sync(() => {
|
|
380
|
+
removeListener(proc, "SIGINT", handler);
|
|
381
|
+
removeListener(proc, "SIGTERM", handler);
|
|
382
|
+
})
|
|
383
|
+
);
|
|
384
|
+
yield* Effect3.sync(() => {
|
|
385
|
+
proc.on("SIGINT", handler);
|
|
386
|
+
proc.on("SIGTERM", handler);
|
|
387
|
+
});
|
|
388
|
+
});
|
|
389
|
+
};
|
|
390
|
+
|
|
391
|
+
// ../logix-core/src/internal/runtime/core/runner/ProgramRunner.kernel.ts
|
|
392
|
+
import { Effect as Effect4, Scope as Scope3 } from "../effect.js";
|
|
393
|
+
var makeProgramRunnerKernel = (makeRuntime, rootImpl, options) => Effect4.gen(function* () {
|
|
394
|
+
const identity = {
|
|
395
|
+
moduleId: String(rootImpl.module.id),
|
|
396
|
+
instanceId: "unknown"
|
|
397
|
+
};
|
|
398
|
+
const scope = yield* Scope3.make();
|
|
399
|
+
const runtime = makeRuntime(rootImpl, options);
|
|
400
|
+
yield* Scope3.addFinalizer(scope, Effect4.promise(() => runtime.dispose()).pipe(Effect4.asVoid));
|
|
401
|
+
const setInstanceId = (value) => {
|
|
402
|
+
identity.instanceId = typeof value === "string" && value.length > 0 ? value : String(value ?? "unknown");
|
|
403
|
+
};
|
|
404
|
+
const close = (params) => closeProgramScope({
|
|
405
|
+
scope,
|
|
406
|
+
timeoutMs: params.timeoutMs,
|
|
407
|
+
identity,
|
|
408
|
+
onError: params.onError
|
|
409
|
+
});
|
|
410
|
+
const installSignals = (enabled) => installGracefulShutdownHandlers({ scope, enabled });
|
|
411
|
+
const toContext = (moduleRuntime) => ({
|
|
412
|
+
scope,
|
|
413
|
+
runtime,
|
|
414
|
+
module: moduleRuntime,
|
|
415
|
+
$: make(rootImpl.module.shape, moduleRuntime)
|
|
416
|
+
});
|
|
417
|
+
return {
|
|
418
|
+
scope,
|
|
419
|
+
runtime,
|
|
420
|
+
identity,
|
|
421
|
+
installSignals,
|
|
422
|
+
close,
|
|
423
|
+
setInstanceId,
|
|
424
|
+
toContext
|
|
425
|
+
};
|
|
426
|
+
});
|
|
427
|
+
|
|
428
|
+
export {
|
|
429
|
+
BootError,
|
|
430
|
+
MainError,
|
|
431
|
+
DisposeError,
|
|
432
|
+
DisposeTimeoutError,
|
|
433
|
+
closeProgramScope,
|
|
434
|
+
installGracefulShutdownHandlers,
|
|
435
|
+
makeProgramRunnerKernel,
|
|
436
|
+
makeApp,
|
|
437
|
+
provide
|
|
438
|
+
};
|
|
439
|
+
//# sourceMappingURL=data:application/json;base64,{
  "version": 3,
  "sources": ["../../../../logix-core/src/internal/runtime/core/runner/ProgramRunner.errors.ts", "../../../../logix-core/src/internal/runtime/AppRuntime.ts", "../../../../logix-core/src/internal/runtime/core/runner/ProgramRunner.closeScope.ts", "../../../../logix-core/src/internal/runtime/core/runner/ProgramRunner.signals.ts", "../../../../logix-core/src/internal/runtime/core/runner/ProgramRunner.kernel.ts"],
  "sourcesContent": ["export type ProgramRunnerErrorTag = 'BootError' | 'MainError' | 'DisposeError' | 'DisposeTimeout'\n\nexport interface ProgramIdentity {\n  moduleId: string\n  instanceId: string\n}\n\nconst summarizeCause = (cause: unknown): { name?: string; message?: string } => {\n  if (cause instanceof Error) {\n    return { name: cause.name, message: cause.message }\n  }\n  return { message: typeof cause === 'string' ? cause : undefined }\n}\n\nabstract class ProgramRunnerErrorBase extends Error {\n  abstract readonly _tag: ProgramRunnerErrorTag\n  readonly moduleId: string\n  readonly instanceId: string\n  readonly entrypoint: 'boot' | 'main' | 'dispose'\n  readonly hint?: string\n\n  protected constructor(params: {\n    readonly message: string\n    readonly identity: ProgramIdentity\n    readonly entrypoint: 'boot' | 'main' | 'dispose'\n    readonly hint?: string\n  }) {\n    super(params.message)\n    this.moduleId = params.identity.moduleId\n    this.instanceId = params.identity.instanceId\n    this.entrypoint = params.entrypoint\n    this.hint = params.hint\n  }\n\n  toJSON(): Record<string, unknown> {\n    return {\n      _tag: this._tag,\n      name: this.name,\n      message: this.message,\n      moduleId: this.moduleId,\n      instanceId: this.instanceId,\n      entrypoint: this.entrypoint,\n      hint: this.hint,\n    }\n  }\n}\n\nexport class BootError extends ProgramRunnerErrorBase {\n  readonly _tag = 'BootError' as const\n  readonly cause?: { name?: string; message?: string }\n\n  constructor(identity: ProgramIdentity, cause: unknown) {\n    super({\n      message: '[Logix] Program boot failed',\n      identity,\n      entrypoint: 'boot',\n      hint: 'Check that options.layer / imports / providers are complete, and that no dependencies are missing during assembly.',\n    })\n    this.name = 'BootError'\n    this.cause = summarizeCause(cause)\n  }\n\n  override toJSON(): Record<string, unknown> {\n    return { ...super.toJSON(), cause: this.cause }\n  }\n}\n\nexport class MainError extends ProgramRunnerErrorBase {\n  readonly _tag = 'MainError' as const\n  readonly cause?: { name?: string; message?: string }\n\n  constructor(identity: ProgramIdentity, cause: unknown) {\n    super({\n      message: '[Logix] Program main failed',\n      identity,\n      entrypoint: 'main',\n      hint: 'Main failed: ensure main handles domain errors explicitly, and check for interruption or missing dependencies.',\n    })\n    this.name = 'MainError'\n    this.cause = summarizeCause(cause)\n  }\n\n  override toJSON(): Record<string, unknown> {\n    return { ...super.toJSON(), cause: this.cause }\n  }\n}\n\nexport class DisposeError extends ProgramRunnerErrorBase {\n  readonly _tag = 'DisposeError' as const\n  readonly cause?: { name?: string; message?: string }\n\n  constructor(identity: ProgramIdentity, cause: unknown) {\n    super({\n      message: '[Logix] Program dispose failed',\n      identity,\n      entrypoint: 'dispose',\n      hint: 'Dispose failed: a finalizer may have thrown, or scope/resource handles may be invalid; check onError/logs.',\n    })\n    this.name = 'DisposeError'\n    this.cause = summarizeCause(cause)\n  }\n\n  override toJSON(): Record<string, unknown> {\n    return { ...super.toJSON(), cause: this.cause }\n  }\n}\n\nexport class DisposeTimeoutError extends ProgramRunnerErrorBase {\n  readonly _tag = 'DisposeTimeout' as const\n  readonly timeoutMs: number\n  readonly elapsedMs: number\n  readonly suggestions: ReadonlyArray<string>\n\n  constructor(identity: ProgramIdentity, params: { readonly timeoutMs: number; readonly elapsedMs: number }) {\n    super({\n      message: '[Logix] Program dispose timed out',\n      identity,\n      entrypoint: 'dispose',\n      hint: 'Dispose timed out: if the program cannot exit naturally, resources may not be released or background fibers are still running.',\n    })\n    this.name = 'DisposeTimeoutError'\n    this.timeoutMs = params.timeoutMs\n    this.elapsedMs = params.elapsedMs\n    this.suggestions = [\n      'Check for event listeners that were not unregistered (e.g. process.on / emitter.on).',\n      'Check for fibers that were not joined/interrupt (long-lived watchers / Stream.run*).',\n      'Check for resource handles that were not closed (timer / socket / file handle).',\n    ]\n  }\n\n  override toJSON(): Record<string, unknown> {\n    return {\n      ...super.toJSON(),\n      timeoutMs: this.timeoutMs,\n      elapsedMs: this.elapsedMs,\n      suggestions: this.suggestions,\n    }\n  }\n}\n", "import { Context, Deferred, Effect, Layer, ManagedRuntime } from 'effect'\nimport {\n  ConcurrencyPolicyTag,\n  ReadQueryStrictGateConfigTag,\n  StateTransactionConfigTag,\n  declarativeLinkRuntimeLayer,\n  hostSchedulerLayer,\n  HostSchedulerTag,\n  runtimeStoreLayer,\n  tickSchedulerLayer,\n  type ConcurrencyPolicy,\n  type ReadQueryStrictGateRuntimeConfig,\n  type StateTransactionRuntimeConfig,\n} from './core/env.js'\nimport { RootContextTag, type RootContext } from './core/RootContext.js'\nimport type { HostScheduler } from './core/HostScheduler.js'\nimport * as ProcessRuntime from './core/process/ProcessRuntime.js'\nimport type { AnyModuleShape, ModuleTag, ModuleRuntime, StateOf, ActionOf } from './core/module.js'\n\n/**\n * AppModuleEntry: a module entry produced by Logix.provide.\n *\n * - module: the Module definition object (both a Tag and a carrier of shape info + factory capability).\n * - layer: the runtime Layer for the Module.\n */\nexport interface AppModuleEntry {\n  readonly module: ModuleTag<any, any>\n  readonly layer: Layer.Layer<any, any, any>\n  /**\n   * Optional: list of Service Tags provided by this module's layer.\n   *\n   * - Used only during app assembly for tag collision detection and Env topology analysis.\n   * - Internally, AppRuntime assembly can declare this explicitly via provideWithTags.\n   * - Does not affect runtime behavior; if omitted, the module layer is treated as \"no explicit service tags declared\".\n   */\n  readonly serviceTags?: ReadonlyArray<Context.Tag<any, any>>\n}\n\nexport interface LogixAppConfig<R> {\n  readonly layer: Layer.Layer<R, never, never>\n  readonly modules: ReadonlyArray<AppModuleEntry>\n  readonly processes: ReadonlyArray<Effect.Effect<void, any, any>>\n  readonly onError?: (cause: import('effect').Cause.Cause<unknown>) => Effect.Effect<void>\n  /**\n   * Optional HostScheduler override for this Runtime.\n   *\n   * IMPORTANT:\n   * - Services like TickScheduler capture HostScheduler at Layer build-time (073).\n   * - This option injects the override into the tick services build pipeline to avoid env-override pitfalls.\n   */\n  readonly hostScheduler?: HostScheduler\n  /**\n   * Runtime-level default StateTransaction config:\n   * - If not provided, each ModuleRuntime falls back to NODE_ENV-based default instrumentation.\n   * - If instrumentation is provided, it becomes the default instrumentation for modules under this Runtime;\n   *   individual modules may still override it via ModuleImpl.stateTransaction.\n   */\n  readonly stateTransaction?: StateTransactionRuntimeConfig\n  /**\n   * Runtime-level concurrency policy:\n   * - If not provided, each entrypoint falls back to builtin defaults (e.g. concurrencyLimit=16).\n   * - If provided, it becomes the default policy for modules under this Runtime;\n   *   individual modules may still override via runtime_module/provider (merged by ModuleRuntime resolver).\n   */\n  readonly concurrencyPolicy?: ConcurrencyPolicy\n  /**\n   * ReadQuery strict gate (057):\n   * - Used in CI/perf gates to upgrade dynamic fallbacks into failures or warnings.\n   * - Not provided by default (preserve usability).\n   */\n  readonly readQueryStrictGate?: ReadQueryStrictGateRuntimeConfig\n}\n\nexport interface AppDefinition<R> {\n  readonly definition: LogixAppConfig<R>\n  readonly layer: Layer.Layer<R, never, never>\n  readonly makeRuntime: () => ManagedRuntime.ManagedRuntime<R, never>\n}\n\ninterface TagInfo {\n  readonly key: string\n  readonly tag: Context.Tag<any, any>\n  readonly ownerModuleId: string\n  readonly source: 'module' | 'service'\n}\n\ninterface TagCollision {\n  readonly key: string\n  readonly conflicts: ReadonlyArray<TagInfo>\n}\n\ninterface TagCollisionError extends Error {\n  readonly _tag: 'TagCollisionError'\n  readonly collisions: ReadonlyArray<TagCollision>\n}\n\nconst getTagKey = (tag: Context.Tag<any, any>): string => {\n  const anyTag = tag as any\n  if (typeof anyTag.key === 'string') {\n    return anyTag.key\n  }\n  if (typeof anyTag._id === 'string') {\n    return anyTag._id\n  }\n  if (typeof anyTag.toString === 'function') {\n    return anyTag.toString()\n  }\n  return '[unknown-tag]'\n}\n\nconst buildTagIndex = (entries: ReadonlyArray<AppModuleEntry>): Map<string, TagInfo[]> => {\n  const index = new Map<string, TagInfo[]>()\n\n  for (const entry of entries) {\n    const ownerId = String(entry.module.id)\n\n    // Record the Module tag itself.\n    const moduleTag = entry.module as unknown as Context.Tag<any, any>\n    const moduleKey = getTagKey(moduleTag)\n    const moduleInfo: TagInfo = {\n      key: moduleKey,\n      tag: moduleTag,\n      ownerModuleId: ownerId,\n      source: 'module',\n    }\n    const existingModuleInfos = index.get(moduleKey)\n    if (existingModuleInfos) {\n      existingModuleInfos.push(moduleInfo)\n    } else {\n      index.set(moduleKey, [moduleInfo])\n    }\n\n    // Record explicitly declared service tags (if any).\n    if (entry.serviceTags && entry.serviceTags.length > 0) {\n      for (const tag of entry.serviceTags) {\n        const key = getTagKey(tag)\n        const info: TagInfo = {\n          key,\n          tag,\n          ownerModuleId: ownerId,\n          source: 'service',\n        }\n        const existingInfos = index.get(key)\n        if (existingInfos) {\n          existingInfos.push(info)\n        } else {\n          index.set(key, [info])\n        }\n      }\n    }\n  }\n\n  return index\n}\n\nconst validateTags = (entries: ReadonlyArray<AppModuleEntry>): void => {\n  const index = buildTagIndex(entries)\n  const collisions: TagCollision[] = []\n\n  for (const [key, infos] of index) {\n    if (infos.length <= 1) {\n      continue\n    }\n    const owners = new Set<string>()\n    for (const info of infos) {\n      owners.add(info.ownerModuleId)\n    }\n    // Treat it as a collision only when the same key appears under multiple different modules.\n    // Duplicates within a single module are not considered an error (may come from multi-layer composition).\n    if (owners.size > 1) {\n      collisions.push({ key, conflicts: infos })\n    }\n  }\n\n  if (collisions.length === 0) {\n    return\n  }\n\n  const message =\n    '[Logix] Tag collision detected:\\n' +\n    collisions\n      .map((c) => {\n        const header = `- key: ${c.key}`\n        const lines = c.conflicts.map((i) => `  - owner: ${i.ownerModuleId}, source: ${i.source}`)\n        return [header, ...lines].join('\\n')\n      })\n      .join('\\n')\n\n  const error: TagCollisionError = Object.assign(new Error(message), {\n    _tag: 'TagCollisionError' as const,\n    collisions,\n  })\n\n  throw error\n}\n\nexport const makeApp = <R>(config: LogixAppConfig<R>): AppDefinition<R> => {\n  const seenIds = new Set<string>()\n  for (const entry of config.modules) {\n    const id = String(entry.module.id)\n\n    if (seenIds.has(id)) {\n      throw new Error(\n        `[Logix] Duplicate Module ID/Tag detected: \"${id}\". \\nEnsure all modules in the application Runtime have unique IDs.`,\n      )\n    }\n    seenIds.add(id)\n  }\n\n  // Validate tag collisions before merging layers.\n  // This exposes \"the same ServiceTag implemented by multiple modules\" early, avoiding silent Env overrides.\n  validateTags(config.modules)\n\n  // If the Runtime provides a unified StateTransaction config, attach the corresponding service to the app Env.\n  const stateTxnLayer: Layer.Layer<R, never, never> = config.stateTransaction\n    ? (Layer.succeed(StateTransactionConfigTag, config.stateTransaction) as Layer.Layer<R, never, never>)\n    : (Layer.empty as Layer.Layer<R, never, never>)\n\n  // If the Runtime provides a unified ConcurrencyPolicy, attach the corresponding service to the app Env.\n  const concurrencyPolicyLayer: Layer.Layer<R, never, never> = config.concurrencyPolicy\n    ? (Layer.succeed(ConcurrencyPolicyTag, config.concurrencyPolicy) as Layer.Layer<R, never, never>)\n    : (Layer.empty as Layer.Layer<R, never, never>)\n\n  // If the Runtime provides a ReadQuery strict gate, attach the corresponding service to the app Env.\n  const readQueryStrictGateLayer: Layer.Layer<R, never, never> = config.readQueryStrictGate\n    ? (Layer.succeed(ReadQueryStrictGateConfigTag, config.readQueryStrictGate) as Layer.Layer<R, never, never>)\n    : (Layer.empty as Layer.Layer<R, never, never>)\n\n  const appModuleIds = config.modules.map((entry) => String(entry.module.id))\n  const appId = appModuleIds.length === 1 ? appModuleIds[0]! : appModuleIds.slice().sort().join('~')\n\n  const pinnedHostSchedulerLayer: Layer.Layer<any, never, never> | undefined =\n    config.hostScheduler !== undefined\n      ? (Layer.succeed(HostSchedulerTag, config.hostScheduler) as Layer.Layer<any, never, never>)\n      : undefined\n\n  const tickServicesLayer = Layer.provideMerge(pinnedHostSchedulerLayer ?? hostSchedulerLayer)(\n    Layer.provideMerge(runtimeStoreLayer)(Layer.provideMerge(declarativeLinkRuntimeLayer)(tickSchedulerLayer())),\n  )\n\n  // Provide tick services as the baseline runtime env for caller layers.\n  // This allows app layers to override TickScheduler/HostScheduler while still depending on RuntimeStore/DeclarativeLinkRuntime.\n  const appLayer = (config.layer as Layer.Layer<any, never, never>).pipe(Layer.provide(tickServicesLayer))\n\n  const baseLayer = Layer.mergeAll(\n    tickServicesLayer,\n    appLayer,\n    // If a HostScheduler override is requested, pin it as the final HostSchedulerTag value to avoid accidental divergence.\n    // (Build-time capture is handled above by injecting it into tickServicesLayer.)\n    pinnedHostSchedulerLayer ?? (Layer.empty as Layer.Layer<any, never, never>),\n    stateTxnLayer,\n    concurrencyPolicyLayer,\n    readQueryStrictGateLayer,\n    ProcessRuntime.layer(),\n    Layer.effect(\n      RootContextTag,\n      Effect.gen(function* () {\n        const ready = yield* Deferred.make<Context.Context<any>>()\n        return { context: undefined, ready, appId, appModuleIds } satisfies RootContext\n      }),\n    ),\n  ) as Layer.Layer<R, never, never>\n\n  const finalLayer = Layer.unwrapScoped(\n    Effect.gen(function* () {\n      const scope = yield* Effect.scope\n\n      // buildWithScope builds layers within the current scope and patches FiberRefs (e.g. Debug sinks).\n      // We wrap it with diffFiberRefs to capture FiberRef patch changes, then feed the patch back as a Layer,\n      // so FiberRef modifications are not \"washed out\" during assembly.\n      //\n      // IMPORTANT (073):\n      // - Build baseLayer first, then build module layers under baseEnv.\n      // - Otherwise, module initialization may fork long-lived fibers (txnQueue/logics) before TickScheduler/RuntimeStore\n      //   is available, and those fibers will permanently miss the runtime services due to Env capture semantics.\n      const [patch, env] = yield* Effect.diffFiberRefs(\n        Effect.gen(function* () {\n          const baseEnv = yield* Layer.buildWithScope(baseLayer, scope)\n\n          const moduleEnv =\n            config.modules.length > 0\n              ? yield* Effect.provide(\n                  Layer.buildWithScope(\n                    config.modules.length === 1\n                      ? config.modules[0]!.layer\n                      : config.modules\n                          .slice(1)\n                          .reduce((acc, entry) => Layer.merge(acc, entry.layer), config.modules[0]!.layer),\n                    scope,\n                  ),\n                  baseEnv as Context.Context<any>,\n                )\n              : undefined\n\n          const mergedEnv = moduleEnv\n            ? (Context.merge(baseEnv as Context.Context<any>, moduleEnv as Context.Context<any>) as Context.Context<any>)\n            : (baseEnv as Context.Context<any>)\n\n          // After env is built, complete RootContext (single source of truth for the root provider).\n          // Note: module logics may already be forked and waiting for RootContext in the run phase; completing it here unblocks them.\n          // RootContextTag is an internal service injected by AppRuntime (should not leak into external R types);\n          // keep types minimal to avoid incorrect generic inference in Context.get.\n          const rootContext = Context.get(mergedEnv as Context.Context<any>, RootContextTag as any) as RootContext\n\n          rootContext.context = mergedEnv as Context.Context<any>\n          yield* Deferred.succeed(rootContext.ready, mergedEnv as Context.Context<any>)\n\n          const processRuntime = Context.get(\n            mergedEnv as Context.Context<any>,\n            ProcessRuntime.ProcessRuntimeTag as any,\n          ) as ProcessRuntime.ProcessRuntime\n\n          // After Env is fully ready, start app-level long-lived processes (Process / Link / watchers / host bridges, etc.).\n          yield* Effect.forEach(\n            config.processes,\n            (process) =>\n              Effect.gen(function* () {\n                const installation = yield* Effect.provide(\n                  processRuntime.install(process as any, {\n                    scope: { type: 'app', appId },\n                    enabled: true,\n                    installedAt: 'appRuntime',\n                  }),\n                  mergedEnv,\n                )\n\n                // Legacy fallback: a raw Effect is still allowed as a process host, but it has no Process static surface/diagnostics.\n                if (installation === undefined) {\n                  yield* Effect.forkScoped(\n                    Effect.provide(\n                      config.onError ? Effect.catchAllCause(process, config.onError) : process,\n                      mergedEnv,\n                    ),\n                  )\n                }\n              }),\n            { discard: true },\n          )\n\n          return mergedEnv\n        }),\n      )\n\n      const fiberRefsLayer = Layer.scopedDiscard(Effect.patchFiberRefs(patch))\n\n      return Layer.mergeAll(Layer.succeedContext(env), fiberRefsLayer)\n    }),\n  ) as Layer.Layer<R, never, never>\n\n  return {\n    definition: config,\n    layer: finalLayer,\n    makeRuntime: () => ManagedRuntime.make(finalLayer),\n  }\n}\n\n/**\n * Sugar: pair a Module with a runtime instance or layer for AppRuntime's modules config.\n */\nexport const provide = <Sh extends AnyModuleShape, R, E>(\n  module: ModuleTag<any, Sh>,\n  resource: Layer.Layer<ModuleRuntime<StateOf<Sh>, ActionOf<Sh>>, E, R> | ModuleRuntime<StateOf<Sh>, ActionOf<Sh>>,\n): AppModuleEntry => {\n  const layer = isLayer(resource)\n    ? resource\n    : Layer.succeed(module, resource as ModuleRuntime<StateOf<Sh>, ActionOf<Sh>>)\n\n  return { module, layer }\n}\n\n/**\n * Sugar: attach explicit ServiceTag metadata to an app module entry for tag collision detection.\n *\n * - serviceTags should include only services implemented by this module's layer.\n * - Internal-only helper: `@logixjs/core` blocks `./internal/*` in package exports, so this is not a public API surface.\n */\nexport const provideWithTags = <Sh extends AnyModuleShape, R, E>(\n  module: ModuleTag<any, Sh>,\n  resource: Layer.Layer<ModuleRuntime<StateOf<Sh>, ActionOf<Sh>>, E, R> | ModuleRuntime<StateOf<Sh>, ActionOf<Sh>>,\n  serviceTags: ReadonlyArray<Context.Tag<any, any>>,\n): AppModuleEntry => {\n  const base = provide(module, resource)\n  return {\n    ...base,\n    serviceTags,\n  }\n}\n\nconst isLayer = (value: unknown): value is Layer.Layer<any, any, any> =>\n  typeof value === 'object' && value !== null && Layer.LayerTypeId in value\n", "import { Cause, Effect, Exit, Fiber, Option, Scope } from 'effect'\nimport { getGlobalHostScheduler } from '../HostScheduler.js'\nimport { HostSchedulerTag } from '../env.js'\nimport { DisposeError, DisposeTimeoutError, type ProgramIdentity } from './ProgramRunner.errors.js'\n\nexport const closeProgramScope = (params: {\n  readonly scope: Scope.CloseableScope\n  readonly timeoutMs: number\n  readonly identity: ProgramIdentity\n  readonly onError?: (cause: Cause.Cause<unknown>) => Effect.Effect<void, never, never>\n}): Effect.Effect<void, never, never> => {\n  return Effect.gen(function* () {\n    const start = Date.now()\n    const hostSchedulerOpt = yield* Effect.serviceOption(HostSchedulerTag)\n    const hostScheduler = Option.isSome(hostSchedulerOpt) ? hostSchedulerOpt.value : getGlobalHostScheduler()\n    const yieldMicrotask = Effect.async<void, never>((resume) => {\n      hostScheduler.scheduleMicrotask(() => resume(Effect.void))\n    })\n\n    const fiber = yield* Effect.forkDaemon(Scope.close(params.scope, Exit.void))\n\n    while (true) {\n      const exitOpt = yield* Fiber.poll(fiber)\n      if (Option.isSome(exitOpt)) {\n        const exit = exitOpt.value\n        if (exit._tag === 'Success') {\n          return\n        }\n        return yield* Effect.die(new DisposeError(params.identity, exit.cause))\n      }\n\n      const elapsedMs = Date.now() - start\n      if (elapsedMs >= params.timeoutMs) {\n        const error = new DisposeTimeoutError(params.identity, {\n          timeoutMs: params.timeoutMs,\n          elapsedMs,\n        })\n\n        if (typeof params.onError === 'function') {\n          yield* params.onError(Cause.die(error)).pipe(Effect.catchAllCause(() => Effect.void))\n        }\n\n        yield* Fiber.interruptFork(fiber)\n        return yield* Effect.die(error)\n      }\n\n      // NOTE: Use a microtask yield (not TestClock-based) to avoid being blocked by TestClock,\n      // while keeping the \"successful close\" fast path cheap (perf-critical for tight loops).\n      yield* yieldMicrotask\n    }\n  })\n}\n", "import { Effect, Exit, Scope } from 'effect'\n\nconst getProcess = (): any => (globalThis as any).process\n\nconst isNodeProcess = (\n  value: unknown,\n): value is {\n  on: (event: string, handler: () => void) => void\n  off?: (event: string, handler: () => void) => void\n  removeListener?: (event: string, handler: () => void) => void\n} => typeof value === 'object' && value !== null && typeof (value as any).on === 'function'\n\nconst removeListener = (proc: any, event: string, handler: () => void): void => {\n  if (typeof proc.off === 'function') {\n    proc.off(event, handler)\n    return\n  }\n  if (typeof proc.removeListener === 'function') {\n    proc.removeListener(event, handler)\n  }\n}\n\nexport const installGracefulShutdownHandlers = (params: {\n  readonly scope: Scope.CloseableScope\n  readonly enabled: boolean\n}): Effect.Effect<void> => {\n  if (!params.enabled) {\n    return Effect.void\n  }\n\n  const proc = getProcess()\n  if (!isNodeProcess(proc)) {\n    return Effect.void\n  }\n\n  const handler = (): void => {\n    void Effect.runPromise(Scope.close(params.scope, Exit.void))\n  }\n\n  return Effect.gen(function* () {\n    yield* Scope.addFinalizer(\n      params.scope,\n      Effect.sync(() => {\n        removeListener(proc, 'SIGINT', handler)\n        removeListener(proc, 'SIGTERM', handler)\n      }),\n    )\n\n    yield* Effect.sync(() => {\n      proc.on('SIGINT', handler)\n      proc.on('SIGTERM', handler)\n    })\n  })\n}\n", "import { Effect, Scope } from 'effect'\nimport type { ManagedRuntime } from 'effect'\nimport type { AnyModuleShape, ModuleImpl } from '../module.js'\nimport { make as makeBoundApi } from '../BoundApiRuntime.js'\nimport { closeProgramScope } from './ProgramRunner.closeScope.js'\nimport type { ProgramIdentity } from './ProgramRunner.errors.js'\nimport { installGracefulShutdownHandlers } from './ProgramRunner.signals.js'\nimport type { ProgramRunContext } from './ProgramRunner.context.js'\n\nexport type RuntimeFactory = (\n  rootImpl: ModuleImpl<any, AnyModuleShape, any>,\n  options?: unknown,\n) => ManagedRuntime.ManagedRuntime<any, never>\n\nexport interface ProgramRunnerKernel<Sh extends AnyModuleShape> {\n  readonly scope: Scope.CloseableScope\n  readonly runtime: ManagedRuntime.ManagedRuntime<any, never>\n  readonly identity: ProgramIdentity\n  readonly installSignals: (enabled: boolean) => Effect.Effect<void>\n  readonly close: (params: {\n    readonly timeoutMs: number\n    readonly onError?: (cause: import('effect').Cause.Cause<unknown>) => Effect.Effect<void, never, never>\n  }) => Effect.Effect<void, never, never>\n  readonly setInstanceId: (value: unknown) => void\n  readonly toContext: (moduleRuntime: unknown) => ProgramRunContext<Sh>\n}\n\nexport const makeProgramRunnerKernel = <Sh extends AnyModuleShape>(\n  makeRuntime: RuntimeFactory,\n  rootImpl: ModuleImpl<any, Sh, any>,\n  options?: unknown,\n): Effect.Effect<ProgramRunnerKernel<Sh>> =>\n  Effect.gen(function* () {\n    const identity: ProgramIdentity = {\n      moduleId: String(rootImpl.module.id),\n      instanceId: 'unknown',\n    }\n\n    const scope = yield* Scope.make()\n    const runtime = makeRuntime(rootImpl as unknown as ModuleImpl<any, AnyModuleShape, any>, options)\n\n    yield* Scope.addFinalizer(scope, Effect.promise(() => runtime.dispose()).pipe(Effect.asVoid))\n\n    const setInstanceId = (value: unknown) => {\n      identity.instanceId = typeof value === 'string' && value.length > 0 ? value : String(value ?? 'unknown')\n    }\n\n    const close = (params: {\n      readonly timeoutMs: number\n      readonly onError?: (cause: import('effect').Cause.Cause<unknown>) => Effect.Effect<void, never, never>\n    }) =>\n      closeProgramScope({\n        scope,\n        timeoutMs: params.timeoutMs,\n        identity,\n        onError: params.onError,\n      })\n\n    const installSignals = (enabled: boolean) => installGracefulShutdownHandlers({ scope, enabled })\n\n    const toContext = (moduleRuntime: unknown) =>\n      ({\n        scope,\n        runtime,\n        module: moduleRuntime as any,\n        $: makeBoundApi(rootImpl.module.shape as any, moduleRuntime as any) as any,\n      }) satisfies ProgramRunContext<Sh>\n\n    return {\n      scope,\n      runtime,\n      identity,\n      installSignals,\n      close,\n      setInstanceId,\n      toContext,\n    }\n  })\n"],
  "mappings": "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",
  "names": ["layer", "Effect", "Effect", "Effect", "Exit", "Scope", "Effect", "Scope", "Effect", "Scope"]
}

|
|
@@ -0,0 +1,42 @@
|
|
|
1
|
+
// @logix/core subpath bundles for @logix/sandbox
|
|
2
|
+
|
|
3
|
+
import {
|
|
4
|
+
exportStaticIr
|
|
5
|
+
} from "./chunk-QGIM3FQK.js";
|
|
6
|
+
import {
|
|
7
|
+
isDevEnv
|
|
8
|
+
} from "./chunk-GP37MEGJ.js";
|
|
9
|
+
|
|
10
|
+
// ../logix-core/src/internal/debug/ModuleTraitsRegistry.ts
|
|
11
|
+
var programsByIdAndDigest = /* @__PURE__ */ new Map();
|
|
12
|
+
var latestDigestById = /* @__PURE__ */ new Map();
|
|
13
|
+
var MAX_VERSIONS_PER_MODULE = 8;
|
|
14
|
+
var registerModuleProgram = (moduleId, program) => {
|
|
15
|
+
if (!isDevEnv()) {
|
|
16
|
+
return;
|
|
17
|
+
}
|
|
18
|
+
const ir = exportStaticIr({ program, moduleId, version: "009" });
|
|
19
|
+
const digest = ir.digest;
|
|
20
|
+
let versions = programsByIdAndDigest.get(moduleId);
|
|
21
|
+
if (!versions) {
|
|
22
|
+
versions = /* @__PURE__ */ new Map();
|
|
23
|
+
programsByIdAndDigest.set(moduleId, versions);
|
|
24
|
+
}
|
|
25
|
+
versions.set(digest, program);
|
|
26
|
+
latestDigestById.set(moduleId, digest);
|
|
27
|
+
if (versions.size > MAX_VERSIONS_PER_MODULE) {
|
|
28
|
+
const oldest = versions.keys().next().value;
|
|
29
|
+
if (oldest) versions.delete(oldest);
|
|
30
|
+
}
|
|
31
|
+
};
|
|
32
|
+
var getModuleProgramById = (moduleId) => {
|
|
33
|
+
const latestDigest = latestDigestById.get(moduleId);
|
|
34
|
+
if (!latestDigest) return void 0;
|
|
35
|
+
return programsByIdAndDigest.get(moduleId)?.get(latestDigest);
|
|
36
|
+
};
|
|
37
|
+
|
|
38
|
+
export {
|
|
39
|
+
registerModuleProgram,
|
|
40
|
+
getModuleProgramById
|
|
41
|
+
};
|
|
42
|
+
//# sourceMappingURL=data:application/json;base64,ewogICJ2ZXJzaW9uIjogMywKICAic291cmNlcyI6IFsiLi4vLi4vLi4vLi4vbG9naXgtY29yZS9zcmMvaW50ZXJuYWwvZGVidWcvTW9kdWxlVHJhaXRzUmVnaXN0cnkudHMiXSwKICAic291cmNlc0NvbnRlbnQiOiBbImltcG9ydCB0eXBlIHsgU3RhdGVUcmFpdFByb2dyYW0gfSBmcm9tIFwiLi4vc3RhdGUtdHJhaXQvbW9kZWwuanNcIlxuaW1wb3J0IHsgaXNEZXZFbnYgfSBmcm9tIFwiLi4vcnVudGltZS9jb3JlL2Vudi5qc1wiXG5pbXBvcnQgeyBleHBvcnRTdGF0aWNJciB9IGZyb20gXCIuLi9zdGF0ZS10cmFpdC9pci5qc1wiXG5cbi8vIFx1NEVDNVx1NzUyOFx1NEU4RSBEZWJ1Zy9EZXZ0b29sc1x1RkYxQVx1NjMwOSBtb2R1bGVJZCBcdThCQjBcdTVGNTUgU3RhdGVUcmFpdFByb2dyYW1cdTMwMDJcbi8vIC0gXHU0RTBEXHU1M0MyXHU0RTBFXHU4RkQwXHU4ODRDXHU2NUY2XHU4ODRDXHU0RTNBXHU1MUIzXHU3QjU2XHVGRjFCXG4vLyAtIFx1OUVEOFx1OEJBNFx1NTcyOFx1NzUxRlx1NEVBN1x1NzNBRlx1NTg4M1x1NEUyRFx1NEUwRFx1NUI1OFx1NTBBOFx1NEVGQlx1NEY1NSBQcm9ncmFtXHVGRjBDXHU5MDdGXHU1MTREXHU5ODlEXHU1OTE2XHU1MTg1XHU1QjU4XHU1MzYwXHU3NTI4XHUzMDAyXG5cbmNvbnN0IHByb2dyYW1zQnlJZEFuZERpZ2VzdCA9IG5ldyBNYXA8XG4gIHN0cmluZyxcbiAgTWFwPHN0cmluZywgU3RhdGVUcmFpdFByb2dyYW08YW55Pj5cbj4oKVxuXG5jb25zdCBsYXRlc3REaWdlc3RCeUlkID0gbmV3IE1hcDxzdHJpbmcsIHN0cmluZz4oKVxuXG4vLyBEZXZ0b29scy1vbmx5XHVGRjFBXHU5MDdGXHU1MTREXHU1NzI4XHU2Nzg0XHU1RUZBL1x1NTNDRFx1NUMwNFx1OTYzNlx1NkJCNVx1OTg5MVx1N0U0MVx1NzUxRlx1NjIxMFx1NEUwRFx1NTQwQyBQcm9ncmFtIFx1NjVGNlx1NjVFMFx1NzU0Q1x1NTg5RVx1OTU3Rlx1MzAwMlxuY29uc3QgTUFYX1ZFUlNJT05TX1BFUl9NT0RVTEUgPSA4XG5cbmV4cG9ydCBjb25zdCByZWdpc3Rlck1vZHVsZVByb2dyYW0gPSAoXG4gIG1vZHVsZUlkOiBzdHJpbmcsXG4gIHByb2dyYW06IFN0YXRlVHJhaXRQcm9ncmFtPGFueT4sXG4pOiB2b2lkID0+IHtcbiAgaWYgKCFpc0RldkVudigpKSB7XG4gICAgLy8gXHU3NTFGXHU0RUE3XHU3M0FGXHU1ODgzXHU5RUQ4XHU4QkE0XHU0RTBEXHU1MDVBXHU2Q0U4XHU1MThDXHVGRjBDXHU5MDdGXHU1MTREXHU5NTdGXHU3NTFGXHU1NDdEXHU1NDY4XHU2NzFGXHU3Njg0IFByb2dyYW0gXHU3RDIyXHU1RjE1XHVGRjFCXG4gICAgLy8gXHU1OTgyXHU5NzAwXHU1NzI4XHU3NTFGXHU0RUE3XHU3M0FGXHU1ODgzXHU1NDJGXHU3NTI4IERldnRvb2xzXHVGRjBDXHU1M0VGXHU1NDBFXHU3RUVEXHU5MDFBXHU4RkM3XHU3M0FGXHU1ODgzXHU1M0Q4XHU5MUNGXHU2MjE2XHU3RjE2XHU4QkQxXHU5MTREXHU3RjZFXHU4QzAzXHU2NTc0XHU3QjU2XHU3NTY1XHUzMDAyXG4gICAgcmV0dXJuXG4gIH1cblxuICBjb25zdCBpciA9IGV4cG9ydFN0YXRpY0lyKHsgcHJvZ3JhbSwgbW9kdWxlSWQsIHZlcnNpb246IFwiMDA5XCIgfSlcbiAgY29uc3QgZGlnZXN0ID0gaXIuZGlnZXN0XG5cbiAgbGV0IHZlcnNpb25zID0gcHJvZ3JhbXNCeUlkQW5kRGlnZXN0LmdldChtb2R1bGVJZClcbiAgaWYgKCF2ZXJzaW9ucykge1xuICAgIHZlcnNpb25zID0gbmV3IE1hcCgpXG4gICAgcHJvZ3JhbXNCeUlkQW5kRGlnZXN0LnNldChtb2R1bGVJZCwgdmVyc2lvbnMpXG4gIH1cblxuICB2ZXJzaW9ucy5zZXQoZGlnZXN0LCBwcm9ncmFtKVxuICBsYXRlc3REaWdlc3RCeUlkLnNldChtb2R1bGVJZCwgZGlnZXN0KVxuXG4gIGlmICh2ZXJzaW9ucy5zaXplID4gTUFYX1ZFUlNJT05TX1BFUl9NT0RVTEUpIHtcbiAgICBjb25zdCBvbGRlc3QgPSB2ZXJzaW9ucy5rZXlzKCkubmV4dCgpLnZhbHVlIGFzIHN0cmluZyB8IHVuZGVmaW5lZFxuICAgIGlmIChvbGRlc3QpIHZlcnNpb25zLmRlbGV0ZShvbGRlc3QpXG4gIH1cbn1cblxuZXhwb3J0IGNvbnN0IGdldE1vZHVsZVByb2dyYW1CeUlkID0gKFxuICBtb2R1bGVJZDogc3RyaW5nLFxuKTogU3RhdGVUcmFpdFByb2dyYW08YW55PiB8IHVuZGVmaW5lZCA9PiB7XG4gIGNvbnN0IGxhdGVzdERpZ2VzdCA9IGxhdGVzdERpZ2VzdEJ5SWQuZ2V0KG1vZHVsZUlkKVxuICBpZiAoIWxhdGVzdERpZ2VzdCkgcmV0dXJuIHVuZGVmaW5lZFxuICByZXR1cm4gcHJvZ3JhbXNCeUlkQW5kRGlnZXN0LmdldChtb2R1bGVJZCk/LmdldChsYXRlc3REaWdlc3QpXG59XG5cbmV4cG9ydCBjb25zdCBnZXRNb2R1bGVQcm9ncmFtQnlJZEFuZERpZ2VzdCA9IChcbiAgbW9kdWxlSWQ6IHN0cmluZyxcbiAgZGlnZXN0OiBzdHJpbmcsXG4pOiBTdGF0ZVRyYWl0UHJvZ3JhbTxhbnk+IHwgdW5kZWZpbmVkID0+XG4gIHByb2dyYW1zQnlJZEFuZERpZ2VzdC5nZXQobW9kdWxlSWQpPy5nZXQoZGlnZXN0KVxuXG5leHBvcnQgY29uc3QgZ2V0TW9kdWxlUHJvZ3JhbURpZ2VzdHNCeUlkID0gKFxuICBtb2R1bGVJZDogc3RyaW5nLFxuKTogUmVhZG9ubHlBcnJheTxzdHJpbmc+ID0+XG4gIEFycmF5LmZyb20ocHJvZ3JhbXNCeUlkQW5kRGlnZXN0LmdldChtb2R1bGVJZCk/LmtleXMoKSA/PyBbXSlcbiJdLAogICJtYXBwaW5ncyI6ICI7Ozs7Ozs7Ozs7QUFRQSxJQUFNLHdCQUF3QixvQkFBSSxJQUdoQztBQUVGLElBQU0sbUJBQW1CLG9CQUFJLElBQW9CO0FBR2pELElBQU0sMEJBQTBCO0FBRXpCLElBQU0sd0JBQXdCLENBQ25DLFVBQ0EsWUFDUztBQUNULE1BQUksQ0FBQyxTQUFTLEdBQUc7QUFHZjtBQUFBLEVBQ0Y7QUFFQSxRQUFNLEtBQUssZUFBZSxFQUFFLFNBQVMsVUFBVSxTQUFTLE1BQU0sQ0FBQztBQUMvRCxRQUFNLFNBQVMsR0FBRztBQUVsQixNQUFJLFdBQVcsc0JBQXNCLElBQUksUUFBUTtBQUNqRCxNQUFJLENBQUMsVUFBVTtBQUNiLGVBQVcsb0JBQUksSUFBSTtBQUNuQiwwQkFBc0IsSUFBSSxVQUFVLFFBQVE7QUFBQSxFQUM5QztBQUVBLFdBQVMsSUFBSSxRQUFRLE9BQU87QUFDNUIsbUJBQWlCLElBQUksVUFBVSxNQUFNO0FBRXJDLE1BQUksU0FBUyxPQUFPLHlCQUF5QjtBQUMzQyxVQUFNLFNBQVMsU0FBUyxLQUFLLEVBQUUsS0FBSyxFQUFFO0FBQ3RDLFFBQUksT0FBUSxVQUFTLE9BQU8sTUFBTTtBQUFBLEVBQ3BDO0FBQ0Y7QUFFTyxJQUFNLHVCQUF1QixDQUNsQyxhQUN1QztBQUN2QyxRQUFNLGVBQWUsaUJBQWlCLElBQUksUUFBUTtBQUNsRCxNQUFJLENBQUMsYUFBYyxRQUFPO0FBQzFCLFNBQU8sc0JBQXNCLElBQUksUUFBUSxHQUFHLElBQUksWUFBWTtBQUM5RDsiLAogICJuYW1lcyI6IFtdCn0K
|
|
@@ -0,0 +1,19 @@
|
|
|
1
|
+
// @logixjs/core subpath bundles for @logixjs/sandbox
|
|
2
|
+
|
|
3
|
+
import {
|
|
4
|
+
compile,
|
|
5
|
+
isReadQuery,
|
|
6
|
+
make
|
|
7
|
+
} from "./chunk-LWI7BXFN.js";
|
|
8
|
+
|
|
9
|
+
// ../logix-core/src/ReadQuery.ts
|
|
10
|
+
var isReadQuery2 = isReadQuery;
|
|
11
|
+
var make2 = make;
|
|
12
|
+
var compile2 = compile;
|
|
13
|
+
|
|
14
|
+
export {
|
|
15
|
+
isReadQuery2 as isReadQuery,
|
|
16
|
+
make2 as make,
|
|
17
|
+
compile2 as compile
|
|
18
|
+
};
|
|
19
|
+
//# sourceMappingURL=data:application/json;base64,ewogICJ2ZXJzaW9uIjogMywKICAic291cmNlcyI6IFsiLi4vLi4vLi4vLi4vbG9naXgtY29yZS9zcmMvUmVhZFF1ZXJ5LnRzIl0sCiAgInNvdXJjZXNDb250ZW50IjogWyJpbXBvcnQgKiBhcyBSZWFkUXVlcnlDb3JlIGZyb20gJy4vaW50ZXJuYWwvcnVudGltZS9jb3JlL1JlYWRRdWVyeS5qcydcblxuZXhwb3J0IHR5cGUgUmVhZExhbmUgPSBSZWFkUXVlcnlDb3JlLlJlYWRMYW5lXG5leHBvcnQgdHlwZSBSZWFkUHJvZHVjZXIgPSBSZWFkUXVlcnlDb3JlLlJlYWRQcm9kdWNlclxuZXhwb3J0IHR5cGUgRXF1YWxzS2luZCA9IFJlYWRRdWVyeUNvcmUuRXF1YWxzS2luZFxuZXhwb3J0IHR5cGUgUmVhZHNEaWdlc3QgPSBSZWFkUXVlcnlDb3JlLlJlYWRzRGlnZXN0XG5cbmV4cG9ydCB0eXBlIFJlYWRRdWVyeVN0YXRpY0lyID0gUmVhZFF1ZXJ5Q29yZS5SZWFkUXVlcnlTdGF0aWNJclxuXG5leHBvcnQgdHlwZSBSZWFkUXVlcnk8UywgVj4gPSBSZWFkUXVlcnlDb3JlLlJlYWRRdWVyeTxTLCBWPlxuZXhwb3J0IHR5cGUgUmVhZFF1ZXJ5Q29tcGlsZWQ8UywgVj4gPSBSZWFkUXVlcnlDb3JlLlJlYWRRdWVyeUNvbXBpbGVkPFMsIFY+XG5leHBvcnQgdHlwZSBSZWFkUXVlcnlJbnB1dDxTLCBWPiA9IFJlYWRRdWVyeUNvcmUuUmVhZFF1ZXJ5SW5wdXQ8UywgVj5cblxuZXhwb3J0IGNvbnN0IGlzUmVhZFF1ZXJ5ID0gUmVhZFF1ZXJ5Q29yZS5pc1JlYWRRdWVyeVxuXG5leHBvcnQgY29uc3QgbWFrZSA9IFJlYWRRdWVyeUNvcmUubWFrZVxuXG5leHBvcnQgY29uc3QgY29tcGlsZSA9IFJlYWRRdWVyeUNvcmUuY29tcGlsZVxuIl0sCiAgIm1hcHBpbmdzIjogIjs7Ozs7Ozs7O0FBYU8sSUFBTUEsZUFBNEI7QUFFbEMsSUFBTUMsUUFBcUI7QUFFM0IsSUFBTUMsV0FBd0I7IiwKICAibmFtZXMiOiBbImlzUmVhZFF1ZXJ5IiwgIm1ha2UiLCAiY29tcGlsZSJdCn0K
|