@graphrefly/graphrefly 0.28.0 → 0.30.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 (284) hide show
  1. package/dist/{cascading-D9WG1-9L.d.ts → cascading-BszPheHD.d.ts} +1 -1
  2. package/dist/{cascading-B-5zmAUv.d.cts → cascading-dNCtjW8j.d.cts} +1 -1
  3. package/dist/{chunk-OAWLCNJJ.js → chunk-2GQREQ6C.js} +1 -1
  4. package/dist/{chunk-DBGGMN3D.js → chunk-33FA6V4B.js} +1 -1
  5. package/dist/chunk-3NEPQO2E.js +43 -0
  6. package/dist/{chunk-UWJE5FQA.js → chunk-4C2OR2GH.js} +11 -11
  7. package/dist/chunk-4JJCCD5S.js +2 -0
  8. package/dist/{chunk-GHJJR5P4.js → chunk-4OFIQ66T.js} +1 -1
  9. package/dist/{chunk-PIOGHC63.js → chunk-567NWZ3T.js} +1 -1
  10. package/dist/chunk-5JDE5JHE.js +1 -0
  11. package/dist/{chunk-ETWTCCJI.js → chunk-5Z4HDCO6.js} +1 -1
  12. package/dist/{chunk-Y2EMPB3I.js → chunk-73Z3W2RN.js} +1 -1
  13. package/dist/{chunk-CRXTH3SH.js → chunk-7JDLFI6N.js} +1 -1
  14. package/dist/{chunk-DQA3UIQ2.js → chunk-7TDOES3L.js} +1 -1
  15. package/dist/{chunk-LBTDSCCO.js → chunk-AMBYCIOH.js} +1 -1
  16. package/dist/{chunk-D7A7DBE4.js → chunk-AUY2YKCO.js} +1 -1
  17. package/dist/{chunk-FNYWM6JC.js → chunk-AV3PIDFQ.js} +1 -1
  18. package/dist/{chunk-UMBIDLJ4.js → chunk-BA5URFYW.js} +1 -1
  19. package/dist/chunk-BKPLTBL5.js +1 -0
  20. package/dist/{chunk-UPXUCFMX.js → chunk-BZP5T4X6.js} +1 -1
  21. package/dist/{chunk-WQ2BN6X6.js → chunk-DDPYNMGG.js} +1 -1
  22. package/dist/{chunk-LQ3Y5NJS.js → chunk-GJR3P6JG.js} +1 -1
  23. package/dist/{chunk-3R5HFPX7.js → chunk-GLSM33ZM.js} +1 -1
  24. package/dist/{chunk-2FOAM3OR.js → chunk-GNCBXARM.js} +1 -1
  25. package/dist/{chunk-K2GNMCQT.js → chunk-ISCENNXS.js} +1 -1
  26. package/dist/{chunk-UPHHLMHE.js → chunk-IUK4EFCE.js} +1 -1
  27. package/dist/{chunk-ERLIRFPA.js → chunk-KA6MMXIY.js} +1 -1
  28. package/dist/{chunk-2PMCKKRK.js → chunk-KASHOCF5.js} +1 -1
  29. package/dist/chunk-LI3E75VE.js +64 -0
  30. package/dist/chunk-MGKAO4EK.js +7 -0
  31. package/dist/{chunk-ZV2DXV5A.js → chunk-NSG4C6BF.js} +1 -1
  32. package/dist/{chunk-4GKB4OUJ.js → chunk-OL33ZI6R.js} +1 -1
  33. package/dist/{chunk-76A3HVQE.js → chunk-P7JXGKDO.js} +1 -1
  34. package/dist/{chunk-U3AICJKU.js → chunk-RD52SNH2.js} +1 -1
  35. package/dist/{chunk-CWLN3X3N.js → chunk-SHYH5SXV.js} +1 -1
  36. package/dist/{chunk-VTPVOGHH.js → chunk-SLMYTGTU.js} +1 -1
  37. package/dist/{chunk-OYHGKYQM.js → chunk-T5SHIKJD.js} +1 -1
  38. package/dist/{chunk-VPYBOXVT.js → chunk-TWMEGG45.js} +1 -1
  39. package/dist/chunk-VIEUJSTT.js +1 -0
  40. package/dist/{chunk-SC3U7ETD.js → chunk-VWPRPPKR.js} +1 -1
  41. package/dist/chunk-W4TSQ6RJ.js +1 -0
  42. package/dist/{chunk-OBKQQA5I.js → chunk-WANIEEKV.js} +1 -1
  43. package/dist/{chunk-XAUNPIMX.js → chunk-XHVB6G6M.js} +1 -1
  44. package/dist/{chunk-MIQTDPY4.js → chunk-XQAXYVXX.js} +1 -1
  45. package/dist/{chunk-MTTAAPCK.js → chunk-Y32RJO24.js} +1 -1
  46. package/dist/{chunk-S35VARIR.js → chunk-Y36UZ5VS.js} +1 -1
  47. package/dist/compat/index.cjs +13 -12
  48. package/dist/compat/index.d.cts +14 -14
  49. package/dist/compat/index.d.ts +14 -14
  50. package/dist/compat/index.js +1 -1
  51. package/dist/compat/jotai/index.cjs +1 -1
  52. package/dist/compat/jotai/index.d.cts +2 -2
  53. package/dist/compat/jotai/index.d.ts +2 -2
  54. package/dist/compat/jotai/index.js +1 -1
  55. package/dist/compat/nanostores/index.cjs +1 -1
  56. package/dist/compat/nanostores/index.d.cts +2 -2
  57. package/dist/compat/nanostores/index.d.ts +2 -2
  58. package/dist/compat/nanostores/index.js +1 -1
  59. package/dist/compat/nestjs/index.cjs +13 -12
  60. package/dist/compat/nestjs/index.d.cts +6 -6
  61. package/dist/compat/nestjs/index.d.ts +6 -6
  62. package/dist/compat/nestjs/index.js +1 -1
  63. package/dist/compat/react/index.d.cts +2 -2
  64. package/dist/compat/react/index.d.ts +2 -2
  65. package/dist/compat/solid/index.d.cts +2 -2
  66. package/dist/compat/solid/index.d.ts +2 -2
  67. package/dist/compat/svelte/index.d.cts +2 -2
  68. package/dist/compat/svelte/index.d.ts +2 -2
  69. package/dist/compat/vue/index.d.cts +2 -2
  70. package/dist/compat/vue/index.d.ts +2 -2
  71. package/dist/compat/zustand/index.cjs +7 -6
  72. package/dist/compat/zustand/index.d.cts +4 -4
  73. package/dist/compat/zustand/index.d.ts +4 -4
  74. package/dist/compat/zustand/index.js +1 -1
  75. package/dist/{composite-BhbKHbOS.d.ts → composite-DGspwCqk.d.ts} +2 -2
  76. package/dist/{composite-B-xqw4Kk.d.cts → composite-nrRumJ7l.d.cts} +2 -2
  77. package/dist/core/index.cjs +1 -1
  78. package/dist/core/index.d.cts +4 -4
  79. package/dist/core/index.d.ts +4 -4
  80. package/dist/core/index.js +1 -1
  81. package/dist/extra/browser.cjs +1 -1
  82. package/dist/extra/browser.d.cts +1 -1
  83. package/dist/extra/browser.d.ts +1 -1
  84. package/dist/extra/browser.js +1 -1
  85. package/dist/extra/index.cjs +20 -19
  86. package/dist/extra/index.d.cts +9 -9
  87. package/dist/extra/index.d.ts +9 -9
  88. package/dist/extra/index.js +1 -1
  89. package/dist/extra/node.cjs +3 -3
  90. package/dist/extra/node.d.cts +1 -1
  91. package/dist/extra/node.d.ts +1 -1
  92. package/dist/extra/node.js +1 -1
  93. package/dist/extra/operators.cjs +1 -1
  94. package/dist/extra/operators.d.cts +1 -1
  95. package/dist/extra/operators.d.ts +1 -1
  96. package/dist/extra/operators.js +1 -1
  97. package/dist/extra/reactive.cjs +1 -1
  98. package/dist/extra/reactive.d.cts +3 -3
  99. package/dist/extra/reactive.d.ts +3 -3
  100. package/dist/extra/reactive.js +1 -1
  101. package/dist/extra/sources.cjs +1 -1
  102. package/dist/extra/sources.d.cts +1 -1
  103. package/dist/extra/sources.d.ts +1 -1
  104. package/dist/extra/sources.js +1 -1
  105. package/dist/extra/storage-browser.cjs +1 -1
  106. package/dist/extra/storage-browser.d.cts +1 -1
  107. package/dist/extra/storage-browser.d.ts +1 -1
  108. package/dist/extra/storage-browser.js +1 -1
  109. package/dist/graph/index.cjs +7 -6
  110. package/dist/graph/index.d.cts +5 -5
  111. package/dist/graph/index.d.ts +5 -5
  112. package/dist/graph/index.js +1 -1
  113. package/dist/{graph-D48Qw9Cg.d.cts → graph-C4Uxwv0T.d.cts} +22 -6
  114. package/dist/{graph-BZGRXwOm.d.ts → graph-CWeI0aHd.d.ts} +22 -6
  115. package/dist/{index-u15meRxL.d.cts → index-9iguV3bF.d.cts} +2 -2
  116. package/dist/{index-DyxjtScX.d.cts → index-B-z8WaSd.d.cts} +2 -2
  117. package/dist/{index-BgyGlizc.d.ts → index-B2HBxvMb.d.ts} +4 -4
  118. package/dist/{index-CzobVSMr.d.ts → index-B5iVOD7w.d.ts} +2 -2
  119. package/dist/{index-rX8HBM5h.d.cts → index-B8Aj_z8S.d.cts} +2 -2
  120. package/dist/{index-D-YB-Vl3.d.ts → index-BANwzwBV.d.ts} +3 -3
  121. package/dist/{index-HDpJe9hX.d.ts → index-BBINVimG.d.ts} +3 -3
  122. package/dist/{index-8FSVk4Uf.d.ts → index-BEpRsvhg.d.ts} +4 -4
  123. package/dist/{index-CHEswufn.d.cts → index-BHu_Wba0.d.cts} +4 -4
  124. package/dist/{index-ZftwfxJM.d.ts → index-BJHQUCZx.d.ts} +7 -7
  125. package/dist/{index-DUqMOlKZ.d.cts → index-BS220yqj.d.cts} +7 -7
  126. package/dist/{index-BWJV63ti.d.ts → index-BX22kvjh.d.ts} +1 -1
  127. package/dist/{index-DfyOkTvs.d.ts → index-BXbQUn4n.d.ts} +2 -2
  128. package/dist/{index-O6TgGUBV.d.cts → index-BpFWP7Bq.d.cts} +3 -3
  129. package/dist/{index-BxJ86YZZ.d.cts → index-Bs3-LC83.d.cts} +3 -3
  130. package/dist/{index-DiOXyAwt.d.ts → index-Bvi5uJxX.d.ts} +1 -1
  131. package/dist/{index-Bqachn9_.d.ts → index-ByPnK85n.d.ts} +1 -1
  132. package/dist/{index-CRO83MmV.d.cts → index-BydMDMf7.d.cts} +1 -1
  133. package/dist/{index-ROpQmGjE.d.ts → index-C5Ghnp5B.d.ts} +3 -3
  134. package/dist/{index-umtoWT8K.d.ts → index-C6NBfXj-.d.ts} +6 -5
  135. package/dist/{index-pXrDMpRO.d.cts → index-C98oJsEs.d.cts} +2 -2
  136. package/dist/{index-B2pwesl9.d.cts → index-CDK5RsV5.d.cts} +1 -1
  137. package/dist/{index-Czq6ynh8.d.ts → index-CFW32Dy1.d.ts} +3 -3
  138. package/dist/{index-Cyojz0AE.d.cts → index-CIXaiYDE.d.cts} +1 -1
  139. package/dist/{index-Oi8d8w4R.d.cts → index-CRAkoq-y.d.cts} +1 -1
  140. package/dist/{index-CpgYhnrG.d.ts → index-Cc8VQIgL.d.ts} +2 -2
  141. package/dist/{index-vscRDkjW.d.cts → index-CcpEvuPl.d.cts} +2 -2
  142. package/dist/{index-BpA5c4G9.d.ts → index-CfFYyLR8.d.ts} +4 -4
  143. package/dist/{index-9oDeHH2u.d.cts → index-ClB7TCfL.d.cts} +2 -2
  144. package/dist/{index-BHvIquRZ.d.ts → index-ClgKmOHe.d.ts} +592 -492
  145. package/dist/{index-DpHe5e0Q.d.ts → index-CotRMjtJ.d.ts} +2 -2
  146. package/dist/{index-B1AmmSlb.d.ts → index-CrC7urhX.d.ts} +1 -1
  147. package/dist/{index-B0c4cmIO.d.ts → index-CvS9IuTG.d.ts} +2 -2
  148. package/dist/{index-rHJSKsU8.d.cts → index-Cy7eFeIX.d.cts} +2 -2
  149. package/dist/{index-BVHOrDwO.d.ts → index-D0C_USMR.d.ts} +1 -1
  150. package/dist/{index-DEwTb_fm.d.cts → index-D6ajK8Mh.d.cts} +592 -492
  151. package/dist/{index-DL-rYJrx.d.cts → index-D7XxY1Ff.d.cts} +1 -1
  152. package/dist/{index-DAlweici.d.ts → index-D9HrBx2J.d.ts} +2 -2
  153. package/dist/{index-fM6y00vT.d.cts → index-D9Y_u6BG.d.cts} +3 -3
  154. package/dist/{index-DcXZBF5a.d.cts → index-DBQUKh59.d.cts} +4 -4
  155. package/dist/{index-D_NwnRYS.d.cts → index-DDo-eqQ4.d.cts} +1 -1
  156. package/dist/{index-m-yHof5p.d.ts → index-DGb1awva.d.ts} +4 -4
  157. package/dist/{index-DxsnAMWD.d.cts → index-DR3gf_DG.d.cts} +9 -9
  158. package/dist/{index-dtN7YA2x.d.cts → index-DVNLe3pS.d.cts} +3 -3
  159. package/dist/{index-Btib9rsU.d.ts → index-Dljd76bC.d.ts} +275 -9
  160. package/dist/{index-DP4ZTkdw.d.ts → index-DnrZghBB.d.ts} +3 -3
  161. package/dist/{index-DaLJvH8Z.d.ts → index-Docdiu9a.d.ts} +3 -3
  162. package/dist/{index-BpIFjILY.d.cts → index-DylQCKEL.d.cts} +4 -4
  163. package/dist/{index-B_agccPe.d.cts → index-FBqTfL_S.d.cts} +1 -1
  164. package/dist/{index-DraikLjn.d.ts → index-FrYrV-Vf.d.ts} +2 -2
  165. package/dist/{index-sm373fsH.d.ts → index-IZ3l_vQ9.d.ts} +2 -2
  166. package/dist/{index-BwM9BEkt.d.ts → index-Ip3q9T9x.d.ts} +1 -1
  167. package/dist/{index-CloUk1kY.d.ts → index-RQg6lTrN.d.ts} +9 -9
  168. package/dist/{index-CEXXwWVH.d.cts → index-SSGqF8mI.d.cts} +2 -2
  169. package/dist/{index-rnwQly8X.d.cts → index-UZO988ox.d.cts} +6 -5
  170. package/dist/{index-C73n7lo-.d.cts → index-iBp74eGU.d.cts} +3 -3
  171. package/dist/{index-tbf2gKHd.d.cts → index-lKuLYmHO.d.cts} +3 -3
  172. package/dist/{index-CMn8S8Hw.d.ts → index-wIx1Jisk.d.ts} +1 -1
  173. package/dist/{index-cByzxQIC.d.cts → index-yIdWFo2b.d.cts} +4 -4
  174. package/dist/{index-RukJ4DLS.d.cts → index-ybtSyjWB.d.cts} +275 -9
  175. package/dist/index.cjs +53 -52
  176. package/dist/index.d.cts +42 -42
  177. package/dist/index.d.ts +42 -42
  178. package/dist/index.js +1 -1
  179. package/dist/{meta-CwesDrMD.d.ts → meta-BMwx3ExI.d.ts} +1 -1
  180. package/dist/{meta-Cgj6zeji.d.cts → meta-COtmHLwT.d.cts} +1 -1
  181. package/dist/{node-Cc1TniY8.d.ts → node-BVV7G1bq.d.cts} +59 -2
  182. package/dist/{node-Cc1TniY8.d.cts → node-BVV7G1bq.d.ts} +59 -2
  183. package/dist/{observable-glXQoGj2.d.cts → observable-BrUAPeH_.d.cts} +1 -1
  184. package/dist/{observable-Ct-gJ9jI.d.ts → observable-ITikPXz3.d.ts} +1 -1
  185. package/dist/patterns/ai/browser.d.cts +3 -3
  186. package/dist/patterns/ai/browser.d.ts +3 -3
  187. package/dist/patterns/ai/browser.js +1 -1
  188. package/dist/patterns/ai/index.cjs +25 -24
  189. package/dist/patterns/ai/index.d.cts +15 -15
  190. package/dist/patterns/ai/index.d.ts +15 -15
  191. package/dist/patterns/ai/index.js +1 -1
  192. package/dist/patterns/ai/node.d.cts +1 -1
  193. package/dist/patterns/ai/node.d.ts +1 -1
  194. package/dist/patterns/ai/node.js +1 -1
  195. package/dist/patterns/audit/index.cjs +7 -6
  196. package/dist/patterns/audit/index.d.cts +5 -5
  197. package/dist/patterns/audit/index.d.ts +5 -5
  198. package/dist/patterns/audit/index.js +1 -1
  199. package/dist/patterns/cqrs/index.cjs +7 -6
  200. package/dist/patterns/cqrs/index.d.cts +4 -4
  201. package/dist/patterns/cqrs/index.d.ts +4 -4
  202. package/dist/patterns/cqrs/index.js +1 -1
  203. package/dist/patterns/demo-shell/index.cjs +8 -7
  204. package/dist/patterns/demo-shell/index.d.cts +5 -5
  205. package/dist/patterns/demo-shell/index.d.ts +5 -5
  206. package/dist/patterns/demo-shell/index.js +1 -1
  207. package/dist/patterns/domain-templates/index.cjs +7 -6
  208. package/dist/patterns/domain-templates/index.d.cts +4 -4
  209. package/dist/patterns/domain-templates/index.d.ts +4 -4
  210. package/dist/patterns/domain-templates/index.js +1 -1
  211. package/dist/patterns/graphspec/index.cjs +26 -25
  212. package/dist/patterns/graphspec/index.d.cts +4 -4
  213. package/dist/patterns/graphspec/index.d.ts +4 -4
  214. package/dist/patterns/graphspec/index.js +1 -1
  215. package/dist/patterns/guarded-execution/index.cjs +7 -6
  216. package/dist/patterns/guarded-execution/index.d.cts +6 -6
  217. package/dist/patterns/guarded-execution/index.d.ts +6 -6
  218. package/dist/patterns/guarded-execution/index.js +1 -1
  219. package/dist/patterns/harness/index.cjs +11 -10
  220. package/dist/patterns/harness/index.d.cts +10 -7
  221. package/dist/patterns/harness/index.d.ts +10 -7
  222. package/dist/patterns/harness/index.js +1 -1
  223. package/dist/patterns/job-queue/index.cjs +7 -6
  224. package/dist/patterns/job-queue/index.d.cts +4 -4
  225. package/dist/patterns/job-queue/index.d.ts +4 -4
  226. package/dist/patterns/job-queue/index.js +1 -1
  227. package/dist/patterns/lens/index.cjs +7 -6
  228. package/dist/patterns/lens/index.d.cts +6 -6
  229. package/dist/patterns/lens/index.d.ts +6 -6
  230. package/dist/patterns/lens/index.js +1 -1
  231. package/dist/patterns/memory/index.cjs +7 -6
  232. package/dist/patterns/memory/index.d.cts +4 -4
  233. package/dist/patterns/memory/index.d.ts +4 -4
  234. package/dist/patterns/memory/index.js +1 -1
  235. package/dist/patterns/messaging/index.cjs +7 -6
  236. package/dist/patterns/messaging/index.d.cts +4 -4
  237. package/dist/patterns/messaging/index.d.ts +4 -4
  238. package/dist/patterns/messaging/index.js +1 -1
  239. package/dist/patterns/orchestration/index.cjs +7 -6
  240. package/dist/patterns/orchestration/index.d.cts +5 -5
  241. package/dist/patterns/orchestration/index.d.ts +5 -5
  242. package/dist/patterns/orchestration/index.js +1 -1
  243. package/dist/patterns/reactive-layout/index.cjs +8 -7
  244. package/dist/patterns/reactive-layout/index.d.cts +5 -5
  245. package/dist/patterns/reactive-layout/index.d.ts +5 -5
  246. package/dist/patterns/reactive-layout/index.js +1 -1
  247. package/dist/patterns/reduction/index.cjs +7 -6
  248. package/dist/patterns/reduction/index.d.cts +4 -4
  249. package/dist/patterns/reduction/index.d.ts +4 -4
  250. package/dist/patterns/reduction/index.js +1 -1
  251. package/dist/patterns/refine-loop/index.cjs +9 -8
  252. package/dist/patterns/refine-loop/index.d.cts +5 -5
  253. package/dist/patterns/refine-loop/index.d.ts +5 -5
  254. package/dist/patterns/refine-loop/index.js +1 -1
  255. package/dist/patterns/resilient-pipeline/index.cjs +1 -1
  256. package/dist/patterns/resilient-pipeline/index.d.cts +6 -6
  257. package/dist/patterns/resilient-pipeline/index.d.ts +6 -6
  258. package/dist/patterns/resilient-pipeline/index.js +1 -1
  259. package/dist/patterns/surface/index.cjs +14 -13
  260. package/dist/patterns/surface/index.d.cts +5 -5
  261. package/dist/patterns/surface/index.d.ts +5 -5
  262. package/dist/patterns/surface/index.js +1 -1
  263. package/dist/{reactive-layout-CpYb5qLP.d.cts → reactive-layout-5oEn8lHM.d.cts} +2 -2
  264. package/dist/{reactive-layout-D8u4wuUR.d.ts → reactive-layout-BAr6-_o5.d.ts} +2 -2
  265. package/dist/{reactive-log-DPzuUDj5.d.cts → reactive-log-5jFeNRmd.d.cts} +1 -1
  266. package/dist/{reactive-log-YuH9VYN8.d.ts → reactive-log-BOJDCI5x.d.ts} +1 -1
  267. package/dist/{reactive-map-CdbNoSgP.d.ts → reactive-map-BvDrRuwt.d.ts} +1 -1
  268. package/dist/{reactive-map-DUeRmb9d.d.cts → reactive-map-CmlPPKHN.d.cts} +1 -1
  269. package/dist/{resilience-CGRzhnD3.d.ts → resilience-CludlzcP.d.ts} +1 -1
  270. package/dist/{resilience-Ba5-b4WD.d.cts → resilience-Q6Bt_7y0.d.cts} +1 -1
  271. package/dist/{resilience-QAHKANT5.js → resilience-XRUF267O.js} +1 -1
  272. package/dist/{sugar-BV0htudb.d.cts → sugar-BHbAACDG.d.ts} +10 -12
  273. package/dist/{sugar-Dtyrq2_q.d.ts → sugar-CqR6DJ7v.d.cts} +10 -12
  274. package/dist/{topology-tree-DROUdq5B.d.cts → topology-tree-CVREibAc.d.cts} +1 -1
  275. package/dist/{topology-tree-CYHOwQZ_.d.ts → topology-tree-CkjojcB6.d.ts} +1 -1
  276. package/package.json +1 -1
  277. package/dist/chunk-6V3SEX2I.js +0 -1
  278. package/dist/chunk-7H6LGFUG.js +0 -64
  279. package/dist/chunk-CKCSDI7T.js +0 -6
  280. package/dist/chunk-QWAPKG3O.js +0 -2
  281. package/dist/chunk-RHESUC3V.js +0 -43
  282. package/dist/chunk-V6YQICXZ.js +0 -1
  283. package/dist/chunk-Z4HDAS2Q.js +0 -1
  284. package/dist/chunk-ZB5EHBIO.js +0 -1
