@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,706 @@
|
|
|
1
|
+
// @logix/core subpath bundles for @logix/sandbox
|
|
2
|
+
|
|
3
|
+
import {
|
|
4
|
+
projectJsonValue
|
|
5
|
+
} from "./chunk-RYSSJBGX.js";
|
|
6
|
+
|
|
7
|
+
// ../logix-core/src/internal/runtime/core/DebugSink.ts
|
|
8
|
+
import { Cause as Cause2, Effect, FiberRef, Layer, Logger } from "../effect.js";
|
|
9
|
+
|
|
10
|
+
// ../logix-core/src/internal/runtime/core/errorSummary.ts
|
|
11
|
+
import { Cause } from "../effect.js";
|
|
12
|
+
var truncate = (value, maxLen) => {
|
|
13
|
+
if (value.length <= maxLen) return { value, truncated: false };
|
|
14
|
+
return { value: value.slice(0, maxLen), truncated: true };
|
|
15
|
+
};
|
|
16
|
+
var safeStringify = (value) => {
|
|
17
|
+
try {
|
|
18
|
+
return { ok: true, json: JSON.stringify(value) };
|
|
19
|
+
} catch {
|
|
20
|
+
return { ok: false };
|
|
21
|
+
}
|
|
22
|
+
};
|
|
23
|
+
var getMessageFromUnknown = (cause) => {
|
|
24
|
+
if (typeof cause === "string") return cause;
|
|
25
|
+
if (typeof cause === "number" || typeof cause === "boolean" || typeof cause === "bigint") return String(cause);
|
|
26
|
+
if (cause instanceof Error) return cause.message || cause.name || "Error";
|
|
27
|
+
if (cause && typeof cause === "object" && "message" in cause && typeof cause.message === "string") {
|
|
28
|
+
return cause.message;
|
|
29
|
+
}
|
|
30
|
+
try {
|
|
31
|
+
const pretty = Cause.pretty(cause, { renderErrorCause: true });
|
|
32
|
+
if (typeof pretty === "string" && pretty.length > 0) return pretty;
|
|
33
|
+
} catch {
|
|
34
|
+
}
|
|
35
|
+
return "Unknown error";
|
|
36
|
+
};
|
|
37
|
+
var toSerializableErrorSummary = (cause, options) => {
|
|
38
|
+
const maxMessageLength = options?.maxMessageLength ?? 256;
|
|
39
|
+
const messageRaw = getMessageFromUnknown(cause);
|
|
40
|
+
const { value: message, truncated } = truncate(messageRaw, maxMessageLength);
|
|
41
|
+
const summary = {
|
|
42
|
+
message
|
|
43
|
+
};
|
|
44
|
+
if (cause instanceof Error) {
|
|
45
|
+
if (cause.name && cause.name !== "Error") summary.name = cause.name;
|
|
46
|
+
const anyCause = cause;
|
|
47
|
+
if (typeof anyCause.code === "string" && anyCause.code.length > 0) summary.code = anyCause.code;
|
|
48
|
+
else if (typeof anyCause.code === "number" && Number.isFinite(anyCause.code)) summary.code = String(anyCause.code);
|
|
49
|
+
if (typeof anyCause.hint === "string" && anyCause.hint.length > 0) summary.hint = anyCause.hint;
|
|
50
|
+
return {
|
|
51
|
+
errorSummary: summary,
|
|
52
|
+
downgrade: truncated ? "oversized" : void 0
|
|
53
|
+
};
|
|
54
|
+
}
|
|
55
|
+
if (cause && typeof cause === "object") {
|
|
56
|
+
const anyCause = cause;
|
|
57
|
+
if (typeof anyCause.name === "string" && anyCause.name.length > 0) summary.name = anyCause.name;
|
|
58
|
+
if (typeof anyCause.code === "string" && anyCause.code.length > 0) summary.code = anyCause.code;
|
|
59
|
+
if (typeof anyCause.hint === "string" && anyCause.hint.length > 0) summary.hint = anyCause.hint;
|
|
60
|
+
}
|
|
61
|
+
const stringifyResult = safeStringify(cause);
|
|
62
|
+
if (!stringifyResult.ok) {
|
|
63
|
+
return {
|
|
64
|
+
errorSummary: summary,
|
|
65
|
+
downgrade: "non_serializable"
|
|
66
|
+
};
|
|
67
|
+
}
|
|
68
|
+
if (truncated) {
|
|
69
|
+
return {
|
|
70
|
+
errorSummary: summary,
|
|
71
|
+
downgrade: "oversized"
|
|
72
|
+
};
|
|
73
|
+
}
|
|
74
|
+
if (message === "Unknown error") {
|
|
75
|
+
return {
|
|
76
|
+
errorSummary: summary,
|
|
77
|
+
downgrade: "unknown"
|
|
78
|
+
};
|
|
79
|
+
}
|
|
80
|
+
return { errorSummary: summary };
|
|
81
|
+
};
|
|
82
|
+
|
|
83
|
+
// ../logix-core/src/internal/runtime/core/DebugSink.ts
|
|
84
|
+
var currentDebugSinks = FiberRef.unsafeMake([]);
|
|
85
|
+
var currentRuntimeLabel = FiberRef.unsafeMake(void 0);
|
|
86
|
+
var currentTxnId = FiberRef.unsafeMake(void 0);
|
|
87
|
+
var currentDiagnosticsLevel = FiberRef.unsafeMake("off");
|
|
88
|
+
var nextGlobalEventSeq = 0;
|
|
89
|
+
var clearRuntimeDebugEventSeq = () => {
|
|
90
|
+
nextGlobalEventSeq = 0;
|
|
91
|
+
};
|
|
92
|
+
var nextEventSeq = () => {
|
|
93
|
+
nextGlobalEventSeq += 1;
|
|
94
|
+
return nextGlobalEventSeq;
|
|
95
|
+
};
|
|
96
|
+
var makeEventId = (instanceId, eventSeq) => `${instanceId}::e${eventSeq}`;
|
|
97
|
+
var mergeDowngrade = (current, next) => {
|
|
98
|
+
if (!current) return next;
|
|
99
|
+
if (!next) return current;
|
|
100
|
+
if (current === "non_serializable" || next === "non_serializable") return "non_serializable";
|
|
101
|
+
if (current === "oversized" || next === "oversized") return "oversized";
|
|
102
|
+
return "unknown";
|
|
103
|
+
};
|
|
104
|
+
var browserLifecycleSeen = /* @__PURE__ */ new Set();
|
|
105
|
+
var browserDiagnosticSeen = /* @__PURE__ */ new Set();
|
|
106
|
+
var lastTxnByInstance = /* @__PURE__ */ new Map();
|
|
107
|
+
var lifecycleErrorLog = (event) => {
|
|
108
|
+
const moduleId = event.moduleId ?? "unknown";
|
|
109
|
+
const causePretty = (() => {
|
|
110
|
+
try {
|
|
111
|
+
return Cause2.pretty(event.cause, {
|
|
112
|
+
renderErrorCause: true
|
|
113
|
+
});
|
|
114
|
+
} catch {
|
|
115
|
+
try {
|
|
116
|
+
return JSON.stringify(event.cause, null, 2);
|
|
117
|
+
} catch {
|
|
118
|
+
return String(event.cause);
|
|
119
|
+
}
|
|
120
|
+
}
|
|
121
|
+
})();
|
|
122
|
+
const message = `[Logix][module=${moduleId}] lifecycle:error
|
|
123
|
+
${causePretty}`;
|
|
124
|
+
return Effect.logError(message).pipe(
|
|
125
|
+
Effect.annotateLogs({
|
|
126
|
+
"logix.moduleId": moduleId,
|
|
127
|
+
"logix.event": "lifecycle:error",
|
|
128
|
+
"logix.cause": causePretty
|
|
129
|
+
})
|
|
130
|
+
);
|
|
131
|
+
};
|
|
132
|
+
var diagnosticLog = (event) => {
|
|
133
|
+
const moduleId = event.moduleId ?? "unknown";
|
|
134
|
+
const header = `[Logix][module=${moduleId}] diagnostic(${event.severity})`;
|
|
135
|
+
const detail = `code=${event.code} message=${event.message}${event.actionTag ? ` action=${event.actionTag}` : ""}${event.hint ? `
|
|
136
|
+
hint: ${event.hint}` : ""}`;
|
|
137
|
+
const msg = `${header}
|
|
138
|
+
${detail}`;
|
|
139
|
+
const base = event.severity === "warning" ? Effect.logWarning(msg) : event.severity === "info" ? Effect.logInfo(msg) : Effect.logError(msg);
|
|
140
|
+
const annotations = {
|
|
141
|
+
"logix.moduleId": moduleId,
|
|
142
|
+
"logix.event": `diagnostic(${event.severity})`,
|
|
143
|
+
"logix.diagnostic.code": event.code,
|
|
144
|
+
"logix.diagnostic.message": event.message
|
|
145
|
+
};
|
|
146
|
+
if (event.hint) {
|
|
147
|
+
annotations["logix.diagnostic.hint"] = event.hint;
|
|
148
|
+
}
|
|
149
|
+
if (event.actionTag) {
|
|
150
|
+
annotations["logix.diagnostic.actionTag"] = event.actionTag;
|
|
151
|
+
}
|
|
152
|
+
return base.pipe(Effect.annotateLogs(annotations));
|
|
153
|
+
};
|
|
154
|
+
var noopLayer = Layer.locallyScoped(currentDebugSinks, []);
|
|
155
|
+
var errorOnlySink = {
|
|
156
|
+
record: (event) => event.type === "lifecycle:error" ? lifecycleErrorLog(event) : event.type === "diagnostic" && event.severity !== "info" ? diagnosticLog(event) : Effect.void
|
|
157
|
+
};
|
|
158
|
+
var errorOnlyLayer = Layer.locallyScoped(currentDebugSinks, [errorOnlySink]);
|
|
159
|
+
var consoleSink = {
|
|
160
|
+
record: (event) => event.type === "lifecycle:error" ? lifecycleErrorLog(event) : event.type === "diagnostic" ? diagnosticLog(event) : Effect.logDebug({ debugEvent: event })
|
|
161
|
+
};
|
|
162
|
+
var consoleLayer = Layer.locallyScoped(currentDebugSinks, [consoleSink]);
|
|
163
|
+
var isBrowser = typeof window !== "undefined" && typeof document !== "undefined";
|
|
164
|
+
var renderBrowserConsoleEvent = (event) => {
|
|
165
|
+
if (typeof event.type === "string" && event.type.startsWith("trace:")) {
|
|
166
|
+
const moduleId = event.moduleId ?? "unknown";
|
|
167
|
+
const type = event.type;
|
|
168
|
+
return Effect.sync(() => {
|
|
169
|
+
console.groupCollapsed(
|
|
170
|
+
"%c[Logix]%c trace %c" + moduleId + "%c " + String(type),
|
|
171
|
+
"color:#6b7280;font-weight:bold",
|
|
172
|
+
// tag
|
|
173
|
+
"color:#3b82f6",
|
|
174
|
+
// label
|
|
175
|
+
"color:#9ca3af",
|
|
176
|
+
// module id
|
|
177
|
+
"color:#6b7280"
|
|
178
|
+
// type
|
|
179
|
+
);
|
|
180
|
+
console.log(event);
|
|
181
|
+
console.groupEnd();
|
|
182
|
+
});
|
|
183
|
+
}
|
|
184
|
+
if (event.type === "lifecycle:error") {
|
|
185
|
+
const moduleId = event.moduleId ?? "unknown";
|
|
186
|
+
const causePretty = (() => {
|
|
187
|
+
try {
|
|
188
|
+
return Cause2.pretty(event.cause, { renderErrorCause: true });
|
|
189
|
+
} catch {
|
|
190
|
+
try {
|
|
191
|
+
return JSON.stringify(event.cause, null, 2);
|
|
192
|
+
} catch {
|
|
193
|
+
return String(event.cause);
|
|
194
|
+
}
|
|
195
|
+
}
|
|
196
|
+
})();
|
|
197
|
+
const key = `${moduleId}|${causePretty}`;
|
|
198
|
+
if (browserLifecycleSeen.has(key)) {
|
|
199
|
+
return Effect.void;
|
|
200
|
+
}
|
|
201
|
+
browserLifecycleSeen.add(key);
|
|
202
|
+
return Effect.sync(() => {
|
|
203
|
+
console.groupCollapsed(
|
|
204
|
+
"%c[Logix]%c lifecycle:error %c" + moduleId,
|
|
205
|
+
"color:#ef4444;font-weight:bold",
|
|
206
|
+
// tag
|
|
207
|
+
"color:#ef4444",
|
|
208
|
+
// label
|
|
209
|
+
"color:#9ca3af"
|
|
210
|
+
// module id
|
|
211
|
+
);
|
|
212
|
+
console.error(causePretty);
|
|
213
|
+
console.groupEnd();
|
|
214
|
+
});
|
|
215
|
+
}
|
|
216
|
+
if (event.type === "diagnostic") {
|
|
217
|
+
const moduleId = event.moduleId ?? "unknown";
|
|
218
|
+
const detail = `code=${event.code} message=${event.message}${event.actionTag ? ` action=${event.actionTag}` : ""}${event.hint ? `
|
|
219
|
+
hint: ${event.hint}` : ""}`;
|
|
220
|
+
const color = event.severity === "warning" ? "color:#d97706" : event.severity === "info" ? "color:#3b82f6" : "color:#ef4444";
|
|
221
|
+
const label = event.severity === "warning" ? "diagnostic(warning)" : event.severity === "info" ? "diagnostic(info)" : "diagnostic(error)";
|
|
222
|
+
const key = `${moduleId}|${event.code}|${event.message}`;
|
|
223
|
+
if (browserDiagnosticSeen.has(key)) {
|
|
224
|
+
return Effect.void;
|
|
225
|
+
}
|
|
226
|
+
browserDiagnosticSeen.add(key);
|
|
227
|
+
return Effect.sync(() => {
|
|
228
|
+
console.groupCollapsed(
|
|
229
|
+
"%c[Logix]%c " + label + "%c module=" + moduleId,
|
|
230
|
+
"color:#6b7280;font-weight:bold",
|
|
231
|
+
color,
|
|
232
|
+
"color:#9ca3af"
|
|
233
|
+
);
|
|
234
|
+
console.log(detail);
|
|
235
|
+
console.groupEnd();
|
|
236
|
+
});
|
|
237
|
+
}
|
|
238
|
+
return Effect.void;
|
|
239
|
+
};
|
|
240
|
+
var browserConsoleSink = {
|
|
241
|
+
record: (event) => {
|
|
242
|
+
if (!isBrowser) {
|
|
243
|
+
return event.type === "lifecycle:error" ? lifecycleErrorLog(event) : event.type === "diagnostic" ? diagnosticLog(event) : Effect.logDebug({ debugEvent: event });
|
|
244
|
+
}
|
|
245
|
+
return renderBrowserConsoleEvent(event);
|
|
246
|
+
}
|
|
247
|
+
};
|
|
248
|
+
var browserConsoleLayer = Layer.locallyScoped(currentDebugSinks, [browserConsoleSink]);
|
|
249
|
+
var browserPrettyLoggerLayer = Logger.replace(
|
|
250
|
+
Logger.defaultLogger,
|
|
251
|
+
Logger.prettyLogger({ mode: "browser", colors: true })
|
|
252
|
+
);
|
|
253
|
+
var record = (event) => Effect.gen(function* () {
|
|
254
|
+
const sinks = yield* FiberRef.get(currentDebugSinks);
|
|
255
|
+
const runtimeLabel = yield* FiberRef.get(currentRuntimeLabel);
|
|
256
|
+
const txnId = yield* FiberRef.get(currentTxnId);
|
|
257
|
+
const now = Date.now();
|
|
258
|
+
const enriched = event;
|
|
259
|
+
if (enriched.timestamp === void 0) {
|
|
260
|
+
;
|
|
261
|
+
enriched.timestamp = now;
|
|
262
|
+
}
|
|
263
|
+
if (runtimeLabel && enriched.runtimeLabel === void 0) {
|
|
264
|
+
;
|
|
265
|
+
enriched.runtimeLabel = runtimeLabel;
|
|
266
|
+
}
|
|
267
|
+
if (txnId && enriched.type === "diagnostic" && enriched.txnId === void 0) {
|
|
268
|
+
;
|
|
269
|
+
enriched.txnId = txnId;
|
|
270
|
+
}
|
|
271
|
+
if (sinks.length > 0) {
|
|
272
|
+
yield* Effect.forEach(
|
|
273
|
+
sinks,
|
|
274
|
+
(sink) => sink.record(enriched),
|
|
275
|
+
{
|
|
276
|
+
discard: true
|
|
277
|
+
}
|
|
278
|
+
);
|
|
279
|
+
return;
|
|
280
|
+
}
|
|
281
|
+
if (isBrowser) {
|
|
282
|
+
yield* renderBrowserConsoleEvent(enriched);
|
|
283
|
+
return;
|
|
284
|
+
}
|
|
285
|
+
if (enriched.type === "lifecycle:error") {
|
|
286
|
+
yield* lifecycleErrorLog(enriched);
|
|
287
|
+
return;
|
|
288
|
+
}
|
|
289
|
+
if (enriched.type === "diagnostic") {
|
|
290
|
+
yield* diagnosticLog(enriched);
|
|
291
|
+
return;
|
|
292
|
+
}
|
|
293
|
+
yield* Effect.void;
|
|
294
|
+
});
|
|
295
|
+
var toRuntimeDebugEventRef = (event, options) => {
|
|
296
|
+
const diagnosticsLevel = options?.diagnosticsLevel ?? "full";
|
|
297
|
+
if (diagnosticsLevel === "off") {
|
|
298
|
+
return void 0;
|
|
299
|
+
}
|
|
300
|
+
const timestamp = typeof event.timestamp === "number" && Number.isFinite(event.timestamp) ? event.timestamp : Date.now();
|
|
301
|
+
const moduleIdRaw = event.moduleId;
|
|
302
|
+
const moduleId = typeof moduleIdRaw === "string" && moduleIdRaw.length > 0 ? moduleIdRaw : "unknown";
|
|
303
|
+
const instanceIdRaw = event.instanceId;
|
|
304
|
+
const instanceId = typeof instanceIdRaw === "string" && instanceIdRaw.length > 0 ? instanceIdRaw : "unknown";
|
|
305
|
+
const runtimeLabelRaw = event.runtimeLabel;
|
|
306
|
+
const runtimeLabel = typeof runtimeLabelRaw === "string" && runtimeLabelRaw.length > 0 ? runtimeLabelRaw : void 0;
|
|
307
|
+
const txnSeqRaw = event.txnSeq;
|
|
308
|
+
const txnSeq = typeof txnSeqRaw === "number" && Number.isFinite(txnSeqRaw) && txnSeqRaw >= 0 ? Math.floor(txnSeqRaw) : 0;
|
|
309
|
+
const txnIdRaw = event.txnId;
|
|
310
|
+
const txnId = typeof txnIdRaw === "string" && txnIdRaw.length > 0 ? txnIdRaw : txnSeq > 0 ? `${instanceId}::t${txnSeq}` : void 0;
|
|
311
|
+
const eventSeqRaw = options?.eventSeq;
|
|
312
|
+
const eventSeq = typeof eventSeqRaw === "number" && Number.isFinite(eventSeqRaw) && eventSeqRaw > 0 ? Math.floor(eventSeqRaw) : nextEventSeq();
|
|
313
|
+
const eventId = makeEventId(instanceId, eventSeq);
|
|
314
|
+
const base = {
|
|
315
|
+
eventId,
|
|
316
|
+
eventSeq,
|
|
317
|
+
moduleId,
|
|
318
|
+
instanceId,
|
|
319
|
+
runtimeLabel,
|
|
320
|
+
txnSeq,
|
|
321
|
+
txnId,
|
|
322
|
+
timestamp
|
|
323
|
+
};
|
|
324
|
+
let downgrade;
|
|
325
|
+
const withDowngrade = (ref) => {
|
|
326
|
+
if (!downgrade) return ref;
|
|
327
|
+
return { ...ref, downgrade: { reason: downgrade } };
|
|
328
|
+
};
|
|
329
|
+
switch (event.type) {
|
|
330
|
+
case "module:init":
|
|
331
|
+
return withDowngrade({
|
|
332
|
+
...base,
|
|
333
|
+
kind: "lifecycle",
|
|
334
|
+
label: "module:init"
|
|
335
|
+
});
|
|
336
|
+
case "module:destroy":
|
|
337
|
+
return withDowngrade({
|
|
338
|
+
...base,
|
|
339
|
+
kind: "lifecycle",
|
|
340
|
+
label: "module:destroy"
|
|
341
|
+
});
|
|
342
|
+
case "lifecycle:phase": {
|
|
343
|
+
const e = event;
|
|
344
|
+
const metaInput = diagnosticsLevel === "light" ? { type: "lifecycle:phase", phase: e.phase, name: e.name } : { type: "lifecycle:phase", phase: e.phase, name: e.name, payload: e.payload };
|
|
345
|
+
const metaProjection = projectJsonValue(metaInput);
|
|
346
|
+
options?.onMetaProjection?.({
|
|
347
|
+
stats: metaProjection.stats,
|
|
348
|
+
downgrade: metaProjection.downgrade
|
|
349
|
+
});
|
|
350
|
+
downgrade = mergeDowngrade(downgrade, metaProjection.downgrade);
|
|
351
|
+
return withDowngrade({
|
|
352
|
+
...base,
|
|
353
|
+
kind: "lifecycle",
|
|
354
|
+
label: e.name,
|
|
355
|
+
meta: metaProjection.value
|
|
356
|
+
});
|
|
357
|
+
}
|
|
358
|
+
case "action:dispatch": {
|
|
359
|
+
const action = event.action;
|
|
360
|
+
const tag = action?._tag ?? action?.type ?? "action:dispatch";
|
|
361
|
+
const label = String(tag);
|
|
362
|
+
const metaInput = diagnosticsLevel === "light" ? { actionTag: label } : { action };
|
|
363
|
+
const metaProjection = projectJsonValue(metaInput);
|
|
364
|
+
options?.onMetaProjection?.({
|
|
365
|
+
stats: metaProjection.stats,
|
|
366
|
+
downgrade: metaProjection.downgrade
|
|
367
|
+
});
|
|
368
|
+
downgrade = mergeDowngrade(downgrade, metaProjection.downgrade);
|
|
369
|
+
return withDowngrade({
|
|
370
|
+
...base,
|
|
371
|
+
kind: "action",
|
|
372
|
+
label,
|
|
373
|
+
meta: metaProjection.value
|
|
374
|
+
});
|
|
375
|
+
}
|
|
376
|
+
case "state:update": {
|
|
377
|
+
const e = event;
|
|
378
|
+
const metaInput = diagnosticsLevel === "light" ? {
|
|
379
|
+
state: e.state,
|
|
380
|
+
dirtySet: e.dirtySet,
|
|
381
|
+
patchCount: e.patchCount,
|
|
382
|
+
commitMode: e.commitMode,
|
|
383
|
+
priority: e.priority,
|
|
384
|
+
originKind: e.originKind,
|
|
385
|
+
originName: e.originName
|
|
386
|
+
} : {
|
|
387
|
+
state: e.state,
|
|
388
|
+
dirtySet: e.dirtySet,
|
|
389
|
+
patchCount: e.patchCount,
|
|
390
|
+
commitMode: e.commitMode,
|
|
391
|
+
priority: e.priority,
|
|
392
|
+
originKind: e.originKind,
|
|
393
|
+
originName: e.originName,
|
|
394
|
+
traitSummary: e.traitSummary,
|
|
395
|
+
replayEvent: e.replayEvent
|
|
396
|
+
};
|
|
397
|
+
const metaProjection = projectJsonValue(metaInput);
|
|
398
|
+
options?.onMetaProjection?.({
|
|
399
|
+
stats: metaProjection.stats,
|
|
400
|
+
downgrade: metaProjection.downgrade
|
|
401
|
+
});
|
|
402
|
+
downgrade = mergeDowngrade(downgrade, metaProjection.downgrade);
|
|
403
|
+
if (txnId) {
|
|
404
|
+
lastTxnByInstance.set(instanceId, { txnId, txnSeq });
|
|
405
|
+
}
|
|
406
|
+
return withDowngrade({
|
|
407
|
+
...base,
|
|
408
|
+
kind: "state",
|
|
409
|
+
label: "state:update",
|
|
410
|
+
meta: metaProjection.value
|
|
411
|
+
});
|
|
412
|
+
}
|
|
413
|
+
case "lifecycle:error": {
|
|
414
|
+
const e = event;
|
|
415
|
+
const summary = toSerializableErrorSummary(e.cause);
|
|
416
|
+
downgrade = mergeDowngrade(downgrade, summary.downgrade);
|
|
417
|
+
const metaInput = diagnosticsLevel === "light" ? { type: "lifecycle:error", phase: e.phase, name: e.hook } : {
|
|
418
|
+
type: "lifecycle:error",
|
|
419
|
+
phase: e.phase,
|
|
420
|
+
name: e.hook,
|
|
421
|
+
hook: e.hook,
|
|
422
|
+
taskId: e.taskId,
|
|
423
|
+
origin: e.origin,
|
|
424
|
+
txnSeq: e.txnSeq,
|
|
425
|
+
opSeq: e.opSeq
|
|
426
|
+
};
|
|
427
|
+
const metaProjection = projectJsonValue(metaInput);
|
|
428
|
+
options?.onMetaProjection?.({
|
|
429
|
+
stats: metaProjection.stats,
|
|
430
|
+
downgrade: metaProjection.downgrade
|
|
431
|
+
});
|
|
432
|
+
downgrade = mergeDowngrade(downgrade, metaProjection.downgrade);
|
|
433
|
+
return withDowngrade({
|
|
434
|
+
...base,
|
|
435
|
+
kind: "lifecycle",
|
|
436
|
+
label: "lifecycle:error",
|
|
437
|
+
meta: metaProjection.value,
|
|
438
|
+
errorSummary: summary.errorSummary
|
|
439
|
+
});
|
|
440
|
+
}
|
|
441
|
+
case "diagnostic": {
|
|
442
|
+
const e = event;
|
|
443
|
+
const metaInput = {
|
|
444
|
+
code: e.code,
|
|
445
|
+
severity: e.severity,
|
|
446
|
+
message: e.message,
|
|
447
|
+
hint: e.hint,
|
|
448
|
+
actionTag: e.actionTag,
|
|
449
|
+
kind: e.kind,
|
|
450
|
+
trigger: e.trigger
|
|
451
|
+
};
|
|
452
|
+
const metaProjection = projectJsonValue(metaInput);
|
|
453
|
+
options?.onMetaProjection?.({
|
|
454
|
+
stats: metaProjection.stats,
|
|
455
|
+
downgrade: metaProjection.downgrade
|
|
456
|
+
});
|
|
457
|
+
downgrade = mergeDowngrade(downgrade, metaProjection.downgrade);
|
|
458
|
+
return withDowngrade({
|
|
459
|
+
...base,
|
|
460
|
+
kind: "diagnostic",
|
|
461
|
+
label: e.code,
|
|
462
|
+
meta: metaProjection.value
|
|
463
|
+
});
|
|
464
|
+
}
|
|
465
|
+
default: {
|
|
466
|
+
if (typeof event.type !== "string" || !event.type.startsWith("trace:")) {
|
|
467
|
+
return void 0;
|
|
468
|
+
}
|
|
469
|
+
if (event.type === "trace:react-render" || event.type === "trace:react-selector") {
|
|
470
|
+
const data = event.data;
|
|
471
|
+
const metaProjection2 = projectJsonValue(
|
|
472
|
+
diagnosticsLevel === "light" ? {
|
|
473
|
+
componentLabel: data?.componentLabel,
|
|
474
|
+
selectorKey: data?.selectorKey,
|
|
475
|
+
fieldPaths: data?.fieldPaths,
|
|
476
|
+
strictModePhase: data?.strictModePhase
|
|
477
|
+
} : {
|
|
478
|
+
componentLabel: data?.componentLabel,
|
|
479
|
+
selectorKey: data?.selectorKey,
|
|
480
|
+
fieldPaths: data?.fieldPaths,
|
|
481
|
+
strictModePhase: data?.strictModePhase,
|
|
482
|
+
meta: data?.meta
|
|
483
|
+
}
|
|
484
|
+
);
|
|
485
|
+
options?.onMetaProjection?.({
|
|
486
|
+
stats: metaProjection2.stats,
|
|
487
|
+
downgrade: metaProjection2.downgrade
|
|
488
|
+
});
|
|
489
|
+
downgrade = mergeDowngrade(downgrade, metaProjection2.downgrade);
|
|
490
|
+
const label = typeof data?.componentLabel === "string" && data.componentLabel.length > 0 ? data.componentLabel : event.type === "trace:react-selector" ? "react-selector" : "react-render";
|
|
491
|
+
const last = event.type === "trace:react-render" ? lastTxnByInstance.get(instanceId) : void 0;
|
|
492
|
+
const txnIdAligned = base.txnId ?? last?.txnId;
|
|
493
|
+
const txnSeqAligned = base.txnSeq > 0 ? base.txnSeq : last?.txnSeq ?? base.txnSeq;
|
|
494
|
+
return withDowngrade({
|
|
495
|
+
...base,
|
|
496
|
+
txnId: txnIdAligned,
|
|
497
|
+
txnSeq: txnSeqAligned,
|
|
498
|
+
kind: event.type === "trace:react-selector" ? "react-selector" : "react-render",
|
|
499
|
+
label,
|
|
500
|
+
meta: metaProjection2.value
|
|
501
|
+
});
|
|
502
|
+
}
|
|
503
|
+
if (event.type === "trace:trait:converge") {
|
|
504
|
+
const stripHeavy = (value) => {
|
|
505
|
+
if (!value || typeof value !== "object" || Array.isArray(value)) return value;
|
|
506
|
+
const anyValue = value;
|
|
507
|
+
const dirty = anyValue.dirty;
|
|
508
|
+
const dirtySlim = dirty && typeof dirty === "object" && !Array.isArray(dirty) ? {
|
|
509
|
+
dirtyAll: dirty.dirtyAll,
|
|
510
|
+
...typeof dirty.reason === "string" ? { reason: dirty.reason } : null
|
|
511
|
+
} : void 0;
|
|
512
|
+
const { top3, dirtyRoots, ...rest } = anyValue;
|
|
513
|
+
return dirtySlim ? { ...rest, dirty: dirtySlim } : rest;
|
|
514
|
+
};
|
|
515
|
+
const data = event.data;
|
|
516
|
+
const metaInput = diagnosticsLevel === "light" ? stripHeavy(data) : data;
|
|
517
|
+
const metaProjection2 = projectJsonValue(metaInput);
|
|
518
|
+
options?.onMetaProjection?.({
|
|
519
|
+
stats: metaProjection2.stats,
|
|
520
|
+
downgrade: metaProjection2.downgrade
|
|
521
|
+
});
|
|
522
|
+
downgrade = mergeDowngrade(downgrade, metaProjection2.downgrade);
|
|
523
|
+
return withDowngrade({
|
|
524
|
+
...base,
|
|
525
|
+
kind: "trait:converge",
|
|
526
|
+
label: "trait:converge",
|
|
527
|
+
meta: metaProjection2.value
|
|
528
|
+
});
|
|
529
|
+
}
|
|
530
|
+
if (event.type === "trace:trait:check") {
|
|
531
|
+
const stripHeavy = (value) => {
|
|
532
|
+
if (!value || typeof value !== "object" || Array.isArray(value)) return value;
|
|
533
|
+
const anyValue = value;
|
|
534
|
+
const degraded = anyValue.degraded;
|
|
535
|
+
const degradedSlim = degraded && typeof degraded === "object" && !Array.isArray(degraded) ? { kind: degraded.kind } : void 0;
|
|
536
|
+
const { degraded: _degraded, ...rest } = anyValue;
|
|
537
|
+
return degradedSlim ? { ...rest, degraded: degradedSlim } : rest;
|
|
538
|
+
};
|
|
539
|
+
const data = event.data;
|
|
540
|
+
const metaInput = diagnosticsLevel === "light" ? stripHeavy(data) : data;
|
|
541
|
+
const metaProjection2 = projectJsonValue(metaInput);
|
|
542
|
+
options?.onMetaProjection?.({
|
|
543
|
+
stats: metaProjection2.stats,
|
|
544
|
+
downgrade: metaProjection2.downgrade
|
|
545
|
+
});
|
|
546
|
+
downgrade = mergeDowngrade(downgrade, metaProjection2.downgrade);
|
|
547
|
+
return withDowngrade({
|
|
548
|
+
...base,
|
|
549
|
+
kind: "trait:check",
|
|
550
|
+
label: "trait:check",
|
|
551
|
+
meta: metaProjection2.value
|
|
552
|
+
});
|
|
553
|
+
}
|
|
554
|
+
if (event.type === "trace:trait:validate") {
|
|
555
|
+
const data = event.data;
|
|
556
|
+
const metaProjection2 = projectJsonValue(data);
|
|
557
|
+
options?.onMetaProjection?.({
|
|
558
|
+
stats: metaProjection2.stats,
|
|
559
|
+
downgrade: metaProjection2.downgrade
|
|
560
|
+
});
|
|
561
|
+
downgrade = mergeDowngrade(downgrade, metaProjection2.downgrade);
|
|
562
|
+
return withDowngrade({
|
|
563
|
+
...base,
|
|
564
|
+
kind: "trait:validate",
|
|
565
|
+
label: "trait:validate",
|
|
566
|
+
meta: metaProjection2.value
|
|
567
|
+
});
|
|
568
|
+
}
|
|
569
|
+
if (event.type === "trace:module:traits") {
|
|
570
|
+
const data = event.data;
|
|
571
|
+
const metaInput = diagnosticsLevel === "light" ? {
|
|
572
|
+
digest: data?.digest,
|
|
573
|
+
count: data?.count
|
|
574
|
+
} : {
|
|
575
|
+
digest: data?.digest,
|
|
576
|
+
count: data?.count,
|
|
577
|
+
traits: data?.traits,
|
|
578
|
+
provenanceIndex: data?.provenanceIndex
|
|
579
|
+
};
|
|
580
|
+
const metaProjection2 = projectJsonValue(metaInput);
|
|
581
|
+
options?.onMetaProjection?.({
|
|
582
|
+
stats: metaProjection2.stats,
|
|
583
|
+
downgrade: metaProjection2.downgrade
|
|
584
|
+
});
|
|
585
|
+
downgrade = mergeDowngrade(downgrade, metaProjection2.downgrade);
|
|
586
|
+
return withDowngrade({
|
|
587
|
+
...base,
|
|
588
|
+
kind: "devtools",
|
|
589
|
+
label: event.type,
|
|
590
|
+
meta: metaProjection2.value
|
|
591
|
+
});
|
|
592
|
+
}
|
|
593
|
+
if (event.type === "trace:module:traits:conflict") {
|
|
594
|
+
const data = event.data;
|
|
595
|
+
const metaInput = diagnosticsLevel === "light" ? {
|
|
596
|
+
conflictCount: data?.conflictCount,
|
|
597
|
+
traitIds: data?.traitIds
|
|
598
|
+
} : {
|
|
599
|
+
conflictCount: data?.conflictCount,
|
|
600
|
+
conflicts: data?.conflicts
|
|
601
|
+
};
|
|
602
|
+
const metaProjection2 = projectJsonValue(metaInput);
|
|
603
|
+
options?.onMetaProjection?.({
|
|
604
|
+
stats: metaProjection2.stats,
|
|
605
|
+
downgrade: metaProjection2.downgrade
|
|
606
|
+
});
|
|
607
|
+
downgrade = mergeDowngrade(downgrade, metaProjection2.downgrade);
|
|
608
|
+
return withDowngrade({
|
|
609
|
+
...base,
|
|
610
|
+
kind: "devtools",
|
|
611
|
+
label: event.type,
|
|
612
|
+
meta: metaProjection2.value
|
|
613
|
+
});
|
|
614
|
+
}
|
|
615
|
+
if (event.type === "trace:module:descriptor") {
|
|
616
|
+
const data = event.data;
|
|
617
|
+
const metaInput = diagnosticsLevel === "light" ? {
|
|
618
|
+
id: data?.id,
|
|
619
|
+
traits: data?.traits,
|
|
620
|
+
source: data?.source
|
|
621
|
+
} : { data };
|
|
622
|
+
const metaProjection2 = projectJsonValue(metaInput);
|
|
623
|
+
options?.onMetaProjection?.({
|
|
624
|
+
stats: metaProjection2.stats,
|
|
625
|
+
downgrade: metaProjection2.downgrade
|
|
626
|
+
});
|
|
627
|
+
downgrade = mergeDowngrade(downgrade, metaProjection2.downgrade);
|
|
628
|
+
return withDowngrade({
|
|
629
|
+
...base,
|
|
630
|
+
kind: "devtools",
|
|
631
|
+
label: event.type,
|
|
632
|
+
meta: metaProjection2.value
|
|
633
|
+
});
|
|
634
|
+
}
|
|
635
|
+
if (event.type === "trace:effectop") {
|
|
636
|
+
const data = event.data;
|
|
637
|
+
const opMeta = data?.meta;
|
|
638
|
+
const opKind = data?.kind ?? "service";
|
|
639
|
+
const label = typeof data?.name === "string" ? data.name : "effectop";
|
|
640
|
+
const moduleId2 = typeof opMeta?.moduleId === "string" ? opMeta.moduleId : moduleId;
|
|
641
|
+
const txnId2 = typeof opMeta?.txnId === "string" && opMeta.txnId.length > 0 ? opMeta.txnId : base.txnId;
|
|
642
|
+
const txnSeq2 = typeof opMeta?.txnSeq === "number" && Number.isFinite(opMeta.txnSeq) && opMeta.txnSeq >= 0 ? Math.floor(opMeta.txnSeq) : base.txnSeq;
|
|
643
|
+
const metaInput = diagnosticsLevel === "light" ? {
|
|
644
|
+
id: data?.id,
|
|
645
|
+
kind: data?.kind,
|
|
646
|
+
name: data?.name,
|
|
647
|
+
meta: opMeta
|
|
648
|
+
} : {
|
|
649
|
+
id: data?.id,
|
|
650
|
+
kind: data?.kind,
|
|
651
|
+
name: data?.name,
|
|
652
|
+
payload: data?.payload,
|
|
653
|
+
meta: opMeta
|
|
654
|
+
};
|
|
655
|
+
const metaProjection2 = projectJsonValue(metaInput);
|
|
656
|
+
options?.onMetaProjection?.({
|
|
657
|
+
stats: metaProjection2.stats,
|
|
658
|
+
downgrade: metaProjection2.downgrade
|
|
659
|
+
});
|
|
660
|
+
downgrade = mergeDowngrade(downgrade, metaProjection2.downgrade);
|
|
661
|
+
return withDowngrade({
|
|
662
|
+
...base,
|
|
663
|
+
moduleId: moduleId2,
|
|
664
|
+
txnId: txnId2,
|
|
665
|
+
txnSeq: txnSeq2,
|
|
666
|
+
kind: opKind,
|
|
667
|
+
label,
|
|
668
|
+
meta: metaProjection2.value
|
|
669
|
+
});
|
|
670
|
+
}
|
|
671
|
+
const metaProjection = projectJsonValue(
|
|
672
|
+
diagnosticsLevel === "light" ? {
|
|
673
|
+
data: void 0
|
|
674
|
+
} : {
|
|
675
|
+
data: event.data
|
|
676
|
+
}
|
|
677
|
+
);
|
|
678
|
+
options?.onMetaProjection?.({
|
|
679
|
+
stats: metaProjection.stats,
|
|
680
|
+
downgrade: metaProjection.downgrade
|
|
681
|
+
});
|
|
682
|
+
downgrade = mergeDowngrade(downgrade, metaProjection.downgrade);
|
|
683
|
+
return withDowngrade({
|
|
684
|
+
...base,
|
|
685
|
+
kind: "devtools",
|
|
686
|
+
label: event.type,
|
|
687
|
+
meta: metaProjection.value
|
|
688
|
+
});
|
|
689
|
+
}
|
|
690
|
+
}
|
|
691
|
+
};
|
|
692
|
+
|
|
693
|
+
export {
|
|
694
|
+
toSerializableErrorSummary,
|
|
695
|
+
currentDebugSinks,
|
|
696
|
+
currentRuntimeLabel,
|
|
697
|
+
currentTxnId,
|
|
698
|
+
currentDiagnosticsLevel,
|
|
699
|
+
clearRuntimeDebugEventSeq,
|
|
700
|
+
noopLayer,
|
|
701
|
+
errorOnlyLayer,
|
|
702
|
+
browserConsoleLayer,
|
|
703
|
+
record,
|
|
704
|
+
toRuntimeDebugEventRef
|
|
705
|
+
};
|
|
706
|
+
//# 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\"\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\t  | {\n\t      readonly type: \"state:update\"\n\t      readonly moduleId?: string\n\t      readonly instanceId?: string\n\t      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\t       * \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\t       * - Phase 2\uFF1A\u4EC5\u56FA\u5316\u5B57\u6BB5\u4F4D\uFF1B\n\t       * - \u540E\u7EED Phase \u4F1A\u4E0E ReplayLog.Event \u7ED3\u6784\u5BF9\u9F50\u3002\n\t       */\n\t      readonly replayEvent?: ReplayEventRef\n\t      readonly runtimeLabel?: string\n\t      readonly timestamp?: number\n\t    }\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?:\n        | \"initRequired\"\n        | \"start\"\n        | \"destroy\"\n        | \"suspend\"\n        | \"resume\"\n        | \"reset\"\n        | \"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\t  | {\n\t      readonly type: \"diagnostic\"\n\t      readonly moduleId?: string\n\t      readonly instanceId?: string\n\t      readonly code: string\n\t      readonly severity: \"error\" | \"warning\" | \"info\"\n\t      readonly message: string\n\t      readonly hint?: string\n\t      readonly actionTag?: string\n\t      readonly kind?: string\n\t      readonly txnSeq?: number\n\t      readonly txnId?: string\n\t      readonly trigger?: TriggerRef\n\t      readonly runtimeLabel?: string\n\t      readonly timestamp?: number\n\t    }\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\" | \"full\"\nexport const currentDiagnosticsLevel = FiberRef.unsafeMake<DiagnosticsLevel>(\"off\")\n\nexport type RuntimeDebugEventKind =\n  | \"action\"\n  | \"state\"\n  | \"service\"\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  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\"\n        ? \"color:#d97706\"\n        : event.severity === \"info\"\n          ? \"color:#3b82f6\"\n          : \"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    const runtimeLabel = yield* FiberRef.get(currentRuntimeLabel)\n    const txnId = yield* FiberRef.get(currentTxnId)\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\tif (runtimeLabel && enriched.runtimeLabel === undefined) {\n\t  ;(enriched as any).runtimeLabel = runtimeLabel\n\t}\n\tif (txnId && enriched.type === \"diagnostic\" && (enriched as any).txnId === undefined) {\n\t  ;(enriched as any).txnId = txnId\n\t}\n\n    if (sinks.length > 0) {\n      yield* Effect.forEach(\n        sinks,\n        (sink) => sink.record(enriched),\n        {\n          discard: true,\n        },\n      )\n      return\n    }\n\n    if (isBrowser) {\n      yield* renderBrowserConsoleEvent(enriched)\n      return\n    }\n    if (enriched.type === \"lifecycle:error\") {\n      yield* lifecycleErrorLog(enriched)\n      return\n    }\n    if (enriched.type === \"diagnostic\") {\n      yield* diagnosticLog(enriched)\n      return\n    }\n    yield* Effect.void\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 timestamp =\n    typeof event.timestamp === \"number\" && Number.isFinite(event.timestamp)\n      ? event.timestamp\n      : Date.now()\n\n  const moduleIdRaw = (event as any).moduleId\n  const moduleId =\n    typeof moduleIdRaw === \"string\" && moduleIdRaw.length > 0 ? moduleIdRaw : \"unknown\"\n\n  const instanceIdRaw = (event as any).instanceId\n  const instanceId =\n    typeof instanceIdRaw === \"string\" && instanceIdRaw.length > 0\n      ? instanceIdRaw\n      : \"unknown\"\n\n  const runtimeLabelRaw = (event as any).runtimeLabel\n  const runtimeLabel =\n    typeof runtimeLabelRaw === \"string\" && runtimeLabelRaw.length > 0\n      ? runtimeLabelRaw\n      : undefined\n\n  const txnSeqRaw = (event as any).txnSeq\n  const txnSeq =\n    typeof txnSeqRaw === \"number\" && Number.isFinite(txnSeqRaw) && txnSeqRaw >= 0\n      ? Math.floor(txnSeqRaw)\n      : 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 eventSeqRaw = options?.eventSeq\n  const eventSeq =\n    typeof eventSeqRaw === \"number\" &&\n    Number.isFinite(eventSeqRaw) &&\n    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    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        diagnosticsLevel === \"light\"\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 = diagnosticsLevel === \"light\" ? { 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    case \"state:update\": {\n      const e = event as Extract<Event, { readonly type: \"state:update\" }>\n      const metaInput =\n        diagnosticsLevel === \"light\"\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            }\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 \"lifecycle:error\": {\n      const e = event as Extract<Event, { readonly type: \"lifecycle:error\" }>\n      const summary = toSerializableErrorSummary(e.cause)\n      downgrade = mergeDowngrade(downgrade, summary.downgrade)\n      const metaInput =\n        diagnosticsLevel === \"light\"\n          ? { type: \"lifecycle:error\", phase: e.phase, name: e.hook }\n          : {\n              type: \"lifecycle:error\",\n              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          diagnosticsLevel === \"light\"\n            ? {\n                componentLabel: data?.componentLabel,\n                selectorKey: data?.selectorKey,\n                fieldPaths: data?.fieldPaths,\n                strictModePhase: data?.strictModePhase,\n              }\n            : {\n                componentLabel: data?.componentLabel,\n                selectorKey: data?.selectorKey,\n                fieldPaths: data?.fieldPaths,\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 =\n          event.type === \"trace:react-render\" ? lastTxnByInstance.get(instanceId) : undefined\n        const txnIdAligned = base.txnId ?? last?.txnId\n        const txnSeqAligned = 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: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      if (event.type === \"trace:trait:converge\") {\n        const stripHeavy = (value: JsonValue): JsonValue => {\n          if (!value || typeof value !== \"object\" || Array.isArray(value)) return value\n\n          const anyValue = value as any\n          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\"\n                    ? { reason: (dirty as any).reason }\n                    : null),\n                }\n              : undefined\n\n          const { top3, dirtyRoots, ...rest } = anyValue\n          return (dirtySlim ? { ...rest, dirty: dirtySlim } : rest) as JsonValue\n        }\n\n        const data = (event as Extract<Event, { readonly type: \"trace:trait:converge\" }>).data\n        const metaInput = diagnosticsLevel === \"light\" ? stripHeavy(data) : data\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: \"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        const stripHeavy = (value: JsonValue): JsonValue => {\n          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        }\n\n        const data = (event as Extract<Event, { readonly type: \"trace:trait:check\" }>).data\n        const metaInput = diagnosticsLevel === \"light\" ? stripHeavy(data) : data\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: \"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      if (event.type === \"trace:module:traits\") {\n        const data: any = (event as any).data\n        const metaInput =\n          diagnosticsLevel === \"light\"\n            ? {\n                digest: data?.digest,\n                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      if (event.type === \"trace:module:traits:conflict\") {\n        const data: any = (event as any).data\n        const metaInput =\n          diagnosticsLevel === \"light\"\n            ? {\n                conflictCount: data?.conflictCount,\n                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      if (event.type === \"trace:module:descriptor\") {\n        const data: any = (event as any).data\n        const metaInput =\n          diagnosticsLevel === \"light\"\n            ? {\n                id: data?.id,\n                traits: data?.traits,\n                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        const metaInput =\n          diagnosticsLevel === \"light\"\n            ? {\n                id: data?.id,\n                kind: data?.kind,\n                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      // \u5176\u4ED6 trace:*\uFF1A\u7EDF\u4E00\u5F52\u7C7B\u4E3A devtools\uFF0C\u5E76\u6309\u6863\u4F4D\u88C1\u526A meta\u3002\n      const metaProjection = projectJsonValue(\n        diagnosticsLevel === \"light\"\n          ? {\n              data: undefined,\n            }\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", "metaProjection"]
}

|