@graphrefly/graphrefly 0.28.0 → 0.30.0
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/dist/{cascading-D9WG1-9L.d.ts → cascading-BszPheHD.d.ts} +1 -1
- package/dist/{cascading-B-5zmAUv.d.cts → cascading-dNCtjW8j.d.cts} +1 -1
- package/dist/{chunk-OAWLCNJJ.js → chunk-2GQREQ6C.js} +1 -1
- package/dist/{chunk-DBGGMN3D.js → chunk-33FA6V4B.js} +1 -1
- package/dist/chunk-3NEPQO2E.js +43 -0
- package/dist/{chunk-UWJE5FQA.js → chunk-4C2OR2GH.js} +11 -11
- package/dist/chunk-4JJCCD5S.js +2 -0
- package/dist/{chunk-GHJJR5P4.js → chunk-4OFIQ66T.js} +1 -1
- package/dist/{chunk-PIOGHC63.js → chunk-567NWZ3T.js} +1 -1
- package/dist/chunk-5JDE5JHE.js +1 -0
- package/dist/{chunk-ETWTCCJI.js → chunk-5Z4HDCO6.js} +1 -1
- package/dist/{chunk-Y2EMPB3I.js → chunk-73Z3W2RN.js} +1 -1
- package/dist/{chunk-CRXTH3SH.js → chunk-7JDLFI6N.js} +1 -1
- package/dist/{chunk-DQA3UIQ2.js → chunk-7TDOES3L.js} +1 -1
- package/dist/{chunk-LBTDSCCO.js → chunk-AMBYCIOH.js} +1 -1
- package/dist/{chunk-D7A7DBE4.js → chunk-AUY2YKCO.js} +1 -1
- package/dist/{chunk-FNYWM6JC.js → chunk-AV3PIDFQ.js} +1 -1
- package/dist/{chunk-UMBIDLJ4.js → chunk-BA5URFYW.js} +1 -1
- package/dist/chunk-BKPLTBL5.js +1 -0
- package/dist/{chunk-UPXUCFMX.js → chunk-BZP5T4X6.js} +1 -1
- package/dist/{chunk-WQ2BN6X6.js → chunk-DDPYNMGG.js} +1 -1
- package/dist/{chunk-LQ3Y5NJS.js → chunk-GJR3P6JG.js} +1 -1
- package/dist/{chunk-3R5HFPX7.js → chunk-GLSM33ZM.js} +1 -1
- package/dist/{chunk-2FOAM3OR.js → chunk-GNCBXARM.js} +1 -1
- package/dist/{chunk-K2GNMCQT.js → chunk-ISCENNXS.js} +1 -1
- package/dist/{chunk-UPHHLMHE.js → chunk-IUK4EFCE.js} +1 -1
- package/dist/{chunk-ERLIRFPA.js → chunk-KA6MMXIY.js} +1 -1
- package/dist/{chunk-2PMCKKRK.js → chunk-KASHOCF5.js} +1 -1
- package/dist/chunk-LI3E75VE.js +64 -0
- package/dist/chunk-MGKAO4EK.js +7 -0
- package/dist/{chunk-ZV2DXV5A.js → chunk-NSG4C6BF.js} +1 -1
- package/dist/{chunk-4GKB4OUJ.js → chunk-OL33ZI6R.js} +1 -1
- package/dist/{chunk-76A3HVQE.js → chunk-P7JXGKDO.js} +1 -1
- package/dist/{chunk-U3AICJKU.js → chunk-RD52SNH2.js} +1 -1
- package/dist/{chunk-CWLN3X3N.js → chunk-SHYH5SXV.js} +1 -1
- package/dist/{chunk-VTPVOGHH.js → chunk-SLMYTGTU.js} +1 -1
- package/dist/{chunk-OYHGKYQM.js → chunk-T5SHIKJD.js} +1 -1
- package/dist/{chunk-VPYBOXVT.js → chunk-TWMEGG45.js} +1 -1
- package/dist/chunk-VIEUJSTT.js +1 -0
- package/dist/{chunk-SC3U7ETD.js → chunk-VWPRPPKR.js} +1 -1
- package/dist/chunk-W4TSQ6RJ.js +1 -0
- package/dist/{chunk-OBKQQA5I.js → chunk-WANIEEKV.js} +1 -1
- package/dist/{chunk-XAUNPIMX.js → chunk-XHVB6G6M.js} +1 -1
- package/dist/{chunk-MIQTDPY4.js → chunk-XQAXYVXX.js} +1 -1
- package/dist/{chunk-MTTAAPCK.js → chunk-Y32RJO24.js} +1 -1
- package/dist/{chunk-S35VARIR.js → chunk-Y36UZ5VS.js} +1 -1
- package/dist/compat/index.cjs +13 -12
- package/dist/compat/index.d.cts +14 -14
- package/dist/compat/index.d.ts +14 -14
- package/dist/compat/index.js +1 -1
- package/dist/compat/jotai/index.cjs +1 -1
- package/dist/compat/jotai/index.d.cts +2 -2
- package/dist/compat/jotai/index.d.ts +2 -2
- package/dist/compat/jotai/index.js +1 -1
- package/dist/compat/nanostores/index.cjs +1 -1
- package/dist/compat/nanostores/index.d.cts +2 -2
- package/dist/compat/nanostores/index.d.ts +2 -2
- package/dist/compat/nanostores/index.js +1 -1
- package/dist/compat/nestjs/index.cjs +13 -12
- package/dist/compat/nestjs/index.d.cts +6 -6
- package/dist/compat/nestjs/index.d.ts +6 -6
- 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 +7 -6
- 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-BhbKHbOS.d.ts → composite-DGspwCqk.d.ts} +2 -2
- package/dist/{composite-B-xqw4Kk.d.cts → composite-nrRumJ7l.d.cts} +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.cjs +1 -1
- package/dist/extra/browser.d.cts +1 -1
- package/dist/extra/browser.d.ts +1 -1
- package/dist/extra/browser.js +1 -1
- package/dist/extra/index.cjs +20 -19
- package/dist/extra/index.d.cts +9 -9
- package/dist/extra/index.d.ts +9 -9
- package/dist/extra/index.js +1 -1
- package/dist/extra/node.cjs +3 -3
- 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/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.cjs +1 -1
- package/dist/extra/storage-browser.d.cts +1 -1
- package/dist/extra/storage-browser.d.ts +1 -1
- package/dist/extra/storage-browser.js +1 -1
- package/dist/graph/index.cjs +7 -6
- 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-D48Qw9Cg.d.cts → graph-C4Uxwv0T.d.cts} +22 -6
- package/dist/{graph-BZGRXwOm.d.ts → graph-CWeI0aHd.d.ts} +22 -6
- package/dist/{index-u15meRxL.d.cts → index-9iguV3bF.d.cts} +2 -2
- package/dist/{index-DyxjtScX.d.cts → index-B-z8WaSd.d.cts} +2 -2
- package/dist/{index-BgyGlizc.d.ts → index-B2HBxvMb.d.ts} +4 -4
- package/dist/{index-CzobVSMr.d.ts → index-B5iVOD7w.d.ts} +2 -2
- package/dist/{index-rX8HBM5h.d.cts → index-B8Aj_z8S.d.cts} +2 -2
- package/dist/{index-D-YB-Vl3.d.ts → index-BANwzwBV.d.ts} +3 -3
- package/dist/{index-HDpJe9hX.d.ts → index-BBINVimG.d.ts} +3 -3
- package/dist/{index-8FSVk4Uf.d.ts → index-BEpRsvhg.d.ts} +4 -4
- package/dist/{index-CHEswufn.d.cts → index-BHu_Wba0.d.cts} +4 -4
- package/dist/{index-ZftwfxJM.d.ts → index-BJHQUCZx.d.ts} +7 -7
- package/dist/{index-DUqMOlKZ.d.cts → index-BS220yqj.d.cts} +7 -7
- package/dist/{index-BWJV63ti.d.ts → index-BX22kvjh.d.ts} +1 -1
- package/dist/{index-DfyOkTvs.d.ts → index-BXbQUn4n.d.ts} +2 -2
- package/dist/{index-O6TgGUBV.d.cts → index-BpFWP7Bq.d.cts} +3 -3
- package/dist/{index-BxJ86YZZ.d.cts → index-Bs3-LC83.d.cts} +3 -3
- package/dist/{index-DiOXyAwt.d.ts → index-Bvi5uJxX.d.ts} +1 -1
- package/dist/{index-Bqachn9_.d.ts → index-ByPnK85n.d.ts} +1 -1
- package/dist/{index-CRO83MmV.d.cts → index-BydMDMf7.d.cts} +1 -1
- package/dist/{index-ROpQmGjE.d.ts → index-C5Ghnp5B.d.ts} +3 -3
- package/dist/{index-umtoWT8K.d.ts → index-C6NBfXj-.d.ts} +6 -5
- package/dist/{index-pXrDMpRO.d.cts → index-C98oJsEs.d.cts} +2 -2
- package/dist/{index-B2pwesl9.d.cts → index-CDK5RsV5.d.cts} +1 -1
- package/dist/{index-Czq6ynh8.d.ts → index-CFW32Dy1.d.ts} +3 -3
- package/dist/{index-Cyojz0AE.d.cts → index-CIXaiYDE.d.cts} +1 -1
- package/dist/{index-Oi8d8w4R.d.cts → index-CRAkoq-y.d.cts} +1 -1
- package/dist/{index-CpgYhnrG.d.ts → index-Cc8VQIgL.d.ts} +2 -2
- package/dist/{index-vscRDkjW.d.cts → index-CcpEvuPl.d.cts} +2 -2
- package/dist/{index-BpA5c4G9.d.ts → index-CfFYyLR8.d.ts} +4 -4
- package/dist/{index-9oDeHH2u.d.cts → index-ClB7TCfL.d.cts} +2 -2
- package/dist/{index-BHvIquRZ.d.ts → index-ClgKmOHe.d.ts} +592 -492
- package/dist/{index-DpHe5e0Q.d.ts → index-CotRMjtJ.d.ts} +2 -2
- package/dist/{index-B1AmmSlb.d.ts → index-CrC7urhX.d.ts} +1 -1
- package/dist/{index-B0c4cmIO.d.ts → index-CvS9IuTG.d.ts} +2 -2
- package/dist/{index-rHJSKsU8.d.cts → index-Cy7eFeIX.d.cts} +2 -2
- package/dist/{index-BVHOrDwO.d.ts → index-D0C_USMR.d.ts} +1 -1
- package/dist/{index-DEwTb_fm.d.cts → index-D6ajK8Mh.d.cts} +592 -492
- package/dist/{index-DL-rYJrx.d.cts → index-D7XxY1Ff.d.cts} +1 -1
- package/dist/{index-DAlweici.d.ts → index-D9HrBx2J.d.ts} +2 -2
- package/dist/{index-fM6y00vT.d.cts → index-D9Y_u6BG.d.cts} +3 -3
- package/dist/{index-DcXZBF5a.d.cts → index-DBQUKh59.d.cts} +4 -4
- package/dist/{index-D_NwnRYS.d.cts → index-DDo-eqQ4.d.cts} +1 -1
- package/dist/{index-m-yHof5p.d.ts → index-DGb1awva.d.ts} +4 -4
- package/dist/{index-DxsnAMWD.d.cts → index-DR3gf_DG.d.cts} +9 -9
- package/dist/{index-dtN7YA2x.d.cts → index-DVNLe3pS.d.cts} +3 -3
- package/dist/{index-Btib9rsU.d.ts → index-Dljd76bC.d.ts} +275 -9
- package/dist/{index-DP4ZTkdw.d.ts → index-DnrZghBB.d.ts} +3 -3
- package/dist/{index-DaLJvH8Z.d.ts → index-Docdiu9a.d.ts} +3 -3
- package/dist/{index-BpIFjILY.d.cts → index-DylQCKEL.d.cts} +4 -4
- package/dist/{index-B_agccPe.d.cts → index-FBqTfL_S.d.cts} +1 -1
- package/dist/{index-DraikLjn.d.ts → index-FrYrV-Vf.d.ts} +2 -2
- package/dist/{index-sm373fsH.d.ts → index-IZ3l_vQ9.d.ts} +2 -2
- package/dist/{index-BwM9BEkt.d.ts → index-Ip3q9T9x.d.ts} +1 -1
- package/dist/{index-CloUk1kY.d.ts → index-RQg6lTrN.d.ts} +9 -9
- package/dist/{index-CEXXwWVH.d.cts → index-SSGqF8mI.d.cts} +2 -2
- package/dist/{index-rnwQly8X.d.cts → index-UZO988ox.d.cts} +6 -5
- package/dist/{index-C73n7lo-.d.cts → index-iBp74eGU.d.cts} +3 -3
- package/dist/{index-tbf2gKHd.d.cts → index-lKuLYmHO.d.cts} +3 -3
- package/dist/{index-CMn8S8Hw.d.ts → index-wIx1Jisk.d.ts} +1 -1
- package/dist/{index-cByzxQIC.d.cts → index-yIdWFo2b.d.cts} +4 -4
- package/dist/{index-RukJ4DLS.d.cts → index-ybtSyjWB.d.cts} +275 -9
- package/dist/index.cjs +53 -52
- package/dist/index.d.cts +42 -42
- package/dist/index.d.ts +42 -42
- package/dist/index.js +1 -1
- package/dist/{meta-CwesDrMD.d.ts → meta-BMwx3ExI.d.ts} +1 -1
- package/dist/{meta-Cgj6zeji.d.cts → meta-COtmHLwT.d.cts} +1 -1
- package/dist/{node-Cc1TniY8.d.ts → node-BVV7G1bq.d.cts} +59 -2
- package/dist/{node-Cc1TniY8.d.cts → node-BVV7G1bq.d.ts} +59 -2
- package/dist/{observable-glXQoGj2.d.cts → observable-BrUAPeH_.d.cts} +1 -1
- package/dist/{observable-Ct-gJ9jI.d.ts → observable-ITikPXz3.d.ts} +1 -1
- package/dist/patterns/ai/browser.d.cts +3 -3
- package/dist/patterns/ai/browser.d.ts +3 -3
- package/dist/patterns/ai/browser.js +1 -1
- package/dist/patterns/ai/index.cjs +25 -24
- package/dist/patterns/ai/index.d.cts +15 -15
- package/dist/patterns/ai/index.d.ts +15 -15
- package/dist/patterns/ai/index.js +1 -1
- package/dist/patterns/ai/node.d.cts +1 -1
- package/dist/patterns/ai/node.d.ts +1 -1
- package/dist/patterns/ai/node.js +1 -1
- package/dist/patterns/audit/index.cjs +7 -6
- package/dist/patterns/audit/index.d.cts +5 -5
- package/dist/patterns/audit/index.d.ts +5 -5
- package/dist/patterns/audit/index.js +1 -1
- package/dist/patterns/cqrs/index.cjs +7 -6
- package/dist/patterns/cqrs/index.d.cts +4 -4
- package/dist/patterns/cqrs/index.d.ts +4 -4
- package/dist/patterns/cqrs/index.js +1 -1
- package/dist/patterns/demo-shell/index.cjs +8 -7
- 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 +7 -6
- 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 +26 -25
- package/dist/patterns/graphspec/index.d.cts +4 -4
- package/dist/patterns/graphspec/index.d.ts +4 -4
- package/dist/patterns/graphspec/index.js +1 -1
- package/dist/patterns/guarded-execution/index.cjs +7 -6
- package/dist/patterns/guarded-execution/index.d.cts +6 -6
- package/dist/patterns/guarded-execution/index.d.ts +6 -6
- package/dist/patterns/guarded-execution/index.js +1 -1
- package/dist/patterns/harness/index.cjs +11 -10
- package/dist/patterns/harness/index.d.cts +10 -7
- package/dist/patterns/harness/index.d.ts +10 -7
- package/dist/patterns/harness/index.js +1 -1
- package/dist/patterns/job-queue/index.cjs +7 -6
- package/dist/patterns/job-queue/index.d.cts +4 -4
- package/dist/patterns/job-queue/index.d.ts +4 -4
- package/dist/patterns/job-queue/index.js +1 -1
- package/dist/patterns/lens/index.cjs +7 -6
- 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 +7 -6
- package/dist/patterns/memory/index.d.cts +4 -4
- package/dist/patterns/memory/index.d.ts +4 -4
- package/dist/patterns/memory/index.js +1 -1
- package/dist/patterns/messaging/index.cjs +7 -6
- package/dist/patterns/messaging/index.d.cts +4 -4
- package/dist/patterns/messaging/index.d.ts +4 -4
- package/dist/patterns/messaging/index.js +1 -1
- package/dist/patterns/orchestration/index.cjs +7 -6
- package/dist/patterns/orchestration/index.d.cts +5 -5
- package/dist/patterns/orchestration/index.d.ts +5 -5
- package/dist/patterns/orchestration/index.js +1 -1
- package/dist/patterns/reactive-layout/index.cjs +8 -7
- 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 +7 -6
- 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 +9 -8
- package/dist/patterns/refine-loop/index.d.cts +5 -5
- package/dist/patterns/refine-loop/index.d.ts +5 -5
- 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 +6 -6
- package/dist/patterns/resilient-pipeline/index.d.ts +6 -6
- package/dist/patterns/resilient-pipeline/index.js +1 -1
- package/dist/patterns/surface/index.cjs +14 -13
- package/dist/patterns/surface/index.d.cts +5 -5
- package/dist/patterns/surface/index.d.ts +5 -5
- package/dist/patterns/surface/index.js +1 -1
- package/dist/{reactive-layout-CpYb5qLP.d.cts → reactive-layout-5oEn8lHM.d.cts} +2 -2
- package/dist/{reactive-layout-D8u4wuUR.d.ts → reactive-layout-BAr6-_o5.d.ts} +2 -2
- package/dist/{reactive-log-DPzuUDj5.d.cts → reactive-log-5jFeNRmd.d.cts} +1 -1
- package/dist/{reactive-log-YuH9VYN8.d.ts → reactive-log-BOJDCI5x.d.ts} +1 -1
- package/dist/{reactive-map-CdbNoSgP.d.ts → reactive-map-BvDrRuwt.d.ts} +1 -1
- package/dist/{reactive-map-DUeRmb9d.d.cts → reactive-map-CmlPPKHN.d.cts} +1 -1
- package/dist/{resilience-CGRzhnD3.d.ts → resilience-CludlzcP.d.ts} +1 -1
- package/dist/{resilience-Ba5-b4WD.d.cts → resilience-Q6Bt_7y0.d.cts} +1 -1
- package/dist/{resilience-QAHKANT5.js → resilience-XRUF267O.js} +1 -1
- package/dist/{sugar-BV0htudb.d.cts → sugar-BHbAACDG.d.ts} +10 -12
- package/dist/{sugar-Dtyrq2_q.d.ts → sugar-CqR6DJ7v.d.cts} +10 -12
- package/dist/{topology-tree-DROUdq5B.d.cts → topology-tree-CVREibAc.d.cts} +1 -1
- package/dist/{topology-tree-CYHOwQZ_.d.ts → topology-tree-CkjojcB6.d.ts} +1 -1
- package/package.json +1 -1
- package/dist/chunk-6V3SEX2I.js +0 -1
- package/dist/chunk-7H6LGFUG.js +0 -64
- package/dist/chunk-CKCSDI7T.js +0 -6
- package/dist/chunk-QWAPKG3O.js +0 -2
- package/dist/chunk-RHESUC3V.js +0 -43
- package/dist/chunk-V6YQICXZ.js +0 -1
- package/dist/chunk-Z4HDAS2Q.js +0 -1
- package/dist/chunk-ZB5EHBIO.js +0 -1
package/dist/graph/index.cjs
CHANGED
|
@@ -1,6 +1,7 @@
|
|
|
1
|
-
"use strict";var Ye=Object.defineProperty;var Xt=Object.getOwnPropertyDescriptor;var Qt=Object.getOwnPropertyNames;var en=Object.prototype.hasOwnProperty;var z=(r,e)=>()=>(r&&(e=r(r=0)),e);var tn=(r,e)=>{for(var t in e)Ye(r,t,{get:e[t],enumerable:!0})},nn=(r,e,t,n)=>{if(e&&typeof e=="object"||typeof e=="function")for(let s of Qt(e))!en.call(r,s)&&s!==t&&Ye(r,s,{get:()=>e[s],enumerable:!(n=Xt(e,s))||n.enumerable});return r};var rn=r=>nn(Ye({},"__esModule",{value:!0}),r);function _t(r){return{name:"dag-cbor",version:1,contentType:"application/dag-cbor",encode:e=>r.encode(e),decode:(e,t)=>r.decode(e)}}function wt(r,e){return{name:"dag-cbor-zstd",version:1,contentType:"application/dag-cbor+zstd",encode:t=>e.compressSync(r.encode(t)),decode:(t,n)=>r.decode(e.decompressSync(t))}}function Oe(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++]=fe,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 Te(r,e){if(r.length<vt)throw new Error(`decodeEnvelope: bytes too short (${r.length} < ${vt})`);let t=0,n=r[t++];if(n!==fe)throw new Error(`decodeEnvelope: unsupported envelope version ${n} (expected ${fe})`);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 u=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:u}}function xe(r){r.registerCodec(Ze)}function Ot(r){if(r.length===0)throw new Error("WAL is empty \u2014 need at least one full snapshot");let e=r[0];if(e.mode!=="full")throw new Error("WAL must start with a full record carrying a baseline snapshot");let t=JSON.parse(JSON.stringify(e.snapshot)),n=e.seq;for(let s=1;s<r.length;s++){let o=r[s];if(o.seq<=n)throw new Error(`WAL chain broken at index ${s}: seq=${o.seq} must exceed prev seq=${n}`);if(o.mode==="full"){t=JSON.parse(JSON.stringify(o.snapshot)),n=o.seq;continue}let i=o.diff;for(let d of i.nodesRemoved)delete t.nodes[d];let u=i.nodesAddedFull;if(u!=null)for(let[d,a]of Object.entries(u))t.nodes[d]=JSON.parse(JSON.stringify(a));for(let d of i.nodesChanged){let a=t.nodes[d.path];a!=null&&(a[d.field]=d.to)}n=o.seq}return t}var Ze,fe,vt,ke=z(()=>{"use strict";Ze={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)}};fe=1,vt=4});function Ae(r){if(r==null)return se;let{type:e,id:t,...n}=r;return{type:e??"system",id:t??"",...n}}var se,Xe=z(()=>{"use strict";se={type:"system",id:""}});function Re(){return oe>0||pe}function Et(){return oe>0}function ge(r){oe>0?he.push(r):r()}function Nt(r){oe+=1;let e=!1;try{r()}catch(t){throw e=!0,t}finally{if(oe-=1,oe===0)if(e){if(!pe){let t=he.splice(0);for(let n of t)try{n()}catch{}ne.length=0,re.length=0,ie.length=0}}else cn()}}function cn(){let r=!pe;r&&(pe=!0);let e=[],t=0;try{for(;ne.length>0||re.length>0||ie.length>0||r&&he.length>0;){if(r&&he.length>0){let o=he.splice(0);for(let i of o)try{i()}catch(u){e.push(u)}continue}if(t+=1,t>1e3)throw ne.length=0,re.length=0,ie.length=0,new Error("batch drain exceeded 1000 iterations \u2014 likely a reactive cycle");let s=(ne.length>0?ne:re.length>0?re:ie).splice(0);for(let o of s)try{o()}catch(i){e.push(i)}}}finally{r&&(pe=!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 a=t(e[0][0]);if(a<3||!Re()){r(e);return}(a>=5?ie:a===4?re:ne).push(()=>r(e));return}let n=e.length,s=n,o=n,i=n,u=0;for(;u<n&&t(e[u][0])<3;)u++;for(s=u;u<n&&t(e[u][0])===3;)u++;for(o=u;u<n&&t(e[u][0])===4;)u++;i=u;let d=Re();if(s>0){let a=e.slice(0,s);r(a)}if(o>s){let a=e.slice(s,o);d?ne.push(()=>r(a)):r(a)}if(i>o){let a=e.slice(o,i);d?re.push(()=>r(a)):r(a)}if(n>i){let a=e.slice(i,n);d?ie.push(()=>r(a)):r(a)}}var oe,pe,ne,re,ie,he,Qe=z(()=>{"use strict";oe=0,pe=!1,ne=[],re=[],ie=[],he=[]});function ae(){return Math.trunc(performance.now()*1e6)}function Ge(){return Date.now()*1e6}var et=z(()=>{"use strict"});function tt(r){let e=ln.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,ln,Me=z(()=>{"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}},ln=["human","llm","wallet","system"]});var me,F,J,W,q,Z,Q,j,K,P,ue,nt,fn,rt,pn,hn,st,St,Dt,At,ot,de=z(()=>{"use strict";me=Symbol.for("graphrefly/START"),F=Symbol.for("graphrefly/DATA"),J=Symbol.for("graphrefly/DIRTY"),W=Symbol.for("graphrefly/RESOLVED"),q=Symbol.for("graphrefly/INVALIDATE"),Z=Symbol.for("graphrefly/PAUSE"),Q=Symbol.for("graphrefly/RESUME"),j=Symbol.for("graphrefly/TEARDOWN"),K=Symbol.for("graphrefly/COMPLETE"),P=Symbol.for("graphrefly/ERROR"),ue=Object.freeze([J]),nt=Object.freeze([W]),fn=Object.freeze([q]),rt=Object.freeze([me]),pn=Object.freeze([K]),hn=Object.freeze([j]),st=Object.freeze([ue]),St=Object.freeze([nt]),Dt=Object.freeze([fn]),At=Object.freeze([pn]),ot=Object.freeze([hn])});function Rt(r){r.registerMessageType(me,{tier:0,wireCrossing:!1}),r.registerMessageType(J,{tier:1,wireCrossing:!1}),r.registerMessageType(q,{tier:1,wireCrossing:!1,metaPassthrough:!1}),r.registerMessageType(Z,{tier:2,wireCrossing:!1}),r.registerMessageType(Q,{tier:2,wireCrossing:!1}),r.registerMessageType(F,{tier:3,wireCrossing:!0}),r.registerMessageType(W,{tier:3,wireCrossing:!0}),r.registerMessageType(K,{tier:4,wireCrossing:!0,metaPassthrough:!1}),r.registerMessageType(P,{tier:4,wireCrossing:!0,metaPassthrough:!1}),r.registerMessageType(j,{tier:5,wireCrossing:!0,metaPassthrough:!1})}var $e,Ct=z(()=>{"use strict";de();$e=class{_messageTypes=new Map;_codecs=new Map;_onMessage;_onSubscribe;_defaultVersioning;_defaultHashFn;_inspectorEnabled=!(typeof process<"u"&&process.env?.NODE_ENV==="production");_globalInspector;_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}registerMessageType(e,t){return this._assertUnfrozen(),this._messageTypes.set(e,{tier:t.tier,wireCrossing:t.wireCrossing??t.tier>=3,metaPassthrough:t.metaPassthrough??!0}),this}messageTier(e){let t=this._messageTypes.get(e);return t!=null?t.tier:1}isWireCrossing(e){let t=this._messageTypes.get(e);return t!=null?t.wireCrossing:!0}isLocalOnly(e){return!this.isWireCrossing(e)}isMetaPassthrough(e){let t=this._messageTypes.get(e);return t!=null?t.metaPassthrough:!0}isKnownMessageType(e){return this._messageTypes.has(e)}registerCodec(e){return this._assertUnfrozen(),this._codecs.set(e.name,e),this}lookupCodec(e){return this._codecs.get(e)}_isFrozen(){return this._frozen}_assertUnfrozen(){if(this._frozen)throw new Error("GraphReFlyConfig is frozen: a node has already captured this config. Register custom types and set hooks before creating any node.")}}});function it(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(it);if(typeof r=="object"&&r!==null){let e={};for(let t of Object.keys(r).sort())e[t]=it(r[t]);return e}return null}function bn(r){let e=mn.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 u=1779033703,d=3144134277,a=1013904242,c=2773480762,f=1359893119,h=2600822924,p=528734635,l=1541459225,g=new Uint32Array(64),b=(_,m)=>_>>>m|_<<32-m;for(let _=0;_<s;_+=64){for(let E=0;E<16;E++)g[E]=i.getUint32(_+E*4,!1);for(let E=16;E<64;E++){let D=g[E-15],N=g[E-2],I=b(D,7)^b(D,18)^D>>>3,Y=b(N,17)^b(N,19)^N>>>10;g[E]=g[E-16]+I+g[E-7]+Y>>>0}let m=u,y=d,x=a,w=c,O=f,k=h,S=p,$=l;for(let E=0;E<64;E++){let D=b(O,6)^b(O,11)^b(O,25),N=O&k^~O&S,I=$+D+N+gn[E]+g[E]>>>0,Y=b(m,2)^b(m,13)^b(m,22),X=m&y^m&x^y&x,ve=Y+X>>>0;$=S,S=k,k=O,O=w+I>>>0,w=x,x=y,y=m,m=I+ve>>>0}u=u+m>>>0,d=d+y>>>0,a=a+x>>>0,c=c+w>>>0,f=f+O>>>0,h=h+k>>>0,p=p+S>>>0,l=l+$>>>0}let v=_=>_.toString(16).padStart(8,"0");return v(u)+v(d)+v(a)+v(c)+v(f)+v(h)+v(p)+v(l)}function at(r){let e=it(r??null),t=JSON.stringify(e);return bn(t).slice(0,16)}function yn(){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 ut(r,e,t){let n=t?.id??yn();if(r===0)return{id:n,version:0};let o=(t?.hash??at)(e);return{id:n,version:0,cid:o,prev:null}}function Gt(r,e,t){r.version+=1,"cid"in r&&(r.prev=r.cid,r.cid=t(e))}var gn,mn,Mt=z(()=>{"use strict";gn=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]),mn=new TextEncoder});function Ft(r){return{node:r,unsub:null,prevData:void 0,dirty:!1,involvedThisWave:!1,dataBatch:[],terminal:void 0}}function dt(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 Fe(r,e,t){let n=It(r)?r:[],s=typeof r=="function"?r:typeof e=="function"?e:void 0,o={};return It(r)?o=(ct(e)?e:t)??{}:ct(r)?o=r:o=(ct(e)?e:t)??{},new M(n,s,o)}var $t,Pt,vn,_n,ce,M,It,ct,be=z(()=>{"use strict";ke();Xe();Qe();et();Ct();Me();de();Mt();$t=()=>{},Pt=100;vn=(r,e,t,n)=>{t.direction==="down-in"&&r._onDepMessage(t.depIndex,e)},_n=(r,e,t,n)=>{let s=r;if(s._status==="completed"||s._status==="errored")return;let o=s._cached,i=o===void 0?[rt]:[rt,[F,o]];s._status==="dirty"&&i.push(ue),Ce(e,i,s._config.tierOf)},ce=new $e({onMessage:vn,onSubscribe:_n});Rt(ce);xe(ce);M=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;_guard;_extraGuards;_hashFn;_versioning;_versioningLevel;_lastMutation;_inspectorHooks;_actions;constructor(e,t,n){this._config=n.config??ce,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._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??at;let s=n.versioning??this._config.defaultVersioning;this._versioningLevel=s,this._versioning=s!=null?ut(s,this._cached===void 0?void 0:this._cached,{id:n.versioningId,hash:this._hashFn}):void 0,this._deps=e.map(Ft);let o={};for(let[u,d]of Object.entries(n.meta??{})){let a={initial:d,name:`${n.name??"node"}:meta:${u}`,describeKind:"state",config:this._config};n.guard!=null&&(a.guard=n.guard),o[u]=new r([],void 0,a)}Object.freeze(o),this.meta=o,this._hasMeta=Object.keys(o).length>0;let i=this;this._actions={emit(u){i._emit([[F,u]])},down(u){i._emit(Pe(u))},up(u){i._emitUp(Pe(u))}},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,u=i?.id??t?.id,d=i?.version??0,a=ut(e,o,{id:u,hash:s});a.version=d,this._versioning=a,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=Ae(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=Ae(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:Ge()}}down(e,t){let n=Pe(e);n.length!==0&&(this._checkGuard(t),this._emit(n))}emit(e,t){this._checkGuard(t),this._emit([[F,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=Ae(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)dt(d)}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 u=!1;return()=>{u||(u=!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=$t,o.unsub=o.node.subscribe(i=>{if(o.unsub===null)return;let u=this._config.tierOf,d=!1;for(let a of i)u(a[0])>=3&&(d=!0),this._config.onMessage(this,a,{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{}dt(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=Ft(e);if(this._deps.push(n),this._sinks==null)return t;n.dirty=!0,this._dirtyDepCount++,this._status!=="dirty"&&this._emit(st),n.unsub=$t;try{n.unsub=e.subscribe(s=>{if(n.unsub===null)return;let o=this._config.tierOf,i=!1;for(let u of s)o(u[0])>=3&&(i=!0),this._config.onMessage(this,u,{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([[P,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([[P,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{}}dt(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!==me){if(s===J){this._depDirtied(n);return}if(s===q){this._depInvalidated(n),this._emit(Dt);return}if(s===Z||s===Q){this._emit([t]);return}if(s===j){this._emit(ot);return}if(s===F)this._depSettledAsData(n,t[1]);else if(s===W)this._depSettledAsResolved(n);else if(s===K)this._depSettledAsTerminal(n,!0);else if(s===P)this._depSettledAsTerminal(n,t[1]);else{this._emit([t]);return}if(!this._fn){(s===F||s===W)&&this._emit([t]),(s===K||s===P)&&this._maybeAutoTerminalAfterWave();return}}}_depDirtied(e){e.dirty||(e.dirty=!0,e.involvedThisWave=!0,this._dirtyDepCount++,this._status!=="dirty"&&this._emit(st))}_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._paused){this._pendingWave=!0;return}if(!this._waveHasNewData&&!this._hasNewTerminal&&this._hasCalledFnOnce){this._clearWaveFlags(),this._emit(St),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([[P,e.terminal]]);return}this._autoComplete&&this._deps.every(t=>t.terminal!==void 0)&&this._emit(At)}_execFn(){if(!this._fn||this._isTerminal&&!this._resubscribable)return;if(this._isExecutingFn){this._pendingRerun=!0;return}let e=this._cleanup;if(typeof e=="function"){this._cleanup=void 0;try{e()}catch(i){this._emit([[P,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(u){this._emit([[P,this._wrapFnError("cleanup.beforeRun threw",u)]]);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 u=t[i];u!=null&&u.length>0&&(this._deps[i].prevData=u[u.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 u of this._inspectorHooks)u(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 u=i;(typeof u.beforeRun=="function"||typeof u.deactivate=="function"||typeof u.invalidate=="function")&&(this._cleanup=i)}}catch(i){this._emit([[P,this._wrapFnError("fn threw",i)]])}finally{this._isExecutingFn=!1,this._pendingRerun?(this._pendingRerun=!1,this._rerunDepth+=1,this._rerunDepth>Pt?(this._rerunDepth=0,this._emit([[P,new Error(`Node "${this.name}": _pendingRerun depth exceeded ${Pt} \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"?[ue,e[0]]:e;let n=!0,s=!1,o=!1,i=-1;for(let d of e){let a=t(d[0]);a<i&&(n=!1),a===3&&(s=!0),d[0]===J&&(o=!0),i=a}let u=e;if(!n){let d=e.map((a,c)=>({m:a,i:c,tier:t(a[0])}));d.sort((a,c)=>a.tier-c.tier||a.i-c.i),u=d.map(a=>a.m)}if(s&&!o&&this._status!=="dirty"){let d=0;for(;d<u.length&&t(u[d][0])===0;)d++;return d===0?[ue,...u]:[...u.slice(0,d),ue,...u.slice(d)]}return u}_emit(e){if(e.length===0)return;let t=e;if(this._isTerminal&&!this._resubscribable){let u=e.filter(d=>d[0]===j||d[0]===q);if(u.length===0)return;t=u}t=this._frameBatch(t);let s=null;for(let u=0;u<t.length;u++){let d=t[u],a=d[0];if(a!==Z&&a!==Q){s?.push(d);continue}if(d.length<2)throw new Error(`Node "${this.name}": [[${a===Z?"PAUSE":"RESUME"}]] must carry a lockId payload \u2014 bare PAUSE/RESUME is a protocol violation (C0 rule). Use \`[[PAUSE, lockId]]\` / \`[[RESUME, lockId]]\`.`);let c=!0;if(this._pausable!==!1){let f=d[1];if(a===Z)this._pauseLocks==null&&(this._pauseLocks=new Set),this._pauseLocks.add(f),this._paused=!0,this._pausable==="resumeAll"&&this._pauseBuffer==null&&(this._pauseBuffer=[]);else if(this._pauseLocks==null||!this._pauseLocks.has(f))c=!1;else if(this._pauseLocks.delete(f),this._pauseLocks.size===0){if(this._paused=!1,this._pauseBuffer!=null&&this._pauseBuffer.length>0){let h=this._pauseBuffer;this._pauseBuffer=[],this._emit(h)}this._pendingWave&&(this._pendingWave=!1,this._maybeRunFnOnSettlement())}}c?s?.push(d):s==null&&(s=t.slice(0,u))}if(s!=null){if(s.length===0)return;t=s}if(this._hasMeta&&t.some(u=>u[0]===j))for(let u of Object.keys(this.meta))try{this.meta[u]._emit(ot)}catch{}let{finalMessages:o,equalsError:i}=this._updateState(t);if(o.length>0&&this._config.inspectorEnabled){let u=this._config.globalInspector;if(u!=null)try{u({kind:"emit",node:this,messages:o})}catch{}}if(o.length>0)if(this._paused&&this._pausable==="resumeAll"&&this._pauseBuffer!=null){let u=this._config.tierOf,d=[];for(let a of o){let c=u(a[0]);c<3||c===5?d.push(a):this._pauseBuffer.push(a)}d.length>0&&this._dispatchOrAccumulate(d)}else this._dispatchOrAccumulate(o);i!=null&&this._emit([[P,i]])}_updateState(e){let t=this._config.tierOf,n,s,o=-1,i=0;for(let c of e)t(c[0])===3&&i++;let u=i<=1,d=-1;if(this._versioning!=null&&i>1){for(let c=e.length-1;c>=0;c--)if(e[c][0]===F){d=c;break}}for(let c=0;c<e.length;c++){let f=e[c],h=f[0];if(h===F){if(f.length>=2){let p=!1;if(u&&this._cached!==void 0)try{p=this._equals(this._cached,f[1])}catch(l){s=this._wrapFnError("equals threw",l),o=c;break}if(p){n==null&&(n=e.slice(0,c)),n.push(nt),this._status="resolved";continue}this._cached=f[1],this._versioning!=null&&(d<0||c===d)&&Gt(this._versioning,f[1],this._hashFn)}this._status="settled",n?.push(f)}else if(n?.push(f),h===J)this._status="dirty";else if(h===W)this._status="resolved";else if(h===K)this._status="completed";else if(h===P)this._status="errored";else if(h===q){this._cached=void 0,this._status="dirty";let p=this._cleanup;if(typeof p=="function"){this._cleanup=void 0;try{p()}catch{}}else if(p!=null&&typeof p=="object"){let l=p.invalidate;if(typeof l=="function")try{l()}catch{}}}else h===j&&(this._resetOnTeardown&&(this._cached=void 0),this._deactivate(!0),this._status="sentinel")}let a=o>=0?n??e.slice(0,o):n??e;return s!=null?{finalMessages:a,equalsError:s}:{finalMessages:a}}_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(Et()){this._batchPendingMessages===null&&(this._batchPendingMessages=[],ge(()=>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)}},It=r=>Array.isArray(r),ct=r=>typeof r=="object"&&r!=null&&!Array.isArray(r)});function Tn(r,e,t){return t?!1:r.some((n,s)=>!(n!=null&&n.length>0)&&e.prevData[s]===void 0)}function Le(r,e){return Fe([],{...e,initial:r})}function Lt(r,e){return Fe((n,s,o)=>r(s,o)??void 0,{describeKind:"producer",...e})}function ft(r,e,t){let n=t?.partial??!1;return Fe(r,(o,i,u)=>{if(Tn(o,u,n)){i.down([[W]]);return}let d=o.map((a,c)=>a!=null&&a.length>0?a.at(-1):u.prevData[c]);i.emit(e(d,u))},{describeKind:"derived",...t})}var jt=z(()=>{"use strict";de();be()});function pt(r){return r.subscribe(()=>{})}var Vt=z(()=>{"use strict"});var je,Ht=z(()=>{"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 Vn={};tn(Vn,{ENVELOPE_VERSION:()=>fe,GRAPH_META_SEGMENT:()=>V,Graph:()=>te,JsonCodec:()=>Ze,SIZEOF_OVERHEAD:()=>G,SIZEOF_SYMBOL:()=>Je,SNAPSHOT_VERSION:()=>ee,createDagCborCodec:()=>_t,createDagCborZstdCodec:()=>wt,decodeEnvelope:()=>Te,diffForWAL:()=>bt,encodeEnvelope:()=>Oe,explainPath:()=>De,graphProfile:()=>Ve,mermaidLiveUrl:()=>mt,reachable:()=>ze,registerBuiltinCodecs:()=>xe,replayWAL:()=>Ot,sizeof:()=>we,validateGraphObservability:()=>Zt,watchTopologyTree:()=>Jt});module.exports=rn(Vn);var G={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},Je=Symbol.for("sizeof");function we(r){let e=new WeakSet,t=new WeakSet,n=[r],s=0;for(;n.length>0;){let o=n.pop();s+=sn(o,e,t,n)}return s}function sn(r,e,t,n){if(r==null)return 0;switch(typeof r){case"number":return G.number;case"boolean":return G.boolean;case"string":return G.string+r.length*2;case"bigint":return G.bigint+on(r);case"symbol":return G.symbol;case"function":return e.has(r)?0:(e.add(r),G.function);case"undefined":return 0}let o=r;if(e.has(o))return 0;e.add(o);let i=o[Je];if(typeof i=="function")try{let a=i.call(o);if(typeof a=="number"&&Number.isFinite(a))return a}catch{}if(o instanceof Date)return G.date;if(o instanceof RegExp)return G.regexp+o.source.length*2;if(o instanceof Error){let a=o.message?o.message.length*2:0,c=o.stack?o.stack.length*2:0;return G.error+a+c}if(typeof URL<"u"&&o instanceof URL)return G.url+o.href.length*2;if(typeof Promise<"u"&&o instanceof Promise)return G.promise;if(o instanceof WeakMap)return G.weakmap;if(o instanceof WeakSet)return G.weakset;if(o instanceof Map){let a=G.map;for(let[c,f]of o)a+=G.mapEntry,n.push(c),n.push(f);return a}if(o instanceof Set){let a=G.set;for(let c of o)a+=G.setEntry,n.push(c);return a}if(Array.isArray(o)){let a=G.array+o.length*8;for(let c of o)n.push(c);return a}if(o instanceof ArrayBuffer)return t.has(o)?0:(t.add(o),o.byteLength);if(ArrayBuffer.isView(o)){let a=o;return t.has(a.buffer)?48:(t.add(a.buffer),a.buffer.byteLength+48)}let u=G.object,d=Object.keys(o);for(let a of d){u+=G.string+a.length*2;try{n.push(o[a])}catch{}}return u}function on(r){let e=r<0n?-r:r;if(e===0n)return 0;let t=e.toString(2).length;return Math.ceil(t/32)*8}ke();function De(r,e,t,n={}){let s=e in r.nodes,o=t in r.nodes;if(!s)return Ee(e,t,"no-such-from");if(!o)return Ee(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 a=an(r,e,n);if(a!=null)return a}let d=Ne(e,r.nodes[e],0,n);return Se(e,t,[d])}if(i===0)return Ee(e,t,"no-path");let u=Tt(r,e,t,i);return u.found?Se(e,t,xt(r,u.pathOrder,n)):Ee(e,t,u.truncated?"max-depth-exceeded":"no-path")}function Tt(r,e,t,n){let s=new Map,o=[{path:t,depth:0}],i=new Set([t]),u=0,d=!1;for(;u<o.length;){let f=o[u++];if(f.path===e)break;if(n!=null&&f.depth>=n){let g=r.nodes[f.path];g?.deps&&g.deps.length>0&&(d=!0);continue}let h=r.nodes[f.path];if(h==null)continue;let p=h.deps??[],l=new Map;for(let g=0;g<p.length;g++){let b=p[g];if(!b)continue;let v=l.get(b);v==null&&(v=[],l.set(b,v)),v.push(g)}for(let[g,b]of l)i.has(g)||(i.add(g),s.set(g,{from:f.path,depIndices:b}),o.push({path:g,depth:f.depth+1}))}if(!s.has(e))return{found:!1,pathOrder:[],truncated:d};let a=[{path:e}],c=e;for(;c!==t;){let f=s.get(c);if(f==null)return{found:!1,pathOrder:[],truncated:!1};a[a.length-1].depIndices=f.depIndices,a.push({path:f.from}),c=f.from}return{found:!0,pathOrder:a,truncated:!1}}function an(r,e,t){let n=r.nodes[e];if(n==null)return null;let s=n.deps??[],o=[];for(let u=0;u<s.length;u++)s[u]===e&&o.push(u);if(o.length>0){let u=Ne(e,n,0,t);u.dep_index=o[0];let d=Ne(e,n,1,t);return Se(e,e,[u,d])}let i=null;for(let u=0;u<s.length;u++){let d=s[u];if(!d||d===e)continue;let a=Tt(r,d,e,t.maxDepth);a.found&&(i==null||a.pathOrder.length<i.pathOrder.length)&&(i=a,i={found:!0,pathOrder:[{path:e,depIndices:[u]},...a.pathOrder],truncated:!1})}return i==null?null:Se(e,e,xt(r,i.pathOrder,t))}function xt(r,e,t){return e.map((n,s)=>{let o=r.nodes[n.path],i=Ne(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 Ne(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 Se(r,e,t){return kt(r,e,!0,"ok",t)}function Ee(r,e,t){return kt(r,e,!1,t,[])}function kt(r,e,t,n,s){let o=un(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 un(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: ${dn(i.value)}`),i.annotation!=null&&o.push(` annotation: ${i.annotation}`),i.lastMutation!=null){let a=i.lastMutation.actor;o.push(` actor: ${a.type}${a.id?`:${a.id}`:""}`)}}return o.join(`
|
|
2
|
-
`)}function
|
|
3
|
-
`)}function zt(r){if(r.version!==ee)throw new Error(`unsupported snapshot version ${String(r.version)} (expected ${ee})`);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 kn(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 u=s.constructor,d=o.constructor;if(u!==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 h=o;if(s.length!==h.length)return!1;for(let p=0;p<s.length;p++)if(!n(s[p],h[p]))return!1;return!0}if(s instanceof Map){let h=o;if(s.size!==h.size)return!1;for(let[p,l]of s)if(!h.has(p)||!n(l,h.get(p)))return!1;return!0}if(s instanceof Set){let h=o;if(s.size!==h.size)return!1;for(let p of s){let l=!1;for(let g of h)if(n(p,g)){l=!0;break}if(!l)return!1}return!0}if(ArrayBuffer.isView(s)){let h=s,p=o;if(h.length!==p.length)return!1;for(let l=0;l<h.length;l++)if(h[l]!==p[l])return!1;return!0}let a=Object.keys(s),c=Object.keys(o);if(a.length!==c.length)return!1;let f=new Set(c);for(let h of a)if(!f.has(h)||!n(s[h],o[h]))return!1;return!0};return n(r,e)}function gt(r){if(r===null||typeof r!="object")return r;if(Array.isArray(r))return r.map(gt);let e=r,t=Object.keys(e).sort(),n={};for(let s of t)n[s]=gt(e[s]);return n}function En(r){return r.replaceAll("\\","\\\\").replaceAll('"','\\"')}function Nn(r){return r.replaceAll("\\","\\\\").replaceAll('"','\\"')}function Sn(r){return r==="TD"?"down":r==="BT"?"up":r==="RL"?"left":"right"}function Wt(r){let e=new Set,t=[];function n(s,o){let i=`${s}\0${o}`;e.has(i)||(e.add(i),t.push([s,o]))}for(let[s,o]of Object.entries(r.nodes)){let i=o.deps;if(i)for(let u of i)n(u,s)}for(let s of r.edges)n(s.from,s.to);return t}function qt(r){if(r===void 0)return"LR";if(r==="TD"||r==="LR"||r==="BT"||r==="RL")return r;throw new Error(`invalid diagram direction ${String(r)}; expected one of: TD, LR, BT, RL`)}function Dn(r,e){let t=e.includeEdges??!0,n=e.includeSubgraphs??!0,{expand:s,...o}=r,i={...o,edges:t?r.edges:[],subgraphs:n?r.subgraphs:[]},u=JSON.stringify(gt(i),null,e.indent??2);return e.logger?.(u),u}function An(r,e){let t=e.includeEdges??!0,n=e.includeSubgraphs??!0,s=[];s.push(`Graph ${r.name}`),s.push("Nodes:");for(let i of Object.keys(r.nodes).sort()){let u=r.nodes[i];s.push(`- ${i} (${u.type}/${u.status}): ${Be(u.value)}`)}if(t){s.push("Edges:");for(let i of r.edges)s.push(`- ${i.from} -> ${i.to}`)}if(n){s.push("Subgraphs:");for(let i of r.subgraphs)s.push(`- ${i}`)}let o=s.join(`
|
|
4
|
-
`);
|
|
5
|
-
`)
|
|
6
|
-
`)}function Gn(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+=Gn(n)}return e+="$",new RegExp(e)}var Mn={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"},$n={data:"",dirty:"",resolved:"",invalidate:"",pause:"",resume:"",complete:"",error:"",teardown:"",derived:"",path:"",reset:""};function Be(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 Pn(r){return r==="none"?$n:r==="ansi"||r==null?Mn:{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 Ut(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 Fn(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 ht(r,e,t){if(r==="")throw new Error(`Graph "${e}": ${t} name must be non-empty`);if(r.includes(C))throw new Error(`Graph "${e}": ${t} "${r}" must not contain '${C}' (path separator)`);if(r===V)throw new Error(`Graph "${e}": ${t} name "${V}" is reserved for meta companion paths`);Fn(r,e,t)}function In(r,e){if(r==="")throw new Error(`Graph "${e}": resolve path must be non-empty`);let t=r.split(C);for(let n of t)if(n==="")throw new Error(`Graph "${e}": resolve path has empty segment`);return t}function Ln(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 Yt(r){for(let e of r._mounts.values())Yt(e);for(let e of r._nodes.values())try{e.down([[j]],{internal:!0})}catch{}}var te=class r{name;opts;config;_nodes=new Map;_nodeToName=new WeakMap;_mounts=new Map;_parent=void 0;_storageDisposers=new Set;_disposers=new Set;_topology;_topologyEmitters=new Set;constructor(e,t){if(e==="")throw new Error("Graph name must be non-empty");if(e.includes(C))throw new Error(`Graph name must not contain '${C}' (got "${e}")`);if(e===V)throw new Error(`Graph name "${V}" is reserved for meta companion paths`);this.name=e,this.opts=Object.freeze({...t??{}}),this.config=t?.config??ce,this._traceRing=new ye(t?.traceCapacity??1e3),t?.versioning!=null&&this.setVersioning(t.versioning)}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=Lt(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)}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(ht(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 u=this._nodeToName.get(e);if(u!==void 0)throw new Error(`Graph "${this.name}": node instance already registered as "${u}"`);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:ae()})),e}setVersioning(e){if(e!=null)for(let t of this._nodes.values())t instanceof M&&t._applyVersioning(e)}remove(e){ht(e,this.name,"remove");let t=this._mounts.get(e);if(t){let o={kind:"mount",nodes:[],mounts:[]},i=[];t._collectObserveTargets("",i);for(let[u,d]of i)u.includes(`${C}${V}${C}`)||o.nodes.push(u);return o.nodes.sort(),o.mounts.push(e),o.mounts.push(...t._collectSubgraphs(`${e}${C}`)),this._mounts.delete(e),t._parent=void 0,Yt(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([[j]],{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(C))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([[F,t]],{actor:n?.actor,internal:s,delivery:"write"})}setAll(e,t){let n=Symbol.iterator in e?e:Object.entries(e);Nt(()=>{for(let[s,o]of n)this.set(s,o,t)})}invalidate(e,t){let n=t?.internal===!0;this.node(e).down([[q]],{actor:t?.actor,internal:n,delivery:"write"})}error(e,t,n){let s=n?.internal===!0;this.node(e).down([[P,t]],{actor:n?.actor,internal:s,delivery:"write"})}complete(e,t){let n=t?.internal===!0;this.node(e).down([[K]],{actor:t?.actor,internal:n,delivery:"write"})}edges(e){let t=e?.recursive===!0,n=new Map;if(!t){for(let[d,a]of this._nodes)n.set(a,d);let u=[];for(let[d,a]of this._nodes)if(a instanceof M)for(let c of a._deps){let f=n.get(c.node);f!=null&&u.push([f,d])}return u.sort((d,a)=>d[0]<a[0]?-1:d[0]>a[0]?1:d[1]<a[1]?-1:d[1]>a[1]?1:0),u}let s=[];this._collectObserveTargets("",s);let o=new Map;for(let[u,d]of s)o.set(d,u);let i=[];for(let[u,d]of s)if(d instanceof M)for(let a of d._deps){let c=o.get(a.node);c!=null&&i.push([c,u])}return i.sort((u,d)=>u[0]<d[0]?-1:u[0]>d[0]?1:u[1]<d[1]?-1:u[1]>d[1]?1:0),i}mount(e,t){if(ht(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(t===this)throw new Error(`Graph "${this.name}": cannot mount a graph into itself`);if(t._parent!=null)throw new Error(`Graph "${this.name}": this child graph is already mounted on "${t._parent.name}"`);for(let n=this;n!=null;n=n._parent)if(n===t)throw new Error(`Graph "${this.name}": mount("${e}", \u2026) would create a mount cycle`);return this._mounts.set(e,t),t._parent=this,this._emitTopology({kind:"added",name:e,nodeKind:"mount"}),t}resolve(e){let t=In(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 u=this._nodes.get(n);if(u)return u;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]===V)return this._resolveMetaChainFromNode(o,s,t.join(C));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(C)}" is invalid`):new Error(`Graph "${this.name}": unknown mount or node "${n}"`);return i.resolve(s.join(C))}_resolveMetaChainFromNode(e,t,n){let s=e,o=0,i=[...t];for(;o<i.length;){if(i[o]!==V)throw new Error(`Graph "${this.name}": expected ${V} segment in meta path "${n}"`);if(o+1>=i.length)throw new Error(`Graph "${this.name}": meta path requires a key after ${V} in "${n}"`);let u=i[o+1],d=s.meta[u];if(!d)throw new Error(`Graph "${this.name}": unknown meta "${u}" 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"},u=Ln(e,this.config);for(let d of[...this._nodes.keys()].sort()){let a=this._nodes.get(d);if(!n.has(a)){n.add(a);try{a.down(e,i)}catch(c){if(c instanceof U)throw c;s.push(c)}u.length!==0&&this._signalMetaSubtree(a,u,n,i,s)}}}_signalMetaSubtree(e,t,n,s,o){for(let i of Object.keys(e.meta).sort()){let u=e.meta[i];if(!n.has(u)){n.add(u);try{u.down(t,s)}catch(d){if(d instanceof U)throw d;o.push(d)}this._signalMetaSubtree(u,t,n,s,o)}}}describe(e){if(e?.reactive===!0)return this._describeReactive(e);let t=e?.actor,n=e?.filter,s=Ie(e?.detail,e?.fields),o=e?.format==="spec",i=o?Ie("minimal"):s,u=[];this._collectObserveTargets("",u);let d=new Map;for(let[w,O]of u)d.set(O,w);let a=[];{let w=u.map(([,S])=>S),O=new Set(d.values()),k=0;for(;w.length>0;){let S=w.shift();if(S instanceof M)for(let $ of S._deps){let E=$.node;if(d.has(E))continue;let D=E.name??"",N=D;if(!N||O.has(N))if(D){let I=2;for(;O.has(`${D}#${I}`);)I++;N=`${D}#${I}`}else for(N=`__internal__/${k++}`;O.has(N);)N=`__internal__/${k++}`;d.set(E,N),O.add(N),a.push([N,E]),w.push(E)}}}let c=[...u,...a],f={};for(let[w,O]of c){if(t!=null&&!O.allowsObserve(t))continue;let k=lt(O,i),S=O instanceof M?O._deps.map(N=>d.get(N.node)??N.node.name??""):[],{name:$,...E}=k,D={...E,deps:S};if(!o){let N=this._annotations.get(w);N!=null&&(D.annotation=N)}if(n!=null)if(typeof n=="function"){let N=n;if(!(N.length>=2?N(w,D):N(D)))continue}else{let N=!0;for(let[I,Y]of Object.entries(n)){let X=I==="deps_includes"?"depsIncludes":I==="meta_has"?"metaHas":I;if(X==="depsIncludes"){if(!D.deps.includes(String(Y))){N=!1;break}continue}if(X==="metaHas"){if(!Object.hasOwn(D.meta??{},String(Y))){N=!1;break}continue}if(D[X]!==Y){N=!1;break}}if(!N)continue}f[w]=D}let h=new Set(Object.keys(f)),p=[];for(let[w,O]of c)if(O instanceof M)for(let k of O._deps){let S=d.get(k.node);S!=null&&p.push([S,w])}p.sort((w,O)=>w[0]<O[0]?-1:w[0]>O[0]?1:w[1]<O[1]?-1:w[1]>O[1]?1:0);let l=p.map(([w,O])=>({from:w,to:O}));(t!=null||n!=null)&&(l=l.filter(w=>h.has(w.from)&&h.has(w.to)));let g=this._collectSubgraphs(""),b=t!=null||n!=null?g.filter(w=>{let O=`${w}${C}`;return[...h].some(k=>k===w||k.startsWith(O))}):g,v=this,_=e,m={name:this.name,nodes:f,edges:l,subgraphs:b,expand(w){let O={..._,format:void 0};return Array.isArray(w)?(O.fields=w,O.detail=void 0):(O.detail=w,O.fields=void 0),v.describe(O)}},y=e??{},x=y.format;return x==="json"?Dn(m,y):x==="pretty"?An(m,y):x==="mermaid"?Kt(m,y):x==="mermaid-url"?Rn(m,y):x==="d2"?Cn(m,y):m}_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}${C}`))}return t}resourceProfile(e){return Ve(this,e)}reachable(e,t,n={}){return n.withDetail===!0?ze(this.describe(),e,t,{...n,withDetail:!0}):ze(this.describe(),e,t,n)}explain(e,t,n){return n?.reactive===!0?this._explainReactive(e,t,n):this._explainStatic(e,t,n)}_explainStatic(e,t,n){let s=this.describe({detail:"full"}),o=new Map(this._annotations),i=new Map;for(let[u,d]of Object.entries(s.nodes))d.lastMutation!=null&&i.set(u,d.lastMutation);return De(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=Le(s,{name:`${n}_version`}),i=this.observe({timeline:!0,structured:!0}),u=!1,d=!1,a=()=>{u||d||(u=!0,ge(()=>{u=!1,!d&&(s+=1,o.emit(s))}))},c=i.onEvent(b=>{let v=b.type;v!=="data"&&v!=="error"&&v!=="complete"&&v!=="teardown"||a()}),f=[],h=new WeakSet,p=b=>{if(h.has(b)||d)return;h.add(b);let v=b.topology.subscribe(_=>{for(let m of _){if(m[0]!==F)continue;let y=m[1];if(a(),y.kind==="added"&&y.nodeKind==="mount"){let x=b._mounts.get(y.name);x!=null&&p(x)}}});f.push(v);for(let _ of b._mounts.keys()){let m=b._mounts.get(_);m!=null&&p(m)}};p(this);let l;try{l=ft([o],()=>this.describe(t),{name:n,describeKind:"derived",meta:{domain:"audit",kind:"describe"},equals:(b,v)=>b===v})}catch(b){c();for(let v of f)v();throw i.dispose(),b}let g=pt(l);return{node:l,dispose(){d=!0,c();for(let b of f)b();f.length=0,i.dispose(),g()}}}_explainReactive(e,t,n){let s=0,o=Le(s,{name:"explain_version"}),i=this.observe({timeline:!0,structured:!0}),u=!1,d=!1,a=i.onEvent(p=>{let l=p.type;l!=="data"&&l!=="error"&&l!=="complete"&&l!=="teardown"||u||d||(u=!0,ge(()=>{u=!1,!d&&(s+=1,o.emit(s))}))}),c={...n?.maxDepth!=null?{maxDepth:n.maxDepth}:{},...n?.findCycle===!0?{findCycle:!0}:{}},f;try{f=ft([o],()=>this._explainStatic(e,t,c),{name:n?.name??"explain",describeKind:"derived",meta:{domain:"audit",kind:"explain_path",from:e,to:t},equals:(p,l)=>p.found===l.found&&p.reason===l.reason&&p.steps.length===l.steps.length&&jn(p.steps,l.steps)})}catch(p){throw a(),i.dispose(),p}let h=pt(f);return{node:f,dispose(){d=!0,a(),i.dispose(),h()}}}_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}${C}${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}${C}${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}${C}${V}${C}${s}`;n.push([i,o]),this._appendMetaObserveTargets(i,o,n)}}observe(e,t){let n=typeof e=="string",o=Ut(n?t:e),i=o.structured===!0||o.timeline===!0||o.causal===!0||o.derived===!0||o.detail==="minimal"||o.detail==="full"||o.format!=null,u=o.actor;if(n){let c=e,f=this.resolve(c);if(u!=null&&!f.allowsObserve(u))throw new U({actor:u,action:"observe",nodeName:c});return i?this._buildStructuredObserver([[c,f]],o,"one"):{subscribe(h){return f.subscribe(h)},up(h){try{f.up?.(h)}catch(p){if(p instanceof U)return;throw p}}}}let d=[];this._collectObserveTargets("",d),d.sort((c,f)=>c[0]<f[0]?-1:c[0]>f[0]?1:0);let a=u==null?d:d.filter(([,c])=>c.allowsObserve(u));return i?this._buildStructuredObserver(a,o,"all"):{subscribe:c=>{let f=a.map(([h,p])=>p.subscribe(l=>{c(h,l)}));return()=>{for(let h of f)h()}},up:(c,f)=>{try{this.resolve(c).up?.(f)}catch(h){if(h instanceof U)return;throw h}}}}_buildStructuredObserver(e,t,n){let s=n==="one"?e[0]?.[0]:void 0,o=i=>{if(n==="one"&&s!=null){let c=this.resolve(s);return this._buildStructuredObserver([[s,c]],i,"one")}let u=[];this._collectObserveTargets("",u),u.sort((c,f)=>c[0]<f[0]?-1:c[0]>f[0]?1:0);let d=i.actor,a=d==null?u:u.filter(([,c])=>c.allowsObserve(d));return this._buildStructuredObserver(a,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,u=t.detail==="minimal",d=this.config.inspectorEnabled,a=(o||i)&&d,c=t.maxEvents,f=c!=null&&c>0?new ye(c):null,h=[],p=new Set,l={},g=new Set,b=0,v=0,_=0,m=0,y=0,x=0,w=!1,O=!1,k=0,S=new Map,$=new Map,E=new Map,D=T=>{f?f.push(T):h.push(T);for(let R of p)R(T)},N=()=>s?{timestamp_ns:ae(),in_batch:Re(),batch_id:k}:{},I=(T,R)=>{if(!(!a||!(T instanceof M)))return T._setInspectorHook(H=>{if(H.kind==="dep_message")S.set(T,H.depIndex);else if(H.kind==="run"){let le=H.batchData.map((A,L)=>A!=null&&A.length>0?A.at(-1):H.prevData[L]);$.set(T,le);let B=H.batchData.map(A=>A!=null?[...A]:void 0);E.set(T,B),i&&D({type:"derived",path:R,dep_values:le,dep_batches:B,...N()})}})},Y=T=>{let R=S.get(T),H=$.get(T);if(!o||H==null)return{};let B=(R!=null&&R>=0&&T instanceof M?T._deps[R]:void 0)?.node,A=B?.v,L=E.get(T);return{trigger_dep_index:R,trigger_dep_name:B?.name,...A!=null?{trigger_version:{id:A.id,version:A.version}}:{},dep_values:[...H],...L!=null?{dep_batches:L}:{}}},X=[],ve=[];for(let[T,R]of e){let H=I(R,T);H&&X.push(H),ve.push(R.subscribe(le=>{k++;for(let B of le){let A=B[0],L=N();if(A===F){l[T]=B[1];let Ke=R instanceof M?R.lastMutation?.actor??se:se;D({type:"data",path:T,data:B[1],actor:Ke,...L,...Y(R)})}else if(u)A===J?b++:A===W?v++:A===q?_++:A===Z?m++:A===Q?y++:A===j?x++:A===K&&!g.has(T)?w=!0:A===P&&(O=!0,g.add(T));else if(A===J)b++,D({type:"dirty",path:T,...L});else if(A===W)v++,D({type:"resolved",path:T,...L,...Y(R)});else if(A===q)_++,D({type:"invalidate",path:T,...L});else if(A===Z)m++,D({type:"pause",path:T,lockId:B[1],...L});else if(A===Q)y++,D({type:"resume",path:T,lockId:B[1],...L});else if(A===K)g.has(T)||(w=!0),D({type:"complete",path:T,...L});else if(A===P){O=!0,g.add(T);let Ke=R instanceof M?R.lastMutation?.actor??se:se;D({type:"error",path:T,data:B[1],actor:Ke,...L})}else A===j&&(x++,D({type:"teardown",path:T,...L}))}}))}let Ue=!1,We=()=>{if(!Ue){Ue=!0;for(let T of ve)T();for(let T of X)T();for(let T of _e)T({value:void 0,done:!0});_e.length=0}},qe=[],_e=[];p.add(T=>{let R=_e.shift();R?R({value:T,done:!1}):qe.push(T)});let yt={get values(){return l},get dirtyCount(){return b},get resolvedCount(){return v},get invalidateCount(){return _},get pauseCount(){return m},get resumeCount(){return y},get teardownCount(){return x},get events(){return f?f.toArray():[...h]},get anyCompletedCleanly(){return w},get anyErrored(){return O},get completedWithoutErrors(){return w&&!O},onEvent(T){return p.add(T),()=>p.delete(T)},dispose:We,expand(T){We();let R={...t};return typeof T=="string"?R.detail=T:Object.assign(R,T),n(Ut(R))},[Symbol.asyncIterator](){return{next(){return qe.length>0?Promise.resolve({value:qe.shift(),done:!1}):Ue?Promise.resolve({value:void 0,done:!0}):new Promise(T=>_e.push(T))},return(){return We(),Promise.resolve({value:void 0,done:!0})}}}};return t.format!=null&&this._attachFormatLogger(yt,t),yt}_attachFormatLogger(e,t){let n=t.format;if(n==null)return;let s=t.logger??(l=>console.log(l)),o=t.includeTypes?new Set(t.includeTypes):null,i=t.excludeTypes?new Set(t.excludeTypes):null,u=o==null&&i==null?()=>!0:l=>(o==null||o.has(l))&&(i==null||!i.has(l)),d=Pn(t.theme),a=n==="stage-log"?ae():0,c=l=>l==null?"":t.stageLabels?.[l]??l,f=(l,g)=>l.length>g?`${l.slice(0,g-1)}\u2026`:l,h=l=>l.type==="data"||l.type==="error"?f(Be(l.data),120):"",p=l=>{if(n==="stage-log"){let O=(ae()-a)/1e9,k=c(l.path).padEnd(9);if(l.type==="data"){let S=h(l);return`[${O.toFixed(3)}s] ${k} \u2190${S?` ${S}`:""}`}if(l.type==="error"){let S=h(l);return`[${O.toFixed(3)}s] ${k} \u2717${S?` ${S}`:""}`}return l.type==="complete"?`[${O.toFixed(3)}s] ${k} \u25A0 complete`:`[${O.toFixed(3)}s] ${k} ${l.type}`}if(n==="json")try{return JSON.stringify(l)}catch{return JSON.stringify({type:l.type,path:l.path,data:"[unserializable]"})}let g=d[l.type]??"",b=l.path?`${d.path}${l.path}${d.reset} `:"",v=l.type==="data"||l.type==="error",_=l.type==="pause"||l.type==="resume",m=v?` ${Be(l.data)}`:_?` ${Be(l.lockId)}`:"",y=l.type==="data"||l.type==="resolved"||l.type==="derived"?l:void 0,x=y?.trigger_dep_name!=null?` <- ${y.trigger_dep_name}`:y?.trigger_dep_index!=null?` <- #${y.trigger_dep_index}`:"",w=l.in_batch?" [batch]":"";return`${b}${g}${l.type.toUpperCase()}${d.reset}${m}${x}${w}`};e.onEvent(l=>{u(l.type)&&s(p(l),l)})}addDisposer(e){return this._disposers.add(e),()=>{this._disposers.delete(e)}}destroy(){Bt(this._disposers,this.name),this.signal([[j]],{internal:!0}),Bt(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}_destroyClearOnly(){for(let e of[...this._mounts.values()])e._parent=void 0,e._destroyClearOnly();this._mounts.clear(),this._nodes.clear(),this._parent=void 0}snapshot(e){let{expand:t,...n}=this.describe({detail:"full"}),s={};for(let u of Object.keys(n.nodes).sort()){let{lastMutation:d,guard:a,...c}=n.nodes[u];s[u]=c}let o=[...n.subgraphs].sort(),i={...n,version:1,nodes:s,subgraphs:o};if(e?.format==null)return i;if(e.format==="json-string")return JSON.stringify(i);if(e.format==="bytes"){if(e.codec==null)throw new Error("snapshot({format: 'bytes'}) requires a `codec` name");let u=this.config.lookupCodec(e.codec);if(u==null)throw new Error(`snapshot: codec "${e.codec}" is not registered on this graph's config. Call config.registerCodec(...) before creating nodes.`);return Oe(u,u.encode(i))}throw new Error(`snapshot: unknown format "${String(e.format)}"`)}static decode(e,t){let n=t?.config??ce,{codec:s,codecVersion:o,payload:i}=Te(e,n);return s.decode(i,o)}restore(e,t){if(zt(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(u=>u.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(u){t?.onError?.(o,u)}}}}}static fromSnapshot(e,t){zt(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((l,g)=>{let b=l.split(C).length,v=g.split(C).length;return b!==v?b-v:l<g?-1:l>g?1:0})){let l=p.split(C),g=o;for(let b of l)g._mounts.has(b)||g.mount(b,new r(b)),g=g._mounts.get(b)}let i=s?Object.entries(s).map(([p,l])=>({re:He(p),factory:l})):[],u=p=>{for(let l of i)if(l.re.test(p))return l.factory},d=p=>{let l=p.split(C),g=l.pop();if(g==null||g.length===0)throw new Error(`invalid snapshot path "${p}"`);let b=o;for(let v of l){let _=b._mounts.get(v);if(!_)throw new Error(`unknown mount "${v}" in path "${p}"`);b=_}return[b,g]},a=Object.entries(e.nodes).filter(([p])=>!p.includes(`${C}${V}${C}`)).sort((p,l)=>p[0]<l[0]?-1:p[0]>l[0]?1:0),c=new Map(a),f=new Map,h=!0;for(;c.size>0&&h;){h=!1;for(let[p,l]of[...c.entries()]){let g=l?.deps??[];if(!g.every(x=>f.has(x)))continue;let[b,v]=d(p),_={...l?.meta??{}},m=u(p),y;if(l?.type==="state")y=Le(l.value,{meta:_});else{if(m==null)continue;y=m(v,{path:p,type:l.type,value:l.value,meta:_,deps:g,resolvedDeps:g.map(x=>f.get(x))})}b.add(y,{name:v}),f.set(p,y),c.delete(p),h=!0}}if(c.size>0){let p=[...c.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()}attachStorage(e,t={}){let n=e.map(a=>({tier:a,debounceMs:Math.max(0,a.debounceMs??0),compactEvery:Math.max(1,a.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=(a,c)=>{if(a.disposed)return;let f=xn(c.nodes);if(a.lastSnapshot!=null&&f!==""&&f===a.lastFingerprint)return;let h=a.seq+1,p=Ge(),b=a.lastSnapshot==null||h%a.compactEvery===0?{mode:"full",snapshot:c,seq:h,timestamp_ns:p,format_version:ee}:{mode:"diff",diff:bt(a.lastSnapshot,c),seq:h,timestamp_ns:p,format_version:ee};if(a.tier.filter&&!a.tier.filter(this.name,b))return;let v;try{v=a.tier.save(this.name,b)}catch(_){t.onError?.(_,a.tier);return}if(v&&typeof v.then=="function"){let y=(a.savePending??Promise.resolve()).then(()=>v,()=>v).then(()=>{a.disposed||(a.seq=h,a.lastSnapshot=c,a.lastFingerprint=f)},x=>{t.onError?.(x,a.tier)});a.savePending=y.finally(()=>{a.savePending===y&&(a.savePending=void 0)})}else a.seq=h,a.lastSnapshot=c,a.lastFingerprint=f},o=(a,c)=>{try{s(a,c)}catch(f){t.onError?.(f,a.tier)}},i=(a,c)=>{if(!c.some(l=>{let g=this.config.messageTier(l[0]);return g>=3&&g<5}))return;if(t.filter){let l=this.tryResolve(a);if(l==null)return;let g=lt(l,Ie("standard"));if(!t.filter(a,g))return}let h,p=()=>(h==null&&(h=this.snapshot()),h);for(let l of n)l.disposed||(l.debounceMs===0?o(l,p()):(l.timer==null&&(l.timer=new je),l.timer.start(l.debounceMs,()=>{l.disposed||o(l,this.snapshot())})))},u;if(t.paths!=null){let c=(typeof t.paths=="string"?this._pathsMatching(t.paths):t.paths).map(f=>{let h=this.tryResolve(f);return h==null?()=>{}:h.subscribe(p=>i(f,p))});u=()=>{for(let f of c)f()}}else u=this.observe().subscribe((a,c)=>i(a,c));let d=()=>{u();for(let a of n)a.disposed=!0,a.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(this.name)}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===ee&&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(e)}catch(d){n?.onError?.(d,s);continue}if(o==null||typeof o!="object"||Array.isArray(o))continue;let i=o,u=i.mode==="full"&&i.snapshot!=null?i.snapshot:i.version===ee&&i.nodes!=null?i:void 0;if(u!=null)try{return r.fromSnapshot(u,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:ae(),...n?.actor!=null?{actor:n.actor}:{}};this._traceRing.push(s)}return}return e!=null?this.config.inspectorEnabled?this._annotations.get(e):void 0:this.config.inspectorEnabled?this._traceRing.toArray():[]}annotation(e){return this._annotations.get(e)}clearTrace(){this._annotations.clear(),this._traceRing.clear()}pruneTrace(e){let t=this._traceRing.toArray().filter(s=>!e(s)),n=this._traceRing.size-t.length;this._traceRing.clear();for(let s of t)this._traceRing.push(s);return n}static diff(e,t){let n=new Set(Object.keys(e.nodes)),s=new Set(Object.keys(t.nodes)),o=[...s].filter(_=>!n.has(_)).sort(),i=[...n].filter(_=>!s.has(_)).sort(),u=[],d=[];for(let _ of n){if(!s.has(_))continue;let m=e.nodes[_],y=t.nodes[_],x=m.v,w=y.v;x!=null&&w!=null&&x.id===w.id&&x.version!==w.version&&d.push({path:_,id:x.id,from:x.version,to:w.version});let O=x!=null&&w!=null&&x.id===w.id&&x.version===w.version;for(let k of["type","status","sentinel"]){let S=m[k],$=y[k];S!==$&&u.push({path:_,field:k,from:S,to:$})}if(!O)for(let k of["value","meta"]){let S=m[k],$=y[k];kn(S,$)||u.push({path:_,field:k,from:S,to:$})}}let a=_=>`${_.from} ${_.to}`,c=new Set(e.edges.map(a)),f=new Set(t.edges.map(a)),h=t.edges.filter(_=>!c.has(a(_))),p=e.edges.filter(_=>!f.has(a(_))),l=new Set(e.subgraphs),g=new Set(t.subgraphs),b=[...g].filter(_=>!l.has(_)).sort(),v=[...l].filter(_=>!g.has(_)).sort();return{nodesAdded:o,nodesRemoved:i,nodesChanged:u,versionChanges:d,edgesAdded:h,edgesRemoved:p,subgraphsAdded:b,subgraphsRemoved:v}}};function bt(r,e){let t=te.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 ze(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,u=new Map,d=new Map,a=new Map,c=new Set;for(let[m,y]of Object.entries(r.nodes)){if(!m)continue;c.add(m);let x=y.deps??[];i.set(m,x);for(let w of x)w&&(c.add(w),u.has(w)||u.set(w,new Set),u.get(w).add(m))}for(let m of r.edges){if(m==null||typeof m!="object")continue;let y=typeof m.from=="string"?m.from:"",x=typeof m.to=="string"?m.to:"";!y||!x||(c.add(y),c.add(x),a.has(y)||a.set(y,new Set),a.get(y).add(x),d.has(x)||d.set(x,new Set),d.get(x).add(y))}if(!c.has(e))return n.withDetail?s:[];let f=n.both===!0,h=m=>{if(f){let O=i.get(m)??[],k=d.get(m),S=u.get(m),$=a.get(m),E=[...O];return k&&E.push(...k),S&&E.push(...S),$&&E.push(...$),E}if(t==="upstream"){let O=i.get(m)??[],k=d.get(m);return k?[...O,...k]:O}let y=u.get(m),x=a.get(m),w=y?[...y]:[];return x&&w.push(...x),w},p=new Set([e]),l=new Map,g=[{path:e,depth:0}],b=0,v=!1;for(;b<g.length;){let m=g[b++];if(o!=null&&m.depth>=o){h(m.path).length>0&&(v=!0);continue}for(let y of h(m.path))!y||p.has(y)||(p.add(y),l.set(y,m.depth+1),g.push({path:y,depth:m.depth+1}))}let _=[...l.keys()].sort((m,y)=>m<y?-1:m>y?1:0);return n.withDetail?{paths:_,depths:l,truncated:v}:_}function jn(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}de();function Jt(r,e){let t=new Map,n=(s,o)=>{if(t.has(s))return;let i={off:()=>{},prefix:o};t.set(s,i);let u=s.topology.subscribe(d=>{for(let a of d){if(a[0]!==F)continue;let c=a[1];if(e(c,s,o),c.kind==="added"&&c.nodeKind==="mount"){let f=s._mounts.get(c.name);if(f instanceof te){let h=`${o}${c.name}::`;n(f,h)}}else if(c.kind==="removed"&&c.nodeKind==="mount"){let f=`${o}${c.name}::`;for(let[h,p]of Array.from(t.entries()))h!==r&&p.prefix.startsWith(f)&&(p.off(),t.delete(h))}}});i.off=u;for(let[d,a]of s._mounts)if(a instanceof te){let c=`${o}${d}::`;n(a,c)}};return n(r,""),()=>{for(let s of t.values())s.off();t.clear()}}function Zt(r,e={}){let t=[],n=e.requireFound??!0;if(e.skipDescribe!==!0)try{let a=r.describe(),c=new Set(Object.keys(a.nodes)),f=[];for(let[h,p]of Object.entries(a.nodes))for(let l of p.deps)l!==""&&!c.has(l)&&f.push(`${h} \u2192 ${l}`);for(let h of a.edges)c.has(h.from)||f.push(`edge.from: ${h.from}`),c.has(h.to)||f.push(`edge.to: ${h.to}`);f.length>0?t.push({kind:"describe",ok:!1,reason:`describe() has ${f.length} dangling pointer(s); nodes \u2289 deps`,danglingDeps:f}):t.push({kind:"describe",ok:!0,nodeCount:c.size,edgeCount:a.edges.length})}catch(a){t.push({kind:"describe",ok:!1,reason:`describe() threw: ${a instanceof Error?a.message:String(a)}`})}for(let a of e.formats??[])try{let c=r.describe({format:a});typeof c!="string"||c.length===0?t.push({kind:"describe-format",ok:!1,format:a,reason:`describe({ format: "${a}" }) returned empty or non-string output`}):t.push({kind:"describe-format",ok:!0,format:a,length:c.length})}catch(c){t.push({kind:"describe-format",ok:!1,format:a,reason:c instanceof Error?c.message:String(c)})}for(let a of e.paths??[])try{r.resolve(a),t.push({kind:"observe",ok:!0,path:a})}catch(c){t.push({kind:"observe",ok:!1,path:a,reason:c instanceof Error?c.message:String(c)})}for(let[a,c]of e.pairs??[])try{let f=r.explain(a,c);n&&f.found===!1?t.push({kind:"explain",ok:!1,from:a,to:c,reason:`explain(${a} \u2192 ${c}) found no path${f.reason?`: ${f.reason}`:""}`}):t.push({kind:"explain",ok:!0,from:a,to:c,found:f.found,steps:f.steps.length})}catch(f){t.push({kind:"explain",ok:!1,from:a,to:c,reason:f instanceof Error?f.message:String(f)})}let s=t.filter(a=>!a.ok),o=s.length===0,i=e.paths?.length??0,u=e.pairs?.length??0,d=e.formats?.length??0;return{ok:o,checks:t,failures:s,summary(){let a=[e.skipDescribe===!0?null:"describe",d>0?`${d} format${d===1?"":"s"}`:null,i>0?`${i} observe path${i===1?"":"s"}`:null,u>0?`${u} explain pair${u===1?"":"s"}`:null].filter(f=>f!=null),c=a.length>0?a.join(", "):"describe-only";return o?`validateGraphObservability: OK (${c})`:`validateGraphObservability: ${s.length} failure(s) across ${c}`}}}0&&(module.exports={ENVELOPE_VERSION,GRAPH_META_SEGMENT,Graph,JsonCodec,SIZEOF_OVERHEAD,SIZEOF_SYMBOL,SNAPSHOT_VERSION,createDagCborCodec,createDagCborZstdCodec,decodeEnvelope,diffForWAL,encodeEnvelope,explainPath,graphProfile,mermaidLiveUrl,reachable,registerBuiltinCodecs,replayWAL,sizeof,validateGraphObservability,watchTopologyTree});
|
|
1
|
+
"use strict";var Qe=Object.defineProperty;var gn=Object.getOwnPropertyDescriptor;var mn=Object.getOwnPropertyNames;var bn=Object.prototype.hasOwnProperty;var W=(t,e)=>()=>(t&&(e=t(t=0)),e);var yn=(t,e)=>{for(var n in e)Qe(t,n,{get:e[n],enumerable:!0})},vn=(t,e,n,r)=>{if(e&&typeof e=="object"||typeof e=="function")for(let s of mn(e))!bn.call(t,s)&&s!==n&&Qe(t,s,{get:()=>e[s],enumerable:!(r=gn(e,s))||r.enumerable});return t};var _n=t=>vn(Qe({},"__esModule",{value:!0}),t);function Et(t){return{name:"dag-cbor",version:1,contentType:"application/dag-cbor",encode:e=>t.encode(e),decode:(e,n)=>t.decode(e)}}function kt(t,e){return{name:"dag-cbor-zstd",version:1,contentType:"application/dag-cbor+zstd",encode:n=>e.compressSync(t.encode(n)),decode:(n,r)=>t.decode(e.decompressSync(n))}}function Oe(t,e){let n=new TextEncoder().encode(t.name);if(n.length===0||n.length>255)throw new Error(`encodeEnvelope: codec name "${t.name}" encodes to ${n.length} bytes (must be 1\u2013255)`);let r=t.version;if(!Number.isInteger(r)||r<0||r>65535)throw new Error(`encodeEnvelope: codec.version ${r} out of u16 range (expected integer 0\u201365535)`);let s=2+n.length+2+e.length;if(s>4294967295)throw new Error(`encodeEnvelope: total envelope size ${s} exceeds 2^32-1 bytes (payload ${e.length} bytes)`);let o=new Uint8Array(s),i=0;return o[i++]=pe,o[i++]=n.length,o.set(n,i),i+=n.length,o[i++]=r>>>8&255,o[i++]=r&255,o.set(e,i),o}function Te(t,e){if(t.length<Tt)throw new Error(`decodeEnvelope: bytes too short (${t.length} < ${Tt})`);let n=0,r=t[n++];if(r!==pe)throw new Error(`decodeEnvelope: unsupported envelope version ${r} (expected ${pe})`);let s=t[n++];if(s===0)throw new Error("decodeEnvelope: name_len must be >= 1");if(n+s+2>t.length)throw new Error(`decodeEnvelope: envelope truncated (need ${n+s+2} bytes, have ${t.length})`);let o=new TextDecoder().decode(t.subarray(n,n+s));n+=s;let i=(t[n]<<8|t[n+1])>>>0;n+=2;let a=t.subarray(n),l=e.lookupCodec(o);if(l==null)throw new Error(`decodeEnvelope: codec "${o}" not registered (envelope codec_v=${i})`);return{codec:l,codecVersion:i,payload:a}}function Ee(t){t.registerCodec(tt)}function Nt(t){if(t.length===0)throw new Error("WAL is empty \u2014 need at least one full snapshot");let e=t[0];if(e.mode!=="full")throw new Error("WAL must start with a full record carrying a baseline snapshot");let n=JSON.parse(JSON.stringify(e.snapshot)),r=e.seq;for(let s=1;s<t.length;s++){let o=t[s];if(o.seq<=r)throw new Error(`WAL chain broken at index ${s}: seq=${o.seq} must exceed prev seq=${r}`);if(o.mode==="full"){n=JSON.parse(JSON.stringify(o.snapshot)),r=o.seq;continue}let i=o.diff;for(let l of i.nodesRemoved)delete n.nodes[l];let a=i.nodesAddedFull;if(a!=null)for(let[l,u]of Object.entries(a))n.nodes[l]=JSON.parse(JSON.stringify(u));for(let l of i.nodesChanged){let u=n.nodes[l.path];u!=null&&(u[l.field]=l.to)}r=o.seq}return n}var tt,pe,Tt,ke=W(()=>{"use strict";tt={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)}};pe=1,Tt=4});function Ae(t){if(t==null)return ie;let{type:e,id:n,...r}=t;return{type:e??"system",id:n??"",...r}}var ie,nt=W(()=>{"use strict";ie={type:"system",id:""}});function Ce(){return ae>0||he}function At(){return ae>0}function me(t){ae>0?ge.push(t):t()}function Ct(t){ae+=1;let e=!1;try{t()}catch(n){throw e=!0,n}finally{if(ae-=1,ae===0)if(e){if(!he){let n=ge.splice(0);for(let r of n)try{r()}catch{}se.length=0,oe.length=0,ue.length=0}}else kn()}}function kn(){let t=!he;t&&(he=!0);let e=[],n=0;try{for(;se.length>0||oe.length>0||ue.length>0||t&&ge.length>0;){if(t&&ge.length>0){let o=ge.splice(0);for(let i of o)try{i()}catch(a){e.push(a)}continue}if(n+=1,n>1e3)throw se.length=0,oe.length=0,ue.length=0,new Error("batch drain exceeded 1000 iterations \u2014 likely a reactive cycle");let s=(se.length>0?se:oe.length>0?oe:ue).splice(0);for(let o of s)try{o()}catch(i){e.push(i)}}}finally{t&&(he=!1)}if(e.length===1)throw e[0];if(e.length>1)throw new AggregateError(e,"batch drain: multiple callbacks threw")}function Ge(t,e,n){if(e.length===0)return;if(e.length===1){let u=n(e[0][0]);if(u<3||!Ce()){t(e);return}(u>=5?ue:u===4?oe:se).push(()=>t(e));return}let r=e.length,s=r,o=r,i=r,a=0;for(;a<r&&n(e[a][0])<3;)a++;for(s=a;a<r&&n(e[a][0])===3;)a++;for(o=a;a<r&&n(e[a][0])===4;)a++;i=a;let l=Ce();if(s>0){let u=e.slice(0,s);t(u)}if(o>s){let u=e.slice(s,o);l?se.push(()=>t(u)):t(u)}if(i>o){let u=e.slice(o,i);l?oe.push(()=>t(u)):t(u)}if(r>i){let u=e.slice(i,r);l?ue.push(()=>t(u)):t(u)}}var ae,he,se,oe,ue,ge,rt=W(()=>{"use strict";ae=0,he=!1,se=[],oe=[],ue=[],ge=[]});function le(){return Math.trunc(performance.now()*1e6)}function Me(){return Date.now()*1e6}var st=W(()=>{"use strict"});function ot(t){let e=Nn.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 U,Nn,$e=W(()=>{"use strict";U=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}},Nn=["human","llm","wallet","system"]});var be,P,J,X,q,Z,Q,H,Y,L,ce,it,Sn,at,Dn,Rn,ut,Gt,Mt,$t,lt,ye=W(()=>{"use strict";be=Symbol.for("graphrefly/START"),P=Symbol.for("graphrefly/DATA"),J=Symbol.for("graphrefly/DIRTY"),X=Symbol.for("graphrefly/RESOLVED"),q=Symbol.for("graphrefly/INVALIDATE"),Z=Symbol.for("graphrefly/PAUSE"),Q=Symbol.for("graphrefly/RESUME"),H=Symbol.for("graphrefly/TEARDOWN"),Y=Symbol.for("graphrefly/COMPLETE"),L=Symbol.for("graphrefly/ERROR"),ce=Object.freeze([J]),it=Object.freeze([X]),Sn=Object.freeze([q]),at=Object.freeze([be]),Dn=Object.freeze([Y]),Rn=Object.freeze([H]),ut=Object.freeze([ce]),Gt=Object.freeze([it]),Mt=Object.freeze([Sn]),$t=Object.freeze([Dn]),lt=Object.freeze([Rn])});function It(t){t.registerMessageType(be,{tier:0,wireCrossing:!1}),t.registerMessageType(J,{tier:1,wireCrossing:!1}),t.registerMessageType(q,{tier:1,wireCrossing:!1,metaPassthrough:!1}),t.registerMessageType(Z,{tier:2,wireCrossing:!1}),t.registerMessageType(Q,{tier:2,wireCrossing:!1}),t.registerMessageType(P,{tier:3,wireCrossing:!0}),t.registerMessageType(X,{tier:3,wireCrossing:!0}),t.registerMessageType(Y,{tier:4,wireCrossing:!0,metaPassthrough:!1}),t.registerMessageType(L,{tier:4,wireCrossing:!0,metaPassthrough:!1}),t.registerMessageType(H,{tier:5,wireCrossing:!0,metaPassthrough:!1})}var Ie,Lt=W(()=>{"use strict";ye();Ie=class{_messageTypes=new Map;_codecs=new Map;_onMessage;_onSubscribe;_defaultVersioning;_defaultHashFn;_inspectorEnabled=!(typeof process<"u"&&process.env?.NODE_ENV==="production");_globalInspector;_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}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 ct(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(ct);if(typeof t=="object"&&t!==null){let e={};for(let n of Object.keys(t).sort())e[n]=ct(t[n]);return e}return null}function Gn(t){let e=Cn.encode(t),n=e.length,r=n*8,s=n+9+63&-64,o=new Uint8Array(s);o.set(e),o[n]=128;let i=new DataView(o.buffer);i.setUint32(s-4,r>>>0,!1),i.setUint32(s-8,Math.floor(r/4294967296)>>>0,!1);let a=1779033703,l=3144134277,u=1013904242,c=2773480762,f=1359893119,h=2600822924,p=528734635,d=1541459225,g=new Uint32Array(64),b=(_,m)=>_>>>m|_<<32-m;for(let _=0;_<s;_+=64){for(let N=0;N<16;N++)g[N]=i.getUint32(_+N*4,!1);for(let N=16;N<64;N++){let D=g[N-15],S=g[N-2],$=b(D,7)^b(D,18)^D>>>3,V=b(S,17)^b(S,19)^S>>>10;g[N]=g[N-16]+$+g[N-7]+V>>>0}let m=a,y=l,O=u,x=c,w=f,T=h,k=p,R=d;for(let N=0;N<64;N++){let D=b(w,6)^b(w,11)^b(w,25),S=w&T^~w&k,$=R+D+S+An[N]+g[N]>>>0,V=b(m,2)^b(m,13)^b(m,22),K=m&y^m&O^y&O,re=V+K>>>0;R=k,k=T,T=w,w=x+$>>>0,x=O,O=y,y=m,m=$+re>>>0}a=a+m>>>0,l=l+y>>>0,u=u+O>>>0,c=c+x>>>0,f=f+w>>>0,h=h+T>>>0,p=p+k>>>0,d=d+R>>>0}let v=_=>_.toString(16).padStart(8,"0");return v(a)+v(l)+v(u)+v(c)+v(f)+v(h)+v(p)+v(d)}function dt(t){let e=ct(t??null),n=JSON.stringify(e);return Gn(n).slice(0,16)}function Mn(){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 ft(t,e,n){let r=n?.id??Mn();if(t===0)return{id:r,version:0};let o=(n?.hash??dt)(e);return{id:r,version:0,cid:o,prev:null}}function Pt(t,e,n){t.version+=1,"cid"in t&&(t.prev=t.cid,t.cid=n(e))}var An,Cn,Ft=W(()=>{"use strict";An=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]),Cn=new TextEncoder});function jt(t){return{node:t,unsub:null,prevData:void 0,dirty:!1,involvedThisWave:!1,dataBatch:[],terminal:void 0}}function pt(t){t.prevData=void 0,t.dirty=!1,t.involvedThisWave=!1,t.dataBatch.length=0,t.terminal=void 0}function Le(t){return t.length===0?t:typeof t[0]=="symbol"?[t]:t}function Pe(t,e,n){let r=Bt(t)?t:[],s=typeof t=="function"?t:typeof e=="function"?e:void 0,o={};return Bt(t)?o=(ht(e)?e:n)??{}:ht(t)?o=t:o=(ht(e)?e:n)??{},new I(r,s,o)}var Ht,Vt,$n,In,de,I,Bt,ht,ve=W(()=>{"use strict";ke();nt();rt();st();Lt();$e();ye();Ft();Ht=()=>{},Vt=100;$n=(t,e,n,r)=>{n.direction==="down-in"&&t._onDepMessage(n.depIndex,e)},In=(t,e,n,r)=>{let s=t;if(s._status==="completed"||s._status==="errored")return;let o=s._cached,i=o===void 0?[at]:[at,[P,o]];s._status==="dirty"&&i.push(ce),Ge(e,i,s._config.tierOf)},de=new Ie({onMessage:$n,onSubscribe:In});It(de);Ee(de);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??de,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??dt;let s=r.versioning??this._config.defaultVersioning;this._versioningLevel=s,this._versioning=s!=null?ft(s,this._cached===void 0?void 0:this._cached,{id:r.versioningId,hash:this._hashFn}):void 0,this._deps=e.map(jt);let o={};for(let[a,l]of Object.entries(r.meta??{})){let u={initial:l,name:`${r.name??"node"}:meta:${a}`,describeKind:"state",config:this._config};r.guard!=null&&(u.guard=r.guard),o[a]=new t([],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([[P,a]])},down(a){i._emit(Le(a))},up(a){i._emitUp(Le(a))}},this.down=this.down.bind(this),this.up=this.up.bind(this)}get _isTerminal(){return this._status==="completed"||this._status==="errored"}get name(){return this._optsName}get status(){return this._status}get cache(){return this._cached===void 0?void 0:this._cached}get lastMutation(){return this._lastMutation}get v(){return this._versioning}hasGuard(){return this._guard!=null}_applyVersioning(e,n){if(this._isExecutingFn)throw new Error(`Node "${this.name}": _applyVersioning cannot run mid-fn \u2014 call it outside of \`_execFn\` (typically at graph setup time before the first subscribe).`);let r=this._versioningLevel;if(r!=null&&e<=r)return;let s=n?.hash??this._hashFn;s!==this._hashFn&&(this._hashFn=s);let o=this._cached===void 0?void 0:this._cached,i=this._versioning,a=i?.id??n?.id,l=i?.version??0,u=ft(e,o,{id:a,hash:s});u.version=l,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=Ae(e);if(this._guard!=null&&!this._guard(n,"observe"))return!1;if(this._extraGuards!=null){for(let r of this._extraGuards)if(!r(n,"observe"))return!1}return!0}_checkGuard(e){if(e?.internal)return;let n=this._guard!=null||this._extraGuards!=null,r=e?.actor!=null;if(!n&&!r)return;let s=Ae(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:Me()}}down(e,n){let r=Le(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=Le(e);if(r.length===0)return;this._checkGuard(n);let s=n??{internal:!0};this._validateUpTiers(r);for(let o of this._deps)o.node.up?.(r,s)}_emitUp(e){if(this._deps.length!==0&&e.length!==0){this._validateUpTiers(e);for(let n of this._deps)n.node.up?.(e,{internal:!0})}}_validateUpTiers(e){let n=this._config.tierOf;for(let r of e){let s=n(r[0]);if(s===3||s===4)throw new Error(`Node "${this.name}": tier-${s} messages cannot flow up \u2014 DATA/RESOLVED/COMPLETE/ERROR are downstream-only. Use \`down(...)\` for value delivery; \`up(...)\` is for control signals (DIRTY, INVALIDATE, PAUSE, RESUME, TEARDOWN).`)}}subscribe(e,n){if(n!=null&&this._guard!=null){let l=Ae(n);if(!this._guard(l,"observe"))throw new U({actor:l,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 l of this._deps)pt(l);if(this._partial===!1){for(let l of this._deps)if(l.prevData!==void 0||l.dataBatch.length!==0||l.terminal!==void 0||l.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(l){throw this._sinkCount-=1,l}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(l){if(this._sinkCount-=1,this._removeSink(e),this._sinkCount===0&&(this._status="sentinel"),typeof o=="function")try{o()}catch{}throw l}this._status==="sentinel"&&this._cached===void 0&&(this._status="pending");let a=!1;return()=>{a||(a=!0,this._sinkCount-=1,this._removeSink(e),typeof o=="function"&&o(),this._sinks==null&&this._deactivate())}}_removeSink(e){if(this._sinks===e)this._sinks=null;else if(this._sinks!=null&&typeof this._sinks!="function")if(this._sinks.delete(e),this._sinks.size===1){let[n]=this._sinks;this._sinks=n}else this._sinks.size===0&&(this._sinks=null)}_activate(){if(this._deps.length===0){this._fn&&this._execFn();return}this._dirtyDepCount=0;let e=this._deps.length,n=0;try{for(let r=0;r<e;r++){let s=r,o=this._deps[r];o.unsub=Ht,o.unsub=o.node.subscribe(i=>{if(o.unsub===null)return;let a=this._config.tierOf,l=!1;for(let u of i)a(u[0])>=3&&(l=!0),this._config.onMessage(this,u,{direction:"down-in",depIndex:s},this._actions);l&&this._maybeRunFnOnSettlement()}),n++}}catch(r){this._deps[n].unsub=null;for(let s=0;s<n;s++){let o=this._deps[s];if(o.unsub!=null){let i=o.unsub;o.unsub=null;try{i()}catch{}pt(o)}}throw this._dirtyDepCount=0,r}}_addDep(e){for(let s=0;s<this._deps.length;s++)if(this._deps[s].node===e)return s;let n=this._deps.length,r=jt(e);if(this._deps.push(r),this._sinks==null)return n;r.dirty=!0,this._dirtyDepCount++,this._status!=="dirty"&&this._emit(ut),r.unsub=Ht;try{r.unsub=e.subscribe(s=>{if(r.unsub===null)return;let o=this._config.tierOf,i=!1;for(let a of s)o(a[0])>=3&&(i=!0),this._config.onMessage(this,a,{direction:"down-in",depIndex:n},this._actions);i&&this._maybeRunFnOnSettlement()})}catch(s){throw r.unsub=null,this._deps.pop(),this._dirtyDepCount--,s}return n}_deactivate(e=!1){let n=this._cleanup;if(this._cleanup=void 0,typeof n=="function")try{n()}catch(r){this._emit([[L,this._wrapFnError("cleanup threw",r)]])}else if(n!=null&&typeof n=="object"){let r=n.deactivate;if(typeof r=="function")try{r()}catch(s){this._emit([[L,this._wrapFnError("cleanup.deactivate threw",s)]])}}for(let r of this._deps){if(r.unsub!=null){let s=r.unsub;r.unsub=null;try{s()}catch{}}pt(r)}this._waveHasNewData=!1,this._hasNewTerminal=!1,this._hasCalledFnOnce=!1,this._paused=!1,this._pendingWave=!1,this._pendingRerun=!1,this._rerunDepth=0,this._store={},this._dirtyDepCount=0,this._pauseLocks=null,this._pauseBuffer=null,this._fn!=null&&(this._cached=void 0),e||(this._fn!=null||this._deps.length>0)&&(!this._isTerminal||this._resubscribable)&&(this._status="sentinel")}_onDepMessage(e,n){let r=this._deps[e],s=n[0];if(this._inspectorHooks!=null){let o={kind:"dep_message",depIndex:e,message:n};for(let i of this._inspectorHooks)i(o)}if(s!==be){if(s===J){this._depDirtied(r);return}if(s===q){this._depInvalidated(r),this._emit(Mt);return}if(s===Z||s===Q){this._emit([n]);return}if(s===H){this._emit(lt);return}if(s===P)this._depSettledAsData(r,n[1]);else if(s===X)this._depSettledAsResolved(r);else if(s===Y)this._depSettledAsTerminal(r,!0);else if(s===L)this._depSettledAsTerminal(r,n[1]);else{this._emit([n]);return}if(!this._fn){(s===P||s===X)&&this._emit([n]),(s===Y||s===L)&&this._maybeAutoTerminalAfterWave();return}}}_depDirtied(e){e.dirty||(e.dirty=!0,e.involvedThisWave=!0,this._dirtyDepCount++,this._status!=="dirty"&&this._emit(ut))}_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(Gt),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($t)}_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 s=this._deps.map(i=>i.terminal),o={prevData:r,terminalDeps:s,store:this._store};if(this._hasCalledFnOnce=!0,this._clearWaveFlags(),this._inspectorHooks!=null){let i={kind:"run",batchData:n,prevData:r};for(let a of this._inspectorHooks)a(i)}this._isExecutingFn=!0;try{let i=this._fn(n,this._actions,o);if(typeof i=="function")this._cleanup=i;else if(i!=null&&typeof i=="object"){let a=i;(typeof a.beforeRun=="function"||typeof a.deactivate=="function"||typeof a.invalidate=="function")&&(this._cleanup=i)}}catch(i){this._emit([[L,this._wrapFnError("fn threw",i)]])}finally{this._isExecutingFn=!1,this._pendingRerun?(this._pendingRerun=!1,this._rerunDepth+=1,this._rerunDepth>Vt?(this._rerunDepth=0,this._emit([[L,new Error(`Node "${this.name}": _pendingRerun depth exceeded ${Vt} \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"?[ce,e[0]]:e;let r=!0,s=!1,o=!1,i=-1;for(let l of e){let u=n(l[0]);u<i&&(r=!1),u===3&&(s=!0),l[0]===J&&(o=!0),i=u}let a=e;if(!r){let l=e.map((u,c)=>({m:u,i:c,tier:n(u[0])}));l.sort((u,c)=>u.tier-c.tier||u.i-c.i),a=l.map(u=>u.m)}if(s&&!o&&this._status!=="dirty"){let l=0;for(;l<a.length&&n(a[l][0])===0;)l++;return l===0?[ce,...a]:[...a.slice(0,l),ce,...a.slice(l)]}return a}_emit(e){if(e.length===0)return;for(let a=0;a<e.length;a++){let l=e[a];if(l[0]===L&&l[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(l=>l[0]===H||l[0]===q);if(a.length===0)return;n=a}n=this._frameBatch(n);let s=null;for(let a=0;a<n.length;a++){let l=n[a],u=l[0];if(u!==Z&&u!==Q){s?.push(l);continue}if(l.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 c=!0;if(this._pausable!==!1){let f=l[1];if(u===Z)this._pauseLocks==null&&(this._pauseLocks=new Set),this._pauseLocks.add(f),this._paused=!0,this._pausable==="resumeAll"&&this._pauseBuffer==null&&(this._pauseBuffer=[]);else if(this._pauseLocks==null||!this._pauseLocks.has(f))c=!1;else if(this._pauseLocks.delete(f),this._pauseLocks.size===0){if(this._paused=!1,this._pauseBuffer!=null&&this._pauseBuffer.length>0){let h=this._pauseBuffer;this._pauseBuffer=[],this._emit(h)}this._pendingWave&&(this._pendingWave=!1,this._maybeRunFnOnSettlement())}}c?s?.push(l):s==null&&(s=n.slice(0,a))}if(s!=null){if(s.length===0)return;n=s}if(this._hasMeta&&n.some(a=>a[0]===H))for(let a of Object.keys(this.meta))try{this.meta[a]._emit(lt)}catch{}let{finalMessages:o,equalsError:i}=this._updateState(n);if(o.length>0&&this._config.inspectorEnabled){let a=this._config.globalInspector;if(a!=null)try{a({kind:"emit",node:this,messages:o})}catch{}}if(o.length>0)if(this._paused&&this._pausable==="resumeAll"&&this._pauseBuffer!=null){let a=this._config.tierOf,l=[];for(let u of o)a(u[0])===3?this._pauseBuffer.push(u):l.push(u);l.length>0&&this._dispatchOrAccumulate(l)}else this._dispatchOrAccumulate(o);i!=null&&this._emit([[L,i]])}_updateState(e){let n=this._config.tierOf,r,s,o=-1,i=0;for(let c of e)n(c[0])===3&&i++;let a=i<=1,l=-1;if(this._versioning!=null&&i>1){for(let c=e.length-1;c>=0;c--)if(e[c][0]===P){l=c;break}}for(let c=0;c<e.length;c++){let f=e[c],h=f[0];if(h===P){if(f.length>=2){let p=!1;if(a&&this._cached!==void 0)try{p=this._equals(this._cached,f[1])}catch(d){s=this._wrapFnError("equals threw",d),o=c;break}if(p){r==null&&(r=e.slice(0,c)),r.push(it),this._status="resolved";continue}this._cached=f[1],this._versioning!=null&&(l<0||c===l)&&Pt(this._versioning,f[1],this._hashFn)}this._status="settled",r?.push(f)}else if(r?.push(f),h===J)this._status="dirty";else if(h===X)this._status="resolved";else if(h===Y)this._status="completed";else if(h===L)this._status="errored";else if(h===q){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 d=p.invalidate;if(typeof d=="function")try{d()}catch{}}}else h===H&&(this._resetOnTeardown&&(this._cached=void 0),this._deactivate(!0),this._status="sentinel")}let u=o>=0?r??e.slice(0,o):r??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 n=[...this._sinks];for(let r of n)r(e)};_dispatchOrAccumulate(e){if(At()){this._batchPendingMessages===null&&(this._batchPendingMessages=[],me(()=>this._flushBatchPending()));for(let n of e)this._batchPendingMessages.push(n);return}Ge(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);Ge(this._deliverToSinks,n,this._config.tierOf)}},Bt=t=>Array.isArray(t),ht=t=>typeof t=="object"&&t!=null&&!Array.isArray(t)});function He(t,e){return Pe([],{...e,initial:t})}function zt(t,e){return Pe((r,s,o)=>t(s,o)??void 0,{describeKind:"producer",...e})}function mt(t,e,n){return Pe(t,(s,o,i)=>{let a=s.map((l,u)=>l!=null&&l.length>0?l.at(-1):i.prevData[u]);o.emit(e(a,i))},{describeKind:"derived",...n})}var Wt=W(()=>{"use strict";ve()});function bt(t){return t.subscribe(()=>{})}var Ut=W(()=>{"use strict"});var Ve,Kt=W(()=>{"use strict";Ve=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 Er={};yn(Er,{ENVELOPE_VERSION:()=>pe,GRAPH_META_SEGMENT:()=>j,Graph:()=>ne,JsonCodec:()=>tt,SIZEOF_OVERHEAD:()=>M,SIZEOF_SYMBOL:()=>et,SNAPSHOT_VERSION:()=>te,createDagCborCodec:()=>Et,createDagCborZstdCodec:()=>kt,decodeEnvelope:()=>Te,diffForWAL:()=>wt,encodeEnvelope:()=>Oe,explainPath:()=>Re,graphProfile:()=>We,mermaidLiveUrl:()=>xt,reachable:()=>qe,registerBuiltinCodecs:()=>Ee,replayWAL:()=>Nt,sizeof:()=>we,validateGraphObservability:()=>hn,watchTopologyTree:()=>pn});module.exports=_n(Er);var M={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},et=Symbol.for("sizeof");function we(t){let e=new WeakSet,n=new WeakSet,r=[t],s=0;for(;r.length>0;){let o=r.pop();s+=xn(o,e,n,r)}return s}function xn(t,e,n,r){if(t==null)return 0;switch(typeof t){case"number":return M.number;case"boolean":return M.boolean;case"string":return M.string+t.length*2;case"bigint":return M.bigint+wn(t);case"symbol":return M.symbol;case"function":return e.has(t)?0:(e.add(t),M.function);case"undefined":return 0}let o=t;if(e.has(o))return 0;e.add(o);let i=o[et];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 M.date;if(o instanceof RegExp)return M.regexp+o.source.length*2;if(o instanceof Error){let u=o.message?o.message.length*2:0,c=o.stack?o.stack.length*2:0;return M.error+u+c}if(typeof URL<"u"&&o instanceof URL)return M.url+o.href.length*2;if(typeof Promise<"u"&&o instanceof Promise)return M.promise;if(o instanceof WeakMap)return M.weakmap;if(o instanceof WeakSet)return M.weakset;if(o instanceof Map){let u=M.map;for(let[c,f]of o)u+=M.mapEntry,r.push(c),r.push(f);return u}if(o instanceof Set){let u=M.set;for(let c of o)u+=M.setEntry,r.push(c);return u}if(Array.isArray(o)){let u=M.array+o.length*8;for(let c of o)r.push(c);return u}if(o instanceof ArrayBuffer)return n.has(o)?0:(n.add(o),o.byteLength);if(ArrayBuffer.isView(o)){let u=o;return n.has(u.buffer)?48:(n.add(u.buffer),u.buffer.byteLength+48)}let a=M.object,l=Object.keys(o);for(let u of l){a+=M.string+u.length*2;try{r.push(o[u])}catch{}}return a}function wn(t){let e=t<0n?-t:t;if(e===0n)return 0;let n=e.toString(2).length;return Math.ceil(n/32)*8}ke();function Re(t,e,n,r={}){let s=e in t.nodes,o=n in t.nodes;if(!s)return Ne(e,n,"no-such-from");if(!o)return Ne(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=On(t,e,r);if(u!=null)return u}let l=Se(e,t.nodes[e],0,r);return De(e,n,[l])}if(i===0)return Ne(e,n,"no-path");let a=St(t,e,n,i);return a.found?De(e,n,Dt(t,a.pathOrder,r)):Ne(e,n,a.truncated?"max-depth-exceeded":"no-path")}function St(t,e,n,r){let s=new Map,o=[{path:n,depth:0}],i=new Set([n]),a=0,l=!1;for(;a<o.length;){let f=o[a++];if(f.path===e)break;if(r!=null&&f.depth>=r){let g=t.nodes[f.path];g?.deps&&g.deps.length>0&&(l=!0);continue}let h=t.nodes[f.path];if(h==null)continue;let p=h.deps??[],d=new Map;for(let g=0;g<p.length;g++){let b=p[g];if(!b)continue;let v=d.get(b);v==null&&(v=[],d.set(b,v)),v.push(g)}for(let[g,b]of d)i.has(g)||(i.add(g),s.set(g,{from:f.path,depIndices:b}),o.push({path:g,depth:f.depth+1}))}if(!s.has(e))return{found:!1,pathOrder:[],truncated:l};let u=[{path:e}],c=e;for(;c!==n;){let f=s.get(c);if(f==null)return{found:!1,pathOrder:[],truncated:!1};u[u.length-1].depIndices=f.depIndices,u.push({path:f.from}),c=f.from}return{found:!0,pathOrder:u,truncated:!1}}function On(t,e,n){let r=t.nodes[e];if(r==null)return null;let s=r.deps??[],o=[];for(let a=0;a<s.length;a++)s[a]===e&&o.push(a);if(o.length>0){let a=Se(e,r,0,n);a.dep_index=o[0];let l=Se(e,r,1,n);return De(e,e,[a,l])}let i=null;for(let a=0;a<s.length;a++){let l=s[a];if(!l||l===e)continue;let u=St(t,l,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:De(e,e,Dt(t,i.pathOrder,n))}function Dt(t,e,n){return e.map((r,s)=>{let o=t.nodes[r.path],i=Se(r.path,o,s,n);return r.depIndices!=null&&r.depIndices.length>0&&(i.dep_index=r.depIndices[0],r.depIndices.length>1&&(i.dep_indices=[...r.depIndices])),i})}function Se(t,e,n,r){let s={path:t,type:e.type,hop:n};e.status!==void 0&&(s.status=e.status),"value"in e&&(s.value=e.value),e.v!=null&&(s.v=e.v);let o=r.annotations?.get(t)??e.annotation;o!=null&&(s.annotation=o);let i=r.lastMutations?.get(t)??e.lastMutation;return i!=null&&(s.lastMutation=i),s}function De(t,e,n){return Rt(t,e,!0,"ok",n)}function Ne(t,e,n){return Rt(t,e,!1,n,[])}function Rt(t,e,n,r,s){let o=Tn(t,e,n,r,s);return{from:t,to:e,found:n,reason:r,steps:s,text:o,toJSON(){return{from:t,to:e,found:n,reason:r,steps:s}}}}function Tn(t,e,n,r,s){if(!n)switch(r){case"no-such-from":return`explainPath: no node named "${t}"`;case"no-such-to":return`explainPath: no node named "${e}"`;case"max-depth-exceeded":return`explainPath: no path from "${t}" to "${e}" within maxDepth`;default:return`explainPath: no path from "${t}" to "${e}"`}let o=[`Causal path: ${t} \u2192 ${e} (${s.length} step(s))`];for(let i of s){let l=` ${i.hop===0?"\xB7":"\u2193"} ${i.path} (${i.type}${i.status?`/${i.status}`:""})`;if(o.push(l),"value"in i&&o.push(` value: ${En(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 En(t){if(t===void 0)return"<sentinel>";if(t===null)return"null";if(typeof t=="string")return JSON.stringify(t);if(typeof t=="number"||typeof t=="boolean"||typeof t=="bigint")return String(t);try{let e=JSON.stringify(t);return e.length>80?`${e.slice(0,77)}...`:e}catch{return String(t)}}nt();rt();st();$e();ye();$e();ve();function Fe(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;default:return new Set(["type","deps"])}}function Ln(t){return t._describeKind!=null?t._describeKind:t._deps.length>0?"derived":t._fn!=null?"producer":"state"}function Pn(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,s=n||e.has("meta")||r!=null&&r.length>0,o="state",i=[];t instanceof I&&(o=Ln(t),i=t._deps.map(u=>u.node.name??""));let a={type:o,deps:i};(n||e.has("status"))&&(a.status=t.status);let l=t instanceof I?t._guard:void 0;if(s){let u={...Pn(t)};if(l!=null&&u.access===void 0&&(u.access=ot(l)),r!=null&&r.length>0&&!e.has("meta")){let c={};for(let f of r)f in u&&(c[f]=u[f]);a.meta=c}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"))&&l!=null&&(a.guard=ot(l)),(n||e.has("lastMutation"))&&t.lastMutation!=null&&(a.lastMutation=t.lastMutation),a}ve();Wt();Ut();Kt();var _e=class{constructor(e){this.capacity=e;if(!Number.isInteger(e)||e<=0)throw new Error(`RingBuffer capacity must be a positive integer (got ${e})`);this.buf=new Array(e)}buf;head=0;_size=0;get size(){return this._size}get maxSize(){return this.capacity}push(e){let n=(this.head+this._size)%this.capacity;this.buf[n]=e,this._size<this.capacity?this._size++:this.head=(this.head+1)%this.capacity}shift(){if(this._size===0)return;let e=this.buf[this.head];return this.buf[this.head]=void 0,this.head=(this.head+1)%this.capacity,this._size--,e}at(e){if(this._size===0)return;let n=e<0?this._size+e:e;if(!(n<0||n>=this._size))return this.buf[(this.head+n)%this.capacity]}toArray(){let e=new Array(this._size);for(let n=0;n<this._size;n++)e[n]=this.buf[(this.head+n)%this.capacity];return e}clear(){for(let e=0;e<this._size;e++)this.buf[(this.head+e)%this.capacity]=void 0;this.head=0,this._size=0}};ke();function yt(t){return t>=768&&t<=879||t>=1155&&t<=1161||t>=1425&&t<=1469||t>=1552&&t<=1562||t>=1611&&t<=1631||t>=1648&&t===1648||t>=1750&&t<=1756||t>=1759&&t<=1764||t>=1767&&t<=1768||t>=1770&&t<=1773||t>=1840&&t<=1866||t>=1958&&t<=1968||t>=2304&&t<=2307||t>=2362&&t<=2383||t>=2385&&t<=2391||t>=2402&&t<=2403||t>=2433&&t<=2435||t>=2492&&t<=2509||t>=2561&&t<=2563||t>=2620&&t<=2641||t>=2672&&t<=2673||t>=2677&&t===2677||t>=3633&&t===3633||t>=3636&&t<=3642||t>=3655&&t<=3662||t>=3761&&t===3761||t>=3764&&t<=3772||t>=3784&&t<=3790||t>=7616&&t<=7679||t>=8400&&t<=8447||t>=65024&&t<=65039||t>=65056&&t<=65071||t===8205?0:t>=4352&&t<=4447||t>=8986&&t<=8987||t>=9001&&t<=9002||t>=9193&&t<=9203||t>=9208&&t<=9210||t>=9725&&t<=9726||t>=9748&&t<=9749||t>=9800&&t<=9811||t===9855||t===9875||t===9889||t>=9898&&t<=9899||t>=9917&&t<=9918||t>=9924&&t<=9925||t===9934||t===9940||t===9962||t>=9970&&t<=9971||t===9973||t===9978||t===9981||t===9986||t===9989||t>=9992&&t<=9997||t===9999||t>=10067&&t<=10069||t===10071||t>=10133&&t<=10135||t===10160||t===10175||t>=10548&&t<=10549||t>=11013&&t<=11015||t>=11035&&t<=11036||t===11088||t===11093||t>=11904&&t<=12350||t>=12352&&t<=12447||t>=12448&&t<=12543||t>=12549&&t<=12591||t>=12593&&t<=12686||t>=12688&&t<=12771||t>=12784&&t<=12830||t>=12832&&t<=12871||t>=12880&&t<=19903||t>=19968&&t<=40959||t>=43360&&t<=43388||t>=44032&&t<=55203||t>=63744&&t<=64255||t>=65040&&t<=65049||t>=65072&&t<=65131||t>=65281&&t<=65376||t>=65504&&t<=65510||t>=126980&&t===126980||t===127183||t>=127344&&t<=127345||t===127358||t===127359||t===127374||t>=127377&&t<=127386||t>=127456&&t<=127487||t>=127488&&t<=127490||t===127514||t===127535||t>=127538&&t<=127546||t>=127568&&t<=127569||t>=127744&&t<=129535||t>=129536&&t<=129791||t>=129792&&t<=130047||t>=131072&&t<=196605||t>=196608&&t<=262141?2:1}function je(t){let e=0;for(let n of t)e+=yt(n.codePointAt(0));return e}function qt(t,e){if(e<=0)return"";let n=0,r="";for(let s of t){let o=yt(s.codePointAt(0));if(n+o>e){if(e<=1)return"\u2026";for(;n+1>e&&r.length>0;){let i=[...r].pop();r=r.slice(0,-i.length),n-=yt(i.codePointAt(0))}return`${r}\u2026`}r+=s,n+=o}return r}var Fn={horizontal:"\u2500",vertical:"\u2502",cornerTL:"\u250C",cornerTR:"\u2510",cornerBL:"\u2514",cornerBR:"\u2518",tDown:"\u252C",tUp:"\u2534",tRight:"\u251C",tLeft:"\u2524",cross:"\u253C",arrowRight:"\u25B6",arrowDown:"\u25BC",arrowLeft:"\u25C0",arrowUp:"\u25B2",boxTL:"\u250C",boxTR:"\u2510",boxBL:"\u2514",boxBR:"\u2518",boxH:"\u2500",boxV:"\u2502"},Hn={horizontal:"-",vertical:"|",cornerTL:"+",cornerTR:"+",cornerBL:"+",cornerBR:"+",tDown:"+",tUp:"+",tRight:"+",tLeft:"+",cross:"+",arrowRight:">",arrowDown:"v",arrowLeft:"<",arrowUp:"^",boxTL:"+",boxTR:"+",boxBL:"+",boxBR:"+",boxH:"-",boxV:"|"};function Zt(t,e){let n=e.charset==="ascii"?Hn:Fn,r=t.width,s=t.height,o=Array.from({length:s},()=>Array.from({length:r},()=>" ")),i=Array.from({length:s},()=>Array.from({length:r},()=>"empty"));for(let a of t.edges)jn(o,i,n,a);for(let a of t.boxes)Vn(o,i,n,a,e.labelOf(a.id));return o.map(a=>Un(a.join(""))).join(`
|
|
3
|
+
`)}function Vn(t,e,n,r,s){let{x:o,y:i,w:a,h:l}=r;if(a<2||l<2){l>0&&Yt(t,e,o,i,a,s);return}ee(t,e,o,i,n.boxTL);for(let c=o+1;c<o+a-1;c+=1)ee(t,e,c,i,n.boxH);ee(t,e,o+a-1,i,n.boxTR);for(let c=i+1;c<i+l-1;c+=1){ee(t,e,o,c,n.boxV);for(let f=o+1;f<o+a-1;f+=1)Qt(t,e,f,c," ","empty");ee(t,e,o+a-1,c,n.boxV)}ee(t,e,o,i+l-1,n.boxBL);for(let c=o+1;c<o+a-1;c+=1)ee(t,e,c,i+l-1,n.boxH);ee(t,e,o+a-1,i+l-1,n.boxBR);let u=i+Math.floor(l/2);Yt(t,e,o+1,u,a-2,s)}function ee(t,e,n,r,s){Qt(t,e,n,r,s,s===" "?"empty":s==="\u2500"||s==="-"?"boxH":s==="\u2502"||s==="|"?"boxV":"boxCorner")}function Qt(t,e,n,r,s,o){if(r<0||r>=t.length)return;let i=t[r];n<0||n>=i.length||(i[n]=s,e[r][n]=o)}function Yt(t,e,n,r,s,o){if(r<0||r>=t.length)return;let i=n,a=s;for(let l of o){let u=je(l);if(u!==0){if(a<u)break;i>=0&&i<t[r].length&&(t[r][i]=l,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 jn(t,e,n,r){let s=r.points;if(s.length<2)return;for(let l=0;l+1<s.length;l+=1)Bn(t,e,n,s[l],s[l+1]);for(let l=1;l+1<s.length;l+=1){let u=s[l-1],c=s[l],f=s[l+1],h=zn(u,c,f,n);h&&Xt(t,e,c.x,c.y,h,"edgeCorner")}let o=s[s.length-1],i=s[s.length-2],a=Wn(i,o,n);a&&Xt(t,e,o.x,o.y,a,"arrow")}function Bn(t,e,n,r,s){if(!(r.x===s.x&&r.y===s.y)){if(r.y===s.y){let o=r.y,i=Math.min(r.x,s.x),a=Math.max(r.x,s.x);for(let l=i;l<=a;l+=1)Jt(t,e,l,o,n,"h")}else if(r.x===s.x){let o=r.x,i=Math.min(r.y,s.y),a=Math.max(r.y,s.y);for(let l=i;l<=a;l+=1)Jt(t,e,o,l,n,"v")}}}function Jt(t,e,n,r,s,o){if(r<0||r>=t.length)return;let i=t[r];if(n<0||n>=i.length)return;let a=e[r][n];if(!(a==="boxH"||a==="boxV"||a==="boxCorner"||a==="label")){if(a==="empty"){i[n]=o==="h"?s.horizontal:s.vertical,e[r][n]=o==="h"?"edgeH":"edgeV";return}if(a==="edgeH"&&o==="v"){i[n]=s.cross,e[r][n]="edgeCorner";return}if(a==="edgeV"&&o==="h"){i[n]=s.cross,e[r][n]="edgeCorner";return}}}function Xt(t,e,n,r,s,o){if(r<0||r>=t.length)return;let i=t[r];if(n<0||n>=i.length)return;let a=e[r][n];a==="boxH"||a==="boxV"||a==="boxCorner"||a==="label"||(i[n]=s,e[r][n]=o)}function zn(t,e,n,r){let s=t.y===e.y,o=e.y===n.y;if(s===o)return;if(s){let l=t.x<e.x,u=n.y>e.y;return l&&u?r.cornerTR:l&&!u?r.cornerBR:!l&&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 Wn(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 Un(t){let e=t.length;for(;e>0&&t.charCodeAt(e-1)===32;)e-=1;return t.slice(0,e)}function nn(t){let e=Kn(t);qn(e),Yn(e),Jn(e),Xn(e,t);let n=er(e,t),{width:r,height:s}=nr(e),o=[];for(let i of e.layers)for(let a of i)a.isVirtual||o.push({id:a.id,layer:a.layer,order:a.order,x:a.x,y:a.y,w:a.w,h:a.h});return{boxes:o,edges:n,width:r,height:s}}function Kn(t){let e=new Map;for(let s of t.nodes)e.set(s,{id:s,isVirtual:!1,layer:-1,order:0,x:0,y:0,w:t.widthCells(s),h:t.heightCells(s),in:[],out:[]});let n=[],r=0;for(let s of t.edges){if(s.from===s.to)continue;let o=e.get(s.from),i=e.get(s.to);if(!o||!i)continue;let a={chainId:r++,chainFrom:s.from,chainTo:s.to,fromId:s.from,toId:s.to,hopIndex:0,chainLen:1};o.out.push(a),i.in.push(a),n.push(a)}return{nodes:e,layers:[],hops:n}}function qn(t){let e=new Map;for(let o of t.nodes.values())e.set(o.id,o.in.length);let n=[];for(let o of t.nodes.values())(e.get(o.id)??0)===0&&(o.layer=0,n.push(o));let r=new Set,s=0;for(;s<n.length;){let o=n[s++];if(!r.has(o.id)){r.add(o.id);for(let i of o.out){let a=t.nodes.get(i.toId);a.layer=Math.max(a.layer,o.layer+1);let l=(e.get(a.id)??0)-1;e.set(a.id,l),l<=0&&n.push(a)}}}for(let o of t.nodes.values())o.layer<0&&(o.layer=0)}function Yn(t){let e=Math.max(0,...Array.from(t.nodes.values(),o=>o.layer)),n=Array.from({length:e+1},()=>[]);for(let o of t.nodes.values())n[o.layer].push(o);let r=[],s=0;for(let o of t.hops){let i=t.nodes.get(o.fromId),a=t.nodes.get(o.toId),l=a.layer-i.layer;if(l<=0){i.out=i.out.filter(f=>f!==o),a.in=a.in.filter(f=>f!==o);continue}if(l===1){o.hopIndex=0,o.chainLen=1,r.push(o);continue}i.out=i.out.filter(f=>f!==o),a.in=a.in.filter(f=>f!==o);let u=i;for(let f=1;f<l;f+=1){let h=`__virt_${s++}__`,p={id:h,isVirtual:!0,layer:i.layer+f,order:0,x:0,y:0,w:0,h:1,in:[],out:[]};t.nodes.set(h,p),n[p.layer].push(p);let d={chainId:o.chainId,chainFrom:o.chainFrom,chainTo:o.chainTo,fromId:u.id,toId:h,hopIndex:f-1,chainLen:l};u.out.push(d),p.in.push(d),r.push(d),u=p}let c={chainId:o.chainId,chainFrom:o.chainFrom,chainTo:o.chainTo,fromId:u.id,toId:a.id,hopIndex:l-1,chainLen:l};u.out.push(c),a.in.push(c),r.push(c)}for(let o of n)for(let i=0;i<o.length;i+=1)o[i].order=i;t.layers=n,t.hops=r}function Jn(t){for(let n=0;n<4;n+=1){for(let r=1;r<t.layers.length;r+=1)en(t,t.layers[r],"in"),Be(t.layers[r]);for(let r=t.layers.length-2;r>=0;r-=1)en(t,t.layers[r],"out"),Be(t.layers[r])}for(let n=0;n<2;n+=1){let r=!1;for(let s=1;s<t.layers.length;s+=1){let o=t.layers[s];for(let i=0;i+1<o.length;i+=1){let a=tn(t,o[i],o[i+1],"in");[o[i],o[i+1]]=[o[i+1],o[i]],Be(o),tn(t,o[i],o[i+1],"in")<a?r=!0:([o[i],o[i+1]]=[o[i+1],o[i]],Be(o))}}if(!r)break}}function en(t,e,n){let r=new Map;for(let s of e){let o=n==="in"?s.in:s.out;if(o.length===0){r.set(s.id,s.order);continue}let i=0,a=0;for(let l of o){let u=t.nodes.get(n==="in"?l.fromId:l.toId);u&&(i+=u.order,a+=1)}r.set(s.id,a===0?s.order:i/a)}e.sort((s,o)=>{let i=r.get(s.id),a=r.get(o.id);return i!==a?i-a:s.order-o.order})}function Be(t){for(let e=0;e<t.length;e+=1)t[e].order=e}function tn(t,e,n,r){let s=r==="in"?e.in:e.out,o=r==="in"?n.in:n.out,i=0;for(let a of s)for(let l of o){let u=t.nodes.get(r==="in"?a.fromId:a.toId)?.order??0,c=t.nodes.get(r==="in"?l.fromId:l.toId)?.order??0;(e.order<n.order&&u>c||e.order>n.order&&u<c)&&(i+=1)}return i}function Xn(t,e){e.direction==="LR"?Zn(t,e):Qn(t,e)}function Zn(t,e){let n=[],r=0;for(let s=0;s<t.layers.length;s+=1){n.push(r);let o=0;for(let i of t.layers[s])o=Math.max(o,i.w);r+=o+e.layerGap}for(let s=0;s<t.layers.length;s+=1)for(let o of t.layers[s])o.x=n[s];for(let s of t.layers){let o=0;for(let i of s)i.y=o,o+=i.h+e.nodeGap}rn(t,e,"y")}function Qn(t,e){let n=[],r=0;for(let s=0;s<t.layers.length;s+=1){n.push(r);let o=0;for(let i of t.layers[s])o=Math.max(o,i.h);r+=o+e.layerGap}for(let s=0;s<t.layers.length;s+=1)for(let o of t.layers[s])o.y=n[s];for(let s of t.layers){let o=0;for(let i of s)i.x=o,o+=i.w+e.nodeGap}rn(t,e,"x")}function rn(t,e,n){let r=o=>n==="y"?o.h:o.w,s=e.nodeGap;for(let o=0;o<2;o+=1){let i=o===0?t.layers.slice(1):t.layers.slice(0,-1).reverse();for(let a of i){let l=new Map;for(let c of a){let f=o===0?c.in:c.out;if(f.length===0)continue;let h=[];for(let d of f){let g=t.nodes.get(o===0?d.fromId:d.toId);if(!g)continue;let b=n==="y"?g.y:g.x;h.push(b+Math.floor(r(g)/2))}if(h.length===0)continue;h.sort((d,g)=>d-g);let p=h[Math.floor(h.length/2)];l.set(c.id,p-Math.floor(r(c)/2))}let u=0;for(let c of a){let f=l.get(c.id),h=n==="y"?c.y:c.x,d=Math.max(f??h,u);n==="y"?c.y=d:c.x=d,u=d+r(c)+s}}}}function er(t,e){let n=new Map;for(let u of t.hops){let c=n.get(u.chainId);c?c.push(u):n.set(u.chainId,[u])}for(let u of n.values())u.sort((c,f)=>c.hopIndex-f.hopIndex);let r=e.direction==="LR",s=u=>r?u.x:u.y,o=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 c=t.layers[u],f=t.layers[u+1],h=0;for(let T of c)h=Math.max(h,s(T)+o(T));let p=Number.POSITIVE_INFINITY;for(let T of f)p=Math.min(p,s(T));let d=Number.isFinite(p)?p-1:h,g=Math.max(1,d-h+1),b=[];for(let T of c)for(let k of T.out)b.push(k);b.sort((T,k)=>{let R=i(t.nodes.get(T.fromId)),N=i(t.nodes.get(k.fromId));if(R!==N)return R-N;let D=i(t.nodes.get(T.toId)),S=i(t.nodes.get(k.toId));return D-S});let v=[],_=new Map;for(let T of b){let k=i(t.nodes.get(T.fromId)),R=i(t.nodes.get(T.toId)),N=Math.min(k,R),D=Math.max(k,R),S=-1;for(let $=0;$<v.length;$+=1){let V=v[$],K=!0;for(let re of V)if(re.lo<=D&&N<=re.hi){K=!1;break}if(K){V.push({lo:N,hi:D}),S=$;break}}S<0&&(v.push([{lo:N,hi:D}]),S=v.length-1),_.set(T,S)}let m=v.length,y=g>=Math.max(3,m+2),O=y?h+1:h,x=y?d-1:d,w=Math.max(1,x-O+1);for(let T of b){let k=_.get(T),R;if(m<=1)R=O+Math.floor(w/2);else{let N=(w-1)/(m-1);R=O+Math.floor(k*N)}a.set(T,Math.max(h,Math.min(d,R)))}}let l=[];for(let[,u]of n){let c=[];for(let h=0;h<u.length;h+=1){let p=u[h],d=t.nodes.get(p.fromId),g=t.nodes.get(p.toId),b=a.get(p),v=d.isVirtual?s(d):s(d)+o(d),_=g.isVirtual?s(g):s(g)-1,m=i(d),y=i(g);h===0&&ze(c,r,v,m),m!==y&&(ze(c,r,b,m),ze(c,r,b,y)),ze(c,r,_,y)}let f=u[0];l.push({from:f.chainFrom,to:f.chainTo,points:tr(c)})}return l}function ze(t,e,n,r){t.push(e?{x:n,y:r}:{x:r,y:n})}function tr(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 nr(t){let e=0,n=0;for(let r of t.layers)for(let s of r)e=Math.max(e,s.x+s.w),n=Math.max(n,s.y+s.h);return{width:e,height:n}}var rr=24,sr=4,or=1,ir=3;function sn(t,e){let n=ar(e.direction),r=Math.max(3,e.maxLabelWidth??rr),s=e.asciiCharset??"unicode",o=Object.keys(t.nodes).sort(),i=new Set(o),a=t.edges.filter(p=>i.has(p.from)&&i.has(p.to)),l=new Map,u=new Map;for(let p of o){let d=qt(p,r);l.set(p,d),u.set(p,je(d)+4)}let c=nn({nodes:o,edges:a,widthCells:p=>u.get(p)??3,heightCells:()=>ir,layerGap:sr,nodeGap:or,direction:n}),f=Zt(c,{charset:s,labelOf:p=>l.get(p)??p}),h=e.logger;return h&&h(f),f}function ar(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)}`)}ve();function We(t,e){let n=e?.topN??10,r=t.describe({detail:"standard"}),s=[],o=t._collectObserveTargets;typeof o=="function"&&o.call(t,"",s);let i=new Map;for(let[h,p]of s)i.set(h,p);let a=[];for(let[h,p]of Object.entries(r.nodes)){let d=i.get(h),g=d instanceof I?d:null,b=g?we(g.cache):0,v=g?g._sinkCount:0,_=p.deps?.length??0,m=p.type==="effect"&&v===0,y=v===0?p.type==="effect"?"orphan-effect":p.type==="derived"?"idle-derived":p.type==="producer"?"idle-producer":null:null;a.push({path:h,type:p.type,status:p.status??"unknown",valueSizeBytes:b,subscriberCount:v,depCount:_,isOrphanEffect:m,orphanKind:y})}let l=a.reduce((h,p)=>h+p.valueSizeBytes,0),u=(h,p)=>[...a].sort(p??((d,g)=>g[h]-d[h])).slice(0,n),c=a.filter(h=>h.orphanKind!=null),f=a.filter(h=>h.isOrphanEffect);return{nodeCount:a.length,edgeCount:r.edges.length,subgraphCount:r.subgraphs.length,nodes:a,totalValueSizeBytes:l,hotspots:{byValueSize:u("valueSizeBytes"),bySubscriberCount:u("subscriberCount"),byDepCount:u("depCount")},orphans:c,orphanEffects:f}}var G="::",j="__meta__",te=1;function on(t,e){let n=Math.max(16,t.size*4),r=0;for(;t.size>0;){if(r++>=n){console.error(`[Graph "${e}".destroy] disposer drain exceeded cap (${n}); ${t.size} disposer(s) discarded`),t.clear();return}let s=t.values().next();if(s.done)return;let o=s.value;t.delete(o);try{o()}catch(i){console.error(`[Graph "${e}".destroy] disposer threw:`,i)}}}function ur(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 an(t){if(t.version!==te)throw new Error(`unsupported snapshot version ${String(t.version)} (expected ${te})`);for(let e of["name","nodes","edges","subgraphs"])if(!(e in t))throw new Error(`snapshot missing required key "${e}"`);if(typeof t.name!="string")throw new TypeError("snapshot 'name' must be a string");if(typeof t.nodes!="object"||t.nodes===null||Array.isArray(t.nodes))throw new TypeError("snapshot 'nodes' must be an object");if(!Array.isArray(t.edges))throw new TypeError("snapshot 'edges' must be an array");if(!Array.isArray(t.subgraphs))throw new TypeError("snapshot 'subgraphs' must be an array")}function lr(t,e){let n=new WeakMap,r=(s,o)=>{if(Object.is(s,o))return!0;if(s==null||o==null||typeof s!="object"||typeof o!="object")return!1;let i=n.get(s);if(i==null&&(i=new WeakSet,n.set(s,i)),i.has(o))return!0;i.add(o);let a=s.constructor,l=o.constructor;if(a!==l)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 h=o;if(s.length!==h.length)return!1;for(let p=0;p<s.length;p++)if(!r(s[p],h[p]))return!1;return!0}if(s instanceof Map){let h=o;if(s.size!==h.size)return!1;for(let[p,d]of s)if(!h.has(p)||!r(d,h.get(p)))return!1;return!0}if(s instanceof Set){let h=o;if(s.size!==h.size)return!1;for(let p of s){let d=!1;for(let g of h)if(r(p,g)){d=!0;break}if(!d)return!1}return!0}if(ArrayBuffer.isView(s)){let h=s,p=o;if(h.length!==p.length)return!1;for(let d=0;d<h.length;d++)if(h[d]!==p[d])return!1;return!0}let u=Object.keys(s),c=Object.keys(o);if(u.length!==c.length)return!1;let f=new Set(c);for(let h of u)if(!f.has(h)||!r(s[h],o[h]))return!1;return!0};return r(t,e)}function _t(t){if(t===null||typeof t!="object")return t;if(Array.isArray(t))return t.map(_t);let e=t,n=Object.keys(e).sort(),r={};for(let s of n)r[s]=_t(e[s]);return r}function cr(t){return t.replaceAll("\\","\\\\").replaceAll('"','\\"')}function dr(t){return t.replaceAll("\\","\\\\").replaceAll('"','\\"')}function fr(t){return t==="TD"?"down":t==="BT"?"up":t==="RL"?"left":"right"}function ln(t){let e=new Set,n=[];function r(s,o){let i=`${s}\0${o}`;e.has(i)||(e.add(i),n.push([s,o]))}for(let[s,o]of Object.entries(t.nodes)){let i=o.deps;if(i)for(let a of i)r(a,s)}for(let s of t.edges)r(s.from,s.to);return n}function cn(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 pr(t,e){let n=e.includeEdges??!0,r=e.includeSubgraphs??!0,{expand:s,...o}=t,i={...o,edges:n?t.edges:[],subgraphs:r?t.subgraphs:[]},a=JSON.stringify(_t(i),null,e.indent??2);return e.logger?.(a),a}function hr(t,e){let n=e.includeEdges??!0,r=e.includeSubgraphs??!0,s=[];s.push(`Graph ${t.name}`),s.push("Nodes:");for(let i of Object.keys(t.nodes).sort()){let a=t.nodes[i];s.push(`- ${i} (${a.type}/${a.status}): ${Ke(a.value)}`)}if(n){s.push("Edges:");for(let i of t.edges)s.push(`- ${i.from} -> ${i.to}`)}if(r){s.push("Subgraphs:");for(let i of t.subgraphs)s.push(`- ${i}`)}let o=s.join(`
|
|
5
|
+
`);return e.logger?.(o),o}function dn(t,e){let n=cn(e.direction),r=Object.keys(t.nodes).sort(),s=new Map;for(let i=0;i<r.length;i+=1)s.set(r[i],`n${i}`);let o=[`flowchart ${n}`];for(let i of r){let a=s.get(i);o.push(` ${a}["${cr(i)}"]`)}for(let[i,a]of ln(t)){let l=s.get(i),u=s.get(a);!l||!u||o.push(` ${l} --> ${u}`)}return o.join(`
|
|
6
|
+
`)}function gr(t,e){let n=dn(t,e);return xt(n)}function xt(t,e){let n=e?.theme??"default",r=e?.autoSync??!0,o=JSON.stringify({code:t,mermaid:{theme:n},autoSync:r}),i=new TextEncoder().encode(o),a="";for(let 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 mr(t,e){let n=cn(e.direction),r=Object.keys(t.nodes).sort(),s=new Map;for(let i=0;i<r.length;i+=1)s.set(r[i],`n${i}`);let o=[`direction: ${fr(n)}`];for(let i of r){let a=s.get(i);o.push(`${a}: "${dr(i)}"`)}for(let[i,a]of ln(t)){let l=s.get(i),u=s.get(a);!l||!u||o.push(`${l} -> ${u}`)}return o.join(`
|
|
7
|
+
`)}function br(t){return t.replace(/[.*+?^${}()|[\]\\]/g,"\\$&")}function Ue(t){let e="^";for(let n=0;n<t.length;n+=1){let r=t[n];if(r==="*"){e+=".*";continue}if(r==="?"){e+=".";continue}if(r==="["){let s=t.indexOf("]",n+1);if(s<=n+1){e+="\\[";continue}let o=t.slice(n+1,s);o.startsWith("!")&&(o=`^${o.slice(1)}`),o=o.replace(/\\/g,"\\\\"),e+=`[${o}]`,n=s;continue}e+=br(r)}return e+="$",new RegExp(e)}var yr={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"},vr={data:"",dirty:"",resolved:"",invalidate:"",pause:"",resume:"",complete:"",error:"",teardown:"",derived:"",path:"",reset:""};function Ke(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 _r(t){return t==="none"?vr:t==="ansi"||t==null?yr:{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 un(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 xr(t,e,n){for(let r=0;r<t.length;r++){let s=t.charCodeAt(r);if(s<32||s===127)throw new Error(`Graph "${e}": ${n} "${t}" must not contain control character (U+${s.toString(16).padStart(4,"0").toUpperCase()} at index ${r})`)}}function vt(t,e,n){if(t==="")throw new Error(`Graph "${e}": ${n} name must be non-empty`);if(t.includes(G))throw new Error(`Graph "${e}": ${n} "${t}" must not contain '${G}' (path separator)`);if(t===j)throw new Error(`Graph "${e}": ${n} name "${j}" is reserved for meta companion paths`);xr(t,e,n)}function wr(t,e){if(t==="")throw new Error(`Graph "${e}": resolve path must be non-empty`);let n=t.split(G);for(let r of n)if(r==="")throw new Error(`Graph "${e}": resolve path has empty segment`);return n}function Or(t,e){let n=!1;for(let s of t)if(!e.isMetaPassthrough(s[0])){n=!0;break}return n?t.filter(s=>e.isMetaPassthrough(s[0])):t}function fn(t){for(let e of t._mounts.values())fn(e);for(let e of t._nodes.values())try{e.down([[H]],{internal:!0})}catch{}}var ne=class t{name;opts;config;_nodes=new Map;_nodeToName=new WeakMap;_mounts=new Map;_parent=void 0;_storageDisposers=new Set;_disposers=new Set;_topology;_topologyEmitters=new Set;constructor(e,n){if(e==="")throw new Error("Graph name must be non-empty");if(e.includes(G))throw new Error(`Graph name must not contain '${G}' (got "${e}")`);if(e===j)throw new Error(`Graph name "${j}" is reserved for meta companion paths`);this.name=e,this.opts=Object.freeze({...n??{}}),this.config=n?.config??de,this._traceRing=new _e(n?.traceCapacity??1e3),n?.versioning!=null&&this.setVersioning(n.versioning)}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=zt(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)}add(e,n){let r=e.name,s=n?.name??r;if(s==null||s==="")throw new Error(`Graph "${this.name}": graph.add requires a non-empty name \u2014 pass via opts.name or set it on the node (e.g. state(0, { name: "x" }))`);let o=s,i=n?.annotation;if(vt(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:le()})),e}setVersioning(e){if(e!=null)for(let n of this._nodes.values())n instanceof I&&n._applyVersioning(e)}remove(e){vt(e,this.name,"remove");let n=this._mounts.get(e);if(n){let o={kind:"mount",nodes:[],mounts:[]},i=[];n._collectObserveTargets("",i);for(let[a,l]of i)a.includes(`${G}${j}${G}`)||o.nodes.push(a);return o.nodes.sort(),o.mounts.push(e),o.mounts.push(...n._collectSubgraphs(`${e}${G}`)),this._mounts.delete(e),n._parent=void 0,fn(n),this._emitTopology({kind:"removed",name:e,nodeKind:"mount",audit:o}),o}let r=this._nodes.get(e);if(!r)throw new Error(`Graph "${this.name}": unknown node or mount "${e}"`);this._nodes.delete(e),this._nodeToName.delete(r),r.down([[H]],{internal:!0});let s={kind:"node",nodes:[e],mounts:[]};return this._emitTopology({kind:"removed",name:e,nodeKind:"node",audit:s}),s}removeAll(e){let n=typeof e=="function"?e:(()=>{let o=Ue(e);return i=>o.test(i)})(),r={kind:"mount",nodes:[],mounts:[]},s=[...this._nodes.keys(),...this._mounts.keys()].filter(o=>n(o));for(let o of s){let i=this.remove(o);r.nodes.push(...i.nodes),r.mounts.push(...i.mounts)}return r.nodes.sort(),r.mounts.sort(),r}[Symbol.iterator](){let e=[...this._nodes.keys()].sort(),n=this._nodes,r=0;return{[Symbol.iterator](){return this},next(){if(r>=e.length)return{value:void 0,done:!0};let s=e[r++];return{value:[s,n.get(s)],done:!1}}}}node(e){if(e==="")throw new Error(`Graph "${this.name}": node name must be non-empty`);if(e.includes(G))return this.resolve(e);let n=this._nodes.get(e);if(!n)throw new Error(`Graph "${this.name}": unknown node "${e}"`);return n}get(e){return this.node(e).cache}set(e,n,r){let s=r?.internal===!0;this.node(e).down([[P,n]],{actor:r?.actor,internal:s,delivery:"write"})}setAll(e,n){let r=Symbol.iterator in e?e:Object.entries(e);Ct(()=>{for(let[s,o]of r)this.set(s,o,n)})}invalidate(e,n){let r=n?.internal===!0;this.node(e).down([[q]],{actor:n?.actor,internal:r,delivery:"write"})}error(e,n,r){let s=r?.internal===!0;this.node(e).down([[L,n]],{actor:r?.actor,internal:s,delivery:"write"})}complete(e,n){let r=n?.internal===!0;this.node(e).down([[Y]],{actor:n?.actor,internal:r,delivery:"write"})}edges(e){let n=e?.recursive===!0,r=new Map;if(!n){for(let[l,u]of this._nodes)r.set(u,l);let a=[];for(let[l,u]of this._nodes)if(u instanceof I)for(let c of u._deps){let f=r.get(c.node);f!=null&&a.push([f,l])}return a.sort((l,u)=>l[0]<u[0]?-1:l[0]>u[0]?1:l[1]<u[1]?-1:l[1]>u[1]?1:0),a}let s=[];this._collectObserveTargets("",s);let o=new Map;for(let[a,l]of s)o.set(l,a);let i=[];for(let[a,l]of s)if(l instanceof I)for(let u of l._deps){let c=o.get(u.node);c!=null&&i.push([c,a])}return i.sort((a,l)=>a[0]<l[0]?-1:a[0]>l[0]?1:a[1]<l[1]?-1:a[1]>l[1]?1:0),i}mount(e,n){if(vt(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 r=this;r!=null;r=r._parent)if(r===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 n=wr(e,this.name);return this._resolveFromSegments(n)}tryResolve(e){try{return this.resolve(e)}catch{return}}_resolveFromSegments(e){let n=e;if(n[0]===this.name&&(n=n.slice(1),n.length===0))throw new Error(`Graph "${this.name}": resolve path ends at graph name only`);let r=n[0],s=n.slice(1);if(s.length===0){let a=this._nodes.get(r);if(a)return a;throw this._mounts.has(r)?new Error(`Graph "${this.name}": path ends at subgraph "${r}" \u2014 not a node (GRAPHREFLY-SPEC \xA73.5)`):new Error(`Graph "${this.name}": unknown name "${r}"`)}let o=this._nodes.get(r);if(o&&s.length>0&&s[0]===j)return this._resolveMetaChainFromNode(o,s,n.join(G));let i=this._mounts.get(r);if(!i)throw this._nodes.has(r)?new Error(`Graph "${this.name}": "${r}" is a node; trailing path "${s.join(G)}" is invalid`):new Error(`Graph "${this.name}": unknown mount or node "${r}"`);return i.resolve(s.join(G))}_resolveMetaChainFromNode(e,n,r){let s=e,o=0,i=[...n];for(;o<i.length;){if(i[o]!==j)throw new Error(`Graph "${this.name}": expected ${j} segment in meta path "${r}"`);if(o+1>=i.length)throw new Error(`Graph "${this.name}": meta path requires a key after ${j} in "${r}"`);let a=i[o+1],l=s.meta[a];if(!l)throw new Error(`Graph "${this.name}": unknown meta "${a}" in path "${r}"`);s=l,o+=2}return s}signal(e,n){if(n?.internal!==!0){for(let s of e)if(this.config.messageTier(s[0])===3)throw new Error(`Graph "${this.name}": Graph.signal() rejects tier-3 messages (DATA / RESOLVED). Broadcast is for control-plane tiers (START / DIRTY / INVALIDATE / PAUSE / RESUME / COMPLETE / ERROR / TEARDOWN). For per-node value writes, use Graph.set or graph.node(name).down(...).`)}let r=[];if(this._signalDeliver(e,n??{},new Set,r),r.length>0)throw r[0]}_signalDeliver(e,n,r,s){for(let l of this._mounts.values())l._signalDeliver(e,n,r,s);let i=n.internal===!0?{internal:!0}:{actor:n.actor,delivery:"signal"},a=Or(e,this.config);for(let l of[...this._nodes.keys()].sort()){let u=this._nodes.get(l);if(!r.has(u)){r.add(u);try{u.down(e,i)}catch(c){if(c instanceof U)throw c;s.push(c)}a.length!==0&&this._signalMetaSubtree(u,a,r,i,s)}}}_signalMetaSubtree(e,n,r,s,o){for(let i of Object.keys(e.meta).sort()){let a=e.meta[i];if(!r.has(a)){r.add(a);try{a.down(n,s)}catch(l){if(l instanceof U)throw l;o.push(l)}this._signalMetaSubtree(a,n,r,s,o)}}}describe(e){if(e?.reactive===!0)return this._describeReactive(e);let n=e?.actor,r=e?.filter,s=Fe(e?.detail,e?.fields),o=e?.format==="spec",i=o?Fe("minimal"):s,a=[];this._collectObserveTargets("",a);let l=new Map;for(let[x,w]of a)l.set(w,x);let u=[];{let x=a.map(([,k])=>k),w=new Set(l.values()),T=0;for(;x.length>0;){let k=x.shift();if(k instanceof I)for(let R of k._deps){let N=R.node;if(l.has(N))continue;let D=N.name??"",S=D;if(!S||w.has(S))if(D){let $=2;for(;w.has(`${D}#${$}`);)$++;S=`${D}#${$}`}else for(S=`__internal__/${T++}`;w.has(S);)S=`__internal__/${T++}`;l.set(N,S),w.add(S),u.push([S,N]),x.push(N)}}}let c=[...a,...u],f={};for(let[x,w]of c){if(n!=null&&!w.allowsObserve(n))continue;let T=gt(w,i),k=w instanceof I?w._deps.map(S=>l.get(S.node)??S.node.name??""):[],{name:R,...N}=T,D={...N,deps:k};if(!o){let S=this._annotations.get(x);S!=null&&(D.annotation=S)}if(r!=null)if(typeof r=="function"){let S=r;if(!(S.length>=2?S(x,D):S(D)))continue}else{let S=!0;for(let[$,V]of Object.entries(r)){let K=$==="deps_includes"?"depsIncludes":$==="meta_has"?"metaHas":$;if(K==="depsIncludes"){if(!D.deps.includes(String(V))){S=!1;break}continue}if(K==="metaHas"){if(!Object.hasOwn(D.meta??{},String(V))){S=!1;break}continue}if(D[K]!==V){S=!1;break}}if(!S)continue}f[x]=D}let h=new Set(Object.keys(f)),p=[];for(let[x,w]of c)if(w instanceof I)for(let T of w._deps){let k=l.get(T.node);k!=null&&p.push([k,x])}p.sort((x,w)=>x[0]<w[0]?-1:x[0]>w[0]?1:x[1]<w[1]?-1:x[1]>w[1]?1:0);let d=p.map(([x,w])=>({from:x,to:w}));(n!=null||r!=null)&&(d=d.filter(x=>h.has(x.from)&&h.has(x.to)));let g=this._collectSubgraphs(""),b=n!=null||r!=null?g.filter(x=>{let w=`${x}${G}`;return[...h].some(T=>T===x||T.startsWith(w))}):g,v=this,_=e,m={name:this.name,nodes:f,edges:d,subgraphs:b,expand(x){let w={..._,format:void 0};return Array.isArray(x)?(w.fields=x,w.detail=void 0):(w.detail=x,w.fields=void 0),v.describe(w)}},y=e??{},O=y.format;return O==="json"?pr(m,y):O==="pretty"?hr(m,y):O==="mermaid"?dn(m,y):O==="mermaid-url"?gr(m,y):O==="d2"?mr(m,y):O==="ascii"?sn(m,y):m}_collectSubgraphs(e){let n=[];for(let r of[...this._mounts.keys()].sort()){let s=e===""?r:`${e}${r}`;n.push(s),n.push(...this._mounts.get(r)._collectSubgraphs(`${s}${G}`))}return n}resourceProfile(e){return We(this,e)}reachable(e,n,r={}){return r.withDetail===!0?qe(this.describe(),e,n,{...r,withDetail:!0}):qe(this.describe(),e,n,r)}explain(e,n,r){return r?.reactive===!0?this._explainReactive(e,n,r):this._explainStatic(e,n,r)}_explainStatic(e,n,r){let s=this.describe({detail:"full"}),o=new Map(this._annotations),i=new Map;for(let[a,l]of Object.entries(s.nodes))l.lastMutation!=null&&i.set(a,l.lastMutation);return Re(s,e,n,{...r?.maxDepth!=null?{maxDepth:r.maxDepth}:{},...r?.findCycle===!0?{findCycle:!0}:{},annotations:o,lastMutations:i})}_describeReactive(e){let n={...e,reactive:!1},r=e.reactiveName??"describe",s=0,o=He(s,{name:`${r}_version`}),i=this.observe({timeline:!0,structured:!0}),a=!1,l=!1,u=()=>{a||l||(a=!0,me(()=>{a=!1,!l&&(s+=1,o.emit(s))}))},c=i.onEvent(b=>{let v=b.type;v!=="data"&&v!=="error"&&v!=="complete"&&v!=="teardown"||u()}),f=[],h=new WeakSet,p=b=>{if(h.has(b)||l)return;h.add(b);let v=b.topology.subscribe(_=>{for(let m of _){if(m[0]!==P)continue;let y=m[1];if(u(),y.kind==="added"&&y.nodeKind==="mount"){let O=b._mounts.get(y.name);O!=null&&p(O)}}});f.push(v);for(let _ of b._mounts.keys()){let m=b._mounts.get(_);m!=null&&p(m)}};p(this);let d;try{d=mt([o],()=>this.describe(n),{name:r,describeKind:"derived",meta:{domain:"audit",kind:"describe"},equals:(b,v)=>b===v})}catch(b){c();for(let v of f)v();throw i.dispose(),b}let g=bt(d);return{node:d,dispose(){l=!0,c();for(let b of f)b();f.length=0,i.dispose(),g()}}}_explainReactive(e,n,r){let s=0,o=He(s,{name:"explain_version"}),i=this.observe({timeline:!0,structured:!0}),a=!1,l=!1,u=i.onEvent(p=>{let d=p.type;d!=="data"&&d!=="error"&&d!=="complete"&&d!=="teardown"||a||l||(a=!0,me(()=>{a=!1,!l&&(s+=1,o.emit(s))}))}),c={...r?.maxDepth!=null?{maxDepth:r.maxDepth}:{},...r?.findCycle===!0?{findCycle:!0}:{}},f;try{f=mt([o],()=>this._explainStatic(e,n,c),{name:r?.name??"explain",describeKind:"derived",meta:{domain:"audit",kind:"explain_path",from:e,to:n},equals:(p,d)=>p.found===d.found&&p.reason===d.reason&&p.steps.length===d.steps.length&&Tr(p.steps,d.steps)})}catch(p){throw u(),i.dispose(),p}let h=bt(f);return{node:f,dispose(){l=!0,u(),i.dispose(),h()}}}_pathsMatching(e){let n=Ue(e),r=[];return this._collectObserveTargets("",r),r.map(([s])=>s).filter(s=>n.test(s))}_collectObserveTargets(e,n){for(let r of[...this._mounts.keys()].sort()){let s=e===""?r:`${e}${G}${r}`;this._mounts.get(r)._collectObserveTargets(s,n)}for(let r of[...this._nodes.keys()].sort()){let s=this._nodes.get(r),o=e===""?r:`${e}${G}${r}`;n.push([o,s]),this._appendMetaObserveTargets(o,s,n)}}_appendMetaObserveTargets(e,n,r){for(let s of Object.keys(n.meta).sort()){let o=n.meta[s],i=`${e}${G}${j}${G}${s}`;r.push([i,o]),this._appendMetaObserveTargets(i,o,r)}}observe(e,n){let r=typeof e=="string",o=un(r?n:e),i=o.structured===!0||o.timeline===!0||o.causal===!0||o.derived===!0||o.detail==="minimal"||o.detail==="full"||o.format!=null,a=o.actor;if(r){let c=e,f=this.resolve(c);if(a!=null&&!f.allowsObserve(a))throw new U({actor:a,action:"observe",nodeName:c});return i?this._buildStructuredObserver([[c,f]],o,"one"):{subscribe(h){return f.subscribe(h)},up(h){try{f.up?.(h)}catch(p){if(p instanceof U)return;throw p}}}}let l=[];this._collectObserveTargets("",l),l.sort((c,f)=>c[0]<f[0]?-1:c[0]>f[0]?1:0);let u=a==null?l:l.filter(([,c])=>c.allowsObserve(a));return i?this._buildStructuredObserver(u,o,"all"):{subscribe:c=>{let f=u.map(([h,p])=>p.subscribe(d=>{c(h,d)}));return()=>{for(let h of f)h()}},up:(c,f)=>{try{this.resolve(c).up?.(f)}catch(h){if(h instanceof U)return;throw h}}}}_buildStructuredObserver(e,n,r){let s=r==="one"?e[0]?.[0]:void 0,o=i=>{if(r==="one"&&s!=null){let c=this.resolve(s);return this._buildStructuredObserver([[s,c]],i,"one")}let a=[];this._collectObserveTargets("",a),a.sort((c,f)=>c[0]<f[0]?-1:c[0]>f[0]?1:0);let l=i.actor,u=l==null?a:a.filter(([,c])=>c.allowsObserve(l));return this._buildStructuredObserver(u,i,"all")};return this._createObserveResult(e,n,o)}_createObserveResult(e,n,r){let s=n.timeline===!0,o=n.causal===!0,i=n.derived===!0,a=n.detail==="minimal",l=this.config.inspectorEnabled,u=(o||i)&&l,c=n.maxEvents,f=c!=null&&c>0?new _e(c):null,h=[],p=new Set,d={},g=new Set,b=0,v=0,_=0,m=0,y=0,O=0,x=!1,w=!1,T=0,k=new Map,R=new Map,N=new Map,D=E=>{f?f.push(E):h.push(E);for(let C of p)C(E)},S=()=>s?{timestamp_ns:le(),in_batch:Ce(),batch_id:T}:{},$=(E,C)=>{if(!(!u||!(E instanceof I)))return E._setInspectorHook(B=>{if(B.kind==="dep_message")k.set(E,B.depIndex);else if(B.kind==="run"){let fe=B.batchData.map((A,F)=>A!=null&&A.length>0?A.at(-1):B.prevData[F]);R.set(E,fe);let z=B.batchData.map(A=>A!=null?[...A]:void 0);N.set(E,z),i&&D({type:"derived",path:C,dep_values:fe,dep_batches:z,...S()})}})},V=E=>{let C=k.get(E),B=R.get(E);if(!o||B==null)return{};let z=(C!=null&&C>=0&&E instanceof I?E._deps[C]:void 0)?.node,A=z?.v,F=N.get(E);return{trigger_dep_index:C,trigger_dep_name:z?.name,...A!=null?{trigger_version:{id:A.id,version:A.version}}:{},dep_values:[...B],...F!=null?{dep_batches:F}:{}}},K=[],re=[];for(let[E,C]of e){let B=$(C,E);B&&K.push(B),re.push(C.subscribe(fe=>{T++;for(let z of fe){let A=z[0],F=S();if(A===P){d[E]=z[1];let Ze=C instanceof I?C.lastMutation?.actor??ie:ie;D({type:"data",path:E,data:z[1],actor:Ze,...F,...V(C)})}else if(a)A===J?b++:A===X?v++:A===q?_++:A===Z?m++:A===Q?y++:A===H?O++:A===Y&&!g.has(E)?x=!0:A===L&&(w=!0,g.add(E));else if(A===J)b++,D({type:"dirty",path:E,...F});else if(A===X)v++,D({type:"resolved",path:E,...F,...V(C)});else if(A===q)_++,D({type:"invalidate",path:E,...F});else if(A===Z)m++,D({type:"pause",path:E,lockId:z[1],...F});else if(A===Q)y++,D({type:"resume",path:E,lockId:z[1],...F});else if(A===Y)g.has(E)||(x=!0),D({type:"complete",path:E,...F});else if(A===L){w=!0,g.add(E);let Ze=C instanceof I?C.lastMutation?.actor??ie:ie;D({type:"error",path:E,data:z[1],actor:Ze,...F})}else A===H&&(O++,D({type:"teardown",path:E,...F}))}}))}let Ye=!1,Je=()=>{if(!Ye){Ye=!0;for(let E of re)E();for(let E of K)E();for(let E of xe)E({value:void 0,done:!0});xe.length=0}},Xe=[],xe=[];p.add(E=>{let C=xe.shift();C?C({value:E,done:!1}):Xe.push(E)});let Ot={get values(){return d},get dirtyCount(){return b},get resolvedCount(){return v},get invalidateCount(){return _},get pauseCount(){return m},get resumeCount(){return y},get teardownCount(){return O},get events(){return f?f.toArray():[...h]},get anyCompletedCleanly(){return x},get anyErrored(){return w},get completedWithoutErrors(){return x&&!w},onEvent(E){return p.add(E),()=>p.delete(E)},dispose:Je,expand(E){Je();let C={...n};return typeof E=="string"?C.detail=E:Object.assign(C,E),r(un(C))},[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(E=>xe.push(E))},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 s=n.logger??(d=>console.log(d)),o=n.includeTypes?new Set(n.includeTypes):null,i=n.excludeTypes?new Set(n.excludeTypes):null,a=o==null&&i==null?()=>!0:d=>(o==null||o.has(d))&&(i==null||!i.has(d)),l=_r(n.theme),u=r==="stage-log"?le():0,c=d=>d==null?"":n.stageLabels?.[d]??d,f=(d,g)=>d.length>g?`${d.slice(0,g-1)}\u2026`:d,h=d=>d.type==="data"||d.type==="error"?f(Ke(d.data),120):"",p=d=>{if(r==="stage-log"){let w=(le()-u)/1e9,T=c(d.path).padEnd(9);if(d.type==="data"){let k=h(d);return`[${w.toFixed(3)}s] ${T} \u2190${k?` ${k}`:""}`}if(d.type==="error"){let k=h(d);return`[${w.toFixed(3)}s] ${T} \u2717${k?` ${k}`:""}`}return d.type==="complete"?`[${w.toFixed(3)}s] ${T} \u25A0 complete`:`[${w.toFixed(3)}s] ${T} ${d.type}`}if(r==="json")try{return JSON.stringify(d)}catch{return JSON.stringify({type:d.type,path:d.path,data:"[unserializable]"})}let g=l[d.type]??"",b=d.path?`${l.path}${d.path}${l.reset} `:"",v=d.type==="data"||d.type==="error",_=d.type==="pause"||d.type==="resume",m=v?` ${Ke(d.data)}`:_?` ${Ke(d.lockId)}`:"",y=d.type==="data"||d.type==="resolved"||d.type==="derived"?d:void 0,O=y?.trigger_dep_name!=null?` <- ${y.trigger_dep_name}`:y?.trigger_dep_index!=null?` <- #${y.trigger_dep_index}`:"",x=d.in_batch?" [batch]":"";return`${b}${g}${d.type.toUpperCase()}${l.reset}${m}${O}${x}`};e.onEvent(d=>{a(d.type)&&s(p(d),d)})}addDisposer(e){return this._disposers.add(e),()=>{this._disposers.delete(e)}}destroy(){on(this._disposers,this.name),this.signal([[H]],{internal:!0}),on(this._storageDisposers,this.name);for(let e of[...this._mounts.values()])e._parent=void 0,e._destroyClearOnly();this._mounts.clear(),this._nodes.clear(),this._parent=void 0}_destroyClearOnly(){for(let e of[...this._mounts.values()])e._parent=void 0,e._destroyClearOnly();this._mounts.clear(),this._nodes.clear(),this._parent=void 0}snapshot(e){let{expand:n,...r}=this.describe({detail:"full"}),s={};for(let a of Object.keys(r.nodes).sort()){let{lastMutation:l,guard:u,...c}=r.nodes[a];s[a]=c}let o=[...r.subgraphs].sort(),i={...r,version:1,nodes:s,subgraphs:o};if(e?.format==null)return i;if(e.format==="json-string")return JSON.stringify(i);if(e.format==="bytes"){if(e.codec==null)throw new Error("snapshot({format: 'bytes'}) requires a `codec` name");let a=this.config.lookupCodec(e.codec);if(a==null)throw new Error(`snapshot: codec "${e.codec}" is not registered on this graph's config. Call config.registerCodec(...) before creating nodes.`);return Oe(a,a.encode(i))}throw new Error(`snapshot: unknown format "${String(e.format)}"`)}static decode(e,n){let r=n?.config??de,{codec:s,codecVersion:o,payload:i}=Te(e,r);return s.decode(i,o)}restore(e,n){if(an(e),e.name!==this.name)throw new Error(`Graph "${this.name}": restore snapshot name "${e.name}" does not match this graph`);let r=n?.only==null?null:(Array.isArray(n.only)?n.only:[n.only]).map(o=>Ue(o)),s=n?.includeProducers===!0;for(let o of Object.keys(e.nodes).sort()){if(r!==null&&!r.some(a=>a.test(o)))continue;let i=e.nodes[o];if(i!==void 0){if(!("value"in i)||i.value===void 0){"value"in i&&i.value===void 0&&n?.onError?.(o,new Error(`restore: slice.value is undefined for "${o}" (undefined is the global SENTINEL; not valid DATA)`));continue}if(!(i.type==="derived"||i.type==="effect")&&!(i.type==="producer"&&!s)){if(i.v!=null){let l=this.tryResolve(o)?.v;if(l!=null&&l.id===i.v.id&&l.version===i.v.version)continue}try{this.set(o,i.value)}catch(a){n?.onError?.(o,a)}}}}}static fromSnapshot(e,n){an(e);let r=typeof n=="function"?n:n?.build,s=typeof n=="function"?void 0:n?.factories,o=new t(e.name);if(r)return r(o),o.restore(e),o;for(let p of[...e.subgraphs].sort((d,g)=>{let b=d.split(G).length,v=g.split(G).length;return b!==v?b-v:d<g?-1:d>g?1:0})){let d=p.split(G),g=o;for(let b of d)g._mounts.has(b)||g.mount(b,new t(b)),g=g._mounts.get(b)}let i=s?Object.entries(s).map(([p,d])=>({re:Ue(p),factory:d})):[],a=p=>{for(let d of i)if(d.re.test(p))return d.factory},l=p=>{let d=p.split(G),g=d.pop();if(g==null||g.length===0)throw new Error(`invalid snapshot path "${p}"`);let b=o;for(let v of d){let _=b._mounts.get(v);if(!_)throw new Error(`unknown mount "${v}" in path "${p}"`);b=_}return[b,g]},u=Object.entries(e.nodes).filter(([p])=>!p.includes(`${G}${j}${G}`)).sort((p,d)=>p[0]<d[0]?-1:p[0]>d[0]?1:0),c=new Map(u),f=new Map,h=!0;for(;c.size>0&&h;){h=!1;for(let[p,d]of[...c.entries()]){let g=d?.deps??[];if(!g.every(O=>f.has(O)))continue;let[b,v]=l(p),_={...d?.meta??{}},m=a(p),y;if(d?.type==="state")y=He(d.value,{meta:_});else{if(m==null)continue;y=m(v,{path:p,type:d.type,value:d.value,meta:_,deps:g,resolvedDeps:g.map(O=>f.get(O))})}b.add(y,{name:v}),f.set(p,y),c.delete(p),h=!0}}if(c.size>0){let p=[...c.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()}attachStorage(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 s=(u,c)=>{if(u.disposed)return;let f=ur(c.nodes);if(u.lastSnapshot!=null&&f!==""&&f===u.lastFingerprint)return;let h=u.seq+1,p=Me(),b=u.lastSnapshot==null||h%u.compactEvery===0?{mode:"full",snapshot:c,seq:h,timestamp_ns:p,format_version:te}:{mode:"diff",diff:wt(u.lastSnapshot,c),seq:h,timestamp_ns:p,format_version:te};if(u.tier.filter&&!u.tier.filter(this.name,b))return;let v;try{v=u.tier.save(this.name,b)}catch(_){n.onError?.(_,u.tier);return}if(v&&typeof v.then=="function"){let y=(u.savePending??Promise.resolve()).then(()=>v,()=>v).then(()=>{u.disposed||(u.seq=h,u.lastSnapshot=c,u.lastFingerprint=f)},O=>{n.onError?.(O,u.tier)});u.savePending=y.finally(()=>{u.savePending===y&&(u.savePending=void 0)})}else u.seq=h,u.lastSnapshot=c,u.lastFingerprint=f},o=(u,c)=>{try{s(u,c)}catch(f){n.onError?.(f,u.tier)}},i=(u,c)=>{if(!c.some(d=>{let g=this.config.messageTier(d[0]);return g>=3&&g<5}))return;if(n.filter){let d=this.tryResolve(u);if(d==null)return;let g=gt(d,Fe("standard"));if(!n.filter(u,g))return}let h,p=()=>(h==null&&(h=this.snapshot()),h);for(let d of r)d.disposed||(d.debounceMs===0?o(d,p()):(d.timer==null&&(d.timer=new Ve),d.timer.start(d.debounceMs,()=>{d.disposed||o(d,this.snapshot())})))},a;if(n.paths!=null){let c=(typeof n.paths=="string"?this._pathsMatching(n.paths):n.paths).map(f=>{let h=this.tryResolve(f);return h==null?()=>{}:h.subscribe(p=>i(f,p))});a=()=>{for(let f of c)f()}}else a=this.observe().subscribe((u,c)=>i(u,c));let l=()=>{a();for(let u of r)u.disposed=!0,u.timer?.cancel();this._storageDisposers.delete(l)};return this._storageDisposers.add(l),{dispose:l}}async _cascadeRestore(e,n){for(let r of e){let s;try{s=await r.load(this.name)}catch(i){n?.(i,r);continue}if(s==null||typeof s!="object"||Array.isArray(s))continue;let o=s;try{if(o.mode==="full"&&o.snapshot!=null)return this.restore(o.snapshot),!0;if(o.version===te&&o.nodes!=null)return this.restore(o),!0}catch(i){n?.(i,r)}}return!1}static async fromStorage(e,n,r){for(let s of n){let o;try{o=await s.load(e)}catch(l){r?.onError?.(l,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===te&&i.nodes!=null?i:void 0;if(a!=null)try{return t.fromSnapshot(a,r)}catch(l){r?.onError?.(l,s)}}throw new Error(`Graph.fromStorage: no tier held a restorable record for "${e}" across ${n.length} tier(s)`)}_annotations=new Map;_traceRing;trace(e,n,r){if(e!=null&&n!=null){if(this.tryResolve(e)==null)return;if(this._annotations.set(e,n),this.config.inspectorEnabled){let s={path:e,annotation:n,timestamp_ns:le(),...r?.actor!=null?{actor:r.actor}:{}};this._traceRing.push(s)}return}return e!=null?this.config.inspectorEnabled?this._annotations.get(e):void 0:this.config.inspectorEnabled?this._traceRing.toArray():[]}annotation(e){return this._annotations.get(e)}clearTrace(){this._annotations.clear(),this._traceRing.clear()}pruneTrace(e){let n=this._traceRing.toArray().filter(s=>!e(s)),r=this._traceRing.size-n.length;this._traceRing.clear();for(let s of n)this._traceRing.push(s);return r}static diff(e,n){let r=new Set(Object.keys(e.nodes)),s=new Set(Object.keys(n.nodes)),o=[...s].filter(_=>!r.has(_)).sort(),i=[...r].filter(_=>!s.has(_)).sort(),a=[],l=[];for(let _ of r){if(!s.has(_))continue;let m=e.nodes[_],y=n.nodes[_],O=m.v,x=y.v;O!=null&&x!=null&&O.id===x.id&&O.version!==x.version&&l.push({path:_,id:O.id,from:O.version,to:x.version});let w=O!=null&&x!=null&&O.id===x.id&&O.version===x.version;for(let T of["type","status","sentinel"]){let k=m[T],R=y[T];k!==R&&a.push({path:_,field:T,from:k,to:R})}if(!w)for(let T of["value","meta"]){let k=m[T],R=y[T];lr(k,R)||a.push({path:_,field:T,from:k,to:R})}}let u=_=>`${_.from} ${_.to}`,c=new Set(e.edges.map(u)),f=new Set(n.edges.map(u)),h=n.edges.filter(_=>!c.has(u(_))),p=e.edges.filter(_=>!f.has(u(_))),d=new Set(e.subgraphs),g=new Set(n.subgraphs),b=[...g].filter(_=>!d.has(_)).sort(),v=[...d].filter(_=>!g.has(_)).sort();return{nodesAdded:o,nodesRemoved:i,nodesChanged:a,versionChanges:l,edgesAdded:h,edgesRemoved:p,subgraphsAdded:b,subgraphsRemoved:v}}};function wt(t,e){let n=ne.diff(t,e),r={};for(let s of n.nodesAdded){let o=e.nodes[s];o!=null&&(r[s]=o)}return{...n,nodesAddedFull:r}}function qe(t,e,n,r={}){let s={paths:[],depths:new Map,truncated:!1};if(!e)return r.withDetail?s:[];if(!r.both&&n!=="upstream"&&n!=="downstream")throw new Error('reachable: direction must be "upstream" or "downstream"');let o=r.maxDepth;if(o!=null&&(!Number.isInteger(o)||o<0))throw new Error("reachable: maxDepth must be an integer >= 0");if(o===0)return r.withDetail?s:[];let i=new Map,a=new Map,l=new Map,u=new Map,c=new Set;for(let[m,y]of Object.entries(t.nodes)){if(!m)continue;c.add(m);let O=y.deps??[];i.set(m,O);for(let x of O)x&&(c.add(x),a.has(x)||a.set(x,new Set),a.get(x).add(m))}for(let m of t.edges){if(m==null||typeof m!="object")continue;let y=typeof m.from=="string"?m.from:"",O=typeof m.to=="string"?m.to:"";!y||!O||(c.add(y),c.add(O),u.has(y)||u.set(y,new Set),u.get(y).add(O),l.has(O)||l.set(O,new Set),l.get(O).add(y))}if(!c.has(e))return r.withDetail?s:[];let f=r.both===!0,h=m=>{if(f){let w=i.get(m)??[],T=l.get(m),k=a.get(m),R=u.get(m),N=[...w];return T&&N.push(...T),k&&N.push(...k),R&&N.push(...R),N}if(n==="upstream"){let w=i.get(m)??[],T=l.get(m);return T?[...w,...T]:w}let y=a.get(m),O=u.get(m),x=y?[...y]:[];return O&&x.push(...O),x},p=new Set([e]),d=new Map,g=[{path:e,depth:0}],b=0,v=!1;for(;b<g.length;){let m=g[b++];if(o!=null&&m.depth>=o){h(m.path).length>0&&(v=!0);continue}for(let y of h(m.path))!y||p.has(y)||(p.add(y),d.set(y,m.depth+1),g.push({path:y,depth:m.depth+1}))}let _=[...d.keys()].sort((m,y)=>m<y?-1:m>y?1:0);return r.withDetail?{paths:_,depths:d,truncated:v}:_}function Tr(t,e){if(t.length!==e.length)return!1;for(let n=0;n<t.length;n++){let r=t[n],s=e[n];if(r.path!==s.path||r.type!==s.type||r.status!==s.status||r.hop!==s.hop||r.dep_index!==s.dep_index||r.annotation!==s.annotation||r.value!==s.value||r.lastMutation!==s.lastMutation)return!1;let o=r.v,i=s.v;if(o!==i&&(o==null||i==null||o.id!==i.id||o.version!==i.version))return!1}return!0}ye();function pn(t,e){let n=new Map,r=(s,o)=>{if(n.has(s))return;let i={off:()=>{},prefix:o};n.set(s,i);let a=s.topology.subscribe(l=>{for(let u of l){if(u[0]!==P)continue;let c=u[1];if(e(c,s,o),c.kind==="added"&&c.nodeKind==="mount"){let f=s._mounts.get(c.name);if(f instanceof ne){let h=`${o}${c.name}::`;r(f,h)}}else if(c.kind==="removed"&&c.nodeKind==="mount"){let f=`${o}${c.name}::`;for(let[h,p]of Array.from(n.entries()))h!==t&&p.prefix.startsWith(f)&&(p.off(),n.delete(h))}}});i.off=a;for(let[l,u]of s._mounts)if(u instanceof ne){let c=`${o}${l}::`;r(u,c)}};return r(t,""),()=>{for(let s of n.values())s.off();n.clear()}}function hn(t,e={}){let n=[],r=e.requireFound??!0;if(e.skipDescribe!==!0)try{let u=t.describe(),c=new Set(Object.keys(u.nodes)),f=[];for(let[h,p]of Object.entries(u.nodes))for(let d of p.deps)d!==""&&!c.has(d)&&f.push(`${h} \u2192 ${d}`);for(let h of u.edges)c.has(h.from)||f.push(`edge.from: ${h.from}`),c.has(h.to)||f.push(`edge.to: ${h.to}`);f.length>0?n.push({kind:"describe",ok:!1,reason:`describe() has ${f.length} dangling pointer(s); nodes \u2289 deps`,danglingDeps:f}):n.push({kind:"describe",ok:!0,nodeCount:c.size,edgeCount:u.edges.length})}catch(u){n.push({kind:"describe",ok:!1,reason:`describe() threw: ${u instanceof Error?u.message:String(u)}`})}for(let u of e.formats??[])try{let c=t.describe({format:u});typeof c!="string"||c.length===0?n.push({kind:"describe-format",ok:!1,format:u,reason:`describe({ format: "${u}" }) returned empty or non-string output`}):n.push({kind:"describe-format",ok:!0,format:u,length:c.length})}catch(c){n.push({kind:"describe-format",ok:!1,format:u,reason:c instanceof Error?c.message:String(c)})}for(let u of e.paths??[])try{t.resolve(u),n.push({kind:"observe",ok:!0,path:u})}catch(c){n.push({kind:"observe",ok:!1,path:u,reason:c instanceof Error?c.message:String(c)})}for(let[u,c]of e.pairs??[])try{let f=t.explain(u,c);r&&f.found===!1?n.push({kind:"explain",ok:!1,from:u,to:c,reason:`explain(${u} \u2192 ${c}) found no path${f.reason?`: ${f.reason}`:""}`}):n.push({kind:"explain",ok:!0,from:u,to:c,found:f.found,steps:f.steps.length})}catch(f){n.push({kind:"explain",ok:!1,from:u,to:c,reason:f instanceof Error?f.message:String(f)})}let s=n.filter(u=>!u.ok),o=s.length===0,i=e.paths?.length??0,a=e.pairs?.length??0,l=e.formats?.length??0;return{ok:o,checks:n,failures:s,summary(){let u=[e.skipDescribe===!0?null:"describe",l>0?`${l} format${l===1?"":"s"}`:null,i>0?`${i} observe path${i===1?"":"s"}`:null,a>0?`${a} explain pair${a===1?"":"s"}`:null].filter(f=>f!=null),c=u.length>0?u.join(", "):"describe-only";return o?`validateGraphObservability: OK (${c})`:`validateGraphObservability: ${s.length} failure(s) across ${c}`}}}0&&(module.exports={ENVELOPE_VERSION,GRAPH_META_SEGMENT,Graph,JsonCodec,SIZEOF_OVERHEAD,SIZEOF_SYMBOL,SNAPSHOT_VERSION,createDagCborCodec,createDagCborZstdCodec,decodeEnvelope,diffForWAL,encodeEnvelope,explainPath,graphProfile,mermaidLiveUrl,reachable,registerBuiltinCodecs,replayWAL,sizeof,validateGraphObservability,watchTopologyTree});
|
package/dist/graph/index.d.cts
CHANGED
|
@@ -1,6 +1,6 @@
|
|
|
1
|
-
export { E as ENVELOPE_VERSION, a as EvictedSubgraphInfo, b as EvictionPolicy, G as GraphCodec, J as JsonCodec, L as LazyGraphCodec, O as ObservabilityCheck, c as ObservabilityDescribeFormat, d as SIZEOF_OVERHEAD, S as SIZEOF_SYMBOL, V as ValidateObservabilityOptions, e as ValidateObservabilityResult, W as WALEntry, f as createDagCborCodec, g as createDagCborZstdCodec, h as decodeEnvelope, i as encodeEnvelope, r as registerBuiltinCodecs, k as replayWAL, s as sizeof, v as validateGraphObservability } from '../index-
|
|
2
|
-
export { C as CausalChain, e as CausalStep, D as DescribeFilter, E as ExplainPathOptions, f as GRAPH_META_SEGMENT, G as Graph, g as GraphActorOptions, h as GraphAttachStorageOptions, i as GraphCheckpointRecord, b as GraphDescribeOptions, c as GraphDescribeOutput, j as GraphDiagramDirection, k as GraphDiagramOptions, l as GraphDiffChange, m as GraphDiffResult, n as GraphFactoryContext, o as GraphNodeFactory, p as GraphObserveAll, q as GraphObserveOne, a as GraphOptions, d as GraphPersistSnapshot, r as GraphProfileOptions, s as GraphProfileResult, t as GraphVersionChange, u as GraphWALDiff, N as NodeProfile, O as ObserveDetail, v as ObserveEvent, w as ObserveOptions, x as ObserveResult, y as ObserveTheme, z as ObserveThemeName, R as ReachableDirection, A as ReachableOptions, S as SNAPSHOT_VERSION, T as TopologyEvent, B as TraceEntry, F as diffForWAL, H as explainPath, I as graphProfile, J as mermaidLiveUrl, K as reachable } from '../graph-
|
|
3
|
-
export { w as watchTopologyTree } from '../topology-tree-
|
|
4
|
-
import '../node-
|
|
5
|
-
import '../meta-
|
|
1
|
+
export { E as ENVELOPE_VERSION, a as EvictedSubgraphInfo, b as EvictionPolicy, G as GraphCodec, J as JsonCodec, L as LazyGraphCodec, O as ObservabilityCheck, c as ObservabilityDescribeFormat, d as SIZEOF_OVERHEAD, S as SIZEOF_SYMBOL, V as ValidateObservabilityOptions, e as ValidateObservabilityResult, W as WALEntry, f as createDagCborCodec, g as createDagCborZstdCodec, h as decodeEnvelope, i as encodeEnvelope, r as registerBuiltinCodecs, k as replayWAL, s as sizeof, v as validateGraphObservability } from '../index-UZO988ox.cjs';
|
|
2
|
+
export { C as CausalChain, e as CausalStep, D as DescribeFilter, E as ExplainPathOptions, f as GRAPH_META_SEGMENT, G as Graph, g as GraphActorOptions, h as GraphAttachStorageOptions, i as GraphCheckpointRecord, b as GraphDescribeOptions, c as GraphDescribeOutput, j as GraphDiagramDirection, k as GraphDiagramOptions, l as GraphDiffChange, m as GraphDiffResult, n as GraphFactoryContext, o as GraphNodeFactory, p as GraphObserveAll, q as GraphObserveOne, a as GraphOptions, d as GraphPersistSnapshot, r as GraphProfileOptions, s as GraphProfileResult, t as GraphVersionChange, u as GraphWALDiff, N as NodeProfile, O as ObserveDetail, v as ObserveEvent, w as ObserveOptions, x as ObserveResult, y as ObserveTheme, z as ObserveThemeName, R as ReachableDirection, A as ReachableOptions, S as SNAPSHOT_VERSION, T as TopologyEvent, B as TraceEntry, F as diffForWAL, H as explainPath, I as graphProfile, J as mermaidLiveUrl, K as reachable } from '../graph-C4Uxwv0T.cjs';
|
|
3
|
+
export { w as watchTopologyTree } from '../topology-tree-CVREibAc.cjs';
|
|
4
|
+
import '../node-BVV7G1bq.cjs';
|
|
5
|
+
import '../meta-COtmHLwT.cjs';
|
|
6
6
|
import '../extra/storage-core.cjs';
|
package/dist/graph/index.d.ts
CHANGED
|
@@ -1,6 +1,6 @@
|
|
|
1
|
-
export { E as ENVELOPE_VERSION, a as EvictedSubgraphInfo, b as EvictionPolicy, G as GraphCodec, J as JsonCodec, L as LazyGraphCodec, O as ObservabilityCheck, c as ObservabilityDescribeFormat, d as SIZEOF_OVERHEAD, S as SIZEOF_SYMBOL, V as ValidateObservabilityOptions, e as ValidateObservabilityResult, W as WALEntry, f as createDagCborCodec, g as createDagCborZstdCodec, h as decodeEnvelope, i as encodeEnvelope, r as registerBuiltinCodecs, k as replayWAL, s as sizeof, v as validateGraphObservability } from '../index-
|
|
2
|
-
export { C as CausalChain, e as CausalStep, D as DescribeFilter, E as ExplainPathOptions, f as GRAPH_META_SEGMENT, G as Graph, g as GraphActorOptions, h as GraphAttachStorageOptions, i as GraphCheckpointRecord, b as GraphDescribeOptions, c as GraphDescribeOutput, j as GraphDiagramDirection, k as GraphDiagramOptions, l as GraphDiffChange, m as GraphDiffResult, n as GraphFactoryContext, o as GraphNodeFactory, p as GraphObserveAll, q as GraphObserveOne, a as GraphOptions, d as GraphPersistSnapshot, r as GraphProfileOptions, s as GraphProfileResult, t as GraphVersionChange, u as GraphWALDiff, N as NodeProfile, O as ObserveDetail, v as ObserveEvent, w as ObserveOptions, x as ObserveResult, y as ObserveTheme, z as ObserveThemeName, R as ReachableDirection, A as ReachableOptions, S as SNAPSHOT_VERSION, T as TopologyEvent, B as TraceEntry, F as diffForWAL, H as explainPath, I as graphProfile, J as mermaidLiveUrl, K as reachable } from '../graph-
|
|
3
|
-
export { w as watchTopologyTree } from '../topology-tree-
|
|
4
|
-
import '../node-
|
|
5
|
-
import '../meta-
|
|
1
|
+
export { E as ENVELOPE_VERSION, a as EvictedSubgraphInfo, b as EvictionPolicy, G as GraphCodec, J as JsonCodec, L as LazyGraphCodec, O as ObservabilityCheck, c as ObservabilityDescribeFormat, d as SIZEOF_OVERHEAD, S as SIZEOF_SYMBOL, V as ValidateObservabilityOptions, e as ValidateObservabilityResult, W as WALEntry, f as createDagCborCodec, g as createDagCborZstdCodec, h as decodeEnvelope, i as encodeEnvelope, r as registerBuiltinCodecs, k as replayWAL, s as sizeof, v as validateGraphObservability } from '../index-C6NBfXj-.js';
|
|
2
|
+
export { C as CausalChain, e as CausalStep, D as DescribeFilter, E as ExplainPathOptions, f as GRAPH_META_SEGMENT, G as Graph, g as GraphActorOptions, h as GraphAttachStorageOptions, i as GraphCheckpointRecord, b as GraphDescribeOptions, c as GraphDescribeOutput, j as GraphDiagramDirection, k as GraphDiagramOptions, l as GraphDiffChange, m as GraphDiffResult, n as GraphFactoryContext, o as GraphNodeFactory, p as GraphObserveAll, q as GraphObserveOne, a as GraphOptions, d as GraphPersistSnapshot, r as GraphProfileOptions, s as GraphProfileResult, t as GraphVersionChange, u as GraphWALDiff, N as NodeProfile, O as ObserveDetail, v as ObserveEvent, w as ObserveOptions, x as ObserveResult, y as ObserveTheme, z as ObserveThemeName, R as ReachableDirection, A as ReachableOptions, S as SNAPSHOT_VERSION, T as TopologyEvent, B as TraceEntry, F as diffForWAL, H as explainPath, I as graphProfile, J as mermaidLiveUrl, K as reachable } from '../graph-CWeI0aHd.js';
|
|
3
|
+
export { w as watchTopologyTree } from '../topology-tree-CkjojcB6.js';
|
|
4
|
+
import '../node-BVV7G1bq.js';
|
|
5
|
+
import '../meta-BMwx3ExI.js';
|
|
6
6
|
import '../extra/storage-core.js';
|
package/dist/graph/index.js
CHANGED
|
@@ -1 +1 @@
|
|
|
1
|
-
import{a as t,b as u}from"../chunk-
|
|
1
|
+
import{a as t,b as u}from"../chunk-GNCBXARM.js";import{c as i,d as j,e as k,f as l,g as m,h as n,i as o,j as p,k as q,l as r,m as s}from"../chunk-MGKAO4EK.js";import"../chunk-ESMPEKEV.js";import"../chunk-TWMEGG45.js";import"../chunk-KASHOCF5.js";import{a,b,c,d,e,f,g,h}from"../chunk-W4TSQ6RJ.js";import"../chunk-CK2E7BTU.js";import"../chunk-QYADASLV.js";export{d as ENVELOPE_VERSION,n as GRAPH_META_SEGMENT,q as Graph,a as JsonCodec,j as SIZEOF_OVERHEAD,k as SIZEOF_SYMBOL,o as SNAPSHOT_VERSION,b as createDagCborCodec,c as createDagCborZstdCodec,f as decodeEnvelope,r as diffForWAL,e as encodeEnvelope,i as explainPath,m as graphProfile,p as mermaidLiveUrl,s as reachable,g as registerBuiltinCodecs,h as replayWAL,l as sizeof,u as validateGraphObservability,t as watchTopologyTree};
|
|
@@ -1,5 +1,5 @@
|
|
|
1
|
-
import { A as Actor, o as GraphReFlyConfig, V as VersioningLevel, a as Node, b as Messages, K as NodeSink } from './node-
|
|
2
|
-
import { b as DescribeNodeOutput, D as DescribeDetail, a as DescribeField } from './meta-
|
|
1
|
+
import { A as Actor, o as GraphReFlyConfig, V as VersioningLevel, a as Node, b as Messages, K as NodeSink } from './node-BVV7G1bq.cjs';
|
|
2
|
+
import { b as DescribeNodeOutput, D as DescribeDetail, a as DescribeField } from './meta-COtmHLwT.cjs';
|
|
3
3
|
import { StorageTier, StorageHandle } from './extra/storage-core.cjs';
|
|
4
4
|
|
|
5
5
|
/**
|
|
@@ -278,18 +278,33 @@ type GraphDescribeOptions = {
|
|
|
278
278
|
* clickable URL, opens the `"mermaid"` source in the mermaid.live editor).
|
|
279
279
|
* No network calls — the payload is encoded into the URL fragment.
|
|
280
280
|
* - `"d2"` — D2 diagram text.
|
|
281
|
+
* - `"ascii"` — stdout-native DAG flowchart rendered with Unicode
|
|
282
|
+
* box-drawing glyphs (or `asciiCharset: "ascii"` for pure ASCII).
|
|
283
|
+
* Graph-size independent: proper Sugiyama layout handles wide + deep
|
|
284
|
+
* DAGs. Supports `direction: "LR" | "TD"`.
|
|
281
285
|
*/
|
|
282
|
-
format?: "spec" | "json" | "pretty" | "mermaid" | "mermaid-url" | "d2";
|
|
286
|
+
format?: "spec" | "json" | "pretty" | "mermaid" | "mermaid-url" | "d2" | "ascii";
|
|
283
287
|
/** Pretty/diagram render: direction for diagram formats (default `LR`). */
|
|
284
288
|
direction?: GraphDiagramDirection;
|
|
285
289
|
/** Pretty/JSON render: indent (default 2 for JSON, ignored for pretty). */
|
|
286
290
|
indent?: number;
|
|
287
|
-
/** Pretty render: optional logger hook; fires with the rendered text before return. */
|
|
291
|
+
/** Pretty/ASCII render: optional logger hook; fires with the rendered text before return. */
|
|
288
292
|
logger?: (text: string) => void;
|
|
289
293
|
/** Pretty render: include an Edges section (default `true`). */
|
|
290
294
|
includeEdges?: boolean;
|
|
291
295
|
/** Pretty render: include a Subgraphs section (default `true`). */
|
|
292
296
|
includeSubgraphs?: boolean;
|
|
297
|
+
/**
|
|
298
|
+
* ASCII render: per-box label cell cap; longer labels are truncated with `…`.
|
|
299
|
+
* Default `24`. Applies only to `format: "ascii"`.
|
|
300
|
+
*/
|
|
301
|
+
maxLabelWidth?: number;
|
|
302
|
+
/**
|
|
303
|
+
* ASCII render: Unicode box-drawing glyphs (`"unicode"`, default) or a
|
|
304
|
+
* plain ASCII fallback (`"ascii"`, uses `-|+<>v`). Applies only to
|
|
305
|
+
* `format: "ascii"`.
|
|
306
|
+
*/
|
|
307
|
+
asciiCharset?: "unicode" | "ascii";
|
|
293
308
|
/**
|
|
294
309
|
* Reactive describe (D2): when `true`, return `{ node, dispose }` where `node`
|
|
295
310
|
* emits a fresh `GraphDescribeOutput` (or format string, if `format` is set)
|
|
@@ -954,17 +969,18 @@ declare class Graph {
|
|
|
954
969
|
* graph.describe({ format: "pretty" }) // human-readable text
|
|
955
970
|
* graph.describe({ format: "mermaid" }) // Mermaid flowchart
|
|
956
971
|
* graph.describe({ format: "d2", direction: "TD" }) // D2 top-down
|
|
972
|
+
* graph.describe({ format: "ascii" }) // stdout DAG flowchart
|
|
957
973
|
* ```
|
|
958
974
|
*/
|
|
959
975
|
describe(options: GraphDescribeOptions & {
|
|
960
976
|
reactive: true;
|
|
961
|
-
format: "json" | "pretty" | "mermaid" | "mermaid-url" | "d2";
|
|
977
|
+
format: "json" | "pretty" | "mermaid" | "mermaid-url" | "d2" | "ascii";
|
|
962
978
|
}): ReactiveDescribeHandle<string>;
|
|
963
979
|
describe(options: GraphDescribeOptions & {
|
|
964
980
|
reactive: true;
|
|
965
981
|
}): ReactiveDescribeHandle<GraphDescribeOutput>;
|
|
966
982
|
describe(options: GraphDescribeOptions & {
|
|
967
|
-
format: "json" | "pretty" | "mermaid" | "mermaid-url" | "d2";
|
|
983
|
+
format: "json" | "pretty" | "mermaid" | "mermaid-url" | "d2" | "ascii";
|
|
968
984
|
}): string;
|
|
969
985
|
describe(options?: GraphDescribeOptions): GraphDescribeOutput;
|
|
970
986
|
private _collectSubgraphs;
|