@graphrefly/graphrefly 0.44.0 → 0.46.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 (720) hide show
  1. package/README.md +22 -19
  2. package/dist/_internal-B23BagFd.d.cts +33 -0
  3. package/dist/_internal-B23BagFd.d.ts +33 -0
  4. package/dist/adaptive-rate-limiter-Dch_xYIi.d.cts +111 -0
  5. package/dist/adaptive-rate-limiter-Dch_xYIi.d.ts +111 -0
  6. package/dist/agents-C0Ji9ldU.d.cts +629 -0
  7. package/dist/agents-C9zexT7I.d.ts +629 -0
  8. package/dist/audit-BAXb3VOg.d.ts +246 -0
  9. package/dist/audit-C_bPfkqS.d.cts +246 -0
  10. package/dist/backoff-7KIK3WQW.js +24 -0
  11. package/dist/backoff-7KIK3WQW.js.map +1 -0
  12. package/dist/backoff-Bnb9OoPh.d.cts +6 -0
  13. package/dist/backoff-Bnb9OoPh.d.ts +6 -0
  14. package/dist/base/composition/index.cjs +811 -0
  15. package/dist/base/composition/index.cjs.map +1 -0
  16. package/dist/base/composition/index.d.cts +469 -0
  17. package/dist/base/composition/index.d.ts +469 -0
  18. package/dist/base/composition/index.js +40 -0
  19. package/dist/base/composition/index.js.map +1 -0
  20. package/dist/base/index.cjs +6336 -0
  21. package/dist/base/index.cjs.map +1 -0
  22. package/dist/base/index.d.cts +22 -0
  23. package/dist/base/index.d.ts +22 -0
  24. package/dist/base/index.js +259 -0
  25. package/dist/base/index.js.map +1 -0
  26. package/dist/base/io/index.cjs +3270 -0
  27. package/dist/base/io/index.cjs.map +1 -0
  28. package/dist/base/io/index.d.cts +2245 -0
  29. package/dist/base/io/index.d.ts +2245 -0
  30. package/dist/base/io/index.js +117 -0
  31. package/dist/base/io/index.js.map +1 -0
  32. package/dist/base/meta/index.cjs +43 -0
  33. package/dist/base/meta/index.cjs.map +1 -0
  34. package/dist/base/meta/index.d.cts +45 -0
  35. package/dist/base/meta/index.d.ts +45 -0
  36. package/dist/base/meta/index.js +13 -0
  37. package/dist/base/meta/index.js.map +1 -0
  38. package/dist/base/mutation/index.cjs +200 -0
  39. package/dist/base/mutation/index.cjs.map +1 -0
  40. package/dist/base/mutation/index.d.cts +177 -0
  41. package/dist/base/mutation/index.d.ts +177 -0
  42. package/dist/base/mutation/index.js +22 -0
  43. package/dist/base/mutation/index.js.map +1 -0
  44. package/dist/base/render/index.cjs +1120 -0
  45. package/dist/base/render/index.cjs.map +1 -0
  46. package/dist/{extra/render/index.d.ts → base/render/index.d.cts} +75 -31
  47. package/dist/{extra/render/index.d.cts → base/render/index.d.ts} +75 -31
  48. package/dist/base/render/index.js +24 -0
  49. package/dist/base/render/index.js.map +1 -0
  50. package/dist/base/sources/browser/index.cjs +172 -0
  51. package/dist/base/sources/browser/index.cjs.map +1 -0
  52. package/dist/base/sources/browser/index.d.cts +84 -0
  53. package/dist/base/sources/browser/index.d.ts +84 -0
  54. package/dist/base/sources/browser/index.js +151 -0
  55. package/dist/base/sources/browser/index.js.map +1 -0
  56. package/dist/base/sources/event/index.cjs +98 -0
  57. package/dist/base/sources/event/index.cjs.map +1 -0
  58. package/dist/base/sources/event/index.d.cts +91 -0
  59. package/dist/base/sources/event/index.d.ts +91 -0
  60. package/dist/base/sources/event/index.js +13 -0
  61. package/dist/base/sources/event/index.js.map +1 -0
  62. package/dist/base/sources/index.cjs +755 -0
  63. package/dist/base/sources/index.cjs.map +1 -0
  64. package/dist/{extra/sources.d.ts → base/sources/index.d.cts} +74 -301
  65. package/dist/{extra/sources.d.cts → base/sources/index.d.ts} +74 -301
  66. package/dist/base/sources/index.js +42 -0
  67. package/dist/base/sources/index.js.map +1 -0
  68. package/dist/base/sources/node/index.cjs +320 -0
  69. package/dist/base/sources/node/index.cjs.map +1 -0
  70. package/dist/{extra/node.d.ts → base/sources/node/index.d.cts} +35 -37
  71. package/dist/{extra/node.d.cts → base/sources/node/index.d.ts} +35 -37
  72. package/dist/base/sources/node/index.js +306 -0
  73. package/dist/base/sources/node/index.js.map +1 -0
  74. package/dist/base/utils/index.cjs +37 -0
  75. package/dist/base/utils/index.cjs.map +1 -0
  76. package/dist/base/utils/index.d.cts +37 -0
  77. package/dist/base/utils/index.d.ts +37 -0
  78. package/dist/base/utils/index.js +11 -0
  79. package/dist/base/utils/index.js.map +1 -0
  80. package/dist/base/worker/index.cjs +548 -0
  81. package/dist/base/worker/index.cjs.map +1 -0
  82. package/dist/base/worker/index.d.cts +207 -0
  83. package/dist/base/worker/index.d.ts +207 -0
  84. package/dist/base/worker/index.js +20 -0
  85. package/dist/base/worker/index.js.map +1 -0
  86. package/dist/breaker-C9skL3d8.d.ts +175 -0
  87. package/dist/breaker-ugSdq54q.d.cts +175 -0
  88. package/dist/{cascading-BglDkMdX.d.cts → cascading-CSSbKGrJ.d.ts} +3 -3
  89. package/dist/{cascading-MFgxu7Yo.d.ts → cascading-baGkiihI.d.cts} +3 -3
  90. package/dist/chunk-255UCBG4.js +58 -0
  91. package/dist/chunk-255UCBG4.js.map +1 -0
  92. package/dist/chunk-2LO3EL4W.js +1 -0
  93. package/dist/chunk-2LO3EL4W.js.map +1 -0
  94. package/dist/chunk-2OB3CEJS.js +1065 -0
  95. package/dist/chunk-2OB3CEJS.js.map +1 -0
  96. package/dist/chunk-36NMM65U.js +144 -0
  97. package/dist/chunk-36NMM65U.js.map +1 -0
  98. package/dist/chunk-3CEXCBN6.js +1 -0
  99. package/dist/chunk-3CEXCBN6.js.map +1 -0
  100. package/dist/chunk-3MUSLI6E.js +105 -0
  101. package/dist/chunk-3MUSLI6E.js.map +1 -0
  102. package/dist/chunk-3PSLNJDU.js +884 -0
  103. package/dist/chunk-3PSLNJDU.js.map +1 -0
  104. package/dist/chunk-3QZY5BI7.js +92 -0
  105. package/dist/chunk-3QZY5BI7.js.map +1 -0
  106. package/dist/chunk-42FQ27MQ.js +594 -0
  107. package/dist/chunk-42FQ27MQ.js.map +1 -0
  108. package/dist/chunk-4GYMCUDZ.js +1085 -0
  109. package/dist/chunk-4GYMCUDZ.js.map +1 -0
  110. package/dist/chunk-4S53H2KR.js +382 -0
  111. package/dist/chunk-4S53H2KR.js.map +1 -0
  112. package/dist/chunk-4XCHZRUJ.js +128 -0
  113. package/dist/chunk-4XCHZRUJ.js.map +1 -0
  114. package/dist/chunk-5THCXDWY.js +725 -0
  115. package/dist/chunk-5THCXDWY.js.map +1 -0
  116. package/dist/chunk-6XZYT4SW.js +256 -0
  117. package/dist/chunk-6XZYT4SW.js.map +1 -0
  118. package/dist/chunk-7EGRP2VX.js +76 -0
  119. package/dist/chunk-7EGRP2VX.js.map +1 -0
  120. package/dist/chunk-A7KV5UK4.js +150 -0
  121. package/dist/chunk-A7KV5UK4.js.map +1 -0
  122. package/dist/chunk-APY2SS5X.js +156 -0
  123. package/dist/chunk-APY2SS5X.js.map +1 -0
  124. package/dist/chunk-AZDQPQ3V.js +66 -0
  125. package/dist/chunk-AZDQPQ3V.js.map +1 -0
  126. package/dist/chunk-BU3SEFA5.js +90 -0
  127. package/dist/chunk-BU3SEFA5.js.map +1 -0
  128. package/dist/chunk-BXGZFGZ4.js +189 -0
  129. package/dist/chunk-BXGZFGZ4.js.map +1 -0
  130. package/dist/chunk-CGHORL6G.js +579 -0
  131. package/dist/chunk-CGHORL6G.js.map +1 -0
  132. package/dist/chunk-CXANAIZU.js +530 -0
  133. package/dist/chunk-CXANAIZU.js.map +1 -0
  134. package/dist/chunk-CZQHCKKG.js +1 -0
  135. package/dist/chunk-CZQHCKKG.js.map +1 -0
  136. package/dist/chunk-DKNHAICT.js +133 -0
  137. package/dist/chunk-DKNHAICT.js.map +1 -0
  138. package/dist/chunk-DM4OMPWK.js +584 -0
  139. package/dist/chunk-DM4OMPWK.js.map +1 -0
  140. package/dist/chunk-DMSNO6ZB.js +452 -0
  141. package/dist/chunk-DMSNO6ZB.js.map +1 -0
  142. package/dist/chunk-E5OZPDIW.js +229 -0
  143. package/dist/chunk-E5OZPDIW.js.map +1 -0
  144. package/dist/chunk-EVYY4X5A.js +509 -0
  145. package/dist/chunk-EVYY4X5A.js.map +1 -0
  146. package/dist/chunk-FDFD67UO.js +1 -0
  147. package/dist/chunk-FDFD67UO.js.map +1 -0
  148. package/dist/chunk-FMPF42Q4.js +13 -0
  149. package/dist/chunk-FMPF42Q4.js.map +1 -0
  150. package/dist/chunk-FR6RGA3B.js +1277 -0
  151. package/dist/chunk-FR6RGA3B.js.map +1 -0
  152. package/dist/chunk-FW23JYNQ.js +454 -0
  153. package/dist/chunk-FW23JYNQ.js.map +1 -0
  154. package/dist/chunk-GBCENOLN.js +1575 -0
  155. package/dist/chunk-GBCENOLN.js.map +1 -0
  156. package/dist/chunk-HL7HUJIX.js +1 -0
  157. package/dist/chunk-HL7HUJIX.js.map +1 -0
  158. package/dist/chunk-HULCUY35.js +2508 -0
  159. package/dist/chunk-HULCUY35.js.map +1 -0
  160. package/dist/chunk-IHTWQEDR.js +169 -0
  161. package/dist/chunk-IHTWQEDR.js.map +1 -0
  162. package/dist/chunk-IJRR6YAI.js +128 -0
  163. package/dist/chunk-IJRR6YAI.js.map +1 -0
  164. package/dist/chunk-JGFRAFDL.js +221 -0
  165. package/dist/chunk-JGFRAFDL.js.map +1 -0
  166. package/dist/chunk-KIIXR252.js +211 -0
  167. package/dist/chunk-KIIXR252.js.map +1 -0
  168. package/dist/chunk-KN3H5CNT.js +11 -0
  169. package/dist/chunk-KN3H5CNT.js.map +1 -0
  170. package/dist/chunk-KPG3DGLA.js +1 -0
  171. package/dist/chunk-KPG3DGLA.js.map +1 -0
  172. package/dist/chunk-KRNQ6RGQ.js +1 -0
  173. package/dist/chunk-KRNQ6RGQ.js.map +1 -0
  174. package/dist/chunk-LBAJK24K.js +1071 -0
  175. package/dist/chunk-LBAJK24K.js.map +1 -0
  176. package/dist/chunk-MLTPJMH6.js +417 -0
  177. package/dist/chunk-MLTPJMH6.js.map +1 -0
  178. package/dist/chunk-N3SZ7BMH.js +95 -0
  179. package/dist/chunk-N3SZ7BMH.js.map +1 -0
  180. package/dist/chunk-NDUD3IMO.js +540 -0
  181. package/dist/chunk-NDUD3IMO.js.map +1 -0
  182. package/dist/chunk-NY2PYHNC.js +873 -0
  183. package/dist/chunk-NY2PYHNC.js.map +1 -0
  184. package/dist/chunk-O3MT7DYI.js +225 -0
  185. package/dist/chunk-O3MT7DYI.js.map +1 -0
  186. package/dist/chunk-OCUDSN63.js +2386 -0
  187. package/dist/chunk-OCUDSN63.js.map +1 -0
  188. package/dist/chunk-OIWU3NYV.js +199 -0
  189. package/dist/chunk-OIWU3NYV.js.map +1 -0
  190. package/dist/chunk-OO5BM6CJ.js +1153 -0
  191. package/dist/chunk-OO5BM6CJ.js.map +1 -0
  192. package/dist/chunk-OQUIJT7A.js +1 -0
  193. package/dist/chunk-OQUIJT7A.js.map +1 -0
  194. package/dist/chunk-P5LBT622.js +105 -0
  195. package/dist/chunk-P5LBT622.js.map +1 -0
  196. package/dist/chunk-PKGQG5QQ.js +519 -0
  197. package/dist/chunk-PKGQG5QQ.js.map +1 -0
  198. package/dist/chunk-PKPO3JTZ.js +561 -0
  199. package/dist/chunk-PKPO3JTZ.js.map +1 -0
  200. package/dist/chunk-PL5UDIQ5.js +118 -0
  201. package/dist/chunk-PL5UDIQ5.js.map +1 -0
  202. package/dist/chunk-PZWISPIQ.js +432 -0
  203. package/dist/chunk-PZWISPIQ.js.map +1 -0
  204. package/dist/chunk-Q3EYOCZB.js +510 -0
  205. package/dist/chunk-Q3EYOCZB.js.map +1 -0
  206. package/dist/chunk-QMBYUVRL.js +15 -0
  207. package/dist/chunk-QMBYUVRL.js.map +1 -0
  208. package/dist/chunk-RAGGHLCV.js +200 -0
  209. package/dist/chunk-RAGGHLCV.js.map +1 -0
  210. package/dist/chunk-RGL53X5G.js +574 -0
  211. package/dist/chunk-RGL53X5G.js.map +1 -0
  212. package/dist/chunk-RJOG4IJU.js +1039 -0
  213. package/dist/chunk-RJOG4IJU.js.map +1 -0
  214. package/dist/chunk-SOOKUYVM.js +403 -0
  215. package/dist/chunk-SOOKUYVM.js.map +1 -0
  216. package/dist/chunk-T5BN5KG7.js +1 -0
  217. package/dist/chunk-T5BN5KG7.js.map +1 -0
  218. package/dist/chunk-TP7244Y6.js +207 -0
  219. package/dist/chunk-TP7244Y6.js.map +1 -0
  220. package/dist/chunk-TSBFTJKM.js +57 -0
  221. package/dist/chunk-TSBFTJKM.js.map +1 -0
  222. package/dist/chunk-URQ2CBBF.js +143 -0
  223. package/dist/chunk-URQ2CBBF.js.map +1 -0
  224. package/dist/chunk-W2BOPXTI.js +1 -0
  225. package/dist/chunk-W2BOPXTI.js.map +1 -0
  226. package/dist/chunk-WKSWLSCX.js +207 -0
  227. package/dist/chunk-WKSWLSCX.js.map +1 -0
  228. package/dist/chunk-Y52CS6YA.js +88 -0
  229. package/dist/chunk-Y52CS6YA.js.map +1 -0
  230. package/dist/chunk-YCBUWK77.js +92 -0
  231. package/dist/chunk-YCBUWK77.js.map +1 -0
  232. package/dist/chunk-YJ4U2D2C.js +314 -0
  233. package/dist/chunk-YJ4U2D2C.js.map +1 -0
  234. package/dist/chunk-Z4YXAUDN.js +239 -0
  235. package/dist/chunk-Z4YXAUDN.js.map +1 -0
  236. package/dist/chunk-Z6EGP5D7.js +92 -0
  237. package/dist/chunk-Z6EGP5D7.js.map +1 -0
  238. package/dist/compat/index.cjs +3100 -9
  239. package/dist/compat/index.cjs.map +1 -0
  240. package/dist/compat/index.d.cts +112 -18
  241. package/dist/compat/index.d.ts +112 -18
  242. package/dist/compat/index.js +176 -1
  243. package/dist/compat/index.js.map +1 -0
  244. package/dist/compat/jotai/index.cjs +149 -1
  245. package/dist/compat/jotai/index.cjs.map +1 -0
  246. package/dist/compat/jotai/index.d.cts +2 -2
  247. package/dist/compat/jotai/index.d.ts +2 -2
  248. package/dist/compat/jotai/index.js +8 -1
  249. package/dist/compat/jotai/index.js.map +1 -0
  250. package/dist/compat/nanostores/index.cjs +205 -1
  251. package/dist/compat/nanostores/index.cjs.map +1 -0
  252. package/dist/compat/nanostores/index.d.cts +2 -2
  253. package/dist/compat/nanostores/index.d.ts +2 -2
  254. package/dist/compat/nanostores/index.js +22 -1
  255. package/dist/compat/nanostores/index.js.map +1 -0
  256. package/dist/compat/nestjs/index.cjs +2241 -9
  257. package/dist/compat/nestjs/index.cjs.map +1 -0
  258. package/dist/compat/nestjs/index.d.cts +7 -10
  259. package/dist/compat/nestjs/index.d.ts +7 -10
  260. package/dist/compat/nestjs/index.js +78 -1
  261. package/dist/compat/nestjs/index.js.map +1 -0
  262. package/dist/compat/react/index.cjs +114 -1
  263. package/dist/compat/react/index.cjs.map +1 -0
  264. package/dist/compat/react/index.d.cts +2 -2
  265. package/dist/compat/react/index.d.ts +2 -2
  266. package/dist/compat/react/index.js +12 -1
  267. package/dist/compat/react/index.js.map +1 -0
  268. package/dist/compat/solid/index.cjs +101 -1
  269. package/dist/compat/solid/index.cjs.map +1 -0
  270. package/dist/compat/solid/index.d.cts +2 -2
  271. package/dist/compat/solid/index.d.ts +2 -2
  272. package/dist/compat/solid/index.js +12 -1
  273. package/dist/compat/solid/index.js.map +1 -0
  274. package/dist/compat/svelte/index.cjs +104 -1
  275. package/dist/compat/svelte/index.cjs.map +1 -0
  276. package/dist/compat/svelte/index.d.cts +2 -2
  277. package/dist/compat/svelte/index.d.ts +2 -2
  278. package/dist/compat/svelte/index.js +12 -1
  279. package/dist/compat/svelte/index.js.map +1 -0
  280. package/dist/compat/vue/index.cjs +119 -1
  281. package/dist/compat/vue/index.cjs.map +1 -0
  282. package/dist/compat/vue/index.d.cts +2 -2
  283. package/dist/compat/vue/index.d.ts +2 -2
  284. package/dist/compat/vue/index.js +12 -1
  285. package/dist/compat/vue/index.js.map +1 -0
  286. package/dist/compat/zustand/index.cjs +69 -3
  287. package/dist/compat/zustand/index.cjs.map +1 -0
  288. package/dist/compat/zustand/index.d.cts +2 -6
  289. package/dist/compat/zustand/index.d.ts +2 -6
  290. package/dist/compat/zustand/index.js +8 -1
  291. package/dist/compat/zustand/index.js.map +1 -0
  292. package/dist/distill-De6Rnn15.d.cts +48 -0
  293. package/dist/distill-De6Rnn15.d.ts +48 -0
  294. package/dist/external-register-CWyroXb_.d.cts +138 -0
  295. package/dist/external-register-CWyroXb_.d.ts +138 -0
  296. package/dist/{fallback-74oxi34l.d.cts → fallback-Bx46zqky.d.cts} +3 -10
  297. package/dist/{fallback-DUyyBTBK.d.ts → fallback-pIWW8A2d.d.ts} +3 -10
  298. package/dist/guarded-execution-BcdtxeBk.d.ts +207 -0
  299. package/dist/guarded-execution-C-3hnP6A.d.cts +207 -0
  300. package/dist/{index-CBGUK09R.d.ts → index-5SU_O78r.d.cts} +5 -5
  301. package/dist/{index-BmZXHqkE.d.ts → index-B6pxYJzO.d.cts} +1 -1
  302. package/dist/{index-hcDJ8PSI.d.cts → index-B6pxYJzO.d.ts} +1 -1
  303. package/dist/{index-C5stwKcw.d.cts → index-BFsng6v1.d.cts} +1 -1
  304. package/dist/{index-CdAlHFEt.d.ts → index-BFsng6v1.d.ts} +1 -1
  305. package/dist/{index-_6ODbuOu.d.cts → index-Bg-LwEt-.d.cts} +1 -1
  306. package/dist/{index-CviRnE4K.d.ts → index-Bg-LwEt-.d.ts} +1 -1
  307. package/dist/{index-CBBLl_rc.d.ts → index-Brp888t0.d.cts} +1 -1
  308. package/dist/{index-BQSKmbuG.d.cts → index-Brp888t0.d.ts} +1 -1
  309. package/dist/{index-sqkqlb1p.d.ts → index-CDfk6jHN.d.cts} +1 -1
  310. package/dist/{index-ZVQhLa2i.d.cts → index-CDfk6jHN.d.ts} +1 -1
  311. package/dist/{index-Climxqsu.d.cts → index-CEXCtYYJ.d.ts} +5 -5
  312. package/dist/index-DLAxYaN5.d.cts +169 -0
  313. package/dist/index-DLAxYaN5.d.ts +169 -0
  314. package/dist/{index-CK29LV56.d.cts → index-DeWbQzMe.d.cts} +1 -1
  315. package/dist/{index-CPQlGA29.d.ts → index-DeWbQzMe.d.ts} +1 -1
  316. package/dist/{index-BrPrLl4e.d.cts → index-dX9IzPqj.d.cts} +1 -1
  317. package/dist/{index-Dgl1HpPn.d.ts → index-dX9IzPqj.d.ts} +1 -1
  318. package/dist/index.cjs +25934 -191
  319. package/dist/index.cjs.map +1 -0
  320. package/dist/index.d.cts +58 -94
  321. package/dist/index.d.ts +58 -94
  322. package/dist/index.js +852 -1
  323. package/dist/index.js.map +1 -0
  324. package/dist/layout-types-B5aiHYgk.d.cts +72 -0
  325. package/dist/layout-types-B5aiHYgk.d.ts +72 -0
  326. package/dist/memory-composers-BryDrRBX.d.cts +529 -0
  327. package/dist/memory-composers-CVQqPYEV.d.ts +529 -0
  328. package/dist/{observable-DWjNfLvC.d.ts → observable-BXQoW1P-.d.cts} +1 -1
  329. package/dist/{observable-e3eiPPFy.d.cts → observable-BXQoW1P-.d.ts} +1 -1
  330. package/dist/{pipeline-graph-Sgj0gCwn.d.ts → pipeline-graph-Ce47CB6Y.d.cts} +13 -10
  331. package/dist/{pipeline-graph-CIKhynsF.d.cts → pipeline-graph-DXCwY9vG.d.ts} +13 -10
  332. package/dist/presets/ai/index.cjs +4377 -0
  333. package/dist/presets/ai/index.cjs.map +1 -0
  334. package/dist/presets/ai/index.d.cts +98 -0
  335. package/dist/presets/ai/index.d.ts +98 -0
  336. package/dist/presets/ai/index.js +54 -0
  337. package/dist/presets/ai/index.js.map +1 -0
  338. package/dist/presets/harness/index.cjs +5929 -0
  339. package/dist/presets/harness/index.cjs.map +1 -0
  340. package/dist/presets/harness/index.d.cts +566 -0
  341. package/dist/presets/harness/index.d.ts +566 -0
  342. package/dist/presets/harness/index.js +71 -0
  343. package/dist/presets/harness/index.js.map +1 -0
  344. package/dist/presets/index.cjs +9782 -0
  345. package/dist/presets/index.cjs.map +1 -0
  346. package/dist/presets/index.d.cts +28 -0
  347. package/dist/presets/index.d.ts +28 -0
  348. package/dist/presets/index.js +129 -0
  349. package/dist/presets/index.js.map +1 -0
  350. package/dist/presets/inspect/index.cjs +1087 -0
  351. package/dist/presets/inspect/index.cjs.map +1 -0
  352. package/dist/presets/inspect/index.d.cts +172 -0
  353. package/dist/presets/inspect/index.d.ts +172 -0
  354. package/dist/presets/inspect/index.js +21 -0
  355. package/dist/presets/inspect/index.js.map +1 -0
  356. package/dist/presets/resilience/index.cjs +1593 -0
  357. package/dist/presets/resilience/index.cjs.map +1 -0
  358. package/dist/presets/resilience/index.d.cts +205 -0
  359. package/dist/presets/resilience/index.d.ts +205 -0
  360. package/dist/presets/resilience/index.js +18 -0
  361. package/dist/presets/resilience/index.js.map +1 -0
  362. package/dist/rate-limiter-CEALq4N1.d.ts +559 -0
  363. package/dist/rate-limiter-DpVbSYdH.d.cts +559 -0
  364. package/dist/{reactive-layout-DOTs9P3X.d.ts → reactive-layout-fswlBUvX.d.cts} +19 -7
  365. package/dist/{reactive-layout-DgctbqZo.d.cts → reactive-layout-fswlBUvX.d.ts} +19 -7
  366. package/dist/retry-BDbRZ_gx.d.ts +125 -0
  367. package/dist/retry-DWuhjvsA.d.cts +125 -0
  368. package/dist/solutions/index.cjs +8200 -0
  369. package/dist/solutions/index.cjs.map +1 -0
  370. package/dist/solutions/index.d.cts +23 -0
  371. package/dist/solutions/index.d.ts +23 -0
  372. package/dist/solutions/index.js +55 -0
  373. package/dist/solutions/index.js.map +1 -0
  374. package/dist/spawnable-5mDY501F.d.cts +746 -0
  375. package/dist/spawnable-D3lR0oQu.d.ts +746 -0
  376. package/dist/status-U-rUI79b.d.cts +84 -0
  377. package/dist/status-U-rUI79b.d.ts +84 -0
  378. package/dist/timeout-U5O4ESK3.js +12 -0
  379. package/dist/timeout-U5O4ESK3.js.map +1 -0
  380. package/dist/{types-CWFysE9E.d.ts → types-BB5Lw-pB.d.cts} +3 -3
  381. package/dist/{types-C0_yquda.d.cts → types-BB5Lw-pB.d.ts} +3 -3
  382. package/dist/types-CJWIMJiZ.d.ts +548 -0
  383. package/dist/types-vCq7ShIm.d.cts +548 -0
  384. package/dist/utils/ai/browser.cjs +2169 -0
  385. package/dist/utils/ai/browser.cjs.map +1 -0
  386. package/dist/{patterns → utils}/ai/browser.d.cts +7 -5
  387. package/dist/{patterns → utils}/ai/browser.d.ts +7 -5
  388. package/dist/utils/ai/browser.js +255 -0
  389. package/dist/utils/ai/browser.js.map +1 -0
  390. package/dist/utils/ai/index.cjs +8468 -0
  391. package/dist/utils/ai/index.cjs.map +1 -0
  392. package/dist/{index-CR8QpwX8.d.ts → utils/ai/index.d.cts} +73 -976
  393. package/dist/{index-UPSiS-X7.d.cts → utils/ai/index.d.ts} +73 -976
  394. package/dist/utils/ai/index.js +173 -0
  395. package/dist/utils/ai/index.js.map +1 -0
  396. package/dist/utils/ai/node.cjs +648 -0
  397. package/dist/utils/ai/node.cjs.map +1 -0
  398. package/dist/{patterns → utils}/ai/node.d.cts +5 -7
  399. package/dist/{patterns → utils}/ai/node.d.ts +5 -7
  400. package/dist/utils/ai/node.js +84 -0
  401. package/dist/utils/ai/node.js.map +1 -0
  402. package/dist/utils/cqrs/index.cjs +1036 -0
  403. package/dist/utils/cqrs/index.cjs.map +1 -0
  404. package/dist/{index-CeFiHtAg.d.ts → utils/cqrs/index.d.cts} +7 -37
  405. package/dist/{index-B-_tFaqV.d.cts → utils/cqrs/index.d.ts} +7 -37
  406. package/dist/utils/cqrs/index.js +18 -0
  407. package/dist/utils/cqrs/index.js.map +1 -0
  408. package/dist/utils/demo-shell/index.cjs +865 -0
  409. package/dist/utils/demo-shell/index.cjs.map +1 -0
  410. package/dist/{index-B8YnZpIR.d.ts → utils/demo-shell/index.d.cts} +4 -16
  411. package/dist/{index-Cwv0KWcU.d.cts → utils/demo-shell/index.d.ts} +4 -16
  412. package/dist/utils/demo-shell/index.js +13 -0
  413. package/dist/utils/demo-shell/index.js.map +1 -0
  414. package/dist/utils/domain-templates/index.cjs +732 -0
  415. package/dist/utils/domain-templates/index.cjs.map +1 -0
  416. package/dist/{index-CzLVrjxn.d.ts → utils/domain-templates/index.d.cts} +3 -20
  417. package/dist/{index-BaQaY_IQ.d.cts → utils/domain-templates/index.d.ts} +3 -20
  418. package/dist/utils/domain-templates/index.js +17 -0
  419. package/dist/utils/domain-templates/index.js.map +1 -0
  420. package/dist/utils/graphspec/index.cjs +1174 -0
  421. package/dist/utils/graphspec/index.cjs.map +1 -0
  422. package/dist/{index-CMh5Rz1y.d.ts → utils/graphspec/index.d.cts} +106 -42
  423. package/dist/{index-CS0LTlB8.d.cts → utils/graphspec/index.d.ts} +106 -42
  424. package/dist/utils/graphspec/index.js +35 -0
  425. package/dist/utils/graphspec/index.js.map +1 -0
  426. package/dist/utils/harness/index.cjs +656 -0
  427. package/dist/utils/harness/index.cjs.map +1 -0
  428. package/dist/utils/harness/index.d.cts +542 -0
  429. package/dist/utils/harness/index.d.ts +542 -0
  430. package/dist/utils/harness/index.js +56 -0
  431. package/dist/utils/harness/index.js.map +1 -0
  432. package/dist/utils/index.cjs +17609 -0
  433. package/dist/utils/index.cjs.map +1 -0
  434. package/dist/utils/index.d.cts +96 -0
  435. package/dist/utils/index.d.ts +96 -0
  436. package/dist/utils/index.js +514 -0
  437. package/dist/utils/index.js.map +1 -0
  438. package/dist/utils/inspect/index.cjs +807 -0
  439. package/dist/utils/inspect/index.cjs.map +1 -0
  440. package/dist/utils/inspect/index.d.cts +123 -0
  441. package/dist/utils/inspect/index.d.ts +123 -0
  442. package/dist/utils/inspect/index.js +30 -0
  443. package/dist/utils/inspect/index.js.map +1 -0
  444. package/dist/utils/job-queue/index.cjs +717 -0
  445. package/dist/utils/job-queue/index.cjs.map +1 -0
  446. package/dist/{index-DisjX8a-.d.ts → utils/job-queue/index.d.cts} +5 -26
  447. package/dist/{index-DV_1YuVk.d.cts → utils/job-queue/index.d.ts} +5 -26
  448. package/dist/utils/job-queue/index.js +18 -0
  449. package/dist/utils/job-queue/index.js.map +1 -0
  450. package/dist/utils/memory/index.cjs +1451 -0
  451. package/dist/utils/memory/index.cjs.map +1 -0
  452. package/dist/{index-CZ3r5Rxp.d.ts → utils/memory/index.d.cts} +242 -34
  453. package/dist/{index-B17QddL1.d.cts → utils/memory/index.d.ts} +242 -34
  454. package/dist/utils/memory/index.js +19 -0
  455. package/dist/utils/memory/index.js.map +1 -0
  456. package/dist/utils/messaging/index.cjs +666 -0
  457. package/dist/utils/messaging/index.cjs.map +1 -0
  458. package/dist/utils/messaging/index.d.cts +562 -0
  459. package/dist/utils/messaging/index.d.ts +562 -0
  460. package/dist/utils/messaging/index.js +50 -0
  461. package/dist/utils/messaging/index.js.map +1 -0
  462. package/dist/utils/orchestration/index.cjs +876 -0
  463. package/dist/utils/orchestration/index.cjs.map +1 -0
  464. package/dist/utils/orchestration/index.d.cts +233 -0
  465. package/dist/utils/orchestration/index.d.ts +233 -0
  466. package/dist/utils/orchestration/index.js +19 -0
  467. package/dist/utils/orchestration/index.js.map +1 -0
  468. package/dist/utils/process/index.cjs +743 -0
  469. package/dist/utils/process/index.cjs.map +1 -0
  470. package/dist/{index-p09KSrTN.d.ts → utils/process/index.d.cts} +97 -44
  471. package/dist/{index-CasX6Pfq.d.cts → utils/process/index.d.ts} +97 -44
  472. package/dist/utils/process/index.js +14 -0
  473. package/dist/utils/process/index.js.map +1 -0
  474. package/dist/utils/reactive-layout/index.cjs +1607 -0
  475. package/dist/utils/reactive-layout/index.cjs.map +1 -0
  476. package/dist/{index-B5S8ULbU.d.ts → utils/reactive-layout/index.d.cts} +58 -81
  477. package/dist/{index-Dc4AYqrJ.d.cts → utils/reactive-layout/index.d.ts} +58 -81
  478. package/dist/utils/reactive-layout/index.js +52 -0
  479. package/dist/utils/reactive-layout/index.js.map +1 -0
  480. package/dist/utils/reduction/index.cjs +203 -0
  481. package/dist/utils/reduction/index.cjs.map +1 -0
  482. package/dist/{index-Byu-OpX_.d.ts → utils/reduction/index.d.cts} +6 -17
  483. package/dist/{index-tRCxuAXF.d.cts → utils/reduction/index.d.ts} +6 -17
  484. package/dist/utils/reduction/index.js +14 -0
  485. package/dist/utils/reduction/index.js.map +1 -0
  486. package/dist/utils/resilience/index.cjs +1617 -0
  487. package/dist/utils/resilience/index.cjs.map +1 -0
  488. package/dist/utils/resilience/index.d.cts +9 -0
  489. package/dist/utils/resilience/index.d.ts +9 -0
  490. package/dist/utils/resilience/index.js +44 -0
  491. package/dist/utils/resilience/index.js.map +1 -0
  492. package/dist/utils/surface/index.cjs +1070 -0
  493. package/dist/utils/surface/index.cjs.map +1 -0
  494. package/dist/{index-CYq8vAyV.d.ts → utils/surface/index.d.cts} +7 -58
  495. package/dist/{index-CSOmP7xT.d.cts → utils/surface/index.d.ts} +7 -58
  496. package/dist/utils/surface/index.js +30 -0
  497. package/dist/utils/surface/index.js.map +1 -0
  498. package/dist/utils/topology-view/index.cjs +620 -0
  499. package/dist/utils/topology-view/index.cjs.map +1 -0
  500. package/dist/utils/topology-view/index.d.cts +68 -0
  501. package/dist/utils/topology-view/index.d.ts +68 -0
  502. package/dist/utils/topology-view/index.js +11 -0
  503. package/dist/utils/topology-view/index.js.map +1 -0
  504. package/package.json +664 -584
  505. package/dist/backoff-HPZMEZNF.js +0 -1
  506. package/dist/chunk-2T7U5EU6.js +0 -1
  507. package/dist/chunk-3G5U5QNE.js +0 -5
  508. package/dist/chunk-4VVTGLXJ.js +0 -1
  509. package/dist/chunk-5M4CCMMD.js +0 -45
  510. package/dist/chunk-5QDBSZBV.js +0 -1
  511. package/dist/chunk-5XJ6B66J.js +0 -1
  512. package/dist/chunk-6QZNQS5B.js +0 -1
  513. package/dist/chunk-6X7AFUJV.js +0 -9
  514. package/dist/chunk-7K6PWTDQ.js +0 -1
  515. package/dist/chunk-7LIAPXJB.js +0 -1
  516. package/dist/chunk-7WPU3UHQ.js +0 -1
  517. package/dist/chunk-A5WCQ5NO.js +0 -1
  518. package/dist/chunk-APPIWSGD.js +0 -84
  519. package/dist/chunk-BEZWM2SY.js +0 -1
  520. package/dist/chunk-C72GO4IZ.js +0 -1
  521. package/dist/chunk-CB676TKJ.js +0 -1
  522. package/dist/chunk-CE6TI2TL.js +0 -1
  523. package/dist/chunk-CE72X3WO.js +0 -1
  524. package/dist/chunk-CK2E7BTU.js +0 -1
  525. package/dist/chunk-CLVB32RD.js +0 -1
  526. package/dist/chunk-CRVT7D2P.js +0 -1
  527. package/dist/chunk-D5RFJOZ2.js +0 -1
  528. package/dist/chunk-D7GPHKFH.js +0 -1
  529. package/dist/chunk-DHRX7JX4.js +0 -2
  530. package/dist/chunk-ESMPEKEV.js +0 -1
  531. package/dist/chunk-F672GV32.js +0 -1
  532. package/dist/chunk-FZMYDOWV.js +0 -1
  533. package/dist/chunk-GHBWHMRZ.js +0 -1
  534. package/dist/chunk-GLERH466.js +0 -1
  535. package/dist/chunk-GPW2V3RE.js +0 -1
  536. package/dist/chunk-HIDYF36O.js +0 -1
  537. package/dist/chunk-HITNVN6B.js +0 -3
  538. package/dist/chunk-HY4DJBA7.js +0 -5
  539. package/dist/chunk-KZIEYVXN.js +0 -1
  540. package/dist/chunk-L6NSJVJZ.js +0 -1
  541. package/dist/chunk-N4MQX6JU.js +0 -18
  542. package/dist/chunk-N7FHEL4D.js +0 -1
  543. package/dist/chunk-NTEURFZH.js +0 -1
  544. package/dist/chunk-OIVP6KFV.js +0 -1
  545. package/dist/chunk-OPHBU3LG.js +0 -1
  546. package/dist/chunk-OYQOZP2F.js +0 -5
  547. package/dist/chunk-PTZK576G.js +0 -1
  548. package/dist/chunk-QYADASLV.js +0 -1
  549. package/dist/chunk-ST7UXLWR.js +0 -1
  550. package/dist/chunk-SVY7VUYU.js +0 -1
  551. package/dist/chunk-TK3NWWD4.js +0 -1
  552. package/dist/chunk-TSOYJ743.js +0 -1
  553. package/dist/chunk-UNGSTR4X.js +0 -61
  554. package/dist/chunk-VIMF6LGM.js +0 -1
  555. package/dist/chunk-VJLMUKOI.js +0 -1
  556. package/dist/chunk-VN6RDSK2.js +0 -1
  557. package/dist/chunk-VV4N5P64.js +0 -1
  558. package/dist/chunk-W3I423PS.js +0 -1
  559. package/dist/chunk-WJR24TAG.js +0 -1
  560. package/dist/chunk-XTGKMHSW.js +0 -1
  561. package/dist/chunk-YBB7ZGTY.js +0 -1
  562. package/dist/chunk-Z4NPUARF.js +0 -1
  563. package/dist/chunk-ZGNQRPDT.js +0 -1
  564. package/dist/chunk-ZKPSFFKU.js +0 -1
  565. package/dist/chunk-ZLV5SQSX.js +0 -1
  566. package/dist/content-addressed-storage-4-ST1tYk.d.cts +0 -124
  567. package/dist/content-addressed-storage-DuYMjV7o.d.ts +0 -124
  568. package/dist/core/index.cjs +0 -1
  569. package/dist/core/index.d.cts +0 -3
  570. package/dist/core/index.d.ts +0 -3
  571. package/dist/core/index.js +0 -1
  572. package/dist/decay-BvOWTZ00.d.ts +0 -112
  573. package/dist/decay-CFlLvXUT.d.cts +0 -112
  574. package/dist/extra/browser.cjs +0 -1
  575. package/dist/extra/browser.d.cts +0 -4
  576. package/dist/extra/browser.d.ts +0 -4
  577. package/dist/extra/browser.js +0 -1
  578. package/dist/extra/index.cjs +0 -20
  579. package/dist/extra/index.d.cts +0 -17
  580. package/dist/extra/index.d.ts +0 -17
  581. package/dist/extra/index.js +0 -1
  582. package/dist/extra/node.cjs +0 -2
  583. package/dist/extra/node.js +0 -2
  584. package/dist/extra/operators.cjs +0 -1
  585. package/dist/extra/operators.d.cts +0 -958
  586. package/dist/extra/operators.d.ts +0 -958
  587. package/dist/extra/operators.js +0 -1
  588. package/dist/extra/reactive.cjs +0 -1
  589. package/dist/extra/reactive.d.cts +0 -353
  590. package/dist/extra/reactive.d.ts +0 -353
  591. package/dist/extra/reactive.js +0 -1
  592. package/dist/extra/render/index.cjs +0 -5
  593. package/dist/extra/render/index.js +0 -1
  594. package/dist/extra/sources.cjs +0 -3
  595. package/dist/extra/sources.js +0 -1
  596. package/dist/extra/storage-browser.cjs +0 -1
  597. package/dist/extra/storage-browser.d.cts +0 -37
  598. package/dist/extra/storage-browser.d.ts +0 -37
  599. package/dist/extra/storage-browser.js +0 -1
  600. package/dist/extra/storage-core.cjs +0 -1
  601. package/dist/extra/storage-core.d.cts +0 -28
  602. package/dist/extra/storage-core.d.ts +0 -28
  603. package/dist/extra/storage-core.js +0 -1
  604. package/dist/extra/storage-node.cjs +0 -1
  605. package/dist/extra/storage-node.d.cts +0 -2
  606. package/dist/extra/storage-node.d.ts +0 -2
  607. package/dist/extra/storage-node.js +0 -0
  608. package/dist/extra/storage-tiers-browser.cjs +0 -1
  609. package/dist/extra/storage-tiers-browser.d.cts +0 -120
  610. package/dist/extra/storage-tiers-browser.d.ts +0 -120
  611. package/dist/extra/storage-tiers-browser.js +0 -1
  612. package/dist/extra/storage-tiers-node.cjs +0 -1
  613. package/dist/extra/storage-tiers-node.d.cts +0 -210
  614. package/dist/extra/storage-tiers-node.d.ts +0 -210
  615. package/dist/extra/storage-tiers-node.js +0 -1
  616. package/dist/extra/storage-tiers.cjs +0 -1
  617. package/dist/extra/storage-tiers.d.cts +0 -412
  618. package/dist/extra/storage-tiers.d.ts +0 -412
  619. package/dist/extra/storage-tiers.js +0 -1
  620. package/dist/graph/index.cjs +0 -7
  621. package/dist/graph/index.d.cts +0 -7
  622. package/dist/graph/index.d.ts +0 -7
  623. package/dist/graph/index.js +0 -1
  624. package/dist/graph-CWvEUQAq.d.cts +0 -1861
  625. package/dist/graph-D9LFnda9.d.ts +0 -1861
  626. package/dist/index-5k1T6jl0.d.cts +0 -121
  627. package/dist/index-9770hRuQ.d.cts +0 -779
  628. package/dist/index-B1F8Enjf.d.ts +0 -704
  629. package/dist/index-BHskSB8v.d.ts +0 -3413
  630. package/dist/index-BIYAkbAi.d.cts +0 -26
  631. package/dist/index-BoJ5JHxI.d.ts +0 -557
  632. package/dist/index-BocU7pqs.d.ts +0 -779
  633. package/dist/index-BxNs2HB9.d.cts +0 -1858
  634. package/dist/index-C1T3d7V-.d.cts +0 -704
  635. package/dist/index-C5ri2Axc.d.cts +0 -301
  636. package/dist/index-C9l6OEBL.d.ts +0 -26
  637. package/dist/index-CC-AvFTy.d.cts +0 -557
  638. package/dist/index-CJF1URuX.d.ts +0 -121
  639. package/dist/index-CdTelp1M.d.ts +0 -202
  640. package/dist/index-Cj3WohTd.d.cts +0 -202
  641. package/dist/index-Co7uli2l.d.cts +0 -3413
  642. package/dist/index-D0aciIex.d.cts +0 -209
  643. package/dist/index-DHen9Klo.d.ts +0 -1858
  644. package/dist/index-Yq60JP3s.d.ts +0 -209
  645. package/dist/index-nozs3fFC.d.ts +0 -301
  646. package/dist/node-kK3CvTrR.d.cts +0 -1347
  647. package/dist/node-kK3CvTrR.d.ts +0 -1347
  648. package/dist/patterns/ai/browser.cjs +0 -8
  649. package/dist/patterns/ai/browser.js +0 -3
  650. package/dist/patterns/ai/index.cjs +0 -74
  651. package/dist/patterns/ai/index.d.cts +0 -20
  652. package/dist/patterns/ai/index.d.ts +0 -20
  653. package/dist/patterns/ai/index.js +0 -1
  654. package/dist/patterns/ai/node.cjs +0 -1
  655. package/dist/patterns/ai/node.js +0 -1
  656. package/dist/patterns/cqrs/index.cjs +0 -3
  657. package/dist/patterns/cqrs/index.d.cts +0 -8
  658. package/dist/patterns/cqrs/index.d.ts +0 -8
  659. package/dist/patterns/cqrs/index.js +0 -1
  660. package/dist/patterns/demo-shell/index.cjs +0 -5
  661. package/dist/patterns/demo-shell/index.d.cts +0 -7
  662. package/dist/patterns/demo-shell/index.d.ts +0 -7
  663. package/dist/patterns/demo-shell/index.js +0 -1
  664. package/dist/patterns/domain-templates/index.cjs +0 -3
  665. package/dist/patterns/domain-templates/index.d.cts +0 -6
  666. package/dist/patterns/domain-templates/index.d.ts +0 -6
  667. package/dist/patterns/domain-templates/index.js +0 -1
  668. package/dist/patterns/graphspec/index.cjs +0 -86
  669. package/dist/patterns/graphspec/index.d.cts +0 -8
  670. package/dist/patterns/graphspec/index.d.ts +0 -8
  671. package/dist/patterns/graphspec/index.js +0 -1
  672. package/dist/patterns/harness/index.cjs +0 -48
  673. package/dist/patterns/harness/index.d.cts +0 -13
  674. package/dist/patterns/harness/index.d.ts +0 -13
  675. package/dist/patterns/harness/index.js +0 -1
  676. package/dist/patterns/inspect/index.cjs +0 -3
  677. package/dist/patterns/inspect/index.d.cts +0 -9
  678. package/dist/patterns/inspect/index.d.ts +0 -9
  679. package/dist/patterns/inspect/index.js +0 -1
  680. package/dist/patterns/job-queue/index.cjs +0 -3
  681. package/dist/patterns/job-queue/index.d.cts +0 -9
  682. package/dist/patterns/job-queue/index.d.ts +0 -9
  683. package/dist/patterns/job-queue/index.js +0 -1
  684. package/dist/patterns/memory/index.cjs +0 -3
  685. package/dist/patterns/memory/index.d.cts +0 -8
  686. package/dist/patterns/memory/index.d.ts +0 -8
  687. package/dist/patterns/memory/index.js +0 -1
  688. package/dist/patterns/messaging/index.cjs +0 -3
  689. package/dist/patterns/messaging/index.d.cts +0 -7
  690. package/dist/patterns/messaging/index.d.ts +0 -7
  691. package/dist/patterns/messaging/index.js +0 -1
  692. package/dist/patterns/orchestration/index.cjs +0 -3
  693. package/dist/patterns/orchestration/index.d.cts +0 -8
  694. package/dist/patterns/orchestration/index.d.ts +0 -8
  695. package/dist/patterns/orchestration/index.js +0 -1
  696. package/dist/patterns/process/index.cjs +0 -3
  697. package/dist/patterns/process/index.d.cts +0 -10
  698. package/dist/patterns/process/index.d.ts +0 -10
  699. package/dist/patterns/process/index.js +0 -1
  700. package/dist/patterns/reactive-layout/index.cjs +0 -4
  701. package/dist/patterns/reactive-layout/index.d.cts +0 -7
  702. package/dist/patterns/reactive-layout/index.d.ts +0 -7
  703. package/dist/patterns/reactive-layout/index.js +0 -1
  704. package/dist/patterns/reduction/index.cjs +0 -3
  705. package/dist/patterns/reduction/index.d.cts +0 -6
  706. package/dist/patterns/reduction/index.d.ts +0 -6
  707. package/dist/patterns/reduction/index.js +0 -1
  708. package/dist/patterns/surface/index.cjs +0 -13
  709. package/dist/patterns/surface/index.d.cts +0 -9
  710. package/dist/patterns/surface/index.d.ts +0 -9
  711. package/dist/patterns/surface/index.js +0 -1
  712. package/dist/reactive-log-BKALbfal.d.ts +0 -223
  713. package/dist/reactive-log-DIGdYqQ6.d.cts +0 -223
  714. package/dist/reactive-map-CEFGp8TK.d.cts +0 -296
  715. package/dist/reactive-map-DS_SIAxv.d.ts +0 -296
  716. package/dist/resilience-6LYQJAC5.js +0 -1
  717. package/dist/sugar-DQjFmVqb.d.cts +0 -399
  718. package/dist/sugar-fhLIE7TT.d.ts +0 -399
  719. package/dist/topology-tree-Bcz27hpF.d.cts +0 -25
  720. package/dist/topology-tree-xvaD0fOX.d.ts +0 -25