@@ -1,19 +1,20 @@
1
- "use strict";var Je=Object.defineProperty;var cn=Object.getOwnPropertyDescriptor;var dn=Object.getOwnPropertyNames;var un=Object.prototype.hasOwnProperty;var K=(r,e)=>()=>(r&&(e=r(r=0)),e);var ln=(r,e)=>{for(var t in e)Je(r,t,{get:e[t],enumerable:!0})},fn=(r,e,t,n)=>{if(e&&typeof e=="object"||typeof e=="function")for(let s of dn(e))!un.call(r,s)&&s!==t&&Je(r,s,{get:()=>e[s],enumerable:!(n=cn(e,s))||n.enumerable});return r};var pn=r=>fn(Je({},"__esModule",{value:!0}),r);var be,j,H,V,Y,X,Z,B,z,M,ie,Ye,hn,Xe,gn,mn,Ze,yt,vt,_t,Qe,te=K(()=>{"use strict";be=Symbol.for("graphrefly/START"),j=Symbol.for("graphrefly/DATA"),H=Symbol.for("graphrefly/DIRTY"),V=Symbol.for("graphrefly/RESOLVED"),Y=Symbol.for("graphrefly/INVALIDATE"),X=Symbol.for("graphrefly/PAUSE"),Z=Symbol.for("graphrefly/RESUME"),B=Symbol.for("graphrefly/TEARDOWN"),z=Symbol.for("graphrefly/COMPLETE"),M=Symbol.for("graphrefly/ERROR"),ie=Object.freeze([H]),Ye=Object.freeze([V]),hn=Object.freeze([Y]),Xe=Object.freeze([be]),gn=Object.freeze([z]),mn=Object.freeze([B]),Ze=Object.freeze([ie]),yt=Object.freeze([Ye]),vt=Object.freeze([hn]),_t=Object.freeze([gn]),Qe=Object.freeze([mn])});function Ot(r,e){let t=new TextEncoder().encode(r.name);if(t.length===0||t.length>255)throw new Error(`encodeEnvelope: codec name "${r.name}" encodes to ${t.length} bytes (must be 1\u2013255)`);let n=r.version;if(!Number.isInteger(n)||n<0||n>65535)throw new Error(`encodeEnvelope: codec.version ${n} out of u16 range (expected integer 0\u201365535)`);let s=2+t.length+2+e.length;if(s>4294967295)throw new Error(`encodeEnvelope: total envelope size ${s} exceeds 2^32-1 bytes (payload ${e.length} bytes)`);let o=new Uint8Array(s),i=0;return o[i++]=et,o[i++]=t.length,o.set(t,i),i+=t.length,o[i++]=n>>>8&255,o[i++]=n&255,o.set(e,i),o}function kt(r,e){if(r.length<wt)throw new Error(`decodeEnvelope: bytes too short (${r.length} < ${wt})`);let t=0,n=r[t++];if(n!==et)throw new Error(`decodeEnvelope: unsupported envelope version ${n} (expected ${et})`);let s=r[t++];if(s===0)throw new Error("decodeEnvelope: name_len must be >= 1");if(t+s+2>r.length)throw new Error(`decodeEnvelope: envelope truncated (need ${t+s+2} bytes, have ${r.length})`);let o=new TextDecoder().decode(r.subarray(t,t+s));t+=s;let i=(r[t]<<8|r[t+1])>>>0;t+=2;let a=r.subarray(t),c=e.lookupCodec(o);if(c==null)throw new Error(`decodeEnvelope: codec "${o}" not registered (envelope codec_v=${i})`);return{codec:c,codecVersion:i,payload:a}}function Nt(r){r.registerCodec(bn)}var bn,et,wt,tt=K(()=>{"use strict";bn={name:"json",version:1,contentType:"application/json",encode(r){let e=JSON.stringify(r);return new TextEncoder().encode(e)},decode(r,e){let t=new TextDecoder().decode(r);return JSON.parse(t)}},et=1,wt=4});function xe(r){if(r==null)return ae;let{type:e,id:t,...n}=r;return{type:e??"system",id:t??"",...n}}var ae,nt=K(()=>{"use strict";ae={type:"system",id:""}});function Te(){return ce>0||ye}function St(){return ce>0}function _e(r){ce>0?ve.push(r):r()}function Ee(r){ce+=1;let e=!1;try{r()}catch(t){throw e=!0,t}finally{if(ce-=1,ce===0)if(e){if(!ye){let t=ve.splice(0);for(let n of t)try{n()}catch{}ne.length=0,re.length=0,de.length=0}}else yn()}}function yn(){let r=!ye;r&&(ye=!0);let e=[],t=0;try{for(;ne.length>0||re.length>0||de.length>0||r&&ve.length>0;){if(r&&ve.length>0){let o=ve.splice(0);for(let i of o)try{i()}catch(a){e.push(a)}continue}if(t+=1,t>1e3)throw ne.length=0,re.length=0,de.length=0,new Error("batch drain exceeded 1000 iterations \u2014 likely a reactive cycle");let s=(ne.length>0?ne:re.length>0?re:de).splice(0);for(let o of s)try{o()}catch(i){e.push(i)}}}finally{r&&(ye=!1)}if(e.length===1)throw e[0];if(e.length>1)throw new AggregateError(e,"batch drain: multiple callbacks threw")}function Re(r,e,t){if(e.length===0)return;if(e.length===1){let d=t(e[0][0]);if(d<3||!Te()){r(e);return}(d>=5?de:d===4?re:ne).push(()=>r(e));return}let n=e.length,s=n,o=n,i=n,a=0;for(;a<n&&t(e[a][0])<3;)a++;for(s=a;a<n&&t(e[a][0])===3;)a++;for(o=a;a<n&&t(e[a][0])===4;)a++;i=a;let c=Te();if(s>0){let d=e.slice(0,s);r(d)}if(o>s){let d=e.slice(s,o);c?ne.push(()=>r(d)):r(d)}if(i>o){let d=e.slice(o,i);c?re.push(()=>r(d)):r(d)}if(n>i){let d=e.slice(i,n);c?de.push(()=>r(d)):r(d)}}var ce,ye,ne,re,de,ve,Ae=K(()=>{"use strict";ce=0,ye=!1,ne=[],re=[],de=[],ve=[]});function ue(){return Math.trunc(performance.now()*1e6)}function De(){return Date.now()*1e6}var rt=K(()=>{"use strict"});function xt(r){r.registerMessageType(be,{tier:0,wireCrossing:!1}),r.registerMessageType(H,{tier:1,wireCrossing:!1}),r.registerMessageType(Y,{tier:1,wireCrossing:!1,metaPassthrough:!1}),r.registerMessageType(X,{tier:2,wireCrossing:!1}),r.registerMessageType(Z,{tier:2,wireCrossing:!1}),r.registerMessageType(j,{tier:3,wireCrossing:!0}),r.registerMessageType(V,{tier:3,wireCrossing:!0}),r.registerMessageType(z,{tier:4,wireCrossing:!0,metaPassthrough:!1}),r.registerMessageType(M,{tier:4,wireCrossing:!0,metaPassthrough:!1}),r.registerMessageType(B,{tier:5,wireCrossing:!0,metaPassthrough:!1})}var $e,Tt=K(()=>{"use strict";te();$e=class{_messageTypes=new Map;_codecs=new Map;_onMessage;_onSubscribe;_defaultVersioning;_defaultHashFn;_inspectorEnabled=!(typeof process<"u"&&process.env?.NODE_ENV==="production");_globalInspector;_frozen=!1;tierOf;constructor(e){this._onMessage=e.onMessage,this._onSubscribe=e.onSubscribe,this._defaultVersioning=e.defaultVersioning,this._defaultHashFn=e.defaultHashFn,this.tierOf=t=>{let n=this._messageTypes.get(t);return n!=null?n.tier:1}}get onMessage(){return this._frozen=!0,this._onMessage}get onSubscribe(){return this._frozen=!0,this._onSubscribe}set onMessage(e){this._assertUnfrozen(),this._onMessage=e}set onSubscribe(e){this._assertUnfrozen(),this._onSubscribe=e}get defaultVersioning(){return this._defaultVersioning}set defaultVersioning(e){this._assertUnfrozen(),this._defaultVersioning=e}get defaultHashFn(){return this._defaultHashFn}set defaultHashFn(e){this._assertUnfrozen(),this._defaultHashFn=e}get inspectorEnabled(){return this._inspectorEnabled}set inspectorEnabled(e){this._inspectorEnabled=e}get globalInspector(){return this._globalInspector}set globalInspector(e){this._globalInspector=e}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 st(r){let e=vn.filter(t=>r({type:t,id:""},"write"));return e.length===0?"restricted":e.includes("human")&&e.includes("llm")&&e.every(t=>t==="human"||t==="llm"||t==="system")?"both":e.length===1?e[0]:e.join("+")}var J,vn,Ge=K(()=>{"use strict";J=class extends Error{actor;action;nodeName;constructor(e,t){super(t??`GuardDenied: action "${String(e.action)}" denied for actor type "${String(e.actor.type)}"`),this.name="GuardDenied",this.actor=e.actor,this.action=e.action,this.nodeName=e.nodeName}get node(){return this.nodeName}},vn=["human","llm","wallet","system"]});function ot(r){if(r===void 0)return null;if(typeof r=="number"){if(!Number.isFinite(r))throw new TypeError(`Cannot hash non-finite number: ${r}`);if(Number.isInteger(r)&&!Number.isSafeInteger(r))throw new TypeError(`Cannot hash integer outside safe range (|n| > 2^53-1): ${r}. Cross-language cid parity is not guaranteed for unsafe integers.`);return r}if(typeof r=="string"||typeof r=="boolean"||r===null)return r;if(Array.isArray(r))return r.map(ot);if(typeof r=="object"&&r!==null){let e={};for(let t of Object.keys(r).sort())e[t]=ot(r[t]);return e}return null}function On(r){let e=wn.encode(r),t=e.length,n=t*8,s=t+9+63&-64,o=new Uint8Array(s);o.set(e),o[t]=128;let i=new DataView(o.buffer);i.setUint32(s-4,n>>>0,!1),i.setUint32(s-8,Math.floor(n/4294967296)>>>0,!1);let a=1779033703,c=3144134277,d=1013904242,f=2773480762,g=1359893119,m=2600822924,l=528734635,u=1541459225,h=new Uint32Array(64),b=(p,y)=>p>>>y|p<<32-y;for(let p=0;p<s;p+=64){for(let x=0;x<16;x++)h[x]=i.getUint32(p+x*4,!1);for(let x=16;x<64;x++){let T=h[x-15],S=h[x-2],A=b(T,7)^b(T,18)^T>>>3,I=b(S,17)^b(S,19)^S>>>10;h[x]=h[x-16]+A+h[x-7]+I>>>0}let y=a,w=c,k=d,N=f,_=g,O=m,R=l,$=u;for(let x=0;x<64;x++){let T=b(_,6)^b(_,11)^b(_,25),S=_&O^~_&R,A=$+T+S+_n[x]+h[x]>>>0,I=b(y,2)^b(y,13)^b(y,22),ee=y&w^y&k^w&k,Ne=I+ee>>>0;$=R,R=O,O=_,_=N+A>>>0,N=k,k=w,w=y,y=A+Ne>>>0}a=a+y>>>0,c=c+w>>>0,d=d+k>>>0,f=f+N>>>0,g=g+_>>>0,m=m+O>>>0,l=l+R>>>0,u=u+$>>>0}let v=p=>p.toString(16).padStart(8,"0");return v(a)+v(c)+v(d)+v(f)+v(g)+v(m)+v(l)+v(u)}function it(r){let e=ot(r??null),t=JSON.stringify(e);return On(t).slice(0,16)}function kn(){let r=globalThis.crypto;if(r?.randomUUID)return r.randomUUID();let e=()=>Math.floor(Math.random()*4294967296).toString(16).padStart(8,"0"),t=e()+e()+e()+e();return`${t.slice(0,8)}-${t.slice(8,12)}-4${t.slice(13,16)}-${(parseInt(t.slice(16,17),16)&3|8).toString(16)}${t.slice(17,20)}-${t.slice(20,32)}`}function at(r,e,t){let n=t?.id??kn();if(r===0)return{id:n,version:0};let o=(t?.hash??it)(e);return{id:n,version:0,cid:o,prev:null}}function Et(r,e,t){r.version+=1,"cid"in r&&(r.prev=r.cid,r.cid=t(e))}var _n,wn,Rt=K(()=>{"use strict";_n=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]),wn=new TextEncoder});function $t(r){return{node:r,unsub:null,prevData:void 0,dirty:!1,involvedThisWave:!1,dataBatch:[],terminal:void 0}}function ct(r){r.prevData=void 0,r.dirty=!1,r.involvedThisWave=!1,r.dataBatch.length=0,r.terminal=void 0}function Ce(r){return r.length===0?r:typeof r[0]=="symbol"?[r]:r}function se(r,e,t){let n=Gt(r)?r:[],s=typeof r=="function"?r:typeof e=="function"?e:void 0,o={};return Gt(r)?o=(dt(e)?e:t)??{}:dt(r)?o=r:o=(dt(e)?e:t)??{},new F(n,s,o)}var At,Dt,Nn,Sn,le,F,Gt,dt,fe=K(()=>{"use strict";tt();nt();Ae();rt();Tt();Ge();te();Rt();At=()=>{},Dt=100;Nn=(r,e,t,n)=>{t.direction==="down-in"&&r._onDepMessage(t.depIndex,e)},Sn=(r,e,t,n)=>{let s=r;if(s._status==="completed"||s._status==="errored")return;let o=s._cached,i=o===void 0?[Xe]:[Xe,[j,o]];s._status==="dirty"&&i.push(ie),Re(e,i,s._config.tierOf)},le=new $e({onMessage:Nn,onSubscribe:Sn});xt(le);Nt(le);F=class r{_optsName;_describeKind;meta;_hasMeta;_config;_deps;_sinks=null;_sinkCount=0;_cached;_status;_cleanup;_store={};_waveHasNewData=!1;_hasNewTerminal=!1;_hasCalledFnOnce=!1;_paused=!1;_pendingWave=!1;_isExecutingFn=!1;_pendingRerun=!1;_rerunDepth=0;_dirtyDepCount=0;_batchPendingMessages=null;_pauseLocks=null;_pauseBuffer=null;_fn;_equals;_resubscribable;_resetOnTeardown;_autoComplete;_autoError;_pausable;_guard;_extraGuards;_hashFn;_versioning;_versioningLevel;_lastMutation;_inspectorHooks;_actions;constructor(e,t,n){this._config=n.config??le,this._config.onMessage,this._optsName=n.name,this._describeKind=n.describeKind,this._equals=n.equals??Object.is,this._resubscribable=n.resubscribable??!1,this._resetOnTeardown=n.resetOnTeardown??!1,this._autoComplete=n.completeWhenDepsComplete??!0,this._autoError=n.errorWhenDepsError??!0,this._pausable=n.pausable??!0,this._guard=n.guard,this._fn=t,this._cached=n.initial!==void 0?n.initial:void 0,this._status=e.length===0&&t==null&&this._cached!==void 0?"settled":"sentinel",this._hashFn=n.versioningHash??this._config.defaultHashFn??it;let s=n.versioning??this._config.defaultVersioning;this._versioningLevel=s,this._versioning=s!=null?at(s,this._cached===void 0?void 0:this._cached,{id:n.versioningId,hash:this._hashFn}):void 0,this._deps=e.map($t);let o={};for(let[a,c]of Object.entries(n.meta??{})){let d={initial:c,name:`${n.name??"node"}:meta:${a}`,describeKind:"state",config:this._config};n.guard!=null&&(d.guard=n.guard),o[a]=new r([],void 0,d)}Object.freeze(o),this.meta=o,this._hasMeta=Object.keys(o).length>0;let i=this;this._actions={emit(a){i._emit([[j,a]])},down(a){i._emit(Ce(a))},up(a){i._emitUp(Ce(a))}},this.down=this.down.bind(this),this.up=this.up.bind(this)}get _isTerminal(){return this._status==="completed"||this._status==="errored"}get name(){return this._optsName}get status(){return this._status}get cache(){return this._cached===void 0?void 0:this._cached}get lastMutation(){return this._lastMutation}get v(){return this._versioning}hasGuard(){return this._guard!=null}_applyVersioning(e,t){if(this._isExecutingFn)throw new Error(`Node "${this.name}": _applyVersioning cannot run mid-fn \u2014 call it outside of \`_execFn\` (typically at graph setup time before the first subscribe).`);let n=this._versioningLevel;if(n!=null&&e<=n)return;let s=t?.hash??this._hashFn;s!==this._hashFn&&(this._hashFn=s);let o=this._cached===void 0?void 0:this._cached,i=this._versioning,a=i?.id??t?.id,c=i?.version??0,d=at(e,o,{id:a,hash:s});d.version=c,this._versioning=d,this._versioningLevel=e}_setInspectorHook(e){return e==null?()=>{}:(this._inspectorHooks==null&&(this._inspectorHooks=new Set),this._inspectorHooks.add(e),()=>{this._inspectorHooks?.delete(e),this._inspectorHooks?.size===0&&(this._inspectorHooks=void 0)})}_pushGuard(e){return this._extraGuards==null&&(this._extraGuards=new Set),this._extraGuards.add(e),()=>{this._extraGuards?.delete(e),this._extraGuards?.size===0&&(this._extraGuards=void 0)}}allowsObserve(e){if(this._guard==null&&this._extraGuards==null)return!0;let t=xe(e);if(this._guard!=null&&!this._guard(t,"observe"))return!1;if(this._extraGuards!=null){for(let n of this._extraGuards)if(!n(t,"observe"))return!1}return!0}_checkGuard(e){if(e?.internal)return;let t=this._guard!=null||this._extraGuards!=null,n=e?.actor!=null;if(!t&&!n)return;let s=xe(e?.actor),o=e?.delivery==="signal"?"signal":"write";if(this._guard!=null&&!this._guard(s,o))throw new J({actor:s,action:o,nodeName:this.name});if(this._extraGuards!=null){for(let i of this._extraGuards)if(!i(s,o))throw new J({actor:s,action:o,nodeName:this.name})}this._lastMutation={actor:s,timestamp_ns:De()}}down(e,t){let n=Ce(e);n.length!==0&&(this._checkGuard(t),this._emit(n))}emit(e,t){this._checkGuard(t),this._emit([[j,e]])}up(e,t){if(this._deps.length===0)return;let n=Ce(e);if(n.length===0)return;this._checkGuard(t);let s=t??{internal:!0};this._validateUpTiers(n);for(let o of this._deps)o.node.up?.(n,s)}_emitUp(e){if(this._deps.length!==0&&e.length!==0){this._validateUpTiers(e);for(let t of this._deps)t.node.up?.(e,{internal:!0})}}_validateUpTiers(e){let t=this._config.tierOf;for(let n of e){let s=t(n[0]);if(s===3||s===4)throw new Error(`Node "${this.name}": tier-${s} messages cannot flow up \u2014 DATA/RESOLVED/COMPLETE/ERROR are downstream-only. Use \`down(...)\` for value delivery; \`up(...)\` is for control signals (DIRTY, INVALIDATE, PAUSE, RESUME, TEARDOWN).`)}}subscribe(e,t){if(t!=null&&this._guard!=null){let c=xe(t);if(!this._guard(c,"observe"))throw new J({actor:c,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 c of this._deps)ct(c)}this._sinkCount+=1;let o;try{o=this._config.onSubscribe(this,e,{sinkCount:this._sinkCount,afterTerminalReset:s},this._actions)}catch(c){throw this._sinkCount-=1,c}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(c){if(this._sinkCount-=1,this._removeSink(e),this._sinkCount===0&&(this._status="sentinel"),typeof o=="function")try{o()}catch{}throw c}this._status==="sentinel"&&this._cached===void 0&&(this._status="pending");let a=!1;return()=>{a||(a=!0,this._sinkCount-=1,this._removeSink(e),typeof o=="function"&&o(),this._sinks==null&&this._deactivate())}}_removeSink(e){if(this._sinks===e)this._sinks=null;else if(this._sinks!=null&&typeof this._sinks!="function")if(this._sinks.delete(e),this._sinks.size===1){let[t]=this._sinks;this._sinks=t}else this._sinks.size===0&&(this._sinks=null)}_activate(){if(this._deps.length===0){this._fn&&this._execFn();return}this._dirtyDepCount=0;let e=this._deps.length,t=0;try{for(let n=0;n<e;n++){let s=n,o=this._deps[n];o.unsub=At,o.unsub=o.node.subscribe(i=>{if(o.unsub===null)return;let a=this._config.tierOf,c=!1;for(let d of i)a(d[0])>=3&&(c=!0),this._config.onMessage(this,d,{direction:"down-in",depIndex:s},this._actions);c&&this._maybeRunFnOnSettlement()}),t++}}catch(n){this._deps[t].unsub=null;for(let s=0;s<t;s++){let o=this._deps[s];if(o.unsub!=null){let i=o.unsub;o.unsub=null;try{i()}catch{}ct(o)}}throw this._dirtyDepCount=0,n}}_addDep(e){for(let s=0;s<this._deps.length;s++)if(this._deps[s].node===e)return s;let t=this._deps.length,n=$t(e);if(this._deps.push(n),this._sinks==null)return t;n.dirty=!0,this._dirtyDepCount++,this._status!=="dirty"&&this._emit(Ze),n.unsub=At;try{n.unsub=e.subscribe(s=>{if(n.unsub===null)return;let o=this._config.tierOf,i=!1;for(let a of s)o(a[0])>=3&&(i=!0),this._config.onMessage(this,a,{direction:"down-in",depIndex:t},this._actions);i&&this._maybeRunFnOnSettlement()})}catch(s){throw n.unsub=null,this._deps.pop(),this._dirtyDepCount--,s}return t}_deactivate(e=!1){let t=this._cleanup;if(this._cleanup=void 0,typeof t=="function")try{t()}catch(n){this._emit([[M,this._wrapFnError("cleanup threw",n)]])}else if(t!=null&&typeof t=="object"){let n=t.deactivate;if(typeof n=="function")try{n()}catch(s){this._emit([[M,this._wrapFnError("cleanup.deactivate threw",s)]])}}for(let n of this._deps){if(n.unsub!=null){let s=n.unsub;n.unsub=null;try{s()}catch{}}ct(n)}this._waveHasNewData=!1,this._hasNewTerminal=!1,this._hasCalledFnOnce=!1,this._paused=!1,this._pendingWave=!1,this._pendingRerun=!1,this._rerunDepth=0,this._store={},this._dirtyDepCount=0,this._pauseLocks=null,this._pauseBuffer=null,this._fn!=null&&(this._cached=void 0),e||(this._fn!=null||this._deps.length>0)&&(!this._isTerminal||this._resubscribable)&&(this._status="sentinel")}_onDepMessage(e,t){let n=this._deps[e],s=t[0];if(this._inspectorHooks!=null){let o={kind:"dep_message",depIndex:e,message:t};for(let i of this._inspectorHooks)i(o)}if(s!==be){if(s===H){this._depDirtied(n);return}if(s===Y){this._depInvalidated(n),this._emit(vt);return}if(s===X||s===Z){this._emit([t]);return}if(s===B){this._emit(Qe);return}if(s===j)this._depSettledAsData(n,t[1]);else if(s===V)this._depSettledAsResolved(n);else if(s===z)this._depSettledAsTerminal(n,!0);else if(s===M)this._depSettledAsTerminal(n,t[1]);else{this._emit([t]);return}if(!this._fn){(s===j||s===V)&&this._emit([t]),(s===z||s===M)&&this._maybeAutoTerminalAfterWave();return}}}_depDirtied(e){e.dirty||(e.dirty=!0,e.involvedThisWave=!0,this._dirtyDepCount++,this._status!=="dirty"&&this._emit(Ze))}_depSettledAsData(e,t){e.dirty&&(e.dirty=!1,this._dirtyDepCount--),e.involvedThisWave=!0,e.dataBatch.push(t),this._waveHasNewData=!0}_depSettledAsResolved(e){e.dirty&&(e.dirty=!1,this._dirtyDepCount--)}_depSettledAsTerminal(e,t){e.dirty&&(e.dirty=!1,this._dirtyDepCount--),e.terminal=t,e.involvedThisWave=!0,this._hasNewTerminal=!0}_depInvalidated(e){e.prevData=void 0,e.terminal=void 0,e.dataBatch.length=0,e.dirty?e.involvedThisWave=!1:(e.dirty=!0,e.involvedThisWave=!0,this._dirtyDepCount++)}_maybeRunFnOnSettlement(){if(!(this._isTerminal&&!this._resubscribable)&&!(this._dirtyDepCount>0)){if(this._paused){this._pendingWave=!0;return}if(!this._waveHasNewData&&!this._hasNewTerminal&&this._hasCalledFnOnce){this._clearWaveFlags(),this._emit(yt),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([[M,e.terminal]]);return}this._autoComplete&&this._deps.every(t=>t.terminal!==void 0)&&this._emit(_t)}_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([[M,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([[M,this._wrapFnError("cleanup.beforeRun threw",a)]]);return}}}let t=this._deps.map(i=>i.involvedThisWave?i.dataBatch.length>0?[...i.dataBatch]:[]:void 0),n=this._deps.map(i=>i.prevData);for(let i=0;i<this._deps.length;i++){let a=t[i];a!=null&&a.length>0&&(this._deps[i].prevData=a[a.length-1])}let s=this._deps.map(i=>i.terminal),o={prevData:n,terminalDeps:s,store:this._store};if(this._hasCalledFnOnce=!0,this._clearWaveFlags(),this._inspectorHooks!=null){let i={kind:"run",batchData:t,prevData:n};for(let a of this._inspectorHooks)a(i)}this._isExecutingFn=!0;try{let i=this._fn(t,this._actions,o);if(typeof i=="function")this._cleanup=i;else if(i!=null&&typeof i=="object"){let a=i;(typeof a.beforeRun=="function"||typeof a.deactivate=="function"||typeof a.invalidate=="function")&&(this._cleanup=i)}}catch(i){this._emit([[M,this._wrapFnError("fn threw",i)]])}finally{this._isExecutingFn=!1,this._pendingRerun?(this._pendingRerun=!1,this._rerunDepth+=1,this._rerunDepth>Dt?(this._rerunDepth=0,this._emit([[M,new Error(`Node "${this.name}": _pendingRerun depth exceeded ${Dt} \u2014 likely a reactive cycle`)]])):this._maybeRunFnOnSettlement()):this._rerunDepth=0,this._clearWaveFlags()}}_clearWaveFlags(){this._waveHasNewData=!1,this._hasNewTerminal=!1;for(let e of this._deps)e.involvedThisWave=!1,e.dataBatch.length=0}_wrapFnError(e,t){let n=t instanceof Error?t.message:String(t);return new Error(`Node "${this.name}": ${e}: ${n}`,{cause:t})}_frameBatch(e){let t=this._config.tierOf;if(e.length===1)return t(e[0][0])===3&&this._status!=="dirty"?[ie,e[0]]:e;let n=!0,s=!1,o=!1,i=-1;for(let c of e){let d=t(c[0]);d<i&&(n=!1),d===3&&(s=!0),c[0]===H&&(o=!0),i=d}let a=e;if(!n){let c=e.map((d,f)=>({m:d,i:f,tier:t(d[0])}));c.sort((d,f)=>d.tier-f.tier||d.i-f.i),a=c.map(d=>d.m)}if(s&&!o&&this._status!=="dirty"){let c=0;for(;c<a.length&&t(a[c][0])===0;)c++;return c===0?[ie,...a]:[...a.slice(0,c),ie,...a.slice(c)]}return a}_emit(e){if(e.length===0)return;let t=e;if(this._isTerminal&&!this._resubscribable){let a=e.filter(c=>c[0]===B||c[0]===Y);if(a.length===0)return;t=a}t=this._frameBatch(t);let s=null;for(let a=0;a<t.length;a++){let c=t[a],d=c[0];if(d!==X&&d!==Z){s?.push(c);continue}if(c.length<2)throw new Error(`Node "${this.name}": [[${d===X?"PAUSE":"RESUME"}]] must carry a lockId payload \u2014 bare PAUSE/RESUME is a protocol violation (C0 rule). Use \`[[PAUSE, lockId]]\` / \`[[RESUME, lockId]]\`.`);let f=!0;if(this._pausable!==!1){let g=c[1];if(d===X)this._pauseLocks==null&&(this._pauseLocks=new Set),this._pauseLocks.add(g),this._paused=!0,this._pausable==="resumeAll"&&this._pauseBuffer==null&&(this._pauseBuffer=[]);else if(this._pauseLocks==null||!this._pauseLocks.has(g))f=!1;else if(this._pauseLocks.delete(g),this._pauseLocks.size===0){if(this._paused=!1,this._pauseBuffer!=null&&this._pauseBuffer.length>0){let m=this._pauseBuffer;this._pauseBuffer=[],this._emit(m)}this._pendingWave&&(this._pendingWave=!1,this._maybeRunFnOnSettlement())}}f?s?.push(c):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(Qe)}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,c=[];for(let d of o){let f=a(d[0]);f<3||f===5?c.push(d):this._pauseBuffer.push(d)}c.length>0&&this._dispatchOrAccumulate(c)}else this._dispatchOrAccumulate(o);i!=null&&this._emit([[M,i]])}_updateState(e){let t=this._config.tierOf,n,s,o=-1,i=0;for(let f of e)t(f[0])===3&&i++;let a=i<=1,c=-1;if(this._versioning!=null&&i>1){for(let f=e.length-1;f>=0;f--)if(e[f][0]===j){c=f;break}}for(let f=0;f<e.length;f++){let g=e[f],m=g[0];if(m===j){if(g.length>=2){let l=!1;if(a&&this._cached!==void 0)try{l=this._equals(this._cached,g[1])}catch(u){s=this._wrapFnError("equals threw",u),o=f;break}if(l){n==null&&(n=e.slice(0,f)),n.push(Ye),this._status="resolved";continue}this._cached=g[1],this._versioning!=null&&(c<0||f===c)&&Et(this._versioning,g[1],this._hashFn)}this._status="settled",n?.push(g)}else if(n?.push(g),m===H)this._status="dirty";else if(m===V)this._status="resolved";else if(m===z)this._status="completed";else if(m===M)this._status="errored";else if(m===Y){this._cached=void 0,this._status="dirty";let l=this._cleanup;if(typeof l=="function"){this._cleanup=void 0;try{l()}catch{}}else if(l!=null&&typeof l=="object"){let u=l.invalidate;if(typeof u=="function")try{u()}catch{}}}else m===B&&(this._resetOnTeardown&&(this._cached=void 0),this._deactivate(!0),this._status="sentinel")}let d=o>=0?n??e.slice(0,o):n??e;return s!=null?{finalMessages:d,equalsError:s}:{finalMessages:d}}_deliverToSinks=e=>{if(this._sinks==null)return;if(typeof this._sinks=="function"){this._sinks(e);return}let t=[...this._sinks];for(let n of t)n(e)};_dispatchOrAccumulate(e){if(St()){this._batchPendingMessages===null&&(this._batchPendingMessages=[],_e(()=>this._flushBatchPending()));for(let t of e)this._batchPendingMessages.push(t);return}Re(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);Re(this._deliverToSinks,t,this._config.tierOf)}},Gt=r=>Array.isArray(r),dt=r=>typeof r=="object"&&r!=null&&!Array.isArray(r)});function Ct(r,e,t){return t?!1:r.some((n,s)=>!(n!=null&&n.length>0)&&e.prevData[s]===void 0)}function Q(r,e){return se([],{...e,initial:r})}function we(r,e){return se((n,s,o)=>r(s,o)??void 0,{describeKind:"producer",...e})}function oe(r,e,t){let n=t?.partial??!1;return se(r,(o,i,a)=>{if(Ct(o,a,n)){i.down([[V]]);return}let c=o.map((d,f)=>d!=null&&d.length>0?d.at(-1):a.prevData[f]);i.emit(e(c,a))},{describeKind:"derived",...t})}function Me(r,e,t){let n=t?.partial??!1;return se(r,(o,i,a)=>{if(Ct(o,a,n)){i.down([[V]]);return}let c=o.map((d,f)=>d!=null&&d.length>0?d.at(-1):a.prevData[f]);return e(c,i,a)??void 0},{describeKind:"effect",...t})}var Fe=K(()=>{"use strict";te();fe()});function pe(r){return r.subscribe(()=>{})}var lt=K(()=>{"use strict"});var je,Mt=K(()=>{"use strict";je=class{_timer;_gen=0;start(e,t){this.cancel(),this._gen+=1;let n=this._gen;this._timer=setTimeout(()=>{this._timer=void 0,n===this._gen&&t()},e)}cancel(){this._timer!==void 0&&(clearTimeout(this._timer),this._timer=void 0)}get pending(){return this._timer!==void 0}}});var cr={};ln(cr,{compileSpec:()=>rr,decompileGraph:()=>or,extractFnFactory:()=>tn,extractSourceFactory:()=>nn,generateCatalogPrompt:()=>rn,isRichFnEntry:()=>ke,isRichSourceEntry:()=>gt,llmCompose:()=>ar,llmRefine:()=>an,specDiff:()=>ir,validateSpec:()=>ze,validateSpecAgainstCatalog:()=>mt});module.exports=pn(cr);Fe();nt();Ae();rt();Ge();te();Ge();fe();function Pe(r,e){if(e!=null&&e.length>0)return new Set(e);switch(r){case"standard":return new Set(["type","status","value","deps","meta","v"]);case"full":return null;default:return new Set(["type","deps"])}}function xn(r){return r._describeKind!=null?r._describeKind:r._deps.length>0?"derived":r._fn!=null?"producer":"state"}function Tn(r){let e={};for(let[t,n]of Object.entries(r.meta))try{e[t]=n.cache}catch{}return e}function ut(r,e){let t=e==null,n=!t&&e!=null?[...e].filter(d=>d.startsWith("meta.")).map(d=>d.slice(5)):null,s=t||e.has("meta")||n!=null&&n.length>0,o="state",i=[];r instanceof F&&(o=xn(r),i=r._deps.map(d=>d.node.name??""));let a={type:o,deps:i};(t||e.has("status"))&&(a.status=r.status);let c=r instanceof F?r._guard:void 0;if(s){let d={...Tn(r)};if(c!=null&&d.access===void 0&&(d.access=st(c)),n!=null&&n.length>0&&!e.has("meta")){let f={};for(let g of n)g in d&&(f[g]=d[g]);a.meta=f}else a.meta=d}if(r.name!=null&&(a.name=r.name),t||e.has("value")){r.status==="sentinel"&&(a.sentinel=!0);try{a.value=r.cache}catch{}}if((t||e.has("v"))&&r.v!=null){let d={id:r.v.id,version:r.v.version};"cid"in r.v&&(d.cid=r.v.cid,d.prev=r.v.prev),a.v=d}return(t||e.has("guard"))&&c!=null&&(a.guard=st(c)),(t||e.has("lastMutation"))&&r.lastMutation!=null&&(a.lastMutation=r.lastMutation),a}fe();Fe();lt();Mt();var Oe=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}};tt();function Ft(r,e,t,n={}){let s=e in r.nodes,o=t in r.nodes;if(!s)return Ie(e,t,"no-such-from");if(!o)return Ie(e,t,"no-such-to");let i=n.maxDepth;if(i!=null&&(!Number.isInteger(i)||i<0))throw new Error("explainPath: maxDepth must be an integer >= 0");if(e===t){if(n.findCycle===!0){let d=En(r,e,n);if(d!=null)return d}let c=Le(e,r.nodes[e],0,n);return Ve(e,t,[c])}if(i===0)return Ie(e,t,"no-path");let a=Pt(r,e,t,i);return a.found?Ve(e,t,jt(r,a.pathOrder,n)):Ie(e,t,a.truncated?"max-depth-exceeded":"no-path")}function Pt(r,e,t,n){let s=new Map,o=[{path:t,depth:0}],i=new Set([t]),a=0,c=!1;for(;a<o.length;){let g=o[a++];if(g.path===e)break;if(n!=null&&g.depth>=n){let h=r.nodes[g.path];h?.deps&&h.deps.length>0&&(c=!0);continue}let m=r.nodes[g.path];if(m==null)continue;let l=m.deps??[],u=new Map;for(let h=0;h<l.length;h++){let b=l[h];if(!b)continue;let v=u.get(b);v==null&&(v=[],u.set(b,v)),v.push(h)}for(let[h,b]of u)i.has(h)||(i.add(h),s.set(h,{from:g.path,depIndices:b}),o.push({path:h,depth:g.depth+1}))}if(!s.has(e))return{found:!1,pathOrder:[],truncated:c};let d=[{path:e}],f=e;for(;f!==t;){let g=s.get(f);if(g==null)return{found:!1,pathOrder:[],truncated:!1};d[d.length-1].depIndices=g.depIndices,d.push({path:g.from}),f=g.from}return{found:!0,pathOrder:d,truncated:!1}}function En(r,e,t){let n=r.nodes[e];if(n==null)return null;let s=n.deps??[],o=[];for(let a=0;a<s.length;a++)s[a]===e&&o.push(a);if(o.length>0){let a=Le(e,n,0,t);a.dep_index=o[0];let c=Le(e,n,1,t);return Ve(e,e,[a,c])}let i=null;for(let a=0;a<s.length;a++){let c=s[a];if(!c||c===e)continue;let d=Pt(r,c,e,t.maxDepth);d.found&&(i==null||d.pathOrder.length<i.pathOrder.length)&&(i=d,i={found:!0,pathOrder:[{path:e,depIndices:[a]},...d.pathOrder],truncated:!1})}return i==null?null:Ve(e,e,jt(r,i.pathOrder,t))}function jt(r,e,t){return e.map((n,s)=>{let o=r.nodes[n.path],i=Le(n.path,o,s,t);return n.depIndices!=null&&n.depIndices.length>0&&(i.dep_index=n.depIndices[0],n.depIndices.length>1&&(i.dep_indices=[...n.depIndices])),i})}function Le(r,e,t,n){let s={path:r,type:e.type,hop:t};e.status!==void 0&&(s.status=e.status),"value"in e&&(s.value=e.value),e.v!=null&&(s.v=e.v);let o=n.annotations?.get(r)??e.annotation;o!=null&&(s.annotation=o);let i=n.lastMutations?.get(r)??e.lastMutation;return i!=null&&(s.lastMutation=i),s}function Ve(r,e,t){return It(r,e,!0,"ok",t)}function Ie(r,e,t){return It(r,e,!1,t,[])}function It(r,e,t,n,s){let o=Rn(r,e,t,n,s);return{from:r,to:e,found:t,reason:n,steps:s,text:o,toJSON(){return{from:r,to:e,found:t,reason:n,steps:s}}}}function Rn(r,e,t,n,s){if(!t)switch(n){case"no-such-from":return`explainPath: no node named "${r}"`;case"no-such-to":return`explainPath: no node named "${e}"`;case"max-depth-exceeded":return`explainPath: no path from "${r}" to "${e}" within maxDepth`;default:return`explainPath: no path from "${r}" to "${e}"`}let o=[`Causal path: ${r} \u2192 ${e} (${s.length} step(s))`];for(let i of s){let c=` ${i.hop===0?"\xB7":"\u2193"} ${i.path} (${i.type}${i.status?`/${i.status}`:""})`;if(o.push(c),"value"in i&&o.push(` value: ${An(i.value)}`),i.annotation!=null&&o.push(` annotation: ${i.annotation}`),i.lastMutation!=null){let d=i.lastMutation.actor;o.push(` actor: ${d.type}${d.id?`:${d.id}`:""}`)}}return o.join(`
2
- `)}function An(r){if(r===void 0)return"<sentinel>";if(r===null)return"null";if(typeof r=="string")return JSON.stringify(r);if(typeof r=="number"||typeof r=="boolean"||typeof r=="bigint")return String(r);try{let e=JSON.stringify(r);return e.length>80?`${e.slice(0,77)}...`:e}catch{return String(r)}}fe();var P={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},Dn=Symbol.for("sizeof");function Lt(r){let e=new WeakSet,t=new WeakSet,n=[r],s=0;for(;n.length>0;){let o=n.pop();s+=$n(o,e,t,n)}return s}function $n(r,e,t,n){if(r==null)return 0;switch(typeof r){case"number":return P.number;case"boolean":return P.boolean;case"string":return P.string+r.length*2;case"bigint":return P.bigint+Gn(r);case"symbol":return P.symbol;case"function":return e.has(r)?0:(e.add(r),P.function);case"undefined":return 0}let o=r;if(e.has(o))return 0;e.add(o);let i=o[Dn];if(typeof i=="function")try{let d=i.call(o);if(typeof d=="number"&&Number.isFinite(d))return d}catch{}if(o instanceof Date)return P.date;if(o instanceof RegExp)return P.regexp+o.source.length*2;if(o instanceof Error){let d=o.message?o.message.length*2:0,f=o.stack?o.stack.length*2:0;return P.error+d+f}if(typeof URL<"u"&&o instanceof URL)return P.url+o.href.length*2;if(typeof Promise<"u"&&o instanceof Promise)return P.promise;if(o instanceof WeakMap)return P.weakmap;if(o instanceof WeakSet)return P.weakset;if(o instanceof Map){let d=P.map;for(let[f,g]of o)d+=P.mapEntry,n.push(f),n.push(g);return d}if(o instanceof Set){let d=P.set;for(let f of o)d+=P.setEntry,n.push(f);return d}if(Array.isArray(o)){let d=P.array+o.length*8;for(let f of o)n.push(f);return d}if(o instanceof ArrayBuffer)return t.has(o)?0:(t.add(o),o.byteLength);if(ArrayBuffer.isView(o)){let d=o;return t.has(d.buffer)?48:(t.add(d.buffer),d.buffer.byteLength+48)}let a=P.object,c=Object.keys(o);for(let d of c){a+=P.string+d.length*2;try{n.push(o[d])}catch{}}return a}function Gn(r){let e=r<0n?-r:r;if(e===0n)return 0;let t=e.toString(2).length;return Math.ceil(t/32)*8}function Vt(r,e){let t=e?.topN??10,n=r.describe({detail:"standard"}),s=[],o=r._collectObserveTargets;typeof o=="function"&&o.call(r,"",s);let i=new Map;for(let[m,l]of s)i.set(m,l);let a=[];for(let[m,l]of Object.entries(n.nodes)){let u=i.get(m),h=u instanceof F?u:null,b=h?Lt(h.cache):0,v=h?h._sinkCount:0,p=l.deps?.length??0,y=l.type==="effect"&&v===0,w=v===0?l.type==="effect"?"orphan-effect":l.type==="derived"?"idle-derived":l.type==="producer"?"idle-producer":null:null;a.push({path:m,type:l.type,status:l.status??"unknown",valueSizeBytes:b,subscriberCount:v,depCount:p,isOrphanEffect:y,orphanKind:w})}let c=a.reduce((m,l)=>m+l.valueSizeBytes,0),d=(m,l)=>[...a].sort(l??((u,h)=>h[m]-u[m])).slice(0,t),f=a.filter(m=>m.orphanKind!=null),g=a.filter(m=>m.isOrphanEffect);return{nodeCount:a.length,edgeCount:n.edges.length,subgraphCount:n.subgraphs.length,nodes:a,totalValueSizeBytes:c,hotspots:{byValueSize:d("valueSizeBytes"),bySubscriberCount:d("subscriberCount"),byDepCount:d("depCount")},orphans:f,orphanEffects:g}}var C="::",U="__meta__",he=1;function Bt(r,e){let t=Math.max(16,r.size*4),n=0;for(;r.size>0;){if(n++>=t){console.error(`[Graph "${e}".destroy] disposer drain exceeded cap (${t}); ${r.size} disposer(s) discarded`),r.clear();return}let s=r.values().next();if(s.done)return;let o=s.value;r.delete(o);try{o()}catch(i){console.error(`[Graph "${e}".destroy] disposer threw:`,i)}}}function Cn(r){let e=[];for(let t of Object.keys(r).sort()){let n=r[t].v;n!=null&&e.push(`${t} ${n.id} ${n.version}`)}return e.join(`
3
- `)}function Ht(r){if(r.version!==he)throw new Error(`unsupported snapshot version ${String(r.version)} (expected ${he})`);for(let e of["name","nodes","edges","subgraphs"])if(!(e in r))throw new Error(`snapshot missing required key "${e}"`);if(typeof r.name!="string")throw new TypeError("snapshot 'name' must be a string");if(typeof r.nodes!="object"||r.nodes===null||Array.isArray(r.nodes))throw new TypeError("snapshot 'nodes' must be an object");if(!Array.isArray(r.edges))throw new TypeError("snapshot 'edges' must be an array");if(!Array.isArray(r.subgraphs))throw new TypeError("snapshot 'subgraphs' must be an array")}function Mn(r,e){let t=new WeakMap,n=(s,o)=>{if(Object.is(s,o))return!0;if(s==null||o==null||typeof s!="object"||typeof o!="object")return!1;let i=t.get(s);if(i==null&&(i=new WeakSet,t.set(s,i)),i.has(o))return!0;i.add(o);let a=s.constructor,c=o.constructor;if(a!==c)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 m=o;if(s.length!==m.length)return!1;for(let l=0;l<s.length;l++)if(!n(s[l],m[l]))return!1;return!0}if(s instanceof Map){let m=o;if(s.size!==m.size)return!1;for(let[l,u]of s)if(!m.has(l)||!n(u,m.get(l)))return!1;return!0}if(s instanceof Set){let m=o;if(s.size!==m.size)return!1;for(let l of s){let u=!1;for(let h of m)if(n(l,h)){u=!0;break}if(!u)return!1}return!0}if(ArrayBuffer.isView(s)){let m=s,l=o;if(m.length!==l.length)return!1;for(let u=0;u<m.length;u++)if(m[u]!==l[u])return!1;return!0}let d=Object.keys(s),f=Object.keys(o);if(d.length!==f.length)return!1;let g=new Set(f);for(let m of d)if(!g.has(m)||!n(s[m],o[m]))return!1;return!0};return n(r,e)}function pt(r){if(r===null||typeof r!="object")return r;if(Array.isArray(r))return r.map(pt);let e=r,t=Object.keys(e).sort(),n={};for(let s of t)n[s]=pt(e[s]);return n}function Fn(r){return r.replaceAll("\\","\\\\").replaceAll('"','\\"')}function Pn(r){return r.replaceAll("\\","\\\\").replaceAll('"','\\"')}function jn(r){return r==="TD"?"down":r==="BT"?"up":r==="RL"?"left":"right"}function Wt(r){let e=new Set,t=[];function n(s,o){let i=`${s}\0${o}`;e.has(i)||(e.add(i),t.push([s,o]))}for(let[s,o]of Object.entries(r.nodes)){let i=o.deps;if(i)for(let a of i)n(a,s)}for(let s of r.edges)n(s.from,s.to);return t}function qt(r){if(r===void 0)return"LR";if(r==="TD"||r==="LR"||r==="BT"||r==="RL")return r;throw new Error(`invalid diagram direction ${String(r)}; expected one of: TD, LR, BT, RL`)}function In(r,e){let t=e.includeEdges??!0,n=e.includeSubgraphs??!0,{expand:s,...o}=r,i={...o,edges:t?r.edges:[],subgraphs:n?r.subgraphs:[]},a=JSON.stringify(pt(i),null,e.indent??2);return e.logger?.(a),a}function Ln(r,e){let t=e.includeEdges??!0,n=e.includeSubgraphs??!0,s=[];s.push(`Graph ${r.name}`),s.push("Nodes:");for(let i of Object.keys(r.nodes).sort()){let a=r.nodes[i];s.push(`- ${i} (${a.type}/${a.status}): ${He(a.value)}`)}if(t){s.push("Edges:");for(let i of r.edges)s.push(`- ${i.from} -> ${i.to}`)}if(n){s.push("Subgraphs:");for(let i of r.subgraphs)s.push(`- ${i}`)}let o=s.join(`
4
- `);return e.logger?.(o),o}function Kt(r,e){let t=qt(e.direction),n=Object.keys(r.nodes).sort(),s=new Map;for(let i=0;i<n.length;i+=1)s.set(n[i],`n${i}`);let o=[`flowchart ${t}`];for(let i of n){let a=s.get(i);o.push(` ${a}["${Fn(i)}"]`)}for(let[i,a]of Wt(r)){let c=s.get(i),d=s.get(a);!c||!d||o.push(` ${c} --> ${d}`)}return o.join(`
5
- `)}function Vn(r,e){let t=Kt(r,e);return Bn(t)}function Bn(r,e){let t=e?.theme??"default",n=e?.autoSync??!0,o=JSON.stringify({code:r,mermaid:{theme:t},autoSync:n}),i=new TextEncoder().encode(o),a="";for(let d=0;d<i.length;d++)a+=String.fromCharCode(i[d]);return`https://mermaid.live/edit#base64:${globalThis.btoa(a).replace(/\+/g,"-").replace(/\//g,"_").replace(/=+$/,"")}`}function Hn(r,e){let t=qt(e.direction),n=Object.keys(r.nodes).sort(),s=new Map;for(let i=0;i<n.length;i+=1)s.set(n[i],`n${i}`);let o=[`direction: ${jn(t)}`];for(let i of n){let a=s.get(i);o.push(`${a}: "${Pn(i)}"`)}for(let[i,a]of Wt(r)){let c=s.get(i),d=s.get(a);!c||!d||o.push(`${c} -> ${d}`)}return o.join(`
6
- `)}function zn(r){return r.replace(/[.*+?^${}()|[\]\\]/g,"\\$&")}function Be(r){let e="^";for(let t=0;t<r.length;t+=1){let n=r[t];if(n==="*"){e+=".*";continue}if(n==="?"){e+=".";continue}if(n==="["){let s=r.indexOf("]",t+1);if(s<=t+1){e+="\\[";continue}let o=r.slice(t+1,s);o.startsWith("!")&&(o=`^${o.slice(1)}`),o=o.replace(/\\/g,"\\\\"),e+=`[${o}]`,t=s;continue}e+=zn(n)}return e+="$",new RegExp(e)}var Un={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"},Wn={data:"",dirty:"",resolved:"",invalidate:"",pause:"",resume:"",complete:"",error:"",teardown:"",derived:"",path:"",reset:""};function He(r){if(typeof r=="string")return JSON.stringify(r);if(typeof r=="number"||typeof r=="boolean"||r==null)return String(r);try{return JSON.stringify(r)}catch{return"[unserializable]"}}function qn(r){return r==="none"?Wn:r==="ansi"||r==null?Un:{data:r.data??"",dirty:r.dirty??"",resolved:r.resolved??"",invalidate:r.invalidate??"",pause:r.pause??"",resume:r.resume??"",complete:r.complete??"",error:r.error??"",teardown:r.teardown??"",derived:r.derived??"",path:r.path??"",reset:r.reset??""}}function zt(r){if(r==null)return{};let e=r.detail;return e==="full"?{...r,structured:r.structured??!0,timeline:r.timeline??!0,causal:r.causal??!0,derived:r.derived??!0}:e==="minimal"?{...r,structured:r.structured??!0}:r.format==="stage-log"?{...r,structured:r.structured??!0,timeline:r.timeline??!0}:r}function Kn(r,e,t){for(let n=0;n<r.length;n++){let s=r.charCodeAt(n);if(s<32||s===127)throw new Error(`Graph "${e}": ${t} "${r}" must not contain control character (U+${s.toString(16).padStart(4,"0").toUpperCase()} at index ${n})`)}}function ft(r,e,t){if(r==="")throw new Error(`Graph "${e}": ${t} name must be non-empty`);if(r.includes(C))throw new Error(`Graph "${e}": ${t} "${r}" must not contain '${C}' (path separator)`);if(r===U)throw new Error(`Graph "${e}": ${t} name "${U}" is reserved for meta companion paths`);Kn(r,e,t)}function Jn(r,e){if(r==="")throw new Error(`Graph "${e}": resolve path must be non-empty`);let t=r.split(C);for(let n of t)if(n==="")throw new Error(`Graph "${e}": resolve path has empty segment`);return t}function Yn(r,e){let t=!1;for(let s of r)if(!e.isMetaPassthrough(s[0])){t=!0;break}return t?r.filter(s=>e.isMetaPassthrough(s[0])):r}function Jt(r){for(let e of r._mounts.values())Jt(e);for(let e of r._nodes.values())try{e.down([[B]],{internal:!0})}catch{}}var ge=class r{name;opts;config;_nodes=new Map;_nodeToName=new WeakMap;_mounts=new Map;_parent=void 0;_storageDisposers=new Set;_disposers=new Set;_topology;_topologyEmitters=new Set;constructor(e,t){if(e==="")throw new Error("Graph name must be non-empty");if(e.includes(C))throw new Error(`Graph name must not contain '${C}' (got "${e}")`);if(e===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??le,this._traceRing=new Oe(t?.traceCapacity??1e3),t?.versioning!=null&&this.setVersioning(t.versioning)}ancestors(e=!0){let t=[],n=e?this:this._parent;for(;n!=null;)t.push(n),n=n._parent;return t}get topology(){return this._topology==null&&(this._topology=we(e=>{let t=n=>{e.emit(n)};return this._topologyEmitters.add(t),()=>{this._topologyEmitters.delete(t)}},{name:`${this.name}_topology`})),this._topology}_emitTopology(e){if(!(this._topology==null||this._topologyEmitters.size===0))for(let t of this._topologyEmitters)t(e)}add(e,t){let n=e.name,s=t?.name??n;if(s==null||s==="")throw new Error(`Graph "${this.name}": graph.add requires a non-empty name \u2014 pass via opts.name or set it on the node (e.g. state(0, { name: "x" }))`);let o=s,i=t?.annotation;if(ft(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:ue()})),e}setVersioning(e){if(e!=null)for(let t of this._nodes.values())t instanceof F&&t._applyVersioning(e)}remove(e){ft(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,c]of i)a.includes(`${C}${U}${C}`)||o.nodes.push(a);return o.nodes.sort(),o.mounts.push(e),o.mounts.push(...t._collectSubgraphs(`${e}${C}`)),this._mounts.delete(e),t._parent=void 0,Jt(t),this._emitTopology({kind:"removed",name:e,nodeKind:"mount",audit:o}),o}let n=this._nodes.get(e);if(!n)throw new Error(`Graph "${this.name}": unknown node or mount "${e}"`);this._nodes.delete(e),this._nodeToName.delete(n),n.down([[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=Be(e);return i=>o.test(i)})(),n={kind:"mount",nodes:[],mounts:[]},s=[...this._nodes.keys(),...this._mounts.keys()].filter(o=>t(o));for(let o of s){let i=this.remove(o);n.nodes.push(...i.nodes),n.mounts.push(...i.mounts)}return n.nodes.sort(),n.mounts.sort(),n}[Symbol.iterator](){let e=[...this._nodes.keys()].sort(),t=this._nodes,n=0;return{[Symbol.iterator](){return this},next(){if(n>=e.length)return{value:void 0,done:!0};let s=e[n++];return{value:[s,t.get(s)],done:!1}}}}node(e){if(e==="")throw new Error(`Graph "${this.name}": node name must be non-empty`);if(e.includes(C))return this.resolve(e);let t=this._nodes.get(e);if(!t)throw new Error(`Graph "${this.name}": unknown node "${e}"`);return t}get(e){return this.node(e).cache}set(e,t,n){let s=n?.internal===!0;this.node(e).down([[j,t]],{actor:n?.actor,internal:s,delivery:"write"})}setAll(e,t){let n=Symbol.iterator in e?e:Object.entries(e);Ee(()=>{for(let[s,o]of n)this.set(s,o,t)})}invalidate(e,t){let n=t?.internal===!0;this.node(e).down([[Y]],{actor:t?.actor,internal:n,delivery:"write"})}error(e,t,n){let s=n?.internal===!0;this.node(e).down([[M,t]],{actor:n?.actor,internal:s,delivery:"write"})}complete(e,t){let n=t?.internal===!0;this.node(e).down([[z]],{actor:t?.actor,internal:n,delivery:"write"})}edges(e){let t=e?.recursive===!0,n=new Map;if(!t){for(let[c,d]of this._nodes)n.set(d,c);let a=[];for(let[c,d]of this._nodes)if(d instanceof F)for(let f of d._deps){let g=n.get(f.node);g!=null&&a.push([g,c])}return a.sort((c,d)=>c[0]<d[0]?-1:c[0]>d[0]?1:c[1]<d[1]?-1:c[1]>d[1]?1:0),a}let s=[];this._collectObserveTargets("",s);let o=new Map;for(let[a,c]of s)o.set(c,a);let i=[];for(let[a,c]of s)if(c instanceof F)for(let d of c._deps){let f=o.get(d.node);f!=null&&i.push([f,a])}return i.sort((a,c)=>a[0]<c[0]?-1:a[0]>c[0]?1:a[1]<c[1]?-1:a[1]>c[1]?1:0),i}mount(e,t){if(ft(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(t===this)throw new Error(`Graph "${this.name}": cannot mount a graph into itself`);if(t._parent!=null)throw new Error(`Graph "${this.name}": this child graph is already mounted on "${t._parent.name}"`);for(let n=this;n!=null;n=n._parent)if(n===t)throw new Error(`Graph "${this.name}": mount("${e}", \u2026) would create a mount cycle`);return this._mounts.set(e,t),t._parent=this,this._emitTopology({kind:"added",name:e,nodeKind:"mount"}),t}resolve(e){let t=Jn(e,this.name);return this._resolveFromSegments(t)}tryResolve(e){try{return this.resolve(e)}catch{return}}_resolveFromSegments(e){let t=e;if(t[0]===this.name&&(t=t.slice(1),t.length===0))throw new Error(`Graph "${this.name}": resolve path ends at graph name only`);let n=t[0],s=t.slice(1);if(s.length===0){let a=this._nodes.get(n);if(a)return a;throw this._mounts.has(n)?new Error(`Graph "${this.name}": path ends at subgraph "${n}" \u2014 not a node (GRAPHREFLY-SPEC \xA73.5)`):new Error(`Graph "${this.name}": unknown name "${n}"`)}let o=this._nodes.get(n);if(o&&s.length>0&&s[0]===U)return this._resolveMetaChainFromNode(o,s,t.join(C));let i=this._mounts.get(n);if(!i)throw this._nodes.has(n)?new Error(`Graph "${this.name}": "${n}" is a node; trailing path "${s.join(C)}" is invalid`):new Error(`Graph "${this.name}": unknown mount or node "${n}"`);return i.resolve(s.join(C))}_resolveMetaChainFromNode(e,t,n){let s=e,o=0,i=[...t];for(;o<i.length;){if(i[o]!==U)throw new Error(`Graph "${this.name}": expected ${U} segment in meta path "${n}"`);if(o+1>=i.length)throw new Error(`Graph "${this.name}": meta path requires a key after ${U} in "${n}"`);let a=i[o+1],c=s.meta[a];if(!c)throw new Error(`Graph "${this.name}": unknown meta "${a}" in path "${n}"`);s=c,o+=2}return s}signal(e,t){if(t?.internal!==!0){for(let s of e)if(this.config.messageTier(s[0])===3)throw new Error(`Graph "${this.name}": Graph.signal() rejects tier-3 messages (DATA / RESOLVED). Broadcast is for control-plane tiers (START / DIRTY / INVALIDATE / PAUSE / RESUME / COMPLETE / ERROR / TEARDOWN). For per-node value writes, use Graph.set or graph.node(name).down(...).`)}let n=[];if(this._signalDeliver(e,t??{},new Set,n),n.length>0)throw n[0]}_signalDeliver(e,t,n,s){for(let c of this._mounts.values())c._signalDeliver(e,t,n,s);let i=t.internal===!0?{internal:!0}:{actor:t.actor,delivery:"signal"},a=Yn(e,this.config);for(let c of[...this._nodes.keys()].sort()){let d=this._nodes.get(c);if(!n.has(d)){n.add(d);try{d.down(e,i)}catch(f){if(f instanceof J)throw f;s.push(f)}a.length!==0&&this._signalMetaSubtree(d,a,n,i,s)}}}_signalMetaSubtree(e,t,n,s,o){for(let i of Object.keys(e.meta).sort()){let a=e.meta[i];if(!n.has(a)){n.add(a);try{a.down(t,s)}catch(c){if(c instanceof J)throw c;o.push(c)}this._signalMetaSubtree(a,t,n,s,o)}}}describe(e){if(e?.reactive===!0)return this._describeReactive(e);let t=e?.actor,n=e?.filter,s=Pe(e?.detail,e?.fields),o=e?.format==="spec",i=o?Pe("minimal"):s,a=[];this._collectObserveTargets("",a);let c=new Map;for(let[N,_]of a)c.set(_,N);let d=[];{let N=a.map(([,R])=>R),_=new Set(c.values()),O=0;for(;N.length>0;){let R=N.shift();if(R instanceof F)for(let $ of R._deps){let x=$.node;if(c.has(x))continue;let T=x.name??"",S=T;if(!S||_.has(S))if(T){let A=2;for(;_.has(`${T}#${A}`);)A++;S=`${T}#${A}`}else for(S=`__internal__/${O++}`;_.has(S);)S=`__internal__/${O++}`;c.set(x,S),_.add(S),d.push([S,x]),N.push(x)}}}let f=[...a,...d],g={};for(let[N,_]of f){if(t!=null&&!_.allowsObserve(t))continue;let O=ut(_,i),R=_ instanceof F?_._deps.map(S=>c.get(S.node)??S.node.name??""):[],{name:$,...x}=O,T={...x,deps:R};if(!o){let S=this._annotations.get(N);S!=null&&(T.annotation=S)}if(n!=null)if(typeof n=="function"){let S=n;if(!(S.length>=2?S(N,T):S(T)))continue}else{let S=!0;for(let[A,I]of Object.entries(n)){let ee=A==="deps_includes"?"depsIncludes":A==="meta_has"?"metaHas":A;if(ee==="depsIncludes"){if(!T.deps.includes(String(I))){S=!1;break}continue}if(ee==="metaHas"){if(!Object.hasOwn(T.meta??{},String(I))){S=!1;break}continue}if(T[ee]!==I){S=!1;break}}if(!S)continue}g[N]=T}let m=new Set(Object.keys(g)),l=[];for(let[N,_]of f)if(_ instanceof F)for(let O of _._deps){let R=c.get(O.node);R!=null&&l.push([R,N])}l.sort((N,_)=>N[0]<_[0]?-1:N[0]>_[0]?1:N[1]<_[1]?-1:N[1]>_[1]?1:0);let u=l.map(([N,_])=>({from:N,to:_}));(t!=null||n!=null)&&(u=u.filter(N=>m.has(N.from)&&m.has(N.to)));let h=this._collectSubgraphs(""),b=t!=null||n!=null?h.filter(N=>{let _=`${N}${C}`;return[...m].some(O=>O===N||O.startsWith(_))}):h,v=this,p=e,y={name:this.name,nodes:g,edges:u,subgraphs:b,expand(N){let _={...p,format:void 0};return Array.isArray(N)?(_.fields=N,_.detail=void 0):(_.detail=N,_.fields=void 0),v.describe(_)}},w=e??{},k=w.format;return k==="json"?In(y,w):k==="pretty"?Ln(y,w):k==="mermaid"?Kt(y,w):k==="mermaid-url"?Vn(y,w):k==="d2"?Hn(y,w):y}_collectSubgraphs(e){let t=[];for(let n of[...this._mounts.keys()].sort()){let s=e===""?n:`${e}${n}`;t.push(s),t.push(...this._mounts.get(n)._collectSubgraphs(`${s}${C}`))}return t}resourceProfile(e){return Vt(this,e)}reachable(e,t,n={}){return n.withDetail===!0?Ut(this.describe(),e,t,{...n,withDetail:!0}):Ut(this.describe(),e,t,n)}explain(e,t,n){return n?.reactive===!0?this._explainReactive(e,t,n):this._explainStatic(e,t,n)}_explainStatic(e,t,n){let s=this.describe({detail:"full"}),o=new Map(this._annotations),i=new Map;for(let[a,c]of Object.entries(s.nodes))c.lastMutation!=null&&i.set(a,c.lastMutation);return Ft(s,e,t,{...n?.maxDepth!=null?{maxDepth:n.maxDepth}:{},...n?.findCycle===!0?{findCycle:!0}:{},annotations:o,lastMutations:i})}_describeReactive(e){let t={...e,reactive:!1},n=e.reactiveName??"describe",s=0,o=Q(s,{name:`${n}_version`}),i=this.observe({timeline:!0,structured:!0}),a=!1,c=!1,d=()=>{a||c||(a=!0,_e(()=>{a=!1,!c&&(s+=1,o.emit(s))}))},f=i.onEvent(b=>{let v=b.type;v!=="data"&&v!=="error"&&v!=="complete"&&v!=="teardown"||d()}),g=[],m=new WeakSet,l=b=>{if(m.has(b)||c)return;m.add(b);let v=b.topology.subscribe(p=>{for(let y of p){if(y[0]!==j)continue;let w=y[1];if(d(),w.kind==="added"&&w.nodeKind==="mount"){let k=b._mounts.get(w.name);k!=null&&l(k)}}});g.push(v);for(let p of b._mounts.keys()){let y=b._mounts.get(p);y!=null&&l(y)}};l(this);let u;try{u=oe([o],()=>this.describe(t),{name:n,describeKind:"derived",meta:{domain:"audit",kind:"describe"},equals:(b,v)=>b===v})}catch(b){f();for(let v of g)v();throw i.dispose(),b}let h=pe(u);return{node:u,dispose(){c=!0,f();for(let b of g)b();g.length=0,i.dispose(),h()}}}_explainReactive(e,t,n){let s=0,o=Q(s,{name:"explain_version"}),i=this.observe({timeline:!0,structured:!0}),a=!1,c=!1,d=i.onEvent(l=>{let u=l.type;u!=="data"&&u!=="error"&&u!=="complete"&&u!=="teardown"||a||c||(a=!0,_e(()=>{a=!1,!c&&(s+=1,o.emit(s))}))}),f={...n?.maxDepth!=null?{maxDepth:n.maxDepth}:{},...n?.findCycle===!0?{findCycle:!0}:{}},g;try{g=oe([o],()=>this._explainStatic(e,t,f),{name:n?.name??"explain",describeKind:"derived",meta:{domain:"audit",kind:"explain_path",from:e,to:t},equals:(l,u)=>l.found===u.found&&l.reason===u.reason&&l.steps.length===u.steps.length&&Zn(l.steps,u.steps)})}catch(l){throw d(),i.dispose(),l}let m=pe(g);return{node:g,dispose(){c=!0,d(),i.dispose(),m()}}}_pathsMatching(e){let t=Be(e),n=[];return this._collectObserveTargets("",n),n.map(([s])=>s).filter(s=>t.test(s))}_collectObserveTargets(e,t){for(let n of[...this._mounts.keys()].sort()){let s=e===""?n:`${e}${C}${n}`;this._mounts.get(n)._collectObserveTargets(s,t)}for(let n of[...this._nodes.keys()].sort()){let s=this._nodes.get(n),o=e===""?n:`${e}${C}${n}`;t.push([o,s]),this._appendMetaObserveTargets(o,s,t)}}_appendMetaObserveTargets(e,t,n){for(let s of Object.keys(t.meta).sort()){let o=t.meta[s],i=`${e}${C}${U}${C}${s}`;n.push([i,o]),this._appendMetaObserveTargets(i,o,n)}}observe(e,t){let n=typeof e=="string",o=zt(n?t:e),i=o.structured===!0||o.timeline===!0||o.causal===!0||o.derived===!0||o.detail==="minimal"||o.detail==="full"||o.format!=null,a=o.actor;if(n){let f=e,g=this.resolve(f);if(a!=null&&!g.allowsObserve(a))throw new J({actor:a,action:"observe",nodeName:f});return i?this._buildStructuredObserver([[f,g]],o,"one"):{subscribe(m){return g.subscribe(m)},up(m){try{g.up?.(m)}catch(l){if(l instanceof J)return;throw l}}}}let c=[];this._collectObserveTargets("",c),c.sort((f,g)=>f[0]<g[0]?-1:f[0]>g[0]?1:0);let d=a==null?c:c.filter(([,f])=>f.allowsObserve(a));return i?this._buildStructuredObserver(d,o,"all"):{subscribe:f=>{let g=d.map(([m,l])=>l.subscribe(u=>{f(m,u)}));return()=>{for(let m of g)m()}},up:(f,g)=>{try{this.resolve(f).up?.(g)}catch(m){if(m instanceof J)return;throw m}}}}_buildStructuredObserver(e,t,n){let s=n==="one"?e[0]?.[0]:void 0,o=i=>{if(n==="one"&&s!=null){let f=this.resolve(s);return this._buildStructuredObserver([[s,f]],i,"one")}let a=[];this._collectObserveTargets("",a),a.sort((f,g)=>f[0]<g[0]?-1:f[0]>g[0]?1:0);let c=i.actor,d=c==null?a:a.filter(([,f])=>f.allowsObserve(c));return this._buildStructuredObserver(d,i,"all")};return this._createObserveResult(e,t,o)}_createObserveResult(e,t,n){let s=t.timeline===!0,o=t.causal===!0,i=t.derived===!0,a=t.detail==="minimal",c=this.config.inspectorEnabled,d=(o||i)&&c,f=t.maxEvents,g=f!=null&&f>0?new Oe(f):null,m=[],l=new Set,u={},h=new Set,b=0,v=0,p=0,y=0,w=0,k=0,N=!1,_=!1,O=0,R=new Map,$=new Map,x=new Map,T=E=>{g?g.push(E):m.push(E);for(let G of l)G(E)},S=()=>s?{timestamp_ns:ue(),in_batch:Te(),batch_id:O}:{},A=(E,G)=>{if(!(!d||!(E instanceof F)))return E._setInspectorHook(W=>{if(W.kind==="dep_message")R.set(E,W.depIndex);else if(W.kind==="run"){let me=W.batchData.map((D,L)=>D!=null&&D.length>0?D.at(-1):W.prevData[L]);$.set(E,me);let q=W.batchData.map(D=>D!=null?[...D]:void 0);x.set(E,q),i&&T({type:"derived",path:G,dep_values:me,dep_batches:q,...S()})}})},I=E=>{let G=R.get(E),W=$.get(E);if(!o||W==null)return{};let q=(G!=null&&G>=0&&E instanceof F?E._deps[G]:void 0)?.node,D=q?.v,L=x.get(E);return{trigger_dep_index:G,trigger_dep_name:q?.name,...D!=null?{trigger_version:{id:D.id,version:D.version}}:{},dep_values:[...W],...L!=null?{dep_batches:L}:{}}},ee=[],Ne=[];for(let[E,G]of e){let W=A(G,E);W&&ee.push(W),Ne.push(G.subscribe(me=>{O++;for(let q of me){let D=q[0],L=S();if(D===j){u[E]=q[1];let Ke=G instanceof F?G.lastMutation?.actor??ae:ae;T({type:"data",path:E,data:q[1],actor:Ke,...L,...I(G)})}else if(a)D===H?b++:D===V?v++:D===Y?p++:D===X?y++:D===Z?w++:D===B?k++:D===z&&!h.has(E)?N=!0:D===M&&(_=!0,h.add(E));else if(D===H)b++,T({type:"dirty",path:E,...L});else if(D===V)v++,T({type:"resolved",path:E,...L,...I(G)});else if(D===Y)p++,T({type:"invalidate",path:E,...L});else if(D===X)y++,T({type:"pause",path:E,lockId:q[1],...L});else if(D===Z)w++,T({type:"resume",path:E,lockId:q[1],...L});else if(D===z)h.has(E)||(N=!0),T({type:"complete",path:E,...L});else if(D===M){_=!0,h.add(E);let Ke=G instanceof F?G.lastMutation?.actor??ae:ae;T({type:"error",path:E,data:q[1],actor:Ke,...L})}else D===B&&(k++,T({type:"teardown",path:E,...L}))}}))}let Ue=!1,We=()=>{if(!Ue){Ue=!0;for(let E of Ne)E();for(let E of ee)E();for(let E of Se)E({value:void 0,done:!0});Se.length=0}},qe=[],Se=[];l.add(E=>{let G=Se.shift();G?G({value:E,done:!1}):qe.push(E)});let bt={get values(){return u},get dirtyCount(){return b},get resolvedCount(){return v},get invalidateCount(){return p},get pauseCount(){return y},get resumeCount(){return w},get teardownCount(){return k},get events(){return g?g.toArray():[...m]},get anyCompletedCleanly(){return N},get anyErrored(){return _},get completedWithoutErrors(){return N&&!_},onEvent(E){return l.add(E),()=>l.delete(E)},dispose:We,expand(E){We();let G={...t};return typeof E=="string"?G.detail=E:Object.assign(G,E),n(zt(G))},[Symbol.asyncIterator](){return{next(){return qe.length>0?Promise.resolve({value:qe.shift(),done:!1}):Ue?Promise.resolve({value:void 0,done:!0}):new Promise(E=>Se.push(E))},return(){return We(),Promise.resolve({value:void 0,done:!0})}}}};return t.format!=null&&this._attachFormatLogger(bt,t),bt}_attachFormatLogger(e,t){let n=t.format;if(n==null)return;let s=t.logger??(u=>console.log(u)),o=t.includeTypes?new Set(t.includeTypes):null,i=t.excludeTypes?new Set(t.excludeTypes):null,a=o==null&&i==null?()=>!0:u=>(o==null||o.has(u))&&(i==null||!i.has(u)),c=qn(t.theme),d=n==="stage-log"?ue():0,f=u=>u==null?"":t.stageLabels?.[u]??u,g=(u,h)=>u.length>h?`${u.slice(0,h-1)}\u2026`:u,m=u=>u.type==="data"||u.type==="error"?g(He(u.data),120):"",l=u=>{if(n==="stage-log"){let _=(ue()-d)/1e9,O=f(u.path).padEnd(9);if(u.type==="data"){let R=m(u);return`[${_.toFixed(3)}s] ${O} \u2190${R?` ${R}`:""}`}if(u.type==="error"){let R=m(u);return`[${_.toFixed(3)}s] ${O} \u2717${R?` ${R}`:""}`}return u.type==="complete"?`[${_.toFixed(3)}s] ${O} \u25A0 complete`:`[${_.toFixed(3)}s] ${O} ${u.type}`}if(n==="json")try{return JSON.stringify(u)}catch{return JSON.stringify({type:u.type,path:u.path,data:"[unserializable]"})}let h=c[u.type]??"",b=u.path?`${c.path}${u.path}${c.reset} `:"",v=u.type==="data"||u.type==="error",p=u.type==="pause"||u.type==="resume",y=v?` ${He(u.data)}`:p?` ${He(u.lockId)}`:"",w=u.type==="data"||u.type==="resolved"||u.type==="derived"?u:void 0,k=w?.trigger_dep_name!=null?` <- ${w.trigger_dep_name}`:w?.trigger_dep_index!=null?` <- #${w.trigger_dep_index}`:"",N=u.in_batch?" [batch]":"";return`${b}${h}${u.type.toUpperCase()}${c.reset}${y}${k}${N}`};e.onEvent(u=>{a(u.type)&&s(l(u),u)})}addDisposer(e){return this._disposers.add(e),()=>{this._disposers.delete(e)}}destroy(){Bt(this._disposers,this.name),this.signal([[B]],{internal:!0}),Bt(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}_destroyClearOnly(){for(let e of[...this._mounts.values()])e._parent=void 0,e._destroyClearOnly();this._mounts.clear(),this._nodes.clear(),this._parent=void 0}snapshot(e){let{expand:t,...n}=this.describe({detail:"full"}),s={};for(let a of Object.keys(n.nodes).sort()){let{lastMutation:c,guard:d,...f}=n.nodes[a];s[a]=f}let o=[...n.subgraphs].sort(),i={...n,version:1,nodes:s,subgraphs:o};if(e?.format==null)return i;if(e.format==="json-string")return JSON.stringify(i);if(e.format==="bytes"){if(e.codec==null)throw new Error("snapshot({format: 'bytes'}) requires a `codec` name");let a=this.config.lookupCodec(e.codec);if(a==null)throw new Error(`snapshot: codec "${e.codec}" is not registered on this graph's config. Call config.registerCodec(...) before creating nodes.`);return Ot(a,a.encode(i))}throw new Error(`snapshot: unknown format "${String(e.format)}"`)}static decode(e,t){let n=t?.config??le,{codec:s,codecVersion:o,payload:i}=kt(e,n);return s.decode(i,o)}restore(e,t){if(Ht(e),e.name!==this.name)throw new Error(`Graph "${this.name}": restore snapshot name "${e.name}" does not match this graph`);let n=t?.only==null?null:(Array.isArray(t.only)?t.only:[t.only]).map(o=>Be(o)),s=t?.includeProducers===!0;for(let o of Object.keys(e.nodes).sort()){if(n!==null&&!n.some(a=>a.test(o)))continue;let i=e.nodes[o];if(i!==void 0){if(!("value"in i)||i.value===void 0){"value"in i&&i.value===void 0&&t?.onError?.(o,new Error(`restore: slice.value is undefined for "${o}" (undefined is the global SENTINEL; not valid DATA)`));continue}if(!(i.type==="derived"||i.type==="effect")&&!(i.type==="producer"&&!s)){if(i.v!=null){let c=this.tryResolve(o)?.v;if(c!=null&&c.id===i.v.id&&c.version===i.v.version)continue}try{this.set(o,i.value)}catch(a){t?.onError?.(o,a)}}}}}static fromSnapshot(e,t){Ht(e);let n=typeof t=="function"?t:t?.build,s=typeof t=="function"?void 0:t?.factories,o=new r(e.name);if(n)return n(o),o.restore(e),o;for(let l of[...e.subgraphs].sort((u,h)=>{let b=u.split(C).length,v=h.split(C).length;return b!==v?b-v:u<h?-1:u>h?1:0})){let u=l.split(C),h=o;for(let b of u)h._mounts.has(b)||h.mount(b,new r(b)),h=h._mounts.get(b)}let i=s?Object.entries(s).map(([l,u])=>({re:Be(l),factory:u})):[],a=l=>{for(let u of i)if(u.re.test(l))return u.factory},c=l=>{let u=l.split(C),h=u.pop();if(h==null||h.length===0)throw new Error(`invalid snapshot path "${l}"`);let b=o;for(let v of u){let p=b._mounts.get(v);if(!p)throw new Error(`unknown mount "${v}" in path "${l}"`);b=p}return[b,h]},d=Object.entries(e.nodes).filter(([l])=>!l.includes(`${C}${U}${C}`)).sort((l,u)=>l[0]<u[0]?-1:l[0]>u[0]?1:0),f=new Map(d),g=new Map,m=!0;for(;f.size>0&&m;){m=!1;for(let[l,u]of[...f.entries()]){let h=u?.deps??[];if(!h.every(k=>g.has(k)))continue;let[b,v]=c(l),p={...u?.meta??{}},y=a(l),w;if(u?.type==="state")w=Q(u.value,{meta:p});else{if(y==null)continue;w=y(v,{path:l,type:u.type,value:u.value,meta:p,deps:h,resolvedDeps:h.map(k=>g.get(k))})}b.add(w,{name:v}),g.set(l,w),f.delete(l),m=!0}}if(f.size>0){let l=[...f.keys()].sort().join(", ");throw new Error(`Graph.fromSnapshot could not reconstruct nodes without build callback: ${l}. Pass matching factories via fromSnapshot(data, { factories: { pattern: factoryFn } }).`)}return o.restore(e),o}toJSON(){return this.snapshot()}attachStorage(e,t={}){let n=e.map(d=>({tier:d,debounceMs:Math.max(0,d.debounceMs??0),compactEvery:Math.max(1,d.compactEvery??10),timer:void 0,seq:0,lastSnapshot:void 0,lastFingerprint:"",disposed:!1,savePending:void 0}));t.autoRestore===!0&&this._cascadeRestore(e,t.onError);let s=(d,f)=>{if(d.disposed)return;let g=Cn(f.nodes);if(d.lastSnapshot!=null&&g!==""&&g===d.lastFingerprint)return;let m=d.seq+1,l=De(),b=d.lastSnapshot==null||m%d.compactEvery===0?{mode:"full",snapshot:f,seq:m,timestamp_ns:l,format_version:he}:{mode:"diff",diff:Xn(d.lastSnapshot,f),seq:m,timestamp_ns:l,format_version:he};if(d.tier.filter&&!d.tier.filter(this.name,b))return;let v;try{v=d.tier.save(this.name,b)}catch(p){t.onError?.(p,d.tier);return}if(v&&typeof v.then=="function"){let w=(d.savePending??Promise.resolve()).then(()=>v,()=>v).then(()=>{d.disposed||(d.seq=m,d.lastSnapshot=f,d.lastFingerprint=g)},k=>{t.onError?.(k,d.tier)});d.savePending=w.finally(()=>{d.savePending===w&&(d.savePending=void 0)})}else d.seq=m,d.lastSnapshot=f,d.lastFingerprint=g},o=(d,f)=>{try{s(d,f)}catch(g){t.onError?.(g,d.tier)}},i=(d,f)=>{if(!f.some(u=>{let h=this.config.messageTier(u[0]);return h>=3&&h<5}))return;if(t.filter){let u=this.tryResolve(d);if(u==null)return;let h=ut(u,Pe("standard"));if(!t.filter(d,h))return}let m,l=()=>(m==null&&(m=this.snapshot()),m);for(let u of n)u.disposed||(u.debounceMs===0?o(u,l()):(u.timer==null&&(u.timer=new je),u.timer.start(u.debounceMs,()=>{u.disposed||o(u,this.snapshot())})))},a;if(t.paths!=null){let f=(typeof t.paths=="string"?this._pathsMatching(t.paths):t.paths).map(g=>{let m=this.tryResolve(g);return m==null?()=>{}:m.subscribe(l=>i(g,l))});a=()=>{for(let g of f)g()}}else a=this.observe().subscribe((d,f)=>i(d,f));let c=()=>{a();for(let d of n)d.disposed=!0,d.timer?.cancel();this._storageDisposers.delete(c)};return this._storageDisposers.add(c),{dispose:c}}async _cascadeRestore(e,t){for(let n of e){let s;try{s=await n.load(this.name)}catch(i){t?.(i,n);continue}if(s==null||typeof s!="object"||Array.isArray(s))continue;let o=s;try{if(o.mode==="full"&&o.snapshot!=null)return this.restore(o.snapshot),!0;if(o.version===he&&o.nodes!=null)return this.restore(o),!0}catch(i){t?.(i,n)}}return!1}static async fromStorage(e,t,n){for(let s of t){let o;try{o=await s.load(e)}catch(c){n?.onError?.(c,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===he&&i.nodes!=null?i:void 0;if(a!=null)try{return r.fromSnapshot(a,n)}catch(c){n?.onError?.(c,s)}}throw new Error(`Graph.fromStorage: no tier held a restorable record for "${e}" across ${t.length} tier(s)`)}_annotations=new Map;_traceRing;trace(e,t,n){if(e!=null&&t!=null){if(this.tryResolve(e)==null)return;if(this._annotations.set(e,t),this.config.inspectorEnabled){let s={path:e,annotation:t,timestamp_ns:ue(),...n?.actor!=null?{actor:n.actor}:{}};this._traceRing.push(s)}return}return e!=null?this.config.inspectorEnabled?this._annotations.get(e):void 0:this.config.inspectorEnabled?this._traceRing.toArray():[]}annotation(e){return this._annotations.get(e)}clearTrace(){this._annotations.clear(),this._traceRing.clear()}pruneTrace(e){let t=this._traceRing.toArray().filter(s=>!e(s)),n=this._traceRing.size-t.length;this._traceRing.clear();for(let s of t)this._traceRing.push(s);return n}static diff(e,t){let n=new Set(Object.keys(e.nodes)),s=new Set(Object.keys(t.nodes)),o=[...s].filter(p=>!n.has(p)).sort(),i=[...n].filter(p=>!s.has(p)).sort(),a=[],c=[];for(let p of n){if(!s.has(p))continue;let y=e.nodes[p],w=t.nodes[p],k=y.v,N=w.v;k!=null&&N!=null&&k.id===N.id&&k.version!==N.version&&c.push({path:p,id:k.id,from:k.version,to:N.version});let _=k!=null&&N!=null&&k.id===N.id&&k.version===N.version;for(let O of["type","status","sentinel"]){let R=y[O],$=w[O];R!==$&&a.push({path:p,field:O,from:R,to:$})}if(!_)for(let O of["value","meta"]){let R=y[O],$=w[O];Mn(R,$)||a.push({path:p,field:O,from:R,to:$})}}let d=p=>`${p.from} ${p.to}`,f=new Set(e.edges.map(d)),g=new Set(t.edges.map(d)),m=t.edges.filter(p=>!f.has(d(p))),l=e.edges.filter(p=>!g.has(d(p))),u=new Set(e.subgraphs),h=new Set(t.subgraphs),b=[...h].filter(p=>!u.has(p)).sort(),v=[...u].filter(p=>!h.has(p)).sort();return{nodesAdded:o,nodesRemoved:i,nodesChanged:a,versionChanges:c,edgesAdded:m,edgesRemoved:l,subgraphsAdded:b,subgraphsRemoved:v}}};function Xn(r,e){let t=ge.diff(r,e),n={};for(let s of t.nodesAdded){let o=e.nodes[s];o!=null&&(n[s]=o)}return{...t,nodesAddedFull:n}}function Ut(r,e,t,n={}){let s={paths:[],depths:new Map,truncated:!1};if(!e)return n.withDetail?s:[];if(!n.both&&t!=="upstream"&&t!=="downstream")throw new Error('reachable: direction must be "upstream" or "downstream"');let o=n.maxDepth;if(o!=null&&(!Number.isInteger(o)||o<0))throw new Error("reachable: maxDepth must be an integer >= 0");if(o===0)return n.withDetail?s:[];let i=new Map,a=new Map,c=new Map,d=new Map,f=new Set;for(let[y,w]of Object.entries(r.nodes)){if(!y)continue;f.add(y);let k=w.deps??[];i.set(y,k);for(let N of k)N&&(f.add(N),a.has(N)||a.set(N,new Set),a.get(N).add(y))}for(let y of r.edges){if(y==null||typeof y!="object")continue;let w=typeof y.from=="string"?y.from:"",k=typeof y.to=="string"?y.to:"";!w||!k||(f.add(w),f.add(k),d.has(w)||d.set(w,new Set),d.get(w).add(k),c.has(k)||c.set(k,new Set),c.get(k).add(w))}if(!f.has(e))return n.withDetail?s:[];let g=n.both===!0,m=y=>{if(g){let _=i.get(y)??[],O=c.get(y),R=a.get(y),$=d.get(y),x=[..._];return O&&x.push(...O),R&&x.push(...R),$&&x.push(...$),x}if(t==="upstream"){let _=i.get(y)??[],O=c.get(y);return O?[..._,...O]:_}let w=a.get(y),k=d.get(y),N=w?[...w]:[];return k&&N.push(...k),N},l=new Set([e]),u=new Map,h=[{path:e,depth:0}],b=0,v=!1;for(;b<h.length;){let y=h[b++];if(o!=null&&y.depth>=o){m(y.path).length>0&&(v=!0);continue}for(let w of m(y.path))!w||l.has(w)||(l.add(w),u.set(w,y.depth+1),h.push({path:w,depth:y.depth+1}))}let p=[...u.keys()].sort((y,w)=>y<w?-1:y>w?1:0);return n.withDetail?{paths:p,depths:u,truncated:v}:p}function Zn(r,e){if(r.length!==e.length)return!1;for(let t=0;t<r.length;t++){let n=r[t],s=e[t];if(n.path!==s.path||n.type!==s.type||n.status!==s.status||n.hop!==s.hop||n.dep_index!==s.dep_index||n.annotation!==s.annotation||n.value!==s.value||n.lastMutation!==s.lastMutation)return!1;let o=n.v,i=s.v;if(o!==i&&(o==null||i==null||o.id!==i.id||o.version!==i.version))return!1}return!0}Ae();te();fe();Fe();te();lt();function Yt(r,e){let t=r.cache??0;return t>=e?!1:(r.down([[H],[j,t+1]]),!0)}function Xt(r,e,t){return{[r]:!0,[`${r}_type`]:e,...t??{}}}function Zt(r,e){return Xt("reduction",r,e)}function Qt(r,e,t,n){let s=n?.maxIterations??10,o=`__feedback_${e}`,i=Q(0,{meta:Zt("feedback_counter",{maxIterations:s,feedbackFrom:e,feedbackTo:t})});r.add(i,{name:o});let a=r.resolve(e),c=r.resolve(t),d=`__feedback_effect_${e}`,f=se([],(g,m)=>{let l=a.subscribe(u=>{for(let h of u){let b=h[0];if(b===j){let v=h[1];if(v==null)return;Ee(()=>{Yt(i,s)&&c.emit(v)})}else if(b===z||b===M){let v=b===M&&h.length>1?[M,h[1]]:[b];i.down([v])}}});return()=>l()},{name:d,describeKind:"effect",meta:{...Zt("feedback_effect",{feedbackFrom:e,feedbackTo:t}),_internal:!0}});return r.add(f,{name:d}),r.addDisposer(pe(f)),r}function ke(r){return typeof r=="object"&&r!==null&&"factory"in r}function gt(r){return typeof r=="object"&&r!==null&&"factory"in r}function tn(r){return ke(r)?r.factory:r}function nn(r){return gt(r)?r.factory:r}function rn(r){let e=[];if(r.fns){let t=new Map;for(let[n,s]of Object.entries(r.fns)){let o=ke(s)?s.tags?.[0]??"Other":"Other";t.has(o)||t.set(o,[]),t.get(o).push(Qn(n,s))}for(let[n,s]of t)e.push(`${n}:
1
+ "use strict";var Qe=Object.defineProperty;var On=Object.getOwnPropertyDescriptor;var Sn=Object.getOwnPropertyNames;var Tn=Object.prototype.hasOwnProperty;var K=(t,e)=>()=>(t&&(e=t(t=0)),e);var Nn=(t,e)=>{for(var n in e)Qe(t,n,{get:e[n],enumerable:!0})},kn=(t,e,n,r)=>{if(e&&typeof e=="object"||typeof e=="function")for(let s of Sn(e))!Tn.call(t,s)&&s!==n&&Qe(t,s,{get:()=>e[s],enumerable:!(r=On(e,s))||r.enumerable});return t};var En=t=>kn(Qe({},"__esModule",{value:!0}),t);function St(t,e){let n=new TextEncoder().encode(t.name);if(n.length===0||n.length>255)throw new Error(`encodeEnvelope: codec name "${t.name}" encodes to ${n.length} bytes (must be 1\u2013255)`);let r=t.version;if(!Number.isInteger(r)||r<0||r>65535)throw new Error(`encodeEnvelope: codec.version ${r} out of u16 range (expected integer 0\u201365535)`);let s=2+n.length+2+e.length;if(s>4294967295)throw new Error(`encodeEnvelope: total envelope size ${s} exceeds 2^32-1 bytes (payload ${e.length} bytes)`);let o=new Uint8Array(s),i=0;return o[i++]=et,o[i++]=n.length,o.set(n,i),i+=n.length,o[i++]=r>>>8&255,o[i++]=r&255,o.set(e,i),o}function Tt(t,e){if(t.length<Ot)throw new Error(`decodeEnvelope: bytes too short (${t.length} < ${Ot})`);let n=0,r=t[n++];if(r!==et)throw new Error(`decodeEnvelope: unsupported envelope version ${r} (expected ${et})`);let s=t[n++];if(s===0)throw new Error("decodeEnvelope: name_len must be >= 1");if(n+s+2>t.length)throw new Error(`decodeEnvelope: envelope truncated (need ${n+s+2} bytes, have ${t.length})`);let o=new TextDecoder().decode(t.subarray(n,n+s));n+=s;let i=(t[n]<<8|t[n+1])>>>0;n+=2;let a=t.subarray(n),c=e.lookupCodec(o);if(c==null)throw new Error(`decodeEnvelope: codec "${o}" not registered (envelope codec_v=${i})`);return{codec:c,codecVersion:i,payload:a}}function Nt(t){t.registerCodec(Rn)}var Rn,et,Ot,tt=K(()=>{"use strict";Rn={name:"json",version:1,contentType:"application/json",encode(t){let e=JSON.stringify(t);return new TextEncoder().encode(e)},decode(t,e){let n=new TextDecoder().decode(t);return JSON.parse(n)}},et=1,Ot=4});function ke(t){if(t==null)return ae;let{type:e,id:n,...r}=t;return{type:e??"system",id:n??"",...r}}var ae,nt=K(()=>{"use strict";ae={type:"system",id:""}});function Ee(){return ce>0||ve}function kt(){return ce>0}function _e(t){ce>0?we.push(t):t()}function Re(t){ce+=1;let e=!1;try{t()}catch(n){throw e=!0,n}finally{if(ce-=1,ce===0)if(e){if(!ve){let n=we.splice(0);for(let r of n)try{r()}catch{}re.length=0,se.length=0,ue.length=0}}else An()}}function An(){let t=!ve;t&&(ve=!0);let e=[],n=0;try{for(;re.length>0||se.length>0||ue.length>0||t&&we.length>0;){if(t&&we.length>0){let o=we.splice(0);for(let i of o)try{i()}catch(a){e.push(a)}continue}if(n+=1,n>1e3)throw re.length=0,se.length=0,ue.length=0,new Error("batch drain exceeded 1000 iterations \u2014 likely a reactive cycle");let s=(re.length>0?re:se.length>0?se:ue).splice(0);for(let o of s)try{o()}catch(i){e.push(i)}}}finally{t&&(ve=!1)}if(e.length===1)throw e[0];if(e.length>1)throw new AggregateError(e,"batch drain: multiple callbacks threw")}function Ae(t,e,n){if(e.length===0)return;if(e.length===1){let u=n(e[0][0]);if(u<3||!Ee()){t(e);return}(u>=5?ue:u===4?se:re).push(()=>t(e));return}let r=e.length,s=r,o=r,i=r,a=0;for(;a<r&&n(e[a][0])<3;)a++;for(s=a;a<r&&n(e[a][0])===3;)a++;for(o=a;a<r&&n(e[a][0])===4;)a++;i=a;let c=Ee();if(s>0){let u=e.slice(0,s);t(u)}if(o>s){let u=e.slice(s,o);c?re.push(()=>t(u)):t(u)}if(i>o){let u=e.slice(o,i);c?se.push(()=>t(u)):t(u)}if(r>i){let u=e.slice(i,r);c?ue.push(()=>t(u)):t(u)}}var ce,ve,re,se,ue,we,De=K(()=>{"use strict";ce=0,ve=!1,re=[],se=[],ue=[],we=[]});function de(){return Math.trunc(performance.now()*1e6)}function Ce(){return Date.now()*1e6}var rt=K(()=>{"use strict"});var xe,P,H,Y,X,Z,Q,B,V,$,le,st,Dn,ot,Cn,Mn,it,Et,Rt,At,at,fe=K(()=>{"use strict";xe=Symbol.for("graphrefly/START"),P=Symbol.for("graphrefly/DATA"),H=Symbol.for("graphrefly/DIRTY"),Y=Symbol.for("graphrefly/RESOLVED"),X=Symbol.for("graphrefly/INVALIDATE"),Z=Symbol.for("graphrefly/PAUSE"),Q=Symbol.for("graphrefly/RESUME"),B=Symbol.for("graphrefly/TEARDOWN"),V=Symbol.for("graphrefly/COMPLETE"),$=Symbol.for("graphrefly/ERROR"),le=Object.freeze([H]),st=Object.freeze([Y]),Dn=Object.freeze([X]),ot=Object.freeze([xe]),Cn=Object.freeze([V]),Mn=Object.freeze([B]),it=Object.freeze([le]),Et=Object.freeze([st]),Rt=Object.freeze([Dn]),At=Object.freeze([Cn]),at=Object.freeze([Mn])});function Dt(t){t.registerMessageType(xe,{tier:0,wireCrossing:!1}),t.registerMessageType(H,{tier:1,wireCrossing:!1}),t.registerMessageType(X,{tier:1,wireCrossing:!1,metaPassthrough:!1}),t.registerMessageType(Z,{tier:2,wireCrossing:!1}),t.registerMessageType(Q,{tier:2,wireCrossing:!1}),t.registerMessageType(P,{tier:3,wireCrossing:!0}),t.registerMessageType(Y,{tier:3,wireCrossing:!0}),t.registerMessageType(V,{tier:4,wireCrossing:!0,metaPassthrough:!1}),t.registerMessageType($,{tier:4,wireCrossing:!0,metaPassthrough:!1}),t.registerMessageType(B,{tier:5,wireCrossing:!0,metaPassthrough:!1})}var Me,Ct=K(()=>{"use strict";fe();Me=class{_messageTypes=new Map;_codecs=new Map;_onMessage;_onSubscribe;_defaultVersioning;_defaultHashFn;_inspectorEnabled=!(typeof process<"u"&&process.env?.NODE_ENV==="production");_globalInspector;_frozen=!1;tierOf;constructor(e){this._onMessage=e.onMessage,this._onSubscribe=e.onSubscribe,this._defaultVersioning=e.defaultVersioning,this._defaultHashFn=e.defaultHashFn,this.tierOf=n=>{let r=this._messageTypes.get(n);return r!=null?r.tier:1}}get onMessage(){return this._frozen=!0,this._onMessage}get onSubscribe(){return this._frozen=!0,this._onSubscribe}set onMessage(e){this._assertUnfrozen(),this._onMessage=e}set onSubscribe(e){this._assertUnfrozen(),this._onSubscribe=e}get defaultVersioning(){return this._defaultVersioning}set defaultVersioning(e){this._assertUnfrozen(),this._defaultVersioning=e}get defaultHashFn(){return this._defaultHashFn}set defaultHashFn(e){this._assertUnfrozen(),this._defaultHashFn=e}get inspectorEnabled(){return this._inspectorEnabled}set inspectorEnabled(e){this._inspectorEnabled=e}get globalInspector(){return this._globalInspector}set globalInspector(e){this._globalInspector=e}registerMessageType(e,n){return this._assertUnfrozen(),this._messageTypes.set(e,{tier:n.tier,wireCrossing:n.wireCrossing??n.tier>=3,metaPassthrough:n.metaPassthrough??!0}),this}messageTier(e){let n=this._messageTypes.get(e);return n!=null?n.tier:1}isWireCrossing(e){let n=this._messageTypes.get(e);return n!=null?n.wireCrossing:!0}isLocalOnly(e){return!this.isWireCrossing(e)}isMetaPassthrough(e){let n=this._messageTypes.get(e);return n!=null?n.metaPassthrough:!0}isKnownMessageType(e){return this._messageTypes.has(e)}registerCodec(e){return this._assertUnfrozen(),this._codecs.set(e.name,e),this}lookupCodec(e){return this._codecs.get(e)}_isFrozen(){return this._frozen}_assertUnfrozen(){if(this._frozen)throw new Error("GraphReFlyConfig is frozen: a node has already captured this config. Register custom types and set hooks before creating any node.")}}});function ct(t){let e=Gn.filter(n=>t({type:n,id:""},"write"));return e.length===0?"restricted":e.includes("human")&&e.includes("llm")&&e.every(n=>n==="human"||n==="llm"||n==="system")?"both":e.length===1?e[0]:e.join("+")}var q,Gn,Ge=K(()=>{"use strict";q=class extends Error{actor;action;nodeName;constructor(e,n){super(n??`GuardDenied: action "${String(e.action)}" denied for actor type "${String(e.actor.type)}"`),this.name="GuardDenied",this.actor=e.actor,this.action=e.action,this.nodeName=e.nodeName}get node(){return this.nodeName}},Gn=["human","llm","wallet","system"]});function ut(t){if(t===void 0)return null;if(typeof t=="number"){if(!Number.isFinite(t))throw new TypeError(`Cannot hash non-finite number: ${t}`);if(Number.isInteger(t)&&!Number.isSafeInteger(t))throw new TypeError(`Cannot hash integer outside safe range (|n| > 2^53-1): ${t}. Cross-language cid parity is not guaranteed for unsafe integers.`);return t}if(typeof t=="string"||typeof t=="boolean"||t===null)return t;if(Array.isArray(t))return t.map(ut);if(typeof t=="object"&&t!==null){let e={};for(let n of Object.keys(t).sort())e[n]=ut(t[n]);return e}return null}function In(t){let e=Ln.encode(t),n=e.length,r=n*8,s=n+9+63&-64,o=new Uint8Array(s);o.set(e),o[n]=128;let i=new DataView(o.buffer);i.setUint32(s-4,r>>>0,!1),i.setUint32(s-8,Math.floor(r/4294967296)>>>0,!1);let a=1779033703,c=3144134277,u=1013904242,f=2773480762,p=1359893119,g=2600822924,l=528734635,d=1541459225,m=new Uint32Array(64),b=(h,y)=>h>>>y|h<<32-y;for(let h=0;h<s;h+=64){for(let N=0;N<16;N++)m[N]=i.getUint32(h+N*4,!1);for(let N=16;N<64;N++){let E=m[N-15],S=m[N-2],A=b(E,7)^b(E,18)^E>>>3,F=b(S,17)^b(S,19)^S>>>10;m[N]=m[N-16]+A+m[N-7]+F>>>0}let y=a,w=c,O=u,T=f,_=p,x=g,k=l,D=d;for(let N=0;N<64;N++){let E=b(_,6)^b(_,11)^b(_,25),S=_&x^~_&k,A=D+E+S+$n[N]+m[N]>>>0,F=b(y,2)^b(y,13)^b(y,22),J=y&w^y&O^w&O,ne=F+J>>>0;D=k,k=x,x=_,_=T+A>>>0,T=O,O=w,w=y,y=A+ne>>>0}a=a+y>>>0,c=c+w>>>0,u=u+O>>>0,f=f+T>>>0,p=p+_>>>0,g=g+x>>>0,l=l+k>>>0,d=d+D>>>0}let v=h=>h.toString(16).padStart(8,"0");return v(a)+v(c)+v(u)+v(f)+v(p)+v(g)+v(l)+v(d)}function dt(t){let e=ut(t??null),n=JSON.stringify(e);return In(n).slice(0,16)}function Pn(){let t=globalThis.crypto;if(t?.randomUUID)return t.randomUUID();let e=()=>Math.floor(Math.random()*4294967296).toString(16).padStart(8,"0"),n=e()+e()+e()+e();return`${n.slice(0,8)}-${n.slice(8,12)}-4${n.slice(13,16)}-${(parseInt(n.slice(16,17),16)&3|8).toString(16)}${n.slice(17,20)}-${n.slice(20,32)}`}function lt(t,e,n){let r=n?.id??Pn();if(t===0)return{id:r,version:0};let o=(n?.hash??dt)(e);return{id:r,version:0,cid:o,prev:null}}function Mt(t,e,n){t.version+=1,"cid"in t&&(t.prev=t.cid,t.cid=n(e))}var $n,Ln,Gt=K(()=>{"use strict";$n=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]),Ln=new TextEncoder});function It(t){return{node:t,unsub:null,prevData:void 0,dirty:!1,involvedThisWave:!1,dataBatch:[],terminal:void 0}}function ft(t){t.prevData=void 0,t.dirty=!1,t.involvedThisWave=!1,t.dataBatch.length=0,t.terminal=void 0}function $e(t){return t.length===0?t:typeof t[0]=="symbol"?[t]:t}function oe(t,e,n){let r=Pt(t)?t:[],s=typeof t=="function"?t:typeof e=="function"?e:void 0,o={};return Pt(t)?o=(pt(e)?e:n)??{}:pt(t)?o=t:o=(pt(e)?e:n)??{},new L(r,s,o)}var $t,Lt,Fn,jn,pe,L,Pt,pt,he=K(()=>{"use strict";tt();nt();De();rt();Ct();Ge();fe();Gt();$t=()=>{},Lt=100;Fn=(t,e,n,r)=>{n.direction==="down-in"&&t._onDepMessage(n.depIndex,e)},jn=(t,e,n,r)=>{let s=t;if(s._status==="completed"||s._status==="errored")return;let o=s._cached,i=o===void 0?[ot]:[ot,[P,o]];s._status==="dirty"&&i.push(le),Ae(e,i,s._config.tierOf)},pe=new Me({onMessage:Fn,onSubscribe:jn});Dt(pe);Nt(pe);L=class t{_optsName;_describeKind;meta;_hasMeta;_config;_deps;_sinks=null;_sinkCount=0;_cached;_status;_cleanup;_store={};_waveHasNewData=!1;_hasNewTerminal=!1;_hasCalledFnOnce=!1;_paused=!1;_pendingWave=!1;_isExecutingFn=!1;_pendingRerun=!1;_rerunDepth=0;_dirtyDepCount=0;_batchPendingMessages=null;_pauseLocks=null;_pauseBuffer=null;_fn;_equals;_resubscribable;_resetOnTeardown;_autoComplete;_autoError;_pausable;_partial;_guard;_extraGuards;_hashFn;_versioning;_versioningLevel;_lastMutation;_inspectorHooks;_actions;constructor(e,n,r){this._config=r.config??pe,this._config.onMessage,this._optsName=r.name,this._describeKind=r.describeKind,this._equals=r.equals??Object.is,this._resubscribable=r.resubscribable??!1,this._resetOnTeardown=r.resetOnTeardown??!1,this._autoComplete=r.completeWhenDepsComplete??!0,this._autoError=r.errorWhenDepsError??!0,this._pausable=r.pausable??!0,this._guard=r.guard,this._fn=n,this._partial=r.partial??!1,this._cached=r.initial!==void 0?r.initial:void 0,this._status=e.length===0&&n==null&&this._cached!==void 0?"settled":"sentinel",this._hashFn=r.versioningHash??this._config.defaultHashFn??dt;let s=r.versioning??this._config.defaultVersioning;this._versioningLevel=s,this._versioning=s!=null?lt(s,this._cached===void 0?void 0:this._cached,{id:r.versioningId,hash:this._hashFn}):void 0,this._deps=e.map(It);let o={};for(let[a,c]of Object.entries(r.meta??{})){let u={initial:c,name:`${r.name??"node"}:meta:${a}`,describeKind:"state",config:this._config};r.guard!=null&&(u.guard=r.guard),o[a]=new t([],void 0,u)}Object.freeze(o),this.meta=o,this._hasMeta=Object.keys(o).length>0;let i=this;this._actions={emit(a){i._emit([[P,a]])},down(a){i._emit($e(a))},up(a){i._emitUp($e(a))}},this.down=this.down.bind(this),this.up=this.up.bind(this)}get _isTerminal(){return this._status==="completed"||this._status==="errored"}get name(){return this._optsName}get status(){return this._status}get cache(){return this._cached===void 0?void 0:this._cached}get lastMutation(){return this._lastMutation}get v(){return this._versioning}hasGuard(){return this._guard!=null}_applyVersioning(e,n){if(this._isExecutingFn)throw new Error(`Node "${this.name}": _applyVersioning cannot run mid-fn \u2014 call it outside of \`_execFn\` (typically at graph setup time before the first subscribe).`);let r=this._versioningLevel;if(r!=null&&e<=r)return;let s=n?.hash??this._hashFn;s!==this._hashFn&&(this._hashFn=s);let o=this._cached===void 0?void 0:this._cached,i=this._versioning,a=i?.id??n?.id,c=i?.version??0,u=lt(e,o,{id:a,hash:s});u.version=c,this._versioning=u,this._versioningLevel=e}_setInspectorHook(e){return e==null?()=>{}:(this._inspectorHooks==null&&(this._inspectorHooks=new Set),this._inspectorHooks.add(e),()=>{this._inspectorHooks?.delete(e),this._inspectorHooks?.size===0&&(this._inspectorHooks=void 0)})}_pushGuard(e){return this._extraGuards==null&&(this._extraGuards=new Set),this._extraGuards.add(e),()=>{this._extraGuards?.delete(e),this._extraGuards?.size===0&&(this._extraGuards=void 0)}}allowsObserve(e){if(this._guard==null&&this._extraGuards==null)return!0;let n=ke(e);if(this._guard!=null&&!this._guard(n,"observe"))return!1;if(this._extraGuards!=null){for(let r of this._extraGuards)if(!r(n,"observe"))return!1}return!0}_checkGuard(e){if(e?.internal)return;let n=this._guard!=null||this._extraGuards!=null,r=e?.actor!=null;if(!n&&!r)return;let s=ke(e?.actor),o=e?.delivery==="signal"?"signal":"write";if(this._guard!=null&&!this._guard(s,o))throw new q({actor:s,action:o,nodeName:this.name});if(this._extraGuards!=null){for(let i of this._extraGuards)if(!i(s,o))throw new q({actor:s,action:o,nodeName:this.name})}this._lastMutation={actor:s,timestamp_ns:Ce()}}down(e,n){let r=$e(e);r.length!==0&&(this._checkGuard(n),this._emit(r))}emit(e,n){this._checkGuard(n),this._emit([[P,e]])}up(e,n){if(this._deps.length===0)return;let r=$e(e);if(r.length===0)return;this._checkGuard(n);let s=n??{internal:!0};this._validateUpTiers(r);for(let o of this._deps)o.node.up?.(r,s)}_emitUp(e){if(this._deps.length!==0&&e.length!==0){this._validateUpTiers(e);for(let n of this._deps)n.node.up?.(e,{internal:!0})}}_validateUpTiers(e){let n=this._config.tierOf;for(let r of e){let s=n(r[0]);if(s===3||s===4)throw new Error(`Node "${this.name}": tier-${s} messages cannot flow up \u2014 DATA/RESOLVED/COMPLETE/ERROR are downstream-only. Use \`down(...)\` for value delivery; \`up(...)\` is for control signals (DIRTY, INVALIDATE, PAUSE, RESUME, TEARDOWN).`)}}subscribe(e,n){if(n!=null&&this._guard!=null){let c=ke(n);if(!this._guard(c,"observe"))throw new q({actor:c,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 c of this._deps)ft(c);if(this._partial===!1){for(let c of this._deps)if(c.prevData!==void 0||c.dataBatch.length!==0||c.terminal!==void 0||c.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(c){throw this._sinkCount-=1,c}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(c){if(this._sinkCount-=1,this._removeSink(e),this._sinkCount===0&&(this._status="sentinel"),typeof o=="function")try{o()}catch{}throw c}this._status==="sentinel"&&this._cached===void 0&&(this._status="pending");let a=!1;return()=>{a||(a=!0,this._sinkCount-=1,this._removeSink(e),typeof o=="function"&&o(),this._sinks==null&&this._deactivate())}}_removeSink(e){if(this._sinks===e)this._sinks=null;else if(this._sinks!=null&&typeof this._sinks!="function")if(this._sinks.delete(e),this._sinks.size===1){let[n]=this._sinks;this._sinks=n}else this._sinks.size===0&&(this._sinks=null)}_activate(){if(this._deps.length===0){this._fn&&this._execFn();return}this._dirtyDepCount=0;let e=this._deps.length,n=0;try{for(let r=0;r<e;r++){let s=r,o=this._deps[r];o.unsub=$t,o.unsub=o.node.subscribe(i=>{if(o.unsub===null)return;let a=this._config.tierOf,c=!1;for(let u of i)a(u[0])>=3&&(c=!0),this._config.onMessage(this,u,{direction:"down-in",depIndex:s},this._actions);c&&this._maybeRunFnOnSettlement()}),n++}}catch(r){this._deps[n].unsub=null;for(let s=0;s<n;s++){let o=this._deps[s];if(o.unsub!=null){let i=o.unsub;o.unsub=null;try{i()}catch{}ft(o)}}throw this._dirtyDepCount=0,r}}_addDep(e){for(let s=0;s<this._deps.length;s++)if(this._deps[s].node===e)return s;let n=this._deps.length,r=It(e);if(this._deps.push(r),this._sinks==null)return n;r.dirty=!0,this._dirtyDepCount++,this._status!=="dirty"&&this._emit(it),r.unsub=$t;try{r.unsub=e.subscribe(s=>{if(r.unsub===null)return;let o=this._config.tierOf,i=!1;for(let a of s)o(a[0])>=3&&(i=!0),this._config.onMessage(this,a,{direction:"down-in",depIndex:n},this._actions);i&&this._maybeRunFnOnSettlement()})}catch(s){throw r.unsub=null,this._deps.pop(),this._dirtyDepCount--,s}return n}_deactivate(e=!1){let n=this._cleanup;if(this._cleanup=void 0,typeof n=="function")try{n()}catch(r){this._emit([[$,this._wrapFnError("cleanup threw",r)]])}else if(n!=null&&typeof n=="object"){let r=n.deactivate;if(typeof r=="function")try{r()}catch(s){this._emit([[$,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{}}ft(r)}this._waveHasNewData=!1,this._hasNewTerminal=!1,this._hasCalledFnOnce=!1,this._paused=!1,this._pendingWave=!1,this._pendingRerun=!1,this._rerunDepth=0,this._store={},this._dirtyDepCount=0,this._pauseLocks=null,this._pauseBuffer=null,this._fn!=null&&(this._cached=void 0),e||(this._fn!=null||this._deps.length>0)&&(!this._isTerminal||this._resubscribable)&&(this._status="sentinel")}_onDepMessage(e,n){let r=this._deps[e],s=n[0];if(this._inspectorHooks!=null){let o={kind:"dep_message",depIndex:e,message:n};for(let i of this._inspectorHooks)i(o)}if(s!==xe){if(s===H){this._depDirtied(r);return}if(s===X){this._depInvalidated(r),this._emit(Rt);return}if(s===Z||s===Q){this._emit([n]);return}if(s===B){this._emit(at);return}if(s===P)this._depSettledAsData(r,n[1]);else if(s===Y)this._depSettledAsResolved(r);else if(s===V)this._depSettledAsTerminal(r,!0);else if(s===$)this._depSettledAsTerminal(r,n[1]);else{this._emit([n]);return}if(!this._fn){(s===P||s===Y)&&this._emit([n]),(s===V||s===$)&&this._maybeAutoTerminalAfterWave();return}}}_depDirtied(e){e.dirty||(e.dirty=!0,e.involvedThisWave=!0,this._dirtyDepCount++,this._status!=="dirty"&&this._emit(it))}_depSettledAsData(e,n){e.dirty&&(e.dirty=!1,this._dirtyDepCount--),e.involvedThisWave=!0,e.dataBatch.push(n),this._waveHasNewData=!0}_depSettledAsResolved(e){e.dirty&&(e.dirty=!1,this._dirtyDepCount--)}_depSettledAsTerminal(e,n){e.dirty&&(e.dirty=!1,this._dirtyDepCount--),e.terminal=n,e.involvedThisWave=!0,this._hasNewTerminal=!0}_depInvalidated(e){e.prevData=void 0,e.terminal=void 0,e.dataBatch.length=0,e.dirty?e.involvedThisWave=!1:(e.dirty=!0,e.involvedThisWave=!0,this._dirtyDepCount++)}_maybeRunFnOnSettlement(){if(!(this._isTerminal&&!this._resubscribable)&&!(this._dirtyDepCount>0)){if(!this._partial&&!this._hasCalledFnOnce)for(let e=0;e<this._deps.length;e++){let n=this._deps[e];if(n.dataBatch.length===0&&n.prevData===void 0&&n.terminal===void 0){this._maybeAutoTerminalAfterWave();return}}if(this._paused){this._pendingWave=!0;return}if(!this._waveHasNewData&&!this._hasNewTerminal&&this._hasCalledFnOnce){this._clearWaveFlags(),this._emit(Et),this._maybeAutoTerminalAfterWave();return}this._fn&&this._execFn(),this._maybeAutoTerminalAfterWave()}}_maybeAutoTerminalAfterWave(){if(this._deps.length===0||this._isTerminal)return;let e=this._deps.find(n=>n.terminal!==void 0&&n.terminal!==!0);if(e!=null){this._autoError&&this._emit([[$,e.terminal]]);return}this._autoComplete&&this._deps.every(n=>n.terminal!==void 0)&&this._emit(At)}_execFn(){if(!this._fn||this._isTerminal&&!this._resubscribable)return;if(this._isExecutingFn){this._pendingRerun=!0;return}let e=this._cleanup;if(typeof e=="function"){this._cleanup=void 0;try{e()}catch(i){this._emit([[$,this._wrapFnError("cleanup threw",i)]]);return}}else if(e!=null&&typeof e=="object"){let i=e.beforeRun;if(typeof i=="function"){e.beforeRun=void 0;try{i()}catch(a){this._emit([[$,this._wrapFnError("cleanup.beforeRun threw",a)]]);return}}}let n=this._deps.map(i=>i.involvedThisWave?i.dataBatch.length>0?[...i.dataBatch]:[]:void 0),r=this._deps.map(i=>i.prevData);for(let i=0;i<this._deps.length;i++){let a=n[i];a!=null&&a.length>0&&(this._deps[i].prevData=a[a.length-1])}let s=this._deps.map(i=>i.terminal),o={prevData:r,terminalDeps:s,store:this._store};if(this._hasCalledFnOnce=!0,this._clearWaveFlags(),this._inspectorHooks!=null){let i={kind:"run",batchData:n,prevData:r};for(let a of this._inspectorHooks)a(i)}this._isExecutingFn=!0;try{let i=this._fn(n,this._actions,o);if(typeof i=="function")this._cleanup=i;else if(i!=null&&typeof i=="object"){let a=i;(typeof a.beforeRun=="function"||typeof a.deactivate=="function"||typeof a.invalidate=="function")&&(this._cleanup=i)}}catch(i){this._emit([[$,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([[$,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,n){let r=n instanceof Error?n.message:String(n);return new Error(`Node "${this.name}": ${e}: ${r}`,{cause:n})}_frameBatch(e){let n=this._config.tierOf;if(e.length===1)return n(e[0][0])===3&&this._status!=="dirty"?[le,e[0]]:e;let r=!0,s=!1,o=!1,i=-1;for(let c of e){let u=n(c[0]);u<i&&(r=!1),u===3&&(s=!0),c[0]===H&&(o=!0),i=u}let a=e;if(!r){let c=e.map((u,f)=>({m:u,i:f,tier:n(u[0])}));c.sort((u,f)=>u.tier-f.tier||u.i-f.i),a=c.map(u=>u.m)}if(s&&!o&&this._status!=="dirty"){let c=0;for(;c<a.length&&n(a[c][0])===0;)c++;return c===0?[le,...a]:[...a.slice(0,c),le,...a.slice(c)]}return a}_emit(e){if(e.length===0)return;for(let a=0;a<e.length;a++){let c=e[a];if(c[0]===$&&c[1]===void 0)throw new TypeError('[ERROR, payload] requires a non-undefined payload (spec \xA71.2). Pass an Error object or domain tag instead \u2014 e.g. node.down([[ERROR, new Error("reason")]])')}let n=e;if(this._isTerminal&&!this._resubscribable){let a=e.filter(c=>c[0]===B||c[0]===X);if(a.length===0)return;n=a}n=this._frameBatch(n);let s=null;for(let a=0;a<n.length;a++){let c=n[a],u=c[0];if(u!==Z&&u!==Q){s?.push(c);continue}if(c.length<2)throw new Error(`Node "${this.name}": [[${u===Z?"PAUSE":"RESUME"}]] must carry a lockId payload \u2014 bare PAUSE/RESUME is a protocol violation (C0 rule). Use \`[[PAUSE, lockId]]\` / \`[[RESUME, lockId]]\`.`);let f=!0;if(this._pausable!==!1){let p=c[1];if(u===Z)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))f=!1;else if(this._pauseLocks.delete(p),this._pauseLocks.size===0){if(this._paused=!1,this._pauseBuffer!=null&&this._pauseBuffer.length>0){let g=this._pauseBuffer;this._pauseBuffer=[],this._emit(g)}this._pendingWave&&(this._pendingWave=!1,this._maybeRunFnOnSettlement())}}f?s?.push(c):s==null&&(s=n.slice(0,a))}if(s!=null){if(s.length===0)return;n=s}if(this._hasMeta&&n.some(a=>a[0]===B))for(let a of Object.keys(this.meta))try{this.meta[a]._emit(at)}catch{}let{finalMessages:o,equalsError:i}=this._updateState(n);if(o.length>0&&this._config.inspectorEnabled){let a=this._config.globalInspector;if(a!=null)try{a({kind:"emit",node:this,messages:o})}catch{}}if(o.length>0)if(this._paused&&this._pausable==="resumeAll"&&this._pauseBuffer!=null){let a=this._config.tierOf,c=[];for(let u of o)a(u[0])===3?this._pauseBuffer.push(u):c.push(u);c.length>0&&this._dispatchOrAccumulate(c)}else this._dispatchOrAccumulate(o);i!=null&&this._emit([[$,i]])}_updateState(e){let n=this._config.tierOf,r,s,o=-1,i=0;for(let f of e)n(f[0])===3&&i++;let a=i<=1,c=-1;if(this._versioning!=null&&i>1){for(let f=e.length-1;f>=0;f--)if(e[f][0]===P){c=f;break}}for(let f=0;f<e.length;f++){let p=e[f],g=p[0];if(g===P){if(p.length>=2){let l=!1;if(a&&this._cached!==void 0)try{l=this._equals(this._cached,p[1])}catch(d){s=this._wrapFnError("equals threw",d),o=f;break}if(l){r==null&&(r=e.slice(0,f)),r.push(st),this._status="resolved";continue}this._cached=p[1],this._versioning!=null&&(c<0||f===c)&&Mt(this._versioning,p[1],this._hashFn)}this._status="settled",r?.push(p)}else if(r?.push(p),g===H)this._status="dirty";else if(g===Y)this._status="resolved";else if(g===V)this._status="completed";else if(g===$)this._status="errored";else if(g===X){this._cached=void 0,this._status="dirty";let l=this._cleanup;if(typeof l=="function"){this._cleanup=void 0;try{l()}catch{}}else if(l!=null&&typeof l=="object"){let d=l.invalidate;if(typeof d=="function")try{d()}catch{}}}else g===B&&(this._resetOnTeardown&&(this._cached=void 0),this._deactivate(!0),this._status="sentinel")}let u=o>=0?r??e.slice(0,o):r??e;return s!=null?{finalMessages:u,equalsError:s}:{finalMessages:u}}_deliverToSinks=e=>{if(this._sinks==null)return;if(typeof this._sinks=="function"){this._sinks(e);return}let n=[...this._sinks];for(let r of n)r(e)};_dispatchOrAccumulate(e){if(kt()){this._batchPendingMessages===null&&(this._batchPendingMessages=[],_e(()=>this._flushBatchPending()));for(let n of e)this._batchPendingMessages.push(n);return}Ae(this._deliverToSinks,e,this._config.tierOf)}_flushBatchPending(){let e=this._batchPendingMessages;if(e===null||(this._batchPendingMessages=null,e.length===0))return;let n=this._frameBatch(e);Ae(this._deliverToSinks,n,this._config.tierOf)}},Pt=t=>Array.isArray(t),pt=t=>typeof t=="object"&&t!=null&&!Array.isArray(t)});function ee(t,e){return oe([],{...e,initial:t})}function Oe(t,e){return oe((r,s,o)=>t(s,o)??void 0,{describeKind:"producer",...e})}function ie(t,e,n){return oe(t,(s,o,i)=>{let a=s.map((c,u)=>c!=null&&c.length>0?c.at(-1):i.prevData[u]);o.emit(e(a,i))},{describeKind:"derived",...n})}function Le(t,e,n){return oe(t,(s,o,i)=>{let a=s.map((c,u)=>c!=null&&c.length>0?c.at(-1):i.prevData[u]);return e(a,o,i)??void 0},{describeKind:"effect",...n})}var Ie=K(()=>{"use strict";he()});function ge(t){return t.subscribe(()=>{})}var gt=K(()=>{"use strict"});var Fe,Ft=K(()=>{"use strict";Fe=class{_timer;_gen=0;start(e,n){this.cancel(),this._gen+=1;let r=this._gen;this._timer=setTimeout(()=>{this._timer=void 0,r===this._gen&&n()},e)}cancel(){this._timer!==void 0&&(clearTimeout(this._timer),this._timer=void 0)}get pending(){return this._timer!==void 0}}});var Ur={};Nn(Ur,{compileSpec:()=>Br,decompileGraph:()=>Vr,extractFnFactory:()=>bn,extractSourceFactory:()=>yn,generateCatalogPrompt:()=>vn,isRichFnEntry:()=>Te,isRichSourceEntry:()=>wt,llmCompose:()=>Wr,llmRefine:()=>xn,specDiff:()=>zr,validateSpec:()=>qe,validateSpecAgainstCatalog:()=>_t});module.exports=En(Ur);Ie();nt();De();rt();Ge();fe();Ge();he();function Pe(t,e){if(e!=null&&e.length>0)return new Set(e);switch(t){case"standard":return new Set(["type","status","value","deps","meta","v"]);case"full":return null;default:return new Set(["type","deps"])}}function Bn(t){return t._describeKind!=null?t._describeKind:t._deps.length>0?"derived":t._fn!=null?"producer":"state"}function Hn(t){let e={};for(let[n,r]of Object.entries(t.meta))try{e[n]=r.cache}catch{}return e}function ht(t,e){let n=e==null,r=!n&&e!=null?[...e].filter(u=>u.startsWith("meta.")).map(u=>u.slice(5)):null,s=n||e.has("meta")||r!=null&&r.length>0,o="state",i=[];t instanceof L&&(o=Bn(t),i=t._deps.map(u=>u.node.name??""));let a={type:o,deps:i};(n||e.has("status"))&&(a.status=t.status);let c=t instanceof L?t._guard:void 0;if(s){let u={...Hn(t)};if(c!=null&&u.access===void 0&&(u.access=ct(c)),r!=null&&r.length>0&&!e.has("meta")){let f={};for(let p of r)p in u&&(f[p]=u[p]);a.meta=f}else a.meta=u}if(t.name!=null&&(a.name=t.name),n||e.has("value")){t.status==="sentinel"&&(a.sentinel=!0);try{a.value=t.cache}catch{}}if((n||e.has("v"))&&t.v!=null){let u={id:t.v.id,version:t.v.version};"cid"in t.v&&(u.cid=t.v.cid,u.prev=t.v.prev),a.v=u}return(n||e.has("guard"))&&c!=null&&(a.guard=ct(c)),(n||e.has("lastMutation"))&&t.lastMutation!=null&&(a.lastMutation=t.lastMutation),a}he();Ie();gt();Ft();var Se=class{constructor(e){this.capacity=e;if(!Number.isInteger(e)||e<=0)throw new Error(`RingBuffer capacity must be a positive integer (got ${e})`);this.buf=new Array(e)}buf;head=0;_size=0;get size(){return this._size}get maxSize(){return this.capacity}push(e){let n=(this.head+this._size)%this.capacity;this.buf[n]=e,this._size<this.capacity?this._size++:this.head=(this.head+1)%this.capacity}shift(){if(this._size===0)return;let e=this.buf[this.head];return this.buf[this.head]=void 0,this.head=(this.head+1)%this.capacity,this._size--,e}at(e){if(this._size===0)return;let n=e<0?this._size+e:e;if(!(n<0||n>=this._size))return this.buf[(this.head+n)%this.capacity]}toArray(){let e=new Array(this._size);for(let n=0;n<this._size;n++)e[n]=this.buf[(this.head+n)%this.capacity];return e}clear(){for(let e=0;e<this._size;e++)this.buf[(this.head+e)%this.capacity]=void 0;this.head=0,this._size=0}};tt();function mt(t){return t>=768&&t<=879||t>=1155&&t<=1161||t>=1425&&t<=1469||t>=1552&&t<=1562||t>=1611&&t<=1631||t>=1648&&t===1648||t>=1750&&t<=1756||t>=1759&&t<=1764||t>=1767&&t<=1768||t>=1770&&t<=1773||t>=1840&&t<=1866||t>=1958&&t<=1968||t>=2304&&t<=2307||t>=2362&&t<=2383||t>=2385&&t<=2391||t>=2402&&t<=2403||t>=2433&&t<=2435||t>=2492&&t<=2509||t>=2561&&t<=2563||t>=2620&&t<=2641||t>=2672&&t<=2673||t>=2677&&t===2677||t>=3633&&t===3633||t>=3636&&t<=3642||t>=3655&&t<=3662||t>=3761&&t===3761||t>=3764&&t<=3772||t>=3784&&t<=3790||t>=7616&&t<=7679||t>=8400&&t<=8447||t>=65024&&t<=65039||t>=65056&&t<=65071||t===8205?0:t>=4352&&t<=4447||t>=8986&&t<=8987||t>=9001&&t<=9002||t>=9193&&t<=9203||t>=9208&&t<=9210||t>=9725&&t<=9726||t>=9748&&t<=9749||t>=9800&&t<=9811||t===9855||t===9875||t===9889||t>=9898&&t<=9899||t>=9917&&t<=9918||t>=9924&&t<=9925||t===9934||t===9940||t===9962||t>=9970&&t<=9971||t===9973||t===9978||t===9981||t===9986||t===9989||t>=9992&&t<=9997||t===9999||t>=10067&&t<=10069||t===10071||t>=10133&&t<=10135||t===10160||t===10175||t>=10548&&t<=10549||t>=11013&&t<=11015||t>=11035&&t<=11036||t===11088||t===11093||t>=11904&&t<=12350||t>=12352&&t<=12447||t>=12448&&t<=12543||t>=12549&&t<=12591||t>=12593&&t<=12686||t>=12688&&t<=12771||t>=12784&&t<=12830||t>=12832&&t<=12871||t>=12880&&t<=19903||t>=19968&&t<=40959||t>=43360&&t<=43388||t>=44032&&t<=55203||t>=63744&&t<=64255||t>=65040&&t<=65049||t>=65072&&t<=65131||t>=65281&&t<=65376||t>=65504&&t<=65510||t>=126980&&t===126980||t===127183||t>=127344&&t<=127345||t===127358||t===127359||t===127374||t>=127377&&t<=127386||t>=127456&&t<=127487||t>=127488&&t<=127490||t===127514||t===127535||t>=127538&&t<=127546||t>=127568&&t<=127569||t>=127744&&t<=129535||t>=129536&&t<=129791||t>=129792&&t<=130047||t>=131072&&t<=196605||t>=196608&&t<=262141?2:1}function je(t){let e=0;for(let n of t)e+=mt(n.codePointAt(0));return e}function jt(t,e){if(e<=0)return"";let n=0,r="";for(let s of t){let o=mt(s.codePointAt(0));if(n+o>e){if(e<=1)return"\u2026";for(;n+1>e&&r.length>0;){let i=[...r].pop();r=r.slice(0,-i.length),n-=mt(i.codePointAt(0))}return`${r}\u2026`}r+=s,n+=o}return r}var Vn={horizontal:"\u2500",vertical:"\u2502",cornerTL:"\u250C",cornerTR:"\u2510",cornerBL:"\u2514",cornerBR:"\u2518",tDown:"\u252C",tUp:"\u2534",tRight:"\u251C",tLeft:"\u2524",cross:"\u253C",arrowRight:"\u25B6",arrowDown:"\u25BC",arrowLeft:"\u25C0",arrowUp:"\u25B2",boxTL:"\u250C",boxTR:"\u2510",boxBL:"\u2514",boxBR:"\u2518",boxH:"\u2500",boxV:"\u2502"},zn={horizontal:"-",vertical:"|",cornerTL:"+",cornerTR:"+",cornerBL:"+",cornerBR:"+",tDown:"+",tUp:"+",tRight:"+",tLeft:"+",cross:"+",arrowRight:">",arrowDown:"v",arrowLeft:"<",arrowUp:"^",boxTL:"+",boxTR:"+",boxBL:"+",boxBR:"+",boxH:"-",boxV:"|"};function zt(t,e){let n=e.charset==="ascii"?zn:Vn,r=t.width,s=t.height,o=Array.from({length:s},()=>Array.from({length:r},()=>" ")),i=Array.from({length:s},()=>Array.from({length:r},()=>"empty"));for(let a of t.edges)Un(o,i,n,a);for(let a of t.boxes)Wn(o,i,n,a,e.labelOf(a.id));return o.map(a=>Yn(a.join(""))).join(`
2
+ `)}function Wn(t,e,n,r,s){let{x:o,y:i,w:a,h:c}=r;if(a<2||c<2){c>0&&Bt(t,e,o,i,a,s);return}te(t,e,o,i,n.boxTL);for(let f=o+1;f<o+a-1;f+=1)te(t,e,f,i,n.boxH);te(t,e,o+a-1,i,n.boxTR);for(let f=i+1;f<i+c-1;f+=1){te(t,e,o,f,n.boxV);for(let p=o+1;p<o+a-1;p+=1)Wt(t,e,p,f," ","empty");te(t,e,o+a-1,f,n.boxV)}te(t,e,o,i+c-1,n.boxBL);for(let f=o+1;f<o+a-1;f+=1)te(t,e,f,i+c-1,n.boxH);te(t,e,o+a-1,i+c-1,n.boxBR);let u=i+Math.floor(c/2);Bt(t,e,o+1,u,a-2,s)}function te(t,e,n,r,s){Wt(t,e,n,r,s,s===" "?"empty":s==="\u2500"||s==="-"?"boxH":s==="\u2502"||s==="|"?"boxV":"boxCorner")}function Wt(t,e,n,r,s,o){if(r<0||r>=t.length)return;let i=t[r];n<0||n>=i.length||(i[n]=s,e[r][n]=o)}function Bt(t,e,n,r,s,o){if(r<0||r>=t.length)return;let i=n,a=s;for(let c of o){let u=je(c);if(u!==0){if(a<u)break;i>=0&&i<t[r].length&&(t[r][i]=c,e[r][i]="label",u===2&&i+1<t[r].length&&(t[r][i+1]="",e[r][i+1]="label")),i+=u,a-=u}}for(;a>0;)i>=0&&i<t[r].length&&(t[r][i]=" ",e[r][i]="empty"),i+=1,a-=1}function Un(t,e,n,r){let s=r.points;if(s.length<2)return;for(let c=0;c+1<s.length;c+=1)Kn(t,e,n,s[c],s[c+1]);for(let c=1;c+1<s.length;c+=1){let u=s[c-1],f=s[c],p=s[c+1],g=qn(u,f,p,n);g&&Vt(t,e,f.x,f.y,g,"edgeCorner")}let o=s[s.length-1],i=s[s.length-2],a=Jn(i,o,n);a&&Vt(t,e,o.x,o.y,a,"arrow")}function Kn(t,e,n,r,s){if(!(r.x===s.x&&r.y===s.y)){if(r.y===s.y){let o=r.y,i=Math.min(r.x,s.x),a=Math.max(r.x,s.x);for(let c=i;c<=a;c+=1)Ht(t,e,c,o,n,"h")}else if(r.x===s.x){let o=r.x,i=Math.min(r.y,s.y),a=Math.max(r.y,s.y);for(let c=i;c<=a;c+=1)Ht(t,e,o,c,n,"v")}}}function Ht(t,e,n,r,s,o){if(r<0||r>=t.length)return;let i=t[r];if(n<0||n>=i.length)return;let a=e[r][n];if(!(a==="boxH"||a==="boxV"||a==="boxCorner"||a==="label")){if(a==="empty"){i[n]=o==="h"?s.horizontal:s.vertical,e[r][n]=o==="h"?"edgeH":"edgeV";return}if(a==="edgeH"&&o==="v"){i[n]=s.cross,e[r][n]="edgeCorner";return}if(a==="edgeV"&&o==="h"){i[n]=s.cross,e[r][n]="edgeCorner";return}}}function Vt(t,e,n,r,s,o){if(r<0||r>=t.length)return;let i=t[r];if(n<0||n>=i.length)return;let a=e[r][n];a==="boxH"||a==="boxV"||a==="boxCorner"||a==="label"||(i[n]=s,e[r][n]=o)}function qn(t,e,n,r){let s=t.y===e.y,o=e.y===n.y;if(s===o)return;if(s){let c=t.x<e.x,u=n.y>e.y;return c&&u?r.cornerTR:c&&!u?r.cornerBR:!c&&u?r.cornerTL:r.cornerBL}let i=t.y<e.y,a=n.x>e.x;return i&&a?r.cornerBL:i&&!a?r.cornerBR:!i&&a?r.cornerTL:r.cornerTR}function Jn(t,e,n){if(e.x>t.x)return n.arrowRight;if(e.x<t.x)return n.arrowLeft;if(e.y>t.y)return n.arrowDown;if(e.y<t.y)return n.arrowUp}function Yn(t){let e=t.length;for(;e>0&&t.charCodeAt(e-1)===32;)e-=1;return t.slice(0,e)}function qt(t){let e=Xn(t);Zn(e),Qn(e),er(e),tr(e,t);let n=sr(e,t),{width:r,height:s}=ir(e),o=[];for(let i of e.layers)for(let a of i)a.isVirtual||o.push({id:a.id,layer:a.layer,order:a.order,x:a.x,y:a.y,w:a.w,h:a.h});return{boxes:o,edges:n,width:r,height:s}}function Xn(t){let e=new Map;for(let s of t.nodes)e.set(s,{id:s,isVirtual:!1,layer:-1,order:0,x:0,y:0,w:t.widthCells(s),h:t.heightCells(s),in:[],out:[]});let n=[],r=0;for(let s of t.edges){if(s.from===s.to)continue;let o=e.get(s.from),i=e.get(s.to);if(!o||!i)continue;let a={chainId:r++,chainFrom:s.from,chainTo:s.to,fromId:s.from,toId:s.to,hopIndex:0,chainLen:1};o.out.push(a),i.in.push(a),n.push(a)}return{nodes:e,layers:[],hops:n}}function Zn(t){let e=new Map;for(let o of t.nodes.values())e.set(o.id,o.in.length);let n=[];for(let o of t.nodes.values())(e.get(o.id)??0)===0&&(o.layer=0,n.push(o));let r=new Set,s=0;for(;s<n.length;){let o=n[s++];if(!r.has(o.id)){r.add(o.id);for(let i of o.out){let a=t.nodes.get(i.toId);a.layer=Math.max(a.layer,o.layer+1);let c=(e.get(a.id)??0)-1;e.set(a.id,c),c<=0&&n.push(a)}}}for(let o of t.nodes.values())o.layer<0&&(o.layer=0)}function Qn(t){let e=Math.max(0,...Array.from(t.nodes.values(),o=>o.layer)),n=Array.from({length:e+1},()=>[]);for(let o of t.nodes.values())n[o.layer].push(o);let r=[],s=0;for(let o of t.hops){let i=t.nodes.get(o.fromId),a=t.nodes.get(o.toId),c=a.layer-i.layer;if(c<=0){i.out=i.out.filter(p=>p!==o),a.in=a.in.filter(p=>p!==o);continue}if(c===1){o.hopIndex=0,o.chainLen=1,r.push(o);continue}i.out=i.out.filter(p=>p!==o),a.in=a.in.filter(p=>p!==o);let u=i;for(let p=1;p<c;p+=1){let g=`__virt_${s++}__`,l={id:g,isVirtual:!0,layer:i.layer+p,order:0,x:0,y:0,w:0,h:1,in:[],out:[]};t.nodes.set(g,l),n[l.layer].push(l);let d={chainId:o.chainId,chainFrom:o.chainFrom,chainTo:o.chainTo,fromId:u.id,toId:g,hopIndex:p-1,chainLen:c};u.out.push(d),l.in.push(d),r.push(d),u=l}let f={chainId:o.chainId,chainFrom:o.chainFrom,chainTo:o.chainTo,fromId:u.id,toId:a.id,hopIndex:c-1,chainLen:c};u.out.push(f),a.in.push(f),r.push(f)}for(let o of n)for(let i=0;i<o.length;i+=1)o[i].order=i;t.layers=n,t.hops=r}function er(t){for(let n=0;n<4;n+=1){for(let r=1;r<t.layers.length;r+=1)Ut(t,t.layers[r],"in"),Be(t.layers[r]);for(let r=t.layers.length-2;r>=0;r-=1)Ut(t,t.layers[r],"out"),Be(t.layers[r])}for(let n=0;n<2;n+=1){let r=!1;for(let s=1;s<t.layers.length;s+=1){let o=t.layers[s];for(let i=0;i+1<o.length;i+=1){let a=Kt(t,o[i],o[i+1],"in");[o[i],o[i+1]]=[o[i+1],o[i]],Be(o),Kt(t,o[i],o[i+1],"in")<a?r=!0:([o[i],o[i+1]]=[o[i+1],o[i]],Be(o))}}if(!r)break}}function Ut(t,e,n){let r=new Map;for(let s of e){let o=n==="in"?s.in:s.out;if(o.length===0){r.set(s.id,s.order);continue}let i=0,a=0;for(let c of o){let u=t.nodes.get(n==="in"?c.fromId:c.toId);u&&(i+=u.order,a+=1)}r.set(s.id,a===0?s.order:i/a)}e.sort((s,o)=>{let i=r.get(s.id),a=r.get(o.id);return i!==a?i-a:s.order-o.order})}function Be(t){for(let e=0;e<t.length;e+=1)t[e].order=e}function Kt(t,e,n,r){let s=r==="in"?e.in:e.out,o=r==="in"?n.in:n.out,i=0;for(let a of s)for(let c of o){let u=t.nodes.get(r==="in"?a.fromId:a.toId)?.order??0,f=t.nodes.get(r==="in"?c.fromId:c.toId)?.order??0;(e.order<n.order&&u>f||e.order>n.order&&u<f)&&(i+=1)}return i}function tr(t,e){e.direction==="LR"?nr(t,e):rr(t,e)}function nr(t,e){let n=[],r=0;for(let s=0;s<t.layers.length;s+=1){n.push(r);let o=0;for(let i of t.layers[s])o=Math.max(o,i.w);r+=o+e.layerGap}for(let s=0;s<t.layers.length;s+=1)for(let o of t.layers[s])o.x=n[s];for(let s of t.layers){let o=0;for(let i of s)i.y=o,o+=i.h+e.nodeGap}Jt(t,e,"y")}function rr(t,e){let n=[],r=0;for(let s=0;s<t.layers.length;s+=1){n.push(r);let o=0;for(let i of t.layers[s])o=Math.max(o,i.h);r+=o+e.layerGap}for(let s=0;s<t.layers.length;s+=1)for(let o of t.layers[s])o.y=n[s];for(let s of t.layers){let o=0;for(let i of s)i.x=o,o+=i.w+e.nodeGap}Jt(t,e,"x")}function Jt(t,e,n){let r=o=>n==="y"?o.h:o.w,s=e.nodeGap;for(let o=0;o<2;o+=1){let i=o===0?t.layers.slice(1):t.layers.slice(0,-1).reverse();for(let a of i){let c=new Map;for(let f of a){let p=o===0?f.in:f.out;if(p.length===0)continue;let g=[];for(let d of p){let m=t.nodes.get(o===0?d.fromId:d.toId);if(!m)continue;let b=n==="y"?m.y:m.x;g.push(b+Math.floor(r(m)/2))}if(g.length===0)continue;g.sort((d,m)=>d-m);let l=g[Math.floor(g.length/2)];c.set(f.id,l-Math.floor(r(f)/2))}let u=0;for(let f of a){let p=c.get(f.id),g=n==="y"?f.y:f.x,d=Math.max(p??g,u);n==="y"?f.y=d:f.x=d,u=d+r(f)+s}}}}function sr(t,e){let n=new Map;for(let u of t.hops){let f=n.get(u.chainId);f?f.push(u):n.set(u.chainId,[u])}for(let u of n.values())u.sort((f,p)=>f.hopIndex-p.hopIndex);let r=e.direction==="LR",s=u=>r?u.x:u.y,o=u=>r?u.w:u.h,i=u=>r?u.y+Math.floor(u.h/2):u.x+Math.floor(u.w/2),a=new Map;for(let u=0;u+1<t.layers.length;u+=1){let f=t.layers[u],p=t.layers[u+1],g=0;for(let x of f)g=Math.max(g,s(x)+o(x));let l=Number.POSITIVE_INFINITY;for(let x of p)l=Math.min(l,s(x));let d=Number.isFinite(l)?l-1:g,m=Math.max(1,d-g+1),b=[];for(let x of f)for(let k of x.out)b.push(k);b.sort((x,k)=>{let D=i(t.nodes.get(x.fromId)),N=i(t.nodes.get(k.fromId));if(D!==N)return D-N;let E=i(t.nodes.get(x.toId)),S=i(t.nodes.get(k.toId));return E-S});let v=[],h=new Map;for(let x of b){let k=i(t.nodes.get(x.fromId)),D=i(t.nodes.get(x.toId)),N=Math.min(k,D),E=Math.max(k,D),S=-1;for(let A=0;A<v.length;A+=1){let F=v[A],J=!0;for(let ne of F)if(ne.lo<=E&&N<=ne.hi){J=!1;break}if(J){F.push({lo:N,hi:E}),S=A;break}}S<0&&(v.push([{lo:N,hi:E}]),S=v.length-1),h.set(x,S)}let y=v.length,w=m>=Math.max(3,y+2),O=w?g+1:g,T=w?d-1:d,_=Math.max(1,T-O+1);for(let x of b){let k=h.get(x),D;if(y<=1)D=O+Math.floor(_/2);else{let N=(_-1)/(y-1);D=O+Math.floor(k*N)}a.set(x,Math.max(g,Math.min(d,D)))}}let c=[];for(let[,u]of n){let f=[];for(let g=0;g<u.length;g+=1){let l=u[g],d=t.nodes.get(l.fromId),m=t.nodes.get(l.toId),b=a.get(l),v=d.isVirtual?s(d):s(d)+o(d),h=m.isVirtual?s(m):s(m)-1,y=i(d),w=i(m);g===0&&He(f,r,v,y),y!==w&&(He(f,r,b,y),He(f,r,b,w)),He(f,r,h,w)}let p=u[0];c.push({from:p.chainFrom,to:p.chainTo,points:or(f)})}return c}function He(t,e,n,r){t.push(e?{x:n,y:r}:{x:r,y:n})}function or(t){let e=[];for(let n of t){let r=e[e.length-1];(!r||r.x!==n.x||r.y!==n.y)&&e.push(n)}return e}function ir(t){let e=0,n=0;for(let r of t.layers)for(let s of r)e=Math.max(e,s.x+s.w),n=Math.max(n,s.y+s.h);return{width:e,height:n}}var ar=24,cr=4,ur=1,dr=3;function Yt(t,e){let n=lr(e.direction),r=Math.max(3,e.maxLabelWidth??ar),s=e.asciiCharset??"unicode",o=Object.keys(t.nodes).sort(),i=new Set(o),a=t.edges.filter(l=>i.has(l.from)&&i.has(l.to)),c=new Map,u=new Map;for(let l of o){let d=jt(l,r);c.set(l,d),u.set(l,je(d)+4)}let f=qt({nodes:o,edges:a,widthCells:l=>u.get(l)??3,heightCells:()=>dr,layerGap:cr,nodeGap:ur,direction:n}),p=zt(f,{charset:s,labelOf:l=>c.get(l)??l}),g=e.logger;return g&&g(p),p}function lr(t){if(t===void 0||t==="LR")return"LR";if(t==="TD")return"TD";throw new Error(`ascii describe supports direction "LR" or "TD" only; got ${String(t)}`)}function Xt(t,e,n,r={}){let s=e in t.nodes,o=n in t.nodes;if(!s)return Ve(e,n,"no-such-from");if(!o)return Ve(e,n,"no-such-to");let i=r.maxDepth;if(i!=null&&(!Number.isInteger(i)||i<0))throw new Error("explainPath: maxDepth must be an integer >= 0");if(e===n){if(r.findCycle===!0){let u=fr(t,e,r);if(u!=null)return u}let c=ze(e,t.nodes[e],0,r);return We(e,n,[c])}if(i===0)return Ve(e,n,"no-path");let a=Zt(t,e,n,i);return a.found?We(e,n,Qt(t,a.pathOrder,r)):Ve(e,n,a.truncated?"max-depth-exceeded":"no-path")}function Zt(t,e,n,r){let s=new Map,o=[{path:n,depth:0}],i=new Set([n]),a=0,c=!1;for(;a<o.length;){let p=o[a++];if(p.path===e)break;if(r!=null&&p.depth>=r){let m=t.nodes[p.path];m?.deps&&m.deps.length>0&&(c=!0);continue}let g=t.nodes[p.path];if(g==null)continue;let l=g.deps??[],d=new Map;for(let m=0;m<l.length;m++){let b=l[m];if(!b)continue;let v=d.get(b);v==null&&(v=[],d.set(b,v)),v.push(m)}for(let[m,b]of d)i.has(m)||(i.add(m),s.set(m,{from:p.path,depIndices:b}),o.push({path:m,depth:p.depth+1}))}if(!s.has(e))return{found:!1,pathOrder:[],truncated:c};let u=[{path:e}],f=e;for(;f!==n;){let p=s.get(f);if(p==null)return{found:!1,pathOrder:[],truncated:!1};u[u.length-1].depIndices=p.depIndices,u.push({path:p.from}),f=p.from}return{found:!0,pathOrder:u,truncated:!1}}function fr(t,e,n){let r=t.nodes[e];if(r==null)return null;let s=r.deps??[],o=[];for(let a=0;a<s.length;a++)s[a]===e&&o.push(a);if(o.length>0){let a=ze(e,r,0,n);a.dep_index=o[0];let c=ze(e,r,1,n);return We(e,e,[a,c])}let i=null;for(let a=0;a<s.length;a++){let c=s[a];if(!c||c===e)continue;let u=Zt(t,c,e,n.maxDepth);u.found&&(i==null||u.pathOrder.length<i.pathOrder.length)&&(i=u,i={found:!0,pathOrder:[{path:e,depIndices:[a]},...u.pathOrder],truncated:!1})}return i==null?null:We(e,e,Qt(t,i.pathOrder,n))}function Qt(t,e,n){return e.map((r,s)=>{let o=t.nodes[r.path],i=ze(r.path,o,s,n);return r.depIndices!=null&&r.depIndices.length>0&&(i.dep_index=r.depIndices[0],r.depIndices.length>1&&(i.dep_indices=[...r.depIndices])),i})}function ze(t,e,n,r){let s={path:t,type:e.type,hop:n};e.status!==void 0&&(s.status=e.status),"value"in e&&(s.value=e.value),e.v!=null&&(s.v=e.v);let o=r.annotations?.get(t)??e.annotation;o!=null&&(s.annotation=o);let i=r.lastMutations?.get(t)??e.lastMutation;return i!=null&&(s.lastMutation=i),s}function We(t,e,n){return en(t,e,!0,"ok",n)}function Ve(t,e,n){return en(t,e,!1,n,[])}function en(t,e,n,r,s){let o=pr(t,e,n,r,s);return{from:t,to:e,found:n,reason:r,steps:s,text:o,toJSON(){return{from:t,to:e,found:n,reason:r,steps:s}}}}function pr(t,e,n,r,s){if(!n)switch(r){case"no-such-from":return`explainPath: no node named "${t}"`;case"no-such-to":return`explainPath: no node named "${e}"`;case"max-depth-exceeded":return`explainPath: no path from "${t}" to "${e}" within maxDepth`;default:return`explainPath: no path from "${t}" to "${e}"`}let o=[`Causal path: ${t} \u2192 ${e} (${s.length} step(s))`];for(let i of s){let c=` ${i.hop===0?"\xB7":"\u2193"} ${i.path} (${i.type}${i.status?`/${i.status}`:""})`;if(o.push(c),"value"in i&&o.push(` value: ${hr(i.value)}`),i.annotation!=null&&o.push(` annotation: ${i.annotation}`),i.lastMutation!=null){let u=i.lastMutation.actor;o.push(` actor: ${u.type}${u.id?`:${u.id}`:""}`)}}return o.join(`
3
+ `)}function hr(t){if(t===void 0)return"<sentinel>";if(t===null)return"null";if(typeof t=="string")return JSON.stringify(t);if(typeof t=="number"||typeof t=="boolean"||typeof t=="bigint")return String(t);try{let e=JSON.stringify(t);return e.length>80?`${e.slice(0,77)}...`:e}catch{return String(t)}}he();var I={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},gr=Symbol.for("sizeof");function tn(t){let e=new WeakSet,n=new WeakSet,r=[t],s=0;for(;r.length>0;){let o=r.pop();s+=mr(o,e,n,r)}return s}function mr(t,e,n,r){if(t==null)return 0;switch(typeof t){case"number":return I.number;case"boolean":return I.boolean;case"string":return I.string+t.length*2;case"bigint":return I.bigint+br(t);case"symbol":return I.symbol;case"function":return e.has(t)?0:(e.add(t),I.function);case"undefined":return 0}let o=t;if(e.has(o))return 0;e.add(o);let i=o[gr];if(typeof i=="function")try{let u=i.call(o);if(typeof u=="number"&&Number.isFinite(u))return u}catch{}if(o instanceof Date)return I.date;if(o instanceof RegExp)return I.regexp+o.source.length*2;if(o instanceof Error){let u=o.message?o.message.length*2:0,f=o.stack?o.stack.length*2:0;return I.error+u+f}if(typeof URL<"u"&&o instanceof URL)return I.url+o.href.length*2;if(typeof Promise<"u"&&o instanceof Promise)return I.promise;if(o instanceof WeakMap)return I.weakmap;if(o instanceof WeakSet)return I.weakset;if(o instanceof Map){let u=I.map;for(let[f,p]of o)u+=I.mapEntry,r.push(f),r.push(p);return u}if(o instanceof Set){let u=I.set;for(let f of o)u+=I.setEntry,r.push(f);return u}if(Array.isArray(o)){let u=I.array+o.length*8;for(let f of o)r.push(f);return u}if(o instanceof ArrayBuffer)return n.has(o)?0:(n.add(o),o.byteLength);if(ArrayBuffer.isView(o)){let u=o;return n.has(u.buffer)?48:(n.add(u.buffer),u.buffer.byteLength+48)}let a=I.object,c=Object.keys(o);for(let u of c){a+=I.string+u.length*2;try{r.push(o[u])}catch{}}return a}function br(t){let e=t<0n?-t:t;if(e===0n)return 0;let n=e.toString(2).length;return Math.ceil(n/32)*8}function nn(t,e){let n=e?.topN??10,r=t.describe({detail:"standard"}),s=[],o=t._collectObserveTargets;typeof o=="function"&&o.call(t,"",s);let i=new Map;for(let[g,l]of s)i.set(g,l);let a=[];for(let[g,l]of Object.entries(r.nodes)){let d=i.get(g),m=d instanceof L?d:null,b=m?tn(m.cache):0,v=m?m._sinkCount:0,h=l.deps?.length??0,y=l.type==="effect"&&v===0,w=v===0?l.type==="effect"?"orphan-effect":l.type==="derived"?"idle-derived":l.type==="producer"?"idle-producer":null:null;a.push({path:g,type:l.type,status:l.status??"unknown",valueSizeBytes:b,subscriberCount:v,depCount:h,isOrphanEffect:y,orphanKind:w})}let c=a.reduce((g,l)=>g+l.valueSizeBytes,0),u=(g,l)=>[...a].sort(l??((d,m)=>m[g]-d[g])).slice(0,n),f=a.filter(g=>g.orphanKind!=null),p=a.filter(g=>g.isOrphanEffect);return{nodeCount:a.length,edgeCount:r.edges.length,subgraphCount:r.subgraphs.length,nodes:a,totalValueSizeBytes:c,hotspots:{byValueSize:u("valueSizeBytes"),bySubscriberCount:u("subscriberCount"),byDepCount:u("depCount")},orphans:f,orphanEffects:p}}var G="::",z="__meta__",me=1;function rn(t,e){let n=Math.max(16,t.size*4),r=0;for(;t.size>0;){if(r++>=n){console.error(`[Graph "${e}".destroy] disposer drain exceeded cap (${n}); ${t.size} disposer(s) discarded`),t.clear();return}let s=t.values().next();if(s.done)return;let o=s.value;t.delete(o);try{o()}catch(i){console.error(`[Graph "${e}".destroy] disposer threw:`,i)}}}function yr(t){let e=[];for(let n of Object.keys(t).sort()){let r=t[n].v;r!=null&&e.push(`${n} ${r.id} ${r.version}`)}return e.join(`
4
+ `)}function sn(t){if(t.version!==me)throw new Error(`unsupported snapshot version ${String(t.version)} (expected ${me})`);for(let e of["name","nodes","edges","subgraphs"])if(!(e in t))throw new Error(`snapshot missing required key "${e}"`);if(typeof t.name!="string")throw new TypeError("snapshot 'name' must be a string");if(typeof t.nodes!="object"||t.nodes===null||Array.isArray(t.nodes))throw new TypeError("snapshot 'nodes' must be an object");if(!Array.isArray(t.edges))throw new TypeError("snapshot 'edges' must be an array");if(!Array.isArray(t.subgraphs))throw new TypeError("snapshot 'subgraphs' must be an array")}function vr(t,e){let n=new WeakMap,r=(s,o)=>{if(Object.is(s,o))return!0;if(s==null||o==null||typeof s!="object"||typeof o!="object")return!1;let i=n.get(s);if(i==null&&(i=new WeakSet,n.set(s,i)),i.has(o))return!0;i.add(o);let a=s.constructor,c=o.constructor;if(a!==c)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 g=o;if(s.length!==g.length)return!1;for(let l=0;l<s.length;l++)if(!r(s[l],g[l]))return!1;return!0}if(s instanceof Map){let g=o;if(s.size!==g.size)return!1;for(let[l,d]of s)if(!g.has(l)||!r(d,g.get(l)))return!1;return!0}if(s instanceof Set){let g=o;if(s.size!==g.size)return!1;for(let l of s){let d=!1;for(let m of g)if(r(l,m)){d=!0;break}if(!d)return!1}return!0}if(ArrayBuffer.isView(s)){let g=s,l=o;if(g.length!==l.length)return!1;for(let d=0;d<g.length;d++)if(g[d]!==l[d])return!1;return!0}let u=Object.keys(s),f=Object.keys(o);if(u.length!==f.length)return!1;let p=new Set(f);for(let g of u)if(!p.has(g)||!r(s[g],o[g]))return!1;return!0};return r(t,e)}function yt(t){if(t===null||typeof t!="object")return t;if(Array.isArray(t))return t.map(yt);let e=t,n=Object.keys(e).sort(),r={};for(let s of n)r[s]=yt(e[s]);return r}function wr(t){return t.replaceAll("\\","\\\\").replaceAll('"','\\"')}function _r(t){return t.replaceAll("\\","\\\\").replaceAll('"','\\"')}function xr(t){return t==="TD"?"down":t==="BT"?"up":t==="RL"?"left":"right"}function cn(t){let e=new Set,n=[];function r(s,o){let i=`${s}\0${o}`;e.has(i)||(e.add(i),n.push([s,o]))}for(let[s,o]of Object.entries(t.nodes)){let i=o.deps;if(i)for(let a of i)r(a,s)}for(let s of t.edges)r(s.from,s.to);return n}function un(t){if(t===void 0)return"LR";if(t==="TD"||t==="LR"||t==="BT"||t==="RL")return t;throw new Error(`invalid diagram direction ${String(t)}; expected one of: TD, LR, BT, RL`)}function Or(t,e){let n=e.includeEdges??!0,r=e.includeSubgraphs??!0,{expand:s,...o}=t,i={...o,edges:n?t.edges:[],subgraphs:r?t.subgraphs:[]},a=JSON.stringify(yt(i),null,e.indent??2);return e.logger?.(a),a}function Sr(t,e){let n=e.includeEdges??!0,r=e.includeSubgraphs??!0,s=[];s.push(`Graph ${t.name}`),s.push("Nodes:");for(let i of Object.keys(t.nodes).sort()){let a=t.nodes[i];s.push(`- ${i} (${a.type}/${a.status}): ${Ke(a.value)}`)}if(n){s.push("Edges:");for(let i of t.edges)s.push(`- ${i.from} -> ${i.to}`)}if(r){s.push("Subgraphs:");for(let i of t.subgraphs)s.push(`- ${i}`)}let o=s.join(`
5
+ `);return e.logger?.(o),o}function dn(t,e){let n=un(e.direction),r=Object.keys(t.nodes).sort(),s=new Map;for(let i=0;i<r.length;i+=1)s.set(r[i],`n${i}`);let o=[`flowchart ${n}`];for(let i of r){let a=s.get(i);o.push(` ${a}["${wr(i)}"]`)}for(let[i,a]of cn(t)){let c=s.get(i),u=s.get(a);!c||!u||o.push(` ${c} --> ${u}`)}return o.join(`
6
+ `)}function Tr(t,e){let n=dn(t,e);return Nr(n)}function Nr(t,e){let n=e?.theme??"default",r=e?.autoSync??!0,o=JSON.stringify({code:t,mermaid:{theme:n},autoSync:r}),i=new TextEncoder().encode(o),a="";for(let u=0;u<i.length;u++)a+=String.fromCharCode(i[u]);return`https://mermaid.live/edit#base64:${globalThis.btoa(a).replace(/\+/g,"-").replace(/\//g,"_").replace(/=+$/,"")}`}function kr(t,e){let n=un(e.direction),r=Object.keys(t.nodes).sort(),s=new Map;for(let i=0;i<r.length;i+=1)s.set(r[i],`n${i}`);let o=[`direction: ${xr(n)}`];for(let i of r){let a=s.get(i);o.push(`${a}: "${_r(i)}"`)}for(let[i,a]of cn(t)){let c=s.get(i),u=s.get(a);!c||!u||o.push(`${c} -> ${u}`)}return o.join(`
7
+ `)}function Er(t){return t.replace(/[.*+?^${}()|[\]\\]/g,"\\$&")}function Ue(t){let e="^";for(let n=0;n<t.length;n+=1){let r=t[n];if(r==="*"){e+=".*";continue}if(r==="?"){e+=".";continue}if(r==="["){let s=t.indexOf("]",n+1);if(s<=n+1){e+="\\[";continue}let o=t.slice(n+1,s);o.startsWith("!")&&(o=`^${o.slice(1)}`),o=o.replace(/\\/g,"\\\\"),e+=`[${o}]`,n=s;continue}e+=Er(r)}return e+="$",new RegExp(e)}var Rr={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"},Ar={data:"",dirty:"",resolved:"",invalidate:"",pause:"",resume:"",complete:"",error:"",teardown:"",derived:"",path:"",reset:""};function Ke(t){if(typeof t=="string")return JSON.stringify(t);if(typeof t=="number"||typeof t=="boolean"||t==null)return String(t);try{return JSON.stringify(t)}catch{return"[unserializable]"}}function Dr(t){return t==="none"?Ar:t==="ansi"||t==null?Rr:{data:t.data??"",dirty:t.dirty??"",resolved:t.resolved??"",invalidate:t.invalidate??"",pause:t.pause??"",resume:t.resume??"",complete:t.complete??"",error:t.error??"",teardown:t.teardown??"",derived:t.derived??"",path:t.path??"",reset:t.reset??""}}function on(t){if(t==null)return{};let e=t.detail;return e==="full"?{...t,structured:t.structured??!0,timeline:t.timeline??!0,causal:t.causal??!0,derived:t.derived??!0}:e==="minimal"?{...t,structured:t.structured??!0}:t.format==="stage-log"?{...t,structured:t.structured??!0,timeline:t.timeline??!0}:t}function Cr(t,e,n){for(let r=0;r<t.length;r++){let s=t.charCodeAt(r);if(s<32||s===127)throw new Error(`Graph "${e}": ${n} "${t}" must not contain control character (U+${s.toString(16).padStart(4,"0").toUpperCase()} at index ${r})`)}}function bt(t,e,n){if(t==="")throw new Error(`Graph "${e}": ${n} name must be non-empty`);if(t.includes(G))throw new Error(`Graph "${e}": ${n} "${t}" must not contain '${G}' (path separator)`);if(t===z)throw new Error(`Graph "${e}": ${n} name "${z}" is reserved for meta companion paths`);Cr(t,e,n)}function Mr(t,e){if(t==="")throw new Error(`Graph "${e}": resolve path must be non-empty`);let n=t.split(G);for(let r of n)if(r==="")throw new Error(`Graph "${e}": resolve path has empty segment`);return n}function Gr(t,e){let n=!1;for(let s of t)if(!e.isMetaPassthrough(s[0])){n=!0;break}return n?t.filter(s=>e.isMetaPassthrough(s[0])):t}function ln(t){for(let e of t._mounts.values())ln(e);for(let e of t._nodes.values())try{e.down([[B]],{internal:!0})}catch{}}var be=class t{name;opts;config;_nodes=new Map;_nodeToName=new WeakMap;_mounts=new Map;_parent=void 0;_storageDisposers=new Set;_disposers=new Set;_topology;_topologyEmitters=new Set;constructor(e,n){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===z)throw new Error(`Graph name "${z}" is reserved for meta companion paths`);this.name=e,this.opts=Object.freeze({...n??{}}),this.config=n?.config??pe,this._traceRing=new Se(n?.traceCapacity??1e3),n?.versioning!=null&&this.setVersioning(n.versioning)}ancestors(e=!0){let n=[],r=e?this:this._parent;for(;r!=null;)n.push(r),r=r._parent;return n}get topology(){return this._topology==null&&(this._topology=Oe(e=>{let n=r=>{e.emit(r)};return this._topologyEmitters.add(n),()=>{this._topologyEmitters.delete(n)}},{name:`${this.name}_topology`})),this._topology}_emitTopology(e){if(!(this._topology==null||this._topologyEmitters.size===0))for(let n of this._topologyEmitters)n(e)}add(e,n){let r=e.name,s=n?.name??r;if(s==null||s==="")throw new Error(`Graph "${this.name}": graph.add requires a non-empty name \u2014 pass via opts.name or set it on the node (e.g. state(0, { name: "x" }))`);let o=s,i=n?.annotation;if(bt(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:de()})),e}setVersioning(e){if(e!=null)for(let n of this._nodes.values())n instanceof L&&n._applyVersioning(e)}remove(e){bt(e,this.name,"remove");let n=this._mounts.get(e);if(n){let o={kind:"mount",nodes:[],mounts:[]},i=[];n._collectObserveTargets("",i);for(let[a,c]of i)a.includes(`${G}${z}${G}`)||o.nodes.push(a);return o.nodes.sort(),o.mounts.push(e),o.mounts.push(...n._collectSubgraphs(`${e}${G}`)),this._mounts.delete(e),n._parent=void 0,ln(n),this._emitTopology({kind:"removed",name:e,nodeKind:"mount",audit:o}),o}let r=this._nodes.get(e);if(!r)throw new Error(`Graph "${this.name}": unknown node or mount "${e}"`);this._nodes.delete(e),this._nodeToName.delete(r),r.down([[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 n=typeof e=="function"?e:(()=>{let o=Ue(e);return i=>o.test(i)})(),r={kind:"mount",nodes:[],mounts:[]},s=[...this._nodes.keys(),...this._mounts.keys()].filter(o=>n(o));for(let o of s){let i=this.remove(o);r.nodes.push(...i.nodes),r.mounts.push(...i.mounts)}return r.nodes.sort(),r.mounts.sort(),r}[Symbol.iterator](){let e=[...this._nodes.keys()].sort(),n=this._nodes,r=0;return{[Symbol.iterator](){return this},next(){if(r>=e.length)return{value:void 0,done:!0};let s=e[r++];return{value:[s,n.get(s)],done:!1}}}}node(e){if(e==="")throw new Error(`Graph "${this.name}": node name must be non-empty`);if(e.includes(G))return this.resolve(e);let n=this._nodes.get(e);if(!n)throw new Error(`Graph "${this.name}": unknown node "${e}"`);return n}get(e){return this.node(e).cache}set(e,n,r){let s=r?.internal===!0;this.node(e).down([[P,n]],{actor:r?.actor,internal:s,delivery:"write"})}setAll(e,n){let r=Symbol.iterator in e?e:Object.entries(e);Re(()=>{for(let[s,o]of r)this.set(s,o,n)})}invalidate(e,n){let r=n?.internal===!0;this.node(e).down([[X]],{actor:n?.actor,internal:r,delivery:"write"})}error(e,n,r){let s=r?.internal===!0;this.node(e).down([[$,n]],{actor:r?.actor,internal:s,delivery:"write"})}complete(e,n){let r=n?.internal===!0;this.node(e).down([[V]],{actor:n?.actor,internal:r,delivery:"write"})}edges(e){let n=e?.recursive===!0,r=new Map;if(!n){for(let[c,u]of this._nodes)r.set(u,c);let a=[];for(let[c,u]of this._nodes)if(u instanceof L)for(let f of u._deps){let p=r.get(f.node);p!=null&&a.push([p,c])}return a.sort((c,u)=>c[0]<u[0]?-1:c[0]>u[0]?1:c[1]<u[1]?-1:c[1]>u[1]?1:0),a}let s=[];this._collectObserveTargets("",s);let o=new Map;for(let[a,c]of s)o.set(c,a);let i=[];for(let[a,c]of s)if(c instanceof L)for(let u of c._deps){let f=o.get(u.node);f!=null&&i.push([f,a])}return i.sort((a,c)=>a[0]<c[0]?-1:a[0]>c[0]?1:a[1]<c[1]?-1:a[1]>c[1]?1:0),i}mount(e,n){if(bt(e,this.name,"mount"),this._nodes.has(e))throw new Error(`Graph "${this.name}": cannot mount at "${e}" \u2014 node with that name exists`);if(this._mounts.has(e))throw new Error(`Graph "${this.name}": mount "${e}" already exists`);if(n===this)throw new Error(`Graph "${this.name}": cannot mount a graph into itself`);if(n._parent!=null)throw new Error(`Graph "${this.name}": this child graph is already mounted on "${n._parent.name}"`);for(let r=this;r!=null;r=r._parent)if(r===n)throw new Error(`Graph "${this.name}": mount("${e}", \u2026) would create a mount cycle`);return this._mounts.set(e,n),n._parent=this,this._emitTopology({kind:"added",name:e,nodeKind:"mount"}),n}resolve(e){let n=Mr(e,this.name);return this._resolveFromSegments(n)}tryResolve(e){try{return this.resolve(e)}catch{return}}_resolveFromSegments(e){let n=e;if(n[0]===this.name&&(n=n.slice(1),n.length===0))throw new Error(`Graph "${this.name}": resolve path ends at graph name only`);let r=n[0],s=n.slice(1);if(s.length===0){let a=this._nodes.get(r);if(a)return a;throw this._mounts.has(r)?new Error(`Graph "${this.name}": path ends at subgraph "${r}" \u2014 not a node (GRAPHREFLY-SPEC \xA73.5)`):new Error(`Graph "${this.name}": unknown name "${r}"`)}let o=this._nodes.get(r);if(o&&s.length>0&&s[0]===z)return this._resolveMetaChainFromNode(o,s,n.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,n,r){let s=e,o=0,i=[...n];for(;o<i.length;){if(i[o]!==z)throw new Error(`Graph "${this.name}": expected ${z} segment in meta path "${r}"`);if(o+1>=i.length)throw new Error(`Graph "${this.name}": meta path requires a key after ${z} in "${r}"`);let a=i[o+1],c=s.meta[a];if(!c)throw new Error(`Graph "${this.name}": unknown meta "${a}" in path "${r}"`);s=c,o+=2}return s}signal(e,n){if(n?.internal!==!0){for(let s of e)if(this.config.messageTier(s[0])===3)throw new Error(`Graph "${this.name}": Graph.signal() rejects tier-3 messages (DATA / RESOLVED). Broadcast is for control-plane tiers (START / DIRTY / INVALIDATE / PAUSE / RESUME / COMPLETE / ERROR / TEARDOWN). For per-node value writes, use Graph.set or graph.node(name).down(...).`)}let r=[];if(this._signalDeliver(e,n??{},new Set,r),r.length>0)throw r[0]}_signalDeliver(e,n,r,s){for(let c of this._mounts.values())c._signalDeliver(e,n,r,s);let i=n.internal===!0?{internal:!0}:{actor:n.actor,delivery:"signal"},a=Gr(e,this.config);for(let c of[...this._nodes.keys()].sort()){let u=this._nodes.get(c);if(!r.has(u)){r.add(u);try{u.down(e,i)}catch(f){if(f instanceof q)throw f;s.push(f)}a.length!==0&&this._signalMetaSubtree(u,a,r,i,s)}}}_signalMetaSubtree(e,n,r,s,o){for(let i of Object.keys(e.meta).sort()){let a=e.meta[i];if(!r.has(a)){r.add(a);try{a.down(n,s)}catch(c){if(c instanceof q)throw c;o.push(c)}this._signalMetaSubtree(a,n,r,s,o)}}}describe(e){if(e?.reactive===!0)return this._describeReactive(e);let n=e?.actor,r=e?.filter,s=Pe(e?.detail,e?.fields),o=e?.format==="spec",i=o?Pe("minimal"):s,a=[];this._collectObserveTargets("",a);let c=new Map;for(let[T,_]of a)c.set(_,T);let u=[];{let T=a.map(([,k])=>k),_=new Set(c.values()),x=0;for(;T.length>0;){let k=T.shift();if(k instanceof L)for(let D of k._deps){let N=D.node;if(c.has(N))continue;let E=N.name??"",S=E;if(!S||_.has(S))if(E){let A=2;for(;_.has(`${E}#${A}`);)A++;S=`${E}#${A}`}else for(S=`__internal__/${x++}`;_.has(S);)S=`__internal__/${x++}`;c.set(N,S),_.add(S),u.push([S,N]),T.push(N)}}}let f=[...a,...u],p={};for(let[T,_]of f){if(n!=null&&!_.allowsObserve(n))continue;let x=ht(_,i),k=_ instanceof L?_._deps.map(S=>c.get(S.node)??S.node.name??""):[],{name:D,...N}=x,E={...N,deps:k};if(!o){let S=this._annotations.get(T);S!=null&&(E.annotation=S)}if(r!=null)if(typeof r=="function"){let S=r;if(!(S.length>=2?S(T,E):S(E)))continue}else{let S=!0;for(let[A,F]of Object.entries(r)){let J=A==="deps_includes"?"depsIncludes":A==="meta_has"?"metaHas":A;if(J==="depsIncludes"){if(!E.deps.includes(String(F))){S=!1;break}continue}if(J==="metaHas"){if(!Object.hasOwn(E.meta??{},String(F))){S=!1;break}continue}if(E[J]!==F){S=!1;break}}if(!S)continue}p[T]=E}let g=new Set(Object.keys(p)),l=[];for(let[T,_]of f)if(_ instanceof L)for(let x of _._deps){let k=c.get(x.node);k!=null&&l.push([k,T])}l.sort((T,_)=>T[0]<_[0]?-1:T[0]>_[0]?1:T[1]<_[1]?-1:T[1]>_[1]?1:0);let d=l.map(([T,_])=>({from:T,to:_}));(n!=null||r!=null)&&(d=d.filter(T=>g.has(T.from)&&g.has(T.to)));let m=this._collectSubgraphs(""),b=n!=null||r!=null?m.filter(T=>{let _=`${T}${G}`;return[...g].some(x=>x===T||x.startsWith(_))}):m,v=this,h=e,y={name:this.name,nodes:p,edges:d,subgraphs:b,expand(T){let _={...h,format:void 0};return Array.isArray(T)?(_.fields=T,_.detail=void 0):(_.detail=T,_.fields=void 0),v.describe(_)}},w=e??{},O=w.format;return O==="json"?Or(y,w):O==="pretty"?Sr(y,w):O==="mermaid"?dn(y,w):O==="mermaid-url"?Tr(y,w):O==="d2"?kr(y,w):O==="ascii"?Yt(y,w):y}_collectSubgraphs(e){let n=[];for(let r of[...this._mounts.keys()].sort()){let s=e===""?r:`${e}${r}`;n.push(s),n.push(...this._mounts.get(r)._collectSubgraphs(`${s}${G}`))}return n}resourceProfile(e){return nn(this,e)}reachable(e,n,r={}){return r.withDetail===!0?an(this.describe(),e,n,{...r,withDetail:!0}):an(this.describe(),e,n,r)}explain(e,n,r){return r?.reactive===!0?this._explainReactive(e,n,r):this._explainStatic(e,n,r)}_explainStatic(e,n,r){let s=this.describe({detail:"full"}),o=new Map(this._annotations),i=new Map;for(let[a,c]of Object.entries(s.nodes))c.lastMutation!=null&&i.set(a,c.lastMutation);return Xt(s,e,n,{...r?.maxDepth!=null?{maxDepth:r.maxDepth}:{},...r?.findCycle===!0?{findCycle:!0}:{},annotations:o,lastMutations:i})}_describeReactive(e){let n={...e,reactive:!1},r=e.reactiveName??"describe",s=0,o=ee(s,{name:`${r}_version`}),i=this.observe({timeline:!0,structured:!0}),a=!1,c=!1,u=()=>{a||c||(a=!0,_e(()=>{a=!1,!c&&(s+=1,o.emit(s))}))},f=i.onEvent(b=>{let v=b.type;v!=="data"&&v!=="error"&&v!=="complete"&&v!=="teardown"||u()}),p=[],g=new WeakSet,l=b=>{if(g.has(b)||c)return;g.add(b);let v=b.topology.subscribe(h=>{for(let y of h){if(y[0]!==P)continue;let w=y[1];if(u(),w.kind==="added"&&w.nodeKind==="mount"){let O=b._mounts.get(w.name);O!=null&&l(O)}}});p.push(v);for(let h of b._mounts.keys()){let y=b._mounts.get(h);y!=null&&l(y)}};l(this);let d;try{d=ie([o],()=>this.describe(n),{name:r,describeKind:"derived",meta:{domain:"audit",kind:"describe"},equals:(b,v)=>b===v})}catch(b){f();for(let v of p)v();throw i.dispose(),b}let m=ge(d);return{node:d,dispose(){c=!0,f();for(let b of p)b();p.length=0,i.dispose(),m()}}}_explainReactive(e,n,r){let s=0,o=ee(s,{name:"explain_version"}),i=this.observe({timeline:!0,structured:!0}),a=!1,c=!1,u=i.onEvent(l=>{let d=l.type;d!=="data"&&d!=="error"&&d!=="complete"&&d!=="teardown"||a||c||(a=!0,_e(()=>{a=!1,!c&&(s+=1,o.emit(s))}))}),f={...r?.maxDepth!=null?{maxDepth:r.maxDepth}:{},...r?.findCycle===!0?{findCycle:!0}:{}},p;try{p=ie([o],()=>this._explainStatic(e,n,f),{name:r?.name??"explain",describeKind:"derived",meta:{domain:"audit",kind:"explain_path",from:e,to:n},equals:(l,d)=>l.found===d.found&&l.reason===d.reason&&l.steps.length===d.steps.length&&Lr(l.steps,d.steps)})}catch(l){throw u(),i.dispose(),l}let g=ge(p);return{node:p,dispose(){c=!0,u(),i.dispose(),g()}}}_pathsMatching(e){let n=Ue(e),r=[];return this._collectObserveTargets("",r),r.map(([s])=>s).filter(s=>n.test(s))}_collectObserveTargets(e,n){for(let r of[...this._mounts.keys()].sort()){let s=e===""?r:`${e}${G}${r}`;this._mounts.get(r)._collectObserveTargets(s,n)}for(let r of[...this._nodes.keys()].sort()){let s=this._nodes.get(r),o=e===""?r:`${e}${G}${r}`;n.push([o,s]),this._appendMetaObserveTargets(o,s,n)}}_appendMetaObserveTargets(e,n,r){for(let s of Object.keys(n.meta).sort()){let o=n.meta[s],i=`${e}${G}${z}${G}${s}`;r.push([i,o]),this._appendMetaObserveTargets(i,o,r)}}observe(e,n){let r=typeof e=="string",o=on(r?n:e),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 f=e,p=this.resolve(f);if(a!=null&&!p.allowsObserve(a))throw new q({actor:a,action:"observe",nodeName:f});return i?this._buildStructuredObserver([[f,p]],o,"one"):{subscribe(g){return p.subscribe(g)},up(g){try{p.up?.(g)}catch(l){if(l instanceof q)return;throw l}}}}let c=[];this._collectObserveTargets("",c),c.sort((f,p)=>f[0]<p[0]?-1:f[0]>p[0]?1:0);let u=a==null?c:c.filter(([,f])=>f.allowsObserve(a));return i?this._buildStructuredObserver(u,o,"all"):{subscribe:f=>{let p=u.map(([g,l])=>l.subscribe(d=>{f(g,d)}));return()=>{for(let g of p)g()}},up:(f,p)=>{try{this.resolve(f).up?.(p)}catch(g){if(g instanceof q)return;throw g}}}}_buildStructuredObserver(e,n,r){let s=r==="one"?e[0]?.[0]:void 0,o=i=>{if(r==="one"&&s!=null){let f=this.resolve(s);return this._buildStructuredObserver([[s,f]],i,"one")}let a=[];this._collectObserveTargets("",a),a.sort((f,p)=>f[0]<p[0]?-1:f[0]>p[0]?1:0);let c=i.actor,u=c==null?a:a.filter(([,f])=>f.allowsObserve(c));return this._buildStructuredObserver(u,i,"all")};return this._createObserveResult(e,n,o)}_createObserveResult(e,n,r){let s=n.timeline===!0,o=n.causal===!0,i=n.derived===!0,a=n.detail==="minimal",c=this.config.inspectorEnabled,u=(o||i)&&c,f=n.maxEvents,p=f!=null&&f>0?new Se(f):null,g=[],l=new Set,d={},m=new Set,b=0,v=0,h=0,y=0,w=0,O=0,T=!1,_=!1,x=0,k=new Map,D=new Map,N=new Map,E=R=>{p?p.push(R):g.push(R);for(let M of l)M(R)},S=()=>s?{timestamp_ns:de(),in_batch:Ee(),batch_id:x}:{},A=(R,M)=>{if(!(!u||!(R instanceof L)))return R._setInspectorHook(W=>{if(W.kind==="dep_message")k.set(R,W.depIndex);else if(W.kind==="run"){let ye=W.batchData.map((C,j)=>C!=null&&C.length>0?C.at(-1):W.prevData[j]);D.set(R,ye);let U=W.batchData.map(C=>C!=null?[...C]:void 0);N.set(R,U),i&&E({type:"derived",path:M,dep_values:ye,dep_batches:U,...S()})}})},F=R=>{let M=k.get(R),W=D.get(R);if(!o||W==null)return{};let U=(M!=null&&M>=0&&R instanceof L?R._deps[M]:void 0)?.node,C=U?.v,j=N.get(R);return{trigger_dep_index:M,trigger_dep_name:U?.name,...C!=null?{trigger_version:{id:C.id,version:C.version}}:{},dep_values:[...W],...j!=null?{dep_batches:j}:{}}},J=[],ne=[];for(let[R,M]of e){let W=A(M,R);W&&J.push(W),ne.push(M.subscribe(ye=>{x++;for(let U of ye){let C=U[0],j=S();if(C===P){d[R]=U[1];let Ze=M instanceof L?M.lastMutation?.actor??ae:ae;E({type:"data",path:R,data:U[1],actor:Ze,...j,...F(M)})}else if(a)C===H?b++:C===Y?v++:C===X?h++:C===Z?y++:C===Q?w++:C===B?O++:C===V&&!m.has(R)?T=!0:C===$&&(_=!0,m.add(R));else if(C===H)b++,E({type:"dirty",path:R,...j});else if(C===Y)v++,E({type:"resolved",path:R,...j,...F(M)});else if(C===X)h++,E({type:"invalidate",path:R,...j});else if(C===Z)y++,E({type:"pause",path:R,lockId:U[1],...j});else if(C===Q)w++,E({type:"resume",path:R,lockId:U[1],...j});else if(C===V)m.has(R)||(T=!0),E({type:"complete",path:R,...j});else if(C===$){_=!0,m.add(R);let Ze=M instanceof L?M.lastMutation?.actor??ae:ae;E({type:"error",path:R,data:U[1],actor:Ze,...j})}else C===B&&(O++,E({type:"teardown",path:R,...j}))}}))}let Je=!1,Ye=()=>{if(!Je){Je=!0;for(let R of ne)R();for(let R of J)R();for(let R of Ne)R({value:void 0,done:!0});Ne.length=0}},Xe=[],Ne=[];l.add(R=>{let M=Ne.shift();M?M({value:R,done:!1}):Xe.push(R)});let xt={get values(){return d},get dirtyCount(){return b},get resolvedCount(){return v},get invalidateCount(){return h},get pauseCount(){return y},get resumeCount(){return w},get teardownCount(){return O},get events(){return p?p.toArray():[...g]},get anyCompletedCleanly(){return T},get anyErrored(){return _},get completedWithoutErrors(){return T&&!_},onEvent(R){return l.add(R),()=>l.delete(R)},dispose:Ye,expand(R){Ye();let M={...n};return typeof R=="string"?M.detail=R:Object.assign(M,R),r(on(M))},[Symbol.asyncIterator](){return{next(){return Xe.length>0?Promise.resolve({value:Xe.shift(),done:!1}):Je?Promise.resolve({value:void 0,done:!0}):new Promise(R=>Ne.push(R))},return(){return Ye(),Promise.resolve({value:void 0,done:!0})}}}};return n.format!=null&&this._attachFormatLogger(xt,n),xt}_attachFormatLogger(e,n){let r=n.format;if(r==null)return;let s=n.logger??(d=>console.log(d)),o=n.includeTypes?new Set(n.includeTypes):null,i=n.excludeTypes?new Set(n.excludeTypes):null,a=o==null&&i==null?()=>!0:d=>(o==null||o.has(d))&&(i==null||!i.has(d)),c=Dr(n.theme),u=r==="stage-log"?de():0,f=d=>d==null?"":n.stageLabels?.[d]??d,p=(d,m)=>d.length>m?`${d.slice(0,m-1)}\u2026`:d,g=d=>d.type==="data"||d.type==="error"?p(Ke(d.data),120):"",l=d=>{if(r==="stage-log"){let _=(de()-u)/1e9,x=f(d.path).padEnd(9);if(d.type==="data"){let k=g(d);return`[${_.toFixed(3)}s] ${x} \u2190${k?` ${k}`:""}`}if(d.type==="error"){let k=g(d);return`[${_.toFixed(3)}s] ${x} \u2717${k?` ${k}`:""}`}return d.type==="complete"?`[${_.toFixed(3)}s] ${x} \u25A0 complete`:`[${_.toFixed(3)}s] ${x} ${d.type}`}if(r==="json")try{return JSON.stringify(d)}catch{return JSON.stringify({type:d.type,path:d.path,data:"[unserializable]"})}let m=c[d.type]??"",b=d.path?`${c.path}${d.path}${c.reset} `:"",v=d.type==="data"||d.type==="error",h=d.type==="pause"||d.type==="resume",y=v?` ${Ke(d.data)}`:h?` ${Ke(d.lockId)}`:"",w=d.type==="data"||d.type==="resolved"||d.type==="derived"?d:void 0,O=w?.trigger_dep_name!=null?` <- ${w.trigger_dep_name}`:w?.trigger_dep_index!=null?` <- #${w.trigger_dep_index}`:"",T=d.in_batch?" [batch]":"";return`${b}${m}${d.type.toUpperCase()}${c.reset}${y}${O}${T}`};e.onEvent(d=>{a(d.type)&&s(l(d),d)})}addDisposer(e){return this._disposers.add(e),()=>{this._disposers.delete(e)}}destroy(){rn(this._disposers,this.name),this.signal([[B]],{internal:!0}),rn(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}_destroyClearOnly(){for(let e of[...this._mounts.values()])e._parent=void 0,e._destroyClearOnly();this._mounts.clear(),this._nodes.clear(),this._parent=void 0}snapshot(e){let{expand:n,...r}=this.describe({detail:"full"}),s={};for(let a of Object.keys(r.nodes).sort()){let{lastMutation:c,guard:u,...f}=r.nodes[a];s[a]=f}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 St(a,a.encode(i))}throw new Error(`snapshot: unknown format "${String(e.format)}"`)}static decode(e,n){let r=n?.config??pe,{codec:s,codecVersion:o,payload:i}=Tt(e,r);return s.decode(i,o)}restore(e,n){if(sn(e),e.name!==this.name)throw new Error(`Graph "${this.name}": restore snapshot name "${e.name}" does not match this graph`);let r=n?.only==null?null:(Array.isArray(n.only)?n.only:[n.only]).map(o=>Ue(o)),s=n?.includeProducers===!0;for(let o of Object.keys(e.nodes).sort()){if(r!==null&&!r.some(a=>a.test(o)))continue;let i=e.nodes[o];if(i!==void 0){if(!("value"in i)||i.value===void 0){"value"in i&&i.value===void 0&&n?.onError?.(o,new Error(`restore: slice.value is undefined for "${o}" (undefined is the global SENTINEL; not valid DATA)`));continue}if(!(i.type==="derived"||i.type==="effect")&&!(i.type==="producer"&&!s)){if(i.v!=null){let c=this.tryResolve(o)?.v;if(c!=null&&c.id===i.v.id&&c.version===i.v.version)continue}try{this.set(o,i.value)}catch(a){n?.onError?.(o,a)}}}}}static fromSnapshot(e,n){sn(e);let r=typeof n=="function"?n:n?.build,s=typeof n=="function"?void 0:n?.factories,o=new t(e.name);if(r)return r(o),o.restore(e),o;for(let l of[...e.subgraphs].sort((d,m)=>{let b=d.split(G).length,v=m.split(G).length;return b!==v?b-v:d<m?-1:d>m?1:0})){let d=l.split(G),m=o;for(let b of d)m._mounts.has(b)||m.mount(b,new t(b)),m=m._mounts.get(b)}let i=s?Object.entries(s).map(([l,d])=>({re:Ue(l),factory:d})):[],a=l=>{for(let d of i)if(d.re.test(l))return d.factory},c=l=>{let d=l.split(G),m=d.pop();if(m==null||m.length===0)throw new Error(`invalid snapshot path "${l}"`);let b=o;for(let v of d){let h=b._mounts.get(v);if(!h)throw new Error(`unknown mount "${v}" in path "${l}"`);b=h}return[b,m]},u=Object.entries(e.nodes).filter(([l])=>!l.includes(`${G}${z}${G}`)).sort((l,d)=>l[0]<d[0]?-1:l[0]>d[0]?1:0),f=new Map(u),p=new Map,g=!0;for(;f.size>0&&g;){g=!1;for(let[l,d]of[...f.entries()]){let m=d?.deps??[];if(!m.every(O=>p.has(O)))continue;let[b,v]=c(l),h={...d?.meta??{}},y=a(l),w;if(d?.type==="state")w=ee(d.value,{meta:h});else{if(y==null)continue;w=y(v,{path:l,type:d.type,value:d.value,meta:h,deps:m,resolvedDeps:m.map(O=>p.get(O))})}b.add(w,{name:v}),p.set(l,w),f.delete(l),g=!0}}if(f.size>0){let l=[...f.keys()].sort().join(", ");throw new Error(`Graph.fromSnapshot could not reconstruct nodes without build callback: ${l}. Pass matching factories via fromSnapshot(data, { factories: { pattern: factoryFn } }).`)}return o.restore(e),o}toJSON(){return this.snapshot()}attachStorage(e,n={}){let r=e.map(u=>({tier:u,debounceMs:Math.max(0,u.debounceMs??0),compactEvery:Math.max(1,u.compactEvery??10),timer:void 0,seq:0,lastSnapshot:void 0,lastFingerprint:"",disposed:!1,savePending:void 0}));n.autoRestore===!0&&this._cascadeRestore(e,n.onError);let s=(u,f)=>{if(u.disposed)return;let p=yr(f.nodes);if(u.lastSnapshot!=null&&p!==""&&p===u.lastFingerprint)return;let g=u.seq+1,l=Ce(),b=u.lastSnapshot==null||g%u.compactEvery===0?{mode:"full",snapshot:f,seq:g,timestamp_ns:l,format_version:me}:{mode:"diff",diff:$r(u.lastSnapshot,f),seq:g,timestamp_ns:l,format_version:me};if(u.tier.filter&&!u.tier.filter(this.name,b))return;let v;try{v=u.tier.save(this.name,b)}catch(h){n.onError?.(h,u.tier);return}if(v&&typeof v.then=="function"){let w=(u.savePending??Promise.resolve()).then(()=>v,()=>v).then(()=>{u.disposed||(u.seq=g,u.lastSnapshot=f,u.lastFingerprint=p)},O=>{n.onError?.(O,u.tier)});u.savePending=w.finally(()=>{u.savePending===w&&(u.savePending=void 0)})}else u.seq=g,u.lastSnapshot=f,u.lastFingerprint=p},o=(u,f)=>{try{s(u,f)}catch(p){n.onError?.(p,u.tier)}},i=(u,f)=>{if(!f.some(d=>{let m=this.config.messageTier(d[0]);return m>=3&&m<5}))return;if(n.filter){let d=this.tryResolve(u);if(d==null)return;let m=ht(d,Pe("standard"));if(!n.filter(u,m))return}let g,l=()=>(g==null&&(g=this.snapshot()),g);for(let d of r)d.disposed||(d.debounceMs===0?o(d,l()):(d.timer==null&&(d.timer=new Fe),d.timer.start(d.debounceMs,()=>{d.disposed||o(d,this.snapshot())})))},a;if(n.paths!=null){let f=(typeof n.paths=="string"?this._pathsMatching(n.paths):n.paths).map(p=>{let g=this.tryResolve(p);return g==null?()=>{}:g.subscribe(l=>i(p,l))});a=()=>{for(let p of f)p()}}else a=this.observe().subscribe((u,f)=>i(u,f));let c=()=>{a();for(let u of r)u.disposed=!0,u.timer?.cancel();this._storageDisposers.delete(c)};return this._storageDisposers.add(c),{dispose:c}}async _cascadeRestore(e,n){for(let r of e){let s;try{s=await r.load(this.name)}catch(i){n?.(i,r);continue}if(s==null||typeof s!="object"||Array.isArray(s))continue;let o=s;try{if(o.mode==="full"&&o.snapshot!=null)return this.restore(o.snapshot),!0;if(o.version===me&&o.nodes!=null)return this.restore(o),!0}catch(i){n?.(i,r)}}return!1}static async fromStorage(e,n,r){for(let s of n){let o;try{o=await s.load(e)}catch(c){r?.onError?.(c,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===me&&i.nodes!=null?i:void 0;if(a!=null)try{return t.fromSnapshot(a,r)}catch(c){r?.onError?.(c,s)}}throw new Error(`Graph.fromStorage: no tier held a restorable record for "${e}" across ${n.length} tier(s)`)}_annotations=new Map;_traceRing;trace(e,n,r){if(e!=null&&n!=null){if(this.tryResolve(e)==null)return;if(this._annotations.set(e,n),this.config.inspectorEnabled){let s={path:e,annotation:n,timestamp_ns:de(),...r?.actor!=null?{actor:r.actor}:{}};this._traceRing.push(s)}return}return e!=null?this.config.inspectorEnabled?this._annotations.get(e):void 0:this.config.inspectorEnabled?this._traceRing.toArray():[]}annotation(e){return this._annotations.get(e)}clearTrace(){this._annotations.clear(),this._traceRing.clear()}pruneTrace(e){let n=this._traceRing.toArray().filter(s=>!e(s)),r=this._traceRing.size-n.length;this._traceRing.clear();for(let s of n)this._traceRing.push(s);return r}static diff(e,n){let r=new Set(Object.keys(e.nodes)),s=new Set(Object.keys(n.nodes)),o=[...s].filter(h=>!r.has(h)).sort(),i=[...r].filter(h=>!s.has(h)).sort(),a=[],c=[];for(let h of r){if(!s.has(h))continue;let y=e.nodes[h],w=n.nodes[h],O=y.v,T=w.v;O!=null&&T!=null&&O.id===T.id&&O.version!==T.version&&c.push({path:h,id:O.id,from:O.version,to:T.version});let _=O!=null&&T!=null&&O.id===T.id&&O.version===T.version;for(let x of["type","status","sentinel"]){let k=y[x],D=w[x];k!==D&&a.push({path:h,field:x,from:k,to:D})}if(!_)for(let x of["value","meta"]){let k=y[x],D=w[x];vr(k,D)||a.push({path:h,field:x,from:k,to:D})}}let u=h=>`${h.from} ${h.to}`,f=new Set(e.edges.map(u)),p=new Set(n.edges.map(u)),g=n.edges.filter(h=>!f.has(u(h))),l=e.edges.filter(h=>!p.has(u(h))),d=new Set(e.subgraphs),m=new Set(n.subgraphs),b=[...m].filter(h=>!d.has(h)).sort(),v=[...d].filter(h=>!m.has(h)).sort();return{nodesAdded:o,nodesRemoved:i,nodesChanged:a,versionChanges:c,edgesAdded:g,edgesRemoved:l,subgraphsAdded:b,subgraphsRemoved:v}}};function $r(t,e){let n=be.diff(t,e),r={};for(let s of n.nodesAdded){let o=e.nodes[s];o!=null&&(r[s]=o)}return{...n,nodesAddedFull:r}}function an(t,e,n,r={}){let s={paths:[],depths:new Map,truncated:!1};if(!e)return r.withDetail?s:[];if(!r.both&&n!=="upstream"&&n!=="downstream")throw new Error('reachable: direction must be "upstream" or "downstream"');let o=r.maxDepth;if(o!=null&&(!Number.isInteger(o)||o<0))throw new Error("reachable: maxDepth must be an integer >= 0");if(o===0)return r.withDetail?s:[];let i=new Map,a=new Map,c=new Map,u=new Map,f=new Set;for(let[y,w]of Object.entries(t.nodes)){if(!y)continue;f.add(y);let O=w.deps??[];i.set(y,O);for(let T of O)T&&(f.add(T),a.has(T)||a.set(T,new Set),a.get(T).add(y))}for(let y of t.edges){if(y==null||typeof y!="object")continue;let w=typeof y.from=="string"?y.from:"",O=typeof y.to=="string"?y.to:"";!w||!O||(f.add(w),f.add(O),u.has(w)||u.set(w,new Set),u.get(w).add(O),c.has(O)||c.set(O,new Set),c.get(O).add(w))}if(!f.has(e))return r.withDetail?s:[];let p=r.both===!0,g=y=>{if(p){let _=i.get(y)??[],x=c.get(y),k=a.get(y),D=u.get(y),N=[..._];return x&&N.push(...x),k&&N.push(...k),D&&N.push(...D),N}if(n==="upstream"){let _=i.get(y)??[],x=c.get(y);return x?[..._,...x]:_}let w=a.get(y),O=u.get(y),T=w?[...w]:[];return O&&T.push(...O),T},l=new Set([e]),d=new Map,m=[{path:e,depth:0}],b=0,v=!1;for(;b<m.length;){let y=m[b++];if(o!=null&&y.depth>=o){g(y.path).length>0&&(v=!0);continue}for(let w of g(y.path))!w||l.has(w)||(l.add(w),d.set(w,y.depth+1),m.push({path:w,depth:y.depth+1}))}let h=[...d.keys()].sort((y,w)=>y<w?-1:y>w?1:0);return r.withDetail?{paths:h,depths:d,truncated:v}:h}function Lr(t,e){if(t.length!==e.length)return!1;for(let n=0;n<t.length;n++){let r=t[n],s=e[n];if(r.path!==s.path||r.type!==s.type||r.status!==s.status||r.hop!==s.hop||r.dep_index!==s.dep_index||r.annotation!==s.annotation||r.value!==s.value||r.lastMutation!==s.lastMutation)return!1;let o=r.v,i=s.v;if(o!==i&&(o==null||i==null||o.id!==i.id||o.version!==i.version))return!1}return!0}De();fe();he();Ie();fe();gt();function fn(t,e){let n=t.cache??0;return n>=e?!1:(t.down([[H],[P,n+1]]),!0)}function pn(t,e,n){return{[t]:!0,[`${t}_type`]:e,...n??{}}}function hn(t,e){return pn("reduction",t,e)}function gn(t,e,n,r){let s=r?.maxIterations??10,o=`__feedback_${e}`,i=ee(0,{meta:hn("feedback_counter",{maxIterations:s,feedbackFrom:e,feedbackTo:n})});t.add(i,{name:o});let a=t.resolve(e),c=t.resolve(n),u=`__feedback_effect_${e}`,f=oe([],(p,g)=>{let l=a.subscribe(d=>{for(let m of d){let b=m[0];if(b===P){let v=m[1];if(v==null)return;Re(()=>{fn(i,s)&&c.emit(v)})}else if(b===V||b===$){let v=b===$&&m.length>1?[$,m[1]]:[b];i.down([v])}}});return()=>l()},{name:u,describeKind:"effect",meta:{...hn("feedback_effect",{feedbackFrom:e,feedbackTo:n}),_internal:!0}});return t.add(f,{name:u}),t.addDisposer(ge(f)),t}function Te(t){return typeof t=="object"&&t!==null&&"factory"in t}function wt(t){return typeof t=="object"&&t!==null&&"factory"in t}function bn(t){return Te(t)?t.factory:t}function yn(t){return wt(t)?t.factory:t}function vn(t){let e=[];if(t.fns){let n=new Map;for(let[r,s]of Object.entries(t.fns)){let o=Te(s)?s.tags?.[0]??"Other":"Other";n.has(o)||n.set(o,[]),n.get(o).push(Ir(r,s))}for(let[r,s]of n)e.push(`${r}:
7
8
  ${s.join(`
8
- `)}`)}if(r.sources){let t=[];for(let[n,s]of Object.entries(r.sources))t.push(er(n,s));t.length>0&&e.push(`Sources:
9
- ${t.join(`
9
+ `)}`)}if(t.sources){let n=[];for(let[r,s]of Object.entries(t.sources))n.push(Pr(r,s));n.length>0&&e.push(`Sources:
10
+ ${n.join(`
10
11
  `)}`)}return e.join(`
11
12
 
12
- `)}function Qn(r,e){if(!ke(e))return`- ${r}`;let t=`- ${r}: ${e.description}`;if(e.configSchema){let n=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: { ${n.join(", ")} }`}return t}function er(r,e){if(!gt(e))return`- ${r}`;let t=`- ${r}: ${e.description}`;if(e.configSchema){let n=Object.entries(e.configSchema).map(([s,o])=>{let i=`${s}: ${o.type}`;return o.required===!1&&(i+="?"),i});t+=`. Config: { ${n.join(", ")} }`}return t}function mt(r,e){let t=[],n=new Set(Object.keys(e.fns??{})),s=new Set(Object.keys(e.sources??{}));for(let[o,i]of Object.entries(r.nodes)){if(i.type==="template")continue;let a=i;if(a.fn&&n.size>0&&!n.has(a.fn))if(s.has(a.fn))t.push(`Node "${o}": fn "${a.fn}" is a source, not a function. Use it as a producer source instead, or use a function from: ${[...n].join(", ")}`);else{let c=ht(a.fn,n);t.push(`Node "${o}": fn "${a.fn}" not found in catalog`+(c?`. Did you mean "${c}"?`:""))}if(a.source&&s.size>0&&!s.has(a.source))if(n.has(a.source))t.push(`Node "${o}": source "${a.source}" is a function, not a source. Use it as fn instead, or use a source from: ${[...s].join(", ")}`);else{let c=ht(a.source,s);t.push(`Node "${o}": source "${a.source}" not found in catalog`+(c?`. Did you mean "${c}"?`:""))}if(a.fn&&a.config&&e.fns?.[a.fn]){let c=e.fns[a.fn];if(ke(c)&&c.configSchema){for(let[d,f]of Object.entries(c.configSchema))if(f.required!==!1&&!(d in a.config)&&t.push(`Node "${o}": config missing required field "${d}"`),d in a.config&&f.enum){let g=a.config[d];f.enum.includes(g)||t.push(`Node "${o}": config.${d} = ${JSON.stringify(g)}, expected one of: ${f.enum.join(", ")}`)}}}}if(r.templates){for(let[o,i]of Object.entries(r.templates))for(let[a,c]of Object.entries(i.nodes))if(c.fn&&n.size>0&&!n.has(c.fn)){let d=ht(c.fn,n);t.push(`Template "${o}" node "${a}": fn "${c.fn}" not found in catalog`+(d?`. Did you mean "${d}"?`:""))}}return{valid:t.length===0,errors:t}}function ht(r,e){let t=null,n=1/0,s=r.toLowerCase();for(let o of e){let i=tr(s,o.toLowerCase());i<n&&i<=Math.max(3,Math.floor(r.length/2))&&(n=i,t=o)}return t}function tr(r,e){let t=r.length,n=e.length,s=Array.from({length:t+1},(o,i)=>Array.from({length:n+1},(a,c)=>i===0?c:c===0?i:0));for(let o=1;o<=t;o++)for(let i=1;i<=n;i++)s[o][i]=r[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][n]}var en=new Set(["state","producer","derived","effect","operator","template"]),nr=new Set(["state","producer","derived","effect","operator"]);function ze(r){let e=[];if(r==null||typeof r!="object")return{valid:!1,errors:["GraphSpec must be a non-null object"]};let t=r;if((typeof t.name!="string"||t.name.length===0)&&e.push("Missing or empty 'name' field"),t.nodes==null||typeof t.nodes!="object"||Array.isArray(t.nodes))return e.push("Missing or invalid 'nodes' field (must be an object)"),{valid:!1,errors:e};let n=new Set(Object.keys(t.nodes)),s=new Map,o=new Map;if(t.templates!=null&&typeof t.templates=="object"&&!Array.isArray(t.templates)){for(let[i,a]of Object.entries(t.templates))if(a!=null&&typeof a=="object"){let c=a;o.set(i,{params:Array.isArray(c.params)?c.params:[]})}}if(t.templates!=null)if(typeof t.templates!="object"||Array.isArray(t.templates))e.push("'templates' must be an object");else for(let[i,a]of Object.entries(t.templates)){if(a==null||typeof a!="object"){e.push(`Template "${i}": must be an object`);continue}let c=a;if(Array.isArray(c.params)||e.push(`Template "${i}": missing 'params' array`),c.nodes==null||typeof c.nodes!="object"||Array.isArray(c.nodes))e.push(`Template "${i}": missing or invalid 'nodes' object`);else{let d=new Set(Array.isArray(c.params)?c.params:[]),f=new Set(Object.keys(c.nodes));for(let[g,m]of Object.entries(c.nodes)){if(m==null||typeof m!="object"){e.push(`Template "${i}" node "${g}": must be an object`);continue}let l=m;if((typeof l.type!="string"||!nr.has(l.type))&&e.push(`Template "${i}" node "${g}": invalid type`),Array.isArray(l.deps))for(let u of l.deps)!f.has(u)&&!d.has(u)&&e.push(`Template "${i}" node "${g}": dep "${u}" is not an inner node or param`)}typeof c.output!="string"?e.push(`Template "${i}": missing 'output' string`):c.nodes[c.output]||e.push(`Template "${i}": output "${c.output}" is not a declared node`)}}for(let[i,a]of Object.entries(t.nodes)){if(a==null||typeof a!="object"){e.push(`Node "${i}": must be an object`);continue}let c=a;if(typeof c.type!="string"||!en.has(c.type)){e.push(`Node "${i}": invalid type "${String(c.type)}" (expected: ${[...en].join(", ")})`);continue}if(s.set(i,c.type),c.type==="template")if(typeof c.template!="string"||!o.has(c.template))e.push(`Node "${i}": template "${String(c.template)}" not found in templates`);else if(c.bind==null||typeof c.bind!="object"||Array.isArray(c.bind))e.push(`Node "${i}": template ref requires 'bind' object`);else{let d=o.get(c.template),f=c.bind;for(let g of d.params)g in f||e.push(`Node "${i}": template param "${g}" is not bound (template "${c.template}")`);for(let[,g]of Object.entries(f))typeof g=="string"&&!n.has(g)&&e.push(`Node "${i}": bind target "${g}" does not reference an existing node`)}else{if(Array.isArray(c.deps))for(let d of c.deps)d===i?e.push(`Node "${i}": self-referencing dep`):n.has(d)||e.push(`Node "${i}": dep "${d}" does not reference an existing node`);(c.type==="derived"||c.type==="effect"||c.type==="operator")&&!Array.isArray(c.deps)&&e.push(`Node "${i}": ${c.type} node should have a 'deps' array`)}}if(t.feedback!=null)if(!Array.isArray(t.feedback))e.push("'feedback' must be an array");else for(let i=0;i<t.feedback.length;i++){let a=t.feedback[i];if(a==null||typeof a!="object"){e.push(`Feedback [${i}]: must be an object`);continue}let c=a;(typeof c.from!="string"||!n.has(c.from))&&e.push(`Feedback [${i}]: 'from' "${String(c.from)}" does not reference an existing node`),typeof c.from=="string"&&c.from===c.to&&e.push(`Feedback [${i}]: 'from' and 'to' must be different nodes`),typeof c.to!="string"||!n.has(c.to)?e.push(`Feedback [${i}]: 'to' "${String(c.to)}" does not reference an existing node`):typeof c.to=="string"&&s.get(c.to)!=="state"&&e.push(`Feedback [${i}]: 'to' node "${c.to}" must be a state node (got "${s.get(c.to)??"unknown"}")`)}return{valid:e.length===0,errors:e}}function rr(r,e){let t=ze(r);if(!t.valid)throw new Error(`compileSpec: invalid GraphSpec:
13
- ${t.errors.join(`
14
- `)}`);let n=e?.catalog??{},s=new ge(r.name),o=r.templates??{},i=mt(r,n);if(!i.valid)throw new Error(`compileSpec: catalog validation errors:
13
+ `)}function Ir(t,e){if(!Te(e))return`- ${t}`;let n=`- ${t}: ${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});n+=`. Config: { ${r.join(", ")} }`}return n}function Pr(t,e){if(!wt(e))return`- ${t}`;let n=`- ${t}: ${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});n+=`. Config: { ${r.join(", ")} }`}return n}function _t(t,e){let n=[],r=new Set(Object.keys(e.fns??{})),s=new Set(Object.keys(e.sources??{}));for(let[o,i]of Object.entries(t.nodes)){if(i.type==="template")continue;let a=i;if(a.fn&&r.size>0&&!r.has(a.fn))if(s.has(a.fn))n.push(`Node "${o}": fn "${a.fn}" is a source, not a function. Use it as a producer source instead, or use a function from: ${[...r].join(", ")}`);else{let c=vt(a.fn,r);n.push(`Node "${o}": fn "${a.fn}" not found in catalog`+(c?`. Did you mean "${c}"?`:""))}if(a.source&&s.size>0&&!s.has(a.source))if(r.has(a.source))n.push(`Node "${o}": source "${a.source}" is a function, not a source. Use it as fn instead, or use a source from: ${[...s].join(", ")}`);else{let c=vt(a.source,s);n.push(`Node "${o}": source "${a.source}" not found in catalog`+(c?`. Did you mean "${c}"?`:""))}if(a.fn&&a.config&&e.fns?.[a.fn]){let c=e.fns[a.fn];if(Te(c)&&c.configSchema){for(let[u,f]of Object.entries(c.configSchema))if(f.required!==!1&&!(u in a.config)&&n.push(`Node "${o}": config missing required field "${u}"`),u in a.config&&f.enum){let p=a.config[u];f.enum.includes(p)||n.push(`Node "${o}": config.${u} = ${JSON.stringify(p)}, expected one of: ${f.enum.join(", ")}`)}}}}if(t.templates){for(let[o,i]of Object.entries(t.templates))for(let[a,c]of Object.entries(i.nodes))if(c.fn&&r.size>0&&!r.has(c.fn)){let u=vt(c.fn,r);n.push(`Template "${o}" node "${a}": fn "${c.fn}" not found in catalog`+(u?`. Did you mean "${u}"?`:""))}}return{valid:n.length===0,errors:n}}function vt(t,e){let n=null,r=1/0,s=t.toLowerCase();for(let o of e){let i=Fr(s,o.toLowerCase());i<r&&i<=Math.max(3,Math.floor(t.length/2))&&(r=i,n=o)}return n}function Fr(t,e){let n=t.length,r=e.length,s=Array.from({length:n+1},(o,i)=>Array.from({length:r+1},(a,c)=>i===0?c:c===0?i:0));for(let o=1;o<=n;o++)for(let i=1;i<=r;i++)s[o][i]=t[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[n][r]}var mn=new Set(["state","producer","derived","effect","operator","template"]),jr=new Set(["state","producer","derived","effect","operator"]);function qe(t){let e=[];if(t==null||typeof t!="object")return{valid:!1,errors:["GraphSpec must be a non-null object"]};let n=t;if((typeof n.name!="string"||n.name.length===0)&&e.push("Missing or empty 'name' field"),n.nodes==null||typeof n.nodes!="object"||Array.isArray(n.nodes))return e.push("Missing or invalid 'nodes' field (must be an object)"),{valid:!1,errors:e};let r=new Set(Object.keys(n.nodes)),s=new Map,o=new Map;if(n.templates!=null&&typeof n.templates=="object"&&!Array.isArray(n.templates)){for(let[i,a]of Object.entries(n.templates))if(a!=null&&typeof a=="object"){let c=a;o.set(i,{params:Array.isArray(c.params)?c.params:[]})}}if(n.templates!=null)if(typeof n.templates!="object"||Array.isArray(n.templates))e.push("'templates' must be an object");else for(let[i,a]of Object.entries(n.templates)){if(a==null||typeof a!="object"){e.push(`Template "${i}": must be an object`);continue}let c=a;if(Array.isArray(c.params)||e.push(`Template "${i}": missing 'params' array`),c.nodes==null||typeof c.nodes!="object"||Array.isArray(c.nodes))e.push(`Template "${i}": missing or invalid 'nodes' object`);else{let u=new Set(Array.isArray(c.params)?c.params:[]),f=new Set(Object.keys(c.nodes));for(let[p,g]of Object.entries(c.nodes)){if(g==null||typeof g!="object"){e.push(`Template "${i}" node "${p}": must be an object`);continue}let l=g;if((typeof l.type!="string"||!jr.has(l.type))&&e.push(`Template "${i}" node "${p}": invalid type`),Array.isArray(l.deps))for(let d of l.deps)!f.has(d)&&!u.has(d)&&e.push(`Template "${i}" node "${p}": dep "${d}" is not an inner node or param`)}typeof c.output!="string"?e.push(`Template "${i}": missing 'output' string`):c.nodes[c.output]||e.push(`Template "${i}": output "${c.output}" is not a declared node`)}}for(let[i,a]of Object.entries(n.nodes)){if(a==null||typeof a!="object"){e.push(`Node "${i}": must be an object`);continue}let c=a;if(typeof c.type!="string"||!mn.has(c.type)){e.push(`Node "${i}": invalid type "${String(c.type)}" (expected: ${[...mn].join(", ")})`);continue}if(s.set(i,c.type),c.type==="template")if(typeof c.template!="string"||!o.has(c.template))e.push(`Node "${i}": template "${String(c.template)}" not found in templates`);else if(c.bind==null||typeof c.bind!="object"||Array.isArray(c.bind))e.push(`Node "${i}": template ref requires 'bind' object`);else{let u=o.get(c.template),f=c.bind;for(let p of u.params)p in f||e.push(`Node "${i}": template param "${p}" is not bound (template "${c.template}")`);for(let[,p]of Object.entries(f))typeof p=="string"&&!r.has(p)&&e.push(`Node "${i}": bind target "${p}" does not reference an existing node`)}else{if(Array.isArray(c.deps))for(let u of c.deps)u===i?e.push(`Node "${i}": self-referencing dep`):r.has(u)||e.push(`Node "${i}": dep "${u}" does not reference an existing node`);(c.type==="derived"||c.type==="effect"||c.type==="operator")&&!Array.isArray(c.deps)&&e.push(`Node "${i}": ${c.type} node should have a 'deps' array`)}}if(n.feedback!=null)if(!Array.isArray(n.feedback))e.push("'feedback' must be an array");else for(let i=0;i<n.feedback.length;i++){let a=n.feedback[i];if(a==null||typeof a!="object"){e.push(`Feedback [${i}]: must be an object`);continue}let c=a;(typeof c.from!="string"||!r.has(c.from))&&e.push(`Feedback [${i}]: 'from' "${String(c.from)}" does not reference an existing node`),typeof c.from=="string"&&c.from===c.to&&e.push(`Feedback [${i}]: 'from' and 'to' must be different nodes`),typeof c.to!="string"||!r.has(c.to)?e.push(`Feedback [${i}]: 'to' "${String(c.to)}" does not reference an existing node`):typeof c.to=="string"&&s.get(c.to)!=="state"&&e.push(`Feedback [${i}]: 'to' node "${c.to}" must be a state node (got "${s.get(c.to)??"unknown"}")`)}return{valid:e.length===0,errors:e}}function Br(t,e){let n=qe(t);if(!n.valid)throw new Error(`compileSpec: invalid GraphSpec:
14
+ ${n.errors.join(`
15
+ `)}`);let r=e?.catalog??{},s=new be(t.name),o=t.templates??{},i=_t(t,r);if(!i.valid)throw new Error(`compileSpec: catalog validation errors:
15
16
  ${i.errors.join(`
16
- `)}`);let a=l=>{let u=n.fns?.[l];return u?tn(u):void 0},c=l=>{let u=n.sources?.[l];return u?nn(u):void 0},d=new Map,f=[];for(let[l,u]of Object.entries(r.nodes)){if(u.type==="template")continue;let h=u;if(h.type==="state"){let b=Q(h.initial,{name:l,meta:h.meta?{...h.meta}:void 0});s.add(b,{name:l}),d.set(l,b)}else if(h.type==="producer"){let b=h.source?c(h.source):void 0,v=h.fn?a(h.fn):void 0;if(b){let p=b(h.config??{});s.add(p,{name:l}),d.set(l,p)}else if(v){let p=v([],h.config??{});s.add(p,{name:l}),d.set(l,p)}else{let p=we(()=>{},{name:l,meta:{...h.meta,_specFn:h.fn,_specSource:h.source}});s.add(p,{name:l}),d.set(l,p)}}else f.push([l,h])}let g=!0,m=new Map(f);for(;m.size>0&&g;){g=!1;for(let[l,u]of[...m.entries()]){let h=u.deps??[];if(!h.every(y=>d.has(y)))continue;let b=h.map(y=>d.get(y)),v=u.fn?a(u.fn):void 0,p;v?p=v(b,u.config??{}):u.type==="effect"?p=Me(b,()=>{}):p=oe(b,y=>y[0]),s.add(p,{name:l}),d.set(l,p),m.delete(l),g=!0}}if(m.size>0){let l=[...m.keys()].sort().join(", ");throw new Error(`compileSpec: unresolvable deps for nodes: ${l}`)}for(let[l,u]of Object.entries(r.nodes)){if(u.type!=="template")continue;let h=u,b=o[h.template],v=new ge(l),p=new Map,y=[];for(let[_,O]of Object.entries(b.nodes)){let R=(O.deps??[]).map(x=>x.startsWith("$")&&h.bind[x]?h.bind[x]:x),$={...O,deps:R};if(O.type==="state"){let x=Q(O.initial,{name:_,meta:O.meta?{...O.meta}:void 0});v.add(x,{name:_}),p.set(_,x)}else if(O.type==="producer"){let x=O.source?c(O.source):void 0,T=O.fn?a(O.fn):void 0;if(x){let S=x(O.config??{});v.add(S,{name:_}),p.set(_,S)}else if(T){let S=T([],O.config??{});v.add(S,{name:_}),p.set(_,S)}else{let S=we(()=>{},{name:_,meta:{...O.meta,_specFn:O.fn,_specSource:O.source}});v.add(S,{name:_}),p.set(_,S)}}else y.push([_,$])}let w=!0,k=new Map(y);for(;k.size>0&&w;){w=!1;for(let[_,O]of[...k.entries()]){let R=O.deps??[];if(!R.every(A=>p.has(A)||d.has(A)))continue;let x=R.map(A=>p.get(A)??d.get(A)),T=O.fn?a(O.fn):void 0,S;T?S=T(x,O.config??{}):O.type==="effect"?S=Me(x,()=>{}):S=oe(x,A=>A[0]),v.add(S,{name:_}),p.set(_,S),k.delete(_),w=!0}}if(k.size>0){let _=[...k.keys()].sort().join(", ");throw new Error(`compileSpec: template "${h.template}" has unresolvable deps: ${_}`)}s.mount(l,v);let N=`${l}::${b.output}`;d.set(l,s.resolve(N));try{let _=s.resolve(N);_.meta._templateName?.emit(h.template),_.meta._templateBind?.emit(h.bind)}catch{}}for(let l of r.feedback??[])Qt(s,l.from,l.to,{maxIterations:l.maxIterations});return s}var sr=new Set(["reduction","reduction_type","_specFn","_specSource","_templateName","_templateBind","feedbackFrom","feedbackTo","_internal"]);function or(r){let e=r.describe({detail:"standard"}),t={},n=[],s=`::${U}::`,o=/^__feedback_(?!effect_)(.+)$/,i=new Set;for(let l of Object.keys(e.nodes)){if(l.includes(s))continue;let u=o.exec(l);if(u){i.add(u[1]);let h=e.nodes[l]?.meta;h?.feedbackFrom&&h?.feedbackTo&&n.push({from:h.feedbackFrom,to:h.feedbackTo,...h.maxIterations?{maxIterations:h.maxIterations}:{}})}}for(let[l,u]of Object.entries(e.nodes)){if(l.includes(s)||o.test(l)||u.meta?._internal||l.startsWith("__feedback_effect_")||l.startsWith("__bridge_")||l.includes("::"))continue;let h={type:u.type};if(u.deps.length>0&&(h.deps=u.deps.filter(b=>!b.includes("::"))),u.type==="state"&&u.value!==void 0&&(h.initial=u.value),u.meta&&Object.keys(u.meta).length>0){let b={};for(let[v,p]of Object.entries(u.meta))sr.has(v)||(b[v]=p);Object.keys(b).length>0&&(h.meta=b)}t[l]=h}let a={},c={},d=new Set;for(let l of e.subgraphs){let u=`${l}::`;for(let[h,b]of Object.entries(e.nodes)){if(!h.startsWith(u)||h.includes(s))continue;let v=b.meta;if(v?._templateName&&v?._templateBind){let p=v._templateName,y=v._templateBind;if(!a[p]){let w={},k=new Set,N=`${l}::`;for(let[T,S]of Object.entries(e.nodes)){if(!T.startsWith(N)||T.includes(s))continue;let A=T.slice(N.length);A.includes("::")||(k.add(A),w[A]={type:S.type,...S.deps.length>0?{deps:S.deps.map(I=>I.startsWith(N)?I.slice(N.length):I)}:{}})}let _=[],O=new Map;for(let T of Object.values(w))for(let S of T.deps??[])if(!k.has(S)&&!O.has(S)){let A=`$${S}`;_.push(A),O.set(S,A)}for(let T of Object.values(w))T.deps&&(T.deps=T.deps.map(S=>O.get(S)??S));let R=new Set;for(let T of Object.values(w))for(let S of T.deps??[])k.has(S)&&R.add(S);let x=[...k].filter(T=>!R.has(T))[0]??[...k].pop();a[p]={params:_,nodes:w,output:x}}delete t[l],c[l]={type:"template",template:p,bind:y},d.add(l);break}}}let f=new Map;for(let l of e.subgraphs){if(d.has(l))continue;let u={},h=`${l}::`;for(let[v,p]of Object.entries(e.nodes)){if(v.includes(s)||!v.startsWith(h))continue;let y=v.slice(h.length);y.includes("::")||(u[y]={type:p.type,...p.deps.length>0?{deps:p.deps.map(w=>w.startsWith(h)?w.slice(h.length):w)}:{}})}let b=JSON.stringify(Object.fromEntries(Object.entries(u).sort(([v],[p])=>v.localeCompare(p)).map(([v,p])=>[v,{type:p.type,deps:p.deps??[]}])));f.has(b)||f.set(b,[]),f.get(b).push({name:l,nodes:u})}for(let[,l]of f){if(l.length<2)continue;let u=`${l[0].name}_template`,h=l[0].nodes,b=new Set(Object.keys(h)),v=[],p=new Map;for(let _ of Object.values(h))for(let O of _.deps??[])if(!b.has(O)&&!p.has(O)){let R=`$${O}`;v.push(R),p.set(O,R)}let y=new Set;for(let _ of Object.values(h))for(let O of _.deps??[])b.has(O)&&y.add(O);let k=[...b].filter(_=>!y.has(_))[0]??[...b].pop(),N={};for(let[_,O]of Object.entries(h))N[_]={...O,deps:O.deps?.map(R=>p.get(R)??R)};a[u]={params:v,nodes:N,output:k};for(let _ of l){delete t[_.name];let O={},R=new Set(Object.keys(_.nodes));for(let $ of Object.values(_.nodes))for(let x of $.deps??[])if(!R.has(x)){let T=p.get(x)??`$${x}`;O[T]=x}c[_.name]={type:"template",template:u,bind:O}}}let g={...t,...c},m={name:e.name,nodes:g};return Object.keys(a).length>0&&(m.templates=a),n.length>0&&(m.feedback=n),m}function ir(r,e){let t=[];r.name!==e.name&&t.push({type:"changed",path:"name",detail:`"${r.name}" \u2192 "${e.name}"`});let n=new Set(Object.keys(r.nodes)),s=new Set(Object.keys(e.nodes));for(let p of s)if(!n.has(p)){let y=e.nodes[p];t.push({type:"added",path:`nodes.${p}`,detail:`type: ${y.type}`})}for(let p of n)s.has(p)||t.push({type:"removed",path:`nodes.${p}`});for(let p of n){if(!s.has(p))continue;let y=r.nodes[p],w=e.nodes[p];if(JSON.stringify(y)!==JSON.stringify(w)){let k=[];y.type!==w.type&&k.push(`type: ${y.type} \u2192 ${w.type}`),JSON.stringify(y.deps)!==JSON.stringify(w.deps)&&k.push("deps changed"),y.fn!==w.fn&&k.push(`fn: ${y.fn} \u2192 ${w.fn}`),JSON.stringify(y.config)!==JSON.stringify(w.config)&&k.push("config changed"),t.push({type:"changed",path:`nodes.${p}`,detail:k.join("; ")||"modified"})}}let o=r.templates??{},i=e.templates??{},a=new Set(Object.keys(o)),c=new Set(Object.keys(i));for(let p of c)a.has(p)||t.push({type:"added",path:`templates.${p}`});for(let p of a)c.has(p)||t.push({type:"removed",path:`templates.${p}`});for(let p of a)c.has(p)&&JSON.stringify(o[p])!==JSON.stringify(i[p])&&t.push({type:"changed",path:`templates.${p}`,detail:"template definition changed"});let d=r.feedback??[],f=e.feedback??[],g=new Set(d.map(p=>`${p.from}->${p.to}`)),m=new Set(f.map(p=>`${p.from}->${p.to}`));for(let p of f){let y=`${p.from}->${p.to}`;g.has(y)||t.push({type:"added",path:`feedback.${y}`,detail:`maxIterations: ${p.maxIterations??10}`})}for(let p of d){let y=`${p.from}->${p.to}`;m.has(y)||t.push({type:"removed",path:`feedback.${y}`})}for(let p of d){let y=`${p.from}->${p.to}`,w=f.find(k=>k.from===p.from&&k.to===p.to);w&&JSON.stringify(p)!==JSON.stringify(w)&&t.push({type:"changed",path:`feedback.${y}`,detail:`maxIterations: ${p.maxIterations??10} \u2192 ${w.maxIterations??10}`})}let l=t.filter(p=>p.type==="added").length,u=t.filter(p=>p.type==="removed").length,h=t.filter(p=>p.type==="changed").length,b=[];l&&b.push(`${l} added`),u&&b.push(`${u} removed`),h&&b.push(`${h} changed`);let v=b.length>0?b.join(", "):"no changes";return{entries:t,summary:v}}var sn=`You are a graph architect for GraphReFly, a reactive graph protocol.
17
+ `)}`);let a=l=>{let d=r.fns?.[l];return d?bn(d):void 0},c=l=>{let d=r.sources?.[l];return d?yn(d):void 0},u=new Map,f=[];for(let[l,d]of Object.entries(t.nodes)){if(d.type==="template")continue;let m=d;if(m.type==="state"){let b=ee(m.initial,{name:l,meta:m.meta?{...m.meta}:void 0});s.add(b,{name:l}),u.set(l,b)}else if(m.type==="producer"){let b=m.source?c(m.source):void 0,v=m.fn?a(m.fn):void 0;if(b){let h=b(m.config??{});s.add(h,{name:l}),u.set(l,h)}else if(v){let h=v([],m.config??{});s.add(h,{name:l}),u.set(l,h)}else{let h=Oe(()=>{},{name:l,meta:{...m.meta,_specFn:m.fn,_specSource:m.source}});s.add(h,{name:l}),u.set(l,h)}}else f.push([l,m])}let p=!0,g=new Map(f);for(;g.size>0&&p;){p=!1;for(let[l,d]of[...g.entries()]){let m=d.deps??[];if(!m.every(y=>u.has(y)))continue;let b=m.map(y=>u.get(y)),v=d.fn?a(d.fn):void 0,h;v?h=v(b,d.config??{}):d.type==="effect"?h=Le(b,()=>{}):h=ie(b,y=>y[0]),s.add(h,{name:l}),u.set(l,h),g.delete(l),p=!0}}if(g.size>0){let l=[...g.keys()].sort().join(", ");throw new Error(`compileSpec: unresolvable deps for nodes: ${l}`)}for(let[l,d]of Object.entries(t.nodes)){if(d.type!=="template")continue;let m=d,b=o[m.template],v=new be(l),h=new Map,y=[];for(let[_,x]of Object.entries(b.nodes)){let k=(x.deps??[]).map(N=>N.startsWith("$")&&m.bind[N]?m.bind[N]:N),D={...x,deps:k};if(x.type==="state"){let N=ee(x.initial,{name:_,meta:x.meta?{...x.meta}:void 0});v.add(N,{name:_}),h.set(_,N)}else if(x.type==="producer"){let N=x.source?c(x.source):void 0,E=x.fn?a(x.fn):void 0;if(N){let S=N(x.config??{});v.add(S,{name:_}),h.set(_,S)}else if(E){let S=E([],x.config??{});v.add(S,{name:_}),h.set(_,S)}else{let S=Oe(()=>{},{name:_,meta:{...x.meta,_specFn:x.fn,_specSource:x.source}});v.add(S,{name:_}),h.set(_,S)}}else y.push([_,D])}let w=!0,O=new Map(y);for(;O.size>0&&w;){w=!1;for(let[_,x]of[...O.entries()]){let k=x.deps??[];if(!k.every(A=>h.has(A)||u.has(A)))continue;let N=k.map(A=>h.get(A)??u.get(A)),E=x.fn?a(x.fn):void 0,S;E?S=E(N,x.config??{}):x.type==="effect"?S=Le(N,()=>{}):S=ie(N,A=>A[0]),v.add(S,{name:_}),h.set(_,S),O.delete(_),w=!0}}if(O.size>0){let _=[...O.keys()].sort().join(", ");throw new Error(`compileSpec: template "${m.template}" has unresolvable deps: ${_}`)}s.mount(l,v);let T=`${l}::${b.output}`;u.set(l,s.resolve(T));try{let _=s.resolve(T);_.meta._templateName?.emit(m.template),_.meta._templateBind?.emit(m.bind)}catch{}}for(let l of t.feedback??[])gn(s,l.from,l.to,{maxIterations:l.maxIterations});return s}var Hr=new Set(["reduction","reduction_type","_specFn","_specSource","_templateName","_templateBind","feedbackFrom","feedbackTo","_internal"]);function Vr(t){let e=t.describe({detail:"standard"}),n={},r=[],s=`::${z}::`,o=/^__feedback_(?!effect_)(.+)$/,i=new Set;for(let l of Object.keys(e.nodes)){if(l.includes(s))continue;let d=o.exec(l);if(d){i.add(d[1]);let m=e.nodes[l]?.meta;m?.feedbackFrom&&m?.feedbackTo&&r.push({from:m.feedbackFrom,to:m.feedbackTo,...m.maxIterations?{maxIterations:m.maxIterations}:{}})}}for(let[l,d]of Object.entries(e.nodes)){if(l.includes(s)||o.test(l)||d.meta?._internal||l.startsWith("__feedback_effect_")||l.startsWith("__bridge_")||l.includes("::"))continue;let m={type:d.type};if(d.deps.length>0&&(m.deps=d.deps.filter(b=>!b.includes("::"))),d.type==="state"&&d.value!==void 0&&(m.initial=d.value),d.meta&&Object.keys(d.meta).length>0){let b={};for(let[v,h]of Object.entries(d.meta))Hr.has(v)||(b[v]=h);Object.keys(b).length>0&&(m.meta=b)}n[l]=m}let a={},c={},u=new Set;for(let l of e.subgraphs){let d=`${l}::`;for(let[m,b]of Object.entries(e.nodes)){if(!m.startsWith(d)||m.includes(s))continue;let v=b.meta;if(v?._templateName&&v?._templateBind){let h=v._templateName,y=v._templateBind;if(!a[h]){let w={},O=new Set,T=`${l}::`;for(let[E,S]of Object.entries(e.nodes)){if(!E.startsWith(T)||E.includes(s))continue;let A=E.slice(T.length);A.includes("::")||(O.add(A),w[A]={type:S.type,...S.deps.length>0?{deps:S.deps.map(F=>F.startsWith(T)?F.slice(T.length):F)}:{}})}let _=[],x=new Map;for(let E of Object.values(w))for(let S of E.deps??[])if(!O.has(S)&&!x.has(S)){let A=`$${S}`;_.push(A),x.set(S,A)}for(let E of Object.values(w))E.deps&&(E.deps=E.deps.map(S=>x.get(S)??S));let k=new Set;for(let E of Object.values(w))for(let S of E.deps??[])O.has(S)&&k.add(S);let N=[...O].filter(E=>!k.has(E))[0]??[...O].pop();a[h]={params:_,nodes:w,output:N}}delete n[l],c[l]={type:"template",template:h,bind:y},u.add(l);break}}}let f=new Map;for(let l of e.subgraphs){if(u.has(l))continue;let d={},m=`${l}::`;for(let[v,h]of Object.entries(e.nodes)){if(v.includes(s)||!v.startsWith(m))continue;let y=v.slice(m.length);y.includes("::")||(d[y]={type:h.type,...h.deps.length>0?{deps:h.deps.map(w=>w.startsWith(m)?w.slice(m.length):w)}:{}})}let b=JSON.stringify(Object.fromEntries(Object.entries(d).sort(([v],[h])=>v.localeCompare(h)).map(([v,h])=>[v,{type:h.type,deps:h.deps??[]}])));f.has(b)||f.set(b,[]),f.get(b).push({name:l,nodes:d})}for(let[,l]of f){if(l.length<2)continue;let d=`${l[0].name}_template`,m=l[0].nodes,b=new Set(Object.keys(m)),v=[],h=new Map;for(let _ of Object.values(m))for(let x of _.deps??[])if(!b.has(x)&&!h.has(x)){let k=`$${x}`;v.push(k),h.set(x,k)}let y=new Set;for(let _ of Object.values(m))for(let x of _.deps??[])b.has(x)&&y.add(x);let O=[...b].filter(_=>!y.has(_))[0]??[...b].pop(),T={};for(let[_,x]of Object.entries(m))T[_]={...x,deps:x.deps?.map(k=>h.get(k)??k)};a[d]={params:v,nodes:T,output:O};for(let _ of l){delete n[_.name];let x={},k=new Set(Object.keys(_.nodes));for(let D of Object.values(_.nodes))for(let N of D.deps??[])if(!k.has(N)){let E=h.get(N)??`$${N}`;x[E]=N}c[_.name]={type:"template",template:d,bind:x}}}let p={...n,...c},g={name:e.name,nodes:p};return Object.keys(a).length>0&&(g.templates=a),r.length>0&&(g.feedback=r),g}function zr(t,e){let n=[];t.name!==e.name&&n.push({type:"changed",path:"name",detail:`"${t.name}" \u2192 "${e.name}"`});let r=new Set(Object.keys(t.nodes)),s=new Set(Object.keys(e.nodes));for(let h of s)if(!r.has(h)){let y=e.nodes[h];n.push({type:"added",path:`nodes.${h}`,detail:`type: ${y.type}`})}for(let h of r)s.has(h)||n.push({type:"removed",path:`nodes.${h}`});for(let h of r){if(!s.has(h))continue;let y=t.nodes[h],w=e.nodes[h];if(JSON.stringify(y)!==JSON.stringify(w)){let O=[];y.type!==w.type&&O.push(`type: ${y.type} \u2192 ${w.type}`),JSON.stringify(y.deps)!==JSON.stringify(w.deps)&&O.push("deps changed"),y.fn!==w.fn&&O.push(`fn: ${y.fn} \u2192 ${w.fn}`),JSON.stringify(y.config)!==JSON.stringify(w.config)&&O.push("config changed"),n.push({type:"changed",path:`nodes.${h}`,detail:O.join("; ")||"modified"})}}let o=t.templates??{},i=e.templates??{},a=new Set(Object.keys(o)),c=new Set(Object.keys(i));for(let h of c)a.has(h)||n.push({type:"added",path:`templates.${h}`});for(let h of a)c.has(h)||n.push({type:"removed",path:`templates.${h}`});for(let h of a)c.has(h)&&JSON.stringify(o[h])!==JSON.stringify(i[h])&&n.push({type:"changed",path:`templates.${h}`,detail:"template definition changed"});let u=t.feedback??[],f=e.feedback??[],p=new Set(u.map(h=>`${h.from}->${h.to}`)),g=new Set(f.map(h=>`${h.from}->${h.to}`));for(let h of f){let y=`${h.from}->${h.to}`;p.has(y)||n.push({type:"added",path:`feedback.${y}`,detail:`maxIterations: ${h.maxIterations??10}`})}for(let h of u){let y=`${h.from}->${h.to}`;g.has(y)||n.push({type:"removed",path:`feedback.${y}`})}for(let h of u){let y=`${h.from}->${h.to}`,w=f.find(O=>O.from===h.from&&O.to===h.to);w&&JSON.stringify(h)!==JSON.stringify(w)&&n.push({type:"changed",path:`feedback.${y}`,detail:`maxIterations: ${h.maxIterations??10} \u2192 ${w.maxIterations??10}`})}let l=n.filter(h=>h.type==="added").length,d=n.filter(h=>h.type==="removed").length,m=n.filter(h=>h.type==="changed").length,b=[];l&&b.push(`${l} added`),d&&b.push(`${d} removed`),m&&b.push(`${m} changed`);let v=b.length>0?b.join(", "):"no changes";return{entries:n,summary:v}}var wn=`You are a graph architect for GraphReFly, a reactive graph protocol.
17
18
 
18
19
  Given a natural-language description, produce a JSON GraphSpec with this structure:
19
20
 
@@ -55,29 +56,29 @@ Rules:
55
56
  - Use "templates" when the same subgraph pattern repeats (e.g., per-source resilience).
56
57
  - Use "feedback" for bounded cycles where a derived value writes back to a state node.
57
58
  - meta.description is required for every node.
58
- - Return ONLY valid JSON, no markdown fences or commentary.`;function on(r){let e=r.match(/^```(?:json)?\s*([\s\S]*?)\s*```[\s\S]*$/);return e?e[1]:r}async function ar(r,e,t){let n=sn,s=t?.catalogDescription??(t?.catalog?rn(t.catalog):void 0);s&&(n+=`
59
+ - Return ONLY valid JSON, no markdown fences or commentary.`;function _n(t){let e=t.match(/^```(?:json)?\s*([\s\S]*?)\s*```[\s\S]*$/);return e?e[1]:t}async function Wr(t,e,n){let r=wn,s=n?.catalogDescription??(n?.catalog?vn(n.catalog):void 0);s&&(r+=`
59
60
 
60
61
  Available catalog (use ONLY these names):
61
- ${s}`),t?.systemPromptExtra&&(n+=`
62
+ ${s}`),n?.systemPromptExtra&&(r+=`
62
63
 
63
- ${t.systemPromptExtra}`);let o=[{role:"system",content:n},{role:"user",content:r}],c=(await e.invoke(o,{model:t?.model,temperature:t?.temperature??0,maxTokens:t?.maxTokens})).content.trim();c.startsWith("```")&&(c=on(c));let d;try{d=JSON.parse(c)}catch{throw new Error(`llmCompose: LLM response is not valid JSON: ${c.slice(0,200)}`)}let f=ze(d);if(!f.valid)throw new Error(`llmCompose: invalid GraphSpec:
64
+ ${n.systemPromptExtra}`);let o=[{role:"system",content:r},{role:"user",content:t}],c=(await e.invoke(o,{model:n?.model,temperature:n?.temperature??0,maxTokens:n?.maxTokens})).content.trim();c.startsWith("```")&&(c=_n(c));let u;try{u=JSON.parse(c)}catch{throw new Error(`llmCompose: LLM response is not valid JSON: ${c.slice(0,200)}`)}let f=qe(u);if(!f.valid)throw new Error(`llmCompose: invalid GraphSpec:
64
65
  ${f.errors.join(`
65
- `)}`);let g=d;if(t?.catalog){let m=t.maxAutoRefine??0;for(let l=0;l<=m;l++){let u=mt(g,t.catalog);if(u.valid)break;if(l===m)throw new Error(`llmCompose: catalog validation failed after ${m} refine attempts:
66
- ${u.errors.join(`
67
- `)}`);g=await an(g,`Fix these catalog errors:
68
- ${u.errors.join(`
66
+ `)}`);let p=u;if(n?.catalog){let g=n.maxAutoRefine??0;for(let l=0;l<=g;l++){let d=_t(p,n.catalog);if(d.valid)break;if(l===g)throw new Error(`llmCompose: catalog validation failed after ${g} refine attempts:
67
+ ${d.errors.join(`
68
+ `)}`);p=await xn(p,`Fix these catalog errors:
69
+ ${d.errors.join(`
69
70
  `)}
70
71
 
71
- Use ONLY functions and sources from the catalog.`,e,{...t,catalogDescription:s})}}return g}async function an(r,e,t,n){let s=sn;n?.catalogDescription&&(s+=`
72
+ Use ONLY functions and sources from the catalog.`,e,{...n,catalogDescription:s})}}return p}async function xn(t,e,n,r){let s=wn;r?.catalogDescription&&(s+=`
72
73
 
73
74
  Available catalog:
74
- ${n.catalogDescription}`),n?.systemPromptExtra&&(s+=`
75
+ ${r.catalogDescription}`),r?.systemPromptExtra&&(s+=`
75
76
 
76
- ${n.systemPromptExtra}`);let o=[{role:"system",content:s},{role:"user",content:`Current GraphSpec:
77
- ${JSON.stringify(r,null,2)}
77
+ ${r.systemPromptExtra}`);let o=[{role:"system",content:s},{role:"user",content:`Current GraphSpec:
78
+ ${JSON.stringify(t,null,2)}
78
79
 
79
80
  Modification request: ${e}
80
81
 
81
- Return the complete modified GraphSpec as JSON.`}],c=(await t.invoke(o,{model:n?.model,temperature:n?.temperature??0,maxTokens:n?.maxTokens})).content.trim();c.startsWith("```")&&(c=on(c));let d;try{d=JSON.parse(c)}catch{throw new Error(`llmRefine: LLM response is not valid JSON: ${c.slice(0,200)}`)}let f=ze(d);if(!f.valid)throw new Error(`llmRefine: invalid GraphSpec:
82
+ Return the complete modified GraphSpec as JSON.`}],c=(await n.invoke(o,{model:r?.model,temperature:r?.temperature??0,maxTokens:r?.maxTokens})).content.trim();c.startsWith("```")&&(c=_n(c));let u;try{u=JSON.parse(c)}catch{throw new Error(`llmRefine: LLM response is not valid JSON: ${c.slice(0,200)}`)}let f=qe(u);if(!f.valid)throw new Error(`llmRefine: invalid GraphSpec:
82
83
  ${f.errors.join(`
83
- `)}`);return d}0&&(module.exports={compileSpec,decompileGraph,extractFnFactory,extractSourceFactory,generateCatalogPrompt,isRichFnEntry,isRichSourceEntry,llmCompose,llmRefine,specDiff,validateSpec,validateSpecAgainstCatalog});
84
+ `)}`);return u}0&&(module.exports={compileSpec,decompileGraph,extractFnFactory,extractSourceFactory,generateCatalogPrompt,isRichFnEntry,isRichSourceEntry,llmCompose,llmRefine,specDiff,validateSpec,validateSpecAgainstCatalog});