@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,499 @@
|
|
|
1
|
+
// @logix/core subpath bundles for @logix/sandbox
|
|
2
|
+
|
|
3
|
+
import {
|
|
4
|
+
getModuleProgramById
|
|
5
|
+
} from "./chunk-6JYAC3G6.js";
|
|
6
|
+
import {
|
|
7
|
+
appendConvergeStaticIrCollectors
|
|
8
|
+
} from "./chunk-75DQFC5M.js";
|
|
9
|
+
import {
|
|
10
|
+
browserConsoleLayer,
|
|
11
|
+
clearRuntimeDebugEventSeq,
|
|
12
|
+
currentDebugSinks,
|
|
13
|
+
currentDiagnosticsLevel,
|
|
14
|
+
currentRuntimeLabel,
|
|
15
|
+
errorOnlyLayer,
|
|
16
|
+
noopLayer,
|
|
17
|
+
record,
|
|
18
|
+
toRuntimeDebugEventRef
|
|
19
|
+
} from "./chunk-CVZPRIDB.js";
|
|
20
|
+
import {
|
|
21
|
+
OBSERVABILITY_PROTOCOL_VERSION,
|
|
22
|
+
exportEvidencePackage
|
|
23
|
+
} from "./chunk-Z5L7EZXS.js";
|
|
24
|
+
import {
|
|
25
|
+
getModuleTraitsProgram,
|
|
26
|
+
getRuntimeInternals
|
|
27
|
+
} from "./chunk-6FKWRVP4.js";
|
|
28
|
+
import {
|
|
29
|
+
getNodeEnv
|
|
30
|
+
} from "./chunk-GP37MEGJ.js";
|
|
31
|
+
|
|
32
|
+
// ../logix-core/src/Debug.ts
|
|
33
|
+
import { Effect as Effect2, Layer, Logger } from "../effect.js";
|
|
34
|
+
|
|
35
|
+
// ../logix-core/src/internal/runtime/core/DevtoolsHub.ts
|
|
36
|
+
import { Effect, FiberRef } from "../effect.js";
|
|
37
|
+
var instances = /* @__PURE__ */ new Map();
|
|
38
|
+
var latestStates = /* @__PURE__ */ new Map();
|
|
39
|
+
var latestTraitSummaries = /* @__PURE__ */ new Map();
|
|
40
|
+
var instanceLabels = /* @__PURE__ */ new Map();
|
|
41
|
+
var convergeStaticIrByDigest = /* @__PURE__ */ new Map();
|
|
42
|
+
var liveInstanceKeys = /* @__PURE__ */ new Set();
|
|
43
|
+
var exportBudget = {
|
|
44
|
+
dropped: 0,
|
|
45
|
+
oversized: 0
|
|
46
|
+
};
|
|
47
|
+
var lastRunTs = 0;
|
|
48
|
+
var lastRunTsSeq = 0;
|
|
49
|
+
var nextRunId = () => {
|
|
50
|
+
const ts = Date.now();
|
|
51
|
+
if (ts === lastRunTs) {
|
|
52
|
+
lastRunTsSeq += 1;
|
|
53
|
+
} else {
|
|
54
|
+
lastRunTs = ts;
|
|
55
|
+
lastRunTsSeq = 0;
|
|
56
|
+
}
|
|
57
|
+
return lastRunTsSeq === 0 ? `run-${ts}` : `run-${ts}.${lastRunTsSeq}`;
|
|
58
|
+
};
|
|
59
|
+
var currentRunId = nextRunId();
|
|
60
|
+
var nextSeq = 1;
|
|
61
|
+
var bufferSize = 500;
|
|
62
|
+
var ringBuffer = [];
|
|
63
|
+
var ringBufferSeq = [];
|
|
64
|
+
var ensureRingBufferSize = () => {
|
|
65
|
+
if (bufferSize <= 0) {
|
|
66
|
+
ringBuffer.length = 0;
|
|
67
|
+
ringBufferSeq.length = 0;
|
|
68
|
+
return;
|
|
69
|
+
}
|
|
70
|
+
if (ringBuffer.length <= bufferSize) return;
|
|
71
|
+
const excess = ringBuffer.length - bufferSize;
|
|
72
|
+
ringBuffer.splice(0, excess);
|
|
73
|
+
ringBufferSeq.splice(0, excess);
|
|
74
|
+
};
|
|
75
|
+
var trimRingBufferIfNeeded = () => {
|
|
76
|
+
if (bufferSize <= 0) {
|
|
77
|
+
ringBuffer.length = 0;
|
|
78
|
+
ringBufferSeq.length = 0;
|
|
79
|
+
return;
|
|
80
|
+
}
|
|
81
|
+
if (bufferSize <= 64) {
|
|
82
|
+
ensureRingBufferSize();
|
|
83
|
+
return;
|
|
84
|
+
}
|
|
85
|
+
const slack = Math.min(1024, Math.floor(bufferSize / 2));
|
|
86
|
+
const threshold = bufferSize + Math.max(1, slack);
|
|
87
|
+
if (ringBuffer.length <= threshold) return;
|
|
88
|
+
const excess = ringBuffer.length - bufferSize;
|
|
89
|
+
ringBuffer.splice(0, excess);
|
|
90
|
+
ringBufferSeq.splice(0, excess);
|
|
91
|
+
};
|
|
92
|
+
var currentSnapshot = {
|
|
93
|
+
instances,
|
|
94
|
+
events: ringBuffer,
|
|
95
|
+
latestStates,
|
|
96
|
+
latestTraitSummaries,
|
|
97
|
+
exportBudget
|
|
98
|
+
};
|
|
99
|
+
var listeners = /* @__PURE__ */ new Set();
|
|
100
|
+
var notifyScheduled = false;
|
|
101
|
+
var scheduleNotify = () => {
|
|
102
|
+
if (notifyScheduled) return;
|
|
103
|
+
notifyScheduled = true;
|
|
104
|
+
queueMicrotask(() => {
|
|
105
|
+
notifyScheduled = false;
|
|
106
|
+
for (const listener of listeners) {
|
|
107
|
+
listener();
|
|
108
|
+
}
|
|
109
|
+
});
|
|
110
|
+
};
|
|
111
|
+
var devtoolsEnabled = false;
|
|
112
|
+
var configureDevtoolsHub = (options) => {
|
|
113
|
+
devtoolsEnabled = true;
|
|
114
|
+
if (typeof options?.bufferSize === "number" && Number.isFinite(options.bufferSize)) {
|
|
115
|
+
const next = Math.floor(options.bufferSize);
|
|
116
|
+
const nextBufferSize = next >= 0 ? next : 0;
|
|
117
|
+
if (nextBufferSize !== bufferSize) {
|
|
118
|
+
bufferSize = nextBufferSize;
|
|
119
|
+
ensureRingBufferSize();
|
|
120
|
+
scheduleNotify();
|
|
121
|
+
}
|
|
122
|
+
}
|
|
123
|
+
};
|
|
124
|
+
var isDevtoolsEnabled = () => devtoolsEnabled;
|
|
125
|
+
var getDevtoolsSnapshot = () => currentSnapshot;
|
|
126
|
+
var subscribeDevtoolsSnapshot = (listener) => {
|
|
127
|
+
listeners.add(listener);
|
|
128
|
+
return () => {
|
|
129
|
+
listeners.delete(listener);
|
|
130
|
+
};
|
|
131
|
+
};
|
|
132
|
+
var getDevtoolsRunId = () => currentRunId;
|
|
133
|
+
var setDevtoolsRunId = (runId) => {
|
|
134
|
+
if (typeof runId !== "string" || runId.length === 0) return;
|
|
135
|
+
currentRunId = runId;
|
|
136
|
+
};
|
|
137
|
+
var startDevtoolsRun = (runId) => {
|
|
138
|
+
currentRunId = typeof runId === "string" && runId.length > 0 ? runId : nextRunId();
|
|
139
|
+
nextSeq = 1;
|
|
140
|
+
clearRuntimeDebugEventSeq();
|
|
141
|
+
clearDevtoolsEvents();
|
|
142
|
+
return currentRunId;
|
|
143
|
+
};
|
|
144
|
+
var clearDevtoolsEvents = () => {
|
|
145
|
+
ringBuffer.length = 0;
|
|
146
|
+
ringBufferSeq.length = 0;
|
|
147
|
+
exportBudget.dropped = 0;
|
|
148
|
+
exportBudget.oversized = 0;
|
|
149
|
+
scheduleNotify();
|
|
150
|
+
};
|
|
151
|
+
var setInstanceLabel = (instanceId, label) => {
|
|
152
|
+
instanceLabels.set(instanceId, label);
|
|
153
|
+
scheduleNotify();
|
|
154
|
+
};
|
|
155
|
+
var getInstanceLabel = (instanceId) => instanceLabels.get(instanceId);
|
|
156
|
+
var registerConvergeStaticIr = (ir) => {
|
|
157
|
+
convergeStaticIrByDigest.set(ir.staticIrDigest, ir);
|
|
158
|
+
};
|
|
159
|
+
var devtoolsHubConvergeStaticIrCollector = {
|
|
160
|
+
register: registerConvergeStaticIr
|
|
161
|
+
};
|
|
162
|
+
var exportDevtoolsEvidencePackage = (options) => {
|
|
163
|
+
const protocolVersion = options?.protocolVersion ?? OBSERVABILITY_PROTOCOL_VERSION;
|
|
164
|
+
const runId = options?.runId ?? currentRunId;
|
|
165
|
+
const source = options?.source ?? { host: "unknown" };
|
|
166
|
+
const events = ringBuffer.map((payload, i) => ({
|
|
167
|
+
protocolVersion,
|
|
168
|
+
runId,
|
|
169
|
+
seq: ringBufferSeq[i] ?? i + 1,
|
|
170
|
+
timestamp: payload.timestamp,
|
|
171
|
+
type: "debug:event",
|
|
172
|
+
payload
|
|
173
|
+
}));
|
|
174
|
+
const isRecord = (value) => typeof value === "object" && value !== null && !Array.isArray(value);
|
|
175
|
+
const convergeDigests = /* @__PURE__ */ new Set();
|
|
176
|
+
let sawFullConverge = false;
|
|
177
|
+
for (const ref of ringBuffer) {
|
|
178
|
+
if (ref.kind !== "trait:converge") continue;
|
|
179
|
+
const meta = ref.meta;
|
|
180
|
+
if (!isRecord(meta)) continue;
|
|
181
|
+
const digest = meta.staticIrDigest;
|
|
182
|
+
if (typeof digest === "string" && digest.length > 0) {
|
|
183
|
+
convergeDigests.add(digest);
|
|
184
|
+
}
|
|
185
|
+
const dirty = meta.dirty;
|
|
186
|
+
if (isRecord(dirty) && typeof dirty.rootCount === "number") {
|
|
187
|
+
sawFullConverge = true;
|
|
188
|
+
}
|
|
189
|
+
}
|
|
190
|
+
let summary;
|
|
191
|
+
if (sawFullConverge && convergeDigests.size > 0) {
|
|
192
|
+
const staticIrByDigest = {};
|
|
193
|
+
for (const digest of convergeDigests) {
|
|
194
|
+
const ir = convergeStaticIrByDigest.get(digest);
|
|
195
|
+
if (ir) {
|
|
196
|
+
staticIrByDigest[digest] = ir;
|
|
197
|
+
}
|
|
198
|
+
}
|
|
199
|
+
if (Object.keys(staticIrByDigest).length > 0) {
|
|
200
|
+
summary = { converge: { staticIrByDigest } };
|
|
201
|
+
}
|
|
202
|
+
}
|
|
203
|
+
return exportEvidencePackage({
|
|
204
|
+
protocolVersion,
|
|
205
|
+
runId,
|
|
206
|
+
source,
|
|
207
|
+
events,
|
|
208
|
+
summary
|
|
209
|
+
});
|
|
210
|
+
};
|
|
211
|
+
var devtoolsHubSink = {
|
|
212
|
+
record: (event) => Effect.gen(function* () {
|
|
213
|
+
const level = yield* FiberRef.get(currentDiagnosticsLevel);
|
|
214
|
+
if (event.type === "trace:instanceLabel") {
|
|
215
|
+
const instanceId = event.instanceId;
|
|
216
|
+
const data = event.data;
|
|
217
|
+
const label = data && typeof data === "object" && "label" in data ? String(data.label) : void 0;
|
|
218
|
+
if (instanceId && label) {
|
|
219
|
+
instanceLabels.set(instanceId, label);
|
|
220
|
+
}
|
|
221
|
+
}
|
|
222
|
+
if (event.type === "module:init" || event.type === "module:destroy") {
|
|
223
|
+
const moduleId = event.moduleId ?? "unknown";
|
|
224
|
+
const runtimeLabel2 = event.runtimeLabel ?? "unknown";
|
|
225
|
+
const instanceId = event.instanceId;
|
|
226
|
+
const key = `${runtimeLabel2}::${moduleId}`;
|
|
227
|
+
const prev = instances.get(key) ?? 0;
|
|
228
|
+
if (event.type === "module:init") {
|
|
229
|
+
instances.set(key, prev + 1);
|
|
230
|
+
if (instanceId) {
|
|
231
|
+
const instanceKey = `${runtimeLabel2}::${moduleId}::${instanceId}`;
|
|
232
|
+
liveInstanceKeys.add(instanceKey);
|
|
233
|
+
latestStates.delete(instanceKey);
|
|
234
|
+
latestTraitSummaries.delete(instanceKey);
|
|
235
|
+
}
|
|
236
|
+
} else {
|
|
237
|
+
const next = prev - 1;
|
|
238
|
+
if (next <= 0) {
|
|
239
|
+
instances.delete(key);
|
|
240
|
+
} else {
|
|
241
|
+
instances.set(key, next);
|
|
242
|
+
}
|
|
243
|
+
if (instanceId) {
|
|
244
|
+
const instanceKey = `${runtimeLabel2}::${moduleId}::${instanceId}`;
|
|
245
|
+
liveInstanceKeys.delete(instanceKey);
|
|
246
|
+
latestStates.delete(instanceKey);
|
|
247
|
+
latestTraitSummaries.delete(instanceKey);
|
|
248
|
+
instanceLabels.delete(instanceId);
|
|
249
|
+
}
|
|
250
|
+
}
|
|
251
|
+
}
|
|
252
|
+
const ref = toRuntimeDebugEventRef(event, {
|
|
253
|
+
diagnosticsLevel: level,
|
|
254
|
+
onMetaProjection: ({ stats }) => {
|
|
255
|
+
exportBudget.dropped += stats.dropped;
|
|
256
|
+
exportBudget.oversized += stats.oversized;
|
|
257
|
+
}
|
|
258
|
+
});
|
|
259
|
+
if (!ref) {
|
|
260
|
+
scheduleNotify();
|
|
261
|
+
return;
|
|
262
|
+
}
|
|
263
|
+
if (ref.kind === "state" && ref.label === "state:update") {
|
|
264
|
+
const runtimeLabel2 = ref.runtimeLabel ?? "unknown";
|
|
265
|
+
const key = `${runtimeLabel2}::${ref.moduleId}::${ref.instanceId}`;
|
|
266
|
+
if (liveInstanceKeys.has(key)) {
|
|
267
|
+
if (ref.meta && typeof ref.meta === "object" && !Array.isArray(ref.meta)) {
|
|
268
|
+
const anyMeta = ref.meta;
|
|
269
|
+
if ("state" in anyMeta) {
|
|
270
|
+
latestStates.set(key, anyMeta.state);
|
|
271
|
+
}
|
|
272
|
+
if ("traitSummary" in anyMeta && anyMeta.traitSummary !== void 0) {
|
|
273
|
+
latestTraitSummaries.set(key, anyMeta.traitSummary);
|
|
274
|
+
}
|
|
275
|
+
}
|
|
276
|
+
}
|
|
277
|
+
}
|
|
278
|
+
if (bufferSize > 0) {
|
|
279
|
+
const seq = nextSeq++;
|
|
280
|
+
ringBuffer.push(ref);
|
|
281
|
+
ringBufferSeq.push(seq);
|
|
282
|
+
trimRingBufferIfNeeded();
|
|
283
|
+
}
|
|
284
|
+
scheduleNotify();
|
|
285
|
+
})
|
|
286
|
+
};
|
|
287
|
+
|
|
288
|
+
// ../logix-core/src/Debug.ts
|
|
289
|
+
var internal = {
|
|
290
|
+
currentDebugSinks,
|
|
291
|
+
currentRuntimeLabel,
|
|
292
|
+
currentDiagnosticsLevel,
|
|
293
|
+
toRuntimeDebugEventRef
|
|
294
|
+
};
|
|
295
|
+
var getDevtoolsSnapshot2 = getDevtoolsSnapshot;
|
|
296
|
+
var subscribeDevtoolsSnapshot2 = subscribeDevtoolsSnapshot;
|
|
297
|
+
var clearDevtoolsEvents2 = clearDevtoolsEvents;
|
|
298
|
+
var getDevtoolsRunId2 = getDevtoolsRunId;
|
|
299
|
+
var setDevtoolsRunId2 = setDevtoolsRunId;
|
|
300
|
+
var startDevtoolsRun2 = startDevtoolsRun;
|
|
301
|
+
var setInstanceLabel2 = setInstanceLabel;
|
|
302
|
+
var getInstanceLabel2 = getInstanceLabel;
|
|
303
|
+
var exportEvidencePackage2 = (options) => exportDevtoolsEvidencePackage(options);
|
|
304
|
+
var diagnosticsLevel = (level) => Layer.fiberRefLocallyScopedWith(
|
|
305
|
+
currentDiagnosticsLevel,
|
|
306
|
+
() => level
|
|
307
|
+
);
|
|
308
|
+
var isDevtoolsEnabled2 = isDevtoolsEnabled;
|
|
309
|
+
var makeModuleRuntimeCounterSink = () => {
|
|
310
|
+
const counts = /* @__PURE__ */ new Map();
|
|
311
|
+
const sink = {
|
|
312
|
+
record: (event) => Effect2.sync(() => {
|
|
313
|
+
if (event.type === "module:init") {
|
|
314
|
+
const moduleId = event.moduleId ?? "unknown";
|
|
315
|
+
const runtimeLabel2 = "runtimeLabel" in event && event.runtimeLabel ? event.runtimeLabel : "unknown";
|
|
316
|
+
const key = `${runtimeLabel2}::${moduleId}`;
|
|
317
|
+
const prev = counts.get(key) ?? 0;
|
|
318
|
+
counts.set(key, prev + 1);
|
|
319
|
+
return;
|
|
320
|
+
}
|
|
321
|
+
if (event.type === "module:destroy") {
|
|
322
|
+
const moduleId = event.moduleId ?? "unknown";
|
|
323
|
+
const runtimeLabel2 = "runtimeLabel" in event && event.runtimeLabel ? event.runtimeLabel : "unknown";
|
|
324
|
+
const key = `${runtimeLabel2}::${moduleId}`;
|
|
325
|
+
const prev = counts.get(key) ?? 0;
|
|
326
|
+
const next = prev - 1;
|
|
327
|
+
if (next <= 0) {
|
|
328
|
+
counts.delete(key);
|
|
329
|
+
} else {
|
|
330
|
+
counts.set(key, next);
|
|
331
|
+
}
|
|
332
|
+
}
|
|
333
|
+
})
|
|
334
|
+
};
|
|
335
|
+
const getSnapshot = () => new Map(counts);
|
|
336
|
+
return { sink, getSnapshot };
|
|
337
|
+
};
|
|
338
|
+
var makeRingBufferSink = (capacity = 1e3) => {
|
|
339
|
+
const buffer = [];
|
|
340
|
+
const sink = {
|
|
341
|
+
record: (event) => Effect2.sync(() => {
|
|
342
|
+
if (capacity <= 0) {
|
|
343
|
+
return;
|
|
344
|
+
}
|
|
345
|
+
if (buffer.length >= capacity) {
|
|
346
|
+
buffer.shift();
|
|
347
|
+
}
|
|
348
|
+
buffer.push(event);
|
|
349
|
+
})
|
|
350
|
+
};
|
|
351
|
+
const getSnapshot = () => buffer.slice();
|
|
352
|
+
const clear = () => {
|
|
353
|
+
buffer.length = 0;
|
|
354
|
+
};
|
|
355
|
+
return { sink, getSnapshot, clear };
|
|
356
|
+
};
|
|
357
|
+
var record2 = record;
|
|
358
|
+
var noopLayer2 = noopLayer;
|
|
359
|
+
var resolveMode = (mode) => {
|
|
360
|
+
if (mode && mode !== "auto") {
|
|
361
|
+
return mode;
|
|
362
|
+
}
|
|
363
|
+
const env = getNodeEnv();
|
|
364
|
+
return env === "production" ? "prod" : "dev";
|
|
365
|
+
};
|
|
366
|
+
var layer = (options) => {
|
|
367
|
+
const mode = resolveMode(options?.mode);
|
|
368
|
+
switch (mode) {
|
|
369
|
+
case "off":
|
|
370
|
+
return noopLayer;
|
|
371
|
+
case "prod":
|
|
372
|
+
return errorOnlyLayer;
|
|
373
|
+
case "dev":
|
|
374
|
+
case "auto": {
|
|
375
|
+
return browserConsoleLayer;
|
|
376
|
+
}
|
|
377
|
+
}
|
|
378
|
+
};
|
|
379
|
+
var withPrettyLogger = (base, options) => Layer.merge(
|
|
380
|
+
base,
|
|
381
|
+
Logger.replace(
|
|
382
|
+
Logger.defaultLogger,
|
|
383
|
+
Logger.prettyLogger(options)
|
|
384
|
+
)
|
|
385
|
+
);
|
|
386
|
+
var replace = (sinks) => Layer.locallyScoped(
|
|
387
|
+
internal.currentDebugSinks,
|
|
388
|
+
sinks
|
|
389
|
+
);
|
|
390
|
+
var appendSinks = (sinks) => Layer.fiberRefLocallyScopedWith(
|
|
391
|
+
currentDebugSinks,
|
|
392
|
+
(current) => [...current, ...sinks]
|
|
393
|
+
);
|
|
394
|
+
function devtoolsHubLayer(baseOrOptions, maybeOptions) {
|
|
395
|
+
const isLayerValue = (value) => typeof value === "object" && value !== null && "_op_layer" in value;
|
|
396
|
+
const hasBase = isLayerValue(baseOrOptions);
|
|
397
|
+
const base = hasBase ? baseOrOptions : Layer.empty;
|
|
398
|
+
const options = hasBase ? maybeOptions : baseOrOptions;
|
|
399
|
+
configureDevtoolsHub(options);
|
|
400
|
+
const append = appendSinks([devtoolsHubSink]);
|
|
401
|
+
const appendConvergeStaticIr = appendConvergeStaticIrCollectors([
|
|
402
|
+
devtoolsHubConvergeStaticIrCollector
|
|
403
|
+
]);
|
|
404
|
+
const enableExportableDiagnostics = diagnosticsLevel(options?.diagnosticsLevel ?? "light");
|
|
405
|
+
return Layer.provideMerge(
|
|
406
|
+
Layer.mergeAll(append, enableExportableDiagnostics, appendConvergeStaticIr),
|
|
407
|
+
base
|
|
408
|
+
);
|
|
409
|
+
}
|
|
410
|
+
var runtimeLabel = (label) => Layer.fiberRefLocallyScopedWith(
|
|
411
|
+
internal.currentRuntimeLabel,
|
|
412
|
+
() => label
|
|
413
|
+
);
|
|
414
|
+
var getModuleTraits = (module) => {
|
|
415
|
+
const moduleTag = module.tag ? module.tag : module;
|
|
416
|
+
const program = getModuleTraitsProgram(moduleTag);
|
|
417
|
+
if (!program) {
|
|
418
|
+
return {};
|
|
419
|
+
}
|
|
420
|
+
return {
|
|
421
|
+
program,
|
|
422
|
+
graph: program.graph,
|
|
423
|
+
plan: program.plan
|
|
424
|
+
};
|
|
425
|
+
};
|
|
426
|
+
var getModuleTraitsById = (moduleId) => {
|
|
427
|
+
const program = getModuleProgramById(moduleId);
|
|
428
|
+
if (!program) {
|
|
429
|
+
return void 0;
|
|
430
|
+
}
|
|
431
|
+
return {
|
|
432
|
+
program,
|
|
433
|
+
graph: program.graph,
|
|
434
|
+
plan: program.plan
|
|
435
|
+
};
|
|
436
|
+
};
|
|
437
|
+
var getModuleTraitsSnapshot = (runtime) => {
|
|
438
|
+
try {
|
|
439
|
+
const internals = getRuntimeInternals(runtime);
|
|
440
|
+
return internals.traits.getModuleTraitsSnapshot();
|
|
441
|
+
} catch {
|
|
442
|
+
return void 0;
|
|
443
|
+
}
|
|
444
|
+
};
|
|
445
|
+
var getModuleFinalTraits = (runtime) => {
|
|
446
|
+
const snapshot = getModuleTraitsSnapshot(runtime);
|
|
447
|
+
if (!snapshot) return [];
|
|
448
|
+
return snapshot.traits.map((t) => ({
|
|
449
|
+
traitId: t.traitId,
|
|
450
|
+
name: t.name,
|
|
451
|
+
description: t.description,
|
|
452
|
+
provenance: snapshot.provenanceIndex[t.traitId]
|
|
453
|
+
}));
|
|
454
|
+
};
|
|
455
|
+
var isLayer = (value) => typeof value === "object" && value !== null && "_op_layer" in value;
|
|
456
|
+
function traceLayer(baseOrHandler, maybeOnTrace) {
|
|
457
|
+
const hasBase = isLayer(baseOrHandler);
|
|
458
|
+
const base = hasBase ? baseOrHandler : Layer.empty;
|
|
459
|
+
const onTrace = hasBase ? maybeOnTrace : baseOrHandler;
|
|
460
|
+
const traceSink = {
|
|
461
|
+
record: (event) => typeof event.type === "string" && event.type.startsWith("trace:") ? onTrace ? onTrace(event) : Effect2.logDebug({ traceEvent: event }) : Effect2.void
|
|
462
|
+
};
|
|
463
|
+
const appendTrace = Layer.fiberRefLocallyScopedWith(
|
|
464
|
+
currentDebugSinks,
|
|
465
|
+
(sinks) => [...sinks, traceSink]
|
|
466
|
+
);
|
|
467
|
+
return Layer.provideMerge(appendTrace, base);
|
|
468
|
+
}
|
|
469
|
+
|
|
470
|
+
export {
|
|
471
|
+
internal,
|
|
472
|
+
getDevtoolsSnapshot2 as getDevtoolsSnapshot,
|
|
473
|
+
subscribeDevtoolsSnapshot2 as subscribeDevtoolsSnapshot,
|
|
474
|
+
clearDevtoolsEvents2 as clearDevtoolsEvents,
|
|
475
|
+
getDevtoolsRunId2 as getDevtoolsRunId,
|
|
476
|
+
setDevtoolsRunId2 as setDevtoolsRunId,
|
|
477
|
+
startDevtoolsRun2 as startDevtoolsRun,
|
|
478
|
+
setInstanceLabel2 as setInstanceLabel,
|
|
479
|
+
getInstanceLabel2 as getInstanceLabel,
|
|
480
|
+
exportEvidencePackage2 as exportEvidencePackage,
|
|
481
|
+
diagnosticsLevel,
|
|
482
|
+
isDevtoolsEnabled2 as isDevtoolsEnabled,
|
|
483
|
+
makeModuleRuntimeCounterSink,
|
|
484
|
+
makeRingBufferSink,
|
|
485
|
+
record2 as record,
|
|
486
|
+
noopLayer2 as noopLayer,
|
|
487
|
+
layer,
|
|
488
|
+
withPrettyLogger,
|
|
489
|
+
replace,
|
|
490
|
+
appendSinks,
|
|
491
|
+
devtoolsHubLayer,
|
|
492
|
+
runtimeLabel,
|
|
493
|
+
getModuleTraits,
|
|
494
|
+
getModuleTraitsById,
|
|
495
|
+
getModuleTraitsSnapshot,
|
|
496
|
+
getModuleFinalTraits,
|
|
497
|
+
traceLayer
|
|
498
|
+
};
|
|
499
|
+
//# sourceMappingURL=data:application/json;base64,{
  "version": 3,
  "sources": ["../../../../logix-core/src/Debug.ts", "../../../../logix-core/src/internal/runtime/core/DevtoolsHub.ts"],
  "sourcesContent": ["import { Effect, Layer, Logger } from \"effect\"\nimport type {\n  AnyModuleShape,\n  ModuleLike,\n  ModuleRuntime,\n  ModuleTag,\n} from \"./internal/module.js\"\nimport type {\n  StateTraitProgram,\n  StateTraitGraph,\n  StateTraitPlan,\n} from \"./StateTrait.js\"\nimport * as Internal from \"./internal/runtime/core/DebugSink.js\"\nimport * as DevtoolsHub from \"./internal/runtime/core/DevtoolsHub.js\"\nimport * as ConvergeStaticIrCollector from \"./internal/runtime/core/ConvergeStaticIrCollector.js\"\nimport * as ModuleTraitsRegistry from \"./internal/debug/ModuleTraitsRegistry.js\"\nimport type * as ModuleTraits from \"./internal/runtime/core/ModuleTraits.js\"\nimport {\n  getModuleTraitsProgram,\n  getRuntimeInternals,\n} from \"./internal/runtime/core/runtimeInternalsAccessor.js\"\nimport { getNodeEnv } from \"./internal/runtime/core/env.js\"\nimport type { EvidencePackage, EvidencePackageSource } from \"./Observability.js\"\n\n// Public Debug API\uFF1A\u4EE5\u547D\u540D\u7A7A\u95F4\u5F62\u5F0F\u6536\u53E3 Debug \u80FD\u529B\uFF0C\u4F9B\u4E1A\u52A1\u4E0E\u5E73\u53F0\u7EDF\u4E00\u4F7F\u7528\u3002\n// \u5B9E\u9645\u4E8B\u4EF6\u6A21\u578B\u4E0E Layer \u5B9A\u4E49\u96C6\u4E2D\u5728 internal/runtime/core/DebugSink.ts \u4E2D\uFF0C\n// \u8FD9\u91CC\u5728\u5176\u57FA\u7840\u4E0A\u63D0\u4F9B\u66F4\u6613\u7528\u7684\u7EC4\u5408\u5165\u53E3\u3002\n\nexport type Event = Internal.Event\nexport interface Sink extends Internal.Sink {}\nexport interface RuntimeDebugEventRef extends Internal.RuntimeDebugEventRef {}\nexport type DiagnosticsLevel = Internal.DiagnosticsLevel\n\nexport const internal = {\n  currentDebugSinks: Internal.currentDebugSinks,\n  currentRuntimeLabel: Internal.currentRuntimeLabel,\n  currentDiagnosticsLevel: Internal.currentDiagnosticsLevel,\n  toRuntimeDebugEventRef: Internal.toRuntimeDebugEventRef,\n}\n\nexport interface DevtoolsSnapshot extends DevtoolsHub.DevtoolsSnapshot {}\nexport interface DevtoolsHubOptions extends DevtoolsHub.DevtoolsHubOptions {\n  readonly diagnosticsLevel?: DiagnosticsLevel\n}\n\nexport const getDevtoolsSnapshot = DevtoolsHub.getDevtoolsSnapshot\nexport const subscribeDevtoolsSnapshot = DevtoolsHub.subscribeDevtoolsSnapshot\nexport const clearDevtoolsEvents = DevtoolsHub.clearDevtoolsEvents\nexport const getDevtoolsRunId = DevtoolsHub.getDevtoolsRunId\nexport const setDevtoolsRunId = DevtoolsHub.setDevtoolsRunId\nexport const startDevtoolsRun = DevtoolsHub.startDevtoolsRun\nexport const setInstanceLabel = DevtoolsHub.setInstanceLabel\nexport const getInstanceLabel = DevtoolsHub.getInstanceLabel\n\nexport const exportEvidencePackage = (options?: {\n  readonly runId?: string\n  readonly source?: EvidencePackageSource\n  readonly protocolVersion?: string\n}): EvidencePackage => DevtoolsHub.exportDevtoolsEvidencePackage(options)\n\n/**\n * diagnosticsLevel\uFF1A\n * - \u63A7\u5236\u201C\u53EF\u5BFC\u51FA\u4E8B\u4EF6\u201D\u7684\u751F\u6210\u4E0E\u88C1\u526A\u7B56\u7565\uFF1B\n * - \u4EC5\u5F71\u54CD DevtoolsHub\uFF08ring buffer / snapshot\uFF09\u7B49\u5BFC\u51FA\u9762\uFF0C\u4E0D\u6539\u53D8 Debug.record \u7684\u9519\u8BEF\u515C\u5E95\u8BED\u4E49\u3002\n */\nexport const diagnosticsLevel = (level: DiagnosticsLevel): Layer.Layer<any, never, never> =>\n  Layer.fiberRefLocallyScopedWith(\n    Internal.currentDiagnosticsLevel as any,\n    () => level,\n  ) as Layer.Layer<any, never, never>\n\n/**\n * isDevtoolsEnabled\uFF1A\n * - \u7528\u4E8E React/Devtools UI \u5728\u975E dev \u73AF\u5883\u4E0B\u5224\u65AD\u662F\u5426\u5E94\u542F\u7528\u989D\u5916\u89C2\u6D4B\uFF08\u5982 react-render \u4E8B\u4EF6\uFF09\u3002\n * - \u8BE5\u6807\u8BB0\u7531 devtoolsHubLayer \u6253\u5F00\uFF08\u663E\u5F0F override\uFF09\u3002\n */\nexport const isDevtoolsEnabled = DevtoolsHub.isDevtoolsEnabled\n\n/**\n * ModuleRuntimeCounter\uFF1A\n * - \u4EC5\u4F9D\u8D56 module:init / module:destroy \u4E8B\u4EF6\uFF0C\u6309 moduleId \u7EF4\u5EA6\u7EDF\u8BA1\u5F53\u524D\u6D3B\u8DC3\u5B9E\u4F8B\u6570\u91CF\uFF1B\n * - \u9002\u5408\u4F5C\u4E3A DevTools / Playground \u7684\u57FA\u7840\u6570\u636E\u6E90\uFF0C\u4E0D\u5173\u5FC3\u5177\u4F53 instanceId \u6216 React key\u3002\n */\nexport interface ModuleRuntimeCounter {\n  readonly sink: Sink\n  readonly getSnapshot: () => ReadonlyMap<string, number>\n}\n\n/**\n * RingBufferSink\uFF1A\n * - \u901A\u7528 DevTools \u8F85\u52A9\u5DE5\u5177\uFF0C\u7528\u4E8E\u5728\u5185\u5B58\u4E2D\u4FDD\u7559\u6700\u8FD1\u4E00\u6BB5 Debug \u4E8B\u4EF6\u7A97\u53E3\uFF08\u73AF\u5F62\u7F13\u51B2\u533A\uFF09\uFF1B\n * - \u4E0D\u505A\u4EFB\u4F55\u7B5B\u9009/\u5206\u7EC4\uFF0C\u8C03\u7528\u65B9\u53EF\u4EE5\u57FA\u4E8E snapshot \u518D\u6309 moduleId / type \u7B49\u7EF4\u5EA6\u52A0\u5DE5\u3002\n */\nexport interface RingBufferSink {\n  readonly sink: Sink\n  readonly getSnapshot: () => ReadonlyArray<Event>\n  readonly clear: () => void\n}\n\n/**\n * makeModuleRuntimeCounterSink\uFF1A\n * - \u6784\u9020\u4E00\u4E2A DebugSink\uFF0C\u7528\u4E8E\u5728\u5185\u5B58\u4E2D\u7D2F\u79EF\u300C\u6BCF\u4E2A moduleId \u5F53\u524D\u6709\u591A\u5C11\u6D3B\u8DC3\u5B9E\u4F8B\u300D\uFF1B\n * - Snapshot \u901A\u8FC7 getSnapshot() \u66B4\u9732\u7ED9 DevTools\uFF0C\u8C03\u7528\u65B9\u53EF\u81EA\u884C\u51B3\u5B9A\u5982\u4F55\u5BF9\u5916\u6865\u63A5\uFF08window/postMessage \u7B49\uFF09\u3002\n */\nexport const makeModuleRuntimeCounterSink = (): ModuleRuntimeCounter => {\n  const counts = new Map<string, number>()\n\n  const sink: Sink = {\n    record: (event: Event) =>\n      Effect.sync(() => {\n        if (event.type === \"module:init\") {\n          const moduleId = event.moduleId ?? \"unknown\"\n          const runtimeLabel =\n            \"runtimeLabel\" in event && event.runtimeLabel\n              ? event.runtimeLabel\n              : \"unknown\"\n          const key = `${runtimeLabel}::${moduleId}`\n          const prev = counts.get(key) ?? 0\n          counts.set(key, prev + 1)\n          return\n        }\n        if (event.type === \"module:destroy\") {\n          const moduleId = event.moduleId ?? \"unknown\"\n          const runtimeLabel =\n            \"runtimeLabel\" in event && event.runtimeLabel\n              ? event.runtimeLabel\n              : \"unknown\"\n          const key = `${runtimeLabel}::${moduleId}`\n          const prev = counts.get(key) ?? 0\n          const next = prev - 1\n          if (next <= 0) {\n            counts.delete(key)\n          } else {\n            counts.set(key, next)\n          }\n        }\n      }),\n  }\n\n  const getSnapshot = (): ReadonlyMap<string, number> =>\n    new Map(counts)\n\n  return { sink, getSnapshot }\n}\n\n/**\n * makeRingBufferSink\uFF1A\n * - \u521B\u5EFA\u4E00\u4E2A\u7B80\u5355\u7684\u73AF\u5F62\u7F13\u51B2\u533A DebugSink\uFF0C\u6309\u65F6\u95F4\u987A\u5E8F\u8BB0\u5F55\u6700\u8FD1 capacity \u6761\u4E8B\u4EF6\uFF1B\n * - \u9002\u5408\u4F5C\u4E3A DevTools / Playground \u7684\u201C\u4E8B\u4EF6\u65F6\u95F4\u7EBF\u201D\u57FA\u7840\u5B9E\u73B0\u3002\n */\nexport const makeRingBufferSink = (capacity = 1000): RingBufferSink => {\n  const buffer: Event[] = []\n\n  const sink: Sink = {\n    record: (event: Event) =>\n      Effect.sync(() => {\n        if (capacity <= 0) {\n          return\n        }\n        if (buffer.length >= capacity) {\n          buffer.shift()\n        }\n        buffer.push(event)\n      }),\n  }\n\n  const getSnapshot = (): ReadonlyArray<Event> => buffer.slice()\n  const clear = (): void => {\n    buffer.length = 0\n  }\n\n  return { sink, getSnapshot, clear }\n}\n\n/**\n * Debug.record\uFF1A\n * - \u5411\u5F53\u524D Fiber \u4E0A\u6302\u8F7D\u7684 Debug sinks \u53D1\u51FA\u4E00\u6761\u4E8B\u4EF6\uFF1B\n * - \u82E5\u5F53\u524D Fiber \u4E0A\u672A\u63D0\u4F9B\u4EFB\u4F55 sink\uFF0C\u5219\u6839\u636E\u8FD0\u884C\u73AF\u5883\u9009\u62E9\u515C\u5E95\u884C\u4E3A\n *   \uFF08\u6D4F\u89C8\u5668\u8D70\u5F69\u8272 console \u5206\u7EC4\uFF0CNode \u53EA\u4FDD\u8BC1\u9519\u8BEF\u7C7B\u4E8B\u4EF6\u4E0D\u4F1A\u5B8C\u5168\u4E22\u5931\uFF09\u3002\n */\nexport const record = Internal.record\n\n/**\n * noopLayer\uFF1A\n * - \u63D0\u4F9B\u4E00\u4E2A\u201C\u7A7A DebugSink \u96C6\u5408\u201D\uFF08\u5185\u90E8\u65E0\u4EFB\u4F55 Sink\uFF09\uFF0C\u76F4\u63A5\u4E22\u5F03\u6240\u6709 Debug \u4E8B\u4EF6\uFF1B\n * - \u4E3B\u8981\u7528\u4E8E\u6D4B\u8BD5\u573A\u666F\u6216\u663E\u5F0F\u5173\u95ED Debug \u80FD\u529B\u3002\n */\nexport const noopLayer = Internal.noopLayer as unknown as Layer.Layer<any, never, never>\n\n/**\n * DebugMode\uFF1A\n * - \"auto\"\uFF1A\u6839\u636E NODE_ENV \u81EA\u52A8\u9009\u62E9 dev / prod\uFF1B\n * - \"dev\"\uFF1A\u5F00\u53D1\u6A21\u5F0F\uFF0C\u8F93\u51FA\u5C3D\u91CF\u4E30\u5BCC\u7684\u8BCA\u65AD\u4FE1\u606F\uFF1B\n * - \"prod\"\uFF1A\u751F\u4EA7\u6A21\u5F0F\uFF0C\u53EA\u4FDD\u7559\u5173\u952E\u9519\u8BEF\u4E0E\u8BCA\u65AD\uFF1B\n * - \"off\"\uFF1A\u5B8C\u5168\u5173\u95ED DebugSink\uFF08\u901A\u5E38\u7528\u4E8E\u57FA\u51C6/\u7279\u6B8A\u6D4B\u8BD5\u573A\u666F\uFF09\u3002\n */\nexport type DebugMode = \"auto\" | \"dev\" | \"prod\" | \"off\"\n\nexport interface DebugLayerOptions {\n  readonly mode?: DebugMode\n  /**\n   * \u4E3A\u672A\u6765\u6269\u5C55\u9884\u7559\uFF1A\u5728 dev \u6A21\u5F0F\u4E0B\u662F\u5426\u6253\u5F00\u9AD8\u566A\u97F3\u7684 action/state \u7EA7\u522B\u65E5\u5FD7\u3002\n   * \u5F53\u524D\u5B9E\u73B0\u4E2D\u5C1A\u672A\u4F7F\u7528\u3002\n   */\n  readonly verboseActions?: boolean\n  /**\n   * \u4E3A\u672A\u6765\u6269\u5C55\u9884\u7559\uFF1A\u5728 prod \u6A21\u5F0F\u4E0B\u662F\u5426\u5C06\u5173\u952E\u4E8B\u4EF6\u6253\u5165 metrics\u3002\n   * \u5F53\u524D\u5B9E\u73B0\u4E2D\u5C1A\u672A\u4F7F\u7528\u3002\n   */\n  readonly enableMetrics?: boolean\n}\n\nconst resolveMode = (mode: DebugMode | undefined): DebugMode => {\n  if (mode && mode !== \"auto\") {\n    return mode\n  }\n\n  const env = getNodeEnv()\n  return env === \"production\" ? \"prod\" : \"dev\"\n}\n\n/**\n * Debug.layer\uFF1A\n * - \u5BF9\u5916\u7EDF\u4E00\u5165\u53E3\uFF0C\u6839\u636E\u5F53\u524D\u73AF\u5883\u6216\u663E\u5F0F\u4F20\u5165\u7684 mode \u7EC4\u5408\u4E00\u5957 Debug \u80FD\u529B\uFF1B\n * - \u9ED8\u8BA4 `mode: \"auto\"`\uFF1A\u975E production \u89C6\u4E3A dev\uFF0Cproduction \u89C6\u4E3A prod\u3002\n *\n * \u5178\u578B\u7528\u6CD5\uFF1A\n *\n *   const runtime = Runtime.make(AppImpl, {\n *     layer: Layer.mergeAll(\n *       Debug.layer(),\n *       businessLayer,\n *     ),\n *   })\n */\nexport const layer = (options?: DebugLayerOptions): Layer.Layer<any, never, never> => {\n  const mode = resolveMode(options?.mode)\n\n  switch (mode) {\n    case \"off\":\n      return Internal.noopLayer as unknown as Layer.Layer<any, never, never>\n    case \"prod\":\n      // \u751F\u4EA7\u73AF\u5883\uFF1A\u4EC5\u4FDD\u7559\u5173\u952E\u9519\u8BEF\u4E0E\u9AD8\u4EF7\u503C\u8BCA\u65AD\uFF0C\u907F\u514D\u9AD8\u566A\u97F3\u65E5\u5FD7\u3002\n      return Internal.errorOnlyLayer as unknown as Layer.Layer<any, never, never>\n    case \"dev\":\n    case \"auto\": {\n      // \u5F00\u53D1\u73AF\u5883\uFF1A\u9ED8\u8BA4\u4EC5\u542F\u7528 Debug Sink \u7684\u6D4F\u89C8\u5668\u53CB\u597D\u8F93\u51FA\uFF0C\n      // Logger.pretty \u7531\u8C03\u7528\u65B9\u81EA\u884C\u9009\u62E9\u662F\u5426\u53E0\u52A0\uFF0C\u907F\u514D\u9690\u5F0F\u6539\u5199 logger\u3002\n      return Internal.browserConsoleLayer as unknown as Layer.Layer<any, never, never>\n    }\n  }\n}\n\n/**\n * PrettyLoggerOptions\uFF1A\u76F4\u63A5\u590D\u7528 Effect.Logger.prettyLogger \u7684\u53C2\u6570\u5F62\u72B6\u3002\n */\nexport type PrettyLoggerOptions = Parameters<typeof Logger.prettyLogger>[0]\n\n/**\n * withPrettyLogger\uFF1A\n * - \u5728\u7ED9\u5B9A Layer \u57FA\u7840\u4E0A\uFF0C\u66FF\u6362 Effect \u9ED8\u8BA4 logger \u4E3A pretty logger\uFF1B\n * - \u7B49\u4EF7\u4E8E Logger.replace(Logger.defaultLogger, Logger.prettyLogger(options))\uFF0C\n *   \u4EE5 Layer \u5F62\u5F0F\u66B4\u9732\uFF0C\u4FBF\u4E8E\u4E0E Debug.layer / \u4E1A\u52A1 Layer \u7EC4\u5408\u3002\n */\nexport const withPrettyLogger = (\n  base: Layer.Layer<any, any, any>,\n  options?: PrettyLoggerOptions\n): Layer.Layer<any, any, any> =>\n  Layer.merge(\n    base,\n    Logger.replace(\n      Logger.defaultLogger,\n      Logger.prettyLogger(options)\n    ) as unknown as Layer.Layer<any, any, any>\n  )\n\n/**\n * replace\uFF1A\n * - \u9AD8\u7EA7\u7528\u6CD5\uFF1A\u5B8C\u5168\u4F7F\u7528\u8C03\u7528\u65B9\u63D0\u4F9B\u7684 Sink Layer \u63A5\u7BA1 Debug \u80FD\u529B\uFF1B\n * - \u901A\u5E38\u914D\u5408 Debug.makeSink / \u81EA\u5B9A\u4E49 Sink \u4F7F\u7528\uFF1B\n * - \u4E0E Debug.layer \u4E92\u65A5\uFF1A\u540C\u4E00\u4F5C\u7528\u57DF\u5185\u5EFA\u8BAE\u4E8C\u9009\u4E00\u3002\n */\nexport const replace = (sinks: ReadonlyArray<Sink>): Layer.Layer<any, never, never> =>\n  Layer.locallyScoped(\n    internal.currentDebugSinks,\n    sinks as ReadonlyArray<Internal.Sink>,\n  ) as Layer.Layer<any, never, never>\n\n/**\n * appendSinks\uFF1A\n * - \u5728\u5F53\u524D Fiber \u7684 Debug sinks \u96C6\u5408\u57FA\u7840\u4E0A\u201C\u8FFD\u52A0\u201D sinks\uFF08\u4E0D\u8986\u76D6\u8C03\u7528\u65B9\u5DF2\u6709 sinks\uFF09\uFF1B\n * - \u5178\u578B\u7528\u4E8E devtoolsHubLayer / traceLayer \u7B49\u88C5\u9970\u5668\u573A\u666F\u3002\n */\nexport const appendSinks = (sinks: ReadonlyArray<Sink>): Layer.Layer<any, never, never> =>\n  Layer.fiberRefLocallyScopedWith(\n    Internal.currentDebugSinks,\n    (current) => [...current, ...(sinks as ReadonlyArray<Internal.Sink>)],\n  ) as Layer.Layer<any, never, never>\n\n/**\n * devtoolsHubLayer\uFF1A\n * - \u8FFD\u52A0 DevtoolsHub Sink\uFF0C\u7528\u4E8E\u5728\u8FDB\u7A0B/\u9875\u9762\u5185\u805A\u5408 Debug \u4E8B\u4EF6\u5FEB\u7167\uFF08DevtoolsSnapshot\uFF09\uFF1B\n * - \u4EE5\u201C\u8FFD\u52A0 sinks\u201D\u7684\u65B9\u5F0F\u5DE5\u4F5C\uFF0C\u4E0D\u4F1A\u8986\u76D6 Debug.layer / Debug.replace / \u81EA\u5B9A\u4E49 sinks\u3002\n */\nexport function devtoolsHubLayer(options?: DevtoolsHubOptions): Layer.Layer<any, never, never>\nexport function devtoolsHubLayer(\n  base: Layer.Layer<any, any, any>,\n  options?: DevtoolsHubOptions,\n): Layer.Layer<any, never, any>\nexport function devtoolsHubLayer(\n  baseOrOptions?: Layer.Layer<any, any, any> | DevtoolsHubOptions,\n  maybeOptions?: DevtoolsHubOptions,\n): Layer.Layer<any, never, any> {\n  // Layer \u5728 effect v3 \u8FD0\u884C\u65F6\u662F\u4E00\u4E2A\u5E26 `_op_layer` \u6807\u8BB0\u7684\u5BF9\u8C61\u3002\n  const isLayerValue = (value: unknown): value is Layer.Layer<any, any, any> =>\n    typeof value === \"object\" && value !== null && \"_op_layer\" in (value as Record<string, unknown>)\n\n  const hasBase = isLayerValue(baseOrOptions)\n  const base = hasBase\n    ? (baseOrOptions as Layer.Layer<any, any, any>)\n    : (Layer.empty as unknown as Layer.Layer<any, any, any>)\n  const options = hasBase\n    ? maybeOptions\n    : (baseOrOptions as DevtoolsHubOptions | undefined)\n\n  DevtoolsHub.configureDevtoolsHub(options)\n  const append = appendSinks([DevtoolsHub.devtoolsHubSink])\n  const appendConvergeStaticIr =\n    ConvergeStaticIrCollector.appendConvergeStaticIrCollectors([\n      DevtoolsHub.devtoolsHubConvergeStaticIrCollector,\n    ])\n  const enableExportableDiagnostics = diagnosticsLevel(options?.diagnosticsLevel ?? \"light\")\n\n  // FiberRef \u5C42\u9700\u8981\u4FDD\u8BC1 base \u5148\u5EFA\u7ACB sinks\uFF0C\u518D\u7531 append \u8FFD\u52A0\uFF1BprovideMerge(append, base)\n  // \u4F1A\u5148\u6784\u5EFA base\uFF0C\u518D\u5E94\u7528 append \u7684 FiberRefs patch\uFF0C\u907F\u514D\u88AB\u8986\u76D6\u3002\n  return Layer.provideMerge(\n    Layer.mergeAll(append, enableExportableDiagnostics, appendConvergeStaticIr) as Layer.Layer<\n      any,\n      never,\n      any\n    >,\n    base,\n  ) as Layer.Layer<any, never, any>\n}\n\n/**\n * runtimeLabel\uFF1A\n * - \u5728\u5F53\u524D Fiber \u4F5C\u7528\u57DF\u5185\u4E3A Debug \u4E8B\u4EF6\u9644\u52A0\u4E00\u4E2A\u903B\u8F91 Runtime \u6807\u8BC6\uFF08\u5982 App \u540D\u79F0 / \u573A\u666F\u6807\u7B7E\uFF09\uFF1B\n * - DevTools \u53EF\u4EE5\u636E\u6B64\u5C06 Debug \u4E8B\u4EF6\u6309 Runtime \u5206\u7EC4\u5C55\u793A\u3002\n */\nexport const runtimeLabel = (label: string): Layer.Layer<any, never, never> =>\n  Layer.fiberRefLocallyScopedWith(\n    internal.currentRuntimeLabel as any,\n    () => label,\n  ) as Layer.Layer<any, never, never>\n\n/**\n * ModuleTraitsDebug\uFF1A\n * - Devtools / \u811A\u672C\u4F7F\u7528\u7684 StateTrait \u8C03\u8BD5\u89C6\u56FE\uFF1B\n * - program \u662F\u5B8C\u6574 Program\uFF0Cgraph / plan \u4E3A\u5176\u4E2D\u7684\u7ED3\u6784\u5316\u5B50\u96C6\u3002\n */\nexport interface ModuleTraitsDebug {\n  readonly program?: StateTraitProgram<any>\n  readonly graph?: StateTraitGraph\n  readonly plan?: StateTraitPlan\n}\n\n/**\n * ModuleTraitsFinalItem\uFF1A\n * - 023\uFF1A\u7528\u4E8E\u6D4B\u8BD5/\u8BCA\u65AD\u679A\u4E3E\u201C\u6700\u7EC8 traits \u6E05\u5355\u201D\uFF08\u6765\u81EA runtime \u521D\u59CB\u5316\u9636\u6BB5\u7684 finalize snapshot\uFF09\u3002\n */\nexport interface ModuleTraitsFinalItem {\n  readonly traitId: string\n  readonly name: string\n  readonly description?: string\n  readonly provenance: ModuleTraits.TraitProvenance\n}\n\n/**\n * getModuleTraits\uFF1A\n * - \u4ECE Module \u5B9A\u4E49\u5BF9\u8C61\u4E2D\u8BFB\u53D6 StateTraitProgram\uFF08\u82E5\u5B58\u5728\uFF09\uFF0C\u5E76\u8FD4\u56DE\u8C03\u8BD5\u89C6\u56FE\uFF1B\n * - \u82E5\u6A21\u5757\u672A\u4F7F\u7528 traits \u69FD\u4F4D\uFF0C\u5219\u8FD4\u56DE\u7A7A\u5BF9\u8C61\u3002\n */\nexport const getModuleTraits = (\n  module:\n    | ModuleTag<string, AnyModuleShape>\n    | ModuleLike<string, AnyModuleShape, any>,\n): ModuleTraitsDebug => {\n  const moduleTag = (module as any).tag ? (module as any).tag : module\n\n  const program = getModuleTraitsProgram(moduleTag as any) as\n    | StateTraitProgram<any>\n    | undefined\n\n  if (!program) {\n    return {}\n  }\n\n  return {\n    program,\n    graph: program.graph,\n    plan: program.plan,\n  }\n}\n\n/**\n * getModuleTraitsById\uFF1A\n * - \u6309 moduleId \u67E5\u8BE2 StateTraitProgram\uFF08\u82E5\u5DF2\u5728 Module.make \u9636\u6BB5\u6CE8\u518C\uFF09\uFF0C\u5E76\u8FD4\u56DE\u8C03\u8BD5\u89C6\u56FE\uFF1B\n * - \u7528\u4E8E Devtools \u7B49\u57FA\u4E8E Debug \u4E8B\u4EF6\uFF08\u53EA\u6709 moduleId \u5B57\u7B26\u4E32\uFF09\u7684\u573A\u666F\u3002\n */\nexport const getModuleTraitsById = (\n  moduleId: string,\n): ModuleTraitsDebug | undefined => {\n  const program = ModuleTraitsRegistry.getModuleProgramById(moduleId)\n  if (!program) {\n    return undefined\n  }\n  return {\n    program,\n    graph: program.graph,\n    plan: program.plan,\n  }\n}\n\n/**\n * getModuleTraitsSnapshot\uFF1A\n * - \u4ECE ModuleRuntime \u5B9E\u4F8B\u4E2D\u8BFB\u53D6 023 \u7684\u6700\u7EC8 traits \u5FEB\u7167\uFF08\u82E5\u5C1A\u672A finalize \u5219\u4E3A undefined\uFF09\u3002\n */\nexport const getModuleTraitsSnapshot = (\n  runtime: ModuleRuntime<any, any>,\n): ModuleTraits.ModuleTraitsSnapshot | undefined => {\n  try {\n    const internals = getRuntimeInternals(runtime as any)\n    return internals.traits.getModuleTraitsSnapshot()\n  } catch {\n    return undefined\n  }\n}\n\n/**\n * getModuleFinalTraits\uFF1A\n * - \u4ECE 023 \u7684\u6700\u7EC8 traits \u5FEB\u7167\u5BFC\u51FA\u201C\u6700\u5C0F\u53EF\u679A\u4E3E\u6E05\u5355\u201D\uFF0C\u7528\u4E8E\u6D4B\u8BD5\u4E0E\u8BCA\u65AD\u5C55\u793A\uFF1B\n * - \u8F93\u51FA\u987A\u5E8F\u4E0E snapshot \u4E00\u81F4\uFF08\u786E\u5B9A\u6027\uFF09\u3002\n */\nexport const getModuleFinalTraits = (\n  runtime: ModuleRuntime<any, any>,\n): ReadonlyArray<ModuleTraitsFinalItem> => {\n  const snapshot = getModuleTraitsSnapshot(runtime)\n  if (!snapshot) return []\n\n  return snapshot.traits.map((t) => ({\n    traitId: t.traitId,\n    name: t.name,\n    description: t.description,\n    provenance: snapshot.provenanceIndex[t.traitId]!,\n  }))\n}\n\n/**\n * traceLayer\uFF1A\n * - \u4F5C\u4E3A\u88C5\u9970\u5668\u5728\u5F53\u524D Fiber \u7684 Debug sinks \u96C6\u5408\u57FA\u7840\u4E0A\u8FFD\u52A0\u4E00\u4E2A\u4EC5\u5904\u7406 `trace:*` \u7684 Sink\uFF1B\n * - \u9ED8\u8BA4\u884C\u4E3A\u662F\u5C06 trace \u4E8B\u4EF6\u4EE5 Debug \u65E5\u5FD7\u8F93\u51FA\uFF08logDebug\uFF09\uFF0C\n *   \u8C03\u7528\u65B9\u53EF\u4EE5\u901A\u8FC7\u4F20\u5165\u81EA\u5B9A\u4E49 handler \u5C06 trace \u4E8B\u4EF6\u5199\u5165 ring buffer / DevToolsBridge \u7B49\uFF1B\n * - \u6B63\u786E\u7528\u6CD5\u793A\u4F8B\uFF1A\n *\n *   const layer = Debug.traceLayer(\n *     Debug.layer({ mode: \"dev\" }),\n *     (event) => Effect.logInfo({ traceEvent: event }),\n *   )\n */\nconst isLayer = (value: unknown): value is Layer.Layer<any, any, any> =>\n  typeof value === \"object\" && value !== null && \"_op_layer\" in (value as Record<string, unknown>)\n\nexport function traceLayer(\n  onTrace?: (event: Event) => Effect.Effect<void>,\n): Layer.Layer<any, never, never>\nexport function traceLayer(\n  base: Layer.Layer<any, any, any>,\n  onTrace?: (event: Event) => Effect.Effect<void>,\n): Layer.Layer<any, never, any>\nexport function traceLayer(\n  baseOrHandler?: Layer.Layer<any, any, any> | ((event: Event) => Effect.Effect<void>),\n  maybeOnTrace?: (event: Event) => Effect.Effect<void>,\n): Layer.Layer<any, never, any> {\n  const hasBase = isLayer(baseOrHandler)\n  const base = hasBase\n    ? (baseOrHandler as Layer.Layer<any, any, any>)\n    : (Layer.empty as unknown as Layer.Layer<any, any, any>)\n  const onTrace = hasBase ? maybeOnTrace : (baseOrHandler as ((event: Event) => Effect.Effect<void>) | undefined)\n\n  const traceSink: Sink = {\n    record: (event: Event) =>\n      typeof event.type === \"string\" && event.type.startsWith(\"trace:\")\n        ? (onTrace ? onTrace(event) : Effect.logDebug({ traceEvent: event }))\n        : Effect.void,\n  }\n\n  // \u901A\u8FC7 FiberRef \u8FFD\u52A0 trace sink\uFF1A\u5728\u5F53\u524D Fiber \u7684 sinks \u96C6\u5408\u57FA\u7840\u4E0A\u8FFD\u52A0\uFF0C\n  // \u4E0D\u518D\u4F9D\u8D56\u4EFB\u4F55 DebugHub / Tag\uFF0C\u53EA\u4F7F\u7528 FiberRef.currentDebugSinks \u4F5C\u4E3A\u5355\u4E00\u771F\u76F8\u3002\n  const appendTrace = Layer.fiberRefLocallyScopedWith(\n    Internal.currentDebugSinks,\n    (sinks) => [...sinks, traceSink],\n  )\n\n  // \u540C devtoolsHubLayer\uFF1A\u5148\u6784\u5EFA base\uFF0C\u518D\u7531 appendTrace \u8FFD\u52A0 FiberRef sinks\u3002\n  return Layer.provideMerge(appendTrace, base as Layer.Layer<any, any, any>) as Layer.Layer<any, never, any>\n}\n", "import { Effect, FiberRef } from \"effect\"\nimport type { JsonValue } from \"../../observability/jsonValue.js\"\nimport type { EvidencePackage, EvidencePackageSource } from \"../../observability/evidence.js\"\nimport { exportEvidencePackage, OBSERVABILITY_PROTOCOL_VERSION } from \"../../observability/evidence.js\"\nimport type { ConvergeStaticIrExport } from \"../../state-trait/converge-ir.js\"\nimport type { ConvergeStaticIrCollector } from \"./ConvergeStaticIrCollector.js\"\nimport {\n  currentDiagnosticsLevel,\n  clearRuntimeDebugEventSeq,\n  toRuntimeDebugEventRef,\n  type Event,\n  type RuntimeDebugEventRef,\n  type Sink,\n} from \"./DebugSink.js\"\n\n/**\n * DevtoolsHub\uFF1A\n * - \u8FDB\u7A0B/\u9875\u9762\u7EA7\u7684 Debug \u4E8B\u4EF6\u805A\u5408\u5668\uFF08\u5168\u5C40\u5355\u4F8B\uFF09\u3002\n *\n * \u6CE8\u610F\uFF1A\u8BE5 Hub \u4EC5\u5728\u663E\u5F0F\u542F\u7528 devtoolsHubLayer \u65F6\u624D\u4F1A\u88AB\u6302\u5165 Debug sinks\uFF0C\n * \u4F46 Snapshot API \u672C\u8EAB\u59CB\u7EC8\u53EF\u7528\uFF08\u672A\u542F\u7528\u65F6\u8FD4\u56DE\u7A7A\u5FEB\u7167\uFF09\u3002\n *\n * \u6027\u80FD\u8BF4\u660E\uFF1A\n * - Devtools \u7684 Debug \u4E8B\u4EF6\u5728\u9AD8\u9891\u573A\u666F\u4F1A\u975E\u5E38\u5BC6\u96C6\uFF08EffectOp / Trait / StateTxn \u7B49\uFF09\uFF1B\n * - \u65E7\u5B9E\u73B0\u4F1A\u5728\u6BCF\u6761\u4E8B\u4EF6\u5230\u6765\u65F6\u590D\u5236 ringBuffer \u4E0E Map \u6765\u6784\u9020\u201C\u4E0D\u53EF\u53D8\u5FEB\u7167\u201D\uFF0C\u6210\u672C\u4E3A O(bufferSize)\uFF1B\n * - \u5F53\u524D\u5B9E\u73B0\u6539\u4E3A\uFF1ASnapshot \u76F4\u63A5\u5F15\u7528\u5185\u90E8\u7684 Map/Array\uFF08\u53EA\u8BFB\u7EA6\u5B9A\uFF09\uFF0C\u5E76\u5728\u5FAE\u4EFB\u52A1\u4E2D\u6279\u91CF\u901A\u77E5\u8BA2\u9605\u8005\uFF1B\n *   \u8FD9\u6837\u907F\u514D per-event \u62F7\u8D1D\uFF0C\u663E\u8457\u964D\u4F4E\u5BF9\u4E1A\u52A1\u6E32\u67D3/\u8F93\u5165\u7684\u4E3B\u7EBF\u7A0B\u5E72\u6270\u3002\n */\n\nexport interface DevtoolsSnapshot {\n  readonly instances: ReadonlyMap<string, number>\n  readonly events: ReadonlyArray<RuntimeDebugEventRef>\n  readonly latestStates: ReadonlyMap<string, JsonValue>\n  readonly latestTraitSummaries: ReadonlyMap<string, JsonValue>\n  /**\n   * exportBudget\uFF1A\n   * - \u8BB0\u5F55\u5BFC\u51FA\u8FB9\u754C\uFF08JsonValue \u6295\u5F71/\u88C1\u526A\uFF09\u5E26\u6765\u7684\u201C\u964D\u7EA7\u8BA1\u6570\u201D\uFF0C\u7528\u4E8E\u89E3\u91CA\u9884\u7B97\u5F71\u54CD\uFF1B\n   * - \u8BA1\u6570\u4E3A\u7D2F\u8BA1\u503C\uFF08\u4E0E ring buffer \u7684\u7A97\u53E3\u53EF\u80FD\u4E0D\u4E00\u81F4\uFF09\uFF1B\u8C03\u7528 clearDevtoolsEvents \u4F1A\u6E05\u96F6\u3002\n   */\n  readonly exportBudget: {\n    readonly dropped: number\n    readonly oversized: number\n  }\n}\n\nexport interface DevtoolsHubOptions {\n  readonly bufferSize?: number\n}\n\n// ---- Global mutable state (singleton) ----\n\nconst instances = new Map<string, number>()\nconst latestStates = new Map<string, JsonValue>()\nconst latestTraitSummaries = new Map<string, JsonValue>()\nconst instanceLabels = new Map<string, string>()\nconst convergeStaticIrByDigest = new Map<string, ConvergeStaticIrExport>()\nconst liveInstanceKeys = new Set<string>()\n\nconst exportBudget = {\n  dropped: 0,\n  oversized: 0,\n}\n\nlet lastRunTs = 0\nlet lastRunTsSeq = 0\n\nconst nextRunId = (): string => {\n  const ts = Date.now()\n  if (ts === lastRunTs) {\n    lastRunTsSeq += 1\n  } else {\n    lastRunTs = ts\n    lastRunTsSeq = 0\n  }\n\n  return lastRunTsSeq === 0 ? `run-${ts}` : `run-${ts}.${lastRunTsSeq}`\n}\n\nlet currentRunId = nextRunId()\nlet nextSeq = 1\n\nlet bufferSize = 500\nconst ringBuffer: RuntimeDebugEventRef[] = []\nconst ringBufferSeq: number[] = []\n\nconst ensureRingBufferSize = (): void => {\n  if (bufferSize <= 0) {\n    ringBuffer.length = 0\n    ringBufferSeq.length = 0\n    return\n  }\n\n  if (ringBuffer.length <= bufferSize) return\n  const excess = ringBuffer.length - bufferSize\n  ringBuffer.splice(0, excess)\n  ringBufferSeq.splice(0, excess)\n}\n\nconst trimRingBufferIfNeeded = (): void => {\n  if (bufferSize <= 0) {\n    ringBuffer.length = 0\n    ringBufferSeq.length = 0\n    return\n  }\n\n  // \u5BF9\u5C0F\u7A97\u53E3\u4FDD\u6301\u4E25\u683C\u4E0A\u754C\uFF0C\u907F\u514D\u201C\u7A97\u53E3 size=5 \u4F46 events.length \u77ED\u65F6\u8D85\u8FC7 5\u201D\u7684\u76F4\u89C9\u504F\u5DEE\uFF1B\n  // \u5BF9\u5927\u7A97\u53E3\u91C7\u7528\u201C\u5141\u8BB8\u77ED\u65F6\u8D85\u51FA + \u6279\u91CF\u88C1\u526A\u201D\u7684\u5747\u644A\u7B56\u7565\uFF0C\u907F\u514D\u6EE1\u8F7D\u6301\u7EED shift() \u7684\u7EBF\u6027\u642C\u79FB\u3002\n  if (bufferSize <= 64) {\n    ensureRingBufferSize()\n    return\n  }\n\n  const slack = Math.min(1024, Math.floor(bufferSize / 2))\n  const threshold = bufferSize + Math.max(1, slack)\n  if (ringBuffer.length <= threshold) return\n\n  const excess = ringBuffer.length - bufferSize\n  ringBuffer.splice(0, excess)\n  ringBufferSeq.splice(0, excess)\n}\n\n// Snapshot \u76F4\u63A5\u5F15\u7528\u5185\u90E8\u7ED3\u6784\uFF08\u53EA\u8BFB\u7EA6\u5B9A\uFF09\uFF0C\u907F\u514D\u9AD8\u9891\u573A\u666F\u4E0B\u7684\u62F7\u8D1D\u6210\u672C\u3002\nconst currentSnapshot: DevtoolsSnapshot = {\n  instances,\n  events: ringBuffer,\n  latestStates,\n  latestTraitSummaries,\n  exportBudget,\n}\n\nconst listeners = new Set<() => void>()\n\nlet notifyScheduled = false\nconst scheduleNotify = () => {\n  if (notifyScheduled) return\n  notifyScheduled = true\n  queueMicrotask(() => {\n    notifyScheduled = false\n    for (const listener of listeners) {\n      listener()\n    }\n  })\n}\n\nlet devtoolsEnabled = false\n\nexport const configureDevtoolsHub = (options?: DevtoolsHubOptions) => {\n  devtoolsEnabled = true\n  if (typeof options?.bufferSize === \"number\" && Number.isFinite(options.bufferSize)) {\n    const next = Math.floor(options.bufferSize)\n    const nextBufferSize = next >= 0 ? next : 0\n    if (nextBufferSize !== bufferSize) {\n      bufferSize = nextBufferSize\n      ensureRingBufferSize()\n      scheduleNotify()\n    }\n  }\n}\n\nexport const isDevtoolsEnabled = (): boolean => devtoolsEnabled\n\n// ---- Snapshot public helpers ----\n\nexport const getDevtoolsSnapshot = (): DevtoolsSnapshot => currentSnapshot\n\nexport const subscribeDevtoolsSnapshot = (listener: () => void): (() => void) => {\n  listeners.add(listener)\n  return () => {\n    listeners.delete(listener)\n  }\n}\n\nexport const getDevtoolsRunId = (): string => currentRunId\n\nexport const setDevtoolsRunId = (runId: string): void => {\n  if (typeof runId !== \"string\" || runId.length === 0) return\n  currentRunId = runId\n}\n\nexport const startDevtoolsRun = (runId?: string): string => {\n  currentRunId = typeof runId === \"string\" && runId.length > 0 ? runId : nextRunId()\n  nextSeq = 1\n  clearRuntimeDebugEventSeq()\n  clearDevtoolsEvents()\n  return currentRunId\n}\n\nexport const clearDevtoolsEvents = (): void => {\n  ringBuffer.length = 0\n  ringBufferSeq.length = 0\n  exportBudget.dropped = 0\n  exportBudget.oversized = 0\n  scheduleNotify()\n}\n\nexport const setInstanceLabel = (instanceId: string, label: string): void => {\n  instanceLabels.set(instanceId, label)\n  scheduleNotify()\n}\n\nexport const getInstanceLabel = (instanceId: string): string | undefined =>\n  instanceLabels.get(instanceId)\n\nconst registerConvergeStaticIr = (ir: ConvergeStaticIrExport): void => {\n  convergeStaticIrByDigest.set(ir.staticIrDigest, ir)\n}\n\nexport const devtoolsHubConvergeStaticIrCollector: ConvergeStaticIrCollector = {\n  register: registerConvergeStaticIr,\n}\n\nexport const exportDevtoolsEvidencePackage = (options?: {\n  readonly runId?: string\n  readonly source?: EvidencePackageSource\n  readonly protocolVersion?: string\n}): EvidencePackage => {\n  const protocolVersion = options?.protocolVersion ?? OBSERVABILITY_PROTOCOL_VERSION\n  const runId = options?.runId ?? currentRunId\n  const source = options?.source ?? { host: \"unknown\" }\n\n  const events = ringBuffer.map((payload, i) => ({\n    protocolVersion,\n    runId,\n    seq: ringBufferSeq[i] ?? i + 1,\n    timestamp: payload.timestamp,\n    type: \"debug:event\",\n    payload: payload as unknown as JsonValue,\n  }))\n\n  const isRecord = (value: unknown): value is Record<string, unknown> =>\n    typeof value === \"object\" && value !== null && !Array.isArray(value)\n\n  // Full \u8BCA\u65AD\u4E0B\uFF1A\u6309 staticIrDigest \u53BB\u91CD\u5BFC\u51FA\u5BF9\u5E94\u7684 ConvergeStaticIR\uFF08\u4F9B\u79BB\u7EBF\u89E3\u91CA/\u56DE\u653E\uFF09\u3002\n  const convergeDigests = new Set<string>()\n  let sawFullConverge = false\n\n  for (const ref of ringBuffer) {\n    if (ref.kind !== \"trait:converge\") continue\n    const meta = ref.meta\n    if (!isRecord(meta)) continue\n\n    const digest = meta.staticIrDigest\n    if (typeof digest === \"string\" && digest.length > 0) {\n      convergeDigests.add(digest)\n    }\n\n    const dirty = meta.dirty\n    if (isRecord(dirty) && typeof dirty.rootCount === \"number\") {\n      sawFullConverge = true\n    }\n  }\n\n  let summary: JsonValue | undefined\n  if (sawFullConverge && convergeDigests.size > 0) {\n    const staticIrByDigest: Record<string, JsonValue> = {}\n    for (const digest of convergeDigests) {\n      const ir = convergeStaticIrByDigest.get(digest)\n      if (ir) {\n        staticIrByDigest[digest] = ir as unknown as JsonValue\n      }\n    }\n    if (Object.keys(staticIrByDigest).length > 0) {\n      summary = { converge: { staticIrByDigest } } as unknown as JsonValue\n    }\n  }\n\n  return exportEvidencePackage({\n    protocolVersion,\n    runId,\n    source,\n    events,\n    summary,\n  })\n}\n\n// ---- Hub Sink ----\n\nexport const devtoolsHubSink: Sink = {\n  record: (event: Event) =>\n    Effect.gen(function* () {\n      // NOTE: Hub \u662F\u5168\u5C40\u5355\u4F8B\uFF0C\u4F46\u4E8B\u4EF6\u7684\u201C\u662F\u5426\u53EF\u5BFC\u51FA/\u662F\u5426\u5199\u5165 buffer\u201D\u7531 FiberRef \u63A7\u5236\uFF0C\n      // \u4EE5\u652F\u6301\u540C\u8FDB\u7A0B\u5185\u4E0D\u540C scope \u7684\u6027\u80FD\u57FA\u7EBF/\u8BCA\u65AD\u5206\u6863\u3002\n      const level = yield* FiberRef.get(currentDiagnosticsLevel)\n\n      // trace:instanceLabel\uFF1A\u4E3A runtime \u5B9E\u4F8B\u8BBE\u7F6E\u6613\u8BFB\u540D\u79F0\u3002\n      if (event.type === \"trace:instanceLabel\") {\n        const instanceId = (event as any).instanceId as string | undefined\n        const data = (event as any).data\n        const label =\n          data && typeof data === \"object\" && \"label\" in data ? String((data as any).label) : undefined\n        if (instanceId && label) {\n          instanceLabels.set(instanceId, label)\n        }\n      }\n\n      // \u5B9E\u4F8B\u8BA1\u6570\uFF1A\u6309 runtimeLabel::moduleId \u7EF4\u5EA6\u7EF4\u62A4\u6D3B\u8DC3\u5B9E\u4F8B\u6570\u91CF\u3002\n      if (event.type === \"module:init\" || event.type === \"module:destroy\") {\n        const moduleId = (event as any).moduleId ?? \"unknown\"\n        const runtimeLabel = (event as any).runtimeLabel ?? \"unknown\"\n        const instanceId = (event as any).instanceId as string | undefined\n        const key = `${runtimeLabel}::${moduleId}`\n        const prev = instances.get(key) ?? 0\n        if (event.type === \"module:init\") {\n          instances.set(key, prev + 1)\n          if (instanceId) {\n            const instanceKey = `${runtimeLabel}::${moduleId}::${instanceId}`\n            liveInstanceKeys.add(instanceKey)\n            // \u82E5 instanceId \u88AB\u590D\u7528\uFF0C\u786E\u4FDD\u6D3E\u751F\u7F13\u5B58\u4E0D\u4F1A\u643A\u5E26\u201C\u4E0A\u4E00\u6B21\u751F\u547D\u671F\u201D\u7684\u6B8B\u7559\u3002\n            latestStates.delete(instanceKey)\n            latestTraitSummaries.delete(instanceKey)\n          }\n        } else {\n          const next = prev - 1\n          if (next <= 0) {\n            instances.delete(key)\n          } else {\n            instances.set(key, next)\n          }\n\n          if (instanceId) {\n            const instanceKey = `${runtimeLabel}::${moduleId}::${instanceId}`\n            liveInstanceKeys.delete(instanceKey)\n            latestStates.delete(instanceKey)\n            latestTraitSummaries.delete(instanceKey)\n            instanceLabels.delete(instanceId)\n          }\n        }\n      }\n\n      const ref = toRuntimeDebugEventRef(event, {\n        diagnosticsLevel: level,\n        onMetaProjection: ({ stats }) => {\n          exportBudget.dropped += stats.dropped\n          exportBudget.oversized += stats.oversized\n        },\n      })\n      if (!ref) {\n        // off \u6863\u4F4D\uFF1A\u4E0D\u5199\u5165 ring buffer / latestStates\uFF0C\u4F46\u5141\u8BB8\u7EF4\u62A4\u6700\u5C0F\u8BA1\u6570\u4E0E\u6807\u7B7E\uFF08\u542B module:destroy \u6E05\u7406\uFF09\u3002\n        scheduleNotify()\n        return\n      }\n\n      // latestStates / latestTraitSummaries\uFF1A\u6309 runtimeLabel::moduleId::instanceId \u8BB0\u5F55\u6700\u65B0\u5FEB\u7167\u3002\n      if (ref.kind === \"state\" && ref.label === \"state:update\") {\n        const runtimeLabel = ref.runtimeLabel ?? \"unknown\"\n        const key = `${runtimeLabel}::${ref.moduleId}::${ref.instanceId}`\n\n        // module:destroy \u540E\u7684\u8FDF\u5230/\u91CD\u653E\u4E8B\u4EF6\uFF1A\u5141\u8BB8\u8FDB\u5165\u7A97\u53E3\u7528\u4E8E\u56DE\u653E\uFF0C\u4F46\u4E0D\u5F97\u91CD\u5EFA latest* \u6D3E\u751F\u7F13\u5B58\u3002\n        if (liveInstanceKeys.has(key)) {\n          if (ref.meta && typeof ref.meta === \"object\" && !Array.isArray(ref.meta)) {\n            const anyMeta = ref.meta as any\n            if (\"state\" in anyMeta) {\n              latestStates.set(key, anyMeta.state as JsonValue)\n            }\n            if (\"traitSummary\" in anyMeta && anyMeta.traitSummary !== undefined) {\n              latestTraitSummaries.set(key, anyMeta.traitSummary as JsonValue)\n            }\n          }\n        }\n      }\n\n      // ring buffer\uFF1A\u4FDD\u7559\u6700\u8FD1 bufferSize \u6761 RuntimeDebugEventRef\u3002\n      if (bufferSize > 0) {\n        const seq = nextSeq++\n        ringBuffer.push(ref)\n        ringBufferSeq.push(seq)\n        trimRingBufferIfNeeded()\n      }\n\n      scheduleNotify()\n    }),\n}\n"],
  "mappings": ";;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;AAAA,SAAS,UAAAA,SAAQ,OAAO,cAAc;;;ACAtC,SAAS,QAAQ,gBAAgB;AAmDjC,IAAM,YAAY,oBAAI,IAAoB;AAC1C,IAAM,eAAe,oBAAI,IAAuB;AAChD,IAAM,uBAAuB,oBAAI,IAAuB;AACxD,IAAM,iBAAiB,oBAAI,IAAoB;AAC/C,IAAM,2BAA2B,oBAAI,IAAoC;AACzE,IAAM,mBAAmB,oBAAI,IAAY;AAEzC,IAAM,eAAe;AAAA,EACnB,SAAS;AAAA,EACT,WAAW;AACb;AAEA,IAAI,YAAY;AAChB,IAAI,eAAe;AAEnB,IAAM,YAAY,MAAc;AAC9B,QAAM,KAAK,KAAK,IAAI;AACpB,MAAI,OAAO,WAAW;AACpB,oBAAgB;AAAA,EAClB,OAAO;AACL,gBAAY;AACZ,mBAAe;AAAA,EACjB;AAEA,SAAO,iBAAiB,IAAI,OAAO,EAAE,KAAK,OAAO,EAAE,IAAI,YAAY;AACrE;AAEA,IAAI,eAAe,UAAU;AAC7B,IAAI,UAAU;AAEd,IAAI,aAAa;AACjB,IAAM,aAAqC,CAAC;AAC5C,IAAM,gBAA0B,CAAC;AAEjC,IAAM,uBAAuB,MAAY;AACvC,MAAI,cAAc,GAAG;AACnB,eAAW,SAAS;AACpB,kBAAc,SAAS;AACvB;AAAA,EACF;AAEA,MAAI,WAAW,UAAU,WAAY;AACrC,QAAM,SAAS,WAAW,SAAS;AACnC,aAAW,OAAO,GAAG,MAAM;AAC3B,gBAAc,OAAO,GAAG,MAAM;AAChC;AAEA,IAAM,yBAAyB,MAAY;AACzC,MAAI,cAAc,GAAG;AACnB,eAAW,SAAS;AACpB,kBAAc,SAAS;AACvB;AAAA,EACF;AAIA,MAAI,cAAc,IAAI;AACpB,yBAAqB;AACrB;AAAA,EACF;AAEA,QAAM,QAAQ,KAAK,IAAI,MAAM,KAAK,MAAM,aAAa,CAAC,CAAC;AACvD,QAAM,YAAY,aAAa,KAAK,IAAI,GAAG,KAAK;AAChD,MAAI,WAAW,UAAU,UAAW;AAEpC,QAAM,SAAS,WAAW,SAAS;AACnC,aAAW,OAAO,GAAG,MAAM;AAC3B,gBAAc,OAAO,GAAG,MAAM;AAChC;AAGA,IAAM,kBAAoC;AAAA,EACxC;AAAA,EACA,QAAQ;AAAA,EACR;AAAA,EACA;AAAA,EACA;AACF;AAEA,IAAM,YAAY,oBAAI,IAAgB;AAEtC,IAAI,kBAAkB;AACtB,IAAM,iBAAiB,MAAM;AAC3B,MAAI,gBAAiB;AACrB,oBAAkB;AAClB,iBAAe,MAAM;AACnB,sBAAkB;AAClB,eAAW,YAAY,WAAW;AAChC,eAAS;AAAA,IACX;AAAA,EACF,CAAC;AACH;AAEA,IAAI,kBAAkB;AAEf,IAAM,uBAAuB,CAAC,YAAiC;AACpE,oBAAkB;AAClB,MAAI,OAAO,SAAS,eAAe,YAAY,OAAO,SAAS,QAAQ,UAAU,GAAG;AAClF,UAAM,OAAO,KAAK,MAAM,QAAQ,UAAU;AAC1C,UAAM,iBAAiB,QAAQ,IAAI,OAAO;AAC1C,QAAI,mBAAmB,YAAY;AACjC,mBAAa;AACb,2BAAqB;AACrB,qBAAe;AAAA,IACjB;AAAA,EACF;AACF;AAEO,IAAM,oBAAoB,MAAe;AAIzC,IAAM,sBAAsB,MAAwB;AAEpD,IAAM,4BAA4B,CAAC,aAAuC;AAC/E,YAAU,IAAI,QAAQ;AACtB,SAAO,MAAM;AACX,cAAU,OAAO,QAAQ;AAAA,EAC3B;AACF;AAEO,IAAM,mBAAmB,MAAc;AAEvC,IAAM,mBAAmB,CAAC,UAAwB;AACvD,MAAI,OAAO,UAAU,YAAY,MAAM,WAAW,EAAG;AACrD,iBAAe;AACjB;AAEO,IAAM,mBAAmB,CAAC,UAA2B;AAC1D,iBAAe,OAAO,UAAU,YAAY,MAAM,SAAS,IAAI,QAAQ,UAAU;AACjF,YAAU;AACV,4BAA0B;AAC1B,sBAAoB;AACpB,SAAO;AACT;AAEO,IAAM,sBAAsB,MAAY;AAC7C,aAAW,SAAS;AACpB,gBAAc,SAAS;AACvB,eAAa,UAAU;AACvB,eAAa,YAAY;AACzB,iBAAe;AACjB;AAEO,IAAM,mBAAmB,CAAC,YAAoB,UAAwB;AAC3E,iBAAe,IAAI,YAAY,KAAK;AACpC,iBAAe;AACjB;AAEO,IAAM,mBAAmB,CAAC,eAC/B,eAAe,IAAI,UAAU;AAE/B,IAAM,2BAA2B,CAAC,OAAqC;AACrE,2BAAyB,IAAI,GAAG,gBAAgB,EAAE;AACpD;AAEO,IAAM,uCAAkE;AAAA,EAC7E,UAAU;AACZ;AAEO,IAAM,gCAAgC,CAAC,YAIvB;AACrB,QAAM,kBAAkB,SAAS,mBAAmB;AACpD,QAAM,QAAQ,SAAS,SAAS;AAChC,QAAM,SAAS,SAAS,UAAU,EAAE,MAAM,UAAU;AAEpD,QAAM,SAAS,WAAW,IAAI,CAAC,SAAS,OAAO;AAAA,IAC7C;AAAA,IACA;AAAA,IACA,KAAK,cAAc,CAAC,KAAK,IAAI;AAAA,IAC7B,WAAW,QAAQ;AAAA,IACnB,MAAM;AAAA,IACN;AAAA,EACF,EAAE;AAEF,QAAM,WAAW,CAAC,UAChB,OAAO,UAAU,YAAY,UAAU,QAAQ,CAAC,MAAM,QAAQ,KAAK;AAGrE,QAAM,kBAAkB,oBAAI,IAAY;AACxC,MAAI,kBAAkB;AAEtB,aAAW,OAAO,YAAY;AAC5B,QAAI,IAAI,SAAS,iBAAkB;AACnC,UAAM,OAAO,IAAI;AACjB,QAAI,CAAC,SAAS,IAAI,EAAG;AAErB,UAAM,SAAS,KAAK;AACpB,QAAI,OAAO,WAAW,YAAY,OAAO,SAAS,GAAG;AACnD,sBAAgB,IAAI,MAAM;AAAA,IAC5B;AAEA,UAAM,QAAQ,KAAK;AACnB,QAAI,SAAS,KAAK,KAAK,OAAO,MAAM,cAAc,UAAU;AAC1D,wBAAkB;AAAA,IACpB;AAAA,EACF;AAEA,MAAI;AACJ,MAAI,mBAAmB,gBAAgB,OAAO,GAAG;AAC/C,UAAM,mBAA8C,CAAC;AACrD,eAAW,UAAU,iBAAiB;AACpC,YAAM,KAAK,yBAAyB,IAAI,MAAM;AAC9C,UAAI,IAAI;AACN,yBAAiB,MAAM,IAAI;AAAA,MAC7B;AAAA,IACF;AACA,QAAI,OAAO,KAAK,gBAAgB,EAAE,SAAS,GAAG;AAC5C,gBAAU,EAAE,UAAU,EAAE,iBAAiB,EAAE;AAAA,IAC7C;AAAA,EACF;AAEA,SAAO,sBAAsB;AAAA,IAC3B;AAAA,IACA;AAAA,IACA;AAAA,IACA;AAAA,IACA;AAAA,EACF,CAAC;AACH;AAIO,IAAM,kBAAwB;AAAA,EACnC,QAAQ,CAAC,UACP,OAAO,IAAI,aAAa;AAGtB,UAAM,QAAQ,OAAO,SAAS,IAAI,uBAAuB;AAGzD,QAAI,MAAM,SAAS,uBAAuB;AACxC,YAAM,aAAc,MAAc;AAClC,YAAM,OAAQ,MAAc;AAC5B,YAAM,QACJ,QAAQ,OAAO,SAAS,YAAY,WAAW,OAAO,OAAQ,KAAa,KAAK,IAAI;AACtF,UAAI,cAAc,OAAO;AACvB,uBAAe,IAAI,YAAY,KAAK;AAAA,MACtC;AAAA,IACF;AAGA,QAAI,MAAM,SAAS,iBAAiB,MAAM,SAAS,kBAAkB;AACnE,YAAM,WAAY,MAAc,YAAY;AAC5C,YAAMC,gBAAgB,MAAc,gBAAgB;AACpD,YAAM,aAAc,MAAc;AAClC,YAAM,MAAM,GAAGA,aAAY,KAAK,QAAQ;AACxC,YAAM,OAAO,UAAU,IAAI,GAAG,KAAK;AACnC,UAAI,MAAM,SAAS,eAAe;AAChC,kBAAU,IAAI,KAAK,OAAO,CAAC;AAC3B,YAAI,YAAY;AACd,gBAAM,cAAc,GAAGA,aAAY,KAAK,QAAQ,KAAK,UAAU;AAC/D,2BAAiB,IAAI,WAAW;AAEhC,uBAAa,OAAO,WAAW;AAC/B,+BAAqB,OAAO,WAAW;AAAA,QACzC;AAAA,MACF,OAAO;AACL,cAAM,OAAO,OAAO;AACpB,YAAI,QAAQ,GAAG;AACb,oBAAU,OAAO,GAAG;AAAA,QACtB,OAAO;AACL,oBAAU,IAAI,KAAK,IAAI;AAAA,QACzB;AAEA,YAAI,YAAY;AACd,gBAAM,cAAc,GAAGA,aAAY,KAAK,QAAQ,KAAK,UAAU;AAC/D,2BAAiB,OAAO,WAAW;AACnC,uBAAa,OAAO,WAAW;AAC/B,+BAAqB,OAAO,WAAW;AACvC,yBAAe,OAAO,UAAU;AAAA,QAClC;AAAA,MACF;AAAA,IACF;AAEA,UAAM,MAAM,uBAAuB,OAAO;AAAA,MACxC,kBAAkB;AAAA,MAClB,kBAAkB,CAAC,EAAE,MAAM,MAAM;AAC/B,qBAAa,WAAW,MAAM;AAC9B,qBAAa,aAAa,MAAM;AAAA,MAClC;AAAA,IACF,CAAC;AACD,QAAI,CAAC,KAAK;AAER,qBAAe;AACf;AAAA,IACF;AAGA,QAAI,IAAI,SAAS,WAAW,IAAI,UAAU,gBAAgB;AACxD,YAAMA,gBAAe,IAAI,gBAAgB;AACzC,YAAM,MAAM,GAAGA,aAAY,KAAK,IAAI,QAAQ,KAAK,IAAI,UAAU;AAG/D,UAAI,iBAAiB,IAAI,GAAG,GAAG;AAC7B,YAAI,IAAI,QAAQ,OAAO,IAAI,SAAS,YAAY,CAAC,MAAM,QAAQ,IAAI,IAAI,GAAG;AACxE,gBAAM,UAAU,IAAI;AACpB,cAAI,WAAW,SAAS;AACtB,yBAAa,IAAI,KAAK,QAAQ,KAAkB;AAAA,UAClD;AACA,cAAI,kBAAkB,WAAW,QAAQ,iBAAiB,QAAW;AACnE,iCAAqB,IAAI,KAAK,QAAQ,YAAyB;AAAA,UACjE;AAAA,QACF;AAAA,MACF;AAAA,IACF;AAGA,QAAI,aAAa,GAAG;AAClB,YAAM,MAAM;AACZ,iBAAW,KAAK,GAAG;AACnB,oBAAc,KAAK,GAAG;AACtB,6BAAuB;AAAA,IACzB;AAEA,mBAAe;AAAA,EACjB,CAAC;AACL;;;ADlVO,IAAM,WAAW;AAAA,EACtB;AAAA,EACA;AAAA,EACA;AAAA,EACA;AACF;AAOO,IAAMC,uBAAkC;AACxC,IAAMC,6BAAwC;AAC9C,IAAMC,uBAAkC;AACxC,IAAMC,oBAA+B;AACrC,IAAMC,oBAA+B;AACrC,IAAMC,oBAA+B;AACrC,IAAMC,oBAA+B;AACrC,IAAMC,oBAA+B;AAErC,IAAMC,yBAAwB,CAAC,YAIH,8BAA8B,OAAO;AAOjE,IAAM,mBAAmB,CAAC,UAC/B,MAAM;AAAA,EACK;AAAA,EACT,MAAM;AACR;AAOK,IAAMC,qBAAgC;AA4BtC,IAAM,+BAA+B,MAA4B;AACtE,QAAM,SAAS,oBAAI,IAAoB;AAEvC,QAAM,OAAa;AAAA,IACjB,QAAQ,CAAC,UACPC,QAAO,KAAK,MAAM;AAChB,UAAI,MAAM,SAAS,eAAe;AAChC,cAAM,WAAW,MAAM,YAAY;AACnC,cAAMC,gBACJ,kBAAkB,SAAS,MAAM,eAC7B,MAAM,eACN;AACN,cAAM,MAAM,GAAGA,aAAY,KAAK,QAAQ;AACxC,cAAM,OAAO,OAAO,IAAI,GAAG,KAAK;AAChC,eAAO,IAAI,KAAK,OAAO,CAAC;AACxB;AAAA,MACF;AACA,UAAI,MAAM,SAAS,kBAAkB;AACnC,cAAM,WAAW,MAAM,YAAY;AACnC,cAAMA,gBACJ,kBAAkB,SAAS,MAAM,eAC7B,MAAM,eACN;AACN,cAAM,MAAM,GAAGA,aAAY,KAAK,QAAQ;AACxC,cAAM,OAAO,OAAO,IAAI,GAAG,KAAK;AAChC,cAAM,OAAO,OAAO;AACpB,YAAI,QAAQ,GAAG;AACb,iBAAO,OAAO,GAAG;AAAA,QACnB,OAAO;AACL,iBAAO,IAAI,KAAK,IAAI;AAAA,QACtB;AAAA,MACF;AAAA,IACF,CAAC;AAAA,EACL;AAEA,QAAM,cAAc,MAClB,IAAI,IAAI,MAAM;AAEhB,SAAO,EAAE,MAAM,YAAY;AAC7B;AAOO,IAAM,qBAAqB,CAAC,WAAW,QAAyB;AACrE,QAAM,SAAkB,CAAC;AAEzB,QAAM,OAAa;AAAA,IACjB,QAAQ,CAAC,UACPD,QAAO,KAAK,MAAM;AAChB,UAAI,YAAY,GAAG;AACjB;AAAA,MACF;AACA,UAAI,OAAO,UAAU,UAAU;AAC7B,eAAO,MAAM;AAAA,MACf;AACA,aAAO,KAAK,KAAK;AAAA,IACnB,CAAC;AAAA,EACL;AAEA,QAAM,cAAc,MAA4B,OAAO,MAAM;AAC7D,QAAM,QAAQ,MAAY;AACxB,WAAO,SAAS;AAAA,EAClB;AAEA,SAAO,EAAE,MAAM,aAAa,MAAM;AACpC;AAQO,IAAME,UAAkB;AAOxB,IAAMC,aAAqB;AAyBlC,IAAM,cAAc,CAAC,SAA2C;AAC9D,MAAI,QAAQ,SAAS,QAAQ;AAC3B,WAAO;AAAA,EACT;AAEA,QAAM,MAAM,WAAW;AACvB,SAAO,QAAQ,eAAe,SAAS;AACzC;AAgBO,IAAM,QAAQ,CAAC,YAAgE;AACpF,QAAM,OAAO,YAAY,SAAS,IAAI;AAEtC,UAAQ,MAAM;AAAA,IACZ,KAAK;AACH,aAAgB;AAAA,IAClB,KAAK;AAEH,aAAgB;AAAA,IAClB,KAAK;AAAA,IACL,KAAK,QAAQ;AAGX,aAAgB;AAAA,IAClB;AAAA,EACF;AACF;AAaO,IAAM,mBAAmB,CAC9B,MACA,YAEA,MAAM;AAAA,EACJ;AAAA,EACA,OAAO;AAAA,IACL,OAAO;AAAA,IACP,OAAO,aAAa,OAAO;AAAA,EAC7B;AACF;AAQK,IAAM,UAAU,CAAC,UACtB,MAAM;AAAA,EACJ,SAAS;AAAA,EACT;AACF;AAOK,IAAM,cAAc,CAAC,UAC1B,MAAM;AAAA,EACK;AAAA,EACT,CAAC,YAAY,CAAC,GAAG,SAAS,GAAI,KAAsC;AACtE;AAYK,SAAS,iBACd,eACA,cAC8B;AAE9B,QAAM,eAAe,CAAC,UACpB,OAAO,UAAU,YAAY,UAAU,QAAQ,eAAgB;AAEjE,QAAM,UAAU,aAAa,aAAa;AAC1C,QAAM,OAAO,UACR,gBACA,MAAM;AACX,QAAM,UAAU,UACZ,eACC;AAEL,EAAY,qBAAqB,OAAO;AACxC,QAAM,SAAS,YAAY,CAAa,eAAe,CAAC;AACxD,QAAM,yBACsB,iCAAiC;AAAA,IAC7C;AAAA,EACd,CAAC;AACH,QAAM,8BAA8B,iBAAiB,SAAS,oBAAoB,OAAO;AAIzF,SAAO,MAAM;AAAA,IACX,MAAM,SAAS,QAAQ,6BAA6B,sBAAsB;AAAA,IAK1E;AAAA,EACF;AACF;AAOO,IAAM,eAAe,CAAC,UAC3B,MAAM;AAAA,EACJ,SAAS;AAAA,EACT,MAAM;AACR;AA6BK,IAAM,kBAAkB,CAC7B,WAGsB;AACtB,QAAM,YAAa,OAAe,MAAO,OAAe,MAAM;AAE9D,QAAM,UAAU,uBAAuB,SAAgB;AAIvD,MAAI,CAAC,SAAS;AACZ,WAAO,CAAC;AAAA,EACV;AAEA,SAAO;AAAA,IACL;AAAA,IACA,OAAO,QAAQ;AAAA,IACf,MAAM,QAAQ;AAAA,EAChB;AACF;AAOO,IAAM,sBAAsB,CACjC,aACkC;AAClC,QAAM,UAA+B,qBAAqB,QAAQ;AAClE,MAAI,CAAC,SAAS;AACZ,WAAO;AAAA,EACT;AACA,SAAO;AAAA,IACL;AAAA,IACA,OAAO,QAAQ;AAAA,IACf,MAAM,QAAQ;AAAA,EAChB;AACF;AAMO,IAAM,0BAA0B,CACrC,YACkD;AAClD,MAAI;AACF,UAAM,YAAY,oBAAoB,OAAc;AACpD,WAAO,UAAU,OAAO,wBAAwB;AAAA,EAClD,QAAQ;AACN,WAAO;AAAA,EACT;AACF;AAOO,IAAM,uBAAuB,CAClC,YACyC;AACzC,QAAM,WAAW,wBAAwB,OAAO;AAChD,MAAI,CAAC,SAAU,QAAO,CAAC;AAEvB,SAAO,SAAS,OAAO,IAAI,CAAC,OAAO;AAAA,IACjC,SAAS,EAAE;AAAA,IACX,MAAM,EAAE;AAAA,IACR,aAAa,EAAE;AAAA,IACf,YAAY,SAAS,gBAAgB,EAAE,OAAO;AAAA,EAChD,EAAE;AACJ;AAcA,IAAM,UAAU,CAAC,UACf,OAAO,UAAU,YAAY,UAAU,QAAQ,eAAgB;AAS1D,SAAS,WACd,eACA,cAC8B;AAC9B,QAAM,UAAU,QAAQ,aAAa;AACrC,QAAM,OAAO,UACR,gBACA,MAAM;AACX,QAAM,UAAU,UAAU,eAAgB;AAE1C,QAAM,YAAkB;AAAA,IACtB,QAAQ,CAAC,UACP,OAAO,MAAM,SAAS,YAAY,MAAM,KAAK,WAAW,QAAQ,IAC3D,UAAU,QAAQ,KAAK,IAAIH,QAAO,SAAS,EAAE,YAAY,MAAM,CAAC,IACjEA,QAAO;AAAA,EACf;AAIA,QAAM,cAAc,MAAM;AAAA,IACf;AAAA,IACT,CAAC,UAAU,CAAC,GAAG,OAAO,SAAS;AAAA,EACjC;AAGA,SAAO,MAAM,aAAa,aAAa,IAAkC;AAC3E;",
  "names": ["Effect", "runtimeLabel", "getDevtoolsSnapshot", "subscribeDevtoolsSnapshot", "clearDevtoolsEvents", "getDevtoolsRunId", "setDevtoolsRunId", "startDevtoolsRun", "setInstanceLabel", "getInstanceLabel", "exportEvidencePackage", "isDevtoolsEnabled", "Effect", "runtimeLabel", "record", "noopLayer"]
}

|