@@ -1,13 +0,0 @@
1
- "use strict";var st=Object.defineProperty;var Ln=Object.getOwnPropertyDescriptor;var In=Object.getOwnPropertyNames;var Vn=Object.prototype.hasOwnProperty;var j=(n,e)=>()=>(n&&(e=n(n=0)),e);var Bn=(n,e)=>{for(var t in e)st(n,t,{get:e[t],enumerable:!0})},Hn=(n,e,t,r)=>{if(e&&typeof e=="object"||typeof e=="function")for(let s of In(e))!Vn.call(n,s)&&s!==t&&st(n,s,{get:()=>e[s],enumerable:!(r=Ln(e,s))||r.enumerable});return n};var zn=n=>Hn(st({},"__esModule",{value:!0}),n);function Mt(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++]=it,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 $t(n,e){if(n.length<Gt)throw new Error(`decodeEnvelope: bytes too short (${n.length} < ${Gt})`);let t=0,r=n[t++];if(r!==it)throw new Error(`decodeEnvelope: unsupported envelope version ${r} (expected ${it})`);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),d=e.lookupCodec(o);if(d==null)throw new Error(`decodeEnvelope: codec "${o}" not registered (envelope codec_v=${i})`);return{codec:d,codecVersion:i,payload:a}}function Ft(n){n.registerCodec(Wn)}var Wn,it,Gt,at=j(()=>{"use strict";Wn={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)}},it=1,Gt=4});function He(n){if(n==null)return ve;let{type:e,id:t,...r}=n;return{type:e??"system",id:t??"",...r}}var ve,ct=j(()=>{"use strict";ve={type:"system",id:""}});function ze(){return we>0||Ge}function Pt(){return we>0}function Se(n){we>0?Me.push(n):n()}function $e(n){we+=1;let e=!1;try{n()}catch(t){throw e=!0,t}finally{if(we-=1,we===0)if(e){if(!Ge){let t=Me.splice(0);for(let r of t)try{r()}catch{}he.length=0,ge.length=0,_e.length=0}}else Un()}}function Un(){let n=!Ge;n&&(Ge=!0);let e=[],t=0;try{for(;he.length>0||ge.length>0||_e.length>0||n&&Me.length>0;){if(n&&Me.length>0){let o=Me.splice(0);for(let i of o)try{i()}catch(a){e.push(a)}continue}if(t+=1,t>1e3)throw he.length=0,ge.length=0,_e.length=0,new Error("batch drain exceeded 1000 iterations \u2014 likely a reactive cycle");let s=(he.length>0?he:ge.length>0?ge:_e).splice(0);for(let o of s)try{o()}catch(i){e.push(i)}}}finally{n&&(Ge=!1)}if(e.length===1)throw e[0];if(e.length>1)throw new AggregateError(e,"batch drain: multiple callbacks threw")}function We(n,e,t){if(e.length===0)return;if(e.length===1){let c=t(e[0][0]);if(c<3||!ze()){n(e);return}(c>=5?_e:c===4?ge:he).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 d=ze();if(s>0){let c=e.slice(0,s);n(c)}if(o>s){let c=e.slice(s,o);d?he.push(()=>n(c)):n(c)}if(i>o){let c=e.slice(o,i);d?ge.push(()=>n(c)):n(c)}if(r>i){let c=e.slice(i,r);d?_e.push(()=>n(c)):n(c)}}var we,Ge,he,ge,_e,Me,Ue=j(()=>{"use strict";we=0,Ge=!1,he=[],ge=[],_e=[],Me=[]});function ae(){return Math.trunc(performance.now()*1e6)}function ke(){return Date.now()*1e6}var Fe=j(()=>{"use strict"});var Te,$,q,K,re,se,de,H,P,D,Ne,dt,qn,ut,Kn,Jn,lt,jt,Lt,It,ft,ue=j(()=>{"use strict";Te=Symbol.for("graphrefly/START"),$=Symbol.for("graphrefly/DATA"),q=Symbol.for("graphrefly/DIRTY"),K=Symbol.for("graphrefly/RESOLVED"),re=Symbol.for("graphrefly/INVALIDATE"),se=Symbol.for("graphrefly/PAUSE"),de=Symbol.for("graphrefly/RESUME"),H=Symbol.for("graphrefly/TEARDOWN"),P=Symbol.for("graphrefly/COMPLETE"),D=Symbol.for("graphrefly/ERROR"),Ne=Object.freeze([q]),dt=Object.freeze([K]),qn=Object.freeze([re]),ut=Object.freeze([Te]),Kn=Object.freeze([P]),Jn=Object.freeze([H]),lt=Object.freeze([Ne]),jt=Object.freeze([dt]),Lt=Object.freeze([qn]),It=Object.freeze([Kn]),ft=Object.freeze([Jn])});function Vt(n){n.registerMessageType(Te,{tier:0,wireCrossing:!1}),n.registerMessageType(q,{tier:1,wireCrossing:!1}),n.registerMessageType(re,{tier:1,wireCrossing:!1,metaPassthrough:!1}),n.registerMessageType(se,{tier:2,wireCrossing:!1}),n.registerMessageType(de,{tier:2,wireCrossing:!1}),n.registerMessageType($,{tier:3,wireCrossing:!0}),n.registerMessageType(K,{tier:3,wireCrossing:!0}),n.registerMessageType(P,{tier:4,wireCrossing:!0,metaPassthrough:!1}),n.registerMessageType(D,{tier:4,wireCrossing:!0,metaPassthrough:!1}),n.registerMessageType(H,{tier:5,wireCrossing:!0,metaPassthrough:!1})}var qe,Bt=j(()=>{"use strict";ue();qe=class{_messageTypes=new Map;_codecs=new Map;_onMessage;_onSubscribe;_defaultVersioning;_defaultHashFn;_inspectorEnabled=!(typeof process<"u"&&process.env?.NODE_ENV==="production");_globalInspector;_rigorRecorder;_frozen=!1;tierOf;constructor(e){this._onMessage=e.onMessage,this._onSubscribe=e.onSubscribe,this._defaultVersioning=e.defaultVersioning,this._defaultHashFn=e.defaultHashFn,this.tierOf=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 Ht(n){return Array.isArray(n)?[...n]:[n]}function Yn(n,e){return n.has(e)||n.has("*")}function zt(n){let e=[];return n((s,o)=>{e.push({kind:"allow",actions:new Set(Ht(s)),where:o?.where??(()=>!0)})},(s,o)=>{e.push({kind:"deny",actions:new Set(Ht(s)),where:o?.where??(()=>!0)})}),(s,o)=>{let i=!1,a=!1;for(let d of e)Yn(d.actions,o)&&d.where(s)&&(d.kind==="deny"?i=!0:a=!0);return i?!1:a}}function pt(n){let e=Xn.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,Xn,Pe=j(()=>{"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}};Xn=["human","llm","wallet","system"]});function ht(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(ht);if(typeof n=="object"&&n!==null){let e={};for(let t of Object.keys(n).sort())e[t]=ht(n[t]);return e}return null}function er(n){let e=Qn.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,d=3144134277,c=1013904242,u=2773480762,h=1359893119,f=2600822924,p=528734635,l=1541459225,b=new Uint32Array(64),m=(v,g)=>v>>>g|v<<32-g;for(let v=0;v<s;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 L=b[k-15],R=b[k-2],A=m(L,7)^m(L,18)^L>>>3,te=m(R,17)^m(R,19)^R>>>10;b[k]=b[k-16]+A+b[k-7]+te>>>0}let g=a,y=d,w=c,S=u,T=h,O=f,E=p,x=l;for(let k=0;k<64;k++){let L=m(T,6)^m(T,11)^m(T,25),R=T&O^~T&E,A=x+L+R+Zn[k]+b[k]>>>0,te=m(g,2)^m(g,13)^m(g,22),be=g&y^g&w^y&w,z=te+be>>>0;x=E,E=O,O=T,T=S+A>>>0,S=w,w=y,y=g,g=A+z>>>0}a=a+g>>>0,d=d+y>>>0,c=c+w>>>0,u=u+S>>>0,h=h+T>>>0,f=f+O>>>0,p=p+E>>>0,l=l+x>>>0}let _=v=>v.toString(16).padStart(8,"0");return _(a)+_(d)+_(c)+_(u)+_(h)+_(f)+_(p)+_(l)}function gt(n){let e=ht(n??null),t=JSON.stringify(e);return er(t).slice(0,16)}function tr(){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 mt(n,e,t){let r=t?.id??tr();if(n===0)return{id:r,version:0};let o=(t?.hash??gt)(e);return{id:r,version:0,cid:o,prev:null}}function Wt(n,e,t){n.version+=1,"cid"in n&&(n.prev=n.cid,n.cid=t(e))}var Zn,Qn,Ut=j(()=>{"use strict";Zn=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]),Qn=new TextEncoder});function Jt(n){return{node:n,unsub:null,prevData:void 0,dirty:!1,involvedThisWave:!1,dataBatch:[],terminal:void 0}}function yt(n){n.prevData=void 0,n.dirty=!1,n.involvedThisWave=!1,n.dataBatch.length=0,n.terminal=void 0}function Ke(n){return n.length===0?n:typeof n[0]=="symbol"?[n]:n}function me(n,e,t){let r=Yt(n)?n:[],s=typeof n=="function"?n:typeof e=="function"?e:void 0,o={};return Yt(n)?o=(bt(e)?e:t)??{}:bt(n)?o=n:o=(bt(e)?e:t)??{},new I(r,s,o)}var qt,Kt,nr,rr,Oe,I,Yt,bt,xe=j(()=>{"use strict";at();ct();Ue();Fe();Bt();Pe();ue();Ut();qt=()=>{},Kt=100;nr=(n,e,t,r)=>{t.direction==="down-in"&&n._onDepMessage(t.depIndex,e)},rr=(n,e,t,r)=>{let s=n;if(s._status==="completed"||s._status==="errored")return;let o=s._cached,i=o===void 0?[ut]:[ut,[$,o]];s._status==="dirty"&&i.push(Ne),We(e,i,s._config.tierOf)},Oe=new qe({onMessage:nr,onSubscribe:rr});Vt(Oe);Ft(Oe);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??Oe,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??gt;let s=r.versioning??this._config.defaultVersioning;this._versioningLevel=s,this._versioning=s!=null?mt(s,this._cached===void 0?void 0:this._cached,{id:r.versioningId,hash:this._hashFn}):void 0,this._deps=e.map(Jt);let o={};for(let[a,d]of Object.entries(r.meta??{})){let c={initial:d,name:`${r.name??"node"}:meta:${a}`,describeKind:"state",config:this._config};r.guard!=null&&(c.guard=r.guard),r.resubscribable===!0&&(c.resubscribable=!0),o[a]=new n([],void 0,c)}Object.freeze(o),this.meta=o,this._hasMeta=Object.keys(o).length>0;let i=this;this._actions={emit(a){i._emit([[$,a]])},down(a){i._emit(Ke(a))},up(a){i._emitUp(Ke(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,d=i?.version??0,c=mt(e,o,{id:a,hash:s});c.version=d,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=He(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=He(e?.actor),o=e?.delivery==="signal"?"signal":"write";if(this._guard!=null&&!this._guard(s,o))throw new Q({actor:s,action:o,nodeName:this.name});if(this._extraGuards!=null){for(let i of this._extraGuards)if(!i(s,o))throw new Q({actor:s,action:o,nodeName:this.name})}this._lastMutation={actor:s,timestamp_ns:ke()}}down(e,t){let r=Ke(e);r.length!==0&&(this._checkGuard(t),this._emit(r))}emit(e,t){this._checkGuard(t),this._emit([[$,e]])}up(e,t){if(this._deps.length===0)return;let r=Ke(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 d=He(t);if(!this._guard(d,"observe"))throw new Q({actor:d,action:"observe",nodeName:this.name})}let s=this._isTerminal&&this._resubscribable;if(s){this._cached=void 0,this._status="sentinel",this._store={},this._hasCalledFnOnce=!1,this._waveHasNewData=!1,this._hasNewTerminal=!1,this._paused=!1,this._pendingWave=!1,this._pendingRerun=!1,this._isExecutingFn=!1,this._rerunDepth=0,this._dirtyDepCount=0,this._pauseLocks=null,this._pauseBuffer=null;for(let d of this._deps)yt(d);if(this._partial===!1){for(let d of this._deps)if(d.prevData!==void 0||d.dataBatch.length!==0||d.terminal!==void 0||d.dirty)throw new Error(`resubscribable-reset invariant: DepRecord not fully reset for node ${this._optsName??"(anonymous)"}`)}}this._sinkCount+=1;let o;try{o=this._config.onSubscribe(this,e,{sinkCount:this._sinkCount,afterTerminalReset:s},this._actions)}catch(d){throw this._sinkCount-=1,d}this._sinks==null?this._sinks=e:typeof this._sinks=="function"?this._sinks=new Set([this._sinks,e]):this._sinks.add(e);let i=this._isTerminal;if(this._sinkCount===1&&!i)try{this._activate()}catch(d){if(this._sinkCount-=1,this._removeSink(e),this._sinkCount===0&&(this._status="sentinel"),typeof o=="function")try{o()}catch{}throw d}this._status==="sentinel"&&this._cached===void 0&&(this._status="pending");let a=!1;return()=>{a||(a=!0,this._sinkCount-=1,this._removeSink(e),typeof o=="function"&&o(),this._sinks==null&&this._deactivate())}}_removeSink(e){if(this._sinks===e)this._sinks=null;else if(this._sinks!=null&&typeof this._sinks!="function")if(this._sinks.delete(e),this._sinks.size===1){let[t]=this._sinks;this._sinks=t}else this._sinks.size===0&&(this._sinks=null)}_activate(){if(this._deps.length===0){this._fn&&this._execFn();return}this._dirtyDepCount=0;let e=this._deps.length,t=0;try{for(let r=0;r<e;r++){let s=r,o=this._deps[r];o.unsub=qt,o.unsub=o.node.subscribe(i=>{if(o.unsub===null)return;let a=this._config.tierOf,d=!1;for(let c of i)a(c[0])>=3&&(d=!0),this._config.onMessage(this,c,{direction:"down-in",depIndex:s},this._actions);d&&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{}yt(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=Jt(e);if(this._deps.push(r),this._sinks==null)return t;r.dirty=!0,this._dirtyDepCount++,this._status!=="dirty"&&this._emit(lt),r.unsub=qt;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([[D,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([[D,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{}}yt(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!==Te){if(s===q){this._depDirtied(r);return}if(s===re){if(this._depInvalidated(r),this._cached===void 0)return;this._emit(Lt);return}if(s===se||s===de){this._emit([t]);return}if(s===H){this._emit(ft);return}if(s===$)this._depSettledAsData(r,t[1]);else if(s===K)this._depSettledAsResolved(r);else if(s===P)this._depSettledAsTerminal(r,!0);else if(s===D)this._depSettledAsTerminal(r,t[1]);else{this._emit([t]);return}if(!this._fn){(s===$||s===K)&&this._emit([t]),(s===P||s===D)&&this._maybeAutoTerminalAfterWave();return}}}_depDirtied(e){e.dirty||(e.dirty=!0,e.involvedThisWave=!0,this._dirtyDepCount++,this._status!=="dirty"&&this._emit(lt))}_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(jt),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([[D,e.terminal]]);return}this._autoComplete&&this._deps.every(t=>t.terminal!==void 0)&&this._emit(It)}_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([[D,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([[D,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([[D,this._wrapFnError("fn threw",i)]])}finally{this._isExecutingFn=!1,this._pendingRerun?(this._pendingRerun=!1,this._rerunDepth+=1,this._rerunDepth>Kt?(this._rerunDepth=0,this._emit([[D,new Error(`Node "${this.name}": _pendingRerun depth exceeded ${Kt} \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"?[Ne,e[0]]:e;let r=!0,s=!1,o=!1,i=-1;for(let d of e){let c=t(d[0]);c<i&&(r=!1),c===3&&(s=!0),d[0]===q&&(o=!0),i=c}let a=e;if(!r){let d=e.map((c,u)=>({m:c,i:u,tier:t(c[0])}));d.sort((c,u)=>c.tier-u.tier||c.i-u.i),a=d.map(c=>c.m)}if(s&&!o&&this._status!=="dirty"){let d=0;for(;d<a.length&&t(a[d][0])===0;)d++;return d===0?[Ne,...a]:[...a.slice(0,d),Ne,...a.slice(d)]}return a}_emit(e){if(e.length===0)return;for(let a=0;a<e.length;a++){let d=e[a];if(d[0]===D&&d[1]===void 0)throw new TypeError('[ERROR, payload] requires a non-undefined payload (spec \xA71.2). Pass an Error object or domain tag instead \u2014 e.g. node.down([[ERROR, new Error("reason")]])')}let t=e;if(this._isTerminal&&!this._resubscribable){let a=e.filter(d=>d[0]===H||d[0]===re);if(a.length===0)return;t=a}t=this._frameBatch(t);let s=null;for(let a=0;a<t.length;a++){let d=t[a],c=d[0];if(c!==se&&c!==de){s?.push(d);continue}if(d.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 u=!0;if(this._pausable!==!1){let h=d[1];if(c===se)this._pauseLocks==null&&(this._pauseLocks=new Set),this._pauseLocks.add(h),this._paused=!0,this._pausable==="resumeAll"&&this._pauseBuffer==null&&(this._pauseBuffer=[]);else if(this._pauseLocks==null||!this._pauseLocks.has(h))u=!1;else if(this._pauseLocks.delete(h),this._pauseLocks.size===0){if(this._paused=!1,this._pauseBuffer!=null&&this._pauseBuffer.length>0){let f=this._pauseBuffer;this._pauseBuffer=[],this._emit(f)}this._pendingWave&&(this._pendingWave=!1,this._maybeRunFnOnSettlement())}}u?s?.push(d):s==null&&(s=t.slice(0,a))}if(s!=null){if(s.length===0)return;t=s}if(this._hasMeta&&t.some(a=>a[0]===H))for(let a of Object.keys(this.meta))try{this.meta[a]._emit(ft)}catch{}let{finalMessages:o,equalsError:i}=this._updateState(t);if(o.length>0&&this._config.inspectorEnabled){let a=this._config.globalInspector;if(a!=null)try{a({kind:"emit",node:this,messages:o})}catch{}}if(o.length>0)if(this._paused&&this._pausable==="resumeAll"&&this._pauseBuffer!=null){let a=this._config.tierOf,d=[];for(let c of o)a(c[0])===3?this._pauseBuffer.push(c):d.push(c);d.length>0&&this._dispatchOrAccumulate(d)}else this._dispatchOrAccumulate(o);i!=null&&this._emit([[D,i]])}_updateState(e){let t=this._config.tierOf,r,s,o=-1,i=0;for(let u of e)t(u[0])===3&&i++;let a=i<=1,d=-1;if(this._versioning!=null&&i>1){for(let u=e.length-1;u>=0;u--)if(e[u][0]===$){d=u;break}}for(let u=0;u<e.length;u++){let h=e[u],f=h[0];if(f===$){if(h.length>=2){let p=!1;if(a&&this._cached!==void 0)try{p=this._equals(this._cached,h[1])}catch(l){s=this._wrapFnError("equals threw",l),o=u;break}if(p){r==null&&(r=e.slice(0,u)),r.push(dt),this._status="resolved";continue}this._cached=h[1],this._versioning!=null&&(d<0||u===d)&&Wt(this._versioning,h[1],this._hashFn)}this._status="settled",r?.push(h)}else if(r?.push(h),f===q)this._status="dirty";else if(f===K)this._status="resolved";else if(f===P){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===D){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===H&&(this._resetOnTeardown&&(this._cached=void 0),this._deactivate(!0),this._status="sentinel")}let c=o>=0?r??e.slice(0,o):r??e;return s!=null?{finalMessages:c,equalsError:s}:{finalMessages:c}}_deliverToSinks=e=>{if(this._sinks==null)return;if(typeof this._sinks=="function"){this._sinks(e);return}let t=[...this._sinks];for(let r of t)r(e)};_dispatchOrAccumulate(e){if(Pt()){this._batchPendingMessages===null&&(this._batchPendingMessages=[],Se(()=>this._flushBatchPending()));for(let t of e)this._batchPendingMessages.push(t);return}We(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);We(this._deliverToSinks,t,this._config.tierOf)}},Yt=n=>Array.isArray(n),bt=n=>typeof n=="object"&&n!=null&&!Array.isArray(n)});function oe(n,e){return me([],{...e,initial:n})}function ie(n,e){return me((r,s,o)=>n(s,o)??void 0,{describeKind:"producer",...e})}function le(n,e,t){return me(n,(s,o,i)=>{let a=s.map((d,c)=>d!=null&&d.length>0?d.at(-1):i.prevData[c]);o.emit(e(a,i))},{describeKind:"derived",...t})}function Re(n,e,t){return me(n,(s,o,i)=>{let a=s.map((d,c)=>d!=null&&d.length>0?d.at(-1):i.prevData[c]);return e(a,o,i)??void 0},{describeKind:"effect",...t})}var je=j(()=>{"use strict";xe()});function vt(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 or(n){return n._describeKind!=null?n._describeKind:n._deps.length>0?"derived":n._fn!=null?"producer":"state"}function sr(n){let e={};for(let[t,r]of Object.entries(n.meta))try{e[t]=r.cache}catch{}return e}function wt(n,e,t){let r=e==null,s=!r&&e!=null?[...e].filter(u=>u.startsWith("meta.")).map(u=>u.slice(5)):null,o=r||e.has("meta")||s!=null&&s.length>0,i="state",a=[];n instanceof I&&(i=or(n),a=n._deps.map(u=>u.node.name??""));let d={type:i,deps:a};(r||e.has("status"))&&(d.status=n.status);let c=n instanceof I?n._guard:void 0;if(o){let u={...sr(n)};if(c!=null&&u.access===void 0&&(u.access=pt(c)),s!=null&&s.length>0&&!e.has("meta")){let h={};for(let f of s)f in u&&(h[f]=u[f]);d.meta=h}else d.meta=u}if(n.name!=null&&(d.name=n.name),(r||e.has("value"))&&(!t||i==="state")){n.status==="sentinel"&&(d.sentinel=!0);try{d.value=n.cache}catch{}}if((r||e.has("v"))&&n.v!=null){let u={id:n.v.id,version:n.v.version};"cid"in n.v&&(u.cid=n.v.cid,u.prev=n.v.prev),d.v=u}return(r||e.has("guard"))&&c!=null&&(d.guard=pt(c)),(r||e.has("lastMutation"))&&n.lastMutation!=null&&(d.lastMutation=n.lastMutation),d}var Xt=j(()=>{"use strict";Pe();xe()});function _t(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(!_t(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)||!_t(n[o],e[o]))return!1;return!0}function Zt(n,e){return`${n}\0${e}`}function St(n,e){let t=[],r=new Set(n.subgraphs),s=new Set(e.subgraphs),o=[];for(let m of s)r.has(m)||o.push(m);o.sort();for(let m of o)t.push({type:"subgraph-mounted",path:m});let i=new Set(Object.keys(n.nodes)),a=new Set(Object.keys(e.nodes)),d=[];for(let m of a)i.has(m)||d.push(m);d.sort();for(let m of d)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||_t(_??{},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 u=new Map;for(let m of n.edges)u.set(Zt(m.from,m.to),m);let h=new Map;for(let m of e.edges)h.set(Zt(m.from,m.to),m);let f=[];for(let[m,_]of h)u.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 u)h.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)s.has(m)||b.push(m);b.sort();for(let m of b)t.push({type:"subgraph-unmounted",path:m});return{events:t,flushedAt_ns:ae()}}var Qt=j(()=>{"use strict";Fe()});function kt(n){return{describeKind:"producer",...n}}function en(n,e){return ie(t=>{let r=!1;try{for(let s of n){if(r)return;t.emit(s)}r||t.down([[P]])}catch(s){r||t.down([[D,s]])}return()=>{r=!0}},kt(e))}function ir(n){return n!=null&&typeof n.then=="function"}function ar(n,e){let{signal:t,...r}=e??{};return ie(s=>{let o=!1,i=()=>{o||(o=!0,s.down([[D,t.reason]]))};if(t?.aborted){i();return}return t?.addEventListener("abort",i,{once:!0}),Promise.resolve(n).then(a=>{o||(o=!0,t?.removeEventListener("abort",i),s.emit(a),s.down([[P]]))},a=>{o||(o=!0,t?.removeEventListener("abort",i),s.down([[D,a]]))}),()=>{o=!0,t?.removeEventListener("abort",i)}},kt(r))}function cr(n,e){let{signal:t,...r}=e??{};return ie(s=>{let o=new AbortController,i=()=>o.abort(t?.reason);t?.aborted?o.abort(t.reason):t?.addEventListener("abort",i,{once:!0});let a=t??o.signal,d=!1,c=n[Symbol.asyncIterator](),u=()=>{d||a.aborted||Promise.resolve(c.next()).then(h=>{if(!(d||a.aborted)){if(h.done){s.down([[P]]);return}s.emit(h.value),u()}},h=>{!d&&!a.aborted&&s.down([[D,h]])})};return u(),()=>{d=!0,t?.removeEventListener("abort",i),o.abort(),Promise.resolve(c.return?.()).catch(()=>{})}},kt(r))}function dr(n){return n!=null&&typeof n=="object"&&"cache"in n&&typeof n.subscribe=="function"}function tn(n,e){if(dr(n))return n;if(ir(n))return ar(n,e);if(n!=null){let t=n;if(typeof t[Symbol.asyncIterator]=="function")return cr(n,e);if(typeof t[Symbol.iterator]=="function")return en(n,e)}return ur(n)}function ur(...n){return en(n,void 0)}function Ee(n){return n.subscribe(()=>{})}var nn=j(()=>{"use strict";ue();je()});var Tt=j(()=>{"use strict";nn()});var Je,rn=j(()=>{"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 Le,on=j(()=>{"use strict";Le=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 sn(n,e,t,r={}){let s=e in n.nodes,o=t in n.nodes;if(!s)return Ye(e,t,"no-such-from");if(!o)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=lr(n,e,r);if(c!=null)return c}let d=Xe(e,n.nodes[e],0,r);return Ze(e,t,[d])}if(i===0)return Ye(e,t,"no-path");let a=an(n,e,t,i);return a.found?Ze(e,t,cn(n,a.pathOrder,r)):Ye(e,t,a.truncated?"max-depth-exceeded":"no-path")}function an(n,e,t,r){let s=new Map,o=[{path:t,depth:0}],i=new Set([t]),a=0,d=!1;for(;a<o.length;){let h=o[a++];if(h.path===e)break;if(r!=null&&h.depth>=r){let b=n.nodes[h.path];b?.deps&&b.deps.length>0&&(d=!0);continue}let f=n.nodes[h.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),s.set(b,{from:h.path,depIndices:m}),o.push({path:b,depth:h.depth+1}))}if(!s.has(e))return{found:!1,pathOrder:[],truncated:d};let c=[{path:e}],u=e;for(;u!==t;){let h=s.get(u);if(h==null)return{found:!1,pathOrder:[],truncated:!1};c[c.length-1].depIndices=h.depIndices,c.push({path:h.from}),u=h.from}return{found:!0,pathOrder:c,truncated:!1}}function lr(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=Xe(e,r,0,t);a.dep_index=o[0];let d=Xe(e,r,1,t);return Ze(e,e,[a,d])}let i=null;for(let a=0;a<s.length;a++){let d=s[a];if(!d||d===e)continue;let c=an(n,d,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,cn(n,i.pathOrder,t))}function cn(n,e,t){return e.map((r,s)=>{let o=n.nodes[r.path],i=Xe(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 Xe(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 Ze(n,e,t){return dn(n,e,!0,"ok",t)}function Ye(n,e,t){return dn(n,e,!1,t,[])}function dn(n,e,t,r,s){let o=fr(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 fr(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 d=` ${i.hop===0?"\xB7":"\u2193"} ${i.path} (${i.type}${i.status?`/${i.status}`:""})`;if(o.push(d),"value"in i&&o.push(` value: ${pr(i.value)}`),i.annotation!=null&&o.push(` annotation: ${i.annotation}`),i.lastMutation!=null){let c=i.lastMutation.actor;o.push(` actor: ${c.type}${c.id?`:${c.id}`:""}`)}}return o.join(`
2
- `)}function pr(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 un=j(()=>{"use strict"});function ln(n){let e=new WeakSet,t=new WeakSet,r=[n],s=0;for(;r.length>0;){let o=r.pop();s+=gr(o,e,t,r)}return s}function gr(n,e,t,r){if(n==null)return 0;switch(typeof n){case"number":return V.number;case"boolean":return V.boolean;case"string":return V.string+n.length*2;case"bigint":return V.bigint+mr(n);case"symbol":return V.symbol;case"function":return e.has(n)?0:(e.add(n),V.function);case"undefined":return 0}let o=n;if(e.has(o))return 0;e.add(o);let i=o[hr];if(typeof i=="function")try{let c=i.call(o);if(typeof c=="number"&&Number.isFinite(c))return c}catch{}if(o instanceof Date)return V.date;if(o instanceof RegExp)return V.regexp+o.source.length*2;if(o instanceof Error){let c=o.message?o.message.length*2:0,u=o.stack?o.stack.length*2:0;return V.error+c+u}if(typeof URL<"u"&&o instanceof URL)return V.url+o.href.length*2;if(typeof Promise<"u"&&o instanceof Promise)return V.promise;if(o instanceof WeakMap)return V.weakmap;if(o instanceof WeakSet)return V.weakset;if(o instanceof Map){let c=V.map;for(let[u,h]of o)c+=V.mapEntry,r.push(u),r.push(h);return c}if(o instanceof Set){let c=V.set;for(let u of o)c+=V.setEntry,r.push(u);return c}if(Array.isArray(o)){let c=V.array+o.length*8;for(let u of o)r.push(u);return c}if(o instanceof ArrayBuffer)return t.has(o)?0:(t.add(o),o.byteLength);if(ArrayBuffer.isView(o)){let c=o;return t.has(c.buffer)?48:(t.add(c.buffer),c.buffer.byteLength+48)}let a=V.object,d=Object.keys(o);for(let c of d){a+=V.string+c.length*2;try{r.push(o[c])}catch{}}return a}function mr(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 V,hr,fn=j(()=>{"use strict";V={object:56,array:64,string:40,number:8,boolean:4,null:0,undefined:0,symbol:40,bigint:16,function:120,map:72,set:72,mapEntry:40,setEntry:24,date:24,regexp:48,error:64,url:80,promise:48,weakmap:40,weakset:40},hr=Symbol.for("sizeof")});function pn(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[f,p]of s)i.set(f,p);let a=[];for(let[f,p]of Object.entries(r.nodes)){let l=i.get(f),b=l instanceof I?l:null,m=b?ln(b.cache):0,_=b?b._sinkCount:0,v=p.deps?.length??0,g=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:g,orphanKind:y})}let d=a.reduce((f,p)=>f+p.valueSizeBytes,0),c=(f,p)=>[...a].sort(p??((l,b)=>b[f]-l[f])).slice(0,t),u=a.filter(f=>f.orphanKind!=null),h=a.filter(f=>f.isOrphanEffect);return{nodeCount:a.length,edgeCount:r.edges.length,subgraphCount:r.subgraphs.length,nodes:a,totalValueSizeBytes:d,hotspots:{byValueSize:c("valueSizeBytes"),bySubscriberCount:c("subscriberCount"),byDepCount:c("depCount")},orphans:u,orphanEffects:h}}var hn=j(()=>{"use strict";xe();fn()});function Qe(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 wn(n){return n!=null&&typeof n=="object"&&"cache"in n&&typeof n.subscribe=="function"&&typeof n.down=="function"}function yr(n){if(n!=null)return wn(n)?n.cache:n}function ye(n){return n!=null&&typeof n=="object"&&"cache"in n&&typeof n.subscribe=="function"&&typeof n.down=="function"}function fe(n){return ye(n)?n.cache??"":n}function gn(n){return ye(n)?n.cache??0:n}function mn(n){return ye(n)?n.cache??!1:n}function br(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 yn(n){if(n.version!==pe)throw new Error(`unsupported snapshot version ${String(n.version)} (expected ${pe})`);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 vr(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,d=o.constructor;if(a!==d)return!1;if(s instanceof Date)return s.getTime()===o.getTime();if(s instanceof RegExp)return s.source===o.source&&s.flags===o.flags;if(Array.isArray(s)){let f=o;if(s.length!==f.length)return!1;for(let p=0;p<s.length;p++)if(!r(s[p],f[p]))return!1;return!0}if(s instanceof Map){let f=o;if(s.size!==f.size)return!1;for(let[p,l]of s)if(!f.has(p)||!r(l,f.get(p)))return!1;return!0}if(s instanceof Set){let f=o;if(s.size!==f.size)return!1;for(let p of s){let l=!1;for(let b of f)if(r(p,b)){l=!0;break}if(!l)return!1}return!0}if(ArrayBuffer.isView(s)){let f=s,p=o;if(f.length!==p.length)return!1;for(let l=0;l<f.length;l++)if(f[l]!==p[l])return!1;return!0}let c=Object.keys(s),u=Object.keys(o);if(c.length!==u.length)return!1;let h=new Set(u);for(let f of c)if(!h.has(f)||!r(s[f],o[f]))return!1;return!0};return r(n,e)}function wr(n){return n.replace(/[.*+?^${}()|[\]\\]/g,"\\$&")}function et(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+=wr(r)}return e+="$",new RegExp(e)}function Nt(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 kr(n){return n==="none"?Sr:n==="ansi"||n==null?_r:{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 bn(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 Tr(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 Ot(n,e,t){if(n==="")throw new Error(`Graph "${e}": ${t} name must be non-empty`);if(n.includes(F))throw new Error(`Graph "${e}": ${t} "${n}" must not contain '${F}' (path separator)`);if(n===ee)throw new Error(`Graph "${e}": ${t} name "${ee}" is reserved for meta companion paths`);Tr(n,e,t)}function Nr(n,e){if(n==="")throw new Error(`Graph "${e}": resolve path must be non-empty`);let t=n.split(F);for(let r of t)if(r==="")throw new Error(`Graph "${e}": resolve path has empty segment`);return t}function Or(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 _n(n){for(let e of n._mounts.values())_n(e);for(let e of n._nodes.values())try{e.down([[H]],{internal:!0})}catch{}}function xr(n,e){let t=ce.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 vn(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,d=new Map,c=new Map,u=new Set;for(let[g,y]of Object.entries(n.nodes)){if(!g)continue;u.add(g);let w=y.deps??[];i.set(g,w);for(let S of w)S&&(u.add(S),a.has(S)||a.set(S,new Set),a.get(S).add(g))}for(let g of n.edges){if(g==null||typeof g!="object")continue;let y=typeof g.from=="string"?g.from:"",w=typeof g.to=="string"?g.to:"";!y||!w||(u.add(y),u.add(w),c.has(y)||c.set(y,new Set),c.get(y).add(w),d.has(w)||d.set(w,new Set),d.get(w).add(y))}if(!u.has(e))return r.withDetail?s:[];let h=r.both===!0,f=g=>{if(h){let T=i.get(g)??[],O=d.get(g),E=a.get(g),x=c.get(g),k=[...T];return O&&k.push(...O),E&&k.push(...E),x&&k.push(...x),k}if(t==="upstream"){let T=i.get(g)??[],O=d.get(g);return O?[...T,...O]:T}let y=a.get(g),w=c.get(g),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 g=b[m++];if(o!=null&&g.depth>=o){f(g.path).length>0&&(_=!0);continue}for(let y of f(g.path))!y||p.has(y)||(p.add(y),l.set(y,g.depth+1),b.push({path:y,depth:g.depth+1}))}let v=[...l.keys()].sort((g,y)=>g<y?-1:g>y?1:0);return r.withDetail?{paths:v,depths:l,truncated:_}:v}function Rr(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 F,ee,pe,_r,Sr,ce,xt=j(()=>{"use strict";ct();Ue();Fe();Pe();ue();Xt();xe();je();Qt();Tt();rn();on();at();un();hn();F="::",ee="__meta__",pe=1;_r={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"},Sr={data:"",dirty:"",resolved:"",invalidate:"",pause:"",resume:"",complete:"",error:"",teardown:"",derived:"",path:"",reset:""};ce=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(F))throw new Error(`Graph name must not contain '${F}' (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??Oe,this._traceRing=new Le(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=ie(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(Ot(o,this.name,"add"),this._mounts.has(o))throw new Error(`Graph "${this.name}": name "${o}" is already a mount point`);if(this._nodes.has(o))throw new Error(`Graph "${this.name}": node "${o}" already exists`);let a=this._nodeToName.get(e);if(a!==void 0)throw new Error(`Graph "${this.name}": node instance already registered as "${a}"`);return this._nodes.set(o,e),this._nodeToName.set(e,o),this._emitTopology({kind:"added",name:o,nodeKind:"node"}),i!=null&&(this._annotations.set(o,i),this.config.inspectorEnabled&&this._traceRing.push({path:o,annotation:i,timestamp_ns:ae()})),e}setVersioning(e){if(e!=null)for(let t of this._nodes.values())t instanceof I&&t._applyVersioning(e)}remove(e){Ot(e,this.name,"remove");let t=this._mounts.get(e);if(t){let o={kind:"mount",nodes:[],mounts:[]},i=[];t._collectObserveTargets("",i);for(let[a,d]of i)a.includes(`${F}${ee}${F}`)||o.nodes.push(a);return o.nodes.sort(),o.mounts.push(e),o.mounts.push(...t._collectSubgraphs(`${e}${F}`)),this._mounts.delete(e),t._parent=void 0,_n(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([[H]],{internal:!0});let s={kind:"node",nodes:[e],mounts:[]};return this._emitTopology({kind:"removed",name:e,nodeKind:"node",audit:s}),s}removeAll(e){let t=typeof e=="function"?e:(()=>{let o=et(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(F))return this.resolve(e);let t=this._nodes.get(e);if(!t)throw new Error(`Graph "${this.name}": unknown node "${e}"`);return t}get(e){return this.node(e).cache}set(e,t,r){let s=r?.internal===!0;this.node(e).down([[$,t]],{actor:r?.actor,internal:s,delivery:"write"})}setAll(e,t){let r=Symbol.iterator in e?e:Object.entries(e);$e(()=>{for(let[s,o]of r)this.set(s,o,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 s=r?.internal===!0;this.node(e).down([[D,t]],{actor:r?.actor,internal:s,delivery:"write"})}complete(e,t){let r=t?.internal===!0;this.node(e).down([[P]],{actor:t?.actor,internal:r,delivery:"write"})}_registerSelfPruningKeepalive(e){let t,r,s=()=>{t?.(),t=void 0,r?.(),r=void 0};t=e.subscribe(o=>{for(let i of o){let a=i[0];if(a===H||a===P||a===D){s();return}}}),r=this.addDisposer(s)}_wireSignalToRemove(e,t){if(t==null)return;let r=()=>{try{this.remove(e)}catch{}};if(t.aborted){r();return}t.addEventListener("abort",r,{once:!0}),this.addDisposer(()=>t.removeEventListener("abort",r))}derived(e,t,r,s){let o=t.map(p=>this.resolve(p)),{keepAlive:i,annotation:a,equals:d,initial:c,meta:u,signal:h}=s??{},f=le(o,r,{name:e,...d!=null?{equals:d}:{},...c!==void 0?{initial:c}:{},...u!=null?{meta:u}:{}});return this.add(f,{name:e,...a!=null?{annotation:a}:{}}),i===!0&&this._registerSelfPruningKeepalive(f),this._wireSignalToRemove(e,h),f}effect(e,t,r,s){let o=t.map(u=>this.resolve(u)),{annotation:i,meta:a,signal:d}=s??{},c=Re(o,r,{name:e,...a!=null?{meta:a}:{}});return this.add(c,{name:e,...i!=null?{annotation:i}:{}}),this._wireSignalToRemove(e,d),c}produce(e,t,r){if(t===void 0)throw new Error(`Graph "${this.name}".produce("${e}", \u2026): source must not be \`undefined\` \u2014 undefined is the global SENTINEL (spec \xA71.1). Pass \`null\` for nullary DATA, or a Promise/AsyncIterable/Iterable for async sources.`);if(t!==null&&typeof t=="object"&&"cache"in t&&typeof t.subscribe=="function")throw new Error(`Graph "${this.name}".produce("${e}", \u2026): Node sources are rejected. For Node\u2192Node, use graph.derived(name, [path], ([v]) => v, { keepAlive: true }) \u2014 fromAny passes Nodes through verbatim and silently drops opts.`);let{annotation:s,meta:o,equals:i,signal:a}=r??{},d=tn(t,{name:e,...o!=null?{meta:o}:{},...i!=null?{equals:i}:{},...a!=null?{signal:a}:{}});return this.add(d,{name:e,...s!=null?{annotation:s}:{}}),this._wireSignalToRemove(e,a),d}batch(e){$e(e)}edges(e){let t=e?.recursive===!0,r=new Map;if(!t){for(let[d,c]of this._nodes)r.set(c,d);let a=[];for(let[d,c]of this._nodes)if(c instanceof I)for(let u of c._deps){let h=r.get(u.node);h!=null&&a.push([h,d])}return a.sort((d,c)=>d[0]<c[0]?-1:d[0]>c[0]?1:d[1]<c[1]?-1:d[1]>c[1]?1:0),a}let s=[];this._collectObserveTargets("",s);let o=new Map;for(let[a,d]of s)o.set(d,a);let i=[];for(let[a,d]of s)if(d instanceof I)for(let c of d._deps){let u=o.get(c.node);u!=null&&i.push([u,a])}return i.sort((a,d)=>a[0]<d[0]?-1:a[0]>d[0]?1:a[1]<d[1]?-1:a[1]>d[1]?1:0),i}mount(e,t){if(t===void 0){let s=new 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(Ot(e,this.name,"mount"),this._nodes.has(e))throw new Error(`Graph "${this.name}": cannot mount at "${e}" \u2014 node with that name exists`);if(this._mounts.has(e))throw new Error(`Graph "${this.name}": mount "${e}" already exists`);if(r===this)throw new Error(`Graph "${this.name}": cannot mount a graph into itself`);if(r._parent!=null)throw new Error(`Graph "${this.name}": this child graph is already mounted on "${r._parent.name}"`);for(let 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=Nr(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]===ee)return this._resolveMetaChainFromNode(o,s,t.join(F));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(F)}" is invalid`):new Error(`Graph "${this.name}": unknown mount or node "${r}"`);return i.resolve(s.join(F))}_resolveMetaChainFromNode(e,t,r){let s=e,o=0,i=[...t];for(;o<i.length;){if(i[o]!==ee)throw new Error(`Graph "${this.name}": expected ${ee} segment in meta path "${r}"`);if(o+1>=i.length)throw new Error(`Graph "${this.name}": meta path requires a key after ${ee} in "${r}"`);let a=i[o+1],d=s.meta[a];if(!d)throw new Error(`Graph "${this.name}": unknown meta "${a}" in path "${r}"`);s=d,o+=2}return s}signal(e,t){if(t?.internal!==!0){for(let s of e)if(this.config.messageTier(s[0])===3)throw new Error(`Graph "${this.name}": Graph.signal() rejects tier-3 messages (DATA / RESOLVED). Broadcast is for control-plane tiers (START / DIRTY / INVALIDATE / PAUSE / RESUME / COMPLETE / ERROR / TEARDOWN). For per-node value writes, use Graph.set or graph.node(name).down(...).`)}let r=[];if(this._signalDeliver(e,t??{},new Set,r),r.length>0)throw r[0]}_signalDeliver(e,t,r,s){for(let d of this._mounts.values())d._signalDeliver(e,t,r,s);let i=t.internal===!0?{internal:!0}:{actor:t.actor,delivery:"signal"},a=Or(e,this.config);for(let d of[...this._nodes.keys()].sort()){let c=this._nodes.get(d);if(!r.has(c)){r.add(c);try{c.down(e,i)}catch(u){if(u instanceof Q)throw u;s.push(u)}a.length!==0&&this._signalMetaSubtree(c,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(d){if(d instanceof Q)throw d;o.push(d)}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=yr(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=vt(e?.detail,e?.fields),o=e?.detail==="spec",i=s,a=[];this._collectObserveTargets("",a);let d=new Map;for(let[y,w]of a)d.set(w,y);let c=[];{let y=a.map(([,T])=>T),w=new Set(d.values()),S=0;for(;y.length>0;){let T=y.shift();if(T instanceof I)for(let O of T._deps){let E=O.node;if(d.has(E))continue;let x=E.name??"",k=x;if(!k||w.has(k))if(x){let L=2;for(;w.has(`${x}#${L}`);)L++;k=`${x}#${L}`}else for(k=`__internal__/${S++}`;w.has(k);)k=`__internal__/${S++}`;d.set(E,k),w.add(k),c.push([k,E]),y.push(E)}}}let u=[...a,...c],h={};for(let[y,w]of u){if(t!=null&&!w.allowsObserve(t))continue;let S=wt(w,i,o),T=w instanceof I?w._deps.map(k=>d.get(k.node)??k.node.name??""):[],{name:O,...E}=S,x={...E,deps:T};if(!o){let k=this._annotations.get(y);k!=null&&(x.annotation=k)}if(r!=null)if(typeof r=="function"){let k=r;if(!(k.length>=2?k(y,x):k(x)))continue}else{let k=!0;for(let[L,R]of Object.entries(r)){let A=L==="deps_includes"?"depsIncludes":L==="meta_has"?"metaHas":L;if(A==="depsIncludes"){if(!x.deps.includes(String(R))){k=!1;break}continue}if(A==="metaHas"){if(!Object.hasOwn(x.meta??{},String(R))){k=!1;break}continue}if(x[A]!==R){k=!1;break}}if(!k)continue}h[y]=x}let f=new Set(Object.keys(h)),p=[];for(let[y,w]of u)if(w instanceof I)for(let S of w._deps){let T=d.get(S.node);T!=null&&p.push([T,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}${F}`;return[...f].some(S=>S===y||S.startsWith(w))}):b,_=this,v=e;return{name:this.name,nodes:h,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 s=e===""?r:`${e}${r}`;t.push(s),t.push(...this._mounts.get(r)._collectSubgraphs(`${s}${F}`))}return t}resourceProfile(e){return pn(this,e)}reachable(e,t,r={}){return r.withDetail===!0?vn(this.describe(),e,t,{...r,withDetail:!0}):vn(this.describe(),e,t,r)}explain(e,t,r){return r?.reactive===!0?this._explainReactive(e,t,r):this._explainStatic(fe(e),fe(t),{...r?.maxDepth!==void 0?{maxDepth:gn(r.maxDepth)}:{},...r?.findCycle!==void 0?{findCycle:mn(r.findCycle)}:{}})}_explainStatic(e,t,r){let s=this.describe({detail:"full"}),o=new Map(this._annotations),i=new Map;for(let[a,d]of Object.entries(s.nodes))d.lastMutation!=null&&i.set(a,d.lastMutation);return sn(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=oe(s,{name:`${r}_version`}),i=this.observe({timeline:!0,structured:!0}),a=!1,d=!1,c=()=>{a||d||(a=!0,Se(()=>{a=!1,!d&&(s+=1,o.emit(s))}))},u=i.onEvent(v=>{let g=v.type;g!=="data"&&g!=="error"&&g!=="complete"&&g!=="teardown"||c()}),h=[],f=new WeakSet,p=v=>{if(f.has(v)||d)return;f.add(v);let g=v.topology.subscribe(y=>{for(let w of y){if(w[0]!==$)continue;let S=w[1];if(c(),S.kind==="added"&&S.nodeKind==="mount"){let T=v._mounts.get(S.name);T!=null&&p(T)}}});h.push(g);for(let y of v._mounts.keys()){let w=v._mounts.get(y);w!=null&&p(w)}};p(this);let l,b=e.actor;wn(b)&&(l=b.subscribe(v=>{let g=!1,y=!1;for(let w of v){let S=w[0];S===$?g=!0:(S===P||S===D||S===H)&&(y=!0)}g&&c(),y&&(l?.(),l=void 0,c())}));let m;try{m=le([o],()=>this.describe(t),{name:r,describeKind:"derived",meta:{domain:"audit",kind:"describe"},equals:(v,g)=>v===g})}catch(v){u(),l?.();for(let g of h)g();throw i.dispose(),v}let _=Ee(m);return{node:m,dispose(){d=!0,u(),l?.();for(let v of h)v();h.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=St(s,o),a=oe(i,{name:r,meta:{domain:"audit",kind:"describe-diff"},equals:(f,p)=>f===p}),d=this._describeReactive({...e,reactiveName:void 0}),c=!1,u=d.node.subscribe(f=>{if(!c)for(let p of f){if(p[0]!==$)continue;let l=p[1],b=St(o,l);o=l,b.events.length!==0&&a.emit(b)}}),h=Ee(a);return{node:a,dispose(){c=!0,u(),d.dispose(),a.down([[H,"describe-diff disposed"]]),h()}}}_explainReactive(e,t,r){let s=0,o=oe(s,{name:"explain_version"}),i=this.observe({timeline:!0,structured:!0}),a=!1,d=!1,c=()=>{a||d||(a=!0,Se(()=>{a=!1,!d&&(s+=1,o.emit(s))}))},u=i.onEvent(v=>{let g=v.type;g!=="data"&&g!=="error"&&g!=="complete"&&g!=="teardown"||c()}),h=[];e!=null&&ye(e)&&h.push(e),t!=null&&ye(t)&&h.push(t),r?.maxDepth!=null&&ye(r.maxDepth)&&h.push(r.maxDepth),r?.findCycle!=null&&ye(r.findCycle)&&h.push(r.findCycle);let f=()=>{for(let v of h)if(v.cache===void 0)return!1;return!0},p=()=>{let v=fe(e),g=fe(t);return{from:v,to:g,found:!1,reason:"pending",steps:[],text:"(awaiting reactive args)",toJSON:()=>({from:v,to:g,found:!1,reason:"pending",steps:[]})}},l;try{l=le([o],()=>{if(!f())return p();let v=fe(e),g=fe(t),y={...r?.maxDepth!==void 0?{maxDepth:gn(r.maxDepth)}:{},...r?.findCycle!==void 0?{findCycle:mn(r.findCycle)}:{}};return this._explainStatic(v,g,y)},{name:r?.name??"explain",describeKind:"derived",meta:{domain:"audit",kind:"explain_path",from:fe(e),to:fe(t)},equals:(v,g)=>v.found===g.found&&v.reason===g.reason&&v.steps.length===g.steps.length&&Rr(v.steps,g.steps)})}catch(v){throw u(),i.dispose(),v}let b=Ee(l),m=[],_=v=>{let g;return g=v.subscribe(y=>{let w=!1,S=!1;for(let T of y){let O=T[0];O===$?w=!0:(O===P||O===D||O===H)&&(S=!0)}(w||S)&&c(),S&&g&&(g(),g=void 0)}),()=>{g&&(g(),g=void 0)}};for(let v of h)m.push(_(v));return{node:l,dispose(){d=!0,u();for(let v of m)v?.();m.length=0,i.dispose(),b()}}}_pathsMatching(e){let t=et(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}${F}${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}${F}${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}${F}${ee}${F}${s}`;r.push([i,o]),this._appendMetaObserveTargets(i,o,r)}}observe(e,t){let r=typeof e=="string",o=bn(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 u=e,h=this.resolve(u);if(a!=null&&!h.allowsObserve(a))throw new Q({actor:a,action:"observe",nodeName:u});return i?this._buildStructuredObserver([[u,h]],o,"one"):{subscribe(f){return h.subscribe(f)},up(f){try{h.up?.(f)}catch(p){if(p instanceof Q)return;throw p}}}}let d=[];this._collectObserveTargets("",d),d.sort((u,h)=>u[0]<h[0]?-1:u[0]>h[0]?1:0);let c=a==null?d:d.filter(([,u])=>u.allowsObserve(a));return i?this._buildStructuredObserver(c,o,"all"):{subscribe:u=>{let h=c.map(([f,p])=>p.subscribe(l=>{u(f,l)}));return()=>{for(let f of h)f()}},up:(u,h)=>{try{this.resolve(u).up?.(h)}catch(f){if(f instanceof Q)return;throw f}}}}_observeReactive(e,t){let r=t.tiers,s=r!=null?new Set(r):null,o=t.reactiveName??"observe";return ie(i=>{let a=[],d=!1,c=!1,u=()=>{if(a.length===0||c)return;let b={events:a.slice(),flushedAt_ns:ae()};a.length=0,i.emit(b)},h={...t,reactive:!1,structured:!0,timeline:!0},f=e!=null?this.observe(e,h):this.observe(h),p=b=>{c||(a.push(b),!d&&(d=!0,Se(()=>{d=!1,u()})))};for(let b of f.events)p(b);let l=f.onEvent(p);return()=>{c=!0,l(),f.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 u=this.resolve(s);return this._buildStructuredObserver([[s,u]],i,"one")}let a=[];this._collectObserveTargets("",a),a.sort((u,h)=>u[0]<h[0]?-1:u[0]>h[0]?1:0);let d=i.actor,c=d==null?a:a.filter(([,u])=>u.allowsObserve(d));return this._buildStructuredObserver(c,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",d=this.config.inspectorEnabled,c=(o||i)&&d,u=t.maxEvents,h=u!=null&&u>0?new Le(u):null,f=[],p=new Set,l=t.tiers!=null?new Set(t.tiers):null,b={},m=new Set,_=0,v=0,g=0,y=0,w=0,S=0,T=!1,O=!1,E=0,x=new Map,k=new Map,L=new Map,R=N=>{if(!(l!=null&&!l.has(N.type))){h?h.push(N):f.push(N);for(let M of p)M(N)}},A=N=>l==null||l.has(N),te=()=>s?{timestamp_ns:ae(),in_batch:ze(),batch_id:E}:{},be=(N,M)=>{if(!(!c||!(N instanceof I)))return N._setInspectorHook(X=>{if(X.kind==="dep_message")x.set(N,X.depIndex);else if(X.kind==="run"){let Ce=X.batchData.map((G,U)=>G!=null&&G.length>0?G.at(-1):X.prevData[U]);k.set(N,Ce);let Z=X.batchData.map(G=>G!=null?[...G]:void 0);L.set(N,Z),i&&R({type:"derived",path:M,dep_values:Ce,dep_batches:Z,...te()})}})},z=N=>{let M=x.get(N),X=k.get(N);if(!o||X==null)return{};let Z=(M!=null&&M>=0&&N instanceof I?N._deps[M]:void 0)?.node,G=Z?.v,U=L.get(N);return{trigger_dep_index:M,trigger_dep_name:Z?.name,...G!=null?{trigger_version:{id:G.id,version:G.version}}:{},dep_values:[...X],...U!=null?{dep_batches:U}:{}}},J=[],W=[];for(let[N,M]of e){let X=be(M,N);X&&J.push(X),W.push(M.subscribe(Ce=>{E++;for(let Z of Ce){let G=Z[0],U=te();if(G===$){b[N]=Z[1];let ot=M instanceof I?M.lastMutation?.actor??ve:ve;R({type:"data",path:N,data:Z[1],actor:ot,...U,...z(M)})}else if(a)G===q?A("dirty")&&_++:G===K?A("resolved")&&v++:G===re?A("invalidate")&&g++:G===se?A("pause")&&y++:G===de?A("resume")&&w++:G===H?A("teardown")&&S++:G===P&&!m.has(N)?A("complete")&&(T=!0):G===D&&A("error")&&(O=!0,m.add(N));else if(G===q)A("dirty")&&_++,R({type:"dirty",path:N,...U});else if(G===K)A("resolved")&&v++,R({type:"resolved",path:N,...U,...z(M)});else if(G===re)A("invalidate")&&g++,R({type:"invalidate",path:N,...U});else if(G===se)A("pause")&&y++,R({type:"pause",path:N,lockId:Z[1],...U});else if(G===de)A("resume")&&w++,R({type:"resume",path:N,lockId:Z[1],...U});else if(G===P)A("complete")&&!m.has(N)&&(T=!0),R({type:"complete",path:N,...U});else if(G===D){A("error")&&(O=!0,m.add(N));let ot=M instanceof I?M.lastMutation?.actor??ve:ve;R({type:"error",path:N,data:Z[1],actor:ot,...U})}else G===H&&(A("teardown")&&S++,R({type:"teardown",path:N,...U}))}}))}let Y=!1,B=()=>{if(!Y){Y=!0;for(let N of W)N();for(let N of J)N();for(let N of Be)N({value:void 0,done:!0});Be.length=0}},ne=[],Be=[];p.add(N=>{let M=Be.shift();M?M({value:N,done:!1}):ne.push(N)});let Ct={get values(){return b},get dirtyCount(){return _},get resolvedCount(){return v},get invalidateCount(){return g},get pauseCount(){return y},get resumeCount(){return w},get teardownCount(){return S},get events(){return h?h.toArray():[...f]},get anyCompletedCleanly(){return T},get anyErrored(){return O},get completedWithoutErrors(){return T&&!O},onEvent(N){return p.add(N),()=>p.delete(N)},dispose:B,expand(N){B();let M={...t};return typeof N=="string"?M.detail=N:Object.assign(M,N),r(bn(M))},[Symbol.asyncIterator](){return{next(){return ne.length>0?Promise.resolve({value:ne.shift(),done:!1}):Y?Promise.resolve({value:void 0,done:!0}):new Promise(N=>Be.push(N))},return(){return B(),Promise.resolve({value:void 0,done:!0})}}}};return t.format!=null&&this._attachFormatLogger(Ct,t),Ct}_attachFormatLogger(e,t){let r=t.format;if(r==null)return;let s=t.logger??(l=>console.log(l)),o=t.includeTypes?new Set(t.includeTypes):null,i=t.excludeTypes?new Set(t.excludeTypes):null,a=o==null&&i==null?()=>!0:l=>(o==null||o.has(l))&&(i==null||!i.has(l)),d=kr(t.theme),c=r==="stage-log"?ae():0,u=l=>l==null?"":t.stageLabels?.[l]??l,h=(l,b)=>l.length>b?`${l.slice(0,b-1)}\u2026`:l,f=l=>l.type==="data"||l.type==="error"?h(Nt(l.data),120):"",p=l=>{if(r==="stage-log"){let T=(ae()-c)/1e9,O=u(l.path).padEnd(9);if(l.type==="data"){let E=f(l);return`[${T.toFixed(3)}s] ${O} \u2190${E?` ${E}`:""}`}if(l.type==="error"){let E=f(l);return`[${T.toFixed(3)}s] ${O} \u2717${E?` ${E}`:""}`}return l.type==="complete"?`[${T.toFixed(3)}s] ${O} \u25A0 complete`:`[${T.toFixed(3)}s] ${O} ${l.type}`}if(r==="json")try{return JSON.stringify(l)}catch{return JSON.stringify({type:l.type,path:l.path,data:"[unserializable]"})}let b=d[l.type]??"",m=l.path?`${d.path}${l.path}${d.reset} `:"",_=l.type==="data"||l.type==="error",v=l.type==="pause"||l.type==="resume",g=_?` ${Nt(l.data)}`:v?` ${Nt(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()}${d.reset}${g}${w}${S}`};e.onEvent(l=>{a(l.type)&&s(p(l),l)})}addDisposer(e){return this._disposers.add(e),()=>{this._disposers.delete(e)}}destroy(){Qe(this._disposers,this.name),this.signal([[H]],{internal:!0}),Qe(this._storageDisposers,this.name);for(let e of[...this._mounts.values()])e._parent=void 0,e._destroyClearOnly();this._mounts.clear(),this._nodes.clear(),this._parent=void 0,this._destroyed=!0}get destroyed(){return this._destroyed}_destroyClearOnly(){Qe(this._disposers,this.name),Qe(this._storageDisposers,this.name);for(let e of[...this._mounts.values()])e._parent=void 0,e._destroyClearOnly();this._mounts.clear(),this._nodes.clear(),this._parent=void 0,this._destroyed=!0}snapshot(e){let{expand:t,...r}=this.describe({detail:"full"}),s={};for(let a of Object.keys(r.nodes).sort()){let{lastMutation:d,guard:c,...u}=r.nodes[a];s[a]=u}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 Mt(a,a.encode(i))}throw new Error(`snapshot: unknown format "${String(e.format)}"`)}static decode(e,t){let r=t?.config??Oe,{codec:s,codecVersion:o,payload:i}=$t(e,r);return s.decode(i,o)}restore(e,t){if(yn(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=>et(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 d=this.tryResolve(o)?.v;if(d!=null&&d.id===i.v.id&&d.version===i.v.version)continue}try{this.set(o,i.value)}catch(a){t?.onError?.(o,a)}}}}}static fromSnapshot(e,t){yn(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 p of[...e.subgraphs].sort((l,b)=>{let m=l.split(F).length,_=b.split(F).length;return m!==_?m-_:l<b?-1:l>b?1:0})){let l=p.split(F),b=o;for(let m of l)b._mounts.has(m)||b.mount(m,new n(m)),b=b._mounts.get(m)}let i=s?Object.entries(s).map(([p,l])=>({re:et(p),factory:l})):[],a=p=>{for(let l of i)if(l.re.test(p))return l.factory},d=p=>{let l=p.split(F),b=l.pop();if(b==null||b.length===0)throw new Error(`invalid snapshot path "${p}"`);let m=o;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(`${F}${ee}${F}`)).sort((p,l)=>p[0]<l[0]?-1:p[0]>l[0]?1:0),u=new Map(c),h=new Map,f=!0;for(;u.size>0&&f;){f=!1;for(let[p,l]of[...u.entries()]){let b=l?.deps??[];if(!b.every(w=>h.has(w)))continue;let[m,_]=d(p),v={...l?.meta??{}},g=a(p),y;if(l?.type==="state")y=oe(l.value,{meta:v});else{if(g==null)continue;y=g(_,{path:p,type:l.type,value:l.value,meta:v,deps:b,resolvedDeps:b.map(w=>h.get(w))})}m.add(y,{name:_}),h.set(p,y),u.delete(p),f=!0}}if(u.size>0){let p=[...u.keys()].sort().join(", ");throw new Error(`Graph.fromSnapshot could not reconstruct nodes without build callback: ${p}. Pass matching factories via fromSnapshot(data, { factories: { pattern: factoryFn } }).`)}return o.restore(e),o}toJSON(){return this.snapshot()}attachSnapshotStorage(e,t={}){let 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 s=(c,u)=>{if(c.disposed)return;let h=br(u.nodes);if(c.lastSnapshot!=null&&h!==""&&h===c.lastFingerprint)return;let f=c.seq+1,p=ke(),m=c.lastSnapshot==null||f%c.compactEvery===0?{name:this.name,mode:"full",snapshot:u,seq:f,timestamp_ns:p,format_version:pe}:{name:this.name,mode:"diff",diff:xr(c.lastSnapshot,u),seq:f,timestamp_ns:p,format_version:pe};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=u,c.lastFingerprint=h)},w=>{t.onError?.(w,c.tier)});c.savePending=y.finally(()=>{c.savePending===y&&(c.savePending=void 0)})}else c.seq=f,c.lastSnapshot=u,c.lastFingerprint=h},o=(c,u)=>{try{s(c,u)}catch(h){t.onError?.(h,c.tier)}},i=(c,u)=>{if(!u.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=wt(l,vt("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?o(l,p()):(l.timer==null&&(l.timer=new Je),l.timer.start(l.debounceMs,()=>{l.disposed||o(l,this.snapshot())})))},a;if(t.paths!=null){let u=(typeof t.paths=="string"?this._pathsMatching(t.paths):t.paths).map(h=>{let f=this.tryResolve(h);return f==null?()=>{}:f.subscribe(p=>i(h,p))});a=()=>{for(let h of u)h()}}else a=this.observe().subscribe((c,u)=>i(c,u));let d=()=>{a();for(let c of r)c.disposed=!0,c.timer?.cancel();this._storageDisposers.delete(d)};return this._storageDisposers.add(d),{dispose:d}}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===pe&&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(d){r?.onError?.(d,s);continue}if(o==null||typeof o!="object"||Array.isArray(o))continue;let i=o,a=i.mode==="full"&&i.snapshot!=null?i.snapshot:i.version===pe&&i.nodes!=null?i:void 0;if(a!=null)try{return n.fromSnapshot(a,r)}catch(d){r?.onError?.(d,s)}}throw new Error(`Graph.fromStorage: no tier held a restorable record for "${e}" across ${t.length} tier(s)`)}_annotations=new Map;_traceRing;trace(e,t,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:ae(),...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(v=>!r.has(v)).sort(),i=[...r].filter(v=>!s.has(v)).sort(),a=[],d=[];for(let v of r){if(!s.has(v))continue;let g=e.nodes[v],y=t.nodes[v],w=g.v,S=y.v;w!=null&&S!=null&&w.id===S.id&&w.version!==S.version&&d.push({path:v,id:w.id,from:w.version,to:S.version});let T=w!=null&&S!=null&&w.id===S.id&&w.version===S.version;for(let O of["type","status","sentinel"]){let E=g[O],x=y[O];E!==x&&a.push({path:v,field:O,from:E,to:x})}if(!T)for(let O of["value","meta"]){let E=g[O],x=y[O];vr(E,x)||a.push({path:v,field:O,from:E,to:x})}}let c=v=>`${v.from} ${v.to}`,u=new Set(e.edges.map(c)),h=new Set(t.edges.map(c)),f=t.edges.filter(v=>!u.has(c(v))),p=e.edges.filter(v=>!h.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:o,nodesRemoved:i,nodesChanged:a,versionChanges:d,edgesAdded:f,edgesRemoved:p,subgraphsAdded:m,subgraphsRemoved:_}}}});function Sn(n,e,t){return{[n]:!0,[`${n}_type`]:e,...t??{}}}var kn=j(()=>{"use strict"});var Fr={};Bn(Fr,{SNAPSHOT_WIRE_VERSION:()=>Dt,SurfaceError:()=>C,asSurfaceError:()=>Cn,createGraph:()=>nt,deleteSnapshot:()=>jn,diffSnapshots:()=>Fn,listSnapshots:()=>Pn,restoreSnapshot:()=>$n,runReduction:()=>Gn,saveSnapshot:()=>Mn});module.exports=zn(Fr);je();xt();Ue();ue();xe();je();kn();Pe();ue();function Tn(n,e){let t=n.cache??0;return t>=e?!1:(n.down([[q],[$,t+1]]),!0)}var Vo=zt((n,e)=>{n("observe"),n("signal"),e("write")});Tt();function Nn(n,e){return Sn("reduction",n,e)}function On(n,e,t,r){let s=r?.maxIterations??10,o=`__feedback_${e}`,i=oe(0,{meta:Nn("feedback_counter",{maxIterations:s,feedbackFrom:e,feedbackTo:t})});n.add(i,{name:o});let a=n.resolve(e),d=n.resolve(t),c=`__feedback_effect_${e}`,u=me([],(h,f)=>{let p=a.subscribe(l=>{for(let b of l){let m=b[0];if(m===$){let _=b[1];if(_==null)return;$e(()=>{Tn(i,s)&&d.emit(_)})}else if(m===P||m===D){let _=m===D&&b.length>1?[D,b[1]]:[m];i.down([_])}}});return()=>p()},{name:c,describeKind:"effect",meta:{...Nn("feedback_effect",{feedbackFrom:e,feedbackTo:t}),_internal:!0}});return n.add(u,{name:c}),n.addDisposer(Ee(u)),n}function Ae(n){let e=n.meta?.factory;return typeof e=="string"?e:void 0}function De(n){let e=n.meta?.factoryArgs;return e!=null&&typeof e=="object"?e:{}}function xn(n){let e=De(n);return"initial"in e?e.initial:n.value}function En(n){return typeof n=="object"&&n!==null&&"factory"in n}function An(n){return typeof n=="object"&&n!==null&&"factory"in n}function Er(n){return En(n)?n.factory:n}function Ar(n){return An(n)?n.factory:n}function Rt(n,e){let t=[],r=new Set(Object.keys(e.fns??{})),s=new Set(Object.keys(e.sources??{}));for(let[o,i]of Object.entries(n.nodes)){if(i.type==="template")continue;let a=i,d=Ae(a);if(d==null)continue;let c=a.type==="producer";if(a.type==="state"&&d==="state")continue;if(c){let h=s.has(d),f=r.has(d);if(!h&&!f&&(s.size>0||r.size>0)){let p=tt(d,s)??tt(d,r);t.push(`Node "${o}": source "${d}" not found in catalog`+(p?`. Did you mean "${p}"?`:""))}}else if(r.size>0&&!r.has(d))if(s.has(d))t.push(`Node "${o}": fn "${d}" is a source, not a function. Use it as a producer source instead, or use a function from: ${[...r].join(", ")}`);else{let h=tt(d,r);t.push(`Node "${o}": fn "${d}" not found in catalog`+(h?`. Did you mean "${h}"?`:""))}let u=De(a);if(!c&&e.fns?.[d]){let h=e.fns[d];if(En(h)&&h.configSchema){for(let[f,p]of Object.entries(h.configSchema))if(p.required!==!1&&!(f in u)&&t.push(`Node "${o}": config missing required field "${f}"`),f in u&&p.enum){let l=u[f];p.enum.includes(l)||t.push(`Node "${o}": config.${f} = ${JSON.stringify(l)}, expected one of: ${p.enum.join(", ")}`)}}}if(c&&e.sources?.[d]){let h=e.sources[d];if(An(h)&&h.configSchema){for(let[f,p]of Object.entries(h.configSchema))if(p.required!==!1&&!(f in u)&&t.push(`Node "${o}": config missing required field "${f}"`),f in u&&p.enum){let l=u[f];p.enum.includes(l)||t.push(`Node "${o}": config.${f} = ${JSON.stringify(l)}, expected one of: ${p.enum.join(", ")}`)}}}}if(n.templates)for(let[o,i]of Object.entries(n.templates))for(let[a,d]of Object.entries(i.nodes)){let c=Ae(d);if(c!=null&&!(d.type==="state"&&c==="state")&&d.type!=="producer"&&r.size>0&&!r.has(c)){let u=tt(c,r);t.push(`Template "${o}" node "${a}": fn "${c}" not found in catalog`+(u?`. Did you mean "${u}"?`:""))}}return{valid:t.length===0,errors:t,warnings:[]}}function tt(n,e){let t=null,r=1/0,s=n.toLowerCase();for(let o of e){let i=Dr(s,o.toLowerCase());i<r&&i<=Math.max(3,Math.floor(n.length/2))&&(r=i,t=o)}return t}function Dr(n,e){let t=n.length,r=e.length,s=Array.from({length:t+1},(o,i)=>Array.from({length:r+1},(a,d)=>i===0?d:d===0?i:0));for(let o=1;o<=t;o++)for(let i=1;i<=r;i++)s[o][i]=n[o-1]===e[i-1]?s[o-1][i-1]:1+Math.min(s[o-1][i],s[o][i-1],s[o-1][i-1]);return s[t][r]}var Rn=new Set(["state","producer","derived","effect","operator","template"]),Cr=new Set(["state","producer","derived","effect","operator"]);function Et(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 s=new Set(Object.keys(r.nodes)),o=new Map,i=new Map;if(r.templates!=null&&typeof r.templates=="object"&&!Array.isArray(r.templates)){for(let[a,d]of Object.entries(r.templates))if(d!=null&&typeof d=="object"){let c=d;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,d]of Object.entries(r.templates)){if(d==null||typeof d!="object"){e.push(`Template "${a}": must be an object`);continue}let c=d;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 u=new Set(Array.isArray(c.params)?c.params:[]),h=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"||!Cr.has(l.type))&&e.push(`Template "${a}" node "${f}": invalid type`),Array.isArray(l.deps))for(let b of l.deps)!h.has(b)&&!u.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,d]of Object.entries(r.nodes)){if(d==null||typeof d!="object"){e.push(`Node "${a}": must be an object`);continue}let c=d;if(typeof c.type!="string"||!Rn.has(c.type)){e.push(`Node "${a}": invalid type "${String(c.type)}" (expected: ${[...Rn].join(", ")})`);continue}if(o.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 u=i.get(c.template),h=c.bind;for(let f of u.params)f in h||e.push(`Node "${a}": template param "${f}" is not bound (template "${c.template}")`);for(let[,f]of Object.entries(h))typeof f=="string"&&!s.has(f)&&e.push(`Node "${a}": bind target "${f}" does not reference an existing node`)}else{if(Array.isArray(c.deps))for(let u of c.deps)u===a?e.push(`Node "${a}": self-referencing dep`):s.has(u)||e.push(`Node "${a}": dep "${u}" 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 d=r.feedback[a];if(d==null||typeof d!="object"){e.push(`Feedback [${a}]: must be an object`);continue}let c=d;typeof c.from!="string"||!s.has(c.from)?e.push(`Feedback [${a}]: 'from' "${String(c.from)}" does not reference an existing node`):o.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"||!s.has(c.to)?e.push(`Feedback [${a}]: 'to' "${String(c.to)}" does not reference an existing node`):typeof c.to=="string"&&o.get(c.to)!=="state"&&e.push(`Feedback [${a}]: 'to' node "${c.to}" must be a state node (got "${o.get(c.to)??"unknown"}")`)}return{valid:e.length===0,errors:e,warnings:t}}function Dn(n,e){let t=Et(n);if(!t.valid)throw new Error(`compileSpec: invalid GraphSpec:
4
- ${t.errors.join(`
5
- `)}`);let r=n.factory,s=n.factoryArgs;if(typeof r=="string"){let g=e?.catalog?.graphFactories?.[r];if(g)return g(s)}let o=e?.catalog??{},i=e?.onMissing??"placeholder",a=new ce(n.name),d=n.templates??{},c=Rt(n,o);if(!c.valid)throw new Error(`compileSpec: catalog validation errors:
6
- ${c.errors.join(`
7
- `)}`);let u=[],h=(g,y,w)=>{u.push({path:g,kind:y,name:w})},f=g=>{let y=o.fns?.[g];return y?Er(y):void 0},p=g=>{let y=o.sources?.[g];return y?Ar(y):void 0},l=g=>{if(!g)return;let y={};for(let[w,S]of Object.entries(g))w==="factory"||w==="factoryArgs"||(y[w]=S);return Object.keys(y).length>0?y:void 0},b=new Map,m=[];for(let[g,y]of Object.entries(n.nodes)){if(y.type==="template")continue;let w=y,S=Ae(w),T=De(w);if(w.type==="state"){let O=xn(w),E=oe(O,{name:g,meta:l(w.meta)});a.add(E,{name:g}),b.set(g,E)}else if(w.type==="producer"){let O=S?p(S):void 0,E=S?f(S):void 0;if(O){let x=O(T);a.add(x,{name:g}),b.set(g,x)}else if(E){let x=E([],T);a.add(x,{name:g}),b.set(g,x)}else{S&&h(g,"source",S);let x=ie(()=>{},{name:g,meta:{...l(w.meta),_specSource:S}});a.add(x,{name:g}),b.set(g,x)}}else m.push([g,w])}let _=!0,v=new Map(m);for(;v.size>0&&_;){_=!1;for(let[g,y]of[...v.entries()]){let w=y.deps??[];if(!w.every(k=>b.has(k)))continue;let S=w.map(k=>b.get(k)),T=Ae(y),O=De(y),E=T?f(T):void 0,x;E?x=E(S,O):y.type==="effect"?(T&&h(g,"fn",T),x=Re(S,()=>{})):(T&&h(g,"fn",T),x=le(S,k=>k[0])),a.add(x,{name:g}),b.set(g,x),v.delete(g),_=!0}}if(v.size>0){let g=[...v.keys()].sort().join(", ");throw new Error(`compileSpec: unresolvable deps for nodes: ${g}`)}for(let[g,y]of Object.entries(n.nodes)){if(y.type!=="template")continue;let w=y,S=d[w.template],T=new ce(g),O=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),be={...A,deps:te},z=Ae(A),J=De(A);if(A.type==="state"){let W=xn(A),Y=oe(W,{name:R,meta:l(A.meta)});T.add(Y,{name:R}),O.set(R,Y)}else if(A.type==="producer"){let W=z?p(z):void 0,Y=z?f(z):void 0;if(W){let B=W(J);T.add(B,{name:R}),O.set(R,B)}else if(Y){let B=Y([],J);T.add(B,{name:R}),O.set(R,B)}else{z&&h(`${g}.${R}`,"source",z);let B=ie(()=>{},{name:R,meta:{...l(A.meta),_specSource:z}});T.add(B,{name:R}),O.set(R,B)}}else E.push([R,be])}let x=!0,k=new Map(E);for(;k.size>0&&x;){x=!1;for(let[R,A]of[...k.entries()]){let te=A.deps??[];if(!te.every(ne=>O.has(ne)||b.has(ne)))continue;let z=te.map(ne=>O.get(ne)??b.get(ne)),J=Ae(A),W=De(A),Y=J?f(J):void 0,B;Y?B=Y(z,W):A.type==="effect"?(J&&h(`${g}.${R}`,"fn",J),B=Re(z,()=>{})):(J&&h(`${g}.${R}`,"fn",J),B=le(z,ne=>ne[0])),T.add(B,{name:R}),O.set(R,B),k.delete(R),x=!0}}if(k.size>0){let R=[...k.keys()].sort().join(", ");throw new Error(`compileSpec: template "${w.template}" has unresolvable deps: ${R}`)}a.mount(g,T);let L=`${g}::${S.output}`;b.set(g,a.resolve(L));try{let R=a.resolve(L);R.meta._templateName?.emit(w.template),R.meta._templateBind?.emit(w.bind)}catch{}}for(let g of n.feedback??[])On(a,g.from,g.to,{maxIterations:g.maxIterations});if(u.length>0){if(i==="error"){let g=u.map(y=>` - ${y.path}: missing ${y.kind} "${y.name}"`);throw new Error(`compileSpec: ${u.length} catalog entr${u.length===1?"y":"ies"} missing \u2014 pass them via opts.catalog or set opts.onMissing to "warn"/"placeholder":
8
- ${g.join(`
9
- `)}`)}if(i==="warn"){let g=e?.onWarn??(y=>console.warn(y));for(let y of u)g(`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=Gr(this.details);t!==void 0&&(e.details=t)}return e}};function Gr(n){try{return JSON.parse(JSON.stringify(n))}catch{return}}function Cn(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 nt(n,e){let t=Et(n);if(!t.valid)throw new C("invalid-spec",`GraphSpec validation failed:
10
- ${t.errors.join(`
11
- `)}`,{errors:t.errors});let r=e?.catalog??{},s=Rt(n,r);if(!s.valid)throw new C("catalog-error",`Catalog validation failed:
12
- ${s.errors.join(`
13
- `)}`,{errors:s.errors});try{return Dn(n,e)}catch(o){let i=o instanceof Error?o.message:String(o);throw new C("catalog-error",i)}}ue();var Mr=3e4;async function Gn(n,e,t){let r=t?.inputPath??"input",s=t?.outputPath??"output",o=t?.timeoutMs??Mr,i=nt(n,{catalog:t?.catalog}),a;try{a=i.resolve(s)}catch{throw i.destroy(),new C("node-not-found",`reduce: output path "${s}" is not registered`,{path:s})}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((d,c)=>{let u=!1,h=!1,f,p,l=!1,b=m=>{h||(h=!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(h)return;if(u){if(_[0]===$){b(()=>d(_[1]));return}if(_[0]===K){let v=a.cache;b(()=>d(v));return}if(_[0]===D){let v=_[1],g=v instanceof Error?v.message:String(v),y=v instanceof Error?v:void 0;b(()=>c(new C("internal-error",`reduce: output emitted ERROR: ${g}`,y!=null?{cause:y}:void 0)));return}if(_[0]===P){b(()=>c(new C("internal-error","reduce: output COMPLETEd without a post-push DATA")));return}}}}),l&&(p?.(),p=void 0),u=!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}!h&&Number.isFinite(o)&&o>0&&(f=setTimeout(()=>{b(()=>c(new C("reduce-timeout",`reduce: no output emitted within ${o}ms`,{timeoutMs:o,outputPath:s})))},o),f.unref?.())})}finally{i.destroy()}}Fe();xt();var Dt=pe,Ie="snapshot:";function Ve(n){if(n.startsWith(Ie))throw new C("snapshot-failed",`snapshot id must not start with "${Ie}" (reserved); got "${n}"`,{snapshotId:n})}function rt(n){return`${Ie}${n}`}function $r(n){return n.startsWith(Ie)?n.slice(Ie.length):void 0}function At(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 Mn(n,e,t){Ve(e);let r;try{r=n.snapshot()}catch(o){let i=o instanceof Error?o.message:String(o);throw new C("snapshot-failed",`snapshot "${e}" serialization failed: ${i}`,{snapshotId:e})}let s={name:n.name,mode:"full",seq:0,timestamp_ns:ke(),format_version:Dt,snapshot:r};try{await t.save(rt(e),s)}catch(o){let i=o instanceof Error?o.message:String(o);throw new C("snapshot-failed",`snapshot "${e}" save failed: ${i}`,{snapshotId:e})}return{snapshotId:e,timestamp_ns:s.timestamp_ns}}async function $n(n,e,t){Ve(n);let r=rt(n),s=await e.load(r);s===void 0&&(s=await e.load(n));let o=At(s,n);try{return ce.fromSnapshot(o,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 Fn(n,e,t){Ve(n),Ve(e);let r=async d=>{let c=rt(d),u=await t.load(c);return u===void 0&&(u=await t.load(d)),u},[s,o]=await Promise.all([r(n),r(e)]),i=At(s,n),a=At(o,e);return ce.diff(i,a)}async function Pn(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=[],s=e?.includeUnprefixed===!0;for(let o of t){let i=$r(o);i!==void 0?r.push(i):s&&r.push(o)}return r}async function jn(n,e){if(Ve(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(rt(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,9 +0,0 @@
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-CS0LTlB8.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-CSOmP7xT.cjs';
3
- import '../../sugar-DQjFmVqb.cjs';
4
- import '../../node-kK3CvTrR.cjs';
5
- import '../../graph-CWvEUQAq.cjs';
6
- import '../../extra/storage-core.cjs';
7
- import '../../extra/storage-tiers.cjs';
8
- import '../../types-C0_yquda.cjs';
9
- import '../../extra/sources.cjs';
@@ -1,9 +0,0 @@
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-CMh5Rz1y.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-CYq8vAyV.js';
3
- import '../../sugar-fhLIE7TT.js';
4
- import '../../node-kK3CvTrR.js';
5
- import '../../graph-D9LFnda9.js';
6
- import '../../extra/storage-core.js';
7
- import '../../extra/storage-tiers.js';
8
- import '../../types-CWFysE9E.js';
9
- import '../../extra/sources.js';
@@ -1 +0,0 @@
1
- import{a,b,c,d,e,f,g,h,i,j}from"../../chunk-HY4DJBA7.js";import"../../chunk-APPIWSGD.js";import"../../chunk-Z4NPUARF.js";import"../../chunk-W3I423PS.js";import"../../chunk-L6NSJVJZ.js";import"../../chunk-HITNVN6B.js";import"../../chunk-ESMPEKEV.js";import"../../chunk-CLVB32RD.js";import"../../chunk-4VVTGLXJ.js";import"../../chunk-GHBWHMRZ.js";import"../../chunk-YBB7ZGTY.js";import"../../chunk-CRVT7D2P.js";import"../../chunk-NTEURFZH.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,223 +0,0 @@
1
- import { V as VersioningLevel, b as NodeGuard, N as Node } from './node-kK3CvTrR.js';
2
- import { AppendLogStorageTier } from './extra/storage-tiers.js';
3
-
4
- type ReactiveLogOptions<T> = {
5
- name?: string;
6
- maxSize?: number;
7
- /**
8
- * Optional versioning level for the underlying `entries` state node. Set
9
- * at construction time; cannot be changed later. Pass `0` for V0 identity
10
- * + monotonic version counter, or `1` for V1 + content-addressed cid.
11
- */
12
- versioning?: VersioningLevel;
13
- /**
14
- * Optional guard policy applied to the `entries` node. Use to deny
15
- * external `write` while permitting `observe` / `signal` — eliminates the
16
- * passthrough-derived pattern in CQRS event streams (Audit 1 #7).
17
- */
18
- guard?: NodeGuard;
19
- /**
20
- * Storage backend. Defaults to `NativeLogBackend` (ring buffer if `maxSize` is set,
21
- * flat array otherwise). Users can plug in persistent / RRB-tree backends via
22
- * the {@link LogBackend} interface.
23
- */
24
- backend?: LogBackend<T>;
25
- };
26
- /**
27
- * Discriminated view spec for {@link ReactiveLogBundle.view}. New `kind`s
28
- * (e.g. `"filter"`, `"windowByTime"`) layer in without new methods.
29
- */
30
- type ViewSpec<_T = unknown> = {
31
- kind: "tail";
32
- n: number;
33
- } | {
34
- kind: "slice";
35
- start: number;
36
- stop?: number;
37
- } | {
38
- kind: "fromCursor";
39
- cursor: Node<number>;
40
- };
41
- type ReactiveLogBundle<T> = {
42
- /** Emits `readonly T[]` on each append/clear/trim (two-phase). */
43
- readonly entries: Node<readonly T[]>;
44
- /** Current entry count (O(1)). */
45
- readonly size: number;
46
- /** Positional access (O(1)); returns `undefined` on out-of-range. Supports negative indices. */
47
- at: (index: number) => T | undefined;
48
- append: (value: T) => void;
49
- /** Push all values, emit one snapshot. No-op if `values` is empty. */
50
- appendMany: (values: readonly T[]) => void;
51
- clear: () => void;
52
- /** Remove the first `n` entries (clamped to `size`). */
53
- trimHead: (n: number) => void;
54
- /**
55
- * Activate the {@link ReactiveLogBundle.lastValue} / {@link ReactiveLogBundle.hasLatest}
56
- * companion nodes (lazy — installed on first call, reused thereafter).
57
- * Returns `entries` so chaining reads naturally.
58
- *
59
- * **Companion-node access is on the bundle** (not `entries.meta`) because
60
- * `Node.meta` is frozen at construction; bundle-level lazy properties
61
- * give the same semantics with simpler ergonomics.
62
- */
63
- withLatest: () => Node<readonly T[]>;
64
- /**
65
- * Most-recently-appended value, or `undefined` if no entries exist (spec
66
- * §5.12 SENTINEL alignment). Accessing this property activates the
67
- * companion lazily — same as calling {@link ReactiveLogBundle.withLatest}.
68
- *
69
- * **Empty-log path emits `RESOLVED`, not `DATA(undefined)`.** When the log
70
- * holds no entries, `lastValue` settles via `[[RESOLVED]]` so the §1.2
71
- * "DATA(undefined) is not a valid emission" invariant stands.
72
- *
73
- * **Caveat when `T` itself includes `undefined`:** if a literal `undefined`
74
- * value is appended, `lastValue` emits `[[DATA, undefined]]` for that
75
- * append wave — the per-value semantics are intentionally preserved so
76
- * subscribers can observe the transition. Use
77
- * {@link ReactiveLogBundle.hasLatest} to disambiguate "no entries yet"
78
- * from "an undefined value was appended"; `lastValue.cache` alone cannot
79
- * tell them apart.
80
- */
81
- readonly lastValue: Node<T | undefined>;
82
- /** Reactive `true` once at least one entry has been appended. */
83
- readonly hasLatest: Node<boolean>;
84
- /**
85
- * Reactive view per discriminated `ViewSpec`. Memoized per-spec — repeat
86
- * calls with identical spec return the same node.
87
- */
88
- view: (spec: ViewSpec<T>) => Node<readonly T[]>;
89
- /**
90
- * Subscribe to `upstream` and append every DATA into this log. Returns a
91
- * disposer. ERROR / COMPLETE on `upstream` propagate through the disposer
92
- * (caller is responsible for terminal handling on the log).
93
- */
94
- attach: (upstream: Node<T>) => () => void;
95
- /**
96
- * Wire one or more append-log storage tiers. Each tier receives entries on
97
- * every append wave; tier-internal flush/rollback honors the wave-as-
98
- * transaction model (Audit 4). Returns a disposer.
99
- */
100
- attachStorage: (tiers: readonly AppendLogStorageTier<T>[]) => () => void;
101
- /** Releases all cached views (tail + slice + fromCursor). */
102
- disposeAllViews: () => void;
103
- /** Releases all internal keepalives. Idempotent. */
104
- dispose: () => void;
105
- };
106
- /**
107
- * Storage contract for {@link reactiveLog}. Implementations own the mutable state and
108
- * expose a monotonic `version` counter that increments on every structural change.
109
- *
110
- * **Audit 1:** `snapshot()` returns an immutable readonly view (codec encodes
111
- * at the storage tier boundary). `restore(values)` replaces backend state on
112
- * cold-tier startup load — fires one DATA emission for the restored shape.
113
- *
114
- * @category extra
115
- */
116
- interface LogBackend<T> {
117
- readonly version: number;
118
- readonly size: number;
119
- at(index: number): T | undefined;
120
- append(value: T): void;
121
- appendMany(values: readonly T[]): void;
122
- clear(): number;
123
- trimHead(n: number): number;
124
- slice(start: number, stop?: number): readonly T[];
125
- tail(n: number): readonly T[];
126
- toArray(): readonly T[];
127
- /** Immutable snapshot for codec serialization. Equivalent to `toArray()`. */
128
- snapshot(): readonly T[];
129
- /** Replace backend state with `values` (used by cold-tier restore). */
130
- restore(values: readonly T[]): void;
131
- }
132
- /**
133
- * Default append-only log backend.
134
- *
135
- * - When `maxSize` is set: uses a **ring buffer** with `_head` index and circular
136
- * modular arithmetic. Append and trim become O(1); snapshot is O(size) unrolling.
137
- * - When `maxSize` is unset: uses a flat array with standard push/splice.
138
- *
139
- * @category extra
140
- */
141
- declare class NativeLogBackend<T> implements LogBackend<T> {
142
- private _version;
143
- private readonly _maxSize?;
144
- private readonly _buf;
145
- private _head;
146
- private _size;
147
- constructor(initial?: readonly T[], maxSize?: number);
148
- get version(): number;
149
- get size(): number;
150
- at(index: number): T | undefined;
151
- append(value: T): void;
152
- appendMany(values: readonly T[]): void;
153
- clear(): number;
154
- trimHead(n: number): number;
155
- slice(start: number, stop?: number): readonly T[];
156
- tail(n: number): readonly T[];
157
- toArray(): readonly T[];
158
- snapshot(): readonly T[];
159
- restore(values: readonly T[]): void;
160
- private _rawAppend;
161
- }
162
- /**
163
- * Creates an append-only reactive log that emits immutable `readonly T[]` snapshots.
164
- *
165
- * Each structural mutation (`append`, `appendMany`, `clear`, `trimHead`) triggers
166
- * a two-phase `[DIRTY, DATA]` emission on the `entries` node so downstream
167
- * derived nodes update reactively. Views (`tail`, `slice`, `fromCursor`) are
168
- * memoized derived nodes — subscribe once and they stay live.
169
- *
170
- * @param initial - Optional initial entries loaded into the log at construction.
171
- * @param options - Optional name, max size (ring buffer), versioning level, guard policy, and custom backend.
172
- * @returns `ReactiveLogBundle<T>` with `entries`, `append`, `appendMany`, `clear`, `trimHead`, `view`, `attach`, `attachStorage`, and disposal methods.
173
- *
174
- * @example
175
- * ```ts
176
- * import { reactiveLog } from "@graphrefly/graphrefly/extra";
177
- *
178
- * const log = reactiveLog<string>([], { name: "messages" });
179
- * log.entries.subscribe((msgs) => {
180
- * for (const m of msgs) {
181
- * if (m[0] === 1) console.log("entries:", m[1]);
182
- * }
183
- * });
184
- * log.append("hello");
185
- * log.append("world");
186
- * ```
187
- *
188
- * @remarks
189
- * **Ring buffer:** Pass `maxSize` to cap the log length; older entries are evicted on overflow.
190
- * **Storage:** Call `attachStorage(tiers)` to wire one or more `AppendLogStorageTier` instances for persistence.
191
- *
192
- * @category extra
193
- */
194
- declare function reactiveLog<T>(initial?: readonly T[], options?: ReactiveLogOptions<T>): ReactiveLogBundle<T>;
195
- /**
196
- * Bundle returned by {@link mergeReactiveLogs}. `node` is the merged output;
197
- * `dispose()` releases the internal subscriptions to all input logs and the
198
- * keepalive on `node`. After dispose the merge stops responding to inputs
199
- * but `node`'s last cached value remains queryable.
200
- *
201
- * @category extra
202
- */
203
- interface MergedReactiveLog<T> {
204
- readonly node: Node<readonly T[]>;
205
- dispose(): void;
206
- }
207
- /**
208
- * Fan-in helper that merges N reactive logs into a single time-ordered output
209
- * by concatenation. Returns `{ node, dispose }`. Producer-pattern: subscribes
210
- * to each input internally; COMPLETE on an input drops it from the active
211
- * set; ERROR propagates per spec §2.2. Memoized by reference identity on the
212
- * `logs` array — repeat calls with the same reference return the same bundle.
213
- *
214
- * Internal subscriptions are invisible in `describe()` (sanctioned per §24);
215
- * `explain()` across the merge surfaces only the merged stream. Caller must
216
- * `dispose()` when done to release subscriptions to input logs (no auto-GC
217
- * because of the memoization map).
218
- *
219
- * @category extra
220
- */
221
- declare function mergeReactiveLogs<T>(logs: readonly Node<readonly T[]>[]): MergedReactiveLog<T>;
222
-
223
- export { type LogBackend as L, type MergedReactiveLog as M, NativeLogBackend as N, type ReactiveLogOptions as R, type ViewSpec as V, type ReactiveLogBundle as a, mergeReactiveLogs as m, reactiveLog as r };