@graphrefly/graphrefly 0.39.0 → 0.41.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 (218) hide show
  1. package/dist/{cascading-g2_rhhaM.d.ts → cascading-BNfxffgc.d.ts} +1 -1
  2. package/dist/{cascading-BzuxW0_w.d.cts → cascading-Cxs1eztH.d.cts} +1 -1
  3. package/dist/chunk-2W553JJC.js +1 -0
  4. package/dist/{chunk-5LK7XMEV.js → chunk-33N4TU3X.js} +1 -1
  5. package/dist/chunk-4MKL6Q3K.js +1 -0
  6. package/dist/chunk-5B3JDG5F.js +1 -0
  7. package/dist/chunk-5QSXEMXG.js +1 -0
  8. package/dist/{chunk-R75BMDLA.js → chunk-5TEFC2ZX.js} +1 -1
  9. package/dist/chunk-5TOPVRN6.js +1 -0
  10. package/dist/{chunk-INHC33EH.js → chunk-5VEZLQFN.js} +1 -1
  11. package/dist/{chunk-NQI2C36M.js → chunk-7PQLZMOG.js} +1 -1
  12. package/dist/{chunk-7NZMZJMW.js → chunk-AI7QC7J6.js} +1 -1
  13. package/dist/{chunk-L7WY6TZS.js → chunk-AK5RHMC5.js} +1 -1
  14. package/dist/{chunk-ZOX3LBRV.js → chunk-CGNOWGV6.js} +1 -1
  15. package/dist/{chunk-INH6FS2G.js → chunk-CYOSWFT2.js} +1 -1
  16. package/dist/{chunk-GX5LSSRE.js → chunk-EC2WNSZ7.js} +1 -1
  17. package/dist/{chunk-HAWKGIXM.js → chunk-ELAASRBT.js} +1 -1
  18. package/dist/{chunk-7QFRK3N3.js → chunk-F7VUYPP6.js} +1 -1
  19. package/dist/{chunk-LQNOXGET.js → chunk-G3M3IMEV.js} +1 -1
  20. package/dist/{chunk-HX3EGQ5Z.js → chunk-GI4Q7PNY.js} +1 -1
  21. package/dist/{chunk-XQ55HO5N.js → chunk-H5SCWHWP.js} +1 -1
  22. package/dist/{chunk-CGDMTXSY.js → chunk-KNVCCBIU.js} +1 -1
  23. package/dist/{chunk-IA7DUNGB.js → chunk-L77I47VU.js} +1 -1
  24. package/dist/{chunk-JNMC2WJ6.js → chunk-M3FQSXEW.js} +1 -1
  25. package/dist/{chunk-D47YVDR5.js → chunk-OLIKJUKI.js} +1 -1
  26. package/dist/{chunk-SC7BQDNP.js → chunk-OV5AA6HJ.js} +1 -1
  27. package/dist/{chunk-7JRF5YEK.js → chunk-POXANAJ6.js} +1 -1
  28. package/dist/chunk-RSMEXK53.js +43 -0
  29. package/dist/{chunk-KD4NHLMU.js → chunk-SC27WTSG.js} +1 -1
  30. package/dist/chunk-TSOYJ743.js +1 -0
  31. package/dist/{chunk-AU7YTQX7.js → chunk-TT4C7DXW.js} +1 -1
  32. package/dist/{chunk-TFPZLQ5H.js → chunk-UISPDFJ3.js} +1 -1
  33. package/dist/{chunk-N7UIBZCW.js → chunk-URJ2VFNC.js} +1 -1
  34. package/dist/{chunk-GEAO3TL3.js → chunk-VV62MIG4.js} +1 -1
  35. package/dist/{chunk-VJJLIEAL.js → chunk-VXPLLA4P.js} +1 -1
  36. package/dist/{chunk-WHIZM6JV.js → chunk-WZYB3JQS.js} +1 -1
  37. package/dist/{chunk-S2U57TFC.js → chunk-X7QKTXXC.js} +1 -1
  38. package/dist/{chunk-7SD73DS6.js → chunk-YQRN4CIV.js} +1 -1
  39. package/dist/chunk-Z6X7B6A4.js +61 -0
  40. package/dist/{chunk-RF3QZP6D.js → chunk-ZAJ7J7TO.js} +1 -1
  41. package/dist/compat/index.d.cts +6 -6
  42. package/dist/compat/index.d.ts +6 -6
  43. package/dist/compat/index.js +1 -1
  44. package/dist/compat/nestjs/index.d.cts +4 -4
  45. package/dist/compat/nestjs/index.d.ts +4 -4
  46. package/dist/compat/nestjs/index.js +1 -1
  47. package/dist/compat/zustand/index.d.cts +2 -2
  48. package/dist/compat/zustand/index.d.ts +2 -2
  49. package/dist/compat/zustand/index.js +1 -1
  50. package/dist/{composite-DGatA-JK.d.ts → decay-BnrlbxSv.d.ts} +38 -2
  51. package/dist/{composite-CKd0e2vz.d.cts → decay-C25AyNAj.d.cts} +38 -2
  52. package/dist/extra/index.cjs +15 -15
  53. package/dist/extra/index.d.cts +6 -6
  54. package/dist/extra/index.d.ts +6 -6
  55. package/dist/extra/index.js +1 -1
  56. package/dist/extra/node.js +1 -1
  57. package/dist/extra/operators.js +1 -1
  58. package/dist/extra/reactive.d.cts +1 -1
  59. package/dist/extra/reactive.d.ts +1 -1
  60. package/dist/extra/reactive.js +1 -1
  61. package/dist/extra/render/index.d.cts +1 -1
  62. package/dist/extra/render/index.d.ts +1 -1
  63. package/dist/extra/sources.cjs +1 -1
  64. package/dist/extra/sources.js +1 -1
  65. package/dist/graph/index.d.cts +3 -3
  66. package/dist/graph/index.d.ts +3 -3
  67. package/dist/graph/index.js +1 -1
  68. package/dist/{graph-30XSgtVX.d.ts → graph-BkIkog4h.d.ts} +1 -1
  69. package/dist/{graph-BUwMAxJI.d.cts → graph-E6likq7w.d.cts} +1 -1
  70. package/dist/{index-BXd6OMEy.d.ts → index-3k4Gg6-n.d.ts} +2 -2
  71. package/dist/{index-DszPlZzK.d.ts → index-40ZT4MHj.d.ts} +1 -1
  72. package/dist/index-8s-Qm-gz.d.ts +218 -0
  73. package/dist/{index-K-vl_c6A.d.cts → index-A3U3CSve.d.cts} +1 -1
  74. package/dist/{index-jKLph6cu.d.ts → index-B6iTqKtJ.d.ts} +1 -1
  75. package/dist/{index-WyFKER-c.d.ts → index-B72TQQHd.d.cts} +3 -3
  76. package/dist/{index-CmqiJZKM.d.ts → index-BAQrjuZF.d.ts} +64 -6
  77. package/dist/{index-CusEP3Sv.d.ts → index-BQ1fR4li.d.ts} +1 -1
  78. package/dist/{index-jr6PuSBt.d.ts → index-BaA-xpSw.d.ts} +2 -2
  79. package/dist/{index-FVoPvhAu.d.cts → index-Bd91Nmf4.d.cts} +2 -2
  80. package/dist/{index-PqbnoScQ.d.ts → index-BgjS2b8N.d.ts} +2 -2
  81. package/dist/{index-DCbE8fFM.d.cts → index-BiHUBEKq.d.cts} +2 -2
  82. package/dist/{index-DlgHqQxW.d.cts → index-BilOa6AE.d.cts} +6 -32
  83. package/dist/{index-DoYc8BWK.d.cts → index-BmSQLAZo.d.cts} +2 -2
  84. package/dist/{index-DlrWu9Hs.d.cts → index-C-dkXOpB.d.cts} +1 -1
  85. package/dist/{index-C7VV_qOs.d.ts → index-C5cQ7Gfx.d.ts} +2 -2
  86. package/dist/{index-CPhBvRJU.d.ts → index-C6ZUaos7.d.ts} +1 -1
  87. package/dist/{index-PlJ3MraE.d.ts → index-CAP3UGsq.d.ts} +1 -1
  88. package/dist/{index-B41Asm7D.d.ts → index-CD2dBMet.d.ts} +2 -2
  89. package/dist/{index-C19qqa38.d.ts → index-CG33HeBW.d.ts} +19 -4
  90. package/dist/index-CGhMJNHb.d.cts +128 -0
  91. package/dist/{index-BAlaVimV.d.ts → index-CQtWm7jS.d.ts} +2 -2
  92. package/dist/{index-8R1vzNOx.d.cts → index-CRm0YIzC.d.cts} +2 -2
  93. package/dist/index-CUIkE1l9.d.cts +230 -0
  94. package/dist/{index-KlZ_ZUip.d.cts → index-Cczxgd2D.d.ts} +3 -3
  95. package/dist/{index-DIHcMLr6.d.cts → index-CgnCFhr2.d.cts} +1 -1
  96. package/dist/{index-BC9VybQs.d.ts → index-Ck35nA-T.d.ts} +2 -2
  97. package/dist/{index-BndG0cpK.d.cts → index-Cnr1WrlX.d.cts} +1 -1
  98. package/dist/{index-H_I66pav.d.cts → index-CtFNGe-m.d.cts} +2 -2
  99. package/dist/index-CuPUehFa.d.cts +218 -0
  100. package/dist/index-D1Gc7wV5.d.ts +230 -0
  101. package/dist/{index-CWHtYmSh.d.cts → index-D4uimgee.d.cts} +1 -1
  102. package/dist/{index-xZYcDqFH.d.cts → index-DGD4_fj6.d.cts} +19 -4
  103. package/dist/{index-CwP_KAMS.d.cts → index-DGTo1yka.d.cts} +64 -6
  104. package/dist/{index-BUPVld1w.d.ts → index-DH4fm2Ck.d.ts} +2 -2
  105. package/dist/{index-DyM4tFAe.d.cts → index-DQQCOIt8.d.cts} +2 -2
  106. package/dist/{index-BJ26eEjs.d.cts → index-DVAlsmEU.d.cts} +2 -2
  107. package/dist/{index-DINuaZlJ.d.cts → index-DVDapw2k.d.cts} +1 -1
  108. package/dist/{index-iTX5IqSP.d.ts → index-DfOK_oL5.d.ts} +208 -203
  109. package/dist/{index-DTtBpuQy.d.cts → index-DgJc8Zgc.d.cts} +5 -3
  110. package/dist/{index-BKMdnYnk.d.ts → index-DhLyOHYZ.d.ts} +1 -1
  111. package/dist/{index-89FczVZ_.d.ts → index-DhnsQfa3.d.ts} +77 -51
  112. package/dist/{index-L8XI8Zql.d.cts → index-DktLSZOc.d.cts} +2 -2
  113. package/dist/{index-pVDQcbar.d.cts → index-DpiGqtrs.d.cts} +77 -51
  114. package/dist/{index-mNwgxC21.d.cts → index-DuRsN9ae.d.cts} +208 -203
  115. package/dist/{index-B9fmw5n2.d.ts → index-I1cCY3ZI.d.ts} +5 -3
  116. package/dist/index-N2MAxt7_.d.ts +128 -0
  117. package/dist/{index-Br3WnqEn.d.ts → index-WSlcjhQF.d.ts} +6 -32
  118. package/dist/{index-DQUVq1_d.d.ts → index-bXXLSvor.d.ts} +2 -2
  119. package/dist/{index-BhUaMYm_.d.ts → index-da2V5vPy.d.ts} +1 -1
  120. package/dist/{index-PsVHpPwP.d.cts → index-t6L2qpHh.d.cts} +2 -2
  121. package/dist/{index-IwFqHxCs.d.cts → index-tV3AA9hI.d.cts} +1 -1
  122. package/dist/index.cjs +48 -48
  123. package/dist/index.d.cts +33 -33
  124. package/dist/index.d.ts +33 -33
  125. package/dist/index.js +1 -1
  126. package/dist/patterns/ai/browser.cjs +5 -5
  127. package/dist/patterns/ai/browser.d.cts +2 -2
  128. package/dist/patterns/ai/browser.d.ts +2 -2
  129. package/dist/patterns/ai/browser.js +1 -1
  130. package/dist/patterns/ai/index.cjs +14 -14
  131. package/dist/patterns/ai/index.d.cts +11 -11
  132. package/dist/patterns/ai/index.d.ts +11 -11
  133. package/dist/patterns/ai/index.js +1 -1
  134. package/dist/patterns/ai/node.js +1 -1
  135. package/dist/patterns/audit/index.d.cts +3 -3
  136. package/dist/patterns/audit/index.d.ts +3 -3
  137. package/dist/patterns/audit/index.js +1 -1
  138. package/dist/patterns/cqrs/index.d.cts +3 -3
  139. package/dist/patterns/cqrs/index.d.ts +3 -3
  140. package/dist/patterns/cqrs/index.js +1 -1
  141. package/dist/patterns/demo-shell/index.d.cts +3 -3
  142. package/dist/patterns/demo-shell/index.d.ts +3 -3
  143. package/dist/patterns/demo-shell/index.js +1 -1
  144. package/dist/patterns/domain-templates/index.d.cts +2 -2
  145. package/dist/patterns/domain-templates/index.d.ts +2 -2
  146. package/dist/patterns/domain-templates/index.js +1 -1
  147. package/dist/patterns/graphspec/index.d.cts +2 -2
  148. package/dist/patterns/graphspec/index.d.ts +2 -2
  149. package/dist/patterns/graphspec/index.js +1 -1
  150. package/dist/patterns/guarded-execution/index.cjs +3 -3
  151. package/dist/patterns/guarded-execution/index.d.cts +4 -4
  152. package/dist/patterns/guarded-execution/index.d.ts +4 -4
  153. package/dist/patterns/guarded-execution/index.js +1 -1
  154. package/dist/patterns/harness/index.cjs +8 -8
  155. package/dist/patterns/harness/index.d.cts +7 -7
  156. package/dist/patterns/harness/index.d.ts +7 -7
  157. package/dist/patterns/harness/index.js +1 -1
  158. package/dist/patterns/job-queue/index.cjs +3 -3
  159. package/dist/patterns/job-queue/index.d.cts +3 -3
  160. package/dist/patterns/job-queue/index.d.ts +3 -3
  161. package/dist/patterns/job-queue/index.js +1 -1
  162. package/dist/patterns/lens/index.cjs +3 -3
  163. package/dist/patterns/lens/index.d.cts +3 -4
  164. package/dist/patterns/lens/index.d.ts +3 -4
  165. package/dist/patterns/lens/index.js +1 -1
  166. package/dist/patterns/memory/index.cjs +1 -1
  167. package/dist/patterns/memory/index.d.cts +3 -3
  168. package/dist/patterns/memory/index.d.ts +3 -3
  169. package/dist/patterns/memory/index.js +1 -1
  170. package/dist/patterns/messaging/index.d.cts +2 -2
  171. package/dist/patterns/messaging/index.d.ts +2 -2
  172. package/dist/patterns/messaging/index.js +1 -1
  173. package/dist/patterns/orchestration/index.d.cts +3 -3
  174. package/dist/patterns/orchestration/index.d.ts +3 -3
  175. package/dist/patterns/orchestration/index.js +1 -1
  176. package/dist/patterns/process/index.d.cts +4 -4
  177. package/dist/patterns/process/index.d.ts +4 -4
  178. package/dist/patterns/process/index.js +1 -1
  179. package/dist/patterns/reactive-layout/index.d.cts +3 -3
  180. package/dist/patterns/reactive-layout/index.d.ts +3 -3
  181. package/dist/patterns/reactive-layout/index.js +1 -1
  182. package/dist/patterns/reduction/index.d.cts +2 -2
  183. package/dist/patterns/reduction/index.d.ts +2 -2
  184. package/dist/patterns/reduction/index.js +1 -1
  185. package/dist/patterns/refine-loop/index.d.cts +3 -3
  186. package/dist/patterns/refine-loop/index.d.ts +3 -3
  187. package/dist/patterns/refine-loop/index.js +1 -1
  188. package/dist/patterns/resilient-pipeline/index.cjs +3 -1
  189. package/dist/patterns/resilient-pipeline/index.d.cts +7 -3
  190. package/dist/patterns/resilient-pipeline/index.d.ts +7 -3
  191. package/dist/patterns/resilient-pipeline/index.js +1 -1
  192. package/dist/patterns/surface/index.d.cts +3 -3
  193. package/dist/patterns/surface/index.d.ts +3 -3
  194. package/dist/patterns/surface/index.js +1 -1
  195. package/dist/{pipeline-graph-D8vKcO_p.d.ts → pipeline-graph-CB4La-UW.d.ts} +2 -2
  196. package/dist/{pipeline-graph-BQPr2Lqs.d.cts → pipeline-graph-MWrQZXCq.d.cts} +2 -2
  197. package/dist/{reactive-layout-8CSc0tiA.d.cts → reactive-layout-BtZfUKuL.d.cts} +1 -1
  198. package/dist/{reactive-layout-DkTXxtSy.d.ts → reactive-layout-KJj4E2dT.d.ts} +1 -1
  199. package/dist/{reactive-map-B2qfD3hb.d.cts → reactive-map-6P_k3AQM.d.cts} +1 -1
  200. package/dist/{reactive-map-jFIsE6Kt.d.ts → reactive-map-CjXByDV-.d.ts} +1 -1
  201. package/dist/{resilience-HTF2LBRS.js → resilience-JISHQD2F.js} +1 -1
  202. package/dist/{topology-tree-B5Ngw3j0.d.cts → topology-tree-3LBKFsUo.d.cts} +1 -1
  203. package/dist/{topology-tree-BtvbgMXJ.d.ts → topology-tree-mF7Emqzm.d.ts} +1 -1
  204. package/package.json +1 -1
  205. package/dist/chunk-5XRI6RM3.js +0 -1
  206. package/dist/chunk-73PBQNST.js +0 -1
  207. package/dist/chunk-A6ZSKGUG.js +0 -1
  208. package/dist/chunk-EWF7KCDJ.js +0 -61
  209. package/dist/chunk-IUB4NYI2.js +0 -1
  210. package/dist/chunk-MC4UYY2X.js +0 -1
  211. package/dist/chunk-XEUANKBO.js +0 -43
  212. package/dist/chunk-ZJ7SM3G2.js +0 -1
  213. package/dist/index-BEHmxORq.d.ts +0 -135
  214. package/dist/index-BM9szD8n.d.cts +0 -113
  215. package/dist/index-BskfDoZ_.d.ts +0 -113
  216. package/dist/index-CIRG8Hxp.d.cts +0 -135
  217. package/dist/index-Cey6VTnX.d.ts +0 -166
  218. package/dist/index-CpLpJb6A.d.cts +0 -166
@@ -1,15 +1,15 @@
1
- export { A as ActuatorApplyFn, a as ActuatorExecutorConfig, b as ActuatorResult, c as AutoSolidifyConfig, C as CodeChange, d as CodeChangeBridgeOptions, D as DEFAULT_DECAY_RATE, e as DEFAULT_EXECUTE_PROMPT, f as DEFAULT_QUEUE_CONFIGS, g as DEFAULT_SEVERITY_WEIGHTS, h as DEFAULT_TRIAGE_PROMPT, j as DEFAULT_VERIFY_PROMPT, k as DispatchActuatorConfig, E as EffectivenessEntry, l as EffectivenessSnapshot, m as EffectivenessTrackerBundle, n as EffectivenessTrackerOptions, o as ErrorClass, p as ErrorClassifier, q as EvalDelta, r as EvalIntakeBridgeOptions, s as EvalJudgeScore, t as EvalResult, u as EvalTaskDelta, v as EvalTaskResult, w as EvalVerifierConfig, x as EvalVerifierSummary, y as ExecuteOutput, z as ExecutePromptFn, B as ExecutionResult, H as HarnessEvalPairConfig, F as HarnessExecutor, G as HarnessGraph, I as HarnessLoopOptions, J as HarnessProfileResult, K as HarnessTraceHandle, L as HarnessTraceOptions, M as HarnessVerifier, N as IntakeBridgeOptions, O as IntakeItem, P as IntakeSource, Q as Intervention, R as KnownIntakeSource, S as LintError, T as NotifyEffectOptions, U as NotifyTransport, V as PrioritySignals, W as QUEUE_NAMES, X as QueueConfig, Y as QueueRoute, Z as RefineExecutorConfig, _ as RefineExecutorResult, $ as RootCause, a0 as Severity, a1 as StrategyEntry, a2 as StrategyKey, a3 as StrategyModelBundle, a4 as StrategySnapshot, a5 as TestFailure, a6 as TraceDetail, a7 as TraceEvent, a8 as TraceEventType, a9 as TriagePromptFn, aa as TriagedItem, ab as VerifyOutput, ac as VerifyPromptFn, ad as VerifyResult, ae as actuatorExecutor, af as affectedTaskFilter, ag as autoSolidify, ah as beforeAfterCompare, ai as codeChangeBridge, aj as createIntakeBridge, ak as defaultErrorClassifier, al as defaultLlmExecutor, am as defaultLlmVerifier, an as dispatchActuator, ao as effectivenessTracker, ap as evalIntakeBridge, aq as evalSource, ar as evalVerifier, as as harnessEvalPair, at as harnessLoop, au as harnessProfile, av as harnessTrace, aw as notifyEffect, ax as priorityScore, ay as refineExecutor, az as resolvePromptFn, aA as strategyKey, aB as strategyModel } from '../../index-mNwgxC21.cjs';
1
+ export { A as ActuatorApplyFn, a as ActuatorExecutorConfig, b as ActuatorResult, c as AutoSolidifyConfig, C as CodeChange, d as CodeChangeBridgeOptions, D as DEFAULT_DECAY_RATE, e as DEFAULT_EXECUTE_PROMPT, f as DEFAULT_QUEUE_CONFIGS, g as DEFAULT_SEVERITY_WEIGHTS, h as DEFAULT_TRIAGE_PROMPT, j as DEFAULT_VERIFY_PROMPT, k as DispatchActuatorConfig, E as EffectivenessEntry, l as EffectivenessSnapshot, m as EffectivenessTrackerBundle, n as EffectivenessTrackerOptions, o as ErrorClass, p as ErrorClassifier, q as EvalDelta, r as EvalIntakeBridgeOptions, s as EvalJudgeScore, t as EvalResult, u as EvalTaskDelta, v as EvalTaskResult, w as EvalVerifierConfig, x as EvalVerifierSummary, y as ExecuteOutput, z as ExecutePromptFn, B as ExecutionResult, H as HarnessEvalPairConfig, F as HarnessExecutor, G as HarnessGraph, I as HarnessJobPayload, J as HarnessLoopOptions, K as HarnessProfileResult, L as HarnessTraceHandle, M as HarnessTraceOptions, N as HarnessVerifier, O as IntakeBridgeOptions, P as IntakeItem, Q as IntakeSource, R as Intervention, S as KnownIntakeSource, T as LintError, U as NotifyEffectOptions, V as NotifyTransport, W as PrioritySignals, X as QUEUE_NAMES, Y as QueueConfig, Z as QueueRoute, _ as RefineExecutorConfig, $ as RefineExecutorResult, a0 as RootCause, a1 as Severity, a2 as StrategyEntry, a3 as StrategyKey, a4 as StrategyModelBundle, a5 as StrategySnapshot, a6 as TestFailure, a7 as TraceDetail, a8 as TraceEvent, a9 as TraceEventType, aa as TriagePromptFn, ab as TriagedItem, ac as VerifyOutput, ad as VerifyPromptFn, ae as VerifyResult, af as actuatorExecutor, ag as affectedTaskFilter, ah as autoSolidify, ai as beforeAfterCompare, aj as codeChangeBridge, ak as createIntakeBridge, al as defaultErrorClassifier, am as defaultLlmExecutor, an as defaultLlmVerifier, ao as dispatchActuator, ap as effectivenessTracker, aq as evalIntakeBridge, ar as evalSource, as as evalVerifier, at as harnessEvalPair, au as harnessLoop, av as harnessProfile, aw as harnessTrace, ax as notifyEffect, ay as priorityScore, az as refineExecutor, aA as resolvePromptFn, aB as strategyKey, aC as strategyModel } from '../../index-DuRsN9ae.cjs';
2
2
  import '../../extra/sources.cjs';
3
3
  import '../../node-BYInONRr.cjs';
4
4
  import '../../types-1Dhoi7HM.cjs';
5
- import '../../index-BndG0cpK.cjs';
6
- import '../../graph-BUwMAxJI.cjs';
5
+ import '../../index-DGD4_fj6.cjs';
6
+ import '../../index-DVDapw2k.cjs';
7
+ import '../../graph-E6likq7w.cjs';
7
8
  import '../../meta-Ct9nqQS5.cjs';
8
9
  import '../../extra/storage-core.cjs';
9
10
  import '../../extra/storage-tiers.cjs';
10
11
  import '../../reactive-log-_zeEnB9H.cjs';
11
- import '../../index-PsVHpPwP.cjs';
12
- import '../../pipeline-graph-BQPr2Lqs.cjs';
12
+ import '../../index-Cnr1WrlX.cjs';
13
+ import '../../index-t6L2qpHh.cjs';
14
+ import '../../pipeline-graph-MWrQZXCq.cjs';
13
15
  import '../../sugar-DzePN5-g.cjs';
14
- import '../../index-DINuaZlJ.cjs';
15
- import '../../index-xZYcDqFH.cjs';
@@ -1,15 +1,15 @@
1
- export { A as ActuatorApplyFn, a as ActuatorExecutorConfig, b as ActuatorResult, c as AutoSolidifyConfig, C as CodeChange, d as CodeChangeBridgeOptions, D as DEFAULT_DECAY_RATE, e as DEFAULT_EXECUTE_PROMPT, f as DEFAULT_QUEUE_CONFIGS, g as DEFAULT_SEVERITY_WEIGHTS, h as DEFAULT_TRIAGE_PROMPT, j as DEFAULT_VERIFY_PROMPT, k as DispatchActuatorConfig, E as EffectivenessEntry, l as EffectivenessSnapshot, m as EffectivenessTrackerBundle, n as EffectivenessTrackerOptions, o as ErrorClass, p as ErrorClassifier, q as EvalDelta, r as EvalIntakeBridgeOptions, s as EvalJudgeScore, t as EvalResult, u as EvalTaskDelta, v as EvalTaskResult, w as EvalVerifierConfig, x as EvalVerifierSummary, y as ExecuteOutput, z as ExecutePromptFn, B as ExecutionResult, H as HarnessEvalPairConfig, F as HarnessExecutor, G as HarnessGraph, I as HarnessLoopOptions, J as HarnessProfileResult, K as HarnessTraceHandle, L as HarnessTraceOptions, M as HarnessVerifier, N as IntakeBridgeOptions, O as IntakeItem, P as IntakeSource, Q as Intervention, R as KnownIntakeSource, S as LintError, T as NotifyEffectOptions, U as NotifyTransport, V as PrioritySignals, W as QUEUE_NAMES, X as QueueConfig, Y as QueueRoute, Z as RefineExecutorConfig, _ as RefineExecutorResult, $ as RootCause, a0 as Severity, a1 as StrategyEntry, a2 as StrategyKey, a3 as StrategyModelBundle, a4 as StrategySnapshot, a5 as TestFailure, a6 as TraceDetail, a7 as TraceEvent, a8 as TraceEventType, a9 as TriagePromptFn, aa as TriagedItem, ab as VerifyOutput, ac as VerifyPromptFn, ad as VerifyResult, ae as actuatorExecutor, af as affectedTaskFilter, ag as autoSolidify, ah as beforeAfterCompare, ai as codeChangeBridge, aj as createIntakeBridge, ak as defaultErrorClassifier, al as defaultLlmExecutor, am as defaultLlmVerifier, an as dispatchActuator, ao as effectivenessTracker, ap as evalIntakeBridge, aq as evalSource, ar as evalVerifier, as as harnessEvalPair, at as harnessLoop, au as harnessProfile, av as harnessTrace, aw as notifyEffect, ax as priorityScore, ay as refineExecutor, az as resolvePromptFn, aA as strategyKey, aB as strategyModel } from '../../index-iTX5IqSP.js';
1
+ export { A as ActuatorApplyFn, a as ActuatorExecutorConfig, b as ActuatorResult, c as AutoSolidifyConfig, C as CodeChange, d as CodeChangeBridgeOptions, D as DEFAULT_DECAY_RATE, e as DEFAULT_EXECUTE_PROMPT, f as DEFAULT_QUEUE_CONFIGS, g as DEFAULT_SEVERITY_WEIGHTS, h as DEFAULT_TRIAGE_PROMPT, j as DEFAULT_VERIFY_PROMPT, k as DispatchActuatorConfig, E as EffectivenessEntry, l as EffectivenessSnapshot, m as EffectivenessTrackerBundle, n as EffectivenessTrackerOptions, o as ErrorClass, p as ErrorClassifier, q as EvalDelta, r as EvalIntakeBridgeOptions, s as EvalJudgeScore, t as EvalResult, u as EvalTaskDelta, v as EvalTaskResult, w as EvalVerifierConfig, x as EvalVerifierSummary, y as ExecuteOutput, z as ExecutePromptFn, B as ExecutionResult, H as HarnessEvalPairConfig, F as HarnessExecutor, G as HarnessGraph, I as HarnessJobPayload, J as HarnessLoopOptions, K as HarnessProfileResult, L as HarnessTraceHandle, M as HarnessTraceOptions, N as HarnessVerifier, O as IntakeBridgeOptions, P as IntakeItem, Q as IntakeSource, R as Intervention, S as KnownIntakeSource, T as LintError, U as NotifyEffectOptions, V as NotifyTransport, W as PrioritySignals, X as QUEUE_NAMES, Y as QueueConfig, Z as QueueRoute, _ as RefineExecutorConfig, $ as RefineExecutorResult, a0 as RootCause, a1 as Severity, a2 as StrategyEntry, a3 as StrategyKey, a4 as StrategyModelBundle, a5 as StrategySnapshot, a6 as TestFailure, a7 as TraceDetail, a8 as TraceEvent, a9 as TraceEventType, aa as TriagePromptFn, ab as TriagedItem, ac as VerifyOutput, ad as VerifyPromptFn, ae as VerifyResult, af as actuatorExecutor, ag as affectedTaskFilter, ah as autoSolidify, ai as beforeAfterCompare, aj as codeChangeBridge, ak as createIntakeBridge, al as defaultErrorClassifier, am as defaultLlmExecutor, an as defaultLlmVerifier, ao as dispatchActuator, ap as effectivenessTracker, aq as evalIntakeBridge, ar as evalSource, as as evalVerifier, at as harnessEvalPair, au as harnessLoop, av as harnessProfile, aw as harnessTrace, ax as notifyEffect, ay as priorityScore, az as refineExecutor, aA as resolvePromptFn, aB as strategyKey, aC as strategyModel } from '../../index-DfOK_oL5.js';
2
2
  import '../../extra/sources.js';
3
3
  import '../../node-BYInONRr.js';
4
4
  import '../../types-39jk0kaV.js';
5
- import '../../index-DszPlZzK.js';
6
- import '../../graph-30XSgtVX.js';
5
+ import '../../index-CG33HeBW.js';
6
+ import '../../index-BQ1fR4li.js';
7
+ import '../../graph-BkIkog4h.js';
7
8
  import '../../meta-D8OyedKp.js';
8
9
  import '../../extra/storage-core.js';
9
10
  import '../../extra/storage-tiers.js';
10
11
  import '../../reactive-log-BlAsPLl2.js';
11
- import '../../index-PqbnoScQ.js';
12
- import '../../pipeline-graph-D8vKcO_p.js';
12
+ import '../../index-40ZT4MHj.js';
13
+ import '../../index-BgjS2b8N.js';
14
+ import '../../pipeline-graph-CB4La-UW.js';
13
15
  import '../../sugar-BhfjgetH.js';
