@graphrefly/graphrefly 0.36.0 → 0.38.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 (249) hide show
  1. package/dist/{chunk-J6TGRQUP.js → chunk-2YFDSYEF.js} +1 -1
  2. package/dist/{chunk-JUJEPZOI.js → chunk-4BDQXBXE.js} +1 -1
  3. package/dist/chunk-5BGFS2XH.js +1 -0
  4. package/dist/chunk-6773HURD.js +1 -0
  5. package/dist/{chunk-AQC53OWG.js → chunk-6KZZ6XQE.js} +1 -1
  6. package/dist/{chunk-5CPPC75H.js → chunk-6VFC334U.js} +1 -1
  7. package/dist/{chunk-KUVDFOJH.js → chunk-7KZZLWZ6.js} +1 -1
  8. package/dist/{chunk-Q7EUZ6NN.js → chunk-B5S7KTGP.js} +1 -1
  9. package/dist/chunk-CMTN3KPT.js +80 -0
  10. package/dist/chunk-DQJLC6YY.js +1 -0
  11. package/dist/chunk-DSOVKKTI.js +1 -0
  12. package/dist/chunk-FAYEMS5M.js +1 -0
  13. package/dist/chunk-FWGIZP3W.js +1 -0
  14. package/dist/{chunk-5Z3AFBN7.js → chunk-G7JN6LCB.js} +1 -1
  15. package/dist/{chunk-PCD2MU7X.js → chunk-IBGE62GZ.js} +1 -1
  16. package/dist/{chunk-MYFR67PY.js → chunk-K5C67OGE.js} +1 -1
  17. package/dist/chunk-KJEAIIIY.js +43 -0
  18. package/dist/chunk-LV3ACS5J.js +1 -0
  19. package/dist/{chunk-7LYIKMW5.js → chunk-NBGPXQSP.js} +1 -1
  20. package/dist/chunk-NN3QPJ6U.js +1 -0
  21. package/dist/{chunk-T6RPUERH.js → chunk-NSAZ6PR6.js} +1 -1
  22. package/dist/{chunk-KCE6WWJE.js → chunk-NV63VQHI.js} +1 -1
  23. package/dist/{chunk-PYEIPRSZ.js → chunk-O245YLM5.js} +1 -1
  24. package/dist/{chunk-K5ZXJPWU.js → chunk-O2BLVQU4.js} +1 -1
  25. package/dist/chunk-PHXZRR6C.js +1 -0
  26. package/dist/{chunk-I57VSGRB.js → chunk-POCWFIJ7.js} +1 -1
  27. package/dist/{chunk-TQSTS3BY.js → chunk-QEVSIVSF.js} +1 -1
  28. package/dist/chunk-QMC2PLNM.js +7 -0
  29. package/dist/chunk-QOJFR6GS.js +1 -0
  30. package/dist/{chunk-MQZWA3DF.js → chunk-RZ5HKPGI.js} +1 -1
  31. package/dist/{chunk-XINLP35X.js → chunk-SFK7MN7S.js} +1 -1
  32. package/dist/{chunk-YOUAVGHJ.js → chunk-SP5O2MIX.js} +1 -1
  33. package/dist/chunk-TB7JKSVS.js +61 -0
  34. package/dist/{chunk-6G5YD37E.js → chunk-TMVY7OWG.js} +1 -1
  35. package/dist/{chunk-F36TA3ET.js → chunk-UAXFKMAG.js} +1 -1
  36. package/dist/{chunk-AACJX2L7.js → chunk-UVLZX2OU.js} +1 -1
  37. package/dist/chunk-XIMFHEKV.js +1 -0
  38. package/dist/{chunk-LO3LO2TO.js → chunk-XLMYQB6F.js} +1 -1
  39. package/dist/{chunk-44QWWUA3.js → chunk-XLYF4LBH.js} +1 -1
  40. package/dist/compat/index.cjs +9 -9
  41. package/dist/compat/index.d.cts +7 -7
  42. package/dist/compat/index.d.ts +7 -7
  43. package/dist/compat/index.js +1 -1
  44. package/dist/compat/nestjs/index.cjs +9 -9
  45. package/dist/compat/nestjs/index.d.cts +5 -5
  46. package/dist/compat/nestjs/index.d.ts +5 -5
  47. package/dist/compat/nestjs/index.js +1 -1
  48. package/dist/compat/zustand/index.cjs +7 -7
  49. package/dist/compat/zustand/index.d.cts +3 -3
  50. package/dist/compat/zustand/index.d.ts +3 -3
  51. package/dist/compat/zustand/index.js +1 -1
  52. package/dist/{composite-_XckYx2e.d.cts → composite-CgG0MqHm.d.cts} +8 -1
  53. package/dist/{composite-CT_mApQD.d.ts → composite-DTOlDuch.d.ts} +8 -1
  54. package/dist/core/index.cjs +1 -1
  55. package/dist/core/index.d.cts +2 -2
  56. package/dist/core/index.d.ts +2 -2
  57. package/dist/core/index.js +1 -1
  58. package/dist/extra/index.cjs +19 -19
  59. package/dist/extra/index.d.cts +5 -5
  60. package/dist/extra/index.d.ts +5 -5
  61. package/dist/extra/index.js +1 -1
  62. package/dist/extra/node.cjs +2 -2
  63. package/dist/extra/node.d.cts +107 -1
  64. package/dist/extra/node.d.ts +107 -1
  65. package/dist/extra/node.js +2 -2
  66. package/dist/extra/operators.cjs +1 -1
  67. package/dist/extra/operators.js +1 -1
  68. package/dist/extra/reactive.d.cts +1 -1
  69. package/dist/extra/reactive.d.ts +1 -1
  70. package/dist/extra/reactive.js +1 -1
  71. package/dist/extra/sources.cjs +1 -1
  72. package/dist/extra/sources.js +1 -1
  73. package/dist/extra/storage-tiers-browser.d.cts +76 -5
  74. package/dist/extra/storage-tiers-browser.d.ts +76 -5
  75. package/dist/extra/storage-tiers-node.d.cts +137 -13
  76. package/dist/extra/storage-tiers-node.d.ts +137 -13
  77. package/dist/extra/storage-tiers.d.cts +151 -23
  78. package/dist/extra/storage-tiers.d.ts +151 -23
  79. package/dist/graph/index.cjs +7 -7
  80. package/dist/graph/index.d.cts +4 -4
  81. package/dist/graph/index.d.ts +4 -4
  82. package/dist/graph/index.js +1 -1
  83. package/dist/{graph-Cv-8x0ZI.d.ts → graph-BjW1taJl.d.ts} +243 -11
  84. package/dist/{graph-kTltt95s.d.cts → graph-CHsVwf9S.d.cts} +243 -11
  85. package/dist/{index-CZAixNU3.d.ts → index-5dNRlW7J.d.ts} +3 -3
  86. package/dist/{index-DtSVSKnd.d.ts → index-AUqWe_fX.d.ts} +7 -4
  87. package/dist/{index-DLyQC5Ww.d.ts → index-B-ORMr3k.d.ts} +2 -2
  88. package/dist/{index-C4ig7whw.d.cts → index-B2IUcH13.d.cts} +2 -2
  89. package/dist/{index-KeBhbNg3.d.ts → index-BFaALJxR.d.ts} +2 -2
  90. package/dist/{index-CsD0fqnO.d.ts → index-BI1wMfyc.d.ts} +2 -2
  91. package/dist/{index-DxxvGTXp.d.ts → index-BUFCHvOR.d.ts} +2 -2
  92. package/dist/{index-HCp5ua_i.d.cts → index-BWUMIt7J.d.cts} +3 -3
  93. package/dist/{index-DHv2M7s8.d.cts → index-BaSy4L6w.d.cts} +37 -17
  94. package/dist/{index-BhkPzu-Z.d.cts → index-BgzPO43H.d.cts} +2 -2
  95. package/dist/{index-BsZlbHM5.d.cts → index-BhzwpIJc.d.cts} +1 -1
  96. package/dist/{index-BC-xjOrd.d.cts → index-BkQqf1EF.d.cts} +80 -7
  97. package/dist/{index-BBdwz2BW.d.ts → index-BmWuVdER.d.ts} +2 -2
  98. package/dist/{index-CVhBdCMf.d.ts → index-Bn0uZEL4.d.ts} +2 -2
  99. package/dist/{index-33mF4XyU.d.cts → index-BpMZzX9P.d.cts} +2 -2
  100. package/dist/{index-ZhKyR8co.d.cts → index-Bpr0Pwgl.d.cts} +2 -2
  101. package/dist/{index-2URa-V4S.d.cts → index-BqcgiSQg.d.cts} +2 -2
  102. package/dist/{index-DzYTXMBz.d.ts → index-BsZk9T8y.d.ts} +1 -1
  103. package/dist/{index-CvUrRb4m.d.cts → index-BsgxnHN8.d.cts} +2 -2
  104. package/dist/index-Bub6x_D4.d.cts +427 -0
  105. package/dist/{index-BZ1V5GzX.d.ts → index-BwOsJfLJ.d.ts} +2 -2
  106. package/dist/{index-BuMzxRO2.d.ts → index-Byp771zP.d.ts} +1 -1
  107. package/dist/{index-DKp1CIbG.d.cts → index-C-3UXnHT.d.cts} +1 -1
  108. package/dist/{index-GaW6Welt.d.cts → index-C56XZiDe.d.cts} +2 -2
  109. package/dist/{index-k67aNfqC.d.cts → index-CAV-3RpJ.d.cts} +2 -2
  110. package/dist/{index-DmtWMP0X.d.cts → index-CAbHN_rP.d.cts} +1 -1
  111. package/dist/{index-BTJxM-wZ.d.ts → index-CEVzBWeB.d.ts} +2 -2
  112. package/dist/{index-BVNGEX7d.d.cts → index-CM-i58FY.d.cts} +2 -2
  113. package/dist/{index-EfPb77rT.d.cts → index-CQsqqEVz.d.cts} +1 -1
  114. package/dist/{index-Cot94_82.d.ts → index-CijfwEWx.d.ts} +2 -2
  115. package/dist/{index-PluovH45.d.cts → index-Ckil6miL.d.cts} +2 -2
  116. package/dist/{index-XxSeddWP.d.cts → index-CpdnP-0y.d.cts} +1 -1
  117. package/dist/{index-Pu1Wa7en.d.ts → index-CrlHFsiT.d.ts} +37 -17
  118. package/dist/{index-BWH17rK_.d.cts → index-Czk3r0yA.d.cts} +37 -3
  119. package/dist/{index-BlRVj-7Q.d.cts → index-D-B7U42V.d.cts} +2 -2
  120. package/dist/{index-B4s70vYf.d.ts → index-D-HZ7sP4.d.ts} +2 -2
  121. package/dist/{index-Cjrpx2Mg.d.cts → index-D7-RSD93.d.cts} +2 -2
  122. package/dist/{index-kBUQj-rT.d.ts → index-D9vBTuzo.d.ts} +2 -2
  123. package/dist/{index-DzCQt2FJ.d.cts → index-DJNAWzcH.d.cts} +2 -2
  124. package/dist/{index-DSSsxS7B.d.ts → index-DJVQ-t07.d.ts} +2 -2
  125. package/dist/{index-BwYGLgmI.d.ts → index-DKrIuF-r.d.ts} +2 -2
  126. package/dist/{index-DXSLMoma.d.ts → index-DOU1Ee_k.d.ts} +1 -1
  127. package/dist/{index-DlccEIi3.d.ts → index-DTDVDzhA.d.ts} +37 -3
  128. package/dist/{index-B5UR87KG.d.ts → index-DY2f2b9z.d.ts} +4 -2
  129. package/dist/{index-D8IyqHvT.d.cts → index-DeSsvHDD.d.cts} +4 -2
  130. package/dist/index-Di7OdwlO.d.ts +427 -0
  131. package/dist/{index-isdlyeeO.d.ts → index-DqICM_I7.d.ts} +80 -7
  132. package/dist/{index-DFe2Pk2u.d.ts → index-ML6vHKXK.d.ts} +1 -1
  133. package/dist/{index-RJIY7QVW.d.cts → index-UsU9ptzs.d.cts} +7 -4
  134. package/dist/{index-jA_OwwNg.d.ts → index-Vz7KPfgz.d.ts} +1 -1
  135. package/dist/index.cjs +50 -50
  136. package/dist/index.d.cts +32 -32
  137. package/dist/index.d.ts +32 -32
  138. package/dist/index.js +1 -1
  139. package/dist/meta-BYqlATmg.d.ts +98 -0
  140. package/dist/meta-DreaEM_a.d.cts +98 -0
  141. package/dist/patterns/ai/browser.cjs +2 -2
  142. package/dist/patterns/ai/browser.js +1 -1
  143. package/dist/patterns/ai/index.cjs +21 -21
  144. package/dist/patterns/ai/index.d.cts +9 -9
  145. package/dist/patterns/ai/index.d.ts +9 -9
  146. package/dist/patterns/ai/index.js +1 -1
  147. package/dist/patterns/ai/node.js +1 -1
  148. package/dist/patterns/audit/index.cjs +7 -7
  149. package/dist/patterns/audit/index.d.cts +5 -5
  150. package/dist/patterns/audit/index.d.ts +5 -5
  151. package/dist/patterns/audit/index.js +1 -1
  152. package/dist/patterns/cqrs/index.cjs +7 -7
  153. package/dist/patterns/cqrs/index.d.cts +4 -4
  154. package/dist/patterns/cqrs/index.d.ts +4 -4
  155. package/dist/patterns/cqrs/index.js +1 -1
  156. package/dist/patterns/demo-shell/index.cjs +8 -8
  157. package/dist/patterns/demo-shell/index.d.cts +4 -4
  158. package/dist/patterns/demo-shell/index.d.ts +4 -4
  159. package/dist/patterns/demo-shell/index.js +1 -1
  160. package/dist/patterns/domain-templates/index.cjs +7 -7
  161. package/dist/patterns/domain-templates/index.d.cts +3 -3
  162. package/dist/patterns/domain-templates/index.d.ts +3 -3
  163. package/dist/patterns/domain-templates/index.js +1 -1
  164. package/dist/patterns/graphspec/index.cjs +21 -21
  165. package/dist/patterns/graphspec/index.d.cts +3 -3
  166. package/dist/patterns/graphspec/index.d.ts +3 -3
  167. package/dist/patterns/graphspec/index.js +1 -1
  168. package/dist/patterns/guarded-execution/index.cjs +7 -7
  169. package/dist/patterns/guarded-execution/index.d.cts +6 -6
  170. package/dist/patterns/guarded-execution/index.d.ts +6 -6
  171. package/dist/patterns/guarded-execution/index.js +1 -1
  172. package/dist/patterns/harness/index.cjs +12 -12
  173. package/dist/patterns/harness/index.d.cts +8 -8
  174. package/dist/patterns/harness/index.d.ts +8 -8
  175. package/dist/patterns/harness/index.js +1 -1
  176. package/dist/patterns/job-queue/index.cjs +7 -7
  177. package/dist/patterns/job-queue/index.d.cts +4 -4
  178. package/dist/patterns/job-queue/index.d.ts +4 -4
  179. package/dist/patterns/job-queue/index.js +1 -1
  180. package/dist/patterns/lens/index.cjs +7 -7
  181. package/dist/patterns/lens/index.d.cts +4 -4
  182. package/dist/patterns/lens/index.d.ts +4 -4
  183. package/dist/patterns/lens/index.js +1 -1
  184. package/dist/patterns/memory/index.cjs +7 -7
  185. package/dist/patterns/memory/index.d.cts +6 -4
  186. package/dist/patterns/memory/index.d.ts +6 -4
  187. package/dist/patterns/memory/index.js +1 -1
  188. package/dist/patterns/messaging/index.cjs +7 -7
  189. package/dist/patterns/messaging/index.d.cts +4 -4
  190. package/dist/patterns/messaging/index.d.ts +4 -4
  191. package/dist/patterns/messaging/index.js +1 -1
  192. package/dist/patterns/orchestration/index.cjs +7 -7
  193. package/dist/patterns/orchestration/index.d.cts +4 -4
  194. package/dist/patterns/orchestration/index.d.ts +4 -4
  195. package/dist/patterns/orchestration/index.js +1 -1
  196. package/dist/patterns/process/index.cjs +1 -1
  197. package/dist/patterns/process/index.d.cts +5 -5
  198. package/dist/patterns/process/index.d.ts +5 -5
  199. package/dist/patterns/process/index.js +1 -1
  200. package/dist/patterns/reactive-layout/index.cjs +8 -8
  201. package/dist/patterns/reactive-layout/index.d.cts +4 -4
  202. package/dist/patterns/reactive-layout/index.d.ts +4 -4
  203. package/dist/patterns/reactive-layout/index.js +1 -1
  204. package/dist/patterns/reduction/index.cjs +7 -7
  205. package/dist/patterns/reduction/index.d.cts +3 -3
  206. package/dist/patterns/reduction/index.d.ts +3 -3
  207. package/dist/patterns/reduction/index.js +1 -1
  208. package/dist/patterns/refine-loop/index.cjs +8 -8
  209. package/dist/patterns/refine-loop/index.d.cts +5 -5
  210. package/dist/patterns/refine-loop/index.d.ts +5 -5
  211. package/dist/patterns/refine-loop/index.js +1 -1
  212. package/dist/patterns/resilient-pipeline/index.cjs +1 -1
  213. package/dist/patterns/resilient-pipeline/index.d.cts +4 -4
  214. package/dist/patterns/resilient-pipeline/index.d.ts +4 -4
  215. package/dist/patterns/resilient-pipeline/index.js +1 -1
  216. package/dist/patterns/surface/index.cjs +14 -14
  217. package/dist/patterns/surface/index.d.cts +4 -4
  218. package/dist/patterns/surface/index.d.ts +4 -4
  219. package/dist/patterns/surface/index.js +1 -1
  220. package/dist/{pipeline-graph-DdBoRu37.d.ts → pipeline-graph-9JBbmRxA.d.ts} +2 -2
  221. package/dist/{pipeline-graph-BlLBWSZ2.d.cts → pipeline-graph-DuHpXSOn.d.cts} +2 -2
  222. package/dist/{reactive-layout-D9zqqaqK.d.cts → reactive-layout-BMLDB4Vd.d.cts} +1 -1
  223. package/dist/{reactive-layout-Btv0-efV.d.ts → reactive-layout-D-tRiNhg.d.ts} +1 -1
  224. package/dist/{reactive-log-jirQsxMY.d.ts → reactive-log-BgWSA1fg.d.ts} +28 -1
  225. package/dist/{reactive-log-ScpWyqny.d.cts → reactive-log-C3IMAGpT.d.cts} +28 -1
  226. package/dist/resilience-LGBK236C.js +1 -0
  227. package/dist/{topology-tree-CJsT24DP.d.ts → topology-tree-D47-nI6Z.d.ts} +1 -1
  228. package/dist/{topology-tree-C50l9ARE.d.cts → topology-tree-jrZue3ao.d.cts} +1 -1
  229. package/package.json +1 -1
  230. package/dist/chunk-3U7IIQB2.js +0 -1
  231. package/dist/chunk-533RQFF6.js +0 -1
  232. package/dist/chunk-5CZ3KIRJ.js +0 -1
  233. package/dist/chunk-5KPIYVCC.js +0 -7
  234. package/dist/chunk-5RTZ6DXG.js +0 -1
  235. package/dist/chunk-A5HZZYRK.js +0 -1
  236. package/dist/chunk-CGA5RXO6.js +0 -1
  237. package/dist/chunk-DBPFMCVH.js +0 -1
  238. package/dist/chunk-GWOKTENT.js +0 -1
  239. package/dist/chunk-JJTF75VS.js +0 -1
  240. package/dist/chunk-KL7CILPL.js +0 -1
  241. package/dist/chunk-M27MVZCP.js +0 -1
  242. package/dist/chunk-N2GCKKKH.js +0 -43
  243. package/dist/chunk-QKUWS7CO.js +0 -80
  244. package/dist/chunk-YBA5N4XY.js +0 -61
  245. package/dist/index-CI_yjtua.d.ts +0 -139
  246. package/dist/index-D9qoEOj_.d.cts +0 -139
  247. package/dist/meta-BGO6C7K9.d.cts +0 -41
  248. package/dist/meta-CC6EPdpK.d.ts +0 -41
  249. package/dist/resilience-OBU472D2.js +0 -1
