@graphrefly/graphrefly 0.38.0 → 0.40.0

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 (321) hide show
  1. package/dist/budget-gate-CmmVtasH.d.ts +115 -0
  2. package/dist/budget-gate-DiP_nK0n.d.cts +115 -0
  3. package/dist/{cascading-BsJ4GbnS.d.ts → cascading-BNfxffgc.d.ts} +2 -2
  4. package/dist/{cascading-B25wxpRa.d.cts → cascading-Cxs1eztH.d.cts} +2 -2
  5. package/dist/chunk-2BX4NB34.js +3 -0
  6. package/dist/{chunk-6VFC334U.js → chunk-2DMKW2AD.js} +1 -1
  7. package/dist/{chunk-4BDQXBXE.js → chunk-2QXRYP7Q.js} +1 -1
  8. package/dist/chunk-32N3JALT.js +1 -0
  9. package/dist/chunk-35JTVPOX.js +1 -0
  10. package/dist/chunk-3G5U5QNE.js +5 -0
  11. package/dist/{chunk-PHXZRR6C.js → chunk-4I45FVQS.js} +1 -1
  12. package/dist/{chunk-B5S7KTGP.js → chunk-6I726LZU.js} +1 -1
  13. package/dist/{chunk-NV63VQHI.js → chunk-6VWBPSSY.js} +1 -1
  14. package/dist/chunk-6XVD5TZV.js +1 -0
  15. package/dist/chunk-756D5TFD.js +1 -0
  16. package/dist/{chunk-DSOVKKTI.js → chunk-7Q4ZD3YW.js} +1 -1
  17. package/dist/{chunk-TMVY7OWG.js → chunk-B7LCDQEV.js} +1 -1
  18. package/dist/chunk-C72GO4IZ.js +1 -0
  19. package/dist/{chunk-RZ5HKPGI.js → chunk-CKFQS2CJ.js} +1 -1
  20. package/dist/chunk-D27JNOLZ.js +1 -0
  21. package/dist/chunk-ECQRP2UT.js +1 -0
  22. package/dist/{chunk-6773HURD.js → chunk-FHRBBHJN.js} +1 -1
  23. package/dist/{chunk-UVLZX2OU.js → chunk-I2DEVPMU.js} +1 -1
  24. package/dist/chunk-INQFTVZA.js +61 -0
  25. package/dist/{chunk-6KZZ6XQE.js → chunk-J63M5U46.js} +1 -1
  26. package/dist/{chunk-POCWFIJ7.js → chunk-JKBOIJ22.js} +1 -1
  27. package/dist/chunk-K2Z7UENB.js +1 -0
  28. package/dist/chunk-L6NSJVJZ.js +1 -0
  29. package/dist/{chunk-K5C67OGE.js → chunk-LCGAVGGV.js} +2 -2
  30. package/dist/chunk-LYM4PBMV.js +1 -0
  31. package/dist/{chunk-O2BLVQU4.js → chunk-MNZIKXK4.js} +1 -1
  32. package/dist/chunk-N43XM7BM.js +1 -0
  33. package/dist/{chunk-FWGIZP3W.js → chunk-OSZ22J7O.js} +1 -1
  34. package/dist/{chunk-FAYEMS5M.js → chunk-PPUYQ66A.js} +1 -1
  35. package/dist/{chunk-SP5O2MIX.js → chunk-QSK3RRII.js} +1 -1
  36. package/dist/chunk-RZJDIV2G.js +1 -0
  37. package/dist/chunk-SSCGRYJ2.js +1 -0
  38. package/dist/chunk-SVFKHUCW.js +1 -0
  39. package/dist/chunk-TSOYJ743.js +1 -0
  40. package/dist/{chunk-O245YLM5.js → chunk-UWA6D7UF.js} +1 -1
  41. package/dist/chunk-VMF23LGB.js +1 -0
  42. package/dist/chunk-WL6LFPJB.js +1 -0
  43. package/dist/chunk-WUT362QV.js +1 -0
  44. package/dist/chunk-XJLYLLIJ.js +1 -0
  45. package/dist/{chunk-IBGE62GZ.js → chunk-XW4YDF6G.js} +1 -1
  46. package/dist/chunk-YKD7WUYJ.js +43 -0
  47. package/dist/{chunk-7KZZLWZ6.js → chunk-YXDRGKXP.js} +1 -1
  48. package/dist/chunk-Z4F3DOWS.js +84 -0
  49. package/dist/compat/index.cjs +9 -13
  50. package/dist/compat/index.d.cts +16 -16
  51. package/dist/compat/index.d.ts +16 -16
  52. package/dist/compat/index.js +1 -1
  53. package/dist/compat/jotai/index.d.cts +2 -2
  54. package/dist/compat/jotai/index.d.ts +2 -2
  55. package/dist/compat/nanostores/index.d.cts +2 -2
  56. package/dist/compat/nanostores/index.d.ts +2 -2
  57. package/dist/compat/nestjs/index.cjs +7 -11
  58. package/dist/compat/nestjs/index.d.cts +8 -8
  59. package/dist/compat/nestjs/index.d.ts +8 -8
  60. package/dist/compat/nestjs/index.js +1 -1
  61. package/dist/compat/react/index.d.cts +2 -2
  62. package/dist/compat/react/index.d.ts +2 -2
  63. package/dist/compat/solid/index.d.cts +2 -2
  64. package/dist/compat/solid/index.d.ts +2 -2
  65. package/dist/compat/svelte/index.d.cts +2 -2
  66. package/dist/compat/svelte/index.d.ts +2 -2
  67. package/dist/compat/vue/index.d.cts +2 -2
  68. package/dist/compat/vue/index.d.ts +2 -2
  69. package/dist/compat/zustand/index.cjs +3 -7
  70. package/dist/compat/zustand/index.d.cts +4 -4
  71. package/dist/compat/zustand/index.d.ts +4 -4
  72. package/dist/compat/zustand/index.js +1 -1
  73. package/dist/core/index.cjs +1 -1
  74. package/dist/core/index.d.cts +4 -4
  75. package/dist/core/index.d.ts +4 -4
  76. package/dist/core/index.js +1 -1
  77. package/dist/{composite-DTOlDuch.d.ts → decay-BnrlbxSv.d.ts} +39 -3
  78. package/dist/{composite-CgG0MqHm.d.cts → decay-C25AyNAj.d.cts} +39 -3
  79. package/dist/extra/browser.d.cts +1 -1
  80. package/dist/extra/browser.d.ts +1 -1
  81. package/dist/extra/index.cjs +16 -20
  82. package/dist/extra/index.d.cts +11 -9
  83. package/dist/extra/index.d.ts +11 -9
  84. package/dist/extra/index.js +1 -1
  85. package/dist/extra/node.cjs +2 -2
  86. package/dist/extra/node.d.cts +1 -1
  87. package/dist/extra/node.d.ts +1 -1
  88. package/dist/extra/node.js +1 -1
  89. package/dist/extra/operators.cjs +1 -1
  90. package/dist/extra/operators.d.cts +1 -1
  91. package/dist/extra/operators.d.ts +1 -1
  92. package/dist/extra/operators.js +1 -1
  93. package/dist/extra/reactive.cjs +1 -1
  94. package/dist/extra/reactive.d.cts +3 -3
  95. package/dist/extra/reactive.d.ts +3 -3
  96. package/dist/extra/reactive.js +1 -1
  97. package/dist/extra/render/index.cjs +5 -0
  98. package/dist/extra/render/index.d.cts +183 -0
  99. package/dist/extra/render/index.d.ts +183 -0
  100. package/dist/extra/render/index.js +1 -0
  101. package/dist/extra/sources.cjs +1 -1
  102. package/dist/extra/sources.d.cts +1 -1
  103. package/dist/extra/sources.d.ts +1 -1
  104. package/dist/extra/sources.js +1 -1
  105. package/dist/extra/storage-browser.d.cts +1 -1
  106. package/dist/extra/storage-browser.d.ts +1 -1
  107. package/dist/{fallback-axI2cXwt.d.cts → fallback-8JYU8tlT.d.cts} +1 -1
  108. package/dist/{fallback-DuEXfA4F.d.ts → fallback-CMZl39L5.d.ts} +1 -1
  109. package/dist/graph/index.cjs +7 -7
  110. package/dist/graph/index.d.cts +5 -5
  111. package/dist/graph/index.d.ts +5 -5
  112. package/dist/graph/index.js +1 -1
  113. package/dist/{graph-BjW1taJl.d.ts → graph-BkIkog4h.d.ts} +76 -100
  114. package/dist/{graph-CHsVwf9S.d.cts → graph-E6likq7w.d.cts} +76 -100
  115. package/dist/{index-CIcu6fIR.d.ts → index-2n8Eai6M.d.ts} +1 -1
  116. package/dist/{index-BwOsJfLJ.d.ts → index-3k4Gg6-n.d.ts} +3 -3
  117. package/dist/{index-BUFCHvOR.d.ts → index-40ZT4MHj.d.ts} +3 -3
  118. package/dist/index-8s-Qm-gz.d.ts +218 -0
  119. package/dist/index-A3U3CSve.d.cts +113 -0
  120. package/dist/{index-CDvC1m5p.d.ts → index-B2RUoIUz.d.ts} +1 -1
  121. package/dist/{index-Byp771zP.d.ts → index-B6iTqKtJ.d.ts} +2 -2
  122. package/dist/{index-D-B7U42V.d.cts → index-B72TQQHd.d.cts} +2 -2
  123. package/dist/{resilience-Bys63Cpd.d.ts → index-BAQrjuZF.d.ts} +202 -26
  124. package/dist/{index-BiomL7AW.d.ts → index-BJSZxSFX.d.ts} +1 -1
  125. package/dist/index-BQ1fR4li.d.ts +210 -0
  126. package/dist/{index-D7-RSD93.d.cts → index-BTHOTC0Q.d.cts} +4 -4
  127. package/dist/{index-CEVzBWeB.d.ts → index-BaA-xpSw.d.ts} +26 -19
  128. package/dist/{index-CAV-3RpJ.d.cts → index-Bd91Nmf4.d.cts} +4 -4
  129. package/dist/{index-BI1wMfyc.d.ts → index-BgjS2b8N.d.ts} +3 -3
  130. package/dist/{index-Bpr0Pwgl.d.cts → index-BiHUBEKq.d.cts} +3 -3
  131. package/dist/{index-UsU9ptzs.d.cts → index-BilOa6AE.d.cts} +55 -9
  132. package/dist/{index-DJVQ-t07.d.ts → index-BmSQLAZo.d.cts} +41 -48
  133. package/dist/{index-DTDVDzhA.d.ts → index-C-dkXOpB.d.cts} +56 -54
  134. package/dist/{index-B-ORMr3k.d.ts → index-C5cQ7Gfx.d.ts} +4 -4
  135. package/dist/{index-ML6vHKXK.d.ts → index-C6ZUaos7.d.ts} +1 -1
  136. package/dist/{index-Vz7KPfgz.d.ts → index-CAP3UGsq.d.ts} +1 -1
  137. package/dist/{index-BFaALJxR.d.ts → index-CD2dBMet.d.ts} +10 -8
  138. package/dist/index-CGhMJNHb.d.cts +128 -0
  139. package/dist/{index-B3D_z0Z6.d.cts → index-CL7oilfm.d.cts} +1 -1
  140. package/dist/{index-Bn0uZEL4.d.ts → index-CQtWm7jS.d.ts} +9 -9
  141. package/dist/{index-CM-i58FY.d.cts → index-CRm0YIzC.d.cts} +9 -9
  142. package/dist/index-CUIkE1l9.d.cts +230 -0
  143. package/dist/{index-CijfwEWx.d.ts → index-Cczxgd2D.d.ts} +2 -2
  144. package/dist/{index-CAbHN_rP.d.cts → index-CgnCFhr2.d.cts} +1 -1
  145. package/dist/{index-B2IUcH13.d.cts → index-Ck35nA-T.d.ts} +41 -48
  146. package/dist/{index-BpMZzX9P.d.cts → index-Cnr1WrlX.d.cts} +3 -3
  147. package/dist/{index-JYtN9uqM.d.ts → index-CoM4rzyB.d.ts} +1 -1
  148. package/dist/{index-Ckil6miL.d.cts → index-CtFNGe-m.d.cts} +2 -2
  149. package/dist/{index-BjWZARLy.d.ts → index-Ctb7_2sG.d.ts} +1 -1
  150. package/dist/index-CuPUehFa.d.cts +218 -0
  151. package/dist/index-D1Gc7wV5.d.ts +230 -0
  152. package/dist/{index-DqICM_I7.d.ts → index-D1IEZUsj.d.ts} +67 -9
  153. package/dist/{index-BFuVcqL8.d.cts → index-D3ayz3hy.d.cts} +1 -1
  154. package/dist/{index-CQsqqEVz.d.cts → index-D4uimgee.d.cts} +1 -1
  155. package/dist/{resilience-BWP2c7Af.d.cts → index-DGTo1yka.d.cts} +202 -26
  156. package/dist/{index-BmWuVdER.d.ts → index-DH4fm2Ck.d.ts} +2 -2
  157. package/dist/{index-BkQqf1EF.d.cts → index-DJ_MPOJ5.d.cts} +67 -9
  158. package/dist/{index-9xhIaM-w.d.cts → index-DOBLxOti.d.cts} +1 -1
  159. package/dist/{index-BqcgiSQg.d.cts → index-DQQCOIt8.d.cts} +10 -8
  160. package/dist/{index-DJNAWzcH.d.cts → index-DVAlsmEU.d.cts} +26 -19
  161. package/dist/index-DVDapw2k.d.cts +210 -0
  162. package/dist/{index-D_QQ_dTD.d.cts → index-DYTBbF8T.d.cts} +1 -1
  163. package/dist/{index-BgzPO43H.d.cts → index-DgJc8Zgc.d.cts} +6 -6
  164. package/dist/{index-Czk3r0yA.d.cts → index-DhLyOHYZ.d.ts} +56 -54
  165. package/dist/{index-CrlHFsiT.d.ts → index-DhnsQfa3.d.ts} +100 -118
  166. package/dist/{index-Bub6x_D4.d.cts → index-DktLSZOc.d.cts} +37 -90
  167. package/dist/{index-BaSy4L6w.d.cts → index-DpiGqtrs.d.cts} +100 -118
  168. package/dist/{index-D-HZ7sP4.d.ts → index-I1cCY3ZI.d.ts} +6 -6
  169. package/dist/{index-D9vBTuzo.d.ts → index-IUCY0OFN.d.ts} +4 -4
  170. package/dist/{index-DeSsvHDD.d.cts → index-MxYuWOrf.d.cts} +3 -3
  171. package/dist/index-N2MAxt7_.d.ts +128 -0
  172. package/dist/{index-CpZKtdMw.d.cts → index-PgwvGWa1.d.cts} +1 -1
  173. package/dist/{index-AUqWe_fX.d.ts → index-WSlcjhQF.d.ts} +55 -9
  174. package/dist/{index-Di7OdwlO.d.ts → index-bXXLSvor.d.ts} +37 -90
  175. package/dist/index-da2V5vPy.d.ts +113 -0
  176. package/dist/{index-DY2f2b9z.d.ts → index-eaQuGJnv.d.ts} +3 -3
  177. package/dist/{index-BsgxnHN8.d.cts → index-t6L2qpHh.d.cts} +3 -3
  178. package/dist/{index-C-3UXnHT.d.cts → index-tV3AA9hI.d.cts} +2 -2
  179. package/dist/{index-8OxXae3g.d.ts → index-yLt-aPMp.d.ts} +1 -1
  180. package/dist/{index-CqSJ25A9.d.cts → index-z8WFPVI8.d.cts} +1 -1
  181. package/dist/index.cjs +63 -59
  182. package/dist/index.d.cts +48 -47
  183. package/dist/index.d.ts +48 -47
  184. package/dist/index.js +1 -1
  185. package/dist/{meta-DreaEM_a.d.cts → meta-Ct9nqQS5.d.cts} +11 -7
  186. package/dist/{meta-BYqlATmg.d.ts → meta-D8OyedKp.d.ts} +11 -7
  187. package/dist/{node-fSc-hCv8.d.cts → node-BYInONRr.d.cts} +3 -3
  188. package/dist/{node-fSc-hCv8.d.ts → node-BYInONRr.d.ts} +3 -3
  189. package/dist/{observable-Cqty11jG.d.cts → observable-DMIlYJV1.d.cts} +1 -1
  190. package/dist/{observable-EAV_rNfM.d.ts → observable-DO8DDEzv.d.ts} +1 -1
  191. package/dist/patterns/ai/browser.cjs +5 -5
  192. package/dist/patterns/ai/browser.d.cts +4 -4
  193. package/dist/patterns/ai/browser.d.ts +4 -4
  194. package/dist/patterns/ai/browser.js +1 -1
  195. package/dist/patterns/ai/index.cjs +16 -20
  196. package/dist/patterns/ai/index.d.cts +17 -17
  197. package/dist/patterns/ai/index.d.ts +17 -17
  198. package/dist/patterns/ai/index.js +1 -1
  199. package/dist/patterns/ai/node.cjs +1 -1
  200. package/dist/patterns/ai/node.d.cts +4 -4
  201. package/dist/patterns/ai/node.d.ts +4 -4
  202. package/dist/patterns/ai/node.js +1 -1
  203. package/dist/patterns/audit/index.cjs +3 -7
  204. package/dist/patterns/audit/index.d.cts +6 -6
  205. package/dist/patterns/audit/index.d.ts +6 -6
  206. package/dist/patterns/audit/index.js +1 -1
  207. package/dist/patterns/cqrs/index.cjs +3 -7
  208. package/dist/patterns/cqrs/index.d.cts +6 -6
  209. package/dist/patterns/cqrs/index.d.ts +6 -6
  210. package/dist/patterns/cqrs/index.js +1 -1
  211. package/dist/patterns/demo-shell/index.cjs +5 -8
  212. package/dist/patterns/demo-shell/index.d.cts +5 -5
  213. package/dist/patterns/demo-shell/index.d.ts +5 -5
  214. package/dist/patterns/demo-shell/index.js +1 -1
  215. package/dist/patterns/domain-templates/index.cjs +3 -7
  216. package/dist/patterns/domain-templates/index.d.cts +4 -4
  217. package/dist/patterns/domain-templates/index.d.ts +4 -4
  218. package/dist/patterns/domain-templates/index.js +1 -1
  219. package/dist/patterns/graphspec/index.cjs +37 -37
  220. package/dist/patterns/graphspec/index.d.cts +5 -5
  221. package/dist/patterns/graphspec/index.d.ts +5 -5
  222. package/dist/patterns/graphspec/index.js +1 -1
  223. package/dist/patterns/guarded-execution/index.cjs +3 -7
  224. package/dist/patterns/guarded-execution/index.d.cts +7 -7
  225. package/dist/patterns/guarded-execution/index.d.ts +7 -7
  226. package/dist/patterns/guarded-execution/index.js +1 -1
  227. package/dist/patterns/harness/index.cjs +8 -12
  228. package/dist/patterns/harness/index.d.cts +12 -12
  229. package/dist/patterns/harness/index.d.ts +12 -12
  230. package/dist/patterns/harness/index.js +1 -1
  231. package/dist/patterns/job-queue/index.cjs +3 -7
  232. package/dist/patterns/job-queue/index.d.cts +6 -6
  233. package/dist/patterns/job-queue/index.d.ts +6 -6
  234. package/dist/patterns/job-queue/index.js +1 -1
  235. package/dist/patterns/lens/index.cjs +3 -7
  236. package/dist/patterns/lens/index.d.cts +5 -6
  237. package/dist/patterns/lens/index.d.ts +5 -6
  238. package/dist/patterns/lens/index.js +1 -1
  239. package/dist/patterns/memory/index.cjs +3 -7
  240. package/dist/patterns/memory/index.d.cts +6 -6
  241. package/dist/patterns/memory/index.d.ts +6 -6
  242. package/dist/patterns/memory/index.js +1 -1
  243. package/dist/patterns/messaging/index.cjs +3 -7
  244. package/dist/patterns/messaging/index.d.cts +5 -5
  245. package/dist/patterns/messaging/index.d.ts +5 -5
  246. package/dist/patterns/messaging/index.js +1 -1
  247. package/dist/patterns/orchestration/index.cjs +3 -7
  248. package/dist/patterns/orchestration/index.d.cts +8 -8
  249. package/dist/patterns/orchestration/index.d.ts +8 -8
  250. package/dist/patterns/orchestration/index.js +1 -1
  251. package/dist/patterns/process/index.cjs +1 -1
  252. package/dist/patterns/process/index.d.cts +7 -7
  253. package/dist/patterns/process/index.d.ts +7 -7
  254. package/dist/patterns/process/index.js +1 -1
  255. package/dist/patterns/reactive-layout/index.cjs +4 -8
  256. package/dist/patterns/reactive-layout/index.d.cts +5 -5
  257. package/dist/patterns/reactive-layout/index.d.ts +5 -5
  258. package/dist/patterns/reactive-layout/index.js +1 -1
  259. package/dist/patterns/reduction/index.cjs +3 -7
  260. package/dist/patterns/reduction/index.d.cts +4 -4
  261. package/dist/patterns/reduction/index.d.ts +4 -4
  262. package/dist/patterns/reduction/index.js +1 -1
  263. package/dist/patterns/refine-loop/index.cjs +5 -9
  264. package/dist/patterns/refine-loop/index.d.cts +6 -6
  265. package/dist/patterns/refine-loop/index.d.ts +6 -6
  266. package/dist/patterns/refine-loop/index.js +1 -1
  267. package/dist/patterns/resilient-pipeline/index.cjs +3 -1
  268. package/dist/patterns/resilient-pipeline/index.d.cts +6 -6
  269. package/dist/patterns/resilient-pipeline/index.d.ts +6 -6
  270. package/dist/patterns/resilient-pipeline/index.js +1 -1
  271. package/dist/patterns/surface/index.cjs +12 -16
  272. package/dist/patterns/surface/index.d.cts +6 -6
  273. package/dist/patterns/surface/index.d.ts +6 -6
  274. package/dist/patterns/surface/index.js +1 -1
  275. package/dist/{pipeline-graph-9JBbmRxA.d.ts → pipeline-graph-CB4La-UW.d.ts} +34 -17
  276. package/dist/{pipeline-graph-DuHpXSOn.d.cts → pipeline-graph-MWrQZXCq.d.cts} +34 -17
  277. package/dist/{reactive-layout-BMLDB4Vd.d.cts → reactive-layout-BtZfUKuL.d.cts} +2 -2
  278. package/dist/{reactive-layout-D-tRiNhg.d.ts → reactive-layout-KJj4E2dT.d.ts} +2 -2
  279. package/dist/{reactive-log-BgWSA1fg.d.ts → reactive-log-BlAsPLl2.d.ts} +2 -2
  280. package/dist/{reactive-log-C3IMAGpT.d.cts → reactive-log-_zeEnB9H.d.cts} +2 -2
  281. package/dist/{reactive-map-DmgeADH8.d.cts → reactive-map-6P_k3AQM.d.cts} +2 -2
  282. package/dist/{reactive-map-CHyeCf4D.d.ts → reactive-map-CjXByDV-.d.ts} +2 -2
  283. package/dist/resilience-S33JV6XC.js +1 -0
  284. package/dist/{sugar-D13E2M_z.d.ts → sugar-BhfjgetH.d.ts} +1 -1
  285. package/dist/{sugar-DgaGJcI6.d.cts → sugar-DzePN5-g.d.cts} +1 -1
  286. package/dist/{topology-tree-jrZue3ao.d.cts → topology-tree-3LBKFsUo.d.cts} +1 -1
  287. package/dist/{topology-tree-D47-nI6Z.d.ts → topology-tree-mF7Emqzm.d.ts} +1 -1
  288. package/dist/{types-BMSGPlpO.d.cts → types-1Dhoi7HM.d.cts} +1 -1
  289. package/dist/{types-CidcBDuk.d.ts → types-39jk0kaV.d.ts} +1 -1
  290. package/package.json +11 -1
  291. package/dist/chunk-2YFDSYEF.js +0 -1
  292. package/dist/chunk-5BGFS2XH.js +0 -1
  293. package/dist/chunk-CMTN3KPT.js +0 -80
  294. package/dist/chunk-DQJLC6YY.js +0 -1
  295. package/dist/chunk-G7JN6LCB.js +0 -1
  296. package/dist/chunk-KJEAIIIY.js +0 -43
  297. package/dist/chunk-LV3ACS5J.js +0 -1
  298. package/dist/chunk-NBGPXQSP.js +0 -1
  299. package/dist/chunk-NN3QPJ6U.js +0 -1
  300. package/dist/chunk-NSAZ6PR6.js +0 -1
  301. package/dist/chunk-O32GJOUJ.js +0 -1
  302. package/dist/chunk-QEVSIVSF.js +0 -1
  303. package/dist/chunk-QMC2PLNM.js +0 -7
  304. package/dist/chunk-QOJFR6GS.js +0 -1
  305. package/dist/chunk-SFK7MN7S.js +0 -1
  306. package/dist/chunk-TB7JKSVS.js +0 -61
  307. package/dist/chunk-UAXFKMAG.js +0 -1
  308. package/dist/chunk-XIMFHEKV.js +0 -1
  309. package/dist/chunk-XLMYQB6F.js +0 -1
  310. package/dist/chunk-XLYF4LBH.js +0 -1
  311. package/dist/imperative-audit-ahAE65a9.d.cts +0 -28
  312. package/dist/imperative-audit-ahAE65a9.d.ts +0 -28
  313. package/dist/index-5dNRlW7J.d.ts +0 -135
  314. package/dist/index-BWUMIt7J.d.cts +0 -135
  315. package/dist/index-BhzwpIJc.d.cts +0 -105
  316. package/dist/index-BsZk9T8y.d.ts +0 -105
  317. package/dist/index-C56XZiDe.d.cts +0 -163
  318. package/dist/index-CpdnP-0y.d.cts +0 -186
  319. package/dist/index-DKrIuF-r.d.ts +0 -163
  320. package/dist/index-DOU1Ee_k.d.ts +0 -186
  321. package/dist/resilience-LGBK236C.js +0 -1
