@graphrefly/graphrefly 0.41.0 → 0.42.0

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (296) hide show
  1. package/dist/{cascading-Cxs1eztH.d.cts → cascading-CH-_VwG9.d.cts} +2 -2
  2. package/dist/{cascading-BNfxffgc.d.ts → cascading-OgKQZjsa.d.ts} +2 -2
  3. package/dist/{chunk-L77I47VU.js → chunk-2K5RXLAH.js} +1 -1
  4. package/dist/chunk-3ERTUW2J.js +45 -0
  5. package/dist/chunk-3K7HA4Y6.js +1 -0
  6. package/dist/chunk-3ZZX7M25.js +1 -0
  7. package/dist/chunk-4QH6VJF4.js +1 -0
  8. package/dist/{chunk-M3FQSXEW.js → chunk-5QRRKBUT.js} +1 -1
  9. package/dist/chunk-5ST42ESJ.js +1 -0
  10. package/dist/{chunk-AK5RHMC5.js → chunk-6YFZMUMR.js} +1 -1
  11. package/dist/{chunk-SC27WTSG.js → chunk-7ARY3Y3T.js} +1 -1
  12. package/dist/chunk-7B7ELAT2.js +1 -0
  13. package/dist/{chunk-F7VUYPP6.js → chunk-7VKFXLZQ.js} +1 -1
  14. package/dist/chunk-ACMJ2ZPS.js +3 -0
  15. package/dist/{chunk-7PQLZMOG.js → chunk-AGNM6RS6.js} +1 -1
  16. package/dist/chunk-AS3TV2TV.js +1 -0
  17. package/dist/{chunk-CGNOWGV6.js → chunk-CISGGAIF.js} +1 -1
  18. package/dist/{chunk-ZAJ7J7TO.js → chunk-DEJTNNQC.js} +1 -1
  19. package/dist/{chunk-AI7QC7J6.js → chunk-FDZAZNRO.js} +1 -1
  20. package/dist/{chunk-OV5AA6HJ.js → chunk-FUZ6S2DY.js} +1 -1
  21. package/dist/{chunk-G3M3IMEV.js → chunk-G5VBJ5K6.js} +1 -1
  22. package/dist/{chunk-KNVCCBIU.js → chunk-HZKW2AAB.js} +1 -1
  23. package/dist/{chunk-CYOSWFT2.js → chunk-IZM3UEH3.js} +3 -3
  24. package/dist/{chunk-UISPDFJ3.js → chunk-KCACBSJH.js} +1 -1
  25. package/dist/{chunk-GI4Q7PNY.js → chunk-KT5DTRBP.js} +1 -1
  26. package/dist/{chunk-33N4TU3X.js → chunk-KY2LMAXU.js} +1 -1
  27. package/dist/{chunk-TT4C7DXW.js → chunk-LDQ3IUIP.js} +1 -1
  28. package/dist/chunk-LPRWATHB.js +61 -0
  29. package/dist/{chunk-X7QKTXXC.js → chunk-NWXQIOIB.js} +3 -3
  30. package/dist/{chunk-VV62MIG4.js → chunk-Q7QQQA3I.js} +1 -1
  31. package/dist/chunk-VE5SIZEM.js +1 -0
  32. package/dist/chunk-VRALOYRD.js +1 -0
  33. package/dist/{chunk-5VEZLQFN.js → chunk-WHMUB5QB.js} +1 -1
  34. package/dist/chunk-XLQPNNIC.js +1 -0
  35. package/dist/{chunk-YQRN4CIV.js → chunk-YGL7FPVQ.js} +1 -1
  36. package/dist/compat/index.cjs +5 -5
  37. package/dist/compat/index.d.cts +16 -16
  38. package/dist/compat/index.d.ts +16 -16
  39. package/dist/compat/index.js +1 -1
  40. package/dist/compat/jotai/index.d.cts +2 -2
  41. package/dist/compat/jotai/index.d.ts +2 -2
  42. package/dist/compat/nanostores/index.d.cts +2 -2
  43. package/dist/compat/nanostores/index.d.ts +2 -2
  44. package/dist/compat/nestjs/index.cjs +5 -5
  45. package/dist/compat/nestjs/index.d.cts +8 -8
  46. package/dist/compat/nestjs/index.d.ts +8 -8
  47. package/dist/compat/nestjs/index.js +1 -1
  48. package/dist/compat/react/index.d.cts +2 -2
  49. package/dist/compat/react/index.d.ts +2 -2
  50. package/dist/compat/solid/index.d.cts +2 -2
  51. package/dist/compat/solid/index.d.ts +2 -2
  52. package/dist/compat/svelte/index.d.cts +2 -2
  53. package/dist/compat/svelte/index.d.ts +2 -2
  54. package/dist/compat/vue/index.d.cts +2 -2
  55. package/dist/compat/vue/index.d.ts +2 -2
  56. package/dist/compat/zustand/index.cjs +3 -3
  57. package/dist/compat/zustand/index.d.cts +4 -4
  58. package/dist/compat/zustand/index.d.ts +4 -4
  59. package/dist/compat/zustand/index.js +1 -1
  60. package/dist/core/index.d.cts +4 -4
  61. package/dist/core/index.d.ts +4 -4
  62. package/dist/{decay-C25AyNAj.d.cts → decay-2ZukgQ4o.d.cts} +2 -2
  63. package/dist/{decay-BnrlbxSv.d.ts → decay-CdEBmDIs.d.ts} +2 -2
  64. package/dist/extra/browser.d.cts +1 -1
  65. package/dist/extra/browser.d.ts +1 -1
  66. package/dist/extra/index.cjs +14 -14
  67. package/dist/extra/index.d.cts +10 -11
  68. package/dist/extra/index.d.ts +10 -11
  69. package/dist/extra/index.js +1 -1
  70. package/dist/extra/node.cjs +2 -2
  71. package/dist/extra/node.d.cts +1 -1
  72. package/dist/extra/node.d.ts +1 -1
  73. package/dist/extra/node.js +1 -1
  74. package/dist/extra/operators.cjs +1 -1
  75. package/dist/extra/operators.d.cts +1 -1
  76. package/dist/extra/operators.d.ts +1 -1
  77. package/dist/extra/operators.js +1 -1
  78. package/dist/extra/reactive.d.cts +3 -3
  79. package/dist/extra/reactive.d.ts +3 -3
  80. package/dist/extra/reactive.js +1 -1
  81. package/dist/extra/render/index.d.cts +3 -3
  82. package/dist/extra/render/index.d.ts +3 -3
  83. package/dist/extra/sources.cjs +3 -1
  84. package/dist/extra/sources.d.cts +1 -1
  85. package/dist/extra/sources.d.ts +1 -1
  86. package/dist/extra/sources.js +1 -1
  87. package/dist/extra/storage-browser.d.cts +1 -1
  88. package/dist/extra/storage-browser.d.ts +1 -1
  89. package/dist/{fallback-CMZl39L5.d.ts → fallback-CqYVLL6X.d.ts} +1 -1
  90. package/dist/{fallback-8JYU8tlT.d.cts → fallback-Ctlj2tMY.d.cts} +1 -1
  91. package/dist/graph/index.cjs +7 -7
  92. package/dist/graph/index.d.cts +5 -5
  93. package/dist/graph/index.d.ts +5 -5
  94. package/dist/graph/index.js +1 -1
  95. package/dist/{graph-BkIkog4h.d.ts → graph-7VguS7a4.d.ts} +3 -3
  96. package/dist/{graph-E6likq7w.d.cts → graph-C4SHb3Ly.d.cts} +3 -3
  97. package/dist/{index-DktLSZOc.d.cts → index-2B7u2pVn.d.cts} +4 -4
  98. package/dist/{index-DGD4_fj6.d.cts → index-3NmAfcH0.d.cts} +8 -5
  99. package/dist/{index-DfOK_oL5.d.ts → index-4Uz-e_fL.d.ts} +372 -17
  100. package/dist/{index-BAQrjuZF.d.ts → index-B-i4_g3k.d.ts} +2 -2
  101. package/dist/{index-DpiGqtrs.d.cts → index-B11anra4.d.cts} +441 -381
  102. package/dist/{index-WSlcjhQF.d.ts → index-B3OTH1dV.d.ts} +124 -13
  103. package/dist/{index-2n8Eai6M.d.ts → index-BG0BN3PB.d.ts} +1 -1
  104. package/dist/{index-z8WFPVI8.d.cts → index-BJX94aud.d.cts} +1 -1
  105. package/dist/{index-DhLyOHYZ.d.ts → index-BP8a88zx.d.ts} +11 -4
  106. package/dist/{index-Cnr1WrlX.d.cts → index-BTQtTb_H.d.cts} +14 -3
  107. package/dist/{index-BaA-xpSw.d.ts → index-BUYXac2c.d.ts} +3 -3
  108. package/dist/{index-DOBLxOti.d.cts → index-BVpm6noz.d.cts} +1 -1
  109. package/dist/{index-DhnsQfa3.d.ts → index-Bbkgpt5t.d.ts} +441 -381
  110. package/dist/{index-Cczxgd2D.d.ts → index-Bc41FuHp.d.cts} +3 -3
  111. package/dist/{index-BiHUBEKq.d.cts → index-BdGtBX-X.d.cts} +3 -3
  112. package/dist/index-BeT2r7sk.d.ts +760 -0
  113. package/dist/{index-da2V5vPy.d.ts → index-Bf7eqeSF.d.ts} +2 -2
  114. package/dist/{index-bXXLSvor.d.ts → index-Bn4zHYLj.d.ts} +4 -4
  115. package/dist/{index-DGTo1yka.d.cts → index-BoLv_OfD.d.cts} +2 -2
  116. package/dist/{index-B72TQQHd.d.cts → index-BsT7F2et.d.ts} +3 -3
  117. package/dist/{index-Bd91Nmf4.d.cts → index-BtAsBp8K.d.cts} +4 -4
  118. package/dist/{index-DgJc8Zgc.d.cts → index-C0-Jv1kP.d.cts} +81 -5
  119. package/dist/{index-C6ZUaos7.d.ts → index-C7O6r5fV.d.ts} +1 -1
  120. package/dist/{index-CL7oilfm.d.cts → index-C9kSENB4.d.cts} +1 -1
  121. package/dist/{index-yLt-aPMp.d.ts → index-CCq87F7t.d.ts} +1 -1
  122. package/dist/{index-DQQCOIt8.d.cts → index-CEMx8n40.d.cts} +10 -5
  123. package/dist/{index-BilOa6AE.d.cts → index-CJIuLu2f.d.cts} +124 -13
  124. package/dist/{index-B2RUoIUz.d.ts → index-CJK1JkYy.d.ts} +1 -1
  125. package/dist/{index-CG33HeBW.d.ts → index-CJQm0g38.d.ts} +8 -5
  126. package/dist/index-CPNSy-U0.d.cts +760 -0
  127. package/dist/{index-A3U3CSve.d.cts → index-CZjOhcBy.d.cts} +2 -2
  128. package/dist/{index-CAP3UGsq.d.ts → index-CZmcDtFn.d.ts} +1 -1
  129. package/dist/{index-DYTBbF8T.d.cts → index-ChOyVLKm.d.cts} +1 -1
  130. package/dist/{index-eaQuGJnv.d.ts → index-CpyNFqkB.d.ts} +3 -3
  131. package/dist/{index-BJSZxSFX.d.ts → index-CvrqGfNS.d.ts} +1 -1
  132. package/dist/{index-DuRsN9ae.d.cts → index-D-Xs74HZ.d.cts} +372 -17
  133. package/dist/{index-C5cQ7Gfx.d.ts → index-D6egPFAL.d.ts} +4 -4
  134. package/dist/{index-CD2dBMet.d.ts → index-D8l8hNXn.d.ts} +10 -5
  135. package/dist/{index-40ZT4MHj.d.ts → index-DBHK8O6H.d.ts} +14 -3
  136. package/dist/{index-DVDapw2k.d.cts → index-DBIqYS43.d.cts} +35 -21
  137. package/dist/{index-3k4Gg6-n.d.ts → index-DBevwHj_.d.ts} +3 -3
  138. package/dist/{index-Ctb7_2sG.d.ts → index-DIOoAZUX.d.ts} +1 -1
  139. package/dist/{index-BQ1fR4li.d.ts → index-DO9XxMzS.d.ts} +35 -21
  140. package/dist/{index-CQtWm7jS.d.ts → index-DQo8xBgd.d.ts} +9 -9
  141. package/dist/{index-DH4fm2Ck.d.ts → index-Dgs8zcj7.d.ts} +2 -2
  142. package/dist/{index-CtFNGe-m.d.cts → index-Dhc7a7Xo.d.cts} +2 -2
  143. package/dist/{index-MxYuWOrf.d.cts → index-DmAgG5CI.d.cts} +3 -3
  144. package/dist/{index-CoM4rzyB.d.ts → index-Dmqp7KjD.d.ts} +1 -1
  145. package/dist/{index-B6iTqKtJ.d.ts → index-Dn-wI9g4.d.ts} +2 -2
  146. package/dist/{index-C-dkXOpB.d.cts → index-Du7u1lSf.d.cts} +11 -4
  147. package/dist/{index-DVAlsmEU.d.cts → index-HoU88d5U.d.cts} +3 -3
  148. package/dist/{index-CRm0YIzC.d.cts → index-LIpQQE9f.d.cts} +9 -9
  149. package/dist/{index-CgnCFhr2.d.cts → index-f5IivDUX.d.cts} +1 -1
  150. package/dist/{index-PgwvGWa1.d.cts → index-hHcaFlJX.d.cts} +1 -1
  151. package/dist/{index-I1cCY3ZI.d.ts → index-pT8sCpOJ.d.ts} +81 -5
  152. package/dist/{index-D4uimgee.d.cts → index-sl4NyzQx.d.cts} +1 -1
  153. package/dist/{index-tV3AA9hI.d.cts → index-tJoTcnHh.d.cts} +2 -2
  154. package/dist/{index-D3ayz3hy.d.cts → index-z96luz5O.d.cts} +1 -1
  155. package/dist/index.cjs +48 -48
  156. package/dist/index.d.cts +45 -50
  157. package/dist/index.d.ts +45 -50
  158. package/dist/index.js +1 -1
  159. package/dist/{meta-D8OyedKp.d.ts → meta-BgVAsg9j.d.ts} +1 -1
  160. package/dist/{meta-Ct9nqQS5.d.cts → meta-vE8bxW1E.d.cts} +1 -1
  161. package/dist/{node-BYInONRr.d.cts → node-ClS5yC-B.d.cts} +1 -1
  162. package/dist/{node-BYInONRr.d.ts → node-ClS5yC-B.d.ts} +1 -1
  163. package/dist/{observable-DO8DDEzv.d.ts → observable-BsBzUrcI.d.ts} +1 -1
  164. package/dist/{observable-DMIlYJV1.d.cts → observable-DLGPPtb8.d.cts} +1 -1
  165. package/dist/patterns/ai/browser.d.cts +4 -4
  166. package/dist/patterns/ai/browser.d.ts +4 -4
  167. package/dist/patterns/ai/browser.js +1 -1
  168. package/dist/patterns/ai/index.cjs +17 -17
  169. package/dist/patterns/ai/index.d.cts +17 -17
  170. package/dist/patterns/ai/index.d.ts +17 -17
  171. package/dist/patterns/ai/index.js +1 -1
  172. package/dist/patterns/ai/node.d.cts +4 -4
  173. package/dist/patterns/ai/node.d.ts +4 -4
  174. package/dist/patterns/ai/node.js +1 -1
  175. package/dist/patterns/cqrs/index.cjs +3 -3
  176. package/dist/patterns/cqrs/index.d.cts +6 -6
  177. package/dist/patterns/cqrs/index.d.ts +6 -6
  178. package/dist/patterns/cqrs/index.js +1 -1
  179. package/dist/patterns/demo-shell/index.cjs +5 -5
  180. package/dist/patterns/demo-shell/index.d.cts +5 -5
  181. package/dist/patterns/demo-shell/index.d.ts +5 -5
  182. package/dist/patterns/demo-shell/index.js +1 -1
  183. package/dist/patterns/domain-templates/index.cjs +3 -3
  184. package/dist/patterns/domain-templates/index.d.cts +4 -4
  185. package/dist/patterns/domain-templates/index.d.ts +4 -4
  186. package/dist/patterns/domain-templates/index.js +1 -1
  187. package/dist/patterns/graphspec/index.cjs +12 -12
  188. package/dist/patterns/graphspec/index.d.cts +5 -5
  189. package/dist/patterns/graphspec/index.d.ts +5 -5
  190. package/dist/patterns/graphspec/index.js +1 -1
  191. package/dist/patterns/harness/index.cjs +10 -8
  192. package/dist/patterns/harness/index.d.cts +11 -12
  193. package/dist/patterns/harness/index.d.ts +11 -12
  194. package/dist/patterns/harness/index.js +1 -1
  195. package/dist/patterns/inspect/index.cjs +3 -0
  196. package/dist/patterns/inspect/index.d.cts +9 -0
  197. package/dist/patterns/inspect/index.d.ts +9 -0
  198. package/dist/patterns/inspect/index.js +1 -0
  199. package/dist/patterns/job-queue/index.cjs +3 -3
  200. package/dist/patterns/job-queue/index.d.cts +6 -6
  201. package/dist/patterns/job-queue/index.d.ts +6 -6
  202. package/dist/patterns/job-queue/index.js +1 -1
  203. package/dist/patterns/memory/index.cjs +3 -3
  204. package/dist/patterns/memory/index.d.cts +6 -6
  205. package/dist/patterns/memory/index.d.ts +6 -6
  206. package/dist/patterns/memory/index.js +1 -1
  207. package/dist/patterns/messaging/index.cjs +3 -3
  208. package/dist/patterns/messaging/index.d.cts +5 -5
  209. package/dist/patterns/messaging/index.d.ts +5 -5
  210. package/dist/patterns/messaging/index.js +1 -1
  211. package/dist/patterns/orchestration/index.cjs +3 -3
  212. package/dist/patterns/orchestration/index.d.cts +7 -7
  213. package/dist/patterns/orchestration/index.d.ts +7 -7
  214. package/dist/patterns/orchestration/index.js +1 -1
  215. package/dist/patterns/process/index.cjs +1 -1
  216. package/dist/patterns/process/index.d.cts +7 -7
  217. package/dist/patterns/process/index.d.ts +7 -7
  218. package/dist/patterns/process/index.js +1 -1
  219. package/dist/patterns/reactive-layout/index.cjs +4 -4
  220. package/dist/patterns/reactive-layout/index.d.cts +5 -5
  221. package/dist/patterns/reactive-layout/index.d.ts +5 -5
  222. package/dist/patterns/reactive-layout/index.js +1 -1
  223. package/dist/patterns/reduction/index.cjs +3 -3
  224. package/dist/patterns/reduction/index.d.cts +4 -4
  225. package/dist/patterns/reduction/index.d.ts +4 -4
  226. package/dist/patterns/reduction/index.js +1 -1
  227. package/dist/patterns/surface/index.cjs +8 -8
  228. package/dist/patterns/surface/index.d.cts +6 -6
  229. package/dist/patterns/surface/index.d.ts +6 -6
  230. package/dist/patterns/surface/index.js +1 -1
  231. package/dist/{pipeline-graph-MWrQZXCq.d.cts → pipeline-graph-WBlobVhU.d.cts} +5 -5
  232. package/dist/{pipeline-graph-CB4La-UW.d.ts → pipeline-graph-v8fMvqNk.d.ts} +5 -5
  233. package/dist/{reactive-layout-BtZfUKuL.d.cts → reactive-layout-Dsvob4zD.d.cts} +2 -2
  234. package/dist/{reactive-layout-KJj4E2dT.d.ts → reactive-layout-v7KPvxoc.d.ts} +2 -2
  235. package/dist/{reactive-log-_zeEnB9H.d.cts → reactive-log-B00laMSQ.d.cts} +1 -1
  236. package/dist/{reactive-log-BlAsPLl2.d.ts → reactive-log-BezYsbA_.d.ts} +1 -1
  237. package/dist/{reactive-map-6P_k3AQM.d.cts → reactive-map-48mnZ-nu.d.cts} +1 -1
  238. package/dist/{reactive-map-CjXByDV-.d.ts → reactive-map-BVVPdvmi.d.ts} +1 -1
  239. package/dist/resilience-445VFFXQ.js +1 -0
  240. package/dist/{sugar-BhfjgetH.d.ts → sugar-CH-2ZY90.d.ts} +1 -1
  241. package/dist/{sugar-DzePN5-g.d.cts → sugar-DStZfUEK.d.cts} +1 -1
  242. package/dist/{topology-tree-mF7Emqzm.d.ts → topology-tree-BNGvuG82.d.ts} +1 -1
  243. package/dist/{topology-tree-3LBKFsUo.d.cts → topology-tree-BSdfSwMi.d.cts} +1 -1
  244. package/dist/{types-1Dhoi7HM.d.cts → types-B1jDWVsM.d.cts} +1 -1
  245. package/dist/{types-39jk0kaV.d.ts → types-DkzUUs0H.d.ts} +1 -1
  246. package/package.json +11 -51
  247. package/dist/budget-gate-CmmVtasH.d.ts +0 -115
  248. package/dist/budget-gate-DiP_nK0n.d.cts +0 -115
  249. package/dist/chunk-2W553JJC.js +0 -1
  250. package/dist/chunk-4MKL6Q3K.js +0 -1
  251. package/dist/chunk-5B3JDG5F.js +0 -1
  252. package/dist/chunk-5QSXEMXG.js +0 -1
  253. package/dist/chunk-5TEFC2ZX.js +0 -1
  254. package/dist/chunk-5TOPVRN6.js +0 -1
  255. package/dist/chunk-EC2WNSZ7.js +0 -1
  256. package/dist/chunk-ELAASRBT.js +0 -3
  257. package/dist/chunk-H5SCWHWP.js +0 -1
  258. package/dist/chunk-OLIKJUKI.js +0 -1
  259. package/dist/chunk-POXANAJ6.js +0 -3
  260. package/dist/chunk-RSMEXK53.js +0 -43
  261. package/dist/chunk-SGS4OJGS.js +0 -1
  262. package/dist/chunk-URJ2VFNC.js +0 -1
  263. package/dist/chunk-VXPLLA4P.js +0 -1
  264. package/dist/chunk-WZYB3JQS.js +0 -1
  265. package/dist/chunk-Z6X7B6A4.js +0 -61
  266. package/dist/index-8s-Qm-gz.d.ts +0 -218
  267. package/dist/index-BgjS2b8N.d.ts +0 -366
  268. package/dist/index-BmSQLAZo.d.cts +0 -244
  269. package/dist/index-CGhMJNHb.d.cts +0 -128
  270. package/dist/index-CUIkE1l9.d.cts +0 -230
  271. package/dist/index-Ck35nA-T.d.ts +0 -244
  272. package/dist/index-CuPUehFa.d.cts +0 -218
  273. package/dist/index-D1Gc7wV5.d.ts +0 -230
  274. package/dist/index-N2MAxt7_.d.ts +0 -128
  275. package/dist/index-t6L2qpHh.d.cts +0 -366
  276. package/dist/patterns/audit/index.cjs +0 -3
  277. package/dist/patterns/audit/index.d.cts +0 -8
  278. package/dist/patterns/audit/index.d.ts +0 -8
  279. package/dist/patterns/audit/index.js +0 -1
  280. package/dist/patterns/guarded-execution/index.cjs +0 -3
  281. package/dist/patterns/guarded-execution/index.d.cts +0 -9
  282. package/dist/patterns/guarded-execution/index.d.ts +0 -9
  283. package/dist/patterns/guarded-execution/index.js +0 -1
  284. package/dist/patterns/lens/index.cjs +0 -3
  285. package/dist/patterns/lens/index.d.cts +0 -7
  286. package/dist/patterns/lens/index.d.ts +0 -7
  287. package/dist/patterns/lens/index.js +0 -1
  288. package/dist/patterns/refine-loop/index.cjs +0 -5
  289. package/dist/patterns/refine-loop/index.d.cts +0 -9
  290. package/dist/patterns/refine-loop/index.d.ts +0 -9
  291. package/dist/patterns/refine-loop/index.js +0 -1
  292. package/dist/patterns/resilient-pipeline/index.cjs +0 -3
  293. package/dist/patterns/resilient-pipeline/index.d.cts +0 -8
  294. package/dist/patterns/resilient-pipeline/index.d.ts +0 -8
  295. package/dist/patterns/resilient-pipeline/index.js +0 -1
  296. package/dist/resilience-JISHQD2F.js +0 -1
