@graphrefly/graphrefly 0.40.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 (87) hide show
  1. package/dist/{chunk-6XVD5TZV.js → chunk-2W553JJC.js} +1 -1
  2. package/dist/{chunk-WL6LFPJB.js → chunk-33N4TU3X.js} +1 -1
  3. package/dist/{chunk-RZJDIV2G.js → chunk-4MKL6Q3K.js} +1 -1
  4. package/dist/chunk-5B3JDG5F.js +1 -0
  5. package/dist/{chunk-K2Z7UENB.js → chunk-5QSXEMXG.js} +1 -1
  6. package/dist/{chunk-ECQRP2UT.js → chunk-5TEFC2ZX.js} +1 -1
  7. package/dist/{chunk-SVFKHUCW.js → chunk-5TOPVRN6.js} +1 -1
  8. package/dist/{chunk-XJLYLLIJ.js → chunk-5VEZLQFN.js} +1 -1
  9. package/dist/{chunk-32N3JALT.js → chunk-7PQLZMOG.js} +1 -1
  10. package/dist/{chunk-2QXRYP7Q.js → chunk-AI7QC7J6.js} +1 -1
  11. package/dist/{chunk-FHRBBHJN.js → chunk-AK5RHMC5.js} +1 -1
  12. package/dist/{chunk-B7LCDQEV.js → chunk-CGNOWGV6.js} +1 -1
  13. package/dist/{chunk-LCGAVGGV.js → chunk-CYOSWFT2.js} +1 -1
  14. package/dist/{chunk-VMF23LGB.js → chunk-EC2WNSZ7.js} +1 -1
  15. package/dist/{chunk-UWA6D7UF.js → chunk-ELAASRBT.js} +1 -1
  16. package/dist/{chunk-Z4F3DOWS.js → chunk-F7VUYPP6.js} +1 -1
  17. package/dist/{chunk-LYM4PBMV.js → chunk-G3M3IMEV.js} +1 -1
  18. package/dist/{chunk-SSCGRYJ2.js → chunk-GI4Q7PNY.js} +1 -1
  19. package/dist/{chunk-7Q4ZD3YW.js → chunk-H5SCWHWP.js} +1 -1
  20. package/dist/{chunk-6I726LZU.js → chunk-KNVCCBIU.js} +1 -1
  21. package/dist/{chunk-CKFQS2CJ.js → chunk-L77I47VU.js} +1 -1
  22. package/dist/{chunk-I2DEVPMU.js → chunk-M3FQSXEW.js} +1 -1
  23. package/dist/{chunk-WUT362QV.js → chunk-OLIKJUKI.js} +1 -1
  24. package/dist/{chunk-QSK3RRII.js → chunk-OV5AA6HJ.js} +1 -1
  25. package/dist/{chunk-2BX4NB34.js → chunk-POXANAJ6.js} +1 -1
  26. package/dist/chunk-RSMEXK53.js +43 -0
  27. package/dist/{chunk-MNZIKXK4.js → chunk-SC27WTSG.js} +1 -1
  28. package/dist/{chunk-YXDRGKXP.js → chunk-TT4C7DXW.js} +1 -1
  29. package/dist/{chunk-2DMKW2AD.js → chunk-UISPDFJ3.js} +1 -1
  30. package/dist/{chunk-J63M5U46.js → chunk-URJ2VFNC.js} +1 -1
  31. package/dist/{chunk-XW4YDF6G.js → chunk-VV62MIG4.js} +1 -1
  32. package/dist/{chunk-756D5TFD.js → chunk-VXPLLA4P.js} +1 -1
  33. package/dist/{chunk-PPUYQ66A.js → chunk-WZYB3JQS.js} +1 -1
  34. package/dist/{chunk-6VWBPSSY.js → chunk-X7QKTXXC.js} +1 -1
  35. package/dist/{chunk-JKBOIJ22.js → chunk-YQRN4CIV.js} +1 -1
  36. package/dist/chunk-Z6X7B6A4.js +61 -0
  37. package/dist/{chunk-N43XM7BM.js → chunk-ZAJ7J7TO.js} +1 -1
  38. package/dist/compat/index.js +1 -1
  39. package/dist/compat/nestjs/index.js +1 -1
  40. package/dist/compat/zustand/index.js +1 -1
  41. package/dist/extra/index.js +1 -1
  42. package/dist/extra/node.js +1 -1
  43. package/dist/extra/operators.js +1 -1
  44. package/dist/extra/reactive.js +1 -1
  45. package/dist/extra/sources.js +1 -1
  46. package/dist/graph/index.js +1 -1
  47. package/dist/{index-IUCY0OFN.d.ts → index-CG33HeBW.d.ts} +17 -2
  48. package/dist/{index-BTHOTC0Q.d.cts → index-DGD4_fj6.d.cts} +17 -2
  49. package/dist/{index-D1IEZUsj.d.ts → index-DfOK_oL5.d.ts} +204 -199
  50. package/dist/{index-DJ_MPOJ5.d.cts → index-DuRsN9ae.d.cts} +204 -199
  51. package/dist/index.cjs +46 -46
  52. package/dist/index.d.cts +2 -2
  53. package/dist/index.d.ts +2 -2
  54. package/dist/index.js +1 -1
  55. package/dist/patterns/ai/browser.js +1 -1
  56. package/dist/patterns/ai/index.cjs +11 -11
  57. package/dist/patterns/ai/index.js +1 -1
  58. package/dist/patterns/ai/node.js +1 -1
  59. package/dist/patterns/audit/index.js +1 -1
  60. package/dist/patterns/cqrs/index.js +1 -1
  61. package/dist/patterns/demo-shell/index.js +1 -1
  62. package/dist/patterns/domain-templates/index.js +1 -1
  63. package/dist/patterns/graphspec/index.js +1 -1
  64. package/dist/patterns/guarded-execution/index.js +1 -1
  65. package/dist/patterns/harness/index.cjs +8 -8
  66. package/dist/patterns/harness/index.d.cts +4 -4
  67. package/dist/patterns/harness/index.d.ts +4 -4
  68. package/dist/patterns/harness/index.js +1 -1
  69. package/dist/patterns/job-queue/index.cjs +3 -3
  70. package/dist/patterns/job-queue/index.d.cts +1 -1
  71. package/dist/patterns/job-queue/index.d.ts +1 -1
  72. package/dist/patterns/job-queue/index.js +1 -1
  73. package/dist/patterns/lens/index.js +1 -1
  74. package/dist/patterns/memory/index.js +1 -1
  75. package/dist/patterns/messaging/index.js +1 -1
  76. package/dist/patterns/orchestration/index.js +1 -1
  77. package/dist/patterns/process/index.js +1 -1
  78. package/dist/patterns/reactive-layout/index.js +1 -1
  79. package/dist/patterns/reduction/index.js +1 -1
  80. package/dist/patterns/refine-loop/index.js +1 -1
  81. package/dist/patterns/resilient-pipeline/index.js +1 -1
  82. package/dist/patterns/surface/index.js +1 -1
  83. package/dist/{resilience-S33JV6XC.js → resilience-JISHQD2F.js} +1 -1
  84. package/package.json +1 -1
  85. package/dist/chunk-INQFTVZA.js +0 -61
  86. package/dist/chunk-OSZ22J7O.js +0 -1
  87. package/dist/chunk-YKD7WUYJ.js +0 -43