@@ -1,7 +1,3 @@
1
- "use strict";var dt=Object.defineProperty;var Cn=Object.getOwnPropertyDescriptor;var Gn=Object.getOwnPropertyNames;var Mn=Object.prototype.hasOwnProperty;var W=(t,e)=>()=>(t&&(e=t(t=0)),e);var Ln=(t,e)=>{for(var n in e)dt(t,n,{get:e[n],enumerable:!0})},In=(t,e,n,r)=>{if(e&&typeof e=="object"||typeof e=="function")for(let s of Gn(e))!Mn.call(t,s)&&s!==n&&dt(t,s,{get:()=>e[s],enumerable:!(r=Cn(e,s))||r.enumerable});return t};var Pn=t=>In(dt({},"__esModule",{value:!0}),t);function U(){return Math.trunc(performance.now()*1e6)}function se(){return Date.now()*1e6}var Te=W(()=>{"use strict"});function It(t){return Array.isArray(t)?[...t]:[t]}function $n(t,e){return t.has(e)||t.has("*")}function Fn(t){let e=[];return t((s,o)=>{e.push({kind:"allow",actions:new Set(It(s)),where:o?.where??(()=>!0)})},(s,o)=>{e.push({kind:"deny",actions:new Set(It(s)),where:o?.where??(()=>!0)})}),(s,o)=>{let i=!1,a=!1;for(let d of e)$n(d.actions,o)&&d.where(s)&&(d.kind==="deny"?i=!0:a=!0);return i?!1:a}}function ct(t){return Fn((e,n)=>{for(let r of t){let s=r.actorType==null?null:new Set(Array.isArray(r.actorType)?r.actorType:[r.actorType]),o=r.actorId==null?null:new Set(Array.isArray(r.actorId)?r.actorId:[r.actorId]),i=Object.entries(r.claims??{}),a=d=>{if(s!==null&&!s.has(String(d.type))||o!==null&&!o.has(String(d.id??"")))return!1;for(let[u,c]of i)if(d[u]!==c)return!1;return!0};r.effect==="deny"?n(r.action,{where:a}):e(r.action,{where:a})}})}function lt(t){let e=Vn.filter(n=>t({type:n,id:""},"write"));return e.length===0?"restricted":e.includes("human")&&e.includes("llm")&&e.every(n=>n==="human"||n==="llm"||n==="system")?"both":e.length===1?e[0]:e.join("+")}var Z,Vn,he=W(()=>{"use strict";Z=class extends Error{actor;action;nodeName;constructor(e,n){super(n??`GuardDenied: action "${String(e.action)}" denied for actor type "${String(e.actor.type)}"`),this.name="GuardDenied",this.actor=e.actor,this.action=e.action,this.nodeName=e.nodeName}get node(){return this.nodeName}};Vn=["human","llm","wallet","system"]});var ge,G,K,q,Q,te,oe,F,z,I,de,Ce,Pt,Ge,$t,Ft,Me,ft,pt,ht,Le,ie=W(()=>{"use strict";ge=Symbol.for("graphrefly/START"),G=Symbol.for("graphrefly/DATA"),K=Symbol.for("graphrefly/DIRTY"),q=Symbol.for("graphrefly/RESOLVED"),Q=Symbol.for("graphrefly/INVALIDATE"),te=Symbol.for("graphrefly/PAUSE"),oe=Symbol.for("graphrefly/RESUME"),F=Symbol.for("graphrefly/TEARDOWN"),z=Symbol.for("graphrefly/COMPLETE"),I=Symbol.for("graphrefly/ERROR"),de=Object.freeze([K]),Ce=Object.freeze([q]),Pt=Object.freeze([Q]),Ge=Object.freeze([ge]),$t=Object.freeze([z]),Ft=Object.freeze([F]),Me=Object.freeze([de]),ft=Object.freeze([Ce]),pt=Object.freeze([Pt]),ht=Object.freeze([$t]),Le=Object.freeze([Ft])});function zt(t,e){let n=new TextEncoder().encode(t.name);if(n.length===0||n.length>255)throw new Error(`encodeEnvelope: codec name "${t.name}" encodes to ${n.length} bytes (must be 1\u2013255)`);let r=t.version;if(!Number.isInteger(r)||r<0||r>65535)throw new Error(`encodeEnvelope: codec.version ${r} out of u16 range (expected integer 0\u201365535)`);let s=2+n.length+2+e.length;if(s>4294967295)throw new Error(`encodeEnvelope: total envelope size ${s} exceeds 2^32-1 bytes (payload ${e.length} bytes)`);let o=new Uint8Array(s),i=0;return o[i++]=gt,o[i++]=n.length,o.set(n,i),i+=n.length,o[i++]=r>>>8&255,o[i++]=r&255,o.set(e,i),o}function Ht(t,e){if(t.length<Vt)throw new Error(`decodeEnvelope: bytes too short (${t.length} < ${Vt})`);let n=0,r=t[n++];if(r!==gt)throw new Error(`decodeEnvelope: unsupported envelope version ${r} (expected ${gt})`);let s=t[n++];if(s===0)throw new Error("decodeEnvelope: name_len must be >= 1");if(n+s+2>t.length)throw new Error(`decodeEnvelope: envelope truncated (need ${n+s+2} bytes, have ${t.length})`);let o=new TextDecoder().decode(t.subarray(n,n+s));n+=s;let i=(t[n]<<8|t[n+1])>>>0;n+=2;let a=t.subarray(n),d=e.lookupCodec(o);if(d==null)throw new Error(`decodeEnvelope: codec "${o}" not registered (envelope codec_v=${i})`);return{codec:d,codecVersion:i,payload:a}}function jt(t){t.registerCodec(zn)}var zn,gt,Vt,mt=W(()=>{"use strict";zn={name:"json",version:1,contentType:"application/json",encode(t){let e=JSON.stringify(t);return new TextEncoder().encode(e)},decode(t,e){let n=new TextDecoder().decode(t);return JSON.parse(n)}},gt=1,Vt=4});function Ie(t){if(t==null)return me;let{type:e,id:n,...r}=t;return{type:e??"system",id:n??"",...r}}var me,Pe=W(()=>{"use strict";me={type:"system",id:""}});function $e(){return ye>0||Oe}function Bt(){return ye>0}function ve(t){ye>0?Ee.push(t):t()}function ke(t){ye+=1;let e=!1;try{t()}catch(n){throw e=!0,n}finally{if(ye-=1,ye===0)if(e){if(!Oe){let n=Ee.splice(0);for(let r of n)try{r()}catch{}ce.length=0,le.length=0,be.length=0}}else Hn()}}function Hn(){let t=!Oe;t&&(Oe=!0);let e=[],n=0;try{for(;ce.length>0||le.length>0||be.length>0||t&&Ee.length>0;){if(t&&Ee.length>0){let o=Ee.splice(0);for(let i of o)try{i()}catch(a){e.push(a)}continue}if(n+=1,n>1e3)throw ce.length=0,le.length=0,be.length=0,new Error("batch drain exceeded 1000 iterations \u2014 likely a reactive cycle");let s=(ce.length>0?ce:le.length>0?le:be).splice(0);for(let o of s)try{o()}catch(i){e.push(i)}}}finally{t&&(Oe=!1)}if(e.length===1)throw e[0];if(e.length>1)throw new AggregateError(e,"batch drain: multiple callbacks threw")}function Fe(t,e,n){if(e.length===0)return;if(e.length===1){let u=n(e[0][0]);if(u<3||!$e()){t(e);return}(u>=5?be:u===4?le:ce).push(()=>t(e));return}let r=e.length,s=r,o=r,i=r,a=0;for(;a<r&&n(e[a][0])<3;)a++;for(s=a;a<r&&n(e[a][0])===3;)a++;for(o=a;a<r&&n(e[a][0])===4;)a++;i=a;let d=$e();if(s>0){let u=e.slice(0,s);t(u)}if(o>s){let u=e.slice(s,o);d?ce.push(()=>t(u)):t(u)}if(i>o){let u=e.slice(o,i);d?le.push(()=>t(u)):t(u)}if(r>i){let u=e.slice(i,r);d?be.push(()=>t(u)):t(u)}}var ye,Oe,ce,le,be,Ee,Ve=W(()=>{"use strict";ye=0,Oe=!1,ce=[],le=[],be=[],Ee=[]});function Wt(t){t.registerMessageType(ge,{tier:0,wireCrossing:!1}),t.registerMessageType(K,{tier:1,wireCrossing:!1}),t.registerMessageType(Q,{tier:1,wireCrossing:!1,metaPassthrough:!1}),t.registerMessageType(te,{tier:2,wireCrossing:!1}),t.registerMessageType(oe,{tier:2,wireCrossing:!1}),t.registerMessageType(G,{tier:3,wireCrossing:!0}),t.registerMessageType(q,{tier:3,wireCrossing:!0}),t.registerMessageType(z,{tier:4,wireCrossing:!0,metaPassthrough:!1}),t.registerMessageType(I,{tier:4,wireCrossing:!0,metaPassthrough:!1}),t.registerMessageType(F,{tier:5,wireCrossing:!0,metaPassthrough:!1})}var ze,Ut=W(()=>{"use strict";ie();ze=class{_messageTypes=new Map;_codecs=new Map;_onMessage;_onSubscribe;_defaultVersioning;_defaultHashFn;_inspectorEnabled=!(typeof process<"u"&&process.env?.NODE_ENV==="production");_globalInspector;_rigorRecorder;_frozen=!1;tierOf;constructor(e){this._onMessage=e.onMessage,this._onSubscribe=e.onSubscribe,this._defaultVersioning=e.defaultVersioning,this._defaultHashFn=e.defaultHashFn,this.tierOf=n=>{let r=this._messageTypes.get(n);return r!=null?r.tier:1}}get onMessage(){return this._frozen=!0,this._onMessage}get onSubscribe(){return this._frozen=!0,this._onSubscribe}set onMessage(e){this._assertUnfrozen(),this._onMessage=e}set onSubscribe(e){this._assertUnfrozen(),this._onSubscribe=e}get defaultVersioning(){return this._defaultVersioning}set defaultVersioning(e){this._assertUnfrozen(),this._defaultVersioning=e}get defaultHashFn(){return this._defaultHashFn}set defaultHashFn(e){this._assertUnfrozen(),this._defaultHashFn=e}get inspectorEnabled(){return this._inspectorEnabled}set inspectorEnabled(e){this._inspectorEnabled=e}get globalInspector(){return this._globalInspector}set globalInspector(e){this._globalInspector=e}get rigorRecorder(){return this._rigorRecorder}set rigorRecorder(e){this._rigorRecorder=e}registerMessageType(e,n){return this._assertUnfrozen(),this._messageTypes.set(e,{tier:n.tier,wireCrossing:n.wireCrossing??n.tier>=3,metaPassthrough:n.metaPassthrough??!0}),this}messageTier(e){let n=this._messageTypes.get(e);return n!=null?n.tier:1}isWireCrossing(e){let n=this._messageTypes.get(e);return n!=null?n.wireCrossing:!0}isLocalOnly(e){return!this.isWireCrossing(e)}isMetaPassthrough(e){let n=this._messageTypes.get(e);return n!=null?n.metaPassthrough:!0}isKnownMessageType(e){return this._messageTypes.has(e)}registerCodec(e){return this._assertUnfrozen(),this._codecs.set(e.name,e),this}lookupCodec(e){return this._codecs.get(e)}_isFrozen(){return this._frozen}_assertUnfrozen(){if(this._frozen)throw new Error("GraphReFlyConfig is frozen: a node has already captured this config. Register custom types and set hooks before creating any node.")}}});function yt(t){if(t===void 0)return null;if(typeof t=="number"){if(!Number.isFinite(t))throw new TypeError(`Cannot hash non-finite number: ${t}`);if(Number.isInteger(t)&&!Number.isSafeInteger(t))throw new TypeError(`Cannot hash integer outside safe range (|n| > 2^53-1): ${t}. Cross-language cid parity is not guaranteed for unsafe integers.`);return t}if(typeof t=="string"||typeof t=="boolean"||t===null)return t;if(Array.isArray(t))return t.map(yt);if(typeof t=="object"&&t!==null){let e={};for(let n of Object.keys(t).sort())e[n]=yt(t[n]);return e}return null}function Wn(t){let e=Bn.encode(t),n=e.length,r=n*8,s=n+9+63&-64,o=new Uint8Array(s);o.set(e),o[n]=128;let i=new DataView(o.buffer);i.setUint32(s-4,r>>>0,!1),i.setUint32(s-8,Math.floor(r/4294967296)>>>0,!1);let a=1779033703,d=3144134277,u=1013904242,c=2773480762,f=1359893119,p=2600822924,h=528734635,l=1541459225,y=new Uint32Array(64),m=(_,v)=>_>>>v|_<<32-v;for(let _=0;_<s;_+=64){for(let k=0;k<16;k++)y[k]=i.getUint32(_+k*4,!1);for(let k=16;k<64;k++){let R=y[k-15],N=y[k-2],D=m(R,7)^m(R,18)^R>>>3,H=m(N,17)^m(N,19)^N>>>10;y[k]=y[k-16]+D+y[k-7]+H>>>0}let v=a,x=d,E=u,T=c,g=f,b=p,O=h,A=l;for(let k=0;k<64;k++){let R=m(g,6)^m(g,11)^m(g,25),N=g&b^~g&O,D=A+R+N+jn[k]+y[k]>>>0,H=m(v,2)^m(v,13)^m(v,22),V=v&x^v&E^x&E,ue=H+V>>>0;A=O,O=b,b=g,g=T+D>>>0,T=E,E=x,x=v,v=D+ue>>>0}a=a+v>>>0,d=d+x>>>0,u=u+E>>>0,c=c+T>>>0,f=f+g>>>0,p=p+b>>>0,h=h+O>>>0,l=l+A>>>0}let w=_=>_.toString(16).padStart(8,"0");return w(a)+w(d)+w(u)+w(c)+w(f)+w(p)+w(h)+w(l)}function Ne(t){let e=yt(t??null),n=JSON.stringify(e);return Wn(n).slice(0,16)}function Un(){let t=globalThis.crypto;if(t?.randomUUID)return t.randomUUID();let e=()=>Math.floor(Math.random()*4294967296).toString(16).padStart(8,"0"),n=e()+e()+e()+e();return`${n.slice(0,8)}-${n.slice(8,12)}-4${n.slice(13,16)}-${(parseInt(n.slice(16,17),16)&3|8).toString(16)}${n.slice(17,20)}-${n.slice(20,32)}`}function bt(t,e,n){let r=n?.id??Un();if(t===0)return{id:r,version:0};let o=(n?.hash??Ne)(e);return{id:r,version:0,cid:o,prev:null}}function Kt(t,e,n){t.version+=1,"cid"in t&&(t.prev=t.cid,t.cid=n(e))}var jn,Bn,vt=W(()=>{"use strict";jn=new Uint32Array([1116352408,1899447441,3049323471,3921009573,961987163,1508970993,2453635748,2870763221,3624381080,310598401,607225278,1426881987,1925078388,2162078206,2614888103,3248222580,3835390401,4022224774,264347078,604807628,770255983,1249150122,1555081692,1996064986,2554220882,2821834349,2952996808,3210313671,3336571891,3584528711,113926993,338241895,666307205,773529912,1294757372,1396182291,1695183700,1986661051,2177026350,2456956037,2730485921,2820302411,3259730800,3345764771,3516065817,3600352804,4094571909,275423344,430227734,506948616,659060556,883997877,958139571,1322822218,1537002063,1747873779,1955562222,2024104815,2227730452,2361852424,2428436474,2756734187,3204031479,3329325298]),Bn=new TextEncoder});function Jt(t){return{node:t,unsub:null,prevData:void 0,dirty:!1,involvedThisWave:!1,dataBatch:[],terminal:void 0}}function _t(t){t.prevData=void 0,t.dirty=!1,t.involvedThisWave=!1,t.dataBatch.length=0,t.terminal=void 0}function He(t){return t.length===0?t:typeof t[0]=="symbol"?[t]:t}function we(t,e,n){let r=Xt(t)?t:[],s=typeof t=="function"?t:typeof e=="function"?e:void 0,o={};return Xt(t)?o=(wt(e)?e:n)??{}:wt(t)?o=t:o=(wt(e)?e:n)??{},new P(r,s,o)}var qt,Yt,Kn,qn,_e,P,Xt,wt,fe=W(()=>{"use strict";mt();Pe();Ve();Te();Ut();he();ie();vt();qt=()=>{},Yt=100;Kn=(t,e,n,r)=>{n.direction==="down-in"&&t._onDepMessage(n.depIndex,e)},qn=(t,e,n,r)=>{let s=t;if(s._status==="completed"||s._status==="errored")return;let o=s._cached,i=o===void 0?[Ge]:[Ge,[G,o]];s._status==="dirty"&&i.push(de),Fe(e,i,s._config.tierOf)},_e=new ze({onMessage:Kn,onSubscribe:qn});Wt(_e);jt(_e);P=class t{_optsName;_describeKind;meta;_hasMeta;_config;_deps;_sinks=null;_sinkCount=0;_cached;_status;_cleanup;_store={};_waveHasNewData=!1;_hasNewTerminal=!1;_hasCalledFnOnce=!1;_paused=!1;_pendingWave=!1;_isExecutingFn=!1;_pendingRerun=!1;_rerunDepth=0;_dirtyDepCount=0;_batchPendingMessages=null;_pauseLocks=null;_pauseBuffer=null;_fn;_equals;_resubscribable;_resetOnTeardown;_autoComplete;_autoError;_pausable;_partial;_guard;_extraGuards;_hashFn;_versioning;_versioningLevel;_lastMutation;_inspectorHooks;_actions;constructor(e,n,r){this._config=r.config??_e,this._config.onMessage,this._optsName=r.name,this._describeKind=r.describeKind,this._equals=r.equals??Object.is,this._resubscribable=r.resubscribable??!1,this._resetOnTeardown=r.resetOnTeardown??!1,this._autoComplete=r.completeWhenDepsComplete??!0,this._autoError=r.errorWhenDepsError??!0,this._pausable=r.pausable??!0,this._guard=r.guard,this._fn=n,this._partial=r.partial??!1,this._cached=r.initial!==void 0?r.initial:void 0,this._status=e.length===0&&n==null&&this._cached!==void 0?"settled":"sentinel",this._hashFn=r.versioningHash??this._config.defaultHashFn??Ne;let s=r.versioning??this._config.defaultVersioning;this._versioningLevel=s,this._versioning=s!=null?bt(s,this._cached===void 0?void 0:this._cached,{id:r.versioningId,hash:this._hashFn}):void 0,this._deps=e.map(Jt);let o={};for(let[a,d]of Object.entries(r.meta??{})){let u={initial:d,name:`${r.name??"node"}:meta:${a}`,describeKind:"state",config:this._config};r.guard!=null&&(u.guard=r.guard),o[a]=new t([],void 0,u)}Object.freeze(o),this.meta=o,this._hasMeta=Object.keys(o).length>0;let i=this;this._actions={emit(a){i._emit([[G,a]])},down(a){i._emit(He(a))},up(a){i._emitUp(He(a))}},this.down=this.down.bind(this),this.up=this.up.bind(this)}get _isTerminal(){return this._status==="completed"||this._status==="errored"}get name(){return this._optsName}get status(){return this._status}get cache(){return this._cached===void 0?void 0:this._cached}get lastMutation(){return this._lastMutation}get v(){return this._versioning}hasGuard(){return this._guard!=null}_applyVersioning(e,n){if(this._isExecutingFn)throw new Error(`Node "${this.name}": _applyVersioning cannot run mid-fn \u2014 call it outside of \`_execFn\` (typically at graph setup time before the first subscribe).`);let r=this._versioningLevel;if(r!=null&&e<=r)return;let s=n?.hash??this._hashFn;s!==this._hashFn&&(this._hashFn=s);let o=this._cached===void 0?void 0:this._cached,i=this._versioning,a=i?.id??n?.id,d=i?.version??0,u=bt(e,o,{id:a,hash:s});u.version=d,this._versioning=u,this._versioningLevel=e}_setInspectorHook(e){return e==null?()=>{}:(this._inspectorHooks==null&&(this._inspectorHooks=new Set),this._inspectorHooks.add(e),()=>{this._inspectorHooks?.delete(e),this._inspectorHooks?.size===0&&(this._inspectorHooks=void 0)})}_pushGuard(e){return this._extraGuards==null&&(this._extraGuards=new Set),this._extraGuards.add(e),()=>{this._extraGuards?.delete(e),this._extraGuards?.size===0&&(this._extraGuards=void 0)}}allowsObserve(e){if(this._guard==null&&this._extraGuards==null)return!0;let n=Ie(e);if(this._guard!=null&&!this._guard(n,"observe"))return!1;if(this._extraGuards!=null){for(let r of this._extraGuards)if(!r(n,"observe"))return!1}return!0}_checkGuard(e){if(e?.internal)return;let n=this._guard!=null||this._extraGuards!=null,r=e?.actor!=null;if(!n&&!r)return;let s=Ie(e?.actor),o=e?.delivery==="signal"?"signal":"write";if(this._guard!=null&&!this._guard(s,o))throw new Z({actor:s,action:o,nodeName:this.name});if(this._extraGuards!=null){for(let i of this._extraGuards)if(!i(s,o))throw new Z({actor:s,action:o,nodeName:this.name})}this._lastMutation={actor:s,timestamp_ns:se()}}down(e,n){let r=He(e);r.length!==0&&(this._checkGuard(n),this._emit(r))}emit(e,n){this._checkGuard(n),this._emit([[G,e]])}up(e,n){if(this._deps.length===0)return;let r=He(e);if(r.length===0)return;this._checkGuard(n);let s=n??{internal:!0};this._validateUpTiers(r);for(let o of this._deps)o.node.up?.(r,s)}_emitUp(e){if(this._deps.length!==0&&e.length!==0){this._validateUpTiers(e);for(let n of this._deps)n.node.up?.(e,{internal:!0})}}_validateUpTiers(e){let n=this._config.tierOf;for(let r of e){let s=n(r[0]);if(s===3||s===4)throw new Error(`Node "${this.name}": tier-${s} messages cannot flow up \u2014 DATA/RESOLVED/COMPLETE/ERROR are downstream-only. Use \`down(...)\` for value delivery; \`up(...)\` is for control signals (DIRTY, INVALIDATE, PAUSE, RESUME, TEARDOWN).`)}}subscribe(e,n){if(n!=null&&this._guard!=null){let d=Ie(n);if(!this._guard(d,"observe"))throw new Z({actor:d,action:"observe",nodeName:this.name})}let s=this._isTerminal&&this._resubscribable;if(s){this._cached=void 0,this._status="sentinel",this._store={},this._hasCalledFnOnce=!1,this._waveHasNewData=!1,this._hasNewTerminal=!1,this._paused=!1,this._pendingWave=!1,this._pendingRerun=!1,this._isExecutingFn=!1,this._rerunDepth=0,this._dirtyDepCount=0,this._pauseLocks=null,this._pauseBuffer=null;for(let d of this._deps)_t(d);if(this._partial===!1){for(let d of this._deps)if(d.prevData!==void 0||d.dataBatch.length!==0||d.terminal!==void 0||d.dirty)throw new Error(`resubscribable-reset invariant: DepRecord not fully reset for node ${this._optsName??"(anonymous)"}`)}}this._sinkCount+=1;let o;try{o=this._config.onSubscribe(this,e,{sinkCount:this._sinkCount,afterTerminalReset:s},this._actions)}catch(d){throw this._sinkCount-=1,d}this._sinks==null?this._sinks=e:typeof this._sinks=="function"?this._sinks=new Set([this._sinks,e]):this._sinks.add(e);let i=this._isTerminal;if(this._sinkCount===1&&!i)try{this._activate()}catch(d){if(this._sinkCount-=1,this._removeSink(e),this._sinkCount===0&&(this._status="sentinel"),typeof o=="function")try{o()}catch{}throw d}this._status==="sentinel"&&this._cached===void 0&&(this._status="pending");let a=!1;return()=>{a||(a=!0,this._sinkCount-=1,this._removeSink(e),typeof o=="function"&&o(),this._sinks==null&&this._deactivate())}}_removeSink(e){if(this._sinks===e)this._sinks=null;else if(this._sinks!=null&&typeof this._sinks!="function")if(this._sinks.delete(e),this._sinks.size===1){let[n]=this._sinks;this._sinks=n}else this._sinks.size===0&&(this._sinks=null)}_activate(){if(this._deps.length===0){this._fn&&this._execFn();return}this._dirtyDepCount=0;let e=this._deps.length,n=0;try{for(let r=0;r<e;r++){let s=r,o=this._deps[r];o.unsub=qt,o.unsub=o.node.subscribe(i=>{if(o.unsub===null)return;let a=this._config.tierOf,d=!1;for(let u of i)a(u[0])>=3&&(d=!0),this._config.onMessage(this,u,{direction:"down-in",depIndex:s},this._actions);d&&this._maybeRunFnOnSettlement()}),n++}}catch(r){this._deps[n].unsub=null;for(let s=0;s<n;s++){let o=this._deps[s];if(o.unsub!=null){let i=o.unsub;o.unsub=null;try{i()}catch{}_t(o)}}throw this._dirtyDepCount=0,r}}_addDep(e){for(let s=0;s<this._deps.length;s++)if(this._deps[s].node===e)return s;let n=this._deps.length,r=Jt(e);if(this._deps.push(r),this._sinks==null)return n;r.dirty=!0,this._dirtyDepCount++,this._status!=="dirty"&&this._emit(Me),r.unsub=qt;try{r.unsub=e.subscribe(s=>{if(r.unsub===null)return;let o=this._config.tierOf,i=!1;for(let a of s)o(a[0])>=3&&(i=!0),this._config.onMessage(this,a,{direction:"down-in",depIndex:n},this._actions);i&&this._maybeRunFnOnSettlement()})}catch(s){throw r.unsub=null,this._deps.pop(),this._dirtyDepCount--,s}return n}_deactivate(e=!1){let n=this._cleanup;if(this._cleanup=void 0,typeof n=="function")try{n()}catch(r){this._emit([[I,this._wrapFnError("cleanup threw",r)]])}else if(n!=null&&typeof n=="object"){let r=n.deactivate;if(typeof r=="function")try{r()}catch(s){this._emit([[I,this._wrapFnError("cleanup.deactivate threw",s)]])}}for(let r of this._deps){if(r.unsub!=null){let s=r.unsub;r.unsub=null;try{s()}catch{}}_t(r)}this._waveHasNewData=!1,this._hasNewTerminal=!1,this._hasCalledFnOnce=!1,this._paused=!1,this._pendingWave=!1,this._pendingRerun=!1,this._rerunDepth=0,this._store={},this._dirtyDepCount=0,this._pauseLocks=null,this._pauseBuffer=null,this._fn!=null&&(this._cached=void 0),e||(this._fn!=null||this._deps.length>0)&&(!this._isTerminal||this._resubscribable)&&(this._status="sentinel")}_onDepMessage(e,n){let r=this._deps[e],s=n[0];if(this._inspectorHooks!=null){let o={kind:"dep_message",depIndex:e,message:n};for(let i of this._inspectorHooks)i(o)}if(s!==ge){if(s===K){this._depDirtied(r);return}if(s===Q){if(this._depInvalidated(r),this._cached===void 0)return;this._emit(pt);return}if(s===te||s===oe){this._emit([n]);return}if(s===F){this._emit(Le);return}if(s===G)this._depSettledAsData(r,n[1]);else if(s===q)this._depSettledAsResolved(r);else if(s===z)this._depSettledAsTerminal(r,!0);else if(s===I)this._depSettledAsTerminal(r,n[1]);else{this._emit([n]);return}if(!this._fn){(s===G||s===q)&&this._emit([n]),(s===z||s===I)&&this._maybeAutoTerminalAfterWave();return}}}_depDirtied(e){e.dirty||(e.dirty=!0,e.involvedThisWave=!0,this._dirtyDepCount++,this._status!=="dirty"&&this._emit(Me))}_depSettledAsData(e,n){e.dirty&&(e.dirty=!1,this._dirtyDepCount--),e.involvedThisWave=!0,e.dataBatch.push(n),this._waveHasNewData=!0}_depSettledAsResolved(e){e.dirty&&(e.dirty=!1,this._dirtyDepCount--)}_depSettledAsTerminal(e,n){e.dirty&&(e.dirty=!1,this._dirtyDepCount--),e.terminal=n,e.involvedThisWave=!0,this._hasNewTerminal=!0}_depInvalidated(e){e.prevData=void 0,e.terminal=void 0,e.dataBatch.length=0,e.dirty?e.involvedThisWave=!1:(e.dirty=!0,e.involvedThisWave=!0,this._dirtyDepCount++)}_maybeRunFnOnSettlement(){if(!(this._isTerminal&&!this._resubscribable)&&!(this._dirtyDepCount>0)){if(!this._partial&&!this._hasCalledFnOnce)for(let e=0;e<this._deps.length;e++){let n=this._deps[e];if(n.dataBatch.length===0&&n.prevData===void 0&&n.terminal===void 0){this._maybeAutoTerminalAfterWave();return}}if(this._paused){this._pendingWave=!0;return}if(!this._waveHasNewData&&!this._hasNewTerminal&&this._hasCalledFnOnce){this._clearWaveFlags(),this._emit(ft),this._maybeAutoTerminalAfterWave();return}this._fn&&this._execFn(),this._maybeAutoTerminalAfterWave()}}_maybeAutoTerminalAfterWave(){if(this._deps.length===0||this._isTerminal)return;let e=this._deps.find(n=>n.terminal!==void 0&&n.terminal!==!0);if(e!=null){this._autoError&&this._emit([[I,e.terminal]]);return}this._autoComplete&&this._deps.every(n=>n.terminal!==void 0)&&this._emit(ht)}_execFn(){if(!this._fn||this._isTerminal&&!this._resubscribable)return;if(this._isExecutingFn){this._pendingRerun=!0;return}let e=this._cleanup;if(typeof e=="function"){this._cleanup=void 0;try{e()}catch(i){this._emit([[I,this._wrapFnError("cleanup threw",i)]]);return}}else if(e!=null&&typeof e=="object"){let i=e.beforeRun;if(typeof i=="function"){e.beforeRun=void 0;try{i()}catch(a){this._emit([[I,this._wrapFnError("cleanup.beforeRun threw",a)]]);return}}}let n=this._deps.map(i=>i.involvedThisWave?i.dataBatch.length>0?[...i.dataBatch]:[]:void 0),r=this._deps.map(i=>i.prevData);for(let i=0;i<this._deps.length;i++){let a=n[i];a!=null&&a.length>0&&(this._deps[i].prevData=a[a.length-1])}let s=this._deps.map(i=>i.terminal),o={prevData:r,terminalDeps:s,store:this._store};if(this._hasCalledFnOnce=!0,this._clearWaveFlags(),this._inspectorHooks!=null){let i={kind:"run",batchData:n,prevData:r};for(let a of this._inspectorHooks)a(i)}this._isExecutingFn=!0;try{let i=this._fn(n,this._actions,o);if(typeof i=="function")this._cleanup=i;else if(i!=null&&typeof i=="object"){let a=i;(typeof a.beforeRun=="function"||typeof a.deactivate=="function"||typeof a.invalidate=="function")&&(this._cleanup=i)}}catch(i){this._emit([[I,this._wrapFnError("fn threw",i)]])}finally{this._isExecutingFn=!1,this._pendingRerun?(this._pendingRerun=!1,this._rerunDepth+=1,this._rerunDepth>Yt?(this._rerunDepth=0,this._emit([[I,new Error(`Node "${this.name}": _pendingRerun depth exceeded ${Yt} \u2014 likely a reactive cycle`)]])):this._maybeRunFnOnSettlement()):this._rerunDepth=0,this._clearWaveFlags()}}_clearWaveFlags(){this._waveHasNewData=!1,this._hasNewTerminal=!1;for(let e of this._deps)e.involvedThisWave=!1,e.dataBatch.length=0}_wrapFnError(e,n){let r=n instanceof Error?n.message:String(n);return new Error(`Node "${this.name}": ${e}: ${r}`,{cause:n})}_frameBatch(e){let n=this._config.tierOf;if(e.length===1)return n(e[0][0])===3&&this._status!=="dirty"?[de,e[0]]:e;let r=!0,s=!1,o=!1,i=-1;for(let d of e){let u=n(d[0]);u<i&&(r=!1),u===3&&(s=!0),d[0]===K&&(o=!0),i=u}let a=e;if(!r){let d=e.map((u,c)=>({m:u,i:c,tier:n(u[0])}));d.sort((u,c)=>u.tier-c.tier||u.i-c.i),a=d.map(u=>u.m)}if(s&&!o&&this._status!=="dirty"){let d=0;for(;d<a.length&&n(a[d][0])===0;)d++;return d===0?[de,...a]:[...a.slice(0,d),de,...a.slice(d)]}return a}_emit(e){if(e.length===0)return;for(let a=0;a<e.length;a++){let d=e[a];if(d[0]===I&&d[1]===void 0)throw new TypeError('[ERROR, payload] requires a non-undefined payload (spec \xA71.2). Pass an Error object or domain tag instead \u2014 e.g. node.down([[ERROR, new Error("reason")]])')}let n=e;if(this._isTerminal&&!this._resubscribable){let a=e.filter(d=>d[0]===F||d[0]===Q);if(a.length===0)return;n=a}n=this._frameBatch(n);let s=null;for(let a=0;a<n.length;a++){let d=n[a],u=d[0];if(u!==te&&u!==oe){s?.push(d);continue}if(d.length<2)throw new Error(`Node "${this.name}": [[${u===te?"PAUSE":"RESUME"}]] must carry a lockId payload \u2014 bare PAUSE/RESUME is a protocol violation (C0 rule). Use \`[[PAUSE, lockId]]\` / \`[[RESUME, lockId]]\`.`);let c=!0;if(this._pausable!==!1){let f=d[1];if(u===te)this._pauseLocks==null&&(this._pauseLocks=new Set),this._pauseLocks.add(f),this._paused=!0,this._pausable==="resumeAll"&&this._pauseBuffer==null&&(this._pauseBuffer=[]);else if(this._pauseLocks==null||!this._pauseLocks.has(f))c=!1;else if(this._pauseLocks.delete(f),this._pauseLocks.size===0){if(this._paused=!1,this._pauseBuffer!=null&&this._pauseBuffer.length>0){let p=this._pauseBuffer;this._pauseBuffer=[],this._emit(p)}this._pendingWave&&(this._pendingWave=!1,this._maybeRunFnOnSettlement())}}c?s?.push(d):s==null&&(s=n.slice(0,a))}if(s!=null){if(s.length===0)return;n=s}if(this._hasMeta&&n.some(a=>a[0]===F))for(let a of Object.keys(this.meta))try{this.meta[a]._emit(Le)}catch{}let{finalMessages:o,equalsError:i}=this._updateState(n);if(o.length>0&&this._config.inspectorEnabled){let a=this._config.globalInspector;if(a!=null)try{a({kind:"emit",node:this,messages:o})}catch{}}if(o.length>0)if(this._paused&&this._pausable==="resumeAll"&&this._pauseBuffer!=null){let a=this._config.tierOf,d=[];for(let u of o)a(u[0])===3?this._pauseBuffer.push(u):d.push(u);d.length>0&&this._dispatchOrAccumulate(d)}else this._dispatchOrAccumulate(o);i!=null&&this._emit([[I,i]])}_updateState(e){let n=this._config.tierOf,r,s,o=-1,i=0;for(let c of e)n(c[0])===3&&i++;let a=i<=1,d=-1;if(this._versioning!=null&&i>1){for(let c=e.length-1;c>=0;c--)if(e[c][0]===G){d=c;break}}for(let c=0;c<e.length;c++){let f=e[c],p=f[0];if(p===G){if(f.length>=2){let h=!1;if(a&&this._cached!==void 0)try{h=this._equals(this._cached,f[1])}catch(l){s=this._wrapFnError("equals threw",l),o=c;break}if(h){r==null&&(r=e.slice(0,c)),r.push(Ce),this._status="resolved";continue}this._cached=f[1],this._versioning!=null&&(d<0||c===d)&&Kt(this._versioning,f[1],this._hashFn)}this._status="settled",r?.push(f)}else if(r?.push(f),p===K)this._status="dirty";else if(p===q)this._status="resolved";else if(p===z){this._status="completed";{let h=this._config.rigorRecorder;if(h!=null)try{h.onTerminalTransition(this,"completed",this._autoComplete,this._autoError,this._deps.length>0)}catch{}}}else if(p===I){this._status="errored";{let h=this._config.rigorRecorder;if(h!=null)try{h.onTerminalTransition(this,"errored",this._autoComplete,this._autoError,this._deps.length>0)}catch{}}}else if(p===Q){if(this._cached!==void 0){let l=this._config.rigorRecorder;if(l!=null)try{l.onNonVacuousInvalidate(this,this._cached)}catch{}}this._cached=void 0,this._status="dirty";let h=this._cleanup;if(typeof h=="function"){this._cleanup=void 0;try{h()}catch{}}else if(h!=null&&typeof h=="object"){let l=h.invalidate;if(typeof l=="function")try{l()}catch{}}}else p===F&&(this._resetOnTeardown&&(this._cached=void 0),this._deactivate(!0),this._status="sentinel")}let u=o>=0?r??e.slice(0,o):r??e;return s!=null?{finalMessages:u,equalsError:s}:{finalMessages:u}}_deliverToSinks=e=>{if(this._sinks==null)return;if(typeof this._sinks=="function"){this._sinks(e);return}let n=[...this._sinks];for(let r of n)r(e)};_dispatchOrAccumulate(e){if(Bt()){this._batchPendingMessages===null&&(this._batchPendingMessages=[],ve(()=>this._flushBatchPending()));for(let n of e)this._batchPendingMessages.push(n);return}Fe(this._deliverToSinks,e,this._config.tierOf)}_flushBatchPending(){let e=this._batchPendingMessages;if(e===null||(this._batchPendingMessages=null,e.length===0))return;let n=this._frameBatch(e);Fe(this._deliverToSinks,n,this._config.tierOf)}},Xt=t=>Array.isArray(t),wt=t=>typeof t=="object"&&t!=null&&!Array.isArray(t)});function ne(t,e){return we([],{...e,initial:t})}function je(t,e){return we((r,s,o)=>t(s,o)??void 0,{describeKind:"producer",...e})}function j(t,e,n){return we(t,(s,o,i)=>{let a=s.map((d,u)=>d!=null&&d.length>0?d.at(-1):i.prevData[u]);o.emit(e(a,i))},{describeKind:"derived",...n})}var Se=W(()=>{"use strict";fe()});function re(t){return t.subscribe(()=>{})}var xt=W(()=>{"use strict"});function qe(t,e){if(e!=null&&e.length>0)return new Set(e);switch(t){case"standard":return new Set(["type","status","value","deps","meta","v"]);case"full":return null;case"spec":return new Set(["type","deps","meta"]);default:return new Set(["type","deps"])}}function nr(t){return t._describeKind!=null?t._describeKind:t._deps.length>0?"derived":t._fn!=null?"producer":"state"}function rr(t){let e={};for(let[n,r]of Object.entries(t.meta))try{e[n]=r.cache}catch{}return e}function Ot(t,e){let n=e==null,r=!n&&e!=null?[...e].filter(u=>u.startsWith("meta.")).map(u=>u.slice(5)):null,s=n||e.has("meta")||r!=null&&r.length>0,o="state",i=[];t instanceof P&&(o=nr(t),i=t._deps.map(u=>u.node.name??""));let a={type:o,deps:i};(n||e.has("status"))&&(a.status=t.status);let d=t instanceof P?t._guard:void 0;if(s){let u={...rr(t)};if(d!=null&&u.access===void 0&&(u.access=lt(d)),r!=null&&r.length>0&&!e.has("meta")){let c={};for(let f of r)f in u&&(c[f]=u[f]);a.meta=c}else a.meta=u}if(t.name!=null&&(a.name=t.name),n||e.has("value")){t.status==="sentinel"&&(a.sentinel=!0);try{a.value=t.cache}catch{}}if((n||e.has("v"))&&t.v!=null){let u={id:t.v.id,version:t.v.version};"cid"in t.v&&(u.cid=t.v.cid,u.prev=t.v.prev),a.v=u}return(n||e.has("guard"))&&d!=null&&(a.guard=lt(d)),(n||e.has("lastMutation"))&&t.lastMutation!=null&&(a.lastMutation=t.lastMutation),a}var rn=W(()=>{"use strict";he();fe()});var Ye,sn=W(()=>{"use strict";Ye=class{_timer;_gen=0;start(e,n){this.cancel(),this._gen+=1;let r=this._gen;this._timer=setTimeout(()=>{this._timer=void 0,r===this._gen&&n()},e)}cancel(){this._timer!==void 0&&(clearTimeout(this._timer),this._timer=void 0)}get pending(){return this._timer!==void 0}}});var to={};Ln(to,{AuditTrailGraph:()=>rt,PolicyEnforcerGraph:()=>ot,auditTrail:()=>Kr,complianceSnapshot:()=>Jr,policyEnforcer:()=>qr,reactiveExplainPath:()=>Yr});module.exports=Pn(to);Te();he();ie();fe();Se();vt();Ve();ie();fe();Se();var Tt=class{_version=0;_maxSize;_buf;_head=0;_size=0;constructor(e,n){if(n!==void 0&&n<1)throw new RangeError("maxSize must be >= 1");if(this._maxSize=n,n!==void 0){if(this._buf=new Array(n),e&&e.length>0){let r=Math.min(e.length,n),s=e.length-r;for(let o=0;o<r;o++)this._buf[o]=e[s+o];this._size=r}}else this._buf=e?[...e]:[],this._size=this._buf.length}get version(){return this._version}get size(){return this._size}at(e){if(!Number.isInteger(e))return;let n=e>=0?e:this._size+e;if(!(n<0||n>=this._size))return this._maxSize!==void 0?this._buf[(this._head+n)%this._maxSize]:this._buf[n]}append(e){this._rawAppend(e),this._version+=1}appendMany(e){if(e.length===0)return;let n=this._maxSize!==void 0&&e.length>this._maxSize?e.length-this._maxSize:0;for(let r=n;r<e.length;r++)this._rawAppend(e[r]);this._version+=1}clear(){if(this._size===0)return 0;let e=this._size;if(this._maxSize===void 0)this._buf.length=0;else for(let n=0;n<e;n++)this._buf[(this._head+n)%this._maxSize]=void 0;return this._head=0,this._size=0,this._version+=1,e}trimHead(e){if(!Number.isInteger(e)||e<0)throw new RangeError(`trimHead: n must be a non-negative integer (got ${e})`);if(e===0||this._size===0)return 0;let n=Math.min(e,this._size);if(this._maxSize===void 0)this._buf.splice(0,n);else{for(let r=0;r<n;r++)this._buf[(this._head+r)%this._maxSize]=void 0;this._head=(this._head+n)%this._maxSize}return this._size-=n,this._version+=1,n}slice(e,n){if(!Number.isInteger(e)||e<0)throw new RangeError(`slice: start must be a non-negative integer (got ${e})`);if(n!==void 0&&(!Number.isInteger(n)||n<0))throw new RangeError(`slice: stop must be a non-negative integer or undefined (got ${n})`);let r=n===void 0?this._size:Math.min(Math.max(n,0),this._size),s=Math.min(e,this._size);if(s>=r)return[];let o=r-s;if(this._maxSize===void 0)return this._buf.slice(s,r);let i=new Array(o);for(let a=0;a<o;a++)i[a]=this._buf[(this._head+s+a)%this._maxSize];return i}tail(e){if(!Number.isInteger(e)||e<0)throw new RangeError(`tail: n must be a non-negative integer (got ${e})`);if(e===0||this._size===0)return[];let n=Math.min(e,this._size);return this.slice(this._size-n,this._size)}toArray(){if(this._maxSize===void 0)return[...this._buf];let e=new Array(this._size);for(let n=0;n<this._size;n++)e[n]=this._buf[(this._head+n)%this._maxSize];return e}snapshot(){return this.toArray()}restore(e){if(this._maxSize===void 0){this._buf.length=0;for(let n=0;n<e.length;n++)this._buf.push(e[n]);this._size=this._buf.length}else{let n=this._maxSize;for(let o=0;o<n;o++)this._buf[o]=void 0;this._head=0;let r=Math.min(e.length,n),s=e.length-r;for(let o=0;o<r;o++)this._buf[o]=e[s+o];this._size=r}this._version+=1}_rawAppend(e){if(this._maxSize===void 0){this._buf.push(e),this._size=this._buf.length;return}this._size<this._maxSize?(this._buf[(this._head+this._size)%this._maxSize]=e,this._size+=1):(this._buf[this._head]=e,this._head=(this._head+1)%this._maxSize)}};function Ae(t){return t.subscribe(()=>{})}var Yn=64;function Be(t,e={}){let{name:n,maxSize:r,versioning:s,guard:o,backend:i}=e,a=i??new Tt(t,r),d=ne(a.toArray(),{name:n,describeKind:"state",equals:(g,b)=>g===b,...s!=null?{versioning:s}:{},...o!=null?{guard:o}:{}});function u(){let g=a.toArray();ke(()=>{d.down([[K]],{internal:!0}),d.down([[G,g]],{internal:!0})})}let c=new Map,f=new Map,p=new Map;function h(g,b){return`${g}:${b===void 0?"END":b}`}function l(g){if(g.size<Yn)return;let b=g.keys().next();if(b.done)return;let O=g.get(b.value);O!==void 0&&O.dispose(),g.delete(b.value)}function y(g){let b=a.version;try{return g()}finally{a.version!==b&&u()}}function m(g){if(!Number.isInteger(g)||g<0)throw new RangeError(`tail: n must be a non-negative integer (got ${g})`);let b=c.get(g);if(b!==void 0)return c.delete(g),c.set(g,b),b.node;l(c);let O=j([d],([k])=>{let R=k;return g===0||R.length===0?[]:R.slice(Math.max(0,R.length-g))},{initial:a.tail(g),describeKind:"derived"}),A=Ae(O);return c.set(g,{node:O,dispose:A}),O}function w(g,b){if(!Number.isInteger(g)||g<0)throw new RangeError(`slice: start must be a non-negative integer (got ${g})`);if(b!==void 0&&(!Number.isInteger(b)||b<0))throw new RangeError(`slice: stop must be a non-negative integer or undefined (got ${b})`);let O=h(g,b),A=f.get(O);if(A!==void 0)return f.delete(O),f.set(O,A),A.node;l(f);let k=j([d],([N])=>{let D=N;return b===void 0?D.slice(g):D.slice(g,b)},{initial:a.slice(g,b),describeKind:"derived"}),R=Ae(k);return f.set(O,{node:k,dispose:R}),k}function _(g){let b=p.get(g);if(b!==void 0)return b.node;let O=j([d,g],([k,R])=>{let N=k,D=Math.max(0,Math.trunc(R??0));return N.slice(D)},{initial:[],describeKind:"derived"}),A=Ae(O);return p.set(g,{node:O,dispose:A}),O}let v,x;function E(){v===void 0&&(v=we([d],(g,b,O)=>{let A=g[0],R=A!=null&&A.length>0?A.at(-1):O.prevData[0];if(R==null||R.length===0){b.down([[q]]);return}b.emit(R[R.length-1])},{name:n!=null?`${n}::lastValue`:"lastValue",describeKind:"derived",initial:a.size===0?void 0:a.at(a.size-1)}),x=j([d],([g])=>g.length>0,{name:n!=null?`${n}::hasLatest`:"hasLatest",describeKind:"derived",initial:a.size>0}),Ae(v),Ae(x))}let T={entries:d,get size(){return a.size},at(g){return a.at(g)},append(g){y(()=>a.append(g))},appendMany(g){g.length!==0&&y(()=>a.appendMany(g))},clear(){y(()=>a.clear())},trimHead(g){y(()=>a.trimHead(g))},withLatest(){return E(),d},get lastValue(){return E(),v},get hasLatest(){return E(),x},view(g){switch(g.kind){case"tail":return m(g.n);case"slice":return w(g.start,g.stop);case"fromCursor":return _(g.cursor)}},attach(g){let b=g.subscribe(O=>{for(let A of O)A[0]===G&&T.append(A[1])});return()=>b()},attachStorage(g){if(g.length===0)return()=>{};let b=new Map;for(let A of g)b.set(A,a.size);(async()=>{for(let A of g)if(typeof A.loadEntries=="function")try{let k=await Promise.resolve(A.loadEntries());k.entries.length>0&&a.size===0&&(a.restore(k.entries),b.set(A,k.entries.length),u());break}catch{}})();let O=d.subscribe(A=>{for(let k of A){if(k[0]!==G)continue;let R=k[1];for(let N of g){let D=b.get(N)??0;if(R.length<D){try{let V=N.appendEntries(R);V instanceof Promise&&V.catch(()=>{})}catch{}b.set(N,R.length);continue}if(R.length===D)continue;let H=R.slice(D);b.set(N,R.length);try{let V=N.appendEntries(H);V instanceof Promise&&V.catch(()=>{})}catch{}}}});return()=>O()},disposeAllViews(){for(let g of c.values())g.dispose();c.clear();for(let g of f.values())g.dispose();f.clear();for(let g of p.values())g.dispose();p.clear()},dispose(){for(let g of c.values())g.dispose();c.clear();for(let g of f.values())g.dispose();f.clear();for(let g of p.values())g.dispose();p.clear()}};return T}var $={object:56,array:64,string:40,number:8,boolean:4,null:0,undefined:0,symbol:40,bigint:16,function:120,map:72,set:72,mapEntry:40,setEntry:24,date:24,regexp:48,error:64,url:80,promise:48,weakmap:40,weakset:40},Jn=Symbol.for("sizeof");function Zt(t){let e=new WeakSet,n=new WeakSet,r=[t],s=0;for(;r.length>0;){let o=r.pop();s+=Xn(o,e,n,r)}return s}function Xn(t,e,n,r){if(t==null)return 0;switch(typeof t){case"number":return $.number;case"boolean":return $.boolean;case"string":return $.string+t.length*2;case"bigint":return $.bigint+Zn(t);case"symbol":return $.symbol;case"function":return e.has(t)?0:(e.add(t),$.function);case"undefined":return 0}let o=t;if(e.has(o))return 0;e.add(o);let i=o[Jn];if(typeof i=="function")try{let u=i.call(o);if(typeof u=="number"&&Number.isFinite(u))return u}catch{}if(o instanceof Date)return $.date;if(o instanceof RegExp)return $.regexp+o.source.length*2;if(o instanceof Error){let u=o.message?o.message.length*2:0,c=o.stack?o.stack.length*2:0;return $.error+u+c}if(typeof URL<"u"&&o instanceof URL)return $.url+o.href.length*2;if(typeof Promise<"u"&&o instanceof Promise)return $.promise;if(o instanceof WeakMap)return $.weakmap;if(o instanceof WeakSet)return $.weakset;if(o instanceof Map){let u=$.map;for(let[c,f]of o)u+=$.mapEntry,r.push(c),r.push(f);return u}if(o instanceof Set){let u=$.set;for(let c of o)u+=$.setEntry,r.push(c);return u}if(Array.isArray(o)){let u=$.array+o.length*8;for(let c of o)r.push(c);return u}if(o instanceof ArrayBuffer)return n.has(o)?0:(n.add(o),o.byteLength);if(ArrayBuffer.isView(o)){let u=o;return n.has(u.buffer)?48:(n.add(u.buffer),u.buffer.byteLength+48)}let a=$.object,d=Object.keys(o);for(let u of d){a+=$.string+u.length*2;try{r.push(o[u])}catch{}}return a}function Zn(t){let e=t<0n?-t:t;if(e===0n)return 0;let n=e.toString(2).length;return Math.ceil(n/32)*8}function Qt(t,e,n,r={}){let s=e in t.nodes,o=n in t.nodes;if(!s)return We(e,n,"no-such-from");if(!o)return We(e,n,"no-such-to");let i=r.maxDepth;if(i!=null&&(!Number.isInteger(i)||i<0))throw new Error("explainPath: maxDepth must be an integer >= 0");if(e===n){if(r.findCycle===!0){let u=Qn(t,e,r);if(u!=null)return u}let d=Ue(e,t.nodes[e],0,r);return Ke(e,n,[d])}if(i===0)return We(e,n,"no-path");let a=en(t,e,n,i);return a.found?Ke(e,n,tn(t,a.pathOrder,r)):We(e,n,a.truncated?"max-depth-exceeded":"no-path")}function en(t,e,n,r){let s=new Map,o=[{path:n,depth:0}],i=new Set([n]),a=0,d=!1;for(;a<o.length;){let f=o[a++];if(f.path===e)break;if(r!=null&&f.depth>=r){let y=t.nodes[f.path];y?.deps&&y.deps.length>0&&(d=!0);continue}let p=t.nodes[f.path];if(p==null)continue;let h=p.deps??[],l=new Map;for(let y=0;y<h.length;y++){let m=h[y];if(!m)continue;let w=l.get(m);w==null&&(w=[],l.set(m,w)),w.push(y)}for(let[y,m]of l)i.has(y)||(i.add(y),s.set(y,{from:f.path,depIndices:m}),o.push({path:y,depth:f.depth+1}))}if(!s.has(e))return{found:!1,pathOrder:[],truncated:d};let u=[{path:e}],c=e;for(;c!==n;){let f=s.get(c);if(f==null)return{found:!1,pathOrder:[],truncated:!1};u[u.length-1].depIndices=f.depIndices,u.push({path:f.from}),c=f.from}return{found:!0,pathOrder:u,truncated:!1}}function Qn(t,e,n){let r=t.nodes[e];if(r==null)return null;let s=r.deps??[],o=[];for(let a=0;a<s.length;a++)s[a]===e&&o.push(a);if(o.length>0){let a=Ue(e,r,0,n);a.dep_index=o[0];let d=Ue(e,r,1,n);return Ke(e,e,[a,d])}let i=null;for(let a=0;a<s.length;a++){let d=s[a];if(!d||d===e)continue;let u=en(t,d,e,n.maxDepth);u.found&&(i==null||u.pathOrder.length<i.pathOrder.length)&&(i=u,i={found:!0,pathOrder:[{path:e,depIndices:[a]},...u.pathOrder],truncated:!1})}return i==null?null:Ke(e,e,tn(t,i.pathOrder,n))}function tn(t,e,n){return e.map((r,s)=>{let o=t.nodes[r.path],i=Ue(r.path,o,s,n);return r.depIndices!=null&&r.depIndices.length>0&&(i.dep_index=r.depIndices[0],r.depIndices.length>1&&(i.dep_indices=[...r.depIndices])),i})}function Ue(t,e,n,r){let s={path:t,type:e.type,hop:n};e.status!==void 0&&(s.status=e.status),"value"in e&&(s.value=e.value),e.v!=null&&(s.v=e.v);let o=r.annotations?.get(t)??e.annotation;o!=null&&(s.annotation=o);let i=r.lastMutations?.get(t)??e.lastMutation;return i!=null&&(s.lastMutation=i),s}function Ke(t,e,n){return nn(t,e,!0,"ok",n)}function We(t,e,n){return nn(t,e,!1,n,[])}function nn(t,e,n,r,s){let o=er(t,e,n,r,s);return{from:t,to:e,found:n,reason:r,steps:s,text:o,toJSON(){return{from:t,to:e,found:n,reason:r,steps:s}}}}function er(t,e,n,r,s){if(!n)switch(r){case"no-such-from":return`explainPath: no node named "${t}"`;case"no-such-to":return`explainPath: no node named "${e}"`;case"max-depth-exceeded":return`explainPath: no path from "${t}" to "${e}" within maxDepth`;default:return`explainPath: no path from "${t}" to "${e}"`}let o=[`Causal path: ${t} \u2192 ${e} (${s.length} step(s))`];for(let i of s){let d=` ${i.hop===0?"\xB7":"\u2193"} ${i.path} (${i.type}${i.status?`/${i.status}`:""})`;if(o.push(d),"value"in i&&o.push(` value: ${tr(i.value)}`),i.annotation!=null&&o.push(` annotation: ${i.annotation}`),i.lastMutation!=null){let u=i.lastMutation.actor;o.push(` actor: ${u.type}${u.id?`:${u.id}`:""}`)}}return o.join(`
2
- `)}function tr(t){if(t===void 0)return"<sentinel>";if(t===null)return"null";if(typeof t=="string")return JSON.stringify(t);if(typeof t=="number"||typeof t=="boolean"||typeof t=="bigint")return String(t);try{let e=JSON.stringify(t);return e.length>80?`${e.slice(0,77)}...`:e}catch{return String(t)}}Pe();Ve();Te();he();ie();rn();fe();Se();Te();function Et(t,e){if(Object.is(t,e))return!0;if(t==null||e==null||typeof t!="object"||typeof e!="object")return!1;if(Array.isArray(t)){if(!Array.isArray(e)||t.length!==e.length)return!1;for(let o=0;o<t.length;o++)if(!Et(t[o],e[o]))return!1;return!0}if(Array.isArray(e))return!1;let n=Object.keys(t),r=Object.keys(e);if(n.length!==r.length)return!1;let s=new Set(r);for(let o of n)if(!s.has(o)||!Et(t[o],e[o]))return!1;return!0}function on(t,e){return`${t}\0${e}`}function kt(t,e){let n=[],r=new Set(t.subgraphs),s=new Set(e.subgraphs),o=[];for(let m of s)r.has(m)||o.push(m);o.sort();for(let m of o)n.push({type:"subgraph-mounted",path:m});let i=new Set(Object.keys(t.nodes)),a=new Set(Object.keys(e.nodes)),d=[];for(let m of a)i.has(m)||d.push(m);d.sort();for(let m of d)n.push({type:"node-added",path:m,node:{...e.nodes[m]}});let u=[];for(let m of a){if(!i.has(m))continue;let w=t.nodes[m]?.meta,_=e.nodes[m]?.meta;w==null&&_==null||Et(w??{},_??{})||u.push(m)}u.sort();for(let m of u)n.push({type:"node-meta-changed",path:m,prevMeta:t.nodes[m]?.meta??{},nextMeta:e.nodes[m]?.meta??{}});let c=new Map;for(let m of t.edges)c.set(on(m.from,m.to),m);let f=new Map;for(let m of e.edges)f.set(on(m.from,m.to),m);let p=[];for(let[m,w]of f)c.has(m)||p.push(w);p.sort((m,w)=>m.from<w.from?-1:m.from>w.from?1:m.to<w.to?-1:m.to>w.to?1:0);for(let m of p)n.push({type:"edge-added",from:m.from,to:m.to});let h=[];for(let[m,w]of c)f.has(m)||h.push(w);h.sort((m,w)=>m.from<w.from?-1:m.from>w.from?1:m.to<w.to?-1:m.to>w.to?1:0);for(let m of h)n.push({type:"edge-removed",from:m.from,to:m.to});let l=[];for(let m of i)a.has(m)||l.push(m);l.sort();for(let m of l)n.push({type:"node-removed",path:m});let y=[];for(let m of r)s.has(m)||y.push(m);y.sort();for(let m of y)n.push({type:"subgraph-unmounted",path:m});return{events:n,flushedAt_ns:U()}}xt();sn();var Re=class{constructor(e){this.capacity=e;if(!Number.isInteger(e)||e<=0)throw new Error(`RingBuffer capacity must be a positive integer (got ${e})`);this.buf=new Array(e)}buf;head=0;_size=0;get size(){return this._size}get maxSize(){return this.capacity}push(e){let n=(this.head+this._size)%this.capacity;this.buf[n]=e,this._size<this.capacity?this._size++:this.head=(this.head+1)%this.capacity}shift(){if(this._size===0)return;let e=this.buf[this.head];return this.buf[this.head]=void 0,this.head=(this.head+1)%this.capacity,this._size--,e}at(e){if(this._size===0)return;let n=e<0?this._size+e:e;if(!(n<0||n>=this._size))return this.buf[(this.head+n)%this.capacity]}toArray(){let e=new Array(this._size);for(let n=0;n<this._size;n++)e[n]=this.buf[(this.head+n)%this.capacity];return e}clear(){for(let e=0;e<this._size;e++)this.buf[(this.head+e)%this.capacity]=void 0;this.head=0,this._size=0}};mt();function Nt(t){return t>=768&&t<=879||t>=1155&&t<=1161||t>=1425&&t<=1469||t>=1552&&t<=1562||t>=1611&&t<=1631||t>=1648&&t===1648||t>=1750&&t<=1756||t>=1759&&t<=1764||t>=1767&&t<=1768||t>=1770&&t<=1773||t>=1840&&t<=1866||t>=1958&&t<=1968||t>=2304&&t<=2307||t>=2362&&t<=2383||t>=2385&&t<=2391||t>=2402&&t<=2403||t>=2433&&t<=2435||t>=2492&&t<=2509||t>=2561&&t<=2563||t>=2620&&t<=2641||t>=2672&&t<=2673||t>=2677&&t===2677||t>=3633&&t===3633||t>=3636&&t<=3642||t>=3655&&t<=3662||t>=3761&&t===3761||t>=3764&&t<=3772||t>=3784&&t<=3790||t>=7616&&t<=7679||t>=8400&&t<=8447||t>=65024&&t<=65039||t>=65056&&t<=65071||t===8205?0:t>=4352&&t<=4447||t>=8986&&t<=8987||t>=9001&&t<=9002||t>=9193&&t<=9203||t>=9208&&t<=9210||t>=9725&&t<=9726||t>=9748&&t<=9749||t>=9800&&t<=9811||t===9855||t===9875||t===9889||t>=9898&&t<=9899||t>=9917&&t<=9918||t>=9924&&t<=9925||t===9934||t===9940||t===9962||t>=9970&&t<=9971||t===9973||t===9978||t===9981||t===9986||t===9989||t>=9992&&t<=9997||t===9999||t>=10067&&t<=10069||t===10071||t>=10133&&t<=10135||t===10160||t===10175||t>=10548&&t<=10549||t>=11013&&t<=11015||t>=11035&&t<=11036||t===11088||t===11093||t>=11904&&t<=12350||t>=12352&&t<=12447||t>=12448&&t<=12543||t>=12549&&t<=12591||t>=12593&&t<=12686||t>=12688&&t<=12771||t>=12784&&t<=12830||t>=12832&&t<=12871||t>=12880&&t<=19903||t>=19968&&t<=40959||t>=43360&&t<=43388||t>=44032&&t<=55203||t>=63744&&t<=64255||t>=65040&&t<=65049||t>=65072&&t<=65131||t>=65281&&t<=65376||t>=65504&&t<=65510||t>=126980&&t===126980||t===127183||t>=127344&&t<=127345||t===127358||t===127359||t===127374||t>=127377&&t<=127386||t>=127456&&t<=127487||t>=127488&&t<=127490||t===127514||t===127535||t>=127538&&t<=127546||t>=127568&&t<=127569||t>=127744&&t<=129535||t>=129536&&t<=129791||t>=129792&&t<=130047||t>=131072&&t<=196605||t>=196608&&t<=262141?2:1}function Je(t){let e=0;for(let n of t)e+=Nt(n.codePointAt(0));return e}function an(t,e){if(e<=0)return"";let n=0,r="";for(let s of t){let o=Nt(s.codePointAt(0));if(n+o>e){if(e<=1)return"\u2026";for(;n+1>e&&r.length>0;){let i=[...r].pop();r=r.slice(0,-i.length),n-=Nt(i.codePointAt(0))}return`${r}\u2026`}r+=s,n+=o}return r}var or={horizontal:"\u2500",vertical:"\u2502",cornerTL:"\u250C",cornerTR:"\u2510",cornerBL:"\u2514",cornerBR:"\u2518",tDown:"\u252C",tUp:"\u2534",tRight:"\u251C",tLeft:"\u2524",cross:"\u253C",arrowRight:"\u25B6",arrowDown:"\u25BC",arrowLeft:"\u25C0",arrowUp:"\u25B2",boxTL:"\u250C",boxTR:"\u2510",boxBL:"\u2514",boxBR:"\u2518",boxH:"\u2500",boxV:"\u2502"},sr={horizontal:"-",vertical:"|",cornerTL:"+",cornerTR:"+",cornerBL:"+",cornerBR:"+",tDown:"+",tUp:"+",tRight:"+",tLeft:"+",cross:"+",arrowRight:">",arrowDown:"v",arrowLeft:"<",arrowUp:"^",boxTL:"+",boxTR:"+",boxBL:"+",boxBR:"+",boxH:"-",boxV:"|"};function ln(t,e){let n=e.charset==="ascii"?sr:or,r=t.width,s=t.height,o=Array.from({length:s},()=>Array.from({length:r},()=>" ")),i=Array.from({length:s},()=>Array.from({length:r},()=>"empty"));for(let a of t.edges)ar(o,i,n,a);for(let a of t.boxes)ir(o,i,n,a,e.labelOf(a.id));return o.map(a=>lr(a.join(""))).join(`
3
- `)}function ir(t,e,n,r,s){let{x:o,y:i,w:a,h:d}=r;if(a<2||d<2){d>0&&un(t,e,o,i,a,s);return}ae(t,e,o,i,n.boxTL);for(let c=o+1;c<o+a-1;c+=1)ae(t,e,c,i,n.boxH);ae(t,e,o+a-1,i,n.boxTR);for(let c=i+1;c<i+d-1;c+=1){ae(t,e,o,c,n.boxV);for(let f=o+1;f<o+a-1;f+=1)fn(t,e,f,c," ","empty");ae(t,e,o+a-1,c,n.boxV)}ae(t,e,o,i+d-1,n.boxBL);for(let c=o+1;c<o+a-1;c+=1)ae(t,e,c,i+d-1,n.boxH);ae(t,e,o+a-1,i+d-1,n.boxBR);let u=i+Math.floor(d/2);un(t,e,o+1,u,a-2,s)}function ae(t,e,n,r,s){fn(t,e,n,r,s,s===" "?"empty":s==="\u2500"||s==="-"?"boxH":s==="\u2502"||s==="|"?"boxV":"boxCorner")}function fn(t,e,n,r,s,o){if(r<0||r>=t.length)return;let i=t[r];n<0||n>=i.length||(i[n]=s,e[r][n]=o)}function un(t,e,n,r,s,o){if(r<0||r>=t.length)return;let i=n,a=s;for(let d of o){let u=Je(d);if(u!==0){if(a<u)break;i>=0&&i<t[r].length&&(t[r][i]=d,e[r][i]="label",u===2&&i+1<t[r].length&&(t[r][i+1]="",e[r][i+1]="label")),i+=u,a-=u}}for(;a>0;)i>=0&&i<t[r].length&&(t[r][i]=" ",e[r][i]="empty"),i+=1,a-=1}function ar(t,e,n,r){let s=r.points;if(s.length<2)return;for(let d=0;d+1<s.length;d+=1)ur(t,e,n,s[d],s[d+1]);for(let d=1;d+1<s.length;d+=1){let u=s[d-1],c=s[d],f=s[d+1],p=dr(u,c,f,n);p&&cn(t,e,c.x,c.y,p,"edgeCorner")}let o=s[s.length-1],i=s[s.length-2],a=cr(i,o,n);a&&cn(t,e,o.x,o.y,a,"arrow")}function ur(t,e,n,r,s){if(!(r.x===s.x&&r.y===s.y)){if(r.y===s.y){let o=r.y,i=Math.min(r.x,s.x),a=Math.max(r.x,s.x);for(let d=i;d<=a;d+=1)dn(t,e,d,o,n,"h")}else if(r.x===s.x){let o=r.x,i=Math.min(r.y,s.y),a=Math.max(r.y,s.y);for(let d=i;d<=a;d+=1)dn(t,e,o,d,n,"v")}}}function dn(t,e,n,r,s,o){if(r<0||r>=t.length)return;let i=t[r];if(n<0||n>=i.length)return;let a=e[r][n];if(!(a==="boxH"||a==="boxV"||a==="boxCorner"||a==="label")){if(a==="empty"){i[n]=o==="h"?s.horizontal:s.vertical,e[r][n]=o==="h"?"edgeH":"edgeV";return}if(a==="edgeH"&&o==="v"){i[n]=s.cross,e[r][n]="edgeCorner";return}if(a==="edgeV"&&o==="h"){i[n]=s.cross,e[r][n]="edgeCorner";return}}}function cn(t,e,n,r,s,o){if(r<0||r>=t.length)return;let i=t[r];if(n<0||n>=i.length)return;let a=e[r][n];a==="boxH"||a==="boxV"||a==="boxCorner"||a==="label"||(i[n]=s,e[r][n]=o)}function dr(t,e,n,r){let s=t.y===e.y,o=e.y===n.y;if(s===o)return;if(s){let d=t.x<e.x,u=n.y>e.y;return d&&u?r.cornerTR:d&&!u?r.cornerBR:!d&&u?r.cornerTL:r.cornerBL}let i=t.y<e.y,a=n.x>e.x;return i&&a?r.cornerBL:i&&!a?r.cornerBR:!i&&a?r.cornerTL:r.cornerTR}function cr(t,e,n){if(e.x>t.x)return n.arrowRight;if(e.x<t.x)return n.arrowLeft;if(e.y>t.y)return n.arrowDown;if(e.y<t.y)return n.arrowUp}function lr(t){let e=t.length;for(;e>0&&t.charCodeAt(e-1)===32;)e-=1;return t.slice(0,e)}function gn(t){let e=fr(t);pr(e),hr(e),gr(e),mr(e,t);let n=vr(e,t),{width:r,height:s}=wr(e),o=[];for(let i of e.layers)for(let a of i)a.isVirtual||o.push({id:a.id,layer:a.layer,order:a.order,x:a.x,y:a.y,w:a.w,h:a.h});return{boxes:o,edges:n,width:r,height:s}}function fr(t){let e=new Map;for(let s of t.nodes)e.set(s,{id:s,isVirtual:!1,layer:-1,order:0,x:0,y:0,w:t.widthCells(s),h:t.heightCells(s),in:[],out:[]});let n=[],r=0;for(let s of t.edges){if(s.from===s.to)continue;let o=e.get(s.from),i=e.get(s.to);if(!o||!i)continue;let a={chainId:r++,chainFrom:s.from,chainTo:s.to,fromId:s.from,toId:s.to,hopIndex:0,chainLen:1};o.out.push(a),i.in.push(a),n.push(a)}return{nodes:e,layers:[],hops:n}}function pr(t){let e=new Map;for(let o of t.nodes.values())e.set(o.id,o.in.length);let n=[];for(let o of t.nodes.values())(e.get(o.id)??0)===0&&(o.layer=0,n.push(o));let r=new Set,s=0;for(;s<n.length;){let o=n[s++];if(!r.has(o.id)){r.add(o.id);for(let i of o.out){let a=t.nodes.get(i.toId);a.layer=Math.max(a.layer,o.layer+1);let d=(e.get(a.id)??0)-1;e.set(a.id,d),d<=0&&n.push(a)}}}for(let o of t.nodes.values())o.layer<0&&(o.layer=0)}function hr(t){let e=Math.max(0,...Array.from(t.nodes.values(),o=>o.layer)),n=Array.from({length:e+1},()=>[]);for(let o of t.nodes.values())n[o.layer].push(o);let r=[],s=0;for(let o of t.hops){let i=t.nodes.get(o.fromId),a=t.nodes.get(o.toId),d=a.layer-i.layer;if(d<=0){i.out=i.out.filter(f=>f!==o),a.in=a.in.filter(f=>f!==o);continue}if(d===1){o.hopIndex=0,o.chainLen=1,r.push(o);continue}i.out=i.out.filter(f=>f!==o),a.in=a.in.filter(f=>f!==o);let u=i;for(let f=1;f<d;f+=1){let p=`__virt_${s++}__`,h={id:p,isVirtual:!0,layer:i.layer+f,order:0,x:0,y:0,w:0,h:1,in:[],out:[]};t.nodes.set(p,h),n[h.layer].push(h);let l={chainId:o.chainId,chainFrom:o.chainFrom,chainTo:o.chainTo,fromId:u.id,toId:p,hopIndex:f-1,chainLen:d};u.out.push(l),h.in.push(l),r.push(l),u=h}let c={chainId:o.chainId,chainFrom:o.chainFrom,chainTo:o.chainTo,fromId:u.id,toId:a.id,hopIndex:d-1,chainLen:d};u.out.push(c),a.in.push(c),r.push(c)}for(let o of n)for(let i=0;i<o.length;i+=1)o[i].order=i;t.layers=n,t.hops=r}function gr(t){for(let n=0;n<4;n+=1){for(let r=1;r<t.layers.length;r+=1)pn(t,t.layers[r],"in"),Xe(t.layers[r]);for(let r=t.layers.length-2;r>=0;r-=1)pn(t,t.layers[r],"out"),Xe(t.layers[r])}for(let n=0;n<2;n+=1){let r=!1;for(let s=1;s<t.layers.length;s+=1){let o=t.layers[s];for(let i=0;i+1<o.length;i+=1){let a=hn(t,o[i],o[i+1],"in");[o[i],o[i+1]]=[o[i+1],o[i]],Xe(o),hn(t,o[i],o[i+1],"in")<a?r=!0:([o[i],o[i+1]]=[o[i+1],o[i]],Xe(o))}}if(!r)break}}function pn(t,e,n){let r=new Map;for(let s of e){let o=n==="in"?s.in:s.out;if(o.length===0){r.set(s.id,s.order);continue}let i=0,a=0;for(let d of o){let u=t.nodes.get(n==="in"?d.fromId:d.toId);u&&(i+=u.order,a+=1)}r.set(s.id,a===0?s.order:i/a)}e.sort((s,o)=>{let i=r.get(s.id),a=r.get(o.id);return i!==a?i-a:s.order-o.order})}function Xe(t){for(let e=0;e<t.length;e+=1)t[e].order=e}function hn(t,e,n,r){let s=r==="in"?e.in:e.out,o=r==="in"?n.in:n.out,i=0;for(let a of s)for(let d of o){let u=t.nodes.get(r==="in"?a.fromId:a.toId)?.order??0,c=t.nodes.get(r==="in"?d.fromId:d.toId)?.order??0;(e.order<n.order&&u>c||e.order>n.order&&u<c)&&(i+=1)}return i}function mr(t,e){e.direction==="LR"?yr(t,e):br(t,e)}function yr(t,e){let n=[],r=0;for(let s=0;s<t.layers.length;s+=1){n.push(r);let o=0;for(let i of t.layers[s])o=Math.max(o,i.w);r+=o+e.layerGap}for(let s=0;s<t.layers.length;s+=1)for(let o of t.layers[s])o.x=n[s];for(let s of t.layers){let o=0;for(let i of s)i.y=o,o+=i.h+e.nodeGap}mn(t,e,"y")}function br(t,e){let n=[],r=0;for(let s=0;s<t.layers.length;s+=1){n.push(r);let o=0;for(let i of t.layers[s])o=Math.max(o,i.h);r+=o+e.layerGap}for(let s=0;s<t.layers.length;s+=1)for(let o of t.layers[s])o.y=n[s];for(let s of t.layers){let o=0;for(let i of s)i.x=o,o+=i.w+e.nodeGap}mn(t,e,"x")}function mn(t,e,n){let r=o=>n==="y"?o.h:o.w,s=e.nodeGap;for(let o=0;o<2;o+=1){let i=o===0?t.layers.slice(1):t.layers.slice(0,-1).reverse();for(let a of i){let d=new Map;for(let c of a){let f=o===0?c.in:c.out;if(f.length===0)continue;let p=[];for(let l of f){let y=t.nodes.get(o===0?l.fromId:l.toId);if(!y)continue;let m=n==="y"?y.y:y.x;p.push(m+Math.floor(r(y)/2))}if(p.length===0)continue;p.sort((l,y)=>l-y);let h=p[Math.floor(p.length/2)];d.set(c.id,h-Math.floor(r(c)/2))}let u=0;for(let c of a){let f=d.get(c.id),p=n==="y"?c.y:c.x,l=Math.max(f??p,u);n==="y"?c.y=l:c.x=l,u=l+r(c)+s}}}}function vr(t,e){let n=new Map;for(let u of t.hops){let c=n.get(u.chainId);c?c.push(u):n.set(u.chainId,[u])}for(let u of n.values())u.sort((c,f)=>c.hopIndex-f.hopIndex);let r=e.direction==="LR",s=u=>r?u.x:u.y,o=u=>r?u.w:u.h,i=u=>r?u.y+Math.floor(u.h/2):u.x+Math.floor(u.w/2),a=new Map;for(let u=0;u+1<t.layers.length;u+=1){let c=t.layers[u],f=t.layers[u+1],p=0;for(let b of c)p=Math.max(p,s(b)+o(b));let h=Number.POSITIVE_INFINITY;for(let b of f)h=Math.min(h,s(b));let l=Number.isFinite(h)?h-1:p,y=Math.max(1,l-p+1),m=[];for(let b of c)for(let O of b.out)m.push(O);m.sort((b,O)=>{let A=i(t.nodes.get(b.fromId)),k=i(t.nodes.get(O.fromId));if(A!==k)return A-k;let R=i(t.nodes.get(b.toId)),N=i(t.nodes.get(O.toId));return R-N});let w=[],_=new Map;for(let b of m){let O=i(t.nodes.get(b.fromId)),A=i(t.nodes.get(b.toId)),k=Math.min(O,A),R=Math.max(O,A),N=-1;for(let D=0;D<w.length;D+=1){let H=w[D],V=!0;for(let ue of H)if(ue.lo<=R&&k<=ue.hi){V=!1;break}if(V){H.push({lo:k,hi:R}),N=D;break}}N<0&&(w.push([{lo:k,hi:R}]),N=w.length-1),_.set(b,N)}let v=w.length,x=y>=Math.max(3,v+2),E=x?p+1:p,T=x?l-1:l,g=Math.max(1,T-E+1);for(let b of m){let O=_.get(b),A;if(v<=1)A=E+Math.floor(g/2);else{let k=(g-1)/(v-1);A=E+Math.floor(O*k)}a.set(b,Math.max(p,Math.min(l,A)))}}let d=[];for(let[,u]of n){let c=[];for(let p=0;p<u.length;p+=1){let h=u[p],l=t.nodes.get(h.fromId),y=t.nodes.get(h.toId),m=a.get(h),w=l.isVirtual?s(l):s(l)+o(l),_=y.isVirtual?s(y):s(y)-1,v=i(l),x=i(y);p===0&&Ze(c,r,w,v),v!==x&&(Ze(c,r,m,v),Ze(c,r,m,x)),Ze(c,r,_,x)}let f=u[0];d.push({from:f.chainFrom,to:f.chainTo,points:_r(c)})}return d}function Ze(t,e,n,r){t.push(e?{x:n,y:r}:{x:r,y:n})}function _r(t){let e=[];for(let n of t){let r=e[e.length-1];(!r||r.x!==n.x||r.y!==n.y)&&e.push(n)}return e}function wr(t){let e=0,n=0;for(let r of t.layers)for(let s of r)e=Math.max(e,s.x+s.w),n=Math.max(n,s.y+s.h);return{width:e,height:n}}var xr=24,Tr=4,Or=1,Er=3;function yn(t,e){let n=kr(e.direction),r=Math.max(3,e.maxLabelWidth??xr),s=e.asciiCharset??"unicode",o=Object.keys(t.nodes).sort(),i=new Set(o),a=t.edges.filter(h=>i.has(h.from)&&i.has(h.to)),d=new Map,u=new Map;for(let h of o){let l=an(h,r);d.set(h,l),u.set(h,Je(l)+4)}let c=gn({nodes:o,edges:a,widthCells:h=>u.get(h)??3,heightCells:()=>Er,layerGap:Tr,nodeGap:Or,direction:n}),f=ln(c,{charset:s,labelOf:h=>d.get(h)??h}),p=e.logger;return p&&p(f),f}function kr(t){if(t===void 0||t==="LR")return"LR";if(t==="TD")return"TD";throw new Error(`ascii describe supports direction "LR" or "TD" only; got ${String(t)}`)}fe();function bn(t,e){let n=e?.topN??10,r=t.describe({detail:"standard"}),s=[],o=t._collectObserveTargets;typeof o=="function"&&o.call(t,"",s);let i=new Map;for(let[p,h]of s)i.set(p,h);let a=[];for(let[p,h]of Object.entries(r.nodes)){let l=i.get(p),y=l instanceof P?l:null,m=y?Zt(y.cache):0,w=y?y._sinkCount:0,_=h.deps?.length??0,v=h.type==="effect"&&w===0,x=w===0?h.type==="effect"?"orphan-effect":h.type==="derived"?"idle-derived":h.type==="producer"?"idle-producer":null:null;a.push({path:p,type:h.type,status:h.status??"unknown",valueSizeBytes:m,subscriberCount:w,depCount:_,isOrphanEffect:v,orphanKind:x})}let d=a.reduce((p,h)=>p+h.valueSizeBytes,0),u=(p,h)=>[...a].sort(h??((l,y)=>y[p]-l[p])).slice(0,n),c=a.filter(p=>p.orphanKind!=null),f=a.filter(p=>p.isOrphanEffect);return{nodeCount:a.length,edgeCount:r.edges.length,subgraphCount:r.subgraphs.length,nodes:a,totalValueSizeBytes:d,hotspots:{byValueSize:u("valueSizeBytes"),bySubscriberCount:u("subscriberCount"),byDepCount:u("depCount")},orphans:c,orphanEffects:f}}var L="::",ee="__meta__",pe=1;function vn(t,e){let n=Math.max(16,t.size*4),r=0;for(;t.size>0;){if(r++>=n){console.error(`[Graph "${e}".destroy] disposer drain exceeded cap (${n}); ${t.size} disposer(s) discarded`),t.clear();return}let s=t.values().next();if(s.done)return;let o=s.value;t.delete(o);try{o()}catch(i){console.error(`[Graph "${e}".destroy] disposer threw:`,i)}}}function xn(t){return t!=null&&typeof t=="object"&&"cache"in t&&typeof t.subscribe=="function"&&typeof t.down=="function"}function Nr(t){if(t!=null)return xn(t)?t.cache:t}function Sr(t){let e=[];for(let n of Object.keys(t).sort()){let r=t[n].v;r!=null&&e.push(`${n} ${r.id} ${r.version}`)}return e.join(`
4
- `)}function _n(t){if(t.version!==pe)throw new Error(`unsupported snapshot version ${String(t.version)} (expected ${pe})`);for(let e of["name","nodes","edges","subgraphs"])if(!(e in t))throw new Error(`snapshot missing required key "${e}"`);if(typeof t.name!="string")throw new TypeError("snapshot 'name' must be a string");if(typeof t.nodes!="object"||t.nodes===null||Array.isArray(t.nodes))throw new TypeError("snapshot 'nodes' must be an object");if(!Array.isArray(t.edges))throw new TypeError("snapshot 'edges' must be an array");if(!Array.isArray(t.subgraphs))throw new TypeError("snapshot 'subgraphs' must be an array")}function Ar(t,e){let n=new WeakMap,r=(s,o)=>{if(Object.is(s,o))return!0;if(s==null||o==null||typeof s!="object"||typeof o!="object")return!1;let i=n.get(s);if(i==null&&(i=new WeakSet,n.set(s,i)),i.has(o))return!0;i.add(o);let a=s.constructor,d=o.constructor;if(a!==d)return!1;if(s instanceof Date)return s.getTime()===o.getTime();if(s instanceof RegExp)return s.source===o.source&&s.flags===o.flags;if(Array.isArray(s)){let p=o;if(s.length!==p.length)return!1;for(let h=0;h<s.length;h++)if(!r(s[h],p[h]))return!1;return!0}if(s instanceof Map){let p=o;if(s.size!==p.size)return!1;for(let[h,l]of s)if(!p.has(h)||!r(l,p.get(h)))return!1;return!0}if(s instanceof Set){let p=o;if(s.size!==p.size)return!1;for(let h of s){let l=!1;for(let y of p)if(r(h,y)){l=!0;break}if(!l)return!1}return!0}if(ArrayBuffer.isView(s)){let p=s,h=o;if(p.length!==h.length)return!1;for(let l=0;l<p.length;l++)if(p[l]!==h[l])return!1;return!0}let u=Object.keys(s),c=Object.keys(o);if(u.length!==c.length)return!1;let f=new Set(c);for(let p of u)if(!f.has(p)||!r(s[p],o[p]))return!1;return!0};return r(t,e)}function At(t){if(t===null||typeof t!="object")return t;if(Array.isArray(t))return t.map(At);let e=t,n=Object.keys(e).sort(),r={};for(let s of n)r[s]=At(e[s]);return r}function Rr(t){return t.replaceAll("\\","\\\\").replaceAll('"','\\"')}function Dr(t){return t.replaceAll("\\","\\\\").replaceAll('"','\\"')}function Cr(t){return t==="TD"?"down":t==="BT"?"up":t==="RL"?"left":"right"}function Tn(t){let e=new Set,n=[];function r(s,o){let i=`${s}\0${o}`;e.has(i)||(e.add(i),n.push([s,o]))}for(let[s,o]of Object.entries(t.nodes)){let i=o.deps;if(i)for(let a of i)r(a,s)}for(let s of t.edges)r(s.from,s.to);return n}function On(t){if(t===void 0)return"LR";if(t==="TD"||t==="LR"||t==="BT"||t==="RL")return t;throw new Error(`invalid diagram direction ${String(t)}; expected one of: TD, LR, BT, RL`)}function Gr(t,e){let n=e.includeEdges??!0,r=e.includeSubgraphs??!0,{expand:s,...o}=t,i={...o,edges:n?t.edges:[],subgraphs:r?t.subgraphs:[]},a=JSON.stringify(At(i),null,e.indent??2);return e.logger?.(a),a}function Mr(t,e){let n=e.includeEdges??!0,r=e.includeSubgraphs??!0,s=[];s.push(`Graph ${t.name}`),s.push("Nodes:");for(let i of Object.keys(t.nodes).sort()){let a=t.nodes[i];s.push(`- ${i} (${a.type}/${a.status}): ${et(a.value)}`)}if(n){s.push("Edges:");for(let i of t.edges)s.push(`- ${i.from} -> ${i.to}`)}if(r){s.push("Subgraphs:");for(let i of t.subgraphs)s.push(`- ${i}`)}let o=s.join(`
5
- `);return e.logger?.(o),o}function En(t,e){let n=On(e.direction),r=Object.keys(t.nodes).sort(),s=new Map;for(let i=0;i<r.length;i+=1)s.set(r[i],`n${i}`);let o=[`flowchart ${n}`];for(let i of r){let a=s.get(i);o.push(` ${a}["${Rr(i)}"]`)}for(let[i,a]of Tn(t)){let d=s.get(i),u=s.get(a);!d||!u||o.push(` ${d} --> ${u}`)}return o.join(`
6
- `)}function Lr(t,e){let n=En(t,e);return kn(n)}function kn(t,e){let n=e?.theme??"default",r=e?.autoSync??!0,o=JSON.stringify({code:t,mermaid:{theme:n},autoSync:r}),i=new TextEncoder().encode(o),a="";for(let u=0;u<i.length;u++)a+=String.fromCharCode(i[u]);return`https://mermaid.live/edit#base64:${globalThis.btoa(a).replace(/\+/g,"-").replace(/\//g,"_").replace(/=+$/,"")}`}function Ir(t,e){let n=On(e.direction),r=Object.keys(t.nodes).sort(),s=new Map;for(let i=0;i<r.length;i+=1)s.set(r[i],`n${i}`);let o=[`direction: ${Cr(n)}`];for(let i of r){let a=s.get(i);o.push(`${a}: "${Dr(i)}"`)}for(let[i,a]of Tn(t)){let d=s.get(i),u=s.get(a);!d||!u||o.push(`${d} -> ${u}`)}return o.join(`
7
- `)}function Pr(t){return t.replace(/[.*+?^${}()|[\]\\]/g,"\\$&")}function Qe(t){let e="^";for(let n=0;n<t.length;n+=1){let r=t[n];if(r==="*"){e+=".*";continue}if(r==="?"){e+=".";continue}if(r==="["){let s=t.indexOf("]",n+1);if(s<=n+1){e+="\\[";continue}let o=t.slice(n+1,s);o.startsWith("!")&&(o=`^${o.slice(1)}`),o=o.replace(/\\/g,"\\\\"),e+=`[${o}]`,n=s;continue}e+=Pr(r)}return e+="$",new RegExp(e)}var $r={data:"\x1B[32m",dirty:"\x1B[33m",resolved:"\x1B[36m",invalidate:"\x1B[93m",pause:"\x1B[90m",resume:"\x1B[96m",complete:"\x1B[34m",error:"\x1B[31m",teardown:"\x1B[91m",derived:"\x1B[35m",path:"\x1B[90m",reset:"\x1B[0m"},Fr={data:"",dirty:"",resolved:"",invalidate:"",pause:"",resume:"",complete:"",error:"",teardown:"",derived:"",path:"",reset:""};function et(t){if(typeof t=="string")return JSON.stringify(t);if(typeof t=="number"||typeof t=="boolean"||t==null)return String(t);try{return JSON.stringify(t)}catch{return"[unserializable]"}}function Vr(t){return t==="none"?Fr:t==="ansi"||t==null?$r:{data:t.data??"",dirty:t.dirty??"",resolved:t.resolved??"",invalidate:t.invalidate??"",pause:t.pause??"",resume:t.resume??"",complete:t.complete??"",error:t.error??"",teardown:t.teardown??"",derived:t.derived??"",path:t.path??"",reset:t.reset??""}}function wn(t){if(t==null)return{};let e=t.detail;return e==="full"?{...t,structured:t.structured??!0,timeline:t.timeline??!0,causal:t.causal??!0,derived:t.derived??!0}:e==="minimal"?{...t,structured:t.structured??!0}:t.format==="stage-log"?{...t,structured:t.structured??!0,timeline:t.timeline??!0}:t}function zr(t,e,n){for(let r=0;r<t.length;r++){let s=t.charCodeAt(r);if(s<32||s===127)throw new Error(`Graph "${e}": ${n} "${t}" must not contain control character (U+${s.toString(16).padStart(4,"0").toUpperCase()} at index ${r})`)}}function St(t,e,n){if(t==="")throw new Error(`Graph "${e}": ${n} name must be non-empty`);if(t.includes(L))throw new Error(`Graph "${e}": ${n} "${t}" must not contain '${L}' (path separator)`);if(t===ee)throw new Error(`Graph "${e}": ${n} name "${ee}" is reserved for meta companion paths`);zr(t,e,n)}function Hr(t,e){if(t==="")throw new Error(`Graph "${e}": resolve path must be non-empty`);let n=t.split(L);for(let r of n)if(r==="")throw new Error(`Graph "${e}": resolve path has empty segment`);return n}function jr(t,e){let n=!1;for(let s of t)if(!e.isMetaPassthrough(s[0])){n=!0;break}return n?t.filter(s=>e.isMetaPassthrough(s[0])):t}function Nn(t){for(let e of t._mounts.values())Nn(e);for(let e of t._nodes.values())try{e.down([[F]],{internal:!0})}catch{}}var Y=class t{name;opts;config;_nodes=new Map;_nodeToName=new WeakMap;_mounts=new Map;_parent=void 0;_storageDisposers=new Set;_disposers=new Set;_destroyed=!1;_topology;_topologyEmitters=new Set;_factory;_factoryArgs;constructor(e,n){if(e==="")throw new Error("Graph name must be non-empty");if(e.includes(L))throw new Error(`Graph name must not contain '${L}' (got "${e}")`);if(e===ee)throw new Error(`Graph name "${ee}" is reserved for meta companion paths`);this.name=e,this.opts=Object.freeze({...n??{}}),this.config=n?.config??_e,this._traceRing=new Re(n?.traceCapacity??1e3),n?.versioning!=null&&this.setVersioning(n.versioning),typeof n?.factory=="string"&&(this._factory=n.factory,n.factoryArgs!==void 0&&(this._factoryArgs=n.factoryArgs))}tagFactory(e,n){return this._factory=e,this._factoryArgs=n,this}ancestors(e=!0){let n=[],r=e?this:this._parent;for(;r!=null;)n.push(r),r=r._parent;return n}get topology(){return this._topology==null&&(this._topology=je(e=>{let n=r=>{e.emit(r)};return this._topologyEmitters.add(n),()=>{this._topologyEmitters.delete(n)}},{name:`${this.name}_topology`})),this._topology}_emitTopology(e){if(!(this._topology==null||this._topologyEmitters.size===0))for(let n of this._topologyEmitters)n(e)}nameOf(e){return this._nodeToName.get(e)}add(e,n){let r=e.name,s=n?.name??r;if(s==null||s==="")throw new Error(`Graph "${this.name}": graph.add requires a non-empty name \u2014 pass via opts.name or set it on the node (e.g. state(0, { name: "x" }))`);let o=s,i=n?.annotation;if(St(o,this.name,"add"),this._mounts.has(o))throw new Error(`Graph "${this.name}": name "${o}" is already a mount point`);if(this._nodes.has(o))throw new Error(`Graph "${this.name}": node "${o}" already exists`);let a=this._nodeToName.get(e);if(a!==void 0)throw new Error(`Graph "${this.name}": node instance already registered as "${a}"`);return this._nodes.set(o,e),this._nodeToName.set(e,o),this._emitTopology({kind:"added",name:o,nodeKind:"node"}),i!=null&&(this._annotations.set(o,i),this.config.inspectorEnabled&&this._traceRing.push({path:o,annotation:i,timestamp_ns:U()})),e}setVersioning(e){if(e!=null)for(let n of this._nodes.values())n instanceof P&&n._applyVersioning(e)}remove(e){St(e,this.name,"remove");let n=this._mounts.get(e);if(n){let o={kind:"mount",nodes:[],mounts:[]},i=[];n._collectObserveTargets("",i);for(let[a,d]of i)a.includes(`${L}${ee}${L}`)||o.nodes.push(a);return o.nodes.sort(),o.mounts.push(e),o.mounts.push(...n._collectSubgraphs(`${e}${L}`)),this._mounts.delete(e),n._parent=void 0,Nn(n),this._emitTopology({kind:"removed",name:e,nodeKind:"mount",audit:o}),o}let r=this._nodes.get(e);if(!r)throw new Error(`Graph "${this.name}": unknown node or mount "${e}"`);this._nodes.delete(e),this._nodeToName.delete(r),r.down([[F]],{internal:!0});let s={kind:"node",nodes:[e],mounts:[]};return this._emitTopology({kind:"removed",name:e,nodeKind:"node",audit:s}),s}removeAll(e){let n=typeof e=="function"?e:(()=>{let o=Qe(e);return i=>o.test(i)})(),r={kind:"mount",nodes:[],mounts:[]},s=[...this._nodes.keys(),...this._mounts.keys()].filter(o=>n(o));for(let o of s){let i=this.remove(o);r.nodes.push(...i.nodes),r.mounts.push(...i.mounts)}return r.nodes.sort(),r.mounts.sort(),r}[Symbol.iterator](){let e=[...this._nodes.keys()].sort(),n=this._nodes,r=0;return{[Symbol.iterator](){return this},next(){if(r>=e.length)return{value:void 0,done:!0};let s=e[r++];return{value:[s,n.get(s)],done:!1}}}}node(e){if(e==="")throw new Error(`Graph "${this.name}": node name must be non-empty`);if(e.includes(L))return this.resolve(e);let n=this._nodes.get(e);if(!n)throw new Error(`Graph "${this.name}": unknown node "${e}"`);return n}get(e){return this.node(e).cache}set(e,n,r){let s=r?.internal===!0;this.node(e).down([[G,n]],{actor:r?.actor,internal:s,delivery:"write"})}setAll(e,n){let r=Symbol.iterator in e?e:Object.entries(e);ke(()=>{for(let[s,o]of r)this.set(s,o,n)})}invalidate(e,n){let r=n?.internal===!0;this.node(e).down([[Q]],{actor:n?.actor,internal:r,delivery:"write"})}error(e,n,r){let s=r?.internal===!0;this.node(e).down([[I,n]],{actor:r?.actor,internal:s,delivery:"write"})}complete(e,n){let r=n?.internal===!0;this.node(e).down([[z]],{actor:n?.actor,internal:r,delivery:"write"})}edges(e){let n=e?.recursive===!0,r=new Map;if(!n){for(let[d,u]of this._nodes)r.set(u,d);let a=[];for(let[d,u]of this._nodes)if(u instanceof P)for(let c of u._deps){let f=r.get(c.node);f!=null&&a.push([f,d])}return a.sort((d,u)=>d[0]<u[0]?-1:d[0]>u[0]?1:d[1]<u[1]?-1:d[1]>u[1]?1:0),a}let s=[];this._collectObserveTargets("",s);let o=new Map;for(let[a,d]of s)o.set(d,a);let i=[];for(let[a,d]of s)if(d instanceof P)for(let u of d._deps){let c=o.get(u.node);c!=null&&i.push([c,a])}return i.sort((a,d)=>a[0]<d[0]?-1:a[0]>d[0]?1:a[1]<d[1]?-1:a[1]>d[1]?1:0),i}mount(e,n){if(n===void 0){let s=new t(e);return this.mount(e,s)}if(typeof n=="function"){let s=new t(e);return n(s),this.mount(e,s)}let r=n;if(St(e,this.name,"mount"),this._nodes.has(e))throw new Error(`Graph "${this.name}": cannot mount at "${e}" \u2014 node with that name exists`);if(this._mounts.has(e))throw new Error(`Graph "${this.name}": mount "${e}" already exists`);if(r===this)throw new Error(`Graph "${this.name}": cannot mount a graph into itself`);if(r._parent!=null)throw new Error(`Graph "${this.name}": this child graph is already mounted on "${r._parent.name}"`);for(let s=this;s!=null;s=s._parent)if(s===r)throw new Error(`Graph "${this.name}": mount("${e}", \u2026) would create a mount cycle`);return this._mounts.set(e,r),r._parent=this,this._emitTopology({kind:"added",name:e,nodeKind:"mount"}),r}resolve(e){let n=Hr(e,this.name);return this._resolveFromSegments(n)}tryResolve(e){try{return this.resolve(e)}catch{return}}_resolveFromSegments(e){let n=e;if(n[0]===this.name&&(n=n.slice(1),n.length===0))throw new Error(`Graph "${this.name}": resolve path ends at graph name only`);let r=n[0],s=n.slice(1);if(s.length===0){let a=this._nodes.get(r);if(a)return a;throw this._mounts.has(r)?new Error(`Graph "${this.name}": path ends at subgraph "${r}" \u2014 not a node (GRAPHREFLY-SPEC \xA73.5)`):new Error(`Graph "${this.name}": unknown name "${r}"`)}let o=this._nodes.get(r);if(o&&s.length>0&&s[0]===ee)return this._resolveMetaChainFromNode(o,s,n.join(L));let i=this._mounts.get(r);if(!i)throw this._nodes.has(r)?new Error(`Graph "${this.name}": "${r}" is a node; trailing path "${s.join(L)}" is invalid`):new Error(`Graph "${this.name}": unknown mount or node "${r}"`);return i.resolve(s.join(L))}_resolveMetaChainFromNode(e,n,r){let s=e,o=0,i=[...n];for(;o<i.length;){if(i[o]!==ee)throw new Error(`Graph "${this.name}": expected ${ee} segment in meta path "${r}"`);if(o+1>=i.length)throw new Error(`Graph "${this.name}": meta path requires a key after ${ee} in "${r}"`);let a=i[o+1],d=s.meta[a];if(!d)throw new Error(`Graph "${this.name}": unknown meta "${a}" in path "${r}"`);s=d,o+=2}return s}signal(e,n){if(n?.internal!==!0){for(let s of e)if(this.config.messageTier(s[0])===3)throw new Error(`Graph "${this.name}": Graph.signal() rejects tier-3 messages (DATA / RESOLVED). Broadcast is for control-plane tiers (START / DIRTY / INVALIDATE / PAUSE / RESUME / COMPLETE / ERROR / TEARDOWN). For per-node value writes, use Graph.set or graph.node(name).down(...).`)}let r=[];if(this._signalDeliver(e,n??{},new Set,r),r.length>0)throw r[0]}_signalDeliver(e,n,r,s){for(let d of this._mounts.values())d._signalDeliver(e,n,r,s);let i=n.internal===!0?{internal:!0}:{actor:n.actor,delivery:"signal"},a=jr(e,this.config);for(let d of[...this._nodes.keys()].sort()){let u=this._nodes.get(d);if(!r.has(u)){r.add(u);try{u.down(e,i)}catch(c){if(c instanceof Z)throw c;s.push(c)}a.length!==0&&this._signalMetaSubtree(u,a,r,i,s)}}}_signalMetaSubtree(e,n,r,s,o){for(let i of Object.keys(e.meta).sort()){let a=e.meta[i];if(!r.has(a)){r.add(a);try{a.down(n,s)}catch(d){if(d instanceof Z)throw d;o.push(d)}this._signalMetaSubtree(a,n,r,s,o)}}}describe(e){if(e?.reactive==="diff")return this._describeReactiveDiff(e);if(e?.reactive===!0)return this._describeReactive(e);let n=Nr(e?.actor),r=e?.filter,s=qe(e?.detail,e?.fields),o=e?.format==="spec",i=o?qe("minimal"):s,a=[];this._collectObserveTargets("",a);let d=new Map;for(let[T,g]of a)d.set(g,T);let u=[];{let T=a.map(([,O])=>O),g=new Set(d.values()),b=0;for(;T.length>0;){let O=T.shift();if(O instanceof P)for(let A of O._deps){let k=A.node;if(d.has(k))continue;let R=k.name??"",N=R;if(!N||g.has(N))if(R){let D=2;for(;g.has(`${R}#${D}`);)D++;N=`${R}#${D}`}else for(N=`__internal__/${b++}`;g.has(N);)N=`__internal__/${b++}`;d.set(k,N),g.add(N),u.push([N,k]),T.push(k)}}}let c=[...a,...u],f={};for(let[T,g]of c){if(n!=null&&!g.allowsObserve(n))continue;let b=Ot(g,i),O=g instanceof P?g._deps.map(N=>d.get(N.node)??N.node.name??""):[],{name:A,...k}=b,R={...k,deps:O};if(!o){let N=this._annotations.get(T);N!=null&&(R.annotation=N)}if(r!=null)if(typeof r=="function"){let N=r;if(!(N.length>=2?N(T,R):N(R)))continue}else{let N=!0;for(let[D,H]of Object.entries(r)){let V=D==="deps_includes"?"depsIncludes":D==="meta_has"?"metaHas":D;if(V==="depsIncludes"){if(!R.deps.includes(String(H))){N=!1;break}continue}if(V==="metaHas"){if(!Object.hasOwn(R.meta??{},String(H))){N=!1;break}continue}if(R[V]!==H){N=!1;break}}if(!N)continue}f[T]=R}let p=new Set(Object.keys(f)),h=[];for(let[T,g]of c)if(g instanceof P)for(let b of g._deps){let O=d.get(b.node);O!=null&&h.push([O,T])}h.sort((T,g)=>T[0]<g[0]?-1:T[0]>g[0]?1:T[1]<g[1]?-1:T[1]>g[1]?1:0);let l=h.map(([T,g])=>({from:T,to:g}));(n!=null||r!=null)&&(l=l.filter(T=>p.has(T.from)&&p.has(T.to)));let y=this._collectSubgraphs(""),m=n!=null||r!=null?y.filter(T=>{let g=`${T}${L}`;return[...p].some(b=>b===T||b.startsWith(g))}):y,w=this,_=e,v={name:this.name,nodes:f,edges:l,subgraphs:m,...this._factory!==void 0?{factory:this._factory}:{},...this._factoryArgs!==void 0?{factoryArgs:this._factoryArgs}:{},expand(T){let g={..._,format:void 0};return Array.isArray(T)?(g.fields=T,g.detail=void 0):(g.detail=T,g.fields=void 0),w.describe(g)}},x=e??{},E=x.format;return E==="json"?Gr(v,x):E==="pretty"?Mr(v,x):E==="mermaid"?En(v,x):E==="mermaid-url"?Lr(v,x):E==="d2"?Ir(v,x):E==="ascii"?yn(v,x):v}_collectSubgraphs(e){let n=[];for(let r of[...this._mounts.keys()].sort()){let s=e===""?r:`${e}${r}`;n.push(s),n.push(...this._mounts.get(r)._collectSubgraphs(`${s}${L}`))}return n}resourceProfile(e){return bn(this,e)}reachable(e,n,r={}){return r.withDetail===!0?Rt(this.describe(),e,n,{...r,withDetail:!0}):Rt(this.describe(),e,n,r)}explain(e,n,r){return r?.reactive===!0?this._explainReactive(e,n,r):this._explainStatic(e,n,r)}_explainStatic(e,n,r){let s=this.describe({detail:"full"}),o=new Map(this._annotations),i=new Map;for(let[a,d]of Object.entries(s.nodes))d.lastMutation!=null&&i.set(a,d.lastMutation);return Qt(s,e,n,{...r?.maxDepth!=null?{maxDepth:r.maxDepth}:{},...r?.findCycle===!0?{findCycle:!0}:{},annotations:o,lastMutations:i})}_describeReactive(e){let n={...e,reactive:!1},r=e.reactiveName??"describe",s=0,o=ne(s,{name:`${r}_version`}),i=this.observe({timeline:!0,structured:!0}),a=!1,d=!1,u=()=>{a||d||(a=!0,ve(()=>{a=!1,!d&&(s+=1,o.emit(s))}))},c=i.onEvent(_=>{let v=_.type;v!=="data"&&v!=="error"&&v!=="complete"&&v!=="teardown"||u()}),f=[],p=new WeakSet,h=_=>{if(p.has(_)||d)return;p.add(_);let v=_.topology.subscribe(x=>{for(let E of x){if(E[0]!==G)continue;let T=E[1];if(u(),T.kind==="added"&&T.nodeKind==="mount"){let g=_._mounts.get(T.name);g!=null&&h(g)}}});f.push(v);for(let x of _._mounts.keys()){let E=_._mounts.get(x);E!=null&&h(E)}};h(this);let l,y=e.actor;xn(y)&&(l=y.subscribe(_=>{let v=!1,x=!1;for(let E of _){let T=E[0];T===G?v=!0:(T===z||T===I||T===F)&&(x=!0)}v&&u(),x&&(l?.(),l=void 0,u())}));let m;try{m=j([o],()=>this.describe(n),{name:r,describeKind:"derived",meta:{domain:"audit",kind:"describe"},equals:(_,v)=>_===v})}catch(_){c(),l?.();for(let v of f)v();throw i.dispose(),_}let w=re(m);return{node:m,dispose(){d=!0,c(),l?.();for(let _ of f)_();f.length=0,i.dispose(),w()}}}_describeReactiveDiff(e){let n={...e,format:void 0,reactive:!1},r=e.reactiveName??"describe-diff",s={name:this.name,nodes:{},edges:[],subgraphs:[]},o=this.describe(n),i=kt(s,o),a=ne(i,{name:r,meta:{domain:"audit",kind:"describe-diff"},equals:(p,h)=>p===h}),d=this._describeReactive({...e,format:void 0,reactiveName:void 0}),u=!1,c=d.node.subscribe(p=>{if(!u)for(let h of p){if(h[0]!==G)continue;let l=h[1],y=kt(o,l);o=l,y.events.length!==0&&a.emit(y)}}),f=re(a);return{node:a,dispose(){u=!0,c(),d.dispose(),a.down([[F,"describe-diff disposed"]]),f()}}}_explainReactive(e,n,r){let s=0,o=ne(s,{name:"explain_version"}),i=this.observe({timeline:!0,structured:!0}),a=!1,d=!1,u=i.onEvent(h=>{let l=h.type;l!=="data"&&l!=="error"&&l!=="complete"&&l!=="teardown"||a||d||(a=!0,ve(()=>{a=!1,!d&&(s+=1,o.emit(s))}))}),c={...r?.maxDepth!=null?{maxDepth:r.maxDepth}:{},...r?.findCycle===!0?{findCycle:!0}:{}},f;try{f=j([o],()=>this._explainStatic(e,n,c),{name:r?.name??"explain",describeKind:"derived",meta:{domain:"audit",kind:"explain_path",from:e,to:n},equals:(h,l)=>h.found===l.found&&h.reason===l.reason&&h.steps.length===l.steps.length&&Br(h.steps,l.steps)})}catch(h){throw u(),i.dispose(),h}let p=re(f);return{node:f,dispose(){d=!0,u(),i.dispose(),p()}}}_pathsMatching(e){let n=Qe(e),r=[];return this._collectObserveTargets("",r),r.map(([s])=>s).filter(s=>n.test(s))}_collectObserveTargets(e,n){for(let r of[...this._mounts.keys()].sort()){let s=e===""?r:`${e}${L}${r}`;this._mounts.get(r)._collectObserveTargets(s,n)}for(let r of[...this._nodes.keys()].sort()){let s=this._nodes.get(r),o=e===""?r:`${e}${L}${r}`;n.push([o,s]),this._appendMetaObserveTargets(o,s,n)}}_appendMetaObserveTargets(e,n,r){for(let s of Object.keys(n.meta).sort()){let o=n.meta[s],i=`${e}${L}${ee}${L}${s}`;r.push([i,o]),this._appendMetaObserveTargets(i,o,r)}}observe(e,n){let r=typeof e=="string",o=wn(r?n:e);if(o.reactive===!0)return this._observeReactive(r?e:void 0,o);let i=o.structured===!0||o.timeline===!0||o.causal===!0||o.derived===!0||o.detail==="minimal"||o.detail==="full"||o.format!=null,a=o.actor;if(r){let c=e,f=this.resolve(c);if(a!=null&&!f.allowsObserve(a))throw new Z({actor:a,action:"observe",nodeName:c});return i?this._buildStructuredObserver([[c,f]],o,"one"):{subscribe(p){return f.subscribe(p)},up(p){try{f.up?.(p)}catch(h){if(h instanceof Z)return;throw h}}}}let d=[];this._collectObserveTargets("",d),d.sort((c,f)=>c[0]<f[0]?-1:c[0]>f[0]?1:0);let u=a==null?d:d.filter(([,c])=>c.allowsObserve(a));return i?this._buildStructuredObserver(u,o,"all"):{subscribe:c=>{let f=u.map(([p,h])=>h.subscribe(l=>{c(p,l)}));return()=>{for(let p of f)p()}},up:(c,f)=>{try{this.resolve(c).up?.(f)}catch(p){if(p instanceof Z)return;throw p}}}}_observeReactive(e,n){let r=n.tiers,s=r!=null?new Set(r):null,o=n.reactiveName??"observe";return je(i=>{let a=[],d=!1,u=!1,c=()=>{if(a.length===0||u)return;let y={events:a.slice(),flushedAt_ns:U()};a.length=0,i.emit(y)},f={...n,reactive:!1,structured:!0,timeline:!0},p=e!=null?this.observe(e,f):this.observe(f),h=y=>{u||(a.push(y),!d&&(d=!0,ve(()=>{d=!1,c()})))};for(let y of p.events)h(y);let l=p.onEvent(h);return()=>{u=!0,l(),p.dispose()}},{name:o,meta:{domain:"audit",kind:"observe-reactive"}})}_buildStructuredObserver(e,n,r){let s=r==="one"?e[0]?.[0]:void 0,o=i=>{if(r==="one"&&s!=null){let c=this.resolve(s);return this._buildStructuredObserver([[s,c]],i,"one")}let a=[];this._collectObserveTargets("",a),a.sort((c,f)=>c[0]<f[0]?-1:c[0]>f[0]?1:0);let d=i.actor,u=d==null?a:a.filter(([,c])=>c.allowsObserve(d));return this._buildStructuredObserver(u,i,"all")};return this._createObserveResult(e,n,o)}_createObserveResult(e,n,r){let s=n.timeline===!0,o=n.causal===!0,i=n.derived===!0,a=n.detail==="minimal",d=this.config.inspectorEnabled,u=(o||i)&&d,c=n.maxEvents,f=c!=null&&c>0?new Re(c):null,p=[],h=new Set,l=n.tiers!=null?new Set(n.tiers):null,y={},m=new Set,w=0,_=0,v=0,x=0,E=0,T=0,g=!1,b=!1,O=0,A=new Map,k=new Map,R=new Map,N=S=>{if(!(l!=null&&!l.has(S.type))){f?f.push(S):p.push(S);for(let M of h)M(S)}},D=S=>l==null||l.has(S),H=()=>s?{timestamp_ns:U(),in_batch:$e(),batch_id:O}:{},V=(S,M)=>{if(!(!u||!(S instanceof P)))return S._setInspectorHook(J=>{if(J.kind==="dep_message")A.set(S,J.depIndex);else if(J.kind==="run"){let xe=J.batchData.map((C,B)=>C!=null&&C.length>0?C.at(-1):J.prevData[B]);k.set(S,xe);let X=J.batchData.map(C=>C!=null?[...C]:void 0);R.set(S,X),i&&N({type:"derived",path:M,dep_values:xe,dep_batches:X,...H()})}})},ue=S=>{let M=A.get(S),J=k.get(S);if(!o||J==null)return{};let X=(M!=null&&M>=0&&S instanceof P?S._deps[M]:void 0)?.node,C=X?.v,B=R.get(S);return{trigger_dep_index:M,trigger_dep_name:X?.name,...C!=null?{trigger_version:{id:C.id,version:C.version}}:{},dep_values:[...J],...B!=null?{dep_batches:B}:{}}},Gt=[],Mt=[];for(let[S,M]of e){let J=V(M,S);J&&Gt.push(J),Mt.push(M.subscribe(xe=>{O++;for(let X of xe){let C=X[0],B=H();if(C===G){y[S]=X[1];let ut=M instanceof P?M.lastMutation?.actor??me:me;N({type:"data",path:S,data:X[1],actor:ut,...B,...ue(M)})}else if(a)C===K?D("dirty")&&w++:C===q?D("resolved")&&_++:C===Q?D("invalidate")&&v++:C===te?D("pause")&&x++:C===oe?D("resume")&&E++:C===F?D("teardown")&&T++:C===z&&!m.has(S)?D("complete")&&(g=!0):C===I&&D("error")&&(b=!0,m.add(S));else if(C===K)D("dirty")&&w++,N({type:"dirty",path:S,...B});else if(C===q)D("resolved")&&_++,N({type:"resolved",path:S,...B,...ue(M)});else if(C===Q)D("invalidate")&&v++,N({type:"invalidate",path:S,...B});else if(C===te)D("pause")&&x++,N({type:"pause",path:S,lockId:X[1],...B});else if(C===oe)D("resume")&&E++,N({type:"resume",path:S,lockId:X[1],...B});else if(C===z)D("complete")&&!m.has(S)&&(g=!0),N({type:"complete",path:S,...B});else if(C===I){D("error")&&(b=!0,m.add(S));let ut=M instanceof P?M.lastMutation?.actor??me:me;N({type:"error",path:S,data:X[1],actor:ut,...B})}else C===F&&(D("teardown")&&T++,N({type:"teardown",path:S,...B}))}}))}let st=!1,it=()=>{if(!st){st=!0;for(let S of Mt)S();for(let S of Gt)S();for(let S of De)S({value:void 0,done:!0});De.length=0}},at=[],De=[];h.add(S=>{let M=De.shift();M?M({value:S,done:!1}):at.push(S)});let Lt={get values(){return y},get dirtyCount(){return w},get resolvedCount(){return _},get invalidateCount(){return v},get pauseCount(){return x},get resumeCount(){return E},get teardownCount(){return T},get events(){return f?f.toArray():[...p]},get anyCompletedCleanly(){return g},get anyErrored(){return b},get completedWithoutErrors(){return g&&!b},onEvent(S){return h.add(S),()=>h.delete(S)},dispose:it,expand(S){it();let M={...n};return typeof S=="string"?M.detail=S:Object.assign(M,S),r(wn(M))},[Symbol.asyncIterator](){return{next(){return at.length>0?Promise.resolve({value:at.shift(),done:!1}):st?Promise.resolve({value:void 0,done:!0}):new Promise(S=>De.push(S))},return(){return it(),Promise.resolve({value:void 0,done:!0})}}}};return n.format!=null&&this._attachFormatLogger(Lt,n),Lt}_attachFormatLogger(e,n){let r=n.format;if(r==null)return;let s=n.logger??(l=>console.log(l)),o=n.includeTypes?new Set(n.includeTypes):null,i=n.excludeTypes?new Set(n.excludeTypes):null,a=o==null&&i==null?()=>!0:l=>(o==null||o.has(l))&&(i==null||!i.has(l)),d=Vr(n.theme),u=r==="stage-log"?U():0,c=l=>l==null?"":n.stageLabels?.[l]??l,f=(l,y)=>l.length>y?`${l.slice(0,y-1)}\u2026`:l,p=l=>l.type==="data"||l.type==="error"?f(et(l.data),120):"",h=l=>{if(r==="stage-log"){let g=(U()-u)/1e9,b=c(l.path).padEnd(9);if(l.type==="data"){let O=p(l);return`[${g.toFixed(3)}s] ${b} \u2190${O?` ${O}`:""}`}if(l.type==="error"){let O=p(l);return`[${g.toFixed(3)}s] ${b} \u2717${O?` ${O}`:""}`}return l.type==="complete"?`[${g.toFixed(3)}s] ${b} \u25A0 complete`:`[${g.toFixed(3)}s] ${b} ${l.type}`}if(r==="json")try{return JSON.stringify(l)}catch{return JSON.stringify({type:l.type,path:l.path,data:"[unserializable]"})}let y=d[l.type]??"",m=l.path?`${d.path}${l.path}${d.reset} `:"",w=l.type==="data"||l.type==="error",_=l.type==="pause"||l.type==="resume",v=w?` ${et(l.data)}`:_?` ${et(l.lockId)}`:"",x=l.type==="data"||l.type==="resolved"||l.type==="derived"?l:void 0,E=x?.trigger_dep_name!=null?` <- ${x.trigger_dep_name}`:x?.trigger_dep_index!=null?` <- #${x.trigger_dep_index}`:"",T=l.in_batch?" [batch]":"";return`${m}${y}${l.type.toUpperCase()}${d.reset}${v}${E}${T}`};e.onEvent(l=>{a(l.type)&&s(h(l),l)})}addDisposer(e){return this._disposers.add(e),()=>{this._disposers.delete(e)}}destroy(){vn(this._disposers,this.name),this.signal([[F]],{internal:!0}),vn(this._storageDisposers,this.name);for(let e of[...this._mounts.values()])e._parent=void 0,e._destroyClearOnly();this._mounts.clear(),this._nodes.clear(),this._parent=void 0,this._destroyed=!0}get destroyed(){return this._destroyed}_destroyClearOnly(){for(let e of[...this._mounts.values()])e._parent=void 0,e._destroyClearOnly();this._mounts.clear(),this._nodes.clear(),this._parent=void 0,this._destroyed=!0}snapshot(e){let{expand:n,...r}=this.describe({detail:"full"}),s={};for(let a of Object.keys(r.nodes).sort()){let{lastMutation:d,guard:u,...c}=r.nodes[a];s[a]=c}let o=[...r.subgraphs].sort(),i={...r,version:1,nodes:s,subgraphs:o};if(e?.format==null)return i;if(e.format==="json-string")return JSON.stringify(i);if(e.format==="bytes"){if(e.codec==null)throw new Error("snapshot({format: 'bytes'}) requires a `codec` name");let a=this.config.lookupCodec(e.codec);if(a==null)throw new Error(`snapshot: codec "${e.codec}" is not registered on this graph's config. Call config.registerCodec(...) before creating nodes.`);return zt(a,a.encode(i))}throw new Error(`snapshot: unknown format "${String(e.format)}"`)}static decode(e,n){let r=n?.config??_e,{codec:s,codecVersion:o,payload:i}=Ht(e,r);return s.decode(i,o)}restore(e,n){if(_n(e),e.name!==this.name)throw new Error(`Graph "${this.name}": restore snapshot name "${e.name}" does not match this graph`);let r=n?.only==null?null:(Array.isArray(n.only)?n.only:[n.only]).map(o=>Qe(o)),s=n?.includeProducers===!0;for(let o of Object.keys(e.nodes).sort()){if(r!==null&&!r.some(a=>a.test(o)))continue;let i=e.nodes[o];if(i!==void 0){if(!("value"in i)||i.value===void 0){"value"in i&&i.value===void 0&&n?.onError?.(o,new Error(`restore: slice.value is undefined for "${o}" (undefined is the global SENTINEL; not valid DATA)`));continue}if(!(i.type==="derived"||i.type==="effect")&&!(i.type==="producer"&&!s)){if(i.v!=null){let d=this.tryResolve(o)?.v;if(d!=null&&d.id===i.v.id&&d.version===i.v.version)continue}try{this.set(o,i.value)}catch(a){n?.onError?.(o,a)}}}}}static fromSnapshot(e,n){_n(e);let r=typeof n=="function"?n:n?.build,s=typeof n=="function"?void 0:n?.factories,o=new t(e.name);if(r)return r(o),o.restore(e),o;for(let h of[...e.subgraphs].sort((l,y)=>{let m=l.split(L).length,w=y.split(L).length;return m!==w?m-w:l<y?-1:l>y?1:0})){let l=h.split(L),y=o;for(let m of l)y._mounts.has(m)||y.mount(m,new t(m)),y=y._mounts.get(m)}let i=s?Object.entries(s).map(([h,l])=>({re:Qe(h),factory:l})):[],a=h=>{for(let l of i)if(l.re.test(h))return l.factory},d=h=>{let l=h.split(L),y=l.pop();if(y==null||y.length===0)throw new Error(`invalid snapshot path "${h}"`);let m=o;for(let w of l){let _=m._mounts.get(w);if(!_)throw new Error(`unknown mount "${w}" in path "${h}"`);m=_}return[m,y]},u=Object.entries(e.nodes).filter(([h])=>!h.includes(`${L}${ee}${L}`)).sort((h,l)=>h[0]<l[0]?-1:h[0]>l[0]?1:0),c=new Map(u),f=new Map,p=!0;for(;c.size>0&&p;){p=!1;for(let[h,l]of[...c.entries()]){let y=l?.deps??[];if(!y.every(E=>f.has(E)))continue;let[m,w]=d(h),_={...l?.meta??{}},v=a(h),x;if(l?.type==="state")x=ne(l.value,{meta:_});else{if(v==null)continue;x=v(w,{path:h,type:l.type,value:l.value,meta:_,deps:y,resolvedDeps:y.map(E=>f.get(E))})}m.add(x,{name:w}),f.set(h,x),c.delete(h),p=!0}}if(c.size>0){let h=[...c.keys()].sort().join(", ");throw new Error(`Graph.fromSnapshot could not reconstruct nodes without build callback: ${h}. Pass matching factories via fromSnapshot(data, { factories: { pattern: factoryFn } }).`)}return o.restore(e),o}toJSON(){return this.snapshot()}attachSnapshotStorage(e,n={}){let r=e.map(u=>({tier:u,debounceMs:Math.max(0,u.debounceMs??0),compactEvery:Math.max(1,u.compactEvery??10),timer:void 0,seq:0,lastSnapshot:void 0,lastFingerprint:"",disposed:!1,savePending:void 0}));n.autoRestore===!0&&this._cascadeRestore(e,n.onError);let s=(u,c)=>{if(u.disposed)return;let f=Sr(c.nodes);if(u.lastSnapshot!=null&&f!==""&&f===u.lastFingerprint)return;let p=u.seq+1,h=se(),m=u.lastSnapshot==null||p%u.compactEvery===0?{name:this.name,mode:"full",snapshot:c,seq:p,timestamp_ns:h,format_version:pe}:{name:this.name,mode:"diff",diff:Sn(u.lastSnapshot,c),seq:p,timestamp_ns:h,format_version:pe};if(u.tier.filter&&!u.tier.filter(m))return;let w;try{w=u.tier.save(m)}catch(_){n.onError?.(_,u.tier);return}if(w&&typeof w.then=="function"){let x=(u.savePending??Promise.resolve()).then(()=>w,()=>w).then(()=>{u.disposed||(u.seq=p,u.lastSnapshot=c,u.lastFingerprint=f)},E=>{n.onError?.(E,u.tier)});u.savePending=x.finally(()=>{u.savePending===x&&(u.savePending=void 0)})}else u.seq=p,u.lastSnapshot=c,u.lastFingerprint=f},o=(u,c)=>{try{s(u,c)}catch(f){n.onError?.(f,u.tier)}},i=(u,c)=>{if(!c.some(l=>{let y=this.config.messageTier(l[0]);return y>=3&&y<5}))return;if(n.filter){let l=this.tryResolve(u);if(l==null)return;let y=Ot(l,qe("standard"));if(!n.filter(u,y))return}let p,h=()=>(p==null&&(p=this.snapshot()),p);for(let l of r)l.disposed||(l.debounceMs===0?o(l,h()):(l.timer==null&&(l.timer=new Ye),l.timer.start(l.debounceMs,()=>{l.disposed||o(l,this.snapshot())})))},a;if(n.paths!=null){let c=(typeof n.paths=="string"?this._pathsMatching(n.paths):n.paths).map(f=>{let p=this.tryResolve(f);return p==null?()=>{}:p.subscribe(h=>i(f,h))});a=()=>{for(let f of c)f()}}else a=this.observe().subscribe((u,c)=>i(u,c));let d=()=>{a();for(let u of r)u.disposed=!0,u.timer?.cancel();this._storageDisposers.delete(d)};return this._storageDisposers.add(d),{dispose:d}}async _cascadeRestore(e,n){for(let r of e){let s;try{s=await r.load?.()}catch(i){n?.(i,r);continue}if(s==null||typeof s!="object"||Array.isArray(s))continue;let o=s;try{if(o.mode==="full"&&o.snapshot!=null)return this.restore(o.snapshot),!0;if(o.version===pe&&o.nodes!=null)return this.restore(o),!0}catch(i){n?.(i,r)}}return!1}static async fromStorage(e,n,r){for(let s of n){let o;try{o=await s.load?.()}catch(d){r?.onError?.(d,s);continue}if(o==null||typeof o!="object"||Array.isArray(o))continue;let i=o,a=i.mode==="full"&&i.snapshot!=null?i.snapshot:i.version===pe&&i.nodes!=null?i:void 0;if(a!=null)try{return t.fromSnapshot(a,r)}catch(d){r?.onError?.(d,s)}}throw new Error(`Graph.fromStorage: no tier held a restorable record for "${e}" across ${n.length} tier(s)`)}_annotations=new Map;_traceRing;trace(e,n,r){if(e!=null&&n!=null){if(this.tryResolve(e)==null)return;if(this._annotations.set(e,n),this.config.inspectorEnabled){let s={path:e,annotation:n,timestamp_ns:U(),...r?.actor!=null?{actor:r.actor}:{}};this._traceRing.push(s)}return}return e!=null?this.config.inspectorEnabled?this._annotations.get(e):void 0:this.config.inspectorEnabled?this._traceRing.toArray():[]}annotation(e){return this._annotations.get(e)}clearTrace(){this._annotations.clear(),this._traceRing.clear()}pruneTrace(e){let n=this._traceRing.toArray().filter(s=>!e(s)),r=this._traceRing.size-n.length;this._traceRing.clear();for(let s of n)this._traceRing.push(s);return r}static diff(e,n){let r=new Set(Object.keys(e.nodes)),s=new Set(Object.keys(n.nodes)),o=[...s].filter(_=>!r.has(_)).sort(),i=[...r].filter(_=>!s.has(_)).sort(),a=[],d=[];for(let _ of r){if(!s.has(_))continue;let v=e.nodes[_],x=n.nodes[_],E=v.v,T=x.v;E!=null&&T!=null&&E.id===T.id&&E.version!==T.version&&d.push({path:_,id:E.id,from:E.version,to:T.version});let g=E!=null&&T!=null&&E.id===T.id&&E.version===T.version;for(let b of["type","status","sentinel"]){let O=v[b],A=x[b];O!==A&&a.push({path:_,field:b,from:O,to:A})}if(!g)for(let b of["value","meta"]){let O=v[b],A=x[b];Ar(O,A)||a.push({path:_,field:b,from:O,to:A})}}let u=_=>`${_.from} ${_.to}`,c=new Set(e.edges.map(u)),f=new Set(n.edges.map(u)),p=n.edges.filter(_=>!c.has(u(_))),h=e.edges.filter(_=>!f.has(u(_))),l=new Set(e.subgraphs),y=new Set(n.subgraphs),m=[...y].filter(_=>!l.has(_)).sort(),w=[...l].filter(_=>!y.has(_)).sort();return{nodesAdded:o,nodesRemoved:i,nodesChanged:a,versionChanges:d,edgesAdded:p,edgesRemoved:h,subgraphsAdded:m,subgraphsRemoved:w}}};function Sn(t,e){let n=Y.diff(t,e),r={};for(let s of n.nodesAdded){let o=e.nodes[s];o!=null&&(r[s]=o)}return{...n,nodesAddedFull:r}}function Rt(t,e,n,r={}){let s={paths:[],depths:new Map,truncated:!1};if(!e)return r.withDetail?s:[];if(!r.both&&n!=="upstream"&&n!=="downstream")throw new Error('reachable: direction must be "upstream" or "downstream"');let o=r.maxDepth;if(o!=null&&(!Number.isInteger(o)||o<0))throw new Error("reachable: maxDepth must be an integer >= 0");if(o===0)return r.withDetail?s:[];let i=new Map,a=new Map,d=new Map,u=new Map,c=new Set;for(let[v,x]of Object.entries(t.nodes)){if(!v)continue;c.add(v);let E=x.deps??[];i.set(v,E);for(let T of E)T&&(c.add(T),a.has(T)||a.set(T,new Set),a.get(T).add(v))}for(let v of t.edges){if(v==null||typeof v!="object")continue;let x=typeof v.from=="string"?v.from:"",E=typeof v.to=="string"?v.to:"";!x||!E||(c.add(x),c.add(E),u.has(x)||u.set(x,new Set),u.get(x).add(E),d.has(E)||d.set(E,new Set),d.get(E).add(x))}if(!c.has(e))return r.withDetail?s:[];let f=r.both===!0,p=v=>{if(f){let g=i.get(v)??[],b=d.get(v),O=a.get(v),A=u.get(v),k=[...g];return b&&k.push(...b),O&&k.push(...O),A&&k.push(...A),k}if(n==="upstream"){let g=i.get(v)??[],b=d.get(v);return b?[...g,...b]:g}let x=a.get(v),E=u.get(v),T=x?[...x]:[];return E&&T.push(...E),T},h=new Set([e]),l=new Map,y=[{path:e,depth:0}],m=0,w=!1;for(;m<y.length;){let v=y[m++];if(o!=null&&v.depth>=o){p(v.path).length>0&&(w=!0);continue}for(let x of p(v.path))!x||h.has(x)||(h.add(x),l.set(x,v.depth+1),y.push({path:x,depth:v.depth+1}))}let _=[...l.keys()].sort((v,x)=>v<x?-1:v>x?1:0);return r.withDetail?{paths:_,depths:l,truncated:w}:_}function Br(t,e){if(t.length!==e.length)return!1;for(let n=0;n<t.length;n++){let r=t[n],s=e[n];if(r.path!==s.path||r.type!==s.type||r.status!==s.status||r.hop!==s.hop||r.dep_index!==s.dep_index||r.annotation!==s.annotation||r.value!==s.value||r.lastMutation!==s.lastMutation)return!1;let o=r.v,i=s.v;if(o!==i&&(o==null||i==null||o.id!==i.id||o.version!==i.version))return!1}return!0}ie();function Dt(t,e){let n=new Map,r=(s,o)=>{if(n.has(s))return;let i={off:()=>{},prefix:o};n.set(s,i);let a=s.topology.subscribe(d=>{for(let u of d){if(u[0]!==G)continue;let c=u[1];if(e(c,s,o),c.kind==="added"&&c.nodeKind==="mount"){let f=s._mounts.get(c.name);if(f instanceof Y){let p=`${o}${c.name}::`;r(f,p)}}else if(c.kind==="removed"&&c.nodeKind==="mount"){let f=`${o}${c.name}::`;for(let[p,h]of Array.from(n.entries()))p!==t&&h.prefix.startsWith(f)&&(h.off(),n.delete(p))}}});i.off=a;for(let[d,u]of s._mounts)if(u instanceof Y){let c=`${o}${d}::`;r(u,c)}};return r(t,""),()=>{for(let s of n.values())s.off();n.clear()}}xt();function tt(t,e,n){return{[t]:!0,[`${t}_type`]:e,...n??{}}}Pe();he();ie();Se();function An(t,e){return tt("messaging",t,e)}var Wr=1024,nt=class extends Y{_log;events;latest;hasLatest;constructor(e,n={}){super(e,n.graph),this._log=Be([],{name:"events",maxSize:n.retainedLimit??Wr}),this._log.withLatest(),this.events=this._log.entries,this.add(this.events,{name:"events"}),this.latest=j([this.events],([r])=>{let s=r;return s.length===0?null:s[s.length-1]},{name:"latest",describeKind:"derived",meta:An("topic_latest")}),this.add(this.latest,{name:"latest"}),this.addDisposer(re(this.latest)),this.hasLatest=j([this.events],([r])=>r.length>0,{name:"hasLatest",describeKind:"derived",meta:An("topic_has_latest")}),this.add(this.hasLatest,{name:"hasLatest"}),this.addDisposer(re(this.hasLatest)),this.addDisposer(()=>{this.events.down([[z]])}),this.addDisposer(()=>this._log.disposeAllViews())}publish(e){if(e===void 0)throw new TypeError(`TopicGraph "${this.name}": publish(undefined) is not allowed (spec \xA75.12 SENTINEL).`);this._log.append(e)}attachEventStorage(e){return this._log.attachStorage(e)}retained(){return this.events.cache}get _logBundle(){return this._log}};function Dn(t,e){return tt("audit",t,e)}var Ur=new Set(["data","error","complete","teardown"]),rt=class extends Y{entries;count;_log;_target;constructor(e,n){super(n.name??`${e.name}_audit`,n.graph),this._target=e,this._log=Be([],{name:"entries",...n.maxSize!=null?{maxSize:n.maxSize}:{}}),this.entries=this._log.entries,this.add(this.entries,{name:"entries"}),this.count=j([this.entries],([d])=>d.length,{name:"count",describeKind:"derived",meta:Dn("count")}),this.add(this.count,{name:"count"}),this.addDisposer(re(this.count));let r=n.includeTypes!=null?new Set(n.includeTypes):Ur,s=n.filter,o=0,i=e.observe({timeline:!0,structured:!0}),a=i.onEvent(d=>{if(d.type==="derived")return;let u=d.type;if(!r.has(u))return;let c=d.path??"",f={seq:o++,timestamp_ns:d.timestamp_ns??U(),wall_clock_ns:se(),path:c,type:u},h=(c?Ct(e,c):void 0)?.lastMutation;h!=null&&(f.actor=h.actor),u==="data"&&(f.value=d.data),u==="error"&&(f.error=d.data);let l=c?Zr(e,c):void 0;l!=null&&(f.annotation=l),!(s!=null&&!s(f))&&this._log.append(f)});this.addDisposer(()=>{a(),i.dispose()}),this.addDisposer(()=>this._log.disposeAllViews())}all(){return this.entries.cache??[]}byNode(e){return this.all().filter(n=>n.path===e)}byActor(e){return this.all().filter(n=>n.actor?.id===e)}byActorType(e){return this.all().filter(n=>n.actor?.type===e)}byTimeRange(e,n){return this.all().filter(r=>!(r.timestamp_ns<e||n!=null&&r.timestamp_ns>=n))}get target(){return this._target}};function Kr(t,e={}){return new rt(t,e)}var ot=class extends Y{policies;violations;violationCount;_target;_mode;_currentGuard;constructor(e,n,r){super(r.name??`${e.name}_policy`,r.graph),this._target=e,this._mode=r.mode??"audit";let s=Xr(n)?n:ne(n,{name:"policies"});this.policies=s,this.add(this.policies,{name:"policies"}),this.violations=new nt("violations",{retainedLimit:r.violationsLimit??1e3}),this.mount("violations",this.violations),this.violationCount=j([this.violations.events],([u])=>u.length,{name:"violationCount",describeKind:"derived",meta:Dn("policy_violation_count")}),this.add(this.violationCount,{name:"violationCount"}),this.addDisposer(re(this.violationCount));let i=s.cache??[];this._currentGuard=ct(i);let a=s.subscribe(u=>{for(let c of u)c[0]===G&&(i=c[1]??[],this._currentGuard=ct(i))});this.addDisposer(a);let d=r.paths!=null?[...r.paths]:Rn(e);if(this._mode==="enforce"){let u=new Map,c=f=>{if(u.has(f))return;let p=Ct(e,f);if(!(p instanceof P))return;let h=(l,y)=>{let m=this._currentGuard(l,y);return m||this._publishViolation(l,y,f,"blocked"),m};u.set(f,p._pushGuard(h))};for(let f of d)c(f);if(r.paths==null){let f=Dt(e,(p,h,l)=>{if(p.kind==="added")if(p.nodeKind==="node")c(`${l}${p.name}`);else{let y=h._mounts.get(p.name);if(!(y instanceof Y))return;let m=`${l}${p.name}::`,w=Rn(y);for(let _ of w)c(_===""?`${l}${p.name}`:`${m}${_}`)}else if(p.kind==="removed")if(p.nodeKind==="node"){let y=`${l}${p.name}`,m=u.get(y);m!=null&&(m(),u.delete(y))}else{let y=`${l}${p.name}`,m=`${y}::`;for(let[w,_]of u)(w===y||w.startsWith(m))&&(_(),u.delete(w))}});this.addDisposer(f)}else{let f=e.topology.subscribe(p=>{for(let h of p){if(h[0]!==G)continue;let l=h[1];if(l.kind!=="removed"||l.nodeKind!=="node")continue;let y=u.get(l.name);y!=null&&(y(),u.delete(l.name))}});this.addDisposer(f)}this.addDisposer(()=>{for(let f of u.values())f();u.clear()})}else{let u=e.observe({timeline:!0,structured:!0}),c=u.onEvent(f=>{if(f.type!=="data"&&f.type!=="error")return;let p=f.path??"";if(!p||r.paths!=null&&!r.paths.includes(p))return;let h=f.actor??Ct(e,p)?.lastMutation?.actor;if(h==null)return;let l="write";this._currentGuard(h,l)||this._publishViolation(h,l,p,"observed")});this.addDisposer(()=>{c(),u.dispose()})}}_publishViolation(e,n,r,s){this.violations.publish({timestamp_ns:U(),wall_clock_ns:se(),path:r,actor:e,action:n,mode:this._mode,result:s})}all(){return this.violations.retained()}get mode(){return this._mode}get target(){return this._target}};function qr(t,e,n={}){return new ot(t,e,n)}function Yr(t,e,n,r){return t.explain(e,n,{reactive:!0,...r})}function Jr(t,e={}){let n={format_version:1,timestamp_ns:U(),wall_clock_ns:se(),graph:t.snapshot()};if(e.actor!=null&&(n.actor=e.actor),e.audit!=null){let s=[...e.audit.all()];n.audit={count:s.length,entries:s}}if(e.policies!=null){let s=e.policies.policies.cache??[];n.policies={mode:e.policies.mode,rules:s,violations:[...e.policies.all()]}}let r=Qr(n);return{...n,fingerprint:r}}function Xr(t){return typeof t=="object"&&t!==null&&"subscribe"in t}function Ct(t,e){try{return t.node(e)}catch{return}}function Zr(t,e){try{return t.annotation(e)}catch{return}}function Rn(t){let e=t.describe({detail:"minimal"});return Object.keys(e.nodes)}function Qr(t){return Ne(JSON.stringify(eo(t)))}function eo(t){let e=new Set,n=r=>{if(r===void 0)return{__undefined:!0};if(r===null)return null;let s=typeof r;if(s==="bigint")return{__bigint:r.toString()};if(s!=="object")return r;let o=r;if(e.has(o))return{__circular:!0};e.add(o);try{if(Array.isArray(o))return o.map(n);if(o instanceof Date)return{__date:o.toISOString()};if(o instanceof RegExp)return{__regexp:{source:o.source,flags:o.flags}};if(o instanceof Map)return{__map:[...o.entries()].map(([d,u])=>[n(d),n(u)])};if(o instanceof Set)return{__set:[...o].map(n)};if(ArrayBuffer.isView(o)){let a=o,d=new Array(a.length);for(let u=0;u<a.length;u++)d[u]=a[u]??0;return{__typed_array:{ctor:o.constructor.name,data:d}}}let i={};for(let a of Object.keys(o).sort())i[a]=n(o[a]);return i}finally{e.delete(o)}};return n(t)}0&&(module.exports={AuditTrailGraph,PolicyEnforcerGraph,auditTrail,complianceSnapshot,policyEnforcer,reactiveExplainPath});
1
+ "use strict";var it=Object.defineProperty;var Tn=Object.getOwnPropertyDescriptor;var On=Object.getOwnPropertyNames;var Nn=Object.prototype.hasOwnProperty;var z=(r,e)=>()=>(r&&(e=r(r=0)),e);var kn=(r,e)=>{for(var t in e)it(r,t,{get:e[t],enumerable:!0})},xn=(r,e,t,n)=>{if(e&&typeof e=="object"||typeof e=="function")for(let s of On(e))!Nn.call(r,s)&&s!==t&&it(r,s,{get:()=>e[s],enumerable:!(n=Tn(e,s))||n.enumerable});return r};var En=r=>xn(it({},"__esModule",{value:!0}),r);function Me(){return ge>0||Ne}function Pt(){return ge>0}function be(r){ge>0?ke.push(r):r()}function ce(r){ge+=1;let e=!1;try{r()}catch(t){throw e=!0,t}finally{if(ge-=1,ge===0)if(e){if(!Ne){let t=ke.splice(0);for(let n of t)try{n()}catch{}ue.length=0,de.length=0,me.length=0}}else An()}}function An(){let r=!Ne;r&&(Ne=!0);let e=[],t=0;try{for(;ue.length>0||de.length>0||me.length>0||r&&ke.length>0;){if(r&&ke.length>0){let o=ke.splice(0);for(let i of o)try{i()}catch(a){e.push(a)}continue}if(t+=1,t>1e3)throw ue.length=0,de.length=0,me.length=0,new Error("batch drain exceeded 1000 iterations \u2014 likely a reactive cycle");let s=(ue.length>0?ue:de.length>0?de:me).splice(0);for(let o of s)try{o()}catch(i){e.push(i)}}}finally{r&&(Ne=!1)}if(e.length===1)throw e[0];if(e.length>1)throw new AggregateError(e,"batch drain: multiple callbacks threw")}function Pe(r,e,t){if(e.length===0)return;if(e.length===1){let d=t(e[0][0]);if(d<3||!Me()){r(e);return}(d>=5?me:d===4?de:ue).push(()=>r(e));return}let n=e.length,s=n,o=n,i=n,a=0;for(;a<n&&t(e[a][0])<3;)a++;for(s=a;a<n&&t(e[a][0])===3;)a++;for(o=a;a<n&&t(e[a][0])===4;)a++;i=a;let u=Me();if(s>0){let d=e.slice(0,s);r(d)}if(o>s){let d=e.slice(s,o);u?ue.push(()=>r(d)):r(d)}if(i>o){let d=e.slice(o,i);u?de.push(()=>r(d)):r(d)}if(n>i){let d=e.slice(i,n);u?me.push(()=>r(d)):r(d)}}var ge,Ne,ue,de,me,ke,xe=z(()=>{"use strict";ge=0,Ne=!1,ue=[],de=[],me=[],ke=[]});function B(){return Math.trunc(performance.now()*1e6)}function oe(){return Date.now()*1e6}var Ee=z(()=>{"use strict"});function $t(r){return Array.isArray(r)?[...r]:[r]}function Sn(r,e){return r.has(e)||r.has("*")}function Rn(r){let e=[];return r((s,o)=>{e.push({kind:"allow",actions:new Set($t(s)),where:o?.where??(()=>!0)})},(s,o)=>{e.push({kind:"deny",actions:new Set($t(s)),where:o?.where??(()=>!0)})}),(s,o)=>{let i=!1,a=!1;for(let u of e)Sn(u.actions,o)&&u.where(s)&&(u.kind==="deny"?i=!0:a=!0);return i?!1:a}}function at(r){return Rn((e,t)=>{for(let n of r){let s=n.actorType==null?null:new Set(Array.isArray(n.actorType)?n.actorType:[n.actorType]),o=n.actorId==null?null:new Set(Array.isArray(n.actorId)?n.actorId:[n.actorId]),i=Object.entries(n.claims??{}),a=u=>{if(s!==null&&!s.has(String(u.type))||o!==null&&!o.has(String(u.id??"")))return!1;for(let[d,l]of i)if(u[d]!==l)return!1;return!0};n.effect==="deny"?t(n.action,{where:a}):e(n.action,{where:a})}})}function ut(r){let e=Dn.filter(t=>r({type:t,id:""},"write"));return e.length===0?"restricted":e.includes("human")&&e.includes("llm")&&e.every(t=>t==="human"||t==="llm"||t==="system")?"both":e.length===1?e[0]:e.join("+")}var J,Dn,ye=z(()=>{"use strict";J=class extends Error{actor;action;nodeName;constructor(e,t){super(t??`GuardDenied: action "${String(e.action)}" denied for actor type "${String(e.actor.type)}"`),this.name="GuardDenied",this.actor=e.actor,this.action=e.action,this.nodeName=e.nodeName}get node(){return this.nodeName}};Dn=["human","llm","wallet","system"]});var ve,C,U,W,X,Q,re,F,V,$,le,$e,It,Ie,Lt,Ft,Le,dt,ct,lt,Fe,ie=z(()=>{"use strict";ve=Symbol.for("graphrefly/START"),C=Symbol.for("graphrefly/DATA"),U=Symbol.for("graphrefly/DIRTY"),W=Symbol.for("graphrefly/RESOLVED"),X=Symbol.for("graphrefly/INVALIDATE"),Q=Symbol.for("graphrefly/PAUSE"),re=Symbol.for("graphrefly/RESUME"),F=Symbol.for("graphrefly/TEARDOWN"),V=Symbol.for("graphrefly/COMPLETE"),$=Symbol.for("graphrefly/ERROR"),le=Object.freeze([U]),$e=Object.freeze([W]),It=Object.freeze([X]),Ie=Object.freeze([ve]),Lt=Object.freeze([V]),Ft=Object.freeze([F]),Le=Object.freeze([le]),dt=Object.freeze([$e]),ct=Object.freeze([It]),lt=Object.freeze([Lt]),Fe=Object.freeze([Ft])});function zt(r,e){let t=new TextEncoder().encode(r.name);if(t.length===0||t.length>255)throw new Error(`encodeEnvelope: codec name "${r.name}" encodes to ${t.length} bytes (must be 1\u2013255)`);let n=r.version;if(!Number.isInteger(n)||n<0||n>65535)throw new Error(`encodeEnvelope: codec.version ${n} out of u16 range (expected integer 0\u201365535)`);let s=2+t.length+2+e.length;if(s>4294967295)throw new Error(`encodeEnvelope: total envelope size ${s} exceeds 2^32-1 bytes (payload ${e.length} bytes)`);let o=new Uint8Array(s),i=0;return o[i++]=ft,o[i++]=t.length,o.set(t,i),i+=t.length,o[i++]=n>>>8&255,o[i++]=n&255,o.set(e,i),o}function jt(r,e){if(r.length<Vt)throw new Error(`decodeEnvelope: bytes too short (${r.length} < ${Vt})`);let t=0,n=r[t++];if(n!==ft)throw new Error(`decodeEnvelope: unsupported envelope version ${n} (expected ${ft})`);let s=r[t++];if(s===0)throw new Error("decodeEnvelope: name_len must be >= 1");if(t+s+2>r.length)throw new Error(`decodeEnvelope: envelope truncated (need ${t+s+2} bytes, have ${r.length})`);let o=new TextDecoder().decode(r.subarray(t,t+s));t+=s;let i=(r[t]<<8|r[t+1])>>>0;t+=2;let a=r.subarray(t),u=e.lookupCodec(o);if(u==null)throw new Error(`decodeEnvelope: codec "${o}" not registered (envelope codec_v=${i})`);return{codec:u,codecVersion:i,payload:a}}function Ht(r){r.registerCodec(Cn)}var Cn,ft,Vt,pt=z(()=>{"use strict";Cn={name:"json",version:1,contentType:"application/json",encode(r){let e=JSON.stringify(r);return new TextEncoder().encode(e)},decode(r,e){let t=new TextDecoder().decode(r);return JSON.parse(t)}},ft=1,Vt=4});function Ve(r){if(r==null)return _e;let{type:e,id:t,...n}=r;return{type:e??"system",id:t??"",...n}}var _e,ze=z(()=>{"use strict";_e={type:"system",id:""}});function Bt(r){r.registerMessageType(ve,{tier:0,wireCrossing:!1}),r.registerMessageType(U,{tier:1,wireCrossing:!1}),r.registerMessageType(X,{tier:1,wireCrossing:!1,metaPassthrough:!1}),r.registerMessageType(Q,{tier:2,wireCrossing:!1}),r.registerMessageType(re,{tier:2,wireCrossing:!1}),r.registerMessageType(C,{tier:3,wireCrossing:!0}),r.registerMessageType(W,{tier:3,wireCrossing:!0}),r.registerMessageType(V,{tier:4,wireCrossing:!0,metaPassthrough:!1}),r.registerMessageType($,{tier:4,wireCrossing:!0,metaPassthrough:!1}),r.registerMessageType(F,{tier:5,wireCrossing:!0,metaPassthrough:!1})}var je,Ut=z(()=>{"use strict";ie();je=class{_messageTypes=new Map;_codecs=new Map;_onMessage;_onSubscribe;_defaultVersioning;_defaultHashFn;_inspectorEnabled=!(typeof process<"u"&&process.env?.NODE_ENV==="production");_globalInspector;_rigorRecorder;_frozen=!1;tierOf;constructor(e){this._onMessage=e.onMessage,this._onSubscribe=e.onSubscribe,this._defaultVersioning=e.defaultVersioning,this._defaultHashFn=e.defaultHashFn,this.tierOf=t=>{let n=this._messageTypes.get(t);return n!=null?n.tier:1}}get onMessage(){return this._frozen=!0,this._onMessage}get onSubscribe(){return this._frozen=!0,this._onSubscribe}set onMessage(e){this._assertUnfrozen(),this._onMessage=e}set onSubscribe(e){this._assertUnfrozen(),this._onSubscribe=e}get defaultVersioning(){return this._defaultVersioning}set defaultVersioning(e){this._assertUnfrozen(),this._defaultVersioning=e}get defaultHashFn(){return this._defaultHashFn}set defaultHashFn(e){this._assertUnfrozen(),this._defaultHashFn=e}get inspectorEnabled(){return this._inspectorEnabled}set inspectorEnabled(e){this._inspectorEnabled=e}get globalInspector(){return this._globalInspector}set globalInspector(e){this._globalInspector=e}get rigorRecorder(){return this._rigorRecorder}set rigorRecorder(e){this._rigorRecorder=e}registerMessageType(e,t){return this._assertUnfrozen(),this._messageTypes.set(e,{tier:t.tier,wireCrossing:t.wireCrossing??t.tier>=3,metaPassthrough:t.metaPassthrough??!0}),this}messageTier(e){let t=this._messageTypes.get(e);return t!=null?t.tier:1}isWireCrossing(e){let t=this._messageTypes.get(e);return t!=null?t.wireCrossing:!0}isLocalOnly(e){return!this.isWireCrossing(e)}isMetaPassthrough(e){let t=this._messageTypes.get(e);return t!=null?t.metaPassthrough:!0}isKnownMessageType(e){return this._messageTypes.has(e)}registerCodec(e){return this._assertUnfrozen(),this._codecs.set(e.name,e),this}lookupCodec(e){return this._codecs.get(e)}_isFrozen(){return this._frozen}_assertUnfrozen(){if(this._frozen)throw new Error("GraphReFlyConfig is frozen: a node has already captured this config. Register custom types and set hooks before creating any node.")}}});function ht(r){if(r===void 0)return null;if(typeof r=="number"){if(!Number.isFinite(r))throw new TypeError(`Cannot hash non-finite number: ${r}`);if(Number.isInteger(r)&&!Number.isSafeInteger(r))throw new TypeError(`Cannot hash integer outside safe range (|n| > 2^53-1): ${r}. Cross-language cid parity is not guaranteed for unsafe integers.`);return r}if(typeof r=="string"||typeof r=="boolean"||r===null)return r;if(Array.isArray(r))return r.map(ht);if(typeof r=="object"&&r!==null){let e={};for(let t of Object.keys(r).sort())e[t]=ht(r[t]);return e}return null}function Pn(r){let e=Mn.encode(r),t=e.length,n=t*8,s=t+9+63&-64,o=new Uint8Array(s);o.set(e),o[t]=128;let i=new DataView(o.buffer);i.setUint32(s-4,n>>>0,!1),i.setUint32(s-8,Math.floor(n/4294967296)>>>0,!1);let a=1779033703,u=3144134277,d=1013904242,l=2773480762,h=1359893119,p=2600822924,g=528734635,c=1541459225,_=new Uint32Array(64),f=(v,b)=>v>>>b|v<<32-b;for(let v=0;v<s;v+=64){for(let N=0;N<16;N++)_[N]=i.getUint32(v+N*4,!1);for(let N=16;N<64;N++){let S=_[N-15],D=_[N-2],R=f(S,7)^f(S,18)^S>>>3,se=f(D,17)^f(D,19)^D>>>10;_[N]=_[N-16]+R+_[N-7]+se>>>0}let b=a,y=u,w=d,k=l,m=h,O=p,x=g,A=c;for(let N=0;N<64;N++){let S=f(m,6)^f(m,11)^f(m,25),D=m&O^~m&x,R=A+S+D+Gn[N]+_[N]>>>0,se=f(b,2)^f(b,13)^f(b,22),ne=b&y^b&w^y&w,Ce=se+ne>>>0;A=x,x=O,O=m,m=k+R>>>0,k=w,w=y,y=b,b=R+Ce>>>0}a=a+b>>>0,u=u+y>>>0,d=d+w>>>0,l=l+k>>>0,h=h+m>>>0,p=p+O>>>0,g=g+x>>>0,c=c+A>>>0}let T=v=>v.toString(16).padStart(8,"0");return T(a)+T(u)+T(d)+T(l)+T(h)+T(p)+T(g)+T(c)}function Ae(r){let e=ht(r??null),t=JSON.stringify(e);return Pn(t).slice(0,16)}function $n(){let r=globalThis.crypto;if(r?.randomUUID)return r.randomUUID();let e=()=>Math.floor(Math.random()*4294967296).toString(16).padStart(8,"0"),t=e()+e()+e()+e();return`${t.slice(0,8)}-${t.slice(8,12)}-4${t.slice(13,16)}-${(parseInt(t.slice(16,17),16)&3|8).toString(16)}${t.slice(17,20)}-${t.slice(20,32)}`}function gt(r,e,t){let n=t?.id??$n();if(r===0)return{id:n,version:0};let o=(t?.hash??Ae)(e);return{id:n,version:0,cid:o,prev:null}}function Wt(r,e,t){r.version+=1,"cid"in r&&(r.prev=r.cid,r.cid=t(e))}var Gn,Mn,mt=z(()=>{"use strict";Gn=new Uint32Array([1116352408,1899447441,3049323471,3921009573,961987163,1508970993,2453635748,2870763221,3624381080,310598401,607225278,1426881987,1925078388,2162078206,2614888103,3248222580,3835390401,4022224774,264347078,604807628,770255983,1249150122,1555081692,1996064986,2554220882,2821834349,2952996808,3210313671,3336571891,3584528711,113926993,338241895,666307205,773529912,1294757372,1396182291,1695183700,1986661051,2177026350,2456956037,2730485921,2820302411,3259730800,3345764771,3516065817,3600352804,4094571909,275423344,430227734,506948616,659060556,883997877,958139571,1322822218,1537002063,1747873779,1955562222,2024104815,2227730452,2361852424,2428436474,2756734187,3204031479,3329325298]),Mn=new TextEncoder});function Yt(r){return{node:r,unsub:null,prevData:void 0,dirty:!1,involvedThisWave:!1,dataBatch:[],terminal:void 0}}function bt(r){r.prevData=void 0,r.dirty=!1,r.involvedThisWave=!1,r.dataBatch.length=0,r.terminal=void 0}function He(r){return r.length===0?r:typeof r[0]=="symbol"?[r]:r}function Te(r,e,t){let n=Jt(r)?r:[],s=typeof r=="function"?r:typeof e=="function"?e:void 0,o={};return Jt(r)?o=(yt(e)?e:t)??{}:yt(r)?o=r:o=(yt(e)?e:t)??{},new I(n,s,o)}var Kt,qt,In,Ln,we,I,Jt,yt,fe=z(()=>{"use strict";pt();ze();xe();Ee();Ut();ye();ie();mt();Kt=()=>{},qt=100;In=(r,e,t,n)=>{t.direction==="down-in"&&r._onDepMessage(t.depIndex,e)},Ln=(r,e,t,n)=>{let s=r;if(s._status==="completed"||s._status==="errored")return;let o=s._cached,i=o===void 0?[Ie]:[Ie,[C,o]];s._status==="dirty"&&i.push(le),Pe(e,i,s._config.tierOf)},we=new je({onMessage:In,onSubscribe:Ln});Bt(we);Ht(we);I=class r{_optsName;_describeKind;meta;_hasMeta;_config;_deps;_sinks=null;_sinkCount=0;_cached;_status;_cleanup;_store={};_waveHasNewData=!1;_hasNewTerminal=!1;_hasCalledFnOnce=!1;_paused=!1;_pendingWave=!1;_isExecutingFn=!1;_pendingRerun=!1;_rerunDepth=0;_dirtyDepCount=0;_batchPendingMessages=null;_pauseLocks=null;_pauseBuffer=null;_fn;_equals;_resubscribable;_resetOnTeardown;_autoComplete;_autoError;_pausable;_partial;_guard;_extraGuards;_hashFn;_versioning;_versioningLevel;_lastMutation;_inspectorHooks;_actions;constructor(e,t,n){this._config=n.config??we,this._config.onMessage,this._optsName=n.name,this._describeKind=n.describeKind,this._equals=n.equals??Object.is,this._resubscribable=n.resubscribable??!1,this._resetOnTeardown=n.resetOnTeardown??!1,this._autoComplete=n.completeWhenDepsComplete??!0,this._autoError=n.errorWhenDepsError??!0,this._pausable=n.pausable??!0,this._guard=n.guard,this._fn=t,this._partial=n.partial??!1,this._cached=n.initial!==void 0?n.initial:void 0,this._status=e.length===0&&t==null&&this._cached!==void 0?"settled":"sentinel",this._hashFn=n.versioningHash??this._config.defaultHashFn??Ae;let s=n.versioning??this._config.defaultVersioning;this._versioningLevel=s,this._versioning=s!=null?gt(s,this._cached===void 0?void 0:this._cached,{id:n.versioningId,hash:this._hashFn}):void 0,this._deps=e.map(Yt);let o={};for(let[a,u]of Object.entries(n.meta??{})){let d={initial:u,name:`${n.name??"node"}:meta:${a}`,describeKind:"state",config:this._config};n.guard!=null&&(d.guard=n.guard),o[a]=new r([],void 0,d)}Object.freeze(o),this.meta=o,this._hasMeta=Object.keys(o).length>0;let i=this;this._actions={emit(a){i._emit([[C,a]])},down(a){i._emit(He(a))},up(a){i._emitUp(He(a))}},this.down=this.down.bind(this),this.up=this.up.bind(this)}get _isTerminal(){return this._status==="completed"||this._status==="errored"}get name(){return this._optsName}get status(){return this._status}get cache(){return this._cached===void 0?void 0:this._cached}get lastMutation(){return this._lastMutation}get v(){return this._versioning}hasGuard(){return this._guard!=null}_applyVersioning(e,t){if(this._isExecutingFn)throw new Error(`Node "${this.name}": _applyVersioning cannot run mid-fn \u2014 call it outside of \`_execFn\` (typically at graph setup time before the first subscribe).`);let n=this._versioningLevel;if(n!=null&&e<=n)return;let s=t?.hash??this._hashFn;s!==this._hashFn&&(this._hashFn=s);let o=this._cached===void 0?void 0:this._cached,i=this._versioning,a=i?.id??t?.id,u=i?.version??0,d=gt(e,o,{id:a,hash:s});d.version=u,this._versioning=d,this._versioningLevel=e}_setInspectorHook(e){return e==null?()=>{}:(this._inspectorHooks==null&&(this._inspectorHooks=new Set),this._inspectorHooks.add(e),()=>{this._inspectorHooks?.delete(e),this._inspectorHooks?.size===0&&(this._inspectorHooks=void 0)})}_pushGuard(e){return this._extraGuards==null&&(this._extraGuards=new Set),this._extraGuards.add(e),()=>{this._extraGuards?.delete(e),this._extraGuards?.size===0&&(this._extraGuards=void 0)}}allowsObserve(e){if(this._guard==null&&this._extraGuards==null)return!0;let t=Ve(e);if(this._guard!=null&&!this._guard(t,"observe"))return!1;if(this._extraGuards!=null){for(let n of this._extraGuards)if(!n(t,"observe"))return!1}return!0}_checkGuard(e){if(e?.internal)return;let t=this._guard!=null||this._extraGuards!=null,n=e?.actor!=null;if(!t&&!n)return;let s=Ve(e?.actor),o=e?.delivery==="signal"?"signal":"write";if(this._guard!=null&&!this._guard(s,o))throw new J({actor:s,action:o,nodeName:this.name});if(this._extraGuards!=null){for(let i of this._extraGuards)if(!i(s,o))throw new J({actor:s,action:o,nodeName:this.name})}this._lastMutation={actor:s,timestamp_ns:oe()}}down(e,t){let n=He(e);n.length!==0&&(this._checkGuard(t),this._emit(n))}emit(e,t){this._checkGuard(t),this._emit([[C,e]])}up(e,t){if(this._deps.length===0)return;let n=He(e);if(n.length===0)return;this._checkGuard(t);let s=t??{internal:!0};this._validateUpTiers(n);for(let o of this._deps)o.node.up?.(n,s)}_emitUp(e){if(this._deps.length!==0&&e.length!==0){this._validateUpTiers(e);for(let t of this._deps)t.node.up?.(e,{internal:!0})}}_validateUpTiers(e){let t=this._config.tierOf;for(let n of e){let s=t(n[0]);if(s===3||s===4)throw new Error(`Node "${this.name}": tier-${s} messages cannot flow up \u2014 DATA/RESOLVED/COMPLETE/ERROR are downstream-only. Use \`down(...)\` for value delivery; \`up(...)\` is for control signals (DIRTY, INVALIDATE, PAUSE, RESUME, TEARDOWN).`)}}subscribe(e,t){if(t!=null&&this._guard!=null){let u=Ve(t);if(!this._guard(u,"observe"))throw new J({actor:u,action:"observe",nodeName:this.name})}let s=this._isTerminal&&this._resubscribable;if(s){this._cached=void 0,this._status="sentinel",this._store={},this._hasCalledFnOnce=!1,this._waveHasNewData=!1,this._hasNewTerminal=!1,this._paused=!1,this._pendingWave=!1,this._pendingRerun=!1,this._isExecutingFn=!1,this._rerunDepth=0,this._dirtyDepCount=0,this._pauseLocks=null,this._pauseBuffer=null;for(let u of this._deps)bt(u);if(this._partial===!1){for(let u of this._deps)if(u.prevData!==void 0||u.dataBatch.length!==0||u.terminal!==void 0||u.dirty)throw new Error(`resubscribable-reset invariant: DepRecord not fully reset for node ${this._optsName??"(anonymous)"}`)}}this._sinkCount+=1;let o;try{o=this._config.onSubscribe(this,e,{sinkCount:this._sinkCount,afterTerminalReset:s},this._actions)}catch(u){throw this._sinkCount-=1,u}this._sinks==null?this._sinks=e:typeof this._sinks=="function"?this._sinks=new Set([this._sinks,e]):this._sinks.add(e);let i=this._isTerminal;if(this._sinkCount===1&&!i)try{this._activate()}catch(u){if(this._sinkCount-=1,this._removeSink(e),this._sinkCount===0&&(this._status="sentinel"),typeof o=="function")try{o()}catch{}throw u}this._status==="sentinel"&&this._cached===void 0&&(this._status="pending");let a=!1;return()=>{a||(a=!0,this._sinkCount-=1,this._removeSink(e),typeof o=="function"&&o(),this._sinks==null&&this._deactivate())}}_removeSink(e){if(this._sinks===e)this._sinks=null;else if(this._sinks!=null&&typeof this._sinks!="function")if(this._sinks.delete(e),this._sinks.size===1){let[t]=this._sinks;this._sinks=t}else this._sinks.size===0&&(this._sinks=null)}_activate(){if(this._deps.length===0){this._fn&&this._execFn();return}this._dirtyDepCount=0;let e=this._deps.length,t=0;try{for(let n=0;n<e;n++){let s=n,o=this._deps[n];o.unsub=Kt,o.unsub=o.node.subscribe(i=>{if(o.unsub===null)return;let a=this._config.tierOf,u=!1;for(let d of i)a(d[0])>=3&&(u=!0),this._config.onMessage(this,d,{direction:"down-in",depIndex:s},this._actions);u&&this._maybeRunFnOnSettlement()}),t++}}catch(n){this._deps[t].unsub=null;for(let s=0;s<t;s++){let o=this._deps[s];if(o.unsub!=null){let i=o.unsub;o.unsub=null;try{i()}catch{}bt(o)}}throw this._dirtyDepCount=0,n}}_addDep(e){for(let s=0;s<this._deps.length;s++)if(this._deps[s].node===e)return s;let t=this._deps.length,n=Yt(e);if(this._deps.push(n),this._sinks==null)return t;n.dirty=!0,this._dirtyDepCount++,this._status!=="dirty"&&this._emit(Le),n.unsub=Kt;try{n.unsub=e.subscribe(s=>{if(n.unsub===null)return;let o=this._config.tierOf,i=!1;for(let a of s)o(a[0])>=3&&(i=!0),this._config.onMessage(this,a,{direction:"down-in",depIndex:t},this._actions);i&&this._maybeRunFnOnSettlement()})}catch(s){throw n.unsub=null,this._deps.pop(),this._dirtyDepCount--,s}return t}_deactivate(e=!1){let t=this._cleanup;if(this._cleanup=void 0,typeof t=="function")try{t()}catch(n){this._emit([[$,this._wrapFnError("cleanup threw",n)]])}else if(t!=null&&typeof t=="object"){let n=t.deactivate;if(typeof n=="function")try{n()}catch(s){this._emit([[$,this._wrapFnError("cleanup.deactivate threw",s)]])}}for(let n of this._deps){if(n.unsub!=null){let s=n.unsub;n.unsub=null;try{s()}catch{}}bt(n)}this._waveHasNewData=!1,this._hasNewTerminal=!1,this._hasCalledFnOnce=!1,this._paused=!1,this._pendingWave=!1,this._pendingRerun=!1,this._rerunDepth=0,this._store={},this._dirtyDepCount=0,this._pauseLocks=null,this._pauseBuffer=null,this._fn!=null&&(this._cached=void 0),e||(this._fn!=null||this._deps.length>0)&&(!this._isTerminal||this._resubscribable)&&(this._status="sentinel")}_onDepMessage(e,t){let n=this._deps[e],s=t[0];if(this._inspectorHooks!=null){let o={kind:"dep_message",depIndex:e,message:t};for(let i of this._inspectorHooks)i(o)}if(s!==ve){if(s===U){this._depDirtied(n);return}if(s===X){if(this._depInvalidated(n),this._cached===void 0)return;this._emit(ct);return}if(s===Q||s===re){this._emit([t]);return}if(s===F){this._emit(Fe);return}if(s===C)this._depSettledAsData(n,t[1]);else if(s===W)this._depSettledAsResolved(n);else if(s===V)this._depSettledAsTerminal(n,!0);else if(s===$)this._depSettledAsTerminal(n,t[1]);else{this._emit([t]);return}if(!this._fn){(s===C||s===W)&&this._emit([t]),(s===V||s===$)&&this._maybeAutoTerminalAfterWave();return}}}_depDirtied(e){e.dirty||(e.dirty=!0,e.involvedThisWave=!0,this._dirtyDepCount++,this._status!=="dirty"&&this._emit(Le))}_depSettledAsData(e,t){e.dirty&&(e.dirty=!1,this._dirtyDepCount--),e.involvedThisWave=!0,e.dataBatch.push(t),this._waveHasNewData=!0}_depSettledAsResolved(e){e.dirty&&(e.dirty=!1,this._dirtyDepCount--)}_depSettledAsTerminal(e,t){e.dirty&&(e.dirty=!1,this._dirtyDepCount--),e.terminal=t,e.involvedThisWave=!0,this._hasNewTerminal=!0}_depInvalidated(e){e.prevData=void 0,e.terminal=void 0,e.dataBatch.length=0,e.dirty?e.involvedThisWave=!1:(e.dirty=!0,e.involvedThisWave=!0,this._dirtyDepCount++)}_maybeRunFnOnSettlement(){if(!(this._isTerminal&&!this._resubscribable)&&!(this._dirtyDepCount>0)){if(!this._partial&&!this._hasCalledFnOnce)for(let e=0;e<this._deps.length;e++){let t=this._deps[e];if(t.dataBatch.length===0&&t.prevData===void 0&&t.terminal===void 0){this._maybeAutoTerminalAfterWave();return}}if(this._paused){this._pendingWave=!0;return}if(!this._waveHasNewData&&!this._hasNewTerminal&&this._hasCalledFnOnce){this._clearWaveFlags(),this._emit(dt),this._maybeAutoTerminalAfterWave();return}this._fn&&this._execFn(),this._maybeAutoTerminalAfterWave()}}_maybeAutoTerminalAfterWave(){if(this._deps.length===0||this._isTerminal)return;let e=this._deps.find(t=>t.terminal!==void 0&&t.terminal!==!0);if(e!=null){this._autoError&&this._emit([[$,e.terminal]]);return}this._autoComplete&&this._deps.every(t=>t.terminal!==void 0)&&this._emit(lt)}_execFn(){if(!this._fn||this._isTerminal&&!this._resubscribable)return;if(this._isExecutingFn){this._pendingRerun=!0;return}let e=this._cleanup;if(typeof e=="function"){this._cleanup=void 0;try{e()}catch(i){this._emit([[$,this._wrapFnError("cleanup threw",i)]]);return}}else if(e!=null&&typeof e=="object"){let i=e.beforeRun;if(typeof i=="function"){e.beforeRun=void 0;try{i()}catch(a){this._emit([[$,this._wrapFnError("cleanup.beforeRun threw",a)]]);return}}}let t=this._deps.map(i=>i.involvedThisWave?i.dataBatch.length>0?[...i.dataBatch]:[]:void 0),n=this._deps.map(i=>i.prevData);for(let i=0;i<this._deps.length;i++){let a=t[i];a!=null&&a.length>0&&(this._deps[i].prevData=a[a.length-1])}let s=this._deps.map(i=>i.terminal),o={prevData:n,terminalDeps:s,store:this._store};if(this._hasCalledFnOnce=!0,this._clearWaveFlags(),this._inspectorHooks!=null){let i={kind:"run",batchData:t,prevData:n};for(let a of this._inspectorHooks)a(i)}this._isExecutingFn=!0;try{let i=this._fn(t,this._actions,o);if(typeof i=="function")this._cleanup=i;else if(i!=null&&typeof i=="object"){let a=i;(typeof a.beforeRun=="function"||typeof a.deactivate=="function"||typeof a.invalidate=="function")&&(this._cleanup=i)}}catch(i){this._emit([[$,this._wrapFnError("fn threw",i)]])}finally{this._isExecutingFn=!1,this._pendingRerun?(this._pendingRerun=!1,this._rerunDepth+=1,this._rerunDepth>qt?(this._rerunDepth=0,this._emit([[$,new Error(`Node "${this.name}": _pendingRerun depth exceeded ${qt} \u2014 likely a reactive cycle`)]])):this._maybeRunFnOnSettlement()):this._rerunDepth=0,this._clearWaveFlags()}}_clearWaveFlags(){this._waveHasNewData=!1,this._hasNewTerminal=!1;for(let e of this._deps)e.involvedThisWave=!1,e.dataBatch.length=0}_wrapFnError(e,t){let n=t instanceof Error?t.message:String(t);return new Error(`Node "${this.name}": ${e}: ${n}`,{cause:t})}_frameBatch(e){let t=this._config.tierOf;if(e.length===1)return t(e[0][0])===3&&this._status!=="dirty"?[le,e[0]]:e;let n=!0,s=!1,o=!1,i=-1;for(let u of e){let d=t(u[0]);d<i&&(n=!1),d===3&&(s=!0),u[0]===U&&(o=!0),i=d}let a=e;if(!n){let u=e.map((d,l)=>({m:d,i:l,tier:t(d[0])}));u.sort((d,l)=>d.tier-l.tier||d.i-l.i),a=u.map(d=>d.m)}if(s&&!o&&this._status!=="dirty"){let u=0;for(;u<a.length&&t(a[u][0])===0;)u++;return u===0?[le,...a]:[...a.slice(0,u),le,...a.slice(u)]}return a}_emit(e){if(e.length===0)return;for(let a=0;a<e.length;a++){let u=e[a];if(u[0]===$&&u[1]===void 0)throw new TypeError('[ERROR, payload] requires a non-undefined payload (spec \xA71.2). Pass an Error object or domain tag instead \u2014 e.g. node.down([[ERROR, new Error("reason")]])')}let t=e;if(this._isTerminal&&!this._resubscribable){let a=e.filter(u=>u[0]===F||u[0]===X);if(a.length===0)return;t=a}t=this._frameBatch(t);let s=null;for(let a=0;a<t.length;a++){let u=t[a],d=u[0];if(d!==Q&&d!==re){s?.push(u);continue}if(u.length<2)throw new Error(`Node "${this.name}": [[${d===Q?"PAUSE":"RESUME"}]] must carry a lockId payload \u2014 bare PAUSE/RESUME is a protocol violation (C0 rule). Use \`[[PAUSE, lockId]]\` / \`[[RESUME, lockId]]\`.`);let l=!0;if(this._pausable!==!1){let h=u[1];if(d===Q)this._pauseLocks==null&&(this._pauseLocks=new Set),this._pauseLocks.add(h),this._paused=!0,this._pausable==="resumeAll"&&this._pauseBuffer==null&&(this._pauseBuffer=[]);else if(this._pauseLocks==null||!this._pauseLocks.has(h))l=!1;else if(this._pauseLocks.delete(h),this._pauseLocks.size===0){if(this._paused=!1,this._pauseBuffer!=null&&this._pauseBuffer.length>0){let p=this._pauseBuffer;this._pauseBuffer=[],this._emit(p)}this._pendingWave&&(this._pendingWave=!1,this._maybeRunFnOnSettlement())}}l?s?.push(u):s==null&&(s=t.slice(0,a))}if(s!=null){if(s.length===0)return;t=s}if(this._hasMeta&&t.some(a=>a[0]===F))for(let a of Object.keys(this.meta))try{this.meta[a]._emit(Fe)}catch{}let{finalMessages:o,equalsError:i}=this._updateState(t);if(o.length>0&&this._config.inspectorEnabled){let a=this._config.globalInspector;if(a!=null)try{a({kind:"emit",node:this,messages:o})}catch{}}if(o.length>0)if(this._paused&&this._pausable==="resumeAll"&&this._pauseBuffer!=null){let a=this._config.tierOf,u=[];for(let d of o)a(d[0])===3?this._pauseBuffer.push(d):u.push(d);u.length>0&&this._dispatchOrAccumulate(u)}else this._dispatchOrAccumulate(o);i!=null&&this._emit([[$,i]])}_updateState(e){let t=this._config.tierOf,n,s,o=-1,i=0;for(let l of e)t(l[0])===3&&i++;let a=i<=1,u=-1;if(this._versioning!=null&&i>1){for(let l=e.length-1;l>=0;l--)if(e[l][0]===C){u=l;break}}for(let l=0;l<e.length;l++){let h=e[l],p=h[0];if(p===C){if(h.length>=2){let g=!1;if(a&&this._cached!==void 0)try{g=this._equals(this._cached,h[1])}catch(c){s=this._wrapFnError("equals threw",c),o=l;break}if(g){n==null&&(n=e.slice(0,l)),n.push($e),this._status="resolved";continue}this._cached=h[1],this._versioning!=null&&(u<0||l===u)&&Wt(this._versioning,h[1],this._hashFn)}this._status="settled",n?.push(h)}else if(n?.push(h),p===U)this._status="dirty";else if(p===W)this._status="resolved";else if(p===V){this._status="completed";{let g=this._config.rigorRecorder;if(g!=null)try{g.onTerminalTransition(this,"completed",this._autoComplete,this._autoError,this._deps.length>0)}catch{}}}else if(p===$){this._status="errored";{let g=this._config.rigorRecorder;if(g!=null)try{g.onTerminalTransition(this,"errored",this._autoComplete,this._autoError,this._deps.length>0)}catch{}}}else if(p===X){if(this._cached!==void 0){let c=this._config.rigorRecorder;if(c!=null)try{c.onNonVacuousInvalidate(this,this._cached)}catch{}}this._cached=void 0,this._status="dirty";let g=this._cleanup;if(typeof g=="function"){this._cleanup=void 0;try{g()}catch{}}else if(g!=null&&typeof g=="object"){let c=g.invalidate;if(typeof c=="function")try{c()}catch{}}}else p===F&&(this._resetOnTeardown&&(this._cached=void 0),this._deactivate(!0),this._status="sentinel")}let d=o>=0?n??e.slice(0,o):n??e;return s!=null?{finalMessages:d,equalsError:s}:{finalMessages:d}}_deliverToSinks=e=>{if(this._sinks==null)return;if(typeof this._sinks=="function"){this._sinks(e);return}let t=[...this._sinks];for(let n of t)n(e)};_dispatchOrAccumulate(e){if(Pt()){this._batchPendingMessages===null&&(this._batchPendingMessages=[],be(()=>this._flushBatchPending()));for(let t of e)this._batchPendingMessages.push(t);return}Pe(this._deliverToSinks,e,this._config.tierOf)}_flushBatchPending(){let e=this._batchPendingMessages;if(e===null||(this._batchPendingMessages=null,e.length===0))return;let t=this._frameBatch(e);Pe(this._deliverToSinks,t,this._config.tierOf)}},Jt=r=>Array.isArray(r),yt=r=>typeof r=="object"&&r!=null&&!Array.isArray(r)});function _t(r,e){if(e!=null&&e.length>0)return new Set(e);switch(r){case"standard":return new Set(["type","status","value","deps","meta","v"]);case"full":return null;case"spec":return new Set(["type","deps","meta","value"]);default:return new Set(["type","deps"])}}function Fn(r){return r._describeKind!=null?r._describeKind:r._deps.length>0?"derived":r._fn!=null?"producer":"state"}function Xt(r){let e=new WeakSet,t={};for(let[n,s]of Zt(r))t[n]=vt(s,e);return t}function vt(r,e){if(r==null)return r;let t=typeof r;if(t==="boolean"||t==="number"||t==="string")return r;if(t==="function")return"<function>";if(Array.isArray(r))return e.has(r)?"<cycle>":(e.add(r),r.map(n=>vt(n,e)));if(t==="object"){let n=r;if(e.has(n))return"<cycle>";e.add(n);try{if(typeof n.subscribe=="function"&&"cache"in n)return"<Node>"}catch{return"<unserializable>"}let s={};for(let[o,i]of Zt(n))s[o]=vt(i,e);return s}return"<unserializable>"}function Zt(r){let e=[],t;try{t=Object.keys(r)}catch{return e}for(let n of t)try{e.push([n,r[n]])}catch{e.push([n,"<unserializable>"])}return e}function Vn(r){let e={};for(let[t,n]of Object.entries(r.meta))try{e[t]=n.cache}catch{}return e}function wt(r,e,t){let n=e==null,s=!n&&e!=null?[...e].filter(l=>l.startsWith("meta.")).map(l=>l.slice(5)):null,o=n||e.has("meta")||s!=null&&s.length>0,i="state",a=[];r instanceof I&&(i=Fn(r),a=r._deps.map(l=>l.node.name??""));let u={type:i,deps:a};(n||e.has("status"))&&(u.status=r.status);let d=r instanceof I?r._guard:void 0;if(o){let l={...Vn(r)};if(d!=null&&l.access===void 0&&(l.access=ut(d)),s!=null&&s.length>0&&!e.has("meta")){let h={};for(let p of s)p in l&&(h[p]=l[p]);u.meta=h}else u.meta=l}if(r.name!=null&&(u.name=r.name),(n||e.has("value"))&&(!t||i==="state")){r.status==="sentinel"&&(u.sentinel=!0);try{u.value=r.cache}catch{}}if((n||e.has("v"))&&r.v!=null){let l={id:r.v.id,version:r.v.version};"cid"in r.v&&(l.cid=r.v.cid,l.prev=r.v.prev),u.v=l}return(n||e.has("guard"))&&d!=null&&(u.guard=ut(d)),(n||e.has("lastMutation"))&&r.lastMutation!=null&&(u.lastMutation=r.lastMutation),u}var Tt=z(()=>{"use strict";ye();fe()});function ee(r,e){return Te([],{...e,initial:r})}function Be(r,e){return Te((n,s,o)=>r(s,o)??void 0,{describeKind:"producer",...e})}function j(r,e,t){return Te(r,(s,o,i)=>{let a=s.map((u,d)=>u!=null&&u.length>0?u.at(-1):i.prevData[d]);o.emit(e(a,i))},{describeKind:"derived",...t})}var Se=z(()=>{"use strict";fe()});function Ue(r,e,t){return{[r]:!0,[`${r}_type`]:e,...t??{}}}var Ot=z(()=>{"use strict"});function te(r){return r.subscribe(()=>{})}var Qt=z(()=>{"use strict"});var We=z(()=>{"use strict";Qt()});var Xe,an=z(()=>{"use strict";Xe=class{_timer;_gen=0;start(e,t){this.cancel(),this._gen+=1;let n=this._gen;this._timer=setTimeout(()=>{this._timer=void 0,n===this._gen&&t()},e)}cancel(){this._timer!==void 0&&(clearTimeout(this._timer),this._timer=void 0)}get pending(){return this._timer!==void 0}}});var De,un=z(()=>{"use strict";De=class{constructor(e){this.capacity=e;if(!Number.isInteger(e)||e<=0)throw new Error(`RingBuffer capacity must be a positive integer (got ${e})`);this.buf=new Array(e)}buf;head=0;_size=0;get size(){return this._size}get maxSize(){return this.capacity}push(e){let t=(this.head+this._size)%this.capacity;this.buf[t]=e,this._size<this.capacity?this._size++:this.head=(this.head+1)%this.capacity}shift(){if(this._size===0)return;let e=this.buf[this.head];return this.buf[this.head]=void 0,this.head=(this.head+1)%this.capacity,this._size--,e}at(e){if(this._size===0)return;let t=e<0?this._size+e:e;if(!(t<0||t>=this._size))return this.buf[(this.head+t)%this.capacity]}toArray(){let e=new Array(this._size);for(let t=0;t<this._size;t++)e[t]=this.buf[(this.head+t)%this.capacity];return e}clear(){for(let e=0;e<this._size;e++)this.buf[(this.head+e)%this.capacity]=void 0;this.head=0,this._size=0}}});var pr={};kn(pr,{AuditTrailGraph:()=>et,PolicyGateGraph:()=>tt,auditTrail:()=>ar,complianceSnapshot:()=>dr,policyGate:()=>ur});module.exports=En(pr);xe();Ee();ye();ie();Tt();fe();Se();mt();Ot();xe();ie();fe();Se();var Nt=class{_version=0;_maxSize;_buf;_head=0;_size=0;constructor(e,t){if(t!==void 0&&t<1)throw new RangeError("maxSize must be >= 1");if(this._maxSize=t,t!==void 0){if(this._buf=new Array(t),e&&e.length>0){let n=Math.min(e.length,t),s=e.length-n;for(let o=0;o<n;o++)this._buf[o]=e[s+o];this._size=n}}else this._buf=e?[...e]:[],this._size=this._buf.length}get version(){return this._version}get size(){return this._size}at(e){if(!Number.isInteger(e))return;let t=e>=0?e:this._size+e;if(!(t<0||t>=this._size))return this._maxSize!==void 0?this._buf[(this._head+t)%this._maxSize]:this._buf[t]}append(e){this._rawAppend(e),this._version+=1}appendMany(e){if(e.length===0)return;let t=this._maxSize!==void 0&&e.length>this._maxSize?e.length-this._maxSize:0;for(let n=t;n<e.length;n++)this._rawAppend(e[n]);this._version+=1}clear(){if(this._size===0)return 0;let e=this._size;if(this._maxSize===void 0)this._buf.length=0;else for(let t=0;t<e;t++)this._buf[(this._head+t)%this._maxSize]=void 0;return this._head=0,this._size=0,this._version+=1,e}trimHead(e){if(!Number.isInteger(e)||e<0)throw new RangeError(`trimHead: n must be a non-negative integer (got ${e})`);if(e===0||this._size===0)return 0;let t=Math.min(e,this._size);if(this._maxSize===void 0)this._buf.splice(0,t);else{for(let n=0;n<t;n++)this._buf[(this._head+n)%this._maxSize]=void 0;this._head=(this._head+t)%this._maxSize}return this._size-=t,this._version+=1,t}slice(e,t){if(!Number.isInteger(e)||e<0)throw new RangeError(`slice: start must be a non-negative integer (got ${e})`);if(t!==void 0&&(!Number.isInteger(t)||t<0))throw new RangeError(`slice: stop must be a non-negative integer or undefined (got ${t})`);let n=t===void 0?this._size:Math.min(Math.max(t,0),this._size),s=Math.min(e,this._size);if(s>=n)return[];let o=n-s;if(this._maxSize===void 0)return this._buf.slice(s,n);let i=new Array(o);for(let a=0;a<o;a++)i[a]=this._buf[(this._head+s+a)%this._maxSize];return i}tail(e){if(!Number.isInteger(e)||e<0)throw new RangeError(`tail: n must be a non-negative integer (got ${e})`);if(e===0||this._size===0)return[];let t=Math.min(e,this._size);return this.slice(this._size-t,this._size)}toArray(){if(this._maxSize===void 0)return[...this._buf];let e=new Array(this._size);for(let t=0;t<this._size;t++)e[t]=this._buf[(this._head+t)%this._maxSize];return e}snapshot(){return this.toArray()}restore(e){if(this._maxSize===void 0){this._buf.length=0;for(let t=0;t<e.length;t++)this._buf.push(e[t]);this._size=this._buf.length}else{let t=this._maxSize;for(let o=0;o<t;o++)this._buf[o]=void 0;this._head=0;let n=Math.min(e.length,t),s=e.length-n;for(let o=0;o<n;o++)this._buf[o]=e[s+o];this._size=n}this._version+=1}_rawAppend(e){if(this._maxSize===void 0){this._buf.push(e),this._size=this._buf.length;return}this._size<this._maxSize?(this._buf[(this._head+this._size)%this._maxSize]=e,this._size+=1):(this._buf[this._head]=e,this._head=(this._head+1)%this._maxSize)}};function Re(r){return r.subscribe(()=>{})}var zn=64;function Ke(r,e={}){let{name:t,maxSize:n,versioning:s,guard:o,backend:i}=e,a=i??new Nt(r,n),u=ee(a.toArray(),{name:t,describeKind:"state",equals:(m,O)=>m===O,...s!=null?{versioning:s}:{},...o!=null?{guard:o}:{}});function d(){let m=a.toArray();ce(()=>{u.down([[U]],{internal:!0}),u.down([[C,m]],{internal:!0})})}let l=new Map,h=new Map,p=new Map;function g(m,O){return`${m}:${O===void 0?"END":O}`}function c(m){if(m.size<zn)return;let O=m.keys().next();if(O.done)return;let x=m.get(O.value);x!==void 0&&x.dispose(),m.delete(O.value)}function _(m){let O=a.version;try{return m()}finally{a.version!==O&&d()}}function f(m){if(!Number.isInteger(m)||m<0)throw new RangeError(`tail: n must be a non-negative integer (got ${m})`);let O=l.get(m);if(O!==void 0)return l.delete(m),l.set(m,O),O.node;c(l);let x=j([u],([N])=>{let S=N;return m===0||S.length===0?[]:S.slice(Math.max(0,S.length-m))},{initial:a.tail(m),describeKind:"derived"}),A=Re(x);return l.set(m,{node:x,dispose:A}),x}function T(m,O){if(!Number.isInteger(m)||m<0)throw new RangeError(`slice: start must be a non-negative integer (got ${m})`);if(O!==void 0&&(!Number.isInteger(O)||O<0))throw new RangeError(`slice: stop must be a non-negative integer or undefined (got ${O})`);let x=g(m,O),A=h.get(x);if(A!==void 0)return h.delete(x),h.set(x,A),A.node;c(h);let N=j([u],([D])=>{let R=D;return O===void 0?R.slice(m):R.slice(m,O)},{initial:a.slice(m,O),describeKind:"derived"}),S=Re(N);return h.set(x,{node:N,dispose:S}),N}function v(m){let O=p.get(m);if(O!==void 0)return O.node;let x=j([u,m],([N,S])=>{let D=N,R=Math.max(0,Math.trunc(S??0));return D.slice(R)},{initial:[],describeKind:"derived"}),A=Re(x);return p.set(m,{node:x,dispose:A}),x}let b,y;function w(){b===void 0&&(b=Te([u],(m,O,x)=>{let A=m[0],S=A!=null&&A.length>0?A.at(-1):x.prevData[0];if(S==null||S.length===0){O.down([[W]]);return}O.emit(S[S.length-1])},{name:t!=null?`${t}::lastValue`:"lastValue",describeKind:"derived",initial:a.size===0?void 0:a.at(a.size-1)}),y=j([u],([m])=>m.length>0,{name:t!=null?`${t}::hasLatest`:"hasLatest",describeKind:"derived",initial:a.size>0}),Re(b),Re(y))}let k={entries:u,get size(){return a.size},at(m){return a.at(m)},append(m){_(()=>a.append(m))},appendMany(m){m.length!==0&&_(()=>a.appendMany(m))},clear(){_(()=>a.clear())},trimHead(m){_(()=>a.trimHead(m))},withLatest(){return w(),u},get lastValue(){return w(),b},get hasLatest(){return w(),y},view(m){switch(m.kind){case"tail":return f(m.n);case"slice":return T(m.start,m.stop);case"fromCursor":return v(m.cursor)}},attach(m){let O=m.subscribe(x=>{for(let A of x)A[0]===C&&k.append(A[1])});return()=>O()},attachStorage(m){if(m.length===0)return()=>{};let O=new Map;for(let A of m)O.set(A,a.size);(async()=>{for(let A of m)if(typeof A.loadEntries=="function")try{let N=await Promise.resolve(A.loadEntries());N.entries.length>0&&a.size===0&&(a.restore(N.entries),O.set(A,N.entries.length),d());break}catch{}})();let x=u.subscribe(A=>{for(let N of A){if(N[0]!==C)continue;let S=N[1];for(let D of m){let R=O.get(D)??0;if(S.length<R){try{let ne=D.appendEntries(S);ne instanceof Promise&&ne.catch(()=>{})}catch{}O.set(D,S.length);continue}if(S.length===R)continue;let se=S.slice(R);O.set(D,S.length);try{let ne=D.appendEntries(se);ne instanceof Promise&&ne.catch(()=>{})}catch{}}}});return()=>x()},disposeAllViews(){for(let m of l.values())m.dispose();l.clear();for(let m of h.values())m.dispose();h.clear();for(let m of p.values())m.dispose();p.clear()},dispose(){for(let m of l.values())m.dispose();l.clear();for(let m of h.values())m.dispose();h.clear();for(let m of p.values())m.dispose();p.clear()}};return k}We();var L={object:56,array:64,string:40,number:8,boolean:4,null:0,undefined:0,symbol:40,bigint:16,function:120,map:72,set:72,mapEntry:40,setEntry:24,date:24,regexp:48,error:64,url:80,promise:48,weakmap:40,weakset:40},jn=Symbol.for("sizeof");function en(r){let e=new WeakSet,t=new WeakSet,n=[r],s=0;for(;n.length>0;){let o=n.pop();s+=Hn(o,e,t,n)}return s}function Hn(r,e,t,n){if(r==null)return 0;switch(typeof r){case"number":return L.number;case"boolean":return L.boolean;case"string":return L.string+r.length*2;case"bigint":return L.bigint+Bn(r);case"symbol":return L.symbol;case"function":return e.has(r)?0:(e.add(r),L.function);case"undefined":return 0}let o=r;if(e.has(o))return 0;e.add(o);let i=o[jn];if(typeof i=="function")try{let d=i.call(o);if(typeof d=="number"&&Number.isFinite(d))return d}catch{}if(o instanceof Date)return L.date;if(o instanceof RegExp)return L.regexp+o.source.length*2;if(o instanceof Error){let d=o.message?o.message.length*2:0,l=o.stack?o.stack.length*2:0;return L.error+d+l}if(typeof URL<"u"&&o instanceof URL)return L.url+o.href.length*2;if(typeof Promise<"u"&&o instanceof Promise)return L.promise;if(o instanceof WeakMap)return L.weakmap;if(o instanceof WeakSet)return L.weakset;if(o instanceof Map){let d=L.map;for(let[l,h]of o)d+=L.mapEntry,n.push(l),n.push(h);return d}if(o instanceof Set){let d=L.set;for(let l of o)d+=L.setEntry,n.push(l);return d}if(Array.isArray(o)){let d=L.array+o.length*8;for(let l of o)n.push(l);return d}if(o instanceof ArrayBuffer)return t.has(o)?0:(t.add(o),o.byteLength);if(ArrayBuffer.isView(o)){let d=o;return t.has(d.buffer)?48:(t.add(d.buffer),d.buffer.byteLength+48)}let a=L.object,u=Object.keys(o);for(let d of u){a+=L.string+d.length*2;try{n.push(o[d])}catch{}}return a}function Bn(r){let e=r<0n?-r:r;if(e===0n)return 0;let t=e.toString(2).length;return Math.ceil(t/32)*8}function tn(r,e,t,n={}){let s=e in r.nodes,o=t in r.nodes;if(!s)return qe(e,t,"no-such-from");if(!o)return qe(e,t,"no-such-to");let i=n.maxDepth;if(i!=null&&(!Number.isInteger(i)||i<0))throw new Error("explainPath: maxDepth must be an integer >= 0");if(e===t){if(n.findCycle===!0){let d=Un(r,e,n);if(d!=null)return d}let u=Ye(e,r.nodes[e],0,n);return Je(e,t,[u])}if(i===0)return qe(e,t,"no-path");let a=nn(r,e,t,i);return a.found?Je(e,t,rn(r,a.pathOrder,n)):qe(e,t,a.truncated?"max-depth-exceeded":"no-path")}function nn(r,e,t,n){let s=new Map,o=[{path:t,depth:0}],i=new Set([t]),a=0,u=!1;for(;a<o.length;){let h=o[a++];if(h.path===e)break;if(n!=null&&h.depth>=n){let _=r.nodes[h.path];_?.deps&&_.deps.length>0&&(u=!0);continue}let p=r.nodes[h.path];if(p==null)continue;let g=p.deps??[],c=new Map;for(let _=0;_<g.length;_++){let f=g[_];if(!f)continue;let T=c.get(f);T==null&&(T=[],c.set(f,T)),T.push(_)}for(let[_,f]of c)i.has(_)||(i.add(_),s.set(_,{from:h.path,depIndices:f}),o.push({path:_,depth:h.depth+1}))}if(!s.has(e))return{found:!1,pathOrder:[],truncated:u};let d=[{path:e}],l=e;for(;l!==t;){let h=s.get(l);if(h==null)return{found:!1,pathOrder:[],truncated:!1};d[d.length-1].depIndices=h.depIndices,d.push({path:h.from}),l=h.from}return{found:!0,pathOrder:d,truncated:!1}}function Un(r,e,t){let n=r.nodes[e];if(n==null)return null;let s=n.deps??[],o=[];for(let a=0;a<s.length;a++)s[a]===e&&o.push(a);if(o.length>0){let a=Ye(e,n,0,t);a.dep_index=o[0];let u=Ye(e,n,1,t);return Je(e,e,[a,u])}let i=null;for(let a=0;a<s.length;a++){let u=s[a];if(!u||u===e)continue;let d=nn(r,u,e,t.maxDepth);d.found&&(i==null||d.pathOrder.length<i.pathOrder.length)&&(i=d,i={found:!0,pathOrder:[{path:e,depIndices:[a]},...d.pathOrder],truncated:!1})}return i==null?null:Je(e,e,rn(r,i.pathOrder,t))}function rn(r,e,t){return e.map((n,s)=>{let o=r.nodes[n.path],i=Ye(n.path,o,s,t);return n.depIndices!=null&&n.depIndices.length>0&&(i.dep_index=n.depIndices[0],n.depIndices.length>1&&(i.dep_indices=[...n.depIndices])),i})}function Ye(r,e,t,n){let s={path:r,type:e.type,hop:t};e.status!==void 0&&(s.status=e.status),"value"in e&&(s.value=e.value),e.v!=null&&(s.v=e.v);let o=n.annotations?.get(r)??e.annotation;o!=null&&(s.annotation=o);let i=n.lastMutations?.get(r)??e.lastMutation;return i!=null&&(s.lastMutation=i),s}function Je(r,e,t){return sn(r,e,!0,"ok",t)}function qe(r,e,t){return sn(r,e,!1,t,[])}function sn(r,e,t,n,s){let o=Wn(r,e,t,n,s);return{from:r,to:e,found:t,reason:n,steps:s,text:o,toJSON(){return{from:r,to:e,found:t,reason:n,steps:s}}}}function Wn(r,e,t,n,s){if(!t)switch(n){case"no-such-from":return`explainPath: no node named "${r}"`;case"no-such-to":return`explainPath: no node named "${e}"`;case"max-depth-exceeded":return`explainPath: no path from "${r}" to "${e}" within maxDepth`;default:return`explainPath: no path from "${r}" to "${e}"`}let o=[`Causal path: ${r} \u2192 ${e} (${s.length} step(s))`];for(let i of s){let u=` ${i.hop===0?"\xB7":"\u2193"} ${i.path} (${i.type}${i.status?`/${i.status}`:""})`;if(o.push(u),"value"in i&&o.push(` value: ${Kn(i.value)}`),i.annotation!=null&&o.push(` annotation: ${i.annotation}`),i.lastMutation!=null){let d=i.lastMutation.actor;o.push(` actor: ${d.type}${d.id?`:${d.id}`:""}`)}}return o.join(`
2
+ `)}function Kn(r){if(r===void 0)return"<sentinel>";if(r===null)return"null";if(typeof r=="string")return JSON.stringify(r);if(typeof r=="number"||typeof r=="boolean"||typeof r=="bigint")return String(r);try{let e=JSON.stringify(r);return e.length>80?`${e.slice(0,77)}...`:e}catch{return String(r)}}ze();xe();Ee();ye();ie();Tt();fe();Se();Ee();function kt(r,e){if(Object.is(r,e))return!0;if(r==null||e==null||typeof r!="object"||typeof e!="object")return!1;if(Array.isArray(r)){if(!Array.isArray(e)||r.length!==e.length)return!1;for(let o=0;o<r.length;o++)if(!kt(r[o],e[o]))return!1;return!0}if(Array.isArray(e))return!1;let t=Object.keys(r),n=Object.keys(e);if(t.length!==n.length)return!1;let s=new Set(n);for(let o of t)if(!s.has(o)||!kt(r[o],e[o]))return!1;return!0}function on(r,e){return`${r}\0${e}`}function xt(r,e){let t=[],n=new Set(r.subgraphs),s=new Set(e.subgraphs),o=[];for(let f of s)n.has(f)||o.push(f);o.sort();for(let f of o)t.push({type:"subgraph-mounted",path:f});let i=new Set(Object.keys(r.nodes)),a=new Set(Object.keys(e.nodes)),u=[];for(let f of a)i.has(f)||u.push(f);u.sort();for(let f of u)t.push({type:"node-added",path:f,node:{...e.nodes[f]}});let d=[];for(let f of a){if(!i.has(f))continue;let T=r.nodes[f]?.meta,v=e.nodes[f]?.meta;T==null&&v==null||kt(T??{},v??{})||d.push(f)}d.sort();for(let f of d)t.push({type:"node-meta-changed",path:f,prevMeta:r.nodes[f]?.meta??{},nextMeta:e.nodes[f]?.meta??{}});let l=new Map;for(let f of r.edges)l.set(on(f.from,f.to),f);let h=new Map;for(let f of e.edges)h.set(on(f.from,f.to),f);let p=[];for(let[f,T]of h)l.has(f)||p.push(T);p.sort((f,T)=>f.from<T.from?-1:f.from>T.from?1:f.to<T.to?-1:f.to>T.to?1:0);for(let f of p)t.push({type:"edge-added",from:f.from,to:f.to});let g=[];for(let[f,T]of l)h.has(f)||g.push(T);g.sort((f,T)=>f.from<T.from?-1:f.from>T.from?1:f.to<T.to?-1:f.to>T.to?1:0);for(let f of g)t.push({type:"edge-removed",from:f.from,to:f.to});let c=[];for(let f of i)a.has(f)||c.push(f);c.sort();for(let f of c)t.push({type:"node-removed",path:f});let _=[];for(let f of n)s.has(f)||_.push(f);_.sort();for(let f of _)t.push({type:"subgraph-unmounted",path:f});return{events:t,flushedAt_ns:B()}}We();an();un();pt();fe();function dn(r,e){let t=e?.topN??10,n=r.describe({detail:"standard"}),s=[],o=r._collectObserveTargets;typeof o=="function"&&o.call(r,"",s);let i=new Map;for(let[p,g]of s)i.set(p,g);let a=[];for(let[p,g]of Object.entries(n.nodes)){let c=i.get(p),_=c instanceof I?c:null,f=_?en(_.cache):0,T=_?_._sinkCount:0,v=g.deps?.length??0,b=g.type==="effect"&&T===0,y=T===0?g.type==="effect"?"orphan-effect":g.type==="derived"?"idle-derived":g.type==="producer"?"idle-producer":null:null;a.push({path:p,type:g.type,status:g.status??"unknown",valueSizeBytes:f,subscriberCount:T,depCount:v,isOrphanEffect:b,orphanKind:y})}let u=a.reduce((p,g)=>p+g.valueSizeBytes,0),d=(p,g)=>[...a].sort(g??((c,_)=>_[p]-c[p])).slice(0,t),l=a.filter(p=>p.orphanKind!=null),h=a.filter(p=>p.isOrphanEffect);return{nodeCount:a.length,edgeCount:n.edges.length,subgraphCount:n.subgraphs.length,nodes:a,totalValueSizeBytes:u,hotspots:{byValueSize:d("valueSizeBytes"),bySubscriberCount:d("subscriberCount"),byDepCount:d("depCount")},orphans:l,orphanEffects:h}}var P="::",Z="__meta__",pe=1;function cn(r,e){let t=Math.max(16,r.size*4),n=0;for(;r.size>0;){if(n++>=t){console.error(`[Graph "${e}".destroy] disposer drain exceeded cap (${t}); ${r.size} disposer(s) discarded`),r.clear();return}let s=r.values().next();if(s.done)return;let o=s.value;r.delete(o);try{o()}catch(i){console.error(`[Graph "${e}".destroy] disposer threw:`,i)}}}function gn(r){return r!=null&&typeof r=="object"&&"cache"in r&&typeof r.subscribe=="function"&&typeof r.down=="function"}function qn(r){if(r!=null)return gn(r)?r.cache:r}function he(r){return r!=null&&typeof r=="object"&&"cache"in r&&typeof r.subscribe=="function"&&typeof r.down=="function"}function ae(r){return he(r)?r.cache??"":r}function ln(r){return he(r)?r.cache??0:r}function fn(r){return he(r)?r.cache??!1:r}function Yn(r){let e=[];for(let t of Object.keys(r).sort()){let n=r[t].v;n!=null&&e.push(`${t} ${n.id} ${n.version}`)}return e.join(`
3
+ `)}function pn(r){if(r.version!==pe)throw new Error(`unsupported snapshot version ${String(r.version)} (expected ${pe})`);for(let e of["name","nodes","edges","subgraphs"])if(!(e in r))throw new Error(`snapshot missing required key "${e}"`);if(typeof r.name!="string")throw new TypeError("snapshot 'name' must be a string");if(typeof r.nodes!="object"||r.nodes===null||Array.isArray(r.nodes))throw new TypeError("snapshot 'nodes' must be an object");if(!Array.isArray(r.edges))throw new TypeError("snapshot 'edges' must be an array");if(!Array.isArray(r.subgraphs))throw new TypeError("snapshot 'subgraphs' must be an array")}function Jn(r,e){let t=new WeakMap,n=(s,o)=>{if(Object.is(s,o))return!0;if(s==null||o==null||typeof s!="object"||typeof o!="object")return!1;let i=t.get(s);if(i==null&&(i=new WeakSet,t.set(s,i)),i.has(o))return!0;i.add(o);let a=s.constructor,u=o.constructor;if(a!==u)return!1;if(s instanceof Date)return s.getTime()===o.getTime();if(s instanceof RegExp)return s.source===o.source&&s.flags===o.flags;if(Array.isArray(s)){let p=o;if(s.length!==p.length)return!1;for(let g=0;g<s.length;g++)if(!n(s[g],p[g]))return!1;return!0}if(s instanceof Map){let p=o;if(s.size!==p.size)return!1;for(let[g,c]of s)if(!p.has(g)||!n(c,p.get(g)))return!1;return!0}if(s instanceof Set){let p=o;if(s.size!==p.size)return!1;for(let g of s){let c=!1;for(let _ of p)if(n(g,_)){c=!0;break}if(!c)return!1}return!0}if(ArrayBuffer.isView(s)){let p=s,g=o;if(p.length!==g.length)return!1;for(let c=0;c<p.length;c++)if(p[c]!==g[c])return!1;return!0}let d=Object.keys(s),l=Object.keys(o);if(d.length!==l.length)return!1;let h=new Set(l);for(let p of d)if(!h.has(p)||!n(s[p],o[p]))return!1;return!0};return n(r,e)}function Xn(r){return r.replace(/[.*+?^${}()|[\]\\]/g,"\\$&")}function Ze(r){let e="^";for(let t=0;t<r.length;t+=1){let n=r[t];if(n==="*"){e+=".*";continue}if(n==="?"){e+=".";continue}if(n==="["){let s=r.indexOf("]",t+1);if(s<=t+1){e+="\\[";continue}let o=r.slice(t+1,s);o.startsWith("!")&&(o=`^${o.slice(1)}`),o=o.replace(/\\/g,"\\\\"),e+=`[${o}]`,t=s;continue}e+=Xn(n)}return e+="$",new RegExp(e)}var Zn={data:"\x1B[32m",dirty:"\x1B[33m",resolved:"\x1B[36m",invalidate:"\x1B[93m",pause:"\x1B[90m",resume:"\x1B[96m",complete:"\x1B[34m",error:"\x1B[31m",teardown:"\x1B[91m",derived:"\x1B[35m",path:"\x1B[90m",reset:"\x1B[0m"},Qn={data:"",dirty:"",resolved:"",invalidate:"",pause:"",resume:"",complete:"",error:"",teardown:"",derived:"",path:"",reset:""};function Et(r){if(typeof r=="string")return JSON.stringify(r);if(typeof r=="number"||typeof r=="boolean"||r==null)return String(r);try{return JSON.stringify(r)}catch{return"[unserializable]"}}function er(r){return r==="none"?Qn:r==="ansi"||r==null?Zn:{data:r.data??"",dirty:r.dirty??"",resolved:r.resolved??"",invalidate:r.invalidate??"",pause:r.pause??"",resume:r.resume??"",complete:r.complete??"",error:r.error??"",teardown:r.teardown??"",derived:r.derived??"",path:r.path??"",reset:r.reset??""}}function hn(r){if(r==null)return{};let e=r.detail;return e==="full"?{...r,structured:r.structured??!0,timeline:r.timeline??!0,causal:r.causal??!0,derived:r.derived??!0}:e==="minimal"?{...r,structured:r.structured??!0}:r.format==="stage-log"?{...r,structured:r.structured??!0,timeline:r.timeline??!0}:r}function tr(r,e,t){for(let n=0;n<r.length;n++){let s=r.charCodeAt(n);if(s<32||s===127)throw new Error(`Graph "${e}": ${t} "${r}" must not contain control character (U+${s.toString(16).padStart(4,"0").toUpperCase()} at index ${n})`)}}function At(r,e,t){if(r==="")throw new Error(`Graph "${e}": ${t} name must be non-empty`);if(r.includes(P))throw new Error(`Graph "${e}": ${t} "${r}" must not contain '${P}' (path separator)`);if(r===Z)throw new Error(`Graph "${e}": ${t} name "${Z}" is reserved for meta companion paths`);tr(r,e,t)}function nr(r,e){if(r==="")throw new Error(`Graph "${e}": resolve path must be non-empty`);let t=r.split(P);for(let n of t)if(n==="")throw new Error(`Graph "${e}": resolve path has empty segment`);return t}function rr(r,e){let t=!1;for(let s of r)if(!e.isMetaPassthrough(s[0])){t=!0;break}return t?r.filter(s=>e.isMetaPassthrough(s[0])):r}function mn(r){for(let e of r._mounts.values())mn(e);for(let e of r._nodes.values())try{e.down([[F]],{internal:!0})}catch{}}var K=class r{name;opts;config;_nodes=new Map;_nodeToName=new WeakMap;_mounts=new Map;_parent=void 0;_storageDisposers=new Set;_disposers=new Set;_destroyed=!1;_topology;_topologyEmitters=new Set;_factory;_factoryArgs;constructor(e,t){if(e==="")throw new Error("Graph name must be non-empty");if(e.includes(P))throw new Error(`Graph name must not contain '${P}' (got "${e}")`);if(e===Z)throw new Error(`Graph name "${Z}" is reserved for meta companion paths`);this.name=e,this.opts=Object.freeze({...t??{}}),this.config=t?.config??we,this._traceRing=new De(t?.traceCapacity??1e3),t?.versioning!=null&&this.setVersioning(t.versioning),typeof t?.factory=="string"&&(this._factory=t.factory,t.factoryArgs!==void 0&&(this._factoryArgs=t.factoryArgs))}tagFactory(e,t){return this._factory=e,this._factoryArgs=t,this}ancestors(e=!0){let t=[],n=e?this:this._parent;for(;n!=null;)t.push(n),n=n._parent;return t}get topology(){return this._topology==null&&(this._topology=Be(e=>{let t=n=>{e.emit(n)};return this._topologyEmitters.add(t),()=>{this._topologyEmitters.delete(t)}},{name:`${this.name}_topology`})),this._topology}_emitTopology(e){if(!(this._topology==null||this._topologyEmitters.size===0))for(let t of this._topologyEmitters)t(e)}nameOf(e){return this._nodeToName.get(e)}add(e,t){let n=e.name,s=t?.name??n;if(s==null||s==="")throw new Error(`Graph "${this.name}": graph.add requires a non-empty name \u2014 pass via opts.name or set it on the node (e.g. state(0, { name: "x" }))`);let o=s,i=t?.annotation;if(At(o,this.name,"add"),this._mounts.has(o))throw new Error(`Graph "${this.name}": name "${o}" is already a mount point`);if(this._nodes.has(o))throw new Error(`Graph "${this.name}": node "${o}" already exists`);let a=this._nodeToName.get(e);if(a!==void 0)throw new Error(`Graph "${this.name}": node instance already registered as "${a}"`);return this._nodes.set(o,e),this._nodeToName.set(e,o),this._emitTopology({kind:"added",name:o,nodeKind:"node"}),i!=null&&(this._annotations.set(o,i),this.config.inspectorEnabled&&this._traceRing.push({path:o,annotation:i,timestamp_ns:B()})),e}setVersioning(e){if(e!=null)for(let t of this._nodes.values())t instanceof I&&t._applyVersioning(e)}remove(e){At(e,this.name,"remove");let t=this._mounts.get(e);if(t){let o={kind:"mount",nodes:[],mounts:[]},i=[];t._collectObserveTargets("",i);for(let[a,u]of i)a.includes(`${P}${Z}${P}`)||o.nodes.push(a);return o.nodes.sort(),o.mounts.push(e),o.mounts.push(...t._collectSubgraphs(`${e}${P}`)),this._mounts.delete(e),t._parent=void 0,mn(t),this._emitTopology({kind:"removed",name:e,nodeKind:"mount",audit:o}),o}let n=this._nodes.get(e);if(!n)throw new Error(`Graph "${this.name}": unknown node or mount "${e}"`);this._nodes.delete(e),this._nodeToName.delete(n),n.down([[F]],{internal:!0});let s={kind:"node",nodes:[e],mounts:[]};return this._emitTopology({kind:"removed",name:e,nodeKind:"node",audit:s}),s}removeAll(e){let t=typeof e=="function"?e:(()=>{let o=Ze(e);return i=>o.test(i)})(),n={kind:"mount",nodes:[],mounts:[]},s=[...this._nodes.keys(),...this._mounts.keys()].filter(o=>t(o));for(let o of s){let i=this.remove(o);n.nodes.push(...i.nodes),n.mounts.push(...i.mounts)}return n.nodes.sort(),n.mounts.sort(),n}[Symbol.iterator](){let e=[...this._nodes.keys()].sort(),t=this._nodes,n=0;return{[Symbol.iterator](){return this},next(){if(n>=e.length)return{value:void 0,done:!0};let s=e[n++];return{value:[s,t.get(s)],done:!1}}}}node(e){if(e==="")throw new Error(`Graph "${this.name}": node name must be non-empty`);if(e.includes(P))return this.resolve(e);let t=this._nodes.get(e);if(!t)throw new Error(`Graph "${this.name}": unknown node "${e}"`);return t}get(e){return this.node(e).cache}set(e,t,n){let s=n?.internal===!0;this.node(e).down([[C,t]],{actor:n?.actor,internal:s,delivery:"write"})}setAll(e,t){let n=Symbol.iterator in e?e:Object.entries(e);ce(()=>{for(let[s,o]of n)this.set(s,o,t)})}invalidate(e,t){let n=t?.internal===!0;this.node(e).down([[X]],{actor:t?.actor,internal:n,delivery:"write"})}error(e,t,n){let s=n?.internal===!0;this.node(e).down([[$,t]],{actor:n?.actor,internal:s,delivery:"write"})}complete(e,t){let n=t?.internal===!0;this.node(e).down([[V]],{actor:t?.actor,internal:n,delivery:"write"})}edges(e){let t=e?.recursive===!0,n=new Map;if(!t){for(let[u,d]of this._nodes)n.set(d,u);let a=[];for(let[u,d]of this._nodes)if(d instanceof I)for(let l of d._deps){let h=n.get(l.node);h!=null&&a.push([h,u])}return a.sort((u,d)=>u[0]<d[0]?-1:u[0]>d[0]?1:u[1]<d[1]?-1:u[1]>d[1]?1:0),a}let s=[];this._collectObserveTargets("",s);let o=new Map;for(let[a,u]of s)o.set(u,a);let i=[];for(let[a,u]of s)if(u instanceof I)for(let d of u._deps){let l=o.get(d.node);l!=null&&i.push([l,a])}return i.sort((a,u)=>a[0]<u[0]?-1:a[0]>u[0]?1:a[1]<u[1]?-1:a[1]>u[1]?1:0),i}mount(e,t){if(t===void 0){let s=new r(e);return this.mount(e,s)}if(typeof t=="function"){let s=new r(e);return t(s),this.mount(e,s)}let n=t;if(At(e,this.name,"mount"),this._nodes.has(e))throw new Error(`Graph "${this.name}": cannot mount at "${e}" \u2014 node with that name exists`);if(this._mounts.has(e))throw new Error(`Graph "${this.name}": mount "${e}" already exists`);if(n===this)throw new Error(`Graph "${this.name}": cannot mount a graph into itself`);if(n._parent!=null)throw new Error(`Graph "${this.name}": this child graph is already mounted on "${n._parent.name}"`);for(let s=this;s!=null;s=s._parent)if(s===n)throw new Error(`Graph "${this.name}": mount("${e}", \u2026) would create a mount cycle`);return this._mounts.set(e,n),n._parent=this,this._emitTopology({kind:"added",name:e,nodeKind:"mount"}),n}resolve(e){let t=nr(e,this.name);return this._resolveFromSegments(t)}tryResolve(e){try{return this.resolve(e)}catch{return}}_resolveFromSegments(e){let t=e;if(t[0]===this.name&&(t=t.slice(1),t.length===0))throw new Error(`Graph "${this.name}": resolve path ends at graph name only`);let n=t[0],s=t.slice(1);if(s.length===0){let a=this._nodes.get(n);if(a)return a;throw this._mounts.has(n)?new Error(`Graph "${this.name}": path ends at subgraph "${n}" \u2014 not a node (GRAPHREFLY-SPEC \xA73.5)`):new Error(`Graph "${this.name}": unknown name "${n}"`)}let o=this._nodes.get(n);if(o&&s.length>0&&s[0]===Z)return this._resolveMetaChainFromNode(o,s,t.join(P));let i=this._mounts.get(n);if(!i)throw this._nodes.has(n)?new Error(`Graph "${this.name}": "${n}" is a node; trailing path "${s.join(P)}" is invalid`):new Error(`Graph "${this.name}": unknown mount or node "${n}"`);return i.resolve(s.join(P))}_resolveMetaChainFromNode(e,t,n){let s=e,o=0,i=[...t];for(;o<i.length;){if(i[o]!==Z)throw new Error(`Graph "${this.name}": expected ${Z} segment in meta path "${n}"`);if(o+1>=i.length)throw new Error(`Graph "${this.name}": meta path requires a key after ${Z} in "${n}"`);let a=i[o+1],u=s.meta[a];if(!u)throw new Error(`Graph "${this.name}": unknown meta "${a}" in path "${n}"`);s=u,o+=2}return s}signal(e,t){if(t?.internal!==!0){for(let s of e)if(this.config.messageTier(s[0])===3)throw new Error(`Graph "${this.name}": Graph.signal() rejects tier-3 messages (DATA / RESOLVED). Broadcast is for control-plane tiers (START / DIRTY / INVALIDATE / PAUSE / RESUME / COMPLETE / ERROR / TEARDOWN). For per-node value writes, use Graph.set or graph.node(name).down(...).`)}let n=[];if(this._signalDeliver(e,t??{},new Set,n),n.length>0)throw n[0]}_signalDeliver(e,t,n,s){for(let u of this._mounts.values())u._signalDeliver(e,t,n,s);let i=t.internal===!0?{internal:!0}:{actor:t.actor,delivery:"signal"},a=rr(e,this.config);for(let u of[...this._nodes.keys()].sort()){let d=this._nodes.get(u);if(!n.has(d)){n.add(d);try{d.down(e,i)}catch(l){if(l instanceof J)throw l;s.push(l)}a.length!==0&&this._signalMetaSubtree(d,a,n,i,s)}}}_signalMetaSubtree(e,t,n,s,o){for(let i of Object.keys(e.meta).sort()){let a=e.meta[i];if(!n.has(a)){n.add(a);try{a.down(t,s)}catch(u){if(u instanceof J)throw u;o.push(u)}this._signalMetaSubtree(a,t,n,s,o)}}}describe(e){if(e?.reactive==="diff")return this._describeReactiveDiff(e);if(e?.reactive===!0)return this._describeReactive(e);let t=qn(e?.actor),n=e?.filter;if(e?.detail!=null&&e?.fields!=null)throw new TypeError("Graph.describe(): pass either `detail` or `fields`, not both. `detail: 'spec'` is the canonical spec projection; use `fields` only when you need a custom subset.");let s=_t(e?.detail,e?.fields),o=e?.detail==="spec",i=s,a=[];this._collectObserveTargets("",a);let u=new Map;for(let[y,w]of a)u.set(w,y);let d=[];{let y=a.map(([,m])=>m),w=new Set(u.values()),k=0;for(;y.length>0;){let m=y.shift();if(m instanceof I)for(let O of m._deps){let x=O.node;if(u.has(x))continue;let A=x.name??"",N=A;if(!N||w.has(N))if(A){let S=2;for(;w.has(`${A}#${S}`);)S++;N=`${A}#${S}`}else for(N=`__internal__/${k++}`;w.has(N);)N=`__internal__/${k++}`;u.set(x,N),w.add(N),d.push([N,x]),y.push(x)}}}let l=[...a,...d],h={};for(let[y,w]of l){if(t!=null&&!w.allowsObserve(t))continue;let k=wt(w,i,o),m=w instanceof I?w._deps.map(N=>u.get(N.node)??N.node.name??""):[],{name:O,...x}=k,A={...x,deps:m};if(!o){let N=this._annotations.get(y);N!=null&&(A.annotation=N)}if(n!=null)if(typeof n=="function"){let N=n;if(!(N.length>=2?N(y,A):N(A)))continue}else{let N=!0;for(let[S,D]of Object.entries(n)){let R=S==="deps_includes"?"depsIncludes":S==="meta_has"?"metaHas":S;if(R==="depsIncludes"){if(!A.deps.includes(String(D))){N=!1;break}continue}if(R==="metaHas"){if(!Object.hasOwn(A.meta??{},String(D))){N=!1;break}continue}if(A[R]!==D){N=!1;break}}if(!N)continue}h[y]=A}let p=new Set(Object.keys(h)),g=[];for(let[y,w]of l)if(w instanceof I)for(let k of w._deps){let m=u.get(k.node);m!=null&&g.push([m,y])}g.sort((y,w)=>y[0]<w[0]?-1:y[0]>w[0]?1:y[1]<w[1]?-1:y[1]>w[1]?1:0);let c=g.map(([y,w])=>({from:y,to:w}));(t!=null||n!=null)&&(c=c.filter(y=>p.has(y.from)&&p.has(y.to)));let _=this._collectSubgraphs(""),f=t!=null||n!=null?_.filter(y=>{let w=`${y}${P}`;return[...p].some(k=>k===y||k.startsWith(w))}):_,T=this,v=e;return{name:this.name,nodes:h,edges:c,subgraphs:f,...this._factory!==void 0?{factory:this._factory}:{},...this._factoryArgs!==void 0?{factoryArgs:this._factoryArgs}:{},expand(y){let w={...v};return Array.isArray(y)?(w.fields=y,w.detail=void 0):(w.detail=y,w.fields=void 0),T.describe(w)}}}_collectSubgraphs(e){let t=[];for(let n of[...this._mounts.keys()].sort()){let s=e===""?n:`${e}${n}`;t.push(s),t.push(...this._mounts.get(n)._collectSubgraphs(`${s}${P}`))}return t}resourceProfile(e){return dn(this,e)}reachable(e,t,n={}){return n.withDetail===!0?St(this.describe(),e,t,{...n,withDetail:!0}):St(this.describe(),e,t,n)}explain(e,t,n){return n?.reactive===!0?this._explainReactive(e,t,n):this._explainStatic(ae(e),ae(t),{...n?.maxDepth!==void 0?{maxDepth:ln(n.maxDepth)}:{},...n?.findCycle!==void 0?{findCycle:fn(n.findCycle)}:{}})}_explainStatic(e,t,n){let s=this.describe({detail:"full"}),o=new Map(this._annotations),i=new Map;for(let[a,u]of Object.entries(s.nodes))u.lastMutation!=null&&i.set(a,u.lastMutation);return tn(s,e,t,{...n?.maxDepth!=null?{maxDepth:n.maxDepth}:{},...n?.findCycle===!0?{findCycle:!0}:{},annotations:o,lastMutations:i})}_describeReactive(e){let t={...e,reactive:!1},n=e.reactiveName??"describe",s=0,o=ee(s,{name:`${n}_version`}),i=this.observe({timeline:!0,structured:!0}),a=!1,u=!1,d=()=>{a||u||(a=!0,be(()=>{a=!1,!u&&(s+=1,o.emit(s))}))},l=i.onEvent(v=>{let b=v.type;b!=="data"&&b!=="error"&&b!=="complete"&&b!=="teardown"||d()}),h=[],p=new WeakSet,g=v=>{if(p.has(v)||u)return;p.add(v);let b=v.topology.subscribe(y=>{for(let w of y){if(w[0]!==C)continue;let k=w[1];if(d(),k.kind==="added"&&k.nodeKind==="mount"){let m=v._mounts.get(k.name);m!=null&&g(m)}}});h.push(b);for(let y of v._mounts.keys()){let w=v._mounts.get(y);w!=null&&g(w)}};g(this);let c,_=e.actor;gn(_)&&(c=_.subscribe(v=>{let b=!1,y=!1;for(let w of v){let k=w[0];k===C?b=!0:(k===V||k===$||k===F)&&(y=!0)}b&&d(),y&&(c?.(),c=void 0,d())}));let f;try{f=j([o],()=>this.describe(t),{name:n,describeKind:"derived",meta:{domain:"audit",kind:"describe"},equals:(v,b)=>v===b})}catch(v){l(),c?.();for(let b of h)b();throw i.dispose(),v}let T=te(f);return{node:f,dispose(){u=!0,l(),c?.();for(let v of h)v();h.length=0,i.dispose(),T()}}}_describeReactiveDiff(e){let t={...e,reactive:!1},n=e.reactiveName??"describe-diff",s={name:this.name,nodes:{},edges:[],subgraphs:[]},o=this.describe(t),i=xt(s,o),a=ee(i,{name:n,meta:{domain:"audit",kind:"describe-diff"},equals:(p,g)=>p===g}),u=this._describeReactive({...e,reactiveName:void 0}),d=!1,l=u.node.subscribe(p=>{if(!d)for(let g of p){if(g[0]!==C)continue;let c=g[1],_=xt(o,c);o=c,_.events.length!==0&&a.emit(_)}}),h=te(a);return{node:a,dispose(){d=!0,l(),u.dispose(),a.down([[F,"describe-diff disposed"]]),h()}}}_explainReactive(e,t,n){let s=0,o=ee(s,{name:"explain_version"}),i=this.observe({timeline:!0,structured:!0}),a=!1,u=!1,d=()=>{a||u||(a=!0,be(()=>{a=!1,!u&&(s+=1,o.emit(s))}))},l=i.onEvent(v=>{let b=v.type;b!=="data"&&b!=="error"&&b!=="complete"&&b!=="teardown"||d()}),h=[];e!=null&&he(e)&&h.push(e),t!=null&&he(t)&&h.push(t),n?.maxDepth!=null&&he(n.maxDepth)&&h.push(n.maxDepth),n?.findCycle!=null&&he(n.findCycle)&&h.push(n.findCycle);let p=()=>{for(let v of h)if(v.cache===void 0)return!1;return!0},g=()=>{let v=ae(e),b=ae(t);return{from:v,to:b,found:!1,reason:"pending",steps:[],text:"(awaiting reactive args)",toJSON:()=>({from:v,to:b,found:!1,reason:"pending",steps:[]})}},c;try{c=j([o],()=>{if(!p())return g();let v=ae(e),b=ae(t),y={...n?.maxDepth!==void 0?{maxDepth:ln(n.maxDepth)}:{},...n?.findCycle!==void 0?{findCycle:fn(n.findCycle)}:{}};return this._explainStatic(v,b,y)},{name:n?.name??"explain",describeKind:"derived",meta:{domain:"audit",kind:"explain_path",from:ae(e),to:ae(t)},equals:(v,b)=>v.found===b.found&&v.reason===b.reason&&v.steps.length===b.steps.length&&sr(v.steps,b.steps)})}catch(v){throw l(),i.dispose(),v}let _=te(c),f=[],T=v=>{let b;return b=v.subscribe(y=>{let w=!1,k=!1;for(let m of y){let O=m[0];O===C?w=!0:(O===V||O===$||O===F)&&(k=!0)}(w||k)&&d(),k&&b&&(b(),b=void 0)}),()=>{b&&(b(),b=void 0)}};for(let v of h)f.push(T(v));return{node:c,dispose(){u=!0,l();for(let v of f)v?.();f.length=0,i.dispose(),_()}}}_pathsMatching(e){let t=Ze(e),n=[];return this._collectObserveTargets("",n),n.map(([s])=>s).filter(s=>t.test(s))}_collectObserveTargets(e,t){for(let n of[...this._mounts.keys()].sort()){let s=e===""?n:`${e}${P}${n}`;this._mounts.get(n)._collectObserveTargets(s,t)}for(let n of[...this._nodes.keys()].sort()){let s=this._nodes.get(n),o=e===""?n:`${e}${P}${n}`;t.push([o,s]),this._appendMetaObserveTargets(o,s,t)}}_appendMetaObserveTargets(e,t,n){for(let s of Object.keys(t.meta).sort()){let o=t.meta[s],i=`${e}${P}${Z}${P}${s}`;n.push([i,o]),this._appendMetaObserveTargets(i,o,n)}}observe(e,t){let n=typeof e=="string",o=hn(n?t:e);if(o.reactive===!0)return this._observeReactive(n?e:void 0,o);let i=o.structured===!0||o.timeline===!0||o.causal===!0||o.derived===!0||o.detail==="minimal"||o.detail==="full"||o.format!=null,a=o.actor;if(n){let l=e,h=this.resolve(l);if(a!=null&&!h.allowsObserve(a))throw new J({actor:a,action:"observe",nodeName:l});return i?this._buildStructuredObserver([[l,h]],o,"one"):{subscribe(p){return h.subscribe(p)},up(p){try{h.up?.(p)}catch(g){if(g instanceof J)return;throw g}}}}let u=[];this._collectObserveTargets("",u),u.sort((l,h)=>l[0]<h[0]?-1:l[0]>h[0]?1:0);let d=a==null?u:u.filter(([,l])=>l.allowsObserve(a));return i?this._buildStructuredObserver(d,o,"all"):{subscribe:l=>{let h=d.map(([p,g])=>g.subscribe(c=>{l(p,c)}));return()=>{for(let p of h)p()}},up:(l,h)=>{try{this.resolve(l).up?.(h)}catch(p){if(p instanceof J)return;throw p}}}}_observeReactive(e,t){let n=t.tiers,s=n!=null?new Set(n):null,o=t.reactiveName??"observe";return Be(i=>{let a=[],u=!1,d=!1,l=()=>{if(a.length===0||d)return;let _={events:a.slice(),flushedAt_ns:B()};a.length=0,i.emit(_)},h={...t,reactive:!1,structured:!0,timeline:!0},p=e!=null?this.observe(e,h):this.observe(h),g=_=>{d||(a.push(_),!u&&(u=!0,be(()=>{u=!1,l()})))};for(let _ of p.events)g(_);let c=p.onEvent(g);return()=>{d=!0,c(),p.dispose()}},{name:o,meta:{domain:"audit",kind:"observe-reactive"}})}_buildStructuredObserver(e,t,n){let s=n==="one"?e[0]?.[0]:void 0,o=i=>{if(n==="one"&&s!=null){let l=this.resolve(s);return this._buildStructuredObserver([[s,l]],i,"one")}let a=[];this._collectObserveTargets("",a),a.sort((l,h)=>l[0]<h[0]?-1:l[0]>h[0]?1:0);let u=i.actor,d=u==null?a:a.filter(([,l])=>l.allowsObserve(u));return this._buildStructuredObserver(d,i,"all")};return this._createObserveResult(e,t,o)}_createObserveResult(e,t,n){let s=t.timeline===!0,o=t.causal===!0,i=t.derived===!0,a=t.detail==="minimal",u=this.config.inspectorEnabled,d=(o||i)&&u,l=t.maxEvents,h=l!=null&&l>0?new De(l):null,p=[],g=new Set,c=t.tiers!=null?new Set(t.tiers):null,_={},f=new Set,T=0,v=0,b=0,y=0,w=0,k=0,m=!1,O=!1,x=0,A=new Map,N=new Map,S=new Map,D=E=>{if(!(c!=null&&!c.has(E.type))){h?h.push(E):p.push(E);for(let M of g)M(E)}},R=E=>c==null||c.has(E),se=()=>s?{timestamp_ns:B(),in_batch:Me(),batch_id:x}:{},ne=(E,M)=>{if(!(!d||!(E instanceof I)))return E._setInspectorHook(q=>{if(q.kind==="dep_message")A.set(E,q.depIndex);else if(q.kind==="run"){let Oe=q.batchData.map((G,H)=>G!=null&&G.length>0?G.at(-1):q.prevData[H]);N.set(E,Oe);let Y=q.batchData.map(G=>G!=null?[...G]:void 0);S.set(E,Y),i&&D({type:"derived",path:M,dep_values:Oe,dep_batches:Y,...se()})}})},Ce=E=>{let M=A.get(E),q=N.get(E);if(!o||q==null)return{};let Y=(M!=null&&M>=0&&E instanceof I?E._deps[M]:void 0)?.node,G=Y?.v,H=S.get(E);return{trigger_dep_index:M,trigger_dep_name:Y?.name,...G!=null?{trigger_version:{id:G.id,version:G.version}}:{},dep_values:[...q],...H!=null?{dep_batches:H}:{}}},Ct=[],Gt=[];for(let[E,M]of e){let q=ne(M,E);q&&Ct.push(q),Gt.push(M.subscribe(Oe=>{x++;for(let Y of Oe){let G=Y[0],H=se();if(G===C){_[E]=Y[1];let ot=M instanceof I?M.lastMutation?.actor??_e:_e;D({type:"data",path:E,data:Y[1],actor:ot,...H,...Ce(M)})}else if(a)G===U?R("dirty")&&T++:G===W?R("resolved")&&v++:G===X?R("invalidate")&&b++:G===Q?R("pause")&&y++:G===re?R("resume")&&w++:G===F?R("teardown")&&k++:G===V&&!f.has(E)?R("complete")&&(m=!0):G===$&&R("error")&&(O=!0,f.add(E));else if(G===U)R("dirty")&&T++,D({type:"dirty",path:E,...H});else if(G===W)R("resolved")&&v++,D({type:"resolved",path:E,...H,...Ce(M)});else if(G===X)R("invalidate")&&b++,D({type:"invalidate",path:E,...H});else if(G===Q)R("pause")&&y++,D({type:"pause",path:E,lockId:Y[1],...H});else if(G===re)R("resume")&&w++,D({type:"resume",path:E,lockId:Y[1],...H});else if(G===V)R("complete")&&!f.has(E)&&(m=!0),D({type:"complete",path:E,...H});else if(G===$){R("error")&&(O=!0,f.add(E));let ot=M instanceof I?M.lastMutation?.actor??_e:_e;D({type:"error",path:E,data:Y[1],actor:ot,...H})}else G===F&&(R("teardown")&&k++,D({type:"teardown",path:E,...H}))}}))}let nt=!1,rt=()=>{if(!nt){nt=!0;for(let E of Gt)E();for(let E of Ct)E();for(let E of Ge)E({value:void 0,done:!0});Ge.length=0}},st=[],Ge=[];g.add(E=>{let M=Ge.shift();M?M({value:E,done:!1}):st.push(E)});let Mt={get values(){return _},get dirtyCount(){return T},get resolvedCount(){return v},get invalidateCount(){return b},get pauseCount(){return y},get resumeCount(){return w},get teardownCount(){return k},get events(){return h?h.toArray():[...p]},get anyCompletedCleanly(){return m},get anyErrored(){return O},get completedWithoutErrors(){return m&&!O},onEvent(E){return g.add(E),()=>g.delete(E)},dispose:rt,expand(E){rt();let M={...t};return typeof E=="string"?M.detail=E:Object.assign(M,E),n(hn(M))},[Symbol.asyncIterator](){return{next(){return st.length>0?Promise.resolve({value:st.shift(),done:!1}):nt?Promise.resolve({value:void 0,done:!0}):new Promise(E=>Ge.push(E))},return(){return rt(),Promise.resolve({value:void 0,done:!0})}}}};return t.format!=null&&this._attachFormatLogger(Mt,t),Mt}_attachFormatLogger(e,t){let n=t.format;if(n==null)return;let s=t.logger??(c=>console.log(c)),o=t.includeTypes?new Set(t.includeTypes):null,i=t.excludeTypes?new Set(t.excludeTypes):null,a=o==null&&i==null?()=>!0:c=>(o==null||o.has(c))&&(i==null||!i.has(c)),u=er(t.theme),d=n==="stage-log"?B():0,l=c=>c==null?"":t.stageLabels?.[c]??c,h=(c,_)=>c.length>_?`${c.slice(0,_-1)}\u2026`:c,p=c=>c.type==="data"||c.type==="error"?h(Et(c.data),120):"",g=c=>{if(n==="stage-log"){let m=(B()-d)/1e9,O=l(c.path).padEnd(9);if(c.type==="data"){let x=p(c);return`[${m.toFixed(3)}s] ${O} \u2190${x?` ${x}`:""}`}if(c.type==="error"){let x=p(c);return`[${m.toFixed(3)}s] ${O} \u2717${x?` ${x}`:""}`}return c.type==="complete"?`[${m.toFixed(3)}s] ${O} \u25A0 complete`:`[${m.toFixed(3)}s] ${O} ${c.type}`}if(n==="json")try{return JSON.stringify(c)}catch{return JSON.stringify({type:c.type,path:c.path,data:"[unserializable]"})}let _=u[c.type]??"",f=c.path?`${u.path}${c.path}${u.reset} `:"",T=c.type==="data"||c.type==="error",v=c.type==="pause"||c.type==="resume",b=T?` ${Et(c.data)}`:v?` ${Et(c.lockId)}`:"",y=c.type==="data"||c.type==="resolved"||c.type==="derived"?c:void 0,w=y?.trigger_dep_name!=null?` <- ${y.trigger_dep_name}`:y?.trigger_dep_index!=null?` <- #${y.trigger_dep_index}`:"",k=c.in_batch?" [batch]":"";return`${f}${_}${c.type.toUpperCase()}${u.reset}${b}${w}${k}`};e.onEvent(c=>{a(c.type)&&s(g(c),c)})}addDisposer(e){return this._disposers.add(e),()=>{this._disposers.delete(e)}}destroy(){cn(this._disposers,this.name),this.signal([[F]],{internal:!0}),cn(this._storageDisposers,this.name);for(let e of[...this._mounts.values()])e._parent=void 0,e._destroyClearOnly();this._mounts.clear(),this._nodes.clear(),this._parent=void 0,this._destroyed=!0}get destroyed(){return this._destroyed}_destroyClearOnly(){for(let e of[...this._mounts.values()])e._parent=void 0,e._destroyClearOnly();this._mounts.clear(),this._nodes.clear(),this._parent=void 0,this._destroyed=!0}snapshot(e){let{expand:t,...n}=this.describe({detail:"full"}),s={};for(let a of Object.keys(n.nodes).sort()){let{lastMutation:u,guard:d,...l}=n.nodes[a];s[a]=l}let o=[...n.subgraphs].sort(),i={...n,version:1,nodes:s,subgraphs:o};if(e?.format==null)return i;if(e.format==="json-string")return JSON.stringify(i);if(e.format==="bytes"){if(e.codec==null)throw new Error("snapshot({format: 'bytes'}) requires a `codec` name");let a=this.config.lookupCodec(e.codec);if(a==null)throw new Error(`snapshot: codec "${e.codec}" is not registered on this graph's config. Call config.registerCodec(...) before creating nodes.`);return zt(a,a.encode(i))}throw new Error(`snapshot: unknown format "${String(e.format)}"`)}static decode(e,t){let n=t?.config??we,{codec:s,codecVersion:o,payload:i}=jt(e,n);return s.decode(i,o)}restore(e,t){if(pn(e),e.name!==this.name)throw new Error(`Graph "${this.name}": restore snapshot name "${e.name}" does not match this graph`);let n=t?.only==null?null:(Array.isArray(t.only)?t.only:[t.only]).map(o=>Ze(o)),s=t?.includeProducers===!0;for(let o of Object.keys(e.nodes).sort()){if(n!==null&&!n.some(a=>a.test(o)))continue;let i=e.nodes[o];if(i!==void 0){if(!("value"in i)||i.value===void 0){"value"in i&&i.value===void 0&&t?.onError?.(o,new Error(`restore: slice.value is undefined for "${o}" (undefined is the global SENTINEL; not valid DATA)`));continue}if(!(i.type==="derived"||i.type==="effect")&&!(i.type==="producer"&&!s)){if(i.v!=null){let u=this.tryResolve(o)?.v;if(u!=null&&u.id===i.v.id&&u.version===i.v.version)continue}try{this.set(o,i.value)}catch(a){t?.onError?.(o,a)}}}}}static fromSnapshot(e,t){pn(e);let n=typeof t=="function"?t:t?.build,s=typeof t=="function"?void 0:t?.factories,o=new r(e.name);if(n)return n(o),o.restore(e),o;for(let g of[...e.subgraphs].sort((c,_)=>{let f=c.split(P).length,T=_.split(P).length;return f!==T?f-T:c<_?-1:c>_?1:0})){let c=g.split(P),_=o;for(let f of c)_._mounts.has(f)||_.mount(f,new r(f)),_=_._mounts.get(f)}let i=s?Object.entries(s).map(([g,c])=>({re:Ze(g),factory:c})):[],a=g=>{for(let c of i)if(c.re.test(g))return c.factory},u=g=>{let c=g.split(P),_=c.pop();if(_==null||_.length===0)throw new Error(`invalid snapshot path "${g}"`);let f=o;for(let T of c){let v=f._mounts.get(T);if(!v)throw new Error(`unknown mount "${T}" in path "${g}"`);f=v}return[f,_]},d=Object.entries(e.nodes).filter(([g])=>!g.includes(`${P}${Z}${P}`)).sort((g,c)=>g[0]<c[0]?-1:g[0]>c[0]?1:0),l=new Map(d),h=new Map,p=!0;for(;l.size>0&&p;){p=!1;for(let[g,c]of[...l.entries()]){let _=c?.deps??[];if(!_.every(w=>h.has(w)))continue;let[f,T]=u(g),v={...c?.meta??{}},b=a(g),y;if(c?.type==="state")y=ee(c.value,{meta:v});else{if(b==null)continue;y=b(T,{path:g,type:c.type,value:c.value,meta:v,deps:_,resolvedDeps:_.map(w=>h.get(w))})}f.add(y,{name:T}),h.set(g,y),l.delete(g),p=!0}}if(l.size>0){let g=[...l.keys()].sort().join(", ");throw new Error(`Graph.fromSnapshot could not reconstruct nodes without build callback: ${g}. Pass matching factories via fromSnapshot(data, { factories: { pattern: factoryFn } }).`)}return o.restore(e),o}toJSON(){return this.snapshot()}attachSnapshotStorage(e,t={}){let n=e.map(d=>({tier:d,debounceMs:Math.max(0,d.debounceMs??0),compactEvery:Math.max(1,d.compactEvery??10),timer:void 0,seq:0,lastSnapshot:void 0,lastFingerprint:"",disposed:!1,savePending:void 0}));t.autoRestore===!0&&this._cascadeRestore(e,t.onError);let s=(d,l)=>{if(d.disposed)return;let h=Yn(l.nodes);if(d.lastSnapshot!=null&&h!==""&&h===d.lastFingerprint)return;let p=d.seq+1,g=oe(),f=d.lastSnapshot==null||p%d.compactEvery===0?{name:this.name,mode:"full",snapshot:l,seq:p,timestamp_ns:g,format_version:pe}:{name:this.name,mode:"diff",diff:bn(d.lastSnapshot,l),seq:p,timestamp_ns:g,format_version:pe};if(d.tier.filter&&!d.tier.filter(f))return;let T;try{T=d.tier.save(f)}catch(v){t.onError?.(v,d.tier);return}if(T&&typeof T.then=="function"){let y=(d.savePending??Promise.resolve()).then(()=>T,()=>T).then(()=>{d.disposed||(d.seq=p,d.lastSnapshot=l,d.lastFingerprint=h)},w=>{t.onError?.(w,d.tier)});d.savePending=y.finally(()=>{d.savePending===y&&(d.savePending=void 0)})}else d.seq=p,d.lastSnapshot=l,d.lastFingerprint=h},o=(d,l)=>{try{s(d,l)}catch(h){t.onError?.(h,d.tier)}},i=(d,l)=>{if(!l.some(c=>{let _=this.config.messageTier(c[0]);return _>=3&&_<5}))return;if(t.filter){let c=this.tryResolve(d);if(c==null)return;let _=wt(c,_t("standard"));if(!t.filter(d,_))return}let p,g=()=>(p==null&&(p=this.snapshot()),p);for(let c of n)c.disposed||(c.debounceMs===0?o(c,g()):(c.timer==null&&(c.timer=new Xe),c.timer.start(c.debounceMs,()=>{c.disposed||o(c,this.snapshot())})))},a;if(t.paths!=null){let l=(typeof t.paths=="string"?this._pathsMatching(t.paths):t.paths).map(h=>{let p=this.tryResolve(h);return p==null?()=>{}:p.subscribe(g=>i(h,g))});a=()=>{for(let h of l)h()}}else a=this.observe().subscribe((d,l)=>i(d,l));let u=()=>{a();for(let d of n)d.disposed=!0,d.timer?.cancel();this._storageDisposers.delete(u)};return this._storageDisposers.add(u),{dispose:u}}async _cascadeRestore(e,t){for(let n of e){let s;try{s=await n.load?.()}catch(i){t?.(i,n);continue}if(s==null||typeof s!="object"||Array.isArray(s))continue;let o=s;try{if(o.mode==="full"&&o.snapshot!=null)return this.restore(o.snapshot),!0;if(o.version===pe&&o.nodes!=null)return this.restore(o),!0}catch(i){t?.(i,n)}}return!1}static async fromStorage(e,t,n){for(let s of t){let o;try{o=await s.load?.()}catch(u){n?.onError?.(u,s);continue}if(o==null||typeof o!="object"||Array.isArray(o))continue;let i=o,a=i.mode==="full"&&i.snapshot!=null?i.snapshot:i.version===pe&&i.nodes!=null?i:void 0;if(a!=null)try{return r.fromSnapshot(a,n)}catch(u){n?.onError?.(u,s)}}throw new Error(`Graph.fromStorage: no tier held a restorable record for "${e}" across ${t.length} tier(s)`)}_annotations=new Map;_traceRing;trace(e,t,n){if(e!=null&&t!=null){if(this.tryResolve(e)==null)return;if(this._annotations.set(e,t),this.config.inspectorEnabled){let s={path:e,annotation:t,timestamp_ns:B(),...n?.actor!=null?{actor:n.actor}:{}};this._traceRing.push(s)}return}return e!=null?this.config.inspectorEnabled?this._annotations.get(e):void 0:this.config.inspectorEnabled?this._traceRing.toArray():[]}annotation(e){return this._annotations.get(e)}clearTrace(){this._annotations.clear(),this._traceRing.clear()}pruneTrace(e){let t=this._traceRing.toArray().filter(s=>!e(s)),n=this._traceRing.size-t.length;this._traceRing.clear();for(let s of t)this._traceRing.push(s);return n}static diff(e,t){let n=new Set(Object.keys(e.nodes)),s=new Set(Object.keys(t.nodes)),o=[...s].filter(v=>!n.has(v)).sort(),i=[...n].filter(v=>!s.has(v)).sort(),a=[],u=[];for(let v of n){if(!s.has(v))continue;let b=e.nodes[v],y=t.nodes[v],w=b.v,k=y.v;w!=null&&k!=null&&w.id===k.id&&w.version!==k.version&&u.push({path:v,id:w.id,from:w.version,to:k.version});let m=w!=null&&k!=null&&w.id===k.id&&w.version===k.version;for(let O of["type","status","sentinel"]){let x=b[O],A=y[O];x!==A&&a.push({path:v,field:O,from:x,to:A})}if(!m)for(let O of["value","meta"]){let x=b[O],A=y[O];Jn(x,A)||a.push({path:v,field:O,from:x,to:A})}}let d=v=>`${v.from} ${v.to}`,l=new Set(e.edges.map(d)),h=new Set(t.edges.map(d)),p=t.edges.filter(v=>!l.has(d(v))),g=e.edges.filter(v=>!h.has(d(v))),c=new Set(e.subgraphs),_=new Set(t.subgraphs),f=[..._].filter(v=>!c.has(v)).sort(),T=[...c].filter(v=>!_.has(v)).sort();return{nodesAdded:o,nodesRemoved:i,nodesChanged:a,versionChanges:u,edgesAdded:p,edgesRemoved:g,subgraphsAdded:f,subgraphsRemoved:T}}};function bn(r,e){let t=K.diff(r,e),n={};for(let s of t.nodesAdded){let o=e.nodes[s];o!=null&&(n[s]=o)}return{...t,nodesAddedFull:n}}function St(r,e,t,n={}){let s={paths:[],depths:new Map,truncated:!1};if(!e)return n.withDetail?s:[];if(!n.both&&t!=="upstream"&&t!=="downstream")throw new Error('reachable: direction must be "upstream" or "downstream"');let o=n.maxDepth;if(o!=null&&(!Number.isInteger(o)||o<0))throw new Error("reachable: maxDepth must be an integer >= 0");if(o===0)return n.withDetail?s:[];let i=new Map,a=new Map,u=new Map,d=new Map,l=new Set;for(let[b,y]of Object.entries(r.nodes)){if(!b)continue;l.add(b);let w=y.deps??[];i.set(b,w);for(let k of w)k&&(l.add(k),a.has(k)||a.set(k,new Set),a.get(k).add(b))}for(let b of r.edges){if(b==null||typeof b!="object")continue;let y=typeof b.from=="string"?b.from:"",w=typeof b.to=="string"?b.to:"";!y||!w||(l.add(y),l.add(w),d.has(y)||d.set(y,new Set),d.get(y).add(w),u.has(w)||u.set(w,new Set),u.get(w).add(y))}if(!l.has(e))return n.withDetail?s:[];let h=n.both===!0,p=b=>{if(h){let m=i.get(b)??[],O=u.get(b),x=a.get(b),A=d.get(b),N=[...m];return O&&N.push(...O),x&&N.push(...x),A&&N.push(...A),N}if(t==="upstream"){let m=i.get(b)??[],O=u.get(b);return O?[...m,...O]:m}let y=a.get(b),w=d.get(b),k=y?[...y]:[];return w&&k.push(...w),k},g=new Set([e]),c=new Map,_=[{path:e,depth:0}],f=0,T=!1;for(;f<_.length;){let b=_[f++];if(o!=null&&b.depth>=o){p(b.path).length>0&&(T=!0);continue}for(let y of p(b.path))!y||g.has(y)||(g.add(y),c.set(y,b.depth+1),_.push({path:y,depth:b.depth+1}))}let v=[...c.keys()].sort((b,y)=>b<y?-1:b>y?1:0);return n.withDetail?{paths:v,depths:c,truncated:T}:v}function sr(r,e){if(r.length!==e.length)return!1;for(let t=0;t<r.length;t++){let n=r[t],s=e[t];if(n.path!==s.path||n.type!==s.type||n.status!==s.status||n.hop!==s.hop||n.dep_index!==s.dep_index||n.annotation!==s.annotation||n.value!==s.value||n.lastMutation!==s.lastMutation)return!1;let o=n.v,i=s.v;if(o!==i&&(o==null||i==null||o.id!==i.id||o.version!==i.version))return!1}return!0}ie();function Rt(r,e){let t=new Map,n=(s,o)=>{if(t.has(s))return;let i={off:()=>{},prefix:o};t.set(s,i);let a=s.topology.subscribe(u=>{for(let d of u){if(d[0]!==C)continue;let l=d[1];if(e(l,s,o),l.kind==="added"&&l.nodeKind==="mount"){let h=s._mounts.get(l.name);if(h instanceof K){let p=`${o}${l.name}::`;n(h,p)}}else if(l.kind==="removed"&&l.nodeKind==="mount"){let h=`${o}${l.name}::`;for(let[p,g]of Array.from(t.entries()))p!==r&&g.prefix.startsWith(h)&&(g.off(),t.delete(p))}}});i.off=a;for(let[u,d]of s._mounts)if(d instanceof K){let l=`${o}${u}::`;n(d,l)}};return n(r,""),()=>{for(let s of t.values())s.off();t.clear()}}ze();ye();ie();Se();Ot();We();function yn(r,e){return Ue("messaging",r,e)}var or=1024,Qe=class extends K{_log;events;latest;hasLatest;constructor(e,t={}){super(e,t.graph),this._log=Ke([],{name:"events",maxSize:t.retainedLimit??or}),this._log.withLatest(),this.events=this._log.entries,this.add(this.events,{name:"events"}),this.latest=j([this.events],([n])=>{let s=n;return s.length===0?null:s[s.length-1]},{name:"latest",describeKind:"derived",meta:yn("topic_latest")}),this.add(this.latest,{name:"latest"}),this.addDisposer(te(this.latest)),this.hasLatest=j([this.events],([n])=>n.length>0,{name:"hasLatest",describeKind:"derived",meta:yn("topic_has_latest")}),this.add(this.hasLatest,{name:"hasLatest"}),this.addDisposer(te(this.hasLatest)),this.addDisposer(()=>{this.events.down([[V]])}),this.addDisposer(()=>this._log.disposeAllViews())}publish(e){if(e===void 0)throw new TypeError(`TopicGraph "${this.name}": publish(undefined) is not allowed (spec \xA75.12 SENTINEL).`);this._log.append(e)}attachEventStorage(e){return this._log.attachStorage(e)}retained(){return this.events.cache}get _logBundle(){return this._log}};function wn(r,e){return Ue("audit",r,e)}var ir=new Set(["data","error","complete","teardown"]),et=class extends K{entries;count;_log;_target;constructor(e,t){super(t.name??`${e.name}_audit`,t.graph),this._target=e,this._log=Ke([],{name:"entries",...t.maxSize!=null?{maxSize:t.maxSize}:{}}),this.entries=this._log.entries,this.add(this.entries,{name:"entries"}),this.count=j([this.entries],([u])=>u.length,{name:"count",describeKind:"derived",meta:wn("count")}),this.add(this.count,{name:"count"}),this.addDisposer(te(this.count));let n=t.includeTypes!=null?new Set(t.includeTypes):ir,s=t.filter,o=0,i=e.observe({timeline:!0,structured:!0}),a=i.onEvent(u=>{if(u.type==="derived")return;let d=u.type;if(!n.has(d))return;let l=u.path??"",h={seq:o++,timestamp_ns:u.timestamp_ns??B(),wall_clock_ns:oe(),path:l,type:d},g=(l?Dt(e,l):void 0)?.lastMutation;g!=null&&(h.actor=g.actor),d==="data"&&(h.value=u.data),d==="error"&&(h.error=u.data);let c=l?cr(e,l):void 0;c!=null&&(h.annotation=c),!(s!=null&&!s(h))&&this._log.append(h)});this.addDisposer(()=>{a(),i.dispose()}),this.addDisposer(()=>this._log.disposeAllViews())}all(){return this.entries.cache??[]}byNode(e){return this.all().filter(t=>t.path===e)}byActor(e){return this.all().filter(t=>t.actor?.id===e)}byActorType(e){return this.all().filter(t=>t.actor?.type===e)}byTimeRange(e,t){return this.all().filter(n=>!(n.timestamp_ns<e||t!=null&&n.timestamp_ns>=t))}get target(){return this._target}};function ar(r,e={}){return new et(r,e)}var tt=class extends K{policies;violations;violationCount;_target;_mode;_currentGuard;constructor(e,t,n){super(n.name??`${e.name}_policy`,n.graph),this._target=e,this._mode=n.mode??"audit";let s=vn(t)?t:ee(t,{name:"policies"});this.policies=s,this.add(this.policies,{name:"policies"}),this.violations=new Qe("violations",{retainedLimit:n.violationsLimit??1e3}),this.mount("violations",this.violations),this.violationCount=j([this.violations.events],([c])=>c.length,{name:"violationCount",describeKind:"derived",meta:wn("policy_violation_count")}),this.add(this.violationCount,{name:"violationCount"}),this.addDisposer(te(this.violationCount));let i=s.cache??[];this._currentGuard=at(i);let a=s.subscribe(c=>{for(let _ of c)_[0]===C&&(i=_[1]??[],this._currentGuard=at(i))});this.addDisposer(a);let u=n.paths,d=vn(u)?u:void 0,l=u!=null,p=d!=null?d.cache??[]:l?[...u]:void 0,g=p??_n(e);if(this._mode!=="enforce"&&d!=null){let c=d.subscribe(_=>{for(let f of _)f[0]===C&&(p=f[1]??[])});this.addDisposer(c)}if(this._mode==="enforce"){let c=new Map,_=f=>{if(c.has(f))return;let T=Dt(e,f);if(!(T instanceof I))return;let v=(b,y)=>{let w=this._currentGuard(b,y);return w||this._publishViolation(b,y,f,"blocked"),w};c.set(f,T._pushGuard(v))};for(let f of g)_(f);if(d!=null){let f=d.subscribe(T=>{for(let v of T){if(v[0]!==C)continue;let b=v[1]??[],y=new Set(b),w=new Set(p??[]);ce(()=>{for(let k of w){if(y.has(k))continue;let m=c.get(k);m!=null&&(m(),c.delete(k))}for(let k of y)w.has(k)||_(k);p=b})}});this.addDisposer(f)}if(l){let f=e.topology.subscribe(T=>{for(let v of T){if(v[0]!==C)continue;let b=v[1];if(b.kind!=="removed"||b.nodeKind!=="node")continue;let y=c.get(b.name);y!=null&&(y(),c.delete(b.name))}});this.addDisposer(f)}else{let f=Rt(e,(T,v,b)=>{if(T.kind==="added")if(T.nodeKind==="node")_(`${b}${T.name}`);else{let y=v._mounts.get(T.name);if(!(y instanceof K))return;let w=`${b}${T.name}::`,k=_n(y);for(let m of k)_(m===""?`${b}${T.name}`:`${w}${m}`)}else if(T.kind==="removed")if(T.nodeKind==="node"){let y=`${b}${T.name}`,w=c.get(y);w!=null&&(w(),c.delete(y))}else{let y=`${b}${T.name}`,w=`${y}::`;for(let[k,m]of c)(k===y||k.startsWith(w))&&(m(),c.delete(k))}});this.addDisposer(f)}this.addDisposer(()=>{for(let f of c.values())f();c.clear()})}else{let c=e.observe({timeline:!0,structured:!0}),_=c.onEvent(f=>{if(f.type!=="data"&&f.type!=="error")return;let T=f.path??"";if(!T||p!=null&&!p.includes(T))return;let v=f.actor??Dt(e,T)?.lastMutation?.actor;if(v==null)return;let b="write";this._currentGuard(v,b)||this._publishViolation(v,b,T,"observed")});this.addDisposer(()=>{_(),c.dispose()})}}_publishViolation(e,t,n,s){this.violations.publish({timestamp_ns:B(),wall_clock_ns:oe(),path:n,actor:e,action:t,mode:this._mode,result:s})}all(){return this.violations.retained()}get mode(){return this._mode}get target(){return this._target}};function ur(r,e,t={}){let n=new tt(r,e,t);return n.tagFactory("policyGate",Xt(t)),n}function dr(r,e={}){let t={format_version:1,timestamp_ns:B(),wall_clock_ns:oe(),graph:r.snapshot()};if(e.actor!=null&&(t.actor=e.actor),e.audit!=null){let s=[...e.audit.all()];t.audit={count:s.length,entries:s}}if(e.policies!=null){let s=e.policies.policies.cache??[];t.policies={mode:e.policies.mode,rules:s,violations:[...e.policies.all()]}}let n=lr(t);return{...t,fingerprint:n}}function vn(r){return typeof r=="object"&&r!==null&&"subscribe"in r}function Dt(r,e){try{return r.node(e)}catch{return}}function cr(r,e){try{return r.annotation(e)}catch{return}}function _n(r){let e=r.describe({detail:"minimal"});return Object.keys(e.nodes)}function lr(r){return Ae(JSON.stringify(fr(r)))}function fr(r){let e=new Set,t=n=>{if(n===void 0)return{__undefined:!0};if(n===null)return null;let s=typeof n;if(s==="bigint")return{__bigint:n.toString()};if(s!=="object")return n;let o=n;if(e.has(o))return{__circular:!0};e.add(o);try{if(Array.isArray(o))return o.map(t);if(o instanceof Date)return{__date:o.toISOString()};if(o instanceof RegExp)return{__regexp:{source:o.source,flags:o.flags}};if(o instanceof Map)return{__map:[...o.entries()].map(([u,d])=>[t(u),t(d)])};if(o instanceof Set)return{__set:[...o].map(t)};if(ArrayBuffer.isView(o)){let a=o,u=new Array(a.length);for(let d=0;d<a.length;d++)u[d]=a[d]??0;return{__typed_array:{ctor:o.constructor.name,data:u}}}let i={};for(let a of Object.keys(o).sort())i[a]=t(o[a]);return i}finally{e.delete(o)}};return t(r)}0&&(module.exports={AuditTrailGraph,PolicyGateGraph,auditTrail,complianceSnapshot,policyGate});
@@ -1,8 +1,8 @@
1
- import '../../node-fSc-hCv8.cjs';
2
- import '../../graph-CHsVwf9S.cjs';
3
- import '../../index-BpMZzX9P.cjs';
4
- export { A as AuditEntry, b as AuditTrailGraph, c as AuditTrailOptions, C as ComplianceSnapshotOptions, d as ComplianceSnapshotResult, P as PolicyEnforcerGraph, e as PolicyEnforcerOptions, a as PolicyViolation, f as auditTrail, g as complianceSnapshot, p as policyEnforcer, r as reactiveExplainPath } from '../../index-B2IUcH13.cjs';
5
- import '../../meta-DreaEM_a.cjs';
1
+ import '../../node-BYInONRr.cjs';
2
+ import '../../graph-E6likq7w.cjs';
3
+ import '../../index-Cnr1WrlX.cjs';
4
+ export { A as AuditEntry, b as AuditTrailGraph, c as AuditTrailOptions, C as ComplianceSnapshotOptions, d as ComplianceSnapshotResult, P as PolicyGateGraph, e as PolicyGateOptions, a as PolicyViolation, f as auditTrail, g as complianceSnapshot, p as policyGate } from '../../index-BmSQLAZo.cjs';
5
+ import '../../meta-Ct9nqQS5.cjs';
6
6
  import '../../extra/storage-core.cjs';