14
- import '../../index-CusEP3Sv.js';
15
- import '../../index-C19qqa38.js';
@@ -1 +1 @@
1
- import{A,B,C,D,E,F,a,b,c,d,e,f,g,h,i,j,k,l,m,n,o,p,q,r,s,t,u,v,w,x,y,z}from"../../chunk-XEUANKBO.js";import"../../chunk-HAWKGIXM.js";import"../../chunk-5XRI6RM3.js";import"../../chunk-EWF7KCDJ.js";import"../../chunk-7QFRK3N3.js";import"../../chunk-HX3EGQ5Z.js";import"../../chunk-NQI2C36M.js";import"../../chunk-GEAO3TL3.js";import"../../chunk-TFPZLQ5H.js";import"../../chunk-N7UIBZCW.js";import"../../chunk-D27JNOLZ.js";import"../../chunk-LQNOXGET.js";import"../../chunk-R75BMDLA.js";import"../../chunk-3G5U5QNE.js";import"../../chunk-C72GO4IZ.js";import"../../chunk-4I45FVQS.js";import"../../chunk-WHIZM6JV.js";import"../../chunk-ZJ7SM3G2.js";import"../../chunk-INH6FS2G.js";import"../../chunk-IUB4NYI2.js";import"../../chunk-CGDMTXSY.js";import"../../chunk-VJJLIEAL.js";import"../../chunk-L6NSJVJZ.js";import"../../chunk-7JRF5YEK.js";import"../../chunk-SGS4OJGS.js";import"../../chunk-ESMPEKEV.js";import"../../chunk-D5RFJOZ2.js";import"../../chunk-CE72X3WO.js";import"../../chunk-L7WY6TZS.js";import"../../chunk-4VVTGLXJ.js";import"../../chunk-35JTVPOX.js";import"../../chunk-KGKJCHEK.js";import"../../chunk-TZQPPQEQ.js";import"../../chunk-AU7YTQX7.js";import"../../chunk-IA7DUNGB.js";import"../../chunk-LYCLF26R.js";import"../../chunk-CK2E7BTU.js";import"../../chunk-QYADASLV.js";export{n as DEFAULT_DECAY_RATE,r as DEFAULT_EXECUTE_PROMPT,l as DEFAULT_QUEUE_CONFIGS,m as DEFAULT_SEVERITY_WEIGHTS,q as DEFAULT_TRIAGE_PROMPT,s as DEFAULT_VERIFY_PROMPT,C as HarnessGraph,k as QUEUE_NAMES,a as actuatorExecutor,h as affectedTaskFilter,c as autoSolidify,g as beforeAfterCompare,i as codeChangeBridge,d as createIntakeBridge,p as defaultErrorClassifier,A as defaultLlmExecutor,B as defaultLlmVerifier,b as dispatchActuator,u as effectivenessTracker,e as evalIntakeBridge,f as evalSource,w as evalVerifier,x as harnessEvalPair,D as harnessLoop,E as harnessProfile,F as harnessTrace,j as notifyEffect,z as priorityScore,v as refineExecutor,t as resolvePromptFn,o as strategyKey,y as strategyModel};
1
+ import{A,B,C,D,E,F,a,b,c,d,e,f,g,h,i,j,k,l,m,n,o,p,q,r,s,t,u,v,w,x,y,z}from"../../chunk-RSMEXK53.js";import"../../chunk-ELAASRBT.js";import"../../chunk-5B3JDG5F.js";import"../../chunk-Z6X7B6A4.js";import"../../chunk-F7VUYPP6.js";import"../../chunk-GI4Q7PNY.js";import"../../chunk-7PQLZMOG.js";import"../../chunk-VV62MIG4.js";import"../../chunk-UISPDFJ3.js";import"../../chunk-URJ2VFNC.js";import"../../chunk-D27JNOLZ.js";import"../../chunk-G3M3IMEV.js";import"../../chunk-4I45FVQS.js";import"../../chunk-5TEFC2ZX.js";import"../../chunk-3G5U5QNE.js";import"../../chunk-C72GO4IZ.js";import"../../chunk-WZYB3JQS.js";import"../../chunk-TSOYJ743.js";import"../../chunk-CYOSWFT2.js";import"../../chunk-4MKL6Q3K.js";import"../../chunk-KNVCCBIU.js";import"../../chunk-KGKJCHEK.js";import"../../chunk-TZQPPQEQ.js";import"../../chunk-VXPLLA4P.js";import"../../chunk-L6NSJVJZ.js";import"../../chunk-TT4C7DXW.js";import"../../chunk-POXANAJ6.js";import"../../chunk-SGS4OJGS.js";import"../../chunk-ESMPEKEV.js";import"../../chunk-D5RFJOZ2.js";import"../../chunk-CE72X3WO.js";import"../../chunk-AK5RHMC5.js";import"../../chunk-4VVTGLXJ.js";import"../../chunk-L77I47VU.js";import"../../chunk-35JTVPOX.js";import"../../chunk-LYCLF26R.js";import"../../chunk-CK2E7BTU.js";import"../../chunk-QYADASLV.js";export{n as DEFAULT_DECAY_RATE,r as DEFAULT_EXECUTE_PROMPT,l as DEFAULT_QUEUE_CONFIGS,m as DEFAULT_SEVERITY_WEIGHTS,q as DEFAULT_TRIAGE_PROMPT,s as DEFAULT_VERIFY_PROMPT,C as HarnessGraph,k as QUEUE_NAMES,a as actuatorExecutor,h as affectedTaskFilter,c as autoSolidify,g as beforeAfterCompare,i as codeChangeBridge,d as createIntakeBridge,p as defaultErrorClassifier,A as defaultLlmExecutor,B as defaultLlmVerifier,b as dispatchActuator,u as effectivenessTracker,e as evalIntakeBridge,f as evalSource,w as evalVerifier,x as harnessEvalPair,D as harnessLoop,E as harnessProfile,F as harnessTrace,j as notifyEffect,z as priorityScore,v as refineExecutor,t as resolvePromptFn,o as strategyKey,y as strategyModel};
@@ -1,3 +1,3 @@
1
- "use strict";var st=Object.defineProperty;var En=Object.getOwnPropertyDescriptor;var Rn=Object.getOwnPropertyNames;var An=Object.prototype.hasOwnProperty;var j=(r,e)=>()=>(r&&(e=r(r=0)),e);var Sn=(r,e)=>{for(var t in e)st(r,t,{get:e[t],enumerable:!0})},Mn=(r,e,t,n)=>{if(e&&typeof e=="object"||typeof e=="function")for(let s of Rn(e))!An.call(r,s)&&s!==t&&st(r,s,{get:()=>e[s],enumerable:!(n=En(e,s))||n.enumerable});return r};var Dn=r=>Mn(st({},"__esModule",{value:!0}),r);function K(){return Math.trunc(performance.now()*1e6)}function ee(){return Date.now()*1e6}var _e=j(()=>{"use strict"});function Le(r){if(r==null)return we;let{type:e,id:t,...n}=r;return{type:e??"system",id:t??"",...n}}var we,$e=j(()=>{"use strict";we={type:"system",id:""}});function Se(){return Te>0||Re}function Ct(){return Te>0}function ke(r){Te>0?Ae.push(r):r()}function q(r){Te+=1;let e=!1;try{r()}catch(t){throw e=!0,t}finally{if(Te-=1,Te===0)if(e){if(!Re){let t=Ae.splice(0);for(let n of t)try{n()}catch{}le.length=0,fe.length=0,xe.length=0}}else Cn()}}function Cn(){let r=!Re;r&&(Re=!0);let e=[],t=0;try{for(;le.length>0||fe.length>0||xe.length>0||r&&Ae.length>0;){if(r&&Ae.length>0){let o=Ae.splice(0);for(let i of o)try{i()}catch(a){e.push(a)}continue}if(t+=1,t>1e3)throw le.length=0,fe.length=0,xe.length=0,new Error("batch drain exceeded 1000 iterations \u2014 likely a reactive cycle");let s=(le.length>0?le:fe.length>0?fe:xe).splice(0);for(let o of s)try{o()}catch(i){e.push(i)}}}finally{r&&(Re=!1)}if(e.length===1)throw e[0];if(e.length>1)throw new AggregateError(e,"batch drain: multiple callbacks threw")}function Me(r,e,t){if(e.length===0)return;if(e.length===1){let u=t(e[0][0]);if(u<3||!Se()){r(e);return}(u>=5?xe:u===4?fe:le).push(()=>r(e));return}let n=e.length,s=n,o=n,i=n,a=0;for(;a<n&&t(e[a][0])<3;)a++;for(s=a;a<n&&t(e[a][0])===3;)a++;for(o=a;a<n&&t(e[a][0])===4;)a++;i=a;let d=Se();if(s>0){let u=e.slice(0,s);r(u)}if(o>s){let u=e.slice(s,o);d?le.push(()=>r(u)):r(u)}if(i>o){let u=e.slice(o,i);d?fe.push(()=>r(u)):r(u)}if(n>i){let u=e.slice(i,n);d?xe.push(()=>r(u)):r(u)}}var Te,Re,le,fe,xe,Ae,pe=j(()=>{"use strict";Te=0,Re=!1,le=[],fe=[],xe=[],Ae=[]});var he,D,V,W,Y,te,re,z,F,C,ge,Ie,Gt,Fe,Pt,Lt,Ve,ot,it,at,ze,se=j(()=>{"use strict";he=Symbol.for("graphrefly/START"),D=Symbol.for("graphrefly/DATA"),V=Symbol.for("graphrefly/DIRTY"),W=Symbol.for("graphrefly/RESOLVED"),Y=Symbol.for("graphrefly/INVALIDATE"),te=Symbol.for("graphrefly/PAUSE"),re=Symbol.for("graphrefly/RESUME"),z=Symbol.for("graphrefly/TEARDOWN"),F=Symbol.for("graphrefly/COMPLETE"),C=Symbol.for("graphrefly/ERROR"),ge=Object.freeze([V]),Ie=Object.freeze([W]),Gt=Object.freeze([Y]),Fe=Object.freeze([he]),Pt=Object.freeze([F]),Lt=Object.freeze([z]),Ve=Object.freeze([ge]),ot=Object.freeze([Ie]),it=Object.freeze([Gt]),at=Object.freeze([Pt]),ze=Object.freeze([Lt])});function $t(r){r.registerMessageType(he,{tier:0,wireCrossing:!1}),r.registerMessageType(V,{tier:1,wireCrossing:!1}),r.registerMessageType(Y,{tier:1,wireCrossing:!1,metaPassthrough:!1}),r.registerMessageType(te,{tier:2,wireCrossing:!1}),r.registerMessageType(re,{tier:2,wireCrossing:!1}),r.registerMessageType(D,{tier:3,wireCrossing:!0}),r.registerMessageType(W,{tier:3,wireCrossing:!0}),r.registerMessageType(F,{tier:4,wireCrossing:!0,metaPassthrough:!1}),r.registerMessageType(C,{tier:4,wireCrossing:!0,metaPassthrough:!1}),r.registerMessageType(z,{tier:5,wireCrossing:!0,metaPassthrough:!1})}var je,It=j(()=>{"use strict";se();je=class{_messageTypes=new Map;_codecs=new Map;_onMessage;_onSubscribe;_defaultVersioning;_defaultHashFn;_inspectorEnabled=!(typeof process<"u"&&process.env?.NODE_ENV==="production");_globalInspector;_rigorRecorder;_frozen=!1;tierOf;constructor(e){this._onMessage=e.onMessage,this._onSubscribe=e.onSubscribe,this._defaultVersioning=e.defaultVersioning,this._defaultHashFn=e.defaultHashFn,this.tierOf=t=>{let n=this._messageTypes.get(t);return n!=null?n.tier:1}}get onMessage(){return this._frozen=!0,this._onMessage}get onSubscribe(){return this._frozen=!0,this._onSubscribe}set onMessage(e){this._assertUnfrozen(),this._onMessage=e}set onSubscribe(e){this._assertUnfrozen(),this._onSubscribe=e}get defaultVersioning(){return this._defaultVersioning}set defaultVersioning(e){this._assertUnfrozen(),this._defaultVersioning=e}get defaultHashFn(){return this._defaultHashFn}set defaultHashFn(e){this._assertUnfrozen(),this._defaultHashFn=e}get inspectorEnabled(){return this._inspectorEnabled}set inspectorEnabled(e){this._inspectorEnabled=e}get globalInspector(){return this._globalInspector}set globalInspector(e){this._globalInspector=e}get rigorRecorder(){return this._rigorRecorder}set rigorRecorder(e){this._rigorRecorder=e}registerMessageType(e,t){return this._assertUnfrozen(),this._messageTypes.set(e,{tier:t.tier,wireCrossing:t.wireCrossing??t.tier>=3,metaPassthrough:t.metaPassthrough??!0}),this}messageTier(e){let t=this._messageTypes.get(e);return t!=null?t.tier:1}isWireCrossing(e){let t=this._messageTypes.get(e);return t!=null?t.wireCrossing:!0}isLocalOnly(e){return!this.isWireCrossing(e)}isMetaPassthrough(e){let t=this._messageTypes.get(e);return t!=null?t.metaPassthrough:!0}isKnownMessageType(e){return this._messageTypes.has(e)}registerCodec(e){return this._assertUnfrozen(),this._codecs.set(e.name,e),this}lookupCodec(e){return this._codecs.get(e)}_isFrozen(){return this._frozen}_assertUnfrozen(){if(this._frozen)throw new Error("GraphReFlyConfig is frozen: a node has already captured this config. Register custom types and set hooks before creating any node.")}}});function Ft(r){return Array.isArray(r)?[...r]:[r]}function Gn(r,e){return r.has(e)||r.has("*")}function Vt(r){let e=[];return r((s,o)=>{e.push({kind:"allow",actions:new Set(Ft(s)),where:o?.where??(()=>!0)})},(s,o)=>{e.push({kind:"deny",actions:new Set(Ft(s)),where:o?.where??(()=>!0)})}),(s,o)=>{let i=!1,a=!1;for(let d of e)Gn(d.actions,o)&&d.where(s)&&(d.kind==="deny"?i=!0:a=!0);return i?!1:a}}function dt(r){let e=Pn.filter(t=>r({type:t,id:""},"write"));return e.length===0?"restricted":e.includes("human")&&e.includes("llm")&&e.every(t=>t==="human"||t==="llm"||t==="system")?"both":e.length===1?e[0]:e.join("+")}var Q,Pn,Ne=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}};Pn=["human","llm","wallet","system"]});function jt(r,e){let t=new TextEncoder().encode(r.name);if(t.length===0||t.length>255)throw new Error(`encodeEnvelope: codec name "${r.name}" encodes to ${t.length} bytes (must be 1\u2013255)`);let n=r.version;if(!Number.isInteger(n)||n<0||n>65535)throw new Error(`encodeEnvelope: codec.version ${n} out of u16 range (expected integer 0\u201365535)`);let s=2+t.length+2+e.length;if(s>4294967295)throw new Error(`encodeEnvelope: total envelope size ${s} exceeds 2^32-1 bytes (payload ${e.length} bytes)`);let o=new Uint8Array(s),i=0;return o[i++]=ut,o[i++]=t.length,o.set(t,i),i+=t.length,o[i++]=n>>>8&255,o[i++]=n&255,o.set(e,i),o}function Bt(r,e){if(r.length<zt)throw new Error(`decodeEnvelope: bytes too short (${r.length} < ${zt})`);let t=0,n=r[t++];if(n!==ut)throw new Error(`decodeEnvelope: unsupported envelope version ${n} (expected ${ut})`);let s=r[t++];if(s===0)throw new Error("decodeEnvelope: name_len must be >= 1");if(t+s+2>r.length)throw new Error(`decodeEnvelope: envelope truncated (need ${t+s+2} bytes, have ${r.length})`);let o=new TextDecoder().decode(r.subarray(t,t+s));t+=s;let i=(r[t]<<8|r[t+1])>>>0;t+=2;let a=r.subarray(t),d=e.lookupCodec(o);if(d==null)throw new Error(`decodeEnvelope: codec "${o}" not registered (envelope codec_v=${i})`);return{codec:d,codecVersion:i,payload:a}}function Ht(r){r.registerCodec(Ln)}var Ln,ut,zt,ct=j(()=>{"use strict";Ln={name:"json",version:1,contentType:"application/json",encode(r){let e=JSON.stringify(r);return new TextEncoder().encode(e)},decode(r,e){let t=new TextDecoder().decode(r);return JSON.parse(t)}},ut=1,zt=4});function lt(r){if(r===void 0)return null;if(typeof r=="number"){if(!Number.isFinite(r))throw new TypeError(`Cannot hash non-finite number: ${r}`);if(Number.isInteger(r)&&!Number.isSafeInteger(r))throw new TypeError(`Cannot hash integer outside safe range (|n| > 2^53-1): ${r}. Cross-language cid parity is not guaranteed for unsafe integers.`);return r}if(typeof r=="string"||typeof r=="boolean"||r===null)return r;if(Array.isArray(r))return r.map(lt);if(typeof r=="object"&&r!==null){let e={};for(let t of Object.keys(r).sort())e[t]=lt(r[t]);return e}return null}function Fn(r){let e=In.encode(r),t=e.length,n=t*8,s=t+9+63&-64,o=new Uint8Array(s);o.set(e),o[t]=128;let i=new DataView(o.buffer);i.setUint32(s-4,n>>>0,!1),i.setUint32(s-8,Math.floor(n/4294967296)>>>0,!1);let a=1779033703,d=3144134277,u=1013904242,c=2773480762,p=1359893119,f=2600822924,h=528734635,l=1541459225,b=new Uint32Array(64),g=(_,y)=>_>>>y|_<<32-y;for(let _=0;_<s;_+=64){for(let k=0;k<16;k++)b[k]=i.getUint32(_+k*4,!1);for(let k=16;k<64;k++){let A=b[k-15],M=b[k-2],S=g(A,7)^g(A,18)^A>>>3,ae=g(M,17)^g(M,19)^M>>>10;b[k]=b[k-16]+S+b[k-7]+ae>>>0}let y=a,w=d,T=u,N=c,m=p,x=f,O=h,E=l;for(let k=0;k<64;k++){let A=g(m,6)^g(m,11)^g(m,25),M=m&x^~m&O,S=E+A+M+$n[k]+b[k]>>>0,ae=g(y,2)^g(y,13)^g(y,22),ne=y&w^y&T^w&T,Ge=ae+ne>>>0;E=O,O=x,x=m,m=N+S>>>0,N=T,T=w,w=y,y=S+Ge>>>0}a=a+y>>>0,d=d+w>>>0,u=u+T>>>0,c=c+N>>>0,p=p+m>>>0,f=f+x>>>0,h=h+O>>>0,l=l+E>>>0}let v=_=>_.toString(16).padStart(8,"0");return v(a)+v(d)+v(u)+v(c)+v(p)+v(f)+v(h)+v(l)}function ft(r){let e=lt(r??null),t=JSON.stringify(e);return Fn(t).slice(0,16)}function Vn(){let r=globalThis.crypto;if(r?.randomUUID)return r.randomUUID();let e=()=>Math.floor(Math.random()*4294967296).toString(16).padStart(8,"0"),t=e()+e()+e()+e();return`${t.slice(0,8)}-${t.slice(8,12)}-4${t.slice(13,16)}-${(parseInt(t.slice(16,17),16)&3|8).toString(16)}${t.slice(17,20)}-${t.slice(20,32)}`}function pt(r,e,t){let n=t?.id??Vn();if(r===0)return{id:n,version:0};let o=(t?.hash??ft)(e);return{id:n,version:0,cid:o,prev:null}}function Kt(r,e,t){r.version+=1,"cid"in r&&(r.prev=r.cid,r.cid=t(e))}var $n,In,qt=j(()=>{"use strict";$n=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]),In=new TextEncoder});function Jt(r){return{node:r,unsub:null,prevData:void 0,dirty:!1,involvedThisWave:!1,dataBatch:[],terminal:void 0}}function ht(r){r.prevData=void 0,r.dirty=!1,r.involvedThisWave=!1,r.dataBatch.length=0,r.terminal=void 0}function Be(r){return r.length===0?r:typeof r[0]=="symbol"?[r]:r}function oe(r,e,t){let n=Yt(r)?r:[],s=typeof r=="function"?r:typeof e=="function"?e:void 0,o={};return Yt(r)?o=(gt(e)?e:t)??{}:gt(r)?o=r:o=(gt(e)?e:t)??{},new $(n,s,o)}var Wt,Ut,zn,jn,Oe,$,Yt,gt,me=j(()=>{"use strict";ct();$e();pe();_e();It();Ne();se();qt();Wt=()=>{},Ut=100;zn=(r,e,t,n)=>{t.direction==="down-in"&&r._onDepMessage(t.depIndex,e)},jn=(r,e,t,n)=>{let s=r;if(s._status==="completed"||s._status==="errored")return;let o=s._cached,i=o===void 0?[Fe]:[Fe,[D,o]];s._status==="dirty"&&i.push(ge),Me(e,i,s._config.tierOf)},Oe=new je({onMessage:zn,onSubscribe:jn});$t(Oe);Ht(Oe);$=class r{_optsName;_describeKind;meta;_hasMeta;_config;_deps;_sinks=null;_sinkCount=0;_cached;_status;_cleanup;_store={};_waveHasNewData=!1;_hasNewTerminal=!1;_hasCalledFnOnce=!1;_paused=!1;_pendingWave=!1;_isExecutingFn=!1;_pendingRerun=!1;_rerunDepth=0;_dirtyDepCount=0;_batchPendingMessages=null;_pauseLocks=null;_pauseBuffer=null;_fn;_equals;_resubscribable;_resetOnTeardown;_autoComplete;_autoError;_pausable;_partial;_guard;_extraGuards;_hashFn;_versioning;_versioningLevel;_lastMutation;_inspectorHooks;_actions;constructor(e,t,n){this._config=n.config??Oe,this._config.onMessage,this._optsName=n.name,this._describeKind=n.describeKind,this._equals=n.equals??Object.is,this._resubscribable=n.resubscribable??!1,this._resetOnTeardown=n.resetOnTeardown??!1,this._autoComplete=n.completeWhenDepsComplete??!0,this._autoError=n.errorWhenDepsError??!0,this._pausable=n.pausable??!0,this._guard=n.guard,this._fn=t,this._partial=n.partial??!1,this._cached=n.initial!==void 0?n.initial:void 0,this._status=e.length===0&&t==null&&this._cached!==void 0?"settled":"sentinel",this._hashFn=n.versioningHash??this._config.defaultHashFn??ft;let s=n.versioning??this._config.defaultVersioning;this._versioningLevel=s,this._versioning=s!=null?pt(s,this._cached===void 0?void 0:this._cached,{id:n.versioningId,hash:this._hashFn}):void 0,this._deps=e.map(Jt);let o={};for(let[a,d]of Object.entries(n.meta??{})){let u={initial:d,name:`${n.name??"node"}:meta:${a}`,describeKind:"state",config:this._config};n.guard!=null&&(u.guard=n.guard),o[a]=new r([],void 0,u)}Object.freeze(o),this.meta=o,this._hasMeta=Object.keys(o).length>0;let i=this;this._actions={emit(a){i._emit([[D,a]])},down(a){i._emit(Be(a))},up(a){i._emitUp(Be(a))}},this.down=this.down.bind(this),this.up=this.up.bind(this)}get _isTerminal(){return this._status==="completed"||this._status==="errored"}get name(){return this._optsName}get status(){return this._status}get cache(){return this._cached===void 0?void 0:this._cached}get lastMutation(){return this._lastMutation}get v(){return this._versioning}hasGuard(){return this._guard!=null}_applyVersioning(e,t){if(this._isExecutingFn)throw new Error(`Node "${this.name}": _applyVersioning cannot run mid-fn \u2014 call it outside of \`_execFn\` (typically at graph setup time before the first subscribe).`);let n=this._versioningLevel;if(n!=null&&e<=n)return;let s=t?.hash??this._hashFn;s!==this._hashFn&&(this._hashFn=s);let o=this._cached===void 0?void 0:this._cached,i=this._versioning,a=i?.id??t?.id,d=i?.version??0,u=pt(e,o,{id:a,hash:s});u.version=d,this._versioning=u,this._versioningLevel=e}_setInspectorHook(e){return e==null?()=>{}:(this._inspectorHooks==null&&(this._inspectorHooks=new Set),this._inspectorHooks.add(e),()=>{this._inspectorHooks?.delete(e),this._inspectorHooks?.size===0&&(this._inspectorHooks=void 0)})}_pushGuard(e){return this._extraGuards==null&&(this._extraGuards=new Set),this._extraGuards.add(e),()=>{this._extraGuards?.delete(e),this._extraGuards?.size===0&&(this._extraGuards=void 0)}}allowsObserve(e){if(this._guard==null&&this._extraGuards==null)return!0;let t=Le(e);if(this._guard!=null&&!this._guard(t,"observe"))return!1;if(this._extraGuards!=null){for(let n of this._extraGuards)if(!n(t,"observe"))return!1}return!0}_checkGuard(e){if(e?.internal)return;let t=this._guard!=null||this._extraGuards!=null,n=e?.actor!=null;if(!t&&!n)return;let s=Le(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:ee()}}down(e,t){let n=Be(e);n.length!==0&&(this._checkGuard(t),this._emit(n))}emit(e,t){this._checkGuard(t),this._emit([[D,e]])}up(e,t){if(this._deps.length===0)return;let n=Be(e);if(n.length===0)return;this._checkGuard(t);let s=t??{internal:!0};this._validateUpTiers(n);for(let o of this._deps)o.node.up?.(n,s)}_emitUp(e){if(this._deps.length!==0&&e.length!==0){this._validateUpTiers(e);for(let t of this._deps)t.node.up?.(e,{internal:!0})}}_validateUpTiers(e){let t=this._config.tierOf;for(let n of e){let s=t(n[0]);if(s===3||s===4)throw new Error(`Node "${this.name}": tier-${s} messages cannot flow up \u2014 DATA/RESOLVED/COMPLETE/ERROR are downstream-only. Use \`down(...)\` for value delivery; \`up(...)\` is for control signals (DIRTY, INVALIDATE, PAUSE, RESUME, TEARDOWN).`)}}subscribe(e,t){if(t!=null&&this._guard!=null){let d=Le(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)ht(d);if(this._partial===!1){for(let d of this._deps)if(d.prevData!==void 0||d.dataBatch.length!==0||d.terminal!==void 0||d.dirty)throw new Error(`resubscribable-reset invariant: DepRecord not fully reset for node ${this._optsName??"(anonymous)"}`)}}this._sinkCount+=1;let o;try{o=this._config.onSubscribe(this,e,{sinkCount:this._sinkCount,afterTerminalReset:s},this._actions)}catch(d){throw this._sinkCount-=1,d}this._sinks==null?this._sinks=e:typeof this._sinks=="function"?this._sinks=new Set([this._sinks,e]):this._sinks.add(e);let i=this._isTerminal;if(this._sinkCount===1&&!i)try{this._activate()}catch(d){if(this._sinkCount-=1,this._removeSink(e),this._sinkCount===0&&(this._status="sentinel"),typeof o=="function")try{o()}catch{}throw d}this._status==="sentinel"&&this._cached===void 0&&(this._status="pending");let a=!1;return()=>{a||(a=!0,this._sinkCount-=1,this._removeSink(e),typeof o=="function"&&o(),this._sinks==null&&this._deactivate())}}_removeSink(e){if(this._sinks===e)this._sinks=null;else if(this._sinks!=null&&typeof this._sinks!="function")if(this._sinks.delete(e),this._sinks.size===1){let[t]=this._sinks;this._sinks=t}else this._sinks.size===0&&(this._sinks=null)}_activate(){if(this._deps.length===0){this._fn&&this._execFn();return}this._dirtyDepCount=0;let e=this._deps.length,t=0;try{for(let n=0;n<e;n++){let s=n,o=this._deps[n];o.unsub=Wt,o.unsub=o.node.subscribe(i=>{if(o.unsub===null)return;let a=this._config.tierOf,d=!1;for(let u of i)a(u[0])>=3&&(d=!0),this._config.onMessage(this,u,{direction:"down-in",depIndex:s},this._actions);d&&this._maybeRunFnOnSettlement()}),t++}}catch(n){this._deps[t].unsub=null;for(let s=0;s<t;s++){let o=this._deps[s];if(o.unsub!=null){let i=o.unsub;o.unsub=null;try{i()}catch{}ht(o)}}throw this._dirtyDepCount=0,n}}_addDep(e){for(let s=0;s<this._deps.length;s++)if(this._deps[s].node===e)return s;let t=this._deps.length,n=Jt(e);if(this._deps.push(n),this._sinks==null)return t;n.dirty=!0,this._dirtyDepCount++,this._status!=="dirty"&&this._emit(Ve),n.unsub=Wt;try{n.unsub=e.subscribe(s=>{if(n.unsub===null)return;let o=this._config.tierOf,i=!1;for(let a of s)o(a[0])>=3&&(i=!0),this._config.onMessage(this,a,{direction:"down-in",depIndex:t},this._actions);i&&this._maybeRunFnOnSettlement()})}catch(s){throw n.unsub=null,this._deps.pop(),this._dirtyDepCount--,s}return t}_deactivate(e=!1){let t=this._cleanup;if(this._cleanup=void 0,typeof t=="function")try{t()}catch(n){this._emit([[C,this._wrapFnError("cleanup threw",n)]])}else if(t!=null&&typeof t=="object"){let n=t.deactivate;if(typeof n=="function")try{n()}catch(s){this._emit([[C,this._wrapFnError("cleanup.deactivate threw",s)]])}}for(let n of this._deps){if(n.unsub!=null){let s=n.unsub;n.unsub=null;try{s()}catch{}}ht(n)}this._waveHasNewData=!1,this._hasNewTerminal=!1,this._hasCalledFnOnce=!1,this._paused=!1,this._pendingWave=!1,this._pendingRerun=!1,this._rerunDepth=0,this._store={},this._dirtyDepCount=0,this._pauseLocks=null,this._pauseBuffer=null,this._fn!=null&&(this._cached=void 0),e||(this._fn!=null||this._deps.length>0)&&(!this._isTerminal||this._resubscribable)&&(this._status="sentinel")}_onDepMessage(e,t){let n=this._deps[e],s=t[0];if(this._inspectorHooks!=null){let o={kind:"dep_message",depIndex:e,message:t};for(let i of this._inspectorHooks)i(o)}if(s!==he){if(s===V){this._depDirtied(n);return}if(s===Y){if(this._depInvalidated(n),this._cached===void 0)return;this._emit(it);return}if(s===te||s===re){this._emit([t]);return}if(s===z){this._emit(ze);return}if(s===D)this._depSettledAsData(n,t[1]);else if(s===W)this._depSettledAsResolved(n);else if(s===F)this._depSettledAsTerminal(n,!0);else if(s===C)this._depSettledAsTerminal(n,t[1]);else{this._emit([t]);return}if(!this._fn){(s===D||s===W)&&this._emit([t]),(s===F||s===C)&&this._maybeAutoTerminalAfterWave();return}}}_depDirtied(e){e.dirty||(e.dirty=!0,e.involvedThisWave=!0,this._dirtyDepCount++,this._status!=="dirty"&&this._emit(Ve))}_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(ot),this._maybeAutoTerminalAfterWave();return}this._fn&&this._execFn(),this._maybeAutoTerminalAfterWave()}}_maybeAutoTerminalAfterWave(){if(this._deps.length===0||this._isTerminal)return;let e=this._deps.find(t=>t.terminal!==void 0&&t.terminal!==!0);if(e!=null){this._autoError&&this._emit([[C,e.terminal]]);return}this._autoComplete&&this._deps.every(t=>t.terminal!==void 0)&&this._emit(at)}_execFn(){if(!this._fn||this._isTerminal&&!this._resubscribable)return;if(this._isExecutingFn){this._pendingRerun=!0;return}let e=this._cleanup;if(typeof e=="function"){this._cleanup=void 0;try{e()}catch(i){this._emit([[C,this._wrapFnError("cleanup threw",i)]]);return}}else if(e!=null&&typeof e=="object"){let i=e.beforeRun;if(typeof i=="function"){e.beforeRun=void 0;try{i()}catch(a){this._emit([[C,this._wrapFnError("cleanup.beforeRun threw",a)]]);return}}}let t=this._deps.map(i=>i.involvedThisWave?i.dataBatch.length>0?[...i.dataBatch]:[]:void 0),n=this._deps.map(i=>i.prevData);for(let i=0;i<this._deps.length;i++){let a=t[i];a!=null&&a.length>0&&(this._deps[i].prevData=a[a.length-1])}let s=this._deps.map(i=>i.terminal),o={prevData:n,terminalDeps:s,store:this._store};if(this._hasCalledFnOnce=!0,this._clearWaveFlags(),this._inspectorHooks!=null){let i={kind:"run",batchData:t,prevData:n};for(let a of this._inspectorHooks)a(i)}this._isExecutingFn=!0;try{let i=this._fn(t,this._actions,o);if(typeof i=="function")this._cleanup=i;else if(i!=null&&typeof i=="object"){let a=i;(typeof a.beforeRun=="function"||typeof a.deactivate=="function"||typeof a.invalidate=="function")&&(this._cleanup=i)}}catch(i){this._emit([[C,this._wrapFnError("fn threw",i)]])}finally{this._isExecutingFn=!1,this._pendingRerun?(this._pendingRerun=!1,this._rerunDepth+=1,this._rerunDepth>Ut?(this._rerunDepth=0,this._emit([[C,new Error(`Node "${this.name}": _pendingRerun depth exceeded ${Ut} \u2014 likely a reactive cycle`)]])):this._maybeRunFnOnSettlement()):this._rerunDepth=0,this._clearWaveFlags()}}_clearWaveFlags(){this._waveHasNewData=!1,this._hasNewTerminal=!1;for(let e of this._deps)e.involvedThisWave=!1,e.dataBatch.length=0}_wrapFnError(e,t){let n=t instanceof Error?t.message:String(t);return new Error(`Node "${this.name}": ${e}: ${n}`,{cause:t})}_frameBatch(e){let t=this._config.tierOf;if(e.length===1)return t(e[0][0])===3&&this._status!=="dirty"?[ge,e[0]]:e;let n=!0,s=!1,o=!1,i=-1;for(let d of e){let u=t(d[0]);u<i&&(n=!1),u===3&&(s=!0),d[0]===V&&(o=!0),i=u}let a=e;if(!n){let d=e.map((u,c)=>({m:u,i:c,tier:t(u[0])}));d.sort((u,c)=>u.tier-c.tier||u.i-c.i),a=d.map(u=>u.m)}if(s&&!o&&this._status!=="dirty"){let d=0;for(;d<a.length&&t(a[d][0])===0;)d++;return d===0?[ge,...a]:[...a.slice(0,d),ge,...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]===C&&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]===z||d[0]===Y);if(a.length===0)return;t=a}t=this._frameBatch(t);let s=null;for(let a=0;a<t.length;a++){let d=t[a],u=d[0];if(u!==te&&u!==re){s?.push(d);continue}if(d.length<2)throw new Error(`Node "${this.name}": [[${u===te?"PAUSE":"RESUME"}]] must carry a lockId payload \u2014 bare PAUSE/RESUME is a protocol violation (C0 rule). Use \`[[PAUSE, lockId]]\` / \`[[RESUME, lockId]]\`.`);let c=!0;if(this._pausable!==!1){let p=d[1];if(u===te)this._pauseLocks==null&&(this._pauseLocks=new Set),this._pauseLocks.add(p),this._paused=!0,this._pausable==="resumeAll"&&this._pauseBuffer==null&&(this._pauseBuffer=[]);else if(this._pauseLocks==null||!this._pauseLocks.has(p))c=!1;else if(this._pauseLocks.delete(p),this._pauseLocks.size===0){if(this._paused=!1,this._pauseBuffer!=null&&this._pauseBuffer.length>0){let f=this._pauseBuffer;this._pauseBuffer=[],this._emit(f)}this._pendingWave&&(this._pendingWave=!1,this._maybeRunFnOnSettlement())}}c?s?.push(d):s==null&&(s=t.slice(0,a))}if(s!=null){if(s.length===0)return;t=s}if(this._hasMeta&&t.some(a=>a[0]===z))for(let a of Object.keys(this.meta))try{this.meta[a]._emit(ze)}catch{}let{finalMessages:o,equalsError:i}=this._updateState(t);if(o.length>0&&this._config.inspectorEnabled){let a=this._config.globalInspector;if(a!=null)try{a({kind:"emit",node:this,messages:o})}catch{}}if(o.length>0)if(this._paused&&this._pausable==="resumeAll"&&this._pauseBuffer!=null){let a=this._config.tierOf,d=[];for(let u of o)a(u[0])===3?this._pauseBuffer.push(u):d.push(u);d.length>0&&this._dispatchOrAccumulate(d)}else this._dispatchOrAccumulate(o);i!=null&&this._emit([[C,i]])}_updateState(e){let t=this._config.tierOf,n,s,o=-1,i=0;for(let c of e)t(c[0])===3&&i++;let a=i<=1,d=-1;if(this._versioning!=null&&i>1){for(let c=e.length-1;c>=0;c--)if(e[c][0]===D){d=c;break}}for(let c=0;c<e.length;c++){let p=e[c],f=p[0];if(f===D){if(p.length>=2){let h=!1;if(a&&this._cached!==void 0)try{h=this._equals(this._cached,p[1])}catch(l){s=this._wrapFnError("equals threw",l),o=c;break}if(h){n==null&&(n=e.slice(0,c)),n.push(Ie),this._status="resolved";continue}this._cached=p[1],this._versioning!=null&&(d<0||c===d)&&Kt(this._versioning,p[1],this._hashFn)}this._status="settled",n?.push(p)}else if(n?.push(p),f===V)this._status="dirty";else if(f===W)this._status="resolved";else if(f===F){this._status="completed";{let h=this._config.rigorRecorder;if(h!=null)try{h.onTerminalTransition(this,"completed",this._autoComplete,this._autoError,this._deps.length>0)}catch{}}}else if(f===C){this._status="errored";{let h=this._config.rigorRecorder;if(h!=null)try{h.onTerminalTransition(this,"errored",this._autoComplete,this._autoError,this._deps.length>0)}catch{}}}else if(f===Y){if(this._cached!==void 0){let l=this._config.rigorRecorder;if(l!=null)try{l.onNonVacuousInvalidate(this,this._cached)}catch{}}this._cached=void 0,this._status="dirty";let h=this._cleanup;if(typeof h=="function"){this._cleanup=void 0;try{h()}catch{}}else if(h!=null&&typeof h=="object"){let l=h.invalidate;if(typeof l=="function")try{l()}catch{}}}else f===z&&(this._resetOnTeardown&&(this._cached=void 0),this._deactivate(!0),this._status="sentinel")}let u=o>=0?n??e.slice(0,o):n??e;return s!=null?{finalMessages:u,equalsError:s}:{finalMessages:u}}_deliverToSinks=e=>{if(this._sinks==null)return;if(typeof this._sinks=="function"){this._sinks(e);return}let t=[...this._sinks];for(let n of t)n(e)};_dispatchOrAccumulate(e){if(Ct()){this._batchPendingMessages===null&&(this._batchPendingMessages=[],ke(()=>this._flushBatchPending()));for(let t of e)this._batchPendingMessages.push(t);return}Me(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);Me(this._deliverToSinks,t,this._config.tierOf)}},Yt=r=>Array.isArray(r),gt=r=>typeof r=="object"&&r!=null&&!Array.isArray(r)});function He(r,e){if(e!=null&&e.length>0)return new Set(e);switch(r){case"standard":return new Set(["type","status","value","deps","meta","v"]);case"full":return null;case"spec":return new Set(["type","deps","meta","value"]);default:return new Set(["type","deps"])}}function Bn(r){return r._describeKind!=null?r._describeKind:r._deps.length>0?"derived":r._fn!=null?"producer":"state"}function bt(r){let e=new WeakSet,t={};for(let[n,s]of Qt(r))t[n]=mt(s,e);return t}function mt(r,e){if(r==null)return r;let t=typeof r;if(t==="boolean"||t==="number"||t==="string")return r;if(t==="function")return"<function>";if(Array.isArray(r))return e.has(r)?"<cycle>":(e.add(r),r.map(n=>mt(n,e)));if(t==="object"){let n=r;if(e.has(n))return"<cycle>";e.add(n);try{if(typeof n.subscribe=="function"&&"cache"in n)return"<Node>"}catch{return"<unserializable>"}let s={};for(let[o,i]of Qt(n))s[o]=mt(i,e);return s}return"<unserializable>"}function Qt(r){let e=[],t;try{t=Object.keys(r)}catch{return e}for(let n of t)try{e.push([n,r[n]])}catch{e.push([n,"<unserializable>"])}return e}function Hn(r){let e={};for(let[t,n]of Object.entries(r.meta))try{e[t]=n.cache}catch{}return e}function yt(r,e,t){let n=e==null,s=!n&&e!=null?[...e].filter(c=>c.startsWith("meta.")).map(c=>c.slice(5)):null,o=n||e.has("meta")||s!=null&&s.length>0,i="state",a=[];r instanceof $&&(i=Bn(r),a=r._deps.map(c=>c.node.name??""));let d={type:i,deps:a};(n||e.has("status"))&&(d.status=r.status);let u=r instanceof $?r._guard:void 0;if(o){let c={...Hn(r)};if(u!=null&&c.access===void 0&&(c.access=dt(u)),s!=null&&s.length>0&&!e.has("meta")){let p={};for(let f of s)f in c&&(p[f]=c[f]);d.meta=p}else d.meta=c}if(r.name!=null&&(d.name=r.name),(n||e.has("value"))&&(!t||i==="state")){r.status==="sentinel"&&(d.sentinel=!0);try{d.value=r.cache}catch{}}if((n||e.has("v"))&&r.v!=null){let c={id:r.v.id,version:r.v.version};"cid"in r.v&&(c.cid=r.v.cid,c.prev=r.v.prev),d.v=c}return(n||e.has("guard"))&&u!=null&&(d.guard=dt(u)),(n||e.has("lastMutation"))&&r.lastMutation!=null&&(d.lastMutation=r.lastMutation),d}var vt=j(()=>{"use strict";Ne();me()});function B(r,e){return oe([],{...e,initial:r})}function de(r,e){return oe((n,s,o)=>r(s,o)??void 0,{describeKind:"producer",...e})}function X(r,e,t){return oe(r,(s,o,i)=>{let a=s.map((d,u)=>d!=null&&d.length>0?d.at(-1):i.prevData[u]);o.emit(e(a,i))},{describeKind:"derived",...t})}var ue=j(()=>{"use strict";me()});function Xt(r,e,t){return{[r]:!0,[`${r}_type`]:e,...t??{}}}var Zt=j(()=>{"use strict"});function Tt(r){return{describeKind:"producer",...r}}function tn(r,e){return de(t=>{let n=!1;try{for(let s of r){if(n)return;t.emit(s)}n||t.down([[F]])}catch(s){n||t.down([[C,s]])}return()=>{n=!0}},Tt(e))}function Kn(r){return r!=null&&typeof r.then=="function"}function qn(r,e){let{signal:t,...n}=e??{};return de(s=>{let o=!1,i=()=>{o||(o=!0,s.down([[C,t.reason]]))};if(t?.aborted){i();return}return t?.addEventListener("abort",i,{once:!0}),Promise.resolve(r).then(a=>{o||(o=!0,t?.removeEventListener("abort",i),s.emit(a),s.down([[F]]))},a=>{o||(o=!0,t?.removeEventListener("abort",i),s.down([[C,a]]))}),()=>{o=!0,t?.removeEventListener("abort",i)}},Tt(n))}function Wn(r,e){let{signal:t,...n}=e??{};return de(s=>{let o=new AbortController,i=()=>o.abort(t?.reason);t?.aborted?o.abort(t.reason):t?.addEventListener("abort",i,{once:!0});let a=t??o.signal,d=!1,u=r[Symbol.asyncIterator](),c=()=>{d||a.aborted||Promise.resolve(u.next()).then(p=>{if(!(d||a.aborted)){if(p.done){s.down([[F]]);return}s.emit(p.value),c()}},p=>{!d&&!a.aborted&&s.down([[C,p]])})};return c(),()=>{d=!0,t?.removeEventListener("abort",i),o.abort(),Promise.resolve(u.return?.()).catch(()=>{})}},Tt(n))}function Un(r){return r!=null&&typeof r=="object"&&"cache"in r&&typeof r.subscribe=="function"}function nn(r,e){if(Un(r))return r;if(Kn(r))return qn(r,e);if(r!=null){let t=r;if(typeof t[Symbol.asyncIterator]=="function")return Wn(r,e);if(typeof t[Symbol.iterator]=="function")return tn(r,e)}return Jn(r)}function Jn(...r){return tn(r,void 0)}function ie(r){return r.subscribe(()=>{})}var rn=j(()=>{"use strict";se();ue()});var xt=j(()=>{"use strict";rn()});var Ke,sn=j(()=>{"use strict";Ke=class{_timer;_gen=0;start(e,t){this.cancel(),this._gen+=1;let n=this._gen;this._timer=setTimeout(()=>{this._timer=void 0,n===this._gen&&t()},e)}cancel(){this._timer!==void 0&&(clearTimeout(this._timer),this._timer=void 0)}get pending(){return this._timer!==void 0}}});var De,on=j(()=>{"use strict";De=class{constructor(e){this.capacity=e;if(!Number.isInteger(e)||e<=0)throw new Error(`RingBuffer capacity must be a positive integer (got ${e})`);this.buf=new Array(e)}buf;head=0;_size=0;get size(){return this._size}get maxSize(){return this.capacity}push(e){let t=(this.head+this._size)%this.capacity;this.buf[t]=e,this._size<this.capacity?this._size++:this.head=(this.head+1)%this.capacity}shift(){if(this._size===0)return;let e=this.buf[this.head];return this.buf[this.head]=void 0,this.head=(this.head+1)%this.capacity,this._size--,e}at(e){if(this._size===0)return;let t=e<0?this._size+e:e;if(!(t<0||t>=this._size))return this.buf[(this.head+t)%this.capacity]}toArray(){let e=new Array(this._size);for(let t=0;t<this._size;t++)e[t]=this.buf[(this.head+t)%this.capacity];return e}clear(){for(let e=0;e<this._size;e++)this.buf[(this.head+e)%this.capacity]=void 0;this.head=0,this._size=0}}});var vr={};Sn(vr,{JobFlowGraph:()=>Ze,JobQueueGraph:()=>Xe,jobEventKeyOf:()=>br,jobFlow:()=>yr,jobQueue:()=>On});module.exports=Dn(vr);_e();$e();pe();Ne();se();vt();ue();me();Zt();Ne();ue();$e();pe();_e();Ne();se();vt();me();ue();_e();function _t(r,e){if(Object.is(r,e))return!0;if(r==null||e==null||typeof r!="object"||typeof e!="object")return!1;if(Array.isArray(r)){if(!Array.isArray(e)||r.length!==e.length)return!1;for(let o=0;o<r.length;o++)if(!_t(r[o],e[o]))return!1;return!0}if(Array.isArray(e))return!1;let t=Object.keys(r),n=Object.keys(e);if(t.length!==n.length)return!1;let s=new Set(n);for(let o of t)if(!s.has(o)||!_t(r[o],e[o]))return!1;return!0}function en(r,e){return`${r}\0${e}`}function wt(r,e){let t=[],n=new Set(r.subgraphs),s=new Set(e.subgraphs),o=[];for(let g of s)n.has(g)||o.push(g);o.sort();for(let g of o)t.push({type:"subgraph-mounted",path:g});let i=new Set(Object.keys(r.nodes)),a=new Set(Object.keys(e.nodes)),d=[];for(let g of a)i.has(g)||d.push(g);d.sort();for(let g of d)t.push({type:"node-added",path:g,node:{...e.nodes[g]}});let u=[];for(let g of a){if(!i.has(g))continue;let v=r.nodes[g]?.meta,_=e.nodes[g]?.meta;v==null&&_==null||_t(v??{},_??{})||u.push(g)}u.sort();for(let g of u)t.push({type:"node-meta-changed",path:g,prevMeta:r.nodes[g]?.meta??{},nextMeta:e.nodes[g]?.meta??{}});let c=new Map;for(let g of r.edges)c.set(en(g.from,g.to),g);let p=new Map;for(let g of e.edges)p.set(en(g.from,g.to),g);let f=[];for(let[g,v]of p)c.has(g)||f.push(v);f.sort((g,v)=>g.from<v.from?-1:g.from>v.from?1:g.to<v.to?-1:g.to>v.to?1:0);for(let g of f)t.push({type:"edge-added",from:g.from,to:g.to});let h=[];for(let[g,v]of c)p.has(g)||h.push(v);h.sort((g,v)=>g.from<v.from?-1:g.from>v.from?1:g.to<v.to?-1:g.to>v.to?1:0);for(let g of h)t.push({type:"edge-removed",from:g.from,to:g.to});let l=[];for(let g of i)a.has(g)||l.push(g);l.sort();for(let g of l)t.push({type:"node-removed",path:g});let b=[];for(let g of n)s.has(g)||b.push(g);b.sort();for(let g of b)t.push({type:"subgraph-unmounted",path:g});return{events:t,flushedAt_ns:K()}}xt();sn();on();ct();function an(r,e,t,n={}){let s=e in r.nodes,o=t in r.nodes;if(!s)return qe(e,t,"no-such-from");if(!o)return qe(e,t,"no-such-to");let i=n.maxDepth;if(i!=null&&(!Number.isInteger(i)||i<0))throw new Error("explainPath: maxDepth must be an integer >= 0");if(e===t){if(n.findCycle===!0){let u=Yn(r,e,n);if(u!=null)return u}let d=We(e,r.nodes[e],0,n);return Ue(e,t,[d])}if(i===0)return qe(e,t,"no-path");let a=dn(r,e,t,i);return a.found?Ue(e,t,un(r,a.pathOrder,n)):qe(e,t,a.truncated?"max-depth-exceeded":"no-path")}function dn(r,e,t,n){let s=new Map,o=[{path:t,depth:0}],i=new Set([t]),a=0,d=!1;for(;a<o.length;){let p=o[a++];if(p.path===e)break;if(n!=null&&p.depth>=n){let b=r.nodes[p.path];b?.deps&&b.deps.length>0&&(d=!0);continue}let f=r.nodes[p.path];if(f==null)continue;let h=f.deps??[],l=new Map;for(let b=0;b<h.length;b++){let g=h[b];if(!g)continue;let v=l.get(g);v==null&&(v=[],l.set(g,v)),v.push(b)}for(let[b,g]of l)i.has(b)||(i.add(b),s.set(b,{from:p.path,depIndices:g}),o.push({path:b,depth:p.depth+1}))}if(!s.has(e))return{found:!1,pathOrder:[],truncated:d};let u=[{path:e}],c=e;for(;c!==t;){let p=s.get(c);if(p==null)return{found:!1,pathOrder:[],truncated:!1};u[u.length-1].depIndices=p.depIndices,u.push({path:p.from}),c=p.from}return{found:!0,pathOrder:u,truncated:!1}}function Yn(r,e,t){let n=r.nodes[e];if(n==null)return null;let s=n.deps??[],o=[];for(let a=0;a<s.length;a++)s[a]===e&&o.push(a);if(o.length>0){let a=We(e,n,0,t);a.dep_index=o[0];let d=We(e,n,1,t);return Ue(e,e,[a,d])}let i=null;for(let a=0;a<s.length;a++){let d=s[a];if(!d||d===e)continue;let u=dn(r,d,e,t.maxDepth);u.found&&(i==null||u.pathOrder.length<i.pathOrder.length)&&(i=u,i={found:!0,pathOrder:[{path:e,depIndices:[a]},...u.pathOrder],truncated:!1})}return i==null?null:Ue(e,e,un(r,i.pathOrder,t))}function un(r,e,t){return e.map((n,s)=>{let o=r.nodes[n.path],i=We(n.path,o,s,t);return n.depIndices!=null&&n.depIndices.length>0&&(i.dep_index=n.depIndices[0],n.depIndices.length>1&&(i.dep_indices=[...n.depIndices])),i})}function We(r,e,t,n){let s={path:r,type:e.type,hop:t};e.status!==void 0&&(s.status=e.status),"value"in e&&(s.value=e.value),e.v!=null&&(s.v=e.v);let o=n.annotations?.get(r)??e.annotation;o!=null&&(s.annotation=o);let i=n.lastMutations?.get(r)??e.lastMutation;return i!=null&&(s.lastMutation=i),s}function Ue(r,e,t){return cn(r,e,!0,"ok",t)}function qe(r,e,t){return cn(r,e,!1,t,[])}function cn(r,e,t,n,s){let o=Qn(r,e,t,n,s);return{from:r,to:e,found:t,reason:n,steps:s,text:o,toJSON(){return{from:r,to:e,found:t,reason:n,steps:s}}}}function Qn(r,e,t,n,s){if(!t)switch(n){case"no-such-from":return`explainPath: no node named "${r}"`;case"no-such-to":return`explainPath: no node named "${e}"`;case"max-depth-exceeded":return`explainPath: no path from "${r}" to "${e}" within maxDepth`;default:return`explainPath: no path from "${r}" to "${e}"`}let o=[`Causal path: ${r} \u2192 ${e} (${s.length} step(s))`];for(let i of s){let d=` ${i.hop===0?"\xB7":"\u2193"} ${i.path} (${i.type}${i.status?`/${i.status}`:""})`;if(o.push(d),"value"in i&&o.push(` value: ${Xn(i.value)}`),i.annotation!=null&&o.push(` annotation: ${i.annotation}`),i.lastMutation!=null){let u=i.lastMutation.actor;o.push(` actor: ${u.type}${u.id?`:${u.id}`:""}`)}}return o.join(`
2
- `)}function Xn(r){if(r===void 0)return"<sentinel>";if(r===null)return"null";if(typeof r=="string")return JSON.stringify(r);if(typeof r=="number"||typeof r=="boolean"||typeof r=="bigint")return String(r);try{let e=JSON.stringify(r);return e.length>80?`${e.slice(0,77)}...`:e}catch{return String(r)}}me();var I={object:56,array:64,string:40,number:8,boolean:4,null:0,undefined:0,symbol:40,bigint:16,function:120,map:72,set:72,mapEntry:40,setEntry:24,date:24,regexp:48,error:64,url:80,promise:48,weakmap:40,weakset:40},Zn=Symbol.for("sizeof");function ln(r){let e=new WeakSet,t=new WeakSet,n=[r],s=0;for(;n.length>0;){let o=n.pop();s+=er(o,e,t,n)}return s}function er(r,e,t,n){if(r==null)return 0;switch(typeof r){case"number":return I.number;case"boolean":return I.boolean;case"string":return I.string+r.length*2;case"bigint":return I.bigint+tr(r);case"symbol":return I.symbol;case"function":return e.has(r)?0:(e.add(r),I.function);case"undefined":return 0}let o=r;if(e.has(o))return 0;e.add(o);let i=o[Zn];if(typeof i=="function")try{let u=i.call(o);if(typeof u=="number"&&Number.isFinite(u))return u}catch{}if(o instanceof Date)return I.date;if(o instanceof RegExp)return I.regexp+o.source.length*2;if(o instanceof Error){let u=o.message?o.message.length*2:0,c=o.stack?o.stack.length*2:0;return I.error+u+c}if(typeof URL<"u"&&o instanceof URL)return I.url+o.href.length*2;if(typeof Promise<"u"&&o instanceof Promise)return I.promise;if(o instanceof WeakMap)return I.weakmap;if(o instanceof WeakSet)return I.weakset;if(o instanceof Map){let u=I.map;for(let[c,p]of o)u+=I.mapEntry,n.push(c),n.push(p);return u}if(o instanceof Set){let u=I.set;for(let c of o)u+=I.setEntry,n.push(c);return u}if(Array.isArray(o)){let u=I.array+o.length*8;for(let c of o)n.push(c);return u}if(o instanceof ArrayBuffer)return t.has(o)?0:(t.add(o),o.byteLength);if(ArrayBuffer.isView(o)){let u=o;return t.has(u.buffer)?48:(t.add(u.buffer),u.buffer.byteLength+48)}let a=I.object,d=Object.keys(o);for(let u of d){a+=I.string+u.length*2;try{n.push(o[u])}catch{}}return a}function tr(r){let e=r<0n?-r:r;if(e===0n)return 0;let t=e.toString(2).length;return Math.ceil(t/32)*8}function fn(r,e){let t=e?.topN??10,n=r.describe({detail:"standard"}),s=[],o=r._collectObserveTargets;typeof o=="function"&&o.call(r,"",s);let i=new Map;for(let[f,h]of s)i.set(f,h);let a=[];for(let[f,h]of Object.entries(n.nodes)){let l=i.get(f),b=l instanceof $?l:null,g=b?ln(b.cache):0,v=b?b._sinkCount:0,_=h.deps?.length??0,y=h.type==="effect"&&v===0,w=v===0?h.type==="effect"?"orphan-effect":h.type==="derived"?"idle-derived":h.type==="producer"?"idle-producer":null:null;a.push({path:f,type:h.type,status:h.status??"unknown",valueSizeBytes:g,subscriberCount:v,depCount:_,isOrphanEffect:y,orphanKind:w})}let d=a.reduce((f,h)=>f+h.valueSizeBytes,0),u=(f,h)=>[...a].sort(h??((l,b)=>b[f]-l[f])).slice(0,t),c=a.filter(f=>f.orphanKind!=null),p=a.filter(f=>f.isOrphanEffect);return{nodeCount:a.length,edgeCount:n.edges.length,subgraphCount:n.subgraphs.length,nodes:a,totalValueSizeBytes:d,hotspots:{byValueSize:u("valueSizeBytes"),bySubscriberCount:u("subscriberCount"),byDepCount:u("depCount")},orphans:c,orphanEffects:p}}var L="::",Z="__meta__",be=1;function pn(r,e){let t=Math.max(16,r.size*4),n=0;for(;r.size>0;){if(n++>=t){console.error(`[Graph "${e}".destroy] disposer drain exceeded cap (${t}); ${r.size} disposer(s) discarded`),r.clear();return}let s=r.values().next();if(s.done)return;let o=s.value;r.delete(o);try{o()}catch(i){console.error(`[Graph "${e}".destroy] disposer threw:`,i)}}}function yn(r){return r!=null&&typeof r=="object"&&"cache"in r&&typeof r.subscribe=="function"&&typeof r.down=="function"}function nr(r){if(r!=null)return yn(r)?r.cache:r}function ye(r){return r!=null&&typeof r=="object"&&"cache"in r&&typeof r.subscribe=="function"&&typeof r.down=="function"}function ce(r){return ye(r)?r.cache??"":r}function hn(r){return ye(r)?r.cache??0:r}function gn(r){return ye(r)?r.cache??!1:r}function rr(r){let e=[];for(let t of Object.keys(r).sort()){let n=r[t].v;n!=null&&e.push(`${t} ${n.id} ${n.version}`)}return e.join(`
3
- `)}function mn(r){if(r.version!==be)throw new Error(`unsupported snapshot version ${String(r.version)} (expected ${be})`);for(let e of["name","nodes","edges","subgraphs"])if(!(e in r))throw new Error(`snapshot missing required key "${e}"`);if(typeof r.name!="string")throw new TypeError("snapshot 'name' must be a string");if(typeof r.nodes!="object"||r.nodes===null||Array.isArray(r.nodes))throw new TypeError("snapshot 'nodes' must be an object");if(!Array.isArray(r.edges))throw new TypeError("snapshot 'edges' must be an array");if(!Array.isArray(r.subgraphs))throw new TypeError("snapshot 'subgraphs' must be an array")}function sr(r,e){let t=new WeakMap,n=(s,o)=>{if(Object.is(s,o))return!0;if(s==null||o==null||typeof s!="object"||typeof o!="object")return!1;let i=t.get(s);if(i==null&&(i=new WeakSet,t.set(s,i)),i.has(o))return!0;i.add(o);let a=s.constructor,d=o.constructor;if(a!==d)return!1;if(s instanceof Date)return s.getTime()===o.getTime();if(s instanceof RegExp)return s.source===o.source&&s.flags===o.flags;if(Array.isArray(s)){let f=o;if(s.length!==f.length)return!1;for(let h=0;h<s.length;h++)if(!n(s[h],f[h]))return!1;return!0}if(s instanceof Map){let f=o;if(s.size!==f.size)return!1;for(let[h,l]of s)if(!f.has(h)||!n(l,f.get(h)))return!1;return!0}if(s instanceof Set){let f=o;if(s.size!==f.size)return!1;for(let h of s){let l=!1;for(let b of f)if(n(h,b)){l=!0;break}if(!l)return!1}return!0}if(ArrayBuffer.isView(s)){let f=s,h=o;if(f.length!==h.length)return!1;for(let l=0;l<f.length;l++)if(f[l]!==h[l])return!1;return!0}let u=Object.keys(s),c=Object.keys(o);if(u.length!==c.length)return!1;let p=new Set(c);for(let f of u)if(!p.has(f)||!n(s[f],o[f]))return!1;return!0};return n(r,e)}function or(r){return r.replace(/[.*+?^${}()|[\]\\]/g,"\\$&")}function Je(r){let e="^";for(let t=0;t<r.length;t+=1){let n=r[t];if(n==="*"){e+=".*";continue}if(n==="?"){e+=".";continue}if(n==="["){let s=r.indexOf("]",t+1);if(s<=t+1){e+="\\[";continue}let o=r.slice(t+1,s);o.startsWith("!")&&(o=`^${o.slice(1)}`),o=o.replace(/\\/g,"\\\\"),e+=`[${o}]`,t=s;continue}e+=or(n)}return e+="$",new RegExp(e)}var ir={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"},ar={data:"",dirty:"",resolved:"",invalidate:"",pause:"",resume:"",complete:"",error:"",teardown:"",derived:"",path:"",reset:""};function kt(r){if(typeof r=="string")return JSON.stringify(r);if(typeof r=="number"||typeof r=="boolean"||r==null)return String(r);try{return JSON.stringify(r)}catch{return"[unserializable]"}}function dr(r){return r==="none"?ar:r==="ansi"||r==null?ir:{data:r.data??"",dirty:r.dirty??"",resolved:r.resolved??"",invalidate:r.invalidate??"",pause:r.pause??"",resume:r.resume??"",complete:r.complete??"",error:r.error??"",teardown:r.teardown??"",derived:r.derived??"",path:r.path??"",reset:r.reset??""}}function bn(r){if(r==null)return{};let e=r.detail;return e==="full"?{...r,structured:r.structured??!0,timeline:r.timeline??!0,causal:r.causal??!0,derived:r.derived??!0}:e==="minimal"?{...r,structured:r.structured??!0}:r.format==="stage-log"?{...r,structured:r.structured??!0,timeline:r.timeline??!0}:r}function ur(r,e,t){for(let n=0;n<r.length;n++){let s=r.charCodeAt(n);if(s<32||s===127)throw new Error(`Graph "${e}": ${t} "${r}" must not contain control character (U+${s.toString(16).padStart(4,"0").toUpperCase()} at index ${n})`)}}function Nt(r,e,t){if(r==="")throw new Error(`Graph "${e}": ${t} name must be non-empty`);if(r.includes(L))throw new Error(`Graph "${e}": ${t} "${r}" must not contain '${L}' (path separator)`);if(r===Z)throw new Error(`Graph "${e}": ${t} name "${Z}" is reserved for meta companion paths`);ur(r,e,t)}function cr(r,e){if(r==="")throw new Error(`Graph "${e}": resolve path must be non-empty`);let t=r.split(L);for(let n of t)if(n==="")throw new Error(`Graph "${e}": resolve path has empty segment`);return t}function lr(r,e){let t=!1;for(let s of r)if(!e.isMetaPassthrough(s[0])){t=!0;break}return t?r.filter(s=>e.isMetaPassthrough(s[0])):r}function vn(r){for(let e of r._mounts.values())vn(e);for(let e of r._nodes.values())try{e.down([[z]],{internal:!0})}catch{}}var ve=class r{name;opts;config;_nodes=new Map;_nodeToName=new WeakMap;_mounts=new Map;_parent=void 0;_storageDisposers=new Set;_disposers=new Set;_destroyed=!1;_topology;_topologyEmitters=new Set;_factory;_factoryArgs;constructor(e,t){if(e==="")throw new Error("Graph name must be non-empty");if(e.includes(L))throw new Error(`Graph name must not contain '${L}' (got "${e}")`);if(e===Z)throw new Error(`Graph name "${Z}" is reserved for meta companion paths`);this.name=e,this.opts=Object.freeze({...t??{}}),this.config=t?.config??Oe,this._traceRing=new De(t?.traceCapacity??1e3),t?.versioning!=null&&this.setVersioning(t.versioning),typeof t?.factory=="string"&&(this._factory=t.factory,t.factoryArgs!==void 0&&(this._factoryArgs=t.factoryArgs))}tagFactory(e,t){return this._factory=e,this._factoryArgs=t,this}ancestors(e=!0){let t=[],n=e?this:this._parent;for(;n!=null;)t.push(n),n=n._parent;return t}get topology(){return this._topology==null&&(this._topology=de(e=>{let t=n=>{e.emit(n)};return this._topologyEmitters.add(t),()=>{this._topologyEmitters.delete(t)}},{name:`${this.name}_topology`})),this._topology}_emitTopology(e){if(!(this._topology==null||this._topologyEmitters.size===0))for(let t of this._topologyEmitters)t(e)}nameOf(e){return this._nodeToName.get(e)}add(e,t){let n=e.name,s=t?.name??n;if(s==null||s==="")throw new Error(`Graph "${this.name}": graph.add requires a non-empty name \u2014 pass via opts.name or set it on the node (e.g. state(0, { name: "x" }))`);let o=s,i=t?.annotation;if(Nt(o,this.name,"add"),this._mounts.has(o))throw new Error(`Graph "${this.name}": name "${o}" is already a mount point`);if(this._nodes.has(o))throw new Error(`Graph "${this.name}": node "${o}" already exists`);let a=this._nodeToName.get(e);if(a!==void 0)throw new Error(`Graph "${this.name}": node instance already registered as "${a}"`);return this._nodes.set(o,e),this._nodeToName.set(e,o),this._emitTopology({kind:"added",name:o,nodeKind:"node"}),i!=null&&(this._annotations.set(o,i),this.config.inspectorEnabled&&this._traceRing.push({path:o,annotation:i,timestamp_ns:K()})),e}setVersioning(e){if(e!=null)for(let t of this._nodes.values())t instanceof $&&t._applyVersioning(e)}remove(e){Nt(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(`${L}${Z}${L}`)||o.nodes.push(a);return o.nodes.sort(),o.mounts.push(e),o.mounts.push(...t._collectSubgraphs(`${e}${L}`)),this._mounts.delete(e),t._parent=void 0,vn(t),this._emitTopology({kind:"removed",name:e,nodeKind:"mount",audit:o}),o}let n=this._nodes.get(e);if(!n)throw new Error(`Graph "${this.name}": unknown node or mount "${e}"`);this._nodes.delete(e),this._nodeToName.delete(n),n.down([[z]],{internal:!0});let s={kind:"node",nodes:[e],mounts:[]};return this._emitTopology({kind:"removed",name:e,nodeKind:"node",audit:s}),s}removeAll(e){let t=typeof e=="function"?e:(()=>{let o=Je(e);return i=>o.test(i)})(),n={kind:"mount",nodes:[],mounts:[]},s=[...this._nodes.keys(),...this._mounts.keys()].filter(o=>t(o));for(let o of s){let i=this.remove(o);n.nodes.push(...i.nodes),n.mounts.push(...i.mounts)}return n.nodes.sort(),n.mounts.sort(),n}[Symbol.iterator](){let e=[...this._nodes.keys()].sort(),t=this._nodes,n=0;return{[Symbol.iterator](){return this},next(){if(n>=e.length)return{value:void 0,done:!0};let s=e[n++];return{value:[s,t.get(s)],done:!1}}}}node(e){if(e==="")throw new Error(`Graph "${this.name}": node name must be non-empty`);if(e.includes(L))return this.resolve(e);let t=this._nodes.get(e);if(!t)throw new Error(`Graph "${this.name}": unknown node "${e}"`);return t}get(e){return this.node(e).cache}set(e,t,n){let s=n?.internal===!0;this.node(e).down([[D,t]],{actor:n?.actor,internal:s,delivery:"write"})}setAll(e,t){let n=Symbol.iterator in e?e:Object.entries(e);q(()=>{for(let[s,o]of n)this.set(s,o,t)})}invalidate(e,t){let n=t?.internal===!0;this.node(e).down([[Y]],{actor:t?.actor,internal:n,delivery:"write"})}error(e,t,n){let s=n?.internal===!0;this.node(e).down([[C,t]],{actor:n?.actor,internal:s,delivery:"write"})}complete(e,t){let n=t?.internal===!0;this.node(e).down([[F]],{actor:t?.actor,internal:n,delivery:"write"})}edges(e){let t=e?.recursive===!0,n=new Map;if(!t){for(let[d,u]of this._nodes)n.set(u,d);let a=[];for(let[d,u]of this._nodes)if(u instanceof $)for(let c of u._deps){let p=n.get(c.node);p!=null&&a.push([p,d])}return a.sort((d,u)=>d[0]<u[0]?-1:d[0]>u[0]?1:d[1]<u[1]?-1:d[1]>u[1]?1:0),a}let s=[];this._collectObserveTargets("",s);let o=new Map;for(let[a,d]of s)o.set(d,a);let i=[];for(let[a,d]of s)if(d instanceof $)for(let u of d._deps){let c=o.get(u.node);c!=null&&i.push([c,a])}return i.sort((a,d)=>a[0]<d[0]?-1:a[0]>d[0]?1:a[1]<d[1]?-1:a[1]>d[1]?1:0),i}mount(e,t){if(t===void 0){let s=new r(e);return this.mount(e,s)}if(typeof t=="function"){let s=new r(e);return t(s),this.mount(e,s)}let n=t;if(Nt(e,this.name,"mount"),this._nodes.has(e))throw new Error(`Graph "${this.name}": cannot mount at "${e}" \u2014 node with that name exists`);if(this._mounts.has(e))throw new Error(`Graph "${this.name}": mount "${e}" already exists`);if(n===this)throw new Error(`Graph "${this.name}": cannot mount a graph into itself`);if(n._parent!=null)throw new Error(`Graph "${this.name}": this child graph is already mounted on "${n._parent.name}"`);for(let s=this;s!=null;s=s._parent)if(s===n)throw new Error(`Graph "${this.name}": mount("${e}", \u2026) would create a mount cycle`);return this._mounts.set(e,n),n._parent=this,this._emitTopology({kind:"added",name:e,nodeKind:"mount"}),n}resolve(e){let t=cr(e,this.name);return this._resolveFromSegments(t)}tryResolve(e){try{return this.resolve(e)}catch{return}}_resolveFromSegments(e){let t=e;if(t[0]===this.name&&(t=t.slice(1),t.length===0))throw new Error(`Graph "${this.name}": resolve path ends at graph name only`);let n=t[0],s=t.slice(1);if(s.length===0){let a=this._nodes.get(n);if(a)return a;throw this._mounts.has(n)?new Error(`Graph "${this.name}": path ends at subgraph "${n}" \u2014 not a node (GRAPHREFLY-SPEC \xA73.5)`):new Error(`Graph "${this.name}": unknown name "${n}"`)}let o=this._nodes.get(n);if(o&&s.length>0&&s[0]===Z)return this._resolveMetaChainFromNode(o,s,t.join(L));let i=this._mounts.get(n);if(!i)throw this._nodes.has(n)?new Error(`Graph "${this.name}": "${n}" is a node; trailing path "${s.join(L)}" is invalid`):new Error(`Graph "${this.name}": unknown mount or node "${n}"`);return i.resolve(s.join(L))}_resolveMetaChainFromNode(e,t,n){let s=e,o=0,i=[...t];for(;o<i.length;){if(i[o]!==Z)throw new Error(`Graph "${this.name}": expected ${Z} segment in meta path "${n}"`);if(o+1>=i.length)throw new Error(`Graph "${this.name}": meta path requires a key after ${Z} in "${n}"`);let a=i[o+1],d=s.meta[a];if(!d)throw new Error(`Graph "${this.name}": unknown meta "${a}" in path "${n}"`);s=d,o+=2}return s}signal(e,t){if(t?.internal!==!0){for(let s of e)if(this.config.messageTier(s[0])===3)throw new Error(`Graph "${this.name}": Graph.signal() rejects tier-3 messages (DATA / RESOLVED). Broadcast is for control-plane tiers (START / DIRTY / INVALIDATE / PAUSE / RESUME / COMPLETE / ERROR / TEARDOWN). For per-node value writes, use Graph.set or graph.node(name).down(...).`)}let n=[];if(this._signalDeliver(e,t??{},new Set,n),n.length>0)throw n[0]}_signalDeliver(e,t,n,s){for(let d of this._mounts.values())d._signalDeliver(e,t,n,s);let i=t.internal===!0?{internal:!0}:{actor:t.actor,delivery:"signal"},a=lr(e,this.config);for(let d of[...this._nodes.keys()].sort()){let u=this._nodes.get(d);if(!n.has(u)){n.add(u);try{u.down(e,i)}catch(c){if(c instanceof Q)throw c;s.push(c)}a.length!==0&&this._signalMetaSubtree(u,a,n,i,s)}}}_signalMetaSubtree(e,t,n,s,o){for(let i of Object.keys(e.meta).sort()){let a=e.meta[i];if(!n.has(a)){n.add(a);try{a.down(t,s)}catch(d){if(d instanceof Q)throw d;o.push(d)}this._signalMetaSubtree(a,t,n,s,o)}}}describe(e){if(e?.reactive==="diff")return this._describeReactiveDiff(e);if(e?.reactive===!0)return this._describeReactive(e);let t=nr(e?.actor),n=e?.filter;if(e?.detail!=null&&e?.fields!=null)throw new TypeError("Graph.describe(): pass either `detail` or `fields`, not both. `detail: 'spec'` is the canonical spec projection; use `fields` only when you need a custom subset.");let s=He(e?.detail,e?.fields),o=e?.detail==="spec",i=s,a=[];this._collectObserveTargets("",a);let d=new Map;for(let[w,T]of a)d.set(T,w);let u=[];{let w=a.map(([,m])=>m),T=new Set(d.values()),N=0;for(;w.length>0;){let m=w.shift();if(m instanceof $)for(let x of m._deps){let O=x.node;if(d.has(O))continue;let E=O.name??"",k=E;if(!k||T.has(k))if(E){let A=2;for(;T.has(`${E}#${A}`);)A++;k=`${E}#${A}`}else for(k=`__internal__/${N++}`;T.has(k);)k=`__internal__/${N++}`;d.set(O,k),T.add(k),u.push([k,O]),w.push(O)}}}let c=[...a,...u],p={};for(let[w,T]of c){if(t!=null&&!T.allowsObserve(t))continue;let N=yt(T,i,o),m=T instanceof $?T._deps.map(k=>d.get(k.node)??k.node.name??""):[],{name:x,...O}=N,E={...O,deps:m};if(!o){let k=this._annotations.get(w);k!=null&&(E.annotation=k)}if(n!=null)if(typeof n=="function"){let k=n;if(!(k.length>=2?k(w,E):k(E)))continue}else{let k=!0;for(let[A,M]of Object.entries(n)){let S=A==="deps_includes"?"depsIncludes":A==="meta_has"?"metaHas":A;if(S==="depsIncludes"){if(!E.deps.includes(String(M))){k=!1;break}continue}if(S==="metaHas"){if(!Object.hasOwn(E.meta??{},String(M))){k=!1;break}continue}if(E[S]!==M){k=!1;break}}if(!k)continue}p[w]=E}let f=new Set(Object.keys(p)),h=[];for(let[w,T]of c)if(T instanceof $)for(let N of T._deps){let m=d.get(N.node);m!=null&&h.push([m,w])}h.sort((w,T)=>w[0]<T[0]?-1:w[0]>T[0]?1:w[1]<T[1]?-1:w[1]>T[1]?1:0);let l=h.map(([w,T])=>({from:w,to:T}));(t!=null||n!=null)&&(l=l.filter(w=>f.has(w.from)&&f.has(w.to)));let b=this._collectSubgraphs(""),g=t!=null||n!=null?b.filter(w=>{let T=`${w}${L}`;return[...f].some(N=>N===w||N.startsWith(T))}):b,v=this,_=e;return{name:this.name,nodes:p,edges:l,subgraphs:g,...this._factory!==void 0?{factory:this._factory}:{},...this._factoryArgs!==void 0?{factoryArgs:this._factoryArgs}:{},expand(w){let T={..._};return Array.isArray(w)?(T.fields=w,T.detail=void 0):(T.detail=w,T.fields=void 0),v.describe(T)}}}_collectSubgraphs(e){let t=[];for(let n of[...this._mounts.keys()].sort()){let s=e===""?n:`${e}${n}`;t.push(s),t.push(...this._mounts.get(n)._collectSubgraphs(`${s}${L}`))}return t}resourceProfile(e){return fn(this,e)}reachable(e,t,n={}){return n.withDetail===!0?Ot(this.describe(),e,t,{...n,withDetail:!0}):Ot(this.describe(),e,t,n)}explain(e,t,n){return n?.reactive===!0?this._explainReactive(e,t,n):this._explainStatic(ce(e),ce(t),{...n?.maxDepth!==void 0?{maxDepth:hn(n.maxDepth)}:{},...n?.findCycle!==void 0?{findCycle:gn(n.findCycle)}:{}})}_explainStatic(e,t,n){let s=this.describe({detail:"full"}),o=new Map(this._annotations),i=new Map;for(let[a,d]of Object.entries(s.nodes))d.lastMutation!=null&&i.set(a,d.lastMutation);return an(s,e,t,{...n?.maxDepth!=null?{maxDepth:n.maxDepth}:{},...n?.findCycle===!0?{findCycle:!0}:{},annotations:o,lastMutations:i})}_describeReactive(e){let t={...e,reactive:!1},n=e.reactiveName??"describe",s=0,o=B(s,{name:`${n}_version`}),i=this.observe({timeline:!0,structured:!0}),a=!1,d=!1,u=()=>{a||d||(a=!0,ke(()=>{a=!1,!d&&(s+=1,o.emit(s))}))},c=i.onEvent(_=>{let y=_.type;y!=="data"&&y!=="error"&&y!=="complete"&&y!=="teardown"||u()}),p=[],f=new WeakSet,h=_=>{if(f.has(_)||d)return;f.add(_);let y=_.topology.subscribe(w=>{for(let T of w){if(T[0]!==D)continue;let N=T[1];if(u(),N.kind==="added"&&N.nodeKind==="mount"){let m=_._mounts.get(N.name);m!=null&&h(m)}}});p.push(y);for(let w of _._mounts.keys()){let T=_._mounts.get(w);T!=null&&h(T)}};h(this);let l,b=e.actor;yn(b)&&(l=b.subscribe(_=>{let y=!1,w=!1;for(let T of _){let N=T[0];N===D?y=!0:(N===F||N===C||N===z)&&(w=!0)}y&&u(),w&&(l?.(),l=void 0,u())}));let g;try{g=X([o],()=>this.describe(t),{name:n,describeKind:"derived",meta:{domain:"audit",kind:"describe"},equals:(_,y)=>_===y})}catch(_){c(),l?.();for(let y of p)y();throw i.dispose(),_}let v=ie(g);return{node:g,dispose(){d=!0,c(),l?.();for(let _ of p)_();p.length=0,i.dispose(),v()}}}_describeReactiveDiff(e){let t={...e,reactive:!1},n=e.reactiveName??"describe-diff",s={name:this.name,nodes:{},edges:[],subgraphs:[]},o=this.describe(t),i=wt(s,o),a=B(i,{name:n,meta:{domain:"audit",kind:"describe-diff"},equals:(f,h)=>f===h}),d=this._describeReactive({...e,reactiveName:void 0}),u=!1,c=d.node.subscribe(f=>{if(!u)for(let h of f){if(h[0]!==D)continue;let l=h[1],b=wt(o,l);o=l,b.events.length!==0&&a.emit(b)}}),p=ie(a);return{node:a,dispose(){u=!0,c(),d.dispose(),a.down([[z,"describe-diff disposed"]]),p()}}}_explainReactive(e,t,n){let s=0,o=B(s,{name:"explain_version"}),i=this.observe({timeline:!0,structured:!0}),a=!1,d=!1,u=()=>{a||d||(a=!0,ke(()=>{a=!1,!d&&(s+=1,o.emit(s))}))},c=i.onEvent(_=>{let y=_.type;y!=="data"&&y!=="error"&&y!=="complete"&&y!=="teardown"||u()}),p=[];e!=null&&ye(e)&&p.push(e),t!=null&&ye(t)&&p.push(t),n?.maxDepth!=null&&ye(n.maxDepth)&&p.push(n.maxDepth),n?.findCycle!=null&&ye(n.findCycle)&&p.push(n.findCycle);let f=()=>{for(let _ of p)if(_.cache===void 0)return!1;return!0},h=()=>{let _=ce(e),y=ce(t);return{from:_,to:y,found:!1,reason:"pending",steps:[],text:"(awaiting reactive args)",toJSON:()=>({from:_,to:y,found:!1,reason:"pending",steps:[]})}},l;try{l=X([o],()=>{if(!f())return h();let _=ce(e),y=ce(t),w={...n?.maxDepth!==void 0?{maxDepth:hn(n.maxDepth)}:{},...n?.findCycle!==void 0?{findCycle:gn(n.findCycle)}:{}};return this._explainStatic(_,y,w)},{name:n?.name??"explain",describeKind:"derived",meta:{domain:"audit",kind:"explain_path",from:ce(e),to:ce(t)},equals:(_,y)=>_.found===y.found&&_.reason===y.reason&&_.steps.length===y.steps.length&&fr(_.steps,y.steps)})}catch(_){throw c(),i.dispose(),_}let b=ie(l),g=[],v=_=>{let y;return y=_.subscribe(w=>{let T=!1,N=!1;for(let m of w){let x=m[0];x===D?T=!0:(x===F||x===C||x===z)&&(N=!0)}(T||N)&&u(),N&&y&&(y(),y=void 0)}),()=>{y&&(y(),y=void 0)}};for(let _ of p)g.push(v(_));return{node:l,dispose(){d=!0,c();for(let _ of g)_?.();g.length=0,i.dispose(),b()}}}_pathsMatching(e){let t=Je(e),n=[];return this._collectObserveTargets("",n),n.map(([s])=>s).filter(s=>t.test(s))}_collectObserveTargets(e,t){for(let n of[...this._mounts.keys()].sort()){let s=e===""?n:`${e}${L}${n}`;this._mounts.get(n)._collectObserveTargets(s,t)}for(let n of[...this._nodes.keys()].sort()){let s=this._nodes.get(n),o=e===""?n:`${e}${L}${n}`;t.push([o,s]),this._appendMetaObserveTargets(o,s,t)}}_appendMetaObserveTargets(e,t,n){for(let s of Object.keys(t.meta).sort()){let o=t.meta[s],i=`${e}${L}${Z}${L}${s}`;n.push([i,o]),this._appendMetaObserveTargets(i,o,n)}}observe(e,t){let n=typeof e=="string",o=bn(n?t:e);if(o.reactive===!0)return this._observeReactive(n?e:void 0,o);let i=o.structured===!0||o.timeline===!0||o.causal===!0||o.derived===!0||o.detail==="minimal"||o.detail==="full"||o.format!=null,a=o.actor;if(n){let c=e,p=this.resolve(c);if(a!=null&&!p.allowsObserve(a))throw new Q({actor:a,action:"observe",nodeName:c});return i?this._buildStructuredObserver([[c,p]],o,"one"):{subscribe(f){return p.subscribe(f)},up(f){try{p.up?.(f)}catch(h){if(h instanceof Q)return;throw h}}}}let d=[];this._collectObserveTargets("",d),d.sort((c,p)=>c[0]<p[0]?-1:c[0]>p[0]?1:0);let u=a==null?d:d.filter(([,c])=>c.allowsObserve(a));return i?this._buildStructuredObserver(u,o,"all"):{subscribe:c=>{let p=u.map(([f,h])=>h.subscribe(l=>{c(f,l)}));return()=>{for(let f of p)f()}},up:(c,p)=>{try{this.resolve(c).up?.(p)}catch(f){if(f instanceof Q)return;throw f}}}}_observeReactive(e,t){let n=t.tiers,s=n!=null?new Set(n):null,o=t.reactiveName??"observe";return de(i=>{let a=[],d=!1,u=!1,c=()=>{if(a.length===0||u)return;let b={events:a.slice(),flushedAt_ns:K()};a.length=0,i.emit(b)},p={...t,reactive:!1,structured:!0,timeline:!0},f=e!=null?this.observe(e,p):this.observe(p),h=b=>{u||(a.push(b),!d&&(d=!0,ke(()=>{d=!1,c()})))};for(let b of f.events)h(b);let l=f.onEvent(h);return()=>{u=!0,l(),f.dispose()}},{name:o,meta:{domain:"audit",kind:"observe-reactive"}})}_buildStructuredObserver(e,t,n){let s=n==="one"?e[0]?.[0]:void 0,o=i=>{if(n==="one"&&s!=null){let c=this.resolve(s);return this._buildStructuredObserver([[s,c]],i,"one")}let a=[];this._collectObserveTargets("",a),a.sort((c,p)=>c[0]<p[0]?-1:c[0]>p[0]?1:0);let d=i.actor,u=d==null?a:a.filter(([,c])=>c.allowsObserve(d));return this._buildStructuredObserver(u,i,"all")};return this._createObserveResult(e,t,o)}_createObserveResult(e,t,n){let s=t.timeline===!0,o=t.causal===!0,i=t.derived===!0,a=t.detail==="minimal",d=this.config.inspectorEnabled,u=(o||i)&&d,c=t.maxEvents,p=c!=null&&c>0?new De(c):null,f=[],h=new Set,l=t.tiers!=null?new Set(t.tiers):null,b={},g=new Set,v=0,_=0,y=0,w=0,T=0,N=0,m=!1,x=!1,O=0,E=new Map,k=new Map,A=new Map,M=R=>{if(!(l!=null&&!l.has(R.type))){p?p.push(R):f.push(R);for(let P of h)P(R)}},S=R=>l==null||l.has(R),ae=()=>s?{timestamp_ns:K(),in_batch:Se(),batch_id:O}:{},ne=(R,P)=>{if(!(!u||!(R instanceof $)))return R._setInspectorHook(U=>{if(U.kind==="dep_message")E.set(R,U.depIndex);else if(U.kind==="run"){let Ee=U.batchData.map((G,H)=>G!=null&&G.length>0?G.at(-1):U.prevData[H]);k.set(R,Ee);let J=U.batchData.map(G=>G!=null?[...G]:void 0);A.set(R,J),i&&M({type:"derived",path:P,dep_values:Ee,dep_batches:J,...ae()})}})},Ge=R=>{let P=E.get(R),U=k.get(R);if(!o||U==null)return{};let J=(P!=null&&P>=0&&R instanceof $?R._deps[P]:void 0)?.node,G=J?.v,H=A.get(R);return{trigger_dep_index:P,trigger_dep_name:J?.name,...G!=null?{trigger_version:{id:G.id,version:G.version}}:{},dep_values:[...U],...H!=null?{dep_batches:H}:{}}},St=[],Mt=[];for(let[R,P]of e){let U=ne(P,R);U&&St.push(U),Mt.push(P.subscribe(Ee=>{O++;for(let J of Ee){let G=J[0],H=ae();if(G===D){b[R]=J[1];let rt=P instanceof $?P.lastMutation?.actor??we:we;M({type:"data",path:R,data:J[1],actor:rt,...H,...Ge(P)})}else if(a)G===V?S("dirty")&&v++:G===W?S("resolved")&&_++:G===Y?S("invalidate")&&y++:G===te?S("pause")&&w++:G===re?S("resume")&&T++:G===z?S("teardown")&&N++:G===F&&!g.has(R)?S("complete")&&(m=!0):G===C&&S("error")&&(x=!0,g.add(R));else if(G===V)S("dirty")&&v++,M({type:"dirty",path:R,...H});else if(G===W)S("resolved")&&_++,M({type:"resolved",path:R,...H,...Ge(P)});else if(G===Y)S("invalidate")&&y++,M({type:"invalidate",path:R,...H});else if(G===te)S("pause")&&w++,M({type:"pause",path:R,lockId:J[1],...H});else if(G===re)S("resume")&&T++,M({type:"resume",path:R,lockId:J[1],...H});else if(G===F)S("complete")&&!g.has(R)&&(m=!0),M({type:"complete",path:R,...H});else if(G===C){S("error")&&(x=!0,g.add(R));let rt=P instanceof $?P.lastMutation?.actor??we:we;M({type:"error",path:R,data:J[1],actor:rt,...H})}else G===z&&(S("teardown")&&N++,M({type:"teardown",path:R,...H}))}}))}let et=!1,tt=()=>{if(!et){et=!0;for(let R of Mt)R();for(let R of St)R();for(let R of Pe)R({value:void 0,done:!0});Pe.length=0}},nt=[],Pe=[];h.add(R=>{let P=Pe.shift();P?P({value:R,done:!1}):nt.push(R)});let Dt={get values(){return b},get dirtyCount(){return v},get resolvedCount(){return _},get invalidateCount(){return y},get pauseCount(){return w},get resumeCount(){return T},get teardownCount(){return N},get events(){return p?p.toArray():[...f]},get anyCompletedCleanly(){return m},get anyErrored(){return x},get completedWithoutErrors(){return m&&!x},onEvent(R){return h.add(R),()=>h.delete(R)},dispose:tt,expand(R){tt();let P={...t};return typeof R=="string"?P.detail=R:Object.assign(P,R),n(bn(P))},[Symbol.asyncIterator](){return{next(){return nt.length>0?Promise.resolve({value:nt.shift(),done:!1}):et?Promise.resolve({value:void 0,done:!0}):new Promise(R=>Pe.push(R))},return(){return tt(),Promise.resolve({value:void 0,done:!0})}}}};return t.format!=null&&this._attachFormatLogger(Dt,t),Dt}_attachFormatLogger(e,t){let n=t.format;if(n==null)return;let s=t.logger??(l=>console.log(l)),o=t.includeTypes?new Set(t.includeTypes):null,i=t.excludeTypes?new Set(t.excludeTypes):null,a=o==null&&i==null?()=>!0:l=>(o==null||o.has(l))&&(i==null||!i.has(l)),d=dr(t.theme),u=n==="stage-log"?K():0,c=l=>l==null?"":t.stageLabels?.[l]??l,p=(l,b)=>l.length>b?`${l.slice(0,b-1)}\u2026`:l,f=l=>l.type==="data"||l.type==="error"?p(kt(l.data),120):"",h=l=>{if(n==="stage-log"){let m=(K()-u)/1e9,x=c(l.path).padEnd(9);if(l.type==="data"){let O=f(l);return`[${m.toFixed(3)}s] ${x} \u2190${O?` ${O}`:""}`}if(l.type==="error"){let O=f(l);return`[${m.toFixed(3)}s] ${x} \u2717${O?` ${O}`:""}`}return l.type==="complete"?`[${m.toFixed(3)}s] ${x} \u25A0 complete`:`[${m.toFixed(3)}s] ${x} ${l.type}`}if(n==="json")try{return JSON.stringify(l)}catch{return JSON.stringify({type:l.type,path:l.path,data:"[unserializable]"})}let b=d[l.type]??"",g=l.path?`${d.path}${l.path}${d.reset} `:"",v=l.type==="data"||l.type==="error",_=l.type==="pause"||l.type==="resume",y=v?` ${kt(l.data)}`:_?` ${kt(l.lockId)}`:"",w=l.type==="data"||l.type==="resolved"||l.type==="derived"?l:void 0,T=w?.trigger_dep_name!=null?` <- ${w.trigger_dep_name}`:w?.trigger_dep_index!=null?` <- #${w.trigger_dep_index}`:"",N=l.in_batch?" [batch]":"";return`${g}${b}${l.type.toUpperCase()}${d.reset}${y}${T}${N}`};e.onEvent(l=>{a(l.type)&&s(h(l),l)})}addDisposer(e){return this._disposers.add(e),()=>{this._disposers.delete(e)}}destroy(){pn(this._disposers,this.name),this.signal([[z]],{internal:!0}),pn(this._storageDisposers,this.name);for(let e of[...this._mounts.values()])e._parent=void 0,e._destroyClearOnly();this._mounts.clear(),this._nodes.clear(),this._parent=void 0,this._destroyed=!0}get destroyed(){return this._destroyed}_destroyClearOnly(){for(let e of[...this._mounts.values()])e._parent=void 0,e._destroyClearOnly();this._mounts.clear(),this._nodes.clear(),this._parent=void 0,this._destroyed=!0}snapshot(e){let{expand:t,...n}=this.describe({detail:"full"}),s={};for(let a of Object.keys(n.nodes).sort()){let{lastMutation:d,guard:u,...c}=n.nodes[a];s[a]=c}let o=[...n.subgraphs].sort(),i={...n,version:1,nodes:s,subgraphs:o};if(e?.format==null)return i;if(e.format==="json-string")return JSON.stringify(i);if(e.format==="bytes"){if(e.codec==null)throw new Error("snapshot({format: 'bytes'}) requires a `codec` name");let a=this.config.lookupCodec(e.codec);if(a==null)throw new Error(`snapshot: codec "${e.codec}" is not registered on this graph's config. Call config.registerCodec(...) before creating nodes.`);return jt(a,a.encode(i))}throw new Error(`snapshot: unknown format "${String(e.format)}"`)}static decode(e,t){let n=t?.config??Oe,{codec:s,codecVersion:o,payload:i}=Bt(e,n);return s.decode(i,o)}restore(e,t){if(mn(e),e.name!==this.name)throw new Error(`Graph "${this.name}": restore snapshot name "${e.name}" does not match this graph`);let n=t?.only==null?null:(Array.isArray(t.only)?t.only:[t.only]).map(o=>Je(o)),s=t?.includeProducers===!0;for(let o of Object.keys(e.nodes).sort()){if(n!==null&&!n.some(a=>a.test(o)))continue;let i=e.nodes[o];if(i!==void 0){if(!("value"in i)||i.value===void 0){"value"in i&&i.value===void 0&&t?.onError?.(o,new Error(`restore: slice.value is undefined for "${o}" (undefined is the global SENTINEL; not valid DATA)`));continue}if(!(i.type==="derived"||i.type==="effect")&&!(i.type==="producer"&&!s)){if(i.v!=null){let d=this.tryResolve(o)?.v;if(d!=null&&d.id===i.v.id&&d.version===i.v.version)continue}try{this.set(o,i.value)}catch(a){t?.onError?.(o,a)}}}}}static fromSnapshot(e,t){mn(e);let n=typeof t=="function"?t:t?.build,s=typeof t=="function"?void 0:t?.factories,o=new r(e.name);if(n)return n(o),o.restore(e),o;for(let h of[...e.subgraphs].sort((l,b)=>{let g=l.split(L).length,v=b.split(L).length;return g!==v?g-v:l<b?-1:l>b?1:0})){let l=h.split(L),b=o;for(let g of l)b._mounts.has(g)||b.mount(g,new r(g)),b=b._mounts.get(g)}let i=s?Object.entries(s).map(([h,l])=>({re:Je(h),factory:l})):[],a=h=>{for(let l of i)if(l.re.test(h))return l.factory},d=h=>{let l=h.split(L),b=l.pop();if(b==null||b.length===0)throw new Error(`invalid snapshot path "${h}"`);let g=o;for(let v of l){let _=g._mounts.get(v);if(!_)throw new Error(`unknown mount "${v}" in path "${h}"`);g=_}return[g,b]},u=Object.entries(e.nodes).filter(([h])=>!h.includes(`${L}${Z}${L}`)).sort((h,l)=>h[0]<l[0]?-1:h[0]>l[0]?1:0),c=new Map(u),p=new Map,f=!0;for(;c.size>0&&f;){f=!1;for(let[h,l]of[...c.entries()]){let b=l?.deps??[];if(!b.every(T=>p.has(T)))continue;let[g,v]=d(h),_={...l?.meta??{}},y=a(h),w;if(l?.type==="state")w=B(l.value,{meta:_});else{if(y==null)continue;w=y(v,{path:h,type:l.type,value:l.value,meta:_,deps:b,resolvedDeps:b.map(T=>p.get(T))})}g.add(w,{name:v}),p.set(h,w),c.delete(h),f=!0}}if(c.size>0){let h=[...c.keys()].sort().join(", ");throw new Error(`Graph.fromSnapshot could not reconstruct nodes without build callback: ${h}. Pass matching factories via fromSnapshot(data, { factories: { pattern: factoryFn } }).`)}return o.restore(e),o}toJSON(){return this.snapshot()}attachSnapshotStorage(e,t={}){let n=e.map(u=>({tier:u,debounceMs:Math.max(0,u.debounceMs??0),compactEvery:Math.max(1,u.compactEvery??10),timer:void 0,seq:0,lastSnapshot:void 0,lastFingerprint:"",disposed:!1,savePending:void 0}));t.autoRestore===!0&&this._cascadeRestore(e,t.onError);let s=(u,c)=>{if(u.disposed)return;let p=rr(c.nodes);if(u.lastSnapshot!=null&&p!==""&&p===u.lastFingerprint)return;let f=u.seq+1,h=ee(),g=u.lastSnapshot==null||f%u.compactEvery===0?{name:this.name,mode:"full",snapshot:c,seq:f,timestamp_ns:h,format_version:be}:{name:this.name,mode:"diff",diff:_n(u.lastSnapshot,c),seq:f,timestamp_ns:h,format_version:be};if(u.tier.filter&&!u.tier.filter(g))return;let v;try{v=u.tier.save(g)}catch(_){t.onError?.(_,u.tier);return}if(v&&typeof v.then=="function"){let w=(u.savePending??Promise.resolve()).then(()=>v,()=>v).then(()=>{u.disposed||(u.seq=f,u.lastSnapshot=c,u.lastFingerprint=p)},T=>{t.onError?.(T,u.tier)});u.savePending=w.finally(()=>{u.savePending===w&&(u.savePending=void 0)})}else u.seq=f,u.lastSnapshot=c,u.lastFingerprint=p},o=(u,c)=>{try{s(u,c)}catch(p){t.onError?.(p,u.tier)}},i=(u,c)=>{if(!c.some(l=>{let b=this.config.messageTier(l[0]);return b>=3&&b<5}))return;if(t.filter){let l=this.tryResolve(u);if(l==null)return;let b=yt(l,He("standard"));if(!t.filter(u,b))return}let f,h=()=>(f==null&&(f=this.snapshot()),f);for(let l of n)l.disposed||(l.debounceMs===0?o(l,h()):(l.timer==null&&(l.timer=new Ke),l.timer.start(l.debounceMs,()=>{l.disposed||o(l,this.snapshot())})))},a;if(t.paths!=null){let c=(typeof t.paths=="string"?this._pathsMatching(t.paths):t.paths).map(p=>{let f=this.tryResolve(p);return f==null?()=>{}:f.subscribe(h=>i(p,h))});a=()=>{for(let p of c)p()}}else a=this.observe().subscribe((u,c)=>i(u,c));let d=()=>{a();for(let u of n)u.disposed=!0,u.timer?.cancel();this._storageDisposers.delete(d)};return this._storageDisposers.add(d),{dispose:d}}async _cascadeRestore(e,t){for(let n of e){let s;try{s=await n.load?.()}catch(i){t?.(i,n);continue}if(s==null||typeof s!="object"||Array.isArray(s))continue;let o=s;try{if(o.mode==="full"&&o.snapshot!=null)return this.restore(o.snapshot),!0;if(o.version===be&&o.nodes!=null)return this.restore(o),!0}catch(i){t?.(i,n)}}return!1}static async fromStorage(e,t,n){for(let s of t){let o;try{o=await s.load?.()}catch(d){n?.onError?.(d,s);continue}if(o==null||typeof o!="object"||Array.isArray(o))continue;let i=o,a=i.mode==="full"&&i.snapshot!=null?i.snapshot:i.version===be&&i.nodes!=null?i:void 0;if(a!=null)try{return r.fromSnapshot(a,n)}catch(d){n?.onError?.(d,s)}}throw new Error(`Graph.fromStorage: no tier held a restorable record for "${e}" across ${t.length} tier(s)`)}_annotations=new Map;_traceRing;trace(e,t,n){if(e!=null&&t!=null){if(this.tryResolve(e)==null)return;if(this._annotations.set(e,t),this.config.inspectorEnabled){let s={path:e,annotation:t,timestamp_ns:K(),...n?.actor!=null?{actor:n.actor}:{}};this._traceRing.push(s)}return}return e!=null?this.config.inspectorEnabled?this._annotations.get(e):void 0:this.config.inspectorEnabled?this._traceRing.toArray():[]}annotation(e){return this._annotations.get(e)}clearTrace(){this._annotations.clear(),this._traceRing.clear()}pruneTrace(e){let t=this._traceRing.toArray().filter(s=>!e(s)),n=this._traceRing.size-t.length;this._traceRing.clear();for(let s of t)this._traceRing.push(s);return n}static diff(e,t){let n=new Set(Object.keys(e.nodes)),s=new Set(Object.keys(t.nodes)),o=[...s].filter(_=>!n.has(_)).sort(),i=[...n].filter(_=>!s.has(_)).sort(),a=[],d=[];for(let _ of n){if(!s.has(_))continue;let y=e.nodes[_],w=t.nodes[_],T=y.v,N=w.v;T!=null&&N!=null&&T.id===N.id&&T.version!==N.version&&d.push({path:_,id:T.id,from:T.version,to:N.version});let m=T!=null&&N!=null&&T.id===N.id&&T.version===N.version;for(let x of["type","status","sentinel"]){let O=y[x],E=w[x];O!==E&&a.push({path:_,field:x,from:O,to:E})}if(!m)for(let x of["value","meta"]){let O=y[x],E=w[x];sr(O,E)||a.push({path:_,field:x,from:O,to:E})}}let u=_=>`${_.from} ${_.to}`,c=new Set(e.edges.map(u)),p=new Set(t.edges.map(u)),f=t.edges.filter(_=>!c.has(u(_))),h=e.edges.filter(_=>!p.has(u(_))),l=new Set(e.subgraphs),b=new Set(t.subgraphs),g=[...b].filter(_=>!l.has(_)).sort(),v=[...l].filter(_=>!b.has(_)).sort();return{nodesAdded:o,nodesRemoved:i,nodesChanged:a,versionChanges:d,edgesAdded:f,edgesRemoved:h,subgraphsAdded:g,subgraphsRemoved:v}}};function _n(r,e){let t=ve.diff(r,e),n={};for(let s of t.nodesAdded){let o=e.nodes[s];o!=null&&(n[s]=o)}return{...t,nodesAddedFull:n}}function Ot(r,e,t,n={}){let s={paths:[],depths:new Map,truncated:!1};if(!e)return n.withDetail?s:[];if(!n.both&&t!=="upstream"&&t!=="downstream")throw new Error('reachable: direction must be "upstream" or "downstream"');let o=n.maxDepth;if(o!=null&&(!Number.isInteger(o)||o<0))throw new Error("reachable: maxDepth must be an integer >= 0");if(o===0)return n.withDetail?s:[];let i=new Map,a=new Map,d=new Map,u=new Map,c=new Set;for(let[y,w]of Object.entries(r.nodes)){if(!y)continue;c.add(y);let T=w.deps??[];i.set(y,T);for(let N of T)N&&(c.add(N),a.has(N)||a.set(N,new Set),a.get(N).add(y))}for(let y of r.edges){if(y==null||typeof y!="object")continue;let w=typeof y.from=="string"?y.from:"",T=typeof y.to=="string"?y.to:"";!w||!T||(c.add(w),c.add(T),u.has(w)||u.set(w,new Set),u.get(w).add(T),d.has(T)||d.set(T,new Set),d.get(T).add(w))}if(!c.has(e))return n.withDetail?s:[];let p=n.both===!0,f=y=>{if(p){let m=i.get(y)??[],x=d.get(y),O=a.get(y),E=u.get(y),k=[...m];return x&&k.push(...x),O&&k.push(...O),E&&k.push(...E),k}if(t==="upstream"){let m=i.get(y)??[],x=d.get(y);return x?[...m,...x]:m}let w=a.get(y),T=u.get(y),N=w?[...w]:[];return T&&N.push(...T),N},h=new Set([e]),l=new Map,b=[{path:e,depth:0}],g=0,v=!1;for(;g<b.length;){let y=b[g++];if(o!=null&&y.depth>=o){f(y.path).length>0&&(v=!0);continue}for(let w of f(y.path))!w||h.has(w)||(h.add(w),l.set(w,y.depth+1),b.push({path:w,depth:y.depth+1}))}let _=[...l.keys()].sort((y,w)=>y<w?-1:y>w?1:0);return n.withDetail?{paths:_,depths:l,truncated:v}:_}function fr(r,e){if(r.length!==e.length)return!1;for(let t=0;t<r.length;t++){let n=r[t],s=e[t];if(n.path!==s.path||n.type!==s.type||n.status!==s.status||n.hop!==s.hop||n.dep_index!==s.dep_index||n.annotation!==s.annotation||n.value!==s.value||n.lastMutation!==s.lastMutation)return!1;let o=n.v,i=s.v;if(o!==i&&(o==null||i==null||o.id!==i.id||o.version!==i.version))return!1}return!0}pe();se();me();ue();var Et=class{_version=0;_maxSize;_buf;_head=0;_size=0;constructor(e,t){if(t!==void 0&&t<1)throw new RangeError("maxSize must be >= 1");if(this._maxSize=t,t!==void 0){if(this._buf=new Array(t),e&&e.length>0){let n=Math.min(e.length,t),s=e.length-n;for(let o=0;o<n;o++)this._buf[o]=e[s+o];this._size=n}}else this._buf=e?[...e]:[],this._size=this._buf.length}get version(){return this._version}get size(){return this._size}at(e){if(!Number.isInteger(e))return;let t=e>=0?e:this._size+e;if(!(t<0||t>=this._size))return this._maxSize!==void 0?this._buf[(this._head+t)%this._maxSize]:this._buf[t]}append(e){this._rawAppend(e),this._version+=1}appendMany(e){if(e.length===0)return;let t=this._maxSize!==void 0&&e.length>this._maxSize?e.length-this._maxSize:0;for(let n=t;n<e.length;n++)this._rawAppend(e[n]);this._version+=1}clear(){if(this._size===0)return 0;let e=this._size;if(this._maxSize===void 0)this._buf.length=0;else for(let t=0;t<e;t++)this._buf[(this._head+t)%this._maxSize]=void 0;return this._head=0,this._size=0,this._version+=1,e}trimHead(e){if(!Number.isInteger(e)||e<0)throw new RangeError(`trimHead: n must be a non-negative integer (got ${e})`);if(e===0||this._size===0)return 0;let t=Math.min(e,this._size);if(this._maxSize===void 0)this._buf.splice(0,t);else{for(let n=0;n<t;n++)this._buf[(this._head+n)%this._maxSize]=void 0;this._head=(this._head+t)%this._maxSize}return this._size-=t,this._version+=1,t}slice(e,t){if(!Number.isInteger(e)||e<0)throw new RangeError(`slice: start must be a non-negative integer (got ${e})`);if(t!==void 0&&(!Number.isInteger(t)||t<0))throw new RangeError(`slice: stop must be a non-negative integer or undefined (got ${t})`);let n=t===void 0?this._size:Math.min(Math.max(t,0),this._size),s=Math.min(e,this._size);if(s>=n)return[];let o=n-s;if(this._maxSize===void 0)return this._buf.slice(s,n);let i=new Array(o);for(let a=0;a<o;a++)i[a]=this._buf[(this._head+s+a)%this._maxSize];return i}tail(e){if(!Number.isInteger(e)||e<0)throw new RangeError(`tail: n must be a non-negative integer (got ${e})`);if(e===0||this._size===0)return[];let t=Math.min(e,this._size);return this.slice(this._size-t,this._size)}toArray(){if(this._maxSize===void 0)return[...this._buf];let e=new Array(this._size);for(let t=0;t<this._size;t++)e[t]=this._buf[(this._head+t)%this._maxSize];return e}snapshot(){return this.toArray()}restore(e){if(this._maxSize===void 0){this._buf.length=0;for(let t=0;t<e.length;t++)this._buf.push(e[t]);this._size=this._buf.length}else{let t=this._maxSize;for(let o=0;o<t;o++)this._buf[o]=void 0;this._head=0;let n=Math.min(e.length,t),s=e.length-n;for(let o=0;o<n;o++)this._buf[o]=e[s+o];this._size=n}this._version+=1}_rawAppend(e){if(this._maxSize===void 0){this._buf.push(e),this._size=this._buf.length;return}this._size<this._maxSize?(this._buf[(this._head+this._size)%this._maxSize]=e,this._size+=1):(this._buf[this._head]=e,this._head=(this._head+1)%this._maxSize)}};function Ce(r){return r.subscribe(()=>{})}var pr=64;function Ye(r,e={}){let{name:t,maxSize:n,versioning:s,guard:o,backend:i}=e,a=i??new Et(r,n),d=B(a.toArray(),{name:t,describeKind:"state",equals:(m,x)=>m===x,...s!=null?{versioning:s}:{},...o!=null?{guard:o}:{}});function u(){let m=a.toArray();q(()=>{d.down([[V]],{internal:!0}),d.down([[D,m]],{internal:!0})})}let c=new Map,p=new Map,f=new Map;function h(m,x){return`${m}:${x===void 0?"END":x}`}function l(m){if(m.size<pr)return;let x=m.keys().next();if(x.done)return;let O=m.get(x.value);O!==void 0&&O.dispose(),m.delete(x.value)}function b(m){let x=a.version;try{return m()}finally{a.version!==x&&u()}}function g(m){if(!Number.isInteger(m)||m<0)throw new RangeError(`tail: n must be a non-negative integer (got ${m})`);let x=c.get(m);if(x!==void 0)return c.delete(m),c.set(m,x),x.node;l(c);let O=X([d],([k])=>{let A=k;return m===0||A.length===0?[]:A.slice(Math.max(0,A.length-m))},{initial:a.tail(m),describeKind:"derived"}),E=Ce(O);return c.set(m,{node:O,dispose:E}),O}function v(m,x){if(!Number.isInteger(m)||m<0)throw new RangeError(`slice: start must be a non-negative integer (got ${m})`);if(x!==void 0&&(!Number.isInteger(x)||x<0))throw new RangeError(`slice: stop must be a non-negative integer or undefined (got ${x})`);let O=h(m,x),E=p.get(O);if(E!==void 0)return p.delete(O),p.set(O,E),E.node;l(p);let k=X([d],([M])=>{let S=M;return x===void 0?S.slice(m):S.slice(m,x)},{initial:a.slice(m,x),describeKind:"derived"}),A=Ce(k);return p.set(O,{node:k,dispose:A}),k}function _(m){let x=f.get(m);if(x!==void 0)return x.node;let O=X([d,m],([k,A])=>{let M=k,S=Math.max(0,Math.trunc(A??0));return M.slice(S)},{initial:[],describeKind:"derived"}),E=Ce(O);return f.set(m,{node:O,dispose:E}),O}let y,w;function T(){y===void 0&&(y=oe([d],(m,x,O)=>{let E=m[0],A=E!=null&&E.length>0?E.at(-1):O.prevData[0];if(A==null||A.length===0){x.down([[W]]);return}x.emit(A[A.length-1])},{name:t!=null?`${t}::lastValue`:"lastValue",describeKind:"derived",initial:a.size===0?void 0:a.at(a.size-1)}),w=X([d],([m])=>m.length>0,{name:t!=null?`${t}::hasLatest`:"hasLatest",describeKind:"derived",initial:a.size>0}),Ce(y),Ce(w))}let N={entries:d,get size(){return a.size},at(m){return a.at(m)},append(m){b(()=>a.append(m))},appendMany(m){m.length!==0&&b(()=>a.appendMany(m))},clear(){b(()=>a.clear())},trimHead(m){b(()=>a.trimHead(m))},withLatest(){return T(),d},get lastValue(){return T(),y},get hasLatest(){return T(),w},view(m){switch(m.kind){case"tail":return g(m.n);case"slice":return v(m.start,m.stop);case"fromCursor":return _(m.cursor)}},attach(m){let x=m.subscribe(O=>{for(let E of O)E[0]===D&&N.append(E[1])});return()=>x()},attachStorage(m){if(m.length===0)return()=>{};let x=new Map;for(let E of m)x.set(E,a.size);(async()=>{for(let E of m)if(typeof E.loadEntries=="function")try{let k=await Promise.resolve(E.loadEntries());k.entries.length>0&&a.size===0&&(a.restore(k.entries),x.set(E,k.entries.length),u());break}catch{}})();let O=d.subscribe(E=>{for(let k of E){if(k[0]!==D)continue;let A=k[1];for(let M of m){let S=x.get(M)??0;if(A.length<S){try{let ne=M.appendEntries(A);ne instanceof Promise&&ne.catch(()=>{})}catch{}x.set(M,A.length);continue}if(A.length===S)continue;let ae=A.slice(S);x.set(M,A.length);try{let ne=M.appendEntries(ae);ne instanceof Promise&&ne.catch(()=>{})}catch{}}}});return()=>O()},disposeAllViews(){for(let m of c.values())m.dispose();c.clear();for(let m of p.values())m.dispose();p.clear();for(let m of f.values())m.dispose();f.clear()},dispose(){for(let m of c.values())m.dispose();c.clear();for(let m of p.values())m.dispose();p.clear();for(let m of f.values())m.dispose();f.clear()}};return N}var hr=Vt((r,e)=>{r("observe"),r("signal"),e("write")});function wn(r){let e=Ye([],{name:r.name,maxSize:r.retainedLimit??1024,guard:r.guard??hr,...r.versioning!=null?{versioning:r.versioning}:{}});return e.withLatest(),r.graph&&r.graph.add(e.entries,{name:r.name}),e}function Tn(r,e,t=0){let n=B(t,{name:e,describeKind:"state"});return r.add(n,{name:e}),n}pe();se();ue();var Rt=class{_version=0;_buf;constructor(e){this._buf=e?[...e]:[]}get version(){return this._version}get size(){return this._buf.length}at(e){if(!Number.isInteger(e))return;let t=e>=0?e:this._buf.length+e;if(!(t<0||t>=this._buf.length))return this._buf[t]}append(e){this._buf.push(e),this._version+=1}appendMany(e){if(e.length===0)return;let t=this._buf.length;this._buf.length=t+e.length;for(let n=0;n<e.length;n++)this._buf[t+n]=e[n];this._version+=1}insert(e,t){if(!Number.isInteger(e)||e<0||e>this._buf.length)throw new RangeError(`insert: index ${e} out of range [0, ${this._buf.length}]`);this._buf.splice(e,0,t),this._version+=1}insertMany(e,t){if(!Number.isInteger(e)||e<0||e>this._buf.length)throw new RangeError(`insertMany: index ${e} out of range [0, ${this._buf.length}]`);t.length!==0&&(this._buf.splice(e,0,...t),this._version+=1)}pop(e){if(this._buf.length===0)throw new RangeError("pop from empty list");if(!Number.isInteger(e))throw new RangeError(`pop: index ${e} must be an integer`);let t=e>=0?e:this._buf.length+e;if(t<0||t>=this._buf.length)throw new RangeError(`pop: index ${e} out of range`);let[n]=this._buf.splice(t,1);return this._version+=1,n}clear(){let e=this._buf.length;return e===0?0:(this._buf.length=0,this._version+=1,e)}toArray(){return[...this._buf]}};function xn(r,e={}){let{name:t,versioning:n,backend:s}=e,o=s??new Rt(r),i=B(o.toArray(),{name:t,describeKind:"state",equals:(u,c)=>u===c,...n!=null?{versioning:n}:{}});function a(){let u=o.toArray();q(()=>{i.down([[V]]),i.down([[D,u]])})}function d(u){let c=o.version;try{return u()}finally{o.version!==c&&a()}}return{items:i,get size(){return o.size},at(u){return o.at(u)},append(u){d(()=>o.append(u))},appendMany(u){d(()=>o.appendMany(u))},insert(u,c){d(()=>o.insert(u,c))},insertMany(u,c){d(()=>o.insertMany(u,c))},pop(u=-1){return d(()=>o.pop(u))},clear(){d(()=>o.clear())},dispose(){}}}pe();_e();se();ue();var At=class{_version=0;_store=new Map;_maxSize;_defaultTtl;constructor(e={}){let{maxSize:t,defaultTtl:n}=e;if(t!==void 0&&t<1)throw new RangeError("maxSize must be >= 1");if(n!==void 0&&n<=0)throw new RangeError("defaultTtl must be positive");this._maxSize=t,this._defaultTtl=n}get version(){return this._version}get size(){return this._store.size}has(e){let t=this._store.get(e);return t===void 0?!1:this._isExpired(t)?(this._store.delete(e),this._version+=1,!1):(this._touchLru(e,t),!0)}get(e){let t=this._store.get(e);if(t!==void 0){if(this._isExpired(t)){this._store.delete(e),this._version+=1;return}return this._touchLru(e,t),t.value}}set(e,t,n){let s=this._resolveExpiresAt(n);this._store.has(e)&&this._store.delete(e),this._store.set(e,{value:t,expiresAt:s}),this._evictLruWhileOver(),this._version+=1}setMany(e,t){let n=this._resolveExpiresAt(t),s=0;try{for(let[o,i]of e)this._store.has(o)&&this._store.delete(o),this._store.set(o,{value:i,expiresAt:n}),s+=1}finally{s>0&&(this._evictLruWhileOver(),this._version+=1)}}delete(e){let t=this._store.delete(e);return t&&(this._version+=1),t}deleteMany(e){let t=0;try{for(let n of e)this._store.delete(n)&&(t+=1)}finally{t>0&&(this._version+=1)}return t}clear(){let e=this._store.size;return e===0?0:(this._store.clear(),this._version+=1,e)}pruneExpired(){let e=K(),t=0;for(let[n,s]of this._store)this._isExpired(s,e)&&(this._store.delete(n),t+=1);return t>0&&(this._version+=1),t}toMap(){let e=K(),t=new Map;for(let[n,s]of this._store)this._isExpired(s,e)||t.set(n,s.value);return t}_resolveExpiresAt(e){let t=e??this._defaultTtl;if(t!==void 0){if(!Number.isFinite(t)||t<=0)throw new RangeError(`MapBackend: ttl must be a positive finite number (got ${t})`);return K()+t*1e9}}_isExpired(e,t){return e.expiresAt===void 0?!1:(t??K())>=e.expiresAt}_touchLru(e,t){this._store.delete(e),this._store.set(e,t)}_evictLruWhileOver(){if(this._maxSize!==void 0)for(;this._store.size>this._maxSize;){let e=this._store.keys().next().value;if(e===void 0)break;this._store.delete(e)}}};function kn(r={}){let{name:e,maxSize:t,defaultTtl:n,versioning:s,backend:o,retention:i}=r;if(i&&t!==void 0)throw new RangeError("reactiveMap: `maxSize` (LRU) and `retention` (score-based) are mutually exclusive. Pick one eviction policy.");if(i&&i.archiveThreshold===void 0&&i.maxSize===void 0)throw new RangeError("reactiveMap: `retention` requires at least one of `archiveThreshold` or `maxSize` to trigger archival.");let a=o??new At({maxSize:t,defaultTtl:n}),d=B(a.toMap(),{name:e,describeKind:"state",equals:(f,h)=>f===h,...s!=null?{versioning:s}:{}});function u(){let f=a.toMap();q(()=>{d.down([[V]]),d.down([[D,f]])})}function c(){if(!i)return;let f=a.toMap(),h=i.archiveThreshold,l=i.maxSize,b=[];for(let[v,_]of f)b.push({key:v,value:_,score:i.score(v,_)});b.sort((v,_)=>v.score-_.score);let g=new Set;if(h!==void 0)for(let v of b)if(v.score<h)g.add(v.key);else break;if(l!==void 0&&b.length-g.size>l)for(let v of b){if(b.length-g.size<=l)break;g.has(v.key)||g.add(v.key)}if(g.size!==0)for(let v of b)g.has(v.key)&&(i.onArchive?.(v.key,v.value,v.score),a.delete(v.key))}function p(f,h="mutation"){let l=a.version;try{return f()}finally{a.version!==l&&(h==="mutation"&&c(),u())}}return{entries:d,has(f){return p(()=>a.has(f),"read")},get(f){return p(()=>a.get(f),"read")},set(f,h,l){p(()=>a.set(f,h,l?.ttl))},setMany(f,h){p(()=>a.setMany(f,h?.ttl))},delete(f){p(()=>a.delete(f))},deleteMany(f){p(()=>a.deleteMany(f))},clear(){p(()=>a.clear())},pruneExpired(){p(()=>a.pruneExpired())},get size(){return a.size},dispose(){}}}xt();var gr=256,mr=1024;function Nn(r,e){if(!Number.isFinite(r)||!Number.isInteger(r)||r<0)throw new Error(`${e} must be a non-negative integer`);return r}function Qe(r,e){return Xt("job_queue",r,e)}var br=r=>r.action,Xe=class extends ve{_pending;_jobs;_seqCursor;pending;jobs;depth;events;audit;constructor(e,t={}){super(e,t.graph),this._pending=xn([],{name:"pending"}),this._jobs=kn({name:"jobs"}),this.pending=this._pending.items,this.jobs=this._jobs.entries,this.add(this.pending,{name:"pending"}),this.add(this.jobs,{name:"jobs"}),this.depth=X([this.pending],([n])=>n.length,{name:"depth",describeKind:"derived",meta:Qe("queue_depth"),initial:0}),this.add(this.depth,{name:"depth"}),this.addDisposer(ie(this.depth)),this.events=wn({name:"events",retainedLimit:1024,graph:this}),this.audit=this.events,this._seqCursor=Tn(this,"seq",0)}_bumpSeq(){let t=(this._seqCursor.cache??0)+1;return this._seqCursor.emit(t),t}attachEventStorage(e){return this.events.attachStorage(e)}enqueue(e,t={}){let n=this._bumpSeq(),s=t.id??`${this.name}-${n}`;if(this._jobs.get(s)!==void 0)throw new Error(`jobQueue("${this.name}"): duplicate job id "${s}"`);let o={id:s,payload:e,attempts:0,metadata:Object.freeze({...t.metadata??{}}),state:"queued"};return this._jobs.set(s,o),this._pending.append(s),this.events.append({action:"enqueue",id:s,payload:e,t_ns:ee(),seq:n}),s}claim(e=1){let t=Nn(e,"job queue claim limit");if(t===0)return[];let n=[];for(;n.length<t&&this.pending.cache.length!==0;){let o=this._pending.pop(0),i=this._jobs.get(o);if(!i||i.state!=="queued")continue;let a={...i,state:"inflight",attempts:i.attempts+1};this._jobs.set(o,a),n.push(a),this.events.append({action:"claim",id:o,attempts:a.attempts,t_ns:ee(),seq:this._bumpSeq()})}return n}ack(e){let t=this._jobs.get(e);return!t||t.state!=="inflight"?!1:(this._jobs.delete(e),this.events.append({action:"ack",id:e,attempts:t.attempts,t_ns:ee(),seq:this._bumpSeq()}),!0)}nack(e,t={}){let n=this._jobs.get(e);return!n||n.state!=="inflight"?!1:t.requeue??!0?(this._jobs.set(e,{...n,state:"queued"}),this._pending.append(e),this.events.append({action:"nack",id:e,attempts:n.attempts,t_ns:ee(),seq:this._bumpSeq()}),!0):(this._jobs.delete(e),this.events.append({action:"nack",id:e,attempts:n.attempts,t_ns:ee(),seq:this._bumpSeq()}),!0)}removeById(e){let t=this._jobs.get(e);if(!t)return!1;if(t.state==="queued"){let s=this.pending.cache.indexOf(e);s>=0&&this._pending.pop(s)}return this._jobs.delete(e),this.events.append({action:"remove",id:e,attempts:t.attempts,t_ns:ee(),seq:this._bumpSeq()}),!0}consumeFrom(e,t){return e.subscribe(n=>{for(let s of n){if(s[0]!==D)continue;let o=s[1];this.enqueue(o,t?{metadata:t.metadata}:void 0)}})}},Ze=class extends ve{_stageNames;_stageWorkFns;_queues=new Map;_completed;completed;completedCount;constructor(e,t={}){super(e,t.graph);let n=t.stages??["incoming","processing","done"],s=[],o=new Map;for(let d of n){let u=typeof d=="string"?d.trim():d.name.trim();typeof d!="string"&&d.work&&o.set(u,d.work),s.push(u)}if(s.length<2)throw new Error(`jobFlow("${e}"): requires at least 2 stages`);if(new Set(s).size!==s.length)throw new Error(`jobFlow("${e}"): stage names must be unique`);this._stageNames=Object.freeze([...s]),this._stageWorkFns=o;for(let d of this._stageNames){let u=On(`${e}-${d}`);this._queues.set(d,u),this.mount(d,u)}this._completed=Ye([],{name:"completed",maxSize:mr}),this.completed=this._completed.entries,this.add(this.completed,{name:"completed"}),this.completedCount=X([this.completed],([d])=>d.length,{name:"completedCount",describeKind:"derived",meta:Qe("job_flow_completed_count"),initial:0}),this.add(this.completedCount,{name:"completedCount"}),this.addDisposer(ie(this.completedCount));let a=Math.max(1,Nn(t.maxPerPump??gr,"job flow maxPerPump"));for(let d=0;d<this._stageNames.length;d+=1){let u=this._stageNames[d],c=this.queue(u),p=d+1<this._stageNames.length?this.queue(this._stageNames[d+1]):null,f=this._stageWorkFns.get(u),h=p===null;if(f){let l=oe([c.pending],()=>{let b=0;for(;b<a;){let g=c.claim(1);if(g.length===0)break;let v=g[0];if(!v)break;let y=[...v.metadata.job_flow_path??[],u],w;try{w=f(v)}catch{c.nack(v.id,{requeue:!1}),b+=1;continue}let T=nn(w),N=!1,m;m=T.subscribe(x=>{if(!N){for(let O of x)if(O[0]===D){N=!0,m?m():Promise.resolve().then(()=>m?.());let E=O[1],k={...v.metadata,job_flow_path:y};if(h){let A={...v,payload:E,metadata:Object.freeze(k)};q(()=>{c.ack(v.id),this._completed.append(A)})}else q(()=>{c.ack(v.id),p.enqueue(E,{metadata:k})});return}else if(O[0]===C){N=!0,m?m():Promise.resolve().then(()=>m?.()),c.nack(v.id,{requeue:!1});return}}}),b+=1}},{name:`pump_${u}`,describeKind:"effect",meta:Qe("job_flow_pump",{stage:u,has_work:!0})});this.add(l,{name:`pump_${u}`}),this.addDisposer(ie(l))}else{let l=oe([c.pending],()=>{let b=0;for(;b<a;){let g=c.claim(1);if(g.length===0)break;let v=g[0];if(!v)break;let y=[...v.metadata.job_flow_path??[],u],w={...v.metadata,job_flow_path:y};if(h){let T={...v,metadata:Object.freeze(w)};q(()=>{c.ack(v.id),this._completed.append(T)})}else q(()=>{c.ack(v.id),p.enqueue(v.payload,{metadata:w})});b+=1}},{name:`pump_${u}`,describeKind:"effect",meta:Qe("job_flow_pump",{stage:u,has_work:!1})});this.add(l,{name:`pump_${u}`}),this.addDisposer(ie(l))}}}stages(){return this._stageNames}queue(e){let t=this._queues.get(e);if(!t)throw new Error(`jobFlow("${this.name}"): unknown stage "${e}"`);return t}enqueue(e,t={}){return this.queue(this._stageNames[0]).enqueue(e,t)}retainedCompleted(){return this.completed.cache}};function On(r,e){return new Xe(r,e)}function yr(r,e){let t=new Ze(r,e),{factory:n,factoryArgs:s,...o}=e??{};return t.tagFactory("jobFlow",bt(o)),t}0&&(module.exports={JobFlowGraph,JobQueueGraph,jobEventKeyOf,jobFlow,jobQueue});
1
+ "use strict";var st=Object.defineProperty;var En=Object.getOwnPropertyDescriptor;var Rn=Object.getOwnPropertyNames;var An=Object.prototype.hasOwnProperty;var j=(r,e)=>()=>(r&&(e=r(r=0)),e);var Sn=(r,e)=>{for(var t in e)st(r,t,{get:e[t],enumerable:!0})},Mn=(r,e,t,n)=>{if(e&&typeof e=="object"||typeof e=="function")for(let s of Rn(e))!An.call(r,s)&&s!==t&&st(r,s,{get:()=>e[s],enumerable:!(n=En(e,s))||n.enumerable});return r};var Dn=r=>Mn(st({},"__esModule",{value:!0}),r);function K(){return Math.trunc(performance.now()*1e6)}function ee(){return Date.now()*1e6}var _e=j(()=>{"use strict"});function Le(r){if(r==null)return we;let{type:e,id:t,...n}=r;return{type:e??"system",id:t??"",...n}}var we,$e=j(()=>{"use strict";we={type:"system",id:""}});function Se(){return Te>0||Re}function Gt(){return Te>0}function ke(r){Te>0?Ae.push(r):r()}function q(r){Te+=1;let e=!1;try{r()}catch(t){throw e=!0,t}finally{if(Te-=1,Te===0)if(e){if(!Re){let t=Ae.splice(0);for(let n of t)try{n()}catch{}le.length=0,fe.length=0,xe.length=0}}else Cn()}}function Cn(){let r=!Re;r&&(Re=!0);let e=[],t=0;try{for(;le.length>0||fe.length>0||xe.length>0||r&&Ae.length>0;){if(r&&Ae.length>0){let o=Ae.splice(0);for(let i of o)try{i()}catch(a){e.push(a)}continue}if(t+=1,t>1e3)throw le.length=0,fe.length=0,xe.length=0,new Error("batch drain exceeded 1000 iterations \u2014 likely a reactive cycle");let s=(le.length>0?le:fe.length>0?fe:xe).splice(0);for(let o of s)try{o()}catch(i){e.push(i)}}}finally{r&&(Re=!1)}if(e.length===1)throw e[0];if(e.length>1)throw new AggregateError(e,"batch drain: multiple callbacks threw")}function Me(r,e,t){if(e.length===0)return;if(e.length===1){let u=t(e[0][0]);if(u<3||!Se()){r(e);return}(u>=5?xe:u===4?fe:le).push(()=>r(e));return}let n=e.length,s=n,o=n,i=n,a=0;for(;a<n&&t(e[a][0])<3;)a++;for(s=a;a<n&&t(e[a][0])===3;)a++;for(o=a;a<n&&t(e[a][0])===4;)a++;i=a;let d=Se();if(s>0){let u=e.slice(0,s);r(u)}if(o>s){let u=e.slice(s,o);d?le.push(()=>r(u)):r(u)}if(i>o){let u=e.slice(o,i);d?fe.push(()=>r(u)):r(u)}if(n>i){let u=e.slice(i,n);d?xe.push(()=>r(u)):r(u)}}var Te,Re,le,fe,xe,Ae,pe=j(()=>{"use strict";Te=0,Re=!1,le=[],fe=[],xe=[],Ae=[]});var he,D,V,W,Y,te,re,z,F,C,ge,Ie,Pt,Fe,Lt,$t,Ve,ot,it,at,ze,se=j(()=>{"use strict";he=Symbol.for("graphrefly/START"),D=Symbol.for("graphrefly/DATA"),V=Symbol.for("graphrefly/DIRTY"),W=Symbol.for("graphrefly/RESOLVED"),Y=Symbol.for("graphrefly/INVALIDATE"),te=Symbol.for("graphrefly/PAUSE"),re=Symbol.for("graphrefly/RESUME"),z=Symbol.for("graphrefly/TEARDOWN"),F=Symbol.for("graphrefly/COMPLETE"),C=Symbol.for("graphrefly/ERROR"),ge=Object.freeze([V]),Ie=Object.freeze([W]),Pt=Object.freeze([Y]),Fe=Object.freeze([he]),Lt=Object.freeze([F]),$t=Object.freeze([z]),Ve=Object.freeze([ge]),ot=Object.freeze([Ie]),it=Object.freeze([Pt]),at=Object.freeze([Lt]),ze=Object.freeze([$t])});function It(r){r.registerMessageType(he,{tier:0,wireCrossing:!1}),r.registerMessageType(V,{tier:1,wireCrossing:!1}),r.registerMessageType(Y,{tier:1,wireCrossing:!1,metaPassthrough:!1}),r.registerMessageType(te,{tier:2,wireCrossing:!1}),r.registerMessageType(re,{tier:2,wireCrossing:!1}),r.registerMessageType(D,{tier:3,wireCrossing:!0}),r.registerMessageType(W,{tier:3,wireCrossing:!0}),r.registerMessageType(F,{tier:4,wireCrossing:!0,metaPassthrough:!1}),r.registerMessageType(C,{tier:4,wireCrossing:!0,metaPassthrough:!1}),r.registerMessageType(z,{tier:5,wireCrossing:!0,metaPassthrough:!1})}var je,Ft=j(()=>{"use strict";se();je=class{_messageTypes=new Map;_codecs=new Map;_onMessage;_onSubscribe;_defaultVersioning;_defaultHashFn;_inspectorEnabled=!(typeof process<"u"&&process.env?.NODE_ENV==="production");_globalInspector;_rigorRecorder;_frozen=!1;tierOf;constructor(e){this._onMessage=e.onMessage,this._onSubscribe=e.onSubscribe,this._defaultVersioning=e.defaultVersioning,this._defaultHashFn=e.defaultHashFn,this.tierOf=t=>{let n=this._messageTypes.get(t);return n!=null?n.tier:1}}get onMessage(){return this._frozen=!0,this._onMessage}get onSubscribe(){return this._frozen=!0,this._onSubscribe}set onMessage(e){this._assertUnfrozen(),this._onMessage=e}set onSubscribe(e){this._assertUnfrozen(),this._onSubscribe=e}get defaultVersioning(){return this._defaultVersioning}set defaultVersioning(e){this._assertUnfrozen(),this._defaultVersioning=e}get defaultHashFn(){return this._defaultHashFn}set defaultHashFn(e){this._assertUnfrozen(),this._defaultHashFn=e}get inspectorEnabled(){return this._inspectorEnabled}set inspectorEnabled(e){this._inspectorEnabled=e}get globalInspector(){return this._globalInspector}set globalInspector(e){this._globalInspector=e}get rigorRecorder(){return this._rigorRecorder}set rigorRecorder(e){this._rigorRecorder=e}registerMessageType(e,t){return this._assertUnfrozen(),this._messageTypes.set(e,{tier:t.tier,wireCrossing:t.wireCrossing??t.tier>=3,metaPassthrough:t.metaPassthrough??!0}),this}messageTier(e){let t=this._messageTypes.get(e);return t!=null?t.tier:1}isWireCrossing(e){let t=this._messageTypes.get(e);return t!=null?t.wireCrossing:!0}isLocalOnly(e){return!this.isWireCrossing(e)}isMetaPassthrough(e){let t=this._messageTypes.get(e);return t!=null?t.metaPassthrough:!0}isKnownMessageType(e){return this._messageTypes.has(e)}registerCodec(e){return this._assertUnfrozen(),this._codecs.set(e.name,e),this}lookupCodec(e){return this._codecs.get(e)}_isFrozen(){return this._frozen}_assertUnfrozen(){if(this._frozen)throw new Error("GraphReFlyConfig is frozen: a node has already captured this config. Register custom types and set hooks before creating any node.")}}});function Vt(r){return Array.isArray(r)?[...r]:[r]}function Gn(r,e){return r.has(e)||r.has("*")}function zt(r){let e=[];return r((s,o)=>{e.push({kind:"allow",actions:new Set(Vt(s)),where:o?.where??(()=>!0)})},(s,o)=>{e.push({kind:"deny",actions:new Set(Vt(s)),where:o?.where??(()=>!0)})}),(s,o)=>{let i=!1,a=!1;for(let d of e)Gn(d.actions,o)&&d.where(s)&&(d.kind==="deny"?i=!0:a=!0);return i?!1:a}}function ut(r){let e=Pn.filter(t=>r({type:t,id:""},"write"));return e.length===0?"restricted":e.includes("human")&&e.includes("llm")&&e.every(t=>t==="human"||t==="llm"||t==="system")?"both":e.length===1?e[0]:e.join("+")}var Q,Pn,Ne=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}};Pn=["human","llm","wallet","system"]});function Bt(r,e){let t=new TextEncoder().encode(r.name);if(t.length===0||t.length>255)throw new Error(`encodeEnvelope: codec name "${r.name}" encodes to ${t.length} bytes (must be 1\u2013255)`);let n=r.version;if(!Number.isInteger(n)||n<0||n>65535)throw new Error(`encodeEnvelope: codec.version ${n} out of u16 range (expected integer 0\u201365535)`);let s=2+t.length+2+e.length;if(s>4294967295)throw new Error(`encodeEnvelope: total envelope size ${s} exceeds 2^32-1 bytes (payload ${e.length} bytes)`);let o=new Uint8Array(s),i=0;return o[i++]=dt,o[i++]=t.length,o.set(t,i),i+=t.length,o[i++]=n>>>8&255,o[i++]=n&255,o.set(e,i),o}function Ht(r,e){if(r.length<jt)throw new Error(`decodeEnvelope: bytes too short (${r.length} < ${jt})`);let t=0,n=r[t++];if(n!==dt)throw new Error(`decodeEnvelope: unsupported envelope version ${n} (expected ${dt})`);let s=r[t++];if(s===0)throw new Error("decodeEnvelope: name_len must be >= 1");if(t+s+2>r.length)throw new Error(`decodeEnvelope: envelope truncated (need ${t+s+2} bytes, have ${r.length})`);let o=new TextDecoder().decode(r.subarray(t,t+s));t+=s;let i=(r[t]<<8|r[t+1])>>>0;t+=2;let a=r.subarray(t),d=e.lookupCodec(o);if(d==null)throw new Error(`decodeEnvelope: codec "${o}" not registered (envelope codec_v=${i})`);return{codec:d,codecVersion:i,payload:a}}function Kt(r){r.registerCodec(Ln)}var Ln,dt,jt,ct=j(()=>{"use strict";Ln={name:"json",version:1,contentType:"application/json",encode(r){let e=JSON.stringify(r);return new TextEncoder().encode(e)},decode(r,e){let t=new TextDecoder().decode(r);return JSON.parse(t)}},dt=1,jt=4});function lt(r){if(r===void 0)return null;if(typeof r=="number"){if(!Number.isFinite(r))throw new TypeError(`Cannot hash non-finite number: ${r}`);if(Number.isInteger(r)&&!Number.isSafeInteger(r))throw new TypeError(`Cannot hash integer outside safe range (|n| > 2^53-1): ${r}. Cross-language cid parity is not guaranteed for unsafe integers.`);return r}if(typeof r=="string"||typeof r=="boolean"||r===null)return r;if(Array.isArray(r))return r.map(lt);if(typeof r=="object"&&r!==null){let e={};for(let t of Object.keys(r).sort())e[t]=lt(r[t]);return e}return null}function Fn(r){let e=In.encode(r),t=e.length,n=t*8,s=t+9+63&-64,o=new Uint8Array(s);o.set(e),o[t]=128;let i=new DataView(o.buffer);i.setUint32(s-4,n>>>0,!1),i.setUint32(s-8,Math.floor(n/4294967296)>>>0,!1);let a=1779033703,d=3144134277,u=1013904242,c=2773480762,p=1359893119,f=2600822924,h=528734635,l=1541459225,v=new Uint32Array(64),g=(y,m)=>y>>>m|y<<32-m;for(let y=0;y<s;y+=64){for(let k=0;k<16;k++)v[k]=i.getUint32(y+k*4,!1);for(let k=16;k<64;k++){let A=v[k-15],M=v[k-2],S=g(A,7)^g(A,18)^A>>>3,ae=g(M,17)^g(M,19)^M>>>10;v[k]=v[k-16]+S+v[k-7]+ae>>>0}let m=a,_=d,T=u,O=c,b=p,x=f,N=h,E=l;for(let k=0;k<64;k++){let A=g(b,6)^g(b,11)^g(b,25),M=b&x^~b&N,S=E+A+M+$n[k]+v[k]>>>0,ae=g(m,2)^g(m,13)^g(m,22),ne=m&_^m&T^_&T,Ge=ae+ne>>>0;E=N,N=x,x=b,b=O+S>>>0,O=T,T=_,_=m,m=S+Ge>>>0}a=a+m>>>0,d=d+_>>>0,u=u+T>>>0,c=c+O>>>0,p=p+b>>>0,f=f+x>>>0,h=h+N>>>0,l=l+E>>>0}let w=y=>y.toString(16).padStart(8,"0");return w(a)+w(d)+w(u)+w(c)+w(p)+w(f)+w(h)+w(l)}function ft(r){let e=lt(r??null),t=JSON.stringify(e);return Fn(t).slice(0,16)}function Vn(){let r=globalThis.crypto;if(r?.randomUUID)return r.randomUUID();let e=()=>Math.floor(Math.random()*4294967296).toString(16).padStart(8,"0"),t=e()+e()+e()+e();return`${t.slice(0,8)}-${t.slice(8,12)}-4${t.slice(13,16)}-${(parseInt(t.slice(16,17),16)&3|8).toString(16)}${t.slice(17,20)}-${t.slice(20,32)}`}function pt(r,e,t){let n=t?.id??Vn();if(r===0)return{id:n,version:0};let o=(t?.hash??ft)(e);return{id:n,version:0,cid:o,prev:null}}function qt(r,e,t){r.version+=1,"cid"in r&&(r.prev=r.cid,r.cid=t(e))}var $n,In,Wt=j(()=>{"use strict";$n=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]),In=new TextEncoder});function Yt(r){return{node:r,unsub:null,prevData:void 0,dirty:!1,involvedThisWave:!1,dataBatch:[],terminal:void 0}}function ht(r){r.prevData=void 0,r.dirty=!1,r.involvedThisWave=!1,r.dataBatch.length=0,r.terminal=void 0}function Be(r){return r.length===0?r:typeof r[0]=="symbol"?[r]:r}function oe(r,e,t){let n=Qt(r)?r:[],s=typeof r=="function"?r:typeof e=="function"?e:void 0,o={};return Qt(r)?o=(gt(e)?e:t)??{}:gt(r)?o=r:o=(gt(e)?e:t)??{},new $(n,s,o)}var Ut,Jt,zn,jn,Oe,$,Qt,gt,me=j(()=>{"use strict";ct();$e();pe();_e();Ft();Ne();se();Wt();Ut=()=>{},Jt=100;zn=(r,e,t,n)=>{t.direction==="down-in"&&r._onDepMessage(t.depIndex,e)},jn=(r,e,t,n)=>{let s=r;if(s._status==="completed"||s._status==="errored")return;let o=s._cached,i=o===void 0?[Fe]:[Fe,[D,o]];s._status==="dirty"&&i.push(ge),Me(e,i,s._config.tierOf)},Oe=new je({onMessage:zn,onSubscribe:jn});It(Oe);Kt(Oe);$=class r{_optsName;_describeKind;meta;_hasMeta;_config;_deps;_sinks=null;_sinkCount=0;_cached;_status;_cleanup;_store={};_waveHasNewData=!1;_hasNewTerminal=!1;_hasCalledFnOnce=!1;_paused=!1;_pendingWave=!1;_isExecutingFn=!1;_pendingRerun=!1;_rerunDepth=0;_dirtyDepCount=0;_batchPendingMessages=null;_pauseLocks=null;_pauseBuffer=null;_fn;_equals;_resubscribable;_resetOnTeardown;_autoComplete;_autoError;_pausable;_partial;_guard;_extraGuards;_hashFn;_versioning;_versioningLevel;_lastMutation;_inspectorHooks;_actions;constructor(e,t,n){this._config=n.config??Oe,this._config.onMessage,this._optsName=n.name,this._describeKind=n.describeKind,this._equals=n.equals??Object.is,this._resubscribable=n.resubscribable??!1,this._resetOnTeardown=n.resetOnTeardown??!1,this._autoComplete=n.completeWhenDepsComplete??!0,this._autoError=n.errorWhenDepsError??!0,this._pausable=n.pausable??!0,this._guard=n.guard,this._fn=t,this._partial=n.partial??!1,this._cached=n.initial!==void 0?n.initial:void 0,this._status=e.length===0&&t==null&&this._cached!==void 0?"settled":"sentinel",this._hashFn=n.versioningHash??this._config.defaultHashFn??ft;let s=n.versioning??this._config.defaultVersioning;this._versioningLevel=s,this._versioning=s!=null?pt(s,this._cached===void 0?void 0:this._cached,{id:n.versioningId,hash:this._hashFn}):void 0,this._deps=e.map(Yt);let o={};for(let[a,d]of Object.entries(n.meta??{})){let u={initial:d,name:`${n.name??"node"}:meta:${a}`,describeKind:"state",config:this._config};n.guard!=null&&(u.guard=n.guard),o[a]=new r([],void 0,u)}Object.freeze(o),this.meta=o,this._hasMeta=Object.keys(o).length>0;let i=this;this._actions={emit(a){i._emit([[D,a]])},down(a){i._emit(Be(a))},up(a){i._emitUp(Be(a))}},this.down=this.down.bind(this),this.up=this.up.bind(this)}get _isTerminal(){return this._status==="completed"||this._status==="errored"}get name(){return this._optsName}get status(){return this._status}get cache(){return this._cached===void 0?void 0:this._cached}get lastMutation(){return this._lastMutation}get v(){return this._versioning}hasGuard(){return this._guard!=null}_applyVersioning(e,t){if(this._isExecutingFn)throw new Error(`Node "${this.name}": _applyVersioning cannot run mid-fn \u2014 call it outside of \`_execFn\` (typically at graph setup time before the first subscribe).`);let n=this._versioningLevel;if(n!=null&&e<=n)return;let s=t?.hash??this._hashFn;s!==this._hashFn&&(this._hashFn=s);let o=this._cached===void 0?void 0:this._cached,i=this._versioning,a=i?.id??t?.id,d=i?.version??0,u=pt(e,o,{id:a,hash:s});u.version=d,this._versioning=u,this._versioningLevel=e}_setInspectorHook(e){return e==null?()=>{}:(this._inspectorHooks==null&&(this._inspectorHooks=new Set),this._inspectorHooks.add(e),()=>{this._inspectorHooks?.delete(e),this._inspectorHooks?.size===0&&(this._inspectorHooks=void 0)})}_pushGuard(e){return this._extraGuards==null&&(this._extraGuards=new Set),this._extraGuards.add(e),()=>{this._extraGuards?.delete(e),this._extraGuards?.size===0&&(this._extraGuards=void 0)}}allowsObserve(e){if(this._guard==null&&this._extraGuards==null)return!0;let t=Le(e);if(this._guard!=null&&!this._guard(t,"observe"))return!1;if(this._extraGuards!=null){for(let n of this._extraGuards)if(!n(t,"observe"))return!1}return!0}_checkGuard(e){if(e?.internal)return;let t=this._guard!=null||this._extraGuards!=null,n=e?.actor!=null;if(!t&&!n)return;let s=Le(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:ee()}}down(e,t){let n=Be(e);n.length!==0&&(this._checkGuard(t),this._emit(n))}emit(e,t){this._checkGuard(t),this._emit([[D,e]])}up(e,t){if(this._deps.length===0)return;let n=Be(e);if(n.length===0)return;this._checkGuard(t);let s=t??{internal:!0};this._validateUpTiers(n);for(let o of this._deps)o.node.up?.(n,s)}_emitUp(e){if(this._deps.length!==0&&e.length!==0){this._validateUpTiers(e);for(let t of this._deps)t.node.up?.(e,{internal:!0})}}_validateUpTiers(e){let t=this._config.tierOf;for(let n of e){let s=t(n[0]);if(s===3||s===4)throw new Error(`Node "${this.name}": tier-${s} messages cannot flow up \u2014 DATA/RESOLVED/COMPLETE/ERROR are downstream-only. Use \`down(...)\` for value delivery; \`up(...)\` is for control signals (DIRTY, INVALIDATE, PAUSE, RESUME, TEARDOWN).`)}}subscribe(e,t){if(t!=null&&this._guard!=null){let d=Le(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)ht(d);if(this._partial===!1){for(let d of this._deps)if(d.prevData!==void 0||d.dataBatch.length!==0||d.terminal!==void 0||d.dirty)throw new Error(`resubscribable-reset invariant: DepRecord not fully reset for node ${this._optsName??"(anonymous)"}`)}}this._sinkCount+=1;let o;try{o=this._config.onSubscribe(this,e,{sinkCount:this._sinkCount,afterTerminalReset:s},this._actions)}catch(d){throw this._sinkCount-=1,d}this._sinks==null?this._sinks=e:typeof this._sinks=="function"?this._sinks=new Set([this._sinks,e]):this._sinks.add(e);let i=this._isTerminal;if(this._sinkCount===1&&!i)try{this._activate()}catch(d){if(this._sinkCount-=1,this._removeSink(e),this._sinkCount===0&&(this._status="sentinel"),typeof o=="function")try{o()}catch{}throw d}this._status==="sentinel"&&this._cached===void 0&&(this._status="pending");let a=!1;return()=>{a||(a=!0,this._sinkCount-=1,this._removeSink(e),typeof o=="function"&&o(),this._sinks==null&&this._deactivate())}}_removeSink(e){if(this._sinks===e)this._sinks=null;else if(this._sinks!=null&&typeof this._sinks!="function")if(this._sinks.delete(e),this._sinks.size===1){let[t]=this._sinks;this._sinks=t}else this._sinks.size===0&&(this._sinks=null)}_activate(){if(this._deps.length===0){this._fn&&this._execFn();return}this._dirtyDepCount=0;let e=this._deps.length,t=0;try{for(let n=0;n<e;n++){let s=n,o=this._deps[n];o.unsub=Ut,o.unsub=o.node.subscribe(i=>{if(o.unsub===null)return;let a=this._config.tierOf,d=!1;for(let u of i)a(u[0])>=3&&(d=!0),this._config.onMessage(this,u,{direction:"down-in",depIndex:s},this._actions);d&&this._maybeRunFnOnSettlement()}),t++}}catch(n){this._deps[t].unsub=null;for(let s=0;s<t;s++){let o=this._deps[s];if(o.unsub!=null){let i=o.unsub;o.unsub=null;try{i()}catch{}ht(o)}}throw this._dirtyDepCount=0,n}}_addDep(e){for(let s=0;s<this._deps.length;s++)if(this._deps[s].node===e)return s;let t=this._deps.length,n=Yt(e);if(this._deps.push(n),this._sinks==null)return t;n.dirty=!0,this._dirtyDepCount++,this._status!=="dirty"&&this._emit(Ve),n.unsub=Ut;try{n.unsub=e.subscribe(s=>{if(n.unsub===null)return;let o=this._config.tierOf,i=!1;for(let a of s)o(a[0])>=3&&(i=!0),this._config.onMessage(this,a,{direction:"down-in",depIndex:t},this._actions);i&&this._maybeRunFnOnSettlement()})}catch(s){throw n.unsub=null,this._deps.pop(),this._dirtyDepCount--,s}return t}_deactivate(e=!1){let t=this._cleanup;if(this._cleanup=void 0,typeof t=="function")try{t()}catch(n){this._emit([[C,this._wrapFnError("cleanup threw",n)]])}else if(t!=null&&typeof t=="object"){let n=t.deactivate;if(typeof n=="function")try{n()}catch(s){this._emit([[C,this._wrapFnError("cleanup.deactivate threw",s)]])}}for(let n of this._deps){if(n.unsub!=null){let s=n.unsub;n.unsub=null;try{s()}catch{}}ht(n)}this._waveHasNewData=!1,this._hasNewTerminal=!1,this._hasCalledFnOnce=!1,this._paused=!1,this._pendingWave=!1,this._pendingRerun=!1,this._rerunDepth=0,this._store={},this._dirtyDepCount=0,this._pauseLocks=null,this._pauseBuffer=null,this._fn!=null&&(this._cached=void 0),e||(this._fn!=null||this._deps.length>0)&&(!this._isTerminal||this._resubscribable)&&(this._status="sentinel")}_onDepMessage(e,t){let n=this._deps[e],s=t[0];if(this._inspectorHooks!=null){let o={kind:"dep_message",depIndex:e,message:t};for(let i of this._inspectorHooks)i(o)}if(s!==he){if(s===V){this._depDirtied(n);return}if(s===Y){if(this._depInvalidated(n),this._cached===void 0)return;this._emit(it);return}if(s===te||s===re){this._emit([t]);return}if(s===z){this._emit(ze);return}if(s===D)this._depSettledAsData(n,t[1]);else if(s===W)this._depSettledAsResolved(n);else if(s===F)this._depSettledAsTerminal(n,!0);else if(s===C)this._depSettledAsTerminal(n,t[1]);else{this._emit([t]);return}if(!this._fn){(s===D||s===W)&&this._emit([t]),(s===F||s===C)&&this._maybeAutoTerminalAfterWave();return}}}_depDirtied(e){e.dirty||(e.dirty=!0,e.involvedThisWave=!0,this._dirtyDepCount++,this._status!=="dirty"&&this._emit(Ve))}_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(ot),this._maybeAutoTerminalAfterWave();return}this._fn&&this._execFn(),this._maybeAutoTerminalAfterWave()}}_maybeAutoTerminalAfterWave(){if(this._deps.length===0||this._isTerminal)return;let e=this._deps.find(t=>t.terminal!==void 0&&t.terminal!==!0);if(e!=null){this._autoError&&this._emit([[C,e.terminal]]);return}this._autoComplete&&this._deps.every(t=>t.terminal!==void 0)&&this._emit(at)}_execFn(){if(!this._fn||this._isTerminal&&!this._resubscribable)return;if(this._isExecutingFn){this._pendingRerun=!0;return}let e=this._cleanup;if(typeof e=="function"){this._cleanup=void 0;try{e()}catch(i){this._emit([[C,this._wrapFnError("cleanup threw",i)]]);return}}else if(e!=null&&typeof e=="object"){let i=e.beforeRun;if(typeof i=="function"){e.beforeRun=void 0;try{i()}catch(a){this._emit([[C,this._wrapFnError("cleanup.beforeRun threw",a)]]);return}}}let t=this._deps.map(i=>i.involvedThisWave?i.dataBatch.length>0?[...i.dataBatch]:[]:void 0),n=this._deps.map(i=>i.prevData);for(let i=0;i<this._deps.length;i++){let a=t[i];a!=null&&a.length>0&&(this._deps[i].prevData=a[a.length-1])}let s=this._deps.map(i=>i.terminal),o={prevData:n,terminalDeps:s,store:this._store};if(this._hasCalledFnOnce=!0,this._clearWaveFlags(),this._inspectorHooks!=null){let i={kind:"run",batchData:t,prevData:n};for(let a of this._inspectorHooks)a(i)}this._isExecutingFn=!0;try{let i=this._fn(t,this._actions,o);if(typeof i=="function")this._cleanup=i;else if(i!=null&&typeof i=="object"){let a=i;(typeof a.beforeRun=="function"||typeof a.deactivate=="function"||typeof a.invalidate=="function")&&(this._cleanup=i)}}catch(i){this._emit([[C,this._wrapFnError("fn threw",i)]])}finally{this._isExecutingFn=!1,this._pendingRerun?(this._pendingRerun=!1,this._rerunDepth+=1,this._rerunDepth>Jt?(this._rerunDepth=0,this._emit([[C,new Error(`Node "${this.name}": _pendingRerun depth exceeded ${Jt} \u2014 likely a reactive cycle`)]])):this._maybeRunFnOnSettlement()):this._rerunDepth=0,this._clearWaveFlags()}}_clearWaveFlags(){this._waveHasNewData=!1,this._hasNewTerminal=!1;for(let e of this._deps)e.involvedThisWave=!1,e.dataBatch.length=0}_wrapFnError(e,t){let n=t instanceof Error?t.message:String(t);return new Error(`Node "${this.name}": ${e}: ${n}`,{cause:t})}_frameBatch(e){let t=this._config.tierOf;if(e.length===1)return t(e[0][0])===3&&this._status!=="dirty"?[ge,e[0]]:e;let n=!0,s=!1,o=!1,i=-1;for(let d of e){let u=t(d[0]);u<i&&(n=!1),u===3&&(s=!0),d[0]===V&&(o=!0),i=u}let a=e;if(!n){let d=e.map((u,c)=>({m:u,i:c,tier:t(u[0])}));d.sort((u,c)=>u.tier-c.tier||u.i-c.i),a=d.map(u=>u.m)}if(s&&!o&&this._status!=="dirty"){let d=0;for(;d<a.length&&t(a[d][0])===0;)d++;return d===0?[ge,...a]:[...a.slice(0,d),ge,...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]===C&&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]===z||d[0]===Y);if(a.length===0)return;t=a}t=this._frameBatch(t);let s=null;for(let a=0;a<t.length;a++){let d=t[a],u=d[0];if(u!==te&&u!==re){s?.push(d);continue}if(d.length<2)throw new Error(`Node "${this.name}": [[${u===te?"PAUSE":"RESUME"}]] must carry a lockId payload \u2014 bare PAUSE/RESUME is a protocol violation (C0 rule). Use \`[[PAUSE, lockId]]\` / \`[[RESUME, lockId]]\`.`);let c=!0;if(this._pausable!==!1){let p=d[1];if(u===te)this._pauseLocks==null&&(this._pauseLocks=new Set),this._pauseLocks.add(p),this._paused=!0,this._pausable==="resumeAll"&&this._pauseBuffer==null&&(this._pauseBuffer=[]);else if(this._pauseLocks==null||!this._pauseLocks.has(p))c=!1;else if(this._pauseLocks.delete(p),this._pauseLocks.size===0){if(this._paused=!1,this._pauseBuffer!=null&&this._pauseBuffer.length>0){let f=this._pauseBuffer;this._pauseBuffer=[],this._emit(f)}this._pendingWave&&(this._pendingWave=!1,this._maybeRunFnOnSettlement())}}c?s?.push(d):s==null&&(s=t.slice(0,a))}if(s!=null){if(s.length===0)return;t=s}if(this._hasMeta&&t.some(a=>a[0]===z))for(let a of Object.keys(this.meta))try{this.meta[a]._emit(ze)}catch{}let{finalMessages:o,equalsError:i}=this._updateState(t);if(o.length>0&&this._config.inspectorEnabled){let a=this._config.globalInspector;if(a!=null)try{a({kind:"emit",node:this,messages:o})}catch{}}if(o.length>0)if(this._paused&&this._pausable==="resumeAll"&&this._pauseBuffer!=null){let a=this._config.tierOf,d=[];for(let u of o)a(u[0])===3?this._pauseBuffer.push(u):d.push(u);d.length>0&&this._dispatchOrAccumulate(d)}else this._dispatchOrAccumulate(o);i!=null&&this._emit([[C,i]])}_updateState(e){let t=this._config.tierOf,n,s,o=-1,i=0;for(let c of e)t(c[0])===3&&i++;let a=i<=1,d=-1;if(this._versioning!=null&&i>1){for(let c=e.length-1;c>=0;c--)if(e[c][0]===D){d=c;break}}for(let c=0;c<e.length;c++){let p=e[c],f=p[0];if(f===D){if(p.length>=2){let h=!1;if(a&&this._cached!==void 0)try{h=this._equals(this._cached,p[1])}catch(l){s=this._wrapFnError("equals threw",l),o=c;break}if(h){n==null&&(n=e.slice(0,c)),n.push(Ie),this._status="resolved";continue}this._cached=p[1],this._versioning!=null&&(d<0||c===d)&&qt(this._versioning,p[1],this._hashFn)}this._status="settled",n?.push(p)}else if(n?.push(p),f===V)this._status="dirty";else if(f===W)this._status="resolved";else if(f===F){this._status="completed";{let h=this._config.rigorRecorder;if(h!=null)try{h.onTerminalTransition(this,"completed",this._autoComplete,this._autoError,this._deps.length>0)}catch{}}}else if(f===C){this._status="errored";{let h=this._config.rigorRecorder;if(h!=null)try{h.onTerminalTransition(this,"errored",this._autoComplete,this._autoError,this._deps.length>0)}catch{}}}else if(f===Y){if(this._cached!==void 0){let l=this._config.rigorRecorder;if(l!=null)try{l.onNonVacuousInvalidate(this,this._cached)}catch{}}this._cached=void 0,this._status="dirty";let h=this._cleanup;if(typeof h=="function"){this._cleanup=void 0;try{h()}catch{}}else if(h!=null&&typeof h=="object"){let l=h.invalidate;if(typeof l=="function")try{l()}catch{}}}else f===z&&(this._resetOnTeardown&&(this._cached=void 0),this._deactivate(!0),this._status="sentinel")}let u=o>=0?n??e.slice(0,o):n??e;return s!=null?{finalMessages:u,equalsError:s}:{finalMessages:u}}_deliverToSinks=e=>{if(this._sinks==null)return;if(typeof this._sinks=="function"){this._sinks(e);return}let t=[...this._sinks];for(let n of t)n(e)};_dispatchOrAccumulate(e){if(Gt()){this._batchPendingMessages===null&&(this._batchPendingMessages=[],ke(()=>this._flushBatchPending()));for(let t of e)this._batchPendingMessages.push(t);return}Me(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);Me(this._deliverToSinks,t,this._config.tierOf)}},Qt=r=>Array.isArray(r),gt=r=>typeof r=="object"&&r!=null&&!Array.isArray(r)});function He(r,e){if(e!=null&&e.length>0)return new Set(e);switch(r){case"standard":return new Set(["type","status","value","deps","meta","v"]);case"full":return null;case"spec":return new Set(["type","deps","meta","value"]);default:return new Set(["type","deps"])}}function Bn(r){return r._describeKind!=null?r._describeKind:r._deps.length>0?"derived":r._fn!=null?"producer":"state"}function bt(r){let e=new WeakSet,t={};for(let[n,s]of Xt(r))t[n]=mt(s,e);return t}function mt(r,e){if(r==null)return r;let t=typeof r;if(t==="boolean"||t==="number"||t==="string")return r;if(t==="function")return"<function>";if(Array.isArray(r))return e.has(r)?"<cycle>":(e.add(r),r.map(n=>mt(n,e)));if(t==="object"){let n=r;if(e.has(n))return"<cycle>";e.add(n);try{if(typeof n.subscribe=="function"&&"cache"in n)return"<Node>"}catch{return"<unserializable>"}let s={};for(let[o,i]of Xt(n))s[o]=mt(i,e);return s}return"<unserializable>"}function Xt(r){let e=[],t;try{t=Object.keys(r)}catch{return e}for(let n of t)try{e.push([n,r[n]])}catch{e.push([n,"<unserializable>"])}return e}function Hn(r){let e={};for(let[t,n]of Object.entries(r.meta))try{e[t]=n.cache}catch{}return e}function yt(r,e,t){let n=e==null,s=!n&&e!=null?[...e].filter(c=>c.startsWith("meta.")).map(c=>c.slice(5)):null,o=n||e.has("meta")||s!=null&&s.length>0,i="state",a=[];r instanceof $&&(i=Bn(r),a=r._deps.map(c=>c.node.name??""));let d={type:i,deps:a};(n||e.has("status"))&&(d.status=r.status);let u=r instanceof $?r._guard:void 0;if(o){let c={...Hn(r)};if(u!=null&&c.access===void 0&&(c.access=ut(u)),s!=null&&s.length>0&&!e.has("meta")){let p={};for(let f of s)f in c&&(p[f]=c[f]);d.meta=p}else d.meta=c}if(r.name!=null&&(d.name=r.name),(n||e.has("value"))&&(!t||i==="state")){r.status==="sentinel"&&(d.sentinel=!0);try{d.value=r.cache}catch{}}if((n||e.has("v"))&&r.v!=null){let c={id:r.v.id,version:r.v.version};"cid"in r.v&&(c.cid=r.v.cid,c.prev=r.v.prev),d.v=c}return(n||e.has("guard"))&&u!=null&&(d.guard=ut(u)),(n||e.has("lastMutation"))&&r.lastMutation!=null&&(d.lastMutation=r.lastMutation),d}var vt=j(()=>{"use strict";Ne();me()});function B(r,e){return oe([],{...e,initial:r})}function ue(r,e){return oe((n,s,o)=>r(s,o)??void 0,{describeKind:"producer",...e})}function X(r,e,t){return oe(r,(s,o,i)=>{let a=s.map((d,u)=>d!=null&&d.length>0?d.at(-1):i.prevData[u]);o.emit(e(a,i))},{describeKind:"derived",...t})}var de=j(()=>{"use strict";me()});function Zt(r,e,t){return{[r]:!0,[`${r}_type`]:e,...t??{}}}var en=j(()=>{"use strict"});function Tt(r){return{describeKind:"producer",...r}}function nn(r,e){return ue(t=>{let n=!1;try{for(let s of r){if(n)return;t.emit(s)}n||t.down([[F]])}catch(s){n||t.down([[C,s]])}return()=>{n=!0}},Tt(e))}function Kn(r){return r!=null&&typeof r.then=="function"}function qn(r,e){let{signal:t,...n}=e??{};return ue(s=>{let o=!1,i=()=>{o||(o=!0,s.down([[C,t.reason]]))};if(t?.aborted){i();return}return t?.addEventListener("abort",i,{once:!0}),Promise.resolve(r).then(a=>{o||(o=!0,t?.removeEventListener("abort",i),s.emit(a),s.down([[F]]))},a=>{o||(o=!0,t?.removeEventListener("abort",i),s.down([[C,a]]))}),()=>{o=!0,t?.removeEventListener("abort",i)}},Tt(n))}function Wn(r,e){let{signal:t,...n}=e??{};return ue(s=>{let o=new AbortController,i=()=>o.abort(t?.reason);t?.aborted?o.abort(t.reason):t?.addEventListener("abort",i,{once:!0});let a=t??o.signal,d=!1,u=r[Symbol.asyncIterator](),c=()=>{d||a.aborted||Promise.resolve(u.next()).then(p=>{if(!(d||a.aborted)){if(p.done){s.down([[F]]);return}s.emit(p.value),c()}},p=>{!d&&!a.aborted&&s.down([[C,p]])})};return c(),()=>{d=!0,t?.removeEventListener("abort",i),o.abort(),Promise.resolve(u.return?.()).catch(()=>{})}},Tt(n))}function Un(r){return r!=null&&typeof r=="object"&&"cache"in r&&typeof r.subscribe=="function"}function rn(r,e){if(Un(r))return r;if(Kn(r))return qn(r,e);if(r!=null){let t=r;if(typeof t[Symbol.asyncIterator]=="function")return Wn(r,e);if(typeof t[Symbol.iterator]=="function")return nn(r,e)}return Jn(r)}function Jn(...r){return nn(r,void 0)}function ie(r){return r.subscribe(()=>{})}var sn=j(()=>{"use strict";se();de()});var xt=j(()=>{"use strict";sn()});var Ke,on=j(()=>{"use strict";Ke=class{_timer;_gen=0;start(e,t){this.cancel(),this._gen+=1;let n=this._gen;this._timer=setTimeout(()=>{this._timer=void 0,n===this._gen&&t()},e)}cancel(){this._timer!==void 0&&(clearTimeout(this._timer),this._timer=void 0)}get pending(){return this._timer!==void 0}}});var De,an=j(()=>{"use strict";De=class{constructor(e){this.capacity=e;if(!Number.isInteger(e)||e<=0)throw new Error(`RingBuffer capacity must be a positive integer (got ${e})`);this.buf=new Array(e)}buf;head=0;_size=0;get size(){return this._size}get maxSize(){return this.capacity}push(e){let t=(this.head+this._size)%this.capacity;this.buf[t]=e,this._size<this.capacity?this._size++:this.head=(this.head+1)%this.capacity}shift(){if(this._size===0)return;let e=this.buf[this.head];return this.buf[this.head]=void 0,this.head=(this.head+1)%this.capacity,this._size--,e}at(e){if(this._size===0)return;let t=e<0?this._size+e:e;if(!(t<0||t>=this._size))return this.buf[(this.head+t)%this.capacity]}toArray(){let e=new Array(this._size);for(let t=0;t<this._size;t++)e[t]=this.buf[(this.head+t)%this.capacity];return e}clear(){for(let e=0;e<this._size;e++)this.buf[(this.head+e)%this.capacity]=void 0;this.head=0,this._size=0}}});var vr={};Sn(vr,{JobFlowGraph:()=>Ze,JobQueueGraph:()=>Xe,jobEventKeyOf:()=>br,jobFlow:()=>yr,jobQueue:()=>On});module.exports=Dn(vr);_e();$e();pe();Ne();se();vt();de();me();en();Ne();de();$e();pe();_e();Ne();se();vt();me();de();_e();function _t(r,e){if(Object.is(r,e))return!0;if(r==null||e==null||typeof r!="object"||typeof e!="object")return!1;if(Array.isArray(r)){if(!Array.isArray(e)||r.length!==e.length)return!1;for(let o=0;o<r.length;o++)if(!_t(r[o],e[o]))return!1;return!0}if(Array.isArray(e))return!1;let t=Object.keys(r),n=Object.keys(e);if(t.length!==n.length)return!1;let s=new Set(n);for(let o of t)if(!s.has(o)||!_t(r[o],e[o]))return!1;return!0}function tn(r,e){return`${r}\0${e}`}function wt(r,e){let t=[],n=new Set(r.subgraphs),s=new Set(e.subgraphs),o=[];for(let g of s)n.has(g)||o.push(g);o.sort();for(let g of o)t.push({type:"subgraph-mounted",path:g});let i=new Set(Object.keys(r.nodes)),a=new Set(Object.keys(e.nodes)),d=[];for(let g of a)i.has(g)||d.push(g);d.sort();for(let g of d)t.push({type:"node-added",path:g,node:{...e.nodes[g]}});let u=[];for(let g of a){if(!i.has(g))continue;let w=r.nodes[g]?.meta,y=e.nodes[g]?.meta;w==null&&y==null||_t(w??{},y??{})||u.push(g)}u.sort();for(let g of u)t.push({type:"node-meta-changed",path:g,prevMeta:r.nodes[g]?.meta??{},nextMeta:e.nodes[g]?.meta??{}});let c=new Map;for(let g of r.edges)c.set(tn(g.from,g.to),g);let p=new Map;for(let g of e.edges)p.set(tn(g.from,g.to),g);let f=[];for(let[g,w]of p)c.has(g)||f.push(w);f.sort((g,w)=>g.from<w.from?-1:g.from>w.from?1:g.to<w.to?-1:g.to>w.to?1:0);for(let g of f)t.push({type:"edge-added",from:g.from,to:g.to});let h=[];for(let[g,w]of c)p.has(g)||h.push(w);h.sort((g,w)=>g.from<w.from?-1:g.from>w.from?1:g.to<w.to?-1:g.to>w.to?1:0);for(let g of h)t.push({type:"edge-removed",from:g.from,to:g.to});let l=[];for(let g of i)a.has(g)||l.push(g);l.sort();for(let g of l)t.push({type:"node-removed",path:g});let v=[];for(let g of n)s.has(g)||v.push(g);v.sort();for(let g of v)t.push({type:"subgraph-unmounted",path:g});return{events:t,flushedAt_ns:K()}}xt();on();an();ct();function un(r,e,t,n={}){let s=e in r.nodes,o=t in r.nodes;if(!s)return qe(e,t,"no-such-from");if(!o)return qe(e,t,"no-such-to");let i=n.maxDepth;if(i!=null&&(!Number.isInteger(i)||i<0))throw new Error("explainPath: maxDepth must be an integer >= 0");if(e===t){if(n.findCycle===!0){let u=Yn(r,e,n);if(u!=null)return u}let d=We(e,r.nodes[e],0,n);return Ue(e,t,[d])}if(i===0)return qe(e,t,"no-path");let a=dn(r,e,t,i);return a.found?Ue(e,t,cn(r,a.pathOrder,n)):qe(e,t,a.truncated?"max-depth-exceeded":"no-path")}function dn(r,e,t,n){let s=new Map,o=[{path:t,depth:0}],i=new Set([t]),a=0,d=!1;for(;a<o.length;){let p=o[a++];if(p.path===e)break;if(n!=null&&p.depth>=n){let v=r.nodes[p.path];v?.deps&&v.deps.length>0&&(d=!0);continue}let f=r.nodes[p.path];if(f==null)continue;let h=f.deps??[],l=new Map;for(let v=0;v<h.length;v++){let g=h[v];if(!g)continue;let w=l.get(g);w==null&&(w=[],l.set(g,w)),w.push(v)}for(let[v,g]of l)i.has(v)||(i.add(v),s.set(v,{from:p.path,depIndices:g}),o.push({path:v,depth:p.depth+1}))}if(!s.has(e))return{found:!1,pathOrder:[],truncated:d};let u=[{path:e}],c=e;for(;c!==t;){let p=s.get(c);if(p==null)return{found:!1,pathOrder:[],truncated:!1};u[u.length-1].depIndices=p.depIndices,u.push({path:p.from}),c=p.from}return{found:!0,pathOrder:u,truncated:!1}}function Yn(r,e,t){let n=r.nodes[e];if(n==null)return null;let s=n.deps??[],o=[];for(let a=0;a<s.length;a++)s[a]===e&&o.push(a);if(o.length>0){let a=We(e,n,0,t);a.dep_index=o[0];let d=We(e,n,1,t);return Ue(e,e,[a,d])}let i=null;for(let a=0;a<s.length;a++){let d=s[a];if(!d||d===e)continue;let u=dn(r,d,e,t.maxDepth);u.found&&(i==null||u.pathOrder.length<i.pathOrder.length)&&(i=u,i={found:!0,pathOrder:[{path:e,depIndices:[a]},...u.pathOrder],truncated:!1})}return i==null?null:Ue(e,e,cn(r,i.pathOrder,t))}function cn(r,e,t){return e.map((n,s)=>{let o=r.nodes[n.path],i=We(n.path,o,s,t);return n.depIndices!=null&&n.depIndices.length>0&&(i.dep_index=n.depIndices[0],n.depIndices.length>1&&(i.dep_indices=[...n.depIndices])),i})}function We(r,e,t,n){let s={path:r,type:e.type,hop:t};e.status!==void 0&&(s.status=e.status),"value"in e&&(s.value=e.value),e.v!=null&&(s.v=e.v);let o=n.annotations?.get(r)??e.annotation;o!=null&&(s.annotation=o);let i=n.lastMutations?.get(r)??e.lastMutation;return i!=null&&(s.lastMutation=i),s}function Ue(r,e,t){return ln(r,e,!0,"ok",t)}function qe(r,e,t){return ln(r,e,!1,t,[])}function ln(r,e,t,n,s){let o=Qn(r,e,t,n,s);return{from:r,to:e,found:t,reason:n,steps:s,text:o,toJSON(){return{from:r,to:e,found:t,reason:n,steps:s}}}}function Qn(r,e,t,n,s){if(!t)switch(n){case"no-such-from":return`explainPath: no node named "${r}"`;case"no-such-to":return`explainPath: no node named "${e}"`;case"max-depth-exceeded":return`explainPath: no path from "${r}" to "${e}" within maxDepth`;default:return`explainPath: no path from "${r}" to "${e}"`}let o=[`Causal path: ${r} \u2192 ${e} (${s.length} step(s))`];for(let i of s){let d=` ${i.hop===0?"\xB7":"\u2193"} ${i.path} (${i.type}${i.status?`/${i.status}`:""})`;if(o.push(d),"value"in i&&o.push(` value: ${Xn(i.value)}`),i.annotation!=null&&o.push(` annotation: ${i.annotation}`),i.lastMutation!=null){let u=i.lastMutation.actor;o.push(` actor: ${u.type}${u.id?`:${u.id}`:""}`)}}return o.join(`
2
+ `)}function Xn(r){if(r===void 0)return"<sentinel>";if(r===null)return"null";if(typeof r=="string")return JSON.stringify(r);if(typeof r=="number"||typeof r=="boolean"||typeof r=="bigint")return String(r);try{let e=JSON.stringify(r);return e.length>80?`${e.slice(0,77)}...`:e}catch{return String(r)}}me();var I={object:56,array:64,string:40,number:8,boolean:4,null:0,undefined:0,symbol:40,bigint:16,function:120,map:72,set:72,mapEntry:40,setEntry:24,date:24,regexp:48,error:64,url:80,promise:48,weakmap:40,weakset:40},Zn=Symbol.for("sizeof");function fn(r){let e=new WeakSet,t=new WeakSet,n=[r],s=0;for(;n.length>0;){let o=n.pop();s+=er(o,e,t,n)}return s}function er(r,e,t,n){if(r==null)return 0;switch(typeof r){case"number":return I.number;case"boolean":return I.boolean;case"string":return I.string+r.length*2;case"bigint":return I.bigint+tr(r);case"symbol":return I.symbol;case"function":return e.has(r)?0:(e.add(r),I.function);case"undefined":return 0}let o=r;if(e.has(o))return 0;e.add(o);let i=o[Zn];if(typeof i=="function")try{let u=i.call(o);if(typeof u=="number"&&Number.isFinite(u))return u}catch{}if(o instanceof Date)return I.date;if(o instanceof RegExp)return I.regexp+o.source.length*2;if(o instanceof Error){let u=o.message?o.message.length*2:0,c=o.stack?o.stack.length*2:0;return I.error+u+c}if(typeof URL<"u"&&o instanceof URL)return I.url+o.href.length*2;if(typeof Promise<"u"&&o instanceof Promise)return I.promise;if(o instanceof WeakMap)return I.weakmap;if(o instanceof WeakSet)return I.weakset;if(o instanceof Map){let u=I.map;for(let[c,p]of o)u+=I.mapEntry,n.push(c),n.push(p);return u}if(o instanceof Set){let u=I.set;for(let c of o)u+=I.setEntry,n.push(c);return u}if(Array.isArray(o)){let u=I.array+o.length*8;for(let c of o)n.push(c);return u}if(o instanceof ArrayBuffer)return t.has(o)?0:(t.add(o),o.byteLength);if(ArrayBuffer.isView(o)){let u=o;return t.has(u.buffer)?48:(t.add(u.buffer),u.buffer.byteLength+48)}let a=I.object,d=Object.keys(o);for(let u of d){a+=I.string+u.length*2;try{n.push(o[u])}catch{}}return a}function tr(r){let e=r<0n?-r:r;if(e===0n)return 0;let t=e.toString(2).length;return Math.ceil(t/32)*8}function pn(r,e){let t=e?.topN??10,n=r.describe({detail:"standard"}),s=[],o=r._collectObserveTargets;typeof o=="function"&&o.call(r,"",s);let i=new Map;for(let[f,h]of s)i.set(f,h);let a=[];for(let[f,h]of Object.entries(n.nodes)){let l=i.get(f),v=l instanceof $?l:null,g=v?fn(v.cache):0,w=v?v._sinkCount:0,y=h.deps?.length??0,m=h.type==="effect"&&w===0,_=w===0?h.type==="effect"?"orphan-effect":h.type==="derived"?"idle-derived":h.type==="producer"?"idle-producer":null:null;a.push({path:f,type:h.type,status:h.status??"unknown",valueSizeBytes:g,subscriberCount:w,depCount:y,isOrphanEffect:m,orphanKind:_})}let d=a.reduce((f,h)=>f+h.valueSizeBytes,0),u=(f,h)=>[...a].sort(h??((l,v)=>v[f]-l[f])).slice(0,t),c=a.filter(f=>f.orphanKind!=null),p=a.filter(f=>f.isOrphanEffect);return{nodeCount:a.length,edgeCount:n.edges.length,subgraphCount:n.subgraphs.length,nodes:a,totalValueSizeBytes:d,hotspots:{byValueSize:u("valueSizeBytes"),bySubscriberCount:u("subscriberCount"),byDepCount:u("depCount")},orphans:c,orphanEffects:p}}var L="::",Z="__meta__",be=1;function hn(r,e){let t=Math.max(16,r.size*4),n=0;for(;r.size>0;){if(n++>=t){console.error(`[Graph "${e}".destroy] disposer drain exceeded cap (${t}); ${r.size} disposer(s) discarded`),r.clear();return}let s=r.values().next();if(s.done)return;let o=s.value;r.delete(o);try{o()}catch(i){console.error(`[Graph "${e}".destroy] disposer threw:`,i)}}}function vn(r){return r!=null&&typeof r=="object"&&"cache"in r&&typeof r.subscribe=="function"&&typeof r.down=="function"}function nr(r){if(r!=null)return vn(r)?r.cache:r}function ye(r){return r!=null&&typeof r=="object"&&"cache"in r&&typeof r.subscribe=="function"&&typeof r.down=="function"}function ce(r){return ye(r)?r.cache??"":r}function gn(r){return ye(r)?r.cache??0:r}function mn(r){return ye(r)?r.cache??!1:r}function rr(r){let e=[];for(let t of Object.keys(r).sort()){let n=r[t].v;n!=null&&e.push(`${t} ${n.id} ${n.version}`)}return e.join(`
3
+ `)}function bn(r){if(r.version!==be)throw new Error(`unsupported snapshot version ${String(r.version)} (expected ${be})`);for(let e of["name","nodes","edges","subgraphs"])if(!(e in r))throw new Error(`snapshot missing required key "${e}"`);if(typeof r.name!="string")throw new TypeError("snapshot 'name' must be a string");if(typeof r.nodes!="object"||r.nodes===null||Array.isArray(r.nodes))throw new TypeError("snapshot 'nodes' must be an object");if(!Array.isArray(r.edges))throw new TypeError("snapshot 'edges' must be an array");if(!Array.isArray(r.subgraphs))throw new TypeError("snapshot 'subgraphs' must be an array")}function sr(r,e){let t=new WeakMap,n=(s,o)=>{if(Object.is(s,o))return!0;if(s==null||o==null||typeof s!="object"||typeof o!="object")return!1;let i=t.get(s);if(i==null&&(i=new WeakSet,t.set(s,i)),i.has(o))return!0;i.add(o);let a=s.constructor,d=o.constructor;if(a!==d)return!1;if(s instanceof Date)return s.getTime()===o.getTime();if(s instanceof RegExp)return s.source===o.source&&s.flags===o.flags;if(Array.isArray(s)){let f=o;if(s.length!==f.length)return!1;for(let h=0;h<s.length;h++)if(!n(s[h],f[h]))return!1;return!0}if(s instanceof Map){let f=o;if(s.size!==f.size)return!1;for(let[h,l]of s)if(!f.has(h)||!n(l,f.get(h)))return!1;return!0}if(s instanceof Set){let f=o;if(s.size!==f.size)return!1;for(let h of s){let l=!1;for(let v of f)if(n(h,v)){l=!0;break}if(!l)return!1}return!0}if(ArrayBuffer.isView(s)){let f=s,h=o;if(f.length!==h.length)return!1;for(let l=0;l<f.length;l++)if(f[l]!==h[l])return!1;return!0}let u=Object.keys(s),c=Object.keys(o);if(u.length!==c.length)return!1;let p=new Set(c);for(let f of u)if(!p.has(f)||!n(s[f],o[f]))return!1;return!0};return n(r,e)}function or(r){return r.replace(/[.*+?^${}()|[\]\\]/g,"\\$&")}function Je(r){let e="^";for(let t=0;t<r.length;t+=1){let n=r[t];if(n==="*"){e+=".*";continue}if(n==="?"){e+=".";continue}if(n==="["){let s=r.indexOf("]",t+1);if(s<=t+1){e+="\\[";continue}let o=r.slice(t+1,s);o.startsWith("!")&&(o=`^${o.slice(1)}`),o=o.replace(/\\/g,"\\\\"),e+=`[${o}]`,t=s;continue}e+=or(n)}return e+="$",new RegExp(e)}var ir={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"},ar={data:"",dirty:"",resolved:"",invalidate:"",pause:"",resume:"",complete:"",error:"",teardown:"",derived:"",path:"",reset:""};function kt(r){if(typeof r=="string")return JSON.stringify(r);if(typeof r=="number"||typeof r=="boolean"||r==null)return String(r);try{return JSON.stringify(r)}catch{return"[unserializable]"}}function ur(r){return r==="none"?ar:r==="ansi"||r==null?ir:{data:r.data??"",dirty:r.dirty??"",resolved:r.resolved??"",invalidate:r.invalidate??"",pause:r.pause??"",resume:r.resume??"",complete:r.complete??"",error:r.error??"",teardown:r.teardown??"",derived:r.derived??"",path:r.path??"",reset:r.reset??""}}function yn(r){if(r==null)return{};let e=r.detail;return e==="full"?{...r,structured:r.structured??!0,timeline:r.timeline??!0,causal:r.causal??!0,derived:r.derived??!0}:e==="minimal"?{...r,structured:r.structured??!0}:r.format==="stage-log"?{...r,structured:r.structured??!0,timeline:r.timeline??!0}:r}function dr(r,e,t){for(let n=0;n<r.length;n++){let s=r.charCodeAt(n);if(s<32||s===127)throw new Error(`Graph "${e}": ${t} "${r}" must not contain control character (U+${s.toString(16).padStart(4,"0").toUpperCase()} at index ${n})`)}}function Nt(r,e,t){if(r==="")throw new Error(`Graph "${e}": ${t} name must be non-empty`);if(r.includes(L))throw new Error(`Graph "${e}": ${t} "${r}" must not contain '${L}' (path separator)`);if(r===Z)throw new Error(`Graph "${e}": ${t} name "${Z}" is reserved for meta companion paths`);dr(r,e,t)}function cr(r,e){if(r==="")throw new Error(`Graph "${e}": resolve path must be non-empty`);let t=r.split(L);for(let n of t)if(n==="")throw new Error(`Graph "${e}": resolve path has empty segment`);return t}function lr(r,e){let t=!1;for(let s of r)if(!e.isMetaPassthrough(s[0])){t=!0;break}return t?r.filter(s=>e.isMetaPassthrough(s[0])):r}function _n(r){for(let e of r._mounts.values())_n(e);for(let e of r._nodes.values())try{e.down([[z]],{internal:!0})}catch{}}var ve=class r{name;opts;config;_nodes=new Map;_nodeToName=new WeakMap;_mounts=new Map;_parent=void 0;_storageDisposers=new Set;_disposers=new Set;_destroyed=!1;_topology;_topologyEmitters=new Set;_factory;_factoryArgs;constructor(e,t){if(e==="")throw new Error("Graph name must be non-empty");if(e.includes(L))throw new Error(`Graph name must not contain '${L}' (got "${e}")`);if(e===Z)throw new Error(`Graph name "${Z}" is reserved for meta companion paths`);this.name=e,this.opts=Object.freeze({...t??{}}),this.config=t?.config??Oe,this._traceRing=new De(t?.traceCapacity??1e3),t?.versioning!=null&&this.setVersioning(t.versioning),typeof t?.factory=="string"&&(this._factory=t.factory,t.factoryArgs!==void 0&&(this._factoryArgs=t.factoryArgs))}tagFactory(e,t){return this._factory=e,this._factoryArgs=t,this}ancestors(e=!0){let t=[],n=e?this:this._parent;for(;n!=null;)t.push(n),n=n._parent;return t}get topology(){return this._topology==null&&(this._topology=ue(e=>{let t=n=>{e.emit(n)};return this._topologyEmitters.add(t),()=>{this._topologyEmitters.delete(t)}},{name:`${this.name}_topology`})),this._topology}_emitTopology(e){if(!(this._topology==null||this._topologyEmitters.size===0))for(let t of this._topologyEmitters)t(e)}nameOf(e){return this._nodeToName.get(e)}add(e,t){let n=e.name,s=t?.name??n;if(s==null||s==="")throw new Error(`Graph "${this.name}": graph.add requires a non-empty name \u2014 pass via opts.name or set it on the node (e.g. state(0, { name: "x" }))`);let o=s,i=t?.annotation;if(Nt(o,this.name,"add"),this._mounts.has(o))throw new Error(`Graph "${this.name}": name "${o}" is already a mount point`);if(this._nodes.has(o))throw new Error(`Graph "${this.name}": node "${o}" already exists`);let a=this._nodeToName.get(e);if(a!==void 0)throw new Error(`Graph "${this.name}": node instance already registered as "${a}"`);return this._nodes.set(o,e),this._nodeToName.set(e,o),this._emitTopology({kind:"added",name:o,nodeKind:"node"}),i!=null&&(this._annotations.set(o,i),this.config.inspectorEnabled&&this._traceRing.push({path:o,annotation:i,timestamp_ns:K()})),e}setVersioning(e){if(e!=null)for(let t of this._nodes.values())t instanceof $&&t._applyVersioning(e)}remove(e){Nt(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(`${L}${Z}${L}`)||o.nodes.push(a);return o.nodes.sort(),o.mounts.push(e),o.mounts.push(...t._collectSubgraphs(`${e}${L}`)),this._mounts.delete(e),t._parent=void 0,_n(t),this._emitTopology({kind:"removed",name:e,nodeKind:"mount",audit:o}),o}let n=this._nodes.get(e);if(!n)throw new Error(`Graph "${this.name}": unknown node or mount "${e}"`);this._nodes.delete(e),this._nodeToName.delete(n),n.down([[z]],{internal:!0});let s={kind:"node",nodes:[e],mounts:[]};return this._emitTopology({kind:"removed",name:e,nodeKind:"node",audit:s}),s}removeAll(e){let t=typeof e=="function"?e:(()=>{let o=Je(e);return i=>o.test(i)})(),n={kind:"mount",nodes:[],mounts:[]},s=[...this._nodes.keys(),...this._mounts.keys()].filter(o=>t(o));for(let o of s){let i=this.remove(o);n.nodes.push(...i.nodes),n.mounts.push(...i.mounts)}return n.nodes.sort(),n.mounts.sort(),n}[Symbol.iterator](){let e=[...this._nodes.keys()].sort(),t=this._nodes,n=0;return{[Symbol.iterator](){return this},next(){if(n>=e.length)return{value:void 0,done:!0};let s=e[n++];return{value:[s,t.get(s)],done:!1}}}}node(e){if(e==="")throw new Error(`Graph "${this.name}": node name must be non-empty`);if(e.includes(L))return this.resolve(e);let t=this._nodes.get(e);if(!t)throw new Error(`Graph "${this.name}": unknown node "${e}"`);return t}get(e){return this.node(e).cache}set(e,t,n){let s=n?.internal===!0;this.node(e).down([[D,t]],{actor:n?.actor,internal:s,delivery:"write"})}setAll(e,t){let n=Symbol.iterator in e?e:Object.entries(e);q(()=>{for(let[s,o]of n)this.set(s,o,t)})}invalidate(e,t){let n=t?.internal===!0;this.node(e).down([[Y]],{actor:t?.actor,internal:n,delivery:"write"})}error(e,t,n){let s=n?.internal===!0;this.node(e).down([[C,t]],{actor:n?.actor,internal:s,delivery:"write"})}complete(e,t){let n=t?.internal===!0;this.node(e).down([[F]],{actor:t?.actor,internal:n,delivery:"write"})}edges(e){let t=e?.recursive===!0,n=new Map;if(!t){for(let[d,u]of this._nodes)n.set(u,d);let a=[];for(let[d,u]of this._nodes)if(u instanceof $)for(let c of u._deps){let p=n.get(c.node);p!=null&&a.push([p,d])}return a.sort((d,u)=>d[0]<u[0]?-1:d[0]>u[0]?1:d[1]<u[1]?-1:d[1]>u[1]?1:0),a}let s=[];this._collectObserveTargets("",s);let o=new Map;for(let[a,d]of s)o.set(d,a);let i=[];for(let[a,d]of s)if(d instanceof $)for(let u of d._deps){let c=o.get(u.node);c!=null&&i.push([c,a])}return i.sort((a,d)=>a[0]<d[0]?-1:a[0]>d[0]?1:a[1]<d[1]?-1:a[1]>d[1]?1:0),i}mount(e,t){if(t===void 0){let s=new r(e);return this.mount(e,s)}if(typeof t=="function"){let s=new r(e);return t(s),this.mount(e,s)}let n=t;if(Nt(e,this.name,"mount"),this._nodes.has(e))throw new Error(`Graph "${this.name}": cannot mount at "${e}" \u2014 node with that name exists`);if(this._mounts.has(e))throw new Error(`Graph "${this.name}": mount "${e}" already exists`);if(n===this)throw new Error(`Graph "${this.name}": cannot mount a graph into itself`);if(n._parent!=null)throw new Error(`Graph "${this.name}": this child graph is already mounted on "${n._parent.name}"`);for(let s=this;s!=null;s=s._parent)if(s===n)throw new Error(`Graph "${this.name}": mount("${e}", \u2026) would create a mount cycle`);return this._mounts.set(e,n),n._parent=this,this._emitTopology({kind:"added",name:e,nodeKind:"mount"}),n}resolve(e){let t=cr(e,this.name);return this._resolveFromSegments(t)}tryResolve(e){try{return this.resolve(e)}catch{return}}_resolveFromSegments(e){let t=e;if(t[0]===this.name&&(t=t.slice(1),t.length===0))throw new Error(`Graph "${this.name}": resolve path ends at graph name only`);let n=t[0],s=t.slice(1);if(s.length===0){let a=this._nodes.get(n);if(a)return a;throw this._mounts.has(n)?new Error(`Graph "${this.name}": path ends at subgraph "${n}" \u2014 not a node (GRAPHREFLY-SPEC \xA73.5)`):new Error(`Graph "${this.name}": unknown name "${n}"`)}let o=this._nodes.get(n);if(o&&s.length>0&&s[0]===Z)return this._resolveMetaChainFromNode(o,s,t.join(L));let i=this._mounts.get(n);if(!i)throw this._nodes.has(n)?new Error(`Graph "${this.name}": "${n}" is a node; trailing path "${s.join(L)}" is invalid`):new Error(`Graph "${this.name}": unknown mount or node "${n}"`);return i.resolve(s.join(L))}_resolveMetaChainFromNode(e,t,n){let s=e,o=0,i=[...t];for(;o<i.length;){if(i[o]!==Z)throw new Error(`Graph "${this.name}": expected ${Z} segment in meta path "${n}"`);if(o+1>=i.length)throw new Error(`Graph "${this.name}": meta path requires a key after ${Z} in "${n}"`);let a=i[o+1],d=s.meta[a];if(!d)throw new Error(`Graph "${this.name}": unknown meta "${a}" in path "${n}"`);s=d,o+=2}return s}signal(e,t){if(t?.internal!==!0){for(let s of e)if(this.config.messageTier(s[0])===3)throw new Error(`Graph "${this.name}": Graph.signal() rejects tier-3 messages (DATA / RESOLVED). Broadcast is for control-plane tiers (START / DIRTY / INVALIDATE / PAUSE / RESUME / COMPLETE / ERROR / TEARDOWN). For per-node value writes, use Graph.set or graph.node(name).down(...).`)}let n=[];if(this._signalDeliver(e,t??{},new Set,n),n.length>0)throw n[0]}_signalDeliver(e,t,n,s){for(let d of this._mounts.values())d._signalDeliver(e,t,n,s);let i=t.internal===!0?{internal:!0}:{actor:t.actor,delivery:"signal"},a=lr(e,this.config);for(let d of[...this._nodes.keys()].sort()){let u=this._nodes.get(d);if(!n.has(u)){n.add(u);try{u.down(e,i)}catch(c){if(c instanceof Q)throw c;s.push(c)}a.length!==0&&this._signalMetaSubtree(u,a,n,i,s)}}}_signalMetaSubtree(e,t,n,s,o){for(let i of Object.keys(e.meta).sort()){let a=e.meta[i];if(!n.has(a)){n.add(a);try{a.down(t,s)}catch(d){if(d instanceof Q)throw d;o.push(d)}this._signalMetaSubtree(a,t,n,s,o)}}}describe(e){if(e?.reactive==="diff")return this._describeReactiveDiff(e);if(e?.reactive===!0)return this._describeReactive(e);let t=nr(e?.actor),n=e?.filter;if(e?.detail!=null&&e?.fields!=null)throw new TypeError("Graph.describe(): pass either `detail` or `fields`, not both. `detail: 'spec'` is the canonical spec projection; use `fields` only when you need a custom subset.");let s=He(e?.detail,e?.fields),o=e?.detail==="spec",i=s,a=[];this._collectObserveTargets("",a);let d=new Map;for(let[_,T]of a)d.set(T,_);let u=[];{let _=a.map(([,b])=>b),T=new Set(d.values()),O=0;for(;_.length>0;){let b=_.shift();if(b instanceof $)for(let x of b._deps){let N=x.node;if(d.has(N))continue;let E=N.name??"",k=E;if(!k||T.has(k))if(E){let A=2;for(;T.has(`${E}#${A}`);)A++;k=`${E}#${A}`}else for(k=`__internal__/${O++}`;T.has(k);)k=`__internal__/${O++}`;d.set(N,k),T.add(k),u.push([k,N]),_.push(N)}}}let c=[...a,...u],p={};for(let[_,T]of c){if(t!=null&&!T.allowsObserve(t))continue;let O=yt(T,i,o),b=T instanceof $?T._deps.map(k=>d.get(k.node)??k.node.name??""):[],{name:x,...N}=O,E={...N,deps:b};if(!o){let k=this._annotations.get(_);k!=null&&(E.annotation=k)}if(n!=null)if(typeof n=="function"){let k=n;if(!(k.length>=2?k(_,E):k(E)))continue}else{let k=!0;for(let[A,M]of Object.entries(n)){let S=A==="deps_includes"?"depsIncludes":A==="meta_has"?"metaHas":A;if(S==="depsIncludes"){if(!E.deps.includes(String(M))){k=!1;break}continue}if(S==="metaHas"){if(!Object.hasOwn(E.meta??{},String(M))){k=!1;break}continue}if(E[S]!==M){k=!1;break}}if(!k)continue}p[_]=E}let f=new Set(Object.keys(p)),h=[];for(let[_,T]of c)if(T instanceof $)for(let O of T._deps){let b=d.get(O.node);b!=null&&h.push([b,_])}h.sort((_,T)=>_[0]<T[0]?-1:_[0]>T[0]?1:_[1]<T[1]?-1:_[1]>T[1]?1:0);let l=h.map(([_,T])=>({from:_,to:T}));(t!=null||n!=null)&&(l=l.filter(_=>f.has(_.from)&&f.has(_.to)));let v=this._collectSubgraphs(""),g=t!=null||n!=null?v.filter(_=>{let T=`${_}${L}`;return[...f].some(O=>O===_||O.startsWith(T))}):v,w=this,y=e;return{name:this.name,nodes:p,edges:l,subgraphs:g,...this._factory!==void 0?{factory:this._factory}:{},...this._factoryArgs!==void 0?{factoryArgs:this._factoryArgs}:{},expand(_){let T={...y};return Array.isArray(_)?(T.fields=_,T.detail=void 0):(T.detail=_,T.fields=void 0),w.describe(T)}}}_collectSubgraphs(e){let t=[];for(let n of[...this._mounts.keys()].sort()){let s=e===""?n:`${e}${n}`;t.push(s),t.push(...this._mounts.get(n)._collectSubgraphs(`${s}${L}`))}return t}resourceProfile(e){return pn(this,e)}reachable(e,t,n={}){return n.withDetail===!0?Ot(this.describe(),e,t,{...n,withDetail:!0}):Ot(this.describe(),e,t,n)}explain(e,t,n){return n?.reactive===!0?this._explainReactive(e,t,n):this._explainStatic(ce(e),ce(t),{...n?.maxDepth!==void 0?{maxDepth:gn(n.maxDepth)}:{},...n?.findCycle!==void 0?{findCycle:mn(n.findCycle)}:{}})}_explainStatic(e,t,n){let s=this.describe({detail:"full"}),o=new Map(this._annotations),i=new Map;for(let[a,d]of Object.entries(s.nodes))d.lastMutation!=null&&i.set(a,d.lastMutation);return un(s,e,t,{...n?.maxDepth!=null?{maxDepth:n.maxDepth}:{},...n?.findCycle===!0?{findCycle:!0}:{},annotations:o,lastMutations:i})}_describeReactive(e){let t={...e,reactive:!1},n=e.reactiveName??"describe",s=0,o=B(s,{name:`${n}_version`}),i=this.observe({timeline:!0,structured:!0}),a=!1,d=!1,u=()=>{a||d||(a=!0,ke(()=>{a=!1,!d&&(s+=1,o.emit(s))}))},c=i.onEvent(y=>{let m=y.type;m!=="data"&&m!=="error"&&m!=="complete"&&m!=="teardown"||u()}),p=[],f=new WeakSet,h=y=>{if(f.has(y)||d)return;f.add(y);let m=y.topology.subscribe(_=>{for(let T of _){if(T[0]!==D)continue;let O=T[1];if(u(),O.kind==="added"&&O.nodeKind==="mount"){let b=y._mounts.get(O.name);b!=null&&h(b)}}});p.push(m);for(let _ of y._mounts.keys()){let T=y._mounts.get(_);T!=null&&h(T)}};h(this);let l,v=e.actor;vn(v)&&(l=v.subscribe(y=>{let m=!1,_=!1;for(let T of y){let O=T[0];O===D?m=!0:(O===F||O===C||O===z)&&(_=!0)}m&&u(),_&&(l?.(),l=void 0,u())}));let g;try{g=X([o],()=>this.describe(t),{name:n,describeKind:"derived",meta:{domain:"audit",kind:"describe"},equals:(y,m)=>y===m})}catch(y){c(),l?.();for(let m of p)m();throw i.dispose(),y}let w=ie(g);return{node:g,dispose(){d=!0,c(),l?.();for(let y of p)y();p.length=0,i.dispose(),w()}}}_describeReactiveDiff(e){let t={...e,reactive:!1},n=e.reactiveName??"describe-diff",s={name:this.name,nodes:{},edges:[],subgraphs:[]},o=this.describe(t),i=wt(s,o),a=B(i,{name:n,meta:{domain:"audit",kind:"describe-diff"},equals:(f,h)=>f===h}),d=this._describeReactive({...e,reactiveName:void 0}),u=!1,c=d.node.subscribe(f=>{if(!u)for(let h of f){if(h[0]!==D)continue;let l=h[1],v=wt(o,l);o=l,v.events.length!==0&&a.emit(v)}}),p=ie(a);return{node:a,dispose(){u=!0,c(),d.dispose(),a.down([[z,"describe-diff disposed"]]),p()}}}_explainReactive(e,t,n){let s=0,o=B(s,{name:"explain_version"}),i=this.observe({timeline:!0,structured:!0}),a=!1,d=!1,u=()=>{a||d||(a=!0,ke(()=>{a=!1,!d&&(s+=1,o.emit(s))}))},c=i.onEvent(y=>{let m=y.type;m!=="data"&&m!=="error"&&m!=="complete"&&m!=="teardown"||u()}),p=[];e!=null&&ye(e)&&p.push(e),t!=null&&ye(t)&&p.push(t),n?.maxDepth!=null&&ye(n.maxDepth)&&p.push(n.maxDepth),n?.findCycle!=null&&ye(n.findCycle)&&p.push(n.findCycle);let f=()=>{for(let y of p)if(y.cache===void 0)return!1;return!0},h=()=>{let y=ce(e),m=ce(t);return{from:y,to:m,found:!1,reason:"pending",steps:[],text:"(awaiting reactive args)",toJSON:()=>({from:y,to:m,found:!1,reason:"pending",steps:[]})}},l;try{l=X([o],()=>{if(!f())return h();let y=ce(e),m=ce(t),_={...n?.maxDepth!==void 0?{maxDepth:gn(n.maxDepth)}:{},...n?.findCycle!==void 0?{findCycle:mn(n.findCycle)}:{}};return this._explainStatic(y,m,_)},{name:n?.name??"explain",describeKind:"derived",meta:{domain:"audit",kind:"explain_path",from:ce(e),to:ce(t)},equals:(y,m)=>y.found===m.found&&y.reason===m.reason&&y.steps.length===m.steps.length&&fr(y.steps,m.steps)})}catch(y){throw c(),i.dispose(),y}let v=ie(l),g=[],w=y=>{let m;return m=y.subscribe(_=>{let T=!1,O=!1;for(let b of _){let x=b[0];x===D?T=!0:(x===F||x===C||x===z)&&(O=!0)}(T||O)&&u(),O&&m&&(m(),m=void 0)}),()=>{m&&(m(),m=void 0)}};for(let y of p)g.push(w(y));return{node:l,dispose(){d=!0,c();for(let y of g)y?.();g.length=0,i.dispose(),v()}}}_pathsMatching(e){let t=Je(e),n=[];return this._collectObserveTargets("",n),n.map(([s])=>s).filter(s=>t.test(s))}_collectObserveTargets(e,t){for(let n of[...this._mounts.keys()].sort()){let s=e===""?n:`${e}${L}${n}`;this._mounts.get(n)._collectObserveTargets(s,t)}for(let n of[...this._nodes.keys()].sort()){let s=this._nodes.get(n),o=e===""?n:`${e}${L}${n}`;t.push([o,s]),this._appendMetaObserveTargets(o,s,t)}}_appendMetaObserveTargets(e,t,n){for(let s of Object.keys(t.meta).sort()){let o=t.meta[s],i=`${e}${L}${Z}${L}${s}`;n.push([i,o]),this._appendMetaObserveTargets(i,o,n)}}observe(e,t){let n=typeof e=="string",o=yn(n?t:e);if(o.reactive===!0)return this._observeReactive(n?e:void 0,o);let i=o.structured===!0||o.timeline===!0||o.causal===!0||o.derived===!0||o.detail==="minimal"||o.detail==="full"||o.format!=null,a=o.actor;if(n){let c=e,p=this.resolve(c);if(a!=null&&!p.allowsObserve(a))throw new Q({actor:a,action:"observe",nodeName:c});return i?this._buildStructuredObserver([[c,p]],o,"one"):{subscribe(f){return p.subscribe(f)},up(f){try{p.up?.(f)}catch(h){if(h instanceof Q)return;throw h}}}}let d=[];this._collectObserveTargets("",d),d.sort((c,p)=>c[0]<p[0]?-1:c[0]>p[0]?1:0);let u=a==null?d:d.filter(([,c])=>c.allowsObserve(a));return i?this._buildStructuredObserver(u,o,"all"):{subscribe:c=>{let p=u.map(([f,h])=>h.subscribe(l=>{c(f,l)}));return()=>{for(let f of p)f()}},up:(c,p)=>{try{this.resolve(c).up?.(p)}catch(f){if(f instanceof Q)return;throw f}}}}_observeReactive(e,t){let n=t.tiers,s=n!=null?new Set(n):null,o=t.reactiveName??"observe";return ue(i=>{let a=[],d=!1,u=!1,c=()=>{if(a.length===0||u)return;let v={events:a.slice(),flushedAt_ns:K()};a.length=0,i.emit(v)},p={...t,reactive:!1,structured:!0,timeline:!0},f=e!=null?this.observe(e,p):this.observe(p),h=v=>{u||(a.push(v),!d&&(d=!0,ke(()=>{d=!1,c()})))};for(let v of f.events)h(v);let l=f.onEvent(h);return()=>{u=!0,l(),f.dispose()}},{name:o,meta:{domain:"audit",kind:"observe-reactive"}})}_buildStructuredObserver(e,t,n){let s=n==="one"?e[0]?.[0]:void 0,o=i=>{if(n==="one"&&s!=null){let c=this.resolve(s);return this._buildStructuredObserver([[s,c]],i,"one")}let a=[];this._collectObserveTargets("",a),a.sort((c,p)=>c[0]<p[0]?-1:c[0]>p[0]?1:0);let d=i.actor,u=d==null?a:a.filter(([,c])=>c.allowsObserve(d));return this._buildStructuredObserver(u,i,"all")};return this._createObserveResult(e,t,o)}_createObserveResult(e,t,n){let s=t.timeline===!0,o=t.causal===!0,i=t.derived===!0,a=t.detail==="minimal",d=this.config.inspectorEnabled,u=(o||i)&&d,c=t.maxEvents,p=c!=null&&c>0?new De(c):null,f=[],h=new Set,l=t.tiers!=null?new Set(t.tiers):null,v={},g=new Set,w=0,y=0,m=0,_=0,T=0,O=0,b=!1,x=!1,N=0,E=new Map,k=new Map,A=new Map,M=R=>{if(!(l!=null&&!l.has(R.type))){p?p.push(R):f.push(R);for(let P of h)P(R)}},S=R=>l==null||l.has(R),ae=()=>s?{timestamp_ns:K(),in_batch:Se(),batch_id:N}:{},ne=(R,P)=>{if(!(!u||!(R instanceof $)))return R._setInspectorHook(U=>{if(U.kind==="dep_message")E.set(R,U.depIndex);else if(U.kind==="run"){let Ee=U.batchData.map((G,H)=>G!=null&&G.length>0?G.at(-1):U.prevData[H]);k.set(R,Ee);let J=U.batchData.map(G=>G!=null?[...G]:void 0);A.set(R,J),i&&M({type:"derived",path:P,dep_values:Ee,dep_batches:J,...ae()})}})},Ge=R=>{let P=E.get(R),U=k.get(R);if(!o||U==null)return{};let J=(P!=null&&P>=0&&R instanceof $?R._deps[P]:void 0)?.node,G=J?.v,H=A.get(R);return{trigger_dep_index:P,trigger_dep_name:J?.name,...G!=null?{trigger_version:{id:G.id,version:G.version}}:{},dep_values:[...U],...H!=null?{dep_batches:H}:{}}},Mt=[],Dt=[];for(let[R,P]of e){let U=ne(P,R);U&&Mt.push(U),Dt.push(P.subscribe(Ee=>{N++;for(let J of Ee){let G=J[0],H=ae();if(G===D){v[R]=J[1];let rt=P instanceof $?P.lastMutation?.actor??we:we;M({type:"data",path:R,data:J[1],actor:rt,...H,...Ge(P)})}else if(a)G===V?S("dirty")&&w++:G===W?S("resolved")&&y++:G===Y?S("invalidate")&&m++:G===te?S("pause")&&_++:G===re?S("resume")&&T++:G===z?S("teardown")&&O++:G===F&&!g.has(R)?S("complete")&&(b=!0):G===C&&S("error")&&(x=!0,g.add(R));else if(G===V)S("dirty")&&w++,M({type:"dirty",path:R,...H});else if(G===W)S("resolved")&&y++,M({type:"resolved",path:R,...H,...Ge(P)});else if(G===Y)S("invalidate")&&m++,M({type:"invalidate",path:R,...H});else if(G===te)S("pause")&&_++,M({type:"pause",path:R,lockId:J[1],...H});else if(G===re)S("resume")&&T++,M({type:"resume",path:R,lockId:J[1],...H});else if(G===F)S("complete")&&!g.has(R)&&(b=!0),M({type:"complete",path:R,...H});else if(G===C){S("error")&&(x=!0,g.add(R));let rt=P instanceof $?P.lastMutation?.actor??we:we;M({type:"error",path:R,data:J[1],actor:rt,...H})}else G===z&&(S("teardown")&&O++,M({type:"teardown",path:R,...H}))}}))}let et=!1,tt=()=>{if(!et){et=!0;for(let R of Dt)R();for(let R of Mt)R();for(let R of Pe)R({value:void 0,done:!0});Pe.length=0}},nt=[],Pe=[];h.add(R=>{let P=Pe.shift();P?P({value:R,done:!1}):nt.push(R)});let Ct={get values(){return v},get dirtyCount(){return w},get resolvedCount(){return y},get invalidateCount(){return m},get pauseCount(){return _},get resumeCount(){return T},get teardownCount(){return O},get events(){return p?p.toArray():[...f]},get anyCompletedCleanly(){return b},get anyErrored(){return x},get completedWithoutErrors(){return b&&!x},onEvent(R){return h.add(R),()=>h.delete(R)},dispose:tt,expand(R){tt();let P={...t};return typeof R=="string"?P.detail=R:Object.assign(P,R),n(yn(P))},[Symbol.asyncIterator](){return{next(){return nt.length>0?Promise.resolve({value:nt.shift(),done:!1}):et?Promise.resolve({value:void 0,done:!0}):new Promise(R=>Pe.push(R))},return(){return tt(),Promise.resolve({value:void 0,done:!0})}}}};return t.format!=null&&this._attachFormatLogger(Ct,t),Ct}_attachFormatLogger(e,t){let n=t.format;if(n==null)return;let s=t.logger??(l=>console.log(l)),o=t.includeTypes?new Set(t.includeTypes):null,i=t.excludeTypes?new Set(t.excludeTypes):null,a=o==null&&i==null?()=>!0:l=>(o==null||o.has(l))&&(i==null||!i.has(l)),d=ur(t.theme),u=n==="stage-log"?K():0,c=l=>l==null?"":t.stageLabels?.[l]??l,p=(l,v)=>l.length>v?`${l.slice(0,v-1)}\u2026`:l,f=l=>l.type==="data"||l.type==="error"?p(kt(l.data),120):"",h=l=>{if(n==="stage-log"){let b=(K()-u)/1e9,x=c(l.path).padEnd(9);if(l.type==="data"){let N=f(l);return`[${b.toFixed(3)}s] ${x} \u2190${N?` ${N}`:""}`}if(l.type==="error"){let N=f(l);return`[${b.toFixed(3)}s] ${x} \u2717${N?` ${N}`:""}`}return l.type==="complete"?`[${b.toFixed(3)}s] ${x} \u25A0 complete`:`[${b.toFixed(3)}s] ${x} ${l.type}`}if(n==="json")try{return JSON.stringify(l)}catch{return JSON.stringify({type:l.type,path:l.path,data:"[unserializable]"})}let v=d[l.type]??"",g=l.path?`${d.path}${l.path}${d.reset} `:"",w=l.type==="data"||l.type==="error",y=l.type==="pause"||l.type==="resume",m=w?` ${kt(l.data)}`:y?` ${kt(l.lockId)}`:"",_=l.type==="data"||l.type==="resolved"||l.type==="derived"?l:void 0,T=_?.trigger_dep_name!=null?` <- ${_.trigger_dep_name}`:_?.trigger_dep_index!=null?` <- #${_.trigger_dep_index}`:"",O=l.in_batch?" [batch]":"";return`${g}${v}${l.type.toUpperCase()}${d.reset}${m}${T}${O}`};e.onEvent(l=>{a(l.type)&&s(h(l),l)})}addDisposer(e){return this._disposers.add(e),()=>{this._disposers.delete(e)}}destroy(){hn(this._disposers,this.name),this.signal([[z]],{internal:!0}),hn(this._storageDisposers,this.name);for(let e of[...this._mounts.values()])e._parent=void 0,e._destroyClearOnly();this._mounts.clear(),this._nodes.clear(),this._parent=void 0,this._destroyed=!0}get destroyed(){return this._destroyed}_destroyClearOnly(){for(let e of[...this._mounts.values()])e._parent=void 0,e._destroyClearOnly();this._mounts.clear(),this._nodes.clear(),this._parent=void 0,this._destroyed=!0}snapshot(e){let{expand:t,...n}=this.describe({detail:"full"}),s={};for(let a of Object.keys(n.nodes).sort()){let{lastMutation:d,guard:u,...c}=n.nodes[a];s[a]=c}let o=[...n.subgraphs].sort(),i={...n,version:1,nodes:s,subgraphs:o};if(e?.format==null)return i;if(e.format==="json-string")return JSON.stringify(i);if(e.format==="bytes"){if(e.codec==null)throw new Error("snapshot({format: 'bytes'}) requires a `codec` name");let a=this.config.lookupCodec(e.codec);if(a==null)throw new Error(`snapshot: codec "${e.codec}" is not registered on this graph's config. Call config.registerCodec(...) before creating nodes.`);return Bt(a,a.encode(i))}throw new Error(`snapshot: unknown format "${String(e.format)}"`)}static decode(e,t){let n=t?.config??Oe,{codec:s,codecVersion:o,payload:i}=Ht(e,n);return s.decode(i,o)}restore(e,t){if(bn(e),e.name!==this.name)throw new Error(`Graph "${this.name}": restore snapshot name "${e.name}" does not match this graph`);let n=t?.only==null?null:(Array.isArray(t.only)?t.only:[t.only]).map(o=>Je(o)),s=t?.includeProducers===!0;for(let o of Object.keys(e.nodes).sort()){if(n!==null&&!n.some(a=>a.test(o)))continue;let i=e.nodes[o];if(i!==void 0){if(!("value"in i)||i.value===void 0){"value"in i&&i.value===void 0&&t?.onError?.(o,new Error(`restore: slice.value is undefined for "${o}" (undefined is the global SENTINEL; not valid DATA)`));continue}if(!(i.type==="derived"||i.type==="effect")&&!(i.type==="producer"&&!s)){if(i.v!=null){let d=this.tryResolve(o)?.v;if(d!=null&&d.id===i.v.id&&d.version===i.v.version)continue}try{this.set(o,i.value)}catch(a){t?.onError?.(o,a)}}}}}static fromSnapshot(e,t){bn(e);let n=typeof t=="function"?t:t?.build,s=typeof t=="function"?void 0:t?.factories,o=new r(e.name);if(n)return n(o),o.restore(e),o;for(let h of[...e.subgraphs].sort((l,v)=>{let g=l.split(L).length,w=v.split(L).length;return g!==w?g-w:l<v?-1:l>v?1:0})){let l=h.split(L),v=o;for(let g of l)v._mounts.has(g)||v.mount(g,new r(g)),v=v._mounts.get(g)}let i=s?Object.entries(s).map(([h,l])=>({re:Je(h),factory:l})):[],a=h=>{for(let l of i)if(l.re.test(h))return l.factory},d=h=>{let l=h.split(L),v=l.pop();if(v==null||v.length===0)throw new Error(`invalid snapshot path "${h}"`);let g=o;for(let w of l){let y=g._mounts.get(w);if(!y)throw new Error(`unknown mount "${w}" in path "${h}"`);g=y}return[g,v]},u=Object.entries(e.nodes).filter(([h])=>!h.includes(`${L}${Z}${L}`)).sort((h,l)=>h[0]<l[0]?-1:h[0]>l[0]?1:0),c=new Map(u),p=new Map,f=!0;for(;c.size>0&&f;){f=!1;for(let[h,l]of[...c.entries()]){let v=l?.deps??[];if(!v.every(T=>p.has(T)))continue;let[g,w]=d(h),y={...l?.meta??{}},m=a(h),_;if(l?.type==="state")_=B(l.value,{meta:y});else{if(m==null)continue;_=m(w,{path:h,type:l.type,value:l.value,meta:y,deps:v,resolvedDeps:v.map(T=>p.get(T))})}g.add(_,{name:w}),p.set(h,_),c.delete(h),f=!0}}if(c.size>0){let h=[...c.keys()].sort().join(", ");throw new Error(`Graph.fromSnapshot could not reconstruct nodes without build callback: ${h}. Pass matching factories via fromSnapshot(data, { factories: { pattern: factoryFn } }).`)}return o.restore(e),o}toJSON(){return this.snapshot()}attachSnapshotStorage(e,t={}){let n=e.map(u=>({tier:u,debounceMs:Math.max(0,u.debounceMs??0),compactEvery:Math.max(1,u.compactEvery??10),timer:void 0,seq:0,lastSnapshot:void 0,lastFingerprint:"",disposed:!1,savePending:void 0}));t.autoRestore===!0&&this._cascadeRestore(e,t.onError);let s=(u,c)=>{if(u.disposed)return;let p=rr(c.nodes);if(u.lastSnapshot!=null&&p!==""&&p===u.lastFingerprint)return;let f=u.seq+1,h=ee(),g=u.lastSnapshot==null||f%u.compactEvery===0?{name:this.name,mode:"full",snapshot:c,seq:f,timestamp_ns:h,format_version:be}:{name:this.name,mode:"diff",diff:wn(u.lastSnapshot,c),seq:f,timestamp_ns:h,format_version:be};if(u.tier.filter&&!u.tier.filter(g))return;let w;try{w=u.tier.save(g)}catch(y){t.onError?.(y,u.tier);return}if(w&&typeof w.then=="function"){let _=(u.savePending??Promise.resolve()).then(()=>w,()=>w).then(()=>{u.disposed||(u.seq=f,u.lastSnapshot=c,u.lastFingerprint=p)},T=>{t.onError?.(T,u.tier)});u.savePending=_.finally(()=>{u.savePending===_&&(u.savePending=void 0)})}else u.seq=f,u.lastSnapshot=c,u.lastFingerprint=p},o=(u,c)=>{try{s(u,c)}catch(p){t.onError?.(p,u.tier)}},i=(u,c)=>{if(!c.some(l=>{let v=this.config.messageTier(l[0]);return v>=3&&v<5}))return;if(t.filter){let l=this.tryResolve(u);if(l==null)return;let v=yt(l,He("standard"));if(!t.filter(u,v))return}let f,h=()=>(f==null&&(f=this.snapshot()),f);for(let l of n)l.disposed||(l.debounceMs===0?o(l,h()):(l.timer==null&&(l.timer=new Ke),l.timer.start(l.debounceMs,()=>{l.disposed||o(l,this.snapshot())})))},a;if(t.paths!=null){let c=(typeof t.paths=="string"?this._pathsMatching(t.paths):t.paths).map(p=>{let f=this.tryResolve(p);return f==null?()=>{}:f.subscribe(h=>i(p,h))});a=()=>{for(let p of c)p()}}else a=this.observe().subscribe((u,c)=>i(u,c));let d=()=>{a();for(let u of n)u.disposed=!0,u.timer?.cancel();this._storageDisposers.delete(d)};return this._storageDisposers.add(d),{dispose:d}}async _cascadeRestore(e,t){for(let n of e){let s;try{s=await n.load?.()}catch(i){t?.(i,n);continue}if(s==null||typeof s!="object"||Array.isArray(s))continue;let o=s;try{if(o.mode==="full"&&o.snapshot!=null)return this.restore(o.snapshot),!0;if(o.version===be&&o.nodes!=null)return this.restore(o),!0}catch(i){t?.(i,n)}}return!1}static async fromStorage(e,t,n){for(let s of t){let o;try{o=await s.load?.()}catch(d){n?.onError?.(d,s);continue}if(o==null||typeof o!="object"||Array.isArray(o))continue;let i=o,a=i.mode==="full"&&i.snapshot!=null?i.snapshot:i.version===be&&i.nodes!=null?i:void 0;if(a!=null)try{return r.fromSnapshot(a,n)}catch(d){n?.onError?.(d,s)}}throw new Error(`Graph.fromStorage: no tier held a restorable record for "${e}" across ${t.length} tier(s)`)}_annotations=new Map;_traceRing;trace(e,t,n){if(e!=null&&t!=null){if(this.tryResolve(e)==null)return;if(this._annotations.set(e,t),this.config.inspectorEnabled){let s={path:e,annotation:t,timestamp_ns:K(),...n?.actor!=null?{actor:n.actor}:{}};this._traceRing.push(s)}return}return e!=null?this.config.inspectorEnabled?this._annotations.get(e):void 0:this.config.inspectorEnabled?this._traceRing.toArray():[]}annotation(e){return this._annotations.get(e)}clearTrace(){this._annotations.clear(),this._traceRing.clear()}pruneTrace(e){let t=this._traceRing.toArray().filter(s=>!e(s)),n=this._traceRing.size-t.length;this._traceRing.clear();for(let s of t)this._traceRing.push(s);return n}static diff(e,t){let n=new Set(Object.keys(e.nodes)),s=new Set(Object.keys(t.nodes)),o=[...s].filter(y=>!n.has(y)).sort(),i=[...n].filter(y=>!s.has(y)).sort(),a=[],d=[];for(let y of n){if(!s.has(y))continue;let m=e.nodes[y],_=t.nodes[y],T=m.v,O=_.v;T!=null&&O!=null&&T.id===O.id&&T.version!==O.version&&d.push({path:y,id:T.id,from:T.version,to:O.version});let b=T!=null&&O!=null&&T.id===O.id&&T.version===O.version;for(let x of["type","status","sentinel"]){let N=m[x],E=_[x];N!==E&&a.push({path:y,field:x,from:N,to:E})}if(!b)for(let x of["value","meta"]){let N=m[x],E=_[x];sr(N,E)||a.push({path:y,field:x,from:N,to:E})}}let u=y=>`${y.from} ${y.to}`,c=new Set(e.edges.map(u)),p=new Set(t.edges.map(u)),f=t.edges.filter(y=>!c.has(u(y))),h=e.edges.filter(y=>!p.has(u(y))),l=new Set(e.subgraphs),v=new Set(t.subgraphs),g=[...v].filter(y=>!l.has(y)).sort(),w=[...l].filter(y=>!v.has(y)).sort();return{nodesAdded:o,nodesRemoved:i,nodesChanged:a,versionChanges:d,edgesAdded:f,edgesRemoved:h,subgraphsAdded:g,subgraphsRemoved:w}}};function wn(r,e){let t=ve.diff(r,e),n={};for(let s of t.nodesAdded){let o=e.nodes[s];o!=null&&(n[s]=o)}return{...t,nodesAddedFull:n}}function Ot(r,e,t,n={}){let s={paths:[],depths:new Map,truncated:!1};if(!e)return n.withDetail?s:[];if(!n.both&&t!=="upstream"&&t!=="downstream")throw new Error('reachable: direction must be "upstream" or "downstream"');let o=n.maxDepth;if(o!=null&&(!Number.isInteger(o)||o<0))throw new Error("reachable: maxDepth must be an integer >= 0");if(o===0)return n.withDetail?s:[];let i=new Map,a=new Map,d=new Map,u=new Map,c=new Set;for(let[m,_]of Object.entries(r.nodes)){if(!m)continue;c.add(m);let T=_.deps??[];i.set(m,T);for(let O of T)O&&(c.add(O),a.has(O)||a.set(O,new Set),a.get(O).add(m))}for(let m of r.edges){if(m==null||typeof m!="object")continue;let _=typeof m.from=="string"?m.from:"",T=typeof m.to=="string"?m.to:"";!_||!T||(c.add(_),c.add(T),u.has(_)||u.set(_,new Set),u.get(_).add(T),d.has(T)||d.set(T,new Set),d.get(T).add(_))}if(!c.has(e))return n.withDetail?s:[];let p=n.both===!0,f=m=>{if(p){let b=i.get(m)??[],x=d.get(m),N=a.get(m),E=u.get(m),k=[...b];return x&&k.push(...x),N&&k.push(...N),E&&k.push(...E),k}if(t==="upstream"){let b=i.get(m)??[],x=d.get(m);return x?[...b,...x]:b}let _=a.get(m),T=u.get(m),O=_?[..._]:[];return T&&O.push(...T),O},h=new Set([e]),l=new Map,v=[{path:e,depth:0}],g=0,w=!1;for(;g<v.length;){let m=v[g++];if(o!=null&&m.depth>=o){f(m.path).length>0&&(w=!0);continue}for(let _ of f(m.path))!_||h.has(_)||(h.add(_),l.set(_,m.depth+1),v.push({path:_,depth:m.depth+1}))}let y=[...l.keys()].sort((m,_)=>m<_?-1:m>_?1:0);return n.withDetail?{paths:y,depths:l,truncated:w}:y}function fr(r,e){if(r.length!==e.length)return!1;for(let t=0;t<r.length;t++){let n=r[t],s=e[t];if(n.path!==s.path||n.type!==s.type||n.status!==s.status||n.hop!==s.hop||n.dep_index!==s.dep_index||n.annotation!==s.annotation||n.value!==s.value||n.lastMutation!==s.lastMutation)return!1;let o=n.v,i=s.v;if(o!==i&&(o==null||i==null||o.id!==i.id||o.version!==i.version))return!1}return!0}pe();se();me();de();var Et=class{_version=0;_maxSize;_buf;_head=0;_size=0;constructor(e,t){if(t!==void 0&&t<1)throw new RangeError("maxSize must be >= 1");if(this._maxSize=t,t!==void 0){if(this._buf=new Array(t),e&&e.length>0){let n=Math.min(e.length,t),s=e.length-n;for(let o=0;o<n;o++)this._buf[o]=e[s+o];this._size=n}}else this._buf=e?[...e]:[],this._size=this._buf.length}get version(){return this._version}get size(){return this._size}at(e){if(!Number.isInteger(e))return;let t=e>=0?e:this._size+e;if(!(t<0||t>=this._size))return this._maxSize!==void 0?this._buf[(this._head+t)%this._maxSize]:this._buf[t]}append(e){this._rawAppend(e),this._version+=1}appendMany(e){if(e.length===0)return;let t=this._maxSize!==void 0&&e.length>this._maxSize?e.length-this._maxSize:0;for(let n=t;n<e.length;n++)this._rawAppend(e[n]);this._version+=1}clear(){if(this._size===0)return 0;let e=this._size;if(this._maxSize===void 0)this._buf.length=0;else for(let t=0;t<e;t++)this._buf[(this._head+t)%this._maxSize]=void 0;return this._head=0,this._size=0,this._version+=1,e}trimHead(e){if(!Number.isInteger(e)||e<0)throw new RangeError(`trimHead: n must be a non-negative integer (got ${e})`);if(e===0||this._size===0)return 0;let t=Math.min(e,this._size);if(this._maxSize===void 0)this._buf.splice(0,t);else{for(let n=0;n<t;n++)this._buf[(this._head+n)%this._maxSize]=void 0;this._head=(this._head+t)%this._maxSize}return this._size-=t,this._version+=1,t}slice(e,t){if(!Number.isInteger(e)||e<0)throw new RangeError(`slice: start must be a non-negative integer (got ${e})`);if(t!==void 0&&(!Number.isInteger(t)||t<0))throw new RangeError(`slice: stop must be a non-negative integer or undefined (got ${t})`);let n=t===void 0?this._size:Math.min(Math.max(t,0),this._size),s=Math.min(e,this._size);if(s>=n)return[];let o=n-s;if(this._maxSize===void 0)return this._buf.slice(s,n);let i=new Array(o);for(let a=0;a<o;a++)i[a]=this._buf[(this._head+s+a)%this._maxSize];return i}tail(e){if(!Number.isInteger(e)||e<0)throw new RangeError(`tail: n must be a non-negative integer (got ${e})`);if(e===0||this._size===0)return[];let t=Math.min(e,this._size);return this.slice(this._size-t,this._size)}toArray(){if(this._maxSize===void 0)return[...this._buf];let e=new Array(this._size);for(let t=0;t<this._size;t++)e[t]=this._buf[(this._head+t)%this._maxSize];return e}snapshot(){return this.toArray()}restore(e){if(this._maxSize===void 0){this._buf.length=0;for(let t=0;t<e.length;t++)this._buf.push(e[t]);this._size=this._buf.length}else{let t=this._maxSize;for(let o=0;o<t;o++)this._buf[o]=void 0;this._head=0;let n=Math.min(e.length,t),s=e.length-n;for(let o=0;o<n;o++)this._buf[o]=e[s+o];this._size=n}this._version+=1}_rawAppend(e){if(this._maxSize===void 0){this._buf.push(e),this._size=this._buf.length;return}this._size<this._maxSize?(this._buf[(this._head+this._size)%this._maxSize]=e,this._size+=1):(this._buf[this._head]=e,this._head=(this._head+1)%this._maxSize)}};function Ce(r){return r.subscribe(()=>{})}var pr=64;function Ye(r,e={}){let{name:t,maxSize:n,versioning:s,guard:o,backend:i}=e,a=i??new Et(r,n),d=B(a.toArray(),{name:t,describeKind:"state",equals:(b,x)=>b===x,...s!=null?{versioning:s}:{},...o!=null?{guard:o}:{}});function u(){let b=a.toArray();q(()=>{d.down([[V]],{internal:!0}),d.down([[D,b]],{internal:!0})})}let c=new Map,p=new Map,f=new Map;function h(b,x){return`${b}:${x===void 0?"END":x}`}function l(b){if(b.size<pr)return;let x=b.keys().next();if(x.done)return;let N=b.get(x.value);N!==void 0&&N.dispose(),b.delete(x.value)}function v(b){let x=a.version;try{return b()}finally{a.version!==x&&u()}}function g(b){if(!Number.isInteger(b)||b<0)throw new RangeError(`tail: n must be a non-negative integer (got ${b})`);let x=c.get(b);if(x!==void 0)return c.delete(b),c.set(b,x),x.node;l(c);let N=X([d],([k])=>{let A=k;return b===0||A.length===0?[]:A.slice(Math.max(0,A.length-b))},{initial:a.tail(b),describeKind:"derived"}),E=Ce(N);return c.set(b,{node:N,dispose:E}),N}function w(b,x){if(!Number.isInteger(b)||b<0)throw new RangeError(`slice: start must be a non-negative integer (got ${b})`);if(x!==void 0&&(!Number.isInteger(x)||x<0))throw new RangeError(`slice: stop must be a non-negative integer or undefined (got ${x})`);let N=h(b,x),E=p.get(N);if(E!==void 0)return p.delete(N),p.set(N,E),E.node;l(p);let k=X([d],([M])=>{let S=M;return x===void 0?S.slice(b):S.slice(b,x)},{initial:a.slice(b,x),describeKind:"derived"}),A=Ce(k);return p.set(N,{node:k,dispose:A}),k}function y(b){let x=f.get(b);if(x!==void 0)return x.node;let N=X([d,b],([k,A])=>{let M=k,S=Math.max(0,Math.trunc(A??0));return M.slice(S)},{initial:[],describeKind:"derived"}),E=Ce(N);return f.set(b,{node:N,dispose:E}),N}let m,_;function T(){m===void 0&&(m=oe([d],(b,x,N)=>{let E=b[0],A=E!=null&&E.length>0?E.at(-1):N.prevData[0];if(A==null||A.length===0){x.down([[W]]);return}x.emit(A[A.length-1])},{name:t!=null?`${t}::lastValue`:"lastValue",describeKind:"derived",initial:a.size===0?void 0:a.at(a.size-1)}),_=X([d],([b])=>b.length>0,{name:t!=null?`${t}::hasLatest`:"hasLatest",describeKind:"derived",initial:a.size>0}),Ce(m),Ce(_))}let O={entries:d,get size(){return a.size},at(b){return a.at(b)},append(b){v(()=>a.append(b))},appendMany(b){b.length!==0&&v(()=>a.appendMany(b))},clear(){v(()=>a.clear())},trimHead(b){v(()=>a.trimHead(b))},withLatest(){return T(),d},get lastValue(){return T(),m},get hasLatest(){return T(),_},view(b){switch(b.kind){case"tail":return g(b.n);case"slice":return w(b.start,b.stop);case"fromCursor":return y(b.cursor)}},attach(b){let x=b.subscribe(N=>{for(let E of N)E[0]===D&&O.append(E[1])});return()=>x()},attachStorage(b){if(b.length===0)return()=>{};let x=new Map;for(let E of b)x.set(E,a.size);(async()=>{for(let E of b)if(typeof E.loadEntries=="function")try{let k=await Promise.resolve(E.loadEntries());k.entries.length>0&&a.size===0&&(a.restore(k.entries),x.set(E,k.entries.length),u());break}catch{}})();let N=d.subscribe(E=>{for(let k of E){if(k[0]!==D)continue;let A=k[1];for(let M of b){let S=x.get(M)??0;if(A.length<S){try{let ne=M.appendEntries(A);ne instanceof Promise&&ne.catch(()=>{})}catch{}x.set(M,A.length);continue}if(A.length===S)continue;let ae=A.slice(S);x.set(M,A.length);try{let ne=M.appendEntries(ae);ne instanceof Promise&&ne.catch(()=>{})}catch{}}}});return()=>N()},disposeAllViews(){for(let b of c.values())b.dispose();c.clear();for(let b of p.values())b.dispose();p.clear();for(let b of f.values())b.dispose();f.clear()},dispose(){for(let b of c.values())b.dispose();c.clear();for(let b of p.values())b.dispose();p.clear();for(let b of f.values())b.dispose();f.clear()}};return O}var hr=zt((r,e)=>{r("observe"),r("signal"),e("write")});function Tn(r){let e=Ye([],{name:r.name,maxSize:r.retainedLimit??1024,guard:r.guard??hr,...r.versioning!=null?{versioning:r.versioning}:{}});return e.withLatest(),r.graph&&r.graph.add(e.entries,{name:r.name}),e}function xn(r,e,t=0){let n=B(t,{name:e,describeKind:"state"});return r.add(n,{name:e}),n}pe();se();de();var Rt=class{_version=0;_buf;constructor(e){this._buf=e?[...e]:[]}get version(){return this._version}get size(){return this._buf.length}at(e){if(!Number.isInteger(e))return;let t=e>=0?e:this._buf.length+e;if(!(t<0||t>=this._buf.length))return this._buf[t]}append(e){this._buf.push(e),this._version+=1}appendMany(e){if(e.length===0)return;let t=this._buf.length;this._buf.length=t+e.length;for(let n=0;n<e.length;n++)this._buf[t+n]=e[n];this._version+=1}insert(e,t){if(!Number.isInteger(e)||e<0||e>this._buf.length)throw new RangeError(`insert: index ${e} out of range [0, ${this._buf.length}]`);this._buf.splice(e,0,t),this._version+=1}insertMany(e,t){if(!Number.isInteger(e)||e<0||e>this._buf.length)throw new RangeError(`insertMany: index ${e} out of range [0, ${this._buf.length}]`);t.length!==0&&(this._buf.splice(e,0,...t),this._version+=1)}pop(e){if(this._buf.length===0)throw new RangeError("pop from empty list");if(!Number.isInteger(e))throw new RangeError(`pop: index ${e} must be an integer`);let t=e>=0?e:this._buf.length+e;if(t<0||t>=this._buf.length)throw new RangeError(`pop: index ${e} out of range`);let[n]=this._buf.splice(t,1);return this._version+=1,n}clear(){let e=this._buf.length;return e===0?0:(this._buf.length=0,this._version+=1,e)}toArray(){return[...this._buf]}};function kn(r,e={}){let{name:t,versioning:n,backend:s}=e,o=s??new Rt(r),i=B(o.toArray(),{name:t,describeKind:"state",equals:(u,c)=>u===c,...n!=null?{versioning:n}:{}});function a(){let u=o.toArray();q(()=>{i.down([[V]]),i.down([[D,u]])})}function d(u){let c=o.version;try{return u()}finally{o.version!==c&&a()}}return{items:i,get size(){return o.size},at(u){return o.at(u)},append(u){d(()=>o.append(u))},appendMany(u){d(()=>o.appendMany(u))},insert(u,c){d(()=>o.insert(u,c))},insertMany(u,c){d(()=>o.insertMany(u,c))},pop(u=-1){return d(()=>o.pop(u))},clear(){d(()=>o.clear())},dispose(){}}}pe();_e();se();de();var At=class{_version=0;_store=new Map;_maxSize;_defaultTtl;constructor(e={}){let{maxSize:t,defaultTtl:n}=e;if(t!==void 0&&t<1)throw new RangeError("maxSize must be >= 1");if(n!==void 0&&n<=0)throw new RangeError("defaultTtl must be positive");this._maxSize=t,this._defaultTtl=n}get version(){return this._version}get size(){return this._store.size}has(e){let t=this._store.get(e);return t===void 0?!1:this._isExpired(t)?(this._store.delete(e),this._version+=1,!1):(this._touchLru(e,t),!0)}get(e){let t=this._store.get(e);if(t!==void 0){if(this._isExpired(t)){this._store.delete(e),this._version+=1;return}return this._touchLru(e,t),t.value}}set(e,t,n){let s=this._resolveExpiresAt(n);this._store.has(e)&&this._store.delete(e),this._store.set(e,{value:t,expiresAt:s}),this._evictLruWhileOver(),this._version+=1}setMany(e,t){let n=this._resolveExpiresAt(t),s=0;try{for(let[o,i]of e)this._store.has(o)&&this._store.delete(o),this._store.set(o,{value:i,expiresAt:n}),s+=1}finally{s>0&&(this._evictLruWhileOver(),this._version+=1)}}delete(e){let t=this._store.delete(e);return t&&(this._version+=1),t}deleteMany(e){let t=0;try{for(let n of e)this._store.delete(n)&&(t+=1)}finally{t>0&&(this._version+=1)}return t}clear(){let e=this._store.size;return e===0?0:(this._store.clear(),this._version+=1,e)}pruneExpired(){let e=K(),t=0;for(let[n,s]of this._store)this._isExpired(s,e)&&(this._store.delete(n),t+=1);return t>0&&(this._version+=1),t}toMap(){let e=K(),t=new Map;for(let[n,s]of this._store)this._isExpired(s,e)||t.set(n,s.value);return t}_resolveExpiresAt(e){let t=e??this._defaultTtl;if(t!==void 0){if(!Number.isFinite(t)||t<=0)throw new RangeError(`MapBackend: ttl must be a positive finite number (got ${t})`);return K()+t*1e9}}_isExpired(e,t){return e.expiresAt===void 0?!1:(t??K())>=e.expiresAt}_touchLru(e,t){this._store.delete(e),this._store.set(e,t)}_evictLruWhileOver(){if(this._maxSize!==void 0)for(;this._store.size>this._maxSize;){let e=this._store.keys().next().value;if(e===void 0)break;this._store.delete(e)}}};function Nn(r={}){let{name:e,maxSize:t,defaultTtl:n,versioning:s,backend:o,retention:i}=r;if(i&&t!==void 0)throw new RangeError("reactiveMap: `maxSize` (LRU) and `retention` (score-based) are mutually exclusive. Pick one eviction policy.");if(i&&i.archiveThreshold===void 0&&i.maxSize===void 0)throw new RangeError("reactiveMap: `retention` requires at least one of `archiveThreshold` or `maxSize` to trigger archival.");let a=o??new At({maxSize:t,defaultTtl:n}),d=B(a.toMap(),{name:e,describeKind:"state",equals:(f,h)=>f===h,...s!=null?{versioning:s}:{}});function u(){let f=a.toMap();q(()=>{d.down([[V]]),d.down([[D,f]])})}function c(){if(!i)return;let f=a.toMap(),h=i.archiveThreshold,l=i.maxSize,v=[];for(let[w,y]of f)v.push({key:w,value:y,score:i.score(w,y)});v.sort((w,y)=>w.score-y.score);let g=new Set;if(h!==void 0)for(let w of v)if(w.score<h)g.add(w.key);else break;if(l!==void 0&&v.length-g.size>l)for(let w of v){if(v.length-g.size<=l)break;g.has(w.key)||g.add(w.key)}if(g.size!==0)for(let w of v)g.has(w.key)&&(i.onArchive?.(w.key,w.value,w.score),a.delete(w.key))}function p(f,h="mutation"){let l=a.version;try{return f()}finally{a.version!==l&&(h==="mutation"&&c(),u())}}return{entries:d,has(f){return p(()=>a.has(f),"read")},get(f){return p(()=>a.get(f),"read")},set(f,h,l){p(()=>a.set(f,h,l?.ttl))},setMany(f,h){p(()=>a.setMany(f,h?.ttl))},delete(f){p(()=>a.delete(f))},deleteMany(f){p(()=>a.deleteMany(f))},clear(){p(()=>a.clear())},pruneExpired(){p(()=>a.pruneExpired())},get size(){return a.size},dispose(){}}}xt();var gr=256,mr=1024;function St(r,e){if(!Number.isFinite(r)||!Number.isInteger(r)||r<0)throw new Error(`${e} must be a non-negative integer`);return r}function Qe(r,e){return Zt("job_queue",r,e)}var br=r=>r.action,Xe=class extends ve{_pending;_jobs;_seqCursor;pending;jobs;depth;events;audit;constructor(e,t={}){super(e,t.graph),this._pending=kn([],{name:"pending"}),this._jobs=Nn({name:"jobs"}),this.pending=this._pending.items,this.jobs=this._jobs.entries,this.add(this.pending,{name:"pending"}),this.add(this.jobs,{name:"jobs"}),this.depth=X([this.pending],([n])=>n.length,{name:"depth",describeKind:"derived",meta:Qe("queue_depth"),initial:0}),this.add(this.depth,{name:"depth"}),this.addDisposer(ie(this.depth)),this.events=Tn({name:"events",retainedLimit:1024,graph:this}),this.audit=this.events,this._seqCursor=xn(this,"seq",0)}_bumpSeq(){let t=(this._seqCursor.cache??0)+1;return this._seqCursor.emit(t),t}attachEventStorage(e){return this.events.attachStorage(e)}enqueue(e,t={}){let n=this._bumpSeq(),s=t.id??`${this.name}-${n}`;if(this._jobs.get(s)!==void 0)throw new Error(`jobQueue("${this.name}"): duplicate job id "${s}"`);let o={id:s,payload:e,attempts:0,metadata:Object.freeze({...t.metadata??{}}),state:"queued"};return this._jobs.set(s,o),this._pending.append(s),this.events.append({action:"enqueue",id:s,payload:e,t_ns:ee(),seq:n}),s}claim(e=1){let t=St(e,"job queue claim limit");if(t===0)return[];let n=[];for(;n.length<t&&this.pending.cache.length!==0;){let o=this._pending.pop(0),i=this._jobs.get(o);if(!i||i.state!=="queued")continue;let a={...i,state:"inflight",attempts:i.attempts+1};this._jobs.set(o,a),n.push(a),this.events.append({action:"claim",id:o,attempts:a.attempts,t_ns:ee(),seq:this._bumpSeq()})}return n}ack(e){let t=this._jobs.get(e);return!t||t.state!=="inflight"?!1:(this._jobs.delete(e),this.events.append({action:"ack",id:e,attempts:t.attempts,t_ns:ee(),seq:this._bumpSeq()}),!0)}nack(e,t={}){let n=this._jobs.get(e);return!n||n.state!=="inflight"?!1:t.requeue??!0?(this._jobs.set(e,{...n,state:"queued"}),this._pending.append(e),this.events.append({action:"nack",id:e,attempts:n.attempts,t_ns:ee(),seq:this._bumpSeq()}),!0):(this._jobs.delete(e),this.events.append({action:"nack",id:e,attempts:n.attempts,t_ns:ee(),seq:this._bumpSeq()}),!0)}removeById(e){let t=this._jobs.get(e);if(!t)return!1;if(t.state==="queued"){let s=this.pending.cache.indexOf(e);s>=0&&this._pending.pop(s)}return this._jobs.delete(e),this.events.append({action:"remove",id:e,attempts:t.attempts,t_ns:ee(),seq:this._bumpSeq()}),!0}consumeFrom(e,t){return e.subscribe(n=>{for(let s of n){if(s[0]!==D)continue;let o=s[1];this.enqueue(o,t?{metadata:t.metadata}:void 0)}})}},Ze=class extends ve{_stageNames;_stageWorkFns;_queues=new Map;_completed;completed;completedCount;constructor(e,t={}){super(e,t.graph);let n=t.stages??["incoming","processing","done"],s=[],o=new Map,i=new Map;for(let u of n){let c=typeof u=="string"?u.trim():u.name.trim();typeof u!="string"&&u.work&&o.set(c,u.work),typeof u!="string"&&u.maxPerPump!=null&&i.set(c,Math.max(1,St(u.maxPerPump,`job flow stage "${c}" maxPerPump`))),s.push(c)}if(s.length<2)throw new Error(`jobFlow("${e}"): requires at least 2 stages`);if(new Set(s).size!==s.length)throw new Error(`jobFlow("${e}"): stage names must be unique`);this._stageNames=Object.freeze([...s]),this._stageWorkFns=o;for(let u of this._stageNames){let c=On(`${e}-${u}`);this._queues.set(u,c),this.mount(u,c)}this._completed=Ye([],{name:"completed",maxSize:mr}),this.completed=this._completed.entries,this.add(this.completed,{name:"completed"}),this.completedCount=X([this.completed],([u])=>u.length,{name:"completedCount",describeKind:"derived",meta:Qe("job_flow_completed_count"),initial:0}),this.add(this.completedCount,{name:"completedCount"}),this.addDisposer(ie(this.completedCount));let d=Math.max(1,St(t.maxPerPump??gr,"job flow maxPerPump"));for(let u=0;u<this._stageNames.length;u+=1){let c=this._stageNames[u],p=this.queue(c),f=u+1<this._stageNames.length?this.queue(this._stageNames[u+1]):null,h=this._stageWorkFns.get(c),l=i.get(c)??d,v=f===null;if(h){let g=oe([p.pending],()=>{let w=0;for(;w<l;){let y=p.claim(1);if(y.length===0)break;let m=y[0];if(!m)break;let T=[...m.metadata.job_flow_path??[],c],O;try{O=h(m)}catch{p.nack(m.id,{requeue:!1}),w+=1;continue}let b=rn(O),x=!1,N;N=b.subscribe(E=>{if(!x){for(let k of E)if(k[0]===D){x=!0,N?N():Promise.resolve().then(()=>N?.());let A=k[1],M={...m.metadata,job_flow_path:T};if(v){let S={...m,payload:A,metadata:Object.freeze(M)};q(()=>{p.ack(m.id),this._completed.append(S)})}else q(()=>{p.ack(m.id),f.enqueue(A,{metadata:M})});return}else if(k[0]===C){x=!0,N?N():Promise.resolve().then(()=>N?.()),p.nack(m.id,{requeue:!1});return}}}),w+=1}},{name:`pump_${c}`,describeKind:"effect",meta:Qe("job_flow_pump",{stage:c,has_work:!0})});this.add(g,{name:`pump_${c}`}),this.addDisposer(ie(g))}else{let g=oe([p.pending],()=>{let w=0;for(;w<l;){let y=p.claim(1);if(y.length===0)break;let m=y[0];if(!m)break;let T=[...m.metadata.job_flow_path??[],c],O={...m.metadata,job_flow_path:T};if(v){let b={...m,metadata:Object.freeze(O)};q(()=>{p.ack(m.id),this._completed.append(b)})}else q(()=>{p.ack(m.id),f.enqueue(m.payload,{metadata:O})});w+=1}},{name:`pump_${c}`,describeKind:"effect",meta:Qe("job_flow_pump",{stage:c,has_work:!1})});this.add(g,{name:`pump_${c}`}),this.addDisposer(ie(g))}}}stages(){return this._stageNames}queue(e){let t=this._queues.get(e);if(!t)throw new Error(`jobFlow("${this.name}"): unknown stage "${e}"`);return t}enqueue(e,t={}){return this.queue(this._stageNames[0]).enqueue(e,t)}retainedCompleted(){return this.completed.cache}};function On(r,e){return new Xe(r,e)}function yr(r,e){let t=new Ze(r,e),{factory:n,factoryArgs:s,...o}=e??{};return t.tagFactory("jobFlow",bt(o)),t}0&&(module.exports={JobFlowGraph,JobQueueGraph,jobEventKeyOf,jobFlow,jobQueue});