@graphrefly/graphrefly 0.44.0 → 0.45.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 (420) hide show
  1. package/README.md +21 -17
  2. package/dist/compat/index.cjs +20 -10
  3. package/dist/compat/index.cjs.map +1 -0
  4. package/dist/compat/index.d.cts +1 -22
  5. package/dist/compat/index.d.ts +1 -22
  6. package/dist/compat/index.js +3 -1
  7. package/dist/compat/index.js.map +1 -0
  8. package/dist/compat/jotai/index.cjs +21 -1
  9. package/dist/compat/jotai/index.cjs.map +1 -0
  10. package/dist/compat/jotai/index.d.cts +1 -2
  11. package/dist/compat/jotai/index.d.ts +1 -2
  12. package/dist/compat/jotai/index.js +3 -1
  13. package/dist/compat/jotai/index.js.map +1 -0
  14. package/dist/compat/nanostores/index.cjs +21 -1
  15. package/dist/compat/nanostores/index.cjs.map +1 -0
  16. package/dist/compat/nanostores/index.d.cts +1 -2
  17. package/dist/compat/nanostores/index.d.ts +1 -2
  18. package/dist/compat/nanostores/index.js +3 -1
  19. package/dist/compat/nanostores/index.js.map +1 -0
  20. package/dist/compat/nestjs/index.cjs +20 -10
  21. package/dist/compat/nestjs/index.cjs.map +1 -0
  22. package/dist/compat/nestjs/index.d.cts +1 -13
  23. package/dist/compat/nestjs/index.d.ts +1 -13
  24. package/dist/compat/nestjs/index.js +3 -1
  25. package/dist/compat/nestjs/index.js.map +1 -0
  26. package/dist/compat/react/index.cjs +21 -1
  27. package/dist/compat/react/index.cjs.map +1 -0
  28. package/dist/compat/react/index.d.cts +1 -2
  29. package/dist/compat/react/index.d.ts +1 -2
  30. package/dist/compat/react/index.js +3 -1
  31. package/dist/compat/react/index.js.map +1 -0
  32. package/dist/compat/solid/index.cjs +21 -1
  33. package/dist/compat/solid/index.cjs.map +1 -0
  34. package/dist/compat/solid/index.d.cts +1 -2
  35. package/dist/compat/solid/index.d.ts +1 -2
  36. package/dist/compat/solid/index.js +3 -1
  37. package/dist/compat/solid/index.js.map +1 -0
  38. package/dist/compat/svelte/index.cjs +21 -1
  39. package/dist/compat/svelte/index.cjs.map +1 -0
  40. package/dist/compat/svelte/index.d.cts +1 -2
  41. package/dist/compat/svelte/index.d.ts +1 -2
  42. package/dist/compat/svelte/index.js +3 -1
  43. package/dist/compat/svelte/index.js.map +1 -0
  44. package/dist/compat/vue/index.cjs +21 -1
  45. package/dist/compat/vue/index.cjs.map +1 -0
  46. package/dist/compat/vue/index.d.cts +1 -3
  47. package/dist/compat/vue/index.d.ts +1 -3
  48. package/dist/compat/vue/index.js +3 -1
  49. package/dist/compat/vue/index.js.map +1 -0
  50. package/dist/compat/zustand/index.cjs +21 -3
  51. package/dist/compat/zustand/index.cjs.map +1 -0
  52. package/dist/compat/zustand/index.d.cts +1 -6
  53. package/dist/compat/zustand/index.d.ts +1 -6
  54. package/dist/compat/zustand/index.js +3 -1
  55. package/dist/compat/zustand/index.js.map +1 -0
  56. package/dist/core/index.cjs +21 -1
  57. package/dist/core/index.cjs.map +1 -0
  58. package/dist/core/index.d.cts +1 -3
  59. package/dist/core/index.d.ts +1 -3
  60. package/dist/core/index.js +3 -1
  61. package/dist/core/index.js.map +1 -0
  62. package/dist/extra/browser.cjs +21 -1
  63. package/dist/extra/browser.cjs.map +1 -0
  64. package/dist/extra/browser.d.cts +1 -4
  65. package/dist/extra/browser.d.ts +1 -4
  66. package/dist/extra/browser.js +3 -1
  67. package/dist/extra/browser.js.map +1 -0
  68. package/dist/extra/index.cjs +20 -19
  69. package/dist/extra/index.cjs.map +1 -0
  70. package/dist/extra/index.d.cts +1 -17
  71. package/dist/extra/index.d.ts +1 -17
  72. package/dist/extra/index.js +3 -1
  73. package/dist/extra/index.js.map +1 -0
  74. package/dist/extra/node.cjs +21 -2
  75. package/dist/extra/node.cjs.map +1 -0
  76. package/dist/extra/node.d.cts +1 -187
  77. package/dist/extra/node.d.ts +1 -187
  78. package/dist/extra/node.js +3 -2
  79. package/dist/extra/node.js.map +1 -0
  80. package/dist/extra/operators.cjs +21 -1
  81. package/dist/extra/operators.cjs.map +1 -0
  82. package/dist/extra/operators.d.cts +1 -958
  83. package/dist/extra/operators.d.ts +1 -958
  84. package/dist/extra/operators.js +3 -1
  85. package/dist/extra/operators.js.map +1 -0
  86. package/dist/extra/reactive.cjs +21 -1
  87. package/dist/extra/reactive.cjs.map +1 -0
  88. package/dist/extra/reactive.d.cts +1 -353
  89. package/dist/extra/reactive.d.ts +1 -353
  90. package/dist/extra/reactive.js +3 -1
  91. package/dist/extra/reactive.js.map +1 -0
  92. package/dist/extra/render/index.cjs +21 -5
  93. package/dist/extra/render/index.cjs.map +1 -0
  94. package/dist/extra/render/index.d.cts +1 -183
  95. package/dist/extra/render/index.d.ts +1 -183
  96. package/dist/extra/render/index.js +3 -1
  97. package/dist/extra/render/index.js.map +1 -0
  98. package/dist/extra/sources.cjs +21 -3
  99. package/dist/extra/sources.cjs.map +1 -0
  100. package/dist/extra/sources.d.cts +1 -584
  101. package/dist/extra/sources.d.ts +1 -584
  102. package/dist/extra/sources.js +3 -1
  103. package/dist/extra/sources.js.map +1 -0
  104. package/dist/extra/storage-browser.cjs +21 -1
  105. package/dist/extra/storage-browser.cjs.map +1 -0
  106. package/dist/extra/storage-browser.d.cts +1 -37
  107. package/dist/extra/storage-browser.d.ts +1 -37
  108. package/dist/extra/storage-browser.js +3 -1
  109. package/dist/extra/storage-browser.js.map +1 -0
  110. package/dist/extra/storage-core.cjs +21 -1
  111. package/dist/extra/storage-core.cjs.map +1 -0
  112. package/dist/extra/storage-core.d.cts +1 -28
  113. package/dist/extra/storage-core.d.ts +1 -28
  114. package/dist/extra/storage-core.js +3 -1
  115. package/dist/extra/storage-core.js.map +1 -0
  116. package/dist/extra/storage-node.cjs +20 -0
  117. package/dist/extra/storage-node.cjs.map +1 -0
  118. package/dist/extra/storage-node.d.cts +1 -2
  119. package/dist/extra/storage-node.d.ts +1 -2
  120. package/dist/extra/storage-node.js +3 -0
  121. package/dist/extra/storage-node.js.map +1 -0
  122. package/dist/extra/storage-tiers-browser.cjs +21 -1
  123. package/dist/extra/storage-tiers-browser.cjs.map +1 -0
  124. package/dist/extra/storage-tiers-browser.d.cts +1 -120
  125. package/dist/extra/storage-tiers-browser.d.ts +1 -120
  126. package/dist/extra/storage-tiers-browser.js +3 -1
  127. package/dist/extra/storage-tiers-browser.js.map +1 -0
  128. package/dist/extra/storage-tiers-node.cjs +21 -1
  129. package/dist/extra/storage-tiers-node.cjs.map +1 -0
  130. package/dist/extra/storage-tiers-node.d.cts +1 -210
  131. package/dist/extra/storage-tiers-node.d.ts +1 -210
  132. package/dist/extra/storage-tiers-node.js +3 -1
  133. package/dist/extra/storage-tiers-node.js.map +1 -0
  134. package/dist/extra/storage-tiers.cjs +21 -1
  135. package/dist/extra/storage-tiers.cjs.map +1 -0
  136. package/dist/extra/storage-tiers.d.cts +1 -412
  137. package/dist/extra/storage-tiers.d.ts +1 -412
  138. package/dist/extra/storage-tiers.js +3 -1
  139. package/dist/extra/storage-tiers.js.map +1 -0
  140. package/dist/extra/storage-wal.cjs +21 -0
  141. package/dist/extra/storage-wal.cjs.map +1 -0
  142. package/dist/extra/storage-wal.d.cts +1 -0
  143. package/dist/extra/storage-wal.d.ts +1 -0
  144. package/dist/extra/storage-wal.js +3 -0
  145. package/dist/extra/storage-wal.js.map +1 -0
  146. package/dist/graph/index.cjs +21 -7
  147. package/dist/graph/index.cjs.map +1 -0
  148. package/dist/graph/index.d.cts +1 -7
  149. package/dist/graph/index.d.ts +1 -7
  150. package/dist/graph/index.js +3 -1
  151. package/dist/graph/index.js.map +1 -0
  152. package/dist/index.cjs +20 -227
  153. package/dist/index.cjs.map +1 -0
  154. package/dist/index.d.cts +45 -95
  155. package/dist/index.d.ts +45 -95
  156. package/dist/index.js +3 -1
  157. package/dist/index.js.map +1 -0
  158. package/dist/patterns/ai/browser.cjs +20 -7
  159. package/dist/patterns/ai/browser.cjs.map +1 -0
  160. package/dist/patterns/ai/browser.d.cts +1 -127
  161. package/dist/patterns/ai/browser.d.ts +1 -127
  162. package/dist/patterns/ai/browser.js +3 -3
  163. package/dist/patterns/ai/browser.js.map +1 -0
  164. package/dist/patterns/ai/index.cjs +20 -73
  165. package/dist/patterns/ai/index.cjs.map +1 -0
  166. package/dist/patterns/ai/index.d.cts +1 -20
  167. package/dist/patterns/ai/index.d.ts +1 -20
  168. package/dist/patterns/ai/index.js +3 -1
  169. package/dist/patterns/ai/index.js.map +1 -0
  170. package/dist/patterns/ai/node.cjs +21 -1
  171. package/dist/patterns/ai/node.cjs.map +1 -0
  172. package/dist/patterns/ai/node.d.cts +1 -59
  173. package/dist/patterns/ai/node.d.ts +1 -59
  174. package/dist/patterns/ai/node.js +3 -1
  175. package/dist/patterns/ai/node.js.map +1 -0
  176. package/dist/patterns/cqrs/index.cjs +21 -3
  177. package/dist/patterns/cqrs/index.cjs.map +1 -0
  178. package/dist/patterns/cqrs/index.d.cts +1 -8
  179. package/dist/patterns/cqrs/index.d.ts +1 -8
  180. package/dist/patterns/cqrs/index.js +3 -1
  181. package/dist/patterns/cqrs/index.js.map +1 -0
  182. package/dist/patterns/demo-shell/index.cjs +21 -5
  183. package/dist/patterns/demo-shell/index.cjs.map +1 -0
  184. package/dist/patterns/demo-shell/index.d.cts +1 -7
  185. package/dist/patterns/demo-shell/index.d.ts +1 -7
  186. package/dist/patterns/demo-shell/index.js +3 -1
  187. package/dist/patterns/demo-shell/index.js.map +1 -0
  188. package/dist/patterns/domain-templates/index.cjs +21 -3
  189. package/dist/patterns/domain-templates/index.cjs.map +1 -0
  190. package/dist/patterns/domain-templates/index.d.cts +1 -6
  191. package/dist/patterns/domain-templates/index.d.ts +1 -6
  192. package/dist/patterns/domain-templates/index.js +3 -1
  193. package/dist/patterns/domain-templates/index.js.map +1 -0
  194. package/dist/patterns/graphspec/index.cjs +21 -86
  195. package/dist/patterns/graphspec/index.cjs.map +1 -0
  196. package/dist/patterns/graphspec/index.d.cts +1 -8
  197. package/dist/patterns/graphspec/index.d.ts +1 -8
  198. package/dist/patterns/graphspec/index.js +3 -1
  199. package/dist/patterns/graphspec/index.js.map +1 -0
  200. package/dist/patterns/harness/index.cjs +21 -48
  201. package/dist/patterns/harness/index.cjs.map +1 -0
  202. package/dist/patterns/harness/index.d.cts +1 -13
  203. package/dist/patterns/harness/index.d.ts +1 -13
  204. package/dist/patterns/harness/index.js +3 -1
  205. package/dist/patterns/harness/index.js.map +1 -0
  206. package/dist/patterns/inspect/index.cjs +21 -3
  207. package/dist/patterns/inspect/index.cjs.map +1 -0
  208. package/dist/patterns/inspect/index.d.cts +1 -9
  209. package/dist/patterns/inspect/index.d.ts +1 -9
  210. package/dist/patterns/inspect/index.js +3 -1
  211. package/dist/patterns/inspect/index.js.map +1 -0
  212. package/dist/patterns/job-queue/index.cjs +21 -3
  213. package/dist/patterns/job-queue/index.cjs.map +1 -0
  214. package/dist/patterns/job-queue/index.d.cts +1 -9
  215. package/dist/patterns/job-queue/index.d.ts +1 -9
  216. package/dist/patterns/job-queue/index.js +3 -1
  217. package/dist/patterns/job-queue/index.js.map +1 -0
  218. package/dist/patterns/memory/index.cjs +21 -3
  219. package/dist/patterns/memory/index.cjs.map +1 -0
  220. package/dist/patterns/memory/index.d.cts +1 -8
  221. package/dist/patterns/memory/index.d.ts +1 -8
  222. package/dist/patterns/memory/index.js +3 -1
  223. package/dist/patterns/memory/index.js.map +1 -0
  224. package/dist/patterns/messaging/index.cjs +21 -3
  225. package/dist/patterns/messaging/index.cjs.map +1 -0
  226. package/dist/patterns/messaging/index.d.cts +1 -7
  227. package/dist/patterns/messaging/index.d.ts +1 -7
  228. package/dist/patterns/messaging/index.js +3 -1
  229. package/dist/patterns/messaging/index.js.map +1 -0
  230. package/dist/patterns/orchestration/index.cjs +21 -3
  231. package/dist/patterns/orchestration/index.cjs.map +1 -0
  232. package/dist/patterns/orchestration/index.d.cts +1 -8
  233. package/dist/patterns/orchestration/index.d.ts +1 -8
  234. package/dist/patterns/orchestration/index.js +3 -1
  235. package/dist/patterns/orchestration/index.js.map +1 -0
  236. package/dist/patterns/process/index.cjs +21 -3
  237. package/dist/patterns/process/index.cjs.map +1 -0
  238. package/dist/patterns/process/index.d.cts +1 -10
  239. package/dist/patterns/process/index.d.ts +1 -10
  240. package/dist/patterns/process/index.js +3 -1
  241. package/dist/patterns/process/index.js.map +1 -0
  242. package/dist/patterns/reactive-layout/index.cjs +21 -4
  243. package/dist/patterns/reactive-layout/index.cjs.map +1 -0
  244. package/dist/patterns/reactive-layout/index.d.cts +1 -7
  245. package/dist/patterns/reactive-layout/index.d.ts +1 -7
  246. package/dist/patterns/reactive-layout/index.js +3 -1
  247. package/dist/patterns/reactive-layout/index.js.map +1 -0
  248. package/dist/patterns/reduction/index.cjs +21 -3
  249. package/dist/patterns/reduction/index.cjs.map +1 -0
  250. package/dist/patterns/reduction/index.d.cts +1 -6
  251. package/dist/patterns/reduction/index.d.ts +1 -6
  252. package/dist/patterns/reduction/index.js +3 -1
  253. package/dist/patterns/reduction/index.js.map +1 -0
  254. package/dist/patterns/surface/index.cjs +21 -13
  255. package/dist/patterns/surface/index.cjs.map +1 -0
  256. package/dist/patterns/surface/index.d.cts +1 -9
  257. package/dist/patterns/surface/index.d.ts +1 -9
  258. package/dist/patterns/surface/index.js +3 -1
  259. package/dist/patterns/surface/index.js.map +1 -0
  260. package/dist/patterns/topology-view/index.cjs +21 -0
  261. package/dist/patterns/topology-view/index.cjs.map +1 -0
  262. package/dist/patterns/topology-view/index.d.cts +1 -0
  263. package/dist/patterns/topology-view/index.d.ts +1 -0
  264. package/dist/patterns/topology-view/index.js +3 -0
  265. package/dist/patterns/topology-view/index.js.map +1 -0
  266. package/dist/testing/index.cjs +21 -0
  267. package/dist/testing/index.cjs.map +1 -0
  268. package/dist/testing/index.d.cts +1 -0
  269. package/dist/testing/index.d.ts +1 -0
  270. package/dist/testing/index.js +3 -0
  271. package/dist/testing/index.js.map +1 -0
  272. package/package.json +608 -584
  273. package/dist/backoff-HPZMEZNF.js +0 -1
  274. package/dist/cascading-BglDkMdX.d.cts +0 -199
  275. package/dist/cascading-MFgxu7Yo.d.ts +0 -199
  276. package/dist/chunk-2T7U5EU6.js +0 -1
  277. package/dist/chunk-3G5U5QNE.js +0 -5
  278. package/dist/chunk-4VVTGLXJ.js +0 -1
  279. package/dist/chunk-5M4CCMMD.js +0 -45
  280. package/dist/chunk-5QDBSZBV.js +0 -1
  281. package/dist/chunk-5XJ6B66J.js +0 -1
  282. package/dist/chunk-6QZNQS5B.js +0 -1
  283. package/dist/chunk-6X7AFUJV.js +0 -9
  284. package/dist/chunk-7K6PWTDQ.js +0 -1
  285. package/dist/chunk-7LIAPXJB.js +0 -1
  286. package/dist/chunk-7WPU3UHQ.js +0 -1
  287. package/dist/chunk-A5WCQ5NO.js +0 -1
  288. package/dist/chunk-APPIWSGD.js +0 -84
  289. package/dist/chunk-BEZWM2SY.js +0 -1
  290. package/dist/chunk-C72GO4IZ.js +0 -1
  291. package/dist/chunk-CB676TKJ.js +0 -1
  292. package/dist/chunk-CE6TI2TL.js +0 -1
  293. package/dist/chunk-CE72X3WO.js +0 -1
  294. package/dist/chunk-CK2E7BTU.js +0 -1
  295. package/dist/chunk-CLVB32RD.js +0 -1
  296. package/dist/chunk-CRVT7D2P.js +0 -1
  297. package/dist/chunk-D5RFJOZ2.js +0 -1
  298. package/dist/chunk-D7GPHKFH.js +0 -1
  299. package/dist/chunk-DHRX7JX4.js +0 -2
  300. package/dist/chunk-ESMPEKEV.js +0 -1
  301. package/dist/chunk-F672GV32.js +0 -1
  302. package/dist/chunk-FZMYDOWV.js +0 -1
  303. package/dist/chunk-GHBWHMRZ.js +0 -1
  304. package/dist/chunk-GLERH466.js +0 -1
  305. package/dist/chunk-GPW2V3RE.js +0 -1
  306. package/dist/chunk-HIDYF36O.js +0 -1
  307. package/dist/chunk-HITNVN6B.js +0 -3
  308. package/dist/chunk-HY4DJBA7.js +0 -5
  309. package/dist/chunk-KZIEYVXN.js +0 -1
  310. package/dist/chunk-L6NSJVJZ.js +0 -1
  311. package/dist/chunk-N4MQX6JU.js +0 -18
  312. package/dist/chunk-N7FHEL4D.js +0 -1
  313. package/dist/chunk-NTEURFZH.js +0 -1
  314. package/dist/chunk-OIVP6KFV.js +0 -1
  315. package/dist/chunk-OPHBU3LG.js +0 -1
  316. package/dist/chunk-OYQOZP2F.js +0 -5
  317. package/dist/chunk-PTZK576G.js +0 -1
  318. package/dist/chunk-QYADASLV.js +0 -1
  319. package/dist/chunk-ST7UXLWR.js +0 -1
  320. package/dist/chunk-SVY7VUYU.js +0 -1
  321. package/dist/chunk-TK3NWWD4.js +0 -1
  322. package/dist/chunk-TSOYJ743.js +0 -1
  323. package/dist/chunk-UNGSTR4X.js +0 -61
  324. package/dist/chunk-VIMF6LGM.js +0 -1
  325. package/dist/chunk-VJLMUKOI.js +0 -1
  326. package/dist/chunk-VN6RDSK2.js +0 -1
  327. package/dist/chunk-VV4N5P64.js +0 -1
  328. package/dist/chunk-W3I423PS.js +0 -1
  329. package/dist/chunk-WJR24TAG.js +0 -1
  330. package/dist/chunk-XTGKMHSW.js +0 -1
  331. package/dist/chunk-YBB7ZGTY.js +0 -1
  332. package/dist/chunk-Z4NPUARF.js +0 -1
  333. package/dist/chunk-ZGNQRPDT.js +0 -1
  334. package/dist/chunk-ZKPSFFKU.js +0 -1
  335. package/dist/chunk-ZLV5SQSX.js +0 -1
  336. package/dist/content-addressed-storage-4-ST1tYk.d.cts +0 -124
  337. package/dist/content-addressed-storage-DuYMjV7o.d.ts +0 -124
  338. package/dist/decay-BvOWTZ00.d.ts +0 -112
  339. package/dist/decay-CFlLvXUT.d.cts +0 -112
  340. package/dist/fallback-74oxi34l.d.cts +0 -250
  341. package/dist/fallback-DUyyBTBK.d.ts +0 -250
  342. package/dist/graph-CWvEUQAq.d.cts +0 -1861
  343. package/dist/graph-D9LFnda9.d.ts +0 -1861
  344. package/dist/index-5k1T6jl0.d.cts +0 -121
  345. package/dist/index-9770hRuQ.d.cts +0 -779
  346. package/dist/index-B-_tFaqV.d.cts +0 -468
  347. package/dist/index-B17QddL1.d.cts +0 -374
  348. package/dist/index-B1F8Enjf.d.ts +0 -704
  349. package/dist/index-B5S8ULbU.d.ts +0 -515
  350. package/dist/index-B8YnZpIR.d.ts +0 -102
  351. package/dist/index-BHskSB8v.d.ts +0 -3413
  352. package/dist/index-BIYAkbAi.d.cts +0 -26
  353. package/dist/index-BQSKmbuG.d.cts +0 -127
  354. package/dist/index-BaQaY_IQ.d.cts +0 -231
  355. package/dist/index-BmZXHqkE.d.ts +0 -36
  356. package/dist/index-BoJ5JHxI.d.ts +0 -557
  357. package/dist/index-BocU7pqs.d.ts +0 -779
  358. package/dist/index-BrPrLl4e.d.cts +0 -86
  359. package/dist/index-BxNs2HB9.d.cts +0 -1858
  360. package/dist/index-Byu-OpX_.d.ts +0 -113
  361. package/dist/index-C1T3d7V-.d.cts +0 -704
  362. package/dist/index-C5ri2Axc.d.cts +0 -301
  363. package/dist/index-C5stwKcw.d.cts +0 -44
  364. package/dist/index-C9l6OEBL.d.ts +0 -26
  365. package/dist/index-CBBLl_rc.d.ts +0 -127
  366. package/dist/index-CBGUK09R.d.ts +0 -754
  367. package/dist/index-CC-AvFTy.d.cts +0 -557
  368. package/dist/index-CJF1URuX.d.ts +0 -121
  369. package/dist/index-CK29LV56.d.cts +0 -34
  370. package/dist/index-CMh5Rz1y.d.ts +0 -385
  371. package/dist/index-CPQlGA29.d.ts +0 -34
  372. package/dist/index-CR8QpwX8.d.ts +0 -2680
  373. package/dist/index-CS0LTlB8.d.cts +0 -385
  374. package/dist/index-CSOmP7xT.d.cts +0 -291
  375. package/dist/index-CYq8vAyV.d.ts +0 -291
  376. package/dist/index-CZ3r5Rxp.d.ts +0 -374
  377. package/dist/index-CasX6Pfq.d.cts +0 -358
  378. package/dist/index-CdAlHFEt.d.ts +0 -44
  379. package/dist/index-CdTelp1M.d.ts +0 -202
  380. package/dist/index-CeFiHtAg.d.ts +0 -468
  381. package/dist/index-Cj3WohTd.d.cts +0 -202
  382. package/dist/index-Climxqsu.d.cts +0 -754
  383. package/dist/index-Co7uli2l.d.cts +0 -3413
  384. package/dist/index-CviRnE4K.d.ts +0 -45
  385. package/dist/index-Cwv0KWcU.d.cts +0 -102
  386. package/dist/index-CzLVrjxn.d.ts +0 -231
  387. package/dist/index-D0aciIex.d.cts +0 -209
  388. package/dist/index-DHen9Klo.d.ts +0 -1858
  389. package/dist/index-DV_1YuVk.d.cts +0 -221
  390. package/dist/index-Dc4AYqrJ.d.cts +0 -515
  391. package/dist/index-Dgl1HpPn.d.ts +0 -86
  392. package/dist/index-DisjX8a-.d.ts +0 -221
  393. package/dist/index-UPSiS-X7.d.cts +0 -2680
  394. package/dist/index-Yq60JP3s.d.ts +0 -209
  395. package/dist/index-ZVQhLa2i.d.cts +0 -37
  396. package/dist/index-_6ODbuOu.d.cts +0 -45
  397. package/dist/index-hcDJ8PSI.d.cts +0 -36
  398. package/dist/index-nozs3fFC.d.ts +0 -301
  399. package/dist/index-p09KSrTN.d.ts +0 -358
  400. package/dist/index-sqkqlb1p.d.ts +0 -37
  401. package/dist/index-tRCxuAXF.d.cts +0 -113
  402. package/dist/node-kK3CvTrR.d.cts +0 -1347
  403. package/dist/node-kK3CvTrR.d.ts +0 -1347
  404. package/dist/observable-DWjNfLvC.d.ts +0 -36
  405. package/dist/observable-e3eiPPFy.d.cts +0 -36
  406. package/dist/pipeline-graph-CIKhynsF.d.cts +0 -142
  407. package/dist/pipeline-graph-Sgj0gCwn.d.ts +0 -142
  408. package/dist/reactive-layout-DOTs9P3X.d.ts +0 -183
  409. package/dist/reactive-layout-DgctbqZo.d.cts +0 -183
  410. package/dist/reactive-log-BKALbfal.d.ts +0 -223
  411. package/dist/reactive-log-DIGdYqQ6.d.cts +0 -223
  412. package/dist/reactive-map-CEFGp8TK.d.cts +0 -296
  413. package/dist/reactive-map-DS_SIAxv.d.ts +0 -296
  414. package/dist/resilience-6LYQJAC5.js +0 -1
  415. package/dist/sugar-DQjFmVqb.d.cts +0 -399
  416. package/dist/sugar-fhLIE7TT.d.ts +0 -399
  417. package/dist/topology-tree-Bcz27hpF.d.cts +0 -25
  418. package/dist/topology-tree-xvaD0fOX.d.ts +0 -25
  419. package/dist/types-C0_yquda.d.cts +0 -442
  420. package/dist/types-CWFysE9E.d.ts +0 -442