@@ -1,3 +1,3 @@
1
- "use strict";var st=Object.defineProperty;var kn=Object.getOwnPropertyDescriptor;var Rn=Object.getOwnPropertyNames;var Nn=Object.prototype.hasOwnProperty;var W=(r,e)=>()=>(r&&(e=r(r=0)),e);var En=(r,e)=>{for(var t in e)st(r,t,{get:e[t],enumerable:!0})},On=(r,e,t,n)=>{if(e&&typeof e=="object"||typeof e=="function")for(let s of Rn(e))!Nn.call(r,s)&&s!==t&&st(r,s,{get:()=>e[s],enumerable:!(n=kn(e,s))||n.enumerable});return r};var Sn=r=>On(st({},"__esModule",{value:!0}),r);function K(){return Math.trunc(performance.now()*1e6)}function le(){return Date.now()*1e6}var me=W(()=>{"use strict"});function Mt(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++]=ot,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 At(r,e){if(r.length<St)throw new Error(`decodeEnvelope: bytes too short (${r.length} < ${St})`);let t=0,n=r[t++];if(n!==ot)throw new Error(`decodeEnvelope: unsupported envelope version ${n} (expected ${ot})`);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 Ct(r){r.registerCodec(Mn)}var Mn,ot,St,it=W(()=>{"use strict";Mn={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)}},ot=1,St=4});function je(r){if(r==null)return xe;let{type:e,id:t,...n}=r;return{type:e??"system",id:t??"",...n}}var xe,at=W(()=>{"use strict";xe={type:"system",id:""}});function Be(){return ke>0||Ge}function Dt(){return ke>0}function Ne(r){ke>0?Ie.push(r):r()}function Ee(r){ke+=1;let e=!1;try{r()}catch(t){throw e=!0,t}finally{if(ke-=1,ke===0)if(e){if(!Ge){let t=Ie.splice(0);for(let n of t)try{n()}catch{}ye.length=0,be.length=0,Re.length=0}}else An()}}function An(){let r=!Ge;r&&(Ge=!0);let e=[],t=0;try{for(;ye.length>0||be.length>0||Re.length>0||r&&Ie.length>0;){if(r&&Ie.length>0){let o=Ie.splice(0);for(let i of o)try{i()}catch(a){e.push(a)}continue}if(t+=1,t>1e3)throw ye.length=0,be.length=0,Re.length=0,new Error("batch drain exceeded 1000 iterations \u2014 likely a reactive cycle");let s=(ye.length>0?ye:be.length>0?be:Re).splice(0);for(let o of s)try{o()}catch(i){e.push(i)}}}finally{r&&(Ge=!1)}if(e.length===1)throw e[0];if(e.length>1)throw new AggregateError(e,"batch drain: multiple callbacks threw")}function qe(r,e,t){if(e.length===0)return;if(e.length===1){let u=t(e[0][0]);if(u<3||!Be()){r(e);return}(u>=5?Re:u===4?be:ye).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=Be();if(s>0){let u=e.slice(0,s);r(u)}if(o>s){let u=e.slice(s,o);d?ye.push(()=>r(u)):r(u)}if(i>o){let u=e.slice(o,i);d?be.push(()=>r(u)):r(u)}if(n>i){let u=e.slice(i,n);d?Re.push(()=>r(u)):r(u)}}var ke,Ge,ye,be,Re,Ie,$e=W(()=>{"use strict";ke=0,Ge=!1,ye=[],be=[],Re=[],Ie=[]});var Oe,I,H,Q,ie,ce,fe,U,Y,z,Se,dt,Cn,ut,Dn,Gn,ct,Gt,It,$t,lt,pe=W(()=>{"use strict";Oe=Symbol.for("graphrefly/START"),I=Symbol.for("graphrefly/DATA"),H=Symbol.for("graphrefly/DIRTY"),Q=Symbol.for("graphrefly/RESOLVED"),ie=Symbol.for("graphrefly/INVALIDATE"),ce=Symbol.for("graphrefly/PAUSE"),fe=Symbol.for("graphrefly/RESUME"),U=Symbol.for("graphrefly/TEARDOWN"),Y=Symbol.for("graphrefly/COMPLETE"),z=Symbol.for("graphrefly/ERROR"),Se=Object.freeze([H]),dt=Object.freeze([Q]),Cn=Object.freeze([ie]),ut=Object.freeze([Oe]),Dn=Object.freeze([Y]),Gn=Object.freeze([U]),ct=Object.freeze([Se]),Gt=Object.freeze([dt]),It=Object.freeze([Cn]),$t=Object.freeze([Dn]),lt=Object.freeze([Gn])});function Vt(r){r.registerMessageType(Oe,{tier:0,wireCrossing:!1}),r.registerMessageType(H,{tier:1,wireCrossing:!1}),r.registerMessageType(ie,{tier:1,wireCrossing:!1,metaPassthrough:!1}),r.registerMessageType(ce,{tier:2,wireCrossing:!1}),r.registerMessageType(fe,{tier:2,wireCrossing:!1}),r.registerMessageType(I,{tier:3,wireCrossing:!0}),r.registerMessageType(Q,{tier:3,wireCrossing:!0}),r.registerMessageType(Y,{tier:4,wireCrossing:!0,metaPassthrough:!1}),r.registerMessageType(z,{tier:4,wireCrossing:!0,metaPassthrough:!1}),r.registerMessageType(U,{tier:5,wireCrossing:!0,metaPassthrough:!1})}var He,zt=W(()=>{"use strict";pe();He=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 Pt(r){return Array.isArray(r)?[...r]:[r]}function In(r,e){return r.has(e)||r.has("*")}function Lt(r){let e=[];return r((s,o)=>{e.push({kind:"allow",actions:new Set(Pt(s)),where:o?.where??(()=>!0)})},(s,o)=>{e.push({kind:"deny",actions:new Set(Pt(s)),where:o?.where??(()=>!0)})}),(s,o)=>{let i=!1,a=!1;for(let d of e)In(d.actions,o)&&d.where(s)&&(d.kind==="deny"?i=!0:a=!0);return i?!1:a}}function ft(r){let e=$n.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 re,$n,Ve=W(()=>{"use strict";re=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}};$n=["human","llm","wallet","system"]});function pt(r){if(r===void 0)return null;if(typeof r=="number"){if(!Number.isFinite(r))throw new TypeError(`Cannot hash non-finite number: ${r}`);if(Number.isInteger(r)&&!Number.isSafeInteger(r))throw new TypeError(`Cannot hash integer outside safe range (|n| > 2^53-1): ${r}. Cross-language cid parity is not guaranteed for unsafe integers.`);return r}if(typeof r=="string"||typeof r=="boolean"||r===null)return r;if(Array.isArray(r))return r.map(pt);if(typeof r=="object"&&r!==null){let e={};for(let t of Object.keys(r).sort())e[t]=pt(r[t]);return e}return null}function Pn(r){let e=zn.encode(r),t=e.length,n=t*8,s=t+9+63&-64,o=new Uint8Array(s);o.set(e),o[t]=128;let i=new DataView(o.buffer);i.setUint32(s-4,n>>>0,!1),i.setUint32(s-8,Math.floor(n/4294967296)>>>0,!1);let a=1779033703,d=3144134277,u=1013904242,l=2773480762,h=1359893119,f=2600822924,p=528734635,c=1541459225,v=new Uint32Array(64),g=(_,T)=>_>>>T|_<<32-T;for(let _=0;_<s;_+=64){for(let w=0;w<16;w++)v[w]=i.getUint32(_+w*4,!1);for(let w=16;w<64;w++){let M=v[w-15],E=v[w-2],O=g(M,7)^g(M,18)^M>>>3,C=g(E,17)^g(E,19)^E>>>10;v[w]=v[w-16]+O+v[w-7]+C>>>0}let T=a,x=d,N=u,S=l,m=h,y=f,b=p,k=c;for(let w=0;w<64;w++){let M=g(m,6)^g(m,11)^g(m,25),E=m&y^~m&b,O=k+M+E+Vn[w]+v[w]>>>0,C=g(T,2)^g(T,13)^g(T,22),D=T&x^T&N^x&N,$=C+D>>>0;k=b,b=y,y=m,m=S+O>>>0,S=N,N=x,x=T,T=O+$>>>0}a=a+T>>>0,d=d+x>>>0,u=u+N>>>0,l=l+S>>>0,h=h+m>>>0,f=f+y>>>0,p=p+b>>>0,c=c+k>>>0}let R=_=>_.toString(16).padStart(8,"0");return R(a)+R(d)+R(u)+R(l)+R(h)+R(f)+R(p)+R(c)}function ht(r){let e=pt(r??null),t=JSON.stringify(e);return Pn(t).slice(0,16)}function Ln(){let r=globalThis.crypto;if(r?.randomUUID)return r.randomUUID();let e=()=>Math.floor(Math.random()*4294967296).toString(16).padStart(8,"0"),t=e()+e()+e()+e();return`${t.slice(0,8)}-${t.slice(8,12)}-4${t.slice(13,16)}-${(parseInt(t.slice(16,17),16)&3|8).toString(16)}${t.slice(17,20)}-${t.slice(20,32)}`}function gt(r,e,t){let n=t?.id??Ln();if(r===0)return{id:n,version:0};let o=(t?.hash??ht)(e);return{id:n,version:0,cid:o,prev:null}}function Ft(r,e,t){r.version+=1,"cid"in r&&(r.prev=r.cid,r.cid=t(e))}var Vn,zn,Kt=W(()=>{"use strict";Vn=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]),zn=new TextEncoder});function qt(r){return{node:r,unsub:null,prevData:void 0,dirty:!1,involvedThisWave:!1,dataBatch:[],terminal:void 0}}function mt(r){r.prevData=void 0,r.dirty=!1,r.involvedThisWave=!1,r.dataBatch.length=0,r.terminal=void 0}function Ue(r){return r.length===0?r:typeof r[0]=="symbol"?[r]:r}function Ae(r,e,t){let n=Ht(r)?r:[],s=typeof r=="function"?r:typeof e=="function"?e:void 0,o={};return Ht(r)?o=(yt(e)?e:t)??{}:yt(r)?o=r:o=(yt(e)?e:t)??{},new L(n,s,o)}var jt,Bt,Fn,Kn,Me,L,Ht,yt,ve=W(()=>{"use strict";it();at();$e();me();zt();Ve();pe();Kt();jt=()=>{},Bt=100;Fn=(r,e,t,n)=>{t.direction==="down-in"&&r._onDepMessage(t.depIndex,e)},Kn=(r,e,t,n)=>{let s=r;if(s._status==="completed"||s._status==="errored")return;let o=s._cached,i=o===void 0?[ut]:[ut,[I,o]];s._status==="dirty"&&i.push(Se),qe(e,i,s._config.tierOf)},Me=new He({onMessage:Fn,onSubscribe:Kn});Vt(Me);Ct(Me);L=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??ht;let s=n.versioning??this._config.defaultVersioning;this._versioningLevel=s,this._versioning=s!=null?gt(s,this._cached===void 0?void 0:this._cached,{id:n.versioningId,hash:this._hashFn}):void 0,this._deps=e.map(qt);let o={};for(let[a,d]of Object.entries(n.meta??{})){let u={initial:d,name:`${n.name??"node"}:meta:${a}`,describeKind:"state",config:this._config};n.guard!=null&&(u.guard=n.guard),o[a]=new r([],void 0,u)}Object.freeze(o),this.meta=o,this._hasMeta=Object.keys(o).length>0;let i=this;this._actions={emit(a){i._emit([[I,a]])},down(a){i._emit(Ue(a))},up(a){i._emitUp(Ue(a))}},this.down=this.down.bind(this),this.up=this.up.bind(this)}get _isTerminal(){return this._status==="completed"||this._status==="errored"}get name(){return this._optsName}get status(){return this._status}get cache(){return this._cached===void 0?void 0:this._cached}get lastMutation(){return this._lastMutation}get v(){return this._versioning}hasGuard(){return this._guard!=null}_applyVersioning(e,t){if(this._isExecutingFn)throw new Error(`Node "${this.name}": _applyVersioning cannot run mid-fn \u2014 call it outside of \`_execFn\` (typically at graph setup time before the first subscribe).`);let n=this._versioningLevel;if(n!=null&&e<=n)return;let s=t?.hash??this._hashFn;s!==this._hashFn&&(this._hashFn=s);let o=this._cached===void 0?void 0:this._cached,i=this._versioning,a=i?.id??t?.id,d=i?.version??0,u=gt(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=je(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=je(e?.actor),o=e?.delivery==="signal"?"signal":"write";if(this._guard!=null&&!this._guard(s,o))throw new re({actor:s,action:o,nodeName:this.name});if(this._extraGuards!=null){for(let i of this._extraGuards)if(!i(s,o))throw new re({actor:s,action:o,nodeName:this.name})}this._lastMutation={actor:s,timestamp_ns:le()}}down(e,t){let n=Ue(e);n.length!==0&&(this._checkGuard(t),this._emit(n))}emit(e,t){this._checkGuard(t),this._emit([[I,e]])}up(e,t){if(this._deps.length===0)return;let n=Ue(e);if(n.length===0)return;this._checkGuard(t);let s=t??{internal:!0};this._validateUpTiers(n);for(let o of this._deps)o.node.up?.(n,s)}_emitUp(e){if(this._deps.length!==0&&e.length!==0){this._validateUpTiers(e);for(let t of this._deps)t.node.up?.(e,{internal:!0})}}_validateUpTiers(e){let t=this._config.tierOf;for(let n of e){let s=t(n[0]);if(s===3||s===4)throw new Error(`Node "${this.name}": tier-${s} messages cannot flow up \u2014 DATA/RESOLVED/COMPLETE/ERROR are downstream-only. Use \`down(...)\` for value delivery; \`up(...)\` is for control signals (DIRTY, INVALIDATE, PAUSE, RESUME, TEARDOWN).`)}}subscribe(e,t){if(t!=null&&this._guard!=null){let d=je(t);if(!this._guard(d,"observe"))throw new re({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)mt(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=jt,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{}mt(o)}}throw this._dirtyDepCount=0,n}}_addDep(e){for(let s=0;s<this._deps.length;s++)if(this._deps[s].node===e)return s;let t=this._deps.length,n=qt(e);if(this._deps.push(n),this._sinks==null)return t;n.dirty=!0,this._dirtyDepCount++,this._status!=="dirty"&&this._emit(ct),n.unsub=jt;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([[z,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([[z,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{}}mt(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!==Oe){if(s===H){this._depDirtied(n);return}if(s===ie){if(this._depInvalidated(n),this._cached===void 0)return;this._emit(It);return}if(s===ce||s===fe){this._emit([t]);return}if(s===U){this._emit(lt);return}if(s===I)this._depSettledAsData(n,t[1]);else if(s===Q)this._depSettledAsResolved(n);else if(s===Y)this._depSettledAsTerminal(n,!0);else if(s===z)this._depSettledAsTerminal(n,t[1]);else{this._emit([t]);return}if(!this._fn){(s===I||s===Q)&&this._emit([t]),(s===Y||s===z)&&this._maybeAutoTerminalAfterWave();return}}}_depDirtied(e){e.dirty||(e.dirty=!0,e.involvedThisWave=!0,this._dirtyDepCount++,this._status!=="dirty"&&this._emit(ct))}_depSettledAsData(e,t){e.dirty&&(e.dirty=!1,this._dirtyDepCount--),e.involvedThisWave=!0,e.dataBatch.push(t),this._waveHasNewData=!0}_depSettledAsResolved(e){e.dirty&&(e.dirty=!1,this._dirtyDepCount--)}_depSettledAsTerminal(e,t){e.dirty&&(e.dirty=!1,this._dirtyDepCount--),e.terminal=t,e.involvedThisWave=!0,this._hasNewTerminal=!0}_depInvalidated(e){e.prevData=void 0,e.terminal=void 0,e.dataBatch.length=0,e.dirty?e.involvedThisWave=!1:(e.dirty=!0,e.involvedThisWave=!0,this._dirtyDepCount++)}_maybeRunFnOnSettlement(){if(!(this._isTerminal&&!this._resubscribable)&&!(this._dirtyDepCount>0)){if(!this._partial&&!this._hasCalledFnOnce)for(let e=0;e<this._deps.length;e++){let t=this._deps[e];if(t.dataBatch.length===0&&t.prevData===void 0&&t.terminal===void 0){this._maybeAutoTerminalAfterWave();return}}if(this._paused){this._pendingWave=!0;return}if(!this._waveHasNewData&&!this._hasNewTerminal&&this._hasCalledFnOnce){this._clearWaveFlags(),this._emit(Gt),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([[z,e.terminal]]);return}this._autoComplete&&this._deps.every(t=>t.terminal!==void 0)&&this._emit($t)}_execFn(){if(!this._fn||this._isTerminal&&!this._resubscribable)return;if(this._isExecutingFn){this._pendingRerun=!0;return}let e=this._cleanup;if(typeof e=="function"){this._cleanup=void 0;try{e()}catch(i){this._emit([[z,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([[z,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([[z,this._wrapFnError("fn threw",i)]])}finally{this._isExecutingFn=!1,this._pendingRerun?(this._pendingRerun=!1,this._rerunDepth+=1,this._rerunDepth>Bt?(this._rerunDepth=0,this._emit([[z,new Error(`Node "${this.name}": _pendingRerun depth exceeded ${Bt} \u2014 likely a reactive cycle`)]])):this._maybeRunFnOnSettlement()):this._rerunDepth=0,this._clearWaveFlags()}}_clearWaveFlags(){this._waveHasNewData=!1,this._hasNewTerminal=!1;for(let e of this._deps)e.involvedThisWave=!1,e.dataBatch.length=0}_wrapFnError(e,t){let 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"?[Se,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]===H&&(o=!0),i=u}let a=e;if(!n){let d=e.map((u,l)=>({m:u,i:l,tier:t(u[0])}));d.sort((u,l)=>u.tier-l.tier||u.i-l.i),a=d.map(u=>u.m)}if(s&&!o&&this._status!=="dirty"){let d=0;for(;d<a.length&&t(a[d][0])===0;)d++;return d===0?[Se,...a]:[...a.slice(0,d),Se,...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]===z&&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]===U||d[0]===ie);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!==ce&&u!==fe){s?.push(d);continue}if(d.length<2)throw new Error(`Node "${this.name}": [[${u===ce?"PAUSE":"RESUME"}]] must carry a lockId payload \u2014 bare PAUSE/RESUME is a protocol violation (C0 rule). Use \`[[PAUSE, lockId]]\` / \`[[RESUME, lockId]]\`.`);let l=!0;if(this._pausable!==!1){let h=d[1];if(u===ce)this._pauseLocks==null&&(this._pauseLocks=new Set),this._pauseLocks.add(h),this._paused=!0,this._pausable==="resumeAll"&&this._pauseBuffer==null&&(this._pauseBuffer=[]);else if(this._pauseLocks==null||!this._pauseLocks.has(h))l=!1;else if(this._pauseLocks.delete(h),this._pauseLocks.size===0){if(this._paused=!1,this._pauseBuffer!=null&&this._pauseBuffer.length>0){let f=this._pauseBuffer;this._pauseBuffer=[],this._emit(f)}this._pendingWave&&(this._pendingWave=!1,this._maybeRunFnOnSettlement())}}l?s?.push(d):s==null&&(s=t.slice(0,a))}if(s!=null){if(s.length===0)return;t=s}if(this._hasMeta&&t.some(a=>a[0]===U))for(let a of Object.keys(this.meta))try{this.meta[a]._emit(lt)}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([[z,i]])}_updateState(e){let t=this._config.tierOf,n,s,o=-1,i=0;for(let l of e)t(l[0])===3&&i++;let a=i<=1,d=-1;if(this._versioning!=null&&i>1){for(let l=e.length-1;l>=0;l--)if(e[l][0]===I){d=l;break}}for(let l=0;l<e.length;l++){let h=e[l],f=h[0];if(f===I){if(h.length>=2){let p=!1;if(a&&this._cached!==void 0)try{p=this._equals(this._cached,h[1])}catch(c){s=this._wrapFnError("equals threw",c),o=l;break}if(p){n==null&&(n=e.slice(0,l)),n.push(dt),this._status="resolved";continue}this._cached=h[1],this._versioning!=null&&(d<0||l===d)&&Ft(this._versioning,h[1],this._hashFn)}this._status="settled",n?.push(h)}else if(n?.push(h),f===H)this._status="dirty";else if(f===Q)this._status="resolved";else if(f===Y){this._status="completed";{let p=this._config.rigorRecorder;if(p!=null)try{p.onTerminalTransition(this,"completed",this._autoComplete,this._autoError,this._deps.length>0)}catch{}}}else if(f===z){this._status="errored";{let p=this._config.rigorRecorder;if(p!=null)try{p.onTerminalTransition(this,"errored",this._autoComplete,this._autoError,this._deps.length>0)}catch{}}}else if(f===ie){if(this._cached!==void 0){let c=this._config.rigorRecorder;if(c!=null)try{c.onNonVacuousInvalidate(this,this._cached)}catch{}}this._cached=void 0,this._status="dirty";let p=this._cleanup;if(typeof p=="function"){this._cleanup=void 0;try{p()}catch{}}else if(p!=null&&typeof p=="object"){let c=p.invalidate;if(typeof c=="function")try{c()}catch{}}}else f===U&&(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(Dt()){this._batchPendingMessages===null&&(this._batchPendingMessages=[],Ne(()=>this._flushBatchPending()));for(let t of e)this._batchPendingMessages.push(t);return}qe(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);qe(this._deliverToSinks,t,this._config.tierOf)}},Ht=r=>Array.isArray(r),yt=r=>typeof r=="object"&&r!=null&&!Array.isArray(r)});function X(r,e){return Ae([],{...e,initial:r})}function ze(r,e){return Ae((n,s,o)=>r(s,o)??void 0,{describeKind:"producer",...e})}function B(r,e,t){return Ae(r,(s,o,i)=>{let a=s.map((d,u)=>d!=null&&d.length>0?d.at(-1):i.prevData[u]);o.emit(e(a,i))},{describeKind:"derived",...t})}var _e=W(()=>{"use strict";ve()});function Ut(r,e,t){return{[r]:!0,[`${r}_type`]:e,...t??{}}}var Wt=W(()=>{"use strict"});function bt(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 jn(r){return r._describeKind!=null?r._describeKind:r._deps.length>0?"derived":r._fn!=null?"producer":"state"}function Bn(r){let e={};for(let[t,n]of Object.entries(r.meta))try{e[t]=n.cache}catch{}return e}function vt(r,e,t){let n=e==null,s=!n&&e!=null?[...e].filter(l=>l.startsWith("meta.")).map(l=>l.slice(5)):null,o=n||e.has("meta")||s!=null&&s.length>0,i="state",a=[];r instanceof L&&(i=jn(r),a=r._deps.map(l=>l.node.name??""));let d={type:i,deps:a};(n||e.has("status"))&&(d.status=r.status);let u=r instanceof L?r._guard:void 0;if(o){let l={...Bn(r)};if(u!=null&&l.access===void 0&&(l.access=ft(u)),s!=null&&s.length>0&&!e.has("meta")){let h={};for(let f of s)f in l&&(h[f]=l[f]);d.meta=h}else d.meta=l}if(r.name!=null&&(d.name=r.name),(n||e.has("value"))&&(!t||i==="state")){r.status==="sentinel"&&(d.sentinel=!0);try{d.value=r.cache}catch{}}if((n||e.has("v"))&&r.v!=null){let l={id:r.v.id,version:r.v.version};"cid"in r.v&&(l.cid=r.v.cid,l.prev=r.v.prev),d.v=l}return(n||e.has("guard"))&&u!=null&&(d.guard=ft(u)),(n||e.has("lastMutation"))&&r.lastMutation!=null&&(d.lastMutation=r.lastMutation),d}var Yt=W(()=>{"use strict";Ve();ve()});function qn(r){return{describeKind:"producer",...r}}function Xt(r,e){let{signal:t,period:n,...s}=e??{};return ze(o=>{let i=!1,a=0,d,u,l=()=>{i=!0,d!==void 0&&clearTimeout(d),u!==void 0&&clearInterval(u),t?.removeEventListener("abort",f)},h=()=>{i||(n!=null?(o.emit(a++),u=setInterval(()=>{i||o.emit(a++)},n)):(i=!0,t?.removeEventListener("abort",f),o.emit(a++),o.down([[Y]])))},f=()=>{i||(l(),o.down([[z,t.reason]]))};if(t?.aborted){f();return}return d=setTimeout(h,r),t?.addEventListener("abort",f,{once:!0}),l},qn(s))}function ae(r){return r.subscribe(()=>{})}var Zt=W(()=>{"use strict";pe();_e()});var Tt=W(()=>{"use strict";Zt()});var We,Qt=W(()=>{"use strict";We=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 Pe,en=W(()=>{"use strict";Pe=class{constructor(e){this.capacity=e;if(!Number.isInteger(e)||e<=0)throw new Error(`RingBuffer capacity must be a positive integer (got ${e})`);this.buf=new Array(e)}buf;head=0;_size=0;get size(){return this._size}get maxSize(){return this.capacity}push(e){let t=(this.head+this._size)%this.capacity;this.buf[t]=e,this._size<this.capacity?this._size++:this.head=(this.head+1)%this.capacity}shift(){if(this._size===0)return;let e=this.buf[this.head];return this.buf[this.head]=void 0,this.head=(this.head+1)%this.capacity,this._size--,e}at(e){if(this._size===0)return;let t=e<0?this._size+e:e;if(!(t<0||t>=this._size))return this.buf[(this.head+t)%this.capacity]}toArray(){let e=new Array(this._size);for(let t=0;t<this._size;t++)e[t]=this.buf[(this.head+t)%this.capacity];return e}clear(){for(let e=0;e<this._size;e++)this.buf[(this.head+e)%this.capacity]=void 0;this.head=0,this._size=0}}});var br={};En(br,{collection:()=>gr,cosineSimilarity:()=>xn,knowledgeGraph:()=>yr,vectorIndex:()=>mr});module.exports=Sn(br);me();ve();_e();Wt();me();Ve();pe();_e();at();$e();me();Ve();pe();Yt();ve();_e();me();function _t(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(!_t(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)||!_t(r[o],e[o]))return!1;return!0}function Jt(r,e){return`${r}\0${e}`}function wt(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 R=r.nodes[g]?.meta,_=e.nodes[g]?.meta;R==null&&_==null||_t(R??{},_??{})||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 l=new Map;for(let g of r.edges)l.set(Jt(g.from,g.to),g);let h=new Map;for(let g of e.edges)h.set(Jt(g.from,g.to),g);let f=[];for(let[g,R]of h)l.has(g)||f.push(R);f.sort((g,R)=>g.from<R.from?-1:g.from>R.from?1:g.to<R.to?-1:g.to>R.to?1:0);for(let g of f)t.push({type:"edge-added",from:g.from,to:g.to});let p=[];for(let[g,R]of l)h.has(g)||p.push(R);p.sort((g,R)=>g.from<R.from?-1:g.from>R.from?1:g.to<R.to?-1:g.to>R.to?1:0);for(let g of p)t.push({type:"edge-removed",from:g.from,to:g.to});let c=[];for(let g of i)a.has(g)||c.push(g);c.sort();for(let g of c)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()}}Tt();Qt();en();it();function tn(r,e,t,n={}){let s=e in r.nodes,o=t in r.nodes;if(!s)return Ye(e,t,"no-such-from");if(!o)return Ye(e,t,"no-such-to");let i=n.maxDepth;if(i!=null&&(!Number.isInteger(i)||i<0))throw new Error("explainPath: maxDepth must be an integer >= 0");if(e===t){if(n.findCycle===!0){let u=Hn(r,e,n);if(u!=null)return u}let d=Je(e,r.nodes[e],0,n);return Xe(e,t,[d])}if(i===0)return Ye(e,t,"no-path");let a=nn(r,e,t,i);return a.found?Xe(e,t,rn(r,a.pathOrder,n)):Ye(e,t,a.truncated?"max-depth-exceeded":"no-path")}function nn(r,e,t,n){let s=new Map,o=[{path:t,depth:0}],i=new Set([t]),a=0,d=!1;for(;a<o.length;){let h=o[a++];if(h.path===e)break;if(n!=null&&h.depth>=n){let v=r.nodes[h.path];v?.deps&&v.deps.length>0&&(d=!0);continue}let f=r.nodes[h.path];if(f==null)continue;let p=f.deps??[],c=new Map;for(let v=0;v<p.length;v++){let g=p[v];if(!g)continue;let R=c.get(g);R==null&&(R=[],c.set(g,R)),R.push(v)}for(let[v,g]of c)i.has(v)||(i.add(v),s.set(v,{from:h.path,depIndices:g}),o.push({path:v,depth:h.depth+1}))}if(!s.has(e))return{found:!1,pathOrder:[],truncated:d};let u=[{path:e}],l=e;for(;l!==t;){let h=s.get(l);if(h==null)return{found:!1,pathOrder:[],truncated:!1};u[u.length-1].depIndices=h.depIndices,u.push({path:h.from}),l=h.from}return{found:!0,pathOrder:u,truncated:!1}}function Hn(r,e,t){let n=r.nodes[e];if(n==null)return null;let s=n.deps??[],o=[];for(let a=0;a<s.length;a++)s[a]===e&&o.push(a);if(o.length>0){let a=Je(e,n,0,t);a.dep_index=o[0];let d=Je(e,n,1,t);return Xe(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=nn(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:Xe(e,e,rn(r,i.pathOrder,t))}function rn(r,e,t){return e.map((n,s)=>{let o=r.nodes[n.path],i=Je(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 Je(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 Xe(r,e,t){return sn(r,e,!0,"ok",t)}function Ye(r,e,t){return sn(r,e,!1,t,[])}function sn(r,e,t,n,s){let o=Un(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 Un(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: ${Wn(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 Wn(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)}}ve();var q={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},Yn=Symbol.for("sizeof");function on(r){let e=new WeakSet,t=new WeakSet,n=[r],s=0;for(;n.length>0;){let o=n.pop();s+=Jn(o,e,t,n)}return s}function Jn(r,e,t,n){if(r==null)return 0;switch(typeof r){case"number":return q.number;case"boolean":return q.boolean;case"string":return q.string+r.length*2;case"bigint":return q.bigint+Xn(r);case"symbol":return q.symbol;case"function":return e.has(r)?0:(e.add(r),q.function);case"undefined":return 0}let o=r;if(e.has(o))return 0;e.add(o);let i=o[Yn];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 q.date;if(o instanceof RegExp)return q.regexp+o.source.length*2;if(o instanceof Error){let u=o.message?o.message.length*2:0,l=o.stack?o.stack.length*2:0;return q.error+u+l}if(typeof URL<"u"&&o instanceof URL)return q.url+o.href.length*2;if(typeof Promise<"u"&&o instanceof Promise)return q.promise;if(o instanceof WeakMap)return q.weakmap;if(o instanceof WeakSet)return q.weakset;if(o instanceof Map){let u=q.map;for(let[l,h]of o)u+=q.mapEntry,n.push(l),n.push(h);return u}if(o instanceof Set){let u=q.set;for(let l of o)u+=q.setEntry,n.push(l);return u}if(Array.isArray(o)){let u=q.array+o.length*8;for(let l of o)n.push(l);return u}if(o instanceof ArrayBuffer)return t.has(o)?0:(t.add(o),o.byteLength);if(ArrayBuffer.isView(o)){let u=o;return t.has(u.buffer)?48:(t.add(u.buffer),u.buffer.byteLength+48)}let a=q.object,d=Object.keys(o);for(let u of d){a+=q.string+u.length*2;try{n.push(o[u])}catch{}}return a}function Xn(r){let e=r<0n?-r:r;if(e===0n)return 0;let t=e.toString(2).length;return Math.ceil(t/32)*8}function an(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,p]of s)i.set(f,p);let a=[];for(let[f,p]of Object.entries(n.nodes)){let c=i.get(f),v=c instanceof L?c:null,g=v?on(v.cache):0,R=v?v._sinkCount:0,_=p.deps?.length??0,T=p.type==="effect"&&R===0,x=R===0?p.type==="effect"?"orphan-effect":p.type==="derived"?"idle-derived":p.type==="producer"?"idle-producer":null:null;a.push({path:f,type:p.type,status:p.status??"unknown",valueSizeBytes:g,subscriberCount:R,depCount:_,isOrphanEffect:T,orphanKind:x})}let d=a.reduce((f,p)=>f+p.valueSizeBytes,0),u=(f,p)=>[...a].sort(p??((c,v)=>v[f]-c[f])).slice(0,t),l=a.filter(f=>f.orphanKind!=null),h=a.filter(f=>f.isOrphanEffect);return{nodeCount:a.length,edgeCount:n.edges.length,subgraphCount:n.subgraphs.length,nodes:a,totalValueSizeBytes:d,hotspots:{byValueSize:u("valueSizeBytes"),bySubscriberCount:u("subscriberCount"),byDepCount:u("depCount")},orphans:l,orphanEffects:h}}var P="::",de="__meta__",Ce=1;function dn(r,e){let t=Math.max(16,r.size*4),n=0;for(;r.size>0;){if(n++>=t){console.error(`[Graph "${e}".destroy] disposer drain exceeded cap (${t}); ${r.size} disposer(s) discarded`),r.clear();return}let s=r.values().next();if(s.done)return;let o=s.value;r.delete(o);try{o()}catch(i){console.error(`[Graph "${e}".destroy] disposer threw:`,i)}}}function hn(r){return r!=null&&typeof r=="object"&&"cache"in r&&typeof r.subscribe=="function"&&typeof r.down=="function"}function Zn(r){if(r!=null)return hn(r)?r.cache:r}function we(r){return r!=null&&typeof r=="object"&&"cache"in r&&typeof r.subscribe=="function"&&typeof r.down=="function"}function he(r){return we(r)?r.cache??"":r}function un(r){return we(r)?r.cache??0:r}function cn(r){return we(r)?r.cache??!1:r}function Qn(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 ln(r){if(r.version!==Ce)throw new Error(`unsupported snapshot version ${String(r.version)} (expected ${Ce})`);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 er(r,e){let t=new WeakMap,n=(s,o)=>{if(Object.is(s,o))return!0;if(s==null||o==null||typeof s!="object"||typeof o!="object")return!1;let i=t.get(s);if(i==null&&(i=new WeakSet,t.set(s,i)),i.has(o))return!0;i.add(o);let a=s.constructor,d=o.constructor;if(a!==d)return!1;if(s instanceof Date)return s.getTime()===o.getTime();if(s instanceof RegExp)return s.source===o.source&&s.flags===o.flags;if(Array.isArray(s)){let f=o;if(s.length!==f.length)return!1;for(let p=0;p<s.length;p++)if(!n(s[p],f[p]))return!1;return!0}if(s instanceof Map){let f=o;if(s.size!==f.size)return!1;for(let[p,c]of s)if(!f.has(p)||!n(c,f.get(p)))return!1;return!0}if(s instanceof Set){let f=o;if(s.size!==f.size)return!1;for(let p of s){let c=!1;for(let v of f)if(n(p,v)){c=!0;break}if(!c)return!1}return!0}if(ArrayBuffer.isView(s)){let f=s,p=o;if(f.length!==p.length)return!1;for(let c=0;c<f.length;c++)if(f[c]!==p[c])return!1;return!0}let u=Object.keys(s),l=Object.keys(o);if(u.length!==l.length)return!1;let h=new Set(l);for(let f of u)if(!h.has(f)||!n(s[f],o[f]))return!1;return!0};return n(r,e)}function tr(r){return r.replace(/[.*+?^${}()|[\]\\]/g,"\\$&")}function Ze(r){let e="^";for(let t=0;t<r.length;t+=1){let n=r[t];if(n==="*"){e+=".*";continue}if(n==="?"){e+=".";continue}if(n==="["){let s=r.indexOf("]",t+1);if(s<=t+1){e+="\\[";continue}let o=r.slice(t+1,s);o.startsWith("!")&&(o=`^${o.slice(1)}`),o=o.replace(/\\/g,"\\\\"),e+=`[${o}]`,t=s;continue}e+=tr(n)}return e+="$",new RegExp(e)}var nr={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"},rr={data:"",dirty:"",resolved:"",invalidate:"",pause:"",resume:"",complete:"",error:"",teardown:"",derived:"",path:"",reset:""};function xt(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 sr(r){return r==="none"?rr:r==="ansi"||r==null?nr:{data:r.data??"",dirty:r.dirty??"",resolved:r.resolved??"",invalidate:r.invalidate??"",pause:r.pause??"",resume:r.resume??"",complete:r.complete??"",error:r.error??"",teardown:r.teardown??"",derived:r.derived??"",path:r.path??"",reset:r.reset??""}}function fn(r){if(r==null)return{};let e=r.detail;return e==="full"?{...r,structured:r.structured??!0,timeline:r.timeline??!0,causal:r.causal??!0,derived:r.derived??!0}:e==="minimal"?{...r,structured:r.structured??!0}:r.format==="stage-log"?{...r,structured:r.structured??!0,timeline:r.timeline??!0}:r}function or(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 kt(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===de)throw new Error(`Graph "${e}": ${t} name "${de}" is reserved for meta companion paths`);or(r,e,t)}function ir(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 ar(r,e){let t=!1;for(let s of r)if(!e.isMetaPassthrough(s[0])){t=!0;break}return t?r.filter(s=>e.isMetaPassthrough(s[0])):r}function gn(r){for(let e of r._mounts.values())gn(e);for(let e of r._nodes.values())try{e.down([[U]],{internal:!0})}catch{}}var Te=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===de)throw new Error(`Graph name "${de}" is reserved for meta companion paths`);this.name=e,this.opts=Object.freeze({...t??{}}),this.config=t?.config??Me,this._traceRing=new Pe(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=ze(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(kt(o,this.name,"add"),this._mounts.has(o))throw new Error(`Graph "${this.name}": name "${o}" is already a mount point`);if(this._nodes.has(o))throw new Error(`Graph "${this.name}": node "${o}" already exists`);let a=this._nodeToName.get(e);if(a!==void 0)throw new Error(`Graph "${this.name}": node instance already registered as "${a}"`);return this._nodes.set(o,e),this._nodeToName.set(e,o),this._emitTopology({kind:"added",name:o,nodeKind:"node"}),i!=null&&(this._annotations.set(o,i),this.config.inspectorEnabled&&this._traceRing.push({path:o,annotation:i,timestamp_ns:K()})),e}setVersioning(e){if(e!=null)for(let t of this._nodes.values())t instanceof L&&t._applyVersioning(e)}remove(e){kt(e,this.name,"remove");let t=this._mounts.get(e);if(t){let o={kind:"mount",nodes:[],mounts:[]},i=[];t._collectObserveTargets("",i);for(let[a,d]of i)a.includes(`${P}${de}${P}`)||o.nodes.push(a);return o.nodes.sort(),o.mounts.push(e),o.mounts.push(...t._collectSubgraphs(`${e}${P}`)),this._mounts.delete(e),t._parent=void 0,gn(t),this._emitTopology({kind:"removed",name:e,nodeKind:"mount",audit:o}),o}let n=this._nodes.get(e);if(!n)throw new Error(`Graph "${this.name}": unknown node or mount "${e}"`);this._nodes.delete(e),this._nodeToName.delete(n),n.down([[U]],{internal:!0});let s={kind:"node",nodes:[e],mounts:[]};return this._emitTopology({kind:"removed",name:e,nodeKind:"node",audit:s}),s}removeAll(e){let t=typeof e=="function"?e:(()=>{let o=Ze(e);return i=>o.test(i)})(),n={kind:"mount",nodes:[],mounts:[]},s=[...this._nodes.keys(),...this._mounts.keys()].filter(o=>t(o));for(let o of s){let i=this.remove(o);n.nodes.push(...i.nodes),n.mounts.push(...i.mounts)}return n.nodes.sort(),n.mounts.sort(),n}[Symbol.iterator](){let e=[...this._nodes.keys()].sort(),t=this._nodes,n=0;return{[Symbol.iterator](){return this},next(){if(n>=e.length)return{value:void 0,done:!0};let s=e[n++];return{value:[s,t.get(s)],done:!1}}}}node(e){if(e==="")throw new Error(`Graph "${this.name}": node name must be non-empty`);if(e.includes(P))return this.resolve(e);let t=this._nodes.get(e);if(!t)throw new Error(`Graph "${this.name}": unknown node "${e}"`);return t}get(e){return this.node(e).cache}set(e,t,n){let s=n?.internal===!0;this.node(e).down([[I,t]],{actor:n?.actor,internal:s,delivery:"write"})}setAll(e,t){let n=Symbol.iterator in e?e:Object.entries(e);Ee(()=>{for(let[s,o]of n)this.set(s,o,t)})}invalidate(e,t){let n=t?.internal===!0;this.node(e).down([[ie]],{actor:t?.actor,internal:n,delivery:"write"})}error(e,t,n){let s=n?.internal===!0;this.node(e).down([[z,t]],{actor:n?.actor,internal:s,delivery:"write"})}complete(e,t){let n=t?.internal===!0;this.node(e).down([[Y]],{actor:t?.actor,internal:n,delivery:"write"})}edges(e){let t=e?.recursive===!0,n=new Map;if(!t){for(let[d,u]of this._nodes)n.set(u,d);let a=[];for(let[d,u]of this._nodes)if(u instanceof L)for(let l of u._deps){let h=n.get(l.node);h!=null&&a.push([h,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 L)for(let u of d._deps){let l=o.get(u.node);l!=null&&i.push([l,a])}return i.sort((a,d)=>a[0]<d[0]?-1:a[0]>d[0]?1:a[1]<d[1]?-1:a[1]>d[1]?1:0),i}mount(e,t){if(t===void 0){let s=new r(e);return this.mount(e,s)}if(typeof t=="function"){let s=new r(e);return t(s),this.mount(e,s)}let n=t;if(kt(e,this.name,"mount"),this._nodes.has(e))throw new Error(`Graph "${this.name}": cannot mount at "${e}" \u2014 node with that name exists`);if(this._mounts.has(e))throw new Error(`Graph "${this.name}": mount "${e}" already exists`);if(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=ir(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]===de)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]!==de)throw new Error(`Graph "${this.name}": expected ${de} segment in meta path "${n}"`);if(o+1>=i.length)throw new Error(`Graph "${this.name}": meta path requires a key after ${de} 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=ar(e,this.config);for(let d of[...this._nodes.keys()].sort()){let u=this._nodes.get(d);if(!n.has(u)){n.add(u);try{u.down(e,i)}catch(l){if(l instanceof re)throw l;s.push(l)}a.length!==0&&this._signalMetaSubtree(u,a,n,i,s)}}}_signalMetaSubtree(e,t,n,s,o){for(let i of Object.keys(e.meta).sort()){let a=e.meta[i];if(!n.has(a)){n.add(a);try{a.down(t,s)}catch(d){if(d instanceof re)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=Zn(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=bt(e?.detail,e?.fields),o=e?.detail==="spec",i=s,a=[];this._collectObserveTargets("",a);let d=new Map;for(let[x,N]of a)d.set(N,x);let u=[];{let x=a.map(([,m])=>m),N=new Set(d.values()),S=0;for(;x.length>0;){let m=x.shift();if(m instanceof L)for(let y of m._deps){let b=y.node;if(d.has(b))continue;let k=b.name??"",w=k;if(!w||N.has(w))if(k){let M=2;for(;N.has(`${k}#${M}`);)M++;w=`${k}#${M}`}else for(w=`__internal__/${S++}`;N.has(w);)w=`__internal__/${S++}`;d.set(b,w),N.add(w),u.push([w,b]),x.push(b)}}}let l=[...a,...u],h={};for(let[x,N]of l){if(t!=null&&!N.allowsObserve(t))continue;let S=vt(N,i,o),m=N instanceof L?N._deps.map(w=>d.get(w.node)??w.node.name??""):[],{name:y,...b}=S,k={...b,deps:m};if(!o){let w=this._annotations.get(x);w!=null&&(k.annotation=w)}if(n!=null)if(typeof n=="function"){let w=n;if(!(w.length>=2?w(x,k):w(k)))continue}else{let w=!0;for(let[M,E]of Object.entries(n)){let O=M==="deps_includes"?"depsIncludes":M==="meta_has"?"metaHas":M;if(O==="depsIncludes"){if(!k.deps.includes(String(E))){w=!1;break}continue}if(O==="metaHas"){if(!Object.hasOwn(k.meta??{},String(E))){w=!1;break}continue}if(k[O]!==E){w=!1;break}}if(!w)continue}h[x]=k}let f=new Set(Object.keys(h)),p=[];for(let[x,N]of l)if(N instanceof L)for(let S of N._deps){let m=d.get(S.node);m!=null&&p.push([m,x])}p.sort((x,N)=>x[0]<N[0]?-1:x[0]>N[0]?1:x[1]<N[1]?-1:x[1]>N[1]?1:0);let c=p.map(([x,N])=>({from:x,to:N}));(t!=null||n!=null)&&(c=c.filter(x=>f.has(x.from)&&f.has(x.to)));let v=this._collectSubgraphs(""),g=t!=null||n!=null?v.filter(x=>{let N=`${x}${P}`;return[...f].some(S=>S===x||S.startsWith(N))}):v,R=this,_=e;return{name:this.name,nodes:h,edges:c,subgraphs:g,...this._factory!==void 0?{factory:this._factory}:{},...this._factoryArgs!==void 0?{factoryArgs:this._factoryArgs}:{},expand(x){let N={..._};return Array.isArray(x)?(N.fields=x,N.detail=void 0):(N.detail=x,N.fields=void 0),R.describe(N)}}}_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 an(this,e)}reachable(e,t,n={}){return n.withDetail===!0?pn(this.describe(),e,t,{...n,withDetail:!0}):pn(this.describe(),e,t,n)}explain(e,t,n){return n?.reactive===!0?this._explainReactive(e,t,n):this._explainStatic(he(e),he(t),{...n?.maxDepth!==void 0?{maxDepth:un(n.maxDepth)}:{},...n?.findCycle!==void 0?{findCycle:cn(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 tn(s,e,t,{...n?.maxDepth!=null?{maxDepth:n.maxDepth}:{},...n?.findCycle===!0?{findCycle:!0}:{},annotations:o,lastMutations:i})}_describeReactive(e){let t={...e,reactive:!1},n=e.reactiveName??"describe",s=0,o=X(s,{name:`${n}_version`}),i=this.observe({timeline:!0,structured:!0}),a=!1,d=!1,u=()=>{a||d||(a=!0,Ne(()=>{a=!1,!d&&(s+=1,o.emit(s))}))},l=i.onEvent(_=>{let T=_.type;T!=="data"&&T!=="error"&&T!=="complete"&&T!=="teardown"||u()}),h=[],f=new WeakSet,p=_=>{if(f.has(_)||d)return;f.add(_);let T=_.topology.subscribe(x=>{for(let N of x){if(N[0]!==I)continue;let S=N[1];if(u(),S.kind==="added"&&S.nodeKind==="mount"){let m=_._mounts.get(S.name);m!=null&&p(m)}}});h.push(T);for(let x of _._mounts.keys()){let N=_._mounts.get(x);N!=null&&p(N)}};p(this);let c,v=e.actor;hn(v)&&(c=v.subscribe(_=>{let T=!1,x=!1;for(let N of _){let S=N[0];S===I?T=!0:(S===Y||S===z||S===U)&&(x=!0)}T&&u(),x&&(c?.(),c=void 0,u())}));let g;try{g=B([o],()=>this.describe(t),{name:n,describeKind:"derived",meta:{domain:"audit",kind:"describe"},equals:(_,T)=>_===T})}catch(_){l(),c?.();for(let T of h)T();throw i.dispose(),_}let R=ae(g);return{node:g,dispose(){d=!0,l(),c?.();for(let _ of h)_();h.length=0,i.dispose(),R()}}}_describeReactiveDiff(e){let t={...e,reactive:!1},n=e.reactiveName??"describe-diff",s={name:this.name,nodes:{},edges:[],subgraphs:[]},o=this.describe(t),i=wt(s,o),a=X(i,{name:n,meta:{domain:"audit",kind:"describe-diff"},equals:(f,p)=>f===p}),d=this._describeReactive({...e,reactiveName:void 0}),u=!1,l=d.node.subscribe(f=>{if(!u)for(let p of f){if(p[0]!==I)continue;let c=p[1],v=wt(o,c);o=c,v.events.length!==0&&a.emit(v)}}),h=ae(a);return{node:a,dispose(){u=!0,l(),d.dispose(),a.down([[U,"describe-diff disposed"]]),h()}}}_explainReactive(e,t,n){let s=0,o=X(s,{name:"explain_version"}),i=this.observe({timeline:!0,structured:!0}),a=!1,d=!1,u=()=>{a||d||(a=!0,Ne(()=>{a=!1,!d&&(s+=1,o.emit(s))}))},l=i.onEvent(_=>{let T=_.type;T!=="data"&&T!=="error"&&T!=="complete"&&T!=="teardown"||u()}),h=[];e!=null&&we(e)&&h.push(e),t!=null&&we(t)&&h.push(t),n?.maxDepth!=null&&we(n.maxDepth)&&h.push(n.maxDepth),n?.findCycle!=null&&we(n.findCycle)&&h.push(n.findCycle);let f=()=>{for(let _ of h)if(_.cache===void 0)return!1;return!0},p=()=>{let _=he(e),T=he(t);return{from:_,to:T,found:!1,reason:"pending",steps:[],text:"(awaiting reactive args)",toJSON:()=>({from:_,to:T,found:!1,reason:"pending",steps:[]})}},c;try{c=B([o],()=>{if(!f())return p();let _=he(e),T=he(t),x={...n?.maxDepth!==void 0?{maxDepth:un(n.maxDepth)}:{},...n?.findCycle!==void 0?{findCycle:cn(n.findCycle)}:{}};return this._explainStatic(_,T,x)},{name:n?.name??"explain",describeKind:"derived",meta:{domain:"audit",kind:"explain_path",from:he(e),to:he(t)},equals:(_,T)=>_.found===T.found&&_.reason===T.reason&&_.steps.length===T.steps.length&&ur(_.steps,T.steps)})}catch(_){throw l(),i.dispose(),_}let v=ae(c),g=[],R=_=>{let T;return T=_.subscribe(x=>{let N=!1,S=!1;for(let m of x){let y=m[0];y===I?N=!0:(y===Y||y===z||y===U)&&(S=!0)}(N||S)&&u(),S&&T&&(T(),T=void 0)}),()=>{T&&(T(),T=void 0)}};for(let _ of h)g.push(R(_));return{node:c,dispose(){d=!0,l();for(let _ of g)_?.();g.length=0,i.dispose(),v()}}}_pathsMatching(e){let t=Ze(e),n=[];return this._collectObserveTargets("",n),n.map(([s])=>s).filter(s=>t.test(s))}_collectObserveTargets(e,t){for(let n of[...this._mounts.keys()].sort()){let s=e===""?n:`${e}${P}${n}`;this._mounts.get(n)._collectObserveTargets(s,t)}for(let n of[...this._nodes.keys()].sort()){let s=this._nodes.get(n),o=e===""?n:`${e}${P}${n}`;t.push([o,s]),this._appendMetaObserveTargets(o,s,t)}}_appendMetaObserveTargets(e,t,n){for(let s of Object.keys(t.meta).sort()){let o=t.meta[s],i=`${e}${P}${de}${P}${s}`;n.push([i,o]),this._appendMetaObserveTargets(i,o,n)}}observe(e,t){let n=typeof e=="string",o=fn(n?t:e);if(o.reactive===!0)return this._observeReactive(n?e:void 0,o);let i=o.structured===!0||o.timeline===!0||o.causal===!0||o.derived===!0||o.detail==="minimal"||o.detail==="full"||o.format!=null,a=o.actor;if(n){let l=e,h=this.resolve(l);if(a!=null&&!h.allowsObserve(a))throw new re({actor:a,action:"observe",nodeName:l});return i?this._buildStructuredObserver([[l,h]],o,"one"):{subscribe(f){return h.subscribe(f)},up(f){try{h.up?.(f)}catch(p){if(p instanceof re)return;throw p}}}}let d=[];this._collectObserveTargets("",d),d.sort((l,h)=>l[0]<h[0]?-1:l[0]>h[0]?1:0);let u=a==null?d:d.filter(([,l])=>l.allowsObserve(a));return i?this._buildStructuredObserver(u,o,"all"):{subscribe:l=>{let h=u.map(([f,p])=>p.subscribe(c=>{l(f,c)}));return()=>{for(let f of h)f()}},up:(l,h)=>{try{this.resolve(l).up?.(h)}catch(f){if(f instanceof re)return;throw f}}}}_observeReactive(e,t){let n=t.tiers,s=n!=null?new Set(n):null,o=t.reactiveName??"observe";return ze(i=>{let a=[],d=!1,u=!1,l=()=>{if(a.length===0||u)return;let v={events:a.slice(),flushedAt_ns:K()};a.length=0,i.emit(v)},h={...t,reactive:!1,structured:!0,timeline:!0},f=e!=null?this.observe(e,h):this.observe(h),p=v=>{u||(a.push(v),!d&&(d=!0,Ne(()=>{d=!1,l()})))};for(let v of f.events)p(v);let c=f.onEvent(p);return()=>{u=!0,c(),f.dispose()}},{name:o,meta:{domain:"audit",kind:"observe-reactive"}})}_buildStructuredObserver(e,t,n){let s=n==="one"?e[0]?.[0]:void 0,o=i=>{if(n==="one"&&s!=null){let l=this.resolve(s);return this._buildStructuredObserver([[s,l]],i,"one")}let a=[];this._collectObserveTargets("",a),a.sort((l,h)=>l[0]<h[0]?-1:l[0]>h[0]?1:0);let d=i.actor,u=d==null?a:a.filter(([,l])=>l.allowsObserve(d));return this._buildStructuredObserver(u,i,"all")};return this._createObserveResult(e,t,o)}_createObserveResult(e,t,n){let s=t.timeline===!0,o=t.causal===!0,i=t.derived===!0,a=t.detail==="minimal",d=this.config.inspectorEnabled,u=(o||i)&&d,l=t.maxEvents,h=l!=null&&l>0?new Pe(l):null,f=[],p=new Set,c=t.tiers!=null?new Set(t.tiers):null,v={},g=new Set,R=0,_=0,T=0,x=0,N=0,S=0,m=!1,y=!1,b=0,k=new Map,w=new Map,M=new Map,E=A=>{if(!(c!=null&&!c.has(A.type))){h?h.push(A):f.push(A);for(let V of p)V(A)}},O=A=>c==null||c.has(A),C=()=>s?{timestamp_ns:K(),in_batch:Be(),batch_id:b}:{},D=(A,V)=>{if(!(!u||!(A instanceof L)))return A._setInspectorHook(te=>{if(te.kind==="dep_message")k.set(A,te.depIndex);else if(te.kind==="run"){let De=te.batchData.map((G,Z)=>G!=null&&G.length>0?G.at(-1):te.prevData[Z]);w.set(A,De);let ne=te.batchData.map(G=>G!=null?[...G]:void 0);M.set(A,ne),i&&E({type:"derived",path:V,dep_values:De,dep_batches:ne,...C()})}})},$=A=>{let V=k.get(A),te=w.get(A);if(!o||te==null)return{};let ne=(V!=null&&V>=0&&A instanceof L?A._deps[V]:void 0)?.node,G=ne?.v,Z=M.get(A);return{trigger_dep_index:V,trigger_dep_name:ne?.name,...G!=null?{trigger_version:{id:G.id,version:G.version}}:{},dep_values:[...te],...Z!=null?{dep_batches:Z}:{}}},F=[],j=[];for(let[A,V]of e){let te=D(V,A);te&&F.push(te),j.push(V.subscribe(De=>{b++;for(let ne of De){let G=ne[0],Z=C();if(G===I){v[A]=ne[1];let rt=V instanceof L?V.lastMutation?.actor??xe:xe;E({type:"data",path:A,data:ne[1],actor:rt,...Z,...$(V)})}else if(a)G===H?O("dirty")&&R++:G===Q?O("resolved")&&_++:G===ie?O("invalidate")&&T++:G===ce?O("pause")&&x++:G===fe?O("resume")&&N++:G===U?O("teardown")&&S++:G===Y&&!g.has(A)?O("complete")&&(m=!0):G===z&&O("error")&&(y=!0,g.add(A));else if(G===H)O("dirty")&&R++,E({type:"dirty",path:A,...Z});else if(G===Q)O("resolved")&&_++,E({type:"resolved",path:A,...Z,...$(V)});else if(G===ie)O("invalidate")&&T++,E({type:"invalidate",path:A,...Z});else if(G===ce)O("pause")&&x++,E({type:"pause",path:A,lockId:ne[1],...Z});else if(G===fe)O("resume")&&N++,E({type:"resume",path:A,lockId:ne[1],...Z});else if(G===Y)O("complete")&&!g.has(A)&&(m=!0),E({type:"complete",path:A,...Z});else if(G===z){O("error")&&(y=!0,g.add(A));let rt=V instanceof L?V.lastMutation?.actor??xe:xe;E({type:"error",path:A,data:ne[1],actor:rt,...Z})}else G===U&&(O("teardown")&&S++,E({type:"teardown",path:A,...Z}))}}))}let oe=!1,ge=()=>{if(!oe){oe=!0;for(let A of j)A();for(let A of F)A();for(let A of ue)A({value:void 0,done:!0});ue.length=0}},J=[],ue=[];p.add(A=>{let V=ue.shift();V?V({value:A,done:!1}):J.push(A)});let Ot={get values(){return v},get dirtyCount(){return R},get resolvedCount(){return _},get invalidateCount(){return T},get pauseCount(){return x},get resumeCount(){return N},get teardownCount(){return S},get events(){return h?h.toArray():[...f]},get anyCompletedCleanly(){return m},get anyErrored(){return y},get completedWithoutErrors(){return m&&!y},onEvent(A){return p.add(A),()=>p.delete(A)},dispose:ge,expand(A){ge();let V={...t};return typeof A=="string"?V.detail=A:Object.assign(V,A),n(fn(V))},[Symbol.asyncIterator](){return{next(){return J.length>0?Promise.resolve({value:J.shift(),done:!1}):oe?Promise.resolve({value:void 0,done:!0}):new Promise(A=>ue.push(A))},return(){return ge(),Promise.resolve({value:void 0,done:!0})}}}};return t.format!=null&&this._attachFormatLogger(Ot,t),Ot}_attachFormatLogger(e,t){let n=t.format;if(n==null)return;let s=t.logger??(c=>console.log(c)),o=t.includeTypes?new Set(t.includeTypes):null,i=t.excludeTypes?new Set(t.excludeTypes):null,a=o==null&&i==null?()=>!0:c=>(o==null||o.has(c))&&(i==null||!i.has(c)),d=sr(t.theme),u=n==="stage-log"?K():0,l=c=>c==null?"":t.stageLabels?.[c]??c,h=(c,v)=>c.length>v?`${c.slice(0,v-1)}\u2026`:c,f=c=>c.type==="data"||c.type==="error"?h(xt(c.data),120):"",p=c=>{if(n==="stage-log"){let m=(K()-u)/1e9,y=l(c.path).padEnd(9);if(c.type==="data"){let b=f(c);return`[${m.toFixed(3)}s] ${y} \u2190${b?` ${b}`:""}`}if(c.type==="error"){let b=f(c);return`[${m.toFixed(3)}s] ${y} \u2717${b?` ${b}`:""}`}return c.type==="complete"?`[${m.toFixed(3)}s] ${y} \u25A0 complete`:`[${m.toFixed(3)}s] ${y} ${c.type}`}if(n==="json")try{return JSON.stringify(c)}catch{return JSON.stringify({type:c.type,path:c.path,data:"[unserializable]"})}let v=d[c.type]??"",g=c.path?`${d.path}${c.path}${d.reset} `:"",R=c.type==="data"||c.type==="error",_=c.type==="pause"||c.type==="resume",T=R?` ${xt(c.data)}`:_?` ${xt(c.lockId)}`:"",x=c.type==="data"||c.type==="resolved"||c.type==="derived"?c:void 0,N=x?.trigger_dep_name!=null?` <- ${x.trigger_dep_name}`:x?.trigger_dep_index!=null?` <- #${x.trigger_dep_index}`:"",S=c.in_batch?" [batch]":"";return`${g}${v}${c.type.toUpperCase()}${d.reset}${T}${N}${S}`};e.onEvent(c=>{a(c.type)&&s(p(c),c)})}addDisposer(e){return this._disposers.add(e),()=>{this._disposers.delete(e)}}destroy(){dn(this._disposers,this.name),this.signal([[U]],{internal:!0}),dn(this._storageDisposers,this.name);for(let e of[...this._mounts.values()])e._parent=void 0,e._destroyClearOnly();this._mounts.clear(),this._nodes.clear(),this._parent=void 0,this._destroyed=!0}get destroyed(){return this._destroyed}_destroyClearOnly(){for(let e of[...this._mounts.values()])e._parent=void 0,e._destroyClearOnly();this._mounts.clear(),this._nodes.clear(),this._parent=void 0,this._destroyed=!0}snapshot(e){let{expand:t,...n}=this.describe({detail:"full"}),s={};for(let a of Object.keys(n.nodes).sort()){let{lastMutation:d,guard:u,...l}=n.nodes[a];s[a]=l}let o=[...n.subgraphs].sort(),i={...n,version:1,nodes:s,subgraphs:o};if(e?.format==null)return i;if(e.format==="json-string")return JSON.stringify(i);if(e.format==="bytes"){if(e.codec==null)throw new Error("snapshot({format: 'bytes'}) requires a `codec` name");let a=this.config.lookupCodec(e.codec);if(a==null)throw new Error(`snapshot: codec "${e.codec}" is not registered on this graph's config. Call config.registerCodec(...) before creating nodes.`);return Mt(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}=At(e,n);return s.decode(i,o)}restore(e,t){if(ln(e),e.name!==this.name)throw new Error(`Graph "${this.name}": restore snapshot name "${e.name}" does not match this graph`);let n=t?.only==null?null:(Array.isArray(t.only)?t.only:[t.only]).map(o=>Ze(o)),s=t?.includeProducers===!0;for(let o of Object.keys(e.nodes).sort()){if(n!==null&&!n.some(a=>a.test(o)))continue;let i=e.nodes[o];if(i!==void 0){if(!("value"in i)||i.value===void 0){"value"in i&&i.value===void 0&&t?.onError?.(o,new Error(`restore: slice.value is undefined for "${o}" (undefined is the global SENTINEL; not valid DATA)`));continue}if(!(i.type==="derived"||i.type==="effect")&&!(i.type==="producer"&&!s)){if(i.v!=null){let d=this.tryResolve(o)?.v;if(d!=null&&d.id===i.v.id&&d.version===i.v.version)continue}try{this.set(o,i.value)}catch(a){t?.onError?.(o,a)}}}}}static fromSnapshot(e,t){ln(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 p of[...e.subgraphs].sort((c,v)=>{let g=c.split(P).length,R=v.split(P).length;return g!==R?g-R:c<v?-1:c>v?1:0})){let c=p.split(P),v=o;for(let g of c)v._mounts.has(g)||v.mount(g,new r(g)),v=v._mounts.get(g)}let i=s?Object.entries(s).map(([p,c])=>({re:Ze(p),factory:c})):[],a=p=>{for(let c of i)if(c.re.test(p))return c.factory},d=p=>{let c=p.split(P),v=c.pop();if(v==null||v.length===0)throw new Error(`invalid snapshot path "${p}"`);let g=o;for(let R of c){let _=g._mounts.get(R);if(!_)throw new Error(`unknown mount "${R}" in path "${p}"`);g=_}return[g,v]},u=Object.entries(e.nodes).filter(([p])=>!p.includes(`${P}${de}${P}`)).sort((p,c)=>p[0]<c[0]?-1:p[0]>c[0]?1:0),l=new Map(u),h=new Map,f=!0;for(;l.size>0&&f;){f=!1;for(let[p,c]of[...l.entries()]){let v=c?.deps??[];if(!v.every(N=>h.has(N)))continue;let[g,R]=d(p),_={...c?.meta??{}},T=a(p),x;if(c?.type==="state")x=X(c.value,{meta:_});else{if(T==null)continue;x=T(R,{path:p,type:c.type,value:c.value,meta:_,deps:v,resolvedDeps:v.map(N=>h.get(N))})}g.add(x,{name:R}),h.set(p,x),l.delete(p),f=!0}}if(l.size>0){let p=[...l.keys()].sort().join(", ");throw new Error(`Graph.fromSnapshot could not reconstruct nodes without build callback: ${p}. Pass matching factories via fromSnapshot(data, { factories: { pattern: factoryFn } }).`)}return o.restore(e),o}toJSON(){return this.snapshot()}attachSnapshotStorage(e,t={}){let n=e.map(u=>({tier:u,debounceMs:Math.max(0,u.debounceMs??0),compactEvery:Math.max(1,u.compactEvery??10),timer:void 0,seq:0,lastSnapshot:void 0,lastFingerprint:"",disposed:!1,savePending:void 0}));t.autoRestore===!0&&this._cascadeRestore(e,t.onError);let s=(u,l)=>{if(u.disposed)return;let h=Qn(l.nodes);if(u.lastSnapshot!=null&&h!==""&&h===u.lastFingerprint)return;let f=u.seq+1,p=le(),g=u.lastSnapshot==null||f%u.compactEvery===0?{name:this.name,mode:"full",snapshot:l,seq:f,timestamp_ns:p,format_version:Ce}:{name:this.name,mode:"diff",diff:dr(u.lastSnapshot,l),seq:f,timestamp_ns:p,format_version:Ce};if(u.tier.filter&&!u.tier.filter(g))return;let R;try{R=u.tier.save(g)}catch(_){t.onError?.(_,u.tier);return}if(R&&typeof R.then=="function"){let x=(u.savePending??Promise.resolve()).then(()=>R,()=>R).then(()=>{u.disposed||(u.seq=f,u.lastSnapshot=l,u.lastFingerprint=h)},N=>{t.onError?.(N,u.tier)});u.savePending=x.finally(()=>{u.savePending===x&&(u.savePending=void 0)})}else u.seq=f,u.lastSnapshot=l,u.lastFingerprint=h},o=(u,l)=>{try{s(u,l)}catch(h){t.onError?.(h,u.tier)}},i=(u,l)=>{if(!l.some(c=>{let v=this.config.messageTier(c[0]);return v>=3&&v<5}))return;if(t.filter){let c=this.tryResolve(u);if(c==null)return;let v=vt(c,bt("standard"));if(!t.filter(u,v))return}let f,p=()=>(f==null&&(f=this.snapshot()),f);for(let c of n)c.disposed||(c.debounceMs===0?o(c,p()):(c.timer==null&&(c.timer=new We),c.timer.start(c.debounceMs,()=>{c.disposed||o(c,this.snapshot())})))},a;if(t.paths!=null){let l=(typeof t.paths=="string"?this._pathsMatching(t.paths):t.paths).map(h=>{let f=this.tryResolve(h);return f==null?()=>{}:f.subscribe(p=>i(h,p))});a=()=>{for(let h of l)h()}}else a=this.observe().subscribe((u,l)=>i(u,l));let d=()=>{a();for(let u of n)u.disposed=!0,u.timer?.cancel();this._storageDisposers.delete(d)};return this._storageDisposers.add(d),{dispose:d}}async _cascadeRestore(e,t){for(let n of e){let s;try{s=await n.load?.()}catch(i){t?.(i,n);continue}if(s==null||typeof s!="object"||Array.isArray(s))continue;let o=s;try{if(o.mode==="full"&&o.snapshot!=null)return this.restore(o.snapshot),!0;if(o.version===Ce&&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===Ce&&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: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(_=>!n.has(_)).sort(),i=[...n].filter(_=>!s.has(_)).sort(),a=[],d=[];for(let _ of n){if(!s.has(_))continue;let T=e.nodes[_],x=t.nodes[_],N=T.v,S=x.v;N!=null&&S!=null&&N.id===S.id&&N.version!==S.version&&d.push({path:_,id:N.id,from:N.version,to:S.version});let m=N!=null&&S!=null&&N.id===S.id&&N.version===S.version;for(let y of["type","status","sentinel"]){let b=T[y],k=x[y];b!==k&&a.push({path:_,field:y,from:b,to:k})}if(!m)for(let y of["value","meta"]){let b=T[y],k=x[y];er(b,k)||a.push({path:_,field:y,from:b,to:k})}}let u=_=>`${_.from} ${_.to}`,l=new Set(e.edges.map(u)),h=new Set(t.edges.map(u)),f=t.edges.filter(_=>!l.has(u(_))),p=e.edges.filter(_=>!h.has(u(_))),c=new Set(e.subgraphs),v=new Set(t.subgraphs),g=[...v].filter(_=>!c.has(_)).sort(),R=[...c].filter(_=>!v.has(_)).sort();return{nodesAdded:o,nodesRemoved:i,nodesChanged:a,versionChanges:d,edgesAdded:f,edgesRemoved:p,subgraphsAdded:g,subgraphsRemoved:R}}};function dr(r,e){let t=Te.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 pn(r,e,t,n={}){let s={paths:[],depths:new Map,truncated:!1};if(!e)return n.withDetail?s:[];if(!n.both&&t!=="upstream"&&t!=="downstream")throw new Error('reachable: direction must be "upstream" or "downstream"');let o=n.maxDepth;if(o!=null&&(!Number.isInteger(o)||o<0))throw new Error("reachable: maxDepth must be an integer >= 0");if(o===0)return n.withDetail?s:[];let i=new Map,a=new Map,d=new Map,u=new Map,l=new Set;for(let[T,x]of Object.entries(r.nodes)){if(!T)continue;l.add(T);let N=x.deps??[];i.set(T,N);for(let S of N)S&&(l.add(S),a.has(S)||a.set(S,new Set),a.get(S).add(T))}for(let T of r.edges){if(T==null||typeof T!="object")continue;let x=typeof T.from=="string"?T.from:"",N=typeof T.to=="string"?T.to:"";!x||!N||(l.add(x),l.add(N),u.has(x)||u.set(x,new Set),u.get(x).add(N),d.has(N)||d.set(N,new Set),d.get(N).add(x))}if(!l.has(e))return n.withDetail?s:[];let h=n.both===!0,f=T=>{if(h){let m=i.get(T)??[],y=d.get(T),b=a.get(T),k=u.get(T),w=[...m];return y&&w.push(...y),b&&w.push(...b),k&&w.push(...k),w}if(t==="upstream"){let m=i.get(T)??[],y=d.get(T);return y?[...m,...y]:m}let x=a.get(T),N=u.get(T),S=x?[...x]:[];return N&&S.push(...N),S},p=new Set([e]),c=new Map,v=[{path:e,depth:0}],g=0,R=!1;for(;g<v.length;){let T=v[g++];if(o!=null&&T.depth>=o){f(T.path).length>0&&(R=!0);continue}for(let x of f(T.path))!x||p.has(x)||(p.add(x),c.set(x,T.depth+1),v.push({path:x,depth:T.depth+1}))}let _=[...c.keys()].sort((T,x)=>T<x?-1:T>x?1:0);return n.withDetail?{paths:_,depths:c,truncated:R}:_}function ur(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}$e();pe();ve();_e();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 Le(r){return r.subscribe(()=>{})}var cr=64;function mn(r,e={}){let{name:t,maxSize:n,versioning:s,guard:o,backend:i}=e,a=i??new Rt(r,n),d=X(a.toArray(),{name:t,describeKind:"state",equals:(m,y)=>m===y,...s!=null?{versioning:s}:{},...o!=null?{guard:o}:{}});function u(){let m=a.toArray();Ee(()=>{d.down([[H]],{internal:!0}),d.down([[I,m]],{internal:!0})})}let l=new Map,h=new Map,f=new Map;function p(m,y){return`${m}:${y===void 0?"END":y}`}function c(m){if(m.size<cr)return;let y=m.keys().next();if(y.done)return;let b=m.get(y.value);b!==void 0&&b.dispose(),m.delete(y.value)}function v(m){let y=a.version;try{return m()}finally{a.version!==y&&u()}}function g(m){if(!Number.isInteger(m)||m<0)throw new RangeError(`tail: n must be a non-negative integer (got ${m})`);let y=l.get(m);if(y!==void 0)return l.delete(m),l.set(m,y),y.node;c(l);let b=B([d],([w])=>{let M=w;return m===0||M.length===0?[]:M.slice(Math.max(0,M.length-m))},{initial:a.tail(m),describeKind:"derived"}),k=Le(b);return l.set(m,{node:b,dispose:k}),b}function R(m,y){if(!Number.isInteger(m)||m<0)throw new RangeError(`slice: start must be a non-negative integer (got ${m})`);if(y!==void 0&&(!Number.isInteger(y)||y<0))throw new RangeError(`slice: stop must be a non-negative integer or undefined (got ${y})`);let b=p(m,y),k=h.get(b);if(k!==void 0)return h.delete(b),h.set(b,k),k.node;c(h);let w=B([d],([E])=>{let O=E;return y===void 0?O.slice(m):O.slice(m,y)},{initial:a.slice(m,y),describeKind:"derived"}),M=Le(w);return h.set(b,{node:w,dispose:M}),w}function _(m){let y=f.get(m);if(y!==void 0)return y.node;let b=B([d,m],([w,M])=>{let E=w,O=Math.max(0,Math.trunc(M??0));return E.slice(O)},{initial:[],describeKind:"derived"}),k=Le(b);return f.set(m,{node:b,dispose:k}),b}let T,x;function N(){T===void 0&&(T=Ae([d],(m,y,b)=>{let k=m[0],M=k!=null&&k.length>0?k.at(-1):b.prevData[0];if(M==null||M.length===0){y.down([[Q]]);return}y.emit(M[M.length-1])},{name:t!=null?`${t}::lastValue`:"lastValue",describeKind:"derived",initial:a.size===0?void 0:a.at(a.size-1)}),x=B([d],([m])=>m.length>0,{name:t!=null?`${t}::hasLatest`:"hasLatest",describeKind:"derived",initial:a.size>0}),Le(T),Le(x))}let S={entries:d,get size(){return a.size},at(m){return a.at(m)},append(m){v(()=>a.append(m))},appendMany(m){m.length!==0&&v(()=>a.appendMany(m))},clear(){v(()=>a.clear())},trimHead(m){v(()=>a.trimHead(m))},withLatest(){return N(),d},get lastValue(){return N(),T},get hasLatest(){return N(),x},view(m){switch(m.kind){case"tail":return g(m.n);case"slice":return R(m.start,m.stop);case"fromCursor":return _(m.cursor)}},attach(m){let y=m.subscribe(b=>{for(let k of b)k[0]===I&&S.append(k[1])});return()=>y()},attachStorage(m){if(m.length===0)return()=>{};let y=new Map;for(let k of m)y.set(k,a.size);(async()=>{for(let k of m)if(typeof k.loadEntries=="function")try{let w=await Promise.resolve(k.loadEntries());w.entries.length>0&&a.size===0&&(a.restore(w.entries),y.set(k,w.entries.length),u());break}catch{}})();let b=d.subscribe(k=>{for(let w of k){if(w[0]!==I)continue;let M=w[1];for(let E of m){let O=y.get(E)??0;if(M.length<O){try{let D=E.appendEntries(M);D instanceof Promise&&D.catch(()=>{})}catch{}y.set(E,M.length);continue}if(M.length===O)continue;let C=M.slice(O);y.set(E,M.length);try{let D=E.appendEntries(C);D instanceof Promise&&D.catch(()=>{})}catch{}}}});return()=>b()},disposeAllViews(){for(let m of l.values())m.dispose();l.clear();for(let m of h.values())m.dispose();h.clear();for(let m of f.values())m.dispose();f.clear()},dispose(){for(let m of l.values())m.dispose();l.clear();for(let m of h.values())m.dispose();h.clear();for(let m of f.values())m.dispose();f.clear()}};return S}var lr=Lt((r,e)=>{r("observe"),r("signal"),e("write")});function Qe(r){let e=mn([],{name:r.name,maxSize:r.retainedLimit??1024,guard:r.guard??lr,...r.versioning!=null?{versioning:r.versioning}:{}});return e.withLatest(),r.graph&&r.graph.add(e.entries,{name:r.name}),e}function bn(r){if(r===null||typeof r!="object"||Object.isFrozen(r))return r;for(let e of Object.keys(r))bn(r[e]);return Object.freeze(r)}function et(r){let e=r.cache,n=(typeof e=="number"&&Number.isFinite(e)?e:0)+1;return r.down([[H],[I,n]]),n}function yn(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 ee(r,e){let t=e.freeze??!0;return function(...s){let o=t?s.map(bn):s,i=le(),a=e.seq?et(e.seq):void 0;try{let d=r(...o);return e.onSuccess&&yn(e.audit,e.onSuccess,o,d,{t_ns:i,seq:a},e.handlerVersion),d}catch(d){if(e.onFailure){let u=d instanceof Error?d.name:typeof d;yn(e.audit,e.onFailure,o,d,{t_ns:i,seq:a,errorType:u},e.handlerVersion)}throw d}}}function tt(r,e,t=0){let n=X(t,{name:e,describeKind:"state"});return r.add(n,{name:e}),n}$e();me();pe();_e();var Nt=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 Fe(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 Nt({maxSize:t,defaultTtl:n}),d=X(a.toMap(),{name:e,describeKind:"state",equals:(f,p)=>f===p,...s!=null?{versioning:s}:{}});function u(){let f=a.toMap();Ee(()=>{d.down([[H]]),d.down([[I,f]])})}function l(){if(!i)return;let f=a.toMap(),p=i.archiveThreshold,c=i.maxSize,v=[];for(let[R,_]of f)v.push({key:R,value:_,score:i.score(R,_)});v.sort((R,_)=>R.score-_.score);let g=new Set;if(p!==void 0)for(let R of v)if(R.score<p)g.add(R.key);else break;if(c!==void 0&&v.length-g.size>c)for(let R of v){if(v.length-g.size<=c)break;g.has(R.key)||g.add(R.key)}if(g.size!==0)for(let R of v)g.has(R.key)&&(i.onArchive?.(R.key,R.value,R.score),a.delete(R.key))}function h(f,p="mutation"){let c=a.version;try{return f()}finally{a.version!==c&&(p==="mutation"&&l(),u())}}return{entries:d,has(f){return h(()=>a.has(f),"read")},get(f){return h(()=>a.get(f),"read")},set(f,p,c){h(()=>a.set(f,p,c?.ttl))},setMany(f,p){h(()=>a.setMany(f,p?.ttl))},delete(f){h(()=>a.delete(f))},deleteMany(f){h(()=>a.deleteMany(f))},clear(){h(()=>a.clear())},pruneExpired(){h(()=>a.pruneExpired())},get size(){return a.size},dispose(){}}}Tt();var $s=Math.LN2/604800;function Et(r,e,t,n=0){if(!Number.isFinite(r))return n;if(!Number.isFinite(e)||e<=0||!Number.isFinite(t)||t<=0)return Math.max(n,r);let s=r*Math.exp(-t*e);return Math.max(n,s)}var fr=1e9;function se(r,e){return Ut("memory",r,e)}function Ke(r,e){return r instanceof L?r:X(r,e?{name:e}:void 0)}function vn(r,e){return(r-e)/fr}function xn(r,e){let t=Math.max(r.length,e.length),n=0,s=0,o=0;for(let a=0;a<t;a+=1){let d=r[a]??0,u=e[a]??0;n+=d*u,s+=d*d,o+=u*u}if(s===0||o===0)return 0;let i=n/Math.sqrt(s*o);return Number.isFinite(i)?i:0}function pr(r,e){if(r===e)return!0;if(r==null||e==null||r.length!==e.length)return!1;for(let t=0;t<r.length;t+=1){let n=r[t],s=e[t];if(n.id!==s.id||n.score!==s.score||n.meta!==s.meta)return!1}return!0}function hr(r,e){if(r===e)return!0;if(r==null||e==null||r.length!==e.length)return!1;for(let t=0;t<r.length;t+=1){let n=r[t],s=e[t];if(n.id!==s.id||n.score!==s.score||n.lastAccessNs!==s.lastAccessNs||n.value!==s.value)return!1}return!0}function gr(r,e={}){let t=e.maxSize,n=e.ranked??!0,s=n?e.decayRate??0:0,o=e.minScore??0;if(t!==void 0&&t<1)throw new RangeError("collection: maxSize must be >= 1");let i=()=>n?1:0,a=e.score??i,d=n&&a instanceof L?a:void 0,u=()=>d?d.cache??i:a,l=new Te(r),f=Fe({name:"items",...t!==void 0?{retention:{score:(E,O)=>n?Et(O.baseScore,vn(K(),O.lastAccessNs),s,o):O.lastAccessNs,maxSize:t}}:{}});l.add(f.entries,{name:"items"});let p;if(n&&s>0){let E=e.refreshIntervalMs??Math.max(1,1e3*Math.LN2/(10*s)),O=Xt(E,{period:E});p=B([O],()=>K(),{name:"refresh_tick_ns",describeKind:"derived",initial:K(),meta:se("clock")}),l.add(p,{name:"refresh_tick_ns"})}let c;if(n){let E=[f.entries];p&&E.push(p),d&&E.push(d),c=B(E,O=>{let C=O[0],D;if(p){let F=O[1];D=typeof F=="number"?F:K()}else D=K();if(!C||C.size===0)return[];let $=[];for(let F of C.values())$.push({...F,score:Et(F.baseScore,vn(D,F.lastAccessNs),s,o)});return $.sort((F,j)=>j.score-F.score||j.lastAccessNs-F.lastAccessNs),$},{name:"ranked",describeKind:"derived",equals:hr,meta:se("ranked")}),l.add(c,{name:"ranked"})}else c=X([],{name:"ranked",describeKind:"state",meta:se("ranked_disabled")}),l.add(c,{name:"ranked"});let v=B([f.entries],([E])=>(E??new Map).size,{name:"size",describeKind:"derived",initial:0,meta:se("size")});l.add(v,{name:"size"}),l.addDisposer(ae(v));let g=Qe({name:"events",retainedLimit:1024,graph:l}),R=tt(l,"seq",0),_=(E,O,C)=>{let D=K(),$=f.get(E),F=C?.score??u()(O);f.set(E,{id:E,value:O,baseScore:F,createdAtNs:$?.createdAtNs??D,lastAccessNs:D})},T=E=>{f.has(E)&&f.delete(E)},x=()=>{f.size!==0&&f.clear()},N=()=>{if(!n)return;let E=u(),O=f.entries.cache;if(!O||O.size===0)return;let C=[];for(let D of O.values())C.push([D.id,{...D,baseScore:E(D.value)}]);f.setMany(C)},S=ee(_,{audit:g,seq:R,onSuccess:([E],O,C)=>({action:"upsert",id:E,t_ns:C.t_ns,seq:C.seq})}),m=ee(T,{audit:g,seq:R,onSuccess:([E],O,C)=>({action:"remove",id:E,t_ns:C.t_ns,seq:C.seq})}),y=ee(x,{audit:g,seq:R,onSuccess:(E,O,C)=>({action:"clear",t_ns:C.t_ns,seq:C.seq})}),b=ee(N,{audit:g,seq:R,onSuccess:(E,O,C)=>({action:"rescore",t_ns:C.t_ns,seq:C.seq})});function k(E){let O=Ke(E,"id");return B([f.entries,O],([C,D])=>C?.get(D),{describeKind:"derived",meta:se("collection_item")})}function w(E){let O=Ke(E,"id");return B([f.entries,O],([C,D])=>C?.has(D)??!1,{describeKind:"derived",meta:se("collection_has")})}return Object.assign(l,{events:g,items:f.entries,ranked:c,size:v,upsert:S,remove:m,clear:y,rescore:b,itemNode:k,hasNode:w})}function mr(r={}){let e=r.backend??"flat",t=r.dimension,n=r.strictDimension??!0,s=r.maxSize,o=r.retentionScore,i;if(e==="hnsw"&&(i=r.hnswFactory?.(),!i))throw new Error('vectorIndex backend "hnsw" requires an optional dependency adapter; install your HNSW package and provide `hnswFactory`.');let a=new Te(r.name??"vector_index"),d;function u(b){if(t!==void 0){if(b.length!==t)throw new RangeError(`vector dimension mismatch: expected ${t}, got ${b.length}`);return}if(n){if(d===void 0){d=b.length;return}if(b.length!==d)throw new RangeError(`vector dimension mismatch: inferred ${d} from first upsert, got ${b.length}. Pass \`strictDimension: false\` to opt into zero-pad behavior, or set an explicit \`dimension\`.`)}}let l=o??(b=>b.upsertedAtNs),h=!1,f=Qe({name:"events",retainedLimit:1024,graph:a}),p=tt(a,"seq",0),c=Fe({name:"entries",...s!==void 0?{retention:{score:(b,k)=>l(k),maxSize:s,onArchive:b=>{h||(e==="hnsw"&&i.remove(b),f.append({action:"evict",id:b,t_ns:le(),seq:et(p)}))}}}:{}});if(a.add(c.entries,{name:"entries"}),a.addDisposer(ae(c.entries)),i?.dispose){let b=i.dispose.bind(i);a.addDisposer(()=>b())}let v=(b,k,w)=>{u(k),e==="hnsw"&&i.upsert(b,k,w);let M=(()=>{if(w!==void 0)return w===null||typeof w!="object"?w:Array.isArray(w)?[...w]:{...w}})(),E={id:b,vector:[...k],...M!==void 0?{meta:M}:{},upsertedAtNs:K()};c.set(b,E)},g=b=>{c.has(b)&&(e==="hnsw"&&i.remove(b),c.delete(b))},R=()=>{if(c.size!==0){h=!0;try{c.clear(),e==="hnsw"&&i.clear()}finally{h=!1}d=void 0}},_=()=>{if(e!=="hnsw")return;let b=c.entries.cache;if(b){i.clear();for(let k of b.values())i.upsert(k.id,k.vector,k.meta)}},T=ee(v,{audit:f,freeze:!1,seq:p,onSuccess:([b],k,w)=>({action:"upsert",id:b,t_ns:w.t_ns,seq:w.seq})}),x=ee(g,{audit:f,seq:p,onSuccess:([b],k,w)=>({action:"remove",id:b,t_ns:w.t_ns,seq:w.seq})}),N=ee(R,{audit:f,seq:p,onSuccess:(b,k,w)=>({action:"clear",t_ns:w.t_ns,seq:w.seq})}),S=ee(_,{audit:f,seq:p,onSuccess:(b,k,w)=>({action:"reindex",t_ns:w.t_ns,seq:w.seq})});function m(b,k=5){let w=Ke(k,"k");return B([c.entries,b,w],M=>{let E=M[0],O=M[1],C=M[2],D=Number.isFinite(C)?Math.max(0,Math.floor(C)):0;if(!E||E.size===0||D<=0)return[];if(O==null||O.length===0)return[];let $=t??(n?d:void 0);return $!==void 0&&O.length!==$?[]:e==="hnsw"?[...i.search(O,D)]:[...E.values()].map(j=>({id:j.id,score:xn(O,j.vector),...j.meta!==void 0?{meta:j.meta}:{}})).sort((j,oe)=>oe.score-j.score).slice(0,D)},{describeKind:"derived",equals:(M,E)=>pr(M,E),meta:se("vector_search")})}return Object.assign(a,{backend:e,events:f,entries:c.entries,upsert:T,remove:x,clear:N,reindex:S,searchNode:m})}var _n="\0";function nt(r,e,t){return`${r}${_n}${e}${_n}${t}`}function wn(r,e){if(!r||r.size===0)return new Map;let t=new Map;for(let s of r.values()){let o=e==="from"?s.from:s.to,i=t.get(o);i||(i=[],t.set(o,i)),i.push(s)}let n=new Map;for(let[s,o]of t)n.set(s,Object.freeze(o));return n}function Tn(r,e){if(r===e)return!0;if(r==null||e==null||r.size!==e.size)return!1;for(let[t,n]of r){let s=e.get(t);if(!s||n.length!==s.length)return!1;for(let o=0;o<n.length;o+=1){let i=n[o],a=s[o];if(i.from!==a.from||i.to!==a.to||i.relation!==a.relation||i.weight!==a.weight)return!1}}return!0}function yr(r,e={}){let t=e.orphanGC??"keep";if(e.entitiesMaxSize!==void 0&&e.entitiesMaxSize<1)throw new RangeError("knowledgeGraph: entitiesMaxSize must be >= 1");if(e.edgesMaxSize!==void 0&&e.edgesMaxSize<1)throw new RangeError("knowledgeGraph: edgesMaxSize must be >= 1");let n=new Te(r),s=Fe({name:"entities",...e.entitiesMaxSize!==void 0?{maxSize:e.entitiesMaxSize}:{}}),o=Fe({name:"edges",...e.edgesMaxSize!==void 0?{maxSize:e.edgesMaxSize}:{}});n.add(s.entries,{name:"entities"}),n.add(o.entries,{name:"edges"});let i=B([o.entries],([y])=>wn(y,"from"),{name:"adjacencyOut",describeKind:"derived",initial:new Map,equals:Tn,meta:se("adjacency_out")}),a=B([o.entries],([y])=>wn(y,"to"),{name:"adjacencyIn",describeKind:"derived",initial:new Map,equals:Tn,meta:se("adjacency_in")});n.add(i,{name:"adjacencyOut"}),n.add(a,{name:"adjacencyIn"}),n.addDisposer(ae(i)),n.addDisposer(ae(a));let d=B([s.entries],([y])=>(y??new Map).size,{name:"entityCount",describeKind:"derived",initial:0,meta:se("entity_count")}),u=B([o.entries],([y])=>(y??new Map).size,{name:"edgeCount",describeKind:"derived",initial:0,meta:se("edge_count")});n.add(d,{name:"entityCount"}),n.add(u,{name:"edgeCount"}),n.addDisposer(ae(d)),n.addDisposer(ae(u));let l=Qe({name:"events",retainedLimit:1024,graph:n}),h=tt(n,"seq",0);function f(y){let b=i.cache,k=a.cache;return(b?.get(y)?.length??0)>0||(k?.get(y)?.length??0)>0}function p(y){if(t==="remove")for(let b of y)s.has(b)&&(f(b)||(s.delete(b),l.append({action:"orphanRemove",id:b,t_ns:le(),seq:et(h)})))}let c=(y,b)=>{s.set(y,b)},v=y=>{let b=o.entries.cache,k=new Set;if(b){let w=[];for(let[M,E]of b)(E.from===y||E.to===y)&&(w.push(M),E.from!==y&&k.add(E.from),E.to!==y&&k.add(E.to));w.length>0&&o.deleteMany(w)}s.has(y)&&s.delete(y),p([...k])},g=(y,b,k,w=1)=>{o.set(nt(y,b,k),{from:y,to:b,relation:k,weight:w})},R=(y,b,k)=>{if(k!==void 0)o.delete(nt(y,b,k));else{let w=o.entries.cache;if(!w)return;let M=[];for(let[E,O]of w)O.from===y&&O.to===b&&M.push(E);M.length>0&&o.deleteMany(M)}p([y,b])},_=ee(c,{audit:l,seq:h,onSuccess:([y],b,k)=>({action:"upsertEntity",id:y,t_ns:k.t_ns,seq:k.seq})}),T=ee(v,{audit:l,seq:h,onSuccess:([y],b,k)=>({action:"removeEntity",id:y,t_ns:k.t_ns,seq:k.seq})}),x=ee(g,{audit:l,seq:h,onSuccess:([y,b,k,w],M,E)=>({action:"link",from:y,to:b,relation:k,weight:w??1,t_ns:E.t_ns,seq:E.seq})}),N=ee(R,{audit:l,seq:h,onSuccess:([y,b,k],w,M)=>({action:"unlink",from:y,to:b,...k!==void 0?{relation:k}:{},t_ns:M.t_ns,seq:M.seq})});function S(y,b){let k=Ke(y,"id"),w=b!==void 0?Ke(b,"relation"):void 0;return B(w?[i,a,k,w]:[i,a,k],E=>{let O=E[0],C=E[1],D=E[2],$=w?E[3]:void 0,F=O.get(D)??[],j=C.get(D)??[],oe=new Set,ge=[];for(let J of F){let ue=nt(J.from,J.to,J.relation);oe.has(ue)||$!==void 0&&J.relation!==$||(oe.add(ue),ge.push(J))}for(let J of j){let ue=nt(J.from,J.to,J.relation);oe.has(ue)||$!==void 0&&J.relation!==$||(oe.add(ue),ge.push(J))}return ge},{describeKind:"derived",equals:(E,O)=>{let C=E,D=O;if(C===D)return!0;if(C==null||D==null||C.length!==D.length)return!1;for(let $=0;$<C.length;$+=1){let F=C[$],j=D[$];if(F.from!==j.from||F.to!==j.to||F.relation!==j.relation||F.weight!==j.weight)return!1}return!0},meta:se("related")})}return Object.assign(n,{events:l,entities:s.entries,edges:o.entries,adjacencyOut:i,adjacencyIn:a,entityCount:d,edgeCount:u,upsertEntity:_,removeEntity:T,link:x,unlink:N,relatedNode:S})}0&&(module.exports={collection,cosineSimilarity,knowledgeGraph,vectorIndex});
1
+ "use strict";var st=Object.defineProperty;var Sn=Object.getOwnPropertyDescriptor;var Mn=Object.getOwnPropertyNames;var An=Object.prototype.hasOwnProperty;var j=(r,e)=>()=>(r&&(e=r(r=0)),e);var Cn=(r,e)=>{for(var t in e)st(r,t,{get:e[t],enumerable:!0})},Dn=(r,e,t,n)=>{if(e&&typeof e=="object"||typeof e=="function")for(let s of Mn(e))!An.call(r,s)&&s!==t&&st(r,s,{get:()=>e[s],enumerable:!(n=Sn(e,s))||n.enumerable});return r};var Gn=r=>Dn(st({},"__esModule",{value:!0}),r);function K(){return Math.trunc(performance.now()*1e6)}function le(){return Date.now()*1e6}var me=j(()=>{"use strict"});function Mt(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++]=ot,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 At(r,e){if(r.length<St)throw new Error(`decodeEnvelope: bytes too short (${r.length} < ${St})`);let t=0,n=r[t++];if(n!==ot)throw new Error(`decodeEnvelope: unsupported envelope version ${n} (expected ${ot})`);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 Ct(r){r.registerCodec(In)}var In,ot,St,it=j(()=>{"use strict";In={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)}},ot=1,St=4});function je(r){if(r==null)return xe;let{type:e,id:t,...n}=r;return{type:e??"system",id:t??"",...n}}var xe,at=j(()=>{"use strict";xe={type:"system",id:""}});function Be(){return Re>0||Ge}function Dt(){return Re>0}function Ne(r){Re>0?Ie.push(r):r()}function Ee(r){Re+=1;let e=!1;try{r()}catch(t){throw e=!0,t}finally{if(Re-=1,Re===0)if(e){if(!Ge){let t=Ie.splice(0);for(let n of t)try{n()}catch{}ye.length=0,be.length=0,ke.length=0}}else $n()}}function $n(){let r=!Ge;r&&(Ge=!0);let e=[],t=0;try{for(;ye.length>0||be.length>0||ke.length>0||r&&Ie.length>0;){if(r&&Ie.length>0){let o=Ie.splice(0);for(let i of o)try{i()}catch(a){e.push(a)}continue}if(t+=1,t>1e3)throw ye.length=0,be.length=0,ke.length=0,new Error("batch drain exceeded 1000 iterations \u2014 likely a reactive cycle");let s=(ye.length>0?ye:be.length>0?be:ke).splice(0);for(let o of s)try{o()}catch(i){e.push(i)}}}finally{r&&(Ge=!1)}if(e.length===1)throw e[0];if(e.length>1)throw new AggregateError(e,"batch drain: multiple callbacks threw")}function qe(r,e,t){if(e.length===0)return;if(e.length===1){let u=t(e[0][0]);if(u<3||!Be()){r(e);return}(u>=5?ke:u===4?be:ye).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=Be();if(s>0){let u=e.slice(0,s);r(u)}if(o>s){let u=e.slice(s,o);d?ye.push(()=>r(u)):r(u)}if(i>o){let u=e.slice(o,i);d?be.push(()=>r(u)):r(u)}if(n>i){let u=e.slice(i,n);d?ke.push(()=>r(u)):r(u)}}var Re,Ge,ye,be,ke,Ie,$e=j(()=>{"use strict";Re=0,Ge=!1,ye=[],be=[],ke=[],Ie=[]});var Oe,I,U,Q,ie,ce,fe,W,Y,z,Se,dt,Vn,ut,zn,Pn,ct,Gt,It,$t,lt,pe=j(()=>{"use strict";Oe=Symbol.for("graphrefly/START"),I=Symbol.for("graphrefly/DATA"),U=Symbol.for("graphrefly/DIRTY"),Q=Symbol.for("graphrefly/RESOLVED"),ie=Symbol.for("graphrefly/INVALIDATE"),ce=Symbol.for("graphrefly/PAUSE"),fe=Symbol.for("graphrefly/RESUME"),W=Symbol.for("graphrefly/TEARDOWN"),Y=Symbol.for("graphrefly/COMPLETE"),z=Symbol.for("graphrefly/ERROR"),Se=Object.freeze([U]),dt=Object.freeze([Q]),Vn=Object.freeze([ie]),ut=Object.freeze([Oe]),zn=Object.freeze([Y]),Pn=Object.freeze([W]),ct=Object.freeze([Se]),Gt=Object.freeze([dt]),It=Object.freeze([Vn]),$t=Object.freeze([zn]),lt=Object.freeze([Pn])});function Vt(r){r.registerMessageType(Oe,{tier:0,wireCrossing:!1}),r.registerMessageType(U,{tier:1,wireCrossing:!1}),r.registerMessageType(ie,{tier:1,wireCrossing:!1,metaPassthrough:!1}),r.registerMessageType(ce,{tier:2,wireCrossing:!1}),r.registerMessageType(fe,{tier:2,wireCrossing:!1}),r.registerMessageType(I,{tier:3,wireCrossing:!0}),r.registerMessageType(Q,{tier:3,wireCrossing:!0}),r.registerMessageType(Y,{tier:4,wireCrossing:!0,metaPassthrough:!1}),r.registerMessageType(z,{tier:4,wireCrossing:!0,metaPassthrough:!1}),r.registerMessageType(W,{tier:5,wireCrossing:!0,metaPassthrough:!1})}var He,zt=j(()=>{"use strict";pe();He=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 Pt(r){return Array.isArray(r)?[...r]:[r]}function Ln(r,e){return r.has(e)||r.has("*")}function Lt(r){let e=[];return r((s,o)=>{e.push({kind:"allow",actions:new Set(Pt(s)),where:o?.where??(()=>!0)})},(s,o)=>{e.push({kind:"deny",actions:new Set(Pt(s)),where:o?.where??(()=>!0)})}),(s,o)=>{let i=!1,a=!1;for(let d of e)Ln(d.actions,o)&&d.where(s)&&(d.kind==="deny"?i=!0:a=!0);return i?!1:a}}function ft(r){let e=Fn.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 re,Fn,Ve=j(()=>{"use strict";re=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}};Fn=["human","llm","wallet","system"]});function pt(r){if(r===void 0)return null;if(typeof r=="number"){if(!Number.isFinite(r))throw new TypeError(`Cannot hash non-finite number: ${r}`);if(Number.isInteger(r)&&!Number.isSafeInteger(r))throw new TypeError(`Cannot hash integer outside safe range (|n| > 2^53-1): ${r}. Cross-language cid parity is not guaranteed for unsafe integers.`);return r}if(typeof r=="string"||typeof r=="boolean"||r===null)return r;if(Array.isArray(r))return r.map(pt);if(typeof r=="object"&&r!==null){let e={};for(let t of Object.keys(r).sort())e[t]=pt(r[t]);return e}return null}function Bn(r){let e=jn.encode(r),t=e.length,n=t*8,s=t+9+63&-64,o=new Uint8Array(s);o.set(e),o[t]=128;let i=new DataView(o.buffer);i.setUint32(s-4,n>>>0,!1),i.setUint32(s-8,Math.floor(n/4294967296)>>>0,!1);let a=1779033703,d=3144134277,u=1013904242,l=2773480762,h=1359893119,f=2600822924,p=528734635,c=1541459225,v=new Uint32Array(64),g=(_,T)=>_>>>T|_<<32-T;for(let _=0;_<s;_+=64){for(let w=0;w<16;w++)v[w]=i.getUint32(_+w*4,!1);for(let w=16;w<64;w++){let M=v[w-15],E=v[w-2],O=g(M,7)^g(M,18)^M>>>3,C=g(E,17)^g(E,19)^E>>>10;v[w]=v[w-16]+O+v[w-7]+C>>>0}let T=a,x=d,N=u,S=l,m=h,y=f,b=p,R=c;for(let w=0;w<64;w++){let M=g(m,6)^g(m,11)^g(m,25),E=m&y^~m&b,O=R+M+E+Kn[w]+v[w]>>>0,C=g(T,2)^g(T,13)^g(T,22),D=T&x^T&N^x&N,$=C+D>>>0;R=b,b=y,y=m,m=S+O>>>0,S=N,N=x,x=T,T=O+$>>>0}a=a+T>>>0,d=d+x>>>0,u=u+N>>>0,l=l+S>>>0,h=h+m>>>0,f=f+y>>>0,p=p+b>>>0,c=c+R>>>0}let k=_=>_.toString(16).padStart(8,"0");return k(a)+k(d)+k(u)+k(l)+k(h)+k(f)+k(p)+k(c)}function ht(r){let e=pt(r??null),t=JSON.stringify(e);return Bn(t).slice(0,16)}function qn(){let r=globalThis.crypto;if(r?.randomUUID)return r.randomUUID();let e=()=>Math.floor(Math.random()*4294967296).toString(16).padStart(8,"0"),t=e()+e()+e()+e();return`${t.slice(0,8)}-${t.slice(8,12)}-4${t.slice(13,16)}-${(parseInt(t.slice(16,17),16)&3|8).toString(16)}${t.slice(17,20)}-${t.slice(20,32)}`}function gt(r,e,t){let n=t?.id??qn();if(r===0)return{id:n,version:0};let o=(t?.hash??ht)(e);return{id:n,version:0,cid:o,prev:null}}function Ft(r,e,t){r.version+=1,"cid"in r&&(r.prev=r.cid,r.cid=t(e))}var Kn,jn,Kt=j(()=>{"use strict";Kn=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]),jn=new TextEncoder});function qt(r){return{node:r,unsub:null,prevData:void 0,dirty:!1,involvedThisWave:!1,dataBatch:[],terminal:void 0}}function mt(r){r.prevData=void 0,r.dirty=!1,r.involvedThisWave=!1,r.dataBatch.length=0,r.terminal=void 0}function Ue(r){return r.length===0?r:typeof r[0]=="symbol"?[r]:r}function Ae(r,e,t){let n=Ht(r)?r:[],s=typeof r=="function"?r:typeof e=="function"?e:void 0,o={};return Ht(r)?o=(yt(e)?e:t)??{}:yt(r)?o=r:o=(yt(e)?e:t)??{},new L(n,s,o)}var jt,Bt,Hn,Un,Me,L,Ht,yt,ve=j(()=>{"use strict";it();at();$e();me();zt();Ve();pe();Kt();jt=()=>{},Bt=100;Hn=(r,e,t,n)=>{t.direction==="down-in"&&r._onDepMessage(t.depIndex,e)},Un=(r,e,t,n)=>{let s=r;if(s._status==="completed"||s._status==="errored")return;let o=s._cached,i=o===void 0?[ut]:[ut,[I,o]];s._status==="dirty"&&i.push(Se),qe(e,i,s._config.tierOf)},Me=new He({onMessage:Hn,onSubscribe:Un});Vt(Me);Ct(Me);L=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??ht;let s=n.versioning??this._config.defaultVersioning;this._versioningLevel=s,this._versioning=s!=null?gt(s,this._cached===void 0?void 0:this._cached,{id:n.versioningId,hash:this._hashFn}):void 0,this._deps=e.map(qt);let o={};for(let[a,d]of Object.entries(n.meta??{})){let u={initial:d,name:`${n.name??"node"}:meta:${a}`,describeKind:"state",config:this._config};n.guard!=null&&(u.guard=n.guard),o[a]=new r([],void 0,u)}Object.freeze(o),this.meta=o,this._hasMeta=Object.keys(o).length>0;let i=this;this._actions={emit(a){i._emit([[I,a]])},down(a){i._emit(Ue(a))},up(a){i._emitUp(Ue(a))}},this.down=this.down.bind(this),this.up=this.up.bind(this)}get _isTerminal(){return this._status==="completed"||this._status==="errored"}get name(){return this._optsName}get status(){return this._status}get cache(){return this._cached===void 0?void 0:this._cached}get lastMutation(){return this._lastMutation}get v(){return this._versioning}hasGuard(){return this._guard!=null}_applyVersioning(e,t){if(this._isExecutingFn)throw new Error(`Node "${this.name}": _applyVersioning cannot run mid-fn \u2014 call it outside of \`_execFn\` (typically at graph setup time before the first subscribe).`);let n=this._versioningLevel;if(n!=null&&e<=n)return;let s=t?.hash??this._hashFn;s!==this._hashFn&&(this._hashFn=s);let o=this._cached===void 0?void 0:this._cached,i=this._versioning,a=i?.id??t?.id,d=i?.version??0,u=gt(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=je(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=je(e?.actor),o=e?.delivery==="signal"?"signal":"write";if(this._guard!=null&&!this._guard(s,o))throw new re({actor:s,action:o,nodeName:this.name});if(this._extraGuards!=null){for(let i of this._extraGuards)if(!i(s,o))throw new re({actor:s,action:o,nodeName:this.name})}this._lastMutation={actor:s,timestamp_ns:le()}}down(e,t){let n=Ue(e);n.length!==0&&(this._checkGuard(t),this._emit(n))}emit(e,t){this._checkGuard(t),this._emit([[I,e]])}up(e,t){if(this._deps.length===0)return;let n=Ue(e);if(n.length===0)return;this._checkGuard(t);let s=t??{internal:!0};this._validateUpTiers(n);for(let o of this._deps)o.node.up?.(n,s)}_emitUp(e){if(this._deps.length!==0&&e.length!==0){this._validateUpTiers(e);for(let t of this._deps)t.node.up?.(e,{internal:!0})}}_validateUpTiers(e){let t=this._config.tierOf;for(let n of e){let s=t(n[0]);if(s===3||s===4)throw new Error(`Node "${this.name}": tier-${s} messages cannot flow up \u2014 DATA/RESOLVED/COMPLETE/ERROR are downstream-only. Use \`down(...)\` for value delivery; \`up(...)\` is for control signals (DIRTY, INVALIDATE, PAUSE, RESUME, TEARDOWN).`)}}subscribe(e,t){if(t!=null&&this._guard!=null){let d=je(t);if(!this._guard(d,"observe"))throw new re({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)mt(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=jt,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{}mt(o)}}throw this._dirtyDepCount=0,n}}_addDep(e){for(let s=0;s<this._deps.length;s++)if(this._deps[s].node===e)return s;let t=this._deps.length,n=qt(e);if(this._deps.push(n),this._sinks==null)return t;n.dirty=!0,this._dirtyDepCount++,this._status!=="dirty"&&this._emit(ct),n.unsub=jt;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([[z,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([[z,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{}}mt(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!==Oe){if(s===U){this._depDirtied(n);return}if(s===ie){if(this._depInvalidated(n),this._cached===void 0)return;this._emit(It);return}if(s===ce||s===fe){this._emit([t]);return}if(s===W){this._emit(lt);return}if(s===I)this._depSettledAsData(n,t[1]);else if(s===Q)this._depSettledAsResolved(n);else if(s===Y)this._depSettledAsTerminal(n,!0);else if(s===z)this._depSettledAsTerminal(n,t[1]);else{this._emit([t]);return}if(!this._fn){(s===I||s===Q)&&this._emit([t]),(s===Y||s===z)&&this._maybeAutoTerminalAfterWave();return}}}_depDirtied(e){e.dirty||(e.dirty=!0,e.involvedThisWave=!0,this._dirtyDepCount++,this._status!=="dirty"&&this._emit(ct))}_depSettledAsData(e,t){e.dirty&&(e.dirty=!1,this._dirtyDepCount--),e.involvedThisWave=!0,e.dataBatch.push(t),this._waveHasNewData=!0}_depSettledAsResolved(e){e.dirty&&(e.dirty=!1,this._dirtyDepCount--)}_depSettledAsTerminal(e,t){e.dirty&&(e.dirty=!1,this._dirtyDepCount--),e.terminal=t,e.involvedThisWave=!0,this._hasNewTerminal=!0}_depInvalidated(e){e.prevData=void 0,e.terminal=void 0,e.dataBatch.length=0,e.dirty?e.involvedThisWave=!1:(e.dirty=!0,e.involvedThisWave=!0,this._dirtyDepCount++)}_maybeRunFnOnSettlement(){if(!(this._isTerminal&&!this._resubscribable)&&!(this._dirtyDepCount>0)){if(!this._partial&&!this._hasCalledFnOnce)for(let e=0;e<this._deps.length;e++){let t=this._deps[e];if(t.dataBatch.length===0&&t.prevData===void 0&&t.terminal===void 0){this._maybeAutoTerminalAfterWave();return}}if(this._paused){this._pendingWave=!0;return}if(!this._waveHasNewData&&!this._hasNewTerminal&&this._hasCalledFnOnce){this._clearWaveFlags(),this._emit(Gt),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([[z,e.terminal]]);return}this._autoComplete&&this._deps.every(t=>t.terminal!==void 0)&&this._emit($t)}_execFn(){if(!this._fn||this._isTerminal&&!this._resubscribable)return;if(this._isExecutingFn){this._pendingRerun=!0;return}let e=this._cleanup;if(typeof e=="function"){this._cleanup=void 0;try{e()}catch(i){this._emit([[z,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([[z,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([[z,this._wrapFnError("fn threw",i)]])}finally{this._isExecutingFn=!1,this._pendingRerun?(this._pendingRerun=!1,this._rerunDepth+=1,this._rerunDepth>Bt?(this._rerunDepth=0,this._emit([[z,new Error(`Node "${this.name}": _pendingRerun depth exceeded ${Bt} \u2014 likely a reactive cycle`)]])):this._maybeRunFnOnSettlement()):this._rerunDepth=0,this._clearWaveFlags()}}_clearWaveFlags(){this._waveHasNewData=!1,this._hasNewTerminal=!1;for(let e of this._deps)e.involvedThisWave=!1,e.dataBatch.length=0}_wrapFnError(e,t){let 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"?[Se,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]===U&&(o=!0),i=u}let a=e;if(!n){let d=e.map((u,l)=>({m:u,i:l,tier:t(u[0])}));d.sort((u,l)=>u.tier-l.tier||u.i-l.i),a=d.map(u=>u.m)}if(s&&!o&&this._status!=="dirty"){let d=0;for(;d<a.length&&t(a[d][0])===0;)d++;return d===0?[Se,...a]:[...a.slice(0,d),Se,...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]===z&&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]===W||d[0]===ie);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!==ce&&u!==fe){s?.push(d);continue}if(d.length<2)throw new Error(`Node "${this.name}": [[${u===ce?"PAUSE":"RESUME"}]] must carry a lockId payload \u2014 bare PAUSE/RESUME is a protocol violation (C0 rule). Use \`[[PAUSE, lockId]]\` / \`[[RESUME, lockId]]\`.`);let l=!0;if(this._pausable!==!1){let h=d[1];if(u===ce)this._pauseLocks==null&&(this._pauseLocks=new Set),this._pauseLocks.add(h),this._paused=!0,this._pausable==="resumeAll"&&this._pauseBuffer==null&&(this._pauseBuffer=[]);else if(this._pauseLocks==null||!this._pauseLocks.has(h))l=!1;else if(this._pauseLocks.delete(h),this._pauseLocks.size===0){if(this._paused=!1,this._pauseBuffer!=null&&this._pauseBuffer.length>0){let f=this._pauseBuffer;this._pauseBuffer=[],this._emit(f)}this._pendingWave&&(this._pendingWave=!1,this._maybeRunFnOnSettlement())}}l?s?.push(d):s==null&&(s=t.slice(0,a))}if(s!=null){if(s.length===0)return;t=s}if(this._hasMeta&&t.some(a=>a[0]===W))for(let a of Object.keys(this.meta))try{this.meta[a]._emit(lt)}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([[z,i]])}_updateState(e){let t=this._config.tierOf,n,s,o=-1,i=0;for(let l of e)t(l[0])===3&&i++;let a=i<=1,d=-1;if(this._versioning!=null&&i>1){for(let l=e.length-1;l>=0;l--)if(e[l][0]===I){d=l;break}}for(let l=0;l<e.length;l++){let h=e[l],f=h[0];if(f===I){if(h.length>=2){let p=!1;if(a&&this._cached!==void 0)try{p=this._equals(this._cached,h[1])}catch(c){s=this._wrapFnError("equals threw",c),o=l;break}if(p){n==null&&(n=e.slice(0,l)),n.push(dt),this._status="resolved";continue}this._cached=h[1],this._versioning!=null&&(d<0||l===d)&&Ft(this._versioning,h[1],this._hashFn)}this._status="settled",n?.push(h)}else if(n?.push(h),f===U)this._status="dirty";else if(f===Q)this._status="resolved";else if(f===Y){this._status="completed";{let p=this._config.rigorRecorder;if(p!=null)try{p.onTerminalTransition(this,"completed",this._autoComplete,this._autoError,this._deps.length>0)}catch{}}}else if(f===z){this._status="errored";{let p=this._config.rigorRecorder;if(p!=null)try{p.onTerminalTransition(this,"errored",this._autoComplete,this._autoError,this._deps.length>0)}catch{}}}else if(f===ie){if(this._cached!==void 0){let c=this._config.rigorRecorder;if(c!=null)try{c.onNonVacuousInvalidate(this,this._cached)}catch{}}this._cached=void 0,this._status="dirty";let p=this._cleanup;if(typeof p=="function"){this._cleanup=void 0;try{p()}catch{}}else if(p!=null&&typeof p=="object"){let c=p.invalidate;if(typeof c=="function")try{c()}catch{}}}else f===W&&(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(Dt()){this._batchPendingMessages===null&&(this._batchPendingMessages=[],Ne(()=>this._flushBatchPending()));for(let t of e)this._batchPendingMessages.push(t);return}qe(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);qe(this._deliverToSinks,t,this._config.tierOf)}},Ht=r=>Array.isArray(r),yt=r=>typeof r=="object"&&r!=null&&!Array.isArray(r)});function X(r,e){return Ae([],{...e,initial:r})}function ze(r,e){return Ae((n,s,o)=>r(s,o)??void 0,{describeKind:"producer",...e})}function q(r,e,t){return Ae(r,(s,o,i)=>{let a=s.map((d,u)=>d!=null&&d.length>0?d.at(-1):i.prevData[u]);o.emit(e(a,i))},{describeKind:"derived",...t})}var _e=j(()=>{"use strict";ve()});function Ut(r,e,t){return{[r]:!0,[`${r}_type`]:e,...t??{}}}var Wt=j(()=>{"use strict"});function bt(r,e){if(e!=null&&e.length>0)return new Set(e);switch(r){case"standard":return new Set(["type","status","value","deps","meta","v"]);case"full":return null;case"spec":return new Set(["type","deps","meta","value"]);default:return new Set(["type","deps"])}}function Wn(r){return r._describeKind!=null?r._describeKind:r._deps.length>0?"derived":r._fn!=null?"producer":"state"}function Yn(r){let e={};for(let[t,n]of Object.entries(r.meta))try{e[t]=n.cache}catch{}return e}function vt(r,e,t){let n=e==null,s=!n&&e!=null?[...e].filter(l=>l.startsWith("meta.")).map(l=>l.slice(5)):null,o=n||e.has("meta")||s!=null&&s.length>0,i="state",a=[];r instanceof L&&(i=Wn(r),a=r._deps.map(l=>l.node.name??""));let d={type:i,deps:a};(n||e.has("status"))&&(d.status=r.status);let u=r instanceof L?r._guard:void 0;if(o){let l={...Yn(r)};if(u!=null&&l.access===void 0&&(l.access=ft(u)),s!=null&&s.length>0&&!e.has("meta")){let h={};for(let f of s)f in l&&(h[f]=l[f]);d.meta=h}else d.meta=l}if(r.name!=null&&(d.name=r.name),(n||e.has("value"))&&(!t||i==="state")){r.status==="sentinel"&&(d.sentinel=!0);try{d.value=r.cache}catch{}}if((n||e.has("v"))&&r.v!=null){let l={id:r.v.id,version:r.v.version};"cid"in r.v&&(l.cid=r.v.cid,l.prev=r.v.prev),d.v=l}return(n||e.has("guard"))&&u!=null&&(d.guard=ft(u)),(n||e.has("lastMutation"))&&r.lastMutation!=null&&(d.lastMutation=r.lastMutation),d}var Yt=j(()=>{"use strict";Ve();ve()});function _t(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(!_t(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)||!_t(r[o],e[o]))return!1;return!0}function Jt(r,e){return`${r}\0${e}`}function wt(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 k=r.nodes[g]?.meta,_=e.nodes[g]?.meta;k==null&&_==null||_t(k??{},_??{})||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 l=new Map;for(let g of r.edges)l.set(Jt(g.from,g.to),g);let h=new Map;for(let g of e.edges)h.set(Jt(g.from,g.to),g);let f=[];for(let[g,k]of h)l.has(g)||f.push(k);f.sort((g,k)=>g.from<k.from?-1:g.from>k.from?1:g.to<k.to?-1:g.to>k.to?1:0);for(let g of f)t.push({type:"edge-added",from:g.from,to:g.to});let p=[];for(let[g,k]of l)h.has(g)||p.push(k);p.sort((g,k)=>g.from<k.from?-1:g.from>k.from?1:g.to<k.to?-1:g.to>k.to?1:0);for(let g of p)t.push({type:"edge-removed",from:g.from,to:g.to});let c=[];for(let g of i)a.has(g)||c.push(g);c.sort();for(let g of c)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 Xt=j(()=>{"use strict";me()});function Jn(r){return{describeKind:"producer",...r}}function Zt(r,e){let{signal:t,period:n,...s}=e??{};return ze(o=>{let i=!1,a=0,d,u,l=()=>{i=!0,d!==void 0&&clearTimeout(d),u!==void 0&&clearInterval(u),t?.removeEventListener("abort",f)},h=()=>{i||(n!=null?(o.emit(a++),u=setInterval(()=>{i||o.emit(a++)},n)):(i=!0,t?.removeEventListener("abort",f),o.emit(a++),o.down([[Y]])))},f=()=>{i||(l(),o.down([[z,t.reason]]))};if(t?.aborted){f();return}return d=setTimeout(h,r),t?.addEventListener("abort",f,{once:!0}),l},Jn(s))}function ae(r){return r.subscribe(()=>{})}var Qt=j(()=>{"use strict";pe();_e()});var Tt=j(()=>{"use strict";Qt()});var We,en=j(()=>{"use strict";We=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 Pe,tn=j(()=>{"use strict";Pe=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 nn(r,e,t,n={}){let s=e in r.nodes,o=t in r.nodes;if(!s)return Ye(e,t,"no-such-from");if(!o)return Ye(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=Xn(r,e,n);if(u!=null)return u}let d=Je(e,r.nodes[e],0,n);return Xe(e,t,[d])}if(i===0)return Ye(e,t,"no-path");let a=rn(r,e,t,i);return a.found?Xe(e,t,sn(r,a.pathOrder,n)):Ye(e,t,a.truncated?"max-depth-exceeded":"no-path")}function rn(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 h=o[a++];if(h.path===e)break;if(n!=null&&h.depth>=n){let v=r.nodes[h.path];v?.deps&&v.deps.length>0&&(d=!0);continue}let f=r.nodes[h.path];if(f==null)continue;let p=f.deps??[],c=new Map;for(let v=0;v<p.length;v++){let g=p[v];if(!g)continue;let k=c.get(g);k==null&&(k=[],c.set(g,k)),k.push(v)}for(let[v,g]of c)i.has(v)||(i.add(v),s.set(v,{from:h.path,depIndices:g}),o.push({path:v,depth:h.depth+1}))}if(!s.has(e))return{found:!1,pathOrder:[],truncated:d};let u=[{path:e}],l=e;for(;l!==t;){let h=s.get(l);if(h==null)return{found:!1,pathOrder:[],truncated:!1};u[u.length-1].depIndices=h.depIndices,u.push({path:h.from}),l=h.from}return{found:!0,pathOrder:u,truncated:!1}}function Xn(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=Je(e,n,0,t);a.dep_index=o[0];let d=Je(e,n,1,t);return Xe(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=rn(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:Xe(e,e,sn(r,i.pathOrder,t))}function sn(r,e,t){return e.map((n,s)=>{let o=r.nodes[n.path],i=Je(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 Je(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 Xe(r,e,t){return on(r,e,!0,"ok",t)}function Ye(r,e,t){return on(r,e,!1,t,[])}function on(r,e,t,n,s){let o=Zn(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 Zn(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: ${Qn(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 Qn(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 an=j(()=>{"use strict"});function dn(r){let e=new WeakSet,t=new WeakSet,n=[r],s=0;for(;n.length>0;){let o=n.pop();s+=tr(o,e,t,n)}return s}function tr(r,e,t,n){if(r==null)return 0;switch(typeof r){case"number":return H.number;case"boolean":return H.boolean;case"string":return H.string+r.length*2;case"bigint":return H.bigint+nr(r);case"symbol":return H.symbol;case"function":return e.has(r)?0:(e.add(r),H.function);case"undefined":return 0}let o=r;if(e.has(o))return 0;e.add(o);let i=o[er];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 H.date;if(o instanceof RegExp)return H.regexp+o.source.length*2;if(o instanceof Error){let u=o.message?o.message.length*2:0,l=o.stack?o.stack.length*2:0;return H.error+u+l}if(typeof URL<"u"&&o instanceof URL)return H.url+o.href.length*2;if(typeof Promise<"u"&&o instanceof Promise)return H.promise;if(o instanceof WeakMap)return H.weakmap;if(o instanceof WeakSet)return H.weakset;if(o instanceof Map){let u=H.map;for(let[l,h]of o)u+=H.mapEntry,n.push(l),n.push(h);return u}if(o instanceof Set){let u=H.set;for(let l of o)u+=H.setEntry,n.push(l);return u}if(Array.isArray(o)){let u=H.array+o.length*8;for(let l of o)n.push(l);return u}if(o instanceof ArrayBuffer)return t.has(o)?0:(t.add(o),o.byteLength);if(ArrayBuffer.isView(o)){let u=o;return t.has(u.buffer)?48:(t.add(u.buffer),u.buffer.byteLength+48)}let a=H.object,d=Object.keys(o);for(let u of d){a+=H.string+u.length*2;try{n.push(o[u])}catch{}}return a}function nr(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 H,er,un=j(()=>{"use strict";H={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},er=Symbol.for("sizeof")});function cn(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,p]of s)i.set(f,p);let a=[];for(let[f,p]of Object.entries(n.nodes)){let c=i.get(f),v=c instanceof L?c:null,g=v?dn(v.cache):0,k=v?v._sinkCount:0,_=p.deps?.length??0,T=p.type==="effect"&&k===0,x=k===0?p.type==="effect"?"orphan-effect":p.type==="derived"?"idle-derived":p.type==="producer"?"idle-producer":null:null;a.push({path:f,type:p.type,status:p.status??"unknown",valueSizeBytes:g,subscriberCount:k,depCount:_,isOrphanEffect:T,orphanKind:x})}let d=a.reduce((f,p)=>f+p.valueSizeBytes,0),u=(f,p)=>[...a].sort(p??((c,v)=>v[f]-c[f])).slice(0,t),l=a.filter(f=>f.orphanKind!=null),h=a.filter(f=>f.isOrphanEffect);return{nodeCount:a.length,edgeCount:n.edges.length,subgraphCount:n.subgraphs.length,nodes:a,totalValueSizeBytes:d,hotspots:{byValueSize:u("valueSizeBytes"),bySubscriberCount:u("subscriberCount"),byDepCount:u("depCount")},orphans:l,orphanEffects:h}}var ln=j(()=>{"use strict";ve();un()});function fn(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 bn(r){return r!=null&&typeof r=="object"&&"cache"in r&&typeof r.subscribe=="function"&&typeof r.down=="function"}function rr(r){if(r!=null)return bn(r)?r.cache:r}function we(r){return r!=null&&typeof r=="object"&&"cache"in r&&typeof r.subscribe=="function"&&typeof r.down=="function"}function he(r){return we(r)?r.cache??"":r}function pn(r){return we(r)?r.cache??0:r}function hn(r){return we(r)?r.cache??!1:r}function sr(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 gn(r){if(r.version!==Ce)throw new Error(`unsupported snapshot version ${String(r.version)} (expected ${Ce})`);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 or(r,e){let t=new WeakMap,n=(s,o)=>{if(Object.is(s,o))return!0;if(s==null||o==null||typeof s!="object"||typeof o!="object")return!1;let i=t.get(s);if(i==null&&(i=new WeakSet,t.set(s,i)),i.has(o))return!0;i.add(o);let a=s.constructor,d=o.constructor;if(a!==d)return!1;if(s instanceof Date)return s.getTime()===o.getTime();if(s instanceof RegExp)return s.source===o.source&&s.flags===o.flags;if(Array.isArray(s)){let f=o;if(s.length!==f.length)return!1;for(let p=0;p<s.length;p++)if(!n(s[p],f[p]))return!1;return!0}if(s instanceof Map){let f=o;if(s.size!==f.size)return!1;for(let[p,c]of s)if(!f.has(p)||!n(c,f.get(p)))return!1;return!0}if(s instanceof Set){let f=o;if(s.size!==f.size)return!1;for(let p of s){let c=!1;for(let v of f)if(n(p,v)){c=!0;break}if(!c)return!1}return!0}if(ArrayBuffer.isView(s)){let f=s,p=o;if(f.length!==p.length)return!1;for(let c=0;c<f.length;c++)if(f[c]!==p[c])return!1;return!0}let u=Object.keys(s),l=Object.keys(o);if(u.length!==l.length)return!1;let h=new Set(l);for(let f of u)if(!h.has(f)||!n(s[f],o[f]))return!1;return!0};return n(r,e)}function ir(r){return r.replace(/[.*+?^${}()|[\]\\]/g,"\\$&")}function Ze(r){let e="^";for(let t=0;t<r.length;t+=1){let n=r[t];if(n==="*"){e+=".*";continue}if(n==="?"){e+=".";continue}if(n==="["){let s=r.indexOf("]",t+1);if(s<=t+1){e+="\\[";continue}let o=r.slice(t+1,s);o.startsWith("!")&&(o=`^${o.slice(1)}`),o=o.replace(/\\/g,"\\\\"),e+=`[${o}]`,t=s;continue}e+=ir(n)}return e+="$",new RegExp(e)}function xt(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 ur(r){return r==="none"?dr:r==="ansi"||r==null?ar:{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 mn(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 cr(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 Rt(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===de)throw new Error(`Graph "${e}": ${t} name "${de}" is reserved for meta companion paths`);cr(r,e,t)}function lr(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 fr(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 vn(r){for(let e of r._mounts.values())vn(e);for(let e of r._nodes.values())try{e.down([[W]],{internal:!0})}catch{}}function pr(r,e){let t=Te.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 yn(r,e,t,n={}){let s={paths:[],depths:new Map,truncated:!1};if(!e)return n.withDetail?s:[];if(!n.both&&t!=="upstream"&&t!=="downstream")throw new Error('reachable: direction must be "upstream" or "downstream"');let o=n.maxDepth;if(o!=null&&(!Number.isInteger(o)||o<0))throw new Error("reachable: maxDepth must be an integer >= 0");if(o===0)return n.withDetail?s:[];let i=new Map,a=new Map,d=new Map,u=new Map,l=new Set;for(let[T,x]of Object.entries(r.nodes)){if(!T)continue;l.add(T);let N=x.deps??[];i.set(T,N);for(let S of N)S&&(l.add(S),a.has(S)||a.set(S,new Set),a.get(S).add(T))}for(let T of r.edges){if(T==null||typeof T!="object")continue;let x=typeof T.from=="string"?T.from:"",N=typeof T.to=="string"?T.to:"";!x||!N||(l.add(x),l.add(N),u.has(x)||u.set(x,new Set),u.get(x).add(N),d.has(N)||d.set(N,new Set),d.get(N).add(x))}if(!l.has(e))return n.withDetail?s:[];let h=n.both===!0,f=T=>{if(h){let m=i.get(T)??[],y=d.get(T),b=a.get(T),R=u.get(T),w=[...m];return y&&w.push(...y),b&&w.push(...b),R&&w.push(...R),w}if(t==="upstream"){let m=i.get(T)??[],y=d.get(T);return y?[...m,...y]:m}let x=a.get(T),N=u.get(T),S=x?[...x]:[];return N&&S.push(...N),S},p=new Set([e]),c=new Map,v=[{path:e,depth:0}],g=0,k=!1;for(;g<v.length;){let T=v[g++];if(o!=null&&T.depth>=o){f(T.path).length>0&&(k=!0);continue}for(let x of f(T.path))!x||p.has(x)||(p.add(x),c.set(x,T.depth+1),v.push({path:x,depth:T.depth+1}))}let _=[...c.keys()].sort((T,x)=>T<x?-1:T>x?1:0);return n.withDetail?{paths:_,depths:c,truncated:k}:_}function hr(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,de,Ce,ar,dr,Te,_n=j(()=>{"use strict";at();$e();me();Ve();pe();Yt();ve();_e();Xt();Tt();en();tn();it();an();ln();P="::",de="__meta__",Ce=1;ar={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"},dr={data:"",dirty:"",resolved:"",invalidate:"",pause:"",resume:"",complete:"",error:"",teardown:"",derived:"",path:"",reset:""};Te=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===de)throw new Error(`Graph name "${de}" is reserved for meta companion paths`);this.name=e,this.opts=Object.freeze({...t??{}}),this.config=t?.config??Me,this._traceRing=new Pe(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=ze(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(Rt(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 L&&t._applyVersioning(e)}remove(e){Rt(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}${de}${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,vn(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([[W]],{internal:!0});let s={kind:"node",nodes:[e],mounts:[]};return this._emitTopology({kind:"removed",name:e,nodeKind:"node",audit:s}),s}removeAll(e){let t=typeof e=="function"?e:(()=>{let o=Ze(e);return i=>o.test(i)})(),n={kind:"mount",nodes:[],mounts:[]},s=[...this._nodes.keys(),...this._mounts.keys()].filter(o=>t(o));for(let o of s){let i=this.remove(o);n.nodes.push(...i.nodes),n.mounts.push(...i.mounts)}return n.nodes.sort(),n.mounts.sort(),n}[Symbol.iterator](){let e=[...this._nodes.keys()].sort(),t=this._nodes,n=0;return{[Symbol.iterator](){return this},next(){if(n>=e.length)return{value:void 0,done:!0};let s=e[n++];return{value:[s,t.get(s)],done:!1}}}}node(e){if(e==="")throw new Error(`Graph "${this.name}": node name must be non-empty`);if(e.includes(P))return this.resolve(e);let t=this._nodes.get(e);if(!t)throw new Error(`Graph "${this.name}": unknown node "${e}"`);return t}get(e){return this.node(e).cache}set(e,t,n){let s=n?.internal===!0;this.node(e).down([[I,t]],{actor:n?.actor,internal:s,delivery:"write"})}setAll(e,t){let n=Symbol.iterator in e?e:Object.entries(e);Ee(()=>{for(let[s,o]of n)this.set(s,o,t)})}invalidate(e,t){let n=t?.internal===!0;this.node(e).down([[ie]],{actor:t?.actor,internal:n,delivery:"write"})}error(e,t,n){let s=n?.internal===!0;this.node(e).down([[z,t]],{actor:n?.actor,internal:s,delivery:"write"})}complete(e,t){let n=t?.internal===!0;this.node(e).down([[Y]],{actor:t?.actor,internal:n,delivery:"write"})}edges(e){let t=e?.recursive===!0,n=new Map;if(!t){for(let[d,u]of this._nodes)n.set(u,d);let a=[];for(let[d,u]of this._nodes)if(u instanceof L)for(let l of u._deps){let h=n.get(l.node);h!=null&&a.push([h,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 L)for(let u of d._deps){let l=o.get(u.node);l!=null&&i.push([l,a])}return i.sort((a,d)=>a[0]<d[0]?-1:a[0]>d[0]?1:a[1]<d[1]?-1:a[1]>d[1]?1:0),i}mount(e,t){if(t===void 0){let s=new r(e);return this.mount(e,s)}if(typeof t=="function"){let s=new r(e);return t(s),this.mount(e,s)}let n=t;if(Rt(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=lr(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]===de)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]!==de)throw new Error(`Graph "${this.name}": expected ${de} segment in meta path "${n}"`);if(o+1>=i.length)throw new Error(`Graph "${this.name}": meta path requires a key after ${de} 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=fr(e,this.config);for(let d of[...this._nodes.keys()].sort()){let u=this._nodes.get(d);if(!n.has(u)){n.add(u);try{u.down(e,i)}catch(l){if(l instanceof re)throw l;s.push(l)}a.length!==0&&this._signalMetaSubtree(u,a,n,i,s)}}}_signalMetaSubtree(e,t,n,s,o){for(let i of Object.keys(e.meta).sort()){let a=e.meta[i];if(!n.has(a)){n.add(a);try{a.down(t,s)}catch(d){if(d instanceof re)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=rr(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=bt(e?.detail,e?.fields),o=e?.detail==="spec",i=s,a=[];this._collectObserveTargets("",a);let d=new Map;for(let[x,N]of a)d.set(N,x);let u=[];{let x=a.map(([,m])=>m),N=new Set(d.values()),S=0;for(;x.length>0;){let m=x.shift();if(m instanceof L)for(let y of m._deps){let b=y.node;if(d.has(b))continue;let R=b.name??"",w=R;if(!w||N.has(w))if(R){let M=2;for(;N.has(`${R}#${M}`);)M++;w=`${R}#${M}`}else for(w=`__internal__/${S++}`;N.has(w);)w=`__internal__/${S++}`;d.set(b,w),N.add(w),u.push([w,b]),x.push(b)}}}let l=[...a,...u],h={};for(let[x,N]of l){if(t!=null&&!N.allowsObserve(t))continue;let S=vt(N,i,o),m=N instanceof L?N._deps.map(w=>d.get(w.node)??w.node.name??""):[],{name:y,...b}=S,R={...b,deps:m};if(!o){let w=this._annotations.get(x);w!=null&&(R.annotation=w)}if(n!=null)if(typeof n=="function"){let w=n;if(!(w.length>=2?w(x,R):w(R)))continue}else{let w=!0;for(let[M,E]of Object.entries(n)){let O=M==="deps_includes"?"depsIncludes":M==="meta_has"?"metaHas":M;if(O==="depsIncludes"){if(!R.deps.includes(String(E))){w=!1;break}continue}if(O==="metaHas"){if(!Object.hasOwn(R.meta??{},String(E))){w=!1;break}continue}if(R[O]!==E){w=!1;break}}if(!w)continue}h[x]=R}let f=new Set(Object.keys(h)),p=[];for(let[x,N]of l)if(N instanceof L)for(let S of N._deps){let m=d.get(S.node);m!=null&&p.push([m,x])}p.sort((x,N)=>x[0]<N[0]?-1:x[0]>N[0]?1:x[1]<N[1]?-1:x[1]>N[1]?1:0);let c=p.map(([x,N])=>({from:x,to:N}));(t!=null||n!=null)&&(c=c.filter(x=>f.has(x.from)&&f.has(x.to)));let v=this._collectSubgraphs(""),g=t!=null||n!=null?v.filter(x=>{let N=`${x}${P}`;return[...f].some(S=>S===x||S.startsWith(N))}):v,k=this,_=e;return{name:this.name,nodes:h,edges:c,subgraphs:g,...this._factory!==void 0?{factory:this._factory}:{},...this._factoryArgs!==void 0?{factoryArgs:this._factoryArgs}:{},expand(x){let N={..._};return Array.isArray(x)?(N.fields=x,N.detail=void 0):(N.detail=x,N.fields=void 0),k.describe(N)}}}_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 cn(this,e)}reachable(e,t,n={}){return n.withDetail===!0?yn(this.describe(),e,t,{...n,withDetail:!0}):yn(this.describe(),e,t,n)}explain(e,t,n){return n?.reactive===!0?this._explainReactive(e,t,n):this._explainStatic(he(e),he(t),{...n?.maxDepth!==void 0?{maxDepth:pn(n.maxDepth)}:{},...n?.findCycle!==void 0?{findCycle:hn(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 nn(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=X(s,{name:`${n}_version`}),i=this.observe({timeline:!0,structured:!0}),a=!1,d=!1,u=()=>{a||d||(a=!0,Ne(()=>{a=!1,!d&&(s+=1,o.emit(s))}))},l=i.onEvent(_=>{let T=_.type;T!=="data"&&T!=="error"&&T!=="complete"&&T!=="teardown"||u()}),h=[],f=new WeakSet,p=_=>{if(f.has(_)||d)return;f.add(_);let T=_.topology.subscribe(x=>{for(let N of x){if(N[0]!==I)continue;let S=N[1];if(u(),S.kind==="added"&&S.nodeKind==="mount"){let m=_._mounts.get(S.name);m!=null&&p(m)}}});h.push(T);for(let x of _._mounts.keys()){let N=_._mounts.get(x);N!=null&&p(N)}};p(this);let c,v=e.actor;bn(v)&&(c=v.subscribe(_=>{let T=!1,x=!1;for(let N of _){let S=N[0];S===I?T=!0:(S===Y||S===z||S===W)&&(x=!0)}T&&u(),x&&(c?.(),c=void 0,u())}));let g;try{g=q([o],()=>this.describe(t),{name:n,describeKind:"derived",meta:{domain:"audit",kind:"describe"},equals:(_,T)=>_===T})}catch(_){l(),c?.();for(let T of h)T();throw i.dispose(),_}let k=ae(g);return{node:g,dispose(){d=!0,l(),c?.();for(let _ of h)_();h.length=0,i.dispose(),k()}}}_describeReactiveDiff(e){let t={...e,reactive:!1},n=e.reactiveName??"describe-diff",s={name:this.name,nodes:{},edges:[],subgraphs:[]},o=this.describe(t),i=wt(s,o),a=X(i,{name:n,meta:{domain:"audit",kind:"describe-diff"},equals:(f,p)=>f===p}),d=this._describeReactive({...e,reactiveName:void 0}),u=!1,l=d.node.subscribe(f=>{if(!u)for(let p of f){if(p[0]!==I)continue;let c=p[1],v=wt(o,c);o=c,v.events.length!==0&&a.emit(v)}}),h=ae(a);return{node:a,dispose(){u=!0,l(),d.dispose(),a.down([[W,"describe-diff disposed"]]),h()}}}_explainReactive(e,t,n){let s=0,o=X(s,{name:"explain_version"}),i=this.observe({timeline:!0,structured:!0}),a=!1,d=!1,u=()=>{a||d||(a=!0,Ne(()=>{a=!1,!d&&(s+=1,o.emit(s))}))},l=i.onEvent(_=>{let T=_.type;T!=="data"&&T!=="error"&&T!=="complete"&&T!=="teardown"||u()}),h=[];e!=null&&we(e)&&h.push(e),t!=null&&we(t)&&h.push(t),n?.maxDepth!=null&&we(n.maxDepth)&&h.push(n.maxDepth),n?.findCycle!=null&&we(n.findCycle)&&h.push(n.findCycle);let f=()=>{for(let _ of h)if(_.cache===void 0)return!1;return!0},p=()=>{let _=he(e),T=he(t);return{from:_,to:T,found:!1,reason:"pending",steps:[],text:"(awaiting reactive args)",toJSON:()=>({from:_,to:T,found:!1,reason:"pending",steps:[]})}},c;try{c=q([o],()=>{if(!f())return p();let _=he(e),T=he(t),x={...n?.maxDepth!==void 0?{maxDepth:pn(n.maxDepth)}:{},...n?.findCycle!==void 0?{findCycle:hn(n.findCycle)}:{}};return this._explainStatic(_,T,x)},{name:n?.name??"explain",describeKind:"derived",meta:{domain:"audit",kind:"explain_path",from:he(e),to:he(t)},equals:(_,T)=>_.found===T.found&&_.reason===T.reason&&_.steps.length===T.steps.length&&hr(_.steps,T.steps)})}catch(_){throw l(),i.dispose(),_}let v=ae(c),g=[],k=_=>{let T;return T=_.subscribe(x=>{let N=!1,S=!1;for(let m of x){let y=m[0];y===I?N=!0:(y===Y||y===z||y===W)&&(S=!0)}(N||S)&&u(),S&&T&&(T(),T=void 0)}),()=>{T&&(T(),T=void 0)}};for(let _ of h)g.push(k(_));return{node:c,dispose(){d=!0,l();for(let _ of g)_?.();g.length=0,i.dispose(),v()}}}_pathsMatching(e){let t=Ze(e),n=[];return this._collectObserveTargets("",n),n.map(([s])=>s).filter(s=>t.test(s))}_collectObserveTargets(e,t){for(let n of[...this._mounts.keys()].sort()){let s=e===""?n:`${e}${P}${n}`;this._mounts.get(n)._collectObserveTargets(s,t)}for(let n of[...this._nodes.keys()].sort()){let s=this._nodes.get(n),o=e===""?n:`${e}${P}${n}`;t.push([o,s]),this._appendMetaObserveTargets(o,s,t)}}_appendMetaObserveTargets(e,t,n){for(let s of Object.keys(t.meta).sort()){let o=t.meta[s],i=`${e}${P}${de}${P}${s}`;n.push([i,o]),this._appendMetaObserveTargets(i,o,n)}}observe(e,t){let n=typeof e=="string",o=mn(n?t:e);if(o.reactive===!0)return this._observeReactive(n?e:void 0,o);let i=o.structured===!0||o.timeline===!0||o.causal===!0||o.derived===!0||o.detail==="minimal"||o.detail==="full"||o.format!=null,a=o.actor;if(n){let l=e,h=this.resolve(l);if(a!=null&&!h.allowsObserve(a))throw new re({actor:a,action:"observe",nodeName:l});return i?this._buildStructuredObserver([[l,h]],o,"one"):{subscribe(f){return h.subscribe(f)},up(f){try{h.up?.(f)}catch(p){if(p instanceof re)return;throw p}}}}let d=[];this._collectObserveTargets("",d),d.sort((l,h)=>l[0]<h[0]?-1:l[0]>h[0]?1:0);let u=a==null?d:d.filter(([,l])=>l.allowsObserve(a));return i?this._buildStructuredObserver(u,o,"all"):{subscribe:l=>{let h=u.map(([f,p])=>p.subscribe(c=>{l(f,c)}));return()=>{for(let f of h)f()}},up:(l,h)=>{try{this.resolve(l).up?.(h)}catch(f){if(f instanceof re)return;throw f}}}}_observeReactive(e,t){let n=t.tiers,s=n!=null?new Set(n):null,o=t.reactiveName??"observe";return ze(i=>{let a=[],d=!1,u=!1,l=()=>{if(a.length===0||u)return;let v={events:a.slice(),flushedAt_ns:K()};a.length=0,i.emit(v)},h={...t,reactive:!1,structured:!0,timeline:!0},f=e!=null?this.observe(e,h):this.observe(h),p=v=>{u||(a.push(v),!d&&(d=!0,Ne(()=>{d=!1,l()})))};for(let v of f.events)p(v);let c=f.onEvent(p);return()=>{u=!0,c(),f.dispose()}},{name:o,meta:{domain:"audit",kind:"observe-reactive"}})}_buildStructuredObserver(e,t,n){let s=n==="one"?e[0]?.[0]:void 0,o=i=>{if(n==="one"&&s!=null){let l=this.resolve(s);return this._buildStructuredObserver([[s,l]],i,"one")}let a=[];this._collectObserveTargets("",a),a.sort((l,h)=>l[0]<h[0]?-1:l[0]>h[0]?1:0);let d=i.actor,u=d==null?a:a.filter(([,l])=>l.allowsObserve(d));return this._buildStructuredObserver(u,i,"all")};return this._createObserveResult(e,t,o)}_createObserveResult(e,t,n){let s=t.timeline===!0,o=t.causal===!0,i=t.derived===!0,a=t.detail==="minimal",d=this.config.inspectorEnabled,u=(o||i)&&d,l=t.maxEvents,h=l!=null&&l>0?new Pe(l):null,f=[],p=new Set,c=t.tiers!=null?new Set(t.tiers):null,v={},g=new Set,k=0,_=0,T=0,x=0,N=0,S=0,m=!1,y=!1,b=0,R=new Map,w=new Map,M=new Map,E=A=>{if(!(c!=null&&!c.has(A.type))){h?h.push(A):f.push(A);for(let V of p)V(A)}},O=A=>c==null||c.has(A),C=()=>s?{timestamp_ns:K(),in_batch:Be(),batch_id:b}:{},D=(A,V)=>{if(!(!u||!(A instanceof L)))return A._setInspectorHook(te=>{if(te.kind==="dep_message")R.set(A,te.depIndex);else if(te.kind==="run"){let De=te.batchData.map((G,Z)=>G!=null&&G.length>0?G.at(-1):te.prevData[Z]);w.set(A,De);let ne=te.batchData.map(G=>G!=null?[...G]:void 0);M.set(A,ne),i&&E({type:"derived",path:V,dep_values:De,dep_batches:ne,...C()})}})},$=A=>{let V=R.get(A),te=w.get(A);if(!o||te==null)return{};let ne=(V!=null&&V>=0&&A instanceof L?A._deps[V]:void 0)?.node,G=ne?.v,Z=M.get(A);return{trigger_dep_index:V,trigger_dep_name:ne?.name,...G!=null?{trigger_version:{id:G.id,version:G.version}}:{},dep_values:[...te],...Z!=null?{dep_batches:Z}:{}}},F=[],B=[];for(let[A,V]of e){let te=D(V,A);te&&F.push(te),B.push(V.subscribe(De=>{b++;for(let ne of De){let G=ne[0],Z=C();if(G===I){v[A]=ne[1];let rt=V instanceof L?V.lastMutation?.actor??xe:xe;E({type:"data",path:A,data:ne[1],actor:rt,...Z,...$(V)})}else if(a)G===U?O("dirty")&&k++:G===Q?O("resolved")&&_++:G===ie?O("invalidate")&&T++:G===ce?O("pause")&&x++:G===fe?O("resume")&&N++:G===W?O("teardown")&&S++:G===Y&&!g.has(A)?O("complete")&&(m=!0):G===z&&O("error")&&(y=!0,g.add(A));else if(G===U)O("dirty")&&k++,E({type:"dirty",path:A,...Z});else if(G===Q)O("resolved")&&_++,E({type:"resolved",path:A,...Z,...$(V)});else if(G===ie)O("invalidate")&&T++,E({type:"invalidate",path:A,...Z});else if(G===ce)O("pause")&&x++,E({type:"pause",path:A,lockId:ne[1],...Z});else if(G===fe)O("resume")&&N++,E({type:"resume",path:A,lockId:ne[1],...Z});else if(G===Y)O("complete")&&!g.has(A)&&(m=!0),E({type:"complete",path:A,...Z});else if(G===z){O("error")&&(y=!0,g.add(A));let rt=V instanceof L?V.lastMutation?.actor??xe:xe;E({type:"error",path:A,data:ne[1],actor:rt,...Z})}else G===W&&(O("teardown")&&S++,E({type:"teardown",path:A,...Z}))}}))}let oe=!1,ge=()=>{if(!oe){oe=!0;for(let A of B)A();for(let A of F)A();for(let A of ue)A({value:void 0,done:!0});ue.length=0}},J=[],ue=[];p.add(A=>{let V=ue.shift();V?V({value:A,done:!1}):J.push(A)});let Ot={get values(){return v},get dirtyCount(){return k},get resolvedCount(){return _},get invalidateCount(){return T},get pauseCount(){return x},get resumeCount(){return N},get teardownCount(){return S},get events(){return h?h.toArray():[...f]},get anyCompletedCleanly(){return m},get anyErrored(){return y},get completedWithoutErrors(){return m&&!y},onEvent(A){return p.add(A),()=>p.delete(A)},dispose:ge,expand(A){ge();let V={...t};return typeof A=="string"?V.detail=A:Object.assign(V,A),n(mn(V))},[Symbol.asyncIterator](){return{next(){return J.length>0?Promise.resolve({value:J.shift(),done:!1}):oe?Promise.resolve({value:void 0,done:!0}):new Promise(A=>ue.push(A))},return(){return ge(),Promise.resolve({value:void 0,done:!0})}}}};return t.format!=null&&this._attachFormatLogger(Ot,t),Ot}_attachFormatLogger(e,t){let n=t.format;if(n==null)return;let s=t.logger??(c=>console.log(c)),o=t.includeTypes?new Set(t.includeTypes):null,i=t.excludeTypes?new Set(t.excludeTypes):null,a=o==null&&i==null?()=>!0:c=>(o==null||o.has(c))&&(i==null||!i.has(c)),d=ur(t.theme),u=n==="stage-log"?K():0,l=c=>c==null?"":t.stageLabels?.[c]??c,h=(c,v)=>c.length>v?`${c.slice(0,v-1)}\u2026`:c,f=c=>c.type==="data"||c.type==="error"?h(xt(c.data),120):"",p=c=>{if(n==="stage-log"){let m=(K()-u)/1e9,y=l(c.path).padEnd(9);if(c.type==="data"){let b=f(c);return`[${m.toFixed(3)}s] ${y} \u2190${b?` ${b}`:""}`}if(c.type==="error"){let b=f(c);return`[${m.toFixed(3)}s] ${y} \u2717${b?` ${b}`:""}`}return c.type==="complete"?`[${m.toFixed(3)}s] ${y} \u25A0 complete`:`[${m.toFixed(3)}s] ${y} ${c.type}`}if(n==="json")try{return JSON.stringify(c)}catch{return JSON.stringify({type:c.type,path:c.path,data:"[unserializable]"})}let v=d[c.type]??"",g=c.path?`${d.path}${c.path}${d.reset} `:"",k=c.type==="data"||c.type==="error",_=c.type==="pause"||c.type==="resume",T=k?` ${xt(c.data)}`:_?` ${xt(c.lockId)}`:"",x=c.type==="data"||c.type==="resolved"||c.type==="derived"?c:void 0,N=x?.trigger_dep_name!=null?` <- ${x.trigger_dep_name}`:x?.trigger_dep_index!=null?` <- #${x.trigger_dep_index}`:"",S=c.in_batch?" [batch]":"";return`${g}${v}${c.type.toUpperCase()}${d.reset}${T}${N}${S}`};e.onEvent(c=>{a(c.type)&&s(p(c),c)})}addDisposer(e){return this._disposers.add(e),()=>{this._disposers.delete(e)}}destroy(){fn(this._disposers,this.name),this.signal([[W]],{internal:!0}),fn(this._storageDisposers,this.name);for(let e of[...this._mounts.values()])e._parent=void 0,e._destroyClearOnly();this._mounts.clear(),this._nodes.clear(),this._parent=void 0,this._destroyed=!0}get destroyed(){return this._destroyed}_destroyClearOnly(){for(let e of[...this._mounts.values()])e._parent=void 0,e._destroyClearOnly();this._mounts.clear(),this._nodes.clear(),this._parent=void 0,this._destroyed=!0}snapshot(e){let{expand:t,...n}=this.describe({detail:"full"}),s={};for(let a of Object.keys(n.nodes).sort()){let{lastMutation:d,guard:u,...l}=n.nodes[a];s[a]=l}let o=[...n.subgraphs].sort(),i={...n,version:1,nodes:s,subgraphs:o};if(e?.format==null)return i;if(e.format==="json-string")return JSON.stringify(i);if(e.format==="bytes"){if(e.codec==null)throw new Error("snapshot({format: 'bytes'}) requires a `codec` name");let a=this.config.lookupCodec(e.codec);if(a==null)throw new Error(`snapshot: codec "${e.codec}" is not registered on this graph's config. Call config.registerCodec(...) before creating nodes.`);return Mt(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}=At(e,n);return s.decode(i,o)}restore(e,t){if(gn(e),e.name!==this.name)throw new Error(`Graph "${this.name}": restore snapshot name "${e.name}" does not match this graph`);let n=t?.only==null?null:(Array.isArray(t.only)?t.only:[t.only]).map(o=>Ze(o)),s=t?.includeProducers===!0;for(let o of Object.keys(e.nodes).sort()){if(n!==null&&!n.some(a=>a.test(o)))continue;let i=e.nodes[o];if(i!==void 0){if(!("value"in i)||i.value===void 0){"value"in i&&i.value===void 0&&t?.onError?.(o,new Error(`restore: slice.value is undefined for "${o}" (undefined is the global SENTINEL; not valid DATA)`));continue}if(!(i.type==="derived"||i.type==="effect")&&!(i.type==="producer"&&!s)){if(i.v!=null){let d=this.tryResolve(o)?.v;if(d!=null&&d.id===i.v.id&&d.version===i.v.version)continue}try{this.set(o,i.value)}catch(a){t?.onError?.(o,a)}}}}}static fromSnapshot(e,t){gn(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 p of[...e.subgraphs].sort((c,v)=>{let g=c.split(P).length,k=v.split(P).length;return g!==k?g-k:c<v?-1:c>v?1:0})){let c=p.split(P),v=o;for(let g of c)v._mounts.has(g)||v.mount(g,new r(g)),v=v._mounts.get(g)}let i=s?Object.entries(s).map(([p,c])=>({re:Ze(p),factory:c})):[],a=p=>{for(let c of i)if(c.re.test(p))return c.factory},d=p=>{let c=p.split(P),v=c.pop();if(v==null||v.length===0)throw new Error(`invalid snapshot path "${p}"`);let g=o;for(let k of c){let _=g._mounts.get(k);if(!_)throw new Error(`unknown mount "${k}" in path "${p}"`);g=_}return[g,v]},u=Object.entries(e.nodes).filter(([p])=>!p.includes(`${P}${de}${P}`)).sort((p,c)=>p[0]<c[0]?-1:p[0]>c[0]?1:0),l=new Map(u),h=new Map,f=!0;for(;l.size>0&&f;){f=!1;for(let[p,c]of[...l.entries()]){let v=c?.deps??[];if(!v.every(N=>h.has(N)))continue;let[g,k]=d(p),_={...c?.meta??{}},T=a(p),x;if(c?.type==="state")x=X(c.value,{meta:_});else{if(T==null)continue;x=T(k,{path:p,type:c.type,value:c.value,meta:_,deps:v,resolvedDeps:v.map(N=>h.get(N))})}g.add(x,{name:k}),h.set(p,x),l.delete(p),f=!0}}if(l.size>0){let p=[...l.keys()].sort().join(", ");throw new Error(`Graph.fromSnapshot could not reconstruct nodes without build callback: ${p}. Pass matching factories via fromSnapshot(data, { factories: { pattern: factoryFn } }).`)}return o.restore(e),o}toJSON(){return this.snapshot()}attachSnapshotStorage(e,t={}){let n=e.map(u=>({tier:u,debounceMs:Math.max(0,u.debounceMs??0),compactEvery:Math.max(1,u.compactEvery??10),timer:void 0,seq:0,lastSnapshot:void 0,lastFingerprint:"",disposed:!1,savePending:void 0}));t.autoRestore===!0&&this._cascadeRestore(e,t.onError);let s=(u,l)=>{if(u.disposed)return;let h=sr(l.nodes);if(u.lastSnapshot!=null&&h!==""&&h===u.lastFingerprint)return;let f=u.seq+1,p=le(),g=u.lastSnapshot==null||f%u.compactEvery===0?{name:this.name,mode:"full",snapshot:l,seq:f,timestamp_ns:p,format_version:Ce}:{name:this.name,mode:"diff",diff:pr(u.lastSnapshot,l),seq:f,timestamp_ns:p,format_version:Ce};if(u.tier.filter&&!u.tier.filter(g))return;let k;try{k=u.tier.save(g)}catch(_){t.onError?.(_,u.tier);return}if(k&&typeof k.then=="function"){let x=(u.savePending??Promise.resolve()).then(()=>k,()=>k).then(()=>{u.disposed||(u.seq=f,u.lastSnapshot=l,u.lastFingerprint=h)},N=>{t.onError?.(N,u.tier)});u.savePending=x.finally(()=>{u.savePending===x&&(u.savePending=void 0)})}else u.seq=f,u.lastSnapshot=l,u.lastFingerprint=h},o=(u,l)=>{try{s(u,l)}catch(h){t.onError?.(h,u.tier)}},i=(u,l)=>{if(!l.some(c=>{let v=this.config.messageTier(c[0]);return v>=3&&v<5}))return;if(t.filter){let c=this.tryResolve(u);if(c==null)return;let v=vt(c,bt("standard"));if(!t.filter(u,v))return}let f,p=()=>(f==null&&(f=this.snapshot()),f);for(let c of n)c.disposed||(c.debounceMs===0?o(c,p()):(c.timer==null&&(c.timer=new We),c.timer.start(c.debounceMs,()=>{c.disposed||o(c,this.snapshot())})))},a;if(t.paths!=null){let l=(typeof t.paths=="string"?this._pathsMatching(t.paths):t.paths).map(h=>{let f=this.tryResolve(h);return f==null?()=>{}:f.subscribe(p=>i(h,p))});a=()=>{for(let h of l)h()}}else a=this.observe().subscribe((u,l)=>i(u,l));let d=()=>{a();for(let u of n)u.disposed=!0,u.timer?.cancel();this._storageDisposers.delete(d)};return this._storageDisposers.add(d),{dispose:d}}async _cascadeRestore(e,t){for(let n of e){let s;try{s=await n.load?.()}catch(i){t?.(i,n);continue}if(s==null||typeof s!="object"||Array.isArray(s))continue;let o=s;try{if(o.mode==="full"&&o.snapshot!=null)return this.restore(o.snapshot),!0;if(o.version===Ce&&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===Ce&&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: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(_=>!n.has(_)).sort(),i=[...n].filter(_=>!s.has(_)).sort(),a=[],d=[];for(let _ of n){if(!s.has(_))continue;let T=e.nodes[_],x=t.nodes[_],N=T.v,S=x.v;N!=null&&S!=null&&N.id===S.id&&N.version!==S.version&&d.push({path:_,id:N.id,from:N.version,to:S.version});let m=N!=null&&S!=null&&N.id===S.id&&N.version===S.version;for(let y of["type","status","sentinel"]){let b=T[y],R=x[y];b!==R&&a.push({path:_,field:y,from:b,to:R})}if(!m)for(let y of["value","meta"]){let b=T[y],R=x[y];or(b,R)||a.push({path:_,field:y,from:b,to:R})}}let u=_=>`${_.from} ${_.to}`,l=new Set(e.edges.map(u)),h=new Set(t.edges.map(u)),f=t.edges.filter(_=>!l.has(u(_))),p=e.edges.filter(_=>!h.has(u(_))),c=new Set(e.subgraphs),v=new Set(t.subgraphs),g=[...v].filter(_=>!c.has(_)).sort(),k=[...c].filter(_=>!v.has(_)).sort();return{nodesAdded:o,nodesRemoved:i,nodesChanged:a,versionChanges:d,edgesAdded:f,edgesRemoved:p,subgraphsAdded:g,subgraphsRemoved:k}}}});var xr={};Cn(xr,{collection:()=>_r,cosineSimilarity:()=>On,knowledgeGraph:()=>Tr,vectorIndex:()=>wr});module.exports=Gn(xr);me();ve();_e();Wt();me();Ve();pe();_e();$e();pe();ve();_e();var kt=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 Le(r){return r.subscribe(()=>{})}var gr=64;function wn(r,e={}){let{name:t,maxSize:n,versioning:s,guard:o,backend:i}=e,a=i??new kt(r,n),d=X(a.toArray(),{name:t,describeKind:"state",equals:(m,y)=>m===y,...s!=null?{versioning:s}:{},...o!=null?{guard:o}:{}});function u(){let m=a.toArray();Ee(()=>{d.down([[U]],{internal:!0}),d.down([[I,m]],{internal:!0})})}let l=new Map,h=new Map,f=new Map;function p(m,y){return`${m}:${y===void 0?"END":y}`}function c(m){if(m.size<gr)return;let y=m.keys().next();if(y.done)return;let b=m.get(y.value);b!==void 0&&b.dispose(),m.delete(y.value)}function v(m){let y=a.version;try{return m()}finally{a.version!==y&&u()}}function g(m){if(!Number.isInteger(m)||m<0)throw new RangeError(`tail: n must be a non-negative integer (got ${m})`);let y=l.get(m);if(y!==void 0)return l.delete(m),l.set(m,y),y.node;c(l);let b=q([d],([w])=>{let M=w;return m===0||M.length===0?[]:M.slice(Math.max(0,M.length-m))},{initial:a.tail(m),describeKind:"derived"}),R=Le(b);return l.set(m,{node:b,dispose:R}),b}function k(m,y){if(!Number.isInteger(m)||m<0)throw new RangeError(`slice: start must be a non-negative integer (got ${m})`);if(y!==void 0&&(!Number.isInteger(y)||y<0))throw new RangeError(`slice: stop must be a non-negative integer or undefined (got ${y})`);let b=p(m,y),R=h.get(b);if(R!==void 0)return h.delete(b),h.set(b,R),R.node;c(h);let w=q([d],([E])=>{let O=E;return y===void 0?O.slice(m):O.slice(m,y)},{initial:a.slice(m,y),describeKind:"derived"}),M=Le(w);return h.set(b,{node:w,dispose:M}),w}function _(m){let y=f.get(m);if(y!==void 0)return y.node;let b=q([d,m],([w,M])=>{let E=w,O=Math.max(0,Math.trunc(M??0));return E.slice(O)},{initial:[],describeKind:"derived"}),R=Le(b);return f.set(m,{node:b,dispose:R}),b}let T,x;function N(){T===void 0&&(T=Ae([d],(m,y,b)=>{let R=m[0],M=R!=null&&R.length>0?R.at(-1):b.prevData[0];if(M==null||M.length===0){y.down([[Q]]);return}y.emit(M[M.length-1])},{name:t!=null?`${t}::lastValue`:"lastValue",describeKind:"derived",initial:a.size===0?void 0:a.at(a.size-1)}),x=q([d],([m])=>m.length>0,{name:t!=null?`${t}::hasLatest`:"hasLatest",describeKind:"derived",initial:a.size>0}),Le(T),Le(x))}let S={entries:d,get size(){return a.size},at(m){return a.at(m)},append(m){v(()=>a.append(m))},appendMany(m){m.length!==0&&v(()=>a.appendMany(m))},clear(){v(()=>a.clear())},trimHead(m){v(()=>a.trimHead(m))},withLatest(){return N(),d},get lastValue(){return N(),T},get hasLatest(){return N(),x},view(m){switch(m.kind){case"tail":return g(m.n);case"slice":return k(m.start,m.stop);case"fromCursor":return _(m.cursor)}},attach(m){let y=m.subscribe(b=>{for(let R of b)R[0]===I&&S.append(R[1])});return()=>y()},attachStorage(m){if(m.length===0)return()=>{};let y=new Map;for(let R of m)y.set(R,a.size);(async()=>{for(let R of m)if(typeof R.loadEntries=="function")try{let w=await Promise.resolve(R.loadEntries());w.entries.length>0&&a.size===0&&(a.restore(w.entries),y.set(R,w.entries.length),u());break}catch{}})();let b=d.subscribe(R=>{for(let w of R){if(w[0]!==I)continue;let M=w[1];for(let E of m){let O=y.get(E)??0;if(M.length<O){try{let D=E.appendEntries(M);D instanceof Promise&&D.catch(()=>{})}catch{}y.set(E,M.length);continue}if(M.length===O)continue;let C=M.slice(O);y.set(E,M.length);try{let D=E.appendEntries(C);D instanceof Promise&&D.catch(()=>{})}catch{}}}});return()=>b()},disposeAllViews(){for(let m of l.values())m.dispose();l.clear();for(let m of h.values())m.dispose();h.clear();for(let m of f.values())m.dispose();f.clear()},dispose(){for(let m of l.values())m.dispose();l.clear();for(let m of h.values())m.dispose();h.clear();for(let m of f.values())m.dispose();f.clear()}};return S}var mr=Lt((r,e)=>{r("observe"),r("signal"),e("write")});function Qe(r){let e=wn([],{name:r.name,maxSize:r.retainedLimit??1024,guard:r.guard??mr,...r.versioning!=null?{versioning:r.versioning}:{}});return e.withLatest(),r.graph&&r.graph.add(e.entries,{name:r.name}),e}function xn(r){if(r===null||typeof r!="object"||Object.isFrozen(r))return r;for(let e of Object.keys(r))xn(r[e]);return Object.freeze(r)}function et(r){let e=r.cache,n=(typeof e=="number"&&Number.isFinite(e)?e:0)+1;return r.down([[U],[I,n]]),n}function Tn(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 ee(r,e){let t=e.freeze??!0;return function(...s){let o=t?s.map(xn):s,i=le(),a=e.seq?et(e.seq):void 0;try{let d=r(...o);return e.audit&&e.onSuccess&&Tn(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;Tn(e.audit,e.onFailure,o,d,{t_ns:i,seq:a,errorType:u},e.handlerVersion)}throw d}}}function tt(r,e,t=0){let n=X(t,{name:e,describeKind:"state"});return r.add(n,{name:e}),n}$e();me();pe();_e();var Nt=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 Fe(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 Nt({maxSize:t,defaultTtl:n}),d=X(a.toMap(),{name:e,describeKind:"state",equals:(f,p)=>f===p,...s!=null?{versioning:s}:{}});function u(){let f=a.toMap();Ee(()=>{d.down([[U]]),d.down([[I,f]])})}function l(){if(!i)return;let f=a.toMap(),p=i.archiveThreshold,c=i.maxSize,v=[];for(let[k,_]of f)v.push({key:k,value:_,score:i.score(k,_)});v.sort((k,_)=>k.score-_.score);let g=new Set;if(p!==void 0)for(let k of v)if(k.score<p)g.add(k.key);else break;if(c!==void 0&&v.length-g.size>c)for(let k of v){if(v.length-g.size<=c)break;g.has(k.key)||g.add(k.key)}if(g.size!==0)for(let k of v)g.has(k.key)&&(i.onArchive?.(k.key,k.value,k.score),a.delete(k.key))}function h(f,p="mutation"){let c=a.version;try{return f()}finally{a.version!==c&&(p==="mutation"&&l(),u())}}return{entries:d,has(f){return h(()=>a.has(f),"read")},get(f){return h(()=>a.get(f),"read")},set(f,p,c){h(()=>a.set(f,p,c?.ttl))},setMany(f,p){h(()=>a.setMany(f,p?.ttl))},delete(f){h(()=>a.delete(f))},deleteMany(f){h(()=>a.deleteMany(f))},clear(){h(()=>a.clear())},pruneExpired(){h(()=>a.pruneExpired())},get size(){return a.size},dispose(){}}}Tt();var Fs=Math.LN2/604800;function Et(r,e,t,n=0){if(!Number.isFinite(r))return n;if(!Number.isFinite(e)||e<=0||!Number.isFinite(t)||t<=0)return Math.max(n,r);let s=r*Math.exp(-t*e);return Math.max(n,s)}_n();var yr=1e9;function se(r,e){return Ut("memory",r,e)}function Ke(r,e){return r instanceof L?r:X(r,e?{name:e}:void 0)}function Rn(r,e){return(r-e)/yr}function On(r,e){let t=Math.max(r.length,e.length),n=0,s=0,o=0;for(let a=0;a<t;a+=1){let d=r[a]??0,u=e[a]??0;n+=d*u,s+=d*d,o+=u*u}if(s===0||o===0)return 0;let i=n/Math.sqrt(s*o);return Number.isFinite(i)?i:0}function br(r,e){if(r===e)return!0;if(r==null||e==null||r.length!==e.length)return!1;for(let t=0;t<r.length;t+=1){let n=r[t],s=e[t];if(n.id!==s.id||n.score!==s.score||n.meta!==s.meta)return!1}return!0}function vr(r,e){if(r===e)return!0;if(r==null||e==null||r.length!==e.length)return!1;for(let t=0;t<r.length;t+=1){let n=r[t],s=e[t];if(n.id!==s.id||n.score!==s.score||n.lastAccessNs!==s.lastAccessNs||n.value!==s.value)return!1}return!0}function _r(r,e={}){let t=e.maxSize,n=e.ranked??!0,s=n?e.decayRate??0:0,o=e.minScore??0;if(t!==void 0&&t<1)throw new RangeError("collection: maxSize must be >= 1");let i=()=>n?1:0,a=e.score??i,d=n&&a instanceof L?a:void 0,u=()=>d?d.cache??i:a,l=new Te(r),f=Fe({name:"items",...t!==void 0?{retention:{score:(E,O)=>n?Et(O.baseScore,Rn(K(),O.lastAccessNs),s,o):O.lastAccessNs,maxSize:t}}:{}});l.add(f.entries,{name:"items"});let p;if(n&&s>0){let E=e.refreshIntervalMs??Math.max(1,1e3*Math.LN2/(10*s)),O=Zt(E,{period:E});p=q([O],()=>K(),{name:"refresh_tick_ns",describeKind:"derived",initial:K(),meta:se("clock")}),l.add(p,{name:"refresh_tick_ns"})}let c;if(n){let E=[f.entries];p&&E.push(p),d&&E.push(d),c=q(E,O=>{let C=O[0],D;if(p){let F=O[1];D=typeof F=="number"?F:K()}else D=K();if(!C||C.size===0)return[];let $=[];for(let F of C.values())$.push({...F,score:Et(F.baseScore,Rn(D,F.lastAccessNs),s,o)});return $.sort((F,B)=>B.score-F.score||B.lastAccessNs-F.lastAccessNs),$},{name:"ranked",describeKind:"derived",equals:vr,meta:se("ranked")}),l.add(c,{name:"ranked"})}else c=X([],{name:"ranked",describeKind:"state",meta:se("ranked_disabled")}),l.add(c,{name:"ranked"});let v=q([f.entries],([E])=>(E??new Map).size,{name:"size",describeKind:"derived",initial:0,meta:se("size")});l.add(v,{name:"size"}),l.addDisposer(ae(v));let g=Qe({name:"events",retainedLimit:1024,graph:l}),k=tt(l,"seq",0),_=(E,O,C)=>{let D=K(),$=f.get(E),F=C?.score??u()(O);f.set(E,{id:E,value:O,baseScore:F,createdAtNs:$?.createdAtNs??D,lastAccessNs:D})},T=E=>{f.has(E)&&f.delete(E)},x=()=>{f.size!==0&&f.clear()},N=()=>{if(!n)return;let E=u(),O=f.entries.cache;if(!O||O.size===0)return;let C=[];for(let D of O.values())C.push([D.id,{...D,baseScore:E(D.value)}]);f.setMany(C)},S=ee(_,{audit:g,seq:k,onSuccess:([E],O,C)=>({action:"upsert",id:E,t_ns:C.t_ns,seq:C.seq})}),m=ee(T,{audit:g,seq:k,onSuccess:([E],O,C)=>({action:"remove",id:E,t_ns:C.t_ns,seq:C.seq})}),y=ee(x,{audit:g,seq:k,onSuccess:(E,O,C)=>({action:"clear",t_ns:C.t_ns,seq:C.seq})}),b=ee(N,{audit:g,seq:k,onSuccess:(E,O,C)=>({action:"rescore",t_ns:C.t_ns,seq:C.seq})});function R(E){let O=Ke(E,"id");return q([f.entries,O],([C,D])=>C?.get(D),{describeKind:"derived",meta:se("collection_item")})}function w(E){let O=Ke(E,"id");return q([f.entries,O],([C,D])=>C?.has(D)??!1,{describeKind:"derived",meta:se("collection_has")})}return Object.assign(l,{events:g,items:f.entries,ranked:c,size:v,upsert:S,remove:m,clear:y,rescore:b,itemNode:R,hasNode:w})}function wr(r={}){let e=r.backend??"flat",t=r.dimension,n=r.strictDimension??!0,s=r.maxSize,o=r.retentionScore,i;if(e==="hnsw"&&(i=r.hnswFactory?.(),!i))throw new Error('vectorIndex backend "hnsw" requires an optional dependency adapter; install your HNSW package and provide `hnswFactory`.');let a=new Te(r.name??"vector_index"),d;function u(b){if(t!==void 0){if(b.length!==t)throw new RangeError(`vector dimension mismatch: expected ${t}, got ${b.length}`);return}if(n){if(d===void 0){d=b.length;return}if(b.length!==d)throw new RangeError(`vector dimension mismatch: inferred ${d} from first upsert, got ${b.length}. Pass \`strictDimension: false\` to opt into zero-pad behavior, or set an explicit \`dimension\`.`)}}let l=o??(b=>b.upsertedAtNs),h=!1,f=Qe({name:"events",retainedLimit:1024,graph:a}),p=tt(a,"seq",0),c=Fe({name:"entries",...s!==void 0?{retention:{score:(b,R)=>l(R),maxSize:s,onArchive:b=>{h||(e==="hnsw"&&i.remove(b),f.append({action:"evict",id:b,t_ns:le(),seq:et(p)}))}}}:{}});if(a.add(c.entries,{name:"entries"}),a.addDisposer(ae(c.entries)),i?.dispose){let b=i.dispose.bind(i);a.addDisposer(()=>b())}let v=(b,R,w)=>{u(R),e==="hnsw"&&i.upsert(b,R,w);let M=(()=>{if(w!==void 0)return w===null||typeof w!="object"?w:Array.isArray(w)?[...w]:{...w}})(),E={id:b,vector:[...R],...M!==void 0?{meta:M}:{},upsertedAtNs:K()};c.set(b,E)},g=b=>{c.has(b)&&(e==="hnsw"&&i.remove(b),c.delete(b))},k=()=>{if(c.size!==0){h=!0;try{c.clear(),e==="hnsw"&&i.clear()}finally{h=!1}d=void 0}},_=()=>{if(e!=="hnsw")return;let b=c.entries.cache;if(b){i.clear();for(let R of b.values())i.upsert(R.id,R.vector,R.meta)}},T=ee(v,{audit:f,freeze:!1,seq:p,onSuccess:([b],R,w)=>({action:"upsert",id:b,t_ns:w.t_ns,seq:w.seq})}),x=ee(g,{audit:f,seq:p,onSuccess:([b],R,w)=>({action:"remove",id:b,t_ns:w.t_ns,seq:w.seq})}),N=ee(k,{audit:f,seq:p,onSuccess:(b,R,w)=>({action:"clear",t_ns:w.t_ns,seq:w.seq})}),S=ee(_,{audit:f,seq:p,onSuccess:(b,R,w)=>({action:"reindex",t_ns:w.t_ns,seq:w.seq})});function m(b,R=5){let w=Ke(R,"k");return q([c.entries,b,w],M=>{let E=M[0],O=M[1],C=M[2],D=Number.isFinite(C)?Math.max(0,Math.floor(C)):0;if(!E||E.size===0||D<=0)return[];if(O==null||O.length===0)return[];let $=t??(n?d:void 0);return $!==void 0&&O.length!==$?[]:e==="hnsw"?[...i.search(O,D)]:[...E.values()].map(B=>({id:B.id,score:On(O,B.vector),...B.meta!==void 0?{meta:B.meta}:{}})).sort((B,oe)=>oe.score-B.score).slice(0,D)},{describeKind:"derived",equals:(M,E)=>br(M,E),meta:se("vector_search")})}return Object.assign(a,{backend:e,events:f,entries:c.entries,upsert:T,remove:x,clear:N,reindex:S,searchNode:m})}var kn="\0";function nt(r,e,t){return`${r}${kn}${e}${kn}${t}`}function Nn(r,e){if(!r||r.size===0)return new Map;let t=new Map;for(let s of r.values()){let o=e==="from"?s.from:s.to,i=t.get(o);i||(i=[],t.set(o,i)),i.push(s)}let n=new Map;for(let[s,o]of t)n.set(s,Object.freeze(o));return n}function En(r,e){if(r===e)return!0;if(r==null||e==null||r.size!==e.size)return!1;for(let[t,n]of r){let s=e.get(t);if(!s||n.length!==s.length)return!1;for(let o=0;o<n.length;o+=1){let i=n[o],a=s[o];if(i.from!==a.from||i.to!==a.to||i.relation!==a.relation||i.weight!==a.weight)return!1}}return!0}function Tr(r,e={}){let t=e.orphanGC??"keep";if(e.entitiesMaxSize!==void 0&&e.entitiesMaxSize<1)throw new RangeError("knowledgeGraph: entitiesMaxSize must be >= 1");if(e.edgesMaxSize!==void 0&&e.edgesMaxSize<1)throw new RangeError("knowledgeGraph: edgesMaxSize must be >= 1");let n=new Te(r),s=Fe({name:"entities",...e.entitiesMaxSize!==void 0?{maxSize:e.entitiesMaxSize}:{}}),o=Fe({name:"edges",...e.edgesMaxSize!==void 0?{maxSize:e.edgesMaxSize}:{}});n.add(s.entries,{name:"entities"}),n.add(o.entries,{name:"edges"});let i=q([o.entries],([y])=>Nn(y,"from"),{name:"adjacencyOut",describeKind:"derived",initial:new Map,equals:En,meta:se("adjacency_out")}),a=q([o.entries],([y])=>Nn(y,"to"),{name:"adjacencyIn",describeKind:"derived",initial:new Map,equals:En,meta:se("adjacency_in")});n.add(i,{name:"adjacencyOut"}),n.add(a,{name:"adjacencyIn"}),n.addDisposer(ae(i)),n.addDisposer(ae(a));let d=q([s.entries],([y])=>(y??new Map).size,{name:"entityCount",describeKind:"derived",initial:0,meta:se("entity_count")}),u=q([o.entries],([y])=>(y??new Map).size,{name:"edgeCount",describeKind:"derived",initial:0,meta:se("edge_count")});n.add(d,{name:"entityCount"}),n.add(u,{name:"edgeCount"}),n.addDisposer(ae(d)),n.addDisposer(ae(u));let l=Qe({name:"events",retainedLimit:1024,graph:n}),h=tt(n,"seq",0);function f(y){let b=i.cache,R=a.cache;return(b?.get(y)?.length??0)>0||(R?.get(y)?.length??0)>0}function p(y){if(t==="remove")for(let b of y)s.has(b)&&(f(b)||(s.delete(b),l.append({action:"orphanRemove",id:b,t_ns:le(),seq:et(h)})))}let c=(y,b)=>{s.set(y,b)},v=y=>{let b=o.entries.cache,R=new Set;if(b){let w=[];for(let[M,E]of b)(E.from===y||E.to===y)&&(w.push(M),E.from!==y&&R.add(E.from),E.to!==y&&R.add(E.to));w.length>0&&o.deleteMany(w)}s.has(y)&&s.delete(y),p([...R])},g=(y,b,R,w=1)=>{o.set(nt(y,b,R),{from:y,to:b,relation:R,weight:w})},k=(y,b,R)=>{if(R!==void 0)o.delete(nt(y,b,R));else{let w=o.entries.cache;if(!w)return;let M=[];for(let[E,O]of w)O.from===y&&O.to===b&&M.push(E);M.length>0&&o.deleteMany(M)}p([y,b])},_=ee(c,{audit:l,seq:h,onSuccess:([y],b,R)=>({action:"upsertEntity",id:y,t_ns:R.t_ns,seq:R.seq})}),T=ee(v,{audit:l,seq:h,onSuccess:([y],b,R)=>({action:"removeEntity",id:y,t_ns:R.t_ns,seq:R.seq})}),x=ee(g,{audit:l,seq:h,onSuccess:([y,b,R,w],M,E)=>({action:"link",from:y,to:b,relation:R,weight:w??1,t_ns:E.t_ns,seq:E.seq})}),N=ee(k,{audit:l,seq:h,onSuccess:([y,b,R],w,M)=>({action:"unlink",from:y,to:b,...R!==void 0?{relation:R}:{},t_ns:M.t_ns,seq:M.seq})});function S(y,b){let R=Ke(y,"id"),w=b!==void 0?Ke(b,"relation"):void 0;return q(w?[i,a,R,w]:[i,a,R],E=>{let O=E[0],C=E[1],D=E[2],$=w?E[3]:void 0,F=O.get(D)??[],B=C.get(D)??[],oe=new Set,ge=[];for(let J of F){let ue=nt(J.from,J.to,J.relation);oe.has(ue)||$!==void 0&&J.relation!==$||(oe.add(ue),ge.push(J))}for(let J of B){let ue=nt(J.from,J.to,J.relation);oe.has(ue)||$!==void 0&&J.relation!==$||(oe.add(ue),ge.push(J))}return ge},{describeKind:"derived",equals:(E,O)=>{let C=E,D=O;if(C===D)return!0;if(C==null||D==null||C.length!==D.length)return!1;for(let $=0;$<C.length;$+=1){let F=C[$],B=D[$];if(F.from!==B.from||F.to!==B.to||F.relation!==B.relation||F.weight!==B.weight)return!1}return!0},meta:se("related")})}return Object.assign(n,{events:l,entities:s.entries,edges:o.entries,adjacencyOut:i,adjacencyIn:a,entityCount:d,edgeCount:u,upsertEntity:_,removeEntity:T,link:x,unlink:N,relatedNode:S})}0&&(module.exports={collection,cosineSimilarity,knowledgeGraph,vectorIndex});
@@ -1,8 +1,8 @@
1
- import '../../node-BYInONRr.cjs';
2
- import '../../index-DVDapw2k.cjs';
3
- import '../../reactive-log-_zeEnB9H.cjs';
4
- import '../../graph-E6likq7w.cjs';
5
- export { b as CollectionAuditRecord, c as CollectionEntry, C as CollectionGraph, d as CollectionOptions, e as CollectionScoreFn, H as HnswAdapter, f as KnowledgeEdge, K as KnowledgeGraph, g as KnowledgeGraphAuditRecord, h as KnowledgeGraphOptions, N as NodeOrValue, R as RankedCollectionEntry, j as VectorBackend, k as VectorIndexAuditRecord, a as VectorIndexGraph, l as VectorIndexOptions, m as VectorRecord, V as VectorSearchResult, n as collection, o as cosineSimilarity, p as knowledgeGraph, v as vectorIndex } from '../../index-DktLSZOc.cjs';
1
+ import '../../node-ClS5yC-B.cjs';
2
+ import '../../index-DBIqYS43.cjs';
3
+ import '../../reactive-log-B00laMSQ.cjs';
4
+ import '../../graph-C4SHb3Ly.cjs';
5
+ export { b as CollectionAuditRecord, c as CollectionEntry, C as CollectionGraph, d as CollectionOptions, e as CollectionScoreFn, H as HnswAdapter, f as KnowledgeEdge, K as KnowledgeGraph, g as KnowledgeGraphAuditRecord, h as KnowledgeGraphOptions, N as NodeOrValue, R as RankedCollectionEntry, j as VectorBackend, k as VectorIndexAuditRecord, a as VectorIndexGraph, l as VectorIndexOptions, m as VectorRecord, V as VectorSearchResult, n as collection, o as cosineSimilarity, p as knowledgeGraph, v as vectorIndex } from '../../index-2B7u2pVn.cjs';
6
6
  import '../../extra/storage-tiers.cjs';
7
- import '../../meta-Ct9nqQS5.cjs';
7
+ import '../../meta-vE8bxW1E.cjs';
8
8
  import '../../extra/storage-core.cjs';
@@ -1,8 +1,8 @@
1
- import '../../node-BYInONRr.js';
2
- import '../../index-BQ1fR4li.js';
3
- import '../../reactive-log-BlAsPLl2.js';
4
- import '../../graph-BkIkog4h.js';
5
- export { b as CollectionAuditRecord, c as CollectionEntry, C as CollectionGraph, d as CollectionOptions, e as CollectionScoreFn, H as HnswAdapter, f as KnowledgeEdge, K as KnowledgeGraph, g as KnowledgeGraphAuditRecord, h as KnowledgeGraphOptions, N as NodeOrValue, R as RankedCollectionEntry, j as VectorBackend, k as VectorIndexAuditRecord, a as VectorIndexGraph, l as VectorIndexOptions, m as VectorRecord, V as VectorSearchResult, n as collection, o as cosineSimilarity, p as knowledgeGraph, v as vectorIndex } from '../../index-bXXLSvor.js';
1
+ import '../../node-ClS5yC-B.js';
2
+ import '../../index-DO9XxMzS.js';
3
+ import '../../reactive-log-BezYsbA_.js';
4
+ import '../../graph-7VguS7a4.js';
5
+ export { b as CollectionAuditRecord, c as CollectionEntry, C as CollectionGraph, d as CollectionOptions, e as CollectionScoreFn, H as HnswAdapter, f as KnowledgeEdge, K as KnowledgeGraph, g as KnowledgeGraphAuditRecord, h as KnowledgeGraphOptions, N as NodeOrValue, R as RankedCollectionEntry, j as VectorBackend, k as VectorIndexAuditRecord, a as VectorIndexGraph, l as VectorIndexOptions, m as VectorRecord, V as VectorSearchResult, n as collection, o as cosineSimilarity, p as knowledgeGraph, v as vectorIndex } from '../../index-Bn4zHYLj.js';
6
6
  import '../../extra/storage-tiers.js';
7
- import '../../meta-D8OyedKp.js';
7
+ import '../../meta-BgVAsg9j.js';
8
8
  import '../../extra/storage-core.js';
@@ -1 +1 @@
1
- import{a,b,c,d}from"../../chunk-GI4Q7PNY.js";import"../../chunk-TSOYJ743.js";import"../../chunk-TZQPPQEQ.js";import"../../chunk-VXPLLA4P.js";import"../../chunk-L6NSJVJZ.js";import"../../chunk-TT4C7DXW.js";import"../../chunk-POXANAJ6.js";import"../../chunk-SGS4OJGS.js";import"../../chunk-ESMPEKEV.js";import"../../chunk-L77I47VU.js";import"../../chunk-35JTVPOX.js";import"../../chunk-LYCLF26R.js";import"../../chunk-CK2E7BTU.js";import"../../chunk-QYADASLV.js";export{b as collection,a as cosineSimilarity,d as knowledgeGraph,c as vectorIndex};
1
+ import{a,b,c,d}from"../../chunk-KT5DTRBP.js";import"../../chunk-TSOYJ743.js";import"../../chunk-TZQPPQEQ.js";import"../../chunk-3ZZX7M25.js";import"../../chunk-L6NSJVJZ.js";import"../../chunk-LDQ3IUIP.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{b as collection,a as cosineSimilarity,d as knowledgeGraph,c as vectorIndex};