@graphrefly/graphrefly 0.43.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 (422) 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 -4
  59. package/dist/core/index.d.ts +1 -4
  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 -950
  83. package/dist/extra/operators.d.ts +1 -950
  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 -96
  155. package/dist/index.d.ts +45 -96
  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 -21
  167. package/dist/patterns/ai/index.d.ts +1 -21
  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 -14
  203. package/dist/patterns/harness/index.d.ts +1 -14
  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 -9
  233. package/dist/patterns/orchestration/index.d.ts +1 -9
  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 -1
  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-CH-_VwG9.d.cts +0 -199
  275. package/dist/cascading-OgKQZjsa.d.ts +0 -199
  276. package/dist/chunk-35JTVPOX.js +0 -1
  277. package/dist/chunk-3G5U5QNE.js +0 -5
  278. package/dist/chunk-3XDYJRYU.js +0 -1
  279. package/dist/chunk-4I45FVQS.js +0 -1
  280. package/dist/chunk-4VVTGLXJ.js +0 -1
  281. package/dist/chunk-4YAN45KM.js +0 -1
  282. package/dist/chunk-5QDBSZBV.js +0 -1
  283. package/dist/chunk-626TESAC.js +0 -3
  284. package/dist/chunk-6HOSXQKF.js +0 -1
  285. package/dist/chunk-6QZNQS5B.js +0 -1
  286. package/dist/chunk-C72GO4IZ.js +0 -1
  287. package/dist/chunk-CE72X3WO.js +0 -1
  288. package/dist/chunk-CK2E7BTU.js +0 -1
  289. package/dist/chunk-CLD3F4R5.js +0 -1
  290. package/dist/chunk-CUNIRONA.js +0 -1
  291. package/dist/chunk-D27JNOLZ.js +0 -1
  292. package/dist/chunk-D5RFJOZ2.js +0 -1
  293. package/dist/chunk-EBW4V6JN.js +0 -1
  294. package/dist/chunk-ESMPEKEV.js +0 -1
  295. package/dist/chunk-F3IGTWCQ.js +0 -1
  296. package/dist/chunk-F672GV32.js +0 -1
  297. package/dist/chunk-FDQGFWLF.js +0 -1
  298. package/dist/chunk-FG4TKHMC.js +0 -1
  299. package/dist/chunk-GPW2V3RE.js +0 -1
  300. package/dist/chunk-I7IGYPSL.js +0 -1
  301. package/dist/chunk-INQD2KRQ.js +0 -1
  302. package/dist/chunk-JNWRYDJN.js +0 -1
  303. package/dist/chunk-JQFH2DV6.js +0 -1
  304. package/dist/chunk-K2Q24F5T.js +0 -1
  305. package/dist/chunk-KGKJCHEK.js +0 -1
  306. package/dist/chunk-KRH66M4O.js +0 -1
  307. package/dist/chunk-KVV66NN2.js +0 -1
  308. package/dist/chunk-L6NSJVJZ.js +0 -1
  309. package/dist/chunk-LYCLF26R.js +0 -1
  310. package/dist/chunk-NNKJUORL.js +0 -1
  311. package/dist/chunk-NON4NLIC.js +0 -45
  312. package/dist/chunk-O2BLLH7M.js +0 -18
  313. package/dist/chunk-OCKEEPRJ.js +0 -2
  314. package/dist/chunk-OFZG3TB3.js +0 -9
  315. package/dist/chunk-OYJKFY7V.js +0 -1
  316. package/dist/chunk-P6C4WHZO.js +0 -5
  317. package/dist/chunk-PT7W5FCD.js +0 -5
  318. package/dist/chunk-Q4U3A3L5.js +0 -1
  319. package/dist/chunk-QE4IGY7I.js +0 -61
  320. package/dist/chunk-QYADASLV.js +0 -1
  321. package/dist/chunk-QYVXF7GW.js +0 -1
  322. package/dist/chunk-S3EEIPO7.js +0 -1
  323. package/dist/chunk-SUWT3ZON.js +0 -1
  324. package/dist/chunk-TPKQW72B.js +0 -1
  325. package/dist/chunk-TSOYJ743.js +0 -1
  326. package/dist/chunk-TZQPPQEQ.js +0 -1
  327. package/dist/chunk-V5A7M7RJ.js +0 -1
  328. package/dist/chunk-VIMF6LGM.js +0 -1
  329. package/dist/chunk-VJLMUKOI.js +0 -1
  330. package/dist/chunk-VN6RDSK2.js +0 -1
  331. package/dist/chunk-VNC3TMVY.js +0 -1
  332. package/dist/chunk-VOPGGIL7.js +0 -1
  333. package/dist/chunk-VQ4A6T2A.js +0 -1
  334. package/dist/chunk-XG62INFA.js +0 -1
  335. package/dist/chunk-Y4NI3X7O.js +0 -84
  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-2ZukgQ4o.d.cts +0 -112
  339. package/dist/decay-CdEBmDIs.d.ts +0 -112
  340. package/dist/fallback-CqYVLL6X.d.ts +0 -250
  341. package/dist/fallback-Ctlj2tMY.d.cts +0 -250
  342. package/dist/graph-7VguS7a4.d.ts +0 -1668
  343. package/dist/graph-C4SHb3Ly.d.cts +0 -1668
  344. package/dist/index-0rKFCVFp.d.cts +0 -557
  345. package/dist/index-B-i4_g3k.d.ts +0 -651
  346. package/dist/index-B5iz82A3.d.cts +0 -2655
  347. package/dist/index-BAOD98JD.d.cts +0 -754
  348. package/dist/index-BG0BN3PB.d.ts +0 -44
  349. package/dist/index-BJX94aud.d.cts +0 -34
  350. package/dist/index-BP8a88zx.d.ts +0 -385
  351. package/dist/index-BTQtTb_H.d.cts +0 -301
  352. package/dist/index-BVpm6noz.d.cts +0 -36
  353. package/dist/index-Bc41FuHp.d.cts +0 -291
  354. package/dist/index-BdGtBX-X.d.cts +0 -515
  355. package/dist/index-Bf7eqeSF.d.ts +0 -113
  356. package/dist/index-BiX1Nkgx.d.cts +0 -1844
  357. package/dist/index-BoLv_OfD.d.cts +0 -651
  358. package/dist/index-BojK2fwH.d.cts +0 -299
  359. package/dist/index-BsT7F2et.d.ts +0 -291
  360. package/dist/index-BwLvVVsy.d.cts +0 -189
  361. package/dist/index-C59mYFKp.d.ts +0 -121
  362. package/dist/index-C7O6r5fV.d.ts +0 -37
  363. package/dist/index-C9kSENB4.d.cts +0 -127
  364. package/dist/index-C9pjcz3l.d.cts +0 -209
  365. package/dist/index-CAC_rNzm.d.ts +0 -189
  366. package/dist/index-CCq87F7t.d.ts +0 -127
  367. package/dist/index-CDXc9zKM.d.cts +0 -26
  368. package/dist/index-CJK1JkYy.d.ts +0 -36
  369. package/dist/index-CLon-IWF.d.cts +0 -374
  370. package/dist/index-COD1kVoS.d.cts +0 -468
  371. package/dist/index-CPT7C_f1.d.ts +0 -374
  372. package/dist/index-CQG3D1cp.d.ts +0 -468
  373. package/dist/index-CZQXo5tH.d.ts +0 -209
  374. package/dist/index-CZjOhcBy.d.cts +0 -113
  375. package/dist/index-ChOyVLKm.d.cts +0 -86
  376. package/dist/index-CvrqGfNS.d.ts +0 -34
  377. package/dist/index-D-AEQVLo.d.ts +0 -2655
  378. package/dist/index-D4Y1cMG0.d.ts +0 -26
  379. package/dist/index-DBHK8O6H.d.ts +0 -301
  380. package/dist/index-DBevwHj_.d.ts +0 -515
  381. package/dist/index-DIOoAZUX.d.ts +0 -45
  382. package/dist/index-DSZ3ZCHF.d.ts +0 -3402
  383. package/dist/index-Dgs8zcj7.d.ts +0 -102
  384. package/dist/index-Dh_HJ82K.d.ts +0 -299
  385. package/dist/index-Dhc7a7Xo.d.cts +0 -102
  386. package/dist/index-Dmqp7KjD.d.ts +0 -86
  387. package/dist/index-Dn-wI9g4.d.ts +0 -231
  388. package/dist/index-Du7u1lSf.d.cts +0 -385
  389. package/dist/index-DwigL4lY.d.ts +0 -1844
  390. package/dist/index-DyR7eU5S.d.cts +0 -779
  391. package/dist/index-JZUPJIJy.d.ts +0 -779
  392. package/dist/index-K0_0eR8g.d.ts +0 -557
  393. package/dist/index-O16yXPK4.d.cts +0 -3402
  394. package/dist/index-O7fucFrU.d.cts +0 -121
  395. package/dist/index-RV_yDjOX.d.cts +0 -198
  396. package/dist/index-cm1GNcWE.d.ts +0 -754
  397. package/dist/index-f5IivDUX.d.cts +0 -37
  398. package/dist/index-hHcaFlJX.d.cts +0 -45
  399. package/dist/index-tJoTcnHh.d.cts +0 -231
  400. package/dist/index-wAzD9yVj.d.ts +0 -198
  401. package/dist/index-z96luz5O.d.cts +0 -44
  402. package/dist/meta-BgVAsg9j.d.ts +0 -102
  403. package/dist/meta-vE8bxW1E.d.cts +0 -102
  404. package/dist/node-ClS5yC-B.d.cts +0 -1347
  405. package/dist/node-ClS5yC-B.d.ts +0 -1347
  406. package/dist/observable-BsBzUrcI.d.ts +0 -36
  407. package/dist/observable-DLGPPtb8.d.cts +0 -36
  408. package/dist/pipeline-graph-DPqKDk59.d.cts +0 -137
  409. package/dist/pipeline-graph-loP57TBA.d.ts +0 -137
  410. package/dist/reactive-layout-Dsvob4zD.d.cts +0 -183
  411. package/dist/reactive-layout-v7KPvxoc.d.ts +0 -183
  412. package/dist/reactive-log-B00laMSQ.d.cts +0 -223
  413. package/dist/reactive-log-BezYsbA_.d.ts +0 -223
  414. package/dist/reactive-map-48mnZ-nu.d.cts +0 -296
  415. package/dist/reactive-map-BVVPdvmi.d.ts +0 -296
  416. package/dist/resilience-YIWPK4YC.js +0 -1
  417. package/dist/sugar-DLwvMr3F.d.ts +0 -223
  418. package/dist/sugar-DyVGtczU.d.cts +0 -223
  419. package/dist/topology-tree-BNGvuG82.d.ts +0 -25
  420. package/dist/topology-tree-BSdfSwMi.d.cts +0 -25
  421. package/dist/types-B1jDWVsM.d.cts +0 -442
  422. package/dist/types-DkzUUs0H.d.ts +0 -442