7
7
  import '../../extra/storage-tiers.cjs';
8
- import '../../reactive-log-C3IMAGpT.cjs';
8
+ import '../../reactive-log-_zeEnB9H.cjs';
@@ -1,8 +1,8 @@
1
- import '../../node-fSc-hCv8.js';
2
- import '../../graph-BjW1taJl.js';
3
- import '../../index-BUFCHvOR.js';
4
- export { A as AuditEntry, b as AuditTrailGraph, c as AuditTrailOptions, C as ComplianceSnapshotOptions, d as ComplianceSnapshotResult, P as PolicyEnforcerGraph, e as PolicyEnforcerOptions, a as PolicyViolation, f as auditTrail, g as complianceSnapshot, p as policyEnforcer, r as reactiveExplainPath } from '../../index-DJVQ-t07.js';
5
- import '../../meta-BYqlATmg.js';
1
+ import '../../node-BYInONRr.js';
2
+ import '../../graph-BkIkog4h.js';
3
+ import '../../index-40ZT4MHj.js';
4
+ export { A as AuditEntry, b as AuditTrailGraph, c as AuditTrailOptions, C as ComplianceSnapshotOptions, d as ComplianceSnapshotResult, P as PolicyGateGraph, e as PolicyGateOptions, a as PolicyViolation, f as auditTrail, g as complianceSnapshot, p as policyGate } from '../../index-Ck35nA-T.js';
5
+ import '../../meta-D8OyedKp.js';
6
6
  import '../../extra/storage-core.js';
