@graphrefly/graphrefly 0.41.0 → 0.43.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 (296) hide show
  1. package/dist/{cascading-Cxs1eztH.d.cts → cascading-CH-_VwG9.d.cts} +2 -2
  2. package/dist/{cascading-BNfxffgc.d.ts → cascading-OgKQZjsa.d.ts} +2 -2
  3. package/dist/chunk-3XDYJRYU.js +1 -0
  4. package/dist/{chunk-AI7QC7J6.js → chunk-4YAN45KM.js} +1 -1
  5. package/dist/chunk-626TESAC.js +3 -0
  6. package/dist/chunk-6HOSXQKF.js +1 -0
  7. package/dist/{chunk-G3M3IMEV.js → chunk-CUNIRONA.js} +1 -1
  8. package/dist/chunk-EBW4V6JN.js +1 -0
  9. package/dist/chunk-FDQGFWLF.js +1 -0
  10. package/dist/{chunk-33N4TU3X.js → chunk-FG4TKHMC.js} +1 -1
  11. package/dist/{chunk-YQRN4CIV.js → chunk-I7IGYPSL.js} +1 -1
  12. package/dist/chunk-INQD2KRQ.js +1 -0
  13. package/dist/{chunk-7PQLZMOG.js → chunk-JNWRYDJN.js} +1 -1
  14. package/dist/{chunk-TT4C7DXW.js → chunk-JQFH2DV6.js} +1 -1
  15. package/dist/{chunk-M3FQSXEW.js → chunk-K2Q24F5T.js} +1 -1
  16. package/dist/chunk-KVV66NN2.js +1 -0
  17. package/dist/chunk-NON4NLIC.js +45 -0
  18. package/dist/{chunk-CYOSWFT2.js → chunk-O2BLLH7M.js} +3 -3
  19. package/dist/{chunk-OV5AA6HJ.js → chunk-OCKEEPRJ.js} +1 -1
  20. package/dist/{chunk-X7QKTXXC.js → chunk-OFZG3TB3.js} +3 -3
  21. package/dist/chunk-OYJKFY7V.js +1 -0
  22. package/dist/{chunk-SC27WTSG.js → chunk-P6C4WHZO.js} +1 -1
  23. package/dist/{chunk-VV62MIG4.js → chunk-PT7W5FCD.js} +1 -1
  24. package/dist/{chunk-UISPDFJ3.js → chunk-Q4U3A3L5.js} +1 -1
  25. package/dist/chunk-QE4IGY7I.js +61 -0
  26. package/dist/{chunk-5VEZLQFN.js → chunk-QYVXF7GW.js} +1 -1
  27. package/dist/{chunk-ZAJ7J7TO.js → chunk-S3EEIPO7.js} +1 -1
  28. package/dist/{chunk-GI4Q7PNY.js → chunk-SUWT3ZON.js} +1 -1
  29. package/dist/{chunk-CGNOWGV6.js → chunk-TPKQW72B.js} +1 -1
  30. package/dist/{chunk-L77I47VU.js → chunk-V5A7M7RJ.js} +1 -1
  31. package/dist/chunk-VNC3TMVY.js +1 -0
  32. package/dist/{chunk-AK5RHMC5.js → chunk-VOPGGIL7.js} +1 -1
  33. package/dist/chunk-VQ4A6T2A.js +1 -0
  34. package/dist/{chunk-KNVCCBIU.js → chunk-XG62INFA.js} +1 -1
  35. package/dist/{chunk-F7VUYPP6.js → chunk-Y4NI3X7O.js} +1 -1
  36. package/dist/compat/index.cjs +5 -5
  37. package/dist/compat/index.d.cts +16 -16
  38. package/dist/compat/index.d.ts +16 -16
  39. package/dist/compat/index.js +1 -1
  40. package/dist/compat/jotai/index.d.cts +2 -2
  41. package/dist/compat/jotai/index.d.ts +2 -2
  42. package/dist/compat/nanostores/index.d.cts +2 -2
  43. package/dist/compat/nanostores/index.d.ts +2 -2
  44. package/dist/compat/nestjs/index.cjs +5 -5
  45. package/dist/compat/nestjs/index.d.cts +8 -8
  46. package/dist/compat/nestjs/index.d.ts +8 -8
  47. package/dist/compat/nestjs/index.js +1 -1
  48. package/dist/compat/react/index.d.cts +2 -2
  49. package/dist/compat/react/index.d.ts +2 -2
  50. package/dist/compat/solid/index.d.cts +2 -2
  51. package/dist/compat/solid/index.d.ts +2 -2
  52. package/dist/compat/svelte/index.d.cts +2 -2
  53. package/dist/compat/svelte/index.d.ts +2 -2
  54. package/dist/compat/vue/index.d.cts +2 -2
  55. package/dist/compat/vue/index.d.ts +2 -2
  56. package/dist/compat/zustand/index.cjs +3 -3
  57. package/dist/compat/zustand/index.d.cts +4 -4
  58. package/dist/compat/zustand/index.d.ts +4 -4
  59. package/dist/compat/zustand/index.js +1 -1
  60. package/dist/core/index.d.cts +4 -4
  61. package/dist/core/index.d.ts +4 -4
  62. package/dist/{decay-C25AyNAj.d.cts → decay-2ZukgQ4o.d.cts} +2 -2
  63. package/dist/{decay-BnrlbxSv.d.ts → decay-CdEBmDIs.d.ts} +2 -2
  64. package/dist/extra/browser.d.cts +1 -1
  65. package/dist/extra/browser.d.ts +1 -1
  66. package/dist/extra/index.cjs +14 -14
  67. package/dist/extra/index.d.cts +10 -11
  68. package/dist/extra/index.d.ts +10 -11
  69. package/dist/extra/index.js +1 -1
  70. package/dist/extra/node.cjs +2 -2
  71. package/dist/extra/node.d.cts +1 -1
  72. package/dist/extra/node.d.ts +1 -1
  73. package/dist/extra/node.js +1 -1
  74. package/dist/extra/operators.cjs +1 -1
  75. package/dist/extra/operators.d.cts +1 -1
  76. package/dist/extra/operators.d.ts +1 -1
  77. package/dist/extra/operators.js +1 -1
  78. package/dist/extra/reactive.d.cts +3 -3
  79. package/dist/extra/reactive.d.ts +3 -3
  80. package/dist/extra/reactive.js +1 -1
  81. package/dist/extra/render/index.d.cts +3 -3
  82. package/dist/extra/render/index.d.ts +3 -3
  83. package/dist/extra/sources.cjs +3 -1
  84. package/dist/extra/sources.d.cts +1 -1
  85. package/dist/extra/sources.d.ts +1 -1
  86. package/dist/extra/sources.js +1 -1
  87. package/dist/extra/storage-browser.d.cts +1 -1
  88. package/dist/extra/storage-browser.d.ts +1 -1
  89. package/dist/{fallback-CMZl39L5.d.ts → fallback-CqYVLL6X.d.ts} +1 -1
  90. package/dist/{fallback-8JYU8tlT.d.cts → fallback-Ctlj2tMY.d.cts} +1 -1
  91. package/dist/graph/index.cjs +7 -7
  92. package/dist/graph/index.d.cts +5 -5
  93. package/dist/graph/index.d.ts +5 -5
  94. package/dist/graph/index.js +1 -1
  95. package/dist/{graph-BkIkog4h.d.ts → graph-7VguS7a4.d.ts} +3 -3
  96. package/dist/{graph-E6likq7w.d.cts → graph-C4SHb3Ly.d.cts} +3 -3
  97. package/dist/{index-DgJc8Zgc.d.cts → index-0rKFCVFp.d.cts} +90 -5
  98. package/dist/{index-BAQrjuZF.d.ts → index-B-i4_g3k.d.ts} +2 -2
  99. package/dist/{index-DpiGqtrs.d.cts → index-B5iz82A3.d.cts} +441 -381
  100. package/dist/{index-Bd91Nmf4.d.cts → index-BAOD98JD.d.cts} +4 -4
  101. package/dist/{index-2n8Eai6M.d.ts → index-BG0BN3PB.d.ts} +1 -1
  102. package/dist/{index-z8WFPVI8.d.cts → index-BJX94aud.d.cts} +1 -1
  103. package/dist/{index-DhLyOHYZ.d.ts → index-BP8a88zx.d.ts} +11 -4
  104. package/dist/{index-Cnr1WrlX.d.cts → index-BTQtTb_H.d.cts} +14 -3
  105. package/dist/{index-DOBLxOti.d.cts → index-BVpm6noz.d.cts} +1 -1
  106. package/dist/{index-Cczxgd2D.d.ts → index-Bc41FuHp.d.cts} +3 -3
  107. package/dist/{index-BiHUBEKq.d.cts → index-BdGtBX-X.d.cts} +3 -3
  108. package/dist/{index-da2V5vPy.d.ts → index-Bf7eqeSF.d.ts} +2 -2
  109. package/dist/{index-DuRsN9ae.d.cts → index-BiX1Nkgx.d.cts} +383 -18
  110. package/dist/{index-DGTo1yka.d.cts → index-BoLv_OfD.d.cts} +2 -2
  111. package/dist/{index-DVAlsmEU.d.cts → index-BojK2fwH.d.cts} +3 -3
  112. package/dist/{index-B72TQQHd.d.cts → index-BsT7F2et.d.ts} +3 -3
  113. package/dist/{index-DGD4_fj6.d.cts → index-BwLvVVsy.d.cts} +8 -5
  114. package/dist/{index-CQtWm7jS.d.ts → index-C59mYFKp.d.ts} +9 -9
  115. package/dist/{index-C6ZUaos7.d.ts → index-C7O6r5fV.d.ts} +1 -1
  116. package/dist/{index-CL7oilfm.d.cts → index-C9kSENB4.d.cts} +1 -1
  117. package/dist/{index-DVDapw2k.d.cts → index-C9pjcz3l.d.cts} +35 -36
  118. package/dist/{index-CG33HeBW.d.ts → index-CAC_rNzm.d.ts} +8 -5
  119. package/dist/{index-yLt-aPMp.d.ts → index-CCq87F7t.d.ts} +1 -1
  120. package/dist/{index-D4uimgee.d.cts → index-CDXc9zKM.d.cts} +1 -1
  121. package/dist/{index-B2RUoIUz.d.ts → index-CJK1JkYy.d.ts} +1 -1
  122. package/dist/{index-DktLSZOc.d.cts → index-CLon-IWF.d.cts} +4 -4
  123. package/dist/{index-DQQCOIt8.d.cts → index-COD1kVoS.d.cts} +10 -5
  124. package/dist/{index-bXXLSvor.d.ts → index-CPT7C_f1.d.ts} +4 -4
  125. package/dist/{index-CD2dBMet.d.ts → index-CQG3D1cp.d.ts} +10 -5
  126. package/dist/{index-BQ1fR4li.d.ts → index-CZQXo5tH.d.ts} +35 -36
  127. package/dist/{index-A3U3CSve.d.cts → index-CZjOhcBy.d.cts} +2 -2
  128. package/dist/{index-DYTBbF8T.d.cts → index-ChOyVLKm.d.cts} +1 -1
  129. package/dist/{index-BJSZxSFX.d.ts → index-CvrqGfNS.d.ts} +1 -1
  130. package/dist/{index-DhnsQfa3.d.ts → index-D-AEQVLo.d.ts} +441 -381
  131. package/dist/{index-CAP3UGsq.d.ts → index-D4Y1cMG0.d.ts} +1 -1
  132. package/dist/{index-40ZT4MHj.d.ts → index-DBHK8O6H.d.ts} +14 -3
  133. package/dist/{index-3k4Gg6-n.d.ts → index-DBevwHj_.d.ts} +3 -3
  134. package/dist/{index-Ctb7_2sG.d.ts → index-DIOoAZUX.d.ts} +1 -1
  135. package/dist/{index-WSlcjhQF.d.ts → index-DSZ3ZCHF.d.ts} +124 -13
  136. package/dist/{index-DH4fm2Ck.d.ts → index-Dgs8zcj7.d.ts} +2 -2
  137. package/dist/{index-BaA-xpSw.d.ts → index-Dh_HJ82K.d.ts} +3 -3
  138. package/dist/{index-CtFNGe-m.d.cts → index-Dhc7a7Xo.d.cts} +2 -2
  139. package/dist/{index-CoM4rzyB.d.ts → index-Dmqp7KjD.d.ts} +1 -1
  140. package/dist/{index-B6iTqKtJ.d.ts → index-Dn-wI9g4.d.ts} +2 -2
  141. package/dist/{index-C-dkXOpB.d.cts → index-Du7u1lSf.d.cts} +11 -4
  142. package/dist/{index-DfOK_oL5.d.ts → index-DwigL4lY.d.ts} +383 -18
  143. package/dist/index-DyR7eU5S.d.cts +779 -0
  144. package/dist/index-JZUPJIJy.d.ts +779 -0
  145. package/dist/{index-I1cCY3ZI.d.ts → index-K0_0eR8g.d.ts} +90 -5
  146. package/dist/{index-BilOa6AE.d.cts → index-O16yXPK4.d.cts} +124 -13
  147. package/dist/{index-CRm0YIzC.d.cts → index-O7fucFrU.d.cts} +9 -9
  148. package/dist/{index-MxYuWOrf.d.cts → index-RV_yDjOX.d.cts} +3 -3
  149. package/dist/{index-C5cQ7Gfx.d.ts → index-cm1GNcWE.d.ts} +4 -4
  150. package/dist/{index-CgnCFhr2.d.cts → index-f5IivDUX.d.cts} +1 -1
  151. package/dist/{index-PgwvGWa1.d.cts → index-hHcaFlJX.d.cts} +1 -1
  152. package/dist/{index-tV3AA9hI.d.cts → index-tJoTcnHh.d.cts} +2 -2
  153. package/dist/{index-eaQuGJnv.d.ts → index-wAzD9yVj.d.ts} +3 -3
  154. package/dist/{index-D3ayz3hy.d.cts → index-z96luz5O.d.cts} +1 -1
  155. package/dist/index.cjs +48 -48
  156. package/dist/index.d.cts +45 -50
  157. package/dist/index.d.ts +45 -50
  158. package/dist/index.js +1 -1
  159. package/dist/{meta-D8OyedKp.d.ts → meta-BgVAsg9j.d.ts} +1 -1
  160. package/dist/{meta-Ct9nqQS5.d.cts → meta-vE8bxW1E.d.cts} +1 -1
  161. package/dist/{node-BYInONRr.d.cts → node-ClS5yC-B.d.cts} +1 -1
  162. package/dist/{node-BYInONRr.d.ts → node-ClS5yC-B.d.ts} +1 -1
  163. package/dist/{observable-DO8DDEzv.d.ts → observable-BsBzUrcI.d.ts} +1 -1
  164. package/dist/{observable-DMIlYJV1.d.cts → observable-DLGPPtb8.d.cts} +1 -1
  165. package/dist/patterns/ai/browser.d.cts +4 -4
  166. package/dist/patterns/ai/browser.d.ts +4 -4
  167. package/dist/patterns/ai/browser.js +1 -1
  168. package/dist/patterns/ai/index.cjs +17 -17
  169. package/dist/patterns/ai/index.d.cts +17 -17
  170. package/dist/patterns/ai/index.d.ts +17 -17
  171. package/dist/patterns/ai/index.js +1 -1
  172. package/dist/patterns/ai/node.d.cts +4 -4
  173. package/dist/patterns/ai/node.d.ts +4 -4
  174. package/dist/patterns/ai/node.js +1 -1
  175. package/dist/patterns/cqrs/index.cjs +3 -3
  176. package/dist/patterns/cqrs/index.d.cts +6 -6
  177. package/dist/patterns/cqrs/index.d.ts +6 -6
  178. package/dist/patterns/cqrs/index.js +1 -1
  179. package/dist/patterns/demo-shell/index.cjs +5 -5
  180. package/dist/patterns/demo-shell/index.d.cts +5 -5
  181. package/dist/patterns/demo-shell/index.d.ts +5 -5
  182. package/dist/patterns/demo-shell/index.js +1 -1
  183. package/dist/patterns/domain-templates/index.cjs +3 -3
  184. package/dist/patterns/domain-templates/index.d.cts +4 -4
  185. package/dist/patterns/domain-templates/index.d.ts +4 -4
  186. package/dist/patterns/domain-templates/index.js +1 -1
  187. package/dist/patterns/graphspec/index.cjs +12 -12
  188. package/dist/patterns/graphspec/index.d.cts +5 -5
  189. package/dist/patterns/graphspec/index.d.ts +5 -5
  190. package/dist/patterns/graphspec/index.js +1 -1
  191. package/dist/patterns/harness/index.cjs +10 -8
  192. package/dist/patterns/harness/index.d.cts +11 -12
  193. package/dist/patterns/harness/index.d.ts +11 -12
  194. package/dist/patterns/harness/index.js +1 -1
  195. package/dist/patterns/inspect/index.cjs +3 -0
  196. package/dist/patterns/inspect/index.d.cts +9 -0
  197. package/dist/patterns/inspect/index.d.ts +9 -0
  198. package/dist/patterns/inspect/index.js +1 -0
  199. package/dist/patterns/job-queue/index.cjs +3 -3
  200. package/dist/patterns/job-queue/index.d.cts +6 -6
  201. package/dist/patterns/job-queue/index.d.ts +6 -6
  202. package/dist/patterns/job-queue/index.js +1 -1
  203. package/dist/patterns/memory/index.cjs +3 -3
  204. package/dist/patterns/memory/index.d.cts +6 -6
  205. package/dist/patterns/memory/index.d.ts +6 -6
  206. package/dist/patterns/memory/index.js +1 -1
  207. package/dist/patterns/messaging/index.cjs +3 -3
  208. package/dist/patterns/messaging/index.d.cts +5 -5
  209. package/dist/patterns/messaging/index.d.ts +5 -5
  210. package/dist/patterns/messaging/index.js +1 -1
  211. package/dist/patterns/orchestration/index.cjs +3 -3
  212. package/dist/patterns/orchestration/index.d.cts +7 -7
  213. package/dist/patterns/orchestration/index.d.ts +7 -7
  214. package/dist/patterns/orchestration/index.js +1 -1
  215. package/dist/patterns/process/index.cjs +1 -1
  216. package/dist/patterns/process/index.d.cts +7 -7
  217. package/dist/patterns/process/index.d.ts +7 -7
  218. package/dist/patterns/process/index.js +1 -1
  219. package/dist/patterns/reactive-layout/index.cjs +4 -4
  220. package/dist/patterns/reactive-layout/index.d.cts +5 -5
  221. package/dist/patterns/reactive-layout/index.d.ts +5 -5
  222. package/dist/patterns/reactive-layout/index.js +1 -1
  223. package/dist/patterns/reduction/index.cjs +3 -3
  224. package/dist/patterns/reduction/index.d.cts +4 -4
  225. package/dist/patterns/reduction/index.d.ts +4 -4
  226. package/dist/patterns/reduction/index.js +1 -1
  227. package/dist/patterns/surface/index.cjs +8 -8
  228. package/dist/patterns/surface/index.d.cts +6 -6
  229. package/dist/patterns/surface/index.d.ts +6 -6
  230. package/dist/patterns/surface/index.js +1 -1
  231. package/dist/{pipeline-graph-MWrQZXCq.d.cts → pipeline-graph-DPqKDk59.d.cts} +5 -5
  232. package/dist/{pipeline-graph-CB4La-UW.d.ts → pipeline-graph-loP57TBA.d.ts} +5 -5
  233. package/dist/{reactive-layout-BtZfUKuL.d.cts → reactive-layout-Dsvob4zD.d.cts} +2 -2
  234. package/dist/{reactive-layout-KJj4E2dT.d.ts → reactive-layout-v7KPvxoc.d.ts} +2 -2
  235. package/dist/{reactive-log-_zeEnB9H.d.cts → reactive-log-B00laMSQ.d.cts} +1 -1
  236. package/dist/{reactive-log-BlAsPLl2.d.ts → reactive-log-BezYsbA_.d.ts} +1 -1
  237. package/dist/{reactive-map-6P_k3AQM.d.cts → reactive-map-48mnZ-nu.d.cts} +1 -1
  238. package/dist/{reactive-map-CjXByDV-.d.ts → reactive-map-BVVPdvmi.d.ts} +1 -1
  239. package/dist/resilience-YIWPK4YC.js +1 -0
  240. package/dist/{sugar-DzePN5-g.d.cts → sugar-DLwvMr3F.d.ts} +24 -4
  241. package/dist/{sugar-BhfjgetH.d.ts → sugar-DyVGtczU.d.cts} +24 -4
  242. package/dist/{topology-tree-mF7Emqzm.d.ts → topology-tree-BNGvuG82.d.ts} +1 -1
  243. package/dist/{topology-tree-3LBKFsUo.d.cts → topology-tree-BSdfSwMi.d.cts} +1 -1
  244. package/dist/{types-1Dhoi7HM.d.cts → types-B1jDWVsM.d.cts} +1 -1
  245. package/dist/{types-39jk0kaV.d.ts → types-DkzUUs0H.d.ts} +1 -1
  246. package/package.json +11 -51
  247. package/dist/budget-gate-CmmVtasH.d.ts +0 -115
  248. package/dist/budget-gate-DiP_nK0n.d.cts +0 -115
  249. package/dist/chunk-2W553JJC.js +0 -1
  250. package/dist/chunk-4MKL6Q3K.js +0 -1
  251. package/dist/chunk-5B3JDG5F.js +0 -1
  252. package/dist/chunk-5QSXEMXG.js +0 -1
  253. package/dist/chunk-5TEFC2ZX.js +0 -1
  254. package/dist/chunk-5TOPVRN6.js +0 -1
  255. package/dist/chunk-EC2WNSZ7.js +0 -1
  256. package/dist/chunk-ELAASRBT.js +0 -3
  257. package/dist/chunk-H5SCWHWP.js +0 -1
  258. package/dist/chunk-OLIKJUKI.js +0 -1
  259. package/dist/chunk-POXANAJ6.js +0 -3
  260. package/dist/chunk-RSMEXK53.js +0 -43
  261. package/dist/chunk-SGS4OJGS.js +0 -1
  262. package/dist/chunk-URJ2VFNC.js +0 -1
  263. package/dist/chunk-VXPLLA4P.js +0 -1
  264. package/dist/chunk-WZYB3JQS.js +0 -1
  265. package/dist/chunk-Z6X7B6A4.js +0 -61
  266. package/dist/index-8s-Qm-gz.d.ts +0 -218
  267. package/dist/index-BgjS2b8N.d.ts +0 -366
  268. package/dist/index-BmSQLAZo.d.cts +0 -244
  269. package/dist/index-CGhMJNHb.d.cts +0 -128
  270. package/dist/index-CUIkE1l9.d.cts +0 -230
  271. package/dist/index-Ck35nA-T.d.ts +0 -244
  272. package/dist/index-CuPUehFa.d.cts +0 -218
  273. package/dist/index-D1Gc7wV5.d.ts +0 -230
  274. package/dist/index-N2MAxt7_.d.ts +0 -128
  275. package/dist/index-t6L2qpHh.d.cts +0 -366
  276. package/dist/patterns/audit/index.cjs +0 -3
  277. package/dist/patterns/audit/index.d.cts +0 -8
  278. package/dist/patterns/audit/index.d.ts +0 -8
  279. package/dist/patterns/audit/index.js +0 -1
  280. package/dist/patterns/guarded-execution/index.cjs +0 -3
  281. package/dist/patterns/guarded-execution/index.d.cts +0 -9
  282. package/dist/patterns/guarded-execution/index.d.ts +0 -9
  283. package/dist/patterns/guarded-execution/index.js +0 -1
  284. package/dist/patterns/lens/index.cjs +0 -3
  285. package/dist/patterns/lens/index.d.cts +0 -7
  286. package/dist/patterns/lens/index.d.ts +0 -7
  287. package/dist/patterns/lens/index.js +0 -1
  288. package/dist/patterns/refine-loop/index.cjs +0 -5
  289. package/dist/patterns/refine-loop/index.d.cts +0 -9
  290. package/dist/patterns/refine-loop/index.d.ts +0 -9
  291. package/dist/patterns/refine-loop/index.js +0 -1
  292. package/dist/patterns/resilient-pipeline/index.cjs +0 -3
  293. package/dist/patterns/resilient-pipeline/index.d.cts +0 -8
  294. package/dist/patterns/resilient-pipeline/index.d.ts +0 -8
  295. package/dist/patterns/resilient-pipeline/index.js +0 -1
  296. package/dist/resilience-JISHQD2F.js +0 -1
