@graphrefly/graphrefly 0.43.0 → 0.44.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 (279) hide show
  1. package/dist/{cascading-CH-_VwG9.d.cts → cascading-BglDkMdX.d.cts} +2 -2
  2. package/dist/{cascading-OgKQZjsa.d.ts → cascading-MFgxu7Yo.d.ts} +2 -2
  3. package/dist/{chunk-KVV66NN2.js → chunk-2T7U5EU6.js} +1 -1
  4. package/dist/chunk-5M4CCMMD.js +45 -0
  5. package/dist/{chunk-I7IGYPSL.js → chunk-5XJ6B66J.js} +1 -1
  6. package/dist/{chunk-OFZG3TB3.js → chunk-6X7AFUJV.js} +1 -1
  7. package/dist/{chunk-EBW4V6JN.js → chunk-7K6PWTDQ.js} +1 -1
  8. package/dist/{chunk-D27JNOLZ.js → chunk-7LIAPXJB.js} +1 -1
  9. package/dist/{chunk-CLD3F4R5.js → chunk-7WPU3UHQ.js} +1 -1
  10. package/dist/{chunk-NNKJUORL.js → chunk-A5WCQ5NO.js} +1 -1
  11. package/dist/chunk-APPIWSGD.js +84 -0
  12. package/dist/{chunk-TZQPPQEQ.js → chunk-BEZWM2SY.js} +1 -1
  13. package/dist/{chunk-K2Q24F5T.js → chunk-CB676TKJ.js} +1 -1
  14. package/dist/{chunk-SUWT3ZON.js → chunk-CE6TI2TL.js} +1 -1
  15. package/dist/{chunk-VOPGGIL7.js → chunk-CLVB32RD.js} +1 -1
  16. package/dist/{chunk-V5A7M7RJ.js → chunk-CRVT7D2P.js} +1 -1
  17. package/dist/chunk-D7GPHKFH.js +1 -0
  18. package/dist/{chunk-OCKEEPRJ.js → chunk-DHRX7JX4.js} +1 -1
  19. package/dist/chunk-FZMYDOWV.js +1 -0
  20. package/dist/{chunk-35JTVPOX.js → chunk-GHBWHMRZ.js} +1 -1
  21. package/dist/{chunk-KGKJCHEK.js → chunk-GLERH466.js} +1 -1
  22. package/dist/{chunk-TPKQW72B.js → chunk-HIDYF36O.js} +1 -1
  23. package/dist/chunk-HITNVN6B.js +3 -0
  24. package/dist/{chunk-P6C4WHZO.js → chunk-HY4DJBA7.js} +1 -1
  25. package/dist/chunk-KZIEYVXN.js +1 -0
  26. package/dist/{chunk-O2BLLH7M.js → chunk-N4MQX6JU.js} +1 -1
  27. package/dist/{chunk-4YAN45KM.js → chunk-N7FHEL4D.js} +1 -1
  28. package/dist/chunk-NTEURFZH.js +1 -0
  29. package/dist/{chunk-OYJKFY7V.js → chunk-OIVP6KFV.js} +1 -1
  30. package/dist/{chunk-Q4U3A3L5.js → chunk-OPHBU3LG.js} +1 -1
  31. package/dist/{chunk-PT7W5FCD.js → chunk-OYQOZP2F.js} +1 -1
  32. package/dist/{chunk-6HOSXQKF.js → chunk-PTZK576G.js} +1 -1
  33. package/dist/{chunk-S3EEIPO7.js → chunk-ST7UXLWR.js} +1 -1
  34. package/dist/chunk-SVY7VUYU.js +1 -0
  35. package/dist/{chunk-QYVXF7GW.js → chunk-TK3NWWD4.js} +1 -1
  36. package/dist/chunk-UNGSTR4X.js +61 -0
  37. package/dist/{chunk-VQ4A6T2A.js → chunk-VV4N5P64.js} +1 -1
  38. package/dist/{chunk-FDQGFWLF.js → chunk-W3I423PS.js} +1 -1
  39. package/dist/{chunk-XG62INFA.js → chunk-WJR24TAG.js} +1 -1
  40. package/dist/{chunk-F3IGTWCQ.js → chunk-XTGKMHSW.js} +1 -1
  41. package/dist/{chunk-JQFH2DV6.js → chunk-YBB7ZGTY.js} +1 -1
  42. package/dist/{chunk-CUNIRONA.js → chunk-Z4NPUARF.js} +1 -1
  43. package/dist/{chunk-KRH66M4O.js → chunk-ZGNQRPDT.js} +1 -1
  44. package/dist/{chunk-JNWRYDJN.js → chunk-ZKPSFFKU.js} +1 -1
  45. package/dist/{chunk-FG4TKHMC.js → chunk-ZLV5SQSX.js} +1 -1
  46. package/dist/compat/index.cjs +5 -5
  47. package/dist/compat/index.d.cts +16 -16
  48. package/dist/compat/index.d.ts +16 -16
  49. package/dist/compat/index.js +1 -1
  50. package/dist/compat/jotai/index.cjs +1 -1
  51. package/dist/compat/jotai/index.d.cts +2 -2
  52. package/dist/compat/jotai/index.d.ts +2 -2
  53. package/dist/compat/jotai/index.js +1 -1
  54. package/dist/compat/nanostores/index.cjs +1 -1
  55. package/dist/compat/nanostores/index.d.cts +2 -2
  56. package/dist/compat/nanostores/index.d.ts +2 -2
  57. package/dist/compat/nanostores/index.js +1 -1
  58. package/dist/compat/nestjs/index.cjs +5 -5
  59. package/dist/compat/nestjs/index.d.cts +8 -8
  60. package/dist/compat/nestjs/index.d.ts +8 -8
  61. package/dist/compat/nestjs/index.js +1 -1
  62. package/dist/compat/react/index.d.cts +2 -2
  63. package/dist/compat/react/index.d.ts +2 -2
  64. package/dist/compat/solid/index.d.cts +2 -2
  65. package/dist/compat/solid/index.d.ts +2 -2
  66. package/dist/compat/svelte/index.d.cts +2 -2
  67. package/dist/compat/svelte/index.d.ts +2 -2
  68. package/dist/compat/vue/index.d.cts +2 -2
  69. package/dist/compat/vue/index.d.ts +2 -2
  70. package/dist/compat/zustand/index.cjs +3 -3
  71. package/dist/compat/zustand/index.d.cts +4 -4
  72. package/dist/compat/zustand/index.d.ts +4 -4
  73. package/dist/compat/zustand/index.js +1 -1
  74. package/dist/core/index.cjs +1 -1
  75. package/dist/core/index.d.cts +3 -4
  76. package/dist/core/index.d.ts +3 -4
  77. package/dist/core/index.js +1 -1
  78. package/dist/{decay-CdEBmDIs.d.ts → decay-BvOWTZ00.d.ts} +2 -2
  79. package/dist/{decay-2ZukgQ4o.d.cts → decay-CFlLvXUT.d.cts} +2 -2
  80. package/dist/extra/browser.cjs +1 -1
  81. package/dist/extra/browser.d.cts +1 -1
  82. package/dist/extra/browser.d.ts +1 -1
  83. package/dist/extra/browser.js +1 -1
  84. package/dist/extra/index.cjs +15 -15
  85. package/dist/extra/index.d.cts +10 -10
  86. package/dist/extra/index.d.ts +10 -10
  87. package/dist/extra/index.js +1 -1
  88. package/dist/extra/node.cjs +2 -2
  89. package/dist/extra/node.d.cts +1 -1
  90. package/dist/extra/node.d.ts +1 -1
  91. package/dist/extra/node.js +1 -1
  92. package/dist/extra/operators.cjs +1 -1
  93. package/dist/extra/operators.d.cts +9 -1
  94. package/dist/extra/operators.d.ts +9 -1
  95. package/dist/extra/operators.js +1 -1
  96. package/dist/extra/reactive.cjs +1 -1
  97. package/dist/extra/reactive.d.cts +3 -3
  98. package/dist/extra/reactive.d.ts +3 -3
  99. package/dist/extra/reactive.js +1 -1
  100. package/dist/extra/render/index.d.cts +3 -3
  101. package/dist/extra/render/index.d.ts +3 -3
  102. package/dist/extra/sources.cjs +3 -3
  103. package/dist/extra/sources.d.cts +1 -1
  104. package/dist/extra/sources.d.ts +1 -1
  105. package/dist/extra/sources.js +1 -1
  106. package/dist/extra/storage-browser.cjs +1 -1
  107. package/dist/extra/storage-browser.d.cts +1 -1
  108. package/dist/extra/storage-browser.d.ts +1 -1
  109. package/dist/extra/storage-browser.js +1 -1
  110. package/dist/{fallback-Ctlj2tMY.d.cts → fallback-74oxi34l.d.cts} +1 -1
  111. package/dist/{fallback-CqYVLL6X.d.ts → fallback-DUyyBTBK.d.ts} +1 -1
  112. package/dist/graph/index.cjs +7 -7
  113. package/dist/graph/index.d.cts +5 -5
  114. package/dist/graph/index.d.ts +5 -5
  115. package/dist/graph/index.js +1 -1
  116. package/dist/{graph-C4SHb3Ly.d.cts → graph-CWvEUQAq.d.cts} +196 -3
  117. package/dist/{graph-7VguS7a4.d.ts → graph-D9LFnda9.d.ts} +196 -3
  118. package/dist/{index-O7fucFrU.d.cts → index-5k1T6jl0.d.cts} +9 -9
  119. package/dist/{index-DyR7eU5S.d.cts → index-9770hRuQ.d.cts} +4 -4
  120. package/dist/{index-COD1kVoS.d.cts → index-B-_tFaqV.d.cts} +4 -4
  121. package/dist/{index-CLon-IWF.d.cts → index-B17QddL1.d.cts} +4 -4
  122. package/dist/{index-B-i4_g3k.d.ts → index-B1F8Enjf.d.ts} +61 -8
  123. package/dist/{index-DBevwHj_.d.ts → index-B5S8ULbU.d.ts} +3 -3
  124. package/dist/{index-Dgs8zcj7.d.ts → index-B8YnZpIR.d.ts} +2 -2
  125. package/dist/{index-DSZ3ZCHF.d.ts → index-BHskSB8v.d.ts} +28 -17
  126. package/dist/{index-CDXc9zKM.d.cts → index-BIYAkbAi.d.cts} +1 -1
  127. package/dist/{index-C9kSENB4.d.cts → index-BQSKmbuG.d.cts} +1 -1
  128. package/dist/{index-tJoTcnHh.d.cts → index-BaQaY_IQ.d.cts} +2 -2
  129. package/dist/{index-CJK1JkYy.d.ts → index-BmZXHqkE.d.ts} +1 -1
  130. package/dist/{index-K0_0eR8g.d.ts → index-BoJ5JHxI.d.ts} +3 -3
  131. package/dist/{index-JZUPJIJy.d.ts → index-BocU7pqs.d.ts} +4 -4
  132. package/dist/{index-ChOyVLKm.d.cts → index-BrPrLl4e.d.cts} +1 -1
  133. package/dist/{index-BiX1Nkgx.d.cts → index-BxNs2HB9.d.cts} +22 -8
  134. package/dist/{index-Bf7eqeSF.d.ts → index-Byu-OpX_.d.ts} +2 -2
  135. package/dist/{index-BoLv_OfD.d.cts → index-C1T3d7V-.d.cts} +61 -8
  136. package/dist/{index-BTQtTb_H.d.cts → index-C5ri2Axc.d.cts} +3 -3
  137. package/dist/{index-z96luz5O.d.cts → index-C5stwKcw.d.cts} +1 -1
  138. package/dist/{index-D4Y1cMG0.d.ts → index-C9l6OEBL.d.ts} +1 -1
  139. package/dist/{index-CCq87F7t.d.ts → index-CBBLl_rc.d.ts} +1 -1
  140. package/dist/{index-cm1GNcWE.d.ts → index-CBGUK09R.d.ts} +4 -4
  141. package/dist/{index-0rKFCVFp.d.cts → index-CC-AvFTy.d.cts} +3 -3
  142. package/dist/{index-C59mYFKp.d.ts → index-CJF1URuX.d.ts} +9 -9
  143. package/dist/{index-BJX94aud.d.cts → index-CK29LV56.d.cts} +1 -1
  144. package/dist/{index-BP8a88zx.d.ts → index-CMh5Rz1y.d.ts} +4 -4
  145. package/dist/{index-CvrqGfNS.d.ts → index-CPQlGA29.d.ts} +1 -1
  146. package/dist/{index-D-AEQVLo.d.ts → index-CR8QpwX8.d.ts} +49 -24
  147. package/dist/{index-Du7u1lSf.d.cts → index-CS0LTlB8.d.cts} +4 -4
  148. package/dist/{index-Bc41FuHp.d.cts → index-CSOmP7xT.d.cts} +2 -2
  149. package/dist/{index-BsT7F2et.d.ts → index-CYq8vAyV.d.ts} +2 -2
  150. package/dist/{index-CPT7C_f1.d.ts → index-CZ3r5Rxp.d.ts} +4 -4
  151. package/dist/{index-BojK2fwH.d.cts → index-CasX6Pfq.d.cts} +68 -9
  152. package/dist/{index-BG0BN3PB.d.ts → index-CdAlHFEt.d.ts} +1 -1
  153. package/dist/{index-wAzD9yVj.d.ts → index-CdTelp1M.d.ts} +8 -4
  154. package/dist/{index-CQG3D1cp.d.ts → index-CeFiHtAg.d.ts} +4 -4
  155. package/dist/{index-RV_yDjOX.d.cts → index-Cj3WohTd.d.cts} +8 -4
  156. package/dist/{index-BAOD98JD.d.cts → index-Climxqsu.d.cts} +4 -4
  157. package/dist/{index-O16yXPK4.d.cts → index-Co7uli2l.d.cts} +28 -17
  158. package/dist/{index-DIOoAZUX.d.ts → index-CviRnE4K.d.ts} +1 -1
  159. package/dist/{index-Dhc7a7Xo.d.cts → index-Cwv0KWcU.d.cts} +2 -2
  160. package/dist/{index-Dn-wI9g4.d.ts → index-CzLVrjxn.d.ts} +2 -2
  161. package/dist/{index-C9pjcz3l.d.cts → index-D0aciIex.d.cts} +3 -3
  162. package/dist/{index-DwigL4lY.d.ts → index-DHen9Klo.d.ts} +22 -8
  163. package/dist/{index-BwLvVVsy.d.cts → index-DV_1YuVk.d.cts} +40 -8
  164. package/dist/{index-BdGtBX-X.d.cts → index-Dc4AYqrJ.d.cts} +3 -3
  165. package/dist/{index-Dmqp7KjD.d.ts → index-Dgl1HpPn.d.ts} +1 -1
  166. package/dist/{index-CAC_rNzm.d.ts → index-DisjX8a-.d.ts} +40 -8
  167. package/dist/{index-B5iz82A3.d.cts → index-UPSiS-X7.d.cts} +49 -24
  168. package/dist/{index-CZQXo5tH.d.ts → index-Yq60JP3s.d.ts} +3 -3
  169. package/dist/{index-f5IivDUX.d.cts → index-ZVQhLa2i.d.cts} +1 -1
  170. package/dist/{index-hHcaFlJX.d.cts → index-_6ODbuOu.d.cts} +1 -1
  171. package/dist/{index-BVpm6noz.d.cts → index-hcDJ8PSI.d.cts} +1 -1
  172. package/dist/{index-DBHK8O6H.d.ts → index-nozs3fFC.d.ts} +3 -3
  173. package/dist/{index-Dh_HJ82K.d.ts → index-p09KSrTN.d.ts} +68 -9
  174. package/dist/{index-C7O6r5fV.d.ts → index-sqkqlb1p.d.ts} +1 -1
  175. package/dist/{index-CZjOhcBy.d.cts → index-tRCxuAXF.d.cts} +2 -2
  176. package/dist/index.cjs +48 -48
  177. package/dist/index.d.cts +42 -43
  178. package/dist/index.d.ts +42 -43
  179. package/dist/index.js +1 -1
  180. package/dist/{node-ClS5yC-B.d.cts → node-kK3CvTrR.d.cts} +1 -1
  181. package/dist/{node-ClS5yC-B.d.ts → node-kK3CvTrR.d.ts} +1 -1
  182. package/dist/{observable-BsBzUrcI.d.ts → observable-DWjNfLvC.d.ts} +1 -1
  183. package/dist/{observable-DLGPPtb8.d.cts → observable-e3eiPPFy.d.cts} +1 -1
  184. package/dist/patterns/ai/browser.cjs +5 -5
  185. package/dist/patterns/ai/browser.d.cts +4 -4
  186. package/dist/patterns/ai/browser.d.ts +4 -4
  187. package/dist/patterns/ai/browser.js +1 -1
  188. package/dist/patterns/ai/index.cjs +16 -16
  189. package/dist/patterns/ai/index.d.cts +16 -17
  190. package/dist/patterns/ai/index.d.ts +16 -17
  191. package/dist/patterns/ai/index.js +1 -1
  192. package/dist/patterns/ai/node.cjs +1 -1
  193. package/dist/patterns/ai/node.d.cts +4 -4
  194. package/dist/patterns/ai/node.d.ts +4 -4
  195. package/dist/patterns/ai/node.js +1 -1
  196. package/dist/patterns/cqrs/index.cjs +3 -3
  197. package/dist/patterns/cqrs/index.d.cts +6 -6
  198. package/dist/patterns/cqrs/index.d.ts +6 -6
  199. package/dist/patterns/cqrs/index.js +1 -1
  200. package/dist/patterns/demo-shell/index.cjs +5 -5
  201. package/dist/patterns/demo-shell/index.d.cts +5 -5
  202. package/dist/patterns/demo-shell/index.d.ts +5 -5
  203. package/dist/patterns/demo-shell/index.js +1 -1
  204. package/dist/patterns/domain-templates/index.cjs +3 -3
  205. package/dist/patterns/domain-templates/index.d.cts +4 -4
  206. package/dist/patterns/domain-templates/index.d.ts +4 -4
  207. package/dist/patterns/domain-templates/index.js +1 -1
  208. package/dist/patterns/graphspec/index.cjs +16 -16
  209. package/dist/patterns/graphspec/index.d.cts +5 -5
  210. package/dist/patterns/graphspec/index.d.ts +5 -5
  211. package/dist/patterns/graphspec/index.js +1 -1
  212. package/dist/patterns/harness/index.cjs +9 -9
  213. package/dist/patterns/harness/index.d.cts +10 -11
  214. package/dist/patterns/harness/index.d.ts +10 -11
  215. package/dist/patterns/harness/index.js +1 -1
  216. package/dist/patterns/inspect/index.cjs +3 -3
  217. package/dist/patterns/inspect/index.d.cts +7 -7
  218. package/dist/patterns/inspect/index.d.ts +7 -7
  219. package/dist/patterns/inspect/index.js +1 -1
  220. package/dist/patterns/job-queue/index.cjs +3 -3
  221. package/dist/patterns/job-queue/index.d.cts +6 -6
  222. package/dist/patterns/job-queue/index.d.ts +6 -6
  223. package/dist/patterns/job-queue/index.js +1 -1
  224. package/dist/patterns/memory/index.cjs +3 -3
  225. package/dist/patterns/memory/index.d.cts +6 -6
  226. package/dist/patterns/memory/index.d.ts +6 -6
  227. package/dist/patterns/memory/index.js +1 -1
  228. package/dist/patterns/messaging/index.cjs +3 -3
  229. package/dist/patterns/messaging/index.d.cts +5 -5
  230. package/dist/patterns/messaging/index.d.ts +5 -5
  231. package/dist/patterns/messaging/index.js +1 -1
  232. package/dist/patterns/orchestration/index.cjs +3 -3
  233. package/dist/patterns/orchestration/index.d.cts +6 -7
  234. package/dist/patterns/orchestration/index.d.ts +6 -7
  235. package/dist/patterns/orchestration/index.js +1 -1
  236. package/dist/patterns/process/index.cjs +3 -1
  237. package/dist/patterns/process/index.d.cts +7 -7
  238. package/dist/patterns/process/index.d.ts +7 -7
  239. package/dist/patterns/process/index.js +1 -1
  240. package/dist/patterns/reactive-layout/index.cjs +4 -4
  241. package/dist/patterns/reactive-layout/index.d.cts +5 -5
  242. package/dist/patterns/reactive-layout/index.d.ts +5 -5
  243. package/dist/patterns/reactive-layout/index.js +1 -1
  244. package/dist/patterns/reduction/index.cjs +3 -3
  245. package/dist/patterns/reduction/index.d.cts +4 -4
  246. package/dist/patterns/reduction/index.d.ts +4 -4
  247. package/dist/patterns/reduction/index.js +1 -1
  248. package/dist/patterns/surface/index.cjs +10 -10
  249. package/dist/patterns/surface/index.d.cts +6 -6
  250. package/dist/patterns/surface/index.d.ts +6 -6
  251. package/dist/patterns/surface/index.js +1 -1
  252. package/dist/{pipeline-graph-DPqKDk59.d.cts → pipeline-graph-CIKhynsF.d.cts} +11 -6
  253. package/dist/{pipeline-graph-loP57TBA.d.ts → pipeline-graph-Sgj0gCwn.d.ts} +11 -6
  254. package/dist/{reactive-layout-v7KPvxoc.d.ts → reactive-layout-DOTs9P3X.d.ts} +2 -2
  255. package/dist/{reactive-layout-Dsvob4zD.d.cts → reactive-layout-DgctbqZo.d.cts} +2 -2
  256. package/dist/{reactive-log-BezYsbA_.d.ts → reactive-log-BKALbfal.d.ts} +1 -1
  257. package/dist/{reactive-log-B00laMSQ.d.cts → reactive-log-DIGdYqQ6.d.cts} +1 -1
  258. package/dist/{reactive-map-48mnZ-nu.d.cts → reactive-map-CEFGp8TK.d.cts} +1 -1
  259. package/dist/{reactive-map-BVVPdvmi.d.ts → reactive-map-DS_SIAxv.d.ts} +1 -1
  260. package/dist/resilience-6LYQJAC5.js +1 -0
  261. package/dist/{sugar-DLwvMr3F.d.ts → sugar-DQjFmVqb.d.cts} +178 -2
  262. package/dist/{sugar-DyVGtczU.d.cts → sugar-fhLIE7TT.d.ts} +178 -2
  263. package/dist/{topology-tree-BSdfSwMi.d.cts → topology-tree-Bcz27hpF.d.cts} +1 -1
  264. package/dist/{topology-tree-BNGvuG82.d.ts → topology-tree-xvaD0fOX.d.ts} +1 -1
  265. package/dist/{types-B1jDWVsM.d.cts → types-C0_yquda.d.cts} +1 -1
  266. package/dist/{types-DkzUUs0H.d.ts → types-CWFysE9E.d.ts} +1 -1
  267. package/package.json +1 -1
  268. package/dist/chunk-3XDYJRYU.js +0 -1
  269. package/dist/chunk-4I45FVQS.js +0 -1
  270. package/dist/chunk-626TESAC.js +0 -3
  271. package/dist/chunk-INQD2KRQ.js +0 -1
  272. package/dist/chunk-LYCLF26R.js +0 -1
  273. package/dist/chunk-NON4NLIC.js +0 -45
  274. package/dist/chunk-QE4IGY7I.js +0 -61
  275. package/dist/chunk-VNC3TMVY.js +0 -1
  276. package/dist/chunk-Y4NI3X7O.js +0 -84
  277. package/dist/meta-BgVAsg9j.d.ts +0 -102
  278. package/dist/meta-vE8bxW1E.d.cts +0 -102
  279. package/dist/resilience-YIWPK4YC.js +0 -1