@@ -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-DJ_MPOJ5.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-Cnr1WrlX.cjs';
5
+ import '../../index-DGD4_fj6.cjs';
6
+ import '../../index-DVDapw2k.cjs';
6
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';
12
+ import '../../index-Cnr1WrlX.cjs';
11
13
  import '../../index-t6L2qpHh.cjs';
12
14
  import '../../pipeline-graph-MWrQZXCq.cjs';
13
15
  import '../../sugar-DzePN5-g.cjs';
14
- import '../../index-DVDapw2k.cjs';
15
- import '../../index-BTHOTC0Q.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-D1IEZUsj.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-40ZT4MHj.js';
5
+ import '../../index-CG33HeBW.js';
6
+ import '../../index-BQ1fR4li.js';
6
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';
12
+ import '../../index-40ZT4MHj.js';
11
13
  import '../../index-BgjS2b8N.js';
12
14
  import '../../pipeline-graph-CB4La-UW.js';
13
15
  import '../../sugar-BhfjgetH.js';
14
- import '../../index-BQ1fR4li.js';
15
- import '../../index-IUCY0OFN.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-YKD7WUYJ.js";import"../../chunk-UWA6D7UF.js";import"../../chunk-OSZ22J7O.js";import"../../chunk-INQFTVZA.js";import"../../chunk-Z4F3DOWS.js";import"../../chunk-SSCGRYJ2.js";import"../../chunk-32N3JALT.js";import"../../chunk-XW4YDF6G.js";import"../../chunk-2DMKW2AD.js";import"../../chunk-J63M5U46.js";import"../../chunk-D27JNOLZ.js";import"../../chunk-LYM4PBMV.js";import"../../chunk-ECQRP2UT.js";import"../../chunk-3G5U5QNE.js";import"../../chunk-C72GO4IZ.js";import"../../chunk-4I45FVQS.js";import"../../chunk-PPUYQ66A.js";import"../../chunk-TSOYJ743.js";import"../../chunk-LCGAVGGV.js";import"../../chunk-RZJDIV2G.js";import"../../chunk-6I726LZU.js";import"../../chunk-756D5TFD.js";import"../../chunk-L6NSJVJZ.js";import"../../chunk-2BX4NB34.js";import"../../chunk-SGS4OJGS.js";import"../../chunk-ESMPEKEV.js";import"../../chunk-D5RFJOZ2.js";import"../../chunk-CE72X3WO.js";import"../../chunk-FHRBBHJN.js";import"../../chunk-4VVTGLXJ.js";import"../../chunk-35JTVPOX.js";import"../../chunk-KGKJCHEK.js";import"../../chunk-TZQPPQEQ.js";import"../../chunk-YXDRGKXP.js";import"../../chunk-CKFQS2CJ.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});