@graphrefly/graphrefly 0.42.0 → 0.44.0

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (284) hide show
  1. package/dist/{cascading-CH-_VwG9.d.cts → cascading-BglDkMdX.d.cts} +2 -2
  2. package/dist/{cascading-OgKQZjsa.d.ts → cascading-MFgxu7Yo.d.ts} +2 -2
  3. package/dist/chunk-2T7U5EU6.js +1 -0
  4. package/dist/chunk-5M4CCMMD.js +45 -0
  5. package/dist/{chunk-YGL7FPVQ.js → chunk-5XJ6B66J.js} +1 -1
  6. package/dist/{chunk-NWXQIOIB.js → chunk-6X7AFUJV.js} +1 -1
  7. package/dist/chunk-7K6PWTDQ.js +1 -0
  8. package/dist/{chunk-D27JNOLZ.js → chunk-7LIAPXJB.js} +1 -1
  9. package/dist/{chunk-CLD3F4R5.js → chunk-7WPU3UHQ.js} +1 -1
  10. package/dist/{chunk-NNKJUORL.js → chunk-A5WCQ5NO.js} +1 -1
  11. package/dist/chunk-APPIWSGD.js +84 -0
  12. package/dist/{chunk-TZQPPQEQ.js → chunk-BEZWM2SY.js} +1 -1
  13. package/dist/{chunk-5QRRKBUT.js → chunk-CB676TKJ.js} +1 -1
  14. package/dist/{chunk-KT5DTRBP.js → chunk-CE6TI2TL.js} +1 -1
  15. package/dist/{chunk-6YFZMUMR.js → chunk-CLVB32RD.js} +1 -1
  16. package/dist/{chunk-2K5RXLAH.js → chunk-CRVT7D2P.js} +1 -1
  17. package/dist/chunk-D7GPHKFH.js +1 -0
  18. package/dist/{chunk-FUZ6S2DY.js → chunk-DHRX7JX4.js} +1 -1
  19. package/dist/chunk-FZMYDOWV.js +1 -0
  20. package/dist/{chunk-35JTVPOX.js → chunk-GHBWHMRZ.js} +1 -1
  21. package/dist/{chunk-KGKJCHEK.js → chunk-GLERH466.js} +1 -1
  22. package/dist/{chunk-CISGGAIF.js → chunk-HIDYF36O.js} +1 -1
  23. package/dist/chunk-HITNVN6B.js +3 -0
  24. package/dist/{chunk-7ARY3Y3T.js → chunk-HY4DJBA7.js} +1 -1
  25. package/dist/chunk-KZIEYVXN.js +1 -0
  26. package/dist/{chunk-IZM3UEH3.js → chunk-N4MQX6JU.js} +1 -1
  27. package/dist/{chunk-FDZAZNRO.js → chunk-N7FHEL4D.js} +1 -1
  28. package/dist/chunk-NTEURFZH.js +1 -0
  29. package/dist/{chunk-4QH6VJF4.js → chunk-OIVP6KFV.js} +1 -1
  30. package/dist/{chunk-KCACBSJH.js → chunk-OPHBU3LG.js} +1 -1
  31. package/dist/{chunk-Q7QQQA3I.js → chunk-OYQOZP2F.js} +1 -1
  32. package/dist/{chunk-7B7ELAT2.js → chunk-PTZK576G.js} +1 -1
  33. package/dist/{chunk-DEJTNNQC.js → chunk-ST7UXLWR.js} +1 -1
  34. package/dist/chunk-SVY7VUYU.js +1 -0
  35. package/dist/{chunk-WHMUB5QB.js → chunk-TK3NWWD4.js} +1 -1
  36. package/dist/chunk-UNGSTR4X.js +61 -0
  37. package/dist/{chunk-VRALOYRD.js → chunk-VV4N5P64.js} +1 -1
  38. package/dist/chunk-W3I423PS.js +1 -0
  39. package/dist/{chunk-HZKW2AAB.js → chunk-WJR24TAG.js} +1 -1
  40. package/dist/{chunk-F3IGTWCQ.js → chunk-XTGKMHSW.js} +1 -1
  41. package/dist/{chunk-LDQ3IUIP.js → chunk-YBB7ZGTY.js} +1 -1
  42. package/dist/{chunk-G5VBJ5K6.js → chunk-Z4NPUARF.js} +1 -1
  43. package/dist/{chunk-KRH66M4O.js → chunk-ZGNQRPDT.js} +1 -1
  44. package/dist/{chunk-AGNM6RS6.js → chunk-ZKPSFFKU.js} +1 -1
  45. package/dist/{chunk-KY2LMAXU.js → chunk-ZLV5SQSX.js} +1 -1
  46. package/dist/compat/index.cjs +5 -5
  47. package/dist/compat/index.d.cts +16 -16
  48. package/dist/compat/index.d.ts +16 -16
  49. package/dist/compat/index.js +1 -1
  50. package/dist/compat/jotai/index.cjs +1 -1
  51. package/dist/compat/jotai/index.d.cts +2 -2
  52. package/dist/compat/jotai/index.d.ts +2 -2
  53. package/dist/compat/jotai/index.js +1 -1
  54. package/dist/compat/nanostores/index.cjs +1 -1
  55. package/dist/compat/nanostores/index.d.cts +2 -2
  56. package/dist/compat/nanostores/index.d.ts +2 -2
  57. package/dist/compat/nanostores/index.js +1 -1
  58. package/dist/compat/nestjs/index.cjs +5 -5
  59. package/dist/compat/nestjs/index.d.cts +8 -8
  60. package/dist/compat/nestjs/index.d.ts +8 -8
  61. package/dist/compat/nestjs/index.js +1 -1
  62. package/dist/compat/react/index.d.cts +2 -2
  63. package/dist/compat/react/index.d.ts +2 -2
  64. package/dist/compat/solid/index.d.cts +2 -2
  65. package/dist/compat/solid/index.d.ts +2 -2
  66. package/dist/compat/svelte/index.d.cts +2 -2
  67. package/dist/compat/svelte/index.d.ts +2 -2
  68. package/dist/compat/vue/index.d.cts +2 -2
  69. package/dist/compat/vue/index.d.ts +2 -2
  70. package/dist/compat/zustand/index.cjs +3 -3
  71. package/dist/compat/zustand/index.d.cts +4 -4
  72. package/dist/compat/zustand/index.d.ts +4 -4
  73. package/dist/compat/zustand/index.js +1 -1
  74. package/dist/core/index.cjs +1 -1
  75. package/dist/core/index.d.cts +3 -4
  76. package/dist/core/index.d.ts +3 -4
  77. package/dist/core/index.js +1 -1
  78. package/dist/{decay-CdEBmDIs.d.ts → decay-BvOWTZ00.d.ts} +2 -2
  79. package/dist/{decay-2ZukgQ4o.d.cts → decay-CFlLvXUT.d.cts} +2 -2
  80. package/dist/extra/browser.cjs +1 -1
  81. package/dist/extra/browser.d.cts +1 -1
  82. package/dist/extra/browser.d.ts +1 -1
  83. package/dist/extra/browser.js +1 -1
  84. package/dist/extra/index.cjs +15 -15
  85. package/dist/extra/index.d.cts +10 -10
  86. package/dist/extra/index.d.ts +10 -10
  87. package/dist/extra/index.js +1 -1
  88. package/dist/extra/node.cjs +2 -2
  89. package/dist/extra/node.d.cts +1 -1
  90. package/dist/extra/node.d.ts +1 -1
  91. package/dist/extra/node.js +1 -1
  92. package/dist/extra/operators.cjs +1 -1
  93. package/dist/extra/operators.d.cts +9 -1
  94. package/dist/extra/operators.d.ts +9 -1
  95. package/dist/extra/operators.js +1 -1
  96. package/dist/extra/reactive.cjs +1 -1
  97. package/dist/extra/reactive.d.cts +3 -3
  98. package/dist/extra/reactive.d.ts +3 -3
  99. package/dist/extra/reactive.js +1 -1
  100. package/dist/extra/render/index.d.cts +3 -3
  101. package/dist/extra/render/index.d.ts +3 -3
  102. package/dist/extra/sources.cjs +3 -3
  103. package/dist/extra/sources.d.cts +1 -1
  104. package/dist/extra/sources.d.ts +1 -1
  105. package/dist/extra/sources.js +1 -1
  106. package/dist/extra/storage-browser.cjs +1 -1
  107. package/dist/extra/storage-browser.d.cts +1 -1
  108. package/dist/extra/storage-browser.d.ts +1 -1
  109. package/dist/extra/storage-browser.js +1 -1
  110. package/dist/{fallback-Ctlj2tMY.d.cts → fallback-74oxi34l.d.cts} +1 -1
  111. package/dist/{fallback-CqYVLL6X.d.ts → fallback-DUyyBTBK.d.ts} +1 -1
  112. package/dist/graph/index.cjs +7 -7
  113. package/dist/graph/index.d.cts +5 -5
  114. package/dist/graph/index.d.ts +5 -5
  115. package/dist/graph/index.js +1 -1
  116. package/dist/{graph-C4SHb3Ly.d.cts → graph-CWvEUQAq.d.cts} +196 -3
  117. package/dist/{graph-7VguS7a4.d.ts → graph-D9LFnda9.d.ts} +196 -3
  118. package/dist/{index-LIpQQE9f.d.cts → index-5k1T6jl0.d.cts} +9 -9
  119. package/dist/{index-CPNSy-U0.d.cts → index-9770hRuQ.d.cts} +23 -4
  120. package/dist/{index-CEMx8n40.d.cts → index-B-_tFaqV.d.cts} +4 -4
  121. package/dist/{index-2B7u2pVn.d.cts → index-B17QddL1.d.cts} +4 -4
  122. package/dist/{index-B-i4_g3k.d.ts → index-B1F8Enjf.d.ts} +61 -8
  123. package/dist/{index-DBevwHj_.d.ts → index-B5S8ULbU.d.ts} +3 -3
  124. package/dist/{index-Dgs8zcj7.d.ts → index-B8YnZpIR.d.ts} +2 -2
  125. package/dist/{index-B3OTH1dV.d.ts → index-BHskSB8v.d.ts} +28 -17
  126. package/dist/{index-sl4NyzQx.d.cts → index-BIYAkbAi.d.cts} +1 -1
  127. package/dist/{index-C9kSENB4.d.cts → index-BQSKmbuG.d.cts} +1 -1
  128. package/dist/{index-tJoTcnHh.d.cts → index-BaQaY_IQ.d.cts} +2 -2
  129. package/dist/{index-CJK1JkYy.d.ts → index-BmZXHqkE.d.ts} +1 -1
  130. package/dist/{index-pT8sCpOJ.d.ts → index-BoJ5JHxI.d.ts} +12 -3
  131. package/dist/{index-BeT2r7sk.d.ts → index-BocU7pqs.d.ts} +23 -4
  132. package/dist/{index-ChOyVLKm.d.cts → index-BrPrLl4e.d.cts} +1 -1
  133. package/dist/{index-D-Xs74HZ.d.cts → index-BxNs2HB9.d.cts} +33 -9
  134. package/dist/{index-Bf7eqeSF.d.ts → index-Byu-OpX_.d.ts} +2 -2
  135. package/dist/{index-BoLv_OfD.d.cts → index-C1T3d7V-.d.cts} +61 -8
  136. package/dist/{index-BTQtTb_H.d.cts → index-C5ri2Axc.d.cts} +3 -3
  137. package/dist/{index-z96luz5O.d.cts → index-C5stwKcw.d.cts} +1 -1
  138. package/dist/{index-CZmcDtFn.d.ts → index-C9l6OEBL.d.ts} +1 -1
  139. package/dist/{index-CCq87F7t.d.ts → index-CBBLl_rc.d.ts} +1 -1
  140. package/dist/{index-D6egPFAL.d.ts → index-CBGUK09R.d.ts} +4 -4
  141. package/dist/{index-C0-Jv1kP.d.cts → index-CC-AvFTy.d.cts} +12 -3
  142. package/dist/{index-DQo8xBgd.d.ts → index-CJF1URuX.d.ts} +9 -9
  143. package/dist/{index-BJX94aud.d.cts → index-CK29LV56.d.cts} +1 -1
  144. package/dist/{index-BP8a88zx.d.ts → index-CMh5Rz1y.d.ts} +4 -4
  145. package/dist/{index-CvrqGfNS.d.ts → index-CPQlGA29.d.ts} +1 -1
  146. package/dist/{index-Bbkgpt5t.d.ts → index-CR8QpwX8.d.ts} +49 -24
  147. package/dist/{index-Du7u1lSf.d.cts → index-CS0LTlB8.d.cts} +4 -4
  148. package/dist/{index-Bc41FuHp.d.cts → index-CSOmP7xT.d.cts} +2 -2
  149. package/dist/{index-BsT7F2et.d.ts → index-CYq8vAyV.d.ts} +2 -2
  150. package/dist/{index-Bn4zHYLj.d.ts → index-CZ3r5Rxp.d.ts} +4 -4
  151. package/dist/{index-HoU88d5U.d.cts → index-CasX6Pfq.d.cts} +68 -9
  152. package/dist/{index-BG0BN3PB.d.ts → index-CdAlHFEt.d.ts} +1 -1
  153. package/dist/{index-CpyNFqkB.d.ts → index-CdTelp1M.d.ts} +8 -4
  154. package/dist/{index-D8l8hNXn.d.ts → index-CeFiHtAg.d.ts} +4 -4
  155. package/dist/{index-DmAgG5CI.d.cts → index-Cj3WohTd.d.cts} +8 -4
  156. package/dist/{index-BtAsBp8K.d.cts → index-Climxqsu.d.cts} +4 -4
  157. package/dist/{index-CJIuLu2f.d.cts → index-Co7uli2l.d.cts} +28 -17
  158. package/dist/{index-DIOoAZUX.d.ts → index-CviRnE4K.d.ts} +1 -1
  159. package/dist/{index-Dhc7a7Xo.d.cts → index-Cwv0KWcU.d.cts} +2 -2
  160. package/dist/{index-Dn-wI9g4.d.ts → index-CzLVrjxn.d.ts} +2 -2
  161. package/dist/{index-DO9XxMzS.d.ts → index-D0aciIex.d.cts} +3 -18
  162. package/dist/{index-4Uz-e_fL.d.ts → index-DHen9Klo.d.ts} +33 -9
  163. package/dist/{index-3NmAfcH0.d.cts → index-DV_1YuVk.d.cts} +40 -8
  164. package/dist/{index-BdGtBX-X.d.cts → index-Dc4AYqrJ.d.cts} +3 -3
  165. package/dist/{index-Dmqp7KjD.d.ts → index-Dgl1HpPn.d.ts} +1 -1
  166. package/dist/{index-CJQm0g38.d.ts → index-DisjX8a-.d.ts} +40 -8
  167. package/dist/{index-B11anra4.d.cts → index-UPSiS-X7.d.cts} +49 -24
  168. package/dist/{index-DBIqYS43.d.cts → index-Yq60JP3s.d.ts} +3 -18
  169. package/dist/{index-f5IivDUX.d.cts → index-ZVQhLa2i.d.cts} +1 -1
  170. package/dist/{index-hHcaFlJX.d.cts → index-_6ODbuOu.d.cts} +1 -1
  171. package/dist/{index-BVpm6noz.d.cts → index-hcDJ8PSI.d.cts} +1 -1
  172. package/dist/{index-DBHK8O6H.d.ts → index-nozs3fFC.d.ts} +3 -3
  173. package/dist/{index-BUYXac2c.d.ts → index-p09KSrTN.d.ts} +68 -9
  174. package/dist/{index-C7O6r5fV.d.ts → index-sqkqlb1p.d.ts} +1 -1
  175. package/dist/{index-CZjOhcBy.d.cts → index-tRCxuAXF.d.cts} +2 -2
  176. package/dist/index.cjs +48 -48
  177. package/dist/index.d.cts +42 -43
  178. package/dist/index.d.ts +42 -43
  179. package/dist/index.js +1 -1
  180. package/dist/{node-ClS5yC-B.d.cts → node-kK3CvTrR.d.cts} +1 -1
  181. package/dist/{node-ClS5yC-B.d.ts → node-kK3CvTrR.d.ts} +1 -1
  182. package/dist/{observable-BsBzUrcI.d.ts → observable-DWjNfLvC.d.ts} +1 -1
  183. package/dist/{observable-DLGPPtb8.d.cts → observable-e3eiPPFy.d.cts} +1 -1
  184. package/dist/patterns/ai/browser.cjs +5 -5
  185. package/dist/patterns/ai/browser.d.cts +4 -4
  186. package/dist/patterns/ai/browser.d.ts +4 -4
  187. package/dist/patterns/ai/browser.js +1 -1
  188. package/dist/patterns/ai/index.cjs +16 -16
  189. package/dist/patterns/ai/index.d.cts +16 -17
  190. package/dist/patterns/ai/index.d.ts +16 -17
  191. package/dist/patterns/ai/index.js +1 -1
  192. package/dist/patterns/ai/node.cjs +1 -1
  193. package/dist/patterns/ai/node.d.cts +4 -4
  194. package/dist/patterns/ai/node.d.ts +4 -4
  195. package/dist/patterns/ai/node.js +1 -1
  196. package/dist/patterns/cqrs/index.cjs +3 -3
  197. package/dist/patterns/cqrs/index.d.cts +6 -6
  198. package/dist/patterns/cqrs/index.d.ts +6 -6
  199. package/dist/patterns/cqrs/index.js +1 -1
  200. package/dist/patterns/demo-shell/index.cjs +5 -5
  201. package/dist/patterns/demo-shell/index.d.cts +5 -5
  202. package/dist/patterns/demo-shell/index.d.ts +5 -5
  203. package/dist/patterns/demo-shell/index.js +1 -1
  204. package/dist/patterns/domain-templates/index.cjs +3 -3
  205. package/dist/patterns/domain-templates/index.d.cts +4 -4
  206. package/dist/patterns/domain-templates/index.d.ts +4 -4
  207. package/dist/patterns/domain-templates/index.js +1 -1
  208. package/dist/patterns/graphspec/index.cjs +16 -16
  209. package/dist/patterns/graphspec/index.d.cts +5 -5
  210. package/dist/patterns/graphspec/index.d.ts +5 -5
  211. package/dist/patterns/graphspec/index.js +1 -1
  212. package/dist/patterns/harness/index.cjs +9 -9
  213. package/dist/patterns/harness/index.d.cts +10 -11
  214. package/dist/patterns/harness/index.d.ts +10 -11
  215. package/dist/patterns/harness/index.js +1 -1
  216. package/dist/patterns/inspect/index.cjs +3 -3
  217. package/dist/patterns/inspect/index.d.cts +7 -7
  218. package/dist/patterns/inspect/index.d.ts +7 -7
  219. package/dist/patterns/inspect/index.js +1 -1
  220. package/dist/patterns/job-queue/index.cjs +3 -3
  221. package/dist/patterns/job-queue/index.d.cts +6 -6
  222. package/dist/patterns/job-queue/index.d.ts +6 -6
  223. package/dist/patterns/job-queue/index.js +1 -1
  224. package/dist/patterns/memory/index.cjs +3 -3
  225. package/dist/patterns/memory/index.d.cts +6 -6
  226. package/dist/patterns/memory/index.d.ts +6 -6
  227. package/dist/patterns/memory/index.js +1 -1
  228. package/dist/patterns/messaging/index.cjs +3 -3
  229. package/dist/patterns/messaging/index.d.cts +5 -5
  230. package/dist/patterns/messaging/index.d.ts +5 -5
  231. package/dist/patterns/messaging/index.js +1 -1
  232. package/dist/patterns/orchestration/index.cjs +3 -3
  233. package/dist/patterns/orchestration/index.d.cts +6 -7
  234. package/dist/patterns/orchestration/index.d.ts +6 -7
  235. package/dist/patterns/orchestration/index.js +1 -1
  236. package/dist/patterns/process/index.cjs +3 -1
  237. package/dist/patterns/process/index.d.cts +7 -7
  238. package/dist/patterns/process/index.d.ts +7 -7
  239. package/dist/patterns/process/index.js +1 -1
  240. package/dist/patterns/reactive-layout/index.cjs +4 -4
  241. package/dist/patterns/reactive-layout/index.d.cts +5 -5
  242. package/dist/patterns/reactive-layout/index.d.ts +5 -5
  243. package/dist/patterns/reactive-layout/index.js +1 -1
  244. package/dist/patterns/reduction/index.cjs +3 -3
  245. package/dist/patterns/reduction/index.d.cts +4 -4
  246. package/dist/patterns/reduction/index.d.ts +4 -4
  247. package/dist/patterns/reduction/index.js +1 -1
  248. package/dist/patterns/surface/index.cjs +10 -10
  249. package/dist/patterns/surface/index.d.cts +6 -6
  250. package/dist/patterns/surface/index.d.ts +6 -6
  251. package/dist/patterns/surface/index.js +1 -1
  252. package/dist/{pipeline-graph-WBlobVhU.d.cts → pipeline-graph-CIKhynsF.d.cts} +11 -6
  253. package/dist/{pipeline-graph-v8fMvqNk.d.ts → pipeline-graph-Sgj0gCwn.d.ts} +11 -6
  254. package/dist/{reactive-layout-v7KPvxoc.d.ts → reactive-layout-DOTs9P3X.d.ts} +2 -2
  255. package/dist/{reactive-layout-Dsvob4zD.d.cts → reactive-layout-DgctbqZo.d.cts} +2 -2
  256. package/dist/{reactive-log-BezYsbA_.d.ts → reactive-log-BKALbfal.d.ts} +1 -1
  257. package/dist/{reactive-log-B00laMSQ.d.cts → reactive-log-DIGdYqQ6.d.cts} +1 -1
  258. package/dist/{reactive-map-48mnZ-nu.d.cts → reactive-map-CEFGp8TK.d.cts} +1 -1
  259. package/dist/{reactive-map-BVVPdvmi.d.ts → reactive-map-DS_SIAxv.d.ts} +1 -1
  260. package/dist/resilience-6LYQJAC5.js +1 -0
  261. package/dist/sugar-DQjFmVqb.d.cts +399 -0
  262. package/dist/sugar-fhLIE7TT.d.ts +399 -0
  263. package/dist/{topology-tree-BSdfSwMi.d.cts → topology-tree-Bcz27hpF.d.cts} +1 -1
  264. package/dist/{topology-tree-BNGvuG82.d.ts → topology-tree-xvaD0fOX.d.ts} +1 -1
  265. package/dist/{types-B1jDWVsM.d.cts → types-C0_yquda.d.cts} +1 -1
  266. package/dist/{types-DkzUUs0H.d.ts → types-CWFysE9E.d.ts} +1 -1
  267. package/package.json +1 -1
  268. package/dist/chunk-3ERTUW2J.js +0 -45
  269. package/dist/chunk-3K7HA4Y6.js +0 -1
  270. package/dist/chunk-3ZZX7M25.js +0 -1
  271. package/dist/chunk-4I45FVQS.js +0 -1
  272. package/dist/chunk-5ST42ESJ.js +0 -1
  273. package/dist/chunk-7VKFXLZQ.js +0 -84
  274. package/dist/chunk-ACMJ2ZPS.js +0 -3
  275. package/dist/chunk-AS3TV2TV.js +0 -1
  276. package/dist/chunk-LPRWATHB.js +0 -61
  277. package/dist/chunk-LYCLF26R.js +0 -1
  278. package/dist/chunk-VE5SIZEM.js +0 -1
  279. package/dist/chunk-XLQPNNIC.js +0 -1
  280. package/dist/meta-BgVAsg9j.d.ts +0 -102
  281. package/dist/meta-vE8bxW1E.d.cts +0 -102
  282. package/dist/resilience-445VFFXQ.js +0 -1
  283. package/dist/sugar-CH-2ZY90.d.ts +0 -203
  284. package/dist/sugar-DStZfUEK.d.cts +0 -203