7
7
  import '../../extra/storage-tiers.js';
8
- import '../../reactive-log-BgWSA1fg.js';
8
+ import '../../reactive-log-BlAsPLl2.js';
@@ -1 +1 @@
1
- import{a,b,c,d,e,f}from"../../chunk-XLYF4LBH.js";import"../../chunk-6KZZ6XQE.js";import"../../chunk-O32GJOUJ.js";import"../../chunk-NSAZ6PR6.js";import"../../chunk-PHXZRR6C.js";import"../../chunk-QMC2PLNM.js";import"../../chunk-SGS4OJGS.js";import"../../chunk-ESMPEKEV.js";import"../../chunk-DQJLC6YY.js";import"../../chunk-7KZZLWZ6.js";import"../../chunk-RZ5HKPGI.js";import"../../chunk-LYCLF26R.js";import"../../chunk-CK2E7BTU.js";import"../../chunk-QYADASLV.js";export{a as AuditTrailGraph,c as PolicyEnforcerGraph,b as auditTrail,f as complianceSnapshot,d as policyEnforcer,e as reactiveExplainPath};
1
+ import{a,b,c,d,e}from"../../chunk-VMF23LGB.js";import"../../chunk-J63M5U46.js";import"../../chunk-ECQRP2UT.js";import"../../chunk-3G5U5QNE.js";import"../../chunk-C72GO4IZ.js";import"../../chunk-4I45FVQS.js";import"../../chunk-L6NSJVJZ.js";import"../../chunk-2BX4NB34.js";import"../../chunk-SGS4OJGS.js";import"../../chunk-ESMPEKEV.js";import"../../chunk-35JTVPOX.js";import"../../chunk-YXDRGKXP.js";import"../../chunk-CKFQS2CJ.js";import"../../chunk-LYCLF26R.js";import"../../chunk-CK2E7BTU.js";import"../../chunk-QYADASLV.js";export{a as AuditTrailGraph,c as PolicyGateGraph,b as auditTrail,e as complianceSnapshot,d as policyGate};