@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.
Files changed (248) hide show
  1. package/LICENSE +201 -0
  2. package/package.json +3 -1
  3. package/public/sandbox/chunks/chunk-2AUQRESB.js +1114 -0
  4. package/public/sandbox/chunks/chunk-2F72LQKW.js +194 -0
  5. package/public/sandbox/chunks/chunk-2PYDGDD3.js +4071 -0
  6. package/public/sandbox/chunks/chunk-2UGKSXDZ.js +16 -0
  7. package/public/sandbox/chunks/chunk-2XVE7F26.js +153 -0
  8. package/public/sandbox/chunks/chunk-3A7TFNZN.js +219 -0
  9. package/public/sandbox/chunks/chunk-3BHC6JAV.js +1070 -0
  10. package/public/sandbox/chunks/chunk-3U4CAKCX.js +61 -0
  11. package/public/sandbox/chunks/chunk-3VU3JLZO.js +272 -0
  12. package/public/sandbox/chunks/chunk-4CPONKWY.js +1170 -0
  13. package/public/sandbox/chunks/chunk-4GMUQTWH.js +850 -0
  14. package/public/sandbox/chunks/chunk-4KIYG5E4.js +749 -0
  15. package/public/sandbox/chunks/chunk-4MY35XR3.js +175 -0
  16. package/public/sandbox/chunks/chunk-5DNHJMHA.js +69 -0
  17. package/public/sandbox/chunks/chunk-5EC4S7X6.js +42 -0
  18. package/public/sandbox/chunks/chunk-5FB7QFSH.js +227 -0
  19. package/public/sandbox/chunks/chunk-5GEYCJW2.js +206 -0
  20. package/public/sandbox/chunks/chunk-5PT7Q5SS.js +373 -0
  21. package/public/sandbox/chunks/chunk-5WN5IGKA.js +166 -0
  22. package/public/sandbox/chunks/chunk-5XOBKSOT.js +213 -0
  23. package/public/sandbox/chunks/chunk-67RVISUC.js +313 -0
  24. package/public/sandbox/chunks/chunk-6ELJEKZS.js +12 -0
  25. package/public/sandbox/chunks/chunk-6FKWRVP4.js +85 -0
  26. package/public/sandbox/chunks/chunk-6JRP52YT.js +34 -0
  27. package/public/sandbox/chunks/chunk-6JYAC3G6.js +42 -0
  28. package/public/sandbox/chunks/chunk-6TUOP63Q.js +86 -0
  29. package/public/sandbox/chunks/{chunk-A6JFUNQQ.js → chunk-74C5VW7Z.js} +2 -2
  30. package/public/sandbox/chunks/chunk-75DQFC5M.js +16 -0
  31. package/public/sandbox/chunks/{chunk-UCFEP3BH.js → chunk-7GPAF2UK.js} +1 -1
  32. package/public/sandbox/chunks/chunk-7KQFTS2Y.js +135 -0
  33. package/public/sandbox/chunks/chunk-7POKWYE3.js +112 -0
  34. package/public/sandbox/chunks/chunk-7VUEF5F3.js +395 -0
  35. package/public/sandbox/chunks/chunk-7W5APZS2.js +77 -0
  36. package/public/sandbox/chunks/chunk-A6OFCXDQ.js +397 -0
  37. package/public/sandbox/chunks/chunk-A7HLOSO6.js +216 -0
  38. package/public/sandbox/chunks/chunk-AGF4RRCB.js +408 -0
  39. package/public/sandbox/chunks/chunk-ASJSJAAL.js +122 -0
  40. package/public/sandbox/chunks/chunk-ASVMK364.js +283 -0
  41. package/public/sandbox/chunks/chunk-AUDTI2BQ.js +895 -0
  42. package/public/sandbox/chunks/chunk-B2SZTA3M.js +16 -0
  43. package/public/sandbox/chunks/chunk-B6YS2UMV.js +372 -0
  44. package/public/sandbox/chunks/chunk-BCEO3MGD.js +244 -0
  45. package/public/sandbox/chunks/chunk-BCOO65D4.js +373 -0
  46. package/public/sandbox/chunks/chunk-BJOWSSEL.js +38 -0
  47. package/public/sandbox/chunks/chunk-BS2WBFW4.js +373 -0
  48. package/public/sandbox/chunks/chunk-BUVHG3NJ.js +439 -0
  49. package/public/sandbox/chunks/chunk-BVE33AN6.js +42 -0
  50. package/public/sandbox/chunks/chunk-BWTGJZVP.js +19 -0
  51. package/public/sandbox/chunks/chunk-BXD7GZC3.js +1025 -0
  52. package/public/sandbox/chunks/chunk-BZH4EUUD.js +164 -0
  53. package/public/sandbox/chunks/{chunk-HFV5GJPK.js → chunk-C2MYMMO4.js} +3 -3
  54. package/public/sandbox/chunks/chunk-CRE4NJJ6.js +271 -0
  55. package/public/sandbox/chunks/chunk-CVZPRIDB.js +706 -0
  56. package/public/sandbox/chunks/chunk-CWOXD5NG.js +991 -0
  57. package/public/sandbox/chunks/chunk-D6DOC3BJ.js +373 -0
  58. package/public/sandbox/chunks/chunk-DEPSGFSY.js +1698 -0
  59. package/public/sandbox/chunks/chunk-DM7C5NP5.js +819 -0
  60. package/public/sandbox/chunks/chunk-DN33LMOF.js +1112 -0
  61. package/public/sandbox/chunks/{chunk-S46P7MC6.js → chunk-DT7YIIWE.js} +2 -2
  62. package/public/sandbox/chunks/chunk-DVB5WRCI.js +260 -0
  63. package/public/sandbox/chunks/{chunk-TOHCFMQS.js → chunk-E3EVW7NR.js} +11 -18
  64. package/public/sandbox/chunks/chunk-E5BV567Q.js +417 -0
  65. package/public/sandbox/chunks/chunk-E7BIWMQQ.js +203 -0
  66. package/public/sandbox/chunks/chunk-EAKGPSOQ.js +83 -0
  67. package/public/sandbox/chunks/chunk-EGUYL2ER.js +75 -0
  68. package/public/sandbox/chunks/chunk-EP5GQYZ5.js +85 -0
  69. package/public/sandbox/chunks/chunk-ET6CJEHC.js +221 -0
  70. package/public/sandbox/chunks/chunk-EU67YZHZ.js +1070 -0
  71. package/public/sandbox/chunks/{chunk-PTSJJANP.js → chunk-EYNDQLSB.js} +1 -1
  72. package/public/sandbox/chunks/{chunk-CEGSWZ5S.js → chunk-EZTMVCJF.js} +1 -1
  73. package/public/sandbox/chunks/chunk-F5CLVIS6.js +907 -0
  74. package/public/sandbox/chunks/chunk-F743SKYD.js +85 -0
  75. package/public/sandbox/chunks/chunk-FEGFZ5OX.js +86 -0
  76. package/public/sandbox/chunks/chunk-FG5B7ZX3.js +373 -0
  77. package/public/sandbox/chunks/chunk-FKZPYMDG.js +373 -0
  78. package/public/sandbox/chunks/chunk-FNLXHWIU.js +220 -0
  79. package/public/sandbox/chunks/chunk-FQRUTYAD.js +1991 -0
  80. package/public/sandbox/chunks/{chunk-VLYP4WUS.js → chunk-FY5A73NK.js} +5 -5
  81. package/public/sandbox/chunks/chunk-G7FAOG3O.js +221 -0
  82. package/public/sandbox/chunks/chunk-GFXHUC7Y.js +73 -0
  83. package/public/sandbox/chunks/chunk-GIPXUIZQ.js +534 -0
  84. package/public/sandbox/chunks/chunk-GP37MEGJ.js +52 -0
  85. package/public/sandbox/chunks/chunk-GXL5QCMF.js +4511 -0
  86. package/public/sandbox/chunks/chunk-GZ2NSE6A.js +177 -0
  87. package/public/sandbox/chunks/chunk-GZATW4YD.js +69 -0
  88. package/public/sandbox/chunks/chunk-H4EBXROQ.js +166 -0
  89. package/public/sandbox/chunks/chunk-HETCPK6Z.js +153 -0
  90. package/public/sandbox/chunks/chunk-HGUFQ2QC.js +4431 -0
  91. package/public/sandbox/chunks/chunk-HGV3VNH3.js +255 -0
  92. package/public/sandbox/chunks/chunk-HIJ67QWR.js +5397 -0
  93. package/public/sandbox/chunks/chunk-IDHERBKW.js +1114 -0
  94. package/public/sandbox/chunks/chunk-IDTK4FIY.js +102 -0
  95. package/public/sandbox/chunks/chunk-ILFVY7H5.js +164 -0
  96. package/public/sandbox/chunks/chunk-ISGSRYGO.js +57 -0
  97. package/public/sandbox/chunks/chunk-J45VPU24.js +408 -0
  98. package/public/sandbox/chunks/chunk-JAUIM3O5.js +42 -0
  99. package/public/sandbox/chunks/chunk-JB7OQEM6.js +373 -0
  100. package/public/sandbox/chunks/chunk-JCKW6NHD.js +15 -0
  101. package/public/sandbox/chunks/chunk-JMA7GY7Z.js +221 -0
  102. package/public/sandbox/chunks/chunk-JY46J6IL.js +836 -0
  103. package/public/sandbox/chunks/{chunk-X72PZOFA.js → chunk-K2MQ66O7.js} +1 -1
  104. package/public/sandbox/chunks/chunk-KA7PZA6F.js +464 -0
  105. package/public/sandbox/chunks/chunk-KDEQTUID.js +102 -0
  106. package/public/sandbox/chunks/chunk-KDJR27JV.js +1696 -0
  107. package/public/sandbox/chunks/chunk-KFE3JO6N.js +77 -0
  108. package/public/sandbox/chunks/chunk-KLDSYWT5.js +536 -0
  109. package/public/sandbox/chunks/chunk-KQWWFYBF.js +203 -0
  110. package/public/sandbox/chunks/chunk-KTFZSXOW.js +6473 -0
  111. package/public/sandbox/chunks/chunk-KXVIC55U.js +108 -0
  112. package/public/sandbox/chunks/{chunk-HNEDTEGQ.js → chunk-L4PNO2H6.js} +1 -1
  113. package/public/sandbox/chunks/{chunk-WE4STGO2.js → chunk-L4ZNW5DI.js} +2 -2
  114. package/public/sandbox/chunks/chunk-LBUINGZ4.js +836 -0
  115. package/public/sandbox/chunks/chunk-LIYPPU6I.js +112 -0
  116. package/public/sandbox/chunks/chunk-LJHTOJXW.js +221 -0
  117. package/public/sandbox/chunks/{chunk-BWSNPKO5.js → chunk-LQL23SWJ.js} +2 -2
  118. package/public/sandbox/chunks/chunk-LTFCYZQ6.js +46 -0
  119. package/public/sandbox/chunks/chunk-LTWLVCKQ.js +166 -0
  120. package/public/sandbox/chunks/chunk-LWI7BXFN.js +395 -0
  121. package/public/sandbox/chunks/chunk-LYBBX6WM.js +225 -0
  122. package/public/sandbox/chunks/chunk-MXE7HIBM.js +474 -0
  123. package/public/sandbox/chunks/chunk-MYBDYNK4.js +6004 -0
  124. package/public/sandbox/chunks/chunk-NC2MIWZX.js +732 -0
  125. package/public/sandbox/chunks/chunk-NE447XAF.js +597 -0
  126. package/public/sandbox/chunks/chunk-NEAYV5C2.js +255 -0
  127. package/public/sandbox/chunks/chunk-NMGFJZ4I.js +26 -0
  128. package/public/sandbox/chunks/chunk-NWCJJZNQ.js +71 -0
  129. package/public/sandbox/chunks/chunk-O57OZBDR.js +214 -0
  130. package/public/sandbox/chunks/chunk-OJJT664Q.js +731 -0
  131. package/public/sandbox/chunks/chunk-OKTBUTCH.js +1175 -0
  132. package/public/sandbox/chunks/chunk-OQ4SYV5D.js +534 -0
  133. package/public/sandbox/chunks/chunk-OTVVIHJD.js +219 -0
  134. package/public/sandbox/chunks/chunk-OWTMSCF7.js +1052 -0
  135. package/public/sandbox/chunks/chunk-P5ZQNFC3.js +122 -0
  136. package/public/sandbox/chunks/chunk-PBPT2U2N.js +1698 -0
  137. package/public/sandbox/chunks/chunk-PHBJLCP3.js +836 -0
  138. package/public/sandbox/chunks/chunk-PHV4HYHB.js +397 -0
  139. package/public/sandbox/chunks/chunk-PIXQ6SOX.js +4071 -0
  140. package/public/sandbox/chunks/chunk-PKJL6YLK.js +73 -0
  141. package/public/sandbox/chunks/chunk-PKPOITIU.js +221 -0
  142. package/public/sandbox/chunks/{chunk-NQW73ACJ.js → chunk-PMXBOYQI.js} +1 -1
  143. package/public/sandbox/chunks/chunk-PQLZD7NR.js +836 -0
  144. package/public/sandbox/chunks/chunk-QEESVOZU.js +16 -0
  145. package/public/sandbox/chunks/chunk-QGIM3FQK.js +159 -0
  146. package/public/sandbox/chunks/chunk-QL5JNEDO.js +69 -0
  147. package/public/sandbox/chunks/chunk-QQOZ3RMH.js +867 -0
  148. package/public/sandbox/chunks/chunk-QUMEVT2F.js +194 -0
  149. package/public/sandbox/chunks/chunk-QVZBXYVY.js +102 -0
  150. package/public/sandbox/chunks/chunk-R5HQS6RB.js +135 -0
  151. package/public/sandbox/chunks/chunk-R75Q2CTT.js +900 -0
  152. package/public/sandbox/chunks/chunk-RBB6SHW2.js +253 -0
  153. package/public/sandbox/chunks/chunk-RDHNRWQP.js +383 -0
  154. package/public/sandbox/chunks/chunk-RIWOEI3T.js +1101 -0
  155. package/public/sandbox/chunks/chunk-RS5FFPUV.js +103 -0
  156. package/public/sandbox/chunks/chunk-RYSSJBGX.js +203 -0
  157. package/public/sandbox/chunks/chunk-S3KBAE5Z.js +1114 -0
  158. package/public/sandbox/chunks/chunk-S6ZZHV6G.js +244 -0
  159. package/public/sandbox/chunks/chunk-SFXJ24HY.js +499 -0
  160. package/public/sandbox/chunks/chunk-SH7TP5CJ.js +1109 -0
  161. package/public/sandbox/chunks/chunk-SI5OKFFY.js +317 -0
  162. package/public/sandbox/chunks/chunk-SIXNQNIR.js +86 -0
  163. package/public/sandbox/chunks/chunk-ST353BOX.js +42 -0
  164. package/public/sandbox/chunks/chunk-SYEHKMLP.js +1140 -0
  165. package/public/sandbox/chunks/chunk-SZ4KQUJU.js +69 -0
  166. package/public/sandbox/chunks/{chunk-5SOP6EKV.js → chunk-SZI65PSP.js} +5 -10
  167. package/public/sandbox/chunks/chunk-T7RLTSMX.js +78 -0
  168. package/public/sandbox/chunks/chunk-TJ2RLUTW.js +57 -0
  169. package/public/sandbox/chunks/chunk-TJB73XPN.js +4071 -0
  170. package/public/sandbox/chunks/chunk-TXJCYO56.js +4046 -0
  171. package/public/sandbox/chunks/chunk-U5J3LCYI.js +731 -0
  172. package/public/sandbox/chunks/chunk-UABFN3NH.js +208 -0
  173. package/public/sandbox/chunks/chunk-UBMUY7WO.js +13 -0
  174. package/public/sandbox/chunks/chunk-UC27CE32.js +69 -0
  175. package/public/sandbox/chunks/chunk-UJGVDFZN.js +147 -0
  176. package/public/sandbox/chunks/chunk-UNVLTK4N.js +122 -0
  177. package/public/sandbox/chunks/chunk-UQKQ6V3V.js +208 -0
  178. package/public/sandbox/chunks/chunk-UZZBHWIO.js +703 -0
  179. package/public/sandbox/chunks/chunk-VKZIJERL.js +1114 -0
  180. package/public/sandbox/chunks/chunk-VQQEAGID.js +372 -0
  181. package/public/sandbox/chunks/{chunk-3LX3KIQQ.js → chunk-W365QUZ5.js} +3 -5
  182. package/public/sandbox/chunks/chunk-WJY2LSWG.js +1052 -0
  183. package/public/sandbox/chunks/chunk-WNOBN3DX.js +391 -0
  184. package/public/sandbox/chunks/chunk-X2Z5VYG3.js +245 -0
  185. package/public/sandbox/chunks/chunk-X74KU74D.js +959 -0
  186. package/public/sandbox/chunks/chunk-XE7ULSGQ.js +46 -0
  187. package/public/sandbox/chunks/chunk-XRXUJZ3X.js +431 -0
  188. package/public/sandbox/chunks/chunk-XWHIN7CC.js +85 -0
  189. package/public/sandbox/chunks/chunk-Y2TVGGVL.js +527 -0
  190. package/public/sandbox/chunks/chunk-YMVMZA3U.js +1395 -0
  191. package/public/sandbox/chunks/chunk-YOBLFWDV.js +431 -0
  192. package/public/sandbox/chunks/chunk-YR2RFEZA.js +11 -0
  193. package/public/sandbox/chunks/chunk-YTD6A35P.js +836 -0
  194. package/public/sandbox/chunks/chunk-Z5L7EZXS.js +81 -0
  195. package/public/sandbox/chunks/chunk-Z65I5ET2.js +108 -0
  196. package/public/sandbox/chunks/chunk-Z6LV34RO.js +390 -0
  197. package/public/sandbox/chunks/chunk-ZAKUP6QG.js +1634 -0
  198. package/public/sandbox/chunks/chunk-ZHNYE2YH.js +731 -0
  199. package/public/sandbox/chunks/chunk-ZHQX3B3Y.js +867 -0
  200. package/public/sandbox/chunks/chunk-ZIXDFRHJ.js +731 -0
  201. package/public/sandbox/chunks/chunk-ZPZ2MZ4D.js +528 -0
  202. package/public/sandbox/chunks/chunk-ZQD6NZXB.js +373 -0
  203. package/public/sandbox/chunks/chunk-ZVVBP7ON.js +16 -0
  204. package/public/sandbox/chunks/chunk-ZWE3P6X2.js +11 -0
  205. package/public/sandbox/logix-core/Bound.js +14 -14
  206. package/public/sandbox/logix-core/Debug.js +12 -10
  207. package/public/sandbox/logix-core/EffectOp.js +3 -4
  208. package/public/sandbox/logix-core/Env.js +5 -2
  209. package/public/sandbox/logix-core/ExternalStore.js +239 -0
  210. package/public/sandbox/logix-core/Flow.js +7 -8
  211. package/public/sandbox/logix-core/Kernel.js +7 -4
  212. package/public/sandbox/logix-core/Link.js +33 -25
  213. package/public/sandbox/logix-core/Middleware.js +13 -11
  214. package/public/sandbox/logix-core/Module.js +93 -30
  215. package/public/sandbox/logix-core/ModuleTag.js +28 -25
  216. package/public/sandbox/logix-core/Observability.js +21 -19
  217. package/public/sandbox/logix-core/Process.js +27 -22
  218. package/public/sandbox/logix-core/ReadQuery.js +7 -11
  219. package/public/sandbox/logix-core/Reflection.js +173 -53
  220. package/public/sandbox/logix-core/Resource.js +6 -3
  221. package/public/sandbox/logix-core/Root.js +7 -3
  222. package/public/sandbox/logix-core/Runtime.js +54 -40
  223. package/public/sandbox/logix-core/ScopeRegistry.js +6 -3
  224. package/public/sandbox/logix-core/StateTrait.js +17 -14
  225. package/public/sandbox/logix-core/TraitLifecycle.js +8 -8
  226. package/public/sandbox/logix-core/Workflow.js +332 -0
  227. package/public/sandbox/logix-core.js +11133 -6622
  228. package/public/sandbox/logix-core.manifest.json +4 -2
  229. package/public/sandbox/worker.js +3 -3
  230. package/public/sandbox/chunks/chunk-4LRLOTMA.js +0 -1698
  231. package/public/sandbox/chunks/chunk-CDLXJHXY.js +0 -120
  232. package/public/sandbox/chunks/chunk-CZRI7MHA.js +0 -46
  233. package/public/sandbox/chunks/chunk-EJDFUZ4B.js +0 -408
  234. package/public/sandbox/chunks/chunk-IP63FME6.js +0 -282
  235. package/public/sandbox/chunks/chunk-JIXTOQXJ.js +0 -1103
  236. package/public/sandbox/chunks/chunk-MPUSOFJ3.js +0 -1928
  237. package/public/sandbox/chunks/chunk-ON2LY6HJ.js +0 -135
  238. package/public/sandbox/chunks/chunk-POIBXAH5.js +0 -995
  239. package/public/sandbox/chunks/chunk-PQ652ULI.js +0 -6359
  240. package/public/sandbox/chunks/chunk-RJQ4PG2F.js +0 -77
  241. package/public/sandbox/chunks/chunk-S4EXG3OS.js +0 -533
  242. package/public/sandbox/chunks/chunk-SUXDGXVE.js +0 -390
  243. package/public/sandbox/chunks/chunk-TOQ6SJ6O.js +0 -244
  244. package/public/sandbox/chunks/chunk-UKYAF3NL.js +0 -1036
  245. package/public/sandbox/chunks/chunk-UMVN3AWO.js +0 -395
  246. package/public/sandbox/chunks/chunk-WFV5PPWJ.js +0 -194
  247. package/public/sandbox/chunks/chunk-YF6IO732.js +0 -206
  248. package/public/sandbox/chunks/chunk-ZUBABAAO.js +0 -86
