@graphrefly/graphrefly 0.41.0 → 0.43.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.
- package/dist/{cascading-Cxs1eztH.d.cts → cascading-CH-_VwG9.d.cts} +2 -2
- package/dist/{cascading-BNfxffgc.d.ts → cascading-OgKQZjsa.d.ts} +2 -2
- package/dist/chunk-3XDYJRYU.js +1 -0
- package/dist/{chunk-AI7QC7J6.js → chunk-4YAN45KM.js} +1 -1
- package/dist/chunk-626TESAC.js +3 -0
- package/dist/chunk-6HOSXQKF.js +1 -0
- package/dist/{chunk-G3M3IMEV.js → chunk-CUNIRONA.js} +1 -1
- package/dist/chunk-EBW4V6JN.js +1 -0
- package/dist/chunk-FDQGFWLF.js +1 -0
- package/dist/{chunk-33N4TU3X.js → chunk-FG4TKHMC.js} +1 -1
- package/dist/{chunk-YQRN4CIV.js → chunk-I7IGYPSL.js} +1 -1
- package/dist/chunk-INQD2KRQ.js +1 -0
- package/dist/{chunk-7PQLZMOG.js → chunk-JNWRYDJN.js} +1 -1
- package/dist/{chunk-TT4C7DXW.js → chunk-JQFH2DV6.js} +1 -1
- package/dist/{chunk-M3FQSXEW.js → chunk-K2Q24F5T.js} +1 -1
- package/dist/chunk-KVV66NN2.js +1 -0
- package/dist/chunk-NON4NLIC.js +45 -0
- package/dist/{chunk-CYOSWFT2.js → chunk-O2BLLH7M.js} +3 -3
- package/dist/{chunk-OV5AA6HJ.js → chunk-OCKEEPRJ.js} +1 -1
- package/dist/{chunk-X7QKTXXC.js → chunk-OFZG3TB3.js} +3 -3
- package/dist/chunk-OYJKFY7V.js +1 -0
- package/dist/{chunk-SC27WTSG.js → chunk-P6C4WHZO.js} +1 -1
- package/dist/{chunk-VV62MIG4.js → chunk-PT7W5FCD.js} +1 -1
- package/dist/{chunk-UISPDFJ3.js → chunk-Q4U3A3L5.js} +1 -1
- package/dist/chunk-QE4IGY7I.js +61 -0
- package/dist/{chunk-5VEZLQFN.js → chunk-QYVXF7GW.js} +1 -1
- package/dist/{chunk-ZAJ7J7TO.js → chunk-S3EEIPO7.js} +1 -1
- package/dist/{chunk-GI4Q7PNY.js → chunk-SUWT3ZON.js} +1 -1
- package/dist/{chunk-CGNOWGV6.js → chunk-TPKQW72B.js} +1 -1
- package/dist/{chunk-L77I47VU.js → chunk-V5A7M7RJ.js} +1 -1
- package/dist/chunk-VNC3TMVY.js +1 -0
- package/dist/{chunk-AK5RHMC5.js → chunk-VOPGGIL7.js} +1 -1
- package/dist/chunk-VQ4A6T2A.js +1 -0
- package/dist/{chunk-KNVCCBIU.js → chunk-XG62INFA.js} +1 -1
- package/dist/{chunk-F7VUYPP6.js → chunk-Y4NI3X7O.js} +1 -1
- package/dist/compat/index.cjs +5 -5
- package/dist/compat/index.d.cts +16 -16
- package/dist/compat/index.d.ts +16 -16
- package/dist/compat/index.js +1 -1
- package/dist/compat/jotai/index.d.cts +2 -2
- package/dist/compat/jotai/index.d.ts +2 -2
- package/dist/compat/nanostores/index.d.cts +2 -2
- package/dist/compat/nanostores/index.d.ts +2 -2
- package/dist/compat/nestjs/index.cjs +5 -5
- package/dist/compat/nestjs/index.d.cts +8 -8
- package/dist/compat/nestjs/index.d.ts +8 -8
- package/dist/compat/nestjs/index.js +1 -1
- package/dist/compat/react/index.d.cts +2 -2
- package/dist/compat/react/index.d.ts +2 -2
- package/dist/compat/solid/index.d.cts +2 -2
- package/dist/compat/solid/index.d.ts +2 -2
- package/dist/compat/svelte/index.d.cts +2 -2
- package/dist/compat/svelte/index.d.ts +2 -2
- package/dist/compat/vue/index.d.cts +2 -2
- package/dist/compat/vue/index.d.ts +2 -2
- package/dist/compat/zustand/index.cjs +3 -3
- package/dist/compat/zustand/index.d.cts +4 -4
- package/dist/compat/zustand/index.d.ts +4 -4
- package/dist/compat/zustand/index.js +1 -1
- package/dist/core/index.d.cts +4 -4
- package/dist/core/index.d.ts +4 -4
- package/dist/{decay-C25AyNAj.d.cts → decay-2ZukgQ4o.d.cts} +2 -2
- package/dist/{decay-BnrlbxSv.d.ts → decay-CdEBmDIs.d.ts} +2 -2
- package/dist/extra/browser.d.cts +1 -1
- package/dist/extra/browser.d.ts +1 -1
- package/dist/extra/index.cjs +14 -14
- package/dist/extra/index.d.cts +10 -11
- package/dist/extra/index.d.ts +10 -11
- package/dist/extra/index.js +1 -1
- package/dist/extra/node.cjs +2 -2
- package/dist/extra/node.d.cts +1 -1
- package/dist/extra/node.d.ts +1 -1
- package/dist/extra/node.js +1 -1
- package/dist/extra/operators.cjs +1 -1
- package/dist/extra/operators.d.cts +1 -1
- package/dist/extra/operators.d.ts +1 -1
- package/dist/extra/operators.js +1 -1
- package/dist/extra/reactive.d.cts +3 -3
- package/dist/extra/reactive.d.ts +3 -3
- package/dist/extra/reactive.js +1 -1
- package/dist/extra/render/index.d.cts +3 -3
- package/dist/extra/render/index.d.ts +3 -3
- package/dist/extra/sources.cjs +3 -1
- package/dist/extra/sources.d.cts +1 -1
- package/dist/extra/sources.d.ts +1 -1
- package/dist/extra/sources.js +1 -1
- package/dist/extra/storage-browser.d.cts +1 -1
- package/dist/extra/storage-browser.d.ts +1 -1
- package/dist/{fallback-CMZl39L5.d.ts → fallback-CqYVLL6X.d.ts} +1 -1
- package/dist/{fallback-8JYU8tlT.d.cts → fallback-Ctlj2tMY.d.cts} +1 -1
- package/dist/graph/index.cjs +7 -7
- package/dist/graph/index.d.cts +5 -5
- package/dist/graph/index.d.ts +5 -5
- package/dist/graph/index.js +1 -1
- package/dist/{graph-BkIkog4h.d.ts → graph-7VguS7a4.d.ts} +3 -3
- package/dist/{graph-E6likq7w.d.cts → graph-C4SHb3Ly.d.cts} +3 -3
- package/dist/{index-DgJc8Zgc.d.cts → index-0rKFCVFp.d.cts} +90 -5
- package/dist/{index-BAQrjuZF.d.ts → index-B-i4_g3k.d.ts} +2 -2
- package/dist/{index-DpiGqtrs.d.cts → index-B5iz82A3.d.cts} +441 -381
- package/dist/{index-Bd91Nmf4.d.cts → index-BAOD98JD.d.cts} +4 -4
- package/dist/{index-2n8Eai6M.d.ts → index-BG0BN3PB.d.ts} +1 -1
- package/dist/{index-z8WFPVI8.d.cts → index-BJX94aud.d.cts} +1 -1
- package/dist/{index-DhLyOHYZ.d.ts → index-BP8a88zx.d.ts} +11 -4
- package/dist/{index-Cnr1WrlX.d.cts → index-BTQtTb_H.d.cts} +14 -3
- package/dist/{index-DOBLxOti.d.cts → index-BVpm6noz.d.cts} +1 -1
- package/dist/{index-Cczxgd2D.d.ts → index-Bc41FuHp.d.cts} +3 -3
- package/dist/{index-BiHUBEKq.d.cts → index-BdGtBX-X.d.cts} +3 -3
- package/dist/{index-da2V5vPy.d.ts → index-Bf7eqeSF.d.ts} +2 -2
- package/dist/{index-DuRsN9ae.d.cts → index-BiX1Nkgx.d.cts} +383 -18
- package/dist/{index-DGTo1yka.d.cts → index-BoLv_OfD.d.cts} +2 -2
- package/dist/{index-DVAlsmEU.d.cts → index-BojK2fwH.d.cts} +3 -3
- package/dist/{index-B72TQQHd.d.cts → index-BsT7F2et.d.ts} +3 -3
- package/dist/{index-DGD4_fj6.d.cts → index-BwLvVVsy.d.cts} +8 -5
- package/dist/{index-CQtWm7jS.d.ts → index-C59mYFKp.d.ts} +9 -9
- package/dist/{index-C6ZUaos7.d.ts → index-C7O6r5fV.d.ts} +1 -1
- package/dist/{index-CL7oilfm.d.cts → index-C9kSENB4.d.cts} +1 -1
- package/dist/{index-DVDapw2k.d.cts → index-C9pjcz3l.d.cts} +35 -36
- package/dist/{index-CG33HeBW.d.ts → index-CAC_rNzm.d.ts} +8 -5
- package/dist/{index-yLt-aPMp.d.ts → index-CCq87F7t.d.ts} +1 -1
- package/dist/{index-D4uimgee.d.cts → index-CDXc9zKM.d.cts} +1 -1
- package/dist/{index-B2RUoIUz.d.ts → index-CJK1JkYy.d.ts} +1 -1
- package/dist/{index-DktLSZOc.d.cts → index-CLon-IWF.d.cts} +4 -4
- package/dist/{index-DQQCOIt8.d.cts → index-COD1kVoS.d.cts} +10 -5
- package/dist/{index-bXXLSvor.d.ts → index-CPT7C_f1.d.ts} +4 -4
- package/dist/{index-CD2dBMet.d.ts → index-CQG3D1cp.d.ts} +10 -5
- package/dist/{index-BQ1fR4li.d.ts → index-CZQXo5tH.d.ts} +35 -36
- package/dist/{index-A3U3CSve.d.cts → index-CZjOhcBy.d.cts} +2 -2
- package/dist/{index-DYTBbF8T.d.cts → index-ChOyVLKm.d.cts} +1 -1
- package/dist/{index-BJSZxSFX.d.ts → index-CvrqGfNS.d.ts} +1 -1
- package/dist/{index-DhnsQfa3.d.ts → index-D-AEQVLo.d.ts} +441 -381
- package/dist/{index-CAP3UGsq.d.ts → index-D4Y1cMG0.d.ts} +1 -1
- package/dist/{index-40ZT4MHj.d.ts → index-DBHK8O6H.d.ts} +14 -3
- package/dist/{index-3k4Gg6-n.d.ts → index-DBevwHj_.d.ts} +3 -3
- package/dist/{index-Ctb7_2sG.d.ts → index-DIOoAZUX.d.ts} +1 -1
- package/dist/{index-WSlcjhQF.d.ts → index-DSZ3ZCHF.d.ts} +124 -13
- package/dist/{index-DH4fm2Ck.d.ts → index-Dgs8zcj7.d.ts} +2 -2
- package/dist/{index-BaA-xpSw.d.ts → index-Dh_HJ82K.d.ts} +3 -3
- package/dist/{index-CtFNGe-m.d.cts → index-Dhc7a7Xo.d.cts} +2 -2
- package/dist/{index-CoM4rzyB.d.ts → index-Dmqp7KjD.d.ts} +1 -1
- package/dist/{index-B6iTqKtJ.d.ts → index-Dn-wI9g4.d.ts} +2 -2
- package/dist/{index-C-dkXOpB.d.cts → index-Du7u1lSf.d.cts} +11 -4
- package/dist/{index-DfOK_oL5.d.ts → index-DwigL4lY.d.ts} +383 -18
- package/dist/index-DyR7eU5S.d.cts +779 -0
- package/dist/index-JZUPJIJy.d.ts +779 -0
- package/dist/{index-I1cCY3ZI.d.ts → index-K0_0eR8g.d.ts} +90 -5
- package/dist/{index-BilOa6AE.d.cts → index-O16yXPK4.d.cts} +124 -13
- package/dist/{index-CRm0YIzC.d.cts → index-O7fucFrU.d.cts} +9 -9
- package/dist/{index-MxYuWOrf.d.cts → index-RV_yDjOX.d.cts} +3 -3
- package/dist/{index-C5cQ7Gfx.d.ts → index-cm1GNcWE.d.ts} +4 -4
- package/dist/{index-CgnCFhr2.d.cts → index-f5IivDUX.d.cts} +1 -1
- package/dist/{index-PgwvGWa1.d.cts → index-hHcaFlJX.d.cts} +1 -1
- package/dist/{index-tV3AA9hI.d.cts → index-tJoTcnHh.d.cts} +2 -2
- package/dist/{index-eaQuGJnv.d.ts → index-wAzD9yVj.d.ts} +3 -3
- package/dist/{index-D3ayz3hy.d.cts → index-z96luz5O.d.cts} +1 -1
- package/dist/index.cjs +48 -48
- package/dist/index.d.cts +45 -50
- package/dist/index.d.ts +45 -50
- package/dist/index.js +1 -1
- package/dist/{meta-D8OyedKp.d.ts → meta-BgVAsg9j.d.ts} +1 -1
- package/dist/{meta-Ct9nqQS5.d.cts → meta-vE8bxW1E.d.cts} +1 -1
- package/dist/{node-BYInONRr.d.cts → node-ClS5yC-B.d.cts} +1 -1
- package/dist/{node-BYInONRr.d.ts → node-ClS5yC-B.d.ts} +1 -1
- package/dist/{observable-DO8DDEzv.d.ts → observable-BsBzUrcI.d.ts} +1 -1
- package/dist/{observable-DMIlYJV1.d.cts → observable-DLGPPtb8.d.cts} +1 -1
- package/dist/patterns/ai/browser.d.cts +4 -4
- package/dist/patterns/ai/browser.d.ts +4 -4
- package/dist/patterns/ai/browser.js +1 -1
- package/dist/patterns/ai/index.cjs +17 -17
- package/dist/patterns/ai/index.d.cts +17 -17
- package/dist/patterns/ai/index.d.ts +17 -17
- package/dist/patterns/ai/index.js +1 -1
- package/dist/patterns/ai/node.d.cts +4 -4
- package/dist/patterns/ai/node.d.ts +4 -4
- package/dist/patterns/ai/node.js +1 -1
- package/dist/patterns/cqrs/index.cjs +3 -3
- package/dist/patterns/cqrs/index.d.cts +6 -6
- package/dist/patterns/cqrs/index.d.ts +6 -6
- package/dist/patterns/cqrs/index.js +1 -1
- package/dist/patterns/demo-shell/index.cjs +5 -5
- package/dist/patterns/demo-shell/index.d.cts +5 -5
- package/dist/patterns/demo-shell/index.d.ts +5 -5
- package/dist/patterns/demo-shell/index.js +1 -1
- package/dist/patterns/domain-templates/index.cjs +3 -3
- package/dist/patterns/domain-templates/index.d.cts +4 -4
- package/dist/patterns/domain-templates/index.d.ts +4 -4
- package/dist/patterns/domain-templates/index.js +1 -1
- package/dist/patterns/graphspec/index.cjs +12 -12
- package/dist/patterns/graphspec/index.d.cts +5 -5
- package/dist/patterns/graphspec/index.d.ts +5 -5
- package/dist/patterns/graphspec/index.js +1 -1
- package/dist/patterns/harness/index.cjs +10 -8
- package/dist/patterns/harness/index.d.cts +11 -12
- package/dist/patterns/harness/index.d.ts +11 -12
- package/dist/patterns/harness/index.js +1 -1
- package/dist/patterns/inspect/index.cjs +3 -0
- package/dist/patterns/inspect/index.d.cts +9 -0
- package/dist/patterns/inspect/index.d.ts +9 -0
- package/dist/patterns/inspect/index.js +1 -0
- package/dist/patterns/job-queue/index.cjs +3 -3
- package/dist/patterns/job-queue/index.d.cts +6 -6
- package/dist/patterns/job-queue/index.d.ts +6 -6
- package/dist/patterns/job-queue/index.js +1 -1
- package/dist/patterns/memory/index.cjs +3 -3
- package/dist/patterns/memory/index.d.cts +6 -6
- package/dist/patterns/memory/index.d.ts +6 -6
- package/dist/patterns/memory/index.js +1 -1
- package/dist/patterns/messaging/index.cjs +3 -3
- package/dist/patterns/messaging/index.d.cts +5 -5
- package/dist/patterns/messaging/index.d.ts +5 -5
- package/dist/patterns/messaging/index.js +1 -1
- package/dist/patterns/orchestration/index.cjs +3 -3
- package/dist/patterns/orchestration/index.d.cts +7 -7
- package/dist/patterns/orchestration/index.d.ts +7 -7
- package/dist/patterns/orchestration/index.js +1 -1
- package/dist/patterns/process/index.cjs +1 -1
- package/dist/patterns/process/index.d.cts +7 -7
- package/dist/patterns/process/index.d.ts +7 -7
- package/dist/patterns/process/index.js +1 -1
- package/dist/patterns/reactive-layout/index.cjs +4 -4
- package/dist/patterns/reactive-layout/index.d.cts +5 -5
- package/dist/patterns/reactive-layout/index.d.ts +5 -5
- package/dist/patterns/reactive-layout/index.js +1 -1
- package/dist/patterns/reduction/index.cjs +3 -3
- package/dist/patterns/reduction/index.d.cts +4 -4
- package/dist/patterns/reduction/index.d.ts +4 -4
- package/dist/patterns/reduction/index.js +1 -1
- package/dist/patterns/surface/index.cjs +8 -8
- package/dist/patterns/surface/index.d.cts +6 -6
- package/dist/patterns/surface/index.d.ts +6 -6
- package/dist/patterns/surface/index.js +1 -1
- package/dist/{pipeline-graph-MWrQZXCq.d.cts → pipeline-graph-DPqKDk59.d.cts} +5 -5
- package/dist/{pipeline-graph-CB4La-UW.d.ts → pipeline-graph-loP57TBA.d.ts} +5 -5
- package/dist/{reactive-layout-BtZfUKuL.d.cts → reactive-layout-Dsvob4zD.d.cts} +2 -2
- package/dist/{reactive-layout-KJj4E2dT.d.ts → reactive-layout-v7KPvxoc.d.ts} +2 -2
- package/dist/{reactive-log-_zeEnB9H.d.cts → reactive-log-B00laMSQ.d.cts} +1 -1
- package/dist/{reactive-log-BlAsPLl2.d.ts → reactive-log-BezYsbA_.d.ts} +1 -1
- package/dist/{reactive-map-6P_k3AQM.d.cts → reactive-map-48mnZ-nu.d.cts} +1 -1
- package/dist/{reactive-map-CjXByDV-.d.ts → reactive-map-BVVPdvmi.d.ts} +1 -1
- package/dist/resilience-YIWPK4YC.js +1 -0
- package/dist/{sugar-DzePN5-g.d.cts → sugar-DLwvMr3F.d.ts} +24 -4
- package/dist/{sugar-BhfjgetH.d.ts → sugar-DyVGtczU.d.cts} +24 -4
- package/dist/{topology-tree-mF7Emqzm.d.ts → topology-tree-BNGvuG82.d.ts} +1 -1
- package/dist/{topology-tree-3LBKFsUo.d.cts → topology-tree-BSdfSwMi.d.cts} +1 -1
- package/dist/{types-1Dhoi7HM.d.cts → types-B1jDWVsM.d.cts} +1 -1
- package/dist/{types-39jk0kaV.d.ts → types-DkzUUs0H.d.ts} +1 -1
- package/package.json +11 -51
- package/dist/budget-gate-CmmVtasH.d.ts +0 -115
- package/dist/budget-gate-DiP_nK0n.d.cts +0 -115
- package/dist/chunk-2W553JJC.js +0 -1
- package/dist/chunk-4MKL6Q3K.js +0 -1
- package/dist/chunk-5B3JDG5F.js +0 -1
- package/dist/chunk-5QSXEMXG.js +0 -1
- package/dist/chunk-5TEFC2ZX.js +0 -1
- package/dist/chunk-5TOPVRN6.js +0 -1
- package/dist/chunk-EC2WNSZ7.js +0 -1
- package/dist/chunk-ELAASRBT.js +0 -3
- package/dist/chunk-H5SCWHWP.js +0 -1
- package/dist/chunk-OLIKJUKI.js +0 -1
- package/dist/chunk-POXANAJ6.js +0 -3
- package/dist/chunk-RSMEXK53.js +0 -43
- package/dist/chunk-SGS4OJGS.js +0 -1
- package/dist/chunk-URJ2VFNC.js +0 -1
- package/dist/chunk-VXPLLA4P.js +0 -1
- package/dist/chunk-WZYB3JQS.js +0 -1
- package/dist/chunk-Z6X7B6A4.js +0 -61
- package/dist/index-8s-Qm-gz.d.ts +0 -218
- package/dist/index-BgjS2b8N.d.ts +0 -366
- package/dist/index-BmSQLAZo.d.cts +0 -244
- package/dist/index-CGhMJNHb.d.cts +0 -128
- package/dist/index-CUIkE1l9.d.cts +0 -230
- package/dist/index-Ck35nA-T.d.ts +0 -244
- package/dist/index-CuPUehFa.d.cts +0 -218
- package/dist/index-D1Gc7wV5.d.ts +0 -230
- package/dist/index-N2MAxt7_.d.ts +0 -128
- package/dist/index-t6L2qpHh.d.cts +0 -366
- package/dist/patterns/audit/index.cjs +0 -3
- package/dist/patterns/audit/index.d.cts +0 -8
- package/dist/patterns/audit/index.d.ts +0 -8
- package/dist/patterns/audit/index.js +0 -1
- package/dist/patterns/guarded-execution/index.cjs +0 -3
- package/dist/patterns/guarded-execution/index.d.cts +0 -9
- package/dist/patterns/guarded-execution/index.d.ts +0 -9
- package/dist/patterns/guarded-execution/index.js +0 -1
- package/dist/patterns/lens/index.cjs +0 -3
- package/dist/patterns/lens/index.d.cts +0 -7
- package/dist/patterns/lens/index.d.ts +0 -7
- package/dist/patterns/lens/index.js +0 -1
- package/dist/patterns/refine-loop/index.cjs +0 -5
- package/dist/patterns/refine-loop/index.d.cts +0 -9
- package/dist/patterns/refine-loop/index.d.ts +0 -9
- package/dist/patterns/refine-loop/index.js +0 -1
- package/dist/patterns/resilient-pipeline/index.cjs +0 -3
- package/dist/patterns/resilient-pipeline/index.d.cts +0 -8
- package/dist/patterns/resilient-pipeline/index.d.ts +0 -8
- package/dist/patterns/resilient-pipeline/index.js +0 -1
- package/dist/resilience-JISHQD2F.js +0 -1
package/dist/graph/index.cjs
CHANGED
|
@@ -1,7 +1,7 @@
|
|
|
1
|
-
"use strict";var st=Object.defineProperty;var $n=Object.getOwnPropertyDescriptor;var Pn=Object.getOwnPropertyNames;var In=Object.prototype.hasOwnProperty;var j=(t,e)=>()=>(t&&(e=t(t=0)),e);var Fn=(t,e)=>{for(var n in e)st(t,n,{get:e[n],enumerable:!0})},jn=(t,e,n,r)=>{if(e&&typeof e=="object"||typeof e=="function")for(let o of Pn(e))!In.call(t,o)&&o!==n&&st(t,o,{get:()=>e[o],enumerable:!(r=$n(e,o))||r.enumerable});return t};var Vn=t=>jn(st({},"__esModule",{value:!0}),t);function Ft(t){return{name:"dag-cbor",version:1,contentType:"application/dag-cbor",encode:e=>t.encode(e),decode:(e,n)=>t.decode(e)}}function jt(t,e){return{name:"dag-cbor-zstd",version:1,contentType:"application/dag-cbor+zstd",encode:n=>e.compressSync(t.encode(n)),decode:(n,r)=>t.decode(e.decompressSync(n))}}function Ne(t,e){let n=new TextEncoder().encode(t.name);if(n.length===0||n.length>255)throw new Error(`encodeEnvelope: codec name "${t.name}" encodes to ${n.length} bytes (must be 1\u2013255)`);let r=t.version;if(!Number.isInteger(r)||r<0||r>65535)throw new Error(`encodeEnvelope: codec.version ${r} out of u16 range (expected integer 0\u201365535)`);let o=2+n.length+2+e.length;if(o>4294967295)throw new Error(`encodeEnvelope: total envelope size ${o} exceeds 2^32-1 bytes (payload ${e.length} bytes)`);let s=new Uint8Array(o),i=0;return s[i++]=me,s[i++]=n.length,s.set(n,i),i+=n.length,s[i++]=r>>>8&255,s[i++]=r&255,s.set(e,i),s}function Se(t,e){if(t.length<It)throw new Error(`decodeEnvelope: bytes too short (${t.length} < ${It})`);let n=0,r=t[n++];if(r!==me)throw new Error(`decodeEnvelope: unsupported envelope version ${r} (expected ${me})`);let o=t[n++];if(o===0)throw new Error("decodeEnvelope: name_len must be >= 1");if(n+o+2>t.length)throw new Error(`decodeEnvelope: envelope truncated (need ${n+o+2} bytes, have ${t.length})`);let s=new TextDecoder().decode(t.subarray(n,n+o));n+=o;let i=(t[n]<<8|t[n+1])>>>0;n+=2;let a=t.subarray(n),c=e.lookupCodec(s);if(c==null)throw new Error(`decodeEnvelope: codec "${s}" not registered (envelope codec_v=${i})`);return{codec:c,codecVersion:i,payload:a}}function De(t){t.registerCodec(at)}function Vt(t){if(t.length===0)throw new Error("WAL is empty \u2014 need at least one full snapshot");let e=t[0];if(e.mode!=="full")throw new Error("WAL must start with a full record carrying a baseline snapshot");let n=JSON.parse(JSON.stringify(e.snapshot)),r=e.seq;for(let o=1;o<t.length;o++){let s=t[o];if(s.seq<=r)throw new Error(`WAL chain broken at index ${o}: seq=${s.seq} must exceed prev seq=${r}`);if(s.mode==="full"){n=JSON.parse(JSON.stringify(s.snapshot)),r=s.seq;continue}let i=s.diff;for(let c of i.nodesRemoved)delete n.nodes[c];let a=i.nodesAddedFull;if(a!=null)for(let[c,u]of Object.entries(a))n.nodes[c]=JSON.parse(JSON.stringify(u));for(let c of i.nodesChanged){let u=n.nodes[c.path];u!=null&&(u[c.field]=c.to)}r=s.seq}return n}var at,me,It,Re=j(()=>{"use strict";at={name:"json",version:1,contentType:"application/json",encode(t){let e=JSON.stringify(t);return new TextEncoder().encode(e)},decode(t,e){let n=new TextDecoder().decode(t);return JSON.parse(n)}};me=1,It=4});function Le(t){if(t==null)return ce;let{type:e,id:n,...r}=t;return{type:e??"system",id:n??"",...r}}var ce,ut=j(()=>{"use strict";ce={type:"system",id:""}});function $e(){return de>0||be}function Ut(){return de>0}function fe(t){de>0?ye.push(t):t()}function Wt(t){de+=1;let e=!1;try{t()}catch(n){throw e=!0,n}finally{if(de-=1,de===0)if(e){if(!be){let n=ye.splice(0);for(let r of n)try{r()}catch{}se.length=0,ie.length=0,le.length=0}}else Kn()}}function Kn(){let t=!be;t&&(be=!0);let e=[],n=0;try{for(;se.length>0||ie.length>0||le.length>0||t&&ye.length>0;){if(t&&ye.length>0){let s=ye.splice(0);for(let i of s)try{i()}catch(a){e.push(a)}continue}if(n+=1,n>1e3)throw se.length=0,ie.length=0,le.length=0,new Error("batch drain exceeded 1000 iterations \u2014 likely a reactive cycle");let o=(se.length>0?se:ie.length>0?ie:le).splice(0);for(let s of o)try{s()}catch(i){e.push(i)}}}finally{t&&(be=!1)}if(e.length===1)throw e[0];if(e.length>1)throw new AggregateError(e,"batch drain: multiple callbacks threw")}function Pe(t,e,n){if(e.length===0)return;if(e.length===1){let u=n(e[0][0]);if(u<3||!$e()){t(e);return}(u>=5?le:u===4?ie:se).push(()=>t(e));return}let r=e.length,o=r,s=r,i=r,a=0;for(;a<r&&n(e[a][0])<3;)a++;for(o=a;a<r&&n(e[a][0])===3;)a++;for(s=a;a<r&&n(e[a][0])===4;)a++;i=a;let c=$e();if(o>0){let u=e.slice(0,o);t(u)}if(s>o){let u=e.slice(o,s);c?se.push(()=>t(u)):t(u)}if(i>s){let u=e.slice(s,i);c?ie.push(()=>t(u)):t(u)}if(r>i){let u=e.slice(i,r);c?le.push(()=>t(u)):t(u)}}var de,be,se,ie,le,ye,ct=j(()=>{"use strict";de=0,be=!1,se=[],ie=[],le=[],ye=[]});function Z(){return Math.trunc(performance.now()*1e6)}function Ie(){return Date.now()*1e6}var Fe=j(()=>{"use strict"});function dt(t){let e=qn.filter(n=>t({type:n,id:""},"write"));return e.length===0?"restricted":e.includes("human")&&e.includes("llm")&&e.every(n=>n==="human"||n==="llm"||n==="system")?"both":e.length===1?e[0]:e.join("+")}var W,qn,je=j(()=>{"use strict";W=class extends Error{actor;action;nodeName;constructor(e,n){super(n??`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}},qn=["human","llm","wallet","system"]});var ve,I,q,J,K,Y,Q,F,H,$,pe,lt,Jn,ft,Yn,Xn,pt,Kt,qt,Jt,ht,_e=j(()=>{"use strict";ve=Symbol.for("graphrefly/START"),I=Symbol.for("graphrefly/DATA"),q=Symbol.for("graphrefly/DIRTY"),J=Symbol.for("graphrefly/RESOLVED"),K=Symbol.for("graphrefly/INVALIDATE"),Y=Symbol.for("graphrefly/PAUSE"),Q=Symbol.for("graphrefly/RESUME"),F=Symbol.for("graphrefly/TEARDOWN"),H=Symbol.for("graphrefly/COMPLETE"),$=Symbol.for("graphrefly/ERROR"),pe=Object.freeze([q]),lt=Object.freeze([J]),Jn=Object.freeze([K]),ft=Object.freeze([ve]),Yn=Object.freeze([H]),Xn=Object.freeze([F]),pt=Object.freeze([pe]),Kt=Object.freeze([lt]),qt=Object.freeze([Jn]),Jt=Object.freeze([Yn]),ht=Object.freeze([Xn])});function Yt(t){t.registerMessageType(ve,{tier:0,wireCrossing:!1}),t.registerMessageType(q,{tier:1,wireCrossing:!1}),t.registerMessageType(K,{tier:1,wireCrossing:!1,metaPassthrough:!1}),t.registerMessageType(Y,{tier:2,wireCrossing:!1}),t.registerMessageType(Q,{tier:2,wireCrossing:!1}),t.registerMessageType(I,{tier:3,wireCrossing:!0}),t.registerMessageType(J,{tier:3,wireCrossing:!0}),t.registerMessageType(H,{tier:4,wireCrossing:!0,metaPassthrough:!1}),t.registerMessageType($,{tier:4,wireCrossing:!0,metaPassthrough:!1}),t.registerMessageType(F,{tier:5,wireCrossing:!0,metaPassthrough:!1})}var Ve,Xt=j(()=>{"use strict";_e();Ve=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=n=>{let r=this._messageTypes.get(n);return r!=null?r.tier:1}}get onMessage(){return this._frozen=!0,this._onMessage}get onSubscribe(){return this._frozen=!0,this._onSubscribe}set onMessage(e){this._assertUnfrozen(),this._onMessage=e}set onSubscribe(e){this._assertUnfrozen(),this._onSubscribe=e}get defaultVersioning(){return this._defaultVersioning}set defaultVersioning(e){this._assertUnfrozen(),this._defaultVersioning=e}get defaultHashFn(){return this._defaultHashFn}set defaultHashFn(e){this._assertUnfrozen(),this._defaultHashFn=e}get inspectorEnabled(){return this._inspectorEnabled}set inspectorEnabled(e){this._inspectorEnabled=e}get globalInspector(){return this._globalInspector}set globalInspector(e){this._globalInspector=e}get rigorRecorder(){return this._rigorRecorder}set rigorRecorder(e){this._rigorRecorder=e}registerMessageType(e,n){return this._assertUnfrozen(),this._messageTypes.set(e,{tier:n.tier,wireCrossing:n.wireCrossing??n.tier>=3,metaPassthrough:n.metaPassthrough??!0}),this}messageTier(e){let n=this._messageTypes.get(e);return n!=null?n.tier:1}isWireCrossing(e){let n=this._messageTypes.get(e);return n!=null?n.wireCrossing:!0}isLocalOnly(e){return!this.isWireCrossing(e)}isMetaPassthrough(e){let n=this._messageTypes.get(e);return n!=null?n.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 gt(t){if(t===void 0)return null;if(typeof t=="number"){if(!Number.isFinite(t))throw new TypeError(`Cannot hash non-finite number: ${t}`);if(Number.isInteger(t)&&!Number.isSafeInteger(t))throw new TypeError(`Cannot hash integer outside safe range (|n| > 2^53-1): ${t}. Cross-language cid parity is not guaranteed for unsafe integers.`);return t}if(typeof t=="string"||typeof t=="boolean"||t===null)return t;if(Array.isArray(t))return t.map(gt);if(typeof t=="object"&&t!==null){let e={};for(let n of Object.keys(t).sort())e[n]=gt(t[n]);return e}return null}function er(t){let e=Qn.encode(t),n=e.length,r=n*8,o=n+9+63&-64,s=new Uint8Array(o);s.set(e),s[n]=128;let i=new DataView(s.buffer);i.setUint32(o-4,r>>>0,!1),i.setUint32(o-8,Math.floor(r/4294967296)>>>0,!1);let a=1779033703,c=3144134277,u=1013904242,d=2773480762,f=1359893119,p=2600822924,h=528734635,l=1541459225,b=new Uint32Array(64),g=(y,m)=>y>>>m|y<<32-m;for(let y=0;y<o;y+=64){for(let w=0;w<16;w++)b[w]=i.getUint32(y+w*4,!1);for(let w=16;w<64;w++){let G=b[w-15],A=b[w-2],D=g(G,7)^g(G,18)^G>>>3,X=g(A,17)^g(A,19)^A>>>10;b[w]=b[w-16]+D+b[w-7]+X>>>0}let m=a,v=c,_=u,k=d,E=f,O=p,N=h,S=l;for(let w=0;w<64;w++){let G=g(E,6)^g(E,11)^g(E,25),A=E&O^~E&N,D=S+G+A+Zn[w]+b[w]>>>0,X=g(m,2)^g(m,13)^g(m,22),ue=m&v^m&_^v&_,oe=X+ue>>>0;S=N,N=O,O=E,E=k+D>>>0,k=_,_=v,v=m,m=D+oe>>>0}a=a+m>>>0,c=c+v>>>0,u=u+_>>>0,d=d+k>>>0,f=f+E>>>0,p=p+O>>>0,h=h+N>>>0,l=l+S>>>0}let x=y=>y.toString(16).padStart(8,"0");return x(a)+x(c)+x(u)+x(d)+x(f)+x(p)+x(h)+x(l)}function mt(t){let e=gt(t??null),n=JSON.stringify(e);return er(n).slice(0,16)}function tr(){let t=globalThis.crypto;if(t?.randomUUID)return t.randomUUID();let e=()=>Math.floor(Math.random()*4294967296).toString(16).padStart(8,"0"),n=e()+e()+e()+e();return`${n.slice(0,8)}-${n.slice(8,12)}-4${n.slice(13,16)}-${(parseInt(n.slice(16,17),16)&3|8).toString(16)}${n.slice(17,20)}-${n.slice(20,32)}`}function bt(t,e,n){let r=n?.id??tr();if(t===0)return{id:r,version:0};let s=(n?.hash??mt)(e);return{id:r,version:0,cid:s,prev:null}}function Zt(t,e,n){t.version+=1,"cid"in t&&(t.prev=t.cid,t.cid=n(e))}var Zn,Qn,Qt=j(()=>{"use strict";Zn=new Uint32Array([1116352408,1899447441,3049323471,3921009573,961987163,1508970993,2453635748,2870763221,3624381080,310598401,607225278,1426881987,1925078388,2162078206,2614888103,3248222580,3835390401,4022224774,264347078,604807628,770255983,1249150122,1555081692,1996064986,2554220882,2821834349,2952996808,3210313671,3336571891,3584528711,113926993,338241895,666307205,773529912,1294757372,1396182291,1695183700,1986661051,2177026350,2456956037,2730485921,2820302411,3259730800,3345764771,3516065817,3600352804,4094571909,275423344,430227734,506948616,659060556,883997877,958139571,1322822218,1537002063,1747873779,1955562222,2024104815,2227730452,2361852424,2428436474,2756734187,3204031479,3329325298]),Qn=new TextEncoder});function nn(t){return{node:t,unsub:null,prevData:void 0,dirty:!1,involvedThisWave:!1,dataBatch:[],terminal:void 0}}function yt(t){t.prevData=void 0,t.dirty=!1,t.involvedThisWave=!1,t.dataBatch.length=0,t.terminal=void 0}function He(t){return t.length===0?t:typeof t[0]=="symbol"?[t]:t}function Be(t,e,n){let r=rn(t)?t:[],o=typeof t=="function"?t:typeof e=="function"?e:void 0,s={};return rn(t)?s=(vt(e)?e:n)??{}:vt(t)?s=t:s=(vt(e)?e:n)??{},new P(r,o,s)}var en,tn,nr,rr,he,P,rn,vt,xe=j(()=>{"use strict";Re();ut();ct();Fe();Xt();je();_e();Qt();en=()=>{},tn=100;nr=(t,e,n,r)=>{n.direction==="down-in"&&t._onDepMessage(n.depIndex,e)},rr=(t,e,n,r)=>{let o=t;if(o._status==="completed"||o._status==="errored")return;let s=o._cached,i=s===void 0?[ft]:[ft,[I,s]];o._status==="dirty"&&i.push(pe),Pe(e,i,o._config.tierOf)},he=new Ve({onMessage:nr,onSubscribe:rr});Yt(he);De(he);P=class t{_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,n,r){this._config=r.config??he,this._config.onMessage,this._optsName=r.name,this._describeKind=r.describeKind,this._equals=r.equals??Object.is,this._resubscribable=r.resubscribable??!1,this._resetOnTeardown=r.resetOnTeardown??!1,this._autoComplete=r.completeWhenDepsComplete??!0,this._autoError=r.errorWhenDepsError??!0,this._pausable=r.pausable??!0,this._guard=r.guard,this._fn=n,this._partial=r.partial??!1,this._cached=r.initial!==void 0?r.initial:void 0,this._status=e.length===0&&n==null&&this._cached!==void 0?"settled":"sentinel",this._hashFn=r.versioningHash??this._config.defaultHashFn??mt;let o=r.versioning??this._config.defaultVersioning;this._versioningLevel=o,this._versioning=o!=null?bt(o,this._cached===void 0?void 0:this._cached,{id:r.versioningId,hash:this._hashFn}):void 0,this._deps=e.map(nn);let s={};for(let[a,c]of Object.entries(r.meta??{})){let u={initial:c,name:`${r.name??"node"}:meta:${a}`,describeKind:"state",config:this._config};r.guard!=null&&(u.guard=r.guard),s[a]=new t([],void 0,u)}Object.freeze(s),this.meta=s,this._hasMeta=Object.keys(s).length>0;let i=this;this._actions={emit(a){i._emit([[I,a]])},down(a){i._emit(He(a))},up(a){i._emitUp(He(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,n){if(this._isExecutingFn)throw new Error(`Node "${this.name}": _applyVersioning cannot run mid-fn \u2014 call it outside of \`_execFn\` (typically at graph setup time before the first subscribe).`);let r=this._versioningLevel;if(r!=null&&e<=r)return;let o=n?.hash??this._hashFn;o!==this._hashFn&&(this._hashFn=o);let s=this._cached===void 0?void 0:this._cached,i=this._versioning,a=i?.id??n?.id,c=i?.version??0,u=bt(e,s,{id:a,hash:o});u.version=c,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 n=Le(e);if(this._guard!=null&&!this._guard(n,"observe"))return!1;if(this._extraGuards!=null){for(let r of this._extraGuards)if(!r(n,"observe"))return!1}return!0}_checkGuard(e){if(e?.internal)return;let n=this._guard!=null||this._extraGuards!=null,r=e?.actor!=null;if(!n&&!r)return;let o=Le(e?.actor),s=e?.delivery==="signal"?"signal":"write";if(this._guard!=null&&!this._guard(o,s))throw new W({actor:o,action:s,nodeName:this.name});if(this._extraGuards!=null){for(let i of this._extraGuards)if(!i(o,s))throw new W({actor:o,action:s,nodeName:this.name})}this._lastMutation={actor:o,timestamp_ns:Ie()}}down(e,n){let r=He(e);r.length!==0&&(this._checkGuard(n),this._emit(r))}emit(e,n){this._checkGuard(n),this._emit([[I,e]])}up(e,n){if(this._deps.length===0)return;let r=He(e);if(r.length===0)return;this._checkGuard(n);let o=n??{internal:!0};this._validateUpTiers(r);for(let s of this._deps)s.node.up?.(r,o)}_emitUp(e){if(this._deps.length!==0&&e.length!==0){this._validateUpTiers(e);for(let n of this._deps)n.node.up?.(e,{internal:!0})}}_validateUpTiers(e){let n=this._config.tierOf;for(let r of e){let o=n(r[0]);if(o===3||o===4)throw new Error(`Node "${this.name}": tier-${o} messages cannot flow up \u2014 DATA/RESOLVED/COMPLETE/ERROR are downstream-only. Use \`down(...)\` for value delivery; \`up(...)\` is for control signals (DIRTY, INVALIDATE, PAUSE, RESUME, TEARDOWN).`)}}subscribe(e,n){if(n!=null&&this._guard!=null){let c=Le(n);if(!this._guard(c,"observe"))throw new W({actor:c,action:"observe",nodeName:this.name})}let o=this._isTerminal&&this._resubscribable;if(o){this._cached=void 0,this._status="sentinel",this._store={},this._hasCalledFnOnce=!1,this._waveHasNewData=!1,this._hasNewTerminal=!1,this._paused=!1,this._pendingWave=!1,this._pendingRerun=!1,this._isExecutingFn=!1,this._rerunDepth=0,this._dirtyDepCount=0,this._pauseLocks=null,this._pauseBuffer=null;for(let c of this._deps)yt(c);if(this._partial===!1){for(let c of this._deps)if(c.prevData!==void 0||c.dataBatch.length!==0||c.terminal!==void 0||c.dirty)throw new Error(`resubscribable-reset invariant: DepRecord not fully reset for node ${this._optsName??"(anonymous)"}`)}}this._sinkCount+=1;let s;try{s=this._config.onSubscribe(this,e,{sinkCount:this._sinkCount,afterTerminalReset:o},this._actions)}catch(c){throw this._sinkCount-=1,c}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(c){if(this._sinkCount-=1,this._removeSink(e),this._sinkCount===0&&(this._status="sentinel"),typeof s=="function")try{s()}catch{}throw c}this._status==="sentinel"&&this._cached===void 0&&(this._status="pending");let a=!1;return()=>{a||(a=!0,this._sinkCount-=1,this._removeSink(e),typeof s=="function"&&s(),this._sinks==null&&this._deactivate())}}_removeSink(e){if(this._sinks===e)this._sinks=null;else if(this._sinks!=null&&typeof this._sinks!="function")if(this._sinks.delete(e),this._sinks.size===1){let[n]=this._sinks;this._sinks=n}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,n=0;try{for(let r=0;r<e;r++){let o=r,s=this._deps[r];s.unsub=en,s.unsub=s.node.subscribe(i=>{if(s.unsub===null)return;let a=this._config.tierOf,c=!1;for(let u of i)a(u[0])>=3&&(c=!0),this._config.onMessage(this,u,{direction:"down-in",depIndex:o},this._actions);c&&this._maybeRunFnOnSettlement()}),n++}}catch(r){this._deps[n].unsub=null;for(let o=0;o<n;o++){let s=this._deps[o];if(s.unsub!=null){let i=s.unsub;s.unsub=null;try{i()}catch{}yt(s)}}throw this._dirtyDepCount=0,r}}_addDep(e){for(let o=0;o<this._deps.length;o++)if(this._deps[o].node===e)return o;let n=this._deps.length,r=nn(e);if(this._deps.push(r),this._sinks==null)return n;r.dirty=!0,this._dirtyDepCount++,this._status!=="dirty"&&this._emit(pt),r.unsub=en;try{r.unsub=e.subscribe(o=>{if(r.unsub===null)return;let s=this._config.tierOf,i=!1;for(let a of o)s(a[0])>=3&&(i=!0),this._config.onMessage(this,a,{direction:"down-in",depIndex:n},this._actions);i&&this._maybeRunFnOnSettlement()})}catch(o){throw r.unsub=null,this._deps.pop(),this._dirtyDepCount--,o}return n}_deactivate(e=!1){let n=this._cleanup;if(this._cleanup=void 0,typeof n=="function")try{n()}catch(r){this._emit([[$,this._wrapFnError("cleanup threw",r)]])}else if(n!=null&&typeof n=="object"){let r=n.deactivate;if(typeof r=="function")try{r()}catch(o){this._emit([[$,this._wrapFnError("cleanup.deactivate threw",o)]])}}for(let r of this._deps){if(r.unsub!=null){let o=r.unsub;r.unsub=null;try{o()}catch{}}yt(r)}this._waveHasNewData=!1,this._hasNewTerminal=!1,this._hasCalledFnOnce=!1,this._paused=!1,this._pendingWave=!1,this._pendingRerun=!1,this._rerunDepth=0,this._store={},this._dirtyDepCount=0,this._pauseLocks=null,this._pauseBuffer=null,this._fn!=null&&(this._cached=void 0),e||(this._fn!=null||this._deps.length>0)&&(!this._isTerminal||this._resubscribable)&&(this._status="sentinel")}_onDepMessage(e,n){let r=this._deps[e],o=n[0];if(this._inspectorHooks!=null){let s={kind:"dep_message",depIndex:e,message:n};for(let i of this._inspectorHooks)i(s)}if(o!==ve){if(o===q){this._depDirtied(r);return}if(o===K){if(this._depInvalidated(r),this._cached===void 0)return;this._emit(qt);return}if(o===Y||o===Q){this._emit([n]);return}if(o===F){this._emit(ht);return}if(o===I)this._depSettledAsData(r,n[1]);else if(o===J)this._depSettledAsResolved(r);else if(o===H)this._depSettledAsTerminal(r,!0);else if(o===$)this._depSettledAsTerminal(r,n[1]);else{this._emit([n]);return}if(!this._fn){(o===I||o===J)&&this._emit([n]),(o===H||o===$)&&this._maybeAutoTerminalAfterWave();return}}}_depDirtied(e){e.dirty||(e.dirty=!0,e.involvedThisWave=!0,this._dirtyDepCount++,this._status!=="dirty"&&this._emit(pt))}_depSettledAsData(e,n){e.dirty&&(e.dirty=!1,this._dirtyDepCount--),e.involvedThisWave=!0,e.dataBatch.push(n),this._waveHasNewData=!0}_depSettledAsResolved(e){e.dirty&&(e.dirty=!1,this._dirtyDepCount--)}_depSettledAsTerminal(e,n){e.dirty&&(e.dirty=!1,this._dirtyDepCount--),e.terminal=n,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 n=this._deps[e];if(n.dataBatch.length===0&&n.prevData===void 0&&n.terminal===void 0){this._maybeAutoTerminalAfterWave();return}}if(this._paused){this._pendingWave=!0;return}if(!this._waveHasNewData&&!this._hasNewTerminal&&this._hasCalledFnOnce){this._clearWaveFlags(),this._emit(Kt),this._maybeAutoTerminalAfterWave();return}this._fn&&this._execFn(),this._maybeAutoTerminalAfterWave()}}_maybeAutoTerminalAfterWave(){if(this._deps.length===0||this._isTerminal)return;let e=this._deps.find(n=>n.terminal!==void 0&&n.terminal!==!0);if(e!=null){this._autoError&&this._emit([[$,e.terminal]]);return}this._autoComplete&&this._deps.every(n=>n.terminal!==void 0)&&this._emit(Jt)}_execFn(){if(!this._fn||this._isTerminal&&!this._resubscribable)return;if(this._isExecutingFn){this._pendingRerun=!0;return}let e=this._cleanup;if(typeof e=="function"){this._cleanup=void 0;try{e()}catch(i){this._emit([[$,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([[$,this._wrapFnError("cleanup.beforeRun threw",a)]]);return}}}let n=this._deps.map(i=>i.involvedThisWave?i.dataBatch.length>0?[...i.dataBatch]:[]:void 0),r=this._deps.map(i=>i.prevData);for(let i=0;i<this._deps.length;i++){let a=n[i];a!=null&&a.length>0&&(this._deps[i].prevData=a[a.length-1])}let o=this._deps.map(i=>i.terminal),s={prevData:r,terminalDeps:o,store:this._store};if(this._hasCalledFnOnce=!0,this._clearWaveFlags(),this._inspectorHooks!=null){let i={kind:"run",batchData:n,prevData:r};for(let a of this._inspectorHooks)a(i)}this._isExecutingFn=!0;try{let i=this._fn(n,this._actions,s);if(typeof i=="function")this._cleanup=i;else if(i!=null&&typeof i=="object"){let a=i;(typeof a.beforeRun=="function"||typeof a.deactivate=="function"||typeof a.invalidate=="function")&&(this._cleanup=i)}}catch(i){this._emit([[$,this._wrapFnError("fn threw",i)]])}finally{this._isExecutingFn=!1,this._pendingRerun?(this._pendingRerun=!1,this._rerunDepth+=1,this._rerunDepth>tn?(this._rerunDepth=0,this._emit([[$,new Error(`Node "${this.name}": _pendingRerun depth exceeded ${tn} \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,n){let r=n instanceof Error?n.message:String(n);return new Error(`Node "${this.name}": ${e}: ${r}`,{cause:n})}_frameBatch(e){let n=this._config.tierOf;if(e.length===1)return n(e[0][0])===3&&this._status!=="dirty"?[pe,e[0]]:e;let r=!0,o=!1,s=!1,i=-1;for(let c of e){let u=n(c[0]);u<i&&(r=!1),u===3&&(o=!0),c[0]===q&&(s=!0),i=u}let a=e;if(!r){let c=e.map((u,d)=>({m:u,i:d,tier:n(u[0])}));c.sort((u,d)=>u.tier-d.tier||u.i-d.i),a=c.map(u=>u.m)}if(o&&!s&&this._status!=="dirty"){let c=0;for(;c<a.length&&n(a[c][0])===0;)c++;return c===0?[pe,...a]:[...a.slice(0,c),pe,...a.slice(c)]}return a}_emit(e){if(e.length===0)return;for(let a=0;a<e.length;a++){let c=e[a];if(c[0]===$&&c[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 n=e;if(this._isTerminal&&!this._resubscribable){let a=e.filter(c=>c[0]===F||c[0]===K);if(a.length===0)return;n=a}n=this._frameBatch(n);let o=null;for(let a=0;a<n.length;a++){let c=n[a],u=c[0];if(u!==Y&&u!==Q){o?.push(c);continue}if(c.length<2)throw new Error(`Node "${this.name}": [[${u===Y?"PAUSE":"RESUME"}]] must carry a lockId payload \u2014 bare PAUSE/RESUME is a protocol violation (C0 rule). Use \`[[PAUSE, lockId]]\` / \`[[RESUME, lockId]]\`.`);let d=!0;if(this._pausable!==!1){let f=c[1];if(u===Y)this._pauseLocks==null&&(this._pauseLocks=new Set),this._pauseLocks.add(f),this._paused=!0,this._pausable==="resumeAll"&&this._pauseBuffer==null&&(this._pauseBuffer=[]);else if(this._pauseLocks==null||!this._pauseLocks.has(f))d=!1;else if(this._pauseLocks.delete(f),this._pauseLocks.size===0){if(this._paused=!1,this._pauseBuffer!=null&&this._pauseBuffer.length>0){let p=this._pauseBuffer;this._pauseBuffer=[],this._emit(p)}this._pendingWave&&(this._pendingWave=!1,this._maybeRunFnOnSettlement())}}d?o?.push(c):o==null&&(o=n.slice(0,a))}if(o!=null){if(o.length===0)return;n=o}if(this._hasMeta&&n.some(a=>a[0]===F))for(let a of Object.keys(this.meta))try{this.meta[a]._emit(ht)}catch{}let{finalMessages:s,equalsError:i}=this._updateState(n);if(s.length>0&&this._config.inspectorEnabled){let a=this._config.globalInspector;if(a!=null)try{a({kind:"emit",node:this,messages:s})}catch{}}if(s.length>0)if(this._paused&&this._pausable==="resumeAll"&&this._pauseBuffer!=null){let a=this._config.tierOf,c=[];for(let u of s)a(u[0])===3?this._pauseBuffer.push(u):c.push(u);c.length>0&&this._dispatchOrAccumulate(c)}else this._dispatchOrAccumulate(s);i!=null&&this._emit([[$,i]])}_updateState(e){let n=this._config.tierOf,r,o,s=-1,i=0;for(let d of e)n(d[0])===3&&i++;let a=i<=1,c=-1;if(this._versioning!=null&&i>1){for(let d=e.length-1;d>=0;d--)if(e[d][0]===I){c=d;break}}for(let d=0;d<e.length;d++){let f=e[d],p=f[0];if(p===I){if(f.length>=2){let h=!1;if(a&&this._cached!==void 0)try{h=this._equals(this._cached,f[1])}catch(l){o=this._wrapFnError("equals threw",l),s=d;break}if(h){r==null&&(r=e.slice(0,d)),r.push(lt),this._status="resolved";continue}this._cached=f[1],this._versioning!=null&&(c<0||d===c)&&Zt(this._versioning,f[1],this._hashFn)}this._status="settled",r?.push(f)}else if(r?.push(f),p===q)this._status="dirty";else if(p===J)this._status="resolved";else if(p===H){this._status="completed";{let h=this._config.rigorRecorder;if(h!=null)try{h.onTerminalTransition(this,"completed",this._autoComplete,this._autoError,this._deps.length>0)}catch{}}}else if(p===$){this._status="errored";{let h=this._config.rigorRecorder;if(h!=null)try{h.onTerminalTransition(this,"errored",this._autoComplete,this._autoError,this._deps.length>0)}catch{}}}else if(p===K){if(this._cached!==void 0){let l=this._config.rigorRecorder;if(l!=null)try{l.onNonVacuousInvalidate(this,this._cached)}catch{}}this._cached=void 0,this._status="dirty";let h=this._cleanup;if(typeof h=="function"){this._cleanup=void 0;try{h()}catch{}}else if(h!=null&&typeof h=="object"){let l=h.invalidate;if(typeof l=="function")try{l()}catch{}}}else p===F&&(this._resetOnTeardown&&(this._cached=void 0),this._deactivate(!0),this._status="sentinel")}let u=s>=0?r??e.slice(0,s):r??e;return o!=null?{finalMessages:u,equalsError:o}:{finalMessages:u}}_deliverToSinks=e=>{if(this._sinks==null)return;if(typeof this._sinks=="function"){this._sinks(e);return}let n=[...this._sinks];for(let r of n)r(e)};_dispatchOrAccumulate(e){if(Ut()){this._batchPendingMessages===null&&(this._batchPendingMessages=[],fe(()=>this._flushBatchPending()));for(let n of e)this._batchPendingMessages.push(n);return}Pe(this._deliverToSinks,e,this._config.tierOf)}_flushBatchPending(){let e=this._batchPendingMessages;if(e===null||(this._batchPendingMessages=null,e.length===0))return;let n=this._frameBatch(e);Pe(this._deliverToSinks,n,this._config.tierOf)}},rn=t=>Array.isArray(t),vt=t=>typeof t=="object"&&t!=null&&!Array.isArray(t)});function _t(t,e){if(e!=null&&e.length>0)return new Set(e);switch(t){case"standard":return new Set(["type","status","value","deps","meta","v"]);case"full":return null;case"spec":return new Set(["type","deps","meta","value"]);default:return new Set(["type","deps"])}}function or(t){return t._describeKind!=null?t._describeKind:t._deps.length>0?"derived":t._fn!=null?"producer":"state"}function sr(t){let e={};for(let[n,r]of Object.entries(t.meta))try{e[n]=r.cache}catch{}return e}function xt(t,e,n){let r=e==null,o=!r&&e!=null?[...e].filter(d=>d.startsWith("meta.")).map(d=>d.slice(5)):null,s=r||e.has("meta")||o!=null&&o.length>0,i="state",a=[];t instanceof P&&(i=or(t),a=t._deps.map(d=>d.node.name??""));let c={type:i,deps:a};(r||e.has("status"))&&(c.status=t.status);let u=t instanceof P?t._guard:void 0;if(s){let d={...sr(t)};if(u!=null&&d.access===void 0&&(d.access=dt(u)),o!=null&&o.length>0&&!e.has("meta")){let f={};for(let p of o)p in d&&(f[p]=d[p]);c.meta=f}else c.meta=d}if(t.name!=null&&(c.name=t.name),(r||e.has("value"))&&(!n||i==="state")){t.status==="sentinel"&&(c.sentinel=!0);try{c.value=t.cache}catch{}}if((r||e.has("v"))&&t.v!=null){let d={id:t.v.id,version:t.v.version};"cid"in t.v&&(d.cid=t.v.cid,d.prev=t.v.prev),c.v=d}return(r||e.has("guard"))&&u!=null&&(c.guard=dt(u)),(r||e.has("lastMutation"))&&t.lastMutation!=null&&(c.lastMutation=t.lastMutation),c}var on=j(()=>{"use strict";je();xe()});function we(t,e){return Be([],{...e,initial:t})}function wt(t,e){return Be((r,o,s)=>t(o,s)??void 0,{describeKind:"producer",...e})}function Ot(t,e,n){return Be(t,(o,s,i)=>{let a=o.map((c,u)=>c!=null&&c.length>0?c.at(-1):i.prevData[u]);s.emit(e(a,i))},{describeKind:"derived",...n})}var sn=j(()=>{"use strict";xe()});function ze(t){return t.subscribe(()=>{})}var un=j(()=>{"use strict"});var cn=j(()=>{"use strict";un()});var Ue,dn=j(()=>{"use strict";Ue=class{_timer;_gen=0;start(e,n){this.cancel(),this._gen+=1;let r=this._gen;this._timer=setTimeout(()=>{this._timer=void 0,r===this._gen&&n()},e)}cancel(){this._timer!==void 0&&(clearTimeout(this._timer),this._timer=void 0)}get pending(){return this._timer!==void 0}}});var Oe,ln=j(()=>{"use strict";Oe=class{constructor(e){this.capacity=e;if(!Number.isInteger(e)||e<=0)throw new Error(`RingBuffer capacity must be a positive integer (got ${e})`);this.buf=new Array(e)}buf;head=0;_size=0;get size(){return this._size}get maxSize(){return this.capacity}push(e){let n=(this.head+this._size)%this.capacity;this.buf[n]=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 n=e<0?this._size+e:e;if(!(n<0||n>=this._size))return this.buf[(this.head+n)%this.capacity]}toArray(){let e=new Array(this._size);for(let n=0;n<this._size;n++)e[n]=this.buf[(this.head+n)%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={};Fn(Vr,{ENVELOPE_VERSION:()=>me,GRAPH_META_SEGMENT:()=>B,Graph:()=>ne,JsonCodec:()=>at,SIZEOF_OVERHEAD:()=>L,SIZEOF_SYMBOL:()=>it,SNAPSHOT_VERSION:()=>te,createDagCborCodec:()=>Ft,createDagCborZstdCodec:()=>jt,decodeEnvelope:()=>Se,diffForWAL:()=>St,encodeEnvelope:()=>Ne,explainPath:()=>Ge,graphProfile:()=>We,reachable:()=>qe,registerBuiltinCodecs:()=>De,replayWAL:()=>Vt,sizeof:()=>Ee,validateGraphObservability:()=>Ln,watchTopologyTree:()=>vn});module.exports=Vn(Vr);var L={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},it=Symbol.for("sizeof");function Ee(t){let e=new WeakSet,n=new WeakSet,r=[t],o=0;for(;r.length>0;){let s=r.pop();o+=Hn(s,e,n,r)}return o}function Hn(t,e,n,r){if(t==null)return 0;switch(typeof t){case"number":return L.number;case"boolean":return L.boolean;case"string":return L.string+t.length*2;case"bigint":return L.bigint+Bn(t);case"symbol":return L.symbol;case"function":return e.has(t)?0:(e.add(t),L.function);case"undefined":return 0}let s=t;if(e.has(s))return 0;e.add(s);let i=s[it];if(typeof i=="function")try{let u=i.call(s);if(typeof u=="number"&&Number.isFinite(u))return u}catch{}if(s instanceof Date)return L.date;if(s instanceof RegExp)return L.regexp+s.source.length*2;if(s instanceof Error){let u=s.message?s.message.length*2:0,d=s.stack?s.stack.length*2:0;return L.error+u+d}if(typeof URL<"u"&&s instanceof URL)return L.url+s.href.length*2;if(typeof Promise<"u"&&s instanceof Promise)return L.promise;if(s instanceof WeakMap)return L.weakmap;if(s instanceof WeakSet)return L.weakset;if(s instanceof Map){let u=L.map;for(let[d,f]of s)u+=L.mapEntry,r.push(d),r.push(f);return u}if(s instanceof Set){let u=L.set;for(let d of s)u+=L.setEntry,r.push(d);return u}if(Array.isArray(s)){let u=L.array+s.length*8;for(let d of s)r.push(d);return u}if(s instanceof ArrayBuffer)return n.has(s)?0:(n.add(s),s.byteLength);if(ArrayBuffer.isView(s)){let u=s;return n.has(u.buffer)?48:(n.add(u.buffer),u.buffer.byteLength+48)}let a=L.object,c=Object.keys(s);for(let u of c){a+=L.string+u.length*2;try{r.push(s[u])}catch{}}return a}function Bn(t){let e=t<0n?-t:t;if(e===0n)return 0;let n=e.toString(2).length;return Math.ceil(n/32)*8}Re();function Ge(t,e,n,r={}){let o=e in t.nodes,s=n in t.nodes;if(!o)return Ae(e,n,"no-such-from");if(!s)return Ae(e,n,"no-such-to");let i=r.maxDepth;if(i!=null&&(!Number.isInteger(i)||i<0))throw new Error("explainPath: maxDepth must be an integer >= 0");if(e===n){if(r.findCycle===!0){let u=zn(t,e,r);if(u!=null)return u}let c=Ce(e,t.nodes[e],0,r);return Me(e,n,[c])}if(i===0)return Ae(e,n,"no-path");let a=Ht(t,e,n,i);return a.found?Me(e,n,Bt(t,a.pathOrder,r)):Ae(e,n,a.truncated?"max-depth-exceeded":"no-path")}function Ht(t,e,n,r){let o=new Map,s=[{path:n,depth:0}],i=new Set([n]),a=0,c=!1;for(;a<s.length;){let f=s[a++];if(f.path===e)break;if(r!=null&&f.depth>=r){let b=t.nodes[f.path];b?.deps&&b.deps.length>0&&(c=!0);continue}let p=t.nodes[f.path];if(p==null)continue;let h=p.deps??[],l=new Map;for(let b=0;b<h.length;b++){let g=h[b];if(!g)continue;let x=l.get(g);x==null&&(x=[],l.set(g,x)),x.push(b)}for(let[b,g]of l)i.has(b)||(i.add(b),o.set(b,{from:f.path,depIndices:g}),s.push({path:b,depth:f.depth+1}))}if(!o.has(e))return{found:!1,pathOrder:[],truncated:c};let u=[{path:e}],d=e;for(;d!==n;){let f=o.get(d);if(f==null)return{found:!1,pathOrder:[],truncated:!1};u[u.length-1].depIndices=f.depIndices,u.push({path:f.from}),d=f.from}return{found:!0,pathOrder:u,truncated:!1}}function zn(t,e,n){let r=t.nodes[e];if(r==null)return null;let o=r.deps??[],s=[];for(let a=0;a<o.length;a++)o[a]===e&&s.push(a);if(s.length>0){let a=Ce(e,r,0,n);a.dep_index=s[0];let c=Ce(e,r,1,n);return Me(e,e,[a,c])}let i=null;for(let a=0;a<o.length;a++){let c=o[a];if(!c||c===e)continue;let u=Ht(t,c,e,n.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:Me(e,e,Bt(t,i.pathOrder,n))}function Bt(t,e,n){return e.map((r,o)=>{let s=t.nodes[r.path],i=Ce(r.path,s,o,n);return r.depIndices!=null&&r.depIndices.length>0&&(i.dep_index=r.depIndices[0],r.depIndices.length>1&&(i.dep_indices=[...r.depIndices])),i})}function Ce(t,e,n,r){let o={path:t,type:e.type,hop:n};e.status!==void 0&&(o.status=e.status),"value"in e&&(o.value=e.value),e.v!=null&&(o.v=e.v);let s=r.annotations?.get(t)??e.annotation;s!=null&&(o.annotation=s);let i=r.lastMutations?.get(t)??e.lastMutation;return i!=null&&(o.lastMutation=i),o}function Me(t,e,n){return zt(t,e,!0,"ok",n)}function Ae(t,e,n){return zt(t,e,!1,n,[])}function zt(t,e,n,r,o){let s=Un(t,e,n,r,o);return{from:t,to:e,found:n,reason:r,steps:o,text:s,toJSON(){return{from:t,to:e,found:n,reason:r,steps:o}}}}function Un(t,e,n,r,o){if(!n)switch(r){case"no-such-from":return`explainPath: no node named "${t}"`;case"no-such-to":return`explainPath: no node named "${e}"`;case"max-depth-exceeded":return`explainPath: no path from "${t}" to "${e}" within maxDepth`;default:return`explainPath: no path from "${t}" to "${e}"`}let s=[`Causal path: ${t} \u2192 ${e} (${o.length} step(s))`];for(let i of o){let c=` ${i.hop===0?"\xB7":"\u2193"} ${i.path} (${i.type}${i.status?`/${i.status}`:""})`;if(s.push(c),"value"in i&&s.push(` value: ${Wn(i.value)}`),i.annotation!=null&&s.push(` annotation: ${i.annotation}`),i.lastMutation!=null){let u=i.lastMutation.actor;s.push(` actor: ${u.type}${u.id?`:${u.id}`:""}`)}}return s.join(`
|
|
2
|
-
`)}function Wn(t){if(t===void 0)return"<sentinel>";if(t===null)return"null";if(typeof t=="string")return JSON.stringify(t);if(typeof t=="number"||typeof t=="boolean"||typeof t=="bigint")return String(t);try{let e=JSON.stringify(t);return e.length>80?`${e.slice(0,77)}...`:e}catch{return String(t)}}ut();ct();Fe();je();_e();on();xe();sn();Fe();function Tt(t,e){if(Object.is(t,e))return!0;if(t==null||e==null||typeof t!="object"||typeof e!="object")return!1;if(Array.isArray(t)){if(!Array.isArray(e)||t.length!==e.length)return!1;for(let s=0;s<t.length;s++)if(!Tt(t[s],e[s]))return!1;return!0}if(Array.isArray(e))return!1;let n=Object.keys(t),r=Object.keys(e);if(n.length!==r.length)return!1;let o=new Set(r);for(let s of n)if(!o.has(s)||!Tt(t[s],e[s]))return!1;return!0}function an(t,e){return`${t}\0${e}`}function kt(t,e){let n=[],r=new Set(t.subgraphs),o=new Set(e.subgraphs),s=[];for(let g of o)r.has(g)||s.push(g);s.sort();for(let g of s)n.push({type:"subgraph-mounted",path:g});let i=new Set(Object.keys(t.nodes)),a=new Set(Object.keys(e.nodes)),c=[];for(let g of a)i.has(g)||c.push(g);c.sort();for(let g of c)n.push({type:"node-added",path:g,node:{...e.nodes[g]}});let u=[];for(let g of a){if(!i.has(g))continue;let x=t.nodes[g]?.meta,y=e.nodes[g]?.meta;x==null&&y==null||Tt(x??{},y??{})||u.push(g)}u.sort();for(let g of u)n.push({type:"node-meta-changed",path:g,prevMeta:t.nodes[g]?.meta??{},nextMeta:e.nodes[g]?.meta??{}});let d=new Map;for(let g of t.edges)d.set(an(g.from,g.to),g);let f=new Map;for(let g of e.edges)f.set(an(g.from,g.to),g);let p=[];for(let[g,x]of f)d.has(g)||p.push(x);p.sort((g,x)=>g.from<x.from?-1:g.from>x.from?1:g.to<x.to?-1:g.to>x.to?1:0);for(let g of p)n.push({type:"edge-added",from:g.from,to:g.to});let h=[];for(let[g,x]of d)f.has(g)||h.push(x);h.sort((g,x)=>g.from<x.from?-1:g.from>x.from?1:g.to<x.to?-1:g.to>x.to?1:0);for(let g of h)n.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)n.push({type:"node-removed",path:g});let b=[];for(let g of r)o.has(g)||b.push(g);b.sort();for(let g of b)n.push({type:"subgraph-unmounted",path:g});return{events:n,flushedAt_ns:Z()}}cn();dn();ln();Re();xe();function We(t,e){let n=e?.topN??10,r=t.describe({detail:"standard"}),o=[],s=t._collectObserveTargets;typeof s=="function"&&s.call(t,"",o);let i=new Map;for(let[p,h]of o)i.set(p,h);let a=[];for(let[p,h]of Object.entries(r.nodes)){let l=i.get(p),b=l instanceof P?l:null,g=b?Ee(b.cache):0,x=b?b._sinkCount:0,y=h.deps?.length??0,m=h.type==="effect"&&x===0,v=x===0?h.type==="effect"?"orphan-effect":h.type==="derived"?"idle-derived":h.type==="producer"?"idle-producer":null:null;a.push({path:p,type:h.type,status:h.status??"unknown",valueSizeBytes:g,subscriberCount:x,depCount:y,isOrphanEffect:m,orphanKind:v})}let c=a.reduce((p,h)=>p+h.valueSizeBytes,0),u=(p,h)=>[...a].sort(h??((l,b)=>b[p]-l[p])).slice(0,n),d=a.filter(p=>p.orphanKind!=null),f=a.filter(p=>p.isOrphanEffect);return{nodeCount:a.length,edgeCount:r.edges.length,subgraphCount:r.subgraphs.length,nodes:a,totalValueSizeBytes:c,hotspots:{byValueSize:u("valueSizeBytes"),bySubscriberCount:u("subscriberCount"),byDepCount:u("depCount")},orphans:d,orphanEffects:f}}var M="::",B="__meta__",te=1;function fn(t,e){let n=Math.max(16,t.size*4),r=0;for(;t.size>0;){if(r++>=n){console.error(`[Graph "${e}".destroy] disposer drain exceeded cap (${n}); ${t.size} disposer(s) discarded`),t.clear();return}let o=t.values().next();if(o.done)return;let s=o.value;t.delete(s);try{s()}catch(i){console.error(`[Graph "${e}".destroy] disposer threw:`,i)}}}function bn(t){return t!=null&&typeof t=="object"&&"cache"in t&&typeof t.subscribe=="function"&&typeof t.down=="function"}function ir(t){if(t!=null)return bn(t)?t.cache:t}function ae(t){return t!=null&&typeof t=="object"&&"cache"in t&&typeof t.subscribe=="function"&&typeof t.down=="function"}function ee(t){return ae(t)?t.cache??"":t}function pn(t){return ae(t)?t.cache??0:t}function hn(t){return ae(t)?t.cache??!1:t}function ar(t){let e=[];for(let n of Object.keys(t).sort()){let r=t[n].v;r!=null&&e.push(`${n} ${r.id} ${r.version}`)}return e.join(`
|
|
3
|
-
`)}function gn(t){if(t.version!==te)throw new Error(`unsupported snapshot version ${String(t.version)} (expected ${te})`);for(let e of["name","nodes","edges","subgraphs"])if(!(e in t))throw new Error(`snapshot missing required key "${e}"`);if(typeof t.name!="string")throw new TypeError("snapshot 'name' must be a string");if(typeof t.nodes!="object"||t.nodes===null||Array.isArray(t.nodes))throw new TypeError("snapshot 'nodes' must be an object");if(!Array.isArray(t.edges))throw new TypeError("snapshot 'edges' must be an array");if(!Array.isArray(t.subgraphs))throw new TypeError("snapshot 'subgraphs' must be an array")}function ur(t,e){let n=new WeakMap,r=(o,s)=>{if(Object.is(o,s))return!0;if(o==null||s==null||typeof o!="object"||typeof s!="object")return!1;let i=n.get(o);if(i==null&&(i=new WeakSet,n.set(o,i)),i.has(s))return!0;i.add(s);let a=o.constructor,c=s.constructor;if(a!==c)return!1;if(o instanceof Date)return o.getTime()===s.getTime();if(o instanceof RegExp)return o.source===s.source&&o.flags===s.flags;if(Array.isArray(o)){let p=s;if(o.length!==p.length)return!1;for(let h=0;h<o.length;h++)if(!r(o[h],p[h]))return!1;return!0}if(o instanceof Map){let p=s;if(o.size!==p.size)return!1;for(let[h,l]of o)if(!p.has(h)||!r(l,p.get(h)))return!1;return!0}if(o instanceof Set){let p=s;if(o.size!==p.size)return!1;for(let h of o){let l=!1;for(let b of p)if(r(h,b)){l=!0;break}if(!l)return!1}return!0}if(ArrayBuffer.isView(o)){let p=o,h=s;if(p.length!==h.length)return!1;for(let l=0;l<p.length;l++)if(p[l]!==h[l])return!1;return!0}let u=Object.keys(o),d=Object.keys(s);if(u.length!==d.length)return!1;let f=new Set(d);for(let p of u)if(!f.has(p)||!r(o[p],s[p]))return!1;return!0};return r(t,e)}function cr(t){return t.replace(/[.*+?^${}()|[\]\\]/g,"\\$&")}function Ke(t){let e="^";for(let n=0;n<t.length;n+=1){let r=t[n];if(r==="*"){e+=".*";continue}if(r==="?"){e+=".";continue}if(r==="["){let o=t.indexOf("]",n+1);if(o<=n+1){e+="\\[";continue}let s=t.slice(n+1,o);s.startsWith("!")&&(s=`^${s.slice(1)}`),s=s.replace(/\\/g,"\\\\"),e+=`[${s}]`,n=o;continue}e+=cr(r)}return e+="$",new RegExp(e)}var dr={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"},lr={data:"",dirty:"",resolved:"",invalidate:"",pause:"",resume:"",complete:"",error:"",teardown:"",derived:"",path:"",reset:""};function Et(t){if(typeof t=="string")return JSON.stringify(t);if(typeof t=="number"||typeof t=="boolean"||t==null)return String(t);try{return JSON.stringify(t)}catch{return"[unserializable]"}}function fr(t){return t==="none"?lr:t==="ansi"||t==null?dr:{data:t.data??"",dirty:t.dirty??"",resolved:t.resolved??"",invalidate:t.invalidate??"",pause:t.pause??"",resume:t.resume??"",complete:t.complete??"",error:t.error??"",teardown:t.teardown??"",derived:t.derived??"",path:t.path??"",reset:t.reset??""}}function mn(t){if(t==null)return{};let e=t.detail;return e==="full"?{...t,structured:t.structured??!0,timeline:t.timeline??!0,causal:t.causal??!0,derived:t.derived??!0}:e==="minimal"?{...t,structured:t.structured??!0}:t.format==="stage-log"?{...t,structured:t.structured??!0,timeline:t.timeline??!0}:t}function pr(t,e,n){for(let r=0;r<t.length;r++){let o=t.charCodeAt(r);if(o<32||o===127)throw new Error(`Graph "${e}": ${n} "${t}" must not contain control character (U+${o.toString(16).padStart(4,"0").toUpperCase()} at index ${r})`)}}function Nt(t,e,n){if(t==="")throw new Error(`Graph "${e}": ${n} name must be non-empty`);if(t.includes(M))throw new Error(`Graph "${e}": ${n} "${t}" must not contain '${M}' (path separator)`);if(t===B)throw new Error(`Graph "${e}": ${n} name "${B}" is reserved for meta companion paths`);pr(t,e,n)}function hr(t,e){if(t==="")throw new Error(`Graph "${e}": resolve path must be non-empty`);let n=t.split(M);for(let r of n)if(r==="")throw new Error(`Graph "${e}": resolve path has empty segment`);return n}function gr(t,e){let n=!1;for(let o of t)if(!e.isMetaPassthrough(o[0])){n=!0;break}return n?t.filter(o=>e.isMetaPassthrough(o[0])):t}function yn(t){for(let e of t._mounts.values())yn(e);for(let e of t._nodes.values())try{e.down([[F]],{internal:!0})}catch{}}var ne=class t{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,n){if(e==="")throw new Error("Graph name must be non-empty");if(e.includes(M))throw new Error(`Graph name must not contain '${M}' (got "${e}")`);if(e===B)throw new Error(`Graph name "${B}" is reserved for meta companion paths`);this.name=e,this.opts=Object.freeze({...n??{}}),this.config=n?.config??he,this._traceRing=new Oe(n?.traceCapacity??1e3),n?.versioning!=null&&this.setVersioning(n.versioning),typeof n?.factory=="string"&&(this._factory=n.factory,n.factoryArgs!==void 0&&(this._factoryArgs=n.factoryArgs))}tagFactory(e,n){return this._factory=e,this._factoryArgs=n,this}ancestors(e=!0){let n=[],r=e?this:this._parent;for(;r!=null;)n.push(r),r=r._parent;return n}get topology(){return this._topology==null&&(this._topology=wt(e=>{let n=r=>{e.emit(r)};return this._topologyEmitters.add(n),()=>{this._topologyEmitters.delete(n)}},{name:`${this.name}_topology`})),this._topology}_emitTopology(e){if(!(this._topology==null||this._topologyEmitters.size===0))for(let n of this._topologyEmitters)n(e)}nameOf(e){return this._nodeToName.get(e)}add(e,n){let r=e.name,o=n?.name??r;if(o==null||o==="")throw new Error(`Graph "${this.name}": graph.add requires a non-empty name \u2014 pass via opts.name or set it on the node (e.g. state(0, { name: "x" }))`);let s=o,i=n?.annotation;if(Nt(s,this.name,"add"),this._mounts.has(s))throw new Error(`Graph "${this.name}": name "${s}" is already a mount point`);if(this._nodes.has(s))throw new Error(`Graph "${this.name}": node "${s}" already exists`);let a=this._nodeToName.get(e);if(a!==void 0)throw new Error(`Graph "${this.name}": node instance already registered as "${a}"`);return this._nodes.set(s,e),this._nodeToName.set(e,s),this._emitTopology({kind:"added",name:s,nodeKind:"node"}),i!=null&&(this._annotations.set(s,i),this.config.inspectorEnabled&&this._traceRing.push({path:s,annotation:i,timestamp_ns:Z()})),e}setVersioning(e){if(e!=null)for(let n of this._nodes.values())n instanceof P&&n._applyVersioning(e)}remove(e){Nt(e,this.name,"remove");let n=this._mounts.get(e);if(n){let s={kind:"mount",nodes:[],mounts:[]},i=[];n._collectObserveTargets("",i);for(let[a,c]of i)a.includes(`${M}${B}${M}`)||s.nodes.push(a);return s.nodes.sort(),s.mounts.push(e),s.mounts.push(...n._collectSubgraphs(`${e}${M}`)),this._mounts.delete(e),n._parent=void 0,yn(n),this._emitTopology({kind:"removed",name:e,nodeKind:"mount",audit:s}),s}let r=this._nodes.get(e);if(!r)throw new Error(`Graph "${this.name}": unknown node or mount "${e}"`);this._nodes.delete(e),this._nodeToName.delete(r),r.down([[F]],{internal:!0});let o={kind:"node",nodes:[e],mounts:[]};return this._emitTopology({kind:"removed",name:e,nodeKind:"node",audit:o}),o}removeAll(e){let n=typeof e=="function"?e:(()=>{let s=Ke(e);return i=>s.test(i)})(),r={kind:"mount",nodes:[],mounts:[]},o=[...this._nodes.keys(),...this._mounts.keys()].filter(s=>n(s));for(let s of o){let i=this.remove(s);r.nodes.push(...i.nodes),r.mounts.push(...i.mounts)}return r.nodes.sort(),r.mounts.sort(),r}[Symbol.iterator](){let e=[...this._nodes.keys()].sort(),n=this._nodes,r=0;return{[Symbol.iterator](){return this},next(){if(r>=e.length)return{value:void 0,done:!0};let o=e[r++];return{value:[o,n.get(o)],done:!1}}}}node(e){if(e==="")throw new Error(`Graph "${this.name}": node name must be non-empty`);if(e.includes(M))return this.resolve(e);let n=this._nodes.get(e);if(!n)throw new Error(`Graph "${this.name}": unknown node "${e}"`);return n}get(e){return this.node(e).cache}set(e,n,r){let o=r?.internal===!0;this.node(e).down([[I,n]],{actor:r?.actor,internal:o,delivery:"write"})}setAll(e,n){let r=Symbol.iterator in e?e:Object.entries(e);Wt(()=>{for(let[o,s]of r)this.set(o,s,n)})}invalidate(e,n){let r=n?.internal===!0;this.node(e).down([[K]],{actor:n?.actor,internal:r,delivery:"write"})}error(e,n,r){let o=r?.internal===!0;this.node(e).down([[$,n]],{actor:r?.actor,internal:o,delivery:"write"})}complete(e,n){let r=n?.internal===!0;this.node(e).down([[H]],{actor:n?.actor,internal:r,delivery:"write"})}edges(e){let n=e?.recursive===!0,r=new Map;if(!n){for(let[c,u]of this._nodes)r.set(u,c);let a=[];for(let[c,u]of this._nodes)if(u instanceof P)for(let d of u._deps){let f=r.get(d.node);f!=null&&a.push([f,c])}return a.sort((c,u)=>c[0]<u[0]?-1:c[0]>u[0]?1:c[1]<u[1]?-1:c[1]>u[1]?1:0),a}let o=[];this._collectObserveTargets("",o);let s=new Map;for(let[a,c]of o)s.set(c,a);let i=[];for(let[a,c]of o)if(c instanceof P)for(let u of c._deps){let d=s.get(u.node);d!=null&&i.push([d,a])}return i.sort((a,c)=>a[0]<c[0]?-1:a[0]>c[0]?1:a[1]<c[1]?-1:a[1]>c[1]?1:0),i}mount(e,n){if(n===void 0){let o=new t(e);return this.mount(e,o)}if(typeof n=="function"){let o=new t(e);return n(o),this.mount(e,o)}let r=n;if(Nt(e,this.name,"mount"),this._nodes.has(e))throw new Error(`Graph "${this.name}": cannot mount at "${e}" \u2014 node with that name exists`);if(this._mounts.has(e))throw new Error(`Graph "${this.name}": mount "${e}" already exists`);if(r===this)throw new Error(`Graph "${this.name}": cannot mount a graph into itself`);if(r._parent!=null)throw new Error(`Graph "${this.name}": this child graph is already mounted on "${r._parent.name}"`);for(let o=this;o!=null;o=o._parent)if(o===r)throw new Error(`Graph "${this.name}": mount("${e}", \u2026) would create a mount cycle`);return this._mounts.set(e,r),r._parent=this,this._emitTopology({kind:"added",name:e,nodeKind:"mount"}),r}resolve(e){let n=hr(e,this.name);return this._resolveFromSegments(n)}tryResolve(e){try{return this.resolve(e)}catch{return}}_resolveFromSegments(e){let n=e;if(n[0]===this.name&&(n=n.slice(1),n.length===0))throw new Error(`Graph "${this.name}": resolve path ends at graph name only`);let r=n[0],o=n.slice(1);if(o.length===0){let a=this._nodes.get(r);if(a)return a;throw this._mounts.has(r)?new Error(`Graph "${this.name}": path ends at subgraph "${r}" \u2014 not a node (GRAPHREFLY-SPEC \xA73.5)`):new Error(`Graph "${this.name}": unknown name "${r}"`)}let s=this._nodes.get(r);if(s&&o.length>0&&o[0]===B)return this._resolveMetaChainFromNode(s,o,n.join(M));let i=this._mounts.get(r);if(!i)throw this._nodes.has(r)?new Error(`Graph "${this.name}": "${r}" is a node; trailing path "${o.join(M)}" is invalid`):new Error(`Graph "${this.name}": unknown mount or node "${r}"`);return i.resolve(o.join(M))}_resolveMetaChainFromNode(e,n,r){let o=e,s=0,i=[...n];for(;s<i.length;){if(i[s]!==B)throw new Error(`Graph "${this.name}": expected ${B} segment in meta path "${r}"`);if(s+1>=i.length)throw new Error(`Graph "${this.name}": meta path requires a key after ${B} in "${r}"`);let a=i[s+1],c=o.meta[a];if(!c)throw new Error(`Graph "${this.name}": unknown meta "${a}" in path "${r}"`);o=c,s+=2}return o}signal(e,n){if(n?.internal!==!0){for(let o of e)if(this.config.messageTier(o[0])===3)throw new Error(`Graph "${this.name}": Graph.signal() rejects tier-3 messages (DATA / RESOLVED). Broadcast is for control-plane tiers (START / DIRTY / INVALIDATE / PAUSE / RESUME / COMPLETE / ERROR / TEARDOWN). For per-node value writes, use Graph.set or graph.node(name).down(...).`)}let r=[];if(this._signalDeliver(e,n??{},new Set,r),r.length>0)throw r[0]}_signalDeliver(e,n,r,o){for(let c of this._mounts.values())c._signalDeliver(e,n,r,o);let i=n.internal===!0?{internal:!0}:{actor:n.actor,delivery:"signal"},a=gr(e,this.config);for(let c of[...this._nodes.keys()].sort()){let u=this._nodes.get(c);if(!r.has(u)){r.add(u);try{u.down(e,i)}catch(d){if(d instanceof W)throw d;o.push(d)}a.length!==0&&this._signalMetaSubtree(u,a,r,i,o)}}}_signalMetaSubtree(e,n,r,o,s){for(let i of Object.keys(e.meta).sort()){let a=e.meta[i];if(!r.has(a)){r.add(a);try{a.down(n,o)}catch(c){if(c instanceof W)throw c;s.push(c)}this._signalMetaSubtree(a,n,r,o,s)}}}describe(e){if(e?.reactive==="diff")return this._describeReactiveDiff(e);if(e?.reactive===!0)return this._describeReactive(e);let n=ir(e?.actor),r=e?.filter;if(e?.detail!=null&&e?.fields!=null)throw new TypeError("Graph.describe(): pass either `detail` or `fields`, not both. `detail: 'spec'` is the canonical spec projection; use `fields` only when you need a custom subset.");let o=_t(e?.detail,e?.fields),s=e?.detail==="spec",i=o,a=[];this._collectObserveTargets("",a);let c=new Map;for(let[v,_]of a)c.set(_,v);let u=[];{let v=a.map(([,E])=>E),_=new Set(c.values()),k=0;for(;v.length>0;){let E=v.shift();if(E instanceof P)for(let O of E._deps){let N=O.node;if(c.has(N))continue;let S=N.name??"",w=S;if(!w||_.has(w))if(S){let G=2;for(;_.has(`${S}#${G}`);)G++;w=`${S}#${G}`}else for(w=`__internal__/${k++}`;_.has(w);)w=`__internal__/${k++}`;c.set(N,w),_.add(w),u.push([w,N]),v.push(N)}}}let d=[...a,...u],f={};for(let[v,_]of d){if(n!=null&&!_.allowsObserve(n))continue;let k=xt(_,i,s),E=_ instanceof P?_._deps.map(w=>c.get(w.node)??w.node.name??""):[],{name:O,...N}=k,S={...N,deps:E};if(!s){let w=this._annotations.get(v);w!=null&&(S.annotation=w)}if(r!=null)if(typeof r=="function"){let w=r;if(!(w.length>=2?w(v,S):w(S)))continue}else{let w=!0;for(let[G,A]of Object.entries(r)){let D=G==="deps_includes"?"depsIncludes":G==="meta_has"?"metaHas":G;if(D==="depsIncludes"){if(!S.deps.includes(String(A))){w=!1;break}continue}if(D==="metaHas"){if(!Object.hasOwn(S.meta??{},String(A))){w=!1;break}continue}if(S[D]!==A){w=!1;break}}if(!w)continue}f[v]=S}let p=new Set(Object.keys(f)),h=[];for(let[v,_]of d)if(_ instanceof P)for(let k of _._deps){let E=c.get(k.node);E!=null&&h.push([E,v])}h.sort((v,_)=>v[0]<_[0]?-1:v[0]>_[0]?1:v[1]<_[1]?-1:v[1]>_[1]?1:0);let l=h.map(([v,_])=>({from:v,to:_}));(n!=null||r!=null)&&(l=l.filter(v=>p.has(v.from)&&p.has(v.to)));let b=this._collectSubgraphs(""),g=n!=null||r!=null?b.filter(v=>{let _=`${v}${M}`;return[...p].some(k=>k===v||k.startsWith(_))}):b,x=this,y=e;return{name:this.name,nodes:f,edges:l,subgraphs:g,...this._factory!==void 0?{factory:this._factory}:{},...this._factoryArgs!==void 0?{factoryArgs:this._factoryArgs}:{},expand(v){let _={...y};return Array.isArray(v)?(_.fields=v,_.detail=void 0):(_.detail=v,_.fields=void 0),x.describe(_)}}}_collectSubgraphs(e){let n=[];for(let r of[...this._mounts.keys()].sort()){let o=e===""?r:`${e}${r}`;n.push(o),n.push(...this._mounts.get(r)._collectSubgraphs(`${o}${M}`))}return n}resourceProfile(e){return We(this,e)}reachable(e,n,r={}){return r.withDetail===!0?qe(this.describe(),e,n,{...r,withDetail:!0}):qe(this.describe(),e,n,r)}explain(e,n,r){return r?.reactive===!0?this._explainReactive(e,n,r):this._explainStatic(ee(e),ee(n),{...r?.maxDepth!==void 0?{maxDepth:pn(r.maxDepth)}:{},...r?.findCycle!==void 0?{findCycle:hn(r.findCycle)}:{}})}_explainStatic(e,n,r){let o=this.describe({detail:"full"}),s=new Map(this._annotations),i=new Map;for(let[a,c]of Object.entries(o.nodes))c.lastMutation!=null&&i.set(a,c.lastMutation);return Ge(o,e,n,{...r?.maxDepth!=null?{maxDepth:r.maxDepth}:{},...r?.findCycle===!0?{findCycle:!0}:{},annotations:s,lastMutations:i})}_describeReactive(e){let n={...e,reactive:!1},r=e.reactiveName??"describe",o=0,s=we(o,{name:`${r}_version`}),i=this.observe({timeline:!0,structured:!0}),a=!1,c=!1,u=()=>{a||c||(a=!0,fe(()=>{a=!1,!c&&(o+=1,s.emit(o))}))},d=i.onEvent(y=>{let m=y.type;m!=="data"&&m!=="error"&&m!=="complete"&&m!=="teardown"||u()}),f=[],p=new WeakSet,h=y=>{if(p.has(y)||c)return;p.add(y);let m=y.topology.subscribe(v=>{for(let _ of v){if(_[0]!==I)continue;let k=_[1];if(u(),k.kind==="added"&&k.nodeKind==="mount"){let E=y._mounts.get(k.name);E!=null&&h(E)}}});f.push(m);for(let v of y._mounts.keys()){let _=y._mounts.get(v);_!=null&&h(_)}};h(this);let l,b=e.actor;bn(b)&&(l=b.subscribe(y=>{let m=!1,v=!1;for(let _ of y){let k=_[0];k===I?m=!0:(k===H||k===$||k===F)&&(v=!0)}m&&u(),v&&(l?.(),l=void 0,u())}));let g;try{g=Ot([s],()=>this.describe(n),{name:r,describeKind:"derived",meta:{domain:"audit",kind:"describe"},equals:(y,m)=>y===m})}catch(y){d(),l?.();for(let m of f)m();throw i.dispose(),y}let x=ze(g);return{node:g,dispose(){c=!0,d(),l?.();for(let y of f)y();f.length=0,i.dispose(),x()}}}_describeReactiveDiff(e){let n={...e,reactive:!1},r=e.reactiveName??"describe-diff",o={name:this.name,nodes:{},edges:[],subgraphs:[]},s=this.describe(n),i=kt(o,s),a=we(i,{name:r,meta:{domain:"audit",kind:"describe-diff"},equals:(p,h)=>p===h}),c=this._describeReactive({...e,reactiveName:void 0}),u=!1,d=c.node.subscribe(p=>{if(!u)for(let h of p){if(h[0]!==I)continue;let l=h[1],b=kt(s,l);s=l,b.events.length!==0&&a.emit(b)}}),f=ze(a);return{node:a,dispose(){u=!0,d(),c.dispose(),a.down([[F,"describe-diff disposed"]]),f()}}}_explainReactive(e,n,r){let o=0,s=we(o,{name:"explain_version"}),i=this.observe({timeline:!0,structured:!0}),a=!1,c=!1,u=()=>{a||c||(a=!0,fe(()=>{a=!1,!c&&(o+=1,s.emit(o))}))},d=i.onEvent(y=>{let m=y.type;m!=="data"&&m!=="error"&&m!=="complete"&&m!=="teardown"||u()}),f=[];e!=null&&ae(e)&&f.push(e),n!=null&&ae(n)&&f.push(n),r?.maxDepth!=null&&ae(r.maxDepth)&&f.push(r.maxDepth),r?.findCycle!=null&&ae(r.findCycle)&&f.push(r.findCycle);let p=()=>{for(let y of f)if(y.cache===void 0)return!1;return!0},h=()=>{let y=ee(e),m=ee(n);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=Ot([s],()=>{if(!p())return h();let y=ee(e),m=ee(n),v={...r?.maxDepth!==void 0?{maxDepth:pn(r.maxDepth)}:{},...r?.findCycle!==void 0?{findCycle:hn(r.findCycle)}:{}};return this._explainStatic(y,m,v)},{name:r?.name??"explain",describeKind:"derived",meta:{domain:"audit",kind:"explain_path",from:ee(e),to:ee(n)},equals:(y,m)=>y.found===m.found&&y.reason===m.reason&&y.steps.length===m.steps.length&&mr(y.steps,m.steps)})}catch(y){throw d(),i.dispose(),y}let b=ze(l),g=[],x=y=>{let m;return m=y.subscribe(v=>{let _=!1,k=!1;for(let E of v){let O=E[0];O===I?_=!0:(O===H||O===$||O===F)&&(k=!0)}(_||k)&&u(),k&&m&&(m(),m=void 0)}),()=>{m&&(m(),m=void 0)}};for(let y of f)g.push(x(y));return{node:l,dispose(){c=!0,d();for(let y of g)y?.();g.length=0,i.dispose(),b()}}}_pathsMatching(e){let n=Ke(e),r=[];return this._collectObserveTargets("",r),r.map(([o])=>o).filter(o=>n.test(o))}_collectObserveTargets(e,n){for(let r of[...this._mounts.keys()].sort()){let o=e===""?r:`${e}${M}${r}`;this._mounts.get(r)._collectObserveTargets(o,n)}for(let r of[...this._nodes.keys()].sort()){let o=this._nodes.get(r),s=e===""?r:`${e}${M}${r}`;n.push([s,o]),this._appendMetaObserveTargets(s,o,n)}}_appendMetaObserveTargets(e,n,r){for(let o of Object.keys(n.meta).sort()){let s=n.meta[o],i=`${e}${M}${B}${M}${o}`;r.push([i,s]),this._appendMetaObserveTargets(i,s,r)}}observe(e,n){let r=typeof e=="string",s=mn(r?n:e);if(s.reactive===!0)return this._observeReactive(r?e:void 0,s);let i=s.structured===!0||s.timeline===!0||s.causal===!0||s.derived===!0||s.detail==="minimal"||s.detail==="full"||s.format!=null,a=s.actor;if(r){let d=e,f=this.resolve(d);if(a!=null&&!f.allowsObserve(a))throw new W({actor:a,action:"observe",nodeName:d});return i?this._buildStructuredObserver([[d,f]],s,"one"):{subscribe(p){return f.subscribe(p)},up(p){try{f.up?.(p)}catch(h){if(h instanceof W)return;throw h}}}}let c=[];this._collectObserveTargets("",c),c.sort((d,f)=>d[0]<f[0]?-1:d[0]>f[0]?1:0);let u=a==null?c:c.filter(([,d])=>d.allowsObserve(a));return i?this._buildStructuredObserver(u,s,"all"):{subscribe:d=>{let f=u.map(([p,h])=>h.subscribe(l=>{d(p,l)}));return()=>{for(let p of f)p()}},up:(d,f)=>{try{this.resolve(d).up?.(f)}catch(p){if(p instanceof W)return;throw p}}}}_observeReactive(e,n){let r=n.tiers,o=r!=null?new Set(r):null,s=n.reactiveName??"observe";return wt(i=>{let a=[],c=!1,u=!1,d=()=>{if(a.length===0||u)return;let b={events:a.slice(),flushedAt_ns:Z()};a.length=0,i.emit(b)},f={...n,reactive:!1,structured:!0,timeline:!0},p=e!=null?this.observe(e,f):this.observe(f),h=b=>{u||(a.push(b),!c&&(c=!0,fe(()=>{c=!1,d()})))};for(let b of p.events)h(b);let l=p.onEvent(h);return()=>{u=!0,l(),p.dispose()}},{name:s,meta:{domain:"audit",kind:"observe-reactive"}})}_buildStructuredObserver(e,n,r){let o=r==="one"?e[0]?.[0]:void 0,s=i=>{if(r==="one"&&o!=null){let d=this.resolve(o);return this._buildStructuredObserver([[o,d]],i,"one")}let a=[];this._collectObserveTargets("",a),a.sort((d,f)=>d[0]<f[0]?-1:d[0]>f[0]?1:0);let c=i.actor,u=c==null?a:a.filter(([,d])=>d.allowsObserve(c));return this._buildStructuredObserver(u,i,"all")};return this._createObserveResult(e,n,s)}_createObserveResult(e,n,r){let o=n.timeline===!0,s=n.causal===!0,i=n.derived===!0,a=n.detail==="minimal",c=this.config.inspectorEnabled,u=(s||i)&&c,d=n.maxEvents,f=d!=null&&d>0?new Oe(d):null,p=[],h=new Set,l=n.tiers!=null?new Set(n.tiers):null,b={},g=new Set,x=0,y=0,m=0,v=0,_=0,k=0,E=!1,O=!1,N=0,S=new Map,w=new Map,G=new Map,A=T=>{if(!(l!=null&&!l.has(T.type))){f?f.push(T):p.push(T);for(let C of h)C(T)}},D=T=>l==null||l.has(T),X=()=>o?{timestamp_ns:Z(),in_batch:$e(),batch_id:N}:{},ue=(T,C)=>{if(!(!u||!(T instanceof P)))return T._setInspectorHook(z=>{if(z.kind==="dep_message")S.set(T,z.depIndex);else if(z.kind==="run"){let ge=z.batchData.map((R,V)=>R!=null&&R.length>0?R.at(-1):z.prevData[V]);w.set(T,ge);let U=z.batchData.map(R=>R!=null?[...R]:void 0);G.set(T,U),i&&A({type:"derived",path:C,dep_values:ge,dep_batches:U,...X()})}})},oe=T=>{let C=S.get(T),z=w.get(T);if(!s||z==null)return{};let U=(C!=null&&C>=0&&T instanceof P?T._deps[C]:void 0)?.node,R=U?.v,V=G.get(T);return{trigger_dep_index:C,trigger_dep_name:U?.name,...R!=null?{trigger_version:{id:R.id,version:R.version}}:{},dep_values:[...z],...V!=null?{dep_batches:V}:{}}},Lt=[],$t=[];for(let[T,C]of e){let z=ue(C,T);z&&Lt.push(z),$t.push(C.subscribe(ge=>{N++;for(let U of ge){let R=U[0],V=X();if(R===I){b[T]=U[1];let ot=C instanceof P?C.lastMutation?.actor??ce:ce;A({type:"data",path:T,data:U[1],actor:ot,...V,...oe(C)})}else if(a)R===q?D("dirty")&&x++:R===J?D("resolved")&&y++:R===K?D("invalidate")&&m++:R===Y?D("pause")&&v++:R===Q?D("resume")&&_++:R===F?D("teardown")&&k++:R===H&&!g.has(T)?D("complete")&&(E=!0):R===$&&D("error")&&(O=!0,g.add(T));else if(R===q)D("dirty")&&x++,A({type:"dirty",path:T,...V});else if(R===J)D("resolved")&&y++,A({type:"resolved",path:T,...V,...oe(C)});else if(R===K)D("invalidate")&&m++,A({type:"invalidate",path:T,...V});else if(R===Y)D("pause")&&v++,A({type:"pause",path:T,lockId:U[1],...V});else if(R===Q)D("resume")&&_++,A({type:"resume",path:T,lockId:U[1],...V});else if(R===H)D("complete")&&!g.has(T)&&(E=!0),A({type:"complete",path:T,...V});else if(R===$){D("error")&&(O=!0,g.add(T));let ot=C instanceof P?C.lastMutation?.actor??ce:ce;A({type:"error",path:T,data:U[1],actor:ot,...V})}else R===F&&(D("teardown")&&k++,A({type:"teardown",path:T,...V}))}}))}let tt=!1,nt=()=>{if(!tt){tt=!0;for(let T of $t)T();for(let T of Lt)T();for(let T of ke)T({value:void 0,done:!0});ke.length=0}},rt=[],ke=[];h.add(T=>{let C=ke.shift();C?C({value:T,done:!1}):rt.push(T)});let Pt={get values(){return b},get dirtyCount(){return x},get resolvedCount(){return y},get invalidateCount(){return m},get pauseCount(){return v},get resumeCount(){return _},get teardownCount(){return k},get events(){return f?f.toArray():[...p]},get anyCompletedCleanly(){return E},get anyErrored(){return O},get completedWithoutErrors(){return E&&!O},onEvent(T){return h.add(T),()=>h.delete(T)},dispose:nt,expand(T){nt();let C={...n};return typeof T=="string"?C.detail=T:Object.assign(C,T),r(mn(C))},[Symbol.asyncIterator](){return{next(){return rt.length>0?Promise.resolve({value:rt.shift(),done:!1}):tt?Promise.resolve({value:void 0,done:!0}):new Promise(T=>ke.push(T))},return(){return nt(),Promise.resolve({value:void 0,done:!0})}}}};return n.format!=null&&this._attachFormatLogger(Pt,n),Pt}_attachFormatLogger(e,n){let r=n.format;if(r==null)return;let o=n.logger??(l=>console.log(l)),s=n.includeTypes?new Set(n.includeTypes):null,i=n.excludeTypes?new Set(n.excludeTypes):null,a=s==null&&i==null?()=>!0:l=>(s==null||s.has(l))&&(i==null||!i.has(l)),c=fr(n.theme),u=r==="stage-log"?Z():0,d=l=>l==null?"":n.stageLabels?.[l]??l,f=(l,b)=>l.length>b?`${l.slice(0,b-1)}\u2026`:l,p=l=>l.type==="data"||l.type==="error"?f(Et(l.data),120):"",h=l=>{if(r==="stage-log"){let E=(Z()-u)/1e9,O=d(l.path).padEnd(9);if(l.type==="data"){let N=p(l);return`[${E.toFixed(3)}s] ${O} \u2190${N?` ${N}`:""}`}if(l.type==="error"){let N=p(l);return`[${E.toFixed(3)}s] ${O} \u2717${N?` ${N}`:""}`}return l.type==="complete"?`[${E.toFixed(3)}s] ${O} \u25A0 complete`:`[${E.toFixed(3)}s] ${O} ${l.type}`}if(r==="json")try{return JSON.stringify(l)}catch{return JSON.stringify({type:l.type,path:l.path,data:"[unserializable]"})}let b=c[l.type]??"",g=l.path?`${c.path}${l.path}${c.reset} `:"",x=l.type==="data"||l.type==="error",y=l.type==="pause"||l.type==="resume",m=x?` ${Et(l.data)}`:y?` ${Et(l.lockId)}`:"",v=l.type==="data"||l.type==="resolved"||l.type==="derived"?l:void 0,_=v?.trigger_dep_name!=null?` <- ${v.trigger_dep_name}`:v?.trigger_dep_index!=null?` <- #${v.trigger_dep_index}`:"",k=l.in_batch?" [batch]":"";return`${g}${b}${l.type.toUpperCase()}${c.reset}${m}${_}${k}`};e.onEvent(l=>{a(l.type)&&o(h(l),l)})}addDisposer(e){return this._disposers.add(e),()=>{this._disposers.delete(e)}}destroy(){fn(this._disposers,this.name),this.signal([[F]],{internal:!0}),fn(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:n,...r}=this.describe({detail:"full"}),o={};for(let a of Object.keys(r.nodes).sort()){let{lastMutation:c,guard:u,...d}=r.nodes[a];o[a]=d}let s=[...r.subgraphs].sort(),i={...r,version:1,nodes:o,subgraphs:s};if(e?.format==null)return i;if(e.format==="json-string")return JSON.stringify(i);if(e.format==="bytes"){if(e.codec==null)throw new Error("snapshot({format: 'bytes'}) requires a `codec` name");let a=this.config.lookupCodec(e.codec);if(a==null)throw new Error(`snapshot: codec "${e.codec}" is not registered on this graph's config. Call config.registerCodec(...) before creating nodes.`);return Ne(a,a.encode(i))}throw new Error(`snapshot: unknown format "${String(e.format)}"`)}static decode(e,n){let r=n?.config??he,{codec:o,codecVersion:s,payload:i}=Se(e,r);return o.decode(i,s)}restore(e,n){if(gn(e),e.name!==this.name)throw new Error(`Graph "${this.name}": restore snapshot name "${e.name}" does not match this graph`);let r=n?.only==null?null:(Array.isArray(n.only)?n.only:[n.only]).map(s=>Ke(s)),o=n?.includeProducers===!0;for(let s of Object.keys(e.nodes).sort()){if(r!==null&&!r.some(a=>a.test(s)))continue;let i=e.nodes[s];if(i!==void 0){if(!("value"in i)||i.value===void 0){"value"in i&&i.value===void 0&&n?.onError?.(s,new Error(`restore: slice.value is undefined for "${s}" (undefined is the global SENTINEL; not valid DATA)`));continue}if(!(i.type==="derived"||i.type==="effect")&&!(i.type==="producer"&&!o)){if(i.v!=null){let c=this.tryResolve(s)?.v;if(c!=null&&c.id===i.v.id&&c.version===i.v.version)continue}try{this.set(s,i.value)}catch(a){n?.onError?.(s,a)}}}}}static fromSnapshot(e,n){gn(e);let r=typeof n=="function"?n:n?.build,o=typeof n=="function"?void 0:n?.factories,s=new t(e.name);if(r)return r(s),s.restore(e),s;for(let h of[...e.subgraphs].sort((l,b)=>{let g=l.split(M).length,x=b.split(M).length;return g!==x?g-x:l<b?-1:l>b?1:0})){let l=h.split(M),b=s;for(let g of l)b._mounts.has(g)||b.mount(g,new t(g)),b=b._mounts.get(g)}let i=o?Object.entries(o).map(([h,l])=>({re:Ke(h),factory:l})):[],a=h=>{for(let l of i)if(l.re.test(h))return l.factory},c=h=>{let l=h.split(M),b=l.pop();if(b==null||b.length===0)throw new Error(`invalid snapshot path "${h}"`);let g=s;for(let x of l){let y=g._mounts.get(x);if(!y)throw new Error(`unknown mount "${x}" in path "${h}"`);g=y}return[g,b]},u=Object.entries(e.nodes).filter(([h])=>!h.includes(`${M}${B}${M}`)).sort((h,l)=>h[0]<l[0]?-1:h[0]>l[0]?1:0),d=new Map(u),f=new Map,p=!0;for(;d.size>0&&p;){p=!1;for(let[h,l]of[...d.entries()]){let b=l?.deps??[];if(!b.every(_=>f.has(_)))continue;let[g,x]=c(h),y={...l?.meta??{}},m=a(h),v;if(l?.type==="state")v=we(l.value,{meta:y});else{if(m==null)continue;v=m(x,{path:h,type:l.type,value:l.value,meta:y,deps:b,resolvedDeps:b.map(_=>f.get(_))})}g.add(v,{name:x}),f.set(h,v),d.delete(h),p=!0}}if(d.size>0){let h=[...d.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 s.restore(e),s}toJSON(){return this.snapshot()}attachSnapshotStorage(e,n={}){let r=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}));n.autoRestore===!0&&this._cascadeRestore(e,n.onError);let o=(u,d)=>{if(u.disposed)return;let f=ar(d.nodes);if(u.lastSnapshot!=null&&f!==""&&f===u.lastFingerprint)return;let p=u.seq+1,h=Ie(),g=u.lastSnapshot==null||p%u.compactEvery===0?{name:this.name,mode:"full",snapshot:d,seq:p,timestamp_ns:h,format_version:te}:{name:this.name,mode:"diff",diff:St(u.lastSnapshot,d),seq:p,timestamp_ns:h,format_version:te};if(u.tier.filter&&!u.tier.filter(g))return;let x;try{x=u.tier.save(g)}catch(y){n.onError?.(y,u.tier);return}if(x&&typeof x.then=="function"){let v=(u.savePending??Promise.resolve()).then(()=>x,()=>x).then(()=>{u.disposed||(u.seq=p,u.lastSnapshot=d,u.lastFingerprint=f)},_=>{n.onError?.(_,u.tier)});u.savePending=v.finally(()=>{u.savePending===v&&(u.savePending=void 0)})}else u.seq=p,u.lastSnapshot=d,u.lastFingerprint=f},s=(u,d)=>{try{o(u,d)}catch(f){n.onError?.(f,u.tier)}},i=(u,d)=>{if(!d.some(l=>{let b=this.config.messageTier(l[0]);return b>=3&&b<5}))return;if(n.filter){let l=this.tryResolve(u);if(l==null)return;let b=xt(l,_t("standard"));if(!n.filter(u,b))return}let p,h=()=>(p==null&&(p=this.snapshot()),p);for(let l of r)l.disposed||(l.debounceMs===0?s(l,h()):(l.timer==null&&(l.timer=new Ue),l.timer.start(l.debounceMs,()=>{l.disposed||s(l,this.snapshot())})))},a;if(n.paths!=null){let d=(typeof n.paths=="string"?this._pathsMatching(n.paths):n.paths).map(f=>{let p=this.tryResolve(f);return p==null?()=>{}:p.subscribe(h=>i(f,h))});a=()=>{for(let f of d)f()}}else a=this.observe().subscribe((u,d)=>i(u,d));let c=()=>{a();for(let u of r)u.disposed=!0,u.timer?.cancel();this._storageDisposers.delete(c)};return this._storageDisposers.add(c),{dispose:c}}async _cascadeRestore(e,n){for(let r of e){let o;try{o=await r.load?.()}catch(i){n?.(i,r);continue}if(o==null||typeof o!="object"||Array.isArray(o))continue;let s=o;try{if(s.mode==="full"&&s.snapshot!=null)return this.restore(s.snapshot),!0;if(s.version===te&&s.nodes!=null)return this.restore(s),!0}catch(i){n?.(i,r)}}return!1}static async fromStorage(e,n,r){for(let o of n){let s;try{s=await o.load?.()}catch(c){r?.onError?.(c,o);continue}if(s==null||typeof s!="object"||Array.isArray(s))continue;let i=s,a=i.mode==="full"&&i.snapshot!=null?i.snapshot:i.version===te&&i.nodes!=null?i:void 0;if(a!=null)try{return t.fromSnapshot(a,r)}catch(c){r?.onError?.(c,o)}}throw new Error(`Graph.fromStorage: no tier held a restorable record for "${e}" across ${n.length} tier(s)`)}_annotations=new Map;_traceRing;trace(e,n,r){if(e!=null&&n!=null){if(this.tryResolve(e)==null)return;if(this._annotations.set(e,n),this.config.inspectorEnabled){let o={path:e,annotation:n,timestamp_ns:Z(),...r?.actor!=null?{actor:r.actor}:{}};this._traceRing.push(o)}return}return e!=null?this.config.inspectorEnabled?this._annotations.get(e):void 0:this.config.inspectorEnabled?this._traceRing.toArray():[]}annotation(e){return this._annotations.get(e)}clearTrace(){this._annotations.clear(),this._traceRing.clear()}pruneTrace(e){let n=this._traceRing.toArray().filter(o=>!e(o)),r=this._traceRing.size-n.length;this._traceRing.clear();for(let o of n)this._traceRing.push(o);return r}static diff(e,n){let r=new Set(Object.keys(e.nodes)),o=new Set(Object.keys(n.nodes)),s=[...o].filter(y=>!r.has(y)).sort(),i=[...r].filter(y=>!o.has(y)).sort(),a=[],c=[];for(let y of r){if(!o.has(y))continue;let m=e.nodes[y],v=n.nodes[y],_=m.v,k=v.v;_!=null&&k!=null&&_.id===k.id&&_.version!==k.version&&c.push({path:y,id:_.id,from:_.version,to:k.version});let E=_!=null&&k!=null&&_.id===k.id&&_.version===k.version;for(let O of["type","status","sentinel"]){let N=m[O],S=v[O];N!==S&&a.push({path:y,field:O,from:N,to:S})}if(!E)for(let O of["value","meta"]){let N=m[O],S=v[O];ur(N,S)||a.push({path:y,field:O,from:N,to:S})}}let u=y=>`${y.from} ${y.to}`,d=new Set(e.edges.map(u)),f=new Set(n.edges.map(u)),p=n.edges.filter(y=>!d.has(u(y))),h=e.edges.filter(y=>!f.has(u(y))),l=new Set(e.subgraphs),b=new Set(n.subgraphs),g=[...b].filter(y=>!l.has(y)).sort(),x=[...l].filter(y=>!b.has(y)).sort();return{nodesAdded:s,nodesRemoved:i,nodesChanged:a,versionChanges:c,edgesAdded:p,edgesRemoved:h,subgraphsAdded:g,subgraphsRemoved:x}}};function St(t,e){let n=ne.diff(t,e),r={};for(let o of n.nodesAdded){let s=e.nodes[o];s!=null&&(r[o]=s)}return{...n,nodesAddedFull:r}}function qe(t,e,n,r={}){let o={paths:[],depths:new Map,truncated:!1};if(!e)return r.withDetail?o:[];if(!r.both&&n!=="upstream"&&n!=="downstream")throw new Error('reachable: direction must be "upstream" or "downstream"');let s=r.maxDepth;if(s!=null&&(!Number.isInteger(s)||s<0))throw new Error("reachable: maxDepth must be an integer >= 0");if(s===0)return r.withDetail?o:[];let i=new Map,a=new Map,c=new Map,u=new Map,d=new Set;for(let[m,v]of Object.entries(t.nodes)){if(!m)continue;d.add(m);let _=v.deps??[];i.set(m,_);for(let k of _)k&&(d.add(k),a.has(k)||a.set(k,new Set),a.get(k).add(m))}for(let m of t.edges){if(m==null||typeof m!="object")continue;let v=typeof m.from=="string"?m.from:"",_=typeof m.to=="string"?m.to:"";!v||!_||(d.add(v),d.add(_),u.has(v)||u.set(v,new Set),u.get(v).add(_),c.has(_)||c.set(_,new Set),c.get(_).add(v))}if(!d.has(e))return r.withDetail?o:[];let f=r.both===!0,p=m=>{if(f){let E=i.get(m)??[],O=c.get(m),N=a.get(m),S=u.get(m),w=[...E];return O&&w.push(...O),N&&w.push(...N),S&&w.push(...S),w}if(n==="upstream"){let E=i.get(m)??[],O=c.get(m);return O?[...E,...O]:E}let v=a.get(m),_=u.get(m),k=v?[...v]:[];return _&&k.push(..._),k},h=new Set([e]),l=new Map,b=[{path:e,depth:0}],g=0,x=!1;for(;g<b.length;){let m=b[g++];if(s!=null&&m.depth>=s){p(m.path).length>0&&(x=!0);continue}for(let v of p(m.path))!v||h.has(v)||(h.add(v),l.set(v,m.depth+1),b.push({path:v,depth:m.depth+1}))}let y=[...l.keys()].sort((m,v)=>m<v?-1:m>v?1:0);return r.withDetail?{paths:y,depths:l,truncated:x}:y}function mr(t,e){if(t.length!==e.length)return!1;for(let n=0;n<t.length;n++){let r=t[n],o=e[n];if(r.path!==o.path||r.type!==o.type||r.status!==o.status||r.hop!==o.hop||r.dep_index!==o.dep_index||r.annotation!==o.annotation||r.value!==o.value||r.lastMutation!==o.lastMutation)return!1;let s=r.v,i=o.v;if(s!==i&&(s==null||i==null||s.id!==i.id||s.version!==i.version))return!1}return!0}_e();function vn(t,e){let n=new Map,r=(o,s)=>{if(n.has(o))return;let i={off:()=>{},prefix:s};n.set(o,i);let a=o.topology.subscribe(c=>{for(let u of c){if(u[0]!==I)continue;let d=u[1];if(e(d,o,s),d.kind==="added"&&d.nodeKind==="mount"){let f=o._mounts.get(d.name);if(f instanceof ne){let p=`${s}${d.name}::`;r(f,p)}}else if(d.kind==="removed"&&d.nodeKind==="mount"){let f=`${s}${d.name}::`;for(let[p,h]of Array.from(n.entries()))p!==t&&h.prefix.startsWith(f)&&(h.off(),n.delete(p))}}});i.off=a;for(let[c,u]of o._mounts)if(u instanceof ne){let d=`${s}${c}::`;r(u,d)}};return r(t,""),()=>{for(let o of n.values())o.off();n.clear()}}function Dt(t){return t>=768&&t<=879||t>=1155&&t<=1161||t>=1425&&t<=1469||t>=1552&&t<=1562||t>=1611&&t<=1631||t>=1648&&t===1648||t>=1750&&t<=1756||t>=1759&&t<=1764||t>=1767&&t<=1768||t>=1770&&t<=1773||t>=1840&&t<=1866||t>=1958&&t<=1968||t>=2304&&t<=2307||t>=2362&&t<=2383||t>=2385&&t<=2391||t>=2402&&t<=2403||t>=2433&&t<=2435||t>=2492&&t<=2509||t>=2561&&t<=2563||t>=2620&&t<=2641||t>=2672&&t<=2673||t>=2677&&t===2677||t>=3633&&t===3633||t>=3636&&t<=3642||t>=3655&&t<=3662||t>=3761&&t===3761||t>=3764&&t<=3772||t>=3784&&t<=3790||t>=7616&&t<=7679||t>=8400&&t<=8447||t>=65024&&t<=65039||t>=65056&&t<=65071||t===8205?0:t>=4352&&t<=4447||t>=8986&&t<=8987||t>=9001&&t<=9002||t>=9193&&t<=9203||t>=9208&&t<=9210||t>=9725&&t<=9726||t>=9748&&t<=9749||t>=9800&&t<=9811||t===9855||t===9875||t===9889||t>=9898&&t<=9899||t>=9917&&t<=9918||t>=9924&&t<=9925||t===9934||t===9940||t===9962||t>=9970&&t<=9971||t===9973||t===9978||t===9981||t===9986||t===9989||t>=9992&&t<=9997||t===9999||t>=10067&&t<=10069||t===10071||t>=10133&&t<=10135||t===10160||t===10175||t>=10548&&t<=10549||t>=11013&&t<=11015||t>=11035&&t<=11036||t===11088||t===11093||t>=11904&&t<=12350||t>=12352&&t<=12447||t>=12448&&t<=12543||t>=12549&&t<=12591||t>=12593&&t<=12686||t>=12688&&t<=12771||t>=12784&&t<=12830||t>=12832&&t<=12871||t>=12880&&t<=19903||t>=19968&&t<=40959||t>=43360&&t<=43388||t>=44032&&t<=55203||t>=63744&&t<=64255||t>=65040&&t<=65049||t>=65072&&t<=65131||t>=65281&&t<=65376||t>=65504&&t<=65510||t>=126980&&t===126980||t===127183||t>=127344&&t<=127345||t===127358||t===127359||t===127374||t>=127377&&t<=127386||t>=127456&&t<=127487||t>=127488&&t<=127490||t===127514||t===127535||t>=127538&&t<=127546||t>=127568&&t<=127569||t>=127744&&t<=129535||t>=129536&&t<=129791||t>=129792&&t<=130047||t>=131072&&t<=196605||t>=196608&&t<=262141?2:1}function Je(t){let e=0;for(let n of t)e+=Dt(n.codePointAt(0));return e}function _n(t,e){if(e<=0)return"";let n=0,r="";for(let o of t){let s=Dt(o.codePointAt(0));if(n+s>e){if(e<=1)return"\u2026";for(;n+1>e&&r.length>0;){let i=[...r].pop();r=r.slice(0,-i.length),n-=Dt(i.codePointAt(0))}return`${r}\u2026`}r+=o,n+=s}return r}var br={horizontal:"\u2500",vertical:"\u2502",cornerTL:"\u250C",cornerTR:"\u2510",cornerBL:"\u2514",cornerBR:"\u2518",tDown:"\u252C",tUp:"\u2534",tRight:"\u251C",tLeft:"\u2524",cross:"\u253C",arrowRight:"\u25B6",arrowDown:"\u25BC",arrowLeft:"\u25C0",arrowUp:"\u25B2",boxTL:"\u250C",boxTR:"\u2510",boxBL:"\u2514",boxBR:"\u2518",boxH:"\u2500",boxV:"\u2502"},yr={horizontal:"-",vertical:"|",cornerTL:"+",cornerTR:"+",cornerBL:"+",cornerBR:"+",tDown:"+",tUp:"+",tRight:"+",tLeft:"+",cross:"+",arrowRight:">",arrowDown:"v",arrowLeft:"<",arrowUp:"^",boxTL:"+",boxTR:"+",boxBL:"+",boxBR:"+",boxH:"-",boxV:"|"};function Tn(t,e){let n=e.charset==="ascii"?yr:br,r=t.width,o=t.height,s=Array.from({length:o},()=>Array.from({length:r},()=>" ")),i=Array.from({length:o},()=>Array.from({length:r},()=>"empty"));for(let a of t.edges)_r(s,i,n,a);for(let a of t.boxes)vr(s,i,n,a,e.labelOf(a.id));return s.map(a=>Tr(a.join(""))).join(`
|
|
4
|
-
`)}function vr(t,e,n,r,o){let{x:s,y:i,w:a,h:c}=r;if(a<2||c<2){c>0&&xn(t,e,s,i,a,o);return}re(t,e,s,i,n.boxTL);for(let d=s+1;d<s+a-1;d+=1)re(t,e,d,i,n.boxH);re(t,e,s+a-1,i,n.boxTR);for(let d=i+1;d<i+c-1;d+=1){re(t,e,s,d,n.boxV);for(let f=s+1;f<s+a-1;f+=1)kn(t,e,f,d," ","empty");re(t,e,s+a-1,d,n.boxV)}re(t,e,s,i+c-1,n.boxBL);for(let d=s+1;d<s+a-1;d+=1)re(t,e,d,i+c-1,n.boxH);re(t,e,s+a-1,i+c-1,n.boxBR);let u=i+Math.floor(c/2);xn(t,e,s+1,u,a-2,o)}function re(t,e,n,r,o){kn(t,e,n,r,o,o===" "?"empty":o==="\u2500"||o==="-"?"boxH":o==="\u2502"||o==="|"?"boxV":"boxCorner")}function kn(t,e,n,r,o,s){if(r<0||r>=t.length)return;let i=t[r];n<0||n>=i.length||(i[n]=o,e[r][n]=s)}function xn(t,e,n,r,o,s){if(r<0||r>=t.length)return;let i=n,a=o;for(let c of s){let u=Je(c);if(u!==0){if(a<u)break;i>=0&&i<t[r].length&&(t[r][i]=c,e[r][i]="label",u===2&&i+1<t[r].length&&(t[r][i+1]="",e[r][i+1]="label")),i+=u,a-=u}}for(;a>0;)i>=0&&i<t[r].length&&(t[r][i]=" ",e[r][i]="empty"),i+=1,a-=1}function _r(t,e,n,r){let o=r.points;if(o.length<2)return;for(let c=0;c+1<o.length;c+=1)xr(t,e,n,o[c],o[c+1]);for(let c=1;c+1<o.length;c+=1){let u=o[c-1],d=o[c],f=o[c+1],p=wr(u,d,f,n);p&&On(t,e,d.x,d.y,p,"edgeCorner")}let s=o[o.length-1],i=o[o.length-2],a=Or(i,s,n);a&&On(t,e,s.x,s.y,a,"arrow")}function xr(t,e,n,r,o){if(!(r.x===o.x&&r.y===o.y)){if(r.y===o.y){let s=r.y,i=Math.min(r.x,o.x),a=Math.max(r.x,o.x);for(let c=i;c<=a;c+=1)wn(t,e,c,s,n,"h")}else if(r.x===o.x){let s=r.x,i=Math.min(r.y,o.y),a=Math.max(r.y,o.y);for(let c=i;c<=a;c+=1)wn(t,e,s,c,n,"v")}}}function wn(t,e,n,r,o,s){if(r<0||r>=t.length)return;let i=t[r];if(n<0||n>=i.length)return;let a=e[r][n];if(!(a==="boxH"||a==="boxV"||a==="boxCorner"||a==="label")){if(a==="empty"){i[n]=s==="h"?o.horizontal:o.vertical,e[r][n]=s==="h"?"edgeH":"edgeV";return}if(a==="edgeH"&&s==="v"){i[n]=o.cross,e[r][n]="edgeCorner";return}if(a==="edgeV"&&s==="h"){i[n]=o.cross,e[r][n]="edgeCorner";return}}}function On(t,e,n,r,o,s){if(r<0||r>=t.length)return;let i=t[r];if(n<0||n>=i.length)return;let a=e[r][n];a==="boxH"||a==="boxV"||a==="boxCorner"||a==="label"||(i[n]=o,e[r][n]=s)}function wr(t,e,n,r){let o=t.y===e.y,s=e.y===n.y;if(o===s)return;if(o){let c=t.x<e.x,u=n.y>e.y;return c&&u?r.cornerTR:c&&!u?r.cornerBR:!c&&u?r.cornerTL:r.cornerBL}let i=t.y<e.y,a=n.x>e.x;return i&&a?r.cornerBL:i&&!a?r.cornerBR:!i&&a?r.cornerTL:r.cornerTR}function Or(t,e,n){if(e.x>t.x)return n.arrowRight;if(e.x<t.x)return n.arrowLeft;if(e.y>t.y)return n.arrowDown;if(e.y<t.y)return n.arrowUp}function Tr(t){let e=t.length;for(;e>0&&t.charCodeAt(e-1)===32;)e-=1;return t.slice(0,e)}function Sn(t){let e=kr(t);Er(e),Nr(e),Sr(e),Dr(e,t);let n=Cr(e,t),{width:r,height:o}=Gr(e),s=[];for(let i of e.layers)for(let a of i)a.isVirtual||s.push({id:a.id,layer:a.layer,order:a.order,x:a.x,y:a.y,w:a.w,h:a.h});return{boxes:s,edges:n,width:r,height:o}}function kr(t){let e=new Map;for(let o of t.nodes)e.set(o,{id:o,isVirtual:!1,layer:-1,order:0,x:0,y:0,w:t.widthCells(o),h:t.heightCells(o),in:[],out:[]});let n=[],r=0;for(let o of t.edges){if(o.from===o.to)continue;let s=e.get(o.from),i=e.get(o.to);if(!s||!i)continue;let a={chainId:r++,chainFrom:o.from,chainTo:o.to,fromId:o.from,toId:o.to,hopIndex:0,chainLen:1};s.out.push(a),i.in.push(a),n.push(a)}return{nodes:e,layers:[],hops:n}}function Er(t){let e=new Map;for(let s of t.nodes.values())e.set(s.id,s.in.length);let n=[];for(let s of t.nodes.values())(e.get(s.id)??0)===0&&(s.layer=0,n.push(s));let r=new Set,o=0;for(;o<n.length;){let s=n[o++];if(!r.has(s.id)){r.add(s.id);for(let i of s.out){let a=t.nodes.get(i.toId);a.layer=Math.max(a.layer,s.layer+1);let c=(e.get(a.id)??0)-1;e.set(a.id,c),c<=0&&n.push(a)}}}for(let s of t.nodes.values())s.layer<0&&(s.layer=0)}function Nr(t){let e=Math.max(0,...Array.from(t.nodes.values(),s=>s.layer)),n=Array.from({length:e+1},()=>[]);for(let s of t.nodes.values())n[s.layer].push(s);let r=[],o=0;for(let s of t.hops){let i=t.nodes.get(s.fromId),a=t.nodes.get(s.toId),c=a.layer-i.layer;if(c<=0){i.out=i.out.filter(f=>f!==s),a.in=a.in.filter(f=>f!==s);continue}if(c===1){s.hopIndex=0,s.chainLen=1,r.push(s);continue}i.out=i.out.filter(f=>f!==s),a.in=a.in.filter(f=>f!==s);let u=i;for(let f=1;f<c;f+=1){let p=`__virt_${o++}__`,h={id:p,isVirtual:!0,layer:i.layer+f,order:0,x:0,y:0,w:0,h:1,in:[],out:[]};t.nodes.set(p,h),n[h.layer].push(h);let l={chainId:s.chainId,chainFrom:s.chainFrom,chainTo:s.chainTo,fromId:u.id,toId:p,hopIndex:f-1,chainLen:c};u.out.push(l),h.in.push(l),r.push(l),u=h}let d={chainId:s.chainId,chainFrom:s.chainFrom,chainTo:s.chainTo,fromId:u.id,toId:a.id,hopIndex:c-1,chainLen:c};u.out.push(d),a.in.push(d),r.push(d)}for(let s of n)for(let i=0;i<s.length;i+=1)s[i].order=i;t.layers=n,t.hops=r}function Sr(t){for(let n=0;n<4;n+=1){for(let r=1;r<t.layers.length;r+=1)En(t,t.layers[r],"in"),Ye(t.layers[r]);for(let r=t.layers.length-2;r>=0;r-=1)En(t,t.layers[r],"out"),Ye(t.layers[r])}for(let n=0;n<2;n+=1){let r=!1;for(let o=1;o<t.layers.length;o+=1){let s=t.layers[o];for(let i=0;i+1<s.length;i+=1){let a=Nn(t,s[i],s[i+1],"in");[s[i],s[i+1]]=[s[i+1],s[i]],Ye(s),Nn(t,s[i],s[i+1],"in")<a?r=!0:([s[i],s[i+1]]=[s[i+1],s[i]],Ye(s))}}if(!r)break}}function En(t,e,n){let r=new Map;for(let o of e){let s=n==="in"?o.in:o.out;if(s.length===0){r.set(o.id,o.order);continue}let i=0,a=0;for(let c of s){let u=t.nodes.get(n==="in"?c.fromId:c.toId);u&&(i+=u.order,a+=1)}r.set(o.id,a===0?o.order:i/a)}e.sort((o,s)=>{let i=r.get(o.id),a=r.get(s.id);return i!==a?i-a:o.order-s.order})}function Ye(t){for(let e=0;e<t.length;e+=1)t[e].order=e}function Nn(t,e,n,r){let o=r==="in"?e.in:e.out,s=r==="in"?n.in:n.out,i=0;for(let a of o)for(let c of s){let u=t.nodes.get(r==="in"?a.fromId:a.toId)?.order??0,d=t.nodes.get(r==="in"?c.fromId:c.toId)?.order??0;(e.order<n.order&&u>d||e.order>n.order&&u<d)&&(i+=1)}return i}function Dr(t,e){e.direction==="LR"?Rr(t,e):Ar(t,e)}function Rr(t,e){let n=[],r=0;for(let o=0;o<t.layers.length;o+=1){n.push(r);let s=0;for(let i of t.layers[o])s=Math.max(s,i.w);r+=s+e.layerGap}for(let o=0;o<t.layers.length;o+=1)for(let s of t.layers[o])s.x=n[o];for(let o of t.layers){let s=0;for(let i of o)i.y=s,s+=i.h+e.nodeGap}Dn(t,e,"y")}function Ar(t,e){let n=[],r=0;for(let o=0;o<t.layers.length;o+=1){n.push(r);let s=0;for(let i of t.layers[o])s=Math.max(s,i.h);r+=s+e.layerGap}for(let o=0;o<t.layers.length;o+=1)for(let s of t.layers[o])s.y=n[o];for(let o of t.layers){let s=0;for(let i of o)i.x=s,s+=i.w+e.nodeGap}Dn(t,e,"x")}function Dn(t,e,n){let r=s=>n==="y"?s.h:s.w,o=e.nodeGap;for(let s=0;s<2;s+=1){let i=s===0?t.layers.slice(1):t.layers.slice(0,-1).reverse();for(let a of i){let c=new Map;for(let d of a){let f=s===0?d.in:d.out;if(f.length===0)continue;let p=[];for(let l of f){let b=t.nodes.get(s===0?l.fromId:l.toId);if(!b)continue;let g=n==="y"?b.y:b.x;p.push(g+Math.floor(r(b)/2))}if(p.length===0)continue;p.sort((l,b)=>l-b);let h=p[Math.floor(p.length/2)];c.set(d.id,h-Math.floor(r(d)/2))}let u=0;for(let d of a){let f=c.get(d.id),p=n==="y"?d.y:d.x,l=Math.max(f??p,u);n==="y"?d.y=l:d.x=l,u=l+r(d)+o}}}}function Cr(t,e){let n=new Map;for(let u of t.hops){let d=n.get(u.chainId);d?d.push(u):n.set(u.chainId,[u])}for(let u of n.values())u.sort((d,f)=>d.hopIndex-f.hopIndex);let r=e.direction==="LR",o=u=>r?u.x:u.y,s=u=>r?u.w:u.h,i=u=>r?u.y+Math.floor(u.h/2):u.x+Math.floor(u.w/2),a=new Map;for(let u=0;u+1<t.layers.length;u+=1){let d=t.layers[u],f=t.layers[u+1],p=0;for(let O of d)p=Math.max(p,o(O)+s(O));let h=Number.POSITIVE_INFINITY;for(let O of f)h=Math.min(h,o(O));let l=Number.isFinite(h)?h-1:p,b=Math.max(1,l-p+1),g=[];for(let O of d)for(let N of O.out)g.push(N);g.sort((O,N)=>{let S=i(t.nodes.get(O.fromId)),w=i(t.nodes.get(N.fromId));if(S!==w)return S-w;let G=i(t.nodes.get(O.toId)),A=i(t.nodes.get(N.toId));return G-A});let x=[],y=new Map;for(let O of g){let N=i(t.nodes.get(O.fromId)),S=i(t.nodes.get(O.toId)),w=Math.min(N,S),G=Math.max(N,S),A=-1;for(let D=0;D<x.length;D+=1){let X=x[D],ue=!0;for(let oe of X)if(oe.lo<=G&&w<=oe.hi){ue=!1;break}if(ue){X.push({lo:w,hi:G}),A=D;break}}A<0&&(x.push([{lo:w,hi:G}]),A=x.length-1),y.set(O,A)}let m=x.length,v=b>=Math.max(3,m+2),_=v?p+1:p,k=v?l-1:l,E=Math.max(1,k-_+1);for(let O of g){let N=y.get(O),S;if(m<=1)S=_+Math.floor(E/2);else{let w=(E-1)/(m-1);S=_+Math.floor(N*w)}a.set(O,Math.max(p,Math.min(l,S)))}}let c=[];for(let[,u]of n){let d=[];for(let p=0;p<u.length;p+=1){let h=u[p],l=t.nodes.get(h.fromId),b=t.nodes.get(h.toId),g=a.get(h),x=l.isVirtual?o(l):o(l)+s(l),y=b.isVirtual?o(b):o(b)-1,m=i(l),v=i(b);p===0&&Xe(d,r,x,m),m!==v&&(Xe(d,r,g,m),Xe(d,r,g,v)),Xe(d,r,y,v)}let f=u[0];c.push({from:f.chainFrom,to:f.chainTo,points:Mr(d)})}return c}function Xe(t,e,n,r){t.push(e?{x:n,y:r}:{x:r,y:n})}function Mr(t){let e=[];for(let n of t){let r=e[e.length-1];(!r||r.x!==n.x||r.y!==n.y)&&e.push(n)}return e}function Gr(t){let e=0,n=0;for(let r of t.layers)for(let o of r)e=Math.max(e,o.x+o.w),n=Math.max(n,o.y+o.h);return{width:e,height:n}}var Lr=24,$r=4,Pr=1,Ir=3;function Rt(t,e){let n=Fr(e?.direction),r=Math.max(3,e?.maxLabelWidth??Lr),o=e?.asciiCharset??"unicode",s=Object.keys(t.nodes).sort(),i=new Set(s),a=t.edges.filter(p=>i.has(p.from)&&i.has(p.to)),c=new Map,u=new Map;for(let p of s){let h=_n(p,r);c.set(p,h),u.set(p,Je(h)+4)}let d=Sn({nodes:s,edges:a,widthCells:p=>u.get(p)??3,heightCells:()=>Ir,layerGap:$r,nodeGap:Pr,direction:n}),f=Tn(d,{charset:o,labelOf:p=>c.get(p)??p});return e?.logger?.(f),f}function Fr(t){if(t===void 0||t==="LR")return"LR";if(t==="TD")return"TD";throw new Error(`ascii describe supports direction "LR" or "TD" only; got ${String(t)}`)}function Ze(t){if(t===null||typeof t!="object")return t;if(Array.isArray(t))return t.map(Ze);let e=t,n=Object.keys(e).sort(),r={};for(let o of n)r[o]=Ze(e[o]);return r}function Rn(t){return t.replaceAll("\\","\\\\").replaceAll('"','\\"')}function An(t){return t.replaceAll("\\","\\\\").replaceAll('"','\\"')}function Cn(t){return t==="TD"?"down":t==="BT"?"up":t==="RL"?"left":"right"}function Qe(t){let e=new Set,n=[];function r(o,s){let i=`${o}\0${s}`;e.has(i)||(e.add(i),n.push([o,s]))}for(let[o,s]of Object.entries(t.nodes)){let i=s.deps;if(i)for(let a of i)r(a,o)}for(let o of t.edges)r(o.from,o.to);return n}function et(t){if(t===void 0)return"LR";if(t==="TD"||t==="LR"||t==="BT"||t==="RL")return t;throw new Error(`invalid diagram direction ${String(t)}; expected one of: TD, LR, BT, RL`)}function Mn(t){if(typeof t=="string")return JSON.stringify(t);if(typeof t=="number"||typeof t=="boolean"||t==null)return String(t);try{return JSON.stringify(t)}catch{return"[unserializable]"}}function At(t,e){let n=et(e?.direction),r=Object.keys(t.nodes).sort(),o=new Map;for(let i=0;i<r.length;i+=1)o.set(r[i],`n${i}`);let s=[`direction: ${Cn(n)}`];for(let i of r){let a=o.get(i);s.push(`${a}: "${An(i)}"`)}for(let[i,a]of Qe(t)){let c=o.get(i),u=o.get(a);!c||!u||s.push(`${c} -> ${u}`)}return s.join(`
|
|
5
|
-
`)}function
|
|
6
|
-
`)}function
|
|
7
|
-
`);return e?.logger?.(s),s}var
|
|
1
|
+
"use strict";var it=Object.defineProperty;var nr=Object.getOwnPropertyDescriptor;var rr=Object.getOwnPropertyNames;var or=Object.prototype.hasOwnProperty;var R=(t,e)=>()=>(t&&(e=t(t=0)),e);var sr=(t,e)=>{for(var n in e)it(t,n,{get:e[n],enumerable:!0})},ir=(t,e,n,r)=>{if(e&&typeof e=="object"||typeof e=="function")for(let o of rr(e))!or.call(t,o)&&o!==n&&it(t,o,{get:()=>e[o],enumerable:!(r=nr(e,o))||r.enumerable});return t};var ar=t=>ir(it({},"__esModule",{value:!0}),t);function Ne(t){let e=new WeakSet,n=new WeakSet,r=[t],o=0;for(;r.length>0;){let s=r.pop();o+=ur(s,e,n,r)}return o}function ur(t,e,n,r){if(t==null)return 0;switch(typeof t){case"number":return $.number;case"boolean":return $.boolean;case"string":return $.string+t.length*2;case"bigint":return $.bigint+cr(t);case"symbol":return $.symbol;case"function":return e.has(t)?0:(e.add(t),$.function);case"undefined":return 0}let s=t;if(e.has(s))return 0;e.add(s);let i=s[at];if(typeof i=="function")try{let u=i.call(s);if(typeof u=="number"&&Number.isFinite(u))return u}catch{}if(s instanceof Date)return $.date;if(s instanceof RegExp)return $.regexp+s.source.length*2;if(s instanceof Error){let u=s.message?s.message.length*2:0,d=s.stack?s.stack.length*2:0;return $.error+u+d}if(typeof URL<"u"&&s instanceof URL)return $.url+s.href.length*2;if(typeof Promise<"u"&&s instanceof Promise)return $.promise;if(s instanceof WeakMap)return $.weakmap;if(s instanceof WeakSet)return $.weakset;if(s instanceof Map){let u=$.map;for(let[d,f]of s)u+=$.mapEntry,r.push(d),r.push(f);return u}if(s instanceof Set){let u=$.set;for(let d of s)u+=$.setEntry,r.push(d);return u}if(Array.isArray(s)){let u=$.array+s.length*8;for(let d of s)r.push(d);return u}if(s instanceof ArrayBuffer)return n.has(s)?0:(n.add(s),s.byteLength);if(ArrayBuffer.isView(s)){let u=s;return n.has(u.buffer)?48:(n.add(u.buffer),u.buffer.byteLength+48)}let a=$.object,c=Object.keys(s);for(let u of c){a+=$.string+u.length*2;try{r.push(s[u])}catch{}}return a}function cr(t){let e=t<0n?-t:t;if(e===0n)return 0;let n=e.toString(2).length;return Math.ceil(n/32)*8}var $,at,ut=R(()=>{"use strict";$={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},at=Symbol.for("sizeof")});function Wt(t){return{name:"dag-cbor",version:1,contentType:"application/dag-cbor",encode:e=>t.encode(e),decode:(e,n)=>t.decode(e)}}function Kt(t,e){return{name:"dag-cbor-zstd",version:1,contentType:"application/dag-cbor+zstd",encode:n=>e.compressSync(t.encode(n)),decode:(n,r)=>t.decode(e.decompressSync(n))}}function Se(t,e){let n=new TextEncoder().encode(t.name);if(n.length===0||n.length>255)throw new Error(`encodeEnvelope: codec name "${t.name}" encodes to ${n.length} bytes (must be 1\u2013255)`);let r=t.version;if(!Number.isInteger(r)||r<0||r>65535)throw new Error(`encodeEnvelope: codec.version ${r} out of u16 range (expected integer 0\u201365535)`);let o=2+n.length+2+e.length;if(o>4294967295)throw new Error(`encodeEnvelope: total envelope size ${o} exceeds 2^32-1 bytes (payload ${e.length} bytes)`);let s=new Uint8Array(o),i=0;return s[i++]=me,s[i++]=n.length,s.set(n,i),i+=n.length,s[i++]=r>>>8&255,s[i++]=r&255,s.set(e,i),s}function Re(t,e){if(t.length<Ut)throw new Error(`decodeEnvelope: bytes too short (${t.length} < ${Ut})`);let n=0,r=t[n++];if(r!==me)throw new Error(`decodeEnvelope: unsupported envelope version ${r} (expected ${me})`);let o=t[n++];if(o===0)throw new Error("decodeEnvelope: name_len must be >= 1");if(n+o+2>t.length)throw new Error(`decodeEnvelope: envelope truncated (need ${n+o+2} bytes, have ${t.length})`);let s=new TextDecoder().decode(t.subarray(n,n+o));n+=o;let i=(t[n]<<8|t[n+1])>>>0;n+=2;let a=t.subarray(n),c=e.lookupCodec(s);if(c==null)throw new Error(`decodeEnvelope: codec "${s}" not registered (envelope codec_v=${i})`);return{codec:c,codecVersion:i,payload:a}}function De(t){t.registerCodec(ct)}function qt(t){if(t.length===0)throw new Error("WAL is empty \u2014 need at least one full snapshot");let e=t[0];if(e.mode!=="full")throw new Error("WAL must start with a full record carrying a baseline snapshot");let n=JSON.parse(JSON.stringify(e.snapshot)),r=e.seq;for(let o=1;o<t.length;o++){let s=t[o];if(s.seq<=r)throw new Error(`WAL chain broken at index ${o}: seq=${s.seq} must exceed prev seq=${r}`);if(s.mode==="full"){n=JSON.parse(JSON.stringify(s.snapshot)),r=s.seq;continue}let i=s.diff;for(let c of i.nodesRemoved)delete n.nodes[c];let a=i.nodesAddedFull;if(a!=null)for(let[c,u]of Object.entries(a))n.nodes[c]=JSON.parse(JSON.stringify(u));for(let c of i.nodesChanged){let u=n.nodes[c.path];u!=null&&(u[c.field]=c.to)}r=s.seq}return n}var ct,me,Ut,Ae=R(()=>{"use strict";ct={name:"json",version:1,contentType:"application/json",encode(t){let e=JSON.stringify(t);return new TextEncoder().encode(e)},decode(t,e){let n=new TextDecoder().decode(t);return JSON.parse(n)}};me=1,Ut=4});function Ie(t,e,n,r={}){let o=e in t.nodes,s=n in t.nodes;if(!o)return Ce(e,n,"no-such-from");if(!s)return Ce(e,n,"no-such-to");let i=r.maxDepth;if(i!=null&&(!Number.isInteger(i)||i<0))throw new Error("explainPath: maxDepth must be an integer >= 0");if(e===n){if(r.findCycle===!0){let u=dr(t,e,r);if(u!=null)return u}let c=Me(e,t.nodes[e],0,r);return Ge(e,n,[c])}if(i===0)return Ce(e,n,"no-path");let a=Jt(t,e,n,i);return a.found?Ge(e,n,Yt(t,a.pathOrder,r)):Ce(e,n,a.truncated?"max-depth-exceeded":"no-path")}function Jt(t,e,n,r){let o=new Map,s=[{path:n,depth:0}],i=new Set([n]),a=0,c=!1;for(;a<s.length;){let f=s[a++];if(f.path===e)break;if(r!=null&&f.depth>=r){let b=t.nodes[f.path];b?.deps&&b.deps.length>0&&(c=!0);continue}let p=t.nodes[f.path];if(p==null)continue;let h=p.deps??[],l=new Map;for(let b=0;b<h.length;b++){let g=h[b];if(!g)continue;let x=l.get(g);x==null&&(x=[],l.set(g,x)),x.push(b)}for(let[b,g]of l)i.has(b)||(i.add(b),o.set(b,{from:f.path,depIndices:g}),s.push({path:b,depth:f.depth+1}))}if(!o.has(e))return{found:!1,pathOrder:[],truncated:c};let u=[{path:e}],d=e;for(;d!==n;){let f=o.get(d);if(f==null)return{found:!1,pathOrder:[],truncated:!1};u[u.length-1].depIndices=f.depIndices,u.push({path:f.from}),d=f.from}return{found:!0,pathOrder:u,truncated:!1}}function dr(t,e,n){let r=t.nodes[e];if(r==null)return null;let o=r.deps??[],s=[];for(let a=0;a<o.length;a++)o[a]===e&&s.push(a);if(s.length>0){let a=Me(e,r,0,n);a.dep_index=s[0];let c=Me(e,r,1,n);return Ge(e,e,[a,c])}let i=null;for(let a=0;a<o.length;a++){let c=o[a];if(!c||c===e)continue;let u=Jt(t,c,e,n.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:Ge(e,e,Yt(t,i.pathOrder,n))}function Yt(t,e,n){return e.map((r,o)=>{let s=t.nodes[r.path],i=Me(r.path,s,o,n);return r.depIndices!=null&&r.depIndices.length>0&&(i.dep_index=r.depIndices[0],r.depIndices.length>1&&(i.dep_indices=[...r.depIndices])),i})}function Me(t,e,n,r){let o={path:t,type:e.type,hop:n};e.status!==void 0&&(o.status=e.status),"value"in e&&(o.value=e.value),e.v!=null&&(o.v=e.v);let s=r.annotations?.get(t)??e.annotation;s!=null&&(o.annotation=s);let i=r.lastMutations?.get(t)??e.lastMutation;return i!=null&&(o.lastMutation=i),o}function Ge(t,e,n){return Xt(t,e,!0,"ok",n)}function Ce(t,e,n){return Xt(t,e,!1,n,[])}function Xt(t,e,n,r,o){let s=lr(t,e,n,r,o);return{from:t,to:e,found:n,reason:r,steps:o,text:s,toJSON(){return{from:t,to:e,found:n,reason:r,steps:o}}}}function lr(t,e,n,r,o){if(!n)switch(r){case"no-such-from":return`explainPath: no node named "${t}"`;case"no-such-to":return`explainPath: no node named "${e}"`;case"max-depth-exceeded":return`explainPath: no path from "${t}" to "${e}" within maxDepth`;default:return`explainPath: no path from "${t}" to "${e}"`}let s=[`Causal path: ${t} \u2192 ${e} (${o.length} step(s))`];for(let i of o){let c=` ${i.hop===0?"\xB7":"\u2193"} ${i.path} (${i.type}${i.status?`/${i.status}`:""})`;if(s.push(c),"value"in i&&s.push(` value: ${fr(i.value)}`),i.annotation!=null&&s.push(` annotation: ${i.annotation}`),i.lastMutation!=null){let u=i.lastMutation.actor;s.push(` actor: ${u.type}${u.id?`:${u.id}`:""}`)}}return s.join(`
|
|
2
|
+
`)}function fr(t){if(t===void 0)return"<sentinel>";if(t===null)return"null";if(typeof t=="string")return JSON.stringify(t);if(typeof t=="number"||typeof t=="boolean"||typeof t=="bigint")return String(t);try{let e=JSON.stringify(t);return e.length>80?`${e.slice(0,77)}...`:e}catch{return String(t)}}var dt=R(()=>{"use strict"});function $e(t){if(t==null)return ce;let{type:e,id:n,...r}=t;return{type:e??"system",id:n??"",...r}}var ce,lt=R(()=>{"use strict";ce={type:"system",id:""}});function Le(){return de>0||be}function Zt(){return de>0}function fe(t){de>0?ye.push(t):t()}function Qt(t){de+=1;let e=!1;try{t()}catch(n){throw e=!0,n}finally{if(de-=1,de===0)if(e){if(!be){let n=ye.splice(0);for(let r of n)try{r()}catch{}se.length=0,ie.length=0,le.length=0}}else pr()}}function pr(){let t=!be;t&&(be=!0);let e=[],n=0;try{for(;se.length>0||ie.length>0||le.length>0||t&&ye.length>0;){if(t&&ye.length>0){let s=ye.splice(0);for(let i of s)try{i()}catch(a){e.push(a)}continue}if(n+=1,n>1e3)throw se.length=0,ie.length=0,le.length=0,new Error("batch drain exceeded 1000 iterations \u2014 likely a reactive cycle");let o=(se.length>0?se:ie.length>0?ie:le).splice(0);for(let s of o)try{s()}catch(i){e.push(i)}}}finally{t&&(be=!1)}if(e.length===1)throw e[0];if(e.length>1)throw new AggregateError(e,"batch drain: multiple callbacks threw")}function Pe(t,e,n){if(e.length===0)return;if(e.length===1){let u=n(e[0][0]);if(u<3||!Le()){t(e);return}(u>=5?le:u===4?ie:se).push(()=>t(e));return}let r=e.length,o=r,s=r,i=r,a=0;for(;a<r&&n(e[a][0])<3;)a++;for(o=a;a<r&&n(e[a][0])===3;)a++;for(s=a;a<r&&n(e[a][0])===4;)a++;i=a;let c=Le();if(o>0){let u=e.slice(0,o);t(u)}if(s>o){let u=e.slice(o,s);c?se.push(()=>t(u)):t(u)}if(i>s){let u=e.slice(s,i);c?ie.push(()=>t(u)):t(u)}if(r>i){let u=e.slice(i,r);c?le.push(()=>t(u)):t(u)}}var de,be,se,ie,le,ye,ft=R(()=>{"use strict";de=0,be=!1,se=[],ie=[],le=[],ye=[]});function Z(){return Math.trunc(performance.now()*1e6)}function Fe(){return Date.now()*1e6}var je=R(()=>{"use strict"});function pt(t){let e=hr.filter(n=>t({type:n,id:""},"write"));return e.length===0?"restricted":e.includes("human")&&e.includes("llm")&&e.every(n=>n==="human"||n==="llm"||n==="system")?"both":e.length===1?e[0]:e.join("+")}var W,hr,Ve=R(()=>{"use strict";W=class extends Error{actor;action;nodeName;constructor(e,n){super(n??`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}},hr=["human","llm","wallet","system"]});var ve,F,q,J,K,Y,Q,j,H,L,pe,ht,gr,gt,mr,br,mt,en,tn,nn,bt,_e=R(()=>{"use strict";ve=Symbol.for("graphrefly/START"),F=Symbol.for("graphrefly/DATA"),q=Symbol.for("graphrefly/DIRTY"),J=Symbol.for("graphrefly/RESOLVED"),K=Symbol.for("graphrefly/INVALIDATE"),Y=Symbol.for("graphrefly/PAUSE"),Q=Symbol.for("graphrefly/RESUME"),j=Symbol.for("graphrefly/TEARDOWN"),H=Symbol.for("graphrefly/COMPLETE"),L=Symbol.for("graphrefly/ERROR"),pe=Object.freeze([q]),ht=Object.freeze([J]),gr=Object.freeze([K]),gt=Object.freeze([ve]),mr=Object.freeze([H]),br=Object.freeze([j]),mt=Object.freeze([pe]),en=Object.freeze([ht]),tn=Object.freeze([gr]),nn=Object.freeze([mr]),bt=Object.freeze([br])});function rn(t){t.registerMessageType(ve,{tier:0,wireCrossing:!1}),t.registerMessageType(q,{tier:1,wireCrossing:!1}),t.registerMessageType(K,{tier:1,wireCrossing:!1,metaPassthrough:!1}),t.registerMessageType(Y,{tier:2,wireCrossing:!1}),t.registerMessageType(Q,{tier:2,wireCrossing:!1}),t.registerMessageType(F,{tier:3,wireCrossing:!0}),t.registerMessageType(J,{tier:3,wireCrossing:!0}),t.registerMessageType(H,{tier:4,wireCrossing:!0,metaPassthrough:!1}),t.registerMessageType(L,{tier:4,wireCrossing:!0,metaPassthrough:!1}),t.registerMessageType(j,{tier:5,wireCrossing:!0,metaPassthrough:!1})}var He,on=R(()=>{"use strict";_e();He=class{_messageTypes=new Map;_codecs=new Map;_onMessage;_onSubscribe;_defaultVersioning;_defaultHashFn;_inspectorEnabled=!(typeof process<"u"&&process.env?.NODE_ENV==="production");_globalInspector;_rigorRecorder;_frozen=!1;tierOf;constructor(e){this._onMessage=e.onMessage,this._onSubscribe=e.onSubscribe,this._defaultVersioning=e.defaultVersioning,this._defaultHashFn=e.defaultHashFn,this.tierOf=n=>{let r=this._messageTypes.get(n);return r!=null?r.tier:1}}get onMessage(){return this._frozen=!0,this._onMessage}get onSubscribe(){return this._frozen=!0,this._onSubscribe}set onMessage(e){this._assertUnfrozen(),this._onMessage=e}set onSubscribe(e){this._assertUnfrozen(),this._onSubscribe=e}get defaultVersioning(){return this._defaultVersioning}set defaultVersioning(e){this._assertUnfrozen(),this._defaultVersioning=e}get defaultHashFn(){return this._defaultHashFn}set defaultHashFn(e){this._assertUnfrozen(),this._defaultHashFn=e}get inspectorEnabled(){return this._inspectorEnabled}set inspectorEnabled(e){this._inspectorEnabled=e}get globalInspector(){return this._globalInspector}set globalInspector(e){this._globalInspector=e}get rigorRecorder(){return this._rigorRecorder}set rigorRecorder(e){this._rigorRecorder=e}registerMessageType(e,n){return this._assertUnfrozen(),this._messageTypes.set(e,{tier:n.tier,wireCrossing:n.wireCrossing??n.tier>=3,metaPassthrough:n.metaPassthrough??!0}),this}messageTier(e){let n=this._messageTypes.get(e);return n!=null?n.tier:1}isWireCrossing(e){let n=this._messageTypes.get(e);return n!=null?n.wireCrossing:!0}isLocalOnly(e){return!this.isWireCrossing(e)}isMetaPassthrough(e){let n=this._messageTypes.get(e);return n!=null?n.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 yt(t){if(t===void 0)return null;if(typeof t=="number"){if(!Number.isFinite(t))throw new TypeError(`Cannot hash non-finite number: ${t}`);if(Number.isInteger(t)&&!Number.isSafeInteger(t))throw new TypeError(`Cannot hash integer outside safe range (|n| > 2^53-1): ${t}. Cross-language cid parity is not guaranteed for unsafe integers.`);return t}if(typeof t=="string"||typeof t=="boolean"||t===null)return t;if(Array.isArray(t))return t.map(yt);if(typeof t=="object"&&t!==null){let e={};for(let n of Object.keys(t).sort())e[n]=yt(t[n]);return e}return null}function _r(t){let e=vr.encode(t),n=e.length,r=n*8,o=n+9+63&-64,s=new Uint8Array(o);s.set(e),s[n]=128;let i=new DataView(s.buffer);i.setUint32(o-4,r>>>0,!1),i.setUint32(o-8,Math.floor(r/4294967296)>>>0,!1);let a=1779033703,c=3144134277,u=1013904242,d=2773480762,f=1359893119,p=2600822924,h=528734635,l=1541459225,b=new Uint32Array(64),g=(y,m)=>y>>>m|y<<32-m;for(let y=0;y<o;y+=64){for(let w=0;w<16;w++)b[w]=i.getUint32(y+w*4,!1);for(let w=16;w<64;w++){let I=b[w-15],C=b[w-2],D=g(I,7)^g(I,18)^I>>>3,X=g(C,17)^g(C,19)^C>>>10;b[w]=b[w-16]+D+b[w-7]+X>>>0}let m=a,v=c,_=u,k=d,E=f,O=p,N=h,S=l;for(let w=0;w<64;w++){let I=g(E,6)^g(E,11)^g(E,25),C=E&O^~E&N,D=S+I+C+yr[w]+b[w]>>>0,X=g(m,2)^g(m,13)^g(m,22),ue=m&v^m&_^v&_,oe=X+ue>>>0;S=N,N=O,O=E,E=k+D>>>0,k=_,_=v,v=m,m=D+oe>>>0}a=a+m>>>0,c=c+v>>>0,u=u+_>>>0,d=d+k>>>0,f=f+E>>>0,p=p+O>>>0,h=h+N>>>0,l=l+S>>>0}let x=y=>y.toString(16).padStart(8,"0");return x(a)+x(c)+x(u)+x(d)+x(f)+x(p)+x(h)+x(l)}function vt(t){let e=yt(t??null),n=JSON.stringify(e);return _r(n).slice(0,16)}function xr(){let t=globalThis.crypto;if(t?.randomUUID)return t.randomUUID();let e=()=>Math.floor(Math.random()*4294967296).toString(16).padStart(8,"0"),n=e()+e()+e()+e();return`${n.slice(0,8)}-${n.slice(8,12)}-4${n.slice(13,16)}-${(parseInt(n.slice(16,17),16)&3|8).toString(16)}${n.slice(17,20)}-${n.slice(20,32)}`}function _t(t,e,n){let r=n?.id??xr();if(t===0)return{id:r,version:0};let s=(n?.hash??vt)(e);return{id:r,version:0,cid:s,prev:null}}function sn(t,e,n){t.version+=1,"cid"in t&&(t.prev=t.cid,t.cid=n(e))}var yr,vr,an=R(()=>{"use strict";yr=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]),vr=new TextEncoder});function dn(t){return{node:t,unsub:null,prevData:void 0,dirty:!1,involvedThisWave:!1,dataBatch:[],terminal:void 0}}function xt(t){t.prevData=void 0,t.dirty=!1,t.involvedThisWave=!1,t.dataBatch.length=0,t.terminal=void 0}function Be(t){return t.length===0?t:typeof t[0]=="symbol"?[t]:t}function ze(t,e,n){let r=ln(t)?t:[],o=typeof t=="function"?t:typeof e=="function"?e:void 0,s={};return ln(t)?s=(wt(e)?e:n)??{}:wt(t)?s=t:s=(wt(e)?e:n)??{},new P(r,o,s)}var un,cn,wr,Or,he,P,ln,wt,xe=R(()=>{"use strict";Ae();lt();ft();je();on();Ve();_e();an();un=()=>{},cn=100;wr=(t,e,n,r)=>{n.direction==="down-in"&&t._onDepMessage(n.depIndex,e)},Or=(t,e,n,r)=>{let o=t;if(o._status==="completed"||o._status==="errored")return;let s=o._cached,i=s===void 0?[gt]:[gt,[F,s]];o._status==="dirty"&&i.push(pe),Pe(e,i,o._config.tierOf)},he=new He({onMessage:wr,onSubscribe:Or});rn(he);De(he);P=class t{_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,n,r){this._config=r.config??he,this._config.onMessage,this._optsName=r.name,this._describeKind=r.describeKind,this._equals=r.equals??Object.is,this._resubscribable=r.resubscribable??!1,this._resetOnTeardown=r.resetOnTeardown??!1,this._autoComplete=r.completeWhenDepsComplete??!0,this._autoError=r.errorWhenDepsError??!0,this._pausable=r.pausable??!0,this._guard=r.guard,this._fn=n,this._partial=r.partial??!1,this._cached=r.initial!==void 0?r.initial:void 0,this._status=e.length===0&&n==null&&this._cached!==void 0?"settled":"sentinel",this._hashFn=r.versioningHash??this._config.defaultHashFn??vt;let o=r.versioning??this._config.defaultVersioning;this._versioningLevel=o,this._versioning=o!=null?_t(o,this._cached===void 0?void 0:this._cached,{id:r.versioningId,hash:this._hashFn}):void 0,this._deps=e.map(dn);let s={};for(let[a,c]of Object.entries(r.meta??{})){let u={initial:c,name:`${r.name??"node"}:meta:${a}`,describeKind:"state",config:this._config};r.guard!=null&&(u.guard=r.guard),s[a]=new t([],void 0,u)}Object.freeze(s),this.meta=s,this._hasMeta=Object.keys(s).length>0;let i=this;this._actions={emit(a){i._emit([[F,a]])},down(a){i._emit(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,n){if(this._isExecutingFn)throw new Error(`Node "${this.name}": _applyVersioning cannot run mid-fn \u2014 call it outside of \`_execFn\` (typically at graph setup time before the first subscribe).`);let r=this._versioningLevel;if(r!=null&&e<=r)return;let o=n?.hash??this._hashFn;o!==this._hashFn&&(this._hashFn=o);let s=this._cached===void 0?void 0:this._cached,i=this._versioning,a=i?.id??n?.id,c=i?.version??0,u=_t(e,s,{id:a,hash:o});u.version=c,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 n=$e(e);if(this._guard!=null&&!this._guard(n,"observe"))return!1;if(this._extraGuards!=null){for(let r of this._extraGuards)if(!r(n,"observe"))return!1}return!0}_checkGuard(e){if(e?.internal)return;let n=this._guard!=null||this._extraGuards!=null,r=e?.actor!=null;if(!n&&!r)return;let o=$e(e?.actor),s=e?.delivery==="signal"?"signal":"write";if(this._guard!=null&&!this._guard(o,s))throw new W({actor:o,action:s,nodeName:this.name});if(this._extraGuards!=null){for(let i of this._extraGuards)if(!i(o,s))throw new W({actor:o,action:s,nodeName:this.name})}this._lastMutation={actor:o,timestamp_ns:Fe()}}down(e,n){let r=Be(e);r.length!==0&&(this._checkGuard(n),this._emit(r))}emit(e,n){this._checkGuard(n),this._emit([[F,e]])}up(e,n){if(this._deps.length===0)return;let r=Be(e);if(r.length===0)return;this._checkGuard(n);let o=n??{internal:!0};this._validateUpTiers(r);for(let s of this._deps)s.node.up?.(r,o)}_emitUp(e){if(this._deps.length!==0&&e.length!==0){this._validateUpTiers(e);for(let n of this._deps)n.node.up?.(e,{internal:!0})}}_validateUpTiers(e){let n=this._config.tierOf;for(let r of e){let o=n(r[0]);if(o===3||o===4)throw new Error(`Node "${this.name}": tier-${o} messages cannot flow up \u2014 DATA/RESOLVED/COMPLETE/ERROR are downstream-only. Use \`down(...)\` for value delivery; \`up(...)\` is for control signals (DIRTY, INVALIDATE, PAUSE, RESUME, TEARDOWN).`)}}subscribe(e,n){if(n!=null&&this._guard!=null){let c=$e(n);if(!this._guard(c,"observe"))throw new W({actor:c,action:"observe",nodeName:this.name})}let o=this._isTerminal&&this._resubscribable;if(o){this._cached=void 0,this._status="sentinel",this._store={},this._hasCalledFnOnce=!1,this._waveHasNewData=!1,this._hasNewTerminal=!1,this._paused=!1,this._pendingWave=!1,this._pendingRerun=!1,this._isExecutingFn=!1,this._rerunDepth=0,this._dirtyDepCount=0,this._pauseLocks=null,this._pauseBuffer=null;for(let c of this._deps)xt(c);if(this._partial===!1){for(let c of this._deps)if(c.prevData!==void 0||c.dataBatch.length!==0||c.terminal!==void 0||c.dirty)throw new Error(`resubscribable-reset invariant: DepRecord not fully reset for node ${this._optsName??"(anonymous)"}`)}}this._sinkCount+=1;let s;try{s=this._config.onSubscribe(this,e,{sinkCount:this._sinkCount,afterTerminalReset:o},this._actions)}catch(c){throw this._sinkCount-=1,c}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(c){if(this._sinkCount-=1,this._removeSink(e),this._sinkCount===0&&(this._status="sentinel"),typeof s=="function")try{s()}catch{}throw c}this._status==="sentinel"&&this._cached===void 0&&(this._status="pending");let a=!1;return()=>{a||(a=!0,this._sinkCount-=1,this._removeSink(e),typeof s=="function"&&s(),this._sinks==null&&this._deactivate())}}_removeSink(e){if(this._sinks===e)this._sinks=null;else if(this._sinks!=null&&typeof this._sinks!="function")if(this._sinks.delete(e),this._sinks.size===1){let[n]=this._sinks;this._sinks=n}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,n=0;try{for(let r=0;r<e;r++){let o=r,s=this._deps[r];s.unsub=un,s.unsub=s.node.subscribe(i=>{if(s.unsub===null)return;let a=this._config.tierOf,c=!1;for(let u of i)a(u[0])>=3&&(c=!0),this._config.onMessage(this,u,{direction:"down-in",depIndex:o},this._actions);c&&this._maybeRunFnOnSettlement()}),n++}}catch(r){this._deps[n].unsub=null;for(let o=0;o<n;o++){let s=this._deps[o];if(s.unsub!=null){let i=s.unsub;s.unsub=null;try{i()}catch{}xt(s)}}throw this._dirtyDepCount=0,r}}_addDep(e){for(let o=0;o<this._deps.length;o++)if(this._deps[o].node===e)return o;let n=this._deps.length,r=dn(e);if(this._deps.push(r),this._sinks==null)return n;r.dirty=!0,this._dirtyDepCount++,this._status!=="dirty"&&this._emit(mt),r.unsub=un;try{r.unsub=e.subscribe(o=>{if(r.unsub===null)return;let s=this._config.tierOf,i=!1;for(let a of o)s(a[0])>=3&&(i=!0),this._config.onMessage(this,a,{direction:"down-in",depIndex:n},this._actions);i&&this._maybeRunFnOnSettlement()})}catch(o){throw r.unsub=null,this._deps.pop(),this._dirtyDepCount--,o}return n}_deactivate(e=!1){let n=this._cleanup;if(this._cleanup=void 0,typeof n=="function")try{n()}catch(r){this._emit([[L,this._wrapFnError("cleanup threw",r)]])}else if(n!=null&&typeof n=="object"){let r=n.deactivate;if(typeof r=="function")try{r()}catch(o){this._emit([[L,this._wrapFnError("cleanup.deactivate threw",o)]])}}for(let r of this._deps){if(r.unsub!=null){let o=r.unsub;r.unsub=null;try{o()}catch{}}xt(r)}this._waveHasNewData=!1,this._hasNewTerminal=!1,this._hasCalledFnOnce=!1,this._paused=!1,this._pendingWave=!1,this._pendingRerun=!1,this._rerunDepth=0,this._store={},this._dirtyDepCount=0,this._pauseLocks=null,this._pauseBuffer=null,this._fn!=null&&(this._cached=void 0),e||(this._fn!=null||this._deps.length>0)&&(!this._isTerminal||this._resubscribable)&&(this._status="sentinel")}_onDepMessage(e,n){let r=this._deps[e],o=n[0];if(this._inspectorHooks!=null){let s={kind:"dep_message",depIndex:e,message:n};for(let i of this._inspectorHooks)i(s)}if(o!==ve){if(o===q){this._depDirtied(r);return}if(o===K){if(this._depInvalidated(r),this._cached===void 0)return;this._emit(tn);return}if(o===Y||o===Q){this._emit([n]);return}if(o===j){this._emit(bt);return}if(o===F)this._depSettledAsData(r,n[1]);else if(o===J)this._depSettledAsResolved(r);else if(o===H)this._depSettledAsTerminal(r,!0);else if(o===L)this._depSettledAsTerminal(r,n[1]);else{this._emit([n]);return}if(!this._fn){(o===F||o===J)&&this._emit([n]),(o===H||o===L)&&this._maybeAutoTerminalAfterWave();return}}}_depDirtied(e){e.dirty||(e.dirty=!0,e.involvedThisWave=!0,this._dirtyDepCount++,this._status!=="dirty"&&this._emit(mt))}_depSettledAsData(e,n){e.dirty&&(e.dirty=!1,this._dirtyDepCount--),e.involvedThisWave=!0,e.dataBatch.push(n),this._waveHasNewData=!0}_depSettledAsResolved(e){e.dirty&&(e.dirty=!1,this._dirtyDepCount--)}_depSettledAsTerminal(e,n){e.dirty&&(e.dirty=!1,this._dirtyDepCount--),e.terminal=n,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 n=this._deps[e];if(n.dataBatch.length===0&&n.prevData===void 0&&n.terminal===void 0){this._maybeAutoTerminalAfterWave();return}}if(this._paused){this._pendingWave=!0;return}if(!this._waveHasNewData&&!this._hasNewTerminal&&this._hasCalledFnOnce){this._clearWaveFlags(),this._emit(en),this._maybeAutoTerminalAfterWave();return}this._fn&&this._execFn(),this._maybeAutoTerminalAfterWave()}}_maybeAutoTerminalAfterWave(){if(this._deps.length===0||this._isTerminal)return;let e=this._deps.find(n=>n.terminal!==void 0&&n.terminal!==!0);if(e!=null){this._autoError&&this._emit([[L,e.terminal]]);return}this._autoComplete&&this._deps.every(n=>n.terminal!==void 0)&&this._emit(nn)}_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([[L,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([[L,this._wrapFnError("cleanup.beforeRun threw",a)]]);return}}}let n=this._deps.map(i=>i.involvedThisWave?i.dataBatch.length>0?[...i.dataBatch]:[]:void 0),r=this._deps.map(i=>i.prevData);for(let i=0;i<this._deps.length;i++){let a=n[i];a!=null&&a.length>0&&(this._deps[i].prevData=a[a.length-1])}let o=this._deps.map(i=>i.terminal),s={prevData:r,terminalDeps:o,store:this._store};if(this._hasCalledFnOnce=!0,this._clearWaveFlags(),this._inspectorHooks!=null){let i={kind:"run",batchData:n,prevData:r};for(let a of this._inspectorHooks)a(i)}this._isExecutingFn=!0;try{let i=this._fn(n,this._actions,s);if(typeof i=="function")this._cleanup=i;else if(i!=null&&typeof i=="object"){let a=i;(typeof a.beforeRun=="function"||typeof a.deactivate=="function"||typeof a.invalidate=="function")&&(this._cleanup=i)}}catch(i){this._emit([[L,this._wrapFnError("fn threw",i)]])}finally{this._isExecutingFn=!1,this._pendingRerun?(this._pendingRerun=!1,this._rerunDepth+=1,this._rerunDepth>cn?(this._rerunDepth=0,this._emit([[L,new Error(`Node "${this.name}": _pendingRerun depth exceeded ${cn} \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,n){let r=n instanceof Error?n.message:String(n);return new Error(`Node "${this.name}": ${e}: ${r}`,{cause:n})}_frameBatch(e){let n=this._config.tierOf;if(e.length===1)return n(e[0][0])===3&&this._status!=="dirty"?[pe,e[0]]:e;let r=!0,o=!1,s=!1,i=-1;for(let c of e){let u=n(c[0]);u<i&&(r=!1),u===3&&(o=!0),c[0]===q&&(s=!0),i=u}let a=e;if(!r){let c=e.map((u,d)=>({m:u,i:d,tier:n(u[0])}));c.sort((u,d)=>u.tier-d.tier||u.i-d.i),a=c.map(u=>u.m)}if(o&&!s&&this._status!=="dirty"){let c=0;for(;c<a.length&&n(a[c][0])===0;)c++;return c===0?[pe,...a]:[...a.slice(0,c),pe,...a.slice(c)]}return a}_emit(e){if(e.length===0)return;for(let a=0;a<e.length;a++){let c=e[a];if(c[0]===L&&c[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 n=e;if(this._isTerminal&&!this._resubscribable){let a=e.filter(c=>c[0]===j||c[0]===K);if(a.length===0)return;n=a}n=this._frameBatch(n);let o=null;for(let a=0;a<n.length;a++){let c=n[a],u=c[0];if(u!==Y&&u!==Q){o?.push(c);continue}if(c.length<2)throw new Error(`Node "${this.name}": [[${u===Y?"PAUSE":"RESUME"}]] must carry a lockId payload \u2014 bare PAUSE/RESUME is a protocol violation (C0 rule). Use \`[[PAUSE, lockId]]\` / \`[[RESUME, lockId]]\`.`);let d=!0;if(this._pausable!==!1){let f=c[1];if(u===Y)this._pauseLocks==null&&(this._pauseLocks=new Set),this._pauseLocks.add(f),this._paused=!0,this._pausable==="resumeAll"&&this._pauseBuffer==null&&(this._pauseBuffer=[]);else if(this._pauseLocks==null||!this._pauseLocks.has(f))d=!1;else if(this._pauseLocks.delete(f),this._pauseLocks.size===0){if(this._paused=!1,this._pauseBuffer!=null&&this._pauseBuffer.length>0){let p=this._pauseBuffer;this._pauseBuffer=[],this._emit(p)}this._pendingWave&&(this._pendingWave=!1,this._maybeRunFnOnSettlement())}}d?o?.push(c):o==null&&(o=n.slice(0,a))}if(o!=null){if(o.length===0)return;n=o}if(this._hasMeta&&n.some(a=>a[0]===j))for(let a of Object.keys(this.meta))try{this.meta[a]._emit(bt)}catch{}let{finalMessages:s,equalsError:i}=this._updateState(n);if(s.length>0&&this._config.inspectorEnabled){let a=this._config.globalInspector;if(a!=null)try{a({kind:"emit",node:this,messages:s})}catch{}}if(s.length>0)if(this._paused&&this._pausable==="resumeAll"&&this._pauseBuffer!=null){let a=this._config.tierOf,c=[];for(let u of s)a(u[0])===3?this._pauseBuffer.push(u):c.push(u);c.length>0&&this._dispatchOrAccumulate(c)}else this._dispatchOrAccumulate(s);i!=null&&this._emit([[L,i]])}_updateState(e){let n=this._config.tierOf,r,o,s=-1,i=0;for(let d of e)n(d[0])===3&&i++;let a=i<=1,c=-1;if(this._versioning!=null&&i>1){for(let d=e.length-1;d>=0;d--)if(e[d][0]===F){c=d;break}}for(let d=0;d<e.length;d++){let f=e[d],p=f[0];if(p===F){if(f.length>=2){let h=!1;if(a&&this._cached!==void 0)try{h=this._equals(this._cached,f[1])}catch(l){o=this._wrapFnError("equals threw",l),s=d;break}if(h){r==null&&(r=e.slice(0,d)),r.push(ht),this._status="resolved";continue}this._cached=f[1],this._versioning!=null&&(c<0||d===c)&&sn(this._versioning,f[1],this._hashFn)}this._status="settled",r?.push(f)}else if(r?.push(f),p===q)this._status="dirty";else if(p===J)this._status="resolved";else if(p===H){this._status="completed";{let h=this._config.rigorRecorder;if(h!=null)try{h.onTerminalTransition(this,"completed",this._autoComplete,this._autoError,this._deps.length>0)}catch{}}}else if(p===L){this._status="errored";{let h=this._config.rigorRecorder;if(h!=null)try{h.onTerminalTransition(this,"errored",this._autoComplete,this._autoError,this._deps.length>0)}catch{}}}else if(p===K){if(this._cached!==void 0){let l=this._config.rigorRecorder;if(l!=null)try{l.onNonVacuousInvalidate(this,this._cached)}catch{}}this._cached=void 0,this._status="dirty";let h=this._cleanup;if(typeof h=="function"){this._cleanup=void 0;try{h()}catch{}}else if(h!=null&&typeof h=="object"){let l=h.invalidate;if(typeof l=="function")try{l()}catch{}}}else p===j&&(this._resetOnTeardown&&(this._cached=void 0),this._deactivate(!0),this._status="sentinel")}let u=s>=0?r??e.slice(0,s):r??e;return o!=null?{finalMessages:u,equalsError:o}:{finalMessages:u}}_deliverToSinks=e=>{if(this._sinks==null)return;if(typeof this._sinks=="function"){this._sinks(e);return}let n=[...this._sinks];for(let r of n)r(e)};_dispatchOrAccumulate(e){if(Zt()){this._batchPendingMessages===null&&(this._batchPendingMessages=[],fe(()=>this._flushBatchPending()));for(let n of e)this._batchPendingMessages.push(n);return}Pe(this._deliverToSinks,e,this._config.tierOf)}_flushBatchPending(){let e=this._batchPendingMessages;if(e===null||(this._batchPendingMessages=null,e.length===0))return;let n=this._frameBatch(e);Pe(this._deliverToSinks,n,this._config.tierOf)}},ln=t=>Array.isArray(t),wt=t=>typeof t=="object"&&t!=null&&!Array.isArray(t)});function Ot(t,e){if(e!=null&&e.length>0)return new Set(e);switch(t){case"standard":return new Set(["type","status","value","deps","meta","v"]);case"full":return null;case"spec":return new Set(["type","deps","meta","value"]);default:return new Set(["type","deps"])}}function Tr(t){return t._describeKind!=null?t._describeKind:t._deps.length>0?"derived":t._fn!=null?"producer":"state"}function kr(t){let e={};for(let[n,r]of Object.entries(t.meta))try{e[n]=r.cache}catch{}return e}function Tt(t,e,n){let r=e==null,o=!r&&e!=null?[...e].filter(d=>d.startsWith("meta.")).map(d=>d.slice(5)):null,s=r||e.has("meta")||o!=null&&o.length>0,i="state",a=[];t instanceof P&&(i=Tr(t),a=t._deps.map(d=>d.node.name??""));let c={type:i,deps:a};(r||e.has("status"))&&(c.status=t.status);let u=t instanceof P?t._guard:void 0;if(s){let d={...kr(t)};if(u!=null&&d.access===void 0&&(d.access=pt(u)),o!=null&&o.length>0&&!e.has("meta")){let f={};for(let p of o)p in d&&(f[p]=d[p]);c.meta=f}else c.meta=d}if(t.name!=null&&(c.name=t.name),(r||e.has("value"))&&(!n||i==="state")){t.status==="sentinel"&&(c.sentinel=!0);try{c.value=t.cache}catch{}}if((r||e.has("v"))&&t.v!=null){let d={id:t.v.id,version:t.v.version};"cid"in t.v&&(d.cid=t.v.cid,d.prev=t.v.prev),c.v=d}return(r||e.has("guard"))&&u!=null&&(c.guard=pt(u)),(r||e.has("lastMutation"))&&t.lastMutation!=null&&(c.lastMutation=t.lastMutation),c}var fn=R(()=>{"use strict";Ve();xe()});function we(t,e){return ze([],{...e,initial:t})}function kt(t,e){return ze((r,o,s)=>t(o,s)??void 0,{describeKind:"producer",...e})}function Et(t,e,n){return ze(t,(o,s,i)=>{let a=o.map((c,u)=>c!=null&&c.length>0?c.at(-1):i.prevData[u]);s.emit(e(a,i))},{describeKind:"derived",...n})}var pn=R(()=>{"use strict";xe()});function Nt(t,e){if(Object.is(t,e))return!0;if(t==null||e==null||typeof t!="object"||typeof e!="object")return!1;if(Array.isArray(t)){if(!Array.isArray(e)||t.length!==e.length)return!1;for(let s=0;s<t.length;s++)if(!Nt(t[s],e[s]))return!1;return!0}if(Array.isArray(e))return!1;let n=Object.keys(t),r=Object.keys(e);if(n.length!==r.length)return!1;let o=new Set(r);for(let s of n)if(!o.has(s)||!Nt(t[s],e[s]))return!1;return!0}function hn(t,e){return`${t}\0${e}`}function St(t,e){let n=[],r=new Set(t.subgraphs),o=new Set(e.subgraphs),s=[];for(let g of o)r.has(g)||s.push(g);s.sort();for(let g of s)n.push({type:"subgraph-mounted",path:g});let i=new Set(Object.keys(t.nodes)),a=new Set(Object.keys(e.nodes)),c=[];for(let g of a)i.has(g)||c.push(g);c.sort();for(let g of c)n.push({type:"node-added",path:g,node:{...e.nodes[g]}});let u=[];for(let g of a){if(!i.has(g))continue;let x=t.nodes[g]?.meta,y=e.nodes[g]?.meta;x==null&&y==null||Nt(x??{},y??{})||u.push(g)}u.sort();for(let g of u)n.push({type:"node-meta-changed",path:g,prevMeta:t.nodes[g]?.meta??{},nextMeta:e.nodes[g]?.meta??{}});let d=new Map;for(let g of t.edges)d.set(hn(g.from,g.to),g);let f=new Map;for(let g of e.edges)f.set(hn(g.from,g.to),g);let p=[];for(let[g,x]of f)d.has(g)||p.push(x);p.sort((g,x)=>g.from<x.from?-1:g.from>x.from?1:g.to<x.to?-1:g.to>x.to?1:0);for(let g of p)n.push({type:"edge-added",from:g.from,to:g.to});let h=[];for(let[g,x]of d)f.has(g)||h.push(x);h.sort((g,x)=>g.from<x.from?-1:g.from>x.from?1:g.to<x.to?-1:g.to>x.to?1:0);for(let g of h)n.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)n.push({type:"node-removed",path:g});let b=[];for(let g of r)o.has(g)||b.push(g);b.sort();for(let g of b)n.push({type:"subgraph-unmounted",path:g});return{events:n,flushedAt_ns:Z()}}var gn=R(()=>{"use strict";je()});function Ue(t){return t.subscribe(()=>{})}var mn=R(()=>{"use strict"});var bn=R(()=>{"use strict";mn()});var We,yn=R(()=>{"use strict";We=class{_timer;_gen=0;start(e,n){this.cancel(),this._gen+=1;let r=this._gen;this._timer=setTimeout(()=>{this._timer=void 0,r===this._gen&&n()},e)}cancel(){this._timer!==void 0&&(clearTimeout(this._timer),this._timer=void 0)}get pending(){return this._timer!==void 0}}});var Oe,vn=R(()=>{"use strict";Oe=class{constructor(e){this.capacity=e;if(!Number.isInteger(e)||e<=0)throw new Error(`RingBuffer capacity must be a positive integer (got ${e})`);this.buf=new Array(e)}buf;head=0;_size=0;get size(){return this._size}get maxSize(){return this.capacity}push(e){let n=(this.head+this._size)%this.capacity;this.buf[n]=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 n=e<0?this._size+e:e;if(!(n<0||n>=this._size))return this.buf[(this.head+n)%this.capacity]}toArray(){let e=new Array(this._size);for(let n=0;n<this._size;n++)e[n]=this.buf[(this.head+n)%this.capacity];return e}clear(){for(let e=0;e<this._size;e++)this.buf[(this.head+e)%this.capacity]=void 0;this.head=0,this._size=0}}});function Ke(t,e){let n=e?.topN??10,r=t.describe({detail:"standard"}),o=[],s=t._collectObserveTargets;typeof s=="function"&&s.call(t,"",o);let i=new Map;for(let[p,h]of o)i.set(p,h);let a=[];for(let[p,h]of Object.entries(r.nodes)){let l=i.get(p),b=l instanceof P?l:null,g=b?Ne(b.cache):0,x=b?b._sinkCount:0,y=h.deps?.length??0,m=h.type==="effect"&&x===0,v=x===0?h.type==="effect"?"orphan-effect":h.type==="derived"?"idle-derived":h.type==="producer"?"idle-producer":null:null;a.push({path:p,type:h.type,status:h.status??"unknown",valueSizeBytes:g,subscriberCount:x,depCount:y,isOrphanEffect:m,orphanKind:v})}let c=a.reduce((p,h)=>p+h.valueSizeBytes,0),u=(p,h)=>[...a].sort(h??((l,b)=>b[p]-l[p])).slice(0,n),d=a.filter(p=>p.orphanKind!=null),f=a.filter(p=>p.isOrphanEffect);return{nodeCount:a.length,edgeCount:r.edges.length,subgraphCount:r.subgraphs.length,nodes:a,totalValueSizeBytes:c,hotspots:{byValueSize:u("valueSizeBytes"),bySubscriberCount:u("subscriberCount"),byDepCount:u("depCount")},orphans:d,orphanEffects:f}}var Rt=R(()=>{"use strict";xe();ut()});function _n(t,e){let n=Math.max(16,t.size*4),r=0;for(;t.size>0;){if(r++>=n){console.error(`[Graph "${e}".destroy] disposer drain exceeded cap (${n}); ${t.size} disposer(s) discarded`),t.clear();return}let o=t.values().next();if(o.done)return;let s=o.value;t.delete(s);try{s()}catch(i){console.error(`[Graph "${e}".destroy] disposer threw:`,i)}}}function kn(t){return t!=null&&typeof t=="object"&&"cache"in t&&typeof t.subscribe=="function"&&typeof t.down=="function"}function Er(t){if(t!=null)return kn(t)?t.cache:t}function ae(t){return t!=null&&typeof t=="object"&&"cache"in t&&typeof t.subscribe=="function"&&typeof t.down=="function"}function ee(t){return ae(t)?t.cache??"":t}function xn(t){return ae(t)?t.cache??0:t}function wn(t){return ae(t)?t.cache??!1:t}function Nr(t){let e=[];for(let n of Object.keys(t).sort()){let r=t[n].v;r!=null&&e.push(`${n} ${r.id} ${r.version}`)}return e.join(`
|
|
3
|
+
`)}function On(t){if(t.version!==te)throw new Error(`unsupported snapshot version ${String(t.version)} (expected ${te})`);for(let e of["name","nodes","edges","subgraphs"])if(!(e in t))throw new Error(`snapshot missing required key "${e}"`);if(typeof t.name!="string")throw new TypeError("snapshot 'name' must be a string");if(typeof t.nodes!="object"||t.nodes===null||Array.isArray(t.nodes))throw new TypeError("snapshot 'nodes' must be an object");if(!Array.isArray(t.edges))throw new TypeError("snapshot 'edges' must be an array");if(!Array.isArray(t.subgraphs))throw new TypeError("snapshot 'subgraphs' must be an array")}function Sr(t,e){let n=new WeakMap,r=(o,s)=>{if(Object.is(o,s))return!0;if(o==null||s==null||typeof o!="object"||typeof s!="object")return!1;let i=n.get(o);if(i==null&&(i=new WeakSet,n.set(o,i)),i.has(s))return!0;i.add(s);let a=o.constructor,c=s.constructor;if(a!==c)return!1;if(o instanceof Date)return o.getTime()===s.getTime();if(o instanceof RegExp)return o.source===s.source&&o.flags===s.flags;if(Array.isArray(o)){let p=s;if(o.length!==p.length)return!1;for(let h=0;h<o.length;h++)if(!r(o[h],p[h]))return!1;return!0}if(o instanceof Map){let p=s;if(o.size!==p.size)return!1;for(let[h,l]of o)if(!p.has(h)||!r(l,p.get(h)))return!1;return!0}if(o instanceof Set){let p=s;if(o.size!==p.size)return!1;for(let h of o){let l=!1;for(let b of p)if(r(h,b)){l=!0;break}if(!l)return!1}return!0}if(ArrayBuffer.isView(o)){let p=o,h=s;if(p.length!==h.length)return!1;for(let l=0;l<p.length;l++)if(p[l]!==h[l])return!1;return!0}let u=Object.keys(o),d=Object.keys(s);if(u.length!==d.length)return!1;let f=new Set(d);for(let p of u)if(!f.has(p)||!r(o[p],s[p]))return!1;return!0};return r(t,e)}function Rr(t){return t.replace(/[.*+?^${}()|[\]\\]/g,"\\$&")}function qe(t){let e="^";for(let n=0;n<t.length;n+=1){let r=t[n];if(r==="*"){e+=".*";continue}if(r==="?"){e+=".";continue}if(r==="["){let o=t.indexOf("]",n+1);if(o<=n+1){e+="\\[";continue}let s=t.slice(n+1,o);s.startsWith("!")&&(s=`^${s.slice(1)}`),s=s.replace(/\\/g,"\\\\"),e+=`[${s}]`,n=o;continue}e+=Rr(r)}return e+="$",new RegExp(e)}function Dt(t){if(typeof t=="string")return JSON.stringify(t);if(typeof t=="number"||typeof t=="boolean"||t==null)return String(t);try{return JSON.stringify(t)}catch{return"[unserializable]"}}function Cr(t){return t==="none"?Ar:t==="ansi"||t==null?Dr:{data:t.data??"",dirty:t.dirty??"",resolved:t.resolved??"",invalidate:t.invalidate??"",pause:t.pause??"",resume:t.resume??"",complete:t.complete??"",error:t.error??"",teardown:t.teardown??"",derived:t.derived??"",path:t.path??"",reset:t.reset??""}}function Tn(t){if(t==null)return{};let e=t.detail;return e==="full"?{...t,structured:t.structured??!0,timeline:t.timeline??!0,causal:t.causal??!0,derived:t.derived??!0}:e==="minimal"?{...t,structured:t.structured??!0}:t.format==="stage-log"?{...t,structured:t.structured??!0,timeline:t.timeline??!0}:t}function Mr(t,e,n){for(let r=0;r<t.length;r++){let o=t.charCodeAt(r);if(o<32||o===127)throw new Error(`Graph "${e}": ${n} "${t}" must not contain control character (U+${o.toString(16).padStart(4,"0").toUpperCase()} at index ${r})`)}}function At(t,e,n){if(t==="")throw new Error(`Graph "${e}": ${n} name must be non-empty`);if(t.includes(G))throw new Error(`Graph "${e}": ${n} "${t}" must not contain '${G}' (path separator)`);if(t===B)throw new Error(`Graph "${e}": ${n} name "${B}" is reserved for meta companion paths`);Mr(t,e,n)}function Gr(t,e){if(t==="")throw new Error(`Graph "${e}": resolve path must be non-empty`);let n=t.split(G);for(let r of n)if(r==="")throw new Error(`Graph "${e}": resolve path has empty segment`);return n}function Ir(t,e){let n=!1;for(let o of t)if(!e.isMetaPassthrough(o[0])){n=!0;break}return n?t.filter(o=>e.isMetaPassthrough(o[0])):t}function En(t){for(let e of t._mounts.values())En(e);for(let e of t._nodes.values())try{e.down([[j]],{internal:!0})}catch{}}function Ct(t,e){let n=ne.diff(t,e),r={};for(let o of n.nodesAdded){let s=e.nodes[o];s!=null&&(r[o]=s)}return{...n,nodesAddedFull:r}}function Je(t,e,n,r={}){let o={paths:[],depths:new Map,truncated:!1};if(!e)return r.withDetail?o:[];if(!r.both&&n!=="upstream"&&n!=="downstream")throw new Error('reachable: direction must be "upstream" or "downstream"');let s=r.maxDepth;if(s!=null&&(!Number.isInteger(s)||s<0))throw new Error("reachable: maxDepth must be an integer >= 0");if(s===0)return r.withDetail?o:[];let i=new Map,a=new Map,c=new Map,u=new Map,d=new Set;for(let[m,v]of Object.entries(t.nodes)){if(!m)continue;d.add(m);let _=v.deps??[];i.set(m,_);for(let k of _)k&&(d.add(k),a.has(k)||a.set(k,new Set),a.get(k).add(m))}for(let m of t.edges){if(m==null||typeof m!="object")continue;let v=typeof m.from=="string"?m.from:"",_=typeof m.to=="string"?m.to:"";!v||!_||(d.add(v),d.add(_),u.has(v)||u.set(v,new Set),u.get(v).add(_),c.has(_)||c.set(_,new Set),c.get(_).add(v))}if(!d.has(e))return r.withDetail?o:[];let f=r.both===!0,p=m=>{if(f){let E=i.get(m)??[],O=c.get(m),N=a.get(m),S=u.get(m),w=[...E];return O&&w.push(...O),N&&w.push(...N),S&&w.push(...S),w}if(n==="upstream"){let E=i.get(m)??[],O=c.get(m);return O?[...E,...O]:E}let v=a.get(m),_=u.get(m),k=v?[...v]:[];return _&&k.push(..._),k},h=new Set([e]),l=new Map,b=[{path:e,depth:0}],g=0,x=!1;for(;g<b.length;){let m=b[g++];if(s!=null&&m.depth>=s){p(m.path).length>0&&(x=!0);continue}for(let v of p(m.path))!v||h.has(v)||(h.add(v),l.set(v,m.depth+1),b.push({path:v,depth:m.depth+1}))}let y=[...l.keys()].sort((m,v)=>m<v?-1:m>v?1:0);return r.withDetail?{paths:y,depths:l,truncated:x}:y}function $r(t,e){if(t.length!==e.length)return!1;for(let n=0;n<t.length;n++){let r=t[n],o=e[n];if(r.path!==o.path||r.type!==o.type||r.status!==o.status||r.hop!==o.hop||r.dep_index!==o.dep_index||r.annotation!==o.annotation||r.value!==o.value||r.lastMutation!==o.lastMutation)return!1;let s=r.v,i=o.v;if(s!==i&&(s==null||i==null||s.id!==i.id||s.version!==i.version))return!1}return!0}var G,B,te,Dr,Ar,ne,Mt=R(()=>{"use strict";lt();ft();je();Ve();_e();fn();xe();pn();gn();bn();yn();vn();Ae();dt();Rt();G="::",B="__meta__",te=1;Dr={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:""};ne=class t{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,n){if(e==="")throw new Error("Graph name must be non-empty");if(e.includes(G))throw new Error(`Graph name must not contain '${G}' (got "${e}")`);if(e===B)throw new Error(`Graph name "${B}" is reserved for meta companion paths`);this.name=e,this.opts=Object.freeze({...n??{}}),this.config=n?.config??he,this._traceRing=new Oe(n?.traceCapacity??1e3),n?.versioning!=null&&this.setVersioning(n.versioning),typeof n?.factory=="string"&&(this._factory=n.factory,n.factoryArgs!==void 0&&(this._factoryArgs=n.factoryArgs))}tagFactory(e,n){return this._factory=e,this._factoryArgs=n,this}ancestors(e=!0){let n=[],r=e?this:this._parent;for(;r!=null;)n.push(r),r=r._parent;return n}get topology(){return this._topology==null&&(this._topology=kt(e=>{let n=r=>{e.emit(r)};return this._topologyEmitters.add(n),()=>{this._topologyEmitters.delete(n)}},{name:`${this.name}_topology`})),this._topology}_emitTopology(e){if(!(this._topology==null||this._topologyEmitters.size===0))for(let n of this._topologyEmitters)n(e)}nameOf(e){return this._nodeToName.get(e)}add(e,n){let r=e.name,o=n?.name??r;if(o==null||o==="")throw new Error(`Graph "${this.name}": graph.add requires a non-empty name \u2014 pass via opts.name or set it on the node (e.g. state(0, { name: "x" }))`);let s=o,i=n?.annotation;if(At(s,this.name,"add"),this._mounts.has(s))throw new Error(`Graph "${this.name}": name "${s}" is already a mount point`);if(this._nodes.has(s))throw new Error(`Graph "${this.name}": node "${s}" already exists`);let a=this._nodeToName.get(e);if(a!==void 0)throw new Error(`Graph "${this.name}": node instance already registered as "${a}"`);return this._nodes.set(s,e),this._nodeToName.set(e,s),this._emitTopology({kind:"added",name:s,nodeKind:"node"}),i!=null&&(this._annotations.set(s,i),this.config.inspectorEnabled&&this._traceRing.push({path:s,annotation:i,timestamp_ns:Z()})),e}setVersioning(e){if(e!=null)for(let n of this._nodes.values())n instanceof P&&n._applyVersioning(e)}remove(e){At(e,this.name,"remove");let n=this._mounts.get(e);if(n){let s={kind:"mount",nodes:[],mounts:[]},i=[];n._collectObserveTargets("",i);for(let[a,c]of i)a.includes(`${G}${B}${G}`)||s.nodes.push(a);return s.nodes.sort(),s.mounts.push(e),s.mounts.push(...n._collectSubgraphs(`${e}${G}`)),this._mounts.delete(e),n._parent=void 0,En(n),this._emitTopology({kind:"removed",name:e,nodeKind:"mount",audit:s}),s}let r=this._nodes.get(e);if(!r)throw new Error(`Graph "${this.name}": unknown node or mount "${e}"`);this._nodes.delete(e),this._nodeToName.delete(r),r.down([[j]],{internal:!0});let o={kind:"node",nodes:[e],mounts:[]};return this._emitTopology({kind:"removed",name:e,nodeKind:"node",audit:o}),o}removeAll(e){let n=typeof e=="function"?e:(()=>{let s=qe(e);return i=>s.test(i)})(),r={kind:"mount",nodes:[],mounts:[]},o=[...this._nodes.keys(),...this._mounts.keys()].filter(s=>n(s));for(let s of o){let i=this.remove(s);r.nodes.push(...i.nodes),r.mounts.push(...i.mounts)}return r.nodes.sort(),r.mounts.sort(),r}[Symbol.iterator](){let e=[...this._nodes.keys()].sort(),n=this._nodes,r=0;return{[Symbol.iterator](){return this},next(){if(r>=e.length)return{value:void 0,done:!0};let o=e[r++];return{value:[o,n.get(o)],done:!1}}}}node(e){if(e==="")throw new Error(`Graph "${this.name}": node name must be non-empty`);if(e.includes(G))return this.resolve(e);let n=this._nodes.get(e);if(!n)throw new Error(`Graph "${this.name}": unknown node "${e}"`);return n}get(e){return this.node(e).cache}set(e,n,r){let o=r?.internal===!0;this.node(e).down([[F,n]],{actor:r?.actor,internal:o,delivery:"write"})}setAll(e,n){let r=Symbol.iterator in e?e:Object.entries(e);Qt(()=>{for(let[o,s]of r)this.set(o,s,n)})}invalidate(e,n){let r=n?.internal===!0;this.node(e).down([[K]],{actor:n?.actor,internal:r,delivery:"write"})}error(e,n,r){let o=r?.internal===!0;this.node(e).down([[L,n]],{actor:r?.actor,internal:o,delivery:"write"})}complete(e,n){let r=n?.internal===!0;this.node(e).down([[H]],{actor:n?.actor,internal:r,delivery:"write"})}edges(e){let n=e?.recursive===!0,r=new Map;if(!n){for(let[c,u]of this._nodes)r.set(u,c);let a=[];for(let[c,u]of this._nodes)if(u instanceof P)for(let d of u._deps){let f=r.get(d.node);f!=null&&a.push([f,c])}return a.sort((c,u)=>c[0]<u[0]?-1:c[0]>u[0]?1:c[1]<u[1]?-1:c[1]>u[1]?1:0),a}let o=[];this._collectObserveTargets("",o);let s=new Map;for(let[a,c]of o)s.set(c,a);let i=[];for(let[a,c]of o)if(c instanceof P)for(let u of c._deps){let d=s.get(u.node);d!=null&&i.push([d,a])}return i.sort((a,c)=>a[0]<c[0]?-1:a[0]>c[0]?1:a[1]<c[1]?-1:a[1]>c[1]?1:0),i}mount(e,n){if(n===void 0){let o=new t(e);return this.mount(e,o)}if(typeof n=="function"){let o=new t(e);return n(o),this.mount(e,o)}let r=n;if(At(e,this.name,"mount"),this._nodes.has(e))throw new Error(`Graph "${this.name}": cannot mount at "${e}" \u2014 node with that name exists`);if(this._mounts.has(e))throw new Error(`Graph "${this.name}": mount "${e}" already exists`);if(r===this)throw new Error(`Graph "${this.name}": cannot mount a graph into itself`);if(r._parent!=null)throw new Error(`Graph "${this.name}": this child graph is already mounted on "${r._parent.name}"`);for(let o=this;o!=null;o=o._parent)if(o===r)throw new Error(`Graph "${this.name}": mount("${e}", \u2026) would create a mount cycle`);return this._mounts.set(e,r),r._parent=this,this._emitTopology({kind:"added",name:e,nodeKind:"mount"}),r}resolve(e){let n=Gr(e,this.name);return this._resolveFromSegments(n)}tryResolve(e){try{return this.resolve(e)}catch{return}}_resolveFromSegments(e){let n=e;if(n[0]===this.name&&(n=n.slice(1),n.length===0))throw new Error(`Graph "${this.name}": resolve path ends at graph name only`);let r=n[0],o=n.slice(1);if(o.length===0){let a=this._nodes.get(r);if(a)return a;throw this._mounts.has(r)?new Error(`Graph "${this.name}": path ends at subgraph "${r}" \u2014 not a node (GRAPHREFLY-SPEC \xA73.5)`):new Error(`Graph "${this.name}": unknown name "${r}"`)}let s=this._nodes.get(r);if(s&&o.length>0&&o[0]===B)return this._resolveMetaChainFromNode(s,o,n.join(G));let i=this._mounts.get(r);if(!i)throw this._nodes.has(r)?new Error(`Graph "${this.name}": "${r}" is a node; trailing path "${o.join(G)}" is invalid`):new Error(`Graph "${this.name}": unknown mount or node "${r}"`);return i.resolve(o.join(G))}_resolveMetaChainFromNode(e,n,r){let o=e,s=0,i=[...n];for(;s<i.length;){if(i[s]!==B)throw new Error(`Graph "${this.name}": expected ${B} segment in meta path "${r}"`);if(s+1>=i.length)throw new Error(`Graph "${this.name}": meta path requires a key after ${B} in "${r}"`);let a=i[s+1],c=o.meta[a];if(!c)throw new Error(`Graph "${this.name}": unknown meta "${a}" in path "${r}"`);o=c,s+=2}return o}signal(e,n){if(n?.internal!==!0){for(let o of e)if(this.config.messageTier(o[0])===3)throw new Error(`Graph "${this.name}": Graph.signal() rejects tier-3 messages (DATA / RESOLVED). Broadcast is for control-plane tiers (START / DIRTY / INVALIDATE / PAUSE / RESUME / COMPLETE / ERROR / TEARDOWN). For per-node value writes, use Graph.set or graph.node(name).down(...).`)}let r=[];if(this._signalDeliver(e,n??{},new Set,r),r.length>0)throw r[0]}_signalDeliver(e,n,r,o){for(let c of this._mounts.values())c._signalDeliver(e,n,r,o);let i=n.internal===!0?{internal:!0}:{actor:n.actor,delivery:"signal"},a=Ir(e,this.config);for(let c of[...this._nodes.keys()].sort()){let u=this._nodes.get(c);if(!r.has(u)){r.add(u);try{u.down(e,i)}catch(d){if(d instanceof W)throw d;o.push(d)}a.length!==0&&this._signalMetaSubtree(u,a,r,i,o)}}}_signalMetaSubtree(e,n,r,o,s){for(let i of Object.keys(e.meta).sort()){let a=e.meta[i];if(!r.has(a)){r.add(a);try{a.down(n,o)}catch(c){if(c instanceof W)throw c;s.push(c)}this._signalMetaSubtree(a,n,r,o,s)}}}describe(e){if(e?.reactive==="diff")return this._describeReactiveDiff(e);if(e?.reactive===!0)return this._describeReactive(e);let n=Er(e?.actor),r=e?.filter;if(e?.detail!=null&&e?.fields!=null)throw new TypeError("Graph.describe(): pass either `detail` or `fields`, not both. `detail: 'spec'` is the canonical spec projection; use `fields` only when you need a custom subset.");let o=Ot(e?.detail,e?.fields),s=e?.detail==="spec",i=o,a=[];this._collectObserveTargets("",a);let c=new Map;for(let[v,_]of a)c.set(_,v);let u=[];{let v=a.map(([,E])=>E),_=new Set(c.values()),k=0;for(;v.length>0;){let E=v.shift();if(E instanceof P)for(let O of E._deps){let N=O.node;if(c.has(N))continue;let S=N.name??"",w=S;if(!w||_.has(w))if(S){let I=2;for(;_.has(`${S}#${I}`);)I++;w=`${S}#${I}`}else for(w=`__internal__/${k++}`;_.has(w);)w=`__internal__/${k++}`;c.set(N,w),_.add(w),u.push([w,N]),v.push(N)}}}let d=[...a,...u],f={};for(let[v,_]of d){if(n!=null&&!_.allowsObserve(n))continue;let k=Tt(_,i,s),E=_ instanceof P?_._deps.map(w=>c.get(w.node)??w.node.name??""):[],{name:O,...N}=k,S={...N,deps:E};if(!s){let w=this._annotations.get(v);w!=null&&(S.annotation=w)}if(r!=null)if(typeof r=="function"){let w=r;if(!(w.length>=2?w(v,S):w(S)))continue}else{let w=!0;for(let[I,C]of Object.entries(r)){let D=I==="deps_includes"?"depsIncludes":I==="meta_has"?"metaHas":I;if(D==="depsIncludes"){if(!S.deps.includes(String(C))){w=!1;break}continue}if(D==="metaHas"){if(!Object.hasOwn(S.meta??{},String(C))){w=!1;break}continue}if(S[D]!==C){w=!1;break}}if(!w)continue}f[v]=S}let p=new Set(Object.keys(f)),h=[];for(let[v,_]of d)if(_ instanceof P)for(let k of _._deps){let E=c.get(k.node);E!=null&&h.push([E,v])}h.sort((v,_)=>v[0]<_[0]?-1:v[0]>_[0]?1:v[1]<_[1]?-1:v[1]>_[1]?1:0);let l=h.map(([v,_])=>({from:v,to:_}));(n!=null||r!=null)&&(l=l.filter(v=>p.has(v.from)&&p.has(v.to)));let b=this._collectSubgraphs(""),g=n!=null||r!=null?b.filter(v=>{let _=`${v}${G}`;return[...p].some(k=>k===v||k.startsWith(_))}):b,x=this,y=e;return{name:this.name,nodes:f,edges:l,subgraphs:g,...this._factory!==void 0?{factory:this._factory}:{},...this._factoryArgs!==void 0?{factoryArgs:this._factoryArgs}:{},expand(v){let _={...y};return Array.isArray(v)?(_.fields=v,_.detail=void 0):(_.detail=v,_.fields=void 0),x.describe(_)}}}_collectSubgraphs(e){let n=[];for(let r of[...this._mounts.keys()].sort()){let o=e===""?r:`${e}${r}`;n.push(o),n.push(...this._mounts.get(r)._collectSubgraphs(`${o}${G}`))}return n}resourceProfile(e){return Ke(this,e)}reachable(e,n,r={}){return r.withDetail===!0?Je(this.describe(),e,n,{...r,withDetail:!0}):Je(this.describe(),e,n,r)}explain(e,n,r){return r?.reactive===!0?this._explainReactive(e,n,r):this._explainStatic(ee(e),ee(n),{...r?.maxDepth!==void 0?{maxDepth:xn(r.maxDepth)}:{},...r?.findCycle!==void 0?{findCycle:wn(r.findCycle)}:{}})}_explainStatic(e,n,r){let o=this.describe({detail:"full"}),s=new Map(this._annotations),i=new Map;for(let[a,c]of Object.entries(o.nodes))c.lastMutation!=null&&i.set(a,c.lastMutation);return Ie(o,e,n,{...r?.maxDepth!=null?{maxDepth:r.maxDepth}:{},...r?.findCycle===!0?{findCycle:!0}:{},annotations:s,lastMutations:i})}_describeReactive(e){let n={...e,reactive:!1},r=e.reactiveName??"describe",o=0,s=we(o,{name:`${r}_version`}),i=this.observe({timeline:!0,structured:!0}),a=!1,c=!1,u=()=>{a||c||(a=!0,fe(()=>{a=!1,!c&&(o+=1,s.emit(o))}))},d=i.onEvent(y=>{let m=y.type;m!=="data"&&m!=="error"&&m!=="complete"&&m!=="teardown"||u()}),f=[],p=new WeakSet,h=y=>{if(p.has(y)||c)return;p.add(y);let m=y.topology.subscribe(v=>{for(let _ of v){if(_[0]!==F)continue;let k=_[1];if(u(),k.kind==="added"&&k.nodeKind==="mount"){let E=y._mounts.get(k.name);E!=null&&h(E)}}});f.push(m);for(let v of y._mounts.keys()){let _=y._mounts.get(v);_!=null&&h(_)}};h(this);let l,b=e.actor;kn(b)&&(l=b.subscribe(y=>{let m=!1,v=!1;for(let _ of y){let k=_[0];k===F?m=!0:(k===H||k===L||k===j)&&(v=!0)}m&&u(),v&&(l?.(),l=void 0,u())}));let g;try{g=Et([s],()=>this.describe(n),{name:r,describeKind:"derived",meta:{domain:"audit",kind:"describe"},equals:(y,m)=>y===m})}catch(y){d(),l?.();for(let m of f)m();throw i.dispose(),y}let x=Ue(g);return{node:g,dispose(){c=!0,d(),l?.();for(let y of f)y();f.length=0,i.dispose(),x()}}}_describeReactiveDiff(e){let n={...e,reactive:!1},r=e.reactiveName??"describe-diff",o={name:this.name,nodes:{},edges:[],subgraphs:[]},s=this.describe(n),i=St(o,s),a=we(i,{name:r,meta:{domain:"audit",kind:"describe-diff"},equals:(p,h)=>p===h}),c=this._describeReactive({...e,reactiveName:void 0}),u=!1,d=c.node.subscribe(p=>{if(!u)for(let h of p){if(h[0]!==F)continue;let l=h[1],b=St(s,l);s=l,b.events.length!==0&&a.emit(b)}}),f=Ue(a);return{node:a,dispose(){u=!0,d(),c.dispose(),a.down([[j,"describe-diff disposed"]]),f()}}}_explainReactive(e,n,r){let o=0,s=we(o,{name:"explain_version"}),i=this.observe({timeline:!0,structured:!0}),a=!1,c=!1,u=()=>{a||c||(a=!0,fe(()=>{a=!1,!c&&(o+=1,s.emit(o))}))},d=i.onEvent(y=>{let m=y.type;m!=="data"&&m!=="error"&&m!=="complete"&&m!=="teardown"||u()}),f=[];e!=null&&ae(e)&&f.push(e),n!=null&&ae(n)&&f.push(n),r?.maxDepth!=null&&ae(r.maxDepth)&&f.push(r.maxDepth),r?.findCycle!=null&&ae(r.findCycle)&&f.push(r.findCycle);let p=()=>{for(let y of f)if(y.cache===void 0)return!1;return!0},h=()=>{let y=ee(e),m=ee(n);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=Et([s],()=>{if(!p())return h();let y=ee(e),m=ee(n),v={...r?.maxDepth!==void 0?{maxDepth:xn(r.maxDepth)}:{},...r?.findCycle!==void 0?{findCycle:wn(r.findCycle)}:{}};return this._explainStatic(y,m,v)},{name:r?.name??"explain",describeKind:"derived",meta:{domain:"audit",kind:"explain_path",from:ee(e),to:ee(n)},equals:(y,m)=>y.found===m.found&&y.reason===m.reason&&y.steps.length===m.steps.length&&$r(y.steps,m.steps)})}catch(y){throw d(),i.dispose(),y}let b=Ue(l),g=[],x=y=>{let m;return m=y.subscribe(v=>{let _=!1,k=!1;for(let E of v){let O=E[0];O===F?_=!0:(O===H||O===L||O===j)&&(k=!0)}(_||k)&&u(),k&&m&&(m(),m=void 0)}),()=>{m&&(m(),m=void 0)}};for(let y of f)g.push(x(y));return{node:l,dispose(){c=!0,d();for(let y of g)y?.();g.length=0,i.dispose(),b()}}}_pathsMatching(e){let n=qe(e),r=[];return this._collectObserveTargets("",r),r.map(([o])=>o).filter(o=>n.test(o))}_collectObserveTargets(e,n){for(let r of[...this._mounts.keys()].sort()){let o=e===""?r:`${e}${G}${r}`;this._mounts.get(r)._collectObserveTargets(o,n)}for(let r of[...this._nodes.keys()].sort()){let o=this._nodes.get(r),s=e===""?r:`${e}${G}${r}`;n.push([s,o]),this._appendMetaObserveTargets(s,o,n)}}_appendMetaObserveTargets(e,n,r){for(let o of Object.keys(n.meta).sort()){let s=n.meta[o],i=`${e}${G}${B}${G}${o}`;r.push([i,s]),this._appendMetaObserveTargets(i,s,r)}}observe(e,n){let r=typeof e=="string",s=Tn(r?n:e);if(s.reactive===!0)return this._observeReactive(r?e:void 0,s);let i=s.structured===!0||s.timeline===!0||s.causal===!0||s.derived===!0||s.detail==="minimal"||s.detail==="full"||s.format!=null,a=s.actor;if(r){let d=e,f=this.resolve(d);if(a!=null&&!f.allowsObserve(a))throw new W({actor:a,action:"observe",nodeName:d});return i?this._buildStructuredObserver([[d,f]],s,"one"):{subscribe(p){return f.subscribe(p)},up(p){try{f.up?.(p)}catch(h){if(h instanceof W)return;throw h}}}}let c=[];this._collectObserveTargets("",c),c.sort((d,f)=>d[0]<f[0]?-1:d[0]>f[0]?1:0);let u=a==null?c:c.filter(([,d])=>d.allowsObserve(a));return i?this._buildStructuredObserver(u,s,"all"):{subscribe:d=>{let f=u.map(([p,h])=>h.subscribe(l=>{d(p,l)}));return()=>{for(let p of f)p()}},up:(d,f)=>{try{this.resolve(d).up?.(f)}catch(p){if(p instanceof W)return;throw p}}}}_observeReactive(e,n){let r=n.tiers,o=r!=null?new Set(r):null,s=n.reactiveName??"observe";return kt(i=>{let a=[],c=!1,u=!1,d=()=>{if(a.length===0||u)return;let b={events:a.slice(),flushedAt_ns:Z()};a.length=0,i.emit(b)},f={...n,reactive:!1,structured:!0,timeline:!0},p=e!=null?this.observe(e,f):this.observe(f),h=b=>{u||(a.push(b),!c&&(c=!0,fe(()=>{c=!1,d()})))};for(let b of p.events)h(b);let l=p.onEvent(h);return()=>{u=!0,l(),p.dispose()}},{name:s,meta:{domain:"audit",kind:"observe-reactive"}})}_buildStructuredObserver(e,n,r){let o=r==="one"?e[0]?.[0]:void 0,s=i=>{if(r==="one"&&o!=null){let d=this.resolve(o);return this._buildStructuredObserver([[o,d]],i,"one")}let a=[];this._collectObserveTargets("",a),a.sort((d,f)=>d[0]<f[0]?-1:d[0]>f[0]?1:0);let c=i.actor,u=c==null?a:a.filter(([,d])=>d.allowsObserve(c));return this._buildStructuredObserver(u,i,"all")};return this._createObserveResult(e,n,s)}_createObserveResult(e,n,r){let o=n.timeline===!0,s=n.causal===!0,i=n.derived===!0,a=n.detail==="minimal",c=this.config.inspectorEnabled,u=(s||i)&&c,d=n.maxEvents,f=d!=null&&d>0?new Oe(d):null,p=[],h=new Set,l=n.tiers!=null?new Set(n.tiers):null,b={},g=new Set,x=0,y=0,m=0,v=0,_=0,k=0,E=!1,O=!1,N=0,S=new Map,w=new Map,I=new Map,C=T=>{if(!(l!=null&&!l.has(T.type))){f?f.push(T):p.push(T);for(let M of h)M(T)}},D=T=>l==null||l.has(T),X=()=>o?{timestamp_ns:Z(),in_batch:Le(),batch_id:N}:{},ue=(T,M)=>{if(!(!u||!(T instanceof P)))return T._setInspectorHook(z=>{if(z.kind==="dep_message")S.set(T,z.depIndex);else if(z.kind==="run"){let ge=z.batchData.map((A,V)=>A!=null&&A.length>0?A.at(-1):z.prevData[V]);w.set(T,ge);let U=z.batchData.map(A=>A!=null?[...A]:void 0);I.set(T,U),i&&C({type:"derived",path:M,dep_values:ge,dep_batches:U,...X()})}})},oe=T=>{let M=S.get(T),z=w.get(T);if(!s||z==null)return{};let U=(M!=null&&M>=0&&T instanceof P?T._deps[M]:void 0)?.node,A=U?.v,V=I.get(T);return{trigger_dep_index:M,trigger_dep_name:U?.name,...A!=null?{trigger_version:{id:A.id,version:A.version}}:{},dep_values:[...z],...V!=null?{dep_batches:V}:{}}},Ht=[],Bt=[];for(let[T,M]of e){let z=ue(M,T);z&&Ht.push(z),Bt.push(M.subscribe(ge=>{N++;for(let U of ge){let A=U[0],V=X();if(A===F){b[T]=U[1];let st=M instanceof P?M.lastMutation?.actor??ce:ce;C({type:"data",path:T,data:U[1],actor:st,...V,...oe(M)})}else if(a)A===q?D("dirty")&&x++:A===J?D("resolved")&&y++:A===K?D("invalidate")&&m++:A===Y?D("pause")&&v++:A===Q?D("resume")&&_++:A===j?D("teardown")&&k++:A===H&&!g.has(T)?D("complete")&&(E=!0):A===L&&D("error")&&(O=!0,g.add(T));else if(A===q)D("dirty")&&x++,C({type:"dirty",path:T,...V});else if(A===J)D("resolved")&&y++,C({type:"resolved",path:T,...V,...oe(M)});else if(A===K)D("invalidate")&&m++,C({type:"invalidate",path:T,...V});else if(A===Y)D("pause")&&v++,C({type:"pause",path:T,lockId:U[1],...V});else if(A===Q)D("resume")&&_++,C({type:"resume",path:T,lockId:U[1],...V});else if(A===H)D("complete")&&!g.has(T)&&(E=!0),C({type:"complete",path:T,...V});else if(A===L){D("error")&&(O=!0,g.add(T));let st=M instanceof P?M.lastMutation?.actor??ce:ce;C({type:"error",path:T,data:U[1],actor:st,...V})}else A===j&&(D("teardown")&&k++,C({type:"teardown",path:T,...V}))}}))}let nt=!1,rt=()=>{if(!nt){nt=!0;for(let T of Bt)T();for(let T of Ht)T();for(let T of Ee)T({value:void 0,done:!0});Ee.length=0}},ot=[],Ee=[];h.add(T=>{let M=Ee.shift();M?M({value:T,done:!1}):ot.push(T)});let zt={get values(){return b},get dirtyCount(){return x},get resolvedCount(){return y},get invalidateCount(){return m},get pauseCount(){return v},get resumeCount(){return _},get teardownCount(){return k},get events(){return f?f.toArray():[...p]},get anyCompletedCleanly(){return E},get anyErrored(){return O},get completedWithoutErrors(){return E&&!O},onEvent(T){return h.add(T),()=>h.delete(T)},dispose:rt,expand(T){rt();let M={...n};return typeof T=="string"?M.detail=T:Object.assign(M,T),r(Tn(M))},[Symbol.asyncIterator](){return{next(){return ot.length>0?Promise.resolve({value:ot.shift(),done:!1}):nt?Promise.resolve({value:void 0,done:!0}):new Promise(T=>Ee.push(T))},return(){return rt(),Promise.resolve({value:void 0,done:!0})}}}};return n.format!=null&&this._attachFormatLogger(zt,n),zt}_attachFormatLogger(e,n){let r=n.format;if(r==null)return;let o=n.logger??(l=>console.log(l)),s=n.includeTypes?new Set(n.includeTypes):null,i=n.excludeTypes?new Set(n.excludeTypes):null,a=s==null&&i==null?()=>!0:l=>(s==null||s.has(l))&&(i==null||!i.has(l)),c=Cr(n.theme),u=r==="stage-log"?Z():0,d=l=>l==null?"":n.stageLabels?.[l]??l,f=(l,b)=>l.length>b?`${l.slice(0,b-1)}\u2026`:l,p=l=>l.type==="data"||l.type==="error"?f(Dt(l.data),120):"",h=l=>{if(r==="stage-log"){let E=(Z()-u)/1e9,O=d(l.path).padEnd(9);if(l.type==="data"){let N=p(l);return`[${E.toFixed(3)}s] ${O} \u2190${N?` ${N}`:""}`}if(l.type==="error"){let N=p(l);return`[${E.toFixed(3)}s] ${O} \u2717${N?` ${N}`:""}`}return l.type==="complete"?`[${E.toFixed(3)}s] ${O} \u25A0 complete`:`[${E.toFixed(3)}s] ${O} ${l.type}`}if(r==="json")try{return JSON.stringify(l)}catch{return JSON.stringify({type:l.type,path:l.path,data:"[unserializable]"})}let b=c[l.type]??"",g=l.path?`${c.path}${l.path}${c.reset} `:"",x=l.type==="data"||l.type==="error",y=l.type==="pause"||l.type==="resume",m=x?` ${Dt(l.data)}`:y?` ${Dt(l.lockId)}`:"",v=l.type==="data"||l.type==="resolved"||l.type==="derived"?l:void 0,_=v?.trigger_dep_name!=null?` <- ${v.trigger_dep_name}`:v?.trigger_dep_index!=null?` <- #${v.trigger_dep_index}`:"",k=l.in_batch?" [batch]":"";return`${g}${b}${l.type.toUpperCase()}${c.reset}${m}${_}${k}`};e.onEvent(l=>{a(l.type)&&o(h(l),l)})}addDisposer(e){return this._disposers.add(e),()=>{this._disposers.delete(e)}}destroy(){_n(this._disposers,this.name),this.signal([[j]],{internal:!0}),_n(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:n,...r}=this.describe({detail:"full"}),o={};for(let a of Object.keys(r.nodes).sort()){let{lastMutation:c,guard:u,...d}=r.nodes[a];o[a]=d}let s=[...r.subgraphs].sort(),i={...r,version:1,nodes:o,subgraphs:s};if(e?.format==null)return i;if(e.format==="json-string")return JSON.stringify(i);if(e.format==="bytes"){if(e.codec==null)throw new Error("snapshot({format: 'bytes'}) requires a `codec` name");let a=this.config.lookupCodec(e.codec);if(a==null)throw new Error(`snapshot: codec "${e.codec}" is not registered on this graph's config. Call config.registerCodec(...) before creating nodes.`);return Se(a,a.encode(i))}throw new Error(`snapshot: unknown format "${String(e.format)}"`)}static decode(e,n){let r=n?.config??he,{codec:o,codecVersion:s,payload:i}=Re(e,r);return o.decode(i,s)}restore(e,n){if(On(e),e.name!==this.name)throw new Error(`Graph "${this.name}": restore snapshot name "${e.name}" does not match this graph`);let r=n?.only==null?null:(Array.isArray(n.only)?n.only:[n.only]).map(s=>qe(s)),o=n?.includeProducers===!0;for(let s of Object.keys(e.nodes).sort()){if(r!==null&&!r.some(a=>a.test(s)))continue;let i=e.nodes[s];if(i!==void 0){if(!("value"in i)||i.value===void 0){"value"in i&&i.value===void 0&&n?.onError?.(s,new Error(`restore: slice.value is undefined for "${s}" (undefined is the global SENTINEL; not valid DATA)`));continue}if(!(i.type==="derived"||i.type==="effect")&&!(i.type==="producer"&&!o)){if(i.v!=null){let c=this.tryResolve(s)?.v;if(c!=null&&c.id===i.v.id&&c.version===i.v.version)continue}try{this.set(s,i.value)}catch(a){n?.onError?.(s,a)}}}}}static fromSnapshot(e,n){On(e);let r=typeof n=="function"?n:n?.build,o=typeof n=="function"?void 0:n?.factories,s=new t(e.name);if(r)return r(s),s.restore(e),s;for(let h of[...e.subgraphs].sort((l,b)=>{let g=l.split(G).length,x=b.split(G).length;return g!==x?g-x:l<b?-1:l>b?1:0})){let l=h.split(G),b=s;for(let g of l)b._mounts.has(g)||b.mount(g,new t(g)),b=b._mounts.get(g)}let i=o?Object.entries(o).map(([h,l])=>({re:qe(h),factory:l})):[],a=h=>{for(let l of i)if(l.re.test(h))return l.factory},c=h=>{let l=h.split(G),b=l.pop();if(b==null||b.length===0)throw new Error(`invalid snapshot path "${h}"`);let g=s;for(let x of l){let y=g._mounts.get(x);if(!y)throw new Error(`unknown mount "${x}" in path "${h}"`);g=y}return[g,b]},u=Object.entries(e.nodes).filter(([h])=>!h.includes(`${G}${B}${G}`)).sort((h,l)=>h[0]<l[0]?-1:h[0]>l[0]?1:0),d=new Map(u),f=new Map,p=!0;for(;d.size>0&&p;){p=!1;for(let[h,l]of[...d.entries()]){let b=l?.deps??[];if(!b.every(_=>f.has(_)))continue;let[g,x]=c(h),y={...l?.meta??{}},m=a(h),v;if(l?.type==="state")v=we(l.value,{meta:y});else{if(m==null)continue;v=m(x,{path:h,type:l.type,value:l.value,meta:y,deps:b,resolvedDeps:b.map(_=>f.get(_))})}g.add(v,{name:x}),f.set(h,v),d.delete(h),p=!0}}if(d.size>0){let h=[...d.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 s.restore(e),s}toJSON(){return this.snapshot()}attachSnapshotStorage(e,n={}){let r=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}));n.autoRestore===!0&&this._cascadeRestore(e,n.onError);let o=(u,d)=>{if(u.disposed)return;let f=Nr(d.nodes);if(u.lastSnapshot!=null&&f!==""&&f===u.lastFingerprint)return;let p=u.seq+1,h=Fe(),g=u.lastSnapshot==null||p%u.compactEvery===0?{name:this.name,mode:"full",snapshot:d,seq:p,timestamp_ns:h,format_version:te}:{name:this.name,mode:"diff",diff:Ct(u.lastSnapshot,d),seq:p,timestamp_ns:h,format_version:te};if(u.tier.filter&&!u.tier.filter(g))return;let x;try{x=u.tier.save(g)}catch(y){n.onError?.(y,u.tier);return}if(x&&typeof x.then=="function"){let v=(u.savePending??Promise.resolve()).then(()=>x,()=>x).then(()=>{u.disposed||(u.seq=p,u.lastSnapshot=d,u.lastFingerprint=f)},_=>{n.onError?.(_,u.tier)});u.savePending=v.finally(()=>{u.savePending===v&&(u.savePending=void 0)})}else u.seq=p,u.lastSnapshot=d,u.lastFingerprint=f},s=(u,d)=>{try{o(u,d)}catch(f){n.onError?.(f,u.tier)}},i=(u,d)=>{if(!d.some(l=>{let b=this.config.messageTier(l[0]);return b>=3&&b<5}))return;if(n.filter){let l=this.tryResolve(u);if(l==null)return;let b=Tt(l,Ot("standard"));if(!n.filter(u,b))return}let p,h=()=>(p==null&&(p=this.snapshot()),p);for(let l of r)l.disposed||(l.debounceMs===0?s(l,h()):(l.timer==null&&(l.timer=new We),l.timer.start(l.debounceMs,()=>{l.disposed||s(l,this.snapshot())})))},a;if(n.paths!=null){let d=(typeof n.paths=="string"?this._pathsMatching(n.paths):n.paths).map(f=>{let p=this.tryResolve(f);return p==null?()=>{}:p.subscribe(h=>i(f,h))});a=()=>{for(let f of d)f()}}else a=this.observe().subscribe((u,d)=>i(u,d));let c=()=>{a();for(let u of r)u.disposed=!0,u.timer?.cancel();this._storageDisposers.delete(c)};return this._storageDisposers.add(c),{dispose:c}}async _cascadeRestore(e,n){for(let r of e){let o;try{o=await r.load?.()}catch(i){n?.(i,r);continue}if(o==null||typeof o!="object"||Array.isArray(o))continue;let s=o;try{if(s.mode==="full"&&s.snapshot!=null)return this.restore(s.snapshot),!0;if(s.version===te&&s.nodes!=null)return this.restore(s),!0}catch(i){n?.(i,r)}}return!1}static async fromStorage(e,n,r){for(let o of n){let s;try{s=await o.load?.()}catch(c){r?.onError?.(c,o);continue}if(s==null||typeof s!="object"||Array.isArray(s))continue;let i=s,a=i.mode==="full"&&i.snapshot!=null?i.snapshot:i.version===te&&i.nodes!=null?i:void 0;if(a!=null)try{return t.fromSnapshot(a,r)}catch(c){r?.onError?.(c,o)}}throw new Error(`Graph.fromStorage: no tier held a restorable record for "${e}" across ${n.length} tier(s)`)}_annotations=new Map;_traceRing;trace(e,n,r){if(e!=null&&n!=null){if(this.tryResolve(e)==null)return;if(this._annotations.set(e,n),this.config.inspectorEnabled){let o={path:e,annotation:n,timestamp_ns:Z(),...r?.actor!=null?{actor:r.actor}:{}};this._traceRing.push(o)}return}return e!=null?this.config.inspectorEnabled?this._annotations.get(e):void 0:this.config.inspectorEnabled?this._traceRing.toArray():[]}annotation(e){return this._annotations.get(e)}clearTrace(){this._annotations.clear(),this._traceRing.clear()}pruneTrace(e){let n=this._traceRing.toArray().filter(o=>!e(o)),r=this._traceRing.size-n.length;this._traceRing.clear();for(let o of n)this._traceRing.push(o);return r}static diff(e,n){let r=new Set(Object.keys(e.nodes)),o=new Set(Object.keys(n.nodes)),s=[...o].filter(y=>!r.has(y)).sort(),i=[...r].filter(y=>!o.has(y)).sort(),a=[],c=[];for(let y of r){if(!o.has(y))continue;let m=e.nodes[y],v=n.nodes[y],_=m.v,k=v.v;_!=null&&k!=null&&_.id===k.id&&_.version!==k.version&&c.push({path:y,id:_.id,from:_.version,to:k.version});let E=_!=null&&k!=null&&_.id===k.id&&_.version===k.version;for(let O of["type","status","sentinel"]){let N=m[O],S=v[O];N!==S&&a.push({path:y,field:O,from:N,to:S})}if(!E)for(let O of["value","meta"]){let N=m[O],S=v[O];Sr(N,S)||a.push({path:y,field:O,from:N,to:S})}}let u=y=>`${y.from} ${y.to}`,d=new Set(e.edges.map(u)),f=new Set(n.edges.map(u)),p=n.edges.filter(y=>!d.has(u(y))),h=e.edges.filter(y=>!f.has(u(y))),l=new Set(e.subgraphs),b=new Set(n.subgraphs),g=[...b].filter(y=>!l.has(y)).sort(),x=[...l].filter(y=>!b.has(y)).sort();return{nodesAdded:s,nodesRemoved:i,nodesChanged:a,versionChanges:c,edgesAdded:p,edgesRemoved:h,subgraphsAdded:g,subgraphsRemoved:x}}}});function Nn(t,e){let n=new Map,r=(o,s)=>{if(n.has(o))return;let i={off:()=>{},prefix:s};n.set(o,i);let a=o.topology.subscribe(c=>{for(let u of c){if(u[0]!==F)continue;let d=u[1];if(e(d,o,s),d.kind==="added"&&d.nodeKind==="mount"){let f=o._mounts.get(d.name);if(f instanceof ne){let p=`${s}${d.name}::`;r(f,p)}}else if(d.kind==="removed"&&d.nodeKind==="mount"){let f=`${s}${d.name}::`;for(let[p,h]of Array.from(n.entries()))p!==t&&h.prefix.startsWith(f)&&(h.off(),n.delete(p))}}});i.off=a;for(let[c,u]of o._mounts)if(u instanceof ne){let d=`${s}${c}::`;r(u,d)}};return r(t,""),()=>{for(let o of n.values())o.off();n.clear()}}var Sn=R(()=>{"use strict";_e();Mt()});function Rn(t){let e=t.describe({detail:"minimal"}),n=Object.keys(e.nodes),r=new Set;for(let s of n){let i=e.nodes[s];if(!i)continue;let a=i.deps??[];for(let c of a)r.add(c)}let o=[];for(let s of n){let i=e.nodes[s];if(!i||s.startsWith("__internal__/"))continue;let c=(i.deps??[]).length,u=r.has(s);if(c===0&&!u){let d=i.type??"unknown";o.push({path:s,kind:d})}}return o.sort((s,i)=>s.path<i.path?-1:s.path>i.path?1:0),{ok:o.length===0,orphans:o,summary(){if(o.length===0)return"validateNoIslands: ok (no islands)";let s=o.slice(0,3).map(i=>`${i.path} (${i.kind})`).join(", ");return`validateNoIslands: ${o.length} island node(s) \u2014 ${s}${o.length>3?", \u2026":""}`}}}var Dn=R(()=>{"use strict"});function Gt(t){return t>=768&&t<=879||t>=1155&&t<=1161||t>=1425&&t<=1469||t>=1552&&t<=1562||t>=1611&&t<=1631||t>=1648&&t===1648||t>=1750&&t<=1756||t>=1759&&t<=1764||t>=1767&&t<=1768||t>=1770&&t<=1773||t>=1840&&t<=1866||t>=1958&&t<=1968||t>=2304&&t<=2307||t>=2362&&t<=2383||t>=2385&&t<=2391||t>=2402&&t<=2403||t>=2433&&t<=2435||t>=2492&&t<=2509||t>=2561&&t<=2563||t>=2620&&t<=2641||t>=2672&&t<=2673||t>=2677&&t===2677||t>=3633&&t===3633||t>=3636&&t<=3642||t>=3655&&t<=3662||t>=3761&&t===3761||t>=3764&&t<=3772||t>=3784&&t<=3790||t>=7616&&t<=7679||t>=8400&&t<=8447||t>=65024&&t<=65039||t>=65056&&t<=65071||t===8205?0:t>=4352&&t<=4447||t>=8986&&t<=8987||t>=9001&&t<=9002||t>=9193&&t<=9203||t>=9208&&t<=9210||t>=9725&&t<=9726||t>=9748&&t<=9749||t>=9800&&t<=9811||t===9855||t===9875||t===9889||t>=9898&&t<=9899||t>=9917&&t<=9918||t>=9924&&t<=9925||t===9934||t===9940||t===9962||t>=9970&&t<=9971||t===9973||t===9978||t===9981||t===9986||t===9989||t>=9992&&t<=9997||t===9999||t>=10067&&t<=10069||t===10071||t>=10133&&t<=10135||t===10160||t===10175||t>=10548&&t<=10549||t>=11013&&t<=11015||t>=11035&&t<=11036||t===11088||t===11093||t>=11904&&t<=12350||t>=12352&&t<=12447||t>=12448&&t<=12543||t>=12549&&t<=12591||t>=12593&&t<=12686||t>=12688&&t<=12771||t>=12784&&t<=12830||t>=12832&&t<=12871||t>=12880&&t<=19903||t>=19968&&t<=40959||t>=43360&&t<=43388||t>=44032&&t<=55203||t>=63744&&t<=64255||t>=65040&&t<=65049||t>=65072&&t<=65131||t>=65281&&t<=65376||t>=65504&&t<=65510||t>=126980&&t===126980||t===127183||t>=127344&&t<=127345||t===127358||t===127359||t===127374||t>=127377&&t<=127386||t>=127456&&t<=127487||t>=127488&&t<=127490||t===127514||t===127535||t>=127538&&t<=127546||t>=127568&&t<=127569||t>=127744&&t<=129535||t>=129536&&t<=129791||t>=129792&&t<=130047||t>=131072&&t<=196605||t>=196608&&t<=262141?2:1}function Ye(t){let e=0;for(let n of t)e+=Gt(n.codePointAt(0));return e}function An(t,e){if(e<=0)return"";let n=0,r="";for(let o of t){let s=Gt(o.codePointAt(0));if(n+s>e){if(e<=1)return"\u2026";for(;n+1>e&&r.length>0;){let i=[...r].pop();r=r.slice(0,-i.length),n-=Gt(i.codePointAt(0))}return`${r}\u2026`}r+=o,n+=s}return r}var It=R(()=>{"use strict"});function In(t,e){let n=e.charset==="ascii"?Pr:Lr,r=t.width,o=t.height,s=Array.from({length:o},()=>Array.from({length:r},()=>" ")),i=Array.from({length:o},()=>Array.from({length:r},()=>"empty"));for(let a of t.edges)jr(s,i,n,a);for(let a of t.boxes)Fr(s,i,n,a,e.labelOf(a.id));return s.map(a=>zr(a.join(""))).join(`
|
|
4
|
+
`)}function Fr(t,e,n,r,o){let{x:s,y:i,w:a,h:c}=r;if(a<2||c<2){c>0&&Cn(t,e,s,i,a,o);return}re(t,e,s,i,n.boxTL);for(let d=s+1;d<s+a-1;d+=1)re(t,e,d,i,n.boxH);re(t,e,s+a-1,i,n.boxTR);for(let d=i+1;d<i+c-1;d+=1){re(t,e,s,d,n.boxV);for(let f=s+1;f<s+a-1;f+=1)$n(t,e,f,d," ","empty");re(t,e,s+a-1,d,n.boxV)}re(t,e,s,i+c-1,n.boxBL);for(let d=s+1;d<s+a-1;d+=1)re(t,e,d,i+c-1,n.boxH);re(t,e,s+a-1,i+c-1,n.boxBR);let u=i+Math.floor(c/2);Cn(t,e,s+1,u,a-2,o)}function re(t,e,n,r,o){$n(t,e,n,r,o,o===" "?"empty":o==="\u2500"||o==="-"?"boxH":o==="\u2502"||o==="|"?"boxV":"boxCorner")}function $n(t,e,n,r,o,s){if(r<0||r>=t.length)return;let i=t[r];n<0||n>=i.length||(i[n]=o,e[r][n]=s)}function Cn(t,e,n,r,o,s){if(r<0||r>=t.length)return;let i=n,a=o;for(let c of s){let u=Ye(c);if(u!==0){if(a<u)break;i>=0&&i<t[r].length&&(t[r][i]=c,e[r][i]="label",u===2&&i+1<t[r].length&&(t[r][i+1]="",e[r][i+1]="label")),i+=u,a-=u}}for(;a>0;)i>=0&&i<t[r].length&&(t[r][i]=" ",e[r][i]="empty"),i+=1,a-=1}function jr(t,e,n,r){let o=r.points;if(o.length<2)return;for(let c=0;c+1<o.length;c+=1)Vr(t,e,n,o[c],o[c+1]);for(let c=1;c+1<o.length;c+=1){let u=o[c-1],d=o[c],f=o[c+1],p=Hr(u,d,f,n);p&&Gn(t,e,d.x,d.y,p,"edgeCorner")}let s=o[o.length-1],i=o[o.length-2],a=Br(i,s,n);a&&Gn(t,e,s.x,s.y,a,"arrow")}function Vr(t,e,n,r,o){if(!(r.x===o.x&&r.y===o.y)){if(r.y===o.y){let s=r.y,i=Math.min(r.x,o.x),a=Math.max(r.x,o.x);for(let c=i;c<=a;c+=1)Mn(t,e,c,s,n,"h")}else if(r.x===o.x){let s=r.x,i=Math.min(r.y,o.y),a=Math.max(r.y,o.y);for(let c=i;c<=a;c+=1)Mn(t,e,s,c,n,"v")}}}function Mn(t,e,n,r,o,s){if(r<0||r>=t.length)return;let i=t[r];if(n<0||n>=i.length)return;let a=e[r][n];if(!(a==="boxH"||a==="boxV"||a==="boxCorner"||a==="label")){if(a==="empty"){i[n]=s==="h"?o.horizontal:o.vertical,e[r][n]=s==="h"?"edgeH":"edgeV";return}if(a==="edgeH"&&s==="v"){i[n]=o.cross,e[r][n]="edgeCorner";return}if(a==="edgeV"&&s==="h"){i[n]=o.cross,e[r][n]="edgeCorner";return}}}function Gn(t,e,n,r,o,s){if(r<0||r>=t.length)return;let i=t[r];if(n<0||n>=i.length)return;let a=e[r][n];a==="boxH"||a==="boxV"||a==="boxCorner"||a==="label"||(i[n]=o,e[r][n]=s)}function Hr(t,e,n,r){let o=t.y===e.y,s=e.y===n.y;if(o===s)return;if(o){let c=t.x<e.x,u=n.y>e.y;return c&&u?r.cornerTR:c&&!u?r.cornerBR:!c&&u?r.cornerTL:r.cornerBL}let i=t.y<e.y,a=n.x>e.x;return i&&a?r.cornerBL:i&&!a?r.cornerBR:!i&&a?r.cornerTL:r.cornerTR}function Br(t,e,n){if(e.x>t.x)return n.arrowRight;if(e.x<t.x)return n.arrowLeft;if(e.y>t.y)return n.arrowDown;if(e.y<t.y)return n.arrowUp}function zr(t){let e=t.length;for(;e>0&&t.charCodeAt(e-1)===32;)e-=1;return t.slice(0,e)}var Lr,Pr,Ln=R(()=>{"use strict";It();Lr={horizontal:"\u2500",vertical:"\u2502",cornerTL:"\u250C",cornerTR:"\u2510",cornerBL:"\u2514",cornerBR:"\u2518",tDown:"\u252C",tUp:"\u2534",tRight:"\u251C",tLeft:"\u2524",cross:"\u253C",arrowRight:"\u25B6",arrowDown:"\u25BC",arrowLeft:"\u25C0",arrowUp:"\u25B2",boxTL:"\u250C",boxTR:"\u2510",boxBL:"\u2514",boxBR:"\u2518",boxH:"\u2500",boxV:"\u2502"},Pr={horizontal:"-",vertical:"|",cornerTL:"+",cornerTR:"+",cornerBL:"+",cornerBR:"+",tDown:"+",tUp:"+",tRight:"+",tLeft:"+",cross:"+",arrowRight:">",arrowDown:"v",arrowLeft:"<",arrowUp:"^",boxTL:"+",boxTR:"+",boxBL:"+",boxBR:"+",boxH:"-",boxV:"|"}});function jn(t){let e=Ur(t);Wr(e),Kr(e),qr(e),Jr(e,t);let n=Zr(e,t),{width:r,height:o}=eo(e),s=[];for(let i of e.layers)for(let a of i)a.isVirtual||s.push({id:a.id,layer:a.layer,order:a.order,x:a.x,y:a.y,w:a.w,h:a.h});return{boxes:s,edges:n,width:r,height:o}}function Ur(t){let e=new Map;for(let o of t.nodes)e.set(o,{id:o,isVirtual:!1,layer:-1,order:0,x:0,y:0,w:t.widthCells(o),h:t.heightCells(o),in:[],out:[]});let n=[],r=0;for(let o of t.edges){if(o.from===o.to)continue;let s=e.get(o.from),i=e.get(o.to);if(!s||!i)continue;let a={chainId:r++,chainFrom:o.from,chainTo:o.to,fromId:o.from,toId:o.to,hopIndex:0,chainLen:1};s.out.push(a),i.in.push(a),n.push(a)}return{nodes:e,layers:[],hops:n}}function Wr(t){let e=new Map;for(let s of t.nodes.values())e.set(s.id,s.in.length);let n=[];for(let s of t.nodes.values())(e.get(s.id)??0)===0&&(s.layer=0,n.push(s));let r=new Set,o=0;for(;o<n.length;){let s=n[o++];if(!r.has(s.id)){r.add(s.id);for(let i of s.out){let a=t.nodes.get(i.toId);a.layer=Math.max(a.layer,s.layer+1);let c=(e.get(a.id)??0)-1;e.set(a.id,c),c<=0&&n.push(a)}}}for(let s of t.nodes.values())s.layer<0&&(s.layer=0)}function Kr(t){let e=Math.max(0,...Array.from(t.nodes.values(),s=>s.layer)),n=Array.from({length:e+1},()=>[]);for(let s of t.nodes.values())n[s.layer].push(s);let r=[],o=0;for(let s of t.hops){let i=t.nodes.get(s.fromId),a=t.nodes.get(s.toId),c=a.layer-i.layer;if(c<=0){i.out=i.out.filter(f=>f!==s),a.in=a.in.filter(f=>f!==s);continue}if(c===1){s.hopIndex=0,s.chainLen=1,r.push(s);continue}i.out=i.out.filter(f=>f!==s),a.in=a.in.filter(f=>f!==s);let u=i;for(let f=1;f<c;f+=1){let p=`__virt_${o++}__`,h={id:p,isVirtual:!0,layer:i.layer+f,order:0,x:0,y:0,w:0,h:1,in:[],out:[]};t.nodes.set(p,h),n[h.layer].push(h);let l={chainId:s.chainId,chainFrom:s.chainFrom,chainTo:s.chainTo,fromId:u.id,toId:p,hopIndex:f-1,chainLen:c};u.out.push(l),h.in.push(l),r.push(l),u=h}let d={chainId:s.chainId,chainFrom:s.chainFrom,chainTo:s.chainTo,fromId:u.id,toId:a.id,hopIndex:c-1,chainLen:c};u.out.push(d),a.in.push(d),r.push(d)}for(let s of n)for(let i=0;i<s.length;i+=1)s[i].order=i;t.layers=n,t.hops=r}function qr(t){for(let n=0;n<4;n+=1){for(let r=1;r<t.layers.length;r+=1)Pn(t,t.layers[r],"in"),Xe(t.layers[r]);for(let r=t.layers.length-2;r>=0;r-=1)Pn(t,t.layers[r],"out"),Xe(t.layers[r])}for(let n=0;n<2;n+=1){let r=!1;for(let o=1;o<t.layers.length;o+=1){let s=t.layers[o];for(let i=0;i+1<s.length;i+=1){let a=Fn(t,s[i],s[i+1],"in");[s[i],s[i+1]]=[s[i+1],s[i]],Xe(s),Fn(t,s[i],s[i+1],"in")<a?r=!0:([s[i],s[i+1]]=[s[i+1],s[i]],Xe(s))}}if(!r)break}}function Pn(t,e,n){let r=new Map;for(let o of e){let s=n==="in"?o.in:o.out;if(s.length===0){r.set(o.id,o.order);continue}let i=0,a=0;for(let c of s){let u=t.nodes.get(n==="in"?c.fromId:c.toId);u&&(i+=u.order,a+=1)}r.set(o.id,a===0?o.order:i/a)}e.sort((o,s)=>{let i=r.get(o.id),a=r.get(s.id);return i!==a?i-a:o.order-s.order})}function Xe(t){for(let e=0;e<t.length;e+=1)t[e].order=e}function Fn(t,e,n,r){let o=r==="in"?e.in:e.out,s=r==="in"?n.in:n.out,i=0;for(let a of o)for(let c of s){let u=t.nodes.get(r==="in"?a.fromId:a.toId)?.order??0,d=t.nodes.get(r==="in"?c.fromId:c.toId)?.order??0;(e.order<n.order&&u>d||e.order>n.order&&u<d)&&(i+=1)}return i}function Jr(t,e){e.direction==="LR"?Yr(t,e):Xr(t,e)}function Yr(t,e){let n=[],r=0;for(let o=0;o<t.layers.length;o+=1){n.push(r);let s=0;for(let i of t.layers[o])s=Math.max(s,i.w);r+=s+e.layerGap}for(let o=0;o<t.layers.length;o+=1)for(let s of t.layers[o])s.x=n[o];for(let o of t.layers){let s=0;for(let i of o)i.y=s,s+=i.h+e.nodeGap}Vn(t,e,"y")}function Xr(t,e){let n=[],r=0;for(let o=0;o<t.layers.length;o+=1){n.push(r);let s=0;for(let i of t.layers[o])s=Math.max(s,i.h);r+=s+e.layerGap}for(let o=0;o<t.layers.length;o+=1)for(let s of t.layers[o])s.y=n[o];for(let o of t.layers){let s=0;for(let i of o)i.x=s,s+=i.w+e.nodeGap}Vn(t,e,"x")}function Vn(t,e,n){let r=s=>n==="y"?s.h:s.w,o=e.nodeGap;for(let s=0;s<2;s+=1){let i=s===0?t.layers.slice(1):t.layers.slice(0,-1).reverse();for(let a of i){let c=new Map;for(let d of a){let f=s===0?d.in:d.out;if(f.length===0)continue;let p=[];for(let l of f){let b=t.nodes.get(s===0?l.fromId:l.toId);if(!b)continue;let g=n==="y"?b.y:b.x;p.push(g+Math.floor(r(b)/2))}if(p.length===0)continue;p.sort((l,b)=>l-b);let h=p[Math.floor(p.length/2)];c.set(d.id,h-Math.floor(r(d)/2))}let u=0;for(let d of a){let f=c.get(d.id),p=n==="y"?d.y:d.x,l=Math.max(f??p,u);n==="y"?d.y=l:d.x=l,u=l+r(d)+o}}}}function Zr(t,e){let n=new Map;for(let u of t.hops){let d=n.get(u.chainId);d?d.push(u):n.set(u.chainId,[u])}for(let u of n.values())u.sort((d,f)=>d.hopIndex-f.hopIndex);let r=e.direction==="LR",o=u=>r?u.x:u.y,s=u=>r?u.w:u.h,i=u=>r?u.y+Math.floor(u.h/2):u.x+Math.floor(u.w/2),a=new Map;for(let u=0;u+1<t.layers.length;u+=1){let d=t.layers[u],f=t.layers[u+1],p=0;for(let O of d)p=Math.max(p,o(O)+s(O));let h=Number.POSITIVE_INFINITY;for(let O of f)h=Math.min(h,o(O));let l=Number.isFinite(h)?h-1:p,b=Math.max(1,l-p+1),g=[];for(let O of d)for(let N of O.out)g.push(N);g.sort((O,N)=>{let S=i(t.nodes.get(O.fromId)),w=i(t.nodes.get(N.fromId));if(S!==w)return S-w;let I=i(t.nodes.get(O.toId)),C=i(t.nodes.get(N.toId));return I-C});let x=[],y=new Map;for(let O of g){let N=i(t.nodes.get(O.fromId)),S=i(t.nodes.get(O.toId)),w=Math.min(N,S),I=Math.max(N,S),C=-1;for(let D=0;D<x.length;D+=1){let X=x[D],ue=!0;for(let oe of X)if(oe.lo<=I&&w<=oe.hi){ue=!1;break}if(ue){X.push({lo:w,hi:I}),C=D;break}}C<0&&(x.push([{lo:w,hi:I}]),C=x.length-1),y.set(O,C)}let m=x.length,v=b>=Math.max(3,m+2),_=v?p+1:p,k=v?l-1:l,E=Math.max(1,k-_+1);for(let O of g){let N=y.get(O),S;if(m<=1)S=_+Math.floor(E/2);else{let w=(E-1)/(m-1);S=_+Math.floor(N*w)}a.set(O,Math.max(p,Math.min(l,S)))}}let c=[];for(let[,u]of n){let d=[];for(let p=0;p<u.length;p+=1){let h=u[p],l=t.nodes.get(h.fromId),b=t.nodes.get(h.toId),g=a.get(h),x=l.isVirtual?o(l):o(l)+s(l),y=b.isVirtual?o(b):o(b)-1,m=i(l),v=i(b);p===0&&Ze(d,r,x,m),m!==v&&(Ze(d,r,g,m),Ze(d,r,g,v)),Ze(d,r,y,v)}let f=u[0];c.push({from:f.chainFrom,to:f.chainTo,points:Qr(d)})}return c}function Ze(t,e,n,r){t.push(e?{x:n,y:r}:{x:r,y:n})}function Qr(t){let e=[];for(let n of t){let r=e[e.length-1];(!r||r.x!==n.x||r.y!==n.y)&&e.push(n)}return e}function eo(t){let e=0,n=0;for(let r of t.layers)for(let o of r)e=Math.max(e,o.x+o.w),n=Math.max(n,o.y+o.h);return{width:e,height:n}}var Hn=R(()=>{"use strict"});function $t(t,e){let n=so(e?.direction),r=Math.max(3,e?.maxLabelWidth??to),o=e?.asciiCharset??"unicode",s=Object.keys(t.nodes).sort(),i=new Set(s),a=t.edges.filter(p=>i.has(p.from)&&i.has(p.to)),c=new Map,u=new Map;for(let p of s){let h=An(p,r);c.set(p,h),u.set(p,Ye(h)+4)}let d=jn({nodes:s,edges:a,widthCells:p=>u.get(p)??3,heightCells:()=>oo,layerGap:no,nodeGap:ro,direction:n}),f=In(d,{charset:o,labelOf:p=>c.get(p)??p});return e?.logger?.(f),f}function so(t){if(t===void 0||t==="LR")return"LR";if(t==="TD")return"TD";throw new Error(`ascii describe supports direction "LR" or "TD" only; got ${String(t)}`)}var to,no,ro,oo,Bn=R(()=>{"use strict";Ln();It();Hn();to=24,no=4,ro=1,oo=3});function Qe(t){if(t===null||typeof t!="object")return t;if(Array.isArray(t))return t.map(Qe);let e=t,n=Object.keys(e).sort(),r={};for(let o of n)r[o]=Qe(e[o]);return r}function zn(t){return t.replaceAll("\\","\\\\").replaceAll('"','\\"')}function Un(t){return t.replaceAll("\\","\\\\").replaceAll('"','\\"')}function Wn(t){return t==="TD"?"down":t==="BT"?"up":t==="RL"?"left":"right"}function et(t){let e=new Set,n=[];function r(o,s){let i=`${o}\0${s}`;e.has(i)||(e.add(i),n.push([o,s]))}for(let[o,s]of Object.entries(t.nodes)){let i=s.deps;if(i)for(let a of i)r(a,o)}for(let o of t.edges)r(o.from,o.to);return n}function tt(t){if(t===void 0)return"LR";if(t==="TD"||t==="LR"||t==="BT"||t==="RL")return t;throw new Error(`invalid diagram direction ${String(t)}; expected one of: TD, LR, BT, RL`)}function Kn(t){if(typeof t=="string")return JSON.stringify(t);if(typeof t=="number"||typeof t=="boolean"||t==null)return String(t);try{return JSON.stringify(t)}catch{return"[unserializable]"}}var Te=R(()=>{"use strict"});function Lt(t,e){let n=tt(e?.direction),r=Object.keys(t.nodes).sort(),o=new Map;for(let i=0;i<r.length;i+=1)o.set(r[i],`n${i}`);let s=[`direction: ${Wn(n)}`];for(let i of r){let a=o.get(i);s.push(`${a}: "${Un(i)}"`)}for(let[i,a]of et(t)){let c=o.get(i),u=o.get(a);!c||!u||s.push(`${c} -> ${u}`)}return s.join(`
|
|
5
|
+
`)}var qn=R(()=>{"use strict";Te()});function Pt(t,e){let n=e?.includeEdges??!0,r=e?.includeSubgraphs??!0,{expand:o,...s}=t,i={...s,edges:n?t.edges:[],subgraphs:r?t.subgraphs:[]},a=JSON.stringify(Qe(i),null,e?.indent??2);return e?.logger?.(a),a}var Jn=R(()=>{"use strict";Te()});function ke(t,e){let n=tt(e?.direction),r=Object.keys(t.nodes).sort(),o=new Map;for(let i=0;i<r.length;i+=1)o.set(r[i],`n${i}`);let s=[`flowchart ${n}`];for(let i of r){let a=o.get(i);s.push(` ${a}["${zn(i)}"]`)}for(let[i,a]of et(t)){let c=o.get(i),u=o.get(a);!c||!u||s.push(` ${c} --> ${u}`)}return s.join(`
|
|
6
|
+
`)}var Ft=R(()=>{"use strict";Te()});function Yn(t,e){let n=e?.theme??"default",r=e?.autoSync??!0,s=JSON.stringify({code:t,mermaid:{theme:n},autoSync:r}),i=new TextEncoder().encode(s),a="";for(let u=0;u<i.length;u++)a+=String.fromCharCode(i[u]);return`https://mermaid.live/edit#base64:${globalThis.btoa(a).replace(/\+/g,"-").replace(/\//g,"_").replace(/=+$/,"")}`}function jt(t,e){let n=ke(t,e);return Yn(n,e)}var Xn=R(()=>{"use strict";Ft()});function Vt(t,e){let n=e?.includeEdges??!0,r=e?.includeSubgraphs??!0,o=[];o.push(`Graph ${t.name}`),o.push("Nodes:");for(let i of Object.keys(t.nodes).sort()){let a=t.nodes[i];o.push(`- ${i} (${a.type}/${a.status}): ${Kn(a.value)}`)}if(n){o.push("Edges:");for(let i of t.edges)o.push(`- ${i.from} -> ${i.to}`)}if(r){o.push("Subgraphs:");for(let i of t.subgraphs)o.push(`- ${i}`)}let s=o.join(`
|
|
7
|
+
`);return e?.logger?.(s),s}var Zn=R(()=>{"use strict";Te()});var Qn=R(()=>{"use strict";Bn();qn();Jn();Ft();Xn();Zn()});function er(t,e={}){let n=[],r=e.requireFound??!0;if(e.skipDescribe!==!0)try{let u=t.describe(),d=new Set(Object.keys(u.nodes)),f=[];for(let[p,h]of Object.entries(u.nodes))for(let l of h.deps)l!==""&&!d.has(l)&&f.push(`${p} \u2192 ${l}`);for(let p of u.edges)d.has(p.from)||f.push(`edge.from: ${p.from}`),d.has(p.to)||f.push(`edge.to: ${p.to}`);f.length>0?n.push({kind:"describe",ok:!1,reason:`describe() has ${f.length} dangling pointer(s); nodes \u2289 deps`,danglingDeps:f}):n.push({kind:"describe",ok:!0,nodeCount:d.size,edgeCount:u.edges.length})}catch(u){n.push({kind:"describe",ok:!1,reason:`describe() threw: ${u instanceof Error?u.message:String(u)}`})}if((e.formats?.length??0)>0){let u=t.describe();for(let d of e.formats)try{let f=io[d](u);typeof f!="string"||f.length===0?n.push({kind:"describe-format",ok:!1,format:d,reason:`${d} renderer returned empty or non-string output`}):n.push({kind:"describe-format",ok:!0,format:d,length:f.length})}catch(f){n.push({kind:"describe-format",ok:!1,format:d,reason:f instanceof Error?f.message:String(f)})}}for(let u of e.paths??[])try{t.resolve(u),n.push({kind:"observe",ok:!0,path:u})}catch(d){n.push({kind:"observe",ok:!1,path:u,reason:d instanceof Error?d.message:String(d)})}for(let[u,d]of e.pairs??[])try{let f=t.explain(u,d);r&&f.found===!1?n.push({kind:"explain",ok:!1,from:u,to:d,reason:`explain(${u} \u2192 ${d}) found no path${f.reason?`: ${f.reason}`:""}`}):n.push({kind:"explain",ok:!0,from:u,to:d,found:f.found,steps:f.steps.length})}catch(f){n.push({kind:"explain",ok:!1,from:u,to:d,reason:f instanceof Error?f.message:String(f)})}let o=n.filter(u=>!u.ok),s=o.length===0,i=e.paths?.length??0,a=e.pairs?.length??0,c=e.formats?.length??0;return{ok:s,checks:n,failures:o,summary(){let u=[e.skipDescribe===!0?null:"describe",c>0?`${c} format${c===1?"":"s"}`:null,i>0?`${i} observe path${i===1?"":"s"}`:null,a>0?`${a} explain pair${a===1?"":"s"}`:null].filter(f=>f!=null),d=u.length>0?u.join(", "):"describe-only";return s?`validateGraphObservability: OK (${d})`:`validateGraphObservability: ${o.length} failure(s) across ${d}`}}}var io,tr=R(()=>{"use strict";Qn();io={json:t=>Pt(t),pretty:t=>Vt(t),mermaid:t=>ke(t),"mermaid-url":t=>jt(t),d2:t=>Lt(t),ascii:t=>$t(t)}});var ao={};sr(ao,{ENVELOPE_VERSION:()=>me,GRAPH_META_SEGMENT:()=>B,Graph:()=>ne,JsonCodec:()=>ct,SIZEOF_OVERHEAD:()=>$,SIZEOF_SYMBOL:()=>at,SNAPSHOT_VERSION:()=>te,createDagCborCodec:()=>Wt,createDagCborZstdCodec:()=>Kt,decodeEnvelope:()=>Re,diffForWAL:()=>Ct,encodeEnvelope:()=>Se,explainPath:()=>Ie,graphProfile:()=>Ke,reachable:()=>Je,registerBuiltinCodecs:()=>De,replayWAL:()=>qt,sizeof:()=>Ne,validateGraphObservability:()=>er,validateNoIslands:()=>Rn,watchTopologyTree:()=>Nn});module.exports=ar(ao);var uo=R(()=>{ut();Ae();dt();Mt();Rt();Sn();Dn();tr()});uo();0&&(module.exports={ENVELOPE_VERSION,GRAPH_META_SEGMENT,Graph,JsonCodec,SIZEOF_OVERHEAD,SIZEOF_SYMBOL,SNAPSHOT_VERSION,createDagCborCodec,createDagCborZstdCodec,decodeEnvelope,diffForWAL,encodeEnvelope,explainPath,graphProfile,reachable,registerBuiltinCodecs,replayWAL,sizeof,validateGraphObservability,validateNoIslands,watchTopologyTree});
|
package/dist/graph/index.d.cts
CHANGED
|
@@ -1,7 +1,7 @@
|
|
|
1
|
-
export { E as ENVELOPE_VERSION, a as EvictedSubgraphInfo, b as EvictionPolicy, G as GraphCodec, J as JsonCodec, L as LazyGraphCodec, O as ObservabilityCheck, c as ObservabilityDescribeFormat, d as SIZEOF_OVERHEAD, S as SIZEOF_SYMBOL, V as
|
|
2
|
-
export { C as CausalChain,
|
|
3
|
-
export { w as watchTopologyTree } from '../topology-tree-
|
|
4
|
-
import '../node-
|
|
5
|
-
import '../meta-
|
|
1
|
+
export { E as ENVELOPE_VERSION, a as EvictedSubgraphInfo, b as EvictionPolicy, G as GraphCodec, I as IslandReport, J as JsonCodec, L as LazyGraphCodec, O as ObservabilityCheck, c as ObservabilityDescribeFormat, d as SIZEOF_OVERHEAD, S as SIZEOF_SYMBOL, V as ValidateNoIslandsResult, e as ValidateObservabilityOptions, f as ValidateObservabilityResult, W as WALEntry, g as createDagCborCodec, h as createDagCborZstdCodec, i as decodeEnvelope, j as encodeEnvelope, r as registerBuiltinCodecs, l as replayWAL, s as sizeof, v as validateGraphObservability, m as validateNoIslands } from '../index-0rKFCVFp.cjs';
|
|
2
|
+
export { C as CausalChain, c as CausalStep, e as DescribeFilter, E as ExplainPathOptions, f as GRAPH_META_SEGMENT, G as Graph, g as GraphActorOptions, h as GraphAttachStorageOptions, i as GraphCheckpointRecord, j as GraphDescribeOptions, b as GraphDescribeOutput, k as GraphDiagramDirection, l as GraphDiffChange, m as GraphDiffResult, n as GraphFactoryContext, o as GraphNodeFactory, p as GraphObserveAll, q as GraphObserveOne, a as GraphOptions, r as GraphPersistSnapshot, s as GraphProfileOptions, t as GraphProfileResult, u as GraphVersionChange, v as GraphWALDiff, N as NodeProfile, O as ObserveChangeset, w as ObserveDetail, x as ObserveEvent, y as ObserveOptions, z as ObserveResult, A as ObserveTheme, B as ObserveThemeName, F as ObserveTier, R as ReachableDirection, H as ReachableOptions, S as SNAPSHOT_VERSION, T as TopologyEvent, I as TraceEntry, J as diffForWAL, K as explainPath, L as graphProfile, P as reachable } from '../graph-C4SHb3Ly.cjs';
|
|
3
|
+
export { w as watchTopologyTree } from '../topology-tree-BSdfSwMi.cjs';
|
|
4
|
+
import '../node-ClS5yC-B.cjs';
|
|
5
|
+
import '../meta-vE8bxW1E.cjs';
|
|
6
6
|
import '../extra/storage-core.cjs';
|
|
7
7
|
import '../extra/storage-tiers.cjs';
|
package/dist/graph/index.d.ts
CHANGED
|
@@ -1,7 +1,7 @@
|
|
|
1
|
-
export { E as ENVELOPE_VERSION, a as EvictedSubgraphInfo, b as EvictionPolicy, G as GraphCodec, J as JsonCodec, L as LazyGraphCodec, O as ObservabilityCheck, c as ObservabilityDescribeFormat, d as SIZEOF_OVERHEAD, S as SIZEOF_SYMBOL, V as
|
|
2
|
-
export { C as CausalChain,
|
|
3
|
-
export { w as watchTopologyTree } from '../topology-tree-
|
|
4
|
-
import '../node-
|
|
5
|
-
import '../meta-
|
|
1
|
+
export { E as ENVELOPE_VERSION, a as EvictedSubgraphInfo, b as EvictionPolicy, G as GraphCodec, I as IslandReport, J as JsonCodec, L as LazyGraphCodec, O as ObservabilityCheck, c as ObservabilityDescribeFormat, d as SIZEOF_OVERHEAD, S as SIZEOF_SYMBOL, V as ValidateNoIslandsResult, e as ValidateObservabilityOptions, f as ValidateObservabilityResult, W as WALEntry, g as createDagCborCodec, h as createDagCborZstdCodec, i as decodeEnvelope, j as encodeEnvelope, r as registerBuiltinCodecs, l as replayWAL, s as sizeof, v as validateGraphObservability, m as validateNoIslands } from '../index-K0_0eR8g.js';
|
|
2
|
+
export { C as CausalChain, c as CausalStep, e as DescribeFilter, E as ExplainPathOptions, f as GRAPH_META_SEGMENT, G as Graph, g as GraphActorOptions, h as GraphAttachStorageOptions, i as GraphCheckpointRecord, j as GraphDescribeOptions, b as GraphDescribeOutput, k as GraphDiagramDirection, l as GraphDiffChange, m as GraphDiffResult, n as GraphFactoryContext, o as GraphNodeFactory, p as GraphObserveAll, q as GraphObserveOne, a as GraphOptions, r as GraphPersistSnapshot, s as GraphProfileOptions, t as GraphProfileResult, u as GraphVersionChange, v as GraphWALDiff, N as NodeProfile, O as ObserveChangeset, w as ObserveDetail, x as ObserveEvent, y as ObserveOptions, z as ObserveResult, A as ObserveTheme, B as ObserveThemeName, F as ObserveTier, R as ReachableDirection, H as ReachableOptions, S as SNAPSHOT_VERSION, T as TopologyEvent, I as TraceEntry, J as diffForWAL, K as explainPath, L as graphProfile, P as reachable } from '../graph-7VguS7a4.js';
|
|
3
|
+
export { w as watchTopologyTree } from '../topology-tree-BNGvuG82.js';
|
|
4
|
+
import '../node-ClS5yC-B.js';
|
|
5
|
+
import '../meta-BgVAsg9j.js';
|
|
6
6
|
import '../extra/storage-core.js';
|
|
7
7
|
import '../extra/storage-tiers.js';
|
package/dist/graph/index.js
CHANGED
|
@@ -1 +1 @@
|
|
|
1
|
-
import{a as s,b as t}from"../chunk-
|
|
1
|
+
import{a as s,b as t,c as u}from"../chunk-KVV66NN2.js";import"../chunk-3G5U5QNE.js";import"../chunk-C72GO4IZ.js";import{a as i,b as j,c as k,d as l,g as m,h as n,i as o,j as p,k as q,l as r}from"../chunk-626TESAC.js";import"../chunk-ESMPEKEV.js";import"../chunk-35JTVPOX.js";import"../chunk-V5A7M7RJ.js";import{a,b,c,d,e,f,g,h}from"../chunk-LYCLF26R.js";import"../chunk-CK2E7BTU.js";import"../chunk-QYADASLV.js";export{d as ENVELOPE_VERSION,n as GRAPH_META_SEGMENT,p as Graph,a as JsonCodec,i as SIZEOF_OVERHEAD,j as SIZEOF_SYMBOL,o as SNAPSHOT_VERSION,b as createDagCborCodec,c as createDagCborZstdCodec,f as decodeEnvelope,q as diffForWAL,e as encodeEnvelope,l as explainPath,m as graphProfile,r as reachable,g as registerBuiltinCodecs,h as replayWAL,k as sizeof,u as validateGraphObservability,t as validateNoIslands,s as watchTopologyTree};
|
|
@@ -1,5 +1,5 @@
|
|
|
1
|
-
import { A as Actor,
|
|
2
|
-
import { D as DescribeNodeOutput, a as DescribeDetail, b as DescribeField } from './meta-
|
|
1
|
+
import { A as Actor, n as GraphReFlyConfig, V as VersioningLevel, N as Node, M as Messages, K as NodeSink } from './node-ClS5yC-B.js';
|
|
2
|
+
import { D as DescribeNodeOutput, a as DescribeDetail, b as DescribeField } from './meta-BgVAsg9j.js';
|
|
3
3
|
import { StorageHandle } from './extra/storage-core.js';
|
|
4
4
|
import { SnapshotStorageTier } from './extra/storage-tiers.js';
|
|
5
5
|
|
|
@@ -1665,4 +1665,4 @@ declare function reachable(described: GraphDescribeOutput, from: string, directi
|
|
|
1665
1665
|
}): ReachableResult;
|
|
1666
1666
|
declare function reachable(described: GraphDescribeOutput, from: string, direction: ReachableDirection, options?: ReachableOptions): string[];
|
|
1667
1667
|
|
|
1668
|
-
export { type ObserveTheme as A, type ObserveThemeName as B, type CausalChain as C, type
|
|
1668
|
+
export { type ObserveTheme as A, type ObserveThemeName as B, type CausalChain as C, type DescribeChangeset as D, type ExplainPathOptions as E, type ObserveTier as F, Graph as G, type ReachableOptions as H, type TraceEntry as I, diffForWAL as J, explainPath as K, graphProfile as L, type Meta as M, type NodeProfile as N, type ObserveChangeset as O, reachable as P, topologyDiff as Q, type ReachableDirection as R, SNAPSHOT_VERSION as S, type TopologyEvent as T, type GraphOptions as a, type GraphDescribeOutput as b, type CausalStep as c, type DescribeEvent as d, type DescribeFilter as e, GRAPH_META_SEGMENT as f, type GraphActorOptions as g, type GraphAttachStorageOptions as h, type GraphCheckpointRecord as i, type GraphDescribeOptions as j, type GraphDiagramDirection as k, type GraphDiffChange as l, type GraphDiffResult as m, type GraphFactoryContext as n, type GraphNodeFactory as o, type GraphObserveAll as p, type GraphObserveOne as q, type GraphPersistSnapshot as r, type GraphProfileOptions as s, type GraphProfileResult as t, type GraphVersionChange as u, type GraphWALDiff as v, type ObserveDetail as w, type ObserveEvent as x, type ObserveOptions as y, type ObserveResult as z };
|