@@ -1,3 +1,21 @@
1
- "use strict";var it=Object.defineProperty;var Gn=Object.getOwnPropertyDescriptor;var In=Object.getOwnPropertyNames;var $n=Object.prototype.hasOwnProperty;var j=(r,e)=>()=>(r&&(e=r(r=0)),e);var Pn=(r,e)=>{for(var t in e)it(r,t,{get:e[t],enumerable:!0})},Vn=(r,e,t,n)=>{if(e&&typeof e=="object"||typeof e=="function")for(let s of In(e))!$n.call(r,s)&&s!==t&&it(r,s,{get:()=>e[s],enumerable:!(n=Gn(e,s))||n.enumerable});return r};var Fn=r=>Vn(it({},"__esModule",{value:!0}),r);function K(){return Math.trunc(performance.now()*1e6)}function le(){return Date.now()*1e6}var be=j(()=>{"use strict"});function Ct(r,e){let t=new TextEncoder().encode(r.name);if(t.length===0||t.length>255)throw new Error(`encodeEnvelope: codec name "${r.name}" encodes to ${t.length} bytes (must be 1\u2013255)`);let n=r.version;if(!Number.isInteger(n)||n<0||n>65535)throw new Error(`encodeEnvelope: codec.version ${n} out of u16 range (expected integer 0\u201365535)`);let s=2+t.length+2+e.length;if(s>4294967295)throw new Error(`encodeEnvelope: total envelope size ${s} exceeds 2^32-1 bytes (payload ${e.length} bytes)`);let o=new Uint8Array(s),i=0;return o[i++]=at,o[i++]=t.length,o.set(t,i),i+=t.length,o[i++]=n>>>8&255,o[i++]=n&255,o.set(e,i),o}function Dt(r,e){if(r.length<Mt)throw new Error(`decodeEnvelope: bytes too short (${r.length} < ${Mt})`);let t=0,n=r[t++];if(n!==at)throw new Error(`decodeEnvelope: unsupported envelope version ${n} (expected ${at})`);let s=r[t++];if(s===0)throw new Error("decodeEnvelope: name_len must be >= 1");if(t+s+2>r.length)throw new Error(`decodeEnvelope: envelope truncated (need ${t+s+2} bytes, have ${r.length})`);let o=new TextDecoder().decode(r.subarray(t,t+s));t+=s;let i=(r[t]<<8|r[t+1])>>>0;t+=2;let a=r.subarray(t),d=e.lookupCodec(o);if(d==null)throw new Error(`decodeEnvelope: codec "${o}" not registered (envelope codec_v=${i})`);return{codec:d,codecVersion:i,payload:a}}function Gt(r){r.registerCodec(zn)}var zn,at,Mt,dt=j(()=>{"use strict";zn={name:"json",version:1,contentType:"application/json",encode(r){let e=JSON.stringify(r);return new TextEncoder().encode(e)},decode(r,e){let t=new TextDecoder().decode(r);return JSON.parse(t)}},at=1,Mt=4});function je(r){if(r==null)return Re;let{type:e,id:t,...n}=r;return{type:e??"system",id:t??"",...n}}var Re,ut=j(()=>{"use strict";Re={type:"system",id:""}});function Be(){return Ee>0||Ie}function It(){return Ee>0}function Se(r){Ee>0?$e.push(r):r()}function _e(r){Ee+=1;let e=!1;try{r()}catch(t){throw e=!0,t}finally{if(Ee-=1,Ee===0)if(e){if(!Ie){let t=$e.splice(0);for(let n of t)try{n()}catch{}ye.length=0,ve.length=0,Oe.length=0}}else Ln()}}function Ln(){let r=!Ie;r&&(Ie=!0);let e=[],t=0;try{for(;ye.length>0||ve.length>0||Oe.length>0||r&&$e.length>0;){if(r&&$e.length>0){let o=$e.splice(0);for(let i of o)try{i()}catch(a){e.push(a)}continue}if(t+=1,t>1e3)throw ye.length=0,ve.length=0,Oe.length=0,new Error("batch drain exceeded 1000 iterations \u2014 likely a reactive cycle");let s=(ye.length>0?ye:ve.length>0?ve:Oe).splice(0);for(let o of s)try{o()}catch(i){e.push(i)}}}finally{r&&(Ie=!1)}if(e.length===1)throw e[0];if(e.length>1)throw new AggregateError(e,"batch drain: multiple callbacks threw")}function qe(r,e,t){if(e.length===0)return;if(e.length===1){let u=t(e[0][0]);if(u<3||!Be()){r(e);return}(u>=5?Oe:u===4?ve:ye).push(()=>r(e));return}let n=e.length,s=n,o=n,i=n,a=0;for(;a<n&&t(e[a][0])<3;)a++;for(s=a;a<n&&t(e[a][0])===3;)a++;for(o=a;a<n&&t(e[a][0])===4;)a++;i=a;let d=Be();if(s>0){let u=e.slice(0,s);r(u)}if(o>s){let u=e.slice(s,o);d?ye.push(()=>r(u)):r(u)}if(i>o){let u=e.slice(o,i);d?ve.push(()=>r(u)):r(u)}if(n>i){let u=e.slice(i,n);d?Oe.push(()=>r(u)):r(u)}}var Ee,Ie,ye,ve,Oe,$e,Pe=j(()=>{"use strict";Ee=0,Ie=!1,ye=[],ve=[],Oe=[],$e=[]});var Ae,$,Y,Q,ie,ce,fe,W,H,G,Me,ct,Kn,lt,jn,Bn,ft,$t,Pt,Vt,pt,pe=j(()=>{"use strict";Ae=Symbol.for("graphrefly/START"),$=Symbol.for("graphrefly/DATA"),Y=Symbol.for("graphrefly/DIRTY"),Q=Symbol.for("graphrefly/RESOLVED"),ie=Symbol.for("graphrefly/INVALIDATE"),ce=Symbol.for("graphrefly/PAUSE"),fe=Symbol.for("graphrefly/RESUME"),W=Symbol.for("graphrefly/TEARDOWN"),H=Symbol.for("graphrefly/COMPLETE"),G=Symbol.for("graphrefly/ERROR"),Me=Object.freeze([Y]),ct=Object.freeze([Q]),Kn=Object.freeze([ie]),lt=Object.freeze([Ae]),jn=Object.freeze([H]),Bn=Object.freeze([W]),ft=Object.freeze([Me]),$t=Object.freeze([ct]),Pt=Object.freeze([Kn]),Vt=Object.freeze([jn]),pt=Object.freeze([Bn])});function Ft(r){r.registerMessageType(Ae,{tier:0,wireCrossing:!1}),r.registerMessageType(Y,{tier:1,wireCrossing:!1}),r.registerMessageType(ie,{tier:1,wireCrossing:!1,metaPassthrough:!1}),r.registerMessageType(ce,{tier:2,wireCrossing:!1}),r.registerMessageType(fe,{tier:2,wireCrossing:!1}),r.registerMessageType($,{tier:3,wireCrossing:!0}),r.registerMessageType(Q,{tier:3,wireCrossing:!0}),r.registerMessageType(H,{tier:4,wireCrossing:!0,metaPassthrough:!1}),r.registerMessageType(G,{tier:4,wireCrossing:!0,metaPassthrough:!1}),r.registerMessageType(W,{tier:5,wireCrossing:!0,metaPassthrough:!1})}var He,zt=j(()=>{"use strict";pe();He=class{_messageTypes=new Map;_codecs=new Map;_onMessage;_onSubscribe;_defaultVersioning;_defaultHashFn;_inspectorEnabled=!(typeof process<"u"&&process.env?.NODE_ENV==="production");_globalInspector;_rigorRecorder;_frozen=!1;tierOf;constructor(e){this._onMessage=e.onMessage,this._onSubscribe=e.onSubscribe,this._defaultVersioning=e.defaultVersioning,this._defaultHashFn=e.defaultHashFn,this.tierOf=t=>{let n=this._messageTypes.get(t);return n!=null?n.tier:1}}get onMessage(){return this._frozen=!0,this._onMessage}get onSubscribe(){return this._frozen=!0,this._onSubscribe}set onMessage(e){this._assertUnfrozen(),this._onMessage=e}set onSubscribe(e){this._assertUnfrozen(),this._onSubscribe=e}get defaultVersioning(){return this._defaultVersioning}set defaultVersioning(e){this._assertUnfrozen(),this._defaultVersioning=e}get defaultHashFn(){return this._defaultHashFn}set defaultHashFn(e){this._assertUnfrozen(),this._defaultHashFn=e}get inspectorEnabled(){return this._inspectorEnabled}set inspectorEnabled(e){this._inspectorEnabled=e}get globalInspector(){return this._globalInspector}set globalInspector(e){this._globalInspector=e}get rigorRecorder(){return this._rigorRecorder}set rigorRecorder(e){this._rigorRecorder=e}registerMessageType(e,t){return this._assertUnfrozen(),this._messageTypes.set(e,{tier:t.tier,wireCrossing:t.wireCrossing??t.tier>=3,metaPassthrough:t.metaPassthrough??!0}),this}messageTier(e){let t=this._messageTypes.get(e);return t!=null?t.tier:1}isWireCrossing(e){let t=this._messageTypes.get(e);return t!=null?t.wireCrossing:!0}isLocalOnly(e){return!this.isWireCrossing(e)}isMetaPassthrough(e){let t=this._messageTypes.get(e);return t!=null?t.metaPassthrough:!0}isKnownMessageType(e){return this._messageTypes.has(e)}registerCodec(e){return this._assertUnfrozen(),this._codecs.set(e.name,e),this}lookupCodec(e){return this._codecs.get(e)}_isFrozen(){return this._frozen}_assertUnfrozen(){if(this._frozen)throw new Error("GraphReFlyConfig is frozen: a node has already captured this config. Register custom types and set hooks before creating any node.")}}});function Lt(r){return Array.isArray(r)?[...r]:[r]}function qn(r,e){return r.has(e)||r.has("*")}function Kt(r){let e=[];return r((s,o)=>{e.push({kind:"allow",actions:new Set(Lt(s)),where:o?.where??(()=>!0)})},(s,o)=>{e.push({kind:"deny",actions:new Set(Lt(s)),where:o?.where??(()=>!0)})}),(s,o)=>{let i=!1,a=!1;for(let d of e)qn(d.actions,o)&&d.where(s)&&(d.kind==="deny"?i=!0:a=!0);return i?!1:a}}function ht(r){let e=Hn.filter(t=>r({type:t,id:""},"write"));return e.length===0?"restricted":e.includes("human")&&e.includes("llm")&&e.every(t=>t==="human"||t==="llm"||t==="system")?"both":e.length===1?e[0]:e.join("+")}var re,Hn,Ve=j(()=>{"use strict";re=class extends Error{actor;action;nodeName;constructor(e,t){super(t??`GuardDenied: action "${String(e.action)}" denied for actor type "${String(e.actor.type)}"`),this.name="GuardDenied",this.actor=e.actor,this.action=e.action,this.nodeName=e.nodeName}get node(){return this.nodeName}};Hn=["human","llm","wallet","system"]});function gt(r){if(r===void 0)return null;if(typeof r=="number"){if(!Number.isFinite(r))throw new TypeError(`Cannot hash non-finite number: ${r}`);if(Number.isInteger(r)&&!Number.isSafeInteger(r))throw new TypeError(`Cannot hash integer outside safe range (|n| > 2^53-1): ${r}. Cross-language cid parity is not guaranteed for unsafe integers.`);return r}if(typeof r=="string"||typeof r=="boolean"||r===null)return r;if(Array.isArray(r))return r.map(gt);if(typeof r=="object"&&r!==null){let e={};for(let t of Object.keys(r).sort())e[t]=gt(r[t]);return e}return null}function Yn(r){let e=Wn.encode(r),t=e.length,n=t*8,s=t+9+63&-64,o=new Uint8Array(s);o.set(e),o[t]=128;let i=new DataView(o.buffer);i.setUint32(s-4,n>>>0,!1),i.setUint32(s-8,Math.floor(n/4294967296)>>>0,!1);let a=1779033703,d=3144134277,u=1013904242,c=2773480762,h=1359893119,f=2600822924,p=528734635,l=1541459225,v=new Uint32Array(64),g=(_,T)=>_>>>T|_<<32-T;for(let _=0;_<s;_+=64){for(let w=0;w<16;w++)v[w]=i.getUint32(_+w*4,!1);for(let w=16;w<64;w++){let A=v[w-15],E=v[w-2],O=g(A,7)^g(A,18)^A>>>3,C=g(E,17)^g(E,19)^E>>>10;v[w]=v[w-16]+O+v[w-7]+C>>>0}let T=a,x=d,R=u,S=c,m=h,b=f,y=p,N=l;for(let w=0;w<64;w++){let A=g(m,6)^g(m,11)^g(m,25),E=m&b^~m&y,O=N+A+E+Un[w]+v[w]>>>0,C=g(T,2)^g(T,13)^g(T,22),D=T&x^T&R^x&R,P=C+D>>>0;N=y,y=b,b=m,m=S+O>>>0,S=R,R=x,x=T,T=O+P>>>0}a=a+T>>>0,d=d+x>>>0,u=u+R>>>0,c=c+S>>>0,h=h+m>>>0,f=f+b>>>0,p=p+y>>>0,l=l+N>>>0}let k=_=>_.toString(16).padStart(8,"0");return k(a)+k(d)+k(u)+k(c)+k(h)+k(f)+k(p)+k(l)}function mt(r){let e=gt(r??null),t=JSON.stringify(e);return Yn(t).slice(0,16)}function Jn(){let r=globalThis.crypto;if(r?.randomUUID)return r.randomUUID();let e=()=>Math.floor(Math.random()*4294967296).toString(16).padStart(8,"0"),t=e()+e()+e()+e();return`${t.slice(0,8)}-${t.slice(8,12)}-4${t.slice(13,16)}-${(parseInt(t.slice(16,17),16)&3|8).toString(16)}${t.slice(17,20)}-${t.slice(20,32)}`}function bt(r,e,t){let n=t?.id??Jn();if(r===0)return{id:n,version:0};let o=(t?.hash??mt)(e);return{id:n,version:0,cid:o,prev:null}}function jt(r,e,t){r.version+=1,"cid"in r&&(r.prev=r.cid,r.cid=t(e))}var Un,Wn,Bt=j(()=>{"use strict";Un=new Uint32Array([1116352408,1899447441,3049323471,3921009573,961987163,1508970993,2453635748,2870763221,3624381080,310598401,607225278,1426881987,1925078388,2162078206,2614888103,3248222580,3835390401,4022224774,264347078,604807628,770255983,1249150122,1555081692,1996064986,2554220882,2821834349,2952996808,3210313671,3336571891,3584528711,113926993,338241895,666307205,773529912,1294757372,1396182291,1695183700,1986661051,2177026350,2456956037,2730485921,2820302411,3259730800,3345764771,3516065817,3600352804,4094571909,275423344,430227734,506948616,659060556,883997877,958139571,1322822218,1537002063,1747873779,1955562222,2024104815,2227730452,2361852424,2428436474,2756734187,3204031479,3329325298]),Wn=new TextEncoder});function Ut(r){return{node:r,unsub:null,prevData:void 0,dirty:!1,involvedThisWave:!1,dataBatch:[],terminal:void 0}}function yt(r){r.prevData=void 0,r.dirty=!1,r.involvedThisWave=!1,r.dataBatch.length=0,r.terminal=void 0}function Ue(r){return r.length===0?r:typeof r[0]=="symbol"?[r]:r}function we(r,e,t){let n=Wt(r)?r:[],s=typeof r=="function"?r:typeof e=="function"?e:void 0,o={};return Wt(r)?o=(vt(e)?e:t)??{}:vt(r)?o=r:o=(vt(e)?e:t)??{},new z(n,s,o)}var qt,Ht,Xn,Zn,Ce,z,Wt,vt,Te=j(()=>{"use strict";dt();ut();Pe();be();zt();Ve();pe();Bt();qt=()=>{},Ht=100;Xn=(r,e,t,n)=>{t.direction==="down-in"&&r._onDepMessage(t.depIndex,e)},Zn=(r,e,t,n)=>{let s=r;if(s._status==="completed"||s._status==="errored")return;let o=s._cached,i=o===void 0?[lt]:[lt,[$,o]];s._status==="dirty"&&i.push(Me),qe(e,i,s._config.tierOf)},Ce=new He({onMessage:Xn,onSubscribe:Zn});Ft(Ce);Gt(Ce);z=class r{_optsName;_describeKind;meta;_hasMeta;_config;_deps;_sinks=null;_sinkCount=0;_cached;_status;_cleanup;_store={};_waveHasNewData=!1;_hasNewTerminal=!1;_hasCalledFnOnce=!1;_paused=!1;_pendingWave=!1;_isExecutingFn=!1;_pendingRerun=!1;_rerunDepth=0;_dirtyDepCount=0;_batchPendingMessages=null;_pauseLocks=null;_pauseBuffer=null;_fn;_equals;_resubscribable;_resetOnTeardown;_autoComplete;_autoError;_pausable;_partial;_guard;_extraGuards;_hashFn;_versioning;_versioningLevel;_lastMutation;_inspectorHooks;_actions;constructor(e,t,n){this._config=n.config??Ce,this._config.onMessage,this._optsName=n.name,this._describeKind=n.describeKind,this._equals=n.equals??Object.is,this._resubscribable=n.resubscribable??!1,this._resetOnTeardown=n.resetOnTeardown??!1,this._autoComplete=n.completeWhenDepsComplete??!0,this._autoError=n.errorWhenDepsError??!0,this._pausable=n.pausable??!0,this._guard=n.guard,this._fn=t,this._partial=n.partial??!1,this._cached=n.initial!==void 0?n.initial:void 0,this._status=e.length===0&&t==null&&this._cached!==void 0?"settled":"sentinel",this._hashFn=n.versioningHash??this._config.defaultHashFn??mt;let s=n.versioning??this._config.defaultVersioning;this._versioningLevel=s,this._versioning=s!=null?bt(s,this._cached===void 0?void 0:this._cached,{id:n.versioningId,hash:this._hashFn}):void 0,this._deps=e.map(Ut);let o={};for(let[a,d]of Object.entries(n.meta??{})){let u={initial:d,name:`${n.name??"node"}:meta:${a}`,describeKind:"state",config:this._config};n.guard!=null&&(u.guard=n.guard),n.resubscribable===!0&&(u.resubscribable=!0),o[a]=new r([],void 0,u)}Object.freeze(o),this.meta=o,this._hasMeta=Object.keys(o).length>0;let i=this;this._actions={emit(a){i._emit([[$,a]])},down(a){i._emit(Ue(a))},up(a){i._emitUp(Ue(a))}},this.down=this.down.bind(this),this.up=this.up.bind(this)}get _isTerminal(){return this._status==="completed"||this._status==="errored"}get name(){return this._optsName}get status(){return this._status}get cache(){return this._cached===void 0?void 0:this._cached}get lastMutation(){return this._lastMutation}get v(){return this._versioning}hasGuard(){return this._guard!=null}_applyVersioning(e,t){if(this._isExecutingFn)throw new Error(`Node "${this.name}": _applyVersioning cannot run mid-fn \u2014 call it outside of \`_execFn\` (typically at graph setup time before the first subscribe).`);let n=this._versioningLevel;if(n!=null&&e<=n)return;let s=t?.hash??this._hashFn;s!==this._hashFn&&(this._hashFn=s);let o=this._cached===void 0?void 0:this._cached,i=this._versioning,a=i?.id??t?.id,d=i?.version??0,u=bt(e,o,{id:a,hash:s});u.version=d,this._versioning=u,this._versioningLevel=e}_setInspectorHook(e){return e==null?()=>{}:(this._inspectorHooks==null&&(this._inspectorHooks=new Set),this._inspectorHooks.add(e),()=>{this._inspectorHooks?.delete(e),this._inspectorHooks?.size===0&&(this._inspectorHooks=void 0)})}_pushGuard(e){return this._extraGuards==null&&(this._extraGuards=new Set),this._extraGuards.add(e),()=>{this._extraGuards?.delete(e),this._extraGuards?.size===0&&(this._extraGuards=void 0)}}allowsObserve(e){if(this._guard==null&&this._extraGuards==null)return!0;let t=je(e);if(this._guard!=null&&!this._guard(t,"observe"))return!1;if(this._extraGuards!=null){for(let n of this._extraGuards)if(!n(t,"observe"))return!1}return!0}_checkGuard(e){if(e?.internal)return;let t=this._guard!=null||this._extraGuards!=null,n=e?.actor!=null;if(!t&&!n)return;let s=je(e?.actor),o=e?.delivery==="signal"?"signal":"write";if(this._guard!=null&&!this._guard(s,o))throw new re({actor:s,action:o,nodeName:this.name});if(this._extraGuards!=null){for(let i of this._extraGuards)if(!i(s,o))throw new re({actor:s,action:o,nodeName:this.name})}this._lastMutation={actor:s,timestamp_ns:le()}}down(e,t){let n=Ue(e);n.length!==0&&(this._checkGuard(t),this._emit(n))}emit(e,t){this._checkGuard(t),this._emit([[$,e]])}up(e,t){if(this._deps.length===0)return;let n=Ue(e);if(n.length===0)return;this._checkGuard(t);let s=t??{internal:!0};this._validateUpTiers(n);for(let o of this._deps)o.node.up?.(n,s)}_emitUp(e){if(this._deps.length!==0&&e.length!==0){this._validateUpTiers(e);for(let t of this._deps)t.node.up?.(e,{internal:!0})}}_validateUpTiers(e){let t=this._config.tierOf;for(let n of e){let s=t(n[0]);if(s===3||s===4)throw new Error(`Node "${this.name}": tier-${s} messages cannot flow up \u2014 DATA/RESOLVED/COMPLETE/ERROR are downstream-only. Use \`down(...)\` for value delivery; \`up(...)\` is for control signals (DIRTY, INVALIDATE, PAUSE, RESUME, TEARDOWN).`)}}subscribe(e,t){if(t!=null&&this._guard!=null){let d=je(t);if(!this._guard(d,"observe"))throw new re({actor:d,action:"observe",nodeName:this.name})}let s=this._isTerminal&&this._resubscribable;if(s){this._cached=void 0,this._status="sentinel",this._store={},this._hasCalledFnOnce=!1,this._waveHasNewData=!1,this._hasNewTerminal=!1,this._paused=!1,this._pendingWave=!1,this._pendingRerun=!1,this._isExecutingFn=!1,this._rerunDepth=0,this._dirtyDepCount=0,this._pauseLocks=null,this._pauseBuffer=null;for(let d of this._deps)yt(d);if(this._partial===!1){for(let d of this._deps)if(d.prevData!==void 0||d.dataBatch.length!==0||d.terminal!==void 0||d.dirty)throw new Error(`resubscribable-reset invariant: DepRecord not fully reset for node ${this._optsName??"(anonymous)"}`)}}this._sinkCount+=1;let o;try{o=this._config.onSubscribe(this,e,{sinkCount:this._sinkCount,afterTerminalReset:s},this._actions)}catch(d){throw this._sinkCount-=1,d}this._sinks==null?this._sinks=e:typeof this._sinks=="function"?this._sinks=new Set([this._sinks,e]):this._sinks.add(e);let i=this._isTerminal;if(this._sinkCount===1&&!i)try{this._activate()}catch(d){if(this._sinkCount-=1,this._removeSink(e),this._sinkCount===0&&(this._status="sentinel"),typeof o=="function")try{o()}catch{}throw d}this._status==="sentinel"&&this._cached===void 0&&(this._status="pending");let a=!1;return()=>{a||(a=!0,this._sinkCount-=1,this._removeSink(e),typeof o=="function"&&o(),this._sinks==null&&this._deactivate())}}_removeSink(e){if(this._sinks===e)this._sinks=null;else if(this._sinks!=null&&typeof this._sinks!="function")if(this._sinks.delete(e),this._sinks.size===1){let[t]=this._sinks;this._sinks=t}else this._sinks.size===0&&(this._sinks=null)}_activate(){if(this._deps.length===0){this._fn&&this._execFn();return}this._dirtyDepCount=0;let e=this._deps.length,t=0;try{for(let n=0;n<e;n++){let s=n,o=this._deps[n];o.unsub=qt,o.unsub=o.node.subscribe(i=>{if(o.unsub===null)return;let a=this._config.tierOf,d=!1;for(let u of i)a(u[0])>=3&&(d=!0),this._config.onMessage(this,u,{direction:"down-in",depIndex:s},this._actions);d&&this._maybeRunFnOnSettlement()}),t++}}catch(n){this._deps[t].unsub=null;for(let s=0;s<t;s++){let o=this._deps[s];if(o.unsub!=null){let i=o.unsub;o.unsub=null;try{i()}catch{}yt(o)}}throw this._dirtyDepCount=0,n}}_addDep(e){for(let s=0;s<this._deps.length;s++)if(this._deps[s].node===e)return s;let t=this._deps.length,n=Ut(e);if(this._deps.push(n),this._sinks==null)return t;n.dirty=!0,this._dirtyDepCount++,this._status!=="dirty"&&this._emit(ft),n.unsub=qt;try{n.unsub=e.subscribe(s=>{if(n.unsub===null)return;let o=this._config.tierOf,i=!1;for(let a of s)o(a[0])>=3&&(i=!0),this._config.onMessage(this,a,{direction:"down-in",depIndex:t},this._actions);i&&this._maybeRunFnOnSettlement()})}catch(s){throw n.unsub=null,this._deps.pop(),this._dirtyDepCount--,s}return t}_deactivate(e=!1){let t=this._cleanup;if(this._cleanup=void 0,typeof t=="function")try{t()}catch(n){this._emit([[G,this._wrapFnError("cleanup threw",n)]])}else if(t!=null&&typeof t=="object"){let n=t.deactivate;if(typeof n=="function")try{n()}catch(s){this._emit([[G,this._wrapFnError("cleanup.deactivate threw",s)]])}}for(let n of this._deps){if(n.unsub!=null){let s=n.unsub;n.unsub=null;try{s()}catch{}}yt(n)}this._waveHasNewData=!1,this._hasNewTerminal=!1,this._hasCalledFnOnce=!1,this._paused=!1,this._pendingWave=!1,this._pendingRerun=!1,this._rerunDepth=0,this._store={},this._dirtyDepCount=0,this._pauseLocks=null,this._pauseBuffer=null,this._fn!=null&&(this._cached=void 0),e||(this._fn!=null||this._deps.length>0)&&(!this._isTerminal||this._resubscribable)&&(this._status="sentinel")}_onDepMessage(e,t){let n=this._deps[e],s=t[0];if(this._inspectorHooks!=null){let o={kind:"dep_message",depIndex:e,message:t};for(let i of this._inspectorHooks)i(o)}if(s!==Ae){if(s===Y){this._depDirtied(n);return}if(s===ie){if(this._depInvalidated(n),this._cached===void 0)return;this._emit(Pt);return}if(s===ce||s===fe){this._emit([t]);return}if(s===W){this._emit(pt);return}if(s===$)this._depSettledAsData(n,t[1]);else if(s===Q)this._depSettledAsResolved(n);else if(s===H)this._depSettledAsTerminal(n,!0);else if(s===G)this._depSettledAsTerminal(n,t[1]);else{this._emit([t]);return}if(!this._fn){(s===$||s===Q)&&this._emit([t]),(s===H||s===G)&&this._maybeAutoTerminalAfterWave();return}}}_depDirtied(e){e.dirty||(e.dirty=!0,e.involvedThisWave=!0,this._dirtyDepCount++,this._status!=="dirty"&&this._emit(ft))}_depSettledAsData(e,t){e.dirty&&(e.dirty=!1,this._dirtyDepCount--),e.involvedThisWave=!0,e.dataBatch.push(t),this._waveHasNewData=!0}_depSettledAsResolved(e){e.dirty&&(e.dirty=!1,this._dirtyDepCount--)}_depSettledAsTerminal(e,t){e.dirty&&(e.dirty=!1,this._dirtyDepCount--),e.terminal=t,e.involvedThisWave=!0,this._hasNewTerminal=!0}_depInvalidated(e){e.prevData=void 0,e.terminal=void 0,e.dataBatch.length=0,e.dirty?e.involvedThisWave=!1:(e.dirty=!0,e.involvedThisWave=!0,this._dirtyDepCount++)}_maybeRunFnOnSettlement(){if(!(this._isTerminal&&!this._resubscribable)&&!(this._dirtyDepCount>0)){if(!this._partial&&!this._hasCalledFnOnce)for(let e=0;e<this._deps.length;e++){let t=this._deps[e];if(t.dataBatch.length===0&&t.prevData===void 0&&t.terminal===void 0){this._maybeAutoTerminalAfterWave();return}}if(this._paused){this._pendingWave=!0;return}if(!this._waveHasNewData&&!this._hasNewTerminal&&this._hasCalledFnOnce){this._clearWaveFlags(),this._emit($t),this._maybeAutoTerminalAfterWave();return}this._fn&&this._execFn(),this._maybeAutoTerminalAfterWave()}}_maybeAutoTerminalAfterWave(){if(this._deps.length===0||this._isTerminal)return;let e=this._deps.find(t=>t.terminal!==void 0&&t.terminal!==!0);if(e!=null){this._autoError&&this._emit([[G,e.terminal]]);return}this._autoComplete&&this._deps.every(t=>t.terminal!==void 0)&&this._emit(Vt)}_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([[G,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([[G,this._wrapFnError("cleanup.beforeRun threw",a)]]);return}}}let t=this._deps.map(i=>i.involvedThisWave?i.dataBatch.length>0?[...i.dataBatch]:[]:void 0),n=this._deps.map(i=>i.prevData);for(let i=0;i<this._deps.length;i++){let a=t[i];a!=null&&a.length>0&&(this._deps[i].prevData=a[a.length-1])}let s=this._deps.map(i=>i.terminal),o={prevData:n,terminalDeps:s,store:this._store};if(this._hasCalledFnOnce=!0,this._clearWaveFlags(),this._inspectorHooks!=null){let i={kind:"run",batchData:t,prevData:n};for(let a of this._inspectorHooks)a(i)}this._isExecutingFn=!0;try{let i=this._fn(t,this._actions,o);if(typeof i=="function")this._cleanup=i;else if(i!=null&&typeof i=="object"){let a=i;(typeof a.beforeRun=="function"||typeof a.deactivate=="function"||typeof a.invalidate=="function")&&(this._cleanup=i)}}catch(i){this._emit([[G,this._wrapFnError("fn threw",i)]])}finally{this._isExecutingFn=!1,this._pendingRerun?(this._pendingRerun=!1,this._rerunDepth+=1,this._rerunDepth>Ht?(this._rerunDepth=0,this._emit([[G,new Error(`Node "${this.name}": _pendingRerun depth exceeded ${Ht} \u2014 likely a reactive cycle`)]])):this._maybeRunFnOnSettlement()):this._rerunDepth=0,this._clearWaveFlags()}}_clearWaveFlags(){this._waveHasNewData=!1,this._hasNewTerminal=!1;for(let e of this._deps)e.involvedThisWave=!1,e.dataBatch.length=0}_wrapFnError(e,t){let n=t instanceof Error?t.message:String(t);return new Error(`Node "${this.name}": ${e}: ${n}`,{cause:t})}_frameBatch(e){let t=this._config.tierOf;if(e.length===1)return t(e[0][0])===3&&this._status!=="dirty"?[Me,e[0]]:e;let n=!0,s=!1,o=!1,i=-1;for(let d of e){let u=t(d[0]);u<i&&(n=!1),u===3&&(s=!0),d[0]===Y&&(o=!0),i=u}let a=e;if(!n){let d=e.map((u,c)=>({m:u,i:c,tier:t(u[0])}));d.sort((u,c)=>u.tier-c.tier||u.i-c.i),a=d.map(u=>u.m)}if(s&&!o&&this._status!=="dirty"){let d=0;for(;d<a.length&&t(a[d][0])===0;)d++;return d===0?[Me,...a]:[...a.slice(0,d),Me,...a.slice(d)]}return a}_emit(e){if(e.length===0)return;for(let a=0;a<e.length;a++){let d=e[a];if(d[0]===G&&d[1]===void 0)throw new TypeError('[ERROR, payload] requires a non-undefined payload (spec \xA71.2). Pass an Error object or domain tag instead \u2014 e.g. node.down([[ERROR, new Error("reason")]])')}let t=e;if(this._isTerminal&&!this._resubscribable){let a=e.filter(d=>d[0]===W||d[0]===ie);if(a.length===0)return;t=a}t=this._frameBatch(t);let s=null;for(let a=0;a<t.length;a++){let d=t[a],u=d[0];if(u!==ce&&u!==fe){s?.push(d);continue}if(d.length<2)throw new Error(`Node "${this.name}": [[${u===ce?"PAUSE":"RESUME"}]] must carry a lockId payload \u2014 bare PAUSE/RESUME is a protocol violation (C0 rule). Use \`[[PAUSE, lockId]]\` / \`[[RESUME, lockId]]\`.`);let c=!0;if(this._pausable!==!1){let h=d[1];if(u===ce)this._pauseLocks==null&&(this._pauseLocks=new Set),this._pauseLocks.add(h),this._paused=!0,this._pausable==="resumeAll"&&this._pauseBuffer==null&&(this._pauseBuffer=[]);else if(this._pauseLocks==null||!this._pauseLocks.has(h))c=!1;else if(this._pauseLocks.delete(h),this._pauseLocks.size===0){if(this._paused=!1,this._pauseBuffer!=null&&this._pauseBuffer.length>0){let f=this._pauseBuffer;this._pauseBuffer=[],this._emit(f)}this._pendingWave&&(this._pendingWave=!1,this._maybeRunFnOnSettlement())}}c?s?.push(d):s==null&&(s=t.slice(0,a))}if(s!=null){if(s.length===0)return;t=s}if(this._hasMeta&&t.some(a=>a[0]===W))for(let a of Object.keys(this.meta))try{this.meta[a]._emit(pt)}catch{}let{finalMessages:o,equalsError:i}=this._updateState(t);if(o.length>0&&this._config.inspectorEnabled){let a=this._config.globalInspector;if(a!=null)try{a({kind:"emit",node:this,messages:o})}catch{}}if(o.length>0)if(this._paused&&this._pausable==="resumeAll"&&this._pauseBuffer!=null){let a=this._config.tierOf,d=[];for(let u of o)a(u[0])===3?this._pauseBuffer.push(u):d.push(u);d.length>0&&this._dispatchOrAccumulate(d)}else this._dispatchOrAccumulate(o);i!=null&&this._emit([[G,i]])}_updateState(e){let t=this._config.tierOf,n,s,o=-1,i=0;for(let c of e)t(c[0])===3&&i++;let a=i<=1,d=-1;if(this._versioning!=null&&i>1){for(let c=e.length-1;c>=0;c--)if(e[c][0]===$){d=c;break}}for(let c=0;c<e.length;c++){let h=e[c],f=h[0];if(f===$){if(h.length>=2){let p=!1;if(a&&this._cached!==void 0)try{p=this._equals(this._cached,h[1])}catch(l){s=this._wrapFnError("equals threw",l),o=c;break}if(p){n==null&&(n=e.slice(0,c)),n.push(ct),this._status="resolved";continue}this._cached=h[1],this._versioning!=null&&(d<0||c===d)&&jt(this._versioning,h[1],this._hashFn)}this._status="settled",n?.push(h)}else if(n?.push(h),f===Y)this._status="dirty";else if(f===Q)this._status="resolved";else if(f===H){this._status="completed";{let p=this._config.rigorRecorder;if(p!=null)try{p.onTerminalTransition(this,"completed",this._autoComplete,this._autoError,this._deps.length>0)}catch{}}}else if(f===G){this._status="errored";{let p=this._config.rigorRecorder;if(p!=null)try{p.onTerminalTransition(this,"errored",this._autoComplete,this._autoError,this._deps.length>0)}catch{}}}else if(f===ie){if(this._cached!==void 0){let l=this._config.rigorRecorder;if(l!=null)try{l.onNonVacuousInvalidate(this,this._cached)}catch{}}this._cached=void 0,this._status="dirty";let p=this._cleanup;if(typeof p=="function"){this._cleanup=void 0;try{p()}catch{}}else if(p!=null&&typeof p=="object"){let l=p.invalidate;if(typeof l=="function")try{l()}catch{}}}else f===W&&(this._resetOnTeardown&&(this._cached=void 0),this._deactivate(!0),this._status="sentinel")}let u=o>=0?n??e.slice(0,o):n??e;return s!=null?{finalMessages:u,equalsError:s}:{finalMessages:u}}_deliverToSinks=e=>{if(this._sinks==null)return;if(typeof this._sinks=="function"){this._sinks(e);return}let t=[...this._sinks];for(let n of t)n(e)};_dispatchOrAccumulate(e){if(It()){this._batchPendingMessages===null&&(this._batchPendingMessages=[],Se(()=>this._flushBatchPending()));for(let t of e)this._batchPendingMessages.push(t);return}qe(this._deliverToSinks,e,this._config.tierOf)}_flushBatchPending(){let e=this._batchPendingMessages;if(e===null||(this._batchPendingMessages=null,e.length===0))return;let t=this._frameBatch(e);qe(this._deliverToSinks,t,this._config.tierOf)}},Wt=r=>Array.isArray(r),vt=r=>typeof r=="object"&&r!=null&&!Array.isArray(r)});function X(r,e){return we([],{...e,initial:r})}function he(r,e){return we((n,s,o)=>r(s,o)??void 0,{describeKind:"producer",...e})}function B(r,e,t){return we(r,(s,o,i)=>{let a=s.map((d,u)=>d!=null&&d.length>0?d.at(-1):i.prevData[u]);o.emit(e(a,i))},{describeKind:"derived",...t})}function Yt(r,e,t){return we(r,(s,o,i)=>{let a=s.map((d,u)=>d!=null&&d.length>0?d.at(-1):i.prevData[u]);return e(a,o,i)??void 0},{describeKind:"effect",...t})}var xe=j(()=>{"use strict";Te()});function Jt(r,e,t){return{[r]:!0,[`${r}_type`]:e,...t??{}}}var Xt=j(()=>{"use strict"});function _t(r,e){if(e!=null&&e.length>0)return new Set(e);switch(r){case"standard":return new Set(["type","status","value","deps","meta","v"]);case"full":return null;case"spec":return new Set(["type","deps","meta","value"]);default:return new Set(["type","deps"])}}function Qn(r){return r._describeKind!=null?r._describeKind:r._deps.length>0?"derived":r._fn!=null?"producer":"state"}function er(r){let e={};for(let[t,n]of Object.entries(r.meta))try{e[t]=n.cache}catch{}return e}function wt(r,e,t){let n=e==null,s=!n&&e!=null?[...e].filter(c=>c.startsWith("meta.")).map(c=>c.slice(5)):null,o=n||e.has("meta")||s!=null&&s.length>0,i="state",a=[];r instanceof z&&(i=Qn(r),a=r._deps.map(c=>c.node.name??""));let d={type:i,deps:a};(n||e.has("status"))&&(d.status=r.status);let u=r instanceof z?r._guard:void 0;if(o){let c={...er(r)};if(u!=null&&c.access===void 0&&(c.access=ht(u)),s!=null&&s.length>0&&!e.has("meta")){let h={};for(let f of s)f in c&&(h[f]=c[f]);d.meta=h}else d.meta=c}if(r.name!=null&&(d.name=r.name),(n||e.has("value"))&&(!t||i==="state")){r.status==="sentinel"&&(d.sentinel=!0);try{d.value=r.cache}catch{}}if((n||e.has("v"))&&r.v!=null){let c={id:r.v.id,version:r.v.version};"cid"in r.v&&(c.cid=r.v.cid,c.prev=r.v.prev),d.v=c}return(n||e.has("guard"))&&u!=null&&(d.guard=ht(u)),(n||e.has("lastMutation"))&&r.lastMutation!=null&&(d.lastMutation=r.lastMutation),d}var Zt=j(()=>{"use strict";Ve();Te()});function Tt(r,e){if(Object.is(r,e))return!0;if(r==null||e==null||typeof r!="object"||typeof e!="object")return!1;if(Array.isArray(r)){if(!Array.isArray(e)||r.length!==e.length)return!1;for(let o=0;o<r.length;o++)if(!Tt(r[o],e[o]))return!1;return!0}if(Array.isArray(e))return!1;let t=Object.keys(r),n=Object.keys(e);if(t.length!==n.length)return!1;let s=new Set(n);for(let o of t)if(!s.has(o)||!Tt(r[o],e[o]))return!1;return!0}function Qt(r,e){return`${r}\0${e}`}function xt(r,e){let t=[],n=new Set(r.subgraphs),s=new Set(e.subgraphs),o=[];for(let g of s)n.has(g)||o.push(g);o.sort();for(let g of o)t.push({type:"subgraph-mounted",path:g});let i=new Set(Object.keys(r.nodes)),a=new Set(Object.keys(e.nodes)),d=[];for(let g of a)i.has(g)||d.push(g);d.sort();for(let g of d)t.push({type:"node-added",path:g,node:{...e.nodes[g]}});let u=[];for(let g of a){if(!i.has(g))continue;let k=r.nodes[g]?.meta,_=e.nodes[g]?.meta;k==null&&_==null||Tt(k??{},_??{})||u.push(g)}u.sort();for(let g of u)t.push({type:"node-meta-changed",path:g,prevMeta:r.nodes[g]?.meta??{},nextMeta:e.nodes[g]?.meta??{}});let c=new Map;for(let g of r.edges)c.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 f=[];for(let[g,k]of h)c.has(g)||f.push(k);f.sort((g,k)=>g.from<k.from?-1:g.from>k.from?1:g.to<k.to?-1:g.to>k.to?1:0);for(let g of f)t.push({type:"edge-added",from:g.from,to:g.to});let p=[];for(let[g,k]of c)h.has(g)||p.push(k);p.sort((g,k)=>g.from<k.from?-1:g.from>k.from?1:g.to<k.to?-1:g.to>k.to?1:0);for(let g of p)t.push({type:"edge-removed",from:g.from,to:g.to});let l=[];for(let g of i)a.has(g)||l.push(g);l.sort();for(let g of l)t.push({type:"node-removed",path:g});let v=[];for(let g of n)s.has(g)||v.push(g);v.sort();for(let g of v)t.push({type:"subgraph-unmounted",path:g});return{events:t,flushedAt_ns:K()}}var en=j(()=>{"use strict";be()});function We(r){return{describeKind:"producer",...r}}function tn(r,e){let{signal:t,period:n,...s}=e??{};return he(o=>{let i=!1,a=0,d,u,c=()=>{i=!0,d!==void 0&&clearTimeout(d),u!==void 0&&clearInterval(u),t?.removeEventListener("abort",f)},h=()=>{i||(n!=null?(o.emit(a++),u=setInterval(()=>{i||o.emit(a++)},n)):(i=!0,t?.removeEventListener("abort",f),o.emit(a++),o.down([[H]])))},f=()=>{i||(c(),o.down([[G,t.reason]]))};if(t?.aborted){f();return}return d=setTimeout(h,r),t?.addEventListener("abort",f,{once:!0}),c},We(s))}function nn(r,e){return he(t=>{let n=!1;try{for(let s of r){if(n)return;t.emit(s)}n||t.down([[H]])}catch(s){n||t.down([[G,s]])}return()=>{n=!0}},We(e))}function tr(r){return r!=null&&typeof r.then=="function"}function nr(r,e){let{signal:t,...n}=e??{};return he(s=>{let o=!1,i=()=>{o||(o=!0,s.down([[G,t.reason]]))};if(t?.aborted){i();return}return t?.addEventListener("abort",i,{once:!0}),Promise.resolve(r).then(a=>{o||(o=!0,t?.removeEventListener("abort",i),s.emit(a),s.down([[H]]))},a=>{o||(o=!0,t?.removeEventListener("abort",i),s.down([[G,a]]))}),()=>{o=!0,t?.removeEventListener("abort",i)}},We(n))}function rr(r,e){let{signal:t,...n}=e??{};return he(s=>{let o=new AbortController,i=()=>o.abort(t?.reason);t?.aborted?o.abort(t.reason):t?.addEventListener("abort",i,{once:!0});let a=t??o.signal,d=!1,u=r[Symbol.asyncIterator](),c=()=>{d||a.aborted||Promise.resolve(u.next()).then(h=>{if(!(d||a.aborted)){if(h.done){s.down([[H]]);return}s.emit(h.value),c()}},h=>{!d&&!a.aborted&&s.down([[G,h]])})};return c(),()=>{d=!0,t?.removeEventListener("abort",i),o.abort(),Promise.resolve(u.return?.()).catch(()=>{})}},We(n))}function sr(r){return r!=null&&typeof r=="object"&&"cache"in r&&typeof r.subscribe=="function"}function rn(r,e){if(sr(r))return r;if(tr(r))return nr(r,e);if(r!=null){let t=r;if(typeof t[Symbol.asyncIterator]=="function")return rr(r,e);if(typeof t[Symbol.iterator]=="function")return nn(r,e)}return or(r)}function or(...r){return nn(r,void 0)}function ae(r){return r.subscribe(()=>{})}var sn=j(()=>{"use strict";pe();xe()});var Nt=j(()=>{"use strict";sn()});var Ye,on=j(()=>{"use strict";Ye=class{_timer;_gen=0;start(e,t){this.cancel(),this._gen+=1;let n=this._gen;this._timer=setTimeout(()=>{this._timer=void 0,n===this._gen&&t()},e)}cancel(){this._timer!==void 0&&(clearTimeout(this._timer),this._timer=void 0)}get pending(){return this._timer!==void 0}}});var Fe,an=j(()=>{"use strict";Fe=class{constructor(e){this.capacity=e;if(!Number.isInteger(e)||e<=0)throw new Error(`RingBuffer capacity must be a positive integer (got ${e})`);this.buf=new Array(e)}buf;head=0;_size=0;get size(){return this._size}get maxSize(){return this.capacity}push(e){let t=(this.head+this._size)%this.capacity;this.buf[t]=e,this._size<this.capacity?this._size++:this.head=(this.head+1)%this.capacity}shift(){if(this._size===0)return;let e=this.buf[this.head];return this.buf[this.head]=void 0,this.head=(this.head+1)%this.capacity,this._size--,e}at(e){if(this._size===0)return;let t=e<0?this._size+e:e;if(!(t<0||t>=this._size))return this.buf[(this.head+t)%this.capacity]}toArray(){let e=new Array(this._size);for(let t=0;t<this._size;t++)e[t]=this.buf[(this.head+t)%this.capacity];return e}clear(){for(let e=0;e<this._size;e++)this.buf[(this.head+e)%this.capacity]=void 0;this.head=0,this._size=0}}});function dn(r,e,t,n={}){let s=e in r.nodes,o=t in r.nodes;if(!s)return Je(e,t,"no-such-from");if(!o)return Je(e,t,"no-such-to");let i=n.maxDepth;if(i!=null&&(!Number.isInteger(i)||i<0))throw new Error("explainPath: maxDepth must be an integer >= 0");if(e===t){if(n.findCycle===!0){let u=ir(r,e,n);if(u!=null)return u}let d=Xe(e,r.nodes[e],0,n);return Ze(e,t,[d])}if(i===0)return Je(e,t,"no-path");let a=un(r,e,t,i);return a.found?Ze(e,t,cn(r,a.pathOrder,n)):Je(e,t,a.truncated?"max-depth-exceeded":"no-path")}function un(r,e,t,n){let s=new Map,o=[{path:t,depth:0}],i=new Set([t]),a=0,d=!1;for(;a<o.length;){let h=o[a++];if(h.path===e)break;if(n!=null&&h.depth>=n){let v=r.nodes[h.path];v?.deps&&v.deps.length>0&&(d=!0);continue}let f=r.nodes[h.path];if(f==null)continue;let p=f.deps??[],l=new Map;for(let v=0;v<p.length;v++){let g=p[v];if(!g)continue;let k=l.get(g);k==null&&(k=[],l.set(g,k)),k.push(v)}for(let[v,g]of l)i.has(v)||(i.add(v),s.set(v,{from:h.path,depIndices:g}),o.push({path:v,depth:h.depth+1}))}if(!s.has(e))return{found:!1,pathOrder:[],truncated:d};let u=[{path:e}],c=e;for(;c!==t;){let h=s.get(c);if(h==null)return{found:!1,pathOrder:[],truncated:!1};u[u.length-1].depIndices=h.depIndices,u.push({path:h.from}),c=h.from}return{found:!0,pathOrder:u,truncated:!1}}function ir(r,e,t){let n=r.nodes[e];if(n==null)return null;let s=n.deps??[],o=[];for(let a=0;a<s.length;a++)s[a]===e&&o.push(a);if(o.length>0){let a=Xe(e,n,0,t);a.dep_index=o[0];let d=Xe(e,n,1,t);return Ze(e,e,[a,d])}let i=null;for(let a=0;a<s.length;a++){let d=s[a];if(!d||d===e)continue;let u=un(r,d,e,t.maxDepth);u.found&&(i==null||u.pathOrder.length<i.pathOrder.length)&&(i=u,i={found:!0,pathOrder:[{path:e,depIndices:[a]},...u.pathOrder],truncated:!1})}return i==null?null:Ze(e,e,cn(r,i.pathOrder,t))}function cn(r,e,t){return e.map((n,s)=>{let o=r.nodes[n.path],i=Xe(n.path,o,s,t);return n.depIndices!=null&&n.depIndices.length>0&&(i.dep_index=n.depIndices[0],n.depIndices.length>1&&(i.dep_indices=[...n.depIndices])),i})}function Xe(r,e,t,n){let s={path:r,type:e.type,hop:t};e.status!==void 0&&(s.status=e.status),"value"in e&&(s.value=e.value),e.v!=null&&(s.v=e.v);let o=n.annotations?.get(r)??e.annotation;o!=null&&(s.annotation=o);let i=n.lastMutations?.get(r)??e.lastMutation;return i!=null&&(s.lastMutation=i),s}function Ze(r,e,t){return ln(r,e,!0,"ok",t)}function Je(r,e,t){return ln(r,e,!1,t,[])}function ln(r,e,t,n,s){let o=ar(r,e,t,n,s);return{from:r,to:e,found:t,reason:n,steps:s,text:o,toJSON(){return{from:r,to:e,found:t,reason:n,steps:s}}}}function ar(r,e,t,n,s){if(!t)switch(n){case"no-such-from":return`explainPath: no node named "${r}"`;case"no-such-to":return`explainPath: no node named "${e}"`;case"max-depth-exceeded":return`explainPath: no path from "${r}" to "${e}" within maxDepth`;default:return`explainPath: no path from "${r}" to "${e}"`}let o=[`Causal path: ${r} \u2192 ${e} (${s.length} step(s))`];for(let i of s){let d=` ${i.hop===0?"\xB7":"\u2193"} ${i.path} (${i.type}${i.status?`/${i.status}`:""})`;if(o.push(d),"value"in i&&o.push(` value: ${dr(i.value)}`),i.annotation!=null&&o.push(` annotation: ${i.annotation}`),i.lastMutation!=null){let u=i.lastMutation.actor;o.push(` actor: ${u.type}${u.id?`:${u.id}`:""}`)}}return o.join(`
2
- `)}function dr(r){if(r===void 0)return"<sentinel>";if(r===null)return"null";if(typeof r=="string")return JSON.stringify(r);if(typeof r=="number"||typeof r=="boolean"||typeof r=="bigint")return String(r);try{let e=JSON.stringify(r);return e.length>80?`${e.slice(0,77)}...`:e}catch{return String(r)}}var fn=j(()=>{"use strict"});function pn(r){let e=new WeakSet,t=new WeakSet,n=[r],s=0;for(;n.length>0;){let o=n.pop();s+=cr(o,e,t,n)}return s}function cr(r,e,t,n){if(r==null)return 0;switch(typeof r){case"number":return U.number;case"boolean":return U.boolean;case"string":return U.string+r.length*2;case"bigint":return U.bigint+lr(r);case"symbol":return U.symbol;case"function":return e.has(r)?0:(e.add(r),U.function);case"undefined":return 0}let o=r;if(e.has(o))return 0;e.add(o);let i=o[ur];if(typeof i=="function")try{let u=i.call(o);if(typeof u=="number"&&Number.isFinite(u))return u}catch{}if(o instanceof Date)return U.date;if(o instanceof RegExp)return U.regexp+o.source.length*2;if(o instanceof Error){let u=o.message?o.message.length*2:0,c=o.stack?o.stack.length*2:0;return U.error+u+c}if(typeof URL<"u"&&o instanceof URL)return U.url+o.href.length*2;if(typeof Promise<"u"&&o instanceof Promise)return U.promise;if(o instanceof WeakMap)return U.weakmap;if(o instanceof WeakSet)return U.weakset;if(o instanceof Map){let u=U.map;for(let[c,h]of o)u+=U.mapEntry,n.push(c),n.push(h);return u}if(o instanceof Set){let u=U.set;for(let c of o)u+=U.setEntry,n.push(c);return u}if(Array.isArray(o)){let u=U.array+o.length*8;for(let c of o)n.push(c);return u}if(o instanceof ArrayBuffer)return t.has(o)?0:(t.add(o),o.byteLength);if(ArrayBuffer.isView(o)){let u=o;return t.has(u.buffer)?48:(t.add(u.buffer),u.buffer.byteLength+48)}let a=U.object,d=Object.keys(o);for(let u of d){a+=U.string+u.length*2;try{n.push(o[u])}catch{}}return a}function lr(r){let e=r<0n?-r:r;if(e===0n)return 0;let t=e.toString(2).length;return Math.ceil(t/32)*8}var U,ur,hn=j(()=>{"use strict";U={object:56,array:64,string:40,number:8,boolean:4,null:0,undefined:0,symbol:40,bigint:16,function:120,map:72,set:72,mapEntry:40,setEntry:24,date:24,regexp:48,error:64,url:80,promise:48,weakmap:40,weakset:40},ur=Symbol.for("sizeof")});function gn(r,e){let t=e?.topN??10,n=r.describe({detail:"standard"}),s=[],o=r._collectObserveTargets;typeof o=="function"&&o.call(r,"",s);let i=new Map;for(let[f,p]of s)i.set(f,p);let a=[];for(let[f,p]of Object.entries(n.nodes)){let l=i.get(f),v=l instanceof z?l:null,g=v?pn(v.cache):0,k=v?v._sinkCount:0,_=p.deps?.length??0,T=p.type==="effect"&&k===0,x=k===0?p.type==="effect"?"orphan-effect":p.type==="derived"?"idle-derived":p.type==="producer"?"idle-producer":null:null;a.push({path:f,type:p.type,status:p.status??"unknown",valueSizeBytes:g,subscriberCount:k,depCount:_,isOrphanEffect:T,orphanKind:x})}let d=a.reduce((f,p)=>f+p.valueSizeBytes,0),u=(f,p)=>[...a].sort(p??((l,v)=>v[f]-l[f])).slice(0,t),c=a.filter(f=>f.orphanKind!=null),h=a.filter(f=>f.isOrphanEffect);return{nodeCount:a.length,edgeCount:n.edges.length,subgraphCount:n.subgraphs.length,nodes:a,totalValueSizeBytes:d,hotspots:{byValueSize:u("valueSizeBytes"),bySubscriberCount:u("subscriberCount"),byDepCount:u("depCount")},orphans:c,orphanEffects:h}}var mn=j(()=>{"use strict";Te();hn()});function Qe(r,e){let t=Math.max(16,r.size*4),n=0;for(;r.size>0;){if(n++>=t){console.error(`[Graph "${e}".destroy] disposer drain exceeded cap (${t}); ${r.size} disposer(s) discarded`),r.clear();return}let s=r.values().next();if(s.done)return;let o=s.value;r.delete(o);try{o()}catch(i){console.error(`[Graph "${e}".destroy] disposer threw:`,i)}}}function Tn(r){return r!=null&&typeof r=="object"&&"cache"in r&&typeof r.subscribe=="function"&&typeof r.down=="function"}function fr(r){if(r!=null)return Tn(r)?r.cache:r}function Ne(r){return r!=null&&typeof r=="object"&&"cache"in r&&typeof r.subscribe=="function"&&typeof r.down=="function"}function ge(r){return Ne(r)?r.cache??"":r}function bn(r){return Ne(r)?r.cache??0:r}function yn(r){return Ne(r)?r.cache??!1:r}function pr(r){let e=[];for(let t of Object.keys(r).sort()){let n=r[t].v;n!=null&&e.push(`${t} ${n.id} ${n.version}`)}return e.join(`
3
- `)}function vn(r){if(r.version!==De)throw new Error(`unsupported snapshot version ${String(r.version)} (expected ${De})`);for(let e of["name","nodes","edges","subgraphs"])if(!(e in r))throw new Error(`snapshot missing required key "${e}"`);if(typeof r.name!="string")throw new TypeError("snapshot 'name' must be a string");if(typeof r.nodes!="object"||r.nodes===null||Array.isArray(r.nodes))throw new TypeError("snapshot 'nodes' must be an object");if(!Array.isArray(r.edges))throw new TypeError("snapshot 'edges' must be an array");if(!Array.isArray(r.subgraphs))throw new TypeError("snapshot 'subgraphs' must be an array")}function hr(r,e){let t=new WeakMap,n=(s,o)=>{if(Object.is(s,o))return!0;if(s==null||o==null||typeof s!="object"||typeof o!="object")return!1;let i=t.get(s);if(i==null&&(i=new WeakSet,t.set(s,i)),i.has(o))return!0;i.add(o);let a=s.constructor,d=o.constructor;if(a!==d)return!1;if(s instanceof Date)return s.getTime()===o.getTime();if(s instanceof RegExp)return s.source===o.source&&s.flags===o.flags;if(Array.isArray(s)){let f=o;if(s.length!==f.length)return!1;for(let p=0;p<s.length;p++)if(!n(s[p],f[p]))return!1;return!0}if(s instanceof Map){let f=o;if(s.size!==f.size)return!1;for(let[p,l]of s)if(!f.has(p)||!n(l,f.get(p)))return!1;return!0}if(s instanceof Set){let f=o;if(s.size!==f.size)return!1;for(let p of s){let l=!1;for(let v of f)if(n(p,v)){l=!0;break}if(!l)return!1}return!0}if(ArrayBuffer.isView(s)){let f=s,p=o;if(f.length!==p.length)return!1;for(let l=0;l<f.length;l++)if(f[l]!==p[l])return!1;return!0}let u=Object.keys(s),c=Object.keys(o);if(u.length!==c.length)return!1;let h=new Set(c);for(let f of u)if(!h.has(f)||!n(s[f],o[f]))return!1;return!0};return n(r,e)}function gr(r){return r.replace(/[.*+?^${}()|[\]\\]/g,"\\$&")}function et(r){let e="^";for(let t=0;t<r.length;t+=1){let n=r[t];if(n==="*"){e+=".*";continue}if(n==="?"){e+=".";continue}if(n==="["){let s=r.indexOf("]",t+1);if(s<=t+1){e+="\\[";continue}let o=r.slice(t+1,s);o.startsWith("!")&&(o=`^${o.slice(1)}`),o=o.replace(/\\/g,"\\\\"),e+=`[${o}]`,t=s;continue}e+=gr(n)}return e+="$",new RegExp(e)}function kt(r){if(typeof r=="string")return JSON.stringify(r);if(typeof r=="number"||typeof r=="boolean"||r==null)return String(r);try{return JSON.stringify(r)}catch{return"[unserializable]"}}function yr(r){return r==="none"?br:r==="ansi"||r==null?mr:{data:r.data??"",dirty:r.dirty??"",resolved:r.resolved??"",invalidate:r.invalidate??"",pause:r.pause??"",resume:r.resume??"",complete:r.complete??"",error:r.error??"",teardown:r.teardown??"",derived:r.derived??"",path:r.path??"",reset:r.reset??""}}function _n(r){if(r==null)return{};let e=r.detail;return e==="full"?{...r,structured:r.structured??!0,timeline:r.timeline??!0,causal:r.causal??!0,derived:r.derived??!0}:e==="minimal"?{...r,structured:r.structured??!0}:r.format==="stage-log"?{...r,structured:r.structured??!0,timeline:r.timeline??!0}:r}function vr(r,e,t){for(let n=0;n<r.length;n++){let s=r.charCodeAt(n);if(s<32||s===127)throw new Error(`Graph "${e}": ${t} "${r}" must not contain control character (U+${s.toString(16).padStart(4,"0").toUpperCase()} at index ${n})`)}}function Rt(r,e,t){if(r==="")throw new Error(`Graph "${e}": ${t} name must be non-empty`);if(r.includes(F))throw new Error(`Graph "${e}": ${t} "${r}" must not contain '${F}' (path separator)`);if(r===de)throw new Error(`Graph "${e}": ${t} name "${de}" is reserved for meta companion paths`);vr(r,e,t)}function _r(r,e){if(r==="")throw new Error(`Graph "${e}": resolve path must be non-empty`);let t=r.split(F);for(let n of t)if(n==="")throw new Error(`Graph "${e}": resolve path has empty segment`);return t}function wr(r,e){let t=!1;for(let s of r)if(!e.isMetaPassthrough(s[0])){t=!0;break}return t?r.filter(s=>e.isMetaPassthrough(s[0])):r}function xn(r){for(let e of r._mounts.values())xn(e);for(let e of r._nodes.values())try{e.down([[W]],{internal:!0})}catch{}}function Tr(r,e){let t=ke.diff(r,e),n={};for(let s of t.nodesAdded){let o=e.nodes[s];o!=null&&(n[s]=o)}return{...t,nodesAddedFull:n}}function wn(r,e,t,n={}){let s={paths:[],depths:new Map,truncated:!1};if(!e)return n.withDetail?s:[];if(!n.both&&t!=="upstream"&&t!=="downstream")throw new Error('reachable: direction must be "upstream" or "downstream"');let o=n.maxDepth;if(o!=null&&(!Number.isInteger(o)||o<0))throw new Error("reachable: maxDepth must be an integer >= 0");if(o===0)return n.withDetail?s:[];let i=new Map,a=new Map,d=new Map,u=new Map,c=new Set;for(let[T,x]of Object.entries(r.nodes)){if(!T)continue;c.add(T);let R=x.deps??[];i.set(T,R);for(let S of R)S&&(c.add(S),a.has(S)||a.set(S,new Set),a.get(S).add(T))}for(let T of r.edges){if(T==null||typeof T!="object")continue;let x=typeof T.from=="string"?T.from:"",R=typeof T.to=="string"?T.to:"";!x||!R||(c.add(x),c.add(R),u.has(x)||u.set(x,new Set),u.get(x).add(R),d.has(R)||d.set(R,new Set),d.get(R).add(x))}if(!c.has(e))return n.withDetail?s:[];let h=n.both===!0,f=T=>{if(h){let m=i.get(T)??[],b=d.get(T),y=a.get(T),N=u.get(T),w=[...m];return b&&w.push(...b),y&&w.push(...y),N&&w.push(...N),w}if(t==="upstream"){let m=i.get(T)??[],b=d.get(T);return b?[...m,...b]:m}let x=a.get(T),R=u.get(T),S=x?[...x]:[];return R&&S.push(...R),S},p=new Set([e]),l=new Map,v=[{path:e,depth:0}],g=0,k=!1;for(;g<v.length;){let T=v[g++];if(o!=null&&T.depth>=o){f(T.path).length>0&&(k=!0);continue}for(let x of f(T.path))!x||p.has(x)||(p.add(x),l.set(x,T.depth+1),v.push({path:x,depth:T.depth+1}))}let _=[...l.keys()].sort((T,x)=>T<x?-1:T>x?1:0);return n.withDetail?{paths:_,depths:l,truncated:k}:_}function xr(r,e){if(r.length!==e.length)return!1;for(let t=0;t<r.length;t++){let n=r[t],s=e[t];if(n.path!==s.path||n.type!==s.type||n.status!==s.status||n.hop!==s.hop||n.dep_index!==s.dep_index||n.annotation!==s.annotation||n.value!==s.value||n.lastMutation!==s.lastMutation)return!1;let o=n.v,i=s.v;if(o!==i&&(o==null||i==null||o.id!==i.id||o.version!==i.version))return!1}return!0}var F,de,De,mr,br,ke,Nn=j(()=>{"use strict";ut();Pe();be();Ve();pe();Zt();Te();xe();en();Nt();on();an();dt();fn();mn();F="::",de="__meta__",De=1;mr={data:"\x1B[32m",dirty:"\x1B[33m",resolved:"\x1B[36m",invalidate:"\x1B[93m",pause:"\x1B[90m",resume:"\x1B[96m",complete:"\x1B[34m",error:"\x1B[31m",teardown:"\x1B[91m",derived:"\x1B[35m",path:"\x1B[90m",reset:"\x1B[0m"},br={data:"",dirty:"",resolved:"",invalidate:"",pause:"",resume:"",complete:"",error:"",teardown:"",derived:"",path:"",reset:""};ke=class r{name;opts;config;_nodes=new Map;_nodeToName=new WeakMap;_mounts=new Map;_parent=void 0;_storageDisposers=new Set;_disposers=new Set;_destroyed=!1;_topology;_topologyEmitters=new Set;_factory;_factoryArgs;constructor(e,t){if(e==="")throw new Error("Graph name must be non-empty");if(e.includes(F))throw new Error(`Graph name must not contain '${F}' (got "${e}")`);if(e===de)throw new Error(`Graph name "${de}" is reserved for meta companion paths`);this.name=e,this.opts=Object.freeze({...t??{}}),this.config=t?.config??Ce,this._traceRing=new Fe(t?.traceCapacity??1e3),t?.versioning!=null&&this.setVersioning(t.versioning),typeof t?.factory=="string"&&(this._factory=t.factory,t.factoryArgs!==void 0&&(this._factoryArgs=t.factoryArgs))}tagFactory(e,t){return this._factory=e,this._factoryArgs=t,this}ancestors(e=!0){let t=[],n=e?this:this._parent;for(;n!=null;)t.push(n),n=n._parent;return t}get topology(){return this._topology==null&&(this._topology=he(e=>{let t=n=>{e.emit(n)};return this._topologyEmitters.add(t),()=>{this._topologyEmitters.delete(t)}},{name:`${this.name}_topology`})),this._topology}_emitTopology(e){if(!(this._topology==null||this._topologyEmitters.size===0))for(let t of this._topologyEmitters)t(e)}nameOf(e){return this._nodeToName.get(e)}add(e,t){let n=e.name,s=t?.name??n;if(s==null||s==="")throw new Error(`Graph "${this.name}": graph.add requires a non-empty name \u2014 pass via opts.name or set it on the node (e.g. state(0, { name: "x" }))`);let o=s,i=t?.annotation;if(Rt(o,this.name,"add"),this._mounts.has(o))throw new Error(`Graph "${this.name}": name "${o}" is already a mount point`);if(this._nodes.has(o))throw new Error(`Graph "${this.name}": node "${o}" already exists`);let a=this._nodeToName.get(e);if(a!==void 0)throw new Error(`Graph "${this.name}": node instance already registered as "${a}"`);return this._nodes.set(o,e),this._nodeToName.set(e,o),this._emitTopology({kind:"added",name:o,nodeKind:"node"}),i!=null&&(this._annotations.set(o,i),this.config.inspectorEnabled&&this._traceRing.push({path:o,annotation:i,timestamp_ns:K()})),e}setVersioning(e){if(e!=null)for(let t of this._nodes.values())t instanceof z&&t._applyVersioning(e)}remove(e){Rt(e,this.name,"remove");let t=this._mounts.get(e);if(t){let o={kind:"mount",nodes:[],mounts:[]},i=[];t._collectObserveTargets("",i);for(let[a,d]of i)a.includes(`${F}${de}${F}`)||o.nodes.push(a);return o.nodes.sort(),o.mounts.push(e),o.mounts.push(...t._collectSubgraphs(`${e}${F}`)),this._mounts.delete(e),t._parent=void 0,xn(t),this._emitTopology({kind:"removed",name:e,nodeKind:"mount",audit:o}),o}let n=this._nodes.get(e);if(!n)throw new Error(`Graph "${this.name}": unknown node or mount "${e}"`);this._nodes.delete(e),this._nodeToName.delete(n),n.down([[W]],{internal:!0});let s={kind:"node",nodes:[e],mounts:[]};return this._emitTopology({kind:"removed",name:e,nodeKind:"node",audit:s}),s}removeAll(e){let t=typeof e=="function"?e:(()=>{let o=et(e);return i=>o.test(i)})(),n={kind:"mount",nodes:[],mounts:[]},s=[...this._nodes.keys(),...this._mounts.keys()].filter(o=>t(o));for(let o of s){let i=this.remove(o);n.nodes.push(...i.nodes),n.mounts.push(...i.mounts)}return n.nodes.sort(),n.mounts.sort(),n}[Symbol.iterator](){let e=[...this._nodes.keys()].sort(),t=this._nodes,n=0;return{[Symbol.iterator](){return this},next(){if(n>=e.length)return{value:void 0,done:!0};let s=e[n++];return{value:[s,t.get(s)],done:!1}}}}node(e){if(e==="")throw new Error(`Graph "${this.name}": node name must be non-empty`);if(e.includes(F))return this.resolve(e);let t=this._nodes.get(e);if(!t)throw new Error(`Graph "${this.name}": unknown node "${e}"`);return t}get(e){return this.node(e).cache}set(e,t,n){let s=n?.internal===!0;this.node(e).down([[$,t]],{actor:n?.actor,internal:s,delivery:"write"})}setAll(e,t){let n=Symbol.iterator in e?e:Object.entries(e);_e(()=>{for(let[s,o]of n)this.set(s,o,t)})}invalidate(e,t){let n=t?.internal===!0;this.node(e).down([[ie]],{actor:t?.actor,internal:n,delivery:"write"})}error(e,t,n){let s=n?.internal===!0;this.node(e).down([[G,t]],{actor:n?.actor,internal:s,delivery:"write"})}complete(e,t){let n=t?.internal===!0;this.node(e).down([[H]],{actor:t?.actor,internal:n,delivery:"write"})}_registerSelfPruningKeepalive(e){let t,n,s=()=>{t?.(),t=void 0,n?.(),n=void 0};t=e.subscribe(o=>{for(let i of o){let a=i[0];if(a===W||a===H||a===G){s();return}}}),n=this.addDisposer(s)}_wireSignalToRemove(e,t){if(t==null)return;let n=()=>{try{this.remove(e)}catch{}};if(t.aborted){n();return}t.addEventListener("abort",n,{once:!0}),this.addDisposer(()=>t.removeEventListener("abort",n))}derived(e,t,n,s){let o=t.map(p=>this.resolve(p)),{keepAlive:i,annotation:a,equals:d,initial:u,meta:c,signal:h}=s??{},f=B(o,n,{name:e,...d!=null?{equals:d}:{},...u!==void 0?{initial:u}:{},...c!=null?{meta:c}:{}});return this.add(f,{name:e,...a!=null?{annotation:a}:{}}),i===!0&&this._registerSelfPruningKeepalive(f),this._wireSignalToRemove(e,h),f}effect(e,t,n,s){let o=t.map(c=>this.resolve(c)),{annotation:i,meta:a,signal:d}=s??{},u=Yt(o,n,{name:e,...a!=null?{meta:a}:{}});return this.add(u,{name:e,...i!=null?{annotation:i}:{}}),this._wireSignalToRemove(e,d),u}produce(e,t,n){if(t===void 0)throw new Error(`Graph "${this.name}".produce("${e}", \u2026): source must not be \`undefined\` \u2014 undefined is the global SENTINEL (spec \xA71.1). Pass \`null\` for nullary DATA, or a Promise/AsyncIterable/Iterable for async sources.`);if(t!==null&&typeof t=="object"&&"cache"in t&&typeof t.subscribe=="function")throw new Error(`Graph "${this.name}".produce("${e}", \u2026): Node sources are rejected. For Node\u2192Node, use graph.derived(name, [path], ([v]) => v, { keepAlive: true }) \u2014 fromAny passes Nodes through verbatim and silently drops opts.`);let{annotation:s,meta:o,equals:i,signal:a}=n??{},d=rn(t,{name:e,...o!=null?{meta:o}:{},...i!=null?{equals:i}:{},...a!=null?{signal:a}:{}});return this.add(d,{name:e,...s!=null?{annotation:s}:{}}),this._wireSignalToRemove(e,a),d}batch(e){_e(e)}edges(e){let t=e?.recursive===!0,n=new Map;if(!t){for(let[d,u]of this._nodes)n.set(u,d);let a=[];for(let[d,u]of this._nodes)if(u instanceof z)for(let c of u._deps){let h=n.get(c.node);h!=null&&a.push([h,d])}return a.sort((d,u)=>d[0]<u[0]?-1:d[0]>u[0]?1:d[1]<u[1]?-1:d[1]>u[1]?1:0),a}let s=[];this._collectObserveTargets("",s);let o=new Map;for(let[a,d]of s)o.set(d,a);let i=[];for(let[a,d]of s)if(d instanceof z)for(let u of d._deps){let c=o.get(u.node);c!=null&&i.push([c,a])}return i.sort((a,d)=>a[0]<d[0]?-1:a[0]>d[0]?1:a[1]<d[1]?-1:a[1]>d[1]?1:0),i}mount(e,t){if(t===void 0){let s=new r(e);return this.mount(e,s)}if(typeof t=="function"){let s=new r(e);return t(s),this.mount(e,s)}let n=t;if(Rt(e,this.name,"mount"),this._nodes.has(e))throw new Error(`Graph "${this.name}": cannot mount at "${e}" \u2014 node with that name exists`);if(this._mounts.has(e))throw new Error(`Graph "${this.name}": mount "${e}" already exists`);if(n===this)throw new Error(`Graph "${this.name}": cannot mount a graph into itself`);if(n._parent!=null)throw new Error(`Graph "${this.name}": this child graph is already mounted on "${n._parent.name}"`);for(let s=this;s!=null;s=s._parent)if(s===n)throw new Error(`Graph "${this.name}": mount("${e}", \u2026) would create a mount cycle`);return this._mounts.set(e,n),n._parent=this,this._emitTopology({kind:"added",name:e,nodeKind:"mount"}),n}resolve(e){let t=_r(e,this.name);return this._resolveFromSegments(t)}tryResolve(e){try{return this.resolve(e)}catch{return}}_resolveFromSegments(e){let t=e;if(t[0]===this.name&&(t=t.slice(1),t.length===0))throw new Error(`Graph "${this.name}": resolve path ends at graph name only`);let n=t[0],s=t.slice(1);if(s.length===0){let a=this._nodes.get(n);if(a)return a;throw this._mounts.has(n)?new Error(`Graph "${this.name}": path ends at subgraph "${n}" \u2014 not a node (GRAPHREFLY-SPEC \xA73.5)`):new Error(`Graph "${this.name}": unknown name "${n}"`)}let o=this._nodes.get(n);if(o&&s.length>0&&s[0]===de)return this._resolveMetaChainFromNode(o,s,t.join(F));let i=this._mounts.get(n);if(!i)throw this._nodes.has(n)?new Error(`Graph "${this.name}": "${n}" is a node; trailing path "${s.join(F)}" is invalid`):new Error(`Graph "${this.name}": unknown mount or node "${n}"`);return i.resolve(s.join(F))}_resolveMetaChainFromNode(e,t,n){let s=e,o=0,i=[...t];for(;o<i.length;){if(i[o]!==de)throw new Error(`Graph "${this.name}": expected ${de} segment in meta path "${n}"`);if(o+1>=i.length)throw new Error(`Graph "${this.name}": meta path requires a key after ${de} in "${n}"`);let a=i[o+1],d=s.meta[a];if(!d)throw new Error(`Graph "${this.name}": unknown meta "${a}" in path "${n}"`);s=d,o+=2}return s}signal(e,t){if(t?.internal!==!0){for(let s of e)if(this.config.messageTier(s[0])===3)throw new Error(`Graph "${this.name}": Graph.signal() rejects tier-3 messages (DATA / RESOLVED). Broadcast is for control-plane tiers (START / DIRTY / INVALIDATE / PAUSE / RESUME / COMPLETE / ERROR / TEARDOWN). For per-node value writes, use Graph.set or graph.node(name).down(...).`)}let n=[];if(this._signalDeliver(e,t??{},new Set,n),n.length>0)throw n[0]}_signalDeliver(e,t,n,s){for(let d of this._mounts.values())d._signalDeliver(e,t,n,s);let i=t.internal===!0?{internal:!0}:{actor:t.actor,delivery:"signal"},a=wr(e,this.config);for(let d of[...this._nodes.keys()].sort()){let u=this._nodes.get(d);if(!n.has(u)){n.add(u);try{u.down(e,i)}catch(c){if(c instanceof re)throw c;s.push(c)}a.length!==0&&this._signalMetaSubtree(u,a,n,i,s)}}}_signalMetaSubtree(e,t,n,s,o){for(let i of Object.keys(e.meta).sort()){let a=e.meta[i];if(!n.has(a)){n.add(a);try{a.down(t,s)}catch(d){if(d instanceof re)throw d;o.push(d)}this._signalMetaSubtree(a,t,n,s,o)}}}describe(e){if(e?.reactive==="diff")return this._describeReactiveDiff(e);if(e?.reactive===!0)return this._describeReactive(e);let t=fr(e?.actor),n=e?.filter;if(e?.detail!=null&&e?.fields!=null)throw new TypeError("Graph.describe(): pass either `detail` or `fields`, not both. `detail: 'spec'` is the canonical spec projection; use `fields` only when you need a custom subset.");let s=_t(e?.detail,e?.fields),o=e?.detail==="spec",i=s,a=[];this._collectObserveTargets("",a);let d=new Map;for(let[x,R]of a)d.set(R,x);let u=[];{let x=a.map(([,m])=>m),R=new Set(d.values()),S=0;for(;x.length>0;){let m=x.shift();if(m instanceof z)for(let b of m._deps){let y=b.node;if(d.has(y))continue;let N=y.name??"",w=N;if(!w||R.has(w))if(N){let A=2;for(;R.has(`${N}#${A}`);)A++;w=`${N}#${A}`}else for(w=`__internal__/${S++}`;R.has(w);)w=`__internal__/${S++}`;d.set(y,w),R.add(w),u.push([w,y]),x.push(y)}}}let c=[...a,...u],h={};for(let[x,R]of c){if(t!=null&&!R.allowsObserve(t))continue;let S=wt(R,i,o),m=R instanceof z?R._deps.map(w=>d.get(w.node)??w.node.name??""):[],{name:b,...y}=S,N={...y,deps:m};if(!o){let w=this._annotations.get(x);w!=null&&(N.annotation=w)}if(n!=null)if(typeof n=="function"){let w=n;if(!(w.length>=2?w(x,N):w(N)))continue}else{let w=!0;for(let[A,E]of Object.entries(n)){let O=A==="deps_includes"?"depsIncludes":A==="meta_has"?"metaHas":A;if(O==="depsIncludes"){if(!N.deps.includes(String(E))){w=!1;break}continue}if(O==="metaHas"){if(!Object.hasOwn(N.meta??{},String(E))){w=!1;break}continue}if(N[O]!==E){w=!1;break}}if(!w)continue}h[x]=N}let f=new Set(Object.keys(h)),p=[];for(let[x,R]of c)if(R instanceof z)for(let S of R._deps){let m=d.get(S.node);m!=null&&p.push([m,x])}p.sort((x,R)=>x[0]<R[0]?-1:x[0]>R[0]?1:x[1]<R[1]?-1:x[1]>R[1]?1:0);let l=p.map(([x,R])=>({from:x,to:R}));(t!=null||n!=null)&&(l=l.filter(x=>f.has(x.from)&&f.has(x.to)));let v=this._collectSubgraphs(""),g=t!=null||n!=null?v.filter(x=>{let R=`${x}${F}`;return[...f].some(S=>S===x||S.startsWith(R))}):v,k=this,_=e;return{name:this.name,nodes:h,edges:l,subgraphs:g,...this._factory!==void 0?{factory:this._factory}:{},...this._factoryArgs!==void 0?{factoryArgs:this._factoryArgs}:{},expand(x){let R={..._};return Array.isArray(x)?(R.fields=x,R.detail=void 0):(R.detail=x,R.fields=void 0),k.describe(R)}}}_collectSubgraphs(e){let t=[];for(let n of[...this._mounts.keys()].sort()){let s=e===""?n:`${e}${n}`;t.push(s),t.push(...this._mounts.get(n)._collectSubgraphs(`${s}${F}`))}return t}resourceProfile(e){return gn(this,e)}reachable(e,t,n={}){return n.withDetail===!0?wn(this.describe(),e,t,{...n,withDetail:!0}):wn(this.describe(),e,t,n)}explain(e,t,n){return n?.reactive===!0?this._explainReactive(e,t,n):this._explainStatic(ge(e),ge(t),{...n?.maxDepth!==void 0?{maxDepth:bn(n.maxDepth)}:{},...n?.findCycle!==void 0?{findCycle:yn(n.findCycle)}:{}})}_explainStatic(e,t,n){let s=this.describe({detail:"full"}),o=new Map(this._annotations),i=new Map;for(let[a,d]of Object.entries(s.nodes))d.lastMutation!=null&&i.set(a,d.lastMutation);return dn(s,e,t,{...n?.maxDepth!=null?{maxDepth:n.maxDepth}:{},...n?.findCycle===!0?{findCycle:!0}:{},annotations:o,lastMutations:i})}_describeReactive(e){let t={...e,reactive:!1},n=e.reactiveName??"describe",s=0,o=X(s,{name:`${n}_version`}),i=this.observe({timeline:!0,structured:!0}),a=!1,d=!1,u=()=>{a||d||(a=!0,Se(()=>{a=!1,!d&&(s+=1,o.emit(s))}))},c=i.onEvent(_=>{let T=_.type;T!=="data"&&T!=="error"&&T!=="complete"&&T!=="teardown"||u()}),h=[],f=new WeakSet,p=_=>{if(f.has(_)||d)return;f.add(_);let T=_.topology.subscribe(x=>{for(let R of x){if(R[0]!==$)continue;let S=R[1];if(u(),S.kind==="added"&&S.nodeKind==="mount"){let m=_._mounts.get(S.name);m!=null&&p(m)}}});h.push(T);for(let x of _._mounts.keys()){let R=_._mounts.get(x);R!=null&&p(R)}};p(this);let l,v=e.actor;Tn(v)&&(l=v.subscribe(_=>{let T=!1,x=!1;for(let R of _){let S=R[0];S===$?T=!0:(S===H||S===G||S===W)&&(x=!0)}T&&u(),x&&(l?.(),l=void 0,u())}));let g;try{g=B([o],()=>this.describe(t),{name:n,describeKind:"derived",meta:{domain:"audit",kind:"describe"},equals:(_,T)=>_===T})}catch(_){c(),l?.();for(let T of h)T();throw i.dispose(),_}let k=ae(g);return{node:g,dispose(){d=!0,c(),l?.();for(let _ of h)_();h.length=0,i.dispose(),k()}}}_describeReactiveDiff(e){let t={...e,reactive:!1},n=e.reactiveName??"describe-diff",s={name:this.name,nodes:{},edges:[],subgraphs:[]},o=this.describe(t),i=xt(s,o),a=X(i,{name:n,meta:{domain:"audit",kind:"describe-diff"},equals:(f,p)=>f===p}),d=this._describeReactive({...e,reactiveName:void 0}),u=!1,c=d.node.subscribe(f=>{if(!u)for(let p of f){if(p[0]!==$)continue;let l=p[1],v=xt(o,l);o=l,v.events.length!==0&&a.emit(v)}}),h=ae(a);return{node:a,dispose(){u=!0,c(),d.dispose(),a.down([[W,"describe-diff disposed"]]),h()}}}_explainReactive(e,t,n){let s=0,o=X(s,{name:"explain_version"}),i=this.observe({timeline:!0,structured:!0}),a=!1,d=!1,u=()=>{a||d||(a=!0,Se(()=>{a=!1,!d&&(s+=1,o.emit(s))}))},c=i.onEvent(_=>{let T=_.type;T!=="data"&&T!=="error"&&T!=="complete"&&T!=="teardown"||u()}),h=[];e!=null&&Ne(e)&&h.push(e),t!=null&&Ne(t)&&h.push(t),n?.maxDepth!=null&&Ne(n.maxDepth)&&h.push(n.maxDepth),n?.findCycle!=null&&Ne(n.findCycle)&&h.push(n.findCycle);let f=()=>{for(let _ of h)if(_.cache===void 0)return!1;return!0},p=()=>{let _=ge(e),T=ge(t);return{from:_,to:T,found:!1,reason:"pending",steps:[],text:"(awaiting reactive args)",toJSON:()=>({from:_,to:T,found:!1,reason:"pending",steps:[]})}},l;try{l=B([o],()=>{if(!f())return p();let _=ge(e),T=ge(t),x={...n?.maxDepth!==void 0?{maxDepth:bn(n.maxDepth)}:{},...n?.findCycle!==void 0?{findCycle:yn(n.findCycle)}:{}};return this._explainStatic(_,T,x)},{name:n?.name??"explain",describeKind:"derived",meta:{domain:"audit",kind:"explain_path",from:ge(e),to:ge(t)},equals:(_,T)=>_.found===T.found&&_.reason===T.reason&&_.steps.length===T.steps.length&&xr(_.steps,T.steps)})}catch(_){throw c(),i.dispose(),_}let v=ae(l),g=[],k=_=>{let T;return T=_.subscribe(x=>{let R=!1,S=!1;for(let m of x){let b=m[0];b===$?R=!0:(b===H||b===G||b===W)&&(S=!0)}(R||S)&&u(),S&&T&&(T(),T=void 0)}),()=>{T&&(T(),T=void 0)}};for(let _ of h)g.push(k(_));return{node:l,dispose(){d=!0,c();for(let _ of g)_?.();g.length=0,i.dispose(),v()}}}_pathsMatching(e){let t=et(e),n=[];return this._collectObserveTargets("",n),n.map(([s])=>s).filter(s=>t.test(s))}_collectObserveTargets(e,t){for(let n of[...this._mounts.keys()].sort()){let s=e===""?n:`${e}${F}${n}`;this._mounts.get(n)._collectObserveTargets(s,t)}for(let n of[...this._nodes.keys()].sort()){let s=this._nodes.get(n),o=e===""?n:`${e}${F}${n}`;t.push([o,s]),this._appendMetaObserveTargets(o,s,t)}}_appendMetaObserveTargets(e,t,n){for(let s of Object.keys(t.meta).sort()){let o=t.meta[s],i=`${e}${F}${de}${F}${s}`;n.push([i,o]),this._appendMetaObserveTargets(i,o,n)}}observe(e,t){let n=typeof e=="string",o=_n(n?t:e);if(o.reactive===!0)return this._observeReactive(n?e:void 0,o);let i=o.structured===!0||o.timeline===!0||o.causal===!0||o.derived===!0||o.detail==="minimal"||o.detail==="full"||o.format!=null,a=o.actor;if(n){let c=e,h=this.resolve(c);if(a!=null&&!h.allowsObserve(a))throw new re({actor:a,action:"observe",nodeName:c});return i?this._buildStructuredObserver([[c,h]],o,"one"):{subscribe(f){return h.subscribe(f)},up(f){try{h.up?.(f)}catch(p){if(p instanceof re)return;throw p}}}}let d=[];this._collectObserveTargets("",d),d.sort((c,h)=>c[0]<h[0]?-1:c[0]>h[0]?1:0);let u=a==null?d:d.filter(([,c])=>c.allowsObserve(a));return i?this._buildStructuredObserver(u,o,"all"):{subscribe:c=>{let h=u.map(([f,p])=>p.subscribe(l=>{c(f,l)}));return()=>{for(let f of h)f()}},up:(c,h)=>{try{this.resolve(c).up?.(h)}catch(f){if(f instanceof re)return;throw f}}}}_observeReactive(e,t){let n=t.tiers,s=n!=null?new Set(n):null,o=t.reactiveName??"observe";return he(i=>{let a=[],d=!1,u=!1,c=()=>{if(a.length===0||u)return;let v={events:a.slice(),flushedAt_ns:K()};a.length=0,i.emit(v)},h={...t,reactive:!1,structured:!0,timeline:!0},f=e!=null?this.observe(e,h):this.observe(h),p=v=>{u||(a.push(v),!d&&(d=!0,Se(()=>{d=!1,c()})))};for(let v of f.events)p(v);let l=f.onEvent(p);return()=>{u=!0,l(),f.dispose()}},{name:o,meta:{domain:"audit",kind:"observe-reactive"}})}_buildStructuredObserver(e,t,n){let s=n==="one"?e[0]?.[0]:void 0,o=i=>{if(n==="one"&&s!=null){let c=this.resolve(s);return this._buildStructuredObserver([[s,c]],i,"one")}let a=[];this._collectObserveTargets("",a),a.sort((c,h)=>c[0]<h[0]?-1:c[0]>h[0]?1:0);let d=i.actor,u=d==null?a:a.filter(([,c])=>c.allowsObserve(d));return this._buildStructuredObserver(u,i,"all")};return this._createObserveResult(e,t,o)}_createObserveResult(e,t,n){let s=t.timeline===!0,o=t.causal===!0,i=t.derived===!0,a=t.detail==="minimal",d=this.config.inspectorEnabled,u=(o||i)&&d,c=t.maxEvents,h=c!=null&&c>0?new Fe(c):null,f=[],p=new Set,l=t.tiers!=null?new Set(t.tiers):null,v={},g=new Set,k=0,_=0,T=0,x=0,R=0,S=0,m=!1,b=!1,y=0,N=new Map,w=new Map,A=new Map,E=M=>{if(!(l!=null&&!l.has(M.type))){h?h.push(M):f.push(M);for(let V of p)V(M)}},O=M=>l==null||l.has(M),C=()=>s?{timestamp_ns:K(),in_batch:Be(),batch_id:y}:{},D=(M,V)=>{if(!(!u||!(M instanceof z)))return M._setInspectorHook(te=>{if(te.kind==="dep_message")N.set(M,te.depIndex);else if(te.kind==="run"){let Ge=te.batchData.map((I,Z)=>I!=null&&I.length>0?I.at(-1):te.prevData[Z]);w.set(M,Ge);let ne=te.batchData.map(I=>I!=null?[...I]:void 0);A.set(M,ne),i&&E({type:"derived",path:V,dep_values:Ge,dep_batches:ne,...C()})}})},P=M=>{let V=N.get(M),te=w.get(M);if(!o||te==null)return{};let ne=(V!=null&&V>=0&&M instanceof z?M._deps[V]:void 0)?.node,I=ne?.v,Z=A.get(M);return{trigger_dep_index:V,trigger_dep_name:ne?.name,...I!=null?{trigger_version:{id:I.id,version:I.version}}:{},dep_values:[...te],...Z!=null?{dep_batches:Z}:{}}},L=[],q=[];for(let[M,V]of e){let te=D(V,M);te&&L.push(te),q.push(V.subscribe(Ge=>{y++;for(let ne of Ge){let I=ne[0],Z=C();if(I===$){v[M]=ne[1];let ot=V instanceof z?V.lastMutation?.actor??Re:Re;E({type:"data",path:M,data:ne[1],actor:ot,...Z,...P(V)})}else if(a)I===Y?O("dirty")&&k++:I===Q?O("resolved")&&_++:I===ie?O("invalidate")&&T++:I===ce?O("pause")&&x++:I===fe?O("resume")&&R++:I===W?O("teardown")&&S++:I===H&&!g.has(M)?O("complete")&&(m=!0):I===G&&O("error")&&(b=!0,g.add(M));else if(I===Y)O("dirty")&&k++,E({type:"dirty",path:M,...Z});else if(I===Q)O("resolved")&&_++,E({type:"resolved",path:M,...Z,...P(V)});else if(I===ie)O("invalidate")&&T++,E({type:"invalidate",path:M,...Z});else if(I===ce)O("pause")&&x++,E({type:"pause",path:M,lockId:ne[1],...Z});else if(I===fe)O("resume")&&R++,E({type:"resume",path:M,lockId:ne[1],...Z});else if(I===H)O("complete")&&!g.has(M)&&(m=!0),E({type:"complete",path:M,...Z});else if(I===G){O("error")&&(b=!0,g.add(M));let ot=V instanceof z?V.lastMutation?.actor??Re:Re;E({type:"error",path:M,data:ne[1],actor:ot,...Z})}else I===W&&(O("teardown")&&S++,E({type:"teardown",path:M,...Z}))}}))}let oe=!1,me=()=>{if(!oe){oe=!0;for(let M of q)M();for(let M of L)M();for(let M of ue)M({value:void 0,done:!0});ue.length=0}},J=[],ue=[];p.add(M=>{let V=ue.shift();V?V({value:M,done:!1}):J.push(M)});let At={get values(){return v},get dirtyCount(){return k},get resolvedCount(){return _},get invalidateCount(){return T},get pauseCount(){return x},get resumeCount(){return R},get teardownCount(){return S},get events(){return h?h.toArray():[...f]},get anyCompletedCleanly(){return m},get anyErrored(){return b},get completedWithoutErrors(){return m&&!b},onEvent(M){return p.add(M),()=>p.delete(M)},dispose:me,expand(M){me();let V={...t};return typeof M=="string"?V.detail=M:Object.assign(V,M),n(_n(V))},[Symbol.asyncIterator](){return{next(){return J.length>0?Promise.resolve({value:J.shift(),done:!1}):oe?Promise.resolve({value:void 0,done:!0}):new Promise(M=>ue.push(M))},return(){return me(),Promise.resolve({value:void 0,done:!0})}}}};return t.format!=null&&this._attachFormatLogger(At,t),At}_attachFormatLogger(e,t){let n=t.format;if(n==null)return;let s=t.logger??(l=>console.log(l)),o=t.includeTypes?new Set(t.includeTypes):null,i=t.excludeTypes?new Set(t.excludeTypes):null,a=o==null&&i==null?()=>!0:l=>(o==null||o.has(l))&&(i==null||!i.has(l)),d=yr(t.theme),u=n==="stage-log"?K():0,c=l=>l==null?"":t.stageLabels?.[l]??l,h=(l,v)=>l.length>v?`${l.slice(0,v-1)}\u2026`:l,f=l=>l.type==="data"||l.type==="error"?h(kt(l.data),120):"",p=l=>{if(n==="stage-log"){let m=(K()-u)/1e9,b=c(l.path).padEnd(9);if(l.type==="data"){let y=f(l);return`[${m.toFixed(3)}s] ${b} \u2190${y?` ${y}`:""}`}if(l.type==="error"){let y=f(l);return`[${m.toFixed(3)}s] ${b} \u2717${y?` ${y}`:""}`}return l.type==="complete"?`[${m.toFixed(3)}s] ${b} \u25A0 complete`:`[${m.toFixed(3)}s] ${b} ${l.type}`}if(n==="json")try{return JSON.stringify(l)}catch{return JSON.stringify({type:l.type,path:l.path,data:"[unserializable]"})}let v=d[l.type]??"",g=l.path?`${d.path}${l.path}${d.reset} `:"",k=l.type==="data"||l.type==="error",_=l.type==="pause"||l.type==="resume",T=k?` ${kt(l.data)}`:_?` ${kt(l.lockId)}`:"",x=l.type==="data"||l.type==="resolved"||l.type==="derived"?l:void 0,R=x?.trigger_dep_name!=null?` <- ${x.trigger_dep_name}`:x?.trigger_dep_index!=null?` <- #${x.trigger_dep_index}`:"",S=l.in_batch?" [batch]":"";return`${g}${v}${l.type.toUpperCase()}${d.reset}${T}${R}${S}`};e.onEvent(l=>{a(l.type)&&s(p(l),l)})}addDisposer(e){return this._disposers.add(e),()=>{this._disposers.delete(e)}}destroy(){Qe(this._disposers,this.name),this.signal([[W]],{internal:!0}),Qe(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(){Qe(this._disposers,this.name),Qe(this._storageDisposers,this.name);for(let e of[...this._mounts.values()])e._parent=void 0,e._destroyClearOnly();this._mounts.clear(),this._nodes.clear(),this._parent=void 0,this._destroyed=!0}snapshot(e){let{expand:t,...n}=this.describe({detail:"full"}),s={};for(let a of Object.keys(n.nodes).sort()){let{lastMutation:d,guard:u,...c}=n.nodes[a];s[a]=c}let o=[...n.subgraphs].sort(),i={...n,version:1,nodes:s,subgraphs:o};if(e?.format==null)return i;if(e.format==="json-string")return JSON.stringify(i);if(e.format==="bytes"){if(e.codec==null)throw new Error("snapshot({format: 'bytes'}) requires a `codec` name");let a=this.config.lookupCodec(e.codec);if(a==null)throw new Error(`snapshot: codec "${e.codec}" is not registered on this graph's config. Call config.registerCodec(...) before creating nodes.`);return Ct(a,a.encode(i))}throw new Error(`snapshot: unknown format "${String(e.format)}"`)}static decode(e,t){let n=t?.config??Ce,{codec:s,codecVersion:o,payload:i}=Dt(e,n);return s.decode(i,o)}restore(e,t){if(vn(e),e.name!==this.name)throw new Error(`Graph "${this.name}": restore snapshot name "${e.name}" does not match this graph`);let n=t?.only==null?null:(Array.isArray(t.only)?t.only:[t.only]).map(o=>et(o)),s=t?.includeProducers===!0;for(let o of Object.keys(e.nodes).sort()){if(n!==null&&!n.some(a=>a.test(o)))continue;let i=e.nodes[o];if(i!==void 0){if(!("value"in i)||i.value===void 0){"value"in i&&i.value===void 0&&t?.onError?.(o,new Error(`restore: slice.value is undefined for "${o}" (undefined is the global SENTINEL; not valid DATA)`));continue}if(!(i.type==="derived"||i.type==="effect")&&!(i.type==="producer"&&!s)){if(i.v!=null){let d=this.tryResolve(o)?.v;if(d!=null&&d.id===i.v.id&&d.version===i.v.version)continue}try{this.set(o,i.value)}catch(a){t?.onError?.(o,a)}}}}}static fromSnapshot(e,t){vn(e);let n=typeof t=="function"?t:t?.build,s=typeof t=="function"?void 0:t?.factories,o=new r(e.name);if(n)return n(o),o.restore(e),o;for(let p of[...e.subgraphs].sort((l,v)=>{let g=l.split(F).length,k=v.split(F).length;return g!==k?g-k:l<v?-1:l>v?1:0})){let l=p.split(F),v=o;for(let g of l)v._mounts.has(g)||v.mount(g,new r(g)),v=v._mounts.get(g)}let i=s?Object.entries(s).map(([p,l])=>({re:et(p),factory:l})):[],a=p=>{for(let l of i)if(l.re.test(p))return l.factory},d=p=>{let l=p.split(F),v=l.pop();if(v==null||v.length===0)throw new Error(`invalid snapshot path "${p}"`);let g=o;for(let k of l){let _=g._mounts.get(k);if(!_)throw new Error(`unknown mount "${k}" in path "${p}"`);g=_}return[g,v]},u=Object.entries(e.nodes).filter(([p])=>!p.includes(`${F}${de}${F}`)).sort((p,l)=>p[0]<l[0]?-1:p[0]>l[0]?1:0),c=new Map(u),h=new Map,f=!0;for(;c.size>0&&f;){f=!1;for(let[p,l]of[...c.entries()]){let v=l?.deps??[];if(!v.every(R=>h.has(R)))continue;let[g,k]=d(p),_={...l?.meta??{}},T=a(p),x;if(l?.type==="state")x=X(l.value,{meta:_});else{if(T==null)continue;x=T(k,{path:p,type:l.type,value:l.value,meta:_,deps:v,resolvedDeps:v.map(R=>h.get(R))})}g.add(x,{name:k}),h.set(p,x),c.delete(p),f=!0}}if(c.size>0){let p=[...c.keys()].sort().join(", ");throw new Error(`Graph.fromSnapshot could not reconstruct nodes without build callback: ${p}. Pass matching factories via fromSnapshot(data, { factories: { pattern: factoryFn } }).`)}return o.restore(e),o}toJSON(){return this.snapshot()}attachSnapshotStorage(e,t={}){let n=e.map(u=>({tier:u,debounceMs:Math.max(0,u.debounceMs??0),compactEvery:Math.max(1,u.compactEvery??10),timer:void 0,seq:0,lastSnapshot:void 0,lastFingerprint:"",disposed:!1,savePending:void 0}));t.autoRestore===!0&&this._cascadeRestore(e,t.onError);let s=(u,c)=>{if(u.disposed)return;let h=pr(c.nodes);if(u.lastSnapshot!=null&&h!==""&&h===u.lastFingerprint)return;let f=u.seq+1,p=le(),g=u.lastSnapshot==null||f%u.compactEvery===0?{name:this.name,mode:"full",snapshot:c,seq:f,timestamp_ns:p,format_version:De}:{name:this.name,mode:"diff",diff:Tr(u.lastSnapshot,c),seq:f,timestamp_ns:p,format_version:De};if(u.tier.filter&&!u.tier.filter(g))return;let k;try{k=u.tier.save(g)}catch(_){t.onError?.(_,u.tier);return}if(k&&typeof k.then=="function"){let x=(u.savePending??Promise.resolve()).then(()=>k,()=>k).then(()=>{u.disposed||(u.seq=f,u.lastSnapshot=c,u.lastFingerprint=h)},R=>{t.onError?.(R,u.tier)});u.savePending=x.finally(()=>{u.savePending===x&&(u.savePending=void 0)})}else u.seq=f,u.lastSnapshot=c,u.lastFingerprint=h},o=(u,c)=>{try{s(u,c)}catch(h){t.onError?.(h,u.tier)}},i=(u,c)=>{if(!c.some(l=>{let v=this.config.messageTier(l[0]);return v>=3&&v<5}))return;if(t.filter){let l=this.tryResolve(u);if(l==null)return;let v=wt(l,_t("standard"));if(!t.filter(u,v))return}let f,p=()=>(f==null&&(f=this.snapshot()),f);for(let l of n)l.disposed||(l.debounceMs===0?o(l,p()):(l.timer==null&&(l.timer=new Ye),l.timer.start(l.debounceMs,()=>{l.disposed||o(l,this.snapshot())})))},a;if(t.paths!=null){let c=(typeof t.paths=="string"?this._pathsMatching(t.paths):t.paths).map(h=>{let f=this.tryResolve(h);return f==null?()=>{}:f.subscribe(p=>i(h,p))});a=()=>{for(let h of c)h()}}else a=this.observe().subscribe((u,c)=>i(u,c));let d=()=>{a();for(let u of n)u.disposed=!0,u.timer?.cancel();this._storageDisposers.delete(d)};return this._storageDisposers.add(d),{dispose:d}}async _cascadeRestore(e,t){for(let n of e){let s;try{s=await n.load?.()}catch(i){t?.(i,n);continue}if(s==null||typeof s!="object"||Array.isArray(s))continue;let o=s;try{if(o.mode==="full"&&o.snapshot!=null)return this.restore(o.snapshot),!0;if(o.version===De&&o.nodes!=null)return this.restore(o),!0}catch(i){t?.(i,n)}}return!1}static async fromStorage(e,t,n){for(let s of t){let o;try{o=await s.load?.()}catch(d){n?.onError?.(d,s);continue}if(o==null||typeof o!="object"||Array.isArray(o))continue;let i=o,a=i.mode==="full"&&i.snapshot!=null?i.snapshot:i.version===De&&i.nodes!=null?i:void 0;if(a!=null)try{return r.fromSnapshot(a,n)}catch(d){n?.onError?.(d,s)}}throw new Error(`Graph.fromStorage: no tier held a restorable record for "${e}" across ${t.length} tier(s)`)}_annotations=new Map;_traceRing;trace(e,t,n){if(e!=null&&t!=null){if(this.tryResolve(e)==null)return;if(this._annotations.set(e,t),this.config.inspectorEnabled){let s={path:e,annotation:t,timestamp_ns:K(),...n?.actor!=null?{actor:n.actor}:{}};this._traceRing.push(s)}return}return e!=null?this.config.inspectorEnabled?this._annotations.get(e):void 0:this.config.inspectorEnabled?this._traceRing.toArray():[]}annotation(e){return this._annotations.get(e)}clearTrace(){this._annotations.clear(),this._traceRing.clear()}pruneTrace(e){let t=this._traceRing.toArray().filter(s=>!e(s)),n=this._traceRing.size-t.length;this._traceRing.clear();for(let s of t)this._traceRing.push(s);return n}static diff(e,t){let n=new Set(Object.keys(e.nodes)),s=new Set(Object.keys(t.nodes)),o=[...s].filter(_=>!n.has(_)).sort(),i=[...n].filter(_=>!s.has(_)).sort(),a=[],d=[];for(let _ of n){if(!s.has(_))continue;let T=e.nodes[_],x=t.nodes[_],R=T.v,S=x.v;R!=null&&S!=null&&R.id===S.id&&R.version!==S.version&&d.push({path:_,id:R.id,from:R.version,to:S.version});let m=R!=null&&S!=null&&R.id===S.id&&R.version===S.version;for(let b of["type","status","sentinel"]){let y=T[b],N=x[b];y!==N&&a.push({path:_,field:b,from:y,to:N})}if(!m)for(let b of["value","meta"]){let y=T[b],N=x[b];hr(y,N)||a.push({path:_,field:b,from:y,to:N})}}let u=_=>`${_.from} ${_.to}`,c=new Set(e.edges.map(u)),h=new Set(t.edges.map(u)),f=t.edges.filter(_=>!c.has(u(_))),p=e.edges.filter(_=>!h.has(u(_))),l=new Set(e.subgraphs),v=new Set(t.subgraphs),g=[...v].filter(_=>!l.has(_)).sort(),k=[...l].filter(_=>!v.has(_)).sort();return{nodesAdded:o,nodesRemoved:i,nodesChanged:a,versionChanges:d,edgesAdded:f,edgesRemoved:p,subgraphsAdded:g,subgraphsRemoved:k}}}});var Cr={};Pn(Cr,{collection:()=>Sr,cosineSimilarity:()=>Dn,knowledgeGraph:()=>Mr,vectorIndex:()=>Ar});module.exports=Fn(Cr);be();Te();xe();Xt();be();Ve();pe();xe();Pe();pe();Te();xe();var Et=class{_version=0;_maxSize;_buf;_head=0;_size=0;constructor(e,t){if(t!==void 0&&t<1)throw new RangeError("maxSize must be >= 1");if(this._maxSize=t,t!==void 0){if(this._buf=new Array(t),e&&e.length>0){let n=Math.min(e.length,t),s=e.length-n;for(let o=0;o<n;o++)this._buf[o]=e[s+o];this._size=n}}else this._buf=e?[...e]:[],this._size=this._buf.length}get version(){return this._version}get size(){return this._size}at(e){if(!Number.isInteger(e))return;let t=e>=0?e:this._size+e;if(!(t<0||t>=this._size))return this._maxSize!==void 0?this._buf[(this._head+t)%this._maxSize]:this._buf[t]}append(e){this._rawAppend(e),this._version+=1}appendMany(e){if(e.length===0)return;let t=this._maxSize!==void 0&&e.length>this._maxSize?e.length-this._maxSize:0;for(let n=t;n<e.length;n++)this._rawAppend(e[n]);this._version+=1}clear(){if(this._size===0)return 0;let e=this._size;if(this._maxSize===void 0)this._buf.length=0;else for(let t=0;t<e;t++)this._buf[(this._head+t)%this._maxSize]=void 0;return this._head=0,this._size=0,this._version+=1,e}trimHead(e){if(!Number.isInteger(e)||e<0)throw new RangeError(`trimHead: n must be a non-negative integer (got ${e})`);if(e===0||this._size===0)return 0;let t=Math.min(e,this._size);if(this._maxSize===void 0)this._buf.splice(0,t);else{for(let n=0;n<t;n++)this._buf[(this._head+n)%this._maxSize]=void 0;this._head=(this._head+t)%this._maxSize}return this._size-=t,this._version+=1,t}slice(e,t){if(!Number.isInteger(e)||e<0)throw new RangeError(`slice: start must be a non-negative integer (got ${e})`);if(t!==void 0&&(!Number.isInteger(t)||t<0))throw new RangeError(`slice: stop must be a non-negative integer or undefined (got ${t})`);let n=t===void 0?this._size:Math.min(Math.max(t,0),this._size),s=Math.min(e,this._size);if(s>=n)return[];let o=n-s;if(this._maxSize===void 0)return this._buf.slice(s,n);let i=new Array(o);for(let a=0;a<o;a++)i[a]=this._buf[(this._head+s+a)%this._maxSize];return i}tail(e){if(!Number.isInteger(e)||e<0)throw new RangeError(`tail: n must be a non-negative integer (got ${e})`);if(e===0||this._size===0)return[];let t=Math.min(e,this._size);return this.slice(this._size-t,this._size)}toArray(){if(this._maxSize===void 0)return[...this._buf];let e=new Array(this._size);for(let t=0;t<this._size;t++)e[t]=this._buf[(this._head+t)%this._maxSize];return e}snapshot(){return this.toArray()}restore(e){if(this._maxSize===void 0){this._buf.length=0;for(let t=0;t<e.length;t++)this._buf.push(e[t]);this._size=this._buf.length}else{let t=this._maxSize;for(let o=0;o<t;o++)this._buf[o]=void 0;this._head=0;let n=Math.min(e.length,t),s=e.length-n;for(let o=0;o<n;o++)this._buf[o]=e[s+o];this._size=n}this._version+=1}_rawAppend(e){if(this._maxSize===void 0){this._buf.push(e),this._size=this._buf.length;return}this._size<this._maxSize?(this._buf[(this._head+this._size)%this._maxSize]=e,this._size+=1):(this._buf[this._head]=e,this._head=(this._head+1)%this._maxSize)}};function ze(r){return r.subscribe(()=>{})}var Nr=64;function kn(r,e={}){let{name:t,maxSize:n,versioning:s,guard:o,backend:i}=e,a=i??new Et(r,n),d=X(a.toArray(),{name:t,describeKind:"state",equals:(m,b)=>m===b,...s!=null?{versioning:s}:{},...o!=null?{guard:o}:{}});function u(){let m=a.toArray();_e(()=>{d.down([[Y]],{internal:!0}),d.down([[$,m]],{internal:!0})})}let c=new Map,h=new Map,f=new Map;function p(m,b){return`${m}:${b===void 0?"END":b}`}function l(m){if(m.size<Nr)return;let b=m.keys().next();if(b.done)return;let y=m.get(b.value);y!==void 0&&y.dispose(),m.delete(b.value)}function v(m){let b=a.version;try{return m()}finally{a.version!==b&&u()}}function g(m){if(!Number.isInteger(m)||m<0)throw new RangeError(`tail: n must be a non-negative integer (got ${m})`);let b=c.get(m);if(b!==void 0)return c.delete(m),c.set(m,b),b.node;l(c);let y=B([d],([w])=>{let A=w;return m===0||A.length===0?[]:A.slice(Math.max(0,A.length-m))},{initial:a.tail(m),describeKind:"derived"}),N=ze(y);return c.set(m,{node:y,dispose:N}),y}function k(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 y=p(m,b),N=h.get(y);if(N!==void 0)return h.delete(y),h.set(y,N),N.node;l(h);let w=B([d],([E])=>{let O=E;return b===void 0?O.slice(m):O.slice(m,b)},{initial:a.slice(m,b),describeKind:"derived"}),A=ze(w);return h.set(y,{node:w,dispose:A}),w}function _(m){let b=f.get(m);if(b!==void 0)return b.node;let y=B([d,m],([w,A])=>{let E=w,O=Math.max(0,Math.trunc(A??0));return E.slice(O)},{initial:[],describeKind:"derived"}),N=ze(y);return f.set(m,{node:y,dispose:N}),y}let T,x;function R(){T===void 0&&(T=we([d],(m,b,y)=>{let N=m[0],A=N!=null&&N.length>0?N.at(-1):y.prevData[0];if(A==null||A.length===0){b.down([[Q]]);return}b.emit(A[A.length-1])},{name:t!=null?`${t}::lastValue`:"lastValue",describeKind:"derived",initial:a.size===0?void 0:a.at(a.size-1)}),x=B([d],([m])=>m.length>0,{name:t!=null?`${t}::hasLatest`:"hasLatest",describeKind:"derived",initial:a.size>0}),ze(T),ze(x))}let S={entries:d,get size(){return a.size},at(m){return a.at(m)},append(m){v(()=>a.append(m))},appendMany(m){m.length!==0&&v(()=>a.appendMany(m))},clear(){v(()=>a.clear())},trimHead(m){v(()=>a.trimHead(m))},withLatest(){return R(),d},get lastValue(){return R(),T},get hasLatest(){return R(),x},view(m){switch(m.kind){case"tail":return g(m.n);case"slice":return k(m.start,m.stop);case"fromCursor":return _(m.cursor)}},attach(m){let b=m.subscribe(y=>{for(let N of y)N[0]===$&&S.append(N[1])});return()=>b()},attachStorage(m){if(m.length===0)return()=>{};let b=new Map;for(let N of m)b.set(N,a.size);(async()=>{for(let N of m)if(typeof N.loadEntries=="function")try{let w=await Promise.resolve(N.loadEntries());w.entries.length>0&&a.size===0&&(a.restore(w.entries),b.set(N,w.entries.length),u());break}catch{}})();let y=d.subscribe(N=>{for(let w of N){if(w[0]!==$)continue;let A=w[1];for(let E of m){let O=b.get(E)??0;if(A.length<O){try{let D=E.appendEntries(A);D instanceof Promise&&D.catch(()=>{})}catch{}b.set(E,A.length);continue}if(A.length===O)continue;let C=A.slice(O);b.set(E,A.length);try{let D=E.appendEntries(C);D instanceof Promise&&D.catch(()=>{})}catch{}}}});return()=>y()},disposeAllViews(){for(let m of c.values())m.dispose();c.clear();for(let m of h.values())m.dispose();h.clear();for(let m of f.values())m.dispose();f.clear()},dispose(){for(let m of c.values())m.dispose();c.clear();for(let m of h.values())m.dispose();h.clear();for(let m of f.values())m.dispose();f.clear()}};return S}var kr=Kt((r,e)=>{r("observe"),r("signal"),e("write")});function tt(r){let e=kn([],{name:r.name,maxSize:r.retainedLimit??1024,guard:r.guard??kr,...r.versioning!=null?{versioning:r.versioning}:{}});return e.withLatest(),r.graph&&r.graph.add(e.entries,{name:r.name}),e}function On(r){if(r===null||typeof r!="object"||Object.isFrozen(r))return r;for(let e of Object.keys(r))On(r[e]);return Object.freeze(r)}var Rn=new WeakSet;function nt(r){let e=r.cache,t=typeof e=="number"&&Number.isFinite(e);!t&&e!==void 0&&!Rn.has(r)&&(Rn.add(r),console.warn(`bumpCursor: cursor cache held a non-numeric value (${String(e)}); resetting to 0. Causes include: a snapshot codec round-tripping the cursor as a string / null / NaN, OR a malformed initial seed (e.g. state<number>(NaN)). Audit consumers may see colliding seq values after this point.`));let s=(t?e:0)+1;return r.down([[Y],[$,s]]),s}function En(r,e,t,n,s,o){let i=e(t,n,s);if(i===void 0)return;let a=o!=null?{...i,handlerVersion:o}:i;r.append(a)}function ee(r,e){let t=e.freeze??!0;return function(...s){let o=t?s.map(On):s,i=le(),a=e.seq?nt(e.seq):void 0;try{let d=r(...o);return e.audit&&e.onSuccess&&En(e.audit,e.onSuccess,o,d,{t_ns:i,seq:a},e.handlerVersion),d}catch(d){if(e.audit&&e.onFailure){let u=d instanceof Error?d.name:typeof d;En(e.audit,e.onFailure,o,d,{t_ns:i,seq:a,errorType:u},e.handlerVersion)}throw d}}}function rt(r,e,t=0){let n=X(t,{name:e,describeKind:"state"});return r.add(n,{name:e}),n}Pe();be();pe();xe();var Ot=class{_version=0;_store=new Map;_maxSize;_defaultTtl;constructor(e={}){let{maxSize:t,defaultTtl:n}=e;if(t!==void 0&&t<1)throw new RangeError("maxSize must be >= 1");if(n!==void 0&&n<=0)throw new RangeError("defaultTtl must be positive");this._maxSize=t,this._defaultTtl=n}get version(){return this._version}get size(){return this._store.size}has(e){let t=this._store.get(e);return t===void 0?!1:this._isExpired(t)?(this._store.delete(e),this._version+=1,!1):(this._touchLru(e,t),!0)}get(e){let t=this._store.get(e);if(t!==void 0){if(this._isExpired(t)){this._store.delete(e),this._version+=1;return}return this._touchLru(e,t),t.value}}set(e,t,n){let s=this._resolveExpiresAt(n);this._store.has(e)&&this._store.delete(e),this._store.set(e,{value:t,expiresAt:s}),this._evictLruWhileOver(),this._version+=1}setMany(e,t){let n=this._resolveExpiresAt(t),s=0;try{for(let[o,i]of e)this._store.has(o)&&this._store.delete(o),this._store.set(o,{value:i,expiresAt:n}),s+=1}finally{s>0&&(this._evictLruWhileOver(),this._version+=1)}}delete(e){let t=this._store.delete(e);return t&&(this._version+=1),t}deleteMany(e){let t=0;try{for(let n of e)this._store.delete(n)&&(t+=1)}finally{t>0&&(this._version+=1)}return t}clear(){let e=this._store.size;return e===0?0:(this._store.clear(),this._version+=1,e)}pruneExpired(){let e=K(),t=0;for(let[n,s]of this._store)this._isExpired(s,e)&&(this._store.delete(n),t+=1);return t>0&&(this._version+=1),t}toMap(){let e=K(),t=new Map;for(let[n,s]of this._store)this._isExpired(s,e)||t.set(n,s.value);return t}_resolveExpiresAt(e){let t=e??this._defaultTtl;if(t!==void 0){if(!Number.isFinite(t)||t<=0)throw new RangeError(`MapBackend: ttl must be a positive finite number (got ${t})`);return K()+t*1e9}}_isExpired(e,t){return e.expiresAt===void 0?!1:(t??K())>=e.expiresAt}_touchLru(e,t){this._store.delete(e),this._store.set(e,t)}_evictLruWhileOver(){if(this._maxSize!==void 0)for(;this._store.size>this._maxSize;){let e=this._store.keys().next().value;if(e===void 0)break;this._store.delete(e)}}};function Le(r={}){let{name:e,maxSize:t,defaultTtl:n,versioning:s,backend:o,retention:i}=r;if(i&&t!==void 0)throw new RangeError("reactiveMap: `maxSize` (LRU) and `retention` (score-based) are mutually exclusive. Pick one eviction policy.");if(i&&i.archiveThreshold===void 0&&i.maxSize===void 0)throw new RangeError("reactiveMap: `retention` requires at least one of `archiveThreshold` or `maxSize` to trigger archival.");let a=o??new Ot({maxSize:t,defaultTtl:n}),d=X(a.toMap(),{name:e,describeKind:"state",equals:(f,p)=>f===p,...s!=null?{versioning:s}:{}});function u(){let f=a.toMap();_e(()=>{d.down([[Y]]),d.down([[$,f]])})}function c(){if(!i)return;let f=a.toMap(),p=i.archiveThreshold,l=i.maxSize,v=[];for(let[k,_]of f)v.push({key:k,value:_,score:i.score(k,_)});v.sort((k,_)=>k.score-_.score);let g=new Set;if(p!==void 0)for(let k of v)if(k.score<p)g.add(k.key);else break;if(l!==void 0&&v.length-g.size>l)for(let k of v){if(v.length-g.size<=l)break;g.has(k.key)||g.add(k.key)}if(g.size!==0)for(let k of v)g.has(k.key)&&(i.onArchive?.(k.key,k.value,k.score),a.delete(k.key))}function h(f,p="mutation"){let l=a.version;try{return f()}finally{a.version!==l&&(p==="mutation"&&c(),u())}}return{entries:d,has(f){return h(()=>a.has(f),"read")},get(f){return h(()=>a.get(f),"read")},set(f,p,l){h(()=>a.set(f,p,l?.ttl))},setMany(f,p){h(()=>a.setMany(f,p?.ttl))},delete(f){h(()=>a.delete(f))},deleteMany(f){h(()=>a.deleteMany(f))},clear(){h(()=>a.clear())},pruneExpired(){h(()=>a.pruneExpired())},get size(){return a.size},dispose(){}}}Nt();var Js=Math.LN2/604800;function St(r,e,t,n=0){if(!Number.isFinite(r))return n;if(!Number.isFinite(e)||e<=0||!Number.isFinite(t)||t<=0)return Math.max(n,r);let s=r*Math.exp(-t*e);return Math.max(n,s)}Nn();var Rr=1e9;function se(r,e){return Jt("memory",r,e)}function Ke(r,e){return r instanceof z?r:X(r,e?{name:e}:void 0)}function Sn(r,e){return(r-e)/Rr}function Dn(r,e){let t=Math.max(r.length,e.length),n=0,s=0,o=0;for(let a=0;a<t;a+=1){let d=r[a]??0,u=e[a]??0;n+=d*u,s+=d*d,o+=u*u}if(s===0||o===0)return 0;let i=n/Math.sqrt(s*o);return Number.isFinite(i)?i:0}function Er(r,e){if(r===e)return!0;if(r==null||e==null||r.length!==e.length)return!1;for(let t=0;t<r.length;t+=1){let n=r[t],s=e[t];if(n.id!==s.id||n.score!==s.score||n.meta!==s.meta)return!1}return!0}function Or(r,e){if(r===e)return!0;if(r==null||e==null||r.length!==e.length)return!1;for(let t=0;t<r.length;t+=1){let n=r[t],s=e[t];if(n.id!==s.id||n.score!==s.score||n.lastAccessNs!==s.lastAccessNs||n.value!==s.value)return!1}return!0}function Sr(r,e={}){let t=e.maxSize,n=e.ranked??!0,s=n?e.decayRate??0:0,o=e.minScore??0;if(t!==void 0&&t<1)throw new RangeError("collection: maxSize must be >= 1");let i=()=>n?1:0,a=e.score??i,d=n&&a instanceof z?a:void 0,u=()=>d?d.cache??i:a,c=new ke(r),f=Le({name:"items",...t!==void 0?{retention:{score:(E,O)=>n?St(O.baseScore,Sn(K(),O.lastAccessNs),s,o):O.lastAccessNs,maxSize:t}}:{}});c.add(f.entries,{name:"items"});let p;if(n&&s>0){let E=e.refreshIntervalMs??Math.max(1,1e3*Math.LN2/(10*s)),O=tn(E,{period:E});p=B([O],()=>K(),{name:"refresh_tick_ns",describeKind:"derived",initial:K(),meta:se("clock")}),c.add(p,{name:"refresh_tick_ns"})}let l;if(n){let E=[f.entries];p&&E.push(p),d&&E.push(d),l=B(E,O=>{let C=O[0],D;if(p){let L=O[1];D=typeof L=="number"?L:K()}else D=K();if(!C||C.size===0)return[];let P=[];for(let L of C.values())P.push({...L,score:St(L.baseScore,Sn(D,L.lastAccessNs),s,o)});return P.sort((L,q)=>q.score-L.score||q.lastAccessNs-L.lastAccessNs),P},{name:"ranked",describeKind:"derived",equals:Or,meta:se("ranked")}),c.add(l,{name:"ranked"})}else l=X([],{name:"ranked",describeKind:"state",meta:se("ranked_disabled")}),c.add(l,{name:"ranked"});let v=B([f.entries],([E])=>(E??new Map).size,{name:"size",describeKind:"derived",initial:0,meta:se("size")});c.add(v,{name:"size"}),c.addDisposer(ae(v));let g=tt({name:"events",retainedLimit:1024,graph:c}),k=rt(c,"seq",0),_=(E,O,C)=>{let D=K(),P=f.get(E),L=C?.score??u()(O);f.set(E,{id:E,value:O,baseScore:L,createdAtNs:P?.createdAtNs??D,lastAccessNs:D})},T=E=>{f.has(E)&&f.delete(E)},x=()=>{f.size!==0&&f.clear()},R=()=>{if(!n)return;let E=u(),O=f.entries.cache;if(!O||O.size===0)return;let C=[];for(let D of O.values())C.push([D.id,{...D,baseScore:E(D.value)}]);f.setMany(C)},S=ee(_,{audit:g,seq:k,onSuccess:([E],O,C)=>({action:"upsert",id:E,t_ns:C.t_ns,seq:C.seq})}),m=ee(T,{audit:g,seq:k,onSuccess:([E],O,C)=>({action:"remove",id:E,t_ns:C.t_ns,seq:C.seq})}),b=ee(x,{audit:g,seq:k,onSuccess:(E,O,C)=>({action:"clear",t_ns:C.t_ns,seq:C.seq})}),y=ee(R,{audit:g,seq:k,onSuccess:(E,O,C)=>({action:"rescore",t_ns:C.t_ns,seq:C.seq})});function N(E){let O=Ke(E,"id");return B([f.entries,O],([C,D])=>C?.get(D),{describeKind:"derived",meta:se("collection_item")})}function w(E){let O=Ke(E,"id");return B([f.entries,O],([C,D])=>C?.has(D)??!1,{describeKind:"derived",meta:se("collection_has")})}return Object.assign(c,{events:g,items:f.entries,ranked:l,size:v,upsert:S,remove:m,clear:b,rescore:y,itemNode:N,hasNode:w})}function Ar(r={}){let e=r.backend??"flat",t=r.dimension,n=r.strictDimension??!0,s=r.maxSize,o=r.retentionScore,i;if(e==="hnsw"&&(i=r.hnswFactory?.(),!i))throw new Error('vectorIndex backend "hnsw" requires an optional dependency adapter; install your HNSW package and provide `hnswFactory`.');let a=new ke(r.name??"vector_index"),d;function u(y){if(t!==void 0){if(y.length!==t)throw new RangeError(`vector dimension mismatch: expected ${t}, got ${y.length}`);return}if(n){if(d===void 0){d=y.length;return}if(y.length!==d)throw new RangeError(`vector dimension mismatch: inferred ${d} from first upsert, got ${y.length}. Pass \`strictDimension: false\` to opt into zero-pad behavior, or set an explicit \`dimension\`.`)}}let c=o??(y=>y.upsertedAtNs),h=!1,f=tt({name:"events",retainedLimit:1024,graph:a}),p=rt(a,"seq",0),l=Le({name:"entries",...s!==void 0?{retention:{score:(y,N)=>c(N),maxSize:s,onArchive:y=>{h||(e==="hnsw"&&i.remove(y),f.append({action:"evict",id:y,t_ns:le(),seq:nt(p)}))}}}:{}});if(a.add(l.entries,{name:"entries"}),a.addDisposer(ae(l.entries)),i?.dispose){let y=i.dispose.bind(i);a.addDisposer(()=>y())}let v=(y,N,w)=>{u(N),e==="hnsw"&&i.upsert(y,N,w);let A=(()=>{if(w!==void 0)return w===null||typeof w!="object"?w:Array.isArray(w)?[...w]:{...w}})(),E={id:y,vector:[...N],...A!==void 0?{meta:A}:{},upsertedAtNs:K()};l.set(y,E)},g=y=>{l.has(y)&&(e==="hnsw"&&i.remove(y),l.delete(y))},k=()=>{if(l.size!==0){h=!0;try{l.clear(),e==="hnsw"&&i.clear()}finally{h=!1}d=void 0}},_=()=>{if(e!=="hnsw")return;let y=l.entries.cache;if(y){i.clear();for(let N of y.values())i.upsert(N.id,N.vector,N.meta)}},T=ee(v,{audit:f,freeze:!1,seq:p,onSuccess:([y],N,w)=>({action:"upsert",id:y,t_ns:w.t_ns,seq:w.seq})}),x=ee(g,{audit:f,seq:p,onSuccess:([y],N,w)=>({action:"remove",id:y,t_ns:w.t_ns,seq:w.seq})}),R=ee(k,{audit:f,seq:p,onSuccess:(y,N,w)=>({action:"clear",t_ns:w.t_ns,seq:w.seq})}),S=ee(_,{audit:f,seq:p,onSuccess:(y,N,w)=>({action:"reindex",t_ns:w.t_ns,seq:w.seq})});function m(y,N=5){let w=Ke(N,"k");return B([l.entries,y,w],A=>{let E=A[0],O=A[1],C=A[2],D=Number.isFinite(C)?Math.max(0,Math.floor(C)):0;if(!E||E.size===0||D<=0)return[];if(O==null||O.length===0)return[];let P=t??(n?d:void 0);return P!==void 0&&O.length!==P?[]:e==="hnsw"?[...i.search(O,D)]:[...E.values()].map(q=>({id:q.id,score:Dn(O,q.vector),...q.meta!==void 0?{meta:q.meta}:{}})).sort((q,oe)=>oe.score-q.score).slice(0,D)},{describeKind:"derived",equals:(A,E)=>Er(A,E),meta:se("vector_search")})}return Object.assign(a,{backend:e,events:f,entries:l.entries,upsert:T,remove:x,clear:R,reindex:S,searchNode:m})}var An="\0";function st(r,e,t){return`${r}${An}${e}${An}${t}`}function Mn(r,e){if(!r||r.size===0)return new Map;let t=new Map;for(let s of r.values()){let o=e==="from"?s.from:s.to,i=t.get(o);i||(i=[],t.set(o,i)),i.push(s)}let n=new Map;for(let[s,o]of t)n.set(s,Object.freeze(o));return n}function Cn(r,e){if(r===e)return!0;if(r==null||e==null||r.size!==e.size)return!1;for(let[t,n]of r){let s=e.get(t);if(!s||n.length!==s.length)return!1;for(let o=0;o<n.length;o+=1){let i=n[o],a=s[o];if(i.from!==a.from||i.to!==a.to||i.relation!==a.relation||i.weight!==a.weight)return!1}}return!0}function Mr(r,e={}){let t=e.orphanGC??"keep";if(e.entitiesMaxSize!==void 0&&e.entitiesMaxSize<1)throw new RangeError("knowledgeGraph: entitiesMaxSize must be >= 1");if(e.edgesMaxSize!==void 0&&e.edgesMaxSize<1)throw new RangeError("knowledgeGraph: edgesMaxSize must be >= 1");let n=new ke(r),s=Le({name:"entities",...e.entitiesMaxSize!==void 0?{maxSize:e.entitiesMaxSize}:{}}),o=Le({name:"edges",...e.edgesMaxSize!==void 0?{maxSize:e.edgesMaxSize}:{}});n.add(s.entries,{name:"entities"}),n.add(o.entries,{name:"edges"});let i=B([o.entries],([b])=>Mn(b,"from"),{name:"adjacencyOut",describeKind:"derived",initial:new Map,equals:Cn,meta:se("adjacency_out")}),a=B([o.entries],([b])=>Mn(b,"to"),{name:"adjacencyIn",describeKind:"derived",initial:new Map,equals:Cn,meta:se("adjacency_in")});n.add(i,{name:"adjacencyOut"}),n.add(a,{name:"adjacencyIn"}),n.addDisposer(ae(i)),n.addDisposer(ae(a));let d=B([s.entries],([b])=>(b??new Map).size,{name:"entityCount",describeKind:"derived",initial:0,meta:se("entity_count")}),u=B([o.entries],([b])=>(b??new Map).size,{name:"edgeCount",describeKind:"derived",initial:0,meta:se("edge_count")});n.add(d,{name:"entityCount"}),n.add(u,{name:"edgeCount"}),n.addDisposer(ae(d)),n.addDisposer(ae(u));let c=tt({name:"events",retainedLimit:1024,graph:n}),h=rt(n,"seq",0);function f(b){let y=i.cache,N=a.cache;return(y?.get(b)?.length??0)>0||(N?.get(b)?.length??0)>0}function p(b){if(t==="remove")for(let y of b)s.has(y)&&(f(y)||(s.delete(y),c.append({action:"orphanRemove",id:y,t_ns:le(),seq:nt(h)})))}let l=(b,y)=>{s.set(b,y)},v=b=>{let y=o.entries.cache,N=new Set;if(y){let w=[];for(let[A,E]of y)(E.from===b||E.to===b)&&(w.push(A),E.from!==b&&N.add(E.from),E.to!==b&&N.add(E.to));w.length>0&&o.deleteMany(w)}s.has(b)&&s.delete(b),p([...N])},g=(b,y,N,w=1)=>{o.set(st(b,y,N),{from:b,to:y,relation:N,weight:w})},k=(b,y,N)=>{if(N!==void 0)o.delete(st(b,y,N));else{let w=o.entries.cache;if(!w)return;let A=[];for(let[E,O]of w)O.from===b&&O.to===y&&A.push(E);A.length>0&&o.deleteMany(A)}p([b,y])},_=ee(l,{audit:c,seq:h,onSuccess:([b],y,N)=>({action:"upsertEntity",id:b,t_ns:N.t_ns,seq:N.seq})}),T=ee(v,{audit:c,seq:h,onSuccess:([b],y,N)=>({action:"removeEntity",id:b,t_ns:N.t_ns,seq:N.seq})}),x=ee(g,{audit:c,seq:h,onSuccess:([b,y,N,w],A,E)=>({action:"link",from:b,to:y,relation:N,weight:w??1,t_ns:E.t_ns,seq:E.seq})}),R=ee(k,{audit:c,seq:h,onSuccess:([b,y,N],w,A)=>({action:"unlink",from:b,to:y,...N!==void 0?{relation:N}:{},t_ns:A.t_ns,seq:A.seq})});function S(b,y){let N=Ke(b,"id"),w=y!==void 0?Ke(y,"relation"):void 0;return B(w?[i,a,N,w]:[i,a,N],E=>{let O=E[0],C=E[1],D=E[2],P=w?E[3]:void 0,L=O.get(D)??[],q=C.get(D)??[],oe=new Set,me=[];for(let J of L){let ue=st(J.from,J.to,J.relation);oe.has(ue)||P!==void 0&&J.relation!==P||(oe.add(ue),me.push(J))}for(let J of q){let ue=st(J.from,J.to,J.relation);oe.has(ue)||P!==void 0&&J.relation!==P||(oe.add(ue),me.push(J))}return me},{describeKind:"derived",equals:(E,O)=>{let C=E,D=O;if(C===D)return!0;if(C==null||D==null||C.length!==D.length)return!1;for(let P=0;P<C.length;P+=1){let L=C[P],q=D[P];if(L.from!==q.from||L.to!==q.to||L.relation!==q.relation||L.weight!==q.weight)return!1}return!0},meta:se("related")})}return Object.assign(n,{events:c,entities:s.entries,edges:o.entries,adjacencyOut:i,adjacencyIn:a,entityCount:d,edgeCount:u,upsertEntity:_,removeEntity:T,link:x,unlink:R,relatedNode:S})}0&&(module.exports={collection,cosineSimilarity,knowledgeGraph,vectorIndex});
1
+ "use strict";
2
+ var __defProp = Object.defineProperty;
3
+ var __getOwnPropDesc = Object.getOwnPropertyDescriptor;
4
+ var __getOwnPropNames = Object.getOwnPropertyNames;
5
+ var __hasOwnProp = Object.prototype.hasOwnProperty;
6
+ var __copyProps = (to, from, except, desc) => {
7
+ if (from && typeof from === "object" || typeof from === "function") {
8
+ for (let key of __getOwnPropNames(from))
9
+ if (!__hasOwnProp.call(to, key) && key !== except)
10
+ __defProp(to, key, { get: () => from[key], enumerable: !(desc = __getOwnPropDesc(from, key)) || desc.enumerable });
11
+ }
12
+ return to;
13
+ };
14
+ var __reExport = (target, mod, secondTarget) => (__copyProps(target, mod, "default"), secondTarget && __copyProps(secondTarget, mod, "default"));
15
+ var __toCommonJS = (mod) => __copyProps(__defProp({}, "__esModule", { value: true }), mod);
16
+
17
+ // src/patterns/memory/index.ts
18
+ var memory_exports = {};
19
+ module.exports = __toCommonJS(memory_exports);
20
+ __reExport(memory_exports, require("@graphrefly/pure-ts/patterns/memory"), module.exports);
21
+ //# sourceMappingURL=index.cjs.map
@@ -0,0 +1 @@
1
+ {"version":3,"sources":["../../../src/patterns/memory/index.ts"],"sourcesContent":["// Phase 13.9.A shim — re-export from pure-TS sibling until\n// @graphrefly/native (napi binding) and per-milestone swap-overs land.\nexport * from \"@graphrefly/pure-ts/patterns/memory\";\n"],"mappings":";;;;;;;;;;;;;;;;;AAAA;AAAA;AAEA,2BAAc,gDAFd;","names":[]}
@@ -1,8 +1 @@
1
- import '../../node-kK3CvTrR.cjs';
2
- import '../../index-D0aciIex.cjs';
3
- import '../../reactive-log-DIGdYqQ6.cjs';
4
- import '../../graph-CWvEUQAq.cjs';
5
- export { b as CollectionAuditRecord, c as CollectionEntry, C as CollectionGraph, d as CollectionOptions, e as CollectionScoreFn, H as HnswAdapter, f as KnowledgeEdge, K as KnowledgeGraph, g as KnowledgeGraphAuditRecord, h as KnowledgeGraphOptions, N as NodeOrValue, R as RankedCollectionEntry, j as VectorBackend, k as VectorIndexAuditRecord, a as VectorIndexGraph, l as VectorIndexOptions, m as VectorRecord, V as VectorSearchResult, n as collection, o as cosineSimilarity, p as knowledgeGraph, v as vectorIndex } from '../../index-B17QddL1.cjs';
6
- import '../../extra/storage-tiers.cjs';
7
- import '../../sugar-DQjFmVqb.cjs';
8
- import '../../extra/storage-core.cjs';
1
+ export * from '@graphrefly/pure-ts/patterns/memory';
@@ -1,8 +1 @@
1
- import '../../node-kK3CvTrR.js';
2
- import '../../index-Yq60JP3s.js';
3
- import '../../reactive-log-BKALbfal.js';
4
- import '../../graph-D9LFnda9.js';
5
- export { b as CollectionAuditRecord, c as CollectionEntry, C as CollectionGraph, d as CollectionOptions, e as CollectionScoreFn, H as HnswAdapter, f as KnowledgeEdge, K as KnowledgeGraph, g as KnowledgeGraphAuditRecord, h as KnowledgeGraphOptions, N as NodeOrValue, R as RankedCollectionEntry, j as VectorBackend, k as VectorIndexAuditRecord, a as VectorIndexGraph, l as VectorIndexOptions, m as VectorRecord, V as VectorSearchResult, n as collection, o as cosineSimilarity, p as knowledgeGraph, v as vectorIndex } from '../../index-CZ3r5Rxp.js';
6
- import '../../extra/storage-tiers.js';
7
- import '../../sugar-fhLIE7TT.js';
8
- import '../../extra/storage-core.js';
1
+ export * from '@graphrefly/pure-ts/patterns/memory';
@@ -1 +1,3 @@
1
- import{a,b,c,d}from"../../chunk-CE6TI2TL.js";import"../../chunk-TSOYJ743.js";import"../../chunk-W3I423PS.js";import"../../chunk-L6NSJVJZ.js";import"../../chunk-HITNVN6B.js";import"../../chunk-ESMPEKEV.js";import"../../chunk-GHBWHMRZ.js";import"../../chunk-BEZWM2SY.js";import"../../chunk-YBB7ZGTY.js";import"../../chunk-CRVT7D2P.js";import"../../chunk-NTEURFZH.js";import"../../chunk-CK2E7BTU.js";import"../../chunk-QYADASLV.js";export{b as collection,a as cosineSimilarity,d as knowledgeGraph,c as vectorIndex};
1
+ // src/patterns/memory/index.ts
2
+ export * from "@graphrefly/pure-ts/patterns/memory";
3
+ //# sourceMappingURL=index.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"sources":["../../../src/patterns/memory/index.ts"],"sourcesContent":["// Phase 13.9.A shim — re-export from pure-TS sibling until\n// @graphrefly/native (napi binding) and per-milestone swap-overs land.\nexport * from \"@graphrefly/pure-ts/patterns/memory\";\n"],"mappings":";AAEA,cAAc;","names":[]}
@@ -1,3 +1,21 @@
1
- "use strict";var ut=Object.defineProperty;var Cn=Object.getOwnPropertyDescriptor;var Mn=Object.getOwnPropertyNames;var Gn=Object.prototype.hasOwnProperty;var $=(r,e)=>()=>(r&&(e=r(r=0)),e);var In=(r,e)=>{for(var t in e)ut(r,t,{get:e[t],enumerable:!0})},Pn=(r,e,t,n)=>{if(e&&typeof e=="object"||typeof e=="function")for(let s of Mn(e))!Gn.call(r,s)&&s!==t&&ut(r,s,{get:()=>e[s],enumerable:!(n=Cn(e,s))||n.enumerable});return r};var Ln=r=>Pn(ut({},"__esModule",{value:!0}),r);function ze(r){if(r==null)return ye;let{type:e,id:t,...n}=r;return{type:e??"system",id:t??"",...n}}var ye,Be=$(()=>{"use strict";ye={type:"system",id:""}});function Ae(){return ve>0||Ee}function Gt(){return ve>0}function Te(r){ve>0?Re.push(r):r()}function ne(r){ve+=1;let e=!1;try{r()}catch(t){throw e=!0,t}finally{if(ve-=1,ve===0)if(e){if(!Ee){let t=Re.splice(0);for(let n of t)try{n()}catch{}le.length=0,pe.length=0,_e.length=0}}else $n()}}function $n(){let r=!Ee;r&&(Ee=!0);let e=[],t=0;try{for(;le.length>0||pe.length>0||_e.length>0||r&&Re.length>0;){if(r&&Re.length>0){let o=Re.splice(0);for(let i of o)try{i()}catch(a){e.push(a)}continue}if(t+=1,t>1e3)throw le.length=0,pe.length=0,_e.length=0,new Error("batch drain exceeded 1000 iterations \u2014 likely a reactive cycle");let s=(le.length>0?le:pe.length>0?pe:_e).splice(0);for(let o of s)try{o()}catch(i){e.push(i)}}}finally{r&&(Ee=!1)}if(e.length===1)throw e[0];if(e.length>1)throw new AggregateError(e,"batch drain: multiple callbacks threw")}function Se(r,e,t){if(e.length===0)return;if(e.length===1){let d=t(e[0][0]);if(d<3||!Ae()){r(e);return}(d>=5?_e:d===4?pe:le).push(()=>r(e));return}let n=e.length,s=n,o=n,i=n,a=0;for(;a<n&&t(e[a][0])<3;)a++;for(s=a;a<n&&t(e[a][0])===3;)a++;for(o=a;a<n&&t(e[a][0])===4;)a++;i=a;let u=Ae();if(s>0){let d=e.slice(0,s);r(d)}if(o>s){let d=e.slice(s,o);u?le.push(()=>r(d)):r(d)}if(i>o){let d=e.slice(o,i);u?pe.push(()=>r(d)):r(d)}if(n>i){let d=e.slice(i,n);u?_e.push(()=>r(d)):r(d)}}var ve,Ee,le,pe,_e,Re,De=$(()=>{"use strict";ve=0,Ee=!1,le=[],pe=[],_e=[],Re=[]});function re(){return Math.trunc(performance.now()*1e6)}function we(){return Date.now()*1e6}var Ce=$(()=>{"use strict"});var fe,G,B,H,Y,Q,se,z,L,C,he,je,It,He,Pt,Lt,We,dt,ct,lt,Ue,ae=$(()=>{"use strict";fe=Symbol.for("graphrefly/START"),G=Symbol.for("graphrefly/DATA"),B=Symbol.for("graphrefly/DIRTY"),H=Symbol.for("graphrefly/RESOLVED"),Y=Symbol.for("graphrefly/INVALIDATE"),Q=Symbol.for("graphrefly/PAUSE"),se=Symbol.for("graphrefly/RESUME"),z=Symbol.for("graphrefly/TEARDOWN"),L=Symbol.for("graphrefly/COMPLETE"),C=Symbol.for("graphrefly/ERROR"),he=Object.freeze([B]),je=Object.freeze([H]),It=Object.freeze([Y]),He=Object.freeze([fe]),Pt=Object.freeze([L]),Lt=Object.freeze([z]),We=Object.freeze([he]),dt=Object.freeze([je]),ct=Object.freeze([It]),lt=Object.freeze([Pt]),Ue=Object.freeze([Lt])});function $t(r){r.registerMessageType(fe,{tier:0,wireCrossing:!1}),r.registerMessageType(B,{tier:1,wireCrossing:!1}),r.registerMessageType(Y,{tier:1,wireCrossing:!1,metaPassthrough:!1}),r.registerMessageType(Q,{tier:2,wireCrossing:!1}),r.registerMessageType(se,{tier:2,wireCrossing:!1}),r.registerMessageType(G,{tier:3,wireCrossing:!0}),r.registerMessageType(H,{tier:3,wireCrossing:!0}),r.registerMessageType(L,{tier:4,wireCrossing:!0,metaPassthrough:!1}),r.registerMessageType(C,{tier:4,wireCrossing:!0,metaPassthrough:!1}),r.registerMessageType(z,{tier:5,wireCrossing:!0,metaPassthrough:!1})}var Ke,Ft=$(()=>{"use strict";ae();Ke=class{_messageTypes=new Map;_codecs=new Map;_onMessage;_onSubscribe;_defaultVersioning;_defaultHashFn;_inspectorEnabled=!(typeof process<"u"&&process.env?.NODE_ENV==="production");_globalInspector;_rigorRecorder;_frozen=!1;tierOf;constructor(e){this._onMessage=e.onMessage,this._onSubscribe=e.onSubscribe,this._defaultVersioning=e.defaultVersioning,this._defaultHashFn=e.defaultHashFn,this.tierOf=t=>{let n=this._messageTypes.get(t);return n!=null?n.tier:1}}get onMessage(){return this._frozen=!0,this._onMessage}get onSubscribe(){return this._frozen=!0,this._onSubscribe}set onMessage(e){this._assertUnfrozen(),this._onMessage=e}set onSubscribe(e){this._assertUnfrozen(),this._onSubscribe=e}get defaultVersioning(){return this._defaultVersioning}set defaultVersioning(e){this._assertUnfrozen(),this._defaultVersioning=e}get defaultHashFn(){return this._defaultHashFn}set defaultHashFn(e){this._assertUnfrozen(),this._defaultHashFn=e}get inspectorEnabled(){return this._inspectorEnabled}set inspectorEnabled(e){this._inspectorEnabled=e}get globalInspector(){return this._globalInspector}set globalInspector(e){this._globalInspector=e}get rigorRecorder(){return this._rigorRecorder}set rigorRecorder(e){this._rigorRecorder=e}registerMessageType(e,t){return this._assertUnfrozen(),this._messageTypes.set(e,{tier:t.tier,wireCrossing:t.wireCrossing??t.tier>=3,metaPassthrough:t.metaPassthrough??!0}),this}messageTier(e){let t=this._messageTypes.get(e);return t!=null?t.tier:1}isWireCrossing(e){let t=this._messageTypes.get(e);return t!=null?t.wireCrossing:!0}isLocalOnly(e){return!this.isWireCrossing(e)}isMetaPassthrough(e){let t=this._messageTypes.get(e);return t!=null?t.metaPassthrough:!0}isKnownMessageType(e){return this._messageTypes.has(e)}registerCodec(e){return this._assertUnfrozen(),this._codecs.set(e.name,e),this}lookupCodec(e){return this._codecs.get(e)}_isFrozen(){return this._frozen}_assertUnfrozen(){if(this._frozen)throw new Error("GraphReFlyConfig is frozen: a node has already captured this config. Register custom types and set hooks before creating any node.")}}});function Vt(r){return Array.isArray(r)?[...r]:[r]}function Fn(r,e){return r.has(e)||r.has("*")}function zt(r){let e=[];return r((s,o)=>{e.push({kind:"allow",actions:new Set(Vt(s)),where:o?.where??(()=>!0)})},(s,o)=>{e.push({kind:"deny",actions:new Set(Vt(s)),where:o?.where??(()=>!0)})}),(s,o)=>{let i=!1,a=!1;for(let u of e)Fn(u.actions,o)&&u.where(s)&&(u.kind==="deny"?i=!0:a=!0);return i?!1:a}}function pt(r){let e=Vn.filter(t=>r({type:t,id:""},"write"));return e.length===0?"restricted":e.includes("human")&&e.includes("llm")&&e.every(t=>t==="human"||t==="llm"||t==="system")?"both":e.length===1?e[0]:e.join("+")}var J,Vn,Oe=$(()=>{"use strict";J=class extends Error{actor;action;nodeName;constructor(e,t){super(t??`GuardDenied: action "${String(e.action)}" denied for actor type "${String(e.actor.type)}"`),this.name="GuardDenied",this.actor=e.actor,this.action=e.action,this.nodeName=e.nodeName}get node(){return this.nodeName}};Vn=["human","llm","wallet","system"]});function jt(r,e){let t=new TextEncoder().encode(r.name);if(t.length===0||t.length>255)throw new Error(`encodeEnvelope: codec name "${r.name}" encodes to ${t.length} bytes (must be 1\u2013255)`);let n=r.version;if(!Number.isInteger(n)||n<0||n>65535)throw new Error(`encodeEnvelope: codec.version ${n} out of u16 range (expected integer 0\u201365535)`);let s=2+t.length+2+e.length;if(s>4294967295)throw new Error(`encodeEnvelope: total envelope size ${s} exceeds 2^32-1 bytes (payload ${e.length} bytes)`);let o=new Uint8Array(s),i=0;return o[i++]=ft,o[i++]=t.length,o.set(t,i),i+=t.length,o[i++]=n>>>8&255,o[i++]=n&255,o.set(e,i),o}function Ht(r,e){if(r.length<Bt)throw new Error(`decodeEnvelope: bytes too short (${r.length} < ${Bt})`);let t=0,n=r[t++];if(n!==ft)throw new Error(`decodeEnvelope: unsupported envelope version ${n} (expected ${ft})`);let s=r[t++];if(s===0)throw new Error("decodeEnvelope: name_len must be >= 1");if(t+s+2>r.length)throw new Error(`decodeEnvelope: envelope truncated (need ${t+s+2} bytes, have ${r.length})`);let o=new TextDecoder().decode(r.subarray(t,t+s));t+=s;let i=(r[t]<<8|r[t+1])>>>0;t+=2;let a=r.subarray(t),u=e.lookupCodec(o);if(u==null)throw new Error(`decodeEnvelope: codec "${o}" not registered (envelope codec_v=${i})`);return{codec:u,codecVersion:i,payload:a}}function Wt(r){r.registerCodec(zn)}var zn,ft,Bt,ht=$(()=>{"use strict";zn={name:"json",version:1,contentType:"application/json",encode(r){let e=JSON.stringify(r);return new TextEncoder().encode(e)},decode(r,e){let t=new TextDecoder().decode(r);return JSON.parse(t)}},ft=1,Bt=4});function gt(r){if(r===void 0)return null;if(typeof r=="number"){if(!Number.isFinite(r))throw new TypeError(`Cannot hash non-finite number: ${r}`);if(Number.isInteger(r)&&!Number.isSafeInteger(r))throw new TypeError(`Cannot hash integer outside safe range (|n| > 2^53-1): ${r}. Cross-language cid parity is not guaranteed for unsafe integers.`);return r}if(typeof r=="string"||typeof r=="boolean"||r===null)return r;if(Array.isArray(r))return r.map(gt);if(typeof r=="object"&&r!==null){let e={};for(let t of Object.keys(r).sort())e[t]=gt(r[t]);return e}return null}function Hn(r){let e=jn.encode(r),t=e.length,n=t*8,s=t+9+63&-64,o=new Uint8Array(s);o.set(e),o[t]=128;let i=new DataView(o.buffer);i.setUint32(s-4,n>>>0,!1),i.setUint32(s-8,Math.floor(n/4294967296)>>>0,!1);let a=1779033703,u=3144134277,d=1013904242,c=2773480762,f=1359893119,p=2600822924,h=528734635,l=1541459225,y=new Uint32Array(64),g=(v,b)=>v>>>b|v<<32-b;for(let v=0;v<s;v+=64){for(let N=0;N<16;N++)y[N]=i.getUint32(v+N*4,!1);for(let N=16;N<64;N++){let A=y[N-15],D=y[N-2],S=g(A,7)^g(A,18)^A>>>3,ie=g(D,17)^g(D,19)^D>>>10;y[N]=y[N-16]+S+y[N-7]+ie>>>0}let b=a,_=u,T=d,x=c,m=f,w=p,k=h,R=l;for(let N=0;N<64;N++){let A=g(m,6)^g(m,11)^g(m,25),D=m&w^~m&k,S=R+A+D+Bn[N]+y[N]>>>0,ie=g(b,2)^g(b,13)^g(b,22),te=b&_^b&T^_&T,Fe=ie+te>>>0;R=k,k=w,w=m,m=x+S>>>0,x=T,T=_,_=b,b=S+Fe>>>0}a=a+b>>>0,u=u+_>>>0,d=d+T>>>0,c=c+x>>>0,f=f+m>>>0,p=p+w>>>0,h=h+k>>>0,l=l+R>>>0}let O=v=>v.toString(16).padStart(8,"0");return O(a)+O(u)+O(d)+O(c)+O(f)+O(p)+O(h)+O(l)}function mt(r){let e=gt(r??null),t=JSON.stringify(e);return Hn(t).slice(0,16)}function Wn(){let r=globalThis.crypto;if(r?.randomUUID)return r.randomUUID();let e=()=>Math.floor(Math.random()*4294967296).toString(16).padStart(8,"0"),t=e()+e()+e()+e();return`${t.slice(0,8)}-${t.slice(8,12)}-4${t.slice(13,16)}-${(parseInt(t.slice(16,17),16)&3|8).toString(16)}${t.slice(17,20)}-${t.slice(20,32)}`}function bt(r,e,t){let n=t?.id??Wn();if(r===0)return{id:n,version:0};let o=(t?.hash??mt)(e);return{id:n,version:0,cid:o,prev:null}}function Ut(r,e,t){r.version+=1,"cid"in r&&(r.prev=r.cid,r.cid=t(e))}var Bn,jn,Kt=$(()=>{"use strict";Bn=new Uint32Array([1116352408,1899447441,3049323471,3921009573,961987163,1508970993,2453635748,2870763221,3624381080,310598401,607225278,1426881987,1925078388,2162078206,2614888103,3248222580,3835390401,4022224774,264347078,604807628,770255983,1249150122,1555081692,1996064986,2554220882,2821834349,2952996808,3210313671,3336571891,3584528711,113926993,338241895,666307205,773529912,1294757372,1396182291,1695183700,1986661051,2177026350,2456956037,2730485921,2820302411,3259730800,3345764771,3516065817,3600352804,4094571909,275423344,430227734,506948616,659060556,883997877,958139571,1322822218,1537002063,1747873779,1955562222,2024104815,2227730452,2361852424,2428436474,2756734187,3204031479,3329325298]),jn=new TextEncoder});function Jt(r){return{node:r,unsub:null,prevData:void 0,dirty:!1,involvedThisWave:!1,dataBatch:[],terminal:void 0}}function yt(r){r.prevData=void 0,r.dirty=!1,r.involvedThisWave=!1,r.dataBatch.length=0,r.terminal=void 0}function qe(r){return r.length===0?r:typeof r[0]=="symbol"?[r]:r}function ee(r,e,t){let n=Xt(r)?r:[],s=typeof r=="function"?r:typeof e=="function"?e:void 0,o={};return Xt(r)?o=(vt(e)?e:t)??{}:vt(r)?o=r:o=(vt(e)?e:t)??{},new F(n,s,o)}var qt,Yt,Un,Kn,Ne,F,Xt,vt,ge=$(()=>{"use strict";ht();Be();De();Ce();Ft();Oe();ae();Kt();qt=()=>{},Yt=100;Un=(r,e,t,n)=>{t.direction==="down-in"&&r._onDepMessage(t.depIndex,e)},Kn=(r,e,t,n)=>{let s=r;if(s._status==="completed"||s._status==="errored")return;let o=s._cached,i=o===void 0?[He]:[He,[G,o]];s._status==="dirty"&&i.push(he),Se(e,i,s._config.tierOf)},Ne=new Ke({onMessage:Un,onSubscribe:Kn});$t(Ne);Wt(Ne);F=class r{_optsName;_describeKind;meta;_hasMeta;_config;_deps;_sinks=null;_sinkCount=0;_cached;_status;_cleanup;_store={};_waveHasNewData=!1;_hasNewTerminal=!1;_hasCalledFnOnce=!1;_paused=!1;_pendingWave=!1;_isExecutingFn=!1;_pendingRerun=!1;_rerunDepth=0;_dirtyDepCount=0;_batchPendingMessages=null;_pauseLocks=null;_pauseBuffer=null;_fn;_equals;_resubscribable;_resetOnTeardown;_autoComplete;_autoError;_pausable;_partial;_guard;_extraGuards;_hashFn;_versioning;_versioningLevel;_lastMutation;_inspectorHooks;_actions;constructor(e,t,n){this._config=n.config??Ne,this._config.onMessage,this._optsName=n.name,this._describeKind=n.describeKind,this._equals=n.equals??Object.is,this._resubscribable=n.resubscribable??!1,this._resetOnTeardown=n.resetOnTeardown??!1,this._autoComplete=n.completeWhenDepsComplete??!0,this._autoError=n.errorWhenDepsError??!0,this._pausable=n.pausable??!0,this._guard=n.guard,this._fn=t,this._partial=n.partial??!1,this._cached=n.initial!==void 0?n.initial:void 0,this._status=e.length===0&&t==null&&this._cached!==void 0?"settled":"sentinel",this._hashFn=n.versioningHash??this._config.defaultHashFn??mt;let s=n.versioning??this._config.defaultVersioning;this._versioningLevel=s,this._versioning=s!=null?bt(s,this._cached===void 0?void 0:this._cached,{id:n.versioningId,hash:this._hashFn}):void 0,this._deps=e.map(Jt);let o={};for(let[a,u]of Object.entries(n.meta??{})){let d={initial:u,name:`${n.name??"node"}:meta:${a}`,describeKind:"state",config:this._config};n.guard!=null&&(d.guard=n.guard),n.resubscribable===!0&&(d.resubscribable=!0),o[a]=new r([],void 0,d)}Object.freeze(o),this.meta=o,this._hasMeta=Object.keys(o).length>0;let i=this;this._actions={emit(a){i._emit([[G,a]])},down(a){i._emit(qe(a))},up(a){i._emitUp(qe(a))}},this.down=this.down.bind(this),this.up=this.up.bind(this)}get _isTerminal(){return this._status==="completed"||this._status==="errored"}get name(){return this._optsName}get status(){return this._status}get cache(){return this._cached===void 0?void 0:this._cached}get lastMutation(){return this._lastMutation}get v(){return this._versioning}hasGuard(){return this._guard!=null}_applyVersioning(e,t){if(this._isExecutingFn)throw new Error(`Node "${this.name}": _applyVersioning cannot run mid-fn \u2014 call it outside of \`_execFn\` (typically at graph setup time before the first subscribe).`);let n=this._versioningLevel;if(n!=null&&e<=n)return;let s=t?.hash??this._hashFn;s!==this._hashFn&&(this._hashFn=s);let o=this._cached===void 0?void 0:this._cached,i=this._versioning,a=i?.id??t?.id,u=i?.version??0,d=bt(e,o,{id:a,hash:s});d.version=u,this._versioning=d,this._versioningLevel=e}_setInspectorHook(e){return e==null?()=>{}:(this._inspectorHooks==null&&(this._inspectorHooks=new Set),this._inspectorHooks.add(e),()=>{this._inspectorHooks?.delete(e),this._inspectorHooks?.size===0&&(this._inspectorHooks=void 0)})}_pushGuard(e){return this._extraGuards==null&&(this._extraGuards=new Set),this._extraGuards.add(e),()=>{this._extraGuards?.delete(e),this._extraGuards?.size===0&&(this._extraGuards=void 0)}}allowsObserve(e){if(this._guard==null&&this._extraGuards==null)return!0;let t=ze(e);if(this._guard!=null&&!this._guard(t,"observe"))return!1;if(this._extraGuards!=null){for(let n of this._extraGuards)if(!n(t,"observe"))return!1}return!0}_checkGuard(e){if(e?.internal)return;let t=this._guard!=null||this._extraGuards!=null,n=e?.actor!=null;if(!t&&!n)return;let s=ze(e?.actor),o=e?.delivery==="signal"?"signal":"write";if(this._guard!=null&&!this._guard(s,o))throw new J({actor:s,action:o,nodeName:this.name});if(this._extraGuards!=null){for(let i of this._extraGuards)if(!i(s,o))throw new J({actor:s,action:o,nodeName:this.name})}this._lastMutation={actor:s,timestamp_ns:we()}}down(e,t){let n=qe(e);n.length!==0&&(this._checkGuard(t),this._emit(n))}emit(e,t){this._checkGuard(t),this._emit([[G,e]])}up(e,t){if(this._deps.length===0)return;let n=qe(e);if(n.length===0)return;this._checkGuard(t);let s=t??{internal:!0};this._validateUpTiers(n);for(let o of this._deps)o.node.up?.(n,s)}_emitUp(e){if(this._deps.length!==0&&e.length!==0){this._validateUpTiers(e);for(let t of this._deps)t.node.up?.(e,{internal:!0})}}_validateUpTiers(e){let t=this._config.tierOf;for(let n of e){let s=t(n[0]);if(s===3||s===4)throw new Error(`Node "${this.name}": tier-${s} messages cannot flow up \u2014 DATA/RESOLVED/COMPLETE/ERROR are downstream-only. Use \`down(...)\` for value delivery; \`up(...)\` is for control signals (DIRTY, INVALIDATE, PAUSE, RESUME, TEARDOWN).`)}}subscribe(e,t){if(t!=null&&this._guard!=null){let u=ze(t);if(!this._guard(u,"observe"))throw new J({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)yt(u);if(this._partial===!1){for(let u of this._deps)if(u.prevData!==void 0||u.dataBatch.length!==0||u.terminal!==void 0||u.dirty)throw new Error(`resubscribable-reset invariant: DepRecord not fully reset for node ${this._optsName??"(anonymous)"}`)}}this._sinkCount+=1;let o;try{o=this._config.onSubscribe(this,e,{sinkCount:this._sinkCount,afterTerminalReset:s},this._actions)}catch(u){throw this._sinkCount-=1,u}this._sinks==null?this._sinks=e:typeof this._sinks=="function"?this._sinks=new Set([this._sinks,e]):this._sinks.add(e);let i=this._isTerminal;if(this._sinkCount===1&&!i)try{this._activate()}catch(u){if(this._sinkCount-=1,this._removeSink(e),this._sinkCount===0&&(this._status="sentinel"),typeof o=="function")try{o()}catch{}throw u}this._status==="sentinel"&&this._cached===void 0&&(this._status="pending");let a=!1;return()=>{a||(a=!0,this._sinkCount-=1,this._removeSink(e),typeof o=="function"&&o(),this._sinks==null&&this._deactivate())}}_removeSink(e){if(this._sinks===e)this._sinks=null;else if(this._sinks!=null&&typeof this._sinks!="function")if(this._sinks.delete(e),this._sinks.size===1){let[t]=this._sinks;this._sinks=t}else this._sinks.size===0&&(this._sinks=null)}_activate(){if(this._deps.length===0){this._fn&&this._execFn();return}this._dirtyDepCount=0;let e=this._deps.length,t=0;try{for(let n=0;n<e;n++){let s=n,o=this._deps[n];o.unsub=qt,o.unsub=o.node.subscribe(i=>{if(o.unsub===null)return;let a=this._config.tierOf,u=!1;for(let d of i)a(d[0])>=3&&(u=!0),this._config.onMessage(this,d,{direction:"down-in",depIndex:s},this._actions);u&&this._maybeRunFnOnSettlement()}),t++}}catch(n){this._deps[t].unsub=null;for(let s=0;s<t;s++){let o=this._deps[s];if(o.unsub!=null){let i=o.unsub;o.unsub=null;try{i()}catch{}yt(o)}}throw this._dirtyDepCount=0,n}}_addDep(e){for(let s=0;s<this._deps.length;s++)if(this._deps[s].node===e)return s;let t=this._deps.length,n=Jt(e);if(this._deps.push(n),this._sinks==null)return t;n.dirty=!0,this._dirtyDepCount++,this._status!=="dirty"&&this._emit(We),n.unsub=qt;try{n.unsub=e.subscribe(s=>{if(n.unsub===null)return;let o=this._config.tierOf,i=!1;for(let a of s)o(a[0])>=3&&(i=!0),this._config.onMessage(this,a,{direction:"down-in",depIndex:t},this._actions);i&&this._maybeRunFnOnSettlement()})}catch(s){throw n.unsub=null,this._deps.pop(),this._dirtyDepCount--,s}return t}_deactivate(e=!1){let t=this._cleanup;if(this._cleanup=void 0,typeof t=="function")try{t()}catch(n){this._emit([[C,this._wrapFnError("cleanup threw",n)]])}else if(t!=null&&typeof t=="object"){let n=t.deactivate;if(typeof n=="function")try{n()}catch(s){this._emit([[C,this._wrapFnError("cleanup.deactivate threw",s)]])}}for(let n of this._deps){if(n.unsub!=null){let s=n.unsub;n.unsub=null;try{s()}catch{}}yt(n)}this._waveHasNewData=!1,this._hasNewTerminal=!1,this._hasCalledFnOnce=!1,this._paused=!1,this._pendingWave=!1,this._pendingRerun=!1,this._rerunDepth=0,this._store={},this._dirtyDepCount=0,this._pauseLocks=null,this._pauseBuffer=null,this._fn!=null&&(this._cached=void 0),e||(this._fn!=null||this._deps.length>0)&&(!this._isTerminal||this._resubscribable)&&(this._status="sentinel")}_onDepMessage(e,t){let n=this._deps[e],s=t[0];if(this._inspectorHooks!=null){let o={kind:"dep_message",depIndex:e,message:t};for(let i of this._inspectorHooks)i(o)}if(s!==fe){if(s===B){this._depDirtied(n);return}if(s===Y){if(this._depInvalidated(n),this._cached===void 0)return;this._emit(ct);return}if(s===Q||s===se){this._emit([t]);return}if(s===z){this._emit(Ue);return}if(s===G)this._depSettledAsData(n,t[1]);else if(s===H)this._depSettledAsResolved(n);else if(s===L)this._depSettledAsTerminal(n,!0);else if(s===C)this._depSettledAsTerminal(n,t[1]);else{this._emit([t]);return}if(!this._fn){(s===G||s===H)&&this._emit([t]),(s===L||s===C)&&this._maybeAutoTerminalAfterWave();return}}}_depDirtied(e){e.dirty||(e.dirty=!0,e.involvedThisWave=!0,this._dirtyDepCount++,this._status!=="dirty"&&this._emit(We))}_depSettledAsData(e,t){e.dirty&&(e.dirty=!1,this._dirtyDepCount--),e.involvedThisWave=!0,e.dataBatch.push(t),this._waveHasNewData=!0}_depSettledAsResolved(e){e.dirty&&(e.dirty=!1,this._dirtyDepCount--)}_depSettledAsTerminal(e,t){e.dirty&&(e.dirty=!1,this._dirtyDepCount--),e.terminal=t,e.involvedThisWave=!0,this._hasNewTerminal=!0}_depInvalidated(e){e.prevData=void 0,e.terminal=void 0,e.dataBatch.length=0,e.dirty?e.involvedThisWave=!1:(e.dirty=!0,e.involvedThisWave=!0,this._dirtyDepCount++)}_maybeRunFnOnSettlement(){if(!(this._isTerminal&&!this._resubscribable)&&!(this._dirtyDepCount>0)){if(!this._partial&&!this._hasCalledFnOnce)for(let e=0;e<this._deps.length;e++){let t=this._deps[e];if(t.dataBatch.length===0&&t.prevData===void 0&&t.terminal===void 0){this._maybeAutoTerminalAfterWave();return}}if(this._paused){this._pendingWave=!0;return}if(!this._waveHasNewData&&!this._hasNewTerminal&&this._hasCalledFnOnce){this._clearWaveFlags(),this._emit(dt),this._maybeAutoTerminalAfterWave();return}this._fn&&this._execFn(),this._maybeAutoTerminalAfterWave()}}_maybeAutoTerminalAfterWave(){if(this._deps.length===0||this._isTerminal)return;let e=this._deps.find(t=>t.terminal!==void 0&&t.terminal!==!0);if(e!=null){this._autoError&&this._emit([[C,e.terminal]]);return}this._autoComplete&&this._deps.every(t=>t.terminal!==void 0)&&this._emit(lt)}_execFn(){if(!this._fn||this._isTerminal&&!this._resubscribable)return;if(this._isExecutingFn){this._pendingRerun=!0;return}let e=this._cleanup;if(typeof e=="function"){this._cleanup=void 0;try{e()}catch(i){this._emit([[C,this._wrapFnError("cleanup threw",i)]]);return}}else if(e!=null&&typeof e=="object"){let i=e.beforeRun;if(typeof i=="function"){e.beforeRun=void 0;try{i()}catch(a){this._emit([[C,this._wrapFnError("cleanup.beforeRun threw",a)]]);return}}}let t=this._deps.map(i=>i.involvedThisWave?i.dataBatch.length>0?[...i.dataBatch]:[]:void 0),n=this._deps.map(i=>i.prevData);for(let i=0;i<this._deps.length;i++){let a=t[i];a!=null&&a.length>0&&(this._deps[i].prevData=a[a.length-1])}let s=this._deps.map(i=>i.terminal),o={prevData:n,terminalDeps:s,store:this._store};if(this._hasCalledFnOnce=!0,this._clearWaveFlags(),this._inspectorHooks!=null){let i={kind:"run",batchData:t,prevData:n};for(let a of this._inspectorHooks)a(i)}this._isExecutingFn=!0;try{let i=this._fn(t,this._actions,o);if(typeof i=="function")this._cleanup=i;else if(i!=null&&typeof i=="object"){let a=i;(typeof a.beforeRun=="function"||typeof a.deactivate=="function"||typeof a.invalidate=="function")&&(this._cleanup=i)}}catch(i){this._emit([[C,this._wrapFnError("fn threw",i)]])}finally{this._isExecutingFn=!1,this._pendingRerun?(this._pendingRerun=!1,this._rerunDepth+=1,this._rerunDepth>Yt?(this._rerunDepth=0,this._emit([[C,new Error(`Node "${this.name}": _pendingRerun depth exceeded ${Yt} \u2014 likely a reactive cycle`)]])):this._maybeRunFnOnSettlement()):this._rerunDepth=0,this._clearWaveFlags()}}_clearWaveFlags(){this._waveHasNewData=!1,this._hasNewTerminal=!1;for(let e of this._deps)e.involvedThisWave=!1,e.dataBatch.length=0}_wrapFnError(e,t){let n=t instanceof Error?t.message:String(t);return new Error(`Node "${this.name}": ${e}: ${n}`,{cause:t})}_frameBatch(e){let t=this._config.tierOf;if(e.length===1)return t(e[0][0])===3&&this._status!=="dirty"?[he,e[0]]:e;let n=!0,s=!1,o=!1,i=-1;for(let u of e){let d=t(u[0]);d<i&&(n=!1),d===3&&(s=!0),u[0]===B&&(o=!0),i=d}let a=e;if(!n){let u=e.map((d,c)=>({m:d,i:c,tier:t(d[0])}));u.sort((d,c)=>d.tier-c.tier||d.i-c.i),a=u.map(d=>d.m)}if(s&&!o&&this._status!=="dirty"){let u=0;for(;u<a.length&&t(a[u][0])===0;)u++;return u===0?[he,...a]:[...a.slice(0,u),he,...a.slice(u)]}return a}_emit(e){if(e.length===0)return;for(let a=0;a<e.length;a++){let u=e[a];if(u[0]===C&&u[1]===void 0)throw new TypeError('[ERROR, payload] requires a non-undefined payload (spec \xA71.2). Pass an Error object or domain tag instead \u2014 e.g. node.down([[ERROR, new Error("reason")]])')}let t=e;if(this._isTerminal&&!this._resubscribable){let a=e.filter(u=>u[0]===z||u[0]===Y);if(a.length===0)return;t=a}t=this._frameBatch(t);let s=null;for(let a=0;a<t.length;a++){let u=t[a],d=u[0];if(d!==Q&&d!==se){s?.push(u);continue}if(u.length<2)throw new Error(`Node "${this.name}": [[${d===Q?"PAUSE":"RESUME"}]] must carry a lockId payload \u2014 bare PAUSE/RESUME is a protocol violation (C0 rule). Use \`[[PAUSE, lockId]]\` / \`[[RESUME, lockId]]\`.`);let c=!0;if(this._pausable!==!1){let f=u[1];if(d===Q)this._pauseLocks==null&&(this._pauseLocks=new Set),this._pauseLocks.add(f),this._paused=!0,this._pausable==="resumeAll"&&this._pauseBuffer==null&&(this._pauseBuffer=[]);else if(this._pauseLocks==null||!this._pauseLocks.has(f))c=!1;else if(this._pauseLocks.delete(f),this._pauseLocks.size===0){if(this._paused=!1,this._pauseBuffer!=null&&this._pauseBuffer.length>0){let p=this._pauseBuffer;this._pauseBuffer=[],this._emit(p)}this._pendingWave&&(this._pendingWave=!1,this._maybeRunFnOnSettlement())}}c?s?.push(u):s==null&&(s=t.slice(0,a))}if(s!=null){if(s.length===0)return;t=s}if(this._hasMeta&&t.some(a=>a[0]===z))for(let a of Object.keys(this.meta))try{this.meta[a]._emit(Ue)}catch{}let{finalMessages:o,equalsError:i}=this._updateState(t);if(o.length>0&&this._config.inspectorEnabled){let a=this._config.globalInspector;if(a!=null)try{a({kind:"emit",node:this,messages:o})}catch{}}if(o.length>0)if(this._paused&&this._pausable==="resumeAll"&&this._pauseBuffer!=null){let a=this._config.tierOf,u=[];for(let d of o)a(d[0])===3?this._pauseBuffer.push(d):u.push(d);u.length>0&&this._dispatchOrAccumulate(u)}else this._dispatchOrAccumulate(o);i!=null&&this._emit([[C,i]])}_updateState(e){let t=this._config.tierOf,n,s,o=-1,i=0;for(let c of e)t(c[0])===3&&i++;let a=i<=1,u=-1;if(this._versioning!=null&&i>1){for(let c=e.length-1;c>=0;c--)if(e[c][0]===G){u=c;break}}for(let c=0;c<e.length;c++){let f=e[c],p=f[0];if(p===G){if(f.length>=2){let h=!1;if(a&&this._cached!==void 0)try{h=this._equals(this._cached,f[1])}catch(l){s=this._wrapFnError("equals threw",l),o=c;break}if(h){n==null&&(n=e.slice(0,c)),n.push(je),this._status="resolved";continue}this._cached=f[1],this._versioning!=null&&(u<0||c===u)&&Ut(this._versioning,f[1],this._hashFn)}this._status="settled",n?.push(f)}else if(n?.push(f),p===B)this._status="dirty";else if(p===H)this._status="resolved";else if(p===L){this._status="completed";{let h=this._config.rigorRecorder;if(h!=null)try{h.onTerminalTransition(this,"completed",this._autoComplete,this._autoError,this._deps.length>0)}catch{}}}else if(p===C){this._status="errored";{let h=this._config.rigorRecorder;if(h!=null)try{h.onTerminalTransition(this,"errored",this._autoComplete,this._autoError,this._deps.length>0)}catch{}}}else if(p===Y){if(this._cached!==void 0){let l=this._config.rigorRecorder;if(l!=null)try{l.onNonVacuousInvalidate(this,this._cached)}catch{}}this._cached=void 0,this._status="dirty";let h=this._cleanup;if(typeof h=="function"){this._cleanup=void 0;try{h()}catch{}}else if(h!=null&&typeof h=="object"){let l=h.invalidate;if(typeof l=="function")try{l()}catch{}}}else p===z&&(this._resetOnTeardown&&(this._cached=void 0),this._deactivate(!0),this._status="sentinel")}let d=o>=0?n??e.slice(0,o):n??e;return s!=null?{finalMessages:d,equalsError:s}:{finalMessages:d}}_deliverToSinks=e=>{if(this._sinks==null)return;if(typeof this._sinks=="function"){this._sinks(e);return}let t=[...this._sinks];for(let n of t)n(e)};_dispatchOrAccumulate(e){if(Gt()){this._batchPendingMessages===null&&(this._batchPendingMessages=[],Te(()=>this._flushBatchPending()));for(let t of e)this._batchPendingMessages.push(t);return}Se(this._deliverToSinks,e,this._config.tierOf)}_flushBatchPending(){let e=this._batchPendingMessages;if(e===null||(this._batchPendingMessages=null,e.length===0))return;let t=this._frameBatch(e);Se(this._deliverToSinks,t,this._config.tierOf)}},Xt=r=>Array.isArray(r),vt=r=>typeof r=="object"&&r!=null&&!Array.isArray(r)});function _t(r,e){if(e!=null&&e.length>0)return new Set(e);switch(r){case"standard":return new Set(["type","status","value","deps","meta","v"]);case"full":return null;case"spec":return new Set(["type","deps","meta","value"]);default:return new Set(["type","deps"])}}function qn(r){return r._describeKind!=null?r._describeKind:r._deps.length>0?"derived":r._fn!=null?"producer":"state"}function Yn(r){let e={};for(let[t,n]of Object.entries(r.meta))try{e[t]=n.cache}catch{}return e}function Tt(r,e,t){let n=e==null,s=!n&&e!=null?[...e].filter(c=>c.startsWith("meta.")).map(c=>c.slice(5)):null,o=n||e.has("meta")||s!=null&&s.length>0,i="state",a=[];r instanceof F&&(i=qn(r),a=r._deps.map(c=>c.node.name??""));let u={type:i,deps:a};(n||e.has("status"))&&(u.status=r.status);let d=r instanceof F?r._guard:void 0;if(o){let c={...Yn(r)};if(d!=null&&c.access===void 0&&(c.access=pt(d)),s!=null&&s.length>0&&!e.has("meta")){let f={};for(let p of s)p in c&&(f[p]=c[p]);u.meta=f}else u.meta=c}if(r.name!=null&&(u.name=r.name),(n||e.has("value"))&&(!t||i==="state")){r.status==="sentinel"&&(u.sentinel=!0);try{u.value=r.cache}catch{}}if((n||e.has("v"))&&r.v!=null){let c={id:r.v.id,version:r.v.version};"cid"in r.v&&(c.cid=r.v.cid,c.prev=r.v.prev),u.v=c}return(n||e.has("guard"))&&d!=null&&(u.guard=pt(d)),(n||e.has("lastMutation"))&&r.lastMutation!=null&&(u.lastMutation=r.lastMutation),u}var Zt=$(()=>{"use strict";Oe();ge()});function U(r,e){return ee([],{...e,initial:r})}function ue(r,e){return ee((n,s,o)=>r(s,o)??void 0,{describeKind:"producer",...e})}function W(r,e,t){return ee(r,(s,o,i)=>{let a=s.map((u,d)=>u!=null&&u.length>0?u.at(-1):i.prevData[d]);o.emit(e(a,i))},{describeKind:"derived",...t})}function wt(r,e,t){return ee(r,(s,o,i)=>{let a=s.map((u,d)=>u!=null&&u.length>0?u.at(-1):i.prevData[d]);return e(a,o,i)??void 0},{describeKind:"effect",...t})}var Me=$(()=>{"use strict";ge()});function Qt(r,e,t){return{[r]:!0,[`${r}_type`]:e,...t??{}}}var en=$(()=>{"use strict"});function Ot(r,e){if(Object.is(r,e))return!0;if(r==null||e==null||typeof r!="object"||typeof e!="object")return!1;if(Array.isArray(r)){if(!Array.isArray(e)||r.length!==e.length)return!1;for(let o=0;o<r.length;o++)if(!Ot(r[o],e[o]))return!1;return!0}if(Array.isArray(e))return!1;let t=Object.keys(r),n=Object.keys(e);if(t.length!==n.length)return!1;let s=new Set(n);for(let o of t)if(!s.has(o)||!Ot(r[o],e[o]))return!1;return!0}function tn(r,e){return`${r}\0${e}`}function Nt(r,e){let t=[],n=new Set(r.subgraphs),s=new Set(e.subgraphs),o=[];for(let g of s)n.has(g)||o.push(g);o.sort();for(let g of o)t.push({type:"subgraph-mounted",path:g});let i=new Set(Object.keys(r.nodes)),a=new Set(Object.keys(e.nodes)),u=[];for(let g of a)i.has(g)||u.push(g);u.sort();for(let g of u)t.push({type:"node-added",path:g,node:{...e.nodes[g]}});let d=[];for(let g of a){if(!i.has(g))continue;let O=r.nodes[g]?.meta,v=e.nodes[g]?.meta;O==null&&v==null||Ot(O??{},v??{})||d.push(g)}d.sort();for(let g of d)t.push({type:"node-meta-changed",path:g,prevMeta:r.nodes[g]?.meta??{},nextMeta:e.nodes[g]?.meta??{}});let c=new Map;for(let g of r.edges)c.set(tn(g.from,g.to),g);let f=new Map;for(let g of e.edges)f.set(tn(g.from,g.to),g);let p=[];for(let[g,O]of f)c.has(g)||p.push(O);p.sort((g,O)=>g.from<O.from?-1:g.from>O.from?1:g.to<O.to?-1:g.to>O.to?1:0);for(let g of p)t.push({type:"edge-added",from:g.from,to:g.to});let h=[];for(let[g,O]of c)f.has(g)||h.push(O);h.sort((g,O)=>g.from<O.from?-1:g.from>O.from?1:g.to<O.to?-1:g.to>O.to?1:0);for(let g of h)t.push({type:"edge-removed",from:g.from,to:g.to});let l=[];for(let g of i)a.has(g)||l.push(g);l.sort();for(let g of l)t.push({type:"node-removed",path:g});let y=[];for(let g of n)s.has(g)||y.push(g);y.sort();for(let g of y)t.push({type:"subgraph-unmounted",path:g});return{events:t,flushedAt_ns:re()}}var nn=$(()=>{"use strict";Ce()});function xt(r){return{describeKind:"producer",...r}}function rn(r,e){return ue(t=>{let n=!1;try{for(let s of r){if(n)return;t.emit(s)}n||t.down([[L]])}catch(s){n||t.down([[C,s]])}return()=>{n=!0}},xt(e))}function Jn(r){return r!=null&&typeof r.then=="function"}function Xn(r,e){let{signal:t,...n}=e??{};return ue(s=>{let o=!1,i=()=>{o||(o=!0,s.down([[C,t.reason]]))};if(t?.aborted){i();return}return t?.addEventListener("abort",i,{once:!0}),Promise.resolve(r).then(a=>{o||(o=!0,t?.removeEventListener("abort",i),s.emit(a),s.down([[L]]))},a=>{o||(o=!0,t?.removeEventListener("abort",i),s.down([[C,a]]))}),()=>{o=!0,t?.removeEventListener("abort",i)}},xt(n))}function Zn(r,e){let{signal:t,...n}=e??{};return ue(s=>{let o=new AbortController,i=()=>o.abort(t?.reason);t?.aborted?o.abort(t.reason):t?.addEventListener("abort",i,{once:!0});let a=t??o.signal,u=!1,d=r[Symbol.asyncIterator](),c=()=>{u||a.aborted||Promise.resolve(d.next()).then(f=>{if(!(u||a.aborted)){if(f.done){s.down([[L]]);return}s.emit(f.value),c()}},f=>{!u&&!a.aborted&&s.down([[C,f]])})};return c(),()=>{u=!0,t?.removeEventListener("abort",i),o.abort(),Promise.resolve(d.return?.()).catch(()=>{})}},xt(n))}function Qn(r){return r!=null&&typeof r=="object"&&"cache"in r&&typeof r.subscribe=="function"}function sn(r,e){if(Qn(r))return r;if(Jn(r))return Xn(r,e);if(r!=null){let t=r;if(typeof t[Symbol.asyncIterator]=="function")return Zn(r,e);if(typeof t[Symbol.iterator]=="function")return rn(r,e)}return er(r)}function er(...r){return rn(r,void 0)}function X(r){return r.subscribe(()=>{})}var on=$(()=>{"use strict";ae();Me()});var kt=$(()=>{"use strict";on()});var Ye,an=$(()=>{"use strict";Ye=class{_timer;_gen=0;start(e,t){this.cancel(),this._gen+=1;let n=this._gen;this._timer=setTimeout(()=>{this._timer=void 0,n===this._gen&&t()},e)}cancel(){this._timer!==void 0&&(clearTimeout(this._timer),this._timer=void 0)}get pending(){return this._timer!==void 0}}});var Ge,un=$(()=>{"use strict";Ge=class{constructor(e){this.capacity=e;if(!Number.isInteger(e)||e<=0)throw new Error(`RingBuffer capacity must be a positive integer (got ${e})`);this.buf=new Array(e)}buf;head=0;_size=0;get size(){return this._size}get maxSize(){return this.capacity}push(e){let t=(this.head+this._size)%this.capacity;this.buf[t]=e,this._size<this.capacity?this._size++:this.head=(this.head+1)%this.capacity}shift(){if(this._size===0)return;let e=this.buf[this.head];return this.buf[this.head]=void 0,this.head=(this.head+1)%this.capacity,this._size--,e}at(e){if(this._size===0)return;let t=e<0?this._size+e:e;if(!(t<0||t>=this._size))return this.buf[(this.head+t)%this.capacity]}toArray(){let e=new Array(this._size);for(let t=0;t<this._size;t++)e[t]=this.buf[(this.head+t)%this.capacity];return e}clear(){for(let e=0;e<this._size;e++)this.buf[(this.head+e)%this.capacity]=void 0;this.head=0,this._size=0}}});function dn(r,e,t,n={}){let s=e in r.nodes,o=t in r.nodes;if(!s)return Je(e,t,"no-such-from");if(!o)return Je(e,t,"no-such-to");let i=n.maxDepth;if(i!=null&&(!Number.isInteger(i)||i<0))throw new Error("explainPath: maxDepth must be an integer >= 0");if(e===t){if(n.findCycle===!0){let d=tr(r,e,n);if(d!=null)return d}let u=Xe(e,r.nodes[e],0,n);return Ze(e,t,[u])}if(i===0)return Je(e,t,"no-path");let a=cn(r,e,t,i);return a.found?Ze(e,t,ln(r,a.pathOrder,n)):Je(e,t,a.truncated?"max-depth-exceeded":"no-path")}function cn(r,e,t,n){let s=new Map,o=[{path:t,depth:0}],i=new Set([t]),a=0,u=!1;for(;a<o.length;){let f=o[a++];if(f.path===e)break;if(n!=null&&f.depth>=n){let y=r.nodes[f.path];y?.deps&&y.deps.length>0&&(u=!0);continue}let p=r.nodes[f.path];if(p==null)continue;let h=p.deps??[],l=new Map;for(let y=0;y<h.length;y++){let g=h[y];if(!g)continue;let O=l.get(g);O==null&&(O=[],l.set(g,O)),O.push(y)}for(let[y,g]of l)i.has(y)||(i.add(y),s.set(y,{from:f.path,depIndices:g}),o.push({path:y,depth:f.depth+1}))}if(!s.has(e))return{found:!1,pathOrder:[],truncated:u};let d=[{path:e}],c=e;for(;c!==t;){let f=s.get(c);if(f==null)return{found:!1,pathOrder:[],truncated:!1};d[d.length-1].depIndices=f.depIndices,d.push({path:f.from}),c=f.from}return{found:!0,pathOrder:d,truncated:!1}}function tr(r,e,t){let n=r.nodes[e];if(n==null)return null;let s=n.deps??[],o=[];for(let a=0;a<s.length;a++)s[a]===e&&o.push(a);if(o.length>0){let a=Xe(e,n,0,t);a.dep_index=o[0];let u=Xe(e,n,1,t);return Ze(e,e,[a,u])}let i=null;for(let a=0;a<s.length;a++){let u=s[a];if(!u||u===e)continue;let d=cn(r,u,e,t.maxDepth);d.found&&(i==null||d.pathOrder.length<i.pathOrder.length)&&(i=d,i={found:!0,pathOrder:[{path:e,depIndices:[a]},...d.pathOrder],truncated:!1})}return i==null?null:Ze(e,e,ln(r,i.pathOrder,t))}function ln(r,e,t){return e.map((n,s)=>{let o=r.nodes[n.path],i=Xe(n.path,o,s,t);return n.depIndices!=null&&n.depIndices.length>0&&(i.dep_index=n.depIndices[0],n.depIndices.length>1&&(i.dep_indices=[...n.depIndices])),i})}function Xe(r,e,t,n){let s={path:r,type:e.type,hop:t};e.status!==void 0&&(s.status=e.status),"value"in e&&(s.value=e.value),e.v!=null&&(s.v=e.v);let o=n.annotations?.get(r)??e.annotation;o!=null&&(s.annotation=o);let i=n.lastMutations?.get(r)??e.lastMutation;return i!=null&&(s.lastMutation=i),s}function Ze(r,e,t){return pn(r,e,!0,"ok",t)}function Je(r,e,t){return pn(r,e,!1,t,[])}function pn(r,e,t,n,s){let o=nr(r,e,t,n,s);return{from:r,to:e,found:t,reason:n,steps:s,text:o,toJSON(){return{from:r,to:e,found:t,reason:n,steps:s}}}}function nr(r,e,t,n,s){if(!t)switch(n){case"no-such-from":return`explainPath: no node named "${r}"`;case"no-such-to":return`explainPath: no node named "${e}"`;case"max-depth-exceeded":return`explainPath: no path from "${r}" to "${e}" within maxDepth`;default:return`explainPath: no path from "${r}" to "${e}"`}let o=[`Causal path: ${r} \u2192 ${e} (${s.length} step(s))`];for(let i of s){let u=` ${i.hop===0?"\xB7":"\u2193"} ${i.path} (${i.type}${i.status?`/${i.status}`:""})`;if(o.push(u),"value"in i&&o.push(` value: ${rr(i.value)}`),i.annotation!=null&&o.push(` annotation: ${i.annotation}`),i.lastMutation!=null){let d=i.lastMutation.actor;o.push(` actor: ${d.type}${d.id?`:${d.id}`:""}`)}}return o.join(`
2
- `)}function rr(r){if(r===void 0)return"<sentinel>";if(r===null)return"null";if(typeof r=="string")return JSON.stringify(r);if(typeof r=="number"||typeof r=="boolean"||typeof r=="bigint")return String(r);try{let e=JSON.stringify(r);return e.length>80?`${e.slice(0,77)}...`:e}catch{return String(r)}}var fn=$(()=>{"use strict"});function hn(r){let e=new WeakSet,t=new WeakSet,n=[r],s=0;for(;n.length>0;){let o=n.pop();s+=or(o,e,t,n)}return s}function or(r,e,t,n){if(r==null)return 0;switch(typeof r){case"number":return V.number;case"boolean":return V.boolean;case"string":return V.string+r.length*2;case"bigint":return V.bigint+ir(r);case"symbol":return V.symbol;case"function":return e.has(r)?0:(e.add(r),V.function);case"undefined":return 0}let o=r;if(e.has(o))return 0;e.add(o);let i=o[sr];if(typeof i=="function")try{let d=i.call(o);if(typeof d=="number"&&Number.isFinite(d))return d}catch{}if(o instanceof Date)return V.date;if(o instanceof RegExp)return V.regexp+o.source.length*2;if(o instanceof Error){let d=o.message?o.message.length*2:0,c=o.stack?o.stack.length*2:0;return V.error+d+c}if(typeof URL<"u"&&o instanceof URL)return V.url+o.href.length*2;if(typeof Promise<"u"&&o instanceof Promise)return V.promise;if(o instanceof WeakMap)return V.weakmap;if(o instanceof WeakSet)return V.weakset;if(o instanceof Map){let d=V.map;for(let[c,f]of o)d+=V.mapEntry,n.push(c),n.push(f);return d}if(o instanceof Set){let d=V.set;for(let c of o)d+=V.setEntry,n.push(c);return d}if(Array.isArray(o)){let d=V.array+o.length*8;for(let c of o)n.push(c);return d}if(o instanceof ArrayBuffer)return t.has(o)?0:(t.add(o),o.byteLength);if(ArrayBuffer.isView(o)){let d=o;return t.has(d.buffer)?48:(t.add(d.buffer),d.buffer.byteLength+48)}let a=V.object,u=Object.keys(o);for(let d of u){a+=V.string+d.length*2;try{n.push(o[d])}catch{}}return a}function ir(r){let e=r<0n?-r:r;if(e===0n)return 0;let t=e.toString(2).length;return Math.ceil(t/32)*8}var V,sr,gn=$(()=>{"use strict";V={object:56,array:64,string:40,number:8,boolean:4,null:0,undefined:0,symbol:40,bigint:16,function:120,map:72,set:72,mapEntry:40,setEntry:24,date:24,regexp:48,error:64,url:80,promise:48,weakmap:40,weakset:40},sr=Symbol.for("sizeof")});function mn(r,e){let t=e?.topN??10,n=r.describe({detail:"standard"}),s=[],o=r._collectObserveTargets;typeof o=="function"&&o.call(r,"",s);let i=new Map;for(let[p,h]of s)i.set(p,h);let a=[];for(let[p,h]of Object.entries(n.nodes)){let l=i.get(p),y=l instanceof F?l:null,g=y?hn(y.cache):0,O=y?y._sinkCount:0,v=h.deps?.length??0,b=h.type==="effect"&&O===0,_=O===0?h.type==="effect"?"orphan-effect":h.type==="derived"?"idle-derived":h.type==="producer"?"idle-producer":null:null;a.push({path:p,type:h.type,status:h.status??"unknown",valueSizeBytes:g,subscriberCount:O,depCount:v,isOrphanEffect:b,orphanKind:_})}let u=a.reduce((p,h)=>p+h.valueSizeBytes,0),d=(p,h)=>[...a].sort(h??((l,y)=>y[p]-l[p])).slice(0,t),c=a.filter(p=>p.orphanKind!=null),f=a.filter(p=>p.isOrphanEffect);return{nodeCount:a.length,edgeCount:n.edges.length,subgraphCount:n.subgraphs.length,nodes:a,totalValueSizeBytes:u,hotspots:{byValueSize:d("valueSizeBytes"),bySubscriberCount:d("subscriberCount"),byDepCount:d("depCount")},orphans:c,orphanEffects:f}}var bn=$(()=>{"use strict";ge();gn()});function Qe(r,e){let t=Math.max(16,r.size*4),n=0;for(;r.size>0;){if(n++>=t){console.error(`[Graph "${e}".destroy] disposer drain exceeded cap (${t}); ${r.size} disposer(s) discarded`),r.clear();return}let s=r.values().next();if(s.done)return;let o=s.value;r.delete(o);try{o()}catch(i){console.error(`[Graph "${e}".destroy] disposer threw:`,i)}}}function wn(r){return r!=null&&typeof r=="object"&&"cache"in r&&typeof r.subscribe=="function"&&typeof r.down=="function"}function ar(r){if(r!=null)return wn(r)?r.cache:r}function be(r){return r!=null&&typeof r=="object"&&"cache"in r&&typeof r.subscribe=="function"&&typeof r.down=="function"}function de(r){return be(r)?r.cache??"":r}function yn(r){return be(r)?r.cache??0:r}function vn(r){return be(r)?r.cache??!1:r}function ur(r){let e=[];for(let t of Object.keys(r).sort()){let n=r[t].v;n!=null&&e.push(`${t} ${n.id} ${n.version}`)}return e.join(`
3
- `)}function _n(r){if(r.version!==me)throw new Error(`unsupported snapshot version ${String(r.version)} (expected ${me})`);for(let e of["name","nodes","edges","subgraphs"])if(!(e in r))throw new Error(`snapshot missing required key "${e}"`);if(typeof r.name!="string")throw new TypeError("snapshot 'name' must be a string");if(typeof r.nodes!="object"||r.nodes===null||Array.isArray(r.nodes))throw new TypeError("snapshot 'nodes' must be an object");if(!Array.isArray(r.edges))throw new TypeError("snapshot 'edges' must be an array");if(!Array.isArray(r.subgraphs))throw new TypeError("snapshot 'subgraphs' must be an array")}function dr(r,e){let t=new WeakMap,n=(s,o)=>{if(Object.is(s,o))return!0;if(s==null||o==null||typeof s!="object"||typeof o!="object")return!1;let i=t.get(s);if(i==null&&(i=new WeakSet,t.set(s,i)),i.has(o))return!0;i.add(o);let a=s.constructor,u=o.constructor;if(a!==u)return!1;if(s instanceof Date)return s.getTime()===o.getTime();if(s instanceof RegExp)return s.source===o.source&&s.flags===o.flags;if(Array.isArray(s)){let p=o;if(s.length!==p.length)return!1;for(let h=0;h<s.length;h++)if(!n(s[h],p[h]))return!1;return!0}if(s instanceof Map){let p=o;if(s.size!==p.size)return!1;for(let[h,l]of s)if(!p.has(h)||!n(l,p.get(h)))return!1;return!0}if(s instanceof Set){let p=o;if(s.size!==p.size)return!1;for(let h of s){let l=!1;for(let y of p)if(n(h,y)){l=!0;break}if(!l)return!1}return!0}if(ArrayBuffer.isView(s)){let p=s,h=o;if(p.length!==h.length)return!1;for(let l=0;l<p.length;l++)if(p[l]!==h[l])return!1;return!0}let d=Object.keys(s),c=Object.keys(o);if(d.length!==c.length)return!1;let f=new Set(c);for(let p of d)if(!f.has(p)||!n(s[p],o[p]))return!1;return!0};return n(r,e)}function cr(r){return r.replace(/[.*+?^${}()|[\]\\]/g,"\\$&")}function et(r){let e="^";for(let t=0;t<r.length;t+=1){let n=r[t];if(n==="*"){e+=".*";continue}if(n==="?"){e+=".";continue}if(n==="["){let s=r.indexOf("]",t+1);if(s<=t+1){e+="\\[";continue}let o=r.slice(t+1,s);o.startsWith("!")&&(o=`^${o.slice(1)}`),o=o.replace(/\\/g,"\\\\"),e+=`[${o}]`,t=s;continue}e+=cr(n)}return e+="$",new RegExp(e)}function Et(r){if(typeof r=="string")return JSON.stringify(r);if(typeof r=="number"||typeof r=="boolean"||r==null)return String(r);try{return JSON.stringify(r)}catch{return"[unserializable]"}}function fr(r){return r==="none"?pr:r==="ansi"||r==null?lr:{data:r.data??"",dirty:r.dirty??"",resolved:r.resolved??"",invalidate:r.invalidate??"",pause:r.pause??"",resume:r.resume??"",complete:r.complete??"",error:r.error??"",teardown:r.teardown??"",derived:r.derived??"",path:r.path??"",reset:r.reset??""}}function Tn(r){if(r==null)return{};let e=r.detail;return e==="full"?{...r,structured:r.structured??!0,timeline:r.timeline??!0,causal:r.causal??!0,derived:r.derived??!0}:e==="minimal"?{...r,structured:r.structured??!0}:r.format==="stage-log"?{...r,structured:r.structured??!0,timeline:r.timeline??!0}:r}function hr(r,e,t){for(let n=0;n<r.length;n++){let s=r.charCodeAt(n);if(s<32||s===127)throw new Error(`Graph "${e}": ${t} "${r}" must not contain control character (U+${s.toString(16).padStart(4,"0").toUpperCase()} at index ${n})`)}}function Rt(r,e,t){if(r==="")throw new Error(`Graph "${e}": ${t} name must be non-empty`);if(r.includes(P))throw new Error(`Graph "${e}": ${t} "${r}" must not contain '${P}' (path separator)`);if(r===Z)throw new Error(`Graph "${e}": ${t} name "${Z}" is reserved for meta companion paths`);hr(r,e,t)}function gr(r,e){if(r==="")throw new Error(`Graph "${e}": resolve path must be non-empty`);let t=r.split(P);for(let n of t)if(n==="")throw new Error(`Graph "${e}": resolve path has empty segment`);return t}function mr(r,e){let t=!1;for(let s of r)if(!e.isMetaPassthrough(s[0])){t=!0;break}return t?r.filter(s=>e.isMetaPassthrough(s[0])):r}function On(r){for(let e of r._mounts.values())On(e);for(let e of r._nodes.values())try{e.down([[z]],{internal:!0})}catch{}}function Nn(r,e){let t=oe.diff(r,e),n={};for(let s of t.nodesAdded){let o=e.nodes[s];o!=null&&(n[s]=o)}return{...t,nodesAddedFull:n}}function At(r,e,t,n={}){let s={paths:[],depths:new Map,truncated:!1};if(!e)return n.withDetail?s:[];if(!n.both&&t!=="upstream"&&t!=="downstream")throw new Error('reachable: direction must be "upstream" or "downstream"');let o=n.maxDepth;if(o!=null&&(!Number.isInteger(o)||o<0))throw new Error("reachable: maxDepth must be an integer >= 0");if(o===0)return n.withDetail?s:[];let i=new Map,a=new Map,u=new Map,d=new Map,c=new Set;for(let[b,_]of Object.entries(r.nodes)){if(!b)continue;c.add(b);let T=_.deps??[];i.set(b,T);for(let x of T)x&&(c.add(x),a.has(x)||a.set(x,new Set),a.get(x).add(b))}for(let b of r.edges){if(b==null||typeof b!="object")continue;let _=typeof b.from=="string"?b.from:"",T=typeof b.to=="string"?b.to:"";!_||!T||(c.add(_),c.add(T),d.has(_)||d.set(_,new Set),d.get(_).add(T),u.has(T)||u.set(T,new Set),u.get(T).add(_))}if(!c.has(e))return n.withDetail?s:[];let f=n.both===!0,p=b=>{if(f){let m=i.get(b)??[],w=u.get(b),k=a.get(b),R=d.get(b),N=[...m];return w&&N.push(...w),k&&N.push(...k),R&&N.push(...R),N}if(t==="upstream"){let m=i.get(b)??[],w=u.get(b);return w?[...m,...w]:m}let _=a.get(b),T=d.get(b),x=_?[..._]:[];return T&&x.push(...T),x},h=new Set([e]),l=new Map,y=[{path:e,depth:0}],g=0,O=!1;for(;g<y.length;){let b=y[g++];if(o!=null&&b.depth>=o){p(b.path).length>0&&(O=!0);continue}for(let _ of p(b.path))!_||h.has(_)||(h.add(_),l.set(_,b.depth+1),y.push({path:_,depth:b.depth+1}))}let v=[...l.keys()].sort((b,_)=>b<_?-1:b>_?1:0);return n.withDetail?{paths:v,depths:l,truncated:O}:v}function br(r,e){if(r.length!==e.length)return!1;for(let t=0;t<r.length;t++){let n=r[t],s=e[t];if(n.path!==s.path||n.type!==s.type||n.status!==s.status||n.hop!==s.hop||n.dep_index!==s.dep_index||n.annotation!==s.annotation||n.value!==s.value||n.lastMutation!==s.lastMutation)return!1;let o=n.v,i=s.v;if(o!==i&&(o==null||i==null||o.id!==i.id||o.version!==i.version))return!1}return!0}var P,Z,me,lr,pr,oe,xn=$(()=>{"use strict";Be();De();Ce();Oe();ae();Zt();ge();Me();nn();kt();an();un();ht();fn();bn();P="::",Z="__meta__",me=1;lr={data:"\x1B[32m",dirty:"\x1B[33m",resolved:"\x1B[36m",invalidate:"\x1B[93m",pause:"\x1B[90m",resume:"\x1B[96m",complete:"\x1B[34m",error:"\x1B[31m",teardown:"\x1B[91m",derived:"\x1B[35m",path:"\x1B[90m",reset:"\x1B[0m"},pr={data:"",dirty:"",resolved:"",invalidate:"",pause:"",resume:"",complete:"",error:"",teardown:"",derived:"",path:"",reset:""};oe=class r{name;opts;config;_nodes=new Map;_nodeToName=new WeakMap;_mounts=new Map;_parent=void 0;_storageDisposers=new Set;_disposers=new Set;_destroyed=!1;_topology;_topologyEmitters=new Set;_factory;_factoryArgs;constructor(e,t){if(e==="")throw new Error("Graph name must be non-empty");if(e.includes(P))throw new Error(`Graph name must not contain '${P}' (got "${e}")`);if(e===Z)throw new Error(`Graph name "${Z}" is reserved for meta companion paths`);this.name=e,this.opts=Object.freeze({...t??{}}),this.config=t?.config??Ne,this._traceRing=new Ge(t?.traceCapacity??1e3),t?.versioning!=null&&this.setVersioning(t.versioning),typeof t?.factory=="string"&&(this._factory=t.factory,t.factoryArgs!==void 0&&(this._factoryArgs=t.factoryArgs))}tagFactory(e,t){return this._factory=e,this._factoryArgs=t,this}ancestors(e=!0){let t=[],n=e?this:this._parent;for(;n!=null;)t.push(n),n=n._parent;return t}get topology(){return this._topology==null&&(this._topology=ue(e=>{let t=n=>{e.emit(n)};return this._topologyEmitters.add(t),()=>{this._topologyEmitters.delete(t)}},{name:`${this.name}_topology`})),this._topology}_emitTopology(e){if(!(this._topology==null||this._topologyEmitters.size===0))for(let t of this._topologyEmitters)t(e)}nameOf(e){return this._nodeToName.get(e)}add(e,t){let n=e.name,s=t?.name??n;if(s==null||s==="")throw new Error(`Graph "${this.name}": graph.add requires a non-empty name \u2014 pass via opts.name or set it on the node (e.g. state(0, { name: "x" }))`);let o=s,i=t?.annotation;if(Rt(o,this.name,"add"),this._mounts.has(o))throw new Error(`Graph "${this.name}": name "${o}" is already a mount point`);if(this._nodes.has(o))throw new Error(`Graph "${this.name}": node "${o}" already exists`);let a=this._nodeToName.get(e);if(a!==void 0)throw new Error(`Graph "${this.name}": node instance already registered as "${a}"`);return this._nodes.set(o,e),this._nodeToName.set(e,o),this._emitTopology({kind:"added",name:o,nodeKind:"node"}),i!=null&&(this._annotations.set(o,i),this.config.inspectorEnabled&&this._traceRing.push({path:o,annotation:i,timestamp_ns:re()})),e}setVersioning(e){if(e!=null)for(let t of this._nodes.values())t instanceof F&&t._applyVersioning(e)}remove(e){Rt(e,this.name,"remove");let t=this._mounts.get(e);if(t){let o={kind:"mount",nodes:[],mounts:[]},i=[];t._collectObserveTargets("",i);for(let[a,u]of i)a.includes(`${P}${Z}${P}`)||o.nodes.push(a);return o.nodes.sort(),o.mounts.push(e),o.mounts.push(...t._collectSubgraphs(`${e}${P}`)),this._mounts.delete(e),t._parent=void 0,On(t),this._emitTopology({kind:"removed",name:e,nodeKind:"mount",audit:o}),o}let n=this._nodes.get(e);if(!n)throw new Error(`Graph "${this.name}": unknown node or mount "${e}"`);this._nodes.delete(e),this._nodeToName.delete(n),n.down([[z]],{internal:!0});let s={kind:"node",nodes:[e],mounts:[]};return this._emitTopology({kind:"removed",name:e,nodeKind:"node",audit:s}),s}removeAll(e){let t=typeof e=="function"?e:(()=>{let o=et(e);return i=>o.test(i)})(),n={kind:"mount",nodes:[],mounts:[]},s=[...this._nodes.keys(),...this._mounts.keys()].filter(o=>t(o));for(let o of s){let i=this.remove(o);n.nodes.push(...i.nodes),n.mounts.push(...i.mounts)}return n.nodes.sort(),n.mounts.sort(),n}[Symbol.iterator](){let e=[...this._nodes.keys()].sort(),t=this._nodes,n=0;return{[Symbol.iterator](){return this},next(){if(n>=e.length)return{value:void 0,done:!0};let s=e[n++];return{value:[s,t.get(s)],done:!1}}}}node(e){if(e==="")throw new Error(`Graph "${this.name}": node name must be non-empty`);if(e.includes(P))return this.resolve(e);let t=this._nodes.get(e);if(!t)throw new Error(`Graph "${this.name}": unknown node "${e}"`);return t}get(e){return this.node(e).cache}set(e,t,n){let s=n?.internal===!0;this.node(e).down([[G,t]],{actor:n?.actor,internal:s,delivery:"write"})}setAll(e,t){let n=Symbol.iterator in e?e:Object.entries(e);ne(()=>{for(let[s,o]of n)this.set(s,o,t)})}invalidate(e,t){let n=t?.internal===!0;this.node(e).down([[Y]],{actor:t?.actor,internal:n,delivery:"write"})}error(e,t,n){let s=n?.internal===!0;this.node(e).down([[C,t]],{actor:n?.actor,internal:s,delivery:"write"})}complete(e,t){let n=t?.internal===!0;this.node(e).down([[L]],{actor:t?.actor,internal:n,delivery:"write"})}_registerSelfPruningKeepalive(e){let t,n,s=()=>{t?.(),t=void 0,n?.(),n=void 0};t=e.subscribe(o=>{for(let i of o){let a=i[0];if(a===z||a===L||a===C){s();return}}}),n=this.addDisposer(s)}_wireSignalToRemove(e,t){if(t==null)return;let n=()=>{try{this.remove(e)}catch{}};if(t.aborted){n();return}t.addEventListener("abort",n,{once:!0}),this.addDisposer(()=>t.removeEventListener("abort",n))}derived(e,t,n,s){let o=t.map(h=>this.resolve(h)),{keepAlive:i,annotation:a,equals:u,initial:d,meta:c,signal:f}=s??{},p=W(o,n,{name:e,...u!=null?{equals:u}:{},...d!==void 0?{initial:d}:{},...c!=null?{meta:c}:{}});return this.add(p,{name:e,...a!=null?{annotation:a}:{}}),i===!0&&this._registerSelfPruningKeepalive(p),this._wireSignalToRemove(e,f),p}effect(e,t,n,s){let o=t.map(c=>this.resolve(c)),{annotation:i,meta:a,signal:u}=s??{},d=wt(o,n,{name:e,...a!=null?{meta:a}:{}});return this.add(d,{name:e,...i!=null?{annotation:i}:{}}),this._wireSignalToRemove(e,u),d}produce(e,t,n){if(t===void 0)throw new Error(`Graph "${this.name}".produce("${e}", \u2026): source must not be \`undefined\` \u2014 undefined is the global SENTINEL (spec \xA71.1). Pass \`null\` for nullary DATA, or a Promise/AsyncIterable/Iterable for async sources.`);if(t!==null&&typeof t=="object"&&"cache"in t&&typeof t.subscribe=="function")throw new Error(`Graph "${this.name}".produce("${e}", \u2026): Node sources are rejected. For Node\u2192Node, use graph.derived(name, [path], ([v]) => v, { keepAlive: true }) \u2014 fromAny passes Nodes through verbatim and silently drops opts.`);let{annotation:s,meta:o,equals:i,signal:a}=n??{},u=sn(t,{name:e,...o!=null?{meta:o}:{},...i!=null?{equals:i}:{},...a!=null?{signal:a}:{}});return this.add(u,{name:e,...s!=null?{annotation:s}:{}}),this._wireSignalToRemove(e,a),u}batch(e){ne(e)}edges(e){let t=e?.recursive===!0,n=new Map;if(!t){for(let[u,d]of this._nodes)n.set(d,u);let a=[];for(let[u,d]of this._nodes)if(d instanceof F)for(let c of d._deps){let f=n.get(c.node);f!=null&&a.push([f,u])}return a.sort((u,d)=>u[0]<d[0]?-1:u[0]>d[0]?1:u[1]<d[1]?-1:u[1]>d[1]?1:0),a}let s=[];this._collectObserveTargets("",s);let o=new Map;for(let[a,u]of s)o.set(u,a);let i=[];for(let[a,u]of s)if(u instanceof F)for(let d of u._deps){let c=o.get(d.node);c!=null&&i.push([c,a])}return i.sort((a,u)=>a[0]<u[0]?-1:a[0]>u[0]?1:a[1]<u[1]?-1:a[1]>u[1]?1:0),i}mount(e,t){if(t===void 0){let s=new r(e);return this.mount(e,s)}if(typeof t=="function"){let s=new r(e);return t(s),this.mount(e,s)}let n=t;if(Rt(e,this.name,"mount"),this._nodes.has(e))throw new Error(`Graph "${this.name}": cannot mount at "${e}" \u2014 node with that name exists`);if(this._mounts.has(e))throw new Error(`Graph "${this.name}": mount "${e}" already exists`);if(n===this)throw new Error(`Graph "${this.name}": cannot mount a graph into itself`);if(n._parent!=null)throw new Error(`Graph "${this.name}": this child graph is already mounted on "${n._parent.name}"`);for(let s=this;s!=null;s=s._parent)if(s===n)throw new Error(`Graph "${this.name}": mount("${e}", \u2026) would create a mount cycle`);return this._mounts.set(e,n),n._parent=this,this._emitTopology({kind:"added",name:e,nodeKind:"mount"}),n}resolve(e){let t=gr(e,this.name);return this._resolveFromSegments(t)}tryResolve(e){try{return this.resolve(e)}catch{return}}_resolveFromSegments(e){let t=e;if(t[0]===this.name&&(t=t.slice(1),t.length===0))throw new Error(`Graph "${this.name}": resolve path ends at graph name only`);let n=t[0],s=t.slice(1);if(s.length===0){let a=this._nodes.get(n);if(a)return a;throw this._mounts.has(n)?new Error(`Graph "${this.name}": path ends at subgraph "${n}" \u2014 not a node (GRAPHREFLY-SPEC \xA73.5)`):new Error(`Graph "${this.name}": unknown name "${n}"`)}let o=this._nodes.get(n);if(o&&s.length>0&&s[0]===Z)return this._resolveMetaChainFromNode(o,s,t.join(P));let i=this._mounts.get(n);if(!i)throw this._nodes.has(n)?new Error(`Graph "${this.name}": "${n}" is a node; trailing path "${s.join(P)}" is invalid`):new Error(`Graph "${this.name}": unknown mount or node "${n}"`);return i.resolve(s.join(P))}_resolveMetaChainFromNode(e,t,n){let s=e,o=0,i=[...t];for(;o<i.length;){if(i[o]!==Z)throw new Error(`Graph "${this.name}": expected ${Z} segment in meta path "${n}"`);if(o+1>=i.length)throw new Error(`Graph "${this.name}": meta path requires a key after ${Z} in "${n}"`);let a=i[o+1],u=s.meta[a];if(!u)throw new Error(`Graph "${this.name}": unknown meta "${a}" in path "${n}"`);s=u,o+=2}return s}signal(e,t){if(t?.internal!==!0){for(let s of e)if(this.config.messageTier(s[0])===3)throw new Error(`Graph "${this.name}": Graph.signal() rejects tier-3 messages (DATA / RESOLVED). Broadcast is for control-plane tiers (START / DIRTY / INVALIDATE / PAUSE / RESUME / COMPLETE / ERROR / TEARDOWN). For per-node value writes, use Graph.set or graph.node(name).down(...).`)}let n=[];if(this._signalDeliver(e,t??{},new Set,n),n.length>0)throw n[0]}_signalDeliver(e,t,n,s){for(let u of this._mounts.values())u._signalDeliver(e,t,n,s);let i=t.internal===!0?{internal:!0}:{actor:t.actor,delivery:"signal"},a=mr(e,this.config);for(let u of[...this._nodes.keys()].sort()){let d=this._nodes.get(u);if(!n.has(d)){n.add(d);try{d.down(e,i)}catch(c){if(c instanceof J)throw c;s.push(c)}a.length!==0&&this._signalMetaSubtree(d,a,n,i,s)}}}_signalMetaSubtree(e,t,n,s,o){for(let i of Object.keys(e.meta).sort()){let a=e.meta[i];if(!n.has(a)){n.add(a);try{a.down(t,s)}catch(u){if(u instanceof J)throw u;o.push(u)}this._signalMetaSubtree(a,t,n,s,o)}}}describe(e){if(e?.reactive==="diff")return this._describeReactiveDiff(e);if(e?.reactive===!0)return this._describeReactive(e);let t=ar(e?.actor),n=e?.filter;if(e?.detail!=null&&e?.fields!=null)throw new TypeError("Graph.describe(): pass either `detail` or `fields`, not both. `detail: 'spec'` is the canonical spec projection; use `fields` only when you need a custom subset.");let s=_t(e?.detail,e?.fields),o=e?.detail==="spec",i=s,a=[];this._collectObserveTargets("",a);let u=new Map;for(let[_,T]of a)u.set(T,_);let d=[];{let _=a.map(([,m])=>m),T=new Set(u.values()),x=0;for(;_.length>0;){let m=_.shift();if(m instanceof F)for(let w of m._deps){let k=w.node;if(u.has(k))continue;let R=k.name??"",N=R;if(!N||T.has(N))if(R){let A=2;for(;T.has(`${R}#${A}`);)A++;N=`${R}#${A}`}else for(N=`__internal__/${x++}`;T.has(N);)N=`__internal__/${x++}`;u.set(k,N),T.add(N),d.push([N,k]),_.push(k)}}}let c=[...a,...d],f={};for(let[_,T]of c){if(t!=null&&!T.allowsObserve(t))continue;let x=Tt(T,i,o),m=T instanceof F?T._deps.map(N=>u.get(N.node)??N.node.name??""):[],{name:w,...k}=x,R={...k,deps:m};if(!o){let N=this._annotations.get(_);N!=null&&(R.annotation=N)}if(n!=null)if(typeof n=="function"){let N=n;if(!(N.length>=2?N(_,R):N(R)))continue}else{let N=!0;for(let[A,D]of Object.entries(n)){let S=A==="deps_includes"?"depsIncludes":A==="meta_has"?"metaHas":A;if(S==="depsIncludes"){if(!R.deps.includes(String(D))){N=!1;break}continue}if(S==="metaHas"){if(!Object.hasOwn(R.meta??{},String(D))){N=!1;break}continue}if(R[S]!==D){N=!1;break}}if(!N)continue}f[_]=R}let p=new Set(Object.keys(f)),h=[];for(let[_,T]of c)if(T instanceof F)for(let x of T._deps){let m=u.get(x.node);m!=null&&h.push([m,_])}h.sort((_,T)=>_[0]<T[0]?-1:_[0]>T[0]?1:_[1]<T[1]?-1:_[1]>T[1]?1:0);let l=h.map(([_,T])=>({from:_,to:T}));(t!=null||n!=null)&&(l=l.filter(_=>p.has(_.from)&&p.has(_.to)));let y=this._collectSubgraphs(""),g=t!=null||n!=null?y.filter(_=>{let T=`${_}${P}`;return[...p].some(x=>x===_||x.startsWith(T))}):y,O=this,v=e;return{name:this.name,nodes:f,edges:l,subgraphs:g,...this._factory!==void 0?{factory:this._factory}:{},...this._factoryArgs!==void 0?{factoryArgs:this._factoryArgs}:{},expand(_){let T={...v};return Array.isArray(_)?(T.fields=_,T.detail=void 0):(T.detail=_,T.fields=void 0),O.describe(T)}}}_collectSubgraphs(e){let t=[];for(let n of[...this._mounts.keys()].sort()){let s=e===""?n:`${e}${n}`;t.push(s),t.push(...this._mounts.get(n)._collectSubgraphs(`${s}${P}`))}return t}resourceProfile(e){return mn(this,e)}reachable(e,t,n={}){return n.withDetail===!0?At(this.describe(),e,t,{...n,withDetail:!0}):At(this.describe(),e,t,n)}explain(e,t,n){return n?.reactive===!0?this._explainReactive(e,t,n):this._explainStatic(de(e),de(t),{...n?.maxDepth!==void 0?{maxDepth:yn(n.maxDepth)}:{},...n?.findCycle!==void 0?{findCycle:vn(n.findCycle)}:{}})}_explainStatic(e,t,n){let s=this.describe({detail:"full"}),o=new Map(this._annotations),i=new Map;for(let[a,u]of Object.entries(s.nodes))u.lastMutation!=null&&i.set(a,u.lastMutation);return dn(s,e,t,{...n?.maxDepth!=null?{maxDepth:n.maxDepth}:{},...n?.findCycle===!0?{findCycle:!0}:{},annotations:o,lastMutations:i})}_describeReactive(e){let t={...e,reactive:!1},n=e.reactiveName??"describe",s=0,o=U(s,{name:`${n}_version`}),i=this.observe({timeline:!0,structured:!0}),a=!1,u=!1,d=()=>{a||u||(a=!0,Te(()=>{a=!1,!u&&(s+=1,o.emit(s))}))},c=i.onEvent(v=>{let b=v.type;b!=="data"&&b!=="error"&&b!=="complete"&&b!=="teardown"||d()}),f=[],p=new WeakSet,h=v=>{if(p.has(v)||u)return;p.add(v);let b=v.topology.subscribe(_=>{for(let T of _){if(T[0]!==G)continue;let x=T[1];if(d(),x.kind==="added"&&x.nodeKind==="mount"){let m=v._mounts.get(x.name);m!=null&&h(m)}}});f.push(b);for(let _ of v._mounts.keys()){let T=v._mounts.get(_);T!=null&&h(T)}};h(this);let l,y=e.actor;wn(y)&&(l=y.subscribe(v=>{let b=!1,_=!1;for(let T of v){let x=T[0];x===G?b=!0:(x===L||x===C||x===z)&&(_=!0)}b&&d(),_&&(l?.(),l=void 0,d())}));let g;try{g=W([o],()=>this.describe(t),{name:n,describeKind:"derived",meta:{domain:"audit",kind:"describe"},equals:(v,b)=>v===b})}catch(v){c(),l?.();for(let b of f)b();throw i.dispose(),v}let O=X(g);return{node:g,dispose(){u=!0,c(),l?.();for(let v of f)v();f.length=0,i.dispose(),O()}}}_describeReactiveDiff(e){let t={...e,reactive:!1},n=e.reactiveName??"describe-diff",s={name:this.name,nodes:{},edges:[],subgraphs:[]},o=this.describe(t),i=Nt(s,o),a=U(i,{name:n,meta:{domain:"audit",kind:"describe-diff"},equals:(p,h)=>p===h}),u=this._describeReactive({...e,reactiveName:void 0}),d=!1,c=u.node.subscribe(p=>{if(!d)for(let h of p){if(h[0]!==G)continue;let l=h[1],y=Nt(o,l);o=l,y.events.length!==0&&a.emit(y)}}),f=X(a);return{node:a,dispose(){d=!0,c(),u.dispose(),a.down([[z,"describe-diff disposed"]]),f()}}}_explainReactive(e,t,n){let s=0,o=U(s,{name:"explain_version"}),i=this.observe({timeline:!0,structured:!0}),a=!1,u=!1,d=()=>{a||u||(a=!0,Te(()=>{a=!1,!u&&(s+=1,o.emit(s))}))},c=i.onEvent(v=>{let b=v.type;b!=="data"&&b!=="error"&&b!=="complete"&&b!=="teardown"||d()}),f=[];e!=null&&be(e)&&f.push(e),t!=null&&be(t)&&f.push(t),n?.maxDepth!=null&&be(n.maxDepth)&&f.push(n.maxDepth),n?.findCycle!=null&&be(n.findCycle)&&f.push(n.findCycle);let p=()=>{for(let v of f)if(v.cache===void 0)return!1;return!0},h=()=>{let v=de(e),b=de(t);return{from:v,to:b,found:!1,reason:"pending",steps:[],text:"(awaiting reactive args)",toJSON:()=>({from:v,to:b,found:!1,reason:"pending",steps:[]})}},l;try{l=W([o],()=>{if(!p())return h();let v=de(e),b=de(t),_={...n?.maxDepth!==void 0?{maxDepth:yn(n.maxDepth)}:{},...n?.findCycle!==void 0?{findCycle:vn(n.findCycle)}:{}};return this._explainStatic(v,b,_)},{name:n?.name??"explain",describeKind:"derived",meta:{domain:"audit",kind:"explain_path",from:de(e),to:de(t)},equals:(v,b)=>v.found===b.found&&v.reason===b.reason&&v.steps.length===b.steps.length&&br(v.steps,b.steps)})}catch(v){throw c(),i.dispose(),v}let y=X(l),g=[],O=v=>{let b;return b=v.subscribe(_=>{let T=!1,x=!1;for(let m of _){let w=m[0];w===G?T=!0:(w===L||w===C||w===z)&&(x=!0)}(T||x)&&d(),x&&b&&(b(),b=void 0)}),()=>{b&&(b(),b=void 0)}};for(let v of f)g.push(O(v));return{node:l,dispose(){u=!0,c();for(let v of g)v?.();g.length=0,i.dispose(),y()}}}_pathsMatching(e){let t=et(e),n=[];return this._collectObserveTargets("",n),n.map(([s])=>s).filter(s=>t.test(s))}_collectObserveTargets(e,t){for(let n of[...this._mounts.keys()].sort()){let s=e===""?n:`${e}${P}${n}`;this._mounts.get(n)._collectObserveTargets(s,t)}for(let n of[...this._nodes.keys()].sort()){let s=this._nodes.get(n),o=e===""?n:`${e}${P}${n}`;t.push([o,s]),this._appendMetaObserveTargets(o,s,t)}}_appendMetaObserveTargets(e,t,n){for(let s of Object.keys(t.meta).sort()){let o=t.meta[s],i=`${e}${P}${Z}${P}${s}`;n.push([i,o]),this._appendMetaObserveTargets(i,o,n)}}observe(e,t){let n=typeof e=="string",o=Tn(n?t:e);if(o.reactive===!0)return this._observeReactive(n?e:void 0,o);let i=o.structured===!0||o.timeline===!0||o.causal===!0||o.derived===!0||o.detail==="minimal"||o.detail==="full"||o.format!=null,a=o.actor;if(n){let c=e,f=this.resolve(c);if(a!=null&&!f.allowsObserve(a))throw new J({actor:a,action:"observe",nodeName:c});return i?this._buildStructuredObserver([[c,f]],o,"one"):{subscribe(p){return f.subscribe(p)},up(p){try{f.up?.(p)}catch(h){if(h instanceof J)return;throw h}}}}let u=[];this._collectObserveTargets("",u),u.sort((c,f)=>c[0]<f[0]?-1:c[0]>f[0]?1:0);let d=a==null?u:u.filter(([,c])=>c.allowsObserve(a));return i?this._buildStructuredObserver(d,o,"all"):{subscribe:c=>{let f=d.map(([p,h])=>h.subscribe(l=>{c(p,l)}));return()=>{for(let p of f)p()}},up:(c,f)=>{try{this.resolve(c).up?.(f)}catch(p){if(p instanceof J)return;throw p}}}}_observeReactive(e,t){let n=t.tiers,s=n!=null?new Set(n):null,o=t.reactiveName??"observe";return ue(i=>{let a=[],u=!1,d=!1,c=()=>{if(a.length===0||d)return;let y={events:a.slice(),flushedAt_ns:re()};a.length=0,i.emit(y)},f={...t,reactive:!1,structured:!0,timeline:!0},p=e!=null?this.observe(e,f):this.observe(f),h=y=>{d||(a.push(y),!u&&(u=!0,Te(()=>{u=!1,c()})))};for(let y of p.events)h(y);let l=p.onEvent(h);return()=>{d=!0,l(),p.dispose()}},{name:o,meta:{domain:"audit",kind:"observe-reactive"}})}_buildStructuredObserver(e,t,n){let s=n==="one"?e[0]?.[0]:void 0,o=i=>{if(n==="one"&&s!=null){let c=this.resolve(s);return this._buildStructuredObserver([[s,c]],i,"one")}let a=[];this._collectObserveTargets("",a),a.sort((c,f)=>c[0]<f[0]?-1:c[0]>f[0]?1:0);let u=i.actor,d=u==null?a:a.filter(([,c])=>c.allowsObserve(u));return this._buildStructuredObserver(d,i,"all")};return this._createObserveResult(e,t,o)}_createObserveResult(e,t,n){let s=t.timeline===!0,o=t.causal===!0,i=t.derived===!0,a=t.detail==="minimal",u=this.config.inspectorEnabled,d=(o||i)&&u,c=t.maxEvents,f=c!=null&&c>0?new Ge(c):null,p=[],h=new Set,l=t.tiers!=null?new Set(t.tiers):null,y={},g=new Set,O=0,v=0,b=0,_=0,T=0,x=0,m=!1,w=!1,k=0,R=new Map,N=new Map,A=new Map,D=E=>{if(!(l!=null&&!l.has(E.type))){f?f.push(E):p.push(E);for(let I of h)I(E)}},S=E=>l==null||l.has(E),ie=()=>s?{timestamp_ns:re(),in_batch:Ae(),batch_id:k}:{},te=(E,I)=>{if(!(!d||!(E instanceof F)))return E._setInspectorHook(K=>{if(K.kind==="dep_message")R.set(E,K.depIndex);else if(K.kind==="run"){let ke=K.batchData.map((M,j)=>M!=null&&M.length>0?M.at(-1):K.prevData[j]);N.set(E,ke);let q=K.batchData.map(M=>M!=null?[...M]:void 0);A.set(E,q),i&&D({type:"derived",path:I,dep_values:ke,dep_batches:q,...ie()})}})},Fe=E=>{let I=R.get(E),K=N.get(E);if(!o||K==null)return{};let q=(I!=null&&I>=0&&E instanceof F?E._deps[I]:void 0)?.node,M=q?.v,j=A.get(E);return{trigger_dep_index:I,trigger_dep_name:q?.name,...M!=null?{trigger_version:{id:M.id,version:M.version}}:{},dep_values:[...K],...j!=null?{dep_batches:j}:{}}},Dt=[],Ct=[];for(let[E,I]of e){let K=te(I,E);K&&Dt.push(K),Ct.push(I.subscribe(ke=>{k++;for(let q of ke){let M=q[0],j=ie();if(M===G){y[E]=q[1];let at=I instanceof F?I.lastMutation?.actor??ye:ye;D({type:"data",path:E,data:q[1],actor:at,...j,...Fe(I)})}else if(a)M===B?S("dirty")&&O++:M===H?S("resolved")&&v++:M===Y?S("invalidate")&&b++:M===Q?S("pause")&&_++:M===se?S("resume")&&T++:M===z?S("teardown")&&x++:M===L&&!g.has(E)?S("complete")&&(m=!0):M===C&&S("error")&&(w=!0,g.add(E));else if(M===B)S("dirty")&&O++,D({type:"dirty",path:E,...j});else if(M===H)S("resolved")&&v++,D({type:"resolved",path:E,...j,...Fe(I)});else if(M===Y)S("invalidate")&&b++,D({type:"invalidate",path:E,...j});else if(M===Q)S("pause")&&_++,D({type:"pause",path:E,lockId:q[1],...j});else if(M===se)S("resume")&&T++,D({type:"resume",path:E,lockId:q[1],...j});else if(M===L)S("complete")&&!g.has(E)&&(m=!0),D({type:"complete",path:E,...j});else if(M===C){S("error")&&(w=!0,g.add(E));let at=I instanceof F?I.lastMutation?.actor??ye:ye;D({type:"error",path:E,data:q[1],actor:at,...j})}else M===z&&(S("teardown")&&x++,D({type:"teardown",path:E,...j}))}}))}let st=!1,ot=()=>{if(!st){st=!0;for(let E of Ct)E();for(let E of Dt)E();for(let E of Ve)E({value:void 0,done:!0});Ve.length=0}},it=[],Ve=[];h.add(E=>{let I=Ve.shift();I?I({value:E,done:!1}):it.push(E)});let Mt={get values(){return y},get dirtyCount(){return O},get resolvedCount(){return v},get invalidateCount(){return b},get pauseCount(){return _},get resumeCount(){return T},get teardownCount(){return x},get events(){return f?f.toArray():[...p]},get anyCompletedCleanly(){return m},get anyErrored(){return w},get completedWithoutErrors(){return m&&!w},onEvent(E){return h.add(E),()=>h.delete(E)},dispose:ot,expand(E){ot();let I={...t};return typeof E=="string"?I.detail=E:Object.assign(I,E),n(Tn(I))},[Symbol.asyncIterator](){return{next(){return it.length>0?Promise.resolve({value:it.shift(),done:!1}):st?Promise.resolve({value:void 0,done:!0}):new Promise(E=>Ve.push(E))},return(){return ot(),Promise.resolve({value:void 0,done:!0})}}}};return t.format!=null&&this._attachFormatLogger(Mt,t),Mt}_attachFormatLogger(e,t){let n=t.format;if(n==null)return;let s=t.logger??(l=>console.log(l)),o=t.includeTypes?new Set(t.includeTypes):null,i=t.excludeTypes?new Set(t.excludeTypes):null,a=o==null&&i==null?()=>!0:l=>(o==null||o.has(l))&&(i==null||!i.has(l)),u=fr(t.theme),d=n==="stage-log"?re():0,c=l=>l==null?"":t.stageLabels?.[l]??l,f=(l,y)=>l.length>y?`${l.slice(0,y-1)}\u2026`:l,p=l=>l.type==="data"||l.type==="error"?f(Et(l.data),120):"",h=l=>{if(n==="stage-log"){let m=(re()-d)/1e9,w=c(l.path).padEnd(9);if(l.type==="data"){let k=p(l);return`[${m.toFixed(3)}s] ${w} \u2190${k?` ${k}`:""}`}if(l.type==="error"){let k=p(l);return`[${m.toFixed(3)}s] ${w} \u2717${k?` ${k}`:""}`}return l.type==="complete"?`[${m.toFixed(3)}s] ${w} \u25A0 complete`:`[${m.toFixed(3)}s] ${w} ${l.type}`}if(n==="json")try{return JSON.stringify(l)}catch{return JSON.stringify({type:l.type,path:l.path,data:"[unserializable]"})}let y=u[l.type]??"",g=l.path?`${u.path}${l.path}${u.reset} `:"",O=l.type==="data"||l.type==="error",v=l.type==="pause"||l.type==="resume",b=O?` ${Et(l.data)}`:v?` ${Et(l.lockId)}`:"",_=l.type==="data"||l.type==="resolved"||l.type==="derived"?l:void 0,T=_?.trigger_dep_name!=null?` <- ${_.trigger_dep_name}`:_?.trigger_dep_index!=null?` <- #${_.trigger_dep_index}`:"",x=l.in_batch?" [batch]":"";return`${g}${y}${l.type.toUpperCase()}${u.reset}${b}${T}${x}`};e.onEvent(l=>{a(l.type)&&s(h(l),l)})}addDisposer(e){return this._disposers.add(e),()=>{this._disposers.delete(e)}}destroy(){Qe(this._disposers,this.name),this.signal([[z]],{internal:!0}),Qe(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(){Qe(this._disposers,this.name),Qe(this._storageDisposers,this.name);for(let e of[...this._mounts.values()])e._parent=void 0,e._destroyClearOnly();this._mounts.clear(),this._nodes.clear(),this._parent=void 0,this._destroyed=!0}snapshot(e){let{expand:t,...n}=this.describe({detail:"full"}),s={};for(let a of Object.keys(n.nodes).sort()){let{lastMutation:u,guard:d,...c}=n.nodes[a];s[a]=c}let o=[...n.subgraphs].sort(),i={...n,version:1,nodes:s,subgraphs:o};if(e?.format==null)return i;if(e.format==="json-string")return JSON.stringify(i);if(e.format==="bytes"){if(e.codec==null)throw new Error("snapshot({format: 'bytes'}) requires a `codec` name");let a=this.config.lookupCodec(e.codec);if(a==null)throw new Error(`snapshot: codec "${e.codec}" is not registered on this graph's config. Call config.registerCodec(...) before creating nodes.`);return jt(a,a.encode(i))}throw new Error(`snapshot: unknown format "${String(e.format)}"`)}static decode(e,t){let n=t?.config??Ne,{codec:s,codecVersion:o,payload:i}=Ht(e,n);return s.decode(i,o)}restore(e,t){if(_n(e),e.name!==this.name)throw new Error(`Graph "${this.name}": restore snapshot name "${e.name}" does not match this graph`);let n=t?.only==null?null:(Array.isArray(t.only)?t.only:[t.only]).map(o=>et(o)),s=t?.includeProducers===!0;for(let o of Object.keys(e.nodes).sort()){if(n!==null&&!n.some(a=>a.test(o)))continue;let i=e.nodes[o];if(i!==void 0){if(!("value"in i)||i.value===void 0){"value"in i&&i.value===void 0&&t?.onError?.(o,new Error(`restore: slice.value is undefined for "${o}" (undefined is the global SENTINEL; not valid DATA)`));continue}if(!(i.type==="derived"||i.type==="effect")&&!(i.type==="producer"&&!s)){if(i.v!=null){let u=this.tryResolve(o)?.v;if(u!=null&&u.id===i.v.id&&u.version===i.v.version)continue}try{this.set(o,i.value)}catch(a){t?.onError?.(o,a)}}}}}static fromSnapshot(e,t){_n(e);let n=typeof t=="function"?t:t?.build,s=typeof t=="function"?void 0:t?.factories,o=new r(e.name);if(n)return n(o),o.restore(e),o;for(let h of[...e.subgraphs].sort((l,y)=>{let g=l.split(P).length,O=y.split(P).length;return g!==O?g-O:l<y?-1:l>y?1:0})){let l=h.split(P),y=o;for(let g of l)y._mounts.has(g)||y.mount(g,new r(g)),y=y._mounts.get(g)}let i=s?Object.entries(s).map(([h,l])=>({re:et(h),factory:l})):[],a=h=>{for(let l of i)if(l.re.test(h))return l.factory},u=h=>{let l=h.split(P),y=l.pop();if(y==null||y.length===0)throw new Error(`invalid snapshot path "${h}"`);let g=o;for(let O of l){let v=g._mounts.get(O);if(!v)throw new Error(`unknown mount "${O}" in path "${h}"`);g=v}return[g,y]},d=Object.entries(e.nodes).filter(([h])=>!h.includes(`${P}${Z}${P}`)).sort((h,l)=>h[0]<l[0]?-1:h[0]>l[0]?1:0),c=new Map(d),f=new Map,p=!0;for(;c.size>0&&p;){p=!1;for(let[h,l]of[...c.entries()]){let y=l?.deps??[];if(!y.every(T=>f.has(T)))continue;let[g,O]=u(h),v={...l?.meta??{}},b=a(h),_;if(l?.type==="state")_=U(l.value,{meta:v});else{if(b==null)continue;_=b(O,{path:h,type:l.type,value:l.value,meta:v,deps:y,resolvedDeps:y.map(T=>f.get(T))})}g.add(_,{name:O}),f.set(h,_),c.delete(h),p=!0}}if(c.size>0){let h=[...c.keys()].sort().join(", ");throw new Error(`Graph.fromSnapshot could not reconstruct nodes without build callback: ${h}. Pass matching factories via fromSnapshot(data, { factories: { pattern: factoryFn } }).`)}return o.restore(e),o}toJSON(){return this.snapshot()}attachSnapshotStorage(e,t={}){let n=e.map(d=>({tier:d,debounceMs:Math.max(0,d.debounceMs??0),compactEvery:Math.max(1,d.compactEvery??10),timer:void 0,seq:0,lastSnapshot:void 0,lastFingerprint:"",disposed:!1,savePending:void 0}));t.autoRestore===!0&&this._cascadeRestore(e,t.onError);let s=(d,c)=>{if(d.disposed)return;let f=ur(c.nodes);if(d.lastSnapshot!=null&&f!==""&&f===d.lastFingerprint)return;let p=d.seq+1,h=we(),g=d.lastSnapshot==null||p%d.compactEvery===0?{name:this.name,mode:"full",snapshot:c,seq:p,timestamp_ns:h,format_version:me}:{name:this.name,mode:"diff",diff:Nn(d.lastSnapshot,c),seq:p,timestamp_ns:h,format_version:me};if(d.tier.filter&&!d.tier.filter(g))return;let O;try{O=d.tier.save(g)}catch(v){t.onError?.(v,d.tier);return}if(O&&typeof O.then=="function"){let _=(d.savePending??Promise.resolve()).then(()=>O,()=>O).then(()=>{d.disposed||(d.seq=p,d.lastSnapshot=c,d.lastFingerprint=f)},T=>{t.onError?.(T,d.tier)});d.savePending=_.finally(()=>{d.savePending===_&&(d.savePending=void 0)})}else d.seq=p,d.lastSnapshot=c,d.lastFingerprint=f},o=(d,c)=>{try{s(d,c)}catch(f){t.onError?.(f,d.tier)}},i=(d,c)=>{if(!c.some(l=>{let y=this.config.messageTier(l[0]);return y>=3&&y<5}))return;if(t.filter){let l=this.tryResolve(d);if(l==null)return;let y=Tt(l,_t("standard"));if(!t.filter(d,y))return}let p,h=()=>(p==null&&(p=this.snapshot()),p);for(let l of n)l.disposed||(l.debounceMs===0?o(l,h()):(l.timer==null&&(l.timer=new Ye),l.timer.start(l.debounceMs,()=>{l.disposed||o(l,this.snapshot())})))},a;if(t.paths!=null){let c=(typeof t.paths=="string"?this._pathsMatching(t.paths):t.paths).map(f=>{let p=this.tryResolve(f);return p==null?()=>{}:p.subscribe(h=>i(f,h))});a=()=>{for(let f of c)f()}}else a=this.observe().subscribe((d,c)=>i(d,c));let u=()=>{a();for(let d of n)d.disposed=!0,d.timer?.cancel();this._storageDisposers.delete(u)};return this._storageDisposers.add(u),{dispose:u}}async _cascadeRestore(e,t){for(let n of e){let s;try{s=await n.load?.()}catch(i){t?.(i,n);continue}if(s==null||typeof s!="object"||Array.isArray(s))continue;let o=s;try{if(o.mode==="full"&&o.snapshot!=null)return this.restore(o.snapshot),!0;if(o.version===me&&o.nodes!=null)return this.restore(o),!0}catch(i){t?.(i,n)}}return!1}static async fromStorage(e,t,n){for(let s of t){let o;try{o=await s.load?.()}catch(u){n?.onError?.(u,s);continue}if(o==null||typeof o!="object"||Array.isArray(o))continue;let i=o,a=i.mode==="full"&&i.snapshot!=null?i.snapshot:i.version===me&&i.nodes!=null?i:void 0;if(a!=null)try{return r.fromSnapshot(a,n)}catch(u){n?.onError?.(u,s)}}throw new Error(`Graph.fromStorage: no tier held a restorable record for "${e}" across ${t.length} tier(s)`)}_annotations=new Map;_traceRing;trace(e,t,n){if(e!=null&&t!=null){if(this.tryResolve(e)==null)return;if(this._annotations.set(e,t),this.config.inspectorEnabled){let s={path:e,annotation:t,timestamp_ns:re(),...n?.actor!=null?{actor:n.actor}:{}};this._traceRing.push(s)}return}return e!=null?this.config.inspectorEnabled?this._annotations.get(e):void 0:this.config.inspectorEnabled?this._traceRing.toArray():[]}annotation(e){return this._annotations.get(e)}clearTrace(){this._annotations.clear(),this._traceRing.clear()}pruneTrace(e){let t=this._traceRing.toArray().filter(s=>!e(s)),n=this._traceRing.size-t.length;this._traceRing.clear();for(let s of t)this._traceRing.push(s);return n}static diff(e,t){let n=new Set(Object.keys(e.nodes)),s=new Set(Object.keys(t.nodes)),o=[...s].filter(v=>!n.has(v)).sort(),i=[...n].filter(v=>!s.has(v)).sort(),a=[],u=[];for(let v of n){if(!s.has(v))continue;let b=e.nodes[v],_=t.nodes[v],T=b.v,x=_.v;T!=null&&x!=null&&T.id===x.id&&T.version!==x.version&&u.push({path:v,id:T.id,from:T.version,to:x.version});let m=T!=null&&x!=null&&T.id===x.id&&T.version===x.version;for(let w of["type","status","sentinel"]){let k=b[w],R=_[w];k!==R&&a.push({path:v,field:w,from:k,to:R})}if(!m)for(let w of["value","meta"]){let k=b[w],R=_[w];dr(k,R)||a.push({path:v,field:w,from:k,to:R})}}let d=v=>`${v.from} ${v.to}`,c=new Set(e.edges.map(d)),f=new Set(t.edges.map(d)),p=t.edges.filter(v=>!c.has(d(v))),h=e.edges.filter(v=>!f.has(d(v))),l=new Set(e.subgraphs),y=new Set(t.subgraphs),g=[...y].filter(v=>!l.has(v)).sort(),O=[...l].filter(v=>!y.has(v)).sort();return{nodesAdded:o,nodesRemoved:i,nodesChanged:a,versionChanges:u,edgesAdded:p,edgesRemoved:h,subgraphsAdded:g,subgraphsRemoved:O}}}});var Sn=$(()=>{"use strict";xn()});var kr={};In(kr,{MessagingHubGraph:()=>rt,SubscriptionGraph:()=>$e,TopicBridgeGraph:()=>tt,TopicGraph:()=>Le,TopicRegistry:()=>nt,messagingHub:()=>Nr,subscription:()=>Dn,topic:()=>Or,topicBridge:()=>xr});module.exports=Ln(kr);Be();De();Oe();ae();Me();ge();en();Ce();Oe();ae();De();ae();ge();Me();var St=class{_version=0;_maxSize;_buf;_head=0;_size=0;constructor(e,t){if(t!==void 0&&t<1)throw new RangeError("maxSize must be >= 1");if(this._maxSize=t,t!==void 0){if(this._buf=new Array(t),e&&e.length>0){let n=Math.min(e.length,t),s=e.length-n;for(let o=0;o<n;o++)this._buf[o]=e[s+o];this._size=n}}else this._buf=e?[...e]:[],this._size=this._buf.length}get version(){return this._version}get size(){return this._size}at(e){if(!Number.isInteger(e))return;let t=e>=0?e:this._size+e;if(!(t<0||t>=this._size))return this._maxSize!==void 0?this._buf[(this._head+t)%this._maxSize]:this._buf[t]}append(e){this._rawAppend(e),this._version+=1}appendMany(e){if(e.length===0)return;let t=this._maxSize!==void 0&&e.length>this._maxSize?e.length-this._maxSize:0;for(let n=t;n<e.length;n++)this._rawAppend(e[n]);this._version+=1}clear(){if(this._size===0)return 0;let e=this._size;if(this._maxSize===void 0)this._buf.length=0;else for(let t=0;t<e;t++)this._buf[(this._head+t)%this._maxSize]=void 0;return this._head=0,this._size=0,this._version+=1,e}trimHead(e){if(!Number.isInteger(e)||e<0)throw new RangeError(`trimHead: n must be a non-negative integer (got ${e})`);if(e===0||this._size===0)return 0;let t=Math.min(e,this._size);if(this._maxSize===void 0)this._buf.splice(0,t);else{for(let n=0;n<t;n++)this._buf[(this._head+n)%this._maxSize]=void 0;this._head=(this._head+t)%this._maxSize}return this._size-=t,this._version+=1,t}slice(e,t){if(!Number.isInteger(e)||e<0)throw new RangeError(`slice: start must be a non-negative integer (got ${e})`);if(t!==void 0&&(!Number.isInteger(t)||t<0))throw new RangeError(`slice: stop must be a non-negative integer or undefined (got ${t})`);let n=t===void 0?this._size:Math.min(Math.max(t,0),this._size),s=Math.min(e,this._size);if(s>=n)return[];let o=n-s;if(this._maxSize===void 0)return this._buf.slice(s,n);let i=new Array(o);for(let a=0;a<o;a++)i[a]=this._buf[(this._head+s+a)%this._maxSize];return i}tail(e){if(!Number.isInteger(e)||e<0)throw new RangeError(`tail: n must be a non-negative integer (got ${e})`);if(e===0||this._size===0)return[];let t=Math.min(e,this._size);return this.slice(this._size-t,this._size)}toArray(){if(this._maxSize===void 0)return[...this._buf];let e=new Array(this._size);for(let t=0;t<this._size;t++)e[t]=this._buf[(this._head+t)%this._maxSize];return e}snapshot(){return this.toArray()}restore(e){if(this._maxSize===void 0){this._buf.length=0;for(let t=0;t<e.length;t++)this._buf.push(e[t]);this._size=this._buf.length}else{let t=this._maxSize;for(let o=0;o<t;o++)this._buf[o]=void 0;this._head=0;let n=Math.min(e.length,t),s=e.length-n;for(let o=0;o<n;o++)this._buf[o]=e[s+o];this._size=n}this._version+=1}_rawAppend(e){if(this._maxSize===void 0){this._buf.push(e),this._size=this._buf.length;return}this._size<this._maxSize?(this._buf[(this._head+this._size)%this._maxSize]=e,this._size+=1):(this._buf[this._head]=e,this._head=(this._head+1)%this._maxSize)}};function Ie(r){return r.subscribe(()=>{})}var yr=64;function kn(r,e={}){let{name:t,maxSize:n,versioning:s,guard:o,backend:i}=e,a=i??new St(r,n),u=U(a.toArray(),{name:t,describeKind:"state",equals:(m,w)=>m===w,...s!=null?{versioning:s}:{},...o!=null?{guard:o}:{}});function d(){let m=a.toArray();ne(()=>{u.down([[B]],{internal:!0}),u.down([[G,m]],{internal:!0})})}let c=new Map,f=new Map,p=new Map;function h(m,w){return`${m}:${w===void 0?"END":w}`}function l(m){if(m.size<yr)return;let w=m.keys().next();if(w.done)return;let k=m.get(w.value);k!==void 0&&k.dispose(),m.delete(w.value)}function y(m){let w=a.version;try{return m()}finally{a.version!==w&&d()}}function g(m){if(!Number.isInteger(m)||m<0)throw new RangeError(`tail: n must be a non-negative integer (got ${m})`);let w=c.get(m);if(w!==void 0)return c.delete(m),c.set(m,w),w.node;l(c);let k=W([u],([N])=>{let A=N;return m===0||A.length===0?[]:A.slice(Math.max(0,A.length-m))},{initial:a.tail(m),describeKind:"derived"}),R=Ie(k);return c.set(m,{node:k,dispose:R}),k}function O(m,w){if(!Number.isInteger(m)||m<0)throw new RangeError(`slice: start must be a non-negative integer (got ${m})`);if(w!==void 0&&(!Number.isInteger(w)||w<0))throw new RangeError(`slice: stop must be a non-negative integer or undefined (got ${w})`);let k=h(m,w),R=f.get(k);if(R!==void 0)return f.delete(k),f.set(k,R),R.node;l(f);let N=W([u],([D])=>{let S=D;return w===void 0?S.slice(m):S.slice(m,w)},{initial:a.slice(m,w),describeKind:"derived"}),A=Ie(N);return f.set(k,{node:N,dispose:A}),N}function v(m){let w=p.get(m);if(w!==void 0)return w.node;let k=W([u,m],([N,A])=>{let D=N,S=Math.max(0,Math.trunc(A??0));return D.slice(S)},{initial:[],describeKind:"derived"}),R=Ie(k);return p.set(m,{node:k,dispose:R}),k}let b,_;function T(){b===void 0&&(b=ee([u],(m,w,k)=>{let R=m[0],A=R!=null&&R.length>0?R.at(-1):k.prevData[0];if(A==null||A.length===0){w.down([[H]]);return}w.emit(A[A.length-1])},{name:t!=null?`${t}::lastValue`:"lastValue",describeKind:"derived",initial:a.size===0?void 0:a.at(a.size-1)}),_=W([u],([m])=>m.length>0,{name:t!=null?`${t}::hasLatest`:"hasLatest",describeKind:"derived",initial:a.size>0}),Ie(b),Ie(_))}let x={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 T(),u},get lastValue(){return T(),b},get hasLatest(){return T(),_},view(m){switch(m.kind){case"tail":return g(m.n);case"slice":return O(m.start,m.stop);case"fromCursor":return v(m.cursor)}},attach(m){let w=m.subscribe(k=>{for(let R of k)R[0]===G&&x.append(R[1])});return()=>w()},attachStorage(m){if(m.length===0)return()=>{};let w=new Map;for(let R of m)w.set(R,a.size);(async()=>{for(let R of m)if(typeof R.loadEntries=="function")try{let N=await Promise.resolve(R.loadEntries());N.entries.length>0&&a.size===0&&(a.restore(N.entries),w.set(R,N.entries.length),d());break}catch{}})();let k=u.subscribe(R=>{for(let N of R){if(N[0]!==G)continue;let A=N[1];for(let D of m){let S=w.get(D)??0;if(A.length<S){try{let te=D.appendEntries(A);te instanceof Promise&&te.catch(()=>{})}catch{}w.set(D,A.length);continue}if(A.length===S)continue;let ie=A.slice(S);w.set(D,A.length);try{let te=D.appendEntries(ie);te instanceof Promise&&te.catch(()=>{})}catch{}}}});return()=>k()},disposeAllViews(){for(let m of c.values())m.dispose();c.clear();for(let m of f.values())m.dispose();f.clear();for(let m of p.values())m.dispose();p.clear()},dispose(){for(let m of c.values())m.dispose();c.clear();for(let m of f.values())m.dispose();f.clear();for(let m of p.values())m.dispose();p.clear()}};return x}var Ks=zt((r,e)=>{r("observe"),r("signal"),e("write")});function An(r){if(r===null||typeof r!="object"||Object.isFrozen(r))return r;for(let e of Object.keys(r))An(r[e]);return Object.freeze(r)}var En=new WeakSet;function vr(r){let e=r.cache,t=typeof e=="number"&&Number.isFinite(e);!t&&e!==void 0&&!En.has(r)&&(En.add(r),console.warn(`bumpCursor: cursor cache held a non-numeric value (${String(e)}); resetting to 0. Causes include: a snapshot codec round-tripping the cursor as a string / null / NaN, OR a malformed initial seed (e.g. state<number>(NaN)). Audit consumers may see colliding seq values after this point.`));let s=(t?e:0)+1;return r.down([[B],[G,s]]),s}function Rn(r,e,t,n,s,o){let i=e(t,n,s);if(i===void 0)return;let a=o!=null?{...i,handlerVersion:o}:i;r.append(a)}function Pe(r,e){let t=e.freeze??!0;return function(...s){let o=t?s.map(An):s,i=we(),a=e.seq?vr(e.seq):void 0;try{let u=r(...o);return e.audit&&e.onSuccess&&Rn(e.audit,e.onSuccess,o,u,{t_ns:i,seq:a},e.handlerVersion),u}catch(u){if(e.audit&&e.onFailure){let d=u instanceof Error?u.name:typeof u;Rn(e.audit,e.onFailure,o,u,{t_ns:i,seq:a,errorType:d},e.handlerVersion)}throw u}}}kt();Sn();var _r=256;function xe(r,e){if(!Number.isFinite(r)||!Number.isInteger(r)||r<0)throw new Error(`${e} must be a non-negative integer`);return r}function ce(r,e){return Qt("messaging",r,e)}var Tr=1024,Le=class extends oe{_log;_publishImpl;events;latest;hasLatest;constructor(e,t={}){super(e,t.graph),this._log=kn([],{name:"events",maxSize:t.retainedLimit??Tr}),this._log.withLatest(),this.events=this._log.entries,this.add(this.events,{name:"events"}),this.latest=W([this.events],([n])=>{let s=n;return s.length===0?null:s[s.length-1]},{name:"latest",describeKind:"derived",meta:ce("topic_latest")}),this.add(this.latest,{name:"latest"}),this.addDisposer(X(this.latest)),this.hasLatest=W([this.events],([n])=>n.length>0,{name:"hasLatest",describeKind:"derived",meta:ce("topic_has_latest")}),this.add(this.hasLatest,{name:"hasLatest"}),this.addDisposer(X(this.hasLatest)),this.addDisposer(()=>{this.events.down([[L]])}),this.addDisposer(()=>this._log.disposeAllViews()),this._publishImpl=Pe(n=>{this._log.append(n)},{freeze:!1})}publish(e){if(e===void 0)throw new TypeError(`TopicGraph "${this.name}": publish(undefined) is not allowed (spec \xA75.12 SENTINEL).`);this._publishImpl(e)}attachEventStorage(e){return this._log.attachStorage(e)}retained(){return this.events.cache}get _logBundle(){return this._log}},$e=class extends oe{cursor;available;topic;_disposed=!1;_ackImpl;_pullAndAckImpl;constructor(e,t,n={}){super(e,n.graph),this.topic=t;let s;if(n.from!==void 0?n.from==="retained"?s=0:n.from==="now"?s=t.events.cache.length:s=xe(n.from,"subscription from"):s=xe(n.cursor??0,"subscription cursor"),this.cursor=U(s,{name:"cursor",describeKind:"state",meta:ce("subscription_cursor")}),this.add(this.cursor,{name:"cursor"}),this.available=t._logBundle.view({kind:"fromCursor",cursor:this.cursor}),this.add(this.available,{name:"available"}),this.addDisposer(X(this.available)),n.advanceOn!==void 0){let o=n.advanceOn,i=!1,a=ee([o],()=>{if(!i){i=!0;return}if(this._disposed)return;let u=this.available.cache;if(u.length===0)return;let d=this.cursor.cache+u.length;this.cursor.emit(d)},{name:"advancePump",describeKind:"effect",meta:ce("subscription_advance_pump")});this.add(a,{name:"advancePump"}),this.addDisposer(X(a))}this._ackImpl=Pe(o=>{let i=this.available.cache,a=o===void 0?i.length:xe(o,"subscription ack count"),u=Math.min(a,i.length);if(u<=0)return this.cursor.cache;let d=this.cursor.cache+u;return this.cursor.emit(d),d},{freeze:!1}),this._pullAndAckImpl=Pe(o=>{let i=this.available.cache,a=o===void 0?i.length:xe(o,"subscription pullAndAck limit"),u=i.slice(0,a);if(u.length===0)return{items:u,cursor:this.cursor.cache};let d=this.cursor.cache+u.length;return this.cursor.emit(d),{items:u,cursor:d}},{freeze:!1})}ack(e){return this._disposed?this.cursor.cache:this._ackImpl(e)}pull(e){if(this._disposed)return[];let t=this.available.cache,n=e===void 0?t.length:xe(e,"subscription pull limit");return t.slice(0,n)}pullAndAck(e){return this._disposed?{items:[],cursor:this.cursor.cache}:this._pullAndAckImpl(e)}dispose(){this._disposed||(this._disposed=!0,this.cursor.down([[L]]),this.destroy())}},tt=class extends oe{_sourceSub;bridgedCount;output;constructor(e,t,n,s={}){super(e,s.graph),this._sourceSub=Dn(`${e}-subscription`,t,{cursor:s.cursor}),this.mount("subscription",this._sourceSub);let o=Math.max(1,xe(s.maxPerPump??_r,"topic bridge maxPerPump")),i=s.map??(p=>p);this.output=W([this._sourceSub.available],([p])=>{let h=p,l=[],y=Math.min(h.length,o);for(let g=0;g<y;g++){let O=i(h[g]);O!==void 0&&l.push(O)}return l},{name:"output",describeKind:"derived",meta:ce("topic_bridge_output",{targetRef:n.name}),initial:[]}),this.add(this.output,{name:"output"}),this.addDisposer(X(this.output)),this.bridgedCount=U(0,{name:"bridgedCount",describeKind:"state",meta:ce("topic_bridge_count")}),this.add(this.bridgedCount,{name:"bridgedCount"}),this.addDisposer(X(this.bridgedCount));let a=this.output,u=this._sourceSub,d=this.bridgedCount,c=ee([a],()=>{let p=a.cache;if(p.length===0)return;let h=u.available.cache.length,l=Math.min(h,o);if(l>0){u.ack(l);let y=d.cache??0;d.emit(y+p.length)}},{name:"ackPump",describeKind:"effect",meta:ce("topic_bridge_ack_pump")});this.add(c,{name:"ackPump"}),this.addDisposer(X(c));let f=wr(this.output,n);this.addDisposer(f)}};function wr(r,e){return r.subscribe(t=>{for(let n of t){if(n[0]!==G)continue;let s=n[1];s.length!==0&&ne(()=>{for(let o of s)e.publish(o)})}})}var nt=class{_map=new Map;version;constructor(e){this.version=e}get size(){return this._map.size}has(e){return this._map.has(e)}get(e){return this._map.get(e)}set(e,t){this._map.set(e,t)}delete(e){return this._map.delete(e)}keys(){return this._map.keys()}},rt=class extends oe{_registry;version;_defaultTopicOptions;_removeTopicImpl;constructor(e,t={}){super(e,t.graph);let n=U(0,{name:"version",describeKind:"state",meta:ce("hub_version")});this.add(n,{name:"version"}),this.version=n,this._registry=new nt(n),this._defaultTopicOptions={...t.defaultTopicOptions??{}},this._removeTopicImpl=Pe(s=>{try{this.remove(s)}finally{this._registry.delete(s);let o=this.version.cache??0;this.version.emit(o+1)}},{freeze:!1})}get size(){return this._registry.size}has(e){return this._registry.has(e)}topicNames(){return this._registry.keys()}topic(e,t){let n=this._registry.get(e);if(n===void 0){let s={...this._defaultTopicOptions,...t??{}};n=new Le(e,s),this._registry.set(e,n),this.mount(e,n);let o=this.version.cache??0;this.version.emit(o+1)}return n}publish(e,t){this.topic(e).publish(t)}publishMany(e){ne(()=>{for(let[t,n]of e)this.topic(t).publish(n)})}subscribe(e,t,n){let s=this.topic(t);return new $e(e,s,n)}removeTopic(e){return this._registry.has(e)?(this._removeTopicImpl(e),!0):!1}};function Or(r,e){return new Le(r,e)}function Nr(r,e){return new rt(r,e)}function Dn(r,e,t){return new $e(r,e,t)}function xr(r,e,t,n){return new tt(r,e,t,n)}0&&(module.exports={MessagingHubGraph,SubscriptionGraph,TopicBridgeGraph,TopicGraph,TopicRegistry,messagingHub,subscription,topic,topicBridge});
1
+ "use strict";
2
+ var __defProp = Object.defineProperty;
3
+ var __getOwnPropDesc = Object.getOwnPropertyDescriptor;
4
+ var __getOwnPropNames = Object.getOwnPropertyNames;
5
+ var __hasOwnProp = Object.prototype.hasOwnProperty;
6
+ var __copyProps = (to, from, except, desc) => {
7
+ if (from && typeof from === "object" || typeof from === "function") {
8
+ for (let key of __getOwnPropNames(from))
9
+ if (!__hasOwnProp.call(to, key) && key !== except)
10
+ __defProp(to, key, { get: () => from[key], enumerable: !(desc = __getOwnPropDesc(from, key)) || desc.enumerable });
11
+ }
12
+ return to;
13
+ };
14
+ var __reExport = (target, mod, secondTarget) => (__copyProps(target, mod, "default"), secondTarget && __copyProps(secondTarget, mod, "default"));
15
+ var __toCommonJS = (mod) => __copyProps(__defProp({}, "__esModule", { value: true }), mod);
16
+
17
+ // src/patterns/messaging/index.ts
18
+ var messaging_exports = {};
19
+ module.exports = __toCommonJS(messaging_exports);
20
+ __reExport(messaging_exports, require("@graphrefly/pure-ts/patterns/messaging"), module.exports);
21
+ //# sourceMappingURL=index.cjs.map
@@ -0,0 +1 @@
1
+ {"version":3,"sources":["../../../src/patterns/messaging/index.ts"],"sourcesContent":["// Phase 13.9.A shim — re-export from pure-TS sibling until\n// @graphrefly/native (napi binding) and per-milestone swap-overs land.\nexport * from \"@graphrefly/pure-ts/patterns/messaging\";\n"],"mappings":";;;;;;;;;;;;;;;;;AAAA;AAAA;AAEA,8BAAc,mDAFd;","names":[]}