@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,9 +1,9 @@
|
|
|
1
|
-
import '../../node-
|
|
2
|
-
import '../../
|
|
1
|
+
import '../../node-BYInONRr.js';
|
|
2
|
+
import '../../index-CusEP3Sv.js';
|
|
3
|
+
import '../../reactive-log-BlAsPLl2.js';
|
|
3
4
|
import '../../extra/sources.js';
|
|
4
5
|
import '../../extra/storage-tiers.js';
|
|
5
|
-
import '../../graph-
|
|
6
|
-
|
|
7
|
-
|
|
8
|
-
import '../../meta-BYqlATmg.js';
|
|
6
|
+
import '../../graph-30XSgtVX.js';
|
|
7
|
+
export { a as JobEnvelope, b as JobEvent, c as JobEventAction, d as JobFlowGraph, e as JobFlowOptions, J as JobQueueGraph, f as JobQueueOptions, g as JobState, S as StageDef, W as WorkFn, j as jobEventKeyOf, h as jobFlow, k as jobQueue } from '../../index-C19qqa38.js';
|
|
8
|
+
import '../../meta-D8OyedKp.js';
|
|
9
9
|
import '../../extra/storage-core.js';
|
|
@@ -1 +1 @@
|
|
|
1
|
-
import{a,b,c,d,e}from"../../chunk-
|
|
1
|
+
import{a,b,c,d,e}from"../../chunk-5XRI6RM3.js";import"../../chunk-R75BMDLA.js";import"../../chunk-3G5U5QNE.js";import"../../chunk-C72GO4IZ.js";import"../../chunk-4I45FVQS.js";import"../../chunk-VJJLIEAL.js";import"../../chunk-L6NSJVJZ.js";import"../../chunk-7JRF5YEK.js";import"../../chunk-SGS4OJGS.js";import"../../chunk-ESMPEKEV.js";import"../../chunk-35JTVPOX.js";import"../../chunk-KGKJCHEK.js";import"../../chunk-TZQPPQEQ.js";import"../../chunk-AU7YTQX7.js";import"../../chunk-IA7DUNGB.js";import"../../chunk-LYCLF26R.js";import"../../chunk-CK2E7BTU.js";import"../../chunk-QYADASLV.js";export{c as JobFlowGraph,b as JobQueueGraph,a as jobEventKeyOf,e as jobFlow,d as jobQueue};
|
|
@@ -1,7 +1,3 @@
|
|
|
1
|
-
"use strict";var Qe=Object.defineProperty;var Tn=Object.getOwnPropertyDescriptor;var On=Object.getOwnPropertyNames;var kn=Object.prototype.hasOwnProperty;var B=(t,e)=>()=>(t&&(e=t(t=0)),e);var En=(t,e)=>{for(var n in e)Qe(t,n,{get:e[n],enumerable:!0})},Nn=(t,e,n,r)=>{if(e&&typeof e=="object"||typeof e=="function")for(let o of On(e))!kn.call(t,o)&&o!==n&&Qe(t,o,{get:()=>e[o],enumerable:!(r=Tn(e,o))||r.enumerable});return t};var Sn=t=>Nn(Qe({},"__esModule",{value:!0}),t);function F(){return Math.trunc(performance.now()*1e6)}function Ne(){return Date.now()*1e6}var ce=B(()=>{"use strict"});function Et(t,e){let n=new TextEncoder().encode(t.name);if(n.length===0||n.length>255)throw new Error(`encodeEnvelope: codec name "${t.name}" encodes to ${n.length} bytes (must be 1\u2013255)`);let r=t.version;if(!Number.isInteger(r)||r<0||r>65535)throw new Error(`encodeEnvelope: codec.version ${r} out of u16 range (expected integer 0\u201365535)`);let o=2+n.length+2+e.length;if(o>4294967295)throw new Error(`encodeEnvelope: total envelope size ${o} exceeds 2^32-1 bytes (payload ${e.length} bytes)`);let s=new Uint8Array(o),i=0;return s[i++]=et,s[i++]=n.length,s.set(n,i),i+=n.length,s[i++]=r>>>8&255,s[i++]=r&255,s.set(e,i),s}function Nt(t,e){if(t.length<kt)throw new Error(`decodeEnvelope: bytes too short (${t.length} < ${kt})`);let n=0,r=t[n++];if(r!==et)throw new Error(`decodeEnvelope: unsupported envelope version ${r} (expected ${et})`);let o=t[n++];if(o===0)throw new Error("decodeEnvelope: name_len must be >= 1");if(n+o+2>t.length)throw new Error(`decodeEnvelope: envelope truncated (need ${n+o+2} bytes, have ${t.length})`);let s=new TextDecoder().decode(t.subarray(n,n+o));n+=o;let i=(t[n]<<8|t[n+1])>>>0;n+=2;let a=t.subarray(n),c=e.lookupCodec(s);if(c==null)throw new Error(`decodeEnvelope: codec "${s}" not registered (envelope codec_v=${i})`);return{codec:c,codecVersion:i,payload:a}}function St(t){t.registerCodec(Rn)}var Rn,et,kt,tt=B(()=>{"use strict";Rn={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)}},et=1,kt=4});function Se(t){if(t==null)return le;let{type:e,id:n,...r}=t;return{type:e??"system",id:n??"",...r}}var le,nt=B(()=>{"use strict";le={type:"system",id:""}});function Re(){return de>0||ve}function Rt(){return de>0}function pe(t){de>0?_e.push(t):t()}function Ae(t){de+=1;let e=!1;try{t()}catch(n){throw e=!0,n}finally{if(de-=1,de===0)if(e){if(!ve){let n=_e.splice(0);for(let r of n)try{r()}catch{}ie.length=0,ae.length=0,fe.length=0}}else An()}}function An(){let t=!ve;t&&(ve=!0);let e=[],n=0;try{for(;ie.length>0||ae.length>0||fe.length>0||t&&_e.length>0;){if(t&&_e.length>0){let s=_e.splice(0);for(let i of s)try{i()}catch(a){e.push(a)}continue}if(n+=1,n>1e3)throw ie.length=0,ae.length=0,fe.length=0,new Error("batch drain exceeded 1000 iterations \u2014 likely a reactive cycle");let o=(ie.length>0?ie:ae.length>0?ae:fe).splice(0);for(let s of o)try{s()}catch(i){e.push(i)}}}finally{t&&(ve=!1)}if(e.length===1)throw e[0];if(e.length>1)throw new AggregateError(e,"batch drain: multiple callbacks threw")}function De(t,e,n){if(e.length===0)return;if(e.length===1){let u=n(e[0][0]);if(u<3||!Re()){t(e);return}(u>=5?fe:u===4?ae:ie).push(()=>t(e));return}let r=e.length,o=r,s=r,i=r,a=0;for(;a<r&&n(e[a][0])<3;)a++;for(o=a;a<r&&n(e[a][0])===3;)a++;for(s=a;a<r&&n(e[a][0])===4;)a++;i=a;let c=Re();if(o>0){let u=e.slice(0,o);t(u)}if(s>o){let u=e.slice(o,s);c?ie.push(()=>t(u)):t(u)}if(i>s){let u=e.slice(s,i);c?ae.push(()=>t(u)):t(u)}if(r>i){let u=e.slice(i,r);c?fe.push(()=>t(u)):t(u)}}var de,ve,ie,ae,fe,_e,Ce=B(()=>{"use strict";de=0,ve=!1,ie=[],ae=[],fe=[],_e=[]});var we,P,W,Z,J,Q,ne,V,U,L,he,rt,Dn,ot,Cn,Gn,st,At,Dt,Ct,it,ge=B(()=>{"use strict";we=Symbol.for("graphrefly/START"),P=Symbol.for("graphrefly/DATA"),W=Symbol.for("graphrefly/DIRTY"),Z=Symbol.for("graphrefly/RESOLVED"),J=Symbol.for("graphrefly/INVALIDATE"),Q=Symbol.for("graphrefly/PAUSE"),ne=Symbol.for("graphrefly/RESUME"),V=Symbol.for("graphrefly/TEARDOWN"),U=Symbol.for("graphrefly/COMPLETE"),L=Symbol.for("graphrefly/ERROR"),he=Object.freeze([W]),rt=Object.freeze([Z]),Dn=Object.freeze([J]),ot=Object.freeze([we]),Cn=Object.freeze([U]),Gn=Object.freeze([V]),st=Object.freeze([he]),At=Object.freeze([rt]),Dt=Object.freeze([Dn]),Ct=Object.freeze([Cn]),it=Object.freeze([Gn])});function Gt(t){t.registerMessageType(we,{tier:0,wireCrossing:!1}),t.registerMessageType(W,{tier:1,wireCrossing:!1}),t.registerMessageType(J,{tier:1,wireCrossing:!1,metaPassthrough:!1}),t.registerMessageType(Q,{tier:2,wireCrossing:!1}),t.registerMessageType(ne,{tier:2,wireCrossing:!1}),t.registerMessageType(P,{tier:3,wireCrossing:!0}),t.registerMessageType(Z,{tier:3,wireCrossing:!0}),t.registerMessageType(U,{tier:4,wireCrossing:!0,metaPassthrough:!1}),t.registerMessageType(L,{tier:4,wireCrossing:!0,metaPassthrough:!1}),t.registerMessageType(V,{tier:5,wireCrossing:!0,metaPassthrough:!1})}var Ge,Mt=B(()=>{"use strict";ge();Ge=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 at(t){let e=Mn.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 q,Mn,Me=B(()=>{"use strict";q=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}},Mn=["human","llm","wallet","system"]});function ut(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(ut);if(typeof t=="object"&&t!==null){let e={};for(let n of Object.keys(t).sort())e[n]=ut(t[n]);return e}return null}function In(t){let e=Ln.encode(t),n=e.length,r=n*8,o=n+9+63&-64,s=new Uint8Array(o);s.set(e),s[n]=128;let i=new DataView(s.buffer);i.setUint32(o-4,r>>>0,!1),i.setUint32(o-8,Math.floor(r/4294967296)>>>0,!1);let a=1779033703,c=3144134277,u=1013904242,d=2773480762,h=1359893119,p=2600822924,f=528734635,l=1541459225,m=new Uint32Array(64),g=(v,b)=>v>>>b|v<<32-b;for(let v=0;v<o;v+=64){for(let S=0;S<16;S++)m[S]=i.getUint32(v+S*4,!1);for(let S=16;S<64;S++){let C=m[S-15],E=m[S-2],R=g(C,7)^g(C,18)^C>>>3,H=g(E,17)^g(E,19)^E>>>10;m[S]=m[S-16]+R+m[S-7]+H>>>0}let b=a,_=c,T=u,w=d,x=h,O=p,N=f,A=l;for(let S=0;S<64;S++){let C=g(x,6)^g(x,11)^g(x,25),E=x&O^~x&N,R=A+C+E+Pn[S]+m[S]>>>0,H=g(b,2)^g(b,13)^g(b,22),X=b&_^b&T^_&T,se=H+X>>>0;A=N,N=O,O=x,x=w+R>>>0,w=T,T=_,_=b,b=R+se>>>0}a=a+b>>>0,c=c+_>>>0,u=u+T>>>0,d=d+w>>>0,h=h+x>>>0,p=p+O>>>0,f=f+N>>>0,l=l+A>>>0}let y=v=>v.toString(16).padStart(8,"0");return y(a)+y(c)+y(u)+y(d)+y(h)+y(p)+y(f)+y(l)}function ct(t){let e=ut(t??null),n=JSON.stringify(e);return In(n).slice(0,16)}function $n(){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 lt(t,e,n){let r=n?.id??$n();if(t===0)return{id:r,version:0};let s=(n?.hash??ct)(e);return{id:r,version:0,cid:s,prev:null}}function Pt(t,e,n){t.version+=1,"cid"in t&&(t.prev=t.cid,t.cid=n(e))}var Pn,Ln,Lt=B(()=>{"use strict";Pn=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]),Ln=new TextEncoder});function Ft(t){return{node:t,unsub:null,prevData:void 0,dirty:!1,involvedThisWave:!1,dataBatch:[],terminal:void 0}}function dt(t){t.prevData=void 0,t.dirty=!1,t.involvedThisWave=!1,t.dataBatch.length=0,t.terminal=void 0}function Pe(t){return t.length===0?t:typeof t[0]=="symbol"?[t]:t}function Le(t,e,n){let r=Vt(t)?t:[],o=typeof t=="function"?t:typeof e=="function"?e:void 0,s={};return Vt(t)?s=(ft(e)?e:n)??{}:ft(t)?s=t:s=(ft(e)?e:n)??{},new I(r,o,s)}var It,$t,Fn,Vn,me,I,Vt,ft,xe=B(()=>{"use strict";tt();nt();Ce();ce();Mt();Me();ge();Lt();It=()=>{},$t=100;Fn=(t,e,n,r)=>{n.direction==="down-in"&&t._onDepMessage(n.depIndex,e)},Vn=(t,e,n,r)=>{let o=t;if(o._status==="completed"||o._status==="errored")return;let s=o._cached,i=s===void 0?[ot]:[ot,[P,s]];o._status==="dirty"&&i.push(he),De(e,i,o._config.tierOf)},me=new Ge({onMessage:Fn,onSubscribe:Vn});Gt(me);St(me);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??me,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??ct;let o=r.versioning??this._config.defaultVersioning;this._versioningLevel=o,this._versioning=o!=null?lt(o,this._cached===void 0?void 0:this._cached,{id:r.versioningId,hash:this._hashFn}):void 0,this._deps=e.map(Ft);let s={};for(let[a,c]of Object.entries(r.meta??{})){let u={initial:c,name:`${r.name??"node"}:meta:${a}`,describeKind:"state",config:this._config};r.guard!=null&&(u.guard=r.guard),s[a]=new t([],void 0,u)}Object.freeze(s),this.meta=s,this._hasMeta=Object.keys(s).length>0;let i=this;this._actions={emit(a){i._emit([[P,a]])},down(a){i._emit(Pe(a))},up(a){i._emitUp(Pe(a))}},this.down=this.down.bind(this),this.up=this.up.bind(this)}get _isTerminal(){return this._status==="completed"||this._status==="errored"}get name(){return this._optsName}get status(){return this._status}get cache(){return this._cached===void 0?void 0:this._cached}get lastMutation(){return this._lastMutation}get v(){return this._versioning}hasGuard(){return this._guard!=null}_applyVersioning(e,n){if(this._isExecutingFn)throw new Error(`Node "${this.name}": _applyVersioning cannot run mid-fn \u2014 call it outside of \`_execFn\` (typically at graph setup time before the first subscribe).`);let r=this._versioningLevel;if(r!=null&&e<=r)return;let o=n?.hash??this._hashFn;o!==this._hashFn&&(this._hashFn=o);let s=this._cached===void 0?void 0:this._cached,i=this._versioning,a=i?.id??n?.id,c=i?.version??0,u=lt(e,s,{id:a,hash:o});u.version=c,this._versioning=u,this._versioningLevel=e}_setInspectorHook(e){return e==null?()=>{}:(this._inspectorHooks==null&&(this._inspectorHooks=new Set),this._inspectorHooks.add(e),()=>{this._inspectorHooks?.delete(e),this._inspectorHooks?.size===0&&(this._inspectorHooks=void 0)})}_pushGuard(e){return this._extraGuards==null&&(this._extraGuards=new Set),this._extraGuards.add(e),()=>{this._extraGuards?.delete(e),this._extraGuards?.size===0&&(this._extraGuards=void 0)}}allowsObserve(e){if(this._guard==null&&this._extraGuards==null)return!0;let n=Se(e);if(this._guard!=null&&!this._guard(n,"observe"))return!1;if(this._extraGuards!=null){for(let r of this._extraGuards)if(!r(n,"observe"))return!1}return!0}_checkGuard(e){if(e?.internal)return;let n=this._guard!=null||this._extraGuards!=null,r=e?.actor!=null;if(!n&&!r)return;let o=Se(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:Ne()}}down(e,n){let r=Pe(e);r.length!==0&&(this._checkGuard(n),this._emit(r))}emit(e,n){this._checkGuard(n),this._emit([[P,e]])}up(e,n){if(this._deps.length===0)return;let r=Pe(e);if(r.length===0)return;this._checkGuard(n);let o=n??{internal:!0};this._validateUpTiers(r);for(let s of this._deps)s.node.up?.(r,o)}_emitUp(e){if(this._deps.length!==0&&e.length!==0){this._validateUpTiers(e);for(let n of this._deps)n.node.up?.(e,{internal:!0})}}_validateUpTiers(e){let n=this._config.tierOf;for(let r of e){let o=n(r[0]);if(o===3||o===4)throw new Error(`Node "${this.name}": tier-${o} messages cannot flow up \u2014 DATA/RESOLVED/COMPLETE/ERROR are downstream-only. Use \`down(...)\` for value delivery; \`up(...)\` is for control signals (DIRTY, INVALIDATE, PAUSE, RESUME, TEARDOWN).`)}}subscribe(e,n){if(n!=null&&this._guard!=null){let c=Se(n);if(!this._guard(c,"observe"))throw new q({actor:c,action:"observe",nodeName:this.name})}let o=this._isTerminal&&this._resubscribable;if(o){this._cached=void 0,this._status="sentinel",this._store={},this._hasCalledFnOnce=!1,this._waveHasNewData=!1,this._hasNewTerminal=!1,this._paused=!1,this._pendingWave=!1,this._pendingRerun=!1,this._isExecutingFn=!1,this._rerunDepth=0,this._dirtyDepCount=0,this._pauseLocks=null,this._pauseBuffer=null;for(let c of this._deps)dt(c);if(this._partial===!1){for(let c of this._deps)if(c.prevData!==void 0||c.dataBatch.length!==0||c.terminal!==void 0||c.dirty)throw new Error(`resubscribable-reset invariant: DepRecord not fully reset for node ${this._optsName??"(anonymous)"}`)}}this._sinkCount+=1;let s;try{s=this._config.onSubscribe(this,e,{sinkCount:this._sinkCount,afterTerminalReset:o},this._actions)}catch(c){throw this._sinkCount-=1,c}this._sinks==null?this._sinks=e:typeof this._sinks=="function"?this._sinks=new Set([this._sinks,e]):this._sinks.add(e);let i=this._isTerminal;if(this._sinkCount===1&&!i)try{this._activate()}catch(c){if(this._sinkCount-=1,this._removeSink(e),this._sinkCount===0&&(this._status="sentinel"),typeof s=="function")try{s()}catch{}throw c}this._status==="sentinel"&&this._cached===void 0&&(this._status="pending");let a=!1;return()=>{a||(a=!0,this._sinkCount-=1,this._removeSink(e),typeof s=="function"&&s(),this._sinks==null&&this._deactivate())}}_removeSink(e){if(this._sinks===e)this._sinks=null;else if(this._sinks!=null&&typeof this._sinks!="function")if(this._sinks.delete(e),this._sinks.size===1){let[n]=this._sinks;this._sinks=n}else this._sinks.size===0&&(this._sinks=null)}_activate(){if(this._deps.length===0){this._fn&&this._execFn();return}this._dirtyDepCount=0;let e=this._deps.length,n=0;try{for(let r=0;r<e;r++){let o=r,s=this._deps[r];s.unsub=It,s.unsub=s.node.subscribe(i=>{if(s.unsub===null)return;let a=this._config.tierOf,c=!1;for(let u of i)a(u[0])>=3&&(c=!0),this._config.onMessage(this,u,{direction:"down-in",depIndex:o},this._actions);c&&this._maybeRunFnOnSettlement()}),n++}}catch(r){this._deps[n].unsub=null;for(let o=0;o<n;o++){let s=this._deps[o];if(s.unsub!=null){let i=s.unsub;s.unsub=null;try{i()}catch{}dt(s)}}throw this._dirtyDepCount=0,r}}_addDep(e){for(let o=0;o<this._deps.length;o++)if(this._deps[o].node===e)return o;let n=this._deps.length,r=Ft(e);if(this._deps.push(r),this._sinks==null)return n;r.dirty=!0,this._dirtyDepCount++,this._status!=="dirty"&&this._emit(st),r.unsub=It;try{r.unsub=e.subscribe(o=>{if(r.unsub===null)return;let s=this._config.tierOf,i=!1;for(let a of o)s(a[0])>=3&&(i=!0),this._config.onMessage(this,a,{direction:"down-in",depIndex:n},this._actions);i&&this._maybeRunFnOnSettlement()})}catch(o){throw r.unsub=null,this._deps.pop(),this._dirtyDepCount--,o}return n}_deactivate(e=!1){let n=this._cleanup;if(this._cleanup=void 0,typeof n=="function")try{n()}catch(r){this._emit([[L,this._wrapFnError("cleanup threw",r)]])}else if(n!=null&&typeof n=="object"){let r=n.deactivate;if(typeof r=="function")try{r()}catch(o){this._emit([[L,this._wrapFnError("cleanup.deactivate threw",o)]])}}for(let r of this._deps){if(r.unsub!=null){let o=r.unsub;r.unsub=null;try{o()}catch{}}dt(r)}this._waveHasNewData=!1,this._hasNewTerminal=!1,this._hasCalledFnOnce=!1,this._paused=!1,this._pendingWave=!1,this._pendingRerun=!1,this._rerunDepth=0,this._store={},this._dirtyDepCount=0,this._pauseLocks=null,this._pauseBuffer=null,this._fn!=null&&(this._cached=void 0),e||(this._fn!=null||this._deps.length>0)&&(!this._isTerminal||this._resubscribable)&&(this._status="sentinel")}_onDepMessage(e,n){let r=this._deps[e],o=n[0];if(this._inspectorHooks!=null){let s={kind:"dep_message",depIndex:e,message:n};for(let i of this._inspectorHooks)i(s)}if(o!==we){if(o===W){this._depDirtied(r);return}if(o===J){if(this._depInvalidated(r),this._cached===void 0)return;this._emit(Dt);return}if(o===Q||o===ne){this._emit([n]);return}if(o===V){this._emit(it);return}if(o===P)this._depSettledAsData(r,n[1]);else if(o===Z)this._depSettledAsResolved(r);else if(o===U)this._depSettledAsTerminal(r,!0);else if(o===L)this._depSettledAsTerminal(r,n[1]);else{this._emit([n]);return}if(!this._fn){(o===P||o===Z)&&this._emit([n]),(o===U||o===L)&&this._maybeAutoTerminalAfterWave();return}}}_depDirtied(e){e.dirty||(e.dirty=!0,e.involvedThisWave=!0,this._dirtyDepCount++,this._status!=="dirty"&&this._emit(st))}_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(At),this._maybeAutoTerminalAfterWave();return}this._fn&&this._execFn(),this._maybeAutoTerminalAfterWave()}}_maybeAutoTerminalAfterWave(){if(this._deps.length===0||this._isTerminal)return;let e=this._deps.find(n=>n.terminal!==void 0&&n.terminal!==!0);if(e!=null){this._autoError&&this._emit([[L,e.terminal]]);return}this._autoComplete&&this._deps.every(n=>n.terminal!==void 0)&&this._emit(Ct)}_execFn(){if(!this._fn||this._isTerminal&&!this._resubscribable)return;if(this._isExecutingFn){this._pendingRerun=!0;return}let e=this._cleanup;if(typeof e=="function"){this._cleanup=void 0;try{e()}catch(i){this._emit([[L,this._wrapFnError("cleanup threw",i)]]);return}}else if(e!=null&&typeof e=="object"){let i=e.beforeRun;if(typeof i=="function"){e.beforeRun=void 0;try{i()}catch(a){this._emit([[L,this._wrapFnError("cleanup.beforeRun threw",a)]]);return}}}let n=this._deps.map(i=>i.involvedThisWave?i.dataBatch.length>0?[...i.dataBatch]:[]:void 0),r=this._deps.map(i=>i.prevData);for(let i=0;i<this._deps.length;i++){let a=n[i];a!=null&&a.length>0&&(this._deps[i].prevData=a[a.length-1])}let o=this._deps.map(i=>i.terminal),s={prevData:r,terminalDeps:o,store:this._store};if(this._hasCalledFnOnce=!0,this._clearWaveFlags(),this._inspectorHooks!=null){let i={kind:"run",batchData:n,prevData:r};for(let a of this._inspectorHooks)a(i)}this._isExecutingFn=!0;try{let i=this._fn(n,this._actions,s);if(typeof i=="function")this._cleanup=i;else if(i!=null&&typeof i=="object"){let a=i;(typeof a.beforeRun=="function"||typeof a.deactivate=="function"||typeof a.invalidate=="function")&&(this._cleanup=i)}}catch(i){this._emit([[L,this._wrapFnError("fn threw",i)]])}finally{this._isExecutingFn=!1,this._pendingRerun?(this._pendingRerun=!1,this._rerunDepth+=1,this._rerunDepth>$t?(this._rerunDepth=0,this._emit([[L,new Error(`Node "${this.name}": _pendingRerun depth exceeded ${$t} \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"?[he,e[0]]:e;let r=!0,o=!1,s=!1,i=-1;for(let c of e){let u=n(c[0]);u<i&&(r=!1),u===3&&(o=!0),c[0]===W&&(s=!0),i=u}let a=e;if(!r){let c=e.map((u,d)=>({m:u,i:d,tier:n(u[0])}));c.sort((u,d)=>u.tier-d.tier||u.i-d.i),a=c.map(u=>u.m)}if(o&&!s&&this._status!=="dirty"){let c=0;for(;c<a.length&&n(a[c][0])===0;)c++;return c===0?[he,...a]:[...a.slice(0,c),he,...a.slice(c)]}return a}_emit(e){if(e.length===0)return;for(let a=0;a<e.length;a++){let c=e[a];if(c[0]===L&&c[1]===void 0)throw new TypeError('[ERROR, payload] requires a non-undefined payload (spec \xA71.2). Pass an Error object or domain tag instead \u2014 e.g. node.down([[ERROR, new Error("reason")]])')}let n=e;if(this._isTerminal&&!this._resubscribable){let a=e.filter(c=>c[0]===V||c[0]===J);if(a.length===0)return;n=a}n=this._frameBatch(n);let o=null;for(let a=0;a<n.length;a++){let c=n[a],u=c[0];if(u!==Q&&u!==ne){o?.push(c);continue}if(c.length<2)throw new Error(`Node "${this.name}": [[${u===Q?"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=c[1];if(u===Q)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?o?.push(c):o==null&&(o=n.slice(0,a))}if(o!=null){if(o.length===0)return;n=o}if(this._hasMeta&&n.some(a=>a[0]===V))for(let a of Object.keys(this.meta))try{this.meta[a]._emit(it)}catch{}let{finalMessages:s,equalsError:i}=this._updateState(n);if(s.length>0&&this._config.inspectorEnabled){let a=this._config.globalInspector;if(a!=null)try{a({kind:"emit",node:this,messages:s})}catch{}}if(s.length>0)if(this._paused&&this._pausable==="resumeAll"&&this._pauseBuffer!=null){let a=this._config.tierOf,c=[];for(let u of s)a(u[0])===3?this._pauseBuffer.push(u):c.push(u);c.length>0&&this._dispatchOrAccumulate(c)}else this._dispatchOrAccumulate(s);i!=null&&this._emit([[L,i]])}_updateState(e){let n=this._config.tierOf,r,o,s=-1,i=0;for(let d of e)n(d[0])===3&&i++;let a=i<=1,c=-1;if(this._versioning!=null&&i>1){for(let d=e.length-1;d>=0;d--)if(e[d][0]===P){c=d;break}}for(let d=0;d<e.length;d++){let h=e[d],p=h[0];if(p===P){if(h.length>=2){let f=!1;if(a&&this._cached!==void 0)try{f=this._equals(this._cached,h[1])}catch(l){o=this._wrapFnError("equals threw",l),s=d;break}if(f){r==null&&(r=e.slice(0,d)),r.push(rt),this._status="resolved";continue}this._cached=h[1],this._versioning!=null&&(c<0||d===c)&&Pt(this._versioning,h[1],this._hashFn)}this._status="settled",r?.push(h)}else if(r?.push(h),p===W)this._status="dirty";else if(p===Z)this._status="resolved";else if(p===U){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===L){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===J){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===V&&(this._resetOnTeardown&&(this._cached=void 0),this._deactivate(!0),this._status="sentinel")}let u=s>=0?r??e.slice(0,s):r??e;return o!=null?{finalMessages:u,equalsError:o}:{finalMessages:u}}_deliverToSinks=e=>{if(this._sinks==null)return;if(typeof this._sinks=="function"){this._sinks(e);return}let n=[...this._sinks];for(let r of n)r(e)};_dispatchOrAccumulate(e){if(Rt()){this._batchPendingMessages===null&&(this._batchPendingMessages=[],pe(()=>this._flushBatchPending()));for(let n of e)this._batchPendingMessages.push(n);return}De(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);De(this._deliverToSinks,n,this._config.tierOf)}},Vt=t=>Array.isArray(t),ft=t=>typeof t=="object"&&t!=null&&!Array.isArray(t)});function ee(t,e){return Le([],{...e,initial:t})}function pt(t,e){return Le((r,o,s)=>t(o,s)??void 0,{describeKind:"producer",...e})}function ye(t,e,n){return Le(t,(o,s,i)=>{let a=o.map((c,u)=>c!=null&&c.length>0?c.at(-1):i.prevData[u]);s.emit(e(a,i))},{describeKind:"derived",...n})}var Ie=B(()=>{"use strict";xe()});function je(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 Un(t){return t._describeKind!=null?t._describeKind:t._deps.length>0?"derived":t._fn!=null?"producer":"state"}function qn(t){let e={};for(let[n,r]of Object.entries(t.meta))try{e[n]=r.cache}catch{}return e}function gt(t,e){let n=e==null,r=!n&&e!=null?[...e].filter(u=>u.startsWith("meta.")).map(u=>u.slice(5)):null,o=n||e.has("meta")||r!=null&&r.length>0,s="state",i=[];t instanceof I&&(s=Un(t),i=t._deps.map(u=>u.node.name??""));let a={type:s,deps:i};(n||e.has("status"))&&(a.status=t.status);let c=t instanceof I?t._guard:void 0;if(o){let u={...qn(t)};if(c!=null&&u.access===void 0&&(u.access=at(c)),r!=null&&r.length>0&&!e.has("meta")){let d={};for(let h of r)h in u&&(d[h]=u[h]);a.meta=d}else a.meta=u}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 u={id:t.v.id,version:t.v.version};"cid"in t.v&&(u.cid=t.v.cid,u.prev=t.v.prev),a.v=u}return(n||e.has("guard"))&&c!=null&&(a.guard=at(c)),(n||e.has("lastMutation"))&&t.lastMutation!=null&&(a.lastMutation=t.lastMutation),a}var Ut=B(()=>{"use strict";Me();xe()});function re(t){return t.subscribe(()=>{})}var bt=B(()=>{"use strict"});var He,Yt=B(()=>{"use strict";He=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 jr={};En(jr,{LensGraph:()=>qe,graphLens:()=>Vr,watchTopologyTree:()=>ke});module.exports=Sn(jr);ce();Ie();Ce();ce();ge();Ie();var ht=class{_version=0;_store=new Map;_maxSize;_defaultTtl;constructor(e={}){let{maxSize:n,defaultTtl:r}=e;if(n!==void 0&&n<1)throw new RangeError("maxSize must be >= 1");if(r!==void 0&&r<=0)throw new RangeError("defaultTtl must be positive");this._maxSize=n,this._defaultTtl=r}get version(){return this._version}get size(){return this._store.size}has(e){let n=this._store.get(e);return n===void 0?!1:this._isExpired(n)?(this._store.delete(e),this._version+=1,!1):(this._touchLru(e,n),!0)}get(e){let n=this._store.get(e);if(n!==void 0){if(this._isExpired(n)){this._store.delete(e),this._version+=1;return}return this._touchLru(e,n),n.value}}set(e,n,r){let o=this._resolveExpiresAt(r);this._store.has(e)&&this._store.delete(e),this._store.set(e,{value:n,expiresAt:o}),this._evictLruWhileOver(),this._version+=1}setMany(e,n){let r=this._resolveExpiresAt(n),o=0;try{for(let[s,i]of e)this._store.has(s)&&this._store.delete(s),this._store.set(s,{value:i,expiresAt:r}),o+=1}finally{o>0&&(this._evictLruWhileOver(),this._version+=1)}}delete(e){let n=this._store.delete(e);return n&&(this._version+=1),n}deleteMany(e){let n=0;try{for(let r of e)this._store.delete(r)&&(n+=1)}finally{n>0&&(this._version+=1)}return n}clear(){let e=this._store.size;return e===0?0:(this._store.clear(),this._version+=1,e)}pruneExpired(){let e=F(),n=0;for(let[r,o]of this._store)this._isExpired(o,e)&&(this._store.delete(r),n+=1);return n>0&&(this._version+=1),n}toMap(){let e=F(),n=new Map;for(let[r,o]of this._store)this._isExpired(o,e)||n.set(r,o.value);return n}_resolveExpiresAt(e){let n=e??this._defaultTtl;if(n!==void 0){if(!Number.isFinite(n)||n<=0)throw new RangeError(`MapBackend: ttl must be a positive finite number (got ${n})`);return F()+n*1e9}}_isExpired(e,n){return e.expiresAt===void 0?!1:(n??F())>=e.expiresAt}_touchLru(e,n){this._store.delete(e),this._store.set(e,n)}_evictLruWhileOver(){if(this._maxSize!==void 0)for(;this._store.size>this._maxSize;){let e=this._store.keys().next().value;if(e===void 0)break;this._store.delete(e)}}};function jt(t={}){let{name:e,maxSize:n,defaultTtl:r,versioning:o,backend:s,retention:i}=t;if(i&&n!==void 0)throw new RangeError("reactiveMap: `maxSize` (LRU) and `retention` (score-based) are mutually exclusive. Pick one eviction policy.");if(i&&i.archiveThreshold===void 0&&i.maxSize===void 0)throw new RangeError("reactiveMap: `retention` requires at least one of `archiveThreshold` or `maxSize` to trigger archival.");let a=s??new ht({maxSize:n,defaultTtl:r}),c=ee(a.toMap(),{name:e,describeKind:"state",equals:(p,f)=>p===f,...o!=null?{versioning:o}:{}});function u(){let p=a.toMap();Ae(()=>{c.down([[W]]),c.down([[P,p]])})}function d(){if(!i)return;let p=a.toMap(),f=i.archiveThreshold,l=i.maxSize,m=[];for(let[y,v]of p)m.push({key:y,value:v,score:i.score(y,v)});m.sort((y,v)=>y.score-v.score);let g=new Set;if(f!==void 0)for(let y of m)if(y.score<f)g.add(y.key);else break;if(l!==void 0&&m.length-g.size>l)for(let y of m){if(m.length-g.size<=l)break;g.has(y.key)||g.add(y.key)}if(g.size!==0)for(let y of m)g.has(y.key)&&(i.onArchive?.(y.key,y.value,y.score),a.delete(y.key))}function h(p,f="mutation"){let l=a.version;try{return p()}finally{a.version!==l&&(f==="mutation"&&d(),u())}}return{entries:c,has(p){return h(()=>a.has(p),"read")},get(p){return h(()=>a.get(p),"read")},set(p,f,l){h(()=>a.set(p,f,l?.ttl))},setMany(p,f){h(()=>a.setMany(p,f?.ttl))},delete(p){h(()=>a.delete(p))},deleteMany(p){h(()=>a.deleteMany(p))},clear(){h(()=>a.clear())},pruneExpired(){h(()=>a.pruneExpired())},get size(){return a.size},dispose(){}}}var $={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},jn=Symbol.for("sizeof");function Ht(t){let e=new WeakSet,n=new WeakSet,r=[t],o=0;for(;r.length>0;){let s=r.pop();o+=Hn(s,e,n,r)}return o}function Hn(t,e,n,r){if(t==null)return 0;switch(typeof t){case"number":return $.number;case"boolean":return $.boolean;case"string":return $.string+t.length*2;case"bigint":return $.bigint+Bn(t);case"symbol":return $.symbol;case"function":return e.has(t)?0:(e.add(t),$.function);case"undefined":return 0}let s=t;if(e.has(s))return 0;e.add(s);let i=s[jn];if(typeof i=="function")try{let u=i.call(s);if(typeof u=="number"&&Number.isFinite(u))return u}catch{}if(s instanceof Date)return $.date;if(s instanceof RegExp)return $.regexp+s.source.length*2;if(s instanceof Error){let u=s.message?s.message.length*2:0,d=s.stack?s.stack.length*2:0;return $.error+u+d}if(typeof URL<"u"&&s instanceof URL)return $.url+s.href.length*2;if(typeof Promise<"u"&&s instanceof Promise)return $.promise;if(s instanceof WeakMap)return $.weakmap;if(s instanceof WeakSet)return $.weakset;if(s instanceof Map){let u=$.map;for(let[d,h]of s)u+=$.mapEntry,r.push(d),r.push(h);return u}if(s instanceof Set){let u=$.set;for(let d of s)u+=$.setEntry,r.push(d);return u}if(Array.isArray(s)){let u=$.array+s.length*8;for(let d of s)r.push(d);return u}if(s instanceof ArrayBuffer)return n.has(s)?0:(n.add(s),s.byteLength);if(ArrayBuffer.isView(s)){let u=s;return n.has(u.buffer)?48:(n.add(u.buffer),u.buffer.byteLength+48)}let a=$.object,c=Object.keys(s);for(let u of c){a+=$.string+u.length*2;try{r.push(s[u])}catch{}}return a}function Bn(t){let e=t<0n?-t:t;if(e===0n)return 0;let n=e.toString(2).length;return Math.ceil(n/32)*8}function Bt(t,e,n,r={}){let o=e in t.nodes,s=n in t.nodes;if(!o)return $e(e,n,"no-such-from");if(!s)return $e(e,n,"no-such-to");let i=r.maxDepth;if(i!=null&&(!Number.isInteger(i)||i<0))throw new Error("explainPath: maxDepth must be an integer >= 0");if(e===n){if(r.findCycle===!0){let u=zn(t,e,r);if(u!=null)return u}let c=Fe(e,t.nodes[e],0,r);return Ve(e,n,[c])}if(i===0)return $e(e,n,"no-path");let a=zt(t,e,n,i);return a.found?Ve(e,n,Kt(t,a.pathOrder,r)):$e(e,n,a.truncated?"max-depth-exceeded":"no-path")}function zt(t,e,n,r){let o=new Map,s=[{path:n,depth:0}],i=new Set([n]),a=0,c=!1;for(;a<s.length;){let h=s[a++];if(h.path===e)break;if(r!=null&&h.depth>=r){let m=t.nodes[h.path];m?.deps&&m.deps.length>0&&(c=!0);continue}let p=t.nodes[h.path];if(p==null)continue;let f=p.deps??[],l=new Map;for(let m=0;m<f.length;m++){let g=f[m];if(!g)continue;let y=l.get(g);y==null&&(y=[],l.set(g,y)),y.push(m)}for(let[m,g]of l)i.has(m)||(i.add(m),o.set(m,{from:h.path,depIndices:g}),s.push({path:m,depth:h.depth+1}))}if(!o.has(e))return{found:!1,pathOrder:[],truncated:c};let u=[{path:e}],d=e;for(;d!==n;){let h=o.get(d);if(h==null)return{found:!1,pathOrder:[],truncated:!1};u[u.length-1].depIndices=h.depIndices,u.push({path:h.from}),d=h.from}return{found:!0,pathOrder:u,truncated:!1}}function zn(t,e,n){let r=t.nodes[e];if(r==null)return null;let o=r.deps??[],s=[];for(let a=0;a<o.length;a++)o[a]===e&&s.push(a);if(s.length>0){let a=Fe(e,r,0,n);a.dep_index=s[0];let c=Fe(e,r,1,n);return Ve(e,e,[a,c])}let i=null;for(let a=0;a<o.length;a++){let c=o[a];if(!c||c===e)continue;let u=zt(t,c,e,n.maxDepth);u.found&&(i==null||u.pathOrder.length<i.pathOrder.length)&&(i=u,i={found:!0,pathOrder:[{path:e,depIndices:[a]},...u.pathOrder],truncated:!1})}return i==null?null:Ve(e,e,Kt(t,i.pathOrder,n))}function Kt(t,e,n){return e.map((r,o)=>{let s=t.nodes[r.path],i=Fe(r.path,s,o,n);return r.depIndices!=null&&r.depIndices.length>0&&(i.dep_index=r.depIndices[0],r.depIndices.length>1&&(i.dep_indices=[...r.depIndices])),i})}function Fe(t,e,n,r){let o={path:t,type:e.type,hop:n};e.status!==void 0&&(o.status=e.status),"value"in e&&(o.value=e.value),e.v!=null&&(o.v=e.v);let s=r.annotations?.get(t)??e.annotation;s!=null&&(o.annotation=s);let i=r.lastMutations?.get(t)??e.lastMutation;return i!=null&&(o.lastMutation=i),o}function Ve(t,e,n){return Wt(t,e,!0,"ok",n)}function $e(t,e,n){return Wt(t,e,!1,n,[])}function Wt(t,e,n,r,o){let s=Kn(t,e,n,r,o);return{from:t,to:e,found:n,reason:r,steps:o,text:s,toJSON(){return{from:t,to:e,found:n,reason:r,steps:o}}}}function Kn(t,e,n,r,o){if(!n)switch(r){case"no-such-from":return`explainPath: no node named "${t}"`;case"no-such-to":return`explainPath: no node named "${e}"`;case"max-depth-exceeded":return`explainPath: no path from "${t}" to "${e}" within maxDepth`;default:return`explainPath: no path from "${t}" to "${e}"`}let s=[`Causal path: ${t} \u2192 ${e} (${o.length} step(s))`];for(let i of o){let c=` ${i.hop===0?"\xB7":"\u2193"} ${i.path} (${i.type}${i.status?`/${i.status}`:""})`;if(s.push(c),"value"in i&&s.push(` value: ${Wn(i.value)}`),i.annotation!=null&&s.push(` annotation: ${i.annotation}`),i.lastMutation!=null){let u=i.lastMutation.actor;s.push(` actor: ${u.type}${u.id?`:${u.id}`:""}`)}}return s.join(`
|
|
2
|
-
`)}function
|
|
3
|
-
`)}function Xn(t,e,n,r,o){let{x:s,y:i,w:a,h:c}=r;if(a<2||c<2){c>0&&Xt(t,e,s,i,a,o);return}oe(t,e,s,i,n.boxTL);for(let d=s+1;d<s+a-1;d+=1)oe(t,e,d,i,n.boxH);oe(t,e,s+a-1,i,n.boxTR);for(let d=i+1;d<i+c-1;d+=1){oe(t,e,s,d,n.boxV);for(let h=s+1;h<s+a-1;h+=1)tn(t,e,h,d," ","empty");oe(t,e,s+a-1,d,n.boxV)}oe(t,e,s,i+c-1,n.boxBL);for(let d=s+1;d<s+a-1;d+=1)oe(t,e,d,i+c-1,n.boxH);oe(t,e,s+a-1,i+c-1,n.boxBR);let u=i+Math.floor(c/2);Xt(t,e,s+1,u,a-2,o)}function oe(t,e,n,r,o){tn(t,e,n,r,o,o===" "?"empty":o==="\u2500"||o==="-"?"boxH":o==="\u2502"||o==="|"?"boxV":"boxCorner")}function tn(t,e,n,r,o,s){if(r<0||r>=t.length)return;let i=t[r];n<0||n>=i.length||(i[n]=o,e[r][n]=s)}function Xt(t,e,n,r,o,s){if(r<0||r>=t.length)return;let i=n,a=o;for(let c of s){let u=Be(c);if(u!==0){if(a<u)break;i>=0&&i<t[r].length&&(t[r][i]=c,e[r][i]="label",u===2&&i+1<t[r].length&&(t[r][i+1]="",e[r][i+1]="label")),i+=u,a-=u}}for(;a>0;)i>=0&&i<t[r].length&&(t[r][i]=" ",e[r][i]="empty"),i+=1,a-=1}function Zn(t,e,n,r){let o=r.points;if(o.length<2)return;for(let c=0;c+1<o.length;c+=1)Qn(t,e,n,o[c],o[c+1]);for(let c=1;c+1<o.length;c+=1){let u=o[c-1],d=o[c],h=o[c+1],p=er(u,d,h,n);p&&Qt(t,e,d.x,d.y,p,"edgeCorner")}let s=o[o.length-1],i=o[o.length-2],a=tr(i,s,n);a&&Qt(t,e,s.x,s.y,a,"arrow")}function Qn(t,e,n,r,o){if(!(r.x===o.x&&r.y===o.y)){if(r.y===o.y){let s=r.y,i=Math.min(r.x,o.x),a=Math.max(r.x,o.x);for(let c=i;c<=a;c+=1)Zt(t,e,c,s,n,"h")}else if(r.x===o.x){let s=r.x,i=Math.min(r.y,o.y),a=Math.max(r.y,o.y);for(let c=i;c<=a;c+=1)Zt(t,e,s,c,n,"v")}}}function Zt(t,e,n,r,o,s){if(r<0||r>=t.length)return;let i=t[r];if(n<0||n>=i.length)return;let a=e[r][n];if(!(a==="boxH"||a==="boxV"||a==="boxCorner"||a==="label")){if(a==="empty"){i[n]=s==="h"?o.horizontal:o.vertical,e[r][n]=s==="h"?"edgeH":"edgeV";return}if(a==="edgeH"&&s==="v"){i[n]=o.cross,e[r][n]="edgeCorner";return}if(a==="edgeV"&&s==="h"){i[n]=o.cross,e[r][n]="edgeCorner";return}}}function Qt(t,e,n,r,o,s){if(r<0||r>=t.length)return;let i=t[r];if(n<0||n>=i.length)return;let a=e[r][n];a==="boxH"||a==="boxV"||a==="boxCorner"||a==="label"||(i[n]=o,e[r][n]=s)}function er(t,e,n,r){let o=t.y===e.y,s=e.y===n.y;if(o===s)return;if(o){let c=t.x<e.x,u=n.y>e.y;return c&&u?r.cornerTR:c&&!u?r.cornerBR:!c&&u?r.cornerTL:r.cornerBL}let i=t.y<e.y,a=n.x>e.x;return i&&a?r.cornerBL:i&&!a?r.cornerBR:!i&&a?r.cornerTL:r.cornerTR}function tr(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 nr(t){let e=t.length;for(;e>0&&t.charCodeAt(e-1)===32;)e-=1;return t.slice(0,e)}function on(t){let e=rr(t);or(e),sr(e),ir(e),ar(e,t);let n=lr(e,t),{width:r,height:o}=fr(e),s=[];for(let i of e.layers)for(let a of i)a.isVirtual||s.push({id:a.id,layer:a.layer,order:a.order,x:a.x,y:a.y,w:a.w,h:a.h});return{boxes:s,edges:n,width:r,height:o}}function rr(t){let e=new Map;for(let o of t.nodes)e.set(o,{id:o,isVirtual:!1,layer:-1,order:0,x:0,y:0,w:t.widthCells(o),h:t.heightCells(o),in:[],out:[]});let n=[],r=0;for(let o of t.edges){if(o.from===o.to)continue;let s=e.get(o.from),i=e.get(o.to);if(!s||!i)continue;let a={chainId:r++,chainFrom:o.from,chainTo:o.to,fromId:o.from,toId:o.to,hopIndex:0,chainLen:1};s.out.push(a),i.in.push(a),n.push(a)}return{nodes:e,layers:[],hops:n}}function or(t){let e=new Map;for(let s of t.nodes.values())e.set(s.id,s.in.length);let n=[];for(let s of t.nodes.values())(e.get(s.id)??0)===0&&(s.layer=0,n.push(s));let r=new Set,o=0;for(;o<n.length;){let s=n[o++];if(!r.has(s.id)){r.add(s.id);for(let i of s.out){let a=t.nodes.get(i.toId);a.layer=Math.max(a.layer,s.layer+1);let c=(e.get(a.id)??0)-1;e.set(a.id,c),c<=0&&n.push(a)}}}for(let s of t.nodes.values())s.layer<0&&(s.layer=0)}function sr(t){let e=Math.max(0,...Array.from(t.nodes.values(),s=>s.layer)),n=Array.from({length:e+1},()=>[]);for(let s of t.nodes.values())n[s.layer].push(s);let r=[],o=0;for(let s of t.hops){let i=t.nodes.get(s.fromId),a=t.nodes.get(s.toId),c=a.layer-i.layer;if(c<=0){i.out=i.out.filter(h=>h!==s),a.in=a.in.filter(h=>h!==s);continue}if(c===1){s.hopIndex=0,s.chainLen=1,r.push(s);continue}i.out=i.out.filter(h=>h!==s),a.in=a.in.filter(h=>h!==s);let u=i;for(let h=1;h<c;h+=1){let p=`__virt_${o++}__`,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:s.chainId,chainFrom:s.chainFrom,chainTo:s.chainTo,fromId:u.id,toId:p,hopIndex:h-1,chainLen:c};u.out.push(l),f.in.push(l),r.push(l),u=f}let d={chainId:s.chainId,chainFrom:s.chainFrom,chainTo:s.chainTo,fromId:u.id,toId:a.id,hopIndex:c-1,chainLen:c};u.out.push(d),a.in.push(d),r.push(d)}for(let s of n)for(let i=0;i<s.length;i+=1)s[i].order=i;t.layers=n,t.hops=r}function ir(t){for(let n=0;n<4;n+=1){for(let r=1;r<t.layers.length;r+=1)nn(t,t.layers[r],"in"),ze(t.layers[r]);for(let r=t.layers.length-2;r>=0;r-=1)nn(t,t.layers[r],"out"),ze(t.layers[r])}for(let n=0;n<2;n+=1){let r=!1;for(let o=1;o<t.layers.length;o+=1){let s=t.layers[o];for(let i=0;i+1<s.length;i+=1){let a=rn(t,s[i],s[i+1],"in");[s[i],s[i+1]]=[s[i+1],s[i]],ze(s),rn(t,s[i],s[i+1],"in")<a?r=!0:([s[i],s[i+1]]=[s[i+1],s[i]],ze(s))}}if(!r)break}}function nn(t,e,n){let r=new Map;for(let o of e){let s=n==="in"?o.in:o.out;if(s.length===0){r.set(o.id,o.order);continue}let i=0,a=0;for(let c of s){let u=t.nodes.get(n==="in"?c.fromId:c.toId);u&&(i+=u.order,a+=1)}r.set(o.id,a===0?o.order:i/a)}e.sort((o,s)=>{let i=r.get(o.id),a=r.get(s.id);return i!==a?i-a:o.order-s.order})}function ze(t){for(let e=0;e<t.length;e+=1)t[e].order=e}function rn(t,e,n,r){let o=r==="in"?e.in:e.out,s=r==="in"?n.in:n.out,i=0;for(let a of o)for(let c of s){let u=t.nodes.get(r==="in"?a.fromId:a.toId)?.order??0,d=t.nodes.get(r==="in"?c.fromId:c.toId)?.order??0;(e.order<n.order&&u>d||e.order>n.order&&u<d)&&(i+=1)}return i}function ar(t,e){e.direction==="LR"?ur(t,e):cr(t,e)}function ur(t,e){let n=[],r=0;for(let o=0;o<t.layers.length;o+=1){n.push(r);let s=0;for(let i of t.layers[o])s=Math.max(s,i.w);r+=s+e.layerGap}for(let o=0;o<t.layers.length;o+=1)for(let s of t.layers[o])s.x=n[o];for(let o of t.layers){let s=0;for(let i of o)i.y=s,s+=i.h+e.nodeGap}sn(t,e,"y")}function cr(t,e){let n=[],r=0;for(let o=0;o<t.layers.length;o+=1){n.push(r);let s=0;for(let i of t.layers[o])s=Math.max(s,i.h);r+=s+e.layerGap}for(let o=0;o<t.layers.length;o+=1)for(let s of t.layers[o])s.y=n[o];for(let o of t.layers){let s=0;for(let i of o)i.x=s,s+=i.w+e.nodeGap}sn(t,e,"x")}function sn(t,e,n){let r=s=>n==="y"?s.h:s.w,o=e.nodeGap;for(let s=0;s<2;s+=1){let i=s===0?t.layers.slice(1):t.layers.slice(0,-1).reverse();for(let a of i){let c=new Map;for(let d of a){let h=s===0?d.in:d.out;if(h.length===0)continue;let p=[];for(let l of h){let m=t.nodes.get(s===0?l.fromId:l.toId);if(!m)continue;let g=n==="y"?m.y:m.x;p.push(g+Math.floor(r(m)/2))}if(p.length===0)continue;p.sort((l,m)=>l-m);let f=p[Math.floor(p.length/2)];c.set(d.id,f-Math.floor(r(d)/2))}let u=0;for(let d of a){let h=c.get(d.id),p=n==="y"?d.y:d.x,l=Math.max(h??p,u);n==="y"?d.y=l:d.x=l,u=l+r(d)+o}}}}function lr(t,e){let n=new Map;for(let u of t.hops){let d=n.get(u.chainId);d?d.push(u):n.set(u.chainId,[u])}for(let u of n.values())u.sort((d,h)=>d.hopIndex-h.hopIndex);let r=e.direction==="LR",o=u=>r?u.x:u.y,s=u=>r?u.w:u.h,i=u=>r?u.y+Math.floor(u.h/2):u.x+Math.floor(u.w/2),a=new Map;for(let u=0;u+1<t.layers.length;u+=1){let d=t.layers[u],h=t.layers[u+1],p=0;for(let O of d)p=Math.max(p,o(O)+s(O));let f=Number.POSITIVE_INFINITY;for(let O of h)f=Math.min(f,o(O));let l=Number.isFinite(f)?f-1:p,m=Math.max(1,l-p+1),g=[];for(let O of d)for(let N of O.out)g.push(N);g.sort((O,N)=>{let A=i(t.nodes.get(O.fromId)),S=i(t.nodes.get(N.fromId));if(A!==S)return A-S;let C=i(t.nodes.get(O.toId)),E=i(t.nodes.get(N.toId));return C-E});let y=[],v=new Map;for(let O of g){let N=i(t.nodes.get(O.fromId)),A=i(t.nodes.get(O.toId)),S=Math.min(N,A),C=Math.max(N,A),E=-1;for(let R=0;R<y.length;R+=1){let H=y[R],X=!0;for(let se of H)if(se.lo<=C&&S<=se.hi){X=!1;break}if(X){H.push({lo:S,hi:C}),E=R;break}}E<0&&(y.push([{lo:S,hi:C}]),E=y.length-1),v.set(O,E)}let b=y.length,_=m>=Math.max(3,b+2),T=_?p+1:p,w=_?l-1:l,x=Math.max(1,w-T+1);for(let O of g){let N=v.get(O),A;if(b<=1)A=T+Math.floor(x/2);else{let S=(x-1)/(b-1);A=T+Math.floor(N*S)}a.set(O,Math.max(p,Math.min(l,A)))}}let c=[];for(let[,u]of n){let d=[];for(let p=0;p<u.length;p+=1){let f=u[p],l=t.nodes.get(f.fromId),m=t.nodes.get(f.toId),g=a.get(f),y=l.isVirtual?o(l):o(l)+s(l),v=m.isVirtual?o(m):o(m)-1,b=i(l),_=i(m);p===0&&Ke(d,r,y,b),b!==_&&(Ke(d,r,g,b),Ke(d,r,g,_)),Ke(d,r,v,_)}let h=u[0];c.push({from:h.chainFrom,to:h.chainTo,points:dr(d)})}return c}function Ke(t,e,n,r){t.push(e?{x:n,y:r}:{x:r,y:n})}function dr(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 fr(t){let e=0,n=0;for(let r of t.layers)for(let o of r)e=Math.max(e,o.x+o.w),n=Math.max(n,o.y+o.h);return{width:e,height:n}}var pr=24,hr=4,gr=1,mr=3;function an(t,e){let n=yr(e.direction),r=Math.max(3,e.maxLabelWidth??pr),o=e.asciiCharset??"unicode",s=Object.keys(t.nodes).sort(),i=new Set(s),a=t.edges.filter(f=>i.has(f.from)&&i.has(f.to)),c=new Map,u=new Map;for(let f of s){let l=Jt(f,r);c.set(f,l),u.set(f,Be(l)+4)}let d=on({nodes:s,edges:a,widthCells:f=>u.get(f)??3,heightCells:()=>mr,layerGap:hr,nodeGap:gr,direction:n}),h=en(d,{charset:o,labelOf:f=>c.get(f)??f}),p=e.logger;return p&&p(h),h}function yr(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)}`)}xe();function un(t,e){let n=e?.topN??10,r=t.describe({detail:"standard"}),o=[],s=t._collectObserveTargets;typeof s=="function"&&s.call(t,"",o);let i=new Map;for(let[p,f]of o)i.set(p,f);let a=[];for(let[p,f]of Object.entries(r.nodes)){let l=i.get(p),m=l instanceof I?l:null,g=m?Ht(m.cache):0,y=m?m._sinkCount:0,v=f.deps?.length??0,b=f.type==="effect"&&y===0,_=y===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:y,depCount:v,isOrphanEffect:b,orphanKind:_})}let c=a.reduce((p,f)=>p+f.valueSizeBytes,0),u=(p,f)=>[...a].sort(f??((l,m)=>m[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:c,hotspots:{byValueSize:u("valueSizeBytes"),bySubscriberCount:u("subscriberCount"),byDepCount:u("depCount")},orphans:d,orphanEffects:h}}var M="::",Y="__meta__",ue=1;function cn(t,e){let n=Math.max(16,t.size*4),r=0;for(;t.size>0;){if(r++>=n){console.error(`[Graph "${e}".destroy] disposer drain exceeded cap (${n}); ${t.size} disposer(s) discarded`),t.clear();return}let o=t.values().next();if(o.done)return;let s=o.value;t.delete(s);try{s()}catch(i){console.error(`[Graph "${e}".destroy] disposer threw:`,i)}}}function fn(t){return t!=null&&typeof t=="object"&&"cache"in t&&typeof t.subscribe=="function"&&typeof t.down=="function"}function br(t){if(t!=null)return fn(t)?t.cache:t}function vr(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
|
-
`)}function ln(t){if(t.version!==ue)throw new Error(`unsupported snapshot version ${String(t.version)} (expected ${ue})`);for(let e of["name","nodes","edges","subgraphs"])if(!(e in t))throw new Error(`snapshot missing required key "${e}"`);if(typeof t.name!="string")throw new TypeError("snapshot 'name' must be a string");if(typeof t.nodes!="object"||t.nodes===null||Array.isArray(t.nodes))throw new TypeError("snapshot 'nodes' must be an object");if(!Array.isArray(t.edges))throw new TypeError("snapshot 'edges' must be an array");if(!Array.isArray(t.subgraphs))throw new TypeError("snapshot 'subgraphs' must be an array")}function _r(t,e){let n=new WeakMap,r=(o,s)=>{if(Object.is(o,s))return!0;if(o==null||s==null||typeof o!="object"||typeof s!="object")return!1;let i=n.get(o);if(i==null&&(i=new WeakSet,n.set(o,i)),i.has(s))return!0;i.add(s);let a=o.constructor,c=s.constructor;if(a!==c)return!1;if(o instanceof Date)return o.getTime()===s.getTime();if(o instanceof RegExp)return o.source===s.source&&o.flags===s.flags;if(Array.isArray(o)){let p=s;if(o.length!==p.length)return!1;for(let f=0;f<o.length;f++)if(!r(o[f],p[f]))return!1;return!0}if(o instanceof Map){let p=s;if(o.size!==p.size)return!1;for(let[f,l]of o)if(!p.has(f)||!r(l,p.get(f)))return!1;return!0}if(o instanceof Set){let p=s;if(o.size!==p.size)return!1;for(let f of o){let l=!1;for(let m of p)if(r(f,m)){l=!0;break}if(!l)return!1}return!0}if(ArrayBuffer.isView(o)){let p=o,f=s;if(p.length!==f.length)return!1;for(let l=0;l<p.length;l++)if(p[l]!==f[l])return!1;return!0}let u=Object.keys(o),d=Object.keys(s);if(u.length!==d.length)return!1;let h=new Set(d);for(let p of u)if(!h.has(p)||!r(o[p],s[p]))return!1;return!0};return r(t,e)}function wt(t){if(t===null||typeof t!="object")return t;if(Array.isArray(t))return t.map(wt);let e=t,n=Object.keys(e).sort(),r={};for(let o of n)r[o]=wt(e[o]);return r}function wr(t){return t.replaceAll("\\","\\\\").replaceAll('"','\\"')}function xr(t){return t.replaceAll("\\","\\\\").replaceAll('"','\\"')}function Tr(t){return t==="TD"?"down":t==="BT"?"up":t==="RL"?"left":"right"}function pn(t){let e=new Set,n=[];function r(o,s){let i=`${o}\0${s}`;e.has(i)||(e.add(i),n.push([o,s]))}for(let[o,s]of Object.entries(t.nodes)){let i=s.deps;if(i)for(let a of i)r(a,o)}for(let o of t.edges)r(o.from,o.to);return n}function hn(t){if(t===void 0)return"LR";if(t==="TD"||t==="LR"||t==="BT"||t==="RL")return t;throw new Error(`invalid diagram direction ${String(t)}; expected one of: TD, LR, BT, RL`)}function Or(t,e){let n=e.includeEdges??!0,r=e.includeSubgraphs??!0,{expand:o,...s}=t,i={...s,edges:n?t.edges:[],subgraphs:r?t.subgraphs:[]},a=JSON.stringify(wt(i),null,e.indent??2);return e.logger?.(a),a}function kr(t,e){let n=e.includeEdges??!0,r=e.includeSubgraphs??!0,o=[];o.push(`Graph ${t.name}`),o.push("Nodes:");for(let i of Object.keys(t.nodes).sort()){let a=t.nodes[i];o.push(`- ${i} (${a.type}/${a.status}): ${Ue(a.value)}`)}if(n){o.push("Edges:");for(let i of t.edges)o.push(`- ${i.from} -> ${i.to}`)}if(r){o.push("Subgraphs:");for(let i of t.subgraphs)o.push(`- ${i}`)}let s=o.join(`
|
|
5
|
-
`);return e.logger?.(s),s}function gn(t,e){let n=hn(e.direction),r=Object.keys(t.nodes).sort(),o=new Map;for(let i=0;i<r.length;i+=1)o.set(r[i],`n${i}`);let s=[`flowchart ${n}`];for(let i of r){let a=o.get(i);s.push(` ${a}["${wr(i)}"]`)}for(let[i,a]of pn(t)){let c=o.get(i),u=o.get(a);!c||!u||s.push(` ${c} --> ${u}`)}return s.join(`
|
|
6
|
-
`)}function Er(t,e){let n=gn(t,e);return mn(n)}function mn(t,e){let n=e?.theme??"default",r=e?.autoSync??!0,s=JSON.stringify({code:t,mermaid:{theme:n},autoSync:r}),i=new TextEncoder().encode(s),a="";for(let u=0;u<i.length;u++)a+=String.fromCharCode(i[u]);return`https://mermaid.live/edit#base64:${globalThis.btoa(a).replace(/\+/g,"-").replace(/\//g,"_").replace(/=+$/,"")}`}function Nr(t,e){let n=hn(e.direction),r=Object.keys(t.nodes).sort(),o=new Map;for(let i=0;i<r.length;i+=1)o.set(r[i],`n${i}`);let s=[`direction: ${Tr(n)}`];for(let i of r){let a=o.get(i);s.push(`${a}: "${xr(i)}"`)}for(let[i,a]of pn(t)){let c=o.get(i),u=o.get(a);!c||!u||s.push(`${c} -> ${u}`)}return s.join(`
|
|
7
|
-
`)}function Sr(t){return t.replace(/[.*+?^${}()|[\]\\]/g,"\\$&")}function We(t){let e="^";for(let n=0;n<t.length;n+=1){let r=t[n];if(r==="*"){e+=".*";continue}if(r==="?"){e+=".";continue}if(r==="["){let o=t.indexOf("]",n+1);if(o<=n+1){e+="\\[";continue}let s=t.slice(n+1,o);s.startsWith("!")&&(s=`^${s.slice(1)}`),s=s.replace(/\\/g,"\\\\"),e+=`[${s}]`,n=o;continue}e+=Sr(r)}return e+="$",new RegExp(e)}var Rr={data:"\x1B[32m",dirty:"\x1B[33m",resolved:"\x1B[36m",invalidate:"\x1B[93m",pause:"\x1B[90m",resume:"\x1B[96m",complete:"\x1B[34m",error:"\x1B[31m",teardown:"\x1B[91m",derived:"\x1B[35m",path:"\x1B[90m",reset:"\x1B[0m"},Ar={data:"",dirty:"",resolved:"",invalidate:"",pause:"",resume:"",complete:"",error:"",teardown:"",derived:"",path:"",reset:""};function Ue(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 Dr(t){return t==="none"?Ar:t==="ansi"||t==null?Rr:{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 dn(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 Cr(t,e,n){for(let r=0;r<t.length;r++){let o=t.charCodeAt(r);if(o<32||o===127)throw new Error(`Graph "${e}": ${n} "${t}" must not contain control character (U+${o.toString(16).padStart(4,"0").toUpperCase()} at index ${r})`)}}function _t(t,e,n){if(t==="")throw new Error(`Graph "${e}": ${n} name must be non-empty`);if(t.includes(M))throw new Error(`Graph "${e}": ${n} "${t}" must not contain '${M}' (path separator)`);if(t===Y)throw new Error(`Graph "${e}": ${n} name "${Y}" is reserved for meta companion paths`);Cr(t,e,n)}function Gr(t,e){if(t==="")throw new Error(`Graph "${e}": resolve path must be non-empty`);let n=t.split(M);for(let r of n)if(r==="")throw new Error(`Graph "${e}": resolve path has empty segment`);return n}function Mr(t,e){let n=!1;for(let o of t)if(!e.isMetaPassthrough(o[0])){n=!0;break}return n?t.filter(o=>e.isMetaPassthrough(o[0])):t}function yn(t){for(let e of t._mounts.values())yn(e);for(let e of t._nodes.values())try{e.down([[V]],{internal:!0})}catch{}}var te=class t{name;opts;config;_nodes=new Map;_nodeToName=new WeakMap;_mounts=new Map;_parent=void 0;_storageDisposers=new Set;_disposers=new Set;_destroyed=!1;_topology;_topologyEmitters=new Set;_factory;_factoryArgs;constructor(e,n){if(e==="")throw new Error("Graph name must be non-empty");if(e.includes(M))throw new Error(`Graph name must not contain '${M}' (got "${e}")`);if(e===Y)throw new Error(`Graph name "${Y}" is reserved for meta companion paths`);this.name=e,this.opts=Object.freeze({...n??{}}),this.config=n?.config??me,this._traceRing=new Te(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=pt(e=>{let n=r=>{e.emit(r)};return this._topologyEmitters.add(n),()=>{this._topologyEmitters.delete(n)}},{name:`${this.name}_topology`})),this._topology}_emitTopology(e){if(!(this._topology==null||this._topologyEmitters.size===0))for(let n of this._topologyEmitters)n(e)}nameOf(e){return this._nodeToName.get(e)}add(e,n){let r=e.name,o=n?.name??r;if(o==null||o==="")throw new Error(`Graph "${this.name}": graph.add requires a non-empty name \u2014 pass via opts.name or set it on the node (e.g. state(0, { name: "x" }))`);let s=o,i=n?.annotation;if(_t(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:F()})),e}setVersioning(e){if(e!=null)for(let n of this._nodes.values())n instanceof I&&n._applyVersioning(e)}remove(e){_t(e,this.name,"remove");let n=this._mounts.get(e);if(n){let s={kind:"mount",nodes:[],mounts:[]},i=[];n._collectObserveTargets("",i);for(let[a,c]of i)a.includes(`${M}${Y}${M}`)||s.nodes.push(a);return s.nodes.sort(),s.mounts.push(e),s.mounts.push(...n._collectSubgraphs(`${e}${M}`)),this._mounts.delete(e),n._parent=void 0,yn(n),this._emitTopology({kind:"removed",name:e,nodeKind:"mount",audit:s}),s}let r=this._nodes.get(e);if(!r)throw new Error(`Graph "${this.name}": unknown node or mount "${e}"`);this._nodes.delete(e),this._nodeToName.delete(r),r.down([[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 n=typeof e=="function"?e:(()=>{let s=We(e);return i=>s.test(i)})(),r={kind:"mount",nodes:[],mounts:[]},o=[...this._nodes.keys(),...this._mounts.keys()].filter(s=>n(s));for(let s of o){let i=this.remove(s);r.nodes.push(...i.nodes),r.mounts.push(...i.mounts)}return r.nodes.sort(),r.mounts.sort(),r}[Symbol.iterator](){let e=[...this._nodes.keys()].sort(),n=this._nodes,r=0;return{[Symbol.iterator](){return this},next(){if(r>=e.length)return{value:void 0,done:!0};let o=e[r++];return{value:[o,n.get(o)],done:!1}}}}node(e){if(e==="")throw new Error(`Graph "${this.name}": node name must be non-empty`);if(e.includes(M))return this.resolve(e);let n=this._nodes.get(e);if(!n)throw new Error(`Graph "${this.name}": unknown node "${e}"`);return n}get(e){return this.node(e).cache}set(e,n,r){let o=r?.internal===!0;this.node(e).down([[P,n]],{actor:r?.actor,internal:o,delivery:"write"})}setAll(e,n){let r=Symbol.iterator in e?e:Object.entries(e);Ae(()=>{for(let[o,s]of r)this.set(o,s,n)})}invalidate(e,n){let r=n?.internal===!0;this.node(e).down([[J]],{actor:n?.actor,internal:r,delivery:"write"})}error(e,n,r){let o=r?.internal===!0;this.node(e).down([[L,n]],{actor:r?.actor,internal:o,delivery:"write"})}complete(e,n){let r=n?.internal===!0;this.node(e).down([[U]],{actor:n?.actor,internal:r,delivery:"write"})}edges(e){let n=e?.recursive===!0,r=new Map;if(!n){for(let[c,u]of this._nodes)r.set(u,c);let a=[];for(let[c,u]of this._nodes)if(u instanceof I)for(let d of u._deps){let h=r.get(d.node);h!=null&&a.push([h,c])}return a.sort((c,u)=>c[0]<u[0]?-1:c[0]>u[0]?1:c[1]<u[1]?-1:c[1]>u[1]?1:0),a}let o=[];this._collectObserveTargets("",o);let s=new Map;for(let[a,c]of o)s.set(c,a);let i=[];for(let[a,c]of o)if(c instanceof I)for(let u of c._deps){let d=s.get(u.node);d!=null&&i.push([d,a])}return i.sort((a,c)=>a[0]<c[0]?-1:a[0]>c[0]?1:a[1]<c[1]?-1:a[1]>c[1]?1:0),i}mount(e,n){if(n===void 0){let o=new t(e);return this.mount(e,o)}if(typeof n=="function"){let o=new t(e);return n(o),this.mount(e,o)}let r=n;if(_t(e,this.name,"mount"),this._nodes.has(e))throw new Error(`Graph "${this.name}": cannot mount at "${e}" \u2014 node with that name exists`);if(this._mounts.has(e))throw new Error(`Graph "${this.name}": mount "${e}" already exists`);if(r===this)throw new Error(`Graph "${this.name}": cannot mount a graph into itself`);if(r._parent!=null)throw new Error(`Graph "${this.name}": this child graph is already mounted on "${r._parent.name}"`);for(let o=this;o!=null;o=o._parent)if(o===r)throw new Error(`Graph "${this.name}": mount("${e}", \u2026) would create a mount cycle`);return this._mounts.set(e,r),r._parent=this,this._emitTopology({kind:"added",name:e,nodeKind:"mount"}),r}resolve(e){let n=Gr(e,this.name);return this._resolveFromSegments(n)}tryResolve(e){try{return this.resolve(e)}catch{return}}_resolveFromSegments(e){let n=e;if(n[0]===this.name&&(n=n.slice(1),n.length===0))throw new Error(`Graph "${this.name}": resolve path ends at graph name only`);let r=n[0],o=n.slice(1);if(o.length===0){let a=this._nodes.get(r);if(a)return a;throw this._mounts.has(r)?new Error(`Graph "${this.name}": path ends at subgraph "${r}" \u2014 not a node (GRAPHREFLY-SPEC \xA73.5)`):new Error(`Graph "${this.name}": unknown name "${r}"`)}let s=this._nodes.get(r);if(s&&o.length>0&&o[0]===Y)return this._resolveMetaChainFromNode(s,o,n.join(M));let i=this._mounts.get(r);if(!i)throw this._nodes.has(r)?new Error(`Graph "${this.name}": "${r}" is a node; trailing path "${o.join(M)}" is invalid`):new Error(`Graph "${this.name}": unknown mount or node "${r}"`);return i.resolve(o.join(M))}_resolveMetaChainFromNode(e,n,r){let o=e,s=0,i=[...n];for(;s<i.length;){if(i[s]!==Y)throw new Error(`Graph "${this.name}": expected ${Y} segment in meta path "${r}"`);if(s+1>=i.length)throw new Error(`Graph "${this.name}": meta path requires a key after ${Y} in "${r}"`);let a=i[s+1],c=o.meta[a];if(!c)throw new Error(`Graph "${this.name}": unknown meta "${a}" in path "${r}"`);o=c,s+=2}return o}signal(e,n){if(n?.internal!==!0){for(let o of e)if(this.config.messageTier(o[0])===3)throw new Error(`Graph "${this.name}": Graph.signal() rejects tier-3 messages (DATA / RESOLVED). Broadcast is for control-plane tiers (START / DIRTY / INVALIDATE / PAUSE / RESUME / COMPLETE / ERROR / TEARDOWN). For per-node value writes, use Graph.set or graph.node(name).down(...).`)}let r=[];if(this._signalDeliver(e,n??{},new Set,r),r.length>0)throw r[0]}_signalDeliver(e,n,r,o){for(let c of this._mounts.values())c._signalDeliver(e,n,r,o);let i=n.internal===!0?{internal:!0}:{actor:n.actor,delivery:"signal"},a=Mr(e,this.config);for(let c of[...this._nodes.keys()].sort()){let u=this._nodes.get(c);if(!r.has(u)){r.add(u);try{u.down(e,i)}catch(d){if(d instanceof q)throw d;o.push(d)}a.length!==0&&this._signalMetaSubtree(u,a,r,i,o)}}}_signalMetaSubtree(e,n,r,o,s){for(let i of Object.keys(e.meta).sort()){let a=e.meta[i];if(!r.has(a)){r.add(a);try{a.down(n,o)}catch(c){if(c instanceof q)throw c;s.push(c)}this._signalMetaSubtree(a,n,r,o,s)}}}describe(e){if(e?.reactive==="diff")return this._describeReactiveDiff(e);if(e?.reactive===!0)return this._describeReactive(e);let n=br(e?.actor),r=e?.filter,o=je(e?.detail,e?.fields),s=e?.format==="spec",i=s?je("minimal"):o,a=[];this._collectObserveTargets("",a);let c=new Map;for(let[w,x]of a)c.set(x,w);let u=[];{let w=a.map(([,N])=>N),x=new Set(c.values()),O=0;for(;w.length>0;){let N=w.shift();if(N instanceof I)for(let A of N._deps){let S=A.node;if(c.has(S))continue;let C=S.name??"",E=C;if(!E||x.has(E))if(C){let R=2;for(;x.has(`${C}#${R}`);)R++;E=`${C}#${R}`}else for(E=`__internal__/${O++}`;x.has(E);)E=`__internal__/${O++}`;c.set(S,E),x.add(E),u.push([E,S]),w.push(S)}}}let d=[...a,...u],h={};for(let[w,x]of d){if(n!=null&&!x.allowsObserve(n))continue;let O=gt(x,i),N=x instanceof I?x._deps.map(E=>c.get(E.node)??E.node.name??""):[],{name:A,...S}=O,C={...S,deps:N};if(!s){let E=this._annotations.get(w);E!=null&&(C.annotation=E)}if(r!=null)if(typeof r=="function"){let E=r;if(!(E.length>=2?E(w,C):E(C)))continue}else{let E=!0;for(let[R,H]of Object.entries(r)){let X=R==="deps_includes"?"depsIncludes":R==="meta_has"?"metaHas":R;if(X==="depsIncludes"){if(!C.deps.includes(String(H))){E=!1;break}continue}if(X==="metaHas"){if(!Object.hasOwn(C.meta??{},String(H))){E=!1;break}continue}if(C[X]!==H){E=!1;break}}if(!E)continue}h[w]=C}let p=new Set(Object.keys(h)),f=[];for(let[w,x]of d)if(x instanceof I)for(let O of x._deps){let N=c.get(O.node);N!=null&&f.push([N,w])}f.sort((w,x)=>w[0]<x[0]?-1:w[0]>x[0]?1:w[1]<x[1]?-1:w[1]>x[1]?1:0);let l=f.map(([w,x])=>({from:w,to:x}));(n!=null||r!=null)&&(l=l.filter(w=>p.has(w.from)&&p.has(w.to)));let m=this._collectSubgraphs(""),g=n!=null||r!=null?m.filter(w=>{let x=`${w}${M}`;return[...p].some(O=>O===w||O.startsWith(x))}):m,y=this,v=e,b={name:this.name,nodes:h,edges:l,subgraphs:g,...this._factory!==void 0?{factory:this._factory}:{},...this._factoryArgs!==void 0?{factoryArgs:this._factoryArgs}:{},expand(w){let x={...v,format:void 0};return Array.isArray(w)?(x.fields=w,x.detail=void 0):(x.detail=w,x.fields=void 0),y.describe(x)}},_=e??{},T=_.format;return T==="json"?Or(b,_):T==="pretty"?kr(b,_):T==="mermaid"?gn(b,_):T==="mermaid-url"?Er(b,_):T==="d2"?Nr(b,_):T==="ascii"?an(b,_):b}_collectSubgraphs(e){let n=[];for(let r of[...this._mounts.keys()].sort()){let o=e===""?r:`${e}${r}`;n.push(o),n.push(...this._mounts.get(r)._collectSubgraphs(`${o}${M}`))}return n}resourceProfile(e){return un(this,e)}reachable(e,n,r={}){return r.withDetail===!0?Oe(this.describe(),e,n,{...r,withDetail:!0}):Oe(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 o=this.describe({detail:"full"}),s=new Map(this._annotations),i=new Map;for(let[a,c]of Object.entries(o.nodes))c.lastMutation!=null&&i.set(a,c.lastMutation);return Bt(o,e,n,{...r?.maxDepth!=null?{maxDepth:r.maxDepth}:{},...r?.findCycle===!0?{findCycle:!0}:{},annotations:s,lastMutations:i})}_describeReactive(e){let n={...e,reactive:!1},r=e.reactiveName??"describe",o=0,s=ee(o,{name:`${r}_version`}),i=this.observe({timeline:!0,structured:!0}),a=!1,c=!1,u=()=>{a||c||(a=!0,pe(()=>{a=!1,!c&&(o+=1,s.emit(o))}))},d=i.onEvent(v=>{let b=v.type;b!=="data"&&b!=="error"&&b!=="complete"&&b!=="teardown"||u()}),h=[],p=new WeakSet,f=v=>{if(p.has(v)||c)return;p.add(v);let b=v.topology.subscribe(_=>{for(let T of _){if(T[0]!==P)continue;let w=T[1];if(u(),w.kind==="added"&&w.nodeKind==="mount"){let x=v._mounts.get(w.name);x!=null&&f(x)}}});h.push(b);for(let _ of v._mounts.keys()){let T=v._mounts.get(_);T!=null&&f(T)}};f(this);let l,m=e.actor;fn(m)&&(l=m.subscribe(v=>{let b=!1,_=!1;for(let T of v){let w=T[0];w===P?b=!0:(w===U||w===L||w===V)&&(_=!0)}b&&u(),_&&(l?.(),l=void 0,u())}));let g;try{g=ye([s],()=>this.describe(n),{name:r,describeKind:"derived",meta:{domain:"audit",kind:"describe"},equals:(v,b)=>v===b})}catch(v){d(),l?.();for(let b of h)b();throw i.dispose(),v}let y=re(g);return{node:g,dispose(){c=!0,d(),l?.();for(let v of h)v();h.length=0,i.dispose(),y()}}}_describeReactiveDiff(e){let n={...e,format:void 0,reactive:!1},r=e.reactiveName??"describe-diff",o={name:this.name,nodes:{},edges:[],subgraphs:[]},s=this.describe(n),i=yt(o,s),a=ee(i,{name:r,meta:{domain:"audit",kind:"describe-diff"},equals:(p,f)=>p===f}),c=this._describeReactive({...e,format:void 0,reactiveName:void 0}),u=!1,d=c.node.subscribe(p=>{if(!u)for(let f of p){if(f[0]!==P)continue;let l=f[1],m=yt(s,l);s=l,m.events.length!==0&&a.emit(m)}}),h=re(a);return{node:a,dispose(){u=!0,d(),c.dispose(),a.down([[V,"describe-diff disposed"]]),h()}}}_explainReactive(e,n,r){let o=0,s=ee(o,{name:"explain_version"}),i=this.observe({timeline:!0,structured:!0}),a=!1,c=!1,u=i.onEvent(f=>{let l=f.type;l!=="data"&&l!=="error"&&l!=="complete"&&l!=="teardown"||a||c||(a=!0,pe(()=>{a=!1,!c&&(o+=1,s.emit(o))}))}),d={...r?.maxDepth!=null?{maxDepth:r.maxDepth}:{},...r?.findCycle===!0?{findCycle:!0}:{}},h;try{h=ye([s],()=>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&&Pr(f.steps,l.steps)})}catch(f){throw u(),i.dispose(),f}let p=re(h);return{node:h,dispose(){c=!0,u(),i.dispose(),p()}}}_pathsMatching(e){let n=We(e),r=[];return this._collectObserveTargets("",r),r.map(([o])=>o).filter(o=>n.test(o))}_collectObserveTargets(e,n){for(let r of[...this._mounts.keys()].sort()){let o=e===""?r:`${e}${M}${r}`;this._mounts.get(r)._collectObserveTargets(o,n)}for(let r of[...this._nodes.keys()].sort()){let o=this._nodes.get(r),s=e===""?r:`${e}${M}${r}`;n.push([s,o]),this._appendMetaObserveTargets(s,o,n)}}_appendMetaObserveTargets(e,n,r){for(let o of Object.keys(n.meta).sort()){let s=n.meta[o],i=`${e}${M}${Y}${M}${o}`;r.push([i,s]),this._appendMetaObserveTargets(i,s,r)}}observe(e,n){let r=typeof e=="string",s=dn(r?n:e);if(s.reactive===!0)return this._observeReactive(r?e:void 0,s);let i=s.structured===!0||s.timeline===!0||s.causal===!0||s.derived===!0||s.detail==="minimal"||s.detail==="full"||s.format!=null,a=s.actor;if(r){let d=e,h=this.resolve(d);if(a!=null&&!h.allowsObserve(a))throw new q({actor:a,action:"observe",nodeName:d});return i?this._buildStructuredObserver([[d,h]],s,"one"):{subscribe(p){return h.subscribe(p)},up(p){try{h.up?.(p)}catch(f){if(f instanceof q)return;throw f}}}}let c=[];this._collectObserveTargets("",c),c.sort((d,h)=>d[0]<h[0]?-1:d[0]>h[0]?1:0);let u=a==null?c:c.filter(([,d])=>d.allowsObserve(a));return i?this._buildStructuredObserver(u,s,"all"):{subscribe:d=>{let h=u.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 q)return;throw p}}}}_observeReactive(e,n){let r=n.tiers,o=r!=null?new Set(r):null,s=n.reactiveName??"observe";return pt(i=>{let a=[],c=!1,u=!1,d=()=>{if(a.length===0||u)return;let m={events:a.slice(),flushedAt_ns:F()};a.length=0,i.emit(m)},h={...n,reactive:!1,structured:!0,timeline:!0},p=e!=null?this.observe(e,h):this.observe(h),f=m=>{u||(a.push(m),!c&&(c=!0,pe(()=>{c=!1,d()})))};for(let m of p.events)f(m);let l=p.onEvent(f);return()=>{u=!0,l(),p.dispose()}},{name:s,meta:{domain:"audit",kind:"observe-reactive"}})}_buildStructuredObserver(e,n,r){let o=r==="one"?e[0]?.[0]:void 0,s=i=>{if(r==="one"&&o!=null){let d=this.resolve(o);return this._buildStructuredObserver([[o,d]],i,"one")}let a=[];this._collectObserveTargets("",a),a.sort((d,h)=>d[0]<h[0]?-1:d[0]>h[0]?1:0);let c=i.actor,u=c==null?a:a.filter(([,d])=>d.allowsObserve(c));return this._buildStructuredObserver(u,i,"all")};return this._createObserveResult(e,n,s)}_createObserveResult(e,n,r){let o=n.timeline===!0,s=n.causal===!0,i=n.derived===!0,a=n.detail==="minimal",c=this.config.inspectorEnabled,u=(s||i)&&c,d=n.maxEvents,h=d!=null&&d>0?new Te(d):null,p=[],f=new Set,l=n.tiers!=null?new Set(n.tiers):null,m={},g=new Set,y=0,v=0,b=0,_=0,T=0,w=0,x=!1,O=!1,N=0,A=new Map,S=new Map,C=new Map,E=k=>{if(!(l!=null&&!l.has(k.type))){h?h.push(k):p.push(k);for(let G of f)G(k)}},R=k=>l==null||l.has(k),H=()=>o?{timestamp_ns:F(),in_batch:Re(),batch_id:N}:{},X=(k,G)=>{if(!(!u||!(k instanceof I)))return k._setInspectorHook(z=>{if(z.kind==="dep_message")A.set(k,z.depIndex);else if(z.kind==="run"){let be=z.batchData.map((D,j)=>D!=null&&D.length>0?D.at(-1):z.prevData[j]);S.set(k,be);let K=z.batchData.map(D=>D!=null?[...D]:void 0);C.set(k,K),i&&E({type:"derived",path:G,dep_values:be,dep_batches:K,...H()})}})},se=k=>{let G=A.get(k),z=S.get(k);if(!s||z==null)return{};let K=(G!=null&&G>=0&&k instanceof I?k._deps[G]:void 0)?.node,D=K?.v,j=C.get(k);return{trigger_dep_index:G,trigger_dep_name:K?.name,...D!=null?{trigger_version:{id:D.id,version:D.version}}:{},dep_values:[...z],...j!=null?{dep_batches:j}:{}}},xt=[],Tt=[];for(let[k,G]of e){let z=X(G,k);z&&xt.push(z),Tt.push(G.subscribe(be=>{N++;for(let K of be){let D=K[0],j=H();if(D===P){m[k]=K[1];let Ze=G instanceof I?G.lastMutation?.actor??le:le;E({type:"data",path:k,data:K[1],actor:Ze,...j,...se(G)})}else if(a)D===W?R("dirty")&&y++:D===Z?R("resolved")&&v++:D===J?R("invalidate")&&b++:D===Q?R("pause")&&_++:D===ne?R("resume")&&T++:D===V?R("teardown")&&w++:D===U&&!g.has(k)?R("complete")&&(x=!0):D===L&&R("error")&&(O=!0,g.add(k));else if(D===W)R("dirty")&&y++,E({type:"dirty",path:k,...j});else if(D===Z)R("resolved")&&v++,E({type:"resolved",path:k,...j,...se(G)});else if(D===J)R("invalidate")&&b++,E({type:"invalidate",path:k,...j});else if(D===Q)R("pause")&&_++,E({type:"pause",path:k,lockId:K[1],...j});else if(D===ne)R("resume")&&T++,E({type:"resume",path:k,lockId:K[1],...j});else if(D===U)R("complete")&&!g.has(k)&&(x=!0),E({type:"complete",path:k,...j});else if(D===L){R("error")&&(O=!0,g.add(k));let Ze=G instanceof I?G.lastMutation?.actor??le:le;E({type:"error",path:k,data:K[1],actor:Ze,...j})}else D===V&&(R("teardown")&&w++,E({type:"teardown",path:k,...j}))}}))}let Ye=!1,Je=()=>{if(!Ye){Ye=!0;for(let k of Tt)k();for(let k of xt)k();for(let k of Ee)k({value:void 0,done:!0});Ee.length=0}},Xe=[],Ee=[];f.add(k=>{let G=Ee.shift();G?G({value:k,done:!1}):Xe.push(k)});let Ot={get values(){return m},get dirtyCount(){return y},get resolvedCount(){return v},get invalidateCount(){return b},get pauseCount(){return _},get resumeCount(){return T},get teardownCount(){return w},get events(){return h?h.toArray():[...p]},get anyCompletedCleanly(){return x},get anyErrored(){return O},get completedWithoutErrors(){return x&&!O},onEvent(k){return f.add(k),()=>f.delete(k)},dispose:Je,expand(k){Je();let G={...n};return typeof k=="string"?G.detail=k:Object.assign(G,k),r(dn(G))},[Symbol.asyncIterator](){return{next(){return Xe.length>0?Promise.resolve({value:Xe.shift(),done:!1}):Ye?Promise.resolve({value:void 0,done:!0}):new Promise(k=>Ee.push(k))},return(){return Je(),Promise.resolve({value:void 0,done:!0})}}}};return n.format!=null&&this._attachFormatLogger(Ot,n),Ot}_attachFormatLogger(e,n){let r=n.format;if(r==null)return;let o=n.logger??(l=>console.log(l)),s=n.includeTypes?new Set(n.includeTypes):null,i=n.excludeTypes?new Set(n.excludeTypes):null,a=s==null&&i==null?()=>!0:l=>(s==null||s.has(l))&&(i==null||!i.has(l)),c=Dr(n.theme),u=r==="stage-log"?F():0,d=l=>l==null?"":n.stageLabels?.[l]??l,h=(l,m)=>l.length>m?`${l.slice(0,m-1)}\u2026`:l,p=l=>l.type==="data"||l.type==="error"?h(Ue(l.data),120):"",f=l=>{if(r==="stage-log"){let x=(F()-u)/1e9,O=d(l.path).padEnd(9);if(l.type==="data"){let N=p(l);return`[${x.toFixed(3)}s] ${O} \u2190${N?` ${N}`:""}`}if(l.type==="error"){let N=p(l);return`[${x.toFixed(3)}s] ${O} \u2717${N?` ${N}`:""}`}return l.type==="complete"?`[${x.toFixed(3)}s] ${O} \u25A0 complete`:`[${x.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 m=c[l.type]??"",g=l.path?`${c.path}${l.path}${c.reset} `:"",y=l.type==="data"||l.type==="error",v=l.type==="pause"||l.type==="resume",b=y?` ${Ue(l.data)}`:v?` ${Ue(l.lockId)}`:"",_=l.type==="data"||l.type==="resolved"||l.type==="derived"?l:void 0,T=_?.trigger_dep_name!=null?` <- ${_.trigger_dep_name}`:_?.trigger_dep_index!=null?` <- #${_.trigger_dep_index}`:"",w=l.in_batch?" [batch]":"";return`${g}${m}${l.type.toUpperCase()}${c.reset}${b}${T}${w}`};e.onEvent(l=>{a(l.type)&&o(f(l),l)})}addDisposer(e){return this._disposers.add(e),()=>{this._disposers.delete(e)}}destroy(){cn(this._disposers,this.name),this.signal([[V]],{internal:!0}),cn(this._storageDisposers,this.name);for(let e of[...this._mounts.values()])e._parent=void 0,e._destroyClearOnly();this._mounts.clear(),this._nodes.clear(),this._parent=void 0,this._destroyed=!0}get destroyed(){return this._destroyed}_destroyClearOnly(){for(let e of[...this._mounts.values()])e._parent=void 0,e._destroyClearOnly();this._mounts.clear(),this._nodes.clear(),this._parent=void 0,this._destroyed=!0}snapshot(e){let{expand:n,...r}=this.describe({detail:"full"}),o={};for(let a of Object.keys(r.nodes).sort()){let{lastMutation:c,guard:u,...d}=r.nodes[a];o[a]=d}let s=[...r.subgraphs].sort(),i={...r,version:1,nodes:o,subgraphs:s};if(e?.format==null)return i;if(e.format==="json-string")return JSON.stringify(i);if(e.format==="bytes"){if(e.codec==null)throw new Error("snapshot({format: 'bytes'}) requires a `codec` name");let a=this.config.lookupCodec(e.codec);if(a==null)throw new Error(`snapshot: codec "${e.codec}" is not registered on this graph's config. Call config.registerCodec(...) before creating nodes.`);return Et(a,a.encode(i))}throw new Error(`snapshot: unknown format "${String(e.format)}"`)}static decode(e,n){let r=n?.config??me,{codec:o,codecVersion:s,payload:i}=Nt(e,r);return o.decode(i,s)}restore(e,n){if(ln(e),e.name!==this.name)throw new Error(`Graph "${this.name}": restore snapshot name "${e.name}" does not match this graph`);let r=n?.only==null?null:(Array.isArray(n.only)?n.only:[n.only]).map(s=>We(s)),o=n?.includeProducers===!0;for(let s of Object.keys(e.nodes).sort()){if(r!==null&&!r.some(a=>a.test(s)))continue;let i=e.nodes[s];if(i!==void 0){if(!("value"in i)||i.value===void 0){"value"in i&&i.value===void 0&&n?.onError?.(s,new Error(`restore: slice.value is undefined for "${s}" (undefined is the global SENTINEL; not valid DATA)`));continue}if(!(i.type==="derived"||i.type==="effect")&&!(i.type==="producer"&&!o)){if(i.v!=null){let c=this.tryResolve(s)?.v;if(c!=null&&c.id===i.v.id&&c.version===i.v.version)continue}try{this.set(s,i.value)}catch(a){n?.onError?.(s,a)}}}}}static fromSnapshot(e,n){ln(e);let r=typeof n=="function"?n:n?.build,o=typeof n=="function"?void 0:n?.factories,s=new t(e.name);if(r)return r(s),s.restore(e),s;for(let f of[...e.subgraphs].sort((l,m)=>{let g=l.split(M).length,y=m.split(M).length;return g!==y?g-y:l<m?-1:l>m?1:0})){let l=f.split(M),m=s;for(let g of l)m._mounts.has(g)||m.mount(g,new t(g)),m=m._mounts.get(g)}let i=o?Object.entries(o).map(([f,l])=>({re:We(f),factory:l})):[],a=f=>{for(let l of i)if(l.re.test(f))return l.factory},c=f=>{let l=f.split(M),m=l.pop();if(m==null||m.length===0)throw new Error(`invalid snapshot path "${f}"`);let g=s;for(let y of l){let v=g._mounts.get(y);if(!v)throw new Error(`unknown mount "${y}" in path "${f}"`);g=v}return[g,m]},u=Object.entries(e.nodes).filter(([f])=>!f.includes(`${M}${Y}${M}`)).sort((f,l)=>f[0]<l[0]?-1:f[0]>l[0]?1:0),d=new Map(u),h=new Map,p=!0;for(;d.size>0&&p;){p=!1;for(let[f,l]of[...d.entries()]){let m=l?.deps??[];if(!m.every(T=>h.has(T)))continue;let[g,y]=c(f),v={...l?.meta??{}},b=a(f),_;if(l?.type==="state")_=ee(l.value,{meta:v});else{if(b==null)continue;_=b(y,{path:f,type:l.type,value:l.value,meta:v,deps:m,resolvedDeps:m.map(T=>h.get(T))})}g.add(_,{name:y}),h.set(f,_),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 s.restore(e),s}toJSON(){return this.snapshot()}attachSnapshotStorage(e,n={}){let r=e.map(u=>({tier:u,debounceMs:Math.max(0,u.debounceMs??0),compactEvery:Math.max(1,u.compactEvery??10),timer:void 0,seq:0,lastSnapshot:void 0,lastFingerprint:"",disposed:!1,savePending:void 0}));n.autoRestore===!0&&this._cascadeRestore(e,n.onError);let o=(u,d)=>{if(u.disposed)return;let h=vr(d.nodes);if(u.lastSnapshot!=null&&h!==""&&h===u.lastFingerprint)return;let p=u.seq+1,f=Ne(),g=u.lastSnapshot==null||p%u.compactEvery===0?{name:this.name,mode:"full",snapshot:d,seq:p,timestamp_ns:f,format_version:ue}:{name:this.name,mode:"diff",diff:bn(u.lastSnapshot,d),seq:p,timestamp_ns:f,format_version:ue};if(u.tier.filter&&!u.tier.filter(g))return;let y;try{y=u.tier.save(g)}catch(v){n.onError?.(v,u.tier);return}if(y&&typeof y.then=="function"){let _=(u.savePending??Promise.resolve()).then(()=>y,()=>y).then(()=>{u.disposed||(u.seq=p,u.lastSnapshot=d,u.lastFingerprint=h)},T=>{n.onError?.(T,u.tier)});u.savePending=_.finally(()=>{u.savePending===_&&(u.savePending=void 0)})}else u.seq=p,u.lastSnapshot=d,u.lastFingerprint=h},s=(u,d)=>{try{o(u,d)}catch(h){n.onError?.(h,u.tier)}},i=(u,d)=>{if(!d.some(l=>{let m=this.config.messageTier(l[0]);return m>=3&&m<5}))return;if(n.filter){let l=this.tryResolve(u);if(l==null)return;let m=gt(l,je("standard"));if(!n.filter(u,m))return}let p,f=()=>(p==null&&(p=this.snapshot()),p);for(let l of r)l.disposed||(l.debounceMs===0?s(l,f()):(l.timer==null&&(l.timer=new He),l.timer.start(l.debounceMs,()=>{l.disposed||s(l,this.snapshot())})))},a;if(n.paths!=null){let d=(typeof n.paths=="string"?this._pathsMatching(n.paths):n.paths).map(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((u,d)=>i(u,d));let c=()=>{a();for(let u of r)u.disposed=!0,u.timer?.cancel();this._storageDisposers.delete(c)};return this._storageDisposers.add(c),{dispose:c}}async _cascadeRestore(e,n){for(let r of e){let o;try{o=await r.load?.()}catch(i){n?.(i,r);continue}if(o==null||typeof o!="object"||Array.isArray(o))continue;let s=o;try{if(s.mode==="full"&&s.snapshot!=null)return this.restore(s.snapshot),!0;if(s.version===ue&&s.nodes!=null)return this.restore(s),!0}catch(i){n?.(i,r)}}return!1}static async fromStorage(e,n,r){for(let o of n){let s;try{s=await o.load?.()}catch(c){r?.onError?.(c,o);continue}if(s==null||typeof s!="object"||Array.isArray(s))continue;let i=s,a=i.mode==="full"&&i.snapshot!=null?i.snapshot:i.version===ue&&i.nodes!=null?i:void 0;if(a!=null)try{return t.fromSnapshot(a,r)}catch(c){r?.onError?.(c,o)}}throw new Error(`Graph.fromStorage: no tier held a restorable record for "${e}" across ${n.length} tier(s)`)}_annotations=new Map;_traceRing;trace(e,n,r){if(e!=null&&n!=null){if(this.tryResolve(e)==null)return;if(this._annotations.set(e,n),this.config.inspectorEnabled){let o={path:e,annotation:n,timestamp_ns:F(),...r?.actor!=null?{actor:r.actor}:{}};this._traceRing.push(o)}return}return e!=null?this.config.inspectorEnabled?this._annotations.get(e):void 0:this.config.inspectorEnabled?this._traceRing.toArray():[]}annotation(e){return this._annotations.get(e)}clearTrace(){this._annotations.clear(),this._traceRing.clear()}pruneTrace(e){let n=this._traceRing.toArray().filter(o=>!e(o)),r=this._traceRing.size-n.length;this._traceRing.clear();for(let o of n)this._traceRing.push(o);return r}static diff(e,n){let r=new Set(Object.keys(e.nodes)),o=new Set(Object.keys(n.nodes)),s=[...o].filter(v=>!r.has(v)).sort(),i=[...r].filter(v=>!o.has(v)).sort(),a=[],c=[];for(let v of r){if(!o.has(v))continue;let b=e.nodes[v],_=n.nodes[v],T=b.v,w=_.v;T!=null&&w!=null&&T.id===w.id&&T.version!==w.version&&c.push({path:v,id:T.id,from:T.version,to:w.version});let x=T!=null&&w!=null&&T.id===w.id&&T.version===w.version;for(let O of["type","status","sentinel"]){let N=b[O],A=_[O];N!==A&&a.push({path:v,field:O,from:N,to:A})}if(!x)for(let O of["value","meta"]){let N=b[O],A=_[O];_r(N,A)||a.push({path:v,field:O,from:N,to:A})}}let u=v=>`${v.from} ${v.to}`,d=new Set(e.edges.map(u)),h=new Set(n.edges.map(u)),p=n.edges.filter(v=>!d.has(u(v))),f=e.edges.filter(v=>!h.has(u(v))),l=new Set(e.subgraphs),m=new Set(n.subgraphs),g=[...m].filter(v=>!l.has(v)).sort(),y=[...l].filter(v=>!m.has(v)).sort();return{nodesAdded:s,nodesRemoved:i,nodesChanged:a,versionChanges:c,edgesAdded:p,edgesRemoved:f,subgraphsAdded:g,subgraphsRemoved:y}}};function bn(t,e){let n=te.diff(t,e),r={};for(let o of n.nodesAdded){let s=e.nodes[o];s!=null&&(r[o]=s)}return{...n,nodesAddedFull:r}}function Oe(t,e,n,r={}){let o={paths:[],depths:new Map,truncated:!1};if(!e)return r.withDetail?o:[];if(!r.both&&n!=="upstream"&&n!=="downstream")throw new Error('reachable: direction must be "upstream" or "downstream"');let s=r.maxDepth;if(s!=null&&(!Number.isInteger(s)||s<0))throw new Error("reachable: maxDepth must be an integer >= 0");if(s===0)return r.withDetail?o:[];let i=new Map,a=new Map,c=new Map,u=new Map,d=new Set;for(let[b,_]of Object.entries(t.nodes)){if(!b)continue;d.add(b);let T=_.deps??[];i.set(b,T);for(let w of T)w&&(d.add(w),a.has(w)||a.set(w,new Set),a.get(w).add(b))}for(let b of t.edges){if(b==null||typeof b!="object")continue;let _=typeof b.from=="string"?b.from:"",T=typeof b.to=="string"?b.to:"";!_||!T||(d.add(_),d.add(T),u.has(_)||u.set(_,new Set),u.get(_).add(T),c.has(T)||c.set(T,new Set),c.get(T).add(_))}if(!d.has(e))return r.withDetail?o:[];let h=r.both===!0,p=b=>{if(h){let x=i.get(b)??[],O=c.get(b),N=a.get(b),A=u.get(b),S=[...x];return O&&S.push(...O),N&&S.push(...N),A&&S.push(...A),S}if(n==="upstream"){let x=i.get(b)??[],O=c.get(b);return O?[...x,...O]:x}let _=a.get(b),T=u.get(b),w=_?[..._]:[];return T&&w.push(...T),w},f=new Set([e]),l=new Map,m=[{path:e,depth:0}],g=0,y=!1;for(;g<m.length;){let b=m[g++];if(s!=null&&b.depth>=s){p(b.path).length>0&&(y=!0);continue}for(let _ of p(b.path))!_||f.has(_)||(f.add(_),l.set(_,b.depth+1),m.push({path:_,depth:b.depth+1}))}let v=[...l.keys()].sort((b,_)=>b<_?-1:b>_?1:0);return r.withDetail?{paths:v,depths:l,truncated:y}:v}function Pr(t,e){if(t.length!==e.length)return!1;for(let n=0;n<t.length;n++){let r=t[n],o=e[n];if(r.path!==o.path||r.type!==o.type||r.status!==o.status||r.hop!==o.hop||r.dep_index!==o.dep_index||r.annotation!==o.annotation||r.value!==o.value||r.lastMutation!==o.lastMutation)return!1;let s=r.v,i=o.v;if(s!==i&&(s==null||i==null||s.id!==i.id||s.version!==i.version))return!1}return!0}ge();function ke(t,e){let n=new Map,r=(o,s)=>{if(n.has(o))return;let i={off:()=>{},prefix:s};n.set(o,i);let a=o.topology.subscribe(c=>{for(let u of c){if(u[0]!==P)continue;let d=u[1];if(e(d,o,s),d.kind==="added"&&d.nodeKind==="mount"){let h=o._mounts.get(d.name);if(h instanceof te){let p=`${s}${d.name}::`;r(h,p)}}else if(d.kind==="removed"&&d.nodeKind==="mount"){let h=`${s}${d.name}::`;for(let[p,f]of Array.from(n.entries()))p!==t&&f.prefix.startsWith(h)&&(f.off(),n.delete(p))}}});i.off=a;for(let[c,u]of o._mounts)if(u instanceof te){let d=`${s}${c}::`;r(u,d)}};return r(t,""),()=>{for(let o of n.values())o.off();n.clear()}}bt();function vn(t,e,n){return{[t]:!0,[`${t}_type`]:e,...n??{}}}function _n(t,e,n,r){return t.explain(e,n,{reactive:!0,...r})}function wn(t){return vn("lens",t)}function Lr(t){let e=Object.keys(t.nodes),n=new Map,r=new Map;for(let m of e){let g=t.nodes[m]?.deps??[];n.set(m,g);for(let y of g)r.has(y)||r.set(y,new Set),r.get(y).add(m)}let o=[],s=[];for(let m of e)(n.get(m)??[]).length===0&&o.push(m),r.has(m)||s.push(m);o.sort(),s.sort();let i=t.edges.length,a=0,c=1,u=2,d=new Map;for(let m of e)d.set(m,a);let h=!1,p=new Map,f=m=>{let g=d.get(m)??a;if(g===c)return h=!0,0;if(g===u)return p.get(m)??0;d.set(m,c);let y=0,v=r.get(m);if(v!=null)for(let b of v){let _=f(b);_+1>y&&(y=_+1)}return d.set(m,u),p.set(m,y),y},l=0;for(let m of o){let g=f(m);g>l&&(l=g)}for(let m of e)d.get(m)===a&&f(m);return{nodeCount:e.length,edgeCount:i,subgraphCount:t.subgraphs.length,sources:o,sinks:s,depth:l,hasCycles:h}}function Ir(t){let e=[];for(let[n,r]of Object.entries(t.nodes)){if(r.status!=="errored")continue;let o={path:n,status:"errored"},s=Oe(t,n,"upstream",{});for(let i of s)if(i!==n&&t.nodes[i]?.status==="errored"){o.upstreamCause=i;break}e.push(o)}return e.sort((n,r)=>n.path<r.path?-1:n.path>r.path?1:0),{ok:e.length===0,problems:e}}function $r(t,e){return t.nodeCount===e.nodeCount&&t.edgeCount===e.edgeCount&&t.subgraphCount===e.subgraphCount&&t.depth===e.depth&&t.hasCycles===e.hasCycles&&xn(t.sources,e.sources)&&xn(t.sinks,e.sinks)}function Fr(t,e){if(t.ok!==e.ok||t.problems.length!==e.problems.length)return!1;for(let n=0;n<t.problems.length;n++){let r=t.problems[n],o=e.problems[n];if(r.path!==o.path||r.status!==o.status||r.upstreamCause!==o.upstreamCause)return!1}return!0}function xn(t,e){if(t.length!==e.length)return!1;for(let n=0;n<t.length;n++)if(t[n]!==e[n])return!1;return!0}var qe=class extends te{stats;health;flow;_target;constructor(e,n={}){super(n.name??`${e.name}_lens`,n.graph),this._target=e;let r=0,o=0,s=ee(0,{name:"stats_tick"}),i=ee(0,{name:"health_tick"});this.add(s,{name:"stats_tick"}),this.add(i,{name:"health_tick"});let a={name:"flow"};n.maxFlowPaths!=null&&(a.maxSize=n.maxFlowPaths),this.flow=jt(a),this.add(this.flow.entries,{name:"flow"});let c=n.pathFilter,u=ke(e,(p,f,l)=>{if(r+=1,s.emit(r),o+=1,i.emit(o),p.kind==="removed")if(p.nodeKind==="node"){let m=`${l}${p.name}`;this.flow.delete(m)}else{let m=`${l}${p.name}::`,g=[];for(let y of p.audit.nodes){let v=y===""?`${l}${p.name}`:`${m}${y}`;g.push(v)}g.length>0&&this.flow.deleteMany(g)}});this.addDisposer(u);let d=e.observe({timeline:!0,structured:!0}),h=d.onEvent(p=>{let f=p.type;if((f==="error"||f==="complete"||f==="data"||f==="teardown")&&(o+=1,i.emit(o)),f==="data"){let l=p.path??"";if(!l||c!=null&&!c(l))return;let m=this.flow.get(l),g=m!=null?m.count+1:1;this.flow.set(l,{path:l,count:g,lastUpdate_ns:F()})}});this.addDisposer(()=>{h(),d.dispose()}),this.stats=ye([s],()=>Lr(e.describe({detail:"minimal"})),{name:"stats",describeKind:"derived",equals:$r,meta:wn("stats")}),this.add(this.stats,{name:"stats"}),this.addDisposer(re(this.stats)),this.health=ye([i],()=>Ir(e.describe({detail:"standard"})),{name:"health",describeKind:"derived",equals:Fr,meta:wn("health")}),this.add(this.health,{name:"health"}),this.addDisposer(re(this.health))}why(e,n,r){let o=_n(this._target,e,n,r);return this.addDisposer(o.dispose),o}get target(){return this._target}};function Vr(t,e){return new qe(t,e)}0&&(module.exports={LensGraph,graphLens,watchTopologyTree});
|
|
1
|
+
"use strict";var Ye=Object.defineProperty;var un=Object.getOwnPropertyDescriptor;var dn=Object.getOwnPropertyNames;var cn=Object.prototype.hasOwnProperty;var V=(r,e)=>()=>(r&&(e=r(r=0)),e);var ln=(r,e)=>{for(var t in e)Ye(r,t,{get:e[t],enumerable:!0})},fn=(r,e,t,n)=>{if(e&&typeof e=="object"||typeof e=="function")for(let s of dn(e))!cn.call(r,s)&&s!==t&&Ye(r,s,{get:()=>e[s],enumerable:!(n=un(e,s))||n.enumerable});return r};var pn=r=>fn(Ye({},"__esModule",{value:!0}),r);function j(){return Math.trunc(performance.now()*1e6)}function Ne(){return Date.now()*1e6}var ue=V(()=>{"use strict"});function Ot(r,e){let t=new TextEncoder().encode(r.name);if(t.length===0||t.length>255)throw new Error(`encodeEnvelope: codec name "${r.name}" encodes to ${t.length} bytes (must be 1\u2013255)`);let n=r.version;if(!Number.isInteger(n)||n<0||n>65535)throw new Error(`encodeEnvelope: codec.version ${n} out of u16 range (expected integer 0\u201365535)`);let s=2+t.length+2+e.length;if(s>4294967295)throw new Error(`encodeEnvelope: total envelope size ${s} exceeds 2^32-1 bytes (payload ${e.length} bytes)`);let o=new Uint8Array(s),i=0;return o[i++]=Je,o[i++]=t.length,o.set(t,i),i+=t.length,o[i++]=n>>>8&255,o[i++]=n&255,o.set(e,i),o}function Tt(r,e){if(r.length<wt)throw new Error(`decodeEnvelope: bytes too short (${r.length} < ${wt})`);let t=0,n=r[t++];if(n!==Je)throw new Error(`decodeEnvelope: unsupported envelope version ${n} (expected ${Je})`);let s=r[t++];if(s===0)throw new Error("decodeEnvelope: name_len must be >= 1");if(t+s+2>r.length)throw new Error(`decodeEnvelope: envelope truncated (need ${t+s+2} bytes, have ${r.length})`);let o=new TextDecoder().decode(r.subarray(t,t+s));t+=s;let i=(r[t]<<8|r[t+1])>>>0;t+=2;let a=r.subarray(t),d=e.lookupCodec(o);if(d==null)throw new Error(`decodeEnvelope: codec "${o}" not registered (envelope codec_v=${i})`);return{codec:d,codecVersion:i,payload:a}}function xt(r){r.registerCodec(hn)}var hn,Je,wt,Ze=V(()=>{"use strict";hn={name:"json",version:1,contentType:"application/json",encode(r){let e=JSON.stringify(r);return new TextEncoder().encode(e)},decode(r,e){let t=new TextDecoder().decode(r);return JSON.parse(t)}},Je=1,wt=4});function Se(r){if(r==null)return de;let{type:e,id:t,...n}=r;return{type:e??"system",id:t??"",...n}}var de,Xe=V(()=>{"use strict";de={type:"system",id:""}});function Re(){return ce>0||ye}function kt(){return ce>0}function fe(r){ce>0?ve.push(r):r()}function Ae(r){ce+=1;let e=!1;try{r()}catch(t){throw e=!0,t}finally{if(ce-=1,ce===0)if(e){if(!ye){let t=ve.splice(0);for(let n of t)try{n()}catch{}ne.length=0,re.length=0,le.length=0}}else gn()}}function gn(){let r=!ye;r&&(ye=!0);let e=[],t=0;try{for(;ne.length>0||re.length>0||le.length>0||r&&ve.length>0;){if(r&&ve.length>0){let o=ve.splice(0);for(let i of o)try{i()}catch(a){e.push(a)}continue}if(t+=1,t>1e3)throw ne.length=0,re.length=0,le.length=0,new Error("batch drain exceeded 1000 iterations \u2014 likely a reactive cycle");let s=(ne.length>0?ne:re.length>0?re:le).splice(0);for(let o of s)try{o()}catch(i){e.push(i)}}}finally{r&&(ye=!1)}if(e.length===1)throw e[0];if(e.length>1)throw new AggregateError(e,"batch drain: multiple callbacks threw")}function Ce(r,e,t){if(e.length===0)return;if(e.length===1){let u=t(e[0][0]);if(u<3||!Re()){r(e);return}(u>=5?le:u===4?re:ne).push(()=>r(e));return}let n=e.length,s=n,o=n,i=n,a=0;for(;a<n&&t(e[a][0])<3;)a++;for(s=a;a<n&&t(e[a][0])===3;)a++;for(o=a;a<n&&t(e[a][0])===4;)a++;i=a;let d=Re();if(s>0){let u=e.slice(0,s);r(u)}if(o>s){let u=e.slice(s,o);d?ne.push(()=>r(u)):r(u)}if(i>o){let u=e.slice(o,i);d?re.push(()=>r(u)):r(u)}if(n>i){let u=e.slice(i,n);d?le.push(()=>r(u)):r(u)}}var ce,ye,ne,re,le,ve,De=V(()=>{"use strict";ce=0,ye=!1,ne=[],re=[],le=[],ve=[]});var _e,M,W,J,Y,Z,ee,L,z,G,pe,Qe,mn,et,bn,yn,tt,Et,Nt,St,nt,he=V(()=>{"use strict";_e=Symbol.for("graphrefly/START"),M=Symbol.for("graphrefly/DATA"),W=Symbol.for("graphrefly/DIRTY"),J=Symbol.for("graphrefly/RESOLVED"),Y=Symbol.for("graphrefly/INVALIDATE"),Z=Symbol.for("graphrefly/PAUSE"),ee=Symbol.for("graphrefly/RESUME"),L=Symbol.for("graphrefly/TEARDOWN"),z=Symbol.for("graphrefly/COMPLETE"),G=Symbol.for("graphrefly/ERROR"),pe=Object.freeze([W]),Qe=Object.freeze([J]),mn=Object.freeze([Y]),et=Object.freeze([_e]),bn=Object.freeze([z]),yn=Object.freeze([L]),tt=Object.freeze([pe]),Et=Object.freeze([Qe]),Nt=Object.freeze([mn]),St=Object.freeze([bn]),nt=Object.freeze([yn])});function Rt(r){r.registerMessageType(_e,{tier:0,wireCrossing:!1}),r.registerMessageType(W,{tier:1,wireCrossing:!1}),r.registerMessageType(Y,{tier:1,wireCrossing:!1,metaPassthrough:!1}),r.registerMessageType(Z,{tier:2,wireCrossing:!1}),r.registerMessageType(ee,{tier:2,wireCrossing:!1}),r.registerMessageType(M,{tier:3,wireCrossing:!0}),r.registerMessageType(J,{tier:3,wireCrossing:!0}),r.registerMessageType(z,{tier:4,wireCrossing:!0,metaPassthrough:!1}),r.registerMessageType(G,{tier:4,wireCrossing:!0,metaPassthrough:!1}),r.registerMessageType(L,{tier:5,wireCrossing:!0,metaPassthrough:!1})}var Me,At=V(()=>{"use strict";he();Me=class{_messageTypes=new Map;_codecs=new Map;_onMessage;_onSubscribe;_defaultVersioning;_defaultHashFn;_inspectorEnabled=!(typeof process<"u"&&process.env?.NODE_ENV==="production");_globalInspector;_rigorRecorder;_frozen=!1;tierOf;constructor(e){this._onMessage=e.onMessage,this._onSubscribe=e.onSubscribe,this._defaultVersioning=e.defaultVersioning,this._defaultHashFn=e.defaultHashFn,this.tierOf=t=>{let n=this._messageTypes.get(t);return n!=null?n.tier:1}}get onMessage(){return this._frozen=!0,this._onMessage}get onSubscribe(){return this._frozen=!0,this._onSubscribe}set onMessage(e){this._assertUnfrozen(),this._onMessage=e}set onSubscribe(e){this._assertUnfrozen(),this._onSubscribe=e}get defaultVersioning(){return this._defaultVersioning}set defaultVersioning(e){this._assertUnfrozen(),this._defaultVersioning=e}get defaultHashFn(){return this._defaultHashFn}set defaultHashFn(e){this._assertUnfrozen(),this._defaultHashFn=e}get inspectorEnabled(){return this._inspectorEnabled}set inspectorEnabled(e){this._inspectorEnabled=e}get globalInspector(){return this._globalInspector}set globalInspector(e){this._globalInspector=e}get rigorRecorder(){return this._rigorRecorder}set rigorRecorder(e){this._rigorRecorder=e}registerMessageType(e,t){return this._assertUnfrozen(),this._messageTypes.set(e,{tier:t.tier,wireCrossing:t.wireCrossing??t.tier>=3,metaPassthrough:t.metaPassthrough??!0}),this}messageTier(e){let t=this._messageTypes.get(e);return t!=null?t.tier:1}isWireCrossing(e){let t=this._messageTypes.get(e);return t!=null?t.wireCrossing:!0}isLocalOnly(e){return!this.isWireCrossing(e)}isMetaPassthrough(e){let t=this._messageTypes.get(e);return t!=null?t.metaPassthrough:!0}isKnownMessageType(e){return this._messageTypes.has(e)}registerCodec(e){return this._assertUnfrozen(),this._codecs.set(e.name,e),this}lookupCodec(e){return this._codecs.get(e)}_isFrozen(){return this._frozen}_assertUnfrozen(){if(this._frozen)throw new Error("GraphReFlyConfig is frozen: a node has already captured this config. Register custom types and set hooks before creating any node.")}}});function rt(r){let e=vn.filter(t=>r({type:t,id:""},"write"));return e.length===0?"restricted":e.includes("human")&&e.includes("llm")&&e.every(t=>t==="human"||t==="llm"||t==="system")?"both":e.length===1?e[0]:e.join("+")}var U,vn,Ge=V(()=>{"use strict";U=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}},vn=["human","llm","wallet","system"]});function st(r){if(r===void 0)return null;if(typeof r=="number"){if(!Number.isFinite(r))throw new TypeError(`Cannot hash non-finite number: ${r}`);if(Number.isInteger(r)&&!Number.isSafeInteger(r))throw new TypeError(`Cannot hash integer outside safe range (|n| > 2^53-1): ${r}. Cross-language cid parity is not guaranteed for unsafe integers.`);return r}if(typeof r=="string"||typeof r=="boolean"||r===null)return r;if(Array.isArray(r))return r.map(st);if(typeof r=="object"&&r!==null){let e={};for(let t of Object.keys(r).sort())e[t]=st(r[t]);return e}return null}function On(r){let e=wn.encode(r),t=e.length,n=t*8,s=t+9+63&-64,o=new Uint8Array(s);o.set(e),o[t]=128;let i=new DataView(o.buffer);i.setUint32(s-4,n>>>0,!1),i.setUint32(s-8,Math.floor(n/4294967296)>>>0,!1);let a=1779033703,d=3144134277,u=1013904242,l=2773480762,g=1359893119,f=2600822924,p=528734635,c=1541459225,m=new Uint32Array(64),h=(b,y)=>b>>>y|b<<32-y;for(let b=0;b<s;b+=64){for(let T=0;T<16;T++)m[T]=i.getUint32(b+T*4,!1);for(let T=16;T<64;T++){let I=m[T-15],P=m[T-2],A=h(I,7)^h(I,18)^I>>>3,ae=h(P,17)^h(P,19)^P>>>10;m[T]=m[T-16]+A+m[T-7]+ae>>>0}let y=a,_=d,w=u,x=l,k=g,E=f,N=p,S=c;for(let T=0;T<64;T++){let I=h(k,6)^h(k,11)^h(k,25),P=k&E^~k&N,A=S+I+P+_n[T]+m[T]>>>0,ae=h(y,2)^h(y,13)^h(y,22),Be=y&_^y&w^_&w,ke=ae+Be>>>0;S=N,N=E,E=k,k=x+A>>>0,x=w,w=_,_=y,y=A+ke>>>0}a=a+y>>>0,d=d+_>>>0,u=u+w>>>0,l=l+x>>>0,g=g+k>>>0,f=f+E>>>0,p=p+N>>>0,c=c+S>>>0}let v=b=>b.toString(16).padStart(8,"0");return v(a)+v(d)+v(u)+v(l)+v(g)+v(f)+v(p)+v(c)}function ot(r){let e=st(r??null),t=JSON.stringify(e);return On(t).slice(0,16)}function Tn(){let r=globalThis.crypto;if(r?.randomUUID)return r.randomUUID();let e=()=>Math.floor(Math.random()*4294967296).toString(16).padStart(8,"0"),t=e()+e()+e()+e();return`${t.slice(0,8)}-${t.slice(8,12)}-4${t.slice(13,16)}-${(parseInt(t.slice(16,17),16)&3|8).toString(16)}${t.slice(17,20)}-${t.slice(20,32)}`}function it(r,e,t){let n=t?.id??Tn();if(r===0)return{id:n,version:0};let o=(t?.hash??ot)(e);return{id:n,version:0,cid:o,prev:null}}function Ct(r,e,t){r.version+=1,"cid"in r&&(r.prev=r.cid,r.cid=t(e))}var _n,wn,Dt=V(()=>{"use strict";_n=new Uint32Array([1116352408,1899447441,3049323471,3921009573,961987163,1508970993,2453635748,2870763221,3624381080,310598401,607225278,1426881987,1925078388,2162078206,2614888103,3248222580,3835390401,4022224774,264347078,604807628,770255983,1249150122,1555081692,1996064986,2554220882,2821834349,2952996808,3210313671,3336571891,3584528711,113926993,338241895,666307205,773529912,1294757372,1396182291,1695183700,1986661051,2177026350,2456956037,2730485921,2820302411,3259730800,3345764771,3516065817,3600352804,4094571909,275423344,430227734,506948616,659060556,883997877,958139571,1322822218,1537002063,1747873779,1955562222,2024104815,2227730452,2361852424,2428436474,2756734187,3204031479,3329325298]),wn=new TextEncoder});function Pt(r){return{node:r,unsub:null,prevData:void 0,dirty:!1,involvedThisWave:!1,dataBatch:[],terminal:void 0}}function at(r){r.prevData=void 0,r.dirty=!1,r.involvedThisWave=!1,r.dataBatch.length=0,r.terminal=void 0}function Pe(r){return r.length===0?r:typeof r[0]=="symbol"?[r]:r}function $e(r,e,t){let n=$t(r)?r:[],s=typeof r=="function"?r:typeof e=="function"?e:void 0,o={};return $t(r)?o=(ut(e)?e:t)??{}:ut(r)?o=r:o=(ut(e)?e:t)??{},new $(n,s,o)}var Mt,Gt,xn,kn,ge,$,$t,ut,we=V(()=>{"use strict";Ze();Xe();De();ue();At();Ge();he();Dt();Mt=()=>{},Gt=100;xn=(r,e,t,n)=>{t.direction==="down-in"&&r._onDepMessage(t.depIndex,e)},kn=(r,e,t,n)=>{let s=r;if(s._status==="completed"||s._status==="errored")return;let o=s._cached,i=o===void 0?[et]:[et,[M,o]];s._status==="dirty"&&i.push(pe),Ce(e,i,s._config.tierOf)},ge=new Me({onMessage:xn,onSubscribe:kn});Rt(ge);xt(ge);$=class r{_optsName;_describeKind;meta;_hasMeta;_config;_deps;_sinks=null;_sinkCount=0;_cached;_status;_cleanup;_store={};_waveHasNewData=!1;_hasNewTerminal=!1;_hasCalledFnOnce=!1;_paused=!1;_pendingWave=!1;_isExecutingFn=!1;_pendingRerun=!1;_rerunDepth=0;_dirtyDepCount=0;_batchPendingMessages=null;_pauseLocks=null;_pauseBuffer=null;_fn;_equals;_resubscribable;_resetOnTeardown;_autoComplete;_autoError;_pausable;_partial;_guard;_extraGuards;_hashFn;_versioning;_versioningLevel;_lastMutation;_inspectorHooks;_actions;constructor(e,t,n){this._config=n.config??ge,this._config.onMessage,this._optsName=n.name,this._describeKind=n.describeKind,this._equals=n.equals??Object.is,this._resubscribable=n.resubscribable??!1,this._resetOnTeardown=n.resetOnTeardown??!1,this._autoComplete=n.completeWhenDepsComplete??!0,this._autoError=n.errorWhenDepsError??!0,this._pausable=n.pausable??!0,this._guard=n.guard,this._fn=t,this._partial=n.partial??!1,this._cached=n.initial!==void 0?n.initial:void 0,this._status=e.length===0&&t==null&&this._cached!==void 0?"settled":"sentinel",this._hashFn=n.versioningHash??this._config.defaultHashFn??ot;let s=n.versioning??this._config.defaultVersioning;this._versioningLevel=s,this._versioning=s!=null?it(s,this._cached===void 0?void 0:this._cached,{id:n.versioningId,hash:this._hashFn}):void 0,this._deps=e.map(Pt);let o={};for(let[a,d]of Object.entries(n.meta??{})){let u={initial:d,name:`${n.name??"node"}:meta:${a}`,describeKind:"state",config:this._config};n.guard!=null&&(u.guard=n.guard),o[a]=new r([],void 0,u)}Object.freeze(o),this.meta=o,this._hasMeta=Object.keys(o).length>0;let i=this;this._actions={emit(a){i._emit([[M,a]])},down(a){i._emit(Pe(a))},up(a){i._emitUp(Pe(a))}},this.down=this.down.bind(this),this.up=this.up.bind(this)}get _isTerminal(){return this._status==="completed"||this._status==="errored"}get name(){return this._optsName}get status(){return this._status}get cache(){return this._cached===void 0?void 0:this._cached}get lastMutation(){return this._lastMutation}get v(){return this._versioning}hasGuard(){return this._guard!=null}_applyVersioning(e,t){if(this._isExecutingFn)throw new Error(`Node "${this.name}": _applyVersioning cannot run mid-fn \u2014 call it outside of \`_execFn\` (typically at graph setup time before the first subscribe).`);let n=this._versioningLevel;if(n!=null&&e<=n)return;let s=t?.hash??this._hashFn;s!==this._hashFn&&(this._hashFn=s);let o=this._cached===void 0?void 0:this._cached,i=this._versioning,a=i?.id??t?.id,d=i?.version??0,u=it(e,o,{id:a,hash:s});u.version=d,this._versioning=u,this._versioningLevel=e}_setInspectorHook(e){return e==null?()=>{}:(this._inspectorHooks==null&&(this._inspectorHooks=new Set),this._inspectorHooks.add(e),()=>{this._inspectorHooks?.delete(e),this._inspectorHooks?.size===0&&(this._inspectorHooks=void 0)})}_pushGuard(e){return this._extraGuards==null&&(this._extraGuards=new Set),this._extraGuards.add(e),()=>{this._extraGuards?.delete(e),this._extraGuards?.size===0&&(this._extraGuards=void 0)}}allowsObserve(e){if(this._guard==null&&this._extraGuards==null)return!0;let t=Se(e);if(this._guard!=null&&!this._guard(t,"observe"))return!1;if(this._extraGuards!=null){for(let n of this._extraGuards)if(!n(t,"observe"))return!1}return!0}_checkGuard(e){if(e?.internal)return;let t=this._guard!=null||this._extraGuards!=null,n=e?.actor!=null;if(!t&&!n)return;let s=Se(e?.actor),o=e?.delivery==="signal"?"signal":"write";if(this._guard!=null&&!this._guard(s,o))throw new U({actor:s,action:o,nodeName:this.name});if(this._extraGuards!=null){for(let i of this._extraGuards)if(!i(s,o))throw new U({actor:s,action:o,nodeName:this.name})}this._lastMutation={actor:s,timestamp_ns:Ne()}}down(e,t){let n=Pe(e);n.length!==0&&(this._checkGuard(t),this._emit(n))}emit(e,t){this._checkGuard(t),this._emit([[M,e]])}up(e,t){if(this._deps.length===0)return;let n=Pe(e);if(n.length===0)return;this._checkGuard(t);let s=t??{internal:!0};this._validateUpTiers(n);for(let o of this._deps)o.node.up?.(n,s)}_emitUp(e){if(this._deps.length!==0&&e.length!==0){this._validateUpTiers(e);for(let t of this._deps)t.node.up?.(e,{internal:!0})}}_validateUpTiers(e){let t=this._config.tierOf;for(let n of e){let s=t(n[0]);if(s===3||s===4)throw new Error(`Node "${this.name}": tier-${s} messages cannot flow up \u2014 DATA/RESOLVED/COMPLETE/ERROR are downstream-only. Use \`down(...)\` for value delivery; \`up(...)\` is for control signals (DIRTY, INVALIDATE, PAUSE, RESUME, TEARDOWN).`)}}subscribe(e,t){if(t!=null&&this._guard!=null){let d=Se(t);if(!this._guard(d,"observe"))throw new U({actor:d,action:"observe",nodeName:this.name})}let s=this._isTerminal&&this._resubscribable;if(s){this._cached=void 0,this._status="sentinel",this._store={},this._hasCalledFnOnce=!1,this._waveHasNewData=!1,this._hasNewTerminal=!1,this._paused=!1,this._pendingWave=!1,this._pendingRerun=!1,this._isExecutingFn=!1,this._rerunDepth=0,this._dirtyDepCount=0,this._pauseLocks=null,this._pauseBuffer=null;for(let d of this._deps)at(d);if(this._partial===!1){for(let d of this._deps)if(d.prevData!==void 0||d.dataBatch.length!==0||d.terminal!==void 0||d.dirty)throw new Error(`resubscribable-reset invariant: DepRecord not fully reset for node ${this._optsName??"(anonymous)"}`)}}this._sinkCount+=1;let o;try{o=this._config.onSubscribe(this,e,{sinkCount:this._sinkCount,afterTerminalReset:s},this._actions)}catch(d){throw this._sinkCount-=1,d}this._sinks==null?this._sinks=e:typeof this._sinks=="function"?this._sinks=new Set([this._sinks,e]):this._sinks.add(e);let i=this._isTerminal;if(this._sinkCount===1&&!i)try{this._activate()}catch(d){if(this._sinkCount-=1,this._removeSink(e),this._sinkCount===0&&(this._status="sentinel"),typeof o=="function")try{o()}catch{}throw d}this._status==="sentinel"&&this._cached===void 0&&(this._status="pending");let a=!1;return()=>{a||(a=!0,this._sinkCount-=1,this._removeSink(e),typeof o=="function"&&o(),this._sinks==null&&this._deactivate())}}_removeSink(e){if(this._sinks===e)this._sinks=null;else if(this._sinks!=null&&typeof this._sinks!="function")if(this._sinks.delete(e),this._sinks.size===1){let[t]=this._sinks;this._sinks=t}else this._sinks.size===0&&(this._sinks=null)}_activate(){if(this._deps.length===0){this._fn&&this._execFn();return}this._dirtyDepCount=0;let e=this._deps.length,t=0;try{for(let n=0;n<e;n++){let s=n,o=this._deps[n];o.unsub=Mt,o.unsub=o.node.subscribe(i=>{if(o.unsub===null)return;let a=this._config.tierOf,d=!1;for(let u of i)a(u[0])>=3&&(d=!0),this._config.onMessage(this,u,{direction:"down-in",depIndex:s},this._actions);d&&this._maybeRunFnOnSettlement()}),t++}}catch(n){this._deps[t].unsub=null;for(let s=0;s<t;s++){let o=this._deps[s];if(o.unsub!=null){let i=o.unsub;o.unsub=null;try{i()}catch{}at(o)}}throw this._dirtyDepCount=0,n}}_addDep(e){for(let s=0;s<this._deps.length;s++)if(this._deps[s].node===e)return s;let t=this._deps.length,n=Pt(e);if(this._deps.push(n),this._sinks==null)return t;n.dirty=!0,this._dirtyDepCount++,this._status!=="dirty"&&this._emit(tt),n.unsub=Mt;try{n.unsub=e.subscribe(s=>{if(n.unsub===null)return;let o=this._config.tierOf,i=!1;for(let a of s)o(a[0])>=3&&(i=!0),this._config.onMessage(this,a,{direction:"down-in",depIndex:t},this._actions);i&&this._maybeRunFnOnSettlement()})}catch(s){throw n.unsub=null,this._deps.pop(),this._dirtyDepCount--,s}return t}_deactivate(e=!1){let t=this._cleanup;if(this._cleanup=void 0,typeof t=="function")try{t()}catch(n){this._emit([[G,this._wrapFnError("cleanup threw",n)]])}else if(t!=null&&typeof t=="object"){let n=t.deactivate;if(typeof n=="function")try{n()}catch(s){this._emit([[G,this._wrapFnError("cleanup.deactivate threw",s)]])}}for(let n of this._deps){if(n.unsub!=null){let s=n.unsub;n.unsub=null;try{s()}catch{}}at(n)}this._waveHasNewData=!1,this._hasNewTerminal=!1,this._hasCalledFnOnce=!1,this._paused=!1,this._pendingWave=!1,this._pendingRerun=!1,this._rerunDepth=0,this._store={},this._dirtyDepCount=0,this._pauseLocks=null,this._pauseBuffer=null,this._fn!=null&&(this._cached=void 0),e||(this._fn!=null||this._deps.length>0)&&(!this._isTerminal||this._resubscribable)&&(this._status="sentinel")}_onDepMessage(e,t){let n=this._deps[e],s=t[0];if(this._inspectorHooks!=null){let o={kind:"dep_message",depIndex:e,message:t};for(let i of this._inspectorHooks)i(o)}if(s!==_e){if(s===W){this._depDirtied(n);return}if(s===Y){if(this._depInvalidated(n),this._cached===void 0)return;this._emit(Nt);return}if(s===Z||s===ee){this._emit([t]);return}if(s===L){this._emit(nt);return}if(s===M)this._depSettledAsData(n,t[1]);else if(s===J)this._depSettledAsResolved(n);else if(s===z)this._depSettledAsTerminal(n,!0);else if(s===G)this._depSettledAsTerminal(n,t[1]);else{this._emit([t]);return}if(!this._fn){(s===M||s===J)&&this._emit([t]),(s===z||s===G)&&this._maybeAutoTerminalAfterWave();return}}}_depDirtied(e){e.dirty||(e.dirty=!0,e.involvedThisWave=!0,this._dirtyDepCount++,this._status!=="dirty"&&this._emit(tt))}_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(Et),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(St)}_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),n=this._deps.map(i=>i.prevData);for(let i=0;i<this._deps.length;i++){let a=t[i];a!=null&&a.length>0&&(this._deps[i].prevData=a[a.length-1])}let s=this._deps.map(i=>i.terminal),o={prevData:n,terminalDeps:s,store:this._store};if(this._hasCalledFnOnce=!0,this._clearWaveFlags(),this._inspectorHooks!=null){let i={kind:"run",batchData:t,prevData:n};for(let a of this._inspectorHooks)a(i)}this._isExecutingFn=!0;try{let i=this._fn(t,this._actions,o);if(typeof i=="function")this._cleanup=i;else if(i!=null&&typeof i=="object"){let a=i;(typeof a.beforeRun=="function"||typeof a.deactivate=="function"||typeof a.invalidate=="function")&&(this._cleanup=i)}}catch(i){this._emit([[G,this._wrapFnError("fn threw",i)]])}finally{this._isExecutingFn=!1,this._pendingRerun?(this._pendingRerun=!1,this._rerunDepth+=1,this._rerunDepth>Gt?(this._rerunDepth=0,this._emit([[G,new Error(`Node "${this.name}": _pendingRerun depth exceeded ${Gt} \u2014 likely a reactive cycle`)]])):this._maybeRunFnOnSettlement()):this._rerunDepth=0,this._clearWaveFlags()}}_clearWaveFlags(){this._waveHasNewData=!1,this._hasNewTerminal=!1;for(let e of this._deps)e.involvedThisWave=!1,e.dataBatch.length=0}_wrapFnError(e,t){let n=t instanceof Error?t.message:String(t);return new Error(`Node "${this.name}": ${e}: ${n}`,{cause:t})}_frameBatch(e){let t=this._config.tierOf;if(e.length===1)return t(e[0][0])===3&&this._status!=="dirty"?[pe,e[0]]:e;let n=!0,s=!1,o=!1,i=-1;for(let d of e){let u=t(d[0]);u<i&&(n=!1),u===3&&(s=!0),d[0]===W&&(o=!0),i=u}let a=e;if(!n){let d=e.map((u,l)=>({m:u,i:l,tier:t(u[0])}));d.sort((u,l)=>u.tier-l.tier||u.i-l.i),a=d.map(u=>u.m)}if(s&&!o&&this._status!=="dirty"){let d=0;for(;d<a.length&&t(a[d][0])===0;)d++;return d===0?[pe,...a]:[...a.slice(0,d),pe,...a.slice(d)]}return a}_emit(e){if(e.length===0)return;for(let a=0;a<e.length;a++){let d=e[a];if(d[0]===G&&d[1]===void 0)throw new TypeError('[ERROR, payload] requires a non-undefined payload (spec \xA71.2). Pass an Error object or domain tag instead \u2014 e.g. node.down([[ERROR, new Error("reason")]])')}let t=e;if(this._isTerminal&&!this._resubscribable){let a=e.filter(d=>d[0]===L||d[0]===Y);if(a.length===0)return;t=a}t=this._frameBatch(t);let s=null;for(let a=0;a<t.length;a++){let d=t[a],u=d[0];if(u!==Z&&u!==ee){s?.push(d);continue}if(d.length<2)throw new Error(`Node "${this.name}": [[${u===Z?"PAUSE":"RESUME"}]] must carry a lockId payload \u2014 bare PAUSE/RESUME is a protocol violation (C0 rule). Use \`[[PAUSE, lockId]]\` / \`[[RESUME, lockId]]\`.`);let l=!0;if(this._pausable!==!1){let g=d[1];if(u===Z)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))l=!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())}}l?s?.push(d):s==null&&(s=t.slice(0,a))}if(s!=null){if(s.length===0)return;t=s}if(this._hasMeta&&t.some(a=>a[0]===L))for(let a of Object.keys(this.meta))try{this.meta[a]._emit(nt)}catch{}let{finalMessages:o,equalsError:i}=this._updateState(t);if(o.length>0&&this._config.inspectorEnabled){let a=this._config.globalInspector;if(a!=null)try{a({kind:"emit",node:this,messages:o})}catch{}}if(o.length>0)if(this._paused&&this._pausable==="resumeAll"&&this._pauseBuffer!=null){let a=this._config.tierOf,d=[];for(let u of o)a(u[0])===3?this._pauseBuffer.push(u):d.push(u);d.length>0&&this._dispatchOrAccumulate(d)}else this._dispatchOrAccumulate(o);i!=null&&this._emit([[G,i]])}_updateState(e){let t=this._config.tierOf,n,s,o=-1,i=0;for(let l of e)t(l[0])===3&&i++;let a=i<=1,d=-1;if(this._versioning!=null&&i>1){for(let l=e.length-1;l>=0;l--)if(e[l][0]===M){d=l;break}}for(let l=0;l<e.length;l++){let g=e[l],f=g[0];if(f===M){if(g.length>=2){let p=!1;if(a&&this._cached!==void 0)try{p=this._equals(this._cached,g[1])}catch(c){s=this._wrapFnError("equals threw",c),o=l;break}if(p){n==null&&(n=e.slice(0,l)),n.push(Qe),this._status="resolved";continue}this._cached=g[1],this._versioning!=null&&(d<0||l===d)&&Ct(this._versioning,g[1],this._hashFn)}this._status="settled",n?.push(g)}else if(n?.push(g),f===W)this._status="dirty";else if(f===J)this._status="resolved";else if(f===z){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===Y){if(this._cached!==void 0){let c=this._config.rigorRecorder;if(c!=null)try{c.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 c=p.invalidate;if(typeof c=="function")try{c()}catch{}}}else f===L&&(this._resetOnTeardown&&(this._cached=void 0),this._deactivate(!0),this._status="sentinel")}let u=o>=0?n??e.slice(0,o):n??e;return s!=null?{finalMessages:u,equalsError:s}:{finalMessages:u}}_deliverToSinks=e=>{if(this._sinks==null)return;if(typeof this._sinks=="function"){this._sinks(e);return}let t=[...this._sinks];for(let n of t)n(e)};_dispatchOrAccumulate(e){if(kt()){this._batchPendingMessages===null&&(this._batchPendingMessages=[],fe(()=>this._flushBatchPending()));for(let t of e)this._batchPendingMessages.push(t);return}Ce(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);Ce(this._deliverToSinks,t,this._config.tierOf)}},$t=r=>Array.isArray(r),ut=r=>typeof r=="object"&&r!=null&&!Array.isArray(r)});function X(r,e){return $e([],{...e,initial:r})}function dt(r,e){return $e((n,s,o)=>r(s,o)??void 0,{describeKind:"producer",...e})}function me(r,e,t){return $e(r,(s,o,i)=>{let a=s.map((d,u)=>d!=null&&d.length>0?d.at(-1):i.prevData[u]);o.emit(e(a,i))},{describeKind:"derived",...t})}var Fe=V(()=>{"use strict";we()});function Ft(r,e,t){return{[r]:!0,[`${r}_type`]:e,...t??{}}}var It=V(()=>{"use strict"});function se(r){return r.subscribe(()=>{})}var Vt=V(()=>{"use strict"});var lt=V(()=>{"use strict";Vt()});function ft(r,e){if(e!=null&&e.length>0)return new Set(e);switch(r){case"standard":return new Set(["type","status","value","deps","meta","v"]);case"full":return null;case"spec":return new Set(["type","deps","meta","value"]);default:return new Set(["type","deps"])}}function Dn(r){return r._describeKind!=null?r._describeKind:r._deps.length>0?"derived":r._fn!=null?"producer":"state"}function Mn(r){let e={};for(let[t,n]of Object.entries(r.meta))try{e[t]=n.cache}catch{}return e}function pt(r,e,t){let n=e==null,s=!n&&e!=null?[...e].filter(l=>l.startsWith("meta.")).map(l=>l.slice(5)):null,o=n||e.has("meta")||s!=null&&s.length>0,i="state",a=[];r instanceof $&&(i=Dn(r),a=r._deps.map(l=>l.node.name??""));let d={type:i,deps:a};(n||e.has("status"))&&(d.status=r.status);let u=r instanceof $?r._guard:void 0;if(o){let l={...Mn(r)};if(u!=null&&l.access===void 0&&(l.access=rt(u)),s!=null&&s.length>0&&!e.has("meta")){let g={};for(let f of s)f in l&&(g[f]=l[f]);d.meta=g}else d.meta=l}if(r.name!=null&&(d.name=r.name),(n||e.has("value"))&&(!t||i==="state")){r.status==="sentinel"&&(d.sentinel=!0);try{d.value=r.cache}catch{}}if((n||e.has("v"))&&r.v!=null){let l={id:r.v.id,version:r.v.version};"cid"in r.v&&(l.cid=r.v.cid,l.prev=r.v.prev),d.v=l}return(n||e.has("guard"))&&u!=null&&(d.guard=rt(u)),(n||e.has("lastMutation"))&&r.lastMutation!=null&&(d.lastMutation=r.lastMutation),d}var Wt=V(()=>{"use strict";Ge();we()});var je,qt=V(()=>{"use strict";je=class{_timer;_gen=0;start(e,t){this.cancel(),this._gen+=1;let n=this._gen;this._timer=setTimeout(()=>{this._timer=void 0,n===this._gen&&t()},e)}cancel(){this._timer!==void 0&&(clearTimeout(this._timer),this._timer=void 0)}get pending(){return this._timer!==void 0}}});var Oe,Yt=V(()=>{"use strict";Oe=class{constructor(e){this.capacity=e;if(!Number.isInteger(e)||e<=0)throw new Error(`RingBuffer capacity must be a positive integer (got ${e})`);this.buf=new Array(e)}buf;head=0;_size=0;get size(){return this._size}get maxSize(){return this.capacity}push(e){let t=(this.head+this._size)%this.capacity;this.buf[t]=e,this._size<this.capacity?this._size++:this.head=(this.head+1)%this.capacity}shift(){if(this._size===0)return;let e=this.buf[this.head];return this.buf[this.head]=void 0,this.head=(this.head+1)%this.capacity,this._size--,e}at(e){if(this._size===0)return;let t=e<0?this._size+e:e;if(!(t<0||t>=this._size))return this.buf[(this.head+t)%this.capacity]}toArray(){let e=new Array(this._size);for(let t=0;t<this._size;t++)e[t]=this.buf[(this.head+t)%this.capacity];return e}clear(){for(let e=0;e<this._size;e++)this.buf[(this.head+e)%this.capacity]=void 0;this.head=0,this._size=0}}});var Jn={};ln(Jn,{LensGraph:()=>ze,graphLens:()=>Yn,watchTopologyTree:()=>xe});module.exports=pn(Jn);ue();Fe();It();De();ue();he();Fe();var ct=class{_version=0;_store=new Map;_maxSize;_defaultTtl;constructor(e={}){let{maxSize:t,defaultTtl:n}=e;if(t!==void 0&&t<1)throw new RangeError("maxSize must be >= 1");if(n!==void 0&&n<=0)throw new RangeError("defaultTtl must be positive");this._maxSize=t,this._defaultTtl=n}get version(){return this._version}get size(){return this._store.size}has(e){let t=this._store.get(e);return t===void 0?!1:this._isExpired(t)?(this._store.delete(e),this._version+=1,!1):(this._touchLru(e,t),!0)}get(e){let t=this._store.get(e);if(t!==void 0){if(this._isExpired(t)){this._store.delete(e),this._version+=1;return}return this._touchLru(e,t),t.value}}set(e,t,n){let s=this._resolveExpiresAt(n);this._store.has(e)&&this._store.delete(e),this._store.set(e,{value:t,expiresAt:s}),this._evictLruWhileOver(),this._version+=1}setMany(e,t){let n=this._resolveExpiresAt(t),s=0;try{for(let[o,i]of e)this._store.has(o)&&this._store.delete(o),this._store.set(o,{value:i,expiresAt:n}),s+=1}finally{s>0&&(this._evictLruWhileOver(),this._version+=1)}}delete(e){let t=this._store.delete(e);return t&&(this._version+=1),t}deleteMany(e){let t=0;try{for(let n of e)this._store.delete(n)&&(t+=1)}finally{t>0&&(this._version+=1)}return t}clear(){let e=this._store.size;return e===0?0:(this._store.clear(),this._version+=1,e)}pruneExpired(){let e=j(),t=0;for(let[n,s]of this._store)this._isExpired(s,e)&&(this._store.delete(n),t+=1);return t>0&&(this._version+=1),t}toMap(){let e=j(),t=new Map;for(let[n,s]of this._store)this._isExpired(s,e)||t.set(n,s.value);return t}_resolveExpiresAt(e){let t=e??this._defaultTtl;if(t!==void 0){if(!Number.isFinite(t)||t<=0)throw new RangeError(`MapBackend: ttl must be a positive finite number (got ${t})`);return j()+t*1e9}}_isExpired(e,t){return e.expiresAt===void 0?!1:(t??j())>=e.expiresAt}_touchLru(e,t){this._store.delete(e),this._store.set(e,t)}_evictLruWhileOver(){if(this._maxSize!==void 0)for(;this._store.size>this._maxSize;){let e=this._store.keys().next().value;if(e===void 0)break;this._store.delete(e)}}};function Lt(r={}){let{name:e,maxSize:t,defaultTtl:n,versioning:s,backend:o,retention:i}=r;if(i&&t!==void 0)throw new RangeError("reactiveMap: `maxSize` (LRU) and `retention` (score-based) are mutually exclusive. Pick one eviction policy.");if(i&&i.archiveThreshold===void 0&&i.maxSize===void 0)throw new RangeError("reactiveMap: `retention` requires at least one of `archiveThreshold` or `maxSize` to trigger archival.");let a=o??new ct({maxSize:t,defaultTtl:n}),d=X(a.toMap(),{name:e,describeKind:"state",equals:(f,p)=>f===p,...s!=null?{versioning:s}:{}});function u(){let f=a.toMap();Ae(()=>{d.down([[W]]),d.down([[M,f]])})}function l(){if(!i)return;let f=a.toMap(),p=i.archiveThreshold,c=i.maxSize,m=[];for(let[v,b]of f)m.push({key:v,value:b,score:i.score(v,b)});m.sort((v,b)=>v.score-b.score);let h=new Set;if(p!==void 0)for(let v of m)if(v.score<p)h.add(v.key);else break;if(c!==void 0&&m.length-h.size>c)for(let v of m){if(m.length-h.size<=c)break;h.has(v.key)||h.add(v.key)}if(h.size!==0)for(let v of m)h.has(v.key)&&(i.onArchive?.(v.key,v.value,v.score),a.delete(v.key))}function g(f,p="mutation"){let c=a.version;try{return f()}finally{a.version!==c&&(p==="mutation"&&l(),u())}}return{entries:d,has(f){return g(()=>a.has(f),"read")},get(f){return g(()=>a.get(f),"read")},set(f,p,c){g(()=>a.set(f,p,c?.ttl))},setMany(f,p){g(()=>a.setMany(f,p?.ttl))},delete(f){g(()=>a.delete(f))},deleteMany(f){g(()=>a.deleteMany(f))},clear(){g(()=>a.clear())},pruneExpired(){g(()=>a.pruneExpired())},get size(){return a.size},dispose(){}}}lt();var F={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},En=Symbol.for("sizeof");function jt(r){let e=new WeakSet,t=new WeakSet,n=[r],s=0;for(;n.length>0;){let o=n.pop();s+=Nn(o,e,t,n)}return s}function Nn(r,e,t,n){if(r==null)return 0;switch(typeof r){case"number":return F.number;case"boolean":return F.boolean;case"string":return F.string+r.length*2;case"bigint":return F.bigint+Sn(r);case"symbol":return F.symbol;case"function":return e.has(r)?0:(e.add(r),F.function);case"undefined":return 0}let o=r;if(e.has(o))return 0;e.add(o);let i=o[En];if(typeof i=="function")try{let u=i.call(o);if(typeof u=="number"&&Number.isFinite(u))return u}catch{}if(o instanceof Date)return F.date;if(o instanceof RegExp)return F.regexp+o.source.length*2;if(o instanceof Error){let u=o.message?o.message.length*2:0,l=o.stack?o.stack.length*2:0;return F.error+u+l}if(typeof URL<"u"&&o instanceof URL)return F.url+o.href.length*2;if(typeof Promise<"u"&&o instanceof Promise)return F.promise;if(o instanceof WeakMap)return F.weakmap;if(o instanceof WeakSet)return F.weakset;if(o instanceof Map){let u=F.map;for(let[l,g]of o)u+=F.mapEntry,n.push(l),n.push(g);return u}if(o instanceof Set){let u=F.set;for(let l of o)u+=F.setEntry,n.push(l);return u}if(Array.isArray(o)){let u=F.array+o.length*8;for(let l of o)n.push(l);return u}if(o instanceof ArrayBuffer)return t.has(o)?0:(t.add(o),o.byteLength);if(ArrayBuffer.isView(o)){let u=o;return t.has(u.buffer)?48:(t.add(u.buffer),u.buffer.byteLength+48)}let a=F.object,d=Object.keys(o);for(let u of d){a+=F.string+u.length*2;try{n.push(o[u])}catch{}}return a}function Sn(r){let e=r<0n?-r:r;if(e===0n)return 0;let t=e.toString(2).length;return Math.ceil(t/32)*8}function Ht(r,e,t,n={}){let s=e in r.nodes,o=t in r.nodes;if(!s)return Ie(e,t,"no-such-from");if(!o)return Ie(e,t,"no-such-to");let i=n.maxDepth;if(i!=null&&(!Number.isInteger(i)||i<0))throw new Error("explainPath: maxDepth must be an integer >= 0");if(e===t){if(n.findCycle===!0){let u=Rn(r,e,n);if(u!=null)return u}let d=Le(e,r.nodes[e],0,n);return Ve(e,t,[d])}if(i===0)return Ie(e,t,"no-path");let a=zt(r,e,t,i);return a.found?Ve(e,t,Bt(r,a.pathOrder,n)):Ie(e,t,a.truncated?"max-depth-exceeded":"no-path")}function zt(r,e,t,n){let s=new Map,o=[{path:t,depth:0}],i=new Set([t]),a=0,d=!1;for(;a<o.length;){let g=o[a++];if(g.path===e)break;if(n!=null&&g.depth>=n){let m=r.nodes[g.path];m?.deps&&m.deps.length>0&&(d=!0);continue}let f=r.nodes[g.path];if(f==null)continue;let p=f.deps??[],c=new Map;for(let m=0;m<p.length;m++){let h=p[m];if(!h)continue;let v=c.get(h);v==null&&(v=[],c.set(h,v)),v.push(m)}for(let[m,h]of c)i.has(m)||(i.add(m),s.set(m,{from:g.path,depIndices:h}),o.push({path:m,depth:g.depth+1}))}if(!s.has(e))return{found:!1,pathOrder:[],truncated:d};let u=[{path:e}],l=e;for(;l!==t;){let g=s.get(l);if(g==null)return{found:!1,pathOrder:[],truncated:!1};u[u.length-1].depIndices=g.depIndices,u.push({path:g.from}),l=g.from}return{found:!0,pathOrder:u,truncated:!1}}function Rn(r,e,t){let n=r.nodes[e];if(n==null)return null;let s=n.deps??[],o=[];for(let a=0;a<s.length;a++)s[a]===e&&o.push(a);if(o.length>0){let a=Le(e,n,0,t);a.dep_index=o[0];let d=Le(e,n,1,t);return Ve(e,e,[a,d])}let i=null;for(let a=0;a<s.length;a++){let d=s[a];if(!d||d===e)continue;let u=zt(r,d,e,t.maxDepth);u.found&&(i==null||u.pathOrder.length<i.pathOrder.length)&&(i=u,i={found:!0,pathOrder:[{path:e,depIndices:[a]},...u.pathOrder],truncated:!1})}return i==null?null:Ve(e,e,Bt(r,i.pathOrder,t))}function Bt(r,e,t){return e.map((n,s)=>{let o=r.nodes[n.path],i=Le(n.path,o,s,t);return n.depIndices!=null&&n.depIndices.length>0&&(i.dep_index=n.depIndices[0],n.depIndices.length>1&&(i.dep_indices=[...n.depIndices])),i})}function Le(r,e,t,n){let s={path:r,type:e.type,hop:t};e.status!==void 0&&(s.status=e.status),"value"in e&&(s.value=e.value),e.v!=null&&(s.v=e.v);let o=n.annotations?.get(r)??e.annotation;o!=null&&(s.annotation=o);let i=n.lastMutations?.get(r)??e.lastMutation;return i!=null&&(s.lastMutation=i),s}function Ve(r,e,t){return Kt(r,e,!0,"ok",t)}function Ie(r,e,t){return Kt(r,e,!1,t,[])}function Kt(r,e,t,n,s){let o=An(r,e,t,n,s);return{from:r,to:e,found:t,reason:n,steps:s,text:o,toJSON(){return{from:r,to:e,found:t,reason:n,steps:s}}}}function An(r,e,t,n,s){if(!t)switch(n){case"no-such-from":return`explainPath: no node named "${r}"`;case"no-such-to":return`explainPath: no node named "${e}"`;case"max-depth-exceeded":return`explainPath: no path from "${r}" to "${e}" within maxDepth`;default:return`explainPath: no path from "${r}" to "${e}"`}let o=[`Causal path: ${r} \u2192 ${e} (${s.length} step(s))`];for(let i of s){let d=` ${i.hop===0?"\xB7":"\u2193"} ${i.path} (${i.type}${i.status?`/${i.status}`:""})`;if(o.push(d),"value"in i&&o.push(` value: ${Cn(i.value)}`),i.annotation!=null&&o.push(` annotation: ${i.annotation}`),i.lastMutation!=null){let u=i.lastMutation.actor;o.push(` actor: ${u.type}${u.id?`:${u.id}`:""}`)}}return o.join(`
|
|
2
|
+
`)}function Cn(r){if(r===void 0)return"<sentinel>";if(r===null)return"null";if(typeof r=="string")return JSON.stringify(r);if(typeof r=="number"||typeof r=="boolean"||typeof r=="bigint")return String(r);try{let e=JSON.stringify(r);return e.length>80?`${e.slice(0,77)}...`:e}catch{return String(r)}}Xe();De();ue();Ge();he();Wt();we();Fe();ue();function ht(r,e){if(Object.is(r,e))return!0;if(r==null||e==null||typeof r!="object"||typeof e!="object")return!1;if(Array.isArray(r)){if(!Array.isArray(e)||r.length!==e.length)return!1;for(let o=0;o<r.length;o++)if(!ht(r[o],e[o]))return!1;return!0}if(Array.isArray(e))return!1;let t=Object.keys(r),n=Object.keys(e);if(t.length!==n.length)return!1;let s=new Set(n);for(let o of t)if(!s.has(o)||!ht(r[o],e[o]))return!1;return!0}function Ut(r,e){return`${r}\0${e}`}function gt(r,e){let t=[],n=new Set(r.subgraphs),s=new Set(e.subgraphs),o=[];for(let h of s)n.has(h)||o.push(h);o.sort();for(let h of o)t.push({type:"subgraph-mounted",path:h});let i=new Set(Object.keys(r.nodes)),a=new Set(Object.keys(e.nodes)),d=[];for(let h of a)i.has(h)||d.push(h);d.sort();for(let h of d)t.push({type:"node-added",path:h,node:{...e.nodes[h]}});let u=[];for(let h of a){if(!i.has(h))continue;let v=r.nodes[h]?.meta,b=e.nodes[h]?.meta;v==null&&b==null||ht(v??{},b??{})||u.push(h)}u.sort();for(let h of u)t.push({type:"node-meta-changed",path:h,prevMeta:r.nodes[h]?.meta??{},nextMeta:e.nodes[h]?.meta??{}});let l=new Map;for(let h of r.edges)l.set(Ut(h.from,h.to),h);let g=new Map;for(let h of e.edges)g.set(Ut(h.from,h.to),h);let f=[];for(let[h,v]of g)l.has(h)||f.push(v);f.sort((h,v)=>h.from<v.from?-1:h.from>v.from?1:h.to<v.to?-1:h.to>v.to?1:0);for(let h of f)t.push({type:"edge-added",from:h.from,to:h.to});let p=[];for(let[h,v]of l)g.has(h)||p.push(v);p.sort((h,v)=>h.from<v.from?-1:h.from>v.from?1:h.to<v.to?-1:h.to>v.to?1:0);for(let h of p)t.push({type:"edge-removed",from:h.from,to:h.to});let c=[];for(let h of i)a.has(h)||c.push(h);c.sort();for(let h of c)t.push({type:"node-removed",path:h});let m=[];for(let h of n)s.has(h)||m.push(h);m.sort();for(let h of m)t.push({type:"subgraph-unmounted",path:h});return{events:t,flushedAt_ns:j()}}lt();qt();Yt();Ze();we();function Jt(r,e){let t=e?.topN??10,n=r.describe({detail:"standard"}),s=[],o=r._collectObserveTargets;typeof o=="function"&&o.call(r,"",s);let i=new Map;for(let[f,p]of s)i.set(f,p);let a=[];for(let[f,p]of Object.entries(n.nodes)){let c=i.get(f),m=c instanceof $?c:null,h=m?jt(m.cache):0,v=m?m._sinkCount:0,b=p.deps?.length??0,y=p.type==="effect"&&v===0,_=v===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:h,subscriberCount:v,depCount:b,isOrphanEffect:y,orphanKind:_})}let d=a.reduce((f,p)=>f+p.valueSizeBytes,0),u=(f,p)=>[...a].sort(p??((c,m)=>m[f]-c[f])).slice(0,t),l=a.filter(f=>f.orphanKind!=null),g=a.filter(f=>f.isOrphanEffect);return{nodeCount:a.length,edgeCount:n.edges.length,subgraphCount:n.subgraphs.length,nodes:a,totalValueSizeBytes:d,hotspots:{byValueSize:u("valueSizeBytes"),bySubscriberCount:u("subscriberCount"),byDepCount:u("depCount")},orphans:l,orphanEffects:g}}var D="::",q="__meta__",oe=1;function Zt(r,e){let t=Math.max(16,r.size*4),n=0;for(;r.size>0;){if(n++>=t){console.error(`[Graph "${e}".destroy] disposer drain exceeded cap (${t}); ${r.size} disposer(s) discarded`),r.clear();return}let s=r.values().next();if(s.done)return;let o=s.value;r.delete(o);try{o()}catch(i){console.error(`[Graph "${e}".destroy] disposer threw:`,i)}}}function nn(r){return r!=null&&typeof r=="object"&&"cache"in r&&typeof r.subscribe=="function"&&typeof r.down=="function"}function Gn(r){if(r!=null)return nn(r)?r.cache:r}function ie(r){return r!=null&&typeof r=="object"&&"cache"in r&&typeof r.subscribe=="function"&&typeof r.down=="function"}function te(r){return ie(r)?r.cache??"":r}function Xt(r){return ie(r)?r.cache??0:r}function Qt(r){return ie(r)?r.cache??!1:r}function Pn(r){let e=[];for(let t of Object.keys(r).sort()){let n=r[t].v;n!=null&&e.push(`${t} ${n.id} ${n.version}`)}return e.join(`
|
|
3
|
+
`)}function en(r){if(r.version!==oe)throw new Error(`unsupported snapshot version ${String(r.version)} (expected ${oe})`);for(let e of["name","nodes","edges","subgraphs"])if(!(e in r))throw new Error(`snapshot missing required key "${e}"`);if(typeof r.name!="string")throw new TypeError("snapshot 'name' must be a string");if(typeof r.nodes!="object"||r.nodes===null||Array.isArray(r.nodes))throw new TypeError("snapshot 'nodes' must be an object");if(!Array.isArray(r.edges))throw new TypeError("snapshot 'edges' must be an array");if(!Array.isArray(r.subgraphs))throw new TypeError("snapshot 'subgraphs' must be an array")}function $n(r,e){let t=new WeakMap,n=(s,o)=>{if(Object.is(s,o))return!0;if(s==null||o==null||typeof s!="object"||typeof o!="object")return!1;let i=t.get(s);if(i==null&&(i=new WeakSet,t.set(s,i)),i.has(o))return!0;i.add(o);let a=s.constructor,d=o.constructor;if(a!==d)return!1;if(s instanceof Date)return s.getTime()===o.getTime();if(s instanceof RegExp)return s.source===o.source&&s.flags===o.flags;if(Array.isArray(s)){let f=o;if(s.length!==f.length)return!1;for(let p=0;p<s.length;p++)if(!n(s[p],f[p]))return!1;return!0}if(s instanceof Map){let f=o;if(s.size!==f.size)return!1;for(let[p,c]of s)if(!f.has(p)||!n(c,f.get(p)))return!1;return!0}if(s instanceof Set){let f=o;if(s.size!==f.size)return!1;for(let p of s){let c=!1;for(let m of f)if(n(p,m)){c=!0;break}if(!c)return!1}return!0}if(ArrayBuffer.isView(s)){let f=s,p=o;if(f.length!==p.length)return!1;for(let c=0;c<f.length;c++)if(f[c]!==p[c])return!1;return!0}let u=Object.keys(s),l=Object.keys(o);if(u.length!==l.length)return!1;let g=new Set(l);for(let f of u)if(!g.has(f)||!n(s[f],o[f]))return!1;return!0};return n(r,e)}function Fn(r){return r.replace(/[.*+?^${}()|[\]\\]/g,"\\$&")}function He(r){let e="^";for(let t=0;t<r.length;t+=1){let n=r[t];if(n==="*"){e+=".*";continue}if(n==="?"){e+=".";continue}if(n==="["){let s=r.indexOf("]",t+1);if(s<=t+1){e+="\\[";continue}let o=r.slice(t+1,s);o.startsWith("!")&&(o=`^${o.slice(1)}`),o=o.replace(/\\/g,"\\\\"),e+=`[${o}]`,t=s;continue}e+=Fn(n)}return e+="$",new RegExp(e)}var In={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"},Ln={data:"",dirty:"",resolved:"",invalidate:"",pause:"",resume:"",complete:"",error:"",teardown:"",derived:"",path:"",reset:""};function mt(r){if(typeof r=="string")return JSON.stringify(r);if(typeof r=="number"||typeof r=="boolean"||r==null)return String(r);try{return JSON.stringify(r)}catch{return"[unserializable]"}}function Vn(r){return r==="none"?Ln:r==="ansi"||r==null?In:{data:r.data??"",dirty:r.dirty??"",resolved:r.resolved??"",invalidate:r.invalidate??"",pause:r.pause??"",resume:r.resume??"",complete:r.complete??"",error:r.error??"",teardown:r.teardown??"",derived:r.derived??"",path:r.path??"",reset:r.reset??""}}function tn(r){if(r==null)return{};let e=r.detail;return e==="full"?{...r,structured:r.structured??!0,timeline:r.timeline??!0,causal:r.causal??!0,derived:r.derived??!0}:e==="minimal"?{...r,structured:r.structured??!0}:r.format==="stage-log"?{...r,structured:r.structured??!0,timeline:r.timeline??!0}:r}function jn(r,e,t){for(let n=0;n<r.length;n++){let s=r.charCodeAt(n);if(s<32||s===127)throw new Error(`Graph "${e}": ${t} "${r}" must not contain control character (U+${s.toString(16).padStart(4,"0").toUpperCase()} at index ${n})`)}}function bt(r,e,t){if(r==="")throw new Error(`Graph "${e}": ${t} name must be non-empty`);if(r.includes(D))throw new Error(`Graph "${e}": ${t} "${r}" must not contain '${D}' (path separator)`);if(r===q)throw new Error(`Graph "${e}": ${t} name "${q}" is reserved for meta companion paths`);jn(r,e,t)}function Hn(r,e){if(r==="")throw new Error(`Graph "${e}": resolve path must be non-empty`);let t=r.split(D);for(let n of t)if(n==="")throw new Error(`Graph "${e}": resolve path has empty segment`);return t}function zn(r,e){let t=!1;for(let s of r)if(!e.isMetaPassthrough(s[0])){t=!0;break}return t?r.filter(s=>e.isMetaPassthrough(s[0])):r}function rn(r){for(let e of r._mounts.values())rn(e);for(let e of r._nodes.values())try{e.down([[L]],{internal:!0})}catch{}}var Q=class r{name;opts;config;_nodes=new Map;_nodeToName=new WeakMap;_mounts=new Map;_parent=void 0;_storageDisposers=new Set;_disposers=new Set;_destroyed=!1;_topology;_topologyEmitters=new Set;_factory;_factoryArgs;constructor(e,t){if(e==="")throw new Error("Graph name must be non-empty");if(e.includes(D))throw new Error(`Graph name must not contain '${D}' (got "${e}")`);if(e===q)throw new Error(`Graph name "${q}" is reserved for meta companion paths`);this.name=e,this.opts=Object.freeze({...t??{}}),this.config=t?.config??ge,this._traceRing=new Oe(t?.traceCapacity??1e3),t?.versioning!=null&&this.setVersioning(t.versioning),typeof t?.factory=="string"&&(this._factory=t.factory,t.factoryArgs!==void 0&&(this._factoryArgs=t.factoryArgs))}tagFactory(e,t){return this._factory=e,this._factoryArgs=t,this}ancestors(e=!0){let t=[],n=e?this:this._parent;for(;n!=null;)t.push(n),n=n._parent;return t}get topology(){return this._topology==null&&(this._topology=dt(e=>{let t=n=>{e.emit(n)};return this._topologyEmitters.add(t),()=>{this._topologyEmitters.delete(t)}},{name:`${this.name}_topology`})),this._topology}_emitTopology(e){if(!(this._topology==null||this._topologyEmitters.size===0))for(let t of this._topologyEmitters)t(e)}nameOf(e){return this._nodeToName.get(e)}add(e,t){let n=e.name,s=t?.name??n;if(s==null||s==="")throw new Error(`Graph "${this.name}": graph.add requires a non-empty name \u2014 pass via opts.name or set it on the node (e.g. state(0, { name: "x" }))`);let o=s,i=t?.annotation;if(bt(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:j()})),e}setVersioning(e){if(e!=null)for(let t of this._nodes.values())t instanceof $&&t._applyVersioning(e)}remove(e){bt(e,this.name,"remove");let t=this._mounts.get(e);if(t){let o={kind:"mount",nodes:[],mounts:[]},i=[];t._collectObserveTargets("",i);for(let[a,d]of i)a.includes(`${D}${q}${D}`)||o.nodes.push(a);return o.nodes.sort(),o.mounts.push(e),o.mounts.push(...t._collectSubgraphs(`${e}${D}`)),this._mounts.delete(e),t._parent=void 0,rn(t),this._emitTopology({kind:"removed",name:e,nodeKind:"mount",audit:o}),o}let n=this._nodes.get(e);if(!n)throw new Error(`Graph "${this.name}": unknown node or mount "${e}"`);this._nodes.delete(e),this._nodeToName.delete(n),n.down([[L]],{internal:!0});let s={kind:"node",nodes:[e],mounts:[]};return this._emitTopology({kind:"removed",name:e,nodeKind:"node",audit:s}),s}removeAll(e){let t=typeof e=="function"?e:(()=>{let o=He(e);return i=>o.test(i)})(),n={kind:"mount",nodes:[],mounts:[]},s=[...this._nodes.keys(),...this._mounts.keys()].filter(o=>t(o));for(let o of s){let i=this.remove(o);n.nodes.push(...i.nodes),n.mounts.push(...i.mounts)}return n.nodes.sort(),n.mounts.sort(),n}[Symbol.iterator](){let e=[...this._nodes.keys()].sort(),t=this._nodes,n=0;return{[Symbol.iterator](){return this},next(){if(n>=e.length)return{value:void 0,done:!0};let s=e[n++];return{value:[s,t.get(s)],done:!1}}}}node(e){if(e==="")throw new Error(`Graph "${this.name}": node name must be non-empty`);if(e.includes(D))return this.resolve(e);let t=this._nodes.get(e);if(!t)throw new Error(`Graph "${this.name}": unknown node "${e}"`);return t}get(e){return this.node(e).cache}set(e,t,n){let s=n?.internal===!0;this.node(e).down([[M,t]],{actor:n?.actor,internal:s,delivery:"write"})}setAll(e,t){let n=Symbol.iterator in e?e:Object.entries(e);Ae(()=>{for(let[s,o]of n)this.set(s,o,t)})}invalidate(e,t){let n=t?.internal===!0;this.node(e).down([[Y]],{actor:t?.actor,internal:n,delivery:"write"})}error(e,t,n){let s=n?.internal===!0;this.node(e).down([[G,t]],{actor:n?.actor,internal:s,delivery:"write"})}complete(e,t){let n=t?.internal===!0;this.node(e).down([[z]],{actor:t?.actor,internal:n,delivery:"write"})}edges(e){let t=e?.recursive===!0,n=new Map;if(!t){for(let[d,u]of this._nodes)n.set(u,d);let a=[];for(let[d,u]of this._nodes)if(u instanceof $)for(let l of u._deps){let g=n.get(l.node);g!=null&&a.push([g,d])}return a.sort((d,u)=>d[0]<u[0]?-1:d[0]>u[0]?1:d[1]<u[1]?-1:d[1]>u[1]?1:0),a}let s=[];this._collectObserveTargets("",s);let o=new Map;for(let[a,d]of s)o.set(d,a);let i=[];for(let[a,d]of s)if(d instanceof $)for(let u of d._deps){let l=o.get(u.node);l!=null&&i.push([l,a])}return i.sort((a,d)=>a[0]<d[0]?-1:a[0]>d[0]?1:a[1]<d[1]?-1:a[1]>d[1]?1:0),i}mount(e,t){if(t===void 0){let s=new r(e);return this.mount(e,s)}if(typeof t=="function"){let s=new r(e);return t(s),this.mount(e,s)}let n=t;if(bt(e,this.name,"mount"),this._nodes.has(e))throw new Error(`Graph "${this.name}": cannot mount at "${e}" \u2014 node with that name exists`);if(this._mounts.has(e))throw new Error(`Graph "${this.name}": mount "${e}" already exists`);if(n===this)throw new Error(`Graph "${this.name}": cannot mount a graph into itself`);if(n._parent!=null)throw new Error(`Graph "${this.name}": this child graph is already mounted on "${n._parent.name}"`);for(let s=this;s!=null;s=s._parent)if(s===n)throw new Error(`Graph "${this.name}": mount("${e}", \u2026) would create a mount cycle`);return this._mounts.set(e,n),n._parent=this,this._emitTopology({kind:"added",name:e,nodeKind:"mount"}),n}resolve(e){let t=Hn(e,this.name);return this._resolveFromSegments(t)}tryResolve(e){try{return this.resolve(e)}catch{return}}_resolveFromSegments(e){let t=e;if(t[0]===this.name&&(t=t.slice(1),t.length===0))throw new Error(`Graph "${this.name}": resolve path ends at graph name only`);let n=t[0],s=t.slice(1);if(s.length===0){let a=this._nodes.get(n);if(a)return a;throw this._mounts.has(n)?new Error(`Graph "${this.name}": path ends at subgraph "${n}" \u2014 not a node (GRAPHREFLY-SPEC \xA73.5)`):new Error(`Graph "${this.name}": unknown name "${n}"`)}let o=this._nodes.get(n);if(o&&s.length>0&&s[0]===q)return this._resolveMetaChainFromNode(o,s,t.join(D));let i=this._mounts.get(n);if(!i)throw this._nodes.has(n)?new Error(`Graph "${this.name}": "${n}" is a node; trailing path "${s.join(D)}" is invalid`):new Error(`Graph "${this.name}": unknown mount or node "${n}"`);return i.resolve(s.join(D))}_resolveMetaChainFromNode(e,t,n){let s=e,o=0,i=[...t];for(;o<i.length;){if(i[o]!==q)throw new Error(`Graph "${this.name}": expected ${q} segment in meta path "${n}"`);if(o+1>=i.length)throw new Error(`Graph "${this.name}": meta path requires a key after ${q} in "${n}"`);let a=i[o+1],d=s.meta[a];if(!d)throw new Error(`Graph "${this.name}": unknown meta "${a}" in path "${n}"`);s=d,o+=2}return s}signal(e,t){if(t?.internal!==!0){for(let s of e)if(this.config.messageTier(s[0])===3)throw new Error(`Graph "${this.name}": Graph.signal() rejects tier-3 messages (DATA / RESOLVED). Broadcast is for control-plane tiers (START / DIRTY / INVALIDATE / PAUSE / RESUME / COMPLETE / ERROR / TEARDOWN). For per-node value writes, use Graph.set or graph.node(name).down(...).`)}let n=[];if(this._signalDeliver(e,t??{},new Set,n),n.length>0)throw n[0]}_signalDeliver(e,t,n,s){for(let d of this._mounts.values())d._signalDeliver(e,t,n,s);let i=t.internal===!0?{internal:!0}:{actor:t.actor,delivery:"signal"},a=zn(e,this.config);for(let d of[...this._nodes.keys()].sort()){let u=this._nodes.get(d);if(!n.has(u)){n.add(u);try{u.down(e,i)}catch(l){if(l instanceof U)throw l;s.push(l)}a.length!==0&&this._signalMetaSubtree(u,a,n,i,s)}}}_signalMetaSubtree(e,t,n,s,o){for(let i of Object.keys(e.meta).sort()){let a=e.meta[i];if(!n.has(a)){n.add(a);try{a.down(t,s)}catch(d){if(d instanceof U)throw d;o.push(d)}this._signalMetaSubtree(a,t,n,s,o)}}}describe(e){if(e?.reactive==="diff")return this._describeReactiveDiff(e);if(e?.reactive===!0)return this._describeReactive(e);let t=Gn(e?.actor),n=e?.filter;if(e?.detail!=null&&e?.fields!=null)throw new TypeError("Graph.describe(): pass either `detail` or `fields`, not both. `detail: 'spec'` is the canonical spec projection; use `fields` only when you need a custom subset.");let s=ft(e?.detail,e?.fields),o=e?.detail==="spec",i=s,a=[];this._collectObserveTargets("",a);let d=new Map;for(let[_,w]of a)d.set(w,_);let u=[];{let _=a.map(([,k])=>k),w=new Set(d.values()),x=0;for(;_.length>0;){let k=_.shift();if(k instanceof $)for(let E of k._deps){let N=E.node;if(d.has(N))continue;let S=N.name??"",T=S;if(!T||w.has(T))if(S){let I=2;for(;w.has(`${S}#${I}`);)I++;T=`${S}#${I}`}else for(T=`__internal__/${x++}`;w.has(T);)T=`__internal__/${x++}`;d.set(N,T),w.add(T),u.push([T,N]),_.push(N)}}}let l=[...a,...u],g={};for(let[_,w]of l){if(t!=null&&!w.allowsObserve(t))continue;let x=pt(w,i,o),k=w instanceof $?w._deps.map(T=>d.get(T.node)??T.node.name??""):[],{name:E,...N}=x,S={...N,deps:k};if(!o){let T=this._annotations.get(_);T!=null&&(S.annotation=T)}if(n!=null)if(typeof n=="function"){let T=n;if(!(T.length>=2?T(_,S):T(S)))continue}else{let T=!0;for(let[I,P]of Object.entries(n)){let A=I==="deps_includes"?"depsIncludes":I==="meta_has"?"metaHas":I;if(A==="depsIncludes"){if(!S.deps.includes(String(P))){T=!1;break}continue}if(A==="metaHas"){if(!Object.hasOwn(S.meta??{},String(P))){T=!1;break}continue}if(S[A]!==P){T=!1;break}}if(!T)continue}g[_]=S}let f=new Set(Object.keys(g)),p=[];for(let[_,w]of l)if(w instanceof $)for(let x of w._deps){let k=d.get(x.node);k!=null&&p.push([k,_])}p.sort((_,w)=>_[0]<w[0]?-1:_[0]>w[0]?1:_[1]<w[1]?-1:_[1]>w[1]?1:0);let c=p.map(([_,w])=>({from:_,to:w}));(t!=null||n!=null)&&(c=c.filter(_=>f.has(_.from)&&f.has(_.to)));let m=this._collectSubgraphs(""),h=t!=null||n!=null?m.filter(_=>{let w=`${_}${D}`;return[...f].some(x=>x===_||x.startsWith(w))}):m,v=this,b=e;return{name:this.name,nodes:g,edges:c,subgraphs:h,...this._factory!==void 0?{factory:this._factory}:{},...this._factoryArgs!==void 0?{factoryArgs:this._factoryArgs}:{},expand(_){let w={...b};return Array.isArray(_)?(w.fields=_,w.detail=void 0):(w.detail=_,w.fields=void 0),v.describe(w)}}}_collectSubgraphs(e){let t=[];for(let n of[...this._mounts.keys()].sort()){let s=e===""?n:`${e}${n}`;t.push(s),t.push(...this._mounts.get(n)._collectSubgraphs(`${s}${D}`))}return t}resourceProfile(e){return Jt(this,e)}reachable(e,t,n={}){return n.withDetail===!0?Te(this.describe(),e,t,{...n,withDetail:!0}):Te(this.describe(),e,t,n)}explain(e,t,n){return n?.reactive===!0?this._explainReactive(e,t,n):this._explainStatic(te(e),te(t),{...n?.maxDepth!==void 0?{maxDepth:Xt(n.maxDepth)}:{},...n?.findCycle!==void 0?{findCycle:Qt(n.findCycle)}:{}})}_explainStatic(e,t,n){let s=this.describe({detail:"full"}),o=new Map(this._annotations),i=new Map;for(let[a,d]of Object.entries(s.nodes))d.lastMutation!=null&&i.set(a,d.lastMutation);return Ht(s,e,t,{...n?.maxDepth!=null?{maxDepth:n.maxDepth}:{},...n?.findCycle===!0?{findCycle:!0}:{},annotations:o,lastMutations:i})}_describeReactive(e){let t={...e,reactive:!1},n=e.reactiveName??"describe",s=0,o=X(s,{name:`${n}_version`}),i=this.observe({timeline:!0,structured:!0}),a=!1,d=!1,u=()=>{a||d||(a=!0,fe(()=>{a=!1,!d&&(s+=1,o.emit(s))}))},l=i.onEvent(b=>{let y=b.type;y!=="data"&&y!=="error"&&y!=="complete"&&y!=="teardown"||u()}),g=[],f=new WeakSet,p=b=>{if(f.has(b)||d)return;f.add(b);let y=b.topology.subscribe(_=>{for(let w of _){if(w[0]!==M)continue;let x=w[1];if(u(),x.kind==="added"&&x.nodeKind==="mount"){let k=b._mounts.get(x.name);k!=null&&p(k)}}});g.push(y);for(let _ of b._mounts.keys()){let w=b._mounts.get(_);w!=null&&p(w)}};p(this);let c,m=e.actor;nn(m)&&(c=m.subscribe(b=>{let y=!1,_=!1;for(let w of b){let x=w[0];x===M?y=!0:(x===z||x===G||x===L)&&(_=!0)}y&&u(),_&&(c?.(),c=void 0,u())}));let h;try{h=me([o],()=>this.describe(t),{name:n,describeKind:"derived",meta:{domain:"audit",kind:"describe"},equals:(b,y)=>b===y})}catch(b){l(),c?.();for(let y of g)y();throw i.dispose(),b}let v=se(h);return{node:h,dispose(){d=!0,l(),c?.();for(let b of g)b();g.length=0,i.dispose(),v()}}}_describeReactiveDiff(e){let t={...e,reactive:!1},n=e.reactiveName??"describe-diff",s={name:this.name,nodes:{},edges:[],subgraphs:[]},o=this.describe(t),i=gt(s,o),a=X(i,{name:n,meta:{domain:"audit",kind:"describe-diff"},equals:(f,p)=>f===p}),d=this._describeReactive({...e,reactiveName:void 0}),u=!1,l=d.node.subscribe(f=>{if(!u)for(let p of f){if(p[0]!==M)continue;let c=p[1],m=gt(o,c);o=c,m.events.length!==0&&a.emit(m)}}),g=se(a);return{node:a,dispose(){u=!0,l(),d.dispose(),a.down([[L,"describe-diff disposed"]]),g()}}}_explainReactive(e,t,n){let s=0,o=X(s,{name:"explain_version"}),i=this.observe({timeline:!0,structured:!0}),a=!1,d=!1,u=()=>{a||d||(a=!0,fe(()=>{a=!1,!d&&(s+=1,o.emit(s))}))},l=i.onEvent(b=>{let y=b.type;y!=="data"&&y!=="error"&&y!=="complete"&&y!=="teardown"||u()}),g=[];e!=null&&ie(e)&&g.push(e),t!=null&&ie(t)&&g.push(t),n?.maxDepth!=null&&ie(n.maxDepth)&&g.push(n.maxDepth),n?.findCycle!=null&&ie(n.findCycle)&&g.push(n.findCycle);let f=()=>{for(let b of g)if(b.cache===void 0)return!1;return!0},p=()=>{let b=te(e),y=te(t);return{from:b,to:y,found:!1,reason:"pending",steps:[],text:"(awaiting reactive args)",toJSON:()=>({from:b,to:y,found:!1,reason:"pending",steps:[]})}},c;try{c=me([o],()=>{if(!f())return p();let b=te(e),y=te(t),_={...n?.maxDepth!==void 0?{maxDepth:Xt(n.maxDepth)}:{},...n?.findCycle!==void 0?{findCycle:Qt(n.findCycle)}:{}};return this._explainStatic(b,y,_)},{name:n?.name??"explain",describeKind:"derived",meta:{domain:"audit",kind:"explain_path",from:te(e),to:te(t)},equals:(b,y)=>b.found===y.found&&b.reason===y.reason&&b.steps.length===y.steps.length&&Bn(b.steps,y.steps)})}catch(b){throw l(),i.dispose(),b}let m=se(c),h=[],v=b=>{let y;return y=b.subscribe(_=>{let w=!1,x=!1;for(let k of _){let E=k[0];E===M?w=!0:(E===z||E===G||E===L)&&(x=!0)}(w||x)&&u(),x&&y&&(y(),y=void 0)}),()=>{y&&(y(),y=void 0)}};for(let b of g)h.push(v(b));return{node:c,dispose(){d=!0,l();for(let b of h)b?.();h.length=0,i.dispose(),m()}}}_pathsMatching(e){let t=He(e),n=[];return this._collectObserveTargets("",n),n.map(([s])=>s).filter(s=>t.test(s))}_collectObserveTargets(e,t){for(let n of[...this._mounts.keys()].sort()){let s=e===""?n:`${e}${D}${n}`;this._mounts.get(n)._collectObserveTargets(s,t)}for(let n of[...this._nodes.keys()].sort()){let s=this._nodes.get(n),o=e===""?n:`${e}${D}${n}`;t.push([o,s]),this._appendMetaObserveTargets(o,s,t)}}_appendMetaObserveTargets(e,t,n){for(let s of Object.keys(t.meta).sort()){let o=t.meta[s],i=`${e}${D}${q}${D}${s}`;n.push([i,o]),this._appendMetaObserveTargets(i,o,n)}}observe(e,t){let n=typeof e=="string",o=tn(n?t:e);if(o.reactive===!0)return this._observeReactive(n?e:void 0,o);let i=o.structured===!0||o.timeline===!0||o.causal===!0||o.derived===!0||o.detail==="minimal"||o.detail==="full"||o.format!=null,a=o.actor;if(n){let l=e,g=this.resolve(l);if(a!=null&&!g.allowsObserve(a))throw new U({actor:a,action:"observe",nodeName:l});return i?this._buildStructuredObserver([[l,g]],o,"one"):{subscribe(f){return g.subscribe(f)},up(f){try{g.up?.(f)}catch(p){if(p instanceof U)return;throw p}}}}let d=[];this._collectObserveTargets("",d),d.sort((l,g)=>l[0]<g[0]?-1:l[0]>g[0]?1:0);let u=a==null?d:d.filter(([,l])=>l.allowsObserve(a));return i?this._buildStructuredObserver(u,o,"all"):{subscribe:l=>{let g=u.map(([f,p])=>p.subscribe(c=>{l(f,c)}));return()=>{for(let f of g)f()}},up:(l,g)=>{try{this.resolve(l).up?.(g)}catch(f){if(f instanceof U)return;throw f}}}}_observeReactive(e,t){let n=t.tiers,s=n!=null?new Set(n):null,o=t.reactiveName??"observe";return dt(i=>{let a=[],d=!1,u=!1,l=()=>{if(a.length===0||u)return;let m={events:a.slice(),flushedAt_ns:j()};a.length=0,i.emit(m)},g={...t,reactive:!1,structured:!0,timeline:!0},f=e!=null?this.observe(e,g):this.observe(g),p=m=>{u||(a.push(m),!d&&(d=!0,fe(()=>{d=!1,l()})))};for(let m of f.events)p(m);let c=f.onEvent(p);return()=>{u=!0,c(),f.dispose()}},{name:o,meta:{domain:"audit",kind:"observe-reactive"}})}_buildStructuredObserver(e,t,n){let s=n==="one"?e[0]?.[0]:void 0,o=i=>{if(n==="one"&&s!=null){let l=this.resolve(s);return this._buildStructuredObserver([[s,l]],i,"one")}let a=[];this._collectObserveTargets("",a),a.sort((l,g)=>l[0]<g[0]?-1:l[0]>g[0]?1:0);let d=i.actor,u=d==null?a:a.filter(([,l])=>l.allowsObserve(d));return this._buildStructuredObserver(u,i,"all")};return this._createObserveResult(e,t,o)}_createObserveResult(e,t,n){let s=t.timeline===!0,o=t.causal===!0,i=t.derived===!0,a=t.detail==="minimal",d=this.config.inspectorEnabled,u=(o||i)&&d,l=t.maxEvents,g=l!=null&&l>0?new Oe(l):null,f=[],p=new Set,c=t.tiers!=null?new Set(t.tiers):null,m={},h=new Set,v=0,b=0,y=0,_=0,w=0,x=0,k=!1,E=!1,N=0,S=new Map,T=new Map,I=new Map,P=O=>{if(!(c!=null&&!c.has(O.type))){g?g.push(O):f.push(O);for(let C of p)C(O)}},A=O=>c==null||c.has(O),ae=()=>s?{timestamp_ns:j(),in_batch:Re(),batch_id:N}:{},Be=(O,C)=>{if(!(!u||!(O instanceof $)))return O._setInspectorHook(B=>{if(B.kind==="dep_message")S.set(O,B.depIndex);else if(B.kind==="run"){let be=B.batchData.map((R,H)=>R!=null&&R.length>0?R.at(-1):B.prevData[H]);T.set(O,be);let K=B.batchData.map(R=>R!=null?[...R]:void 0);I.set(O,K),i&&P({type:"derived",path:C,dep_values:be,dep_batches:K,...ae()})}})},ke=O=>{let C=S.get(O),B=T.get(O);if(!o||B==null)return{};let K=(C!=null&&C>=0&&O instanceof $?O._deps[C]:void 0)?.node,R=K?.v,H=I.get(O);return{trigger_dep_index:C,trigger_dep_name:K?.name,...R!=null?{trigger_version:{id:R.id,version:R.version}}:{},dep_values:[...B],...H!=null?{dep_batches:H}:{}}},yt=[],vt=[];for(let[O,C]of e){let B=Be(C,O);B&&yt.push(B),vt.push(C.subscribe(be=>{N++;for(let K of be){let R=K[0],H=ae();if(R===M){m[O]=K[1];let qe=C instanceof $?C.lastMutation?.actor??de:de;P({type:"data",path:O,data:K[1],actor:qe,...H,...ke(C)})}else if(a)R===W?A("dirty")&&v++:R===J?A("resolved")&&b++:R===Y?A("invalidate")&&y++:R===Z?A("pause")&&_++:R===ee?A("resume")&&w++:R===L?A("teardown")&&x++:R===z&&!h.has(O)?A("complete")&&(k=!0):R===G&&A("error")&&(E=!0,h.add(O));else if(R===W)A("dirty")&&v++,P({type:"dirty",path:O,...H});else if(R===J)A("resolved")&&b++,P({type:"resolved",path:O,...H,...ke(C)});else if(R===Y)A("invalidate")&&y++,P({type:"invalidate",path:O,...H});else if(R===Z)A("pause")&&_++,P({type:"pause",path:O,lockId:K[1],...H});else if(R===ee)A("resume")&&w++,P({type:"resume",path:O,lockId:K[1],...H});else if(R===z)A("complete")&&!h.has(O)&&(k=!0),P({type:"complete",path:O,...H});else if(R===G){A("error")&&(E=!0,h.add(O));let qe=C instanceof $?C.lastMutation?.actor??de:de;P({type:"error",path:O,data:K[1],actor:qe,...H})}else R===L&&(A("teardown")&&x++,P({type:"teardown",path:O,...H}))}}))}let Ke=!1,We=()=>{if(!Ke){Ke=!0;for(let O of vt)O();for(let O of yt)O();for(let O of Ee)O({value:void 0,done:!0});Ee.length=0}},Ue=[],Ee=[];p.add(O=>{let C=Ee.shift();C?C({value:O,done:!1}):Ue.push(O)});let _t={get values(){return m},get dirtyCount(){return v},get resolvedCount(){return b},get invalidateCount(){return y},get pauseCount(){return _},get resumeCount(){return w},get teardownCount(){return x},get events(){return g?g.toArray():[...f]},get anyCompletedCleanly(){return k},get anyErrored(){return E},get completedWithoutErrors(){return k&&!E},onEvent(O){return p.add(O),()=>p.delete(O)},dispose:We,expand(O){We();let C={...t};return typeof O=="string"?C.detail=O:Object.assign(C,O),n(tn(C))},[Symbol.asyncIterator](){return{next(){return Ue.length>0?Promise.resolve({value:Ue.shift(),done:!1}):Ke?Promise.resolve({value:void 0,done:!0}):new Promise(O=>Ee.push(O))},return(){return We(),Promise.resolve({value:void 0,done:!0})}}}};return t.format!=null&&this._attachFormatLogger(_t,t),_t}_attachFormatLogger(e,t){let n=t.format;if(n==null)return;let s=t.logger??(c=>console.log(c)),o=t.includeTypes?new Set(t.includeTypes):null,i=t.excludeTypes?new Set(t.excludeTypes):null,a=o==null&&i==null?()=>!0:c=>(o==null||o.has(c))&&(i==null||!i.has(c)),d=Vn(t.theme),u=n==="stage-log"?j():0,l=c=>c==null?"":t.stageLabels?.[c]??c,g=(c,m)=>c.length>m?`${c.slice(0,m-1)}\u2026`:c,f=c=>c.type==="data"||c.type==="error"?g(mt(c.data),120):"",p=c=>{if(n==="stage-log"){let k=(j()-u)/1e9,E=l(c.path).padEnd(9);if(c.type==="data"){let N=f(c);return`[${k.toFixed(3)}s] ${E} \u2190${N?` ${N}`:""}`}if(c.type==="error"){let N=f(c);return`[${k.toFixed(3)}s] ${E} \u2717${N?` ${N}`:""}`}return c.type==="complete"?`[${k.toFixed(3)}s] ${E} \u25A0 complete`:`[${k.toFixed(3)}s] ${E} ${c.type}`}if(n==="json")try{return JSON.stringify(c)}catch{return JSON.stringify({type:c.type,path:c.path,data:"[unserializable]"})}let m=d[c.type]??"",h=c.path?`${d.path}${c.path}${d.reset} `:"",v=c.type==="data"||c.type==="error",b=c.type==="pause"||c.type==="resume",y=v?` ${mt(c.data)}`:b?` ${mt(c.lockId)}`:"",_=c.type==="data"||c.type==="resolved"||c.type==="derived"?c:void 0,w=_?.trigger_dep_name!=null?` <- ${_.trigger_dep_name}`:_?.trigger_dep_index!=null?` <- #${_.trigger_dep_index}`:"",x=c.in_batch?" [batch]":"";return`${h}${m}${c.type.toUpperCase()}${d.reset}${y}${w}${x}`};e.onEvent(c=>{a(c.type)&&s(p(c),c)})}addDisposer(e){return this._disposers.add(e),()=>{this._disposers.delete(e)}}destroy(){Zt(this._disposers,this.name),this.signal([[L]],{internal:!0}),Zt(this._storageDisposers,this.name);for(let e of[...this._mounts.values()])e._parent=void 0,e._destroyClearOnly();this._mounts.clear(),this._nodes.clear(),this._parent=void 0,this._destroyed=!0}get destroyed(){return this._destroyed}_destroyClearOnly(){for(let e of[...this._mounts.values()])e._parent=void 0,e._destroyClearOnly();this._mounts.clear(),this._nodes.clear(),this._parent=void 0,this._destroyed=!0}snapshot(e){let{expand:t,...n}=this.describe({detail:"full"}),s={};for(let a of Object.keys(n.nodes).sort()){let{lastMutation:d,guard:u,...l}=n.nodes[a];s[a]=l}let o=[...n.subgraphs].sort(),i={...n,version:1,nodes:s,subgraphs:o};if(e?.format==null)return i;if(e.format==="json-string")return JSON.stringify(i);if(e.format==="bytes"){if(e.codec==null)throw new Error("snapshot({format: 'bytes'}) requires a `codec` name");let a=this.config.lookupCodec(e.codec);if(a==null)throw new Error(`snapshot: codec "${e.codec}" is not registered on this graph's config. Call config.registerCodec(...) before creating nodes.`);return Ot(a,a.encode(i))}throw new Error(`snapshot: unknown format "${String(e.format)}"`)}static decode(e,t){let n=t?.config??ge,{codec:s,codecVersion:o,payload:i}=Tt(e,n);return s.decode(i,o)}restore(e,t){if(en(e),e.name!==this.name)throw new Error(`Graph "${this.name}": restore snapshot name "${e.name}" does not match this graph`);let n=t?.only==null?null:(Array.isArray(t.only)?t.only:[t.only]).map(o=>He(o)),s=t?.includeProducers===!0;for(let o of Object.keys(e.nodes).sort()){if(n!==null&&!n.some(a=>a.test(o)))continue;let i=e.nodes[o];if(i!==void 0){if(!("value"in i)||i.value===void 0){"value"in i&&i.value===void 0&&t?.onError?.(o,new Error(`restore: slice.value is undefined for "${o}" (undefined is the global SENTINEL; not valid DATA)`));continue}if(!(i.type==="derived"||i.type==="effect")&&!(i.type==="producer"&&!s)){if(i.v!=null){let d=this.tryResolve(o)?.v;if(d!=null&&d.id===i.v.id&&d.version===i.v.version)continue}try{this.set(o,i.value)}catch(a){t?.onError?.(o,a)}}}}}static fromSnapshot(e,t){en(e);let n=typeof t=="function"?t:t?.build,s=typeof t=="function"?void 0:t?.factories,o=new r(e.name);if(n)return n(o),o.restore(e),o;for(let p of[...e.subgraphs].sort((c,m)=>{let h=c.split(D).length,v=m.split(D).length;return h!==v?h-v:c<m?-1:c>m?1:0})){let c=p.split(D),m=o;for(let h of c)m._mounts.has(h)||m.mount(h,new r(h)),m=m._mounts.get(h)}let i=s?Object.entries(s).map(([p,c])=>({re:He(p),factory:c})):[],a=p=>{for(let c of i)if(c.re.test(p))return c.factory},d=p=>{let c=p.split(D),m=c.pop();if(m==null||m.length===0)throw new Error(`invalid snapshot path "${p}"`);let h=o;for(let v of c){let b=h._mounts.get(v);if(!b)throw new Error(`unknown mount "${v}" in path "${p}"`);h=b}return[h,m]},u=Object.entries(e.nodes).filter(([p])=>!p.includes(`${D}${q}${D}`)).sort((p,c)=>p[0]<c[0]?-1:p[0]>c[0]?1:0),l=new Map(u),g=new Map,f=!0;for(;l.size>0&&f;){f=!1;for(let[p,c]of[...l.entries()]){let m=c?.deps??[];if(!m.every(w=>g.has(w)))continue;let[h,v]=d(p),b={...c?.meta??{}},y=a(p),_;if(c?.type==="state")_=X(c.value,{meta:b});else{if(y==null)continue;_=y(v,{path:p,type:c.type,value:c.value,meta:b,deps:m,resolvedDeps:m.map(w=>g.get(w))})}h.add(_,{name:v}),g.set(p,_),l.delete(p),f=!0}}if(l.size>0){let p=[...l.keys()].sort().join(", ");throw new Error(`Graph.fromSnapshot could not reconstruct nodes without build callback: ${p}. Pass matching factories via fromSnapshot(data, { factories: { pattern: factoryFn } }).`)}return o.restore(e),o}toJSON(){return this.snapshot()}attachSnapshotStorage(e,t={}){let n=e.map(u=>({tier:u,debounceMs:Math.max(0,u.debounceMs??0),compactEvery:Math.max(1,u.compactEvery??10),timer:void 0,seq:0,lastSnapshot:void 0,lastFingerprint:"",disposed:!1,savePending:void 0}));t.autoRestore===!0&&this._cascadeRestore(e,t.onError);let s=(u,l)=>{if(u.disposed)return;let g=Pn(l.nodes);if(u.lastSnapshot!=null&&g!==""&&g===u.lastFingerprint)return;let f=u.seq+1,p=Ne(),h=u.lastSnapshot==null||f%u.compactEvery===0?{name:this.name,mode:"full",snapshot:l,seq:f,timestamp_ns:p,format_version:oe}:{name:this.name,mode:"diff",diff:sn(u.lastSnapshot,l),seq:f,timestamp_ns:p,format_version:oe};if(u.tier.filter&&!u.tier.filter(h))return;let v;try{v=u.tier.save(h)}catch(b){t.onError?.(b,u.tier);return}if(v&&typeof v.then=="function"){let _=(u.savePending??Promise.resolve()).then(()=>v,()=>v).then(()=>{u.disposed||(u.seq=f,u.lastSnapshot=l,u.lastFingerprint=g)},w=>{t.onError?.(w,u.tier)});u.savePending=_.finally(()=>{u.savePending===_&&(u.savePending=void 0)})}else u.seq=f,u.lastSnapshot=l,u.lastFingerprint=g},o=(u,l)=>{try{s(u,l)}catch(g){t.onError?.(g,u.tier)}},i=(u,l)=>{if(!l.some(c=>{let m=this.config.messageTier(c[0]);return m>=3&&m<5}))return;if(t.filter){let c=this.tryResolve(u);if(c==null)return;let m=pt(c,ft("standard"));if(!t.filter(u,m))return}let f,p=()=>(f==null&&(f=this.snapshot()),f);for(let c of n)c.disposed||(c.debounceMs===0?o(c,p()):(c.timer==null&&(c.timer=new je),c.timer.start(c.debounceMs,()=>{c.disposed||o(c,this.snapshot())})))},a;if(t.paths!=null){let l=(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 l)g()}}else a=this.observe().subscribe((u,l)=>i(u,l));let d=()=>{a();for(let u of n)u.disposed=!0,u.timer?.cancel();this._storageDisposers.delete(d)};return this._storageDisposers.add(d),{dispose:d}}async _cascadeRestore(e,t){for(let n of e){let s;try{s=await n.load?.()}catch(i){t?.(i,n);continue}if(s==null||typeof s!="object"||Array.isArray(s))continue;let o=s;try{if(o.mode==="full"&&o.snapshot!=null)return this.restore(o.snapshot),!0;if(o.version===oe&&o.nodes!=null)return this.restore(o),!0}catch(i){t?.(i,n)}}return!1}static async fromStorage(e,t,n){for(let s of t){let o;try{o=await s.load?.()}catch(d){n?.onError?.(d,s);continue}if(o==null||typeof o!="object"||Array.isArray(o))continue;let i=o,a=i.mode==="full"&&i.snapshot!=null?i.snapshot:i.version===oe&&i.nodes!=null?i:void 0;if(a!=null)try{return r.fromSnapshot(a,n)}catch(d){n?.onError?.(d,s)}}throw new Error(`Graph.fromStorage: no tier held a restorable record for "${e}" across ${t.length} tier(s)`)}_annotations=new Map;_traceRing;trace(e,t,n){if(e!=null&&t!=null){if(this.tryResolve(e)==null)return;if(this._annotations.set(e,t),this.config.inspectorEnabled){let s={path:e,annotation:t,timestamp_ns:j(),...n?.actor!=null?{actor:n.actor}:{}};this._traceRing.push(s)}return}return e!=null?this.config.inspectorEnabled?this._annotations.get(e):void 0:this.config.inspectorEnabled?this._traceRing.toArray():[]}annotation(e){return this._annotations.get(e)}clearTrace(){this._annotations.clear(),this._traceRing.clear()}pruneTrace(e){let t=this._traceRing.toArray().filter(s=>!e(s)),n=this._traceRing.size-t.length;this._traceRing.clear();for(let s of t)this._traceRing.push(s);return n}static diff(e,t){let n=new Set(Object.keys(e.nodes)),s=new Set(Object.keys(t.nodes)),o=[...s].filter(b=>!n.has(b)).sort(),i=[...n].filter(b=>!s.has(b)).sort(),a=[],d=[];for(let b of n){if(!s.has(b))continue;let y=e.nodes[b],_=t.nodes[b],w=y.v,x=_.v;w!=null&&x!=null&&w.id===x.id&&w.version!==x.version&&d.push({path:b,id:w.id,from:w.version,to:x.version});let k=w!=null&&x!=null&&w.id===x.id&&w.version===x.version;for(let E of["type","status","sentinel"]){let N=y[E],S=_[E];N!==S&&a.push({path:b,field:E,from:N,to:S})}if(!k)for(let E of["value","meta"]){let N=y[E],S=_[E];$n(N,S)||a.push({path:b,field:E,from:N,to:S})}}let u=b=>`${b.from} ${b.to}`,l=new Set(e.edges.map(u)),g=new Set(t.edges.map(u)),f=t.edges.filter(b=>!l.has(u(b))),p=e.edges.filter(b=>!g.has(u(b))),c=new Set(e.subgraphs),m=new Set(t.subgraphs),h=[...m].filter(b=>!c.has(b)).sort(),v=[...c].filter(b=>!m.has(b)).sort();return{nodesAdded:o,nodesRemoved:i,nodesChanged:a,versionChanges:d,edgesAdded:f,edgesRemoved:p,subgraphsAdded:h,subgraphsRemoved:v}}};function sn(r,e){let t=Q.diff(r,e),n={};for(let s of t.nodesAdded){let o=e.nodes[s];o!=null&&(n[s]=o)}return{...t,nodesAddedFull:n}}function Te(r,e,t,n={}){let s={paths:[],depths:new Map,truncated:!1};if(!e)return n.withDetail?s:[];if(!n.both&&t!=="upstream"&&t!=="downstream")throw new Error('reachable: direction must be "upstream" or "downstream"');let o=n.maxDepth;if(o!=null&&(!Number.isInteger(o)||o<0))throw new Error("reachable: maxDepth must be an integer >= 0");if(o===0)return n.withDetail?s:[];let i=new Map,a=new Map,d=new Map,u=new Map,l=new Set;for(let[y,_]of Object.entries(r.nodes)){if(!y)continue;l.add(y);let w=_.deps??[];i.set(y,w);for(let x of w)x&&(l.add(x),a.has(x)||a.set(x,new Set),a.get(x).add(y))}for(let y of r.edges){if(y==null||typeof y!="object")continue;let _=typeof y.from=="string"?y.from:"",w=typeof y.to=="string"?y.to:"";!_||!w||(l.add(_),l.add(w),u.has(_)||u.set(_,new Set),u.get(_).add(w),d.has(w)||d.set(w,new Set),d.get(w).add(_))}if(!l.has(e))return n.withDetail?s:[];let g=n.both===!0,f=y=>{if(g){let k=i.get(y)??[],E=d.get(y),N=a.get(y),S=u.get(y),T=[...k];return E&&T.push(...E),N&&T.push(...N),S&&T.push(...S),T}if(t==="upstream"){let k=i.get(y)??[],E=d.get(y);return E?[...k,...E]:k}let _=a.get(y),w=u.get(y),x=_?[..._]:[];return w&&x.push(...w),x},p=new Set([e]),c=new Map,m=[{path:e,depth:0}],h=0,v=!1;for(;h<m.length;){let y=m[h++];if(o!=null&&y.depth>=o){f(y.path).length>0&&(v=!0);continue}for(let _ of f(y.path))!_||p.has(_)||(p.add(_),c.set(_,y.depth+1),m.push({path:_,depth:y.depth+1}))}let b=[...c.keys()].sort((y,_)=>y<_?-1:y>_?1:0);return n.withDetail?{paths:b,depths:c,truncated:v}:b}function Bn(r,e){if(r.length!==e.length)return!1;for(let t=0;t<r.length;t++){let n=r[t],s=e[t];if(n.path!==s.path||n.type!==s.type||n.status!==s.status||n.hop!==s.hop||n.dep_index!==s.dep_index||n.annotation!==s.annotation||n.value!==s.value||n.lastMutation!==s.lastMutation)return!1;let o=n.v,i=s.v;if(o!==i&&(o==null||i==null||o.id!==i.id||o.version!==i.version))return!1}return!0}he();function xe(r,e){let t=new Map,n=(s,o)=>{if(t.has(s))return;let i={off:()=>{},prefix:o};t.set(s,i);let a=s.topology.subscribe(d=>{for(let u of d){if(u[0]!==M)continue;let l=u[1];if(e(l,s,o),l.kind==="added"&&l.nodeKind==="mount"){let g=s._mounts.get(l.name);if(g instanceof Q){let f=`${o}${l.name}::`;n(g,f)}}else if(l.kind==="removed"&&l.nodeKind==="mount"){let g=`${o}${l.name}::`;for(let[f,p]of Array.from(t.entries()))f!==r&&p.prefix.startsWith(g)&&(p.off(),t.delete(f))}}});i.off=a;for(let[d,u]of s._mounts)if(u instanceof Q){let l=`${o}${d}::`;n(u,l)}};return n(r,""),()=>{for(let s of t.values())s.off();t.clear()}}function on(r){return Ft("lens",r)}function Kn(r){let e=Object.keys(r.nodes),t=new Map,n=new Map;for(let m of e){let h=r.nodes[m]?.deps??[];t.set(m,h);for(let v of h)n.has(v)||n.set(v,new Set),n.get(v).add(m)}let s=[],o=[];for(let m of e)(t.get(m)??[]).length===0&&s.push(m),n.has(m)||o.push(m);s.sort(),o.sort();let i=r.edges.length,a=0,d=1,u=2,l=new Map;for(let m of e)l.set(m,a);let g=!1,f=new Map,p=m=>{let h=l.get(m)??a;if(h===d)return g=!0,0;if(h===u)return f.get(m)??0;l.set(m,d);let v=0,b=n.get(m);if(b!=null)for(let y of b){let _=p(y);_+1>v&&(v=_+1)}return l.set(m,u),f.set(m,v),v},c=0;for(let m of s){let h=p(m);h>c&&(c=h)}for(let m of e)l.get(m)===a&&p(m);return{nodeCount:e.length,edgeCount:i,subgraphCount:r.subgraphs.length,sources:s,sinks:o,depth:c,hasCycles:g}}function Wn(r){let e=[];for(let[t,n]of Object.entries(r.nodes)){if(n.status!=="errored")continue;let s={path:t,status:"errored"},o=Te(r,t,"upstream",{});for(let i of o)if(i!==t&&r.nodes[i]?.status==="errored"){s.upstreamCause=i;break}e.push(s)}return e.sort((t,n)=>t.path<n.path?-1:t.path>n.path?1:0),{ok:e.length===0,problems:e}}function Un(r,e){return r.nodeCount===e.nodeCount&&r.edgeCount===e.edgeCount&&r.subgraphCount===e.subgraphCount&&r.depth===e.depth&&r.hasCycles===e.hasCycles&&an(r.sources,e.sources)&&an(r.sinks,e.sinks)}function qn(r,e){if(r.ok!==e.ok||r.problems.length!==e.problems.length)return!1;for(let t=0;t<r.problems.length;t++){let n=r.problems[t],s=e.problems[t];if(n.path!==s.path||n.status!==s.status||n.upstreamCause!==s.upstreamCause)return!1}return!0}function an(r,e){if(r.length!==e.length)return!1;for(let t=0;t<r.length;t++)if(r[t]!==e[t])return!1;return!0}var ze=class extends Q{stats;health;flow;_target;constructor(e,t={}){super(t.name??`${e.name}_lens`,t.graph),this._target=e;let n=0,s=0,o=X(0,{name:"stats_tick"}),i=X(0,{name:"health_tick"});this.add(o,{name:"stats_tick"}),this.add(i,{name:"health_tick"});let a={name:"flow"};t.maxFlowPaths!=null&&(a.maxSize=t.maxFlowPaths),this.flow=Lt(a),this.add(this.flow.entries,{name:"flow"});let d=t.pathFilter,u=xe(e,(f,p,c)=>{if(n+=1,o.emit(n),s+=1,i.emit(s),f.kind==="removed")if(f.nodeKind==="node"){let m=`${c}${f.name}`;this.flow.delete(m)}else{let m=`${c}${f.name}::`,h=[];for(let v of f.audit.nodes){let b=v===""?`${c}${f.name}`:`${m}${v}`;h.push(b)}h.length>0&&this.flow.deleteMany(h)}});this.addDisposer(u);let l=e.observe({timeline:!0,structured:!0}),g=l.onEvent(f=>{let p=f.type;if((p==="error"||p==="complete"||p==="data"||p==="teardown")&&(s+=1,i.emit(s)),p==="data"){let c=f.path??"";if(!c||d!=null&&!d(c))return;let m=this.flow.get(c),h=m!=null?m.count+1:1;this.flow.set(c,{path:c,count:h,lastUpdate_ns:j()})}});this.addDisposer(()=>{g(),l.dispose()}),this.stats=me([o],()=>Kn(e.describe({detail:"minimal"})),{name:"stats",describeKind:"derived",equals:Un,meta:on("stats")}),this.add(this.stats,{name:"stats"}),this.addDisposer(se(this.stats)),this.health=me([i],()=>Wn(e.describe({detail:"standard"})),{name:"health",describeKind:"derived",equals:qn,meta:on("health")}),this.add(this.health,{name:"health"}),this.addDisposer(se(this.health))}why(e,t,n){let s=this._target.explain(e,t,{reactive:!0,...n});return this.addDisposer(s.dispose),s}get target(){return this._target}};function Yn(r,e){return new ze(r,e)}0&&(module.exports={LensGraph,graphLens,watchTopologyTree});
|
|
@@ -1,8 +1,8 @@
|
|
|
1
|
-
import '../../node-
|
|
2
|
-
import '../../reactive-map-
|
|
3
|
-
import '../../graph-
|
|
4
|
-
export { w as watchTopologyTree } from '../../topology-tree-
|
|
5
|
-
export { F as FlowEntry, G as GraphLensOptions, H as HealthProblem, a as HealthReport, L as LensGraph, T as TopologyStats, g as graphLens } from '../../index-
|
|
6
|
-
import '../../meta-
|
|
1
|
+
import '../../node-BYInONRr.cjs';
|
|
2
|
+
import '../../reactive-map-B2qfD3hb.cjs';
|
|
3
|
+
import '../../graph-BUwMAxJI.cjs';
|
|
4
|
+
export { w as watchTopologyTree } from '../../topology-tree-B5Ngw3j0.cjs';
|
|
5
|
+
export { F as FlowEntry, G as GraphLensOptions, H as HealthProblem, a as HealthReport, L as LensGraph, T as TopologyStats, g as graphLens } from '../../index-CpLpJb6A.cjs';
|
|
6
|
+
import '../../meta-Ct9nqQS5.cjs';
|
|
7
7
|
import '../../extra/storage-core.cjs';
|
|
8
8
|
import '../../extra/storage-tiers.cjs';
|
|
@@ -1,8 +1,8 @@
|
|
|
1
|
-
import '../../node-
|
|
2
|
-
import '../../reactive-map-
|
|
3
|
-
import '../../graph-
|
|
4
|
-
export { w as watchTopologyTree } from '../../topology-tree-
|
|
5
|
-
export { F as FlowEntry, G as GraphLensOptions, H as HealthProblem, a as HealthReport, L as LensGraph, T as TopologyStats, g as graphLens } from '../../index-
|
|
6
|
-
import '../../meta-
|
|
1
|
+
import '../../node-BYInONRr.js';
|
|
2
|
+
import '../../reactive-map-jFIsE6Kt.js';
|
|
3
|
+
import '../../graph-30XSgtVX.js';
|
|
4
|
+
export { w as watchTopologyTree } from '../../topology-tree-BtvbgMXJ.js';
|
|
5
|
+
export { F as FlowEntry, G as GraphLensOptions, H as HealthProblem, a as HealthReport, L as LensGraph, T as TopologyStats, g as graphLens } from '../../index-Cey6VTnX.js';
|
|
6
|
+
import '../../meta-D8OyedKp.js';
|
|
7
7
|
import '../../extra/storage-core.js';
|
|
8
8
|
import '../../extra/storage-tiers.js';
|
|
@@ -1 +1 @@
|
|
|
1
|
-
import{a as b,b as c}from"../../chunk-
|
|
1
|
+
import{a as b,b as c}from"../../chunk-73PBQNST.js";import{a}from"../../chunk-R75BMDLA.js";import"../../chunk-3G5U5QNE.js";import"../../chunk-C72GO4IZ.js";import"../../chunk-L6NSJVJZ.js";import"../../chunk-7JRF5YEK.js";import"../../chunk-SGS4OJGS.js";import"../../chunk-ESMPEKEV.js";import"../../chunk-35JTVPOX.js";import"../../chunk-TZQPPQEQ.js";import"../../chunk-IA7DUNGB.js";import"../../chunk-LYCLF26R.js";import"../../chunk-CK2E7BTU.js";import"../../chunk-QYADASLV.js";export{b as LensGraph,c as graphLens,a as watchTopologyTree};
|