@@ -1,3 +1,21 @@
1
- "use strict";var qe=Object.defineProperty;var mn=Object.getOwnPropertyDescriptor;var bn=Object.getOwnPropertyNames;var yn=Object.prototype.hasOwnProperty;var G=(n,e)=>()=>(n&&(e=n(n=0)),e);var vn=(n,e)=>{for(var t in e)qe(n,t,{get:e[t],enumerable:!0})},wn=(n,e,t,r)=>{if(e&&typeof e=="object"||typeof e=="function")for(let s of bn(e))!yn.call(n,s)&&s!==t&&qe(n,s,{get:()=>e[s],enumerable:!(r=mn(e,s))||r.enumerable});return n};var _n=n=>wn(qe({},"__esModule",{value:!0}),n);function Ee(){return ue>0||_e}function wt(){return ue>0}function ce(n){ue>0?Te.push(n):n()}function Re(n){ue+=1;let e=!1;try{n()}catch(t){throw e=!0,t}finally{if(ue-=1,ue===0)if(e){if(!_e){let t=Te.splice(0);for(let r of t)try{r()}catch{}ee.length=0,te.length=0,de.length=0}}else Tn()}}function Tn(){let n=!_e;n&&(_e=!0);let e=[],t=0;try{for(;ee.length>0||te.length>0||de.length>0||n&&Te.length>0;){if(n&&Te.length>0){let o=Te.splice(0);for(let i of o)try{i()}catch(a){e.push(a)}continue}if(t+=1,t>1e3)throw ee.length=0,te.length=0,de.length=0,new Error("batch drain exceeded 1000 iterations \u2014 likely a reactive cycle");let s=(ee.length>0?ee:te.length>0?te:de).splice(0);for(let o of s)try{o()}catch(i){e.push(i)}}}finally{n&&(_e=!1)}if(e.length===1)throw e[0];if(e.length>1)throw new AggregateError(e,"batch drain: multiple callbacks threw")}function Ae(n,e,t){if(e.length===0)return;if(e.length===1){let d=t(e[0][0]);if(d<3||!Ee()){n(e);return}(d>=5?de:d===4?te:ee).push(()=>n(e));return}let r=e.length,s=r,o=r,i=r,a=0;for(;a<r&&t(e[a][0])<3;)a++;for(s=a;a<r&&t(e[a][0])===3;)a++;for(o=a;a<r&&t(e[a][0])===4;)a++;i=a;let u=Ee();if(s>0){let d=e.slice(0,s);n(d)}if(o>s){let d=e.slice(s,o);u?ee.push(()=>n(d)):n(d)}if(i>o){let d=e.slice(o,i);u?te.push(()=>n(d)):n(d)}if(r>i){let d=e.slice(i,r);u?de.push(()=>n(d)):n(d)}}var ue,_e,ee,te,de,Te,Se=G(()=>{"use strict";ue=0,_e=!1,ee=[],te=[],de=[],Te=[]});var le,P,U,q,K,J,Z,V,L,S,fe,Ke,Nn,Ye,On,xn,Je,_t,Tt,Nt,Xe,ne=G(()=>{"use strict";le=Symbol.for("graphrefly/START"),P=Symbol.for("graphrefly/DATA"),U=Symbol.for("graphrefly/DIRTY"),q=Symbol.for("graphrefly/RESOLVED"),K=Symbol.for("graphrefly/INVALIDATE"),J=Symbol.for("graphrefly/PAUSE"),Z=Symbol.for("graphrefly/RESUME"),V=Symbol.for("graphrefly/TEARDOWN"),L=Symbol.for("graphrefly/COMPLETE"),S=Symbol.for("graphrefly/ERROR"),fe=Object.freeze([U]),Ke=Object.freeze([q]),Nn=Object.freeze([K]),Ye=Object.freeze([le]),On=Object.freeze([L]),xn=Object.freeze([V]),Je=Object.freeze([fe]),_t=Object.freeze([Ke]),Tt=Object.freeze([Nn]),Nt=Object.freeze([On]),Xe=Object.freeze([xn])});function xt(n,e){let t=new TextEncoder().encode(n.name);if(t.length===0||t.length>255)throw new Error(`encodeEnvelope: codec name "${n.name}" encodes to ${t.length} bytes (must be 1\u2013255)`);let r=n.version;if(!Number.isInteger(r)||r<0||r>65535)throw new Error(`encodeEnvelope: codec.version ${r} out of u16 range (expected integer 0\u201365535)`);let s=2+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++]=Ze,o[i++]=t.length,o.set(t,i),i+=t.length,o[i++]=r>>>8&255,o[i++]=r&255,o.set(e,i),o}function kt(n,e){if(n.length<Ot)throw new Error(`decodeEnvelope: bytes too short (${n.length} < ${Ot})`);let t=0,r=n[t++];if(r!==Ze)throw new Error(`decodeEnvelope: unsupported envelope version ${r} (expected ${Ze})`);let s=n[t++];if(s===0)throw new Error("decodeEnvelope: name_len must be >= 1");if(t+s+2>n.length)throw new Error(`decodeEnvelope: envelope truncated (need ${t+s+2} bytes, have ${n.length})`);let o=new TextDecoder().decode(n.subarray(t,t+s));t+=s;let i=(n[t]<<8|n[t+1])>>>0;t+=2;let a=n.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 Et(n){n.registerCodec(kn)}var kn,Ze,Ot,Qe=G(()=>{"use strict";kn={name:"json",version:1,contentType:"application/json",encode(n){let e=JSON.stringify(n);return new TextEncoder().encode(e)},decode(n,e){let t=new TextDecoder().decode(n);return JSON.parse(t)}},Ze=1,Ot=4});function De(n){if(n==null)return pe;let{type:e,id:t,...r}=n;return{type:e??"system",id:t??"",...r}}var pe,et=G(()=>{"use strict";pe={type:"system",id:""}});function X(){return Math.trunc(performance.now()*1e6)}function Ce(){return Date.now()*1e6}var Me=G(()=>{"use strict"});function Rt(n){n.registerMessageType(le,{tier:0,wireCrossing:!1}),n.registerMessageType(U,{tier:1,wireCrossing:!1}),n.registerMessageType(K,{tier:1,wireCrossing:!1,metaPassthrough:!1}),n.registerMessageType(J,{tier:2,wireCrossing:!1}),n.registerMessageType(Z,{tier:2,wireCrossing:!1}),n.registerMessageType(P,{tier:3,wireCrossing:!0}),n.registerMessageType(q,{tier:3,wireCrossing:!0}),n.registerMessageType(L,{tier:4,wireCrossing:!0,metaPassthrough:!1}),n.registerMessageType(S,{tier:4,wireCrossing:!0,metaPassthrough:!1}),n.registerMessageType(V,{tier:5,wireCrossing:!0,metaPassthrough:!1})}var Ge,At=G(()=>{"use strict";ne();Ge=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 r=this._messageTypes.get(t);return r!=null?r.tier:1}}get onMessage(){return this._frozen=!0,this._onMessage}get onSubscribe(){return this._frozen=!0,this._onSubscribe}set onMessage(e){this._assertUnfrozen(),this._onMessage=e}set onSubscribe(e){this._assertUnfrozen(),this._onSubscribe=e}get defaultVersioning(){return this._defaultVersioning}set defaultVersioning(e){this._assertUnfrozen(),this._defaultVersioning=e}get defaultHashFn(){return this._defaultHashFn}set defaultHashFn(e){this._assertUnfrozen(),this._defaultHashFn=e}get inspectorEnabled(){return this._inspectorEnabled}set inspectorEnabled(e){this._inspectorEnabled=e}get globalInspector(){return this._globalInspector}set globalInspector(e){this._globalInspector=e}get rigorRecorder(){return this._rigorRecorder}set rigorRecorder(e){this._rigorRecorder=e}registerMessageType(e,t){return this._assertUnfrozen(),this._messageTypes.set(e,{tier:t.tier,wireCrossing:t.wireCrossing??t.tier>=3,metaPassthrough:t.metaPassthrough??!0}),this}messageTier(e){let t=this._messageTypes.get(e);return t!=null?t.tier:1}isWireCrossing(e){let t=this._messageTypes.get(e);return t!=null?t.wireCrossing:!0}isLocalOnly(e){return!this.isWireCrossing(e)}isMetaPassthrough(e){let t=this._messageTypes.get(e);return t!=null?t.metaPassthrough:!0}isKnownMessageType(e){return this._messageTypes.has(e)}registerCodec(e){return this._assertUnfrozen(),this._codecs.set(e.name,e),this}lookupCodec(e){return this._codecs.get(e)}_isFrozen(){return this._frozen}_assertUnfrozen(){if(this._frozen)throw new Error("GraphReFlyConfig is frozen: a node has already captured this config. Register custom types and set hooks before creating any node.")}}});function St(n){return Array.isArray(n)?[...n]:[n]}function En(n,e){return n.has(e)||n.has("*")}function Dt(n){let e=[];return n((s,o)=>{e.push({kind:"allow",actions:new Set(St(s)),where:o?.where??(()=>!0)})},(s,o)=>{e.push({kind:"deny",actions:new Set(St(s)),where:o?.where??(()=>!0)})}),(s,o)=>{let i=!1,a=!1;for(let u of e)En(u.actions,o)&&u.where(s)&&(u.kind==="deny"?i=!0:a=!0);return i?!1:a}}function tt(n){let e=Rn.filter(t=>n({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 W,Rn,Ne=G(()=>{"use strict";W=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}};Rn=["human","llm","wallet","system"]});function nt(n){if(n===void 0)return null;if(typeof n=="number"){if(!Number.isFinite(n))throw new TypeError(`Cannot hash non-finite number: ${n}`);if(Number.isInteger(n)&&!Number.isSafeInteger(n))throw new TypeError(`Cannot hash integer outside safe range (|n| > 2^53-1): ${n}. Cross-language cid parity is not guaranteed for unsafe integers.`);return n}if(typeof n=="string"||typeof n=="boolean"||n===null)return n;if(Array.isArray(n))return n.map(nt);if(typeof n=="object"&&n!==null){let e={};for(let t of Object.keys(n).sort())e[t]=nt(n[t]);return e}return null}function Dn(n){let e=Sn.encode(n),t=e.length,r=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,r>>>0,!1),i.setUint32(s-8,Math.floor(r/4294967296)>>>0,!1);let a=1779033703,u=3144134277,d=1013904242,l=2773480762,g=1359893119,h=2600822924,f=528734635,c=1541459225,m=new Uint32Array(64),p=(y,b)=>y>>>b|y<<32-b;for(let y=0;y<s;y+=64){for(let N=0;N<16;N++)m[N]=i.getUint32(y+N*4,!1);for(let N=16;N<64;N++){let j=m[N-15],$=m[N-2],D=p(j,7)^p(j,18)^j>>>3,ae=p($,17)^p($,19)^$>>>10;m[N]=m[N-16]+D+m[N-7]+ae>>>0}let b=a,v=u,w=d,O=l,x=g,k=h,E=f,R=c;for(let N=0;N<64;N++){let j=p(x,6)^p(x,11)^p(x,25),$=x&k^~x&E,D=R+j+$+An[N]+m[N]>>>0,ae=p(b,2)^p(b,13)^p(b,22),Be=b&v^b&w^v&w,xe=ae+Be>>>0;R=E,E=k,k=x,x=O+D>>>0,O=w,w=v,v=b,b=D+xe>>>0}a=a+b>>>0,u=u+v>>>0,d=d+w>>>0,l=l+O>>>0,g=g+x>>>0,h=h+k>>>0,f=f+E>>>0,c=c+R>>>0}let _=y=>y.toString(16).padStart(8,"0");return _(a)+_(u)+_(d)+_(l)+_(g)+_(h)+_(f)+_(c)}function rt(n){let e=nt(n??null),t=JSON.stringify(e);return Dn(t).slice(0,16)}function Cn(){let n=globalThis.crypto;if(n?.randomUUID)return n.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 st(n,e,t){let r=t?.id??Cn();if(n===0)return{id:r,version:0};let o=(t?.hash??rt)(e);return{id:r,version:0,cid:o,prev:null}}function Ct(n,e,t){n.version+=1,"cid"in n&&(n.prev=n.cid,n.cid=t(e))}var An,Sn,Mt=G(()=>{"use strict";An=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]),Sn=new TextEncoder});function $t(n){return{node:n,unsub:null,prevData:void 0,dirty:!1,involvedThisWave:!1,dataBatch:[],terminal:void 0}}function ot(n){n.prevData=void 0,n.dirty=!1,n.involvedThisWave=!1,n.dataBatch.length=0,n.terminal=void 0}function Pe(n){return n.length===0?n:typeof n[0]=="symbol"?[n]:n}function re(n,e,t){let r=It(n)?n:[],s=typeof n=="function"?n:typeof e=="function"?e:void 0,o={};return It(n)?o=(it(e)?e:t)??{}:it(n)?o=n:o=(it(e)?e:t)??{},new I(r,s,o)}var Gt,Pt,Mn,Gn,he,I,It,it,ge=G(()=>{"use strict";Qe();et();Se();Me();At();Ne();ne();Mt();Gt=()=>{},Pt=100;Mn=(n,e,t,r)=>{t.direction==="down-in"&&n._onDepMessage(t.depIndex,e)},Gn=(n,e,t,r)=>{let s=n;if(s._status==="completed"||s._status==="errored")return;let o=s._cached,i=o===void 0?[Ye]:[Ye,[P,o]];s._status==="dirty"&&i.push(fe),Ae(e,i,s._config.tierOf)},he=new Ge({onMessage:Mn,onSubscribe:Gn});Rt(he);Et(he);I=class n{_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,r){this._config=r.config??he,this._config.onMessage,this._optsName=r.name,this._describeKind=r.describeKind,this._equals=r.equals??Object.is,this._resubscribable=r.resubscribable??!1,this._resetOnTeardown=r.resetOnTeardown??!1,this._autoComplete=r.completeWhenDepsComplete??!0,this._autoError=r.errorWhenDepsError??!0,this._pausable=r.pausable??!0,this._guard=r.guard,this._fn=t,this._partial=r.partial??!1,this._cached=r.initial!==void 0?r.initial:void 0,this._status=e.length===0&&t==null&&this._cached!==void 0?"settled":"sentinel",this._hashFn=r.versioningHash??this._config.defaultHashFn??rt;let s=r.versioning??this._config.defaultVersioning;this._versioningLevel=s,this._versioning=s!=null?st(s,this._cached===void 0?void 0:this._cached,{id:r.versioningId,hash:this._hashFn}):void 0,this._deps=e.map($t);let o={};for(let[a,u]of Object.entries(r.meta??{})){let d={initial:u,name:`${r.name??"node"}:meta:${a}`,describeKind:"state",config:this._config};r.guard!=null&&(d.guard=r.guard),o[a]=new n([],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([[P,a]])},down(a){i._emit(Pe(a))},up(a){i._emitUp(Pe(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 r=this._versioningLevel;if(r!=null&&e<=r)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=st(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=De(e);if(this._guard!=null&&!this._guard(t,"observe"))return!1;if(this._extraGuards!=null){for(let r of this._extraGuards)if(!r(t,"observe"))return!1}return!0}_checkGuard(e){if(e?.internal)return;let t=this._guard!=null||this._extraGuards!=null,r=e?.actor!=null;if(!t&&!r)return;let s=De(e?.actor),o=e?.delivery==="signal"?"signal":"write";if(this._guard!=null&&!this._guard(s,o))throw new W({actor:s,action:o,nodeName:this.name});if(this._extraGuards!=null){for(let i of this._extraGuards)if(!i(s,o))throw new W({actor:s,action:o,nodeName:this.name})}this._lastMutation={actor:s,timestamp_ns:Ce()}}down(e,t){let r=Pe(e);r.length!==0&&(this._checkGuard(t),this._emit(r))}emit(e,t){this._checkGuard(t),this._emit([[P,e]])}up(e,t){if(this._deps.length===0)return;let r=Pe(e);if(r.length===0)return;this._checkGuard(t);let s=t??{internal:!0};this._validateUpTiers(r);for(let o of this._deps)o.node.up?.(r,s)}_emitUp(e){if(this._deps.length!==0&&e.length!==0){this._validateUpTiers(e);for(let t of this._deps)t.node.up?.(e,{internal:!0})}}_validateUpTiers(e){let t=this._config.tierOf;for(let r of e){let s=t(r[0]);if(s===3||s===4)throw new Error(`Node "${this.name}": tier-${s} messages cannot flow up \u2014 DATA/RESOLVED/COMPLETE/ERROR are downstream-only. Use \`down(...)\` for value delivery; \`up(...)\` is for control signals (DIRTY, INVALIDATE, PAUSE, RESUME, TEARDOWN).`)}}subscribe(e,t){if(t!=null&&this._guard!=null){let u=De(t);if(!this._guard(u,"observe"))throw new W({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)ot(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 r=0;r<e;r++){let s=r,o=this._deps[r];o.unsub=Gt,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(r){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{}ot(o)}}throw this._dirtyDepCount=0,r}}_addDep(e){for(let s=0;s<this._deps.length;s++)if(this._deps[s].node===e)return s;let t=this._deps.length,r=$t(e);if(this._deps.push(r),this._sinks==null)return t;r.dirty=!0,this._dirtyDepCount++,this._status!=="dirty"&&this._emit(Je),r.unsub=Gt;try{r.unsub=e.subscribe(s=>{if(r.unsub===null)return;let o=this._config.tierOf,i=!1;for(let a of s)o(a[0])>=3&&(i=!0),this._config.onMessage(this,a,{direction:"down-in",depIndex:t},this._actions);i&&this._maybeRunFnOnSettlement()})}catch(s){throw r.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(r){this._emit([[S,this._wrapFnError("cleanup threw",r)]])}else if(t!=null&&typeof t=="object"){let r=t.deactivate;if(typeof r=="function")try{r()}catch(s){this._emit([[S,this._wrapFnError("cleanup.deactivate threw",s)]])}}for(let r of this._deps){if(r.unsub!=null){let s=r.unsub;r.unsub=null;try{s()}catch{}}ot(r)}this._waveHasNewData=!1,this._hasNewTerminal=!1,this._hasCalledFnOnce=!1,this._paused=!1,this._pendingWave=!1,this._pendingRerun=!1,this._rerunDepth=0,this._store={},this._dirtyDepCount=0,this._pauseLocks=null,this._pauseBuffer=null,this._fn!=null&&(this._cached=void 0),e||(this._fn!=null||this._deps.length>0)&&(!this._isTerminal||this._resubscribable)&&(this._status="sentinel")}_onDepMessage(e,t){let r=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!==le){if(s===U){this._depDirtied(r);return}if(s===K){if(this._depInvalidated(r),this._cached===void 0)return;this._emit(Tt);return}if(s===J||s===Z){this._emit([t]);return}if(s===V){this._emit(Xe);return}if(s===P)this._depSettledAsData(r,t[1]);else if(s===q)this._depSettledAsResolved(r);else if(s===L)this._depSettledAsTerminal(r,!0);else if(s===S)this._depSettledAsTerminal(r,t[1]);else{this._emit([t]);return}if(!this._fn){(s===P||s===q)&&this._emit([t]),(s===L||s===S)&&this._maybeAutoTerminalAfterWave();return}}}_depDirtied(e){e.dirty||(e.dirty=!0,e.involvedThisWave=!0,this._dirtyDepCount++,this._status!=="dirty"&&this._emit(Je))}_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([[S,e.terminal]]);return}this._autoComplete&&this._deps.every(t=>t.terminal!==void 0)&&this._emit(Nt)}_execFn(){if(!this._fn||this._isTerminal&&!this._resubscribable)return;if(this._isExecutingFn){this._pendingRerun=!0;return}let e=this._cleanup;if(typeof e=="function"){this._cleanup=void 0;try{e()}catch(i){this._emit([[S,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([[S,this._wrapFnError("cleanup.beforeRun threw",a)]]);return}}}let t=this._deps.map(i=>i.involvedThisWave?i.dataBatch.length>0?[...i.dataBatch]:[]:void 0),r=this._deps.map(i=>i.prevData);for(let i=0;i<this._deps.length;i++){let a=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:r,terminalDeps:s,store:this._store};if(this._hasCalledFnOnce=!0,this._clearWaveFlags(),this._inspectorHooks!=null){let i={kind:"run",batchData:t,prevData:r};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([[S,this._wrapFnError("fn threw",i)]])}finally{this._isExecutingFn=!1,this._pendingRerun?(this._pendingRerun=!1,this._rerunDepth+=1,this._rerunDepth>Pt?(this._rerunDepth=0,this._emit([[S,new Error(`Node "${this.name}": _pendingRerun depth exceeded ${Pt} \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 r=t instanceof Error?t.message:String(t);return new Error(`Node "${this.name}": ${e}: ${r}`,{cause:t})}_frameBatch(e){let t=this._config.tierOf;if(e.length===1)return t(e[0][0])===3&&this._status!=="dirty"?[fe,e[0]]:e;let r=!0,s=!1,o=!1,i=-1;for(let u of e){let d=t(u[0]);d<i&&(r=!1),d===3&&(s=!0),u[0]===U&&(o=!0),i=d}let a=e;if(!r){let u=e.map((d,l)=>({m:d,i:l,tier:t(d[0])}));u.sort((d,l)=>d.tier-l.tier||d.i-l.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?[fe,...a]:[...a.slice(0,u),fe,...a.slice(u)]}return a}_emit(e){if(e.length===0)return;for(let a=0;a<e.length;a++){let u=e[a];if(u[0]===S&&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]===V||u[0]===K);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!==J&&d!==Z){s?.push(u);continue}if(u.length<2)throw new Error(`Node "${this.name}": [[${d===J?"PAUSE":"RESUME"}]] must carry a lockId payload \u2014 bare PAUSE/RESUME is a protocol violation (C0 rule). Use \`[[PAUSE, lockId]]\` / \`[[RESUME, lockId]]\`.`);let l=!0;if(this._pausable!==!1){let g=u[1];if(d===J)this._pauseLocks==null&&(this._pauseLocks=new Set),this._pauseLocks.add(g),this._paused=!0,this._pausable==="resumeAll"&&this._pauseBuffer==null&&(this._pauseBuffer=[]);else if(this._pauseLocks==null||!this._pauseLocks.has(g))l=!1;else if(this._pauseLocks.delete(g),this._pauseLocks.size===0){if(this._paused=!1,this._pauseBuffer!=null&&this._pauseBuffer.length>0){let h=this._pauseBuffer;this._pauseBuffer=[],this._emit(h)}this._pendingWave&&(this._pendingWave=!1,this._maybeRunFnOnSettlement())}}l?s?.push(u):s==null&&(s=t.slice(0,a))}if(s!=null){if(s.length===0)return;t=s}if(this._hasMeta&&t.some(a=>a[0]===V))for(let a of Object.keys(this.meta))try{this.meta[a]._emit(Xe)}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([[S,i]])}_updateState(e){let t=this._config.tierOf,r,s,o=-1,i=0;for(let l of e)t(l[0])===3&&i++;let a=i<=1,u=-1;if(this._versioning!=null&&i>1){for(let l=e.length-1;l>=0;l--)if(e[l][0]===P){u=l;break}}for(let l=0;l<e.length;l++){let g=e[l],h=g[0];if(h===P){if(g.length>=2){let f=!1;if(a&&this._cached!==void 0)try{f=this._equals(this._cached,g[1])}catch(c){s=this._wrapFnError("equals threw",c),o=l;break}if(f){r==null&&(r=e.slice(0,l)),r.push(Ke),this._status="resolved";continue}this._cached=g[1],this._versioning!=null&&(u<0||l===u)&&Ct(this._versioning,g[1],this._hashFn)}this._status="settled",r?.push(g)}else if(r?.push(g),h===U)this._status="dirty";else if(h===q)this._status="resolved";else if(h===L){this._status="completed";{let f=this._config.rigorRecorder;if(f!=null)try{f.onTerminalTransition(this,"completed",this._autoComplete,this._autoError,this._deps.length>0)}catch{}}}else if(h===S){this._status="errored";{let f=this._config.rigorRecorder;if(f!=null)try{f.onTerminalTransition(this,"errored",this._autoComplete,this._autoError,this._deps.length>0)}catch{}}}else if(h===K){if(this._cached!==void 0){let c=this._config.rigorRecorder;if(c!=null)try{c.onNonVacuousInvalidate(this,this._cached)}catch{}}this._cached=void 0,this._status="dirty";let f=this._cleanup;if(typeof f=="function"){this._cleanup=void 0;try{f()}catch{}}else if(f!=null&&typeof f=="object"){let c=f.invalidate;if(typeof c=="function")try{c()}catch{}}}else h===V&&(this._resetOnTeardown&&(this._cached=void 0),this._deactivate(!0),this._status="sentinel")}let d=o>=0?r??e.slice(0,o):r??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 r of t)r(e)};_dispatchOrAccumulate(e){if(wt()){this._batchPendingMessages===null&&(this._batchPendingMessages=[],ce(()=>this._flushBatchPending()));for(let t of e)this._batchPendingMessages.push(t);return}Ae(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);Ae(this._deliverToSinks,t,this._config.tierOf)}},It=n=>Array.isArray(n),it=n=>typeof n=="object"&&n!=null&&!Array.isArray(n)});function se(n,e){return re([],{...e,initial:n})}function me(n,e){return re((r,s,o)=>n(s,o)??void 0,{describeKind:"producer",...e})}function be(n,e,t){return re(n,(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 Ft(n,e,t){return re(n,(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 $e=G(()=>{"use strict";ge()});function at(n,e){if(e!=null&&e.length>0)return new Set(e);switch(n){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 Pn(n){return n._describeKind!=null?n._describeKind:n._deps.length>0?"derived":n._fn!=null?"producer":"state"}function ut(n,e){let t={factory:n};return e!==void 0&&(t.factoryArgs=e),t}function $n(n){let e={};for(let[t,r]of Object.entries(n.meta))try{e[t]=r.cache}catch{}return e}function dt(n,e,t){let r=e==null,s=!r&&e!=null?[...e].filter(l=>l.startsWith("meta.")).map(l=>l.slice(5)):null,o=r||e.has("meta")||s!=null&&s.length>0,i="state",a=[];n instanceof I&&(i=Pn(n),a=n._deps.map(l=>l.node.name??""));let u={type:i,deps:a};(r||e.has("status"))&&(u.status=n.status);let d=n instanceof I?n._guard:void 0;if(o){let l={...$n(n)};if(d!=null&&l.access===void 0&&(l.access=tt(d)),s!=null&&s.length>0&&!e.has("meta")){let g={};for(let h of s)h in l&&(g[h]=l[h]);u.meta=g}else u.meta=l}if(n.name!=null&&(u.name=n.name),(r||e.has("value"))&&(!t||i==="state")){n.status==="sentinel"&&(u.sentinel=!0);try{u.value=n.cache}catch{}}if((r||e.has("v"))&&n.v!=null){let l={id:n.v.id,version:n.v.version};"cid"in n.v&&(l.cid=n.v.cid,l.prev=n.v.prev),u.v=l}return(r||e.has("guard"))&&d!=null&&(u.guard=tt(d)),(r||e.has("lastMutation"))&&n.lastMutation!=null&&(u.lastMutation=n.lastMutation),u}var ct=G(()=>{"use strict";Ne();ge()});function oe(n){return n.subscribe(()=>{})}var Lt=G(()=>{"use strict"});var lt=G(()=>{"use strict";Lt()});function jt(n){return{describeKind:"derived",...n}}function Vt(...n){return n.length===0?me(e=>{e.down([[L]])},{...jt(),meta:{...ut("merge")}}):me(e=>{let t=n.length,r=0,s=[];for(let o of n){let i=o.subscribe(a=>{for(let u of a)u[0]===P?e.emit(u[1]):u[0]===L?(r+=1,r>=t&&e.down([[L]])):u[0]===S&&e.down([u])});s.push(i)}return()=>{for(let o of s)o()}},{...jt(),meta:{...ut("merge")}})}var Bt=G(()=>{"use strict";ne();ct();$e()});var Ut=G(()=>{"use strict";Bt()});function ft(n,e){if(Object.is(n,e))return!0;if(n==null||e==null||typeof n!="object"||typeof e!="object")return!1;if(Array.isArray(n)){if(!Array.isArray(e)||n.length!==e.length)return!1;for(let o=0;o<n.length;o++)if(!ft(n[o],e[o]))return!1;return!0}if(Array.isArray(e))return!1;let t=Object.keys(n),r=Object.keys(e);if(t.length!==r.length)return!1;let s=new Set(r);for(let o of t)if(!s.has(o)||!ft(n[o],e[o]))return!1;return!0}function Ht(n,e){return`${n}\0${e}`}function pt(n,e){let t=[],r=new Set(n.subgraphs),s=new Set(e.subgraphs),o=[];for(let p of s)r.has(p)||o.push(p);o.sort();for(let p of o)t.push({type:"subgraph-mounted",path:p});let i=new Set(Object.keys(n.nodes)),a=new Set(Object.keys(e.nodes)),u=[];for(let p of a)i.has(p)||u.push(p);u.sort();for(let p of u)t.push({type:"node-added",path:p,node:{...e.nodes[p]}});let d=[];for(let p of a){if(!i.has(p))continue;let _=n.nodes[p]?.meta,y=e.nodes[p]?.meta;_==null&&y==null||ft(_??{},y??{})||d.push(p)}d.sort();for(let p of d)t.push({type:"node-meta-changed",path:p,prevMeta:n.nodes[p]?.meta??{},nextMeta:e.nodes[p]?.meta??{}});let l=new Map;for(let p of n.edges)l.set(Ht(p.from,p.to),p);let g=new Map;for(let p of e.edges)g.set(Ht(p.from,p.to),p);let h=[];for(let[p,_]of g)l.has(p)||h.push(_);h.sort((p,_)=>p.from<_.from?-1:p.from>_.from?1:p.to<_.to?-1:p.to>_.to?1:0);for(let p of h)t.push({type:"edge-added",from:p.from,to:p.to});let f=[];for(let[p,_]of l)g.has(p)||f.push(_);f.sort((p,_)=>p.from<_.from?-1:p.from>_.from?1:p.to<_.to?-1:p.to>_.to?1:0);for(let p of f)t.push({type:"edge-removed",from:p.from,to:p.to});let c=[];for(let p of i)a.has(p)||c.push(p);c.sort();for(let p of c)t.push({type:"node-removed",path:p});let m=[];for(let p of r)s.has(p)||m.push(p);m.sort();for(let p of m)t.push({type:"subgraph-unmounted",path:p});return{events:t,flushedAt_ns:X()}}var zt=G(()=>{"use strict";Me()});var Ie,Wt=G(()=>{"use strict";Ie=class{_timer;_gen=0;start(e,t){this.cancel(),this._gen+=1;let r=this._gen;this._timer=setTimeout(()=>{this._timer=void 0,r===this._gen&&t()},e)}cancel(){this._timer!==void 0&&(clearTimeout(this._timer),this._timer=void 0)}get pending(){return this._timer!==void 0}}});var Oe,qt=G(()=>{"use strict";Oe=class{constructor(e){this.capacity=e;if(!Number.isInteger(e)||e<=0)throw new Error(`RingBuffer capacity must be a positive integer (got ${e})`);this.buf=new Array(e)}buf;head=0;_size=0;get size(){return this._size}get maxSize(){return this.capacity}push(e){let t=(this.head+this._size)%this.capacity;this.buf[t]=e,this._size<this.capacity?this._size++:this.head=(this.head+1)%this.capacity}shift(){if(this._size===0)return;let e=this.buf[this.head];return this.buf[this.head]=void 0,this.head=(this.head+1)%this.capacity,this._size--,e}at(e){if(this._size===0)return;let t=e<0?this._size+e:e;if(!(t<0||t>=this._size))return this.buf[(this.head+t)%this.capacity]}toArray(){let e=new Array(this._size);for(let t=0;t<this._size;t++)e[t]=this.buf[(this.head+t)%this.capacity];return e}clear(){for(let e=0;e<this._size;e++)this.buf[(this.head+e)%this.capacity]=void 0;this.head=0,this._size=0}}});function Kt(n,e,t,r={}){let s=e in n.nodes,o=t in n.nodes;if(!s)return Fe(e,t,"no-such-from");if(!o)return Fe(e,t,"no-such-to");let i=r.maxDepth;if(i!=null&&(!Number.isInteger(i)||i<0))throw new Error("explainPath: maxDepth must be an integer >= 0");if(e===t){if(r.findCycle===!0){let d=In(n,e,r);if(d!=null)return d}let u=Le(e,n.nodes[e],0,r);return je(e,t,[u])}if(i===0)return Fe(e,t,"no-path");let a=Yt(n,e,t,i);return a.found?je(e,t,Jt(n,a.pathOrder,r)):Fe(e,t,a.truncated?"max-depth-exceeded":"no-path")}function Yt(n,e,t,r){let s=new Map,o=[{path:t,depth:0}],i=new Set([t]),a=0,u=!1;for(;a<o.length;){let g=o[a++];if(g.path===e)break;if(r!=null&&g.depth>=r){let m=n.nodes[g.path];m?.deps&&m.deps.length>0&&(u=!0);continue}let h=n.nodes[g.path];if(h==null)continue;let f=h.deps??[],c=new Map;for(let m=0;m<f.length;m++){let p=f[m];if(!p)continue;let _=c.get(p);_==null&&(_=[],c.set(p,_)),_.push(m)}for(let[m,p]of c)i.has(m)||(i.add(m),s.set(m,{from:g.path,depIndices:p}),o.push({path:m,depth:g.depth+1}))}if(!s.has(e))return{found:!1,pathOrder:[],truncated:u};let d=[{path:e}],l=e;for(;l!==t;){let g=s.get(l);if(g==null)return{found:!1,pathOrder:[],truncated:!1};d[d.length-1].depIndices=g.depIndices,d.push({path:g.from}),l=g.from}return{found:!0,pathOrder:d,truncated:!1}}function In(n,e,t){let r=n.nodes[e];if(r==null)return null;let s=r.deps??[],o=[];for(let a=0;a<s.length;a++)s[a]===e&&o.push(a);if(o.length>0){let a=Le(e,r,0,t);a.dep_index=o[0];let u=Le(e,r,1,t);return je(e,e,[a,u])}let i=null;for(let a=0;a<s.length;a++){let u=s[a];if(!u||u===e)continue;let d=Yt(n,u,e,t.maxDepth);d.found&&(i==null||d.pathOrder.length<i.pathOrder.length)&&(i=d,i={found:!0,pathOrder:[{path:e,depIndices:[a]},...d.pathOrder],truncated:!1})}return i==null?null:je(e,e,Jt(n,i.pathOrder,t))}function Jt(n,e,t){return e.map((r,s)=>{let o=n.nodes[r.path],i=Le(r.path,o,s,t);return r.depIndices!=null&&r.depIndices.length>0&&(i.dep_index=r.depIndices[0],r.depIndices.length>1&&(i.dep_indices=[...r.depIndices])),i})}function Le(n,e,t,r){let s={path:n,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=r.annotations?.get(n)??e.annotation;o!=null&&(s.annotation=o);let i=r.lastMutations?.get(n)??e.lastMutation;return i!=null&&(s.lastMutation=i),s}function je(n,e,t){return Xt(n,e,!0,"ok",t)}function Fe(n,e,t){return Xt(n,e,!1,t,[])}function Xt(n,e,t,r,s){let o=Fn(n,e,t,r,s);return{from:n,to:e,found:t,reason:r,steps:s,text:o,toJSON(){return{from:n,to:e,found:t,reason:r,steps:s}}}}function Fn(n,e,t,r,s){if(!t)switch(r){case"no-such-from":return`explainPath: no node named "${n}"`;case"no-such-to":return`explainPath: no node named "${e}"`;case"max-depth-exceeded":return`explainPath: no path from "${n}" to "${e}" within maxDepth`;default:return`explainPath: no path from "${n}" to "${e}"`}let o=[`Causal path: ${n} \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: ${Ln(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 Ln(n){if(n===void 0)return"<sentinel>";if(n===null)return"null";if(typeof n=="string")return JSON.stringify(n);if(typeof n=="number"||typeof n=="boolean"||typeof n=="bigint")return String(n);try{let e=JSON.stringify(n);return e.length>80?`${e.slice(0,77)}...`:e}catch{return String(n)}}var Zt=G(()=>{"use strict"});function Qt(n){let e=new WeakSet,t=new WeakSet,r=[n],s=0;for(;r.length>0;){let o=r.pop();s+=Vn(o,e,t,r)}return s}function Vn(n,e,t,r){if(n==null)return 0;switch(typeof n){case"number":return F.number;case"boolean":return F.boolean;case"string":return F.string+n.length*2;case"bigint":return F.bigint+Bn(n);case"symbol":return F.symbol;case"function":return e.has(n)?0:(e.add(n),F.function);case"undefined":return 0}let o=n;if(e.has(o))return 0;e.add(o);let i=o[jn];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 F.date;if(o instanceof RegExp)return F.regexp+o.source.length*2;if(o instanceof Error){let d=o.message?o.message.length*2:0,l=o.stack?o.stack.length*2:0;return F.error+d+l}if(typeof URL<"u"&&o instanceof URL)return F.url+o.href.length*2;if(typeof Promise<"u"&&o instanceof Promise)return F.promise;if(o instanceof WeakMap)return F.weakmap;if(o instanceof WeakSet)return F.weakset;if(o instanceof Map){let d=F.map;for(let[l,g]of o)d+=F.mapEntry,r.push(l),r.push(g);return d}if(o instanceof Set){let d=F.set;for(let l of o)d+=F.setEntry,r.push(l);return d}if(Array.isArray(o)){let d=F.array+o.length*8;for(let l of o)r.push(l);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=F.object,u=Object.keys(o);for(let d of u){a+=F.string+d.length*2;try{r.push(o[d])}catch{}}return a}function Bn(n){let e=n<0n?-n:n;if(e===0n)return 0;let t=e.toString(2).length;return Math.ceil(t/32)*8}var F,jn,en=G(()=>{"use strict";F={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},jn=Symbol.for("sizeof")});function tn(n,e){let t=e?.topN??10,r=n.describe({detail:"standard"}),s=[],o=n._collectObserveTargets;typeof o=="function"&&o.call(n,"",s);let i=new Map;for(let[h,f]of s)i.set(h,f);let a=[];for(let[h,f]of Object.entries(r.nodes)){let c=i.get(h),m=c instanceof I?c:null,p=m?Qt(m.cache):0,_=m?m._sinkCount:0,y=f.deps?.length??0,b=f.type==="effect"&&_===0,v=_===0?f.type==="effect"?"orphan-effect":f.type==="derived"?"idle-derived":f.type==="producer"?"idle-producer":null:null;a.push({path:h,type:f.type,status:f.status??"unknown",valueSizeBytes:p,subscriberCount:_,depCount:y,isOrphanEffect:b,orphanKind:v})}let u=a.reduce((h,f)=>h+f.valueSizeBytes,0),d=(h,f)=>[...a].sort(f??((c,m)=>m[h]-c[h])).slice(0,t),l=a.filter(h=>h.orphanKind!=null),g=a.filter(h=>h.isOrphanEffect);return{nodeCount:a.length,edgeCount:r.edges.length,subgraphCount:r.subgraphs.length,nodes:a,totalValueSizeBytes:u,hotspots:{byValueSize:d("valueSizeBytes"),bySubscriberCount:d("subscriberCount"),byDepCount:d("depCount")},orphans:l,orphanEffects:g}}var nn=G(()=>{"use strict";ge();en()});function rn(n,e){let t=Math.max(16,n.size*4),r=0;for(;n.size>0;){if(r++>=t){console.error(`[Graph "${e}".destroy] disposer drain exceeded cap (${t}); ${n.size} disposer(s) discarded`),n.clear();return}let s=n.values().next();if(s.done)return;let o=s.value;n.delete(o);try{o()}catch(i){console.error(`[Graph "${e}".destroy] disposer threw:`,i)}}}function cn(n){return n!=null&&typeof n=="object"&&"cache"in n&&typeof n.subscribe=="function"&&typeof n.down=="function"}function Un(n){if(n!=null)return cn(n)?n.cache:n}function ie(n){return n!=null&&typeof n=="object"&&"cache"in n&&typeof n.subscribe=="function"&&typeof n.down=="function"}function Q(n){return ie(n)?n.cache??"":n}function sn(n){return ie(n)?n.cache??0:n}function on(n){return ie(n)?n.cache??!1:n}function Hn(n){let e=[];for(let t of Object.keys(n).sort()){let r=n[t].v;r!=null&&e.push(`${t} ${r.id} ${r.version}`)}return e.join(`
3
- `)}function an(n){if(n.version!==ye)throw new Error(`unsupported snapshot version ${String(n.version)} (expected ${ye})`);for(let e of["name","nodes","edges","subgraphs"])if(!(e in n))throw new Error(`snapshot missing required key "${e}"`);if(typeof n.name!="string")throw new TypeError("snapshot 'name' must be a string");if(typeof n.nodes!="object"||n.nodes===null||Array.isArray(n.nodes))throw new TypeError("snapshot 'nodes' must be an object");if(!Array.isArray(n.edges))throw new TypeError("snapshot 'edges' must be an array");if(!Array.isArray(n.subgraphs))throw new TypeError("snapshot 'subgraphs' must be an array")}function zn(n,e){let t=new WeakMap,r=(s,o)=>{if(Object.is(s,o))return!0;if(s==null||o==null||typeof s!="object"||typeof o!="object")return!1;let i=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 h=o;if(s.length!==h.length)return!1;for(let f=0;f<s.length;f++)if(!r(s[f],h[f]))return!1;return!0}if(s instanceof Map){let h=o;if(s.size!==h.size)return!1;for(let[f,c]of s)if(!h.has(f)||!r(c,h.get(f)))return!1;return!0}if(s instanceof Set){let h=o;if(s.size!==h.size)return!1;for(let f of s){let c=!1;for(let m of h)if(r(f,m)){c=!0;break}if(!c)return!1}return!0}if(ArrayBuffer.isView(s)){let h=s,f=o;if(h.length!==f.length)return!1;for(let c=0;c<h.length;c++)if(h[c]!==f[c])return!1;return!0}let d=Object.keys(s),l=Object.keys(o);if(d.length!==l.length)return!1;let g=new Set(l);for(let h of d)if(!g.has(h)||!r(s[h],o[h]))return!1;return!0};return r(n,e)}function Wn(n){return n.replace(/[.*+?^${}()|[\]\\]/g,"\\$&")}function Ve(n){let e="^";for(let t=0;t<n.length;t+=1){let r=n[t];if(r==="*"){e+=".*";continue}if(r==="?"){e+=".";continue}if(r==="["){let s=n.indexOf("]",t+1);if(s<=t+1){e+="\\[";continue}let o=n.slice(t+1,s);o.startsWith("!")&&(o=`^${o.slice(1)}`),o=o.replace(/\\/g,"\\\\"),e+=`[${o}]`,t=s;continue}e+=Wn(r)}return e+="$",new RegExp(e)}function ht(n){if(typeof n=="string")return JSON.stringify(n);if(typeof n=="number"||typeof n=="boolean"||n==null)return String(n);try{return JSON.stringify(n)}catch{return"[unserializable]"}}function Yn(n){return n==="none"?Kn:n==="ansi"||n==null?qn:{data:n.data??"",dirty:n.dirty??"",resolved:n.resolved??"",invalidate:n.invalidate??"",pause:n.pause??"",resume:n.resume??"",complete:n.complete??"",error:n.error??"",teardown:n.teardown??"",derived:n.derived??"",path:n.path??"",reset:n.reset??""}}function un(n){if(n==null)return{};let e=n.detail;return e==="full"?{...n,structured:n.structured??!0,timeline:n.timeline??!0,causal:n.causal??!0,derived:n.derived??!0}:e==="minimal"?{...n,structured:n.structured??!0}:n.format==="stage-log"?{...n,structured:n.structured??!0,timeline:n.timeline??!0}:n}function Jn(n,e,t){for(let r=0;r<n.length;r++){let s=n.charCodeAt(r);if(s<32||s===127)throw new Error(`Graph "${e}": ${t} "${n}" must not contain control character (U+${s.toString(16).padStart(4,"0").toUpperCase()} at index ${r})`)}}function gt(n,e,t){if(n==="")throw new Error(`Graph "${e}": ${t} name must be non-empty`);if(n.includes(M))throw new Error(`Graph "${e}": ${t} "${n}" must not contain '${M}' (path separator)`);if(n===Y)throw new Error(`Graph "${e}": ${t} name "${Y}" is reserved for meta companion paths`);Jn(n,e,t)}function Xn(n,e){if(n==="")throw new Error(`Graph "${e}": resolve path must be non-empty`);let t=n.split(M);for(let r of t)if(r==="")throw new Error(`Graph "${e}": resolve path has empty segment`);return t}function Zn(n,e){let t=!1;for(let s of n)if(!e.isMetaPassthrough(s[0])){t=!0;break}return t?n.filter(s=>e.isMetaPassthrough(s[0])):n}function ln(n){for(let e of n._mounts.values())ln(e);for(let e of n._nodes.values())try{e.down([[V]],{internal:!0})}catch{}}function Qn(n,e){let t=ve.diff(n,e),r={};for(let s of t.nodesAdded){let o=e.nodes[s];o!=null&&(r[s]=o)}return{...t,nodesAddedFull:r}}function dn(n,e,t,r={}){let s={paths:[],depths:new Map,truncated:!1};if(!e)return r.withDetail?s:[];if(!r.both&&t!=="upstream"&&t!=="downstream")throw new Error('reachable: direction must be "upstream" or "downstream"');let o=r.maxDepth;if(o!=null&&(!Number.isInteger(o)||o<0))throw new Error("reachable: maxDepth must be an integer >= 0");if(o===0)return r.withDetail?s:[];let i=new Map,a=new Map,u=new Map,d=new Map,l=new Set;for(let[b,v]of Object.entries(n.nodes)){if(!b)continue;l.add(b);let w=v.deps??[];i.set(b,w);for(let O of w)O&&(l.add(O),a.has(O)||a.set(O,new Set),a.get(O).add(b))}for(let b of n.edges){if(b==null||typeof b!="object")continue;let v=typeof b.from=="string"?b.from:"",w=typeof b.to=="string"?b.to:"";!v||!w||(l.add(v),l.add(w),d.has(v)||d.set(v,new Set),d.get(v).add(w),u.has(w)||u.set(w,new Set),u.get(w).add(v))}if(!l.has(e))return r.withDetail?s:[];let g=r.both===!0,h=b=>{if(g){let x=i.get(b)??[],k=u.get(b),E=a.get(b),R=d.get(b),N=[...x];return k&&N.push(...k),E&&N.push(...E),R&&N.push(...R),N}if(t==="upstream"){let x=i.get(b)??[],k=u.get(b);return k?[...x,...k]:x}let v=a.get(b),w=d.get(b),O=v?[...v]:[];return w&&O.push(...w),O},f=new Set([e]),c=new Map,m=[{path:e,depth:0}],p=0,_=!1;for(;p<m.length;){let b=m[p++];if(o!=null&&b.depth>=o){h(b.path).length>0&&(_=!0);continue}for(let v of h(b.path))!v||f.has(v)||(f.add(v),c.set(v,b.depth+1),m.push({path:v,depth:b.depth+1}))}let y=[...c.keys()].sort((b,v)=>b<v?-1:b>v?1:0);return r.withDetail?{paths:y,depths:c,truncated:_}:y}function er(n,e){if(n.length!==e.length)return!1;for(let t=0;t<n.length;t++){let r=n[t],s=e[t];if(r.path!==s.path||r.type!==s.type||r.status!==s.status||r.hop!==s.hop||r.dep_index!==s.dep_index||r.annotation!==s.annotation||r.value!==s.value||r.lastMutation!==s.lastMutation)return!1;let o=r.v,i=s.v;if(o!==i&&(o==null||i==null||o.id!==i.id||o.version!==i.version))return!1}return!0}var M,Y,ye,qn,Kn,ve,fn=G(()=>{"use strict";et();Se();Me();Ne();ne();ct();ge();$e();zt();lt();Wt();qt();Qe();Zt();nn();M="::",Y="__meta__",ye=1;qn={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"},Kn={data:"",dirty:"",resolved:"",invalidate:"",pause:"",resume:"",complete:"",error:"",teardown:"",derived:"",path:"",reset:""};ve=class n{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(M))throw new Error(`Graph name must not contain '${M}' (got "${e}")`);if(e===Y)throw new Error(`Graph name "${Y}" is reserved for meta companion paths`);this.name=e,this.opts=Object.freeze({...t??{}}),this.config=t?.config??he,this._traceRing=new Oe(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=[],r=e?this:this._parent;for(;r!=null;)t.push(r),r=r._parent;return t}get topology(){return this._topology==null&&(this._topology=me(e=>{let t=r=>{e.emit(r)};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 r=e.name,s=t?.name??r;if(s==null||s==="")throw new Error(`Graph "${this.name}": graph.add requires a non-empty name \u2014 pass via opts.name or set it on the node (e.g. state(0, { name: "x" }))`);let o=s,i=t?.annotation;if(gt(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:X()})),e}setVersioning(e){if(e!=null)for(let t of this._nodes.values())t instanceof I&&t._applyVersioning(e)}remove(e){gt(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(`${M}${Y}${M}`)||o.nodes.push(a);return o.nodes.sort(),o.mounts.push(e),o.mounts.push(...t._collectSubgraphs(`${e}${M}`)),this._mounts.delete(e),t._parent=void 0,ln(t),this._emitTopology({kind:"removed",name:e,nodeKind:"mount",audit:o}),o}let r=this._nodes.get(e);if(!r)throw new Error(`Graph "${this.name}": unknown node or mount "${e}"`);this._nodes.delete(e),this._nodeToName.delete(r),r.down([[V]],{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=Ve(e);return i=>o.test(i)})(),r={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);r.nodes.push(...i.nodes),r.mounts.push(...i.mounts)}return r.nodes.sort(),r.mounts.sort(),r}[Symbol.iterator](){let e=[...this._nodes.keys()].sort(),t=this._nodes,r=0;return{[Symbol.iterator](){return this},next(){if(r>=e.length)return{value:void 0,done:!0};let s=e[r++];return{value:[s,t.get(s)],done:!1}}}}node(e){if(e==="")throw new Error(`Graph "${this.name}": node name must be non-empty`);if(e.includes(M))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,r){let s=r?.internal===!0;this.node(e).down([[P,t]],{actor:r?.actor,internal:s,delivery:"write"})}setAll(e,t){let r=Symbol.iterator in e?e:Object.entries(e);Re(()=>{for(let[s,o]of r)this.set(s,o,t)})}invalidate(e,t){let r=t?.internal===!0;this.node(e).down([[K]],{actor:t?.actor,internal:r,delivery:"write"})}error(e,t,r){let s=r?.internal===!0;this.node(e).down([[S,t]],{actor:r?.actor,internal:s,delivery:"write"})}complete(e,t){let r=t?.internal===!0;this.node(e).down([[L]],{actor:t?.actor,internal:r,delivery:"write"})}edges(e){let t=e?.recursive===!0,r=new Map;if(!t){for(let[u,d]of this._nodes)r.set(d,u);let a=[];for(let[u,d]of this._nodes)if(d instanceof I)for(let l of d._deps){let g=r.get(l.node);g!=null&&a.push([g,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 I)for(let d of u._deps){let l=o.get(d.node);l!=null&&i.push([l,a])}return i.sort((a,u)=>a[0]<u[0]?-1:a[0]>u[0]?1:a[1]<u[1]?-1:a[1]>u[1]?1:0),i}mount(e,t){if(t===void 0){let s=new n(e);return this.mount(e,s)}if(typeof t=="function"){let s=new n(e);return t(s),this.mount(e,s)}let r=t;if(gt(e,this.name,"mount"),this._nodes.has(e))throw new Error(`Graph "${this.name}": cannot mount at "${e}" \u2014 node with that name exists`);if(this._mounts.has(e))throw new Error(`Graph "${this.name}": mount "${e}" already exists`);if(r===this)throw new Error(`Graph "${this.name}": cannot mount a graph into itself`);if(r._parent!=null)throw new Error(`Graph "${this.name}": this child graph is already mounted on "${r._parent.name}"`);for(let s=this;s!=null;s=s._parent)if(s===r)throw new Error(`Graph "${this.name}": mount("${e}", \u2026) would create a mount cycle`);return this._mounts.set(e,r),r._parent=this,this._emitTopology({kind:"added",name:e,nodeKind:"mount"}),r}resolve(e){let t=Xn(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 r=t[0],s=t.slice(1);if(s.length===0){let a=this._nodes.get(r);if(a)return a;throw this._mounts.has(r)?new Error(`Graph "${this.name}": path ends at subgraph "${r}" \u2014 not a node (GRAPHREFLY-SPEC \xA73.5)`):new Error(`Graph "${this.name}": unknown name "${r}"`)}let o=this._nodes.get(r);if(o&&s.length>0&&s[0]===Y)return this._resolveMetaChainFromNode(o,s,t.join(M));let i=this._mounts.get(r);if(!i)throw this._nodes.has(r)?new Error(`Graph "${this.name}": "${r}" is a node; trailing path "${s.join(M)}" is invalid`):new Error(`Graph "${this.name}": unknown mount or node "${r}"`);return i.resolve(s.join(M))}_resolveMetaChainFromNode(e,t,r){let s=e,o=0,i=[...t];for(;o<i.length;){if(i[o]!==Y)throw new Error(`Graph "${this.name}": expected ${Y} segment in meta path "${r}"`);if(o+1>=i.length)throw new Error(`Graph "${this.name}": meta path requires a key after ${Y} in "${r}"`);let a=i[o+1],u=s.meta[a];if(!u)throw new Error(`Graph "${this.name}": unknown meta "${a}" in path "${r}"`);s=u,o+=2}return s}signal(e,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 r=[];if(this._signalDeliver(e,t??{},new Set,r),r.length>0)throw r[0]}_signalDeliver(e,t,r,s){for(let u of this._mounts.values())u._signalDeliver(e,t,r,s);let i=t.internal===!0?{internal:!0}:{actor:t.actor,delivery:"signal"},a=Zn(e,this.config);for(let u of[...this._nodes.keys()].sort()){let d=this._nodes.get(u);if(!r.has(d)){r.add(d);try{d.down(e,i)}catch(l){if(l instanceof W)throw l;s.push(l)}a.length!==0&&this._signalMetaSubtree(d,a,r,i,s)}}}_signalMetaSubtree(e,t,r,s,o){for(let i of Object.keys(e.meta).sort()){let a=e.meta[i];if(!r.has(a)){r.add(a);try{a.down(t,s)}catch(u){if(u instanceof W)throw u;o.push(u)}this._signalMetaSubtree(a,t,r,s,o)}}}describe(e){if(e?.reactive==="diff")return this._describeReactiveDiff(e);if(e?.reactive===!0)return this._describeReactive(e);let t=Un(e?.actor),r=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=at(e?.detail,e?.fields),o=e?.detail==="spec",i=s,a=[];this._collectObserveTargets("",a);let u=new Map;for(let[v,w]of a)u.set(w,v);let d=[];{let v=a.map(([,x])=>x),w=new Set(u.values()),O=0;for(;v.length>0;){let x=v.shift();if(x instanceof I)for(let k of x._deps){let E=k.node;if(u.has(E))continue;let R=E.name??"",N=R;if(!N||w.has(N))if(R){let j=2;for(;w.has(`${R}#${j}`);)j++;N=`${R}#${j}`}else for(N=`__internal__/${O++}`;w.has(N);)N=`__internal__/${O++}`;u.set(E,N),w.add(N),d.push([N,E]),v.push(E)}}}let l=[...a,...d],g={};for(let[v,w]of l){if(t!=null&&!w.allowsObserve(t))continue;let O=dt(w,i,o),x=w instanceof I?w._deps.map(N=>u.get(N.node)??N.node.name??""):[],{name:k,...E}=O,R={...E,deps:x};if(!o){let N=this._annotations.get(v);N!=null&&(R.annotation=N)}if(r!=null)if(typeof r=="function"){let N=r;if(!(N.length>=2?N(v,R):N(R)))continue}else{let N=!0;for(let[j,$]of Object.entries(r)){let D=j==="deps_includes"?"depsIncludes":j==="meta_has"?"metaHas":j;if(D==="depsIncludes"){if(!R.deps.includes(String($))){N=!1;break}continue}if(D==="metaHas"){if(!Object.hasOwn(R.meta??{},String($))){N=!1;break}continue}if(R[D]!==$){N=!1;break}}if(!N)continue}g[v]=R}let h=new Set(Object.keys(g)),f=[];for(let[v,w]of l)if(w instanceof I)for(let O of w._deps){let x=u.get(O.node);x!=null&&f.push([x,v])}f.sort((v,w)=>v[0]<w[0]?-1:v[0]>w[0]?1:v[1]<w[1]?-1:v[1]>w[1]?1:0);let c=f.map(([v,w])=>({from:v,to:w}));(t!=null||r!=null)&&(c=c.filter(v=>h.has(v.from)&&h.has(v.to)));let m=this._collectSubgraphs(""),p=t!=null||r!=null?m.filter(v=>{let w=`${v}${M}`;return[...h].some(O=>O===v||O.startsWith(w))}):m,_=this,y=e;return{name:this.name,nodes:g,edges:c,subgraphs:p,...this._factory!==void 0?{factory:this._factory}:{},...this._factoryArgs!==void 0?{factoryArgs:this._factoryArgs}:{},expand(v){let w={...y};return Array.isArray(v)?(w.fields=v,w.detail=void 0):(w.detail=v,w.fields=void 0),_.describe(w)}}}_collectSubgraphs(e){let t=[];for(let r of[...this._mounts.keys()].sort()){let s=e===""?r:`${e}${r}`;t.push(s),t.push(...this._mounts.get(r)._collectSubgraphs(`${s}${M}`))}return t}resourceProfile(e){return tn(this,e)}reachable(e,t,r={}){return r.withDetail===!0?dn(this.describe(),e,t,{...r,withDetail:!0}):dn(this.describe(),e,t,r)}explain(e,t,r){return r?.reactive===!0?this._explainReactive(e,t,r):this._explainStatic(Q(e),Q(t),{...r?.maxDepth!==void 0?{maxDepth:sn(r.maxDepth)}:{},...r?.findCycle!==void 0?{findCycle:on(r.findCycle)}:{}})}_explainStatic(e,t,r){let s=this.describe({detail:"full"}),o=new Map(this._annotations),i=new Map;for(let[a,u]of Object.entries(s.nodes))u.lastMutation!=null&&i.set(a,u.lastMutation);return Kt(s,e,t,{...r?.maxDepth!=null?{maxDepth:r.maxDepth}:{},...r?.findCycle===!0?{findCycle:!0}:{},annotations:o,lastMutations:i})}_describeReactive(e){let t={...e,reactive:!1},r=e.reactiveName??"describe",s=0,o=se(s,{name:`${r}_version`}),i=this.observe({timeline:!0,structured:!0}),a=!1,u=!1,d=()=>{a||u||(a=!0,ce(()=>{a=!1,!u&&(s+=1,o.emit(s))}))},l=i.onEvent(y=>{let b=y.type;b!=="data"&&b!=="error"&&b!=="complete"&&b!=="teardown"||d()}),g=[],h=new WeakSet,f=y=>{if(h.has(y)||u)return;h.add(y);let b=y.topology.subscribe(v=>{for(let w of v){if(w[0]!==P)continue;let O=w[1];if(d(),O.kind==="added"&&O.nodeKind==="mount"){let x=y._mounts.get(O.name);x!=null&&f(x)}}});g.push(b);for(let v of y._mounts.keys()){let w=y._mounts.get(v);w!=null&&f(w)}};f(this);let c,m=e.actor;cn(m)&&(c=m.subscribe(y=>{let b=!1,v=!1;for(let w of y){let O=w[0];O===P?b=!0:(O===L||O===S||O===V)&&(v=!0)}b&&d(),v&&(c?.(),c=void 0,d())}));let p;try{p=be([o],()=>this.describe(t),{name:r,describeKind:"derived",meta:{domain:"audit",kind:"describe"},equals:(y,b)=>y===b})}catch(y){l(),c?.();for(let b of g)b();throw i.dispose(),y}let _=oe(p);return{node:p,dispose(){u=!0,l(),c?.();for(let y of g)y();g.length=0,i.dispose(),_()}}}_describeReactiveDiff(e){let t={...e,reactive:!1},r=e.reactiveName??"describe-diff",s={name:this.name,nodes:{},edges:[],subgraphs:[]},o=this.describe(t),i=pt(s,o),a=se(i,{name:r,meta:{domain:"audit",kind:"describe-diff"},equals:(h,f)=>h===f}),u=this._describeReactive({...e,reactiveName:void 0}),d=!1,l=u.node.subscribe(h=>{if(!d)for(let f of h){if(f[0]!==P)continue;let c=f[1],m=pt(o,c);o=c,m.events.length!==0&&a.emit(m)}}),g=oe(a);return{node:a,dispose(){d=!0,l(),u.dispose(),a.down([[V,"describe-diff disposed"]]),g()}}}_explainReactive(e,t,r){let s=0,o=se(s,{name:"explain_version"}),i=this.observe({timeline:!0,structured:!0}),a=!1,u=!1,d=()=>{a||u||(a=!0,ce(()=>{a=!1,!u&&(s+=1,o.emit(s))}))},l=i.onEvent(y=>{let b=y.type;b!=="data"&&b!=="error"&&b!=="complete"&&b!=="teardown"||d()}),g=[];e!=null&&ie(e)&&g.push(e),t!=null&&ie(t)&&g.push(t),r?.maxDepth!=null&&ie(r.maxDepth)&&g.push(r.maxDepth),r?.findCycle!=null&&ie(r.findCycle)&&g.push(r.findCycle);let h=()=>{for(let y of g)if(y.cache===void 0)return!1;return!0},f=()=>{let y=Q(e),b=Q(t);return{from:y,to:b,found:!1,reason:"pending",steps:[],text:"(awaiting reactive args)",toJSON:()=>({from:y,to:b,found:!1,reason:"pending",steps:[]})}},c;try{c=be([o],()=>{if(!h())return f();let y=Q(e),b=Q(t),v={...r?.maxDepth!==void 0?{maxDepth:sn(r.maxDepth)}:{},...r?.findCycle!==void 0?{findCycle:on(r.findCycle)}:{}};return this._explainStatic(y,b,v)},{name:r?.name??"explain",describeKind:"derived",meta:{domain:"audit",kind:"explain_path",from:Q(e),to:Q(t)},equals:(y,b)=>y.found===b.found&&y.reason===b.reason&&y.steps.length===b.steps.length&&er(y.steps,b.steps)})}catch(y){throw l(),i.dispose(),y}let m=oe(c),p=[],_=y=>{let b;return b=y.subscribe(v=>{let w=!1,O=!1;for(let x of v){let k=x[0];k===P?w=!0:(k===L||k===S||k===V)&&(O=!0)}(w||O)&&d(),O&&b&&(b(),b=void 0)}),()=>{b&&(b(),b=void 0)}};for(let y of g)p.push(_(y));return{node:c,dispose(){u=!0,l();for(let y of p)y?.();p.length=0,i.dispose(),m()}}}_pathsMatching(e){let t=Ve(e),r=[];return this._collectObserveTargets("",r),r.map(([s])=>s).filter(s=>t.test(s))}_collectObserveTargets(e,t){for(let r of[...this._mounts.keys()].sort()){let s=e===""?r:`${e}${M}${r}`;this._mounts.get(r)._collectObserveTargets(s,t)}for(let r of[...this._nodes.keys()].sort()){let s=this._nodes.get(r),o=e===""?r:`${e}${M}${r}`;t.push([o,s]),this._appendMetaObserveTargets(o,s,t)}}_appendMetaObserveTargets(e,t,r){for(let s of Object.keys(t.meta).sort()){let o=t.meta[s],i=`${e}${M}${Y}${M}${s}`;r.push([i,o]),this._appendMetaObserveTargets(i,o,r)}}observe(e,t){let r=typeof e=="string",o=un(r?t:e);if(o.reactive===!0)return this._observeReactive(r?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(r){let l=e,g=this.resolve(l);if(a!=null&&!g.allowsObserve(a))throw new W({actor:a,action:"observe",nodeName:l});return i?this._buildStructuredObserver([[l,g]],o,"one"):{subscribe(h){return g.subscribe(h)},up(h){try{g.up?.(h)}catch(f){if(f instanceof W)return;throw f}}}}let u=[];this._collectObserveTargets("",u),u.sort((l,g)=>l[0]<g[0]?-1:l[0]>g[0]?1:0);let d=a==null?u:u.filter(([,l])=>l.allowsObserve(a));return i?this._buildStructuredObserver(d,o,"all"):{subscribe:l=>{let g=d.map(([h,f])=>f.subscribe(c=>{l(h,c)}));return()=>{for(let h of g)h()}},up:(l,g)=>{try{this.resolve(l).up?.(g)}catch(h){if(h instanceof W)return;throw h}}}}_observeReactive(e,t){let r=t.tiers,s=r!=null?new Set(r):null,o=t.reactiveName??"observe";return me(i=>{let a=[],u=!1,d=!1,l=()=>{if(a.length===0||d)return;let m={events:a.slice(),flushedAt_ns:X()};a.length=0,i.emit(m)},g={...t,reactive:!1,structured:!0,timeline:!0},h=e!=null?this.observe(e,g):this.observe(g),f=m=>{d||(a.push(m),!u&&(u=!0,ce(()=>{u=!1,l()})))};for(let m of h.events)f(m);let c=h.onEvent(f);return()=>{d=!0,c(),h.dispose()}},{name:o,meta:{domain:"audit",kind:"observe-reactive"}})}_buildStructuredObserver(e,t,r){let s=r==="one"?e[0]?.[0]:void 0,o=i=>{if(r==="one"&&s!=null){let l=this.resolve(s);return this._buildStructuredObserver([[s,l]],i,"one")}let a=[];this._collectObserveTargets("",a),a.sort((l,g)=>l[0]<g[0]?-1:l[0]>g[0]?1:0);let u=i.actor,d=u==null?a:a.filter(([,l])=>l.allowsObserve(u));return this._buildStructuredObserver(d,i,"all")};return this._createObserveResult(e,t,o)}_createObserveResult(e,t,r){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,l=t.maxEvents,g=l!=null&&l>0?new Oe(l):null,h=[],f=new Set,c=t.tiers!=null?new Set(t.tiers):null,m={},p=new Set,_=0,y=0,b=0,v=0,w=0,O=0,x=!1,k=!1,E=0,R=new Map,N=new Map,j=new Map,$=T=>{if(!(c!=null&&!c.has(T.type))){g?g.push(T):h.push(T);for(let C of f)C(T)}},D=T=>c==null||c.has(T),ae=()=>s?{timestamp_ns:X(),in_batch:Ee(),batch_id:E}:{},Be=(T,C)=>{if(!(!d||!(T instanceof I)))return T._setInspectorHook(H=>{if(H.kind==="dep_message")R.set(T,H.depIndex);else if(H.kind==="run"){let we=H.batchData.map((A,B)=>A!=null&&A.length>0?A.at(-1):H.prevData[B]);N.set(T,we);let z=H.batchData.map(A=>A!=null?[...A]:void 0);j.set(T,z),i&&$({type:"derived",path:C,dep_values:we,dep_batches:z,...ae()})}})},xe=T=>{let C=R.get(T),H=N.get(T);if(!o||H==null)return{};let z=(C!=null&&C>=0&&T instanceof I?T._deps[C]:void 0)?.node,A=z?.v,B=j.get(T);return{trigger_dep_index:C,trigger_dep_name:z?.name,...A!=null?{trigger_version:{id:A.id,version:A.version}}:{},dep_values:[...H],...B!=null?{dep_batches:B}:{}}},bt=[],yt=[];for(let[T,C]of e){let H=Be(C,T);H&&bt.push(H),yt.push(C.subscribe(we=>{E++;for(let z of we){let A=z[0],B=ae();if(A===P){m[T]=z[1];let We=C instanceof I?C.lastMutation?.actor??pe:pe;$({type:"data",path:T,data:z[1],actor:We,...B,...xe(C)})}else if(a)A===U?D("dirty")&&_++:A===q?D("resolved")&&y++:A===K?D("invalidate")&&b++:A===J?D("pause")&&v++:A===Z?D("resume")&&w++:A===V?D("teardown")&&O++:A===L&&!p.has(T)?D("complete")&&(x=!0):A===S&&D("error")&&(k=!0,p.add(T));else if(A===U)D("dirty")&&_++,$({type:"dirty",path:T,...B});else if(A===q)D("resolved")&&y++,$({type:"resolved",path:T,...B,...xe(C)});else if(A===K)D("invalidate")&&b++,$({type:"invalidate",path:T,...B});else if(A===J)D("pause")&&v++,$({type:"pause",path:T,lockId:z[1],...B});else if(A===Z)D("resume")&&w++,$({type:"resume",path:T,lockId:z[1],...B});else if(A===L)D("complete")&&!p.has(T)&&(x=!0),$({type:"complete",path:T,...B});else if(A===S){D("error")&&(k=!0,p.add(T));let We=C instanceof I?C.lastMutation?.actor??pe:pe;$({type:"error",path:T,data:z[1],actor:We,...B})}else A===V&&(D("teardown")&&O++,$({type:"teardown",path:T,...B}))}}))}let Ue=!1,He=()=>{if(!Ue){Ue=!0;for(let T of yt)T();for(let T of bt)T();for(let T of ke)T({value:void 0,done:!0});ke.length=0}},ze=[],ke=[];f.add(T=>{let C=ke.shift();C?C({value:T,done:!1}):ze.push(T)});let vt={get values(){return m},get dirtyCount(){return _},get resolvedCount(){return y},get invalidateCount(){return b},get pauseCount(){return v},get resumeCount(){return w},get teardownCount(){return O},get events(){return g?g.toArray():[...h]},get anyCompletedCleanly(){return x},get anyErrored(){return k},get completedWithoutErrors(){return x&&!k},onEvent(T){return f.add(T),()=>f.delete(T)},dispose:He,expand(T){He();let C={...t};return typeof T=="string"?C.detail=T:Object.assign(C,T),r(un(C))},[Symbol.asyncIterator](){return{next(){return ze.length>0?Promise.resolve({value:ze.shift(),done:!1}):Ue?Promise.resolve({value:void 0,done:!0}):new Promise(T=>ke.push(T))},return(){return He(),Promise.resolve({value:void 0,done:!0})}}}};return t.format!=null&&this._attachFormatLogger(vt,t),vt}_attachFormatLogger(e,t){let r=t.format;if(r==null)return;let s=t.logger??(c=>console.log(c)),o=t.includeTypes?new Set(t.includeTypes):null,i=t.excludeTypes?new Set(t.excludeTypes):null,a=o==null&&i==null?()=>!0:c=>(o==null||o.has(c))&&(i==null||!i.has(c)),u=Yn(t.theme),d=r==="stage-log"?X():0,l=c=>c==null?"":t.stageLabels?.[c]??c,g=(c,m)=>c.length>m?`${c.slice(0,m-1)}\u2026`:c,h=c=>c.type==="data"||c.type==="error"?g(ht(c.data),120):"",f=c=>{if(r==="stage-log"){let x=(X()-d)/1e9,k=l(c.path).padEnd(9);if(c.type==="data"){let E=h(c);return`[${x.toFixed(3)}s] ${k} \u2190${E?` ${E}`:""}`}if(c.type==="error"){let E=h(c);return`[${x.toFixed(3)}s] ${k} \u2717${E?` ${E}`:""}`}return c.type==="complete"?`[${x.toFixed(3)}s] ${k} \u25A0 complete`:`[${x.toFixed(3)}s] ${k} ${c.type}`}if(r==="json")try{return JSON.stringify(c)}catch{return JSON.stringify({type:c.type,path:c.path,data:"[unserializable]"})}let m=u[c.type]??"",p=c.path?`${u.path}${c.path}${u.reset} `:"",_=c.type==="data"||c.type==="error",y=c.type==="pause"||c.type==="resume",b=_?` ${ht(c.data)}`:y?` ${ht(c.lockId)}`:"",v=c.type==="data"||c.type==="resolved"||c.type==="derived"?c:void 0,w=v?.trigger_dep_name!=null?` <- ${v.trigger_dep_name}`:v?.trigger_dep_index!=null?` <- #${v.trigger_dep_index}`:"",O=c.in_batch?" [batch]":"";return`${p}${m}${c.type.toUpperCase()}${u.reset}${b}${w}${O}`};e.onEvent(c=>{a(c.type)&&s(f(c),c)})}addDisposer(e){return this._disposers.add(e),()=>{this._disposers.delete(e)}}destroy(){rn(this._disposers,this.name),this.signal([[V]],{internal:!0}),rn(this._storageDisposers,this.name);for(let e of[...this._mounts.values()])e._parent=void 0,e._destroyClearOnly();this._mounts.clear(),this._nodes.clear(),this._parent=void 0,this._destroyed=!0}get destroyed(){return this._destroyed}_destroyClearOnly(){for(let e of[...this._mounts.values()])e._parent=void 0,e._destroyClearOnly();this._mounts.clear(),this._nodes.clear(),this._parent=void 0,this._destroyed=!0}snapshot(e){let{expand:t,...r}=this.describe({detail:"full"}),s={};for(let a of Object.keys(r.nodes).sort()){let{lastMutation:u,guard:d,...l}=r.nodes[a];s[a]=l}let o=[...r.subgraphs].sort(),i={...r,version:1,nodes:s,subgraphs:o};if(e?.format==null)return i;if(e.format==="json-string")return JSON.stringify(i);if(e.format==="bytes"){if(e.codec==null)throw new Error("snapshot({format: 'bytes'}) requires a `codec` name");let a=this.config.lookupCodec(e.codec);if(a==null)throw new Error(`snapshot: codec "${e.codec}" is not registered on this graph's config. Call config.registerCodec(...) before creating nodes.`);return xt(a,a.encode(i))}throw new Error(`snapshot: unknown format "${String(e.format)}"`)}static decode(e,t){let r=t?.config??he,{codec:s,codecVersion:o,payload:i}=kt(e,r);return s.decode(i,o)}restore(e,t){if(an(e),e.name!==this.name)throw new Error(`Graph "${this.name}": restore snapshot name "${e.name}" does not match this graph`);let r=t?.only==null?null:(Array.isArray(t.only)?t.only:[t.only]).map(o=>Ve(o)),s=t?.includeProducers===!0;for(let o of Object.keys(e.nodes).sort()){if(r!==null&&!r.some(a=>a.test(o)))continue;let i=e.nodes[o];if(i!==void 0){if(!("value"in i)||i.value===void 0){"value"in i&&i.value===void 0&&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){an(e);let r=typeof t=="function"?t:t?.build,s=typeof t=="function"?void 0:t?.factories,o=new n(e.name);if(r)return r(o),o.restore(e),o;for(let f of[...e.subgraphs].sort((c,m)=>{let p=c.split(M).length,_=m.split(M).length;return p!==_?p-_:c<m?-1:c>m?1:0})){let c=f.split(M),m=o;for(let p of c)m._mounts.has(p)||m.mount(p,new n(p)),m=m._mounts.get(p)}let i=s?Object.entries(s).map(([f,c])=>({re:Ve(f),factory:c})):[],a=f=>{for(let c of i)if(c.re.test(f))return c.factory},u=f=>{let c=f.split(M),m=c.pop();if(m==null||m.length===0)throw new Error(`invalid snapshot path "${f}"`);let p=o;for(let _ of c){let y=p._mounts.get(_);if(!y)throw new Error(`unknown mount "${_}" in path "${f}"`);p=y}return[p,m]},d=Object.entries(e.nodes).filter(([f])=>!f.includes(`${M}${Y}${M}`)).sort((f,c)=>f[0]<c[0]?-1:f[0]>c[0]?1:0),l=new Map(d),g=new Map,h=!0;for(;l.size>0&&h;){h=!1;for(let[f,c]of[...l.entries()]){let m=c?.deps??[];if(!m.every(w=>g.has(w)))continue;let[p,_]=u(f),y={...c?.meta??{}},b=a(f),v;if(c?.type==="state")v=se(c.value,{meta:y});else{if(b==null)continue;v=b(_,{path:f,type:c.type,value:c.value,meta:y,deps:m,resolvedDeps:m.map(w=>g.get(w))})}p.add(v,{name:_}),g.set(f,v),l.delete(f),h=!0}}if(l.size>0){let f=[...l.keys()].sort().join(", ");throw new Error(`Graph.fromSnapshot could not reconstruct nodes without build callback: ${f}. Pass matching factories via fromSnapshot(data, { factories: { pattern: factoryFn } }).`)}return o.restore(e),o}toJSON(){return this.snapshot()}attachSnapshotStorage(e,t={}){let r=e.map(d=>({tier:d,debounceMs:Math.max(0,d.debounceMs??0),compactEvery:Math.max(1,d.compactEvery??10),timer:void 0,seq:0,lastSnapshot:void 0,lastFingerprint:"",disposed:!1,savePending:void 0}));t.autoRestore===!0&&this._cascadeRestore(e,t.onError);let s=(d,l)=>{if(d.disposed)return;let g=Hn(l.nodes);if(d.lastSnapshot!=null&&g!==""&&g===d.lastFingerprint)return;let h=d.seq+1,f=Ce(),p=d.lastSnapshot==null||h%d.compactEvery===0?{name:this.name,mode:"full",snapshot:l,seq:h,timestamp_ns:f,format_version:ye}:{name:this.name,mode:"diff",diff:Qn(d.lastSnapshot,l),seq:h,timestamp_ns:f,format_version:ye};if(d.tier.filter&&!d.tier.filter(p))return;let _;try{_=d.tier.save(p)}catch(y){t.onError?.(y,d.tier);return}if(_&&typeof _.then=="function"){let v=(d.savePending??Promise.resolve()).then(()=>_,()=>_).then(()=>{d.disposed||(d.seq=h,d.lastSnapshot=l,d.lastFingerprint=g)},w=>{t.onError?.(w,d.tier)});d.savePending=v.finally(()=>{d.savePending===v&&(d.savePending=void 0)})}else d.seq=h,d.lastSnapshot=l,d.lastFingerprint=g},o=(d,l)=>{try{s(d,l)}catch(g){t.onError?.(g,d.tier)}},i=(d,l)=>{if(!l.some(c=>{let m=this.config.messageTier(c[0]);return m>=3&&m<5}))return;if(t.filter){let c=this.tryResolve(d);if(c==null)return;let m=dt(c,at("standard"));if(!t.filter(d,m))return}let h,f=()=>(h==null&&(h=this.snapshot()),h);for(let c of r)c.disposed||(c.debounceMs===0?o(c,f()):(c.timer==null&&(c.timer=new Ie),c.timer.start(c.debounceMs,()=>{c.disposed||o(c,this.snapshot())})))},a;if(t.paths!=null){let l=(typeof t.paths=="string"?this._pathsMatching(t.paths):t.paths).map(g=>{let h=this.tryResolve(g);return h==null?()=>{}:h.subscribe(f=>i(g,f))});a=()=>{for(let g of l)g()}}else a=this.observe().subscribe((d,l)=>i(d,l));let u=()=>{a();for(let d of r)d.disposed=!0,d.timer?.cancel();this._storageDisposers.delete(u)};return this._storageDisposers.add(u),{dispose:u}}async _cascadeRestore(e,t){for(let r of e){let s;try{s=await r.load?.()}catch(i){t?.(i,r);continue}if(s==null||typeof s!="object"||Array.isArray(s))continue;let o=s;try{if(o.mode==="full"&&o.snapshot!=null)return this.restore(o.snapshot),!0;if(o.version===ye&&o.nodes!=null)return this.restore(o),!0}catch(i){t?.(i,r)}}return!1}static async fromStorage(e,t,r){for(let s of t){let o;try{o=await s.load?.()}catch(u){r?.onError?.(u,s);continue}if(o==null||typeof o!="object"||Array.isArray(o))continue;let i=o,a=i.mode==="full"&&i.snapshot!=null?i.snapshot:i.version===ye&&i.nodes!=null?i:void 0;if(a!=null)try{return n.fromSnapshot(a,r)}catch(u){r?.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,r){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:X(),...r?.actor!=null?{actor:r.actor}:{}};this._traceRing.push(s)}return}return e!=null?this.config.inspectorEnabled?this._annotations.get(e):void 0:this.config.inspectorEnabled?this._traceRing.toArray():[]}annotation(e){return this._annotations.get(e)}clearTrace(){this._annotations.clear(),this._traceRing.clear()}pruneTrace(e){let t=this._traceRing.toArray().filter(s=>!e(s)),r=this._traceRing.size-t.length;this._traceRing.clear();for(let s of t)this._traceRing.push(s);return r}static diff(e,t){let r=new Set(Object.keys(e.nodes)),s=new Set(Object.keys(t.nodes)),o=[...s].filter(y=>!r.has(y)).sort(),i=[...r].filter(y=>!s.has(y)).sort(),a=[],u=[];for(let y of r){if(!s.has(y))continue;let b=e.nodes[y],v=t.nodes[y],w=b.v,O=v.v;w!=null&&O!=null&&w.id===O.id&&w.version!==O.version&&u.push({path:y,id:w.id,from:w.version,to:O.version});let x=w!=null&&O!=null&&w.id===O.id&&w.version===O.version;for(let k of["type","status","sentinel"]){let E=b[k],R=v[k];E!==R&&a.push({path:y,field:k,from:E,to:R})}if(!x)for(let k of["value","meta"]){let E=b[k],R=v[k];zn(E,R)||a.push({path:y,field:k,from:E,to:R})}}let d=y=>`${y.from} ${y.to}`,l=new Set(e.edges.map(d)),g=new Set(t.edges.map(d)),h=t.edges.filter(y=>!l.has(d(y))),f=e.edges.filter(y=>!g.has(d(y))),c=new Set(e.subgraphs),m=new Set(t.subgraphs),p=[...m].filter(y=>!c.has(y)).sort(),_=[...c].filter(y=>!m.has(y)).sort();return{nodesAdded:o,nodesRemoved:i,nodesChanged:a,versionChanges:u,edgesAdded:h,edgesRemoved:f,subgraphsAdded:p,subgraphsRemoved:_}}}});function pn(n,e,t){return{[n]:!0,[`${n}_type`]:e,...t??{}}}var hn=G(()=>{"use strict"});var sr={};vn(sr,{feedback:()=>nr,funnel:()=>tr,scorer:()=>rr});module.exports=_n(sr);Se();ne();ge();$e();Ut();fn();hn();Ne();ne();function gn(n,e){let t=n.cache??0;return t>=e?!1:(n.down([[U],[P,t+1]]),!0)}var fs=Dt((n,e)=>{n("observe"),n("signal"),e("write")});lt();function mt(n,e){return pn("reduction",n,e)}function tr(n,e,t,r){if(e.length===0)throw new RangeError("funnel requires at least one source");if(t.length===0)throw new RangeError("funnel requires at least one stage");let s=new ve(n,r),o=e.length===1?e[0]:Vt(...e);s.add(o,{name:"merged"});let i="merged";for(let a=0;a<t.length;a++){let u=t[a],d=new ve(u.name);u.build(d);try{d.resolve("input")}catch{throw new Error(`funnel stage "${u.name}" must define an "input" node`)}try{d.resolve("output")}catch{throw new Error(`funnel stage "${u.name}" must define an "output" node`)}s.mount(u.name,d);let l=s.resolve(i),g=`${u.name}::input`,h=s.resolve(g),f=`__bridge_${i}\u2192${u.name}_input`,c=Ft([l],([m])=>{h.emit(m)},{name:f});s.add(c,{name:f}),s.addDisposer(oe(c)),i=`${u.name}::output`}return s}function nr(n,e,t,r){let s=r?.maxIterations??10,o=`__feedback_${e}`,i=se(0,{meta:mt("feedback_counter",{maxIterations:s,feedbackFrom:e,feedbackTo:t})});n.add(i,{name:o});let a=n.resolve(e),u=n.resolve(t),d=`__feedback_effect_${e}`,l=re([],(g,h)=>{let f=a.subscribe(c=>{for(let m of c){let p=m[0];if(p===P){let _=m[1];if(_==null)return;Re(()=>{gn(i,s)&&u.emit(_)})}else if(p===L||p===S){let _=p===S&&m.length>1?[S,m[1]]:[p];i.down([_])}}});return()=>f()},{name:d,describeKind:"effect",meta:{...mt("feedback_effect",{feedbackFrom:e,feedbackTo:t}),_internal:!0}});return n.add(l,{name:d}),n.addDisposer(oe(l)),n}function rr(n,e,t){if(n.length===0)throw new RangeError("scorer requires at least one source");if(n.length!==e.length)throw new RangeError("scorer requires the same number of sources and weights");let r=[...n,...e],s=n.length,o=t?.scoreFns;return be(r,i=>{let a=i.slice(0,s),u=i.slice(s),d=[],l=0;for(let g=0;g<s;g++){let h=a[g]??0,f=u[g]??0,m=(o?.[g]?o[g](h):h)*f;d.push(m),l+=m}return{value:a,score:l,breakdown:d}},{...t?{equals:t.equals,resubscribable:t.resubscribable,resetOnTeardown:t.resetOnTeardown}:{},describeKind:"derived",meta:mt("scorer",t?.meta)})}0&&(module.exports={feedback,funnel,scorer});
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/reduction/index.ts
18
+ var reduction_exports = {};
19
+ module.exports = __toCommonJS(reduction_exports);
20
+ __reExport(reduction_exports, require("@graphrefly/pure-ts/patterns/reduction"), module.exports);
21
+ //# sourceMappingURL=index.cjs.map
@@ -0,0 +1 @@
1
+ {"version":3,"sources":["../../../src/patterns/reduction/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/reduction\";\n"],"mappings":";;;;;;;;;;;;;;;;;AAAA;AAAA;AAEA,8BAAc,mDAFd;","names":[]}
@@ -1,6 +1 @@
1
- import '../../node-ClS5yC-B.cjs';
2
- import '../../graph-C4SHb3Ly.cjs';
3
- export { F as FeedbackOptions, a as FunnelOptions, b as FunnelStage, S as ScoredItem, c as ScorerOptions, d as StepRef, f as feedback, e as funnel, s as scorer } from '../../index-CZjOhcBy.cjs';
4
- import '../../meta-vE8bxW1E.cjs';
5
- import '../../extra/storage-core.cjs';
6
- import '../../extra/storage-tiers.cjs';
1
+ export * from '@graphrefly/pure-ts/patterns/reduction';
@@ -1,6 +1 @@
1
- import '../../node-ClS5yC-B.js';
2
- import '../../graph-7VguS7a4.js';
3
- export { F as FeedbackOptions, a as FunnelOptions, b as FunnelStage, S as ScoredItem, c as ScorerOptions, d as StepRef, f as feedback, e as funnel, s as scorer } from '../../index-Bf7eqeSF.js';
4
- import '../../meta-BgVAsg9j.js';
5
- import '../../extra/storage-core.js';
6
- import '../../extra/storage-tiers.js';
1
+ export * from '@graphrefly/pure-ts/patterns/reduction';
@@ -1 +1,3 @@
1
- import{a,b,c}from"../../chunk-CUNIRONA.js";import"../../chunk-FDQGFWLF.js";import"../../chunk-L6NSJVJZ.js";import"../../chunk-626TESAC.js";import"../../chunk-ESMPEKEV.js";import"../../chunk-VOPGGIL7.js";import"../../chunk-4VVTGLXJ.js";import"../../chunk-35JTVPOX.js";import"../../chunk-JQFH2DV6.js";import"../../chunk-V5A7M7RJ.js";import"../../chunk-LYCLF26R.js";import"../../chunk-CK2E7BTU.js";import"../../chunk-QYADASLV.js";export{b as feedback,a as funnel,c as scorer};
1
+ // src/patterns/reduction/index.ts
2
+ export * from "@graphrefly/pure-ts/patterns/reduction";
3
+ //# sourceMappingURL=index.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"sources":["../../../src/patterns/reduction/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/reduction\";\n"],"mappings":";AAEA,cAAc;","names":[]}
@@ -1,13 +1,21 @@
1
- "use strict";var st=Object.defineProperty;var Fn=Object.getOwnPropertyDescriptor;var Pn=Object.getOwnPropertyNames;var jn=Object.prototype.hasOwnProperty;var P=(n,e)=>()=>(n&&(e=n(n=0)),e);var Ln=(n,e)=>{for(var t in e)st(n,t,{get:e[t],enumerable:!0})},In=(n,e,t,r)=>{if(e&&typeof e=="object"||typeof e=="function")for(let o of Pn(e))!jn.call(n,o)&&o!==t&&st(n,o,{get:()=>e[o],enumerable:!(r=Fn(e,o))||r.enumerable});return n};var Vn=n=>In(st({},"__esModule",{value:!0}),n);function Dt(n,e){let t=new TextEncoder().encode(n.name);if(t.length===0||t.length>255)throw new Error(`encodeEnvelope: codec name "${n.name}" encodes to ${t.length} bytes (must be 1\u2013255)`);let r=n.version;if(!Number.isInteger(r)||r<0||r>65535)throw new Error(`encodeEnvelope: codec.version ${r} out of u16 range (expected integer 0\u201365535)`);let o=2+t.length+2+e.length;if(o>4294967295)throw new Error(`encodeEnvelope: total envelope size ${o} exceeds 2^32-1 bytes (payload ${e.length} bytes)`);let s=new Uint8Array(o),i=0;return s[i++]=ot,s[i++]=t.length,s.set(t,i),i+=t.length,s[i++]=r>>>8&255,s[i++]=r&255,s.set(e,i),s}function Gt(n,e){if(n.length<Ct)throw new Error(`decodeEnvelope: bytes too short (${n.length} < ${Ct})`);let t=0,r=n[t++];if(r!==ot)throw new Error(`decodeEnvelope: unsupported envelope version ${r} (expected ${ot})`);let o=n[t++];if(o===0)throw new Error("decodeEnvelope: name_len must be >= 1");if(t+o+2>n.length)throw new Error(`decodeEnvelope: envelope truncated (need ${t+o+2} bytes, have ${n.length})`);let s=new TextDecoder().decode(n.subarray(t,t+o));t+=o;let i=(n[t]<<8|n[t+1])>>>0;t+=2;let a=n.subarray(t),u=e.lookupCodec(s);if(u==null)throw new Error(`decodeEnvelope: codec "${s}" not registered (envelope codec_v=${i})`);return{codec:u,codecVersion:i,payload:a}}function Mt(n){n.registerCodec(Bn)}var Bn,ot,Ct,it=P(()=>{"use strict";Bn={name:"json",version:1,contentType:"application/json",encode(n){let e=JSON.stringify(n);return new TextEncoder().encode(e)},decode(n,e){let t=new TextDecoder().decode(n);return JSON.parse(t)}},ot=1,Ct=4});function Ie(n){if(n==null)return be;let{type:e,id:t,...r}=n;return{type:e??"system",id:t??"",...r}}var be,at=P(()=>{"use strict";be={type:"system",id:""}});function Ve(){return ve>0||Ce}function $t(){return ve>0}function _e(n){ve>0?De.push(n):n()}function Be(n){ve+=1;let e=!1;try{n()}catch(t){throw e=!0,t}finally{if(ve-=1,ve===0)if(e){if(!Ce){let t=De.splice(0);for(let r of t)try{r()}catch{}le.length=0,fe.length=0,we.length=0}}else Hn()}}function Hn(){let n=!Ce;n&&(Ce=!0);let e=[],t=0;try{for(;le.length>0||fe.length>0||we.length>0||n&&De.length>0;){if(n&&De.length>0){let s=De.splice(0);for(let i of s)try{i()}catch(a){e.push(a)}continue}if(t+=1,t>1e3)throw le.length=0,fe.length=0,we.length=0,new Error("batch drain exceeded 1000 iterations \u2014 likely a reactive cycle");let o=(le.length>0?le:fe.length>0?fe:we).splice(0);for(let s of o)try{s()}catch(i){e.push(i)}}}finally{n&&(Ce=!1)}if(e.length===1)throw e[0];if(e.length>1)throw new AggregateError(e,"batch drain: multiple callbacks threw")}function He(n,e,t){if(e.length===0)return;if(e.length===1){let c=t(e[0][0]);if(c<3||!Ve()){n(e);return}(c>=5?we:c===4?fe:le).push(()=>n(e));return}let r=e.length,o=r,s=r,i=r,a=0;for(;a<r&&t(e[a][0])<3;)a++;for(o=a;a<r&&t(e[a][0])===3;)a++;for(s=a;a<r&&t(e[a][0])===4;)a++;i=a;let u=Ve();if(o>0){let c=e.slice(0,o);n(c)}if(s>o){let c=e.slice(o,s);u?le.push(()=>n(c)):n(c)}if(i>s){let c=e.slice(s,i);u?fe.push(()=>n(c)):n(c)}if(r>i){let c=e.slice(i,r);u?we.push(()=>n(c)):n(c)}}var ve,Ce,le,fe,we,De,ze=P(()=>{"use strict";ve=0,Ce=!1,le=[],fe=[],we=[],De=[]});function ie(){return Math.trunc(performance.now()*1e6)}function Se(){return Date.now()*1e6}var Ge=P(()=>{"use strict"});var Me,F,X,Z,re,se,ce,B,H,G,ke,ct,zn,ut,Wn,Un,dt,Ft,Pt,jt,lt,pe=P(()=>{"use strict";Me=Symbol.for("graphrefly/START"),F=Symbol.for("graphrefly/DATA"),X=Symbol.for("graphrefly/DIRTY"),Z=Symbol.for("graphrefly/RESOLVED"),re=Symbol.for("graphrefly/INVALIDATE"),se=Symbol.for("graphrefly/PAUSE"),ce=Symbol.for("graphrefly/RESUME"),B=Symbol.for("graphrefly/TEARDOWN"),H=Symbol.for("graphrefly/COMPLETE"),G=Symbol.for("graphrefly/ERROR"),ke=Object.freeze([X]),ct=Object.freeze([Z]),zn=Object.freeze([re]),ut=Object.freeze([Me]),Wn=Object.freeze([H]),Un=Object.freeze([B]),dt=Object.freeze([ke]),Ft=Object.freeze([ct]),Pt=Object.freeze([zn]),jt=Object.freeze([Wn]),lt=Object.freeze([Un])});function Lt(n){n.registerMessageType(Me,{tier:0,wireCrossing:!1}),n.registerMessageType(X,{tier:1,wireCrossing:!1}),n.registerMessageType(re,{tier:1,wireCrossing:!1,metaPassthrough:!1}),n.registerMessageType(se,{tier:2,wireCrossing:!1}),n.registerMessageType(ce,{tier:2,wireCrossing:!1}),n.registerMessageType(F,{tier:3,wireCrossing:!0}),n.registerMessageType(Z,{tier:3,wireCrossing:!0}),n.registerMessageType(H,{tier:4,wireCrossing:!0,metaPassthrough:!1}),n.registerMessageType(G,{tier:4,wireCrossing:!0,metaPassthrough:!1}),n.registerMessageType(B,{tier:5,wireCrossing:!0,metaPassthrough:!1})}var We,It=P(()=>{"use strict";pe();We=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 r=this._messageTypes.get(t);return r!=null?r.tier:1}}get onMessage(){return this._frozen=!0,this._onMessage}get onSubscribe(){return this._frozen=!0,this._onSubscribe}set onMessage(e){this._assertUnfrozen(),this._onMessage=e}set onSubscribe(e){this._assertUnfrozen(),this._onSubscribe=e}get defaultVersioning(){return this._defaultVersioning}set defaultVersioning(e){this._assertUnfrozen(),this._defaultVersioning=e}get defaultHashFn(){return this._defaultHashFn}set defaultHashFn(e){this._assertUnfrozen(),this._defaultHashFn=e}get inspectorEnabled(){return this._inspectorEnabled}set inspectorEnabled(e){this._inspectorEnabled=e}get globalInspector(){return this._globalInspector}set globalInspector(e){this._globalInspector=e}get rigorRecorder(){return this._rigorRecorder}set rigorRecorder(e){this._rigorRecorder=e}registerMessageType(e,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(n){return Array.isArray(n)?[...n]:[n]}function qn(n,e){return n.has(e)||n.has("*")}function Bt(n){let e=[];return n((o,s)=>{e.push({kind:"allow",actions:new Set(Vt(o)),where:s?.where??(()=>!0)})},(o,s)=>{e.push({kind:"deny",actions:new Set(Vt(o)),where:s?.where??(()=>!0)})}),(o,s)=>{let i=!1,a=!1;for(let u of e)qn(u.actions,s)&&u.where(o)&&(u.kind==="deny"?i=!0:a=!0);return i?!1:a}}function ft(n){let e=Kn.filter(t=>n({type:t,id:""},"write"));return e.length===0?"restricted":e.includes("human")&&e.includes("llm")&&e.every(t=>t==="human"||t==="llm"||t==="system")?"both":e.length===1?e[0]:e.join("+")}var Q,Kn,$e=P(()=>{"use strict";Q=class extends Error{actor;action;nodeName;constructor(e,t){super(t??`GuardDenied: action "${String(e.action)}" denied for actor type "${String(e.actor.type)}"`),this.name="GuardDenied",this.actor=e.actor,this.action=e.action,this.nodeName=e.nodeName}get node(){return this.nodeName}};Kn=["human","llm","wallet","system"]});function pt(n){if(n===void 0)return null;if(typeof n=="number"){if(!Number.isFinite(n))throw new TypeError(`Cannot hash non-finite number: ${n}`);if(Number.isInteger(n)&&!Number.isSafeInteger(n))throw new TypeError(`Cannot hash integer outside safe range (|n| > 2^53-1): ${n}. Cross-language cid parity is not guaranteed for unsafe integers.`);return n}if(typeof n=="string"||typeof n=="boolean"||n===null)return n;if(Array.isArray(n))return n.map(pt);if(typeof n=="object"&&n!==null){let e={};for(let t of Object.keys(n).sort())e[t]=pt(n[t]);return e}return null}function Xn(n){let e=Yn.encode(n),t=e.length,r=t*8,o=t+9+63&-64,s=new Uint8Array(o);s.set(e),s[t]=128;let i=new DataView(s.buffer);i.setUint32(o-4,r>>>0,!1),i.setUint32(o-8,Math.floor(r/4294967296)>>>0,!1);let a=1779033703,u=3144134277,c=1013904242,d=2773480762,g=1359893119,f=2600822924,p=528734635,l=1541459225,b=new Uint32Array(64),m=(v,h)=>v>>>h|v<<32-h;for(let v=0;v<o;v+=64){for(let k=0;k<16;k++)b[k]=i.getUint32(v+k*4,!1);for(let k=16;k<64;k++){let j=b[k-15],R=b[k-2],A=m(j,7)^m(j,18)^j>>>3,te=m(R,17)^m(R,19)^R>>>10;b[k]=b[k-16]+A+b[k-7]+te>>>0}let h=a,y=u,w=c,S=d,N=g,x=f,E=p,T=l;for(let k=0;k<64;k++){let j=m(N,6)^m(N,11)^m(N,25),R=N&x^~N&E,A=T+j+R+Jn[k]+b[k]>>>0,te=m(h,2)^m(h,13)^m(h,22),ye=h&y^h&w^y&w,z=te+ye>>>0;T=E,E=x,x=N,N=S+A>>>0,S=w,w=y,y=h,h=A+z>>>0}a=a+h>>>0,u=u+y>>>0,c=c+w>>>0,d=d+S>>>0,g=g+N>>>0,f=f+x>>>0,p=p+E>>>0,l=l+T>>>0}let _=v=>v.toString(16).padStart(8,"0");return _(a)+_(u)+_(c)+_(d)+_(g)+_(f)+_(p)+_(l)}function ht(n){let e=pt(n??null),t=JSON.stringify(e);return Xn(t).slice(0,16)}function Zn(){let n=globalThis.crypto;if(n?.randomUUID)return n.randomUUID();let e=()=>Math.floor(Math.random()*4294967296).toString(16).padStart(8,"0"),t=e()+e()+e()+e();return`${t.slice(0,8)}-${t.slice(8,12)}-4${t.slice(13,16)}-${(parseInt(t.slice(16,17),16)&3|8).toString(16)}${t.slice(17,20)}-${t.slice(20,32)}`}function gt(n,e,t){let r=t?.id??Zn();if(n===0)return{id:r,version:0};let s=(t?.hash??ht)(e);return{id:r,version:0,cid:s,prev:null}}function Ht(n,e,t){n.version+=1,"cid"in n&&(n.prev=n.cid,n.cid=t(e))}var Jn,Yn,zt=P(()=>{"use strict";Jn=new Uint32Array([1116352408,1899447441,3049323471,3921009573,961987163,1508970993,2453635748,2870763221,3624381080,310598401,607225278,1426881987,1925078388,2162078206,2614888103,3248222580,3835390401,4022224774,264347078,604807628,770255983,1249150122,1555081692,1996064986,2554220882,2821834349,2952996808,3210313671,3336571891,3584528711,113926993,338241895,666307205,773529912,1294757372,1396182291,1695183700,1986661051,2177026350,2456956037,2730485921,2820302411,3259730800,3345764771,3516065817,3600352804,4094571909,275423344,430227734,506948616,659060556,883997877,958139571,1322822218,1537002063,1747873779,1955562222,2024104815,2227730452,2361852424,2428436474,2756734187,3204031479,3329325298]),Yn=new TextEncoder});function qt(n){return{node:n,unsub:null,prevData:void 0,dirty:!1,involvedThisWave:!1,dataBatch:[],terminal:void 0}}function mt(n){n.prevData=void 0,n.dirty=!1,n.involvedThisWave=!1,n.dataBatch.length=0,n.terminal=void 0}function Ue(n){return n.length===0?n:typeof n[0]=="symbol"?[n]:n}function he(n,e,t){let r=Kt(n)?n:[],o=typeof n=="function"?n:typeof e=="function"?e:void 0,s={};return Kt(n)?s=(yt(e)?e:t)??{}:yt(n)?s=n:s=(yt(e)?e:t)??{},new L(r,o,s)}var Wt,Ut,Qn,er,Ne,L,Kt,yt,Oe=P(()=>{"use strict";it();at();ze();Ge();It();$e();pe();zt();Wt=()=>{},Ut=100;Qn=(n,e,t,r)=>{t.direction==="down-in"&&n._onDepMessage(t.depIndex,e)},er=(n,e,t,r)=>{let o=n;if(o._status==="completed"||o._status==="errored")return;let s=o._cached,i=s===void 0?[ut]:[ut,[F,s]];o._status==="dirty"&&i.push(ke),He(e,i,o._config.tierOf)},Ne=new We({onMessage:Qn,onSubscribe:er});Lt(Ne);Mt(Ne);L=class n{_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,r){this._config=r.config??Ne,this._config.onMessage,this._optsName=r.name,this._describeKind=r.describeKind,this._equals=r.equals??Object.is,this._resubscribable=r.resubscribable??!1,this._resetOnTeardown=r.resetOnTeardown??!1,this._autoComplete=r.completeWhenDepsComplete??!0,this._autoError=r.errorWhenDepsError??!0,this._pausable=r.pausable??!0,this._guard=r.guard,this._fn=t,this._partial=r.partial??!1,this._cached=r.initial!==void 0?r.initial:void 0,this._status=e.length===0&&t==null&&this._cached!==void 0?"settled":"sentinel",this._hashFn=r.versioningHash??this._config.defaultHashFn??ht;let o=r.versioning??this._config.defaultVersioning;this._versioningLevel=o,this._versioning=o!=null?gt(o,this._cached===void 0?void 0:this._cached,{id:r.versioningId,hash:this._hashFn}):void 0,this._deps=e.map(qt);let s={};for(let[a,u]of Object.entries(r.meta??{})){let c={initial:u,name:`${r.name??"node"}:meta:${a}`,describeKind:"state",config:this._config};r.guard!=null&&(c.guard=r.guard),s[a]=new n([],void 0,c)}Object.freeze(s),this.meta=s,this._hasMeta=Object.keys(s).length>0;let i=this;this._actions={emit(a){i._emit([[F,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 r=this._versioningLevel;if(r!=null&&e<=r)return;let o=t?.hash??this._hashFn;o!==this._hashFn&&(this._hashFn=o);let s=this._cached===void 0?void 0:this._cached,i=this._versioning,a=i?.id??t?.id,u=i?.version??0,c=gt(e,s,{id:a,hash:o});c.version=u,this._versioning=c,this._versioningLevel=e}_setInspectorHook(e){return e==null?()=>{}:(this._inspectorHooks==null&&(this._inspectorHooks=new Set),this._inspectorHooks.add(e),()=>{this._inspectorHooks?.delete(e),this._inspectorHooks?.size===0&&(this._inspectorHooks=void 0)})}_pushGuard(e){return this._extraGuards==null&&(this._extraGuards=new Set),this._extraGuards.add(e),()=>{this._extraGuards?.delete(e),this._extraGuards?.size===0&&(this._extraGuards=void 0)}}allowsObserve(e){if(this._guard==null&&this._extraGuards==null)return!0;let t=Ie(e);if(this._guard!=null&&!this._guard(t,"observe"))return!1;if(this._extraGuards!=null){for(let r of this._extraGuards)if(!r(t,"observe"))return!1}return!0}_checkGuard(e){if(e?.internal)return;let t=this._guard!=null||this._extraGuards!=null,r=e?.actor!=null;if(!t&&!r)return;let o=Ie(e?.actor),s=e?.delivery==="signal"?"signal":"write";if(this._guard!=null&&!this._guard(o,s))throw new Q({actor:o,action:s,nodeName:this.name});if(this._extraGuards!=null){for(let i of this._extraGuards)if(!i(o,s))throw new Q({actor:o,action:s,nodeName:this.name})}this._lastMutation={actor:o,timestamp_ns:Se()}}down(e,t){let r=Ue(e);r.length!==0&&(this._checkGuard(t),this._emit(r))}emit(e,t){this._checkGuard(t),this._emit([[F,e]])}up(e,t){if(this._deps.length===0)return;let r=Ue(e);if(r.length===0)return;this._checkGuard(t);let o=t??{internal:!0};this._validateUpTiers(r);for(let s of this._deps)s.node.up?.(r,o)}_emitUp(e){if(this._deps.length!==0&&e.length!==0){this._validateUpTiers(e);for(let t of this._deps)t.node.up?.(e,{internal:!0})}}_validateUpTiers(e){let t=this._config.tierOf;for(let r of e){let o=t(r[0]);if(o===3||o===4)throw new Error(`Node "${this.name}": tier-${o} messages cannot flow up \u2014 DATA/RESOLVED/COMPLETE/ERROR are downstream-only. Use \`down(...)\` for value delivery; \`up(...)\` is for control signals (DIRTY, INVALIDATE, PAUSE, RESUME, TEARDOWN).`)}}subscribe(e,t){if(t!=null&&this._guard!=null){let u=Ie(t);if(!this._guard(u,"observe"))throw new Q({actor:u,action:"observe",nodeName:this.name})}let o=this._isTerminal&&this._resubscribable;if(o){this._cached=void 0,this._status="sentinel",this._store={},this._hasCalledFnOnce=!1,this._waveHasNewData=!1,this._hasNewTerminal=!1,this._paused=!1,this._pendingWave=!1,this._pendingRerun=!1,this._isExecutingFn=!1,this._rerunDepth=0,this._dirtyDepCount=0,this._pauseLocks=null,this._pauseBuffer=null;for(let u of this._deps)mt(u);if(this._partial===!1){for(let u of this._deps)if(u.prevData!==void 0||u.dataBatch.length!==0||u.terminal!==void 0||u.dirty)throw new Error(`resubscribable-reset invariant: DepRecord not fully reset for node ${this._optsName??"(anonymous)"}`)}}this._sinkCount+=1;let s;try{s=this._config.onSubscribe(this,e,{sinkCount:this._sinkCount,afterTerminalReset:o},this._actions)}catch(u){throw this._sinkCount-=1,u}this._sinks==null?this._sinks=e:typeof this._sinks=="function"?this._sinks=new Set([this._sinks,e]):this._sinks.add(e);let i=this._isTerminal;if(this._sinkCount===1&&!i)try{this._activate()}catch(u){if(this._sinkCount-=1,this._removeSink(e),this._sinkCount===0&&(this._status="sentinel"),typeof s=="function")try{s()}catch{}throw u}this._status==="sentinel"&&this._cached===void 0&&(this._status="pending");let a=!1;return()=>{a||(a=!0,this._sinkCount-=1,this._removeSink(e),typeof s=="function"&&s(),this._sinks==null&&this._deactivate())}}_removeSink(e){if(this._sinks===e)this._sinks=null;else if(this._sinks!=null&&typeof this._sinks!="function")if(this._sinks.delete(e),this._sinks.size===1){let[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 r=0;r<e;r++){let o=r,s=this._deps[r];s.unsub=Wt,s.unsub=s.node.subscribe(i=>{if(s.unsub===null)return;let a=this._config.tierOf,u=!1;for(let c of i)a(c[0])>=3&&(u=!0),this._config.onMessage(this,c,{direction:"down-in",depIndex:o},this._actions);u&&this._maybeRunFnOnSettlement()}),t++}}catch(r){this._deps[t].unsub=null;for(let o=0;o<t;o++){let s=this._deps[o];if(s.unsub!=null){let i=s.unsub;s.unsub=null;try{i()}catch{}mt(s)}}throw this._dirtyDepCount=0,r}}_addDep(e){for(let o=0;o<this._deps.length;o++)if(this._deps[o].node===e)return o;let t=this._deps.length,r=qt(e);if(this._deps.push(r),this._sinks==null)return t;r.dirty=!0,this._dirtyDepCount++,this._status!=="dirty"&&this._emit(dt),r.unsub=Wt;try{r.unsub=e.subscribe(o=>{if(r.unsub===null)return;let s=this._config.tierOf,i=!1;for(let a of o)s(a[0])>=3&&(i=!0),this._config.onMessage(this,a,{direction:"down-in",depIndex:t},this._actions);i&&this._maybeRunFnOnSettlement()})}catch(o){throw r.unsub=null,this._deps.pop(),this._dirtyDepCount--,o}return t}_deactivate(e=!1){let t=this._cleanup;if(this._cleanup=void 0,typeof t=="function")try{t()}catch(r){this._emit([[G,this._wrapFnError("cleanup threw",r)]])}else if(t!=null&&typeof t=="object"){let r=t.deactivate;if(typeof r=="function")try{r()}catch(o){this._emit([[G,this._wrapFnError("cleanup.deactivate threw",o)]])}}for(let r of this._deps){if(r.unsub!=null){let o=r.unsub;r.unsub=null;try{o()}catch{}}mt(r)}this._waveHasNewData=!1,this._hasNewTerminal=!1,this._hasCalledFnOnce=!1,this._paused=!1,this._pendingWave=!1,this._pendingRerun=!1,this._rerunDepth=0,this._store={},this._dirtyDepCount=0,this._pauseLocks=null,this._pauseBuffer=null,this._fn!=null&&(this._cached=void 0),e||(this._fn!=null||this._deps.length>0)&&(!this._isTerminal||this._resubscribable)&&(this._status="sentinel")}_onDepMessage(e,t){let r=this._deps[e],o=t[0];if(this._inspectorHooks!=null){let s={kind:"dep_message",depIndex:e,message:t};for(let i of this._inspectorHooks)i(s)}if(o!==Me){if(o===X){this._depDirtied(r);return}if(o===re){if(this._depInvalidated(r),this._cached===void 0)return;this._emit(Pt);return}if(o===se||o===ce){this._emit([t]);return}if(o===B){this._emit(lt);return}if(o===F)this._depSettledAsData(r,t[1]);else if(o===Z)this._depSettledAsResolved(r);else if(o===H)this._depSettledAsTerminal(r,!0);else if(o===G)this._depSettledAsTerminal(r,t[1]);else{this._emit([t]);return}if(!this._fn){(o===F||o===Z)&&this._emit([t]),(o===H||o===G)&&this._maybeAutoTerminalAfterWave();return}}}_depDirtied(e){e.dirty||(e.dirty=!0,e.involvedThisWave=!0,this._dirtyDepCount++,this._status!=="dirty"&&this._emit(dt))}_depSettledAsData(e,t){e.dirty&&(e.dirty=!1,this._dirtyDepCount--),e.involvedThisWave=!0,e.dataBatch.push(t),this._waveHasNewData=!0}_depSettledAsResolved(e){e.dirty&&(e.dirty=!1,this._dirtyDepCount--)}_depSettledAsTerminal(e,t){e.dirty&&(e.dirty=!1,this._dirtyDepCount--),e.terminal=t,e.involvedThisWave=!0,this._hasNewTerminal=!0}_depInvalidated(e){e.prevData=void 0,e.terminal=void 0,e.dataBatch.length=0,e.dirty?e.involvedThisWave=!1:(e.dirty=!0,e.involvedThisWave=!0,this._dirtyDepCount++)}_maybeRunFnOnSettlement(){if(!(this._isTerminal&&!this._resubscribable)&&!(this._dirtyDepCount>0)){if(!this._partial&&!this._hasCalledFnOnce)for(let e=0;e<this._deps.length;e++){let t=this._deps[e];if(t.dataBatch.length===0&&t.prevData===void 0&&t.terminal===void 0){this._maybeAutoTerminalAfterWave();return}}if(this._paused){this._pendingWave=!0;return}if(!this._waveHasNewData&&!this._hasNewTerminal&&this._hasCalledFnOnce){this._clearWaveFlags(),this._emit(Ft),this._maybeAutoTerminalAfterWave();return}this._fn&&this._execFn(),this._maybeAutoTerminalAfterWave()}}_maybeAutoTerminalAfterWave(){if(this._deps.length===0||this._isTerminal)return;let e=this._deps.find(t=>t.terminal!==void 0&&t.terminal!==!0);if(e!=null){this._autoError&&this._emit([[G,e.terminal]]);return}this._autoComplete&&this._deps.every(t=>t.terminal!==void 0)&&this._emit(jt)}_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),r=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 o=this._deps.map(i=>i.terminal),s={prevData:r,terminalDeps:o,store:this._store};if(this._hasCalledFnOnce=!0,this._clearWaveFlags(),this._inspectorHooks!=null){let i={kind:"run",batchData:t,prevData:r};for(let a of this._inspectorHooks)a(i)}this._isExecutingFn=!0;try{let i=this._fn(t,this._actions,s);if(typeof i=="function")this._cleanup=i;else if(i!=null&&typeof i=="object"){let a=i;(typeof a.beforeRun=="function"||typeof a.deactivate=="function"||typeof a.invalidate=="function")&&(this._cleanup=i)}}catch(i){this._emit([[G,this._wrapFnError("fn threw",i)]])}finally{this._isExecutingFn=!1,this._pendingRerun?(this._pendingRerun=!1,this._rerunDepth+=1,this._rerunDepth>Ut?(this._rerunDepth=0,this._emit([[G,new Error(`Node "${this.name}": _pendingRerun depth exceeded ${Ut} \u2014 likely a reactive cycle`)]])):this._maybeRunFnOnSettlement()):this._rerunDepth=0,this._clearWaveFlags()}}_clearWaveFlags(){this._waveHasNewData=!1,this._hasNewTerminal=!1;for(let e of this._deps)e.involvedThisWave=!1,e.dataBatch.length=0}_wrapFnError(e,t){let r=t instanceof Error?t.message:String(t);return new Error(`Node "${this.name}": ${e}: ${r}`,{cause:t})}_frameBatch(e){let t=this._config.tierOf;if(e.length===1)return t(e[0][0])===3&&this._status!=="dirty"?[ke,e[0]]:e;let r=!0,o=!1,s=!1,i=-1;for(let u of e){let c=t(u[0]);c<i&&(r=!1),c===3&&(o=!0),u[0]===X&&(s=!0),i=c}let a=e;if(!r){let u=e.map((c,d)=>({m:c,i:d,tier:t(c[0])}));u.sort((c,d)=>c.tier-d.tier||c.i-d.i),a=u.map(c=>c.m)}if(o&&!s&&this._status!=="dirty"){let u=0;for(;u<a.length&&t(a[u][0])===0;)u++;return u===0?[ke,...a]:[...a.slice(0,u),ke,...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]===G&&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]===B||u[0]===re);if(a.length===0)return;t=a}t=this._frameBatch(t);let o=null;for(let a=0;a<t.length;a++){let u=t[a],c=u[0];if(c!==se&&c!==ce){o?.push(u);continue}if(u.length<2)throw new Error(`Node "${this.name}": [[${c===se?"PAUSE":"RESUME"}]] must carry a lockId payload \u2014 bare PAUSE/RESUME is a protocol violation (C0 rule). Use \`[[PAUSE, lockId]]\` / \`[[RESUME, lockId]]\`.`);let d=!0;if(this._pausable!==!1){let g=u[1];if(c===se)this._pauseLocks==null&&(this._pauseLocks=new Set),this._pauseLocks.add(g),this._paused=!0,this._pausable==="resumeAll"&&this._pauseBuffer==null&&(this._pauseBuffer=[]);else if(this._pauseLocks==null||!this._pauseLocks.has(g))d=!1;else if(this._pauseLocks.delete(g),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())}}d?o?.push(u):o==null&&(o=t.slice(0,a))}if(o!=null){if(o.length===0)return;t=o}if(this._hasMeta&&t.some(a=>a[0]===B))for(let a of Object.keys(this.meta))try{this.meta[a]._emit(lt)}catch{}let{finalMessages:s,equalsError:i}=this._updateState(t);if(s.length>0&&this._config.inspectorEnabled){let a=this._config.globalInspector;if(a!=null)try{a({kind:"emit",node:this,messages:s})}catch{}}if(s.length>0)if(this._paused&&this._pausable==="resumeAll"&&this._pauseBuffer!=null){let a=this._config.tierOf,u=[];for(let c of s)a(c[0])===3?this._pauseBuffer.push(c):u.push(c);u.length>0&&this._dispatchOrAccumulate(u)}else this._dispatchOrAccumulate(s);i!=null&&this._emit([[G,i]])}_updateState(e){let t=this._config.tierOf,r,o,s=-1,i=0;for(let d of e)t(d[0])===3&&i++;let a=i<=1,u=-1;if(this._versioning!=null&&i>1){for(let d=e.length-1;d>=0;d--)if(e[d][0]===F){u=d;break}}for(let d=0;d<e.length;d++){let g=e[d],f=g[0];if(f===F){if(g.length>=2){let p=!1;if(a&&this._cached!==void 0)try{p=this._equals(this._cached,g[1])}catch(l){o=this._wrapFnError("equals threw",l),s=d;break}if(p){r==null&&(r=e.slice(0,d)),r.push(ct),this._status="resolved";continue}this._cached=g[1],this._versioning!=null&&(u<0||d===u)&&Ht(this._versioning,g[1],this._hashFn)}this._status="settled",r?.push(g)}else if(r?.push(g),f===X)this._status="dirty";else if(f===Z)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===re){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===B&&(this._resetOnTeardown&&(this._cached=void 0),this._deactivate(!0),this._status="sentinel")}let c=s>=0?r??e.slice(0,s):r??e;return o!=null?{finalMessages:c,equalsError:o}:{finalMessages:c}}_deliverToSinks=e=>{if(this._sinks==null)return;if(typeof this._sinks=="function"){this._sinks(e);return}let t=[...this._sinks];for(let r of t)r(e)};_dispatchOrAccumulate(e){if($t()){this._batchPendingMessages===null&&(this._batchPendingMessages=[],_e(()=>this._flushBatchPending()));for(let t of e)this._batchPendingMessages.push(t);return}He(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);He(this._deliverToSinks,t,this._config.tierOf)}},Kt=n=>Array.isArray(n),yt=n=>typeof n=="object"&&n!=null&&!Array.isArray(n)});function oe(n,e){return he([],{...e,initial:n})}function xe(n,e){return he((r,o,s)=>n(o,s)??void 0,{describeKind:"producer",...e})}function ge(n,e,t){return he(n,(o,s,i)=>{let a=o.map((u,c)=>u!=null&&u.length>0?u.at(-1):i.prevData[c]);s.emit(e(a,i))},{describeKind:"derived",...t})}function qe(n,e,t){return he(n,(o,s,i)=>{let a=o.map((u,c)=>u!=null&&u.length>0?u.at(-1):i.prevData[c]);return e(a,s,i)??void 0},{describeKind:"effect",...t})}var Ke=P(()=>{"use strict";Oe()});function bt(n,e){if(e!=null&&e.length>0)return new Set(e);switch(n){case"standard":return new Set(["type","status","value","deps","meta","v"]);case"full":return null;case"spec":return new Set(["type","deps","meta","value"]);default:return new Set(["type","deps"])}}function tr(n){return n._describeKind!=null?n._describeKind:n._deps.length>0?"derived":n._fn!=null?"producer":"state"}function nr(n){let e={};for(let[t,r]of Object.entries(n.meta))try{e[t]=r.cache}catch{}return e}function vt(n,e,t){let r=e==null,o=!r&&e!=null?[...e].filter(d=>d.startsWith("meta.")).map(d=>d.slice(5)):null,s=r||e.has("meta")||o!=null&&o.length>0,i="state",a=[];n instanceof L&&(i=tr(n),a=n._deps.map(d=>d.node.name??""));let u={type:i,deps:a};(r||e.has("status"))&&(u.status=n.status);let c=n instanceof L?n._guard:void 0;if(s){let d={...nr(n)};if(c!=null&&d.access===void 0&&(d.access=ft(c)),o!=null&&o.length>0&&!e.has("meta")){let g={};for(let f of o)f in d&&(g[f]=d[f]);u.meta=g}else u.meta=d}if(n.name!=null&&(u.name=n.name),(r||e.has("value"))&&(!t||i==="state")){n.status==="sentinel"&&(u.sentinel=!0);try{u.value=n.cache}catch{}}if((r||e.has("v"))&&n.v!=null){let d={id:n.v.id,version:n.v.version};"cid"in n.v&&(d.cid=n.v.cid,d.prev=n.v.prev),u.v=d}return(r||e.has("guard"))&&c!=null&&(u.guard=ft(c)),(r||e.has("lastMutation"))&&n.lastMutation!=null&&(u.lastMutation=n.lastMutation),u}var Jt=P(()=>{"use strict";$e();Oe()});function wt(n,e){if(Object.is(n,e))return!0;if(n==null||e==null||typeof n!="object"||typeof e!="object")return!1;if(Array.isArray(n)){if(!Array.isArray(e)||n.length!==e.length)return!1;for(let s=0;s<n.length;s++)if(!wt(n[s],e[s]))return!1;return!0}if(Array.isArray(e))return!1;let t=Object.keys(n),r=Object.keys(e);if(t.length!==r.length)return!1;let o=new Set(r);for(let s of t)if(!o.has(s)||!wt(n[s],e[s]))return!1;return!0}function Yt(n,e){return`${n}\0${e}`}function _t(n,e){let t=[],r=new Set(n.subgraphs),o=new Set(e.subgraphs),s=[];for(let m of o)r.has(m)||s.push(m);s.sort();for(let m of s)t.push({type:"subgraph-mounted",path:m});let i=new Set(Object.keys(n.nodes)),a=new Set(Object.keys(e.nodes)),u=[];for(let m of a)i.has(m)||u.push(m);u.sort();for(let m of u)t.push({type:"node-added",path:m,node:{...e.nodes[m]}});let c=[];for(let m of a){if(!i.has(m))continue;let _=n.nodes[m]?.meta,v=e.nodes[m]?.meta;_==null&&v==null||wt(_??{},v??{})||c.push(m)}c.sort();for(let m of c)t.push({type:"node-meta-changed",path:m,prevMeta:n.nodes[m]?.meta??{},nextMeta:e.nodes[m]?.meta??{}});let d=new Map;for(let m of n.edges)d.set(Yt(m.from,m.to),m);let g=new Map;for(let m of e.edges)g.set(Yt(m.from,m.to),m);let f=[];for(let[m,_]of g)d.has(m)||f.push(_);f.sort((m,_)=>m.from<_.from?-1:m.from>_.from?1:m.to<_.to?-1:m.to>_.to?1:0);for(let m of f)t.push({type:"edge-added",from:m.from,to:m.to});let p=[];for(let[m,_]of d)g.has(m)||p.push(_);p.sort((m,_)=>m.from<_.from?-1:m.from>_.from?1:m.to<_.to?-1:m.to>_.to?1:0);for(let m of p)t.push({type:"edge-removed",from:m.from,to:m.to});let l=[];for(let m of i)a.has(m)||l.push(m);l.sort();for(let m of l)t.push({type:"node-removed",path:m});let b=[];for(let m of r)o.has(m)||b.push(m);b.sort();for(let m of b)t.push({type:"subgraph-unmounted",path:m});return{events:t,flushedAt_ns:ie()}}var Xt=P(()=>{"use strict";Ge()});function Te(n){return n.subscribe(()=>{})}var Zt=P(()=>{"use strict"});var St=P(()=>{"use strict";Zt()});var Je,Qt=P(()=>{"use strict";Je=class{_timer;_gen=0;start(e,t){this.cancel(),this._gen+=1;let r=this._gen;this._timer=setTimeout(()=>{this._timer=void 0,r===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,en=P(()=>{"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 tn(n,e,t,r={}){let o=e in n.nodes,s=t in n.nodes;if(!o)return Ye(e,t,"no-such-from");if(!s)return Ye(e,t,"no-such-to");let i=r.maxDepth;if(i!=null&&(!Number.isInteger(i)||i<0))throw new Error("explainPath: maxDepth must be an integer >= 0");if(e===t){if(r.findCycle===!0){let c=rr(n,e,r);if(c!=null)return c}let u=Xe(e,n.nodes[e],0,r);return Ze(e,t,[u])}if(i===0)return Ye(e,t,"no-path");let a=nn(n,e,t,i);return a.found?Ze(e,t,rn(n,a.pathOrder,r)):Ye(e,t,a.truncated?"max-depth-exceeded":"no-path")}function nn(n,e,t,r){let o=new Map,s=[{path:t,depth:0}],i=new Set([t]),a=0,u=!1;for(;a<s.length;){let g=s[a++];if(g.path===e)break;if(r!=null&&g.depth>=r){let b=n.nodes[g.path];b?.deps&&b.deps.length>0&&(u=!0);continue}let f=n.nodes[g.path];if(f==null)continue;let p=f.deps??[],l=new Map;for(let b=0;b<p.length;b++){let m=p[b];if(!m)continue;let _=l.get(m);_==null&&(_=[],l.set(m,_)),_.push(b)}for(let[b,m]of l)i.has(b)||(i.add(b),o.set(b,{from:g.path,depIndices:m}),s.push({path:b,depth:g.depth+1}))}if(!o.has(e))return{found:!1,pathOrder:[],truncated:u};let c=[{path:e}],d=e;for(;d!==t;){let g=o.get(d);if(g==null)return{found:!1,pathOrder:[],truncated:!1};c[c.length-1].depIndices=g.depIndices,c.push({path:g.from}),d=g.from}return{found:!0,pathOrder:c,truncated:!1}}function rr(n,e,t){let r=n.nodes[e];if(r==null)return null;let o=r.deps??[],s=[];for(let a=0;a<o.length;a++)o[a]===e&&s.push(a);if(s.length>0){let a=Xe(e,r,0,t);a.dep_index=s[0];let u=Xe(e,r,1,t);return Ze(e,e,[a,u])}let i=null;for(let a=0;a<o.length;a++){let u=o[a];if(!u||u===e)continue;let c=nn(n,u,e,t.maxDepth);c.found&&(i==null||c.pathOrder.length<i.pathOrder.length)&&(i=c,i={found:!0,pathOrder:[{path:e,depIndices:[a]},...c.pathOrder],truncated:!1})}return i==null?null:Ze(e,e,rn(n,i.pathOrder,t))}function rn(n,e,t){return e.map((r,o)=>{let s=n.nodes[r.path],i=Xe(r.path,s,o,t);return r.depIndices!=null&&r.depIndices.length>0&&(i.dep_index=r.depIndices[0],r.depIndices.length>1&&(i.dep_indices=[...r.depIndices])),i})}function Xe(n,e,t,r){let o={path:n,type:e.type,hop:t};e.status!==void 0&&(o.status=e.status),"value"in e&&(o.value=e.value),e.v!=null&&(o.v=e.v);let s=r.annotations?.get(n)??e.annotation;s!=null&&(o.annotation=s);let i=r.lastMutations?.get(n)??e.lastMutation;return i!=null&&(o.lastMutation=i),o}function Ze(n,e,t){return sn(n,e,!0,"ok",t)}function Ye(n,e,t){return sn(n,e,!1,t,[])}function sn(n,e,t,r,o){let s=sr(n,e,t,r,o);return{from:n,to:e,found:t,reason:r,steps:o,text:s,toJSON(){return{from:n,to:e,found:t,reason:r,steps:o}}}}function sr(n,e,t,r,o){if(!t)switch(r){case"no-such-from":return`explainPath: no node named "${n}"`;case"no-such-to":return`explainPath: no node named "${e}"`;case"max-depth-exceeded":return`explainPath: no path from "${n}" to "${e}" within maxDepth`;default:return`explainPath: no path from "${n}" to "${e}"`}let s=[`Causal path: ${n} \u2192 ${e} (${o.length} step(s))`];for(let i of o){let u=` ${i.hop===0?"\xB7":"\u2193"} ${i.path} (${i.type}${i.status?`/${i.status}`:""})`;if(s.push(u),"value"in i&&s.push(` value: ${or(i.value)}`),i.annotation!=null&&s.push(` annotation: ${i.annotation}`),i.lastMutation!=null){let c=i.lastMutation.actor;s.push(` actor: ${c.type}${c.id?`:${c.id}`:""}`)}}return s.join(`
2
- `)}function or(n){if(n===void 0)return"<sentinel>";if(n===null)return"null";if(typeof n=="string")return JSON.stringify(n);if(typeof n=="number"||typeof n=="boolean"||typeof n=="bigint")return String(n);try{let e=JSON.stringify(n);return e.length>80?`${e.slice(0,77)}...`:e}catch{return String(n)}}var on=P(()=>{"use strict"});function an(n){let e=new WeakSet,t=new WeakSet,r=[n],o=0;for(;r.length>0;){let s=r.pop();o+=ar(s,e,t,r)}return o}function ar(n,e,t,r){if(n==null)return 0;switch(typeof n){case"number":return I.number;case"boolean":return I.boolean;case"string":return I.string+n.length*2;case"bigint":return I.bigint+cr(n);case"symbol":return I.symbol;case"function":return e.has(n)?0:(e.add(n),I.function);case"undefined":return 0}let s=n;if(e.has(s))return 0;e.add(s);let i=s[ir];if(typeof i=="function")try{let c=i.call(s);if(typeof c=="number"&&Number.isFinite(c))return c}catch{}if(s instanceof Date)return I.date;if(s instanceof RegExp)return I.regexp+s.source.length*2;if(s instanceof Error){let c=s.message?s.message.length*2:0,d=s.stack?s.stack.length*2:0;return I.error+c+d}if(typeof URL<"u"&&s instanceof URL)return I.url+s.href.length*2;if(typeof Promise<"u"&&s instanceof Promise)return I.promise;if(s instanceof WeakMap)return I.weakmap;if(s instanceof WeakSet)return I.weakset;if(s instanceof Map){let c=I.map;for(let[d,g]of s)c+=I.mapEntry,r.push(d),r.push(g);return c}if(s instanceof Set){let c=I.set;for(let d of s)c+=I.setEntry,r.push(d);return c}if(Array.isArray(s)){let c=I.array+s.length*8;for(let d of s)r.push(d);return c}if(s instanceof ArrayBuffer)return t.has(s)?0:(t.add(s),s.byteLength);if(ArrayBuffer.isView(s)){let c=s;return t.has(c.buffer)?48:(t.add(c.buffer),c.buffer.byteLength+48)}let a=I.object,u=Object.keys(s);for(let c of u){a+=I.string+c.length*2;try{r.push(s[c])}catch{}}return a}function cr(n){let e=n<0n?-n:n;if(e===0n)return 0;let t=e.toString(2).length;return Math.ceil(t/32)*8}var I,ir,cn=P(()=>{"use strict";I={object:56,array:64,string:40,number:8,boolean:4,null:0,undefined:0,symbol:40,bigint:16,function:120,map:72,set:72,mapEntry:40,setEntry:24,date:24,regexp:48,error:64,url:80,promise:48,weakmap:40,weakset:40},ir=Symbol.for("sizeof")});function un(n,e){let t=e?.topN??10,r=n.describe({detail:"standard"}),o=[],s=n._collectObserveTargets;typeof s=="function"&&s.call(n,"",o);let i=new Map;for(let[f,p]of o)i.set(f,p);let a=[];for(let[f,p]of Object.entries(r.nodes)){let l=i.get(f),b=l instanceof L?l:null,m=b?an(b.cache):0,_=b?b._sinkCount:0,v=p.deps?.length??0,h=p.type==="effect"&&_===0,y=_===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:m,subscriberCount:_,depCount:v,isOrphanEffect:h,orphanKind:y})}let u=a.reduce((f,p)=>f+p.valueSizeBytes,0),c=(f,p)=>[...a].sort(p??((l,b)=>b[f]-l[f])).slice(0,t),d=a.filter(f=>f.orphanKind!=null),g=a.filter(f=>f.isOrphanEffect);return{nodeCount:a.length,edgeCount:r.edges.length,subgraphCount:r.subgraphs.length,nodes:a,totalValueSizeBytes:u,hotspots:{byValueSize:c("valueSizeBytes"),bySubscriberCount:c("subscriberCount"),byDepCount:c("depCount")},orphans:d,orphanEffects:g}}var dn=P(()=>{"use strict";Oe();cn()});function ln(n,e){let t=Math.max(16,n.size*4),r=0;for(;n.size>0;){if(r++>=t){console.error(`[Graph "${e}".destroy] disposer drain exceeded cap (${t}); ${n.size} disposer(s) discarded`),n.clear();return}let o=n.values().next();if(o.done)return;let s=o.value;n.delete(s);try{s()}catch(i){console.error(`[Graph "${e}".destroy] disposer threw:`,i)}}}function yn(n){return n!=null&&typeof n=="object"&&"cache"in n&&typeof n.subscribe=="function"&&typeof n.down=="function"}function ur(n){if(n!=null)return yn(n)?n.cache:n}function me(n){return n!=null&&typeof n=="object"&&"cache"in n&&typeof n.subscribe=="function"&&typeof n.down=="function"}function ue(n){return me(n)?n.cache??"":n}function fn(n){return me(n)?n.cache??0:n}function pn(n){return me(n)?n.cache??!1:n}function dr(n){let e=[];for(let t of Object.keys(n).sort()){let r=n[t].v;r!=null&&e.push(`${t} ${r.id} ${r.version}`)}return e.join(`
3
- `)}function hn(n){if(n.version!==de)throw new Error(`unsupported snapshot version ${String(n.version)} (expected ${de})`);for(let e of["name","nodes","edges","subgraphs"])if(!(e in n))throw new Error(`snapshot missing required key "${e}"`);if(typeof n.name!="string")throw new TypeError("snapshot 'name' must be a string");if(typeof n.nodes!="object"||n.nodes===null||Array.isArray(n.nodes))throw new TypeError("snapshot 'nodes' must be an object");if(!Array.isArray(n.edges))throw new TypeError("snapshot 'edges' must be an array");if(!Array.isArray(n.subgraphs))throw new TypeError("snapshot 'subgraphs' must be an array")}function lr(n,e){let t=new WeakMap,r=(o,s)=>{if(Object.is(o,s))return!0;if(o==null||s==null||typeof o!="object"||typeof s!="object")return!1;let i=t.get(o);if(i==null&&(i=new WeakSet,t.set(o,i)),i.has(s))return!0;i.add(s);let a=o.constructor,u=s.constructor;if(a!==u)return!1;if(o instanceof Date)return o.getTime()===s.getTime();if(o instanceof RegExp)return o.source===s.source&&o.flags===s.flags;if(Array.isArray(o)){let f=s;if(o.length!==f.length)return!1;for(let p=0;p<o.length;p++)if(!r(o[p],f[p]))return!1;return!0}if(o instanceof Map){let f=s;if(o.size!==f.size)return!1;for(let[p,l]of o)if(!f.has(p)||!r(l,f.get(p)))return!1;return!0}if(o instanceof Set){let f=s;if(o.size!==f.size)return!1;for(let p of o){let l=!1;for(let b of f)if(r(p,b)){l=!0;break}if(!l)return!1}return!0}if(ArrayBuffer.isView(o)){let f=o,p=s;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 c=Object.keys(o),d=Object.keys(s);if(c.length!==d.length)return!1;let g=new Set(d);for(let f of c)if(!g.has(f)||!r(o[f],s[f]))return!1;return!0};return r(n,e)}function fr(n){return n.replace(/[.*+?^${}()|[\]\\]/g,"\\$&")}function Qe(n){let e="^";for(let t=0;t<n.length;t+=1){let r=n[t];if(r==="*"){e+=".*";continue}if(r==="?"){e+=".";continue}if(r==="["){let o=n.indexOf("]",t+1);if(o<=t+1){e+="\\[";continue}let s=n.slice(t+1,o);s.startsWith("!")&&(s=`^${s.slice(1)}`),s=s.replace(/\\/g,"\\\\"),e+=`[${s}]`,t=o;continue}e+=fr(r)}return e+="$",new RegExp(e)}function kt(n){if(typeof n=="string")return JSON.stringify(n);if(typeof n=="number"||typeof n=="boolean"||n==null)return String(n);try{return JSON.stringify(n)}catch{return"[unserializable]"}}function gr(n){return n==="none"?hr:n==="ansi"||n==null?pr:{data:n.data??"",dirty:n.dirty??"",resolved:n.resolved??"",invalidate:n.invalidate??"",pause:n.pause??"",resume:n.resume??"",complete:n.complete??"",error:n.error??"",teardown:n.teardown??"",derived:n.derived??"",path:n.path??"",reset:n.reset??""}}function gn(n){if(n==null)return{};let e=n.detail;return e==="full"?{...n,structured:n.structured??!0,timeline:n.timeline??!0,causal:n.causal??!0,derived:n.derived??!0}:e==="minimal"?{...n,structured:n.structured??!0}:n.format==="stage-log"?{...n,structured:n.structured??!0,timeline:n.timeline??!0}:n}function mr(n,e,t){for(let r=0;r<n.length;r++){let o=n.charCodeAt(r);if(o<32||o===127)throw new Error(`Graph "${e}": ${t} "${n}" must not contain control character (U+${o.toString(16).padStart(4,"0").toUpperCase()} at index ${r})`)}}function Nt(n,e,t){if(n==="")throw new Error(`Graph "${e}": ${t} name must be non-empty`);if(n.includes($))throw new Error(`Graph "${e}": ${t} "${n}" must not contain '${$}' (path separator)`);if(n===ee)throw new Error(`Graph "${e}": ${t} name "${ee}" is reserved for meta companion paths`);mr(n,e,t)}function yr(n,e){if(n==="")throw new Error(`Graph "${e}": resolve path must be non-empty`);let t=n.split($);for(let r of t)if(r==="")throw new Error(`Graph "${e}": resolve path has empty segment`);return t}function br(n,e){let t=!1;for(let o of n)if(!e.isMetaPassthrough(o[0])){t=!0;break}return t?n.filter(o=>e.isMetaPassthrough(o[0])):n}function bn(n){for(let e of n._mounts.values())bn(e);for(let e of n._nodes.values())try{e.down([[B]],{internal:!0})}catch{}}function vr(n,e){let t=ae.diff(n,e),r={};for(let o of t.nodesAdded){let s=e.nodes[o];s!=null&&(r[o]=s)}return{...t,nodesAddedFull:r}}function mn(n,e,t,r={}){let o={paths:[],depths:new Map,truncated:!1};if(!e)return r.withDetail?o:[];if(!r.both&&t!=="upstream"&&t!=="downstream")throw new Error('reachable: direction must be "upstream" or "downstream"');let s=r.maxDepth;if(s!=null&&(!Number.isInteger(s)||s<0))throw new Error("reachable: maxDepth must be an integer >= 0");if(s===0)return r.withDetail?o:[];let i=new Map,a=new Map,u=new Map,c=new Map,d=new Set;for(let[h,y]of Object.entries(n.nodes)){if(!h)continue;d.add(h);let w=y.deps??[];i.set(h,w);for(let S of w)S&&(d.add(S),a.has(S)||a.set(S,new Set),a.get(S).add(h))}for(let h of n.edges){if(h==null||typeof h!="object")continue;let y=typeof h.from=="string"?h.from:"",w=typeof h.to=="string"?h.to:"";!y||!w||(d.add(y),d.add(w),c.has(y)||c.set(y,new Set),c.get(y).add(w),u.has(w)||u.set(w,new Set),u.get(w).add(y))}if(!d.has(e))return r.withDetail?o:[];let g=r.both===!0,f=h=>{if(g){let N=i.get(h)??[],x=u.get(h),E=a.get(h),T=c.get(h),k=[...N];return x&&k.push(...x),E&&k.push(...E),T&&k.push(...T),k}if(t==="upstream"){let N=i.get(h)??[],x=u.get(h);return x?[...N,...x]:N}let y=a.get(h),w=c.get(h),S=y?[...y]:[];return w&&S.push(...w),S},p=new Set([e]),l=new Map,b=[{path:e,depth:0}],m=0,_=!1;for(;m<b.length;){let h=b[m++];if(s!=null&&h.depth>=s){f(h.path).length>0&&(_=!0);continue}for(let y of f(h.path))!y||p.has(y)||(p.add(y),l.set(y,h.depth+1),b.push({path:y,depth:h.depth+1}))}let v=[...l.keys()].sort((h,y)=>h<y?-1:h>y?1:0);return r.withDetail?{paths:v,depths:l,truncated:_}:v}function wr(n,e){if(n.length!==e.length)return!1;for(let t=0;t<n.length;t++){let r=n[t],o=e[t];if(r.path!==o.path||r.type!==o.type||r.status!==o.status||r.hop!==o.hop||r.dep_index!==o.dep_index||r.annotation!==o.annotation||r.value!==o.value||r.lastMutation!==o.lastMutation)return!1;let s=r.v,i=o.v;if(s!==i&&(s==null||i==null||s.id!==i.id||s.version!==i.version))return!1}return!0}var $,ee,de,pr,hr,ae,Ot=P(()=>{"use strict";at();ze();Ge();$e();pe();Jt();Oe();Ke();Xt();St();Qt();en();it();on();dn();$="::",ee="__meta__",de=1;pr={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"},hr={data:"",dirty:"",resolved:"",invalidate:"",pause:"",resume:"",complete:"",error:"",teardown:"",derived:"",path:"",reset:""};ae=class n{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($))throw new Error(`Graph name must not contain '${$}' (got "${e}")`);if(e===ee)throw new Error(`Graph name "${ee}" is reserved for meta companion paths`);this.name=e,this.opts=Object.freeze({...t??{}}),this.config=t?.config??Ne,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=[],r=e?this:this._parent;for(;r!=null;)t.push(r),r=r._parent;return t}get topology(){return this._topology==null&&(this._topology=xe(e=>{let t=r=>{e.emit(r)};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 r=e.name,o=t?.name??r;if(o==null||o==="")throw new Error(`Graph "${this.name}": graph.add requires a non-empty name \u2014 pass via opts.name or set it on the node (e.g. state(0, { name: "x" }))`);let s=o,i=t?.annotation;if(Nt(s,this.name,"add"),this._mounts.has(s))throw new Error(`Graph "${this.name}": name "${s}" is already a mount point`);if(this._nodes.has(s))throw new Error(`Graph "${this.name}": node "${s}" already exists`);let a=this._nodeToName.get(e);if(a!==void 0)throw new Error(`Graph "${this.name}": node instance already registered as "${a}"`);return this._nodes.set(s,e),this._nodeToName.set(e,s),this._emitTopology({kind:"added",name:s,nodeKind:"node"}),i!=null&&(this._annotations.set(s,i),this.config.inspectorEnabled&&this._traceRing.push({path:s,annotation:i,timestamp_ns:ie()})),e}setVersioning(e){if(e!=null)for(let t of this._nodes.values())t instanceof L&&t._applyVersioning(e)}remove(e){Nt(e,this.name,"remove");let t=this._mounts.get(e);if(t){let s={kind:"mount",nodes:[],mounts:[]},i=[];t._collectObserveTargets("",i);for(let[a,u]of i)a.includes(`${$}${ee}${$}`)||s.nodes.push(a);return s.nodes.sort(),s.mounts.push(e),s.mounts.push(...t._collectSubgraphs(`${e}${$}`)),this._mounts.delete(e),t._parent=void 0,bn(t),this._emitTopology({kind:"removed",name:e,nodeKind:"mount",audit:s}),s}let r=this._nodes.get(e);if(!r)throw new Error(`Graph "${this.name}": unknown node or mount "${e}"`);this._nodes.delete(e),this._nodeToName.delete(r),r.down([[B]],{internal:!0});let o={kind:"node",nodes:[e],mounts:[]};return this._emitTopology({kind:"removed",name:e,nodeKind:"node",audit:o}),o}removeAll(e){let t=typeof e=="function"?e:(()=>{let s=Qe(e);return i=>s.test(i)})(),r={kind:"mount",nodes:[],mounts:[]},o=[...this._nodes.keys(),...this._mounts.keys()].filter(s=>t(s));for(let s of o){let i=this.remove(s);r.nodes.push(...i.nodes),r.mounts.push(...i.mounts)}return r.nodes.sort(),r.mounts.sort(),r}[Symbol.iterator](){let e=[...this._nodes.keys()].sort(),t=this._nodes,r=0;return{[Symbol.iterator](){return this},next(){if(r>=e.length)return{value:void 0,done:!0};let o=e[r++];return{value:[o,t.get(o)],done:!1}}}}node(e){if(e==="")throw new Error(`Graph "${this.name}": node name must be non-empty`);if(e.includes($))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,r){let o=r?.internal===!0;this.node(e).down([[F,t]],{actor:r?.actor,internal:o,delivery:"write"})}setAll(e,t){let r=Symbol.iterator in e?e:Object.entries(e);Be(()=>{for(let[o,s]of r)this.set(o,s,t)})}invalidate(e,t){let r=t?.internal===!0;this.node(e).down([[re]],{actor:t?.actor,internal:r,delivery:"write"})}error(e,t,r){let o=r?.internal===!0;this.node(e).down([[G,t]],{actor:r?.actor,internal:o,delivery:"write"})}complete(e,t){let r=t?.internal===!0;this.node(e).down([[H]],{actor:t?.actor,internal:r,delivery:"write"})}edges(e){let t=e?.recursive===!0,r=new Map;if(!t){for(let[u,c]of this._nodes)r.set(c,u);let a=[];for(let[u,c]of this._nodes)if(c instanceof L)for(let d of c._deps){let g=r.get(d.node);g!=null&&a.push([g,u])}return a.sort((u,c)=>u[0]<c[0]?-1:u[0]>c[0]?1:u[1]<c[1]?-1:u[1]>c[1]?1:0),a}let o=[];this._collectObserveTargets("",o);let s=new Map;for(let[a,u]of o)s.set(u,a);let i=[];for(let[a,u]of o)if(u instanceof L)for(let c of u._deps){let d=s.get(c.node);d!=null&&i.push([d,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 o=new n(e);return this.mount(e,o)}if(typeof t=="function"){let o=new n(e);return t(o),this.mount(e,o)}let r=t;if(Nt(e,this.name,"mount"),this._nodes.has(e))throw new Error(`Graph "${this.name}": cannot mount at "${e}" \u2014 node with that name exists`);if(this._mounts.has(e))throw new Error(`Graph "${this.name}": mount "${e}" already exists`);if(r===this)throw new Error(`Graph "${this.name}": cannot mount a graph into itself`);if(r._parent!=null)throw new Error(`Graph "${this.name}": this child graph is already mounted on "${r._parent.name}"`);for(let o=this;o!=null;o=o._parent)if(o===r)throw new Error(`Graph "${this.name}": mount("${e}", \u2026) would create a mount cycle`);return this._mounts.set(e,r),r._parent=this,this._emitTopology({kind:"added",name:e,nodeKind:"mount"}),r}resolve(e){let t=yr(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 r=t[0],o=t.slice(1);if(o.length===0){let a=this._nodes.get(r);if(a)return a;throw this._mounts.has(r)?new Error(`Graph "${this.name}": path ends at subgraph "${r}" \u2014 not a node (GRAPHREFLY-SPEC \xA73.5)`):new Error(`Graph "${this.name}": unknown name "${r}"`)}let s=this._nodes.get(r);if(s&&o.length>0&&o[0]===ee)return this._resolveMetaChainFromNode(s,o,t.join($));let i=this._mounts.get(r);if(!i)throw this._nodes.has(r)?new Error(`Graph "${this.name}": "${r}" is a node; trailing path "${o.join($)}" is invalid`):new Error(`Graph "${this.name}": unknown mount or node "${r}"`);return i.resolve(o.join($))}_resolveMetaChainFromNode(e,t,r){let o=e,s=0,i=[...t];for(;s<i.length;){if(i[s]!==ee)throw new Error(`Graph "${this.name}": expected ${ee} segment in meta path "${r}"`);if(s+1>=i.length)throw new Error(`Graph "${this.name}": meta path requires a key after ${ee} in "${r}"`);let a=i[s+1],u=o.meta[a];if(!u)throw new Error(`Graph "${this.name}": unknown meta "${a}" in path "${r}"`);o=u,s+=2}return o}signal(e,t){if(t?.internal!==!0){for(let o of e)if(this.config.messageTier(o[0])===3)throw new Error(`Graph "${this.name}": Graph.signal() rejects tier-3 messages (DATA / RESOLVED). Broadcast is for control-plane tiers (START / DIRTY / INVALIDATE / PAUSE / RESUME / COMPLETE / ERROR / TEARDOWN). For per-node value writes, use Graph.set or graph.node(name).down(...).`)}let r=[];if(this._signalDeliver(e,t??{},new Set,r),r.length>0)throw r[0]}_signalDeliver(e,t,r,o){for(let u of this._mounts.values())u._signalDeliver(e,t,r,o);let i=t.internal===!0?{internal:!0}:{actor:t.actor,delivery:"signal"},a=br(e,this.config);for(let u of[...this._nodes.keys()].sort()){let c=this._nodes.get(u);if(!r.has(c)){r.add(c);try{c.down(e,i)}catch(d){if(d instanceof Q)throw d;o.push(d)}a.length!==0&&this._signalMetaSubtree(c,a,r,i,o)}}}_signalMetaSubtree(e,t,r,o,s){for(let i of Object.keys(e.meta).sort()){let a=e.meta[i];if(!r.has(a)){r.add(a);try{a.down(t,o)}catch(u){if(u instanceof Q)throw u;s.push(u)}this._signalMetaSubtree(a,t,r,o,s)}}}describe(e){if(e?.reactive==="diff")return this._describeReactiveDiff(e);if(e?.reactive===!0)return this._describeReactive(e);let t=ur(e?.actor),r=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 o=bt(e?.detail,e?.fields),s=e?.detail==="spec",i=o,a=[];this._collectObserveTargets("",a);let u=new Map;for(let[y,w]of a)u.set(w,y);let c=[];{let y=a.map(([,N])=>N),w=new Set(u.values()),S=0;for(;y.length>0;){let N=y.shift();if(N instanceof L)for(let x of N._deps){let E=x.node;if(u.has(E))continue;let T=E.name??"",k=T;if(!k||w.has(k))if(T){let j=2;for(;w.has(`${T}#${j}`);)j++;k=`${T}#${j}`}else for(k=`__internal__/${S++}`;w.has(k);)k=`__internal__/${S++}`;u.set(E,k),w.add(k),c.push([k,E]),y.push(E)}}}let d=[...a,...c],g={};for(let[y,w]of d){if(t!=null&&!w.allowsObserve(t))continue;let S=vt(w,i,s),N=w instanceof L?w._deps.map(k=>u.get(k.node)??k.node.name??""):[],{name:x,...E}=S,T={...E,deps:N};if(!s){let k=this._annotations.get(y);k!=null&&(T.annotation=k)}if(r!=null)if(typeof r=="function"){let k=r;if(!(k.length>=2?k(y,T):k(T)))continue}else{let k=!0;for(let[j,R]of Object.entries(r)){let A=j==="deps_includes"?"depsIncludes":j==="meta_has"?"metaHas":j;if(A==="depsIncludes"){if(!T.deps.includes(String(R))){k=!1;break}continue}if(A==="metaHas"){if(!Object.hasOwn(T.meta??{},String(R))){k=!1;break}continue}if(T[A]!==R){k=!1;break}}if(!k)continue}g[y]=T}let f=new Set(Object.keys(g)),p=[];for(let[y,w]of d)if(w instanceof L)for(let S of w._deps){let N=u.get(S.node);N!=null&&p.push([N,y])}p.sort((y,w)=>y[0]<w[0]?-1:y[0]>w[0]?1:y[1]<w[1]?-1:y[1]>w[1]?1:0);let l=p.map(([y,w])=>({from:y,to:w}));(t!=null||r!=null)&&(l=l.filter(y=>f.has(y.from)&&f.has(y.to)));let b=this._collectSubgraphs(""),m=t!=null||r!=null?b.filter(y=>{let w=`${y}${$}`;return[...f].some(S=>S===y||S.startsWith(w))}):b,_=this,v=e;return{name:this.name,nodes:g,edges:l,subgraphs:m,...this._factory!==void 0?{factory:this._factory}:{},...this._factoryArgs!==void 0?{factoryArgs:this._factoryArgs}:{},expand(y){let w={...v};return Array.isArray(y)?(w.fields=y,w.detail=void 0):(w.detail=y,w.fields=void 0),_.describe(w)}}}_collectSubgraphs(e){let t=[];for(let r of[...this._mounts.keys()].sort()){let o=e===""?r:`${e}${r}`;t.push(o),t.push(...this._mounts.get(r)._collectSubgraphs(`${o}${$}`))}return t}resourceProfile(e){return un(this,e)}reachable(e,t,r={}){return r.withDetail===!0?mn(this.describe(),e,t,{...r,withDetail:!0}):mn(this.describe(),e,t,r)}explain(e,t,r){return r?.reactive===!0?this._explainReactive(e,t,r):this._explainStatic(ue(e),ue(t),{...r?.maxDepth!==void 0?{maxDepth:fn(r.maxDepth)}:{},...r?.findCycle!==void 0?{findCycle:pn(r.findCycle)}:{}})}_explainStatic(e,t,r){let o=this.describe({detail:"full"}),s=new Map(this._annotations),i=new Map;for(let[a,u]of Object.entries(o.nodes))u.lastMutation!=null&&i.set(a,u.lastMutation);return tn(o,e,t,{...r?.maxDepth!=null?{maxDepth:r.maxDepth}:{},...r?.findCycle===!0?{findCycle:!0}:{},annotations:s,lastMutations:i})}_describeReactive(e){let t={...e,reactive:!1},r=e.reactiveName??"describe",o=0,s=oe(o,{name:`${r}_version`}),i=this.observe({timeline:!0,structured:!0}),a=!1,u=!1,c=()=>{a||u||(a=!0,_e(()=>{a=!1,!u&&(o+=1,s.emit(o))}))},d=i.onEvent(v=>{let h=v.type;h!=="data"&&h!=="error"&&h!=="complete"&&h!=="teardown"||c()}),g=[],f=new WeakSet,p=v=>{if(f.has(v)||u)return;f.add(v);let h=v.topology.subscribe(y=>{for(let w of y){if(w[0]!==F)continue;let S=w[1];if(c(),S.kind==="added"&&S.nodeKind==="mount"){let N=v._mounts.get(S.name);N!=null&&p(N)}}});g.push(h);for(let y of v._mounts.keys()){let w=v._mounts.get(y);w!=null&&p(w)}};p(this);let l,b=e.actor;yn(b)&&(l=b.subscribe(v=>{let h=!1,y=!1;for(let w of v){let S=w[0];S===F?h=!0:(S===H||S===G||S===B)&&(y=!0)}h&&c(),y&&(l?.(),l=void 0,c())}));let m;try{m=ge([s],()=>this.describe(t),{name:r,describeKind:"derived",meta:{domain:"audit",kind:"describe"},equals:(v,h)=>v===h})}catch(v){d(),l?.();for(let h of g)h();throw i.dispose(),v}let _=Te(m);return{node:m,dispose(){u=!0,d(),l?.();for(let v of g)v();g.length=0,i.dispose(),_()}}}_describeReactiveDiff(e){let t={...e,reactive:!1},r=e.reactiveName??"describe-diff",o={name:this.name,nodes:{},edges:[],subgraphs:[]},s=this.describe(t),i=_t(o,s),a=oe(i,{name:r,meta:{domain:"audit",kind:"describe-diff"},equals:(f,p)=>f===p}),u=this._describeReactive({...e,reactiveName:void 0}),c=!1,d=u.node.subscribe(f=>{if(!c)for(let p of f){if(p[0]!==F)continue;let l=p[1],b=_t(s,l);s=l,b.events.length!==0&&a.emit(b)}}),g=Te(a);return{node:a,dispose(){c=!0,d(),u.dispose(),a.down([[B,"describe-diff disposed"]]),g()}}}_explainReactive(e,t,r){let o=0,s=oe(o,{name:"explain_version"}),i=this.observe({timeline:!0,structured:!0}),a=!1,u=!1,c=()=>{a||u||(a=!0,_e(()=>{a=!1,!u&&(o+=1,s.emit(o))}))},d=i.onEvent(v=>{let h=v.type;h!=="data"&&h!=="error"&&h!=="complete"&&h!=="teardown"||c()}),g=[];e!=null&&me(e)&&g.push(e),t!=null&&me(t)&&g.push(t),r?.maxDepth!=null&&me(r.maxDepth)&&g.push(r.maxDepth),r?.findCycle!=null&&me(r.findCycle)&&g.push(r.findCycle);let f=()=>{for(let v of g)if(v.cache===void 0)return!1;return!0},p=()=>{let v=ue(e),h=ue(t);return{from:v,to:h,found:!1,reason:"pending",steps:[],text:"(awaiting reactive args)",toJSON:()=>({from:v,to:h,found:!1,reason:"pending",steps:[]})}},l;try{l=ge([s],()=>{if(!f())return p();let v=ue(e),h=ue(t),y={...r?.maxDepth!==void 0?{maxDepth:fn(r.maxDepth)}:{},...r?.findCycle!==void 0?{findCycle:pn(r.findCycle)}:{}};return this._explainStatic(v,h,y)},{name:r?.name??"explain",describeKind:"derived",meta:{domain:"audit",kind:"explain_path",from:ue(e),to:ue(t)},equals:(v,h)=>v.found===h.found&&v.reason===h.reason&&v.steps.length===h.steps.length&&wr(v.steps,h.steps)})}catch(v){throw d(),i.dispose(),v}let b=Te(l),m=[],_=v=>{let h;return h=v.subscribe(y=>{let w=!1,S=!1;for(let N of y){let x=N[0];x===F?w=!0:(x===H||x===G||x===B)&&(S=!0)}(w||S)&&c(),S&&h&&(h(),h=void 0)}),()=>{h&&(h(),h=void 0)}};for(let v of g)m.push(_(v));return{node:l,dispose(){u=!0,d();for(let v of m)v?.();m.length=0,i.dispose(),b()}}}_pathsMatching(e){let t=Qe(e),r=[];return this._collectObserveTargets("",r),r.map(([o])=>o).filter(o=>t.test(o))}_collectObserveTargets(e,t){for(let r of[...this._mounts.keys()].sort()){let o=e===""?r:`${e}${$}${r}`;this._mounts.get(r)._collectObserveTargets(o,t)}for(let r of[...this._nodes.keys()].sort()){let o=this._nodes.get(r),s=e===""?r:`${e}${$}${r}`;t.push([s,o]),this._appendMetaObserveTargets(s,o,t)}}_appendMetaObserveTargets(e,t,r){for(let o of Object.keys(t.meta).sort()){let s=t.meta[o],i=`${e}${$}${ee}${$}${o}`;r.push([i,s]),this._appendMetaObserveTargets(i,s,r)}}observe(e,t){let r=typeof e=="string",s=gn(r?t:e);if(s.reactive===!0)return this._observeReactive(r?e:void 0,s);let i=s.structured===!0||s.timeline===!0||s.causal===!0||s.derived===!0||s.detail==="minimal"||s.detail==="full"||s.format!=null,a=s.actor;if(r){let d=e,g=this.resolve(d);if(a!=null&&!g.allowsObserve(a))throw new Q({actor:a,action:"observe",nodeName:d});return i?this._buildStructuredObserver([[d,g]],s,"one"):{subscribe(f){return g.subscribe(f)},up(f){try{g.up?.(f)}catch(p){if(p instanceof Q)return;throw p}}}}let u=[];this._collectObserveTargets("",u),u.sort((d,g)=>d[0]<g[0]?-1:d[0]>g[0]?1:0);let c=a==null?u:u.filter(([,d])=>d.allowsObserve(a));return i?this._buildStructuredObserver(c,s,"all"):{subscribe:d=>{let g=c.map(([f,p])=>p.subscribe(l=>{d(f,l)}));return()=>{for(let f of g)f()}},up:(d,g)=>{try{this.resolve(d).up?.(g)}catch(f){if(f instanceof Q)return;throw f}}}}_observeReactive(e,t){let r=t.tiers,o=r!=null?new Set(r):null,s=t.reactiveName??"observe";return xe(i=>{let a=[],u=!1,c=!1,d=()=>{if(a.length===0||c)return;let b={events:a.slice(),flushedAt_ns:ie()};a.length=0,i.emit(b)},g={...t,reactive:!1,structured:!0,timeline:!0},f=e!=null?this.observe(e,g):this.observe(g),p=b=>{c||(a.push(b),!u&&(u=!0,_e(()=>{u=!1,d()})))};for(let b of f.events)p(b);let l=f.onEvent(p);return()=>{c=!0,l(),f.dispose()}},{name:s,meta:{domain:"audit",kind:"observe-reactive"}})}_buildStructuredObserver(e,t,r){let o=r==="one"?e[0]?.[0]:void 0,s=i=>{if(r==="one"&&o!=null){let d=this.resolve(o);return this._buildStructuredObserver([[o,d]],i,"one")}let a=[];this._collectObserveTargets("",a),a.sort((d,g)=>d[0]<g[0]?-1:d[0]>g[0]?1:0);let u=i.actor,c=u==null?a:a.filter(([,d])=>d.allowsObserve(u));return this._buildStructuredObserver(c,i,"all")};return this._createObserveResult(e,t,s)}_createObserveResult(e,t,r){let o=t.timeline===!0,s=t.causal===!0,i=t.derived===!0,a=t.detail==="minimal",u=this.config.inspectorEnabled,c=(s||i)&&u,d=t.maxEvents,g=d!=null&&d>0?new Fe(d):null,f=[],p=new Set,l=t.tiers!=null?new Set(t.tiers):null,b={},m=new Set,_=0,v=0,h=0,y=0,w=0,S=0,N=!1,x=!1,E=0,T=new Map,k=new Map,j=new Map,R=O=>{if(!(l!=null&&!l.has(O.type))){g?g.push(O):f.push(O);for(let M of p)M(O)}},A=O=>l==null||l.has(O),te=()=>o?{timestamp_ns:ie(),in_batch:Ve(),batch_id:E}:{},ye=(O,M)=>{if(!(!c||!(O instanceof L)))return O._setInspectorHook(J=>{if(J.kind==="dep_message")T.set(O,J.depIndex);else if(J.kind==="run"){let Ae=J.batchData.map((D,U)=>D!=null&&D.length>0?D.at(-1):J.prevData[U]);k.set(O,Ae);let Y=J.batchData.map(D=>D!=null?[...D]:void 0);j.set(O,Y),i&&R({type:"derived",path:M,dep_values:Ae,dep_batches:Y,...te()})}})},z=O=>{let M=T.get(O),J=k.get(O);if(!s||J==null)return{};let Y=(M!=null&&M>=0&&O instanceof L?O._deps[M]:void 0)?.node,D=Y?.v,U=j.get(O);return{trigger_dep_index:M,trigger_dep_name:Y?.name,...D!=null?{trigger_version:{id:D.id,version:D.version}}:{},dep_values:[...J],...U!=null?{dep_batches:U}:{}}},q=[],W=[];for(let[O,M]of e){let J=ye(M,O);J&&q.push(J),W.push(M.subscribe(Ae=>{E++;for(let Y of Ae){let D=Y[0],U=te();if(D===F){b[O]=Y[1];let rt=M instanceof L?M.lastMutation?.actor??be:be;R({type:"data",path:O,data:Y[1],actor:rt,...U,...z(M)})}else if(a)D===X?A("dirty")&&_++:D===Z?A("resolved")&&v++:D===re?A("invalidate")&&h++:D===se?A("pause")&&y++:D===ce?A("resume")&&w++:D===B?A("teardown")&&S++:D===H&&!m.has(O)?A("complete")&&(N=!0):D===G&&A("error")&&(x=!0,m.add(O));else if(D===X)A("dirty")&&_++,R({type:"dirty",path:O,...U});else if(D===Z)A("resolved")&&v++,R({type:"resolved",path:O,...U,...z(M)});else if(D===re)A("invalidate")&&h++,R({type:"invalidate",path:O,...U});else if(D===se)A("pause")&&y++,R({type:"pause",path:O,lockId:Y[1],...U});else if(D===ce)A("resume")&&w++,R({type:"resume",path:O,lockId:Y[1],...U});else if(D===H)A("complete")&&!m.has(O)&&(N=!0),R({type:"complete",path:O,...U});else if(D===G){A("error")&&(x=!0,m.add(O));let rt=M instanceof L?M.lastMutation?.actor??be:be;R({type:"error",path:O,data:Y[1],actor:rt,...U})}else D===B&&(A("teardown")&&S++,R({type:"teardown",path:O,...U}))}}))}let K=!1,V=()=>{if(!K){K=!0;for(let O of W)O();for(let O of q)O();for(let O of Le)O({value:void 0,done:!0});Le.length=0}},ne=[],Le=[];p.add(O=>{let M=Le.shift();M?M({value:O,done:!1}):ne.push(O)});let At={get values(){return b},get dirtyCount(){return _},get resolvedCount(){return v},get invalidateCount(){return h},get pauseCount(){return y},get resumeCount(){return w},get teardownCount(){return S},get events(){return g?g.toArray():[...f]},get anyCompletedCleanly(){return N},get anyErrored(){return x},get completedWithoutErrors(){return N&&!x},onEvent(O){return p.add(O),()=>p.delete(O)},dispose:V,expand(O){V();let M={...t};return typeof O=="string"?M.detail=O:Object.assign(M,O),r(gn(M))},[Symbol.asyncIterator](){return{next(){return ne.length>0?Promise.resolve({value:ne.shift(),done:!1}):K?Promise.resolve({value:void 0,done:!0}):new Promise(O=>Le.push(O))},return(){return V(),Promise.resolve({value:void 0,done:!0})}}}};return t.format!=null&&this._attachFormatLogger(At,t),At}_attachFormatLogger(e,t){let r=t.format;if(r==null)return;let o=t.logger??(l=>console.log(l)),s=t.includeTypes?new Set(t.includeTypes):null,i=t.excludeTypes?new Set(t.excludeTypes):null,a=s==null&&i==null?()=>!0:l=>(s==null||s.has(l))&&(i==null||!i.has(l)),u=gr(t.theme),c=r==="stage-log"?ie():0,d=l=>l==null?"":t.stageLabels?.[l]??l,g=(l,b)=>l.length>b?`${l.slice(0,b-1)}\u2026`:l,f=l=>l.type==="data"||l.type==="error"?g(kt(l.data),120):"",p=l=>{if(r==="stage-log"){let N=(ie()-c)/1e9,x=d(l.path).padEnd(9);if(l.type==="data"){let E=f(l);return`[${N.toFixed(3)}s] ${x} \u2190${E?` ${E}`:""}`}if(l.type==="error"){let E=f(l);return`[${N.toFixed(3)}s] ${x} \u2717${E?` ${E}`:""}`}return l.type==="complete"?`[${N.toFixed(3)}s] ${x} \u25A0 complete`:`[${N.toFixed(3)}s] ${x} ${l.type}`}if(r==="json")try{return JSON.stringify(l)}catch{return JSON.stringify({type:l.type,path:l.path,data:"[unserializable]"})}let b=u[l.type]??"",m=l.path?`${u.path}${l.path}${u.reset} `:"",_=l.type==="data"||l.type==="error",v=l.type==="pause"||l.type==="resume",h=_?` ${kt(l.data)}`:v?` ${kt(l.lockId)}`:"",y=l.type==="data"||l.type==="resolved"||l.type==="derived"?l:void 0,w=y?.trigger_dep_name!=null?` <- ${y.trigger_dep_name}`:y?.trigger_dep_index!=null?` <- #${y.trigger_dep_index}`:"",S=l.in_batch?" [batch]":"";return`${m}${b}${l.type.toUpperCase()}${u.reset}${h}${w}${S}`};e.onEvent(l=>{a(l.type)&&o(p(l),l)})}addDisposer(e){return this._disposers.add(e),()=>{this._disposers.delete(e)}}destroy(){ln(this._disposers,this.name),this.signal([[B]],{internal:!0}),ln(this._storageDisposers,this.name);for(let e of[...this._mounts.values()])e._parent=void 0,e._destroyClearOnly();this._mounts.clear(),this._nodes.clear(),this._parent=void 0,this._destroyed=!0}get destroyed(){return this._destroyed}_destroyClearOnly(){for(let e of[...this._mounts.values()])e._parent=void 0,e._destroyClearOnly();this._mounts.clear(),this._nodes.clear(),this._parent=void 0,this._destroyed=!0}snapshot(e){let{expand:t,...r}=this.describe({detail:"full"}),o={};for(let a of Object.keys(r.nodes).sort()){let{lastMutation:u,guard:c,...d}=r.nodes[a];o[a]=d}let s=[...r.subgraphs].sort(),i={...r,version:1,nodes:o,subgraphs:s};if(e?.format==null)return i;if(e.format==="json-string")return JSON.stringify(i);if(e.format==="bytes"){if(e.codec==null)throw new Error("snapshot({format: 'bytes'}) requires a `codec` name");let a=this.config.lookupCodec(e.codec);if(a==null)throw new Error(`snapshot: codec "${e.codec}" is not registered on this graph's config. Call config.registerCodec(...) before creating nodes.`);return Dt(a,a.encode(i))}throw new Error(`snapshot: unknown format "${String(e.format)}"`)}static decode(e,t){let r=t?.config??Ne,{codec:o,codecVersion:s,payload:i}=Gt(e,r);return o.decode(i,s)}restore(e,t){if(hn(e),e.name!==this.name)throw new Error(`Graph "${this.name}": restore snapshot name "${e.name}" does not match this graph`);let r=t?.only==null?null:(Array.isArray(t.only)?t.only:[t.only]).map(s=>Qe(s)),o=t?.includeProducers===!0;for(let s of Object.keys(e.nodes).sort()){if(r!==null&&!r.some(a=>a.test(s)))continue;let i=e.nodes[s];if(i!==void 0){if(!("value"in i)||i.value===void 0){"value"in i&&i.value===void 0&&t?.onError?.(s,new Error(`restore: slice.value is undefined for "${s}" (undefined is the global SENTINEL; not valid DATA)`));continue}if(!(i.type==="derived"||i.type==="effect")&&!(i.type==="producer"&&!o)){if(i.v!=null){let u=this.tryResolve(s)?.v;if(u!=null&&u.id===i.v.id&&u.version===i.v.version)continue}try{this.set(s,i.value)}catch(a){t?.onError?.(s,a)}}}}}static fromSnapshot(e,t){hn(e);let r=typeof t=="function"?t:t?.build,o=typeof t=="function"?void 0:t?.factories,s=new n(e.name);if(r)return r(s),s.restore(e),s;for(let p of[...e.subgraphs].sort((l,b)=>{let m=l.split($).length,_=b.split($).length;return m!==_?m-_:l<b?-1:l>b?1:0})){let l=p.split($),b=s;for(let m of l)b._mounts.has(m)||b.mount(m,new n(m)),b=b._mounts.get(m)}let i=o?Object.entries(o).map(([p,l])=>({re:Qe(p),factory:l})):[],a=p=>{for(let l of i)if(l.re.test(p))return l.factory},u=p=>{let l=p.split($),b=l.pop();if(b==null||b.length===0)throw new Error(`invalid snapshot path "${p}"`);let m=s;for(let _ of l){let v=m._mounts.get(_);if(!v)throw new Error(`unknown mount "${_}" in path "${p}"`);m=v}return[m,b]},c=Object.entries(e.nodes).filter(([p])=>!p.includes(`${$}${ee}${$}`)).sort((p,l)=>p[0]<l[0]?-1:p[0]>l[0]?1:0),d=new Map(c),g=new Map,f=!0;for(;d.size>0&&f;){f=!1;for(let[p,l]of[...d.entries()]){let b=l?.deps??[];if(!b.every(w=>g.has(w)))continue;let[m,_]=u(p),v={...l?.meta??{}},h=a(p),y;if(l?.type==="state")y=oe(l.value,{meta:v});else{if(h==null)continue;y=h(_,{path:p,type:l.type,value:l.value,meta:v,deps:b,resolvedDeps:b.map(w=>g.get(w))})}m.add(y,{name:_}),g.set(p,y),d.delete(p),f=!0}}if(d.size>0){let p=[...d.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 s.restore(e),s}toJSON(){return this.snapshot()}attachSnapshotStorage(e,t={}){let r=e.map(c=>({tier:c,debounceMs:Math.max(0,c.debounceMs??0),compactEvery:Math.max(1,c.compactEvery??10),timer:void 0,seq:0,lastSnapshot:void 0,lastFingerprint:"",disposed:!1,savePending:void 0}));t.autoRestore===!0&&this._cascadeRestore(e,t.onError);let o=(c,d)=>{if(c.disposed)return;let g=dr(d.nodes);if(c.lastSnapshot!=null&&g!==""&&g===c.lastFingerprint)return;let f=c.seq+1,p=Se(),m=c.lastSnapshot==null||f%c.compactEvery===0?{name:this.name,mode:"full",snapshot:d,seq:f,timestamp_ns:p,format_version:de}:{name:this.name,mode:"diff",diff:vr(c.lastSnapshot,d),seq:f,timestamp_ns:p,format_version:de};if(c.tier.filter&&!c.tier.filter(m))return;let _;try{_=c.tier.save(m)}catch(v){t.onError?.(v,c.tier);return}if(_&&typeof _.then=="function"){let y=(c.savePending??Promise.resolve()).then(()=>_,()=>_).then(()=>{c.disposed||(c.seq=f,c.lastSnapshot=d,c.lastFingerprint=g)},w=>{t.onError?.(w,c.tier)});c.savePending=y.finally(()=>{c.savePending===y&&(c.savePending=void 0)})}else c.seq=f,c.lastSnapshot=d,c.lastFingerprint=g},s=(c,d)=>{try{o(c,d)}catch(g){t.onError?.(g,c.tier)}},i=(c,d)=>{if(!d.some(l=>{let b=this.config.messageTier(l[0]);return b>=3&&b<5}))return;if(t.filter){let l=this.tryResolve(c);if(l==null)return;let b=vt(l,bt("standard"));if(!t.filter(c,b))return}let f,p=()=>(f==null&&(f=this.snapshot()),f);for(let l of r)l.disposed||(l.debounceMs===0?s(l,p()):(l.timer==null&&(l.timer=new Je),l.timer.start(l.debounceMs,()=>{l.disposed||s(l,this.snapshot())})))},a;if(t.paths!=null){let d=(typeof t.paths=="string"?this._pathsMatching(t.paths):t.paths).map(g=>{let f=this.tryResolve(g);return f==null?()=>{}:f.subscribe(p=>i(g,p))});a=()=>{for(let g of d)g()}}else a=this.observe().subscribe((c,d)=>i(c,d));let u=()=>{a();for(let c of r)c.disposed=!0,c.timer?.cancel();this._storageDisposers.delete(u)};return this._storageDisposers.add(u),{dispose:u}}async _cascadeRestore(e,t){for(let r of e){let o;try{o=await r.load?.()}catch(i){t?.(i,r);continue}if(o==null||typeof o!="object"||Array.isArray(o))continue;let s=o;try{if(s.mode==="full"&&s.snapshot!=null)return this.restore(s.snapshot),!0;if(s.version===de&&s.nodes!=null)return this.restore(s),!0}catch(i){t?.(i,r)}}return!1}static async fromStorage(e,t,r){for(let o of t){let s;try{s=await o.load?.()}catch(u){r?.onError?.(u,o);continue}if(s==null||typeof s!="object"||Array.isArray(s))continue;let i=s,a=i.mode==="full"&&i.snapshot!=null?i.snapshot:i.version===de&&i.nodes!=null?i:void 0;if(a!=null)try{return n.fromSnapshot(a,r)}catch(u){r?.onError?.(u,o)}}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,r){if(e!=null&&t!=null){if(this.tryResolve(e)==null)return;if(this._annotations.set(e,t),this.config.inspectorEnabled){let o={path:e,annotation:t,timestamp_ns:ie(),...r?.actor!=null?{actor:r.actor}:{}};this._traceRing.push(o)}return}return e!=null?this.config.inspectorEnabled?this._annotations.get(e):void 0:this.config.inspectorEnabled?this._traceRing.toArray():[]}annotation(e){return this._annotations.get(e)}clearTrace(){this._annotations.clear(),this._traceRing.clear()}pruneTrace(e){let t=this._traceRing.toArray().filter(o=>!e(o)),r=this._traceRing.size-t.length;this._traceRing.clear();for(let o of t)this._traceRing.push(o);return r}static diff(e,t){let r=new Set(Object.keys(e.nodes)),o=new Set(Object.keys(t.nodes)),s=[...o].filter(v=>!r.has(v)).sort(),i=[...r].filter(v=>!o.has(v)).sort(),a=[],u=[];for(let v of r){if(!o.has(v))continue;let h=e.nodes[v],y=t.nodes[v],w=h.v,S=y.v;w!=null&&S!=null&&w.id===S.id&&w.version!==S.version&&u.push({path:v,id:w.id,from:w.version,to:S.version});let N=w!=null&&S!=null&&w.id===S.id&&w.version===S.version;for(let x of["type","status","sentinel"]){let E=h[x],T=y[x];E!==T&&a.push({path:v,field:x,from:E,to:T})}if(!N)for(let x of["value","meta"]){let E=h[x],T=y[x];lr(E,T)||a.push({path:v,field:x,from:E,to:T})}}let c=v=>`${v.from} ${v.to}`,d=new Set(e.edges.map(c)),g=new Set(t.edges.map(c)),f=t.edges.filter(v=>!d.has(c(v))),p=e.edges.filter(v=>!g.has(c(v))),l=new Set(e.subgraphs),b=new Set(t.subgraphs),m=[...b].filter(v=>!l.has(v)).sort(),_=[...l].filter(v=>!b.has(v)).sort();return{nodesAdded:s,nodesRemoved:i,nodesChanged:a,versionChanges:u,edgesAdded:f,edgesRemoved:p,subgraphsAdded:m,subgraphsRemoved:_}}}});function vn(n,e,t){return{[n]:!0,[`${n}_type`]:e,...t??{}}}var wn=P(()=>{"use strict"});var Rr={};Ln(Rr,{SNAPSHOT_WIRE_VERSION:()=>Et,SurfaceError:()=>C,asSurfaceError:()=>En,createGraph:()=>tt,deleteSnapshot:()=>$n,diffSnapshots:()=>Gn,listSnapshots:()=>Mn,restoreSnapshot:()=>Dn,runReduction:()=>An,saveSnapshot:()=>Cn});module.exports=Vn(Rr);Ke();Ot();ze();pe();Oe();Ke();wn();$e();pe();function _n(n,e){let t=n.cache??0;return t>=e?!1:(n.down([[X],[F,t+1]]),!0)}var As=Bt((n,e)=>{n("observe"),n("signal"),e("write")});St();function Sn(n,e){return vn("reduction",n,e)}function kn(n,e,t,r){let o=r?.maxIterations??10,s=`__feedback_${e}`,i=oe(0,{meta:Sn("feedback_counter",{maxIterations:o,feedbackFrom:e,feedbackTo:t})});n.add(i,{name:s});let a=n.resolve(e),u=n.resolve(t),c=`__feedback_effect_${e}`,d=he([],(g,f)=>{let p=a.subscribe(l=>{for(let b of l){let m=b[0];if(m===F){let _=b[1];if(_==null)return;Be(()=>{_n(i,o)&&u.emit(_)})}else if(m===H||m===G){let _=m===G&&b.length>1?[G,b[1]]:[m];i.down([_])}}});return()=>p()},{name:c,describeKind:"effect",meta:{...Sn("feedback_effect",{feedbackFrom:e,feedbackTo:t}),_internal:!0}});return n.add(d,{name:c}),n.addDisposer(Te(d)),n}function Re(n){let e=n.meta?.factory;return typeof e=="string"?e:void 0}function Ee(n){let e=n.meta?.factoryArgs;return e!=null&&typeof e=="object"?e:{}}function Nn(n){let e=Ee(n);return"initial"in e?e.initial:n.value}function xn(n){return typeof n=="object"&&n!==null&&"factory"in n}function Tn(n){return typeof n=="object"&&n!==null&&"factory"in n}function _r(n){return xn(n)?n.factory:n}function Sr(n){return Tn(n)?n.factory:n}function xt(n,e){let t=[],r=new Set(Object.keys(e.fns??{})),o=new Set(Object.keys(e.sources??{}));for(let[s,i]of Object.entries(n.nodes)){if(i.type==="template")continue;let a=i,u=Re(a);if(u==null)continue;let c=a.type==="producer";if(a.type==="state"&&u==="state")continue;if(c){let g=o.has(u),f=r.has(u);if(!g&&!f&&(o.size>0||r.size>0)){let p=et(u,o)??et(u,r);t.push(`Node "${s}": source "${u}" not found in catalog`+(p?`. Did you mean "${p}"?`:""))}}else if(r.size>0&&!r.has(u))if(o.has(u))t.push(`Node "${s}": fn "${u}" is a source, not a function. Use it as a producer source instead, or use a function from: ${[...r].join(", ")}`);else{let g=et(u,r);t.push(`Node "${s}": fn "${u}" not found in catalog`+(g?`. Did you mean "${g}"?`:""))}let d=Ee(a);if(!c&&e.fns?.[u]){let g=e.fns[u];if(xn(g)&&g.configSchema){for(let[f,p]of Object.entries(g.configSchema))if(p.required!==!1&&!(f in d)&&t.push(`Node "${s}": config missing required field "${f}"`),f in d&&p.enum){let l=d[f];p.enum.includes(l)||t.push(`Node "${s}": config.${f} = ${JSON.stringify(l)}, expected one of: ${p.enum.join(", ")}`)}}}if(c&&e.sources?.[u]){let g=e.sources[u];if(Tn(g)&&g.configSchema){for(let[f,p]of Object.entries(g.configSchema))if(p.required!==!1&&!(f in d)&&t.push(`Node "${s}": config missing required field "${f}"`),f in d&&p.enum){let l=d[f];p.enum.includes(l)||t.push(`Node "${s}": config.${f} = ${JSON.stringify(l)}, expected one of: ${p.enum.join(", ")}`)}}}}if(n.templates)for(let[s,i]of Object.entries(n.templates))for(let[a,u]of Object.entries(i.nodes)){let c=Re(u);if(c!=null&&!(u.type==="state"&&c==="state")&&u.type!=="producer"&&r.size>0&&!r.has(c)){let d=et(c,r);t.push(`Template "${s}" node "${a}": fn "${c}" not found in catalog`+(d?`. Did you mean "${d}"?`:""))}}return{valid:t.length===0,errors:t,warnings:[]}}function et(n,e){let t=null,r=1/0,o=n.toLowerCase();for(let s of e){let i=kr(o,s.toLowerCase());i<r&&i<=Math.max(3,Math.floor(n.length/2))&&(r=i,t=s)}return t}function kr(n,e){let t=n.length,r=e.length,o=Array.from({length:t+1},(s,i)=>Array.from({length:r+1},(a,u)=>i===0?u:u===0?i:0));for(let s=1;s<=t;s++)for(let i=1;i<=r;i++)o[s][i]=n[s-1]===e[i-1]?o[s-1][i-1]:1+Math.min(o[s-1][i],o[s][i-1],o[s-1][i-1]);return o[t][r]}var On=new Set(["state","producer","derived","effect","operator","template"]),Nr=new Set(["state","producer","derived","effect","operator"]);function Tt(n){let e=[],t=[];if(n==null||typeof n!="object")return{valid:!1,errors:["GraphSpec must be a non-null object"],warnings:t};let r=n;if((typeof r.name!="string"||r.name.length===0)&&e.push("Missing or empty 'name' field"),r.nodes==null||typeof r.nodes!="object"||Array.isArray(r.nodes))return e.push("Missing or invalid 'nodes' field (must be an object)"),{valid:!1,errors:e,warnings:t};let o=new Set(Object.keys(r.nodes)),s=new Map,i=new Map;if(r.templates!=null&&typeof r.templates=="object"&&!Array.isArray(r.templates)){for(let[a,u]of Object.entries(r.templates))if(u!=null&&typeof u=="object"){let c=u;i.set(a,{params:Array.isArray(c.params)?c.params:[]})}}if(r.templates!=null)if(typeof r.templates!="object"||Array.isArray(r.templates))e.push("'templates' must be an object");else for(let[a,u]of Object.entries(r.templates)){if(u==null||typeof u!="object"){e.push(`Template "${a}": must be an object`);continue}let c=u;if(Array.isArray(c.params)||e.push(`Template "${a}": missing 'params' array`),c.nodes==null||typeof c.nodes!="object"||Array.isArray(c.nodes))e.push(`Template "${a}": missing or invalid 'nodes' object`);else{let d=new Set(Array.isArray(c.params)?c.params:[]),g=new Set(Object.keys(c.nodes));for(let[f,p]of Object.entries(c.nodes)){if(p==null||typeof p!="object"){e.push(`Template "${a}" node "${f}": must be an object`);continue}let l=p;if((typeof l.type!="string"||!Nr.has(l.type))&&e.push(`Template "${a}" node "${f}": invalid type`),Array.isArray(l.deps))for(let b of l.deps)!g.has(b)&&!d.has(b)&&e.push(`Template "${a}" node "${f}": dep "${b}" is not an inner node or param`)}typeof c.output!="string"?e.push(`Template "${a}": missing 'output' string`):c.nodes[c.output]||e.push(`Template "${a}": output "${c.output}" is not a declared node`)}}for(let[a,u]of Object.entries(r.nodes)){if(u==null||typeof u!="object"){e.push(`Node "${a}": must be an object`);continue}let c=u;if(typeof c.type!="string"||!On.has(c.type)){e.push(`Node "${a}": invalid type "${String(c.type)}" (expected: ${[...On].join(", ")})`);continue}if(s.set(a,c.type),c.type==="template")if(typeof c.template!="string"||!i.has(c.template))e.push(`Node "${a}": template "${String(c.template)}" not found in templates`);else if(c.bind==null||typeof c.bind!="object"||Array.isArray(c.bind))e.push(`Node "${a}": template ref requires 'bind' object`);else{let d=i.get(c.template),g=c.bind;for(let f of d.params)f in g||e.push(`Node "${a}": template param "${f}" is not bound (template "${c.template}")`);for(let[,f]of Object.entries(g))typeof f=="string"&&!o.has(f)&&e.push(`Node "${a}": bind target "${f}" does not reference an existing node`)}else{if(Array.isArray(c.deps))for(let d of c.deps)d===a?e.push(`Node "${a}": self-referencing dep`):o.has(d)||e.push(`Node "${a}": dep "${d}" does not reference an existing node`);(c.type==="derived"||c.type==="effect"||c.type==="operator")&&!Array.isArray(c.deps)&&e.push(`Node "${a}": ${c.type} node should have a 'deps' array`)}}if(r.feedback!=null)if(!Array.isArray(r.feedback))e.push("'feedback' must be an array");else for(let a=0;a<r.feedback.length;a++){let u=r.feedback[a];if(u==null||typeof u!="object"){e.push(`Feedback [${a}]: must be an object`);continue}let c=u;typeof c.from!="string"||!o.has(c.from)?e.push(`Feedback [${a}]: 'from' "${String(c.from)}" does not reference an existing node`):s.get(c.from)==="effect"&&t.push(`Feedback [${a}]: 'from' "${c.from}" is an effect node \u2014 effects emit no DATA, so the feedback edge will never fire. Did you mean a derived/state node upstream?`),typeof c.from=="string"&&c.from===c.to&&e.push(`Feedback [${a}]: 'from' and 'to' must be different nodes`),typeof c.to!="string"||!o.has(c.to)?e.push(`Feedback [${a}]: 'to' "${String(c.to)}" does not reference an existing node`):typeof c.to=="string"&&s.get(c.to)!=="state"&&e.push(`Feedback [${a}]: 'to' node "${c.to}" must be a state node (got "${s.get(c.to)??"unknown"}")`)}return{valid:e.length===0,errors:e,warnings:t}}function Rn(n,e){let t=Tt(n);if(!t.valid)throw new Error(`compileSpec: invalid GraphSpec:
4
- ${t.errors.join(`
5
- `)}`);let r=n.factory,o=n.factoryArgs;if(typeof r=="string"){let h=e?.catalog?.graphFactories?.[r];if(h)return h(o)}let s=e?.catalog??{},i=e?.onMissing??"placeholder",a=new ae(n.name),u=n.templates??{},c=xt(n,s);if(!c.valid)throw new Error(`compileSpec: catalog validation errors:
6
- ${c.errors.join(`
7
- `)}`);let d=[],g=(h,y,w)=>{d.push({path:h,kind:y,name:w})},f=h=>{let y=s.fns?.[h];return y?_r(y):void 0},p=h=>{let y=s.sources?.[h];return y?Sr(y):void 0},l=h=>{if(!h)return;let y={};for(let[w,S]of Object.entries(h))w==="factory"||w==="factoryArgs"||(y[w]=S);return Object.keys(y).length>0?y:void 0},b=new Map,m=[];for(let[h,y]of Object.entries(n.nodes)){if(y.type==="template")continue;let w=y,S=Re(w),N=Ee(w);if(w.type==="state"){let x=Nn(w),E=oe(x,{name:h,meta:l(w.meta)});a.add(E,{name:h}),b.set(h,E)}else if(w.type==="producer"){let x=S?p(S):void 0,E=S?f(S):void 0;if(x){let T=x(N);a.add(T,{name:h}),b.set(h,T)}else if(E){let T=E([],N);a.add(T,{name:h}),b.set(h,T)}else{S&&g(h,"source",S);let T=xe(()=>{},{name:h,meta:{...l(w.meta),_specSource:S}});a.add(T,{name:h}),b.set(h,T)}}else m.push([h,w])}let _=!0,v=new Map(m);for(;v.size>0&&_;){_=!1;for(let[h,y]of[...v.entries()]){let w=y.deps??[];if(!w.every(k=>b.has(k)))continue;let S=w.map(k=>b.get(k)),N=Re(y),x=Ee(y),E=N?f(N):void 0,T;E?T=E(S,x):y.type==="effect"?(N&&g(h,"fn",N),T=qe(S,()=>{})):(N&&g(h,"fn",N),T=ge(S,k=>k[0])),a.add(T,{name:h}),b.set(h,T),v.delete(h),_=!0}}if(v.size>0){let h=[...v.keys()].sort().join(", ");throw new Error(`compileSpec: unresolvable deps for nodes: ${h}`)}for(let[h,y]of Object.entries(n.nodes)){if(y.type!=="template")continue;let w=y,S=u[w.template],N=new ae(h),x=new Map,E=[];for(let[R,A]of Object.entries(S.nodes)){let te=(A.deps??[]).map(W=>W.startsWith("$")&&w.bind[W]?w.bind[W]:W),ye={...A,deps:te},z=Re(A),q=Ee(A);if(A.type==="state"){let W=Nn(A),K=oe(W,{name:R,meta:l(A.meta)});N.add(K,{name:R}),x.set(R,K)}else if(A.type==="producer"){let W=z?p(z):void 0,K=z?f(z):void 0;if(W){let V=W(q);N.add(V,{name:R}),x.set(R,V)}else if(K){let V=K([],q);N.add(V,{name:R}),x.set(R,V)}else{z&&g(`${h}.${R}`,"source",z);let V=xe(()=>{},{name:R,meta:{...l(A.meta),_specSource:z}});N.add(V,{name:R}),x.set(R,V)}}else E.push([R,ye])}let T=!0,k=new Map(E);for(;k.size>0&&T;){T=!1;for(let[R,A]of[...k.entries()]){let te=A.deps??[];if(!te.every(ne=>x.has(ne)||b.has(ne)))continue;let z=te.map(ne=>x.get(ne)??b.get(ne)),q=Re(A),W=Ee(A),K=q?f(q):void 0,V;K?V=K(z,W):A.type==="effect"?(q&&g(`${h}.${R}`,"fn",q),V=qe(z,()=>{})):(q&&g(`${h}.${R}`,"fn",q),V=ge(z,ne=>ne[0])),N.add(V,{name:R}),x.set(R,V),k.delete(R),T=!0}}if(k.size>0){let R=[...k.keys()].sort().join(", ");throw new Error(`compileSpec: template "${w.template}" has unresolvable deps: ${R}`)}a.mount(h,N);let j=`${h}::${S.output}`;b.set(h,a.resolve(j));try{let R=a.resolve(j);R.meta._templateName?.emit(w.template),R.meta._templateBind?.emit(w.bind)}catch{}}for(let h of n.feedback??[])kn(a,h.from,h.to,{maxIterations:h.maxIterations});if(d.length>0){if(i==="error"){let h=d.map(y=>` - ${y.path}: missing ${y.kind} "${y.name}"`);throw new Error(`compileSpec: ${d.length} catalog entr${d.length===1?"y":"ies"} missing \u2014 pass them via opts.catalog or set opts.onMissing to "warn"/"placeholder":
8
- ${h.join(`
9
- `)}`)}if(i==="warn"){let h=e?.onWarn??(y=>console.warn(y));for(let y of d)h(`compileSpec: ${y.path} references missing ${y.kind} "${y.name}" \u2014 substituted placeholder`)}}return a}var C=class extends Error{code;details;constructor(e,t,r){super(t),this.name="SurfaceError",this.code=e,r!==void 0&&(this.details=r)}toJSON(){let e={code:this.code,message:this.message};if(this.details!==void 0){let t=Or(this.details);t!==void 0&&(e.details=t)}return e}};function Or(n){try{return JSON.parse(JSON.stringify(n))}catch{return}}function En(n,e="internal-error"){if(n instanceof C)return n;let t=n instanceof Error?n.message:String(n);return new C(e,t)}function tt(n,e){let t=Tt(n);if(!t.valid)throw new C("invalid-spec",`GraphSpec validation failed:
10
- ${t.errors.join(`
11
- `)}`,{errors:t.errors});let r=e?.catalog??{},o=xt(n,r);if(!o.valid)throw new C("catalog-error",`Catalog validation failed:
12
- ${o.errors.join(`
13
- `)}`,{errors:o.errors});try{return Rn(n,e)}catch(s){let i=s instanceof Error?s.message:String(s);throw new C("catalog-error",i)}}pe();var xr=3e4;async function An(n,e,t){let r=t?.inputPath??"input",o=t?.outputPath??"output",s=t?.timeoutMs??xr,i=tt(n,{catalog:t?.catalog}),a;try{a=i.resolve(o)}catch{throw i.destroy(),new C("node-not-found",`reduce: output path "${o}" is not registered`,{path:o})}try{i.resolve(r)}catch{throw i.destroy(),new C("node-not-found",`reduce: input path "${r}" is not registered`,{path:r})}try{return await new Promise((u,c)=>{let d=!1,g=!1,f,p,l=!1,b=m=>{g||(g=!0,f!==void 0&&clearTimeout(f),p!==void 0?(p(),p=void 0):l=!0,m())};p=a.subscribe(m=>{for(let _ of m){if(g)return;if(d){if(_[0]===F){b(()=>u(_[1]));return}if(_[0]===Z){let v=a.cache;b(()=>u(v));return}if(_[0]===G){let v=_[1],h=v instanceof Error?v.message:String(v),y=v instanceof Error?v:void 0;b(()=>c(new C("internal-error",`reduce: output emitted ERROR: ${h}`,y!=null?{cause:y}:void 0)));return}if(_[0]===H){b(()=>c(new C("internal-error","reduce: output COMPLETEd without a post-push DATA")));return}}}}),l&&(p?.(),p=void 0),d=!0;try{i.set(r,e)}catch(m){let _=m instanceof Error?m.message:String(m),v=m instanceof Error?m:void 0;b(()=>c(new C("internal-error",`reduce: failed to set input on "${r}": ${_}`,v!=null?{path:r,cause:v}:{path:r})));return}!g&&Number.isFinite(s)&&s>0&&(f=setTimeout(()=>{b(()=>c(new C("reduce-timeout",`reduce: no output emitted within ${s}ms`,{timeoutMs:s,outputPath:o})))},s),f.unref?.())})}finally{i.destroy()}}Ge();Ot();var Et=de,Pe="snapshot:";function je(n){if(n.startsWith(Pe))throw new C("snapshot-failed",`snapshot id must not start with "${Pe}" (reserved); got "${n}"`,{snapshotId:n})}function nt(n){return`${Pe}${n}`}function Tr(n){return n.startsWith(Pe)?n.slice(Pe.length):void 0}function Rt(n,e){if(n==null||typeof n!="object")throw new C("snapshot-not-found",`snapshot "${e}" not found in tier`,{snapshotId:e});let t=n;if("mode"in t){if(t.mode==="full"&&"snapshot"in t)return t.snapshot;throw t.mode==="diff"?new C("restore-failed",`snapshot "${e}" is a diff record; restore the baseline and replay WAL instead`,{snapshotId:e,mode:"diff"}):new C("restore-failed",`snapshot "${e}" has unknown mode "${String(t.mode)}"`,{snapshotId:e,mode:String(t.mode)})}if("nodes"in t&&"edges"in t&&"subgraphs"in t&&"name"in t)return t;throw new C("restore-failed",`snapshot "${e}" payload is not a GraphCheckpointRecord or GraphPersistSnapshot`,{snapshotId:e})}async function Cn(n,e,t){je(e);let r;try{r=n.snapshot()}catch(s){let i=s instanceof Error?s.message:String(s);throw new C("snapshot-failed",`snapshot "${e}" serialization failed: ${i}`,{snapshotId:e})}let o={name:n.name,mode:"full",seq:0,timestamp_ns:Se(),format_version:Et,snapshot:r};try{await t.save(nt(e),o)}catch(s){let i=s instanceof Error?s.message:String(s);throw new C("snapshot-failed",`snapshot "${e}" save failed: ${i}`,{snapshotId:e})}return{snapshotId:e,timestamp_ns:o.timestamp_ns}}async function Dn(n,e,t){je(n);let r=nt(n),o=await e.load(r);o===void 0&&(o=await e.load(n));let s=Rt(o,n);try{return ae.fromSnapshot(s,t?.factories?{factories:t.factories}:void 0)}catch(i){let a=i instanceof Error?i.message:String(i);throw new C("restore-failed",`snapshot "${n}" restore failed: ${a}`,{snapshotId:n})}}async function Gn(n,e,t){je(n),je(e);let r=async u=>{let c=nt(u),d=await t.load(c);return d===void 0&&(d=await t.load(u)),d},[o,s]=await Promise.all([r(n),r(e)]),i=Rt(o,n),a=Rt(s,e);return ae.diff(i,a)}async function Mn(n,e){if(typeof n.list!="function")throw new C("tier-no-list","KvStorageTier does not implement list(); wrap the tier with an enumerator or use a different backend");let t=await n.list(),r=[],o=e?.includeUnprefixed===!0;for(let s of t){let i=Tr(s);i!==void 0?r.push(i):o&&r.push(s)}return r}async function $n(n,e){if(je(n),typeof e.delete!="function")throw new C("snapshot-failed",`KvStorageTier is append-only (no delete()); cannot delete "${n}"`,{snapshotId:n});try{await e.delete(nt(n))}catch(t){let r=t instanceof Error?t.message:String(t);throw new C("snapshot-failed",`snapshot "${n}" delete failed: ${r}`,{snapshotId:n})}}0&&(module.exports={SNAPSHOT_WIRE_VERSION,SurfaceError,asSurfaceError,createGraph,deleteSnapshot,diffSnapshots,listSnapshots,restoreSnapshot,runReduction,saveSnapshot});
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/surface/index.ts
18
+ var surface_exports = {};
19
+ module.exports = __toCommonJS(surface_exports);
20
+ __reExport(surface_exports, require("@graphrefly/pure-ts/patterns/surface"), module.exports);
21
+ //# sourceMappingURL=index.cjs.map
@@ -0,0 +1 @@
1
+ {"version":3,"sources":["../../../src/patterns/surface/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/surface\";\n"],"mappings":";;;;;;;;;;;;;;;;;AAAA;AAAA;AAEA,4BAAc,iDAFd;","names":[]}
@@ -1,9 +1 @@
1
- export { C as CatalogFnEntry, a as CatalogSourceEntry, b as ConfigFieldSchema, F as FnFactory, G as GraphSpec, c as GraphSpecCatalog, d as GraphSpecFeedbackEdge, e as GraphSpecNode, f as GraphSpecTemplate, g as GraphSpecTemplateRef, h as GraphSpecValidation, S as SourceFactory } from '../../index-Du7u1lSf.cjs';
2
- export { C as CreateGraphOptions, R as ReduceOptions, a as RestoreSnapshotOptions, S as SNAPSHOT_WIRE_VERSION, b as SaveSnapshotResult, c as SurfaceError, d as SurfaceErrorCode, e as SurfaceErrorPayload, f as asSurfaceError, g as createGraph, h as deleteSnapshot, i as diffSnapshots, l as listSnapshots, r as restoreSnapshot, j as runReduction, s as saveSnapshot } from '../../index-Bc41FuHp.cjs';
3
- import '../../meta-vE8bxW1E.cjs';
4
- import '../../node-ClS5yC-B.cjs';
5
- import '../../graph-C4SHb3Ly.cjs';
6
- import '../../extra/storage-core.cjs';
7
- import '../../extra/storage-tiers.cjs';
8
- import '../../types-B1jDWVsM.cjs';
9
- import '../../extra/sources.cjs';
1
+ export * from '@graphrefly/pure-ts/patterns/surface';
@@ -1,9 +1 @@
1
- export { C as CatalogFnEntry, a as CatalogSourceEntry, b as ConfigFieldSchema, F as FnFactory, G as GraphSpec, c as GraphSpecCatalog, d as GraphSpecFeedbackEdge, e as GraphSpecNode, f as GraphSpecTemplate, g as GraphSpecTemplateRef, h as GraphSpecValidation, S as SourceFactory } from '../../index-BP8a88zx.js';
2
- export { C as CreateGraphOptions, R as ReduceOptions, a as RestoreSnapshotOptions, S as SNAPSHOT_WIRE_VERSION, b as SaveSnapshotResult, c as SurfaceError, d as SurfaceErrorCode, e as SurfaceErrorPayload, f as asSurfaceError, g as createGraph, h as deleteSnapshot, i as diffSnapshots, l as listSnapshots, r as restoreSnapshot, j as runReduction, s as saveSnapshot } from '../../index-BsT7F2et.js';
3
- import '../../meta-BgVAsg9j.js';
4
- import '../../node-ClS5yC-B.js';
5
- import '../../graph-7VguS7a4.js';
6
- import '../../extra/storage-core.js';
7
- import '../../extra/storage-tiers.js';
8
- import '../../types-DkzUUs0H.js';
9
- import '../../extra/sources.js';
1
+ export * from '@graphrefly/pure-ts/patterns/surface';
@@ -1 +1,3 @@
1
- import{a,b,c,d,e,f,g,h,i,j}from"../../chunk-P6C4WHZO.js";import"../../chunk-Y4NI3X7O.js";import"../../chunk-CUNIRONA.js";import"../../chunk-FDQGFWLF.js";import"../../chunk-L6NSJVJZ.js";import"../../chunk-626TESAC.js";import"../../chunk-ESMPEKEV.js";import"../../chunk-VOPGGIL7.js";import"../../chunk-4VVTGLXJ.js";import"../../chunk-35JTVPOX.js";import"../../chunk-JQFH2DV6.js";import"../../chunk-V5A7M7RJ.js";import"../../chunk-LYCLF26R.js";import"../../chunk-CK2E7BTU.js";import"../../chunk-QYADASLV.js";export{e as SNAPSHOT_WIRE_VERSION,a as SurfaceError,b as asSurfaceError,c as createGraph,j as deleteSnapshot,h as diffSnapshots,i as listSnapshots,g as restoreSnapshot,d as runReduction,f as saveSnapshot};
1
+ // src/patterns/surface/index.ts
2
+ export * from "@graphrefly/pure-ts/patterns/surface";
3
+ //# sourceMappingURL=index.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"sources":["../../../src/patterns/surface/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/surface\";\n"],"mappings":";AAEA,cAAc;","names":[]}