@graphrefly/graphrefly 0.38.0 → 0.39.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/budget-gate-CmmVtasH.d.ts +115 -0
- package/dist/budget-gate-DiP_nK0n.d.cts +115 -0
- package/dist/{cascading-BsJ4GbnS.d.ts → cascading-BzuxW0_w.d.cts} +2 -2
- package/dist/{cascading-B25wxpRa.d.cts → cascading-g2_rhhaM.d.ts} +2 -2
- package/dist/chunk-35JTVPOX.js +1 -0
- package/dist/chunk-3G5U5QNE.js +5 -0
- package/dist/{chunk-PHXZRR6C.js → chunk-4I45FVQS.js} +1 -1
- package/dist/chunk-5LK7XMEV.js +1 -0
- package/dist/{chunk-FWGIZP3W.js → chunk-5XRI6RM3.js} +1 -1
- package/dist/chunk-73PBQNST.js +1 -0
- package/dist/chunk-7JRF5YEK.js +3 -0
- package/dist/{chunk-4BDQXBXE.js → chunk-7NZMZJMW.js} +1 -1
- package/dist/chunk-7QFRK3N3.js +84 -0
- package/dist/{chunk-POCWFIJ7.js → chunk-7SD73DS6.js} +1 -1
- package/dist/{chunk-NBGPXQSP.js → chunk-A6ZSKGUG.js} +1 -1
- package/dist/{chunk-7KZZLWZ6.js → chunk-AU7YTQX7.js} +1 -1
- package/dist/chunk-C72GO4IZ.js +1 -0
- package/dist/{chunk-B5S7KTGP.js → chunk-CGDMTXSY.js} +1 -1
- package/dist/chunk-D27JNOLZ.js +1 -0
- package/dist/chunk-D47YVDR5.js +1 -0
- package/dist/chunk-EWF7KCDJ.js +61 -0
- package/dist/{chunk-IBGE62GZ.js → chunk-GEAO3TL3.js} +1 -1
- package/dist/chunk-GX5LSSRE.js +1 -0
- package/dist/{chunk-O245YLM5.js → chunk-HAWKGIXM.js} +1 -1
- package/dist/chunk-HX3EGQ5Z.js +1 -0
- package/dist/{chunk-RZ5HKPGI.js → chunk-IA7DUNGB.js} +1 -1
- package/dist/{chunk-K5C67OGE.js → chunk-INH6FS2G.js} +2 -2
- package/dist/chunk-INHC33EH.js +1 -0
- package/dist/chunk-IUB4NYI2.js +1 -0
- package/dist/{chunk-UVLZX2OU.js → chunk-JNMC2WJ6.js} +1 -1
- package/dist/{chunk-O2BLVQU4.js → chunk-KD4NHLMU.js} +1 -1
- package/dist/chunk-L6NSJVJZ.js +1 -0
- package/dist/{chunk-6773HURD.js → chunk-L7WY6TZS.js} +1 -1
- package/dist/chunk-LQNOXGET.js +1 -0
- package/dist/chunk-MC4UYY2X.js +1 -0
- package/dist/{chunk-6KZZ6XQE.js → chunk-N7UIBZCW.js} +1 -1
- package/dist/chunk-NQI2C36M.js +1 -0
- package/dist/chunk-R75BMDLA.js +1 -0
- package/dist/chunk-RF3QZP6D.js +1 -0
- package/dist/{chunk-NV63VQHI.js → chunk-S2U57TFC.js} +1 -1
- package/dist/{chunk-SP5O2MIX.js → chunk-SC7BQDNP.js} +1 -1
- package/dist/{chunk-6VFC334U.js → chunk-TFPZLQ5H.js} +1 -1
- package/dist/chunk-VJJLIEAL.js +1 -0
- package/dist/{chunk-FAYEMS5M.js → chunk-WHIZM6JV.js} +1 -1
- package/dist/chunk-XEUANKBO.js +43 -0
- package/dist/{chunk-DSOVKKTI.js → chunk-XQ55HO5N.js} +1 -1
- package/dist/chunk-ZJ7SM3G2.js +1 -0
- package/dist/{chunk-TMVY7OWG.js → chunk-ZOX3LBRV.js} +1 -1
- package/dist/compat/index.cjs +9 -13
- 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 +7 -11
- 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 -7
- 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/{composite-CgG0MqHm.d.cts → composite-CKd0e2vz.d.cts} +2 -2
- package/dist/{composite-DTOlDuch.d.ts → composite-DGatA-JK.d.ts} +2 -2
- package/dist/core/index.cjs +1 -1
- package/dist/core/index.d.cts +4 -4
- package/dist/core/index.d.ts +4 -4
- package/dist/core/index.js +1 -1
- package/dist/extra/browser.d.cts +1 -1
- package/dist/extra/browser.d.ts +1 -1
- package/dist/extra/index.cjs +16 -20
- package/dist/extra/index.d.cts +11 -9
- package/dist/extra/index.d.ts +11 -9
- 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.cjs +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.cjs +5 -0
- package/dist/extra/render/index.d.cts +183 -0
- package/dist/extra/render/index.d.ts +183 -0
- package/dist/extra/render/index.js +1 -0
- package/dist/extra/sources.cjs +1 -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-axI2cXwt.d.cts → fallback-8JYU8tlT.d.cts} +1 -1
- package/dist/{fallback-DuEXfA4F.d.ts → fallback-CMZl39L5.d.ts} +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-BjW1taJl.d.ts → graph-30XSgtVX.d.ts} +76 -100
- package/dist/{graph-CHsVwf9S.d.cts → graph-BUwMAxJI.d.cts} +76 -100
- package/dist/{index-CIcu6fIR.d.ts → index-2n8Eai6M.d.ts} +1 -1
- package/dist/{index-CrlHFsiT.d.ts → index-89FczVZ_.d.ts} +41 -85
- package/dist/{index-CM-i58FY.d.cts → index-8R1vzNOx.d.cts} +9 -9
- package/dist/{index-CDvC1m5p.d.ts → index-B2RUoIUz.d.ts} +1 -1
- package/dist/{index-BFaALJxR.d.ts → index-B41Asm7D.d.ts} +10 -8
- package/dist/{index-D-HZ7sP4.d.ts → index-B9fmw5n2.d.ts} +4 -6
- package/dist/{index-Bn0uZEL4.d.ts → index-BAlaVimV.d.ts} +9 -9
- package/dist/{index-DJVQ-t07.d.ts → index-BC9VybQs.d.ts} +41 -48
- package/dist/{index-5dNRlW7J.d.ts → index-BEHmxORq.d.ts} +11 -11
- package/dist/{index-DJNAWzcH.d.cts → index-BJ26eEjs.d.cts} +26 -19
- package/dist/{index-BiomL7AW.d.ts → index-BJSZxSFX.d.ts} +1 -1
- package/dist/{index-Czk3r0yA.d.cts → index-BKMdnYnk.d.ts} +56 -54
- package/dist/{index-BsZk9T8y.d.ts → index-BM9szD8n.d.cts} +14 -6
- package/dist/{index-BmWuVdER.d.ts → index-BUPVld1w.d.ts} +2 -2
- package/dist/{index-BwOsJfLJ.d.ts → index-BXd6OMEy.d.ts} +3 -3
- package/dist/index-BhUaMYm_.d.ts +113 -0
- package/dist/{index-BpMZzX9P.d.cts → index-BndG0cpK.d.cts} +3 -3
- package/dist/{index-AUqWe_fX.d.ts → index-Br3WnqEn.d.ts} +81 -9
- package/dist/{index-BhzwpIJc.d.cts → index-BskfDoZ_.d.ts} +14 -6
- package/dist/{index-D9vBTuzo.d.ts → index-C19qqa38.d.ts} +4 -4
- package/dist/{index-B-ORMr3k.d.ts → index-C7VV_qOs.d.ts} +4 -4
- package/dist/{index-BWUMIt7J.d.cts → index-CIRG8Hxp.d.cts} +11 -11
- package/dist/{index-B3D_z0Z6.d.cts → index-CL7oilfm.d.cts} +1 -1
- package/dist/{index-ML6vHKXK.d.ts → index-CPhBvRJU.d.ts} +1 -1
- package/dist/{index-CQsqqEVz.d.cts → index-CWHtYmSh.d.cts} +1 -1
- package/dist/{index-DKrIuF-r.d.ts → index-Cey6VTnX.d.ts} +8 -5
- package/dist/{resilience-BWP2c7Af.d.cts → index-CmqiJZKM.d.ts} +141 -23
- package/dist/{index-JYtN9uqM.d.ts → index-CoM4rzyB.d.ts} +1 -1
- package/dist/{index-C56XZiDe.d.cts → index-CpLpJb6A.d.cts} +8 -5
- package/dist/{index-BjWZARLy.d.ts → index-Ctb7_2sG.d.ts} +1 -1
- package/dist/index-CusEP3Sv.d.ts +210 -0
- package/dist/{resilience-Bys63Cpd.d.ts → index-CwP_KAMS.d.cts} +141 -23
- package/dist/{index-BFuVcqL8.d.cts → index-D3ayz3hy.d.cts} +1 -1
- package/dist/{index-Bpr0Pwgl.d.cts → index-DCbE8fFM.d.cts} +3 -3
- package/dist/{index-CAbHN_rP.d.cts → index-DIHcMLr6.d.cts} +1 -1
- package/dist/index-DINuaZlJ.d.cts +210 -0
- package/dist/{index-9xhIaM-w.d.cts → index-DOBLxOti.d.cts} +1 -1
- package/dist/{index-Di7OdwlO.d.ts → index-DQUVq1_d.d.ts} +37 -90
- package/dist/{index-BgzPO43H.d.cts → index-DTtBpuQy.d.cts} +4 -6
- package/dist/{index-D_QQ_dTD.d.cts → index-DYTBbF8T.d.cts} +1 -1
- package/dist/{index-UsU9ptzs.d.cts → index-DlgHqQxW.d.cts} +81 -9
- package/dist/{index-DTDVDzhA.d.ts → index-DlrWu9Hs.d.cts} +56 -54
- package/dist/{index-B2IUcH13.d.cts → index-DoYc8BWK.d.cts} +41 -48
- package/dist/{index-BUFCHvOR.d.ts → index-DszPlZzK.d.ts} +3 -3
- package/dist/{index-BqcgiSQg.d.cts → index-DyM4tFAe.d.cts} +10 -8
- package/dist/{index-CAV-3RpJ.d.cts → index-FVoPvhAu.d.cts} +4 -4
- package/dist/{index-Ckil6miL.d.cts → index-H_I66pav.d.cts} +2 -2
- package/dist/{index-C-3UXnHT.d.cts → index-IwFqHxCs.d.cts} +2 -2
- package/dist/index-K-vl_c6A.d.cts +113 -0
- package/dist/{index-CijfwEWx.d.ts → index-KlZ_ZUip.d.cts} +3 -3
- package/dist/{index-Bub6x_D4.d.cts → index-L8XI8Zql.d.cts} +37 -90
- package/dist/{index-DeSsvHDD.d.cts → index-MxYuWOrf.d.cts} +3 -3
- package/dist/{index-CpZKtdMw.d.cts → index-PgwvGWa1.d.cts} +1 -1
- package/dist/{index-Vz7KPfgz.d.ts → index-PlJ3MraE.d.ts} +1 -1
- package/dist/{index-BI1wMfyc.d.ts → index-PqbnoScQ.d.ts} +3 -3
- package/dist/{index-BsgxnHN8.d.cts → index-PsVHpPwP.d.cts} +3 -3
- package/dist/{index-D-B7U42V.d.cts → index-WyFKER-c.d.ts} +3 -3
- package/dist/{index-DY2f2b9z.d.ts → index-eaQuGJnv.d.ts} +3 -3
- package/dist/{index-DqICM_I7.d.ts → index-iTX5IqSP.d.ts} +67 -9
- package/dist/{index-Byp771zP.d.ts → index-jKLph6cu.d.ts} +2 -2
- package/dist/{index-CEVzBWeB.d.ts → index-jr6PuSBt.d.ts} +26 -19
- package/dist/{index-BkQqf1EF.d.cts → index-mNwgxC21.d.cts} +67 -9
- package/dist/{index-BaSy4L6w.d.cts → index-pVDQcbar.d.cts} +41 -85
- package/dist/{index-D7-RSD93.d.cts → index-xZYcDqFH.d.cts} +4 -4
- package/dist/{index-8OxXae3g.d.ts → index-yLt-aPMp.d.ts} +1 -1
- package/dist/{index-CqSJ25A9.d.cts → index-z8WFPVI8.d.cts} +1 -1
- package/dist/index.cjs +63 -59
- package/dist/index.d.cts +48 -47
- package/dist/index.d.ts +48 -47
- package/dist/index.js +1 -1
- package/dist/{meta-DreaEM_a.d.cts → meta-Ct9nqQS5.d.cts} +11 -7
- package/dist/{meta-BYqlATmg.d.ts → meta-D8OyedKp.d.ts} +11 -7
- package/dist/{node-fSc-hCv8.d.cts → node-BYInONRr.d.cts} +3 -3
- package/dist/{node-fSc-hCv8.d.ts → node-BYInONRr.d.ts} +3 -3
- package/dist/{observable-Cqty11jG.d.cts → observable-DMIlYJV1.d.cts} +1 -1
- package/dist/{observable-EAV_rNfM.d.ts → observable-DO8DDEzv.d.ts} +1 -1
- package/dist/patterns/ai/browser.cjs +5 -5
- 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 +16 -20
- 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.cjs +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/audit/index.cjs +3 -7
- package/dist/patterns/audit/index.d.cts +6 -6
- package/dist/patterns/audit/index.d.ts +6 -6
- package/dist/patterns/audit/index.js +1 -1
- package/dist/patterns/cqrs/index.cjs +3 -7
- 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 -8
- 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 -7
- 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 +37 -37
- 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/guarded-execution/index.cjs +3 -7
- package/dist/patterns/guarded-execution/index.d.cts +7 -7
- package/dist/patterns/guarded-execution/index.d.ts +7 -7
- package/dist/patterns/guarded-execution/index.js +1 -1
- package/dist/patterns/harness/index.cjs +8 -12
- package/dist/patterns/harness/index.d.cts +12 -12
- package/dist/patterns/harness/index.d.ts +12 -12
- package/dist/patterns/harness/index.js +1 -1
- package/dist/patterns/job-queue/index.cjs +3 -7
- 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/lens/index.cjs +3 -7
- package/dist/patterns/lens/index.d.cts +6 -6
- package/dist/patterns/lens/index.d.ts +6 -6
- package/dist/patterns/lens/index.js +1 -1
- package/dist/patterns/memory/index.cjs +3 -7
- 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 -7
- 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 -7
- package/dist/patterns/orchestration/index.d.cts +8 -8
- package/dist/patterns/orchestration/index.d.ts +8 -8
- 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 -8
- 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 -7
- 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/refine-loop/index.cjs +5 -9
- package/dist/patterns/refine-loop/index.d.cts +6 -6
- package/dist/patterns/refine-loop/index.d.ts +6 -6
- package/dist/patterns/refine-loop/index.js +1 -1
- package/dist/patterns/resilient-pipeline/index.cjs +1 -1
- package/dist/patterns/resilient-pipeline/index.d.cts +4 -8
- package/dist/patterns/resilient-pipeline/index.d.ts +4 -8
- package/dist/patterns/resilient-pipeline/index.js +1 -1
- package/dist/patterns/surface/index.cjs +12 -16
- 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-DuHpXSOn.d.cts → pipeline-graph-BQPr2Lqs.d.cts} +34 -17
- package/dist/{pipeline-graph-9JBbmRxA.d.ts → pipeline-graph-D8vKcO_p.d.ts} +34 -17
- package/dist/{reactive-layout-BMLDB4Vd.d.cts → reactive-layout-8CSc0tiA.d.cts} +2 -2
- package/dist/{reactive-layout-D-tRiNhg.d.ts → reactive-layout-DkTXxtSy.d.ts} +2 -2
- package/dist/{reactive-log-BgWSA1fg.d.ts → reactive-log-BlAsPLl2.d.ts} +2 -2
- package/dist/{reactive-log-C3IMAGpT.d.cts → reactive-log-_zeEnB9H.d.cts} +2 -2
- package/dist/{reactive-map-DmgeADH8.d.cts → reactive-map-B2qfD3hb.d.cts} +1 -1
- package/dist/{reactive-map-CHyeCf4D.d.ts → reactive-map-jFIsE6Kt.d.ts} +1 -1
- package/dist/resilience-HTF2LBRS.js +1 -0
- package/dist/{sugar-D13E2M_z.d.ts → sugar-BhfjgetH.d.ts} +1 -1
- package/dist/{sugar-DgaGJcI6.d.cts → sugar-DzePN5-g.d.cts} +1 -1
- package/dist/{topology-tree-jrZue3ao.d.cts → topology-tree-B5Ngw3j0.d.cts} +1 -1
- package/dist/{topology-tree-D47-nI6Z.d.ts → topology-tree-BtvbgMXJ.d.ts} +1 -1
- package/dist/{types-BMSGPlpO.d.cts → types-1Dhoi7HM.d.cts} +1 -1
- package/dist/{types-CidcBDuk.d.ts → types-39jk0kaV.d.ts} +1 -1
- package/package.json +11 -1
- package/dist/chunk-2YFDSYEF.js +0 -1
- package/dist/chunk-5BGFS2XH.js +0 -1
- package/dist/chunk-CMTN3KPT.js +0 -80
- package/dist/chunk-DQJLC6YY.js +0 -1
- package/dist/chunk-G7JN6LCB.js +0 -1
- package/dist/chunk-KJEAIIIY.js +0 -43
- package/dist/chunk-LV3ACS5J.js +0 -1
- package/dist/chunk-NN3QPJ6U.js +0 -1
- package/dist/chunk-NSAZ6PR6.js +0 -1
- package/dist/chunk-O32GJOUJ.js +0 -1
- package/dist/chunk-QEVSIVSF.js +0 -1
- package/dist/chunk-QMC2PLNM.js +0 -7
- package/dist/chunk-QOJFR6GS.js +0 -1
- package/dist/chunk-SFK7MN7S.js +0 -1
- package/dist/chunk-TB7JKSVS.js +0 -61
- package/dist/chunk-UAXFKMAG.js +0 -1
- package/dist/chunk-XIMFHEKV.js +0 -1
- package/dist/chunk-XLMYQB6F.js +0 -1
- package/dist/chunk-XLYF4LBH.js +0 -1
- package/dist/imperative-audit-ahAE65a9.d.cts +0 -28
- package/dist/imperative-audit-ahAE65a9.d.ts +0 -28
- package/dist/index-CpdnP-0y.d.cts +0 -186
- package/dist/index-DOU1Ee_k.d.ts +0 -186
- package/dist/resilience-LGBK236C.js +0 -1
|
@@ -1,17 +1,13 @@
|
|
|
1
|
-
"use strict";var st=Object.defineProperty;var In=Object.getOwnPropertyDescriptor;var jn=Object.getOwnPropertyNames;var Vn=Object.prototype.hasOwnProperty;var K=(t,e)=>()=>(t&&(e=t(t=0)),e);var Bn=(t,e)=>{for(var n in e)st(t,n,{get:e[n],enumerable:!0})},Hn=(t,e,n,r)=>{if(e&&typeof e=="object"||typeof e=="function")for(let s of jn(e))!Vn.call(t,s)&&s!==n&&st(t,s,{get:()=>e[s],enumerable:!(r=In(e,s))||r.enumerable});return t};var zn=t=>Hn(st({},"__esModule",{value:!0}),t);function Dt(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 s=2+n.length+2+e.length;if(s>4294967295)throw new Error(`encodeEnvelope: total envelope size ${s} exceeds 2^32-1 bytes (payload ${e.length} bytes)`);let o=new Uint8Array(s),i=0;return o[i++]=it,o[i++]=n.length,o.set(n,i),i+=n.length,o[i++]=r>>>8&255,o[i++]=r&255,o.set(e,i),o}function Mt(t,e){if(t.length<Gt)throw new Error(`decodeEnvelope: bytes too short (${t.length} < ${Gt})`);let n=0,r=t[n++];if(r!==it)throw new Error(`decodeEnvelope: unsupported envelope version ${r} (expected ${it})`);let s=t[n++];if(s===0)throw new Error("decodeEnvelope: name_len must be >= 1");if(n+s+2>t.length)throw new Error(`decodeEnvelope: envelope truncated (need ${n+s+2} bytes, have ${t.length})`);let o=new TextDecoder().decode(t.subarray(n,n+s));n+=s;let i=(t[n]<<8|t[n+1])>>>0;n+=2;let a=t.subarray(n),u=e.lookupCodec(o);if(u==null)throw new Error(`decodeEnvelope: codec "${o}" not registered (envelope codec_v=${i})`);return{codec:u,codecVersion:i,payload:a}}function $t(t){t.registerCodec(Wn)}var Wn,it,Gt,at=K(()=>{"use strict";Wn={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)}},it=1,Gt=4});function De(t){if(t==null)return ge;let{type:e,id:n,...r}=t;return{type:e??"system",id:n??"",...r}}var ge,ct=K(()=>{"use strict";ge={type:"system",id:""}});function Me(){return me>0||Oe}function Pt(){return me>0}function be(t){me>0?Ne.push(t):t()}function $e(t){me+=1;let e=!1;try{t()}catch(n){throw e=!0,n}finally{if(me-=1,me===0)if(e){if(!Oe){let n=Ne.splice(0);for(let r of n)try{r()}catch{}ue.length=0,de.length=0,ye.length=0}}else Un()}}function Un(){let t=!Oe;t&&(Oe=!0);let e=[],n=0;try{for(;ue.length>0||de.length>0||ye.length>0||t&&Ne.length>0;){if(t&&Ne.length>0){let o=Ne.splice(0);for(let i of o)try{i()}catch(a){e.push(a)}continue}if(n+=1,n>1e3)throw ue.length=0,de.length=0,ye.length=0,new Error("batch drain exceeded 1000 iterations \u2014 likely a reactive cycle");let s=(ue.length>0?ue:de.length>0?de:ye).splice(0);for(let o of s)try{o()}catch(i){e.push(i)}}}finally{t&&(Oe=!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 c=n(e[0][0]);if(c<3||!Me()){t(e);return}(c>=5?ye:c===4?de:ue).push(()=>t(e));return}let r=e.length,s=r,o=r,i=r,a=0;for(;a<r&&n(e[a][0])<3;)a++;for(s=a;a<r&&n(e[a][0])===3;)a++;for(o=a;a<r&&n(e[a][0])===4;)a++;i=a;let u=Me();if(s>0){let c=e.slice(0,s);t(c)}if(o>s){let c=e.slice(s,o);u?ue.push(()=>t(c)):t(c)}if(i>o){let c=e.slice(o,i);u?de.push(()=>t(c)):t(c)}if(r>i){let c=e.slice(i,r);u?ye.push(()=>t(c)):t(c)}}var me,Oe,ue,de,ye,Ne,Le=K(()=>{"use strict";me=0,Oe=!1,ue=[],de=[],ye=[],Ne=[]});function oe(){return Math.trunc(performance.now()*1e6)}function ve(){return Date.now()*1e6}var Te=K(()=>{"use strict"});var Ee,F,q,J,ee,te,se,H,z,M,we,ut,Kn,dt,qn,Jn,lt,Lt,Ft,It,ft,le=K(()=>{"use strict";Ee=Symbol.for("graphrefly/START"),F=Symbol.for("graphrefly/DATA"),q=Symbol.for("graphrefly/DIRTY"),J=Symbol.for("graphrefly/RESOLVED"),ee=Symbol.for("graphrefly/INVALIDATE"),te=Symbol.for("graphrefly/PAUSE"),se=Symbol.for("graphrefly/RESUME"),H=Symbol.for("graphrefly/TEARDOWN"),z=Symbol.for("graphrefly/COMPLETE"),M=Symbol.for("graphrefly/ERROR"),we=Object.freeze([q]),ut=Object.freeze([J]),Kn=Object.freeze([ee]),dt=Object.freeze([Ee]),qn=Object.freeze([z]),Jn=Object.freeze([H]),lt=Object.freeze([we]),Lt=Object.freeze([ut]),Ft=Object.freeze([Kn]),It=Object.freeze([qn]),ft=Object.freeze([Jn])});function jt(t){t.registerMessageType(Ee,{tier:0,wireCrossing:!1}),t.registerMessageType(q,{tier:1,wireCrossing:!1}),t.registerMessageType(ee,{tier:1,wireCrossing:!1,metaPassthrough:!1}),t.registerMessageType(te,{tier:2,wireCrossing:!1}),t.registerMessageType(se,{tier:2,wireCrossing:!1}),t.registerMessageType(F,{tier:3,wireCrossing:!0}),t.registerMessageType(J,{tier:3,wireCrossing:!0}),t.registerMessageType(z,{tier:4,wireCrossing:!0,metaPassthrough:!1}),t.registerMessageType(M,{tier:4,wireCrossing:!0,metaPassthrough:!1}),t.registerMessageType(H,{tier:5,wireCrossing:!0,metaPassthrough:!1})}var Fe,Vt=K(()=>{"use strict";le();Fe=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 pt(t){let e=Yn.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 Z,Yn,Ie=K(()=>{"use strict";Z=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}},Yn=["human","llm","wallet","system"]});function ht(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(ht);if(typeof t=="object"&&t!==null){let e={};for(let n of Object.keys(t).sort())e[n]=ht(t[n]);return e}return null}function Qn(t){let e=Zn.encode(t),n=e.length,r=n*8,s=n+9+63&-64,o=new Uint8Array(s);o.set(e),o[n]=128;let i=new DataView(o.buffer);i.setUint32(s-4,r>>>0,!1),i.setUint32(s-8,Math.floor(r/4294967296)>>>0,!1);let a=1779033703,u=3144134277,c=1013904242,d=2773480762,h=1359893119,p=2600822924,f=528734635,l=1541459225,b=new Uint32Array(64),g=(m,y)=>m>>>y|m<<32-y;for(let m=0;m<s;m+=64){for(let R=0;R<16;R++)b[R]=i.getUint32(m+R*4,!1);for(let R=16;R<64;R++){let T=b[R-15],S=b[R-2],A=g(T,7)^g(T,18)^T>>>3,B=g(S,17)^g(S,19)^S>>>10;b[R]=b[R-16]+A+b[R-7]+B>>>0}let y=a,v=u,k=c,x=d,_=h,O=p,E=f,C=l;for(let R=0;R<64;R++){let T=g(_,6)^g(_,11)^g(_,25),S=_&O^~_&E,A=C+T+S+Xn[R]+b[R]>>>0,B=g(y,2)^g(y,13)^g(y,22),$=y&v^y&k^v&k,U=B+$>>>0;C=E,E=O,O=_,_=x+A>>>0,x=k,k=v,v=y,y=A+U>>>0}a=a+y>>>0,u=u+v>>>0,c=c+k>>>0,d=d+x>>>0,h=h+_>>>0,p=p+O>>>0,f=f+E>>>0,l=l+C>>>0}let w=m=>m.toString(16).padStart(8,"0");return w(a)+w(u)+w(c)+w(d)+w(h)+w(p)+w(f)+w(l)}function gt(t){let e=ht(t??null),n=JSON.stringify(e);return Qn(n).slice(0,16)}function er(){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 mt(t,e,n){let r=n?.id??er();if(t===0)return{id:r,version:0};let o=(n?.hash??gt)(e);return{id:r,version:0,cid:o,prev:null}}function Bt(t,e,n){t.version+=1,"cid"in t&&(t.prev=t.cid,t.cid=n(e))}var Xn,Zn,Ht=K(()=>{"use strict";Xn=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]),Zn=new TextEncoder});function Ut(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 je(t){return t.length===0?t:typeof t[0]=="symbol"?[t]:t}function fe(t,e,n){let r=Kt(t)?t:[],s=typeof t=="function"?t:typeof e=="function"?e:void 0,o={};return Kt(t)?o=(bt(e)?e:n)??{}:bt(t)?o=t:o=(bt(e)?e:n)??{},new I(r,s,o)}var zt,Wt,tr,nr,_e,I,Kt,bt,xe=K(()=>{"use strict";at();ct();Le();Te();Vt();Ie();le();Ht();zt=()=>{},Wt=100;tr=(t,e,n,r)=>{n.direction==="down-in"&&t._onDepMessage(n.depIndex,e)},nr=(t,e,n,r)=>{let s=t;if(s._status==="completed"||s._status==="errored")return;let o=s._cached,i=o===void 0?[dt]:[dt,[F,o]];s._status==="dirty"&&i.push(we),Pe(e,i,s._config.tierOf)},_e=new Fe({onMessage:tr,onSubscribe:nr});jt(_e);$t(_e);I=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??_e,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??gt;let s=r.versioning??this._config.defaultVersioning;this._versioningLevel=s,this._versioning=s!=null?mt(s,this._cached===void 0?void 0:this._cached,{id:r.versioningId,hash:this._hashFn}):void 0,this._deps=e.map(Ut);let o={};for(let[a,u]of Object.entries(r.meta??{})){let c={initial:u,name:`${r.name??"node"}:meta:${a}`,describeKind:"state",config:this._config};r.guard!=null&&(c.guard=r.guard),o[a]=new t([],void 0,c)}Object.freeze(o),this.meta=o,this._hasMeta=Object.keys(o).length>0;let i=this;this._actions={emit(a){i._emit([[F,a]])},down(a){i._emit(je(a))},up(a){i._emitUp(je(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 s=n?.hash??this._hashFn;s!==this._hashFn&&(this._hashFn=s);let o=this._cached===void 0?void 0:this._cached,i=this._versioning,a=i?.id??n?.id,u=i?.version??0,c=mt(e,o,{id:a,hash:s});c.version=u,this._versioning=c,this._versioningLevel=e}_setInspectorHook(e){return e==null?()=>{}:(this._inspectorHooks==null&&(this._inspectorHooks=new Set),this._inspectorHooks.add(e),()=>{this._inspectorHooks?.delete(e),this._inspectorHooks?.size===0&&(this._inspectorHooks=void 0)})}_pushGuard(e){return this._extraGuards==null&&(this._extraGuards=new Set),this._extraGuards.add(e),()=>{this._extraGuards?.delete(e),this._extraGuards?.size===0&&(this._extraGuards=void 0)}}allowsObserve(e){if(this._guard==null&&this._extraGuards==null)return!0;let n=De(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 s=De(e?.actor),o=e?.delivery==="signal"?"signal":"write";if(this._guard!=null&&!this._guard(s,o))throw new Z({actor:s,action:o,nodeName:this.name});if(this._extraGuards!=null){for(let i of this._extraGuards)if(!i(s,o))throw new Z({actor:s,action:o,nodeName:this.name})}this._lastMutation={actor:s,timestamp_ns:ve()}}down(e,n){let r=je(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=je(e);if(r.length===0)return;this._checkGuard(n);let s=n??{internal:!0};this._validateUpTiers(r);for(let o of this._deps)o.node.up?.(r,s)}_emitUp(e){if(this._deps.length!==0&&e.length!==0){this._validateUpTiers(e);for(let n of this._deps)n.node.up?.(e,{internal:!0})}}_validateUpTiers(e){let n=this._config.tierOf;for(let r of e){let s=n(r[0]);if(s===3||s===4)throw new Error(`Node "${this.name}": tier-${s} messages cannot flow up \u2014 DATA/RESOLVED/COMPLETE/ERROR are downstream-only. Use \`down(...)\` for value delivery; \`up(...)\` is for control signals (DIRTY, INVALIDATE, PAUSE, RESUME, TEARDOWN).`)}}subscribe(e,n){if(n!=null&&this._guard!=null){let u=De(n);if(!this._guard(u,"observe"))throw new Z({actor:u,action:"observe",nodeName:this.name})}let s=this._isTerminal&&this._resubscribable;if(s){this._cached=void 0,this._status="sentinel",this._store={},this._hasCalledFnOnce=!1,this._waveHasNewData=!1,this._hasNewTerminal=!1,this._paused=!1,this._pendingWave=!1,this._pendingRerun=!1,this._isExecutingFn=!1,this._rerunDepth=0,this._dirtyDepCount=0,this._pauseLocks=null,this._pauseBuffer=null;for(let u of this._deps)yt(u);if(this._partial===!1){for(let u of this._deps)if(u.prevData!==void 0||u.dataBatch.length!==0||u.terminal!==void 0||u.dirty)throw new Error(`resubscribable-reset invariant: DepRecord not fully reset for node ${this._optsName??"(anonymous)"}`)}}this._sinkCount+=1;let o;try{o=this._config.onSubscribe(this,e,{sinkCount:this._sinkCount,afterTerminalReset:s},this._actions)}catch(u){throw this._sinkCount-=1,u}this._sinks==null?this._sinks=e:typeof this._sinks=="function"?this._sinks=new Set([this._sinks,e]):this._sinks.add(e);let i=this._isTerminal;if(this._sinkCount===1&&!i)try{this._activate()}catch(u){if(this._sinkCount-=1,this._removeSink(e),this._sinkCount===0&&(this._status="sentinel"),typeof o=="function")try{o()}catch{}throw u}this._status==="sentinel"&&this._cached===void 0&&(this._status="pending");let a=!1;return()=>{a||(a=!0,this._sinkCount-=1,this._removeSink(e),typeof o=="function"&&o(),this._sinks==null&&this._deactivate())}}_removeSink(e){if(this._sinks===e)this._sinks=null;else if(this._sinks!=null&&typeof this._sinks!="function")if(this._sinks.delete(e),this._sinks.size===1){let[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 s=r,o=this._deps[r];o.unsub=zt,o.unsub=o.node.subscribe(i=>{if(o.unsub===null)return;let a=this._config.tierOf,u=!1;for(let c of i)a(c[0])>=3&&(u=!0),this._config.onMessage(this,c,{direction:"down-in",depIndex:s},this._actions);u&&this._maybeRunFnOnSettlement()}),n++}}catch(r){this._deps[n].unsub=null;for(let s=0;s<n;s++){let o=this._deps[s];if(o.unsub!=null){let i=o.unsub;o.unsub=null;try{i()}catch{}yt(o)}}throw this._dirtyDepCount=0,r}}_addDep(e){for(let s=0;s<this._deps.length;s++)if(this._deps[s].node===e)return s;let n=this._deps.length,r=Ut(e);if(this._deps.push(r),this._sinks==null)return n;r.dirty=!0,this._dirtyDepCount++,this._status!=="dirty"&&this._emit(lt),r.unsub=zt;try{r.unsub=e.subscribe(s=>{if(r.unsub===null)return;let o=this._config.tierOf,i=!1;for(let a of s)o(a[0])>=3&&(i=!0),this._config.onMessage(this,a,{direction:"down-in",depIndex:n},this._actions);i&&this._maybeRunFnOnSettlement()})}catch(s){throw r.unsub=null,this._deps.pop(),this._dirtyDepCount--,s}return n}_deactivate(e=!1){let n=this._cleanup;if(this._cleanup=void 0,typeof n=="function")try{n()}catch(r){this._emit([[M,this._wrapFnError("cleanup threw",r)]])}else if(n!=null&&typeof n=="object"){let r=n.deactivate;if(typeof r=="function")try{r()}catch(s){this._emit([[M,this._wrapFnError("cleanup.deactivate threw",s)]])}}for(let r of this._deps){if(r.unsub!=null){let s=r.unsub;r.unsub=null;try{s()}catch{}}yt(r)}this._waveHasNewData=!1,this._hasNewTerminal=!1,this._hasCalledFnOnce=!1,this._paused=!1,this._pendingWave=!1,this._pendingRerun=!1,this._rerunDepth=0,this._store={},this._dirtyDepCount=0,this._pauseLocks=null,this._pauseBuffer=null,this._fn!=null&&(this._cached=void 0),e||(this._fn!=null||this._deps.length>0)&&(!this._isTerminal||this._resubscribable)&&(this._status="sentinel")}_onDepMessage(e,n){let r=this._deps[e],s=n[0];if(this._inspectorHooks!=null){let o={kind:"dep_message",depIndex:e,message:n};for(let i of this._inspectorHooks)i(o)}if(s!==Ee){if(s===q){this._depDirtied(r);return}if(s===ee){if(this._depInvalidated(r),this._cached===void 0)return;this._emit(Ft);return}if(s===te||s===se){this._emit([n]);return}if(s===H){this._emit(ft);return}if(s===F)this._depSettledAsData(r,n[1]);else if(s===J)this._depSettledAsResolved(r);else if(s===z)this._depSettledAsTerminal(r,!0);else if(s===M)this._depSettledAsTerminal(r,n[1]);else{this._emit([n]);return}if(!this._fn){(s===F||s===J)&&this._emit([n]),(s===z||s===M)&&this._maybeAutoTerminalAfterWave();return}}}_depDirtied(e){e.dirty||(e.dirty=!0,e.involvedThisWave=!0,this._dirtyDepCount++,this._status!=="dirty"&&this._emit(lt))}_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(Lt),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([[M,e.terminal]]);return}this._autoComplete&&this._deps.every(n=>n.terminal!==void 0)&&this._emit(It)}_execFn(){if(!this._fn||this._isTerminal&&!this._resubscribable)return;if(this._isExecutingFn){this._pendingRerun=!0;return}let e=this._cleanup;if(typeof e=="function"){this._cleanup=void 0;try{e()}catch(i){this._emit([[M,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([[M,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 s=this._deps.map(i=>i.terminal),o={prevData:r,terminalDeps:s,store:this._store};if(this._hasCalledFnOnce=!0,this._clearWaveFlags(),this._inspectorHooks!=null){let i={kind:"run",batchData:n,prevData:r};for(let a of this._inspectorHooks)a(i)}this._isExecutingFn=!0;try{let i=this._fn(n,this._actions,o);if(typeof i=="function")this._cleanup=i;else if(i!=null&&typeof i=="object"){let a=i;(typeof a.beforeRun=="function"||typeof a.deactivate=="function"||typeof a.invalidate=="function")&&(this._cleanup=i)}}catch(i){this._emit([[M,this._wrapFnError("fn threw",i)]])}finally{this._isExecutingFn=!1,this._pendingRerun?(this._pendingRerun=!1,this._rerunDepth+=1,this._rerunDepth>Wt?(this._rerunDepth=0,this._emit([[M,new Error(`Node "${this.name}": _pendingRerun depth exceeded ${Wt} \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"?[we,e[0]]:e;let r=!0,s=!1,o=!1,i=-1;for(let u of e){let c=n(u[0]);c<i&&(r=!1),c===3&&(s=!0),u[0]===q&&(o=!0),i=c}let a=e;if(!r){let u=e.map((c,d)=>({m:c,i:d,tier:n(c[0])}));u.sort((c,d)=>c.tier-d.tier||c.i-d.i),a=u.map(c=>c.m)}if(s&&!o&&this._status!=="dirty"){let u=0;for(;u<a.length&&n(a[u][0])===0;)u++;return u===0?[we,...a]:[...a.slice(0,u),we,...a.slice(u)]}return a}_emit(e){if(e.length===0)return;for(let a=0;a<e.length;a++){let u=e[a];if(u[0]===M&&u[1]===void 0)throw new TypeError('[ERROR, payload] requires a non-undefined payload (spec \xA71.2). Pass an Error object or domain tag instead \u2014 e.g. node.down([[ERROR, new Error("reason")]])')}let n=e;if(this._isTerminal&&!this._resubscribable){let a=e.filter(u=>u[0]===H||u[0]===ee);if(a.length===0)return;n=a}n=this._frameBatch(n);let s=null;for(let a=0;a<n.length;a++){let u=n[a],c=u[0];if(c!==te&&c!==se){s?.push(u);continue}if(u.length<2)throw new Error(`Node "${this.name}": [[${c===te?"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 h=u[1];if(c===te)this._pauseLocks==null&&(this._pauseLocks=new Set),this._pauseLocks.add(h),this._paused=!0,this._pausable==="resumeAll"&&this._pauseBuffer==null&&(this._pauseBuffer=[]);else if(this._pauseLocks==null||!this._pauseLocks.has(h))d=!1;else if(this._pauseLocks.delete(h),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?s?.push(u):s==null&&(s=n.slice(0,a))}if(s!=null){if(s.length===0)return;n=s}if(this._hasMeta&&n.some(a=>a[0]===H))for(let a of Object.keys(this.meta))try{this.meta[a]._emit(ft)}catch{}let{finalMessages:o,equalsError:i}=this._updateState(n);if(o.length>0&&this._config.inspectorEnabled){let a=this._config.globalInspector;if(a!=null)try{a({kind:"emit",node:this,messages:o})}catch{}}if(o.length>0)if(this._paused&&this._pausable==="resumeAll"&&this._pauseBuffer!=null){let a=this._config.tierOf,u=[];for(let c of o)a(c[0])===3?this._pauseBuffer.push(c):u.push(c);u.length>0&&this._dispatchOrAccumulate(u)}else this._dispatchOrAccumulate(o);i!=null&&this._emit([[M,i]])}_updateState(e){let n=this._config.tierOf,r,s,o=-1,i=0;for(let d of e)n(d[0])===3&&i++;let a=i<=1,u=-1;if(this._versioning!=null&&i>1){for(let d=e.length-1;d>=0;d--)if(e[d][0]===F){u=d;break}}for(let d=0;d<e.length;d++){let h=e[d],p=h[0];if(p===F){if(h.length>=2){let f=!1;if(a&&this._cached!==void 0)try{f=this._equals(this._cached,h[1])}catch(l){s=this._wrapFnError("equals threw",l),o=d;break}if(f){r==null&&(r=e.slice(0,d)),r.push(ut),this._status="resolved";continue}this._cached=h[1],this._versioning!=null&&(u<0||d===u)&&Bt(this._versioning,h[1],this._hashFn)}this._status="settled",r?.push(h)}else if(r?.push(h),p===q)this._status="dirty";else if(p===J)this._status="resolved";else if(p===z){this._status="completed";{let f=this._config.rigorRecorder;if(f!=null)try{f.onTerminalTransition(this,"completed",this._autoComplete,this._autoError,this._deps.length>0)}catch{}}}else if(p===M){this._status="errored";{let f=this._config.rigorRecorder;if(f!=null)try{f.onTerminalTransition(this,"errored",this._autoComplete,this._autoError,this._deps.length>0)}catch{}}}else if(p===ee){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 f=this._cleanup;if(typeof f=="function"){this._cleanup=void 0;try{f()}catch{}}else if(f!=null&&typeof f=="object"){let l=f.invalidate;if(typeof l=="function")try{l()}catch{}}}else p===H&&(this._resetOnTeardown&&(this._cached=void 0),this._deactivate(!0),this._status="sentinel")}let c=o>=0?r??e.slice(0,o):r??e;return s!=null?{finalMessages:c,equalsError:s}:{finalMessages:c}}_deliverToSinks=e=>{if(this._sinks==null)return;if(typeof this._sinks=="function"){this._sinks(e);return}let n=[...this._sinks];for(let r of n)r(e)};_dispatchOrAccumulate(e){if(Pt()){this._batchPendingMessages===null&&(this._batchPendingMessages=[],be(()=>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)}},Kt=t=>Array.isArray(t),bt=t=>typeof t=="object"&&t!=null&&!Array.isArray(t)});function re(t,e){return fe([],{...e,initial:t})}function Se(t,e){return fe((r,s,o)=>t(s,o)??void 0,{describeKind:"producer",...e})}function pe(t,e,n){return fe(t,(s,o,i)=>{let a=s.map((u,c)=>u!=null&&u.length>0?u.at(-1):i.prevData[c]);o.emit(e(a,i))},{describeKind:"derived",...n})}function Ve(t,e,n){return fe(t,(s,o,i)=>{let a=s.map((u,c)=>u!=null&&u.length>0?u.at(-1):i.prevData[c]);return e(a,o,i)??void 0},{describeKind:"effect",...n})}var Be=K(()=>{"use strict";xe()});function He(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"]);default:return new Set(["type","deps"])}}function rr(t){return t._describeKind!=null?t._describeKind:t._deps.length>0?"derived":t._fn!=null?"producer":"state"}function or(t){let e={};for(let[n,r]of Object.entries(t.meta))try{e[n]=r.cache}catch{}return e}function vt(t,e){let n=e==null,r=!n&&e!=null?[...e].filter(c=>c.startsWith("meta.")).map(c=>c.slice(5)):null,s=n||e.has("meta")||r!=null&&r.length>0,o="state",i=[];t instanceof I&&(o=rr(t),i=t._deps.map(c=>c.node.name??""));let a={type:o,deps:i};(n||e.has("status"))&&(a.status=t.status);let u=t instanceof I?t._guard:void 0;if(s){let c={...or(t)};if(u!=null&&c.access===void 0&&(c.access=pt(u)),r!=null&&r.length>0&&!e.has("meta")){let d={};for(let h of r)h in c&&(d[h]=c[h]);a.meta=d}else a.meta=c}if(t.name!=null&&(a.name=t.name),n||e.has("value")){t.status==="sentinel"&&(a.sentinel=!0);try{a.value=t.cache}catch{}}if((n||e.has("v"))&&t.v!=null){let c={id:t.v.id,version:t.v.version};"cid"in t.v&&(c.cid=t.v.cid,c.prev=t.v.prev),a.v=c}return(n||e.has("guard"))&&u!=null&&(a.guard=pt(u)),(n||e.has("lastMutation"))&&t.lastMutation!=null&&(a.lastMutation=t.lastMutation),a}var qt=K(()=>{"use strict";Ie();xe()});function he(t){return t.subscribe(()=>{})}var xt=K(()=>{"use strict"});var ze,Yt=K(()=>{"use strict";ze=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 uo={};Bn(uo,{SNAPSHOT_WIRE_VERSION:()=>At,SurfaceError:()=>G,asSurfaceError:()=>Gn,createGraph:()=>Qe,deleteSnapshot:()=>Fn,diffSnapshots:()=>Pn,listSnapshots:()=>Ln,restoreSnapshot:()=>$n,runReduction:()=>Dn,saveSnapshot:()=>Mn});module.exports=zn(uo);Be();ct();Le();Te();Ie();le();qt();xe();Be();Te();function wt(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 o=0;o<t.length;o++)if(!wt(t[o],e[o]))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 s=new Set(r);for(let o of n)if(!s.has(o)||!wt(t[o],e[o]))return!1;return!0}function Jt(t,e){return`${t}\0${e}`}function _t(t,e){let n=[],r=new Set(t.subgraphs),s=new Set(e.subgraphs),o=[];for(let g of s)r.has(g)||o.push(g);o.sort();for(let g of o)n.push({type:"subgraph-mounted",path:g});let i=new Set(Object.keys(t.nodes)),a=new Set(Object.keys(e.nodes)),u=[];for(let g of a)i.has(g)||u.push(g);u.sort();for(let g of u)n.push({type:"node-added",path:g,node:{...e.nodes[g]}});let c=[];for(let g of a){if(!i.has(g))continue;let w=t.nodes[g]?.meta,m=e.nodes[g]?.meta;w==null&&m==null||wt(w??{},m??{})||c.push(g)}c.sort();for(let g of c)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(Jt(g.from,g.to),g);let h=new Map;for(let g of e.edges)h.set(Jt(g.from,g.to),g);let p=[];for(let[g,w]of h)d.has(g)||p.push(w);p.sort((g,w)=>g.from<w.from?-1:g.from>w.from?1:g.to<w.to?-1:g.to>w.to?1:0);for(let g of p)n.push({type:"edge-added",from:g.from,to:g.to});let f=[];for(let[g,w]of d)h.has(g)||f.push(w);f.sort((g,w)=>g.from<w.from?-1:g.from>w.from?1:g.to<w.to?-1:g.to>w.to?1:0);for(let g of f)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)s.has(g)||b.push(g);b.sort();for(let g of b)n.push({type:"subgraph-unmounted",path:g});return{events:n,flushedAt_ns:oe()}}xt();Yt();var Re=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}};at();function St(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 We(t){let e=0;for(let n of t)e+=St(n.codePointAt(0));return e}function Xt(t,e){if(e<=0)return"";let n=0,r="";for(let s of t){let o=St(s.codePointAt(0));if(n+o>e){if(e<=1)return"\u2026";for(;n+1>e&&r.length>0;){let i=[...r].pop();r=r.slice(0,-i.length),n-=St(i.codePointAt(0))}return`${r}\u2026`}r+=s,n+=o}return r}var sr={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"},ir={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"?ir:sr,r=t.width,s=t.height,o=Array.from({length:s},()=>Array.from({length:r},()=>" ")),i=Array.from({length:s},()=>Array.from({length:r},()=>"empty"));for(let a of t.edges)cr(o,i,n,a);for(let a of t.boxes)ar(o,i,n,a,e.labelOf(a.id));return o.map(a=>fr(a.join(""))).join(`
|
|
2
|
-
`)}function ar(t,e,n,r,s){let{x:o,y:i,w:a,h:u}=r;if(a<2||u<2){u>0&&Zt(t,e,o,i,a,s);return}ae(t,e,o,i,n.boxTL);for(let d=o+1;d<o+a-1;d+=1)ae(t,e,d,i,n.boxH);ae(t,e,o+a-1,i,n.boxTR);for(let d=i+1;d<i+u-1;d+=1){ae(t,e,o,d,n.boxV);for(let h=o+1;h<o+a-1;h+=1)nn(t,e,h,d," ","empty");ae(t,e,o+a-1,d,n.boxV)}ae(t,e,o,i+u-1,n.boxBL);for(let d=o+1;d<o+a-1;d+=1)ae(t,e,d,i+u-1,n.boxH);ae(t,e,o+a-1,i+u-1,n.boxBR);let c=i+Math.floor(u/2);Zt(t,e,o+1,c,a-2,s)}function ae(t,e,n,r,s){nn(t,e,n,r,s,s===" "?"empty":s==="\u2500"||s==="-"?"boxH":s==="\u2502"||s==="|"?"boxV":"boxCorner")}function nn(t,e,n,r,s,o){if(r<0||r>=t.length)return;let i=t[r];n<0||n>=i.length||(i[n]=s,e[r][n]=o)}function Zt(t,e,n,r,s,o){if(r<0||r>=t.length)return;let i=n,a=s;for(let u of o){let c=We(u);if(c!==0){if(a<c)break;i>=0&&i<t[r].length&&(t[r][i]=u,e[r][i]="label",c===2&&i+1<t[r].length&&(t[r][i+1]="",e[r][i+1]="label")),i+=c,a-=c}}for(;a>0;)i>=0&&i<t[r].length&&(t[r][i]=" ",e[r][i]="empty"),i+=1,a-=1}function cr(t,e,n,r){let s=r.points;if(s.length<2)return;for(let u=0;u+1<s.length;u+=1)ur(t,e,n,s[u],s[u+1]);for(let u=1;u+1<s.length;u+=1){let c=s[u-1],d=s[u],h=s[u+1],p=dr(c,d,h,n);p&&en(t,e,d.x,d.y,p,"edgeCorner")}let o=s[s.length-1],i=s[s.length-2],a=lr(i,o,n);a&&en(t,e,o.x,o.y,a,"arrow")}function ur(t,e,n,r,s){if(!(r.x===s.x&&r.y===s.y)){if(r.y===s.y){let o=r.y,i=Math.min(r.x,s.x),a=Math.max(r.x,s.x);for(let u=i;u<=a;u+=1)Qt(t,e,u,o,n,"h")}else if(r.x===s.x){let o=r.x,i=Math.min(r.y,s.y),a=Math.max(r.y,s.y);for(let u=i;u<=a;u+=1)Qt(t,e,o,u,n,"v")}}}function Qt(t,e,n,r,s,o){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]=o==="h"?s.horizontal:s.vertical,e[r][n]=o==="h"?"edgeH":"edgeV";return}if(a==="edgeH"&&o==="v"){i[n]=s.cross,e[r][n]="edgeCorner";return}if(a==="edgeV"&&o==="h"){i[n]=s.cross,e[r][n]="edgeCorner";return}}}function en(t,e,n,r,s,o){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]=s,e[r][n]=o)}function dr(t,e,n,r){let s=t.y===e.y,o=e.y===n.y;if(s===o)return;if(s){let u=t.x<e.x,c=n.y>e.y;return u&&c?r.cornerTR:u&&!c?r.cornerBR:!u&&c?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 lr(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 fr(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=pr(t);hr(e),gr(e),mr(e),yr(e,t);let n=wr(e,t),{width:r,height:s}=xr(e),o=[];for(let i of e.layers)for(let a of i)a.isVirtual||o.push({id:a.id,layer:a.layer,order:a.order,x:a.x,y:a.y,w:a.w,h:a.h});return{boxes:o,edges:n,width:r,height:s}}function pr(t){let e=new Map;for(let s of t.nodes)e.set(s,{id:s,isVirtual:!1,layer:-1,order:0,x:0,y:0,w:t.widthCells(s),h:t.heightCells(s),in:[],out:[]});let n=[],r=0;for(let s of t.edges){if(s.from===s.to)continue;let o=e.get(s.from),i=e.get(s.to);if(!o||!i)continue;let a={chainId:r++,chainFrom:s.from,chainTo:s.to,fromId:s.from,toId:s.to,hopIndex:0,chainLen:1};o.out.push(a),i.in.push(a),n.push(a)}return{nodes:e,layers:[],hops:n}}function hr(t){let e=new Map;for(let o of t.nodes.values())e.set(o.id,o.in.length);let n=[];for(let o of t.nodes.values())(e.get(o.id)??0)===0&&(o.layer=0,n.push(o));let r=new Set,s=0;for(;s<n.length;){let o=n[s++];if(!r.has(o.id)){r.add(o.id);for(let i of o.out){let a=t.nodes.get(i.toId);a.layer=Math.max(a.layer,o.layer+1);let u=(e.get(a.id)??0)-1;e.set(a.id,u),u<=0&&n.push(a)}}}for(let o of t.nodes.values())o.layer<0&&(o.layer=0)}function gr(t){let e=Math.max(0,...Array.from(t.nodes.values(),o=>o.layer)),n=Array.from({length:e+1},()=>[]);for(let o of t.nodes.values())n[o.layer].push(o);let r=[],s=0;for(let o of t.hops){let i=t.nodes.get(o.fromId),a=t.nodes.get(o.toId),u=a.layer-i.layer;if(u<=0){i.out=i.out.filter(h=>h!==o),a.in=a.in.filter(h=>h!==o);continue}if(u===1){o.hopIndex=0,o.chainLen=1,r.push(o);continue}i.out=i.out.filter(h=>h!==o),a.in=a.in.filter(h=>h!==o);let c=i;for(let h=1;h<u;h+=1){let p=`__virt_${s++}__`,f={id:p,isVirtual:!0,layer:i.layer+h,order:0,x:0,y:0,w:0,h:1,in:[],out:[]};t.nodes.set(p,f),n[f.layer].push(f);let l={chainId:o.chainId,chainFrom:o.chainFrom,chainTo:o.chainTo,fromId:c.id,toId:p,hopIndex:h-1,chainLen:u};c.out.push(l),f.in.push(l),r.push(l),c=f}let d={chainId:o.chainId,chainFrom:o.chainFrom,chainTo:o.chainTo,fromId:c.id,toId:a.id,hopIndex:u-1,chainLen:u};c.out.push(d),a.in.push(d),r.push(d)}for(let o of n)for(let i=0;i<o.length;i+=1)o[i].order=i;t.layers=n,t.hops=r}function mr(t){for(let n=0;n<4;n+=1){for(let r=1;r<t.layers.length;r+=1)rn(t,t.layers[r],"in"),Ue(t.layers[r]);for(let r=t.layers.length-2;r>=0;r-=1)rn(t,t.layers[r],"out"),Ue(t.layers[r])}for(let n=0;n<2;n+=1){let r=!1;for(let s=1;s<t.layers.length;s+=1){let o=t.layers[s];for(let i=0;i+1<o.length;i+=1){let a=on(t,o[i],o[i+1],"in");[o[i],o[i+1]]=[o[i+1],o[i]],Ue(o),on(t,o[i],o[i+1],"in")<a?r=!0:([o[i],o[i+1]]=[o[i+1],o[i]],Ue(o))}}if(!r)break}}function rn(t,e,n){let r=new Map;for(let s of e){let o=n==="in"?s.in:s.out;if(o.length===0){r.set(s.id,s.order);continue}let i=0,a=0;for(let u of o){let c=t.nodes.get(n==="in"?u.fromId:u.toId);c&&(i+=c.order,a+=1)}r.set(s.id,a===0?s.order:i/a)}e.sort((s,o)=>{let i=r.get(s.id),a=r.get(o.id);return i!==a?i-a:s.order-o.order})}function Ue(t){for(let e=0;e<t.length;e+=1)t[e].order=e}function on(t,e,n,r){let s=r==="in"?e.in:e.out,o=r==="in"?n.in:n.out,i=0;for(let a of s)for(let u of o){let c=t.nodes.get(r==="in"?a.fromId:a.toId)?.order??0,d=t.nodes.get(r==="in"?u.fromId:u.toId)?.order??0;(e.order<n.order&&c>d||e.order>n.order&&c<d)&&(i+=1)}return i}function yr(t,e){e.direction==="LR"?br(t,e):vr(t,e)}function br(t,e){let n=[],r=0;for(let s=0;s<t.layers.length;s+=1){n.push(r);let o=0;for(let i of t.layers[s])o=Math.max(o,i.w);r+=o+e.layerGap}for(let s=0;s<t.layers.length;s+=1)for(let o of t.layers[s])o.x=n[s];for(let s of t.layers){let o=0;for(let i of s)i.y=o,o+=i.h+e.nodeGap}an(t,e,"y")}function vr(t,e){let n=[],r=0;for(let s=0;s<t.layers.length;s+=1){n.push(r);let o=0;for(let i of t.layers[s])o=Math.max(o,i.h);r+=o+e.layerGap}for(let s=0;s<t.layers.length;s+=1)for(let o of t.layers[s])o.y=n[s];for(let s of t.layers){let o=0;for(let i of s)i.x=o,o+=i.w+e.nodeGap}an(t,e,"x")}function an(t,e,n){let r=o=>n==="y"?o.h:o.w,s=e.nodeGap;for(let o=0;o<2;o+=1){let i=o===0?t.layers.slice(1):t.layers.slice(0,-1).reverse();for(let a of i){let u=new Map;for(let d of a){let h=o===0?d.in:d.out;if(h.length===0)continue;let p=[];for(let l of h){let b=t.nodes.get(o===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 f=p[Math.floor(p.length/2)];u.set(d.id,f-Math.floor(r(d)/2))}let c=0;for(let d of a){let h=u.get(d.id),p=n==="y"?d.y:d.x,l=Math.max(h??p,c);n==="y"?d.y=l:d.x=l,c=l+r(d)+s}}}}function wr(t,e){let n=new Map;for(let c of t.hops){let d=n.get(c.chainId);d?d.push(c):n.set(c.chainId,[c])}for(let c of n.values())c.sort((d,h)=>d.hopIndex-h.hopIndex);let r=e.direction==="LR",s=c=>r?c.x:c.y,o=c=>r?c.w:c.h,i=c=>r?c.y+Math.floor(c.h/2):c.x+Math.floor(c.w/2),a=new Map;for(let c=0;c+1<t.layers.length;c+=1){let d=t.layers[c],h=t.layers[c+1],p=0;for(let O of d)p=Math.max(p,s(O)+o(O));let f=Number.POSITIVE_INFINITY;for(let O of h)f=Math.min(f,s(O));let l=Number.isFinite(f)?f-1:p,b=Math.max(1,l-p+1),g=[];for(let O of d)for(let E of O.out)g.push(E);g.sort((O,E)=>{let C=i(t.nodes.get(O.fromId)),R=i(t.nodes.get(E.fromId));if(C!==R)return C-R;let T=i(t.nodes.get(O.toId)),S=i(t.nodes.get(E.toId));return T-S});let w=[],m=new Map;for(let O of g){let E=i(t.nodes.get(O.fromId)),C=i(t.nodes.get(O.toId)),R=Math.min(E,C),T=Math.max(E,C),S=-1;for(let A=0;A<w.length;A+=1){let B=w[A],$=!0;for(let U of B)if(U.lo<=T&&R<=U.hi){$=!1;break}if($){B.push({lo:R,hi:T}),S=A;break}}S<0&&(w.push([{lo:R,hi:T}]),S=w.length-1),m.set(O,S)}let y=w.length,v=b>=Math.max(3,y+2),k=v?p+1:p,x=v?l-1:l,_=Math.max(1,x-k+1);for(let O of g){let E=m.get(O),C;if(y<=1)C=k+Math.floor(_/2);else{let R=(_-1)/(y-1);C=k+Math.floor(E*R)}a.set(O,Math.max(p,Math.min(l,C)))}}let u=[];for(let[,c]of n){let d=[];for(let p=0;p<c.length;p+=1){let f=c[p],l=t.nodes.get(f.fromId),b=t.nodes.get(f.toId),g=a.get(f),w=l.isVirtual?s(l):s(l)+o(l),m=b.isVirtual?s(b):s(b)-1,y=i(l),v=i(b);p===0&&Ke(d,r,w,y),y!==v&&(Ke(d,r,g,y),Ke(d,r,g,v)),Ke(d,r,m,v)}let h=c[0];u.push({from:h.chainFrom,to:h.chainTo,points:_r(d)})}return u}function Ke(t,e,n,r){t.push(e?{x:n,y:r}:{x:r,y:n})}function _r(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 xr(t){let e=0,n=0;for(let r of t.layers)for(let s of r)e=Math.max(e,s.x+s.w),n=Math.max(n,s.y+s.h);return{width:e,height:n}}var Sr=24,kr=4,Or=1,Nr=3;function cn(t,e){let n=Tr(e.direction),r=Math.max(3,e.maxLabelWidth??Sr),s=e.asciiCharset??"unicode",o=Object.keys(t.nodes).sort(),i=new Set(o),a=t.edges.filter(f=>i.has(f.from)&&i.has(f.to)),u=new Map,c=new Map;for(let f of o){let l=Xt(f,r);u.set(f,l),c.set(f,We(l)+4)}let d=sn({nodes:o,edges:a,widthCells:f=>c.get(f)??3,heightCells:()=>Nr,layerGap:kr,nodeGap:Or,direction:n}),h=tn(d,{charset:s,labelOf:f=>u.get(f)??f}),p=e.logger;return p&&p(h),h}function Tr(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 un(t,e,n,r={}){let s=e in t.nodes,o=n in t.nodes;if(!s)return qe(e,n,"no-such-from");if(!o)return qe(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 c=Er(t,e,r);if(c!=null)return c}let u=Je(e,t.nodes[e],0,r);return Ye(e,n,[u])}if(i===0)return qe(e,n,"no-path");let a=dn(t,e,n,i);return a.found?Ye(e,n,ln(t,a.pathOrder,r)):qe(e,n,a.truncated?"max-depth-exceeded":"no-path")}function dn(t,e,n,r){let s=new Map,o=[{path:n,depth:0}],i=new Set([n]),a=0,u=!1;for(;a<o.length;){let h=o[a++];if(h.path===e)break;if(r!=null&&h.depth>=r){let b=t.nodes[h.path];b?.deps&&b.deps.length>0&&(u=!0);continue}let p=t.nodes[h.path];if(p==null)continue;let f=p.deps??[],l=new Map;for(let b=0;b<f.length;b++){let g=f[b];if(!g)continue;let w=l.get(g);w==null&&(w=[],l.set(g,w)),w.push(b)}for(let[b,g]of l)i.has(b)||(i.add(b),s.set(b,{from:h.path,depIndices:g}),o.push({path:b,depth:h.depth+1}))}if(!s.has(e))return{found:!1,pathOrder:[],truncated:u};let c=[{path:e}],d=e;for(;d!==n;){let h=s.get(d);if(h==null)return{found:!1,pathOrder:[],truncated:!1};c[c.length-1].depIndices=h.depIndices,c.push({path:h.from}),d=h.from}return{found:!0,pathOrder:c,truncated:!1}}function Er(t,e,n){let r=t.nodes[e];if(r==null)return null;let s=r.deps??[],o=[];for(let a=0;a<s.length;a++)s[a]===e&&o.push(a);if(o.length>0){let a=Je(e,r,0,n);a.dep_index=o[0];let u=Je(e,r,1,n);return Ye(e,e,[a,u])}let i=null;for(let a=0;a<s.length;a++){let u=s[a];if(!u||u===e)continue;let c=dn(t,u,e,n.maxDepth);c.found&&(i==null||c.pathOrder.length<i.pathOrder.length)&&(i=c,i={found:!0,pathOrder:[{path:e,depIndices:[a]},...c.pathOrder],truncated:!1})}return i==null?null:Ye(e,e,ln(t,i.pathOrder,n))}function ln(t,e,n){return e.map((r,s)=>{let o=t.nodes[r.path],i=Je(r.path,o,s,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 Je(t,e,n,r){let s={path:t,type:e.type,hop:n};e.status!==void 0&&(s.status=e.status),"value"in e&&(s.value=e.value),e.v!=null&&(s.v=e.v);let o=r.annotations?.get(t)??e.annotation;o!=null&&(s.annotation=o);let i=r.lastMutations?.get(t)??e.lastMutation;return i!=null&&(s.lastMutation=i),s}function Ye(t,e,n){return fn(t,e,!0,"ok",n)}function qe(t,e,n){return fn(t,e,!1,n,[])}function fn(t,e,n,r,s){let o=Rr(t,e,n,r,s);return{from:t,to:e,found:n,reason:r,steps:s,text:o,toJSON(){return{from:t,to:e,found:n,reason:r,steps:s}}}}function Rr(t,e,n,r,s){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 o=[`Causal path: ${t} \u2192 ${e} (${s.length} step(s))`];for(let i of s){let u=` ${i.hop===0?"\xB7":"\u2193"} ${i.path} (${i.type}${i.status?`/${i.status}`:""})`;if(o.push(u),"value"in i&&o.push(` value: ${Ar(i.value)}`),i.annotation!=null&&o.push(` annotation: ${i.annotation}`),i.lastMutation!=null){let c=i.lastMutation.actor;o.push(` actor: ${c.type}${c.id?`:${c.id}`:""}`)}}return o.join(`
|
|
3
|
-
`)}function Ar(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)}}xe();var j={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},Cr=Symbol.for("sizeof");function pn(t){let e=new WeakSet,n=new WeakSet,r=[t],s=0;for(;r.length>0;){let o=r.pop();s+=Gr(o,e,n,r)}return s}function Gr(t,e,n,r){if(t==null)return 0;switch(typeof t){case"number":return j.number;case"boolean":return j.boolean;case"string":return j.string+t.length*2;case"bigint":return j.bigint+Dr(t);case"symbol":return j.symbol;case"function":return e.has(t)?0:(e.add(t),j.function);case"undefined":return 0}let o=t;if(e.has(o))return 0;e.add(o);let i=o[Cr];if(typeof i=="function")try{let c=i.call(o);if(typeof c=="number"&&Number.isFinite(c))return c}catch{}if(o instanceof Date)return j.date;if(o instanceof RegExp)return j.regexp+o.source.length*2;if(o instanceof Error){let c=o.message?o.message.length*2:0,d=o.stack?o.stack.length*2:0;return j.error+c+d}if(typeof URL<"u"&&o instanceof URL)return j.url+o.href.length*2;if(typeof Promise<"u"&&o instanceof Promise)return j.promise;if(o instanceof WeakMap)return j.weakmap;if(o instanceof WeakSet)return j.weakset;if(o instanceof Map){let c=j.map;for(let[d,h]of o)c+=j.mapEntry,r.push(d),r.push(h);return c}if(o instanceof Set){let c=j.set;for(let d of o)c+=j.setEntry,r.push(d);return c}if(Array.isArray(o)){let c=j.array+o.length*8;for(let d of o)r.push(d);return c}if(o instanceof ArrayBuffer)return n.has(o)?0:(n.add(o),o.byteLength);if(ArrayBuffer.isView(o)){let c=o;return n.has(c.buffer)?48:(n.add(c.buffer),c.buffer.byteLength+48)}let a=j.object,u=Object.keys(o);for(let c of u){a+=j.string+c.length*2;try{r.push(o[c])}catch{}}return a}function Dr(t){let e=t<0n?-t:t;if(e===0n)return 0;let n=e.toString(2).length;return Math.ceil(n/32)*8}function hn(t,e){let n=e?.topN??10,r=t.describe({detail:"standard"}),s=[],o=t._collectObserveTargets;typeof o=="function"&&o.call(t,"",s);let i=new Map;for(let[p,f]of s)i.set(p,f);let a=[];for(let[p,f]of Object.entries(r.nodes)){let l=i.get(p),b=l instanceof I?l:null,g=b?pn(b.cache):0,w=b?b._sinkCount:0,m=f.deps?.length??0,y=f.type==="effect"&&w===0,v=w===0?f.type==="effect"?"orphan-effect":f.type==="derived"?"idle-derived":f.type==="producer"?"idle-producer":null:null;a.push({path:p,type:f.type,status:f.status??"unknown",valueSizeBytes:g,subscriberCount:w,depCount:m,isOrphanEffect:y,orphanKind:v})}let u=a.reduce((p,f)=>p+f.valueSizeBytes,0),c=(p,f)=>[...a].sort(f??((l,b)=>b[p]-l[p])).slice(0,n),d=a.filter(p=>p.orphanKind!=null),h=a.filter(p=>p.isOrphanEffect);return{nodeCount:a.length,edgeCount:r.edges.length,subgraphCount:r.subgraphs.length,nodes:a,totalValueSizeBytes:u,hotspots:{byValueSize:c("valueSizeBytes"),bySubscriberCount:c("subscriberCount"),byDepCount:c("depCount")},orphans:d,orphanEffects:h}}var L="::",Q="__meta__",ce=1;function gn(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 s=t.values().next();if(s.done)return;let o=s.value;t.delete(o);try{o()}catch(i){console.error(`[Graph "${e}".destroy] disposer threw:`,i)}}}function vn(t){return t!=null&&typeof t=="object"&&"cache"in t&&typeof t.subscribe=="function"&&typeof t.down=="function"}function Mr(t){if(t!=null)return vn(t)?t.cache:t}function $r(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(`
|
|
4
|
-
|
|
5
|
-
`)
|
|
6
|
-
`)}function Br(t,e){let n=xn(t,e);return Hr(n)}function Hr(t,e){let n=e?.theme??"default",r=e?.autoSync??!0,o=JSON.stringify({code:t,mermaid:{theme:n},autoSync:r}),i=new TextEncoder().encode(o),a="";for(let c=0;c<i.length;c++)a+=String.fromCharCode(i[c]);return`https://mermaid.live/edit#base64:${globalThis.btoa(a).replace(/\+/g,"-").replace(/\//g,"_").replace(/=+$/,"")}`}function zr(t,e){let n=_n(e.direction),r=Object.keys(t.nodes).sort(),s=new Map;for(let i=0;i<r.length;i+=1)s.set(r[i],`n${i}`);let o=[`direction: ${Ir(n)}`];for(let i of r){let a=s.get(i);o.push(`${a}: "${Fr(i)}"`)}for(let[i,a]of wn(t)){let u=s.get(i),c=s.get(a);!u||!c||o.push(`${u} -> ${c}`)}return o.join(`
|
|
7
|
-
`)}function Wr(t){return t.replace(/[.*+?^${}()|[\]\\]/g,"\\$&")}function Xe(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 s=t.indexOf("]",n+1);if(s<=n+1){e+="\\[";continue}let o=t.slice(n+1,s);o.startsWith("!")&&(o=`^${o.slice(1)}`),o=o.replace(/\\/g,"\\\\"),e+=`[${o}]`,n=s;continue}e+=Wr(r)}return e+="$",new RegExp(e)}var Ur={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"},Kr={data:"",dirty:"",resolved:"",invalidate:"",pause:"",resume:"",complete:"",error:"",teardown:"",derived:"",path:"",reset:""};function Ze(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 qr(t){return t==="none"?Kr:t==="ansi"||t==null?Ur:{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 yn(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 Jr(t,e,n){for(let r=0;r<t.length;r++){let s=t.charCodeAt(r);if(s<32||s===127)throw new Error(`Graph "${e}": ${n} "${t}" must not contain control character (U+${s.toString(16).padStart(4,"0").toUpperCase()} at index ${r})`)}}function kt(t,e,n){if(t==="")throw new Error(`Graph "${e}": ${n} name must be non-empty`);if(t.includes(L))throw new Error(`Graph "${e}": ${n} "${t}" must not contain '${L}' (path separator)`);if(t===Q)throw new Error(`Graph "${e}": ${n} name "${Q}" is reserved for meta companion paths`);Jr(t,e,n)}function Yr(t,e){if(t==="")throw new Error(`Graph "${e}": resolve path must be non-empty`);let n=t.split(L);for(let r of n)if(r==="")throw new Error(`Graph "${e}": resolve path has empty segment`);return n}function Xr(t,e){let n=!1;for(let s of t)if(!e.isMetaPassthrough(s[0])){n=!0;break}return n?t.filter(s=>e.isMetaPassthrough(s[0])):t}function Sn(t){for(let e of t._mounts.values())Sn(e);for(let e of t._nodes.values())try{e.down([[H]],{internal:!0})}catch{}}var ie=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(L))throw new Error(`Graph name must not contain '${L}' (got "${e}")`);if(e===Q)throw new Error(`Graph name "${Q}" is reserved for meta companion paths`);this.name=e,this.opts=Object.freeze({...n??{}}),this.config=n?.config??_e,this._traceRing=new Re(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=Se(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,s=n?.name??r;if(s==null||s==="")throw new Error(`Graph "${this.name}": graph.add requires a non-empty name \u2014 pass via opts.name or set it on the node (e.g. state(0, { name: "x" }))`);let o=s,i=n?.annotation;if(kt(o,this.name,"add"),this._mounts.has(o))throw new Error(`Graph "${this.name}": name "${o}" is already a mount point`);if(this._nodes.has(o))throw new Error(`Graph "${this.name}": node "${o}" already exists`);let a=this._nodeToName.get(e);if(a!==void 0)throw new Error(`Graph "${this.name}": node instance already registered as "${a}"`);return this._nodes.set(o,e),this._nodeToName.set(e,o),this._emitTopology({kind:"added",name:o,nodeKind:"node"}),i!=null&&(this._annotations.set(o,i),this.config.inspectorEnabled&&this._traceRing.push({path:o,annotation:i,timestamp_ns:oe()})),e}setVersioning(e){if(e!=null)for(let n of this._nodes.values())n instanceof I&&n._applyVersioning(e)}remove(e){kt(e,this.name,"remove");let n=this._mounts.get(e);if(n){let o={kind:"mount",nodes:[],mounts:[]},i=[];n._collectObserveTargets("",i);for(let[a,u]of i)a.includes(`${L}${Q}${L}`)||o.nodes.push(a);return o.nodes.sort(),o.mounts.push(e),o.mounts.push(...n._collectSubgraphs(`${e}${L}`)),this._mounts.delete(e),n._parent=void 0,Sn(n),this._emitTopology({kind:"removed",name:e,nodeKind:"mount",audit:o}),o}let r=this._nodes.get(e);if(!r)throw new Error(`Graph "${this.name}": unknown node or mount "${e}"`);this._nodes.delete(e),this._nodeToName.delete(r),r.down([[H]],{internal:!0});let s={kind:"node",nodes:[e],mounts:[]};return this._emitTopology({kind:"removed",name:e,nodeKind:"node",audit:s}),s}removeAll(e){let n=typeof e=="function"?e:(()=>{let o=Xe(e);return i=>o.test(i)})(),r={kind:"mount",nodes:[],mounts:[]},s=[...this._nodes.keys(),...this._mounts.keys()].filter(o=>n(o));for(let o of s){let i=this.remove(o);r.nodes.push(...i.nodes),r.mounts.push(...i.mounts)}return r.nodes.sort(),r.mounts.sort(),r}[Symbol.iterator](){let e=[...this._nodes.keys()].sort(),n=this._nodes,r=0;return{[Symbol.iterator](){return this},next(){if(r>=e.length)return{value:void 0,done:!0};let s=e[r++];return{value:[s,n.get(s)],done:!1}}}}node(e){if(e==="")throw new Error(`Graph "${this.name}": node name must be non-empty`);if(e.includes(L))return this.resolve(e);let 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 s=r?.internal===!0;this.node(e).down([[F,n]],{actor:r?.actor,internal:s,delivery:"write"})}setAll(e,n){let r=Symbol.iterator in e?e:Object.entries(e);$e(()=>{for(let[s,o]of r)this.set(s,o,n)})}invalidate(e,n){let r=n?.internal===!0;this.node(e).down([[ee]],{actor:n?.actor,internal:r,delivery:"write"})}error(e,n,r){let s=r?.internal===!0;this.node(e).down([[M,n]],{actor:r?.actor,internal:s,delivery:"write"})}complete(e,n){let r=n?.internal===!0;this.node(e).down([[z]],{actor:n?.actor,internal:r,delivery:"write"})}edges(e){let n=e?.recursive===!0,r=new Map;if(!n){for(let[u,c]of this._nodes)r.set(c,u);let a=[];for(let[u,c]of this._nodes)if(c instanceof I)for(let d of c._deps){let h=r.get(d.node);h!=null&&a.push([h,u])}return a.sort((u,c)=>u[0]<c[0]?-1:u[0]>c[0]?1:u[1]<c[1]?-1:u[1]>c[1]?1:0),a}let s=[];this._collectObserveTargets("",s);let o=new Map;for(let[a,u]of s)o.set(u,a);let i=[];for(let[a,u]of s)if(u instanceof I)for(let c of u._deps){let d=o.get(c.node);d!=null&&i.push([d,a])}return i.sort((a,u)=>a[0]<u[0]?-1:a[0]>u[0]?1:a[1]<u[1]?-1:a[1]>u[1]?1:0),i}mount(e,n){if(n===void 0){let s=new t(e);return this.mount(e,s)}if(typeof n=="function"){let s=new t(e);return n(s),this.mount(e,s)}let r=n;if(kt(e,this.name,"mount"),this._nodes.has(e))throw new Error(`Graph "${this.name}": cannot mount at "${e}" \u2014 node with that name exists`);if(this._mounts.has(e))throw new Error(`Graph "${this.name}": mount "${e}" already exists`);if(r===this)throw new Error(`Graph "${this.name}": cannot mount a graph into itself`);if(r._parent!=null)throw new Error(`Graph "${this.name}": this child graph is already mounted on "${r._parent.name}"`);for(let s=this;s!=null;s=s._parent)if(s===r)throw new Error(`Graph "${this.name}": mount("${e}", \u2026) would create a mount cycle`);return this._mounts.set(e,r),r._parent=this,this._emitTopology({kind:"added",name:e,nodeKind:"mount"}),r}resolve(e){let n=Yr(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],s=n.slice(1);if(s.length===0){let a=this._nodes.get(r);if(a)return a;throw this._mounts.has(r)?new Error(`Graph "${this.name}": path ends at subgraph "${r}" \u2014 not a node (GRAPHREFLY-SPEC \xA73.5)`):new Error(`Graph "${this.name}": unknown name "${r}"`)}let o=this._nodes.get(r);if(o&&s.length>0&&s[0]===Q)return this._resolveMetaChainFromNode(o,s,n.join(L));let i=this._mounts.get(r);if(!i)throw this._nodes.has(r)?new Error(`Graph "${this.name}": "${r}" is a node; trailing path "${s.join(L)}" is invalid`):new Error(`Graph "${this.name}": unknown mount or node "${r}"`);return i.resolve(s.join(L))}_resolveMetaChainFromNode(e,n,r){let s=e,o=0,i=[...n];for(;o<i.length;){if(i[o]!==Q)throw new Error(`Graph "${this.name}": expected ${Q} segment in meta path "${r}"`);if(o+1>=i.length)throw new Error(`Graph "${this.name}": meta path requires a key after ${Q} in "${r}"`);let a=i[o+1],u=s.meta[a];if(!u)throw new Error(`Graph "${this.name}": unknown meta "${a}" in path "${r}"`);s=u,o+=2}return s}signal(e,n){if(n?.internal!==!0){for(let s of e)if(this.config.messageTier(s[0])===3)throw new Error(`Graph "${this.name}": Graph.signal() rejects tier-3 messages (DATA / RESOLVED). Broadcast is for control-plane tiers (START / DIRTY / INVALIDATE / PAUSE / RESUME / COMPLETE / ERROR / TEARDOWN). For per-node value writes, use Graph.set or graph.node(name).down(...).`)}let r=[];if(this._signalDeliver(e,n??{},new Set,r),r.length>0)throw r[0]}_signalDeliver(e,n,r,s){for(let u of this._mounts.values())u._signalDeliver(e,n,r,s);let i=n.internal===!0?{internal:!0}:{actor:n.actor,delivery:"signal"},a=Xr(e,this.config);for(let u of[...this._nodes.keys()].sort()){let c=this._nodes.get(u);if(!r.has(c)){r.add(c);try{c.down(e,i)}catch(d){if(d instanceof Z)throw d;s.push(d)}a.length!==0&&this._signalMetaSubtree(c,a,r,i,s)}}}_signalMetaSubtree(e,n,r,s,o){for(let i of Object.keys(e.meta).sort()){let a=e.meta[i];if(!r.has(a)){r.add(a);try{a.down(n,s)}catch(u){if(u instanceof Z)throw u;o.push(u)}this._signalMetaSubtree(a,n,r,s,o)}}}describe(e){if(e?.reactive==="diff")return this._describeReactiveDiff(e);if(e?.reactive===!0)return this._describeReactive(e);let n=Mr(e?.actor),r=e?.filter,s=He(e?.detail,e?.fields),o=e?.format==="spec",i=o?He("minimal"):s,a=[];this._collectObserveTargets("",a);let u=new Map;for(let[x,_]of a)u.set(_,x);let c=[];{let x=a.map(([,E])=>E),_=new Set(u.values()),O=0;for(;x.length>0;){let E=x.shift();if(E instanceof I)for(let C of E._deps){let R=C.node;if(u.has(R))continue;let T=R.name??"",S=T;if(!S||_.has(S))if(T){let A=2;for(;_.has(`${T}#${A}`);)A++;S=`${T}#${A}`}else for(S=`__internal__/${O++}`;_.has(S);)S=`__internal__/${O++}`;u.set(R,S),_.add(S),c.push([S,R]),x.push(R)}}}let d=[...a,...c],h={};for(let[x,_]of d){if(n!=null&&!_.allowsObserve(n))continue;let O=vt(_,i),E=_ instanceof I?_._deps.map(S=>u.get(S.node)??S.node.name??""):[],{name:C,...R}=O,T={...R,deps:E};if(!o){let S=this._annotations.get(x);S!=null&&(T.annotation=S)}if(r!=null)if(typeof r=="function"){let S=r;if(!(S.length>=2?S(x,T):S(T)))continue}else{let S=!0;for(let[A,B]of Object.entries(r)){let $=A==="deps_includes"?"depsIncludes":A==="meta_has"?"metaHas":A;if($==="depsIncludes"){if(!T.deps.includes(String(B))){S=!1;break}continue}if($==="metaHas"){if(!Object.hasOwn(T.meta??{},String(B))){S=!1;break}continue}if(T[$]!==B){S=!1;break}}if(!S)continue}h[x]=T}let p=new Set(Object.keys(h)),f=[];for(let[x,_]of d)if(_ instanceof I)for(let O of _._deps){let E=u.get(O.node);E!=null&&f.push([E,x])}f.sort((x,_)=>x[0]<_[0]?-1:x[0]>_[0]?1:x[1]<_[1]?-1:x[1]>_[1]?1:0);let l=f.map(([x,_])=>({from:x,to:_}));(n!=null||r!=null)&&(l=l.filter(x=>p.has(x.from)&&p.has(x.to)));let b=this._collectSubgraphs(""),g=n!=null||r!=null?b.filter(x=>{let _=`${x}${L}`;return[...p].some(O=>O===x||O.startsWith(_))}):b,w=this,m=e,y={name:this.name,nodes:h,edges:l,subgraphs:g,...this._factory!==void 0?{factory:this._factory}:{},...this._factoryArgs!==void 0?{factoryArgs:this._factoryArgs}:{},expand(x){let _={...m,format:void 0};return Array.isArray(x)?(_.fields=x,_.detail=void 0):(_.detail=x,_.fields=void 0),w.describe(_)}},v=e??{},k=v.format;return k==="json"?jr(y,v):k==="pretty"?Vr(y,v):k==="mermaid"?xn(y,v):k==="mermaid-url"?Br(y,v):k==="d2"?zr(y,v):k==="ascii"?cn(y,v):y}_collectSubgraphs(e){let n=[];for(let r of[...this._mounts.keys()].sort()){let s=e===""?r:`${e}${r}`;n.push(s),n.push(...this._mounts.get(r)._collectSubgraphs(`${s}${L}`))}return n}resourceProfile(e){return hn(this,e)}reachable(e,n,r={}){return r.withDetail===!0?bn(this.describe(),e,n,{...r,withDetail:!0}):bn(this.describe(),e,n,r)}explain(e,n,r){return r?.reactive===!0?this._explainReactive(e,n,r):this._explainStatic(e,n,r)}_explainStatic(e,n,r){let s=this.describe({detail:"full"}),o=new Map(this._annotations),i=new Map;for(let[a,u]of Object.entries(s.nodes))u.lastMutation!=null&&i.set(a,u.lastMutation);return un(s,e,n,{...r?.maxDepth!=null?{maxDepth:r.maxDepth}:{},...r?.findCycle===!0?{findCycle:!0}:{},annotations:o,lastMutations:i})}_describeReactive(e){let n={...e,reactive:!1},r=e.reactiveName??"describe",s=0,o=re(s,{name:`${r}_version`}),i=this.observe({timeline:!0,structured:!0}),a=!1,u=!1,c=()=>{a||u||(a=!0,be(()=>{a=!1,!u&&(s+=1,o.emit(s))}))},d=i.onEvent(m=>{let y=m.type;y!=="data"&&y!=="error"&&y!=="complete"&&y!=="teardown"||c()}),h=[],p=new WeakSet,f=m=>{if(p.has(m)||u)return;p.add(m);let y=m.topology.subscribe(v=>{for(let k of v){if(k[0]!==F)continue;let x=k[1];if(c(),x.kind==="added"&&x.nodeKind==="mount"){let _=m._mounts.get(x.name);_!=null&&f(_)}}});h.push(y);for(let v of m._mounts.keys()){let k=m._mounts.get(v);k!=null&&f(k)}};f(this);let l,b=e.actor;vn(b)&&(l=b.subscribe(m=>{let y=!1,v=!1;for(let k of m){let x=k[0];x===F?y=!0:(x===z||x===M||x===H)&&(v=!0)}y&&c(),v&&(l?.(),l=void 0,c())}));let g;try{g=pe([o],()=>this.describe(n),{name:r,describeKind:"derived",meta:{domain:"audit",kind:"describe"},equals:(m,y)=>m===y})}catch(m){d(),l?.();for(let y of h)y();throw i.dispose(),m}let w=he(g);return{node:g,dispose(){u=!0,d(),l?.();for(let m of h)m();h.length=0,i.dispose(),w()}}}_describeReactiveDiff(e){let n={...e,format:void 0,reactive:!1},r=e.reactiveName??"describe-diff",s={name:this.name,nodes:{},edges:[],subgraphs:[]},o=this.describe(n),i=_t(s,o),a=re(i,{name:r,meta:{domain:"audit",kind:"describe-diff"},equals:(p,f)=>p===f}),u=this._describeReactive({...e,format:void 0,reactiveName:void 0}),c=!1,d=u.node.subscribe(p=>{if(!c)for(let f of p){if(f[0]!==F)continue;let l=f[1],b=_t(o,l);o=l,b.events.length!==0&&a.emit(b)}}),h=he(a);return{node:a,dispose(){c=!0,d(),u.dispose(),a.down([[H,"describe-diff disposed"]]),h()}}}_explainReactive(e,n,r){let s=0,o=re(s,{name:"explain_version"}),i=this.observe({timeline:!0,structured:!0}),a=!1,u=!1,c=i.onEvent(f=>{let l=f.type;l!=="data"&&l!=="error"&&l!=="complete"&&l!=="teardown"||a||u||(a=!0,be(()=>{a=!1,!u&&(s+=1,o.emit(s))}))}),d={...r?.maxDepth!=null?{maxDepth:r.maxDepth}:{},...r?.findCycle===!0?{findCycle:!0}:{}},h;try{h=pe([o],()=>this._explainStatic(e,n,d),{name:r?.name??"explain",describeKind:"derived",meta:{domain:"audit",kind:"explain_path",from:e,to:n},equals:(f,l)=>f.found===l.found&&f.reason===l.reason&&f.steps.length===l.steps.length&&Qr(f.steps,l.steps)})}catch(f){throw c(),i.dispose(),f}let p=he(h);return{node:h,dispose(){u=!0,c(),i.dispose(),p()}}}_pathsMatching(e){let n=Xe(e),r=[];return this._collectObserveTargets("",r),r.map(([s])=>s).filter(s=>n.test(s))}_collectObserveTargets(e,n){for(let r of[...this._mounts.keys()].sort()){let s=e===""?r:`${e}${L}${r}`;this._mounts.get(r)._collectObserveTargets(s,n)}for(let r of[...this._nodes.keys()].sort()){let s=this._nodes.get(r),o=e===""?r:`${e}${L}${r}`;n.push([o,s]),this._appendMetaObserveTargets(o,s,n)}}_appendMetaObserveTargets(e,n,r){for(let s of Object.keys(n.meta).sort()){let o=n.meta[s],i=`${e}${L}${Q}${L}${s}`;r.push([i,o]),this._appendMetaObserveTargets(i,o,r)}}observe(e,n){let r=typeof e=="string",o=yn(r?n:e);if(o.reactive===!0)return this._observeReactive(r?e:void 0,o);let i=o.structured===!0||o.timeline===!0||o.causal===!0||o.derived===!0||o.detail==="minimal"||o.detail==="full"||o.format!=null,a=o.actor;if(r){let d=e,h=this.resolve(d);if(a!=null&&!h.allowsObserve(a))throw new Z({actor:a,action:"observe",nodeName:d});return i?this._buildStructuredObserver([[d,h]],o,"one"):{subscribe(p){return h.subscribe(p)},up(p){try{h.up?.(p)}catch(f){if(f instanceof Z)return;throw f}}}}let u=[];this._collectObserveTargets("",u),u.sort((d,h)=>d[0]<h[0]?-1:d[0]>h[0]?1:0);let c=a==null?u:u.filter(([,d])=>d.allowsObserve(a));return i?this._buildStructuredObserver(c,o,"all"):{subscribe:d=>{let h=c.map(([p,f])=>f.subscribe(l=>{d(p,l)}));return()=>{for(let p of h)p()}},up:(d,h)=>{try{this.resolve(d).up?.(h)}catch(p){if(p instanceof Z)return;throw p}}}}_observeReactive(e,n){let r=n.tiers,s=r!=null?new Set(r):null,o=n.reactiveName??"observe";return Se(i=>{let a=[],u=!1,c=!1,d=()=>{if(a.length===0||c)return;let b={events:a.slice(),flushedAt_ns:oe()};a.length=0,i.emit(b)},h={...n,reactive:!1,structured:!0,timeline:!0},p=e!=null?this.observe(e,h):this.observe(h),f=b=>{c||(a.push(b),!u&&(u=!0,be(()=>{u=!1,d()})))};for(let b of p.events)f(b);let l=p.onEvent(f);return()=>{c=!0,l(),p.dispose()}},{name:o,meta:{domain:"audit",kind:"observe-reactive"}})}_buildStructuredObserver(e,n,r){let s=r==="one"?e[0]?.[0]:void 0,o=i=>{if(r==="one"&&s!=null){let d=this.resolve(s);return this._buildStructuredObserver([[s,d]],i,"one")}let a=[];this._collectObserveTargets("",a),a.sort((d,h)=>d[0]<h[0]?-1:d[0]>h[0]?1:0);let u=i.actor,c=u==null?a:a.filter(([,d])=>d.allowsObserve(u));return this._buildStructuredObserver(c,i,"all")};return this._createObserveResult(e,n,o)}_createObserveResult(e,n,r){let s=n.timeline===!0,o=n.causal===!0,i=n.derived===!0,a=n.detail==="minimal",u=this.config.inspectorEnabled,c=(o||i)&&u,d=n.maxEvents,h=d!=null&&d>0?new Re(d):null,p=[],f=new Set,l=n.tiers!=null?new Set(n.tiers):null,b={},g=new Set,w=0,m=0,y=0,v=0,k=0,x=0,_=!1,O=!1,E=0,C=new Map,R=new Map,T=new Map,S=N=>{if(!(l!=null&&!l.has(N.type))){h?h.push(N):p.push(N);for(let P of f)P(N)}},A=N=>l==null||l.has(N),B=()=>s?{timestamp_ns:oe(),in_batch:Me(),batch_id:E}:{},$=(N,P)=>{if(!(!c||!(N instanceof I)))return N._setInspectorHook(Y=>{if(Y.kind==="dep_message")C.set(N,Y.depIndex);else if(Y.kind==="run"){let ke=Y.batchData.map((D,W)=>D!=null&&D.length>0?D.at(-1):Y.prevData[W]);R.set(N,ke);let X=Y.batchData.map(D=>D!=null?[...D]:void 0);T.set(N,X),i&&S({type:"derived",path:P,dep_values:ke,dep_batches:X,...B()})}})},U=N=>{let P=C.get(N),Y=R.get(N);if(!o||Y==null)return{};let X=(P!=null&&P>=0&&N instanceof I?N._deps[P]:void 0)?.node,D=X?.v,W=T.get(N);return{trigger_dep_index:P,trigger_dep_name:X?.name,...D!=null?{trigger_version:{id:D.id,version:D.version}}:{},dep_values:[...Y],...W!=null?{dep_batches:W}:{}}},V=[],ne=[];for(let[N,P]of e){let Y=$(P,N);Y&&V.push(Y),ne.push(P.subscribe(ke=>{E++;for(let X of ke){let D=X[0],W=B();if(D===F){b[N]=X[1];let ot=P instanceof I?P.lastMutation?.actor??ge:ge;S({type:"data",path:N,data:X[1],actor:ot,...W,...U(P)})}else if(a)D===q?A("dirty")&&w++:D===J?A("resolved")&&m++:D===ee?A("invalidate")&&y++:D===te?A("pause")&&v++:D===se?A("resume")&&k++:D===H?A("teardown")&&x++:D===z&&!g.has(N)?A("complete")&&(_=!0):D===M&&A("error")&&(O=!0,g.add(N));else if(D===q)A("dirty")&&w++,S({type:"dirty",path:N,...W});else if(D===J)A("resolved")&&m++,S({type:"resolved",path:N,...W,...U(P)});else if(D===ee)A("invalidate")&&y++,S({type:"invalidate",path:N,...W});else if(D===te)A("pause")&&v++,S({type:"pause",path:N,lockId:X[1],...W});else if(D===se)A("resume")&&k++,S({type:"resume",path:N,lockId:X[1],...W});else if(D===z)A("complete")&&!g.has(N)&&(_=!0),S({type:"complete",path:N,...W});else if(D===M){A("error")&&(O=!0,g.add(N));let ot=P instanceof I?P.lastMutation?.actor??ge:ge;S({type:"error",path:N,data:X[1],actor:ot,...W})}else D===H&&(A("teardown")&&x++,S({type:"teardown",path:N,...W}))}}))}let tt=!1,nt=()=>{if(!tt){tt=!0;for(let N of ne)N();for(let N of V)N();for(let N of Ge)N({value:void 0,done:!0});Ge.length=0}},rt=[],Ge=[];f.add(N=>{let P=Ge.shift();P?P({value:N,done:!1}):rt.push(N)});let Ct={get values(){return b},get dirtyCount(){return w},get resolvedCount(){return m},get invalidateCount(){return y},get pauseCount(){return v},get resumeCount(){return k},get teardownCount(){return x},get events(){return h?h.toArray():[...p]},get anyCompletedCleanly(){return _},get anyErrored(){return O},get completedWithoutErrors(){return _&&!O},onEvent(N){return f.add(N),()=>f.delete(N)},dispose:nt,expand(N){nt();let P={...n};return typeof N=="string"?P.detail=N:Object.assign(P,N),r(yn(P))},[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(N=>Ge.push(N))},return(){return nt(),Promise.resolve({value:void 0,done:!0})}}}};return n.format!=null&&this._attachFormatLogger(Ct,n),Ct}_attachFormatLogger(e,n){let r=n.format;if(r==null)return;let s=n.logger??(l=>console.log(l)),o=n.includeTypes?new Set(n.includeTypes):null,i=n.excludeTypes?new Set(n.excludeTypes):null,a=o==null&&i==null?()=>!0:l=>(o==null||o.has(l))&&(i==null||!i.has(l)),u=qr(n.theme),c=r==="stage-log"?oe():0,d=l=>l==null?"":n.stageLabels?.[l]??l,h=(l,b)=>l.length>b?`${l.slice(0,b-1)}\u2026`:l,p=l=>l.type==="data"||l.type==="error"?h(Ze(l.data),120):"",f=l=>{if(r==="stage-log"){let _=(oe()-c)/1e9,O=d(l.path).padEnd(9);if(l.type==="data"){let E=p(l);return`[${_.toFixed(3)}s] ${O} \u2190${E?` ${E}`:""}`}if(l.type==="error"){let E=p(l);return`[${_.toFixed(3)}s] ${O} \u2717${E?` ${E}`:""}`}return l.type==="complete"?`[${_.toFixed(3)}s] ${O} \u25A0 complete`:`[${_.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=u[l.type]??"",g=l.path?`${u.path}${l.path}${u.reset} `:"",w=l.type==="data"||l.type==="error",m=l.type==="pause"||l.type==="resume",y=w?` ${Ze(l.data)}`:m?` ${Ze(l.lockId)}`:"",v=l.type==="data"||l.type==="resolved"||l.type==="derived"?l:void 0,k=v?.trigger_dep_name!=null?` <- ${v.trigger_dep_name}`:v?.trigger_dep_index!=null?` <- #${v.trigger_dep_index}`:"",x=l.in_batch?" [batch]":"";return`${g}${b}${l.type.toUpperCase()}${u.reset}${y}${k}${x}`};e.onEvent(l=>{a(l.type)&&s(f(l),l)})}addDisposer(e){return this._disposers.add(e),()=>{this._disposers.delete(e)}}destroy(){gn(this._disposers,this.name),this.signal([[H]],{internal:!0}),gn(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"}),s={};for(let a of Object.keys(r.nodes).sort()){let{lastMutation:u,guard:c,...d}=r.nodes[a];s[a]=d}let o=[...r.subgraphs].sort(),i={...r,version:1,nodes:s,subgraphs:o};if(e?.format==null)return i;if(e.format==="json-string")return JSON.stringify(i);if(e.format==="bytes"){if(e.codec==null)throw new Error("snapshot({format: 'bytes'}) requires a `codec` name");let a=this.config.lookupCodec(e.codec);if(a==null)throw new Error(`snapshot: codec "${e.codec}" is not registered on this graph's config. Call config.registerCodec(...) before creating nodes.`);return Dt(a,a.encode(i))}throw new Error(`snapshot: unknown format "${String(e.format)}"`)}static decode(e,n){let r=n?.config??_e,{codec:s,codecVersion:o,payload:i}=Mt(e,r);return s.decode(i,o)}restore(e,n){if(mn(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(o=>Xe(o)),s=n?.includeProducers===!0;for(let o of Object.keys(e.nodes).sort()){if(r!==null&&!r.some(a=>a.test(o)))continue;let i=e.nodes[o];if(i!==void 0){if(!("value"in i)||i.value===void 0){"value"in i&&i.value===void 0&&n?.onError?.(o,new Error(`restore: slice.value is undefined for "${o}" (undefined is the global SENTINEL; not valid DATA)`));continue}if(!(i.type==="derived"||i.type==="effect")&&!(i.type==="producer"&&!s)){if(i.v!=null){let u=this.tryResolve(o)?.v;if(u!=null&&u.id===i.v.id&&u.version===i.v.version)continue}try{this.set(o,i.value)}catch(a){n?.onError?.(o,a)}}}}}static fromSnapshot(e,n){mn(e);let r=typeof n=="function"?n:n?.build,s=typeof n=="function"?void 0:n?.factories,o=new t(e.name);if(r)return r(o),o.restore(e),o;for(let f of[...e.subgraphs].sort((l,b)=>{let g=l.split(L).length,w=b.split(L).length;return g!==w?g-w:l<b?-1:l>b?1:0})){let l=f.split(L),b=o;for(let g of l)b._mounts.has(g)||b.mount(g,new t(g)),b=b._mounts.get(g)}let i=s?Object.entries(s).map(([f,l])=>({re:Xe(f),factory:l})):[],a=f=>{for(let l of i)if(l.re.test(f))return l.factory},u=f=>{let l=f.split(L),b=l.pop();if(b==null||b.length===0)throw new Error(`invalid snapshot path "${f}"`);let g=o;for(let w of l){let m=g._mounts.get(w);if(!m)throw new Error(`unknown mount "${w}" in path "${f}"`);g=m}return[g,b]},c=Object.entries(e.nodes).filter(([f])=>!f.includes(`${L}${Q}${L}`)).sort((f,l)=>f[0]<l[0]?-1:f[0]>l[0]?1:0),d=new Map(c),h=new Map,p=!0;for(;d.size>0&&p;){p=!1;for(let[f,l]of[...d.entries()]){let b=l?.deps??[];if(!b.every(k=>h.has(k)))continue;let[g,w]=u(f),m={...l?.meta??{}},y=a(f),v;if(l?.type==="state")v=re(l.value,{meta:m});else{if(y==null)continue;v=y(w,{path:f,type:l.type,value:l.value,meta:m,deps:b,resolvedDeps:b.map(k=>h.get(k))})}g.add(v,{name:w}),h.set(f,v),d.delete(f),p=!0}}if(d.size>0){let f=[...d.keys()].sort().join(", ");throw new Error(`Graph.fromSnapshot could not reconstruct nodes without build callback: ${f}. Pass matching factories via fromSnapshot(data, { factories: { pattern: factoryFn } }).`)}return o.restore(e),o}toJSON(){return this.snapshot()}attachSnapshotStorage(e,n={}){let r=e.map(c=>({tier:c,debounceMs:Math.max(0,c.debounceMs??0),compactEvery:Math.max(1,c.compactEvery??10),timer:void 0,seq:0,lastSnapshot:void 0,lastFingerprint:"",disposed:!1,savePending:void 0}));n.autoRestore===!0&&this._cascadeRestore(e,n.onError);let s=(c,d)=>{if(c.disposed)return;let h=$r(d.nodes);if(c.lastSnapshot!=null&&h!==""&&h===c.lastFingerprint)return;let p=c.seq+1,f=ve(),g=c.lastSnapshot==null||p%c.compactEvery===0?{name:this.name,mode:"full",snapshot:d,seq:p,timestamp_ns:f,format_version:ce}:{name:this.name,mode:"diff",diff:Zr(c.lastSnapshot,d),seq:p,timestamp_ns:f,format_version:ce};if(c.tier.filter&&!c.tier.filter(g))return;let w;try{w=c.tier.save(g)}catch(m){n.onError?.(m,c.tier);return}if(w&&typeof w.then=="function"){let v=(c.savePending??Promise.resolve()).then(()=>w,()=>w).then(()=>{c.disposed||(c.seq=p,c.lastSnapshot=d,c.lastFingerprint=h)},k=>{n.onError?.(k,c.tier)});c.savePending=v.finally(()=>{c.savePending===v&&(c.savePending=void 0)})}else c.seq=p,c.lastSnapshot=d,c.lastFingerprint=h},o=(c,d)=>{try{s(c,d)}catch(h){n.onError?.(h,c.tier)}},i=(c,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(c);if(l==null)return;let b=vt(l,He("standard"));if(!n.filter(c,b))return}let p,f=()=>(p==null&&(p=this.snapshot()),p);for(let l of r)l.disposed||(l.debounceMs===0?o(l,f()):(l.timer==null&&(l.timer=new ze),l.timer.start(l.debounceMs,()=>{l.disposed||o(l,this.snapshot())})))},a;if(n.paths!=null){let d=(typeof n.paths=="string"?this._pathsMatching(n.paths):n.paths).map(h=>{let p=this.tryResolve(h);return p==null?()=>{}:p.subscribe(f=>i(h,f))});a=()=>{for(let h of d)h()}}else a=this.observe().subscribe((c,d)=>i(c,d));let u=()=>{a();for(let c of r)c.disposed=!0,c.timer?.cancel();this._storageDisposers.delete(u)};return this._storageDisposers.add(u),{dispose:u}}async _cascadeRestore(e,n){for(let r of e){let s;try{s=await r.load?.()}catch(i){n?.(i,r);continue}if(s==null||typeof s!="object"||Array.isArray(s))continue;let o=s;try{if(o.mode==="full"&&o.snapshot!=null)return this.restore(o.snapshot),!0;if(o.version===ce&&o.nodes!=null)return this.restore(o),!0}catch(i){n?.(i,r)}}return!1}static async fromStorage(e,n,r){for(let s of n){let o;try{o=await s.load?.()}catch(u){r?.onError?.(u,s);continue}if(o==null||typeof o!="object"||Array.isArray(o))continue;let i=o,a=i.mode==="full"&&i.snapshot!=null?i.snapshot:i.version===ce&&i.nodes!=null?i:void 0;if(a!=null)try{return t.fromSnapshot(a,r)}catch(u){r?.onError?.(u,s)}}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 s={path:e,annotation:n,timestamp_ns:oe(),...r?.actor!=null?{actor:r.actor}:{}};this._traceRing.push(s)}return}return e!=null?this.config.inspectorEnabled?this._annotations.get(e):void 0:this.config.inspectorEnabled?this._traceRing.toArray():[]}annotation(e){return this._annotations.get(e)}clearTrace(){this._annotations.clear(),this._traceRing.clear()}pruneTrace(e){let n=this._traceRing.toArray().filter(s=>!e(s)),r=this._traceRing.size-n.length;this._traceRing.clear();for(let s of n)this._traceRing.push(s);return r}static diff(e,n){let r=new Set(Object.keys(e.nodes)),s=new Set(Object.keys(n.nodes)),o=[...s].filter(m=>!r.has(m)).sort(),i=[...r].filter(m=>!s.has(m)).sort(),a=[],u=[];for(let m of r){if(!s.has(m))continue;let y=e.nodes[m],v=n.nodes[m],k=y.v,x=v.v;k!=null&&x!=null&&k.id===x.id&&k.version!==x.version&&u.push({path:m,id:k.id,from:k.version,to:x.version});let _=k!=null&&x!=null&&k.id===x.id&&k.version===x.version;for(let O of["type","status","sentinel"]){let E=y[O],C=v[O];E!==C&&a.push({path:m,field:O,from:E,to:C})}if(!_)for(let O of["value","meta"]){let E=y[O],C=v[O];Pr(E,C)||a.push({path:m,field:O,from:E,to:C})}}let c=m=>`${m.from} ${m.to}`,d=new Set(e.edges.map(c)),h=new Set(n.edges.map(c)),p=n.edges.filter(m=>!d.has(c(m))),f=e.edges.filter(m=>!h.has(c(m))),l=new Set(e.subgraphs),b=new Set(n.subgraphs),g=[...b].filter(m=>!l.has(m)).sort(),w=[...l].filter(m=>!b.has(m)).sort();return{nodesAdded:o,nodesRemoved:i,nodesChanged:a,versionChanges:u,edgesAdded:p,edgesRemoved:f,subgraphsAdded:g,subgraphsRemoved:w}}};function Zr(t,e){let n=ie.diff(t,e),r={};for(let s of n.nodesAdded){let o=e.nodes[s];o!=null&&(r[s]=o)}return{...n,nodesAddedFull:r}}function bn(t,e,n,r={}){let s={paths:[],depths:new Map,truncated:!1};if(!e)return r.withDetail?s:[];if(!r.both&&n!=="upstream"&&n!=="downstream")throw new Error('reachable: direction must be "upstream" or "downstream"');let o=r.maxDepth;if(o!=null&&(!Number.isInteger(o)||o<0))throw new Error("reachable: maxDepth must be an integer >= 0");if(o===0)return r.withDetail?s:[];let i=new Map,a=new Map,u=new Map,c=new Map,d=new Set;for(let[y,v]of Object.entries(t.nodes)){if(!y)continue;d.add(y);let k=v.deps??[];i.set(y,k);for(let x of k)x&&(d.add(x),a.has(x)||a.set(x,new Set),a.get(x).add(y))}for(let y of t.edges){if(y==null||typeof y!="object")continue;let v=typeof y.from=="string"?y.from:"",k=typeof y.to=="string"?y.to:"";!v||!k||(d.add(v),d.add(k),c.has(v)||c.set(v,new Set),c.get(v).add(k),u.has(k)||u.set(k,new Set),u.get(k).add(v))}if(!d.has(e))return r.withDetail?s:[];let h=r.both===!0,p=y=>{if(h){let _=i.get(y)??[],O=u.get(y),E=a.get(y),C=c.get(y),R=[..._];return O&&R.push(...O),E&&R.push(...E),C&&R.push(...C),R}if(n==="upstream"){let _=i.get(y)??[],O=u.get(y);return O?[..._,...O]:_}let v=a.get(y),k=c.get(y),x=v?[...v]:[];return k&&x.push(...k),x},f=new Set([e]),l=new Map,b=[{path:e,depth:0}],g=0,w=!1;for(;g<b.length;){let y=b[g++];if(o!=null&&y.depth>=o){p(y.path).length>0&&(w=!0);continue}for(let v of p(y.path))!v||f.has(v)||(f.add(v),l.set(v,y.depth+1),b.push({path:v,depth:y.depth+1}))}let m=[...l.keys()].sort((y,v)=>y<v?-1:y>v?1:0);return r.withDetail?{paths:m,depths:l,truncated:w}:m}function Qr(t,e){if(t.length!==e.length)return!1;for(let n=0;n<t.length;n++){let r=t[n],s=e[n];if(r.path!==s.path||r.type!==s.type||r.status!==s.status||r.hop!==s.hop||r.dep_index!==s.dep_index||r.annotation!==s.annotation||r.value!==s.value||r.lastMutation!==s.lastMutation)return!1;let o=r.v,i=s.v;if(o!==i&&(o==null||i==null||o.id!==i.id||o.version!==i.version))return!1}return!0}Le();le();xe();Be();le();xt();function kn(t,e){let n=t.cache??0;return n>=e?!1:(t.down([[q],[F,n+1]]),!0)}function On(t,e,n){return{[t]:!0,[`${t}_type`]:e,...n??{}}}function Nn(t,e){return On("reduction",t,e)}function Tn(t,e,n,r){let s=r?.maxIterations??10,o=`__feedback_${e}`,i=re(0,{meta:Nn("feedback_counter",{maxIterations:s,feedbackFrom:e,feedbackTo:n})});t.add(i,{name:o});let a=t.resolve(e),u=t.resolve(n),c=`__feedback_effect_${e}`,d=fe([],(h,p)=>{let f=a.subscribe(l=>{for(let b of l){let g=b[0];if(g===F){let w=b[1];if(w==null)return;$e(()=>{kn(i,s)&&u.emit(w)})}else if(g===z||g===M){let w=g===M&&b.length>1?[M,b[1]]:[g];i.down([w])}}});return()=>f()},{name:c,describeKind:"effect",meta:{...Nn("feedback_effect",{feedbackFrom:e,feedbackTo:n}),_internal:!0}});return t.add(d,{name:c}),t.addDisposer(he(d)),t}function An(t){return typeof t=="object"&&t!==null&&"factory"in t}function eo(t){return typeof t=="object"&&t!==null&&"factory"in t}function to(t){return An(t)?t.factory:t}function no(t){return eo(t)?t.factory:t}function En(t){let e=t.meta;if(!e||typeof e.factory!="string")return t;let n=e.factory,r=e.factoryArgs??{},s={...t},o=!1;if(t.type==="producer"?s.source==null&&s.fn==null&&(s.source=n,o=!0):s.fn==null&&(s.fn=n,o=!0),s.config==null&&(s.config=r),!o&&(s.meta??e)===e){let i={...e};delete i.factory,delete i.factoryArgs,Object.keys(i).length>0?s.meta=i:s.meta=void 0}return s}function ro(t){let e={},n=!1;for(let[i,a]of Object.entries(t.nodes)){if(a.type==="template"){e[i]=a;continue}let u=En(a);e[i]=u,u!==a&&(n=!0)}let r=t.templates,s;if(r){s={};for(let[i,a]of Object.entries(r)){let u={},c=!1;for(let[d,h]of Object.entries(a.nodes)){let p=En(h);u[d]=p,p!==h&&(c=!0)}s[i]=c?{...a,nodes:u}:a,c&&(n=!0)}}if(!n)return t;let o={...t,nodes:e};return s&&(o.templates=s),o}function Tt(t,e){let n=[],r=new Set(Object.keys(e.fns??{})),s=new Set(Object.keys(e.sources??{}));for(let[o,i]of Object.entries(t.nodes)){if(i.type==="template")continue;let a=i;if(a.fn&&r.size>0&&!r.has(a.fn))if(s.has(a.fn))n.push(`Node "${o}": fn "${a.fn}" is a source, not a function. Use it as a producer source instead, or use a function from: ${[...r].join(", ")}`);else{let u=Nt(a.fn,r);n.push(`Node "${o}": fn "${a.fn}" not found in catalog`+(u?`. Did you mean "${u}"?`:""))}if(a.source&&s.size>0&&!s.has(a.source))if(r.has(a.source))n.push(`Node "${o}": source "${a.source}" is a function, not a source. Use it as fn instead, or use a source from: ${[...s].join(", ")}`);else{let u=Nt(a.source,s);n.push(`Node "${o}": source "${a.source}" not found in catalog`+(u?`. Did you mean "${u}"?`:""))}if(a.fn&&a.config&&e.fns?.[a.fn]){let u=e.fns[a.fn];if(An(u)&&u.configSchema){for(let[c,d]of Object.entries(u.configSchema))if(d.required!==!1&&!(c in a.config)&&n.push(`Node "${o}": config missing required field "${c}"`),c in a.config&&d.enum){let h=a.config[c];d.enum.includes(h)||n.push(`Node "${o}": config.${c} = ${JSON.stringify(h)}, expected one of: ${d.enum.join(", ")}`)}}}}if(t.templates){for(let[o,i]of Object.entries(t.templates))for(let[a,u]of Object.entries(i.nodes))if(u.fn&&r.size>0&&!r.has(u.fn)){let c=Nt(u.fn,r);n.push(`Template "${o}" node "${a}": fn "${u.fn}" not found in catalog`+(c?`. Did you mean "${c}"?`:""))}}return{valid:n.length===0,errors:n,warnings:[]}}function Nt(t,e){let n=null,r=1/0,s=t.toLowerCase();for(let o of e){let i=oo(s,o.toLowerCase());i<r&&i<=Math.max(3,Math.floor(t.length/2))&&(r=i,n=o)}return n}function oo(t,e){let n=t.length,r=e.length,s=Array.from({length:n+1},(o,i)=>Array.from({length:r+1},(a,u)=>i===0?u:u===0?i:0));for(let o=1;o<=n;o++)for(let i=1;i<=r;i++)s[o][i]=t[o-1]===e[i-1]?s[o-1][i-1]:1+Math.min(s[o-1][i],s[o][i-1],s[o-1][i-1]);return s[n][r]}var Rn=new Set(["state","producer","derived","effect","operator","template"]),so=new Set(["state","producer","derived","effect","operator"]);function Et(t){let e=[],n=[];if(t==null||typeof t!="object")return{valid:!1,errors:["GraphSpec must be a non-null object"],warnings:n};let r=t;if((typeof r.name!="string"||r.name.length===0)&&e.push("Missing or empty 'name' field"),r.nodes==null||typeof r.nodes!="object"||Array.isArray(r.nodes))return e.push("Missing or invalid 'nodes' field (must be an object)"),{valid:!1,errors:e,warnings:n};let s=new Set(Object.keys(r.nodes)),o=new Map,i=new Map;if(r.templates!=null&&typeof r.templates=="object"&&!Array.isArray(r.templates)){for(let[a,u]of Object.entries(r.templates))if(u!=null&&typeof u=="object"){let c=u;i.set(a,{params:Array.isArray(c.params)?c.params:[]})}}if(r.templates!=null)if(typeof r.templates!="object"||Array.isArray(r.templates))e.push("'templates' must be an object");else for(let[a,u]of Object.entries(r.templates)){if(u==null||typeof u!="object"){e.push(`Template "${a}": must be an object`);continue}let c=u;if(Array.isArray(c.params)||e.push(`Template "${a}": missing 'params' array`),c.nodes==null||typeof c.nodes!="object"||Array.isArray(c.nodes))e.push(`Template "${a}": missing or invalid 'nodes' object`);else{let d=new Set(Array.isArray(c.params)?c.params:[]),h=new Set(Object.keys(c.nodes));for(let[p,f]of Object.entries(c.nodes)){if(f==null||typeof f!="object"){e.push(`Template "${a}" node "${p}": must be an object`);continue}let l=f;if((typeof l.type!="string"||!so.has(l.type))&&e.push(`Template "${a}" node "${p}": invalid type`),Array.isArray(l.deps))for(let b of l.deps)!h.has(b)&&!d.has(b)&&e.push(`Template "${a}" node "${p}": dep "${b}" is not an inner node or param`)}typeof c.output!="string"?e.push(`Template "${a}": missing 'output' string`):c.nodes[c.output]||e.push(`Template "${a}": output "${c.output}" is not a declared node`)}}for(let[a,u]of Object.entries(r.nodes)){if(u==null||typeof u!="object"){e.push(`Node "${a}": must be an object`);continue}let c=u;if(typeof c.type!="string"||!Rn.has(c.type)){e.push(`Node "${a}": invalid type "${String(c.type)}" (expected: ${[...Rn].join(", ")})`);continue}if(o.set(a,c.type),c.type==="template")if(typeof c.template!="string"||!i.has(c.template))e.push(`Node "${a}": template "${String(c.template)}" not found in templates`);else if(c.bind==null||typeof c.bind!="object"||Array.isArray(c.bind))e.push(`Node "${a}": template ref requires 'bind' object`);else{let d=i.get(c.template),h=c.bind;for(let p of d.params)p in h||e.push(`Node "${a}": template param "${p}" is not bound (template "${c.template}")`);for(let[,p]of Object.entries(h))typeof p=="string"&&!s.has(p)&&e.push(`Node "${a}": bind target "${p}" does not reference an existing node`)}else{if(Array.isArray(c.deps))for(let d of c.deps)d===a?e.push(`Node "${a}": self-referencing dep`):s.has(d)||e.push(`Node "${a}": dep "${d}" does not reference an existing node`);(c.type==="derived"||c.type==="effect"||c.type==="operator")&&!Array.isArray(c.deps)&&e.push(`Node "${a}": ${c.type} node should have a 'deps' array`)}}if(r.feedback!=null)if(!Array.isArray(r.feedback))e.push("'feedback' must be an array");else for(let a=0;a<r.feedback.length;a++){let u=r.feedback[a];if(u==null||typeof u!="object"){e.push(`Feedback [${a}]: must be an object`);continue}let c=u;typeof c.from!="string"||!s.has(c.from)?e.push(`Feedback [${a}]: 'from' "${String(c.from)}" does not reference an existing node`):o.get(c.from)==="effect"&&n.push(`Feedback [${a}]: 'from' "${c.from}" is an effect node \u2014 effects emit no DATA, so the feedback edge will never fire. Did you mean a derived/state node upstream?`),typeof c.from=="string"&&c.from===c.to&&e.push(`Feedback [${a}]: 'from' and 'to' must be different nodes`),typeof c.to!="string"||!s.has(c.to)?e.push(`Feedback [${a}]: 'to' "${String(c.to)}" does not reference an existing node`):typeof c.to=="string"&&o.get(c.to)!=="state"&&e.push(`Feedback [${a}]: 'to' node "${c.to}" must be a state node (got "${o.get(c.to)??"unknown"}")`)}return{valid:e.length===0,errors:e,warnings:n}}function Cn(t,e){let n=Et(t);if(!n.valid)throw new Error(`compileSpec: invalid GraphSpec:
|
|
8
|
-
${n.errors.join(`
|
|
9
|
-
`)}`);let r=t.factory,s=t.factoryArgs;if(typeof r=="string"){let m=e?.catalog?.graphFactories?.[r];if(m)return m(s)}t=ro(t);let o=e?.catalog??{},i=e?.onMissing??"placeholder",a=new ie(t.name),u=t.templates??{},c=Tt(t,o);if(!c.valid)throw new Error(`compileSpec: catalog validation errors:
|
|
1
|
+
"use strict";var st=Object.defineProperty;var Cn=Object.getOwnPropertyDescriptor;var Dn=Object.getOwnPropertyNames;var Gn=Object.prototype.hasOwnProperty;var z=(n,e)=>()=>(n&&(e=n(n=0)),e);var Mn=(n,e)=>{for(var t in e)st(n,t,{get:e[t],enumerable:!0})},$n=(n,e,t,r)=>{if(e&&typeof e=="object"||typeof e=="function")for(let o of Dn(e))!Gn.call(n,o)&&o!==t&&st(n,o,{get:()=>e[o],enumerable:!(r=Cn(e,o))||r.enumerable});return n};var Fn=n=>$n(st({},"__esModule",{value:!0}),n);function Ct(n,e){let t=new TextEncoder().encode(n.name);if(t.length===0||t.length>255)throw new Error(`encodeEnvelope: codec name "${n.name}" encodes to ${t.length} bytes (must be 1\u2013255)`);let r=n.version;if(!Number.isInteger(r)||r<0||r>65535)throw new Error(`encodeEnvelope: codec.version ${r} out of u16 range (expected integer 0\u201365535)`);let o=2+t.length+2+e.length;if(o>4294967295)throw new Error(`encodeEnvelope: total envelope size ${o} exceeds 2^32-1 bytes (payload ${e.length} bytes)`);let s=new Uint8Array(o),i=0;return s[i++]=ot,s[i++]=t.length,s.set(t,i),i+=t.length,s[i++]=r>>>8&255,s[i++]=r&255,s.set(e,i),s}function Dt(n,e){if(n.length<At)throw new Error(`decodeEnvelope: bytes too short (${n.length} < ${At})`);let t=0,r=n[t++];if(r!==ot)throw new Error(`decodeEnvelope: unsupported envelope version ${r} (expected ${ot})`);let o=n[t++];if(o===0)throw new Error("decodeEnvelope: name_len must be >= 1");if(t+o+2>n.length)throw new Error(`decodeEnvelope: envelope truncated (need ${t+o+2} bytes, have ${n.length})`);let s=new TextDecoder().decode(n.subarray(t,t+o));t+=o;let i=(n[t]<<8|n[t+1])>>>0;t+=2;let a=n.subarray(t),u=e.lookupCodec(s);if(u==null)throw new Error(`decodeEnvelope: codec "${s}" not registered (envelope codec_v=${i})`);return{codec:u,codecVersion:i,payload:a}}function Gt(n){n.registerCodec(Pn)}var Pn,ot,At,it=z(()=>{"use strict";Pn={name:"json",version:1,contentType:"application/json",encode(n){let e=JSON.stringify(n);return new TextEncoder().encode(e)},decode(n,e){let t=new TextDecoder().decode(n);return JSON.parse(t)}},ot=1,At=4});function Ie(n){if(n==null)return be;let{type:e,id:t,...r}=n;return{type:e??"system",id:t??"",...r}}var be,at=z(()=>{"use strict";be={type:"system",id:""}});function Ve(){return ve>0||Ce}function Mt(){return ve>0}function _e(n){ve>0?De.push(n):n()}function Be(n){ve+=1;let e=!1;try{n()}catch(t){throw e=!0,t}finally{if(ve-=1,ve===0)if(e){if(!Ce){let t=De.splice(0);for(let r of t)try{r()}catch{}le.length=0,fe.length=0,we.length=0}}else jn()}}function jn(){let n=!Ce;n&&(Ce=!0);let e=[],t=0;try{for(;le.length>0||fe.length>0||we.length>0||n&&De.length>0;){if(n&&De.length>0){let s=De.splice(0);for(let i of s)try{i()}catch(a){e.push(a)}continue}if(t+=1,t>1e3)throw le.length=0,fe.length=0,we.length=0,new Error("batch drain exceeded 1000 iterations \u2014 likely a reactive cycle");let o=(le.length>0?le:fe.length>0?fe:we).splice(0);for(let s of o)try{s()}catch(i){e.push(i)}}}finally{n&&(Ce=!1)}if(e.length===1)throw e[0];if(e.length>1)throw new AggregateError(e,"batch drain: multiple callbacks threw")}function He(n,e,t){if(e.length===0)return;if(e.length===1){let c=t(e[0][0]);if(c<3||!Ve()){n(e);return}(c>=5?we:c===4?fe:le).push(()=>n(e));return}let r=e.length,o=r,s=r,i=r,a=0;for(;a<r&&t(e[a][0])<3;)a++;for(o=a;a<r&&t(e[a][0])===3;)a++;for(s=a;a<r&&t(e[a][0])===4;)a++;i=a;let u=Ve();if(o>0){let c=e.slice(0,o);n(c)}if(s>o){let c=e.slice(o,s);u?le.push(()=>n(c)):n(c)}if(i>s){let c=e.slice(s,i);u?fe.push(()=>n(c)):n(c)}if(r>i){let c=e.slice(i,r);u?we.push(()=>n(c)):n(c)}}var ve,Ce,le,fe,we,De,ze=z(()=>{"use strict";ve=0,Ce=!1,le=[],fe=[],we=[],De=[]});function ie(){return Math.trunc(performance.now()*1e6)}function Se(){return Date.now()*1e6}var Ge=z(()=>{"use strict"});var Me,F,X,Z,re,se,ce,V,B,G,ke,ct,Ln,ut,In,Vn,dt,$t,Ft,Pt,lt,pe=z(()=>{"use strict";Me=Symbol.for("graphrefly/START"),F=Symbol.for("graphrefly/DATA"),X=Symbol.for("graphrefly/DIRTY"),Z=Symbol.for("graphrefly/RESOLVED"),re=Symbol.for("graphrefly/INVALIDATE"),se=Symbol.for("graphrefly/PAUSE"),ce=Symbol.for("graphrefly/RESUME"),V=Symbol.for("graphrefly/TEARDOWN"),B=Symbol.for("graphrefly/COMPLETE"),G=Symbol.for("graphrefly/ERROR"),ke=Object.freeze([X]),ct=Object.freeze([Z]),Ln=Object.freeze([re]),ut=Object.freeze([Me]),In=Object.freeze([B]),Vn=Object.freeze([V]),dt=Object.freeze([ke]),$t=Object.freeze([ct]),Ft=Object.freeze([Ln]),Pt=Object.freeze([In]),lt=Object.freeze([Vn])});function jt(n){n.registerMessageType(Me,{tier:0,wireCrossing:!1}),n.registerMessageType(X,{tier:1,wireCrossing:!1}),n.registerMessageType(re,{tier:1,wireCrossing:!1,metaPassthrough:!1}),n.registerMessageType(se,{tier:2,wireCrossing:!1}),n.registerMessageType(ce,{tier:2,wireCrossing:!1}),n.registerMessageType(F,{tier:3,wireCrossing:!0}),n.registerMessageType(Z,{tier:3,wireCrossing:!0}),n.registerMessageType(B,{tier:4,wireCrossing:!0,metaPassthrough:!1}),n.registerMessageType(G,{tier:4,wireCrossing:!0,metaPassthrough:!1}),n.registerMessageType(V,{tier:5,wireCrossing:!0,metaPassthrough:!1})}var Ue,Lt=z(()=>{"use strict";pe();Ue=class{_messageTypes=new Map;_codecs=new Map;_onMessage;_onSubscribe;_defaultVersioning;_defaultHashFn;_inspectorEnabled=!(typeof process<"u"&&process.env?.NODE_ENV==="production");_globalInspector;_rigorRecorder;_frozen=!1;tierOf;constructor(e){this._onMessage=e.onMessage,this._onSubscribe=e.onSubscribe,this._defaultVersioning=e.defaultVersioning,this._defaultHashFn=e.defaultHashFn,this.tierOf=t=>{let r=this._messageTypes.get(t);return r!=null?r.tier:1}}get onMessage(){return this._frozen=!0,this._onMessage}get onSubscribe(){return this._frozen=!0,this._onSubscribe}set onMessage(e){this._assertUnfrozen(),this._onMessage=e}set onSubscribe(e){this._assertUnfrozen(),this._onSubscribe=e}get defaultVersioning(){return this._defaultVersioning}set defaultVersioning(e){this._assertUnfrozen(),this._defaultVersioning=e}get defaultHashFn(){return this._defaultHashFn}set defaultHashFn(e){this._assertUnfrozen(),this._defaultHashFn=e}get inspectorEnabled(){return this._inspectorEnabled}set inspectorEnabled(e){this._inspectorEnabled=e}get globalInspector(){return this._globalInspector}set globalInspector(e){this._globalInspector=e}get rigorRecorder(){return this._rigorRecorder}set rigorRecorder(e){this._rigorRecorder=e}registerMessageType(e,t){return this._assertUnfrozen(),this._messageTypes.set(e,{tier:t.tier,wireCrossing:t.wireCrossing??t.tier>=3,metaPassthrough:t.metaPassthrough??!0}),this}messageTier(e){let t=this._messageTypes.get(e);return t!=null?t.tier:1}isWireCrossing(e){let t=this._messageTypes.get(e);return t!=null?t.wireCrossing:!0}isLocalOnly(e){return!this.isWireCrossing(e)}isMetaPassthrough(e){let t=this._messageTypes.get(e);return t!=null?t.metaPassthrough:!0}isKnownMessageType(e){return this._messageTypes.has(e)}registerCodec(e){return this._assertUnfrozen(),this._codecs.set(e.name,e),this}lookupCodec(e){return this._codecs.get(e)}_isFrozen(){return this._frozen}_assertUnfrozen(){if(this._frozen)throw new Error("GraphReFlyConfig is frozen: a node has already captured this config. Register custom types and set hooks before creating any node.")}}});function It(n){return Array.isArray(n)?[...n]:[n]}function Bn(n,e){return n.has(e)||n.has("*")}function Vt(n){let e=[];return n((o,s)=>{e.push({kind:"allow",actions:new Set(It(o)),where:s?.where??(()=>!0)})},(o,s)=>{e.push({kind:"deny",actions:new Set(It(o)),where:s?.where??(()=>!0)})}),(o,s)=>{let i=!1,a=!1;for(let u of e)Bn(u.actions,s)&&u.where(o)&&(u.kind==="deny"?i=!0:a=!0);return i?!1:a}}function ft(n){let e=Hn.filter(t=>n({type:t,id:""},"write"));return e.length===0?"restricted":e.includes("human")&&e.includes("llm")&&e.every(t=>t==="human"||t==="llm"||t==="system")?"both":e.length===1?e[0]:e.join("+")}var Q,Hn,$e=z(()=>{"use strict";Q=class extends Error{actor;action;nodeName;constructor(e,t){super(t??`GuardDenied: action "${String(e.action)}" denied for actor type "${String(e.actor.type)}"`),this.name="GuardDenied",this.actor=e.actor,this.action=e.action,this.nodeName=e.nodeName}get node(){return this.nodeName}};Hn=["human","llm","wallet","system"]});function pt(n){if(n===void 0)return null;if(typeof n=="number"){if(!Number.isFinite(n))throw new TypeError(`Cannot hash non-finite number: ${n}`);if(Number.isInteger(n)&&!Number.isSafeInteger(n))throw new TypeError(`Cannot hash integer outside safe range (|n| > 2^53-1): ${n}. Cross-language cid parity is not guaranteed for unsafe integers.`);return n}if(typeof n=="string"||typeof n=="boolean"||n===null)return n;if(Array.isArray(n))return n.map(pt);if(typeof n=="object"&&n!==null){let e={};for(let t of Object.keys(n).sort())e[t]=pt(n[t]);return e}return null}function Wn(n){let e=Un.encode(n),t=e.length,r=t*8,o=t+9+63&-64,s=new Uint8Array(o);s.set(e),s[t]=128;let i=new DataView(s.buffer);i.setUint32(o-4,r>>>0,!1),i.setUint32(o-8,Math.floor(r/4294967296)>>>0,!1);let a=1779033703,u=3144134277,c=1013904242,d=2773480762,g=1359893119,f=2600822924,p=528734635,l=1541459225,b=new Uint32Array(64),m=(v,h)=>v>>>h|v<<32-h;for(let v=0;v<o;v+=64){for(let k=0;k<16;k++)b[k]=i.getUint32(v+k*4,!1);for(let k=16;k<64;k++){let P=b[k-15],R=b[k-2],A=m(P,7)^m(P,18)^P>>>3,te=m(R,17)^m(R,19)^R>>>10;b[k]=b[k-16]+A+b[k-7]+te>>>0}let h=a,y=u,w=c,S=d,N=g,x=f,E=p,T=l;for(let k=0;k<64;k++){let P=m(N,6)^m(N,11)^m(N,25),R=N&x^~N&E,A=T+P+R+zn[k]+b[k]>>>0,te=m(h,2)^m(h,13)^m(h,22),ye=h&y^h&w^y&w,H=te+ye>>>0;T=E,E=x,x=N,N=S+A>>>0,S=w,w=y,y=h,h=A+H>>>0}a=a+h>>>0,u=u+y>>>0,c=c+w>>>0,d=d+S>>>0,g=g+N>>>0,f=f+x>>>0,p=p+E>>>0,l=l+T>>>0}let _=v=>v.toString(16).padStart(8,"0");return _(a)+_(u)+_(c)+_(d)+_(g)+_(f)+_(p)+_(l)}function ht(n){let e=pt(n??null),t=JSON.stringify(e);return Wn(t).slice(0,16)}function qn(){let n=globalThis.crypto;if(n?.randomUUID)return n.randomUUID();let e=()=>Math.floor(Math.random()*4294967296).toString(16).padStart(8,"0"),t=e()+e()+e()+e();return`${t.slice(0,8)}-${t.slice(8,12)}-4${t.slice(13,16)}-${(parseInt(t.slice(16,17),16)&3|8).toString(16)}${t.slice(17,20)}-${t.slice(20,32)}`}function gt(n,e,t){let r=t?.id??qn();if(n===0)return{id:r,version:0};let s=(t?.hash??ht)(e);return{id:r,version:0,cid:s,prev:null}}function Bt(n,e,t){n.version+=1,"cid"in n&&(n.prev=n.cid,n.cid=t(e))}var zn,Un,Ht=z(()=>{"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]),Un=new TextEncoder});function Wt(n){return{node:n,unsub:null,prevData:void 0,dirty:!1,involvedThisWave:!1,dataBatch:[],terminal:void 0}}function mt(n){n.prevData=void 0,n.dirty=!1,n.involvedThisWave=!1,n.dataBatch.length=0,n.terminal=void 0}function We(n){return n.length===0?n:typeof n[0]=="symbol"?[n]:n}function he(n,e,t){let r=qt(n)?n:[],o=typeof n=="function"?n:typeof e=="function"?e:void 0,s={};return qt(n)?s=(yt(e)?e:t)??{}:yt(n)?s=n:s=(yt(e)?e:t)??{},new j(r,o,s)}var zt,Ut,Kn,Jn,Ne,j,qt,yt,Oe=z(()=>{"use strict";it();at();ze();Ge();Lt();$e();pe();Ht();zt=()=>{},Ut=100;Kn=(n,e,t,r)=>{t.direction==="down-in"&&n._onDepMessage(t.depIndex,e)},Jn=(n,e,t,r)=>{let o=n;if(o._status==="completed"||o._status==="errored")return;let s=o._cached,i=s===void 0?[ut]:[ut,[F,s]];o._status==="dirty"&&i.push(ke),He(e,i,o._config.tierOf)},Ne=new Ue({onMessage:Kn,onSubscribe:Jn});jt(Ne);Gt(Ne);j=class n{_optsName;_describeKind;meta;_hasMeta;_config;_deps;_sinks=null;_sinkCount=0;_cached;_status;_cleanup;_store={};_waveHasNewData=!1;_hasNewTerminal=!1;_hasCalledFnOnce=!1;_paused=!1;_pendingWave=!1;_isExecutingFn=!1;_pendingRerun=!1;_rerunDepth=0;_dirtyDepCount=0;_batchPendingMessages=null;_pauseLocks=null;_pauseBuffer=null;_fn;_equals;_resubscribable;_resetOnTeardown;_autoComplete;_autoError;_pausable;_partial;_guard;_extraGuards;_hashFn;_versioning;_versioningLevel;_lastMutation;_inspectorHooks;_actions;constructor(e,t,r){this._config=r.config??Ne,this._config.onMessage,this._optsName=r.name,this._describeKind=r.describeKind,this._equals=r.equals??Object.is,this._resubscribable=r.resubscribable??!1,this._resetOnTeardown=r.resetOnTeardown??!1,this._autoComplete=r.completeWhenDepsComplete??!0,this._autoError=r.errorWhenDepsError??!0,this._pausable=r.pausable??!0,this._guard=r.guard,this._fn=t,this._partial=r.partial??!1,this._cached=r.initial!==void 0?r.initial:void 0,this._status=e.length===0&&t==null&&this._cached!==void 0?"settled":"sentinel",this._hashFn=r.versioningHash??this._config.defaultHashFn??ht;let o=r.versioning??this._config.defaultVersioning;this._versioningLevel=o,this._versioning=o!=null?gt(o,this._cached===void 0?void 0:this._cached,{id:r.versioningId,hash:this._hashFn}):void 0,this._deps=e.map(Wt);let s={};for(let[a,u]of Object.entries(r.meta??{})){let c={initial:u,name:`${r.name??"node"}:meta:${a}`,describeKind:"state",config:this._config};r.guard!=null&&(c.guard=r.guard),s[a]=new n([],void 0,c)}Object.freeze(s),this.meta=s,this._hasMeta=Object.keys(s).length>0;let i=this;this._actions={emit(a){i._emit([[F,a]])},down(a){i._emit(We(a))},up(a){i._emitUp(We(a))}},this.down=this.down.bind(this),this.up=this.up.bind(this)}get _isTerminal(){return this._status==="completed"||this._status==="errored"}get name(){return this._optsName}get status(){return this._status}get cache(){return this._cached===void 0?void 0:this._cached}get lastMutation(){return this._lastMutation}get v(){return this._versioning}hasGuard(){return this._guard!=null}_applyVersioning(e,t){if(this._isExecutingFn)throw new Error(`Node "${this.name}": _applyVersioning cannot run mid-fn \u2014 call it outside of \`_execFn\` (typically at graph setup time before the first subscribe).`);let r=this._versioningLevel;if(r!=null&&e<=r)return;let o=t?.hash??this._hashFn;o!==this._hashFn&&(this._hashFn=o);let s=this._cached===void 0?void 0:this._cached,i=this._versioning,a=i?.id??t?.id,u=i?.version??0,c=gt(e,s,{id:a,hash:o});c.version=u,this._versioning=c,this._versioningLevel=e}_setInspectorHook(e){return e==null?()=>{}:(this._inspectorHooks==null&&(this._inspectorHooks=new Set),this._inspectorHooks.add(e),()=>{this._inspectorHooks?.delete(e),this._inspectorHooks?.size===0&&(this._inspectorHooks=void 0)})}_pushGuard(e){return this._extraGuards==null&&(this._extraGuards=new Set),this._extraGuards.add(e),()=>{this._extraGuards?.delete(e),this._extraGuards?.size===0&&(this._extraGuards=void 0)}}allowsObserve(e){if(this._guard==null&&this._extraGuards==null)return!0;let t=Ie(e);if(this._guard!=null&&!this._guard(t,"observe"))return!1;if(this._extraGuards!=null){for(let r of this._extraGuards)if(!r(t,"observe"))return!1}return!0}_checkGuard(e){if(e?.internal)return;let t=this._guard!=null||this._extraGuards!=null,r=e?.actor!=null;if(!t&&!r)return;let o=Ie(e?.actor),s=e?.delivery==="signal"?"signal":"write";if(this._guard!=null&&!this._guard(o,s))throw new Q({actor:o,action:s,nodeName:this.name});if(this._extraGuards!=null){for(let i of this._extraGuards)if(!i(o,s))throw new Q({actor:o,action:s,nodeName:this.name})}this._lastMutation={actor:o,timestamp_ns:Se()}}down(e,t){let r=We(e);r.length!==0&&(this._checkGuard(t),this._emit(r))}emit(e,t){this._checkGuard(t),this._emit([[F,e]])}up(e,t){if(this._deps.length===0)return;let r=We(e);if(r.length===0)return;this._checkGuard(t);let o=t??{internal:!0};this._validateUpTiers(r);for(let s of this._deps)s.node.up?.(r,o)}_emitUp(e){if(this._deps.length!==0&&e.length!==0){this._validateUpTiers(e);for(let t of this._deps)t.node.up?.(e,{internal:!0})}}_validateUpTiers(e){let t=this._config.tierOf;for(let r of e){let o=t(r[0]);if(o===3||o===4)throw new Error(`Node "${this.name}": tier-${o} messages cannot flow up \u2014 DATA/RESOLVED/COMPLETE/ERROR are downstream-only. Use \`down(...)\` for value delivery; \`up(...)\` is for control signals (DIRTY, INVALIDATE, PAUSE, RESUME, TEARDOWN).`)}}subscribe(e,t){if(t!=null&&this._guard!=null){let u=Ie(t);if(!this._guard(u,"observe"))throw new Q({actor:u,action:"observe",nodeName:this.name})}let o=this._isTerminal&&this._resubscribable;if(o){this._cached=void 0,this._status="sentinel",this._store={},this._hasCalledFnOnce=!1,this._waveHasNewData=!1,this._hasNewTerminal=!1,this._paused=!1,this._pendingWave=!1,this._pendingRerun=!1,this._isExecutingFn=!1,this._rerunDepth=0,this._dirtyDepCount=0,this._pauseLocks=null,this._pauseBuffer=null;for(let u of this._deps)mt(u);if(this._partial===!1){for(let u of this._deps)if(u.prevData!==void 0||u.dataBatch.length!==0||u.terminal!==void 0||u.dirty)throw new Error(`resubscribable-reset invariant: DepRecord not fully reset for node ${this._optsName??"(anonymous)"}`)}}this._sinkCount+=1;let s;try{s=this._config.onSubscribe(this,e,{sinkCount:this._sinkCount,afterTerminalReset:o},this._actions)}catch(u){throw this._sinkCount-=1,u}this._sinks==null?this._sinks=e:typeof this._sinks=="function"?this._sinks=new Set([this._sinks,e]):this._sinks.add(e);let i=this._isTerminal;if(this._sinkCount===1&&!i)try{this._activate()}catch(u){if(this._sinkCount-=1,this._removeSink(e),this._sinkCount===0&&(this._status="sentinel"),typeof s=="function")try{s()}catch{}throw u}this._status==="sentinel"&&this._cached===void 0&&(this._status="pending");let a=!1;return()=>{a||(a=!0,this._sinkCount-=1,this._removeSink(e),typeof s=="function"&&s(),this._sinks==null&&this._deactivate())}}_removeSink(e){if(this._sinks===e)this._sinks=null;else if(this._sinks!=null&&typeof this._sinks!="function")if(this._sinks.delete(e),this._sinks.size===1){let[t]=this._sinks;this._sinks=t}else this._sinks.size===0&&(this._sinks=null)}_activate(){if(this._deps.length===0){this._fn&&this._execFn();return}this._dirtyDepCount=0;let e=this._deps.length,t=0;try{for(let r=0;r<e;r++){let o=r,s=this._deps[r];s.unsub=zt,s.unsub=s.node.subscribe(i=>{if(s.unsub===null)return;let a=this._config.tierOf,u=!1;for(let c of i)a(c[0])>=3&&(u=!0),this._config.onMessage(this,c,{direction:"down-in",depIndex:o},this._actions);u&&this._maybeRunFnOnSettlement()}),t++}}catch(r){this._deps[t].unsub=null;for(let o=0;o<t;o++){let s=this._deps[o];if(s.unsub!=null){let i=s.unsub;s.unsub=null;try{i()}catch{}mt(s)}}throw this._dirtyDepCount=0,r}}_addDep(e){for(let o=0;o<this._deps.length;o++)if(this._deps[o].node===e)return o;let t=this._deps.length,r=Wt(e);if(this._deps.push(r),this._sinks==null)return t;r.dirty=!0,this._dirtyDepCount++,this._status!=="dirty"&&this._emit(dt),r.unsub=zt;try{r.unsub=e.subscribe(o=>{if(r.unsub===null)return;let s=this._config.tierOf,i=!1;for(let a of o)s(a[0])>=3&&(i=!0),this._config.onMessage(this,a,{direction:"down-in",depIndex:t},this._actions);i&&this._maybeRunFnOnSettlement()})}catch(o){throw r.unsub=null,this._deps.pop(),this._dirtyDepCount--,o}return t}_deactivate(e=!1){let t=this._cleanup;if(this._cleanup=void 0,typeof t=="function")try{t()}catch(r){this._emit([[G,this._wrapFnError("cleanup threw",r)]])}else if(t!=null&&typeof t=="object"){let r=t.deactivate;if(typeof r=="function")try{r()}catch(o){this._emit([[G,this._wrapFnError("cleanup.deactivate threw",o)]])}}for(let r of this._deps){if(r.unsub!=null){let o=r.unsub;r.unsub=null;try{o()}catch{}}mt(r)}this._waveHasNewData=!1,this._hasNewTerminal=!1,this._hasCalledFnOnce=!1,this._paused=!1,this._pendingWave=!1,this._pendingRerun=!1,this._rerunDepth=0,this._store={},this._dirtyDepCount=0,this._pauseLocks=null,this._pauseBuffer=null,this._fn!=null&&(this._cached=void 0),e||(this._fn!=null||this._deps.length>0)&&(!this._isTerminal||this._resubscribable)&&(this._status="sentinel")}_onDepMessage(e,t){let r=this._deps[e],o=t[0];if(this._inspectorHooks!=null){let s={kind:"dep_message",depIndex:e,message:t};for(let i of this._inspectorHooks)i(s)}if(o!==Me){if(o===X){this._depDirtied(r);return}if(o===re){if(this._depInvalidated(r),this._cached===void 0)return;this._emit(Ft);return}if(o===se||o===ce){this._emit([t]);return}if(o===V){this._emit(lt);return}if(o===F)this._depSettledAsData(r,t[1]);else if(o===Z)this._depSettledAsResolved(r);else if(o===B)this._depSettledAsTerminal(r,!0);else if(o===G)this._depSettledAsTerminal(r,t[1]);else{this._emit([t]);return}if(!this._fn){(o===F||o===Z)&&this._emit([t]),(o===B||o===G)&&this._maybeAutoTerminalAfterWave();return}}}_depDirtied(e){e.dirty||(e.dirty=!0,e.involvedThisWave=!0,this._dirtyDepCount++,this._status!=="dirty"&&this._emit(dt))}_depSettledAsData(e,t){e.dirty&&(e.dirty=!1,this._dirtyDepCount--),e.involvedThisWave=!0,e.dataBatch.push(t),this._waveHasNewData=!0}_depSettledAsResolved(e){e.dirty&&(e.dirty=!1,this._dirtyDepCount--)}_depSettledAsTerminal(e,t){e.dirty&&(e.dirty=!1,this._dirtyDepCount--),e.terminal=t,e.involvedThisWave=!0,this._hasNewTerminal=!0}_depInvalidated(e){e.prevData=void 0,e.terminal=void 0,e.dataBatch.length=0,e.dirty?e.involvedThisWave=!1:(e.dirty=!0,e.involvedThisWave=!0,this._dirtyDepCount++)}_maybeRunFnOnSettlement(){if(!(this._isTerminal&&!this._resubscribable)&&!(this._dirtyDepCount>0)){if(!this._partial&&!this._hasCalledFnOnce)for(let e=0;e<this._deps.length;e++){let t=this._deps[e];if(t.dataBatch.length===0&&t.prevData===void 0&&t.terminal===void 0){this._maybeAutoTerminalAfterWave();return}}if(this._paused){this._pendingWave=!0;return}if(!this._waveHasNewData&&!this._hasNewTerminal&&this._hasCalledFnOnce){this._clearWaveFlags(),this._emit($t),this._maybeAutoTerminalAfterWave();return}this._fn&&this._execFn(),this._maybeAutoTerminalAfterWave()}}_maybeAutoTerminalAfterWave(){if(this._deps.length===0||this._isTerminal)return;let e=this._deps.find(t=>t.terminal!==void 0&&t.terminal!==!0);if(e!=null){this._autoError&&this._emit([[G,e.terminal]]);return}this._autoComplete&&this._deps.every(t=>t.terminal!==void 0)&&this._emit(Pt)}_execFn(){if(!this._fn||this._isTerminal&&!this._resubscribable)return;if(this._isExecutingFn){this._pendingRerun=!0;return}let e=this._cleanup;if(typeof e=="function"){this._cleanup=void 0;try{e()}catch(i){this._emit([[G,this._wrapFnError("cleanup threw",i)]]);return}}else if(e!=null&&typeof e=="object"){let i=e.beforeRun;if(typeof i=="function"){e.beforeRun=void 0;try{i()}catch(a){this._emit([[G,this._wrapFnError("cleanup.beforeRun threw",a)]]);return}}}let t=this._deps.map(i=>i.involvedThisWave?i.dataBatch.length>0?[...i.dataBatch]:[]:void 0),r=this._deps.map(i=>i.prevData);for(let i=0;i<this._deps.length;i++){let a=t[i];a!=null&&a.length>0&&(this._deps[i].prevData=a[a.length-1])}let o=this._deps.map(i=>i.terminal),s={prevData:r,terminalDeps:o,store:this._store};if(this._hasCalledFnOnce=!0,this._clearWaveFlags(),this._inspectorHooks!=null){let i={kind:"run",batchData:t,prevData:r};for(let a of this._inspectorHooks)a(i)}this._isExecutingFn=!0;try{let i=this._fn(t,this._actions,s);if(typeof i=="function")this._cleanup=i;else if(i!=null&&typeof i=="object"){let a=i;(typeof a.beforeRun=="function"||typeof a.deactivate=="function"||typeof a.invalidate=="function")&&(this._cleanup=i)}}catch(i){this._emit([[G,this._wrapFnError("fn threw",i)]])}finally{this._isExecutingFn=!1,this._pendingRerun?(this._pendingRerun=!1,this._rerunDepth+=1,this._rerunDepth>Ut?(this._rerunDepth=0,this._emit([[G,new Error(`Node "${this.name}": _pendingRerun depth exceeded ${Ut} \u2014 likely a reactive cycle`)]])):this._maybeRunFnOnSettlement()):this._rerunDepth=0,this._clearWaveFlags()}}_clearWaveFlags(){this._waveHasNewData=!1,this._hasNewTerminal=!1;for(let e of this._deps)e.involvedThisWave=!1,e.dataBatch.length=0}_wrapFnError(e,t){let r=t instanceof Error?t.message:String(t);return new Error(`Node "${this.name}": ${e}: ${r}`,{cause:t})}_frameBatch(e){let t=this._config.tierOf;if(e.length===1)return t(e[0][0])===3&&this._status!=="dirty"?[ke,e[0]]:e;let r=!0,o=!1,s=!1,i=-1;for(let u of e){let c=t(u[0]);c<i&&(r=!1),c===3&&(o=!0),u[0]===X&&(s=!0),i=c}let a=e;if(!r){let u=e.map((c,d)=>({m:c,i:d,tier:t(c[0])}));u.sort((c,d)=>c.tier-d.tier||c.i-d.i),a=u.map(c=>c.m)}if(o&&!s&&this._status!=="dirty"){let u=0;for(;u<a.length&&t(a[u][0])===0;)u++;return u===0?[ke,...a]:[...a.slice(0,u),ke,...a.slice(u)]}return a}_emit(e){if(e.length===0)return;for(let a=0;a<e.length;a++){let u=e[a];if(u[0]===G&&u[1]===void 0)throw new TypeError('[ERROR, payload] requires a non-undefined payload (spec \xA71.2). Pass an Error object or domain tag instead \u2014 e.g. node.down([[ERROR, new Error("reason")]])')}let t=e;if(this._isTerminal&&!this._resubscribable){let a=e.filter(u=>u[0]===V||u[0]===re);if(a.length===0)return;t=a}t=this._frameBatch(t);let o=null;for(let a=0;a<t.length;a++){let u=t[a],c=u[0];if(c!==se&&c!==ce){o?.push(u);continue}if(u.length<2)throw new Error(`Node "${this.name}": [[${c===se?"PAUSE":"RESUME"}]] must carry a lockId payload \u2014 bare PAUSE/RESUME is a protocol violation (C0 rule). Use \`[[PAUSE, lockId]]\` / \`[[RESUME, lockId]]\`.`);let d=!0;if(this._pausable!==!1){let g=u[1];if(c===se)this._pauseLocks==null&&(this._pauseLocks=new Set),this._pauseLocks.add(g),this._paused=!0,this._pausable==="resumeAll"&&this._pauseBuffer==null&&(this._pauseBuffer=[]);else if(this._pauseLocks==null||!this._pauseLocks.has(g))d=!1;else if(this._pauseLocks.delete(g),this._pauseLocks.size===0){if(this._paused=!1,this._pauseBuffer!=null&&this._pauseBuffer.length>0){let f=this._pauseBuffer;this._pauseBuffer=[],this._emit(f)}this._pendingWave&&(this._pendingWave=!1,this._maybeRunFnOnSettlement())}}d?o?.push(u):o==null&&(o=t.slice(0,a))}if(o!=null){if(o.length===0)return;t=o}if(this._hasMeta&&t.some(a=>a[0]===V))for(let a of Object.keys(this.meta))try{this.meta[a]._emit(lt)}catch{}let{finalMessages:s,equalsError:i}=this._updateState(t);if(s.length>0&&this._config.inspectorEnabled){let a=this._config.globalInspector;if(a!=null)try{a({kind:"emit",node:this,messages:s})}catch{}}if(s.length>0)if(this._paused&&this._pausable==="resumeAll"&&this._pauseBuffer!=null){let a=this._config.tierOf,u=[];for(let c of s)a(c[0])===3?this._pauseBuffer.push(c):u.push(c);u.length>0&&this._dispatchOrAccumulate(u)}else this._dispatchOrAccumulate(s);i!=null&&this._emit([[G,i]])}_updateState(e){let t=this._config.tierOf,r,o,s=-1,i=0;for(let d of e)t(d[0])===3&&i++;let a=i<=1,u=-1;if(this._versioning!=null&&i>1){for(let d=e.length-1;d>=0;d--)if(e[d][0]===F){u=d;break}}for(let d=0;d<e.length;d++){let g=e[d],f=g[0];if(f===F){if(g.length>=2){let p=!1;if(a&&this._cached!==void 0)try{p=this._equals(this._cached,g[1])}catch(l){o=this._wrapFnError("equals threw",l),s=d;break}if(p){r==null&&(r=e.slice(0,d)),r.push(ct),this._status="resolved";continue}this._cached=g[1],this._versioning!=null&&(u<0||d===u)&&Bt(this._versioning,g[1],this._hashFn)}this._status="settled",r?.push(g)}else if(r?.push(g),f===X)this._status="dirty";else if(f===Z)this._status="resolved";else if(f===B){this._status="completed";{let p=this._config.rigorRecorder;if(p!=null)try{p.onTerminalTransition(this,"completed",this._autoComplete,this._autoError,this._deps.length>0)}catch{}}}else if(f===G){this._status="errored";{let p=this._config.rigorRecorder;if(p!=null)try{p.onTerminalTransition(this,"errored",this._autoComplete,this._autoError,this._deps.length>0)}catch{}}}else if(f===re){if(this._cached!==void 0){let l=this._config.rigorRecorder;if(l!=null)try{l.onNonVacuousInvalidate(this,this._cached)}catch{}}this._cached=void 0,this._status="dirty";let p=this._cleanup;if(typeof p=="function"){this._cleanup=void 0;try{p()}catch{}}else if(p!=null&&typeof p=="object"){let l=p.invalidate;if(typeof l=="function")try{l()}catch{}}}else f===V&&(this._resetOnTeardown&&(this._cached=void 0),this._deactivate(!0),this._status="sentinel")}let c=s>=0?r??e.slice(0,s):r??e;return o!=null?{finalMessages:c,equalsError:o}:{finalMessages:c}}_deliverToSinks=e=>{if(this._sinks==null)return;if(typeof this._sinks=="function"){this._sinks(e);return}let t=[...this._sinks];for(let r of t)r(e)};_dispatchOrAccumulate(e){if(Mt()){this._batchPendingMessages===null&&(this._batchPendingMessages=[],_e(()=>this._flushBatchPending()));for(let t of e)this._batchPendingMessages.push(t);return}He(this._deliverToSinks,e,this._config.tierOf)}_flushBatchPending(){let e=this._batchPendingMessages;if(e===null||(this._batchPendingMessages=null,e.length===0))return;let t=this._frameBatch(e);He(this._deliverToSinks,t,this._config.tierOf)}},qt=n=>Array.isArray(n),yt=n=>typeof n=="object"&&n!=null&&!Array.isArray(n)});function oe(n,e){return he([],{...e,initial:n})}function xe(n,e){return he((r,o,s)=>n(o,s)??void 0,{describeKind:"producer",...e})}function ge(n,e,t){return he(n,(o,s,i)=>{let a=o.map((u,c)=>u!=null&&u.length>0?u.at(-1):i.prevData[c]);s.emit(e(a,i))},{describeKind:"derived",...t})}function qe(n,e,t){return he(n,(o,s,i)=>{let a=o.map((u,c)=>u!=null&&u.length>0?u.at(-1):i.prevData[c]);return e(a,s,i)??void 0},{describeKind:"effect",...t})}var Ke=z(()=>{"use strict";Oe()});function bt(n,e){if(e!=null&&e.length>0)return new Set(e);switch(n){case"standard":return new Set(["type","status","value","deps","meta","v"]);case"full":return null;case"spec":return new Set(["type","deps","meta","value"]);default:return new Set(["type","deps"])}}function Yn(n){return n._describeKind!=null?n._describeKind:n._deps.length>0?"derived":n._fn!=null?"producer":"state"}function Xn(n){let e={};for(let[t,r]of Object.entries(n.meta))try{e[t]=r.cache}catch{}return e}function vt(n,e,t){let r=e==null,o=!r&&e!=null?[...e].filter(d=>d.startsWith("meta.")).map(d=>d.slice(5)):null,s=r||e.has("meta")||o!=null&&o.length>0,i="state",a=[];n instanceof j&&(i=Yn(n),a=n._deps.map(d=>d.node.name??""));let u={type:i,deps:a};(r||e.has("status"))&&(u.status=n.status);let c=n instanceof j?n._guard:void 0;if(s){let d={...Xn(n)};if(c!=null&&d.access===void 0&&(d.access=ft(c)),o!=null&&o.length>0&&!e.has("meta")){let g={};for(let f of o)f in d&&(g[f]=d[f]);u.meta=g}else u.meta=d}if(n.name!=null&&(u.name=n.name),(r||e.has("value"))&&(!t||i==="state")){n.status==="sentinel"&&(u.sentinel=!0);try{u.value=n.cache}catch{}}if((r||e.has("v"))&&n.v!=null){let d={id:n.v.id,version:n.v.version};"cid"in n.v&&(d.cid=n.v.cid,d.prev=n.v.prev),u.v=d}return(r||e.has("guard"))&&c!=null&&(u.guard=ft(c)),(r||e.has("lastMutation"))&&n.lastMutation!=null&&(u.lastMutation=n.lastMutation),u}var Kt=z(()=>{"use strict";$e();Oe()});function Te(n){return n.subscribe(()=>{})}var Yt=z(()=>{"use strict"});var St=z(()=>{"use strict";Yt()});var Je,Xt=z(()=>{"use strict";Je=class{_timer;_gen=0;start(e,t){this.cancel(),this._gen+=1;let r=this._gen;this._timer=setTimeout(()=>{this._timer=void 0,r===this._gen&&t()},e)}cancel(){this._timer!==void 0&&(clearTimeout(this._timer),this._timer=void 0)}get pending(){return this._timer!==void 0}}});var Fe,Zt=z(()=>{"use strict";Fe=class{constructor(e){this.capacity=e;if(!Number.isInteger(e)||e<=0)throw new Error(`RingBuffer capacity must be a positive integer (got ${e})`);this.buf=new Array(e)}buf;head=0;_size=0;get size(){return this._size}get maxSize(){return this.capacity}push(e){let t=(this.head+this._size)%this.capacity;this.buf[t]=e,this._size<this.capacity?this._size++:this.head=(this.head+1)%this.capacity}shift(){if(this._size===0)return;let e=this.buf[this.head];return this.buf[this.head]=void 0,this.head=(this.head+1)%this.capacity,this._size--,e}at(e){if(this._size===0)return;let t=e<0?this._size+e:e;if(!(t<0||t>=this._size))return this.buf[(this.head+t)%this.capacity]}toArray(){let e=new Array(this._size);for(let t=0;t<this._size;t++)e[t]=this.buf[(this.head+t)%this.capacity];return e}clear(){for(let e=0;e<this._size;e++)this.buf[(this.head+e)%this.capacity]=void 0;this.head=0,this._size=0}}});function hn(n,e,t){return{[n]:!0,[`${n}_type`]:e,...t??{}}}var gn=z(()=>{"use strict"});var kr={};Mn(kr,{SNAPSHOT_WIRE_VERSION:()=>Rt,SurfaceError:()=>C,asSurfaceError:()=>Nn,createGraph:()=>tt,deleteSnapshot:()=>An,diffSnapshots:()=>Rn,listSnapshots:()=>En,restoreSnapshot:()=>Tn,runReduction:()=>On,saveSnapshot:()=>xn});module.exports=Fn(kr);Ke();at();ze();Ge();$e();pe();Kt();Oe();Ke();Ge();function wt(n,e){if(Object.is(n,e))return!0;if(n==null||e==null||typeof n!="object"||typeof e!="object")return!1;if(Array.isArray(n)){if(!Array.isArray(e)||n.length!==e.length)return!1;for(let s=0;s<n.length;s++)if(!wt(n[s],e[s]))return!1;return!0}if(Array.isArray(e))return!1;let t=Object.keys(n),r=Object.keys(e);if(t.length!==r.length)return!1;let o=new Set(r);for(let s of t)if(!o.has(s)||!wt(n[s],e[s]))return!1;return!0}function Jt(n,e){return`${n}\0${e}`}function _t(n,e){let t=[],r=new Set(n.subgraphs),o=new Set(e.subgraphs),s=[];for(let m of o)r.has(m)||s.push(m);s.sort();for(let m of s)t.push({type:"subgraph-mounted",path:m});let i=new Set(Object.keys(n.nodes)),a=new Set(Object.keys(e.nodes)),u=[];for(let m of a)i.has(m)||u.push(m);u.sort();for(let m of u)t.push({type:"node-added",path:m,node:{...e.nodes[m]}});let c=[];for(let m of a){if(!i.has(m))continue;let _=n.nodes[m]?.meta,v=e.nodes[m]?.meta;_==null&&v==null||wt(_??{},v??{})||c.push(m)}c.sort();for(let m of c)t.push({type:"node-meta-changed",path:m,prevMeta:n.nodes[m]?.meta??{},nextMeta:e.nodes[m]?.meta??{}});let d=new Map;for(let m of n.edges)d.set(Jt(m.from,m.to),m);let g=new Map;for(let m of e.edges)g.set(Jt(m.from,m.to),m);let f=[];for(let[m,_]of g)d.has(m)||f.push(_);f.sort((m,_)=>m.from<_.from?-1:m.from>_.from?1:m.to<_.to?-1:m.to>_.to?1:0);for(let m of f)t.push({type:"edge-added",from:m.from,to:m.to});let p=[];for(let[m,_]of d)g.has(m)||p.push(_);p.sort((m,_)=>m.from<_.from?-1:m.from>_.from?1:m.to<_.to?-1:m.to>_.to?1:0);for(let m of p)t.push({type:"edge-removed",from:m.from,to:m.to});let l=[];for(let m of i)a.has(m)||l.push(m);l.sort();for(let m of l)t.push({type:"node-removed",path:m});let b=[];for(let m of r)o.has(m)||b.push(m);b.sort();for(let m of b)t.push({type:"subgraph-unmounted",path:m});return{events:t,flushedAt_ns:ie()}}St();Xt();Zt();it();function Qt(n,e,t,r={}){let o=e in n.nodes,s=t in n.nodes;if(!o)return Ye(e,t,"no-such-from");if(!s)return Ye(e,t,"no-such-to");let i=r.maxDepth;if(i!=null&&(!Number.isInteger(i)||i<0))throw new Error("explainPath: maxDepth must be an integer >= 0");if(e===t){if(r.findCycle===!0){let c=Zn(n,e,r);if(c!=null)return c}let u=Xe(e,n.nodes[e],0,r);return Ze(e,t,[u])}if(i===0)return Ye(e,t,"no-path");let a=en(n,e,t,i);return a.found?Ze(e,t,tn(n,a.pathOrder,r)):Ye(e,t,a.truncated?"max-depth-exceeded":"no-path")}function en(n,e,t,r){let o=new Map,s=[{path:t,depth:0}],i=new Set([t]),a=0,u=!1;for(;a<s.length;){let g=s[a++];if(g.path===e)break;if(r!=null&&g.depth>=r){let b=n.nodes[g.path];b?.deps&&b.deps.length>0&&(u=!0);continue}let f=n.nodes[g.path];if(f==null)continue;let p=f.deps??[],l=new Map;for(let b=0;b<p.length;b++){let m=p[b];if(!m)continue;let _=l.get(m);_==null&&(_=[],l.set(m,_)),_.push(b)}for(let[b,m]of l)i.has(b)||(i.add(b),o.set(b,{from:g.path,depIndices:m}),s.push({path:b,depth:g.depth+1}))}if(!o.has(e))return{found:!1,pathOrder:[],truncated:u};let c=[{path:e}],d=e;for(;d!==t;){let g=o.get(d);if(g==null)return{found:!1,pathOrder:[],truncated:!1};c[c.length-1].depIndices=g.depIndices,c.push({path:g.from}),d=g.from}return{found:!0,pathOrder:c,truncated:!1}}function Zn(n,e,t){let r=n.nodes[e];if(r==null)return null;let o=r.deps??[],s=[];for(let a=0;a<o.length;a++)o[a]===e&&s.push(a);if(s.length>0){let a=Xe(e,r,0,t);a.dep_index=s[0];let u=Xe(e,r,1,t);return Ze(e,e,[a,u])}let i=null;for(let a=0;a<o.length;a++){let u=o[a];if(!u||u===e)continue;let c=en(n,u,e,t.maxDepth);c.found&&(i==null||c.pathOrder.length<i.pathOrder.length)&&(i=c,i={found:!0,pathOrder:[{path:e,depIndices:[a]},...c.pathOrder],truncated:!1})}return i==null?null:Ze(e,e,tn(n,i.pathOrder,t))}function tn(n,e,t){return e.map((r,o)=>{let s=n.nodes[r.path],i=Xe(r.path,s,o,t);return r.depIndices!=null&&r.depIndices.length>0&&(i.dep_index=r.depIndices[0],r.depIndices.length>1&&(i.dep_indices=[...r.depIndices])),i})}function Xe(n,e,t,r){let o={path:n,type:e.type,hop:t};e.status!==void 0&&(o.status=e.status),"value"in e&&(o.value=e.value),e.v!=null&&(o.v=e.v);let s=r.annotations?.get(n)??e.annotation;s!=null&&(o.annotation=s);let i=r.lastMutations?.get(n)??e.lastMutation;return i!=null&&(o.lastMutation=i),o}function Ze(n,e,t){return nn(n,e,!0,"ok",t)}function Ye(n,e,t){return nn(n,e,!1,t,[])}function nn(n,e,t,r,o){let s=Qn(n,e,t,r,o);return{from:n,to:e,found:t,reason:r,steps:o,text:s,toJSON(){return{from:n,to:e,found:t,reason:r,steps:o}}}}function Qn(n,e,t,r,o){if(!t)switch(r){case"no-such-from":return`explainPath: no node named "${n}"`;case"no-such-to":return`explainPath: no node named "${e}"`;case"max-depth-exceeded":return`explainPath: no path from "${n}" to "${e}" within maxDepth`;default:return`explainPath: no path from "${n}" to "${e}"`}let s=[`Causal path: ${n} \u2192 ${e} (${o.length} step(s))`];for(let i of o){let u=` ${i.hop===0?"\xB7":"\u2193"} ${i.path} (${i.type}${i.status?`/${i.status}`:""})`;if(s.push(u),"value"in i&&s.push(` value: ${er(i.value)}`),i.annotation!=null&&s.push(` annotation: ${i.annotation}`),i.lastMutation!=null){let c=i.lastMutation.actor;s.push(` actor: ${c.type}${c.id?`:${c.id}`:""}`)}}return s.join(`
|
|
2
|
+
`)}function er(n){if(n===void 0)return"<sentinel>";if(n===null)return"null";if(typeof n=="string")return JSON.stringify(n);if(typeof n=="number"||typeof n=="boolean"||typeof n=="bigint")return String(n);try{let e=JSON.stringify(n);return e.length>80?`${e.slice(0,77)}...`:e}catch{return String(n)}}Oe();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},tr=Symbol.for("sizeof");function rn(n){let e=new WeakSet,t=new WeakSet,r=[n],o=0;for(;r.length>0;){let s=r.pop();o+=nr(s,e,t,r)}return o}function nr(n,e,t,r){if(n==null)return 0;switch(typeof n){case"number":return L.number;case"boolean":return L.boolean;case"string":return L.string+n.length*2;case"bigint":return L.bigint+rr(n);case"symbol":return L.symbol;case"function":return e.has(n)?0:(e.add(n),L.function);case"undefined":return 0}let s=n;if(e.has(s))return 0;e.add(s);let i=s[tr];if(typeof i=="function")try{let c=i.call(s);if(typeof c=="number"&&Number.isFinite(c))return c}catch{}if(s instanceof Date)return L.date;if(s instanceof RegExp)return L.regexp+s.source.length*2;if(s instanceof Error){let c=s.message?s.message.length*2:0,d=s.stack?s.stack.length*2:0;return L.error+c+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 c=L.map;for(let[d,g]of s)c+=L.mapEntry,r.push(d),r.push(g);return c}if(s instanceof Set){let c=L.set;for(let d of s)c+=L.setEntry,r.push(d);return c}if(Array.isArray(s)){let c=L.array+s.length*8;for(let d of s)r.push(d);return c}if(s instanceof ArrayBuffer)return t.has(s)?0:(t.add(s),s.byteLength);if(ArrayBuffer.isView(s)){let c=s;return t.has(c.buffer)?48:(t.add(c.buffer),c.buffer.byteLength+48)}let a=L.object,u=Object.keys(s);for(let c of u){a+=L.string+c.length*2;try{r.push(s[c])}catch{}}return a}function rr(n){let e=n<0n?-n:n;if(e===0n)return 0;let t=e.toString(2).length;return Math.ceil(t/32)*8}function sn(n,e){let t=e?.topN??10,r=n.describe({detail:"standard"}),o=[],s=n._collectObserveTargets;typeof s=="function"&&s.call(n,"",o);let i=new Map;for(let[f,p]of o)i.set(f,p);let a=[];for(let[f,p]of Object.entries(r.nodes)){let l=i.get(f),b=l instanceof j?l:null,m=b?rn(b.cache):0,_=b?b._sinkCount:0,v=p.deps?.length??0,h=p.type==="effect"&&_===0,y=_===0?p.type==="effect"?"orphan-effect":p.type==="derived"?"idle-derived":p.type==="producer"?"idle-producer":null:null;a.push({path:f,type:p.type,status:p.status??"unknown",valueSizeBytes:m,subscriberCount:_,depCount:v,isOrphanEffect:h,orphanKind:y})}let u=a.reduce((f,p)=>f+p.valueSizeBytes,0),c=(f,p)=>[...a].sort(p??((l,b)=>b[f]-l[f])).slice(0,t),d=a.filter(f=>f.orphanKind!=null),g=a.filter(f=>f.isOrphanEffect);return{nodeCount:a.length,edgeCount:r.edges.length,subgraphCount:r.subgraphs.length,nodes:a,totalValueSizeBytes:u,hotspots:{byValueSize:c("valueSizeBytes"),bySubscriberCount:c("subscriberCount"),byDepCount:c("depCount")},orphans:d,orphanEffects:g}}var $="::",ee="__meta__",de=1;function on(n,e){let t=Math.max(16,n.size*4),r=0;for(;n.size>0;){if(r++>=t){console.error(`[Graph "${e}".destroy] disposer drain exceeded cap (${t}); ${n.size} disposer(s) discarded`),n.clear();return}let o=n.values().next();if(o.done)return;let s=o.value;n.delete(s);try{s()}catch(i){console.error(`[Graph "${e}".destroy] disposer threw:`,i)}}}function fn(n){return n!=null&&typeof n=="object"&&"cache"in n&&typeof n.subscribe=="function"&&typeof n.down=="function"}function sr(n){if(n!=null)return fn(n)?n.cache:n}function me(n){return n!=null&&typeof n=="object"&&"cache"in n&&typeof n.subscribe=="function"&&typeof n.down=="function"}function ue(n){return me(n)?n.cache??"":n}function an(n){return me(n)?n.cache??0:n}function cn(n){return me(n)?n.cache??!1:n}function or(n){let e=[];for(let t of Object.keys(n).sort()){let r=n[t].v;r!=null&&e.push(`${t} ${r.id} ${r.version}`)}return e.join(`
|
|
3
|
+
`)}function un(n){if(n.version!==de)throw new Error(`unsupported snapshot version ${String(n.version)} (expected ${de})`);for(let e of["name","nodes","edges","subgraphs"])if(!(e in n))throw new Error(`snapshot missing required key "${e}"`);if(typeof n.name!="string")throw new TypeError("snapshot 'name' must be a string");if(typeof n.nodes!="object"||n.nodes===null||Array.isArray(n.nodes))throw new TypeError("snapshot 'nodes' must be an object");if(!Array.isArray(n.edges))throw new TypeError("snapshot 'edges' must be an array");if(!Array.isArray(n.subgraphs))throw new TypeError("snapshot 'subgraphs' must be an array")}function ir(n,e){let t=new WeakMap,r=(o,s)=>{if(Object.is(o,s))return!0;if(o==null||s==null||typeof o!="object"||typeof s!="object")return!1;let i=t.get(o);if(i==null&&(i=new WeakSet,t.set(o,i)),i.has(s))return!0;i.add(s);let a=o.constructor,u=s.constructor;if(a!==u)return!1;if(o instanceof Date)return o.getTime()===s.getTime();if(o instanceof RegExp)return o.source===s.source&&o.flags===s.flags;if(Array.isArray(o)){let f=s;if(o.length!==f.length)return!1;for(let p=0;p<o.length;p++)if(!r(o[p],f[p]))return!1;return!0}if(o instanceof Map){let f=s;if(o.size!==f.size)return!1;for(let[p,l]of o)if(!f.has(p)||!r(l,f.get(p)))return!1;return!0}if(o instanceof Set){let f=s;if(o.size!==f.size)return!1;for(let p of o){let l=!1;for(let b of f)if(r(p,b)){l=!0;break}if(!l)return!1}return!0}if(ArrayBuffer.isView(o)){let f=o,p=s;if(f.length!==p.length)return!1;for(let l=0;l<f.length;l++)if(f[l]!==p[l])return!1;return!0}let c=Object.keys(o),d=Object.keys(s);if(c.length!==d.length)return!1;let g=new Set(d);for(let f of c)if(!g.has(f)||!r(o[f],s[f]))return!1;return!0};return r(n,e)}function ar(n){return n.replace(/[.*+?^${}()|[\]\\]/g,"\\$&")}function Qe(n){let e="^";for(let t=0;t<n.length;t+=1){let r=n[t];if(r==="*"){e+=".*";continue}if(r==="?"){e+=".";continue}if(r==="["){let o=n.indexOf("]",t+1);if(o<=t+1){e+="\\[";continue}let s=n.slice(t+1,o);s.startsWith("!")&&(s=`^${s.slice(1)}`),s=s.replace(/\\/g,"\\\\"),e+=`[${s}]`,t=o;continue}e+=ar(r)}return e+="$",new RegExp(e)}var cr={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"},ur={data:"",dirty:"",resolved:"",invalidate:"",pause:"",resume:"",complete:"",error:"",teardown:"",derived:"",path:"",reset:""};function kt(n){if(typeof n=="string")return JSON.stringify(n);if(typeof n=="number"||typeof n=="boolean"||n==null)return String(n);try{return JSON.stringify(n)}catch{return"[unserializable]"}}function dr(n){return n==="none"?ur:n==="ansi"||n==null?cr:{data:n.data??"",dirty:n.dirty??"",resolved:n.resolved??"",invalidate:n.invalidate??"",pause:n.pause??"",resume:n.resume??"",complete:n.complete??"",error:n.error??"",teardown:n.teardown??"",derived:n.derived??"",path:n.path??"",reset:n.reset??""}}function dn(n){if(n==null)return{};let e=n.detail;return e==="full"?{...n,structured:n.structured??!0,timeline:n.timeline??!0,causal:n.causal??!0,derived:n.derived??!0}:e==="minimal"?{...n,structured:n.structured??!0}:n.format==="stage-log"?{...n,structured:n.structured??!0,timeline:n.timeline??!0}:n}function lr(n,e,t){for(let r=0;r<n.length;r++){let o=n.charCodeAt(r);if(o<32||o===127)throw new Error(`Graph "${e}": ${t} "${n}" must not contain control character (U+${o.toString(16).padStart(4,"0").toUpperCase()} at index ${r})`)}}function Nt(n,e,t){if(n==="")throw new Error(`Graph "${e}": ${t} name must be non-empty`);if(n.includes($))throw new Error(`Graph "${e}": ${t} "${n}" must not contain '${$}' (path separator)`);if(n===ee)throw new Error(`Graph "${e}": ${t} name "${ee}" is reserved for meta companion paths`);lr(n,e,t)}function fr(n,e){if(n==="")throw new Error(`Graph "${e}": resolve path must be non-empty`);let t=n.split($);for(let r of t)if(r==="")throw new Error(`Graph "${e}": resolve path has empty segment`);return t}function pr(n,e){let t=!1;for(let o of n)if(!e.isMetaPassthrough(o[0])){t=!0;break}return t?n.filter(o=>e.isMetaPassthrough(o[0])):n}function pn(n){for(let e of n._mounts.values())pn(e);for(let e of n._nodes.values())try{e.down([[V]],{internal:!0})}catch{}}var ae=class n{name;opts;config;_nodes=new Map;_nodeToName=new WeakMap;_mounts=new Map;_parent=void 0;_storageDisposers=new Set;_disposers=new Set;_destroyed=!1;_topology;_topologyEmitters=new Set;_factory;_factoryArgs;constructor(e,t){if(e==="")throw new Error("Graph name must be non-empty");if(e.includes($))throw new Error(`Graph name must not contain '${$}' (got "${e}")`);if(e===ee)throw new Error(`Graph name "${ee}" is reserved for meta companion paths`);this.name=e,this.opts=Object.freeze({...t??{}}),this.config=t?.config??Ne,this._traceRing=new Fe(t?.traceCapacity??1e3),t?.versioning!=null&&this.setVersioning(t.versioning),typeof t?.factory=="string"&&(this._factory=t.factory,t.factoryArgs!==void 0&&(this._factoryArgs=t.factoryArgs))}tagFactory(e,t){return this._factory=e,this._factoryArgs=t,this}ancestors(e=!0){let t=[],r=e?this:this._parent;for(;r!=null;)t.push(r),r=r._parent;return t}get topology(){return this._topology==null&&(this._topology=xe(e=>{let t=r=>{e.emit(r)};return this._topologyEmitters.add(t),()=>{this._topologyEmitters.delete(t)}},{name:`${this.name}_topology`})),this._topology}_emitTopology(e){if(!(this._topology==null||this._topologyEmitters.size===0))for(let t of this._topologyEmitters)t(e)}nameOf(e){return this._nodeToName.get(e)}add(e,t){let r=e.name,o=t?.name??r;if(o==null||o==="")throw new Error(`Graph "${this.name}": graph.add requires a non-empty name \u2014 pass via opts.name or set it on the node (e.g. state(0, { name: "x" }))`);let s=o,i=t?.annotation;if(Nt(s,this.name,"add"),this._mounts.has(s))throw new Error(`Graph "${this.name}": name "${s}" is already a mount point`);if(this._nodes.has(s))throw new Error(`Graph "${this.name}": node "${s}" already exists`);let a=this._nodeToName.get(e);if(a!==void 0)throw new Error(`Graph "${this.name}": node instance already registered as "${a}"`);return this._nodes.set(s,e),this._nodeToName.set(e,s),this._emitTopology({kind:"added",name:s,nodeKind:"node"}),i!=null&&(this._annotations.set(s,i),this.config.inspectorEnabled&&this._traceRing.push({path:s,annotation:i,timestamp_ns:ie()})),e}setVersioning(e){if(e!=null)for(let t of this._nodes.values())t instanceof j&&t._applyVersioning(e)}remove(e){Nt(e,this.name,"remove");let t=this._mounts.get(e);if(t){let s={kind:"mount",nodes:[],mounts:[]},i=[];t._collectObserveTargets("",i);for(let[a,u]of i)a.includes(`${$}${ee}${$}`)||s.nodes.push(a);return s.nodes.sort(),s.mounts.push(e),s.mounts.push(...t._collectSubgraphs(`${e}${$}`)),this._mounts.delete(e),t._parent=void 0,pn(t),this._emitTopology({kind:"removed",name:e,nodeKind:"mount",audit:s}),s}let r=this._nodes.get(e);if(!r)throw new Error(`Graph "${this.name}": unknown node or mount "${e}"`);this._nodes.delete(e),this._nodeToName.delete(r),r.down([[V]],{internal:!0});let o={kind:"node",nodes:[e],mounts:[]};return this._emitTopology({kind:"removed",name:e,nodeKind:"node",audit:o}),o}removeAll(e){let t=typeof e=="function"?e:(()=>{let s=Qe(e);return i=>s.test(i)})(),r={kind:"mount",nodes:[],mounts:[]},o=[...this._nodes.keys(),...this._mounts.keys()].filter(s=>t(s));for(let s of o){let i=this.remove(s);r.nodes.push(...i.nodes),r.mounts.push(...i.mounts)}return r.nodes.sort(),r.mounts.sort(),r}[Symbol.iterator](){let e=[...this._nodes.keys()].sort(),t=this._nodes,r=0;return{[Symbol.iterator](){return this},next(){if(r>=e.length)return{value:void 0,done:!0};let o=e[r++];return{value:[o,t.get(o)],done:!1}}}}node(e){if(e==="")throw new Error(`Graph "${this.name}": node name must be non-empty`);if(e.includes($))return this.resolve(e);let t=this._nodes.get(e);if(!t)throw new Error(`Graph "${this.name}": unknown node "${e}"`);return t}get(e){return this.node(e).cache}set(e,t,r){let o=r?.internal===!0;this.node(e).down([[F,t]],{actor:r?.actor,internal:o,delivery:"write"})}setAll(e,t){let r=Symbol.iterator in e?e:Object.entries(e);Be(()=>{for(let[o,s]of r)this.set(o,s,t)})}invalidate(e,t){let r=t?.internal===!0;this.node(e).down([[re]],{actor:t?.actor,internal:r,delivery:"write"})}error(e,t,r){let o=r?.internal===!0;this.node(e).down([[G,t]],{actor:r?.actor,internal:o,delivery:"write"})}complete(e,t){let r=t?.internal===!0;this.node(e).down([[B]],{actor:t?.actor,internal:r,delivery:"write"})}edges(e){let t=e?.recursive===!0,r=new Map;if(!t){for(let[u,c]of this._nodes)r.set(c,u);let a=[];for(let[u,c]of this._nodes)if(c instanceof j)for(let d of c._deps){let g=r.get(d.node);g!=null&&a.push([g,u])}return a.sort((u,c)=>u[0]<c[0]?-1:u[0]>c[0]?1:u[1]<c[1]?-1:u[1]>c[1]?1:0),a}let o=[];this._collectObserveTargets("",o);let s=new Map;for(let[a,u]of o)s.set(u,a);let i=[];for(let[a,u]of o)if(u instanceof j)for(let c of u._deps){let d=s.get(c.node);d!=null&&i.push([d,a])}return i.sort((a,u)=>a[0]<u[0]?-1:a[0]>u[0]?1:a[1]<u[1]?-1:a[1]>u[1]?1:0),i}mount(e,t){if(t===void 0){let o=new n(e);return this.mount(e,o)}if(typeof t=="function"){let o=new n(e);return t(o),this.mount(e,o)}let r=t;if(Nt(e,this.name,"mount"),this._nodes.has(e))throw new Error(`Graph "${this.name}": cannot mount at "${e}" \u2014 node with that name exists`);if(this._mounts.has(e))throw new Error(`Graph "${this.name}": mount "${e}" already exists`);if(r===this)throw new Error(`Graph "${this.name}": cannot mount a graph into itself`);if(r._parent!=null)throw new Error(`Graph "${this.name}": this child graph is already mounted on "${r._parent.name}"`);for(let o=this;o!=null;o=o._parent)if(o===r)throw new Error(`Graph "${this.name}": mount("${e}", \u2026) would create a mount cycle`);return this._mounts.set(e,r),r._parent=this,this._emitTopology({kind:"added",name:e,nodeKind:"mount"}),r}resolve(e){let t=fr(e,this.name);return this._resolveFromSegments(t)}tryResolve(e){try{return this.resolve(e)}catch{return}}_resolveFromSegments(e){let t=e;if(t[0]===this.name&&(t=t.slice(1),t.length===0))throw new Error(`Graph "${this.name}": resolve path ends at graph name only`);let r=t[0],o=t.slice(1);if(o.length===0){let a=this._nodes.get(r);if(a)return a;throw this._mounts.has(r)?new Error(`Graph "${this.name}": path ends at subgraph "${r}" \u2014 not a node (GRAPHREFLY-SPEC \xA73.5)`):new Error(`Graph "${this.name}": unknown name "${r}"`)}let s=this._nodes.get(r);if(s&&o.length>0&&o[0]===ee)return this._resolveMetaChainFromNode(s,o,t.join($));let i=this._mounts.get(r);if(!i)throw this._nodes.has(r)?new Error(`Graph "${this.name}": "${r}" is a node; trailing path "${o.join($)}" is invalid`):new Error(`Graph "${this.name}": unknown mount or node "${r}"`);return i.resolve(o.join($))}_resolveMetaChainFromNode(e,t,r){let o=e,s=0,i=[...t];for(;s<i.length;){if(i[s]!==ee)throw new Error(`Graph "${this.name}": expected ${ee} segment in meta path "${r}"`);if(s+1>=i.length)throw new Error(`Graph "${this.name}": meta path requires a key after ${ee} in "${r}"`);let a=i[s+1],u=o.meta[a];if(!u)throw new Error(`Graph "${this.name}": unknown meta "${a}" in path "${r}"`);o=u,s+=2}return o}signal(e,t){if(t?.internal!==!0){for(let o of e)if(this.config.messageTier(o[0])===3)throw new Error(`Graph "${this.name}": Graph.signal() rejects tier-3 messages (DATA / RESOLVED). Broadcast is for control-plane tiers (START / DIRTY / INVALIDATE / PAUSE / RESUME / COMPLETE / ERROR / TEARDOWN). For per-node value writes, use Graph.set or graph.node(name).down(...).`)}let r=[];if(this._signalDeliver(e,t??{},new Set,r),r.length>0)throw r[0]}_signalDeliver(e,t,r,o){for(let u of this._mounts.values())u._signalDeliver(e,t,r,o);let i=t.internal===!0?{internal:!0}:{actor:t.actor,delivery:"signal"},a=pr(e,this.config);for(let u of[...this._nodes.keys()].sort()){let c=this._nodes.get(u);if(!r.has(c)){r.add(c);try{c.down(e,i)}catch(d){if(d instanceof Q)throw d;o.push(d)}a.length!==0&&this._signalMetaSubtree(c,a,r,i,o)}}}_signalMetaSubtree(e,t,r,o,s){for(let i of Object.keys(e.meta).sort()){let a=e.meta[i];if(!r.has(a)){r.add(a);try{a.down(t,o)}catch(u){if(u instanceof Q)throw u;s.push(u)}this._signalMetaSubtree(a,t,r,o,s)}}}describe(e){if(e?.reactive==="diff")return this._describeReactiveDiff(e);if(e?.reactive===!0)return this._describeReactive(e);let t=sr(e?.actor),r=e?.filter;if(e?.detail!=null&&e?.fields!=null)throw new TypeError("Graph.describe(): pass either `detail` or `fields`, not both. `detail: 'spec'` is the canonical spec projection; use `fields` only when you need a custom subset.");let o=bt(e?.detail,e?.fields),s=e?.detail==="spec",i=o,a=[];this._collectObserveTargets("",a);let u=new Map;for(let[y,w]of a)u.set(w,y);let c=[];{let y=a.map(([,N])=>N),w=new Set(u.values()),S=0;for(;y.length>0;){let N=y.shift();if(N instanceof j)for(let x of N._deps){let E=x.node;if(u.has(E))continue;let T=E.name??"",k=T;if(!k||w.has(k))if(T){let P=2;for(;w.has(`${T}#${P}`);)P++;k=`${T}#${P}`}else for(k=`__internal__/${S++}`;w.has(k);)k=`__internal__/${S++}`;u.set(E,k),w.add(k),c.push([k,E]),y.push(E)}}}let d=[...a,...c],g={};for(let[y,w]of d){if(t!=null&&!w.allowsObserve(t))continue;let S=vt(w,i,s),N=w instanceof j?w._deps.map(k=>u.get(k.node)??k.node.name??""):[],{name:x,...E}=S,T={...E,deps:N};if(!s){let k=this._annotations.get(y);k!=null&&(T.annotation=k)}if(r!=null)if(typeof r=="function"){let k=r;if(!(k.length>=2?k(y,T):k(T)))continue}else{let k=!0;for(let[P,R]of Object.entries(r)){let A=P==="deps_includes"?"depsIncludes":P==="meta_has"?"metaHas":P;if(A==="depsIncludes"){if(!T.deps.includes(String(R))){k=!1;break}continue}if(A==="metaHas"){if(!Object.hasOwn(T.meta??{},String(R))){k=!1;break}continue}if(T[A]!==R){k=!1;break}}if(!k)continue}g[y]=T}let f=new Set(Object.keys(g)),p=[];for(let[y,w]of d)if(w instanceof j)for(let S of w._deps){let N=u.get(S.node);N!=null&&p.push([N,y])}p.sort((y,w)=>y[0]<w[0]?-1:y[0]>w[0]?1:y[1]<w[1]?-1:y[1]>w[1]?1:0);let l=p.map(([y,w])=>({from:y,to:w}));(t!=null||r!=null)&&(l=l.filter(y=>f.has(y.from)&&f.has(y.to)));let b=this._collectSubgraphs(""),m=t!=null||r!=null?b.filter(y=>{let w=`${y}${$}`;return[...f].some(S=>S===y||S.startsWith(w))}):b,_=this,v=e;return{name:this.name,nodes:g,edges:l,subgraphs:m,...this._factory!==void 0?{factory:this._factory}:{},...this._factoryArgs!==void 0?{factoryArgs:this._factoryArgs}:{},expand(y){let w={...v};return Array.isArray(y)?(w.fields=y,w.detail=void 0):(w.detail=y,w.fields=void 0),_.describe(w)}}}_collectSubgraphs(e){let t=[];for(let r of[...this._mounts.keys()].sort()){let o=e===""?r:`${e}${r}`;t.push(o),t.push(...this._mounts.get(r)._collectSubgraphs(`${o}${$}`))}return t}resourceProfile(e){return sn(this,e)}reachable(e,t,r={}){return r.withDetail===!0?ln(this.describe(),e,t,{...r,withDetail:!0}):ln(this.describe(),e,t,r)}explain(e,t,r){return r?.reactive===!0?this._explainReactive(e,t,r):this._explainStatic(ue(e),ue(t),{...r?.maxDepth!==void 0?{maxDepth:an(r.maxDepth)}:{},...r?.findCycle!==void 0?{findCycle:cn(r.findCycle)}:{}})}_explainStatic(e,t,r){let o=this.describe({detail:"full"}),s=new Map(this._annotations),i=new Map;for(let[a,u]of Object.entries(o.nodes))u.lastMutation!=null&&i.set(a,u.lastMutation);return Qt(o,e,t,{...r?.maxDepth!=null?{maxDepth:r.maxDepth}:{},...r?.findCycle===!0?{findCycle:!0}:{},annotations:s,lastMutations:i})}_describeReactive(e){let t={...e,reactive:!1},r=e.reactiveName??"describe",o=0,s=oe(o,{name:`${r}_version`}),i=this.observe({timeline:!0,structured:!0}),a=!1,u=!1,c=()=>{a||u||(a=!0,_e(()=>{a=!1,!u&&(o+=1,s.emit(o))}))},d=i.onEvent(v=>{let h=v.type;h!=="data"&&h!=="error"&&h!=="complete"&&h!=="teardown"||c()}),g=[],f=new WeakSet,p=v=>{if(f.has(v)||u)return;f.add(v);let h=v.topology.subscribe(y=>{for(let w of y){if(w[0]!==F)continue;let S=w[1];if(c(),S.kind==="added"&&S.nodeKind==="mount"){let N=v._mounts.get(S.name);N!=null&&p(N)}}});g.push(h);for(let y of v._mounts.keys()){let w=v._mounts.get(y);w!=null&&p(w)}};p(this);let l,b=e.actor;fn(b)&&(l=b.subscribe(v=>{let h=!1,y=!1;for(let w of v){let S=w[0];S===F?h=!0:(S===B||S===G||S===V)&&(y=!0)}h&&c(),y&&(l?.(),l=void 0,c())}));let m;try{m=ge([s],()=>this.describe(t),{name:r,describeKind:"derived",meta:{domain:"audit",kind:"describe"},equals:(v,h)=>v===h})}catch(v){d(),l?.();for(let h of g)h();throw i.dispose(),v}let _=Te(m);return{node:m,dispose(){u=!0,d(),l?.();for(let v of g)v();g.length=0,i.dispose(),_()}}}_describeReactiveDiff(e){let t={...e,reactive:!1},r=e.reactiveName??"describe-diff",o={name:this.name,nodes:{},edges:[],subgraphs:[]},s=this.describe(t),i=_t(o,s),a=oe(i,{name:r,meta:{domain:"audit",kind:"describe-diff"},equals:(f,p)=>f===p}),u=this._describeReactive({...e,reactiveName:void 0}),c=!1,d=u.node.subscribe(f=>{if(!c)for(let p of f){if(p[0]!==F)continue;let l=p[1],b=_t(s,l);s=l,b.events.length!==0&&a.emit(b)}}),g=Te(a);return{node:a,dispose(){c=!0,d(),u.dispose(),a.down([[V,"describe-diff disposed"]]),g()}}}_explainReactive(e,t,r){let o=0,s=oe(o,{name:"explain_version"}),i=this.observe({timeline:!0,structured:!0}),a=!1,u=!1,c=()=>{a||u||(a=!0,_e(()=>{a=!1,!u&&(o+=1,s.emit(o))}))},d=i.onEvent(v=>{let h=v.type;h!=="data"&&h!=="error"&&h!=="complete"&&h!=="teardown"||c()}),g=[];e!=null&&me(e)&&g.push(e),t!=null&&me(t)&&g.push(t),r?.maxDepth!=null&&me(r.maxDepth)&&g.push(r.maxDepth),r?.findCycle!=null&&me(r.findCycle)&&g.push(r.findCycle);let f=()=>{for(let v of g)if(v.cache===void 0)return!1;return!0},p=()=>{let v=ue(e),h=ue(t);return{from:v,to:h,found:!1,reason:"pending",steps:[],text:"(awaiting reactive args)",toJSON:()=>({from:v,to:h,found:!1,reason:"pending",steps:[]})}},l;try{l=ge([s],()=>{if(!f())return p();let v=ue(e),h=ue(t),y={...r?.maxDepth!==void 0?{maxDepth:an(r.maxDepth)}:{},...r?.findCycle!==void 0?{findCycle:cn(r.findCycle)}:{}};return this._explainStatic(v,h,y)},{name:r?.name??"explain",describeKind:"derived",meta:{domain:"audit",kind:"explain_path",from:ue(e),to:ue(t)},equals:(v,h)=>v.found===h.found&&v.reason===h.reason&&v.steps.length===h.steps.length&&gr(v.steps,h.steps)})}catch(v){throw d(),i.dispose(),v}let b=Te(l),m=[],_=v=>{let h;return h=v.subscribe(y=>{let w=!1,S=!1;for(let N of y){let x=N[0];x===F?w=!0:(x===B||x===G||x===V)&&(S=!0)}(w||S)&&c(),S&&h&&(h(),h=void 0)}),()=>{h&&(h(),h=void 0)}};for(let v of g)m.push(_(v));return{node:l,dispose(){u=!0,d();for(let v of m)v?.();m.length=0,i.dispose(),b()}}}_pathsMatching(e){let t=Qe(e),r=[];return this._collectObserveTargets("",r),r.map(([o])=>o).filter(o=>t.test(o))}_collectObserveTargets(e,t){for(let r of[...this._mounts.keys()].sort()){let o=e===""?r:`${e}${$}${r}`;this._mounts.get(r)._collectObserveTargets(o,t)}for(let r of[...this._nodes.keys()].sort()){let o=this._nodes.get(r),s=e===""?r:`${e}${$}${r}`;t.push([s,o]),this._appendMetaObserveTargets(s,o,t)}}_appendMetaObserveTargets(e,t,r){for(let o of Object.keys(t.meta).sort()){let s=t.meta[o],i=`${e}${$}${ee}${$}${o}`;r.push([i,s]),this._appendMetaObserveTargets(i,s,r)}}observe(e,t){let r=typeof e=="string",s=dn(r?t:e);if(s.reactive===!0)return this._observeReactive(r?e:void 0,s);let i=s.structured===!0||s.timeline===!0||s.causal===!0||s.derived===!0||s.detail==="minimal"||s.detail==="full"||s.format!=null,a=s.actor;if(r){let d=e,g=this.resolve(d);if(a!=null&&!g.allowsObserve(a))throw new Q({actor:a,action:"observe",nodeName:d});return i?this._buildStructuredObserver([[d,g]],s,"one"):{subscribe(f){return g.subscribe(f)},up(f){try{g.up?.(f)}catch(p){if(p instanceof Q)return;throw p}}}}let u=[];this._collectObserveTargets("",u),u.sort((d,g)=>d[0]<g[0]?-1:d[0]>g[0]?1:0);let c=a==null?u:u.filter(([,d])=>d.allowsObserve(a));return i?this._buildStructuredObserver(c,s,"all"):{subscribe:d=>{let g=c.map(([f,p])=>p.subscribe(l=>{d(f,l)}));return()=>{for(let f of g)f()}},up:(d,g)=>{try{this.resolve(d).up?.(g)}catch(f){if(f instanceof Q)return;throw f}}}}_observeReactive(e,t){let r=t.tiers,o=r!=null?new Set(r):null,s=t.reactiveName??"observe";return xe(i=>{let a=[],u=!1,c=!1,d=()=>{if(a.length===0||c)return;let b={events:a.slice(),flushedAt_ns:ie()};a.length=0,i.emit(b)},g={...t,reactive:!1,structured:!0,timeline:!0},f=e!=null?this.observe(e,g):this.observe(g),p=b=>{c||(a.push(b),!u&&(u=!0,_e(()=>{u=!1,d()})))};for(let b of f.events)p(b);let l=f.onEvent(p);return()=>{c=!0,l(),f.dispose()}},{name:s,meta:{domain:"audit",kind:"observe-reactive"}})}_buildStructuredObserver(e,t,r){let o=r==="one"?e[0]?.[0]:void 0,s=i=>{if(r==="one"&&o!=null){let d=this.resolve(o);return this._buildStructuredObserver([[o,d]],i,"one")}let a=[];this._collectObserveTargets("",a),a.sort((d,g)=>d[0]<g[0]?-1:d[0]>g[0]?1:0);let u=i.actor,c=u==null?a:a.filter(([,d])=>d.allowsObserve(u));return this._buildStructuredObserver(c,i,"all")};return this._createObserveResult(e,t,s)}_createObserveResult(e,t,r){let o=t.timeline===!0,s=t.causal===!0,i=t.derived===!0,a=t.detail==="minimal",u=this.config.inspectorEnabled,c=(s||i)&&u,d=t.maxEvents,g=d!=null&&d>0?new Fe(d):null,f=[],p=new Set,l=t.tiers!=null?new Set(t.tiers):null,b={},m=new Set,_=0,v=0,h=0,y=0,w=0,S=0,N=!1,x=!1,E=0,T=new Map,k=new Map,P=new Map,R=O=>{if(!(l!=null&&!l.has(O.type))){g?g.push(O):f.push(O);for(let M of p)M(O)}},A=O=>l==null||l.has(O),te=()=>o?{timestamp_ns:ie(),in_batch:Ve(),batch_id:E}:{},ye=(O,M)=>{if(!(!c||!(O instanceof j)))return O._setInspectorHook(J=>{if(J.kind==="dep_message")T.set(O,J.depIndex);else if(J.kind==="run"){let Ae=J.batchData.map((D,W)=>D!=null&&D.length>0?D.at(-1):J.prevData[W]);k.set(O,Ae);let Y=J.batchData.map(D=>D!=null?[...D]:void 0);P.set(O,Y),i&&R({type:"derived",path:M,dep_values:Ae,dep_batches:Y,...te()})}})},H=O=>{let M=T.get(O),J=k.get(O);if(!s||J==null)return{};let Y=(M!=null&&M>=0&&O instanceof j?O._deps[M]:void 0)?.node,D=Y?.v,W=P.get(O);return{trigger_dep_index:M,trigger_dep_name:Y?.name,...D!=null?{trigger_version:{id:D.id,version:D.version}}:{},dep_values:[...J],...W!=null?{dep_batches:W}:{}}},q=[],U=[];for(let[O,M]of e){let J=ye(M,O);J&&q.push(J),U.push(M.subscribe(Ae=>{E++;for(let Y of Ae){let D=Y[0],W=te();if(D===F){b[O]=Y[1];let rt=M instanceof j?M.lastMutation?.actor??be:be;R({type:"data",path:O,data:Y[1],actor:rt,...W,...H(M)})}else if(a)D===X?A("dirty")&&_++:D===Z?A("resolved")&&v++:D===re?A("invalidate")&&h++:D===se?A("pause")&&y++:D===ce?A("resume")&&w++:D===V?A("teardown")&&S++:D===B&&!m.has(O)?A("complete")&&(N=!0):D===G&&A("error")&&(x=!0,m.add(O));else if(D===X)A("dirty")&&_++,R({type:"dirty",path:O,...W});else if(D===Z)A("resolved")&&v++,R({type:"resolved",path:O,...W,...H(M)});else if(D===re)A("invalidate")&&h++,R({type:"invalidate",path:O,...W});else if(D===se)A("pause")&&y++,R({type:"pause",path:O,lockId:Y[1],...W});else if(D===ce)A("resume")&&w++,R({type:"resume",path:O,lockId:Y[1],...W});else if(D===B)A("complete")&&!m.has(O)&&(N=!0),R({type:"complete",path:O,...W});else if(D===G){A("error")&&(x=!0,m.add(O));let rt=M instanceof j?M.lastMutation?.actor??be:be;R({type:"error",path:O,data:Y[1],actor:rt,...W})}else D===V&&(A("teardown")&&S++,R({type:"teardown",path:O,...W}))}}))}let K=!1,I=()=>{if(!K){K=!0;for(let O of U)O();for(let O of q)O();for(let O of Le)O({value:void 0,done:!0});Le.length=0}},ne=[],Le=[];p.add(O=>{let M=Le.shift();M?M({value:O,done:!1}):ne.push(O)});let Et={get values(){return b},get dirtyCount(){return _},get resolvedCount(){return v},get invalidateCount(){return h},get pauseCount(){return y},get resumeCount(){return w},get teardownCount(){return S},get events(){return g?g.toArray():[...f]},get anyCompletedCleanly(){return N},get anyErrored(){return x},get completedWithoutErrors(){return N&&!x},onEvent(O){return p.add(O),()=>p.delete(O)},dispose:I,expand(O){I();let M={...t};return typeof O=="string"?M.detail=O:Object.assign(M,O),r(dn(M))},[Symbol.asyncIterator](){return{next(){return ne.length>0?Promise.resolve({value:ne.shift(),done:!1}):K?Promise.resolve({value:void 0,done:!0}):new Promise(O=>Le.push(O))},return(){return I(),Promise.resolve({value:void 0,done:!0})}}}};return t.format!=null&&this._attachFormatLogger(Et,t),Et}_attachFormatLogger(e,t){let r=t.format;if(r==null)return;let o=t.logger??(l=>console.log(l)),s=t.includeTypes?new Set(t.includeTypes):null,i=t.excludeTypes?new Set(t.excludeTypes):null,a=s==null&&i==null?()=>!0:l=>(s==null||s.has(l))&&(i==null||!i.has(l)),u=dr(t.theme),c=r==="stage-log"?ie():0,d=l=>l==null?"":t.stageLabels?.[l]??l,g=(l,b)=>l.length>b?`${l.slice(0,b-1)}\u2026`:l,f=l=>l.type==="data"||l.type==="error"?g(kt(l.data),120):"",p=l=>{if(r==="stage-log"){let N=(ie()-c)/1e9,x=d(l.path).padEnd(9);if(l.type==="data"){let E=f(l);return`[${N.toFixed(3)}s] ${x} \u2190${E?` ${E}`:""}`}if(l.type==="error"){let E=f(l);return`[${N.toFixed(3)}s] ${x} \u2717${E?` ${E}`:""}`}return l.type==="complete"?`[${N.toFixed(3)}s] ${x} \u25A0 complete`:`[${N.toFixed(3)}s] ${x} ${l.type}`}if(r==="json")try{return JSON.stringify(l)}catch{return JSON.stringify({type:l.type,path:l.path,data:"[unserializable]"})}let b=u[l.type]??"",m=l.path?`${u.path}${l.path}${u.reset} `:"",_=l.type==="data"||l.type==="error",v=l.type==="pause"||l.type==="resume",h=_?` ${kt(l.data)}`:v?` ${kt(l.lockId)}`:"",y=l.type==="data"||l.type==="resolved"||l.type==="derived"?l:void 0,w=y?.trigger_dep_name!=null?` <- ${y.trigger_dep_name}`:y?.trigger_dep_index!=null?` <- #${y.trigger_dep_index}`:"",S=l.in_batch?" [batch]":"";return`${m}${b}${l.type.toUpperCase()}${u.reset}${h}${w}${S}`};e.onEvent(l=>{a(l.type)&&o(p(l),l)})}addDisposer(e){return this._disposers.add(e),()=>{this._disposers.delete(e)}}destroy(){on(this._disposers,this.name),this.signal([[V]],{internal:!0}),on(this._storageDisposers,this.name);for(let e of[...this._mounts.values()])e._parent=void 0,e._destroyClearOnly();this._mounts.clear(),this._nodes.clear(),this._parent=void 0,this._destroyed=!0}get destroyed(){return this._destroyed}_destroyClearOnly(){for(let e of[...this._mounts.values()])e._parent=void 0,e._destroyClearOnly();this._mounts.clear(),this._nodes.clear(),this._parent=void 0,this._destroyed=!0}snapshot(e){let{expand:t,...r}=this.describe({detail:"full"}),o={};for(let a of Object.keys(r.nodes).sort()){let{lastMutation:u,guard:c,...d}=r.nodes[a];o[a]=d}let s=[...r.subgraphs].sort(),i={...r,version:1,nodes:o,subgraphs:s};if(e?.format==null)return i;if(e.format==="json-string")return JSON.stringify(i);if(e.format==="bytes"){if(e.codec==null)throw new Error("snapshot({format: 'bytes'}) requires a `codec` name");let a=this.config.lookupCodec(e.codec);if(a==null)throw new Error(`snapshot: codec "${e.codec}" is not registered on this graph's config. Call config.registerCodec(...) before creating nodes.`);return Ct(a,a.encode(i))}throw new Error(`snapshot: unknown format "${String(e.format)}"`)}static decode(e,t){let r=t?.config??Ne,{codec:o,codecVersion:s,payload:i}=Dt(e,r);return o.decode(i,s)}restore(e,t){if(un(e),e.name!==this.name)throw new Error(`Graph "${this.name}": restore snapshot name "${e.name}" does not match this graph`);let r=t?.only==null?null:(Array.isArray(t.only)?t.only:[t.only]).map(s=>Qe(s)),o=t?.includeProducers===!0;for(let s of Object.keys(e.nodes).sort()){if(r!==null&&!r.some(a=>a.test(s)))continue;let i=e.nodes[s];if(i!==void 0){if(!("value"in i)||i.value===void 0){"value"in i&&i.value===void 0&&t?.onError?.(s,new Error(`restore: slice.value is undefined for "${s}" (undefined is the global SENTINEL; not valid DATA)`));continue}if(!(i.type==="derived"||i.type==="effect")&&!(i.type==="producer"&&!o)){if(i.v!=null){let u=this.tryResolve(s)?.v;if(u!=null&&u.id===i.v.id&&u.version===i.v.version)continue}try{this.set(s,i.value)}catch(a){t?.onError?.(s,a)}}}}}static fromSnapshot(e,t){un(e);let r=typeof t=="function"?t:t?.build,o=typeof t=="function"?void 0:t?.factories,s=new n(e.name);if(r)return r(s),s.restore(e),s;for(let p of[...e.subgraphs].sort((l,b)=>{let m=l.split($).length,_=b.split($).length;return m!==_?m-_:l<b?-1:l>b?1:0})){let l=p.split($),b=s;for(let m of l)b._mounts.has(m)||b.mount(m,new n(m)),b=b._mounts.get(m)}let i=o?Object.entries(o).map(([p,l])=>({re:Qe(p),factory:l})):[],a=p=>{for(let l of i)if(l.re.test(p))return l.factory},u=p=>{let l=p.split($),b=l.pop();if(b==null||b.length===0)throw new Error(`invalid snapshot path "${p}"`);let m=s;for(let _ of l){let v=m._mounts.get(_);if(!v)throw new Error(`unknown mount "${_}" in path "${p}"`);m=v}return[m,b]},c=Object.entries(e.nodes).filter(([p])=>!p.includes(`${$}${ee}${$}`)).sort((p,l)=>p[0]<l[0]?-1:p[0]>l[0]?1:0),d=new Map(c),g=new Map,f=!0;for(;d.size>0&&f;){f=!1;for(let[p,l]of[...d.entries()]){let b=l?.deps??[];if(!b.every(w=>g.has(w)))continue;let[m,_]=u(p),v={...l?.meta??{}},h=a(p),y;if(l?.type==="state")y=oe(l.value,{meta:v});else{if(h==null)continue;y=h(_,{path:p,type:l.type,value:l.value,meta:v,deps:b,resolvedDeps:b.map(w=>g.get(w))})}m.add(y,{name:_}),g.set(p,y),d.delete(p),f=!0}}if(d.size>0){let p=[...d.keys()].sort().join(", ");throw new Error(`Graph.fromSnapshot could not reconstruct nodes without build callback: ${p}. Pass matching factories via fromSnapshot(data, { factories: { pattern: factoryFn } }).`)}return s.restore(e),s}toJSON(){return this.snapshot()}attachSnapshotStorage(e,t={}){let r=e.map(c=>({tier:c,debounceMs:Math.max(0,c.debounceMs??0),compactEvery:Math.max(1,c.compactEvery??10),timer:void 0,seq:0,lastSnapshot:void 0,lastFingerprint:"",disposed:!1,savePending:void 0}));t.autoRestore===!0&&this._cascadeRestore(e,t.onError);let o=(c,d)=>{if(c.disposed)return;let g=or(d.nodes);if(c.lastSnapshot!=null&&g!==""&&g===c.lastFingerprint)return;let f=c.seq+1,p=Se(),m=c.lastSnapshot==null||f%c.compactEvery===0?{name:this.name,mode:"full",snapshot:d,seq:f,timestamp_ns:p,format_version:de}:{name:this.name,mode:"diff",diff:hr(c.lastSnapshot,d),seq:f,timestamp_ns:p,format_version:de};if(c.tier.filter&&!c.tier.filter(m))return;let _;try{_=c.tier.save(m)}catch(v){t.onError?.(v,c.tier);return}if(_&&typeof _.then=="function"){let y=(c.savePending??Promise.resolve()).then(()=>_,()=>_).then(()=>{c.disposed||(c.seq=f,c.lastSnapshot=d,c.lastFingerprint=g)},w=>{t.onError?.(w,c.tier)});c.savePending=y.finally(()=>{c.savePending===y&&(c.savePending=void 0)})}else c.seq=f,c.lastSnapshot=d,c.lastFingerprint=g},s=(c,d)=>{try{o(c,d)}catch(g){t.onError?.(g,c.tier)}},i=(c,d)=>{if(!d.some(l=>{let b=this.config.messageTier(l[0]);return b>=3&&b<5}))return;if(t.filter){let l=this.tryResolve(c);if(l==null)return;let b=vt(l,bt("standard"));if(!t.filter(c,b))return}let f,p=()=>(f==null&&(f=this.snapshot()),f);for(let l of r)l.disposed||(l.debounceMs===0?s(l,p()):(l.timer==null&&(l.timer=new Je),l.timer.start(l.debounceMs,()=>{l.disposed||s(l,this.snapshot())})))},a;if(t.paths!=null){let d=(typeof t.paths=="string"?this._pathsMatching(t.paths):t.paths).map(g=>{let f=this.tryResolve(g);return f==null?()=>{}:f.subscribe(p=>i(g,p))});a=()=>{for(let g of d)g()}}else a=this.observe().subscribe((c,d)=>i(c,d));let u=()=>{a();for(let c of r)c.disposed=!0,c.timer?.cancel();this._storageDisposers.delete(u)};return this._storageDisposers.add(u),{dispose:u}}async _cascadeRestore(e,t){for(let r of e){let o;try{o=await r.load?.()}catch(i){t?.(i,r);continue}if(o==null||typeof o!="object"||Array.isArray(o))continue;let s=o;try{if(s.mode==="full"&&s.snapshot!=null)return this.restore(s.snapshot),!0;if(s.version===de&&s.nodes!=null)return this.restore(s),!0}catch(i){t?.(i,r)}}return!1}static async fromStorage(e,t,r){for(let o of t){let s;try{s=await o.load?.()}catch(u){r?.onError?.(u,o);continue}if(s==null||typeof s!="object"||Array.isArray(s))continue;let i=s,a=i.mode==="full"&&i.snapshot!=null?i.snapshot:i.version===de&&i.nodes!=null?i:void 0;if(a!=null)try{return n.fromSnapshot(a,r)}catch(u){r?.onError?.(u,o)}}throw new Error(`Graph.fromStorage: no tier held a restorable record for "${e}" across ${t.length} tier(s)`)}_annotations=new Map;_traceRing;trace(e,t,r){if(e!=null&&t!=null){if(this.tryResolve(e)==null)return;if(this._annotations.set(e,t),this.config.inspectorEnabled){let o={path:e,annotation:t,timestamp_ns:ie(),...r?.actor!=null?{actor:r.actor}:{}};this._traceRing.push(o)}return}return e!=null?this.config.inspectorEnabled?this._annotations.get(e):void 0:this.config.inspectorEnabled?this._traceRing.toArray():[]}annotation(e){return this._annotations.get(e)}clearTrace(){this._annotations.clear(),this._traceRing.clear()}pruneTrace(e){let t=this._traceRing.toArray().filter(o=>!e(o)),r=this._traceRing.size-t.length;this._traceRing.clear();for(let o of t)this._traceRing.push(o);return r}static diff(e,t){let r=new Set(Object.keys(e.nodes)),o=new Set(Object.keys(t.nodes)),s=[...o].filter(v=>!r.has(v)).sort(),i=[...r].filter(v=>!o.has(v)).sort(),a=[],u=[];for(let v of r){if(!o.has(v))continue;let h=e.nodes[v],y=t.nodes[v],w=h.v,S=y.v;w!=null&&S!=null&&w.id===S.id&&w.version!==S.version&&u.push({path:v,id:w.id,from:w.version,to:S.version});let N=w!=null&&S!=null&&w.id===S.id&&w.version===S.version;for(let x of["type","status","sentinel"]){let E=h[x],T=y[x];E!==T&&a.push({path:v,field:x,from:E,to:T})}if(!N)for(let x of["value","meta"]){let E=h[x],T=y[x];ir(E,T)||a.push({path:v,field:x,from:E,to:T})}}let c=v=>`${v.from} ${v.to}`,d=new Set(e.edges.map(c)),g=new Set(t.edges.map(c)),f=t.edges.filter(v=>!d.has(c(v))),p=e.edges.filter(v=>!g.has(c(v))),l=new Set(e.subgraphs),b=new Set(t.subgraphs),m=[...b].filter(v=>!l.has(v)).sort(),_=[...l].filter(v=>!b.has(v)).sort();return{nodesAdded:s,nodesRemoved:i,nodesChanged:a,versionChanges:u,edgesAdded:f,edgesRemoved:p,subgraphsAdded:m,subgraphsRemoved:_}}};function hr(n,e){let t=ae.diff(n,e),r={};for(let o of t.nodesAdded){let s=e.nodes[o];s!=null&&(r[o]=s)}return{...t,nodesAddedFull:r}}function ln(n,e,t,r={}){let o={paths:[],depths:new Map,truncated:!1};if(!e)return r.withDetail?o:[];if(!r.both&&t!=="upstream"&&t!=="downstream")throw new Error('reachable: direction must be "upstream" or "downstream"');let s=r.maxDepth;if(s!=null&&(!Number.isInteger(s)||s<0))throw new Error("reachable: maxDepth must be an integer >= 0");if(s===0)return r.withDetail?o:[];let i=new Map,a=new Map,u=new Map,c=new Map,d=new Set;for(let[h,y]of Object.entries(n.nodes)){if(!h)continue;d.add(h);let w=y.deps??[];i.set(h,w);for(let S of w)S&&(d.add(S),a.has(S)||a.set(S,new Set),a.get(S).add(h))}for(let h of n.edges){if(h==null||typeof h!="object")continue;let y=typeof h.from=="string"?h.from:"",w=typeof h.to=="string"?h.to:"";!y||!w||(d.add(y),d.add(w),c.has(y)||c.set(y,new Set),c.get(y).add(w),u.has(w)||u.set(w,new Set),u.get(w).add(y))}if(!d.has(e))return r.withDetail?o:[];let g=r.both===!0,f=h=>{if(g){let N=i.get(h)??[],x=u.get(h),E=a.get(h),T=c.get(h),k=[...N];return x&&k.push(...x),E&&k.push(...E),T&&k.push(...T),k}if(t==="upstream"){let N=i.get(h)??[],x=u.get(h);return x?[...N,...x]:N}let y=a.get(h),w=c.get(h),S=y?[...y]:[];return w&&S.push(...w),S},p=new Set([e]),l=new Map,b=[{path:e,depth:0}],m=0,_=!1;for(;m<b.length;){let h=b[m++];if(s!=null&&h.depth>=s){f(h.path).length>0&&(_=!0);continue}for(let y of f(h.path))!y||p.has(y)||(p.add(y),l.set(y,h.depth+1),b.push({path:y,depth:h.depth+1}))}let v=[...l.keys()].sort((h,y)=>h<y?-1:h>y?1:0);return r.withDetail?{paths:v,depths:l,truncated:_}:v}function gr(n,e){if(n.length!==e.length)return!1;for(let t=0;t<n.length;t++){let r=n[t],o=e[t];if(r.path!==o.path||r.type!==o.type||r.status!==o.status||r.hop!==o.hop||r.dep_index!==o.dep_index||r.annotation!==o.annotation||r.value!==o.value||r.lastMutation!==o.lastMutation)return!1;let s=r.v,i=o.v;if(s!==i&&(s==null||i==null||s.id!==i.id||s.version!==i.version))return!1}return!0}ze();pe();Oe();Ke();gn();$e();pe();function mn(n,e){let t=n.cache??0;return t>=e?!1:(n.down([[X],[F,t+1]]),!0)}var Os=Vt((n,e)=>{n("observe"),n("signal"),e("write")});St();function yn(n,e){return hn("reduction",n,e)}function bn(n,e,t,r){let o=r?.maxIterations??10,s=`__feedback_${e}`,i=oe(0,{meta:yn("feedback_counter",{maxIterations:o,feedbackFrom:e,feedbackTo:t})});n.add(i,{name:s});let a=n.resolve(e),u=n.resolve(t),c=`__feedback_effect_${e}`,d=he([],(g,f)=>{let p=a.subscribe(l=>{for(let b of l){let m=b[0];if(m===F){let _=b[1];if(_==null)return;Be(()=>{mn(i,o)&&u.emit(_)})}else if(m===B||m===G){let _=m===G&&b.length>1?[G,b[1]]:[m];i.down([_])}}});return()=>p()},{name:c,describeKind:"effect",meta:{...yn("feedback_effect",{feedbackFrom:e,feedbackTo:t}),_internal:!0}});return n.add(d,{name:c}),n.addDisposer(Te(d)),n}function Re(n){let e=n.meta?.factory;return typeof e=="string"?e:void 0}function Ee(n){let e=n.meta?.factoryArgs;return e!=null&&typeof e=="object"?e:{}}function vn(n){let e=Ee(n);return"initial"in e?e.initial:n.value}function _n(n){return typeof n=="object"&&n!==null&&"factory"in n}function Sn(n){return typeof n=="object"&&n!==null&&"factory"in n}function mr(n){return _n(n)?n.factory:n}function yr(n){return Sn(n)?n.factory:n}function Ot(n,e){let t=[],r=new Set(Object.keys(e.fns??{})),o=new Set(Object.keys(e.sources??{}));for(let[s,i]of Object.entries(n.nodes)){if(i.type==="template")continue;let a=i,u=Re(a);if(u==null)continue;let c=a.type==="producer";if(a.type==="state"&&u==="state")continue;if(c){let g=o.has(u),f=r.has(u);if(!g&&!f&&(o.size>0||r.size>0)){let p=et(u,o)??et(u,r);t.push(`Node "${s}": source "${u}" not found in catalog`+(p?`. Did you mean "${p}"?`:""))}}else if(r.size>0&&!r.has(u))if(o.has(u))t.push(`Node "${s}": fn "${u}" is a source, not a function. Use it as a producer source instead, or use a function from: ${[...r].join(", ")}`);else{let g=et(u,r);t.push(`Node "${s}": fn "${u}" not found in catalog`+(g?`. Did you mean "${g}"?`:""))}let d=Ee(a);if(!c&&e.fns?.[u]){let g=e.fns[u];if(_n(g)&&g.configSchema){for(let[f,p]of Object.entries(g.configSchema))if(p.required!==!1&&!(f in d)&&t.push(`Node "${s}": config missing required field "${f}"`),f in d&&p.enum){let l=d[f];p.enum.includes(l)||t.push(`Node "${s}": config.${f} = ${JSON.stringify(l)}, expected one of: ${p.enum.join(", ")}`)}}}if(c&&e.sources?.[u]){let g=e.sources[u];if(Sn(g)&&g.configSchema){for(let[f,p]of Object.entries(g.configSchema))if(p.required!==!1&&!(f in d)&&t.push(`Node "${s}": config missing required field "${f}"`),f in d&&p.enum){let l=d[f];p.enum.includes(l)||t.push(`Node "${s}": config.${f} = ${JSON.stringify(l)}, expected one of: ${p.enum.join(", ")}`)}}}}if(n.templates)for(let[s,i]of Object.entries(n.templates))for(let[a,u]of Object.entries(i.nodes)){let c=Re(u);if(c!=null&&!(u.type==="state"&&c==="state")&&u.type!=="producer"&&r.size>0&&!r.has(c)){let d=et(c,r);t.push(`Template "${s}" node "${a}": fn "${c}" not found in catalog`+(d?`. Did you mean "${d}"?`:""))}}return{valid:t.length===0,errors:t,warnings:[]}}function et(n,e){let t=null,r=1/0,o=n.toLowerCase();for(let s of e){let i=br(o,s.toLowerCase());i<r&&i<=Math.max(3,Math.floor(n.length/2))&&(r=i,t=s)}return t}function br(n,e){let t=n.length,r=e.length,o=Array.from({length:t+1},(s,i)=>Array.from({length:r+1},(a,u)=>i===0?u:u===0?i:0));for(let s=1;s<=t;s++)for(let i=1;i<=r;i++)o[s][i]=n[s-1]===e[i-1]?o[s-1][i-1]:1+Math.min(o[s-1][i],o[s][i-1],o[s-1][i-1]);return o[t][r]}var wn=new Set(["state","producer","derived","effect","operator","template"]),vr=new Set(["state","producer","derived","effect","operator"]);function xt(n){let e=[],t=[];if(n==null||typeof n!="object")return{valid:!1,errors:["GraphSpec must be a non-null object"],warnings:t};let r=n;if((typeof r.name!="string"||r.name.length===0)&&e.push("Missing or empty 'name' field"),r.nodes==null||typeof r.nodes!="object"||Array.isArray(r.nodes))return e.push("Missing or invalid 'nodes' field (must be an object)"),{valid:!1,errors:e,warnings:t};let o=new Set(Object.keys(r.nodes)),s=new Map,i=new Map;if(r.templates!=null&&typeof r.templates=="object"&&!Array.isArray(r.templates)){for(let[a,u]of Object.entries(r.templates))if(u!=null&&typeof u=="object"){let c=u;i.set(a,{params:Array.isArray(c.params)?c.params:[]})}}if(r.templates!=null)if(typeof r.templates!="object"||Array.isArray(r.templates))e.push("'templates' must be an object");else for(let[a,u]of Object.entries(r.templates)){if(u==null||typeof u!="object"){e.push(`Template "${a}": must be an object`);continue}let c=u;if(Array.isArray(c.params)||e.push(`Template "${a}": missing 'params' array`),c.nodes==null||typeof c.nodes!="object"||Array.isArray(c.nodes))e.push(`Template "${a}": missing or invalid 'nodes' object`);else{let d=new Set(Array.isArray(c.params)?c.params:[]),g=new Set(Object.keys(c.nodes));for(let[f,p]of Object.entries(c.nodes)){if(p==null||typeof p!="object"){e.push(`Template "${a}" node "${f}": must be an object`);continue}let l=p;if((typeof l.type!="string"||!vr.has(l.type))&&e.push(`Template "${a}" node "${f}": invalid type`),Array.isArray(l.deps))for(let b of l.deps)!g.has(b)&&!d.has(b)&&e.push(`Template "${a}" node "${f}": dep "${b}" is not an inner node or param`)}typeof c.output!="string"?e.push(`Template "${a}": missing 'output' string`):c.nodes[c.output]||e.push(`Template "${a}": output "${c.output}" is not a declared node`)}}for(let[a,u]of Object.entries(r.nodes)){if(u==null||typeof u!="object"){e.push(`Node "${a}": must be an object`);continue}let c=u;if(typeof c.type!="string"||!wn.has(c.type)){e.push(`Node "${a}": invalid type "${String(c.type)}" (expected: ${[...wn].join(", ")})`);continue}if(s.set(a,c.type),c.type==="template")if(typeof c.template!="string"||!i.has(c.template))e.push(`Node "${a}": template "${String(c.template)}" not found in templates`);else if(c.bind==null||typeof c.bind!="object"||Array.isArray(c.bind))e.push(`Node "${a}": template ref requires 'bind' object`);else{let d=i.get(c.template),g=c.bind;for(let f of d.params)f in g||e.push(`Node "${a}": template param "${f}" is not bound (template "${c.template}")`);for(let[,f]of Object.entries(g))typeof f=="string"&&!o.has(f)&&e.push(`Node "${a}": bind target "${f}" does not reference an existing node`)}else{if(Array.isArray(c.deps))for(let d of c.deps)d===a?e.push(`Node "${a}": self-referencing dep`):o.has(d)||e.push(`Node "${a}": dep "${d}" does not reference an existing node`);(c.type==="derived"||c.type==="effect"||c.type==="operator")&&!Array.isArray(c.deps)&&e.push(`Node "${a}": ${c.type} node should have a 'deps' array`)}}if(r.feedback!=null)if(!Array.isArray(r.feedback))e.push("'feedback' must be an array");else for(let a=0;a<r.feedback.length;a++){let u=r.feedback[a];if(u==null||typeof u!="object"){e.push(`Feedback [${a}]: must be an object`);continue}let c=u;typeof c.from!="string"||!o.has(c.from)?e.push(`Feedback [${a}]: 'from' "${String(c.from)}" does not reference an existing node`):s.get(c.from)==="effect"&&t.push(`Feedback [${a}]: 'from' "${c.from}" is an effect node \u2014 effects emit no DATA, so the feedback edge will never fire. Did you mean a derived/state node upstream?`),typeof c.from=="string"&&c.from===c.to&&e.push(`Feedback [${a}]: 'from' and 'to' must be different nodes`),typeof c.to!="string"||!o.has(c.to)?e.push(`Feedback [${a}]: 'to' "${String(c.to)}" does not reference an existing node`):typeof c.to=="string"&&s.get(c.to)!=="state"&&e.push(`Feedback [${a}]: 'to' node "${c.to}" must be a state node (got "${s.get(c.to)??"unknown"}")`)}return{valid:e.length===0,errors:e,warnings:t}}function kn(n,e){let t=xt(n);if(!t.valid)throw new Error(`compileSpec: invalid GraphSpec:
|
|
4
|
+
${t.errors.join(`
|
|
5
|
+
`)}`);let r=n.factory,o=n.factoryArgs;if(typeof r=="string"){let h=e?.catalog?.graphFactories?.[r];if(h)return h(o)}let s=e?.catalog??{},i=e?.onMissing??"placeholder",a=new ae(n.name),u=n.templates??{},c=Ot(n,s);if(!c.valid)throw new Error(`compileSpec: catalog validation errors:
|
|
10
6
|
${c.errors.join(`
|
|
11
|
-
`)}`);let d=[],
|
|
12
|
-
${
|
|
13
|
-
`)}`)}if(i==="warn"){let
|
|
14
|
-
${
|
|
15
|
-
`)}`,{errors:
|
|
16
|
-
${
|
|
17
|
-
`)}`,{errors:
|
|
7
|
+
`)}`);let d=[],g=(h,y,w)=>{d.push({path:h,kind:y,name:w})},f=h=>{let y=s.fns?.[h];return y?mr(y):void 0},p=h=>{let y=s.sources?.[h];return y?yr(y):void 0},l=h=>{if(!h)return;let y={};for(let[w,S]of Object.entries(h))w==="factory"||w==="factoryArgs"||(y[w]=S);return Object.keys(y).length>0?y:void 0},b=new Map,m=[];for(let[h,y]of Object.entries(n.nodes)){if(y.type==="template")continue;let w=y,S=Re(w),N=Ee(w);if(w.type==="state"){let x=vn(w),E=oe(x,{name:h,meta:l(w.meta)});a.add(E,{name:h}),b.set(h,E)}else if(w.type==="producer"){let x=S?p(S):void 0,E=S?f(S):void 0;if(x){let T=x(N);a.add(T,{name:h}),b.set(h,T)}else if(E){let T=E([],N);a.add(T,{name:h}),b.set(h,T)}else{S&&g(h,"source",S);let T=xe(()=>{},{name:h,meta:{...l(w.meta),_specSource:S}});a.add(T,{name:h}),b.set(h,T)}}else m.push([h,w])}let _=!0,v=new Map(m);for(;v.size>0&&_;){_=!1;for(let[h,y]of[...v.entries()]){let w=y.deps??[];if(!w.every(k=>b.has(k)))continue;let S=w.map(k=>b.get(k)),N=Re(y),x=Ee(y),E=N?f(N):void 0,T;E?T=E(S,x):y.type==="effect"?(N&&g(h,"fn",N),T=qe(S,()=>{})):(N&&g(h,"fn",N),T=ge(S,k=>k[0])),a.add(T,{name:h}),b.set(h,T),v.delete(h),_=!0}}if(v.size>0){let h=[...v.keys()].sort().join(", ");throw new Error(`compileSpec: unresolvable deps for nodes: ${h}`)}for(let[h,y]of Object.entries(n.nodes)){if(y.type!=="template")continue;let w=y,S=u[w.template],N=new ae(h),x=new Map,E=[];for(let[R,A]of Object.entries(S.nodes)){let te=(A.deps??[]).map(U=>U.startsWith("$")&&w.bind[U]?w.bind[U]:U),ye={...A,deps:te},H=Re(A),q=Ee(A);if(A.type==="state"){let U=vn(A),K=oe(U,{name:R,meta:l(A.meta)});N.add(K,{name:R}),x.set(R,K)}else if(A.type==="producer"){let U=H?p(H):void 0,K=H?f(H):void 0;if(U){let I=U(q);N.add(I,{name:R}),x.set(R,I)}else if(K){let I=K([],q);N.add(I,{name:R}),x.set(R,I)}else{H&&g(`${h}.${R}`,"source",H);let I=xe(()=>{},{name:R,meta:{...l(A.meta),_specSource:H}});N.add(I,{name:R}),x.set(R,I)}}else E.push([R,ye])}let T=!0,k=new Map(E);for(;k.size>0&&T;){T=!1;for(let[R,A]of[...k.entries()]){let te=A.deps??[];if(!te.every(ne=>x.has(ne)||b.has(ne)))continue;let H=te.map(ne=>x.get(ne)??b.get(ne)),q=Re(A),U=Ee(A),K=q?f(q):void 0,I;K?I=K(H,U):A.type==="effect"?(q&&g(`${h}.${R}`,"fn",q),I=qe(H,()=>{})):(q&&g(`${h}.${R}`,"fn",q),I=ge(H,ne=>ne[0])),N.add(I,{name:R}),x.set(R,I),k.delete(R),T=!0}}if(k.size>0){let R=[...k.keys()].sort().join(", ");throw new Error(`compileSpec: template "${w.template}" has unresolvable deps: ${R}`)}a.mount(h,N);let P=`${h}::${S.output}`;b.set(h,a.resolve(P));try{let R=a.resolve(P);R.meta._templateName?.emit(w.template),R.meta._templateBind?.emit(w.bind)}catch{}}for(let h of n.feedback??[])bn(a,h.from,h.to,{maxIterations:h.maxIterations});if(d.length>0){if(i==="error"){let h=d.map(y=>` - ${y.path}: missing ${y.kind} "${y.name}"`);throw new Error(`compileSpec: ${d.length} catalog entr${d.length===1?"y":"ies"} missing \u2014 pass them via opts.catalog or set opts.onMissing to "warn"/"placeholder":
|
|
8
|
+
${h.join(`
|
|
9
|
+
`)}`)}if(i==="warn"){let h=e?.onWarn??(y=>console.warn(y));for(let y of d)h(`compileSpec: ${y.path} references missing ${y.kind} "${y.name}" \u2014 substituted placeholder`)}}return a}var C=class extends Error{code;details;constructor(e,t,r){super(t),this.name="SurfaceError",this.code=e,r!==void 0&&(this.details=r)}toJSON(){let e={code:this.code,message:this.message};if(this.details!==void 0){let t=wr(this.details);t!==void 0&&(e.details=t)}return e}};function wr(n){try{return JSON.parse(JSON.stringify(n))}catch{return}}function Nn(n,e="internal-error"){if(n instanceof C)return n;let t=n instanceof Error?n.message:String(n);return new C(e,t)}function tt(n,e){let t=xt(n);if(!t.valid)throw new C("invalid-spec",`GraphSpec validation failed:
|
|
10
|
+
${t.errors.join(`
|
|
11
|
+
`)}`,{errors:t.errors});let r=e?.catalog??{},o=Ot(n,r);if(!o.valid)throw new C("catalog-error",`Catalog validation failed:
|
|
12
|
+
${o.errors.join(`
|
|
13
|
+
`)}`,{errors:o.errors});try{return kn(n,e)}catch(s){let i=s instanceof Error?s.message:String(s);throw new C("catalog-error",i)}}pe();var _r=3e4;async function On(n,e,t){let r=t?.inputPath??"input",o=t?.outputPath??"output",s=t?.timeoutMs??_r,i=tt(n,{catalog:t?.catalog}),a;try{a=i.resolve(o)}catch{throw i.destroy(),new C("node-not-found",`reduce: output path "${o}" is not registered`,{path:o})}try{i.resolve(r)}catch{throw i.destroy(),new C("node-not-found",`reduce: input path "${r}" is not registered`,{path:r})}try{return await new Promise((u,c)=>{let d=!1,g=!1,f,p,l=!1,b=m=>{g||(g=!0,f!==void 0&&clearTimeout(f),p!==void 0?(p(),p=void 0):l=!0,m())};p=a.subscribe(m=>{for(let _ of m){if(g)return;if(d){if(_[0]===F){b(()=>u(_[1]));return}if(_[0]===Z){let v=a.cache;b(()=>u(v));return}if(_[0]===G){let v=_[1],h=v instanceof Error?v.message:String(v),y=v instanceof Error?v:void 0;b(()=>c(new C("internal-error",`reduce: output emitted ERROR: ${h}`,y!=null?{cause:y}:void 0)));return}if(_[0]===B){b(()=>c(new C("internal-error","reduce: output COMPLETEd without a post-push DATA")));return}}}}),l&&(p?.(),p=void 0),d=!0;try{i.set(r,e)}catch(m){let _=m instanceof Error?m.message:String(m),v=m instanceof Error?m:void 0;b(()=>c(new C("internal-error",`reduce: failed to set input on "${r}": ${_}`,v!=null?{path:r,cause:v}:{path:r})));return}!g&&Number.isFinite(s)&&s>0&&(f=setTimeout(()=>{b(()=>c(new C("reduce-timeout",`reduce: no output emitted within ${s}ms`,{timeoutMs:s,outputPath:o})))},s),f.unref?.())})}finally{i.destroy()}}Ge();var Rt=de,Pe="snapshot:";function je(n){if(n.startsWith(Pe))throw new C("snapshot-failed",`snapshot id must not start with "${Pe}" (reserved); got "${n}"`,{snapshotId:n})}function nt(n){return`${Pe}${n}`}function Sr(n){return n.startsWith(Pe)?n.slice(Pe.length):void 0}function Tt(n,e){if(n==null||typeof n!="object")throw new C("snapshot-not-found",`snapshot "${e}" not found in tier`,{snapshotId:e});let t=n;if("mode"in t){if(t.mode==="full"&&"snapshot"in t)return t.snapshot;throw t.mode==="diff"?new C("restore-failed",`snapshot "${e}" is a diff record; restore the baseline and replay WAL instead`,{snapshotId:e,mode:"diff"}):new C("restore-failed",`snapshot "${e}" has unknown mode "${String(t.mode)}"`,{snapshotId:e,mode:String(t.mode)})}if("nodes"in t&&"edges"in t&&"subgraphs"in t&&"name"in t)return t;throw new C("restore-failed",`snapshot "${e}" payload is not a GraphCheckpointRecord or GraphPersistSnapshot`,{snapshotId:e})}async function xn(n,e,t){je(e);let r;try{r=n.snapshot()}catch(s){let i=s instanceof Error?s.message:String(s);throw new C("snapshot-failed",`snapshot "${e}" serialization failed: ${i}`,{snapshotId:e})}let o={name:n.name,mode:"full",seq:0,timestamp_ns:Se(),format_version:Rt,snapshot:r};try{await t.save(nt(e),o)}catch(s){let i=s instanceof Error?s.message:String(s);throw new C("snapshot-failed",`snapshot "${e}" save failed: ${i}`,{snapshotId:e})}return{snapshotId:e,timestamp_ns:o.timestamp_ns}}async function Tn(n,e,t){je(n);let r=nt(n),o=await e.load(r);o===void 0&&(o=await e.load(n));let s=Tt(o,n);try{return ae.fromSnapshot(s,t?.factories?{factories:t.factories}:void 0)}catch(i){let a=i instanceof Error?i.message:String(i);throw new C("restore-failed",`snapshot "${n}" restore failed: ${a}`,{snapshotId:n})}}async function Rn(n,e,t){je(n),je(e);let r=async u=>{let c=nt(u),d=await t.load(c);return d===void 0&&(d=await t.load(u)),d},[o,s]=await Promise.all([r(n),r(e)]),i=Tt(o,n),a=Tt(s,e);return ae.diff(i,a)}async function En(n,e){if(typeof n.list!="function")throw new C("tier-no-list","KvStorageTier does not implement list(); wrap the tier with an enumerator or use a different backend");let t=await n.list(),r=[],o=e?.includeUnprefixed===!0;for(let s of t){let i=Sr(s);i!==void 0?r.push(i):o&&r.push(s)}return r}async function An(n,e){if(je(n),typeof e.delete!="function")throw new C("snapshot-failed",`KvStorageTier is append-only (no delete()); cannot delete "${n}"`,{snapshotId:n});try{await e.delete(nt(n))}catch(t){let r=t instanceof Error?t.message:String(t);throw new C("snapshot-failed",`snapshot "${n}" delete failed: ${r}`,{snapshotId:n})}}0&&(module.exports={SNAPSHOT_WIRE_VERSION,SurfaceError,asSurfaceError,createGraph,deleteSnapshot,diffSnapshots,listSnapshots,restoreSnapshot,runReduction,saveSnapshot});
|
|
@@ -1,9 +1,9 @@
|
|
|
1
|
-
export { C as CatalogFnEntry, a as CatalogSourceEntry, b as ConfigFieldSchema, F as FnFactory, G as GraphSpec, c as GraphSpecCatalog, d as GraphSpecFeedbackEdge, e as GraphSpecNode, f as GraphSpecTemplate, g as GraphSpecTemplateRef, h as GraphSpecValidation, S as SourceFactory } from '../../index-
|
|
2
|
-
export { C as CreateGraphOptions, R as ReduceOptions, a as RestoreSnapshotOptions, S as SNAPSHOT_WIRE_VERSION, b as SaveSnapshotResult, c as SurfaceError, d as SurfaceErrorCode, e as SurfaceErrorPayload, f as asSurfaceError, g as createGraph, h as deleteSnapshot, i as diffSnapshots, l as listSnapshots, r as restoreSnapshot, j as runReduction, s as saveSnapshot } from '../../index-
|
|
3
|
-
import '../../
|
|
4
|
-
import '../../
|
|
5
|
-
import '../../
|
|
1
|
+
export { C as CatalogFnEntry, a as CatalogSourceEntry, b as ConfigFieldSchema, F as FnFactory, G as GraphSpec, c as GraphSpecCatalog, d as GraphSpecFeedbackEdge, e as GraphSpecNode, f as GraphSpecTemplate, g as GraphSpecTemplateRef, h as GraphSpecValidation, S as SourceFactory } from '../../index-DlrWu9Hs.cjs';
|
|
2
|
+
export { C as CreateGraphOptions, R as ReduceOptions, a as RestoreSnapshotOptions, S as SNAPSHOT_WIRE_VERSION, b as SaveSnapshotResult, c as SurfaceError, d as SurfaceErrorCode, e as SurfaceErrorPayload, f as asSurfaceError, g as createGraph, h as deleteSnapshot, i as diffSnapshots, l as listSnapshots, r as restoreSnapshot, j as runReduction, s as saveSnapshot } from '../../index-KlZ_ZUip.cjs';
|
|
3
|
+
import '../../meta-Ct9nqQS5.cjs';
|
|
4
|
+
import '../../node-BYInONRr.cjs';
|
|
5
|
+
import '../../graph-BUwMAxJI.cjs';
|
|
6
6
|
import '../../extra/storage-core.cjs';
|
|
7
7
|
import '../../extra/storage-tiers.cjs';
|
|
8
|
-
import '../../types-
|
|
8
|
+
import '../../types-1Dhoi7HM.cjs';
|
|
9
9
|
import '../../extra/sources.cjs';
|