@@ -1,3 +1,3 @@
1
- "use strict";var ot=Object.defineProperty;var Ln=Object.getOwnPropertyDescriptor;var $n=Object.getOwnPropertyNames;var Fn=Object.prototype.hasOwnProperty;var L=(r,e)=>()=>(r&&(e=r(r=0)),e);var Vn=(r,e)=>{for(var t in e)ot(r,t,{get:e[t],enumerable:!0})},zn=(r,e,t,n)=>{if(e&&typeof e=="object"||typeof e=="function")for(let s of $n(e))!Fn.call(r,s)&&s!==t&&ot(r,s,{get:()=>e[s],enumerable:!(n=Ln(e,s))||n.enumerable});return r};var jn=r=>zn(ot({},"__esModule",{value:!0}),r);function K(){return Math.trunc(performance.now()*1e6)}function ae(){return Date.now()*1e6}var le=L(()=>{"use strict"});function Le(r){if(r==null)return we;let{type:e,id:t,...n}=r;return{type:e??"system",id:t??"",...n}}var we,$e=L(()=>{"use strict";we={type:"system",id:""}});function Se(){return Te>0||Re}function It(){return Te>0}function ke(r){Te>0?Ae.push(r):r()}function q(r){Te+=1;let e=!1;try{r()}catch(t){throw e=!0,t}finally{if(Te-=1,Te===0)if(e){if(!Re){let t=Ae.splice(0);for(let n of t)try{n()}catch{}fe.length=0,pe.length=0,xe.length=0}}else Bn()}}function Bn(){let r=!Re;r&&(Re=!0);let e=[],t=0;try{for(;fe.length>0||pe.length>0||xe.length>0||r&&Ae.length>0;){if(r&&Ae.length>0){let o=Ae.splice(0);for(let i of o)try{i()}catch(a){e.push(a)}continue}if(t+=1,t>1e3)throw fe.length=0,pe.length=0,xe.length=0,new Error("batch drain exceeded 1000 iterations \u2014 likely a reactive cycle");let s=(fe.length>0?fe:pe.length>0?pe:xe).splice(0);for(let o of s)try{o()}catch(i){e.push(i)}}}finally{r&&(Re=!1)}if(e.length===1)throw e[0];if(e.length>1)throw new AggregateError(e,"batch drain: multiple callbacks threw")}function Me(r,e,t){if(e.length===0)return;if(e.length===1){let d=t(e[0][0]);if(d<3||!Se()){r(e);return}(d>=5?xe:d===4?pe:fe).push(()=>r(e));return}let n=e.length,s=n,o=n,i=n,a=0;for(;a<n&&t(e[a][0])<3;)a++;for(s=a;a<n&&t(e[a][0])===3;)a++;for(o=a;a<n&&t(e[a][0])===4;)a++;i=a;let u=Se();if(s>0){let d=e.slice(0,s);r(d)}if(o>s){let d=e.slice(s,o);u?fe.push(()=>r(d)):r(d)}if(i>o){let d=e.slice(o,i);u?pe.push(()=>r(d)):r(d)}if(n>i){let d=e.slice(i,n);u?xe.push(()=>r(d)):r(d)}}var Te,Re,fe,pe,xe,Ae,he=L(()=>{"use strict";Te=0,Re=!1,fe=[],pe=[],xe=[],Ae=[]});var ge,D,$,W,Y,ee,re,j,z,C,me,Fe,Lt,Ve,$t,Ft,ze,it,at,dt,je,te=L(()=>{"use strict";ge=Symbol.for("graphrefly/START"),D=Symbol.for("graphrefly/DATA"),$=Symbol.for("graphrefly/DIRTY"),W=Symbol.for("graphrefly/RESOLVED"),Y=Symbol.for("graphrefly/INVALIDATE"),ee=Symbol.for("graphrefly/PAUSE"),re=Symbol.for("graphrefly/RESUME"),j=Symbol.for("graphrefly/TEARDOWN"),z=Symbol.for("graphrefly/COMPLETE"),C=Symbol.for("graphrefly/ERROR"),me=Object.freeze([$]),Fe=Object.freeze([W]),Lt=Object.freeze([Y]),Ve=Object.freeze([ge]),$t=Object.freeze([z]),Ft=Object.freeze([j]),ze=Object.freeze([me]),it=Object.freeze([Fe]),at=Object.freeze([Lt]),dt=Object.freeze([$t]),je=Object.freeze([Ft])});function Vt(r){r.registerMessageType(ge,{tier:0,wireCrossing:!1}),r.registerMessageType($,{tier:1,wireCrossing:!1}),r.registerMessageType(Y,{tier:1,wireCrossing:!1,metaPassthrough:!1}),r.registerMessageType(ee,{tier:2,wireCrossing:!1}),r.registerMessageType(re,{tier:2,wireCrossing:!1}),r.registerMessageType(D,{tier:3,wireCrossing:!0}),r.registerMessageType(W,{tier:3,wireCrossing:!0}),r.registerMessageType(z,{tier:4,wireCrossing:!0,metaPassthrough:!1}),r.registerMessageType(C,{tier:4,wireCrossing:!0,metaPassthrough:!1}),r.registerMessageType(j,{tier:5,wireCrossing:!0,metaPassthrough:!1})}var Be,zt=L(()=>{"use strict";te();Be=class{_messageTypes=new Map;_codecs=new Map;_onMessage;_onSubscribe;_defaultVersioning;_defaultHashFn;_inspectorEnabled=!(typeof process<"u"&&process.env?.NODE_ENV==="production");_globalInspector;_rigorRecorder;_frozen=!1;tierOf;constructor(e){this._onMessage=e.onMessage,this._onSubscribe=e.onSubscribe,this._defaultVersioning=e.defaultVersioning,this._defaultHashFn=e.defaultHashFn,this.tierOf=t=>{let n=this._messageTypes.get(t);return n!=null?n.tier:1}}get onMessage(){return this._frozen=!0,this._onMessage}get onSubscribe(){return this._frozen=!0,this._onSubscribe}set onMessage(e){this._assertUnfrozen(),this._onMessage=e}set onSubscribe(e){this._assertUnfrozen(),this._onSubscribe=e}get defaultVersioning(){return this._defaultVersioning}set defaultVersioning(e){this._assertUnfrozen(),this._defaultVersioning=e}get defaultHashFn(){return this._defaultHashFn}set defaultHashFn(e){this._assertUnfrozen(),this._defaultHashFn=e}get inspectorEnabled(){return this._inspectorEnabled}set inspectorEnabled(e){this._inspectorEnabled=e}get globalInspector(){return this._globalInspector}set globalInspector(e){this._globalInspector=e}get rigorRecorder(){return this._rigorRecorder}set rigorRecorder(e){this._rigorRecorder=e}registerMessageType(e,t){return this._assertUnfrozen(),this._messageTypes.set(e,{tier:t.tier,wireCrossing:t.wireCrossing??t.tier>=3,metaPassthrough:t.metaPassthrough??!0}),this}messageTier(e){let t=this._messageTypes.get(e);return t!=null?t.tier:1}isWireCrossing(e){let t=this._messageTypes.get(e);return t!=null?t.wireCrossing:!0}isLocalOnly(e){return!this.isWireCrossing(e)}isMetaPassthrough(e){let t=this._messageTypes.get(e);return t!=null?t.metaPassthrough:!0}isKnownMessageType(e){return this._messageTypes.has(e)}registerCodec(e){return this._assertUnfrozen(),this._codecs.set(e.name,e),this}lookupCodec(e){return this._codecs.get(e)}_isFrozen(){return this._frozen}_assertUnfrozen(){if(this._frozen)throw new Error("GraphReFlyConfig is frozen: a node has already captured this config. Register custom types and set hooks before creating any node.")}}});function jt(r){return Array.isArray(r)?[...r]:[r]}function Hn(r,e){return r.has(e)||r.has("*")}function Bt(r){let e=[];return r((s,o)=>{e.push({kind:"allow",actions:new Set(jt(s)),where:o?.where??(()=>!0)})},(s,o)=>{e.push({kind:"deny",actions:new Set(jt(s)),where:o?.where??(()=>!0)})}),(s,o)=>{let i=!1,a=!1;for(let u of e)Hn(u.actions,o)&&u.where(s)&&(u.kind==="deny"?i=!0:a=!0);return i?!1:a}}function ut(r){let e=Kn.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 Q,Kn,Ne=L(()=>{"use strict";Q=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}};Kn=["human","llm","wallet","system"]});function Kt(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++]=ct,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 qt(r,e){if(r.length<Ht)throw new Error(`decodeEnvelope: bytes too short (${r.length} < ${Ht})`);let t=0,n=r[t++];if(n!==ct)throw new Error(`decodeEnvelope: unsupported envelope version ${n} (expected ${ct})`);let s=r[t++];if(s===0)throw new Error("decodeEnvelope: name_len must be >= 1");if(t+s+2>r.length)throw new Error(`decodeEnvelope: envelope truncated (need ${t+s+2} bytes, have ${r.length})`);let o=new TextDecoder().decode(r.subarray(t,t+s));t+=s;let i=(r[t]<<8|r[t+1])>>>0;t+=2;let a=r.subarray(t),u=e.lookupCodec(o);if(u==null)throw new Error(`decodeEnvelope: codec "${o}" not registered (envelope codec_v=${i})`);return{codec:u,codecVersion:i,payload:a}}function Wt(r){r.registerCodec(qn)}var qn,ct,Ht,lt=L(()=>{"use strict";qn={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)}},ct=1,Ht=4});function ft(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(ft);if(typeof r=="object"&&r!==null){let e={};for(let t of Object.keys(r).sort())e[t]=ft(r[t]);return e}return null}function Jn(r){let e=Un.encode(r),t=e.length,n=t*8,s=t+9+63&-64,o=new Uint8Array(s);o.set(e),o[t]=128;let i=new DataView(o.buffer);i.setUint32(s-4,n>>>0,!1),i.setUint32(s-8,Math.floor(n/4294967296)>>>0,!1);let a=1779033703,u=3144134277,d=1013904242,c=2773480762,p=1359893119,f=2600822924,h=528734635,l=1541459225,v=new Uint32Array(64),g=(y,m)=>y>>>m|y<<32-m;for(let y=0;y<s;y+=64){for(let k=0;k<16;k++)v[k]=i.getUint32(y+k*4,!1);for(let k=16;k<64;k++){let A=v[k-15],M=v[k-2],S=g(A,7)^g(A,18)^A>>>3,ie=g(M,17)^g(M,19)^M>>>10;v[k]=v[k-16]+S+v[k-7]+ie>>>0}let m=a,_=u,T=d,O=c,b=p,x=f,N=h,E=l;for(let k=0;k<64;k++){let A=g(b,6)^g(b,11)^g(b,25),M=b&x^~b&N,S=E+A+M+Wn[k]+v[k]>>>0,ie=g(m,2)^g(m,13)^g(m,22),ne=m&_^m&T^_&T,Pe=ie+ne>>>0;E=N,N=x,x=b,b=O+S>>>0,O=T,T=_,_=m,m=S+Pe>>>0}a=a+m>>>0,u=u+_>>>0,d=d+T>>>0,c=c+O>>>0,p=p+b>>>0,f=f+x>>>0,h=h+N>>>0,l=l+E>>>0}let w=y=>y.toString(16).padStart(8,"0");return w(a)+w(u)+w(d)+w(c)+w(p)+w(f)+w(h)+w(l)}function pt(r){let e=ft(r??null),t=JSON.stringify(e);return Jn(t).slice(0,16)}function Yn(){let r=globalThis.crypto;if(r?.randomUUID)return r.randomUUID();let e=()=>Math.floor(Math.random()*4294967296).toString(16).padStart(8,"0"),t=e()+e()+e()+e();return`${t.slice(0,8)}-${t.slice(8,12)}-4${t.slice(13,16)}-${(parseInt(t.slice(16,17),16)&3|8).toString(16)}${t.slice(17,20)}-${t.slice(20,32)}`}function ht(r,e,t){let n=t?.id??Yn();if(r===0)return{id:n,version:0};let o=(t?.hash??pt)(e);return{id:n,version:0,cid:o,prev:null}}function Ut(r,e,t){r.version+=1,"cid"in r&&(r.prev=r.cid,r.cid=t(e))}var Wn,Un,Jt=L(()=>{"use strict";Wn=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]),Un=new TextEncoder});function Xt(r){return{node:r,unsub:null,prevData:void 0,dirty:!1,involvedThisWave:!1,dataBatch:[],terminal:void 0}}function gt(r){r.prevData=void 0,r.dirty=!1,r.involvedThisWave=!1,r.dataBatch.length=0,r.terminal=void 0}function He(r){return r.length===0?r:typeof r[0]=="symbol"?[r]:r}function se(r,e,t){let n=Zt(r)?r:[],s=typeof r=="function"?r:typeof e=="function"?e:void 0,o={};return Zt(r)?o=(mt(e)?e:t)??{}:mt(r)?o=r:o=(mt(e)?e:t)??{},new F(n,s,o)}var Yt,Qt,Qn,Xn,Oe,F,Zt,mt,be=L(()=>{"use strict";lt();$e();he();le();zt();Ne();te();Jt();Yt=()=>{},Qt=100;Qn=(r,e,t,n)=>{t.direction==="down-in"&&r._onDepMessage(t.depIndex,e)},Xn=(r,e,t,n)=>{let s=r;if(s._status==="completed"||s._status==="errored")return;let o=s._cached,i=o===void 0?[Ve]:[Ve,[D,o]];s._status==="dirty"&&i.push(me),Me(e,i,s._config.tierOf)},Oe=new Be({onMessage:Qn,onSubscribe:Xn});Vt(Oe);Wt(Oe);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;_partial;_guard;_extraGuards;_hashFn;_versioning;_versioningLevel;_lastMutation;_inspectorHooks;_actions;constructor(e,t,n){this._config=n.config??Oe,this._config.onMessage,this._optsName=n.name,this._describeKind=n.describeKind,this._equals=n.equals??Object.is,this._resubscribable=n.resubscribable??!1,this._resetOnTeardown=n.resetOnTeardown??!1,this._autoComplete=n.completeWhenDepsComplete??!0,this._autoError=n.errorWhenDepsError??!0,this._pausable=n.pausable??!0,this._guard=n.guard,this._fn=t,this._partial=n.partial??!1,this._cached=n.initial!==void 0?n.initial:void 0,this._status=e.length===0&&t==null&&this._cached!==void 0?"settled":"sentinel",this._hashFn=n.versioningHash??this._config.defaultHashFn??pt;let s=n.versioning??this._config.defaultVersioning;this._versioningLevel=s,this._versioning=s!=null?ht(s,this._cached===void 0?void 0:this._cached,{id:n.versioningId,hash:this._hashFn}):void 0,this._deps=e.map(Xt);let o={};for(let[a,u]of Object.entries(n.meta??{})){let d={initial:u,name:`${n.name??"node"}:meta:${a}`,describeKind:"state",config:this._config};n.guard!=null&&(d.guard=n.guard),o[a]=new r([],void 0,d)}Object.freeze(o),this.meta=o,this._hasMeta=Object.keys(o).length>0;let i=this;this._actions={emit(a){i._emit([[D,a]])},down(a){i._emit(He(a))},up(a){i._emitUp(He(a))}},this.down=this.down.bind(this),this.up=this.up.bind(this)}get _isTerminal(){return this._status==="completed"||this._status==="errored"}get name(){return this._optsName}get status(){return this._status}get cache(){return this._cached===void 0?void 0:this._cached}get lastMutation(){return this._lastMutation}get v(){return this._versioning}hasGuard(){return this._guard!=null}_applyVersioning(e,t){if(this._isExecutingFn)throw new Error(`Node "${this.name}": _applyVersioning cannot run mid-fn \u2014 call it outside of \`_execFn\` (typically at graph setup time before the first subscribe).`);let n=this._versioningLevel;if(n!=null&&e<=n)return;let s=t?.hash??this._hashFn;s!==this._hashFn&&(this._hashFn=s);let o=this._cached===void 0?void 0:this._cached,i=this._versioning,a=i?.id??t?.id,u=i?.version??0,d=ht(e,o,{id:a,hash:s});d.version=u,this._versioning=d,this._versioningLevel=e}_setInspectorHook(e){return e==null?()=>{}:(this._inspectorHooks==null&&(this._inspectorHooks=new Set),this._inspectorHooks.add(e),()=>{this._inspectorHooks?.delete(e),this._inspectorHooks?.size===0&&(this._inspectorHooks=void 0)})}_pushGuard(e){return this._extraGuards==null&&(this._extraGuards=new Set),this._extraGuards.add(e),()=>{this._extraGuards?.delete(e),this._extraGuards?.size===0&&(this._extraGuards=void 0)}}allowsObserve(e){if(this._guard==null&&this._extraGuards==null)return!0;let t=Le(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=Le(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:ae()}}down(e,t){let n=He(e);n.length!==0&&(this._checkGuard(t),this._emit(n))}emit(e,t){this._checkGuard(t),this._emit([[D,e]])}up(e,t){if(this._deps.length===0)return;let n=He(e);if(n.length===0)return;this._checkGuard(t);let s=t??{internal:!0};this._validateUpTiers(n);for(let o of this._deps)o.node.up?.(n,s)}_emitUp(e){if(this._deps.length!==0&&e.length!==0){this._validateUpTiers(e);for(let t of this._deps)t.node.up?.(e,{internal:!0})}}_validateUpTiers(e){let t=this._config.tierOf;for(let n of e){let s=t(n[0]);if(s===3||s===4)throw new Error(`Node "${this.name}": tier-${s} messages cannot flow up \u2014 DATA/RESOLVED/COMPLETE/ERROR are downstream-only. Use \`down(...)\` for value delivery; \`up(...)\` is for control signals (DIRTY, INVALIDATE, PAUSE, RESUME, TEARDOWN).`)}}subscribe(e,t){if(t!=null&&this._guard!=null){let u=Le(t);if(!this._guard(u,"observe"))throw new Q({actor:u,action:"observe",nodeName:this.name})}let s=this._isTerminal&&this._resubscribable;if(s){this._cached=void 0,this._status="sentinel",this._store={},this._hasCalledFnOnce=!1,this._waveHasNewData=!1,this._hasNewTerminal=!1,this._paused=!1,this._pendingWave=!1,this._pendingRerun=!1,this._isExecutingFn=!1,this._rerunDepth=0,this._dirtyDepCount=0,this._pauseLocks=null,this._pauseBuffer=null;for(let u of this._deps)gt(u);if(this._partial===!1){for(let u of this._deps)if(u.prevData!==void 0||u.dataBatch.length!==0||u.terminal!==void 0||u.dirty)throw new Error(`resubscribable-reset invariant: DepRecord not fully reset for node ${this._optsName??"(anonymous)"}`)}}this._sinkCount+=1;let o;try{o=this._config.onSubscribe(this,e,{sinkCount:this._sinkCount,afterTerminalReset:s},this._actions)}catch(u){throw this._sinkCount-=1,u}this._sinks==null?this._sinks=e:typeof this._sinks=="function"?this._sinks=new Set([this._sinks,e]):this._sinks.add(e);let i=this._isTerminal;if(this._sinkCount===1&&!i)try{this._activate()}catch(u){if(this._sinkCount-=1,this._removeSink(e),this._sinkCount===0&&(this._status="sentinel"),typeof o=="function")try{o()}catch{}throw u}this._status==="sentinel"&&this._cached===void 0&&(this._status="pending");let a=!1;return()=>{a||(a=!0,this._sinkCount-=1,this._removeSink(e),typeof o=="function"&&o(),this._sinks==null&&this._deactivate())}}_removeSink(e){if(this._sinks===e)this._sinks=null;else if(this._sinks!=null&&typeof this._sinks!="function")if(this._sinks.delete(e),this._sinks.size===1){let[t]=this._sinks;this._sinks=t}else this._sinks.size===0&&(this._sinks=null)}_activate(){if(this._deps.length===0){this._fn&&this._execFn();return}this._dirtyDepCount=0;let e=this._deps.length,t=0;try{for(let n=0;n<e;n++){let s=n,o=this._deps[n];o.unsub=Yt,o.unsub=o.node.subscribe(i=>{if(o.unsub===null)return;let a=this._config.tierOf,u=!1;for(let d of i)a(d[0])>=3&&(u=!0),this._config.onMessage(this,d,{direction:"down-in",depIndex:s},this._actions);u&&this._maybeRunFnOnSettlement()}),t++}}catch(n){this._deps[t].unsub=null;for(let s=0;s<t;s++){let o=this._deps[s];if(o.unsub!=null){let i=o.unsub;o.unsub=null;try{i()}catch{}gt(o)}}throw this._dirtyDepCount=0,n}}_addDep(e){for(let s=0;s<this._deps.length;s++)if(this._deps[s].node===e)return s;let t=this._deps.length,n=Xt(e);if(this._deps.push(n),this._sinks==null)return t;n.dirty=!0,this._dirtyDepCount++,this._status!=="dirty"&&this._emit(ze),n.unsub=Yt;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([[C,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([[C,this._wrapFnError("cleanup.deactivate threw",s)]])}}for(let n of this._deps){if(n.unsub!=null){let s=n.unsub;n.unsub=null;try{s()}catch{}}gt(n)}this._waveHasNewData=!1,this._hasNewTerminal=!1,this._hasCalledFnOnce=!1,this._paused=!1,this._pendingWave=!1,this._pendingRerun=!1,this._rerunDepth=0,this._store={},this._dirtyDepCount=0,this._pauseLocks=null,this._pauseBuffer=null,this._fn!=null&&(this._cached=void 0),e||(this._fn!=null||this._deps.length>0)&&(!this._isTerminal||this._resubscribable)&&(this._status="sentinel")}_onDepMessage(e,t){let n=this._deps[e],s=t[0];if(this._inspectorHooks!=null){let o={kind:"dep_message",depIndex:e,message:t};for(let i of this._inspectorHooks)i(o)}if(s!==ge){if(s===$){this._depDirtied(n);return}if(s===Y){if(this._depInvalidated(n),this._cached===void 0)return;this._emit(at);return}if(s===ee||s===re){this._emit([t]);return}if(s===j){this._emit(je);return}if(s===D)this._depSettledAsData(n,t[1]);else if(s===W)this._depSettledAsResolved(n);else if(s===z)this._depSettledAsTerminal(n,!0);else if(s===C)this._depSettledAsTerminal(n,t[1]);else{this._emit([t]);return}if(!this._fn){(s===D||s===W)&&this._emit([t]),(s===z||s===C)&&this._maybeAutoTerminalAfterWave();return}}}_depDirtied(e){e.dirty||(e.dirty=!0,e.involvedThisWave=!0,this._dirtyDepCount++,this._status!=="dirty"&&this._emit(ze))}_depSettledAsData(e,t){e.dirty&&(e.dirty=!1,this._dirtyDepCount--),e.involvedThisWave=!0,e.dataBatch.push(t),this._waveHasNewData=!0}_depSettledAsResolved(e){e.dirty&&(e.dirty=!1,this._dirtyDepCount--)}_depSettledAsTerminal(e,t){e.dirty&&(e.dirty=!1,this._dirtyDepCount--),e.terminal=t,e.involvedThisWave=!0,this._hasNewTerminal=!0}_depInvalidated(e){e.prevData=void 0,e.terminal=void 0,e.dataBatch.length=0,e.dirty?e.involvedThisWave=!1:(e.dirty=!0,e.involvedThisWave=!0,this._dirtyDepCount++)}_maybeRunFnOnSettlement(){if(!(this._isTerminal&&!this._resubscribable)&&!(this._dirtyDepCount>0)){if(!this._partial&&!this._hasCalledFnOnce)for(let e=0;e<this._deps.length;e++){let t=this._deps[e];if(t.dataBatch.length===0&&t.prevData===void 0&&t.terminal===void 0){this._maybeAutoTerminalAfterWave();return}}if(this._paused){this._pendingWave=!0;return}if(!this._waveHasNewData&&!this._hasNewTerminal&&this._hasCalledFnOnce){this._clearWaveFlags(),this._emit(it),this._maybeAutoTerminalAfterWave();return}this._fn&&this._execFn(),this._maybeAutoTerminalAfterWave()}}_maybeAutoTerminalAfterWave(){if(this._deps.length===0||this._isTerminal)return;let e=this._deps.find(t=>t.terminal!==void 0&&t.terminal!==!0);if(e!=null){this._autoError&&this._emit([[C,e.terminal]]);return}this._autoComplete&&this._deps.every(t=>t.terminal!==void 0)&&this._emit(dt)}_execFn(){if(!this._fn||this._isTerminal&&!this._resubscribable)return;if(this._isExecutingFn){this._pendingRerun=!0;return}let e=this._cleanup;if(typeof e=="function"){this._cleanup=void 0;try{e()}catch(i){this._emit([[C,this._wrapFnError("cleanup threw",i)]]);return}}else if(e!=null&&typeof e=="object"){let i=e.beforeRun;if(typeof i=="function"){e.beforeRun=void 0;try{i()}catch(a){this._emit([[C,this._wrapFnError("cleanup.beforeRun threw",a)]]);return}}}let t=this._deps.map(i=>i.involvedThisWave?i.dataBatch.length>0?[...i.dataBatch]:[]:void 0),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([[C,this._wrapFnError("fn threw",i)]])}finally{this._isExecutingFn=!1,this._pendingRerun?(this._pendingRerun=!1,this._rerunDepth+=1,this._rerunDepth>Qt?(this._rerunDepth=0,this._emit([[C,new Error(`Node "${this.name}": _pendingRerun depth exceeded ${Qt} \u2014 likely a reactive cycle`)]])):this._maybeRunFnOnSettlement()):this._rerunDepth=0,this._clearWaveFlags()}}_clearWaveFlags(){this._waveHasNewData=!1,this._hasNewTerminal=!1;for(let e of this._deps)e.involvedThisWave=!1,e.dataBatch.length=0}_wrapFnError(e,t){let n=t instanceof Error?t.message:String(t);return new Error(`Node "${this.name}": ${e}: ${n}`,{cause:t})}_frameBatch(e){let t=this._config.tierOf;if(e.length===1)return t(e[0][0])===3&&this._status!=="dirty"?[me,e[0]]:e;let n=!0,s=!1,o=!1,i=-1;for(let u of e){let d=t(u[0]);d<i&&(n=!1),d===3&&(s=!0),u[0]===$&&(o=!0),i=d}let a=e;if(!n){let u=e.map((d,c)=>({m:d,i:c,tier:t(d[0])}));u.sort((d,c)=>d.tier-c.tier||d.i-c.i),a=u.map(d=>d.m)}if(s&&!o&&this._status!=="dirty"){let u=0;for(;u<a.length&&t(a[u][0])===0;)u++;return u===0?[me,...a]:[...a.slice(0,u),me,...a.slice(u)]}return a}_emit(e){if(e.length===0)return;for(let a=0;a<e.length;a++){let u=e[a];if(u[0]===C&&u[1]===void 0)throw new TypeError('[ERROR, payload] requires a non-undefined payload (spec \xA71.2). Pass an Error object or domain tag instead \u2014 e.g. node.down([[ERROR, new Error("reason")]])')}let t=e;if(this._isTerminal&&!this._resubscribable){let a=e.filter(u=>u[0]===j||u[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 u=t[a],d=u[0];if(d!==ee&&d!==re){s?.push(u);continue}if(u.length<2)throw new Error(`Node "${this.name}": [[${d===ee?"PAUSE":"RESUME"}]] must carry a lockId payload \u2014 bare PAUSE/RESUME is a protocol violation (C0 rule). Use \`[[PAUSE, lockId]]\` / \`[[RESUME, lockId]]\`.`);let c=!0;if(this._pausable!==!1){let p=u[1];if(d===ee)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))c=!1;else if(this._pauseLocks.delete(p),this._pauseLocks.size===0){if(this._paused=!1,this._pauseBuffer!=null&&this._pauseBuffer.length>0){let f=this._pauseBuffer;this._pauseBuffer=[],this._emit(f)}this._pendingWave&&(this._pendingWave=!1,this._maybeRunFnOnSettlement())}}c?s?.push(u):s==null&&(s=t.slice(0,a))}if(s!=null){if(s.length===0)return;t=s}if(this._hasMeta&&t.some(a=>a[0]===j))for(let a of Object.keys(this.meta))try{this.meta[a]._emit(je)}catch{}let{finalMessages:o,equalsError:i}=this._updateState(t);if(o.length>0&&this._config.inspectorEnabled){let a=this._config.globalInspector;if(a!=null)try{a({kind:"emit",node:this,messages:o})}catch{}}if(o.length>0)if(this._paused&&this._pausable==="resumeAll"&&this._pauseBuffer!=null){let a=this._config.tierOf,u=[];for(let d of o)a(d[0])===3?this._pauseBuffer.push(d):u.push(d);u.length>0&&this._dispatchOrAccumulate(u)}else this._dispatchOrAccumulate(o);i!=null&&this._emit([[C,i]])}_updateState(e){let t=this._config.tierOf,n,s,o=-1,i=0;for(let c of e)t(c[0])===3&&i++;let a=i<=1,u=-1;if(this._versioning!=null&&i>1){for(let c=e.length-1;c>=0;c--)if(e[c][0]===D){u=c;break}}for(let c=0;c<e.length;c++){let p=e[c],f=p[0];if(f===D){if(p.length>=2){let h=!1;if(a&&this._cached!==void 0)try{h=this._equals(this._cached,p[1])}catch(l){s=this._wrapFnError("equals threw",l),o=c;break}if(h){n==null&&(n=e.slice(0,c)),n.push(Fe),this._status="resolved";continue}this._cached=p[1],this._versioning!=null&&(u<0||c===u)&&Ut(this._versioning,p[1],this._hashFn)}this._status="settled",n?.push(p)}else if(n?.push(p),f===$)this._status="dirty";else if(f===W)this._status="resolved";else if(f===z){this._status="completed";{let h=this._config.rigorRecorder;if(h!=null)try{h.onTerminalTransition(this,"completed",this._autoComplete,this._autoError,this._deps.length>0)}catch{}}}else if(f===C){this._status="errored";{let h=this._config.rigorRecorder;if(h!=null)try{h.onTerminalTransition(this,"errored",this._autoComplete,this._autoError,this._deps.length>0)}catch{}}}else if(f===Y){if(this._cached!==void 0){let l=this._config.rigorRecorder;if(l!=null)try{l.onNonVacuousInvalidate(this,this._cached)}catch{}}this._cached=void 0,this._status="dirty";let h=this._cleanup;if(typeof h=="function"){this._cleanup=void 0;try{h()}catch{}}else if(h!=null&&typeof h=="object"){let l=h.invalidate;if(typeof l=="function")try{l()}catch{}}}else f===j&&(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(It()){this._batchPendingMessages===null&&(this._batchPendingMessages=[],ke(()=>this._flushBatchPending()));for(let t of e)this._batchPendingMessages.push(t);return}Me(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);Me(this._deliverToSinks,t,this._config.tierOf)}},Zt=r=>Array.isArray(r),mt=r=>typeof r=="object"&&r!=null&&!Array.isArray(r)});function Ke(r,e){if(e!=null&&e.length>0)return new Set(e);switch(r){case"standard":return new Set(["type","status","value","deps","meta","v"]);case"full":return null;case"spec":return new Set(["type","deps","meta","value"]);default:return new Set(["type","deps"])}}function Zn(r){return r._describeKind!=null?r._describeKind:r._deps.length>0?"derived":r._fn!=null?"producer":"state"}function yt(r){let e=new WeakSet,t={};for(let[n,s]of en(r))t[n]=bt(s,e);return t}function bt(r,e){if(r==null)return r;let t=typeof r;if(t==="boolean"||t==="number"||t==="string")return r;if(t==="function")return"<function>";if(Array.isArray(r))return e.has(r)?"<cycle>":(e.add(r),r.map(n=>bt(n,e)));if(t==="object"){let n=r;if(e.has(n))return"<cycle>";e.add(n);try{if(typeof n.subscribe=="function"&&"cache"in n)return"<Node>"}catch{return"<unserializable>"}let s={};for(let[o,i]of en(n))s[o]=bt(i,e);return s}return"<unserializable>"}function en(r){let e=[],t;try{t=Object.keys(r)}catch{return e}for(let n of t)try{e.push([n,r[n]])}catch{e.push([n,"<unserializable>"])}return e}function er(r){let e={};for(let[t,n]of Object.entries(r.meta))try{e[t]=n.cache}catch{}return e}function vt(r,e,t){let n=e==null,s=!n&&e!=null?[...e].filter(c=>c.startsWith("meta.")).map(c=>c.slice(5)):null,o=n||e.has("meta")||s!=null&&s.length>0,i="state",a=[];r instanceof F&&(i=Zn(r),a=r._deps.map(c=>c.node.name??""));let u={type:i,deps:a};(n||e.has("status"))&&(u.status=r.status);let d=r instanceof F?r._guard:void 0;if(o){let c={...er(r)};if(d!=null&&c.access===void 0&&(c.access=ut(d)),s!=null&&s.length>0&&!e.has("meta")){let p={};for(let f of s)f in c&&(p[f]=c[f]);u.meta=p}else u.meta=c}if(r.name!=null&&(u.name=r.name),(n||e.has("value"))&&(!t||i==="state")){r.status==="sentinel"&&(u.sentinel=!0);try{u.value=r.cache}catch{}}if((n||e.has("v"))&&r.v!=null){let c={id:r.v.id,version:r.v.version};"cid"in r.v&&(c.cid=r.v.cid,c.prev=r.v.prev),u.v=c}return(n||e.has("guard"))&&d!=null&&(u.guard=ut(d)),(n||e.has("lastMutation"))&&r.lastMutation!=null&&(u.lastMutation=r.lastMutation),u}var _t=L(()=>{"use strict";Ne();be()});function B(r,e){return se([],{...e,initial:r})}function de(r,e){return se((n,s,o)=>r(s,o)??void 0,{describeKind:"producer",...e})}function X(r,e,t){return se(r,(s,o,i)=>{let a=s.map((u,d)=>u!=null&&u.length>0?u.at(-1):i.prevData[d]);o.emit(e(a,i))},{describeKind:"derived",...t})}var ue=L(()=>{"use strict";be()});function tn(r,e,t){return{[r]:!0,[`${r}_type`]:e,...t??{}}}var nn=L(()=>{"use strict"});function wt(r,e){if(Object.is(r,e))return!0;if(r==null||e==null||typeof r!="object"||typeof e!="object")return!1;if(Array.isArray(r)){if(!Array.isArray(e)||r.length!==e.length)return!1;for(let o=0;o<r.length;o++)if(!wt(r[o],e[o]))return!1;return!0}if(Array.isArray(e))return!1;let t=Object.keys(r),n=Object.keys(e);if(t.length!==n.length)return!1;let s=new Set(n);for(let o of t)if(!s.has(o)||!wt(r[o],e[o]))return!1;return!0}function rn(r,e){return`${r}\0${e}`}function Tt(r,e){let t=[],n=new Set(r.subgraphs),s=new Set(e.subgraphs),o=[];for(let g of s)n.has(g)||o.push(g);o.sort();for(let g of o)t.push({type:"subgraph-mounted",path:g});let i=new Set(Object.keys(r.nodes)),a=new Set(Object.keys(e.nodes)),u=[];for(let g of a)i.has(g)||u.push(g);u.sort();for(let g of u)t.push({type:"node-added",path:g,node:{...e.nodes[g]}});let d=[];for(let g of a){if(!i.has(g))continue;let w=r.nodes[g]?.meta,y=e.nodes[g]?.meta;w==null&&y==null||wt(w??{},y??{})||d.push(g)}d.sort();for(let g of d)t.push({type:"node-meta-changed",path:g,prevMeta:r.nodes[g]?.meta??{},nextMeta:e.nodes[g]?.meta??{}});let c=new Map;for(let g of r.edges)c.set(rn(g.from,g.to),g);let p=new Map;for(let g of e.edges)p.set(rn(g.from,g.to),g);let f=[];for(let[g,w]of p)c.has(g)||f.push(w);f.sort((g,w)=>g.from<w.from?-1:g.from>w.from?1:g.to<w.to?-1:g.to>w.to?1:0);for(let g of f)t.push({type:"edge-added",from:g.from,to:g.to});let h=[];for(let[g,w]of c)p.has(g)||h.push(w);h.sort((g,w)=>g.from<w.from?-1:g.from>w.from?1:g.to<w.to?-1:g.to>w.to?1:0);for(let g of h)t.push({type:"edge-removed",from:g.from,to:g.to});let l=[];for(let g of i)a.has(g)||l.push(g);l.sort();for(let g of l)t.push({type:"node-removed",path:g});let v=[];for(let g of n)s.has(g)||v.push(g);v.sort();for(let g of v)t.push({type:"subgraph-unmounted",path:g});return{events:t,flushedAt_ns:K()}}var sn=L(()=>{"use strict";le()});function xt(r){return{describeKind:"producer",...r}}function on(r,e){return de(t=>{let n=!1;try{for(let s of r){if(n)return;t.emit(s)}n||t.down([[z]])}catch(s){n||t.down([[C,s]])}return()=>{n=!0}},xt(e))}function tr(r){return r!=null&&typeof r.then=="function"}function nr(r,e){let{signal:t,...n}=e??{};return de(s=>{let o=!1,i=()=>{o||(o=!0,s.down([[C,t.reason]]))};if(t?.aborted){i();return}return t?.addEventListener("abort",i,{once:!0}),Promise.resolve(r).then(a=>{o||(o=!0,t?.removeEventListener("abort",i),s.emit(a),s.down([[z]]))},a=>{o||(o=!0,t?.removeEventListener("abort",i),s.down([[C,a]]))}),()=>{o=!0,t?.removeEventListener("abort",i)}},xt(n))}function rr(r,e){let{signal:t,...n}=e??{};return de(s=>{let o=new AbortController,i=()=>o.abort(t?.reason);t?.aborted?o.abort(t.reason):t?.addEventListener("abort",i,{once:!0});let a=t??o.signal,u=!1,d=r[Symbol.asyncIterator](),c=()=>{u||a.aborted||Promise.resolve(d.next()).then(p=>{if(!(u||a.aborted)){if(p.done){s.down([[z]]);return}s.emit(p.value),c()}},p=>{!u&&!a.aborted&&s.down([[C,p]])})};return c(),()=>{u=!0,t?.removeEventListener("abort",i),o.abort(),Promise.resolve(d.return?.()).catch(()=>{})}},xt(n))}function sr(r){return r!=null&&typeof r=="object"&&"cache"in r&&typeof r.subscribe=="function"}function an(r,e){if(sr(r))return r;if(tr(r))return nr(r,e);if(r!=null){let t=r;if(typeof t[Symbol.asyncIterator]=="function")return rr(r,e);if(typeof t[Symbol.iterator]=="function")return on(r,e)}return or(r)}function or(...r){return on(r,void 0)}function oe(r){return r.subscribe(()=>{})}var dn=L(()=>{"use strict";te();ue()});var kt=L(()=>{"use strict";dn()});var qe,un=L(()=>{"use strict";qe=class{_timer;_gen=0;start(e,t){this.cancel(),this._gen+=1;let n=this._gen;this._timer=setTimeout(()=>{this._timer=void 0,n===this._gen&&t()},e)}cancel(){this._timer!==void 0&&(clearTimeout(this._timer),this._timer=void 0)}get pending(){return this._timer!==void 0}}});var De,cn=L(()=>{"use strict";De=class{constructor(e){this.capacity=e;if(!Number.isInteger(e)||e<=0)throw new Error(`RingBuffer capacity must be a positive integer (got ${e})`);this.buf=new Array(e)}buf;head=0;_size=0;get size(){return this._size}get maxSize(){return this.capacity}push(e){let t=(this.head+this._size)%this.capacity;this.buf[t]=e,this._size<this.capacity?this._size++:this.head=(this.head+1)%this.capacity}shift(){if(this._size===0)return;let e=this.buf[this.head];return this.buf[this.head]=void 0,this.head=(this.head+1)%this.capacity,this._size--,e}at(e){if(this._size===0)return;let t=e<0?this._size+e:e;if(!(t<0||t>=this._size))return this.buf[(this.head+t)%this.capacity]}toArray(){let e=new Array(this._size);for(let t=0;t<this._size;t++)e[t]=this.buf[(this.head+t)%this.capacity];return e}clear(){for(let e=0;e<this._size;e++)this.buf[(this.head+e)%this.capacity]=void 0;this.head=0,this._size=0}}});function ln(r,e,t,n={}){let s=e in r.nodes,o=t in r.nodes;if(!s)return We(e,t,"no-such-from");if(!o)return We(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=ir(r,e,n);if(d!=null)return d}let u=Ue(e,r.nodes[e],0,n);return Je(e,t,[u])}if(i===0)return We(e,t,"no-path");let a=fn(r,e,t,i);return a.found?Je(e,t,pn(r,a.pathOrder,n)):We(e,t,a.truncated?"max-depth-exceeded":"no-path")}function fn(r,e,t,n){let s=new Map,o=[{path:t,depth:0}],i=new Set([t]),a=0,u=!1;for(;a<o.length;){let p=o[a++];if(p.path===e)break;if(n!=null&&p.depth>=n){let v=r.nodes[p.path];v?.deps&&v.deps.length>0&&(u=!0);continue}let f=r.nodes[p.path];if(f==null)continue;let h=f.deps??[],l=new Map;for(let v=0;v<h.length;v++){let g=h[v];if(!g)continue;let w=l.get(g);w==null&&(w=[],l.set(g,w)),w.push(v)}for(let[v,g]of l)i.has(v)||(i.add(v),s.set(v,{from:p.path,depIndices:g}),o.push({path:v,depth:p.depth+1}))}if(!s.has(e))return{found:!1,pathOrder:[],truncated:u};let d=[{path:e}],c=e;for(;c!==t;){let p=s.get(c);if(p==null)return{found:!1,pathOrder:[],truncated:!1};d[d.length-1].depIndices=p.depIndices,d.push({path:p.from}),c=p.from}return{found:!0,pathOrder:d,truncated:!1}}function ir(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=Ue(e,n,0,t);a.dep_index=o[0];let u=Ue(e,n,1,t);return Je(e,e,[a,u])}let i=null;for(let a=0;a<s.length;a++){let u=s[a];if(!u||u===e)continue;let d=fn(r,u,e,t.maxDepth);d.found&&(i==null||d.pathOrder.length<i.pathOrder.length)&&(i=d,i={found:!0,pathOrder:[{path:e,depIndices:[a]},...d.pathOrder],truncated:!1})}return i==null?null:Je(e,e,pn(r,i.pathOrder,t))}function pn(r,e,t){return e.map((n,s)=>{let o=r.nodes[n.path],i=Ue(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 Ue(r,e,t,n){let s={path:r,type:e.type,hop:t};e.status!==void 0&&(s.status=e.status),"value"in e&&(s.value=e.value),e.v!=null&&(s.v=e.v);let o=n.annotations?.get(r)??e.annotation;o!=null&&(s.annotation=o);let i=n.lastMutations?.get(r)??e.lastMutation;return i!=null&&(s.lastMutation=i),s}function Je(r,e,t){return hn(r,e,!0,"ok",t)}function We(r,e,t){return hn(r,e,!1,t,[])}function hn(r,e,t,n,s){let o=ar(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 ar(r,e,t,n,s){if(!t)switch(n){case"no-such-from":return`explainPath: no node named "${r}"`;case"no-such-to":return`explainPath: no node named "${e}"`;case"max-depth-exceeded":return`explainPath: no path from "${r}" to "${e}" within maxDepth`;default:return`explainPath: no path from "${r}" to "${e}"`}let o=[`Causal path: ${r} \u2192 ${e} (${s.length} step(s))`];for(let i of s){let u=` ${i.hop===0?"\xB7":"\u2193"} ${i.path} (${i.type}${i.status?`/${i.status}`:""})`;if(o.push(u),"value"in i&&o.push(` value: ${dr(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 dr(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)}}var gn=L(()=>{"use strict"});function mn(r){let e=new WeakSet,t=new WeakSet,n=[r],s=0;for(;n.length>0;){let o=n.pop();s+=cr(o,e,t,n)}return s}function cr(r,e,t,n){if(r==null)return 0;switch(typeof r){case"number":return V.number;case"boolean":return V.boolean;case"string":return V.string+r.length*2;case"bigint":return V.bigint+lr(r);case"symbol":return V.symbol;case"function":return e.has(r)?0:(e.add(r),V.function);case"undefined":return 0}let o=r;if(e.has(o))return 0;e.add(o);let i=o[ur];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 V.date;if(o instanceof RegExp)return V.regexp+o.source.length*2;if(o instanceof Error){let d=o.message?o.message.length*2:0,c=o.stack?o.stack.length*2:0;return V.error+d+c}if(typeof URL<"u"&&o instanceof URL)return V.url+o.href.length*2;if(typeof Promise<"u"&&o instanceof Promise)return V.promise;if(o instanceof WeakMap)return V.weakmap;if(o instanceof WeakSet)return V.weakset;if(o instanceof Map){let d=V.map;for(let[c,p]of o)d+=V.mapEntry,n.push(c),n.push(p);return d}if(o instanceof Set){let d=V.set;for(let c of o)d+=V.setEntry,n.push(c);return d}if(Array.isArray(o)){let d=V.array+o.length*8;for(let c of o)n.push(c);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=V.object,u=Object.keys(o);for(let d of u){a+=V.string+d.length*2;try{n.push(o[d])}catch{}}return a}function lr(r){let e=r<0n?-r:r;if(e===0n)return 0;let t=e.toString(2).length;return Math.ceil(t/32)*8}var V,ur,bn=L(()=>{"use strict";V={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},ur=Symbol.for("sizeof")});function yn(r,e){let t=e?.topN??10,n=r.describe({detail:"standard"}),s=[],o=r._collectObserveTargets;typeof o=="function"&&o.call(r,"",s);let i=new Map;for(let[f,h]of s)i.set(f,h);let a=[];for(let[f,h]of Object.entries(n.nodes)){let l=i.get(f),v=l instanceof F?l:null,g=v?mn(v.cache):0,w=v?v._sinkCount:0,y=h.deps?.length??0,m=h.type==="effect"&&w===0,_=w===0?h.type==="effect"?"orphan-effect":h.type==="derived"?"idle-derived":h.type==="producer"?"idle-producer":null:null;a.push({path:f,type:h.type,status:h.status??"unknown",valueSizeBytes:g,subscriberCount:w,depCount:y,isOrphanEffect:m,orphanKind:_})}let u=a.reduce((f,h)=>f+h.valueSizeBytes,0),d=(f,h)=>[...a].sort(h??((l,v)=>v[f]-l[f])).slice(0,t),c=a.filter(f=>f.orphanKind!=null),p=a.filter(f=>f.isOrphanEffect);return{nodeCount:a.length,edgeCount:n.edges.length,subgraphCount:n.subgraphs.length,nodes:a,totalValueSizeBytes:u,hotspots:{byValueSize:d("valueSizeBytes"),bySubscriberCount:d("subscriberCount"),byDepCount:d("depCount")},orphans:c,orphanEffects:p}}var vn=L(()=>{"use strict";be();bn()});function _n(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 Nn(r){return r!=null&&typeof r=="object"&&"cache"in r&&typeof r.subscribe=="function"&&typeof r.down=="function"}function fr(r){if(r!=null)return Nn(r)?r.cache:r}function ve(r){return r!=null&&typeof r=="object"&&"cache"in r&&typeof r.subscribe=="function"&&typeof r.down=="function"}function ce(r){return ve(r)?r.cache??"":r}function wn(r){return ve(r)?r.cache??0:r}function Tn(r){return ve(r)?r.cache??!1:r}function pr(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 xn(r){if(r.version!==ye)throw new Error(`unsupported snapshot version ${String(r.version)} (expected ${ye})`);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 hr(r,e){let t=new WeakMap,n=(s,o)=>{if(Object.is(s,o))return!0;if(s==null||o==null||typeof s!="object"||typeof o!="object")return!1;let i=t.get(s);if(i==null&&(i=new WeakSet,t.set(s,i)),i.has(o))return!0;i.add(o);let a=s.constructor,u=o.constructor;if(a!==u)return!1;if(s instanceof Date)return s.getTime()===o.getTime();if(s instanceof RegExp)return s.source===o.source&&s.flags===o.flags;if(Array.isArray(s)){let f=o;if(s.length!==f.length)return!1;for(let h=0;h<s.length;h++)if(!n(s[h],f[h]))return!1;return!0}if(s instanceof Map){let f=o;if(s.size!==f.size)return!1;for(let[h,l]of s)if(!f.has(h)||!n(l,f.get(h)))return!1;return!0}if(s instanceof Set){let f=o;if(s.size!==f.size)return!1;for(let h of s){let l=!1;for(let v of f)if(n(h,v)){l=!0;break}if(!l)return!1}return!0}if(ArrayBuffer.isView(s)){let f=s,h=o;if(f.length!==h.length)return!1;for(let l=0;l<f.length;l++)if(f[l]!==h[l])return!1;return!0}let d=Object.keys(s),c=Object.keys(o);if(d.length!==c.length)return!1;let p=new Set(c);for(let f of d)if(!p.has(f)||!n(s[f],o[f]))return!1;return!0};return n(r,e)}function gr(r){return r.replace(/[.*+?^${}()|[\]\\]/g,"\\$&")}function Ye(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+=gr(n)}return e+="$",new RegExp(e)}function Nt(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 yr(r){return r==="none"?br:r==="ansi"||r==null?mr:{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 kn(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 vr(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 Ot(r,e,t){if(r==="")throw new Error(`Graph "${e}": ${t} name must be non-empty`);if(r.includes(I))throw new Error(`Graph "${e}": ${t} "${r}" must not contain '${I}' (path separator)`);if(r===Z)throw new Error(`Graph "${e}": ${t} name "${Z}" is reserved for meta companion paths`);vr(r,e,t)}function _r(r,e){if(r==="")throw new Error(`Graph "${e}": resolve path must be non-empty`);let t=r.split(I);for(let n of t)if(n==="")throw new Error(`Graph "${e}": resolve path has empty segment`);return t}function wr(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 On(r){for(let e of r._mounts.values())On(e);for(let e of r._nodes.values())try{e.down([[j]],{internal:!0})}catch{}}function En(r,e){let t=_e.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 Et(r,e,t,n={}){let s={paths:[],depths:new Map,truncated:!1};if(!e)return n.withDetail?s:[];if(!n.both&&t!=="upstream"&&t!=="downstream")throw new Error('reachable: direction must be "upstream" or "downstream"');let o=n.maxDepth;if(o!=null&&(!Number.isInteger(o)||o<0))throw new Error("reachable: maxDepth must be an integer >= 0");if(o===0)return n.withDetail?s:[];let i=new Map,a=new Map,u=new Map,d=new Map,c=new Set;for(let[m,_]of Object.entries(r.nodes)){if(!m)continue;c.add(m);let T=_.deps??[];i.set(m,T);for(let O of T)O&&(c.add(O),a.has(O)||a.set(O,new Set),a.get(O).add(m))}for(let m of r.edges){if(m==null||typeof m!="object")continue;let _=typeof m.from=="string"?m.from:"",T=typeof m.to=="string"?m.to:"";!_||!T||(c.add(_),c.add(T),d.has(_)||d.set(_,new Set),d.get(_).add(T),u.has(T)||u.set(T,new Set),u.get(T).add(_))}if(!c.has(e))return n.withDetail?s:[];let p=n.both===!0,f=m=>{if(p){let b=i.get(m)??[],x=u.get(m),N=a.get(m),E=d.get(m),k=[...b];return x&&k.push(...x),N&&k.push(...N),E&&k.push(...E),k}if(t==="upstream"){let b=i.get(m)??[],x=u.get(m);return x?[...b,...x]:b}let _=a.get(m),T=d.get(m),O=_?[..._]:[];return T&&O.push(...T),O},h=new Set([e]),l=new Map,v=[{path:e,depth:0}],g=0,w=!1;for(;g<v.length;){let m=v[g++];if(o!=null&&m.depth>=o){f(m.path).length>0&&(w=!0);continue}for(let _ of f(m.path))!_||h.has(_)||(h.add(_),l.set(_,m.depth+1),v.push({path:_,depth:m.depth+1}))}let y=[...l.keys()].sort((m,_)=>m<_?-1:m>_?1:0);return n.withDetail?{paths:y,depths:l,truncated:w}:y}function Tr(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}var I,Z,ye,mr,br,_e,Rn=L(()=>{"use strict";$e();he();le();Ne();te();_t();be();ue();sn();kt();un();cn();lt();gn();vn();I="::",Z="__meta__",ye=1;mr={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"},br={data:"",dirty:"",resolved:"",invalidate:"",pause:"",resume:"",complete:"",error:"",teardown:"",derived:"",path:"",reset:""};_e=class r{name;opts;config;_nodes=new Map;_nodeToName=new WeakMap;_mounts=new Map;_parent=void 0;_storageDisposers=new Set;_disposers=new Set;_destroyed=!1;_topology;_topologyEmitters=new Set;_factory;_factoryArgs;constructor(e,t){if(e==="")throw new Error("Graph name must be non-empty");if(e.includes(I))throw new Error(`Graph name must not contain '${I}' (got "${e}")`);if(e===Z)throw new Error(`Graph name "${Z}" is reserved for meta companion paths`);this.name=e,this.opts=Object.freeze({...t??{}}),this.config=t?.config??Oe,this._traceRing=new De(t?.traceCapacity??1e3),t?.versioning!=null&&this.setVersioning(t.versioning),typeof t?.factory=="string"&&(this._factory=t.factory,t.factoryArgs!==void 0&&(this._factoryArgs=t.factoryArgs))}tagFactory(e,t){return this._factory=e,this._factoryArgs=t,this}ancestors(e=!0){let t=[],n=e?this:this._parent;for(;n!=null;)t.push(n),n=n._parent;return t}get topology(){return this._topology==null&&(this._topology=de(e=>{let t=n=>{e.emit(n)};return this._topologyEmitters.add(t),()=>{this._topologyEmitters.delete(t)}},{name:`${this.name}_topology`})),this._topology}_emitTopology(e){if(!(this._topology==null||this._topologyEmitters.size===0))for(let t of this._topologyEmitters)t(e)}nameOf(e){return this._nodeToName.get(e)}add(e,t){let n=e.name,s=t?.name??n;if(s==null||s==="")throw new Error(`Graph "${this.name}": graph.add requires a non-empty name \u2014 pass via opts.name or set it on the node (e.g. state(0, { name: "x" }))`);let o=s,i=t?.annotation;if(Ot(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:K()})),e}setVersioning(e){if(e!=null)for(let t of this._nodes.values())t instanceof F&&t._applyVersioning(e)}remove(e){Ot(e,this.name,"remove");let t=this._mounts.get(e);if(t){let o={kind:"mount",nodes:[],mounts:[]},i=[];t._collectObserveTargets("",i);for(let[a,u]of i)a.includes(`${I}${Z}${I}`)||o.nodes.push(a);return o.nodes.sort(),o.mounts.push(e),o.mounts.push(...t._collectSubgraphs(`${e}${I}`)),this._mounts.delete(e),t._parent=void 0,On(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([[j]],{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=Ye(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(I))return this.resolve(e);let t=this._nodes.get(e);if(!t)throw new Error(`Graph "${this.name}": unknown node "${e}"`);return t}get(e){return this.node(e).cache}set(e,t,n){let s=n?.internal===!0;this.node(e).down([[D,t]],{actor:n?.actor,internal:s,delivery:"write"})}setAll(e,t){let n=Symbol.iterator in e?e:Object.entries(e);q(()=>{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([[C,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[u,d]of this._nodes)n.set(d,u);let a=[];for(let[u,d]of this._nodes)if(d instanceof F)for(let c of d._deps){let p=n.get(c.node);p!=null&&a.push([p,u])}return a.sort((u,d)=>u[0]<d[0]?-1:u[0]>d[0]?1:u[1]<d[1]?-1:u[1]>d[1]?1:0),a}let s=[];this._collectObserveTargets("",s);let o=new Map;for(let[a,u]of s)o.set(u,a);let i=[];for(let[a,u]of s)if(u instanceof F)for(let d of u._deps){let c=o.get(d.node);c!=null&&i.push([c,a])}return i.sort((a,u)=>a[0]<u[0]?-1:a[0]>u[0]?1:a[1]<u[1]?-1:a[1]>u[1]?1:0),i}mount(e,t){if(t===void 0){let s=new r(e);return this.mount(e,s)}if(typeof t=="function"){let s=new r(e);return t(s),this.mount(e,s)}let n=t;if(Ot(e,this.name,"mount"),this._nodes.has(e))throw new Error(`Graph "${this.name}": cannot mount at "${e}" \u2014 node with that name exists`);if(this._mounts.has(e))throw new Error(`Graph "${this.name}": mount "${e}" already exists`);if(n===this)throw new Error(`Graph "${this.name}": cannot mount a graph into itself`);if(n._parent!=null)throw new Error(`Graph "${this.name}": this child graph is already mounted on "${n._parent.name}"`);for(let s=this;s!=null;s=s._parent)if(s===n)throw new Error(`Graph "${this.name}": mount("${e}", \u2026) would create a mount cycle`);return this._mounts.set(e,n),n._parent=this,this._emitTopology({kind:"added",name:e,nodeKind:"mount"}),n}resolve(e){let t=_r(e,this.name);return this._resolveFromSegments(t)}tryResolve(e){try{return this.resolve(e)}catch{return}}_resolveFromSegments(e){let t=e;if(t[0]===this.name&&(t=t.slice(1),t.length===0))throw new Error(`Graph "${this.name}": resolve path ends at graph name only`);let n=t[0],s=t.slice(1);if(s.length===0){let a=this._nodes.get(n);if(a)return a;throw this._mounts.has(n)?new Error(`Graph "${this.name}": path ends at subgraph "${n}" \u2014 not a node (GRAPHREFLY-SPEC \xA73.5)`):new Error(`Graph "${this.name}": unknown name "${n}"`)}let o=this._nodes.get(n);if(o&&s.length>0&&s[0]===Z)return this._resolveMetaChainFromNode(o,s,t.join(I));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(I)}" is invalid`):new Error(`Graph "${this.name}": unknown mount or node "${n}"`);return i.resolve(s.join(I))}_resolveMetaChainFromNode(e,t,n){let s=e,o=0,i=[...t];for(;o<i.length;){if(i[o]!==Z)throw new Error(`Graph "${this.name}": expected ${Z} segment in meta path "${n}"`);if(o+1>=i.length)throw new Error(`Graph "${this.name}": meta path requires a key after ${Z} in "${n}"`);let a=i[o+1],u=s.meta[a];if(!u)throw new Error(`Graph "${this.name}": unknown meta "${a}" in path "${n}"`);s=u,o+=2}return s}signal(e,t){if(t?.internal!==!0){for(let s of e)if(this.config.messageTier(s[0])===3)throw new Error(`Graph "${this.name}": Graph.signal() rejects tier-3 messages (DATA / RESOLVED). Broadcast is for control-plane tiers (START / DIRTY / INVALIDATE / PAUSE / RESUME / COMPLETE / ERROR / TEARDOWN). For per-node value writes, use Graph.set or graph.node(name).down(...).`)}let n=[];if(this._signalDeliver(e,t??{},new Set,n),n.length>0)throw n[0]}_signalDeliver(e,t,n,s){for(let u of this._mounts.values())u._signalDeliver(e,t,n,s);let i=t.internal===!0?{internal:!0}:{actor:t.actor,delivery:"signal"},a=wr(e,this.config);for(let u of[...this._nodes.keys()].sort()){let d=this._nodes.get(u);if(!n.has(d)){n.add(d);try{d.down(e,i)}catch(c){if(c instanceof Q)throw c;s.push(c)}a.length!==0&&this._signalMetaSubtree(d,a,n,i,s)}}}_signalMetaSubtree(e,t,n,s,o){for(let i of Object.keys(e.meta).sort()){let a=e.meta[i];if(!n.has(a)){n.add(a);try{a.down(t,s)}catch(u){if(u instanceof Q)throw u;o.push(u)}this._signalMetaSubtree(a,t,n,s,o)}}}describe(e){if(e?.reactive==="diff")return this._describeReactiveDiff(e);if(e?.reactive===!0)return this._describeReactive(e);let t=fr(e?.actor),n=e?.filter;if(e?.detail!=null&&e?.fields!=null)throw new TypeError("Graph.describe(): pass either `detail` or `fields`, not both. `detail: 'spec'` is the canonical spec projection; use `fields` only when you need a custom subset.");let s=Ke(e?.detail,e?.fields),o=e?.detail==="spec",i=s,a=[];this._collectObserveTargets("",a);let u=new Map;for(let[_,T]of a)u.set(T,_);let d=[];{let _=a.map(([,b])=>b),T=new Set(u.values()),O=0;for(;_.length>0;){let b=_.shift();if(b instanceof F)for(let x of b._deps){let N=x.node;if(u.has(N))continue;let E=N.name??"",k=E;if(!k||T.has(k))if(E){let A=2;for(;T.has(`${E}#${A}`);)A++;k=`${E}#${A}`}else for(k=`__internal__/${O++}`;T.has(k);)k=`__internal__/${O++}`;u.set(N,k),T.add(k),d.push([k,N]),_.push(N)}}}let c=[...a,...d],p={};for(let[_,T]of c){if(t!=null&&!T.allowsObserve(t))continue;let O=vt(T,i,o),b=T instanceof F?T._deps.map(k=>u.get(k.node)??k.node.name??""):[],{name:x,...N}=O,E={...N,deps:b};if(!o){let k=this._annotations.get(_);k!=null&&(E.annotation=k)}if(n!=null)if(typeof n=="function"){let k=n;if(!(k.length>=2?k(_,E):k(E)))continue}else{let k=!0;for(let[A,M]of Object.entries(n)){let S=A==="deps_includes"?"depsIncludes":A==="meta_has"?"metaHas":A;if(S==="depsIncludes"){if(!E.deps.includes(String(M))){k=!1;break}continue}if(S==="metaHas"){if(!Object.hasOwn(E.meta??{},String(M))){k=!1;break}continue}if(E[S]!==M){k=!1;break}}if(!k)continue}p[_]=E}let f=new Set(Object.keys(p)),h=[];for(let[_,T]of c)if(T instanceof F)for(let O of T._deps){let b=u.get(O.node);b!=null&&h.push([b,_])}h.sort((_,T)=>_[0]<T[0]?-1:_[0]>T[0]?1:_[1]<T[1]?-1:_[1]>T[1]?1:0);let l=h.map(([_,T])=>({from:_,to:T}));(t!=null||n!=null)&&(l=l.filter(_=>f.has(_.from)&&f.has(_.to)));let v=this._collectSubgraphs(""),g=t!=null||n!=null?v.filter(_=>{let T=`${_}${I}`;return[...f].some(O=>O===_||O.startsWith(T))}):v,w=this,y=e;return{name:this.name,nodes:p,edges:l,subgraphs:g,...this._factory!==void 0?{factory:this._factory}:{},...this._factoryArgs!==void 0?{factoryArgs:this._factoryArgs}:{},expand(_){let T={...y};return Array.isArray(_)?(T.fields=_,T.detail=void 0):(T.detail=_,T.fields=void 0),w.describe(T)}}}_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}${I}`))}return t}resourceProfile(e){return yn(this,e)}reachable(e,t,n={}){return n.withDetail===!0?Et(this.describe(),e,t,{...n,withDetail:!0}):Et(this.describe(),e,t,n)}explain(e,t,n){return n?.reactive===!0?this._explainReactive(e,t,n):this._explainStatic(ce(e),ce(t),{...n?.maxDepth!==void 0?{maxDepth:wn(n.maxDepth)}:{},...n?.findCycle!==void 0?{findCycle:Tn(n.findCycle)}:{}})}_explainStatic(e,t,n){let s=this.describe({detail:"full"}),o=new Map(this._annotations),i=new Map;for(let[a,u]of Object.entries(s.nodes))u.lastMutation!=null&&i.set(a,u.lastMutation);return ln(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=B(s,{name:`${n}_version`}),i=this.observe({timeline:!0,structured:!0}),a=!1,u=!1,d=()=>{a||u||(a=!0,ke(()=>{a=!1,!u&&(s+=1,o.emit(s))}))},c=i.onEvent(y=>{let m=y.type;m!=="data"&&m!=="error"&&m!=="complete"&&m!=="teardown"||d()}),p=[],f=new WeakSet,h=y=>{if(f.has(y)||u)return;f.add(y);let m=y.topology.subscribe(_=>{for(let T of _){if(T[0]!==D)continue;let O=T[1];if(d(),O.kind==="added"&&O.nodeKind==="mount"){let b=y._mounts.get(O.name);b!=null&&h(b)}}});p.push(m);for(let _ of y._mounts.keys()){let T=y._mounts.get(_);T!=null&&h(T)}};h(this);let l,v=e.actor;Nn(v)&&(l=v.subscribe(y=>{let m=!1,_=!1;for(let T of y){let O=T[0];O===D?m=!0:(O===z||O===C||O===j)&&(_=!0)}m&&d(),_&&(l?.(),l=void 0,d())}));let g;try{g=X([o],()=>this.describe(t),{name:n,describeKind:"derived",meta:{domain:"audit",kind:"describe"},equals:(y,m)=>y===m})}catch(y){c(),l?.();for(let m of p)m();throw i.dispose(),y}let w=oe(g);return{node:g,dispose(){u=!0,c(),l?.();for(let y of p)y();p.length=0,i.dispose(),w()}}}_describeReactiveDiff(e){let t={...e,reactive:!1},n=e.reactiveName??"describe-diff",s={name:this.name,nodes:{},edges:[],subgraphs:[]},o=this.describe(t),i=Tt(s,o),a=B(i,{name:n,meta:{domain:"audit",kind:"describe-diff"},equals:(f,h)=>f===h}),u=this._describeReactive({...e,reactiveName:void 0}),d=!1,c=u.node.subscribe(f=>{if(!d)for(let h of f){if(h[0]!==D)continue;let l=h[1],v=Tt(o,l);o=l,v.events.length!==0&&a.emit(v)}}),p=oe(a);return{node:a,dispose(){d=!0,c(),u.dispose(),a.down([[j,"describe-diff disposed"]]),p()}}}_explainReactive(e,t,n){let s=0,o=B(s,{name:"explain_version"}),i=this.observe({timeline:!0,structured:!0}),a=!1,u=!1,d=()=>{a||u||(a=!0,ke(()=>{a=!1,!u&&(s+=1,o.emit(s))}))},c=i.onEvent(y=>{let m=y.type;m!=="data"&&m!=="error"&&m!=="complete"&&m!=="teardown"||d()}),p=[];e!=null&&ve(e)&&p.push(e),t!=null&&ve(t)&&p.push(t),n?.maxDepth!=null&&ve(n.maxDepth)&&p.push(n.maxDepth),n?.findCycle!=null&&ve(n.findCycle)&&p.push(n.findCycle);let f=()=>{for(let y of p)if(y.cache===void 0)return!1;return!0},h=()=>{let y=ce(e),m=ce(t);return{from:y,to:m,found:!1,reason:"pending",steps:[],text:"(awaiting reactive args)",toJSON:()=>({from:y,to:m,found:!1,reason:"pending",steps:[]})}},l;try{l=X([o],()=>{if(!f())return h();let y=ce(e),m=ce(t),_={...n?.maxDepth!==void 0?{maxDepth:wn(n.maxDepth)}:{},...n?.findCycle!==void 0?{findCycle:Tn(n.findCycle)}:{}};return this._explainStatic(y,m,_)},{name:n?.name??"explain",describeKind:"derived",meta:{domain:"audit",kind:"explain_path",from:ce(e),to:ce(t)},equals:(y,m)=>y.found===m.found&&y.reason===m.reason&&y.steps.length===m.steps.length&&Tr(y.steps,m.steps)})}catch(y){throw c(),i.dispose(),y}let v=oe(l),g=[],w=y=>{let m;return m=y.subscribe(_=>{let T=!1,O=!1;for(let b of _){let x=b[0];x===D?T=!0:(x===z||x===C||x===j)&&(O=!0)}(T||O)&&d(),O&&m&&(m(),m=void 0)}),()=>{m&&(m(),m=void 0)}};for(let y of p)g.push(w(y));return{node:l,dispose(){u=!0,c();for(let y of g)y?.();g.length=0,i.dispose(),v()}}}_pathsMatching(e){let t=Ye(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}${I}${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}${I}${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}${I}${Z}${I}${s}`;n.push([i,o]),this._appendMetaObserveTargets(i,o,n)}}observe(e,t){let n=typeof e=="string",o=kn(n?t:e);if(o.reactive===!0)return this._observeReactive(n?e:void 0,o);let i=o.structured===!0||o.timeline===!0||o.causal===!0||o.derived===!0||o.detail==="minimal"||o.detail==="full"||o.format!=null,a=o.actor;if(n){let c=e,p=this.resolve(c);if(a!=null&&!p.allowsObserve(a))throw new Q({actor:a,action:"observe",nodeName:c});return i?this._buildStructuredObserver([[c,p]],o,"one"):{subscribe(f){return p.subscribe(f)},up(f){try{p.up?.(f)}catch(h){if(h instanceof Q)return;throw h}}}}let u=[];this._collectObserveTargets("",u),u.sort((c,p)=>c[0]<p[0]?-1:c[0]>p[0]?1:0);let d=a==null?u:u.filter(([,c])=>c.allowsObserve(a));return i?this._buildStructuredObserver(d,o,"all"):{subscribe:c=>{let p=d.map(([f,h])=>h.subscribe(l=>{c(f,l)}));return()=>{for(let f of p)f()}},up:(c,p)=>{try{this.resolve(c).up?.(p)}catch(f){if(f instanceof Q)return;throw f}}}}_observeReactive(e,t){let n=t.tiers,s=n!=null?new Set(n):null,o=t.reactiveName??"observe";return de(i=>{let a=[],u=!1,d=!1,c=()=>{if(a.length===0||d)return;let v={events:a.slice(),flushedAt_ns:K()};a.length=0,i.emit(v)},p={...t,reactive:!1,structured:!0,timeline:!0},f=e!=null?this.observe(e,p):this.observe(p),h=v=>{d||(a.push(v),!u&&(u=!0,ke(()=>{u=!1,c()})))};for(let v of f.events)h(v);let l=f.onEvent(h);return()=>{d=!0,l(),f.dispose()}},{name:o,meta:{domain:"audit",kind:"observe-reactive"}})}_buildStructuredObserver(e,t,n){let s=n==="one"?e[0]?.[0]:void 0,o=i=>{if(n==="one"&&s!=null){let c=this.resolve(s);return this._buildStructuredObserver([[s,c]],i,"one")}let a=[];this._collectObserveTargets("",a),a.sort((c,p)=>c[0]<p[0]?-1:c[0]>p[0]?1:0);let u=i.actor,d=u==null?a:a.filter(([,c])=>c.allowsObserve(u));return this._buildStructuredObserver(d,i,"all")};return this._createObserveResult(e,t,o)}_createObserveResult(e,t,n){let s=t.timeline===!0,o=t.causal===!0,i=t.derived===!0,a=t.detail==="minimal",u=this.config.inspectorEnabled,d=(o||i)&&u,c=t.maxEvents,p=c!=null&&c>0?new De(c):null,f=[],h=new Set,l=t.tiers!=null?new Set(t.tiers):null,v={},g=new Set,w=0,y=0,m=0,_=0,T=0,O=0,b=!1,x=!1,N=0,E=new Map,k=new Map,A=new Map,M=R=>{if(!(l!=null&&!l.has(R.type))){p?p.push(R):f.push(R);for(let P of h)P(R)}},S=R=>l==null||l.has(R),ie=()=>s?{timestamp_ns:K(),in_batch:Se(),batch_id:N}:{},ne=(R,P)=>{if(!(!d||!(R instanceof F)))return R._setInspectorHook(U=>{if(U.kind==="dep_message")E.set(R,U.depIndex);else if(U.kind==="run"){let Ee=U.batchData.map((G,H)=>G!=null&&G.length>0?G.at(-1):U.prevData[H]);k.set(R,Ee);let J=U.batchData.map(G=>G!=null?[...G]:void 0);A.set(R,J),i&&M({type:"derived",path:P,dep_values:Ee,dep_batches:J,...ie()})}})},Pe=R=>{let P=E.get(R),U=k.get(R);if(!o||U==null)return{};let J=(P!=null&&P>=0&&R instanceof F?R._deps[P]:void 0)?.node,G=J?.v,H=A.get(R);return{trigger_dep_index:P,trigger_dep_name:J?.name,...G!=null?{trigger_version:{id:G.id,version:G.version}}:{},dep_values:[...U],...H!=null?{dep_batches:H}:{}}},Ct=[],Gt=[];for(let[R,P]of e){let U=ne(P,R);U&&Ct.push(U),Gt.push(P.subscribe(Ee=>{N++;for(let J of Ee){let G=J[0],H=ie();if(G===D){v[R]=J[1];let st=P instanceof F?P.lastMutation?.actor??we:we;M({type:"data",path:R,data:J[1],actor:st,...H,...Pe(P)})}else if(a)G===$?S("dirty")&&w++:G===W?S("resolved")&&y++:G===Y?S("invalidate")&&m++:G===ee?S("pause")&&_++:G===re?S("resume")&&T++:G===j?S("teardown")&&O++:G===z&&!g.has(R)?S("complete")&&(b=!0):G===C&&S("error")&&(x=!0,g.add(R));else if(G===$)S("dirty")&&w++,M({type:"dirty",path:R,...H});else if(G===W)S("resolved")&&y++,M({type:"resolved",path:R,...H,...Pe(P)});else if(G===Y)S("invalidate")&&m++,M({type:"invalidate",path:R,...H});else if(G===ee)S("pause")&&_++,M({type:"pause",path:R,lockId:J[1],...H});else if(G===re)S("resume")&&T++,M({type:"resume",path:R,lockId:J[1],...H});else if(G===z)S("complete")&&!g.has(R)&&(b=!0),M({type:"complete",path:R,...H});else if(G===C){S("error")&&(x=!0,g.add(R));let st=P instanceof F?P.lastMutation?.actor??we:we;M({type:"error",path:R,data:J[1],actor:st,...H})}else G===j&&(S("teardown")&&O++,M({type:"teardown",path:R,...H}))}}))}let tt=!1,nt=()=>{if(!tt){tt=!0;for(let R of Gt)R();for(let R of Ct)R();for(let R of Ie)R({value:void 0,done:!0});Ie.length=0}},rt=[],Ie=[];h.add(R=>{let P=Ie.shift();P?P({value:R,done:!1}):rt.push(R)});let Pt={get values(){return v},get dirtyCount(){return w},get resolvedCount(){return y},get invalidateCount(){return m},get pauseCount(){return _},get resumeCount(){return T},get teardownCount(){return O},get events(){return p?p.toArray():[...f]},get anyCompletedCleanly(){return b},get anyErrored(){return x},get completedWithoutErrors(){return b&&!x},onEvent(R){return h.add(R),()=>h.delete(R)},dispose:nt,expand(R){nt();let P={...t};return typeof R=="string"?P.detail=R:Object.assign(P,R),n(kn(P))},[Symbol.asyncIterator](){return{next(){return rt.length>0?Promise.resolve({value:rt.shift(),done:!1}):tt?Promise.resolve({value:void 0,done:!0}):new Promise(R=>Ie.push(R))},return(){return nt(),Promise.resolve({value:void 0,done:!0})}}}};return t.format!=null&&this._attachFormatLogger(Pt,t),Pt}_attachFormatLogger(e,t){let n=t.format;if(n==null)return;let s=t.logger??(l=>console.log(l)),o=t.includeTypes?new Set(t.includeTypes):null,i=t.excludeTypes?new Set(t.excludeTypes):null,a=o==null&&i==null?()=>!0:l=>(o==null||o.has(l))&&(i==null||!i.has(l)),u=yr(t.theme),d=n==="stage-log"?K():0,c=l=>l==null?"":t.stageLabels?.[l]??l,p=(l,v)=>l.length>v?`${l.slice(0,v-1)}\u2026`:l,f=l=>l.type==="data"||l.type==="error"?p(Nt(l.data),120):"",h=l=>{if(n==="stage-log"){let b=(K()-d)/1e9,x=c(l.path).padEnd(9);if(l.type==="data"){let N=f(l);return`[${b.toFixed(3)}s] ${x} \u2190${N?` ${N}`:""}`}if(l.type==="error"){let N=f(l);return`[${b.toFixed(3)}s] ${x} \u2717${N?` ${N}`:""}`}return l.type==="complete"?`[${b.toFixed(3)}s] ${x} \u25A0 complete`:`[${b.toFixed(3)}s] ${x} ${l.type}`}if(n==="json")try{return JSON.stringify(l)}catch{return JSON.stringify({type:l.type,path:l.path,data:"[unserializable]"})}let v=u[l.type]??"",g=l.path?`${u.path}${l.path}${u.reset} `:"",w=l.type==="data"||l.type==="error",y=l.type==="pause"||l.type==="resume",m=w?` ${Nt(l.data)}`:y?` ${Nt(l.lockId)}`:"",_=l.type==="data"||l.type==="resolved"||l.type==="derived"?l:void 0,T=_?.trigger_dep_name!=null?` <- ${_.trigger_dep_name}`:_?.trigger_dep_index!=null?` <- #${_.trigger_dep_index}`:"",O=l.in_batch?" [batch]":"";return`${g}${v}${l.type.toUpperCase()}${u.reset}${m}${T}${O}`};e.onEvent(l=>{a(l.type)&&s(h(l),l)})}addDisposer(e){return this._disposers.add(e),()=>{this._disposers.delete(e)}}destroy(){_n(this._disposers,this.name),this.signal([[j]],{internal:!0}),_n(this._storageDisposers,this.name);for(let e of[...this._mounts.values()])e._parent=void 0,e._destroyClearOnly();this._mounts.clear(),this._nodes.clear(),this._parent=void 0,this._destroyed=!0}get destroyed(){return this._destroyed}_destroyClearOnly(){for(let e of[...this._mounts.values()])e._parent=void 0,e._destroyClearOnly();this._mounts.clear(),this._nodes.clear(),this._parent=void 0,this._destroyed=!0}snapshot(e){let{expand:t,...n}=this.describe({detail:"full"}),s={};for(let a of Object.keys(n.nodes).sort()){let{lastMutation:u,guard:d,...c}=n.nodes[a];s[a]=c}let o=[...n.subgraphs].sort(),i={...n,version:1,nodes:s,subgraphs:o};if(e?.format==null)return i;if(e.format==="json-string")return JSON.stringify(i);if(e.format==="bytes"){if(e.codec==null)throw new Error("snapshot({format: 'bytes'}) requires a `codec` name");let a=this.config.lookupCodec(e.codec);if(a==null)throw new Error(`snapshot: codec "${e.codec}" is not registered on this graph's config. Call config.registerCodec(...) before creating nodes.`);return Kt(a,a.encode(i))}throw new Error(`snapshot: unknown format "${String(e.format)}"`)}static decode(e,t){let n=t?.config??Oe,{codec:s,codecVersion:o,payload:i}=qt(e,n);return s.decode(i,o)}restore(e,t){if(xn(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=>Ye(o)),s=t?.includeProducers===!0;for(let o of Object.keys(e.nodes).sort()){if(n!==null&&!n.some(a=>a.test(o)))continue;let i=e.nodes[o];if(i!==void 0){if(!("value"in i)||i.value===void 0){"value"in i&&i.value===void 0&&t?.onError?.(o,new Error(`restore: slice.value is undefined for "${o}" (undefined is the global SENTINEL; not valid DATA)`));continue}if(!(i.type==="derived"||i.type==="effect")&&!(i.type==="producer"&&!s)){if(i.v!=null){let u=this.tryResolve(o)?.v;if(u!=null&&u.id===i.v.id&&u.version===i.v.version)continue}try{this.set(o,i.value)}catch(a){t?.onError?.(o,a)}}}}}static fromSnapshot(e,t){xn(e);let n=typeof t=="function"?t:t?.build,s=typeof t=="function"?void 0:t?.factories,o=new r(e.name);if(n)return n(o),o.restore(e),o;for(let h of[...e.subgraphs].sort((l,v)=>{let g=l.split(I).length,w=v.split(I).length;return g!==w?g-w:l<v?-1:l>v?1:0})){let l=h.split(I),v=o;for(let g of l)v._mounts.has(g)||v.mount(g,new r(g)),v=v._mounts.get(g)}let i=s?Object.entries(s).map(([h,l])=>({re:Ye(h),factory:l})):[],a=h=>{for(let l of i)if(l.re.test(h))return l.factory},u=h=>{let l=h.split(I),v=l.pop();if(v==null||v.length===0)throw new Error(`invalid snapshot path "${h}"`);let g=o;for(let w of l){let y=g._mounts.get(w);if(!y)throw new Error(`unknown mount "${w}" in path "${h}"`);g=y}return[g,v]},d=Object.entries(e.nodes).filter(([h])=>!h.includes(`${I}${Z}${I}`)).sort((h,l)=>h[0]<l[0]?-1:h[0]>l[0]?1:0),c=new Map(d),p=new Map,f=!0;for(;c.size>0&&f;){f=!1;for(let[h,l]of[...c.entries()]){let v=l?.deps??[];if(!v.every(T=>p.has(T)))continue;let[g,w]=u(h),y={...l?.meta??{}},m=a(h),_;if(l?.type==="state")_=B(l.value,{meta:y});else{if(m==null)continue;_=m(w,{path:h,type:l.type,value:l.value,meta:y,deps:v,resolvedDeps:v.map(T=>p.get(T))})}g.add(_,{name:w}),p.set(h,_),c.delete(h),f=!0}}if(c.size>0){let h=[...c.keys()].sort().join(", ");throw new Error(`Graph.fromSnapshot could not reconstruct nodes without build callback: ${h}. Pass matching factories via fromSnapshot(data, { factories: { pattern: factoryFn } }).`)}return o.restore(e),o}toJSON(){return this.snapshot()}attachSnapshotStorage(e,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,c)=>{if(d.disposed)return;let p=pr(c.nodes);if(d.lastSnapshot!=null&&p!==""&&p===d.lastFingerprint)return;let f=d.seq+1,h=ae(),g=d.lastSnapshot==null||f%d.compactEvery===0?{name:this.name,mode:"full",snapshot:c,seq:f,timestamp_ns:h,format_version:ye}:{name:this.name,mode:"diff",diff:En(d.lastSnapshot,c),seq:f,timestamp_ns:h,format_version:ye};if(d.tier.filter&&!d.tier.filter(g))return;let w;try{w=d.tier.save(g)}catch(y){t.onError?.(y,d.tier);return}if(w&&typeof w.then=="function"){let _=(d.savePending??Promise.resolve()).then(()=>w,()=>w).then(()=>{d.disposed||(d.seq=f,d.lastSnapshot=c,d.lastFingerprint=p)},T=>{t.onError?.(T,d.tier)});d.savePending=_.finally(()=>{d.savePending===_&&(d.savePending=void 0)})}else d.seq=f,d.lastSnapshot=c,d.lastFingerprint=p},o=(d,c)=>{try{s(d,c)}catch(p){t.onError?.(p,d.tier)}},i=(d,c)=>{if(!c.some(l=>{let v=this.config.messageTier(l[0]);return v>=3&&v<5}))return;if(t.filter){let l=this.tryResolve(d);if(l==null)return;let v=vt(l,Ke("standard"));if(!t.filter(d,v))return}let f,h=()=>(f==null&&(f=this.snapshot()),f);for(let l of n)l.disposed||(l.debounceMs===0?o(l,h()):(l.timer==null&&(l.timer=new qe),l.timer.start(l.debounceMs,()=>{l.disposed||o(l,this.snapshot())})))},a;if(t.paths!=null){let c=(typeof t.paths=="string"?this._pathsMatching(t.paths):t.paths).map(p=>{let f=this.tryResolve(p);return f==null?()=>{}:f.subscribe(h=>i(p,h))});a=()=>{for(let p of c)p()}}else a=this.observe().subscribe((d,c)=>i(d,c));let u=()=>{a();for(let d of n)d.disposed=!0,d.timer?.cancel();this._storageDisposers.delete(u)};return this._storageDisposers.add(u),{dispose:u}}async _cascadeRestore(e,t){for(let n of e){let s;try{s=await n.load?.()}catch(i){t?.(i,n);continue}if(s==null||typeof s!="object"||Array.isArray(s))continue;let o=s;try{if(o.mode==="full"&&o.snapshot!=null)return this.restore(o.snapshot),!0;if(o.version===ye&&o.nodes!=null)return this.restore(o),!0}catch(i){t?.(i,n)}}return!1}static async fromStorage(e,t,n){for(let s of t){let o;try{o=await s.load?.()}catch(u){n?.onError?.(u,s);continue}if(o==null||typeof o!="object"||Array.isArray(o))continue;let i=o,a=i.mode==="full"&&i.snapshot!=null?i.snapshot:i.version===ye&&i.nodes!=null?i:void 0;if(a!=null)try{return r.fromSnapshot(a,n)}catch(u){n?.onError?.(u,s)}}throw new Error(`Graph.fromStorage: no tier held a restorable record for "${e}" across ${t.length} tier(s)`)}_annotations=new Map;_traceRing;trace(e,t,n){if(e!=null&&t!=null){if(this.tryResolve(e)==null)return;if(this._annotations.set(e,t),this.config.inspectorEnabled){let s={path:e,annotation:t,timestamp_ns:K(),...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(y=>!n.has(y)).sort(),i=[...n].filter(y=>!s.has(y)).sort(),a=[],u=[];for(let y of n){if(!s.has(y))continue;let m=e.nodes[y],_=t.nodes[y],T=m.v,O=_.v;T!=null&&O!=null&&T.id===O.id&&T.version!==O.version&&u.push({path:y,id:T.id,from:T.version,to:O.version});let b=T!=null&&O!=null&&T.id===O.id&&T.version===O.version;for(let x of["type","status","sentinel"]){let N=m[x],E=_[x];N!==E&&a.push({path:y,field:x,from:N,to:E})}if(!b)for(let x of["value","meta"]){let N=m[x],E=_[x];hr(N,E)||a.push({path:y,field:x,from:N,to:E})}}let d=y=>`${y.from} ${y.to}`,c=new Set(e.edges.map(d)),p=new Set(t.edges.map(d)),f=t.edges.filter(y=>!c.has(d(y))),h=e.edges.filter(y=>!p.has(d(y))),l=new Set(e.subgraphs),v=new Set(t.subgraphs),g=[...v].filter(y=>!l.has(y)).sort(),w=[...l].filter(y=>!v.has(y)).sort();return{nodesAdded:o,nodesRemoved:i,nodesChanged:a,versionChanges:u,edgesAdded:f,edgesRemoved:h,subgraphsAdded:g,subgraphsRemoved:w}}}});var Pn=L(()=>{"use strict";Rn()});var Ar={};Vn(Ar,{JobFlowGraph:()=>et,JobQueueGraph:()=>Ze,jobEventKeyOf:()=>Er,jobFlow:()=>Rr,jobQueue:()=>In});module.exports=jn(Ar);le();$e();he();Ne();te();_t();ue();be();nn();le();Ne();te();ue();he();te();be();ue();var Rt=class{_version=0;_maxSize;_buf;_head=0;_size=0;constructor(e,t){if(t!==void 0&&t<1)throw new RangeError("maxSize must be >= 1");if(this._maxSize=t,t!==void 0){if(this._buf=new Array(t),e&&e.length>0){let n=Math.min(e.length,t),s=e.length-n;for(let o=0;o<n;o++)this._buf[o]=e[s+o];this._size=n}}else this._buf=e?[...e]:[],this._size=this._buf.length}get version(){return this._version}get size(){return this._size}at(e){if(!Number.isInteger(e))return;let t=e>=0?e:this._size+e;if(!(t<0||t>=this._size))return this._maxSize!==void 0?this._buf[(this._head+t)%this._maxSize]:this._buf[t]}append(e){this._rawAppend(e),this._version+=1}appendMany(e){if(e.length===0)return;let t=this._maxSize!==void 0&&e.length>this._maxSize?e.length-this._maxSize:0;for(let n=t;n<e.length;n++)this._rawAppend(e[n]);this._version+=1}clear(){if(this._size===0)return 0;let e=this._size;if(this._maxSize===void 0)this._buf.length=0;else for(let t=0;t<e;t++)this._buf[(this._head+t)%this._maxSize]=void 0;return this._head=0,this._size=0,this._version+=1,e}trimHead(e){if(!Number.isInteger(e)||e<0)throw new RangeError(`trimHead: n must be a non-negative integer (got ${e})`);if(e===0||this._size===0)return 0;let t=Math.min(e,this._size);if(this._maxSize===void 0)this._buf.splice(0,t);else{for(let n=0;n<t;n++)this._buf[(this._head+n)%this._maxSize]=void 0;this._head=(this._head+t)%this._maxSize}return this._size-=t,this._version+=1,t}slice(e,t){if(!Number.isInteger(e)||e<0)throw new RangeError(`slice: start must be a non-negative integer (got ${e})`);if(t!==void 0&&(!Number.isInteger(t)||t<0))throw new RangeError(`slice: stop must be a non-negative integer or undefined (got ${t})`);let n=t===void 0?this._size:Math.min(Math.max(t,0),this._size),s=Math.min(e,this._size);if(s>=n)return[];let o=n-s;if(this._maxSize===void 0)return this._buf.slice(s,n);let i=new Array(o);for(let a=0;a<o;a++)i[a]=this._buf[(this._head+s+a)%this._maxSize];return i}tail(e){if(!Number.isInteger(e)||e<0)throw new RangeError(`tail: n must be a non-negative integer (got ${e})`);if(e===0||this._size===0)return[];let t=Math.min(e,this._size);return this.slice(this._size-t,this._size)}toArray(){if(this._maxSize===void 0)return[...this._buf];let e=new Array(this._size);for(let t=0;t<this._size;t++)e[t]=this._buf[(this._head+t)%this._maxSize];return e}snapshot(){return this.toArray()}restore(e){if(this._maxSize===void 0){this._buf.length=0;for(let t=0;t<e.length;t++)this._buf.push(e[t]);this._size=this._buf.length}else{let t=this._maxSize;for(let o=0;o<t;o++)this._buf[o]=void 0;this._head=0;let n=Math.min(e.length,t),s=e.length-n;for(let o=0;o<n;o++)this._buf[o]=e[s+o];this._size=n}this._version+=1}_rawAppend(e){if(this._maxSize===void 0){this._buf.push(e),this._size=this._buf.length;return}this._size<this._maxSize?(this._buf[(this._head+this._size)%this._maxSize]=e,this._size+=1):(this._buf[this._head]=e,this._head=(this._head+1)%this._maxSize)}};function Ce(r){return r.subscribe(()=>{})}var xr=64;function Qe(r,e={}){let{name:t,maxSize:n,versioning:s,guard:o,backend:i}=e,a=i??new Rt(r,n),u=B(a.toArray(),{name:t,describeKind:"state",equals:(b,x)=>b===x,...s!=null?{versioning:s}:{},...o!=null?{guard:o}:{}});function d(){let b=a.toArray();q(()=>{u.down([[$]],{internal:!0}),u.down([[D,b]],{internal:!0})})}let c=new Map,p=new Map,f=new Map;function h(b,x){return`${b}:${x===void 0?"END":x}`}function l(b){if(b.size<xr)return;let x=b.keys().next();if(x.done)return;let N=b.get(x.value);N!==void 0&&N.dispose(),b.delete(x.value)}function v(b){let x=a.version;try{return b()}finally{a.version!==x&&d()}}function g(b){if(!Number.isInteger(b)||b<0)throw new RangeError(`tail: n must be a non-negative integer (got ${b})`);let x=c.get(b);if(x!==void 0)return c.delete(b),c.set(b,x),x.node;l(c);let N=X([u],([k])=>{let A=k;return b===0||A.length===0?[]:A.slice(Math.max(0,A.length-b))},{initial:a.tail(b),describeKind:"derived"}),E=Ce(N);return c.set(b,{node:N,dispose:E}),N}function w(b,x){if(!Number.isInteger(b)||b<0)throw new RangeError(`slice: start must be a non-negative integer (got ${b})`);if(x!==void 0&&(!Number.isInteger(x)||x<0))throw new RangeError(`slice: stop must be a non-negative integer or undefined (got ${x})`);let N=h(b,x),E=p.get(N);if(E!==void 0)return p.delete(N),p.set(N,E),E.node;l(p);let k=X([u],([M])=>{let S=M;return x===void 0?S.slice(b):S.slice(b,x)},{initial:a.slice(b,x),describeKind:"derived"}),A=Ce(k);return p.set(N,{node:k,dispose:A}),k}function y(b){let x=f.get(b);if(x!==void 0)return x.node;let N=X([u,b],([k,A])=>{let M=k,S=Math.max(0,Math.trunc(A??0));return M.slice(S)},{initial:[],describeKind:"derived"}),E=Ce(N);return f.set(b,{node:N,dispose:E}),N}let m,_;function T(){m===void 0&&(m=se([u],(b,x,N)=>{let E=b[0],A=E!=null&&E.length>0?E.at(-1):N.prevData[0];if(A==null||A.length===0){x.down([[W]]);return}x.emit(A[A.length-1])},{name:t!=null?`${t}::lastValue`:"lastValue",describeKind:"derived",initial:a.size===0?void 0:a.at(a.size-1)}),_=X([u],([b])=>b.length>0,{name:t!=null?`${t}::hasLatest`:"hasLatest",describeKind:"derived",initial:a.size>0}),Ce(m),Ce(_))}let O={entries:u,get size(){return a.size},at(b){return a.at(b)},append(b){v(()=>a.append(b))},appendMany(b){b.length!==0&&v(()=>a.appendMany(b))},clear(){v(()=>a.clear())},trimHead(b){v(()=>a.trimHead(b))},withLatest(){return T(),u},get lastValue(){return T(),m},get hasLatest(){return T(),_},view(b){switch(b.kind){case"tail":return g(b.n);case"slice":return w(b.start,b.stop);case"fromCursor":return y(b.cursor)}},attach(b){let x=b.subscribe(N=>{for(let E of N)E[0]===D&&O.append(E[1])});return()=>x()},attachStorage(b){if(b.length===0)return()=>{};let x=new Map;for(let E of b)x.set(E,a.size);(async()=>{for(let E of b)if(typeof E.loadEntries=="function")try{let k=await Promise.resolve(E.loadEntries());k.entries.length>0&&a.size===0&&(a.restore(k.entries),x.set(E,k.entries.length),d());break}catch{}})();let N=u.subscribe(E=>{for(let k of E){if(k[0]!==D)continue;let A=k[1];for(let M of b){let S=x.get(M)??0;if(A.length<S){try{let ne=M.appendEntries(A);ne instanceof Promise&&ne.catch(()=>{})}catch{}x.set(M,A.length);continue}if(A.length===S)continue;let ie=A.slice(S);x.set(M,A.length);try{let ne=M.appendEntries(ie);ne instanceof Promise&&ne.catch(()=>{})}catch{}}}});return()=>N()},disposeAllViews(){for(let b of c.values())b.dispose();c.clear();for(let b of p.values())b.dispose();p.clear();for(let b of f.values())b.dispose();f.clear()},dispose(){for(let b of c.values())b.dispose();c.clear();for(let b of p.values())b.dispose();p.clear();for(let b of f.values())b.dispose();f.clear()}};return O}var kr=Bt((r,e)=>{r("observe"),r("signal"),e("write")});function Sn(r){let e=Qe([],{name:r.name,maxSize:r.retainedLimit??1024,guard:r.guard??kr,...r.versioning!=null?{versioning:r.versioning}:{}});return e.withLatest(),r.graph&&r.graph.add(e.entries,{name:r.name}),e}function Mn(r){if(r===null||typeof r!="object"||Object.isFrozen(r))return r;for(let e of Object.keys(r))Mn(r[e]);return Object.freeze(r)}function At(r){let e=r.cache,n=(typeof e=="number"&&Number.isFinite(e)?e:0)+1;return r.down([[$],[D,n]]),n}function An(r,e,t,n,s,o){let i=e(t,n,s);if(i===void 0)return;let a=o!=null?{...i,handlerVersion:o}:i;r.append(a)}function Ge(r,e){let t=e.freeze??!0;return function(...s){let o=t?s.map(Mn):s,i=ae(),a=e.seq?At(e.seq):void 0;try{let u=r(...o);return e.audit&&e.onSuccess&&An(e.audit,e.onSuccess,o,u,{t_ns:i,seq:a},e.handlerVersion),u}catch(u){if(e.audit&&e.onFailure){let d=u instanceof Error?u.name:typeof u;An(e.audit,e.onFailure,o,u,{t_ns:i,seq:a,errorType:d},e.handlerVersion)}throw u}}}function Dn(r,e,t=0){let n=B(t,{name:e,describeKind:"state"});return r.add(n,{name:e}),n}he();te();ue();var St=class{_version=0;_buf;constructor(e){this._buf=e?[...e]:[]}get version(){return this._version}get size(){return this._buf.length}at(e){if(!Number.isInteger(e))return;let t=e>=0?e:this._buf.length+e;if(!(t<0||t>=this._buf.length))return this._buf[t]}append(e){this._buf.push(e),this._version+=1}appendMany(e){if(e.length===0)return;let t=this._buf.length;this._buf.length=t+e.length;for(let n=0;n<e.length;n++)this._buf[t+n]=e[n];this._version+=1}insert(e,t){if(!Number.isInteger(e)||e<0||e>this._buf.length)throw new RangeError(`insert: index ${e} out of range [0, ${this._buf.length}]`);this._buf.splice(e,0,t),this._version+=1}insertMany(e,t){if(!Number.isInteger(e)||e<0||e>this._buf.length)throw new RangeError(`insertMany: index ${e} out of range [0, ${this._buf.length}]`);t.length!==0&&(this._buf.splice(e,0,...t),this._version+=1)}pop(e){if(this._buf.length===0)throw new RangeError("pop from empty list");if(!Number.isInteger(e))throw new RangeError(`pop: index ${e} must be an integer`);let t=e>=0?e:this._buf.length+e;if(t<0||t>=this._buf.length)throw new RangeError(`pop: index ${e} out of range`);let[n]=this._buf.splice(t,1);return this._version+=1,n}clear(){let e=this._buf.length;return e===0?0:(this._buf.length=0,this._version+=1,e)}toArray(){return[...this._buf]}};function Cn(r,e={}){let{name:t,versioning:n,backend:s}=e,o=s??new St(r),i=B(o.toArray(),{name:t,describeKind:"state",equals:(d,c)=>d===c,...n!=null?{versioning:n}:{}});function a(){let d=o.toArray();q(()=>{i.down([[$]]),i.down([[D,d]])})}function u(d){let c=o.version;try{return d()}finally{o.version!==c&&a()}}return{items:i,get size(){return o.size},at(d){return o.at(d)},append(d){u(()=>o.append(d))},appendMany(d){u(()=>o.appendMany(d))},insert(d,c){u(()=>o.insert(d,c))},insertMany(d,c){u(()=>o.insertMany(d,c))},pop(d=-1){return u(()=>o.pop(d))},clear(){u(()=>o.clear())},dispose(){}}}he();le();te();ue();var Mt=class{_version=0;_store=new Map;_maxSize;_defaultTtl;constructor(e={}){let{maxSize:t,defaultTtl:n}=e;if(t!==void 0&&t<1)throw new RangeError("maxSize must be >= 1");if(n!==void 0&&n<=0)throw new RangeError("defaultTtl must be positive");this._maxSize=t,this._defaultTtl=n}get version(){return this._version}get size(){return this._store.size}has(e){let t=this._store.get(e);return t===void 0?!1:this._isExpired(t)?(this._store.delete(e),this._version+=1,!1):(this._touchLru(e,t),!0)}get(e){let t=this._store.get(e);if(t!==void 0){if(this._isExpired(t)){this._store.delete(e),this._version+=1;return}return this._touchLru(e,t),t.value}}set(e,t,n){let s=this._resolveExpiresAt(n);this._store.has(e)&&this._store.delete(e),this._store.set(e,{value:t,expiresAt:s}),this._evictLruWhileOver(),this._version+=1}setMany(e,t){let n=this._resolveExpiresAt(t),s=0;try{for(let[o,i]of e)this._store.has(o)&&this._store.delete(o),this._store.set(o,{value:i,expiresAt:n}),s+=1}finally{s>0&&(this._evictLruWhileOver(),this._version+=1)}}delete(e){let t=this._store.delete(e);return t&&(this._version+=1),t}deleteMany(e){let t=0;try{for(let n of e)this._store.delete(n)&&(t+=1)}finally{t>0&&(this._version+=1)}return t}clear(){let e=this._store.size;return e===0?0:(this._store.clear(),this._version+=1,e)}pruneExpired(){let e=K(),t=0;for(let[n,s]of this._store)this._isExpired(s,e)&&(this._store.delete(n),t+=1);return t>0&&(this._version+=1),t}toMap(){let e=K(),t=new Map;for(let[n,s]of this._store)this._isExpired(s,e)||t.set(n,s.value);return t}_resolveExpiresAt(e){let t=e??this._defaultTtl;if(t!==void 0){if(!Number.isFinite(t)||t<=0)throw new RangeError(`MapBackend: ttl must be a positive finite number (got ${t})`);return K()+t*1e9}}_isExpired(e,t){return e.expiresAt===void 0?!1:(t??K())>=e.expiresAt}_touchLru(e,t){this._store.delete(e),this._store.set(e,t)}_evictLruWhileOver(){if(this._maxSize!==void 0)for(;this._store.size>this._maxSize;){let e=this._store.keys().next().value;if(e===void 0)break;this._store.delete(e)}}};function Gn(r={}){let{name:e,maxSize:t,defaultTtl:n,versioning:s,backend:o,retention:i}=r;if(i&&t!==void 0)throw new RangeError("reactiveMap: `maxSize` (LRU) and `retention` (score-based) are mutually exclusive. Pick one eviction policy.");if(i&&i.archiveThreshold===void 0&&i.maxSize===void 0)throw new RangeError("reactiveMap: `retention` requires at least one of `archiveThreshold` or `maxSize` to trigger archival.");let a=o??new Mt({maxSize:t,defaultTtl:n}),u=B(a.toMap(),{name:e,describeKind:"state",equals:(f,h)=>f===h,...s!=null?{versioning:s}:{}});function d(){let f=a.toMap();q(()=>{u.down([[$]]),u.down([[D,f]])})}function c(){if(!i)return;let f=a.toMap(),h=i.archiveThreshold,l=i.maxSize,v=[];for(let[w,y]of f)v.push({key:w,value:y,score:i.score(w,y)});v.sort((w,y)=>w.score-y.score);let g=new Set;if(h!==void 0)for(let w of v)if(w.score<h)g.add(w.key);else break;if(l!==void 0&&v.length-g.size>l)for(let w of v){if(v.length-g.size<=l)break;g.has(w.key)||g.add(w.key)}if(g.size!==0)for(let w of v)g.has(w.key)&&(i.onArchive?.(w.key,w.value,w.score),a.delete(w.key))}function p(f,h="mutation"){let l=a.version;try{return f()}finally{a.version!==l&&(h==="mutation"&&c(),d())}}return{entries:u,has(f){return p(()=>a.has(f),"read")},get(f){return p(()=>a.get(f),"read")},set(f,h,l){p(()=>a.set(f,h,l?.ttl))},setMany(f,h){p(()=>a.setMany(f,h?.ttl))},delete(f){p(()=>a.delete(f))},deleteMany(f){p(()=>a.deleteMany(f))},clear(){p(()=>a.clear())},pruneExpired(){p(()=>a.pruneExpired())},get size(){return a.size},dispose(){}}}kt();Pn();var Nr=256,Or=1024;function Dt(r,e){if(!Number.isFinite(r)||!Number.isInteger(r)||r<0)throw new Error(`${e} must be a non-negative integer`);return r}function Xe(r,e){return tn("job_queue",r,e)}var Er=r=>r.action,Ze=class extends _e{_pending;_jobs;_seqCursor;pending;jobs;depth;events;audit;_enqueueImpl;_ackImpl;_nackImpl;_removeByIdImpl;constructor(e,t={}){super(e,t.graph),this._pending=Cn([],{name:"pending"}),this._jobs=Gn({name:"jobs"}),this.pending=this._pending.items,this.jobs=this._jobs.entries,this.add(this.pending,{name:"pending"}),this.add(this.jobs,{name:"jobs"}),this.depth=X([this.pending],([n])=>n.length,{name:"depth",describeKind:"derived",meta:Xe("queue_depth"),initial:0}),this.add(this.depth,{name:"depth"}),this.addDisposer(oe(this.depth)),this.events=Sn({name:"events",retainedLimit:1024,graph:this}),this.audit=this.events,this._seqCursor=Dn(this,"seq",0),this._enqueueImpl=Ge((n,s)=>{let o=this._seqCursor.cache,i=s.id??`${this.name}-${o}`;if(this._jobs.get(i)!==void 0)throw new Error(`jobQueue("${this.name}"): duplicate job id "${i}"`);let a={id:i,payload:n,attempts:0,metadata:Object.freeze({...s.metadata??{}}),state:"queued"};return this._jobs.set(i,a),this._pending.append(i),i},{audit:this.events,seq:this._seqCursor,freeze:!1,onSuccess:([n],s,{t_ns:o,seq:i})=>({action:"enqueue",id:s,payload:n,t_ns:o,seq:i??0})}),this._ackImpl=Ge((n,s)=>{this._jobs.delete(n)},{audit:this.events,seq:this._seqCursor,freeze:!1,onSuccess:([n,s],o,{t_ns:i,seq:a})=>({action:"ack",id:n,attempts:s.attempts,t_ns:i,seq:a??0})}),this._nackImpl=Ge((n,s,o)=>{o?(this._jobs.set(n,{...s,state:"queued"}),this._pending.append(n)):this._jobs.delete(n)},{audit:this.events,seq:this._seqCursor,freeze:!1,onSuccess:([n,s],o,{t_ns:i,seq:a})=>({action:"nack",id:n,attempts:s.attempts,t_ns:i,seq:a??0})}),this._removeByIdImpl=Ge((n,s)=>{if(s.state==="queued"){let i=this.pending.cache.indexOf(n);i>=0&&this._pending.pop(i)}this._jobs.delete(n)},{audit:this.events,seq:this._seqCursor,freeze:!1,onSuccess:([n,s],o,{t_ns:i,seq:a})=>({action:"remove",id:n,attempts:s.attempts,t_ns:i,seq:a??0})})}attachEventStorage(e){return this.events.attachStorage(e)}enqueue(e,t={}){return this._enqueueImpl(e,t)}claim(e=1){let t=Dt(e,"job queue claim limit");if(t===0)return[];let n=[];for(;n.length<t&&this.pending.cache.length!==0;){let o=this._pending.pop(0),i=this._jobs.get(o);if(!i||i.state!=="queued")continue;let a={...i,state:"inflight",attempts:i.attempts+1};this._jobs.set(o,a),n.push(a),this.events.append({action:"claim",id:o,attempts:a.attempts,t_ns:ae(),seq:At(this._seqCursor)})}return n}ack(e){let t=this._jobs.get(e);return!t||t.state!=="inflight"?!1:(this._ackImpl(e,t),!0)}nack(e,t={}){let n=this._jobs.get(e);return!n||n.state!=="inflight"?!1:(this._nackImpl(e,n,t.requeue??!0),!0)}removeById(e){let t=this._jobs.get(e);return t?(this._removeByIdImpl(e,t),!0):!1}consumeFrom(e,t){return e.subscribe(n=>{for(let s of n){if(s[0]!==D)continue;let o=s[1];this.enqueue(o,t?{metadata:t.metadata}:void 0)}})}},et=class extends _e{_stageNames;_stageWorkFns;_queues=new Map;_completed;completed;completedCount;constructor(e,t={}){super(e,t.graph);let n=t.stages??["incoming","processing","done"],s=[],o=new Map,i=new Map;for(let d of n){let c=typeof d=="string"?d.trim():d.name.trim();typeof d!="string"&&d.work&&o.set(c,d.work),typeof d!="string"&&d.maxPerPump!=null&&i.set(c,Math.max(1,Dt(d.maxPerPump,`job flow stage "${c}" maxPerPump`))),s.push(c)}if(s.length<2)throw new Error(`jobFlow("${e}"): requires at least 2 stages`);if(new Set(s).size!==s.length)throw new Error(`jobFlow("${e}"): stage names must be unique`);this._stageNames=Object.freeze([...s]),this._stageWorkFns=o;for(let d of this._stageNames){let c=In(`${e}-${d}`);this._queues.set(d,c),this.mount(d,c)}this._completed=Qe([],{name:"completed",maxSize:Or}),this.completed=this._completed.entries,this.add(this.completed,{name:"completed"}),this.completedCount=X([this.completed],([d])=>d.length,{name:"completedCount",describeKind:"derived",meta:Xe("job_flow_completed_count"),initial:0}),this.add(this.completedCount,{name:"completedCount"}),this.addDisposer(oe(this.completedCount));let u=Math.max(1,Dt(t.maxPerPump??Nr,"job flow maxPerPump"));for(let d=0;d<this._stageNames.length;d+=1){let c=this._stageNames[d],p=this.queue(c),f=d+1<this._stageNames.length?this.queue(this._stageNames[d+1]):null,h=this._stageWorkFns.get(c),l=i.get(c)??u,v=f===null;if(h){let g=se([p.pending],()=>{let w=0;for(;w<l;){let y=p.claim(1);if(y.length===0)break;let m=y[0];if(!m)break;let T=[...m.metadata.job_flow_path??[],c],O;try{O=h(m)}catch{p.nack(m.id,{requeue:!1}),w+=1;continue}let b=an(O),x=!1,N;N=b.subscribe(E=>{if(!x){for(let k of E)if(k[0]===D){x=!0,N?N():Promise.resolve().then(()=>N?.());let A=k[1],M={...m.metadata,job_flow_path:T};if(v){let S={...m,payload:A,metadata:Object.freeze(M)};q(()=>{p.ack(m.id),this._completed.append(S)})}else q(()=>{p.ack(m.id),f.enqueue(A,{metadata:M})});return}else if(k[0]===C){x=!0,N?N():Promise.resolve().then(()=>N?.()),p.nack(m.id,{requeue:!1});return}}}),w+=1}},{name:`pump_${c}`,describeKind:"effect",meta:Xe("job_flow_pump",{stage:c,has_work:!0})});this.add(g,{name:`pump_${c}`}),this.addDisposer(oe(g))}else{let g=se([p.pending],()=>{let w=0;for(;w<l;){let y=p.claim(1);if(y.length===0)break;let m=y[0];if(!m)break;let T=[...m.metadata.job_flow_path??[],c],O={...m.metadata,job_flow_path:T};if(v){let b={...m,metadata:Object.freeze(O)};q(()=>{p.ack(m.id),this._completed.append(b)})}else q(()=>{p.ack(m.id),f.enqueue(m.payload,{metadata:O})});w+=1}},{name:`pump_${c}`,describeKind:"effect",meta:Xe("job_flow_pump",{stage:c,has_work:!1})});this.add(g,{name:`pump_${c}`}),this.addDisposer(oe(g))}}}stages(){return this._stageNames}queue(e){let t=this._queues.get(e);if(!t)throw new Error(`jobFlow("${this.name}"): unknown stage "${e}"`);return t}enqueue(e,t={}){return this.queue(this._stageNames[0]).enqueue(e,t)}retainedCompleted(){return this.completed.cache}};function In(r,e){return new Ze(r,e)}function Rr(r,e){let t=new et(r,e),{factory:n,factoryArgs:s,...o}=e??{};return t.tagFactory("jobFlow",yt(o)),t}0&&(module.exports={JobFlowGraph,JobQueueGraph,jobEventKeyOf,jobFlow,jobQueue});
1
+ "use strict";var lt=Object.defineProperty;var Fn=Object.getOwnPropertyDescriptor;var Vn=Object.getOwnPropertyNames;var zn=Object.prototype.hasOwnProperty;var $=(r,e)=>()=>(r&&(e=r(r=0)),e);var jn=(r,e)=>{for(var t in e)lt(r,t,{get:e[t],enumerable:!0})},Bn=(r,e,t,n)=>{if(e&&typeof e=="object"||typeof e=="function")for(let s of Vn(e))!zn.call(r,s)&&s!==t&&lt(r,s,{get:()=>e[s],enumerable:!(n=Fn(e,s))||n.enumerable});return r};var Hn=r=>Bn(lt({},"__esModule",{value:!0}),r);function W(){return Math.trunc(performance.now()*1e6)}function ue(){return Date.now()*1e6}var he=$(()=>{"use strict"});function Be(r){if(r==null)return Oe;let{type:e,id:t,...n}=r;return{type:e??"system",id:t??"",...n}}var Oe,He=$(()=>{"use strict";Oe={type:"system",id:""}});function $e(){return Ee>0||Ie}function Ft(){return Ee>0}function Ae(r){Ee>0?Pe.push(r):r()}function H(r){Ee+=1;let e=!1;try{r()}catch(t){throw e=!0,t}finally{if(Ee-=1,Ee===0)if(e){if(!Ie){let t=Pe.splice(0);for(let n of t)try{n()}catch{}ge.length=0,me.length=0,Re.length=0}}else Kn()}}function Kn(){let r=!Ie;r&&(Ie=!0);let e=[],t=0;try{for(;ge.length>0||me.length>0||Re.length>0||r&&Pe.length>0;){if(r&&Pe.length>0){let o=Pe.splice(0);for(let i of o)try{i()}catch(a){e.push(a)}continue}if(t+=1,t>1e3)throw ge.length=0,me.length=0,Re.length=0,new Error("batch drain exceeded 1000 iterations \u2014 likely a reactive cycle");let s=(ge.length>0?ge:me.length>0?me:Re).splice(0);for(let o of s)try{o()}catch(i){e.push(i)}}}finally{r&&(Ie=!1)}if(e.length===1)throw e[0];if(e.length>1)throw new AggregateError(e,"batch drain: multiple callbacks threw")}function Le(r,e,t){if(e.length===0)return;if(e.length===1){let u=t(e[0][0]);if(u<3||!$e()){r(e);return}(u>=5?Re:u===4?me:ge).push(()=>r(e));return}let n=e.length,s=n,o=n,i=n,a=0;for(;a<n&&t(e[a][0])<3;)a++;for(s=a;a<n&&t(e[a][0])===3;)a++;for(o=a;a<n&&t(e[a][0])===4;)a++;i=a;let d=$e();if(s>0){let u=e.slice(0,s);r(u)}if(o>s){let u=e.slice(s,o);d?ge.push(()=>r(u)):r(u)}if(i>o){let u=e.slice(o,i);d?me.push(()=>r(u)):r(u)}if(n>i){let u=e.slice(i,n);d?Re.push(()=>r(u)):r(u)}}var Ee,Ie,ge,me,Re,Pe,be=$(()=>{"use strict";Ee=0,Ie=!1,ge=[],me=[],Re=[],Pe=[]});var ye,M,L,U,X,ne,ie,j,F,C,ve,Ke,Vt,qe,zt,jt,We,ft,pt,ht,Ue,re=$(()=>{"use strict";ye=Symbol.for("graphrefly/START"),M=Symbol.for("graphrefly/DATA"),L=Symbol.for("graphrefly/DIRTY"),U=Symbol.for("graphrefly/RESOLVED"),X=Symbol.for("graphrefly/INVALIDATE"),ne=Symbol.for("graphrefly/PAUSE"),ie=Symbol.for("graphrefly/RESUME"),j=Symbol.for("graphrefly/TEARDOWN"),F=Symbol.for("graphrefly/COMPLETE"),C=Symbol.for("graphrefly/ERROR"),ve=Object.freeze([L]),Ke=Object.freeze([U]),Vt=Object.freeze([X]),qe=Object.freeze([ye]),zt=Object.freeze([F]),jt=Object.freeze([j]),We=Object.freeze([ve]),ft=Object.freeze([Ke]),pt=Object.freeze([Vt]),ht=Object.freeze([zt]),Ue=Object.freeze([jt])});function Bt(r){r.registerMessageType(ye,{tier:0,wireCrossing:!1}),r.registerMessageType(L,{tier:1,wireCrossing:!1}),r.registerMessageType(X,{tier:1,wireCrossing:!1,metaPassthrough:!1}),r.registerMessageType(ne,{tier:2,wireCrossing:!1}),r.registerMessageType(ie,{tier:2,wireCrossing:!1}),r.registerMessageType(M,{tier:3,wireCrossing:!0}),r.registerMessageType(U,{tier:3,wireCrossing:!0}),r.registerMessageType(F,{tier:4,wireCrossing:!0,metaPassthrough:!1}),r.registerMessageType(C,{tier:4,wireCrossing:!0,metaPassthrough:!1}),r.registerMessageType(j,{tier:5,wireCrossing:!0,metaPassthrough:!1})}var Je,Ht=$(()=>{"use strict";re();Je=class{_messageTypes=new Map;_codecs=new Map;_onMessage;_onSubscribe;_defaultVersioning;_defaultHashFn;_inspectorEnabled=!(typeof process<"u"&&process.env?.NODE_ENV==="production");_globalInspector;_rigorRecorder;_frozen=!1;tierOf;constructor(e){this._onMessage=e.onMessage,this._onSubscribe=e.onSubscribe,this._defaultVersioning=e.defaultVersioning,this._defaultHashFn=e.defaultHashFn,this.tierOf=t=>{let n=this._messageTypes.get(t);return n!=null?n.tier:1}}get onMessage(){return this._frozen=!0,this._onMessage}get onSubscribe(){return this._frozen=!0,this._onSubscribe}set onMessage(e){this._assertUnfrozen(),this._onMessage=e}set onSubscribe(e){this._assertUnfrozen(),this._onSubscribe=e}get defaultVersioning(){return this._defaultVersioning}set defaultVersioning(e){this._assertUnfrozen(),this._defaultVersioning=e}get defaultHashFn(){return this._defaultHashFn}set defaultHashFn(e){this._assertUnfrozen(),this._defaultHashFn=e}get inspectorEnabled(){return this._inspectorEnabled}set inspectorEnabled(e){this._inspectorEnabled=e}get globalInspector(){return this._globalInspector}set globalInspector(e){this._globalInspector=e}get rigorRecorder(){return this._rigorRecorder}set rigorRecorder(e){this._rigorRecorder=e}registerMessageType(e,t){return this._assertUnfrozen(),this._messageTypes.set(e,{tier:t.tier,wireCrossing:t.wireCrossing??t.tier>=3,metaPassthrough:t.metaPassthrough??!0}),this}messageTier(e){let t=this._messageTypes.get(e);return t!=null?t.tier:1}isWireCrossing(e){let t=this._messageTypes.get(e);return t!=null?t.wireCrossing:!0}isLocalOnly(e){return!this.isWireCrossing(e)}isMetaPassthrough(e){let t=this._messageTypes.get(e);return t!=null?t.metaPassthrough:!0}isKnownMessageType(e){return this._messageTypes.has(e)}registerCodec(e){return this._assertUnfrozen(),this._codecs.set(e.name,e),this}lookupCodec(e){return this._codecs.get(e)}_isFrozen(){return this._frozen}_assertUnfrozen(){if(this._frozen)throw new Error("GraphReFlyConfig is frozen: a node has already captured this config. Register custom types and set hooks before creating any node.")}}});function Kt(r){return Array.isArray(r)?[...r]:[r]}function qn(r,e){return r.has(e)||r.has("*")}function qt(r){let e=[];return r((s,o)=>{e.push({kind:"allow",actions:new Set(Kt(s)),where:o?.where??(()=>!0)})},(s,o)=>{e.push({kind:"deny",actions:new Set(Kt(s)),where:o?.where??(()=>!0)})}),(s,o)=>{let i=!1,a=!1;for(let d of e)qn(d.actions,o)&&d.where(s)&&(d.kind==="deny"?i=!0:a=!0);return i?!1:a}}function gt(r){let e=Wn.filter(t=>r({type:t,id:""},"write"));return e.length===0?"restricted":e.includes("human")&&e.includes("llm")&&e.every(t=>t==="human"||t==="llm"||t==="system")?"both":e.length===1?e[0]:e.join("+")}var Z,Wn,Se=$(()=>{"use strict";Z=class extends Error{actor;action;nodeName;constructor(e,t){super(t??`GuardDenied: action "${String(e.action)}" denied for actor type "${String(e.actor.type)}"`),this.name="GuardDenied",this.actor=e.actor,this.action=e.action,this.nodeName=e.nodeName}get node(){return this.nodeName}};Wn=["human","llm","wallet","system"]});function Ut(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++]=mt,o[i++]=t.length,o.set(t,i),i+=t.length,o[i++]=n>>>8&255,o[i++]=n&255,o.set(e,i),o}function Jt(r,e){if(r.length<Wt)throw new Error(`decodeEnvelope: bytes too short (${r.length} < ${Wt})`);let t=0,n=r[t++];if(n!==mt)throw new Error(`decodeEnvelope: unsupported envelope version ${n} (expected ${mt})`);let s=r[t++];if(s===0)throw new Error("decodeEnvelope: name_len must be >= 1");if(t+s+2>r.length)throw new Error(`decodeEnvelope: envelope truncated (need ${t+s+2} bytes, have ${r.length})`);let o=new TextDecoder().decode(r.subarray(t,t+s));t+=s;let i=(r[t]<<8|r[t+1])>>>0;t+=2;let a=r.subarray(t),d=e.lookupCodec(o);if(d==null)throw new Error(`decodeEnvelope: codec "${o}" not registered (envelope codec_v=${i})`);return{codec:d,codecVersion:i,payload:a}}function Yt(r){r.registerCodec(Un)}var Un,mt,Wt,bt=$(()=>{"use strict";Un={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)}},mt=1,Wt=4});function yt(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(yt);if(typeof r=="object"&&r!==null){let e={};for(let t of Object.keys(r).sort())e[t]=yt(r[t]);return e}return null}function Qn(r){let e=Yn.encode(r),t=e.length,n=t*8,s=t+9+63&-64,o=new Uint8Array(s);o.set(e),o[t]=128;let i=new DataView(o.buffer);i.setUint32(s-4,n>>>0,!1),i.setUint32(s-8,Math.floor(n/4294967296)>>>0,!1);let a=1779033703,d=3144134277,u=1013904242,c=2773480762,f=1359893119,p=2600822924,h=528734635,l=1541459225,y=new Uint32Array(64),g=(v,b)=>v>>>b|v<<32-b;for(let v=0;v<s;v+=64){for(let k=0;k<16;k++)y[k]=i.getUint32(v+k*4,!1);for(let k=16;k<64;k++){let A=y[k-15],D=y[k-2],S=g(A,7)^g(A,18)^A>>>3,te=g(D,17)^g(D,19)^D>>>10;y[k]=y[k-16]+S+y[k-7]+te>>>0}let b=a,_=d,T=u,O=c,m=f,x=p,N=h,E=l;for(let k=0;k<64;k++){let A=g(m,6)^g(m,11)^g(m,25),D=m&x^~m&N,S=E+A+D+Jn[k]+y[k]>>>0,te=g(b,2)^g(b,13)^g(b,22),K=b&_^b&T^_&T,pe=te+K>>>0;E=N,N=x,x=m,m=O+S>>>0,O=T,T=_,_=b,b=S+pe>>>0}a=a+b>>>0,d=d+_>>>0,u=u+T>>>0,c=c+O>>>0,f=f+m>>>0,p=p+x>>>0,h=h+N>>>0,l=l+E>>>0}let w=v=>v.toString(16).padStart(8,"0");return w(a)+w(d)+w(u)+w(c)+w(f)+w(p)+w(h)+w(l)}function vt(r){let e=yt(r??null),t=JSON.stringify(e);return Qn(t).slice(0,16)}function Xn(){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 _t(r,e,t){let n=t?.id??Xn();if(r===0)return{id:n,version:0};let o=(t?.hash??vt)(e);return{id:n,version:0,cid:o,prev:null}}function Qt(r,e,t){r.version+=1,"cid"in r&&(r.prev=r.cid,r.cid=t(e))}var Jn,Yn,Xt=$(()=>{"use strict";Jn=new Uint32Array([1116352408,1899447441,3049323471,3921009573,961987163,1508970993,2453635748,2870763221,3624381080,310598401,607225278,1426881987,1925078388,2162078206,2614888103,3248222580,3835390401,4022224774,264347078,604807628,770255983,1249150122,1555081692,1996064986,2554220882,2821834349,2952996808,3210313671,3336571891,3584528711,113926993,338241895,666307205,773529912,1294757372,1396182291,1695183700,1986661051,2177026350,2456956037,2730485921,2820302411,3259730800,3345764771,3516065817,3600352804,4094571909,275423344,430227734,506948616,659060556,883997877,958139571,1322822218,1537002063,1747873779,1955562222,2024104815,2227730452,2361852424,2428436474,2756734187,3204031479,3329325298]),Yn=new TextEncoder});function tn(r){return{node:r,unsub:null,prevData:void 0,dirty:!1,involvedThisWave:!1,dataBatch:[],terminal:void 0}}function wt(r){r.prevData=void 0,r.dirty=!1,r.involvedThisWave=!1,r.dataBatch.length=0,r.terminal=void 0}function Ye(r){return r.length===0?r:typeof r[0]=="symbol"?[r]:r}function se(r,e,t){let n=nn(r)?r:[],s=typeof r=="function"?r:typeof e=="function"?e:void 0,o={};return nn(r)?o=(Tt(e)?e:t)??{}:Tt(r)?o=r:o=(Tt(e)?e:t)??{},new V(n,s,o)}var Zt,en,Zn,er,Me,V,nn,Tt,_e=$(()=>{"use strict";bt();He();be();he();Ht();Se();re();Xt();Zt=()=>{},en=100;Zn=(r,e,t,n)=>{t.direction==="down-in"&&r._onDepMessage(t.depIndex,e)},er=(r,e,t,n)=>{let s=r;if(s._status==="completed"||s._status==="errored")return;let o=s._cached,i=o===void 0?[qe]:[qe,[M,o]];s._status==="dirty"&&i.push(ve),Le(e,i,s._config.tierOf)},Me=new Je({onMessage:Zn,onSubscribe:er});Bt(Me);Yt(Me);V=class r{_optsName;_describeKind;meta;_hasMeta;_config;_deps;_sinks=null;_sinkCount=0;_cached;_status;_cleanup;_store={};_waveHasNewData=!1;_hasNewTerminal=!1;_hasCalledFnOnce=!1;_paused=!1;_pendingWave=!1;_isExecutingFn=!1;_pendingRerun=!1;_rerunDepth=0;_dirtyDepCount=0;_batchPendingMessages=null;_pauseLocks=null;_pauseBuffer=null;_fn;_equals;_resubscribable;_resetOnTeardown;_autoComplete;_autoError;_pausable;_partial;_guard;_extraGuards;_hashFn;_versioning;_versioningLevel;_lastMutation;_inspectorHooks;_actions;constructor(e,t,n){this._config=n.config??Me,this._config.onMessage,this._optsName=n.name,this._describeKind=n.describeKind,this._equals=n.equals??Object.is,this._resubscribable=n.resubscribable??!1,this._resetOnTeardown=n.resetOnTeardown??!1,this._autoComplete=n.completeWhenDepsComplete??!0,this._autoError=n.errorWhenDepsError??!0,this._pausable=n.pausable??!0,this._guard=n.guard,this._fn=t,this._partial=n.partial??!1,this._cached=n.initial!==void 0?n.initial:void 0,this._status=e.length===0&&t==null&&this._cached!==void 0?"settled":"sentinel",this._hashFn=n.versioningHash??this._config.defaultHashFn??vt;let s=n.versioning??this._config.defaultVersioning;this._versioningLevel=s,this._versioning=s!=null?_t(s,this._cached===void 0?void 0:this._cached,{id:n.versioningId,hash:this._hashFn}):void 0,this._deps=e.map(tn);let o={};for(let[a,d]of Object.entries(n.meta??{})){let u={initial:d,name:`${n.name??"node"}:meta:${a}`,describeKind:"state",config:this._config};n.guard!=null&&(u.guard=n.guard),n.resubscribable===!0&&(u.resubscribable=!0),o[a]=new r([],void 0,u)}Object.freeze(o),this.meta=o,this._hasMeta=Object.keys(o).length>0;let i=this;this._actions={emit(a){i._emit([[M,a]])},down(a){i._emit(Ye(a))},up(a){i._emitUp(Ye(a))}},this.down=this.down.bind(this),this.up=this.up.bind(this)}get _isTerminal(){return this._status==="completed"||this._status==="errored"}get name(){return this._optsName}get status(){return this._status}get cache(){return this._cached===void 0?void 0:this._cached}get lastMutation(){return this._lastMutation}get v(){return this._versioning}hasGuard(){return this._guard!=null}_applyVersioning(e,t){if(this._isExecutingFn)throw new Error(`Node "${this.name}": _applyVersioning cannot run mid-fn \u2014 call it outside of \`_execFn\` (typically at graph setup time before the first subscribe).`);let n=this._versioningLevel;if(n!=null&&e<=n)return;let s=t?.hash??this._hashFn;s!==this._hashFn&&(this._hashFn=s);let o=this._cached===void 0?void 0:this._cached,i=this._versioning,a=i?.id??t?.id,d=i?.version??0,u=_t(e,o,{id:a,hash:s});u.version=d,this._versioning=u,this._versioningLevel=e}_setInspectorHook(e){return e==null?()=>{}:(this._inspectorHooks==null&&(this._inspectorHooks=new Set),this._inspectorHooks.add(e),()=>{this._inspectorHooks?.delete(e),this._inspectorHooks?.size===0&&(this._inspectorHooks=void 0)})}_pushGuard(e){return this._extraGuards==null&&(this._extraGuards=new Set),this._extraGuards.add(e),()=>{this._extraGuards?.delete(e),this._extraGuards?.size===0&&(this._extraGuards=void 0)}}allowsObserve(e){if(this._guard==null&&this._extraGuards==null)return!0;let t=Be(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=Be(e?.actor),o=e?.delivery==="signal"?"signal":"write";if(this._guard!=null&&!this._guard(s,o))throw new Z({actor:s,action:o,nodeName:this.name});if(this._extraGuards!=null){for(let i of this._extraGuards)if(!i(s,o))throw new Z({actor:s,action:o,nodeName:this.name})}this._lastMutation={actor:s,timestamp_ns:ue()}}down(e,t){let n=Ye(e);n.length!==0&&(this._checkGuard(t),this._emit(n))}emit(e,t){this._checkGuard(t),this._emit([[M,e]])}up(e,t){if(this._deps.length===0)return;let n=Ye(e);if(n.length===0)return;this._checkGuard(t);let s=t??{internal:!0};this._validateUpTiers(n);for(let o of this._deps)o.node.up?.(n,s)}_emitUp(e){if(this._deps.length!==0&&e.length!==0){this._validateUpTiers(e);for(let t of this._deps)t.node.up?.(e,{internal:!0})}}_validateUpTiers(e){let t=this._config.tierOf;for(let n of e){let s=t(n[0]);if(s===3||s===4)throw new Error(`Node "${this.name}": tier-${s} messages cannot flow up \u2014 DATA/RESOLVED/COMPLETE/ERROR are downstream-only. Use \`down(...)\` for value delivery; \`up(...)\` is for control signals (DIRTY, INVALIDATE, PAUSE, RESUME, TEARDOWN).`)}}subscribe(e,t){if(t!=null&&this._guard!=null){let d=Be(t);if(!this._guard(d,"observe"))throw new Z({actor:d,action:"observe",nodeName:this.name})}let s=this._isTerminal&&this._resubscribable;if(s){this._cached=void 0,this._status="sentinel",this._store={},this._hasCalledFnOnce=!1,this._waveHasNewData=!1,this._hasNewTerminal=!1,this._paused=!1,this._pendingWave=!1,this._pendingRerun=!1,this._isExecutingFn=!1,this._rerunDepth=0,this._dirtyDepCount=0,this._pauseLocks=null,this._pauseBuffer=null;for(let d of this._deps)wt(d);if(this._partial===!1){for(let d of this._deps)if(d.prevData!==void 0||d.dataBatch.length!==0||d.terminal!==void 0||d.dirty)throw new Error(`resubscribable-reset invariant: DepRecord not fully reset for node ${this._optsName??"(anonymous)"}`)}}this._sinkCount+=1;let o;try{o=this._config.onSubscribe(this,e,{sinkCount:this._sinkCount,afterTerminalReset:s},this._actions)}catch(d){throw this._sinkCount-=1,d}this._sinks==null?this._sinks=e:typeof this._sinks=="function"?this._sinks=new Set([this._sinks,e]):this._sinks.add(e);let i=this._isTerminal;if(this._sinkCount===1&&!i)try{this._activate()}catch(d){if(this._sinkCount-=1,this._removeSink(e),this._sinkCount===0&&(this._status="sentinel"),typeof o=="function")try{o()}catch{}throw d}this._status==="sentinel"&&this._cached===void 0&&(this._status="pending");let a=!1;return()=>{a||(a=!0,this._sinkCount-=1,this._removeSink(e),typeof o=="function"&&o(),this._sinks==null&&this._deactivate())}}_removeSink(e){if(this._sinks===e)this._sinks=null;else if(this._sinks!=null&&typeof this._sinks!="function")if(this._sinks.delete(e),this._sinks.size===1){let[t]=this._sinks;this._sinks=t}else this._sinks.size===0&&(this._sinks=null)}_activate(){if(this._deps.length===0){this._fn&&this._execFn();return}this._dirtyDepCount=0;let e=this._deps.length,t=0;try{for(let n=0;n<e;n++){let s=n,o=this._deps[n];o.unsub=Zt,o.unsub=o.node.subscribe(i=>{if(o.unsub===null)return;let a=this._config.tierOf,d=!1;for(let u of i)a(u[0])>=3&&(d=!0),this._config.onMessage(this,u,{direction:"down-in",depIndex:s},this._actions);d&&this._maybeRunFnOnSettlement()}),t++}}catch(n){this._deps[t].unsub=null;for(let s=0;s<t;s++){let o=this._deps[s];if(o.unsub!=null){let i=o.unsub;o.unsub=null;try{i()}catch{}wt(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=tn(e);if(this._deps.push(n),this._sinks==null)return t;n.dirty=!0,this._dirtyDepCount++,this._status!=="dirty"&&this._emit(We),n.unsub=Zt;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([[C,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([[C,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{}}wt(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!==ye){if(s===L){this._depDirtied(n);return}if(s===X){if(this._depInvalidated(n),this._cached===void 0)return;this._emit(pt);return}if(s===ne||s===ie){this._emit([t]);return}if(s===j){this._emit(Ue);return}if(s===M)this._depSettledAsData(n,t[1]);else if(s===U)this._depSettledAsResolved(n);else if(s===F)this._depSettledAsTerminal(n,!0);else if(s===C)this._depSettledAsTerminal(n,t[1]);else{this._emit([t]);return}if(!this._fn){(s===M||s===U)&&this._emit([t]),(s===F||s===C)&&this._maybeAutoTerminalAfterWave();return}}}_depDirtied(e){e.dirty||(e.dirty=!0,e.involvedThisWave=!0,this._dirtyDepCount++,this._status!=="dirty"&&this._emit(We))}_depSettledAsData(e,t){e.dirty&&(e.dirty=!1,this._dirtyDepCount--),e.involvedThisWave=!0,e.dataBatch.push(t),this._waveHasNewData=!0}_depSettledAsResolved(e){e.dirty&&(e.dirty=!1,this._dirtyDepCount--)}_depSettledAsTerminal(e,t){e.dirty&&(e.dirty=!1,this._dirtyDepCount--),e.terminal=t,e.involvedThisWave=!0,this._hasNewTerminal=!0}_depInvalidated(e){e.prevData=void 0,e.terminal=void 0,e.dataBatch.length=0,e.dirty?e.involvedThisWave=!1:(e.dirty=!0,e.involvedThisWave=!0,this._dirtyDepCount++)}_maybeRunFnOnSettlement(){if(!(this._isTerminal&&!this._resubscribable)&&!(this._dirtyDepCount>0)){if(!this._partial&&!this._hasCalledFnOnce)for(let e=0;e<this._deps.length;e++){let t=this._deps[e];if(t.dataBatch.length===0&&t.prevData===void 0&&t.terminal===void 0){this._maybeAutoTerminalAfterWave();return}}if(this._paused){this._pendingWave=!0;return}if(!this._waveHasNewData&&!this._hasNewTerminal&&this._hasCalledFnOnce){this._clearWaveFlags(),this._emit(ft),this._maybeAutoTerminalAfterWave();return}this._fn&&this._execFn(),this._maybeAutoTerminalAfterWave()}}_maybeAutoTerminalAfterWave(){if(this._deps.length===0||this._isTerminal)return;let e=this._deps.find(t=>t.terminal!==void 0&&t.terminal!==!0);if(e!=null){this._autoError&&this._emit([[C,e.terminal]]);return}this._autoComplete&&this._deps.every(t=>t.terminal!==void 0)&&this._emit(ht)}_execFn(){if(!this._fn||this._isTerminal&&!this._resubscribable)return;if(this._isExecutingFn){this._pendingRerun=!0;return}let e=this._cleanup;if(typeof e=="function"){this._cleanup=void 0;try{e()}catch(i){this._emit([[C,this._wrapFnError("cleanup threw",i)]]);return}}else if(e!=null&&typeof e=="object"){let i=e.beforeRun;if(typeof i=="function"){e.beforeRun=void 0;try{i()}catch(a){this._emit([[C,this._wrapFnError("cleanup.beforeRun threw",a)]]);return}}}let t=this._deps.map(i=>i.involvedThisWave?i.dataBatch.length>0?[...i.dataBatch]:[]:void 0),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([[C,this._wrapFnError("fn threw",i)]])}finally{this._isExecutingFn=!1,this._pendingRerun?(this._pendingRerun=!1,this._rerunDepth+=1,this._rerunDepth>en?(this._rerunDepth=0,this._emit([[C,new Error(`Node "${this.name}": _pendingRerun depth exceeded ${en} \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"?[ve,e[0]]:e;let n=!0,s=!1,o=!1,i=-1;for(let d of e){let u=t(d[0]);u<i&&(n=!1),u===3&&(s=!0),d[0]===L&&(o=!0),i=u}let a=e;if(!n){let d=e.map((u,c)=>({m:u,i:c,tier:t(u[0])}));d.sort((u,c)=>u.tier-c.tier||u.i-c.i),a=d.map(u=>u.m)}if(s&&!o&&this._status!=="dirty"){let d=0;for(;d<a.length&&t(a[d][0])===0;)d++;return d===0?[ve,...a]:[...a.slice(0,d),ve,...a.slice(d)]}return a}_emit(e){if(e.length===0)return;for(let a=0;a<e.length;a++){let d=e[a];if(d[0]===C&&d[1]===void 0)throw new TypeError('[ERROR, payload] requires a non-undefined payload (spec \xA71.2). Pass an Error object or domain tag instead \u2014 e.g. node.down([[ERROR, new Error("reason")]])')}let t=e;if(this._isTerminal&&!this._resubscribable){let a=e.filter(d=>d[0]===j||d[0]===X);if(a.length===0)return;t=a}t=this._frameBatch(t);let s=null;for(let a=0;a<t.length;a++){let d=t[a],u=d[0];if(u!==ne&&u!==ie){s?.push(d);continue}if(d.length<2)throw new Error(`Node "${this.name}": [[${u===ne?"PAUSE":"RESUME"}]] must carry a lockId payload \u2014 bare PAUSE/RESUME is a protocol violation (C0 rule). Use \`[[PAUSE, lockId]]\` / \`[[RESUME, lockId]]\`.`);let c=!0;if(this._pausable!==!1){let f=d[1];if(u===ne)this._pauseLocks==null&&(this._pauseLocks=new Set),this._pauseLocks.add(f),this._paused=!0,this._pausable==="resumeAll"&&this._pauseBuffer==null&&(this._pauseBuffer=[]);else if(this._pauseLocks==null||!this._pauseLocks.has(f))c=!1;else if(this._pauseLocks.delete(f),this._pauseLocks.size===0){if(this._paused=!1,this._pauseBuffer!=null&&this._pauseBuffer.length>0){let p=this._pauseBuffer;this._pauseBuffer=[],this._emit(p)}this._pendingWave&&(this._pendingWave=!1,this._maybeRunFnOnSettlement())}}c?s?.push(d):s==null&&(s=t.slice(0,a))}if(s!=null){if(s.length===0)return;t=s}if(this._hasMeta&&t.some(a=>a[0]===j))for(let a of Object.keys(this.meta))try{this.meta[a]._emit(Ue)}catch{}let{finalMessages:o,equalsError:i}=this._updateState(t);if(o.length>0&&this._config.inspectorEnabled){let a=this._config.globalInspector;if(a!=null)try{a({kind:"emit",node:this,messages:o})}catch{}}if(o.length>0)if(this._paused&&this._pausable==="resumeAll"&&this._pauseBuffer!=null){let a=this._config.tierOf,d=[];for(let u of o)a(u[0])===3?this._pauseBuffer.push(u):d.push(u);d.length>0&&this._dispatchOrAccumulate(d)}else this._dispatchOrAccumulate(o);i!=null&&this._emit([[C,i]])}_updateState(e){let t=this._config.tierOf,n,s,o=-1,i=0;for(let c of e)t(c[0])===3&&i++;let a=i<=1,d=-1;if(this._versioning!=null&&i>1){for(let c=e.length-1;c>=0;c--)if(e[c][0]===M){d=c;break}}for(let c=0;c<e.length;c++){let f=e[c],p=f[0];if(p===M){if(f.length>=2){let h=!1;if(a&&this._cached!==void 0)try{h=this._equals(this._cached,f[1])}catch(l){s=this._wrapFnError("equals threw",l),o=c;break}if(h){n==null&&(n=e.slice(0,c)),n.push(Ke),this._status="resolved";continue}this._cached=f[1],this._versioning!=null&&(d<0||c===d)&&Qt(this._versioning,f[1],this._hashFn)}this._status="settled",n?.push(f)}else if(n?.push(f),p===L)this._status="dirty";else if(p===U)this._status="resolved";else if(p===F){this._status="completed";{let h=this._config.rigorRecorder;if(h!=null)try{h.onTerminalTransition(this,"completed",this._autoComplete,this._autoError,this._deps.length>0)}catch{}}}else if(p===C){this._status="errored";{let h=this._config.rigorRecorder;if(h!=null)try{h.onTerminalTransition(this,"errored",this._autoComplete,this._autoError,this._deps.length>0)}catch{}}}else if(p===X){if(this._cached!==void 0){let l=this._config.rigorRecorder;if(l!=null)try{l.onNonVacuousInvalidate(this,this._cached)}catch{}}this._cached=void 0,this._status="dirty";let h=this._cleanup;if(typeof h=="function"){this._cleanup=void 0;try{h()}catch{}}else if(h!=null&&typeof h=="object"){let l=h.invalidate;if(typeof l=="function")try{l()}catch{}}}else p===j&&(this._resetOnTeardown&&(this._cached=void 0),this._deactivate(!0),this._status="sentinel")}let u=o>=0?n??e.slice(0,o):n??e;return s!=null?{finalMessages:u,equalsError:s}:{finalMessages:u}}_deliverToSinks=e=>{if(this._sinks==null)return;if(typeof this._sinks=="function"){this._sinks(e);return}let t=[...this._sinks];for(let n of t)n(e)};_dispatchOrAccumulate(e){if(Ft()){this._batchPendingMessages===null&&(this._batchPendingMessages=[],Ae(()=>this._flushBatchPending()));for(let t of e)this._batchPendingMessages.push(t);return}Le(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);Le(this._deliverToSinks,t,this._config.tierOf)}},nn=r=>Array.isArray(r),Tt=r=>typeof r=="object"&&r!=null&&!Array.isArray(r)});function Qe(r,e){if(e!=null&&e.length>0)return new Set(e);switch(r){case"standard":return new Set(["type","status","value","deps","meta","v"]);case"full":return null;case"spec":return new Set(["type","deps","meta","value"]);default:return new Set(["type","deps"])}}function tr(r){return r._describeKind!=null?r._describeKind:r._deps.length>0?"derived":r._fn!=null?"producer":"state"}function kt(r){let e=new WeakSet,t={};for(let[n,s]of rn(r))t[n]=xt(s,e);return t}function xt(r,e){if(r==null)return r;let t=typeof r;if(t==="boolean"||t==="number"||t==="string")return r;if(t==="function")return"<function>";if(Array.isArray(r))return e.has(r)?"<cycle>":(e.add(r),r.map(n=>xt(n,e)));if(t==="object"){let n=r;if(e.has(n))return"<cycle>";e.add(n);try{if(typeof n.subscribe=="function"&&"cache"in n)return"<Node>"}catch{return"<unserializable>"}let s={};for(let[o,i]of rn(n))s[o]=xt(i,e);return s}return"<unserializable>"}function rn(r){let e=[],t;try{t=Object.keys(r)}catch{return e}for(let n of t)try{e.push([n,r[n]])}catch{e.push([n,"<unserializable>"])}return e}function nr(r){let e={};for(let[t,n]of Object.entries(r.meta))try{e[t]=n.cache}catch{}return e}function Nt(r,e,t){let n=e==null,s=!n&&e!=null?[...e].filter(c=>c.startsWith("meta.")).map(c=>c.slice(5)):null,o=n||e.has("meta")||s!=null&&s.length>0,i="state",a=[];r instanceof V&&(i=tr(r),a=r._deps.map(c=>c.node.name??""));let d={type:i,deps:a};(n||e.has("status"))&&(d.status=r.status);let u=r instanceof V?r._guard:void 0;if(o){let c={...nr(r)};if(u!=null&&c.access===void 0&&(c.access=gt(u)),s!=null&&s.length>0&&!e.has("meta")){let f={};for(let p of s)p in c&&(f[p]=c[p]);d.meta=f}else d.meta=c}if(r.name!=null&&(d.name=r.name),(n||e.has("value"))&&(!t||i==="state")){r.status==="sentinel"&&(d.sentinel=!0);try{d.value=r.cache}catch{}}if((n||e.has("v"))&&r.v!=null){let c={id:r.v.id,version:r.v.version};"cid"in r.v&&(c.cid=r.v.cid,c.prev=r.v.prev),d.v=c}return(n||e.has("guard"))&&u!=null&&(d.guard=gt(u)),(n||e.has("lastMutation"))&&r.lastMutation!=null&&(d.lastMutation=r.lastMutation),d}var Ot=$(()=>{"use strict";Se();_e()});function B(r,e){return se([],{...e,initial:r})}function ce(r,e){return se((n,s,o)=>r(s,o)??void 0,{describeKind:"producer",...e})}function J(r,e,t){return se(r,(s,o,i)=>{let a=s.map((d,u)=>d!=null&&d.length>0?d.at(-1):i.prevData[u]);o.emit(e(a,i))},{describeKind:"derived",...t})}function Et(r,e,t){return se(r,(s,o,i)=>{let a=s.map((d,u)=>d!=null&&d.length>0?d.at(-1):i.prevData[u]);return e(a,o,i)??void 0},{describeKind:"effect",...t})}var le=$(()=>{"use strict";_e()});function sn(r,e,t){return{[r]:!0,[`${r}_type`]:e,...t??{}}}var on=$(()=>{"use strict"});function Rt(r,e){if(Object.is(r,e))return!0;if(r==null||e==null||typeof r!="object"||typeof e!="object")return!1;if(Array.isArray(r)){if(!Array.isArray(e)||r.length!==e.length)return!1;for(let o=0;o<r.length;o++)if(!Rt(r[o],e[o]))return!1;return!0}if(Array.isArray(e))return!1;let t=Object.keys(r),n=Object.keys(e);if(t.length!==n.length)return!1;let s=new Set(n);for(let o of t)if(!s.has(o)||!Rt(r[o],e[o]))return!1;return!0}function an(r,e){return`${r}\0${e}`}function At(r,e){let t=[],n=new Set(r.subgraphs),s=new Set(e.subgraphs),o=[];for(let g of s)n.has(g)||o.push(g);o.sort();for(let g of o)t.push({type:"subgraph-mounted",path:g});let i=new Set(Object.keys(r.nodes)),a=new Set(Object.keys(e.nodes)),d=[];for(let g of a)i.has(g)||d.push(g);d.sort();for(let g of d)t.push({type:"node-added",path:g,node:{...e.nodes[g]}});let u=[];for(let g of a){if(!i.has(g))continue;let w=r.nodes[g]?.meta,v=e.nodes[g]?.meta;w==null&&v==null||Rt(w??{},v??{})||u.push(g)}u.sort();for(let g of u)t.push({type:"node-meta-changed",path:g,prevMeta:r.nodes[g]?.meta??{},nextMeta:e.nodes[g]?.meta??{}});let c=new Map;for(let g of r.edges)c.set(an(g.from,g.to),g);let f=new Map;for(let g of e.edges)f.set(an(g.from,g.to),g);let p=[];for(let[g,w]of f)c.has(g)||p.push(w);p.sort((g,w)=>g.from<w.from?-1:g.from>w.from?1:g.to<w.to?-1:g.to>w.to?1:0);for(let g of p)t.push({type:"edge-added",from:g.from,to:g.to});let h=[];for(let[g,w]of c)f.has(g)||h.push(w);h.sort((g,w)=>g.from<w.from?-1:g.from>w.from?1:g.to<w.to?-1:g.to>w.to?1:0);for(let g of h)t.push({type:"edge-removed",from:g.from,to:g.to});let l=[];for(let g of i)a.has(g)||l.push(g);l.sort();for(let g of l)t.push({type:"node-removed",path:g});let y=[];for(let g of n)s.has(g)||y.push(g);y.sort();for(let g of y)t.push({type:"subgraph-unmounted",path:g});return{events:t,flushedAt_ns:W()}}var dn=$(()=>{"use strict";he()});function St(r){return{describeKind:"producer",...r}}function un(r,e){return ce(t=>{let n=!1;try{for(let s of r){if(n)return;t.emit(s)}n||t.down([[F]])}catch(s){n||t.down([[C,s]])}return()=>{n=!0}},St(e))}function rr(r){return r!=null&&typeof r.then=="function"}function sr(r,e){let{signal:t,...n}=e??{};return ce(s=>{let o=!1,i=()=>{o||(o=!0,s.down([[C,t.reason]]))};if(t?.aborted){i();return}return t?.addEventListener("abort",i,{once:!0}),Promise.resolve(r).then(a=>{o||(o=!0,t?.removeEventListener("abort",i),s.emit(a),s.down([[F]]))},a=>{o||(o=!0,t?.removeEventListener("abort",i),s.down([[C,a]]))}),()=>{o=!0,t?.removeEventListener("abort",i)}},St(n))}function or(r,e){let{signal:t,...n}=e??{};return ce(s=>{let o=new AbortController,i=()=>o.abort(t?.reason);t?.aborted?o.abort(t.reason):t?.addEventListener("abort",i,{once:!0});let a=t??o.signal,d=!1,u=r[Symbol.asyncIterator](),c=()=>{d||a.aborted||Promise.resolve(u.next()).then(f=>{if(!(d||a.aborted)){if(f.done){s.down([[F]]);return}s.emit(f.value),c()}},f=>{!d&&!a.aborted&&s.down([[C,f]])})};return c(),()=>{d=!0,t?.removeEventListener("abort",i),o.abort(),Promise.resolve(u.return?.()).catch(()=>{})}},St(n))}function ir(r){return r!=null&&typeof r=="object"&&"cache"in r&&typeof r.subscribe=="function"}function Xe(r,e){if(ir(r))return r;if(rr(r))return sr(r,e);if(r!=null){let t=r;if(typeof t[Symbol.asyncIterator]=="function")return or(r,e);if(typeof t[Symbol.iterator]=="function")return un(r,e)}return ar(r)}function ar(...r){return un(r,void 0)}function ae(r){return r.subscribe(()=>{})}var cn=$(()=>{"use strict";re();le()});var Mt=$(()=>{"use strict";cn()});var Ze,ln=$(()=>{"use strict";Ze=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 Fe,fn=$(()=>{"use strict";Fe=class{constructor(e){this.capacity=e;if(!Number.isInteger(e)||e<=0)throw new Error(`RingBuffer capacity must be a positive integer (got ${e})`);this.buf=new Array(e)}buf;head=0;_size=0;get size(){return this._size}get maxSize(){return this.capacity}push(e){let t=(this.head+this._size)%this.capacity;this.buf[t]=e,this._size<this.capacity?this._size++:this.head=(this.head+1)%this.capacity}shift(){if(this._size===0)return;let e=this.buf[this.head];return this.buf[this.head]=void 0,this.head=(this.head+1)%this.capacity,this._size--,e}at(e){if(this._size===0)return;let t=e<0?this._size+e:e;if(!(t<0||t>=this._size))return this.buf[(this.head+t)%this.capacity]}toArray(){let e=new Array(this._size);for(let t=0;t<this._size;t++)e[t]=this.buf[(this.head+t)%this.capacity];return e}clear(){for(let e=0;e<this._size;e++)this.buf[(this.head+e)%this.capacity]=void 0;this.head=0,this._size=0}}});function pn(r,e,t,n={}){let s=e in r.nodes,o=t in r.nodes;if(!s)return et(e,t,"no-such-from");if(!o)return et(e,t,"no-such-to");let i=n.maxDepth;if(i!=null&&(!Number.isInteger(i)||i<0))throw new Error("explainPath: maxDepth must be an integer >= 0");if(e===t){if(n.findCycle===!0){let u=dr(r,e,n);if(u!=null)return u}let d=tt(e,r.nodes[e],0,n);return nt(e,t,[d])}if(i===0)return et(e,t,"no-path");let a=hn(r,e,t,i);return a.found?nt(e,t,gn(r,a.pathOrder,n)):et(e,t,a.truncated?"max-depth-exceeded":"no-path")}function hn(r,e,t,n){let s=new Map,o=[{path:t,depth:0}],i=new Set([t]),a=0,d=!1;for(;a<o.length;){let f=o[a++];if(f.path===e)break;if(n!=null&&f.depth>=n){let y=r.nodes[f.path];y?.deps&&y.deps.length>0&&(d=!0);continue}let p=r.nodes[f.path];if(p==null)continue;let h=p.deps??[],l=new Map;for(let y=0;y<h.length;y++){let g=h[y];if(!g)continue;let w=l.get(g);w==null&&(w=[],l.set(g,w)),w.push(y)}for(let[y,g]of l)i.has(y)||(i.add(y),s.set(y,{from:f.path,depIndices:g}),o.push({path:y,depth:f.depth+1}))}if(!s.has(e))return{found:!1,pathOrder:[],truncated:d};let u=[{path:e}],c=e;for(;c!==t;){let f=s.get(c);if(f==null)return{found:!1,pathOrder:[],truncated:!1};u[u.length-1].depIndices=f.depIndices,u.push({path:f.from}),c=f.from}return{found:!0,pathOrder:u,truncated:!1}}function dr(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=tt(e,n,0,t);a.dep_index=o[0];let d=tt(e,n,1,t);return nt(e,e,[a,d])}let i=null;for(let a=0;a<s.length;a++){let d=s[a];if(!d||d===e)continue;let u=hn(r,d,e,t.maxDepth);u.found&&(i==null||u.pathOrder.length<i.pathOrder.length)&&(i=u,i={found:!0,pathOrder:[{path:e,depIndices:[a]},...u.pathOrder],truncated:!1})}return i==null?null:nt(e,e,gn(r,i.pathOrder,t))}function gn(r,e,t){return e.map((n,s)=>{let o=r.nodes[n.path],i=tt(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 tt(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 nt(r,e,t){return mn(r,e,!0,"ok",t)}function et(r,e,t){return mn(r,e,!1,t,[])}function mn(r,e,t,n,s){let o=ur(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 ur(r,e,t,n,s){if(!t)switch(n){case"no-such-from":return`explainPath: no node named "${r}"`;case"no-such-to":return`explainPath: no node named "${e}"`;case"max-depth-exceeded":return`explainPath: no path from "${r}" to "${e}" within maxDepth`;default:return`explainPath: no path from "${r}" to "${e}"`}let o=[`Causal path: ${r} \u2192 ${e} (${s.length} step(s))`];for(let i of s){let d=` ${i.hop===0?"\xB7":"\u2193"} ${i.path} (${i.type}${i.status?`/${i.status}`:""})`;if(o.push(d),"value"in i&&o.push(` value: ${cr(i.value)}`),i.annotation!=null&&o.push(` annotation: ${i.annotation}`),i.lastMutation!=null){let u=i.lastMutation.actor;o.push(` actor: ${u.type}${u.id?`:${u.id}`:""}`)}}return o.join(`
2
+ `)}function cr(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)}}var bn=$(()=>{"use strict"});function yn(r){let e=new WeakSet,t=new WeakSet,n=[r],s=0;for(;n.length>0;){let o=n.pop();s+=fr(o,e,t,n)}return s}function fr(r,e,t,n){if(r==null)return 0;switch(typeof r){case"number":return z.number;case"boolean":return z.boolean;case"string":return z.string+r.length*2;case"bigint":return z.bigint+pr(r);case"symbol":return z.symbol;case"function":return e.has(r)?0:(e.add(r),z.function);case"undefined":return 0}let o=r;if(e.has(o))return 0;e.add(o);let i=o[lr];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 z.date;if(o instanceof RegExp)return z.regexp+o.source.length*2;if(o instanceof Error){let u=o.message?o.message.length*2:0,c=o.stack?o.stack.length*2:0;return z.error+u+c}if(typeof URL<"u"&&o instanceof URL)return z.url+o.href.length*2;if(typeof Promise<"u"&&o instanceof Promise)return z.promise;if(o instanceof WeakMap)return z.weakmap;if(o instanceof WeakSet)return z.weakset;if(o instanceof Map){let u=z.map;for(let[c,f]of o)u+=z.mapEntry,n.push(c),n.push(f);return u}if(o instanceof Set){let u=z.set;for(let c of o)u+=z.setEntry,n.push(c);return u}if(Array.isArray(o)){let u=z.array+o.length*8;for(let c of o)n.push(c);return u}if(o instanceof ArrayBuffer)return t.has(o)?0:(t.add(o),o.byteLength);if(ArrayBuffer.isView(o)){let u=o;return t.has(u.buffer)?48:(t.add(u.buffer),u.buffer.byteLength+48)}let a=z.object,d=Object.keys(o);for(let u of d){a+=z.string+u.length*2;try{n.push(o[u])}catch{}}return a}function pr(r){let e=r<0n?-r:r;if(e===0n)return 0;let t=e.toString(2).length;return Math.ceil(t/32)*8}var z,lr,vn=$(()=>{"use strict";z={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},lr=Symbol.for("sizeof")});function _n(r,e){let t=e?.topN??10,n=r.describe({detail:"standard"}),s=[],o=r._collectObserveTargets;typeof o=="function"&&o.call(r,"",s);let i=new Map;for(let[p,h]of s)i.set(p,h);let a=[];for(let[p,h]of Object.entries(n.nodes)){let l=i.get(p),y=l instanceof V?l:null,g=y?yn(y.cache):0,w=y?y._sinkCount:0,v=h.deps?.length??0,b=h.type==="effect"&&w===0,_=w===0?h.type==="effect"?"orphan-effect":h.type==="derived"?"idle-derived":h.type==="producer"?"idle-producer":null:null;a.push({path:p,type:h.type,status:h.status??"unknown",valueSizeBytes:g,subscriberCount:w,depCount:v,isOrphanEffect:b,orphanKind:_})}let d=a.reduce((p,h)=>p+h.valueSizeBytes,0),u=(p,h)=>[...a].sort(h??((l,y)=>y[p]-l[p])).slice(0,t),c=a.filter(p=>p.orphanKind!=null),f=a.filter(p=>p.isOrphanEffect);return{nodeCount:a.length,edgeCount:n.edges.length,subgraphCount:n.subgraphs.length,nodes:a,totalValueSizeBytes:d,hotspots:{byValueSize:u("valueSizeBytes"),bySubscriberCount:u("subscriberCount"),byDepCount:u("depCount")},orphans:c,orphanEffects:f}}var wn=$(()=>{"use strict";_e();vn()});function rt(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 On(r){return r!=null&&typeof r=="object"&&"cache"in r&&typeof r.subscribe=="function"&&typeof r.down=="function"}function hr(r){if(r!=null)return On(r)?r.cache:r}function Te(r){return r!=null&&typeof r=="object"&&"cache"in r&&typeof r.subscribe=="function"&&typeof r.down=="function"}function fe(r){return Te(r)?r.cache??"":r}function Tn(r){return Te(r)?r.cache??0:r}function xn(r){return Te(r)?r.cache??!1:r}function gr(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 kn(r){if(r.version!==we)throw new Error(`unsupported snapshot version ${String(r.version)} (expected ${we})`);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 mr(r,e){let t=new WeakMap,n=(s,o)=>{if(Object.is(s,o))return!0;if(s==null||o==null||typeof s!="object"||typeof o!="object")return!1;let i=t.get(s);if(i==null&&(i=new WeakSet,t.set(s,i)),i.has(o))return!0;i.add(o);let a=s.constructor,d=o.constructor;if(a!==d)return!1;if(s instanceof Date)return s.getTime()===o.getTime();if(s instanceof RegExp)return s.source===o.source&&s.flags===o.flags;if(Array.isArray(s)){let p=o;if(s.length!==p.length)return!1;for(let h=0;h<s.length;h++)if(!n(s[h],p[h]))return!1;return!0}if(s instanceof Map){let p=o;if(s.size!==p.size)return!1;for(let[h,l]of s)if(!p.has(h)||!n(l,p.get(h)))return!1;return!0}if(s instanceof Set){let p=o;if(s.size!==p.size)return!1;for(let h of s){let l=!1;for(let y of p)if(n(h,y)){l=!0;break}if(!l)return!1}return!0}if(ArrayBuffer.isView(s)){let p=s,h=o;if(p.length!==h.length)return!1;for(let l=0;l<p.length;l++)if(p[l]!==h[l])return!1;return!0}let u=Object.keys(s),c=Object.keys(o);if(u.length!==c.length)return!1;let f=new Set(c);for(let p of u)if(!f.has(p)||!n(s[p],o[p]))return!1;return!0};return n(r,e)}function br(r){return r.replace(/[.*+?^${}()|[\]\\]/g,"\\$&")}function st(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+=br(n)}return e+="$",new RegExp(e)}function Dt(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 _r(r){return r==="none"?vr:r==="ansi"||r==null?yr:{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 Nn(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 wr(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 Ct(r,e,t){if(r==="")throw new Error(`Graph "${e}": ${t} name must be non-empty`);if(r.includes(P))throw new Error(`Graph "${e}": ${t} "${r}" must not contain '${P}' (path separator)`);if(r===ee)throw new Error(`Graph "${e}": ${t} name "${ee}" is reserved for meta companion paths`);wr(r,e,t)}function Tr(r,e){if(r==="")throw new Error(`Graph "${e}": resolve path must be non-empty`);let t=r.split(P);for(let n of t)if(n==="")throw new Error(`Graph "${e}": resolve path has empty segment`);return t}function xr(r,e){let t=!1;for(let s of r)if(!e.isMetaPassthrough(s[0])){t=!0;break}return t?r.filter(s=>e.isMetaPassthrough(s[0])):r}function En(r){for(let e of r._mounts.values())En(e);for(let e of r._nodes.values())try{e.down([[j]],{internal:!0})}catch{}}function Rn(r,e){let t=xe.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 Gt(r,e,t,n={}){let s={paths:[],depths:new Map,truncated:!1};if(!e)return n.withDetail?s:[];if(!n.both&&t!=="upstream"&&t!=="downstream")throw new Error('reachable: direction must be "upstream" or "downstream"');let o=n.maxDepth;if(o!=null&&(!Number.isInteger(o)||o<0))throw new Error("reachable: maxDepth must be an integer >= 0");if(o===0)return n.withDetail?s:[];let i=new Map,a=new Map,d=new Map,u=new Map,c=new Set;for(let[b,_]of Object.entries(r.nodes)){if(!b)continue;c.add(b);let T=_.deps??[];i.set(b,T);for(let O of T)O&&(c.add(O),a.has(O)||a.set(O,new Set),a.get(O).add(b))}for(let b of r.edges){if(b==null||typeof b!="object")continue;let _=typeof b.from=="string"?b.from:"",T=typeof b.to=="string"?b.to:"";!_||!T||(c.add(_),c.add(T),u.has(_)||u.set(_,new Set),u.get(_).add(T),d.has(T)||d.set(T,new Set),d.get(T).add(_))}if(!c.has(e))return n.withDetail?s:[];let f=n.both===!0,p=b=>{if(f){let m=i.get(b)??[],x=d.get(b),N=a.get(b),E=u.get(b),k=[...m];return x&&k.push(...x),N&&k.push(...N),E&&k.push(...E),k}if(t==="upstream"){let m=i.get(b)??[],x=d.get(b);return x?[...m,...x]:m}let _=a.get(b),T=u.get(b),O=_?[..._]:[];return T&&O.push(...T),O},h=new Set([e]),l=new Map,y=[{path:e,depth:0}],g=0,w=!1;for(;g<y.length;){let b=y[g++];if(o!=null&&b.depth>=o){p(b.path).length>0&&(w=!0);continue}for(let _ of p(b.path))!_||h.has(_)||(h.add(_),l.set(_,b.depth+1),y.push({path:_,depth:b.depth+1}))}let v=[...l.keys()].sort((b,_)=>b<_?-1:b>_?1:0);return n.withDetail?{paths:v,depths:l,truncated:w}:v}function kr(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}var P,ee,we,yr,vr,xe,An=$(()=>{"use strict";He();be();he();Se();re();Ot();_e();le();dn();Mt();ln();fn();bt();bn();wn();P="::",ee="__meta__",we=1;yr={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"},vr={data:"",dirty:"",resolved:"",invalidate:"",pause:"",resume:"",complete:"",error:"",teardown:"",derived:"",path:"",reset:""};xe=class r{name;opts;config;_nodes=new Map;_nodeToName=new WeakMap;_mounts=new Map;_parent=void 0;_storageDisposers=new Set;_disposers=new Set;_destroyed=!1;_topology;_topologyEmitters=new Set;_factory;_factoryArgs;constructor(e,t){if(e==="")throw new Error("Graph name must be non-empty");if(e.includes(P))throw new Error(`Graph name must not contain '${P}' (got "${e}")`);if(e===ee)throw new Error(`Graph name "${ee}" is reserved for meta companion paths`);this.name=e,this.opts=Object.freeze({...t??{}}),this.config=t?.config??Me,this._traceRing=new Fe(t?.traceCapacity??1e3),t?.versioning!=null&&this.setVersioning(t.versioning),typeof t?.factory=="string"&&(this._factory=t.factory,t.factoryArgs!==void 0&&(this._factoryArgs=t.factoryArgs))}tagFactory(e,t){return this._factory=e,this._factoryArgs=t,this}ancestors(e=!0){let t=[],n=e?this:this._parent;for(;n!=null;)t.push(n),n=n._parent;return t}get topology(){return this._topology==null&&(this._topology=ce(e=>{let t=n=>{e.emit(n)};return this._topologyEmitters.add(t),()=>{this._topologyEmitters.delete(t)}},{name:`${this.name}_topology`})),this._topology}_emitTopology(e){if(!(this._topology==null||this._topologyEmitters.size===0))for(let t of this._topologyEmitters)t(e)}nameOf(e){return this._nodeToName.get(e)}add(e,t){let n=e.name,s=t?.name??n;if(s==null||s==="")throw new Error(`Graph "${this.name}": graph.add requires a non-empty name \u2014 pass via opts.name or set it on the node (e.g. state(0, { name: "x" }))`);let o=s,i=t?.annotation;if(Ct(o,this.name,"add"),this._mounts.has(o))throw new Error(`Graph "${this.name}": name "${o}" is already a mount point`);if(this._nodes.has(o))throw new Error(`Graph "${this.name}": node "${o}" already exists`);let a=this._nodeToName.get(e);if(a!==void 0)throw new Error(`Graph "${this.name}": node instance already registered as "${a}"`);return this._nodes.set(o,e),this._nodeToName.set(e,o),this._emitTopology({kind:"added",name:o,nodeKind:"node"}),i!=null&&(this._annotations.set(o,i),this.config.inspectorEnabled&&this._traceRing.push({path:o,annotation:i,timestamp_ns:W()})),e}setVersioning(e){if(e!=null)for(let t of this._nodes.values())t instanceof V&&t._applyVersioning(e)}remove(e){Ct(e,this.name,"remove");let t=this._mounts.get(e);if(t){let o={kind:"mount",nodes:[],mounts:[]},i=[];t._collectObserveTargets("",i);for(let[a,d]of i)a.includes(`${P}${ee}${P}`)||o.nodes.push(a);return o.nodes.sort(),o.mounts.push(e),o.mounts.push(...t._collectSubgraphs(`${e}${P}`)),this._mounts.delete(e),t._parent=void 0,En(t),this._emitTopology({kind:"removed",name:e,nodeKind:"mount",audit:o}),o}let n=this._nodes.get(e);if(!n)throw new Error(`Graph "${this.name}": unknown node or mount "${e}"`);this._nodes.delete(e),this._nodeToName.delete(n),n.down([[j]],{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=st(e);return i=>o.test(i)})(),n={kind:"mount",nodes:[],mounts:[]},s=[...this._nodes.keys(),...this._mounts.keys()].filter(o=>t(o));for(let o of s){let i=this.remove(o);n.nodes.push(...i.nodes),n.mounts.push(...i.mounts)}return n.nodes.sort(),n.mounts.sort(),n}[Symbol.iterator](){let e=[...this._nodes.keys()].sort(),t=this._nodes,n=0;return{[Symbol.iterator](){return this},next(){if(n>=e.length)return{value:void 0,done:!0};let s=e[n++];return{value:[s,t.get(s)],done:!1}}}}node(e){if(e==="")throw new Error(`Graph "${this.name}": node name must be non-empty`);if(e.includes(P))return this.resolve(e);let t=this._nodes.get(e);if(!t)throw new Error(`Graph "${this.name}": unknown node "${e}"`);return t}get(e){return this.node(e).cache}set(e,t,n){let s=n?.internal===!0;this.node(e).down([[M,t]],{actor:n?.actor,internal:s,delivery:"write"})}setAll(e,t){let n=Symbol.iterator in e?e:Object.entries(e);H(()=>{for(let[s,o]of n)this.set(s,o,t)})}invalidate(e,t){let n=t?.internal===!0;this.node(e).down([[X]],{actor:t?.actor,internal:n,delivery:"write"})}error(e,t,n){let s=n?.internal===!0;this.node(e).down([[C,t]],{actor:n?.actor,internal:s,delivery:"write"})}complete(e,t){let n=t?.internal===!0;this.node(e).down([[F]],{actor:t?.actor,internal:n,delivery:"write"})}_registerSelfPruningKeepalive(e){let t,n,s=()=>{t?.(),t=void 0,n?.(),n=void 0};t=e.subscribe(o=>{for(let i of o){let a=i[0];if(a===j||a===F||a===C){s();return}}}),n=this.addDisposer(s)}_wireSignalToRemove(e,t){if(t==null)return;let n=()=>{try{this.remove(e)}catch{}};if(t.aborted){n();return}t.addEventListener("abort",n,{once:!0}),this.addDisposer(()=>t.removeEventListener("abort",n))}derived(e,t,n,s){let o=t.map(h=>this.resolve(h)),{keepAlive:i,annotation:a,equals:d,initial:u,meta:c,signal:f}=s??{},p=J(o,n,{name:e,...d!=null?{equals:d}:{},...u!==void 0?{initial:u}:{},...c!=null?{meta:c}:{}});return this.add(p,{name:e,...a!=null?{annotation:a}:{}}),i===!0&&this._registerSelfPruningKeepalive(p),this._wireSignalToRemove(e,f),p}effect(e,t,n,s){let o=t.map(c=>this.resolve(c)),{annotation:i,meta:a,signal:d}=s??{},u=Et(o,n,{name:e,...a!=null?{meta:a}:{}});return this.add(u,{name:e,...i!=null?{annotation:i}:{}}),this._wireSignalToRemove(e,d),u}produce(e,t,n){if(t===void 0)throw new Error(`Graph "${this.name}".produce("${e}", \u2026): source must not be \`undefined\` \u2014 undefined is the global SENTINEL (spec \xA71.1). Pass \`null\` for nullary DATA, or a Promise/AsyncIterable/Iterable for async sources.`);if(t!==null&&typeof t=="object"&&"cache"in t&&typeof t.subscribe=="function")throw new Error(`Graph "${this.name}".produce("${e}", \u2026): Node sources are rejected. For Node\u2192Node, use graph.derived(name, [path], ([v]) => v, { keepAlive: true }) \u2014 fromAny passes Nodes through verbatim and silently drops opts.`);let{annotation:s,meta:o,equals:i,signal:a}=n??{},d=Xe(t,{name:e,...o!=null?{meta:o}:{},...i!=null?{equals:i}:{},...a!=null?{signal:a}:{}});return this.add(d,{name:e,...s!=null?{annotation:s}:{}}),this._wireSignalToRemove(e,a),d}batch(e){H(e)}edges(e){let t=e?.recursive===!0,n=new Map;if(!t){for(let[d,u]of this._nodes)n.set(u,d);let a=[];for(let[d,u]of this._nodes)if(u instanceof V)for(let c of u._deps){let f=n.get(c.node);f!=null&&a.push([f,d])}return a.sort((d,u)=>d[0]<u[0]?-1:d[0]>u[0]?1:d[1]<u[1]?-1:d[1]>u[1]?1:0),a}let s=[];this._collectObserveTargets("",s);let o=new Map;for(let[a,d]of s)o.set(d,a);let i=[];for(let[a,d]of s)if(d instanceof V)for(let u of d._deps){let c=o.get(u.node);c!=null&&i.push([c,a])}return i.sort((a,d)=>a[0]<d[0]?-1:a[0]>d[0]?1:a[1]<d[1]?-1:a[1]>d[1]?1:0),i}mount(e,t){if(t===void 0){let s=new r(e);return this.mount(e,s)}if(typeof t=="function"){let s=new r(e);return t(s),this.mount(e,s)}let n=t;if(Ct(e,this.name,"mount"),this._nodes.has(e))throw new Error(`Graph "${this.name}": cannot mount at "${e}" \u2014 node with that name exists`);if(this._mounts.has(e))throw new Error(`Graph "${this.name}": mount "${e}" already exists`);if(n===this)throw new Error(`Graph "${this.name}": cannot mount a graph into itself`);if(n._parent!=null)throw new Error(`Graph "${this.name}": this child graph is already mounted on "${n._parent.name}"`);for(let s=this;s!=null;s=s._parent)if(s===n)throw new Error(`Graph "${this.name}": mount("${e}", \u2026) would create a mount cycle`);return this._mounts.set(e,n),n._parent=this,this._emitTopology({kind:"added",name:e,nodeKind:"mount"}),n}resolve(e){let t=Tr(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]===ee)return this._resolveMetaChainFromNode(o,s,t.join(P));let i=this._mounts.get(n);if(!i)throw this._nodes.has(n)?new Error(`Graph "${this.name}": "${n}" is a node; trailing path "${s.join(P)}" is invalid`):new Error(`Graph "${this.name}": unknown mount or node "${n}"`);return i.resolve(s.join(P))}_resolveMetaChainFromNode(e,t,n){let s=e,o=0,i=[...t];for(;o<i.length;){if(i[o]!==ee)throw new Error(`Graph "${this.name}": expected ${ee} segment in meta path "${n}"`);if(o+1>=i.length)throw new Error(`Graph "${this.name}": meta path requires a key after ${ee} in "${n}"`);let a=i[o+1],d=s.meta[a];if(!d)throw new Error(`Graph "${this.name}": unknown meta "${a}" in path "${n}"`);s=d,o+=2}return s}signal(e,t){if(t?.internal!==!0){for(let s of e)if(this.config.messageTier(s[0])===3)throw new Error(`Graph "${this.name}": Graph.signal() rejects tier-3 messages (DATA / RESOLVED). Broadcast is for control-plane tiers (START / DIRTY / INVALIDATE / PAUSE / RESUME / COMPLETE / ERROR / TEARDOWN). For per-node value writes, use Graph.set or graph.node(name).down(...).`)}let n=[];if(this._signalDeliver(e,t??{},new Set,n),n.length>0)throw n[0]}_signalDeliver(e,t,n,s){for(let d of this._mounts.values())d._signalDeliver(e,t,n,s);let i=t.internal===!0?{internal:!0}:{actor:t.actor,delivery:"signal"},a=xr(e,this.config);for(let d of[...this._nodes.keys()].sort()){let u=this._nodes.get(d);if(!n.has(u)){n.add(u);try{u.down(e,i)}catch(c){if(c instanceof Z)throw c;s.push(c)}a.length!==0&&this._signalMetaSubtree(u,a,n,i,s)}}}_signalMetaSubtree(e,t,n,s,o){for(let i of Object.keys(e.meta).sort()){let a=e.meta[i];if(!n.has(a)){n.add(a);try{a.down(t,s)}catch(d){if(d instanceof Z)throw d;o.push(d)}this._signalMetaSubtree(a,t,n,s,o)}}}describe(e){if(e?.reactive==="diff")return this._describeReactiveDiff(e);if(e?.reactive===!0)return this._describeReactive(e);let t=hr(e?.actor),n=e?.filter;if(e?.detail!=null&&e?.fields!=null)throw new TypeError("Graph.describe(): pass either `detail` or `fields`, not both. `detail: 'spec'` is the canonical spec projection; use `fields` only when you need a custom subset.");let s=Qe(e?.detail,e?.fields),o=e?.detail==="spec",i=s,a=[];this._collectObserveTargets("",a);let d=new Map;for(let[_,T]of a)d.set(T,_);let u=[];{let _=a.map(([,m])=>m),T=new Set(d.values()),O=0;for(;_.length>0;){let m=_.shift();if(m instanceof V)for(let x of m._deps){let N=x.node;if(d.has(N))continue;let E=N.name??"",k=E;if(!k||T.has(k))if(E){let A=2;for(;T.has(`${E}#${A}`);)A++;k=`${E}#${A}`}else for(k=`__internal__/${O++}`;T.has(k);)k=`__internal__/${O++}`;d.set(N,k),T.add(k),u.push([k,N]),_.push(N)}}}let c=[...a,...u],f={};for(let[_,T]of c){if(t!=null&&!T.allowsObserve(t))continue;let O=Nt(T,i,o),m=T instanceof V?T._deps.map(k=>d.get(k.node)??k.node.name??""):[],{name:x,...N}=O,E={...N,deps:m};if(!o){let k=this._annotations.get(_);k!=null&&(E.annotation=k)}if(n!=null)if(typeof n=="function"){let k=n;if(!(k.length>=2?k(_,E):k(E)))continue}else{let k=!0;for(let[A,D]of Object.entries(n)){let S=A==="deps_includes"?"depsIncludes":A==="meta_has"?"metaHas":A;if(S==="depsIncludes"){if(!E.deps.includes(String(D))){k=!1;break}continue}if(S==="metaHas"){if(!Object.hasOwn(E.meta??{},String(D))){k=!1;break}continue}if(E[S]!==D){k=!1;break}}if(!k)continue}f[_]=E}let p=new Set(Object.keys(f)),h=[];for(let[_,T]of c)if(T instanceof V)for(let O of T._deps){let m=d.get(O.node);m!=null&&h.push([m,_])}h.sort((_,T)=>_[0]<T[0]?-1:_[0]>T[0]?1:_[1]<T[1]?-1:_[1]>T[1]?1:0);let l=h.map(([_,T])=>({from:_,to:T}));(t!=null||n!=null)&&(l=l.filter(_=>p.has(_.from)&&p.has(_.to)));let y=this._collectSubgraphs(""),g=t!=null||n!=null?y.filter(_=>{let T=`${_}${P}`;return[...p].some(O=>O===_||O.startsWith(T))}):y,w=this,v=e;return{name:this.name,nodes:f,edges:l,subgraphs:g,...this._factory!==void 0?{factory:this._factory}:{},...this._factoryArgs!==void 0?{factoryArgs:this._factoryArgs}:{},expand(_){let T={...v};return Array.isArray(_)?(T.fields=_,T.detail=void 0):(T.detail=_,T.fields=void 0),w.describe(T)}}}_collectSubgraphs(e){let t=[];for(let n of[...this._mounts.keys()].sort()){let s=e===""?n:`${e}${n}`;t.push(s),t.push(...this._mounts.get(n)._collectSubgraphs(`${s}${P}`))}return t}resourceProfile(e){return _n(this,e)}reachable(e,t,n={}){return n.withDetail===!0?Gt(this.describe(),e,t,{...n,withDetail:!0}):Gt(this.describe(),e,t,n)}explain(e,t,n){return n?.reactive===!0?this._explainReactive(e,t,n):this._explainStatic(fe(e),fe(t),{...n?.maxDepth!==void 0?{maxDepth:Tn(n.maxDepth)}:{},...n?.findCycle!==void 0?{findCycle:xn(n.findCycle)}:{}})}_explainStatic(e,t,n){let s=this.describe({detail:"full"}),o=new Map(this._annotations),i=new Map;for(let[a,d]of Object.entries(s.nodes))d.lastMutation!=null&&i.set(a,d.lastMutation);return pn(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=B(s,{name:`${n}_version`}),i=this.observe({timeline:!0,structured:!0}),a=!1,d=!1,u=()=>{a||d||(a=!0,Ae(()=>{a=!1,!d&&(s+=1,o.emit(s))}))},c=i.onEvent(v=>{let b=v.type;b!=="data"&&b!=="error"&&b!=="complete"&&b!=="teardown"||u()}),f=[],p=new WeakSet,h=v=>{if(p.has(v)||d)return;p.add(v);let b=v.topology.subscribe(_=>{for(let T of _){if(T[0]!==M)continue;let O=T[1];if(u(),O.kind==="added"&&O.nodeKind==="mount"){let m=v._mounts.get(O.name);m!=null&&h(m)}}});f.push(b);for(let _ of v._mounts.keys()){let T=v._mounts.get(_);T!=null&&h(T)}};h(this);let l,y=e.actor;On(y)&&(l=y.subscribe(v=>{let b=!1,_=!1;for(let T of v){let O=T[0];O===M?b=!0:(O===F||O===C||O===j)&&(_=!0)}b&&u(),_&&(l?.(),l=void 0,u())}));let g;try{g=J([o],()=>this.describe(t),{name:n,describeKind:"derived",meta:{domain:"audit",kind:"describe"},equals:(v,b)=>v===b})}catch(v){c(),l?.();for(let b of f)b();throw i.dispose(),v}let w=ae(g);return{node:g,dispose(){d=!0,c(),l?.();for(let v of f)v();f.length=0,i.dispose(),w()}}}_describeReactiveDiff(e){let t={...e,reactive:!1},n=e.reactiveName??"describe-diff",s={name:this.name,nodes:{},edges:[],subgraphs:[]},o=this.describe(t),i=At(s,o),a=B(i,{name:n,meta:{domain:"audit",kind:"describe-diff"},equals:(p,h)=>p===h}),d=this._describeReactive({...e,reactiveName:void 0}),u=!1,c=d.node.subscribe(p=>{if(!u)for(let h of p){if(h[0]!==M)continue;let l=h[1],y=At(o,l);o=l,y.events.length!==0&&a.emit(y)}}),f=ae(a);return{node:a,dispose(){u=!0,c(),d.dispose(),a.down([[j,"describe-diff disposed"]]),f()}}}_explainReactive(e,t,n){let s=0,o=B(s,{name:"explain_version"}),i=this.observe({timeline:!0,structured:!0}),a=!1,d=!1,u=()=>{a||d||(a=!0,Ae(()=>{a=!1,!d&&(s+=1,o.emit(s))}))},c=i.onEvent(v=>{let b=v.type;b!=="data"&&b!=="error"&&b!=="complete"&&b!=="teardown"||u()}),f=[];e!=null&&Te(e)&&f.push(e),t!=null&&Te(t)&&f.push(t),n?.maxDepth!=null&&Te(n.maxDepth)&&f.push(n.maxDepth),n?.findCycle!=null&&Te(n.findCycle)&&f.push(n.findCycle);let p=()=>{for(let v of f)if(v.cache===void 0)return!1;return!0},h=()=>{let v=fe(e),b=fe(t);return{from:v,to:b,found:!1,reason:"pending",steps:[],text:"(awaiting reactive args)",toJSON:()=>({from:v,to:b,found:!1,reason:"pending",steps:[]})}},l;try{l=J([o],()=>{if(!p())return h();let v=fe(e),b=fe(t),_={...n?.maxDepth!==void 0?{maxDepth:Tn(n.maxDepth)}:{},...n?.findCycle!==void 0?{findCycle:xn(n.findCycle)}:{}};return this._explainStatic(v,b,_)},{name:n?.name??"explain",describeKind:"derived",meta:{domain:"audit",kind:"explain_path",from:fe(e),to:fe(t)},equals:(v,b)=>v.found===b.found&&v.reason===b.reason&&v.steps.length===b.steps.length&&kr(v.steps,b.steps)})}catch(v){throw c(),i.dispose(),v}let y=ae(l),g=[],w=v=>{let b;return b=v.subscribe(_=>{let T=!1,O=!1;for(let m of _){let x=m[0];x===M?T=!0:(x===F||x===C||x===j)&&(O=!0)}(T||O)&&u(),O&&b&&(b(),b=void 0)}),()=>{b&&(b(),b=void 0)}};for(let v of f)g.push(w(v));return{node:l,dispose(){d=!0,c();for(let v of g)v?.();g.length=0,i.dispose(),y()}}}_pathsMatching(e){let t=st(e),n=[];return this._collectObserveTargets("",n),n.map(([s])=>s).filter(s=>t.test(s))}_collectObserveTargets(e,t){for(let n of[...this._mounts.keys()].sort()){let s=e===""?n:`${e}${P}${n}`;this._mounts.get(n)._collectObserveTargets(s,t)}for(let n of[...this._nodes.keys()].sort()){let s=this._nodes.get(n),o=e===""?n:`${e}${P}${n}`;t.push([o,s]),this._appendMetaObserveTargets(o,s,t)}}_appendMetaObserveTargets(e,t,n){for(let s of Object.keys(t.meta).sort()){let o=t.meta[s],i=`${e}${P}${ee}${P}${s}`;n.push([i,o]),this._appendMetaObserveTargets(i,o,n)}}observe(e,t){let n=typeof e=="string",o=Nn(n?t:e);if(o.reactive===!0)return this._observeReactive(n?e:void 0,o);let i=o.structured===!0||o.timeline===!0||o.causal===!0||o.derived===!0||o.detail==="minimal"||o.detail==="full"||o.format!=null,a=o.actor;if(n){let c=e,f=this.resolve(c);if(a!=null&&!f.allowsObserve(a))throw new Z({actor:a,action:"observe",nodeName:c});return i?this._buildStructuredObserver([[c,f]],o,"one"):{subscribe(p){return f.subscribe(p)},up(p){try{f.up?.(p)}catch(h){if(h instanceof Z)return;throw h}}}}let d=[];this._collectObserveTargets("",d),d.sort((c,f)=>c[0]<f[0]?-1:c[0]>f[0]?1:0);let u=a==null?d:d.filter(([,c])=>c.allowsObserve(a));return i?this._buildStructuredObserver(u,o,"all"):{subscribe:c=>{let f=u.map(([p,h])=>h.subscribe(l=>{c(p,l)}));return()=>{for(let p of f)p()}},up:(c,f)=>{try{this.resolve(c).up?.(f)}catch(p){if(p instanceof Z)return;throw p}}}}_observeReactive(e,t){let n=t.tiers,s=n!=null?new Set(n):null,o=t.reactiveName??"observe";return ce(i=>{let a=[],d=!1,u=!1,c=()=>{if(a.length===0||u)return;let y={events:a.slice(),flushedAt_ns:W()};a.length=0,i.emit(y)},f={...t,reactive:!1,structured:!0,timeline:!0},p=e!=null?this.observe(e,f):this.observe(f),h=y=>{u||(a.push(y),!d&&(d=!0,Ae(()=>{d=!1,c()})))};for(let y of p.events)h(y);let l=p.onEvent(h);return()=>{u=!0,l(),p.dispose()}},{name:o,meta:{domain:"audit",kind:"observe-reactive"}})}_buildStructuredObserver(e,t,n){let s=n==="one"?e[0]?.[0]:void 0,o=i=>{if(n==="one"&&s!=null){let c=this.resolve(s);return this._buildStructuredObserver([[s,c]],i,"one")}let a=[];this._collectObserveTargets("",a),a.sort((c,f)=>c[0]<f[0]?-1:c[0]>f[0]?1:0);let d=i.actor,u=d==null?a:a.filter(([,c])=>c.allowsObserve(d));return this._buildStructuredObserver(u,i,"all")};return this._createObserveResult(e,t,o)}_createObserveResult(e,t,n){let s=t.timeline===!0,o=t.causal===!0,i=t.derived===!0,a=t.detail==="minimal",d=this.config.inspectorEnabled,u=(o||i)&&d,c=t.maxEvents,f=c!=null&&c>0?new Fe(c):null,p=[],h=new Set,l=t.tiers!=null?new Set(t.tiers):null,y={},g=new Set,w=0,v=0,b=0,_=0,T=0,O=0,m=!1,x=!1,N=0,E=new Map,k=new Map,A=new Map,D=R=>{if(!(l!=null&&!l.has(R.type))){f?f.push(R):p.push(R);for(let I of h)I(R)}},S=R=>l==null||l.has(R),te=()=>s?{timestamp_ns:W(),in_batch:$e(),batch_id:N}:{},K=(R,I)=>{if(!(!u||!(R instanceof V)))return R._setInspectorHook(Y=>{if(Y.kind==="dep_message")E.set(R,Y.depIndex);else if(Y.kind==="run"){let Ge=Y.batchData.map((G,q)=>G!=null&&G.length>0?G.at(-1):Y.prevData[q]);k.set(R,Ge);let Q=Y.batchData.map(G=>G!=null?[...G]:void 0);A.set(R,Q),i&&D({type:"derived",path:I,dep_values:Ge,dep_batches:Q,...te()})}})},pe=R=>{let I=E.get(R),Y=k.get(R);if(!o||Y==null)return{};let Q=(I!=null&&I>=0&&R instanceof V?R._deps[I]:void 0)?.node,G=Q?.v,q=A.get(R);return{trigger_dep_index:I,trigger_dep_name:Q?.name,...G!=null?{trigger_version:{id:G.id,version:G.version}}:{},dep_values:[...Y],...q!=null?{dep_batches:q}:{}}},je=[],ke=[];for(let[R,I]of e){let Y=K(I,R);Y&&je.push(Y),ke.push(I.subscribe(Ge=>{N++;for(let Q of Ge){let G=Q[0],q=te();if(G===M){y[R]=Q[1];let ct=I instanceof V?I.lastMutation?.actor??Oe:Oe;D({type:"data",path:R,data:Q[1],actor:ct,...q,...pe(I)})}else if(a)G===L?S("dirty")&&w++:G===U?S("resolved")&&v++:G===X?S("invalidate")&&b++:G===ne?S("pause")&&_++:G===ie?S("resume")&&T++:G===j?S("teardown")&&O++:G===F&&!g.has(R)?S("complete")&&(m=!0):G===C&&S("error")&&(x=!0,g.add(R));else if(G===L)S("dirty")&&w++,D({type:"dirty",path:R,...q});else if(G===U)S("resolved")&&v++,D({type:"resolved",path:R,...q,...pe(I)});else if(G===X)S("invalidate")&&b++,D({type:"invalidate",path:R,...q});else if(G===ne)S("pause")&&_++,D({type:"pause",path:R,lockId:Q[1],...q});else if(G===ie)S("resume")&&T++,D({type:"resume",path:R,lockId:Q[1],...q});else if(G===F)S("complete")&&!g.has(R)&&(m=!0),D({type:"complete",path:R,...q});else if(G===C){S("error")&&(x=!0,g.add(R));let ct=I instanceof V?I.lastMutation?.actor??Oe:Oe;D({type:"error",path:R,data:Q[1],actor:ct,...q})}else G===j&&(S("teardown")&&O++,D({type:"teardown",path:R,...q}))}}))}let oe=!1,Ne=()=>{if(!oe){oe=!0;for(let R of ke)R();for(let R of je)R();for(let R of de)R({value:void 0,done:!0});de.length=0}},De=[],de=[];h.add(R=>{let I=de.shift();I?I({value:R,done:!1}):De.push(R)});let Ce={get values(){return y},get dirtyCount(){return w},get resolvedCount(){return v},get invalidateCount(){return b},get pauseCount(){return _},get resumeCount(){return T},get teardownCount(){return O},get events(){return f?f.toArray():[...p]},get anyCompletedCleanly(){return m},get anyErrored(){return x},get completedWithoutErrors(){return m&&!x},onEvent(R){return h.add(R),()=>h.delete(R)},dispose:Ne,expand(R){Ne();let I={...t};return typeof R=="string"?I.detail=R:Object.assign(I,R),n(Nn(I))},[Symbol.asyncIterator](){return{next(){return De.length>0?Promise.resolve({value:De.shift(),done:!1}):oe?Promise.resolve({value:void 0,done:!0}):new Promise(R=>de.push(R))},return(){return Ne(),Promise.resolve({value:void 0,done:!0})}}}};return t.format!=null&&this._attachFormatLogger(Ce,t),Ce}_attachFormatLogger(e,t){let n=t.format;if(n==null)return;let s=t.logger??(l=>console.log(l)),o=t.includeTypes?new Set(t.includeTypes):null,i=t.excludeTypes?new Set(t.excludeTypes):null,a=o==null&&i==null?()=>!0:l=>(o==null||o.has(l))&&(i==null||!i.has(l)),d=_r(t.theme),u=n==="stage-log"?W():0,c=l=>l==null?"":t.stageLabels?.[l]??l,f=(l,y)=>l.length>y?`${l.slice(0,y-1)}\u2026`:l,p=l=>l.type==="data"||l.type==="error"?f(Dt(l.data),120):"",h=l=>{if(n==="stage-log"){let m=(W()-u)/1e9,x=c(l.path).padEnd(9);if(l.type==="data"){let N=p(l);return`[${m.toFixed(3)}s] ${x} \u2190${N?` ${N}`:""}`}if(l.type==="error"){let N=p(l);return`[${m.toFixed(3)}s] ${x} \u2717${N?` ${N}`:""}`}return l.type==="complete"?`[${m.toFixed(3)}s] ${x} \u25A0 complete`:`[${m.toFixed(3)}s] ${x} ${l.type}`}if(n==="json")try{return JSON.stringify(l)}catch{return JSON.stringify({type:l.type,path:l.path,data:"[unserializable]"})}let y=d[l.type]??"",g=l.path?`${d.path}${l.path}${d.reset} `:"",w=l.type==="data"||l.type==="error",v=l.type==="pause"||l.type==="resume",b=w?` ${Dt(l.data)}`:v?` ${Dt(l.lockId)}`:"",_=l.type==="data"||l.type==="resolved"||l.type==="derived"?l:void 0,T=_?.trigger_dep_name!=null?` <- ${_.trigger_dep_name}`:_?.trigger_dep_index!=null?` <- #${_.trigger_dep_index}`:"",O=l.in_batch?" [batch]":"";return`${g}${y}${l.type.toUpperCase()}${d.reset}${b}${T}${O}`};e.onEvent(l=>{a(l.type)&&s(h(l),l)})}addDisposer(e){return this._disposers.add(e),()=>{this._disposers.delete(e)}}destroy(){rt(this._disposers,this.name),this.signal([[j]],{internal:!0}),rt(this._storageDisposers,this.name);for(let e of[...this._mounts.values()])e._parent=void 0,e._destroyClearOnly();this._mounts.clear(),this._nodes.clear(),this._parent=void 0,this._destroyed=!0}get destroyed(){return this._destroyed}_destroyClearOnly(){rt(this._disposers,this.name),rt(this._storageDisposers,this.name);for(let e of[...this._mounts.values()])e._parent=void 0,e._destroyClearOnly();this._mounts.clear(),this._nodes.clear(),this._parent=void 0,this._destroyed=!0}snapshot(e){let{expand:t,...n}=this.describe({detail:"full"}),s={};for(let a of Object.keys(n.nodes).sort()){let{lastMutation:d,guard:u,...c}=n.nodes[a];s[a]=c}let o=[...n.subgraphs].sort(),i={...n,version:1,nodes:s,subgraphs:o};if(e?.format==null)return i;if(e.format==="json-string")return JSON.stringify(i);if(e.format==="bytes"){if(e.codec==null)throw new Error("snapshot({format: 'bytes'}) requires a `codec` name");let a=this.config.lookupCodec(e.codec);if(a==null)throw new Error(`snapshot: codec "${e.codec}" is not registered on this graph's config. Call config.registerCodec(...) before creating nodes.`);return Ut(a,a.encode(i))}throw new Error(`snapshot: unknown format "${String(e.format)}"`)}static decode(e,t){let n=t?.config??Me,{codec:s,codecVersion:o,payload:i}=Jt(e,n);return s.decode(i,o)}restore(e,t){if(kn(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=>st(o)),s=t?.includeProducers===!0;for(let o of Object.keys(e.nodes).sort()){if(n!==null&&!n.some(a=>a.test(o)))continue;let i=e.nodes[o];if(i!==void 0){if(!("value"in i)||i.value===void 0){"value"in i&&i.value===void 0&&t?.onError?.(o,new Error(`restore: slice.value is undefined for "${o}" (undefined is the global SENTINEL; not valid DATA)`));continue}if(!(i.type==="derived"||i.type==="effect")&&!(i.type==="producer"&&!s)){if(i.v!=null){let d=this.tryResolve(o)?.v;if(d!=null&&d.id===i.v.id&&d.version===i.v.version)continue}try{this.set(o,i.value)}catch(a){t?.onError?.(o,a)}}}}}static fromSnapshot(e,t){kn(e);let n=typeof t=="function"?t:t?.build,s=typeof t=="function"?void 0:t?.factories,o=new r(e.name);if(n)return n(o),o.restore(e),o;for(let h of[...e.subgraphs].sort((l,y)=>{let g=l.split(P).length,w=y.split(P).length;return g!==w?g-w:l<y?-1:l>y?1:0})){let l=h.split(P),y=o;for(let g of l)y._mounts.has(g)||y.mount(g,new r(g)),y=y._mounts.get(g)}let i=s?Object.entries(s).map(([h,l])=>({re:st(h),factory:l})):[],a=h=>{for(let l of i)if(l.re.test(h))return l.factory},d=h=>{let l=h.split(P),y=l.pop();if(y==null||y.length===0)throw new Error(`invalid snapshot path "${h}"`);let g=o;for(let w of l){let v=g._mounts.get(w);if(!v)throw new Error(`unknown mount "${w}" in path "${h}"`);g=v}return[g,y]},u=Object.entries(e.nodes).filter(([h])=>!h.includes(`${P}${ee}${P}`)).sort((h,l)=>h[0]<l[0]?-1:h[0]>l[0]?1:0),c=new Map(u),f=new Map,p=!0;for(;c.size>0&&p;){p=!1;for(let[h,l]of[...c.entries()]){let y=l?.deps??[];if(!y.every(T=>f.has(T)))continue;let[g,w]=d(h),v={...l?.meta??{}},b=a(h),_;if(l?.type==="state")_=B(l.value,{meta:v});else{if(b==null)continue;_=b(w,{path:h,type:l.type,value:l.value,meta:v,deps:y,resolvedDeps:y.map(T=>f.get(T))})}g.add(_,{name:w}),f.set(h,_),c.delete(h),p=!0}}if(c.size>0){let h=[...c.keys()].sort().join(", ");throw new Error(`Graph.fromSnapshot could not reconstruct nodes without build callback: ${h}. Pass matching factories via fromSnapshot(data, { factories: { pattern: factoryFn } }).`)}return o.restore(e),o}toJSON(){return this.snapshot()}attachSnapshotStorage(e,t={}){let n=e.map(u=>({tier:u,debounceMs:Math.max(0,u.debounceMs??0),compactEvery:Math.max(1,u.compactEvery??10),timer:void 0,seq:0,lastSnapshot:void 0,lastFingerprint:"",disposed:!1,savePending:void 0}));t.autoRestore===!0&&this._cascadeRestore(e,t.onError);let s=(u,c)=>{if(u.disposed)return;let f=gr(c.nodes);if(u.lastSnapshot!=null&&f!==""&&f===u.lastFingerprint)return;let p=u.seq+1,h=ue(),g=u.lastSnapshot==null||p%u.compactEvery===0?{name:this.name,mode:"full",snapshot:c,seq:p,timestamp_ns:h,format_version:we}:{name:this.name,mode:"diff",diff:Rn(u.lastSnapshot,c),seq:p,timestamp_ns:h,format_version:we};if(u.tier.filter&&!u.tier.filter(g))return;let w;try{w=u.tier.save(g)}catch(v){t.onError?.(v,u.tier);return}if(w&&typeof w.then=="function"){let _=(u.savePending??Promise.resolve()).then(()=>w,()=>w).then(()=>{u.disposed||(u.seq=p,u.lastSnapshot=c,u.lastFingerprint=f)},T=>{t.onError?.(T,u.tier)});u.savePending=_.finally(()=>{u.savePending===_&&(u.savePending=void 0)})}else u.seq=p,u.lastSnapshot=c,u.lastFingerprint=f},o=(u,c)=>{try{s(u,c)}catch(f){t.onError?.(f,u.tier)}},i=(u,c)=>{if(!c.some(l=>{let y=this.config.messageTier(l[0]);return y>=3&&y<5}))return;if(t.filter){let l=this.tryResolve(u);if(l==null)return;let y=Nt(l,Qe("standard"));if(!t.filter(u,y))return}let p,h=()=>(p==null&&(p=this.snapshot()),p);for(let l of n)l.disposed||(l.debounceMs===0?o(l,h()):(l.timer==null&&(l.timer=new Ze),l.timer.start(l.debounceMs,()=>{l.disposed||o(l,this.snapshot())})))},a;if(t.paths!=null){let c=(typeof t.paths=="string"?this._pathsMatching(t.paths):t.paths).map(f=>{let p=this.tryResolve(f);return p==null?()=>{}:p.subscribe(h=>i(f,h))});a=()=>{for(let f of c)f()}}else a=this.observe().subscribe((u,c)=>i(u,c));let d=()=>{a();for(let u of n)u.disposed=!0,u.timer?.cancel();this._storageDisposers.delete(d)};return this._storageDisposers.add(d),{dispose:d}}async _cascadeRestore(e,t){for(let n of e){let s;try{s=await n.load?.()}catch(i){t?.(i,n);continue}if(s==null||typeof s!="object"||Array.isArray(s))continue;let o=s;try{if(o.mode==="full"&&o.snapshot!=null)return this.restore(o.snapshot),!0;if(o.version===we&&o.nodes!=null)return this.restore(o),!0}catch(i){t?.(i,n)}}return!1}static async fromStorage(e,t,n){for(let s of t){let o;try{o=await s.load?.()}catch(d){n?.onError?.(d,s);continue}if(o==null||typeof o!="object"||Array.isArray(o))continue;let i=o,a=i.mode==="full"&&i.snapshot!=null?i.snapshot:i.version===we&&i.nodes!=null?i:void 0;if(a!=null)try{return r.fromSnapshot(a,n)}catch(d){n?.onError?.(d,s)}}throw new Error(`Graph.fromStorage: no tier held a restorable record for "${e}" across ${t.length} tier(s)`)}_annotations=new Map;_traceRing;trace(e,t,n){if(e!=null&&t!=null){if(this.tryResolve(e)==null)return;if(this._annotations.set(e,t),this.config.inspectorEnabled){let s={path:e,annotation:t,timestamp_ns:W(),...n?.actor!=null?{actor:n.actor}:{}};this._traceRing.push(s)}return}return e!=null?this.config.inspectorEnabled?this._annotations.get(e):void 0:this.config.inspectorEnabled?this._traceRing.toArray():[]}annotation(e){return this._annotations.get(e)}clearTrace(){this._annotations.clear(),this._traceRing.clear()}pruneTrace(e){let t=this._traceRing.toArray().filter(s=>!e(s)),n=this._traceRing.size-t.length;this._traceRing.clear();for(let s of t)this._traceRing.push(s);return n}static diff(e,t){let n=new Set(Object.keys(e.nodes)),s=new Set(Object.keys(t.nodes)),o=[...s].filter(v=>!n.has(v)).sort(),i=[...n].filter(v=>!s.has(v)).sort(),a=[],d=[];for(let v of n){if(!s.has(v))continue;let b=e.nodes[v],_=t.nodes[v],T=b.v,O=_.v;T!=null&&O!=null&&T.id===O.id&&T.version!==O.version&&d.push({path:v,id:T.id,from:T.version,to:O.version});let m=T!=null&&O!=null&&T.id===O.id&&T.version===O.version;for(let x of["type","status","sentinel"]){let N=b[x],E=_[x];N!==E&&a.push({path:v,field:x,from:N,to:E})}if(!m)for(let x of["value","meta"]){let N=b[x],E=_[x];mr(N,E)||a.push({path:v,field:x,from:N,to:E})}}let u=v=>`${v.from} ${v.to}`,c=new Set(e.edges.map(u)),f=new Set(t.edges.map(u)),p=t.edges.filter(v=>!c.has(u(v))),h=e.edges.filter(v=>!f.has(u(v))),l=new Set(e.subgraphs),y=new Set(t.subgraphs),g=[...y].filter(v=>!l.has(v)).sort(),w=[...l].filter(v=>!y.has(v)).sort();return{nodesAdded:o,nodesRemoved:i,nodesChanged:a,versionChanges:d,edgesAdded:p,edgesRemoved:h,subgraphsAdded:g,subgraphsRemoved:w}}}});var $n=$(()=>{"use strict";An()});var Mr={};jn(Mr,{JobFlowGraph:()=>ut,JobQueueGraph:()=>dt,jobEventKeyOf:()=>Ar,jobFlow:()=>Sr,jobQueue:()=>Ln});module.exports=Hn(Mr);he();He();be();Se();re();Ot();le();_e();on();he();Se();re();le();be();re();_e();le();var It=class{_version=0;_maxSize;_buf;_head=0;_size=0;constructor(e,t){if(t!==void 0&&t<1)throw new RangeError("maxSize must be >= 1");if(this._maxSize=t,t!==void 0){if(this._buf=new Array(t),e&&e.length>0){let n=Math.min(e.length,t),s=e.length-n;for(let o=0;o<n;o++)this._buf[o]=e[s+o];this._size=n}}else this._buf=e?[...e]:[],this._size=this._buf.length}get version(){return this._version}get size(){return this._size}at(e){if(!Number.isInteger(e))return;let t=e>=0?e:this._size+e;if(!(t<0||t>=this._size))return this._maxSize!==void 0?this._buf[(this._head+t)%this._maxSize]:this._buf[t]}append(e){this._rawAppend(e),this._version+=1}appendMany(e){if(e.length===0)return;let t=this._maxSize!==void 0&&e.length>this._maxSize?e.length-this._maxSize:0;for(let n=t;n<e.length;n++)this._rawAppend(e[n]);this._version+=1}clear(){if(this._size===0)return 0;let e=this._size;if(this._maxSize===void 0)this._buf.length=0;else for(let t=0;t<e;t++)this._buf[(this._head+t)%this._maxSize]=void 0;return this._head=0,this._size=0,this._version+=1,e}trimHead(e){if(!Number.isInteger(e)||e<0)throw new RangeError(`trimHead: n must be a non-negative integer (got ${e})`);if(e===0||this._size===0)return 0;let t=Math.min(e,this._size);if(this._maxSize===void 0)this._buf.splice(0,t);else{for(let n=0;n<t;n++)this._buf[(this._head+n)%this._maxSize]=void 0;this._head=(this._head+t)%this._maxSize}return this._size-=t,this._version+=1,t}slice(e,t){if(!Number.isInteger(e)||e<0)throw new RangeError(`slice: start must be a non-negative integer (got ${e})`);if(t!==void 0&&(!Number.isInteger(t)||t<0))throw new RangeError(`slice: stop must be a non-negative integer or undefined (got ${t})`);let n=t===void 0?this._size:Math.min(Math.max(t,0),this._size),s=Math.min(e,this._size);if(s>=n)return[];let o=n-s;if(this._maxSize===void 0)return this._buf.slice(s,n);let i=new Array(o);for(let a=0;a<o;a++)i[a]=this._buf[(this._head+s+a)%this._maxSize];return i}tail(e){if(!Number.isInteger(e)||e<0)throw new RangeError(`tail: n must be a non-negative integer (got ${e})`);if(e===0||this._size===0)return[];let t=Math.min(e,this._size);return this.slice(this._size-t,this._size)}toArray(){if(this._maxSize===void 0)return[...this._buf];let e=new Array(this._size);for(let t=0;t<this._size;t++)e[t]=this._buf[(this._head+t)%this._maxSize];return e}snapshot(){return this.toArray()}restore(e){if(this._maxSize===void 0){this._buf.length=0;for(let t=0;t<e.length;t++)this._buf.push(e[t]);this._size=this._buf.length}else{let t=this._maxSize;for(let o=0;o<t;o++)this._buf[o]=void 0;this._head=0;let n=Math.min(e.length,t),s=e.length-n;for(let o=0;o<n;o++)this._buf[o]=e[s+o];this._size=n}this._version+=1}_rawAppend(e){if(this._maxSize===void 0){this._buf.push(e),this._size=this._buf.length;return}this._size<this._maxSize?(this._buf[(this._head+this._size)%this._maxSize]=e,this._size+=1):(this._buf[this._head]=e,this._head=(this._head+1)%this._maxSize)}};function Ve(r){return r.subscribe(()=>{})}var Nr=64;function ot(r,e={}){let{name:t,maxSize:n,versioning:s,guard:o,backend:i}=e,a=i??new It(r,n),d=B(a.toArray(),{name:t,describeKind:"state",equals:(m,x)=>m===x,...s!=null?{versioning:s}:{},...o!=null?{guard:o}:{}});function u(){let m=a.toArray();H(()=>{d.down([[L]],{internal:!0}),d.down([[M,m]],{internal:!0})})}let c=new Map,f=new Map,p=new Map;function h(m,x){return`${m}:${x===void 0?"END":x}`}function l(m){if(m.size<Nr)return;let x=m.keys().next();if(x.done)return;let N=m.get(x.value);N!==void 0&&N.dispose(),m.delete(x.value)}function y(m){let x=a.version;try{return m()}finally{a.version!==x&&u()}}function g(m){if(!Number.isInteger(m)||m<0)throw new RangeError(`tail: n must be a non-negative integer (got ${m})`);let x=c.get(m);if(x!==void 0)return c.delete(m),c.set(m,x),x.node;l(c);let N=J([d],([k])=>{let A=k;return m===0||A.length===0?[]:A.slice(Math.max(0,A.length-m))},{initial:a.tail(m),describeKind:"derived"}),E=Ve(N);return c.set(m,{node:N,dispose:E}),N}function w(m,x){if(!Number.isInteger(m)||m<0)throw new RangeError(`slice: start must be a non-negative integer (got ${m})`);if(x!==void 0&&(!Number.isInteger(x)||x<0))throw new RangeError(`slice: stop must be a non-negative integer or undefined (got ${x})`);let N=h(m,x),E=f.get(N);if(E!==void 0)return f.delete(N),f.set(N,E),E.node;l(f);let k=J([d],([D])=>{let S=D;return x===void 0?S.slice(m):S.slice(m,x)},{initial:a.slice(m,x),describeKind:"derived"}),A=Ve(k);return f.set(N,{node:k,dispose:A}),k}function v(m){let x=p.get(m);if(x!==void 0)return x.node;let N=J([d,m],([k,A])=>{let D=k,S=Math.max(0,Math.trunc(A??0));return D.slice(S)},{initial:[],describeKind:"derived"}),E=Ve(N);return p.set(m,{node:N,dispose:E}),N}let b,_;function T(){b===void 0&&(b=se([d],(m,x,N)=>{let E=m[0],A=E!=null&&E.length>0?E.at(-1):N.prevData[0];if(A==null||A.length===0){x.down([[U]]);return}x.emit(A[A.length-1])},{name:t!=null?`${t}::lastValue`:"lastValue",describeKind:"derived",initial:a.size===0?void 0:a.at(a.size-1)}),_=J([d],([m])=>m.length>0,{name:t!=null?`${t}::hasLatest`:"hasLatest",describeKind:"derived",initial:a.size>0}),Ve(b),Ve(_))}let O={entries:d,get size(){return a.size},at(m){return a.at(m)},append(m){y(()=>a.append(m))},appendMany(m){m.length!==0&&y(()=>a.appendMany(m))},clear(){y(()=>a.clear())},trimHead(m){y(()=>a.trimHead(m))},withLatest(){return T(),d},get lastValue(){return T(),b},get hasLatest(){return T(),_},view(m){switch(m.kind){case"tail":return g(m.n);case"slice":return w(m.start,m.stop);case"fromCursor":return v(m.cursor)}},attach(m){let x=m.subscribe(N=>{for(let E of N)E[0]===M&&O.append(E[1])});return()=>x()},attachStorage(m){if(m.length===0)return()=>{};let x=new Map;for(let E of m)x.set(E,a.size);(async()=>{for(let E of m)if(typeof E.loadEntries=="function")try{let k=await Promise.resolve(E.loadEntries());k.entries.length>0&&a.size===0&&(a.restore(k.entries),x.set(E,k.entries.length),u());break}catch{}})();let N=d.subscribe(E=>{for(let k of E){if(k[0]!==M)continue;let A=k[1];for(let D of m){let S=x.get(D)??0;if(A.length<S){try{let K=D.appendEntries(A);K instanceof Promise&&K.catch(()=>{})}catch{}x.set(D,A.length);continue}if(A.length===S)continue;let te=A.slice(S);x.set(D,A.length);try{let K=D.appendEntries(te);K instanceof Promise&&K.catch(()=>{})}catch{}}}});return()=>N()},disposeAllViews(){for(let m of c.values())m.dispose();c.clear();for(let m of f.values())m.dispose();f.clear();for(let m of p.values())m.dispose();p.clear()},dispose(){for(let m of c.values())m.dispose();c.clear();for(let m of f.values())m.dispose();f.clear();for(let m of p.values())m.dispose();p.clear()}};return O}var Or=qt((r,e)=>{r("observe"),r("signal"),e("write")});function Dn(r){let e=ot([],{name:r.name,maxSize:r.retainedLimit??1024,guard:r.guard??Or,...r.versioning!=null?{versioning:r.versioning}:{}});return e.withLatest(),r.graph&&r.graph.add(e.entries,{name:r.name}),e}function Cn(r){if(r===null||typeof r!="object"||Object.isFrozen(r))return r;for(let e of Object.keys(r))Cn(r[e]);return Object.freeze(r)}var Sn=new WeakSet;function Pt(r){let e=r.cache,t=typeof e=="number"&&Number.isFinite(e);!t&&e!==void 0&&!Sn.has(r)&&(Sn.add(r),console.warn(`bumpCursor: cursor cache held a non-numeric value (${String(e)}); resetting to 0. Causes include: a snapshot codec round-tripping the cursor as a string / null / NaN, OR a malformed initial seed (e.g. state<number>(NaN)). Audit consumers may see colliding seq values after this point.`));let s=(t?e:0)+1;return r.down([[L],[M,s]]),s}function Mn(r,e,t,n,s,o){let i=e(t,n,s);if(i===void 0)return;let a=o!=null?{...i,handlerVersion:o}:i;r.append(a)}function ze(r,e){let t=e.freeze??!0;return function(...s){let o=t?s.map(Cn):s,i=ue(),a=e.seq?Pt(e.seq):void 0;try{let d=r(...o);return e.audit&&e.onSuccess&&Mn(e.audit,e.onSuccess,o,d,{t_ns:i,seq:a},e.handlerVersion),d}catch(d){if(e.audit&&e.onFailure){let u=d instanceof Error?d.name:typeof d;Mn(e.audit,e.onFailure,o,d,{t_ns:i,seq:a,errorType:u},e.handlerVersion)}throw d}}}function Gn(r,e,t=0){let n=B(t,{name:e,describeKind:"state"});return r.add(n,{name:e}),n}be();re();le();var $t=class{_version=0;_buf;constructor(e){this._buf=e?[...e]:[]}get version(){return this._version}get size(){return this._buf.length}at(e){if(!Number.isInteger(e))return;let t=e>=0?e:this._buf.length+e;if(!(t<0||t>=this._buf.length))return this._buf[t]}append(e){this._buf.push(e),this._version+=1}appendMany(e){if(e.length===0)return;let t=this._buf.length;this._buf.length=t+e.length;for(let n=0;n<e.length;n++)this._buf[t+n]=e[n];this._version+=1}insert(e,t){if(!Number.isInteger(e)||e<0||e>this._buf.length)throw new RangeError(`insert: index ${e} out of range [0, ${this._buf.length}]`);this._buf.splice(e,0,t),this._version+=1}insertMany(e,t){if(!Number.isInteger(e)||e<0||e>this._buf.length)throw new RangeError(`insertMany: index ${e} out of range [0, ${this._buf.length}]`);t.length!==0&&(this._buf.splice(e,0,...t),this._version+=1)}pop(e){if(this._buf.length===0)throw new RangeError("pop from empty list");if(!Number.isInteger(e))throw new RangeError(`pop: index ${e} must be an integer`);let t=e>=0?e:this._buf.length+e;if(t<0||t>=this._buf.length)throw new RangeError(`pop: index ${e} out of range`);let[n]=this._buf.splice(t,1);return this._version+=1,n}clear(){let e=this._buf.length;return e===0?0:(this._buf.length=0,this._version+=1,e)}toArray(){return[...this._buf]}};function In(r,e={}){let{name:t,versioning:n,backend:s}=e,o=s??new $t(r),i=B(o.toArray(),{name:t,describeKind:"state",equals:(u,c)=>u===c,...n!=null?{versioning:n}:{}});function a(){let u=o.toArray();H(()=>{i.down([[L]]),i.down([[M,u]])})}function d(u){let c=o.version;try{return u()}finally{o.version!==c&&a()}}return{items:i,get size(){return o.size},at(u){return o.at(u)},append(u){d(()=>o.append(u))},appendMany(u){d(()=>o.appendMany(u))},insert(u,c){d(()=>o.insert(u,c))},insertMany(u,c){d(()=>o.insertMany(u,c))},pop(u=-1){return d(()=>o.pop(u))},clear(){d(()=>o.clear())},dispose(){}}}be();he();re();le();var Lt=class{_version=0;_store=new Map;_maxSize;_defaultTtl;constructor(e={}){let{maxSize:t,defaultTtl:n}=e;if(t!==void 0&&t<1)throw new RangeError("maxSize must be >= 1");if(n!==void 0&&n<=0)throw new RangeError("defaultTtl must be positive");this._maxSize=t,this._defaultTtl=n}get version(){return this._version}get size(){return this._store.size}has(e){let t=this._store.get(e);return t===void 0?!1:this._isExpired(t)?(this._store.delete(e),this._version+=1,!1):(this._touchLru(e,t),!0)}get(e){let t=this._store.get(e);if(t!==void 0){if(this._isExpired(t)){this._store.delete(e),this._version+=1;return}return this._touchLru(e,t),t.value}}set(e,t,n){let s=this._resolveExpiresAt(n);this._store.has(e)&&this._store.delete(e),this._store.set(e,{value:t,expiresAt:s}),this._evictLruWhileOver(),this._version+=1}setMany(e,t){let n=this._resolveExpiresAt(t),s=0;try{for(let[o,i]of e)this._store.has(o)&&this._store.delete(o),this._store.set(o,{value:i,expiresAt:n}),s+=1}finally{s>0&&(this._evictLruWhileOver(),this._version+=1)}}delete(e){let t=this._store.delete(e);return t&&(this._version+=1),t}deleteMany(e){let t=0;try{for(let n of e)this._store.delete(n)&&(t+=1)}finally{t>0&&(this._version+=1)}return t}clear(){let e=this._store.size;return e===0?0:(this._store.clear(),this._version+=1,e)}pruneExpired(){let e=W(),t=0;for(let[n,s]of this._store)this._isExpired(s,e)&&(this._store.delete(n),t+=1);return t>0&&(this._version+=1),t}toMap(){let e=W(),t=new Map;for(let[n,s]of this._store)this._isExpired(s,e)||t.set(n,s.value);return t}_resolveExpiresAt(e){let t=e??this._defaultTtl;if(t!==void 0){if(!Number.isFinite(t)||t<=0)throw new RangeError(`MapBackend: ttl must be a positive finite number (got ${t})`);return W()+t*1e9}}_isExpired(e,t){return e.expiresAt===void 0?!1:(t??W())>=e.expiresAt}_touchLru(e,t){this._store.delete(e),this._store.set(e,t)}_evictLruWhileOver(){if(this._maxSize!==void 0)for(;this._store.size>this._maxSize;){let e=this._store.keys().next().value;if(e===void 0)break;this._store.delete(e)}}};function Pn(r={}){let{name:e,maxSize:t,defaultTtl:n,versioning:s,backend:o,retention:i}=r;if(i&&t!==void 0)throw new RangeError("reactiveMap: `maxSize` (LRU) and `retention` (score-based) are mutually exclusive. Pick one eviction policy.");if(i&&i.archiveThreshold===void 0&&i.maxSize===void 0)throw new RangeError("reactiveMap: `retention` requires at least one of `archiveThreshold` or `maxSize` to trigger archival.");let a=o??new Lt({maxSize:t,defaultTtl:n}),d=B(a.toMap(),{name:e,describeKind:"state",equals:(p,h)=>p===h,...s!=null?{versioning:s}:{}});function u(){let p=a.toMap();H(()=>{d.down([[L]]),d.down([[M,p]])})}function c(){if(!i)return;let p=a.toMap(),h=i.archiveThreshold,l=i.maxSize,y=[];for(let[w,v]of p)y.push({key:w,value:v,score:i.score(w,v)});y.sort((w,v)=>w.score-v.score);let g=new Set;if(h!==void 0)for(let w of y)if(w.score<h)g.add(w.key);else break;if(l!==void 0&&y.length-g.size>l)for(let w of y){if(y.length-g.size<=l)break;g.has(w.key)||g.add(w.key)}if(g.size!==0)for(let w of y)g.has(w.key)&&(i.onArchive?.(w.key,w.value,w.score),a.delete(w.key))}function f(p,h="mutation"){let l=a.version;try{return p()}finally{a.version!==l&&(h==="mutation"&&c(),u())}}return{entries:d,has(p){return f(()=>a.has(p),"read")},get(p){return f(()=>a.get(p),"read")},set(p,h,l){f(()=>a.set(p,h,l?.ttl))},setMany(p,h){f(()=>a.setMany(p,h?.ttl))},delete(p){f(()=>a.delete(p))},deleteMany(p){f(()=>a.deleteMany(p))},clear(){f(()=>a.clear())},pruneExpired(){f(()=>a.pruneExpired())},get size(){return a.size},dispose(){}}}Mt();$n();var Er=256,Rr=1024;function it(r,e){if(!Number.isFinite(r)||!Number.isInteger(r)||r<0)throw new Error(`${e} must be a non-negative integer`);return r}function at(r,e){return sn("job_queue",r,e)}var Ar=r=>r.action,dt=class extends xe{_pending;_jobs;_seqCursor;pending;jobs;depth;events;audit;_enqueueImpl;_ackImpl;_nackImpl;_removeByIdImpl;constructor(e,t={}){super(e,t.graph),this._pending=In([],{name:"pending"}),this._jobs=Pn({name:"jobs"}),this.pending=this._pending.items,this.jobs=this._jobs.entries,this.add(this.pending,{name:"pending"}),this.add(this.jobs,{name:"jobs"}),this.depth=J([this.pending],([n])=>n.length,{name:"depth",describeKind:"derived",meta:at("queue_depth"),initial:0}),this.add(this.depth,{name:"depth"}),this.addDisposer(ae(this.depth)),this.events=Dn({name:"events",retainedLimit:1024,graph:this}),this.audit=this.events,this._seqCursor=Gn(this,"seq",0),this._enqueueImpl=ze((n,s)=>{let o=this._seqCursor.cache,i=s.id??`${this.name}-${o}`;if(this._jobs.get(i)!==void 0)throw new Error(`jobQueue("${this.name}"): duplicate job id "${i}"`);let a={id:i,payload:n,attempts:0,metadata:Object.freeze({...s.metadata??{}}),state:"queued"};return this._jobs.set(i,a),this._pending.append(i),i},{audit:this.events,seq:this._seqCursor,freeze:!1,onSuccess:([n],s,{t_ns:o,seq:i})=>({action:"enqueue",id:s,payload:n,t_ns:o,seq:i??0})}),this._ackImpl=ze((n,s)=>{this._jobs.delete(n)},{audit:this.events,seq:this._seqCursor,freeze:!1,onSuccess:([n,s],o,{t_ns:i,seq:a})=>({action:"ack",id:n,attempts:s.attempts,t_ns:i,seq:a??0})}),this._nackImpl=ze((n,s,o)=>{o?(this._jobs.set(n,{...s,state:"queued"}),this._pending.append(n)):this._jobs.delete(n)},{audit:this.events,seq:this._seqCursor,freeze:!1,onSuccess:([n,s],o,{t_ns:i,seq:a})=>({action:"nack",id:n,attempts:s.attempts,t_ns:i,seq:a??0})}),this._removeByIdImpl=ze((n,s)=>{if(s.state==="queued"){let i=this.pending.cache.indexOf(n);i>=0&&this._pending.pop(i)}this._jobs.delete(n)},{audit:this.events,seq:this._seqCursor,freeze:!1,onSuccess:([n,s],o,{t_ns:i,seq:a})=>({action:"remove",id:n,attempts:s.attempts,t_ns:i,seq:a??0})})}attachEventStorage(e){return this.events.attachStorage(e)}enqueue(e,t={}){return this._enqueueImpl(e,t)}claim(e=1){let t=it(e,"job queue claim limit");if(t===0)return[];let n=[];for(;n.length<t&&this.pending.cache.length!==0;){let o=this._pending.pop(0),i=this._jobs.get(o);if(!i||i.state!=="queued")continue;let a={...i,state:"inflight",attempts:i.attempts+1};this._jobs.set(o,a),n.push(a),this.events.append({action:"claim",id:o,attempts:a.attempts,t_ns:ue(),seq:Pt(this._seqCursor)})}return n}ack(e){let t=this._jobs.get(e);return!t||t.state!=="inflight"?!1:(this._ackImpl(e,t),!0)}nack(e,t={}){let n=this._jobs.get(e);return!n||n.state!=="inflight"?!1:(this._nackImpl(e,n,t.requeue??!0),!0)}removeById(e){let t=this._jobs.get(e);return t?(this._removeByIdImpl(e,t),!0):!1}consumeFrom(e,t){return e.subscribe(n=>{for(let s of n){if(s[0]!==M)continue;let o=s[1];this.enqueue(o,t?{metadata:t.metadata}:void 0)}})}},ut=class extends xe{_stageNames;_stageWorkFns;_queues=new Map;_completed;completed;completedCount;constructor(e,t={}){super(e,t.graph);let n=t.stages??["incoming","processing","done"],s=[],o=new Map,i=new Map,a=new Map;for(let c of n){let f=typeof c=="string"?c.trim():c.name.trim();typeof c!="string"&&c.work&&o.set(f,c.work),typeof c!="string"&&c.maxPerPump!=null&&i.set(f,Math.max(1,it(c.maxPerPump,`job flow stage "${f}" maxPerPump`))),typeof c!="string"&&c.maxInflight!=null&&a.set(f,Math.max(1,it(c.maxInflight,`job flow stage "${f}" maxInflight`))),s.push(f)}if(s.length<2)throw new Error(`jobFlow("${e}"): requires at least 2 stages`);if(new Set(s).size!==s.length)throw new Error(`jobFlow("${e}"): stage names must be unique`);this._stageNames=Object.freeze([...s]),this._stageWorkFns=o;for(let c of this._stageNames){let f=Ln(`${e}-${c}`);this._queues.set(c,f),this.mount(c,f)}this._completed=ot([],{name:"completed",maxSize:Rr}),this.completed=this._completed.entries,this.add(this.completed,{name:"completed"}),this.completedCount=J([this.completed],([c])=>c.length,{name:"completedCount",describeKind:"derived",meta:at("job_flow_completed_count"),initial:0}),this.add(this.completedCount,{name:"completedCount"}),this.addDisposer(ae(this.completedCount));let u=Math.max(1,it(t.maxPerPump??Er,"job flow maxPerPump"));for(let c=0;c<this._stageNames.length;c+=1){let f=this._stageNames[c],p=this.queue(f),h=c+1<this._stageNames.length?this.queue(this._stageNames[c+1]):null,l=this._stageWorkFns.get(f),y=i.get(f)??u,g=a.get(f),w=g!==void 0?B(0,{name:`__inflight__/${f}`}):null;w&&this.add(w,{name:`__inflight__/${f}`});let v=h===null;if(l){let b=w!=null?[p.pending,w]:[p.pending],_=se(b,(T,O,m)=>{"inflight"in m.store||(m.store.inflight={entries:new Set,terminated:!1});let x=m.store.inflight,N=x.entries,E=0;for(;E<y&&!(g!==void 0&&N.size>=g);){let k=p.claim(1);if(k.length===0)break;let A=k[0];if(!A)break;let S=[...A.metadata.job_flow_path??[],f],te=new AbortController,K={unsub:()=>{},ac:te};N.add(K),w?.emit(N.size);let pe;try{pe=l(A,{signal:te.signal})}catch{N.delete(K),w?.emit(N.size),p.nack(A.id,{requeue:!1}),E+=1;continue}let je=Xe(pe),ke=!1,oe,Ne=()=>{oe?oe():Promise.resolve().then(()=>oe?.()),N.delete(K),x.terminated||w?.emit(N.size)};oe=je.subscribe(De=>{if(!ke){for(let de of De)if(de[0]===M){ke=!0,Ne();let Ce=de[1],R={...A.metadata,job_flow_path:S};if(v){let I={...A,payload:Ce,metadata:Object.freeze(R)};H(()=>{p.ack(A.id),this._completed.append(I)})}else H(()=>{p.ack(A.id),h.enqueue(Ce,{metadata:R})});return}else if(de[0]===C){ke=!0,Ne(),p.nack(A.id,{requeue:!1});return}}}),K.unsub=()=>oe?.(),E+=1}return{deactivate:()=>{x.terminated=!0;for(let k of N){try{k.ac.abort()}catch{}try{k.unsub()}catch{}}N.clear()}}},{name:`pump_${f}`,describeKind:"effect",meta:at("job_flow_pump",{stage:f,has_work:!0})});this.add(_,{name:`pump_${f}`}),this.addDisposer(ae(_))}else{let b=se([p.pending],()=>{let _=0;for(;_<y;){let T=p.claim(1);if(T.length===0)break;let O=T[0];if(!O)break;let x=[...O.metadata.job_flow_path??[],f],N={...O.metadata,job_flow_path:x};if(v){let E={...O,metadata:Object.freeze(N)};H(()=>{p.ack(O.id),this._completed.append(E)})}else H(()=>{p.ack(O.id),h.enqueue(O.payload,{metadata:N})});_+=1}},{name:`pump_${f}`,describeKind:"effect",meta:at("job_flow_pump",{stage:f,has_work:!1})});this.add(b,{name:`pump_${f}`}),this.addDisposer(ae(b))}}}stages(){return this._stageNames}queue(e){let t=this._queues.get(e);if(!t)throw new Error(`jobFlow("${this.name}"): unknown stage "${e}"`);return t}enqueue(e,t={}){return this.queue(this._stageNames[0]).enqueue(e,t)}retainedCompleted(){return this.completed.cache}};function Ln(r,e){return new dt(r,e)}function Sr(r,e){let t=new ut(r,e),{factory:n,factoryArgs:s,...o}=e??{};return t.tagFactory("jobFlow",kt(o)),t}0&&(module.exports={JobFlowGraph,JobQueueGraph,jobEventKeyOf,jobFlow,jobQueue});
@@ -1,9 +1,9 @@
1
- import '../../node-ClS5yC-B.cjs';
2
- import '../../index-DBIqYS43.cjs';
3
- import '../../reactive-log-B00laMSQ.cjs';
1
+ import '../../node-kK3CvTrR.cjs';
2
+ import '../../index-D0aciIex.cjs';
3
+ import '../../reactive-log-DIGdYqQ6.cjs';
4
4
  import '../../extra/sources.cjs';
5
5
  import '../../extra/storage-tiers.cjs';
6
- import '../../graph-C4SHb3Ly.cjs';
7
- export { J as JobEnvelope, c as JobEvent, d as JobEventAction, a as JobFlowGraph, e as JobFlowOptions, b as JobQueueGraph, f as JobQueueOptions, g as JobState, S as StageDef, W as WorkFn, j as jobEventKeyOf, h as jobFlow, k as jobQueue } from '../../index-3NmAfcH0.cjs';
8
- import '../../meta-vE8bxW1E.cjs';
6
+ import '../../graph-CWvEUQAq.cjs';
7
+ export { J as JobEnvelope, c as JobEvent, d as JobEventAction, a as JobFlowGraph, e as JobFlowOptions, b as JobQueueGraph, f as JobQueueOptions, g as JobState, S as StageDef, W as WorkFn, j as jobEventKeyOf, h as jobFlow, k as jobQueue } from '../../index-DV_1YuVk.cjs';
8
+ import '../../sugar-DQjFmVqb.cjs';
9
9
  import '../../extra/storage-core.cjs';
@@ -1,9 +1,9 @@
1
- import '../../node-ClS5yC-B.js';
2
- import '../../index-DO9XxMzS.js';
3
- import '../../reactive-log-BezYsbA_.js';
1
+ import '../../node-kK3CvTrR.js';
2
+ import '../../index-Yq60JP3s.js';
3
+ import '../../reactive-log-BKALbfal.js';
4
4
  import '../../extra/sources.js';
5
5
  import '../../extra/storage-tiers.js';
6
- import '../../graph-7VguS7a4.js';
7
- export { J as JobEnvelope, c as JobEvent, d as JobEventAction, a as JobFlowGraph, e as JobFlowOptions, b as JobQueueGraph, f as JobQueueOptions, g as JobState, S as StageDef, W as WorkFn, j as jobEventKeyOf, h as jobFlow, k as jobQueue } from '../../index-CJQm0g38.js';
8
- import '../../meta-BgVAsg9j.js';
6
+ import '../../graph-D9LFnda9.js';
7
+ export { J as JobEnvelope, c as JobEvent, d as JobEventAction, a as JobFlowGraph, e as JobFlowOptions, b as JobQueueGraph, f as JobQueueOptions, g as JobState, S as StageDef, W as WorkFn, j as jobEventKeyOf, h as jobFlow, k as jobQueue } from '../../index-DisjX8a-.js';
8
+ import '../../sugar-fhLIE7TT.js';
9
9
  import '../../extra/storage-core.js';
@@ -1 +1 @@
1
- import{a,b,c,d,e}from"../../chunk-5ST42ESJ.js";import"../../chunk-4I45FVQS.js";import"../../chunk-KGKJCHEK.js";import"../../chunk-TZQPPQEQ.js";import"../../chunk-3ZZX7M25.js";import"../../chunk-L6NSJVJZ.js";import"../../chunk-LDQ3IUIP.js";import"../../chunk-XLQPNNIC.js";import"../../chunk-3G5U5QNE.js";import"../../chunk-C72GO4IZ.js";import"../../chunk-ACMJ2ZPS.js";import"../../chunk-ESMPEKEV.js";import"../../chunk-2K5RXLAH.js";import"../../chunk-35JTVPOX.js";import"../../chunk-LYCLF26R.js";import"../../chunk-CK2E7BTU.js";import"../../chunk-QYADASLV.js";export{c as JobFlowGraph,b as JobQueueGraph,a as jobEventKeyOf,e as jobFlow,d as jobQueue};
1
+ import{a,b,c,d,e}from"../../chunk-FZMYDOWV.js";import"../../chunk-KZIEYVXN.js";import"../../chunk-W3I423PS.js";import"../../chunk-L6NSJVJZ.js";import"../../chunk-2T7U5EU6.js";import"../../chunk-3G5U5QNE.js";import"../../chunk-C72GO4IZ.js";import"../../chunk-HITNVN6B.js";import"../../chunk-ESMPEKEV.js";import"../../chunk-GHBWHMRZ.js";import"../../chunk-GLERH466.js";import"../../chunk-BEZWM2SY.js";import"../../chunk-YBB7ZGTY.js";import"../../chunk-CRVT7D2P.js";import"../../chunk-NTEURFZH.js";import"../../chunk-CK2E7BTU.js";import"../../chunk-QYADASLV.js";export{c as JobFlowGraph,b as JobQueueGraph,a as jobEventKeyOf,e as jobFlow,d as jobQueue};