@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,850 @@
|
|
|
1
|
+
// @logix/core subpath bundles for @logix/sandbox
|
|
2
|
+
|
|
3
|
+
import {
|
|
4
|
+
currentLinkId,
|
|
5
|
+
projectJsonValue
|
|
6
|
+
} from "./chunk-S6ZZHV6G.js";
|
|
7
|
+
|
|
8
|
+
// ../logix-core/src/internal/runtime/core/DebugSink.ts
|
|
9
|
+
import { Cause as Cause2, Effect, FiberRef, Layer, Logger } from "../effect.js";
|
|
10
|
+
|
|
11
|
+
// ../logix-core/src/internal/runtime/core/errorSummary.ts
|
|
12
|
+
import { Cause } from "../effect.js";
|
|
13
|
+
var truncate = (value, maxLen) => {
|
|
14
|
+
if (value.length <= maxLen) return { value, truncated: false };
|
|
15
|
+
return { value: value.slice(0, maxLen), truncated: true };
|
|
16
|
+
};
|
|
17
|
+
var safeStringify = (value) => {
|
|
18
|
+
try {
|
|
19
|
+
return { ok: true, json: JSON.stringify(value) };
|
|
20
|
+
} catch {
|
|
21
|
+
return { ok: false };
|
|
22
|
+
}
|
|
23
|
+
};
|
|
24
|
+
var getMessageFromUnknown = (cause) => {
|
|
25
|
+
if (typeof cause === "string") return cause;
|
|
26
|
+
if (typeof cause === "number" || typeof cause === "boolean" || typeof cause === "bigint") return String(cause);
|
|
27
|
+
if (cause instanceof Error) return cause.message || cause.name || "Error";
|
|
28
|
+
if (cause && typeof cause === "object" && "message" in cause && typeof cause.message === "string") {
|
|
29
|
+
return cause.message;
|
|
30
|
+
}
|
|
31
|
+
try {
|
|
32
|
+
const pretty = Cause.pretty(cause, { renderErrorCause: true });
|
|
33
|
+
if (typeof pretty === "string" && pretty.length > 0) return pretty;
|
|
34
|
+
} catch {
|
|
35
|
+
}
|
|
36
|
+
return "Unknown error";
|
|
37
|
+
};
|
|
38
|
+
var toSerializableErrorSummary = (cause, options) => {
|
|
39
|
+
const maxMessageLength = options?.maxMessageLength ?? 256;
|
|
40
|
+
const messageRaw = getMessageFromUnknown(cause);
|
|
41
|
+
const { value: message, truncated } = truncate(messageRaw, maxMessageLength);
|
|
42
|
+
const summary = {
|
|
43
|
+
message
|
|
44
|
+
};
|
|
45
|
+
if (cause instanceof Error) {
|
|
46
|
+
if (cause.name && cause.name !== "Error") summary.name = cause.name;
|
|
47
|
+
const anyCause = cause;
|
|
48
|
+
if (typeof anyCause.code === "string" && anyCause.code.length > 0) summary.code = anyCause.code;
|
|
49
|
+
else if (typeof anyCause.code === "number" && Number.isFinite(anyCause.code)) summary.code = String(anyCause.code);
|
|
50
|
+
if (typeof anyCause.hint === "string" && anyCause.hint.length > 0) summary.hint = anyCause.hint;
|
|
51
|
+
return {
|
|
52
|
+
errorSummary: summary,
|
|
53
|
+
downgrade: truncated ? "oversized" : void 0
|
|
54
|
+
};
|
|
55
|
+
}
|
|
56
|
+
if (cause && typeof cause === "object") {
|
|
57
|
+
const anyCause = cause;
|
|
58
|
+
if (typeof anyCause.name === "string" && anyCause.name.length > 0) summary.name = anyCause.name;
|
|
59
|
+
if (typeof anyCause.code === "string" && anyCause.code.length > 0) summary.code = anyCause.code;
|
|
60
|
+
if (typeof anyCause.hint === "string" && anyCause.hint.length > 0) summary.hint = anyCause.hint;
|
|
61
|
+
}
|
|
62
|
+
const stringifyResult = safeStringify(cause);
|
|
63
|
+
if (!stringifyResult.ok) {
|
|
64
|
+
return {
|
|
65
|
+
errorSummary: summary,
|
|
66
|
+
downgrade: "non_serializable"
|
|
67
|
+
};
|
|
68
|
+
}
|
|
69
|
+
if (truncated) {
|
|
70
|
+
return {
|
|
71
|
+
errorSummary: summary,
|
|
72
|
+
downgrade: "oversized"
|
|
73
|
+
};
|
|
74
|
+
}
|
|
75
|
+
if (message === "Unknown error") {
|
|
76
|
+
return {
|
|
77
|
+
errorSummary: summary,
|
|
78
|
+
downgrade: "unknown"
|
|
79
|
+
};
|
|
80
|
+
}
|
|
81
|
+
return { errorSummary: summary };
|
|
82
|
+
};
|
|
83
|
+
|
|
84
|
+
// ../logix-core/src/internal/runtime/core/DebugSink.ts
|
|
85
|
+
var currentDebugSinks = FiberRef.unsafeMake([]);
|
|
86
|
+
var currentRuntimeLabel = FiberRef.unsafeMake(void 0);
|
|
87
|
+
var currentTxnId = FiberRef.unsafeMake(void 0);
|
|
88
|
+
var currentDiagnosticsLevel = FiberRef.unsafeMake("off");
|
|
89
|
+
var diagnosticsLevel = (level) => Layer.fiberRefLocallyScopedWith(currentDiagnosticsLevel, () => level);
|
|
90
|
+
var currentTraitConvergeDiagnosticsSampling = FiberRef.unsafeMake({
|
|
91
|
+
sampleEveryN: 32,
|
|
92
|
+
topK: 3
|
|
93
|
+
});
|
|
94
|
+
var traitConvergeDiagnosticsSampling = (config) => Layer.fiberRefLocallyScopedWith(currentTraitConvergeDiagnosticsSampling, () => config);
|
|
95
|
+
var appendSinks = (sinks) => Layer.fiberRefLocallyScopedWith(currentDebugSinks, (current) => [...current, ...sinks]);
|
|
96
|
+
var nextGlobalEventSeq = 0;
|
|
97
|
+
var clearRuntimeDebugEventSeq = () => {
|
|
98
|
+
nextGlobalEventSeq = 0;
|
|
99
|
+
};
|
|
100
|
+
var nextEventSeq = () => {
|
|
101
|
+
nextGlobalEventSeq += 1;
|
|
102
|
+
return nextGlobalEventSeq;
|
|
103
|
+
};
|
|
104
|
+
var makeEventId = (instanceId, eventSeq) => `${instanceId}::e${eventSeq}`;
|
|
105
|
+
var mergeDowngrade = (current, next) => {
|
|
106
|
+
if (!current) return next;
|
|
107
|
+
if (!next) return current;
|
|
108
|
+
if (current === "non_serializable" || next === "non_serializable") return "non_serializable";
|
|
109
|
+
if (current === "oversized" || next === "oversized") return "oversized";
|
|
110
|
+
return "unknown";
|
|
111
|
+
};
|
|
112
|
+
var browserLifecycleSeen = /* @__PURE__ */ new Set();
|
|
113
|
+
var browserDiagnosticSeen = /* @__PURE__ */ new Set();
|
|
114
|
+
var lastTxnByInstance = /* @__PURE__ */ new Map();
|
|
115
|
+
var lifecycleErrorLog = (event) => {
|
|
116
|
+
const moduleId = event.moduleId ?? "unknown";
|
|
117
|
+
const causePretty = (() => {
|
|
118
|
+
try {
|
|
119
|
+
return Cause2.pretty(event.cause, {
|
|
120
|
+
renderErrorCause: true
|
|
121
|
+
});
|
|
122
|
+
} catch {
|
|
123
|
+
try {
|
|
124
|
+
return JSON.stringify(event.cause, null, 2);
|
|
125
|
+
} catch {
|
|
126
|
+
return String(event.cause);
|
|
127
|
+
}
|
|
128
|
+
}
|
|
129
|
+
})();
|
|
130
|
+
const message = `[Logix][module=${moduleId}] lifecycle:error
|
|
131
|
+
${causePretty}`;
|
|
132
|
+
return Effect.logError(message).pipe(
|
|
133
|
+
Effect.annotateLogs({
|
|
134
|
+
"logix.moduleId": moduleId,
|
|
135
|
+
"logix.event": "lifecycle:error",
|
|
136
|
+
"logix.cause": causePretty
|
|
137
|
+
})
|
|
138
|
+
);
|
|
139
|
+
};
|
|
140
|
+
var diagnosticLog = (event) => {
|
|
141
|
+
const moduleId = event.moduleId ?? "unknown";
|
|
142
|
+
const header = `[Logix][module=${moduleId}] diagnostic(${event.severity})`;
|
|
143
|
+
const detail = `code=${event.code} message=${event.message}${event.actionTag ? ` action=${event.actionTag}` : ""}${event.hint ? `
|
|
144
|
+
hint: ${event.hint}` : ""}`;
|
|
145
|
+
const msg = `${header}
|
|
146
|
+
${detail}`;
|
|
147
|
+
const base = event.severity === "warning" ? Effect.logWarning(msg) : event.severity === "info" ? Effect.logInfo(msg) : Effect.logError(msg);
|
|
148
|
+
const annotations = {
|
|
149
|
+
"logix.moduleId": moduleId,
|
|
150
|
+
"logix.event": `diagnostic(${event.severity})`,
|
|
151
|
+
"logix.diagnostic.code": event.code,
|
|
152
|
+
"logix.diagnostic.message": event.message
|
|
153
|
+
};
|
|
154
|
+
if (event.hint) {
|
|
155
|
+
annotations["logix.diagnostic.hint"] = event.hint;
|
|
156
|
+
}
|
|
157
|
+
if (event.actionTag) {
|
|
158
|
+
annotations["logix.diagnostic.actionTag"] = event.actionTag;
|
|
159
|
+
}
|
|
160
|
+
return base.pipe(Effect.annotateLogs(annotations));
|
|
161
|
+
};
|
|
162
|
+
var noopLayer = Layer.locallyScoped(currentDebugSinks, []);
|
|
163
|
+
var errorOnlySink = {
|
|
164
|
+
record: (event) => event.type === "lifecycle:error" ? lifecycleErrorLog(event) : event.type === "diagnostic" && event.severity !== "info" ? diagnosticLog(event) : Effect.void
|
|
165
|
+
};
|
|
166
|
+
var errorOnlyLayer = Layer.locallyScoped(currentDebugSinks, [errorOnlySink]);
|
|
167
|
+
var consoleSink = {
|
|
168
|
+
record: (event) => event.type === "lifecycle:error" ? lifecycleErrorLog(event) : event.type === "diagnostic" ? diagnosticLog(event) : Effect.logDebug({ debugEvent: event })
|
|
169
|
+
};
|
|
170
|
+
var consoleLayer = Layer.locallyScoped(currentDebugSinks, [consoleSink]);
|
|
171
|
+
var isBrowser = typeof window !== "undefined" && typeof document !== "undefined";
|
|
172
|
+
var renderBrowserConsoleEvent = (event) => {
|
|
173
|
+
if (typeof event.type === "string" && event.type.startsWith("trace:")) {
|
|
174
|
+
const moduleId = event.moduleId ?? "unknown";
|
|
175
|
+
const type = event.type;
|
|
176
|
+
return Effect.sync(() => {
|
|
177
|
+
console.groupCollapsed(
|
|
178
|
+
"%c[Logix]%c trace %c" + moduleId + "%c " + String(type),
|
|
179
|
+
"color:#6b7280;font-weight:bold",
|
|
180
|
+
// tag
|
|
181
|
+
"color:#3b82f6",
|
|
182
|
+
// label
|
|
183
|
+
"color:#9ca3af",
|
|
184
|
+
// module id
|
|
185
|
+
"color:#6b7280"
|
|
186
|
+
// type
|
|
187
|
+
);
|
|
188
|
+
console.log(event);
|
|
189
|
+
console.groupEnd();
|
|
190
|
+
});
|
|
191
|
+
}
|
|
192
|
+
if (event.type === "lifecycle:error") {
|
|
193
|
+
const moduleId = event.moduleId ?? "unknown";
|
|
194
|
+
const causePretty = (() => {
|
|
195
|
+
try {
|
|
196
|
+
return Cause2.pretty(event.cause, { renderErrorCause: true });
|
|
197
|
+
} catch {
|
|
198
|
+
try {
|
|
199
|
+
return JSON.stringify(event.cause, null, 2);
|
|
200
|
+
} catch {
|
|
201
|
+
return String(event.cause);
|
|
202
|
+
}
|
|
203
|
+
}
|
|
204
|
+
})();
|
|
205
|
+
const key = `${moduleId}|${causePretty}`;
|
|
206
|
+
if (browserLifecycleSeen.has(key)) {
|
|
207
|
+
return Effect.void;
|
|
208
|
+
}
|
|
209
|
+
browserLifecycleSeen.add(key);
|
|
210
|
+
return Effect.sync(() => {
|
|
211
|
+
console.groupCollapsed(
|
|
212
|
+
"%c[Logix]%c lifecycle:error %c" + moduleId,
|
|
213
|
+
"color:#ef4444;font-weight:bold",
|
|
214
|
+
// tag
|
|
215
|
+
"color:#ef4444",
|
|
216
|
+
// label
|
|
217
|
+
"color:#9ca3af"
|
|
218
|
+
// module id
|
|
219
|
+
);
|
|
220
|
+
console.error(causePretty);
|
|
221
|
+
console.groupEnd();
|
|
222
|
+
});
|
|
223
|
+
}
|
|
224
|
+
if (event.type === "diagnostic") {
|
|
225
|
+
const moduleId = event.moduleId ?? "unknown";
|
|
226
|
+
const detail = `code=${event.code} message=${event.message}${event.actionTag ? ` action=${event.actionTag}` : ""}${event.hint ? `
|
|
227
|
+
hint: ${event.hint}` : ""}`;
|
|
228
|
+
const color = event.severity === "warning" ? "color:#d97706" : event.severity === "info" ? "color:#3b82f6" : "color:#ef4444";
|
|
229
|
+
const label = event.severity === "warning" ? "diagnostic(warning)" : event.severity === "info" ? "diagnostic(info)" : "diagnostic(error)";
|
|
230
|
+
const key = `${moduleId}|${event.code}|${event.message}`;
|
|
231
|
+
if (browserDiagnosticSeen.has(key)) {
|
|
232
|
+
return Effect.void;
|
|
233
|
+
}
|
|
234
|
+
browserDiagnosticSeen.add(key);
|
|
235
|
+
return Effect.sync(() => {
|
|
236
|
+
console.groupCollapsed(
|
|
237
|
+
"%c[Logix]%c " + label + "%c module=" + moduleId,
|
|
238
|
+
"color:#6b7280;font-weight:bold",
|
|
239
|
+
color,
|
|
240
|
+
"color:#9ca3af"
|
|
241
|
+
);
|
|
242
|
+
console.log(detail);
|
|
243
|
+
console.groupEnd();
|
|
244
|
+
});
|
|
245
|
+
}
|
|
246
|
+
return Effect.void;
|
|
247
|
+
};
|
|
248
|
+
var browserConsoleSink = {
|
|
249
|
+
record: (event) => {
|
|
250
|
+
if (!isBrowser) {
|
|
251
|
+
return event.type === "lifecycle:error" ? lifecycleErrorLog(event) : event.type === "diagnostic" ? diagnosticLog(event) : Effect.logDebug({ debugEvent: event });
|
|
252
|
+
}
|
|
253
|
+
return renderBrowserConsoleEvent(event);
|
|
254
|
+
}
|
|
255
|
+
};
|
|
256
|
+
var browserConsoleLayer = Layer.locallyScoped(currentDebugSinks, [browserConsoleSink]);
|
|
257
|
+
var browserPrettyLoggerLayer = Logger.replace(
|
|
258
|
+
Logger.defaultLogger,
|
|
259
|
+
Logger.prettyLogger({ mode: "browser", colors: true })
|
|
260
|
+
);
|
|
261
|
+
var record = (event) => Effect.gen(function* () {
|
|
262
|
+
const sinks = yield* FiberRef.get(currentDebugSinks);
|
|
263
|
+
if (sinks.length === 0) {
|
|
264
|
+
if (isBrowser) {
|
|
265
|
+
if (event.type === "lifecycle:error" || event.type === "diagnostic") {
|
|
266
|
+
yield* renderBrowserConsoleEvent(event);
|
|
267
|
+
return;
|
|
268
|
+
}
|
|
269
|
+
yield* Effect.void;
|
|
270
|
+
return;
|
|
271
|
+
}
|
|
272
|
+
if (event.type === "lifecycle:error") {
|
|
273
|
+
yield* lifecycleErrorLog(event);
|
|
274
|
+
return;
|
|
275
|
+
}
|
|
276
|
+
if (event.type === "diagnostic") {
|
|
277
|
+
yield* diagnosticLog(event);
|
|
278
|
+
return;
|
|
279
|
+
}
|
|
280
|
+
yield* Effect.void;
|
|
281
|
+
return;
|
|
282
|
+
}
|
|
283
|
+
const now = Date.now();
|
|
284
|
+
const enriched = event;
|
|
285
|
+
if (enriched.timestamp === void 0) {
|
|
286
|
+
;
|
|
287
|
+
enriched.timestamp = now;
|
|
288
|
+
}
|
|
289
|
+
if (enriched.runtimeLabel === void 0) {
|
|
290
|
+
const runtimeLabel = yield* FiberRef.get(currentRuntimeLabel);
|
|
291
|
+
if (runtimeLabel) {
|
|
292
|
+
;
|
|
293
|
+
enriched.runtimeLabel = runtimeLabel;
|
|
294
|
+
}
|
|
295
|
+
}
|
|
296
|
+
if (enriched.type === "diagnostic" && enriched.txnId === void 0) {
|
|
297
|
+
const txnId = yield* FiberRef.get(currentTxnId);
|
|
298
|
+
if (txnId) {
|
|
299
|
+
;
|
|
300
|
+
enriched.txnId = txnId;
|
|
301
|
+
}
|
|
302
|
+
}
|
|
303
|
+
if (enriched.type === "trace:effectop" && enriched.linkId === void 0) {
|
|
304
|
+
const linkId = yield* FiberRef.get(currentLinkId);
|
|
305
|
+
if (linkId) {
|
|
306
|
+
;
|
|
307
|
+
enriched.linkId = linkId;
|
|
308
|
+
}
|
|
309
|
+
}
|
|
310
|
+
if (sinks.length === 1) {
|
|
311
|
+
yield* sinks[0].record(enriched);
|
|
312
|
+
return;
|
|
313
|
+
}
|
|
314
|
+
yield* Effect.forEach(sinks, (sink) => sink.record(enriched), { discard: true });
|
|
315
|
+
});
|
|
316
|
+
var toRuntimeDebugEventRef = (event, options) => {
|
|
317
|
+
const diagnosticsLevel2 = options?.diagnosticsLevel ?? "full";
|
|
318
|
+
if (diagnosticsLevel2 === "off") {
|
|
319
|
+
return void 0;
|
|
320
|
+
}
|
|
321
|
+
const isLightLike = diagnosticsLevel2 === "light" || diagnosticsLevel2 === "sampled";
|
|
322
|
+
const timestamp = typeof event.timestamp === "number" && Number.isFinite(event.timestamp) ? event.timestamp : Date.now();
|
|
323
|
+
const moduleIdRaw = event.moduleId;
|
|
324
|
+
const moduleId = typeof moduleIdRaw === "string" && moduleIdRaw.length > 0 ? moduleIdRaw : "unknown";
|
|
325
|
+
const instanceIdRaw = event.instanceId;
|
|
326
|
+
const instanceId = typeof instanceIdRaw === "string" && instanceIdRaw.length > 0 ? instanceIdRaw : "unknown";
|
|
327
|
+
const runtimeLabelRaw = event.runtimeLabel;
|
|
328
|
+
const runtimeLabel = typeof runtimeLabelRaw === "string" && runtimeLabelRaw.length > 0 ? runtimeLabelRaw : void 0;
|
|
329
|
+
const txnSeqRaw = event.txnSeq;
|
|
330
|
+
const txnSeq = typeof txnSeqRaw === "number" && Number.isFinite(txnSeqRaw) && txnSeqRaw >= 0 ? Math.floor(txnSeqRaw) : 0;
|
|
331
|
+
const txnIdRaw = event.txnId;
|
|
332
|
+
const txnId = typeof txnIdRaw === "string" && txnIdRaw.length > 0 ? txnIdRaw : txnSeq > 0 ? `${instanceId}::t${txnSeq}` : void 0;
|
|
333
|
+
const linkId = (() => {
|
|
334
|
+
const linkIdRaw = event.linkId;
|
|
335
|
+
if (typeof linkIdRaw === "string" && linkIdRaw.length > 0) return linkIdRaw;
|
|
336
|
+
if (typeof event.type !== "string" || !event.type.startsWith("trace:")) {
|
|
337
|
+
return void 0;
|
|
338
|
+
}
|
|
339
|
+
const data = event.data;
|
|
340
|
+
const meta = data?.meta;
|
|
341
|
+
const linkIdFromMeta = meta?.linkId;
|
|
342
|
+
if (typeof linkIdFromMeta === "string" && linkIdFromMeta.length > 0) return linkIdFromMeta;
|
|
343
|
+
return void 0;
|
|
344
|
+
})();
|
|
345
|
+
const eventSeqRaw = options?.eventSeq;
|
|
346
|
+
const eventSeq = typeof eventSeqRaw === "number" && Number.isFinite(eventSeqRaw) && eventSeqRaw > 0 ? Math.floor(eventSeqRaw) : nextEventSeq();
|
|
347
|
+
const eventId = makeEventId(instanceId, eventSeq);
|
|
348
|
+
const base = {
|
|
349
|
+
eventId,
|
|
350
|
+
eventSeq,
|
|
351
|
+
moduleId,
|
|
352
|
+
instanceId,
|
|
353
|
+
runtimeLabel,
|
|
354
|
+
txnSeq,
|
|
355
|
+
txnId,
|
|
356
|
+
linkId,
|
|
357
|
+
timestamp
|
|
358
|
+
};
|
|
359
|
+
let downgrade;
|
|
360
|
+
const withDowngrade = (ref) => {
|
|
361
|
+
if (!downgrade) return ref;
|
|
362
|
+
return { ...ref, downgrade: { reason: downgrade } };
|
|
363
|
+
};
|
|
364
|
+
switch (event.type) {
|
|
365
|
+
case "module:init":
|
|
366
|
+
return withDowngrade({
|
|
367
|
+
...base,
|
|
368
|
+
kind: "lifecycle",
|
|
369
|
+
label: "module:init"
|
|
370
|
+
});
|
|
371
|
+
case "module:destroy":
|
|
372
|
+
return withDowngrade({
|
|
373
|
+
...base,
|
|
374
|
+
kind: "lifecycle",
|
|
375
|
+
label: "module:destroy"
|
|
376
|
+
});
|
|
377
|
+
case "lifecycle:phase": {
|
|
378
|
+
const e = event;
|
|
379
|
+
const metaInput = isLightLike ? { type: "lifecycle:phase", phase: e.phase, name: e.name } : { type: "lifecycle:phase", phase: e.phase, name: e.name, payload: e.payload };
|
|
380
|
+
const metaProjection = projectJsonValue(metaInput);
|
|
381
|
+
options?.onMetaProjection?.({
|
|
382
|
+
stats: metaProjection.stats,
|
|
383
|
+
downgrade: metaProjection.downgrade
|
|
384
|
+
});
|
|
385
|
+
downgrade = mergeDowngrade(downgrade, metaProjection.downgrade);
|
|
386
|
+
return withDowngrade({
|
|
387
|
+
...base,
|
|
388
|
+
kind: "lifecycle",
|
|
389
|
+
label: e.name,
|
|
390
|
+
meta: metaProjection.value
|
|
391
|
+
});
|
|
392
|
+
}
|
|
393
|
+
case "action:dispatch": {
|
|
394
|
+
const action = event.action;
|
|
395
|
+
const tag = action?._tag ?? action?.type ?? "action:dispatch";
|
|
396
|
+
const label = String(tag);
|
|
397
|
+
const metaInput = isLightLike ? { actionTag: label } : { action };
|
|
398
|
+
const metaProjection = projectJsonValue(metaInput);
|
|
399
|
+
options?.onMetaProjection?.({
|
|
400
|
+
stats: metaProjection.stats,
|
|
401
|
+
downgrade: metaProjection.downgrade
|
|
402
|
+
});
|
|
403
|
+
downgrade = mergeDowngrade(downgrade, metaProjection.downgrade);
|
|
404
|
+
return withDowngrade({
|
|
405
|
+
...base,
|
|
406
|
+
kind: "action",
|
|
407
|
+
label,
|
|
408
|
+
meta: metaProjection.value
|
|
409
|
+
});
|
|
410
|
+
}
|
|
411
|
+
case "state:update": {
|
|
412
|
+
const e = event;
|
|
413
|
+
const metaInput = isLightLike ? {
|
|
414
|
+
state: e.state,
|
|
415
|
+
dirtySet: e.dirtySet,
|
|
416
|
+
patchCount: e.patchCount,
|
|
417
|
+
commitMode: e.commitMode,
|
|
418
|
+
priority: e.priority,
|
|
419
|
+
originKind: e.originKind,
|
|
420
|
+
originName: e.originName
|
|
421
|
+
} : {
|
|
422
|
+
state: e.state,
|
|
423
|
+
dirtySet: e.dirtySet,
|
|
424
|
+
patchCount: e.patchCount,
|
|
425
|
+
commitMode: e.commitMode,
|
|
426
|
+
priority: e.priority,
|
|
427
|
+
originKind: e.originKind,
|
|
428
|
+
originName: e.originName,
|
|
429
|
+
traitSummary: e.traitSummary,
|
|
430
|
+
replayEvent: e.replayEvent
|
|
431
|
+
};
|
|
432
|
+
const metaProjection = projectJsonValue(metaInput);
|
|
433
|
+
options?.onMetaProjection?.({
|
|
434
|
+
stats: metaProjection.stats,
|
|
435
|
+
downgrade: metaProjection.downgrade
|
|
436
|
+
});
|
|
437
|
+
downgrade = mergeDowngrade(downgrade, metaProjection.downgrade);
|
|
438
|
+
if (txnId) {
|
|
439
|
+
lastTxnByInstance.set(instanceId, { txnId, txnSeq });
|
|
440
|
+
}
|
|
441
|
+
return withDowngrade({
|
|
442
|
+
...base,
|
|
443
|
+
kind: "state",
|
|
444
|
+
label: "state:update",
|
|
445
|
+
meta: metaProjection.value
|
|
446
|
+
});
|
|
447
|
+
}
|
|
448
|
+
case "process:start":
|
|
449
|
+
case "process:stop":
|
|
450
|
+
case "process:restart":
|
|
451
|
+
case "process:trigger":
|
|
452
|
+
case "process:dispatch":
|
|
453
|
+
case "process:error": {
|
|
454
|
+
const e = event;
|
|
455
|
+
const ts2 = typeof e.timestampMs === "number" && Number.isFinite(e.timestampMs) ? e.timestampMs : timestamp;
|
|
456
|
+
const metaInput = {
|
|
457
|
+
identity: e.identity,
|
|
458
|
+
severity: e.severity,
|
|
459
|
+
eventSeq: e.eventSeq,
|
|
460
|
+
timestampMs: e.timestampMs,
|
|
461
|
+
trigger: e.trigger,
|
|
462
|
+
dispatch: e.dispatch,
|
|
463
|
+
error: e.error
|
|
464
|
+
};
|
|
465
|
+
const metaProjection = projectJsonValue(metaInput);
|
|
466
|
+
options?.onMetaProjection?.({
|
|
467
|
+
stats: metaProjection.stats,
|
|
468
|
+
downgrade: metaProjection.downgrade
|
|
469
|
+
});
|
|
470
|
+
downgrade = mergeDowngrade(downgrade, metaProjection.downgrade);
|
|
471
|
+
const errorSummary = e.type === "process:error" || e.type === "process:restart" ? e.error : void 0;
|
|
472
|
+
return withDowngrade({
|
|
473
|
+
...base,
|
|
474
|
+
timestamp: ts2,
|
|
475
|
+
kind: "process",
|
|
476
|
+
label: e.type,
|
|
477
|
+
meta: metaProjection.value,
|
|
478
|
+
errorSummary
|
|
479
|
+
});
|
|
480
|
+
}
|
|
481
|
+
case "lifecycle:error": {
|
|
482
|
+
const e = event;
|
|
483
|
+
const summary = toSerializableErrorSummary(e.cause);
|
|
484
|
+
downgrade = mergeDowngrade(downgrade, summary.downgrade);
|
|
485
|
+
const metaInput = isLightLike ? { type: "lifecycle:error", phase: e.phase, name: e.hook } : {
|
|
486
|
+
type: "lifecycle:error",
|
|
487
|
+
phase: e.phase,
|
|
488
|
+
name: e.hook,
|
|
489
|
+
hook: e.hook,
|
|
490
|
+
taskId: e.taskId,
|
|
491
|
+
origin: e.origin,
|
|
492
|
+
txnSeq: e.txnSeq,
|
|
493
|
+
opSeq: e.opSeq
|
|
494
|
+
};
|
|
495
|
+
const metaProjection = projectJsonValue(metaInput);
|
|
496
|
+
options?.onMetaProjection?.({
|
|
497
|
+
stats: metaProjection.stats,
|
|
498
|
+
downgrade: metaProjection.downgrade
|
|
499
|
+
});
|
|
500
|
+
downgrade = mergeDowngrade(downgrade, metaProjection.downgrade);
|
|
501
|
+
return withDowngrade({
|
|
502
|
+
...base,
|
|
503
|
+
kind: "lifecycle",
|
|
504
|
+
label: "lifecycle:error",
|
|
505
|
+
meta: metaProjection.value,
|
|
506
|
+
errorSummary: summary.errorSummary
|
|
507
|
+
});
|
|
508
|
+
}
|
|
509
|
+
case "diagnostic": {
|
|
510
|
+
const e = event;
|
|
511
|
+
const metaInput = {
|
|
512
|
+
code: e.code,
|
|
513
|
+
severity: e.severity,
|
|
514
|
+
message: e.message,
|
|
515
|
+
hint: e.hint,
|
|
516
|
+
actionTag: e.actionTag,
|
|
517
|
+
kind: e.kind,
|
|
518
|
+
trigger: e.trigger
|
|
519
|
+
};
|
|
520
|
+
const metaProjection = projectJsonValue(metaInput);
|
|
521
|
+
options?.onMetaProjection?.({
|
|
522
|
+
stats: metaProjection.stats,
|
|
523
|
+
downgrade: metaProjection.downgrade
|
|
524
|
+
});
|
|
525
|
+
downgrade = mergeDowngrade(downgrade, metaProjection.downgrade);
|
|
526
|
+
return withDowngrade({
|
|
527
|
+
...base,
|
|
528
|
+
kind: "diagnostic",
|
|
529
|
+
label: e.code,
|
|
530
|
+
meta: metaProjection.value
|
|
531
|
+
});
|
|
532
|
+
}
|
|
533
|
+
default: {
|
|
534
|
+
if (typeof event.type !== "string" || !event.type.startsWith("trace:")) {
|
|
535
|
+
return void 0;
|
|
536
|
+
}
|
|
537
|
+
if (event.type === "trace:react-render" || event.type === "trace:react-selector") {
|
|
538
|
+
const data = event.data;
|
|
539
|
+
const metaProjection2 = projectJsonValue(
|
|
540
|
+
isLightLike ? {
|
|
541
|
+
componentLabel: data?.componentLabel,
|
|
542
|
+
selectorKey: data?.selectorKey,
|
|
543
|
+
fieldPaths: data?.fieldPaths,
|
|
544
|
+
selectorId: data?.selectorId,
|
|
545
|
+
lane: data?.lane,
|
|
546
|
+
producer: data?.producer,
|
|
547
|
+
fallbackReason: data?.fallbackReason,
|
|
548
|
+
readsDigest: data?.readsDigest,
|
|
549
|
+
equalsKind: data?.equalsKind,
|
|
550
|
+
strictModePhase: data?.strictModePhase
|
|
551
|
+
} : {
|
|
552
|
+
componentLabel: data?.componentLabel,
|
|
553
|
+
selectorKey: data?.selectorKey,
|
|
554
|
+
fieldPaths: data?.fieldPaths,
|
|
555
|
+
selectorId: data?.selectorId,
|
|
556
|
+
lane: data?.lane,
|
|
557
|
+
producer: data?.producer,
|
|
558
|
+
fallbackReason: data?.fallbackReason,
|
|
559
|
+
readsDigest: data?.readsDigest,
|
|
560
|
+
equalsKind: data?.equalsKind,
|
|
561
|
+
strictModePhase: data?.strictModePhase,
|
|
562
|
+
meta: data?.meta
|
|
563
|
+
}
|
|
564
|
+
);
|
|
565
|
+
options?.onMetaProjection?.({
|
|
566
|
+
stats: metaProjection2.stats,
|
|
567
|
+
downgrade: metaProjection2.downgrade
|
|
568
|
+
});
|
|
569
|
+
downgrade = mergeDowngrade(downgrade, metaProjection2.downgrade);
|
|
570
|
+
const label = typeof data?.componentLabel === "string" && data.componentLabel.length > 0 ? data.componentLabel : event.type === "trace:react-selector" ? "react-selector" : "react-render";
|
|
571
|
+
const last = lastTxnByInstance.get(instanceId);
|
|
572
|
+
const txnSeqFromMeta = typeof data?.meta?.txnSeq === "number" && Number.isFinite(data.meta.txnSeq) && data.meta.txnSeq >= 0 ? Math.floor(data.meta.txnSeq) : void 0;
|
|
573
|
+
const txnIdFromMeta = typeof data?.meta?.txnId === "string" && data.meta.txnId.length > 0 ? data.meta.txnId : void 0;
|
|
574
|
+
const txnIdAligned = txnIdFromMeta ?? base.txnId ?? last?.txnId;
|
|
575
|
+
const txnSeqAligned = txnSeqFromMeta ?? (base.txnSeq > 0 ? base.txnSeq : last?.txnSeq ?? base.txnSeq);
|
|
576
|
+
return withDowngrade({
|
|
577
|
+
...base,
|
|
578
|
+
txnId: txnIdAligned,
|
|
579
|
+
txnSeq: txnSeqAligned,
|
|
580
|
+
kind: event.type === "trace:react-selector" ? "react-selector" : "react-render",
|
|
581
|
+
label,
|
|
582
|
+
meta: metaProjection2.value
|
|
583
|
+
});
|
|
584
|
+
}
|
|
585
|
+
if (event.type === "trace:selector:eval") {
|
|
586
|
+
const data = event.data;
|
|
587
|
+
const metaInput = {
|
|
588
|
+
selectorId: data?.selectorId,
|
|
589
|
+
lane: data?.lane,
|
|
590
|
+
producer: data?.producer,
|
|
591
|
+
fallbackReason: data?.fallbackReason,
|
|
592
|
+
readsDigest: data?.readsDigest,
|
|
593
|
+
equalsKind: data?.equalsKind,
|
|
594
|
+
changed: data?.changed
|
|
595
|
+
};
|
|
596
|
+
const metaProjection2 = projectJsonValue(metaInput);
|
|
597
|
+
options?.onMetaProjection?.({
|
|
598
|
+
stats: metaProjection2.stats,
|
|
599
|
+
downgrade: metaProjection2.downgrade
|
|
600
|
+
});
|
|
601
|
+
downgrade = mergeDowngrade(downgrade, metaProjection2.downgrade);
|
|
602
|
+
return withDowngrade({
|
|
603
|
+
...base,
|
|
604
|
+
kind: "devtools",
|
|
605
|
+
label: event.type,
|
|
606
|
+
meta: metaProjection2.value
|
|
607
|
+
});
|
|
608
|
+
}
|
|
609
|
+
if (event.type === "trace:exec-vm") {
|
|
610
|
+
const data = event.data;
|
|
611
|
+
const metaInput = {
|
|
612
|
+
version: data?.version,
|
|
613
|
+
stage: data?.stage,
|
|
614
|
+
hit: data?.hit,
|
|
615
|
+
reason: data?.reason,
|
|
616
|
+
serviceId: data?.serviceId,
|
|
617
|
+
implId: data?.implId
|
|
618
|
+
};
|
|
619
|
+
const metaProjection2 = projectJsonValue(metaInput);
|
|
620
|
+
options?.onMetaProjection?.({
|
|
621
|
+
stats: metaProjection2.stats,
|
|
622
|
+
downgrade: metaProjection2.downgrade
|
|
623
|
+
});
|
|
624
|
+
downgrade = mergeDowngrade(downgrade, metaProjection2.downgrade);
|
|
625
|
+
return withDowngrade({
|
|
626
|
+
...base,
|
|
627
|
+
kind: "devtools",
|
|
628
|
+
label: event.type,
|
|
629
|
+
meta: metaProjection2.value
|
|
630
|
+
});
|
|
631
|
+
}
|
|
632
|
+
if (event.type === "trace:trait:converge") {
|
|
633
|
+
const stripHeavyLight = (value) => {
|
|
634
|
+
if (!value || typeof value !== "object" || Array.isArray(value)) return value;
|
|
635
|
+
const anyValue = value;
|
|
636
|
+
const dirty = anyValue.dirty;
|
|
637
|
+
const dirtySlim = dirty && typeof dirty === "object" && !Array.isArray(dirty) ? {
|
|
638
|
+
dirtyAll: dirty.dirtyAll,
|
|
639
|
+
...typeof dirty.reason === "string" ? { reason: dirty.reason } : null
|
|
640
|
+
} : void 0;
|
|
641
|
+
const { top3, dirtyRoots, ...rest } = anyValue;
|
|
642
|
+
return dirtySlim ? { ...rest, dirty: dirtySlim } : rest;
|
|
643
|
+
};
|
|
644
|
+
const stripHeavySampled = (value) => {
|
|
645
|
+
if (!value || typeof value !== "object" || Array.isArray(value)) return value;
|
|
646
|
+
const anyValue = value;
|
|
647
|
+
const dirty = anyValue.dirty;
|
|
648
|
+
const dirtySlim = dirty && typeof dirty === "object" && !Array.isArray(dirty) ? {
|
|
649
|
+
dirtyAll: dirty.dirtyAll,
|
|
650
|
+
...typeof dirty.reason === "string" ? { reason: dirty.reason } : null
|
|
651
|
+
} : void 0;
|
|
652
|
+
const { dirtyRoots, ...rest } = anyValue;
|
|
653
|
+
return dirtySlim ? { ...rest, dirty: dirtySlim } : rest;
|
|
654
|
+
};
|
|
655
|
+
const data = event.data;
|
|
656
|
+
const metaInput = diagnosticsLevel2 === "light" ? stripHeavyLight(data) : diagnosticsLevel2 === "sampled" ? stripHeavySampled(data) : data;
|
|
657
|
+
const metaProjection2 = projectJsonValue(metaInput);
|
|
658
|
+
options?.onMetaProjection?.({
|
|
659
|
+
stats: metaProjection2.stats,
|
|
660
|
+
downgrade: metaProjection2.downgrade
|
|
661
|
+
});
|
|
662
|
+
downgrade = mergeDowngrade(downgrade, metaProjection2.downgrade);
|
|
663
|
+
return withDowngrade({
|
|
664
|
+
...base,
|
|
665
|
+
kind: "trait:converge",
|
|
666
|
+
label: "trait:converge",
|
|
667
|
+
meta: metaProjection2.value
|
|
668
|
+
});
|
|
669
|
+
}
|
|
670
|
+
if (event.type === "trace:trait:check") {
|
|
671
|
+
const stripHeavy = (value) => {
|
|
672
|
+
if (!value || typeof value !== "object" || Array.isArray(value)) return value;
|
|
673
|
+
const anyValue = value;
|
|
674
|
+
const degraded = anyValue.degraded;
|
|
675
|
+
const degradedSlim = degraded && typeof degraded === "object" && !Array.isArray(degraded) ? { kind: degraded.kind } : void 0;
|
|
676
|
+
const { degraded: _degraded, ...rest } = anyValue;
|
|
677
|
+
return degradedSlim ? { ...rest, degraded: degradedSlim } : rest;
|
|
678
|
+
};
|
|
679
|
+
const data = event.data;
|
|
680
|
+
const metaInput = isLightLike ? stripHeavy(data) : data;
|
|
681
|
+
const metaProjection2 = projectJsonValue(metaInput);
|
|
682
|
+
options?.onMetaProjection?.({
|
|
683
|
+
stats: metaProjection2.stats,
|
|
684
|
+
downgrade: metaProjection2.downgrade
|
|
685
|
+
});
|
|
686
|
+
downgrade = mergeDowngrade(downgrade, metaProjection2.downgrade);
|
|
687
|
+
return withDowngrade({
|
|
688
|
+
...base,
|
|
689
|
+
kind: "trait:check",
|
|
690
|
+
label: "trait:check",
|
|
691
|
+
meta: metaProjection2.value
|
|
692
|
+
});
|
|
693
|
+
}
|
|
694
|
+
if (event.type === "trace:trait:validate") {
|
|
695
|
+
const data = event.data;
|
|
696
|
+
const metaProjection2 = projectJsonValue(data);
|
|
697
|
+
options?.onMetaProjection?.({
|
|
698
|
+
stats: metaProjection2.stats,
|
|
699
|
+
downgrade: metaProjection2.downgrade
|
|
700
|
+
});
|
|
701
|
+
downgrade = mergeDowngrade(downgrade, metaProjection2.downgrade);
|
|
702
|
+
return withDowngrade({
|
|
703
|
+
...base,
|
|
704
|
+
kind: "trait:validate",
|
|
705
|
+
label: "trait:validate",
|
|
706
|
+
meta: metaProjection2.value
|
|
707
|
+
});
|
|
708
|
+
}
|
|
709
|
+
if (event.type === "trace:module:traits") {
|
|
710
|
+
const data = event.data;
|
|
711
|
+
const metaInput = isLightLike ? {
|
|
712
|
+
digest: data?.digest,
|
|
713
|
+
count: data?.count
|
|
714
|
+
} : {
|
|
715
|
+
digest: data?.digest,
|
|
716
|
+
count: data?.count,
|
|
717
|
+
traits: data?.traits,
|
|
718
|
+
provenanceIndex: data?.provenanceIndex
|
|
719
|
+
};
|
|
720
|
+
const metaProjection2 = projectJsonValue(metaInput);
|
|
721
|
+
options?.onMetaProjection?.({
|
|
722
|
+
stats: metaProjection2.stats,
|
|
723
|
+
downgrade: metaProjection2.downgrade
|
|
724
|
+
});
|
|
725
|
+
downgrade = mergeDowngrade(downgrade, metaProjection2.downgrade);
|
|
726
|
+
return withDowngrade({
|
|
727
|
+
...base,
|
|
728
|
+
kind: "devtools",
|
|
729
|
+
label: event.type,
|
|
730
|
+
meta: metaProjection2.value
|
|
731
|
+
});
|
|
732
|
+
}
|
|
733
|
+
if (event.type === "trace:module:traits:conflict") {
|
|
734
|
+
const data = event.data;
|
|
735
|
+
const metaInput = isLightLike ? {
|
|
736
|
+
conflictCount: data?.conflictCount,
|
|
737
|
+
traitIds: data?.traitIds
|
|
738
|
+
} : {
|
|
739
|
+
conflictCount: data?.conflictCount,
|
|
740
|
+
conflicts: data?.conflicts
|
|
741
|
+
};
|
|
742
|
+
const metaProjection2 = projectJsonValue(metaInput);
|
|
743
|
+
options?.onMetaProjection?.({
|
|
744
|
+
stats: metaProjection2.stats,
|
|
745
|
+
downgrade: metaProjection2.downgrade
|
|
746
|
+
});
|
|
747
|
+
downgrade = mergeDowngrade(downgrade, metaProjection2.downgrade);
|
|
748
|
+
return withDowngrade({
|
|
749
|
+
...base,
|
|
750
|
+
kind: "devtools",
|
|
751
|
+
label: event.type,
|
|
752
|
+
meta: metaProjection2.value
|
|
753
|
+
});
|
|
754
|
+
}
|
|
755
|
+
if (event.type === "trace:module:descriptor") {
|
|
756
|
+
const data = event.data;
|
|
757
|
+
const metaInput = isLightLike ? {
|
|
758
|
+
id: data?.id,
|
|
759
|
+
traits: data?.traits,
|
|
760
|
+
source: data?.source
|
|
761
|
+
} : { data };
|
|
762
|
+
const metaProjection2 = projectJsonValue(metaInput);
|
|
763
|
+
options?.onMetaProjection?.({
|
|
764
|
+
stats: metaProjection2.stats,
|
|
765
|
+
downgrade: metaProjection2.downgrade
|
|
766
|
+
});
|
|
767
|
+
downgrade = mergeDowngrade(downgrade, metaProjection2.downgrade);
|
|
768
|
+
return withDowngrade({
|
|
769
|
+
...base,
|
|
770
|
+
kind: "devtools",
|
|
771
|
+
label: event.type,
|
|
772
|
+
meta: metaProjection2.value
|
|
773
|
+
});
|
|
774
|
+
}
|
|
775
|
+
if (event.type === "trace:effectop") {
|
|
776
|
+
const data = event.data;
|
|
777
|
+
const opMeta = data?.meta;
|
|
778
|
+
const opKind = data?.kind ?? "service";
|
|
779
|
+
const label = typeof data?.name === "string" ? data.name : "effectop";
|
|
780
|
+
const moduleId2 = typeof opMeta?.moduleId === "string" ? opMeta.moduleId : moduleId;
|
|
781
|
+
const txnId2 = typeof opMeta?.txnId === "string" && opMeta.txnId.length > 0 ? opMeta.txnId : base.txnId;
|
|
782
|
+
const txnSeq2 = typeof opMeta?.txnSeq === "number" && Number.isFinite(opMeta.txnSeq) && opMeta.txnSeq >= 0 ? Math.floor(opMeta.txnSeq) : base.txnSeq;
|
|
783
|
+
const metaInput = isLightLike ? {
|
|
784
|
+
id: data?.id,
|
|
785
|
+
kind: data?.kind,
|
|
786
|
+
name: data?.name,
|
|
787
|
+
meta: opMeta
|
|
788
|
+
} : {
|
|
789
|
+
id: data?.id,
|
|
790
|
+
kind: data?.kind,
|
|
791
|
+
name: data?.name,
|
|
792
|
+
payload: data?.payload,
|
|
793
|
+
meta: opMeta
|
|
794
|
+
};
|
|
795
|
+
const metaProjection2 = projectJsonValue(metaInput);
|
|
796
|
+
options?.onMetaProjection?.({
|
|
797
|
+
stats: metaProjection2.stats,
|
|
798
|
+
downgrade: metaProjection2.downgrade
|
|
799
|
+
});
|
|
800
|
+
downgrade = mergeDowngrade(downgrade, metaProjection2.downgrade);
|
|
801
|
+
return withDowngrade({
|
|
802
|
+
...base,
|
|
803
|
+
moduleId: moduleId2,
|
|
804
|
+
txnId: txnId2,
|
|
805
|
+
txnSeq: txnSeq2,
|
|
806
|
+
kind: opKind,
|
|
807
|
+
label,
|
|
808
|
+
meta: metaProjection2.value
|
|
809
|
+
});
|
|
810
|
+
}
|
|
811
|
+
const metaProjection = projectJsonValue(
|
|
812
|
+
isLightLike ? {
|
|
813
|
+
data: void 0
|
|
814
|
+
} : {
|
|
815
|
+
data: event.data
|
|
816
|
+
}
|
|
817
|
+
);
|
|
818
|
+
options?.onMetaProjection?.({
|
|
819
|
+
stats: metaProjection.stats,
|
|
820
|
+
downgrade: metaProjection.downgrade
|
|
821
|
+
});
|
|
822
|
+
downgrade = mergeDowngrade(downgrade, metaProjection.downgrade);
|
|
823
|
+
return withDowngrade({
|
|
824
|
+
...base,
|
|
825
|
+
kind: "devtools",
|
|
826
|
+
label: event.type,
|
|
827
|
+
meta: metaProjection.value
|
|
828
|
+
});
|
|
829
|
+
}
|
|
830
|
+
}
|
|
831
|
+
};
|
|
832
|
+
|
|
833
|
+
export {
|
|
834
|
+
toSerializableErrorSummary,
|
|
835
|
+
currentDebugSinks,
|
|
836
|
+
currentRuntimeLabel,
|
|
837
|
+
currentTxnId,
|
|
838
|
+
currentDiagnosticsLevel,
|
|
839
|
+
diagnosticsLevel,
|
|
840
|
+
currentTraitConvergeDiagnosticsSampling,
|
|
841
|
+
traitConvergeDiagnosticsSampling,
|
|
842
|
+
appendSinks,
|
|
843
|
+
clearRuntimeDebugEventSeq,
|
|
844
|
+
noopLayer,
|
|
845
|
+
errorOnlyLayer,
|
|
846
|
+
browserConsoleLayer,
|
|
847
|
+
record,
|
|
848
|
+
toRuntimeDebugEventRef
|
|
849
|
+
};
|
|
850
|
+
//# sourceMappingURL=data:application/json;base64,{
  "version": 3,
  "sources": ["../../../../logix-core/src/internal/runtime/core/DebugSink.ts", "../../../../logix-core/src/internal/runtime/core/errorSummary.ts"],
  "sourcesContent": ["import { Cause, Effect, FiberRef, Layer, Logger } from 'effect'\nimport {\n  projectJsonValue,\n  type DowngradeReason as JsonDowngradeReason,\n  type JsonValue,\n  type JsonValueProjectionStats,\n} from '../../observability/jsonValue.js'\nimport type * as ReplayLog from './ReplayLog.js'\nimport {\n  toSerializableErrorSummary,\n  type DowngradeReason as ErrorDowngradeReason,\n  type SerializableErrorSummary,\n} from './errorSummary.js'\nimport * as EffectOpCore from './EffectOpCore.js'\nimport type * as ProcessProtocol from './process/protocol.js'\n\nexport interface TriggerRef {\n  readonly kind: string\n  readonly name?: string\n  readonly details?: unknown\n}\n\ntype TraceEventType = `trace:${string}`\ntype GenericTraceEventType = Exclude<\n  TraceEventType,\n  'trace:trait:converge' | 'trace:trait:check' | 'trace:trait:validate'\n>\n\n/**\n * ReplayEventRef\uFF1A\n * - Debug \u4E8B\u4EF6\u4FA7\u5F15\u7528\u7684\u201C\u56DE\u653E\u4E8B\u4EF6\u201D\u7ED3\u6784\uFF1B\n * - \u57FA\u4E8E ReplayLog.Event\uFF0C\u5E76\u8865\u9F50 txn/trigger \u7B49\u5173\u8054\u5B57\u6BB5\u4EE5\u4FBF\u4E8E\u5728 Devtools \u4E2D\u505A\u805A\u5408\u4E0E\u89E3\u91CA\u3002\n */\nexport type ReplayEventRef = ReplayLog.ReplayLogEvent & {\n  readonly txnId?: string\n  readonly trigger?: TriggerRef\n}\n\nexport type Event =\n  | {\n      readonly type: 'module:init'\n      readonly moduleId?: string\n      readonly instanceId?: string\n      readonly runtimeLabel?: string\n      readonly timestamp?: number\n    }\n  | {\n      readonly type: 'module:destroy'\n      readonly moduleId?: string\n      readonly instanceId?: string\n      readonly runtimeLabel?: string\n      readonly timestamp?: number\n    }\n  | {\n      readonly type: 'lifecycle:phase'\n      readonly moduleId?: string\n      readonly instanceId?: string\n      readonly phase: 'init' | 'run' | 'destroy' | 'platform'\n      readonly name: string\n      readonly payload?: unknown\n      readonly runtimeLabel?: string\n      readonly timestamp?: number\n    }\n  | {\n      readonly type: 'action:dispatch'\n      readonly moduleId?: string\n      readonly instanceId?: string\n      readonly action: unknown\n      readonly txnSeq?: number\n      readonly txnId?: string\n      readonly runtimeLabel?: string\n      readonly timestamp?: number\n    }\n  | {\n      readonly type: 'state:update'\n      readonly moduleId?: string\n      readonly instanceId?: string\n      readonly state: unknown\n      readonly txnSeq?: number\n      readonly txnId?: string\n      /**\n       * \u53EF\u9009\uFF1A\u672C\u6B21\u63D0\u4EA4\u805A\u5408\u7684\u5F71\u54CD\u57DF\uFF08\u5B57\u6BB5\u7EA7 dirty-set\uFF09\u3002\n       * - \u7531 Runtime \u5728 commit \u70B9\u586B\u5145\uFF1B\n       * - \u5FC5\u987B\u4FDD\u6301 Slim \u4E14\u53EF\u5E8F\u5217\u5316\uFF1B\n       * - \u53EF\u88AB Devtools \u7528\u4E8E explain \u201C\u4E3A\u4F55\u89E6\u53D1 converge/validate/\u4E3A\u4F55\u9000\u5316 full\u201D\u3002\n       */\n      readonly dirtySet?: unknown\n      /**\n       * \u53EF\u9009\uFF1A\u672C\u6B21\u63D0\u4EA4\u805A\u5408\u7684 Patch \u6570\u91CF\uFF08\u6765\u81EA StateTransaction\uFF09\uFF1B\n       * - \u4EC5\u5728\u4E8B\u52A1\u8DEF\u5F84\u4E0B\u7531 Runtime \u586B\u5145\uFF1B\n       * - Devtools \u53EF\u7528\u4F5C\u4E8B\u52A1\u6982\u8981\u4FE1\u606F\u7684\u8F7B\u91CF\u6307\u6807\u3002\n       */\n      readonly patchCount?: number\n      /**\n       * \u53EF\u9009\uFF1A\u63D0\u4EA4\u6A21\u5F0F\uFF08\u666E\u901A/\u6279\u5904\u7406/\u4F4E\u4F18\u5148\u7EA7\u7B49\uFF09\u3002\n       * - \u7531 Runtime \u586B\u5145\uFF1B\n       * - \u9ED8\u8BA4\u503C\u7531\u8C03\u7528\u65B9\u51B3\u5B9A\uFF08\u901A\u5E38\u4E3A \"normal\"\uFF09\u3002\n       */\n      readonly commitMode?: string\n      /**\n       * \u53EF\u9009\uFF1A\u5BF9\u5916\u53EF\u89C1\u6027\u4F18\u5148\u7EA7\uFF08normal/low\uFF09\u3002\n       * - \u7531 Runtime \u586B\u5145\uFF1B\n       * - \u4E3B\u8981\u7528\u4E8E React \u5916\u90E8\u8BA2\u9605\u8C03\u5EA6\uFF08\u907F\u514D\u975E\u5FC5\u8981 render\uFF09\u3002\n       */\n      readonly priority?: string\n      /**\n       * \u53EF\u9009\uFF1A\u89E6\u53D1\u672C\u6B21\u72B6\u6001\u63D0\u4EA4\u7684\u4E8B\u52A1\u6765\u6E90\u79CD\u7C7B\uFF08origin.kind\uFF09\uFF1A\n       * - \u4F8B\u5982 \"action\" / \"source-refresh\" / \"service-callback\" / \"devtools\"\uFF1B\n       * - \u4EC5\u5728\u57FA\u4E8E StateTransaction \u7684\u8DEF\u5F84\u4E0B\u7531 Runtime \u586B\u5145\uFF1B\n       * - Devtools \u53EF\u636E\u6B64\u533A\u5206\u4E1A\u52A1\u4E8B\u52A1\u4E0E Devtools time-travel \u64CD\u4F5C\u3002\n       */\n      readonly originKind?: string\n      /**\n       * \u53EF\u9009\uFF1A\u89E6\u53D1\u672C\u6B21\u72B6\u6001\u63D0\u4EA4\u7684\u4E8B\u52A1\u6765\u6E90\u540D\u79F0\uFF08origin.name\uFF09\uFF1A\n       * - \u4F8B\u5982 action dispatch / fieldPath / task:success/task:failure \u7B49\uFF1B\n       * - \u4EC5\u5728\u57FA\u4E8E StateTransaction \u7684\u8DEF\u5F84\u4E0B\u7531 Runtime \u586B\u5145\u3002\n       */\n      readonly originName?: string\n      /**\n       * \u9884\u7559\uFF1ATrait \u6536\u655B\u6458\u8981\uFF08\u7528\u4E8E Devtools \u5C55\u793A\u7A97\u53E3\u7EA7\u7EDF\u8BA1/TopN \u6210\u672C/\u964D\u7EA7\u539F\u56E0\u7B49\uFF09\u3002\n       * - Phase 2\uFF1A\u4EC5\u56FA\u5316\u5B57\u6BB5\u4F4D\uFF0C\u4E0D\u9501\u6B7B\u7ED3\u6784\uFF1B\n       * - \u540E\u7EED Phase \u4F1A\u4E0E Trait/Replay \u4E8B\u4EF6\u6A21\u578B\u5BF9\u9F50\u4E3A\u53EF\u89E3\u91CA\u7ED3\u6784\u3002\n       */\n      readonly traitSummary?: unknown\n      /**\n       * \u9884\u7559\uFF1A\u672C\u6B21\u4E8B\u52A1\u5173\u8054\u7684\u56DE\u653E\u4E8B\u4EF6\uFF08ReplayLog \u4FA7\u7684 re-emit \u4E8B\u5B9E\u6E90\uFF09\u3002\n       * - Phase 2\uFF1A\u4EC5\u56FA\u5316\u5B57\u6BB5\u4F4D\uFF1B\n       * - \u540E\u7EED Phase \u4F1A\u4E0E ReplayLog.Event \u7ED3\u6784\u5BF9\u9F50\u3002\n       */\n      readonly replayEvent?: ReplayEventRef\n      readonly runtimeLabel?: string\n      readonly timestamp?: number\n    }\n  | {\n      readonly type:\n        | 'process:start'\n        | 'process:stop'\n        | 'process:restart'\n        | 'process:trigger'\n        | 'process:dispatch'\n        | 'process:error'\n      readonly moduleId?: string\n      readonly instanceId?: string\n      readonly identity: ProcessProtocol.ProcessInstanceIdentity\n      readonly severity: 'info' | 'warning' | 'error'\n      readonly eventSeq: number\n      readonly timestampMs: number\n      readonly trigger?: ProcessProtocol.ProcessTrigger\n      readonly dispatch?: {\n        readonly moduleId: string\n        readonly instanceId: string\n        readonly actionId: string\n      }\n      readonly error?: ProcessProtocol.SerializableErrorSummary\n      readonly txnSeq?: number\n      readonly txnId?: string\n      readonly runtimeLabel?: string\n      readonly timestamp?: number\n    }\n  | {\n      readonly type: 'lifecycle:error'\n      readonly moduleId?: string\n      readonly instanceId?: string\n      readonly cause: unknown\n      readonly phase?: 'init' | 'run' | 'destroy' | 'platform'\n      readonly hook?: 'initRequired' | 'start' | 'destroy' | 'suspend' | 'resume' | 'reset' | 'unknown'\n      readonly taskId?: string\n      readonly opSeq?: number\n      readonly origin?: string\n      readonly txnSeq?: number\n      readonly runtimeLabel?: string\n      readonly timestamp?: number\n    }\n  | {\n      readonly type: 'diagnostic'\n      readonly moduleId?: string\n      readonly instanceId?: string\n      readonly code: string\n      readonly severity: 'error' | 'warning' | 'info'\n      readonly message: string\n      readonly hint?: string\n      readonly actionTag?: string\n      readonly kind?: string\n      readonly txnSeq?: number\n      readonly txnId?: string\n      readonly trigger?: TriggerRef\n      readonly runtimeLabel?: string\n      readonly timestamp?: number\n    }\n  /**\n   * trace:* \u4E8B\u4EF6\uFF1A\n   * - \u4F5C\u4E3A\u8FD0\u884C\u65F6 trace / Playground / Alignment Lab \u7684\u6269\u5C55\u94A9\u5B50\uFF1B\n   * - \u5F53\u524D\u53EA\u7EA6\u5B9A type \u524D\u7F00\u4E0E moduleId\uFF0C\u5177\u4F53 payload \u7ED3\u6784\u7531\u4E0A\u5C42\u7EA6\u5B9A\uFF08\u4F8B\u5982 data \u5185\u6302 spanId/attributes \u7B49\uFF09\u3002\n   */\n  | {\n      readonly type: 'trace:trait:converge'\n      readonly moduleId?: string\n      readonly instanceId?: string\n      readonly data: JsonValue\n      readonly txnSeq?: number\n      readonly txnId?: string\n      readonly runtimeLabel?: string\n      readonly timestamp?: number\n    }\n  | {\n      readonly type: 'trace:trait:check'\n      readonly moduleId?: string\n      readonly instanceId?: string\n      readonly data: JsonValue\n      readonly txnSeq?: number\n      readonly txnId?: string\n      readonly runtimeLabel?: string\n      readonly timestamp?: number\n    }\n  | {\n      readonly type: 'trace:trait:validate'\n      readonly moduleId?: string\n      readonly instanceId?: string\n      readonly data: JsonValue\n      readonly txnSeq?: number\n      readonly txnId?: string\n      readonly runtimeLabel?: string\n      readonly timestamp?: number\n    }\n  | {\n      readonly type: GenericTraceEventType\n      readonly moduleId?: string\n      readonly instanceId?: string\n      readonly data?: unknown\n      readonly txnSeq?: number\n      readonly runtimeLabel?: string\n      readonly timestamp?: number\n    }\n\nexport interface Sink {\n  readonly record: (event: Event) => Effect.Effect<void>\n}\nexport const currentDebugSinks = FiberRef.unsafeMake<ReadonlyArray<Sink>>([])\nexport const currentRuntimeLabel = FiberRef.unsafeMake<string | undefined>(undefined)\nexport const currentTxnId = FiberRef.unsafeMake<string | undefined>(undefined)\nexport type DiagnosticsLevel = 'off' | 'light' | 'sampled' | 'full'\nexport const currentDiagnosticsLevel = FiberRef.unsafeMake<DiagnosticsLevel>('off')\n\nexport const diagnosticsLevel = (level: DiagnosticsLevel): Layer.Layer<any, never, never> =>\n  Layer.fiberRefLocallyScopedWith(currentDiagnosticsLevel as any, () => level) as Layer.Layer<any, never, never>\n\nexport interface TraitConvergeDiagnosticsSamplingConfig {\n  /**\n   * \u6BCF\u9694 N \u4E2A txn \u91C7\u6837\u4E00\u6B21\uFF08\u786E\u5B9A\u6027\uFF0C\u57FA\u4E8E\u7A33\u5B9A txnSeq\uFF09\u3002\n   * - 1\uFF1A\u6BCF\u6B21\u90FD\u91C7\u6837\uFF08\u7B49\u4EF7 full \u7684\u8BA1\u65F6\u7C92\u5EA6\uFF0C\u4F46 payload \u4ECD\u4FDD\u6301 slim\uFF09\n   */\n  readonly sampleEveryN: number\n  /**\n   * \u8F93\u51FA\u7684 TopK hotspots \u6570\u91CF\u4E0A\u9650\uFF08\u5EFA\u8BAE \u22643\uFF09\u3002\n   */\n  readonly topK: number\n}\n\nexport const currentTraitConvergeDiagnosticsSampling = FiberRef.unsafeMake<TraitConvergeDiagnosticsSamplingConfig>({\n  sampleEveryN: 32,\n  topK: 3,\n})\n\nexport const traitConvergeDiagnosticsSampling = (\n  config: TraitConvergeDiagnosticsSamplingConfig,\n): Layer.Layer<any, never, never> =>\n  Layer.fiberRefLocallyScopedWith(currentTraitConvergeDiagnosticsSampling as any, () => config) as Layer.Layer<\n    any,\n    never,\n    never\n  >\n\nexport const appendSinks = (sinks: ReadonlyArray<Sink>): Layer.Layer<any, never, never> =>\n  Layer.fiberRefLocallyScopedWith(currentDebugSinks, (current) => [...current, ...sinks]) as Layer.Layer<\n    any,\n    never,\n    never\n  >\n\nexport type RuntimeDebugEventKind =\n  | 'action'\n  | 'state'\n  | 'service'\n  | 'process'\n  | 'trait-computed'\n  | 'trait-link'\n  | 'trait-source'\n  | 'lifecycle'\n  | 'react-render'\n  | 'devtools'\n  | 'diagnostic'\n  | (string & {})\n\nexport interface RuntimeDebugEventRef {\n  readonly eventId: string\n  readonly eventSeq: number\n  readonly moduleId: string\n  readonly instanceId: string\n  readonly runtimeLabel?: string\n  readonly txnSeq: number\n  readonly txnId?: string\n  /**\n   * linkId\uFF1A\n   * - \u5F53\u524D\u64CD\u4F5C\u94FE\u8DEF id\uFF08\u540C\u4E00\u94FE\u8DEF\u4E0B\u7684\u8FB9\u754C\u64CD\u4F5C\u5171\u4EAB\uFF09\uFF1B\n   * - \u7531 Runtime \u5728\u8FB9\u754C\u8D77\u70B9\u521B\u5EFA\uFF0C\u5E76\u901A\u8FC7 FiberRef \u5728\u5D4C\u5957/\u8DE8\u6A21\u5757\u94FE\u8DEF\u4E2D\u4F20\u9012\u3002\n   */\n  readonly linkId?: string\n  readonly timestamp: number\n  readonly kind: RuntimeDebugEventKind\n  readonly label: string\n  readonly meta?: JsonValue\n  readonly errorSummary?: SerializableErrorSummary\n  readonly downgrade?: {\n    readonly reason?: 'non_serializable' | 'oversized' | 'unknown'\n  }\n}\n\nlet nextGlobalEventSeq = 0\n\nexport const clearRuntimeDebugEventSeq = (): void => {\n  nextGlobalEventSeq = 0\n}\n\nconst nextEventSeq = (): number => {\n  nextGlobalEventSeq += 1\n  return nextGlobalEventSeq\n}\n\nconst makeEventId = (instanceId: string, eventSeq: number): string => `${instanceId}::e${eventSeq}`\n\ntype DowngradeReason = JsonDowngradeReason | ErrorDowngradeReason\n\nconst mergeDowngrade = (\n  current: DowngradeReason | undefined,\n  next: DowngradeReason | undefined,\n): DowngradeReason | undefined => {\n  if (!current) return next\n  if (!next) return current\n  if (current === 'non_serializable' || next === 'non_serializable') return 'non_serializable'\n  if (current === 'oversized' || next === 'oversized') return 'oversized'\n  return 'unknown'\n}\n\n// \u6D4F\u89C8\u5668\u73AF\u5883\u4E0B\uFF0C\u4E3A\u4E86\u51CF\u5C11 React StrictMode \u7B49\u5BFC\u81F4\u7684\u91CD\u590D\u65E5\u5FD7\u566A\u97F3\uFF0C\n// \u5BF9 lifecycle:error \u4E0E diagnostic \u4E8B\u4EF6\u505A\u4E00\u6B21\u7B80\u5355\u53BB\u91CD\uFF1A\u540C\u4E00 moduleId+payload \u53EA\u6253\u5370\u4E00\u6B21\u3002\nconst browserLifecycleSeen = new Set<string>()\nconst browserDiagnosticSeen = new Set<string>()\n\n// \u7528\u4E8E\u5C06 trace:react-render \u4E8B\u4EF6\u4E0E\u6700\u8FD1\u4E00\u6B21 state:update \u4E8B\u52A1\u5BF9\u9F50\uFF08\u4EC5\u4F5C\u4E3A UI \u8F85\u52A9\u5173\u8054\uFF09\u3002\nconst lastTxnByInstance = new Map<string, { readonly txnId: string; readonly txnSeq: number }>()\n\nconst lifecycleErrorLog = (event: Extract<Event, { readonly type: 'lifecycle:error' }>) => {\n  const moduleId = event.moduleId ?? 'unknown'\n  const causePretty = (() => {\n    try {\n      return Cause.pretty(event.cause as Cause.Cause<unknown>, {\n        renderErrorCause: true,\n      })\n    } catch {\n      try {\n        return JSON.stringify(event.cause, null, 2)\n      } catch {\n        return String(event.cause)\n      }\n    }\n  })()\n\n  const message = `[Logix][module=${moduleId}] lifecycle:error\\n${causePretty}`\n\n  return Effect.logError(message).pipe(\n    Effect.annotateLogs({\n      'logix.moduleId': moduleId,\n      'logix.event': 'lifecycle:error',\n      'logix.cause': causePretty,\n    }),\n  )\n}\n\nconst diagnosticLog = (event: Extract<Event, { readonly type: 'diagnostic' }>) => {\n  const moduleId = event.moduleId ?? 'unknown'\n  const header = `[Logix][module=${moduleId}] diagnostic(${event.severity})`\n  const detail = `code=${event.code} message=${event.message}${\n    event.actionTag ? ` action=${event.actionTag}` : ''\n  }${event.hint ? `\\nhint: ${event.hint}` : ''}`\n  const msg = `${header}\\n${detail}`\n\n  const base =\n    event.severity === 'warning'\n      ? Effect.logWarning(msg)\n      : event.severity === 'info'\n        ? Effect.logInfo(msg)\n        : Effect.logError(msg)\n\n  const annotations: Record<string, unknown> = {\n    'logix.moduleId': moduleId,\n    'logix.event': `diagnostic(${event.severity})`,\n    'logix.diagnostic.code': event.code,\n    'logix.diagnostic.message': event.message,\n  }\n  if (event.hint) {\n    annotations['logix.diagnostic.hint'] = event.hint\n  }\n  if (event.actionTag) {\n    annotations['logix.diagnostic.actionTag'] = event.actionTag\n  }\n\n  return base.pipe(Effect.annotateLogs(annotations))\n}\n\n/**\n * \u57FA\u4E8E FiberRef.currentDebugSinks \u7684\u9ED8\u8BA4 Layer \u7EC4\u5408\uFF1A\n * - \u4F7F\u7528 Layer.locallyScoped \u786E\u4FDD Debug sinks \u4F5C\u4E3A FiberRef \u72B6\u6001\u6CE8\u5165\uFF0C\n * - \u4E0D\u518D\u5C06 FiberRef \u8BEF\u7528\u4E3A Context.Tag\u3002\n */\nexport const noopLayer = Layer.locallyScoped(currentDebugSinks, [])\n\n/**\n * errorOnlyLayer\uFF1A\n * - \u9ED8\u8BA4\u7684 DebugSink \u5B9E\u73B0\uFF0C\u4EC5\u5173\u5FC3 lifecycle:error \u4E8B\u4EF6\uFF1B\n * - \u9002\u5408\u4F5C\u4E3A Runtime \u7684\u201C\u6700\u4F4E\u9650\u5EA6\u89C2\u6D4B\u201D\u5C42\uFF0C\u4FDD\u8BC1\u81F4\u547D\u9519\u8BEF\u4E0D\u4F1A\u6084\u7136\u6D88\u5931\uFF1B\n * - \u5176\u4ED6\u4E8B\u4EF6\uFF08module:init/destroy\u3001action:dispatch\u3001state:update\uFF09\u9ED8\u8BA4\u4E0D\u8BB0\u5F55\u3002\n */\nconst errorOnlySink: Sink = {\n  record: (event: Event) =>\n    event.type === 'lifecycle:error'\n      ? lifecycleErrorLog(event)\n      : event.type === 'diagnostic' && event.severity !== 'info'\n        ? diagnosticLog(event)\n        : Effect.void,\n}\n\nexport const errorOnlyLayer = Layer.locallyScoped(currentDebugSinks, [errorOnlySink])\n\n/**\n * consoleLayer\uFF1A\n * - \u5168\u91CF\u8C03\u8BD5\u5C42\uFF0C\u5C06\u6240\u6709 Debug \u4E8B\u4EF6\u4EE5 Effect \u65E5\u5FD7\u5F62\u5F0F\u8F93\u51FA\uFF08logfmt / structured\uFF09\uFF0C\n * - \u9002\u5408\u4F5C\u4E3A\u901A\u7528\u73AF\u5883\uFF08Node / \u6D4B\u8BD5\u73AF\u5883\uFF09\u7684\u89C2\u6D4B\u5C42\u3002\n */\nconst consoleSink: Sink = {\n  record: (event: Event) =>\n    event.type === 'lifecycle:error'\n      ? lifecycleErrorLog(event)\n      : event.type === 'diagnostic'\n        ? diagnosticLog(event)\n        : Effect.logDebug({ debugEvent: event }),\n}\n\nexport const consoleLayer = Layer.locallyScoped(currentDebugSinks, [consoleSink])\n\nconst isBrowser = typeof window !== 'undefined' && typeof document !== 'undefined'\n\n// \u6D4F\u89C8\u5668\u73AF\u5883\u4E0B\u7EDF\u4E00\u7684 Console \u6E32\u67D3\u903B\u8F91\uFF0C\u7528\u4E8E DebugSink \u7F3A\u7701\u5B9E\u73B0\u4E0E browserConsoleLayer\u3002\nconst renderBrowserConsoleEvent = (event: Event): Effect.Effect<void> => {\n  // trace:* \u4E8B\u4EF6\uFF1A\u5728\u6D4F\u89C8\u5668\u4E2D\u4EE5\u72EC\u7ACB\u5206\u7EC4\u5C55\u793A\uFF0C\u4FBF\u4E8E Playground / DevTools \u89C2\u6D4B\u3002\n  if (typeof (event as any).type === 'string' && (event as any).type.startsWith('trace:')) {\n    const moduleId = (event as any).moduleId ?? 'unknown'\n    const type = (event as any).type\n\n    return Effect.sync(() => {\n      // eslint-disable-next-line no-console\n      console.groupCollapsed(\n        '%c[Logix]%c trace %c' + moduleId + '%c ' + String(type),\n        'color:#6b7280;font-weight:bold', // tag\n        'color:#3b82f6', // label\n        'color:#9ca3af', // module id\n        'color:#6b7280', // type\n      )\n      // eslint-disable-next-line no-console\n      console.log(event)\n      // eslint-disable-next-line no-console\n      console.groupEnd()\n    })\n  }\n\n  if (event.type === 'lifecycle:error') {\n    const moduleId = event.moduleId ?? 'unknown'\n    const causePretty = (() => {\n      try {\n        return Cause.pretty(event.cause as Cause.Cause<unknown>, { renderErrorCause: true })\n      } catch {\n        try {\n          return JSON.stringify(event.cause, null, 2)\n        } catch {\n          return String(event.cause)\n        }\n      }\n    })()\n\n    const key = `${moduleId}|${causePretty}`\n    if (browserLifecycleSeen.has(key)) {\n      return Effect.void\n    }\n    browserLifecycleSeen.add(key)\n\n    return Effect.sync(() => {\n      // eslint-disable-next-line no-console\n      console.groupCollapsed(\n        '%c[Logix]%c lifecycle:error %c' + moduleId,\n        'color:#ef4444;font-weight:bold', // tag\n        'color:#ef4444', // label\n        'color:#9ca3af', // module id\n      )\n      // eslint-disable-next-line no-console\n      console.error(causePretty)\n      // eslint-disable-next-line no-console\n      console.groupEnd()\n    })\n  }\n\n  if (event.type === 'diagnostic') {\n    const moduleId = event.moduleId ?? 'unknown'\n    const detail = `code=${event.code} message=${event.message}${\n      event.actionTag ? ` action=${event.actionTag}` : ''\n    }${event.hint ? `\\nhint: ${event.hint}` : ''}`\n\n    const color =\n      event.severity === 'warning' ? 'color:#d97706' : event.severity === 'info' ? 'color:#3b82f6' : 'color:#ef4444'\n\n    const label =\n      event.severity === 'warning'\n        ? 'diagnostic(warning)'\n        : event.severity === 'info'\n          ? 'diagnostic(info)'\n          : 'diagnostic(error)'\n\n    const key = `${moduleId}|${event.code}|${event.message}`\n    if (browserDiagnosticSeen.has(key)) {\n      return Effect.void\n    }\n    browserDiagnosticSeen.add(key)\n\n    return Effect.sync(() => {\n      // eslint-disable-next-line no-console\n      console.groupCollapsed(\n        '%c[Logix]%c ' + label + '%c module=' + moduleId,\n        'color:#6b7280;font-weight:bold',\n        color,\n        'color:#9ca3af',\n      )\n      // eslint-disable-next-line no-console\n      console.log(detail)\n      // eslint-disable-next-line no-console\n      console.groupEnd()\n    })\n  }\n\n  // \u5176\u4ED6\u4E8B\u4EF6\uFF1A\u9ED8\u8BA4\u4E0D\u5728\u6D4F\u89C8\u5668\u63A7\u5236\u53F0\u8F93\u51FA\uFF0C\u4EE5\u514D\u5728\u4E1A\u52A1\u5F00\u53D1\u573A\u666F\u4E2D\u8FC7\u4E8E\u5435\u95F9\uFF1B\n  // \u5982\u9700\u67E5\u770B\u5185\u90E8\u8C03\u8BD5\u4E8B\u4EF6\uFF0C\u53EF\u901A\u8FC7\u81EA\u5B9A\u4E49 Debug Sink \u6216\u5728 Node \u73AF\u5883\u4E0B\u4F7F\u7528 consoleLayer\u3002\n  return Effect.void\n}\n\n/**\n * \u6D4F\u89C8\u5668 Console \u8C03\u8BD5\u5C42\uFF1A\n * - \u5728\u6D4F\u89C8\u5668\u73AF\u5883\u4E0B\u4F7F\u7528 console.groupCollapsed + \u5F69\u8272 label \u6A21\u62DF pretty logger \u7684\u5206\u7EC4\u6548\u679C\uFF1B\n * - \u5728\u975E\u6D4F\u89C8\u5668\u73AF\u5883\u4E0B\u56DE\u9000\u5230 consoleLayer \u7684 Effect \u65E5\u5FD7\u5B9E\u73B0\u3002\n */\nconst browserConsoleSink: Sink = {\n  record: (event: Event) => {\n    if (!isBrowser) {\n      // \u975E\u6D4F\u89C8\u5668\u73AF\u5883\uFF1A\u9000\u56DE\u5230 Effect.log* \u7684 consoleLayer \u884C\u4E3A\n      return event.type === 'lifecycle:error'\n        ? lifecycleErrorLog(event)\n        : event.type === 'diagnostic'\n          ? diagnosticLog(event)\n          : Effect.logDebug({ debugEvent: event })\n    }\n\n    return renderBrowserConsoleEvent(event)\n  },\n}\n\nexport const browserConsoleLayer = Layer.locallyScoped(currentDebugSinks, [browserConsoleSink])\n\n/**\n * \u6D4F\u89C8\u5668\u53CB\u597D\u7684 Logger \u5C42\uFF1A\u4F7F\u7528 Effect \u5B98\u65B9\u7684 pretty logger\uFF08browser \u6A21\u5F0F\uFF09\u66FF\u6362\u9ED8\u8BA4 logger\u3002\n * - \u4E0D\u518D\u624B\u5199 console \u6837\u5F0F\uFF0C\u76F4\u63A5\u590D\u7528 Effect \u7684\u5F69\u8272/\u5206\u7EC4\u683C\u5F0F\uFF1B\n * - \u5728\u670D\u52A1\u7AEF\u73AF\u5883\u4E0B\u4E5F\u80FD\u5B89\u5168\u9000\u5316\u4E3A\u9ED8\u8BA4 logger\u3002\n */\nexport const browserPrettyLoggerLayer = Logger.replace(\n  Logger.defaultLogger,\n  Logger.prettyLogger({ mode: 'browser', colors: true }),\n)\n\n/**\n * defaultLayer\uFF1A\n * - \u516C\u5171\u9ED8\u8BA4\u5C42\uFF0C\u5F53\u524D\u7B49\u540C\u4E8E errorOnlyLayer\uFF1B\n * - \u4EC5\u8BB0\u5F55 lifecycle:error\uFF0C\u907F\u514D\u5728\u9ED8\u8BA4\u60C5\u51B5\u4E0B\u5BF9 action/state \u6253\u5370\u5927\u91CF\u65E5\u5FD7\u3002\n */\nexport const defaultLayer = errorOnlyLayer\n\nexport const record = (event: Event) =>\n  Effect.gen(function* () {\n    const sinks = yield* FiberRef.get(currentDebugSinks)\n\n    // Fast path: when no sinks are installed, only a small subset of events are ever surfaced.\n    // Avoid paying per-event FiberRef + enrichment costs for high-frequency events like state:update.\n    if (sinks.length === 0) {\n      if (isBrowser) {\n        if (event.type === 'lifecycle:error' || event.type === 'diagnostic') {\n          yield* renderBrowserConsoleEvent(event)\n          return\n        }\n        yield* Effect.void\n        return\n      }\n\n      if (event.type === 'lifecycle:error') {\n        yield* lifecycleErrorLog(event)\n        return\n      }\n      if (event.type === 'diagnostic') {\n        yield* diagnosticLog(event)\n        return\n      }\n      yield* Effect.void\n      return\n    }\n\n    // \u4E3A Debug.Event \u8865\u5168\u57FA\u7840\u5B57\u6BB5\uFF1A\n    // - timestamp\uFF1A\u7528\u4E8E Devtools/Timeline/Overview \u505A\u65F6\u95F4\u805A\u5408\uFF0C\u907F\u514D UI \u4FA7\u7528 Date.now()\u201C\u9996\u6B21\u89C2\u5BDF\u65F6\u95F4\u201D\u5BFC\u81F4\u5931\u771F\uFF1B\n    // - runtimeLabel\uFF1A\u6765\u81EA FiberRef\uFF0C\u4FBF\u4E8E\u6309 runtime \u7EF4\u5EA6\u5206\u7EC4\uFF08\u4EC5\u5728\u4E8B\u4EF6\u672A\u663E\u5F0F\u63D0\u4F9B\u65F6\u6CE8\u5165\uFF09\u3002\n    const now = Date.now()\n    const enriched = event as Event\n    if (enriched.timestamp === undefined) {\n      ;(enriched as any).timestamp = now\n    }\n    if (enriched.runtimeLabel === undefined) {\n      const runtimeLabel = yield* FiberRef.get(currentRuntimeLabel)\n      if (runtimeLabel) {\n        ;(enriched as any).runtimeLabel = runtimeLabel\n      }\n    }\n    if (enriched.type === 'diagnostic' && (enriched as any).txnId === undefined) {\n      const txnId = yield* FiberRef.get(currentTxnId)\n      if (txnId) {\n        ;(enriched as any).txnId = txnId\n      }\n    }\n    // linkId \u4EC5\u5BF9 EffectOp \u4E8B\u4EF6\u6709\u610F\u4E49\uFF1A\u907F\u514D\u5728\u9AD8\u9891\u4E8B\u4EF6\uFF08state:update \u7B49\uFF09\u4E0A\u989D\u5916\u8BFB\u53D6 FiberRef\u3002\n    if ((enriched as any).type === 'trace:effectop' && (enriched as any).linkId === undefined) {\n      const linkId = yield* FiberRef.get(EffectOpCore.currentLinkId)\n      if (linkId) {\n        ;(enriched as any).linkId = linkId\n      }\n    }\n\n    if (sinks.length === 1) {\n      yield* sinks[0]!.record(enriched)\n      return\n    }\n\n    yield* Effect.forEach(sinks, (sink) => sink.record(enriched), { discard: true })\n  })\n\n/**\n * \u5C06\u5185\u90E8 Debug.Event \u5F52\u4E00\u5316\u4E3A RuntimeDebugEventRef\uFF1A\n * - \u4FBF\u4E8E Devtools / Runtime \u7EDF\u4E00\u6D88\u8D39 Debug \u4E8B\u4EF6\uFF1B\n * - \u4E0D\u6539\u53D8\u539F\u6709 DebugSink \u884C\u4E3A\uFF0C\u4EC5\u63D0\u4F9B\u7ED3\u6784\u5316\u89C6\u56FE\u3002\n */\nexport const toRuntimeDebugEventRef = (\n  event: Event,\n  options?: {\n    readonly diagnosticsLevel?: DiagnosticsLevel\n    readonly eventSeq?: number\n    readonly onMetaProjection?: (projection: {\n      readonly stats: JsonValueProjectionStats\n      readonly downgrade?: JsonDowngradeReason\n    }) => void\n  },\n): RuntimeDebugEventRef | undefined => {\n  const diagnosticsLevel = options?.diagnosticsLevel ?? 'full'\n  if (diagnosticsLevel === 'off') {\n    return undefined\n  }\n\n  const isLightLike = diagnosticsLevel === 'light' || diagnosticsLevel === 'sampled'\n\n  const timestamp =\n    typeof event.timestamp === 'number' && Number.isFinite(event.timestamp) ? event.timestamp : Date.now()\n\n  const moduleIdRaw = (event as any).moduleId\n  const moduleId = typeof moduleIdRaw === 'string' && moduleIdRaw.length > 0 ? moduleIdRaw : 'unknown'\n\n  const instanceIdRaw = (event as any).instanceId\n  const instanceId = typeof instanceIdRaw === 'string' && instanceIdRaw.length > 0 ? instanceIdRaw : 'unknown'\n\n  const runtimeLabelRaw = (event as any).runtimeLabel\n  const runtimeLabel = typeof runtimeLabelRaw === 'string' && runtimeLabelRaw.length > 0 ? runtimeLabelRaw : undefined\n\n  const txnSeqRaw = (event as any).txnSeq\n  const txnSeq =\n    typeof txnSeqRaw === 'number' && Number.isFinite(txnSeqRaw) && txnSeqRaw >= 0 ? Math.floor(txnSeqRaw) : 0\n\n  const txnIdRaw = (event as any).txnId\n  const txnId =\n    typeof txnIdRaw === 'string' && txnIdRaw.length > 0\n      ? txnIdRaw\n      : txnSeq > 0\n        ? `${instanceId}::t${txnSeq}`\n        : undefined\n\n  const linkId = (() => {\n    const linkIdRaw = (event as any).linkId\n    if (typeof linkIdRaw === 'string' && linkIdRaw.length > 0) return linkIdRaw\n\n    // trace:*\uFF1A\u5141\u8BB8\u4ECE data.meta.linkId \u515C\u5E95\u63D0\u53D6\uFF08\u907F\u514D UI \u4FA7\u6DF1\u5165 meta \u6DF1\u6E0A\uFF09\u3002\n    if (typeof (event as any).type !== 'string' || !(event as any).type.startsWith('trace:')) {\n      return undefined\n    }\n\n    const data: any = (event as any).data\n    const meta: any = data?.meta\n    const linkIdFromMeta = meta?.linkId\n    if (typeof linkIdFromMeta === 'string' && linkIdFromMeta.length > 0) return linkIdFromMeta\n\n    return undefined\n  })()\n\n  const eventSeqRaw = options?.eventSeq\n  const eventSeq =\n    typeof eventSeqRaw === 'number' && Number.isFinite(eventSeqRaw) && eventSeqRaw > 0\n      ? Math.floor(eventSeqRaw)\n      : nextEventSeq()\n  const eventId = makeEventId(instanceId, eventSeq)\n\n  const base = {\n    eventId,\n    eventSeq,\n    moduleId,\n    instanceId,\n    runtimeLabel,\n    txnSeq,\n    txnId,\n    linkId,\n    timestamp,\n  } as const\n\n  let downgrade: DowngradeReason | undefined\n\n  const withDowngrade = (ref: Omit<RuntimeDebugEventRef, 'downgrade'>): RuntimeDebugEventRef => {\n    if (!downgrade) return ref\n    return { ...ref, downgrade: { reason: downgrade } }\n  }\n\n  switch (event.type) {\n    case 'module:init':\n      return withDowngrade({\n        ...base,\n        kind: 'lifecycle',\n        label: 'module:init',\n      })\n    case 'module:destroy':\n      return withDowngrade({\n        ...base,\n        kind: 'lifecycle',\n        label: 'module:destroy',\n      })\n    case 'lifecycle:phase': {\n      const e = event as Extract<Event, { readonly type: 'lifecycle:phase' }>\n      const metaInput =\n        isLightLike\n          ? { type: 'lifecycle:phase', phase: e.phase, name: e.name }\n          : { type: 'lifecycle:phase', phase: e.phase, name: e.name, payload: e.payload }\n      const metaProjection = projectJsonValue(metaInput)\n      options?.onMetaProjection?.({\n        stats: metaProjection.stats,\n        downgrade: metaProjection.downgrade,\n      })\n      downgrade = mergeDowngrade(downgrade, metaProjection.downgrade)\n      return withDowngrade({\n        ...base,\n        kind: 'lifecycle',\n        label: e.name,\n        meta: metaProjection.value,\n      })\n    }\n    case 'action:dispatch': {\n      const action: any = (event as any).action\n      const tag = action?._tag ?? action?.type ?? 'action:dispatch'\n      const label = String(tag)\n      const metaInput = isLightLike ? { actionTag: label } : { action }\n      const metaProjection = projectJsonValue(metaInput)\n      options?.onMetaProjection?.({\n        stats: metaProjection.stats,\n        downgrade: metaProjection.downgrade,\n      })\n      downgrade = mergeDowngrade(downgrade, metaProjection.downgrade)\n      return withDowngrade({\n        ...base,\n        kind: 'action',\n        label,\n        meta: metaProjection.value,\n      })\n    }\n\t    case 'state:update': {\n\t      const e = event as Extract<Event, { readonly type: 'state:update' }>\n\t      const metaInput =\n\t        isLightLike\n\t          ? {\n\t              state: e.state,\n\t              dirtySet: e.dirtySet,\n              patchCount: e.patchCount,\n              commitMode: e.commitMode,\n              priority: e.priority,\n              originKind: e.originKind,\n              originName: e.originName,\n            }\n          : {\n              state: e.state,\n              dirtySet: e.dirtySet,\n              patchCount: e.patchCount,\n              commitMode: e.commitMode,\n              priority: e.priority,\n              originKind: e.originKind,\n              originName: e.originName,\n              traitSummary: e.traitSummary,\n              replayEvent: e.replayEvent,\n            }\n      const metaProjection = projectJsonValue(metaInput)\n      options?.onMetaProjection?.({\n        stats: metaProjection.stats,\n        downgrade: metaProjection.downgrade,\n      })\n      downgrade = mergeDowngrade(downgrade, metaProjection.downgrade)\n      if (txnId) {\n        lastTxnByInstance.set(instanceId, { txnId, txnSeq })\n      }\n      return withDowngrade({\n        ...base,\n        kind: 'state',\n        label: 'state:update',\n        meta: metaProjection.value,\n      })\n    }\n    case 'process:start':\n    case 'process:stop':\n    case 'process:restart':\n    case 'process:trigger':\n    case 'process:dispatch':\n    case 'process:error': {\n      const e = event as Extract<\n        Event,\n        {\n          readonly type:\n            | 'process:start'\n            | 'process:stop'\n            | 'process:restart'\n            | 'process:trigger'\n            | 'process:dispatch'\n            | 'process:error'\n        }\n      >\n\n      const ts2 = typeof e.timestampMs === 'number' && Number.isFinite(e.timestampMs) ? e.timestampMs : timestamp\n\n      const metaInput = {\n        identity: e.identity,\n        severity: e.severity,\n        eventSeq: e.eventSeq,\n        timestampMs: e.timestampMs,\n        trigger: e.trigger,\n        dispatch: e.dispatch,\n        error: e.error,\n      }\n      const metaProjection = projectJsonValue(metaInput)\n      options?.onMetaProjection?.({\n        stats: metaProjection.stats,\n        downgrade: metaProjection.downgrade,\n      })\n      downgrade = mergeDowngrade(downgrade, metaProjection.downgrade)\n\n      const errorSummary =\n        e.type === 'process:error' || e.type === 'process:restart'\n          ? (e.error as any as SerializableErrorSummary | undefined)\n          : undefined\n\n      return withDowngrade({\n        ...base,\n        timestamp: ts2,\n        kind: 'process',\n        label: e.type,\n        meta: metaProjection.value,\n        errorSummary,\n      })\n    }\n\t    case 'lifecycle:error': {\n\t      const e = event as Extract<Event, { readonly type: 'lifecycle:error' }>\n\t      const summary = toSerializableErrorSummary(e.cause)\n\t      downgrade = mergeDowngrade(downgrade, summary.downgrade)\n\t      const metaInput =\n\t        isLightLike\n\t          ? { type: 'lifecycle:error', phase: e.phase, name: e.hook }\n\t          : {\n\t              type: 'lifecycle:error',\n\t              phase: e.phase,\n              name: e.hook,\n              hook: e.hook,\n              taskId: e.taskId,\n              origin: e.origin,\n              txnSeq: e.txnSeq,\n              opSeq: e.opSeq,\n            }\n      const metaProjection = projectJsonValue(metaInput)\n      options?.onMetaProjection?.({\n        stats: metaProjection.stats,\n        downgrade: metaProjection.downgrade,\n      })\n      downgrade = mergeDowngrade(downgrade, metaProjection.downgrade)\n      return withDowngrade({\n        ...base,\n        kind: 'lifecycle',\n        label: 'lifecycle:error',\n        meta: metaProjection.value,\n        errorSummary: summary.errorSummary,\n      })\n    }\n    case 'diagnostic': {\n      const e = event as Extract<Event, { readonly type: 'diagnostic' }>\n      const metaInput = {\n        code: e.code,\n        severity: e.severity,\n        message: e.message,\n        hint: e.hint,\n        actionTag: e.actionTag,\n        kind: e.kind,\n        trigger: e.trigger,\n      }\n      const metaProjection = projectJsonValue(metaInput)\n      options?.onMetaProjection?.({\n        stats: metaProjection.stats,\n        downgrade: metaProjection.downgrade,\n      })\n      downgrade = mergeDowngrade(downgrade, metaProjection.downgrade)\n      return withDowngrade({\n        ...base,\n        kind: 'diagnostic',\n        label: e.code,\n        meta: metaProjection.value,\n      })\n    }\n    default: {\n      if (typeof event.type !== 'string' || !event.type.startsWith('trace:')) {\n        return undefined\n      }\n\n      // trace:react-render / trace:react-selector\uFF1A\u53EA\u4FDD\u7559 Slim meta\uFF08\u5B57\u6BB5\u88C1\u526A\u7531 JsonValue \u6295\u5F71\u627F\u62C5\uFF09\u3002\n      if (event.type === 'trace:react-render' || event.type === 'trace:react-selector') {\n        const data: any = (event as any).data\n        const metaProjection = projectJsonValue(\n          isLightLike\n            ? {\n                componentLabel: data?.componentLabel,\n                selectorKey: data?.selectorKey,\n                fieldPaths: data?.fieldPaths,\n                selectorId: data?.selectorId,\n                lane: data?.lane,\n                producer: data?.producer,\n                fallbackReason: data?.fallbackReason,\n                readsDigest: data?.readsDigest,\n                equalsKind: data?.equalsKind,\n                strictModePhase: data?.strictModePhase,\n              }\n            : {\n                componentLabel: data?.componentLabel,\n                selectorKey: data?.selectorKey,\n                fieldPaths: data?.fieldPaths,\n                selectorId: data?.selectorId,\n                lane: data?.lane,\n                producer: data?.producer,\n                fallbackReason: data?.fallbackReason,\n                readsDigest: data?.readsDigest,\n                equalsKind: data?.equalsKind,\n                strictModePhase: data?.strictModePhase,\n                meta: data?.meta,\n              },\n        )\n        options?.onMetaProjection?.({\n          stats: metaProjection.stats,\n          downgrade: metaProjection.downgrade,\n        })\n        downgrade = mergeDowngrade(downgrade, metaProjection.downgrade)\n        const label =\n          typeof data?.componentLabel === 'string' && data.componentLabel.length > 0\n            ? data.componentLabel\n            : event.type === 'trace:react-selector'\n              ? 'react-selector'\n              : 'react-render'\n        const last = lastTxnByInstance.get(instanceId)\n        const txnSeqFromMeta =\n          typeof data?.meta?.txnSeq === 'number' && Number.isFinite(data.meta.txnSeq) && data.meta.txnSeq >= 0\n            ? Math.floor(data.meta.txnSeq)\n            : undefined\n        const txnIdFromMeta = typeof data?.meta?.txnId === 'string' && data.meta.txnId.length > 0 ? data.meta.txnId : undefined\n        const txnIdAligned = txnIdFromMeta ?? base.txnId ?? last?.txnId\n        const txnSeqAligned = txnSeqFromMeta ?? (base.txnSeq > 0 ? base.txnSeq : (last?.txnSeq ?? base.txnSeq))\n        return withDowngrade({\n          ...base,\n          txnId: txnIdAligned,\n          txnSeq: txnSeqAligned,\n          kind: event.type === 'trace:react-selector' ? 'react-selector' : 'react-render',\n          label,\n          meta: metaProjection.value,\n        })\n      }\n\n      // trace:selector:eval\uFF1ASelectorGraph \u5728 commit \u5185\u7684\u91CD\u7B97/\u547D\u4E2D\u8BC1\u636E\uFF08\u7528\u4E8E txn\u2192selector\u2192render \u56E0\u679C\u94FE\uFF09\u3002\n      if (event.type === 'trace:selector:eval') {\n        const data: any = (event as any).data\n        const metaInput = {\n          selectorId: data?.selectorId,\n          lane: data?.lane,\n          producer: data?.producer,\n          fallbackReason: data?.fallbackReason,\n          readsDigest: data?.readsDigest,\n          equalsKind: data?.equalsKind,\n          changed: data?.changed,\n        }\n\n        const metaProjection = projectJsonValue(metaInput)\n        options?.onMetaProjection?.({\n          stats: metaProjection.stats,\n          downgrade: metaProjection.downgrade,\n        })\n        downgrade = mergeDowngrade(downgrade, metaProjection.downgrade)\n\n        return withDowngrade({\n          ...base,\n          kind: 'devtools',\n          label: event.type,\n          meta: metaProjection.value,\n        })\n      }\n\n      // trace:exec-vm\uFF1AExec VM \u547D\u4E2D/\u672A\u547D\u4E2D\u8BC1\u636E\uFF08049\uFF09\u3002light \u6863\u4F4D\u4E5F\u4FDD\u7559\u6700\u5C0F\u6458\u8981\u5B57\u6BB5\u3002\n      if (event.type === 'trace:exec-vm') {\n        const data: any = (event as any).data\n        const metaInput = {\n          version: data?.version,\n          stage: data?.stage,\n          hit: data?.hit,\n          reason: data?.reason,\n          serviceId: data?.serviceId,\n          implId: data?.implId,\n        }\n\n        const metaProjection = projectJsonValue(metaInput)\n        options?.onMetaProjection?.({\n          stats: metaProjection.stats,\n          downgrade: metaProjection.downgrade,\n        })\n        downgrade = mergeDowngrade(downgrade, metaProjection.downgrade)\n\n        return withDowngrade({\n          ...base,\n          kind: 'devtools',\n          label: event.type,\n          meta: metaProjection.value,\n        })\n      }\n\n\t      // trace:trait:converge\uFF1A\u6536\u655B\u8BC1\u636E\u5FC5\u987B\u53EF\u5BFC\u51FA\uFF08JsonValue \u786C\u95E8\uFF09\uFF0C\u5E76\u5728 light \u6863\u4F4D\u88C1\u526A\u91CD\u5B57\u6BB5\u3002\n\t      if (event.type === 'trace:trait:converge') {\n\t        const stripHeavyLight = (value: JsonValue): JsonValue => {\n\t          if (!value || typeof value !== 'object' || Array.isArray(value)) return value\n\n\t          const anyValue = value as any\n\t          const dirty = anyValue.dirty\n          const dirtySlim =\n            dirty && typeof dirty === 'object' && !Array.isArray(dirty)\n              ? {\n                  dirtyAll: (dirty as any).dirtyAll,\n                  ...(typeof (dirty as any).reason === 'string' ? { reason: (dirty as any).reason } : null),\n                }\n              : undefined\n\n\t          const { top3, dirtyRoots, ...rest } = anyValue\n\t          return (dirtySlim ? { ...rest, dirty: dirtySlim } : rest) as JsonValue\n\t        }\n\n\t        const stripHeavySampled = (value: JsonValue): JsonValue => {\n\t          if (!value || typeof value !== 'object' || Array.isArray(value)) return value\n\n\t          const anyValue = value as any\n\t          const dirty = anyValue.dirty\n\t          const dirtySlim =\n\t            dirty && typeof dirty === 'object' && !Array.isArray(dirty)\n\t              ? {\n\t                  dirtyAll: (dirty as any).dirtyAll,\n\t                  ...(typeof (dirty as any).reason === 'string' ? { reason: (dirty as any).reason } : null),\n\t                }\n\t              : undefined\n\n\t          const { dirtyRoots, ...rest } = anyValue\n\t          return (dirtySlim ? { ...rest, dirty: dirtySlim } : rest) as JsonValue\n\t        }\n\n\t        const data = (event as Extract<Event, { readonly type: 'trace:trait:converge' }>).data\n\t        const metaInput =\n\t          diagnosticsLevel === 'light'\n\t            ? stripHeavyLight(data)\n\t            : diagnosticsLevel === 'sampled'\n\t              ? stripHeavySampled(data)\n\t              : data\n\t        const metaProjection = projectJsonValue(metaInput)\n\t        options?.onMetaProjection?.({\n\t          stats: metaProjection.stats,\n\t          downgrade: metaProjection.downgrade,\n        })\n        downgrade = mergeDowngrade(downgrade, metaProjection.downgrade)\n\n        return withDowngrade({\n          ...base,\n          kind: 'trait:converge',\n          label: 'trait:converge',\n          meta: metaProjection.value,\n        })\n      }\n\n      // trace:trait:check\uFF1A\u6821\u9A8C\u8BCA\u65AD\u5FC5\u987B\u53EF\u5BFC\u51FA\uFF0C\u5E76\u5728 light \u6863\u4F4D\u4FDD\u6301 Slim\uFF08\u4E0D\u4E22\u5173\u952E\u5B57\u6BB5\uFF09\u3002\n      if (event.type === 'trace:trait:check') {\n\t        const stripHeavy = (value: JsonValue): JsonValue => {\n\t          if (!value || typeof value !== 'object' || Array.isArray(value)) return value\n          const anyValue = value as any\n          const degraded = anyValue.degraded\n          const degradedSlim =\n            degraded && typeof degraded === 'object' && !Array.isArray(degraded)\n              ? { kind: (degraded as any).kind }\n              : undefined\n\n          const { degraded: _degraded, ...rest } = anyValue\n          return (degradedSlim ? { ...rest, degraded: degradedSlim } : rest) as JsonValue\n\t        }\n\n\t        const data = (event as Extract<Event, { readonly type: 'trace:trait:check' }>).data\n\t        const metaInput = isLightLike ? stripHeavy(data) : data\n\t        const metaProjection = projectJsonValue(metaInput)\n        options?.onMetaProjection?.({\n          stats: metaProjection.stats,\n          downgrade: metaProjection.downgrade,\n        })\n        downgrade = mergeDowngrade(downgrade, metaProjection.downgrade)\n\n        return withDowngrade({\n          ...base,\n          kind: 'trait:check',\n          label: 'trait:check',\n          meta: metaProjection.value,\n        })\n      }\n\n      // trace:trait:validate\uFF1A\u6821\u9A8C\u51B3\u7B56\u6458\u8981\u5FC5\u987B\u53EF\u5BFC\u51FA\uFF0C\u4E14\u5728 light \u6863\u4F4D\u4FDD\u6301 Slim\uFF08\u9ED8\u8BA4\u4E0D\u643A\u5E26\u91CD\u5B57\u6BB5\uFF09\u3002\n      if (event.type === 'trace:trait:validate') {\n        const data = (event as Extract<Event, { readonly type: 'trace:trait:validate' }>).data\n        const metaProjection = projectJsonValue(data)\n        options?.onMetaProjection?.({\n          stats: metaProjection.stats,\n          downgrade: metaProjection.downgrade,\n        })\n        downgrade = mergeDowngrade(downgrade, metaProjection.downgrade)\n\n        return withDowngrade({\n          ...base,\n          kind: 'trait:validate',\n          label: 'trait:validate',\n          meta: metaProjection.value,\n        })\n      }\n\n      // trace:module:traits\uFF1Atraits \u6700\u7EC8\u5FEB\u7167\u5FC5\u987B\u53EF\u5BFC\u51FA\uFF0C\u5E76\u5728 light \u6863\u4F4D\u4FDD\u6301 Slim\uFF08digest/count\uFF09\u3002\n\t      if (event.type === 'trace:module:traits') {\n\t        const data: any = (event as any).data\n\t        const metaInput =\n\t          isLightLike\n\t            ? {\n\t                digest: data?.digest,\n\t                count: data?.count,\n              }\n            : {\n                digest: data?.digest,\n                count: data?.count,\n                traits: data?.traits,\n                provenanceIndex: data?.provenanceIndex,\n              }\n\n        const metaProjection = projectJsonValue(metaInput)\n        options?.onMetaProjection?.({\n          stats: metaProjection.stats,\n          downgrade: metaProjection.downgrade,\n        })\n        downgrade = mergeDowngrade(downgrade, metaProjection.downgrade)\n\n        return withDowngrade({\n          ...base,\n          kind: 'devtools',\n          label: event.type,\n          meta: metaProjection.value,\n        })\n      }\n\n      // trace:module:traits:conflict\uFF1A\u51B2\u7A81\u7EC6\u8282\u5FC5\u987B\u53EF\u5BFC\u51FA\uFF0C\u907F\u514D\u4F9D\u8D56 lifecycle:error \u7684\u622A\u65AD message\u3002\n\t      if (event.type === 'trace:module:traits:conflict') {\n\t        const data: any = (event as any).data\n\t        const metaInput =\n\t          isLightLike\n\t            ? {\n\t                conflictCount: data?.conflictCount,\n\t                traitIds: data?.traitIds,\n              }\n            : {\n                conflictCount: data?.conflictCount,\n                conflicts: data?.conflicts,\n              }\n\n        const metaProjection = projectJsonValue(metaInput)\n        options?.onMetaProjection?.({\n          stats: metaProjection.stats,\n          downgrade: metaProjection.downgrade,\n        })\n        downgrade = mergeDowngrade(downgrade, metaProjection.downgrade)\n\n        return withDowngrade({\n          ...base,\n          kind: 'devtools',\n          label: event.type,\n          meta: metaProjection.value,\n        })\n      }\n\n      // trace:module:descriptor\uFF1A\u5728 light \u6863\u4F4D\u4E5F\u4FDD\u7559\u5173\u952E\u951A\u70B9\uFF08\u907F\u514D data \u88AB\u5B8C\u5168\u88C1\u526A\uFF09\u3002\n\t      if (event.type === 'trace:module:descriptor') {\n\t        const data: any = (event as any).data\n\t        const metaInput =\n\t          isLightLike\n\t            ? {\n\t                id: data?.id,\n\t                traits: data?.traits,\n\t                source: data?.source,\n              }\n            : { data }\n\n        const metaProjection = projectJsonValue(metaInput)\n        options?.onMetaProjection?.({\n          stats: metaProjection.stats,\n          downgrade: metaProjection.downgrade,\n        })\n        downgrade = mergeDowngrade(downgrade, metaProjection.downgrade)\n\n        return withDowngrade({\n          ...base,\n          kind: 'devtools',\n          label: event.type,\n          meta: metaProjection.value,\n        })\n      }\n\n      // trace:effectop\uFF1A\u4FDD\u7559 Slim op meta\uFF0C\u5E76\u4F18\u5148\u4F7F\u7528 EffectOp.meta.moduleId\uFF08\u82E5\u5B58\u5728\uFF09\u3002\n      if (event.type === 'trace:effectop') {\n        const data: any = (event as any).data\n        const opMeta: any = data?.meta\n        const opKind = (data?.kind ?? 'service') as RuntimeDebugEventKind\n        const label = typeof data?.name === 'string' ? data.name : 'effectop'\n        const moduleId2 = typeof opMeta?.moduleId === 'string' ? opMeta.moduleId : moduleId\n        const txnId2 = typeof opMeta?.txnId === 'string' && opMeta.txnId.length > 0 ? opMeta.txnId : base.txnId\n        const txnSeq2 =\n          typeof opMeta?.txnSeq === 'number' && Number.isFinite(opMeta.txnSeq) && opMeta.txnSeq >= 0\n            ? Math.floor(opMeta.txnSeq)\n            : base.txnSeq\n\n\t        const metaInput =\n\t          isLightLike\n\t            ? {\n\t                id: data?.id,\n\t                kind: data?.kind,\n\t                name: data?.name,\n                meta: opMeta,\n              }\n            : {\n                id: data?.id,\n                kind: data?.kind,\n                name: data?.name,\n                payload: data?.payload,\n                meta: opMeta,\n              }\n\n        const metaProjection = projectJsonValue(metaInput)\n        options?.onMetaProjection?.({\n          stats: metaProjection.stats,\n          downgrade: metaProjection.downgrade,\n        })\n        downgrade = mergeDowngrade(downgrade, metaProjection.downgrade)\n\n        return withDowngrade({\n          ...base,\n          moduleId: moduleId2,\n          txnId: txnId2,\n          txnSeq: txnSeq2,\n          kind: opKind,\n          label,\n          meta: metaProjection.value,\n        })\n      }\n\n\t      // \u5176\u4ED6 trace:*\uFF1A\u7EDF\u4E00\u5F52\u7C7B\u4E3A devtools\uFF0C\u5E76\u6309\u6863\u4F4D\u88C1\u526A meta\u3002\n\t      const metaProjection = projectJsonValue(\n\t        isLightLike\n\t          ? {\n\t              data: undefined,\n\t            }\n          : {\n              data: (event as any).data,\n            },\n      )\n      options?.onMetaProjection?.({\n        stats: metaProjection.stats,\n        downgrade: metaProjection.downgrade,\n      })\n      downgrade = mergeDowngrade(downgrade, metaProjection.downgrade)\n      return withDowngrade({\n        ...base,\n        kind: 'devtools',\n        label: event.type,\n        meta: metaProjection.value,\n      })\n    }\n  }\n}\n", "import { Cause } from 'effect'\n\nexport type DowngradeReason = 'non_serializable' | 'oversized' | 'unknown'\n\nexport interface SerializableErrorSummary {\n  readonly message: string\n  readonly name?: string\n  readonly code?: string\n  readonly hint?: string\n}\n\nexport interface ErrorSummaryResult {\n  readonly errorSummary: SerializableErrorSummary\n  readonly downgrade?: DowngradeReason\n}\n\nconst truncate = (value: string, maxLen: number): { readonly value: string; readonly truncated: boolean } => {\n  if (value.length <= maxLen) return { value, truncated: false }\n  return { value: value.slice(0, maxLen), truncated: true }\n}\n\nconst safeStringify = (value: unknown): { readonly ok: true; readonly json: string } | { readonly ok: false } => {\n  try {\n    return { ok: true, json: JSON.stringify(value) }\n  } catch {\n    return { ok: false }\n  }\n}\n\nconst getMessageFromUnknown = (cause: unknown): string => {\n  if (typeof cause === 'string') return cause\n  if (typeof cause === 'number' || typeof cause === 'boolean' || typeof cause === 'bigint') return String(cause)\n  if (cause instanceof Error) return cause.message || cause.name || 'Error'\n  if (cause && typeof cause === 'object' && 'message' in (cause as any) && typeof (cause as any).message === 'string') {\n    return (cause as any).message as string\n  }\n\n  // Try Effect Cause pretty (best-effort). This may include more details than needed,\n  // so callers MUST still treat it as an untrusted/oversized string and truncate.\n  try {\n    const pretty = Cause.pretty(cause as Cause.Cause<unknown>, { renderErrorCause: true })\n    if (typeof pretty === 'string' && pretty.length > 0) return pretty\n  } catch {\n    // ignore\n  }\n\n  return 'Unknown error'\n}\n\nexport const toSerializableErrorSummary = (\n  cause: unknown,\n  options?: {\n    readonly maxMessageLength?: number\n  },\n): ErrorSummaryResult => {\n  const maxMessageLength = options?.maxMessageLength ?? 256\n\n  const messageRaw = getMessageFromUnknown(cause)\n  const { value: message, truncated } = truncate(messageRaw, maxMessageLength)\n\n  const summary: { message: string; name?: string; code?: string; hint?: string } = {\n    message,\n  }\n\n  if (cause instanceof Error) {\n    if (cause.name && cause.name !== 'Error') summary.name = cause.name\n    const anyCause = cause as any\n    if (typeof anyCause.code === 'string' && anyCause.code.length > 0) summary.code = anyCause.code\n    else if (typeof anyCause.code === 'number' && Number.isFinite(anyCause.code)) summary.code = String(anyCause.code)\n    if (typeof anyCause.hint === 'string' && anyCause.hint.length > 0) summary.hint = anyCause.hint\n    return {\n      errorSummary: summary,\n      downgrade: truncated ? 'oversized' : undefined,\n    }\n  }\n\n  if (cause && typeof cause === 'object') {\n    const anyCause = cause as any\n    if (typeof anyCause.name === 'string' && anyCause.name.length > 0) summary.name = anyCause.name\n    if (typeof anyCause.code === 'string' && anyCause.code.length > 0) summary.code = anyCause.code\n    if (typeof anyCause.hint === 'string' && anyCause.hint.length > 0) summary.hint = anyCause.hint\n  }\n\n  // If the original cause isn't JSON-serializable, mark it explicitly.\n  const stringifyResult = safeStringify(cause)\n  if (!stringifyResult.ok) {\n    return {\n      errorSummary: summary,\n      downgrade: 'non_serializable',\n    }\n  }\n\n  if (truncated) {\n    return {\n      errorSummary: summary,\n      downgrade: 'oversized',\n    }\n  }\n\n  if (message === 'Unknown error') {\n    return {\n      errorSummary: summary,\n      downgrade: 'unknown',\n    }\n  }\n\n  return { errorSummary: summary }\n}\n"],
  "mappings": "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",
  "names": ["Cause", "Cause", "diagnosticsLevel", "metaProjection"]
}

|