@@ -1,18 +1,18 @@
1
- "use strict";var nt=Object.defineProperty;var Sn=Object.getOwnPropertyDescriptor;var Rn=Object.getOwnPropertyNames;var En=Object.prototype.hasOwnProperty;var $=(n,e)=>()=>(n&&(e=n(n=0)),e);var An=(n,e)=>{for(var t in e)nt(n,t,{get:e[t],enumerable:!0})},Dn=(n,e,t,r)=>{if(e&&typeof e=="object"||typeof e=="function")for(let s of Rn(e))!En.call(n,s)&&s!==t&&nt(n,s,{get:()=>e[s],enumerable:!(r=Sn(e,s))||r.enumerable});return n};var Cn=n=>Dn(nt({},"__esModule",{value:!0}),n);function xt(n,e){let t=new TextEncoder().encode(n.name);if(t.length===0||t.length>255)throw new Error(`encodeEnvelope: codec name "${n.name}" encodes to ${t.length} bytes (must be 1\u2013255)`);let r=n.version;if(!Number.isInteger(r)||r<0||r>65535)throw new Error(`encodeEnvelope: codec.version ${r} out of u16 range (expected integer 0\u201365535)`);let s=2+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++]=rt,o[i++]=t.length,o.set(t,i),i+=t.length,o[i++]=r>>>8&255,o[i++]=r&255,o.set(e,i),o}function St(n,e){if(n.length<Tt)throw new Error(`decodeEnvelope: bytes too short (${n.length} < ${Tt})`);let t=0,r=n[t++];if(r!==rt)throw new Error(`decodeEnvelope: unsupported envelope version ${r} (expected ${rt})`);let s=n[t++];if(s===0)throw new Error("decodeEnvelope: name_len must be >= 1");if(t+s+2>n.length)throw new Error(`decodeEnvelope: envelope truncated (need ${t+s+2} bytes, have ${n.length})`);let o=new TextDecoder().decode(n.subarray(t,t+s));t+=s;let i=(n[t]<<8|n[t+1])>>>0;t+=2;let a=n.subarray(t),u=e.lookupCodec(o);if(u==null)throw new Error(`decodeEnvelope: codec "${o}" not registered (envelope codec_v=${i})`);return{codec:u,codecVersion:i,payload:a}}function Rt(n){n.registerCodec(Mn)}var Mn,rt,Tt,st=$(()=>{"use strict";Mn={name:"json",version:1,contentType:"application/json",encode(n){let e=JSON.stringify(n);return new TextEncoder().encode(e)},decode(n,e){let t=new TextDecoder().decode(n);return JSON.parse(t)}},rt=1,Tt=4});function Fe(n){if(n==null)return me;let{type:e,id:t,...r}=n;return{type:e??"system",id:t??"",...r}}var me,ot=$(()=>{"use strict";me={type:"system",id:""}});function Pe(){return be>0||Ee}function Et(){return be>0}function ve(n){be>0?Ae.push(n):n()}function Ie(n){be+=1;let e=!1;try{n()}catch(t){throw e=!0,t}finally{if(be-=1,be===0)if(e){if(!Ee){let t=Ae.splice(0);for(let r of t)try{r()}catch{}de.length=0,le.length=0,ye.length=0}}else Gn()}}function Gn(){let n=!Ee;n&&(Ee=!0);let e=[],t=0;try{for(;de.length>0||le.length>0||ye.length>0||n&&Ae.length>0;){if(n&&Ae.length>0){let o=Ae.splice(0);for(let i of o)try{i()}catch(a){e.push(a)}continue}if(t+=1,t>1e3)throw de.length=0,le.length=0,ye.length=0,new Error("batch drain exceeded 1000 iterations \u2014 likely a reactive cycle");let s=(de.length>0?de:le.length>0?le:ye).splice(0);for(let o of s)try{o()}catch(i){e.push(i)}}}finally{n&&(Ee=!1)}if(e.length===1)throw e[0];if(e.length>1)throw new AggregateError(e,"batch drain: multiple callbacks threw")}function je(n,e,t){if(e.length===0)return;if(e.length===1){let c=t(e[0][0]);if(c<3||!Pe()){n(e);return}(c>=5?ye:c===4?le:de).push(()=>n(e));return}let r=e.length,s=r,o=r,i=r,a=0;for(;a<r&&t(e[a][0])<3;)a++;for(s=a;a<r&&t(e[a][0])===3;)a++;for(o=a;a<r&&t(e[a][0])===4;)a++;i=a;let u=Pe();if(s>0){let c=e.slice(0,s);n(c)}if(o>s){let c=e.slice(s,o);u?de.push(()=>n(c)):n(c)}if(i>o){let c=e.slice(o,i);u?le.push(()=>n(c)):n(c)}if(r>i){let c=e.slice(i,r);u?ye.push(()=>n(c)):n(c)}}var be,Ee,de,le,ye,Ae,Le=$(()=>{"use strict";be=0,Ee=!1,de=[],le=[],ye=[],Ae=[]});function oe(){return Math.trunc(performance.now()*1e6)}function Ve(){return Date.now()*1e6}var Be=$(()=>{"use strict"});var De,F,X,ne,te,re,ie,V,z,C,_e,it,$n,at,Fn,Pn,ct,At,Dt,Ct,ut,we=$(()=>{"use strict";De=Symbol.for("graphrefly/START"),F=Symbol.for("graphrefly/DATA"),X=Symbol.for("graphrefly/DIRTY"),ne=Symbol.for("graphrefly/RESOLVED"),te=Symbol.for("graphrefly/INVALIDATE"),re=Symbol.for("graphrefly/PAUSE"),ie=Symbol.for("graphrefly/RESUME"),V=Symbol.for("graphrefly/TEARDOWN"),z=Symbol.for("graphrefly/COMPLETE"),C=Symbol.for("graphrefly/ERROR"),_e=Object.freeze([X]),it=Object.freeze([ne]),$n=Object.freeze([te]),at=Object.freeze([De]),Fn=Object.freeze([z]),Pn=Object.freeze([V]),ct=Object.freeze([_e]),At=Object.freeze([it]),Dt=Object.freeze([$n]),Ct=Object.freeze([Fn]),ut=Object.freeze([Pn])});function Mt(n){n.registerMessageType(De,{tier:0,wireCrossing:!1}),n.registerMessageType(X,{tier:1,wireCrossing:!1}),n.registerMessageType(te,{tier:1,wireCrossing:!1,metaPassthrough:!1}),n.registerMessageType(re,{tier:2,wireCrossing:!1}),n.registerMessageType(ie,{tier:2,wireCrossing:!1}),n.registerMessageType(F,{tier:3,wireCrossing:!0}),n.registerMessageType(ne,{tier:3,wireCrossing:!0}),n.registerMessageType(z,{tier:4,wireCrossing:!0,metaPassthrough:!1}),n.registerMessageType(C,{tier:4,wireCrossing:!0,metaPassthrough:!1}),n.registerMessageType(V,{tier:5,wireCrossing:!0,metaPassthrough:!1})}var ze,Gt=$(()=>{"use strict";we();ze=class{_messageTypes=new Map;_codecs=new Map;_onMessage;_onSubscribe;_defaultVersioning;_defaultHashFn;_inspectorEnabled=!(typeof process<"u"&&process.env?.NODE_ENV==="production");_globalInspector;_rigorRecorder;_frozen=!1;tierOf;constructor(e){this._onMessage=e.onMessage,this._onSubscribe=e.onSubscribe,this._defaultVersioning=e.defaultVersioning,this._defaultHashFn=e.defaultHashFn,this.tierOf=t=>{let r=this._messageTypes.get(t);return r!=null?r.tier:1}}get onMessage(){return this._frozen=!0,this._onMessage}get onSubscribe(){return this._frozen=!0,this._onSubscribe}set onMessage(e){this._assertUnfrozen(),this._onMessage=e}set onSubscribe(e){this._assertUnfrozen(),this._onSubscribe=e}get defaultVersioning(){return this._defaultVersioning}set defaultVersioning(e){this._assertUnfrozen(),this._defaultVersioning=e}get defaultHashFn(){return this._defaultHashFn}set defaultHashFn(e){this._assertUnfrozen(),this._defaultHashFn=e}get inspectorEnabled(){return this._inspectorEnabled}set inspectorEnabled(e){this._inspectorEnabled=e}get globalInspector(){return this._globalInspector}set globalInspector(e){this._globalInspector=e}get rigorRecorder(){return this._rigorRecorder}set rigorRecorder(e){this._rigorRecorder=e}registerMessageType(e,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 $t(n){return Array.isArray(n)?[...n]:[n]}function In(n,e){return n.has(e)||n.has("*")}function Ft(n){let e=[];return n((s,o)=>{e.push({kind:"allow",actions:new Set($t(s)),where:o?.where??(()=>!0)})},(s,o)=>{e.push({kind:"deny",actions:new Set($t(s)),where:o?.where??(()=>!0)})}),(s,o)=>{let i=!1,a=!1;for(let u of e)In(u.actions,o)&&u.where(s)&&(u.kind==="deny"?i=!0:a=!0);return i?!1:a}}function dt(n){let e=jn.filter(t=>n({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,jn,Ce=$(()=>{"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}};jn=["human","llm","wallet","system"]});function lt(n){if(n===void 0)return null;if(typeof n=="number"){if(!Number.isFinite(n))throw new TypeError(`Cannot hash non-finite number: ${n}`);if(Number.isInteger(n)&&!Number.isSafeInteger(n))throw new TypeError(`Cannot hash integer outside safe range (|n| > 2^53-1): ${n}. Cross-language cid parity is not guaranteed for unsafe integers.`);return n}if(typeof n=="string"||typeof n=="boolean"||n===null)return n;if(Array.isArray(n))return n.map(lt);if(typeof n=="object"&&n!==null){let e={};for(let t of Object.keys(n).sort())e[t]=lt(n[t]);return e}return null}function Bn(n){let e=Vn.encode(n),t=e.length,r=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,r>>>0,!1),i.setUint32(s-8,Math.floor(r/4294967296)>>>0,!1);let a=1779033703,u=3144134277,c=1013904242,d=2773480762,m=1359893119,p=2600822924,h=528734635,l=1541459225,v=new Uint32Array(64),y=(g,f)=>g>>>f|g<<32-f;for(let g=0;g<s;g+=64){for(let N=0;N<16;N++)v[N]=i.getUint32(g+N*4,!1);for(let N=16;N<64;N++){let P=v[N-15],E=v[N-2],A=y(P,7)^y(P,18)^P>>>3,Q=y(E,17)^y(E,19)^E>>>10;v[N]=v[N-16]+A+v[N-7]+Q>>>0}let f=a,b=u,_=c,k=d,O=m,T=p,R=h,S=l;for(let N=0;N<64;N++){let P=y(O,6)^y(O,11)^y(O,25),E=O&T^~O&R,A=S+P+E+Ln[N]+v[N]>>>0,Q=y(f,2)^y(f,13)^y(f,22),ge=f&b^f&_^b&_,B=Q+ge>>>0;S=R,R=T,T=O,O=k+A>>>0,k=_,_=b,b=f,f=A+B>>>0}a=a+f>>>0,u=u+b>>>0,c=c+_>>>0,d=d+k>>>0,m=m+O>>>0,p=p+T>>>0,h=h+R>>>0,l=l+S>>>0}let w=g=>g.toString(16).padStart(8,"0");return w(a)+w(u)+w(c)+w(d)+w(m)+w(p)+w(h)+w(l)}function ft(n){let e=lt(n??null),t=JSON.stringify(e);return Bn(t).slice(0,16)}function zn(){let n=globalThis.crypto;if(n?.randomUUID)return n.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 pt(n,e,t){let r=t?.id??zn();if(n===0)return{id:r,version:0};let o=(t?.hash??ft)(e);return{id:r,version:0,cid:o,prev:null}}function Pt(n,e,t){n.version+=1,"cid"in n&&(n.prev=n.cid,n.cid=t(e))}var Ln,Vn,It=$(()=>{"use strict";Ln=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]),Vn=new TextEncoder});function Vt(n){return{node:n,unsub:null,prevData:void 0,dirty:!1,involvedThisWave:!1,dataBatch:[],terminal:void 0}}function ht(n){n.prevData=void 0,n.dirty=!1,n.involvedThisWave=!1,n.dataBatch.length=0,n.terminal=void 0}function He(n){return n.length===0?n:typeof n[0]=="symbol"?[n]:n}function fe(n,e,t){let r=Bt(n)?n:[],s=typeof n=="function"?n:typeof e=="function"?e:void 0,o={};return Bt(n)?o=(gt(e)?e:t)??{}:gt(n)?o=n:o=(gt(e)?e:t)??{},new I(r,s,o)}var jt,Lt,Hn,Wn,ke,I,Bt,gt,Ne=$(()=>{"use strict";st();ot();Le();Be();Gt();Ce();we();It();jt=()=>{},Lt=100;Hn=(n,e,t,r)=>{t.direction==="down-in"&&n._onDepMessage(t.depIndex,e)},Wn=(n,e,t,r)=>{let s=n;if(s._status==="completed"||s._status==="errored")return;let o=s._cached,i=o===void 0?[at]:[at,[F,o]];s._status==="dirty"&&i.push(_e),je(e,i,s._config.tierOf)},ke=new ze({onMessage:Hn,onSubscribe:Wn});Mt(ke);Rt(ke);I=class n{_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,r){this._config=r.config??ke,this._config.onMessage,this._optsName=r.name,this._describeKind=r.describeKind,this._equals=r.equals??Object.is,this._resubscribable=r.resubscribable??!1,this._resetOnTeardown=r.resetOnTeardown??!1,this._autoComplete=r.completeWhenDepsComplete??!0,this._autoError=r.errorWhenDepsError??!0,this._pausable=r.pausable??!0,this._guard=r.guard,this._fn=t,this._partial=r.partial??!1,this._cached=r.initial!==void 0?r.initial:void 0,this._status=e.length===0&&t==null&&this._cached!==void 0?"settled":"sentinel",this._hashFn=r.versioningHash??this._config.defaultHashFn??ft;let s=r.versioning??this._config.defaultVersioning;this._versioningLevel=s,this._versioning=s!=null?pt(s,this._cached===void 0?void 0:this._cached,{id:r.versioningId,hash:this._hashFn}):void 0,this._deps=e.map(Vt);let o={};for(let[a,u]of Object.entries(r.meta??{})){let c={initial:u,name:`${r.name??"node"}:meta:${a}`,describeKind:"state",config:this._config};r.guard!=null&&(c.guard=r.guard),o[a]=new n([],void 0,c)}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(He(a))},up(a){i._emitUp(He(a))}},this.down=this.down.bind(this),this.up=this.up.bind(this)}get _isTerminal(){return this._status==="completed"||this._status==="errored"}get name(){return this._optsName}get status(){return this._status}get cache(){return this._cached===void 0?void 0:this._cached}get lastMutation(){return this._lastMutation}get v(){return this._versioning}hasGuard(){return this._guard!=null}_applyVersioning(e,t){if(this._isExecutingFn)throw new Error(`Node "${this.name}": _applyVersioning cannot run mid-fn \u2014 call it outside of \`_execFn\` (typically at graph setup time before the first subscribe).`);let r=this._versioningLevel;if(r!=null&&e<=r)return;let s=t?.hash??this._hashFn;s!==this._hashFn&&(this._hashFn=s);let o=this._cached===void 0?void 0:this._cached,i=this._versioning,a=i?.id??t?.id,u=i?.version??0,c=pt(e,o,{id:a,hash:s});c.version=u,this._versioning=c,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=Fe(e);if(this._guard!=null&&!this._guard(t,"observe"))return!1;if(this._extraGuards!=null){for(let r of this._extraGuards)if(!r(t,"observe"))return!1}return!0}_checkGuard(e){if(e?.internal)return;let t=this._guard!=null||this._extraGuards!=null,r=e?.actor!=null;if(!t&&!r)return;let s=Fe(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:Ve()}}down(e,t){let r=He(e);r.length!==0&&(this._checkGuard(t),this._emit(r))}emit(e,t){this._checkGuard(t),this._emit([[F,e]])}up(e,t){if(this._deps.length===0)return;let r=He(e);if(r.length===0)return;this._checkGuard(t);let s=t??{internal:!0};this._validateUpTiers(r);for(let o of this._deps)o.node.up?.(r,s)}_emitUp(e){if(this._deps.length!==0&&e.length!==0){this._validateUpTiers(e);for(let t of this._deps)t.node.up?.(e,{internal:!0})}}_validateUpTiers(e){let t=this._config.tierOf;for(let r of e){let s=t(r[0]);if(s===3||s===4)throw new Error(`Node "${this.name}": tier-${s} messages cannot flow up \u2014 DATA/RESOLVED/COMPLETE/ERROR are downstream-only. Use \`down(...)\` for value delivery; \`up(...)\` is for control signals (DIRTY, INVALIDATE, PAUSE, RESUME, TEARDOWN).`)}}subscribe(e,t){if(t!=null&&this._guard!=null){let u=Fe(t);if(!this._guard(u,"observe"))throw new Z({actor:u,action:"observe",nodeName:this.name})}let s=this._isTerminal&&this._resubscribable;if(s){this._cached=void 0,this._status="sentinel",this._store={},this._hasCalledFnOnce=!1,this._waveHasNewData=!1,this._hasNewTerminal=!1,this._paused=!1,this._pendingWave=!1,this._pendingRerun=!1,this._isExecutingFn=!1,this._rerunDepth=0,this._dirtyDepCount=0,this._pauseLocks=null,this._pauseBuffer=null;for(let u of this._deps)ht(u);if(this._partial===!1){for(let u of this._deps)if(u.prevData!==void 0||u.dataBatch.length!==0||u.terminal!==void 0||u.dirty)throw new Error(`resubscribable-reset invariant: DepRecord not fully reset for node ${this._optsName??"(anonymous)"}`)}}this._sinkCount+=1;let o;try{o=this._config.onSubscribe(this,e,{sinkCount:this._sinkCount,afterTerminalReset:s},this._actions)}catch(u){throw this._sinkCount-=1,u}this._sinks==null?this._sinks=e:typeof this._sinks=="function"?this._sinks=new Set([this._sinks,e]):this._sinks.add(e);let i=this._isTerminal;if(this._sinkCount===1&&!i)try{this._activate()}catch(u){if(this._sinkCount-=1,this._removeSink(e),this._sinkCount===0&&(this._status="sentinel"),typeof o=="function")try{o()}catch{}throw u}this._status==="sentinel"&&this._cached===void 0&&(this._status="pending");let a=!1;return()=>{a||(a=!0,this._sinkCount-=1,this._removeSink(e),typeof o=="function"&&o(),this._sinks==null&&this._deactivate())}}_removeSink(e){if(this._sinks===e)this._sinks=null;else if(this._sinks!=null&&typeof this._sinks!="function")if(this._sinks.delete(e),this._sinks.size===1){let[t]=this._sinks;this._sinks=t}else this._sinks.size===0&&(this._sinks=null)}_activate(){if(this._deps.length===0){this._fn&&this._execFn();return}this._dirtyDepCount=0;let e=this._deps.length,t=0;try{for(let r=0;r<e;r++){let s=r,o=this._deps[r];o.unsub=jt,o.unsub=o.node.subscribe(i=>{if(o.unsub===null)return;let a=this._config.tierOf,u=!1;for(let c of i)a(c[0])>=3&&(u=!0),this._config.onMessage(this,c,{direction:"down-in",depIndex:s},this._actions);u&&this._maybeRunFnOnSettlement()}),t++}}catch(r){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{}ht(o)}}throw this._dirtyDepCount=0,r}}_addDep(e){for(let s=0;s<this._deps.length;s++)if(this._deps[s].node===e)return s;let t=this._deps.length,r=Vt(e);if(this._deps.push(r),this._sinks==null)return t;r.dirty=!0,this._dirtyDepCount++,this._status!=="dirty"&&this._emit(ct),r.unsub=jt;try{r.unsub=e.subscribe(s=>{if(r.unsub===null)return;let o=this._config.tierOf,i=!1;for(let a of s)o(a[0])>=3&&(i=!0),this._config.onMessage(this,a,{direction:"down-in",depIndex:t},this._actions);i&&this._maybeRunFnOnSettlement()})}catch(s){throw r.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(r){this._emit([[C,this._wrapFnError("cleanup threw",r)]])}else if(t!=null&&typeof t=="object"){let r=t.deactivate;if(typeof r=="function")try{r()}catch(s){this._emit([[C,this._wrapFnError("cleanup.deactivate threw",s)]])}}for(let r of this._deps){if(r.unsub!=null){let s=r.unsub;r.unsub=null;try{s()}catch{}}ht(r)}this._waveHasNewData=!1,this._hasNewTerminal=!1,this._hasCalledFnOnce=!1,this._paused=!1,this._pendingWave=!1,this._pendingRerun=!1,this._rerunDepth=0,this._store={},this._dirtyDepCount=0,this._pauseLocks=null,this._pauseBuffer=null,this._fn!=null&&(this._cached=void 0),e||(this._fn!=null||this._deps.length>0)&&(!this._isTerminal||this._resubscribable)&&(this._status="sentinel")}_onDepMessage(e,t){let r=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!==De){if(s===X){this._depDirtied(r);return}if(s===te){if(this._depInvalidated(r),this._cached===void 0)return;this._emit(Dt);return}if(s===re||s===ie){this._emit([t]);return}if(s===V){this._emit(ut);return}if(s===F)this._depSettledAsData(r,t[1]);else if(s===ne)this._depSettledAsResolved(r);else if(s===z)this._depSettledAsTerminal(r,!0);else if(s===C)this._depSettledAsTerminal(r,t[1]);else{this._emit([t]);return}if(!this._fn){(s===F||s===ne)&&this._emit([t]),(s===z||s===C)&&this._maybeAutoTerminalAfterWave();return}}}_depDirtied(e){e.dirty||(e.dirty=!0,e.involvedThisWave=!0,this._dirtyDepCount++,this._status!=="dirty"&&this._emit(ct))}_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(At),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([[C,e.terminal]]);return}this._autoComplete&&this._deps.every(t=>t.terminal!==void 0)&&this._emit(Ct)}_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([[C,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([[C,this._wrapFnError("cleanup.beforeRun threw",a)]]);return}}}let t=this._deps.map(i=>i.involvedThisWave?i.dataBatch.length>0?[...i.dataBatch]:[]:void 0),r=this._deps.map(i=>i.prevData);for(let i=0;i<this._deps.length;i++){let a=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:r,terminalDeps:s,store:this._store};if(this._hasCalledFnOnce=!0,this._clearWaveFlags(),this._inspectorHooks!=null){let i={kind:"run",batchData:t,prevData:r};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([[C,this._wrapFnError("fn threw",i)]])}finally{this._isExecutingFn=!1,this._pendingRerun?(this._pendingRerun=!1,this._rerunDepth+=1,this._rerunDepth>Lt?(this._rerunDepth=0,this._emit([[C,new Error(`Node "${this.name}": _pendingRerun depth exceeded ${Lt} \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 r=t instanceof Error?t.message:String(t);return new Error(`Node "${this.name}": ${e}: ${r}`,{cause:t})}_frameBatch(e){let t=this._config.tierOf;if(e.length===1)return t(e[0][0])===3&&this._status!=="dirty"?[_e,e[0]]:e;let r=!0,s=!1,o=!1,i=-1;for(let u of e){let c=t(u[0]);c<i&&(r=!1),c===3&&(s=!0),u[0]===X&&(o=!0),i=c}let a=e;if(!r){let u=e.map((c,d)=>({m:c,i:d,tier:t(c[0])}));u.sort((c,d)=>c.tier-d.tier||c.i-d.i),a=u.map(c=>c.m)}if(s&&!o&&this._status!=="dirty"){let u=0;for(;u<a.length&&t(a[u][0])===0;)u++;return u===0?[_e,...a]:[...a.slice(0,u),_e,...a.slice(u)]}return a}_emit(e){if(e.length===0)return;for(let a=0;a<e.length;a++){let u=e[a];if(u[0]===C&&u[1]===void 0)throw new TypeError('[ERROR, payload] requires a non-undefined payload (spec \xA71.2). Pass an Error object or domain tag instead \u2014 e.g. node.down([[ERROR, new Error("reason")]])')}let t=e;if(this._isTerminal&&!this._resubscribable){let a=e.filter(u=>u[0]===V||u[0]===te);if(a.length===0)return;t=a}t=this._frameBatch(t);let s=null;for(let a=0;a<t.length;a++){let u=t[a],c=u[0];if(c!==re&&c!==ie){s?.push(u);continue}if(u.length<2)throw new Error(`Node "${this.name}": [[${c===re?"PAUSE":"RESUME"}]] must carry a lockId payload \u2014 bare PAUSE/RESUME is a protocol violation (C0 rule). Use \`[[PAUSE, lockId]]\` / \`[[RESUME, lockId]]\`.`);let d=!0;if(this._pausable!==!1){let m=u[1];if(c===re)this._pauseLocks==null&&(this._pauseLocks=new Set),this._pauseLocks.add(m),this._paused=!0,this._pausable==="resumeAll"&&this._pauseBuffer==null&&(this._pauseBuffer=[]);else if(this._pauseLocks==null||!this._pauseLocks.has(m))d=!1;else if(this._pauseLocks.delete(m),this._pauseLocks.size===0){if(this._paused=!1,this._pauseBuffer!=null&&this._pauseBuffer.length>0){let p=this._pauseBuffer;this._pauseBuffer=[],this._emit(p)}this._pendingWave&&(this._pendingWave=!1,this._maybeRunFnOnSettlement())}}d?s?.push(u):s==null&&(s=t.slice(0,a))}if(s!=null){if(s.length===0)return;t=s}if(this._hasMeta&&t.some(a=>a[0]===V))for(let a of Object.keys(this.meta))try{this.meta[a]._emit(ut)}catch{}let{finalMessages:o,equalsError:i}=this._updateState(t);if(o.length>0&&this._config.inspectorEnabled){let a=this._config.globalInspector;if(a!=null)try{a({kind:"emit",node:this,messages:o})}catch{}}if(o.length>0)if(this._paused&&this._pausable==="resumeAll"&&this._pauseBuffer!=null){let a=this._config.tierOf,u=[];for(let c of o)a(c[0])===3?this._pauseBuffer.push(c):u.push(c);u.length>0&&this._dispatchOrAccumulate(u)}else this._dispatchOrAccumulate(o);i!=null&&this._emit([[C,i]])}_updateState(e){let t=this._config.tierOf,r,s,o=-1,i=0;for(let d of e)t(d[0])===3&&i++;let a=i<=1,u=-1;if(this._versioning!=null&&i>1){for(let d=e.length-1;d>=0;d--)if(e[d][0]===F){u=d;break}}for(let d=0;d<e.length;d++){let m=e[d],p=m[0];if(p===F){if(m.length>=2){let h=!1;if(a&&this._cached!==void 0)try{h=this._equals(this._cached,m[1])}catch(l){s=this._wrapFnError("equals threw",l),o=d;break}if(h){r==null&&(r=e.slice(0,d)),r.push(it),this._status="resolved";continue}this._cached=m[1],this._versioning!=null&&(u<0||d===u)&&Pt(this._versioning,m[1],this._hashFn)}this._status="settled",r?.push(m)}else if(r?.push(m),p===X)this._status="dirty";else if(p===ne)this._status="resolved";else if(p===z){this._status="completed";{let h=this._config.rigorRecorder;if(h!=null)try{h.onTerminalTransition(this,"completed",this._autoComplete,this._autoError,this._deps.length>0)}catch{}}}else if(p===C){this._status="errored";{let h=this._config.rigorRecorder;if(h!=null)try{h.onTerminalTransition(this,"errored",this._autoComplete,this._autoError,this._deps.length>0)}catch{}}}else if(p===te){if(this._cached!==void 0){let l=this._config.rigorRecorder;if(l!=null)try{l.onNonVacuousInvalidate(this,this._cached)}catch{}}this._cached=void 0,this._status="dirty";let h=this._cleanup;if(typeof h=="function"){this._cleanup=void 0;try{h()}catch{}}else if(h!=null&&typeof h=="object"){let l=h.invalidate;if(typeof l=="function")try{l()}catch{}}}else p===V&&(this._resetOnTeardown&&(this._cached=void 0),this._deactivate(!0),this._status="sentinel")}let c=o>=0?r??e.slice(0,o):r??e;return s!=null?{finalMessages:c,equalsError:s}:{finalMessages:c}}_deliverToSinks=e=>{if(this._sinks==null)return;if(typeof this._sinks=="function"){this._sinks(e);return}let t=[...this._sinks];for(let r of t)r(e)};_dispatchOrAccumulate(e){if(Et()){this._batchPendingMessages===null&&(this._batchPendingMessages=[],ve(()=>this._flushBatchPending()));for(let t of e)this._batchPendingMessages.push(t);return}je(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);je(this._deliverToSinks,t,this._config.tierOf)}},Bt=n=>Array.isArray(n),gt=n=>typeof n=="object"&&n!=null&&!Array.isArray(n)});function se(n,e){return fe([],{...e,initial:n})}function Oe(n,e){return fe((r,s,o)=>n(s,o)??void 0,{describeKind:"producer",...e})}function pe(n,e,t){return fe(n,(s,o,i)=>{let a=s.map((u,c)=>u!=null&&u.length>0?u.at(-1):i.prevData[c]);o.emit(e(a,i))},{describeKind:"derived",...t})}function We(n,e,t){return fe(n,(s,o,i)=>{let a=s.map((u,c)=>u!=null&&u.length>0?u.at(-1):i.prevData[c]);return e(a,o,i)??void 0},{describeKind:"effect",...t})}var Ue=$(()=>{"use strict";Ne()});function mt(n,e){if(e!=null&&e.length>0)return new Set(e);switch(n){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 Un(n){return n._describeKind!=null?n._describeKind:n._deps.length>0?"derived":n._fn!=null?"producer":"state"}function qn(n){let e={};for(let[t,r]of Object.entries(n.meta))try{e[t]=r.cache}catch{}return e}function bt(n,e,t){let r=e==null,s=!r&&e!=null?[...e].filter(d=>d.startsWith("meta.")).map(d=>d.slice(5)):null,o=r||e.has("meta")||s!=null&&s.length>0,i="state",a=[];n instanceof I&&(i=Un(n),a=n._deps.map(d=>d.node.name??""));let u={type:i,deps:a};(r||e.has("status"))&&(u.status=n.status);let c=n instanceof I?n._guard:void 0;if(o){let d={...qn(n)};if(c!=null&&d.access===void 0&&(d.access=dt(c)),s!=null&&s.length>0&&!e.has("meta")){let m={};for(let p of s)p in d&&(m[p]=d[p]);u.meta=m}else u.meta=d}if(n.name!=null&&(u.name=n.name),(r||e.has("value"))&&(!t||i==="state")){n.status==="sentinel"&&(u.sentinel=!0);try{u.value=n.cache}catch{}}if((r||e.has("v"))&&n.v!=null){let d={id:n.v.id,version:n.v.version};"cid"in n.v&&(d.cid=n.v.cid,d.prev=n.v.prev),u.v=d}return(r||e.has("guard"))&&c!=null&&(u.guard=dt(c)),(r||e.has("lastMutation"))&&n.lastMutation!=null&&(u.lastMutation=n.lastMutation),u}var zt=$(()=>{"use strict";Ce();Ne()});function yt(n,e){if(Object.is(n,e))return!0;if(n==null||e==null||typeof n!="object"||typeof e!="object")return!1;if(Array.isArray(n)){if(!Array.isArray(e)||n.length!==e.length)return!1;for(let o=0;o<n.length;o++)if(!yt(n[o],e[o]))return!1;return!0}if(Array.isArray(e))return!1;let t=Object.keys(n),r=Object.keys(e);if(t.length!==r.length)return!1;let s=new Set(r);for(let o of t)if(!s.has(o)||!yt(n[o],e[o]))return!1;return!0}function Ht(n,e){return`${n}\0${e}`}function vt(n,e){let t=[],r=new Set(n.subgraphs),s=new Set(e.subgraphs),o=[];for(let y of s)r.has(y)||o.push(y);o.sort();for(let y of o)t.push({type:"subgraph-mounted",path:y});let i=new Set(Object.keys(n.nodes)),a=new Set(Object.keys(e.nodes)),u=[];for(let y of a)i.has(y)||u.push(y);u.sort();for(let y of u)t.push({type:"node-added",path:y,node:{...e.nodes[y]}});let c=[];for(let y of a){if(!i.has(y))continue;let w=n.nodes[y]?.meta,g=e.nodes[y]?.meta;w==null&&g==null||yt(w??{},g??{})||c.push(y)}c.sort();for(let y of c)t.push({type:"node-meta-changed",path:y,prevMeta:n.nodes[y]?.meta??{},nextMeta:e.nodes[y]?.meta??{}});let d=new Map;for(let y of n.edges)d.set(Ht(y.from,y.to),y);let m=new Map;for(let y of e.edges)m.set(Ht(y.from,y.to),y);let p=[];for(let[y,w]of m)d.has(y)||p.push(w);p.sort((y,w)=>y.from<w.from?-1:y.from>w.from?1:y.to<w.to?-1:y.to>w.to?1:0);for(let y of p)t.push({type:"edge-added",from:y.from,to:y.to});let h=[];for(let[y,w]of d)m.has(y)||h.push(w);h.sort((y,w)=>y.from<w.from?-1:y.from>w.from?1:y.to<w.to?-1:y.to>w.to?1:0);for(let y of h)t.push({type:"edge-removed",from:y.from,to:y.to});let l=[];for(let y of i)a.has(y)||l.push(y);l.sort();for(let y of l)t.push({type:"node-removed",path:y});let v=[];for(let y of r)s.has(y)||v.push(y);v.sort();for(let y of v)t.push({type:"subgraph-unmounted",path:y});return{events:t,flushedAt_ns:oe()}}var Wt=$(()=>{"use strict";Be()});function Te(n){return n.subscribe(()=>{})}var Ut=$(()=>{"use strict"});var _t=$(()=>{"use strict";Ut()});var qe,qt=$(()=>{"use strict";qe=class{_timer;_gen=0;start(e,t){this.cancel(),this._gen+=1;let r=this._gen;this._timer=setTimeout(()=>{this._timer=void 0,r===this._gen&&t()},e)}cancel(){this._timer!==void 0&&(clearTimeout(this._timer),this._timer=void 0)}get pending(){return this._timer!==void 0}}});var Me,Kt=$(()=>{"use strict";Me=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}}});function Jt(n,e,t,r={}){let s=e in n.nodes,o=t in n.nodes;if(!s)return Ke(e,t,"no-such-from");if(!o)return Ke(e,t,"no-such-to");let i=r.maxDepth;if(i!=null&&(!Number.isInteger(i)||i<0))throw new Error("explainPath: maxDepth must be an integer >= 0");if(e===t){if(r.findCycle===!0){let c=Kn(n,e,r);if(c!=null)return c}let u=Je(e,n.nodes[e],0,r);return Ye(e,t,[u])}if(i===0)return Ke(e,t,"no-path");let a=Yt(n,e,t,i);return a.found?Ye(e,t,Xt(n,a.pathOrder,r)):Ke(e,t,a.truncated?"max-depth-exceeded":"no-path")}function Yt(n,e,t,r){let s=new Map,o=[{path:t,depth:0}],i=new Set([t]),a=0,u=!1;for(;a<o.length;){let m=o[a++];if(m.path===e)break;if(r!=null&&m.depth>=r){let v=n.nodes[m.path];v?.deps&&v.deps.length>0&&(u=!0);continue}let p=n.nodes[m.path];if(p==null)continue;let h=p.deps??[],l=new Map;for(let v=0;v<h.length;v++){let y=h[v];if(!y)continue;let w=l.get(y);w==null&&(w=[],l.set(y,w)),w.push(v)}for(let[v,y]of l)i.has(v)||(i.add(v),s.set(v,{from:m.path,depIndices:y}),o.push({path:v,depth:m.depth+1}))}if(!s.has(e))return{found:!1,pathOrder:[],truncated:u};let c=[{path:e}],d=e;for(;d!==t;){let m=s.get(d);if(m==null)return{found:!1,pathOrder:[],truncated:!1};c[c.length-1].depIndices=m.depIndices,c.push({path:m.from}),d=m.from}return{found:!0,pathOrder:c,truncated:!1}}function Kn(n,e,t){let r=n.nodes[e];if(r==null)return null;let s=r.deps??[],o=[];for(let a=0;a<s.length;a++)s[a]===e&&o.push(a);if(o.length>0){let a=Je(e,r,0,t);a.dep_index=o[0];let u=Je(e,r,1,t);return Ye(e,e,[a,u])}let i=null;for(let a=0;a<s.length;a++){let u=s[a];if(!u||u===e)continue;let c=Yt(n,u,e,t.maxDepth);c.found&&(i==null||c.pathOrder.length<i.pathOrder.length)&&(i=c,i={found:!0,pathOrder:[{path:e,depIndices:[a]},...c.pathOrder],truncated:!1})}return i==null?null:Ye(e,e,Xt(n,i.pathOrder,t))}function Xt(n,e,t){return e.map((r,s)=>{let o=n.nodes[r.path],i=Je(r.path,o,s,t);return r.depIndices!=null&&r.depIndices.length>0&&(i.dep_index=r.depIndices[0],r.depIndices.length>1&&(i.dep_indices=[...r.depIndices])),i})}function Je(n,e,t,r){let s={path:n,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=r.annotations?.get(n)??e.annotation;o!=null&&(s.annotation=o);let i=r.lastMutations?.get(n)??e.lastMutation;return i!=null&&(s.lastMutation=i),s}function Ye(n,e,t){return Zt(n,e,!0,"ok",t)}function Ke(n,e,t){return Zt(n,e,!1,t,[])}function Zt(n,e,t,r,s){let o=Jn(n,e,t,r,s);return{from:n,to:e,found:t,reason:r,steps:s,text:o,toJSON(){return{from:n,to:e,found:t,reason:r,steps:s}}}}function Jn(n,e,t,r,s){if(!t)switch(r){case"no-such-from":return`explainPath: no node named "${n}"`;case"no-such-to":return`explainPath: no node named "${e}"`;case"max-depth-exceeded":return`explainPath: no path from "${n}" to "${e}" within maxDepth`;default:return`explainPath: no path from "${n}" to "${e}"`}let o=[`Causal path: ${n} \u2192 ${e} (${s.length} step(s))`];for(let i of s){let u=` ${i.hop===0?"\xB7":"\u2193"} ${i.path} (${i.type}${i.status?`/${i.status}`:""})`;if(o.push(u),"value"in i&&o.push(` value: ${Yn(i.value)}`),i.annotation!=null&&o.push(` annotation: ${i.annotation}`),i.lastMutation!=null){let c=i.lastMutation.actor;o.push(` actor: ${c.type}${c.id?`:${c.id}`:""}`)}}return o.join(`
2
- `)}function Yn(n){if(n===void 0)return"<sentinel>";if(n===null)return"null";if(typeof n=="string")return JSON.stringify(n);if(typeof n=="number"||typeof n=="boolean"||typeof n=="bigint")return String(n);try{let e=JSON.stringify(n);return e.length>80?`${e.slice(0,77)}...`:e}catch{return String(n)}}var Qt=$(()=>{"use strict"});function en(n){let e=new WeakSet,t=new WeakSet,r=[n],s=0;for(;r.length>0;){let o=r.pop();s+=Zn(o,e,t,r)}return s}function Zn(n,e,t,r){if(n==null)return 0;switch(typeof n){case"number":return j.number;case"boolean":return j.boolean;case"string":return j.string+n.length*2;case"bigint":return j.bigint+Qn(n);case"symbol":return j.symbol;case"function":return e.has(n)?0:(e.add(n),j.function);case"undefined":return 0}let o=n;if(e.has(o))return 0;e.add(o);let i=o[Xn];if(typeof i=="function")try{let c=i.call(o);if(typeof c=="number"&&Number.isFinite(c))return c}catch{}if(o instanceof Date)return j.date;if(o instanceof RegExp)return j.regexp+o.source.length*2;if(o instanceof Error){let c=o.message?o.message.length*2:0,d=o.stack?o.stack.length*2:0;return j.error+c+d}if(typeof URL<"u"&&o instanceof URL)return j.url+o.href.length*2;if(typeof Promise<"u"&&o instanceof Promise)return j.promise;if(o instanceof WeakMap)return j.weakmap;if(o instanceof WeakSet)return j.weakset;if(o instanceof Map){let c=j.map;for(let[d,m]of o)c+=j.mapEntry,r.push(d),r.push(m);return c}if(o instanceof Set){let c=j.set;for(let d of o)c+=j.setEntry,r.push(d);return c}if(Array.isArray(o)){let c=j.array+o.length*8;for(let d of o)r.push(d);return c}if(o instanceof ArrayBuffer)return t.has(o)?0:(t.add(o),o.byteLength);if(ArrayBuffer.isView(o)){let c=o;return t.has(c.buffer)?48:(t.add(c.buffer),c.buffer.byteLength+48)}let a=j.object,u=Object.keys(o);for(let c of u){a+=j.string+c.length*2;try{r.push(o[c])}catch{}}return a}function Qn(n){let e=n<0n?-n:n;if(e===0n)return 0;let t=e.toString(2).length;return Math.ceil(t/32)*8}var j,Xn,tn=$(()=>{"use strict";j={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},Xn=Symbol.for("sizeof")});function nn(n,e){let t=e?.topN??10,r=n.describe({detail:"standard"}),s=[],o=n._collectObserveTargets;typeof o=="function"&&o.call(n,"",s);let i=new Map;for(let[p,h]of s)i.set(p,h);let a=[];for(let[p,h]of Object.entries(r.nodes)){let l=i.get(p),v=l instanceof I?l:null,y=v?en(v.cache):0,w=v?v._sinkCount:0,g=h.deps?.length??0,f=h.type==="effect"&&w===0,b=w===0?h.type==="effect"?"orphan-effect":h.type==="derived"?"idle-derived":h.type==="producer"?"idle-producer":null:null;a.push({path:p,type:h.type,status:h.status??"unknown",valueSizeBytes:y,subscriberCount:w,depCount:g,isOrphanEffect:f,orphanKind:b})}let u=a.reduce((p,h)=>p+h.valueSizeBytes,0),c=(p,h)=>[...a].sort(h??((l,v)=>v[p]-l[p])).slice(0,t),d=a.filter(p=>p.orphanKind!=null),m=a.filter(p=>p.isOrphanEffect);return{nodeCount:a.length,edgeCount:r.edges.length,subgraphCount:r.subgraphs.length,nodes:a,totalValueSizeBytes:u,hotspots:{byValueSize:c("valueSizeBytes"),bySubscriberCount:c("subscriberCount"),byDepCount:c("depCount")},orphans:d,orphanEffects:m}}var rn=$(()=>{"use strict";Ne();tn()});function sn(n,e){let t=Math.max(16,n.size*4),r=0;for(;n.size>0;){if(r++>=t){console.error(`[Graph "${e}".destroy] disposer drain exceeded cap (${t}); ${n.size} disposer(s) discarded`),n.clear();return}let s=n.values().next();if(s.done)return;let o=s.value;n.delete(o);try{o()}catch(i){console.error(`[Graph "${e}".destroy] disposer threw:`,i)}}}function ln(n){return n!=null&&typeof n=="object"&&"cache"in n&&typeof n.subscribe=="function"&&typeof n.down=="function"}function er(n){if(n!=null)return ln(n)?n.cache:n}function he(n){return n!=null&&typeof n=="object"&&"cache"in n&&typeof n.subscribe=="function"&&typeof n.down=="function"}function ae(n){return he(n)?n.cache??"":n}function on(n){return he(n)?n.cache??0:n}function an(n){return he(n)?n.cache??!1:n}function tr(n){let e=[];for(let t of Object.keys(n).sort()){let r=n[t].v;r!=null&&e.push(`${t} ${r.id} ${r.version}`)}return e.join(`
3
- `)}function cn(n){if(n.version!==xe)throw new Error(`unsupported snapshot version ${String(n.version)} (expected ${xe})`);for(let e of["name","nodes","edges","subgraphs"])if(!(e in n))throw new Error(`snapshot missing required key "${e}"`);if(typeof n.name!="string")throw new TypeError("snapshot 'name' must be a string");if(typeof n.nodes!="object"||n.nodes===null||Array.isArray(n.nodes))throw new TypeError("snapshot 'nodes' must be an object");if(!Array.isArray(n.edges))throw new TypeError("snapshot 'edges' must be an array");if(!Array.isArray(n.subgraphs))throw new TypeError("snapshot 'subgraphs' must be an array")}function nr(n,e){let t=new WeakMap,r=(s,o)=>{if(Object.is(s,o))return!0;if(s==null||o==null||typeof s!="object"||typeof o!="object")return!1;let i=t.get(s);if(i==null&&(i=new WeakSet,t.set(s,i)),i.has(o))return!0;i.add(o);let a=s.constructor,u=o.constructor;if(a!==u)return!1;if(s instanceof Date)return s.getTime()===o.getTime();if(s instanceof RegExp)return s.source===o.source&&s.flags===o.flags;if(Array.isArray(s)){let p=o;if(s.length!==p.length)return!1;for(let h=0;h<s.length;h++)if(!r(s[h],p[h]))return!1;return!0}if(s instanceof Map){let p=o;if(s.size!==p.size)return!1;for(let[h,l]of s)if(!p.has(h)||!r(l,p.get(h)))return!1;return!0}if(s instanceof Set){let p=o;if(s.size!==p.size)return!1;for(let h of s){let l=!1;for(let v of p)if(r(h,v)){l=!0;break}if(!l)return!1}return!0}if(ArrayBuffer.isView(s)){let p=s,h=o;if(p.length!==h.length)return!1;for(let l=0;l<p.length;l++)if(p[l]!==h[l])return!1;return!0}let c=Object.keys(s),d=Object.keys(o);if(c.length!==d.length)return!1;let m=new Set(d);for(let p of c)if(!m.has(p)||!r(s[p],o[p]))return!1;return!0};return r(n,e)}function rr(n){return n.replace(/[.*+?^${}()|[\]\\]/g,"\\$&")}function Xe(n){let e="^";for(let t=0;t<n.length;t+=1){let r=n[t];if(r==="*"){e+=".*";continue}if(r==="?"){e+=".";continue}if(r==="["){let s=n.indexOf("]",t+1);if(s<=t+1){e+="\\[";continue}let o=n.slice(t+1,s);o.startsWith("!")&&(o=`^${o.slice(1)}`),o=o.replace(/\\/g,"\\\\"),e+=`[${o}]`,t=s;continue}e+=rr(r)}return e+="$",new RegExp(e)}function wt(n){if(typeof n=="string")return JSON.stringify(n);if(typeof n=="number"||typeof n=="boolean"||n==null)return String(n);try{return JSON.stringify(n)}catch{return"[unserializable]"}}function ir(n){return n==="none"?or:n==="ansi"||n==null?sr:{data:n.data??"",dirty:n.dirty??"",resolved:n.resolved??"",invalidate:n.invalidate??"",pause:n.pause??"",resume:n.resume??"",complete:n.complete??"",error:n.error??"",teardown:n.teardown??"",derived:n.derived??"",path:n.path??"",reset:n.reset??""}}function un(n){if(n==null)return{};let e=n.detail;return e==="full"?{...n,structured:n.structured??!0,timeline:n.timeline??!0,causal:n.causal??!0,derived:n.derived??!0}:e==="minimal"?{...n,structured:n.structured??!0}:n.format==="stage-log"?{...n,structured:n.structured??!0,timeline:n.timeline??!0}:n}function ar(n,e,t){for(let r=0;r<n.length;r++){let s=n.charCodeAt(r);if(s<32||s===127)throw new Error(`Graph "${e}": ${t} "${n}" must not contain control character (U+${s.toString(16).padStart(4,"0").toUpperCase()} at index ${r})`)}}function kt(n,e,t){if(n==="")throw new Error(`Graph "${e}": ${t} name must be non-empty`);if(n.includes(G))throw new Error(`Graph "${e}": ${t} "${n}" must not contain '${G}' (path separator)`);if(n===U)throw new Error(`Graph "${e}": ${t} name "${U}" is reserved for meta companion paths`);ar(n,e,t)}function cr(n,e){if(n==="")throw new Error(`Graph "${e}": resolve path must be non-empty`);let t=n.split(G);for(let r of t)if(r==="")throw new Error(`Graph "${e}": resolve path has empty segment`);return t}function ur(n,e){let t=!1;for(let s of n)if(!e.isMetaPassthrough(s[0])){t=!0;break}return t?n.filter(s=>e.isMetaPassthrough(s[0])):n}function fn(n){for(let e of n._mounts.values())fn(e);for(let e of n._nodes.values())try{e.down([[V]],{internal:!0})}catch{}}function dr(n,e){let t=Se.diff(n,e),r={};for(let s of t.nodesAdded){let o=e.nodes[s];o!=null&&(r[s]=o)}return{...t,nodesAddedFull:r}}function dn(n,e,t,r={}){let s={paths:[],depths:new Map,truncated:!1};if(!e)return r.withDetail?s:[];if(!r.both&&t!=="upstream"&&t!=="downstream")throw new Error('reachable: direction must be "upstream" or "downstream"');let o=r.maxDepth;if(o!=null&&(!Number.isInteger(o)||o<0))throw new Error("reachable: maxDepth must be an integer >= 0");if(o===0)return r.withDetail?s:[];let i=new Map,a=new Map,u=new Map,c=new Map,d=new Set;for(let[f,b]of Object.entries(n.nodes)){if(!f)continue;d.add(f);let _=b.deps??[];i.set(f,_);for(let k of _)k&&(d.add(k),a.has(k)||a.set(k,new Set),a.get(k).add(f))}for(let f of n.edges){if(f==null||typeof f!="object")continue;let b=typeof f.from=="string"?f.from:"",_=typeof f.to=="string"?f.to:"";!b||!_||(d.add(b),d.add(_),c.has(b)||c.set(b,new Set),c.get(b).add(_),u.has(_)||u.set(_,new Set),u.get(_).add(b))}if(!d.has(e))return r.withDetail?s:[];let m=r.both===!0,p=f=>{if(m){let O=i.get(f)??[],T=u.get(f),R=a.get(f),S=c.get(f),N=[...O];return T&&N.push(...T),R&&N.push(...R),S&&N.push(...S),N}if(t==="upstream"){let O=i.get(f)??[],T=u.get(f);return T?[...O,...T]:O}let b=a.get(f),_=c.get(f),k=b?[...b]:[];return _&&k.push(..._),k},h=new Set([e]),l=new Map,v=[{path:e,depth:0}],y=0,w=!1;for(;y<v.length;){let f=v[y++];if(o!=null&&f.depth>=o){p(f.path).length>0&&(w=!0);continue}for(let b of p(f.path))!b||h.has(b)||(h.add(b),l.set(b,f.depth+1),v.push({path:b,depth:f.depth+1}))}let g=[...l.keys()].sort((f,b)=>f<b?-1:f>b?1:0);return r.withDetail?{paths:g,depths:l,truncated:w}:g}function lr(n,e){if(n.length!==e.length)return!1;for(let t=0;t<n.length;t++){let r=n[t],s=e[t];if(r.path!==s.path||r.type!==s.type||r.status!==s.status||r.hop!==s.hop||r.dep_index!==s.dep_index||r.annotation!==s.annotation||r.value!==s.value||r.lastMutation!==s.lastMutation)return!1;let o=r.v,i=s.v;if(o!==i&&(o==null||i==null||o.id!==i.id||o.version!==i.version))return!1}return!0}var G,U,xe,sr,or,Se,pn=$(()=>{"use strict";ot();Le();Be();Ce();we();zt();Ne();Ue();Wt();_t();qt();Kt();st();Qt();rn();G="::",U="__meta__",xe=1;sr={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"},or={data:"",dirty:"",resolved:"",invalidate:"",pause:"",resume:"",complete:"",error:"",teardown:"",derived:"",path:"",reset:""};Se=class n{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(G))throw new Error(`Graph name must not contain '${G}' (got "${e}")`);if(e===U)throw new Error(`Graph name "${U}" is reserved for meta companion paths`);this.name=e,this.opts=Object.freeze({...t??{}}),this.config=t?.config??ke,this._traceRing=new Me(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=[],r=e?this:this._parent;for(;r!=null;)t.push(r),r=r._parent;return t}get topology(){return this._topology==null&&(this._topology=Oe(e=>{let t=r=>{e.emit(r)};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 r=e.name,s=t?.name??r;if(s==null||s==="")throw new Error(`Graph "${this.name}": graph.add requires a non-empty name \u2014 pass via opts.name or set it on the node (e.g. state(0, { name: "x" }))`);let o=s,i=t?.annotation;if(kt(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:oe()})),e}setVersioning(e){if(e!=null)for(let t of this._nodes.values())t instanceof I&&t._applyVersioning(e)}remove(e){kt(e,this.name,"remove");let t=this._mounts.get(e);if(t){let o={kind:"mount",nodes:[],mounts:[]},i=[];t._collectObserveTargets("",i);for(let[a,u]of i)a.includes(`${G}${U}${G}`)||o.nodes.push(a);return o.nodes.sort(),o.mounts.push(e),o.mounts.push(...t._collectSubgraphs(`${e}${G}`)),this._mounts.delete(e),t._parent=void 0,fn(t),this._emitTopology({kind:"removed",name:e,nodeKind:"mount",audit:o}),o}let r=this._nodes.get(e);if(!r)throw new Error(`Graph "${this.name}": unknown node or mount "${e}"`);this._nodes.delete(e),this._nodeToName.delete(r),r.down([[V]],{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=Xe(e);return i=>o.test(i)})(),r={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);r.nodes.push(...i.nodes),r.mounts.push(...i.mounts)}return r.nodes.sort(),r.mounts.sort(),r}[Symbol.iterator](){let e=[...this._nodes.keys()].sort(),t=this._nodes,r=0;return{[Symbol.iterator](){return this},next(){if(r>=e.length)return{value:void 0,done:!0};let s=e[r++];return{value:[s,t.get(s)],done:!1}}}}node(e){if(e==="")throw new Error(`Graph "${this.name}": node name must be non-empty`);if(e.includes(G))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,r){let s=r?.internal===!0;this.node(e).down([[F,t]],{actor:r?.actor,internal:s,delivery:"write"})}setAll(e,t){let r=Symbol.iterator in e?e:Object.entries(e);Ie(()=>{for(let[s,o]of r)this.set(s,o,t)})}invalidate(e,t){let r=t?.internal===!0;this.node(e).down([[te]],{actor:t?.actor,internal:r,delivery:"write"})}error(e,t,r){let s=r?.internal===!0;this.node(e).down([[C,t]],{actor:r?.actor,internal:s,delivery:"write"})}complete(e,t){let r=t?.internal===!0;this.node(e).down([[z]],{actor:t?.actor,internal:r,delivery:"write"})}edges(e){let t=e?.recursive===!0,r=new Map;if(!t){for(let[u,c]of this._nodes)r.set(c,u);let a=[];for(let[u,c]of this._nodes)if(c instanceof I)for(let d of c._deps){let m=r.get(d.node);m!=null&&a.push([m,u])}return a.sort((u,c)=>u[0]<c[0]?-1:u[0]>c[0]?1:u[1]<c[1]?-1:u[1]>c[1]?1:0),a}let s=[];this._collectObserveTargets("",s);let o=new Map;for(let[a,u]of s)o.set(u,a);let i=[];for(let[a,u]of s)if(u instanceof I)for(let c of u._deps){let d=o.get(c.node);d!=null&&i.push([d,a])}return i.sort((a,u)=>a[0]<u[0]?-1:a[0]>u[0]?1:a[1]<u[1]?-1:a[1]>u[1]?1:0),i}mount(e,t){if(t===void 0){let s=new n(e);return this.mount(e,s)}if(typeof t=="function"){let s=new n(e);return t(s),this.mount(e,s)}let r=t;if(kt(e,this.name,"mount"),this._nodes.has(e))throw new Error(`Graph "${this.name}": cannot mount at "${e}" \u2014 node with that name exists`);if(this._mounts.has(e))throw new Error(`Graph "${this.name}": mount "${e}" already exists`);if(r===this)throw new Error(`Graph "${this.name}": cannot mount a graph into itself`);if(r._parent!=null)throw new Error(`Graph "${this.name}": this child graph is already mounted on "${r._parent.name}"`);for(let s=this;s!=null;s=s._parent)if(s===r)throw new Error(`Graph "${this.name}": mount("${e}", \u2026) would create a mount cycle`);return this._mounts.set(e,r),r._parent=this,this._emitTopology({kind:"added",name:e,nodeKind:"mount"}),r}resolve(e){let t=cr(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 r=t[0],s=t.slice(1);if(s.length===0){let a=this._nodes.get(r);if(a)return a;throw this._mounts.has(r)?new Error(`Graph "${this.name}": path ends at subgraph "${r}" \u2014 not a node (GRAPHREFLY-SPEC \xA73.5)`):new Error(`Graph "${this.name}": unknown name "${r}"`)}let o=this._nodes.get(r);if(o&&s.length>0&&s[0]===U)return this._resolveMetaChainFromNode(o,s,t.join(G));let i=this._mounts.get(r);if(!i)throw this._nodes.has(r)?new Error(`Graph "${this.name}": "${r}" is a node; trailing path "${s.join(G)}" is invalid`):new Error(`Graph "${this.name}": unknown mount or node "${r}"`);return i.resolve(s.join(G))}_resolveMetaChainFromNode(e,t,r){let s=e,o=0,i=[...t];for(;o<i.length;){if(i[o]!==U)throw new Error(`Graph "${this.name}": expected ${U} segment in meta path "${r}"`);if(o+1>=i.length)throw new Error(`Graph "${this.name}": meta path requires a key after ${U} in "${r}"`);let a=i[o+1],u=s.meta[a];if(!u)throw new Error(`Graph "${this.name}": unknown meta "${a}" in path "${r}"`);s=u,o+=2}return s}signal(e,t){if(t?.internal!==!0){for(let s of e)if(this.config.messageTier(s[0])===3)throw new Error(`Graph "${this.name}": Graph.signal() rejects tier-3 messages (DATA / RESOLVED). Broadcast is for control-plane tiers (START / DIRTY / INVALIDATE / PAUSE / RESUME / COMPLETE / ERROR / TEARDOWN). For per-node value writes, use Graph.set or graph.node(name).down(...).`)}let r=[];if(this._signalDeliver(e,t??{},new Set,r),r.length>0)throw r[0]}_signalDeliver(e,t,r,s){for(let u of this._mounts.values())u._signalDeliver(e,t,r,s);let i=t.internal===!0?{internal:!0}:{actor:t.actor,delivery:"signal"},a=ur(e,this.config);for(let u of[...this._nodes.keys()].sort()){let c=this._nodes.get(u);if(!r.has(c)){r.add(c);try{c.down(e,i)}catch(d){if(d instanceof Z)throw d;s.push(d)}a.length!==0&&this._signalMetaSubtree(c,a,r,i,s)}}}_signalMetaSubtree(e,t,r,s,o){for(let i of Object.keys(e.meta).sort()){let a=e.meta[i];if(!r.has(a)){r.add(a);try{a.down(t,s)}catch(u){if(u instanceof Z)throw u;o.push(u)}this._signalMetaSubtree(a,t,r,s,o)}}}describe(e){if(e?.reactive==="diff")return this._describeReactiveDiff(e);if(e?.reactive===!0)return this._describeReactive(e);let t=er(e?.actor),r=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=mt(e?.detail,e?.fields),o=e?.detail==="spec",i=s,a=[];this._collectObserveTargets("",a);let u=new Map;for(let[b,_]of a)u.set(_,b);let c=[];{let b=a.map(([,O])=>O),_=new Set(u.values()),k=0;for(;b.length>0;){let O=b.shift();if(O instanceof I)for(let T of O._deps){let R=T.node;if(u.has(R))continue;let S=R.name??"",N=S;if(!N||_.has(N))if(S){let P=2;for(;_.has(`${S}#${P}`);)P++;N=`${S}#${P}`}else for(N=`__internal__/${k++}`;_.has(N);)N=`__internal__/${k++}`;u.set(R,N),_.add(N),c.push([N,R]),b.push(R)}}}let d=[...a,...c],m={};for(let[b,_]of d){if(t!=null&&!_.allowsObserve(t))continue;let k=bt(_,i,o),O=_ instanceof I?_._deps.map(N=>u.get(N.node)??N.node.name??""):[],{name:T,...R}=k,S={...R,deps:O};if(!o){let N=this._annotations.get(b);N!=null&&(S.annotation=N)}if(r!=null)if(typeof r=="function"){let N=r;if(!(N.length>=2?N(b,S):N(S)))continue}else{let N=!0;for(let[P,E]of Object.entries(r)){let A=P==="deps_includes"?"depsIncludes":P==="meta_has"?"metaHas":P;if(A==="depsIncludes"){if(!S.deps.includes(String(E))){N=!1;break}continue}if(A==="metaHas"){if(!Object.hasOwn(S.meta??{},String(E))){N=!1;break}continue}if(S[A]!==E){N=!1;break}}if(!N)continue}m[b]=S}let p=new Set(Object.keys(m)),h=[];for(let[b,_]of d)if(_ instanceof I)for(let k of _._deps){let O=u.get(k.node);O!=null&&h.push([O,b])}h.sort((b,_)=>b[0]<_[0]?-1:b[0]>_[0]?1:b[1]<_[1]?-1:b[1]>_[1]?1:0);let l=h.map(([b,_])=>({from:b,to:_}));(t!=null||r!=null)&&(l=l.filter(b=>p.has(b.from)&&p.has(b.to)));let v=this._collectSubgraphs(""),y=t!=null||r!=null?v.filter(b=>{let _=`${b}${G}`;return[...p].some(k=>k===b||k.startsWith(_))}):v,w=this,g=e;return{name:this.name,nodes:m,edges:l,subgraphs:y,...this._factory!==void 0?{factory:this._factory}:{},...this._factoryArgs!==void 0?{factoryArgs:this._factoryArgs}:{},expand(b){let _={...g};return Array.isArray(b)?(_.fields=b,_.detail=void 0):(_.detail=b,_.fields=void 0),w.describe(_)}}}_collectSubgraphs(e){let t=[];for(let r of[...this._mounts.keys()].sort()){let s=e===""?r:`${e}${r}`;t.push(s),t.push(...this._mounts.get(r)._collectSubgraphs(`${s}${G}`))}return t}resourceProfile(e){return nn(this,e)}reachable(e,t,r={}){return r.withDetail===!0?dn(this.describe(),e,t,{...r,withDetail:!0}):dn(this.describe(),e,t,r)}explain(e,t,r){return r?.reactive===!0?this._explainReactive(e,t,r):this._explainStatic(ae(e),ae(t),{...r?.maxDepth!==void 0?{maxDepth:on(r.maxDepth)}:{},...r?.findCycle!==void 0?{findCycle:an(r.findCycle)}:{}})}_explainStatic(e,t,r){let s=this.describe({detail:"full"}),o=new Map(this._annotations),i=new Map;for(let[a,u]of Object.entries(s.nodes))u.lastMutation!=null&&i.set(a,u.lastMutation);return Jt(s,e,t,{...r?.maxDepth!=null?{maxDepth:r.maxDepth}:{},...r?.findCycle===!0?{findCycle:!0}:{},annotations:o,lastMutations:i})}_describeReactive(e){let t={...e,reactive:!1},r=e.reactiveName??"describe",s=0,o=se(s,{name:`${r}_version`}),i=this.observe({timeline:!0,structured:!0}),a=!1,u=!1,c=()=>{a||u||(a=!0,ve(()=>{a=!1,!u&&(s+=1,o.emit(s))}))},d=i.onEvent(g=>{let f=g.type;f!=="data"&&f!=="error"&&f!=="complete"&&f!=="teardown"||c()}),m=[],p=new WeakSet,h=g=>{if(p.has(g)||u)return;p.add(g);let f=g.topology.subscribe(b=>{for(let _ of b){if(_[0]!==F)continue;let k=_[1];if(c(),k.kind==="added"&&k.nodeKind==="mount"){let O=g._mounts.get(k.name);O!=null&&h(O)}}});m.push(f);for(let b of g._mounts.keys()){let _=g._mounts.get(b);_!=null&&h(_)}};h(this);let l,v=e.actor;ln(v)&&(l=v.subscribe(g=>{let f=!1,b=!1;for(let _ of g){let k=_[0];k===F?f=!0:(k===z||k===C||k===V)&&(b=!0)}f&&c(),b&&(l?.(),l=void 0,c())}));let y;try{y=pe([o],()=>this.describe(t),{name:r,describeKind:"derived",meta:{domain:"audit",kind:"describe"},equals:(g,f)=>g===f})}catch(g){d(),l?.();for(let f of m)f();throw i.dispose(),g}let w=Te(y);return{node:y,dispose(){u=!0,d(),l?.();for(let g of m)g();m.length=0,i.dispose(),w()}}}_describeReactiveDiff(e){let t={...e,reactive:!1},r=e.reactiveName??"describe-diff",s={name:this.name,nodes:{},edges:[],subgraphs:[]},o=this.describe(t),i=vt(s,o),a=se(i,{name:r,meta:{domain:"audit",kind:"describe-diff"},equals:(p,h)=>p===h}),u=this._describeReactive({...e,reactiveName:void 0}),c=!1,d=u.node.subscribe(p=>{if(!c)for(let h of p){if(h[0]!==F)continue;let l=h[1],v=vt(o,l);o=l,v.events.length!==0&&a.emit(v)}}),m=Te(a);return{node:a,dispose(){c=!0,d(),u.dispose(),a.down([[V,"describe-diff disposed"]]),m()}}}_explainReactive(e,t,r){let s=0,o=se(s,{name:"explain_version"}),i=this.observe({timeline:!0,structured:!0}),a=!1,u=!1,c=()=>{a||u||(a=!0,ve(()=>{a=!1,!u&&(s+=1,o.emit(s))}))},d=i.onEvent(g=>{let f=g.type;f!=="data"&&f!=="error"&&f!=="complete"&&f!=="teardown"||c()}),m=[];e!=null&&he(e)&&m.push(e),t!=null&&he(t)&&m.push(t),r?.maxDepth!=null&&he(r.maxDepth)&&m.push(r.maxDepth),r?.findCycle!=null&&he(r.findCycle)&&m.push(r.findCycle);let p=()=>{for(let g of m)if(g.cache===void 0)return!1;return!0},h=()=>{let g=ae(e),f=ae(t);return{from:g,to:f,found:!1,reason:"pending",steps:[],text:"(awaiting reactive args)",toJSON:()=>({from:g,to:f,found:!1,reason:"pending",steps:[]})}},l;try{l=pe([o],()=>{if(!p())return h();let g=ae(e),f=ae(t),b={...r?.maxDepth!==void 0?{maxDepth:on(r.maxDepth)}:{},...r?.findCycle!==void 0?{findCycle:an(r.findCycle)}:{}};return this._explainStatic(g,f,b)},{name:r?.name??"explain",describeKind:"derived",meta:{domain:"audit",kind:"explain_path",from:ae(e),to:ae(t)},equals:(g,f)=>g.found===f.found&&g.reason===f.reason&&g.steps.length===f.steps.length&&lr(g.steps,f.steps)})}catch(g){throw d(),i.dispose(),g}let v=Te(l),y=[],w=g=>{let f;return f=g.subscribe(b=>{let _=!1,k=!1;for(let O of b){let T=O[0];T===F?_=!0:(T===z||T===C||T===V)&&(k=!0)}(_||k)&&c(),k&&f&&(f(),f=void 0)}),()=>{f&&(f(),f=void 0)}};for(let g of m)y.push(w(g));return{node:l,dispose(){u=!0,d();for(let g of y)g?.();y.length=0,i.dispose(),v()}}}_pathsMatching(e){let t=Xe(e),r=[];return this._collectObserveTargets("",r),r.map(([s])=>s).filter(s=>t.test(s))}_collectObserveTargets(e,t){for(let r of[...this._mounts.keys()].sort()){let s=e===""?r:`${e}${G}${r}`;this._mounts.get(r)._collectObserveTargets(s,t)}for(let r of[...this._nodes.keys()].sort()){let s=this._nodes.get(r),o=e===""?r:`${e}${G}${r}`;t.push([o,s]),this._appendMetaObserveTargets(o,s,t)}}_appendMetaObserveTargets(e,t,r){for(let s of Object.keys(t.meta).sort()){let o=t.meta[s],i=`${e}${G}${U}${G}${s}`;r.push([i,o]),this._appendMetaObserveTargets(i,o,r)}}observe(e,t){let r=typeof e=="string",o=un(r?t:e);if(o.reactive===!0)return this._observeReactive(r?e:void 0,o);let i=o.structured===!0||o.timeline===!0||o.causal===!0||o.derived===!0||o.detail==="minimal"||o.detail==="full"||o.format!=null,a=o.actor;if(r){let d=e,m=this.resolve(d);if(a!=null&&!m.allowsObserve(a))throw new Z({actor:a,action:"observe",nodeName:d});return i?this._buildStructuredObserver([[d,m]],o,"one"):{subscribe(p){return m.subscribe(p)},up(p){try{m.up?.(p)}catch(h){if(h instanceof Z)return;throw h}}}}let u=[];this._collectObserveTargets("",u),u.sort((d,m)=>d[0]<m[0]?-1:d[0]>m[0]?1:0);let c=a==null?u:u.filter(([,d])=>d.allowsObserve(a));return i?this._buildStructuredObserver(c,o,"all"):{subscribe:d=>{let m=c.map(([p,h])=>h.subscribe(l=>{d(p,l)}));return()=>{for(let p of m)p()}},up:(d,m)=>{try{this.resolve(d).up?.(m)}catch(p){if(p instanceof Z)return;throw p}}}}_observeReactive(e,t){let r=t.tiers,s=r!=null?new Set(r):null,o=t.reactiveName??"observe";return Oe(i=>{let a=[],u=!1,c=!1,d=()=>{if(a.length===0||c)return;let v={events:a.slice(),flushedAt_ns:oe()};a.length=0,i.emit(v)},m={...t,reactive:!1,structured:!0,timeline:!0},p=e!=null?this.observe(e,m):this.observe(m),h=v=>{c||(a.push(v),!u&&(u=!0,ve(()=>{u=!1,d()})))};for(let v of p.events)h(v);let l=p.onEvent(h);return()=>{c=!0,l(),p.dispose()}},{name:o,meta:{domain:"audit",kind:"observe-reactive"}})}_buildStructuredObserver(e,t,r){let s=r==="one"?e[0]?.[0]:void 0,o=i=>{if(r==="one"&&s!=null){let d=this.resolve(s);return this._buildStructuredObserver([[s,d]],i,"one")}let a=[];this._collectObserveTargets("",a),a.sort((d,m)=>d[0]<m[0]?-1:d[0]>m[0]?1:0);let u=i.actor,c=u==null?a:a.filter(([,d])=>d.allowsObserve(u));return this._buildStructuredObserver(c,i,"all")};return this._createObserveResult(e,t,o)}_createObserveResult(e,t,r){let s=t.timeline===!0,o=t.causal===!0,i=t.derived===!0,a=t.detail==="minimal",u=this.config.inspectorEnabled,c=(o||i)&&u,d=t.maxEvents,m=d!=null&&d>0?new Me(d):null,p=[],h=new Set,l=t.tiers!=null?new Set(t.tiers):null,v={},y=new Set,w=0,g=0,f=0,b=0,_=0,k=0,O=!1,T=!1,R=0,S=new Map,N=new Map,P=new Map,E=x=>{if(!(l!=null&&!l.has(x.type))){m?m.push(x):p.push(x);for(let M of h)M(x)}},A=x=>l==null||l.has(x),Q=()=>s?{timestamp_ns:oe(),in_batch:Pe(),batch_id:R}:{},ge=(x,M)=>{if(!(!c||!(x instanceof I)))return x._setInspectorHook(J=>{if(J.kind==="dep_message")S.set(x,J.depIndex);else if(J.kind==="run"){let Re=J.batchData.map((D,W)=>D!=null&&D.length>0?D.at(-1):J.prevData[W]);N.set(x,Re);let Y=J.batchData.map(D=>D!=null?[...D]:void 0);P.set(x,Y),i&&E({type:"derived",path:M,dep_values:Re,dep_batches:Y,...Q()})}})},B=x=>{let M=S.get(x),J=N.get(x);if(!o||J==null)return{};let Y=(M!=null&&M>=0&&x instanceof I?x._deps[M]:void 0)?.node,D=Y?.v,W=P.get(x);return{trigger_dep_index:M,trigger_dep_name:Y?.name,...D!=null?{trigger_version:{id:D.id,version:D.version}}:{},dep_values:[...J],...W!=null?{dep_batches:W}:{}}},q=[],H=[];for(let[x,M]of e){let J=ge(M,x);J&&q.push(J),H.push(M.subscribe(Re=>{R++;for(let Y of Re){let D=Y[0],W=Q();if(D===F){v[x]=Y[1];let tt=M instanceof I?M.lastMutation?.actor??me:me;E({type:"data",path:x,data:Y[1],actor:tt,...W,...B(M)})}else if(a)D===X?A("dirty")&&w++:D===ne?A("resolved")&&g++:D===te?A("invalidate")&&f++:D===re?A("pause")&&b++:D===ie?A("resume")&&_++:D===V?A("teardown")&&k++:D===z&&!y.has(x)?A("complete")&&(O=!0):D===C&&A("error")&&(T=!0,y.add(x));else if(D===X)A("dirty")&&w++,E({type:"dirty",path:x,...W});else if(D===ne)A("resolved")&&g++,E({type:"resolved",path:x,...W,...B(M)});else if(D===te)A("invalidate")&&f++,E({type:"invalidate",path:x,...W});else if(D===re)A("pause")&&b++,E({type:"pause",path:x,lockId:Y[1],...W});else if(D===ie)A("resume")&&_++,E({type:"resume",path:x,lockId:Y[1],...W});else if(D===z)A("complete")&&!y.has(x)&&(O=!0),E({type:"complete",path:x,...W});else if(D===C){A("error")&&(T=!0,y.add(x));let tt=M instanceof I?M.lastMutation?.actor??me:me;E({type:"error",path:x,data:Y[1],actor:tt,...W})}else D===V&&(A("teardown")&&k++,E({type:"teardown",path:x,...W}))}}))}let K=!1,L=()=>{if(!K){K=!0;for(let x of H)x();for(let x of q)x();for(let x of $e)x({value:void 0,done:!0});$e.length=0}},ee=[],$e=[];h.add(x=>{let M=$e.shift();M?M({value:x,done:!1}):ee.push(x)});let Ot={get values(){return v},get dirtyCount(){return w},get resolvedCount(){return g},get invalidateCount(){return f},get pauseCount(){return b},get resumeCount(){return _},get teardownCount(){return k},get events(){return m?m.toArray():[...p]},get anyCompletedCleanly(){return O},get anyErrored(){return T},get completedWithoutErrors(){return O&&!T},onEvent(x){return h.add(x),()=>h.delete(x)},dispose:L,expand(x){L();let M={...t};return typeof x=="string"?M.detail=x:Object.assign(M,x),r(un(M))},[Symbol.asyncIterator](){return{next(){return ee.length>0?Promise.resolve({value:ee.shift(),done:!1}):K?Promise.resolve({value:void 0,done:!0}):new Promise(x=>$e.push(x))},return(){return L(),Promise.resolve({value:void 0,done:!0})}}}};return t.format!=null&&this._attachFormatLogger(Ot,t),Ot}_attachFormatLogger(e,t){let r=t.format;if(r==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)),u=ir(t.theme),c=r==="stage-log"?oe():0,d=l=>l==null?"":t.stageLabels?.[l]??l,m=(l,v)=>l.length>v?`${l.slice(0,v-1)}\u2026`:l,p=l=>l.type==="data"||l.type==="error"?m(wt(l.data),120):"",h=l=>{if(r==="stage-log"){let O=(oe()-c)/1e9,T=d(l.path).padEnd(9);if(l.type==="data"){let R=p(l);return`[${O.toFixed(3)}s] ${T} \u2190${R?` ${R}`:""}`}if(l.type==="error"){let R=p(l);return`[${O.toFixed(3)}s] ${T} \u2717${R?` ${R}`:""}`}return l.type==="complete"?`[${O.toFixed(3)}s] ${T} \u25A0 complete`:`[${O.toFixed(3)}s] ${T} ${l.type}`}if(r==="json")try{return JSON.stringify(l)}catch{return JSON.stringify({type:l.type,path:l.path,data:"[unserializable]"})}let v=u[l.type]??"",y=l.path?`${u.path}${l.path}${u.reset} `:"",w=l.type==="data"||l.type==="error",g=l.type==="pause"||l.type==="resume",f=w?` ${wt(l.data)}`:g?` ${wt(l.lockId)}`:"",b=l.type==="data"||l.type==="resolved"||l.type==="derived"?l:void 0,_=b?.trigger_dep_name!=null?` <- ${b.trigger_dep_name}`:b?.trigger_dep_index!=null?` <- #${b.trigger_dep_index}`:"",k=l.in_batch?" [batch]":"";return`${y}${v}${l.type.toUpperCase()}${u.reset}${f}${_}${k}`};e.onEvent(l=>{a(l.type)&&s(h(l),l)})}addDisposer(e){return this._disposers.add(e),()=>{this._disposers.delete(e)}}destroy(){sn(this._disposers,this.name),this.signal([[V]],{internal:!0}),sn(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,...r}=this.describe({detail:"full"}),s={};for(let a of Object.keys(r.nodes).sort()){let{lastMutation:u,guard:c,...d}=r.nodes[a];s[a]=d}let o=[...r.subgraphs].sort(),i={...r,version:1,nodes:s,subgraphs:o};if(e?.format==null)return i;if(e.format==="json-string")return JSON.stringify(i);if(e.format==="bytes"){if(e.codec==null)throw new Error("snapshot({format: 'bytes'}) requires a `codec` name");let a=this.config.lookupCodec(e.codec);if(a==null)throw new Error(`snapshot: codec "${e.codec}" is not registered on this graph's config. Call config.registerCodec(...) before creating nodes.`);return xt(a,a.encode(i))}throw new Error(`snapshot: unknown format "${String(e.format)}"`)}static decode(e,t){let r=t?.config??ke,{codec:s,codecVersion:o,payload:i}=St(e,r);return s.decode(i,o)}restore(e,t){if(cn(e),e.name!==this.name)throw new Error(`Graph "${this.name}": restore snapshot name "${e.name}" does not match this graph`);let r=t?.only==null?null:(Array.isArray(t.only)?t.only:[t.only]).map(o=>Xe(o)),s=t?.includeProducers===!0;for(let o of Object.keys(e.nodes).sort()){if(r!==null&&!r.some(a=>a.test(o)))continue;let i=e.nodes[o];if(i!==void 0){if(!("value"in i)||i.value===void 0){"value"in i&&i.value===void 0&&t?.onError?.(o,new Error(`restore: slice.value is undefined for "${o}" (undefined is the global SENTINEL; not valid DATA)`));continue}if(!(i.type==="derived"||i.type==="effect")&&!(i.type==="producer"&&!s)){if(i.v!=null){let u=this.tryResolve(o)?.v;if(u!=null&&u.id===i.v.id&&u.version===i.v.version)continue}try{this.set(o,i.value)}catch(a){t?.onError?.(o,a)}}}}}static fromSnapshot(e,t){cn(e);let r=typeof t=="function"?t:t?.build,s=typeof t=="function"?void 0:t?.factories,o=new n(e.name);if(r)return r(o),o.restore(e),o;for(let h of[...e.subgraphs].sort((l,v)=>{let y=l.split(G).length,w=v.split(G).length;return y!==w?y-w:l<v?-1:l>v?1:0})){let l=h.split(G),v=o;for(let y of l)v._mounts.has(y)||v.mount(y,new n(y)),v=v._mounts.get(y)}let i=s?Object.entries(s).map(([h,l])=>({re:Xe(h),factory:l})):[],a=h=>{for(let l of i)if(l.re.test(h))return l.factory},u=h=>{let l=h.split(G),v=l.pop();if(v==null||v.length===0)throw new Error(`invalid snapshot path "${h}"`);let y=o;for(let w of l){let g=y._mounts.get(w);if(!g)throw new Error(`unknown mount "${w}" in path "${h}"`);y=g}return[y,v]},c=Object.entries(e.nodes).filter(([h])=>!h.includes(`${G}${U}${G}`)).sort((h,l)=>h[0]<l[0]?-1:h[0]>l[0]?1:0),d=new Map(c),m=new Map,p=!0;for(;d.size>0&&p;){p=!1;for(let[h,l]of[...d.entries()]){let v=l?.deps??[];if(!v.every(_=>m.has(_)))continue;let[y,w]=u(h),g={...l?.meta??{}},f=a(h),b;if(l?.type==="state")b=se(l.value,{meta:g});else{if(f==null)continue;b=f(w,{path:h,type:l.type,value:l.value,meta:g,deps:v,resolvedDeps:v.map(_=>m.get(_))})}y.add(b,{name:w}),m.set(h,b),d.delete(h),p=!0}}if(d.size>0){let h=[...d.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 r=e.map(c=>({tier:c,debounceMs:Math.max(0,c.debounceMs??0),compactEvery:Math.max(1,c.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=(c,d)=>{if(c.disposed)return;let m=tr(d.nodes);if(c.lastSnapshot!=null&&m!==""&&m===c.lastFingerprint)return;let p=c.seq+1,h=Ve(),y=c.lastSnapshot==null||p%c.compactEvery===0?{name:this.name,mode:"full",snapshot:d,seq:p,timestamp_ns:h,format_version:xe}:{name:this.name,mode:"diff",diff:dr(c.lastSnapshot,d),seq:p,timestamp_ns:h,format_version:xe};if(c.tier.filter&&!c.tier.filter(y))return;let w;try{w=c.tier.save(y)}catch(g){t.onError?.(g,c.tier);return}if(w&&typeof w.then=="function"){let b=(c.savePending??Promise.resolve()).then(()=>w,()=>w).then(()=>{c.disposed||(c.seq=p,c.lastSnapshot=d,c.lastFingerprint=m)},_=>{t.onError?.(_,c.tier)});c.savePending=b.finally(()=>{c.savePending===b&&(c.savePending=void 0)})}else c.seq=p,c.lastSnapshot=d,c.lastFingerprint=m},o=(c,d)=>{try{s(c,d)}catch(m){t.onError?.(m,c.tier)}},i=(c,d)=>{if(!d.some(l=>{let v=this.config.messageTier(l[0]);return v>=3&&v<5}))return;if(t.filter){let l=this.tryResolve(c);if(l==null)return;let v=bt(l,mt("standard"));if(!t.filter(c,v))return}let p,h=()=>(p==null&&(p=this.snapshot()),p);for(let l of r)l.disposed||(l.debounceMs===0?o(l,h()):(l.timer==null&&(l.timer=new qe),l.timer.start(l.debounceMs,()=>{l.disposed||o(l,this.snapshot())})))},a;if(t.paths!=null){let d=(typeof t.paths=="string"?this._pathsMatching(t.paths):t.paths).map(m=>{let p=this.tryResolve(m);return p==null?()=>{}:p.subscribe(h=>i(m,h))});a=()=>{for(let m of d)m()}}else a=this.observe().subscribe((c,d)=>i(c,d));let u=()=>{a();for(let c of r)c.disposed=!0,c.timer?.cancel();this._storageDisposers.delete(u)};return this._storageDisposers.add(u),{dispose:u}}async _cascadeRestore(e,t){for(let r of e){let s;try{s=await r.load?.()}catch(i){t?.(i,r);continue}if(s==null||typeof s!="object"||Array.isArray(s))continue;let o=s;try{if(o.mode==="full"&&o.snapshot!=null)return this.restore(o.snapshot),!0;if(o.version===xe&&o.nodes!=null)return this.restore(o),!0}catch(i){t?.(i,r)}}return!1}static async fromStorage(e,t,r){for(let s of t){let o;try{o=await s.load?.()}catch(u){r?.onError?.(u,s);continue}if(o==null||typeof o!="object"||Array.isArray(o))continue;let i=o,a=i.mode==="full"&&i.snapshot!=null?i.snapshot:i.version===xe&&i.nodes!=null?i:void 0;if(a!=null)try{return n.fromSnapshot(a,r)}catch(u){r?.onError?.(u,s)}}throw new Error(`Graph.fromStorage: no tier held a restorable record for "${e}" across ${t.length} tier(s)`)}_annotations=new Map;_traceRing;trace(e,t,r){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:oe(),...r?.actor!=null?{actor:r.actor}:{}};this._traceRing.push(s)}return}return e!=null?this.config.inspectorEnabled?this._annotations.get(e):void 0:this.config.inspectorEnabled?this._traceRing.toArray():[]}annotation(e){return this._annotations.get(e)}clearTrace(){this._annotations.clear(),this._traceRing.clear()}pruneTrace(e){let t=this._traceRing.toArray().filter(s=>!e(s)),r=this._traceRing.size-t.length;this._traceRing.clear();for(let s of t)this._traceRing.push(s);return r}static diff(e,t){let r=new Set(Object.keys(e.nodes)),s=new Set(Object.keys(t.nodes)),o=[...s].filter(g=>!r.has(g)).sort(),i=[...r].filter(g=>!s.has(g)).sort(),a=[],u=[];for(let g of r){if(!s.has(g))continue;let f=e.nodes[g],b=t.nodes[g],_=f.v,k=b.v;_!=null&&k!=null&&_.id===k.id&&_.version!==k.version&&u.push({path:g,id:_.id,from:_.version,to:k.version});let O=_!=null&&k!=null&&_.id===k.id&&_.version===k.version;for(let T of["type","status","sentinel"]){let R=f[T],S=b[T];R!==S&&a.push({path:g,field:T,from:R,to:S})}if(!O)for(let T of["value","meta"]){let R=f[T],S=b[T];nr(R,S)||a.push({path:g,field:T,from:R,to:S})}}let c=g=>`${g.from} ${g.to}`,d=new Set(e.edges.map(c)),m=new Set(t.edges.map(c)),p=t.edges.filter(g=>!d.has(c(g))),h=e.edges.filter(g=>!m.has(c(g))),l=new Set(e.subgraphs),v=new Set(t.subgraphs),y=[...v].filter(g=>!l.has(g)).sort(),w=[...l].filter(g=>!v.has(g)).sort();return{nodesAdded:o,nodesRemoved:i,nodesChanged:a,versionChanges:u,edgesAdded:p,edgesRemoved:h,subgraphsAdded:y,subgraphsRemoved:w}}}});function hn(n,e,t){return{[n]:!0,[`${n}_type`]:e,...t??{}}}var gn=$(()=>{"use strict"});var wr={};An(wr,{compileSpec:()=>mr,decompileSpec:()=>yr,extractFnFactory:()=>wn,extractSourceFactory:()=>kn,generateCatalogPrompt:()=>Nn,isRichFnEntry:()=>Ge,isRichSourceEntry:()=>Qe,llmCompose:()=>_r,llmRefine:()=>xn,specDiff:()=>vr,validateSpec:()=>et,validateSpecAgainstCatalog:()=>Nt});module.exports=Cn(wr);Ue();pn();Le();we();Ne();Ue();gn();Ce();we();function mn(n,e){let t=n.cache??0;return t>=e?!1:(n.down([[X],[F,t+1]]),!0)}var Ns=Ft((n,e)=>{n("observe"),n("signal"),e("write")});_t();function bn(n,e){return hn("reduction",n,e)}function yn(n,e,t,r){let s=r?.maxIterations??10,o=`__feedback_${e}`,i=se(0,{meta:bn("feedback_counter",{maxIterations:s,feedbackFrom:e,feedbackTo:t})});n.add(i,{name:o});let a=n.resolve(e),u=n.resolve(t),c=`__feedback_effect_${e}`,d=fe([],(m,p)=>{let h=a.subscribe(l=>{for(let v of l){let y=v[0];if(y===F){let w=v[1];if(w==null)return;Ie(()=>{mn(i,s)&&u.emit(w)})}else if(y===z||y===C){let w=y===C&&v.length>1?[C,v[1]]:[y];i.down([w])}}});return()=>h()},{name:c,describeKind:"effect",meta:{...bn("feedback_effect",{feedbackFrom:e,feedbackTo:t}),_internal:!0}});return n.add(d,{name:c}),n.addDisposer(Te(d)),n}function ce(n){let e=n.meta?.factory;return typeof e=="string"?e:void 0}function ue(n){let e=n.meta?.factoryArgs;return e!=null&&typeof e=="object"?e:{}}function vn(n){let e=ue(n);return"initial"in e?e.initial:n.value}function Ge(n){return typeof n=="object"&&n!==null&&"factory"in n}function Qe(n){return typeof n=="object"&&n!==null&&"factory"in n}function wn(n){return Ge(n)?n.factory:n}function kn(n){return Qe(n)?n.factory:n}function Nn(n){let e=[];if(n.fns){let t=new Map;for(let[r,s]of Object.entries(n.fns)){let o=Ge(s)?s.tags?.[0]??"Other":"Other";t.has(o)||t.set(o,[]),t.get(o).push(fr(r,s))}for(let[r,s]of t)e.push(`${r}:
1
+ "use strict";var rt=Object.defineProperty;var An=Object.getOwnPropertyDescriptor;var Dn=Object.getOwnPropertyNames;var Cn=Object.prototype.hasOwnProperty;var F=(n,e)=>()=>(n&&(e=n(n=0)),e);var Mn=(n,e)=>{for(var t in e)rt(n,t,{get:e[t],enumerable:!0})},Gn=(n,e,t,r)=>{if(e&&typeof e=="object"||typeof e=="function")for(let s of Dn(e))!Cn.call(n,s)&&s!==t&&rt(n,s,{get:()=>e[s],enumerable:!(r=An(e,s))||r.enumerable});return n};var $n=n=>Gn(rt({},"__esModule",{value:!0}),n);function Rt(n,e){let t=new TextEncoder().encode(n.name);if(t.length===0||t.length>255)throw new Error(`encodeEnvelope: codec name "${n.name}" encodes to ${t.length} bytes (must be 1\u2013255)`);let r=n.version;if(!Number.isInteger(r)||r<0||r>65535)throw new Error(`encodeEnvelope: codec.version ${r} out of u16 range (expected integer 0\u201365535)`);let s=2+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++]=st,o[i++]=t.length,o.set(t,i),i+=t.length,o[i++]=r>>>8&255,o[i++]=r&255,o.set(e,i),o}function Et(n,e){if(n.length<St)throw new Error(`decodeEnvelope: bytes too short (${n.length} < ${St})`);let t=0,r=n[t++];if(r!==st)throw new Error(`decodeEnvelope: unsupported envelope version ${r} (expected ${st})`);let s=n[t++];if(s===0)throw new Error("decodeEnvelope: name_len must be >= 1");if(t+s+2>n.length)throw new Error(`decodeEnvelope: envelope truncated (need ${t+s+2} bytes, have ${n.length})`);let o=new TextDecoder().decode(n.subarray(t,t+s));t+=s;let i=(n[t]<<8|n[t+1])>>>0;t+=2;let a=n.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 At(n){n.registerCodec(Fn)}var Fn,st,St,ot=F(()=>{"use strict";Fn={name:"json",version:1,contentType:"application/json",encode(n){let e=JSON.stringify(n);return new TextEncoder().encode(e)},decode(n,e){let t=new TextDecoder().decode(n);return JSON.parse(t)}},st=1,St=4});function je(n){if(n==null)return ye;let{type:e,id:t,...r}=n;return{type:e??"system",id:t??"",...r}}var ye,it=F(()=>{"use strict";ye={type:"system",id:""}});function Le(){return ve>0||De}function Dt(){return ve>0}function _e(n){ve>0?Ce.push(n):n()}function Me(n){ve+=1;let e=!1;try{n()}catch(t){throw e=!0,t}finally{if(ve-=1,ve===0)if(e){if(!De){let t=Ce.splice(0);for(let r of t)try{r()}catch{}fe.length=0,pe.length=0,we.length=0}}else Pn()}}function Pn(){let n=!De;n&&(De=!0);let e=[],t=0;try{for(;fe.length>0||pe.length>0||we.length>0||n&&Ce.length>0;){if(n&&Ce.length>0){let o=Ce.splice(0);for(let i of o)try{i()}catch(a){e.push(a)}continue}if(t+=1,t>1e3)throw fe.length=0,pe.length=0,we.length=0,new Error("batch drain exceeded 1000 iterations \u2014 likely a reactive cycle");let s=(fe.length>0?fe:pe.length>0?pe:we).splice(0);for(let o of s)try{o()}catch(i){e.push(i)}}}finally{n&&(De=!1)}if(e.length===1)throw e[0];if(e.length>1)throw new AggregateError(e,"batch drain: multiple callbacks threw")}function Ve(n,e,t){if(e.length===0)return;if(e.length===1){let c=t(e[0][0]);if(c<3||!Le()){n(e);return}(c>=5?we:c===4?pe:fe).push(()=>n(e));return}let r=e.length,s=r,o=r,i=r,a=0;for(;a<r&&t(e[a][0])<3;)a++;for(s=a;a<r&&t(e[a][0])===3;)a++;for(o=a;a<r&&t(e[a][0])===4;)a++;i=a;let d=Le();if(s>0){let c=e.slice(0,s);n(c)}if(o>s){let c=e.slice(s,o);d?fe.push(()=>n(c)):n(c)}if(i>o){let c=e.slice(o,i);d?pe.push(()=>n(c)):n(c)}if(r>i){let c=e.slice(i,r);d?we.push(()=>n(c)):n(c)}}var ve,De,fe,pe,we,Ce,Be=F(()=>{"use strict";ve=0,De=!1,fe=[],pe=[],we=[],Ce=[]});function ie(){return Math.trunc(performance.now()*1e6)}function ze(){return Date.now()*1e6}var He=F(()=>{"use strict"});var ke,$,U,te,ne,se,ae,B,I,D,Te,at,In,ct,jn,Ln,dt,Ct,Mt,Gt,ut,he=F(()=>{"use strict";ke=Symbol.for("graphrefly/START"),$=Symbol.for("graphrefly/DATA"),U=Symbol.for("graphrefly/DIRTY"),te=Symbol.for("graphrefly/RESOLVED"),ne=Symbol.for("graphrefly/INVALIDATE"),se=Symbol.for("graphrefly/PAUSE"),ae=Symbol.for("graphrefly/RESUME"),B=Symbol.for("graphrefly/TEARDOWN"),I=Symbol.for("graphrefly/COMPLETE"),D=Symbol.for("graphrefly/ERROR"),Te=Object.freeze([U]),at=Object.freeze([te]),In=Object.freeze([ne]),ct=Object.freeze([ke]),jn=Object.freeze([I]),Ln=Object.freeze([B]),dt=Object.freeze([Te]),Ct=Object.freeze([at]),Mt=Object.freeze([In]),Gt=Object.freeze([jn]),ut=Object.freeze([Ln])});function $t(n){n.registerMessageType(ke,{tier:0,wireCrossing:!1}),n.registerMessageType(U,{tier:1,wireCrossing:!1}),n.registerMessageType(ne,{tier:1,wireCrossing:!1,metaPassthrough:!1}),n.registerMessageType(se,{tier:2,wireCrossing:!1}),n.registerMessageType(ae,{tier:2,wireCrossing:!1}),n.registerMessageType($,{tier:3,wireCrossing:!0}),n.registerMessageType(te,{tier:3,wireCrossing:!0}),n.registerMessageType(I,{tier:4,wireCrossing:!0,metaPassthrough:!1}),n.registerMessageType(D,{tier:4,wireCrossing:!0,metaPassthrough:!1}),n.registerMessageType(B,{tier:5,wireCrossing:!0,metaPassthrough:!1})}var We,Ft=F(()=>{"use strict";he();We=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 r=this._messageTypes.get(t);return r!=null?r.tier:1}}get onMessage(){return this._frozen=!0,this._onMessage}get onSubscribe(){return this._frozen=!0,this._onSubscribe}set onMessage(e){this._assertUnfrozen(),this._onMessage=e}set onSubscribe(e){this._assertUnfrozen(),this._onSubscribe=e}get defaultVersioning(){return this._defaultVersioning}set defaultVersioning(e){this._assertUnfrozen(),this._defaultVersioning=e}get defaultHashFn(){return this._defaultHashFn}set defaultHashFn(e){this._assertUnfrozen(),this._defaultHashFn=e}get inspectorEnabled(){return this._inspectorEnabled}set inspectorEnabled(e){this._inspectorEnabled=e}get globalInspector(){return this._globalInspector}set globalInspector(e){this._globalInspector=e}get rigorRecorder(){return this._rigorRecorder}set rigorRecorder(e){this._rigorRecorder=e}registerMessageType(e,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 Pt(n){return Array.isArray(n)?[...n]:[n]}function Vn(n,e){return n.has(e)||n.has("*")}function It(n){let e=[];return n((s,o)=>{e.push({kind:"allow",actions:new Set(Pt(s)),where:o?.where??(()=>!0)})},(s,o)=>{e.push({kind:"deny",actions:new Set(Pt(s)),where:o?.where??(()=>!0)})}),(s,o)=>{let i=!1,a=!1;for(let d of e)Vn(d.actions,o)&&d.where(s)&&(d.kind==="deny"?i=!0:a=!0);return i?!1:a}}function lt(n){let e=Bn.filter(t=>n({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,Bn,Ge=F(()=>{"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}};Bn=["human","llm","wallet","system"]});function ft(n){if(n===void 0)return null;if(typeof n=="number"){if(!Number.isFinite(n))throw new TypeError(`Cannot hash non-finite number: ${n}`);if(Number.isInteger(n)&&!Number.isSafeInteger(n))throw new TypeError(`Cannot hash integer outside safe range (|n| > 2^53-1): ${n}. Cross-language cid parity is not guaranteed for unsafe integers.`);return n}if(typeof n=="string"||typeof n=="boolean"||n===null)return n;if(Array.isArray(n))return n.map(ft);if(typeof n=="object"&&n!==null){let e={};for(let t of Object.keys(n).sort())e[t]=ft(n[t]);return e}return null}function Wn(n){let e=Hn.encode(n),t=e.length,r=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,r>>>0,!1),i.setUint32(s-8,Math.floor(r/4294967296)>>>0,!1);let a=1779033703,d=3144134277,c=1013904242,u=2773480762,p=1359893119,h=2600822924,g=528734635,l=1541459225,v=new Uint32Array(64),b=(m,f)=>m>>>f|m<<32-f;for(let m=0;m<s;m+=64){for(let T=0;T<16;T++)v[T]=i.getUint32(m+T*4,!1);for(let T=16;T<64;T++){let P=v[T-15],E=v[T-2],A=b(P,7)^b(P,18)^P>>>3,Q=b(E,17)^b(E,19)^E>>>10;v[T]=v[T-16]+A+v[T-7]+Q>>>0}let f=a,y=d,w=c,k=u,N=p,O=h,R=g,S=l;for(let T=0;T<64;T++){let P=b(N,6)^b(N,11)^b(N,25),E=N&O^~N&R,A=S+P+E+zn[T]+v[T]>>>0,Q=b(f,2)^b(f,13)^b(f,22),be=f&y^f&w^y&w,z=Q+be>>>0;S=R,R=O,O=N,N=k+A>>>0,k=w,w=y,y=f,f=A+z>>>0}a=a+f>>>0,d=d+y>>>0,c=c+w>>>0,u=u+k>>>0,p=p+N>>>0,h=h+O>>>0,g=g+R>>>0,l=l+S>>>0}let _=m=>m.toString(16).padStart(8,"0");return _(a)+_(d)+_(c)+_(u)+_(p)+_(h)+_(g)+_(l)}function pt(n){let e=ft(n??null),t=JSON.stringify(e);return Wn(t).slice(0,16)}function Un(){let n=globalThis.crypto;if(n?.randomUUID)return n.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(n,e,t){let r=t?.id??Un();if(n===0)return{id:r,version:0};let o=(t?.hash??pt)(e);return{id:r,version:0,cid:o,prev:null}}function jt(n,e,t){n.version+=1,"cid"in n&&(n.prev=n.cid,n.cid=t(e))}var zn,Hn,Lt=F(()=>{"use strict";zn=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]),Hn=new TextEncoder});function zt(n){return{node:n,unsub:null,prevData:void 0,dirty:!1,involvedThisWave:!1,dataBatch:[],terminal:void 0}}function gt(n){n.prevData=void 0,n.dirty=!1,n.involvedThisWave=!1,n.dataBatch.length=0,n.terminal=void 0}function Ue(n){return n.length===0?n:typeof n[0]=="symbol"?[n]:n}function ge(n,e,t){let r=Ht(n)?n:[],s=typeof n=="function"?n:typeof e=="function"?e:void 0,o={};return Ht(n)?o=(mt(e)?e:t)??{}:mt(n)?o=n:o=(mt(e)?e:t)??{},new j(r,s,o)}var Vt,Bt,qn,Kn,Ne,j,Ht,mt,Oe=F(()=>{"use strict";ot();it();Be();He();Ft();Ge();he();Lt();Vt=()=>{},Bt=100;qn=(n,e,t,r)=>{t.direction==="down-in"&&n._onDepMessage(t.depIndex,e)},Kn=(n,e,t,r)=>{let s=n;if(s._status==="completed"||s._status==="errored")return;let o=s._cached,i=o===void 0?[ct]:[ct,[$,o]];s._status==="dirty"&&i.push(Te),Ve(e,i,s._config.tierOf)},Ne=new We({onMessage:qn,onSubscribe:Kn});$t(Ne);At(Ne);j=class n{_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,r){this._config=r.config??Ne,this._config.onMessage,this._optsName=r.name,this._describeKind=r.describeKind,this._equals=r.equals??Object.is,this._resubscribable=r.resubscribable??!1,this._resetOnTeardown=r.resetOnTeardown??!1,this._autoComplete=r.completeWhenDepsComplete??!0,this._autoError=r.errorWhenDepsError??!0,this._pausable=r.pausable??!0,this._guard=r.guard,this._fn=t,this._partial=r.partial??!1,this._cached=r.initial!==void 0?r.initial:void 0,this._status=e.length===0&&t==null&&this._cached!==void 0?"settled":"sentinel",this._hashFn=r.versioningHash??this._config.defaultHashFn??pt;let s=r.versioning??this._config.defaultVersioning;this._versioningLevel=s,this._versioning=s!=null?ht(s,this._cached===void 0?void 0:this._cached,{id:r.versioningId,hash:this._hashFn}):void 0,this._deps=e.map(zt);let o={};for(let[a,d]of Object.entries(r.meta??{})){let c={initial:d,name:`${r.name??"node"}:meta:${a}`,describeKind:"state",config:this._config};r.guard!=null&&(c.guard=r.guard),r.resubscribable===!0&&(c.resubscribable=!0),o[a]=new n([],void 0,c)}Object.freeze(o),this.meta=o,this._hasMeta=Object.keys(o).length>0;let i=this;this._actions={emit(a){i._emit([[$,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 r=this._versioningLevel;if(r!=null&&e<=r)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,c=ht(e,o,{id:a,hash:s});c.version=d,this._versioning=c,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=je(e);if(this._guard!=null&&!this._guard(t,"observe"))return!1;if(this._extraGuards!=null){for(let r of this._extraGuards)if(!r(t,"observe"))return!1}return!0}_checkGuard(e){if(e?.internal)return;let t=this._guard!=null||this._extraGuards!=null,r=e?.actor!=null;if(!t&&!r)return;let s=je(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:ze()}}down(e,t){let r=Ue(e);r.length!==0&&(this._checkGuard(t),this._emit(r))}emit(e,t){this._checkGuard(t),this._emit([[$,e]])}up(e,t){if(this._deps.length===0)return;let r=Ue(e);if(r.length===0)return;this._checkGuard(t);let s=t??{internal:!0};this._validateUpTiers(r);for(let o of this._deps)o.node.up?.(r,s)}_emitUp(e){if(this._deps.length!==0&&e.length!==0){this._validateUpTiers(e);for(let t of this._deps)t.node.up?.(e,{internal:!0})}}_validateUpTiers(e){let t=this._config.tierOf;for(let r of e){let s=t(r[0]);if(s===3||s===4)throw new Error(`Node "${this.name}": tier-${s} messages cannot flow up \u2014 DATA/RESOLVED/COMPLETE/ERROR are downstream-only. Use \`down(...)\` for value delivery; \`up(...)\` is for control signals (DIRTY, INVALIDATE, PAUSE, RESUME, TEARDOWN).`)}}subscribe(e,t){if(t!=null&&this._guard!=null){let d=je(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 r=0;r<e;r++){let s=r,o=this._deps[r];o.unsub=Vt,o.unsub=o.node.subscribe(i=>{if(o.unsub===null)return;let a=this._config.tierOf,d=!1;for(let c of i)a(c[0])>=3&&(d=!0),this._config.onMessage(this,c,{direction:"down-in",depIndex:s},this._actions);d&&this._maybeRunFnOnSettlement()}),t++}}catch(r){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,r}}_addDep(e){for(let s=0;s<this._deps.length;s++)if(this._deps[s].node===e)return s;let t=this._deps.length,r=zt(e);if(this._deps.push(r),this._sinks==null)return t;r.dirty=!0,this._dirtyDepCount++,this._status!=="dirty"&&this._emit(dt),r.unsub=Vt;try{r.unsub=e.subscribe(s=>{if(r.unsub===null)return;let o=this._config.tierOf,i=!1;for(let a of s)o(a[0])>=3&&(i=!0),this._config.onMessage(this,a,{direction:"down-in",depIndex:t},this._actions);i&&this._maybeRunFnOnSettlement()})}catch(s){throw r.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(r){this._emit([[D,this._wrapFnError("cleanup threw",r)]])}else if(t!=null&&typeof t=="object"){let r=t.deactivate;if(typeof r=="function")try{r()}catch(s){this._emit([[D,this._wrapFnError("cleanup.deactivate threw",s)]])}}for(let r of this._deps){if(r.unsub!=null){let s=r.unsub;r.unsub=null;try{s()}catch{}}gt(r)}this._waveHasNewData=!1,this._hasNewTerminal=!1,this._hasCalledFnOnce=!1,this._paused=!1,this._pendingWave=!1,this._pendingRerun=!1,this._rerunDepth=0,this._store={},this._dirtyDepCount=0,this._pauseLocks=null,this._pauseBuffer=null,this._fn!=null&&(this._cached=void 0),e||(this._fn!=null||this._deps.length>0)&&(!this._isTerminal||this._resubscribable)&&(this._status="sentinel")}_onDepMessage(e,t){let r=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!==ke){if(s===U){this._depDirtied(r);return}if(s===ne){if(this._depInvalidated(r),this._cached===void 0)return;this._emit(Mt);return}if(s===se||s===ae){this._emit([t]);return}if(s===B){this._emit(ut);return}if(s===$)this._depSettledAsData(r,t[1]);else if(s===te)this._depSettledAsResolved(r);else if(s===I)this._depSettledAsTerminal(r,!0);else if(s===D)this._depSettledAsTerminal(r,t[1]);else{this._emit([t]);return}if(!this._fn){(s===$||s===te)&&this._emit([t]),(s===I||s===D)&&this._maybeAutoTerminalAfterWave();return}}}_depDirtied(e){e.dirty||(e.dirty=!0,e.involvedThisWave=!0,this._dirtyDepCount++,this._status!=="dirty"&&this._emit(dt))}_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(Ct),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([[D,e.terminal]]);return}this._autoComplete&&this._deps.every(t=>t.terminal!==void 0)&&this._emit(Gt)}_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([[D,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([[D,this._wrapFnError("cleanup.beforeRun threw",a)]]);return}}}let t=this._deps.map(i=>i.involvedThisWave?i.dataBatch.length>0?[...i.dataBatch]:[]:void 0),r=this._deps.map(i=>i.prevData);for(let i=0;i<this._deps.length;i++){let a=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:r,terminalDeps:s,store:this._store};if(this._hasCalledFnOnce=!0,this._clearWaveFlags(),this._inspectorHooks!=null){let i={kind:"run",batchData:t,prevData:r};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([[D,this._wrapFnError("fn threw",i)]])}finally{this._isExecutingFn=!1,this._pendingRerun?(this._pendingRerun=!1,this._rerunDepth+=1,this._rerunDepth>Bt?(this._rerunDepth=0,this._emit([[D,new Error(`Node "${this.name}": _pendingRerun depth exceeded ${Bt} \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 r=t instanceof Error?t.message:String(t);return new Error(`Node "${this.name}": ${e}: ${r}`,{cause:t})}_frameBatch(e){let t=this._config.tierOf;if(e.length===1)return t(e[0][0])===3&&this._status!=="dirty"?[Te,e[0]]:e;let r=!0,s=!1,o=!1,i=-1;for(let d of e){let c=t(d[0]);c<i&&(r=!1),c===3&&(s=!0),d[0]===U&&(o=!0),i=c}let a=e;if(!r){let d=e.map((c,u)=>({m:c,i:u,tier:t(c[0])}));d.sort((c,u)=>c.tier-u.tier||c.i-u.i),a=d.map(c=>c.m)}if(s&&!o&&this._status!=="dirty"){let d=0;for(;d<a.length&&t(a[d][0])===0;)d++;return d===0?[Te,...a]:[...a.slice(0,d),Te,...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&&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]===B||d[0]===ne);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],c=d[0];if(c!==se&&c!==ae){s?.push(d);continue}if(d.length<2)throw new Error(`Node "${this.name}": [[${c===se?"PAUSE":"RESUME"}]] must carry a lockId payload \u2014 bare PAUSE/RESUME is a protocol violation (C0 rule). Use \`[[PAUSE, lockId]]\` / \`[[RESUME, lockId]]\`.`);let u=!0;if(this._pausable!==!1){let p=d[1];if(c===se)this._pauseLocks==null&&(this._pauseLocks=new Set),this._pauseLocks.add(p),this._paused=!0,this._pausable==="resumeAll"&&this._pauseBuffer==null&&(this._pauseBuffer=[]);else if(this._pauseLocks==null||!this._pauseLocks.has(p))u=!1;else if(this._pauseLocks.delete(p),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())}}u?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]===B))for(let a of Object.keys(this.meta))try{this.meta[a]._emit(ut)}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 c of o)a(c[0])===3?this._pauseBuffer.push(c):d.push(c);d.length>0&&this._dispatchOrAccumulate(d)}else this._dispatchOrAccumulate(o);i!=null&&this._emit([[D,i]])}_updateState(e){let t=this._config.tierOf,r,s,o=-1,i=0;for(let u of e)t(u[0])===3&&i++;let a=i<=1,d=-1;if(this._versioning!=null&&i>1){for(let u=e.length-1;u>=0;u--)if(e[u][0]===$){d=u;break}}for(let u=0;u<e.length;u++){let p=e[u],h=p[0];if(h===$){if(p.length>=2){let g=!1;if(a&&this._cached!==void 0)try{g=this._equals(this._cached,p[1])}catch(l){s=this._wrapFnError("equals threw",l),o=u;break}if(g){r==null&&(r=e.slice(0,u)),r.push(at),this._status="resolved";continue}this._cached=p[1],this._versioning!=null&&(d<0||u===d)&&jt(this._versioning,p[1],this._hashFn)}this._status="settled",r?.push(p)}else if(r?.push(p),h===U)this._status="dirty";else if(h===te)this._status="resolved";else if(h===I){this._status="completed";{let g=this._config.rigorRecorder;if(g!=null)try{g.onTerminalTransition(this,"completed",this._autoComplete,this._autoError,this._deps.length>0)}catch{}}}else if(h===D){this._status="errored";{let g=this._config.rigorRecorder;if(g!=null)try{g.onTerminalTransition(this,"errored",this._autoComplete,this._autoError,this._deps.length>0)}catch{}}}else if(h===ne){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 g=this._cleanup;if(typeof g=="function"){this._cleanup=void 0;try{g()}catch{}}else if(g!=null&&typeof g=="object"){let l=g.invalidate;if(typeof l=="function")try{l()}catch{}}}else h===B&&(this._resetOnTeardown&&(this._cached=void 0),this._deactivate(!0),this._status="sentinel")}let c=o>=0?r??e.slice(0,o):r??e;return s!=null?{finalMessages:c,equalsError:s}:{finalMessages:c}}_deliverToSinks=e=>{if(this._sinks==null)return;if(typeof this._sinks=="function"){this._sinks(e);return}let t=[...this._sinks];for(let r of t)r(e)};_dispatchOrAccumulate(e){if(Dt()){this._batchPendingMessages===null&&(this._batchPendingMessages=[],_e(()=>this._flushBatchPending()));for(let t of e)this._batchPendingMessages.push(t);return}Ve(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);Ve(this._deliverToSinks,t,this._config.tierOf)}},Ht=n=>Array.isArray(n),mt=n=>typeof n=="object"&&n!=null&&!Array.isArray(n)});function re(n,e){return ge([],{...e,initial:n})}function oe(n,e){return ge((r,s,o)=>n(s,o)??void 0,{describeKind:"producer",...e})}function ce(n,e,t){return ge(n,(s,o,i)=>{let a=s.map((d,c)=>d!=null&&d.length>0?d.at(-1):i.prevData[c]);o.emit(e(a,i))},{describeKind:"derived",...t})}function xe(n,e,t){return ge(n,(s,o,i)=>{let a=s.map((d,c)=>d!=null&&d.length>0?d.at(-1):i.prevData[c]);return e(a,o,i)??void 0},{describeKind:"effect",...t})}var $e=F(()=>{"use strict";Oe()});function bt(n,e){if(e!=null&&e.length>0)return new Set(e);switch(n){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 Jn(n){return n._describeKind!=null?n._describeKind:n._deps.length>0?"derived":n._fn!=null?"producer":"state"}function Yn(n){let e={};for(let[t,r]of Object.entries(n.meta))try{e[t]=r.cache}catch{}return e}function yt(n,e,t){let r=e==null,s=!r&&e!=null?[...e].filter(u=>u.startsWith("meta.")).map(u=>u.slice(5)):null,o=r||e.has("meta")||s!=null&&s.length>0,i="state",a=[];n instanceof j&&(i=Jn(n),a=n._deps.map(u=>u.node.name??""));let d={type:i,deps:a};(r||e.has("status"))&&(d.status=n.status);let c=n instanceof j?n._guard:void 0;if(o){let u={...Yn(n)};if(c!=null&&u.access===void 0&&(u.access=lt(c)),s!=null&&s.length>0&&!e.has("meta")){let p={};for(let h of s)h in u&&(p[h]=u[h]);d.meta=p}else d.meta=u}if(n.name!=null&&(d.name=n.name),(r||e.has("value"))&&(!t||i==="state")){n.status==="sentinel"&&(d.sentinel=!0);try{d.value=n.cache}catch{}}if((r||e.has("v"))&&n.v!=null){let u={id:n.v.id,version:n.v.version};"cid"in n.v&&(u.cid=n.v.cid,u.prev=n.v.prev),d.v=u}return(r||e.has("guard"))&&c!=null&&(d.guard=lt(c)),(r||e.has("lastMutation"))&&n.lastMutation!=null&&(d.lastMutation=n.lastMutation),d}var Wt=F(()=>{"use strict";Ge();Oe()});function vt(n,e){if(Object.is(n,e))return!0;if(n==null||e==null||typeof n!="object"||typeof e!="object")return!1;if(Array.isArray(n)){if(!Array.isArray(e)||n.length!==e.length)return!1;for(let o=0;o<n.length;o++)if(!vt(n[o],e[o]))return!1;return!0}if(Array.isArray(e))return!1;let t=Object.keys(n),r=Object.keys(e);if(t.length!==r.length)return!1;let s=new Set(r);for(let o of t)if(!s.has(o)||!vt(n[o],e[o]))return!1;return!0}function Ut(n,e){return`${n}\0${e}`}function wt(n,e){let t=[],r=new Set(n.subgraphs),s=new Set(e.subgraphs),o=[];for(let b of s)r.has(b)||o.push(b);o.sort();for(let b of o)t.push({type:"subgraph-mounted",path:b});let i=new Set(Object.keys(n.nodes)),a=new Set(Object.keys(e.nodes)),d=[];for(let b of a)i.has(b)||d.push(b);d.sort();for(let b of d)t.push({type:"node-added",path:b,node:{...e.nodes[b]}});let c=[];for(let b of a){if(!i.has(b))continue;let _=n.nodes[b]?.meta,m=e.nodes[b]?.meta;_==null&&m==null||vt(_??{},m??{})||c.push(b)}c.sort();for(let b of c)t.push({type:"node-meta-changed",path:b,prevMeta:n.nodes[b]?.meta??{},nextMeta:e.nodes[b]?.meta??{}});let u=new Map;for(let b of n.edges)u.set(Ut(b.from,b.to),b);let p=new Map;for(let b of e.edges)p.set(Ut(b.from,b.to),b);let h=[];for(let[b,_]of p)u.has(b)||h.push(_);h.sort((b,_)=>b.from<_.from?-1:b.from>_.from?1:b.to<_.to?-1:b.to>_.to?1:0);for(let b of h)t.push({type:"edge-added",from:b.from,to:b.to});let g=[];for(let[b,_]of u)p.has(b)||g.push(_);g.sort((b,_)=>b.from<_.from?-1:b.from>_.from?1:b.to<_.to?-1:b.to>_.to?1:0);for(let b of g)t.push({type:"edge-removed",from:b.from,to:b.to});let l=[];for(let b of i)a.has(b)||l.push(b);l.sort();for(let b of l)t.push({type:"node-removed",path:b});let v=[];for(let b of r)s.has(b)||v.push(b);v.sort();for(let b of v)t.push({type:"subgraph-unmounted",path:b});return{events:t,flushedAt_ns:ie()}}var qt=F(()=>{"use strict";He()});function _t(n){return{describeKind:"producer",...n}}function Kt(n,e){return oe(t=>{let r=!1;try{for(let s of n){if(r)return;t.emit(s)}r||t.down([[I]])}catch(s){r||t.down([[D,s]])}return()=>{r=!0}},_t(e))}function Xn(n){return n!=null&&typeof n.then=="function"}function Zn(n,e){let{signal:t,...r}=e??{};return oe(s=>{let o=!1,i=()=>{o||(o=!0,s.down([[D,t.reason]]))};if(t?.aborted){i();return}return t?.addEventListener("abort",i,{once:!0}),Promise.resolve(n).then(a=>{o||(o=!0,t?.removeEventListener("abort",i),s.emit(a),s.down([[I]]))},a=>{o||(o=!0,t?.removeEventListener("abort",i),s.down([[D,a]]))}),()=>{o=!0,t?.removeEventListener("abort",i)}},_t(r))}function Qn(n,e){let{signal:t,...r}=e??{};return oe(s=>{let o=new AbortController,i=()=>o.abort(t?.reason);t?.aborted?o.abort(t.reason):t?.addEventListener("abort",i,{once:!0});let a=t??o.signal,d=!1,c=n[Symbol.asyncIterator](),u=()=>{d||a.aborted||Promise.resolve(c.next()).then(p=>{if(!(d||a.aborted)){if(p.done){s.down([[I]]);return}s.emit(p.value),u()}},p=>{!d&&!a.aborted&&s.down([[D,p]])})};return u(),()=>{d=!0,t?.removeEventListener("abort",i),o.abort(),Promise.resolve(c.return?.()).catch(()=>{})}},_t(r))}function er(n){return n!=null&&typeof n=="object"&&"cache"in n&&typeof n.subscribe=="function"}function Jt(n,e){if(er(n))return n;if(Xn(n))return Zn(n,e);if(n!=null){let t=n;if(typeof t[Symbol.asyncIterator]=="function")return Qn(n,e);if(typeof t[Symbol.iterator]=="function")return Kt(n,e)}return tr(n)}function tr(...n){return Kt(n,void 0)}function Se(n){return n.subscribe(()=>{})}var Yt=F(()=>{"use strict";he();$e()});var kt=F(()=>{"use strict";Yt()});var qe,Xt=F(()=>{"use strict";qe=class{_timer;_gen=0;start(e,t){this.cancel(),this._gen+=1;let r=this._gen;this._timer=setTimeout(()=>{this._timer=void 0,r===this._gen&&t()},e)}cancel(){this._timer!==void 0&&(clearTimeout(this._timer),this._timer=void 0)}get pending(){return this._timer!==void 0}}});var Fe,Zt=F(()=>{"use strict";Fe=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}}});function Qt(n,e,t,r={}){let s=e in n.nodes,o=t in n.nodes;if(!s)return Ke(e,t,"no-such-from");if(!o)return Ke(e,t,"no-such-to");let i=r.maxDepth;if(i!=null&&(!Number.isInteger(i)||i<0))throw new Error("explainPath: maxDepth must be an integer >= 0");if(e===t){if(r.findCycle===!0){let c=nr(n,e,r);if(c!=null)return c}let d=Je(e,n.nodes[e],0,r);return Ye(e,t,[d])}if(i===0)return Ke(e,t,"no-path");let a=en(n,e,t,i);return a.found?Ye(e,t,tn(n,a.pathOrder,r)):Ke(e,t,a.truncated?"max-depth-exceeded":"no-path")}function en(n,e,t,r){let s=new Map,o=[{path:t,depth:0}],i=new Set([t]),a=0,d=!1;for(;a<o.length;){let p=o[a++];if(p.path===e)break;if(r!=null&&p.depth>=r){let v=n.nodes[p.path];v?.deps&&v.deps.length>0&&(d=!0);continue}let h=n.nodes[p.path];if(h==null)continue;let g=h.deps??[],l=new Map;for(let v=0;v<g.length;v++){let b=g[v];if(!b)continue;let _=l.get(b);_==null&&(_=[],l.set(b,_)),_.push(v)}for(let[v,b]of l)i.has(v)||(i.add(v),s.set(v,{from:p.path,depIndices:b}),o.push({path:v,depth:p.depth+1}))}if(!s.has(e))return{found:!1,pathOrder:[],truncated:d};let c=[{path:e}],u=e;for(;u!==t;){let p=s.get(u);if(p==null)return{found:!1,pathOrder:[],truncated:!1};c[c.length-1].depIndices=p.depIndices,c.push({path:p.from}),u=p.from}return{found:!0,pathOrder:c,truncated:!1}}function nr(n,e,t){let r=n.nodes[e];if(r==null)return null;let s=r.deps??[],o=[];for(let a=0;a<s.length;a++)s[a]===e&&o.push(a);if(o.length>0){let a=Je(e,r,0,t);a.dep_index=o[0];let d=Je(e,r,1,t);return Ye(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 c=en(n,d,e,t.maxDepth);c.found&&(i==null||c.pathOrder.length<i.pathOrder.length)&&(i=c,i={found:!0,pathOrder:[{path:e,depIndices:[a]},...c.pathOrder],truncated:!1})}return i==null?null:Ye(e,e,tn(n,i.pathOrder,t))}function tn(n,e,t){return e.map((r,s)=>{let o=n.nodes[r.path],i=Je(r.path,o,s,t);return r.depIndices!=null&&r.depIndices.length>0&&(i.dep_index=r.depIndices[0],r.depIndices.length>1&&(i.dep_indices=[...r.depIndices])),i})}function Je(n,e,t,r){let s={path:n,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=r.annotations?.get(n)??e.annotation;o!=null&&(s.annotation=o);let i=r.lastMutations?.get(n)??e.lastMutation;return i!=null&&(s.lastMutation=i),s}function Ye(n,e,t){return nn(n,e,!0,"ok",t)}function Ke(n,e,t){return nn(n,e,!1,t,[])}function nn(n,e,t,r,s){let o=rr(n,e,t,r,s);return{from:n,to:e,found:t,reason:r,steps:s,text:o,toJSON(){return{from:n,to:e,found:t,reason:r,steps:s}}}}function rr(n,e,t,r,s){if(!t)switch(r){case"no-such-from":return`explainPath: no node named "${n}"`;case"no-such-to":return`explainPath: no node named "${e}"`;case"max-depth-exceeded":return`explainPath: no path from "${n}" to "${e}" within maxDepth`;default:return`explainPath: no path from "${n}" to "${e}"`}let o=[`Causal path: ${n} \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: ${sr(i.value)}`),i.annotation!=null&&o.push(` annotation: ${i.annotation}`),i.lastMutation!=null){let c=i.lastMutation.actor;o.push(` actor: ${c.type}${c.id?`:${c.id}`:""}`)}}return o.join(`
2
+ `)}function sr(n){if(n===void 0)return"<sentinel>";if(n===null)return"null";if(typeof n=="string")return JSON.stringify(n);if(typeof n=="number"||typeof n=="boolean"||typeof n=="bigint")return String(n);try{let e=JSON.stringify(n);return e.length>80?`${e.slice(0,77)}...`:e}catch{return String(n)}}var rn=F(()=>{"use strict"});function sn(n){let e=new WeakSet,t=new WeakSet,r=[n],s=0;for(;r.length>0;){let o=r.pop();s+=ir(o,e,t,r)}return s}function ir(n,e,t,r){if(n==null)return 0;switch(typeof n){case"number":return L.number;case"boolean":return L.boolean;case"string":return L.string+n.length*2;case"bigint":return L.bigint+ar(n);case"symbol":return L.symbol;case"function":return e.has(n)?0:(e.add(n),L.function);case"undefined":return 0}let o=n;if(e.has(o))return 0;e.add(o);let i=o[or];if(typeof i=="function")try{let c=i.call(o);if(typeof c=="number"&&Number.isFinite(c))return c}catch{}if(o instanceof Date)return L.date;if(o instanceof RegExp)return L.regexp+o.source.length*2;if(o instanceof Error){let c=o.message?o.message.length*2:0,u=o.stack?o.stack.length*2:0;return L.error+c+u}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 c=L.map;for(let[u,p]of o)c+=L.mapEntry,r.push(u),r.push(p);return c}if(o instanceof Set){let c=L.set;for(let u of o)c+=L.setEntry,r.push(u);return c}if(Array.isArray(o)){let c=L.array+o.length*8;for(let u of o)r.push(u);return c}if(o instanceof ArrayBuffer)return t.has(o)?0:(t.add(o),o.byteLength);if(ArrayBuffer.isView(o)){let c=o;return t.has(c.buffer)?48:(t.add(c.buffer),c.buffer.byteLength+48)}let a=L.object,d=Object.keys(o);for(let c of d){a+=L.string+c.length*2;try{r.push(o[c])}catch{}}return a}function ar(n){let e=n<0n?-n:n;if(e===0n)return 0;let t=e.toString(2).length;return Math.ceil(t/32)*8}var L,or,on=F(()=>{"use strict";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},or=Symbol.for("sizeof")});function an(n,e){let t=e?.topN??10,r=n.describe({detail:"standard"}),s=[],o=n._collectObserveTargets;typeof o=="function"&&o.call(n,"",s);let i=new Map;for(let[h,g]of s)i.set(h,g);let a=[];for(let[h,g]of Object.entries(r.nodes)){let l=i.get(h),v=l instanceof j?l:null,b=v?sn(v.cache):0,_=v?v._sinkCount:0,m=g.deps?.length??0,f=g.type==="effect"&&_===0,y=_===0?g.type==="effect"?"orphan-effect":g.type==="derived"?"idle-derived":g.type==="producer"?"idle-producer":null:null;a.push({path:h,type:g.type,status:g.status??"unknown",valueSizeBytes:b,subscriberCount:_,depCount:m,isOrphanEffect:f,orphanKind:y})}let d=a.reduce((h,g)=>h+g.valueSizeBytes,0),c=(h,g)=>[...a].sort(g??((l,v)=>v[h]-l[h])).slice(0,t),u=a.filter(h=>h.orphanKind!=null),p=a.filter(h=>h.isOrphanEffect);return{nodeCount:a.length,edgeCount:r.edges.length,subgraphCount:r.subgraphs.length,nodes:a,totalValueSizeBytes:d,hotspots:{byValueSize:c("valueSizeBytes"),bySubscriberCount:c("subscriberCount"),byDepCount:c("depCount")},orphans:u,orphanEffects:p}}var cn=F(()=>{"use strict";Oe();on()});function Xe(n,e){let t=Math.max(16,n.size*4),r=0;for(;n.size>0;){if(r++>=t){console.error(`[Graph "${e}".destroy] disposer drain exceeded cap (${t}); ${n.size} disposer(s) discarded`),n.clear();return}let s=n.values().next();if(s.done)return;let o=s.value;n.delete(o);try{o()}catch(i){console.error(`[Graph "${e}".destroy] disposer threw:`,i)}}}function hn(n){return n!=null&&typeof n=="object"&&"cache"in n&&typeof n.subscribe=="function"&&typeof n.down=="function"}function cr(n){if(n!=null)return hn(n)?n.cache:n}function me(n){return n!=null&&typeof n=="object"&&"cache"in n&&typeof n.subscribe=="function"&&typeof n.down=="function"}function de(n){return me(n)?n.cache??"":n}function dn(n){return me(n)?n.cache??0:n}function un(n){return me(n)?n.cache??!1:n}function dr(n){let e=[];for(let t of Object.keys(n).sort()){let r=n[t].v;r!=null&&e.push(`${t} ${r.id} ${r.version}`)}return e.join(`
3
+ `)}function ln(n){if(n.version!==Re)throw new Error(`unsupported snapshot version ${String(n.version)} (expected ${Re})`);for(let e of["name","nodes","edges","subgraphs"])if(!(e in n))throw new Error(`snapshot missing required key "${e}"`);if(typeof n.name!="string")throw new TypeError("snapshot 'name' must be a string");if(typeof n.nodes!="object"||n.nodes===null||Array.isArray(n.nodes))throw new TypeError("snapshot 'nodes' must be an object");if(!Array.isArray(n.edges))throw new TypeError("snapshot 'edges' must be an array");if(!Array.isArray(n.subgraphs))throw new TypeError("snapshot 'subgraphs' must be an array")}function ur(n,e){let t=new WeakMap,r=(s,o)=>{if(Object.is(s,o))return!0;if(s==null||o==null||typeof s!="object"||typeof o!="object")return!1;let i=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 g=0;g<s.length;g++)if(!r(s[g],h[g]))return!1;return!0}if(s instanceof Map){let h=o;if(s.size!==h.size)return!1;for(let[g,l]of s)if(!h.has(g)||!r(l,h.get(g)))return!1;return!0}if(s instanceof Set){let h=o;if(s.size!==h.size)return!1;for(let g of s){let l=!1;for(let v of h)if(r(g,v)){l=!0;break}if(!l)return!1}return!0}if(ArrayBuffer.isView(s)){let h=s,g=o;if(h.length!==g.length)return!1;for(let l=0;l<h.length;l++)if(h[l]!==g[l])return!1;return!0}let c=Object.keys(s),u=Object.keys(o);if(c.length!==u.length)return!1;let p=new Set(u);for(let h of c)if(!p.has(h)||!r(s[h],o[h]))return!1;return!0};return r(n,e)}function lr(n){return n.replace(/[.*+?^${}()|[\]\\]/g,"\\$&")}function Ze(n){let e="^";for(let t=0;t<n.length;t+=1){let r=n[t];if(r==="*"){e+=".*";continue}if(r==="?"){e+=".";continue}if(r==="["){let s=n.indexOf("]",t+1);if(s<=t+1){e+="\\[";continue}let o=n.slice(t+1,s);o.startsWith("!")&&(o=`^${o.slice(1)}`),o=o.replace(/\\/g,"\\\\"),e+=`[${o}]`,t=s;continue}e+=lr(r)}return e+="$",new RegExp(e)}function Tt(n){if(typeof n=="string")return JSON.stringify(n);if(typeof n=="number"||typeof n=="boolean"||n==null)return String(n);try{return JSON.stringify(n)}catch{return"[unserializable]"}}function hr(n){return n==="none"?pr:n==="ansi"||n==null?fr:{data:n.data??"",dirty:n.dirty??"",resolved:n.resolved??"",invalidate:n.invalidate??"",pause:n.pause??"",resume:n.resume??"",complete:n.complete??"",error:n.error??"",teardown:n.teardown??"",derived:n.derived??"",path:n.path??"",reset:n.reset??""}}function fn(n){if(n==null)return{};let e=n.detail;return e==="full"?{...n,structured:n.structured??!0,timeline:n.timeline??!0,causal:n.causal??!0,derived:n.derived??!0}:e==="minimal"?{...n,structured:n.structured??!0}:n.format==="stage-log"?{...n,structured:n.structured??!0,timeline:n.timeline??!0}:n}function gr(n,e,t){for(let r=0;r<n.length;r++){let s=n.charCodeAt(r);if(s<32||s===127)throw new Error(`Graph "${e}": ${t} "${n}" must not contain control character (U+${s.toString(16).padStart(4,"0").toUpperCase()} at index ${r})`)}}function Nt(n,e,t){if(n==="")throw new Error(`Graph "${e}": ${t} name must be non-empty`);if(n.includes(G))throw new Error(`Graph "${e}": ${t} "${n}" must not contain '${G}' (path separator)`);if(n===q)throw new Error(`Graph "${e}": ${t} name "${q}" is reserved for meta companion paths`);gr(n,e,t)}function mr(n,e){if(n==="")throw new Error(`Graph "${e}": resolve path must be non-empty`);let t=n.split(G);for(let r of t)if(r==="")throw new Error(`Graph "${e}": resolve path has empty segment`);return t}function br(n,e){let t=!1;for(let s of n)if(!e.isMetaPassthrough(s[0])){t=!0;break}return t?n.filter(s=>e.isMetaPassthrough(s[0])):n}function gn(n){for(let e of n._mounts.values())gn(e);for(let e of n._nodes.values())try{e.down([[B]],{internal:!0})}catch{}}function yr(n,e){let t=Ee.diff(n,e),r={};for(let s of t.nodesAdded){let o=e.nodes[s];o!=null&&(r[s]=o)}return{...t,nodesAddedFull:r}}function pn(n,e,t,r={}){let s={paths:[],depths:new Map,truncated:!1};if(!e)return r.withDetail?s:[];if(!r.both&&t!=="upstream"&&t!=="downstream")throw new Error('reachable: direction must be "upstream" or "downstream"');let o=r.maxDepth;if(o!=null&&(!Number.isInteger(o)||o<0))throw new Error("reachable: maxDepth must be an integer >= 0");if(o===0)return r.withDetail?s:[];let i=new Map,a=new Map,d=new Map,c=new Map,u=new Set;for(let[f,y]of Object.entries(n.nodes)){if(!f)continue;u.add(f);let w=y.deps??[];i.set(f,w);for(let k of w)k&&(u.add(k),a.has(k)||a.set(k,new Set),a.get(k).add(f))}for(let f of n.edges){if(f==null||typeof f!="object")continue;let y=typeof f.from=="string"?f.from:"",w=typeof f.to=="string"?f.to:"";!y||!w||(u.add(y),u.add(w),c.has(y)||c.set(y,new Set),c.get(y).add(w),d.has(w)||d.set(w,new Set),d.get(w).add(y))}if(!u.has(e))return r.withDetail?s:[];let p=r.both===!0,h=f=>{if(p){let N=i.get(f)??[],O=d.get(f),R=a.get(f),S=c.get(f),T=[...N];return O&&T.push(...O),R&&T.push(...R),S&&T.push(...S),T}if(t==="upstream"){let N=i.get(f)??[],O=d.get(f);return O?[...N,...O]:N}let y=a.get(f),w=c.get(f),k=y?[...y]:[];return w&&k.push(...w),k},g=new Set([e]),l=new Map,v=[{path:e,depth:0}],b=0,_=!1;for(;b<v.length;){let f=v[b++];if(o!=null&&f.depth>=o){h(f.path).length>0&&(_=!0);continue}for(let y of h(f.path))!y||g.has(y)||(g.add(y),l.set(y,f.depth+1),v.push({path:y,depth:f.depth+1}))}let m=[...l.keys()].sort((f,y)=>f<y?-1:f>y?1:0);return r.withDetail?{paths:m,depths:l,truncated:_}:m}function vr(n,e){if(n.length!==e.length)return!1;for(let t=0;t<n.length;t++){let r=n[t],s=e[t];if(r.path!==s.path||r.type!==s.type||r.status!==s.status||r.hop!==s.hop||r.dep_index!==s.dep_index||r.annotation!==s.annotation||r.value!==s.value||r.lastMutation!==s.lastMutation)return!1;let o=r.v,i=s.v;if(o!==i&&(o==null||i==null||o.id!==i.id||o.version!==i.version))return!1}return!0}var G,q,Re,fr,pr,Ee,mn=F(()=>{"use strict";it();Be();He();Ge();he();Wt();Oe();$e();qt();kt();Xt();Zt();ot();rn();cn();G="::",q="__meta__",Re=1;fr={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"},pr={data:"",dirty:"",resolved:"",invalidate:"",pause:"",resume:"",complete:"",error:"",teardown:"",derived:"",path:"",reset:""};Ee=class n{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(G))throw new Error(`Graph name must not contain '${G}' (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??Ne,this._traceRing=new Fe(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=[],r=e?this:this._parent;for(;r!=null;)t.push(r),r=r._parent;return t}get topology(){return this._topology==null&&(this._topology=oe(e=>{let t=r=>{e.emit(r)};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 r=e.name,s=t?.name??r;if(s==null||s==="")throw new Error(`Graph "${this.name}": graph.add requires a non-empty name \u2014 pass via opts.name or set it on the node (e.g. state(0, { name: "x" }))`);let o=s,i=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:ie()})),e}setVersioning(e){if(e!=null)for(let t of this._nodes.values())t instanceof j&&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(`${G}${q}${G}`)||o.nodes.push(a);return o.nodes.sort(),o.mounts.push(e),o.mounts.push(...t._collectSubgraphs(`${e}${G}`)),this._mounts.delete(e),t._parent=void 0,gn(t),this._emitTopology({kind:"removed",name:e,nodeKind:"mount",audit:o}),o}let r=this._nodes.get(e);if(!r)throw new Error(`Graph "${this.name}": unknown node or mount "${e}"`);this._nodes.delete(e),this._nodeToName.delete(r),r.down([[B]],{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)})(),r={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);r.nodes.push(...i.nodes),r.mounts.push(...i.mounts)}return r.nodes.sort(),r.mounts.sort(),r}[Symbol.iterator](){let e=[...this._nodes.keys()].sort(),t=this._nodes,r=0;return{[Symbol.iterator](){return this},next(){if(r>=e.length)return{value:void 0,done:!0};let s=e[r++];return{value:[s,t.get(s)],done:!1}}}}node(e){if(e==="")throw new Error(`Graph "${this.name}": node name must be non-empty`);if(e.includes(G))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,r){let s=r?.internal===!0;this.node(e).down([[$,t]],{actor:r?.actor,internal:s,delivery:"write"})}setAll(e,t){let r=Symbol.iterator in e?e:Object.entries(e);Me(()=>{for(let[s,o]of r)this.set(s,o,t)})}invalidate(e,t){let r=t?.internal===!0;this.node(e).down([[ne]],{actor:t?.actor,internal:r,delivery:"write"})}error(e,t,r){let s=r?.internal===!0;this.node(e).down([[D,t]],{actor:r?.actor,internal:s,delivery:"write"})}complete(e,t){let r=t?.internal===!0;this.node(e).down([[I]],{actor:t?.actor,internal:r,delivery:"write"})}_registerSelfPruningKeepalive(e){let t,r,s=()=>{t?.(),t=void 0,r?.(),r=void 0};t=e.subscribe(o=>{for(let i of o){let a=i[0];if(a===B||a===I||a===D){s();return}}}),r=this.addDisposer(s)}_wireSignalToRemove(e,t){if(t==null)return;let r=()=>{try{this.remove(e)}catch{}};if(t.aborted){r();return}t.addEventListener("abort",r,{once:!0}),this.addDisposer(()=>t.removeEventListener("abort",r))}derived(e,t,r,s){let o=t.map(g=>this.resolve(g)),{keepAlive:i,annotation:a,equals:d,initial:c,meta:u,signal:p}=s??{},h=ce(o,r,{name:e,...d!=null?{equals:d}:{},...c!==void 0?{initial:c}:{},...u!=null?{meta:u}:{}});return this.add(h,{name:e,...a!=null?{annotation:a}:{}}),i===!0&&this._registerSelfPruningKeepalive(h),this._wireSignalToRemove(e,p),h}effect(e,t,r,s){let o=t.map(u=>this.resolve(u)),{annotation:i,meta:a,signal:d}=s??{},c=xe(o,r,{name:e,...a!=null?{meta:a}:{}});return this.add(c,{name:e,...i!=null?{annotation:i}:{}}),this._wireSignalToRemove(e,d),c}produce(e,t,r){if(t===void 0)throw new Error(`Graph "${this.name}".produce("${e}", \u2026): source must not be \`undefined\` \u2014 undefined is the global SENTINEL (spec \xA71.1). Pass \`null\` for nullary DATA, or a Promise/AsyncIterable/Iterable for async sources.`);if(t!==null&&typeof t=="object"&&"cache"in t&&typeof t.subscribe=="function")throw new Error(`Graph "${this.name}".produce("${e}", \u2026): Node sources are rejected. For Node\u2192Node, use graph.derived(name, [path], ([v]) => v, { keepAlive: true }) \u2014 fromAny passes Nodes through verbatim and silently drops opts.`);let{annotation:s,meta:o,equals:i,signal:a}=r??{},d=Jt(t,{name:e,...o!=null?{meta:o}:{},...i!=null?{equals:i}:{},...a!=null?{signal:a}:{}});return this.add(d,{name:e,...s!=null?{annotation:s}:{}}),this._wireSignalToRemove(e,a),d}batch(e){Me(e)}edges(e){let t=e?.recursive===!0,r=new Map;if(!t){for(let[d,c]of this._nodes)r.set(c,d);let a=[];for(let[d,c]of this._nodes)if(c instanceof j)for(let u of c._deps){let p=r.get(u.node);p!=null&&a.push([p,d])}return a.sort((d,c)=>d[0]<c[0]?-1:d[0]>c[0]?1:d[1]<c[1]?-1:d[1]>c[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 j)for(let c of d._deps){let u=o.get(c.node);u!=null&&i.push([u,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 n(e);return this.mount(e,s)}if(typeof t=="function"){let s=new n(e);return t(s),this.mount(e,s)}let r=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(r===this)throw new Error(`Graph "${this.name}": cannot mount a graph into itself`);if(r._parent!=null)throw new Error(`Graph "${this.name}": this child graph is already mounted on "${r._parent.name}"`);for(let s=this;s!=null;s=s._parent)if(s===r)throw new Error(`Graph "${this.name}": mount("${e}", \u2026) would create a mount cycle`);return this._mounts.set(e,r),r._parent=this,this._emitTopology({kind:"added",name:e,nodeKind:"mount"}),r}resolve(e){let t=mr(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 r=t[0],s=t.slice(1);if(s.length===0){let a=this._nodes.get(r);if(a)return a;throw this._mounts.has(r)?new Error(`Graph "${this.name}": path ends at subgraph "${r}" \u2014 not a node (GRAPHREFLY-SPEC \xA73.5)`):new Error(`Graph "${this.name}": unknown name "${r}"`)}let o=this._nodes.get(r);if(o&&s.length>0&&s[0]===q)return this._resolveMetaChainFromNode(o,s,t.join(G));let i=this._mounts.get(r);if(!i)throw this._nodes.has(r)?new Error(`Graph "${this.name}": "${r}" is a node; trailing path "${s.join(G)}" is invalid`):new Error(`Graph "${this.name}": unknown mount or node "${r}"`);return i.resolve(s.join(G))}_resolveMetaChainFromNode(e,t,r){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 "${r}"`);if(o+1>=i.length)throw new Error(`Graph "${this.name}": meta path requires a key after ${q} in "${r}"`);let a=i[o+1],d=s.meta[a];if(!d)throw new Error(`Graph "${this.name}": unknown meta "${a}" in path "${r}"`);s=d,o+=2}return s}signal(e,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 r=[];if(this._signalDeliver(e,t??{},new Set,r),r.length>0)throw r[0]}_signalDeliver(e,t,r,s){for(let d of this._mounts.values())d._signalDeliver(e,t,r,s);let i=t.internal===!0?{internal:!0}:{actor:t.actor,delivery:"signal"},a=br(e,this.config);for(let d of[...this._nodes.keys()].sort()){let c=this._nodes.get(d);if(!r.has(c)){r.add(c);try{c.down(e,i)}catch(u){if(u instanceof Z)throw u;s.push(u)}a.length!==0&&this._signalMetaSubtree(c,a,r,i,s)}}}_signalMetaSubtree(e,t,r,s,o){for(let i of Object.keys(e.meta).sort()){let a=e.meta[i];if(!r.has(a)){r.add(a);try{a.down(t,s)}catch(d){if(d instanceof Z)throw d;o.push(d)}this._signalMetaSubtree(a,t,r,s,o)}}}describe(e){if(e?.reactive==="diff")return this._describeReactiveDiff(e);if(e?.reactive===!0)return this._describeReactive(e);let t=cr(e?.actor),r=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=bt(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 c=[];{let y=a.map(([,N])=>N),w=new Set(d.values()),k=0;for(;y.length>0;){let N=y.shift();if(N instanceof j)for(let O of N._deps){let R=O.node;if(d.has(R))continue;let S=R.name??"",T=S;if(!T||w.has(T))if(S){let P=2;for(;w.has(`${S}#${P}`);)P++;T=`${S}#${P}`}else for(T=`__internal__/${k++}`;w.has(T);)T=`__internal__/${k++}`;d.set(R,T),w.add(T),c.push([T,R]),y.push(R)}}}let u=[...a,...c],p={};for(let[y,w]of u){if(t!=null&&!w.allowsObserve(t))continue;let k=yt(w,i,o),N=w instanceof j?w._deps.map(T=>d.get(T.node)??T.node.name??""):[],{name:O,...R}=k,S={...R,deps:N};if(!o){let T=this._annotations.get(y);T!=null&&(S.annotation=T)}if(r!=null)if(typeof r=="function"){let T=r;if(!(T.length>=2?T(y,S):T(S)))continue}else{let T=!0;for(let[P,E]of Object.entries(r)){let A=P==="deps_includes"?"depsIncludes":P==="meta_has"?"metaHas":P;if(A==="depsIncludes"){if(!S.deps.includes(String(E))){T=!1;break}continue}if(A==="metaHas"){if(!Object.hasOwn(S.meta??{},String(E))){T=!1;break}continue}if(S[A]!==E){T=!1;break}}if(!T)continue}p[y]=S}let h=new Set(Object.keys(p)),g=[];for(let[y,w]of u)if(w instanceof j)for(let k of w._deps){let N=d.get(k.node);N!=null&&g.push([N,y])}g.sort((y,w)=>y[0]<w[0]?-1:y[0]>w[0]?1:y[1]<w[1]?-1:y[1]>w[1]?1:0);let l=g.map(([y,w])=>({from:y,to:w}));(t!=null||r!=null)&&(l=l.filter(y=>h.has(y.from)&&h.has(y.to)));let v=this._collectSubgraphs(""),b=t!=null||r!=null?v.filter(y=>{let w=`${y}${G}`;return[...h].some(k=>k===y||k.startsWith(w))}):v,_=this,m=e;return{name:this.name,nodes:p,edges:l,subgraphs:b,...this._factory!==void 0?{factory:this._factory}:{},...this._factoryArgs!==void 0?{factoryArgs:this._factoryArgs}:{},expand(y){let w={...m};return Array.isArray(y)?(w.fields=y,w.detail=void 0):(w.detail=y,w.fields=void 0),_.describe(w)}}}_collectSubgraphs(e){let t=[];for(let r of[...this._mounts.keys()].sort()){let s=e===""?r:`${e}${r}`;t.push(s),t.push(...this._mounts.get(r)._collectSubgraphs(`${s}${G}`))}return t}resourceProfile(e){return an(this,e)}reachable(e,t,r={}){return r.withDetail===!0?pn(this.describe(),e,t,{...r,withDetail:!0}):pn(this.describe(),e,t,r)}explain(e,t,r){return r?.reactive===!0?this._explainReactive(e,t,r):this._explainStatic(de(e),de(t),{...r?.maxDepth!==void 0?{maxDepth:dn(r.maxDepth)}:{},...r?.findCycle!==void 0?{findCycle:un(r.findCycle)}:{}})}_explainStatic(e,t,r){let s=this.describe({detail:"full"}),o=new Map(this._annotations),i=new Map;for(let[a,d]of Object.entries(s.nodes))d.lastMutation!=null&&i.set(a,d.lastMutation);return Qt(s,e,t,{...r?.maxDepth!=null?{maxDepth:r.maxDepth}:{},...r?.findCycle===!0?{findCycle:!0}:{},annotations:o,lastMutations:i})}_describeReactive(e){let t={...e,reactive:!1},r=e.reactiveName??"describe",s=0,o=re(s,{name:`${r}_version`}),i=this.observe({timeline:!0,structured:!0}),a=!1,d=!1,c=()=>{a||d||(a=!0,_e(()=>{a=!1,!d&&(s+=1,o.emit(s))}))},u=i.onEvent(m=>{let f=m.type;f!=="data"&&f!=="error"&&f!=="complete"&&f!=="teardown"||c()}),p=[],h=new WeakSet,g=m=>{if(h.has(m)||d)return;h.add(m);let f=m.topology.subscribe(y=>{for(let w of y){if(w[0]!==$)continue;let k=w[1];if(c(),k.kind==="added"&&k.nodeKind==="mount"){let N=m._mounts.get(k.name);N!=null&&g(N)}}});p.push(f);for(let y of m._mounts.keys()){let w=m._mounts.get(y);w!=null&&g(w)}};g(this);let l,v=e.actor;hn(v)&&(l=v.subscribe(m=>{let f=!1,y=!1;for(let w of m){let k=w[0];k===$?f=!0:(k===I||k===D||k===B)&&(y=!0)}f&&c(),y&&(l?.(),l=void 0,c())}));let b;try{b=ce([o],()=>this.describe(t),{name:r,describeKind:"derived",meta:{domain:"audit",kind:"describe"},equals:(m,f)=>m===f})}catch(m){u(),l?.();for(let f of p)f();throw i.dispose(),m}let _=Se(b);return{node:b,dispose(){d=!0,u(),l?.();for(let m of p)m();p.length=0,i.dispose(),_()}}}_describeReactiveDiff(e){let t={...e,reactive:!1},r=e.reactiveName??"describe-diff",s={name:this.name,nodes:{},edges:[],subgraphs:[]},o=this.describe(t),i=wt(s,o),a=re(i,{name:r,meta:{domain:"audit",kind:"describe-diff"},equals:(h,g)=>h===g}),d=this._describeReactive({...e,reactiveName:void 0}),c=!1,u=d.node.subscribe(h=>{if(!c)for(let g of h){if(g[0]!==$)continue;let l=g[1],v=wt(o,l);o=l,v.events.length!==0&&a.emit(v)}}),p=Se(a);return{node:a,dispose(){c=!0,u(),d.dispose(),a.down([[B,"describe-diff disposed"]]),p()}}}_explainReactive(e,t,r){let s=0,o=re(s,{name:"explain_version"}),i=this.observe({timeline:!0,structured:!0}),a=!1,d=!1,c=()=>{a||d||(a=!0,_e(()=>{a=!1,!d&&(s+=1,o.emit(s))}))},u=i.onEvent(m=>{let f=m.type;f!=="data"&&f!=="error"&&f!=="complete"&&f!=="teardown"||c()}),p=[];e!=null&&me(e)&&p.push(e),t!=null&&me(t)&&p.push(t),r?.maxDepth!=null&&me(r.maxDepth)&&p.push(r.maxDepth),r?.findCycle!=null&&me(r.findCycle)&&p.push(r.findCycle);let h=()=>{for(let m of p)if(m.cache===void 0)return!1;return!0},g=()=>{let m=de(e),f=de(t);return{from:m,to:f,found:!1,reason:"pending",steps:[],text:"(awaiting reactive args)",toJSON:()=>({from:m,to:f,found:!1,reason:"pending",steps:[]})}},l;try{l=ce([o],()=>{if(!h())return g();let m=de(e),f=de(t),y={...r?.maxDepth!==void 0?{maxDepth:dn(r.maxDepth)}:{},...r?.findCycle!==void 0?{findCycle:un(r.findCycle)}:{}};return this._explainStatic(m,f,y)},{name:r?.name??"explain",describeKind:"derived",meta:{domain:"audit",kind:"explain_path",from:de(e),to:de(t)},equals:(m,f)=>m.found===f.found&&m.reason===f.reason&&m.steps.length===f.steps.length&&vr(m.steps,f.steps)})}catch(m){throw u(),i.dispose(),m}let v=Se(l),b=[],_=m=>{let f;return f=m.subscribe(y=>{let w=!1,k=!1;for(let N of y){let O=N[0];O===$?w=!0:(O===I||O===D||O===B)&&(k=!0)}(w||k)&&c(),k&&f&&(f(),f=void 0)}),()=>{f&&(f(),f=void 0)}};for(let m of p)b.push(_(m));return{node:l,dispose(){d=!0,u();for(let m of b)m?.();b.length=0,i.dispose(),v()}}}_pathsMatching(e){let t=Ze(e),r=[];return this._collectObserveTargets("",r),r.map(([s])=>s).filter(s=>t.test(s))}_collectObserveTargets(e,t){for(let r of[...this._mounts.keys()].sort()){let s=e===""?r:`${e}${G}${r}`;this._mounts.get(r)._collectObserveTargets(s,t)}for(let r of[...this._nodes.keys()].sort()){let s=this._nodes.get(r),o=e===""?r:`${e}${G}${r}`;t.push([o,s]),this._appendMetaObserveTargets(o,s,t)}}_appendMetaObserveTargets(e,t,r){for(let s of Object.keys(t.meta).sort()){let o=t.meta[s],i=`${e}${G}${q}${G}${s}`;r.push([i,o]),this._appendMetaObserveTargets(i,o,r)}}observe(e,t){let r=typeof e=="string",o=fn(r?t:e);if(o.reactive===!0)return this._observeReactive(r?e:void 0,o);let i=o.structured===!0||o.timeline===!0||o.causal===!0||o.derived===!0||o.detail==="minimal"||o.detail==="full"||o.format!=null,a=o.actor;if(r){let u=e,p=this.resolve(u);if(a!=null&&!p.allowsObserve(a))throw new Z({actor:a,action:"observe",nodeName:u});return i?this._buildStructuredObserver([[u,p]],o,"one"):{subscribe(h){return p.subscribe(h)},up(h){try{p.up?.(h)}catch(g){if(g instanceof Z)return;throw g}}}}let d=[];this._collectObserveTargets("",d),d.sort((u,p)=>u[0]<p[0]?-1:u[0]>p[0]?1:0);let c=a==null?d:d.filter(([,u])=>u.allowsObserve(a));return i?this._buildStructuredObserver(c,o,"all"):{subscribe:u=>{let p=c.map(([h,g])=>g.subscribe(l=>{u(h,l)}));return()=>{for(let h of p)h()}},up:(u,p)=>{try{this.resolve(u).up?.(p)}catch(h){if(h instanceof Z)return;throw h}}}}_observeReactive(e,t){let r=t.tiers,s=r!=null?new Set(r):null,o=t.reactiveName??"observe";return oe(i=>{let a=[],d=!1,c=!1,u=()=>{if(a.length===0||c)return;let v={events:a.slice(),flushedAt_ns:ie()};a.length=0,i.emit(v)},p={...t,reactive:!1,structured:!0,timeline:!0},h=e!=null?this.observe(e,p):this.observe(p),g=v=>{c||(a.push(v),!d&&(d=!0,_e(()=>{d=!1,u()})))};for(let v of h.events)g(v);let l=h.onEvent(g);return()=>{c=!0,l(),h.dispose()}},{name:o,meta:{domain:"audit",kind:"observe-reactive"}})}_buildStructuredObserver(e,t,r){let s=r==="one"?e[0]?.[0]:void 0,o=i=>{if(r==="one"&&s!=null){let u=this.resolve(s);return this._buildStructuredObserver([[s,u]],i,"one")}let a=[];this._collectObserveTargets("",a),a.sort((u,p)=>u[0]<p[0]?-1:u[0]>p[0]?1:0);let d=i.actor,c=d==null?a:a.filter(([,u])=>u.allowsObserve(d));return this._buildStructuredObserver(c,i,"all")};return this._createObserveResult(e,t,o)}_createObserveResult(e,t,r){let s=t.timeline===!0,o=t.causal===!0,i=t.derived===!0,a=t.detail==="minimal",d=this.config.inspectorEnabled,c=(o||i)&&d,u=t.maxEvents,p=u!=null&&u>0?new Fe(u):null,h=[],g=new Set,l=t.tiers!=null?new Set(t.tiers):null,v={},b=new Set,_=0,m=0,f=0,y=0,w=0,k=0,N=!1,O=!1,R=0,S=new Map,T=new Map,P=new Map,E=x=>{if(!(l!=null&&!l.has(x.type))){p?p.push(x):h.push(x);for(let M of g)M(x)}},A=x=>l==null||l.has(x),Q=()=>s?{timestamp_ns:ie(),in_batch:Le(),batch_id:R}:{},be=(x,M)=>{if(!(!c||!(x instanceof j)))return x._setInspectorHook(Y=>{if(Y.kind==="dep_message")S.set(x,Y.depIndex);else if(Y.kind==="run"){let Ae=Y.batchData.map((C,W)=>C!=null&&C.length>0?C.at(-1):Y.prevData[W]);T.set(x,Ae);let X=Y.batchData.map(C=>C!=null?[...C]:void 0);P.set(x,X),i&&E({type:"derived",path:M,dep_values:Ae,dep_batches:X,...Q()})}})},z=x=>{let M=S.get(x),Y=T.get(x);if(!o||Y==null)return{};let X=(M!=null&&M>=0&&x instanceof j?x._deps[M]:void 0)?.node,C=X?.v,W=P.get(x);return{trigger_dep_index:M,trigger_dep_name:X?.name,...C!=null?{trigger_version:{id:C.id,version:C.version}}:{},dep_values:[...Y],...W!=null?{dep_batches:W}:{}}},K=[],H=[];for(let[x,M]of e){let Y=be(M,x);Y&&K.push(Y),H.push(M.subscribe(Ae=>{R++;for(let X of Ae){let C=X[0],W=Q();if(C===$){v[x]=X[1];let nt=M instanceof j?M.lastMutation?.actor??ye:ye;E({type:"data",path:x,data:X[1],actor:nt,...W,...z(M)})}else if(a)C===U?A("dirty")&&_++:C===te?A("resolved")&&m++:C===ne?A("invalidate")&&f++:C===se?A("pause")&&y++:C===ae?A("resume")&&w++:C===B?A("teardown")&&k++:C===I&&!b.has(x)?A("complete")&&(N=!0):C===D&&A("error")&&(O=!0,b.add(x));else if(C===U)A("dirty")&&_++,E({type:"dirty",path:x,...W});else if(C===te)A("resolved")&&m++,E({type:"resolved",path:x,...W,...z(M)});else if(C===ne)A("invalidate")&&f++,E({type:"invalidate",path:x,...W});else if(C===se)A("pause")&&y++,E({type:"pause",path:x,lockId:X[1],...W});else if(C===ae)A("resume")&&w++,E({type:"resume",path:x,lockId:X[1],...W});else if(C===I)A("complete")&&!b.has(x)&&(N=!0),E({type:"complete",path:x,...W});else if(C===D){A("error")&&(O=!0,b.add(x));let nt=M instanceof j?M.lastMutation?.actor??ye:ye;E({type:"error",path:x,data:X[1],actor:nt,...W})}else C===B&&(A("teardown")&&k++,E({type:"teardown",path:x,...W}))}}))}let J=!1,V=()=>{if(!J){J=!0;for(let x of H)x();for(let x of K)x();for(let x of Ie)x({value:void 0,done:!0});Ie.length=0}},ee=[],Ie=[];g.add(x=>{let M=Ie.shift();M?M({value:x,done:!1}):ee.push(x)});let xt={get values(){return v},get dirtyCount(){return _},get resolvedCount(){return m},get invalidateCount(){return f},get pauseCount(){return y},get resumeCount(){return w},get teardownCount(){return k},get events(){return p?p.toArray():[...h]},get anyCompletedCleanly(){return N},get anyErrored(){return O},get completedWithoutErrors(){return N&&!O},onEvent(x){return g.add(x),()=>g.delete(x)},dispose:V,expand(x){V();let M={...t};return typeof x=="string"?M.detail=x:Object.assign(M,x),r(fn(M))},[Symbol.asyncIterator](){return{next(){return ee.length>0?Promise.resolve({value:ee.shift(),done:!1}):J?Promise.resolve({value:void 0,done:!0}):new Promise(x=>Ie.push(x))},return(){return V(),Promise.resolve({value:void 0,done:!0})}}}};return t.format!=null&&this._attachFormatLogger(xt,t),xt}_attachFormatLogger(e,t){let r=t.format;if(r==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=hr(t.theme),c=r==="stage-log"?ie():0,u=l=>l==null?"":t.stageLabels?.[l]??l,p=(l,v)=>l.length>v?`${l.slice(0,v-1)}\u2026`:l,h=l=>l.type==="data"||l.type==="error"?p(Tt(l.data),120):"",g=l=>{if(r==="stage-log"){let N=(ie()-c)/1e9,O=u(l.path).padEnd(9);if(l.type==="data"){let R=h(l);return`[${N.toFixed(3)}s] ${O} \u2190${R?` ${R}`:""}`}if(l.type==="error"){let R=h(l);return`[${N.toFixed(3)}s] ${O} \u2717${R?` ${R}`:""}`}return l.type==="complete"?`[${N.toFixed(3)}s] ${O} \u25A0 complete`:`[${N.toFixed(3)}s] ${O} ${l.type}`}if(r==="json")try{return JSON.stringify(l)}catch{return JSON.stringify({type:l.type,path:l.path,data:"[unserializable]"})}let v=d[l.type]??"",b=l.path?`${d.path}${l.path}${d.reset} `:"",_=l.type==="data"||l.type==="error",m=l.type==="pause"||l.type==="resume",f=_?` ${Tt(l.data)}`:m?` ${Tt(l.lockId)}`:"",y=l.type==="data"||l.type==="resolved"||l.type==="derived"?l:void 0,w=y?.trigger_dep_name!=null?` <- ${y.trigger_dep_name}`:y?.trigger_dep_index!=null?` <- #${y.trigger_dep_index}`:"",k=l.in_batch?" [batch]":"";return`${b}${v}${l.type.toUpperCase()}${d.reset}${f}${w}${k}`};e.onEvent(l=>{a(l.type)&&s(g(l),l)})}addDisposer(e){return this._disposers.add(e),()=>{this._disposers.delete(e)}}destroy(){Xe(this._disposers,this.name),this.signal([[B]],{internal:!0}),Xe(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(){Xe(this._disposers,this.name),Xe(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}snapshot(e){let{expand:t,...r}=this.describe({detail:"full"}),s={};for(let a of Object.keys(r.nodes).sort()){let{lastMutation:d,guard:c,...u}=r.nodes[a];s[a]=u}let o=[...r.subgraphs].sort(),i={...r,version:1,nodes:s,subgraphs:o};if(e?.format==null)return i;if(e.format==="json-string")return JSON.stringify(i);if(e.format==="bytes"){if(e.codec==null)throw new Error("snapshot({format: 'bytes'}) requires a `codec` name");let a=this.config.lookupCodec(e.codec);if(a==null)throw new Error(`snapshot: codec "${e.codec}" is not registered on this graph's config. Call config.registerCodec(...) before creating nodes.`);return Rt(a,a.encode(i))}throw new Error(`snapshot: unknown format "${String(e.format)}"`)}static decode(e,t){let r=t?.config??Ne,{codec:s,codecVersion:o,payload:i}=Et(e,r);return s.decode(i,o)}restore(e,t){if(ln(e),e.name!==this.name)throw new Error(`Graph "${this.name}": restore snapshot name "${e.name}" does not match this graph`);let r=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(r!==null&&!r.some(a=>a.test(o)))continue;let i=e.nodes[o];if(i!==void 0){if(!("value"in i)||i.value===void 0){"value"in i&&i.value===void 0&&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){ln(e);let r=typeof t=="function"?t:t?.build,s=typeof t=="function"?void 0:t?.factories,o=new n(e.name);if(r)return r(o),o.restore(e),o;for(let g of[...e.subgraphs].sort((l,v)=>{let b=l.split(G).length,_=v.split(G).length;return b!==_?b-_:l<v?-1:l>v?1:0})){let l=g.split(G),v=o;for(let b of l)v._mounts.has(b)||v.mount(b,new n(b)),v=v._mounts.get(b)}let i=s?Object.entries(s).map(([g,l])=>({re:Ze(g),factory:l})):[],a=g=>{for(let l of i)if(l.re.test(g))return l.factory},d=g=>{let l=g.split(G),v=l.pop();if(v==null||v.length===0)throw new Error(`invalid snapshot path "${g}"`);let b=o;for(let _ of l){let m=b._mounts.get(_);if(!m)throw new Error(`unknown mount "${_}" in path "${g}"`);b=m}return[b,v]},c=Object.entries(e.nodes).filter(([g])=>!g.includes(`${G}${q}${G}`)).sort((g,l)=>g[0]<l[0]?-1:g[0]>l[0]?1:0),u=new Map(c),p=new Map,h=!0;for(;u.size>0&&h;){h=!1;for(let[g,l]of[...u.entries()]){let v=l?.deps??[];if(!v.every(w=>p.has(w)))continue;let[b,_]=d(g),m={...l?.meta??{}},f=a(g),y;if(l?.type==="state")y=re(l.value,{meta:m});else{if(f==null)continue;y=f(_,{path:g,type:l.type,value:l.value,meta:m,deps:v,resolvedDeps:v.map(w=>p.get(w))})}b.add(y,{name:_}),p.set(g,y),u.delete(g),h=!0}}if(u.size>0){let g=[...u.keys()].sort().join(", ");throw new Error(`Graph.fromSnapshot could not reconstruct nodes without build callback: ${g}. Pass matching factories via fromSnapshot(data, { factories: { pattern: factoryFn } }).`)}return o.restore(e),o}toJSON(){return this.snapshot()}attachSnapshotStorage(e,t={}){let r=e.map(c=>({tier:c,debounceMs:Math.max(0,c.debounceMs??0),compactEvery:Math.max(1,c.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=(c,u)=>{if(c.disposed)return;let p=dr(u.nodes);if(c.lastSnapshot!=null&&p!==""&&p===c.lastFingerprint)return;let h=c.seq+1,g=ze(),b=c.lastSnapshot==null||h%c.compactEvery===0?{name:this.name,mode:"full",snapshot:u,seq:h,timestamp_ns:g,format_version:Re}:{name:this.name,mode:"diff",diff:yr(c.lastSnapshot,u),seq:h,timestamp_ns:g,format_version:Re};if(c.tier.filter&&!c.tier.filter(b))return;let _;try{_=c.tier.save(b)}catch(m){t.onError?.(m,c.tier);return}if(_&&typeof _.then=="function"){let y=(c.savePending??Promise.resolve()).then(()=>_,()=>_).then(()=>{c.disposed||(c.seq=h,c.lastSnapshot=u,c.lastFingerprint=p)},w=>{t.onError?.(w,c.tier)});c.savePending=y.finally(()=>{c.savePending===y&&(c.savePending=void 0)})}else c.seq=h,c.lastSnapshot=u,c.lastFingerprint=p},o=(c,u)=>{try{s(c,u)}catch(p){t.onError?.(p,c.tier)}},i=(c,u)=>{if(!u.some(l=>{let v=this.config.messageTier(l[0]);return v>=3&&v<5}))return;if(t.filter){let l=this.tryResolve(c);if(l==null)return;let v=yt(l,bt("standard"));if(!t.filter(c,v))return}let h,g=()=>(h==null&&(h=this.snapshot()),h);for(let l of r)l.disposed||(l.debounceMs===0?o(l,g()):(l.timer==null&&(l.timer=new qe),l.timer.start(l.debounceMs,()=>{l.disposed||o(l,this.snapshot())})))},a;if(t.paths!=null){let u=(typeof t.paths=="string"?this._pathsMatching(t.paths):t.paths).map(p=>{let h=this.tryResolve(p);return h==null?()=>{}:h.subscribe(g=>i(p,g))});a=()=>{for(let p of u)p()}}else a=this.observe().subscribe((c,u)=>i(c,u));let d=()=>{a();for(let c of r)c.disposed=!0,c.timer?.cancel();this._storageDisposers.delete(d)};return this._storageDisposers.add(d),{dispose:d}}async _cascadeRestore(e,t){for(let r of e){let s;try{s=await r.load?.()}catch(i){t?.(i,r);continue}if(s==null||typeof s!="object"||Array.isArray(s))continue;let o=s;try{if(o.mode==="full"&&o.snapshot!=null)return this.restore(o.snapshot),!0;if(o.version===Re&&o.nodes!=null)return this.restore(o),!0}catch(i){t?.(i,r)}}return!1}static async fromStorage(e,t,r){for(let s of t){let o;try{o=await s.load?.()}catch(d){r?.onError?.(d,s);continue}if(o==null||typeof o!="object"||Array.isArray(o))continue;let i=o,a=i.mode==="full"&&i.snapshot!=null?i.snapshot:i.version===Re&&i.nodes!=null?i:void 0;if(a!=null)try{return n.fromSnapshot(a,r)}catch(d){r?.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,r){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:ie(),...r?.actor!=null?{actor:r.actor}:{}};this._traceRing.push(s)}return}return e!=null?this.config.inspectorEnabled?this._annotations.get(e):void 0:this.config.inspectorEnabled?this._traceRing.toArray():[]}annotation(e){return this._annotations.get(e)}clearTrace(){this._annotations.clear(),this._traceRing.clear()}pruneTrace(e){let t=this._traceRing.toArray().filter(s=>!e(s)),r=this._traceRing.size-t.length;this._traceRing.clear();for(let s of t)this._traceRing.push(s);return r}static diff(e,t){let r=new Set(Object.keys(e.nodes)),s=new Set(Object.keys(t.nodes)),o=[...s].filter(m=>!r.has(m)).sort(),i=[...r].filter(m=>!s.has(m)).sort(),a=[],d=[];for(let m of r){if(!s.has(m))continue;let f=e.nodes[m],y=t.nodes[m],w=f.v,k=y.v;w!=null&&k!=null&&w.id===k.id&&w.version!==k.version&&d.push({path:m,id:w.id,from:w.version,to:k.version});let N=w!=null&&k!=null&&w.id===k.id&&w.version===k.version;for(let O of["type","status","sentinel"]){let R=f[O],S=y[O];R!==S&&a.push({path:m,field:O,from:R,to:S})}if(!N)for(let O of["value","meta"]){let R=f[O],S=y[O];ur(R,S)||a.push({path:m,field:O,from:R,to:S})}}let c=m=>`${m.from} ${m.to}`,u=new Set(e.edges.map(c)),p=new Set(t.edges.map(c)),h=t.edges.filter(m=>!u.has(c(m))),g=e.edges.filter(m=>!p.has(c(m))),l=new Set(e.subgraphs),v=new Set(t.subgraphs),b=[...v].filter(m=>!l.has(m)).sort(),_=[...l].filter(m=>!v.has(m)).sort();return{nodesAdded:o,nodesRemoved:i,nodesChanged:a,versionChanges:d,edgesAdded:h,edgesRemoved:g,subgraphsAdded:b,subgraphsRemoved:_}}}});function bn(n,e,t){return{[n]:!0,[`${n}_type`]:e,...t??{}}}var yn=F(()=>{"use strict"});var Er={};Mn(Er,{compileSpec:()=>Nr,decompileSpec:()=>xr,extractFnFactory:()=>Nn,extractSourceFactory:()=>On,generateCatalogPrompt:()=>xn,isRichFnEntry:()=>Pe,isRichSourceEntry:()=>et,llmCompose:()=>Rr,llmRefine:()=>En,specDiff:()=>Sr,validateSpec:()=>tt,validateSpecAgainstCatalog:()=>Ot});module.exports=$n(Er);$e();mn();Be();he();Oe();$e();yn();Ge();he();function vn(n,e){let t=n.cache??0;return t>=e?!1:(n.down([[U],[$,t+1]]),!0)}var Ms=It((n,e)=>{n("observe"),n("signal"),e("write")});kt();function wn(n,e){return bn("reduction",n,e)}function _n(n,e,t,r){let s=r?.maxIterations??10,o=`__feedback_${e}`,i=re(0,{meta:wn("feedback_counter",{maxIterations:s,feedbackFrom:e,feedbackTo:t})});n.add(i,{name:o});let a=n.resolve(e),d=n.resolve(t),c=`__feedback_effect_${e}`,u=ge([],(p,h)=>{let g=a.subscribe(l=>{for(let v of l){let b=v[0];if(b===$){let _=v[1];if(_==null)return;Me(()=>{vn(i,s)&&d.emit(_)})}else if(b===I||b===D){let _=b===D&&v.length>1?[D,v[1]]:[b];i.down([_])}}});return()=>g()},{name:c,describeKind:"effect",meta:{...wn("feedback_effect",{feedbackFrom:e,feedbackTo:t}),_internal:!0}});return n.add(u,{name:c}),n.addDisposer(Se(u)),n}function ue(n){let e=n.meta?.factory;return typeof e=="string"?e:void 0}function le(n){let e=n.meta?.factoryArgs;return e!=null&&typeof e=="object"?e:{}}function kn(n){let e=le(n);return"initial"in e?e.initial:n.value}function Pe(n){return typeof n=="object"&&n!==null&&"factory"in n}function et(n){return typeof n=="object"&&n!==null&&"factory"in n}function Nn(n){return Pe(n)?n.factory:n}function On(n){return et(n)?n.factory:n}function xn(n){let e=[];if(n.fns){let t=new Map;for(let[r,s]of Object.entries(n.fns)){let o=Pe(s)?s.tags?.[0]??"Other":"Other";t.has(o)||t.set(o,[]),t.get(o).push(wr(r,s))}for(let[r,s]of t)e.push(`${r}:
4
4
  ${s.join(`
5
- `)}`)}if(n.sources){let t=[];for(let[r,s]of Object.entries(n.sources))t.push(pr(r,s));t.length>0&&e.push(`Sources:
5
+ `)}`)}if(n.sources){let t=[];for(let[r,s]of Object.entries(n.sources))t.push(_r(r,s));t.length>0&&e.push(`Sources:
6
6
  ${t.join(`
7
7
  `)}`)}return e.join(`
8
8
 
9
- `)}function fr(n,e){if(!Ge(e))return`- ${n}`;let t=`- ${n}: ${e.description}`;if(e.configSchema){let r=Object.entries(e.configSchema).map(([s,o])=>{let i=`${s}: ${o.type}`;return o.enum&&(i+=` (${o.enum.join("|")})`),o.required===!1&&(i+="?"),i});t+=`. Config: { ${r.join(", ")} }`}return t}function pr(n,e){if(!Qe(e))return`- ${n}`;let t=`- ${n}: ${e.description}`;if(e.configSchema){let r=Object.entries(e.configSchema).map(([s,o])=>{let i=`${s}: ${o.type}`;return o.required===!1&&(i+="?"),i});t+=`. Config: { ${r.join(", ")} }`}return t}function Nt(n,e){let t=[],r=new Set(Object.keys(e.fns??{})),s=new Set(Object.keys(e.sources??{}));for(let[o,i]of Object.entries(n.nodes)){if(i.type==="template")continue;let a=i,u=ce(a);if(u==null)continue;let c=a.type==="producer";if(a.type==="state"&&u==="state")continue;if(c){let m=s.has(u),p=r.has(u);if(!m&&!p&&(s.size>0||r.size>0)){let h=Ze(u,s)??Ze(u,r);t.push(`Node "${o}": source "${u}" not found in catalog`+(h?`. Did you mean "${h}"?`:""))}}else if(r.size>0&&!r.has(u))if(s.has(u))t.push(`Node "${o}": fn "${u}" is a source, not a function. Use it as a producer source instead, or use a function from: ${[...r].join(", ")}`);else{let m=Ze(u,r);t.push(`Node "${o}": fn "${u}" not found in catalog`+(m?`. Did you mean "${m}"?`:""))}let d=ue(a);if(!c&&e.fns?.[u]){let m=e.fns[u];if(Ge(m)&&m.configSchema){for(let[p,h]of Object.entries(m.configSchema))if(h.required!==!1&&!(p in d)&&t.push(`Node "${o}": config missing required field "${p}"`),p in d&&h.enum){let l=d[p];h.enum.includes(l)||t.push(`Node "${o}": config.${p} = ${JSON.stringify(l)}, expected one of: ${h.enum.join(", ")}`)}}}if(c&&e.sources?.[u]){let m=e.sources[u];if(Qe(m)&&m.configSchema){for(let[p,h]of Object.entries(m.configSchema))if(h.required!==!1&&!(p in d)&&t.push(`Node "${o}": config missing required field "${p}"`),p in d&&h.enum){let l=d[p];h.enum.includes(l)||t.push(`Node "${o}": config.${p} = ${JSON.stringify(l)}, expected one of: ${h.enum.join(", ")}`)}}}}if(n.templates)for(let[o,i]of Object.entries(n.templates))for(let[a,u]of Object.entries(i.nodes)){let c=ce(u);if(c!=null&&!(u.type==="state"&&c==="state")&&u.type!=="producer"&&r.size>0&&!r.has(c)){let d=Ze(c,r);t.push(`Template "${o}" node "${a}": fn "${c}" not found in catalog`+(d?`. Did you mean "${d}"?`:""))}}return{valid:t.length===0,errors:t,warnings:[]}}function Ze(n,e){let t=null,r=1/0,s=n.toLowerCase();for(let o of e){let i=hr(s,o.toLowerCase());i<r&&i<=Math.max(3,Math.floor(n.length/2))&&(r=i,t=o)}return t}function hr(n,e){let t=n.length,r=e.length,s=Array.from({length:t+1},(o,i)=>Array.from({length:r+1},(a,u)=>i===0?u:u===0?i:0));for(let o=1;o<=t;o++)for(let i=1;i<=r;i++)s[o][i]=n[o-1]===e[i-1]?s[o-1][i-1]:1+Math.min(s[o-1][i],s[o][i-1],s[o-1][i-1]);return s[t][r]}var _n=new Set(["state","producer","derived","effect","operator","template"]),gr=new Set(["state","producer","derived","effect","operator"]);function et(n){let e=[],t=[];if(n==null||typeof n!="object")return{valid:!1,errors:["GraphSpec must be a non-null object"],warnings:t};let r=n;if((typeof r.name!="string"||r.name.length===0)&&e.push("Missing or empty 'name' field"),r.nodes==null||typeof r.nodes!="object"||Array.isArray(r.nodes))return e.push("Missing or invalid 'nodes' field (must be an object)"),{valid:!1,errors:e,warnings:t};let s=new Set(Object.keys(r.nodes)),o=new Map,i=new Map;if(r.templates!=null&&typeof r.templates=="object"&&!Array.isArray(r.templates)){for(let[a,u]of Object.entries(r.templates))if(u!=null&&typeof u=="object"){let c=u;i.set(a,{params:Array.isArray(c.params)?c.params:[]})}}if(r.templates!=null)if(typeof r.templates!="object"||Array.isArray(r.templates))e.push("'templates' must be an object");else for(let[a,u]of Object.entries(r.templates)){if(u==null||typeof u!="object"){e.push(`Template "${a}": must be an object`);continue}let c=u;if(Array.isArray(c.params)||e.push(`Template "${a}": missing 'params' array`),c.nodes==null||typeof c.nodes!="object"||Array.isArray(c.nodes))e.push(`Template "${a}": missing or invalid 'nodes' object`);else{let d=new Set(Array.isArray(c.params)?c.params:[]),m=new Set(Object.keys(c.nodes));for(let[p,h]of Object.entries(c.nodes)){if(h==null||typeof h!="object"){e.push(`Template "${a}" node "${p}": must be an object`);continue}let l=h;if((typeof l.type!="string"||!gr.has(l.type))&&e.push(`Template "${a}" node "${p}": invalid type`),Array.isArray(l.deps))for(let v of l.deps)!m.has(v)&&!d.has(v)&&e.push(`Template "${a}" node "${p}": dep "${v}" is not an inner node or param`)}typeof c.output!="string"?e.push(`Template "${a}": missing 'output' string`):c.nodes[c.output]||e.push(`Template "${a}": output "${c.output}" is not a declared node`)}}for(let[a,u]of Object.entries(r.nodes)){if(u==null||typeof u!="object"){e.push(`Node "${a}": must be an object`);continue}let c=u;if(typeof c.type!="string"||!_n.has(c.type)){e.push(`Node "${a}": invalid type "${String(c.type)}" (expected: ${[..._n].join(", ")})`);continue}if(o.set(a,c.type),c.type==="template")if(typeof c.template!="string"||!i.has(c.template))e.push(`Node "${a}": template "${String(c.template)}" not found in templates`);else if(c.bind==null||typeof c.bind!="object"||Array.isArray(c.bind))e.push(`Node "${a}": template ref requires 'bind' object`);else{let d=i.get(c.template),m=c.bind;for(let p of d.params)p in m||e.push(`Node "${a}": template param "${p}" is not bound (template "${c.template}")`);for(let[,p]of Object.entries(m))typeof p=="string"&&!s.has(p)&&e.push(`Node "${a}": bind target "${p}" does not reference an existing node`)}else{if(Array.isArray(c.deps))for(let d of c.deps)d===a?e.push(`Node "${a}": self-referencing dep`):s.has(d)||e.push(`Node "${a}": dep "${d}" does not reference an existing node`);(c.type==="derived"||c.type==="effect"||c.type==="operator")&&!Array.isArray(c.deps)&&e.push(`Node "${a}": ${c.type} node should have a 'deps' array`)}}if(r.feedback!=null)if(!Array.isArray(r.feedback))e.push("'feedback' must be an array");else for(let a=0;a<r.feedback.length;a++){let u=r.feedback[a];if(u==null||typeof u!="object"){e.push(`Feedback [${a}]: must be an object`);continue}let c=u;typeof c.from!="string"||!s.has(c.from)?e.push(`Feedback [${a}]: 'from' "${String(c.from)}" does not reference an existing node`):o.get(c.from)==="effect"&&t.push(`Feedback [${a}]: 'from' "${c.from}" is an effect node \u2014 effects emit no DATA, so the feedback edge will never fire. Did you mean a derived/state node upstream?`),typeof c.from=="string"&&c.from===c.to&&e.push(`Feedback [${a}]: 'from' and 'to' must be different nodes`),typeof c.to!="string"||!s.has(c.to)?e.push(`Feedback [${a}]: 'to' "${String(c.to)}" does not reference an existing node`):typeof c.to=="string"&&o.get(c.to)!=="state"&&e.push(`Feedback [${a}]: 'to' node "${c.to}" must be a state node (got "${o.get(c.to)??"unknown"}")`)}return{valid:e.length===0,errors:e,warnings:t}}function mr(n,e){let t=et(n);if(!t.valid)throw new Error(`compileSpec: invalid GraphSpec:
9
+ `)}function wr(n,e){if(!Pe(e))return`- ${n}`;let t=`- ${n}: ${e.description}`;if(e.configSchema){let r=Object.entries(e.configSchema).map(([s,o])=>{let i=`${s}: ${o.type}`;return o.enum&&(i+=` (${o.enum.join("|")})`),o.required===!1&&(i+="?"),i});t+=`. Config: { ${r.join(", ")} }`}return t}function _r(n,e){if(!et(e))return`- ${n}`;let t=`- ${n}: ${e.description}`;if(e.configSchema){let r=Object.entries(e.configSchema).map(([s,o])=>{let i=`${s}: ${o.type}`;return o.required===!1&&(i+="?"),i});t+=`. Config: { ${r.join(", ")} }`}return t}function Ot(n,e){let t=[],r=new Set(Object.keys(e.fns??{})),s=new Set(Object.keys(e.sources??{}));for(let[o,i]of Object.entries(n.nodes)){if(i.type==="template")continue;let a=i,d=ue(a);if(d==null)continue;let c=a.type==="producer";if(a.type==="state"&&d==="state")continue;if(c){let p=s.has(d),h=r.has(d);if(!p&&!h&&(s.size>0||r.size>0)){let g=Qe(d,s)??Qe(d,r);t.push(`Node "${o}": source "${d}" not found in catalog`+(g?`. Did you mean "${g}"?`:""))}}else if(r.size>0&&!r.has(d))if(s.has(d))t.push(`Node "${o}": fn "${d}" is a source, not a function. Use it as a producer source instead, or use a function from: ${[...r].join(", ")}`);else{let p=Qe(d,r);t.push(`Node "${o}": fn "${d}" not found in catalog`+(p?`. Did you mean "${p}"?`:""))}let u=le(a);if(!c&&e.fns?.[d]){let p=e.fns[d];if(Pe(p)&&p.configSchema){for(let[h,g]of Object.entries(p.configSchema))if(g.required!==!1&&!(h in u)&&t.push(`Node "${o}": config missing required field "${h}"`),h in u&&g.enum){let l=u[h];g.enum.includes(l)||t.push(`Node "${o}": config.${h} = ${JSON.stringify(l)}, expected one of: ${g.enum.join(", ")}`)}}}if(c&&e.sources?.[d]){let p=e.sources[d];if(et(p)&&p.configSchema){for(let[h,g]of Object.entries(p.configSchema))if(g.required!==!1&&!(h in u)&&t.push(`Node "${o}": config missing required field "${h}"`),h in u&&g.enum){let l=u[h];g.enum.includes(l)||t.push(`Node "${o}": config.${h} = ${JSON.stringify(l)}, expected one of: ${g.enum.join(", ")}`)}}}}if(n.templates)for(let[o,i]of Object.entries(n.templates))for(let[a,d]of Object.entries(i.nodes)){let c=ue(d);if(c!=null&&!(d.type==="state"&&c==="state")&&d.type!=="producer"&&r.size>0&&!r.has(c)){let u=Qe(c,r);t.push(`Template "${o}" node "${a}": fn "${c}" not found in catalog`+(u?`. Did you mean "${u}"?`:""))}}return{valid:t.length===0,errors:t,warnings:[]}}function Qe(n,e){let t=null,r=1/0,s=n.toLowerCase();for(let o of e){let i=kr(s,o.toLowerCase());i<r&&i<=Math.max(3,Math.floor(n.length/2))&&(r=i,t=o)}return t}function kr(n,e){let t=n.length,r=e.length,s=Array.from({length:t+1},(o,i)=>Array.from({length:r+1},(a,d)=>i===0?d:d===0?i:0));for(let o=1;o<=t;o++)for(let i=1;i<=r;i++)s[o][i]=n[o-1]===e[i-1]?s[o-1][i-1]:1+Math.min(s[o-1][i],s[o][i-1],s[o-1][i-1]);return s[t][r]}var Tn=new Set(["state","producer","derived","effect","operator","template"]),Tr=new Set(["state","producer","derived","effect","operator"]);function tt(n){let e=[],t=[];if(n==null||typeof n!="object")return{valid:!1,errors:["GraphSpec must be a non-null object"],warnings:t};let r=n;if((typeof r.name!="string"||r.name.length===0)&&e.push("Missing or empty 'name' field"),r.nodes==null||typeof r.nodes!="object"||Array.isArray(r.nodes))return e.push("Missing or invalid 'nodes' field (must be an object)"),{valid:!1,errors:e,warnings:t};let s=new Set(Object.keys(r.nodes)),o=new Map,i=new Map;if(r.templates!=null&&typeof r.templates=="object"&&!Array.isArray(r.templates)){for(let[a,d]of Object.entries(r.templates))if(d!=null&&typeof d=="object"){let c=d;i.set(a,{params:Array.isArray(c.params)?c.params:[]})}}if(r.templates!=null)if(typeof r.templates!="object"||Array.isArray(r.templates))e.push("'templates' must be an object");else for(let[a,d]of Object.entries(r.templates)){if(d==null||typeof d!="object"){e.push(`Template "${a}": must be an object`);continue}let c=d;if(Array.isArray(c.params)||e.push(`Template "${a}": missing 'params' array`),c.nodes==null||typeof c.nodes!="object"||Array.isArray(c.nodes))e.push(`Template "${a}": missing or invalid 'nodes' object`);else{let u=new Set(Array.isArray(c.params)?c.params:[]),p=new Set(Object.keys(c.nodes));for(let[h,g]of Object.entries(c.nodes)){if(g==null||typeof g!="object"){e.push(`Template "${a}" node "${h}": must be an object`);continue}let l=g;if((typeof l.type!="string"||!Tr.has(l.type))&&e.push(`Template "${a}" node "${h}": invalid type`),Array.isArray(l.deps))for(let v of l.deps)!p.has(v)&&!u.has(v)&&e.push(`Template "${a}" node "${h}": dep "${v}" is not an inner node or param`)}typeof c.output!="string"?e.push(`Template "${a}": missing 'output' string`):c.nodes[c.output]||e.push(`Template "${a}": output "${c.output}" is not a declared node`)}}for(let[a,d]of Object.entries(r.nodes)){if(d==null||typeof d!="object"){e.push(`Node "${a}": must be an object`);continue}let c=d;if(typeof c.type!="string"||!Tn.has(c.type)){e.push(`Node "${a}": invalid type "${String(c.type)}" (expected: ${[...Tn].join(", ")})`);continue}if(o.set(a,c.type),c.type==="template")if(typeof c.template!="string"||!i.has(c.template))e.push(`Node "${a}": template "${String(c.template)}" not found in templates`);else if(c.bind==null||typeof c.bind!="object"||Array.isArray(c.bind))e.push(`Node "${a}": template ref requires 'bind' object`);else{let u=i.get(c.template),p=c.bind;for(let h of u.params)h in p||e.push(`Node "${a}": template param "${h}" is not bound (template "${c.template}")`);for(let[,h]of Object.entries(p))typeof h=="string"&&!s.has(h)&&e.push(`Node "${a}": bind target "${h}" does not reference an existing node`)}else{if(Array.isArray(c.deps))for(let u of c.deps)u===a?e.push(`Node "${a}": self-referencing dep`):s.has(u)||e.push(`Node "${a}": dep "${u}" does not reference an existing node`);(c.type==="derived"||c.type==="effect"||c.type==="operator")&&!Array.isArray(c.deps)&&e.push(`Node "${a}": ${c.type} node should have a 'deps' array`)}}if(r.feedback!=null)if(!Array.isArray(r.feedback))e.push("'feedback' must be an array");else for(let a=0;a<r.feedback.length;a++){let d=r.feedback[a];if(d==null||typeof d!="object"){e.push(`Feedback [${a}]: must be an object`);continue}let c=d;typeof c.from!="string"||!s.has(c.from)?e.push(`Feedback [${a}]: 'from' "${String(c.from)}" does not reference an existing node`):o.get(c.from)==="effect"&&t.push(`Feedback [${a}]: 'from' "${c.from}" is an effect node \u2014 effects emit no DATA, so the feedback edge will never fire. Did you mean a derived/state node upstream?`),typeof c.from=="string"&&c.from===c.to&&e.push(`Feedback [${a}]: 'from' and 'to' must be different nodes`),typeof c.to!="string"||!s.has(c.to)?e.push(`Feedback [${a}]: 'to' "${String(c.to)}" does not reference an existing node`):typeof c.to=="string"&&o.get(c.to)!=="state"&&e.push(`Feedback [${a}]: 'to' node "${c.to}" must be a state node (got "${o.get(c.to)??"unknown"}")`)}return{valid:e.length===0,errors:e,warnings:t}}function Nr(n,e){let t=tt(n);if(!t.valid)throw new Error(`compileSpec: invalid GraphSpec:
10
10
  ${t.errors.join(`
11
- `)}`);let r=n.factory,s=n.factoryArgs;if(typeof r=="string"){let f=e?.catalog?.graphFactories?.[r];if(f)return f(s)}let o=e?.catalog??{},i=e?.onMissing??"placeholder",a=new Se(n.name),u=n.templates??{},c=Nt(n,o);if(!c.valid)throw new Error(`compileSpec: catalog validation errors:
11
+ `)}`);let r=n.factory,s=n.factoryArgs;if(typeof r=="string"){let f=e?.catalog?.graphFactories?.[r];if(f)return f(s)}let o=e?.catalog??{},i=e?.onMissing??"placeholder",a=new Ee(n.name),d=n.templates??{},c=Ot(n,o);if(!c.valid)throw new Error(`compileSpec: catalog validation errors:
12
12
  ${c.errors.join(`
13
- `)}`);let d=[],m=(f,b,_)=>{d.push({path:f,kind:b,name:_})},p=f=>{let b=o.fns?.[f];return b?wn(b):void 0},h=f=>{let b=o.sources?.[f];return b?kn(b):void 0},l=f=>{if(!f)return;let b={};for(let[_,k]of Object.entries(f))_==="factory"||_==="factoryArgs"||(b[_]=k);return Object.keys(b).length>0?b:void 0},v=new Map,y=[];for(let[f,b]of Object.entries(n.nodes)){if(b.type==="template")continue;let _=b,k=ce(_),O=ue(_);if(_.type==="state"){let T=vn(_),R=se(T,{name:f,meta:l(_.meta)});a.add(R,{name:f}),v.set(f,R)}else if(_.type==="producer"){let T=k?h(k):void 0,R=k?p(k):void 0;if(T){let S=T(O);a.add(S,{name:f}),v.set(f,S)}else if(R){let S=R([],O);a.add(S,{name:f}),v.set(f,S)}else{k&&m(f,"source",k);let S=Oe(()=>{},{name:f,meta:{...l(_.meta),_specSource:k}});a.add(S,{name:f}),v.set(f,S)}}else y.push([f,_])}let w=!0,g=new Map(y);for(;g.size>0&&w;){w=!1;for(let[f,b]of[...g.entries()]){let _=b.deps??[];if(!_.every(N=>v.has(N)))continue;let k=_.map(N=>v.get(N)),O=ce(b),T=ue(b),R=O?p(O):void 0,S;R?S=R(k,T):b.type==="effect"?(O&&m(f,"fn",O),S=We(k,()=>{})):(O&&m(f,"fn",O),S=pe(k,N=>N[0])),a.add(S,{name:f}),v.set(f,S),g.delete(f),w=!0}}if(g.size>0){let f=[...g.keys()].sort().join(", ");throw new Error(`compileSpec: unresolvable deps for nodes: ${f}`)}for(let[f,b]of Object.entries(n.nodes)){if(b.type!=="template")continue;let _=b,k=u[_.template],O=new Se(f),T=new Map,R=[];for(let[E,A]of Object.entries(k.nodes)){let Q=(A.deps??[]).map(H=>H.startsWith("$")&&_.bind[H]?_.bind[H]:H),ge={...A,deps:Q},B=ce(A),q=ue(A);if(A.type==="state"){let H=vn(A),K=se(H,{name:E,meta:l(A.meta)});O.add(K,{name:E}),T.set(E,K)}else if(A.type==="producer"){let H=B?h(B):void 0,K=B?p(B):void 0;if(H){let L=H(q);O.add(L,{name:E}),T.set(E,L)}else if(K){let L=K([],q);O.add(L,{name:E}),T.set(E,L)}else{B&&m(`${f}.${E}`,"source",B);let L=Oe(()=>{},{name:E,meta:{...l(A.meta),_specSource:B}});O.add(L,{name:E}),T.set(E,L)}}else R.push([E,ge])}let S=!0,N=new Map(R);for(;N.size>0&&S;){S=!1;for(let[E,A]of[...N.entries()]){let Q=A.deps??[];if(!Q.every(ee=>T.has(ee)||v.has(ee)))continue;let B=Q.map(ee=>T.get(ee)??v.get(ee)),q=ce(A),H=ue(A),K=q?p(q):void 0,L;K?L=K(B,H):A.type==="effect"?(q&&m(`${f}.${E}`,"fn",q),L=We(B,()=>{})):(q&&m(`${f}.${E}`,"fn",q),L=pe(B,ee=>ee[0])),O.add(L,{name:E}),T.set(E,L),N.delete(E),S=!0}}if(N.size>0){let E=[...N.keys()].sort().join(", ");throw new Error(`compileSpec: template "${_.template}" has unresolvable deps: ${E}`)}a.mount(f,O);let P=`${f}::${k.output}`;v.set(f,a.resolve(P));try{let E=a.resolve(P);E.meta._templateName?.emit(_.template),E.meta._templateBind?.emit(_.bind)}catch{}}for(let f of n.feedback??[])yn(a,f.from,f.to,{maxIterations:f.maxIterations});if(d.length>0){if(i==="error"){let f=d.map(b=>` - ${b.path}: missing ${b.kind} "${b.name}"`);throw new Error(`compileSpec: ${d.length} catalog entr${d.length===1?"y":"ies"} missing \u2014 pass them via opts.catalog or set opts.onMissing to "warn"/"placeholder":
13
+ `)}`);let u=[],p=(f,y,w)=>{u.push({path:f,kind:y,name:w})},h=f=>{let y=o.fns?.[f];return y?Nn(y):void 0},g=f=>{let y=o.sources?.[f];return y?On(y):void 0},l=f=>{if(!f)return;let y={};for(let[w,k]of Object.entries(f))w==="factory"||w==="factoryArgs"||(y[w]=k);return Object.keys(y).length>0?y:void 0},v=new Map,b=[];for(let[f,y]of Object.entries(n.nodes)){if(y.type==="template")continue;let w=y,k=ue(w),N=le(w);if(w.type==="state"){let O=kn(w),R=re(O,{name:f,meta:l(w.meta)});a.add(R,{name:f}),v.set(f,R)}else if(w.type==="producer"){let O=k?g(k):void 0,R=k?h(k):void 0;if(O){let S=O(N);a.add(S,{name:f}),v.set(f,S)}else if(R){let S=R([],N);a.add(S,{name:f}),v.set(f,S)}else{k&&p(f,"source",k);let S=oe(()=>{},{name:f,meta:{...l(w.meta),_specSource:k}});a.add(S,{name:f}),v.set(f,S)}}else b.push([f,w])}let _=!0,m=new Map(b);for(;m.size>0&&_;){_=!1;for(let[f,y]of[...m.entries()]){let w=y.deps??[];if(!w.every(T=>v.has(T)))continue;let k=w.map(T=>v.get(T)),N=ue(y),O=le(y),R=N?h(N):void 0,S;R?S=R(k,O):y.type==="effect"?(N&&p(f,"fn",N),S=xe(k,()=>{})):(N&&p(f,"fn",N),S=ce(k,T=>T[0])),a.add(S,{name:f}),v.set(f,S),m.delete(f),_=!0}}if(m.size>0){let f=[...m.keys()].sort().join(", ");throw new Error(`compileSpec: unresolvable deps for nodes: ${f}`)}for(let[f,y]of Object.entries(n.nodes)){if(y.type!=="template")continue;let w=y,k=d[w.template],N=new Ee(f),O=new Map,R=[];for(let[E,A]of Object.entries(k.nodes)){let Q=(A.deps??[]).map(H=>H.startsWith("$")&&w.bind[H]?w.bind[H]:H),be={...A,deps:Q},z=ue(A),K=le(A);if(A.type==="state"){let H=kn(A),J=re(H,{name:E,meta:l(A.meta)});N.add(J,{name:E}),O.set(E,J)}else if(A.type==="producer"){let H=z?g(z):void 0,J=z?h(z):void 0;if(H){let V=H(K);N.add(V,{name:E}),O.set(E,V)}else if(J){let V=J([],K);N.add(V,{name:E}),O.set(E,V)}else{z&&p(`${f}.${E}`,"source",z);let V=oe(()=>{},{name:E,meta:{...l(A.meta),_specSource:z}});N.add(V,{name:E}),O.set(E,V)}}else R.push([E,be])}let S=!0,T=new Map(R);for(;T.size>0&&S;){S=!1;for(let[E,A]of[...T.entries()]){let Q=A.deps??[];if(!Q.every(ee=>O.has(ee)||v.has(ee)))continue;let z=Q.map(ee=>O.get(ee)??v.get(ee)),K=ue(A),H=le(A),J=K?h(K):void 0,V;J?V=J(z,H):A.type==="effect"?(K&&p(`${f}.${E}`,"fn",K),V=xe(z,()=>{})):(K&&p(`${f}.${E}`,"fn",K),V=ce(z,ee=>ee[0])),N.add(V,{name:E}),O.set(E,V),T.delete(E),S=!0}}if(T.size>0){let E=[...T.keys()].sort().join(", ");throw new Error(`compileSpec: template "${w.template}" has unresolvable deps: ${E}`)}a.mount(f,N);let P=`${f}::${k.output}`;v.set(f,a.resolve(P));try{let E=a.resolve(P);E.meta._templateName?.emit(w.template),E.meta._templateBind?.emit(w.bind)}catch{}}for(let f of n.feedback??[])_n(a,f.from,f.to,{maxIterations:f.maxIterations});if(u.length>0){if(i==="error"){let f=u.map(y=>` - ${y.path}: missing ${y.kind} "${y.name}"`);throw new Error(`compileSpec: ${u.length} catalog entr${u.length===1?"y":"ies"} missing \u2014 pass them via opts.catalog or set opts.onMissing to "warn"/"placeholder":
14
14
  ${f.join(`
15
- `)}`)}if(i==="warn"){let f=e?.onWarn??(b=>console.warn(b));for(let b of d)f(`compileSpec: ${b.path} references missing ${b.kind} "${b.name}" \u2014 substituted placeholder`)}}return a}var br=new Set(["reduction","reduction_type","_specFn","_specSource","_templateName","_templateBind","feedbackFrom","feedbackTo","_internal"]);function yr(n){let e=n.describe({detail:"spec"}),t=`::${U}::`,r=/^__feedback_(?!effect_)(.+)$/,s=[],o=new Set;for(let[u,c]of Object.entries(e.nodes))c.meta?.factory!=null&&!u.includes("::")&&o.add(u);let i={};for(let[u,c]of Object.entries(e.nodes)){if(u.includes(t))continue;let d=u.indexOf("::");if(d>0&&o.has(u.slice(0,d)))continue;if(r.exec(u)){let v=c.meta;v?.feedbackFrom&&v?.feedbackTo&&s.push({from:v.feedbackFrom,to:v.feedbackTo,...v.maxIterations?{maxIterations:v.maxIterations}:{}});continue}if(c.meta?._internal||u.startsWith("__feedback_effect_")||u.startsWith("__bridge_"))continue;let p=c.meta,h=p;if(p&&Object.keys(p).length>0){let v={};for(let[y,w]of Object.entries(p))br.has(y)||(v[y]=w);v.factory==="withStatus"?(delete v.status,delete v.error):v.factory==="withBreaker"?delete v.breakerState:v.factory==="verifiable"&&delete v.sourceVersion,h=Object.keys(v).length>0?v:void 0}let l={...c};h===void 0?delete l.meta:l.meta=h,i[u]=l}let a={...e,nodes:i};return delete a.expand,s.length>0&&(a.feedback=s),a}function vr(n,e){let t=[];n.name!==e.name&&t.push({type:"changed",path:"name",detail:`"${n.name}" \u2192 "${e.name}"`});let r=new Set(Object.keys(n.nodes)),s=new Set(Object.keys(e.nodes));for(let g of s)if(!r.has(g)){let f=e.nodes[g];t.push({type:"added",path:`nodes.${g}`,detail:`type: ${f.type}`})}for(let g of r)s.has(g)||t.push({type:"removed",path:`nodes.${g}`});for(let g of r){if(!s.has(g))continue;let f=n.nodes[g],b=e.nodes[g];if(JSON.stringify(f)!==JSON.stringify(b)){let _=[];f.type!==b.type&&_.push(`type: ${f.type} \u2192 ${b.type}`),JSON.stringify(f.deps)!==JSON.stringify(b.deps)&&_.push("deps changed");let k=f.type==="template"?void 0:ce(f),O=b.type==="template"?void 0:ce(b);k!==O&&_.push(`fn: ${k} \u2192 ${O}`);let T=f.type==="template"?void 0:ue(f),R=b.type==="template"?void 0:ue(b);JSON.stringify(T)!==JSON.stringify(R)&&_.push("config changed"),t.push({type:"changed",path:`nodes.${g}`,detail:_.join("; ")||"modified"})}}let o=n.templates??{},i=e.templates??{},a=new Set(Object.keys(o)),u=new Set(Object.keys(i));for(let g of u)a.has(g)||t.push({type:"added",path:`templates.${g}`});for(let g of a)u.has(g)||t.push({type:"removed",path:`templates.${g}`});for(let g of a)u.has(g)&&JSON.stringify(o[g])!==JSON.stringify(i[g])&&t.push({type:"changed",path:`templates.${g}`,detail:"template definition changed"});let c=n.feedback??[],d=e.feedback??[],m=new Set(c.map(g=>`${g.from}->${g.to}`)),p=new Set(d.map(g=>`${g.from}->${g.to}`));for(let g of d){let f=`${g.from}->${g.to}`;m.has(f)||t.push({type:"added",path:`feedback.${f}`,detail:`maxIterations: ${g.maxIterations??10}`})}for(let g of c){let f=`${g.from}->${g.to}`;p.has(f)||t.push({type:"removed",path:`feedback.${f}`})}for(let g of c){let f=`${g.from}->${g.to}`,b=d.find(_=>_.from===g.from&&_.to===g.to);b&&JSON.stringify(g)!==JSON.stringify(b)&&t.push({type:"changed",path:`feedback.${f}`,detail:`maxIterations: ${g.maxIterations??10} \u2192 ${b.maxIterations??10}`})}let h=t.filter(g=>g.type==="added").length,l=t.filter(g=>g.type==="removed").length,v=t.filter(g=>g.type==="changed").length,y=[];h&&y.push(`${h} added`),l&&y.push(`${l} removed`),v&&y.push(`${v} changed`);let w=y.length>0?y.join(", "):"no changes";return{entries:t,summary:w}}var On=`You are a graph architect for GraphReFly, a reactive graph protocol.
15
+ `)}`)}if(i==="warn"){let f=e?.onWarn??(y=>console.warn(y));for(let y of u)f(`compileSpec: ${y.path} references missing ${y.kind} "${y.name}" \u2014 substituted placeholder`)}}return a}var Or=new Set(["reduction","reduction_type","_specFn","_specSource","_templateName","_templateBind","feedbackFrom","feedbackTo","_internal"]);function xr(n){let e=n.describe({detail:"spec"}),t=`::${q}::`,r=/^__feedback_(?!effect_)(.+)$/,s=[],o=new Set;for(let[c,u]of Object.entries(e.nodes))u.meta?.factory!=null&&!c.includes("::")&&o.add(c);let i=new Set(Object.keys(e.nodes));for(let c of i){let u=c.indexOf("::");if(u<=0)continue;let p=c.slice(0,u);if(!c.includes(t)&&!(c.startsWith("__feedback_effect_")||c.startsWith("__bridge_"))&&!o.has(p)&&i.has(p))throw new Error(`decompileSpec: untagged compound factory at "${p}" (child: "${c}"). Compound factories that ship \`parent::child\` topology MUST set \`meta.factory\` on the parent so \`compileSpec\` can reconstruct the internals via the catalog. Either tag the parent (\`{ meta: factoryTag('myFactory', args) }\`) OR rename the child to use \`/\` instead of \`::\` if it's not a compound-factory internal (see COMPOSITION-GUIDE \xA738).`)}let a={};for(let[c,u]of Object.entries(e.nodes)){if(c.includes(t))continue;let p=c.indexOf("::");if(p>0&&o.has(c.slice(0,p)))continue;if(r.exec(c)){let b=u.meta;b?.feedbackFrom&&b?.feedbackTo&&s.push({from:b.feedbackFrom,to:b.feedbackTo,...b.maxIterations?{maxIterations:b.maxIterations}:{}});continue}if(u.meta?._internal||c.startsWith("__feedback_effect_")||c.startsWith("__bridge_"))continue;let g=u.meta,l=g;if(g&&Object.keys(g).length>0){let b={};for(let[_,m]of Object.entries(g))Or.has(_)||(b[_]=m);b.factory==="withStatus"?(delete b.status,delete b.error):b.factory==="withBreaker"?delete b.breakerState:b.factory==="verifiable"&&delete b.sourceVersion,l=Object.keys(b).length>0?b:void 0}let v={...u};l===void 0?delete v.meta:v.meta=l,a[c]=v}let d={...e,nodes:a};return delete d.expand,s.length>0&&(d.feedback=s),d}function Sr(n,e){let t=[];n.name!==e.name&&t.push({type:"changed",path:"name",detail:`"${n.name}" \u2192 "${e.name}"`});let r=new Set(Object.keys(n.nodes)),s=new Set(Object.keys(e.nodes));for(let m of s)if(!r.has(m)){let f=e.nodes[m];t.push({type:"added",path:`nodes.${m}`,detail:`type: ${f.type}`})}for(let m of r)s.has(m)||t.push({type:"removed",path:`nodes.${m}`});for(let m of r){if(!s.has(m))continue;let f=n.nodes[m],y=e.nodes[m];if(JSON.stringify(f)!==JSON.stringify(y)){let w=[];f.type!==y.type&&w.push(`type: ${f.type} \u2192 ${y.type}`),JSON.stringify(f.deps)!==JSON.stringify(y.deps)&&w.push("deps changed");let k=f.type==="template"?void 0:ue(f),N=y.type==="template"?void 0:ue(y);k!==N&&w.push(`fn: ${k} \u2192 ${N}`);let O=f.type==="template"?void 0:le(f),R=y.type==="template"?void 0:le(y);JSON.stringify(O)!==JSON.stringify(R)&&w.push("config changed"),t.push({type:"changed",path:`nodes.${m}`,detail:w.join("; ")||"modified"})}}let o=n.templates??{},i=e.templates??{},a=new Set(Object.keys(o)),d=new Set(Object.keys(i));for(let m of d)a.has(m)||t.push({type:"added",path:`templates.${m}`});for(let m of a)d.has(m)||t.push({type:"removed",path:`templates.${m}`});for(let m of a)d.has(m)&&JSON.stringify(o[m])!==JSON.stringify(i[m])&&t.push({type:"changed",path:`templates.${m}`,detail:"template definition changed"});let c=n.feedback??[],u=e.feedback??[],p=new Set(c.map(m=>`${m.from}->${m.to}`)),h=new Set(u.map(m=>`${m.from}->${m.to}`));for(let m of u){let f=`${m.from}->${m.to}`;p.has(f)||t.push({type:"added",path:`feedback.${f}`,detail:`maxIterations: ${m.maxIterations??10}`})}for(let m of c){let f=`${m.from}->${m.to}`;h.has(f)||t.push({type:"removed",path:`feedback.${f}`})}for(let m of c){let f=`${m.from}->${m.to}`,y=u.find(w=>w.from===m.from&&w.to===m.to);y&&JSON.stringify(m)!==JSON.stringify(y)&&t.push({type:"changed",path:`feedback.${f}`,detail:`maxIterations: ${m.maxIterations??10} \u2192 ${y.maxIterations??10}`})}let g=t.filter(m=>m.type==="added").length,l=t.filter(m=>m.type==="removed").length,v=t.filter(m=>m.type==="changed").length,b=[];g&&b.push(`${g} added`),l&&b.push(`${l} removed`),v&&b.push(`${v} changed`);let _=b.length>0?b.join(", "):"no changes";return{entries:t,summary:_}}var Sn=`You are a graph architect for GraphReFly, a reactive graph protocol.
16
16
 
17
17
  Given a natural-language description, produce a JSON GraphSpec with this structure:
18
18
 
@@ -58,20 +58,20 @@ Rules:
58
58
  - Use "templates" when the same subgraph pattern repeats (e.g., per-source resilience).
59
59
  - Use "feedback" for bounded cycles where a derived value writes back to a state node.
60
60
  - meta.description is required for every node.
61
- - Return ONLY valid JSON, no markdown fences or commentary.`;function Tn(n){let e=n.match(/^```(?:json)?\s*([\s\S]*?)\s*```[\s\S]*$/);return e?e[1]:n}async function _r(n,e,t){let r=On,s=t?.catalogDescription??(t?.catalog?Nn(t.catalog):void 0);s&&(r+=`
61
+ - Return ONLY valid JSON, no markdown fences or commentary.`;function Rn(n){let e=n.match(/^```(?:json)?\s*([\s\S]*?)\s*```[\s\S]*$/);return e?e[1]:n}async function Rr(n,e,t){let r=Sn,s=t?.catalogDescription??(t?.catalog?xn(t.catalog):void 0);s&&(r+=`
62
62
 
63
63
  Available catalog (use ONLY these names):
64
64
  ${s}`),t?.systemPromptExtra&&(r+=`
65
65
 
66
- ${t.systemPromptExtra}`);let o=[{role:"system",content:r},{role:"user",content:n}],u=(await e.invoke(o,{model:t?.model,temperature:t?.temperature??0,maxTokens:t?.maxTokens})).content.trim();u.startsWith("```")&&(u=Tn(u));let c;try{c=JSON.parse(u)}catch{throw new Error(`llmCompose: LLM response is not valid JSON: ${u.slice(0,200)}`)}let d=et(c);if(!d.valid)throw new Error(`llmCompose: invalid GraphSpec:
67
- ${d.errors.join(`
68
- `)}`);let m=c;if(t?.catalog){let p=t.maxAutoRefine??0;for(let h=0;h<=p;h++){let l=Nt(m,t.catalog);if(l.valid)break;if(h===p)throw new Error(`llmCompose: catalog validation failed after ${p} refine attempts:
66
+ ${t.systemPromptExtra}`);let o=[{role:"system",content:r},{role:"user",content:n}],d=(await e.invoke(o,{model:t?.model,temperature:t?.temperature??0,maxTokens:t?.maxTokens})).content.trim();d.startsWith("```")&&(d=Rn(d));let c;try{c=JSON.parse(d)}catch{throw new Error(`llmCompose: LLM response is not valid JSON: ${d.slice(0,200)}`)}let u=tt(c);if(!u.valid)throw new Error(`llmCompose: invalid GraphSpec:
67
+ ${u.errors.join(`
68
+ `)}`);let p=c;if(t?.catalog){let h=t.maxAutoRefine??0;for(let g=0;g<=h;g++){let l=Ot(p,t.catalog);if(l.valid)break;if(g===h)throw new Error(`llmCompose: catalog validation failed after ${h} refine attempts:
69
69
  ${l.errors.join(`
70
- `)}`);m=await xn(m,`Fix these catalog errors:
70
+ `)}`);p=await En(p,`Fix these catalog errors:
71
71
  ${l.errors.join(`
72
72
  `)}
73
73
 
74
- Use ONLY functions and sources from the catalog.`,e,{...t,catalogDescription:s})}}return m}async function xn(n,e,t,r){let s=On;r?.catalogDescription&&(s+=`
74
+ Use ONLY functions and sources from the catalog.`,e,{...t,catalogDescription:s})}}return p}async function En(n,e,t,r){let s=Sn;r?.catalogDescription&&(s+=`
75
75
 
76
76
  Available catalog:
77
77
  ${r.catalogDescription}`),r?.systemPromptExtra&&(s+=`
@@ -81,6 +81,6 @@ ${JSON.stringify(n,null,2)}
81
81
 
82
82
  Modification request: ${e}
83
83
 
84
- Return the complete modified GraphSpec as JSON.`}],u=(await t.invoke(o,{model:r?.model,temperature:r?.temperature??0,maxTokens:r?.maxTokens})).content.trim();u.startsWith("```")&&(u=Tn(u));let c;try{c=JSON.parse(u)}catch{throw new Error(`llmRefine: LLM response is not valid JSON: ${u.slice(0,200)}`)}let d=et(c);if(!d.valid)throw new Error(`llmRefine: invalid GraphSpec:
85
- ${d.errors.join(`
84
+ Return the complete modified GraphSpec as JSON.`}],d=(await t.invoke(o,{model:r?.model,temperature:r?.temperature??0,maxTokens:r?.maxTokens})).content.trim();d.startsWith("```")&&(d=Rn(d));let c;try{c=JSON.parse(d)}catch{throw new Error(`llmRefine: LLM response is not valid JSON: ${d.slice(0,200)}`)}let u=tt(c);if(!u.valid)throw new Error(`llmRefine: invalid GraphSpec:
85
+ ${u.errors.join(`
86
86
  `)}`);return c}0&&(module.exports={compileSpec,decompileSpec,extractFnFactory,extractSourceFactory,generateCatalogPrompt,isRichFnEntry,isRichSourceEntry,llmCompose,llmRefine,specDiff,validateSpec,validateSpecAgainstCatalog});