@@ -1,3 +0,0 @@
1
- "use strict";var st=Object.defineProperty;var On=Object.getOwnPropertyDescriptor;var Nn=Object.getOwnPropertyNames;var kn=Object.prototype.hasOwnProperty;var j=(r,e)=>()=>(r&&(e=r(r=0)),e);var xn=(r,e)=>{for(var t in e)st(r,t,{get:e[t],enumerable:!0})},En=(r,e,t,n)=>{if(e&&typeof e=="object"||typeof e=="function")for(let s of Nn(e))!kn.call(r,s)&&s!==t&&st(r,s,{get:()=>e[s],enumerable:!(n=On(e,s))||n.enumerable});return r};var An=r=>En(st({},"__esModule",{value:!0}),r);function W(){return Math.trunc(performance.now()*1e6)}function he(){return Date.now()*1e6}var ge=j(()=>{"use strict"});var me,D,K,q,X,ee,re,F,V,$,ae,$e,Ct,Ie,Mt,Pt,Le,ot,it,at,Fe,se=j(()=>{"use strict";me=Symbol.for("graphrefly/START"),D=Symbol.for("graphrefly/DATA"),K=Symbol.for("graphrefly/DIRTY"),q=Symbol.for("graphrefly/RESOLVED"),X=Symbol.for("graphrefly/INVALIDATE"),ee=Symbol.for("graphrefly/PAUSE"),re=Symbol.for("graphrefly/RESUME"),F=Symbol.for("graphrefly/TEARDOWN"),V=Symbol.for("graphrefly/COMPLETE"),$=Symbol.for("graphrefly/ERROR"),ae=Object.freeze([K]),$e=Object.freeze([q]),Ct=Object.freeze([X]),Ie=Object.freeze([me]),Mt=Object.freeze([V]),Pt=Object.freeze([F]),Le=Object.freeze([ae]),ot=Object.freeze([$e]),it=Object.freeze([Ct]),at=Object.freeze([Mt]),Fe=Object.freeze([Pt])});function It(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++]=dt,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 Lt(r,e){if(r.length<$t)throw new Error(`decodeEnvelope: bytes too short (${r.length} < ${$t})`);let t=0,n=r[t++];if(n!==dt)throw new Error(`decodeEnvelope: unsupported envelope version ${n} (expected ${dt})`);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),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 Ft(r){r.registerCodec(Sn)}var Sn,dt,$t,ut=j(()=>{"use strict";Sn={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)}},dt=1,$t=4});function Ve(r){if(r==null)return be;let{type:e,id:t,...n}=r;return{type:e??"system",id:t??"",...n}}var be,ze=j(()=>{"use strict";be={type:"system",id:""}});function je(){return ye>0||Ae}function Vt(){return ye>0}function _e(r){ye>0?Se.push(r):r()}function ce(r){ye+=1;let e=!1;try{r()}catch(t){throw e=!0,t}finally{if(ye-=1,ye===0)if(e){if(!Ae){let t=Se.splice(0);for(let n of t)try{n()}catch{}de.length=0,ue.length=0,ve.length=0}}else Rn()}}function Rn(){let r=!Ae;r&&(Ae=!0);let e=[],t=0;try{for(;de.length>0||ue.length>0||ve.length>0||r&&Se.length>0;){if(r&&Se.length>0){let o=Se.splice(0);for(let i of o)try{i()}catch(a){e.push(a)}continue}if(t+=1,t>1e3)throw de.length=0,ue.length=0,ve.length=0,new Error("batch drain exceeded 1000 iterations \u2014 likely a reactive cycle");let s=(de.length>0?de:ue.length>0?ue:ve).splice(0);for(let o of s)try{o()}catch(i){e.push(i)}}}finally{r&&(Ae=!1)}if(e.length===1)throw e[0];if(e.length>1)throw new AggregateError(e,"batch drain: multiple callbacks threw")}function He(r,e,t){if(e.length===0)return;if(e.length===1){let u=t(e[0][0]);if(u<3||!je()){r(e);return}(u>=5?ve:u===4?ue:de).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 d=je();if(s>0){let u=e.slice(0,s);r(u)}if(o>s){let u=e.slice(s,o);d?de.push(()=>r(u)):r(u)}if(i>o){let u=e.slice(o,i);d?ue.push(()=>r(u)):r(u)}if(n>i){let u=e.slice(i,n);d?ve.push(()=>r(u)):r(u)}}var ye,Ae,de,ue,ve,Se,Re=j(()=>{"use strict";ye=0,Ae=!1,de=[],ue=[],ve=[],Se=[]});function zt(r){r.registerMessageType(me,{tier:0,wireCrossing:!1}),r.registerMessageType(K,{tier:1,wireCrossing:!1}),r.registerMessageType(X,{tier:1,wireCrossing:!1,metaPassthrough:!1}),r.registerMessageType(ee,{tier:2,wireCrossing:!1}),r.registerMessageType(re,{tier:2,wireCrossing:!1}),r.registerMessageType(D,{tier:3,wireCrossing:!0}),r.registerMessageType(q,{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 Be,jt=j(()=>{"use strict";se();Be=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){return Array.isArray(r)?[...r]:[r]}function Dn(r,e){return r.has(e)||r.has("*")}function Gn(r){let e=[];return r((s,o)=>{e.push({kind:"allow",actions:new Set(Ht(s)),where:o?.where??(()=>!0)})},(s,o)=>{e.push({kind:"deny",actions:new Set(Ht(s)),where:o?.where??(()=>!0)})}),(s,o)=>{let i=!1,a=!1;for(let d of e)Dn(d.actions,o)&&d.where(s)&&(d.kind==="deny"?i=!0:a=!0);return i?!1:a}}function ct(r){return Gn((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=d=>{if(s!==null&&!s.has(String(d.type))||o!==null&&!o.has(String(d.id??"")))return!1;for(let[u,l]of i)if(d[u]!==l)return!1;return!0};n.effect==="deny"?t(n.action,{where:a}):e(n.action,{where:a})}})}function lt(r){let e=Cn.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 Z,Cn,we=j(()=>{"use strict";Z=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}};Cn=["human","llm","wallet","system"]});function pt(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(pt);if(typeof r=="object"&&r!==null){let e={};for(let t of Object.keys(r).sort())e[t]=pt(r[t]);return e}return null}function $n(r){let e=Pn.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,d=3144134277,u=1013904242,l=2773480762,g=1359893119,f=2600822924,h=528734635,c=1541459225,_=new Uint32Array(64),p=(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],G=_[N-2],R=p(S,7)^p(S,18)^S>>>3,oe=p(G,17)^p(G,19)^G>>>10;_[N]=_[N-16]+R+_[N-7]+oe>>>0}let b=a,y=d,w=u,k=l,m=g,O=f,x=h,A=c;for(let N=0;N<64;N++){let S=p(m,6)^p(m,11)^p(m,25),G=m&O^~m&x,R=A+S+G+Mn[N]+_[N]>>>0,oe=p(b,2)^p(b,13)^p(b,22),ne=b&y^b&w^y&w,Me=oe+ne>>>0;A=x,x=O,O=m,m=k+R>>>0,k=w,w=y,y=b,b=R+Me>>>0}a=a+b>>>0,d=d+y>>>0,u=u+w>>>0,l=l+k>>>0,g=g+m>>>0,f=f+O>>>0,h=h+x>>>0,c=c+A>>>0}let T=v=>v.toString(16).padStart(8,"0");return T(a)+T(d)+T(u)+T(l)+T(g)+T(f)+T(h)+T(c)}function ft(r){let e=pt(r??null),t=JSON.stringify(e);return $n(t).slice(0,16)}function In(){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 ht(r,e,t){let n=t?.id??In();if(r===0)return{id:n,version:0};let o=(t?.hash??ft)(e);return{id:n,version:0,cid:o,prev:null}}function Bt(r,e,t){r.version+=1,"cid"in r&&(r.prev=r.cid,r.cid=t(e))}var Mn,Pn,Ut=j(()=>{"use strict";Mn=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]),Pn=new TextEncoder});function qt(r){return{node:r,unsub:null,prevData:void 0,dirty:!1,involvedThisWave:!1,dataBatch:[],terminal:void 0}}function gt(r){r.prevData=void 0,r.dirty=!1,r.involvedThisWave=!1,r.dataBatch.length=0,r.terminal=void 0}function Ue(r){return r.length===0?r:typeof r[0]=="symbol"?[r]:r}function Oe(r,e,t){let n=Yt(r)?r:[],s=typeof r=="function"?r:typeof e=="function"?e:void 0,o={};return Yt(r)?o=(mt(e)?e:t)??{}:mt(r)?o=r:o=(mt(e)?e:t)??{},new I(n,s,o)}var Wt,Kt,Ln,Fn,Te,I,Yt,mt,le=j(()=>{"use strict";ut();ze();Re();ge();jt();we();se();Ut();Wt=()=>{},Kt=100;Ln=(r,e,t,n)=>{t.direction==="down-in"&&r._onDepMessage(t.depIndex,e)},Fn=(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,[D,o]];s._status==="dirty"&&i.push(ae),He(e,i,s._config.tierOf)},Te=new Be({onMessage:Ln,onSubscribe:Fn});zt(Te);Ft(Te);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??Te,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??ft;let s=n.versioning??this._config.defaultVersioning;this._versioningLevel=s,this._versioning=s!=null?ht(s,this._cached===void 0?void 0:this._cached,{id:n.versioningId,hash:this._hashFn}):void 0,this._deps=e.map(qt);let o={};for(let[a,d]of Object.entries(n.meta??{})){let u={initial:d,name:`${n.name??"node"}:meta:${a}`,describeKind:"state",config:this._config};n.guard!=null&&(u.guard=n.guard),o[a]=new r([],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([[D,a]])},down(a){i._emit(Ue(a))},up(a){i._emitUp(Ue(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,d=i?.version??0,u=ht(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 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 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:he()}}down(e,t){let n=Ue(e);n.length!==0&&(this._checkGuard(t),this._emit(n))}emit(e,t){this._checkGuard(t),this._emit([[D,e]])}up(e,t){if(this._deps.length===0)return;let n=Ue(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 d=Ve(t);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)gt(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[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=Wt,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()}),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{}gt(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=qt(e);if(this._deps.push(n),this._sinks==null)return t;n.dirty=!0,this._dirtyDepCount++,this._status!=="dirty"&&this._emit(Le),n.unsub=Wt;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{}}gt(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!==me){if(s===K){this._depDirtied(n);return}if(s===X){if(this._depInvalidated(n),this._cached===void 0)return;this._emit(it);return}if(s===ee||s===re){this._emit([t]);return}if(s===F){this._emit(Fe);return}if(s===D)this._depSettledAsData(n,t[1]);else if(s===q)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===D||s===q)&&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(ot),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(at)}_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>Kt?(this._rerunDepth=0,this._emit([[$,new Error(`Node "${this.name}": _pendingRerun depth exceeded ${Kt} \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"?[ae,e[0]]:e;let n=!0,s=!1,o=!1,i=-1;for(let d of e){let u=t(d[0]);u<i&&(n=!1),u===3&&(s=!0),d[0]===K&&(o=!0),i=u}let a=e;if(!n){let d=e.map((u,l)=>({m:u,i:l,tier:t(u[0])}));d.sort((u,l)=>u.tier-l.tier||u.i-l.i),a=d.map(u=>u.m)}if(s&&!o&&this._status!=="dirty"){let d=0;for(;d<a.length&&t(a[d][0])===0;)d++;return d===0?[ae,...a]:[...a.slice(0,d),ae,...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]===$&&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 t=e;if(this._isTerminal&&!this._resubscribable){let a=e.filter(d=>d[0]===F||d[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 d=t[a],u=d[0];if(u!==ee&&u!==re){s?.push(d);continue}if(d.length<2)throw new Error(`Node "${this.name}": [[${u===ee?"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 g=d[1];if(u===ee)this._pauseLocks==null&&(this._pauseLocks=new Set),this._pauseLocks.add(g),this._paused=!0,this._pausable==="resumeAll"&&this._pauseBuffer==null&&(this._pauseBuffer=[]);else if(this._pauseLocks==null||!this._pauseLocks.has(g))l=!1;else if(this._pauseLocks.delete(g),this._pauseLocks.size===0){if(this._paused=!1,this._pauseBuffer!=null&&this._pauseBuffer.length>0){let f=this._pauseBuffer;this._pauseBuffer=[],this._emit(f)}this._pendingWave&&(this._pendingWave=!1,this._maybeRunFnOnSettlement())}}l?s?.push(d):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,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]])}_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,d=-1;if(this._versioning!=null&&i>1){for(let l=e.length-1;l>=0;l--)if(e[l][0]===D){d=l;break}}for(let l=0;l<e.length;l++){let g=e[l],f=g[0];if(f===D){if(g.length>=2){let h=!1;if(a&&this._cached!==void 0)try{h=this._equals(this._cached,g[1])}catch(c){s=this._wrapFnError("equals threw",c),o=l;break}if(h){n==null&&(n=e.slice(0,l)),n.push($e),this._status="resolved";continue}this._cached=g[1],this._versioning!=null&&(d<0||l===d)&&Bt(this._versioning,g[1],this._hashFn)}this._status="settled",n?.push(g)}else if(n?.push(g),f===K)this._status="dirty";else if(f===q)this._status="resolved";else if(f===V){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(f===$){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(f===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 h=this._cleanup;if(typeof h=="function"){this._cleanup=void 0;try{h()}catch{}}else if(h!=null&&typeof h=="object"){let c=h.invalidate;if(typeof c=="function")try{c()}catch{}}}else f===F&&(this._resetOnTeardown&&(this._cached=void 0),this._deactivate(!0),this._status="sentinel")}let u=o>=0?n??e.slice(0,o):n??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 t=[...this._sinks];for(let n of t)n(e)};_dispatchOrAccumulate(e){if(Vt()){this._batchPendingMessages===null&&(this._batchPendingMessages=[],_e(()=>this._flushBatchPending()));for(let t of e)this._batchPendingMessages.push(t);return}He(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);He(this._deliverToSinks,t,this._config.tierOf)}},Yt=r=>Array.isArray(r),mt=r=>typeof r=="object"&&r!=null&&!Array.isArray(r)});function H(r,e){return Oe([],{...e,initial:r})}function We(r,e){return Oe((n,s,o)=>r(s,o)??void 0,{describeKind:"producer",...e})}function z(r,e,t){return Oe(r,(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",...t})}var Ne=j(()=>{"use strict";le()});function ke(r,e,t){return{[r]:!0,[`${r}_type`]:e,...t??{}}}var Ke=j(()=>{"use strict"});function te(r){return r.subscribe(()=>{})}var Jt=j(()=>{"use strict"});var De=j(()=>{"use strict";Jt()});function yt(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 Wn(r){return r._describeKind!=null?r._describeKind:r._deps.length>0?"derived":r._fn!=null?"producer":"state"}function nn(r){let e=new WeakSet,t={};for(let[n,s]of rn(r))t[n]=bt(s,e);return t}function bt(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=>bt(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 rn(n))s[o]=bt(i,e);return s}return"<unserializable>"}function rn(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 Kn(r){let e={};for(let[t,n]of Object.entries(r.meta))try{e[t]=n.cache}catch{}return e}function vt(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=Wn(r),a=r._deps.map(l=>l.node.name??""));let d={type:i,deps:a};(n||e.has("status"))&&(d.status=r.status);let u=r instanceof I?r._guard:void 0;if(o){let l={...Kn(r)};if(u!=null&&l.access===void 0&&(l.access=lt(u)),s!=null&&s.length>0&&!e.has("meta")){let g={};for(let f of s)f in l&&(g[f]=l[f]);d.meta=g}else d.meta=l}if(r.name!=null&&(d.name=r.name),(n||e.has("value"))&&(!t||i==="state")){r.status==="sentinel"&&(d.sentinel=!0);try{d.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),d.v=l}return(n||e.has("guard"))&&u!=null&&(d.guard=lt(u)),(n||e.has("lastMutation"))&&r.lastMutation!=null&&(d.lastMutation=r.lastMutation),d}var _t=j(()=>{"use strict";we();le()});var Xe,on=j(()=>{"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 Ge,an=j(()=>{"use strict";Ge=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 cr={};xn(cr,{GuardedExecutionGraph:()=>Qe,guardedExecution:()=>ur});module.exports=An(cr);ge();se();Ne();Ke();De();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},Vn=Symbol.for("sizeof");function Xt(r){let e=new WeakSet,t=new WeakSet,n=[r],s=0;for(;n.length>0;){let o=n.pop();s+=zn(o,e,t,n)}return s}function zn(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+jn(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[Vn];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 L.date;if(o instanceof RegExp)return L.regexp+o.source.length*2;if(o instanceof Error){let u=o.message?o.message.length*2:0,l=o.stack?o.stack.length*2:0;return L.error+u+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 u=L.map;for(let[l,g]of o)u+=L.mapEntry,n.push(l),n.push(g);return u}if(o instanceof Set){let u=L.set;for(let l of o)u+=L.setEntry,n.push(l);return u}if(Array.isArray(o)){let u=L.array+o.length*8;for(let l of o)n.push(l);return u}if(o instanceof ArrayBuffer)return t.has(o)?0:(t.add(o),o.byteLength);if(ArrayBuffer.isView(o)){let u=o;return t.has(u.buffer)?48:(t.add(u.buffer),u.buffer.byteLength+48)}let a=L.object,d=Object.keys(o);for(let u of d){a+=L.string+u.length*2;try{n.push(o[u])}catch{}}return a}function jn(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 Zt(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 u=Hn(r,e,n);if(u!=null)return u}let d=Ye(e,r.nodes[e],0,n);return Je(e,t,[d])}if(i===0)return qe(e,t,"no-path");let a=Qt(r,e,t,i);return a.found?Je(e,t,en(r,a.pathOrder,n)):qe(e,t,a.truncated?"max-depth-exceeded":"no-path")}function Qt(r,e,t,n){let s=new Map,o=[{path:t,depth:0}],i=new Set([t]),a=0,d=!1;for(;a<o.length;){let g=o[a++];if(g.path===e)break;if(n!=null&&g.depth>=n){let _=r.nodes[g.path];_?.deps&&_.deps.length>0&&(d=!0);continue}let f=r.nodes[g.path];if(f==null)continue;let h=f.deps??[],c=new Map;for(let _=0;_<h.length;_++){let p=h[_];if(!p)continue;let T=c.get(p);T==null&&(T=[],c.set(p,T)),T.push(_)}for(let[_,p]of c)i.has(_)||(i.add(_),s.set(_,{from:g.path,depIndices:p}),o.push({path:_,depth:g.depth+1}))}if(!s.has(e))return{found:!1,pathOrder:[],truncated:d};let u=[{path:e}],l=e;for(;l!==t;){let g=s.get(l);if(g==null)return{found:!1,pathOrder:[],truncated:!1};u[u.length-1].depIndices=g.depIndices,u.push({path:g.from}),l=g.from}return{found:!0,pathOrder:u,truncated:!1}}function Hn(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 d=Ye(e,n,1,t);return Je(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=Qt(r,d,e,t.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:Je(e,e,en(r,i.pathOrder,t))}function en(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 tn(r,e,!0,"ok",t)}function qe(r,e,t){return tn(r,e,!1,t,[])}function tn(r,e,t,n,s){let o=Bn(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 Bn(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 d=` ${i.hop===0?"\xB7":"\u2193"} ${i.path} (${i.type}${i.status?`/${i.status}`:""})`;if(o.push(d),"value"in i&&o.push(` value: ${Un(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 Un(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();Re();ge();we();se();_t();le();Ne();ge();function wt(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(!wt(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)||!wt(r[o],e[o]))return!1;return!0}function sn(r,e){return`${r}\0${e}`}function Tt(r,e){let t=[],n=new Set(r.subgraphs),s=new Set(e.subgraphs),o=[];for(let p of s)n.has(p)||o.push(p);o.sort();for(let p of o)t.push({type:"subgraph-mounted",path:p});let i=new Set(Object.keys(r.nodes)),a=new Set(Object.keys(e.nodes)),d=[];for(let p of a)i.has(p)||d.push(p);d.sort();for(let p of d)t.push({type:"node-added",path:p,node:{...e.nodes[p]}});let u=[];for(let p of a){if(!i.has(p))continue;let T=r.nodes[p]?.meta,v=e.nodes[p]?.meta;T==null&&v==null||wt(T??{},v??{})||u.push(p)}u.sort();for(let p of u)t.push({type:"node-meta-changed",path:p,prevMeta:r.nodes[p]?.meta??{},nextMeta:e.nodes[p]?.meta??{}});let l=new Map;for(let p of r.edges)l.set(sn(p.from,p.to),p);let g=new Map;for(let p of e.edges)g.set(sn(p.from,p.to),p);let f=[];for(let[p,T]of g)l.has(p)||f.push(T);f.sort((p,T)=>p.from<T.from?-1:p.from>T.from?1:p.to<T.to?-1:p.to>T.to?1:0);for(let p of f)t.push({type:"edge-added",from:p.from,to:p.to});let h=[];for(let[p,T]of l)g.has(p)||h.push(T);h.sort((p,T)=>p.from<T.from?-1:p.from>T.from?1:p.to<T.to?-1:p.to>T.to?1:0);for(let p of h)t.push({type:"edge-removed",from:p.from,to:p.to});let c=[];for(let p of i)a.has(p)||c.push(p);c.sort();for(let p of c)t.push({type:"node-removed",path:p});let _=[];for(let p of n)s.has(p)||_.push(p);_.sort();for(let p of _)t.push({type:"subgraph-unmounted",path:p});return{events:t,flushedAt_ns:W()}}De();on();an();ut();le();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[f,h]of s)i.set(f,h);let a=[];for(let[f,h]of Object.entries(n.nodes)){let c=i.get(f),_=c instanceof I?c:null,p=_?Xt(_.cache):0,T=_?_._sinkCount:0,v=h.deps?.length??0,b=h.type==="effect"&&T===0,y=T===0?h.type==="effect"?"orphan-effect":h.type==="derived"?"idle-derived":h.type==="producer"?"idle-producer":null:null;a.push({path:f,type:h.type,status:h.status??"unknown",valueSizeBytes:p,subscriberCount:T,depCount:v,isOrphanEffect:b,orphanKind:y})}let d=a.reduce((f,h)=>f+h.valueSizeBytes,0),u=(f,h)=>[...a].sort(h??((c,_)=>_[f]-c[f])).slice(0,t),l=a.filter(f=>f.orphanKind!=null),g=a.filter(f=>f.isOrphanEffect);return{nodeCount:a.length,edgeCount:n.edges.length,subgraphCount:n.subgraphs.length,nodes:a,totalValueSizeBytes:d,hotspots:{byValueSize:u("valueSizeBytes"),bySubscriberCount:u("subscriberCount"),byDepCount:u("depCount")},orphans:l,orphanEffects:g}}var P="::",Q="__meta__",pe=1;function un(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 hn(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 hn(r)?r.cache:r}function fe(r){return r!=null&&typeof r=="object"&&"cache"in r&&typeof r.subscribe=="function"&&typeof r.down=="function"}function ie(r){return fe(r)?r.cache??"":r}function cn(r){return fe(r)?r.cache??0:r}function ln(r){return fe(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,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 f=o;if(s.length!==f.length)return!1;for(let h=0;h<s.length;h++)if(!n(s[h],f[h]))return!1;return!0}if(s instanceof Map){let f=o;if(s.size!==f.size)return!1;for(let[h,c]of s)if(!f.has(h)||!n(c,f.get(h)))return!1;return!0}if(s instanceof Set){let f=o;if(s.size!==f.size)return!1;for(let h of s){let c=!1;for(let _ of f)if(n(h,_)){c=!0;break}if(!c)return!1}return!0}if(ArrayBuffer.isView(s)){let f=s,h=o;if(f.length!==h.length)return!1;for(let c=0;c<f.length;c++)if(f[c]!==h[c])return!1;return!0}let u=Object.keys(s),l=Object.keys(o);if(u.length!==l.length)return!1;let g=new Set(l);for(let f of u)if(!g.has(f)||!n(s[f],o[f]))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 Ot(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 fn(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 Nt(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===Q)throw new Error(`Graph "${e}": ${t} name "${Q}" 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 gn(r){for(let e of r._mounts.values())gn(e);for(let e of r._nodes.values())try{e.down([[F]],{internal:!0})}catch{}}var U=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===Q)throw new Error(`Graph name "${Q}" is reserved for meta companion paths`);this.name=e,this.opts=Object.freeze({...t??{}}),this.config=t?.config??Te,this._traceRing=new Ge(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=We(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(Nt(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:W()})),e}setVersioning(e){if(e!=null)for(let t of this._nodes.values())t instanceof I&&t._applyVersioning(e)}remove(e){Nt(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,d]of i)a.includes(`${P}${Q}${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,gn(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([[D,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[d,u]of this._nodes)n.set(u,d);let a=[];for(let[d,u]of this._nodes)if(u instanceof I)for(let l of u._deps){let g=n.get(l.node);g!=null&&a.push([g,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 I)for(let u of d._deps){let l=o.get(u.node);l!=null&&i.push([l,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,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(Nt(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]===Q)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]!==Q)throw new Error(`Graph "${this.name}": expected ${Q} segment in meta path "${n}"`);if(o+1>=i.length)throw new Error(`Graph "${this.name}": meta path requires a key after ${Q} in "${n}"`);let a=i[o+1],d=s.meta[a];if(!d)throw new Error(`Graph "${this.name}": unknown meta "${a}" in path "${n}"`);s=d,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 d of this._mounts.values())d._signalDeliver(e,t,n,s);let i=t.internal===!0?{internal:!0}:{actor:t.actor,delivery:"signal"},a=rr(e,this.config);for(let d of[...this._nodes.keys()].sort()){let u=this._nodes.get(d);if(!n.has(u)){n.add(u);try{u.down(e,i)}catch(l){if(l instanceof Z)throw l;s.push(l)}a.length!==0&&this._signalMetaSubtree(u,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(d){if(d instanceof Z)throw d;o.push(d)}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=yt(e?.detail,e?.fields),o=e?.detail==="spec",i=s,a=[];this._collectObserveTargets("",a);let d=new Map;for(let[y,w]of a)d.set(w,y);let u=[];{let y=a.map(([,m])=>m),w=new Set(d.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(d.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++}`;d.set(x,N),w.add(N),u.push([N,x]),y.push(x)}}}let l=[...a,...u],g={};for(let[y,w]of l){if(t!=null&&!w.allowsObserve(t))continue;let k=vt(w,i,o),m=w instanceof I?w._deps.map(N=>d.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,G]of Object.entries(n)){let R=S==="deps_includes"?"depsIncludes":S==="meta_has"?"metaHas":S;if(R==="depsIncludes"){if(!A.deps.includes(String(G))){N=!1;break}continue}if(R==="metaHas"){if(!Object.hasOwn(A.meta??{},String(G))){N=!1;break}continue}if(A[R]!==G){N=!1;break}}if(!N)continue}g[y]=A}let f=new Set(Object.keys(g)),h=[];for(let[y,w]of l)if(w instanceof I)for(let k of w._deps){let m=d.get(k.node);m!=null&&h.push([m,y])}h.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=h.map(([y,w])=>({from:y,to:w}));(t!=null||n!=null)&&(c=c.filter(y=>f.has(y.from)&&f.has(y.to)));let _=this._collectSubgraphs(""),p=t!=null||n!=null?_.filter(y=>{let w=`${y}${P}`;return[...f].some(k=>k===y||k.startsWith(w))}):_,T=this,v=e;return{name:this.name,nodes:g,edges:c,subgraphs:p,...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?kt(this.describe(),e,t,{...n,withDetail:!0}):kt(this.describe(),e,t,n)}explain(e,t,n){return n?.reactive===!0?this._explainReactive(e,t,n):this._explainStatic(ie(e),ie(t),{...n?.maxDepth!==void 0?{maxDepth:cn(n.maxDepth)}:{},...n?.findCycle!==void 0?{findCycle:ln(n.findCycle)}:{}})}_explainStatic(e,t,n){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 Zt(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=H(s,{name:`${n}_version`}),i=this.observe({timeline:!0,structured:!0}),a=!1,d=!1,u=()=>{a||d||(a=!0,_e(()=>{a=!1,!d&&(s+=1,o.emit(s))}))},l=i.onEvent(v=>{let b=v.type;b!=="data"&&b!=="error"&&b!=="complete"&&b!=="teardown"||u()}),g=[],f=new WeakSet,h=v=>{if(f.has(v)||d)return;f.add(v);let b=v.topology.subscribe(y=>{for(let w of y){if(w[0]!==D)continue;let k=w[1];if(u(),k.kind==="added"&&k.nodeKind==="mount"){let m=v._mounts.get(k.name);m!=null&&h(m)}}});g.push(b);for(let y of v._mounts.keys()){let w=v._mounts.get(y);w!=null&&h(w)}};h(this);let c,_=e.actor;hn(_)&&(c=_.subscribe(v=>{let b=!1,y=!1;for(let w of v){let k=w[0];k===D?b=!0:(k===V||k===$||k===F)&&(y=!0)}b&&u(),y&&(c?.(),c=void 0,u())}));let p;try{p=z([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 g)b();throw i.dispose(),v}let T=te(p);return{node:p,dispose(){d=!0,l(),c?.();for(let v of g)v();g.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=Tt(s,o),a=H(i,{name:n,meta:{domain:"audit",kind:"describe-diff"},equals:(f,h)=>f===h}),d=this._describeReactive({...e,reactiveName:void 0}),u=!1,l=d.node.subscribe(f=>{if(!u)for(let h of f){if(h[0]!==D)continue;let c=h[1],_=Tt(o,c);o=c,_.events.length!==0&&a.emit(_)}}),g=te(a);return{node:a,dispose(){u=!0,l(),d.dispose(),a.down([[F,"describe-diff disposed"]]),g()}}}_explainReactive(e,t,n){let s=0,o=H(s,{name:"explain_version"}),i=this.observe({timeline:!0,structured:!0}),a=!1,d=!1,u=()=>{a||d||(a=!0,_e(()=>{a=!1,!d&&(s+=1,o.emit(s))}))},l=i.onEvent(v=>{let b=v.type;b!=="data"&&b!=="error"&&b!=="complete"&&b!=="teardown"||u()}),g=[];e!=null&&fe(e)&&g.push(e),t!=null&&fe(t)&&g.push(t),n?.maxDepth!=null&&fe(n.maxDepth)&&g.push(n.maxDepth),n?.findCycle!=null&&fe(n.findCycle)&&g.push(n.findCycle);let f=()=>{for(let v of g)if(v.cache===void 0)return!1;return!0},h=()=>{let v=ie(e),b=ie(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=z([o],()=>{if(!f())return h();let v=ie(e),b=ie(t),y={...n?.maxDepth!==void 0?{maxDepth:cn(n.maxDepth)}:{},...n?.findCycle!==void 0?{findCycle:ln(n.findCycle)}:{}};return this._explainStatic(v,b,y)},{name:n?.name??"explain",describeKind:"derived",meta:{domain:"audit",kind:"explain_path",from:ie(e),to:ie(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),p=[],T=v=>{let b;return b=v.subscribe(y=>{let w=!1,k=!1;for(let m of y){let O=m[0];O===D?w=!0:(O===V||O===$||O===F)&&(k=!0)}(w||k)&&u(),k&&b&&(b(),b=void 0)}),()=>{b&&(b(),b=void 0)}};for(let v of g)p.push(T(v));return{node:c,dispose(){d=!0,l();for(let v of p)v?.();p.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}${Q}${P}${s}`;n.push([i,o]),this._appendMetaObserveTargets(i,o,n)}}observe(e,t){let n=typeof e=="string",o=fn(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,g=this.resolve(l);if(a!=null&&!g.allowsObserve(a))throw new Z({actor:a,action:"observe",nodeName:l});return i?this._buildStructuredObserver([[l,g]],o,"one"):{subscribe(f){return g.subscribe(f)},up(f){try{g.up?.(f)}catch(h){if(h instanceof Z)return;throw h}}}}let d=[];this._collectObserveTargets("",d),d.sort((l,g)=>l[0]<g[0]?-1:l[0]>g[0]?1:0);let u=a==null?d:d.filter(([,l])=>l.allowsObserve(a));return i?this._buildStructuredObserver(u,o,"all"):{subscribe:l=>{let g=u.map(([f,h])=>h.subscribe(c=>{l(f,c)}));return()=>{for(let f of g)f()}},up:(l,g)=>{try{this.resolve(l).up?.(g)}catch(f){if(f instanceof Z)return;throw f}}}}_observeReactive(e,t){let n=t.tiers,s=n!=null?new Set(n):null,o=t.reactiveName??"observe";return We(i=>{let a=[],d=!1,u=!1,l=()=>{if(a.length===0||u)return;let _={events:a.slice(),flushedAt_ns:W()};a.length=0,i.emit(_)},g={...t,reactive:!1,structured:!0,timeline:!0},f=e!=null?this.observe(e,g):this.observe(g),h=_=>{u||(a.push(_),!d&&(d=!0,_e(()=>{d=!1,l()})))};for(let _ of f.events)h(_);let c=f.onEvent(h);return()=>{u=!0,c(),f.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,g)=>l[0]<g[0]?-1:l[0]>g[0]?1:0);let d=i.actor,u=d==null?a:a.filter(([,l])=>l.allowsObserve(d));return this._buildStructuredObserver(u,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",d=this.config.inspectorEnabled,u=(o||i)&&d,l=t.maxEvents,g=l!=null&&l>0?new Ge(l):null,f=[],h=new Set,c=t.tiers!=null?new Set(t.tiers):null,_={},p=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,G=E=>{if(!(c!=null&&!c.has(E.type))){g?g.push(E):f.push(E);for(let M of h)M(E)}},R=E=>c==null||c.has(E),oe=()=>s?{timestamp_ns:W(),in_batch:je(),batch_id:x}:{},ne=(E,M)=>{if(!(!u||!(E instanceof I)))return E._setInspectorHook(Y=>{if(Y.kind==="dep_message")A.set(E,Y.depIndex);else if(Y.kind==="run"){let Ee=Y.batchData.map((C,B)=>C!=null&&C.length>0?C.at(-1):Y.prevData[B]);N.set(E,Ee);let J=Y.batchData.map(C=>C!=null?[...C]:void 0);S.set(E,J),i&&G({type:"derived",path:M,dep_values:Ee,dep_batches:J,...oe()})}})},Me=E=>{let M=A.get(E),Y=N.get(E);if(!o||Y==null)return{};let J=(M!=null&&M>=0&&E instanceof I?E._deps[M]:void 0)?.node,C=J?.v,B=S.get(E);return{trigger_dep_index:M,trigger_dep_name:J?.name,...C!=null?{trigger_version:{id:C.id,version:C.version}}:{},dep_values:[...Y],...B!=null?{dep_batches:B}:{}}},Rt=[],Dt=[];for(let[E,M]of e){let Y=ne(M,E);Y&&Rt.push(Y),Dt.push(M.subscribe(Ee=>{x++;for(let J of Ee){let C=J[0],B=oe();if(C===D){_[E]=J[1];let rt=M instanceof I?M.lastMutation?.actor??be:be;G({type:"data",path:E,data:J[1],actor:rt,...B,...Me(M)})}else if(a)C===K?R("dirty")&&T++:C===q?R("resolved")&&v++:C===X?R("invalidate")&&b++:C===ee?R("pause")&&y++:C===re?R("resume")&&w++:C===F?R("teardown")&&k++:C===V&&!p.has(E)?R("complete")&&(m=!0):C===$&&R("error")&&(O=!0,p.add(E));else if(C===K)R("dirty")&&T++,G({type:"dirty",path:E,...B});else if(C===q)R("resolved")&&v++,G({type:"resolved",path:E,...B,...Me(M)});else if(C===X)R("invalidate")&&b++,G({type:"invalidate",path:E,...B});else if(C===ee)R("pause")&&y++,G({type:"pause",path:E,lockId:J[1],...B});else if(C===re)R("resume")&&w++,G({type:"resume",path:E,lockId:J[1],...B});else if(C===V)R("complete")&&!p.has(E)&&(m=!0),G({type:"complete",path:E,...B});else if(C===$){R("error")&&(O=!0,p.add(E));let rt=M instanceof I?M.lastMutation?.actor??be:be;G({type:"error",path:E,data:J[1],actor:rt,...B})}else C===F&&(R("teardown")&&k++,G({type:"teardown",path:E,...B}))}}))}let et=!1,tt=()=>{if(!et){et=!0;for(let E of Dt)E();for(let E of Rt)E();for(let E of Pe)E({value:void 0,done:!0});Pe.length=0}},nt=[],Pe=[];h.add(E=>{let M=Pe.shift();M?M({value:E,done:!1}):nt.push(E)});let Gt={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 g?g.toArray():[...f]},get anyCompletedCleanly(){return m},get anyErrored(){return O},get completedWithoutErrors(){return m&&!O},onEvent(E){return h.add(E),()=>h.delete(E)},dispose:tt,expand(E){tt();let M={...t};return typeof E=="string"?M.detail=E:Object.assign(M,E),n(fn(M))},[Symbol.asyncIterator](){return{next(){return nt.length>0?Promise.resolve({value:nt.shift(),done:!1}):et?Promise.resolve({value:void 0,done:!0}):new Promise(E=>Pe.push(E))},return(){return tt(),Promise.resolve({value:void 0,done:!0})}}}};return t.format!=null&&this._attachFormatLogger(Gt,t),Gt}_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)),d=er(t.theme),u=n==="stage-log"?W():0,l=c=>c==null?"":t.stageLabels?.[c]??c,g=(c,_)=>c.length>_?`${c.slice(0,_-1)}\u2026`:c,f=c=>c.type==="data"||c.type==="error"?g(Ot(c.data),120):"",h=c=>{if(n==="stage-log"){let m=(W()-u)/1e9,O=l(c.path).padEnd(9);if(c.type==="data"){let x=f(c);return`[${m.toFixed(3)}s] ${O} \u2190${x?` ${x}`:""}`}if(c.type==="error"){let x=f(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 _=d[c.type]??"",p=c.path?`${d.path}${c.path}${d.reset} `:"",T=c.type==="data"||c.type==="error",v=c.type==="pause"||c.type==="resume",b=T?` ${Ot(c.data)}`:v?` ${Ot(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`${p}${_}${c.type.toUpperCase()}${d.reset}${b}${w}${k}`};e.onEvent(c=>{a(c.type)&&s(h(c),c)})}addDisposer(e){return this._disposers.add(e),()=>{this._disposers.delete(e)}}destroy(){un(this._disposers,this.name),this.signal([[F]],{internal:!0}),un(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:d,guard:u,...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 It(a,a.encode(i))}throw new Error(`snapshot: unknown format "${String(e.format)}"`)}static decode(e,t){let n=t?.config??Te,{codec:s,codecVersion:o,payload:i}=Lt(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 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){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 h of[...e.subgraphs].sort((c,_)=>{let p=c.split(P).length,T=_.split(P).length;return p!==T?p-T:c<_?-1:c>_?1:0})){let c=h.split(P),_=o;for(let p of c)_._mounts.has(p)||_.mount(p,new r(p)),_=_._mounts.get(p)}let i=s?Object.entries(s).map(([h,c])=>({re:Ze(h),factory:c})):[],a=h=>{for(let c of i)if(c.re.test(h))return c.factory},d=h=>{let c=h.split(P),_=c.pop();if(_==null||_.length===0)throw new Error(`invalid snapshot path "${h}"`);let p=o;for(let T of c){let v=p._mounts.get(T);if(!v)throw new Error(`unknown mount "${T}" in path "${h}"`);p=v}return[p,_]},u=Object.entries(e.nodes).filter(([h])=>!h.includes(`${P}${Q}${P}`)).sort((h,c)=>h[0]<c[0]?-1:h[0]>c[0]?1:0),l=new Map(u),g=new Map,f=!0;for(;l.size>0&&f;){f=!1;for(let[h,c]of[...l.entries()]){let _=c?.deps??[];if(!_.every(w=>g.has(w)))continue;let[p,T]=d(h),v={...c?.meta??{}},b=a(h),y;if(c?.type==="state")y=H(c.value,{meta:v});else{if(b==null)continue;y=b(T,{path:h,type:c.type,value:c.value,meta:v,deps:_,resolvedDeps:_.map(w=>g.get(w))})}p.add(y,{name:T}),g.set(h,y),l.delete(h),f=!0}}if(l.size>0){let h=[...l.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,t={}){let n=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}));t.autoRestore===!0&&this._cascadeRestore(e,t.onError);let s=(u,l)=>{if(u.disposed)return;let g=Yn(l.nodes);if(u.lastSnapshot!=null&&g!==""&&g===u.lastFingerprint)return;let f=u.seq+1,h=he(),p=u.lastSnapshot==null||f%u.compactEvery===0?{name:this.name,mode:"full",snapshot:l,seq:f,timestamp_ns:h,format_version:pe}:{name:this.name,mode:"diff",diff:mn(u.lastSnapshot,l),seq:f,timestamp_ns:h,format_version:pe};if(u.tier.filter&&!u.tier.filter(p))return;let T;try{T=u.tier.save(p)}catch(v){t.onError?.(v,u.tier);return}if(T&&typeof T.then=="function"){let y=(u.savePending??Promise.resolve()).then(()=>T,()=>T).then(()=>{u.disposed||(u.seq=f,u.lastSnapshot=l,u.lastFingerprint=g)},w=>{t.onError?.(w,u.tier)});u.savePending=y.finally(()=>{u.savePending===y&&(u.savePending=void 0)})}else u.seq=f,u.lastSnapshot=l,u.lastFingerprint=g},o=(u,l)=>{try{s(u,l)}catch(g){t.onError?.(g,u.tier)}},i=(u,l)=>{if(!l.some(c=>{let _=this.config.messageTier(c[0]);return _>=3&&_<5}))return;if(t.filter){let c=this.tryResolve(u);if(c==null)return;let _=vt(c,yt("standard"));if(!t.filter(u,_))return}let f,h=()=>(f==null&&(f=this.snapshot()),f);for(let c of n)c.disposed||(c.debounceMs===0?o(c,h()):(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(g=>{let f=this.tryResolve(g);return f==null?()=>{}:f.subscribe(h=>i(g,h))});a=()=>{for(let g of l)g()}}else a=this.observe().subscribe((u,l)=>i(u,l));let d=()=>{a();for(let u of n)u.disposed=!0,u.timer?.cancel();this._storageDisposers.delete(d)};return this._storageDisposers.add(d),{dispose:d}}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(d){n?.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 r.fromSnapshot(a,n)}catch(d){n?.onError?.(d,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:W(),...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=[],d=[];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&&d.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 u=v=>`${v.from} ${v.to}`,l=new Set(e.edges.map(u)),g=new Set(t.edges.map(u)),f=t.edges.filter(v=>!l.has(u(v))),h=e.edges.filter(v=>!g.has(u(v))),c=new Set(e.subgraphs),_=new Set(t.subgraphs),p=[..._].filter(v=>!c.has(v)).sort(),T=[...c].filter(v=>!_.has(v)).sort();return{nodesAdded:o,nodesRemoved:i,nodesChanged:a,versionChanges:d,edgesAdded:f,edgesRemoved:h,subgraphsAdded:p,subgraphsRemoved:T}}};function mn(r,e){let t=U.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 kt(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,d=new Map,u=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),u.has(y)||u.set(y,new Set),u.get(y).add(w),d.has(w)||d.set(w,new Set),d.get(w).add(y))}if(!l.has(e))return n.withDetail?s:[];let g=n.both===!0,f=b=>{if(g){let m=i.get(b)??[],O=d.get(b),x=a.get(b),A=u.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=d.get(b);return O?[...m,...O]:m}let y=a.get(b),w=u.get(b),k=y?[...y]:[];return w&&k.push(...w),k},h=new Set([e]),c=new Map,_=[{path:e,depth:0}],p=0,T=!1;for(;p<_.length;){let b=_[p++];if(o!=null&&b.depth>=o){f(b.path).length>0&&(T=!0);continue}for(let y of f(b.path))!y||h.has(y)||(h.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}se();function xt(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(d=>{for(let u of d){if(u[0]!==D)continue;let l=u[1];if(e(l,s,o),l.kind==="added"&&l.nodeKind==="mount"){let g=s._mounts.get(l.name);if(g instanceof U){let f=`${o}${l.name}::`;n(g,f)}}else if(l.kind==="removed"&&l.nodeKind==="mount"){let g=`${o}${l.name}::`;for(let[f,h]of Array.from(t.entries()))f!==r&&h.prefix.startsWith(g)&&(h.off(),t.delete(f))}}});i.off=a;for(let[d,u]of s._mounts)if(u instanceof U){let l=`${o}${d}::`;n(u,l)}};return n(r,""),()=>{for(let s of t.values())s.off();t.clear()}}Re();ge();we();se();_t();le();Ne();Ke();Re();se();le();Ne();var Et=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 Ce(r){return r.subscribe(()=>{})}var or=64;function bn(r,e={}){let{name:t,maxSize:n,versioning:s,guard:o,backend:i}=e,a=i??new Et(r,n),d=H(a.toArray(),{name:t,describeKind:"state",equals:(m,O)=>m===O,...s!=null?{versioning:s}:{},...o!=null?{guard:o}:{}});function u(){let m=a.toArray();ce(()=>{d.down([[K]],{internal:!0}),d.down([[D,m]],{internal:!0})})}let l=new Map,g=new Map,f=new Map;function h(m,O){return`${m}:${O===void 0?"END":O}`}function c(m){if(m.size<or)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&&u()}}function p(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=z([d],([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=Ce(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=h(m,O),A=g.get(x);if(A!==void 0)return g.delete(x),g.set(x,A),A.node;c(g);let N=z([d],([G])=>{let R=G;return O===void 0?R.slice(m):R.slice(m,O)},{initial:a.slice(m,O),describeKind:"derived"}),S=Ce(N);return g.set(x,{node:N,dispose:S}),N}function v(m){let O=f.get(m);if(O!==void 0)return O.node;let x=z([d,m],([N,S])=>{let G=N,R=Math.max(0,Math.trunc(S??0));return G.slice(R)},{initial:[],describeKind:"derived"}),A=Ce(x);return f.set(m,{node:x,dispose:A}),x}let b,y;function w(){b===void 0&&(b=Oe([d],(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([[q]]);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=z([d],([m])=>m.length>0,{name:t!=null?`${t}::hasLatest`:"hasLatest",describeKind:"derived",initial:a.size>0}),Ce(b),Ce(y))}let k={entries:d,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(),d},get lastValue(){return w(),b},get hasLatest(){return w(),y},view(m){switch(m.kind){case"tail":return p(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]===D&&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),u());break}catch{}})();let x=d.subscribe(A=>{for(let N of A){if(N[0]!==D)continue;let S=N[1];for(let G of m){let R=O.get(G)??0;if(S.length<R){try{let ne=G.appendEntries(S);ne instanceof Promise&&ne.catch(()=>{})}catch{}O.set(G,S.length);continue}if(S.length===R)continue;let oe=S.slice(R);O.set(G,S.length);try{let ne=G.appendEntries(oe);ne instanceof Promise&&ne.catch(()=>{})}catch{}}}});return()=>x()},disposeAllViews(){for(let m of l.values())m.dispose();l.clear();for(let m of g.values())m.dispose();g.clear();for(let m of f.values())m.dispose();f.clear()},dispose(){for(let m of l.values())m.dispose();l.clear();for(let m of g.values())m.dispose();g.clear();for(let m of f.values())m.dispose();f.clear()}};return k}De();ze();we();se();Ne();Ke();De();function yn(r,e){return ke("messaging",r,e)}var ir=1024,xe=class extends U{_log;events;latest;hasLatest;constructor(e,t={}){super(e,t.graph),this._log=bn([],{name:"events",maxSize:t.retainedLimit??ir}),this._log.withLatest(),this.events=this._log.entries,this.add(this.events,{name:"events"}),this.latest=z([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=z([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 ar(r,e){return ke("audit",r,e)}var At=class extends U{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:H(t,{name:"policies"});this.policies=s,this.add(this.policies,{name:"policies"}),this.violations=new xe("violations",{retainedLimit:n.violationsLimit??1e3}),this.mount("violations",this.violations),this.violationCount=z([this.violations.events],([c])=>c.length,{name:"violationCount",describeKind:"derived",meta:ar("policy_violation_count")}),this.add(this.violationCount,{name:"violationCount"}),this.addDisposer(te(this.violationCount));let i=s.cache??[];this._currentGuard=ct(i);let a=s.subscribe(c=>{for(let _ of c)_[0]===D&&(i=_[1]??[],this._currentGuard=ct(i))});this.addDisposer(a);let d=n.paths,u=vn(d)?d:void 0,l=d!=null,f=u!=null?u.cache??[]:l?[...d]:void 0,h=f??wn(e);if(this._mode!=="enforce"&&u!=null){let c=u.subscribe(_=>{for(let p of _)p[0]===D&&(f=p[1]??[])});this.addDisposer(c)}if(this._mode==="enforce"){let c=new Map,_=p=>{if(c.has(p))return;let T=_n(e,p);if(!(T instanceof I))return;let v=(b,y)=>{let w=this._currentGuard(b,y);return w||this._publishViolation(b,y,p,"blocked"),w};c.set(p,T._pushGuard(v))};for(let p of h)_(p);if(u!=null){let p=u.subscribe(T=>{for(let v of T){if(v[0]!==D)continue;let b=v[1]??[],y=new Set(b),w=new Set(f??[]);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);f=b})}});this.addDisposer(p)}if(l){let p=e.topology.subscribe(T=>{for(let v of T){if(v[0]!==D)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(p)}else{let p=xt(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 U))return;let w=`${b}${T.name}::`,k=wn(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(p)}this.addDisposer(()=>{for(let p of c.values())p();c.clear()})}else{let c=e.observe({timeline:!0,structured:!0}),_=c.onEvent(p=>{if(p.type!=="data"&&p.type!=="error")return;let T=p.path??"";if(!T||f!=null&&!f.includes(T))return;let v=p.actor??_n(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:W(),wall_clock_ns:he(),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 Tn(r,e,t={}){let n=new At(r,e,t);return n.tagFactory("policyGate",nn(t)),n}function vn(r){return typeof r=="object"&&r!==null&&"subscribe"in r}function _n(r,e){try{return r.node(e)}catch{return}}function wn(r){let e=r.describe({detail:"minimal"});return Object.keys(e.nodes)}function St(r){return typeof r=="object"&&r!==null&&"subscribe"in r&&"down"in r}function dr(r){return ke("guarded",r)}var Qe=class extends U{enforcer;violations;lints;scope;scopedDescribe;_target;_actorNode;_mode;_firedLintKinds=new Set;constructor(e,t){super(t.name??`${e.name}_guarded`,t.graph),this._target=e,this._mode=t.mode??"enforce";let n=t.policies,s=St(n);if(!s&&this._mode==="enforce"&&n.length===0)throw new RangeError('guardedExecution: empty `policies` in `mode: "enforce"` denies every action. Pass at least `{ effect: "allow", action: "*" }` and layer deny rules on top.');this.lints=new xe("lints",{retainedLimit:t.lintsLimit??64}),this.mount("lints",this.lints);let o=t.actor;o==null?this._actorNode=H(null,{name:"actor"}):St(o)?this._actorNode=z([o],([d])=>d??null,{name:"actor",initial:null}):this._actorNode=H(o,{name:"actor"});let i={mode:this._mode,name:"enforcer"};if(t.violationsLimit!=null&&(i.violationsLimit=t.violationsLimit),this.enforcer=Tn(e,t.policies,i),this.violations=this.enforcer.violations,this.mount("enforcer",this.enforcer),s&&this._mode==="enforce"){let d=n,u=d.cache;u!=null&&u.length===0&&this._fireLint("empty-policies",'`policies` Node cached an empty array in `mode: "enforce"` \u2014 every action will be denied. Add at least one allow rule.');let l=d.subscribe(g=>{for(let f of g){if(f[0]!==D)continue;let h=f[1];(h==null||h.length===0)&&this._fireLint("empty-policies",'`policies` Node emitted an empty array in `mode: "enforce"` \u2014 every action will be denied. Add at least one allow rule.')}});this.addDisposer(l)}if(this._mode==="audit"){let d=e.describe({detail:"full"});Object.values(d.nodes).some(l=>l.guard!=null)||this._fireLint("audit-no-effect",'`mode: "audit"` + target has no per-node guards \u2014 `scopedDescribeNode` filters by per-node guards only, so policy rules will not affect describe() visibility. Policies still populate the `violations` topic on writes.')}o==null&&this._fireLint("no-actor","no actor configured \u2014 `wrapper.scopedDescribe` and `scopedDescribeNode()` will return an unscoped describe (full visibility) unless a per-call actor is supplied."),this.scope=z([this._actorNode,this.enforcer.policies],([d,u])=>({actor:d??null,mode:this._mode,policiesCount:u.length}),{name:"scope",describeKind:"derived",meta:dr("scope")}),this.add(this.scope,{name:"scope"}),this.addDisposer(te(this.scope));let a=e.describe({reactive:!0,actor:this._actorNode,reactiveName:"scopedDescribe"});this.scopedDescribe=a.node,this.add(this.scopedDescribe,{name:"scopedDescribe"}),this.addDisposer(a.dispose)}_fireLint(e,t){this._firedLintKinds.has(e)||(this._firedLintKinds.add(e),this.lints.publish({kind:e,message:t,timestamp_ns:W()}))}scopedDescribeNode(e,t){let n=e==null?this._actorNode:St(e)?e:H(e,{name:"actor_override"}),s=this._target.describe({reactive:!0,actor:n,...t??{}});return this.addDisposer(s.dispose),{node:s.node,dispose:s.dispose}}get target(){return this._target}};function ur(r,e){return new Qe(r,e)}0&&(module.exports={GuardedExecutionGraph,guardedExecution});
@@ -1,9 +0,0 @@
1
- import '../../node-BYInONRr.cjs';
2
- export { D as DescribeFilter } from '../../graph-E6likq7w.cjs';
3
- import '../../index-BmSQLAZo.cjs';
4
- import '../../index-Cnr1WrlX.cjs';
5
- export { G as GuardedExecutionGraph, a as GuardedExecutionLint, b as GuardedExecutionOptions, c as GuardedScope, g as guardedExecution } from '../../index-CuPUehFa.cjs';
6
- import '../../meta-Ct9nqQS5.cjs';
7
- import '../../extra/storage-core.cjs';
8
- import '../../extra/storage-tiers.cjs';
9
- import '../../reactive-log-_zeEnB9H.cjs';
@@ -1,9 +0,0 @@
1
- import '../../node-BYInONRr.js';
2
- export { D as DescribeFilter } from '../../graph-BkIkog4h.js';
3
- import '../../index-Ck35nA-T.js';
4
- import '../../index-40ZT4MHj.js';
5
- export { G as GuardedExecutionGraph, a as GuardedExecutionLint, b as GuardedExecutionOptions, c as GuardedScope, g as guardedExecution } from '../../index-8s-Qm-gz.js';
6
- import '../../meta-D8OyedKp.js';
7
- import '../../extra/storage-core.js';
8
- import '../../extra/storage-tiers.js';
9
- import '../../reactive-log-BlAsPLl2.js';
@@ -1 +0,0 @@
1
- import{a,b}from"../../chunk-2W553JJC.js";import"../../chunk-EC2WNSZ7.js";import"../../chunk-URJ2VFNC.js";import"../../chunk-4I45FVQS.js";import"../../chunk-5TEFC2ZX.js";import"../../chunk-3G5U5QNE.js";import"../../chunk-C72GO4IZ.js";import"../../chunk-L6NSJVJZ.js";import"../../chunk-TT4C7DXW.js";import"../../chunk-POXANAJ6.js";import"../../chunk-SGS4OJGS.js";import"../../chunk-ESMPEKEV.js";import"../../chunk-L77I47VU.js";import"../../chunk-35JTVPOX.js";import"../../chunk-LYCLF26R.js";import"../../chunk-CK2E7BTU.js";import"../../chunk-QYADASLV.js";export{a as GuardedExecutionGraph,b as guardedExecution};
@@ -1,3 +0,0 @@
1
- "use strict";var ze=Object.defineProperty;var sn=Object.getOwnPropertyDescriptor;var on=Object.getOwnPropertyNames;var an=Object.prototype.hasOwnProperty;var j=(r,e)=>()=>(r&&(e=r(r=0)),e);var un=(r,e)=>{for(var t in e)ze(r,t,{get:e[t],enumerable:!0})},dn=(r,e,t,n)=>{if(e&&typeof e=="object"||typeof e=="function")for(let s of on(e))!an.call(r,s)&&s!==t&&ze(r,s,{get:()=>e[s],enumerable:!(n=sn(e,s))||n.enumerable});return r};var cn=r=>dn(ze({},"__esModule",{value:!0}),r);function _t(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++]=Ue,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 wt(r,e){if(r.length<vt)throw new Error(`decodeEnvelope: bytes too short (${r.length} < ${vt})`);let t=0,n=r[t++];if(n!==Ue)throw new Error(`decodeEnvelope: unsupported envelope version ${n} (expected ${Ue})`);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),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 Ot(r){r.registerCodec(ln)}var ln,Ue,vt,We=j(()=>{"use strict";ln={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)}},Ue=1,vt=4});function xe(r){if(r==null)return ae;let{type:e,id:t,...n}=r;return{type:e??"system",id:t??"",...n}}var ae,Ke=j(()=>{"use strict";ae={type:"system",id:""}});function ke(){return ue>0||ge}function Tt(){return ue>0}function ce(r){ue>0?me.push(r):r()}function Nt(r){ue+=1;let e=!1;try{r()}catch(t){throw e=!0,t}finally{if(ue-=1,ue===0)if(e){if(!ge){let t=me.splice(0);for(let n of t)try{n()}catch{}ee.length=0,te.length=0,de.length=0}}else fn()}}function fn(){let r=!ge;r&&(ge=!0);let e=[],t=0;try{for(;ee.length>0||te.length>0||de.length>0||r&&me.length>0;){if(r&&me.length>0){let o=me.splice(0);for(let i of o)try{i()}catch(a){e.push(a)}continue}if(t+=1,t>1e3)throw ee.length=0,te.length=0,de.length=0,new Error("batch drain exceeded 1000 iterations \u2014 likely a reactive cycle");let s=(ee.length>0?ee:te.length>0?te:de).splice(0);for(let o of s)try{o()}catch(i){e.push(i)}}}finally{r&&(ge=!1)}if(e.length===1)throw e[0];if(e.length>1)throw new AggregateError(e,"batch drain: multiple callbacks threw")}function Ee(r,e,t){if(e.length===0)return;if(e.length===1){let u=t(e[0][0]);if(u<3||!ke()){r(e);return}(u>=5?de:u===4?te:ee).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 d=ke();if(s>0){let u=e.slice(0,s);r(u)}if(o>s){let u=e.slice(s,o);d?ee.push(()=>r(u)):r(u)}if(i>o){let u=e.slice(o,i);d?te.push(()=>r(u)):r(u)}if(n>i){let u=e.slice(i,n);d?de.push(()=>r(u)):r(u)}}var ue,ge,ee,te,de,me,qe=j(()=>{"use strict";ue=0,ge=!1,ee=[],te=[],de=[],me=[]});function Z(){return Math.trunc(performance.now()*1e6)}function Se(){return Date.now()*1e6}var Re=j(()=>{"use strict"});var be,F,q,Y,K,J,X,L,V,G,le,Ye,pn,Je,hn,gn,Ze,xt,kt,Et,Xe,ye=j(()=>{"use strict";be=Symbol.for("graphrefly/START"),F=Symbol.for("graphrefly/DATA"),q=Symbol.for("graphrefly/DIRTY"),Y=Symbol.for("graphrefly/RESOLVED"),K=Symbol.for("graphrefly/INVALIDATE"),J=Symbol.for("graphrefly/PAUSE"),X=Symbol.for("graphrefly/RESUME"),L=Symbol.for("graphrefly/TEARDOWN"),V=Symbol.for("graphrefly/COMPLETE"),G=Symbol.for("graphrefly/ERROR"),le=Object.freeze([q]),Ye=Object.freeze([Y]),pn=Object.freeze([K]),Je=Object.freeze([be]),hn=Object.freeze([V]),gn=Object.freeze([L]),Ze=Object.freeze([le]),xt=Object.freeze([Ye]),kt=Object.freeze([pn]),Et=Object.freeze([hn]),Xe=Object.freeze([gn])});function St(r){r.registerMessageType(be,{tier:0,wireCrossing:!1}),r.registerMessageType(q,{tier:1,wireCrossing:!1}),r.registerMessageType(K,{tier:1,wireCrossing:!1,metaPassthrough:!1}),r.registerMessageType(J,{tier:2,wireCrossing:!1}),r.registerMessageType(X,{tier:2,wireCrossing:!1}),r.registerMessageType(F,{tier:3,wireCrossing:!0}),r.registerMessageType(Y,{tier:3,wireCrossing:!0}),r.registerMessageType(V,{tier:4,wireCrossing:!0,metaPassthrough:!1}),r.registerMessageType(G,{tier:4,wireCrossing:!0,metaPassthrough:!1}),r.registerMessageType(L,{tier:5,wireCrossing:!0,metaPassthrough:!1})}var Ae,Rt=j(()=>{"use strict";ye();Ae=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 Qe(r){let e=mn.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 U,mn,De=j(()=>{"use strict";U=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}},mn=["human","llm","wallet","system"]});function et(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(et);if(typeof r=="object"&&r!==null){let e={};for(let t of Object.keys(r).sort())e[t]=et(r[t]);return e}return null}function vn(r){let e=yn.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,d=3144134277,u=1013904242,c=2773480762,g=1359893119,h=2600822924,f=528734635,l=1541459225,y=new Uint32Array(64),p=(b,m)=>b>>>m|b<<32-m;for(let b=0;b<s;b+=64){for(let T=0;T<16;T++)y[T]=i.getUint32(b+T*4,!1);for(let T=16;T<64;T++){let I=y[T-15],M=y[T-2],A=p(I,7)^p(I,18)^I>>>3,ie=p(M,17)^p(M,19)^M>>>10;y[T]=y[T-16]+A+y[T-7]+ie>>>0}let m=a,v=d,_=u,N=c,x=g,k=h,E=f,S=l;for(let T=0;T<64;T++){let I=p(x,6)^p(x,11)^p(x,25),M=x&k^~x&E,A=S+I+M+bn[T]+y[T]>>>0,ie=p(m,2)^p(m,13)^p(m,22),Le=m&v^m&_^v&_,Te=ie+Le>>>0;S=E,E=k,k=x,x=N+A>>>0,N=_,_=v,v=m,m=A+Te>>>0}a=a+m>>>0,d=d+v>>>0,u=u+_>>>0,c=c+N>>>0,g=g+x>>>0,h=h+k>>>0,f=f+E>>>0,l=l+S>>>0}let w=b=>b.toString(16).padStart(8,"0");return w(a)+w(d)+w(u)+w(c)+w(g)+w(h)+w(f)+w(l)}function tt(r){let e=et(r??null),t=JSON.stringify(e);return vn(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 nt(r,e,t){let n=t?.id??_n();if(r===0)return{id:n,version:0};let o=(t?.hash??tt)(e);return{id:n,version:0,cid:o,prev:null}}function At(r,e,t){r.version+=1,"cid"in r&&(r.prev=r.cid,r.cid=t(e))}var bn,yn,Dt=j(()=>{"use strict";bn=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]),yn=new TextEncoder});function Mt(r){return{node:r,unsub:null,prevData:void 0,dirty:!1,involvedThisWave:!1,dataBatch:[],terminal:void 0}}function rt(r){r.prevData=void 0,r.dirty=!1,r.involvedThisWave=!1,r.dataBatch.length=0,r.terminal=void 0}function Ce(r){return r.length===0?r:typeof r[0]=="symbol"?[r]:r}function Ge(r,e,t){let n=Pt(r)?r:[],s=typeof r=="function"?r:typeof e=="function"?e:void 0,o={};return Pt(r)?o=(st(e)?e:t)??{}:st(r)?o=r:o=(st(e)?e:t)??{},new P(n,s,o)}var Ct,Gt,wn,On,fe,P,Pt,st,ve=j(()=>{"use strict";We();Ke();qe();Re();Rt();De();ye();Dt();Ct=()=>{},Gt=100;wn=(r,e,t,n)=>{t.direction==="down-in"&&r._onDepMessage(t.depIndex,e)},On=(r,e,t,n)=>{let s=r;if(s._status==="completed"||s._status==="errored")return;let o=s._cached,i=o===void 0?[Je]:[Je,[F,o]];s._status==="dirty"&&i.push(le),Ee(e,i,s._config.tierOf)},fe=new Ae({onMessage:wn,onSubscribe:On});St(fe);Ot(fe);P=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??fe,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??tt;let s=n.versioning??this._config.defaultVersioning;this._versioningLevel=s,this._versioning=s!=null?nt(s,this._cached===void 0?void 0:this._cached,{id:n.versioningId,hash:this._hashFn}):void 0,this._deps=e.map(Mt);let o={};for(let[a,d]of Object.entries(n.meta??{})){let u={initial:d,name:`${n.name??"node"}:meta:${a}`,describeKind:"state",config:this._config};n.guard!=null&&(u.guard=n.guard),o[a]=new r([],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([[F,a]])},down(a){i._emit(Ce(a))},up(a){i._emitUp(Ce(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,d=i?.version??0,u=nt(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 t=xe(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=xe(e?.actor),o=e?.delivery==="signal"?"signal":"write";if(this._guard!=null&&!this._guard(s,o))throw new U({actor:s,action:o,nodeName:this.name});if(this._extraGuards!=null){for(let i of this._extraGuards)if(!i(s,o))throw new U({actor:s,action:o,nodeName:this.name})}this._lastMutation={actor:s,timestamp_ns:Se()}}down(e,t){let n=Ce(e);n.length!==0&&(this._checkGuard(t),this._emit(n))}emit(e,t){this._checkGuard(t),this._emit([[F,e]])}up(e,t){if(this._deps.length===0)return;let n=Ce(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 d=xe(t);if(!this._guard(d,"observe"))throw new U({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)rt(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[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=Ct,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()}),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{}rt(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=Mt(e);if(this._deps.push(n),this._sinks==null)return t;n.dirty=!0,this._dirtyDepCount++,this._status!=="dirty"&&this._emit(Ze),n.unsub=Ct;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([[G,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([[G,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{}}rt(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!==be){if(s===q){this._depDirtied(n);return}if(s===K){if(this._depInvalidated(n),this._cached===void 0)return;this._emit(kt);return}if(s===J||s===X){this._emit([t]);return}if(s===L){this._emit(Xe);return}if(s===F)this._depSettledAsData(n,t[1]);else if(s===Y)this._depSettledAsResolved(n);else if(s===V)this._depSettledAsTerminal(n,!0);else if(s===G)this._depSettledAsTerminal(n,t[1]);else{this._emit([t]);return}if(!this._fn){(s===F||s===Y)&&this._emit([t]),(s===V||s===G)&&this._maybeAutoTerminalAfterWave();return}}}_depDirtied(e){e.dirty||(e.dirty=!0,e.involvedThisWave=!0,this._dirtyDepCount++,this._status!=="dirty"&&this._emit(Ze))}_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(xt),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([[G,e.terminal]]);return}this._autoComplete&&this._deps.every(t=>t.terminal!==void 0)&&this._emit(Et)}_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([[G,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([[G,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([[G,this._wrapFnError("fn threw",i)]])}finally{this._isExecutingFn=!1,this._pendingRerun?(this._pendingRerun=!1,this._rerunDepth+=1,this._rerunDepth>Gt?(this._rerunDepth=0,this._emit([[G,new Error(`Node "${this.name}": _pendingRerun depth exceeded ${Gt} \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 d of e){let u=t(d[0]);u<i&&(n=!1),u===3&&(s=!0),d[0]===q&&(o=!0),i=u}let a=e;if(!n){let d=e.map((u,c)=>({m:u,i:c,tier:t(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&&t(a[d][0])===0;)d++;return d===0?[le,...a]:[...a.slice(0,d),le,...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]===G&&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 t=e;if(this._isTerminal&&!this._resubscribable){let a=e.filter(d=>d[0]===L||d[0]===K);if(a.length===0)return;t=a}t=this._frameBatch(t);let s=null;for(let a=0;a<t.length;a++){let d=t[a],u=d[0];if(u!==J&&u!==X){s?.push(d);continue}if(d.length<2)throw new Error(`Node "${this.name}": [[${u===J?"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 g=d[1];if(u===J)this._pauseLocks==null&&(this._pauseLocks=new Set),this._pauseLocks.add(g),this._paused=!0,this._pausable==="resumeAll"&&this._pauseBuffer==null&&(this._pauseBuffer=[]);else if(this._pauseLocks==null||!this._pauseLocks.has(g))c=!1;else if(this._pauseLocks.delete(g),this._pauseLocks.size===0){if(this._paused=!1,this._pauseBuffer!=null&&this._pauseBuffer.length>0){let h=this._pauseBuffer;this._pauseBuffer=[],this._emit(h)}this._pendingWave&&(this._pendingWave=!1,this._maybeRunFnOnSettlement())}}c?s?.push(d):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]===L))for(let a of Object.keys(this.meta))try{this.meta[a]._emit(Xe)}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,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([[G,i]])}_updateState(e){let t=this._config.tierOf,n,s,o=-1,i=0;for(let c of e)t(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]===F){d=c;break}}for(let c=0;c<e.length;c++){let g=e[c],h=g[0];if(h===F){if(g.length>=2){let f=!1;if(a&&this._cached!==void 0)try{f=this._equals(this._cached,g[1])}catch(l){s=this._wrapFnError("equals threw",l),o=c;break}if(f){n==null&&(n=e.slice(0,c)),n.push(Ye),this._status="resolved";continue}this._cached=g[1],this._versioning!=null&&(d<0||c===d)&&At(this._versioning,g[1],this._hashFn)}this._status="settled",n?.push(g)}else if(n?.push(g),h===q)this._status="dirty";else if(h===Y)this._status="resolved";else if(h===V){this._status="completed";{let f=this._config.rigorRecorder;if(f!=null)try{f.onTerminalTransition(this,"completed",this._autoComplete,this._autoError,this._deps.length>0)}catch{}}}else if(h===G){this._status="errored";{let f=this._config.rigorRecorder;if(f!=null)try{f.onTerminalTransition(this,"errored",this._autoComplete,this._autoError,this._deps.length>0)}catch{}}}else if(h===K){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 f=this._cleanup;if(typeof f=="function"){this._cleanup=void 0;try{f()}catch{}}else if(f!=null&&typeof f=="object"){let l=f.invalidate;if(typeof l=="function")try{l()}catch{}}}else h===L&&(this._resetOnTeardown&&(this._cached=void 0),this._deactivate(!0),this._status="sentinel")}let u=o>=0?n??e.slice(0,o):n??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 t=[...this._sinks];for(let n of t)n(e)};_dispatchOrAccumulate(e){if(Tt()){this._batchPendingMessages===null&&(this._batchPendingMessages=[],ce(()=>this._flushBatchPending()));for(let t of e)this._batchPendingMessages.push(t);return}Ee(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);Ee(this._deliverToSinks,t,this._config.tierOf)}},Pt=r=>Array.isArray(r),st=r=>typeof r=="object"&&r!=null&&!Array.isArray(r)});function _e(r,e){return Ge([],{...e,initial:r})}function ot(r,e){return Ge((n,s,o)=>r(s,o)??void 0,{describeKind:"producer",...e})}function pe(r,e,t){return Ge(r,(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",...t})}var it=j(()=>{"use strict";ve()});function at(r,e,t){return{[r]:!0,[`${r}_type`]:e,...t??{}}}var $t=j(()=>{"use strict"});function ne(r){return r.subscribe(()=>{})}var Ft=j(()=>{"use strict"});var ut=j(()=>{"use strict";Ft()});function dt(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 Rn(r){return r._describeKind!=null?r._describeKind:r._deps.length>0?"derived":r._fn!=null?"producer":"state"}function An(r){let e={};for(let[t,n]of Object.entries(r.meta))try{e[t]=n.cache}catch{}return e}function ct(r,e,t){let n=e==null,s=!n&&e!=null?[...e].filter(c=>c.startsWith("meta.")).map(c=>c.slice(5)):null,o=n||e.has("meta")||s!=null&&s.length>0,i="state",a=[];r instanceof P&&(i=Rn(r),a=r._deps.map(c=>c.node.name??""));let d={type:i,deps:a};(n||e.has("status"))&&(d.status=r.status);let u=r instanceof P?r._guard:void 0;if(o){let c={...An(r)};if(u!=null&&c.access===void 0&&(c.access=Qe(u)),s!=null&&s.length>0&&!e.has("meta")){let g={};for(let h of s)h in c&&(g[h]=c[h]);d.meta=g}else d.meta=c}if(r.name!=null&&(d.name=r.name),(n||e.has("value"))&&(!t||i==="state")){r.status==="sentinel"&&(d.sentinel=!0);try{d.value=r.cache}catch{}}if((n||e.has("v"))&&r.v!=null){let c={id:r.v.id,version:r.v.version};"cid"in r.v&&(c.cid=r.v.cid,c.prev=r.v.prev),d.v=c}return(n||e.has("guard"))&&u!=null&&(d.guard=Qe(u)),(n||e.has("lastMutation"))&&r.lastMutation!=null&&(d.lastMutation=r.lastMutation),d}var Bt=j(()=>{"use strict";De();ve()});var Fe,Ut=j(()=>{"use strict";Fe=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 we,Wt=j(()=>{"use strict";we=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 Bn={};un(Bn,{computeHealthReport:()=>nn,graphLens:()=>Vn,healthReportEqual:()=>rn,watchTopologyTree:()=>gt});module.exports=cn(Bn);it();$t();ut();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},Tn=Symbol.for("sizeof");function It(r){let e=new WeakSet,t=new WeakSet,n=[r],s=0;for(;n.length>0;){let o=n.pop();s+=Nn(o,e,t,n)}return s}function Nn(r,e,t,n){if(r==null)return 0;switch(typeof r){case"number":return $.number;case"boolean":return $.boolean;case"string":return $.string+r.length*2;case"bigint":return $.bigint+xn(r);case"symbol":return $.symbol;case"function":return e.has(r)?0:(e.add(r),$.function);case"undefined":return 0}let o=r;if(e.has(o))return 0;e.add(o);let i=o[Tn];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,g]of o)u+=$.mapEntry,n.push(c),n.push(g);return u}if(o instanceof Set){let u=$.set;for(let c of o)u+=$.setEntry,n.push(c);return u}if(Array.isArray(o)){let u=$.array+o.length*8;for(let c of o)n.push(c);return u}if(o instanceof ArrayBuffer)return t.has(o)?0:(t.add(o),o.byteLength);if(ArrayBuffer.isView(o)){let u=o;return t.has(u.buffer)?48:(t.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{n.push(o[u])}catch{}}return a}function xn(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 Lt(r,e,t,n={}){let s=e in r.nodes,o=t in r.nodes;if(!s)return Me(e,t,"no-such-from");if(!o)return Me(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 u=kn(r,e,n);if(u!=null)return u}let d=Pe(e,r.nodes[e],0,n);return $e(e,t,[d])}if(i===0)return Me(e,t,"no-path");let a=jt(r,e,t,i);return a.found?$e(e,t,Ht(r,a.pathOrder,n)):Me(e,t,a.truncated?"max-depth-exceeded":"no-path")}function jt(r,e,t,n){let s=new Map,o=[{path:t,depth:0}],i=new Set([t]),a=0,d=!1;for(;a<o.length;){let g=o[a++];if(g.path===e)break;if(n!=null&&g.depth>=n){let y=r.nodes[g.path];y?.deps&&y.deps.length>0&&(d=!0);continue}let h=r.nodes[g.path];if(h==null)continue;let f=h.deps??[],l=new Map;for(let y=0;y<f.length;y++){let p=f[y];if(!p)continue;let w=l.get(p);w==null&&(w=[],l.set(p,w)),w.push(y)}for(let[y,p]of l)i.has(y)||(i.add(y),s.set(y,{from:g.path,depIndices:p}),o.push({path:y,depth:g.depth+1}))}if(!s.has(e))return{found:!1,pathOrder:[],truncated:d};let u=[{path:e}],c=e;for(;c!==t;){let g=s.get(c);if(g==null)return{found:!1,pathOrder:[],truncated:!1};u[u.length-1].depIndices=g.depIndices,u.push({path:g.from}),c=g.from}return{found:!0,pathOrder:u,truncated:!1}}function kn(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=Pe(e,n,0,t);a.dep_index=o[0];let d=Pe(e,n,1,t);return $e(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=jt(r,d,e,t.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:$e(e,e,Ht(r,i.pathOrder,t))}function Ht(r,e,t){return e.map((n,s)=>{let o=r.nodes[n.path],i=Pe(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 Pe(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 $e(r,e,t){return Vt(r,e,!0,"ok",t)}function Me(r,e,t){return Vt(r,e,!1,t,[])}function Vt(r,e,t,n,s){let o=En(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 En(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 d=` ${i.hop===0?"\xB7":"\u2193"} ${i.path} (${i.type}${i.status?`/${i.status}`:""})`;if(o.push(d),"value"in i&&o.push(` value: ${Sn(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 Sn(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)}}Ke();qe();Re();De();ye();Bt();ve();it();Re();function lt(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(!lt(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)||!lt(r[o],e[o]))return!1;return!0}function zt(r,e){return`${r}\0${e}`}function ft(r,e){let t=[],n=new Set(r.subgraphs),s=new Set(e.subgraphs),o=[];for(let p of s)n.has(p)||o.push(p);o.sort();for(let p of o)t.push({type:"subgraph-mounted",path:p});let i=new Set(Object.keys(r.nodes)),a=new Set(Object.keys(e.nodes)),d=[];for(let p of a)i.has(p)||d.push(p);d.sort();for(let p of d)t.push({type:"node-added",path:p,node:{...e.nodes[p]}});let u=[];for(let p of a){if(!i.has(p))continue;let w=r.nodes[p]?.meta,b=e.nodes[p]?.meta;w==null&&b==null||lt(w??{},b??{})||u.push(p)}u.sort();for(let p of u)t.push({type:"node-meta-changed",path:p,prevMeta:r.nodes[p]?.meta??{},nextMeta:e.nodes[p]?.meta??{}});let c=new Map;for(let p of r.edges)c.set(zt(p.from,p.to),p);let g=new Map;for(let p of e.edges)g.set(zt(p.from,p.to),p);let h=[];for(let[p,w]of g)c.has(p)||h.push(w);h.sort((p,w)=>p.from<w.from?-1:p.from>w.from?1:p.to<w.to?-1:p.to>w.to?1:0);for(let p of h)t.push({type:"edge-added",from:p.from,to:p.to});let f=[];for(let[p,w]of c)g.has(p)||f.push(w);f.sort((p,w)=>p.from<w.from?-1:p.from>w.from?1:p.to<w.to?-1:p.to>w.to?1:0);for(let p of f)t.push({type:"edge-removed",from:p.from,to:p.to});let l=[];for(let p of i)a.has(p)||l.push(p);l.sort();for(let p of l)t.push({type:"node-removed",path:p});let y=[];for(let p of n)s.has(p)||y.push(p);y.sort();for(let p of y)t.push({type:"subgraph-unmounted",path:p});return{events:t,flushedAt_ns:Z()}}ut();Ut();Wt();We();ve();function Kt(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[h,f]of s)i.set(h,f);let a=[];for(let[h,f]of Object.entries(n.nodes)){let l=i.get(h),y=l instanceof P?l:null,p=y?It(y.cache):0,w=y?y._sinkCount:0,b=f.deps?.length??0,m=f.type==="effect"&&w===0,v=w===0?f.type==="effect"?"orphan-effect":f.type==="derived"?"idle-derived":f.type==="producer"?"idle-producer":null:null;a.push({path:h,type:f.type,status:f.status??"unknown",valueSizeBytes:p,subscriberCount:w,depCount:b,isOrphanEffect:m,orphanKind:v})}let d=a.reduce((h,f)=>h+f.valueSizeBytes,0),u=(h,f)=>[...a].sort(f??((l,y)=>y[h]-l[h])).slice(0,t),c=a.filter(h=>h.orphanKind!=null),g=a.filter(h=>h.isOrphanEffect);return{nodeCount:a.length,edgeCount:n.edges.length,subgraphCount:n.subgraphs.length,nodes:a,totalValueSizeBytes:d,hotspots:{byValueSize:u("valueSizeBytes"),bySubscriberCount:u("subscriberCount"),byDepCount:u("depCount")},orphans:c,orphanEffects:g}}var C="::",W="__meta__",re=1;function qt(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 Qt(r){return r!=null&&typeof r=="object"&&"cache"in r&&typeof r.subscribe=="function"&&typeof r.down=="function"}function Dn(r){if(r!=null)return Qt(r)?r.cache:r}function se(r){return r!=null&&typeof r=="object"&&"cache"in r&&typeof r.subscribe=="function"&&typeof r.down=="function"}function Q(r){return se(r)?r.cache??"":r}function Yt(r){return se(r)?r.cache??0:r}function Jt(r){return se(r)?r.cache??!1:r}function Cn(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 Zt(r){if(r.version!==re)throw new Error(`unsupported snapshot version ${String(r.version)} (expected ${re})`);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 Gn(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,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 h=o;if(s.length!==h.length)return!1;for(let f=0;f<s.length;f++)if(!n(s[f],h[f]))return!1;return!0}if(s instanceof Map){let h=o;if(s.size!==h.size)return!1;for(let[f,l]of s)if(!h.has(f)||!n(l,h.get(f)))return!1;return!0}if(s instanceof Set){let h=o;if(s.size!==h.size)return!1;for(let f of s){let l=!1;for(let y of h)if(n(f,y)){l=!0;break}if(!l)return!1}return!0}if(ArrayBuffer.isView(s)){let h=s,f=o;if(h.length!==f.length)return!1;for(let l=0;l<h.length;l++)if(h[l]!==f[l])return!1;return!0}let u=Object.keys(s),c=Object.keys(o);if(u.length!==c.length)return!1;let g=new Set(c);for(let h of u)if(!g.has(h)||!n(s[h],o[h]))return!1;return!0};return n(r,e)}function Mn(r){return r.replace(/[.*+?^${}()|[\]\\]/g,"\\$&")}function Ie(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+=Mn(n)}return e+="$",new RegExp(e)}var Pn={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"},$n={data:"",dirty:"",resolved:"",invalidate:"",pause:"",resume:"",complete:"",error:"",teardown:"",derived:"",path:"",reset:""};function pt(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 Fn(r){return r==="none"?$n:r==="ansi"||r==null?Pn:{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 Xt(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 In(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 ht(r,e,t){if(r==="")throw new Error(`Graph "${e}": ${t} name must be non-empty`);if(r.includes(C))throw new Error(`Graph "${e}": ${t} "${r}" must not contain '${C}' (path separator)`);if(r===W)throw new Error(`Graph "${e}": ${t} name "${W}" is reserved for meta companion paths`);In(r,e,t)}function Ln(r,e){if(r==="")throw new Error(`Graph "${e}": resolve path must be non-empty`);let t=r.split(C);for(let n of t)if(n==="")throw new Error(`Graph "${e}": resolve path has empty segment`);return t}function jn(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 en(r){for(let e of r._mounts.values())en(e);for(let e of r._nodes.values())try{e.down([[L]],{internal:!0})}catch{}}var oe=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(C))throw new Error(`Graph name must not contain '${C}' (got "${e}")`);if(e===W)throw new Error(`Graph name "${W}" is reserved for meta companion paths`);this.name=e,this.opts=Object.freeze({...t??{}}),this.config=t?.config??fe,this._traceRing=new we(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=ot(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(ht(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:Z()})),e}setVersioning(e){if(e!=null)for(let t of this._nodes.values())t instanceof P&&t._applyVersioning(e)}remove(e){ht(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,d]of i)a.includes(`${C}${W}${C}`)||o.nodes.push(a);return o.nodes.sort(),o.mounts.push(e),o.mounts.push(...t._collectSubgraphs(`${e}${C}`)),this._mounts.delete(e),t._parent=void 0,en(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([[L]],{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=Ie(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(C))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([[F,t]],{actor:n?.actor,internal:s,delivery:"write"})}setAll(e,t){let n=Symbol.iterator in e?e:Object.entries(e);Nt(()=>{for(let[s,o]of n)this.set(s,o,t)})}invalidate(e,t){let n=t?.internal===!0;this.node(e).down([[K]],{actor:t?.actor,internal:n,delivery:"write"})}error(e,t,n){let s=n?.internal===!0;this.node(e).down([[G,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[d,u]of this._nodes)n.set(u,d);let a=[];for(let[d,u]of this._nodes)if(u instanceof P)for(let c of u._deps){let g=n.get(c.node);g!=null&&a.push([g,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,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(ht(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=Ln(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]===W)return this._resolveMetaChainFromNode(o,s,t.join(C));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(C)}" is invalid`):new Error(`Graph "${this.name}": unknown mount or node "${n}"`);return i.resolve(s.join(C))}_resolveMetaChainFromNode(e,t,n){let s=e,o=0,i=[...t];for(;o<i.length;){if(i[o]!==W)throw new Error(`Graph "${this.name}": expected ${W} segment in meta path "${n}"`);if(o+1>=i.length)throw new Error(`Graph "${this.name}": meta path requires a key after ${W} in "${n}"`);let a=i[o+1],d=s.meta[a];if(!d)throw new Error(`Graph "${this.name}": unknown meta "${a}" in path "${n}"`);s=d,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 d of this._mounts.values())d._signalDeliver(e,t,n,s);let i=t.internal===!0?{internal:!0}:{actor:t.actor,delivery:"signal"},a=jn(e,this.config);for(let d of[...this._nodes.keys()].sort()){let u=this._nodes.get(d);if(!n.has(u)){n.add(u);try{u.down(e,i)}catch(c){if(c instanceof U)throw c;s.push(c)}a.length!==0&&this._signalMetaSubtree(u,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(d){if(d instanceof U)throw d;o.push(d)}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=Dn(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=dt(e?.detail,e?.fields),o=e?.detail==="spec",i=s,a=[];this._collectObserveTargets("",a);let d=new Map;for(let[v,_]of a)d.set(_,v);let u=[];{let v=a.map(([,x])=>x),_=new Set(d.values()),N=0;for(;v.length>0;){let x=v.shift();if(x instanceof P)for(let k of x._deps){let E=k.node;if(d.has(E))continue;let S=E.name??"",T=S;if(!T||_.has(T))if(S){let I=2;for(;_.has(`${S}#${I}`);)I++;T=`${S}#${I}`}else for(T=`__internal__/${N++}`;_.has(T);)T=`__internal__/${N++}`;d.set(E,T),_.add(T),u.push([T,E]),v.push(E)}}}let c=[...a,...u],g={};for(let[v,_]of c){if(t!=null&&!_.allowsObserve(t))continue;let N=ct(_,i,o),x=_ instanceof P?_._deps.map(T=>d.get(T.node)??T.node.name??""):[],{name:k,...E}=N,S={...E,deps:x};if(!o){let T=this._annotations.get(v);T!=null&&(S.annotation=T)}if(n!=null)if(typeof n=="function"){let T=n;if(!(T.length>=2?T(v,S):T(S)))continue}else{let T=!0;for(let[I,M]of Object.entries(n)){let A=I==="deps_includes"?"depsIncludes":I==="meta_has"?"metaHas":I;if(A==="depsIncludes"){if(!S.deps.includes(String(M))){T=!1;break}continue}if(A==="metaHas"){if(!Object.hasOwn(S.meta??{},String(M))){T=!1;break}continue}if(S[A]!==M){T=!1;break}}if(!T)continue}g[v]=S}let h=new Set(Object.keys(g)),f=[];for(let[v,_]of c)if(_ instanceof P)for(let N of _._deps){let x=d.get(N.node);x!=null&&f.push([x,v])}f.sort((v,_)=>v[0]<_[0]?-1:v[0]>_[0]?1:v[1]<_[1]?-1:v[1]>_[1]?1:0);let l=f.map(([v,_])=>({from:v,to:_}));(t!=null||n!=null)&&(l=l.filter(v=>h.has(v.from)&&h.has(v.to)));let y=this._collectSubgraphs(""),p=t!=null||n!=null?y.filter(v=>{let _=`${v}${C}`;return[...h].some(N=>N===v||N.startsWith(_))}):y,w=this,b=e;return{name:this.name,nodes:g,edges:l,subgraphs:p,...this._factory!==void 0?{factory:this._factory}:{},...this._factoryArgs!==void 0?{factoryArgs:this._factoryArgs}:{},expand(v){let _={...b};return Array.isArray(v)?(_.fields=v,_.detail=void 0):(_.detail=v,_.fields=void 0),w.describe(_)}}}_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}${C}`))}return t}resourceProfile(e){return Kt(this,e)}reachable(e,t,n={}){return n.withDetail===!0?Oe(this.describe(),e,t,{...n,withDetail:!0}):Oe(this.describe(),e,t,n)}explain(e,t,n){return n?.reactive===!0?this._explainReactive(e,t,n):this._explainStatic(Q(e),Q(t),{...n?.maxDepth!==void 0?{maxDepth:Yt(n.maxDepth)}:{},...n?.findCycle!==void 0?{findCycle:Jt(n.findCycle)}:{}})}_explainStatic(e,t,n){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 Lt(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=_e(s,{name:`${n}_version`}),i=this.observe({timeline:!0,structured:!0}),a=!1,d=!1,u=()=>{a||d||(a=!0,ce(()=>{a=!1,!d&&(s+=1,o.emit(s))}))},c=i.onEvent(b=>{let m=b.type;m!=="data"&&m!=="error"&&m!=="complete"&&m!=="teardown"||u()}),g=[],h=new WeakSet,f=b=>{if(h.has(b)||d)return;h.add(b);let m=b.topology.subscribe(v=>{for(let _ of v){if(_[0]!==F)continue;let N=_[1];if(u(),N.kind==="added"&&N.nodeKind==="mount"){let x=b._mounts.get(N.name);x!=null&&f(x)}}});g.push(m);for(let v of b._mounts.keys()){let _=b._mounts.get(v);_!=null&&f(_)}};f(this);let l,y=e.actor;Qt(y)&&(l=y.subscribe(b=>{let m=!1,v=!1;for(let _ of b){let N=_[0];N===F?m=!0:(N===V||N===G||N===L)&&(v=!0)}m&&u(),v&&(l?.(),l=void 0,u())}));let p;try{p=pe([o],()=>this.describe(t),{name:n,describeKind:"derived",meta:{domain:"audit",kind:"describe"},equals:(b,m)=>b===m})}catch(b){c(),l?.();for(let m of g)m();throw i.dispose(),b}let w=ne(p);return{node:p,dispose(){d=!0,c(),l?.();for(let b of g)b();g.length=0,i.dispose(),w()}}}_describeReactiveDiff(e){let t={...e,reactive:!1},n=e.reactiveName??"describe-diff",s={name:this.name,nodes:{},edges:[],subgraphs:[]},o=this.describe(t),i=ft(s,o),a=_e(i,{name:n,meta:{domain:"audit",kind:"describe-diff"},equals:(h,f)=>h===f}),d=this._describeReactive({...e,reactiveName:void 0}),u=!1,c=d.node.subscribe(h=>{if(!u)for(let f of h){if(f[0]!==F)continue;let l=f[1],y=ft(o,l);o=l,y.events.length!==0&&a.emit(y)}}),g=ne(a);return{node:a,dispose(){u=!0,c(),d.dispose(),a.down([[L,"describe-diff disposed"]]),g()}}}_explainReactive(e,t,n){let s=0,o=_e(s,{name:"explain_version"}),i=this.observe({timeline:!0,structured:!0}),a=!1,d=!1,u=()=>{a||d||(a=!0,ce(()=>{a=!1,!d&&(s+=1,o.emit(s))}))},c=i.onEvent(b=>{let m=b.type;m!=="data"&&m!=="error"&&m!=="complete"&&m!=="teardown"||u()}),g=[];e!=null&&se(e)&&g.push(e),t!=null&&se(t)&&g.push(t),n?.maxDepth!=null&&se(n.maxDepth)&&g.push(n.maxDepth),n?.findCycle!=null&&se(n.findCycle)&&g.push(n.findCycle);let h=()=>{for(let b of g)if(b.cache===void 0)return!1;return!0},f=()=>{let b=Q(e),m=Q(t);return{from:b,to:m,found:!1,reason:"pending",steps:[],text:"(awaiting reactive args)",toJSON:()=>({from:b,to:m,found:!1,reason:"pending",steps:[]})}},l;try{l=pe([o],()=>{if(!h())return f();let b=Q(e),m=Q(t),v={...n?.maxDepth!==void 0?{maxDepth:Yt(n.maxDepth)}:{},...n?.findCycle!==void 0?{findCycle:Jt(n.findCycle)}:{}};return this._explainStatic(b,m,v)},{name:n?.name??"explain",describeKind:"derived",meta:{domain:"audit",kind:"explain_path",from:Q(e),to:Q(t)},equals:(b,m)=>b.found===m.found&&b.reason===m.reason&&b.steps.length===m.steps.length&&Hn(b.steps,m.steps)})}catch(b){throw c(),i.dispose(),b}let y=ne(l),p=[],w=b=>{let m;return m=b.subscribe(v=>{let _=!1,N=!1;for(let x of v){let k=x[0];k===F?_=!0:(k===V||k===G||k===L)&&(N=!0)}(_||N)&&u(),N&&m&&(m(),m=void 0)}),()=>{m&&(m(),m=void 0)}};for(let b of g)p.push(w(b));return{node:l,dispose(){d=!0,c();for(let b of p)b?.();p.length=0,i.dispose(),y()}}}_pathsMatching(e){let t=Ie(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}${C}${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}${C}${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}${C}${W}${C}${s}`;n.push([i,o]),this._appendMetaObserveTargets(i,o,n)}}observe(e,t){let n=typeof e=="string",o=Xt(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 c=e,g=this.resolve(c);if(a!=null&&!g.allowsObserve(a))throw new U({actor:a,action:"observe",nodeName:c});return i?this._buildStructuredObserver([[c,g]],o,"one"):{subscribe(h){return g.subscribe(h)},up(h){try{g.up?.(h)}catch(f){if(f instanceof U)return;throw f}}}}let d=[];this._collectObserveTargets("",d),d.sort((c,g)=>c[0]<g[0]?-1:c[0]>g[0]?1:0);let u=a==null?d:d.filter(([,c])=>c.allowsObserve(a));return i?this._buildStructuredObserver(u,o,"all"):{subscribe:c=>{let g=u.map(([h,f])=>f.subscribe(l=>{c(h,l)}));return()=>{for(let h of g)h()}},up:(c,g)=>{try{this.resolve(c).up?.(g)}catch(h){if(h instanceof U)return;throw h}}}}_observeReactive(e,t){let n=t.tiers,s=n!=null?new Set(n):null,o=t.reactiveName??"observe";return ot(i=>{let a=[],d=!1,u=!1,c=()=>{if(a.length===0||u)return;let y={events:a.slice(),flushedAt_ns:Z()};a.length=0,i.emit(y)},g={...t,reactive:!1,structured:!0,timeline:!0},h=e!=null?this.observe(e,g):this.observe(g),f=y=>{u||(a.push(y),!d&&(d=!0,ce(()=>{d=!1,c()})))};for(let y of h.events)f(y);let l=h.onEvent(f);return()=>{u=!0,l(),h.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 c=this.resolve(s);return this._buildStructuredObserver([[s,c]],i,"one")}let a=[];this._collectObserveTargets("",a),a.sort((c,g)=>c[0]<g[0]?-1:c[0]>g[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,t,o)}_createObserveResult(e,t,n){let s=t.timeline===!0,o=t.causal===!0,i=t.derived===!0,a=t.detail==="minimal",d=this.config.inspectorEnabled,u=(o||i)&&d,c=t.maxEvents,g=c!=null&&c>0?new we(c):null,h=[],f=new Set,l=t.tiers!=null?new Set(t.tiers):null,y={},p=new Set,w=0,b=0,m=0,v=0,_=0,N=0,x=!1,k=!1,E=0,S=new Map,T=new Map,I=new Map,M=O=>{if(!(l!=null&&!l.has(O.type))){g?g.push(O):h.push(O);for(let D of f)D(O)}},A=O=>l==null||l.has(O),ie=()=>s?{timestamp_ns:Z(),in_batch:ke(),batch_id:E}:{},Le=(O,D)=>{if(!(!u||!(O instanceof P)))return O._setInspectorHook(B=>{if(B.kind==="dep_message")S.set(O,B.depIndex);else if(B.kind==="run"){let he=B.batchData.map((R,H)=>R!=null&&R.length>0?R.at(-1):B.prevData[H]);T.set(O,he);let z=B.batchData.map(R=>R!=null?[...R]:void 0);I.set(O,z),i&&M({type:"derived",path:D,dep_values:he,dep_batches:z,...ie()})}})},Te=O=>{let D=S.get(O),B=T.get(O);if(!o||B==null)return{};let z=(D!=null&&D>=0&&O instanceof P?O._deps[D]:void 0)?.node,R=z?.v,H=I.get(O);return{trigger_dep_index:D,trigger_dep_name:z?.name,...R!=null?{trigger_version:{id:R.id,version:R.version}}:{},dep_values:[...B],...H!=null?{dep_batches:H}:{}}},mt=[],bt=[];for(let[O,D]of e){let B=Le(D,O);B&&mt.push(B),bt.push(D.subscribe(he=>{E++;for(let z of he){let R=z[0],H=ie();if(R===F){y[O]=z[1];let Be=D instanceof P?D.lastMutation?.actor??ae:ae;M({type:"data",path:O,data:z[1],actor:Be,...H,...Te(D)})}else if(a)R===q?A("dirty")&&w++:R===Y?A("resolved")&&b++:R===K?A("invalidate")&&m++:R===J?A("pause")&&v++:R===X?A("resume")&&_++:R===L?A("teardown")&&N++:R===V&&!p.has(O)?A("complete")&&(x=!0):R===G&&A("error")&&(k=!0,p.add(O));else if(R===q)A("dirty")&&w++,M({type:"dirty",path:O,...H});else if(R===Y)A("resolved")&&b++,M({type:"resolved",path:O,...H,...Te(D)});else if(R===K)A("invalidate")&&m++,M({type:"invalidate",path:O,...H});else if(R===J)A("pause")&&v++,M({type:"pause",path:O,lockId:z[1],...H});else if(R===X)A("resume")&&_++,M({type:"resume",path:O,lockId:z[1],...H});else if(R===V)A("complete")&&!p.has(O)&&(x=!0),M({type:"complete",path:O,...H});else if(R===G){A("error")&&(k=!0,p.add(O));let Be=D instanceof P?D.lastMutation?.actor??ae:ae;M({type:"error",path:O,data:z[1],actor:Be,...H})}else R===L&&(A("teardown")&&N++,M({type:"teardown",path:O,...H}))}}))}let je=!1,He=()=>{if(!je){je=!0;for(let O of bt)O();for(let O of mt)O();for(let O of Ne)O({value:void 0,done:!0});Ne.length=0}},Ve=[],Ne=[];f.add(O=>{let D=Ne.shift();D?D({value:O,done:!1}):Ve.push(O)});let yt={get values(){return y},get dirtyCount(){return w},get resolvedCount(){return b},get invalidateCount(){return m},get pauseCount(){return v},get resumeCount(){return _},get teardownCount(){return N},get events(){return g?g.toArray():[...h]},get anyCompletedCleanly(){return x},get anyErrored(){return k},get completedWithoutErrors(){return x&&!k},onEvent(O){return f.add(O),()=>f.delete(O)},dispose:He,expand(O){He();let D={...t};return typeof O=="string"?D.detail=O:Object.assign(D,O),n(Xt(D))},[Symbol.asyncIterator](){return{next(){return Ve.length>0?Promise.resolve({value:Ve.shift(),done:!1}):je?Promise.resolve({value:void 0,done:!0}):new Promise(O=>Ne.push(O))},return(){return He(),Promise.resolve({value:void 0,done:!0})}}}};return t.format!=null&&this._attachFormatLogger(yt,t),yt}_attachFormatLogger(e,t){let n=t.format;if(n==null)return;let s=t.logger??(l=>console.log(l)),o=t.includeTypes?new Set(t.includeTypes):null,i=t.excludeTypes?new Set(t.excludeTypes):null,a=o==null&&i==null?()=>!0:l=>(o==null||o.has(l))&&(i==null||!i.has(l)),d=Fn(t.theme),u=n==="stage-log"?Z():0,c=l=>l==null?"":t.stageLabels?.[l]??l,g=(l,y)=>l.length>y?`${l.slice(0,y-1)}\u2026`:l,h=l=>l.type==="data"||l.type==="error"?g(pt(l.data),120):"",f=l=>{if(n==="stage-log"){let x=(Z()-u)/1e9,k=c(l.path).padEnd(9);if(l.type==="data"){let E=h(l);return`[${x.toFixed(3)}s] ${k} \u2190${E?` ${E}`:""}`}if(l.type==="error"){let E=h(l);return`[${x.toFixed(3)}s] ${k} \u2717${E?` ${E}`:""}`}return l.type==="complete"?`[${x.toFixed(3)}s] ${k} \u25A0 complete`:`[${x.toFixed(3)}s] ${k} ${l.type}`}if(n==="json")try{return JSON.stringify(l)}catch{return JSON.stringify({type:l.type,path:l.path,data:"[unserializable]"})}let y=d[l.type]??"",p=l.path?`${d.path}${l.path}${d.reset} `:"",w=l.type==="data"||l.type==="error",b=l.type==="pause"||l.type==="resume",m=w?` ${pt(l.data)}`:b?` ${pt(l.lockId)}`:"",v=l.type==="data"||l.type==="resolved"||l.type==="derived"?l:void 0,_=v?.trigger_dep_name!=null?` <- ${v.trigger_dep_name}`:v?.trigger_dep_index!=null?` <- #${v.trigger_dep_index}`:"",N=l.in_batch?" [batch]":"";return`${p}${y}${l.type.toUpperCase()}${d.reset}${m}${_}${N}`};e.onEvent(l=>{a(l.type)&&s(f(l),l)})}addDisposer(e){return this._disposers.add(e),()=>{this._disposers.delete(e)}}destroy(){qt(this._disposers,this.name),this.signal([[L]],{internal:!0}),qt(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:d,guard:u,...c}=n.nodes[a];s[a]=c}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 _t(a,a.encode(i))}throw new Error(`snapshot: unknown format "${String(e.format)}"`)}static decode(e,t){let n=t?.config??fe,{codec:s,codecVersion:o,payload:i}=wt(e,n);return s.decode(i,o)}restore(e,t){if(Zt(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=>Ie(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 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){t?.onError?.(o,a)}}}}}static fromSnapshot(e,t){Zt(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 f of[...e.subgraphs].sort((l,y)=>{let p=l.split(C).length,w=y.split(C).length;return p!==w?p-w:l<y?-1:l>y?1:0})){let l=f.split(C),y=o;for(let p of l)y._mounts.has(p)||y.mount(p,new r(p)),y=y._mounts.get(p)}let i=s?Object.entries(s).map(([f,l])=>({re:Ie(f),factory:l})):[],a=f=>{for(let l of i)if(l.re.test(f))return l.factory},d=f=>{let l=f.split(C),y=l.pop();if(y==null||y.length===0)throw new Error(`invalid snapshot path "${f}"`);let p=o;for(let w of l){let b=p._mounts.get(w);if(!b)throw new Error(`unknown mount "${w}" in path "${f}"`);p=b}return[p,y]},u=Object.entries(e.nodes).filter(([f])=>!f.includes(`${C}${W}${C}`)).sort((f,l)=>f[0]<l[0]?-1:f[0]>l[0]?1:0),c=new Map(u),g=new Map,h=!0;for(;c.size>0&&h;){h=!1;for(let[f,l]of[...c.entries()]){let y=l?.deps??[];if(!y.every(_=>g.has(_)))continue;let[p,w]=d(f),b={...l?.meta??{}},m=a(f),v;if(l?.type==="state")v=_e(l.value,{meta:b});else{if(m==null)continue;v=m(w,{path:f,type:l.type,value:l.value,meta:b,deps:y,resolvedDeps:y.map(_=>g.get(_))})}p.add(v,{name:w}),g.set(f,v),c.delete(f),h=!0}}if(c.size>0){let f=[...c.keys()].sort().join(", ");throw new Error(`Graph.fromSnapshot could not reconstruct nodes without build callback: ${f}. 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(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}));t.autoRestore===!0&&this._cascadeRestore(e,t.onError);let s=(u,c)=>{if(u.disposed)return;let g=Cn(c.nodes);if(u.lastSnapshot!=null&&g!==""&&g===u.lastFingerprint)return;let h=u.seq+1,f=Se(),p=u.lastSnapshot==null||h%u.compactEvery===0?{name:this.name,mode:"full",snapshot:c,seq:h,timestamp_ns:f,format_version:re}:{name:this.name,mode:"diff",diff:tn(u.lastSnapshot,c),seq:h,timestamp_ns:f,format_version:re};if(u.tier.filter&&!u.tier.filter(p))return;let w;try{w=u.tier.save(p)}catch(b){t.onError?.(b,u.tier);return}if(w&&typeof w.then=="function"){let v=(u.savePending??Promise.resolve()).then(()=>w,()=>w).then(()=>{u.disposed||(u.seq=h,u.lastSnapshot=c,u.lastFingerprint=g)},_=>{t.onError?.(_,u.tier)});u.savePending=v.finally(()=>{u.savePending===v&&(u.savePending=void 0)})}else u.seq=h,u.lastSnapshot=c,u.lastFingerprint=g},o=(u,c)=>{try{s(u,c)}catch(g){t.onError?.(g,u.tier)}},i=(u,c)=>{if(!c.some(l=>{let y=this.config.messageTier(l[0]);return y>=3&&y<5}))return;if(t.filter){let l=this.tryResolve(u);if(l==null)return;let y=ct(l,dt("standard"));if(!t.filter(u,y))return}let h,f=()=>(h==null&&(h=this.snapshot()),h);for(let l of n)l.disposed||(l.debounceMs===0?o(l,f()):(l.timer==null&&(l.timer=new Fe),l.timer.start(l.debounceMs,()=>{l.disposed||o(l,this.snapshot())})))},a;if(t.paths!=null){let c=(typeof t.paths=="string"?this._pathsMatching(t.paths):t.paths).map(g=>{let h=this.tryResolve(g);return h==null?()=>{}:h.subscribe(f=>i(g,f))});a=()=>{for(let g of c)g()}}else a=this.observe().subscribe((u,c)=>i(u,c));let d=()=>{a();for(let u of n)u.disposed=!0,u.timer?.cancel();this._storageDisposers.delete(d)};return this._storageDisposers.add(d),{dispose:d}}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===re&&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(d){n?.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===re&&i.nodes!=null?i:void 0;if(a!=null)try{return r.fromSnapshot(a,n)}catch(d){n?.onError?.(d,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:Z(),...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(b=>!n.has(b)).sort(),i=[...n].filter(b=>!s.has(b)).sort(),a=[],d=[];for(let b of n){if(!s.has(b))continue;let m=e.nodes[b],v=t.nodes[b],_=m.v,N=v.v;_!=null&&N!=null&&_.id===N.id&&_.version!==N.version&&d.push({path:b,id:_.id,from:_.version,to:N.version});let x=_!=null&&N!=null&&_.id===N.id&&_.version===N.version;for(let k of["type","status","sentinel"]){let E=m[k],S=v[k];E!==S&&a.push({path:b,field:k,from:E,to:S})}if(!x)for(let k of["value","meta"]){let E=m[k],S=v[k];Gn(E,S)||a.push({path:b,field:k,from:E,to:S})}}let u=b=>`${b.from} ${b.to}`,c=new Set(e.edges.map(u)),g=new Set(t.edges.map(u)),h=t.edges.filter(b=>!c.has(u(b))),f=e.edges.filter(b=>!g.has(u(b))),l=new Set(e.subgraphs),y=new Set(t.subgraphs),p=[...y].filter(b=>!l.has(b)).sort(),w=[...l].filter(b=>!y.has(b)).sort();return{nodesAdded:o,nodesRemoved:i,nodesChanged:a,versionChanges:d,edgesAdded:h,edgesRemoved:f,subgraphsAdded:p,subgraphsRemoved:w}}};function tn(r,e){let t=oe.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 Oe(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,d=new Map,u=new Map,c=new Set;for(let[m,v]of Object.entries(r.nodes)){if(!m)continue;c.add(m);let _=v.deps??[];i.set(m,_);for(let N of _)N&&(c.add(N),a.has(N)||a.set(N,new Set),a.get(N).add(m))}for(let m of r.edges){if(m==null||typeof m!="object")continue;let v=typeof m.from=="string"?m.from:"",_=typeof m.to=="string"?m.to:"";!v||!_||(c.add(v),c.add(_),u.has(v)||u.set(v,new Set),u.get(v).add(_),d.has(_)||d.set(_,new Set),d.get(_).add(v))}if(!c.has(e))return n.withDetail?s:[];let g=n.both===!0,h=m=>{if(g){let x=i.get(m)??[],k=d.get(m),E=a.get(m),S=u.get(m),T=[...x];return k&&T.push(...k),E&&T.push(...E),S&&T.push(...S),T}if(t==="upstream"){let x=i.get(m)??[],k=d.get(m);return k?[...x,...k]:x}let v=a.get(m),_=u.get(m),N=v?[...v]:[];return _&&N.push(..._),N},f=new Set([e]),l=new Map,y=[{path:e,depth:0}],p=0,w=!1;for(;p<y.length;){let m=y[p++];if(o!=null&&m.depth>=o){h(m.path).length>0&&(w=!0);continue}for(let v of h(m.path))!v||f.has(v)||(f.add(v),l.set(v,m.depth+1),y.push({path:v,depth:m.depth+1}))}let b=[...l.keys()].sort((m,v)=>m<v?-1:m>v?1:0);return n.withDetail?{paths:b,depths:l,truncated:w}:b}function Hn(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}ye();function gt(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(d=>{for(let u of d){if(u[0]!==F)continue;let c=u[1];if(e(c,s,o),c.kind==="added"&&c.nodeKind==="mount"){let g=s._mounts.get(c.name);if(g instanceof oe){let h=`${o}${c.name}::`;n(g,h)}}else if(c.kind==="removed"&&c.nodeKind==="mount"){let g=`${o}${c.name}::`;for(let[h,f]of Array.from(t.entries()))h!==r&&f.prefix.startsWith(g)&&(f.off(),t.delete(h))}}});i.off=a;for(let[d,u]of s._mounts)if(u instanceof oe){let c=`${o}${d}::`;n(u,c)}};return n(r,""),()=>{for(let s of t.values())s.off();t.clear()}}function nn(r){let e=[];for(let[t,n]of Object.entries(r.nodes)){if(n.status!=="errored")continue;let s={path:t,status:"errored"},o=Oe(r,t,"upstream",{});for(let i of o)if(i!==t&&r.nodes[i]?.status==="errored"){s.upstreamCause=i;break}e.push(s)}return e.sort((t,n)=>t.path<n.path?-1:t.path>n.path?1:0),{ok:e.length===0,problems:e}}function rn(r,e){if(r.ok!==e.ok||r.problems.length!==e.problems.length)return!1;for(let t=0;t<r.problems.length;t++){let n=r.problems[t],s=e.problems[t];if(n.path!==s.path||n.status!==s.status||n.upstreamCause!==s.upstreamCause)return!1}return!0}function Vn(r){let e=r.describe({reactive:!0,detail:"standard",reactiveName:"graphLens.topology"}),t=e.node,n=pe([t],([g])=>nn(g),{name:"graphLens.health",describeKind:"derived",equals:rn,meta:at("lens","health")}),s=ne(n),o=new Map,i=-1,a=r.observe({reactive:!0,tiers:["data"]}),d=pe([a,t],([g,h])=>{let f=g,l=h;if(f!=null&&f.flushedAt_ns>i){i=f.flushedAt_ns;for(let y of f.events){if(y.type!=="data")continue;let p=y.path;if(p==null||p==="")continue;let w=o.get(p);o.set(p,{path:p,count:(w?.count??0)+1,lastUpdate_ns:f.flushedAt_ns})}}if(l!=null&&o.size>0){let y=new Set(Object.keys(l.nodes));for(let p of[...o.keys()])y.has(p)||o.delete(p)}return new Map(o)},{name:"graphLens.flow",describeKind:"derived",meta:at("lens","flow")}),u=ne(d),c=!1;return{topology:t,health:n,flow:d,dispose(){c||(c=!0,u(),s(),e.dispose())}}}0&&(module.exports={computeHealthReport,graphLens,healthReportEqual,watchTopologyTree});
@@ -1,7 +0,0 @@
1
- import '../../node-BYInONRr.cjs';
2
- import '../../graph-E6likq7w.cjs';
3
- export { w as watchTopologyTree } from '../../topology-tree-3LBKFsUo.cjs';
4
- export { F as FlowEntry, G as GraphLensView, H as HealthProblem, a as HealthReport, c as computeHealthReport, g as graphLens, h as healthReportEqual } from '../../index-CGhMJNHb.cjs';
5
- import '../../meta-Ct9nqQS5.cjs';
6
- import '../../extra/storage-core.cjs';
7
- import '../../extra/storage-tiers.cjs';
@@ -1,7 +0,0 @@
1
- import '../../node-BYInONRr.js';
2
- import '../../graph-BkIkog4h.js';
3
- export { w as watchTopologyTree } from '../../topology-tree-mF7Emqzm.js';
4
- export { F as FlowEntry, G as GraphLensView, H as HealthProblem, a as HealthReport, c as computeHealthReport, g as graphLens, h as healthReportEqual } from '../../index-N2MAxt7_.js';
5
- import '../../meta-D8OyedKp.js';
6
- import '../../extra/storage-core.js';
7
- import '../../extra/storage-tiers.js';
@@ -1 +0,0 @@
1
- import{a as b,b as c,c as d}from"../../chunk-5QSXEMXG.js";import{a}from"../../chunk-5TEFC2ZX.js";import"../../chunk-3G5U5QNE.js";import"../../chunk-C72GO4IZ.js";import"../../chunk-L6NSJVJZ.js";import"../../chunk-POXANAJ6.js";import"../../chunk-SGS4OJGS.js";import"../../chunk-ESMPEKEV.js";import"../../chunk-L77I47VU.js";import"../../chunk-35JTVPOX.js";import"../../chunk-LYCLF26R.js";import"../../chunk-CK2E7BTU.js";import"../../chunk-QYADASLV.js";export{b as computeHealthReport,d as graphLens,c as healthReportEqual,a as watchTopologyTree};