@@ -0,0 +1,959 @@
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 currentOpSeq = FiberRef.unsafeMake(void 0);
89
+ var currentDiagnosticsLevel = FiberRef.unsafeMake("off");
90
+ var diagnosticsLevel = (level) => Layer.fiberRefLocallyScopedWith(currentDiagnosticsLevel, () => level);
91
+ var currentTraitConvergeDiagnosticsSampling = FiberRef.unsafeMake({
92
+ sampleEveryN: 32,
93
+ topK: 3
94
+ });
95
+ var traitConvergeDiagnosticsSampling = (config) => Layer.fiberRefLocallyScopedWith(currentTraitConvergeDiagnosticsSampling, () => config);
96
+ var appendSinks = (sinks) => Layer.fiberRefLocallyScopedWith(currentDebugSinks, (current) => [...current, ...sinks]);
97
+ var nextGlobalEventSeq = 0;
98
+ var clearRuntimeDebugEventSeq = () => {
99
+ nextGlobalEventSeq = 0;
100
+ };
101
+ var nextEventSeq = () => {
102
+ nextGlobalEventSeq += 1;
103
+ return nextGlobalEventSeq;
104
+ };
105
+ var makeEventId = (instanceId, eventSeq) => `${instanceId}::e${eventSeq}`;
106
+ var mergeDowngrade = (current, next) => {
107
+ if (!current) return next;
108
+ if (!next) return current;
109
+ if (current === "non_serializable" || next === "non_serializable") return "non_serializable";
110
+ if (current === "oversized" || next === "oversized") return "oversized";
111
+ return "unknown";
112
+ };
113
+ var browserLifecycleSeen = /* @__PURE__ */ new Set();
114
+ var browserDiagnosticSeen = /* @__PURE__ */ new Set();
115
+ var lastTxnByInstance = /* @__PURE__ */ new Map();
116
+ var pendingTxnAlignmentByInstance = /* @__PURE__ */ new Map();
117
+ var enqueuePendingTxnAlignment = (instanceId, ref) => {
118
+ const list = pendingTxnAlignmentByInstance.get(instanceId);
119
+ if (!list) {
120
+ pendingTxnAlignmentByInstance.set(instanceId, [ref]);
121
+ return;
122
+ }
123
+ list.push(ref);
124
+ if (list.length > 64) {
125
+ list.shift();
126
+ }
127
+ };
128
+ var backfillPendingTxnAlignment = (instanceId, txn) => {
129
+ const pending = pendingTxnAlignmentByInstance.get(instanceId);
130
+ if (!pending || pending.length === 0) {
131
+ pendingTxnAlignmentByInstance.delete(instanceId);
132
+ return;
133
+ }
134
+ for (const ref of pending) {
135
+ const anyRef = ref;
136
+ if (anyRef.txnId == null) {
137
+ anyRef.txnId = txn.txnId;
138
+ }
139
+ if (typeof anyRef.txnSeq !== "number" || anyRef.txnSeq <= 0) {
140
+ anyRef.txnSeq = txn.txnSeq;
141
+ }
142
+ }
143
+ pendingTxnAlignmentByInstance.delete(instanceId);
144
+ };
145
+ var lifecycleErrorLog = (event) => {
146
+ const moduleId = event.moduleId ?? "unknown";
147
+ const causePretty = (() => {
148
+ try {
149
+ return Cause2.pretty(event.cause, {
150
+ renderErrorCause: true
151
+ });
152
+ } catch {
153
+ try {
154
+ return JSON.stringify(event.cause, null, 2);
155
+ } catch {
156
+ return String(event.cause);
157
+ }
158
+ }
159
+ })();
160
+ const message = `[Logix][module=${moduleId}] lifecycle:error
161
+ ${causePretty}`;
162
+ return Effect.logError(message).pipe(
163
+ Effect.annotateLogs({
164
+ "logix.moduleId": moduleId,
165
+ "logix.event": "lifecycle:error",
166
+ "logix.cause": causePretty
167
+ })
168
+ );
169
+ };
170
+ var diagnosticLog = (event) => {
171
+ const moduleId = event.moduleId ?? "unknown";
172
+ const header = `[Logix][module=${moduleId}] diagnostic(${event.severity})`;
173
+ const detail = `code=${event.code} message=${event.message}${event.actionTag ? ` action=${event.actionTag}` : ""}${event.hint ? `
174
+ hint: ${event.hint}` : ""}`;
175
+ const msg = `${header}
176
+ ${detail}`;
177
+ const base = event.severity === "warning" ? Effect.logWarning(msg) : event.severity === "info" ? Effect.logInfo(msg) : Effect.logError(msg);
178
+ const annotations = {
179
+ "logix.moduleId": moduleId,
180
+ "logix.event": `diagnostic(${event.severity})`,
181
+ "logix.diagnostic.code": event.code,
182
+ "logix.diagnostic.message": event.message
183
+ };
184
+ if (event.hint) {
185
+ annotations["logix.diagnostic.hint"] = event.hint;
186
+ }
187
+ if (event.actionTag) {
188
+ annotations["logix.diagnostic.actionTag"] = event.actionTag;
189
+ }
190
+ return base.pipe(Effect.annotateLogs(annotations));
191
+ };
192
+ var noopLayer = Layer.locallyScoped(currentDebugSinks, []);
193
+ var errorOnlySink = {
194
+ record: (event) => event.type === "lifecycle:error" ? lifecycleErrorLog(event) : event.type === "diagnostic" && event.severity !== "info" ? diagnosticLog(event) : Effect.void
195
+ };
196
+ var errorOnlyLayer = Layer.locallyScoped(currentDebugSinks, [errorOnlySink]);
197
+ var consoleSink = {
198
+ record: (event) => event.type === "lifecycle:error" ? lifecycleErrorLog(event) : event.type === "diagnostic" ? diagnosticLog(event) : Effect.logDebug({ debugEvent: event })
199
+ };
200
+ var consoleLayer = Layer.locallyScoped(currentDebugSinks, [consoleSink]);
201
+ var isBrowser = typeof window !== "undefined" && typeof document !== "undefined";
202
+ var renderBrowserConsoleEvent = (event) => {
203
+ if (typeof event.type === "string" && event.type.startsWith("trace:")) {
204
+ const moduleId = event.moduleId ?? "unknown";
205
+ const type = event.type;
206
+ return Effect.sync(() => {
207
+ console.groupCollapsed(
208
+ "%c[Logix]%c trace %c" + moduleId + "%c " + String(type),
209
+ "color:#6b7280;font-weight:bold",
210
+ // tag
211
+ "color:#3b82f6",
212
+ // label
213
+ "color:#9ca3af",
214
+ // module id
215
+ "color:#6b7280"
216
+ // type
217
+ );
218
+ console.log(event);
219
+ console.groupEnd();
220
+ });
221
+ }
222
+ if (event.type === "lifecycle:error") {
223
+ const moduleId = event.moduleId ?? "unknown";
224
+ const causePretty = (() => {
225
+ try {
226
+ return Cause2.pretty(event.cause, { renderErrorCause: true });
227
+ } catch {
228
+ try {
229
+ return JSON.stringify(event.cause, null, 2);
230
+ } catch {
231
+ return String(event.cause);
232
+ }
233
+ }
234
+ })();
235
+ const key = `${moduleId}|${causePretty}`;
236
+ if (browserLifecycleSeen.has(key)) {
237
+ return Effect.void;
238
+ }
239
+ browserLifecycleSeen.add(key);
240
+ return Effect.sync(() => {
241
+ console.groupCollapsed(
242
+ "%c[Logix]%c lifecycle:error %c" + moduleId,
243
+ "color:#ef4444;font-weight:bold",
244
+ // tag
245
+ "color:#ef4444",
246
+ // label
247
+ "color:#9ca3af"
248
+ // module id
249
+ );
250
+ console.error(causePretty);
251
+ console.groupEnd();
252
+ });
253
+ }
254
+ if (event.type === "diagnostic") {
255
+ const moduleId = event.moduleId ?? "unknown";
256
+ const detail = `code=${event.code} message=${event.message}${event.actionTag ? ` action=${event.actionTag}` : ""}${event.hint ? `
257
+ hint: ${event.hint}` : ""}`;
258
+ const color = event.severity === "warning" ? "color:#d97706" : event.severity === "info" ? "color:#3b82f6" : "color:#ef4444";
259
+ const label = event.severity === "warning" ? "diagnostic(warning)" : event.severity === "info" ? "diagnostic(info)" : "diagnostic(error)";
260
+ const key = `${moduleId}|${event.code}|${event.message}`;
261
+ if (browserDiagnosticSeen.has(key)) {
262
+ return Effect.void;
263
+ }
264
+ browserDiagnosticSeen.add(key);
265
+ return Effect.sync(() => {
266
+ console.groupCollapsed(
267
+ "%c[Logix]%c " + label + "%c module=" + moduleId,
268
+ "color:#6b7280;font-weight:bold",
269
+ color,
270
+ "color:#9ca3af"
271
+ );
272
+ console.log(detail);
273
+ console.groupEnd();
274
+ });
275
+ }
276
+ return Effect.void;
277
+ };
278
+ var browserConsoleSink = {
279
+ record: (event) => {
280
+ if (!isBrowser) {
281
+ return event.type === "lifecycle:error" ? lifecycleErrorLog(event) : event.type === "diagnostic" ? diagnosticLog(event) : Effect.logDebug({ debugEvent: event });
282
+ }
283
+ return renderBrowserConsoleEvent(event);
284
+ }
285
+ };
286
+ var browserConsoleLayer = Layer.locallyScoped(currentDebugSinks, [browserConsoleSink]);
287
+ var browserPrettyLoggerLayer = Logger.replace(
288
+ Logger.defaultLogger,
289
+ Logger.prettyLogger({ mode: "browser", colors: true })
290
+ );
291
+ var record = (event) => Effect.gen(function* () {
292
+ const sinks = yield* FiberRef.get(currentDebugSinks);
293
+ if (sinks.length === 0) {
294
+ if (isBrowser) {
295
+ if (event.type === "lifecycle:error" || event.type === "diagnostic") {
296
+ yield* renderBrowserConsoleEvent(event);
297
+ return;
298
+ }
299
+ yield* Effect.void;
300
+ return;
301
+ }
302
+ if (event.type === "lifecycle:error") {
303
+ yield* lifecycleErrorLog(event);
304
+ return;
305
+ }
306
+ if (event.type === "diagnostic") {
307
+ yield* diagnosticLog(event);
308
+ return;
309
+ }
310
+ yield* Effect.void;
311
+ return;
312
+ }
313
+ const enriched = event;
314
+ const diagnosticsLevel2 = yield* FiberRef.get(currentDiagnosticsLevel);
315
+ let now;
316
+ const getNow = () => {
317
+ if (now === void 0) now = Date.now();
318
+ return now;
319
+ };
320
+ if (enriched.timestamp === void 0 && (diagnosticsLevel2 !== "off" || enriched.type === "lifecycle:error" || enriched.type === "diagnostic")) {
321
+ ;
322
+ enriched.timestamp = getNow();
323
+ }
324
+ if (diagnosticsLevel2 !== "off" && enriched.runtimeLabel === void 0) {
325
+ const runtimeLabel = yield* FiberRef.get(currentRuntimeLabel);
326
+ if (runtimeLabel) {
327
+ ;
328
+ enriched.runtimeLabel = runtimeLabel;
329
+ }
330
+ }
331
+ if (enriched.type === "diagnostic" && enriched.txnId === void 0) {
332
+ const txnId = yield* FiberRef.get(currentTxnId);
333
+ if (txnId) {
334
+ ;
335
+ enriched.txnId = txnId;
336
+ }
337
+ }
338
+ if (diagnosticsLevel2 !== "off" && enriched.type === "trace:effectop" && enriched.linkId === void 0) {
339
+ const linkId = yield* FiberRef.get(currentLinkId);
340
+ if (linkId) {
341
+ ;
342
+ enriched.linkId = linkId;
343
+ }
344
+ }
345
+ if (sinks.length === 1) {
346
+ yield* sinks[0].record(enriched);
347
+ return;
348
+ }
349
+ yield* Effect.forEach(sinks, (sink) => sink.record(enriched), { discard: true });
350
+ });
351
+ var toRuntimeDebugEventRef = (event, options) => {
352
+ const diagnosticsLevel2 = options?.diagnosticsLevel ?? "full";
353
+ if (diagnosticsLevel2 === "off") {
354
+ return void 0;
355
+ }
356
+ const isLightLike = diagnosticsLevel2 === "light" || diagnosticsLevel2 === "sampled";
357
+ const timestamp = typeof event.timestamp === "number" && Number.isFinite(event.timestamp) ? event.timestamp : Date.now();
358
+ const moduleIdRaw = event.moduleId;
359
+ const moduleId = typeof moduleIdRaw === "string" && moduleIdRaw.length > 0 ? moduleIdRaw : "unknown";
360
+ const instanceIdRaw = event.instanceId;
361
+ const instanceId = typeof instanceIdRaw === "string" && instanceIdRaw.length > 0 ? instanceIdRaw : "unknown";
362
+ const runtimeLabelRaw = event.runtimeLabel;
363
+ const runtimeLabel = typeof runtimeLabelRaw === "string" && runtimeLabelRaw.length > 0 ? runtimeLabelRaw : void 0;
364
+ const txnSeqRaw = event.txnSeq;
365
+ const txnSeq = typeof txnSeqRaw === "number" && Number.isFinite(txnSeqRaw) && txnSeqRaw >= 0 ? Math.floor(txnSeqRaw) : 0;
366
+ const txnIdRaw = event.txnId;
367
+ const txnId = typeof txnIdRaw === "string" && txnIdRaw.length > 0 ? txnIdRaw : txnSeq > 0 ? `${instanceId}::t${txnSeq}` : void 0;
368
+ const linkId = (() => {
369
+ const linkIdRaw = event.linkId;
370
+ if (typeof linkIdRaw === "string" && linkIdRaw.length > 0) return linkIdRaw;
371
+ if (typeof event.type !== "string" || !event.type.startsWith("trace:")) {
372
+ return void 0;
373
+ }
374
+ const data = event.data;
375
+ const meta = data?.meta;
376
+ const linkIdFromMeta = meta?.linkId;
377
+ if (typeof linkIdFromMeta === "string" && linkIdFromMeta.length > 0) return linkIdFromMeta;
378
+ return void 0;
379
+ })();
380
+ const eventSeqRaw = options?.eventSeq;
381
+ const eventSeq = typeof eventSeqRaw === "number" && Number.isFinite(eventSeqRaw) && eventSeqRaw > 0 ? Math.floor(eventSeqRaw) : nextEventSeq();
382
+ const eventId = makeEventId(instanceId, eventSeq);
383
+ const base = {
384
+ eventId,
385
+ eventSeq,
386
+ moduleId,
387
+ instanceId,
388
+ runtimeLabel,
389
+ txnSeq,
390
+ txnId,
391
+ linkId,
392
+ timestamp
393
+ };
394
+ let downgrade;
395
+ const withDowngrade = (ref) => {
396
+ if (!downgrade) return ref;
397
+ return { ...ref, downgrade: { reason: downgrade } };
398
+ };
399
+ switch (event.type) {
400
+ case "module:init":
401
+ return withDowngrade({
402
+ ...base,
403
+ kind: "lifecycle",
404
+ label: "module:init"
405
+ });
406
+ case "module:destroy":
407
+ return withDowngrade({
408
+ ...base,
409
+ kind: "lifecycle",
410
+ label: "module:destroy"
411
+ });
412
+ case "lifecycle:phase": {
413
+ const e = event;
414
+ const metaInput = isLightLike ? { type: "lifecycle:phase", phase: e.phase, name: e.name } : { type: "lifecycle:phase", phase: e.phase, name: e.name, payload: e.payload };
415
+ const metaProjection = projectJsonValue(metaInput);
416
+ options?.onMetaProjection?.({
417
+ stats: metaProjection.stats,
418
+ downgrade: metaProjection.downgrade
419
+ });
420
+ downgrade = mergeDowngrade(downgrade, metaProjection.downgrade);
421
+ return withDowngrade({
422
+ ...base,
423
+ kind: "lifecycle",
424
+ label: e.name,
425
+ meta: metaProjection.value
426
+ });
427
+ }
428
+ case "action:dispatch": {
429
+ const action = event.action;
430
+ const tag = action?._tag ?? action?.type ?? "action:dispatch";
431
+ const label = String(tag);
432
+ const metaInput = isLightLike ? { actionTag: label } : { action };
433
+ const metaProjection = projectJsonValue(metaInput);
434
+ options?.onMetaProjection?.({
435
+ stats: metaProjection.stats,
436
+ downgrade: metaProjection.downgrade
437
+ });
438
+ downgrade = mergeDowngrade(downgrade, metaProjection.downgrade);
439
+ return withDowngrade({
440
+ ...base,
441
+ kind: "action",
442
+ label,
443
+ meta: metaProjection.value
444
+ });
445
+ }
446
+ case "state:update": {
447
+ const e = event;
448
+ const metaInput = isLightLike ? {
449
+ state: e.state,
450
+ dirtySet: e.dirtySet,
451
+ patchCount: e.patchCount,
452
+ commitMode: e.commitMode,
453
+ priority: e.priority,
454
+ originKind: e.originKind,
455
+ originName: e.originName
456
+ } : {
457
+ state: e.state,
458
+ dirtySet: e.dirtySet,
459
+ patchCount: e.patchCount,
460
+ commitMode: e.commitMode,
461
+ priority: e.priority,
462
+ originKind: e.originKind,
463
+ originName: e.originName,
464
+ traitSummary: e.traitSummary,
465
+ replayEvent: e.replayEvent
466
+ };
467
+ const metaProjection = projectJsonValue(metaInput);
468
+ options?.onMetaProjection?.({
469
+ stats: metaProjection.stats,
470
+ downgrade: metaProjection.downgrade
471
+ });
472
+ downgrade = mergeDowngrade(downgrade, metaProjection.downgrade);
473
+ if (txnId) {
474
+ lastTxnByInstance.set(instanceId, { txnId, txnSeq });
475
+ backfillPendingTxnAlignment(instanceId, { txnId, txnSeq });
476
+ }
477
+ return withDowngrade({
478
+ ...base,
479
+ kind: "state",
480
+ label: "state:update",
481
+ meta: metaProjection.value
482
+ });
483
+ }
484
+ case "process:start":
485
+ case "process:stop":
486
+ case "process:restart":
487
+ case "process:trigger":
488
+ case "process:dispatch":
489
+ case "process:error": {
490
+ const e = event;
491
+ const ts2 = typeof e.timestampMs === "number" && Number.isFinite(e.timestampMs) ? e.timestampMs : timestamp;
492
+ const metaInput = {
493
+ identity: e.identity,
494
+ severity: e.severity,
495
+ eventSeq: e.eventSeq,
496
+ timestampMs: e.timestampMs,
497
+ trigger: e.trigger,
498
+ dispatch: e.dispatch,
499
+ error: e.error
500
+ };
501
+ const metaProjection = projectJsonValue(metaInput);
502
+ options?.onMetaProjection?.({
503
+ stats: metaProjection.stats,
504
+ downgrade: metaProjection.downgrade
505
+ });
506
+ downgrade = mergeDowngrade(downgrade, metaProjection.downgrade);
507
+ const errorSummary = e.type === "process:error" || e.type === "process:restart" ? e.error : void 0;
508
+ return withDowngrade({
509
+ ...base,
510
+ timestamp: ts2,
511
+ kind: "process",
512
+ label: e.type,
513
+ meta: metaProjection.value,
514
+ errorSummary
515
+ });
516
+ }
517
+ case "lifecycle:error": {
518
+ const e = event;
519
+ const summary = toSerializableErrorSummary(e.cause);
520
+ downgrade = mergeDowngrade(downgrade, summary.downgrade);
521
+ const metaInput = isLightLike ? { type: "lifecycle:error", phase: e.phase, name: e.hook } : {
522
+ type: "lifecycle:error",
523
+ phase: e.phase,
524
+ name: e.hook,
525
+ hook: e.hook,
526
+ taskId: e.taskId,
527
+ origin: e.origin,
528
+ txnSeq: e.txnSeq,
529
+ opSeq: e.opSeq
530
+ };
531
+ const metaProjection = projectJsonValue(metaInput);
532
+ options?.onMetaProjection?.({
533
+ stats: metaProjection.stats,
534
+ downgrade: metaProjection.downgrade
535
+ });
536
+ downgrade = mergeDowngrade(downgrade, metaProjection.downgrade);
537
+ return withDowngrade({
538
+ ...base,
539
+ kind: "lifecycle",
540
+ label: "lifecycle:error",
541
+ meta: metaProjection.value,
542
+ errorSummary: summary.errorSummary
543
+ });
544
+ }
545
+ case "diagnostic": {
546
+ const e = event;
547
+ const metaInput = {
548
+ code: e.code,
549
+ severity: e.severity,
550
+ message: e.message,
551
+ hint: e.hint,
552
+ actionTag: e.actionTag,
553
+ kind: e.kind,
554
+ trigger: e.trigger
555
+ };
556
+ const metaProjection = projectJsonValue(metaInput);
557
+ options?.onMetaProjection?.({
558
+ stats: metaProjection.stats,
559
+ downgrade: metaProjection.downgrade
560
+ });
561
+ downgrade = mergeDowngrade(downgrade, metaProjection.downgrade);
562
+ return withDowngrade({
563
+ ...base,
564
+ kind: "diagnostic",
565
+ label: e.code,
566
+ meta: metaProjection.value
567
+ });
568
+ }
569
+ default: {
570
+ if (typeof event.type !== "string" || !event.type.startsWith("trace:")) {
571
+ return void 0;
572
+ }
573
+ if (event.type === "trace:txn-lane") {
574
+ const data = event.data;
575
+ const evidence = data?.evidence ?? data;
576
+ const metaProjection2 = projectJsonValue(evidence);
577
+ options?.onMetaProjection?.({
578
+ stats: metaProjection2.stats,
579
+ downgrade: metaProjection2.downgrade
580
+ });
581
+ downgrade = mergeDowngrade(downgrade, metaProjection2.downgrade);
582
+ const label = typeof evidence?.kind === "string" && evidence.kind.length > 0 ? String(evidence.kind) : "txn-lane";
583
+ return withDowngrade({
584
+ ...base,
585
+ kind: "txn-lane",
586
+ label,
587
+ meta: metaProjection2.value
588
+ });
589
+ }
590
+ if (event.type === "trace:react-render" || event.type === "trace:react-selector") {
591
+ const data = event.data;
592
+ const metaProjection2 = projectJsonValue(
593
+ isLightLike ? {
594
+ componentLabel: data?.componentLabel,
595
+ selectorKey: data?.selectorKey,
596
+ fieldPaths: data?.fieldPaths,
597
+ selectorId: data?.selectorId,
598
+ lane: data?.lane,
599
+ producer: data?.producer,
600
+ fallbackReason: data?.fallbackReason,
601
+ readsDigest: data?.readsDigest,
602
+ equalsKind: data?.equalsKind,
603
+ strictModePhase: data?.strictModePhase
604
+ } : {
605
+ componentLabel: data?.componentLabel,
606
+ selectorKey: data?.selectorKey,
607
+ fieldPaths: data?.fieldPaths,
608
+ selectorId: data?.selectorId,
609
+ lane: data?.lane,
610
+ producer: data?.producer,
611
+ fallbackReason: data?.fallbackReason,
612
+ readsDigest: data?.readsDigest,
613
+ equalsKind: data?.equalsKind,
614
+ strictModePhase: data?.strictModePhase,
615
+ meta: data?.meta
616
+ }
617
+ );
618
+ options?.onMetaProjection?.({
619
+ stats: metaProjection2.stats,
620
+ downgrade: metaProjection2.downgrade
621
+ });
622
+ downgrade = mergeDowngrade(downgrade, metaProjection2.downgrade);
623
+ const label = typeof data?.componentLabel === "string" && data.componentLabel.length > 0 ? data.componentLabel : event.type === "trace:react-selector" ? "react-selector" : "react-render";
624
+ const last = lastTxnByInstance.get(instanceId);
625
+ const txnSeqFromMeta = typeof data?.meta?.txnSeq === "number" && Number.isFinite(data.meta.txnSeq) && data.meta.txnSeq >= 0 ? Math.floor(data.meta.txnSeq) : void 0;
626
+ const txnIdFromMeta = typeof data?.meta?.txnId === "string" && data.meta.txnId.length > 0 ? data.meta.txnId : void 0;
627
+ const txnIdAligned = txnIdFromMeta ?? base.txnId ?? last?.txnId;
628
+ const txnSeqAligned = txnSeqFromMeta ?? (base.txnSeq > 0 ? base.txnSeq : last?.txnSeq ?? base.txnSeq);
629
+ const ref = withDowngrade({
630
+ ...base,
631
+ txnId: txnIdAligned,
632
+ txnSeq: txnSeqAligned,
633
+ kind: event.type === "trace:react-selector" ? "react-selector" : "react-render",
634
+ label,
635
+ meta: metaProjection2.value
636
+ });
637
+ if (instanceId !== "unknown" && (ref.txnId == null || ref.txnSeq <= 0)) {
638
+ enqueuePendingTxnAlignment(instanceId, ref);
639
+ }
640
+ return ref;
641
+ }
642
+ if (event.type === "trace:selector:eval") {
643
+ const data = event.data;
644
+ const metaInput = {
645
+ selectorId: data?.selectorId,
646
+ lane: data?.lane,
647
+ producer: data?.producer,
648
+ fallbackReason: data?.fallbackReason,
649
+ readsDigest: data?.readsDigest,
650
+ equalsKind: data?.equalsKind,
651
+ changed: data?.changed,
652
+ evalMs: data?.evalMs
653
+ };
654
+ const metaProjection2 = projectJsonValue(metaInput);
655
+ options?.onMetaProjection?.({
656
+ stats: metaProjection2.stats,
657
+ downgrade: metaProjection2.downgrade
658
+ });
659
+ downgrade = mergeDowngrade(downgrade, metaProjection2.downgrade);
660
+ return withDowngrade({
661
+ ...base,
662
+ kind: "devtools",
663
+ label: event.type,
664
+ meta: metaProjection2.value
665
+ });
666
+ }
667
+ if (event.type === "trace:exec-vm") {
668
+ const data = event.data;
669
+ const metaInput = {
670
+ version: data?.version,
671
+ stage: data?.stage,
672
+ hit: data?.hit,
673
+ reasonCode: data?.reasonCode ?? data?.reason,
674
+ reasonDetail: data?.reasonDetail,
675
+ execIrVersion: data?.execIrVersion,
676
+ execIrHash: data?.execIrHash,
677
+ serviceId: data?.serviceId,
678
+ implId: data?.implId
679
+ };
680
+ const metaProjection2 = projectJsonValue(metaInput);
681
+ options?.onMetaProjection?.({
682
+ stats: metaProjection2.stats,
683
+ downgrade: metaProjection2.downgrade
684
+ });
685
+ downgrade = mergeDowngrade(downgrade, metaProjection2.downgrade);
686
+ return withDowngrade({
687
+ ...base,
688
+ kind: "devtools",
689
+ label: event.type,
690
+ meta: metaProjection2.value
691
+ });
692
+ }
693
+ if (event.type === "trace:trait:converge") {
694
+ const resolveDirtyRootPaths = (args) => {
695
+ const resolve = options?.resolveConvergeStaticIr;
696
+ if (!resolve) return void 0;
697
+ const digest = args.staticIrDigest;
698
+ if (typeof digest !== "string" || digest.length === 0) return void 0;
699
+ const rootIds = args.rootIds;
700
+ if (!Array.isArray(rootIds) || rootIds.length === 0) return void 0;
701
+ const ir = resolve(digest);
702
+ const fieldPaths = ir?.fieldPaths;
703
+ if (!Array.isArray(fieldPaths) || fieldPaths.length === 0) return void 0;
704
+ const out = [];
705
+ for (const id of rootIds) {
706
+ if (typeof id !== "number" || !Number.isFinite(id)) continue;
707
+ const idx = Math.floor(id);
708
+ if (idx < 0 || idx >= fieldPaths.length) continue;
709
+ const path = fieldPaths[idx];
710
+ if (Array.isArray(path)) {
711
+ out.push(path);
712
+ }
713
+ }
714
+ return out.length > 0 ? out : void 0;
715
+ };
716
+ const enrichDirtyRootPaths = (value) => {
717
+ if (!value || typeof value !== "object" || Array.isArray(value)) return value;
718
+ const anyValue = value;
719
+ const dirty = anyValue.dirty;
720
+ if (!dirty || typeof dirty !== "object" || Array.isArray(dirty)) return value;
721
+ const dirtyRootPaths = resolveDirtyRootPaths({
722
+ staticIrDigest: anyValue.staticIrDigest,
723
+ rootIds: dirty?.rootIds
724
+ });
725
+ if (!dirtyRootPaths) return value;
726
+ return {
727
+ ...anyValue,
728
+ dirty: {
729
+ ...dirty,
730
+ rootPaths: dirtyRootPaths
731
+ }
732
+ };
733
+ };
734
+ const stripHeavyLight = (value) => {
735
+ if (!value || typeof value !== "object" || Array.isArray(value)) return value;
736
+ const anyValue = value;
737
+ const dirty = anyValue.dirty;
738
+ const dirtyRootPaths = resolveDirtyRootPaths({
739
+ staticIrDigest: anyValue.staticIrDigest,
740
+ rootIds: dirty?.rootIds
741
+ });
742
+ const dirtySlim = dirty && typeof dirty === "object" && !Array.isArray(dirty) ? {
743
+ dirtyAll: dirty.dirtyAll,
744
+ ...typeof dirty.reason === "string" ? { reason: dirty.reason } : null,
745
+ ...Array.isArray(dirty.rootIds) ? { rootIds: dirty.rootIds } : null,
746
+ ...typeof dirty.rootIdsTruncated === "boolean" ? { rootIdsTruncated: dirty.rootIdsTruncated } : null,
747
+ ...dirtyRootPaths ? { rootPaths: dirtyRootPaths } : null
748
+ } : void 0;
749
+ const { top3, dirtyRoots, ...rest } = anyValue;
750
+ return dirtySlim ? { ...rest, dirty: dirtySlim } : rest;
751
+ };
752
+ const stripHeavySampled = (value) => {
753
+ if (!value || typeof value !== "object" || Array.isArray(value)) return value;
754
+ const anyValue = value;
755
+ const dirty = anyValue.dirty;
756
+ const dirtySlim = dirty && typeof dirty === "object" && !Array.isArray(dirty) ? {
757
+ dirtyAll: dirty.dirtyAll,
758
+ ...typeof dirty.reason === "string" ? { reason: dirty.reason } : null
759
+ } : void 0;
760
+ const { dirtyRoots, ...rest } = anyValue;
761
+ return dirtySlim ? { ...rest, dirty: dirtySlim } : rest;
762
+ };
763
+ const data = event.data;
764
+ const metaInput = diagnosticsLevel2 === "light" ? stripHeavyLight(data) : diagnosticsLevel2 === "sampled" ? stripHeavySampled(data) : enrichDirtyRootPaths(data);
765
+ const metaProjection2 = projectJsonValue(metaInput);
766
+ options?.onMetaProjection?.({
767
+ stats: metaProjection2.stats,
768
+ downgrade: metaProjection2.downgrade
769
+ });
770
+ downgrade = mergeDowngrade(downgrade, metaProjection2.downgrade);
771
+ return withDowngrade({
772
+ ...base,
773
+ kind: "trait:converge",
774
+ label: "trait:converge",
775
+ meta: metaProjection2.value
776
+ });
777
+ }
778
+ if (event.type === "trace:trait:check") {
779
+ const stripHeavy = (value) => {
780
+ if (!value || typeof value !== "object" || Array.isArray(value)) return value;
781
+ const anyValue = value;
782
+ const degraded = anyValue.degraded;
783
+ const degradedSlim = degraded && typeof degraded === "object" && !Array.isArray(degraded) ? { kind: degraded.kind } : void 0;
784
+ const { degraded: _degraded, ...rest } = anyValue;
785
+ return degradedSlim ? { ...rest, degraded: degradedSlim } : rest;
786
+ };
787
+ const data = event.data;
788
+ const metaInput = isLightLike ? stripHeavy(data) : data;
789
+ const metaProjection2 = projectJsonValue(metaInput);
790
+ options?.onMetaProjection?.({
791
+ stats: metaProjection2.stats,
792
+ downgrade: metaProjection2.downgrade
793
+ });
794
+ downgrade = mergeDowngrade(downgrade, metaProjection2.downgrade);
795
+ return withDowngrade({
796
+ ...base,
797
+ kind: "trait:check",
798
+ label: "trait:check",
799
+ meta: metaProjection2.value
800
+ });
801
+ }
802
+ if (event.type === "trace:trait:validate") {
803
+ const data = event.data;
804
+ const metaProjection2 = projectJsonValue(data);
805
+ options?.onMetaProjection?.({
806
+ stats: metaProjection2.stats,
807
+ downgrade: metaProjection2.downgrade
808
+ });
809
+ downgrade = mergeDowngrade(downgrade, metaProjection2.downgrade);
810
+ return withDowngrade({
811
+ ...base,
812
+ kind: "trait:validate",
813
+ label: "trait:validate",
814
+ meta: metaProjection2.value
815
+ });
816
+ }
817
+ if (event.type === "trace:module:traits") {
818
+ const data = event.data;
819
+ const metaInput = isLightLike ? {
820
+ digest: data?.digest,
821
+ count: data?.count
822
+ } : {
823
+ digest: data?.digest,
824
+ count: data?.count,
825
+ traits: data?.traits,
826
+ provenanceIndex: data?.provenanceIndex
827
+ };
828
+ const metaProjection2 = projectJsonValue(metaInput);
829
+ options?.onMetaProjection?.({
830
+ stats: metaProjection2.stats,
831
+ downgrade: metaProjection2.downgrade
832
+ });
833
+ downgrade = mergeDowngrade(downgrade, metaProjection2.downgrade);
834
+ return withDowngrade({
835
+ ...base,
836
+ kind: "devtools",
837
+ label: event.type,
838
+ meta: metaProjection2.value
839
+ });
840
+ }
841
+ if (event.type === "trace:module:traits:conflict") {
842
+ const data = event.data;
843
+ const metaInput = isLightLike ? {
844
+ conflictCount: data?.conflictCount,
845
+ traitIds: data?.traitIds
846
+ } : {
847
+ conflictCount: data?.conflictCount,
848
+ conflicts: data?.conflicts
849
+ };
850
+ const metaProjection2 = projectJsonValue(metaInput);
851
+ options?.onMetaProjection?.({
852
+ stats: metaProjection2.stats,
853
+ downgrade: metaProjection2.downgrade
854
+ });
855
+ downgrade = mergeDowngrade(downgrade, metaProjection2.downgrade);
856
+ return withDowngrade({
857
+ ...base,
858
+ kind: "devtools",
859
+ label: event.type,
860
+ meta: metaProjection2.value
861
+ });
862
+ }
863
+ if (event.type === "trace:module:descriptor") {
864
+ const data = event.data;
865
+ const metaInput = isLightLike ? {
866
+ id: data?.id,
867
+ traits: data?.traits,
868
+ source: data?.source
869
+ } : { data };
870
+ const metaProjection2 = projectJsonValue(metaInput);
871
+ options?.onMetaProjection?.({
872
+ stats: metaProjection2.stats,
873
+ downgrade: metaProjection2.downgrade
874
+ });
875
+ downgrade = mergeDowngrade(downgrade, metaProjection2.downgrade);
876
+ return withDowngrade({
877
+ ...base,
878
+ kind: "devtools",
879
+ label: event.type,
880
+ meta: metaProjection2.value
881
+ });
882
+ }
883
+ if (event.type === "trace:effectop") {
884
+ const data = event.data;
885
+ const opMeta = data?.meta;
886
+ const opKind = data?.kind ?? "service";
887
+ const label = typeof data?.name === "string" ? data.name : "effectop";
888
+ const moduleId2 = typeof opMeta?.moduleId === "string" ? opMeta.moduleId : moduleId;
889
+ const txnId2 = typeof opMeta?.txnId === "string" && opMeta.txnId.length > 0 ? opMeta.txnId : base.txnId;
890
+ const txnSeq2 = typeof opMeta?.txnSeq === "number" && Number.isFinite(opMeta.txnSeq) && opMeta.txnSeq >= 0 ? Math.floor(opMeta.txnSeq) : base.txnSeq;
891
+ const metaInput = isLightLike ? {
892
+ id: data?.id,
893
+ kind: data?.kind,
894
+ name: data?.name,
895
+ meta: opMeta
896
+ } : {
897
+ id: data?.id,
898
+ kind: data?.kind,
899
+ name: data?.name,
900
+ payload: data?.payload,
901
+ meta: opMeta
902
+ };
903
+ const metaProjection2 = projectJsonValue(metaInput);
904
+ options?.onMetaProjection?.({
905
+ stats: metaProjection2.stats,
906
+ downgrade: metaProjection2.downgrade
907
+ });
908
+ downgrade = mergeDowngrade(downgrade, metaProjection2.downgrade);
909
+ return withDowngrade({
910
+ ...base,
911
+ moduleId: moduleId2,
912
+ txnId: txnId2,
913
+ txnSeq: txnSeq2,
914
+ kind: opKind,
915
+ label,
916
+ meta: metaProjection2.value
917
+ });
918
+ }
919
+ const metaProjection = projectJsonValue(
920
+ isLightLike ? {
921
+ data: void 0
922
+ } : {
923
+ data: event.data
924
+ }
925
+ );
926
+ options?.onMetaProjection?.({
927
+ stats: metaProjection.stats,
928
+ downgrade: metaProjection.downgrade
929
+ });
930
+ downgrade = mergeDowngrade(downgrade, metaProjection.downgrade);
931
+ return withDowngrade({
932
+ ...base,
933
+ kind: "devtools",
934
+ label: event.type,
935
+ meta: metaProjection.value
936
+ });
937
+ }
938
+ }
939
+ };
940
+
941
+ export {
942
+ toSerializableErrorSummary,
943
+ currentDebugSinks,
944
+ currentRuntimeLabel,
945
+ currentTxnId,
946
+ currentOpSeq,
947
+ currentDiagnosticsLevel,
948
+ diagnosticsLevel,
949
+ currentTraitConvergeDiagnosticsSampling,
950
+ traitConvergeDiagnosticsSampling,
951
+ appendSinks,
952
+ clearRuntimeDebugEventSeq,
953
+ noopLayer,
954
+ errorOnlyLayer,
955
+ browserConsoleLayer,
956
+ record,
957
+ toRuntimeDebugEventRef
958
+ };
959
+ //# 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'\nimport type { ConvergeStaticIrExport } from '../../state-trait/converge-ir.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 txnId?: string\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 const currentOpSeq = FiberRef.unsafeMake<number | 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\nexport type TxnLaneEvidenceReason =\n  | 'disabled'\n  | 'forced_off'\n  | 'forced_sync'\n  | 'queued_non_urgent'\n  | 'preempted_by_urgent'\n  | 'budget_yield'\n  | 'coalesced'\n  | 'canceled'\n  | 'max_lag_forced'\n  | 'starvation_protection'\n\nexport type TxnLaneNonUrgentYieldReason = 'none' | 'input_pending' | 'budget_exceeded' | 'forced_frame_yield'\n\nexport type TxnLaneEvidence = {\n  readonly anchor: {\n    readonly moduleId: string\n    readonly instanceId: string\n    readonly txnSeq: number\n    readonly opSeq?: number\n  }\n  readonly lane: 'urgent' | 'nonUrgent'\n  readonly kind: string\n  readonly policy: {\n    readonly enabled: boolean\n    readonly overrideMode?: 'forced_off' | 'forced_sync'\n    readonly configScope: 'provider' | 'runtime_module' | 'runtime_default' | 'builtin'\n    readonly budgetMs: number\n    readonly debounceMs: number\n    readonly maxLagMs: number\n    readonly allowCoalesce: boolean\n    readonly yieldStrategy?: 'baseline' | 'inputPending'\n    readonly queueMode?: 'fifo' | 'lanes'\n  }\n  readonly backlog: {\n    readonly pendingCount: number\n    readonly ageMs?: number\n    readonly coalescedCount?: number\n    readonly canceledCount?: number\n  }\n  readonly budget?: {\n    readonly budgetMs?: number\n    readonly sliceDurationMs?: number\n    readonly yieldCount?: number\n    readonly yielded?: boolean\n    readonly yieldReason?: TxnLaneNonUrgentYieldReason\n  }\n  readonly starvation?: {\n    readonly triggered?: boolean\n    readonly reason?: string\n  }\n  readonly reasons: ReadonlyArray<TxnLaneEvidenceReason>\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\n// trace:react-render / trace:react-selector \u4E8B\u4EF6\u53EF\u80FD\u4F1A\u5728 state:update \u4E4B\u524D\u8FDB\u5165 sink\uFF08\u5E76\u53D1/\u8C03\u5EA6\u5BFC\u81F4\u7684\u4E71\u5E8F\uFF09\u3002\n// \u4E3A\u4E86\u5728 Devtools/UI \u5C42\u62FF\u5230\u53EF\u7528\u7684 txn \u951A\u70B9\uFF0C\u8FD9\u91CC\u5141\u8BB8\u5BF9\u201C\u7F3A txn\u201D\u7684 ref \u505A\u4E00\u6B21\u540E\u8865\u3002\nconst pendingTxnAlignmentByInstance = new Map<string, Array<RuntimeDebugEventRef>>()\n\nconst enqueuePendingTxnAlignment = (instanceId: string, ref: RuntimeDebugEventRef): void => {\n  const list = pendingTxnAlignmentByInstance.get(instanceId)\n  if (!list) {\n    pendingTxnAlignmentByInstance.set(instanceId, [ref])\n    return\n  }\n  list.push(ref)\n  if (list.length > 64) {\n    list.shift()\n  }\n}\n\nconst backfillPendingTxnAlignment = (\n  instanceId: string,\n  txn: { readonly txnId: string; readonly txnSeq: number },\n): void => {\n  const pending = pendingTxnAlignmentByInstance.get(instanceId)\n  if (!pending || pending.length === 0) {\n    pendingTxnAlignmentByInstance.delete(instanceId)\n    return\n  }\n\n  for (const ref of pending) {\n    const anyRef: any = ref as any\n    if (anyRef.txnId == null) {\n      anyRef.txnId = txn.txnId\n    }\n    if (typeof anyRef.txnSeq !== 'number' || anyRef.txnSeq <= 0) {\n      anyRef.txnSeq = txn.txnSeq\n    }\n  }\n\n  pendingTxnAlignmentByInstance.delete(instanceId)\n}\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    const enriched = event as Event\n\n    const diagnosticsLevel = yield* FiberRef.get(currentDiagnosticsLevel)\n\n    // \u4E3A Debug.Event \u8865\u5168\u57FA\u7840\u5B57\u6BB5\uFF08\u4EC5\u5728 diagnosticsLevel!=off \u65F6\u542F\u7528\uFF09\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    let now: number | undefined\n    const getNow = (): number => {\n      if (now === undefined) now = Date.now()\n      return now\n    }\n\n    // diagnostics=off\uFF1A\u5C3D\u91CF\u4FDD\u6301\u8FD1\u96F6\u6210\u672C\uFF0C\u4E0D\u4E3A\u9AD8\u9891\u4E8B\u4EF6\u8865\u5168 timestamp\uFF08\u907F\u514D\u989D\u5916 Date.now()\uFF09\u3002\n    // \u4F4E\u9891\u4E8B\u4EF6\uFF08lifecycle:error/diagnostic\uFF09\u4ECD\u5141\u8BB8\u8865\u5168 timestamp\uFF0C\u4FBF\u4E8E\u5B9A\u4F4D\u4E0E\u6392\u67E5\u3002\n    if (\n      enriched.timestamp === undefined &&\n      (diagnosticsLevel !== 'off' || enriched.type === 'lifecycle:error' || enriched.type === 'diagnostic')\n    ) {\n      ;(enriched as any).timestamp = getNow()\n    }\n    if (diagnosticsLevel !== 'off' && enriched.runtimeLabel === undefined) {\n      const runtimeLabel = yield* FiberRef.get(currentRuntimeLabel)\n      if (runtimeLabel) {\n        ;(enriched as any).runtimeLabel = runtimeLabel\n      }\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 (\n      diagnosticsLevel !== 'off' &&\n      (enriched as any).type === 'trace:effectop' &&\n      (enriched as any).linkId === undefined\n    ) {\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 resolveConvergeStaticIr?: (staticIrDigest: string) => ConvergeStaticIrExport | undefined\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 = 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    case 'state:update': {\n      const e = event as Extract<Event, { readonly type: 'state:update' }>\n      const metaInput = isLightLike\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        backfillPendingTxnAlignment(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    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 = isLightLike\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:txn-lane\uFF1ATxn Lanes \u7684 Slim \u8BC1\u636E\uFF08lane/backlog/reasons\uFF09\uFF0C\u7528\u4E8E Devtools \u6C47\u603B\u4E0E\u79BB\u7EBF\u5BFC\u51FA\u3002\n      if (event.type === 'trace:txn-lane') {\n        const data: any = (event as any).data\n        const evidence = data?.evidence ?? data\n\n        const metaProjection = projectJsonValue(evidence)\n        options?.onMetaProjection?.({\n          stats: metaProjection.stats,\n          downgrade: metaProjection.downgrade,\n        })\n        downgrade = mergeDowngrade(downgrade, metaProjection.downgrade)\n\n        const label =\n          typeof evidence?.kind === 'string' && evidence.kind.length > 0 ? String(evidence.kind) : 'txn-lane'\n\n        return withDowngrade({\n          ...base,\n          kind: 'txn-lane',\n          label,\n          meta: metaProjection.value,\n        })\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 =\n          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        const ref = 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        if (instanceId !== 'unknown' && (ref.txnId == null || ref.txnSeq <= 0)) {\n          enqueuePendingTxnAlignment(instanceId, ref)\n        }\n\n        return ref\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          evalMs: data?.evalMs,\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          reasonCode: data?.reasonCode ?? data?.reason,\n          reasonDetail: data?.reasonDetail,\n          execIrVersion: data?.execIrVersion,\n          execIrHash: data?.execIrHash,\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      // 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 resolveDirtyRootPaths = (args: {\n          readonly staticIrDigest: unknown\n          readonly rootIds: unknown\n        }): ReadonlyArray<JsonValue> | undefined => {\n          const resolve = options?.resolveConvergeStaticIr\n          if (!resolve) return undefined\n          const digest = args.staticIrDigest\n          if (typeof digest !== 'string' || digest.length === 0) return undefined\n\n          const rootIds = args.rootIds\n          if (!Array.isArray(rootIds) || rootIds.length === 0) return undefined\n\n          const ir = resolve(digest) as ConvergeStaticIrExport | undefined\n          const fieldPaths = (ir as any)?.fieldPaths as unknown\n          if (!Array.isArray(fieldPaths) || fieldPaths.length === 0) return undefined\n\n          const out: Array<JsonValue> = []\n          for (const id of rootIds) {\n            if (typeof id !== 'number' || !Number.isFinite(id)) continue\n            const idx = Math.floor(id)\n            if (idx < 0 || idx >= fieldPaths.length) continue\n            const path = fieldPaths[idx]\n            if (Array.isArray(path)) {\n              out.push(path as any)\n            }\n          }\n\n          return out.length > 0 ? out : undefined\n        }\n\n        const enrichDirtyRootPaths = (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          if (!dirty || typeof dirty !== 'object' || Array.isArray(dirty)) return value\n\n          const dirtyRootPaths = resolveDirtyRootPaths({\n            staticIrDigest: anyValue.staticIrDigest,\n            rootIds: dirty?.rootIds,\n          })\n          if (!dirtyRootPaths) return value\n\n          return {\n            ...anyValue,\n            dirty: {\n              ...(dirty as any),\n              rootPaths: dirtyRootPaths,\n            },\n          } as JsonValue\n        }\n\n        const stripHeavyLight = (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 dirtyRootPaths = resolveDirtyRootPaths({\n            staticIrDigest: anyValue.staticIrDigest,\n            rootIds: dirty?.rootIds,\n          })\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                  ...(Array.isArray((dirty as any).rootIds) ? { rootIds: (dirty as any).rootIds } : null),\n                  ...(typeof (dirty as any).rootIdsTruncated === 'boolean'\n                    ? { rootIdsTruncated: (dirty as any).rootIdsTruncated }\n                    : null),\n                  ...(dirtyRootPaths ? { rootPaths: dirtyRootPaths } : null),\n                }\n              : undefined\n\n          const { top3, dirtyRoots, ...rest } = anyValue\n          return (dirtySlim ? { ...rest, dirty: dirtySlim } : rest) as JsonValue\n        }\n\n        const stripHeavySampled = (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' ? { reason: (dirty as any).reason } : null),\n                }\n              : undefined\n\n          const { 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 =\n          diagnosticsLevel === 'light'\n            ? stripHeavyLight(data)\n            : diagnosticsLevel === 'sampled'\n              ? stripHeavySampled(data)\n              : enrichDirtyRootPaths(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 = isLightLike ? 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 = isLightLike\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 = isLightLike\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 = isLightLike\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 = isLightLike\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        isLightLike\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", "diagnosticsLevel", "metaProjection"]
}