@@ -1,7 +1,7 @@
1
- "use strict";var Ye=Object.defineProperty;var dn=Object.getOwnPropertyDescriptor;var fn=Object.getOwnPropertyNames;var pn=Object.prototype.hasOwnProperty;var W=(t,e)=>()=>(t&&(e=t(t=0)),e);var hn=(t,e)=>{for(var n in e)Ye(t,n,{get:e[n],enumerable:!0})},gn=(t,e,n,r)=>{if(e&&typeof e=="object"||typeof e=="function")for(let s of fn(e))!pn.call(t,s)&&s!==n&&Ye(t,s,{get:()=>e[s],enumerable:!(r=dn(e,s))||r.enumerable});return t};var mn=t=>gn(Ye({},"__esModule",{value:!0}),t);function j(){return Math.trunc(performance.now()*1e6)}function Ee(){return Date.now()*1e6}var Oe=W(()=>{"use strict"});function vt(t,e){let n=new TextEncoder().encode(t.name);if(n.length===0||n.length>255)throw new Error(`encodeEnvelope: codec name "${t.name}" encodes to ${n.length} bytes (must be 1\u2013255)`);let r=t.version;if(!Number.isInteger(r)||r<0||r>65535)throw new Error(`encodeEnvelope: codec.version ${r} out of u16 range (expected integer 0\u201365535)`);let s=2+n.length+2+e.length;if(s>4294967295)throw new Error(`encodeEnvelope: total envelope size ${s} exceeds 2^32-1 bytes (payload ${e.length} bytes)`);let o=new Uint8Array(s),i=0;return o[i++]=Je,o[i++]=n.length,o.set(n,i),i+=n.length,o[i++]=r>>>8&255,o[i++]=r&255,o.set(e,i),o}function _t(t,e){if(t.length<yt)throw new Error(`decodeEnvelope: bytes too short (${t.length} < ${yt})`);let n=0,r=t[n++];if(r!==Je)throw new Error(`decodeEnvelope: unsupported envelope version ${r} (expected ${Je})`);let s=t[n++];if(s===0)throw new Error("decodeEnvelope: name_len must be >= 1");if(n+s+2>t.length)throw new Error(`decodeEnvelope: envelope truncated (need ${n+s+2} bytes, have ${t.length})`);let o=new TextDecoder().decode(t.subarray(n,n+s));n+=s;let i=(t[n]<<8|t[n+1])>>>0;n+=2;let a=t.subarray(n),u=e.lookupCodec(o);if(u==null)throw new Error(`decodeEnvelope: codec "${o}" not registered (envelope codec_v=${i})`);return{codec:u,codecVersion:i,payload:a}}function xt(t){t.registerCodec(bn)}var bn,Je,yt,Xe=W(()=>{"use strict";bn={name:"json",version:1,contentType:"application/json",encode(t){let e=JSON.stringify(t);return new TextEncoder().encode(e)},decode(t,e){let n=new TextDecoder().decode(t);return JSON.parse(n)}},Je=1,yt=4});function Ne(t){if(t==null)return ce;let{type:e,id:n,...r}=t;return{type:e??"system",id:n??"",...r}}var ce,Ze=W(()=>{"use strict";ce={type:"system",id:""}});function Re(){return le>0||be}function wt(){return le>0}function ve(t){le>0?ye.push(t):t()}function Tt(t){le+=1;let e=!1;try{t()}catch(n){throw e=!0,n}finally{if(le-=1,le===0)if(e){if(!be){let n=ye.splice(0);for(let r of n)try{r()}catch{}ie.length=0,ae.length=0,de.length=0}}else yn()}}function yn(){let t=!be;t&&(be=!0);let e=[],n=0;try{for(;ie.length>0||ae.length>0||de.length>0||t&&ye.length>0;){if(t&&ye.length>0){let o=ye.splice(0);for(let i of o)try{i()}catch(a){e.push(a)}continue}if(n+=1,n>1e3)throw ie.length=0,ae.length=0,de.length=0,new Error("batch drain exceeded 1000 iterations \u2014 likely a reactive cycle");let s=(ie.length>0?ie:ae.length>0?ae:de).splice(0);for(let o of s)try{o()}catch(i){e.push(i)}}}finally{t&&(be=!1)}if(e.length===1)throw e[0];if(e.length>1)throw new AggregateError(e,"batch drain: multiple callbacks threw")}function ke(t,e,n){if(e.length===0)return;if(e.length===1){let c=n(e[0][0]);if(c<3||!Re()){t(e);return}(c>=5?de:c===4?ae:ie).push(()=>t(e));return}let r=e.length,s=r,o=r,i=r,a=0;for(;a<r&&n(e[a][0])<3;)a++;for(s=a;a<r&&n(e[a][0])===3;)a++;for(o=a;a<r&&n(e[a][0])===4;)a++;i=a;let u=Re();if(s>0){let c=e.slice(0,s);t(c)}if(o>s){let c=e.slice(s,o);u?ie.push(()=>t(c)):t(c)}if(i>o){let c=e.slice(o,i);u?ae.push(()=>t(c)):t(c)}if(r>i){let c=e.slice(i,r);u?de.push(()=>t(c)):t(c)}}var le,be,ie,ae,de,ye,Qe=W(()=>{"use strict";le=0,be=!1,ie=[],ae=[],de=[],ye=[]});var _e,V,Z,Q,Y,ee,re,H,J,P,fe,et,vn,tt,_n,xn,nt,Et,Ot,Nt,rt,Se=W(()=>{"use strict";_e=Symbol.for("graphrefly/START"),V=Symbol.for("graphrefly/DATA"),Z=Symbol.for("graphrefly/DIRTY"),Q=Symbol.for("graphrefly/RESOLVED"),Y=Symbol.for("graphrefly/INVALIDATE"),ee=Symbol.for("graphrefly/PAUSE"),re=Symbol.for("graphrefly/RESUME"),H=Symbol.for("graphrefly/TEARDOWN"),J=Symbol.for("graphrefly/COMPLETE"),P=Symbol.for("graphrefly/ERROR"),fe=Object.freeze([Z]),et=Object.freeze([Q]),vn=Object.freeze([Y]),tt=Object.freeze([_e]),_n=Object.freeze([J]),xn=Object.freeze([H]),nt=Object.freeze([fe]),Et=Object.freeze([et]),Ot=Object.freeze([vn]),Nt=Object.freeze([_n]),rt=Object.freeze([xn])});function Rt(t){t.registerMessageType(_e,{tier:0,wireCrossing:!1}),t.registerMessageType(Z,{tier:1,wireCrossing:!1}),t.registerMessageType(Y,{tier:1,wireCrossing:!1,metaPassthrough:!1}),t.registerMessageType(ee,{tier:2,wireCrossing:!1}),t.registerMessageType(re,{tier:2,wireCrossing:!1}),t.registerMessageType(V,{tier:3,wireCrossing:!0}),t.registerMessageType(Q,{tier:3,wireCrossing:!0}),t.registerMessageType(J,{tier:4,wireCrossing:!0,metaPassthrough:!1}),t.registerMessageType(P,{tier:4,wireCrossing:!0,metaPassthrough:!1}),t.registerMessageType(H,{tier:5,wireCrossing:!0,metaPassthrough:!1})}var Ae,kt=W(()=>{"use strict";Se();Ae=class{_messageTypes=new Map;_codecs=new Map;_onMessage;_onSubscribe;_defaultVersioning;_defaultHashFn;_inspectorEnabled=!(typeof process<"u"&&process.env?.NODE_ENV==="production");_globalInspector;_rigorRecorder;_frozen=!1;tierOf;constructor(e){this._onMessage=e.onMessage,this._onSubscribe=e.onSubscribe,this._defaultVersioning=e.defaultVersioning,this._defaultHashFn=e.defaultHashFn,this.tierOf=n=>{let r=this._messageTypes.get(n);return r!=null?r.tier:1}}get onMessage(){return this._frozen=!0,this._onMessage}get onSubscribe(){return this._frozen=!0,this._onSubscribe}set onMessage(e){this._assertUnfrozen(),this._onMessage=e}set onSubscribe(e){this._assertUnfrozen(),this._onSubscribe=e}get defaultVersioning(){return this._defaultVersioning}set defaultVersioning(e){this._assertUnfrozen(),this._defaultVersioning=e}get defaultHashFn(){return this._defaultHashFn}set defaultHashFn(e){this._assertUnfrozen(),this._defaultHashFn=e}get inspectorEnabled(){return this._inspectorEnabled}set inspectorEnabled(e){this._inspectorEnabled=e}get globalInspector(){return this._globalInspector}set globalInspector(e){this._globalInspector=e}get rigorRecorder(){return this._rigorRecorder}set rigorRecorder(e){this._rigorRecorder=e}registerMessageType(e,n){return this._assertUnfrozen(),this._messageTypes.set(e,{tier:n.tier,wireCrossing:n.wireCrossing??n.tier>=3,metaPassthrough:n.metaPassthrough??!0}),this}messageTier(e){let n=this._messageTypes.get(e);return n!=null?n.tier:1}isWireCrossing(e){let n=this._messageTypes.get(e);return n!=null?n.wireCrossing:!0}isLocalOnly(e){return!this.isWireCrossing(e)}isMetaPassthrough(e){let n=this._messageTypes.get(e);return n!=null?n.metaPassthrough:!0}isKnownMessageType(e){return this._messageTypes.has(e)}registerCodec(e){return this._assertUnfrozen(),this._codecs.set(e.name,e),this}lookupCodec(e){return this._codecs.get(e)}_isFrozen(){return this._frozen}_assertUnfrozen(){if(this._frozen)throw new Error("GraphReFlyConfig is frozen: a node has already captured this config. Register custom types and set hooks before creating any node.")}}});function st(t){let e=wn.filter(n=>t({type:n,id:""},"write"));return e.length===0?"restricted":e.includes("human")&&e.includes("llm")&&e.every(n=>n==="human"||n==="llm"||n==="system")?"both":e.length===1?e[0]:e.join("+")}var K,wn,Ce=W(()=>{"use strict";K=class extends Error{actor;action;nodeName;constructor(e,n){super(n??`GuardDenied: action "${String(e.action)}" denied for actor type "${String(e.actor.type)}"`),this.name="GuardDenied",this.actor=e.actor,this.action=e.action,this.nodeName=e.nodeName}get node(){return this.nodeName}},wn=["human","llm","wallet","system"]});function ot(t){if(t===void 0)return null;if(typeof t=="number"){if(!Number.isFinite(t))throw new TypeError(`Cannot hash non-finite number: ${t}`);if(Number.isInteger(t)&&!Number.isSafeInteger(t))throw new TypeError(`Cannot hash integer outside safe range (|n| > 2^53-1): ${t}. Cross-language cid parity is not guaranteed for unsafe integers.`);return t}if(typeof t=="string"||typeof t=="boolean"||t===null)return t;if(Array.isArray(t))return t.map(ot);if(typeof t=="object"&&t!==null){let e={};for(let n of Object.keys(t).sort())e[n]=ot(t[n]);return e}return null}function On(t){let e=En.encode(t),n=e.length,r=n*8,s=n+9+63&-64,o=new Uint8Array(s);o.set(e),o[n]=128;let i=new DataView(o.buffer);i.setUint32(s-4,r>>>0,!1),i.setUint32(s-8,Math.floor(r/4294967296)>>>0,!1);let a=1779033703,u=3144134277,c=1013904242,l=2773480762,p=1359893119,h=2600822924,f=528734635,d=1541459225,g=new Uint32Array(64),m=(_,b)=>_>>>b|_<<32-b;for(let _=0;_<s;_+=64){for(let R=0;R<16;R++)g[R]=i.getUint32(_+R*4,!1);for(let R=16;R<64;R++){let S=g[R-15],k=g[R-2],G=m(S,7)^m(S,18)^S>>>3,B=m(k,17)^m(k,19)^k>>>10;g[R]=g[R-16]+G+g[R-7]+B>>>0}let b=a,v=u,T=c,x=l,w=p,E=h,N=f,A=d;for(let R=0;R<64;R++){let S=m(w,6)^m(w,11)^m(w,25),k=w&E^~w&N,G=A+S+k+Tn[R]+g[R]>>>0,B=m(b,2)^m(b,13)^m(b,22),q=b&v^b&T^v&T,oe=B+q>>>0;A=N,N=E,E=w,w=x+G>>>0,x=T,T=v,v=b,b=G+oe>>>0}a=a+b>>>0,u=u+v>>>0,c=c+T>>>0,l=l+x>>>0,p=p+w>>>0,h=h+E>>>0,f=f+N>>>0,d=d+A>>>0}let y=_=>_.toString(16).padStart(8,"0");return y(a)+y(u)+y(c)+y(l)+y(p)+y(h)+y(f)+y(d)}function it(t){let e=ot(t??null),n=JSON.stringify(e);return On(n).slice(0,16)}function Nn(){let t=globalThis.crypto;if(t?.randomUUID)return t.randomUUID();let e=()=>Math.floor(Math.random()*4294967296).toString(16).padStart(8,"0"),n=e()+e()+e()+e();return`${n.slice(0,8)}-${n.slice(8,12)}-4${n.slice(13,16)}-${(parseInt(n.slice(16,17),16)&3|8).toString(16)}${n.slice(17,20)}-${n.slice(20,32)}`}function at(t,e,n){let r=n?.id??Nn();if(t===0)return{id:r,version:0};let o=(n?.hash??it)(e);return{id:r,version:0,cid:o,prev:null}}function St(t,e,n){t.version+=1,"cid"in t&&(t.prev=t.cid,t.cid=n(e))}var Tn,En,At=W(()=>{"use strict";Tn=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]),En=new TextEncoder});function Dt(t){return{node:t,unsub:null,prevData:void 0,dirty:!1,involvedThisWave:!1,dataBatch:[],terminal:void 0}}function ut(t){t.prevData=void 0,t.dirty=!1,t.involvedThisWave=!1,t.dataBatch.length=0,t.terminal=void 0}function Me(t){return t.length===0?t:typeof t[0]=="symbol"?[t]:t}function De(t,e,n){let r=Gt(t)?t:[],s=typeof t=="function"?t:typeof e=="function"?e:void 0,o={};return Gt(t)?o=(ct(e)?e:n)??{}:ct(t)?o=t:o=(ct(e)?e:n)??{},new I(r,s,o)}var Ct,Mt,Rn,kn,pe,I,Gt,ct,xe=W(()=>{"use strict";Xe();Ze();Qe();Oe();kt();Ce();Se();At();Ct=()=>{},Mt=100;Rn=(t,e,n,r)=>{n.direction==="down-in"&&t._onDepMessage(n.depIndex,e)},kn=(t,e,n,r)=>{let s=t;if(s._status==="completed"||s._status==="errored")return;let o=s._cached,i=o===void 0?[tt]:[tt,[V,o]];s._status==="dirty"&&i.push(fe),ke(e,i,s._config.tierOf)},pe=new Ae({onMessage:Rn,onSubscribe:kn});Rt(pe);xt(pe);I=class t{_optsName;_describeKind;meta;_hasMeta;_config;_deps;_sinks=null;_sinkCount=0;_cached;_status;_cleanup;_store={};_waveHasNewData=!1;_hasNewTerminal=!1;_hasCalledFnOnce=!1;_paused=!1;_pendingWave=!1;_isExecutingFn=!1;_pendingRerun=!1;_rerunDepth=0;_dirtyDepCount=0;_batchPendingMessages=null;_pauseLocks=null;_pauseBuffer=null;_fn;_equals;_resubscribable;_resetOnTeardown;_autoComplete;_autoError;_pausable;_partial;_guard;_extraGuards;_hashFn;_versioning;_versioningLevel;_lastMutation;_inspectorHooks;_actions;constructor(e,n,r){this._config=r.config??pe,this._config.onMessage,this._optsName=r.name,this._describeKind=r.describeKind,this._equals=r.equals??Object.is,this._resubscribable=r.resubscribable??!1,this._resetOnTeardown=r.resetOnTeardown??!1,this._autoComplete=r.completeWhenDepsComplete??!0,this._autoError=r.errorWhenDepsError??!0,this._pausable=r.pausable??!0,this._guard=r.guard,this._fn=n,this._partial=r.partial??!1,this._cached=r.initial!==void 0?r.initial:void 0,this._status=e.length===0&&n==null&&this._cached!==void 0?"settled":"sentinel",this._hashFn=r.versioningHash??this._config.defaultHashFn??it;let s=r.versioning??this._config.defaultVersioning;this._versioningLevel=s,this._versioning=s!=null?at(s,this._cached===void 0?void 0:this._cached,{id:r.versioningId,hash:this._hashFn}):void 0,this._deps=e.map(Dt);let o={};for(let[a,u]of Object.entries(r.meta??{})){let c={initial:u,name:`${r.name??"node"}:meta:${a}`,describeKind:"state",config:this._config};r.guard!=null&&(c.guard=r.guard),o[a]=new t([],void 0,c)}Object.freeze(o),this.meta=o,this._hasMeta=Object.keys(o).length>0;let i=this;this._actions={emit(a){i._emit([[V,a]])},down(a){i._emit(Me(a))},up(a){i._emitUp(Me(a))}},this.down=this.down.bind(this),this.up=this.up.bind(this)}get _isTerminal(){return this._status==="completed"||this._status==="errored"}get name(){return this._optsName}get status(){return this._status}get cache(){return this._cached===void 0?void 0:this._cached}get lastMutation(){return this._lastMutation}get v(){return this._versioning}hasGuard(){return this._guard!=null}_applyVersioning(e,n){if(this._isExecutingFn)throw new Error(`Node "${this.name}": _applyVersioning cannot run mid-fn \u2014 call it outside of \`_execFn\` (typically at graph setup time before the first subscribe).`);let r=this._versioningLevel;if(r!=null&&e<=r)return;let s=n?.hash??this._hashFn;s!==this._hashFn&&(this._hashFn=s);let o=this._cached===void 0?void 0:this._cached,i=this._versioning,a=i?.id??n?.id,u=i?.version??0,c=at(e,o,{id:a,hash:s});c.version=u,this._versioning=c,this._versioningLevel=e}_setInspectorHook(e){return e==null?()=>{}:(this._inspectorHooks==null&&(this._inspectorHooks=new Set),this._inspectorHooks.add(e),()=>{this._inspectorHooks?.delete(e),this._inspectorHooks?.size===0&&(this._inspectorHooks=void 0)})}_pushGuard(e){return this._extraGuards==null&&(this._extraGuards=new Set),this._extraGuards.add(e),()=>{this._extraGuards?.delete(e),this._extraGuards?.size===0&&(this._extraGuards=void 0)}}allowsObserve(e){if(this._guard==null&&this._extraGuards==null)return!0;let n=Ne(e);if(this._guard!=null&&!this._guard(n,"observe"))return!1;if(this._extraGuards!=null){for(let r of this._extraGuards)if(!r(n,"observe"))return!1}return!0}_checkGuard(e){if(e?.internal)return;let n=this._guard!=null||this._extraGuards!=null,r=e?.actor!=null;if(!n&&!r)return;let s=Ne(e?.actor),o=e?.delivery==="signal"?"signal":"write";if(this._guard!=null&&!this._guard(s,o))throw new K({actor:s,action:o,nodeName:this.name});if(this._extraGuards!=null){for(let i of this._extraGuards)if(!i(s,o))throw new K({actor:s,action:o,nodeName:this.name})}this._lastMutation={actor:s,timestamp_ns:Ee()}}down(e,n){let r=Me(e);r.length!==0&&(this._checkGuard(n),this._emit(r))}emit(e,n){this._checkGuard(n),this._emit([[V,e]])}up(e,n){if(this._deps.length===0)return;let r=Me(e);if(r.length===0)return;this._checkGuard(n);let s=n??{internal:!0};this._validateUpTiers(r);for(let o of this._deps)o.node.up?.(r,s)}_emitUp(e){if(this._deps.length!==0&&e.length!==0){this._validateUpTiers(e);for(let n of this._deps)n.node.up?.(e,{internal:!0})}}_validateUpTiers(e){let n=this._config.tierOf;for(let r of e){let s=n(r[0]);if(s===3||s===4)throw new Error(`Node "${this.name}": tier-${s} messages cannot flow up \u2014 DATA/RESOLVED/COMPLETE/ERROR are downstream-only. Use \`down(...)\` for value delivery; \`up(...)\` is for control signals (DIRTY, INVALIDATE, PAUSE, RESUME, TEARDOWN).`)}}subscribe(e,n){if(n!=null&&this._guard!=null){let u=Ne(n);if(!this._guard(u,"observe"))throw new K({actor:u,action:"observe",nodeName:this.name})}let s=this._isTerminal&&this._resubscribable;if(s){this._cached=void 0,this._status="sentinel",this._store={},this._hasCalledFnOnce=!1,this._waveHasNewData=!1,this._hasNewTerminal=!1,this._paused=!1,this._pendingWave=!1,this._pendingRerun=!1,this._isExecutingFn=!1,this._rerunDepth=0,this._dirtyDepCount=0,this._pauseLocks=null,this._pauseBuffer=null;for(let u of this._deps)ut(u);if(this._partial===!1){for(let u of this._deps)if(u.prevData!==void 0||u.dataBatch.length!==0||u.terminal!==void 0||u.dirty)throw new Error(`resubscribable-reset invariant: DepRecord not fully reset for node ${this._optsName??"(anonymous)"}`)}}this._sinkCount+=1;let o;try{o=this._config.onSubscribe(this,e,{sinkCount:this._sinkCount,afterTerminalReset:s},this._actions)}catch(u){throw this._sinkCount-=1,u}this._sinks==null?this._sinks=e:typeof this._sinks=="function"?this._sinks=new Set([this._sinks,e]):this._sinks.add(e);let i=this._isTerminal;if(this._sinkCount===1&&!i)try{this._activate()}catch(u){if(this._sinkCount-=1,this._removeSink(e),this._sinkCount===0&&(this._status="sentinel"),typeof o=="function")try{o()}catch{}throw u}this._status==="sentinel"&&this._cached===void 0&&(this._status="pending");let a=!1;return()=>{a||(a=!0,this._sinkCount-=1,this._removeSink(e),typeof o=="function"&&o(),this._sinks==null&&this._deactivate())}}_removeSink(e){if(this._sinks===e)this._sinks=null;else if(this._sinks!=null&&typeof this._sinks!="function")if(this._sinks.delete(e),this._sinks.size===1){let[n]=this._sinks;this._sinks=n}else this._sinks.size===0&&(this._sinks=null)}_activate(){if(this._deps.length===0){this._fn&&this._execFn();return}this._dirtyDepCount=0;let e=this._deps.length,n=0;try{for(let r=0;r<e;r++){let s=r,o=this._deps[r];o.unsub=Ct,o.unsub=o.node.subscribe(i=>{if(o.unsub===null)return;let a=this._config.tierOf,u=!1;for(let c of i)a(c[0])>=3&&(u=!0),this._config.onMessage(this,c,{direction:"down-in",depIndex:s},this._actions);u&&this._maybeRunFnOnSettlement()}),n++}}catch(r){this._deps[n].unsub=null;for(let s=0;s<n;s++){let o=this._deps[s];if(o.unsub!=null){let i=o.unsub;o.unsub=null;try{i()}catch{}ut(o)}}throw this._dirtyDepCount=0,r}}_addDep(e){for(let s=0;s<this._deps.length;s++)if(this._deps[s].node===e)return s;let n=this._deps.length,r=Dt(e);if(this._deps.push(r),this._sinks==null)return n;r.dirty=!0,this._dirtyDepCount++,this._status!=="dirty"&&this._emit(nt),r.unsub=Ct;try{r.unsub=e.subscribe(s=>{if(r.unsub===null)return;let o=this._config.tierOf,i=!1;for(let a of s)o(a[0])>=3&&(i=!0),this._config.onMessage(this,a,{direction:"down-in",depIndex:n},this._actions);i&&this._maybeRunFnOnSettlement()})}catch(s){throw r.unsub=null,this._deps.pop(),this._dirtyDepCount--,s}return n}_deactivate(e=!1){let n=this._cleanup;if(this._cleanup=void 0,typeof n=="function")try{n()}catch(r){this._emit([[P,this._wrapFnError("cleanup threw",r)]])}else if(n!=null&&typeof n=="object"){let r=n.deactivate;if(typeof r=="function")try{r()}catch(s){this._emit([[P,this._wrapFnError("cleanup.deactivate threw",s)]])}}for(let r of this._deps){if(r.unsub!=null){let s=r.unsub;r.unsub=null;try{s()}catch{}}ut(r)}this._waveHasNewData=!1,this._hasNewTerminal=!1,this._hasCalledFnOnce=!1,this._paused=!1,this._pendingWave=!1,this._pendingRerun=!1,this._rerunDepth=0,this._store={},this._dirtyDepCount=0,this._pauseLocks=null,this._pauseBuffer=null,this._fn!=null&&(this._cached=void 0),e||(this._fn!=null||this._deps.length>0)&&(!this._isTerminal||this._resubscribable)&&(this._status="sentinel")}_onDepMessage(e,n){let r=this._deps[e],s=n[0];if(this._inspectorHooks!=null){let o={kind:"dep_message",depIndex:e,message:n};for(let i of this._inspectorHooks)i(o)}if(s!==_e){if(s===Z){this._depDirtied(r);return}if(s===Y){if(this._depInvalidated(r),this._cached===void 0)return;this._emit(Ot);return}if(s===ee||s===re){this._emit([n]);return}if(s===H){this._emit(rt);return}if(s===V)this._depSettledAsData(r,n[1]);else if(s===Q)this._depSettledAsResolved(r);else if(s===J)this._depSettledAsTerminal(r,!0);else if(s===P)this._depSettledAsTerminal(r,n[1]);else{this._emit([n]);return}if(!this._fn){(s===V||s===Q)&&this._emit([n]),(s===J||s===P)&&this._maybeAutoTerminalAfterWave();return}}}_depDirtied(e){e.dirty||(e.dirty=!0,e.involvedThisWave=!0,this._dirtyDepCount++,this._status!=="dirty"&&this._emit(nt))}_depSettledAsData(e,n){e.dirty&&(e.dirty=!1,this._dirtyDepCount--),e.involvedThisWave=!0,e.dataBatch.push(n),this._waveHasNewData=!0}_depSettledAsResolved(e){e.dirty&&(e.dirty=!1,this._dirtyDepCount--)}_depSettledAsTerminal(e,n){e.dirty&&(e.dirty=!1,this._dirtyDepCount--),e.terminal=n,e.involvedThisWave=!0,this._hasNewTerminal=!0}_depInvalidated(e){e.prevData=void 0,e.terminal=void 0,e.dataBatch.length=0,e.dirty?e.involvedThisWave=!1:(e.dirty=!0,e.involvedThisWave=!0,this._dirtyDepCount++)}_maybeRunFnOnSettlement(){if(!(this._isTerminal&&!this._resubscribable)&&!(this._dirtyDepCount>0)){if(!this._partial&&!this._hasCalledFnOnce)for(let e=0;e<this._deps.length;e++){let n=this._deps[e];if(n.dataBatch.length===0&&n.prevData===void 0&&n.terminal===void 0){this._maybeAutoTerminalAfterWave();return}}if(this._paused){this._pendingWave=!0;return}if(!this._waveHasNewData&&!this._hasNewTerminal&&this._hasCalledFnOnce){this._clearWaveFlags(),this._emit(Et),this._maybeAutoTerminalAfterWave();return}this._fn&&this._execFn(),this._maybeAutoTerminalAfterWave()}}_maybeAutoTerminalAfterWave(){if(this._deps.length===0||this._isTerminal)return;let e=this._deps.find(n=>n.terminal!==void 0&&n.terminal!==!0);if(e!=null){this._autoError&&this._emit([[P,e.terminal]]);return}this._autoComplete&&this._deps.every(n=>n.terminal!==void 0)&&this._emit(Nt)}_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([[P,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([[P,this._wrapFnError("cleanup.beforeRun threw",a)]]);return}}}let n=this._deps.map(i=>i.involvedThisWave?i.dataBatch.length>0?[...i.dataBatch]:[]:void 0),r=this._deps.map(i=>i.prevData);for(let i=0;i<this._deps.length;i++){let a=n[i];a!=null&&a.length>0&&(this._deps[i].prevData=a[a.length-1])}let s=this._deps.map(i=>i.terminal),o={prevData:r,terminalDeps:s,store:this._store};if(this._hasCalledFnOnce=!0,this._clearWaveFlags(),this._inspectorHooks!=null){let i={kind:"run",batchData:n,prevData:r};for(let a of this._inspectorHooks)a(i)}this._isExecutingFn=!0;try{let i=this._fn(n,this._actions,o);if(typeof i=="function")this._cleanup=i;else if(i!=null&&typeof i=="object"){let a=i;(typeof a.beforeRun=="function"||typeof a.deactivate=="function"||typeof a.invalidate=="function")&&(this._cleanup=i)}}catch(i){this._emit([[P,this._wrapFnError("fn threw",i)]])}finally{this._isExecutingFn=!1,this._pendingRerun?(this._pendingRerun=!1,this._rerunDepth+=1,this._rerunDepth>Mt?(this._rerunDepth=0,this._emit([[P,new Error(`Node "${this.name}": _pendingRerun depth exceeded ${Mt} \u2014 likely a reactive cycle`)]])):this._maybeRunFnOnSettlement()):this._rerunDepth=0,this._clearWaveFlags()}}_clearWaveFlags(){this._waveHasNewData=!1,this._hasNewTerminal=!1;for(let e of this._deps)e.involvedThisWave=!1,e.dataBatch.length=0}_wrapFnError(e,n){let r=n instanceof Error?n.message:String(n);return new Error(`Node "${this.name}": ${e}: ${r}`,{cause:n})}_frameBatch(e){let n=this._config.tierOf;if(e.length===1)return n(e[0][0])===3&&this._status!=="dirty"?[fe,e[0]]:e;let r=!0,s=!1,o=!1,i=-1;for(let u of e){let c=n(u[0]);c<i&&(r=!1),c===3&&(s=!0),u[0]===Z&&(o=!0),i=c}let a=e;if(!r){let u=e.map((c,l)=>({m:c,i:l,tier:n(c[0])}));u.sort((c,l)=>c.tier-l.tier||c.i-l.i),a=u.map(c=>c.m)}if(s&&!o&&this._status!=="dirty"){let u=0;for(;u<a.length&&n(a[u][0])===0;)u++;return u===0?[fe,...a]:[...a.slice(0,u),fe,...a.slice(u)]}return a}_emit(e){if(e.length===0)return;for(let a=0;a<e.length;a++){let u=e[a];if(u[0]===P&&u[1]===void 0)throw new TypeError('[ERROR, payload] requires a non-undefined payload (spec \xA71.2). Pass an Error object or domain tag instead \u2014 e.g. node.down([[ERROR, new Error("reason")]])')}let n=e;if(this._isTerminal&&!this._resubscribable){let a=e.filter(u=>u[0]===H||u[0]===Y);if(a.length===0)return;n=a}n=this._frameBatch(n);let s=null;for(let a=0;a<n.length;a++){let u=n[a],c=u[0];if(c!==ee&&c!==re){s?.push(u);continue}if(u.length<2)throw new Error(`Node "${this.name}": [[${c===ee?"PAUSE":"RESUME"}]] must carry a lockId payload \u2014 bare PAUSE/RESUME is a protocol violation (C0 rule). Use \`[[PAUSE, lockId]]\` / \`[[RESUME, lockId]]\`.`);let l=!0;if(this._pausable!==!1){let p=u[1];if(c===ee)this._pauseLocks==null&&(this._pauseLocks=new Set),this._pauseLocks.add(p),this._paused=!0,this._pausable==="resumeAll"&&this._pauseBuffer==null&&(this._pauseBuffer=[]);else if(this._pauseLocks==null||!this._pauseLocks.has(p))l=!1;else if(this._pauseLocks.delete(p),this._pauseLocks.size===0){if(this._paused=!1,this._pauseBuffer!=null&&this._pauseBuffer.length>0){let h=this._pauseBuffer;this._pauseBuffer=[],this._emit(h)}this._pendingWave&&(this._pendingWave=!1,this._maybeRunFnOnSettlement())}}l?s?.push(u):s==null&&(s=n.slice(0,a))}if(s!=null){if(s.length===0)return;n=s}if(this._hasMeta&&n.some(a=>a[0]===H))for(let a of Object.keys(this.meta))try{this.meta[a]._emit(rt)}catch{}let{finalMessages:o,equalsError:i}=this._updateState(n);if(o.length>0&&this._config.inspectorEnabled){let a=this._config.globalInspector;if(a!=null)try{a({kind:"emit",node:this,messages:o})}catch{}}if(o.length>0)if(this._paused&&this._pausable==="resumeAll"&&this._pauseBuffer!=null){let a=this._config.tierOf,u=[];for(let c of o)a(c[0])===3?this._pauseBuffer.push(c):u.push(c);u.length>0&&this._dispatchOrAccumulate(u)}else this._dispatchOrAccumulate(o);i!=null&&this._emit([[P,i]])}_updateState(e){let n=this._config.tierOf,r,s,o=-1,i=0;for(let l of e)n(l[0])===3&&i++;let a=i<=1,u=-1;if(this._versioning!=null&&i>1){for(let l=e.length-1;l>=0;l--)if(e[l][0]===V){u=l;break}}for(let l=0;l<e.length;l++){let p=e[l],h=p[0];if(h===V){if(p.length>=2){let f=!1;if(a&&this._cached!==void 0)try{f=this._equals(this._cached,p[1])}catch(d){s=this._wrapFnError("equals threw",d),o=l;break}if(f){r==null&&(r=e.slice(0,l)),r.push(et),this._status="resolved";continue}this._cached=p[1],this._versioning!=null&&(u<0||l===u)&&St(this._versioning,p[1],this._hashFn)}this._status="settled",r?.push(p)}else if(r?.push(p),h===Z)this._status="dirty";else if(h===Q)this._status="resolved";else if(h===J){this._status="completed";{let f=this._config.rigorRecorder;if(f!=null)try{f.onTerminalTransition(this,"completed",this._autoComplete,this._autoError,this._deps.length>0)}catch{}}}else if(h===P){this._status="errored";{let f=this._config.rigorRecorder;if(f!=null)try{f.onTerminalTransition(this,"errored",this._autoComplete,this._autoError,this._deps.length>0)}catch{}}}else if(h===Y){if(this._cached!==void 0){let d=this._config.rigorRecorder;if(d!=null)try{d.onNonVacuousInvalidate(this,this._cached)}catch{}}this._cached=void 0,this._status="dirty";let f=this._cleanup;if(typeof f=="function"){this._cleanup=void 0;try{f()}catch{}}else if(f!=null&&typeof f=="object"){let d=f.invalidate;if(typeof d=="function")try{d()}catch{}}}else h===H&&(this._resetOnTeardown&&(this._cached=void 0),this._deactivate(!0),this._status="sentinel")}let c=o>=0?r??e.slice(0,o):r??e;return s!=null?{finalMessages:c,equalsError:s}:{finalMessages:c}}_deliverToSinks=e=>{if(this._sinks==null)return;if(typeof this._sinks=="function"){this._sinks(e);return}let n=[...this._sinks];for(let r of n)r(e)};_dispatchOrAccumulate(e){if(wt()){this._batchPendingMessages===null&&(this._batchPendingMessages=[],ve(()=>this._flushBatchPending()));for(let n of e)this._batchPendingMessages.push(n);return}ke(this._deliverToSinks,e,this._config.tierOf)}_flushBatchPending(){let e=this._batchPendingMessages;if(e===null||(this._batchPendingMessages=null,e.length===0))return;let n=this._frameBatch(e);ke(this._deliverToSinks,n,this._config.tierOf)}},Gt=t=>Array.isArray(t),ct=t=>typeof t=="object"&&t!=null&&!Array.isArray(t)});function te(t,e){return De([],{...e,initial:t})}function It(t,e){return De((r,s,o)=>t(s,o)??void 0,{describeKind:"producer",...e})}function ue(t,e,n){return De(t,(s,o,i)=>{let a=s.map((u,c)=>u!=null&&u.length>0?u.at(-1):i.prevData[c]);o.emit(e(a,i))},{describeKind:"derived",...n})}var lt=W(()=>{"use strict";xe()});function ft(t){return t.subscribe(()=>{})}var Lt=W(()=>{"use strict"});var Ie,Pt=W(()=>{"use strict";Ie=class{_timer;_gen=0;start(e,n){this.cancel(),this._gen+=1;let r=this._gen;this._timer=setTimeout(()=>{this._timer=void 0,r===this._gen&&n()},e)}cancel(){this._timer!==void 0&&(clearTimeout(this._timer),this._timer=void 0)}get pending(){return this._timer!==void 0}}});var Ar={};hn(Ar,{collection:()=>Rr,decay:()=>mt,knowledgeGraph:()=>Sr,lightCollection:()=>Nr,vectorIndex:()=>kr});module.exports=mn(Ar);Oe();lt();Ze();Qe();Oe();Ce();Se();Ce();xe();function Ge(t,e){if(e!=null&&e.length>0)return new Set(e);switch(t){case"standard":return new Set(["type","status","value","deps","meta","v"]);case"full":return null;default:return new Set(["type","deps"])}}function Sn(t){return t._describeKind!=null?t._describeKind:t._deps.length>0?"derived":t._fn!=null?"producer":"state"}function An(t){let e={};for(let[n,r]of Object.entries(t.meta))try{e[n]=r.cache}catch{}return e}function dt(t,e){let n=e==null,r=!n&&e!=null?[...e].filter(c=>c.startsWith("meta.")).map(c=>c.slice(5)):null,s=n||e.has("meta")||r!=null&&r.length>0,o="state",i=[];t instanceof I&&(o=Sn(t),i=t._deps.map(c=>c.node.name??""));let a={type:o,deps:i};(n||e.has("status"))&&(a.status=t.status);let u=t instanceof I?t._guard:void 0;if(s){let c={...An(t)};if(u!=null&&c.access===void 0&&(c.access=st(u)),r!=null&&r.length>0&&!e.has("meta")){let l={};for(let p of r)p in c&&(l[p]=c[p]);a.meta=l}else a.meta=c}if(t.name!=null&&(a.name=t.name),n||e.has("value")){t.status==="sentinel"&&(a.sentinel=!0);try{a.value=t.cache}catch{}}if((n||e.has("v"))&&t.v!=null){let c={id:t.v.id,version:t.v.version};"cid"in t.v&&(c.cid=t.v.cid,c.prev=t.v.prev),a.v=c}return(n||e.has("guard"))&&u!=null&&(a.guard=st(u)),(n||e.has("lastMutation"))&&t.lastMutation!=null&&(a.lastMutation=t.lastMutation),a}xe();lt();Lt();Pt();var we=class{constructor(e){this.capacity=e;if(!Number.isInteger(e)||e<=0)throw new Error(`RingBuffer capacity must be a positive integer (got ${e})`);this.buf=new Array(e)}buf;head=0;_size=0;get size(){return this._size}get maxSize(){return this.capacity}push(e){let n=(this.head+this._size)%this.capacity;this.buf[n]=e,this._size<this.capacity?this._size++:this.head=(this.head+1)%this.capacity}shift(){if(this._size===0)return;let e=this.buf[this.head];return this.buf[this.head]=void 0,this.head=(this.head+1)%this.capacity,this._size--,e}at(e){if(this._size===0)return;let n=e<0?this._size+e:e;if(!(n<0||n>=this._size))return this.buf[(this.head+n)%this.capacity]}toArray(){let e=new Array(this._size);for(let n=0;n<this._size;n++)e[n]=this.buf[(this.head+n)%this.capacity];return e}clear(){for(let e=0;e<this._size;e++)this.buf[(this.head+e)%this.capacity]=void 0;this.head=0,this._size=0}};Xe();function pt(t){return t>=768&&t<=879||t>=1155&&t<=1161||t>=1425&&t<=1469||t>=1552&&t<=1562||t>=1611&&t<=1631||t>=1648&&t===1648||t>=1750&&t<=1756||t>=1759&&t<=1764||t>=1767&&t<=1768||t>=1770&&t<=1773||t>=1840&&t<=1866||t>=1958&&t<=1968||t>=2304&&t<=2307||t>=2362&&t<=2383||t>=2385&&t<=2391||t>=2402&&t<=2403||t>=2433&&t<=2435||t>=2492&&t<=2509||t>=2561&&t<=2563||t>=2620&&t<=2641||t>=2672&&t<=2673||t>=2677&&t===2677||t>=3633&&t===3633||t>=3636&&t<=3642||t>=3655&&t<=3662||t>=3761&&t===3761||t>=3764&&t<=3772||t>=3784&&t<=3790||t>=7616&&t<=7679||t>=8400&&t<=8447||t>=65024&&t<=65039||t>=65056&&t<=65071||t===8205?0:t>=4352&&t<=4447||t>=8986&&t<=8987||t>=9001&&t<=9002||t>=9193&&t<=9203||t>=9208&&t<=9210||t>=9725&&t<=9726||t>=9748&&t<=9749||t>=9800&&t<=9811||t===9855||t===9875||t===9889||t>=9898&&t<=9899||t>=9917&&t<=9918||t>=9924&&t<=9925||t===9934||t===9940||t===9962||t>=9970&&t<=9971||t===9973||t===9978||t===9981||t===9986||t===9989||t>=9992&&t<=9997||t===9999||t>=10067&&t<=10069||t===10071||t>=10133&&t<=10135||t===10160||t===10175||t>=10548&&t<=10549||t>=11013&&t<=11015||t>=11035&&t<=11036||t===11088||t===11093||t>=11904&&t<=12350||t>=12352&&t<=12447||t>=12448&&t<=12543||t>=12549&&t<=12591||t>=12593&&t<=12686||t>=12688&&t<=12771||t>=12784&&t<=12830||t>=12832&&t<=12871||t>=12880&&t<=19903||t>=19968&&t<=40959||t>=43360&&t<=43388||t>=44032&&t<=55203||t>=63744&&t<=64255||t>=65040&&t<=65049||t>=65072&&t<=65131||t>=65281&&t<=65376||t>=65504&&t<=65510||t>=126980&&t===126980||t===127183||t>=127344&&t<=127345||t===127358||t===127359||t===127374||t>=127377&&t<=127386||t>=127456&&t<=127487||t>=127488&&t<=127490||t===127514||t===127535||t>=127538&&t<=127546||t>=127568&&t<=127569||t>=127744&&t<=129535||t>=129536&&t<=129791||t>=129792&&t<=130047||t>=131072&&t<=196605||t>=196608&&t<=262141?2:1}function Le(t){let e=0;for(let n of t)e+=pt(n.codePointAt(0));return e}function $t(t,e){if(e<=0)return"";let n=0,r="";for(let s of t){let o=pt(s.codePointAt(0));if(n+o>e){if(e<=1)return"\u2026";for(;n+1>e&&r.length>0;){let i=[...r].pop();r=r.slice(0,-i.length),n-=pt(i.codePointAt(0))}return`${r}\u2026`}r+=s,n+=o}return r}var Cn={horizontal:"\u2500",vertical:"\u2502",cornerTL:"\u250C",cornerTR:"\u2510",cornerBL:"\u2514",cornerBR:"\u2518",tDown:"\u252C",tUp:"\u2534",tRight:"\u251C",tLeft:"\u2524",cross:"\u253C",arrowRight:"\u25B6",arrowDown:"\u25BC",arrowLeft:"\u25C0",arrowUp:"\u25B2",boxTL:"\u250C",boxTR:"\u2510",boxBL:"\u2514",boxBR:"\u2518",boxH:"\u2500",boxV:"\u2502"},Mn={horizontal:"-",vertical:"|",cornerTL:"+",cornerTR:"+",cornerBL:"+",cornerBR:"+",tDown:"+",tUp:"+",tRight:"+",tLeft:"+",cross:"+",arrowRight:">",arrowDown:"v",arrowLeft:"<",arrowUp:"^",boxTL:"+",boxTR:"+",boxBL:"+",boxBR:"+",boxH:"-",boxV:"|"};function Bt(t,e){let n=e.charset==="ascii"?Mn:Cn,r=t.width,s=t.height,o=Array.from({length:s},()=>Array.from({length:r},()=>" ")),i=Array.from({length:s},()=>Array.from({length:r},()=>"empty"));for(let a of t.edges)Gn(o,i,n,a);for(let a of t.boxes)Dn(o,i,n,a,e.labelOf(a.id));return o.map(a=>$n(a.join(""))).join(`
2
- `)}function Dn(t,e,n,r,s){let{x:o,y:i,w:a,h:u}=r;if(a<2||u<2){u>0&&Ft(t,e,o,i,a,s);return}se(t,e,o,i,n.boxTL);for(let l=o+1;l<o+a-1;l+=1)se(t,e,l,i,n.boxH);se(t,e,o+a-1,i,n.boxTR);for(let l=i+1;l<i+u-1;l+=1){se(t,e,o,l,n.boxV);for(let p=o+1;p<o+a-1;p+=1)jt(t,e,p,l," ","empty");se(t,e,o+a-1,l,n.boxV)}se(t,e,o,i+u-1,n.boxBL);for(let l=o+1;l<o+a-1;l+=1)se(t,e,l,i+u-1,n.boxH);se(t,e,o+a-1,i+u-1,n.boxBR);let c=i+Math.floor(u/2);Ft(t,e,o+1,c,a-2,s)}function se(t,e,n,r,s){jt(t,e,n,r,s,s===" "?"empty":s==="\u2500"||s==="-"?"boxH":s==="\u2502"||s==="|"?"boxV":"boxCorner")}function jt(t,e,n,r,s,o){if(r<0||r>=t.length)return;let i=t[r];n<0||n>=i.length||(i[n]=s,e[r][n]=o)}function Ft(t,e,n,r,s,o){if(r<0||r>=t.length)return;let i=n,a=s;for(let u of o){let c=Le(u);if(c!==0){if(a<c)break;i>=0&&i<t[r].length&&(t[r][i]=u,e[r][i]="label",c===2&&i+1<t[r].length&&(t[r][i+1]="",e[r][i+1]="label")),i+=c,a-=c}}for(;a>0;)i>=0&&i<t[r].length&&(t[r][i]=" ",e[r][i]="empty"),i+=1,a-=1}function Gn(t,e,n,r){let s=r.points;if(s.length<2)return;for(let u=0;u+1<s.length;u+=1)In(t,e,n,s[u],s[u+1]);for(let u=1;u+1<s.length;u+=1){let c=s[u-1],l=s[u],p=s[u+1],h=Ln(c,l,p,n);h&&Ht(t,e,l.x,l.y,h,"edgeCorner")}let o=s[s.length-1],i=s[s.length-2],a=Pn(i,o,n);a&&Ht(t,e,o.x,o.y,a,"arrow")}function In(t,e,n,r,s){if(!(r.x===s.x&&r.y===s.y)){if(r.y===s.y){let o=r.y,i=Math.min(r.x,s.x),a=Math.max(r.x,s.x);for(let u=i;u<=a;u+=1)Vt(t,e,u,o,n,"h")}else if(r.x===s.x){let o=r.x,i=Math.min(r.y,s.y),a=Math.max(r.y,s.y);for(let u=i;u<=a;u+=1)Vt(t,e,o,u,n,"v")}}}function Vt(t,e,n,r,s,o){if(r<0||r>=t.length)return;let i=t[r];if(n<0||n>=i.length)return;let a=e[r][n];if(!(a==="boxH"||a==="boxV"||a==="boxCorner"||a==="label")){if(a==="empty"){i[n]=o==="h"?s.horizontal:s.vertical,e[r][n]=o==="h"?"edgeH":"edgeV";return}if(a==="edgeH"&&o==="v"){i[n]=s.cross,e[r][n]="edgeCorner";return}if(a==="edgeV"&&o==="h"){i[n]=s.cross,e[r][n]="edgeCorner";return}}}function Ht(t,e,n,r,s,o){if(r<0||r>=t.length)return;let i=t[r];if(n<0||n>=i.length)return;let a=e[r][n];a==="boxH"||a==="boxV"||a==="boxCorner"||a==="label"||(i[n]=s,e[r][n]=o)}function Ln(t,e,n,r){let s=t.y===e.y,o=e.y===n.y;if(s===o)return;if(s){let u=t.x<e.x,c=n.y>e.y;return u&&c?r.cornerTR:u&&!c?r.cornerBR:!u&&c?r.cornerTL:r.cornerBL}let i=t.y<e.y,a=n.x>e.x;return i&&a?r.cornerBL:i&&!a?r.cornerBR:!i&&a?r.cornerTL:r.cornerTR}function Pn(t,e,n){if(e.x>t.x)return n.arrowRight;if(e.x<t.x)return n.arrowLeft;if(e.y>t.y)return n.arrowDown;if(e.y<t.y)return n.arrowUp}function $n(t){let e=t.length;for(;e>0&&t.charCodeAt(e-1)===32;)e-=1;return t.slice(0,e)}function Wt(t){let e=Fn(t);Vn(e),Hn(e),Bn(e),jn(e,t);let n=Wn(e,t),{width:r,height:s}=qn(e),o=[];for(let i of e.layers)for(let a of i)a.isVirtual||o.push({id:a.id,layer:a.layer,order:a.order,x:a.x,y:a.y,w:a.w,h:a.h});return{boxes:o,edges:n,width:r,height:s}}function Fn(t){let e=new Map;for(let s of t.nodes)e.set(s,{id:s,isVirtual:!1,layer:-1,order:0,x:0,y:0,w:t.widthCells(s),h:t.heightCells(s),in:[],out:[]});let n=[],r=0;for(let s of t.edges){if(s.from===s.to)continue;let o=e.get(s.from),i=e.get(s.to);if(!o||!i)continue;let a={chainId:r++,chainFrom:s.from,chainTo:s.to,fromId:s.from,toId:s.to,hopIndex:0,chainLen:1};o.out.push(a),i.in.push(a),n.push(a)}return{nodes:e,layers:[],hops:n}}function Vn(t){let e=new Map;for(let o of t.nodes.values())e.set(o.id,o.in.length);let n=[];for(let o of t.nodes.values())(e.get(o.id)??0)===0&&(o.layer=0,n.push(o));let r=new Set,s=0;for(;s<n.length;){let o=n[s++];if(!r.has(o.id)){r.add(o.id);for(let i of o.out){let a=t.nodes.get(i.toId);a.layer=Math.max(a.layer,o.layer+1);let u=(e.get(a.id)??0)-1;e.set(a.id,u),u<=0&&n.push(a)}}}for(let o of t.nodes.values())o.layer<0&&(o.layer=0)}function Hn(t){let e=Math.max(0,...Array.from(t.nodes.values(),o=>o.layer)),n=Array.from({length:e+1},()=>[]);for(let o of t.nodes.values())n[o.layer].push(o);let r=[],s=0;for(let o of t.hops){let i=t.nodes.get(o.fromId),a=t.nodes.get(o.toId),u=a.layer-i.layer;if(u<=0){i.out=i.out.filter(p=>p!==o),a.in=a.in.filter(p=>p!==o);continue}if(u===1){o.hopIndex=0,o.chainLen=1,r.push(o);continue}i.out=i.out.filter(p=>p!==o),a.in=a.in.filter(p=>p!==o);let c=i;for(let p=1;p<u;p+=1){let h=`__virt_${s++}__`,f={id:h,isVirtual:!0,layer:i.layer+p,order:0,x:0,y:0,w:0,h:1,in:[],out:[]};t.nodes.set(h,f),n[f.layer].push(f);let d={chainId:o.chainId,chainFrom:o.chainFrom,chainTo:o.chainTo,fromId:c.id,toId:h,hopIndex:p-1,chainLen:u};c.out.push(d),f.in.push(d),r.push(d),c=f}let l={chainId:o.chainId,chainFrom:o.chainFrom,chainTo:o.chainTo,fromId:c.id,toId:a.id,hopIndex:u-1,chainLen:u};c.out.push(l),a.in.push(l),r.push(l)}for(let o of n)for(let i=0;i<o.length;i+=1)o[i].order=i;t.layers=n,t.hops=r}function Bn(t){for(let n=0;n<4;n+=1){for(let r=1;r<t.layers.length;r+=1)zt(t,t.layers[r],"in"),Pe(t.layers[r]);for(let r=t.layers.length-2;r>=0;r-=1)zt(t,t.layers[r],"out"),Pe(t.layers[r])}for(let n=0;n<2;n+=1){let r=!1;for(let s=1;s<t.layers.length;s+=1){let o=t.layers[s];for(let i=0;i+1<o.length;i+=1){let a=Ut(t,o[i],o[i+1],"in");[o[i],o[i+1]]=[o[i+1],o[i]],Pe(o),Ut(t,o[i],o[i+1],"in")<a?r=!0:([o[i],o[i+1]]=[o[i+1],o[i]],Pe(o))}}if(!r)break}}function zt(t,e,n){let r=new Map;for(let s of e){let o=n==="in"?s.in:s.out;if(o.length===0){r.set(s.id,s.order);continue}let i=0,a=0;for(let u of o){let c=t.nodes.get(n==="in"?u.fromId:u.toId);c&&(i+=c.order,a+=1)}r.set(s.id,a===0?s.order:i/a)}e.sort((s,o)=>{let i=r.get(s.id),a=r.get(o.id);return i!==a?i-a:s.order-o.order})}function Pe(t){for(let e=0;e<t.length;e+=1)t[e].order=e}function Ut(t,e,n,r){let s=r==="in"?e.in:e.out,o=r==="in"?n.in:n.out,i=0;for(let a of s)for(let u of o){let c=t.nodes.get(r==="in"?a.fromId:a.toId)?.order??0,l=t.nodes.get(r==="in"?u.fromId:u.toId)?.order??0;(e.order<n.order&&c>l||e.order>n.order&&c<l)&&(i+=1)}return i}function jn(t,e){e.direction==="LR"?zn(t,e):Un(t,e)}function zn(t,e){let n=[],r=0;for(let s=0;s<t.layers.length;s+=1){n.push(r);let o=0;for(let i of t.layers[s])o=Math.max(o,i.w);r+=o+e.layerGap}for(let s=0;s<t.layers.length;s+=1)for(let o of t.layers[s])o.x=n[s];for(let s of t.layers){let o=0;for(let i of s)i.y=o,o+=i.h+e.nodeGap}Kt(t,e,"y")}function Un(t,e){let n=[],r=0;for(let s=0;s<t.layers.length;s+=1){n.push(r);let o=0;for(let i of t.layers[s])o=Math.max(o,i.h);r+=o+e.layerGap}for(let s=0;s<t.layers.length;s+=1)for(let o of t.layers[s])o.y=n[s];for(let s of t.layers){let o=0;for(let i of s)i.x=o,o+=i.w+e.nodeGap}Kt(t,e,"x")}function Kt(t,e,n){let r=o=>n==="y"?o.h:o.w,s=e.nodeGap;for(let o=0;o<2;o+=1){let i=o===0?t.layers.slice(1):t.layers.slice(0,-1).reverse();for(let a of i){let u=new Map;for(let l of a){let p=o===0?l.in:l.out;if(p.length===0)continue;let h=[];for(let d of p){let g=t.nodes.get(o===0?d.fromId:d.toId);if(!g)continue;let m=n==="y"?g.y:g.x;h.push(m+Math.floor(r(g)/2))}if(h.length===0)continue;h.sort((d,g)=>d-g);let f=h[Math.floor(h.length/2)];u.set(l.id,f-Math.floor(r(l)/2))}let c=0;for(let l of a){let p=u.get(l.id),h=n==="y"?l.y:l.x,d=Math.max(p??h,c);n==="y"?l.y=d:l.x=d,c=d+r(l)+s}}}}function Wn(t,e){let n=new Map;for(let c of t.hops){let l=n.get(c.chainId);l?l.push(c):n.set(c.chainId,[c])}for(let c of n.values())c.sort((l,p)=>l.hopIndex-p.hopIndex);let r=e.direction==="LR",s=c=>r?c.x:c.y,o=c=>r?c.w:c.h,i=c=>r?c.y+Math.floor(c.h/2):c.x+Math.floor(c.w/2),a=new Map;for(let c=0;c+1<t.layers.length;c+=1){let l=t.layers[c],p=t.layers[c+1],h=0;for(let E of l)h=Math.max(h,s(E)+o(E));let f=Number.POSITIVE_INFINITY;for(let E of p)f=Math.min(f,s(E));let d=Number.isFinite(f)?f-1:h,g=Math.max(1,d-h+1),m=[];for(let E of l)for(let N of E.out)m.push(N);m.sort((E,N)=>{let A=i(t.nodes.get(E.fromId)),R=i(t.nodes.get(N.fromId));if(A!==R)return A-R;let S=i(t.nodes.get(E.toId)),k=i(t.nodes.get(N.toId));return S-k});let y=[],_=new Map;for(let E of m){let N=i(t.nodes.get(E.fromId)),A=i(t.nodes.get(E.toId)),R=Math.min(N,A),S=Math.max(N,A),k=-1;for(let G=0;G<y.length;G+=1){let B=y[G],q=!0;for(let oe of B)if(oe.lo<=S&&R<=oe.hi){q=!1;break}if(q){B.push({lo:R,hi:S}),k=G;break}}k<0&&(y.push([{lo:R,hi:S}]),k=y.length-1),_.set(E,k)}let b=y.length,v=g>=Math.max(3,b+2),T=v?h+1:h,x=v?d-1:d,w=Math.max(1,x-T+1);for(let E of m){let N=_.get(E),A;if(b<=1)A=T+Math.floor(w/2);else{let R=(w-1)/(b-1);A=T+Math.floor(N*R)}a.set(E,Math.max(h,Math.min(d,A)))}}let u=[];for(let[,c]of n){let l=[];for(let h=0;h<c.length;h+=1){let f=c[h],d=t.nodes.get(f.fromId),g=t.nodes.get(f.toId),m=a.get(f),y=d.isVirtual?s(d):s(d)+o(d),_=g.isVirtual?s(g):s(g)-1,b=i(d),v=i(g);h===0&&$e(l,r,y,b),b!==v&&($e(l,r,m,b),$e(l,r,m,v)),$e(l,r,_,v)}let p=c[0];u.push({from:p.chainFrom,to:p.chainTo,points:Kn(l)})}return u}function $e(t,e,n,r){t.push(e?{x:n,y:r}:{x:r,y:n})}function Kn(t){let e=[];for(let n of t){let r=e[e.length-1];(!r||r.x!==n.x||r.y!==n.y)&&e.push(n)}return e}function qn(t){let e=0,n=0;for(let r of t.layers)for(let s of r)e=Math.max(e,s.x+s.w),n=Math.max(n,s.y+s.h);return{width:e,height:n}}var Yn=24,Jn=4,Xn=1,Zn=3;function qt(t,e){let n=Qn(e.direction),r=Math.max(3,e.maxLabelWidth??Yn),s=e.asciiCharset??"unicode",o=Object.keys(t.nodes).sort(),i=new Set(o),a=t.edges.filter(f=>i.has(f.from)&&i.has(f.to)),u=new Map,c=new Map;for(let f of o){let d=$t(f,r);u.set(f,d),c.set(f,Le(d)+4)}let l=Wt({nodes:o,edges:a,widthCells:f=>c.get(f)??3,heightCells:()=>Zn,layerGap:Jn,nodeGap:Xn,direction:n}),p=Bt(l,{charset:s,labelOf:f=>u.get(f)??f}),h=e.logger;return h&&h(p),p}function Qn(t){if(t===void 0||t==="LR")return"LR";if(t==="TD")return"TD";throw new Error(`ascii describe supports direction "LR" or "TD" only; got ${String(t)}`)}function Yt(t,e,n,r={}){let s=e in t.nodes,o=n in t.nodes;if(!s)return Fe(e,n,"no-such-from");if(!o)return Fe(e,n,"no-such-to");let i=r.maxDepth;if(i!=null&&(!Number.isInteger(i)||i<0))throw new Error("explainPath: maxDepth must be an integer >= 0");if(e===n){if(r.findCycle===!0){let c=er(t,e,r);if(c!=null)return c}let u=Ve(e,t.nodes[e],0,r);return He(e,n,[u])}if(i===0)return Fe(e,n,"no-path");let a=Jt(t,e,n,i);return a.found?He(e,n,Xt(t,a.pathOrder,r)):Fe(e,n,a.truncated?"max-depth-exceeded":"no-path")}function Jt(t,e,n,r){let s=new Map,o=[{path:n,depth:0}],i=new Set([n]),a=0,u=!1;for(;a<o.length;){let p=o[a++];if(p.path===e)break;if(r!=null&&p.depth>=r){let g=t.nodes[p.path];g?.deps&&g.deps.length>0&&(u=!0);continue}let h=t.nodes[p.path];if(h==null)continue;let f=h.deps??[],d=new Map;for(let g=0;g<f.length;g++){let m=f[g];if(!m)continue;let y=d.get(m);y==null&&(y=[],d.set(m,y)),y.push(g)}for(let[g,m]of d)i.has(g)||(i.add(g),s.set(g,{from:p.path,depIndices:m}),o.push({path:g,depth:p.depth+1}))}if(!s.has(e))return{found:!1,pathOrder:[],truncated:u};let c=[{path:e}],l=e;for(;l!==n;){let p=s.get(l);if(p==null)return{found:!1,pathOrder:[],truncated:!1};c[c.length-1].depIndices=p.depIndices,c.push({path:p.from}),l=p.from}return{found:!0,pathOrder:c,truncated:!1}}function er(t,e,n){let r=t.nodes[e];if(r==null)return null;let s=r.deps??[],o=[];for(let a=0;a<s.length;a++)s[a]===e&&o.push(a);if(o.length>0){let a=Ve(e,r,0,n);a.dep_index=o[0];let u=Ve(e,r,1,n);return He(e,e,[a,u])}let i=null;for(let a=0;a<s.length;a++){let u=s[a];if(!u||u===e)continue;let c=Jt(t,u,e,n.maxDepth);c.found&&(i==null||c.pathOrder.length<i.pathOrder.length)&&(i=c,i={found:!0,pathOrder:[{path:e,depIndices:[a]},...c.pathOrder],truncated:!1})}return i==null?null:He(e,e,Xt(t,i.pathOrder,n))}function Xt(t,e,n){return e.map((r,s)=>{let o=t.nodes[r.path],i=Ve(r.path,o,s,n);return r.depIndices!=null&&r.depIndices.length>0&&(i.dep_index=r.depIndices[0],r.depIndices.length>1&&(i.dep_indices=[...r.depIndices])),i})}function Ve(t,e,n,r){let s={path:t,type:e.type,hop:n};e.status!==void 0&&(s.status=e.status),"value"in e&&(s.value=e.value),e.v!=null&&(s.v=e.v);let o=r.annotations?.get(t)??e.annotation;o!=null&&(s.annotation=o);let i=r.lastMutations?.get(t)??e.lastMutation;return i!=null&&(s.lastMutation=i),s}function He(t,e,n){return Zt(t,e,!0,"ok",n)}function Fe(t,e,n){return Zt(t,e,!1,n,[])}function Zt(t,e,n,r,s){let o=tr(t,e,n,r,s);return{from:t,to:e,found:n,reason:r,steps:s,text:o,toJSON(){return{from:t,to:e,found:n,reason:r,steps:s}}}}function tr(t,e,n,r,s){if(!n)switch(r){case"no-such-from":return`explainPath: no node named "${t}"`;case"no-such-to":return`explainPath: no node named "${e}"`;case"max-depth-exceeded":return`explainPath: no path from "${t}" to "${e}" within maxDepth`;default:return`explainPath: no path from "${t}" to "${e}"`}let o=[`Causal path: ${t} \u2192 ${e} (${s.length} step(s))`];for(let i of s){let u=` ${i.hop===0?"\xB7":"\u2193"} ${i.path} (${i.type}${i.status?`/${i.status}`:""})`;if(o.push(u),"value"in i&&o.push(` value: ${nr(i.value)}`),i.annotation!=null&&o.push(` annotation: ${i.annotation}`),i.lastMutation!=null){let c=i.lastMutation.actor;o.push(` actor: ${c.type}${c.id?`:${c.id}`:""}`)}}return o.join(`
3
- `)}function nr(t){if(t===void 0)return"<sentinel>";if(t===null)return"null";if(typeof t=="string")return JSON.stringify(t);if(typeof t=="number"||typeof t=="boolean"||typeof t=="bigint")return String(t);try{let e=JSON.stringify(t);return e.length>80?`${e.slice(0,77)}...`:e}catch{return String(t)}}xe();var L={object:56,array:64,string:40,number:8,boolean:4,null:0,undefined:0,symbol:40,bigint:16,function:120,map:72,set:72,mapEntry:40,setEntry:24,date:24,regexp:48,error:64,url:80,promise:48,weakmap:40,weakset:40},rr=Symbol.for("sizeof");function Qt(t){let e=new WeakSet,n=new WeakSet,r=[t],s=0;for(;r.length>0;){let o=r.pop();s+=sr(o,e,n,r)}return s}function sr(t,e,n,r){if(t==null)return 0;switch(typeof t){case"number":return L.number;case"boolean":return L.boolean;case"string":return L.string+t.length*2;case"bigint":return L.bigint+or(t);case"symbol":return L.symbol;case"function":return e.has(t)?0:(e.add(t),L.function);case"undefined":return 0}let o=t;if(e.has(o))return 0;e.add(o);let i=o[rr];if(typeof i=="function")try{let c=i.call(o);if(typeof c=="number"&&Number.isFinite(c))return c}catch{}if(o instanceof Date)return L.date;if(o instanceof RegExp)return L.regexp+o.source.length*2;if(o instanceof Error){let c=o.message?o.message.length*2:0,l=o.stack?o.stack.length*2:0;return L.error+c+l}if(typeof URL<"u"&&o instanceof URL)return L.url+o.href.length*2;if(typeof Promise<"u"&&o instanceof Promise)return L.promise;if(o instanceof WeakMap)return L.weakmap;if(o instanceof WeakSet)return L.weakset;if(o instanceof Map){let c=L.map;for(let[l,p]of o)c+=L.mapEntry,r.push(l),r.push(p);return c}if(o instanceof Set){let c=L.set;for(let l of o)c+=L.setEntry,r.push(l);return c}if(Array.isArray(o)){let c=L.array+o.length*8;for(let l of o)r.push(l);return c}if(o instanceof ArrayBuffer)return n.has(o)?0:(n.add(o),o.byteLength);if(ArrayBuffer.isView(o)){let c=o;return n.has(c.buffer)?48:(n.add(c.buffer),c.buffer.byteLength+48)}let a=L.object,u=Object.keys(o);for(let c of u){a+=L.string+c.length*2;try{r.push(o[c])}catch{}}return a}function or(t){let e=t<0n?-t:t;if(e===0n)return 0;let n=e.toString(2).length;return Math.ceil(n/32)*8}function en(t,e){let n=e?.topN??10,r=t.describe({detail:"standard"}),s=[],o=t._collectObserveTargets;typeof o=="function"&&o.call(t,"",s);let i=new Map;for(let[h,f]of s)i.set(h,f);let a=[];for(let[h,f]of Object.entries(r.nodes)){let d=i.get(h),g=d instanceof I?d:null,m=g?Qt(g.cache):0,y=g?g._sinkCount:0,_=f.deps?.length??0,b=f.type==="effect"&&y===0,v=y===0?f.type==="effect"?"orphan-effect":f.type==="derived"?"idle-derived":f.type==="producer"?"idle-producer":null:null;a.push({path:h,type:f.type,status:f.status??"unknown",valueSizeBytes:m,subscriberCount:y,depCount:_,isOrphanEffect:b,orphanKind:v})}let u=a.reduce((h,f)=>h+f.valueSizeBytes,0),c=(h,f)=>[...a].sort(f??((d,g)=>g[h]-d[h])).slice(0,n),l=a.filter(h=>h.orphanKind!=null),p=a.filter(h=>h.isOrphanEffect);return{nodeCount:a.length,edgeCount:r.edges.length,subgraphCount:r.subgraphs.length,nodes:a,totalValueSizeBytes:u,hotspots:{byValueSize:c("valueSizeBytes"),bySubscriberCount:c("subscriberCount"),byDepCount:c("depCount")},orphans:l,orphanEffects:p}}var D="::",X="__meta__",he=1;function tn(t,e){let n=Math.max(16,t.size*4),r=0;for(;t.size>0;){if(r++>=n){console.error(`[Graph "${e}".destroy] disposer drain exceeded cap (${n}); ${t.size} disposer(s) discarded`),t.clear();return}let s=t.values().next();if(s.done)return;let o=s.value;t.delete(o);try{o()}catch(i){console.error(`[Graph "${e}".destroy] disposer threw:`,i)}}}function ir(t){let e=[];for(let n of Object.keys(t).sort()){let r=t[n].v;r!=null&&e.push(`${n} ${r.id} ${r.version}`)}return e.join(`
4
- `)}function nn(t){if(t.version!==he)throw new Error(`unsupported snapshot version ${String(t.version)} (expected ${he})`);for(let e of["name","nodes","edges","subgraphs"])if(!(e in t))throw new Error(`snapshot missing required key "${e}"`);if(typeof t.name!="string")throw new TypeError("snapshot 'name' must be a string");if(typeof t.nodes!="object"||t.nodes===null||Array.isArray(t.nodes))throw new TypeError("snapshot 'nodes' must be an object");if(!Array.isArray(t.edges))throw new TypeError("snapshot 'edges' must be an array");if(!Array.isArray(t.subgraphs))throw new TypeError("snapshot 'subgraphs' must be an array")}function ar(t,e){let n=new WeakMap,r=(s,o)=>{if(Object.is(s,o))return!0;if(s==null||o==null||typeof s!="object"||typeof o!="object")return!1;let i=n.get(s);if(i==null&&(i=new WeakSet,n.set(s,i)),i.has(o))return!0;i.add(o);let a=s.constructor,u=o.constructor;if(a!==u)return!1;if(s instanceof Date)return s.getTime()===o.getTime();if(s instanceof RegExp)return s.source===o.source&&s.flags===o.flags;if(Array.isArray(s)){let h=o;if(s.length!==h.length)return!1;for(let f=0;f<s.length;f++)if(!r(s[f],h[f]))return!1;return!0}if(s instanceof Map){let h=o;if(s.size!==h.size)return!1;for(let[f,d]of s)if(!h.has(f)||!r(d,h.get(f)))return!1;return!0}if(s instanceof Set){let h=o;if(s.size!==h.size)return!1;for(let f of s){let d=!1;for(let g of h)if(r(f,g)){d=!0;break}if(!d)return!1}return!0}if(ArrayBuffer.isView(s)){let h=s,f=o;if(h.length!==f.length)return!1;for(let d=0;d<h.length;d++)if(h[d]!==f[d])return!1;return!0}let c=Object.keys(s),l=Object.keys(o);if(c.length!==l.length)return!1;let p=new Set(l);for(let h of c)if(!p.has(h)||!r(s[h],o[h]))return!1;return!0};return r(t,e)}function gt(t){if(t===null||typeof t!="object")return t;if(Array.isArray(t))return t.map(gt);let e=t,n=Object.keys(e).sort(),r={};for(let s of n)r[s]=gt(e[s]);return r}function ur(t){return t.replaceAll("\\","\\\\").replaceAll('"','\\"')}function cr(t){return t.replaceAll("\\","\\\\").replaceAll('"','\\"')}function lr(t){return t==="TD"?"down":t==="BT"?"up":t==="RL"?"left":"right"}function on(t){let e=new Set,n=[];function r(s,o){let i=`${s}\0${o}`;e.has(i)||(e.add(i),n.push([s,o]))}for(let[s,o]of Object.entries(t.nodes)){let i=o.deps;if(i)for(let a of i)r(a,s)}for(let s of t.edges)r(s.from,s.to);return n}function an(t){if(t===void 0)return"LR";if(t==="TD"||t==="LR"||t==="BT"||t==="RL")return t;throw new Error(`invalid diagram direction ${String(t)}; expected one of: TD, LR, BT, RL`)}function dr(t,e){let n=e.includeEdges??!0,r=e.includeSubgraphs??!0,{expand:s,...o}=t,i={...o,edges:n?t.edges:[],subgraphs:r?t.subgraphs:[]},a=JSON.stringify(gt(i),null,e.indent??2);return e.logger?.(a),a}function fr(t,e){let n=e.includeEdges??!0,r=e.includeSubgraphs??!0,s=[];s.push(`Graph ${t.name}`),s.push("Nodes:");for(let i of Object.keys(t.nodes).sort()){let a=t.nodes[i];s.push(`- ${i} (${a.type}/${a.status}): ${je(a.value)}`)}if(n){s.push("Edges:");for(let i of t.edges)s.push(`- ${i.from} -> ${i.to}`)}if(r){s.push("Subgraphs:");for(let i of t.subgraphs)s.push(`- ${i}`)}let o=s.join(`
5
- `);return e.logger?.(o),o}function un(t,e){let n=an(e.direction),r=Object.keys(t.nodes).sort(),s=new Map;for(let i=0;i<r.length;i+=1)s.set(r[i],`n${i}`);let o=[`flowchart ${n}`];for(let i of r){let a=s.get(i);o.push(` ${a}["${ur(i)}"]`)}for(let[i,a]of on(t)){let u=s.get(i),c=s.get(a);!u||!c||o.push(` ${u} --> ${c}`)}return o.join(`
6
- `)}function pr(t,e){let n=un(t,e);return hr(n)}function hr(t,e){let n=e?.theme??"default",r=e?.autoSync??!0,o=JSON.stringify({code:t,mermaid:{theme:n},autoSync:r}),i=new TextEncoder().encode(o),a="";for(let c=0;c<i.length;c++)a+=String.fromCharCode(i[c]);return`https://mermaid.live/edit#base64:${globalThis.btoa(a).replace(/\+/g,"-").replace(/\//g,"_").replace(/=+$/,"")}`}function gr(t,e){let n=an(e.direction),r=Object.keys(t.nodes).sort(),s=new Map;for(let i=0;i<r.length;i+=1)s.set(r[i],`n${i}`);let o=[`direction: ${lr(n)}`];for(let i of r){let a=s.get(i);o.push(`${a}: "${cr(i)}"`)}for(let[i,a]of on(t)){let u=s.get(i),c=s.get(a);!u||!c||o.push(`${u} -> ${c}`)}return o.join(`
7
- `)}function mr(t){return t.replace(/[.*+?^${}()|[\]\\]/g,"\\$&")}function Be(t){let e="^";for(let n=0;n<t.length;n+=1){let r=t[n];if(r==="*"){e+=".*";continue}if(r==="?"){e+=".";continue}if(r==="["){let s=t.indexOf("]",n+1);if(s<=n+1){e+="\\[";continue}let o=t.slice(n+1,s);o.startsWith("!")&&(o=`^${o.slice(1)}`),o=o.replace(/\\/g,"\\\\"),e+=`[${o}]`,n=s;continue}e+=mr(r)}return e+="$",new RegExp(e)}var br={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"},yr={data:"",dirty:"",resolved:"",invalidate:"",pause:"",resume:"",complete:"",error:"",teardown:"",derived:"",path:"",reset:""};function je(t){if(typeof t=="string")return JSON.stringify(t);if(typeof t=="number"||typeof t=="boolean"||t==null)return String(t);try{return JSON.stringify(t)}catch{return"[unserializable]"}}function vr(t){return t==="none"?yr:t==="ansi"||t==null?br:{data:t.data??"",dirty:t.dirty??"",resolved:t.resolved??"",invalidate:t.invalidate??"",pause:t.pause??"",resume:t.resume??"",complete:t.complete??"",error:t.error??"",teardown:t.teardown??"",derived:t.derived??"",path:t.path??"",reset:t.reset??""}}function rn(t){if(t==null)return{};let e=t.detail;return e==="full"?{...t,structured:t.structured??!0,timeline:t.timeline??!0,causal:t.causal??!0,derived:t.derived??!0}:e==="minimal"?{...t,structured:t.structured??!0}:t.format==="stage-log"?{...t,structured:t.structured??!0,timeline:t.timeline??!0}:t}function _r(t,e,n){for(let r=0;r<t.length;r++){let s=t.charCodeAt(r);if(s<32||s===127)throw new Error(`Graph "${e}": ${n} "${t}" must not contain control character (U+${s.toString(16).padStart(4,"0").toUpperCase()} at index ${r})`)}}function ht(t,e,n){if(t==="")throw new Error(`Graph "${e}": ${n} name must be non-empty`);if(t.includes(D))throw new Error(`Graph "${e}": ${n} "${t}" must not contain '${D}' (path separator)`);if(t===X)throw new Error(`Graph "${e}": ${n} name "${X}" is reserved for meta companion paths`);_r(t,e,n)}function xr(t,e){if(t==="")throw new Error(`Graph "${e}": resolve path must be non-empty`);let n=t.split(D);for(let r of n)if(r==="")throw new Error(`Graph "${e}": resolve path has empty segment`);return n}function wr(t,e){let n=!1;for(let s of t)if(!e.isMetaPassthrough(s[0])){n=!0;break}return n?t.filter(s=>e.isMetaPassthrough(s[0])):t}function cn(t){for(let e of t._mounts.values())cn(e);for(let e of t._nodes.values())try{e.down([[H]],{internal:!0})}catch{}}var ge=class t{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;constructor(e,n){if(e==="")throw new Error("Graph name must be non-empty");if(e.includes(D))throw new Error(`Graph name must not contain '${D}' (got "${e}")`);if(e===X)throw new Error(`Graph name "${X}" is reserved for meta companion paths`);this.name=e,this.opts=Object.freeze({...n??{}}),this.config=n?.config??pe,this._traceRing=new we(n?.traceCapacity??1e3),n?.versioning!=null&&this.setVersioning(n.versioning)}ancestors(e=!0){let n=[],r=e?this:this._parent;for(;r!=null;)n.push(r),r=r._parent;return n}get topology(){return this._topology==null&&(this._topology=It(e=>{let n=r=>{e.emit(r)};return this._topologyEmitters.add(n),()=>{this._topologyEmitters.delete(n)}},{name:`${this.name}_topology`})),this._topology}_emitTopology(e){if(!(this._topology==null||this._topologyEmitters.size===0))for(let n of this._topologyEmitters)n(e)}nameOf(e){return this._nodeToName.get(e)}add(e,n){let r=e.name,s=n?.name??r;if(s==null||s==="")throw new Error(`Graph "${this.name}": graph.add requires a non-empty name \u2014 pass via opts.name or set it on the node (e.g. state(0, { name: "x" }))`);let o=s,i=n?.annotation;if(ht(o,this.name,"add"),this._mounts.has(o))throw new Error(`Graph "${this.name}": name "${o}" is already a mount point`);if(this._nodes.has(o))throw new Error(`Graph "${this.name}": node "${o}" already exists`);let a=this._nodeToName.get(e);if(a!==void 0)throw new Error(`Graph "${this.name}": node instance already registered as "${a}"`);return this._nodes.set(o,e),this._nodeToName.set(e,o),this._emitTopology({kind:"added",name:o,nodeKind:"node"}),i!=null&&(this._annotations.set(o,i),this.config.inspectorEnabled&&this._traceRing.push({path:o,annotation:i,timestamp_ns:j()})),e}setVersioning(e){if(e!=null)for(let n of this._nodes.values())n instanceof I&&n._applyVersioning(e)}remove(e){ht(e,this.name,"remove");let n=this._mounts.get(e);if(n){let o={kind:"mount",nodes:[],mounts:[]},i=[];n._collectObserveTargets("",i);for(let[a,u]of i)a.includes(`${D}${X}${D}`)||o.nodes.push(a);return o.nodes.sort(),o.mounts.push(e),o.mounts.push(...n._collectSubgraphs(`${e}${D}`)),this._mounts.delete(e),n._parent=void 0,cn(n),this._emitTopology({kind:"removed",name:e,nodeKind:"mount",audit:o}),o}let r=this._nodes.get(e);if(!r)throw new Error(`Graph "${this.name}": unknown node or mount "${e}"`);this._nodes.delete(e),this._nodeToName.delete(r),r.down([[H]],{internal:!0});let s={kind:"node",nodes:[e],mounts:[]};return this._emitTopology({kind:"removed",name:e,nodeKind:"node",audit:s}),s}removeAll(e){let n=typeof e=="function"?e:(()=>{let o=Be(e);return i=>o.test(i)})(),r={kind:"mount",nodes:[],mounts:[]},s=[...this._nodes.keys(),...this._mounts.keys()].filter(o=>n(o));for(let o of s){let i=this.remove(o);r.nodes.push(...i.nodes),r.mounts.push(...i.mounts)}return r.nodes.sort(),r.mounts.sort(),r}[Symbol.iterator](){let e=[...this._nodes.keys()].sort(),n=this._nodes,r=0;return{[Symbol.iterator](){return this},next(){if(r>=e.length)return{value:void 0,done:!0};let s=e[r++];return{value:[s,n.get(s)],done:!1}}}}node(e){if(e==="")throw new Error(`Graph "${this.name}": node name must be non-empty`);if(e.includes(D))return this.resolve(e);let n=this._nodes.get(e);if(!n)throw new Error(`Graph "${this.name}": unknown node "${e}"`);return n}get(e){return this.node(e).cache}set(e,n,r){let s=r?.internal===!0;this.node(e).down([[V,n]],{actor:r?.actor,internal:s,delivery:"write"})}setAll(e,n){let r=Symbol.iterator in e?e:Object.entries(e);Tt(()=>{for(let[s,o]of r)this.set(s,o,n)})}invalidate(e,n){let r=n?.internal===!0;this.node(e).down([[Y]],{actor:n?.actor,internal:r,delivery:"write"})}error(e,n,r){let s=r?.internal===!0;this.node(e).down([[P,n]],{actor:r?.actor,internal:s,delivery:"write"})}complete(e,n){let r=n?.internal===!0;this.node(e).down([[J]],{actor:n?.actor,internal:r,delivery:"write"})}edges(e){let n=e?.recursive===!0,r=new Map;if(!n){for(let[u,c]of this._nodes)r.set(c,u);let a=[];for(let[u,c]of this._nodes)if(c instanceof I)for(let l of c._deps){let p=r.get(l.node);p!=null&&a.push([p,u])}return a.sort((u,c)=>u[0]<c[0]?-1:u[0]>c[0]?1:u[1]<c[1]?-1:u[1]>c[1]?1:0),a}let s=[];this._collectObserveTargets("",s);let o=new Map;for(let[a,u]of s)o.set(u,a);let i=[];for(let[a,u]of s)if(u instanceof I)for(let c of u._deps){let l=o.get(c.node);l!=null&&i.push([l,a])}return i.sort((a,u)=>a[0]<u[0]?-1:a[0]>u[0]?1:a[1]<u[1]?-1:a[1]>u[1]?1:0),i}mount(e,n){if(n===void 0){let s=new t(e);return this.mount(e,s)}if(typeof n=="function"){let s=new t(e);return n(s),this.mount(e,s)}let r=n;if(ht(e,this.name,"mount"),this._nodes.has(e))throw new Error(`Graph "${this.name}": cannot mount at "${e}" \u2014 node with that name exists`);if(this._mounts.has(e))throw new Error(`Graph "${this.name}": mount "${e}" already exists`);if(r===this)throw new Error(`Graph "${this.name}": cannot mount a graph into itself`);if(r._parent!=null)throw new Error(`Graph "${this.name}": this child graph is already mounted on "${r._parent.name}"`);for(let s=this;s!=null;s=s._parent)if(s===r)throw new Error(`Graph "${this.name}": mount("${e}", \u2026) would create a mount cycle`);return this._mounts.set(e,r),r._parent=this,this._emitTopology({kind:"added",name:e,nodeKind:"mount"}),r}resolve(e){let n=xr(e,this.name);return this._resolveFromSegments(n)}tryResolve(e){try{return this.resolve(e)}catch{return}}_resolveFromSegments(e){let n=e;if(n[0]===this.name&&(n=n.slice(1),n.length===0))throw new Error(`Graph "${this.name}": resolve path ends at graph name only`);let r=n[0],s=n.slice(1);if(s.length===0){let a=this._nodes.get(r);if(a)return a;throw this._mounts.has(r)?new Error(`Graph "${this.name}": path ends at subgraph "${r}" \u2014 not a node (GRAPHREFLY-SPEC \xA73.5)`):new Error(`Graph "${this.name}": unknown name "${r}"`)}let o=this._nodes.get(r);if(o&&s.length>0&&s[0]===X)return this._resolveMetaChainFromNode(o,s,n.join(D));let i=this._mounts.get(r);if(!i)throw this._nodes.has(r)?new Error(`Graph "${this.name}": "${r}" is a node; trailing path "${s.join(D)}" is invalid`):new Error(`Graph "${this.name}": unknown mount or node "${r}"`);return i.resolve(s.join(D))}_resolveMetaChainFromNode(e,n,r){let s=e,o=0,i=[...n];for(;o<i.length;){if(i[o]!==X)throw new Error(`Graph "${this.name}": expected ${X} segment in meta path "${r}"`);if(o+1>=i.length)throw new Error(`Graph "${this.name}": meta path requires a key after ${X} in "${r}"`);let a=i[o+1],u=s.meta[a];if(!u)throw new Error(`Graph "${this.name}": unknown meta "${a}" in path "${r}"`);s=u,o+=2}return s}signal(e,n){if(n?.internal!==!0){for(let s of e)if(this.config.messageTier(s[0])===3)throw new Error(`Graph "${this.name}": Graph.signal() rejects tier-3 messages (DATA / RESOLVED). Broadcast is for control-plane tiers (START / DIRTY / INVALIDATE / PAUSE / RESUME / COMPLETE / ERROR / TEARDOWN). For per-node value writes, use Graph.set or graph.node(name).down(...).`)}let r=[];if(this._signalDeliver(e,n??{},new Set,r),r.length>0)throw r[0]}_signalDeliver(e,n,r,s){for(let u of this._mounts.values())u._signalDeliver(e,n,r,s);let i=n.internal===!0?{internal:!0}:{actor:n.actor,delivery:"signal"},a=wr(e,this.config);for(let u of[...this._nodes.keys()].sort()){let c=this._nodes.get(u);if(!r.has(c)){r.add(c);try{c.down(e,i)}catch(l){if(l instanceof K)throw l;s.push(l)}a.length!==0&&this._signalMetaSubtree(c,a,r,i,s)}}}_signalMetaSubtree(e,n,r,s,o){for(let i of Object.keys(e.meta).sort()){let a=e.meta[i];if(!r.has(a)){r.add(a);try{a.down(n,s)}catch(u){if(u instanceof K)throw u;o.push(u)}this._signalMetaSubtree(a,n,r,s,o)}}}describe(e){if(e?.reactive===!0)return this._describeReactive(e);let n=e?.actor,r=e?.filter,s=Ge(e?.detail,e?.fields),o=e?.format==="spec",i=o?Ge("minimal"):s,a=[];this._collectObserveTargets("",a);let u=new Map;for(let[x,w]of a)u.set(w,x);let c=[];{let x=a.map(([,N])=>N),w=new Set(u.values()),E=0;for(;x.length>0;){let N=x.shift();if(N instanceof I)for(let A of N._deps){let R=A.node;if(u.has(R))continue;let S=R.name??"",k=S;if(!k||w.has(k))if(S){let G=2;for(;w.has(`${S}#${G}`);)G++;k=`${S}#${G}`}else for(k=`__internal__/${E++}`;w.has(k);)k=`__internal__/${E++}`;u.set(R,k),w.add(k),c.push([k,R]),x.push(R)}}}let l=[...a,...c],p={};for(let[x,w]of l){if(n!=null&&!w.allowsObserve(n))continue;let E=dt(w,i),N=w instanceof I?w._deps.map(k=>u.get(k.node)??k.node.name??""):[],{name:A,...R}=E,S={...R,deps:N};if(!o){let k=this._annotations.get(x);k!=null&&(S.annotation=k)}if(r!=null)if(typeof r=="function"){let k=r;if(!(k.length>=2?k(x,S):k(S)))continue}else{let k=!0;for(let[G,B]of Object.entries(r)){let q=G==="deps_includes"?"depsIncludes":G==="meta_has"?"metaHas":G;if(q==="depsIncludes"){if(!S.deps.includes(String(B))){k=!1;break}continue}if(q==="metaHas"){if(!Object.hasOwn(S.meta??{},String(B))){k=!1;break}continue}if(S[q]!==B){k=!1;break}}if(!k)continue}p[x]=S}let h=new Set(Object.keys(p)),f=[];for(let[x,w]of l)if(w instanceof I)for(let E of w._deps){let N=u.get(E.node);N!=null&&f.push([N,x])}f.sort((x,w)=>x[0]<w[0]?-1:x[0]>w[0]?1:x[1]<w[1]?-1:x[1]>w[1]?1:0);let d=f.map(([x,w])=>({from:x,to:w}));(n!=null||r!=null)&&(d=d.filter(x=>h.has(x.from)&&h.has(x.to)));let g=this._collectSubgraphs(""),m=n!=null||r!=null?g.filter(x=>{let w=`${x}${D}`;return[...h].some(E=>E===x||E.startsWith(w))}):g,y=this,_=e,b={name:this.name,nodes:p,edges:d,subgraphs:m,expand(x){let w={..._,format:void 0};return Array.isArray(x)?(w.fields=x,w.detail=void 0):(w.detail=x,w.fields=void 0),y.describe(w)}},v=e??{},T=v.format;return T==="json"?dr(b,v):T==="pretty"?fr(b,v):T==="mermaid"?un(b,v):T==="mermaid-url"?pr(b,v):T==="d2"?gr(b,v):T==="ascii"?qt(b,v):b}_collectSubgraphs(e){let n=[];for(let r of[...this._mounts.keys()].sort()){let s=e===""?r:`${e}${r}`;n.push(s),n.push(...this._mounts.get(r)._collectSubgraphs(`${s}${D}`))}return n}resourceProfile(e){return en(this,e)}reachable(e,n,r={}){return r.withDetail===!0?sn(this.describe(),e,n,{...r,withDetail:!0}):sn(this.describe(),e,n,r)}explain(e,n,r){return r?.reactive===!0?this._explainReactive(e,n,r):this._explainStatic(e,n,r)}_explainStatic(e,n,r){let s=this.describe({detail:"full"}),o=new Map(this._annotations),i=new Map;for(let[a,u]of Object.entries(s.nodes))u.lastMutation!=null&&i.set(a,u.lastMutation);return Yt(s,e,n,{...r?.maxDepth!=null?{maxDepth:r.maxDepth}:{},...r?.findCycle===!0?{findCycle:!0}:{},annotations:o,lastMutations:i})}_describeReactive(e){let n={...e,reactive:!1},r=e.reactiveName??"describe",s=0,o=te(s,{name:`${r}_version`}),i=this.observe({timeline:!0,structured:!0}),a=!1,u=!1,c=()=>{a||u||(a=!0,ve(()=>{a=!1,!u&&(s+=1,o.emit(s))}))},l=i.onEvent(m=>{let y=m.type;y!=="data"&&y!=="error"&&y!=="complete"&&y!=="teardown"||c()}),p=[],h=new WeakSet,f=m=>{if(h.has(m)||u)return;h.add(m);let y=m.topology.subscribe(_=>{for(let b of _){if(b[0]!==V)continue;let v=b[1];if(c(),v.kind==="added"&&v.nodeKind==="mount"){let T=m._mounts.get(v.name);T!=null&&f(T)}}});p.push(y);for(let _ of m._mounts.keys()){let b=m._mounts.get(_);b!=null&&f(b)}};f(this);let d;try{d=ue([o],()=>this.describe(n),{name:r,describeKind:"derived",meta:{domain:"audit",kind:"describe"},equals:(m,y)=>m===y})}catch(m){l();for(let y of p)y();throw i.dispose(),m}let g=ft(d);return{node:d,dispose(){u=!0,l();for(let m of p)m();p.length=0,i.dispose(),g()}}}_explainReactive(e,n,r){let s=0,o=te(s,{name:"explain_version"}),i=this.observe({timeline:!0,structured:!0}),a=!1,u=!1,c=i.onEvent(f=>{let d=f.type;d!=="data"&&d!=="error"&&d!=="complete"&&d!=="teardown"||a||u||(a=!0,ve(()=>{a=!1,!u&&(s+=1,o.emit(s))}))}),l={...r?.maxDepth!=null?{maxDepth:r.maxDepth}:{},...r?.findCycle===!0?{findCycle:!0}:{}},p;try{p=ue([o],()=>this._explainStatic(e,n,l),{name:r?.name??"explain",describeKind:"derived",meta:{domain:"audit",kind:"explain_path",from:e,to:n},equals:(f,d)=>f.found===d.found&&f.reason===d.reason&&f.steps.length===d.steps.length&&Er(f.steps,d.steps)})}catch(f){throw c(),i.dispose(),f}let h=ft(p);return{node:p,dispose(){u=!0,c(),i.dispose(),h()}}}_pathsMatching(e){let n=Be(e),r=[];return this._collectObserveTargets("",r),r.map(([s])=>s).filter(s=>n.test(s))}_collectObserveTargets(e,n){for(let r of[...this._mounts.keys()].sort()){let s=e===""?r:`${e}${D}${r}`;this._mounts.get(r)._collectObserveTargets(s,n)}for(let r of[...this._nodes.keys()].sort()){let s=this._nodes.get(r),o=e===""?r:`${e}${D}${r}`;n.push([o,s]),this._appendMetaObserveTargets(o,s,n)}}_appendMetaObserveTargets(e,n,r){for(let s of Object.keys(n.meta).sort()){let o=n.meta[s],i=`${e}${D}${X}${D}${s}`;r.push([i,o]),this._appendMetaObserveTargets(i,o,r)}}observe(e,n){let r=typeof e=="string",o=rn(r?n:e),i=o.structured===!0||o.timeline===!0||o.causal===!0||o.derived===!0||o.detail==="minimal"||o.detail==="full"||o.format!=null,a=o.actor;if(r){let l=e,p=this.resolve(l);if(a!=null&&!p.allowsObserve(a))throw new K({actor:a,action:"observe",nodeName:l});return i?this._buildStructuredObserver([[l,p]],o,"one"):{subscribe(h){return p.subscribe(h)},up(h){try{p.up?.(h)}catch(f){if(f instanceof K)return;throw f}}}}let u=[];this._collectObserveTargets("",u),u.sort((l,p)=>l[0]<p[0]?-1:l[0]>p[0]?1:0);let c=a==null?u:u.filter(([,l])=>l.allowsObserve(a));return i?this._buildStructuredObserver(c,o,"all"):{subscribe:l=>{let p=c.map(([h,f])=>f.subscribe(d=>{l(h,d)}));return()=>{for(let h of p)h()}},up:(l,p)=>{try{this.resolve(l).up?.(p)}catch(h){if(h instanceof K)return;throw h}}}}_buildStructuredObserver(e,n,r){let s=r==="one"?e[0]?.[0]:void 0,o=i=>{if(r==="one"&&s!=null){let l=this.resolve(s);return this._buildStructuredObserver([[s,l]],i,"one")}let a=[];this._collectObserveTargets("",a),a.sort((l,p)=>l[0]<p[0]?-1:l[0]>p[0]?1:0);let u=i.actor,c=u==null?a:a.filter(([,l])=>l.allowsObserve(u));return this._buildStructuredObserver(c,i,"all")};return this._createObserveResult(e,n,o)}_createObserveResult(e,n,r){let s=n.timeline===!0,o=n.causal===!0,i=n.derived===!0,a=n.detail==="minimal",u=this.config.inspectorEnabled,c=(o||i)&&u,l=n.maxEvents,p=l!=null&&l>0?new we(l):null,h=[],f=new Set,d={},g=new Set,m=0,y=0,_=0,b=0,v=0,T=0,x=!1,w=!1,E=0,N=new Map,A=new Map,R=new Map,S=O=>{p?p.push(O):h.push(O);for(let M of f)M(O)},k=()=>s?{timestamp_ns:j(),in_batch:Re(),batch_id:E}:{},G=(O,M)=>{if(!(!c||!(O instanceof I)))return O._setInspectorHook(z=>{if(z.kind==="dep_message")N.set(O,z.depIndex);else if(z.kind==="run"){let me=z.batchData.map((C,F)=>C!=null&&C.length>0?C.at(-1):z.prevData[F]);A.set(O,me);let U=z.batchData.map(C=>C!=null?[...C]:void 0);R.set(O,U),i&&S({type:"derived",path:M,dep_values:me,dep_batches:U,...k()})}})},B=O=>{let M=N.get(O),z=A.get(O);if(!o||z==null)return{};let U=(M!=null&&M>=0&&O instanceof I?O._deps[M]:void 0)?.node,C=U?.v,F=R.get(O);return{trigger_dep_index:M,trigger_dep_name:U?.name,...C!=null?{trigger_version:{id:C.id,version:C.version}}:{},dep_values:[...z],...F!=null?{dep_batches:F}:{}}},q=[],oe=[];for(let[O,M]of e){let z=G(M,O);z&&q.push(z),oe.push(M.subscribe(me=>{E++;for(let U of me){let C=U[0],F=k();if(C===V){d[O]=U[1];let qe=M instanceof I?M.lastMutation?.actor??ce:ce;S({type:"data",path:O,data:U[1],actor:qe,...F,...B(M)})}else if(a)C===Z?m++:C===Q?y++:C===Y?_++:C===ee?b++:C===re?v++:C===H?T++:C===J&&!g.has(O)?x=!0:C===P&&(w=!0,g.add(O));else if(C===Z)m++,S({type:"dirty",path:O,...F});else if(C===Q)y++,S({type:"resolved",path:O,...F,...B(M)});else if(C===Y)_++,S({type:"invalidate",path:O,...F});else if(C===ee)b++,S({type:"pause",path:O,lockId:U[1],...F});else if(C===re)v++,S({type:"resume",path:O,lockId:U[1],...F});else if(C===J)g.has(O)||(x=!0),S({type:"complete",path:O,...F});else if(C===P){w=!0,g.add(O);let qe=M instanceof I?M.lastMutation?.actor??ce:ce;S({type:"error",path:O,data:U[1],actor:qe,...F})}else C===H&&(T++,S({type:"teardown",path:O,...F}))}}))}let Ue=!1,We=()=>{if(!Ue){Ue=!0;for(let O of oe)O();for(let O of q)O();for(let O of Te)O({value:void 0,done:!0});Te.length=0}},Ke=[],Te=[];f.add(O=>{let M=Te.shift();M?M({value:O,done:!1}):Ke.push(O)});let bt={get values(){return d},get dirtyCount(){return m},get resolvedCount(){return y},get invalidateCount(){return _},get pauseCount(){return b},get resumeCount(){return v},get teardownCount(){return T},get events(){return p?p.toArray():[...h]},get anyCompletedCleanly(){return x},get anyErrored(){return w},get completedWithoutErrors(){return x&&!w},onEvent(O){return f.add(O),()=>f.delete(O)},dispose:We,expand(O){We();let M={...n};return typeof O=="string"?M.detail=O:Object.assign(M,O),r(rn(M))},[Symbol.asyncIterator](){return{next(){return Ke.length>0?Promise.resolve({value:Ke.shift(),done:!1}):Ue?Promise.resolve({value:void 0,done:!0}):new Promise(O=>Te.push(O))},return(){return We(),Promise.resolve({value:void 0,done:!0})}}}};return n.format!=null&&this._attachFormatLogger(bt,n),bt}_attachFormatLogger(e,n){let r=n.format;if(r==null)return;let s=n.logger??(d=>console.log(d)),o=n.includeTypes?new Set(n.includeTypes):null,i=n.excludeTypes?new Set(n.excludeTypes):null,a=o==null&&i==null?()=>!0:d=>(o==null||o.has(d))&&(i==null||!i.has(d)),u=vr(n.theme),c=r==="stage-log"?j():0,l=d=>d==null?"":n.stageLabels?.[d]??d,p=(d,g)=>d.length>g?`${d.slice(0,g-1)}\u2026`:d,h=d=>d.type==="data"||d.type==="error"?p(je(d.data),120):"",f=d=>{if(r==="stage-log"){let w=(j()-c)/1e9,E=l(d.path).padEnd(9);if(d.type==="data"){let N=h(d);return`[${w.toFixed(3)}s] ${E} \u2190${N?` ${N}`:""}`}if(d.type==="error"){let N=h(d);return`[${w.toFixed(3)}s] ${E} \u2717${N?` ${N}`:""}`}return d.type==="complete"?`[${w.toFixed(3)}s] ${E} \u25A0 complete`:`[${w.toFixed(3)}s] ${E} ${d.type}`}if(r==="json")try{return JSON.stringify(d)}catch{return JSON.stringify({type:d.type,path:d.path,data:"[unserializable]"})}let g=u[d.type]??"",m=d.path?`${u.path}${d.path}${u.reset} `:"",y=d.type==="data"||d.type==="error",_=d.type==="pause"||d.type==="resume",b=y?` ${je(d.data)}`:_?` ${je(d.lockId)}`:"",v=d.type==="data"||d.type==="resolved"||d.type==="derived"?d:void 0,T=v?.trigger_dep_name!=null?` <- ${v.trigger_dep_name}`:v?.trigger_dep_index!=null?` <- #${v.trigger_dep_index}`:"",x=d.in_batch?" [batch]":"";return`${m}${g}${d.type.toUpperCase()}${u.reset}${b}${T}${x}`};e.onEvent(d=>{a(d.type)&&s(f(d),d)})}addDisposer(e){return this._disposers.add(e),()=>{this._disposers.delete(e)}}destroy(){tn(this._disposers,this.name),this.signal([[H]],{internal:!0}),tn(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:n,...r}=this.describe({detail:"full"}),s={};for(let a of Object.keys(r.nodes).sort()){let{lastMutation:u,guard:c,...l}=r.nodes[a];s[a]=l}let o=[...r.subgraphs].sort(),i={...r,version:1,nodes:s,subgraphs:o};if(e?.format==null)return i;if(e.format==="json-string")return JSON.stringify(i);if(e.format==="bytes"){if(e.codec==null)throw new Error("snapshot({format: 'bytes'}) requires a `codec` name");let a=this.config.lookupCodec(e.codec);if(a==null)throw new Error(`snapshot: codec "${e.codec}" is not registered on this graph's config. Call config.registerCodec(...) before creating nodes.`);return vt(a,a.encode(i))}throw new Error(`snapshot: unknown format "${String(e.format)}"`)}static decode(e,n){let r=n?.config??pe,{codec:s,codecVersion:o,payload:i}=_t(e,r);return s.decode(i,o)}restore(e,n){if(nn(e),e.name!==this.name)throw new Error(`Graph "${this.name}": restore snapshot name "${e.name}" does not match this graph`);let r=n?.only==null?null:(Array.isArray(n.only)?n.only:[n.only]).map(o=>Be(o)),s=n?.includeProducers===!0;for(let o of Object.keys(e.nodes).sort()){if(r!==null&&!r.some(a=>a.test(o)))continue;let i=e.nodes[o];if(i!==void 0){if(!("value"in i)||i.value===void 0){"value"in i&&i.value===void 0&&n?.onError?.(o,new Error(`restore: slice.value is undefined for "${o}" (undefined is the global SENTINEL; not valid DATA)`));continue}if(!(i.type==="derived"||i.type==="effect")&&!(i.type==="producer"&&!s)){if(i.v!=null){let u=this.tryResolve(o)?.v;if(u!=null&&u.id===i.v.id&&u.version===i.v.version)continue}try{this.set(o,i.value)}catch(a){n?.onError?.(o,a)}}}}}static fromSnapshot(e,n){nn(e);let r=typeof n=="function"?n:n?.build,s=typeof n=="function"?void 0:n?.factories,o=new t(e.name);if(r)return r(o),o.restore(e),o;for(let f of[...e.subgraphs].sort((d,g)=>{let m=d.split(D).length,y=g.split(D).length;return m!==y?m-y:d<g?-1:d>g?1:0})){let d=f.split(D),g=o;for(let m of d)g._mounts.has(m)||g.mount(m,new t(m)),g=g._mounts.get(m)}let i=s?Object.entries(s).map(([f,d])=>({re:Be(f),factory:d})):[],a=f=>{for(let d of i)if(d.re.test(f))return d.factory},u=f=>{let d=f.split(D),g=d.pop();if(g==null||g.length===0)throw new Error(`invalid snapshot path "${f}"`);let m=o;for(let y of d){let _=m._mounts.get(y);if(!_)throw new Error(`unknown mount "${y}" in path "${f}"`);m=_}return[m,g]},c=Object.entries(e.nodes).filter(([f])=>!f.includes(`${D}${X}${D}`)).sort((f,d)=>f[0]<d[0]?-1:f[0]>d[0]?1:0),l=new Map(c),p=new Map,h=!0;for(;l.size>0&&h;){h=!1;for(let[f,d]of[...l.entries()]){let g=d?.deps??[];if(!g.every(T=>p.has(T)))continue;let[m,y]=u(f),_={...d?.meta??{}},b=a(f),v;if(d?.type==="state")v=te(d.value,{meta:_});else{if(b==null)continue;v=b(y,{path:f,type:d.type,value:d.value,meta:_,deps:g,resolvedDeps:g.map(T=>p.get(T))})}m.add(v,{name:y}),p.set(f,v),l.delete(f),h=!0}}if(l.size>0){let f=[...l.keys()].sort().join(", ");throw new Error(`Graph.fromSnapshot could not reconstruct nodes without build callback: ${f}. Pass matching factories via fromSnapshot(data, { factories: { pattern: factoryFn } }).`)}return o.restore(e),o}toJSON(){return this.snapshot()}attachSnapshotStorage(e,n={}){let r=e.map(c=>({tier:c,debounceMs:Math.max(0,c.debounceMs??0),compactEvery:Math.max(1,c.compactEvery??10),timer:void 0,seq:0,lastSnapshot:void 0,lastFingerprint:"",disposed:!1,savePending:void 0}));n.autoRestore===!0&&this._cascadeRestore(e,n.onError);let s=(c,l)=>{if(c.disposed)return;let p=ir(l.nodes);if(c.lastSnapshot!=null&&p!==""&&p===c.lastFingerprint)return;let h=c.seq+1,f=Ee(),m=c.lastSnapshot==null||h%c.compactEvery===0?{name:this.name,mode:"full",snapshot:l,seq:h,timestamp_ns:f,format_version:he}:{name:this.name,mode:"diff",diff:Tr(c.lastSnapshot,l),seq:h,timestamp_ns:f,format_version:he};if(c.tier.filter&&!c.tier.filter(m))return;let y;try{y=c.tier.save(m)}catch(_){n.onError?.(_,c.tier);return}if(y&&typeof y.then=="function"){let v=(c.savePending??Promise.resolve()).then(()=>y,()=>y).then(()=>{c.disposed||(c.seq=h,c.lastSnapshot=l,c.lastFingerprint=p)},T=>{n.onError?.(T,c.tier)});c.savePending=v.finally(()=>{c.savePending===v&&(c.savePending=void 0)})}else c.seq=h,c.lastSnapshot=l,c.lastFingerprint=p},o=(c,l)=>{try{s(c,l)}catch(p){n.onError?.(p,c.tier)}},i=(c,l)=>{if(!l.some(d=>{let g=this.config.messageTier(d[0]);return g>=3&&g<5}))return;if(n.filter){let d=this.tryResolve(c);if(d==null)return;let g=dt(d,Ge("standard"));if(!n.filter(c,g))return}let h,f=()=>(h==null&&(h=this.snapshot()),h);for(let d of r)d.disposed||(d.debounceMs===0?o(d,f()):(d.timer==null&&(d.timer=new Ie),d.timer.start(d.debounceMs,()=>{d.disposed||o(d,this.snapshot())})))},a;if(n.paths!=null){let l=(typeof n.paths=="string"?this._pathsMatching(n.paths):n.paths).map(p=>{let h=this.tryResolve(p);return h==null?()=>{}:h.subscribe(f=>i(p,f))});a=()=>{for(let p of l)p()}}else a=this.observe().subscribe((c,l)=>i(c,l));let u=()=>{a();for(let c of r)c.disposed=!0,c.timer?.cancel();this._storageDisposers.delete(u)};return this._storageDisposers.add(u),{dispose:u}}async _cascadeRestore(e,n){for(let r of e){let s;try{s=await r.load?.()}catch(i){n?.(i,r);continue}if(s==null||typeof s!="object"||Array.isArray(s))continue;let o=s;try{if(o.mode==="full"&&o.snapshot!=null)return this.restore(o.snapshot),!0;if(o.version===he&&o.nodes!=null)return this.restore(o),!0}catch(i){n?.(i,r)}}return!1}static async fromStorage(e,n,r){for(let s of n){let o;try{o=await s.load?.()}catch(u){r?.onError?.(u,s);continue}if(o==null||typeof o!="object"||Array.isArray(o))continue;let i=o,a=i.mode==="full"&&i.snapshot!=null?i.snapshot:i.version===he&&i.nodes!=null?i:void 0;if(a!=null)try{return t.fromSnapshot(a,r)}catch(u){r?.onError?.(u,s)}}throw new Error(`Graph.fromStorage: no tier held a restorable record for "${e}" across ${n.length} tier(s)`)}_annotations=new Map;_traceRing;trace(e,n,r){if(e!=null&&n!=null){if(this.tryResolve(e)==null)return;if(this._annotations.set(e,n),this.config.inspectorEnabled){let s={path:e,annotation:n,timestamp_ns:j(),...r?.actor!=null?{actor:r.actor}:{}};this._traceRing.push(s)}return}return e!=null?this.config.inspectorEnabled?this._annotations.get(e):void 0:this.config.inspectorEnabled?this._traceRing.toArray():[]}annotation(e){return this._annotations.get(e)}clearTrace(){this._annotations.clear(),this._traceRing.clear()}pruneTrace(e){let n=this._traceRing.toArray().filter(s=>!e(s)),r=this._traceRing.size-n.length;this._traceRing.clear();for(let s of n)this._traceRing.push(s);return r}static diff(e,n){let r=new Set(Object.keys(e.nodes)),s=new Set(Object.keys(n.nodes)),o=[...s].filter(_=>!r.has(_)).sort(),i=[...r].filter(_=>!s.has(_)).sort(),a=[],u=[];for(let _ of r){if(!s.has(_))continue;let b=e.nodes[_],v=n.nodes[_],T=b.v,x=v.v;T!=null&&x!=null&&T.id===x.id&&T.version!==x.version&&u.push({path:_,id:T.id,from:T.version,to:x.version});let w=T!=null&&x!=null&&T.id===x.id&&T.version===x.version;for(let E of["type","status","sentinel"]){let N=b[E],A=v[E];N!==A&&a.push({path:_,field:E,from:N,to:A})}if(!w)for(let E of["value","meta"]){let N=b[E],A=v[E];ar(N,A)||a.push({path:_,field:E,from:N,to:A})}}let c=_=>`${_.from} ${_.to}`,l=new Set(e.edges.map(c)),p=new Set(n.edges.map(c)),h=n.edges.filter(_=>!l.has(c(_))),f=e.edges.filter(_=>!p.has(c(_))),d=new Set(e.subgraphs),g=new Set(n.subgraphs),m=[...g].filter(_=>!d.has(_)).sort(),y=[...d].filter(_=>!g.has(_)).sort();return{nodesAdded:o,nodesRemoved:i,nodesChanged:a,versionChanges:u,edgesAdded:h,edgesRemoved:f,subgraphsAdded:m,subgraphsRemoved:y}}};function Tr(t,e){let n=ge.diff(t,e),r={};for(let s of n.nodesAdded){let o=e.nodes[s];o!=null&&(r[s]=o)}return{...n,nodesAddedFull:r}}function sn(t,e,n,r={}){let s={paths:[],depths:new Map,truncated:!1};if(!e)return r.withDetail?s:[];if(!r.both&&n!=="upstream"&&n!=="downstream")throw new Error('reachable: direction must be "upstream" or "downstream"');let o=r.maxDepth;if(o!=null&&(!Number.isInteger(o)||o<0))throw new Error("reachable: maxDepth must be an integer >= 0");if(o===0)return r.withDetail?s:[];let i=new Map,a=new Map,u=new Map,c=new Map,l=new Set;for(let[b,v]of Object.entries(t.nodes)){if(!b)continue;l.add(b);let T=v.deps??[];i.set(b,T);for(let x of T)x&&(l.add(x),a.has(x)||a.set(x,new Set),a.get(x).add(b))}for(let b of t.edges){if(b==null||typeof b!="object")continue;let v=typeof b.from=="string"?b.from:"",T=typeof b.to=="string"?b.to:"";!v||!T||(l.add(v),l.add(T),c.has(v)||c.set(v,new Set),c.get(v).add(T),u.has(T)||u.set(T,new Set),u.get(T).add(v))}if(!l.has(e))return r.withDetail?s:[];let p=r.both===!0,h=b=>{if(p){let w=i.get(b)??[],E=u.get(b),N=a.get(b),A=c.get(b),R=[...w];return E&&R.push(...E),N&&R.push(...N),A&&R.push(...A),R}if(n==="upstream"){let w=i.get(b)??[],E=u.get(b);return E?[...w,...E]:w}let v=a.get(b),T=c.get(b),x=v?[...v]:[];return T&&x.push(...T),x},f=new Set([e]),d=new Map,g=[{path:e,depth:0}],m=0,y=!1;for(;m<g.length;){let b=g[m++];if(o!=null&&b.depth>=o){h(b.path).length>0&&(y=!0);continue}for(let v of h(b.path))!v||f.has(v)||(f.add(v),d.set(v,b.depth+1),g.push({path:v,depth:b.depth+1}))}let _=[...d.keys()].sort((b,v)=>b<v?-1:b>v?1:0);return r.withDetail?{paths:_,depths:d,truncated:y}:_}function Er(t,e){if(t.length!==e.length)return!1;for(let n=0;n<t.length;n++){let r=t[n],s=e[n];if(r.path!==s.path||r.type!==s.type||r.status!==s.status||r.hop!==s.hop||r.dep_index!==s.dep_index||r.annotation!==s.annotation||r.value!==s.value||r.lastMutation!==s.lastMutation)return!1;let o=r.v,i=s.v;if(o!==i&&(o==null||i==null||o.id!==i.id||o.version!==i.version))return!1}return!0}function mt(t,e,n,r=0){if(!Number.isFinite(t))return r;if(!Number.isFinite(e)||e<=0||!Number.isFinite(n)||n<=0)return Math.max(r,t);let s=t*Math.exp(-n*e);return Math.max(r,s)}function ln(t){if(t!==void 0&&t<1)throw new RangeError("maxSize must be >= 1")}function ne(t){return new Map(t)}function $(t){return t.cache??new Map}function ze(t){return t.cache??[]}function Or(t,e){let n=Math.max(t.length,e.length),r=0,s=0,o=0;for(let i=0;i<n;i+=1){let a=t[i]??0,u=e[i]??0;r+=a*u,s+=a*a,o+=u*u}return s===0||o===0?0:r/Math.sqrt(s*o)}function Nr(t={}){let e=t.maxSize,n=t.policy??"fifo";ln(e);let r=te(new Map,{name:t.name,describeKind:"state"});function s(i){if(e!==void 0)for(;i.size>e;){let a;for(let u of i.values()){if(!a){a=u;continue}let c=n==="lru"?u.lastAccessNs:u.createdAtNs,l=n==="lru"?a.lastAccessNs:a.createdAtNs;c<l&&(a=u)}if(!a)break;i.delete(a.id)}}function o(i){r.emit(i)}return{entries:r,upsert(i,a){let u=j(),c=$(r),l=c.get(i),p=ne(c);p.set(i,{id:i,value:a,createdAtNs:l?.createdAtNs??u,lastAccessNs:u}),s(p),o(p)},remove(i){let a=ne($(r));a.delete(i)&&o(a)},clear(){$(r).size!==0&&o(new Map)},get(i){let a=$(r),u=a.get(i);if(u){if(n==="lru"){let c=j(),l=ne(a);l.set(i,{...u,lastAccessNs:c}),o(l)}return u.value}},has(i){return $(r).has(i)}}}function Rr(t,e={}){let n=e.maxSize,r=e.policy??"lru",s=e.decayRate??0,o=e.minScore??0,i=e.score??(()=>1);ln(n);let a=new ge(t),u=te(new Map,{name:"items",describeKind:"state"}),c=ue([u],([g])=>{let m=g??new Map,y=j(),_=[...m.values()].map(b=>{let v=(y-b.lastAccessNs)/1e9;return{...b,score:mt(b.baseScore,v,s,o)}});return _.sort((b,v)=>v.score-b.score||v.lastAccessNs-b.lastAccessNs),_},{name:"ranked",describeKind:"derived"}),l=ue([u],([g])=>(g??new Map).size,{name:"size",describeKind:"derived",initial:0});c.subscribe(()=>{}),l.subscribe(()=>{}),a.add(u,{name:"items"}),a.add(c,{name:"ranked"}),a.add(l,{name:"size"});function p(g,m){let y=(m-g.lastAccessNs)/1e9;return mt(g.baseScore,y,s,o)}function h(g){if(n!==void 0)for(;g.size>n;){let m=j(),y,_=Number.POSITIVE_INFINITY;for(let b of g.values()){let v=p(b,m);if(v<_){y=b,_=v;continue}if(v===_&&y){let T=r==="lru"?b.lastAccessNs:b.createdAtNs,x=r==="lru"?y.lastAccessNs:y.createdAtNs;T<x&&(y=b)}}if(!y)break;g.delete(y.id)}}function f(g){u.emit(g)}return Object.assign(a,{upsert(g,m,y){let _=j(),b=$(u),v=b.get(g),T=y?.score??i(m),x=ne(b);x.set(g,{id:g,value:m,baseScore:T,createdAtNs:v?.createdAtNs??_,lastAccessNs:_}),h(x),f(x)},remove(g){let m=ne($(u));m.delete(g)&&f(m)},clear(){$(u).size!==0&&f(new Map)},getItem(g){let m=$(u),y=m.get(g);if(y){if(r==="lru"){let _=ne(m);_.set(g,{...y,lastAccessNs:j()}),f(_)}return y}}})}function kr(t={}){let e=t.backend??"flat",n=t.dimension,r;if(e==="hnsw"&&(r=t.hnswFactory?.(),!r))throw new Error('vectorIndex backend "hnsw" requires an optional dependency adapter; install your HNSW package and provide `hnswFactory`.');let s=te(new Map,{describeKind:"state",name:"vector-index"});function o(a){if(n!==void 0&&a.length!==n)throw new RangeError(`vector dimension mismatch: expected ${n}, got ${a.length}`)}function i(a){s.emit(a)}return{backend:e,entries:s,upsert(a,u,c){o(u);let l=ne($(s));l.set(a,{id:a,vector:[...u],meta:c}),e==="hnsw"&&r.upsert(a,u,c),i(l)},remove(a){let u=ne($(s));u.delete(a)&&(e==="hnsw"&&r.remove(a),i(u))},clear(){$(s).size!==0&&(e==="hnsw"&&r.clear(),i(new Map))},search(a,u=5){return o(a),u<=0?[]:e==="hnsw"?r.search(a,u):[...$(s).values()].map(l=>({id:l.id,score:Or(a,l.vector),meta:l.meta})).sort((l,p)=>p.score-l.score).slice(0,u)}}}function Sr(t){let e=new ge(t),n=te(new Map,{name:"entities",describeKind:"state"}),r=te([],{name:"edges",describeKind:"state"}),s=ue([r],([u])=>{let c=u??[],l=new Map;for(let p of c){let h=l.get(p.from)??[];l.set(p.from,Object.freeze([...h,p]))}return l},{name:"adjacency",describeKind:"derived",initial:new Map});s.subscribe(()=>{}),e.add(n,{name:"entities"}),e.add(r,{name:"edges"}),e.add(s,{name:"adjacency"});function o(u){n.emit(u)}function i(u){r.emit(u)}return Object.assign(e,{upsertEntity(u,c){let l=ne($(n));l.set(u,c),o(l)},removeEntity(u){let c=ne($(n)),l=c.delete(u),p=ze(r),h=p.filter(f=>f.from!==u&&f.to!==u);!l&&h.length===p.length||(o(c),i(h))},link(u,c,l,p=1){let h=`${u}\0${c}\0${l}`,f=ze(r),d=new Set(f.map(m=>`${m.from}\0${m.to}\0${m.relation}`)),g=[...f];if(d.has(h))for(let m=0;m<g.length;m+=1){let y=g[m];if(y.from===u&&y.to===c&&y.relation===l){g[m]={...y,weight:p};break}}else g.push({from:u,to:c,relation:l,weight:p});i(g)},unlink(u,c,l){let p=ze(r),h=p.filter(f=>l===void 0?!(f.from===u&&f.to===c):!(f.from===u&&f.to===c&&f.relation===l));h.length!==p.length&&i(h)},related(u,c){return ze(r).filter(l=>(l.from===u||l.to===u)&&(c===void 0||l.relation===c))}})}0&&(module.exports={collection,decay,knowledgeGraph,lightCollection,vectorIndex});
1
+ "use strict";var ut=Object.defineProperty;var $n=Object.getOwnPropertyDescriptor;var Pn=Object.getOwnPropertyNames;var Vn=Object.prototype.hasOwnProperty;var Z=(t,e)=>()=>(t&&(e=t(t=0)),e);var zn=(t,e)=>{for(var n in e)ut(t,n,{get:e[n],enumerable:!0})},Fn=(t,e,n,r)=>{if(e&&typeof e=="object"||typeof e=="function")for(let o of Pn(e))!Vn.call(t,o)&&o!==n&&ut(t,o,{get:()=>e[o],enumerable:!(r=$n(e,o))||r.enumerable});return t};var Kn=t=>Fn(ut({},"__esModule",{value:!0}),t);function V(){return Math.trunc(performance.now()*1e6)}function le(){return Date.now()*1e6}var me=Z(()=>{"use strict"});function Gt(t,e){let n=new TextEncoder().encode(t.name);if(n.length===0||n.length>255)throw new Error(`encodeEnvelope: codec name "${t.name}" encodes to ${n.length} bytes (must be 1\u2013255)`);let r=t.version;if(!Number.isInteger(r)||r<0||r>65535)throw new Error(`encodeEnvelope: codec.version ${r} out of u16 range (expected integer 0\u201365535)`);let o=2+n.length+2+e.length;if(o>4294967295)throw new Error(`encodeEnvelope: total envelope size ${o} exceeds 2^32-1 bytes (payload ${e.length} bytes)`);let s=new Uint8Array(o),i=0;return s[i++]=ct,s[i++]=n.length,s.set(n,i),i+=n.length,s[i++]=r>>>8&255,s[i++]=r&255,s.set(e,i),s}function Lt(t,e){if(t.length<Dt)throw new Error(`decodeEnvelope: bytes too short (${t.length} < ${Dt})`);let n=0,r=t[n++];if(r!==ct)throw new Error(`decodeEnvelope: unsupported envelope version ${r} (expected ${ct})`);let o=t[n++];if(o===0)throw new Error("decodeEnvelope: name_len must be >= 1");if(n+o+2>t.length)throw new Error(`decodeEnvelope: envelope truncated (need ${n+o+2} bytes, have ${t.length})`);let s=new TextDecoder().decode(t.subarray(n,n+o));n+=o;let i=(t[n]<<8|t[n+1])>>>0;n+=2;let a=t.subarray(n),u=e.lookupCodec(s);if(u==null)throw new Error(`decodeEnvelope: codec "${s}" not registered (envelope codec_v=${i})`);return{codec:u,codecVersion:i,payload:a}}function It(t){t.registerCodec(Bn)}var Bn,ct,Dt,lt=Z(()=>{"use strict";Bn={name:"json",version:1,contentType:"application/json",encode(t){let e=JSON.stringify(t);return new TextEncoder().encode(e)},decode(t,e){let n=new TextDecoder().decode(t);return JSON.parse(n)}},ct=1,Dt=4});function Be(t){if(t==null)return xe;let{type:e,id:n,...r}=t;return{type:e??"system",id:n??"",...r}}var xe,ft=Z(()=>{"use strict";xe={type:"system",id:""}});function je(){return Te>0||Le}function $t(){return Te>0}function ke(t){Te>0?Ie.push(t):t()}function Ee(t){Te+=1;let e=!1;try{t()}catch(n){throw e=!0,n}finally{if(Te-=1,Te===0)if(e){if(!Le){let n=Ie.splice(0);for(let r of n)try{r()}catch{}ye.length=0,be.length=0,Re.length=0}}else jn()}}function jn(){let t=!Le;t&&(Le=!0);let e=[],n=0;try{for(;ye.length>0||be.length>0||Re.length>0||t&&Ie.length>0;){if(t&&Ie.length>0){let s=Ie.splice(0);for(let i of s)try{i()}catch(a){e.push(a)}continue}if(n+=1,n>1e3)throw ye.length=0,be.length=0,Re.length=0,new Error("batch drain exceeded 1000 iterations \u2014 likely a reactive cycle");let o=(ye.length>0?ye:be.length>0?be:Re).splice(0);for(let s of o)try{s()}catch(i){e.push(i)}}}finally{t&&(Le=!1)}if(e.length===1)throw e[0];if(e.length>1)throw new AggregateError(e,"batch drain: multiple callbacks threw")}function He(t,e,n){if(e.length===0)return;if(e.length===1){let d=n(e[0][0]);if(d<3||!je()){t(e);return}(d>=5?Re:d===4?be:ye).push(()=>t(e));return}let r=e.length,o=r,s=r,i=r,a=0;for(;a<r&&n(e[a][0])<3;)a++;for(o=a;a<r&&n(e[a][0])===3;)a++;for(s=a;a<r&&n(e[a][0])===4;)a++;i=a;let u=je();if(o>0){let d=e.slice(0,o);t(d)}if(s>o){let d=e.slice(o,s);u?ye.push(()=>t(d)):t(d)}if(i>s){let d=e.slice(s,i);u?be.push(()=>t(d)):t(d)}if(r>i){let d=e.slice(i,r);u?Re.push(()=>t(d)):t(d)}}var Te,Le,ye,be,Re,Ie,$e=Z(()=>{"use strict";Te=0,Le=!1,ye=[],be=[],Re=[],Ie=[]});var Ne,I,H,Q,ie,ce,fe,q,Y,z,Oe,pt,Hn,ht,qn,Wn,gt,Pt,Vt,zt,mt,pe=Z(()=>{"use strict";Ne=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"),q=Symbol.for("graphrefly/TEARDOWN"),Y=Symbol.for("graphrefly/COMPLETE"),z=Symbol.for("graphrefly/ERROR"),Oe=Object.freeze([H]),pt=Object.freeze([Q]),Hn=Object.freeze([ie]),ht=Object.freeze([Ne]),qn=Object.freeze([Y]),Wn=Object.freeze([q]),gt=Object.freeze([Oe]),Pt=Object.freeze([pt]),Vt=Object.freeze([Hn]),zt=Object.freeze([qn]),mt=Object.freeze([Wn])});function Ft(t){t.registerMessageType(Ne,{tier:0,wireCrossing:!1}),t.registerMessageType(H,{tier:1,wireCrossing:!1}),t.registerMessageType(ie,{tier:1,wireCrossing:!1,metaPassthrough:!1}),t.registerMessageType(ce,{tier:2,wireCrossing:!1}),t.registerMessageType(fe,{tier:2,wireCrossing:!1}),t.registerMessageType(I,{tier:3,wireCrossing:!0}),t.registerMessageType(Q,{tier:3,wireCrossing:!0}),t.registerMessageType(Y,{tier:4,wireCrossing:!0,metaPassthrough:!1}),t.registerMessageType(z,{tier:4,wireCrossing:!0,metaPassthrough:!1}),t.registerMessageType(q,{tier:5,wireCrossing:!0,metaPassthrough:!1})}var qe,Kt=Z(()=>{"use strict";pe();qe=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=n=>{let r=this._messageTypes.get(n);return r!=null?r.tier:1}}get onMessage(){return this._frozen=!0,this._onMessage}get onSubscribe(){return this._frozen=!0,this._onSubscribe}set onMessage(e){this._assertUnfrozen(),this._onMessage=e}set onSubscribe(e){this._assertUnfrozen(),this._onSubscribe=e}get defaultVersioning(){return this._defaultVersioning}set defaultVersioning(e){this._assertUnfrozen(),this._defaultVersioning=e}get defaultHashFn(){return this._defaultHashFn}set defaultHashFn(e){this._assertUnfrozen(),this._defaultHashFn=e}get inspectorEnabled(){return this._inspectorEnabled}set inspectorEnabled(e){this._inspectorEnabled=e}get globalInspector(){return this._globalInspector}set globalInspector(e){this._globalInspector=e}get rigorRecorder(){return this._rigorRecorder}set rigorRecorder(e){this._rigorRecorder=e}registerMessageType(e,n){return this._assertUnfrozen(),this._messageTypes.set(e,{tier:n.tier,wireCrossing:n.wireCrossing??n.tier>=3,metaPassthrough:n.metaPassthrough??!0}),this}messageTier(e){let n=this._messageTypes.get(e);return n!=null?n.tier:1}isWireCrossing(e){let n=this._messageTypes.get(e);return n!=null?n.wireCrossing:!0}isLocalOnly(e){return!this.isWireCrossing(e)}isMetaPassthrough(e){let n=this._messageTypes.get(e);return n!=null?n.metaPassthrough:!0}isKnownMessageType(e){return this._messageTypes.has(e)}registerCodec(e){return this._assertUnfrozen(),this._codecs.set(e.name,e),this}lookupCodec(e){return this._codecs.get(e)}_isFrozen(){return this._frozen}_assertUnfrozen(){if(this._frozen)throw new Error("GraphReFlyConfig is frozen: a node has already captured this config. Register custom types and set hooks before creating any node.")}}});function Bt(t){return Array.isArray(t)?[...t]:[t]}function Un(t,e){return t.has(e)||t.has("*")}function jt(t){let e=[];return t((o,s)=>{e.push({kind:"allow",actions:new Set(Bt(o)),where:s?.where??(()=>!0)})},(o,s)=>{e.push({kind:"deny",actions:new Set(Bt(o)),where:s?.where??(()=>!0)})}),(o,s)=>{let i=!1,a=!1;for(let u of e)Un(u.actions,s)&&u.where(o)&&(u.kind==="deny"?i=!0:a=!0);return i?!1:a}}function yt(t){let e=Yn.filter(n=>t({type:n,id:""},"write"));return e.length===0?"restricted":e.includes("human")&&e.includes("llm")&&e.every(n=>n==="human"||n==="llm"||n==="system")?"both":e.length===1?e[0]:e.join("+")}var ne,Yn,Pe=Z(()=>{"use strict";ne=class extends Error{actor;action;nodeName;constructor(e,n){super(n??`GuardDenied: action "${String(e.action)}" denied for actor type "${String(e.actor.type)}"`),this.name="GuardDenied",this.actor=e.actor,this.action=e.action,this.nodeName=e.nodeName}get node(){return this.nodeName}};Yn=["human","llm","wallet","system"]});function bt(t){if(t===void 0)return null;if(typeof t=="number"){if(!Number.isFinite(t))throw new TypeError(`Cannot hash non-finite number: ${t}`);if(Number.isInteger(t)&&!Number.isSafeInteger(t))throw new TypeError(`Cannot hash integer outside safe range (|n| > 2^53-1): ${t}. Cross-language cid parity is not guaranteed for unsafe integers.`);return t}if(typeof t=="string"||typeof t=="boolean"||t===null)return t;if(Array.isArray(t))return t.map(bt);if(typeof t=="object"&&t!==null){let e={};for(let n of Object.keys(t).sort())e[n]=bt(t[n]);return e}return null}function Zn(t){let e=Xn.encode(t),n=e.length,r=n*8,o=n+9+63&-64,s=new Uint8Array(o);s.set(e),s[n]=128;let i=new DataView(s.buffer);i.setUint32(o-4,r>>>0,!1),i.setUint32(o-8,Math.floor(r/4294967296)>>>0,!1);let a=1779033703,u=3144134277,d=1013904242,l=2773480762,h=1359893119,p=2600822924,f=528734635,c=1541459225,y=new Uint32Array(64),g=(E,x)=>E>>>x|E<<32-x;for(let E=0;E<o;E+=64){for(let T=0;T<16;T++)y[T]=i.getUint32(E+T*4,!1);for(let T=16;T<64;T++){let k=y[T-15],_=y[T-2],O=g(k,7)^g(k,18)^k>>>3,D=g(_,17)^g(_,19)^_>>>10;y[T]=y[T-16]+O+y[T-7]+D>>>0}let x=a,N=u,M=d,S=l,m=h,b=p,v=f,R=c;for(let T=0;T<64;T++){let k=g(m,6)^g(m,11)^g(m,25),_=m&b^~m&v,O=R+k+_+Jn[T]+y[T]>>>0,D=g(x,2)^g(x,13)^g(x,22),C=x&N^x&M^N&M,L=D+C>>>0;R=v,v=b,b=m,m=S+O>>>0,S=M,M=N,N=x,x=O+L>>>0}a=a+x>>>0,u=u+N>>>0,d=d+M>>>0,l=l+S>>>0,h=h+m>>>0,p=p+b>>>0,f=f+v>>>0,c=c+R>>>0}let w=E=>E.toString(16).padStart(8,"0");return w(a)+w(u)+w(d)+w(l)+w(h)+w(p)+w(f)+w(c)}function vt(t){let e=bt(t??null),n=JSON.stringify(e);return Zn(n).slice(0,16)}function Qn(){let t=globalThis.crypto;if(t?.randomUUID)return t.randomUUID();let e=()=>Math.floor(Math.random()*4294967296).toString(16).padStart(8,"0"),n=e()+e()+e()+e();return`${n.slice(0,8)}-${n.slice(8,12)}-4${n.slice(13,16)}-${(parseInt(n.slice(16,17),16)&3|8).toString(16)}${n.slice(17,20)}-${n.slice(20,32)}`}function _t(t,e,n){let r=n?.id??Qn();if(t===0)return{id:r,version:0};let s=(n?.hash??vt)(e);return{id:r,version:0,cid:s,prev:null}}function Ht(t,e,n){t.version+=1,"cid"in t&&(t.prev=t.cid,t.cid=n(e))}var Jn,Xn,qt=Z(()=>{"use strict";Jn=new Uint32Array([1116352408,1899447441,3049323471,3921009573,961987163,1508970993,2453635748,2870763221,3624381080,310598401,607225278,1426881987,1925078388,2162078206,2614888103,3248222580,3835390401,4022224774,264347078,604807628,770255983,1249150122,1555081692,1996064986,2554220882,2821834349,2952996808,3210313671,3336571891,3584528711,113926993,338241895,666307205,773529912,1294757372,1396182291,1695183700,1986661051,2177026350,2456956037,2730485921,2820302411,3259730800,3345764771,3516065817,3600352804,4094571909,275423344,430227734,506948616,659060556,883997877,958139571,1322822218,1537002063,1747873779,1955562222,2024104815,2227730452,2361852424,2428436474,2756734187,3204031479,3329325298]),Xn=new TextEncoder});function Yt(t){return{node:t,unsub:null,prevData:void 0,dirty:!1,involvedThisWave:!1,dataBatch:[],terminal:void 0}}function wt(t){t.prevData=void 0,t.dirty=!1,t.involvedThisWave=!1,t.dataBatch.length=0,t.terminal=void 0}function We(t){return t.length===0?t:typeof t[0]=="symbol"?[t]:t}function Me(t,e,n){let r=Jt(t)?t:[],o=typeof t=="function"?t:typeof e=="function"?e:void 0,s={};return Jt(t)?s=(xt(e)?e:n)??{}:xt(t)?s=t:s=(xt(e)?e:n)??{},new F(r,o,s)}var Wt,Ut,er,tr,Se,F,Jt,xt,ve=Z(()=>{"use strict";lt();ft();$e();me();Kt();Pe();pe();qt();Wt=()=>{},Ut=100;er=(t,e,n,r)=>{n.direction==="down-in"&&t._onDepMessage(n.depIndex,e)},tr=(t,e,n,r)=>{let o=t;if(o._status==="completed"||o._status==="errored")return;let s=o._cached,i=s===void 0?[ht]:[ht,[I,s]];o._status==="dirty"&&i.push(Oe),He(e,i,o._config.tierOf)},Se=new qe({onMessage:er,onSubscribe:tr});Ft(Se);It(Se);F=class t{_optsName;_describeKind;meta;_hasMeta;_config;_deps;_sinks=null;_sinkCount=0;_cached;_status;_cleanup;_store={};_waveHasNewData=!1;_hasNewTerminal=!1;_hasCalledFnOnce=!1;_paused=!1;_pendingWave=!1;_isExecutingFn=!1;_pendingRerun=!1;_rerunDepth=0;_dirtyDepCount=0;_batchPendingMessages=null;_pauseLocks=null;_pauseBuffer=null;_fn;_equals;_resubscribable;_resetOnTeardown;_autoComplete;_autoError;_pausable;_partial;_guard;_extraGuards;_hashFn;_versioning;_versioningLevel;_lastMutation;_inspectorHooks;_actions;constructor(e,n,r){this._config=r.config??Se,this._config.onMessage,this._optsName=r.name,this._describeKind=r.describeKind,this._equals=r.equals??Object.is,this._resubscribable=r.resubscribable??!1,this._resetOnTeardown=r.resetOnTeardown??!1,this._autoComplete=r.completeWhenDepsComplete??!0,this._autoError=r.errorWhenDepsError??!0,this._pausable=r.pausable??!0,this._guard=r.guard,this._fn=n,this._partial=r.partial??!1,this._cached=r.initial!==void 0?r.initial:void 0,this._status=e.length===0&&n==null&&this._cached!==void 0?"settled":"sentinel",this._hashFn=r.versioningHash??this._config.defaultHashFn??vt;let o=r.versioning??this._config.defaultVersioning;this._versioningLevel=o,this._versioning=o!=null?_t(o,this._cached===void 0?void 0:this._cached,{id:r.versioningId,hash:this._hashFn}):void 0,this._deps=e.map(Yt);let s={};for(let[a,u]of Object.entries(r.meta??{})){let d={initial:u,name:`${r.name??"node"}:meta:${a}`,describeKind:"state",config:this._config};r.guard!=null&&(d.guard=r.guard),s[a]=new t([],void 0,d)}Object.freeze(s),this.meta=s,this._hasMeta=Object.keys(s).length>0;let i=this;this._actions={emit(a){i._emit([[I,a]])},down(a){i._emit(We(a))},up(a){i._emitUp(We(a))}},this.down=this.down.bind(this),this.up=this.up.bind(this)}get _isTerminal(){return this._status==="completed"||this._status==="errored"}get name(){return this._optsName}get status(){return this._status}get cache(){return this._cached===void 0?void 0:this._cached}get lastMutation(){return this._lastMutation}get v(){return this._versioning}hasGuard(){return this._guard!=null}_applyVersioning(e,n){if(this._isExecutingFn)throw new Error(`Node "${this.name}": _applyVersioning cannot run mid-fn \u2014 call it outside of \`_execFn\` (typically at graph setup time before the first subscribe).`);let r=this._versioningLevel;if(r!=null&&e<=r)return;let o=n?.hash??this._hashFn;o!==this._hashFn&&(this._hashFn=o);let s=this._cached===void 0?void 0:this._cached,i=this._versioning,a=i?.id??n?.id,u=i?.version??0,d=_t(e,s,{id:a,hash:o});d.version=u,this._versioning=d,this._versioningLevel=e}_setInspectorHook(e){return e==null?()=>{}:(this._inspectorHooks==null&&(this._inspectorHooks=new Set),this._inspectorHooks.add(e),()=>{this._inspectorHooks?.delete(e),this._inspectorHooks?.size===0&&(this._inspectorHooks=void 0)})}_pushGuard(e){return this._extraGuards==null&&(this._extraGuards=new Set),this._extraGuards.add(e),()=>{this._extraGuards?.delete(e),this._extraGuards?.size===0&&(this._extraGuards=void 0)}}allowsObserve(e){if(this._guard==null&&this._extraGuards==null)return!0;let n=Be(e);if(this._guard!=null&&!this._guard(n,"observe"))return!1;if(this._extraGuards!=null){for(let r of this._extraGuards)if(!r(n,"observe"))return!1}return!0}_checkGuard(e){if(e?.internal)return;let n=this._guard!=null||this._extraGuards!=null,r=e?.actor!=null;if(!n&&!r)return;let o=Be(e?.actor),s=e?.delivery==="signal"?"signal":"write";if(this._guard!=null&&!this._guard(o,s))throw new ne({actor:o,action:s,nodeName:this.name});if(this._extraGuards!=null){for(let i of this._extraGuards)if(!i(o,s))throw new ne({actor:o,action:s,nodeName:this.name})}this._lastMutation={actor:o,timestamp_ns:le()}}down(e,n){let r=We(e);r.length!==0&&(this._checkGuard(n),this._emit(r))}emit(e,n){this._checkGuard(n),this._emit([[I,e]])}up(e,n){if(this._deps.length===0)return;let r=We(e);if(r.length===0)return;this._checkGuard(n);let o=n??{internal:!0};this._validateUpTiers(r);for(let s of this._deps)s.node.up?.(r,o)}_emitUp(e){if(this._deps.length!==0&&e.length!==0){this._validateUpTiers(e);for(let n of this._deps)n.node.up?.(e,{internal:!0})}}_validateUpTiers(e){let n=this._config.tierOf;for(let r of e){let o=n(r[0]);if(o===3||o===4)throw new Error(`Node "${this.name}": tier-${o} messages cannot flow up \u2014 DATA/RESOLVED/COMPLETE/ERROR are downstream-only. Use \`down(...)\` for value delivery; \`up(...)\` is for control signals (DIRTY, INVALIDATE, PAUSE, RESUME, TEARDOWN).`)}}subscribe(e,n){if(n!=null&&this._guard!=null){let u=Be(n);if(!this._guard(u,"observe"))throw new ne({actor:u,action:"observe",nodeName:this.name})}let o=this._isTerminal&&this._resubscribable;if(o){this._cached=void 0,this._status="sentinel",this._store={},this._hasCalledFnOnce=!1,this._waveHasNewData=!1,this._hasNewTerminal=!1,this._paused=!1,this._pendingWave=!1,this._pendingRerun=!1,this._isExecutingFn=!1,this._rerunDepth=0,this._dirtyDepCount=0,this._pauseLocks=null,this._pauseBuffer=null;for(let u of this._deps)wt(u);if(this._partial===!1){for(let u of this._deps)if(u.prevData!==void 0||u.dataBatch.length!==0||u.terminal!==void 0||u.dirty)throw new Error(`resubscribable-reset invariant: DepRecord not fully reset for node ${this._optsName??"(anonymous)"}`)}}this._sinkCount+=1;let s;try{s=this._config.onSubscribe(this,e,{sinkCount:this._sinkCount,afterTerminalReset:o},this._actions)}catch(u){throw this._sinkCount-=1,u}this._sinks==null?this._sinks=e:typeof this._sinks=="function"?this._sinks=new Set([this._sinks,e]):this._sinks.add(e);let i=this._isTerminal;if(this._sinkCount===1&&!i)try{this._activate()}catch(u){if(this._sinkCount-=1,this._removeSink(e),this._sinkCount===0&&(this._status="sentinel"),typeof s=="function")try{s()}catch{}throw u}this._status==="sentinel"&&this._cached===void 0&&(this._status="pending");let a=!1;return()=>{a||(a=!0,this._sinkCount-=1,this._removeSink(e),typeof s=="function"&&s(),this._sinks==null&&this._deactivate())}}_removeSink(e){if(this._sinks===e)this._sinks=null;else if(this._sinks!=null&&typeof this._sinks!="function")if(this._sinks.delete(e),this._sinks.size===1){let[n]=this._sinks;this._sinks=n}else this._sinks.size===0&&(this._sinks=null)}_activate(){if(this._deps.length===0){this._fn&&this._execFn();return}this._dirtyDepCount=0;let e=this._deps.length,n=0;try{for(let r=0;r<e;r++){let o=r,s=this._deps[r];s.unsub=Wt,s.unsub=s.node.subscribe(i=>{if(s.unsub===null)return;let a=this._config.tierOf,u=!1;for(let d of i)a(d[0])>=3&&(u=!0),this._config.onMessage(this,d,{direction:"down-in",depIndex:o},this._actions);u&&this._maybeRunFnOnSettlement()}),n++}}catch(r){this._deps[n].unsub=null;for(let o=0;o<n;o++){let s=this._deps[o];if(s.unsub!=null){let i=s.unsub;s.unsub=null;try{i()}catch{}wt(s)}}throw this._dirtyDepCount=0,r}}_addDep(e){for(let o=0;o<this._deps.length;o++)if(this._deps[o].node===e)return o;let n=this._deps.length,r=Yt(e);if(this._deps.push(r),this._sinks==null)return n;r.dirty=!0,this._dirtyDepCount++,this._status!=="dirty"&&this._emit(gt),r.unsub=Wt;try{r.unsub=e.subscribe(o=>{if(r.unsub===null)return;let s=this._config.tierOf,i=!1;for(let a of o)s(a[0])>=3&&(i=!0),this._config.onMessage(this,a,{direction:"down-in",depIndex:n},this._actions);i&&this._maybeRunFnOnSettlement()})}catch(o){throw r.unsub=null,this._deps.pop(),this._dirtyDepCount--,o}return n}_deactivate(e=!1){let n=this._cleanup;if(this._cleanup=void 0,typeof n=="function")try{n()}catch(r){this._emit([[z,this._wrapFnError("cleanup threw",r)]])}else if(n!=null&&typeof n=="object"){let r=n.deactivate;if(typeof r=="function")try{r()}catch(o){this._emit([[z,this._wrapFnError("cleanup.deactivate threw",o)]])}}for(let r of this._deps){if(r.unsub!=null){let o=r.unsub;r.unsub=null;try{o()}catch{}}wt(r)}this._waveHasNewData=!1,this._hasNewTerminal=!1,this._hasCalledFnOnce=!1,this._paused=!1,this._pendingWave=!1,this._pendingRerun=!1,this._rerunDepth=0,this._store={},this._dirtyDepCount=0,this._pauseLocks=null,this._pauseBuffer=null,this._fn!=null&&(this._cached=void 0),e||(this._fn!=null||this._deps.length>0)&&(!this._isTerminal||this._resubscribable)&&(this._status="sentinel")}_onDepMessage(e,n){let r=this._deps[e],o=n[0];if(this._inspectorHooks!=null){let s={kind:"dep_message",depIndex:e,message:n};for(let i of this._inspectorHooks)i(s)}if(o!==Ne){if(o===H){this._depDirtied(r);return}if(o===ie){if(this._depInvalidated(r),this._cached===void 0)return;this._emit(Vt);return}if(o===ce||o===fe){this._emit([n]);return}if(o===q){this._emit(mt);return}if(o===I)this._depSettledAsData(r,n[1]);else if(o===Q)this._depSettledAsResolved(r);else if(o===Y)this._depSettledAsTerminal(r,!0);else if(o===z)this._depSettledAsTerminal(r,n[1]);else{this._emit([n]);return}if(!this._fn){(o===I||o===Q)&&this._emit([n]),(o===Y||o===z)&&this._maybeAutoTerminalAfterWave();return}}}_depDirtied(e){e.dirty||(e.dirty=!0,e.involvedThisWave=!0,this._dirtyDepCount++,this._status!=="dirty"&&this._emit(gt))}_depSettledAsData(e,n){e.dirty&&(e.dirty=!1,this._dirtyDepCount--),e.involvedThisWave=!0,e.dataBatch.push(n),this._waveHasNewData=!0}_depSettledAsResolved(e){e.dirty&&(e.dirty=!1,this._dirtyDepCount--)}_depSettledAsTerminal(e,n){e.dirty&&(e.dirty=!1,this._dirtyDepCount--),e.terminal=n,e.involvedThisWave=!0,this._hasNewTerminal=!0}_depInvalidated(e){e.prevData=void 0,e.terminal=void 0,e.dataBatch.length=0,e.dirty?e.involvedThisWave=!1:(e.dirty=!0,e.involvedThisWave=!0,this._dirtyDepCount++)}_maybeRunFnOnSettlement(){if(!(this._isTerminal&&!this._resubscribable)&&!(this._dirtyDepCount>0)){if(!this._partial&&!this._hasCalledFnOnce)for(let e=0;e<this._deps.length;e++){let n=this._deps[e];if(n.dataBatch.length===0&&n.prevData===void 0&&n.terminal===void 0){this._maybeAutoTerminalAfterWave();return}}if(this._paused){this._pendingWave=!0;return}if(!this._waveHasNewData&&!this._hasNewTerminal&&this._hasCalledFnOnce){this._clearWaveFlags(),this._emit(Pt),this._maybeAutoTerminalAfterWave();return}this._fn&&this._execFn(),this._maybeAutoTerminalAfterWave()}}_maybeAutoTerminalAfterWave(){if(this._deps.length===0||this._isTerminal)return;let e=this._deps.find(n=>n.terminal!==void 0&&n.terminal!==!0);if(e!=null){this._autoError&&this._emit([[z,e.terminal]]);return}this._autoComplete&&this._deps.every(n=>n.terminal!==void 0)&&this._emit(zt)}_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 n=this._deps.map(i=>i.involvedThisWave?i.dataBatch.length>0?[...i.dataBatch]:[]:void 0),r=this._deps.map(i=>i.prevData);for(let i=0;i<this._deps.length;i++){let a=n[i];a!=null&&a.length>0&&(this._deps[i].prevData=a[a.length-1])}let o=this._deps.map(i=>i.terminal),s={prevData:r,terminalDeps:o,store:this._store};if(this._hasCalledFnOnce=!0,this._clearWaveFlags(),this._inspectorHooks!=null){let i={kind:"run",batchData:n,prevData:r};for(let a of this._inspectorHooks)a(i)}this._isExecutingFn=!0;try{let i=this._fn(n,this._actions,s);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>Ut?(this._rerunDepth=0,this._emit([[z,new Error(`Node "${this.name}": _pendingRerun depth exceeded ${Ut} \u2014 likely a reactive cycle`)]])):this._maybeRunFnOnSettlement()):this._rerunDepth=0,this._clearWaveFlags()}}_clearWaveFlags(){this._waveHasNewData=!1,this._hasNewTerminal=!1;for(let e of this._deps)e.involvedThisWave=!1,e.dataBatch.length=0}_wrapFnError(e,n){let r=n instanceof Error?n.message:String(n);return new Error(`Node "${this.name}": ${e}: ${r}`,{cause:n})}_frameBatch(e){let n=this._config.tierOf;if(e.length===1)return n(e[0][0])===3&&this._status!=="dirty"?[Oe,e[0]]:e;let r=!0,o=!1,s=!1,i=-1;for(let u of e){let d=n(u[0]);d<i&&(r=!1),d===3&&(o=!0),u[0]===H&&(s=!0),i=d}let a=e;if(!r){let u=e.map((d,l)=>({m:d,i:l,tier:n(d[0])}));u.sort((d,l)=>d.tier-l.tier||d.i-l.i),a=u.map(d=>d.m)}if(o&&!s&&this._status!=="dirty"){let u=0;for(;u<a.length&&n(a[u][0])===0;)u++;return u===0?[Oe,...a]:[...a.slice(0,u),Oe,...a.slice(u)]}return a}_emit(e){if(e.length===0)return;for(let a=0;a<e.length;a++){let u=e[a];if(u[0]===z&&u[1]===void 0)throw new TypeError('[ERROR, payload] requires a non-undefined payload (spec \xA71.2). Pass an Error object or domain tag instead \u2014 e.g. node.down([[ERROR, new Error("reason")]])')}let n=e;if(this._isTerminal&&!this._resubscribable){let a=e.filter(u=>u[0]===q||u[0]===ie);if(a.length===0)return;n=a}n=this._frameBatch(n);let o=null;for(let a=0;a<n.length;a++){let u=n[a],d=u[0];if(d!==ce&&d!==fe){o?.push(u);continue}if(u.length<2)throw new Error(`Node "${this.name}": [[${d===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=u[1];if(d===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 p=this._pauseBuffer;this._pauseBuffer=[],this._emit(p)}this._pendingWave&&(this._pendingWave=!1,this._maybeRunFnOnSettlement())}}l?o?.push(u):o==null&&(o=n.slice(0,a))}if(o!=null){if(o.length===0)return;n=o}if(this._hasMeta&&n.some(a=>a[0]===q))for(let a of Object.keys(this.meta))try{this.meta[a]._emit(mt)}catch{}let{finalMessages:s,equalsError:i}=this._updateState(n);if(s.length>0&&this._config.inspectorEnabled){let a=this._config.globalInspector;if(a!=null)try{a({kind:"emit",node:this,messages:s})}catch{}}if(s.length>0)if(this._paused&&this._pausable==="resumeAll"&&this._pauseBuffer!=null){let a=this._config.tierOf,u=[];for(let d of s)a(d[0])===3?this._pauseBuffer.push(d):u.push(d);u.length>0&&this._dispatchOrAccumulate(u)}else this._dispatchOrAccumulate(s);i!=null&&this._emit([[z,i]])}_updateState(e){let n=this._config.tierOf,r,o,s=-1,i=0;for(let l of e)n(l[0])===3&&i++;let a=i<=1,u=-1;if(this._versioning!=null&&i>1){for(let l=e.length-1;l>=0;l--)if(e[l][0]===I){u=l;break}}for(let l=0;l<e.length;l++){let h=e[l],p=h[0];if(p===I){if(h.length>=2){let f=!1;if(a&&this._cached!==void 0)try{f=this._equals(this._cached,h[1])}catch(c){o=this._wrapFnError("equals threw",c),s=l;break}if(f){r==null&&(r=e.slice(0,l)),r.push(pt),this._status="resolved";continue}this._cached=h[1],this._versioning!=null&&(u<0||l===u)&&Ht(this._versioning,h[1],this._hashFn)}this._status="settled",r?.push(h)}else if(r?.push(h),p===H)this._status="dirty";else if(p===Q)this._status="resolved";else if(p===Y){this._status="completed";{let f=this._config.rigorRecorder;if(f!=null)try{f.onTerminalTransition(this,"completed",this._autoComplete,this._autoError,this._deps.length>0)}catch{}}}else if(p===z){this._status="errored";{let f=this._config.rigorRecorder;if(f!=null)try{f.onTerminalTransition(this,"errored",this._autoComplete,this._autoError,this._deps.length>0)}catch{}}}else if(p===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 f=this._cleanup;if(typeof f=="function"){this._cleanup=void 0;try{f()}catch{}}else if(f!=null&&typeof f=="object"){let c=f.invalidate;if(typeof c=="function")try{c()}catch{}}}else p===q&&(this._resetOnTeardown&&(this._cached=void 0),this._deactivate(!0),this._status="sentinel")}let d=s>=0?r??e.slice(0,s):r??e;return o!=null?{finalMessages:d,equalsError:o}:{finalMessages:d}}_deliverToSinks=e=>{if(this._sinks==null)return;if(typeof this._sinks=="function"){this._sinks(e);return}let n=[...this._sinks];for(let r of n)r(e)};_dispatchOrAccumulate(e){if($t()){this._batchPendingMessages===null&&(this._batchPendingMessages=[],ke(()=>this._flushBatchPending()));for(let n of e)this._batchPendingMessages.push(n);return}He(this._deliverToSinks,e,this._config.tierOf)}_flushBatchPending(){let e=this._batchPendingMessages;if(e===null||(this._batchPendingMessages=null,e.length===0))return;let n=this._frameBatch(e);He(this._deliverToSinks,n,this._config.tierOf)}},Jt=t=>Array.isArray(t),xt=t=>typeof t=="object"&&t!=null&&!Array.isArray(t)});function X(t,e){return Me([],{...e,initial:t})}function Ve(t,e){return Me((r,o,s)=>t(o,s)??void 0,{describeKind:"producer",...e})}function K(t,e,n){return Me(t,(o,s,i)=>{let a=o.map((u,d)=>u!=null&&u.length>0?u.at(-1):i.prevData[d]);s.emit(e(a,i))},{describeKind:"derived",...n})}var _e=Z(()=>{"use strict";ve()});function nr(t){return{describeKind:"producer",...t}}function Xt(t,e){let{signal:n,period:r,...o}=e??{};return Ve(s=>{let i=!1,a=0,u,d,l=()=>{i=!0,u!==void 0&&clearTimeout(u),d!==void 0&&clearInterval(d),n?.removeEventListener("abort",p)},h=()=>{i||(r!=null?(s.emit(a++),d=setInterval(()=>{i||s.emit(a++)},r)):(i=!0,n?.removeEventListener("abort",p),s.emit(a++),s.down([[Y]])))},p=()=>{i||(l(),s.down([[z,n.reason]]))};if(n?.aborted){p();return}return u=setTimeout(h,t),n?.addEventListener("abort",p,{once:!0}),l},nr(o))}function re(t){return t.subscribe(()=>{})}var Ue=Z(()=>{"use strict";pe();_e()});function Ye(t,e){if(e!=null&&e.length>0)return new Set(e);switch(t){case"standard":return new Set(["type","status","value","deps","meta","v"]);case"full":return null;case"spec":return new Set(["type","deps","meta"]);default:return new Set(["type","deps"])}}function rr(t){return t._describeKind!=null?t._describeKind:t._deps.length>0?"derived":t._fn!=null?"producer":"state"}function or(t){let e={};for(let[n,r]of Object.entries(t.meta))try{e[n]=r.cache}catch{}return e}function Rt(t,e){let n=e==null,r=!n&&e!=null?[...e].filter(d=>d.startsWith("meta.")).map(d=>d.slice(5)):null,o=n||e.has("meta")||r!=null&&r.length>0,s="state",i=[];t instanceof F&&(s=rr(t),i=t._deps.map(d=>d.node.name??""));let a={type:s,deps:i};(n||e.has("status"))&&(a.status=t.status);let u=t instanceof F?t._guard:void 0;if(o){let d={...or(t)};if(u!=null&&d.access===void 0&&(d.access=yt(u)),r!=null&&r.length>0&&!e.has("meta")){let l={};for(let h of r)h in d&&(l[h]=d[h]);a.meta=l}else a.meta=d}if(t.name!=null&&(a.name=t.name),n||e.has("value")){t.status==="sentinel"&&(a.sentinel=!0);try{a.value=t.cache}catch{}}if((n||e.has("v"))&&t.v!=null){let d={id:t.v.id,version:t.v.version};"cid"in t.v&&(d.cid=t.v.cid,d.prev=t.v.prev),a.v=d}return(n||e.has("guard"))&&u!=null&&(a.guard=yt(u)),(n||e.has("lastMutation"))&&t.lastMutation!=null&&(a.lastMutation=t.lastMutation),a}var Zt=Z(()=>{"use strict";Pe();ve()});var Je,en=Z(()=>{"use strict";Je=class{_timer;_gen=0;start(e,n){this.cancel(),this._gen+=1;let r=this._gen;this._timer=setTimeout(()=>{this._timer=void 0,r===this._gen&&n()},e)}cancel(){this._timer!==void 0&&(clearTimeout(this._timer),this._timer=void 0)}get pending(){return this._timer!==void 0}}});var co={};zn(co,{collection:()=>io,cosineSimilarity:()=>In,decay:()=>At,knowledgeGraph:()=>uo,lightCollection:()=>oo,vectorIndex:()=>ao});module.exports=Kn(co);me();ve();_e();$e();me();pe();_e();var Tt=class{_version=0;_store=new Map;_maxSize;_defaultTtl;constructor(e={}){let{maxSize:n,defaultTtl:r}=e;if(n!==void 0&&n<1)throw new RangeError("maxSize must be >= 1");if(r!==void 0&&r<=0)throw new RangeError("defaultTtl must be positive");this._maxSize=n,this._defaultTtl=r}get version(){return this._version}get size(){return this._store.size}has(e){let n=this._store.get(e);return n===void 0?!1:this._isExpired(n)?(this._store.delete(e),this._version+=1,!1):(this._touchLru(e,n),!0)}get(e){let n=this._store.get(e);if(n!==void 0){if(this._isExpired(n)){this._store.delete(e),this._version+=1;return}return this._touchLru(e,n),n.value}}set(e,n,r){let o=this._resolveExpiresAt(r);this._store.has(e)&&this._store.delete(e),this._store.set(e,{value:n,expiresAt:o}),this._evictLruWhileOver(),this._version+=1}setMany(e,n){let r=this._resolveExpiresAt(n),o=0;try{for(let[s,i]of e)this._store.has(s)&&this._store.delete(s),this._store.set(s,{value:i,expiresAt:r}),o+=1}finally{o>0&&(this._evictLruWhileOver(),this._version+=1)}}delete(e){let n=this._store.delete(e);return n&&(this._version+=1),n}deleteMany(e){let n=0;try{for(let r of e)this._store.delete(r)&&(n+=1)}finally{n>0&&(this._version+=1)}return n}clear(){let e=this._store.size;return e===0?0:(this._store.clear(),this._version+=1,e)}pruneExpired(){let e=V(),n=0;for(let[r,o]of this._store)this._isExpired(o,e)&&(this._store.delete(r),n+=1);return n>0&&(this._version+=1),n}toMap(){let e=V(),n=new Map;for(let[r,o]of this._store)this._isExpired(o,e)||n.set(r,o.value);return n}_resolveExpiresAt(e){let n=e??this._defaultTtl;if(n!==void 0){if(!Number.isFinite(n)||n<=0)throw new RangeError(`MapBackend: ttl must be a positive finite number (got ${n})`);return V()+n*1e9}}_isExpired(e,n){return e.expiresAt===void 0?!1:(n??V())>=e.expiresAt}_touchLru(e,n){this._store.delete(e),this._store.set(e,n)}_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 Ae(t={}){let{name:e,maxSize:n,defaultTtl:r,versioning:o,backend:s,retention:i}=t;if(i&&n!==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=s??new Tt({maxSize:n,defaultTtl:r}),u=X(a.toMap(),{name:e,describeKind:"state",equals:(p,f)=>p===f,...o!=null?{versioning:o}:{}});function d(){let p=a.toMap();Ee(()=>{u.down([[H]]),u.down([[I,p]])})}function l(){if(!i)return;let p=a.toMap(),f=i.archiveThreshold,c=i.maxSize,y=[];for(let[w,E]of p)y.push({key:w,value:E,score:i.score(w,E)});y.sort((w,E)=>w.score-E.score);let g=new Set;if(f!==void 0)for(let w of y)if(w.score<f)g.add(w.key);else break;if(c!==void 0&&y.length-g.size>c)for(let w of y){if(y.length-g.size<=c)break;g.has(w.key)||g.add(w.key)}if(g.size!==0)for(let w of y)g.has(w.key)&&(i.onArchive?.(w.key,w.value,w.score),a.delete(w.key))}function h(p,f="mutation"){let c=a.version;try{return p()}finally{a.version!==c&&(f==="mutation"&&l(),d())}}return{entries:u,has(p){return h(()=>a.has(p),"read")},get(p){return h(()=>a.get(p),"read")},set(p,f,c){h(()=>a.set(p,f,c?.ttl))},setMany(p,f){h(()=>a.setMany(p,f?.ttl))},delete(p){h(()=>a.delete(p))},deleteMany(p){h(()=>a.deleteMany(p))},clear(){h(()=>a.clear())},pruneExpired(){h(()=>a.pruneExpired())},get size(){return a.size},dispose(){}}}Ue();ft();$e();me();Pe();pe();Zt();ve();_e();me();function kt(t,e){if(Object.is(t,e))return!0;if(t==null||e==null||typeof t!="object"||typeof e!="object")return!1;if(Array.isArray(t)){if(!Array.isArray(e)||t.length!==e.length)return!1;for(let s=0;s<t.length;s++)if(!kt(t[s],e[s]))return!1;return!0}if(Array.isArray(e))return!1;let n=Object.keys(t),r=Object.keys(e);if(n.length!==r.length)return!1;let o=new Set(r);for(let s of n)if(!o.has(s)||!kt(t[s],e[s]))return!1;return!0}function Qt(t,e){return`${t}\0${e}`}function Et(t,e){let n=[],r=new Set(t.subgraphs),o=new Set(e.subgraphs),s=[];for(let g of o)r.has(g)||s.push(g);s.sort();for(let g of s)n.push({type:"subgraph-mounted",path:g});let i=new Set(Object.keys(t.nodes)),a=new Set(Object.keys(e.nodes)),u=[];for(let g of a)i.has(g)||u.push(g);u.sort();for(let g of u)n.push({type:"node-added",path:g,node:{...e.nodes[g]}});let d=[];for(let g of a){if(!i.has(g))continue;let w=t.nodes[g]?.meta,E=e.nodes[g]?.meta;w==null&&E==null||kt(w??{},E??{})||d.push(g)}d.sort();for(let g of d)n.push({type:"node-meta-changed",path:g,prevMeta:t.nodes[g]?.meta??{},nextMeta:e.nodes[g]?.meta??{}});let l=new Map;for(let g of t.edges)l.set(Qt(g.from,g.to),g);let h=new Map;for(let g of e.edges)h.set(Qt(g.from,g.to),g);let p=[];for(let[g,w]of h)l.has(g)||p.push(w);p.sort((g,w)=>g.from<w.from?-1:g.from>w.from?1:g.to<w.to?-1:g.to>w.to?1:0);for(let g of p)n.push({type:"edge-added",from:g.from,to:g.to});let f=[];for(let[g,w]of l)h.has(g)||f.push(w);f.sort((g,w)=>g.from<w.from?-1:g.from>w.from?1:g.to<w.to?-1:g.to>w.to?1:0);for(let g of f)n.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)n.push({type:"node-removed",path:g});let y=[];for(let g of r)o.has(g)||y.push(g);y.sort();for(let g of y)n.push({type:"subgraph-unmounted",path:g});return{events:n,flushedAt_ns:V()}}Ue();en();var ze=class{constructor(e){this.capacity=e;if(!Number.isInteger(e)||e<=0)throw new Error(`RingBuffer capacity must be a positive integer (got ${e})`);this.buf=new Array(e)}buf;head=0;_size=0;get size(){return this._size}get maxSize(){return this.capacity}push(e){let n=(this.head+this._size)%this.capacity;this.buf[n]=e,this._size<this.capacity?this._size++:this.head=(this.head+1)%this.capacity}shift(){if(this._size===0)return;let e=this.buf[this.head];return this.buf[this.head]=void 0,this.head=(this.head+1)%this.capacity,this._size--,e}at(e){if(this._size===0)return;let n=e<0?this._size+e:e;if(!(n<0||n>=this._size))return this.buf[(this.head+n)%this.capacity]}toArray(){let e=new Array(this._size);for(let n=0;n<this._size;n++)e[n]=this.buf[(this.head+n)%this.capacity];return e}clear(){for(let e=0;e<this._size;e++)this.buf[(this.head+e)%this.capacity]=void 0;this.head=0,this._size=0}};lt();function Nt(t){return t>=768&&t<=879||t>=1155&&t<=1161||t>=1425&&t<=1469||t>=1552&&t<=1562||t>=1611&&t<=1631||t>=1648&&t===1648||t>=1750&&t<=1756||t>=1759&&t<=1764||t>=1767&&t<=1768||t>=1770&&t<=1773||t>=1840&&t<=1866||t>=1958&&t<=1968||t>=2304&&t<=2307||t>=2362&&t<=2383||t>=2385&&t<=2391||t>=2402&&t<=2403||t>=2433&&t<=2435||t>=2492&&t<=2509||t>=2561&&t<=2563||t>=2620&&t<=2641||t>=2672&&t<=2673||t>=2677&&t===2677||t>=3633&&t===3633||t>=3636&&t<=3642||t>=3655&&t<=3662||t>=3761&&t===3761||t>=3764&&t<=3772||t>=3784&&t<=3790||t>=7616&&t<=7679||t>=8400&&t<=8447||t>=65024&&t<=65039||t>=65056&&t<=65071||t===8205?0:t>=4352&&t<=4447||t>=8986&&t<=8987||t>=9001&&t<=9002||t>=9193&&t<=9203||t>=9208&&t<=9210||t>=9725&&t<=9726||t>=9748&&t<=9749||t>=9800&&t<=9811||t===9855||t===9875||t===9889||t>=9898&&t<=9899||t>=9917&&t<=9918||t>=9924&&t<=9925||t===9934||t===9940||t===9962||t>=9970&&t<=9971||t===9973||t===9978||t===9981||t===9986||t===9989||t>=9992&&t<=9997||t===9999||t>=10067&&t<=10069||t===10071||t>=10133&&t<=10135||t===10160||t===10175||t>=10548&&t<=10549||t>=11013&&t<=11015||t>=11035&&t<=11036||t===11088||t===11093||t>=11904&&t<=12350||t>=12352&&t<=12447||t>=12448&&t<=12543||t>=12549&&t<=12591||t>=12593&&t<=12686||t>=12688&&t<=12771||t>=12784&&t<=12830||t>=12832&&t<=12871||t>=12880&&t<=19903||t>=19968&&t<=40959||t>=43360&&t<=43388||t>=44032&&t<=55203||t>=63744&&t<=64255||t>=65040&&t<=65049||t>=65072&&t<=65131||t>=65281&&t<=65376||t>=65504&&t<=65510||t>=126980&&t===126980||t===127183||t>=127344&&t<=127345||t===127358||t===127359||t===127374||t>=127377&&t<=127386||t>=127456&&t<=127487||t>=127488&&t<=127490||t===127514||t===127535||t>=127538&&t<=127546||t>=127568&&t<=127569||t>=127744&&t<=129535||t>=129536&&t<=129791||t>=129792&&t<=130047||t>=131072&&t<=196605||t>=196608&&t<=262141?2:1}function Xe(t){let e=0;for(let n of t)e+=Nt(n.codePointAt(0));return e}function tn(t,e){if(e<=0)return"";let n=0,r="";for(let o of t){let s=Nt(o.codePointAt(0));if(n+s>e){if(e<=1)return"\u2026";for(;n+1>e&&r.length>0;){let i=[...r].pop();r=r.slice(0,-i.length),n-=Nt(i.codePointAt(0))}return`${r}\u2026`}r+=o,n+=s}return r}var sr={horizontal:"\u2500",vertical:"\u2502",cornerTL:"\u250C",cornerTR:"\u2510",cornerBL:"\u2514",cornerBR:"\u2518",tDown:"\u252C",tUp:"\u2534",tRight:"\u251C",tLeft:"\u2524",cross:"\u253C",arrowRight:"\u25B6",arrowDown:"\u25BC",arrowLeft:"\u25C0",arrowUp:"\u25B2",boxTL:"\u250C",boxTR:"\u2510",boxBL:"\u2514",boxBR:"\u2518",boxH:"\u2500",boxV:"\u2502"},ir={horizontal:"-",vertical:"|",cornerTL:"+",cornerTR:"+",cornerBL:"+",cornerBR:"+",tDown:"+",tUp:"+",tRight:"+",tLeft:"+",cross:"+",arrowRight:">",arrowDown:"v",arrowLeft:"<",arrowUp:"^",boxTL:"+",boxTR:"+",boxBL:"+",boxBR:"+",boxH:"-",boxV:"|"};function sn(t,e){let n=e.charset==="ascii"?ir:sr,r=t.width,o=t.height,s=Array.from({length:o},()=>Array.from({length:r},()=>" ")),i=Array.from({length:o},()=>Array.from({length:r},()=>"empty"));for(let a of t.edges)dr(s,i,n,a);for(let a of t.boxes)ar(s,i,n,a,e.labelOf(a.id));return s.map(a=>fr(a.join(""))).join(`
2
+ `)}function ar(t,e,n,r,o){let{x:s,y:i,w:a,h:u}=r;if(a<2||u<2){u>0&&nn(t,e,s,i,a,o);return}he(t,e,s,i,n.boxTL);for(let l=s+1;l<s+a-1;l+=1)he(t,e,l,i,n.boxH);he(t,e,s+a-1,i,n.boxTR);for(let l=i+1;l<i+u-1;l+=1){he(t,e,s,l,n.boxV);for(let h=s+1;h<s+a-1;h+=1)an(t,e,h,l," ","empty");he(t,e,s+a-1,l,n.boxV)}he(t,e,s,i+u-1,n.boxBL);for(let l=s+1;l<s+a-1;l+=1)he(t,e,l,i+u-1,n.boxH);he(t,e,s+a-1,i+u-1,n.boxBR);let d=i+Math.floor(u/2);nn(t,e,s+1,d,a-2,o)}function he(t,e,n,r,o){an(t,e,n,r,o,o===" "?"empty":o==="\u2500"||o==="-"?"boxH":o==="\u2502"||o==="|"?"boxV":"boxCorner")}function an(t,e,n,r,o,s){if(r<0||r>=t.length)return;let i=t[r];n<0||n>=i.length||(i[n]=o,e[r][n]=s)}function nn(t,e,n,r,o,s){if(r<0||r>=t.length)return;let i=n,a=o;for(let u of s){let d=Xe(u);if(d!==0){if(a<d)break;i>=0&&i<t[r].length&&(t[r][i]=u,e[r][i]="label",d===2&&i+1<t[r].length&&(t[r][i+1]="",e[r][i+1]="label")),i+=d,a-=d}}for(;a>0;)i>=0&&i<t[r].length&&(t[r][i]=" ",e[r][i]="empty"),i+=1,a-=1}function dr(t,e,n,r){let o=r.points;if(o.length<2)return;for(let u=0;u+1<o.length;u+=1)ur(t,e,n,o[u],o[u+1]);for(let u=1;u+1<o.length;u+=1){let d=o[u-1],l=o[u],h=o[u+1],p=cr(d,l,h,n);p&&on(t,e,l.x,l.y,p,"edgeCorner")}let s=o[o.length-1],i=o[o.length-2],a=lr(i,s,n);a&&on(t,e,s.x,s.y,a,"arrow")}function ur(t,e,n,r,o){if(!(r.x===o.x&&r.y===o.y)){if(r.y===o.y){let s=r.y,i=Math.min(r.x,o.x),a=Math.max(r.x,o.x);for(let u=i;u<=a;u+=1)rn(t,e,u,s,n,"h")}else if(r.x===o.x){let s=r.x,i=Math.min(r.y,o.y),a=Math.max(r.y,o.y);for(let u=i;u<=a;u+=1)rn(t,e,s,u,n,"v")}}}function rn(t,e,n,r,o,s){if(r<0||r>=t.length)return;let i=t[r];if(n<0||n>=i.length)return;let a=e[r][n];if(!(a==="boxH"||a==="boxV"||a==="boxCorner"||a==="label")){if(a==="empty"){i[n]=s==="h"?o.horizontal:o.vertical,e[r][n]=s==="h"?"edgeH":"edgeV";return}if(a==="edgeH"&&s==="v"){i[n]=o.cross,e[r][n]="edgeCorner";return}if(a==="edgeV"&&s==="h"){i[n]=o.cross,e[r][n]="edgeCorner";return}}}function on(t,e,n,r,o,s){if(r<0||r>=t.length)return;let i=t[r];if(n<0||n>=i.length)return;let a=e[r][n];a==="boxH"||a==="boxV"||a==="boxCorner"||a==="label"||(i[n]=o,e[r][n]=s)}function cr(t,e,n,r){let o=t.y===e.y,s=e.y===n.y;if(o===s)return;if(o){let u=t.x<e.x,d=n.y>e.y;return u&&d?r.cornerTR:u&&!d?r.cornerBR:!u&&d?r.cornerTL:r.cornerBL}let i=t.y<e.y,a=n.x>e.x;return i&&a?r.cornerBL:i&&!a?r.cornerBR:!i&&a?r.cornerTL:r.cornerTR}function lr(t,e,n){if(e.x>t.x)return n.arrowRight;if(e.x<t.x)return n.arrowLeft;if(e.y>t.y)return n.arrowDown;if(e.y<t.y)return n.arrowUp}function fr(t){let e=t.length;for(;e>0&&t.charCodeAt(e-1)===32;)e-=1;return t.slice(0,e)}function cn(t){let e=pr(t);hr(e),gr(e),mr(e),yr(e,t);let n=_r(e,t),{width:r,height:o}=xr(e),s=[];for(let i of e.layers)for(let a of i)a.isVirtual||s.push({id:a.id,layer:a.layer,order:a.order,x:a.x,y:a.y,w:a.w,h:a.h});return{boxes:s,edges:n,width:r,height:o}}function pr(t){let e=new Map;for(let o of t.nodes)e.set(o,{id:o,isVirtual:!1,layer:-1,order:0,x:0,y:0,w:t.widthCells(o),h:t.heightCells(o),in:[],out:[]});let n=[],r=0;for(let o of t.edges){if(o.from===o.to)continue;let s=e.get(o.from),i=e.get(o.to);if(!s||!i)continue;let a={chainId:r++,chainFrom:o.from,chainTo:o.to,fromId:o.from,toId:o.to,hopIndex:0,chainLen:1};s.out.push(a),i.in.push(a),n.push(a)}return{nodes:e,layers:[],hops:n}}function hr(t){let e=new Map;for(let s of t.nodes.values())e.set(s.id,s.in.length);let n=[];for(let s of t.nodes.values())(e.get(s.id)??0)===0&&(s.layer=0,n.push(s));let r=new Set,o=0;for(;o<n.length;){let s=n[o++];if(!r.has(s.id)){r.add(s.id);for(let i of s.out){let a=t.nodes.get(i.toId);a.layer=Math.max(a.layer,s.layer+1);let u=(e.get(a.id)??0)-1;e.set(a.id,u),u<=0&&n.push(a)}}}for(let s of t.nodes.values())s.layer<0&&(s.layer=0)}function gr(t){let e=Math.max(0,...Array.from(t.nodes.values(),s=>s.layer)),n=Array.from({length:e+1},()=>[]);for(let s of t.nodes.values())n[s.layer].push(s);let r=[],o=0;for(let s of t.hops){let i=t.nodes.get(s.fromId),a=t.nodes.get(s.toId),u=a.layer-i.layer;if(u<=0){i.out=i.out.filter(h=>h!==s),a.in=a.in.filter(h=>h!==s);continue}if(u===1){s.hopIndex=0,s.chainLen=1,r.push(s);continue}i.out=i.out.filter(h=>h!==s),a.in=a.in.filter(h=>h!==s);let d=i;for(let h=1;h<u;h+=1){let p=`__virt_${o++}__`,f={id:p,isVirtual:!0,layer:i.layer+h,order:0,x:0,y:0,w:0,h:1,in:[],out:[]};t.nodes.set(p,f),n[f.layer].push(f);let c={chainId:s.chainId,chainFrom:s.chainFrom,chainTo:s.chainTo,fromId:d.id,toId:p,hopIndex:h-1,chainLen:u};d.out.push(c),f.in.push(c),r.push(c),d=f}let l={chainId:s.chainId,chainFrom:s.chainFrom,chainTo:s.chainTo,fromId:d.id,toId:a.id,hopIndex:u-1,chainLen:u};d.out.push(l),a.in.push(l),r.push(l)}for(let s of n)for(let i=0;i<s.length;i+=1)s[i].order=i;t.layers=n,t.hops=r}function mr(t){for(let n=0;n<4;n+=1){for(let r=1;r<t.layers.length;r+=1)dn(t,t.layers[r],"in"),Ze(t.layers[r]);for(let r=t.layers.length-2;r>=0;r-=1)dn(t,t.layers[r],"out"),Ze(t.layers[r])}for(let n=0;n<2;n+=1){let r=!1;for(let o=1;o<t.layers.length;o+=1){let s=t.layers[o];for(let i=0;i+1<s.length;i+=1){let a=un(t,s[i],s[i+1],"in");[s[i],s[i+1]]=[s[i+1],s[i]],Ze(s),un(t,s[i],s[i+1],"in")<a?r=!0:([s[i],s[i+1]]=[s[i+1],s[i]],Ze(s))}}if(!r)break}}function dn(t,e,n){let r=new Map;for(let o of e){let s=n==="in"?o.in:o.out;if(s.length===0){r.set(o.id,o.order);continue}let i=0,a=0;for(let u of s){let d=t.nodes.get(n==="in"?u.fromId:u.toId);d&&(i+=d.order,a+=1)}r.set(o.id,a===0?o.order:i/a)}e.sort((o,s)=>{let i=r.get(o.id),a=r.get(s.id);return i!==a?i-a:o.order-s.order})}function Ze(t){for(let e=0;e<t.length;e+=1)t[e].order=e}function un(t,e,n,r){let o=r==="in"?e.in:e.out,s=r==="in"?n.in:n.out,i=0;for(let a of o)for(let u of s){let d=t.nodes.get(r==="in"?a.fromId:a.toId)?.order??0,l=t.nodes.get(r==="in"?u.fromId:u.toId)?.order??0;(e.order<n.order&&d>l||e.order>n.order&&d<l)&&(i+=1)}return i}function yr(t,e){e.direction==="LR"?br(t,e):vr(t,e)}function br(t,e){let n=[],r=0;for(let o=0;o<t.layers.length;o+=1){n.push(r);let s=0;for(let i of t.layers[o])s=Math.max(s,i.w);r+=s+e.layerGap}for(let o=0;o<t.layers.length;o+=1)for(let s of t.layers[o])s.x=n[o];for(let o of t.layers){let s=0;for(let i of o)i.y=s,s+=i.h+e.nodeGap}ln(t,e,"y")}function vr(t,e){let n=[],r=0;for(let o=0;o<t.layers.length;o+=1){n.push(r);let s=0;for(let i of t.layers[o])s=Math.max(s,i.h);r+=s+e.layerGap}for(let o=0;o<t.layers.length;o+=1)for(let s of t.layers[o])s.y=n[o];for(let o of t.layers){let s=0;for(let i of o)i.x=s,s+=i.w+e.nodeGap}ln(t,e,"x")}function ln(t,e,n){let r=s=>n==="y"?s.h:s.w,o=e.nodeGap;for(let s=0;s<2;s+=1){let i=s===0?t.layers.slice(1):t.layers.slice(0,-1).reverse();for(let a of i){let u=new Map;for(let l of a){let h=s===0?l.in:l.out;if(h.length===0)continue;let p=[];for(let c of h){let y=t.nodes.get(s===0?c.fromId:c.toId);if(!y)continue;let g=n==="y"?y.y:y.x;p.push(g+Math.floor(r(y)/2))}if(p.length===0)continue;p.sort((c,y)=>c-y);let f=p[Math.floor(p.length/2)];u.set(l.id,f-Math.floor(r(l)/2))}let d=0;for(let l of a){let h=u.get(l.id),p=n==="y"?l.y:l.x,c=Math.max(h??p,d);n==="y"?l.y=c:l.x=c,d=c+r(l)+o}}}}function _r(t,e){let n=new Map;for(let d of t.hops){let l=n.get(d.chainId);l?l.push(d):n.set(d.chainId,[d])}for(let d of n.values())d.sort((l,h)=>l.hopIndex-h.hopIndex);let r=e.direction==="LR",o=d=>r?d.x:d.y,s=d=>r?d.w:d.h,i=d=>r?d.y+Math.floor(d.h/2):d.x+Math.floor(d.w/2),a=new Map;for(let d=0;d+1<t.layers.length;d+=1){let l=t.layers[d],h=t.layers[d+1],p=0;for(let b of l)p=Math.max(p,o(b)+s(b));let f=Number.POSITIVE_INFINITY;for(let b of h)f=Math.min(f,o(b));let c=Number.isFinite(f)?f-1:p,y=Math.max(1,c-p+1),g=[];for(let b of l)for(let v of b.out)g.push(v);g.sort((b,v)=>{let R=i(t.nodes.get(b.fromId)),T=i(t.nodes.get(v.fromId));if(R!==T)return R-T;let k=i(t.nodes.get(b.toId)),_=i(t.nodes.get(v.toId));return k-_});let w=[],E=new Map;for(let b of g){let v=i(t.nodes.get(b.fromId)),R=i(t.nodes.get(b.toId)),T=Math.min(v,R),k=Math.max(v,R),_=-1;for(let O=0;O<w.length;O+=1){let D=w[O],C=!0;for(let L of D)if(L.lo<=k&&T<=L.hi){C=!1;break}if(C){D.push({lo:T,hi:k}),_=O;break}}_<0&&(w.push([{lo:T,hi:k}]),_=w.length-1),E.set(b,_)}let x=w.length,N=y>=Math.max(3,x+2),M=N?p+1:p,S=N?c-1:c,m=Math.max(1,S-M+1);for(let b of g){let v=E.get(b),R;if(x<=1)R=M+Math.floor(m/2);else{let T=(m-1)/(x-1);R=M+Math.floor(v*T)}a.set(b,Math.max(p,Math.min(c,R)))}}let u=[];for(let[,d]of n){let l=[];for(let p=0;p<d.length;p+=1){let f=d[p],c=t.nodes.get(f.fromId),y=t.nodes.get(f.toId),g=a.get(f),w=c.isVirtual?o(c):o(c)+s(c),E=y.isVirtual?o(y):o(y)-1,x=i(c),N=i(y);p===0&&Qe(l,r,w,x),x!==N&&(Qe(l,r,g,x),Qe(l,r,g,N)),Qe(l,r,E,N)}let h=d[0];u.push({from:h.chainFrom,to:h.chainTo,points:wr(l)})}return u}function Qe(t,e,n,r){t.push(e?{x:n,y:r}:{x:r,y:n})}function wr(t){let e=[];for(let n of t){let r=e[e.length-1];(!r||r.x!==n.x||r.y!==n.y)&&e.push(n)}return e}function xr(t){let e=0,n=0;for(let r of t.layers)for(let o of r)e=Math.max(e,o.x+o.w),n=Math.max(n,o.y+o.h);return{width:e,height:n}}var Tr=24,Rr=4,kr=1,Er=3;function fn(t,e){let n=Nr(e.direction),r=Math.max(3,e.maxLabelWidth??Tr),o=e.asciiCharset??"unicode",s=Object.keys(t.nodes).sort(),i=new Set(s),a=t.edges.filter(f=>i.has(f.from)&&i.has(f.to)),u=new Map,d=new Map;for(let f of s){let c=tn(f,r);u.set(f,c),d.set(f,Xe(c)+4)}let l=cn({nodes:s,edges:a,widthCells:f=>d.get(f)??3,heightCells:()=>Er,layerGap:Rr,nodeGap:kr,direction:n}),h=sn(l,{charset:o,labelOf:f=>u.get(f)??f}),p=e.logger;return p&&p(h),h}function Nr(t){if(t===void 0||t==="LR")return"LR";if(t==="TD")return"TD";throw new Error(`ascii describe supports direction "LR" or "TD" only; got ${String(t)}`)}function pn(t,e,n,r={}){let o=e in t.nodes,s=n in t.nodes;if(!o)return et(e,n,"no-such-from");if(!s)return et(e,n,"no-such-to");let i=r.maxDepth;if(i!=null&&(!Number.isInteger(i)||i<0))throw new Error("explainPath: maxDepth must be an integer >= 0");if(e===n){if(r.findCycle===!0){let d=Or(t,e,r);if(d!=null)return d}let u=tt(e,t.nodes[e],0,r);return nt(e,n,[u])}if(i===0)return et(e,n,"no-path");let a=hn(t,e,n,i);return a.found?nt(e,n,gn(t,a.pathOrder,r)):et(e,n,a.truncated?"max-depth-exceeded":"no-path")}function hn(t,e,n,r){let o=new Map,s=[{path:n,depth:0}],i=new Set([n]),a=0,u=!1;for(;a<s.length;){let h=s[a++];if(h.path===e)break;if(r!=null&&h.depth>=r){let y=t.nodes[h.path];y?.deps&&y.deps.length>0&&(u=!0);continue}let p=t.nodes[h.path];if(p==null)continue;let f=p.deps??[],c=new Map;for(let y=0;y<f.length;y++){let g=f[y];if(!g)continue;let w=c.get(g);w==null&&(w=[],c.set(g,w)),w.push(y)}for(let[y,g]of c)i.has(y)||(i.add(y),o.set(y,{from:h.path,depIndices:g}),s.push({path:y,depth:h.depth+1}))}if(!o.has(e))return{found:!1,pathOrder:[],truncated:u};let d=[{path:e}],l=e;for(;l!==n;){let h=o.get(l);if(h==null)return{found:!1,pathOrder:[],truncated:!1};d[d.length-1].depIndices=h.depIndices,d.push({path:h.from}),l=h.from}return{found:!0,pathOrder:d,truncated:!1}}function Or(t,e,n){let r=t.nodes[e];if(r==null)return null;let o=r.deps??[],s=[];for(let a=0;a<o.length;a++)o[a]===e&&s.push(a);if(s.length>0){let a=tt(e,r,0,n);a.dep_index=s[0];let u=tt(e,r,1,n);return nt(e,e,[a,u])}let i=null;for(let a=0;a<o.length;a++){let u=o[a];if(!u||u===e)continue;let d=hn(t,u,e,n.maxDepth);d.found&&(i==null||d.pathOrder.length<i.pathOrder.length)&&(i=d,i={found:!0,pathOrder:[{path:e,depIndices:[a]},...d.pathOrder],truncated:!1})}return i==null?null:nt(e,e,gn(t,i.pathOrder,n))}function gn(t,e,n){return e.map((r,o)=>{let s=t.nodes[r.path],i=tt(r.path,s,o,n);return r.depIndices!=null&&r.depIndices.length>0&&(i.dep_index=r.depIndices[0],r.depIndices.length>1&&(i.dep_indices=[...r.depIndices])),i})}function tt(t,e,n,r){let o={path:t,type:e.type,hop:n};e.status!==void 0&&(o.status=e.status),"value"in e&&(o.value=e.value),e.v!=null&&(o.v=e.v);let s=r.annotations?.get(t)??e.annotation;s!=null&&(o.annotation=s);let i=r.lastMutations?.get(t)??e.lastMutation;return i!=null&&(o.lastMutation=i),o}function nt(t,e,n){return mn(t,e,!0,"ok",n)}function et(t,e,n){return mn(t,e,!1,n,[])}function mn(t,e,n,r,o){let s=Sr(t,e,n,r,o);return{from:t,to:e,found:n,reason:r,steps:o,text:s,toJSON(){return{from:t,to:e,found:n,reason:r,steps:o}}}}function Sr(t,e,n,r,o){if(!n)switch(r){case"no-such-from":return`explainPath: no node named "${t}"`;case"no-such-to":return`explainPath: no node named "${e}"`;case"max-depth-exceeded":return`explainPath: no path from "${t}" to "${e}" within maxDepth`;default:return`explainPath: no path from "${t}" to "${e}"`}let s=[`Causal path: ${t} \u2192 ${e} (${o.length} step(s))`];for(let i of o){let u=` ${i.hop===0?"\xB7":"\u2193"} ${i.path} (${i.type}${i.status?`/${i.status}`:""})`;if(s.push(u),"value"in i&&s.push(` value: ${Mr(i.value)}`),i.annotation!=null&&s.push(` annotation: ${i.annotation}`),i.lastMutation!=null){let d=i.lastMutation.actor;s.push(` actor: ${d.type}${d.id?`:${d.id}`:""}`)}}return s.join(`
3
+ `)}function Mr(t){if(t===void 0)return"<sentinel>";if(t===null)return"null";if(typeof t=="string")return JSON.stringify(t);if(typeof t=="number"||typeof t=="boolean"||typeof t=="bigint")return String(t);try{let e=JSON.stringify(t);return e.length>80?`${e.slice(0,77)}...`:e}catch{return String(t)}}ve();var B={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},Ar=Symbol.for("sizeof");function yn(t){let e=new WeakSet,n=new WeakSet,r=[t],o=0;for(;r.length>0;){let s=r.pop();o+=Cr(s,e,n,r)}return o}function Cr(t,e,n,r){if(t==null)return 0;switch(typeof t){case"number":return B.number;case"boolean":return B.boolean;case"string":return B.string+t.length*2;case"bigint":return B.bigint+Dr(t);case"symbol":return B.symbol;case"function":return e.has(t)?0:(e.add(t),B.function);case"undefined":return 0}let s=t;if(e.has(s))return 0;e.add(s);let i=s[Ar];if(typeof i=="function")try{let d=i.call(s);if(typeof d=="number"&&Number.isFinite(d))return d}catch{}if(s instanceof Date)return B.date;if(s instanceof RegExp)return B.regexp+s.source.length*2;if(s instanceof Error){let d=s.message?s.message.length*2:0,l=s.stack?s.stack.length*2:0;return B.error+d+l}if(typeof URL<"u"&&s instanceof URL)return B.url+s.href.length*2;if(typeof Promise<"u"&&s instanceof Promise)return B.promise;if(s instanceof WeakMap)return B.weakmap;if(s instanceof WeakSet)return B.weakset;if(s instanceof Map){let d=B.map;for(let[l,h]of s)d+=B.mapEntry,r.push(l),r.push(h);return d}if(s instanceof Set){let d=B.set;for(let l of s)d+=B.setEntry,r.push(l);return d}if(Array.isArray(s)){let d=B.array+s.length*8;for(let l of s)r.push(l);return d}if(s instanceof ArrayBuffer)return n.has(s)?0:(n.add(s),s.byteLength);if(ArrayBuffer.isView(s)){let d=s;return n.has(d.buffer)?48:(n.add(d.buffer),d.buffer.byteLength+48)}let a=B.object,u=Object.keys(s);for(let d of u){a+=B.string+d.length*2;try{r.push(s[d])}catch{}}return a}function Dr(t){let e=t<0n?-t:t;if(e===0n)return 0;let n=e.toString(2).length;return Math.ceil(n/32)*8}function bn(t,e){let n=e?.topN??10,r=t.describe({detail:"standard"}),o=[],s=t._collectObserveTargets;typeof s=="function"&&s.call(t,"",o);let i=new Map;for(let[p,f]of o)i.set(p,f);let a=[];for(let[p,f]of Object.entries(r.nodes)){let c=i.get(p),y=c instanceof F?c:null,g=y?yn(y.cache):0,w=y?y._sinkCount:0,E=f.deps?.length??0,x=f.type==="effect"&&w===0,N=w===0?f.type==="effect"?"orphan-effect":f.type==="derived"?"idle-derived":f.type==="producer"?"idle-producer":null:null;a.push({path:p,type:f.type,status:f.status??"unknown",valueSizeBytes:g,subscriberCount:w,depCount:E,isOrphanEffect:x,orphanKind:N})}let u=a.reduce((p,f)=>p+f.valueSizeBytes,0),d=(p,f)=>[...a].sort(f??((c,y)=>y[p]-c[p])).slice(0,n),l=a.filter(p=>p.orphanKind!=null),h=a.filter(p=>p.isOrphanEffect);return{nodeCount:a.length,edgeCount:r.edges.length,subgraphCount:r.subgraphs.length,nodes:a,totalValueSizeBytes:u,hotspots:{byValueSize:d("valueSizeBytes"),bySubscriberCount:d("subscriberCount"),byDepCount:d("depCount")},orphans:l,orphanEffects:h}}var P="::",ae="__meta__",Ce=1;function vn(t,e){let n=Math.max(16,t.size*4),r=0;for(;t.size>0;){if(r++>=n){console.error(`[Graph "${e}".destroy] disposer drain exceeded cap (${n}); ${t.size} disposer(s) discarded`),t.clear();return}let o=t.values().next();if(o.done)return;let s=o.value;t.delete(s);try{s()}catch(i){console.error(`[Graph "${e}".destroy] disposer threw:`,i)}}}function Tn(t){return t!=null&&typeof t=="object"&&"cache"in t&&typeof t.subscribe=="function"&&typeof t.down=="function"}function Gr(t){if(t!=null)return Tn(t)?t.cache:t}function Lr(t){let e=[];for(let n of Object.keys(t).sort()){let r=t[n].v;r!=null&&e.push(`${n} ${r.id} ${r.version}`)}return e.join(`
4
+ `)}function _n(t){if(t.version!==Ce)throw new Error(`unsupported snapshot version ${String(t.version)} (expected ${Ce})`);for(let e of["name","nodes","edges","subgraphs"])if(!(e in t))throw new Error(`snapshot missing required key "${e}"`);if(typeof t.name!="string")throw new TypeError("snapshot 'name' must be a string");if(typeof t.nodes!="object"||t.nodes===null||Array.isArray(t.nodes))throw new TypeError("snapshot 'nodes' must be an object");if(!Array.isArray(t.edges))throw new TypeError("snapshot 'edges' must be an array");if(!Array.isArray(t.subgraphs))throw new TypeError("snapshot 'subgraphs' must be an array")}function Ir(t,e){let n=new WeakMap,r=(o,s)=>{if(Object.is(o,s))return!0;if(o==null||s==null||typeof o!="object"||typeof s!="object")return!1;let i=n.get(o);if(i==null&&(i=new WeakSet,n.set(o,i)),i.has(s))return!0;i.add(s);let a=o.constructor,u=s.constructor;if(a!==u)return!1;if(o instanceof Date)return o.getTime()===s.getTime();if(o instanceof RegExp)return o.source===s.source&&o.flags===s.flags;if(Array.isArray(o)){let p=s;if(o.length!==p.length)return!1;for(let f=0;f<o.length;f++)if(!r(o[f],p[f]))return!1;return!0}if(o instanceof Map){let p=s;if(o.size!==p.size)return!1;for(let[f,c]of o)if(!p.has(f)||!r(c,p.get(f)))return!1;return!0}if(o instanceof Set){let p=s;if(o.size!==p.size)return!1;for(let f of o){let c=!1;for(let y of p)if(r(f,y)){c=!0;break}if(!c)return!1}return!0}if(ArrayBuffer.isView(o)){let p=o,f=s;if(p.length!==f.length)return!1;for(let c=0;c<p.length;c++)if(p[c]!==f[c])return!1;return!0}let d=Object.keys(o),l=Object.keys(s);if(d.length!==l.length)return!1;let h=new Set(l);for(let p of d)if(!h.has(p)||!r(o[p],s[p]))return!1;return!0};return r(t,e)}function St(t){if(t===null||typeof t!="object")return t;if(Array.isArray(t))return t.map(St);let e=t,n=Object.keys(e).sort(),r={};for(let o of n)r[o]=St(e[o]);return r}function $r(t){return t.replaceAll("\\","\\\\").replaceAll('"','\\"')}function Pr(t){return t.replaceAll("\\","\\\\").replaceAll('"','\\"')}function Vr(t){return t==="TD"?"down":t==="BT"?"up":t==="RL"?"left":"right"}function Rn(t){let e=new Set,n=[];function r(o,s){let i=`${o}\0${s}`;e.has(i)||(e.add(i),n.push([o,s]))}for(let[o,s]of Object.entries(t.nodes)){let i=s.deps;if(i)for(let a of i)r(a,o)}for(let o of t.edges)r(o.from,o.to);return n}function kn(t){if(t===void 0)return"LR";if(t==="TD"||t==="LR"||t==="BT"||t==="RL")return t;throw new Error(`invalid diagram direction ${String(t)}; expected one of: TD, LR, BT, RL`)}function zr(t,e){let n=e.includeEdges??!0,r=e.includeSubgraphs??!0,{expand:o,...s}=t,i={...s,edges:n?t.edges:[],subgraphs:r?t.subgraphs:[]},a=JSON.stringify(St(i),null,e.indent??2);return e.logger?.(a),a}function Fr(t,e){let n=e.includeEdges??!0,r=e.includeSubgraphs??!0,o=[];o.push(`Graph ${t.name}`),o.push("Nodes:");for(let i of Object.keys(t.nodes).sort()){let a=t.nodes[i];o.push(`- ${i} (${a.type}/${a.status}): ${ot(a.value)}`)}if(n){o.push("Edges:");for(let i of t.edges)o.push(`- ${i.from} -> ${i.to}`)}if(r){o.push("Subgraphs:");for(let i of t.subgraphs)o.push(`- ${i}`)}let s=o.join(`
5
+ `);return e.logger?.(s),s}function En(t,e){let n=kn(e.direction),r=Object.keys(t.nodes).sort(),o=new Map;for(let i=0;i<r.length;i+=1)o.set(r[i],`n${i}`);let s=[`flowchart ${n}`];for(let i of r){let a=o.get(i);s.push(` ${a}["${$r(i)}"]`)}for(let[i,a]of Rn(t)){let u=o.get(i),d=o.get(a);!u||!d||s.push(` ${u} --> ${d}`)}return s.join(`
6
+ `)}function Kr(t,e){let n=En(t,e);return Br(n)}function Br(t,e){let n=e?.theme??"default",r=e?.autoSync??!0,s=JSON.stringify({code:t,mermaid:{theme:n},autoSync:r}),i=new TextEncoder().encode(s),a="";for(let d=0;d<i.length;d++)a+=String.fromCharCode(i[d]);return`https://mermaid.live/edit#base64:${globalThis.btoa(a).replace(/\+/g,"-").replace(/\//g,"_").replace(/=+$/,"")}`}function jr(t,e){let n=kn(e.direction),r=Object.keys(t.nodes).sort(),o=new Map;for(let i=0;i<r.length;i+=1)o.set(r[i],`n${i}`);let s=[`direction: ${Vr(n)}`];for(let i of r){let a=o.get(i);s.push(`${a}: "${Pr(i)}"`)}for(let[i,a]of Rn(t)){let u=o.get(i),d=o.get(a);!u||!d||s.push(`${u} -> ${d}`)}return s.join(`
7
+ `)}function Hr(t){return t.replace(/[.*+?^${}()|[\]\\]/g,"\\$&")}function rt(t){let e="^";for(let n=0;n<t.length;n+=1){let r=t[n];if(r==="*"){e+=".*";continue}if(r==="?"){e+=".";continue}if(r==="["){let o=t.indexOf("]",n+1);if(o<=n+1){e+="\\[";continue}let s=t.slice(n+1,o);s.startsWith("!")&&(s=`^${s.slice(1)}`),s=s.replace(/\\/g,"\\\\"),e+=`[${s}]`,n=o;continue}e+=Hr(r)}return e+="$",new RegExp(e)}var qr={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"},Wr={data:"",dirty:"",resolved:"",invalidate:"",pause:"",resume:"",complete:"",error:"",teardown:"",derived:"",path:"",reset:""};function ot(t){if(typeof t=="string")return JSON.stringify(t);if(typeof t=="number"||typeof t=="boolean"||t==null)return String(t);try{return JSON.stringify(t)}catch{return"[unserializable]"}}function Ur(t){return t==="none"?Wr:t==="ansi"||t==null?qr:{data:t.data??"",dirty:t.dirty??"",resolved:t.resolved??"",invalidate:t.invalidate??"",pause:t.pause??"",resume:t.resume??"",complete:t.complete??"",error:t.error??"",teardown:t.teardown??"",derived:t.derived??"",path:t.path??"",reset:t.reset??""}}function wn(t){if(t==null)return{};let e=t.detail;return e==="full"?{...t,structured:t.structured??!0,timeline:t.timeline??!0,causal:t.causal??!0,derived:t.derived??!0}:e==="minimal"?{...t,structured:t.structured??!0}:t.format==="stage-log"?{...t,structured:t.structured??!0,timeline:t.timeline??!0}:t}function Yr(t,e,n){for(let r=0;r<t.length;r++){let o=t.charCodeAt(r);if(o<32||o===127)throw new Error(`Graph "${e}": ${n} "${t}" must not contain control character (U+${o.toString(16).padStart(4,"0").toUpperCase()} at index ${r})`)}}function Ot(t,e,n){if(t==="")throw new Error(`Graph "${e}": ${n} name must be non-empty`);if(t.includes(P))throw new Error(`Graph "${e}": ${n} "${t}" must not contain '${P}' (path separator)`);if(t===ae)throw new Error(`Graph "${e}": ${n} name "${ae}" is reserved for meta companion paths`);Yr(t,e,n)}function Jr(t,e){if(t==="")throw new Error(`Graph "${e}": resolve path must be non-empty`);let n=t.split(P);for(let r of n)if(r==="")throw new Error(`Graph "${e}": resolve path has empty segment`);return n}function Xr(t,e){let n=!1;for(let o of t)if(!e.isMetaPassthrough(o[0])){n=!0;break}return n?t.filter(o=>e.isMetaPassthrough(o[0])):t}function Nn(t){for(let e of t._mounts.values())Nn(e);for(let e of t._nodes.values())try{e.down([[q]],{internal:!0})}catch{}}var we=class t{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,n){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===ae)throw new Error(`Graph name "${ae}" is reserved for meta companion paths`);this.name=e,this.opts=Object.freeze({...n??{}}),this.config=n?.config??Se,this._traceRing=new ze(n?.traceCapacity??1e3),n?.versioning!=null&&this.setVersioning(n.versioning),typeof n?.factory=="string"&&(this._factory=n.factory,n.factoryArgs!==void 0&&(this._factoryArgs=n.factoryArgs))}tagFactory(e,n){return this._factory=e,this._factoryArgs=n,this}ancestors(e=!0){let n=[],r=e?this:this._parent;for(;r!=null;)n.push(r),r=r._parent;return n}get topology(){return this._topology==null&&(this._topology=Ve(e=>{let n=r=>{e.emit(r)};return this._topologyEmitters.add(n),()=>{this._topologyEmitters.delete(n)}},{name:`${this.name}_topology`})),this._topology}_emitTopology(e){if(!(this._topology==null||this._topologyEmitters.size===0))for(let n of this._topologyEmitters)n(e)}nameOf(e){return this._nodeToName.get(e)}add(e,n){let r=e.name,o=n?.name??r;if(o==null||o==="")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 s=o,i=n?.annotation;if(Ot(s,this.name,"add"),this._mounts.has(s))throw new Error(`Graph "${this.name}": name "${s}" is already a mount point`);if(this._nodes.has(s))throw new Error(`Graph "${this.name}": node "${s}" 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(s,e),this._nodeToName.set(e,s),this._emitTopology({kind:"added",name:s,nodeKind:"node"}),i!=null&&(this._annotations.set(s,i),this.config.inspectorEnabled&&this._traceRing.push({path:s,annotation:i,timestamp_ns:V()})),e}setVersioning(e){if(e!=null)for(let n of this._nodes.values())n instanceof F&&n._applyVersioning(e)}remove(e){Ot(e,this.name,"remove");let n=this._mounts.get(e);if(n){let s={kind:"mount",nodes:[],mounts:[]},i=[];n._collectObserveTargets("",i);for(let[a,u]of i)a.includes(`${P}${ae}${P}`)||s.nodes.push(a);return s.nodes.sort(),s.mounts.push(e),s.mounts.push(...n._collectSubgraphs(`${e}${P}`)),this._mounts.delete(e),n._parent=void 0,Nn(n),this._emitTopology({kind:"removed",name:e,nodeKind:"mount",audit:s}),s}let r=this._nodes.get(e);if(!r)throw new Error(`Graph "${this.name}": unknown node or mount "${e}"`);this._nodes.delete(e),this._nodeToName.delete(r),r.down([[q]],{internal:!0});let o={kind:"node",nodes:[e],mounts:[]};return this._emitTopology({kind:"removed",name:e,nodeKind:"node",audit:o}),o}removeAll(e){let n=typeof e=="function"?e:(()=>{let s=rt(e);return i=>s.test(i)})(),r={kind:"mount",nodes:[],mounts:[]},o=[...this._nodes.keys(),...this._mounts.keys()].filter(s=>n(s));for(let s of o){let i=this.remove(s);r.nodes.push(...i.nodes),r.mounts.push(...i.mounts)}return r.nodes.sort(),r.mounts.sort(),r}[Symbol.iterator](){let e=[...this._nodes.keys()].sort(),n=this._nodes,r=0;return{[Symbol.iterator](){return this},next(){if(r>=e.length)return{value:void 0,done:!0};let o=e[r++];return{value:[o,n.get(o)],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 n=this._nodes.get(e);if(!n)throw new Error(`Graph "${this.name}": unknown node "${e}"`);return n}get(e){return this.node(e).cache}set(e,n,r){let o=r?.internal===!0;this.node(e).down([[I,n]],{actor:r?.actor,internal:o,delivery:"write"})}setAll(e,n){let r=Symbol.iterator in e?e:Object.entries(e);Ee(()=>{for(let[o,s]of r)this.set(o,s,n)})}invalidate(e,n){let r=n?.internal===!0;this.node(e).down([[ie]],{actor:n?.actor,internal:r,delivery:"write"})}error(e,n,r){let o=r?.internal===!0;this.node(e).down([[z,n]],{actor:r?.actor,internal:o,delivery:"write"})}complete(e,n){let r=n?.internal===!0;this.node(e).down([[Y]],{actor:n?.actor,internal:r,delivery:"write"})}edges(e){let n=e?.recursive===!0,r=new Map;if(!n){for(let[u,d]of this._nodes)r.set(d,u);let a=[];for(let[u,d]of this._nodes)if(d instanceof F)for(let l of d._deps){let h=r.get(l.node);h!=null&&a.push([h,u])}return a.sort((u,d)=>u[0]<d[0]?-1:u[0]>d[0]?1:u[1]<d[1]?-1:u[1]>d[1]?1:0),a}let o=[];this._collectObserveTargets("",o);let s=new Map;for(let[a,u]of o)s.set(u,a);let i=[];for(let[a,u]of o)if(u instanceof F)for(let d of u._deps){let l=s.get(d.node);l!=null&&i.push([l,a])}return i.sort((a,u)=>a[0]<u[0]?-1:a[0]>u[0]?1:a[1]<u[1]?-1:a[1]>u[1]?1:0),i}mount(e,n){if(n===void 0){let o=new t(e);return this.mount(e,o)}if(typeof n=="function"){let o=new t(e);return n(o),this.mount(e,o)}let r=n;if(Ot(e,this.name,"mount"),this._nodes.has(e))throw new Error(`Graph "${this.name}": cannot mount at "${e}" \u2014 node with that name exists`);if(this._mounts.has(e))throw new Error(`Graph "${this.name}": mount "${e}" already exists`);if(r===this)throw new Error(`Graph "${this.name}": cannot mount a graph into itself`);if(r._parent!=null)throw new Error(`Graph "${this.name}": this child graph is already mounted on "${r._parent.name}"`);for(let o=this;o!=null;o=o._parent)if(o===r)throw new Error(`Graph "${this.name}": mount("${e}", \u2026) would create a mount cycle`);return this._mounts.set(e,r),r._parent=this,this._emitTopology({kind:"added",name:e,nodeKind:"mount"}),r}resolve(e){let n=Jr(e,this.name);return this._resolveFromSegments(n)}tryResolve(e){try{return this.resolve(e)}catch{return}}_resolveFromSegments(e){let n=e;if(n[0]===this.name&&(n=n.slice(1),n.length===0))throw new Error(`Graph "${this.name}": resolve path ends at graph name only`);let r=n[0],o=n.slice(1);if(o.length===0){let a=this._nodes.get(r);if(a)return a;throw this._mounts.has(r)?new Error(`Graph "${this.name}": path ends at subgraph "${r}" \u2014 not a node (GRAPHREFLY-SPEC \xA73.5)`):new Error(`Graph "${this.name}": unknown name "${r}"`)}let s=this._nodes.get(r);if(s&&o.length>0&&o[0]===ae)return this._resolveMetaChainFromNode(s,o,n.join(P));let i=this._mounts.get(r);if(!i)throw this._nodes.has(r)?new Error(`Graph "${this.name}": "${r}" is a node; trailing path "${o.join(P)}" is invalid`):new Error(`Graph "${this.name}": unknown mount or node "${r}"`);return i.resolve(o.join(P))}_resolveMetaChainFromNode(e,n,r){let o=e,s=0,i=[...n];for(;s<i.length;){if(i[s]!==ae)throw new Error(`Graph "${this.name}": expected ${ae} segment in meta path "${r}"`);if(s+1>=i.length)throw new Error(`Graph "${this.name}": meta path requires a key after ${ae} in "${r}"`);let a=i[s+1],u=o.meta[a];if(!u)throw new Error(`Graph "${this.name}": unknown meta "${a}" in path "${r}"`);o=u,s+=2}return o}signal(e,n){if(n?.internal!==!0){for(let o of e)if(this.config.messageTier(o[0])===3)throw new Error(`Graph "${this.name}": Graph.signal() rejects tier-3 messages (DATA / RESOLVED). Broadcast is for control-plane tiers (START / DIRTY / INVALIDATE / PAUSE / RESUME / COMPLETE / ERROR / TEARDOWN). For per-node value writes, use Graph.set or graph.node(name).down(...).`)}let r=[];if(this._signalDeliver(e,n??{},new Set,r),r.length>0)throw r[0]}_signalDeliver(e,n,r,o){for(let u of this._mounts.values())u._signalDeliver(e,n,r,o);let i=n.internal===!0?{internal:!0}:{actor:n.actor,delivery:"signal"},a=Xr(e,this.config);for(let u of[...this._nodes.keys()].sort()){let d=this._nodes.get(u);if(!r.has(d)){r.add(d);try{d.down(e,i)}catch(l){if(l instanceof ne)throw l;o.push(l)}a.length!==0&&this._signalMetaSubtree(d,a,r,i,o)}}}_signalMetaSubtree(e,n,r,o,s){for(let i of Object.keys(e.meta).sort()){let a=e.meta[i];if(!r.has(a)){r.add(a);try{a.down(n,o)}catch(u){if(u instanceof ne)throw u;s.push(u)}this._signalMetaSubtree(a,n,r,o,s)}}}describe(e){if(e?.reactive==="diff")return this._describeReactiveDiff(e);if(e?.reactive===!0)return this._describeReactive(e);let n=Gr(e?.actor),r=e?.filter,o=Ye(e?.detail,e?.fields),s=e?.format==="spec",i=s?Ye("minimal"):o,a=[];this._collectObserveTargets("",a);let u=new Map;for(let[S,m]of a)u.set(m,S);let d=[];{let S=a.map(([,v])=>v),m=new Set(u.values()),b=0;for(;S.length>0;){let v=S.shift();if(v instanceof F)for(let R of v._deps){let T=R.node;if(u.has(T))continue;let k=T.name??"",_=k;if(!_||m.has(_))if(k){let O=2;for(;m.has(`${k}#${O}`);)O++;_=`${k}#${O}`}else for(_=`__internal__/${b++}`;m.has(_);)_=`__internal__/${b++}`;u.set(T,_),m.add(_),d.push([_,T]),S.push(T)}}}let l=[...a,...d],h={};for(let[S,m]of l){if(n!=null&&!m.allowsObserve(n))continue;let b=Rt(m,i),v=m instanceof F?m._deps.map(_=>u.get(_.node)??_.node.name??""):[],{name:R,...T}=b,k={...T,deps:v};if(!s){let _=this._annotations.get(S);_!=null&&(k.annotation=_)}if(r!=null)if(typeof r=="function"){let _=r;if(!(_.length>=2?_(S,k):_(k)))continue}else{let _=!0;for(let[O,D]of Object.entries(r)){let C=O==="deps_includes"?"depsIncludes":O==="meta_has"?"metaHas":O;if(C==="depsIncludes"){if(!k.deps.includes(String(D))){_=!1;break}continue}if(C==="metaHas"){if(!Object.hasOwn(k.meta??{},String(D))){_=!1;break}continue}if(k[C]!==D){_=!1;break}}if(!_)continue}h[S]=k}let p=new Set(Object.keys(h)),f=[];for(let[S,m]of l)if(m instanceof F)for(let b of m._deps){let v=u.get(b.node);v!=null&&f.push([v,S])}f.sort((S,m)=>S[0]<m[0]?-1:S[0]>m[0]?1:S[1]<m[1]?-1:S[1]>m[1]?1:0);let c=f.map(([S,m])=>({from:S,to:m}));(n!=null||r!=null)&&(c=c.filter(S=>p.has(S.from)&&p.has(S.to)));let y=this._collectSubgraphs(""),g=n!=null||r!=null?y.filter(S=>{let m=`${S}${P}`;return[...p].some(b=>b===S||b.startsWith(m))}):y,w=this,E=e,x={name:this.name,nodes:h,edges:c,subgraphs:g,...this._factory!==void 0?{factory:this._factory}:{},...this._factoryArgs!==void 0?{factoryArgs:this._factoryArgs}:{},expand(S){let m={...E,format:void 0};return Array.isArray(S)?(m.fields=S,m.detail=void 0):(m.detail=S,m.fields=void 0),w.describe(m)}},N=e??{},M=N.format;return M==="json"?zr(x,N):M==="pretty"?Fr(x,N):M==="mermaid"?En(x,N):M==="mermaid-url"?Kr(x,N):M==="d2"?jr(x,N):M==="ascii"?fn(x,N):x}_collectSubgraphs(e){let n=[];for(let r of[...this._mounts.keys()].sort()){let o=e===""?r:`${e}${r}`;n.push(o),n.push(...this._mounts.get(r)._collectSubgraphs(`${o}${P}`))}return n}resourceProfile(e){return bn(this,e)}reachable(e,n,r={}){return r.withDetail===!0?xn(this.describe(),e,n,{...r,withDetail:!0}):xn(this.describe(),e,n,r)}explain(e,n,r){return r?.reactive===!0?this._explainReactive(e,n,r):this._explainStatic(e,n,r)}_explainStatic(e,n,r){let o=this.describe({detail:"full"}),s=new Map(this._annotations),i=new Map;for(let[a,u]of Object.entries(o.nodes))u.lastMutation!=null&&i.set(a,u.lastMutation);return pn(o,e,n,{...r?.maxDepth!=null?{maxDepth:r.maxDepth}:{},...r?.findCycle===!0?{findCycle:!0}:{},annotations:s,lastMutations:i})}_describeReactive(e){let n={...e,reactive:!1},r=e.reactiveName??"describe",o=0,s=X(o,{name:`${r}_version`}),i=this.observe({timeline:!0,structured:!0}),a=!1,u=!1,d=()=>{a||u||(a=!0,ke(()=>{a=!1,!u&&(o+=1,s.emit(o))}))},l=i.onEvent(E=>{let x=E.type;x!=="data"&&x!=="error"&&x!=="complete"&&x!=="teardown"||d()}),h=[],p=new WeakSet,f=E=>{if(p.has(E)||u)return;p.add(E);let x=E.topology.subscribe(N=>{for(let M of N){if(M[0]!==I)continue;let S=M[1];if(d(),S.kind==="added"&&S.nodeKind==="mount"){let m=E._mounts.get(S.name);m!=null&&f(m)}}});h.push(x);for(let N of E._mounts.keys()){let M=E._mounts.get(N);M!=null&&f(M)}};f(this);let c,y=e.actor;Tn(y)&&(c=y.subscribe(E=>{let x=!1,N=!1;for(let M of E){let S=M[0];S===I?x=!0:(S===Y||S===z||S===q)&&(N=!0)}x&&d(),N&&(c?.(),c=void 0,d())}));let g;try{g=K([s],()=>this.describe(n),{name:r,describeKind:"derived",meta:{domain:"audit",kind:"describe"},equals:(E,x)=>E===x})}catch(E){l(),c?.();for(let x of h)x();throw i.dispose(),E}let w=re(g);return{node:g,dispose(){u=!0,l(),c?.();for(let E of h)E();h.length=0,i.dispose(),w()}}}_describeReactiveDiff(e){let n={...e,format:void 0,reactive:!1},r=e.reactiveName??"describe-diff",o={name:this.name,nodes:{},edges:[],subgraphs:[]},s=this.describe(n),i=Et(o,s),a=X(i,{name:r,meta:{domain:"audit",kind:"describe-diff"},equals:(p,f)=>p===f}),u=this._describeReactive({...e,format:void 0,reactiveName:void 0}),d=!1,l=u.node.subscribe(p=>{if(!d)for(let f of p){if(f[0]!==I)continue;let c=f[1],y=Et(s,c);s=c,y.events.length!==0&&a.emit(y)}}),h=re(a);return{node:a,dispose(){d=!0,l(),u.dispose(),a.down([[q,"describe-diff disposed"]]),h()}}}_explainReactive(e,n,r){let o=0,s=X(o,{name:"explain_version"}),i=this.observe({timeline:!0,structured:!0}),a=!1,u=!1,d=i.onEvent(f=>{let c=f.type;c!=="data"&&c!=="error"&&c!=="complete"&&c!=="teardown"||a||u||(a=!0,ke(()=>{a=!1,!u&&(o+=1,s.emit(o))}))}),l={...r?.maxDepth!=null?{maxDepth:r.maxDepth}:{},...r?.findCycle===!0?{findCycle:!0}:{}},h;try{h=K([s],()=>this._explainStatic(e,n,l),{name:r?.name??"explain",describeKind:"derived",meta:{domain:"audit",kind:"explain_path",from:e,to:n},equals:(f,c)=>f.found===c.found&&f.reason===c.reason&&f.steps.length===c.steps.length&&Qr(f.steps,c.steps)})}catch(f){throw d(),i.dispose(),f}let p=re(h);return{node:h,dispose(){u=!0,d(),i.dispose(),p()}}}_pathsMatching(e){let n=rt(e),r=[];return this._collectObserveTargets("",r),r.map(([o])=>o).filter(o=>n.test(o))}_collectObserveTargets(e,n){for(let r of[...this._mounts.keys()].sort()){let o=e===""?r:`${e}${P}${r}`;this._mounts.get(r)._collectObserveTargets(o,n)}for(let r of[...this._nodes.keys()].sort()){let o=this._nodes.get(r),s=e===""?r:`${e}${P}${r}`;n.push([s,o]),this._appendMetaObserveTargets(s,o,n)}}_appendMetaObserveTargets(e,n,r){for(let o of Object.keys(n.meta).sort()){let s=n.meta[o],i=`${e}${P}${ae}${P}${o}`;r.push([i,s]),this._appendMetaObserveTargets(i,s,r)}}observe(e,n){let r=typeof e=="string",s=wn(r?n:e);if(s.reactive===!0)return this._observeReactive(r?e:void 0,s);let i=s.structured===!0||s.timeline===!0||s.causal===!0||s.derived===!0||s.detail==="minimal"||s.detail==="full"||s.format!=null,a=s.actor;if(r){let l=e,h=this.resolve(l);if(a!=null&&!h.allowsObserve(a))throw new ne({actor:a,action:"observe",nodeName:l});return i?this._buildStructuredObserver([[l,h]],s,"one"):{subscribe(p){return h.subscribe(p)},up(p){try{h.up?.(p)}catch(f){if(f instanceof ne)return;throw f}}}}let u=[];this._collectObserveTargets("",u),u.sort((l,h)=>l[0]<h[0]?-1:l[0]>h[0]?1:0);let d=a==null?u:u.filter(([,l])=>l.allowsObserve(a));return i?this._buildStructuredObserver(d,s,"all"):{subscribe:l=>{let h=d.map(([p,f])=>f.subscribe(c=>{l(p,c)}));return()=>{for(let p of h)p()}},up:(l,h)=>{try{this.resolve(l).up?.(h)}catch(p){if(p instanceof ne)return;throw p}}}}_observeReactive(e,n){let r=n.tiers,o=r!=null?new Set(r):null,s=n.reactiveName??"observe";return Ve(i=>{let a=[],u=!1,d=!1,l=()=>{if(a.length===0||d)return;let y={events:a.slice(),flushedAt_ns:V()};a.length=0,i.emit(y)},h={...n,reactive:!1,structured:!0,timeline:!0},p=e!=null?this.observe(e,h):this.observe(h),f=y=>{d||(a.push(y),!u&&(u=!0,ke(()=>{u=!1,l()})))};for(let y of p.events)f(y);let c=p.onEvent(f);return()=>{d=!0,c(),p.dispose()}},{name:s,meta:{domain:"audit",kind:"observe-reactive"}})}_buildStructuredObserver(e,n,r){let o=r==="one"?e[0]?.[0]:void 0,s=i=>{if(r==="one"&&o!=null){let l=this.resolve(o);return this._buildStructuredObserver([[o,l]],i,"one")}let a=[];this._collectObserveTargets("",a),a.sort((l,h)=>l[0]<h[0]?-1:l[0]>h[0]?1:0);let u=i.actor,d=u==null?a:a.filter(([,l])=>l.allowsObserve(u));return this._buildStructuredObserver(d,i,"all")};return this._createObserveResult(e,n,s)}_createObserveResult(e,n,r){let o=n.timeline===!0,s=n.causal===!0,i=n.derived===!0,a=n.detail==="minimal",u=this.config.inspectorEnabled,d=(s||i)&&u,l=n.maxEvents,h=l!=null&&l>0?new ze(l):null,p=[],f=new Set,c=n.tiers!=null?new Set(n.tiers):null,y={},g=new Set,w=0,E=0,x=0,N=0,M=0,S=0,m=!1,b=!1,v=0,R=new Map,T=new Map,k=new Map,_=A=>{if(!(c!=null&&!c.has(A.type))){h?h.push(A):p.push(A);for(let $ of f)$(A)}},O=A=>c==null||c.has(A),D=()=>o?{timestamp_ns:V(),in_batch:je(),batch_id:v}:{},C=(A,$)=>{if(!(!d||!(A instanceof F)))return A._setInspectorHook(ee=>{if(ee.kind==="dep_message")R.set(A,ee.depIndex);else if(ee.kind==="run"){let Ge=ee.batchData.map((G,J)=>G!=null&&G.length>0?G.at(-1):ee.prevData[J]);T.set(A,Ge);let te=ee.batchData.map(G=>G!=null?[...G]:void 0);k.set(A,te),i&&_({type:"derived",path:$,dep_values:Ge,dep_batches:te,...D()})}})},L=A=>{let $=R.get(A),ee=T.get(A);if(!s||ee==null)return{};let te=($!=null&&$>=0&&A instanceof F?A._deps[$]:void 0)?.node,G=te?.v,J=k.get(A);return{trigger_dep_index:$,trigger_dep_name:te?.name,...G!=null?{trigger_version:{id:G.id,version:G.version}}:{},dep_values:[...ee],...J!=null?{dep_batches:J}:{}}},de=[],j=[];for(let[A,$]of e){let ee=C($,A);ee&&de.push(ee),j.push($.subscribe(Ge=>{v++;for(let te of Ge){let G=te[0],J=D();if(G===I){y[A]=te[1];let dt=$ instanceof F?$.lastMutation?.actor??xe:xe;_({type:"data",path:A,data:te[1],actor:dt,...J,...L($)})}else if(a)G===H?O("dirty")&&w++:G===Q?O("resolved")&&E++:G===ie?O("invalidate")&&x++:G===ce?O("pause")&&N++:G===fe?O("resume")&&M++:G===q?O("teardown")&&S++:G===Y&&!g.has(A)?O("complete")&&(m=!0):G===z&&O("error")&&(b=!0,g.add(A));else if(G===H)O("dirty")&&w++,_({type:"dirty",path:A,...J});else if(G===Q)O("resolved")&&E++,_({type:"resolved",path:A,...J,...L($)});else if(G===ie)O("invalidate")&&x++,_({type:"invalidate",path:A,...J});else if(G===ce)O("pause")&&N++,_({type:"pause",path:A,lockId:te[1],...J});else if(G===fe)O("resume")&&M++,_({type:"resume",path:A,lockId:te[1],...J});else if(G===Y)O("complete")&&!g.has(A)&&(m=!0),_({type:"complete",path:A,...J});else if(G===z){O("error")&&(b=!0,g.add(A));let dt=$ instanceof F?$.lastMutation?.actor??xe:xe;_({type:"error",path:A,data:te[1],actor:dt,...J})}else G===q&&(O("teardown")&&S++,_({type:"teardown",path:A,...J}))}}))}let se=!1,ge=()=>{if(!se){se=!0;for(let A of j)A();for(let A of de)A();for(let A of ue)A({value:void 0,done:!0});ue.length=0}},U=[],ue=[];f.add(A=>{let $=ue.shift();$?$({value:A,done:!1}):U.push(A)});let Ct={get values(){return y},get dirtyCount(){return w},get resolvedCount(){return E},get invalidateCount(){return x},get pauseCount(){return N},get resumeCount(){return M},get teardownCount(){return S},get events(){return h?h.toArray():[...p]},get anyCompletedCleanly(){return m},get anyErrored(){return b},get completedWithoutErrors(){return m&&!b},onEvent(A){return f.add(A),()=>f.delete(A)},dispose:ge,expand(A){ge();let $={...n};return typeof A=="string"?$.detail=A:Object.assign($,A),r(wn($))},[Symbol.asyncIterator](){return{next(){return U.length>0?Promise.resolve({value:U.shift(),done:!1}):se?Promise.resolve({value:void 0,done:!0}):new Promise(A=>ue.push(A))},return(){return ge(),Promise.resolve({value:void 0,done:!0})}}}};return n.format!=null&&this._attachFormatLogger(Ct,n),Ct}_attachFormatLogger(e,n){let r=n.format;if(r==null)return;let o=n.logger??(c=>console.log(c)),s=n.includeTypes?new Set(n.includeTypes):null,i=n.excludeTypes?new Set(n.excludeTypes):null,a=s==null&&i==null?()=>!0:c=>(s==null||s.has(c))&&(i==null||!i.has(c)),u=Ur(n.theme),d=r==="stage-log"?V():0,l=c=>c==null?"":n.stageLabels?.[c]??c,h=(c,y)=>c.length>y?`${c.slice(0,y-1)}\u2026`:c,p=c=>c.type==="data"||c.type==="error"?h(ot(c.data),120):"",f=c=>{if(r==="stage-log"){let m=(V()-d)/1e9,b=l(c.path).padEnd(9);if(c.type==="data"){let v=p(c);return`[${m.toFixed(3)}s] ${b} \u2190${v?` ${v}`:""}`}if(c.type==="error"){let v=p(c);return`[${m.toFixed(3)}s] ${b} \u2717${v?` ${v}`:""}`}return c.type==="complete"?`[${m.toFixed(3)}s] ${b} \u25A0 complete`:`[${m.toFixed(3)}s] ${b} ${c.type}`}if(r==="json")try{return JSON.stringify(c)}catch{return JSON.stringify({type:c.type,path:c.path,data:"[unserializable]"})}let y=u[c.type]??"",g=c.path?`${u.path}${c.path}${u.reset} `:"",w=c.type==="data"||c.type==="error",E=c.type==="pause"||c.type==="resume",x=w?` ${ot(c.data)}`:E?` ${ot(c.lockId)}`:"",N=c.type==="data"||c.type==="resolved"||c.type==="derived"?c:void 0,M=N?.trigger_dep_name!=null?` <- ${N.trigger_dep_name}`:N?.trigger_dep_index!=null?` <- #${N.trigger_dep_index}`:"",S=c.in_batch?" [batch]":"";return`${g}${y}${c.type.toUpperCase()}${u.reset}${x}${M}${S}`};e.onEvent(c=>{a(c.type)&&o(f(c),c)})}addDisposer(e){return this._disposers.add(e),()=>{this._disposers.delete(e)}}destroy(){vn(this._disposers,this.name),this.signal([[q]],{internal:!0}),vn(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:n,...r}=this.describe({detail:"full"}),o={};for(let a of Object.keys(r.nodes).sort()){let{lastMutation:u,guard:d,...l}=r.nodes[a];o[a]=l}let s=[...r.subgraphs].sort(),i={...r,version:1,nodes:o,subgraphs:s};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 Gt(a,a.encode(i))}throw new Error(`snapshot: unknown format "${String(e.format)}"`)}static decode(e,n){let r=n?.config??Se,{codec:o,codecVersion:s,payload:i}=Lt(e,r);return o.decode(i,s)}restore(e,n){if(_n(e),e.name!==this.name)throw new Error(`Graph "${this.name}": restore snapshot name "${e.name}" does not match this graph`);let r=n?.only==null?null:(Array.isArray(n.only)?n.only:[n.only]).map(s=>rt(s)),o=n?.includeProducers===!0;for(let s of Object.keys(e.nodes).sort()){if(r!==null&&!r.some(a=>a.test(s)))continue;let i=e.nodes[s];if(i!==void 0){if(!("value"in i)||i.value===void 0){"value"in i&&i.value===void 0&&n?.onError?.(s,new Error(`restore: slice.value is undefined for "${s}" (undefined is the global SENTINEL; not valid DATA)`));continue}if(!(i.type==="derived"||i.type==="effect")&&!(i.type==="producer"&&!o)){if(i.v!=null){let u=this.tryResolve(s)?.v;if(u!=null&&u.id===i.v.id&&u.version===i.v.version)continue}try{this.set(s,i.value)}catch(a){n?.onError?.(s,a)}}}}}static fromSnapshot(e,n){_n(e);let r=typeof n=="function"?n:n?.build,o=typeof n=="function"?void 0:n?.factories,s=new t(e.name);if(r)return r(s),s.restore(e),s;for(let f of[...e.subgraphs].sort((c,y)=>{let g=c.split(P).length,w=y.split(P).length;return g!==w?g-w:c<y?-1:c>y?1:0})){let c=f.split(P),y=s;for(let g of c)y._mounts.has(g)||y.mount(g,new t(g)),y=y._mounts.get(g)}let i=o?Object.entries(o).map(([f,c])=>({re:rt(f),factory:c})):[],a=f=>{for(let c of i)if(c.re.test(f))return c.factory},u=f=>{let c=f.split(P),y=c.pop();if(y==null||y.length===0)throw new Error(`invalid snapshot path "${f}"`);let g=s;for(let w of c){let E=g._mounts.get(w);if(!E)throw new Error(`unknown mount "${w}" in path "${f}"`);g=E}return[g,y]},d=Object.entries(e.nodes).filter(([f])=>!f.includes(`${P}${ae}${P}`)).sort((f,c)=>f[0]<c[0]?-1:f[0]>c[0]?1:0),l=new Map(d),h=new Map,p=!0;for(;l.size>0&&p;){p=!1;for(let[f,c]of[...l.entries()]){let y=c?.deps??[];if(!y.every(M=>h.has(M)))continue;let[g,w]=u(f),E={...c?.meta??{}},x=a(f),N;if(c?.type==="state")N=X(c.value,{meta:E});else{if(x==null)continue;N=x(w,{path:f,type:c.type,value:c.value,meta:E,deps:y,resolvedDeps:y.map(M=>h.get(M))})}g.add(N,{name:w}),h.set(f,N),l.delete(f),p=!0}}if(l.size>0){let f=[...l.keys()].sort().join(", ");throw new Error(`Graph.fromSnapshot could not reconstruct nodes without build callback: ${f}. Pass matching factories via fromSnapshot(data, { factories: { pattern: factoryFn } }).`)}return s.restore(e),s}toJSON(){return this.snapshot()}attachSnapshotStorage(e,n={}){let r=e.map(d=>({tier:d,debounceMs:Math.max(0,d.debounceMs??0),compactEvery:Math.max(1,d.compactEvery??10),timer:void 0,seq:0,lastSnapshot:void 0,lastFingerprint:"",disposed:!1,savePending:void 0}));n.autoRestore===!0&&this._cascadeRestore(e,n.onError);let o=(d,l)=>{if(d.disposed)return;let h=Lr(l.nodes);if(d.lastSnapshot!=null&&h!==""&&h===d.lastFingerprint)return;let p=d.seq+1,f=le(),g=d.lastSnapshot==null||p%d.compactEvery===0?{name:this.name,mode:"full",snapshot:l,seq:p,timestamp_ns:f,format_version:Ce}:{name:this.name,mode:"diff",diff:Zr(d.lastSnapshot,l),seq:p,timestamp_ns:f,format_version:Ce};if(d.tier.filter&&!d.tier.filter(g))return;let w;try{w=d.tier.save(g)}catch(E){n.onError?.(E,d.tier);return}if(w&&typeof w.then=="function"){let N=(d.savePending??Promise.resolve()).then(()=>w,()=>w).then(()=>{d.disposed||(d.seq=p,d.lastSnapshot=l,d.lastFingerprint=h)},M=>{n.onError?.(M,d.tier)});d.savePending=N.finally(()=>{d.savePending===N&&(d.savePending=void 0)})}else d.seq=p,d.lastSnapshot=l,d.lastFingerprint=h},s=(d,l)=>{try{o(d,l)}catch(h){n.onError?.(h,d.tier)}},i=(d,l)=>{if(!l.some(c=>{let y=this.config.messageTier(c[0]);return y>=3&&y<5}))return;if(n.filter){let c=this.tryResolve(d);if(c==null)return;let y=Rt(c,Ye("standard"));if(!n.filter(d,y))return}let p,f=()=>(p==null&&(p=this.snapshot()),p);for(let c of r)c.disposed||(c.debounceMs===0?s(c,f()):(c.timer==null&&(c.timer=new Je),c.timer.start(c.debounceMs,()=>{c.disposed||s(c,this.snapshot())})))},a;if(n.paths!=null){let l=(typeof n.paths=="string"?this._pathsMatching(n.paths):n.paths).map(h=>{let p=this.tryResolve(h);return p==null?()=>{}:p.subscribe(f=>i(h,f))});a=()=>{for(let h of l)h()}}else a=this.observe().subscribe((d,l)=>i(d,l));let u=()=>{a();for(let d of r)d.disposed=!0,d.timer?.cancel();this._storageDisposers.delete(u)};return this._storageDisposers.add(u),{dispose:u}}async _cascadeRestore(e,n){for(let r of e){let o;try{o=await r.load?.()}catch(i){n?.(i,r);continue}if(o==null||typeof o!="object"||Array.isArray(o))continue;let s=o;try{if(s.mode==="full"&&s.snapshot!=null)return this.restore(s.snapshot),!0;if(s.version===Ce&&s.nodes!=null)return this.restore(s),!0}catch(i){n?.(i,r)}}return!1}static async fromStorage(e,n,r){for(let o of n){let s;try{s=await o.load?.()}catch(u){r?.onError?.(u,o);continue}if(s==null||typeof s!="object"||Array.isArray(s))continue;let i=s,a=i.mode==="full"&&i.snapshot!=null?i.snapshot:i.version===Ce&&i.nodes!=null?i:void 0;if(a!=null)try{return t.fromSnapshot(a,r)}catch(u){r?.onError?.(u,o)}}throw new Error(`Graph.fromStorage: no tier held a restorable record for "${e}" across ${n.length} tier(s)`)}_annotations=new Map;_traceRing;trace(e,n,r){if(e!=null&&n!=null){if(this.tryResolve(e)==null)return;if(this._annotations.set(e,n),this.config.inspectorEnabled){let o={path:e,annotation:n,timestamp_ns:V(),...r?.actor!=null?{actor:r.actor}:{}};this._traceRing.push(o)}return}return e!=null?this.config.inspectorEnabled?this._annotations.get(e):void 0:this.config.inspectorEnabled?this._traceRing.toArray():[]}annotation(e){return this._annotations.get(e)}clearTrace(){this._annotations.clear(),this._traceRing.clear()}pruneTrace(e){let n=this._traceRing.toArray().filter(o=>!e(o)),r=this._traceRing.size-n.length;this._traceRing.clear();for(let o of n)this._traceRing.push(o);return r}static diff(e,n){let r=new Set(Object.keys(e.nodes)),o=new Set(Object.keys(n.nodes)),s=[...o].filter(E=>!r.has(E)).sort(),i=[...r].filter(E=>!o.has(E)).sort(),a=[],u=[];for(let E of r){if(!o.has(E))continue;let x=e.nodes[E],N=n.nodes[E],M=x.v,S=N.v;M!=null&&S!=null&&M.id===S.id&&M.version!==S.version&&u.push({path:E,id:M.id,from:M.version,to:S.version});let m=M!=null&&S!=null&&M.id===S.id&&M.version===S.version;for(let b of["type","status","sentinel"]){let v=x[b],R=N[b];v!==R&&a.push({path:E,field:b,from:v,to:R})}if(!m)for(let b of["value","meta"]){let v=x[b],R=N[b];Ir(v,R)||a.push({path:E,field:b,from:v,to:R})}}let d=E=>`${E.from} ${E.to}`,l=new Set(e.edges.map(d)),h=new Set(n.edges.map(d)),p=n.edges.filter(E=>!l.has(d(E))),f=e.edges.filter(E=>!h.has(d(E))),c=new Set(e.subgraphs),y=new Set(n.subgraphs),g=[...y].filter(E=>!c.has(E)).sort(),w=[...c].filter(E=>!y.has(E)).sort();return{nodesAdded:s,nodesRemoved:i,nodesChanged:a,versionChanges:u,edgesAdded:p,edgesRemoved:f,subgraphsAdded:g,subgraphsRemoved:w}}};function Zr(t,e){let n=we.diff(t,e),r={};for(let o of n.nodesAdded){let s=e.nodes[o];s!=null&&(r[o]=s)}return{...n,nodesAddedFull:r}}function xn(t,e,n,r={}){let o={paths:[],depths:new Map,truncated:!1};if(!e)return r.withDetail?o:[];if(!r.both&&n!=="upstream"&&n!=="downstream")throw new Error('reachable: direction must be "upstream" or "downstream"');let s=r.maxDepth;if(s!=null&&(!Number.isInteger(s)||s<0))throw new Error("reachable: maxDepth must be an integer >= 0");if(s===0)return r.withDetail?o:[];let i=new Map,a=new Map,u=new Map,d=new Map,l=new Set;for(let[x,N]of Object.entries(t.nodes)){if(!x)continue;l.add(x);let M=N.deps??[];i.set(x,M);for(let S of M)S&&(l.add(S),a.has(S)||a.set(S,new Set),a.get(S).add(x))}for(let x of t.edges){if(x==null||typeof x!="object")continue;let N=typeof x.from=="string"?x.from:"",M=typeof x.to=="string"?x.to:"";!N||!M||(l.add(N),l.add(M),d.has(N)||d.set(N,new Set),d.get(N).add(M),u.has(M)||u.set(M,new Set),u.get(M).add(N))}if(!l.has(e))return r.withDetail?o:[];let h=r.both===!0,p=x=>{if(h){let m=i.get(x)??[],b=u.get(x),v=a.get(x),R=d.get(x),T=[...m];return b&&T.push(...b),v&&T.push(...v),R&&T.push(...R),T}if(n==="upstream"){let m=i.get(x)??[],b=u.get(x);return b?[...m,...b]:m}let N=a.get(x),M=d.get(x),S=N?[...N]:[];return M&&S.push(...M),S},f=new Set([e]),c=new Map,y=[{path:e,depth:0}],g=0,w=!1;for(;g<y.length;){let x=y[g++];if(s!=null&&x.depth>=s){p(x.path).length>0&&(w=!0);continue}for(let N of p(x.path))!N||f.has(N)||(f.add(N),c.set(N,x.depth+1),y.push({path:N,depth:x.depth+1}))}let E=[...c.keys()].sort((x,N)=>x<N?-1:x>N?1:0);return r.withDetail?{paths:E,depths:c,truncated:w}:E}function Qr(t,e){if(t.length!==e.length)return!1;for(let n=0;n<t.length;n++){let r=t[n],o=e[n];if(r.path!==o.path||r.type!==o.type||r.status!==o.status||r.hop!==o.hop||r.dep_index!==o.dep_index||r.annotation!==o.annotation||r.value!==o.value||r.lastMutation!==o.lastMutation)return!1;let s=r.v,i=o.v;if(s!==i&&(s==null||i==null||s.id!==i.id||s.version!==i.version))return!1}return!0}me();Pe();pe();_e();$e();pe();ve();_e();var Mt=class{_version=0;_maxSize;_buf;_head=0;_size=0;constructor(e,n){if(n!==void 0&&n<1)throw new RangeError("maxSize must be >= 1");if(this._maxSize=n,n!==void 0){if(this._buf=new Array(n),e&&e.length>0){let r=Math.min(e.length,n),o=e.length-r;for(let s=0;s<r;s++)this._buf[s]=e[o+s];this._size=r}}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 n=e>=0?e:this._size+e;if(!(n<0||n>=this._size))return this._maxSize!==void 0?this._buf[(this._head+n)%this._maxSize]:this._buf[n]}append(e){this._rawAppend(e),this._version+=1}appendMany(e){if(e.length===0)return;let n=this._maxSize!==void 0&&e.length>this._maxSize?e.length-this._maxSize:0;for(let r=n;r<e.length;r++)this._rawAppend(e[r]);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 n=0;n<e;n++)this._buf[(this._head+n)%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 n=Math.min(e,this._size);if(this._maxSize===void 0)this._buf.splice(0,n);else{for(let r=0;r<n;r++)this._buf[(this._head+r)%this._maxSize]=void 0;this._head=(this._head+n)%this._maxSize}return this._size-=n,this._version+=1,n}slice(e,n){if(!Number.isInteger(e)||e<0)throw new RangeError(`slice: start must be a non-negative integer (got ${e})`);if(n!==void 0&&(!Number.isInteger(n)||n<0))throw new RangeError(`slice: stop must be a non-negative integer or undefined (got ${n})`);let r=n===void 0?this._size:Math.min(Math.max(n,0),this._size),o=Math.min(e,this._size);if(o>=r)return[];let s=r-o;if(this._maxSize===void 0)return this._buf.slice(o,r);let i=new Array(s);for(let a=0;a<s;a++)i[a]=this._buf[(this._head+o+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 n=Math.min(e,this._size);return this.slice(this._size-n,this._size)}toArray(){if(this._maxSize===void 0)return[...this._buf];let e=new Array(this._size);for(let n=0;n<this._size;n++)e[n]=this._buf[(this._head+n)%this._maxSize];return e}snapshot(){return this.toArray()}restore(e){if(this._maxSize===void 0){this._buf.length=0;for(let n=0;n<e.length;n++)this._buf.push(e[n]);this._size=this._buf.length}else{let n=this._maxSize;for(let s=0;s<n;s++)this._buf[s]=void 0;this._head=0;let r=Math.min(e.length,n),o=e.length-r;for(let s=0;s<r;s++)this._buf[s]=e[o+s];this._size=r}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 Fe(t){return t.subscribe(()=>{})}var eo=64;function On(t,e={}){let{name:n,maxSize:r,versioning:o,guard:s,backend:i}=e,a=i??new Mt(t,r),u=X(a.toArray(),{name:n,describeKind:"state",equals:(m,b)=>m===b,...o!=null?{versioning:o}:{},...s!=null?{guard:s}:{}});function d(){let m=a.toArray();Ee(()=>{u.down([[H]],{internal:!0}),u.down([[I,m]],{internal:!0})})}let l=new Map,h=new Map,p=new Map;function f(m,b){return`${m}:${b===void 0?"END":b}`}function c(m){if(m.size<eo)return;let b=m.keys().next();if(b.done)return;let v=m.get(b.value);v!==void 0&&v.dispose(),m.delete(b.value)}function y(m){let b=a.version;try{return m()}finally{a.version!==b&&d()}}function g(m){if(!Number.isInteger(m)||m<0)throw new RangeError(`tail: n must be a non-negative integer (got ${m})`);let b=l.get(m);if(b!==void 0)return l.delete(m),l.set(m,b),b.node;c(l);let v=K([u],([T])=>{let k=T;return m===0||k.length===0?[]:k.slice(Math.max(0,k.length-m))},{initial:a.tail(m),describeKind:"derived"}),R=Fe(v);return l.set(m,{node:v,dispose:R}),v}function w(m,b){if(!Number.isInteger(m)||m<0)throw new RangeError(`slice: start must be a non-negative integer (got ${m})`);if(b!==void 0&&(!Number.isInteger(b)||b<0))throw new RangeError(`slice: stop must be a non-negative integer or undefined (got ${b})`);let v=f(m,b),R=h.get(v);if(R!==void 0)return h.delete(v),h.set(v,R),R.node;c(h);let T=K([u],([_])=>{let O=_;return b===void 0?O.slice(m):O.slice(m,b)},{initial:a.slice(m,b),describeKind:"derived"}),k=Fe(T);return h.set(v,{node:T,dispose:k}),T}function E(m){let b=p.get(m);if(b!==void 0)return b.node;let v=K([u,m],([T,k])=>{let _=T,O=Math.max(0,Math.trunc(k??0));return _.slice(O)},{initial:[],describeKind:"derived"}),R=Fe(v);return p.set(m,{node:v,dispose:R}),v}let x,N;function M(){x===void 0&&(x=Me([u],(m,b,v)=>{let R=m[0],k=R!=null&&R.length>0?R.at(-1):v.prevData[0];if(k==null||k.length===0){b.down([[Q]]);return}b.emit(k[k.length-1])},{name:n!=null?`${n}::lastValue`:"lastValue",describeKind:"derived",initial:a.size===0?void 0:a.at(a.size-1)}),N=K([u],([m])=>m.length>0,{name:n!=null?`${n}::hasLatest`:"hasLatest",describeKind:"derived",initial:a.size>0}),Fe(x),Fe(N))}let S={entries:u,get size(){return a.size},at(m){return a.at(m)},append(m){y(()=>a.append(m))},appendMany(m){m.length!==0&&y(()=>a.appendMany(m))},clear(){y(()=>a.clear())},trimHead(m){y(()=>a.trimHead(m))},withLatest(){return M(),u},get lastValue(){return M(),x},get hasLatest(){return M(),N},view(m){switch(m.kind){case"tail":return g(m.n);case"slice":return w(m.start,m.stop);case"fromCursor":return E(m.cursor)}},attach(m){let b=m.subscribe(v=>{for(let R of v)R[0]===I&&S.append(R[1])});return()=>b()},attachStorage(m){if(m.length===0)return()=>{};let b=new Map;for(let R of m)b.set(R,a.size);(async()=>{for(let R of m)if(typeof R.loadEntries=="function")try{let T=await Promise.resolve(R.loadEntries());T.entries.length>0&&a.size===0&&(a.restore(T.entries),b.set(R,T.entries.length),d());break}catch{}})();let v=u.subscribe(R=>{for(let T of R){if(T[0]!==I)continue;let k=T[1];for(let _ of m){let O=b.get(_)??0;if(k.length<O){try{let C=_.appendEntries(k);C instanceof Promise&&C.catch(()=>{})}catch{}b.set(_,k.length);continue}if(k.length===O)continue;let D=k.slice(O);b.set(_,k.length);try{let C=_.appendEntries(D);C instanceof Promise&&C.catch(()=>{})}catch{}}}});return()=>v()},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 p.values())m.dispose();p.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 p.values())m.dispose();p.clear()}};return S}var to=jt((t,e)=>{t("observe"),t("signal"),e("write")});function Ke(t){let e=On([],{name:t.name,maxSize:t.retainedLimit??1024,guard:t.guard??to,...t.versioning!=null?{versioning:t.versioning}:{}});return e.withLatest(),t.graph&&t.graph.add(e.entries,{name:t.name}),e}function Mn(t){if(t===null||typeof t!="object"||Object.isFrozen(t))return t;for(let e of Object.keys(t))Mn(t[e]);return Object.freeze(t)}function st(t){let e=t.cache,r=(typeof e=="number"&&Number.isFinite(e)?e:0)+1;return t.down([[H],[I,r]]),r}function Sn(t,e,n,r,o,s){let i=e(n,r,o);if(i===void 0)return;let a=s!=null?{...i,handlerVersion:s}:i;t.append(a)}function W(t,e){let n=e.freeze??!0;return function(...o){let s=n?o.map(Mn):o,i=le(),a=e.seq?st(e.seq):void 0;try{let u=t(...s);return e.onSuccess&&Sn(e.audit,e.onSuccess,s,u,{t_ns:i,seq:a},e.handlerVersion),u}catch(u){if(e.onFailure){let d=u instanceof Error?u.name:typeof u;Sn(e.audit,e.onFailure,s,u,{t_ns:i,seq:a,errorType:d},e.handlerVersion)}throw u}}}function it(t,e,n=0){let r=X(n,{name:e,describeKind:"state"});return t.add(r,{name:e}),r}Ue();function An(t,e,n){return{[t]:!0,[`${t}_type`]:e,...n??{}}}var no=1e9;function oe(t,e){return An("memory",t,e)}function De(t,e){return t instanceof F?t:X(t,e?{name:e}:void 0)}function Cn(t,e){return(t-e)/no}function At(t,e,n,r=0){if(!Number.isFinite(t))return r;if(!Number.isFinite(e)||e<=0||!Number.isFinite(n)||n<=0)return Math.max(r,t);let o=t*Math.exp(-n*e);return Math.max(r,o)}function In(t,e){let n=Math.max(t.length,e.length),r=0,o=0,s=0;for(let a=0;a<n;a+=1){let u=t[a]??0,d=e[a]??0;r+=u*d,o+=u*u,s+=d*d}if(o===0||s===0)return 0;let i=r/Math.sqrt(o*s);return Number.isFinite(i)?i:0}function ro(t,e){if(t===e)return!0;if(t==null||e==null||t.length!==e.length)return!1;for(let n=0;n<t.length;n+=1){let r=t[n],o=e[n];if(r.id!==o.id||r.score!==o.score||r.meta!==o.meta)return!1}return!0}function oo(t={}){let e=t.maxSize;if(e!==void 0&&e<1)throw new RangeError("lightCollection: maxSize must be >= 1");let n=Ae({name:t.name,...e!==void 0?{maxSize:e}:{}}),r=n.entries,o=Ke({name:t.name?`${t.name}_events`:"events",retainedLimit:1024}),s=(f,c)=>{let y=V(),g=r.cache?.get(f);n.set(f,{id:f,value:c,createdAtNs:g?.createdAtNs??y,lastAccessNs:y})},i=f=>{n.has(f)&&n.delete(f)},a=()=>{n.size!==0&&n.clear()},u=W(s,{audit:o,onSuccess:([f],c,y)=>({action:"upsert",id:f,t_ns:y.t_ns}),onFailure:(f,c,y)=>({action:"upsert",t_ns:y.t_ns,handlerVersion:{id:"lightCollection.upsert",version:1}})}),d=W(i,{audit:o,onSuccess:([f],c,y)=>({action:"remove",id:f,t_ns:y.t_ns})}),l=W(a,{audit:o,onSuccess:(f,c,y)=>({action:"clear",t_ns:y.t_ns})});function h(f){let c=De(f,"id");return K([r,c],([y,g])=>y?.get(g),{describeKind:"derived",meta:oe("light_collection_item")})}function p(f){let c=De(f,"id");return K([r,c],([y,g])=>y?.has(g)??!1,{describeKind:"derived",meta:oe("light_collection_has")})}return{entries:r,events:o,upsert:u,remove:d,clear:l,itemNode:h,hasNode:p}}function so(t,e){if(t===e)return!0;if(t==null||e==null||t.length!==e.length)return!1;for(let n=0;n<t.length;n+=1){let r=t[n],o=e[n];if(r.id!==o.id||r.score!==o.score||r.lastAccessNs!==o.lastAccessNs||r.value!==o.value)return!1}return!0}function io(t,e={}){let n=e.maxSize,r=e.decayRate??0,o=e.minScore??0;if(n!==void 0&&n<1)throw new RangeError("collection: maxSize must be >= 1");let s=()=>1,i=e.score??s,a=i instanceof F?i:void 0,u=()=>a?a.cache??s:i,d=new we(t),h=Ae({name:"items",...n!==void 0?{retention:{score:(k,_)=>At(_.baseScore,Cn(V(),_.lastAccessNs),r,o),maxSize:n}}:{}});d.add(h.entries,{name:"items"});let p;if(r>0){let k=e.refreshIntervalMs??Math.max(1,1e3*Math.LN2/(10*r)),_=Xt(k,{period:k});p=K([_],()=>V(),{name:"refresh_tick_ns",describeKind:"derived",initial:V(),meta:oe("clock")}),d.add(p,{name:"refresh_tick_ns"})}let f=[h.entries];p&&f.push(p),a&&f.push(a);let c=K(f,k=>{let _=k[0],O;if(p){let C=k[1];O=typeof C=="number"?C:V()}else O=V();if(!_||_.size===0)return[];let D=[];for(let C of _.values())D.push({...C,score:At(C.baseScore,Cn(O,C.lastAccessNs),r,o)});return D.sort((C,L)=>L.score-C.score||L.lastAccessNs-C.lastAccessNs),D},{name:"ranked",describeKind:"derived",equals:so,meta:oe("ranked")});d.add(c,{name:"ranked"});let y=K([h.entries],([k])=>(k??new Map).size,{name:"size",describeKind:"derived",initial:0,meta:oe("size")});d.add(y,{name:"size"}),d.addDisposer(re(y));let g=Ke({name:"events",retainedLimit:1024,graph:d}),w=it(d,"seq",0),E=(k,_,O)=>{let D=V(),C=h.get(k),L=O?.score??u()(_);h.set(k,{id:k,value:_,baseScore:L,createdAtNs:C?.createdAtNs??D,lastAccessNs:D})},x=k=>{h.has(k)&&h.delete(k)},N=()=>{h.size!==0&&h.clear()},M=()=>{let k=u(),_=h.entries.cache;if(!_||_.size===0)return;let O=[];for(let D of _.values())O.push([D.id,{...D,baseScore:k(D.value)}]);h.setMany(O)},S=W(E,{audit:g,seq:w,onSuccess:([k],_,O)=>({action:"upsert",id:k,t_ns:O.t_ns,seq:O.seq})}),m=W(x,{audit:g,seq:w,onSuccess:([k],_,O)=>({action:"remove",id:k,t_ns:O.t_ns,seq:O.seq})}),b=W(N,{audit:g,seq:w,onSuccess:(k,_,O)=>({action:"clear",t_ns:O.t_ns,seq:O.seq})}),v=W(M,{audit:g,seq:w,onSuccess:(k,_,O)=>({action:"rescore",t_ns:O.t_ns,seq:O.seq})});function R(k){let _=De(k,"id");return K([h.entries,_],([O,D])=>O?.get(D),{describeKind:"derived",meta:oe("collection_item")})}return Object.assign(d,{events:g,items:h.entries,ranked:c,size:y,upsert:S,remove:m,clear:b,rescore:v,itemNode:R})}function ao(t={}){let e=t.backend??"flat",n=t.dimension,r=t.strictDimension??!0,o=t.maxSize,s=t.retentionScore,i;if(e==="hnsw"&&(i=t.hnswFactory?.(),!i))throw new Error('vectorIndex backend "hnsw" requires an optional dependency adapter; install your HNSW package and provide `hnswFactory`.');let a=new we(t.name??"vector_index"),u;function d(v){if(n!==void 0){if(v.length!==n)throw new RangeError(`vector dimension mismatch: expected ${n}, got ${v.length}`);return}if(r){if(u===void 0){u=v.length;return}if(v.length!==u)throw new RangeError(`vector dimension mismatch: inferred ${u} from first upsert, got ${v.length}. Pass \`strictDimension: false\` to opt into zero-pad behavior, or set an explicit \`dimension\`.`)}}let l=s??(v=>v.upsertedAtNs),h=!1,p=Ke({name:"events",retainedLimit:1024,graph:a}),f=it(a,"seq",0),c=Ae({name:"entries",...o!==void 0?{retention:{score:(v,R)=>l(R),maxSize:o,onArchive:v=>{h||(e==="hnsw"&&i.remove(v),p.append({action:"evict",id:v,t_ns:le(),seq:st(f)}))}}}:{}});if(a.add(c.entries,{name:"entries"}),a.addDisposer(re(c.entries)),i?.dispose){let v=i.dispose.bind(i);a.addDisposer(()=>v())}let y=(v,R,T)=>{d(R),e==="hnsw"&&i.upsert(v,R,T);let k=(()=>{if(T!==void 0)return T===null||typeof T!="object"?T:Array.isArray(T)?[...T]:{...T}})(),_={id:v,vector:[...R],...k!==void 0?{meta:k}:{},upsertedAtNs:V()};c.set(v,_)},g=v=>{c.has(v)&&(e==="hnsw"&&i.remove(v),c.delete(v))},w=()=>{if(c.size!==0){h=!0;try{c.clear(),e==="hnsw"&&i.clear()}finally{h=!1}u=void 0}},E=()=>{if(e!=="hnsw")return;let v=c.entries.cache;if(v){i.clear();for(let R of v.values())i.upsert(R.id,R.vector,R.meta)}},x=W(y,{audit:p,freeze:!1,seq:f,onSuccess:([v],R,T)=>({action:"upsert",id:v,t_ns:T.t_ns,seq:T.seq})}),N=W(g,{audit:p,seq:f,onSuccess:([v],R,T)=>({action:"remove",id:v,t_ns:T.t_ns,seq:T.seq})}),M=W(w,{audit:p,seq:f,onSuccess:(v,R,T)=>({action:"clear",t_ns:T.t_ns,seq:T.seq})}),S=W(E,{audit:p,seq:f,onSuccess:(v,R,T)=>({action:"reindex",t_ns:T.t_ns,seq:T.seq})});function m(v,R=5){let T=De(R,"k");return K([c.entries,v,T],k=>{let _=k[0],O=k[1],D=k[2],C=Number.isFinite(D)?Math.max(0,Math.floor(D)):0;if(!_||_.size===0||C<=0)return[];if(O==null||O.length===0)return[];let L=n??(r?u:void 0);return L!==void 0&&O.length!==L?[]:e==="hnsw"?[...i.search(O,C)]:[..._.values()].map(j=>({id:j.id,score:In(O,j.vector),...j.meta!==void 0?{meta:j.meta}:{}})).sort((j,se)=>se.score-j.score).slice(0,C)},{describeKind:"derived",equals:(k,_)=>ro(k,_),meta:oe("vector_search")})}return Object.assign(a,{backend:e,events:p,entries:c.entries,upsert:x,remove:N,clear:M,reindex:S,searchNode:m})}var Dn="\0";function at(t,e,n){return`${t}${Dn}${e}${Dn}${n}`}function Gn(t,e){if(!t||t.size===0)return new Map;let n=new Map;for(let o of t.values()){let s=e==="from"?o.from:o.to,i=n.get(s);i||(i=[],n.set(s,i)),i.push(o)}let r=new Map;for(let[o,s]of n)r.set(o,Object.freeze(s));return r}function Ln(t,e){if(t===e)return!0;if(t==null||e==null||t.size!==e.size)return!1;for(let[n,r]of t){let o=e.get(n);if(!o||r.length!==o.length)return!1;for(let s=0;s<r.length;s+=1){let i=r[s],a=o[s];if(i.from!==a.from||i.to!==a.to||i.relation!==a.relation||i.weight!==a.weight)return!1}}return!0}function uo(t,e={}){let n=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 r=new we(t),o=Ae({name:"entities",...e.entitiesMaxSize!==void 0?{maxSize:e.entitiesMaxSize}:{}}),s=Ae({name:"edges",...e.edgesMaxSize!==void 0?{maxSize:e.edgesMaxSize}:{}});r.add(o.entries,{name:"entities"}),r.add(s.entries,{name:"edges"});let i=K([s.entries],([b])=>Gn(b,"from"),{name:"adjacencyOut",describeKind:"derived",initial:new Map,equals:Ln,meta:oe("adjacency_out")}),a=K([s.entries],([b])=>Gn(b,"to"),{name:"adjacencyIn",describeKind:"derived",initial:new Map,equals:Ln,meta:oe("adjacency_in")});r.add(i,{name:"adjacencyOut"}),r.add(a,{name:"adjacencyIn"}),r.addDisposer(re(i)),r.addDisposer(re(a));let u=K([o.entries],([b])=>(b??new Map).size,{name:"entityCount",describeKind:"derived",initial:0,meta:oe("entity_count")}),d=K([s.entries],([b])=>(b??new Map).size,{name:"edgeCount",describeKind:"derived",initial:0,meta:oe("edge_count")});r.add(u,{name:"entityCount"}),r.add(d,{name:"edgeCount"}),r.addDisposer(re(u)),r.addDisposer(re(d));let l=Ke({name:"events",retainedLimit:1024,graph:r}),h=it(r,"seq",0);function p(b){let v=i.cache,R=a.cache;return(v?.get(b)?.length??0)>0||(R?.get(b)?.length??0)>0}function f(b){if(n==="remove")for(let v of b)o.has(v)&&(p(v)||(o.delete(v),l.append({action:"orphanRemove",id:v,t_ns:le(),seq:st(h)})))}let c=(b,v)=>{o.set(b,v)},y=b=>{let v=s.entries.cache,R=new Set;if(v){let T=[];for(let[k,_]of v)(_.from===b||_.to===b)&&(T.push(k),_.from!==b&&R.add(_.from),_.to!==b&&R.add(_.to));T.length>0&&s.deleteMany(T)}o.has(b)&&o.delete(b),f([...R])},g=(b,v,R,T=1)=>{s.set(at(b,v,R),{from:b,to:v,relation:R,weight:T})},w=(b,v,R)=>{if(R!==void 0)s.delete(at(b,v,R));else{let T=s.entries.cache;if(!T)return;let k=[];for(let[_,O]of T)O.from===b&&O.to===v&&k.push(_);k.length>0&&s.deleteMany(k)}f([b,v])},E=W(c,{audit:l,seq:h,onSuccess:([b],v,R)=>({action:"upsertEntity",id:b,t_ns:R.t_ns,seq:R.seq})}),x=W(y,{audit:l,seq:h,onSuccess:([b],v,R)=>({action:"removeEntity",id:b,t_ns:R.t_ns,seq:R.seq})}),N=W(g,{audit:l,seq:h,onSuccess:([b,v,R,T],k,_)=>({action:"link",from:b,to:v,relation:R,weight:T??1,t_ns:_.t_ns,seq:_.seq})}),M=W(w,{audit:l,seq:h,onSuccess:([b,v,R],T,k)=>({action:"unlink",from:b,to:v,...R!==void 0?{relation:R}:{},t_ns:k.t_ns,seq:k.seq})});function S(b,v){let R=De(b,"id"),T=v!==void 0?De(v,"relation"):void 0;return K(T?[i,a,R,T]:[i,a,R],_=>{let O=_[0],D=_[1],C=_[2],L=T?_[3]:void 0,de=O.get(C)??[],j=D.get(C)??[],se=new Set,ge=[];for(let U of de){let ue=at(U.from,U.to,U.relation);se.has(ue)||L!==void 0&&U.relation!==L||(se.add(ue),ge.push(U))}for(let U of j){let ue=at(U.from,U.to,U.relation);se.has(ue)||L!==void 0&&U.relation!==L||(se.add(ue),ge.push(U))}return ge},{describeKind:"derived",equals:(_,O)=>{let D=_,C=O;if(D===C)return!0;if(D==null||C==null||D.length!==C.length)return!1;for(let L=0;L<D.length;L+=1){let de=D[L],j=C[L];if(de.from!==j.from||de.to!==j.to||de.relation!==j.relation||de.weight!==j.weight)return!1}return!0},meta:oe("related")})}return Object.assign(r,{events:l,entities:o.entries,edges:s.entries,adjacencyOut:i,adjacencyIn:a,entityCount:u,edgeCount:d,upsertEntity:E,removeEntity:x,link:N,unlink:M,relatedNode:S})}0&&(module.exports={collection,cosineSimilarity,decay,knowledgeGraph,lightCollection,vectorIndex});
@@ -1,6 +1,8 @@
1
1
  import '../../node-fSc-hCv8.cjs';
2
- import '../../graph-kTltt95s.cjs';
3
- export { C as CollectionEntry, b as CollectionGraph, c as CollectionOptions, d as CollectionPolicy, H as HnswAdapter, e as KnowledgeEdge, K as KnowledgeGraphGraph, L as LightCollectionBundle, f as LightCollectionEntry, g as LightCollectionOptions, R as RankedCollectionEntry, h as VectorBackend, a as VectorIndexBundle, j as VectorIndexOptions, k as VectorRecord, V as VectorSearchResult, l as collection, m as decay, n as knowledgeGraph, o as lightCollection, v as vectorIndex } from '../../index-D9qoEOj_.cjs';
4
- import '../../meta-BGO6C7K9.cjs';
5
- import '../../extra/storage-core.cjs';
2
+ import '../../reactive-log-C3IMAGpT.cjs';
3
+ import '../../graph-CHsVwf9S.cjs';
4
+ import '../../imperative-audit-ahAE65a9.cjs';
5
+ export { C as CollectionAuditRecord, b 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, j as LightCollectionAuditRecord, L as LightCollectionBundle, k as LightCollectionEntry, l as LightCollectionOptions, N as NodeOrValue, R as RankedCollectionEntry, m as VectorBackend, n as VectorIndexAuditRecord, a as VectorIndexGraph, o as VectorIndexOptions, p as VectorRecord, V as VectorSearchResult, q as collection, r as cosineSimilarity, s as decay, t as knowledgeGraph, u as lightCollection, v as vectorIndex } from '../../index-Bub6x_D4.cjs';
6
6
  import '../../extra/storage-tiers.cjs';
7
+ import '../../meta-DreaEM_a.cjs';
8
+ import '../../extra/storage-core.cjs';
@@ -1,6 +1,8 @@
1
1
  import '../../node-fSc-hCv8.js';
2
- import '../../graph-Cv-8x0ZI.js';
3
- export { C as CollectionEntry, b as CollectionGraph, c as CollectionOptions, d as CollectionPolicy, H as HnswAdapter, e as KnowledgeEdge, K as KnowledgeGraphGraph, L as LightCollectionBundle, f as LightCollectionEntry, g as LightCollectionOptions, R as RankedCollectionEntry, h as VectorBackend, a as VectorIndexBundle, j as VectorIndexOptions, k as VectorRecord, V as VectorSearchResult, l as collection, m as decay, n as knowledgeGraph, o as lightCollection, v as vectorIndex } from '../../index-CI_yjtua.js';
4
- import '../../meta-CC6EPdpK.js';
5
- import '../../extra/storage-core.js';
2
+ import '../../reactive-log-BgWSA1fg.js';
3
+ import '../../graph-BjW1taJl.js';
4
+ import '../../imperative-audit-ahAE65a9.js';
5
+ export { C as CollectionAuditRecord, b 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, j as LightCollectionAuditRecord, L as LightCollectionBundle, k as LightCollectionEntry, l as LightCollectionOptions, N as NodeOrValue, R as RankedCollectionEntry, m as VectorBackend, n as VectorIndexAuditRecord, a as VectorIndexGraph, o as VectorIndexOptions, p as VectorRecord, V as VectorSearchResult, q as collection, r as cosineSimilarity, s as decay, t as knowledgeGraph, u as lightCollection, v as vectorIndex } from '../../index-Di7OdwlO.js';
6
6
  import '../../extra/storage-tiers.js';
7
+ import '../../meta-BYqlATmg.js';
8
+ import '../../extra/storage-core.js';