@graphrefly/graphrefly 0.37.0 → 0.38.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/{chunk-CZIQ6JCE.js → chunk-2YFDSYEF.js} +1 -1
- package/dist/{chunk-YVYSO5CW.js → chunk-4BDQXBXE.js} +1 -1
- package/dist/chunk-5BGFS2XH.js +1 -0
- package/dist/chunk-6773HURD.js +1 -0
- package/dist/{chunk-U3COB5WU.js → chunk-6KZZ6XQE.js} +1 -1
- package/dist/{chunk-5CPPC75H.js → chunk-6VFC334U.js} +1 -1
- package/dist/{chunk-KUVDFOJH.js → chunk-7KZZLWZ6.js} +1 -1
- package/dist/{chunk-Q7EUZ6NN.js → chunk-B5S7KTGP.js} +1 -1
- package/dist/chunk-CMTN3KPT.js +80 -0
- package/dist/chunk-DQJLC6YY.js +1 -0
- package/dist/chunk-DSOVKKTI.js +1 -0
- package/dist/chunk-FAYEMS5M.js +1 -0
- package/dist/chunk-FWGIZP3W.js +1 -0
- package/dist/{chunk-FMI4CWFL.js → chunk-G7JN6LCB.js} +1 -1
- package/dist/{chunk-PCD2MU7X.js → chunk-IBGE62GZ.js} +1 -1
- package/dist/{chunk-MYFR67PY.js → chunk-K5C67OGE.js} +1 -1
- package/dist/chunk-KJEAIIIY.js +43 -0
- package/dist/chunk-LV3ACS5J.js +1 -0
- package/dist/{chunk-LOQRPP4Y.js → chunk-NBGPXQSP.js} +1 -1
- package/dist/chunk-NN3QPJ6U.js +1 -0
- package/dist/{chunk-QWVQIL3T.js → chunk-NSAZ6PR6.js} +1 -1
- package/dist/{chunk-MC5LZG3U.js → chunk-NV63VQHI.js} +1 -1
- package/dist/{chunk-2C4NESZE.js → chunk-O245YLM5.js} +1 -1
- package/dist/{chunk-TLS7M7H4.js → chunk-O2BLVQU4.js} +1 -1
- package/dist/chunk-PHXZRR6C.js +1 -0
- package/dist/{chunk-K6ZFJ473.js → chunk-POCWFIJ7.js} +1 -1
- package/dist/{chunk-C5CBVOCB.js → chunk-QEVSIVSF.js} +1 -1
- package/dist/chunk-QMC2PLNM.js +7 -0
- package/dist/chunk-QOJFR6GS.js +1 -0
- package/dist/{chunk-MQZWA3DF.js → chunk-RZ5HKPGI.js} +1 -1
- package/dist/{chunk-WSLN4JFO.js → chunk-SFK7MN7S.js} +1 -1
- package/dist/{chunk-QP5TH523.js → chunk-SP5O2MIX.js} +1 -1
- package/dist/chunk-TB7JKSVS.js +61 -0
- package/dist/{chunk-T4U24DXX.js → chunk-TMVY7OWG.js} +1 -1
- package/dist/{chunk-UODQF4EY.js → chunk-UAXFKMAG.js} +1 -1
- package/dist/{chunk-TFK4P4CX.js → chunk-UVLZX2OU.js} +1 -1
- package/dist/chunk-XIMFHEKV.js +1 -0
- package/dist/{chunk-XIJKEXWR.js → chunk-XLMYQB6F.js} +1 -1
- package/dist/{chunk-4EATTNAE.js → chunk-XLYF4LBH.js} +1 -1
- package/dist/compat/index.cjs +9 -9
- package/dist/compat/index.d.cts +7 -7
- package/dist/compat/index.d.ts +7 -7
- package/dist/compat/index.js +1 -1
- package/dist/compat/nestjs/index.cjs +11 -11
- package/dist/compat/nestjs/index.d.cts +5 -5
- package/dist/compat/nestjs/index.d.ts +5 -5
- package/dist/compat/nestjs/index.js +1 -1
- package/dist/compat/zustand/index.cjs +7 -7
- package/dist/compat/zustand/index.d.cts +3 -3
- package/dist/compat/zustand/index.d.ts +3 -3
- package/dist/compat/zustand/index.js +1 -1
- package/dist/{composite-_XckYx2e.d.cts → composite-CgG0MqHm.d.cts} +8 -1
- package/dist/{composite-CT_mApQD.d.ts → composite-DTOlDuch.d.ts} +8 -1
- package/dist/core/index.cjs +1 -1
- package/dist/core/index.d.cts +2 -2
- package/dist/core/index.d.ts +2 -2
- package/dist/core/index.js +1 -1
- package/dist/extra/index.cjs +19 -19
- package/dist/extra/index.d.cts +5 -5
- package/dist/extra/index.d.ts +5 -5
- package/dist/extra/index.js +1 -1
- package/dist/extra/node.cjs +2 -2
- package/dist/extra/node.d.cts +107 -1
- package/dist/extra/node.d.ts +107 -1
- package/dist/extra/node.js +2 -2
- package/dist/extra/operators.cjs +1 -1
- package/dist/extra/operators.js +1 -1
- package/dist/extra/reactive.d.cts +1 -1
- package/dist/extra/reactive.d.ts +1 -1
- package/dist/extra/reactive.js +1 -1
- package/dist/extra/sources.cjs +1 -1
- package/dist/extra/sources.js +1 -1
- package/dist/extra/storage-tiers-browser.d.cts +76 -5
- package/dist/extra/storage-tiers-browser.d.ts +76 -5
- package/dist/extra/storage-tiers-node.d.cts +137 -13
- package/dist/extra/storage-tiers-node.d.ts +137 -13
- package/dist/extra/storage-tiers.d.cts +151 -23
- package/dist/extra/storage-tiers.d.ts +151 -23
- package/dist/graph/index.cjs +7 -7
- package/dist/graph/index.d.cts +4 -4
- package/dist/graph/index.d.ts +4 -4
- package/dist/graph/index.js +1 -1
- package/dist/{graph-YQXDndFy.d.ts → graph-BjW1taJl.d.ts} +217 -10
- package/dist/{graph-CaNXUc3c.d.cts → graph-CHsVwf9S.d.cts} +217 -10
- package/dist/{index-CUTHDZ7Q.d.ts → index-5dNRlW7J.d.ts} +3 -3
- package/dist/{index-Bpzw8hx3.d.ts → index-AUqWe_fX.d.ts} +7 -4
- package/dist/{index-fHKHdAso.d.ts → index-B-ORMr3k.d.ts} +2 -2
- package/dist/{index-DcWbx58m.d.cts → index-B2IUcH13.d.cts} +2 -2
- package/dist/{index-DuhOdNyg.d.ts → index-BFaALJxR.d.ts} +2 -2
- package/dist/{index-DPqR3wdW.d.ts → index-BI1wMfyc.d.ts} +2 -2
- package/dist/{index-D0ZxFXYl.d.ts → index-BUFCHvOR.d.ts} +2 -2
- package/dist/{index-CLPQyYY5.d.cts → index-BWUMIt7J.d.cts} +3 -3
- package/dist/{index-CkN8CZlT.d.cts → index-BaSy4L6w.d.cts} +37 -17
- package/dist/{index-B1IcU--K.d.cts → index-BgzPO43H.d.cts} +2 -2
- package/dist/{index-D6tRNEKz.d.cts → index-BhzwpIJc.d.cts} +1 -1
- package/dist/{index-4IwO4mH2.d.cts → index-BkQqf1EF.d.cts} +80 -7
- package/dist/{index-CajEOoAN.d.ts → index-BmWuVdER.d.ts} +2 -2
- package/dist/{index-0qOD-421.d.ts → index-Bn0uZEL4.d.ts} +2 -2
- package/dist/{index-DAKm44My.d.cts → index-BpMZzX9P.d.cts} +2 -2
- package/dist/{index-CrpjECS6.d.cts → index-Bpr0Pwgl.d.cts} +2 -2
- package/dist/{index-BECJ8M0T.d.cts → index-BqcgiSQg.d.cts} +2 -2
- package/dist/{index-DfAo9WKr.d.ts → index-BsZk9T8y.d.ts} +1 -1
- package/dist/{index-CU3z8Cel.d.cts → index-BsgxnHN8.d.cts} +2 -2
- package/dist/index-Bub6x_D4.d.cts +427 -0
- package/dist/{index-C-pFD_FV.d.ts → index-BwOsJfLJ.d.ts} +2 -2
- package/dist/{index-CRycrNfn.d.ts → index-Byp771zP.d.ts} +1 -1
- package/dist/{index-e1m3ZHgc.d.cts → index-C-3UXnHT.d.cts} +1 -1
- package/dist/{index-DTYIRT_v.d.cts → index-C56XZiDe.d.cts} +2 -2
- package/dist/{index-D11pGlaI.d.cts → index-CAV-3RpJ.d.cts} +2 -2
- package/dist/{index-D_DThl_J.d.cts → index-CAbHN_rP.d.cts} +1 -1
- package/dist/{index-BhLA9feT.d.ts → index-CEVzBWeB.d.ts} +2 -2
- package/dist/{index-Ci358GSC.d.cts → index-CM-i58FY.d.cts} +2 -2
- package/dist/{index-B9qJmmv3.d.cts → index-CQsqqEVz.d.cts} +1 -1
- package/dist/{index-C0tga1_x.d.ts → index-CijfwEWx.d.ts} +2 -2
- package/dist/{index-BwtIbzSV.d.cts → index-Ckil6miL.d.cts} +2 -2
- package/dist/{index-BokynmA4.d.cts → index-CpdnP-0y.d.cts} +1 -1
- package/dist/{index-BmLkcDlj.d.ts → index-CrlHFsiT.d.ts} +37 -17
- package/dist/{index-DCAuN9u5.d.cts → index-Czk3r0yA.d.cts} +37 -3
- package/dist/{index-C4N-dg5U.d.cts → index-D-B7U42V.d.cts} +2 -2
- package/dist/{index-CKcnuQ2c.d.ts → index-D-HZ7sP4.d.ts} +2 -2
- package/dist/{index-D6pwWiOc.d.cts → index-D7-RSD93.d.cts} +2 -2
- package/dist/{index-9mbs_PIG.d.ts → index-D9vBTuzo.d.ts} +2 -2
- package/dist/{index-C_qi0WlF.d.cts → index-DJNAWzcH.d.cts} +2 -2
- package/dist/{index-Ae6L8liv.d.ts → index-DJVQ-t07.d.ts} +2 -2
- package/dist/{index-D_d1erkR.d.ts → index-DKrIuF-r.d.ts} +2 -2
- package/dist/{index-DXz9uwcs.d.ts → index-DOU1Ee_k.d.ts} +1 -1
- package/dist/{index-D1E1tqHT.d.ts → index-DTDVDzhA.d.ts} +37 -3
- package/dist/{index-B5UR87KG.d.ts → index-DY2f2b9z.d.ts} +4 -2
- package/dist/{index-D8IyqHvT.d.cts → index-DeSsvHDD.d.cts} +4 -2
- package/dist/index-Di7OdwlO.d.ts +427 -0
- package/dist/{index-CzIWlnPp.d.ts → index-DqICM_I7.d.ts} +80 -7
- package/dist/{index-BOfHwQc1.d.ts → index-ML6vHKXK.d.ts} +1 -1
- package/dist/{index-DqtXA3yX.d.cts → index-UsU9ptzs.d.cts} +7 -4
- package/dist/{index-B46GWgk3.d.ts → index-Vz7KPfgz.d.ts} +1 -1
- package/dist/index.cjs +50 -50
- package/dist/index.d.cts +32 -32
- package/dist/index.d.ts +32 -32
- package/dist/index.js +1 -1
- package/dist/meta-BYqlATmg.d.ts +98 -0
- package/dist/meta-DreaEM_a.d.cts +98 -0
- package/dist/patterns/ai/browser.cjs +2 -2
- package/dist/patterns/ai/browser.js +1 -1
- package/dist/patterns/ai/index.cjs +21 -21
- package/dist/patterns/ai/index.d.cts +9 -9
- package/dist/patterns/ai/index.d.ts +9 -9
- package/dist/patterns/ai/index.js +1 -1
- package/dist/patterns/ai/node.js +1 -1
- package/dist/patterns/audit/index.cjs +7 -7
- 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 -7
- 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 -8
- package/dist/patterns/demo-shell/index.d.cts +4 -4
- package/dist/patterns/demo-shell/index.d.ts +4 -4
- package/dist/patterns/demo-shell/index.js +1 -1
- package/dist/patterns/domain-templates/index.cjs +7 -7
- package/dist/patterns/domain-templates/index.d.cts +3 -3
- package/dist/patterns/domain-templates/index.d.ts +3 -3
- package/dist/patterns/domain-templates/index.js +1 -1
- package/dist/patterns/graphspec/index.cjs +21 -21
- package/dist/patterns/graphspec/index.d.cts +3 -3
- package/dist/patterns/graphspec/index.d.ts +3 -3
- package/dist/patterns/graphspec/index.js +1 -1
- package/dist/patterns/guarded-execution/index.cjs +7 -7
- 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 +12 -12
- package/dist/patterns/harness/index.d.cts +8 -8
- package/dist/patterns/harness/index.d.ts +8 -8
- package/dist/patterns/harness/index.js +1 -1
- package/dist/patterns/job-queue/index.cjs +7 -7
- 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 -7
- package/dist/patterns/lens/index.d.cts +4 -4
- package/dist/patterns/lens/index.d.ts +4 -4
- package/dist/patterns/lens/index.js +1 -1
- package/dist/patterns/memory/index.cjs +7 -7
- package/dist/patterns/memory/index.d.cts +6 -4
- package/dist/patterns/memory/index.d.ts +6 -4
- package/dist/patterns/memory/index.js +1 -1
- package/dist/patterns/messaging/index.cjs +7 -7
- 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 -7
- package/dist/patterns/orchestration/index.d.cts +4 -4
- package/dist/patterns/orchestration/index.d.ts +4 -4
- package/dist/patterns/orchestration/index.js +1 -1
- package/dist/patterns/process/index.d.cts +5 -5
- package/dist/patterns/process/index.d.ts +5 -5
- package/dist/patterns/process/index.js +1 -1
- package/dist/patterns/reactive-layout/index.cjs +8 -8
- package/dist/patterns/reactive-layout/index.d.cts +4 -4
- package/dist/patterns/reactive-layout/index.d.ts +4 -4
- package/dist/patterns/reactive-layout/index.js +1 -1
- package/dist/patterns/reduction/index.cjs +7 -7
- package/dist/patterns/reduction/index.d.cts +3 -3
- package/dist/patterns/reduction/index.d.ts +3 -3
- package/dist/patterns/reduction/index.js +1 -1
- package/dist/patterns/refine-loop/index.cjs +8 -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 +4 -4
- package/dist/patterns/resilient-pipeline/index.d.ts +4 -4
- package/dist/patterns/resilient-pipeline/index.js +1 -1
- package/dist/patterns/surface/index.cjs +14 -14
- package/dist/patterns/surface/index.d.cts +4 -4
- package/dist/patterns/surface/index.d.ts +4 -4
- package/dist/patterns/surface/index.js +1 -1
- package/dist/{pipeline-graph-DX2Twdj-.d.ts → pipeline-graph-9JBbmRxA.d.ts} +2 -2
- package/dist/{pipeline-graph-BrrYGjuZ.d.cts → pipeline-graph-DuHpXSOn.d.cts} +2 -2
- package/dist/{reactive-layout-DrGjuwyC.d.cts → reactive-layout-BMLDB4Vd.d.cts} +1 -1
- package/dist/{reactive-layout-BDdngW56.d.ts → reactive-layout-D-tRiNhg.d.ts} +1 -1
- package/dist/{reactive-log-jirQsxMY.d.ts → reactive-log-BgWSA1fg.d.ts} +28 -1
- package/dist/{reactive-log-ScpWyqny.d.cts → reactive-log-C3IMAGpT.d.cts} +28 -1
- package/dist/resilience-LGBK236C.js +1 -0
- package/dist/{topology-tree-BI665P0L.d.ts → topology-tree-D47-nI6Z.d.ts} +1 -1
- package/dist/{topology-tree-BkhmMg2a.d.cts → topology-tree-jrZue3ao.d.cts} +1 -1
- package/package.json +1 -1
- package/dist/chunk-533RQFF6.js +0 -1
- package/dist/chunk-6SVKZ7VI.js +0 -1
- package/dist/chunk-A5HZZYRK.js +0 -1
- package/dist/chunk-B4L5X2QO.js +0 -7
- package/dist/chunk-FJ6IEMOS.js +0 -1
- package/dist/chunk-G6Q3DUMJ.js +0 -1
- package/dist/chunk-GDDPCDLG.js +0 -1
- package/dist/chunk-GFOT6UBB.js +0 -1
- package/dist/chunk-JJTF75VS.js +0 -1
- package/dist/chunk-K2WYIVHM.js +0 -1
- package/dist/chunk-KTWBUJO5.js +0 -61
- package/dist/chunk-M27MVZCP.js +0 -1
- package/dist/chunk-NKKUUKPD.js +0 -43
- package/dist/chunk-QKBCTKH7.js +0 -1
- package/dist/chunk-WGST56ZH.js +0 -80
- package/dist/index-BCq12BqB.d.ts +0 -139
- package/dist/index-DbWwMWiB.d.cts +0 -139
- package/dist/meta-BGO6C7K9.d.cts +0 -41
- package/dist/meta-CC6EPdpK.d.ts +0 -41
- package/dist/resilience-OBU472D2.js +0 -1
|
@@ -1,7 +1,7 @@
|
|
|
1
|
-
"use strict";var et=Object.defineProperty;var wn=Object.getOwnPropertyDescriptor;var xn=Object.getOwnPropertyNames;var Tn=Object.prototype.hasOwnProperty;var Q=(t,e)=>()=>(t&&(e=t(t=0)),e);var On=(t,e)=>{for(var n in e)et(t,n,{get:e[n],enumerable:!0})},Nn=(t,e,n,r)=>{if(e&&typeof e=="object"||typeof e=="function")for(let o of xn(e))!Tn.call(t,o)&&o!==n&&et(t,o,{get:()=>e[o],enumerable:!(r=wn(e,o))||r.enumerable});return t};var Rn=t=>Nn(et({},"__esModule",{value:!0}),t);function Pe(){return ge>0||Re}function _t(){return ge>0}function Ee(t){ge>0?ke.push(t):t()}function ie(t){ge+=1;let e=!1;try{t()}catch(n){throw e=!0,n}finally{if(ge-=1,ge===0)if(e){if(!Re){let n=ke.splice(0);for(let r of n)try{r()}catch{}le.length=0,fe.length=0,me.length=0}}else kn()}}function kn(){let t=!Re;t&&(Re=!0);let e=[],n=0;try{for(;le.length>0||fe.length>0||me.length>0||t&&ke.length>0;){if(t&&ke.length>0){let s=ke.splice(0);for(let i of s)try{i()}catch(a){e.push(a)}continue}if(n+=1,n>1e3)throw le.length=0,fe.length=0,me.length=0,new Error("batch drain exceeded 1000 iterations \u2014 likely a reactive cycle");let o=(le.length>0?le:fe.length>0?fe:me).splice(0);for(let s of o)try{s()}catch(i){e.push(i)}}}finally{t&&(Re=!1)}if(e.length===1)throw e[0];if(e.length>1)throw new AggregateError(e,"batch drain: multiple callbacks threw")}function $e(t,e,n){if(e.length===0)return;if(e.length===1){let u=n(e[0][0]);if(u<3||!Pe()){t(e);return}(u>=5?me:u===4?fe:le).push(()=>t(e));return}let r=e.length,o=r,s=r,i=r,a=0;for(;a<r&&n(e[a][0])<3;)a++;for(o=a;a<r&&n(e[a][0])===3;)a++;for(s=a;a<r&&n(e[a][0])===4;)a++;i=a;let d=Pe();if(o>0){let u=e.slice(0,o);t(u)}if(s>o){let u=e.slice(o,s);d?le.push(()=>t(u)):t(u)}if(i>s){let u=e.slice(s,i);d?fe.push(()=>t(u)):t(u)}if(r>i){let u=e.slice(i,r);d?me.push(()=>t(u)):t(u)}}var ge,Re,le,fe,me,ke,be=Q(()=>{"use strict";ge=0,Re=!1,le=[],fe=[],me=[],ke=[]});function ye(){return Math.trunc(performance.now()*1e6)}function ue(){return Date.now()*1e6}var Se=Q(()=>{"use strict"});var Ae,P,Y,H,te,re,de,W,U,$,ve,tt,En,nt,Sn,An,rt,wt,xt,Tt,ot,pe=Q(()=>{"use strict";Ae=Symbol.for("graphrefly/START"),P=Symbol.for("graphrefly/DATA"),Y=Symbol.for("graphrefly/DIRTY"),H=Symbol.for("graphrefly/RESOLVED"),te=Symbol.for("graphrefly/INVALIDATE"),re=Symbol.for("graphrefly/PAUSE"),de=Symbol.for("graphrefly/RESUME"),W=Symbol.for("graphrefly/TEARDOWN"),U=Symbol.for("graphrefly/COMPLETE"),$=Symbol.for("graphrefly/ERROR"),ve=Object.freeze([Y]),tt=Object.freeze([H]),En=Object.freeze([te]),nt=Object.freeze([Ae]),Sn=Object.freeze([U]),An=Object.freeze([W]),rt=Object.freeze([ve]),wt=Object.freeze([tt]),xt=Object.freeze([En]),Tt=Object.freeze([Sn]),ot=Object.freeze([An])});function Nt(t,e){let n=new TextEncoder().encode(t.name);if(n.length===0||n.length>255)throw new Error(`encodeEnvelope: codec name "${t.name}" encodes to ${n.length} bytes (must be 1\u2013255)`);let r=t.version;if(!Number.isInteger(r)||r<0||r>65535)throw new Error(`encodeEnvelope: codec.version ${r} out of u16 range (expected integer 0\u201365535)`);let o=2+n.length+2+e.length;if(o>4294967295)throw new Error(`encodeEnvelope: total envelope size ${o} exceeds 2^32-1 bytes (payload ${e.length} bytes)`);let s=new Uint8Array(o),i=0;return s[i++]=st,s[i++]=n.length,s.set(n,i),i+=n.length,s[i++]=r>>>8&255,s[i++]=r&255,s.set(e,i),s}function Rt(t,e){if(t.length<Ot)throw new Error(`decodeEnvelope: bytes too short (${t.length} < ${Ot})`);let n=0,r=t[n++];if(r!==st)throw new Error(`decodeEnvelope: unsupported envelope version ${r} (expected ${st})`);let o=t[n++];if(o===0)throw new Error("decodeEnvelope: name_len must be >= 1");if(n+o+2>t.length)throw new Error(`decodeEnvelope: envelope truncated (need ${n+o+2} bytes, have ${t.length})`);let s=new TextDecoder().decode(t.subarray(n,n+o));n+=o;let i=(t[n]<<8|t[n+1])>>>0;n+=2;let a=t.subarray(n),d=e.lookupCodec(s);if(d==null)throw new Error(`decodeEnvelope: codec "${s}" not registered (envelope codec_v=${i})`);return{codec:d,codecVersion:i,payload:a}}function kt(t){t.registerCodec(Dn)}var Dn,st,Ot,it=Q(()=>{"use strict";Dn={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)}},st=1,Ot=4});function Fe(t){if(t==null)return _e;let{type:e,id:n,...r}=t;return{type:e??"system",id:n??"",...r}}var _e,at=Q(()=>{"use strict";_e={type:"system",id:""}});function Et(t){t.registerMessageType(Ae,{tier:0,wireCrossing:!1}),t.registerMessageType(Y,{tier:1,wireCrossing:!1}),t.registerMessageType(te,{tier:1,wireCrossing:!1,metaPassthrough:!1}),t.registerMessageType(re,{tier:2,wireCrossing:!1}),t.registerMessageType(de,{tier:2,wireCrossing:!1}),t.registerMessageType(P,{tier:3,wireCrossing:!0}),t.registerMessageType(H,{tier:3,wireCrossing:!0}),t.registerMessageType(U,{tier:4,wireCrossing:!0,metaPassthrough:!1}),t.registerMessageType($,{tier:4,wireCrossing:!0,metaPassthrough:!1}),t.registerMessageType(W,{tier:5,wireCrossing:!0,metaPassthrough:!1})}var Ve,St=Q(()=>{"use strict";pe();Ve=class{_messageTypes=new Map;_codecs=new Map;_onMessage;_onSubscribe;_defaultVersioning;_defaultHashFn;_inspectorEnabled=!(typeof process<"u"&&process.env?.NODE_ENV==="production");_globalInspector;_rigorRecorder;_frozen=!1;tierOf;constructor(e){this._onMessage=e.onMessage,this._onSubscribe=e.onSubscribe,this._defaultVersioning=e.defaultVersioning,this._defaultHashFn=e.defaultHashFn,this.tierOf=n=>{let r=this._messageTypes.get(n);return r!=null?r.tier:1}}get onMessage(){return this._frozen=!0,this._onMessage}get onSubscribe(){return this._frozen=!0,this._onSubscribe}set onMessage(e){this._assertUnfrozen(),this._onMessage=e}set onSubscribe(e){this._assertUnfrozen(),this._onSubscribe=e}get defaultVersioning(){return this._defaultVersioning}set defaultVersioning(e){this._assertUnfrozen(),this._defaultVersioning=e}get defaultHashFn(){return this._defaultHashFn}set defaultHashFn(e){this._assertUnfrozen(),this._defaultHashFn=e}get inspectorEnabled(){return this._inspectorEnabled}set inspectorEnabled(e){this._inspectorEnabled=e}get globalInspector(){return this._globalInspector}set globalInspector(e){this._globalInspector=e}get rigorRecorder(){return this._rigorRecorder}set rigorRecorder(e){this._rigorRecorder=e}registerMessageType(e,n){return this._assertUnfrozen(),this._messageTypes.set(e,{tier:n.tier,wireCrossing:n.wireCrossing??n.tier>=3,metaPassthrough:n.metaPassthrough??!0}),this}messageTier(e){let n=this._messageTypes.get(e);return n!=null?n.tier:1}isWireCrossing(e){let n=this._messageTypes.get(e);return n!=null?n.wireCrossing:!0}isLocalOnly(e){return!this.isWireCrossing(e)}isMetaPassthrough(e){let n=this._messageTypes.get(e);return n!=null?n.metaPassthrough:!0}isKnownMessageType(e){return this._messageTypes.has(e)}registerCodec(e){return this._assertUnfrozen(),this._codecs.set(e.name,e),this}lookupCodec(e){return this._codecs.get(e)}_isFrozen(){return this._frozen}_assertUnfrozen(){if(this._frozen)throw new Error("GraphReFlyConfig is frozen: a node has already captured this config. Register custom types and set hooks before creating any node.")}}});function At(t){return Array.isArray(t)?[...t]:[t]}function Cn(t,e){return t.has(e)||t.has("*")}function Dt(t){let e=[];return t((o,s)=>{e.push({kind:"allow",actions:new Set(At(o)),where:s?.where??(()=>!0)})},(o,s)=>{e.push({kind:"deny",actions:new Set(At(o)),where:s?.where??(()=>!0)})}),(o,s)=>{let i=!1,a=!1;for(let d of e)Cn(d.actions,s)&&d.where(o)&&(d.kind==="deny"?i=!0:a=!0);return i?!1:a}}function ut(t){let e=Mn.filter(n=>t({type:n,id:""},"write"));return e.length===0?"restricted":e.includes("human")&&e.includes("llm")&&e.every(n=>n==="human"||n==="llm"||n==="system")?"both":e.length===1?e[0]:e.join("+")}var ee,Mn,De=Q(()=>{"use strict";ee=class extends Error{actor;action;nodeName;constructor(e,n){super(n??`GuardDenied: action "${String(e.action)}" denied for actor type "${String(e.actor.type)}"`),this.name="GuardDenied",this.actor=e.actor,this.action=e.action,this.nodeName=e.nodeName}get node(){return this.nodeName}};Mn=["human","llm","wallet","system"]});function dt(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(dt);if(typeof t=="object"&&t!==null){let e={};for(let n of Object.keys(t).sort())e[n]=dt(t[n]);return e}return null}function In(t){let e=Ln.encode(t),n=e.length,r=n*8,o=n+9+63&-64,s=new Uint8Array(o);s.set(e),s[n]=128;let i=new DataView(s.buffer);i.setUint32(o-4,r>>>0,!1),i.setUint32(o-8,Math.floor(r/4294967296)>>>0,!1);let a=1779033703,d=3144134277,u=1013904242,c=2773480762,p=1359893119,h=2600822924,f=528734635,l=1541459225,m=new Uint32Array(64),x=(v,b)=>v>>>b|v<<32-b;for(let v=0;v<o;v+=64){for(let R=0;R<16;R++)m[R]=i.getUint32(v+R*4,!1);for(let R=16;R<64;R++){let E=m[R-15],A=m[R-2],L=x(E,7)^x(E,18)^E>>>3,j=x(A,17)^x(A,19)^A>>>10;m[R]=m[R-16]+L+m[R-7]+j>>>0}let b=a,_=d,T=u,w=c,g=p,y=h,O=f,S=l;for(let R=0;R<64;R++){let E=x(g,6)^x(g,11)^x(g,25),A=g&y^~g&O,L=S+E+A+Gn[R]+m[R]>>>0,j=x(b,2)^x(b,13)^x(b,22),B=b&_^b&T^_&T,se=j+B>>>0;S=O,O=y,y=g,g=w+L>>>0,w=T,T=_,_=b,b=L+se>>>0}a=a+b>>>0,d=d+_>>>0,u=u+T>>>0,c=c+w>>>0,p=p+g>>>0,h=h+y>>>0,f=f+O>>>0,l=l+S>>>0}let k=v=>v.toString(16).padStart(8,"0");return k(a)+k(d)+k(u)+k(c)+k(p)+k(h)+k(f)+k(l)}function ct(t){let e=dt(t??null),n=JSON.stringify(e);return In(n).slice(0,16)}function Pn(){let t=globalThis.crypto;if(t?.randomUUID)return t.randomUUID();let e=()=>Math.floor(Math.random()*4294967296).toString(16).padStart(8,"0"),n=e()+e()+e()+e();return`${n.slice(0,8)}-${n.slice(8,12)}-4${n.slice(13,16)}-${(parseInt(n.slice(16,17),16)&3|8).toString(16)}${n.slice(17,20)}-${n.slice(20,32)}`}function lt(t,e,n){let r=n?.id??Pn();if(t===0)return{id:r,version:0};let s=(n?.hash??ct)(e);return{id:r,version:0,cid:s,prev:null}}function Ct(t,e,n){t.version+=1,"cid"in t&&(t.prev=t.cid,t.cid=n(e))}var Gn,Ln,Mt=Q(()=>{"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]),Ln=new TextEncoder});function It(t){return{node:t,unsub:null,prevData:void 0,dirty:!1,involvedThisWave:!1,dataBatch:[],terminal:void 0}}function ft(t){t.prevData=void 0,t.dirty=!1,t.involvedThisWave=!1,t.dataBatch.length=0,t.terminal=void 0}function ze(t){return t.length===0?t:typeof t[0]=="symbol"?[t]:t}function ae(t,e,n){let r=Pt(t)?t:[],o=typeof t=="function"?t:typeof e=="function"?e:void 0,s={};return Pt(t)?s=(pt(e)?e:n)??{}:pt(t)?s=t:s=(pt(e)?e:n)??{},new V(r,o,s)}var Gt,Lt,$n,Fn,we,V,Pt,pt,he=Q(()=>{"use strict";it();at();be();Se();St();De();pe();Mt();Gt=()=>{},Lt=100;$n=(t,e,n,r)=>{n.direction==="down-in"&&t._onDepMessage(n.depIndex,e)},Fn=(t,e,n,r)=>{let o=t;if(o._status==="completed"||o._status==="errored")return;let s=o._cached,i=s===void 0?[nt]:[nt,[P,s]];o._status==="dirty"&&i.push(ve),$e(e,i,o._config.tierOf)},we=new Ve({onMessage:$n,onSubscribe:Fn});Et(we);kt(we);V=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??we,this._config.onMessage,this._optsName=r.name,this._describeKind=r.describeKind,this._equals=r.equals??Object.is,this._resubscribable=r.resubscribable??!1,this._resetOnTeardown=r.resetOnTeardown??!1,this._autoComplete=r.completeWhenDepsComplete??!0,this._autoError=r.errorWhenDepsError??!0,this._pausable=r.pausable??!0,this._guard=r.guard,this._fn=n,this._partial=r.partial??!1,this._cached=r.initial!==void 0?r.initial:void 0,this._status=e.length===0&&n==null&&this._cached!==void 0?"settled":"sentinel",this._hashFn=r.versioningHash??this._config.defaultHashFn??ct;let o=r.versioning??this._config.defaultVersioning;this._versioningLevel=o,this._versioning=o!=null?lt(o,this._cached===void 0?void 0:this._cached,{id:r.versioningId,hash:this._hashFn}):void 0,this._deps=e.map(It);let s={};for(let[a,d]of Object.entries(r.meta??{})){let u={initial:d,name:`${r.name??"node"}:meta:${a}`,describeKind:"state",config:this._config};r.guard!=null&&(u.guard=r.guard),s[a]=new t([],void 0,u)}Object.freeze(s),this.meta=s,this._hasMeta=Object.keys(s).length>0;let i=this;this._actions={emit(a){i._emit([[P,a]])},down(a){i._emit(ze(a))},up(a){i._emitUp(ze(a))}},this.down=this.down.bind(this),this.up=this.up.bind(this)}get _isTerminal(){return this._status==="completed"||this._status==="errored"}get name(){return this._optsName}get status(){return this._status}get cache(){return this._cached===void 0?void 0:this._cached}get lastMutation(){return this._lastMutation}get v(){return this._versioning}hasGuard(){return this._guard!=null}_applyVersioning(e,n){if(this._isExecutingFn)throw new Error(`Node "${this.name}": _applyVersioning cannot run mid-fn \u2014 call it outside of \`_execFn\` (typically at graph setup time before the first subscribe).`);let r=this._versioningLevel;if(r!=null&&e<=r)return;let o=n?.hash??this._hashFn;o!==this._hashFn&&(this._hashFn=o);let s=this._cached===void 0?void 0:this._cached,i=this._versioning,a=i?.id??n?.id,d=i?.version??0,u=lt(e,s,{id:a,hash:o});u.version=d,this._versioning=u,this._versioningLevel=e}_setInspectorHook(e){return e==null?()=>{}:(this._inspectorHooks==null&&(this._inspectorHooks=new Set),this._inspectorHooks.add(e),()=>{this._inspectorHooks?.delete(e),this._inspectorHooks?.size===0&&(this._inspectorHooks=void 0)})}_pushGuard(e){return this._extraGuards==null&&(this._extraGuards=new Set),this._extraGuards.add(e),()=>{this._extraGuards?.delete(e),this._extraGuards?.size===0&&(this._extraGuards=void 0)}}allowsObserve(e){if(this._guard==null&&this._extraGuards==null)return!0;let n=Fe(e);if(this._guard!=null&&!this._guard(n,"observe"))return!1;if(this._extraGuards!=null){for(let r of this._extraGuards)if(!r(n,"observe"))return!1}return!0}_checkGuard(e){if(e?.internal)return;let n=this._guard!=null||this._extraGuards!=null,r=e?.actor!=null;if(!n&&!r)return;let o=Fe(e?.actor),s=e?.delivery==="signal"?"signal":"write";if(this._guard!=null&&!this._guard(o,s))throw new ee({actor:o,action:s,nodeName:this.name});if(this._extraGuards!=null){for(let i of this._extraGuards)if(!i(o,s))throw new ee({actor:o,action:s,nodeName:this.name})}this._lastMutation={actor:o,timestamp_ns:ue()}}down(e,n){let r=ze(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=ze(e);if(r.length===0)return;this._checkGuard(n);let o=n??{internal:!0};this._validateUpTiers(r);for(let s of this._deps)s.node.up?.(r,o)}_emitUp(e){if(this._deps.length!==0&&e.length!==0){this._validateUpTiers(e);for(let n of this._deps)n.node.up?.(e,{internal:!0})}}_validateUpTiers(e){let n=this._config.tierOf;for(let r of e){let o=n(r[0]);if(o===3||o===4)throw new Error(`Node "${this.name}": tier-${o} messages cannot flow up \u2014 DATA/RESOLVED/COMPLETE/ERROR are downstream-only. Use \`down(...)\` for value delivery; \`up(...)\` is for control signals (DIRTY, INVALIDATE, PAUSE, RESUME, TEARDOWN).`)}}subscribe(e,n){if(n!=null&&this._guard!=null){let d=Fe(n);if(!this._guard(d,"observe"))throw new ee({actor:d,action:"observe",nodeName:this.name})}let o=this._isTerminal&&this._resubscribable;if(o){this._cached=void 0,this._status="sentinel",this._store={},this._hasCalledFnOnce=!1,this._waveHasNewData=!1,this._hasNewTerminal=!1,this._paused=!1,this._pendingWave=!1,this._pendingRerun=!1,this._isExecutingFn=!1,this._rerunDepth=0,this._dirtyDepCount=0,this._pauseLocks=null,this._pauseBuffer=null;for(let d of this._deps)ft(d);if(this._partial===!1){for(let d of this._deps)if(d.prevData!==void 0||d.dataBatch.length!==0||d.terminal!==void 0||d.dirty)throw new Error(`resubscribable-reset invariant: DepRecord not fully reset for node ${this._optsName??"(anonymous)"}`)}}this._sinkCount+=1;let s;try{s=this._config.onSubscribe(this,e,{sinkCount:this._sinkCount,afterTerminalReset:o},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 s=="function")try{s()}catch{}throw d}this._status==="sentinel"&&this._cached===void 0&&(this._status="pending");let a=!1;return()=>{a||(a=!0,this._sinkCount-=1,this._removeSink(e),typeof s=="function"&&s(),this._sinks==null&&this._deactivate())}}_removeSink(e){if(this._sinks===e)this._sinks=null;else if(this._sinks!=null&&typeof this._sinks!="function")if(this._sinks.delete(e),this._sinks.size===1){let[n]=this._sinks;this._sinks=n}else this._sinks.size===0&&(this._sinks=null)}_activate(){if(this._deps.length===0){this._fn&&this._execFn();return}this._dirtyDepCount=0;let e=this._deps.length,n=0;try{for(let r=0;r<e;r++){let o=r,s=this._deps[r];s.unsub=Gt,s.unsub=s.node.subscribe(i=>{if(s.unsub===null)return;let a=this._config.tierOf,d=!1;for(let u of i)a(u[0])>=3&&(d=!0),this._config.onMessage(this,u,{direction:"down-in",depIndex:o},this._actions);d&&this._maybeRunFnOnSettlement()}),n++}}catch(r){this._deps[n].unsub=null;for(let o=0;o<n;o++){let s=this._deps[o];if(s.unsub!=null){let i=s.unsub;s.unsub=null;try{i()}catch{}ft(s)}}throw this._dirtyDepCount=0,r}}_addDep(e){for(let o=0;o<this._deps.length;o++)if(this._deps[o].node===e)return o;let n=this._deps.length,r=It(e);if(this._deps.push(r),this._sinks==null)return n;r.dirty=!0,this._dirtyDepCount++,this._status!=="dirty"&&this._emit(rt),r.unsub=Gt;try{r.unsub=e.subscribe(o=>{if(r.unsub===null)return;let s=this._config.tierOf,i=!1;for(let a of o)s(a[0])>=3&&(i=!0),this._config.onMessage(this,a,{direction:"down-in",depIndex:n},this._actions);i&&this._maybeRunFnOnSettlement()})}catch(o){throw r.unsub=null,this._deps.pop(),this._dirtyDepCount--,o}return n}_deactivate(e=!1){let n=this._cleanup;if(this._cleanup=void 0,typeof n=="function")try{n()}catch(r){this._emit([[$,this._wrapFnError("cleanup threw",r)]])}else if(n!=null&&typeof n=="object"){let r=n.deactivate;if(typeof r=="function")try{r()}catch(o){this._emit([[$,this._wrapFnError("cleanup.deactivate threw",o)]])}}for(let r of this._deps){if(r.unsub!=null){let o=r.unsub;r.unsub=null;try{o()}catch{}}ft(r)}this._waveHasNewData=!1,this._hasNewTerminal=!1,this._hasCalledFnOnce=!1,this._paused=!1,this._pendingWave=!1,this._pendingRerun=!1,this._rerunDepth=0,this._store={},this._dirtyDepCount=0,this._pauseLocks=null,this._pauseBuffer=null,this._fn!=null&&(this._cached=void 0),e||(this._fn!=null||this._deps.length>0)&&(!this._isTerminal||this._resubscribable)&&(this._status="sentinel")}_onDepMessage(e,n){let r=this._deps[e],o=n[0];if(this._inspectorHooks!=null){let s={kind:"dep_message",depIndex:e,message:n};for(let i of this._inspectorHooks)i(s)}if(o!==Ae){if(o===Y){this._depDirtied(r);return}if(o===te){if(this._depInvalidated(r),this._cached===void 0)return;this._emit(xt);return}if(o===re||o===de){this._emit([n]);return}if(o===W){this._emit(ot);return}if(o===P)this._depSettledAsData(r,n[1]);else if(o===H)this._depSettledAsResolved(r);else if(o===U)this._depSettledAsTerminal(r,!0);else if(o===$)this._depSettledAsTerminal(r,n[1]);else{this._emit([n]);return}if(!this._fn){(o===P||o===H)&&this._emit([n]),(o===U||o===$)&&this._maybeAutoTerminalAfterWave();return}}}_depDirtied(e){e.dirty||(e.dirty=!0,e.involvedThisWave=!0,this._dirtyDepCount++,this._status!=="dirty"&&this._emit(rt))}_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(wt),this._maybeAutoTerminalAfterWave();return}this._fn&&this._execFn(),this._maybeAutoTerminalAfterWave()}}_maybeAutoTerminalAfterWave(){if(this._deps.length===0||this._isTerminal)return;let e=this._deps.find(n=>n.terminal!==void 0&&n.terminal!==!0);if(e!=null){this._autoError&&this._emit([[$,e.terminal]]);return}this._autoComplete&&this._deps.every(n=>n.terminal!==void 0)&&this._emit(Tt)}_execFn(){if(!this._fn||this._isTerminal&&!this._resubscribable)return;if(this._isExecutingFn){this._pendingRerun=!0;return}let e=this._cleanup;if(typeof e=="function"){this._cleanup=void 0;try{e()}catch(i){this._emit([[$,this._wrapFnError("cleanup threw",i)]]);return}}else if(e!=null&&typeof e=="object"){let i=e.beforeRun;if(typeof i=="function"){e.beforeRun=void 0;try{i()}catch(a){this._emit([[$,this._wrapFnError("cleanup.beforeRun threw",a)]]);return}}}let n=this._deps.map(i=>i.involvedThisWave?i.dataBatch.length>0?[...i.dataBatch]:[]:void 0),r=this._deps.map(i=>i.prevData);for(let i=0;i<this._deps.length;i++){let a=n[i];a!=null&&a.length>0&&(this._deps[i].prevData=a[a.length-1])}let o=this._deps.map(i=>i.terminal),s={prevData:r,terminalDeps:o,store:this._store};if(this._hasCalledFnOnce=!0,this._clearWaveFlags(),this._inspectorHooks!=null){let i={kind:"run",batchData:n,prevData:r};for(let a of this._inspectorHooks)a(i)}this._isExecutingFn=!0;try{let i=this._fn(n,this._actions,s);if(typeof i=="function")this._cleanup=i;else if(i!=null&&typeof i=="object"){let a=i;(typeof a.beforeRun=="function"||typeof a.deactivate=="function"||typeof a.invalidate=="function")&&(this._cleanup=i)}}catch(i){this._emit([[$,this._wrapFnError("fn threw",i)]])}finally{this._isExecutingFn=!1,this._pendingRerun?(this._pendingRerun=!1,this._rerunDepth+=1,this._rerunDepth>Lt?(this._rerunDepth=0,this._emit([[$,new Error(`Node "${this.name}": _pendingRerun depth exceeded ${Lt} \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"?[ve,e[0]]:e;let r=!0,o=!1,s=!1,i=-1;for(let d of e){let u=n(d[0]);u<i&&(r=!1),u===3&&(o=!0),d[0]===Y&&(s=!0),i=u}let a=e;if(!r){let d=e.map((u,c)=>({m:u,i:c,tier:n(u[0])}));d.sort((u,c)=>u.tier-c.tier||u.i-c.i),a=d.map(u=>u.m)}if(o&&!s&&this._status!=="dirty"){let d=0;for(;d<a.length&&n(a[d][0])===0;)d++;return d===0?[ve,...a]:[...a.slice(0,d),ve,...a.slice(d)]}return a}_emit(e){if(e.length===0)return;for(let a=0;a<e.length;a++){let d=e[a];if(d[0]===$&&d[1]===void 0)throw new TypeError('[ERROR, payload] requires a non-undefined payload (spec \xA71.2). Pass an Error object or domain tag instead \u2014 e.g. node.down([[ERROR, new Error("reason")]])')}let n=e;if(this._isTerminal&&!this._resubscribable){let a=e.filter(d=>d[0]===W||d[0]===te);if(a.length===0)return;n=a}n=this._frameBatch(n);let o=null;for(let a=0;a<n.length;a++){let d=n[a],u=d[0];if(u!==re&&u!==de){o?.push(d);continue}if(d.length<2)throw new Error(`Node "${this.name}": [[${u===re?"PAUSE":"RESUME"}]] must carry a lockId payload \u2014 bare PAUSE/RESUME is a protocol violation (C0 rule). Use \`[[PAUSE, lockId]]\` / \`[[RESUME, lockId]]\`.`);let c=!0;if(this._pausable!==!1){let p=d[1];if(u===re)this._pauseLocks==null&&(this._pauseLocks=new Set),this._pauseLocks.add(p),this._paused=!0,this._pausable==="resumeAll"&&this._pauseBuffer==null&&(this._pauseBuffer=[]);else if(this._pauseLocks==null||!this._pauseLocks.has(p))c=!1;else if(this._pauseLocks.delete(p),this._pauseLocks.size===0){if(this._paused=!1,this._pauseBuffer!=null&&this._pauseBuffer.length>0){let h=this._pauseBuffer;this._pauseBuffer=[],this._emit(h)}this._pendingWave&&(this._pendingWave=!1,this._maybeRunFnOnSettlement())}}c?o?.push(d):o==null&&(o=n.slice(0,a))}if(o!=null){if(o.length===0)return;n=o}if(this._hasMeta&&n.some(a=>a[0]===W))for(let a of Object.keys(this.meta))try{this.meta[a]._emit(ot)}catch{}let{finalMessages:s,equalsError:i}=this._updateState(n);if(s.length>0&&this._config.inspectorEnabled){let a=this._config.globalInspector;if(a!=null)try{a({kind:"emit",node:this,messages:s})}catch{}}if(s.length>0)if(this._paused&&this._pausable==="resumeAll"&&this._pauseBuffer!=null){let a=this._config.tierOf,d=[];for(let u of s)a(u[0])===3?this._pauseBuffer.push(u):d.push(u);d.length>0&&this._dispatchOrAccumulate(d)}else this._dispatchOrAccumulate(s);i!=null&&this._emit([[$,i]])}_updateState(e){let n=this._config.tierOf,r,o,s=-1,i=0;for(let c of e)n(c[0])===3&&i++;let a=i<=1,d=-1;if(this._versioning!=null&&i>1){for(let c=e.length-1;c>=0;c--)if(e[c][0]===P){d=c;break}}for(let c=0;c<e.length;c++){let p=e[c],h=p[0];if(h===P){if(p.length>=2){let f=!1;if(a&&this._cached!==void 0)try{f=this._equals(this._cached,p[1])}catch(l){o=this._wrapFnError("equals threw",l),s=c;break}if(f){r==null&&(r=e.slice(0,c)),r.push(tt),this._status="resolved";continue}this._cached=p[1],this._versioning!=null&&(d<0||c===d)&&Ct(this._versioning,p[1],this._hashFn)}this._status="settled",r?.push(p)}else if(r?.push(p),h===Y)this._status="dirty";else if(h===H)this._status="resolved";else if(h===U){this._status="completed";{let f=this._config.rigorRecorder;if(f!=null)try{f.onTerminalTransition(this,"completed",this._autoComplete,this._autoError,this._deps.length>0)}catch{}}}else if(h===$){this._status="errored";{let f=this._config.rigorRecorder;if(f!=null)try{f.onTerminalTransition(this,"errored",this._autoComplete,this._autoError,this._deps.length>0)}catch{}}}else if(h===te){if(this._cached!==void 0){let l=this._config.rigorRecorder;if(l!=null)try{l.onNonVacuousInvalidate(this,this._cached)}catch{}}this._cached=void 0,this._status="dirty";let f=this._cleanup;if(typeof f=="function"){this._cleanup=void 0;try{f()}catch{}}else if(f!=null&&typeof f=="object"){let l=f.invalidate;if(typeof l=="function")try{l()}catch{}}}else h===W&&(this._resetOnTeardown&&(this._cached=void 0),this._deactivate(!0),this._status="sentinel")}let u=s>=0?r??e.slice(0,s):r??e;return o!=null?{finalMessages:u,equalsError:o}:{finalMessages:u}}_deliverToSinks=e=>{if(this._sinks==null)return;if(typeof this._sinks=="function"){this._sinks(e);return}let n=[...this._sinks];for(let r of n)r(e)};_dispatchOrAccumulate(e){if(_t()){this._batchPendingMessages===null&&(this._batchPendingMessages=[],Ee(()=>this._flushBatchPending()));for(let n of e)this._batchPendingMessages.push(n);return}$e(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);$e(this._deliverToSinks,n,this._config.tierOf)}},Pt=t=>Array.isArray(t),pt=t=>typeof t=="object"&&t!=null&&!Array.isArray(t)});function oe(t,e){return ae([],{...e,initial:t})}function $t(t,e){return ae((r,o,s)=>t(o,s)??void 0,{describeKind:"producer",...e})}function J(t,e,n){return ae(t,(o,s,i)=>{let a=o.map((d,u)=>d!=null&&d.length>0?d.at(-1):i.prevData[u]);s.emit(e(a,i))},{describeKind:"derived",...n})}var Be=Q(()=>{"use strict";he()});function gt(t){return t.subscribe(()=>{})}var Ft=Q(()=>{"use strict"});var He,Vt=Q(()=>{"use strict";He=class{_timer;_gen=0;start(e,n){this.cancel(),this._gen+=1;let r=this._gen;this._timer=setTimeout(()=>{this._timer=void 0,r===this._gen&&n()},e)}cancel(){this._timer!==void 0&&(clearTimeout(this._timer),this._timer=void 0)}get pending(){return this._timer!==void 0}}});var Vr={};On(Vr,{PipelineGraph:()=>Le,decisionKeyOf:()=>vn,pipelineGraph:()=>_n});module.exports=Rn(Vr);be();Se();pe();he();Be();at();be();Se();De();pe();De();he();function je(t,e){if(e!=null&&e.length>0)return new Set(e);switch(t){case"standard":return new Set(["type","status","value","deps","meta","v"]);case"full":return null;default:return new Set(["type","deps"])}}function Vn(t){return t._describeKind!=null?t._describeKind:t._deps.length>0?"derived":t._fn!=null?"producer":"state"}function zn(t){let e={};for(let[n,r]of Object.entries(t.meta))try{e[n]=r.cache}catch{}return e}function ht(t,e){let n=e==null,r=!n&&e!=null?[...e].filter(u=>u.startsWith("meta.")).map(u=>u.slice(5)):null,o=n||e.has("meta")||r!=null&&r.length>0,s="state",i=[];t instanceof V&&(s=Vn(t),i=t._deps.map(u=>u.node.name??""));let a={type:s,deps:i};(n||e.has("status"))&&(a.status=t.status);let d=t instanceof V?t._guard:void 0;if(o){let u={...zn(t)};if(d!=null&&u.access===void 0&&(u.access=ut(d)),r!=null&&r.length>0&&!e.has("meta")){let c={};for(let p of r)p in u&&(c[p]=u[p]);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"))&&d!=null&&(a.guard=ut(d)),(n||e.has("lastMutation"))&&t.lastMutation!=null&&(a.lastMutation=t.lastMutation),a}he();Be();Ft();Vt();var Ce=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}};it();function mt(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 Ue(t){let e=0;for(let n of t)e+=mt(n.codePointAt(0));return e}function zt(t,e){if(e<=0)return"";let n=0,r="";for(let o of t){let s=mt(o.codePointAt(0));if(n+s>e){if(e<=1)return"\u2026";for(;n+1>e&&r.length>0;){let i=[...r].pop();r=r.slice(0,-i.length),n-=mt(i.codePointAt(0))}return`${r}\u2026`}r+=o,n+=s}return r}var Bn={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"},jn={horizontal:"-",vertical:"|",cornerTL:"+",cornerTR:"+",cornerBL:"+",cornerBR:"+",tDown:"+",tUp:"+",tRight:"+",tLeft:"+",cross:"+",arrowRight:">",arrowDown:"v",arrowLeft:"<",arrowUp:"^",boxTL:"+",boxTR:"+",boxBL:"+",boxBR:"+",boxH:"-",boxV:"|"};function Ut(t,e){let n=e.charset==="ascii"?jn:Bn,r=t.width,o=t.height,s=Array.from({length:o},()=>Array.from({length:r},()=>" ")),i=Array.from({length:o},()=>Array.from({length:r},()=>"empty"));for(let a of t.edges)Un(s,i,n,a);for(let a of t.boxes)Hn(s,i,n,a,e.labelOf(a.id));return s.map(a=>Yn(a.join(""))).join(`
|
|
2
|
-
`)}function Hn(t,e,n,r,o){let{x:s,y:i,w:a,h:d}=r;if(a<2||d<2){d>0&&Bt(t,e,s,i,a,o);return}ce(t,e,s,i,n.boxTL);for(let c=s+1;c<s+a-1;c+=1)ce(t,e,c,i,n.boxH);ce(t,e,s+a-1,i,n.boxTR);for(let c=i+1;c<i+d-1;c+=1){ce(t,e,s,c,n.boxV);for(let p=s+1;p<s+a-1;p+=1)Wt(t,e,p,c," ","empty");ce(t,e,s+a-1,c,n.boxV)}ce(t,e,s,i+d-1,n.boxBL);for(let c=s+1;c<s+a-1;c+=1)ce(t,e,c,i+d-1,n.boxH);ce(t,e,s+a-1,i+d-1,n.boxBR);let u=i+Math.floor(d/2);Bt(t,e,s+1,u,a-2,o)}function ce(t,e,n,r,o){Wt(t,e,n,r,o,o===" "?"empty":o==="\u2500"||o==="-"?"boxH":o==="\u2502"||o==="|"?"boxV":"boxCorner")}function Wt(t,e,n,r,o,s){if(r<0||r>=t.length)return;let i=t[r];n<0||n>=i.length||(i[n]=o,e[r][n]=s)}function Bt(t,e,n,r,o,s){if(r<0||r>=t.length)return;let i=n,a=o;for(let d of s){let u=Ue(d);if(u!==0){if(a<u)break;i>=0&&i<t[r].length&&(t[r][i]=d,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 Un(t,e,n,r){let o=r.points;if(o.length<2)return;for(let d=0;d+1<o.length;d+=1)Wn(t,e,n,o[d],o[d+1]);for(let d=1;d+1<o.length;d+=1){let u=o[d-1],c=o[d],p=o[d+1],h=Kn(u,c,p,n);h&&Ht(t,e,c.x,c.y,h,"edgeCorner")}let s=o[o.length-1],i=o[o.length-2],a=qn(i,s,n);a&&Ht(t,e,s.x,s.y,a,"arrow")}function Wn(t,e,n,r,o){if(!(r.x===o.x&&r.y===o.y)){if(r.y===o.y){let s=r.y,i=Math.min(r.x,o.x),a=Math.max(r.x,o.x);for(let d=i;d<=a;d+=1)jt(t,e,d,s,n,"h")}else if(r.x===o.x){let s=r.x,i=Math.min(r.y,o.y),a=Math.max(r.y,o.y);for(let d=i;d<=a;d+=1)jt(t,e,s,d,n,"v")}}}function jt(t,e,n,r,o,s){if(r<0||r>=t.length)return;let i=t[r];if(n<0||n>=i.length)return;let a=e[r][n];if(!(a==="boxH"||a==="boxV"||a==="boxCorner"||a==="label")){if(a==="empty"){i[n]=s==="h"?o.horizontal:o.vertical,e[r][n]=s==="h"?"edgeH":"edgeV";return}if(a==="edgeH"&&s==="v"){i[n]=o.cross,e[r][n]="edgeCorner";return}if(a==="edgeV"&&s==="h"){i[n]=o.cross,e[r][n]="edgeCorner";return}}}function Ht(t,e,n,r,o,s){if(r<0||r>=t.length)return;let i=t[r];if(n<0||n>=i.length)return;let a=e[r][n];a==="boxH"||a==="boxV"||a==="boxCorner"||a==="label"||(i[n]=o,e[r][n]=s)}function Kn(t,e,n,r){let o=t.y===e.y,s=e.y===n.y;if(o===s)return;if(o){let d=t.x<e.x,u=n.y>e.y;return d&&u?r.cornerTR:d&&!u?r.cornerBR:!d&&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 qn(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 Yn(t){let e=t.length;for(;e>0&&t.charCodeAt(e-1)===32;)e-=1;return t.slice(0,e)}function Yt(t){let e=Jn(t);Xn(e),Zn(e),Qn(e),er(e,t);let n=rr(e,t),{width:r,height:o}=sr(e),s=[];for(let i of e.layers)for(let a of i)a.isVirtual||s.push({id:a.id,layer:a.layer,order:a.order,x:a.x,y:a.y,w:a.w,h:a.h});return{boxes:s,edges:n,width:r,height:o}}function Jn(t){let e=new Map;for(let o of t.nodes)e.set(o,{id:o,isVirtual:!1,layer:-1,order:0,x:0,y:0,w:t.widthCells(o),h:t.heightCells(o),in:[],out:[]});let n=[],r=0;for(let o of t.edges){if(o.from===o.to)continue;let s=e.get(o.from),i=e.get(o.to);if(!s||!i)continue;let a={chainId:r++,chainFrom:o.from,chainTo:o.to,fromId:o.from,toId:o.to,hopIndex:0,chainLen:1};s.out.push(a),i.in.push(a),n.push(a)}return{nodes:e,layers:[],hops:n}}function Xn(t){let e=new Map;for(let s of t.nodes.values())e.set(s.id,s.in.length);let n=[];for(let s of t.nodes.values())(e.get(s.id)??0)===0&&(s.layer=0,n.push(s));let r=new Set,o=0;for(;o<n.length;){let s=n[o++];if(!r.has(s.id)){r.add(s.id);for(let i of s.out){let a=t.nodes.get(i.toId);a.layer=Math.max(a.layer,s.layer+1);let d=(e.get(a.id)??0)-1;e.set(a.id,d),d<=0&&n.push(a)}}}for(let s of t.nodes.values())s.layer<0&&(s.layer=0)}function Zn(t){let e=Math.max(0,...Array.from(t.nodes.values(),s=>s.layer)),n=Array.from({length:e+1},()=>[]);for(let s of t.nodes.values())n[s.layer].push(s);let r=[],o=0;for(let s of t.hops){let i=t.nodes.get(s.fromId),a=t.nodes.get(s.toId),d=a.layer-i.layer;if(d<=0){i.out=i.out.filter(p=>p!==s),a.in=a.in.filter(p=>p!==s);continue}if(d===1){s.hopIndex=0,s.chainLen=1,r.push(s);continue}i.out=i.out.filter(p=>p!==s),a.in=a.in.filter(p=>p!==s);let u=i;for(let p=1;p<d;p+=1){let h=`__virt_${o++}__`,f={id:h,isVirtual:!0,layer:i.layer+p,order:0,x:0,y:0,w:0,h:1,in:[],out:[]};t.nodes.set(h,f),n[f.layer].push(f);let l={chainId:s.chainId,chainFrom:s.chainFrom,chainTo:s.chainTo,fromId:u.id,toId:h,hopIndex:p-1,chainLen:d};u.out.push(l),f.in.push(l),r.push(l),u=f}let c={chainId:s.chainId,chainFrom:s.chainFrom,chainTo:s.chainTo,fromId:u.id,toId:a.id,hopIndex:d-1,chainLen:d};u.out.push(c),a.in.push(c),r.push(c)}for(let s of n)for(let i=0;i<s.length;i+=1)s[i].order=i;t.layers=n,t.hops=r}function Qn(t){for(let n=0;n<4;n+=1){for(let r=1;r<t.layers.length;r+=1)Kt(t,t.layers[r],"in"),We(t.layers[r]);for(let r=t.layers.length-2;r>=0;r-=1)Kt(t,t.layers[r],"out"),We(t.layers[r])}for(let n=0;n<2;n+=1){let r=!1;for(let o=1;o<t.layers.length;o+=1){let s=t.layers[o];for(let i=0;i+1<s.length;i+=1){let a=qt(t,s[i],s[i+1],"in");[s[i],s[i+1]]=[s[i+1],s[i]],We(s),qt(t,s[i],s[i+1],"in")<a?r=!0:([s[i],s[i+1]]=[s[i+1],s[i]],We(s))}}if(!r)break}}function Kt(t,e,n){let r=new Map;for(let o of e){let s=n==="in"?o.in:o.out;if(s.length===0){r.set(o.id,o.order);continue}let i=0,a=0;for(let d of s){let u=t.nodes.get(n==="in"?d.fromId:d.toId);u&&(i+=u.order,a+=1)}r.set(o.id,a===0?o.order:i/a)}e.sort((o,s)=>{let i=r.get(o.id),a=r.get(s.id);return i!==a?i-a:o.order-s.order})}function We(t){for(let e=0;e<t.length;e+=1)t[e].order=e}function qt(t,e,n,r){let o=r==="in"?e.in:e.out,s=r==="in"?n.in:n.out,i=0;for(let a of o)for(let d of s){let u=t.nodes.get(r==="in"?a.fromId:a.toId)?.order??0,c=t.nodes.get(r==="in"?d.fromId:d.toId)?.order??0;(e.order<n.order&&u>c||e.order>n.order&&u<c)&&(i+=1)}return i}function er(t,e){e.direction==="LR"?tr(t,e):nr(t,e)}function tr(t,e){let n=[],r=0;for(let o=0;o<t.layers.length;o+=1){n.push(r);let s=0;for(let i of t.layers[o])s=Math.max(s,i.w);r+=s+e.layerGap}for(let o=0;o<t.layers.length;o+=1)for(let s of t.layers[o])s.x=n[o];for(let o of t.layers){let s=0;for(let i of o)i.y=s,s+=i.h+e.nodeGap}Jt(t,e,"y")}function nr(t,e){let n=[],r=0;for(let o=0;o<t.layers.length;o+=1){n.push(r);let s=0;for(let i of t.layers[o])s=Math.max(s,i.h);r+=s+e.layerGap}for(let o=0;o<t.layers.length;o+=1)for(let s of t.layers[o])s.y=n[o];for(let o of t.layers){let s=0;for(let i of o)i.x=s,s+=i.w+e.nodeGap}Jt(t,e,"x")}function Jt(t,e,n){let r=s=>n==="y"?s.h:s.w,o=e.nodeGap;for(let s=0;s<2;s+=1){let i=s===0?t.layers.slice(1):t.layers.slice(0,-1).reverse();for(let a of i){let d=new Map;for(let c of a){let p=s===0?c.in:c.out;if(p.length===0)continue;let h=[];for(let l of p){let m=t.nodes.get(s===0?l.fromId:l.toId);if(!m)continue;let x=n==="y"?m.y:m.x;h.push(x+Math.floor(r(m)/2))}if(h.length===0)continue;h.sort((l,m)=>l-m);let f=h[Math.floor(h.length/2)];d.set(c.id,f-Math.floor(r(c)/2))}let u=0;for(let c of a){let p=d.get(c.id),h=n==="y"?c.y:c.x,l=Math.max(p??h,u);n==="y"?c.y=l:c.x=l,u=l+r(c)+o}}}}function rr(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,p)=>c.hopIndex-p.hopIndex);let r=e.direction==="LR",o=u=>r?u.x:u.y,s=u=>r?u.w:u.h,i=u=>r?u.y+Math.floor(u.h/2):u.x+Math.floor(u.w/2),a=new Map;for(let u=0;u+1<t.layers.length;u+=1){let c=t.layers[u],p=t.layers[u+1],h=0;for(let y of c)h=Math.max(h,o(y)+s(y));let f=Number.POSITIVE_INFINITY;for(let y of p)f=Math.min(f,o(y));let l=Number.isFinite(f)?f-1:h,m=Math.max(1,l-h+1),x=[];for(let y of c)for(let O of y.out)x.push(O);x.sort((y,O)=>{let S=i(t.nodes.get(y.fromId)),R=i(t.nodes.get(O.fromId));if(S!==R)return S-R;let E=i(t.nodes.get(y.toId)),A=i(t.nodes.get(O.toId));return E-A});let k=[],v=new Map;for(let y of x){let O=i(t.nodes.get(y.fromId)),S=i(t.nodes.get(y.toId)),R=Math.min(O,S),E=Math.max(O,S),A=-1;for(let L=0;L<k.length;L+=1){let j=k[L],B=!0;for(let se of j)if(se.lo<=E&&R<=se.hi){B=!1;break}if(B){j.push({lo:R,hi:E}),A=L;break}}A<0&&(k.push([{lo:R,hi:E}]),A=k.length-1),v.set(y,A)}let b=k.length,_=m>=Math.max(3,b+2),T=_?h+1:h,w=_?l-1:l,g=Math.max(1,w-T+1);for(let y of x){let O=v.get(y),S;if(b<=1)S=T+Math.floor(g/2);else{let R=(g-1)/(b-1);S=T+Math.floor(O*R)}a.set(y,Math.max(h,Math.min(l,S)))}}let d=[];for(let[,u]of n){let c=[];for(let h=0;h<u.length;h+=1){let f=u[h],l=t.nodes.get(f.fromId),m=t.nodes.get(f.toId),x=a.get(f),k=l.isVirtual?o(l):o(l)+s(l),v=m.isVirtual?o(m):o(m)-1,b=i(l),_=i(m);h===0&&Ke(c,r,k,b),b!==_&&(Ke(c,r,x,b),Ke(c,r,x,_)),Ke(c,r,v,_)}let p=u[0];d.push({from:p.chainFrom,to:p.chainTo,points:or(c)})}return d}function Ke(t,e,n,r){t.push(e?{x:n,y:r}:{x:r,y:n})}function or(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 sr(t){let e=0,n=0;for(let r of t.layers)for(let o of r)e=Math.max(e,o.x+o.w),n=Math.max(n,o.y+o.h);return{width:e,height:n}}var ir=24,ar=4,ur=1,dr=3;function Xt(t,e){let n=cr(e.direction),r=Math.max(3,e.maxLabelWidth??ir),o=e.asciiCharset??"unicode",s=Object.keys(t.nodes).sort(),i=new Set(s),a=t.edges.filter(f=>i.has(f.from)&&i.has(f.to)),d=new Map,u=new Map;for(let f of s){let l=zt(f,r);d.set(f,l),u.set(f,Ue(l)+4)}let c=Yt({nodes:s,edges:a,widthCells:f=>u.get(f)??3,heightCells:()=>dr,layerGap:ar,nodeGap:ur,direction:n}),p=Ut(c,{charset:o,labelOf:f=>d.get(f)??f}),h=e.logger;return h&&h(p),p}function cr(t){if(t===void 0||t==="LR")return"LR";if(t==="TD")return"TD";throw new Error(`ascii describe supports direction "LR" or "TD" only; got ${String(t)}`)}function Zt(t,e,n,r={}){let o=e in t.nodes,s=n in t.nodes;if(!o)return qe(e,n,"no-such-from");if(!s)return qe(e,n,"no-such-to");let i=r.maxDepth;if(i!=null&&(!Number.isInteger(i)||i<0))throw new Error("explainPath: maxDepth must be an integer >= 0");if(e===n){if(r.findCycle===!0){let u=lr(t,e,r);if(u!=null)return u}let d=Ye(e,t.nodes[e],0,r);return Je(e,n,[d])}if(i===0)return qe(e,n,"no-path");let a=Qt(t,e,n,i);return a.found?Je(e,n,en(t,a.pathOrder,r)):qe(e,n,a.truncated?"max-depth-exceeded":"no-path")}function Qt(t,e,n,r){let o=new Map,s=[{path:n,depth:0}],i=new Set([n]),a=0,d=!1;for(;a<s.length;){let p=s[a++];if(p.path===e)break;if(r!=null&&p.depth>=r){let m=t.nodes[p.path];m?.deps&&m.deps.length>0&&(d=!0);continue}let h=t.nodes[p.path];if(h==null)continue;let f=h.deps??[],l=new Map;for(let m=0;m<f.length;m++){let x=f[m];if(!x)continue;let k=l.get(x);k==null&&(k=[],l.set(x,k)),k.push(m)}for(let[m,x]of l)i.has(m)||(i.add(m),o.set(m,{from:p.path,depIndices:x}),s.push({path:m,depth:p.depth+1}))}if(!o.has(e))return{found:!1,pathOrder:[],truncated:d};let u=[{path:e}],c=e;for(;c!==n;){let p=o.get(c);if(p==null)return{found:!1,pathOrder:[],truncated:!1};u[u.length-1].depIndices=p.depIndices,u.push({path:p.from}),c=p.from}return{found:!0,pathOrder:u,truncated:!1}}function lr(t,e,n){let r=t.nodes[e];if(r==null)return null;let o=r.deps??[],s=[];for(let a=0;a<o.length;a++)o[a]===e&&s.push(a);if(s.length>0){let a=Ye(e,r,0,n);a.dep_index=s[0];let d=Ye(e,r,1,n);return Je(e,e,[a,d])}let i=null;for(let a=0;a<o.length;a++){let d=o[a];if(!d||d===e)continue;let u=Qt(t,d,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:Je(e,e,en(t,i.pathOrder,n))}function en(t,e,n){return e.map((r,o)=>{let s=t.nodes[r.path],i=Ye(r.path,s,o,n);return r.depIndices!=null&&r.depIndices.length>0&&(i.dep_index=r.depIndices[0],r.depIndices.length>1&&(i.dep_indices=[...r.depIndices])),i})}function Ye(t,e,n,r){let o={path:t,type:e.type,hop:n};e.status!==void 0&&(o.status=e.status),"value"in e&&(o.value=e.value),e.v!=null&&(o.v=e.v);let s=r.annotations?.get(t)??e.annotation;s!=null&&(o.annotation=s);let i=r.lastMutations?.get(t)??e.lastMutation;return i!=null&&(o.lastMutation=i),o}function Je(t,e,n){return tn(t,e,!0,"ok",n)}function qe(t,e,n){return tn(t,e,!1,n,[])}function tn(t,e,n,r,o){let s=fr(t,e,n,r,o);return{from:t,to:e,found:n,reason:r,steps:o,text:s,toJSON(){return{from:t,to:e,found:n,reason:r,steps:o}}}}function fr(t,e,n,r,o){if(!n)switch(r){case"no-such-from":return`explainPath: no node named "${t}"`;case"no-such-to":return`explainPath: no node named "${e}"`;case"max-depth-exceeded":return`explainPath: no path from "${t}" to "${e}" within maxDepth`;default:return`explainPath: no path from "${t}" to "${e}"`}let s=[`Causal path: ${t} \u2192 ${e} (${o.length} step(s))`];for(let i of o){let d=` ${i.hop===0?"\xB7":"\u2193"} ${i.path} (${i.type}${i.status?`/${i.status}`:""})`;if(s.push(d),"value"in i&&s.push(` value: ${pr(i.value)}`),i.annotation!=null&&s.push(` annotation: ${i.annotation}`),i.lastMutation!=null){let u=i.lastMutation.actor;s.push(` actor: ${u.type}${u.id?`:${u.id}`:""}`)}}return s.join(`
|
|
3
|
-
`)}function
|
|
4
|
-
`)}function
|
|
5
|
-
`);return e.logger?.(s),s}function
|
|
6
|
-
`)}function
|
|
7
|
-
`)}function Er(t){return t.replace(/[.*+?^${}()|[\]\\]/g,"\\$&")}function Xe(t){let e="^";for(let n=0;n<t.length;n+=1){let r=t[n];if(r==="*"){e+=".*";continue}if(r==="?"){e+=".";continue}if(r==="["){let o=t.indexOf("]",n+1);if(o<=n+1){e+="\\[";continue}let s=t.slice(n+1,o);s.startsWith("!")&&(s=`^${s.slice(1)}`),s=s.replace(/\\/g,"\\\\"),e+=`[${s}]`,n=o;continue}e+=Er(r)}return e+="$",new RegExp(e)}var Sr={data:"\x1B[32m",dirty:"\x1B[33m",resolved:"\x1B[36m",invalidate:"\x1B[93m",pause:"\x1B[90m",resume:"\x1B[96m",complete:"\x1B[34m",error:"\x1B[31m",teardown:"\x1B[91m",derived:"\x1B[35m",path:"\x1B[90m",reset:"\x1B[0m"},Ar={data:"",dirty:"",resolved:"",invalidate:"",pause:"",resume:"",complete:"",error:"",teardown:"",derived:"",path:"",reset:""};function Ze(t){if(typeof t=="string")return JSON.stringify(t);if(typeof t=="number"||typeof t=="boolean"||t==null)return String(t);try{return JSON.stringify(t)}catch{return"[unserializable]"}}function Dr(t){return t==="none"?Ar:t==="ansi"||t==null?Sr:{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 an(t){if(t==null)return{};let e=t.detail;return e==="full"?{...t,structured:t.structured??!0,timeline:t.timeline??!0,causal:t.causal??!0,derived:t.derived??!0}:e==="minimal"?{...t,structured:t.structured??!0}:t.format==="stage-log"?{...t,structured:t.structured??!0,timeline:t.timeline??!0}:t}function Cr(t,e,n){for(let r=0;r<t.length;r++){let o=t.charCodeAt(r);if(o<32||o===127)throw new Error(`Graph "${e}": ${n} "${t}" must not contain control character (U+${o.toString(16).padStart(4,"0").toUpperCase()} at index ${r})`)}}function bt(t,e,n){if(t==="")throw new Error(`Graph "${e}": ${n} name must be non-empty`);if(t.includes(F))throw new Error(`Graph "${e}": ${n} "${t}" must not contain '${F}' (path separator)`);if(t===ne)throw new Error(`Graph "${e}": ${n} name "${ne}" is reserved for meta companion paths`);Cr(t,e,n)}function Mr(t,e){if(t==="")throw new Error(`Graph "${e}": resolve path must be non-empty`);let n=t.split(F);for(let r of n)if(r==="")throw new Error(`Graph "${e}": resolve path has empty segment`);return n}function Gr(t,e){let n=!1;for(let o of t)if(!e.isMetaPassthrough(o[0])){n=!0;break}return n?t.filter(o=>e.isMetaPassthrough(o[0])):t}function pn(t){for(let e of t._mounts.values())pn(e);for(let e of t._nodes.values())try{e.down([[W]],{internal:!0})}catch{}}var Te=class t{name;opts;config;_nodes=new Map;_nodeToName=new WeakMap;_mounts=new Map;_parent=void 0;_storageDisposers=new Set;_disposers=new Set;_destroyed=!1;_topology;_topologyEmitters=new Set;constructor(e,n){if(e==="")throw new Error("Graph name must be non-empty");if(e.includes(F))throw new Error(`Graph name must not contain '${F}' (got "${e}")`);if(e===ne)throw new Error(`Graph name "${ne}" is reserved for meta companion paths`);this.name=e,this.opts=Object.freeze({...n??{}}),this.config=n?.config??we,this._traceRing=new Ce(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=$t(e=>{let n=r=>{e.emit(r)};return this._topologyEmitters.add(n),()=>{this._topologyEmitters.delete(n)}},{name:`${this.name}_topology`})),this._topology}_emitTopology(e){if(!(this._topology==null||this._topologyEmitters.size===0))for(let n of this._topologyEmitters)n(e)}nameOf(e){return this._nodeToName.get(e)}add(e,n){let r=e.name,o=n?.name??r;if(o==null||o==="")throw new Error(`Graph "${this.name}": graph.add requires a non-empty name \u2014 pass via opts.name or set it on the node (e.g. state(0, { name: "x" }))`);let s=o,i=n?.annotation;if(bt(s,this.name,"add"),this._mounts.has(s))throw new Error(`Graph "${this.name}": name "${s}" is already a mount point`);if(this._nodes.has(s))throw new Error(`Graph "${this.name}": node "${s}" already exists`);let a=this._nodeToName.get(e);if(a!==void 0)throw new Error(`Graph "${this.name}": node instance already registered as "${a}"`);return this._nodes.set(s,e),this._nodeToName.set(e,s),this._emitTopology({kind:"added",name:s,nodeKind:"node"}),i!=null&&(this._annotations.set(s,i),this.config.inspectorEnabled&&this._traceRing.push({path:s,annotation:i,timestamp_ns:ye()})),e}setVersioning(e){if(e!=null)for(let n of this._nodes.values())n instanceof V&&n._applyVersioning(e)}remove(e){bt(e,this.name,"remove");let n=this._mounts.get(e);if(n){let s={kind:"mount",nodes:[],mounts:[]},i=[];n._collectObserveTargets("",i);for(let[a,d]of i)a.includes(`${F}${ne}${F}`)||s.nodes.push(a);return s.nodes.sort(),s.mounts.push(e),s.mounts.push(...n._collectSubgraphs(`${e}${F}`)),this._mounts.delete(e),n._parent=void 0,pn(n),this._emitTopology({kind:"removed",name:e,nodeKind:"mount",audit:s}),s}let r=this._nodes.get(e);if(!r)throw new Error(`Graph "${this.name}": unknown node or mount "${e}"`);this._nodes.delete(e),this._nodeToName.delete(r),r.down([[W]],{internal:!0});let o={kind:"node",nodes:[e],mounts:[]};return this._emitTopology({kind:"removed",name:e,nodeKind:"node",audit:o}),o}removeAll(e){let n=typeof e=="function"?e:(()=>{let s=Xe(e);return i=>s.test(i)})(),r={kind:"mount",nodes:[],mounts:[]},o=[...this._nodes.keys(),...this._mounts.keys()].filter(s=>n(s));for(let s of o){let i=this.remove(s);r.nodes.push(...i.nodes),r.mounts.push(...i.mounts)}return r.nodes.sort(),r.mounts.sort(),r}[Symbol.iterator](){let e=[...this._nodes.keys()].sort(),n=this._nodes,r=0;return{[Symbol.iterator](){return this},next(){if(r>=e.length)return{value:void 0,done:!0};let o=e[r++];return{value:[o,n.get(o)],done:!1}}}}node(e){if(e==="")throw new Error(`Graph "${this.name}": node name must be non-empty`);if(e.includes(F))return this.resolve(e);let n=this._nodes.get(e);if(!n)throw new Error(`Graph "${this.name}": unknown node "${e}"`);return n}get(e){return this.node(e).cache}set(e,n,r){let o=r?.internal===!0;this.node(e).down([[P,n]],{actor:r?.actor,internal:o,delivery:"write"})}setAll(e,n){let r=Symbol.iterator in e?e:Object.entries(e);ie(()=>{for(let[o,s]of r)this.set(o,s,n)})}invalidate(e,n){let r=n?.internal===!0;this.node(e).down([[te]],{actor:n?.actor,internal:r,delivery:"write"})}error(e,n,r){let o=r?.internal===!0;this.node(e).down([[$,n]],{actor:r?.actor,internal:o,delivery:"write"})}complete(e,n){let r=n?.internal===!0;this.node(e).down([[U]],{actor:n?.actor,internal:r,delivery:"write"})}edges(e){let n=e?.recursive===!0,r=new Map;if(!n){for(let[d,u]of this._nodes)r.set(u,d);let a=[];for(let[d,u]of this._nodes)if(u instanceof V)for(let c of u._deps){let p=r.get(c.node);p!=null&&a.push([p,d])}return a.sort((d,u)=>d[0]<u[0]?-1:d[0]>u[0]?1:d[1]<u[1]?-1:d[1]>u[1]?1:0),a}let o=[];this._collectObserveTargets("",o);let s=new Map;for(let[a,d]of o)s.set(d,a);let i=[];for(let[a,d]of o)if(d instanceof V)for(let u of d._deps){let c=s.get(u.node);c!=null&&i.push([c,a])}return i.sort((a,d)=>a[0]<d[0]?-1:a[0]>d[0]?1:a[1]<d[1]?-1:a[1]>d[1]?1:0),i}mount(e,n){if(n===void 0){let o=new t(e);return this.mount(e,o)}if(typeof n=="function"){let o=new t(e);return n(o),this.mount(e,o)}let r=n;if(bt(e,this.name,"mount"),this._nodes.has(e))throw new Error(`Graph "${this.name}": cannot mount at "${e}" \u2014 node with that name exists`);if(this._mounts.has(e))throw new Error(`Graph "${this.name}": mount "${e}" already exists`);if(r===this)throw new Error(`Graph "${this.name}": cannot mount a graph into itself`);if(r._parent!=null)throw new Error(`Graph "${this.name}": this child graph is already mounted on "${r._parent.name}"`);for(let o=this;o!=null;o=o._parent)if(o===r)throw new Error(`Graph "${this.name}": mount("${e}", \u2026) would create a mount cycle`);return this._mounts.set(e,r),r._parent=this,this._emitTopology({kind:"added",name:e,nodeKind:"mount"}),r}resolve(e){let n=Mr(e,this.name);return this._resolveFromSegments(n)}tryResolve(e){try{return this.resolve(e)}catch{return}}_resolveFromSegments(e){let n=e;if(n[0]===this.name&&(n=n.slice(1),n.length===0))throw new Error(`Graph "${this.name}": resolve path ends at graph name only`);let r=n[0],o=n.slice(1);if(o.length===0){let a=this._nodes.get(r);if(a)return a;throw this._mounts.has(r)?new Error(`Graph "${this.name}": path ends at subgraph "${r}" \u2014 not a node (GRAPHREFLY-SPEC \xA73.5)`):new Error(`Graph "${this.name}": unknown name "${r}"`)}let s=this._nodes.get(r);if(s&&o.length>0&&o[0]===ne)return this._resolveMetaChainFromNode(s,o,n.join(F));let i=this._mounts.get(r);if(!i)throw this._nodes.has(r)?new Error(`Graph "${this.name}": "${r}" is a node; trailing path "${o.join(F)}" is invalid`):new Error(`Graph "${this.name}": unknown mount or node "${r}"`);return i.resolve(o.join(F))}_resolveMetaChainFromNode(e,n,r){let o=e,s=0,i=[...n];for(;s<i.length;){if(i[s]!==ne)throw new Error(`Graph "${this.name}": expected ${ne} segment in meta path "${r}"`);if(s+1>=i.length)throw new Error(`Graph "${this.name}": meta path requires a key after ${ne} in "${r}"`);let a=i[s+1],d=o.meta[a];if(!d)throw new Error(`Graph "${this.name}": unknown meta "${a}" in path "${r}"`);o=d,s+=2}return o}signal(e,n){if(n?.internal!==!0){for(let o of e)if(this.config.messageTier(o[0])===3)throw new Error(`Graph "${this.name}": Graph.signal() rejects tier-3 messages (DATA / RESOLVED). Broadcast is for control-plane tiers (START / DIRTY / INVALIDATE / PAUSE / RESUME / COMPLETE / ERROR / TEARDOWN). For per-node value writes, use Graph.set or graph.node(name).down(...).`)}let r=[];if(this._signalDeliver(e,n??{},new Set,r),r.length>0)throw r[0]}_signalDeliver(e,n,r,o){for(let d of this._mounts.values())d._signalDeliver(e,n,r,o);let i=n.internal===!0?{internal:!0}:{actor:n.actor,delivery:"signal"},a=Gr(e,this.config);for(let d of[...this._nodes.keys()].sort()){let u=this._nodes.get(d);if(!r.has(u)){r.add(u);try{u.down(e,i)}catch(c){if(c instanceof ee)throw c;o.push(c)}a.length!==0&&this._signalMetaSubtree(u,a,r,i,o)}}}_signalMetaSubtree(e,n,r,o,s){for(let i of Object.keys(e.meta).sort()){let a=e.meta[i];if(!r.has(a)){r.add(a);try{a.down(n,o)}catch(d){if(d instanceof ee)throw d;s.push(d)}this._signalMetaSubtree(a,n,r,o,s)}}}describe(e){if(e?.reactive===!0)return this._describeReactive(e);let n=br(e?.actor),r=e?.filter,o=je(e?.detail,e?.fields),s=e?.format==="spec",i=s?je("minimal"):o,a=[];this._collectObserveTargets("",a);let d=new Map;for(let[w,g]of a)d.set(g,w);let u=[];{let w=a.map(([,O])=>O),g=new Set(d.values()),y=0;for(;w.length>0;){let O=w.shift();if(O instanceof V)for(let S of O._deps){let R=S.node;if(d.has(R))continue;let E=R.name??"",A=E;if(!A||g.has(A))if(E){let L=2;for(;g.has(`${E}#${L}`);)L++;A=`${E}#${L}`}else for(A=`__internal__/${y++}`;g.has(A);)A=`__internal__/${y++}`;d.set(R,A),g.add(A),u.push([A,R]),w.push(R)}}}let c=[...a,...u],p={};for(let[w,g]of c){if(n!=null&&!g.allowsObserve(n))continue;let y=ht(g,i),O=g instanceof V?g._deps.map(A=>d.get(A.node)??A.node.name??""):[],{name:S,...R}=y,E={...R,deps:O};if(!s){let A=this._annotations.get(w);A!=null&&(E.annotation=A)}if(r!=null)if(typeof r=="function"){let A=r;if(!(A.length>=2?A(w,E):A(E)))continue}else{let A=!0;for(let[L,j]of Object.entries(r)){let B=L==="deps_includes"?"depsIncludes":L==="meta_has"?"metaHas":L;if(B==="depsIncludes"){if(!E.deps.includes(String(j))){A=!1;break}continue}if(B==="metaHas"){if(!Object.hasOwn(E.meta??{},String(j))){A=!1;break}continue}if(E[B]!==j){A=!1;break}}if(!A)continue}p[w]=E}let h=new Set(Object.keys(p)),f=[];for(let[w,g]of c)if(g instanceof V)for(let y of g._deps){let O=d.get(y.node);O!=null&&f.push([O,w])}f.sort((w,g)=>w[0]<g[0]?-1:w[0]>g[0]?1:w[1]<g[1]?-1:w[1]>g[1]?1:0);let l=f.map(([w,g])=>({from:w,to:g}));(n!=null||r!=null)&&(l=l.filter(w=>h.has(w.from)&&h.has(w.to)));let m=this._collectSubgraphs(""),x=n!=null||r!=null?m.filter(w=>{let g=`${w}${F}`;return[...h].some(y=>y===w||y.startsWith(g))}):m,k=this,v=e,b={name:this.name,nodes:p,edges:l,subgraphs:x,expand(w){let g={...v,format:void 0};return Array.isArray(w)?(g.fields=w,g.detail=void 0):(g.detail=w,g.fields=void 0),k.describe(g)}},_=e??{},T=_.format;return T==="json"?Tr(b,_):T==="pretty"?Or(b,_):T==="mermaid"?fn(b,_):T==="mermaid-url"?Nr(b,_):T==="d2"?kr(b,_):T==="ascii"?Xt(b,_):b}_collectSubgraphs(e){let n=[];for(let r of[...this._mounts.keys()].sort()){let o=e===""?r:`${e}${r}`;n.push(o),n.push(...this._mounts.get(r)._collectSubgraphs(`${o}${F}`))}return n}resourceProfile(e){return rn(this,e)}reachable(e,n,r={}){return r.withDetail===!0?un(this.describe(),e,n,{...r,withDetail:!0}):un(this.describe(),e,n,r)}explain(e,n,r){return r?.reactive===!0?this._explainReactive(e,n,r):this._explainStatic(e,n,r)}_explainStatic(e,n,r){let o=this.describe({detail:"full"}),s=new Map(this._annotations),i=new Map;for(let[a,d]of Object.entries(o.nodes))d.lastMutation!=null&&i.set(a,d.lastMutation);return Zt(o,e,n,{...r?.maxDepth!=null?{maxDepth:r.maxDepth}:{},...r?.findCycle===!0?{findCycle:!0}:{},annotations:s,lastMutations:i})}_describeReactive(e){let n={...e,reactive:!1},r=e.reactiveName??"describe",o=0,s=oe(o,{name:`${r}_version`}),i=this.observe({timeline:!0,structured:!0}),a=!1,d=!1,u=()=>{a||d||(a=!0,Ee(()=>{a=!1,!d&&(o+=1,s.emit(o))}))},c=i.onEvent(v=>{let b=v.type;b!=="data"&&b!=="error"&&b!=="complete"&&b!=="teardown"||u()}),p=[],h=new WeakSet,f=v=>{if(h.has(v)||d)return;h.add(v);let b=v.topology.subscribe(_=>{for(let T of _){if(T[0]!==P)continue;let w=T[1];if(u(),w.kind==="added"&&w.nodeKind==="mount"){let g=v._mounts.get(w.name);g!=null&&f(g)}}});p.push(b);for(let _ of v._mounts.keys()){let T=v._mounts.get(_);T!=null&&f(T)}};f(this);let l,m=e.actor;dn(m)&&(l=m.subscribe(v=>{let b=!1,_=!1;for(let T of v){let w=T[0];w===P?b=!0:(w===U||w===$||w===W)&&(_=!0)}b&&u(),_&&(l?.(),l=void 0,u())}));let x;try{x=J([s],()=>this.describe(n),{name:r,describeKind:"derived",meta:{domain:"audit",kind:"describe"},equals:(v,b)=>v===b})}catch(v){c(),l?.();for(let b of p)b();throw i.dispose(),v}let k=gt(x);return{node:x,dispose(){d=!0,c(),l?.();for(let v of p)v();p.length=0,i.dispose(),k()}}}_explainReactive(e,n,r){let o=0,s=oe(o,{name:"explain_version"}),i=this.observe({timeline:!0,structured:!0}),a=!1,d=!1,u=i.onEvent(f=>{let l=f.type;l!=="data"&&l!=="error"&&l!=="complete"&&l!=="teardown"||a||d||(a=!0,Ee(()=>{a=!1,!d&&(o+=1,s.emit(o))}))}),c={...r?.maxDepth!=null?{maxDepth:r.maxDepth}:{},...r?.findCycle===!0?{findCycle:!0}:{}},p;try{p=J([s],()=>this._explainStatic(e,n,c),{name:r?.name??"explain",describeKind:"derived",meta:{domain:"audit",kind:"explain_path",from:e,to:n},equals:(f,l)=>f.found===l.found&&f.reason===l.reason&&f.steps.length===l.steps.length&&Ir(f.steps,l.steps)})}catch(f){throw u(),i.dispose(),f}let h=gt(p);return{node:p,dispose(){d=!0,u(),i.dispose(),h()}}}_pathsMatching(e){let n=Xe(e),r=[];return this._collectObserveTargets("",r),r.map(([o])=>o).filter(o=>n.test(o))}_collectObserveTargets(e,n){for(let r of[...this._mounts.keys()].sort()){let o=e===""?r:`${e}${F}${r}`;this._mounts.get(r)._collectObserveTargets(o,n)}for(let r of[...this._nodes.keys()].sort()){let o=this._nodes.get(r),s=e===""?r:`${e}${F}${r}`;n.push([s,o]),this._appendMetaObserveTargets(s,o,n)}}_appendMetaObserveTargets(e,n,r){for(let o of Object.keys(n.meta).sort()){let s=n.meta[o],i=`${e}${F}${ne}${F}${o}`;r.push([i,s]),this._appendMetaObserveTargets(i,s,r)}}observe(e,n){let r=typeof e=="string",s=an(r?n:e),i=s.structured===!0||s.timeline===!0||s.causal===!0||s.derived===!0||s.detail==="minimal"||s.detail==="full"||s.format!=null,a=s.actor;if(r){let c=e,p=this.resolve(c);if(a!=null&&!p.allowsObserve(a))throw new ee({actor:a,action:"observe",nodeName:c});return i?this._buildStructuredObserver([[c,p]],s,"one"):{subscribe(h){return p.subscribe(h)},up(h){try{p.up?.(h)}catch(f){if(f instanceof ee)return;throw f}}}}let d=[];this._collectObserveTargets("",d),d.sort((c,p)=>c[0]<p[0]?-1:c[0]>p[0]?1:0);let u=a==null?d:d.filter(([,c])=>c.allowsObserve(a));return i?this._buildStructuredObserver(u,s,"all"):{subscribe:c=>{let p=u.map(([h,f])=>f.subscribe(l=>{c(h,l)}));return()=>{for(let h of p)h()}},up:(c,p)=>{try{this.resolve(c).up?.(p)}catch(h){if(h instanceof ee)return;throw h}}}}_buildStructuredObserver(e,n,r){let o=r==="one"?e[0]?.[0]:void 0,s=i=>{if(r==="one"&&o!=null){let c=this.resolve(o);return this._buildStructuredObserver([[o,c]],i,"one")}let a=[];this._collectObserveTargets("",a),a.sort((c,p)=>c[0]<p[0]?-1:c[0]>p[0]?1:0);let d=i.actor,u=d==null?a:a.filter(([,c])=>c.allowsObserve(d));return this._buildStructuredObserver(u,i,"all")};return this._createObserveResult(e,n,s)}_createObserveResult(e,n,r){let o=n.timeline===!0,s=n.causal===!0,i=n.derived===!0,a=n.detail==="minimal",d=this.config.inspectorEnabled,u=(s||i)&&d,c=n.maxEvents,p=c!=null&&c>0?new Ce(c):null,h=[],f=new Set,l={},m=new Set,x=0,k=0,v=0,b=0,_=0,T=0,w=!1,g=!1,y=0,O=new Map,S=new Map,R=new Map,E=N=>{p?p.push(N):h.push(N);for(let G of f)G(N)},A=()=>o?{timestamp_ns:ye(),in_batch:Pe(),batch_id:y}:{},L=(N,G)=>{if(!(!u||!(N instanceof V)))return N._setInspectorHook(K=>{if(K.kind==="dep_message")O.set(N,K.depIndex);else if(K.kind==="run"){let Ne=K.batchData.map((I,q)=>I!=null&&I.length>0?I.at(-1):K.prevData[q]);S.set(N,Ne);let Z=K.batchData.map(I=>I!=null?[...I]:void 0);R.set(N,Z),i&&E({type:"derived",path:G,dep_values:Ne,dep_batches:Z,...A()})}})},j=N=>{let G=O.get(N),K=S.get(N);if(!s||K==null)return{};let Z=(G!=null&&G>=0&&N instanceof V?N._deps[G]:void 0)?.node,I=Z?.v,q=R.get(N);return{trigger_dep_index:G,trigger_dep_name:Z?.name,...I!=null?{trigger_version:{id:I.id,version:I.version}}:{},dep_values:[...K],...q!=null?{dep_batches:q}:{}}},B=[],se=[];for(let[N,G]of e){let K=L(G,N);K&&B.push(K),se.push(G.subscribe(Ne=>{y++;for(let Z of Ne){let I=Z[0],q=A();if(I===P){l[N]=Z[1];let Qe=G instanceof V?G.lastMutation?.actor??_e:_e;E({type:"data",path:N,data:Z[1],actor:Qe,...q,...j(G)})}else if(a)I===Y?x++:I===H?k++:I===te?v++:I===re?b++:I===de?_++:I===W?T++:I===U&&!m.has(N)?w=!0:I===$&&(g=!0,m.add(N));else if(I===Y)x++,E({type:"dirty",path:N,...q});else if(I===H)k++,E({type:"resolved",path:N,...q,...j(G)});else if(I===te)v++,E({type:"invalidate",path:N,...q});else if(I===re)b++,E({type:"pause",path:N,lockId:Z[1],...q});else if(I===de)_++,E({type:"resume",path:N,lockId:Z[1],...q});else if(I===U)m.has(N)||(w=!0),E({type:"complete",path:N,...q});else if(I===$){g=!0,m.add(N);let Qe=G instanceof V?G.lastMutation?.actor??_e:_e;E({type:"error",path:N,data:Z[1],actor:Qe,...q})}else I===W&&(T++,E({type:"teardown",path:N,...q}))}}))}let Ie=!1,C=()=>{if(!Ie){Ie=!0;for(let N of se)N();for(let N of B)N();for(let N of D)N({value:void 0,done:!0});D.length=0}},M=[],D=[];f.add(N=>{let G=D.shift();G?G({value:N,done:!1}):M.push(N)});let X={get values(){return l},get dirtyCount(){return x},get resolvedCount(){return k},get invalidateCount(){return v},get pauseCount(){return b},get resumeCount(){return _},get teardownCount(){return T},get events(){return p?p.toArray():[...h]},get anyCompletedCleanly(){return w},get anyErrored(){return g},get completedWithoutErrors(){return w&&!g},onEvent(N){return f.add(N),()=>f.delete(N)},dispose:C,expand(N){C();let G={...n};return typeof N=="string"?G.detail=N:Object.assign(G,N),r(an(G))},[Symbol.asyncIterator](){return{next(){return M.length>0?Promise.resolve({value:M.shift(),done:!1}):Ie?Promise.resolve({value:void 0,done:!0}):new Promise(N=>D.push(N))},return(){return C(),Promise.resolve({value:void 0,done:!0})}}}};return n.format!=null&&this._attachFormatLogger(X,n),X}_attachFormatLogger(e,n){let r=n.format;if(r==null)return;let o=n.logger??(l=>console.log(l)),s=n.includeTypes?new Set(n.includeTypes):null,i=n.excludeTypes?new Set(n.excludeTypes):null,a=s==null&&i==null?()=>!0:l=>(s==null||s.has(l))&&(i==null||!i.has(l)),d=Dr(n.theme),u=r==="stage-log"?ye():0,c=l=>l==null?"":n.stageLabels?.[l]??l,p=(l,m)=>l.length>m?`${l.slice(0,m-1)}\u2026`:l,h=l=>l.type==="data"||l.type==="error"?p(Ze(l.data),120):"",f=l=>{if(r==="stage-log"){let g=(ye()-u)/1e9,y=c(l.path).padEnd(9);if(l.type==="data"){let O=h(l);return`[${g.toFixed(3)}s] ${y} \u2190${O?` ${O}`:""}`}if(l.type==="error"){let O=h(l);return`[${g.toFixed(3)}s] ${y} \u2717${O?` ${O}`:""}`}return l.type==="complete"?`[${g.toFixed(3)}s] ${y} \u25A0 complete`:`[${g.toFixed(3)}s] ${y} ${l.type}`}if(r==="json")try{return JSON.stringify(l)}catch{return JSON.stringify({type:l.type,path:l.path,data:"[unserializable]"})}let m=d[l.type]??"",x=l.path?`${d.path}${l.path}${d.reset} `:"",k=l.type==="data"||l.type==="error",v=l.type==="pause"||l.type==="resume",b=k?` ${Ze(l.data)}`:v?` ${Ze(l.lockId)}`:"",_=l.type==="data"||l.type==="resolved"||l.type==="derived"?l:void 0,T=_?.trigger_dep_name!=null?` <- ${_.trigger_dep_name}`:_?.trigger_dep_index!=null?` <- #${_.trigger_dep_index}`:"",w=l.in_batch?" [batch]":"";return`${x}${m}${l.type.toUpperCase()}${d.reset}${b}${T}${w}`};e.onEvent(l=>{a(l.type)&&o(f(l),l)})}addDisposer(e){return this._disposers.add(e),()=>{this._disposers.delete(e)}}destroy(){on(this._disposers,this.name),this.signal([[W]],{internal:!0}),on(this._storageDisposers,this.name);for(let e of[...this._mounts.values()])e._parent=void 0,e._destroyClearOnly();this._mounts.clear(),this._nodes.clear(),this._parent=void 0,this._destroyed=!0}get destroyed(){return this._destroyed}_destroyClearOnly(){for(let e of[...this._mounts.values()])e._parent=void 0,e._destroyClearOnly();this._mounts.clear(),this._nodes.clear(),this._parent=void 0,this._destroyed=!0}snapshot(e){let{expand:n,...r}=this.describe({detail:"full"}),o={};for(let a of Object.keys(r.nodes).sort()){let{lastMutation:d,guard:u,...c}=r.nodes[a];o[a]=c}let s=[...r.subgraphs].sort(),i={...r,version:1,nodes:o,subgraphs:s};if(e?.format==null)return i;if(e.format==="json-string")return JSON.stringify(i);if(e.format==="bytes"){if(e.codec==null)throw new Error("snapshot({format: 'bytes'}) requires a `codec` name");let a=this.config.lookupCodec(e.codec);if(a==null)throw new Error(`snapshot: codec "${e.codec}" is not registered on this graph's config. Call config.registerCodec(...) before creating nodes.`);return Nt(a,a.encode(i))}throw new Error(`snapshot: unknown format "${String(e.format)}"`)}static decode(e,n){let r=n?.config??we,{codec:o,codecVersion:s,payload:i}=Rt(e,r);return o.decode(i,s)}restore(e,n){if(sn(e),e.name!==this.name)throw new Error(`Graph "${this.name}": restore snapshot name "${e.name}" does not match this graph`);let r=n?.only==null?null:(Array.isArray(n.only)?n.only:[n.only]).map(s=>Xe(s)),o=n?.includeProducers===!0;for(let s of Object.keys(e.nodes).sort()){if(r!==null&&!r.some(a=>a.test(s)))continue;let i=e.nodes[s];if(i!==void 0){if(!("value"in i)||i.value===void 0){"value"in i&&i.value===void 0&&n?.onError?.(s,new Error(`restore: slice.value is undefined for "${s}" (undefined is the global SENTINEL; not valid DATA)`));continue}if(!(i.type==="derived"||i.type==="effect")&&!(i.type==="producer"&&!o)){if(i.v!=null){let d=this.tryResolve(s)?.v;if(d!=null&&d.id===i.v.id&&d.version===i.v.version)continue}try{this.set(s,i.value)}catch(a){n?.onError?.(s,a)}}}}}static fromSnapshot(e,n){sn(e);let r=typeof n=="function"?n:n?.build,o=typeof n=="function"?void 0:n?.factories,s=new t(e.name);if(r)return r(s),s.restore(e),s;for(let f of[...e.subgraphs].sort((l,m)=>{let x=l.split(F).length,k=m.split(F).length;return x!==k?x-k:l<m?-1:l>m?1:0})){let l=f.split(F),m=s;for(let x of l)m._mounts.has(x)||m.mount(x,new t(x)),m=m._mounts.get(x)}let i=o?Object.entries(o).map(([f,l])=>({re:Xe(f),factory:l})):[],a=f=>{for(let l of i)if(l.re.test(f))return l.factory},d=f=>{let l=f.split(F),m=l.pop();if(m==null||m.length===0)throw new Error(`invalid snapshot path "${f}"`);let x=s;for(let k of l){let v=x._mounts.get(k);if(!v)throw new Error(`unknown mount "${k}" in path "${f}"`);x=v}return[x,m]},u=Object.entries(e.nodes).filter(([f])=>!f.includes(`${F}${ne}${F}`)).sort((f,l)=>f[0]<l[0]?-1:f[0]>l[0]?1:0),c=new Map(u),p=new Map,h=!0;for(;c.size>0&&h;){h=!1;for(let[f,l]of[...c.entries()]){let m=l?.deps??[];if(!m.every(T=>p.has(T)))continue;let[x,k]=d(f),v={...l?.meta??{}},b=a(f),_;if(l?.type==="state")_=oe(l.value,{meta:v});else{if(b==null)continue;_=b(k,{path:f,type:l.type,value:l.value,meta:v,deps:m,resolvedDeps:m.map(T=>p.get(T))})}x.add(_,{name:k}),p.set(f,_),c.delete(f),h=!0}}if(c.size>0){let f=[...c.keys()].sort().join(", ");throw new Error(`Graph.fromSnapshot could not reconstruct nodes without build callback: ${f}. Pass matching factories via fromSnapshot(data, { factories: { pattern: factoryFn } }).`)}return s.restore(e),s}toJSON(){return this.snapshot()}attachSnapshotStorage(e,n={}){let r=e.map(u=>({tier:u,debounceMs:Math.max(0,u.debounceMs??0),compactEvery:Math.max(1,u.compactEvery??10),timer:void 0,seq:0,lastSnapshot:void 0,lastFingerprint:"",disposed:!1,savePending:void 0}));n.autoRestore===!0&&this._cascadeRestore(e,n.onError);let o=(u,c)=>{if(u.disposed)return;let p=yr(c.nodes);if(u.lastSnapshot!=null&&p!==""&&p===u.lastFingerprint)return;let h=u.seq+1,f=ue(),x=u.lastSnapshot==null||h%u.compactEvery===0?{name:this.name,mode:"full",snapshot:c,seq:h,timestamp_ns:f,format_version:xe}:{name:this.name,mode:"diff",diff:Lr(u.lastSnapshot,c),seq:h,timestamp_ns:f,format_version:xe};if(u.tier.filter&&!u.tier.filter(x))return;let k;try{k=u.tier.save(x)}catch(v){n.onError?.(v,u.tier);return}if(k&&typeof k.then=="function"){let _=(u.savePending??Promise.resolve()).then(()=>k,()=>k).then(()=>{u.disposed||(u.seq=h,u.lastSnapshot=c,u.lastFingerprint=p)},T=>{n.onError?.(T,u.tier)});u.savePending=_.finally(()=>{u.savePending===_&&(u.savePending=void 0)})}else u.seq=h,u.lastSnapshot=c,u.lastFingerprint=p},s=(u,c)=>{try{o(u,c)}catch(p){n.onError?.(p,u.tier)}},i=(u,c)=>{if(!c.some(l=>{let m=this.config.messageTier(l[0]);return m>=3&&m<5}))return;if(n.filter){let l=this.tryResolve(u);if(l==null)return;let m=ht(l,je("standard"));if(!n.filter(u,m))return}let h,f=()=>(h==null&&(h=this.snapshot()),h);for(let l of r)l.disposed||(l.debounceMs===0?s(l,f()):(l.timer==null&&(l.timer=new He),l.timer.start(l.debounceMs,()=>{l.disposed||s(l,this.snapshot())})))},a;if(n.paths!=null){let c=(typeof n.paths=="string"?this._pathsMatching(n.paths):n.paths).map(p=>{let h=this.tryResolve(p);return h==null?()=>{}:h.subscribe(f=>i(p,f))});a=()=>{for(let p of c)p()}}else a=this.observe().subscribe((u,c)=>i(u,c));let d=()=>{a();for(let u of r)u.disposed=!0,u.timer?.cancel();this._storageDisposers.delete(d)};return this._storageDisposers.add(d),{dispose:d}}async _cascadeRestore(e,n){for(let r of e){let o;try{o=await r.load?.()}catch(i){n?.(i,r);continue}if(o==null||typeof o!="object"||Array.isArray(o))continue;let s=o;try{if(s.mode==="full"&&s.snapshot!=null)return this.restore(s.snapshot),!0;if(s.version===xe&&s.nodes!=null)return this.restore(s),!0}catch(i){n?.(i,r)}}return!1}static async fromStorage(e,n,r){for(let o of n){let s;try{s=await o.load?.()}catch(d){r?.onError?.(d,o);continue}if(s==null||typeof s!="object"||Array.isArray(s))continue;let i=s,a=i.mode==="full"&&i.snapshot!=null?i.snapshot:i.version===xe&&i.nodes!=null?i:void 0;if(a!=null)try{return t.fromSnapshot(a,r)}catch(d){r?.onError?.(d,o)}}throw new Error(`Graph.fromStorage: no tier held a restorable record for "${e}" across ${n.length} tier(s)`)}_annotations=new Map;_traceRing;trace(e,n,r){if(e!=null&&n!=null){if(this.tryResolve(e)==null)return;if(this._annotations.set(e,n),this.config.inspectorEnabled){let o={path:e,annotation:n,timestamp_ns:ye(),...r?.actor!=null?{actor:r.actor}:{}};this._traceRing.push(o)}return}return e!=null?this.config.inspectorEnabled?this._annotations.get(e):void 0:this.config.inspectorEnabled?this._traceRing.toArray():[]}annotation(e){return this._annotations.get(e)}clearTrace(){this._annotations.clear(),this._traceRing.clear()}pruneTrace(e){let n=this._traceRing.toArray().filter(o=>!e(o)),r=this._traceRing.size-n.length;this._traceRing.clear();for(let o of n)this._traceRing.push(o);return r}static diff(e,n){let r=new Set(Object.keys(e.nodes)),o=new Set(Object.keys(n.nodes)),s=[...o].filter(v=>!r.has(v)).sort(),i=[...r].filter(v=>!o.has(v)).sort(),a=[],d=[];for(let v of r){if(!o.has(v))continue;let b=e.nodes[v],_=n.nodes[v],T=b.v,w=_.v;T!=null&&w!=null&&T.id===w.id&&T.version!==w.version&&d.push({path:v,id:T.id,from:T.version,to:w.version});let g=T!=null&&w!=null&&T.id===w.id&&T.version===w.version;for(let y of["type","status","sentinel"]){let O=b[y],S=_[y];O!==S&&a.push({path:v,field:y,from:O,to:S})}if(!g)for(let y of["value","meta"]){let O=b[y],S=_[y];vr(O,S)||a.push({path:v,field:y,from:O,to:S})}}let u=v=>`${v.from} ${v.to}`,c=new Set(e.edges.map(u)),p=new Set(n.edges.map(u)),h=n.edges.filter(v=>!c.has(u(v))),f=e.edges.filter(v=>!p.has(u(v))),l=new Set(e.subgraphs),m=new Set(n.subgraphs),x=[...m].filter(v=>!l.has(v)).sort(),k=[...l].filter(v=>!m.has(v)).sort();return{nodesAdded:s,nodesRemoved:i,nodesChanged:a,versionChanges:d,edgesAdded:h,edgesRemoved:f,subgraphsAdded:x,subgraphsRemoved:k}}};function Lr(t,e){let n=Te.diff(t,e),r={};for(let o of n.nodesAdded){let s=e.nodes[o];s!=null&&(r[o]=s)}return{...n,nodesAddedFull:r}}function un(t,e,n,r={}){let o={paths:[],depths:new Map,truncated:!1};if(!e)return r.withDetail?o:[];if(!r.both&&n!=="upstream"&&n!=="downstream")throw new Error('reachable: direction must be "upstream" or "downstream"');let s=r.maxDepth;if(s!=null&&(!Number.isInteger(s)||s<0))throw new Error("reachable: maxDepth must be an integer >= 0");if(s===0)return r.withDetail?o:[];let i=new Map,a=new Map,d=new Map,u=new Map,c=new Set;for(let[b,_]of Object.entries(t.nodes)){if(!b)continue;c.add(b);let T=_.deps??[];i.set(b,T);for(let w of T)w&&(c.add(w),a.has(w)||a.set(w,new Set),a.get(w).add(b))}for(let b of t.edges){if(b==null||typeof b!="object")continue;let _=typeof b.from=="string"?b.from:"",T=typeof b.to=="string"?b.to:"";!_||!T||(c.add(_),c.add(T),u.has(_)||u.set(_,new Set),u.get(_).add(T),d.has(T)||d.set(T,new Set),d.get(T).add(_))}if(!c.has(e))return r.withDetail?o:[];let p=r.both===!0,h=b=>{if(p){let g=i.get(b)??[],y=d.get(b),O=a.get(b),S=u.get(b),R=[...g];return y&&R.push(...y),O&&R.push(...O),S&&R.push(...S),R}if(n==="upstream"){let g=i.get(b)??[],y=d.get(b);return y?[...g,...y]:g}let _=a.get(b),T=u.get(b),w=_?[..._]:[];return T&&w.push(...T),w},f=new Set([e]),l=new Map,m=[{path:e,depth:0}],x=0,k=!1;for(;x<m.length;){let b=m[x++];if(s!=null&&b.depth>=s){h(b.path).length>0&&(k=!0);continue}for(let _ of h(b.path))!_||f.has(_)||(f.add(_),l.set(_,b.depth+1),m.push({path:_,depth:b.depth+1}))}let v=[...l.keys()].sort((b,_)=>b<_?-1:b>_?1:0);return r.withDetail?{paths:v,depths:l,truncated:k}:v}function Ir(t,e){if(t.length!==e.length)return!1;for(let n=0;n<t.length;n++){let r=t[n],o=e[n];if(r.path!==o.path||r.type!==o.type||r.status!==o.status||r.hop!==o.hop||r.dep_index!==o.dep_index||r.annotation!==o.annotation||r.value!==o.value||r.lastMutation!==o.lastMutation)return!1;let s=r.v,i=o.v;if(s!==i&&(s==null||i==null||s.id!==i.id||s.version!==i.version))return!1}return!0}be();Se();De();pe();be();pe();he();Be();var vt=class{_version=0;_maxSize;_buf;_head=0;_size=0;constructor(e,n){if(n!==void 0&&n<1)throw new RangeError("maxSize must be >= 1");if(this._maxSize=n,n!==void 0){if(this._buf=new Array(n),e&&e.length>0){let r=Math.min(e.length,n),o=e.length-r;for(let s=0;s<r;s++)this._buf[s]=e[o+s];this._size=r}}else this._buf=e?[...e]:[],this._size=this._buf.length}get version(){return this._version}get size(){return this._size}at(e){if(!Number.isInteger(e))return;let n=e>=0?e:this._size+e;if(!(n<0||n>=this._size))return this._maxSize!==void 0?this._buf[(this._head+n)%this._maxSize]:this._buf[n]}append(e){this._rawAppend(e),this._version+=1}appendMany(e){if(e.length===0)return;let n=this._maxSize!==void 0&&e.length>this._maxSize?e.length-this._maxSize:0;for(let r=n;r<e.length;r++)this._rawAppend(e[r]);this._version+=1}clear(){if(this._size===0)return 0;let e=this._size;if(this._maxSize===void 0)this._buf.length=0;else for(let n=0;n<e;n++)this._buf[(this._head+n)%this._maxSize]=void 0;return this._head=0,this._size=0,this._version+=1,e}trimHead(e){if(!Number.isInteger(e)||e<0)throw new RangeError(`trimHead: n must be a non-negative integer (got ${e})`);if(e===0||this._size===0)return 0;let n=Math.min(e,this._size);if(this._maxSize===void 0)this._buf.splice(0,n);else{for(let r=0;r<n;r++)this._buf[(this._head+r)%this._maxSize]=void 0;this._head=(this._head+n)%this._maxSize}return this._size-=n,this._version+=1,n}slice(e,n){if(!Number.isInteger(e)||e<0)throw new RangeError(`slice: start must be a non-negative integer (got ${e})`);if(n!==void 0&&(!Number.isInteger(n)||n<0))throw new RangeError(`slice: stop must be a non-negative integer or undefined (got ${n})`);let r=n===void 0?this._size:Math.min(Math.max(n,0),this._size),o=Math.min(e,this._size);if(o>=r)return[];let s=r-o;if(this._maxSize===void 0)return this._buf.slice(o,r);let i=new Array(s);for(let a=0;a<s;a++)i[a]=this._buf[(this._head+o+a)%this._maxSize];return i}tail(e){if(!Number.isInteger(e)||e<0)throw new RangeError(`tail: n must be a non-negative integer (got ${e})`);if(e===0||this._size===0)return[];let n=Math.min(e,this._size);return this.slice(this._size-n,this._size)}toArray(){if(this._maxSize===void 0)return[...this._buf];let e=new Array(this._size);for(let n=0;n<this._size;n++)e[n]=this._buf[(this._head+n)%this._maxSize];return e}snapshot(){return this.toArray()}restore(e){if(this._maxSize===void 0){this._buf.length=0;for(let n=0;n<e.length;n++)this._buf.push(e[n]);this._size=this._buf.length}else{let n=this._maxSize;for(let s=0;s<n;s++)this._buf[s]=void 0;this._head=0;let r=Math.min(e.length,n),o=e.length-r;for(let s=0;s<r;s++)this._buf[s]=e[o+s];this._size=r}this._version+=1}_rawAppend(e){if(this._maxSize===void 0){this._buf.push(e),this._size=this._buf.length;return}this._size<this._maxSize?(this._buf[(this._head+this._size)%this._maxSize]=e,this._size+=1):(this._buf[this._head]=e,this._head=(this._head+1)%this._maxSize)}};function Me(t){return t.subscribe(()=>{})}var Pr=64;function hn(t,e={}){let{name:n,maxSize:r,versioning:o,guard:s,backend:i}=e,a=i??new vt(t,r),d=oe(a.toArray(),{name:n,describeKind:"state",equals:(g,y)=>g===y,...o!=null?{versioning:o}:{},...s!=null?{guard:s}:{}});function u(){let g=a.toArray();ie(()=>{d.down([[Y]],{internal:!0}),d.down([[P,g]],{internal:!0})})}let c=new Map,p=new Map,h=new Map;function f(g,y){return`${g}:${y===void 0?"END":y}`}function l(g){if(g.size<Pr)return;let y=g.keys().next();if(y.done)return;let O=g.get(y.value);O!==void 0&&O.dispose(),g.delete(y.value)}function m(g){let y=a.version;try{return g()}finally{a.version!==y&&u()}}function x(g){if(!Number.isInteger(g)||g<0)throw new RangeError(`tail: n must be a non-negative integer (got ${g})`);let y=c.get(g);if(y!==void 0)return c.delete(g),c.set(g,y),y.node;l(c);let O=J([d],([R])=>{let E=R;return g===0||E.length===0?[]:E.slice(Math.max(0,E.length-g))},{initial:a.tail(g),describeKind:"derived"}),S=Me(O);return c.set(g,{node:O,dispose:S}),O}function k(g,y){if(!Number.isInteger(g)||g<0)throw new RangeError(`slice: start must be a non-negative integer (got ${g})`);if(y!==void 0&&(!Number.isInteger(y)||y<0))throw new RangeError(`slice: stop must be a non-negative integer or undefined (got ${y})`);let O=f(g,y),S=p.get(O);if(S!==void 0)return p.delete(O),p.set(O,S),S.node;l(p);let R=J([d],([A])=>{let L=A;return y===void 0?L.slice(g):L.slice(g,y)},{initial:a.slice(g,y),describeKind:"derived"}),E=Me(R);return p.set(O,{node:R,dispose:E}),R}function v(g){let y=h.get(g);if(y!==void 0)return y.node;let O=J([d,g],([R,E])=>{let A=R,L=Math.max(0,Math.trunc(E??0));return A.slice(L)},{initial:[],describeKind:"derived"}),S=Me(O);return h.set(g,{node:O,dispose:S}),O}let b,_;function T(){b===void 0&&(b=ae([d],(g,y,O)=>{let S=g[0],E=S!=null&&S.length>0?S.at(-1):O.prevData[0];if(E==null||E.length===0){y.down([[H]]);return}y.emit(E[E.length-1])},{name:n!=null?`${n}::lastValue`:"lastValue",describeKind:"derived",initial:a.size===0?void 0:a.at(a.size-1)}),_=J([d],([g])=>g.length>0,{name:n!=null?`${n}::hasLatest`:"hasLatest",describeKind:"derived",initial:a.size>0}),Me(b),Me(_))}let w={entries:d,get size(){return a.size},at(g){return a.at(g)},append(g){m(()=>a.append(g))},appendMany(g){g.length!==0&&m(()=>a.appendMany(g))},clear(){m(()=>a.clear())},trimHead(g){m(()=>a.trimHead(g))},withLatest(){return T(),d},get lastValue(){return T(),b},get hasLatest(){return T(),_},view(g){switch(g.kind){case"tail":return x(g.n);case"slice":return k(g.start,g.stop);case"fromCursor":return v(g.cursor)}},attach(g){let y=g.subscribe(O=>{for(let S of O)S[0]===P&&w.append(S[1])});return()=>y()},attachStorage(g){if(g.length===0)return()=>{};let y=new Map;for(let S of g)y.set(S,a.size);(async()=>{for(let S of g)if(typeof S.loadEntries=="function")try{let R=await Promise.resolve(S.loadEntries());R.entries.length>0&&a.size===0&&(a.restore(R.entries),y.set(S,R.entries.length),u());break}catch{}})();let O=d.subscribe(S=>{for(let R of S){if(R[0]!==P)continue;let E=R[1];for(let A of g){let L=y.get(A)??0;if(E.length<L){try{let B=A.appendEntries(E);B instanceof Promise&&B.catch(()=>{})}catch{}y.set(A,E.length);continue}if(E.length===L)continue;let j=E.slice(L);y.set(A,E.length);try{let B=A.appendEntries(j);B instanceof Promise&&B.catch(()=>{})}catch{}}}});return()=>O()},disposeAllViews(){for(let g of c.values())g.dispose();c.clear();for(let g of p.values())g.dispose();p.clear();for(let g of h.values())g.dispose();h.clear()},dispose(){for(let g of c.values())g.dispose();c.clear();for(let g of p.values())g.dispose();p.clear();for(let g of h.values())g.dispose();h.clear()}};return w}var $r=Dt((t,e)=>{t("observe"),t("signal"),e("write")});function mn(t){let e=hn([],{name:t.name,maxSize:t.retainedLimit??1024,guard:t.guard??$r,...t.versioning!=null?{versioning:t.versioning}:{}});return e.withLatest(),t.graph&&t.graph.add(e.entries,{name:t.name}),e}function bn(t){if(t===null||typeof t!="object"||Object.isFrozen(t))return t;for(let e of Object.keys(t))bn(t[e]);return Object.freeze(t)}function Fr(t){let e=t.cache,r=(typeof e=="number"&&Number.isFinite(e)?e:0)+1;return t.down([[Y],[P,r]]),r}function gn(t,e,n,r,o,s){let i=e(n,r,o);if(i===void 0)return;let a=s!=null?{...i,handlerVersion:s}:i;t.append(a)}function Oe(t,e){let n=e.freeze??!0;return function(...o){let s=n?o.map(bn):o,i=ue(),a,d,u=!1,c;try{ie(()=>{e.seq&&(c=Fr(e.seq));try{a=t(...s),e.onSuccess&&gn(e.audit,e.onSuccess,s,a,{t_ns:i,seq:c},e.handlerVersion)}catch(p){throw d=p,u=!0,p}})}catch(p){if(u&&e.onFailure){let h=d instanceof Error?d.name:typeof d;gn(e.audit,e.onFailure,s,d,{t_ns:i,seq:c,errorType:h},e.handlerVersion)}throw u?d:p}return a}}function yn(t,e,n){return{[t]:!0,[`${t}_type`]:e,...n??{}}}function Ge(t,e){return yn("orchestration",t,e)}var vn=t=>t.action,Le=class extends Te{constructor(e,n){super(e,n)}task(e,n,r={}){let o=(r.deps??[]).map(i=>this._resolveStep(i)),s=J(o,n,{name:e,describeKind:"derived",meta:Ge("task",r.meta)});return this.add(s,{name:e}),s}classify(e,n,r,o={}){let s=this._resolveStep(n),i=J([s],([a])=>{try{return{tag:r(a),value:a}}catch(d){return{tag:"error",value:a,error:d}}},{name:e,describeKind:"derived",meta:Ge("classify",o.meta)});return this.add(i,{name:e}),i}combine(e,n,r={}){let o=Object.keys(n),s=o.map(a=>this._resolveStep(n[a])),i=J(s,a=>{let d={};for(let u=0;u<o.length;u++)d[o[u]]=a[u];return d},{name:e,describeKind:"derived",meta:Ge("combine",r.meta)});return this.add(i,{name:e}),i}gate(e,n,r={}){let o=r.maxPending??1e3;if(o<1&&o!==Number.POSITIVE_INFINITY)throw new RangeError("gate: maxPending must be >= 1");let s=r.startOpen??!1;typeof n!="string"&&this.nameOf(n)===void 0&&this.add(n,{name:`${e}/source`});let i=this._resolveStep(n),a=new Te(`${e}_state`),d=oe([],{name:"pending",equals:()=>!1}),u=oe(s,{name:"isOpen"}),c=J([d],([C])=>C.length,{name:"count"}),p=oe(0,{name:"droppedCount"}),h=mn({name:"decisions",retainedLimit:1024,graph:a});a.add(d,{name:"pending"}),a.add(u,{name:"isOpen"}),a.add(c,{name:"count"}),a.add(p,{name:"droppedCount"}),this.mount(`${e}_state`,a);let f=[],l=!1,m=!1,x=s,k=u.subscribe(C=>{for(let M of C)M[0]===P&&(x=M[1])});this.addDisposer(k);function v(){d.emit([...f])}function b(C,M,D){h.append({action:C,t_ns:ue(),...M!==void 0?{items:M,count:M.length}:{},...D!==void 0?{unflushed:D}:{},...r.handlerVersion!=null?{handlerVersion:r.handlerVersion}:{}})}function _(C){if(f.push(C),f.length>o){let M=f.shift();p.emit(p.cache+1),b("drop",[M])}v()}function T(C){let M=f.splice(0,C);return v(),M}let w=ae([i],(C,M,D)=>{let X=D.terminalDeps[0];if(X!==void 0){l=!0;let G=f.length;f=[],v(),b("teardown",void 0,G),M.down(X===!0?[[U]]:[[$,X]]);return}let N=C[0];if(N==null||N.length===0){M.down([[H]]);return}for(let G of N)x?M.emit(G):(_(G),M.down([[H]]))},{name:e,describeKind:"derived",meta:Ge("gate",r.meta)});if(this.add(w,{name:e}),r.approver!=null){r.approver.cache&&(u.emit(!0),x=!0,r.onceOnly&&(m=!0));let M=r.approver.subscribe(D=>{for(let X of D){if(X[0]!==P)continue;let N=!!X[1];if(N&&!x){if(r.onceOnly){if(m)continue;m=!0}ie(()=>{u.emit(!0);let G=T(f.length);b("open",G);for(let K of G){if(l)break;w.emit(K)}})}else if(!N&&x){if(r.onceOnly&&m)continue;ie(()=>{u.emit(!1),b("close")})}}});this.addDisposer(M)}let g=C=>{if(l)throw new Error(`gate: ${C}() called after gate was torn down`)},y=(C=1)=>{g("approve");let M=T(C);for(let D of M){if(l)break;w.emit(D)}},O=(C=1)=>{g("reject"),T(C)},S=(C,M=1)=>{g("modify");let D=[...f],X=T(M);for(let N=0;N<X.length&&!l;N++)w.emit(C(X[N],N,D))},R=()=>{g("open"),u.emit(!0);let C=T(f.length);for(let M of C){if(l)break;w.emit(M)}},E=()=>{g("close"),!(r.onceOnly&&m)&&u.emit(!1)},A=Oe(y,{audit:h,freeze:!1,onSuccess:(C,M,D)=>({action:"approve",count:C[0]??1,t_ns:D.t_ns,...r.handlerVersion!=null?{handlerVersion:r.handlerVersion}:{}}),onFailure:(C,M,D)=>({action:"drop",t_ns:D.t_ns,errorType:D.errorType,...r.handlerVersion!=null?{handlerVersion:r.handlerVersion}:{}})}),L=Oe(O,{audit:h,freeze:!1,onSuccess:(C,M,D)=>({action:"reject",count:C[0]??1,t_ns:D.t_ns,...r.handlerVersion!=null?{handlerVersion:r.handlerVersion}:{}}),onFailure:(C,M,D)=>({action:"drop",t_ns:D.t_ns,errorType:D.errorType,...r.handlerVersion!=null?{handlerVersion:r.handlerVersion}:{}})}),j=Oe(S,{audit:h,freeze:!1,onSuccess:(C,M,D)=>({action:"modify",count:C[1]??1,t_ns:D.t_ns,...r.handlerVersion!=null?{handlerVersion:r.handlerVersion}:{}}),onFailure:(C,M,D)=>({action:"drop",t_ns:D.t_ns,errorType:D.errorType,...r.handlerVersion!=null?{handlerVersion:r.handlerVersion}:{}})}),B=Oe(R,{audit:h,freeze:!1,onSuccess:(C,M,D)=>({action:"open",t_ns:D.t_ns,...r.handlerVersion!=null?{handlerVersion:r.handlerVersion}:{}}),onFailure:(C,M,D)=>({action:"drop",t_ns:D.t_ns,errorType:D.errorType,...r.handlerVersion!=null?{handlerVersion:r.handlerVersion}:{}})}),se=Oe(E,{audit:h,freeze:!1,onSuccess:(C,M,D)=>({action:"close",t_ns:D.t_ns,...r.handlerVersion!=null?{handlerVersion:r.handlerVersion}:{}}),onFailure:(C,M,D)=>({action:"drop",t_ns:D.t_ns,errorType:D.errorType,...r.handlerVersion!=null?{handlerVersion:r.handlerVersion}:{}})});return this.addDisposer(c.subscribe(()=>{})),{node:w,pending:d,count:c,isOpen:u,droppedCount:p,decisions:h,audit:h,approve:A,reject:L,modify:j,open:B,close:se}}approval(e,n,r,o={}){return this.gate(e,n,{...o,approver:r,maxPending:1})}catch(e,n,r,o={}){let s=this._resolveStep(n),i=o.on??"error",a=ae([s],(d,u,c)=>{let p=c.terminalDeps[0];if(p!==void 0){let f=p===!0?{kind:"complete"}:{kind:"error",error:p};if(i==="terminal"||i===f.kind){u.emit(r(f,u));return}u.down(f.kind==="complete"?[[U]]:[[$,f.error]]);return}let h=d[0];if(h==null||h.length===0){u.down([[H]]);return}for(let f of h)u.emit(f)},{name:e,describeKind:"derived",completeWhenDepsComplete:o.completeWhenDepsComplete??!(i==="complete"||i==="terminal"),errorWhenDepsError:!(i==="error"||i==="terminal"),meta:Ge("catch",o.meta)});return this.add(a,{name:e}),a}_resolveStep(e){if(typeof e=="string")return this.resolve(e);if(this.nameOf(e)===void 0)throw new Error(`PipelineGraph "${this.name}": Node dep is not registered. Pass a string path or call graph.add(node) first.`);return e}};function _n(t,e){return new Le(t,e)}0&&(module.exports={PipelineGraph,decisionKeyOf,pipelineGraph});
|
|
1
|
+
"use strict";var rt=Object.defineProperty;var An=Object.getOwnPropertyDescriptor;var Dn=Object.getOwnPropertyNames;var Cn=Object.prototype.hasOwnProperty;var X=(t,e)=>()=>(t&&(e=t(t=0)),e);var Mn=(t,e)=>{for(var n in e)rt(t,n,{get:e[n],enumerable:!0})},Gn=(t,e,n,r)=>{if(e&&typeof e=="object"||typeof e=="function")for(let o of Dn(e))!Cn.call(t,o)&&o!==n&&rt(t,o,{get:()=>e[o],enumerable:!(r=An(e,o))||r.enumerable});return t};var Ln=t=>Gn(rt({},"__esModule",{value:!0}),t);function $e(){return ye>0||Ae}function Nt(){return ye>0}function _e(t){ye>0?De.push(t):t()}function ue(t){ye+=1;let e=!1;try{t()}catch(n){throw e=!0,n}finally{if(ye-=1,ye===0)if(e){if(!Ae){let n=De.splice(0);for(let r of n)try{r()}catch{}he.length=0,ge.length=0,ve.length=0}}else In()}}function In(){let t=!Ae;t&&(Ae=!0);let e=[],n=0;try{for(;he.length>0||ge.length>0||ve.length>0||t&&De.length>0;){if(t&&De.length>0){let s=De.splice(0);for(let i of s)try{i()}catch(a){e.push(a)}continue}if(n+=1,n>1e3)throw he.length=0,ge.length=0,ve.length=0,new Error("batch drain exceeded 1000 iterations \u2014 likely a reactive cycle");let o=(he.length>0?he:ge.length>0?ge:ve).splice(0);for(let s of o)try{s()}catch(i){e.push(i)}}}finally{t&&(Ae=!1)}if(e.length===1)throw e[0];if(e.length>1)throw new AggregateError(e,"batch drain: multiple callbacks threw")}function Fe(t,e,n){if(e.length===0)return;if(e.length===1){let u=n(e[0][0]);if(u<3||!$e()){t(e);return}(u>=5?ve:u===4?ge:he).push(()=>t(e));return}let r=e.length,o=r,s=r,i=r,a=0;for(;a<r&&n(e[a][0])<3;)a++;for(o=a;a<r&&n(e[a][0])===3;)a++;for(s=a;a<r&&n(e[a][0])===4;)a++;i=a;let d=$e();if(o>0){let u=e.slice(0,o);t(u)}if(s>o){let u=e.slice(o,s);d?he.push(()=>t(u)):t(u)}if(i>s){let u=e.slice(s,i);d?ge.push(()=>t(u)):t(u)}if(r>i){let u=e.slice(i,r);d?ve.push(()=>t(u)):t(u)}}var ye,Ae,he,ge,ve,De,we=X(()=>{"use strict";ye=0,Ae=!1,he=[],ge=[],ve=[],De=[]});function de(){return Math.trunc(performance.now()*1e6)}function le(){return Date.now()*1e6}var xe=X(()=>{"use strict"});var Ce,I,Y,W,ne,ie,fe,U,K,$,Te,st,Pn,ot,$n,Fn,it,Et,St,At,at,me=X(()=>{"use strict";Ce=Symbol.for("graphrefly/START"),I=Symbol.for("graphrefly/DATA"),Y=Symbol.for("graphrefly/DIRTY"),W=Symbol.for("graphrefly/RESOLVED"),ne=Symbol.for("graphrefly/INVALIDATE"),ie=Symbol.for("graphrefly/PAUSE"),fe=Symbol.for("graphrefly/RESUME"),U=Symbol.for("graphrefly/TEARDOWN"),K=Symbol.for("graphrefly/COMPLETE"),$=Symbol.for("graphrefly/ERROR"),Te=Object.freeze([Y]),st=Object.freeze([W]),Pn=Object.freeze([ne]),ot=Object.freeze([Ce]),$n=Object.freeze([K]),Fn=Object.freeze([U]),it=Object.freeze([Te]),Et=Object.freeze([st]),St=Object.freeze([Pn]),At=Object.freeze([$n]),at=Object.freeze([Fn])});function Dt(t){return Array.isArray(t)?[...t]:[t]}function Vn(t,e){return t.has(e)||t.has("*")}function Ct(t){let e=[];return t((o,s)=>{e.push({kind:"allow",actions:new Set(Dt(o)),where:s?.where??(()=>!0)})},(o,s)=>{e.push({kind:"deny",actions:new Set(Dt(o)),where:s?.where??(()=>!0)})}),(o,s)=>{let i=!1,a=!1;for(let d of e)Vn(d.actions,s)&&d.where(o)&&(d.kind==="deny"?i=!0:a=!0);return i?!1:a}}function ut(t){let e=zn.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 te,zn,Me=X(()=>{"use strict";te=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}};zn=["human","llm","wallet","system"]});function Gt(t,e){let n=new TextEncoder().encode(t.name);if(n.length===0||n.length>255)throw new Error(`encodeEnvelope: codec name "${t.name}" encodes to ${n.length} bytes (must be 1\u2013255)`);let r=t.version;if(!Number.isInteger(r)||r<0||r>65535)throw new Error(`encodeEnvelope: codec.version ${r} out of u16 range (expected integer 0\u201365535)`);let o=2+n.length+2+e.length;if(o>4294967295)throw new Error(`encodeEnvelope: total envelope size ${o} exceeds 2^32-1 bytes (payload ${e.length} bytes)`);let s=new Uint8Array(o),i=0;return s[i++]=dt,s[i++]=n.length,s.set(n,i),i+=n.length,s[i++]=r>>>8&255,s[i++]=r&255,s.set(e,i),s}function Lt(t,e){if(t.length<Mt)throw new Error(`decodeEnvelope: bytes too short (${t.length} < ${Mt})`);let n=0,r=t[n++];if(r!==dt)throw new Error(`decodeEnvelope: unsupported envelope version ${r} (expected ${dt})`);let o=t[n++];if(o===0)throw new Error("decodeEnvelope: name_len must be >= 1");if(n+o+2>t.length)throw new Error(`decodeEnvelope: envelope truncated (need ${n+o+2} bytes, have ${t.length})`);let s=new TextDecoder().decode(t.subarray(n,n+o));n+=o;let i=(t[n]<<8|t[n+1])>>>0;n+=2;let a=t.subarray(n),d=e.lookupCodec(s);if(d==null)throw new Error(`decodeEnvelope: codec "${s}" not registered (envelope codec_v=${i})`);return{codec:d,codecVersion:i,payload:a}}function It(t){t.registerCodec(jn)}var jn,dt,Mt,ct=X(()=>{"use strict";jn={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)}},dt=1,Mt=4});function Ve(t){if(t==null)return Oe;let{type:e,id:n,...r}=t;return{type:e??"system",id:n??"",...r}}var Oe,lt=X(()=>{"use strict";Oe={type:"system",id:""}});function Pt(t){t.registerMessageType(Ce,{tier:0,wireCrossing:!1}),t.registerMessageType(Y,{tier:1,wireCrossing:!1}),t.registerMessageType(ne,{tier:1,wireCrossing:!1,metaPassthrough:!1}),t.registerMessageType(ie,{tier:2,wireCrossing:!1}),t.registerMessageType(fe,{tier:2,wireCrossing:!1}),t.registerMessageType(I,{tier:3,wireCrossing:!0}),t.registerMessageType(W,{tier:3,wireCrossing:!0}),t.registerMessageType(K,{tier:4,wireCrossing:!0,metaPassthrough:!1}),t.registerMessageType($,{tier:4,wireCrossing:!0,metaPassthrough:!1}),t.registerMessageType(U,{tier:5,wireCrossing:!0,metaPassthrough:!1})}var ze,$t=X(()=>{"use strict";me();ze=class{_messageTypes=new Map;_codecs=new Map;_onMessage;_onSubscribe;_defaultVersioning;_defaultHashFn;_inspectorEnabled=!(typeof process<"u"&&process.env?.NODE_ENV==="production");_globalInspector;_rigorRecorder;_frozen=!1;tierOf;constructor(e){this._onMessage=e.onMessage,this._onSubscribe=e.onSubscribe,this._defaultVersioning=e.defaultVersioning,this._defaultHashFn=e.defaultHashFn,this.tierOf=n=>{let r=this._messageTypes.get(n);return r!=null?r.tier:1}}get onMessage(){return this._frozen=!0,this._onMessage}get onSubscribe(){return this._frozen=!0,this._onSubscribe}set onMessage(e){this._assertUnfrozen(),this._onMessage=e}set onSubscribe(e){this._assertUnfrozen(),this._onSubscribe=e}get defaultVersioning(){return this._defaultVersioning}set defaultVersioning(e){this._assertUnfrozen(),this._defaultVersioning=e}get defaultHashFn(){return this._defaultHashFn}set defaultHashFn(e){this._assertUnfrozen(),this._defaultHashFn=e}get inspectorEnabled(){return this._inspectorEnabled}set inspectorEnabled(e){this._inspectorEnabled=e}get globalInspector(){return this._globalInspector}set globalInspector(e){this._globalInspector=e}get rigorRecorder(){return this._rigorRecorder}set rigorRecorder(e){this._rigorRecorder=e}registerMessageType(e,n){return this._assertUnfrozen(),this._messageTypes.set(e,{tier:n.tier,wireCrossing:n.wireCrossing??n.tier>=3,metaPassthrough:n.metaPassthrough??!0}),this}messageTier(e){let n=this._messageTypes.get(e);return n!=null?n.tier:1}isWireCrossing(e){let n=this._messageTypes.get(e);return n!=null?n.wireCrossing:!0}isLocalOnly(e){return!this.isWireCrossing(e)}isMetaPassthrough(e){let n=this._messageTypes.get(e);return n!=null?n.metaPassthrough:!0}isKnownMessageType(e){return this._messageTypes.has(e)}registerCodec(e){return this._assertUnfrozen(),this._codecs.set(e.name,e),this}lookupCodec(e){return this._codecs.get(e)}_isFrozen(){return this._frozen}_assertUnfrozen(){if(this._frozen)throw new Error("GraphReFlyConfig is frozen: a node has already captured this config. Register custom types and set hooks before creating any node.")}}});function ft(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(ft);if(typeof t=="object"&&t!==null){let e={};for(let n of Object.keys(t).sort())e[n]=ft(t[n]);return e}return null}function Wn(t){let e=Hn.encode(t),n=e.length,r=n*8,o=n+9+63&-64,s=new Uint8Array(o);s.set(e),s[n]=128;let i=new DataView(s.buffer);i.setUint32(o-4,r>>>0,!1),i.setUint32(o-8,Math.floor(r/4294967296)>>>0,!1);let a=1779033703,d=3144134277,u=1013904242,c=2773480762,p=1359893119,h=2600822924,f=528734635,l=1541459225,b=new Uint32Array(64),m=(_,y)=>_>>>y|_<<32-y;for(let _=0;_<o;_+=64){for(let R=0;R<16;R++)b[R]=i.getUint32(_+R*4,!1);for(let R=16;R<64;R++){let A=b[R-15],N=b[R-2],D=m(A,7)^m(A,18)^A>>>3,B=m(N,17)^m(N,19)^N>>>10;b[R]=b[R-16]+D+b[R-7]+B>>>0}let y=a,w=d,O=u,T=c,g=p,v=h,k=f,S=l;for(let R=0;R<64;R++){let A=m(g,6)^m(g,11)^m(g,25),N=g&v^~g&k,D=S+A+N+Bn[R]+b[R]>>>0,B=m(y,2)^m(y,13)^m(y,22),j=y&w^y&O^w&O,ae=B+j>>>0;S=k,k=v,v=g,g=T+D>>>0,T=O,O=w,w=y,y=D+ae>>>0}a=a+y>>>0,d=d+w>>>0,u=u+O>>>0,c=c+T>>>0,p=p+g>>>0,h=h+v>>>0,f=f+k>>>0,l=l+S>>>0}let x=_=>_.toString(16).padStart(8,"0");return x(a)+x(d)+x(u)+x(c)+x(p)+x(h)+x(f)+x(l)}function pt(t){let e=ft(t??null),n=JSON.stringify(e);return Wn(n).slice(0,16)}function Un(){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 ht(t,e,n){let r=n?.id??Un();if(t===0)return{id:r,version:0};let s=(n?.hash??pt)(e);return{id:r,version:0,cid:s,prev:null}}function Ft(t,e,n){t.version+=1,"cid"in t&&(t.prev=t.cid,t.cid=n(e))}var Bn,Hn,Vt=X(()=>{"use strict";Bn=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]),Hn=new TextEncoder});function Bt(t){return{node:t,unsub:null,prevData:void 0,dirty:!1,involvedThisWave:!1,dataBatch:[],terminal:void 0}}function gt(t){t.prevData=void 0,t.dirty=!1,t.involvedThisWave=!1,t.dataBatch.length=0,t.terminal=void 0}function je(t){return t.length===0?t:typeof t[0]=="symbol"?[t]:t}function ce(t,e,n){let r=Ht(t)?t:[],o=typeof t=="function"?t:typeof e=="function"?e:void 0,s={};return Ht(t)?s=(mt(e)?e:n)??{}:mt(t)?s=t:s=(mt(e)?e:n)??{},new V(r,o,s)}var zt,jt,Kn,qn,ke,V,Ht,mt,be=X(()=>{"use strict";ct();lt();we();xe();$t();Me();me();Vt();zt=()=>{},jt=100;Kn=(t,e,n,r)=>{n.direction==="down-in"&&t._onDepMessage(n.depIndex,e)},qn=(t,e,n,r)=>{let o=t;if(o._status==="completed"||o._status==="errored")return;let s=o._cached,i=s===void 0?[ot]:[ot,[I,s]];o._status==="dirty"&&i.push(Te),Fe(e,i,o._config.tierOf)},ke=new ze({onMessage:Kn,onSubscribe:qn});Pt(ke);It(ke);V=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??ke,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??pt;let o=r.versioning??this._config.defaultVersioning;this._versioningLevel=o,this._versioning=o!=null?ht(o,this._cached===void 0?void 0:this._cached,{id:r.versioningId,hash:this._hashFn}):void 0,this._deps=e.map(Bt);let s={};for(let[a,d]of Object.entries(r.meta??{})){let u={initial:d,name:`${r.name??"node"}:meta:${a}`,describeKind:"state",config:this._config};r.guard!=null&&(u.guard=r.guard),s[a]=new t([],void 0,u)}Object.freeze(s),this.meta=s,this._hasMeta=Object.keys(s).length>0;let i=this;this._actions={emit(a){i._emit([[I,a]])},down(a){i._emit(je(a))},up(a){i._emitUp(je(a))}},this.down=this.down.bind(this),this.up=this.up.bind(this)}get _isTerminal(){return this._status==="completed"||this._status==="errored"}get name(){return this._optsName}get status(){return this._status}get cache(){return this._cached===void 0?void 0:this._cached}get lastMutation(){return this._lastMutation}get v(){return this._versioning}hasGuard(){return this._guard!=null}_applyVersioning(e,n){if(this._isExecutingFn)throw new Error(`Node "${this.name}": _applyVersioning cannot run mid-fn \u2014 call it outside of \`_execFn\` (typically at graph setup time before the first subscribe).`);let r=this._versioningLevel;if(r!=null&&e<=r)return;let o=n?.hash??this._hashFn;o!==this._hashFn&&(this._hashFn=o);let s=this._cached===void 0?void 0:this._cached,i=this._versioning,a=i?.id??n?.id,d=i?.version??0,u=ht(e,s,{id:a,hash:o});u.version=d,this._versioning=u,this._versioningLevel=e}_setInspectorHook(e){return e==null?()=>{}:(this._inspectorHooks==null&&(this._inspectorHooks=new Set),this._inspectorHooks.add(e),()=>{this._inspectorHooks?.delete(e),this._inspectorHooks?.size===0&&(this._inspectorHooks=void 0)})}_pushGuard(e){return this._extraGuards==null&&(this._extraGuards=new Set),this._extraGuards.add(e),()=>{this._extraGuards?.delete(e),this._extraGuards?.size===0&&(this._extraGuards=void 0)}}allowsObserve(e){if(this._guard==null&&this._extraGuards==null)return!0;let n=Ve(e);if(this._guard!=null&&!this._guard(n,"observe"))return!1;if(this._extraGuards!=null){for(let r of this._extraGuards)if(!r(n,"observe"))return!1}return!0}_checkGuard(e){if(e?.internal)return;let n=this._guard!=null||this._extraGuards!=null,r=e?.actor!=null;if(!n&&!r)return;let o=Ve(e?.actor),s=e?.delivery==="signal"?"signal":"write";if(this._guard!=null&&!this._guard(o,s))throw new te({actor:o,action:s,nodeName:this.name});if(this._extraGuards!=null){for(let i of this._extraGuards)if(!i(o,s))throw new te({actor:o,action:s,nodeName:this.name})}this._lastMutation={actor:o,timestamp_ns:le()}}down(e,n){let r=je(e);r.length!==0&&(this._checkGuard(n),this._emit(r))}emit(e,n){this._checkGuard(n),this._emit([[I,e]])}up(e,n){if(this._deps.length===0)return;let r=je(e);if(r.length===0)return;this._checkGuard(n);let o=n??{internal:!0};this._validateUpTiers(r);for(let s of this._deps)s.node.up?.(r,o)}_emitUp(e){if(this._deps.length!==0&&e.length!==0){this._validateUpTiers(e);for(let n of this._deps)n.node.up?.(e,{internal:!0})}}_validateUpTiers(e){let n=this._config.tierOf;for(let r of e){let o=n(r[0]);if(o===3||o===4)throw new Error(`Node "${this.name}": tier-${o} messages cannot flow up \u2014 DATA/RESOLVED/COMPLETE/ERROR are downstream-only. Use \`down(...)\` for value delivery; \`up(...)\` is for control signals (DIRTY, INVALIDATE, PAUSE, RESUME, TEARDOWN).`)}}subscribe(e,n){if(n!=null&&this._guard!=null){let d=Ve(n);if(!this._guard(d,"observe"))throw new te({actor:d,action:"observe",nodeName:this.name})}let o=this._isTerminal&&this._resubscribable;if(o){this._cached=void 0,this._status="sentinel",this._store={},this._hasCalledFnOnce=!1,this._waveHasNewData=!1,this._hasNewTerminal=!1,this._paused=!1,this._pendingWave=!1,this._pendingRerun=!1,this._isExecutingFn=!1,this._rerunDepth=0,this._dirtyDepCount=0,this._pauseLocks=null,this._pauseBuffer=null;for(let d of this._deps)gt(d);if(this._partial===!1){for(let d of this._deps)if(d.prevData!==void 0||d.dataBatch.length!==0||d.terminal!==void 0||d.dirty)throw new Error(`resubscribable-reset invariant: DepRecord not fully reset for node ${this._optsName??"(anonymous)"}`)}}this._sinkCount+=1;let s;try{s=this._config.onSubscribe(this,e,{sinkCount:this._sinkCount,afterTerminalReset:o},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 s=="function")try{s()}catch{}throw d}this._status==="sentinel"&&this._cached===void 0&&(this._status="pending");let a=!1;return()=>{a||(a=!0,this._sinkCount-=1,this._removeSink(e),typeof s=="function"&&s(),this._sinks==null&&this._deactivate())}}_removeSink(e){if(this._sinks===e)this._sinks=null;else if(this._sinks!=null&&typeof this._sinks!="function")if(this._sinks.delete(e),this._sinks.size===1){let[n]=this._sinks;this._sinks=n}else this._sinks.size===0&&(this._sinks=null)}_activate(){if(this._deps.length===0){this._fn&&this._execFn();return}this._dirtyDepCount=0;let e=this._deps.length,n=0;try{for(let r=0;r<e;r++){let o=r,s=this._deps[r];s.unsub=zt,s.unsub=s.node.subscribe(i=>{if(s.unsub===null)return;let a=this._config.tierOf,d=!1;for(let u of i)a(u[0])>=3&&(d=!0),this._config.onMessage(this,u,{direction:"down-in",depIndex:o},this._actions);d&&this._maybeRunFnOnSettlement()}),n++}}catch(r){this._deps[n].unsub=null;for(let o=0;o<n;o++){let s=this._deps[o];if(s.unsub!=null){let i=s.unsub;s.unsub=null;try{i()}catch{}gt(s)}}throw this._dirtyDepCount=0,r}}_addDep(e){for(let o=0;o<this._deps.length;o++)if(this._deps[o].node===e)return o;let n=this._deps.length,r=Bt(e);if(this._deps.push(r),this._sinks==null)return n;r.dirty=!0,this._dirtyDepCount++,this._status!=="dirty"&&this._emit(it),r.unsub=zt;try{r.unsub=e.subscribe(o=>{if(r.unsub===null)return;let s=this._config.tierOf,i=!1;for(let a of o)s(a[0])>=3&&(i=!0),this._config.onMessage(this,a,{direction:"down-in",depIndex:n},this._actions);i&&this._maybeRunFnOnSettlement()})}catch(o){throw r.unsub=null,this._deps.pop(),this._dirtyDepCount--,o}return n}_deactivate(e=!1){let n=this._cleanup;if(this._cleanup=void 0,typeof n=="function")try{n()}catch(r){this._emit([[$,this._wrapFnError("cleanup threw",r)]])}else if(n!=null&&typeof n=="object"){let r=n.deactivate;if(typeof r=="function")try{r()}catch(o){this._emit([[$,this._wrapFnError("cleanup.deactivate threw",o)]])}}for(let r of this._deps){if(r.unsub!=null){let o=r.unsub;r.unsub=null;try{o()}catch{}}gt(r)}this._waveHasNewData=!1,this._hasNewTerminal=!1,this._hasCalledFnOnce=!1,this._paused=!1,this._pendingWave=!1,this._pendingRerun=!1,this._rerunDepth=0,this._store={},this._dirtyDepCount=0,this._pauseLocks=null,this._pauseBuffer=null,this._fn!=null&&(this._cached=void 0),e||(this._fn!=null||this._deps.length>0)&&(!this._isTerminal||this._resubscribable)&&(this._status="sentinel")}_onDepMessage(e,n){let r=this._deps[e],o=n[0];if(this._inspectorHooks!=null){let s={kind:"dep_message",depIndex:e,message:n};for(let i of this._inspectorHooks)i(s)}if(o!==Ce){if(o===Y){this._depDirtied(r);return}if(o===ne){if(this._depInvalidated(r),this._cached===void 0)return;this._emit(St);return}if(o===ie||o===fe){this._emit([n]);return}if(o===U){this._emit(at);return}if(o===I)this._depSettledAsData(r,n[1]);else if(o===W)this._depSettledAsResolved(r);else if(o===K)this._depSettledAsTerminal(r,!0);else if(o===$)this._depSettledAsTerminal(r,n[1]);else{this._emit([n]);return}if(!this._fn){(o===I||o===W)&&this._emit([n]),(o===K||o===$)&&this._maybeAutoTerminalAfterWave();return}}}_depDirtied(e){e.dirty||(e.dirty=!0,e.involvedThisWave=!0,this._dirtyDepCount++,this._status!=="dirty"&&this._emit(it))}_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(Et),this._maybeAutoTerminalAfterWave();return}this._fn&&this._execFn(),this._maybeAutoTerminalAfterWave()}}_maybeAutoTerminalAfterWave(){if(this._deps.length===0||this._isTerminal)return;let e=this._deps.find(n=>n.terminal!==void 0&&n.terminal!==!0);if(e!=null){this._autoError&&this._emit([[$,e.terminal]]);return}this._autoComplete&&this._deps.every(n=>n.terminal!==void 0)&&this._emit(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([[$,this._wrapFnError("cleanup threw",i)]]);return}}else if(e!=null&&typeof e=="object"){let i=e.beforeRun;if(typeof i=="function"){e.beforeRun=void 0;try{i()}catch(a){this._emit([[$,this._wrapFnError("cleanup.beforeRun threw",a)]]);return}}}let n=this._deps.map(i=>i.involvedThisWave?i.dataBatch.length>0?[...i.dataBatch]:[]:void 0),r=this._deps.map(i=>i.prevData);for(let i=0;i<this._deps.length;i++){let a=n[i];a!=null&&a.length>0&&(this._deps[i].prevData=a[a.length-1])}let o=this._deps.map(i=>i.terminal),s={prevData:r,terminalDeps:o,store:this._store};if(this._hasCalledFnOnce=!0,this._clearWaveFlags(),this._inspectorHooks!=null){let i={kind:"run",batchData:n,prevData:r};for(let a of this._inspectorHooks)a(i)}this._isExecutingFn=!0;try{let i=this._fn(n,this._actions,s);if(typeof i=="function")this._cleanup=i;else if(i!=null&&typeof i=="object"){let a=i;(typeof a.beforeRun=="function"||typeof a.deactivate=="function"||typeof a.invalidate=="function")&&(this._cleanup=i)}}catch(i){this._emit([[$,this._wrapFnError("fn threw",i)]])}finally{this._isExecutingFn=!1,this._pendingRerun?(this._pendingRerun=!1,this._rerunDepth+=1,this._rerunDepth>jt?(this._rerunDepth=0,this._emit([[$,new Error(`Node "${this.name}": _pendingRerun depth exceeded ${jt} \u2014 likely a reactive cycle`)]])):this._maybeRunFnOnSettlement()):this._rerunDepth=0,this._clearWaveFlags()}}_clearWaveFlags(){this._waveHasNewData=!1,this._hasNewTerminal=!1;for(let e of this._deps)e.involvedThisWave=!1,e.dataBatch.length=0}_wrapFnError(e,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"?[Te,e[0]]:e;let r=!0,o=!1,s=!1,i=-1;for(let d of e){let u=n(d[0]);u<i&&(r=!1),u===3&&(o=!0),d[0]===Y&&(s=!0),i=u}let a=e;if(!r){let d=e.map((u,c)=>({m:u,i:c,tier:n(u[0])}));d.sort((u,c)=>u.tier-c.tier||u.i-c.i),a=d.map(u=>u.m)}if(o&&!s&&this._status!=="dirty"){let d=0;for(;d<a.length&&n(a[d][0])===0;)d++;return d===0?[Te,...a]:[...a.slice(0,d),Te,...a.slice(d)]}return a}_emit(e){if(e.length===0)return;for(let a=0;a<e.length;a++){let d=e[a];if(d[0]===$&&d[1]===void 0)throw new TypeError('[ERROR, payload] requires a non-undefined payload (spec \xA71.2). Pass an Error object or domain tag instead \u2014 e.g. node.down([[ERROR, new Error("reason")]])')}let n=e;if(this._isTerminal&&!this._resubscribable){let a=e.filter(d=>d[0]===U||d[0]===ne);if(a.length===0)return;n=a}n=this._frameBatch(n);let o=null;for(let a=0;a<n.length;a++){let d=n[a],u=d[0];if(u!==ie&&u!==fe){o?.push(d);continue}if(d.length<2)throw new Error(`Node "${this.name}": [[${u===ie?"PAUSE":"RESUME"}]] must carry a lockId payload \u2014 bare PAUSE/RESUME is a protocol violation (C0 rule). Use \`[[PAUSE, lockId]]\` / \`[[RESUME, lockId]]\`.`);let c=!0;if(this._pausable!==!1){let p=d[1];if(u===ie)this._pauseLocks==null&&(this._pauseLocks=new Set),this._pauseLocks.add(p),this._paused=!0,this._pausable==="resumeAll"&&this._pauseBuffer==null&&(this._pauseBuffer=[]);else if(this._pauseLocks==null||!this._pauseLocks.has(p))c=!1;else if(this._pauseLocks.delete(p),this._pauseLocks.size===0){if(this._paused=!1,this._pauseBuffer!=null&&this._pauseBuffer.length>0){let h=this._pauseBuffer;this._pauseBuffer=[],this._emit(h)}this._pendingWave&&(this._pendingWave=!1,this._maybeRunFnOnSettlement())}}c?o?.push(d):o==null&&(o=n.slice(0,a))}if(o!=null){if(o.length===0)return;n=o}if(this._hasMeta&&n.some(a=>a[0]===U))for(let a of Object.keys(this.meta))try{this.meta[a]._emit(at)}catch{}let{finalMessages:s,equalsError:i}=this._updateState(n);if(s.length>0&&this._config.inspectorEnabled){let a=this._config.globalInspector;if(a!=null)try{a({kind:"emit",node:this,messages:s})}catch{}}if(s.length>0)if(this._paused&&this._pausable==="resumeAll"&&this._pauseBuffer!=null){let a=this._config.tierOf,d=[];for(let u of s)a(u[0])===3?this._pauseBuffer.push(u):d.push(u);d.length>0&&this._dispatchOrAccumulate(d)}else this._dispatchOrAccumulate(s);i!=null&&this._emit([[$,i]])}_updateState(e){let n=this._config.tierOf,r,o,s=-1,i=0;for(let c of e)n(c[0])===3&&i++;let a=i<=1,d=-1;if(this._versioning!=null&&i>1){for(let c=e.length-1;c>=0;c--)if(e[c][0]===I){d=c;break}}for(let c=0;c<e.length;c++){let p=e[c],h=p[0];if(h===I){if(p.length>=2){let f=!1;if(a&&this._cached!==void 0)try{f=this._equals(this._cached,p[1])}catch(l){o=this._wrapFnError("equals threw",l),s=c;break}if(f){r==null&&(r=e.slice(0,c)),r.push(st),this._status="resolved";continue}this._cached=p[1],this._versioning!=null&&(d<0||c===d)&&Ft(this._versioning,p[1],this._hashFn)}this._status="settled",r?.push(p)}else if(r?.push(p),h===Y)this._status="dirty";else if(h===W)this._status="resolved";else if(h===K){this._status="completed";{let f=this._config.rigorRecorder;if(f!=null)try{f.onTerminalTransition(this,"completed",this._autoComplete,this._autoError,this._deps.length>0)}catch{}}}else if(h===$){this._status="errored";{let f=this._config.rigorRecorder;if(f!=null)try{f.onTerminalTransition(this,"errored",this._autoComplete,this._autoError,this._deps.length>0)}catch{}}}else if(h===ne){if(this._cached!==void 0){let l=this._config.rigorRecorder;if(l!=null)try{l.onNonVacuousInvalidate(this,this._cached)}catch{}}this._cached=void 0,this._status="dirty";let f=this._cleanup;if(typeof f=="function"){this._cleanup=void 0;try{f()}catch{}}else if(f!=null&&typeof f=="object"){let l=f.invalidate;if(typeof l=="function")try{l()}catch{}}}else h===U&&(this._resetOnTeardown&&(this._cached=void 0),this._deactivate(!0),this._status="sentinel")}let u=s>=0?r??e.slice(0,s):r??e;return o!=null?{finalMessages:u,equalsError:o}:{finalMessages:u}}_deliverToSinks=e=>{if(this._sinks==null)return;if(typeof this._sinks=="function"){this._sinks(e);return}let n=[...this._sinks];for(let r of n)r(e)};_dispatchOrAccumulate(e){if(Nt()){this._batchPendingMessages===null&&(this._batchPendingMessages=[],_e(()=>this._flushBatchPending()));for(let n of e)this._batchPendingMessages.push(n);return}Fe(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);Fe(this._deliverToSinks,n,this._config.tierOf)}},Ht=t=>Array.isArray(t),mt=t=>typeof t=="object"&&t!=null&&!Array.isArray(t)});function Be(t,e){if(e!=null&&e.length>0)return new Set(e);switch(t){case"standard":return new Set(["type","status","value","deps","meta","v"]);case"full":return null;case"spec":return new Set(["type","deps","meta"]);default:return new Set(["type","deps"])}}function Yn(t){return t._describeKind!=null?t._describeKind:t._deps.length>0?"derived":t._fn!=null?"producer":"state"}function Wt(t){let e=new WeakSet,n={};for(let[r,o]of Ut(t))n[r]=bt(o,e);return n}function bt(t,e){if(t==null)return t;let n=typeof t;if(n==="boolean"||n==="number"||n==="string")return t;if(n==="function")return"<function>";if(Array.isArray(t))return e.has(t)?"<cycle>":(e.add(t),t.map(r=>bt(r,e)));if(n==="object"){let r=t;if(e.has(r))return"<cycle>";e.add(r);try{if(typeof r.subscribe=="function"&&"cache"in r)return"<Node>"}catch{return"<unserializable>"}let o={};for(let[s,i]of Ut(r))o[s]=bt(i,e);return o}return"<unserializable>"}function Ut(t){let e=[],n;try{n=Object.keys(t)}catch{return e}for(let r of n)try{e.push([r,t[r]])}catch{e.push([r,"<unserializable>"])}return e}function Jn(t){let e={};for(let[n,r]of Object.entries(t.meta))try{e[n]=r.cache}catch{}return e}function yt(t,e){let n=e==null,r=!n&&e!=null?[...e].filter(u=>u.startsWith("meta.")).map(u=>u.slice(5)):null,o=n||e.has("meta")||r!=null&&r.length>0,s="state",i=[];t instanceof V&&(s=Yn(t),i=t._deps.map(u=>u.node.name??""));let a={type:s,deps:i};(n||e.has("status"))&&(a.status=t.status);let d=t instanceof V?t._guard:void 0;if(o){let u={...Jn(t)};if(d!=null&&u.access===void 0&&(u.access=ut(d)),r!=null&&r.length>0&&!e.has("meta")){let c={};for(let p of r)p in u&&(c[p]=u[p]);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"))&&d!=null&&(a.guard=ut(d)),(n||e.has("lastMutation"))&&t.lastMutation!=null&&(a.lastMutation=t.lastMutation),a}var vt=X(()=>{"use strict";Me();be()});function re(t,e){return ce([],{...e,initial:t})}function _t(t,e){return ce((r,o,s)=>t(o,s)??void 0,{describeKind:"producer",...e})}function Z(t,e,n){return ce(t,(o,s,i)=>{let a=o.map((d,u)=>d!=null&&d.length>0?d.at(-1):i.prevData[u]);s.emit(e(a,i))},{describeKind:"derived",...n})}var He=X(()=>{"use strict";be()});function We(t){return t.subscribe(()=>{})}var qt=X(()=>{"use strict"});var Ue,Yt=X(()=>{"use strict";Ue=class{_timer;_gen=0;start(e,n){this.cancel(),this._gen+=1;let r=this._gen;this._timer=setTimeout(()=>{this._timer=void 0,r===this._gen&&n()},e)}cancel(){this._timer!==void 0&&(clearTimeout(this._timer),this._timer=void 0)}get pending(){return this._timer!==void 0}}});var Yr={};Mn(Yr,{PipelineGraph:()=>Pe,decisionKeyOf:()=>En,pipelineGraph:()=>Sn});module.exports=Ln(Yr);we();xe();me();vt();be();He();lt();we();xe();Me();me();vt();be();He();xe();function wt(t,e){if(Object.is(t,e))return!0;if(t==null||e==null||typeof t!="object"||typeof e!="object")return!1;if(Array.isArray(t)){if(!Array.isArray(e)||t.length!==e.length)return!1;for(let s=0;s<t.length;s++)if(!wt(t[s],e[s]))return!1;return!0}if(Array.isArray(e))return!1;let n=Object.keys(t),r=Object.keys(e);if(n.length!==r.length)return!1;let o=new Set(r);for(let s of n)if(!o.has(s)||!wt(t[s],e[s]))return!1;return!0}function Kt(t,e){return`${t}\0${e}`}function xt(t,e){let n=[],r=new Set(t.subgraphs),o=new Set(e.subgraphs),s=[];for(let m of o)r.has(m)||s.push(m);s.sort();for(let m of s)n.push({type:"subgraph-mounted",path:m});let i=new Set(Object.keys(t.nodes)),a=new Set(Object.keys(e.nodes)),d=[];for(let m of a)i.has(m)||d.push(m);d.sort();for(let m of d)n.push({type:"node-added",path:m,node:{...e.nodes[m]}});let u=[];for(let m of a){if(!i.has(m))continue;let x=t.nodes[m]?.meta,_=e.nodes[m]?.meta;x==null&&_==null||wt(x??{},_??{})||u.push(m)}u.sort();for(let m of u)n.push({type:"node-meta-changed",path:m,prevMeta:t.nodes[m]?.meta??{},nextMeta:e.nodes[m]?.meta??{}});let c=new Map;for(let m of t.edges)c.set(Kt(m.from,m.to),m);let p=new Map;for(let m of e.edges)p.set(Kt(m.from,m.to),m);let h=[];for(let[m,x]of p)c.has(m)||h.push(x);h.sort((m,x)=>m.from<x.from?-1:m.from>x.from?1:m.to<x.to?-1:m.to>x.to?1:0);for(let m of h)n.push({type:"edge-added",from:m.from,to:m.to});let f=[];for(let[m,x]of c)p.has(m)||f.push(x);f.sort((m,x)=>m.from<x.from?-1:m.from>x.from?1:m.to<x.to?-1:m.to>x.to?1:0);for(let m of f)n.push({type:"edge-removed",from:m.from,to:m.to});let l=[];for(let m of i)a.has(m)||l.push(m);l.sort();for(let m of l)n.push({type:"node-removed",path:m});let b=[];for(let m of r)o.has(m)||b.push(m);b.sort();for(let m of b)n.push({type:"subgraph-unmounted",path:m});return{events:n,flushedAt_ns:de()}}qt();Yt();var Ge=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}};ct();function Tt(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 Ke(t){let e=0;for(let n of t)e+=Tt(n.codePointAt(0));return e}function Jt(t,e){if(e<=0)return"";let n=0,r="";for(let o of t){let s=Tt(o.codePointAt(0));if(n+s>e){if(e<=1)return"\u2026";for(;n+1>e&&r.length>0;){let i=[...r].pop();r=r.slice(0,-i.length),n-=Tt(i.codePointAt(0))}return`${r}\u2026`}r+=o,n+=s}return r}var Xn={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"},Zn={horizontal:"-",vertical:"|",cornerTL:"+",cornerTR:"+",cornerBL:"+",cornerBR:"+",tDown:"+",tUp:"+",tRight:"+",tLeft:"+",cross:"+",arrowRight:">",arrowDown:"v",arrowLeft:"<",arrowUp:"^",boxTL:"+",boxTR:"+",boxBL:"+",boxBR:"+",boxH:"-",boxV:"|"};function en(t,e){let n=e.charset==="ascii"?Zn:Xn,r=t.width,o=t.height,s=Array.from({length:o},()=>Array.from({length:r},()=>" ")),i=Array.from({length:o},()=>Array.from({length:r},()=>"empty"));for(let a of t.edges)er(s,i,n,a);for(let a of t.boxes)Qn(s,i,n,a,e.labelOf(a.id));return s.map(a=>sr(a.join(""))).join(`
|
|
2
|
+
`)}function Qn(t,e,n,r,o){let{x:s,y:i,w:a,h:d}=r;if(a<2||d<2){d>0&&Xt(t,e,s,i,a,o);return}pe(t,e,s,i,n.boxTL);for(let c=s+1;c<s+a-1;c+=1)pe(t,e,c,i,n.boxH);pe(t,e,s+a-1,i,n.boxTR);for(let c=i+1;c<i+d-1;c+=1){pe(t,e,s,c,n.boxV);for(let p=s+1;p<s+a-1;p+=1)tn(t,e,p,c," ","empty");pe(t,e,s+a-1,c,n.boxV)}pe(t,e,s,i+d-1,n.boxBL);for(let c=s+1;c<s+a-1;c+=1)pe(t,e,c,i+d-1,n.boxH);pe(t,e,s+a-1,i+d-1,n.boxBR);let u=i+Math.floor(d/2);Xt(t,e,s+1,u,a-2,o)}function pe(t,e,n,r,o){tn(t,e,n,r,o,o===" "?"empty":o==="\u2500"||o==="-"?"boxH":o==="\u2502"||o==="|"?"boxV":"boxCorner")}function tn(t,e,n,r,o,s){if(r<0||r>=t.length)return;let i=t[r];n<0||n>=i.length||(i[n]=o,e[r][n]=s)}function Xt(t,e,n,r,o,s){if(r<0||r>=t.length)return;let i=n,a=o;for(let d of s){let u=Ke(d);if(u!==0){if(a<u)break;i>=0&&i<t[r].length&&(t[r][i]=d,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 er(t,e,n,r){let o=r.points;if(o.length<2)return;for(let d=0;d+1<o.length;d+=1)tr(t,e,n,o[d],o[d+1]);for(let d=1;d+1<o.length;d+=1){let u=o[d-1],c=o[d],p=o[d+1],h=nr(u,c,p,n);h&&Qt(t,e,c.x,c.y,h,"edgeCorner")}let s=o[o.length-1],i=o[o.length-2],a=rr(i,s,n);a&&Qt(t,e,s.x,s.y,a,"arrow")}function tr(t,e,n,r,o){if(!(r.x===o.x&&r.y===o.y)){if(r.y===o.y){let s=r.y,i=Math.min(r.x,o.x),a=Math.max(r.x,o.x);for(let d=i;d<=a;d+=1)Zt(t,e,d,s,n,"h")}else if(r.x===o.x){let s=r.x,i=Math.min(r.y,o.y),a=Math.max(r.y,o.y);for(let d=i;d<=a;d+=1)Zt(t,e,s,d,n,"v")}}}function Zt(t,e,n,r,o,s){if(r<0||r>=t.length)return;let i=t[r];if(n<0||n>=i.length)return;let a=e[r][n];if(!(a==="boxH"||a==="boxV"||a==="boxCorner"||a==="label")){if(a==="empty"){i[n]=s==="h"?o.horizontal:o.vertical,e[r][n]=s==="h"?"edgeH":"edgeV";return}if(a==="edgeH"&&s==="v"){i[n]=o.cross,e[r][n]="edgeCorner";return}if(a==="edgeV"&&s==="h"){i[n]=o.cross,e[r][n]="edgeCorner";return}}}function Qt(t,e,n,r,o,s){if(r<0||r>=t.length)return;let i=t[r];if(n<0||n>=i.length)return;let a=e[r][n];a==="boxH"||a==="boxV"||a==="boxCorner"||a==="label"||(i[n]=o,e[r][n]=s)}function nr(t,e,n,r){let o=t.y===e.y,s=e.y===n.y;if(o===s)return;if(o){let d=t.x<e.x,u=n.y>e.y;return d&&u?r.cornerTR:d&&!u?r.cornerBR:!d&&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 rr(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 sr(t){let e=t.length;for(;e>0&&t.charCodeAt(e-1)===32;)e-=1;return t.slice(0,e)}function sn(t){let e=or(t);ir(e),ar(e),ur(e),dr(e,t);let n=fr(e,t),{width:r,height:o}=hr(e),s=[];for(let i of e.layers)for(let a of i)a.isVirtual||s.push({id:a.id,layer:a.layer,order:a.order,x:a.x,y:a.y,w:a.w,h:a.h});return{boxes:s,edges:n,width:r,height:o}}function or(t){let e=new Map;for(let o of t.nodes)e.set(o,{id:o,isVirtual:!1,layer:-1,order:0,x:0,y:0,w:t.widthCells(o),h:t.heightCells(o),in:[],out:[]});let n=[],r=0;for(let o of t.edges){if(o.from===o.to)continue;let s=e.get(o.from),i=e.get(o.to);if(!s||!i)continue;let a={chainId:r++,chainFrom:o.from,chainTo:o.to,fromId:o.from,toId:o.to,hopIndex:0,chainLen:1};s.out.push(a),i.in.push(a),n.push(a)}return{nodes:e,layers:[],hops:n}}function ir(t){let e=new Map;for(let s of t.nodes.values())e.set(s.id,s.in.length);let n=[];for(let s of t.nodes.values())(e.get(s.id)??0)===0&&(s.layer=0,n.push(s));let r=new Set,o=0;for(;o<n.length;){let s=n[o++];if(!r.has(s.id)){r.add(s.id);for(let i of s.out){let a=t.nodes.get(i.toId);a.layer=Math.max(a.layer,s.layer+1);let d=(e.get(a.id)??0)-1;e.set(a.id,d),d<=0&&n.push(a)}}}for(let s of t.nodes.values())s.layer<0&&(s.layer=0)}function ar(t){let e=Math.max(0,...Array.from(t.nodes.values(),s=>s.layer)),n=Array.from({length:e+1},()=>[]);for(let s of t.nodes.values())n[s.layer].push(s);let r=[],o=0;for(let s of t.hops){let i=t.nodes.get(s.fromId),a=t.nodes.get(s.toId),d=a.layer-i.layer;if(d<=0){i.out=i.out.filter(p=>p!==s),a.in=a.in.filter(p=>p!==s);continue}if(d===1){s.hopIndex=0,s.chainLen=1,r.push(s);continue}i.out=i.out.filter(p=>p!==s),a.in=a.in.filter(p=>p!==s);let u=i;for(let p=1;p<d;p+=1){let h=`__virt_${o++}__`,f={id:h,isVirtual:!0,layer:i.layer+p,order:0,x:0,y:0,w:0,h:1,in:[],out:[]};t.nodes.set(h,f),n[f.layer].push(f);let l={chainId:s.chainId,chainFrom:s.chainFrom,chainTo:s.chainTo,fromId:u.id,toId:h,hopIndex:p-1,chainLen:d};u.out.push(l),f.in.push(l),r.push(l),u=f}let c={chainId:s.chainId,chainFrom:s.chainFrom,chainTo:s.chainTo,fromId:u.id,toId:a.id,hopIndex:d-1,chainLen:d};u.out.push(c),a.in.push(c),r.push(c)}for(let s of n)for(let i=0;i<s.length;i+=1)s[i].order=i;t.layers=n,t.hops=r}function ur(t){for(let n=0;n<4;n+=1){for(let r=1;r<t.layers.length;r+=1)nn(t,t.layers[r],"in"),qe(t.layers[r]);for(let r=t.layers.length-2;r>=0;r-=1)nn(t,t.layers[r],"out"),qe(t.layers[r])}for(let n=0;n<2;n+=1){let r=!1;for(let o=1;o<t.layers.length;o+=1){let s=t.layers[o];for(let i=0;i+1<s.length;i+=1){let a=rn(t,s[i],s[i+1],"in");[s[i],s[i+1]]=[s[i+1],s[i]],qe(s),rn(t,s[i],s[i+1],"in")<a?r=!0:([s[i],s[i+1]]=[s[i+1],s[i]],qe(s))}}if(!r)break}}function nn(t,e,n){let r=new Map;for(let o of e){let s=n==="in"?o.in:o.out;if(s.length===0){r.set(o.id,o.order);continue}let i=0,a=0;for(let d of s){let u=t.nodes.get(n==="in"?d.fromId:d.toId);u&&(i+=u.order,a+=1)}r.set(o.id,a===0?o.order:i/a)}e.sort((o,s)=>{let i=r.get(o.id),a=r.get(s.id);return i!==a?i-a:o.order-s.order})}function qe(t){for(let e=0;e<t.length;e+=1)t[e].order=e}function rn(t,e,n,r){let o=r==="in"?e.in:e.out,s=r==="in"?n.in:n.out,i=0;for(let a of o)for(let d of s){let u=t.nodes.get(r==="in"?a.fromId:a.toId)?.order??0,c=t.nodes.get(r==="in"?d.fromId:d.toId)?.order??0;(e.order<n.order&&u>c||e.order>n.order&&u<c)&&(i+=1)}return i}function dr(t,e){e.direction==="LR"?cr(t,e):lr(t,e)}function cr(t,e){let n=[],r=0;for(let o=0;o<t.layers.length;o+=1){n.push(r);let s=0;for(let i of t.layers[o])s=Math.max(s,i.w);r+=s+e.layerGap}for(let o=0;o<t.layers.length;o+=1)for(let s of t.layers[o])s.x=n[o];for(let o of t.layers){let s=0;for(let i of o)i.y=s,s+=i.h+e.nodeGap}on(t,e,"y")}function lr(t,e){let n=[],r=0;for(let o=0;o<t.layers.length;o+=1){n.push(r);let s=0;for(let i of t.layers[o])s=Math.max(s,i.h);r+=s+e.layerGap}for(let o=0;o<t.layers.length;o+=1)for(let s of t.layers[o])s.y=n[o];for(let o of t.layers){let s=0;for(let i of o)i.x=s,s+=i.w+e.nodeGap}on(t,e,"x")}function on(t,e,n){let r=s=>n==="y"?s.h:s.w,o=e.nodeGap;for(let s=0;s<2;s+=1){let i=s===0?t.layers.slice(1):t.layers.slice(0,-1).reverse();for(let a of i){let d=new Map;for(let c of a){let p=s===0?c.in:c.out;if(p.length===0)continue;let h=[];for(let l of p){let b=t.nodes.get(s===0?l.fromId:l.toId);if(!b)continue;let m=n==="y"?b.y:b.x;h.push(m+Math.floor(r(b)/2))}if(h.length===0)continue;h.sort((l,b)=>l-b);let f=h[Math.floor(h.length/2)];d.set(c.id,f-Math.floor(r(c)/2))}let u=0;for(let c of a){let p=d.get(c.id),h=n==="y"?c.y:c.x,l=Math.max(p??h,u);n==="y"?c.y=l:c.x=l,u=l+r(c)+o}}}}function fr(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,p)=>c.hopIndex-p.hopIndex);let r=e.direction==="LR",o=u=>r?u.x:u.y,s=u=>r?u.w:u.h,i=u=>r?u.y+Math.floor(u.h/2):u.x+Math.floor(u.w/2),a=new Map;for(let u=0;u+1<t.layers.length;u+=1){let c=t.layers[u],p=t.layers[u+1],h=0;for(let v of c)h=Math.max(h,o(v)+s(v));let f=Number.POSITIVE_INFINITY;for(let v of p)f=Math.min(f,o(v));let l=Number.isFinite(f)?f-1:h,b=Math.max(1,l-h+1),m=[];for(let v of c)for(let k of v.out)m.push(k);m.sort((v,k)=>{let S=i(t.nodes.get(v.fromId)),R=i(t.nodes.get(k.fromId));if(S!==R)return S-R;let A=i(t.nodes.get(v.toId)),N=i(t.nodes.get(k.toId));return A-N});let x=[],_=new Map;for(let v of m){let k=i(t.nodes.get(v.fromId)),S=i(t.nodes.get(v.toId)),R=Math.min(k,S),A=Math.max(k,S),N=-1;for(let D=0;D<x.length;D+=1){let B=x[D],j=!0;for(let ae of B)if(ae.lo<=A&&R<=ae.hi){j=!1;break}if(j){B.push({lo:R,hi:A}),N=D;break}}N<0&&(x.push([{lo:R,hi:A}]),N=x.length-1),_.set(v,N)}let y=x.length,w=b>=Math.max(3,y+2),O=w?h+1:h,T=w?l-1:l,g=Math.max(1,T-O+1);for(let v of m){let k=_.get(v),S;if(y<=1)S=O+Math.floor(g/2);else{let R=(g-1)/(y-1);S=O+Math.floor(k*R)}a.set(v,Math.max(h,Math.min(l,S)))}}let d=[];for(let[,u]of n){let c=[];for(let h=0;h<u.length;h+=1){let f=u[h],l=t.nodes.get(f.fromId),b=t.nodes.get(f.toId),m=a.get(f),x=l.isVirtual?o(l):o(l)+s(l),_=b.isVirtual?o(b):o(b)-1,y=i(l),w=i(b);h===0&&Ye(c,r,x,y),y!==w&&(Ye(c,r,m,y),Ye(c,r,m,w)),Ye(c,r,_,w)}let p=u[0];d.push({from:p.chainFrom,to:p.chainTo,points:pr(c)})}return d}function Ye(t,e,n,r){t.push(e?{x:n,y:r}:{x:r,y:n})}function pr(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 hr(t){let e=0,n=0;for(let r of t.layers)for(let o of r)e=Math.max(e,o.x+o.w),n=Math.max(n,o.y+o.h);return{width:e,height:n}}var gr=24,mr=4,br=1,yr=3;function an(t,e){let n=vr(e.direction),r=Math.max(3,e.maxLabelWidth??gr),o=e.asciiCharset??"unicode",s=Object.keys(t.nodes).sort(),i=new Set(s),a=t.edges.filter(f=>i.has(f.from)&&i.has(f.to)),d=new Map,u=new Map;for(let f of s){let l=Jt(f,r);d.set(f,l),u.set(f,Ke(l)+4)}let c=sn({nodes:s,edges:a,widthCells:f=>u.get(f)??3,heightCells:()=>yr,layerGap:mr,nodeGap:br,direction:n}),p=en(c,{charset:o,labelOf:f=>d.get(f)??f}),h=e.logger;return h&&h(p),p}function vr(t){if(t===void 0||t==="LR")return"LR";if(t==="TD")return"TD";throw new Error(`ascii describe supports direction "LR" or "TD" only; got ${String(t)}`)}function un(t,e,n,r={}){let o=e in t.nodes,s=n in t.nodes;if(!o)return Je(e,n,"no-such-from");if(!s)return Je(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=_r(t,e,r);if(u!=null)return u}let d=Xe(e,t.nodes[e],0,r);return Ze(e,n,[d])}if(i===0)return Je(e,n,"no-path");let a=dn(t,e,n,i);return a.found?Ze(e,n,cn(t,a.pathOrder,r)):Je(e,n,a.truncated?"max-depth-exceeded":"no-path")}function dn(t,e,n,r){let o=new Map,s=[{path:n,depth:0}],i=new Set([n]),a=0,d=!1;for(;a<s.length;){let p=s[a++];if(p.path===e)break;if(r!=null&&p.depth>=r){let b=t.nodes[p.path];b?.deps&&b.deps.length>0&&(d=!0);continue}let h=t.nodes[p.path];if(h==null)continue;let f=h.deps??[],l=new Map;for(let b=0;b<f.length;b++){let m=f[b];if(!m)continue;let x=l.get(m);x==null&&(x=[],l.set(m,x)),x.push(b)}for(let[b,m]of l)i.has(b)||(i.add(b),o.set(b,{from:p.path,depIndices:m}),s.push({path:b,depth:p.depth+1}))}if(!o.has(e))return{found:!1,pathOrder:[],truncated:d};let u=[{path:e}],c=e;for(;c!==n;){let p=o.get(c);if(p==null)return{found:!1,pathOrder:[],truncated:!1};u[u.length-1].depIndices=p.depIndices,u.push({path:p.from}),c=p.from}return{found:!0,pathOrder:u,truncated:!1}}function _r(t,e,n){let r=t.nodes[e];if(r==null)return null;let o=r.deps??[],s=[];for(let a=0;a<o.length;a++)o[a]===e&&s.push(a);if(s.length>0){let a=Xe(e,r,0,n);a.dep_index=s[0];let d=Xe(e,r,1,n);return Ze(e,e,[a,d])}let i=null;for(let a=0;a<o.length;a++){let d=o[a];if(!d||d===e)continue;let u=dn(t,d,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:Ze(e,e,cn(t,i.pathOrder,n))}function cn(t,e,n){return e.map((r,o)=>{let s=t.nodes[r.path],i=Xe(r.path,s,o,n);return r.depIndices!=null&&r.depIndices.length>0&&(i.dep_index=r.depIndices[0],r.depIndices.length>1&&(i.dep_indices=[...r.depIndices])),i})}function Xe(t,e,n,r){let o={path:t,type:e.type,hop:n};e.status!==void 0&&(o.status=e.status),"value"in e&&(o.value=e.value),e.v!=null&&(o.v=e.v);let s=r.annotations?.get(t)??e.annotation;s!=null&&(o.annotation=s);let i=r.lastMutations?.get(t)??e.lastMutation;return i!=null&&(o.lastMutation=i),o}function Ze(t,e,n){return ln(t,e,!0,"ok",n)}function Je(t,e,n){return ln(t,e,!1,n,[])}function ln(t,e,n,r,o){let s=wr(t,e,n,r,o);return{from:t,to:e,found:n,reason:r,steps:o,text:s,toJSON(){return{from:t,to:e,found:n,reason:r,steps:o}}}}function wr(t,e,n,r,o){if(!n)switch(r){case"no-such-from":return`explainPath: no node named "${t}"`;case"no-such-to":return`explainPath: no node named "${e}"`;case"max-depth-exceeded":return`explainPath: no path from "${t}" to "${e}" within maxDepth`;default:return`explainPath: no path from "${t}" to "${e}"`}let s=[`Causal path: ${t} \u2192 ${e} (${o.length} step(s))`];for(let i of o){let d=` ${i.hop===0?"\xB7":"\u2193"} ${i.path} (${i.type}${i.status?`/${i.status}`:""})`;if(s.push(d),"value"in i&&s.push(` value: ${xr(i.value)}`),i.annotation!=null&&s.push(` annotation: ${i.annotation}`),i.lastMutation!=null){let u=i.lastMutation.actor;s.push(` actor: ${u.type}${u.id?`:${u.id}`:""}`)}}return s.join(`
|
|
3
|
+
`)}function xr(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)}}be();var z={object:56,array:64,string:40,number:8,boolean:4,null:0,undefined:0,symbol:40,bigint:16,function:120,map:72,set:72,mapEntry:40,setEntry:24,date:24,regexp:48,error:64,url:80,promise:48,weakmap:40,weakset:40},Tr=Symbol.for("sizeof");function fn(t){let e=new WeakSet,n=new WeakSet,r=[t],o=0;for(;r.length>0;){let s=r.pop();o+=Or(s,e,n,r)}return o}function Or(t,e,n,r){if(t==null)return 0;switch(typeof t){case"number":return z.number;case"boolean":return z.boolean;case"string":return z.string+t.length*2;case"bigint":return z.bigint+kr(t);case"symbol":return z.symbol;case"function":return e.has(t)?0:(e.add(t),z.function);case"undefined":return 0}let s=t;if(e.has(s))return 0;e.add(s);let i=s[Tr];if(typeof i=="function")try{let u=i.call(s);if(typeof u=="number"&&Number.isFinite(u))return u}catch{}if(s instanceof Date)return z.date;if(s instanceof RegExp)return z.regexp+s.source.length*2;if(s instanceof Error){let u=s.message?s.message.length*2:0,c=s.stack?s.stack.length*2:0;return z.error+u+c}if(typeof URL<"u"&&s instanceof URL)return z.url+s.href.length*2;if(typeof Promise<"u"&&s instanceof Promise)return z.promise;if(s instanceof WeakMap)return z.weakmap;if(s instanceof WeakSet)return z.weakset;if(s instanceof Map){let u=z.map;for(let[c,p]of s)u+=z.mapEntry,r.push(c),r.push(p);return u}if(s instanceof Set){let u=z.set;for(let c of s)u+=z.setEntry,r.push(c);return u}if(Array.isArray(s)){let u=z.array+s.length*8;for(let c of s)r.push(c);return u}if(s instanceof ArrayBuffer)return n.has(s)?0:(n.add(s),s.byteLength);if(ArrayBuffer.isView(s)){let u=s;return n.has(u.buffer)?48:(n.add(u.buffer),u.buffer.byteLength+48)}let a=z.object,d=Object.keys(s);for(let u of d){a+=z.string+u.length*2;try{r.push(s[u])}catch{}}return a}function kr(t){let e=t<0n?-t:t;if(e===0n)return 0;let n=e.toString(2).length;return Math.ceil(n/32)*8}function pn(t,e){let n=e?.topN??10,r=t.describe({detail:"standard"}),o=[],s=t._collectObserveTargets;typeof s=="function"&&s.call(t,"",o);let i=new Map;for(let[h,f]of o)i.set(h,f);let a=[];for(let[h,f]of Object.entries(r.nodes)){let l=i.get(h),b=l instanceof V?l:null,m=b?fn(b.cache):0,x=b?b._sinkCount:0,_=f.deps?.length??0,y=f.type==="effect"&&x===0,w=x===0?f.type==="effect"?"orphan-effect":f.type==="derived"?"idle-derived":f.type==="producer"?"idle-producer":null:null;a.push({path:h,type:f.type,status:f.status??"unknown",valueSizeBytes:m,subscriberCount:x,depCount:_,isOrphanEffect:y,orphanKind:w})}let d=a.reduce((h,f)=>h+f.valueSizeBytes,0),u=(h,f)=>[...a].sort(f??((l,b)=>b[h]-l[h])).slice(0,n),c=a.filter(h=>h.orphanKind!=null),p=a.filter(h=>h.isOrphanEffect);return{nodeCount:a.length,edgeCount:r.edges.length,subgraphCount:r.subgraphs.length,nodes:a,totalValueSizeBytes:d,hotspots:{byValueSize:u("valueSizeBytes"),bySubscriberCount:u("subscriberCount"),byDepCount:u("depCount")},orphans:c,orphanEffects:p}}var F="::",se="__meta__",Re=1;function hn(t,e){let n=Math.max(16,t.size*4),r=0;for(;t.size>0;){if(r++>=n){console.error(`[Graph "${e}".destroy] disposer drain exceeded cap (${n}); ${t.size} disposer(s) discarded`),t.clear();return}let o=t.values().next();if(o.done)return;let s=o.value;t.delete(s);try{s()}catch(i){console.error(`[Graph "${e}".destroy] disposer threw:`,i)}}}function yn(t){return t!=null&&typeof t=="object"&&"cache"in t&&typeof t.subscribe=="function"&&typeof t.down=="function"}function Rr(t){if(t!=null)return yn(t)?t.cache:t}function Nr(t){let e=[];for(let n of Object.keys(t).sort()){let r=t[n].v;r!=null&&e.push(`${n} ${r.id} ${r.version}`)}return e.join(`
|
|
4
|
+
`)}function gn(t){if(t.version!==Re)throw new Error(`unsupported snapshot version ${String(t.version)} (expected ${Re})`);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 Er(t,e){let n=new WeakMap,r=(o,s)=>{if(Object.is(o,s))return!0;if(o==null||s==null||typeof o!="object"||typeof s!="object")return!1;let i=n.get(o);if(i==null&&(i=new WeakSet,n.set(o,i)),i.has(s))return!0;i.add(s);let a=o.constructor,d=s.constructor;if(a!==d)return!1;if(o instanceof Date)return o.getTime()===s.getTime();if(o instanceof RegExp)return o.source===s.source&&o.flags===s.flags;if(Array.isArray(o)){let h=s;if(o.length!==h.length)return!1;for(let f=0;f<o.length;f++)if(!r(o[f],h[f]))return!1;return!0}if(o instanceof Map){let h=s;if(o.size!==h.size)return!1;for(let[f,l]of o)if(!h.has(f)||!r(l,h.get(f)))return!1;return!0}if(o instanceof Set){let h=s;if(o.size!==h.size)return!1;for(let f of o){let l=!1;for(let b of h)if(r(f,b)){l=!0;break}if(!l)return!1}return!0}if(ArrayBuffer.isView(o)){let h=o,f=s;if(h.length!==f.length)return!1;for(let l=0;l<h.length;l++)if(h[l]!==f[l])return!1;return!0}let u=Object.keys(o),c=Object.keys(s);if(u.length!==c.length)return!1;let p=new Set(c);for(let h of u)if(!p.has(h)||!r(o[h],s[h]))return!1;return!0};return r(t,e)}function kt(t){if(t===null||typeof t!="object")return t;if(Array.isArray(t))return t.map(kt);let e=t,n=Object.keys(e).sort(),r={};for(let o of n)r[o]=kt(e[o]);return r}function Sr(t){return t.replaceAll("\\","\\\\").replaceAll('"','\\"')}function Ar(t){return t.replaceAll("\\","\\\\").replaceAll('"','\\"')}function Dr(t){return t==="TD"?"down":t==="BT"?"up":t==="RL"?"left":"right"}function vn(t){let e=new Set,n=[];function r(o,s){let i=`${o}\0${s}`;e.has(i)||(e.add(i),n.push([o,s]))}for(let[o,s]of Object.entries(t.nodes)){let i=s.deps;if(i)for(let a of i)r(a,o)}for(let o of t.edges)r(o.from,o.to);return n}function _n(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 Cr(t,e){let n=e.includeEdges??!0,r=e.includeSubgraphs??!0,{expand:o,...s}=t,i={...s,edges:n?t.edges:[],subgraphs:r?t.subgraphs:[]},a=JSON.stringify(kt(i),null,e.indent??2);return e.logger?.(a),a}function Mr(t,e){let n=e.includeEdges??!0,r=e.includeSubgraphs??!0,o=[];o.push(`Graph ${t.name}`),o.push("Nodes:");for(let i of Object.keys(t.nodes).sort()){let a=t.nodes[i];o.push(`- ${i} (${a.type}/${a.status}): ${et(a.value)}`)}if(n){o.push("Edges:");for(let i of t.edges)o.push(`- ${i.from} -> ${i.to}`)}if(r){o.push("Subgraphs:");for(let i of t.subgraphs)o.push(`- ${i}`)}let s=o.join(`
|
|
5
|
+
`);return e.logger?.(s),s}function wn(t,e){let n=_n(e.direction),r=Object.keys(t.nodes).sort(),o=new Map;for(let i=0;i<r.length;i+=1)o.set(r[i],`n${i}`);let s=[`flowchart ${n}`];for(let i of r){let a=o.get(i);s.push(` ${a}["${Sr(i)}"]`)}for(let[i,a]of vn(t)){let d=o.get(i),u=o.get(a);!d||!u||s.push(` ${d} --> ${u}`)}return s.join(`
|
|
6
|
+
`)}function Gr(t,e){let n=wn(t,e);return Lr(n)}function Lr(t,e){let n=e?.theme??"default",r=e?.autoSync??!0,s=JSON.stringify({code:t,mermaid:{theme:n},autoSync:r}),i=new TextEncoder().encode(s),a="";for(let u=0;u<i.length;u++)a+=String.fromCharCode(i[u]);return`https://mermaid.live/edit#base64:${globalThis.btoa(a).replace(/\+/g,"-").replace(/\//g,"_").replace(/=+$/,"")}`}function Ir(t,e){let n=_n(e.direction),r=Object.keys(t.nodes).sort(),o=new Map;for(let i=0;i<r.length;i+=1)o.set(r[i],`n${i}`);let s=[`direction: ${Dr(n)}`];for(let i of r){let a=o.get(i);s.push(`${a}: "${Ar(i)}"`)}for(let[i,a]of vn(t)){let d=o.get(i),u=o.get(a);!d||!u||s.push(`${d} -> ${u}`)}return s.join(`
|
|
7
|
+
`)}function Pr(t){return t.replace(/[.*+?^${}()|[\]\\]/g,"\\$&")}function Qe(t){let e="^";for(let n=0;n<t.length;n+=1){let r=t[n];if(r==="*"){e+=".*";continue}if(r==="?"){e+=".";continue}if(r==="["){let o=t.indexOf("]",n+1);if(o<=n+1){e+="\\[";continue}let s=t.slice(n+1,o);s.startsWith("!")&&(s=`^${s.slice(1)}`),s=s.replace(/\\/g,"\\\\"),e+=`[${s}]`,n=o;continue}e+=Pr(r)}return e+="$",new RegExp(e)}var $r={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"},Fr={data:"",dirty:"",resolved:"",invalidate:"",pause:"",resume:"",complete:"",error:"",teardown:"",derived:"",path:"",reset:""};function et(t){if(typeof t=="string")return JSON.stringify(t);if(typeof t=="number"||typeof t=="boolean"||t==null)return String(t);try{return JSON.stringify(t)}catch{return"[unserializable]"}}function Vr(t){return t==="none"?Fr:t==="ansi"||t==null?$r:{data:t.data??"",dirty:t.dirty??"",resolved:t.resolved??"",invalidate:t.invalidate??"",pause:t.pause??"",resume:t.resume??"",complete:t.complete??"",error:t.error??"",teardown:t.teardown??"",derived:t.derived??"",path:t.path??"",reset:t.reset??""}}function mn(t){if(t==null)return{};let e=t.detail;return e==="full"?{...t,structured:t.structured??!0,timeline:t.timeline??!0,causal:t.causal??!0,derived:t.derived??!0}:e==="minimal"?{...t,structured:t.structured??!0}:t.format==="stage-log"?{...t,structured:t.structured??!0,timeline:t.timeline??!0}:t}function zr(t,e,n){for(let r=0;r<t.length;r++){let o=t.charCodeAt(r);if(o<32||o===127)throw new Error(`Graph "${e}": ${n} "${t}" must not contain control character (U+${o.toString(16).padStart(4,"0").toUpperCase()} at index ${r})`)}}function Ot(t,e,n){if(t==="")throw new Error(`Graph "${e}": ${n} name must be non-empty`);if(t.includes(F))throw new Error(`Graph "${e}": ${n} "${t}" must not contain '${F}' (path separator)`);if(t===se)throw new Error(`Graph "${e}": ${n} name "${se}" is reserved for meta companion paths`);zr(t,e,n)}function jr(t,e){if(t==="")throw new Error(`Graph "${e}": resolve path must be non-empty`);let n=t.split(F);for(let r of n)if(r==="")throw new Error(`Graph "${e}": resolve path has empty segment`);return n}function Br(t,e){let n=!1;for(let o of t)if(!e.isMetaPassthrough(o[0])){n=!0;break}return n?t.filter(o=>e.isMetaPassthrough(o[0])):t}function xn(t){for(let e of t._mounts.values())xn(e);for(let e of t._nodes.values())try{e.down([[U]],{internal:!0})}catch{}}var Ne=class t{name;opts;config;_nodes=new Map;_nodeToName=new WeakMap;_mounts=new Map;_parent=void 0;_storageDisposers=new Set;_disposers=new Set;_destroyed=!1;_topology;_topologyEmitters=new Set;_factory;_factoryArgs;constructor(e,n){if(e==="")throw new Error("Graph name must be non-empty");if(e.includes(F))throw new Error(`Graph name must not contain '${F}' (got "${e}")`);if(e===se)throw new Error(`Graph name "${se}" is reserved for meta companion paths`);this.name=e,this.opts=Object.freeze({...n??{}}),this.config=n?.config??ke,this._traceRing=new Ge(n?.traceCapacity??1e3),n?.versioning!=null&&this.setVersioning(n.versioning),typeof n?.factory=="string"&&(this._factory=n.factory,n.factoryArgs!==void 0&&(this._factoryArgs=n.factoryArgs))}tagFactory(e,n){return this._factory=e,this._factoryArgs=n,this}ancestors(e=!0){let n=[],r=e?this:this._parent;for(;r!=null;)n.push(r),r=r._parent;return n}get topology(){return this._topology==null&&(this._topology=_t(e=>{let n=r=>{e.emit(r)};return this._topologyEmitters.add(n),()=>{this._topologyEmitters.delete(n)}},{name:`${this.name}_topology`})),this._topology}_emitTopology(e){if(!(this._topology==null||this._topologyEmitters.size===0))for(let n of this._topologyEmitters)n(e)}nameOf(e){return this._nodeToName.get(e)}add(e,n){let r=e.name,o=n?.name??r;if(o==null||o==="")throw new Error(`Graph "${this.name}": graph.add requires a non-empty name \u2014 pass via opts.name or set it on the node (e.g. state(0, { name: "x" }))`);let s=o,i=n?.annotation;if(Ot(s,this.name,"add"),this._mounts.has(s))throw new Error(`Graph "${this.name}": name "${s}" is already a mount point`);if(this._nodes.has(s))throw new Error(`Graph "${this.name}": node "${s}" already exists`);let a=this._nodeToName.get(e);if(a!==void 0)throw new Error(`Graph "${this.name}": node instance already registered as "${a}"`);return this._nodes.set(s,e),this._nodeToName.set(e,s),this._emitTopology({kind:"added",name:s,nodeKind:"node"}),i!=null&&(this._annotations.set(s,i),this.config.inspectorEnabled&&this._traceRing.push({path:s,annotation:i,timestamp_ns:de()})),e}setVersioning(e){if(e!=null)for(let n of this._nodes.values())n instanceof V&&n._applyVersioning(e)}remove(e){Ot(e,this.name,"remove");let n=this._mounts.get(e);if(n){let s={kind:"mount",nodes:[],mounts:[]},i=[];n._collectObserveTargets("",i);for(let[a,d]of i)a.includes(`${F}${se}${F}`)||s.nodes.push(a);return s.nodes.sort(),s.mounts.push(e),s.mounts.push(...n._collectSubgraphs(`${e}${F}`)),this._mounts.delete(e),n._parent=void 0,xn(n),this._emitTopology({kind:"removed",name:e,nodeKind:"mount",audit:s}),s}let r=this._nodes.get(e);if(!r)throw new Error(`Graph "${this.name}": unknown node or mount "${e}"`);this._nodes.delete(e),this._nodeToName.delete(r),r.down([[U]],{internal:!0});let o={kind:"node",nodes:[e],mounts:[]};return this._emitTopology({kind:"removed",name:e,nodeKind:"node",audit:o}),o}removeAll(e){let n=typeof e=="function"?e:(()=>{let s=Qe(e);return i=>s.test(i)})(),r={kind:"mount",nodes:[],mounts:[]},o=[...this._nodes.keys(),...this._mounts.keys()].filter(s=>n(s));for(let s of o){let i=this.remove(s);r.nodes.push(...i.nodes),r.mounts.push(...i.mounts)}return r.nodes.sort(),r.mounts.sort(),r}[Symbol.iterator](){let e=[...this._nodes.keys()].sort(),n=this._nodes,r=0;return{[Symbol.iterator](){return this},next(){if(r>=e.length)return{value:void 0,done:!0};let o=e[r++];return{value:[o,n.get(o)],done:!1}}}}node(e){if(e==="")throw new Error(`Graph "${this.name}": node name must be non-empty`);if(e.includes(F))return this.resolve(e);let n=this._nodes.get(e);if(!n)throw new Error(`Graph "${this.name}": unknown node "${e}"`);return n}get(e){return this.node(e).cache}set(e,n,r){let o=r?.internal===!0;this.node(e).down([[I,n]],{actor:r?.actor,internal:o,delivery:"write"})}setAll(e,n){let r=Symbol.iterator in e?e:Object.entries(e);ue(()=>{for(let[o,s]of r)this.set(o,s,n)})}invalidate(e,n){let r=n?.internal===!0;this.node(e).down([[ne]],{actor:n?.actor,internal:r,delivery:"write"})}error(e,n,r){let o=r?.internal===!0;this.node(e).down([[$,n]],{actor:r?.actor,internal:o,delivery:"write"})}complete(e,n){let r=n?.internal===!0;this.node(e).down([[K]],{actor:n?.actor,internal:r,delivery:"write"})}edges(e){let n=e?.recursive===!0,r=new Map;if(!n){for(let[d,u]of this._nodes)r.set(u,d);let a=[];for(let[d,u]of this._nodes)if(u instanceof V)for(let c of u._deps){let p=r.get(c.node);p!=null&&a.push([p,d])}return a.sort((d,u)=>d[0]<u[0]?-1:d[0]>u[0]?1:d[1]<u[1]?-1:d[1]>u[1]?1:0),a}let o=[];this._collectObserveTargets("",o);let s=new Map;for(let[a,d]of o)s.set(d,a);let i=[];for(let[a,d]of o)if(d instanceof V)for(let u of d._deps){let c=s.get(u.node);c!=null&&i.push([c,a])}return i.sort((a,d)=>a[0]<d[0]?-1:a[0]>d[0]?1:a[1]<d[1]?-1:a[1]>d[1]?1:0),i}mount(e,n){if(n===void 0){let o=new t(e);return this.mount(e,o)}if(typeof n=="function"){let o=new t(e);return n(o),this.mount(e,o)}let r=n;if(Ot(e,this.name,"mount"),this._nodes.has(e))throw new Error(`Graph "${this.name}": cannot mount at "${e}" \u2014 node with that name exists`);if(this._mounts.has(e))throw new Error(`Graph "${this.name}": mount "${e}" already exists`);if(r===this)throw new Error(`Graph "${this.name}": cannot mount a graph into itself`);if(r._parent!=null)throw new Error(`Graph "${this.name}": this child graph is already mounted on "${r._parent.name}"`);for(let o=this;o!=null;o=o._parent)if(o===r)throw new Error(`Graph "${this.name}": mount("${e}", \u2026) would create a mount cycle`);return this._mounts.set(e,r),r._parent=this,this._emitTopology({kind:"added",name:e,nodeKind:"mount"}),r}resolve(e){let n=jr(e,this.name);return this._resolveFromSegments(n)}tryResolve(e){try{return this.resolve(e)}catch{return}}_resolveFromSegments(e){let n=e;if(n[0]===this.name&&(n=n.slice(1),n.length===0))throw new Error(`Graph "${this.name}": resolve path ends at graph name only`);let r=n[0],o=n.slice(1);if(o.length===0){let a=this._nodes.get(r);if(a)return a;throw this._mounts.has(r)?new Error(`Graph "${this.name}": path ends at subgraph "${r}" \u2014 not a node (GRAPHREFLY-SPEC \xA73.5)`):new Error(`Graph "${this.name}": unknown name "${r}"`)}let s=this._nodes.get(r);if(s&&o.length>0&&o[0]===se)return this._resolveMetaChainFromNode(s,o,n.join(F));let i=this._mounts.get(r);if(!i)throw this._nodes.has(r)?new Error(`Graph "${this.name}": "${r}" is a node; trailing path "${o.join(F)}" is invalid`):new Error(`Graph "${this.name}": unknown mount or node "${r}"`);return i.resolve(o.join(F))}_resolveMetaChainFromNode(e,n,r){let o=e,s=0,i=[...n];for(;s<i.length;){if(i[s]!==se)throw new Error(`Graph "${this.name}": expected ${se} segment in meta path "${r}"`);if(s+1>=i.length)throw new Error(`Graph "${this.name}": meta path requires a key after ${se} in "${r}"`);let a=i[s+1],d=o.meta[a];if(!d)throw new Error(`Graph "${this.name}": unknown meta "${a}" in path "${r}"`);o=d,s+=2}return o}signal(e,n){if(n?.internal!==!0){for(let o of e)if(this.config.messageTier(o[0])===3)throw new Error(`Graph "${this.name}": Graph.signal() rejects tier-3 messages (DATA / RESOLVED). Broadcast is for control-plane tiers (START / DIRTY / INVALIDATE / PAUSE / RESUME / COMPLETE / ERROR / TEARDOWN). For per-node value writes, use Graph.set or graph.node(name).down(...).`)}let r=[];if(this._signalDeliver(e,n??{},new Set,r),r.length>0)throw r[0]}_signalDeliver(e,n,r,o){for(let d of this._mounts.values())d._signalDeliver(e,n,r,o);let i=n.internal===!0?{internal:!0}:{actor:n.actor,delivery:"signal"},a=Br(e,this.config);for(let d of[...this._nodes.keys()].sort()){let u=this._nodes.get(d);if(!r.has(u)){r.add(u);try{u.down(e,i)}catch(c){if(c instanceof te)throw c;o.push(c)}a.length!==0&&this._signalMetaSubtree(u,a,r,i,o)}}}_signalMetaSubtree(e,n,r,o,s){for(let i of Object.keys(e.meta).sort()){let a=e.meta[i];if(!r.has(a)){r.add(a);try{a.down(n,o)}catch(d){if(d instanceof te)throw d;s.push(d)}this._signalMetaSubtree(a,n,r,o,s)}}}describe(e){if(e?.reactive==="diff")return this._describeReactiveDiff(e);if(e?.reactive===!0)return this._describeReactive(e);let n=Rr(e?.actor),r=e?.filter,o=Be(e?.detail,e?.fields),s=e?.format==="spec",i=s?Be("minimal"):o,a=[];this._collectObserveTargets("",a);let d=new Map;for(let[T,g]of a)d.set(g,T);let u=[];{let T=a.map(([,k])=>k),g=new Set(d.values()),v=0;for(;T.length>0;){let k=T.shift();if(k instanceof V)for(let S of k._deps){let R=S.node;if(d.has(R))continue;let A=R.name??"",N=A;if(!N||g.has(N))if(A){let D=2;for(;g.has(`${A}#${D}`);)D++;N=`${A}#${D}`}else for(N=`__internal__/${v++}`;g.has(N);)N=`__internal__/${v++}`;d.set(R,N),g.add(N),u.push([N,R]),T.push(R)}}}let c=[...a,...u],p={};for(let[T,g]of c){if(n!=null&&!g.allowsObserve(n))continue;let v=yt(g,i),k=g instanceof V?g._deps.map(N=>d.get(N.node)??N.node.name??""):[],{name:S,...R}=v,A={...R,deps:k};if(!s){let N=this._annotations.get(T);N!=null&&(A.annotation=N)}if(r!=null)if(typeof r=="function"){let N=r;if(!(N.length>=2?N(T,A):N(A)))continue}else{let N=!0;for(let[D,B]of Object.entries(r)){let j=D==="deps_includes"?"depsIncludes":D==="meta_has"?"metaHas":D;if(j==="depsIncludes"){if(!A.deps.includes(String(B))){N=!1;break}continue}if(j==="metaHas"){if(!Object.hasOwn(A.meta??{},String(B))){N=!1;break}continue}if(A[j]!==B){N=!1;break}}if(!N)continue}p[T]=A}let h=new Set(Object.keys(p)),f=[];for(let[T,g]of c)if(g instanceof V)for(let v of g._deps){let k=d.get(v.node);k!=null&&f.push([k,T])}f.sort((T,g)=>T[0]<g[0]?-1:T[0]>g[0]?1:T[1]<g[1]?-1:T[1]>g[1]?1:0);let l=f.map(([T,g])=>({from:T,to:g}));(n!=null||r!=null)&&(l=l.filter(T=>h.has(T.from)&&h.has(T.to)));let b=this._collectSubgraphs(""),m=n!=null||r!=null?b.filter(T=>{let g=`${T}${F}`;return[...h].some(v=>v===T||v.startsWith(g))}):b,x=this,_=e,y={name:this.name,nodes:p,edges:l,subgraphs:m,...this._factory!==void 0?{factory:this._factory}:{},...this._factoryArgs!==void 0?{factoryArgs:this._factoryArgs}:{},expand(T){let g={..._,format:void 0};return Array.isArray(T)?(g.fields=T,g.detail=void 0):(g.detail=T,g.fields=void 0),x.describe(g)}},w=e??{},O=w.format;return O==="json"?Cr(y,w):O==="pretty"?Mr(y,w):O==="mermaid"?wn(y,w):O==="mermaid-url"?Gr(y,w):O==="d2"?Ir(y,w):O==="ascii"?an(y,w):y}_collectSubgraphs(e){let n=[];for(let r of[...this._mounts.keys()].sort()){let o=e===""?r:`${e}${r}`;n.push(o),n.push(...this._mounts.get(r)._collectSubgraphs(`${o}${F}`))}return n}resourceProfile(e){return pn(this,e)}reachable(e,n,r={}){return r.withDetail===!0?bn(this.describe(),e,n,{...r,withDetail:!0}):bn(this.describe(),e,n,r)}explain(e,n,r){return r?.reactive===!0?this._explainReactive(e,n,r):this._explainStatic(e,n,r)}_explainStatic(e,n,r){let o=this.describe({detail:"full"}),s=new Map(this._annotations),i=new Map;for(let[a,d]of Object.entries(o.nodes))d.lastMutation!=null&&i.set(a,d.lastMutation);return un(o,e,n,{...r?.maxDepth!=null?{maxDepth:r.maxDepth}:{},...r?.findCycle===!0?{findCycle:!0}:{},annotations:s,lastMutations:i})}_describeReactive(e){let n={...e,reactive:!1},r=e.reactiveName??"describe",o=0,s=re(o,{name:`${r}_version`}),i=this.observe({timeline:!0,structured:!0}),a=!1,d=!1,u=()=>{a||d||(a=!0,_e(()=>{a=!1,!d&&(o+=1,s.emit(o))}))},c=i.onEvent(_=>{let y=_.type;y!=="data"&&y!=="error"&&y!=="complete"&&y!=="teardown"||u()}),p=[],h=new WeakSet,f=_=>{if(h.has(_)||d)return;h.add(_);let y=_.topology.subscribe(w=>{for(let O of w){if(O[0]!==I)continue;let T=O[1];if(u(),T.kind==="added"&&T.nodeKind==="mount"){let g=_._mounts.get(T.name);g!=null&&f(g)}}});p.push(y);for(let w of _._mounts.keys()){let O=_._mounts.get(w);O!=null&&f(O)}};f(this);let l,b=e.actor;yn(b)&&(l=b.subscribe(_=>{let y=!1,w=!1;for(let O of _){let T=O[0];T===I?y=!0:(T===K||T===$||T===U)&&(w=!0)}y&&u(),w&&(l?.(),l=void 0,u())}));let m;try{m=Z([s],()=>this.describe(n),{name:r,describeKind:"derived",meta:{domain:"audit",kind:"describe"},equals:(_,y)=>_===y})}catch(_){c(),l?.();for(let y of p)y();throw i.dispose(),_}let x=We(m);return{node:m,dispose(){d=!0,c(),l?.();for(let _ of p)_();p.length=0,i.dispose(),x()}}}_describeReactiveDiff(e){let n={...e,format:void 0,reactive:!1},r=e.reactiveName??"describe-diff",o={name:this.name,nodes:{},edges:[],subgraphs:[]},s=this.describe(n),i=xt(o,s),a=re(i,{name:r,meta:{domain:"audit",kind:"describe-diff"},equals:(h,f)=>h===f}),d=this._describeReactive({...e,format:void 0,reactiveName:void 0}),u=!1,c=d.node.subscribe(h=>{if(!u)for(let f of h){if(f[0]!==I)continue;let l=f[1],b=xt(s,l);s=l,b.events.length!==0&&a.emit(b)}}),p=We(a);return{node:a,dispose(){u=!0,c(),d.dispose(),a.down([[U,"describe-diff disposed"]]),p()}}}_explainReactive(e,n,r){let o=0,s=re(o,{name:"explain_version"}),i=this.observe({timeline:!0,structured:!0}),a=!1,d=!1,u=i.onEvent(f=>{let l=f.type;l!=="data"&&l!=="error"&&l!=="complete"&&l!=="teardown"||a||d||(a=!0,_e(()=>{a=!1,!d&&(o+=1,s.emit(o))}))}),c={...r?.maxDepth!=null?{maxDepth:r.maxDepth}:{},...r?.findCycle===!0?{findCycle:!0}:{}},p;try{p=Z([s],()=>this._explainStatic(e,n,c),{name:r?.name??"explain",describeKind:"derived",meta:{domain:"audit",kind:"explain_path",from:e,to:n},equals:(f,l)=>f.found===l.found&&f.reason===l.reason&&f.steps.length===l.steps.length&&Wr(f.steps,l.steps)})}catch(f){throw u(),i.dispose(),f}let h=We(p);return{node:p,dispose(){d=!0,u(),i.dispose(),h()}}}_pathsMatching(e){let n=Qe(e),r=[];return this._collectObserveTargets("",r),r.map(([o])=>o).filter(o=>n.test(o))}_collectObserveTargets(e,n){for(let r of[...this._mounts.keys()].sort()){let o=e===""?r:`${e}${F}${r}`;this._mounts.get(r)._collectObserveTargets(o,n)}for(let r of[...this._nodes.keys()].sort()){let o=this._nodes.get(r),s=e===""?r:`${e}${F}${r}`;n.push([s,o]),this._appendMetaObserveTargets(s,o,n)}}_appendMetaObserveTargets(e,n,r){for(let o of Object.keys(n.meta).sort()){let s=n.meta[o],i=`${e}${F}${se}${F}${o}`;r.push([i,s]),this._appendMetaObserveTargets(i,s,r)}}observe(e,n){let r=typeof e=="string",s=mn(r?n:e);if(s.reactive===!0)return this._observeReactive(r?e:void 0,s);let i=s.structured===!0||s.timeline===!0||s.causal===!0||s.derived===!0||s.detail==="minimal"||s.detail==="full"||s.format!=null,a=s.actor;if(r){let c=e,p=this.resolve(c);if(a!=null&&!p.allowsObserve(a))throw new te({actor:a,action:"observe",nodeName:c});return i?this._buildStructuredObserver([[c,p]],s,"one"):{subscribe(h){return p.subscribe(h)},up(h){try{p.up?.(h)}catch(f){if(f instanceof te)return;throw f}}}}let d=[];this._collectObserveTargets("",d),d.sort((c,p)=>c[0]<p[0]?-1:c[0]>p[0]?1:0);let u=a==null?d:d.filter(([,c])=>c.allowsObserve(a));return i?this._buildStructuredObserver(u,s,"all"):{subscribe:c=>{let p=u.map(([h,f])=>f.subscribe(l=>{c(h,l)}));return()=>{for(let h of p)h()}},up:(c,p)=>{try{this.resolve(c).up?.(p)}catch(h){if(h instanceof te)return;throw h}}}}_observeReactive(e,n){let r=n.tiers,o=r!=null?new Set(r):null,s=n.reactiveName??"observe";return _t(i=>{let a=[],d=!1,u=!1,c=()=>{if(a.length===0||u)return;let b={events:a.slice(),flushedAt_ns:de()};a.length=0,i.emit(b)},p={...n,reactive:!1,structured:!0,timeline:!0},h=e!=null?this.observe(e,p):this.observe(p),f=b=>{u||(a.push(b),!d&&(d=!0,_e(()=>{d=!1,c()})))};for(let b of h.events)f(b);let l=h.onEvent(f);return()=>{u=!0,l(),h.dispose()}},{name:s,meta:{domain:"audit",kind:"observe-reactive"}})}_buildStructuredObserver(e,n,r){let o=r==="one"?e[0]?.[0]:void 0,s=i=>{if(r==="one"&&o!=null){let c=this.resolve(o);return this._buildStructuredObserver([[o,c]],i,"one")}let a=[];this._collectObserveTargets("",a),a.sort((c,p)=>c[0]<p[0]?-1:c[0]>p[0]?1:0);let d=i.actor,u=d==null?a:a.filter(([,c])=>c.allowsObserve(d));return this._buildStructuredObserver(u,i,"all")};return this._createObserveResult(e,n,s)}_createObserveResult(e,n,r){let o=n.timeline===!0,s=n.causal===!0,i=n.derived===!0,a=n.detail==="minimal",d=this.config.inspectorEnabled,u=(s||i)&&d,c=n.maxEvents,p=c!=null&&c>0?new Ge(c):null,h=[],f=new Set,l=n.tiers!=null?new Set(n.tiers):null,b={},m=new Set,x=0,_=0,y=0,w=0,O=0,T=0,g=!1,v=!1,k=0,S=new Map,R=new Map,A=new Map,N=E=>{if(!(l!=null&&!l.has(E.type))){p?p.push(E):h.push(E);for(let P of f)P(E)}},D=E=>l==null||l.has(E),B=()=>o?{timestamp_ns:de(),in_batch:$e(),batch_id:k}:{},j=(E,P)=>{if(!(!u||!(E instanceof V)))return E._setInspectorHook(Q=>{if(Q.kind==="dep_message")S.set(E,Q.depIndex);else if(Q.kind==="run"){let Se=Q.batchData.map((L,q)=>L!=null&&L.length>0?L.at(-1):Q.prevData[q]);R.set(E,Se);let ee=Q.batchData.map(L=>L!=null?[...L]:void 0);A.set(E,ee),i&&N({type:"derived",path:P,dep_values:Se,dep_batches:ee,...B()})}})},ae=E=>{let P=S.get(E),Q=R.get(E);if(!s||Q==null)return{};let ee=(P!=null&&P>=0&&E instanceof V?E._deps[P]:void 0)?.node,L=ee?.v,q=A.get(E);return{trigger_dep_index:P,trigger_dep_name:ee?.name,...L!=null?{trigger_version:{id:L.id,version:L.version}}:{},dep_values:[...Q],...q!=null?{dep_batches:q}:{}}},tt=[],M=[];for(let[E,P]of e){let Q=j(P,E);Q&&tt.push(Q),M.push(P.subscribe(Se=>{k++;for(let ee of Se){let L=ee[0],q=B();if(L===I){b[E]=ee[1];let nt=P instanceof V?P.lastMutation?.actor??Oe:Oe;N({type:"data",path:E,data:ee[1],actor:nt,...q,...ae(P)})}else if(a)L===Y?D("dirty")&&x++:L===W?D("resolved")&&_++:L===ne?D("invalidate")&&y++:L===ie?D("pause")&&w++:L===fe?D("resume")&&O++:L===U?D("teardown")&&T++:L===K&&!m.has(E)?D("complete")&&(g=!0):L===$&&D("error")&&(v=!0,m.add(E));else if(L===Y)D("dirty")&&x++,N({type:"dirty",path:E,...q});else if(L===W)D("resolved")&&_++,N({type:"resolved",path:E,...q,...ae(P)});else if(L===ne)D("invalidate")&&y++,N({type:"invalidate",path:E,...q});else if(L===ie)D("pause")&&w++,N({type:"pause",path:E,lockId:ee[1],...q});else if(L===fe)D("resume")&&O++,N({type:"resume",path:E,lockId:ee[1],...q});else if(L===K)D("complete")&&!m.has(E)&&(g=!0),N({type:"complete",path:E,...q});else if(L===$){D("error")&&(v=!0,m.add(E));let nt=P instanceof V?P.lastMutation?.actor??Oe:Oe;N({type:"error",path:E,data:ee[1],actor:nt,...q})}else L===U&&(D("teardown")&&T++,N({type:"teardown",path:E,...q}))}}))}let G=!1,C=()=>{if(!G){G=!0;for(let E of M)E();for(let E of tt)E();for(let E of H)E({value:void 0,done:!0});H.length=0}},J=[],H=[];f.add(E=>{let P=H.shift();P?P({value:E,done:!1}):J.push(E)});let oe={get values(){return b},get dirtyCount(){return x},get resolvedCount(){return _},get invalidateCount(){return y},get pauseCount(){return w},get resumeCount(){return O},get teardownCount(){return T},get events(){return p?p.toArray():[...h]},get anyCompletedCleanly(){return g},get anyErrored(){return v},get completedWithoutErrors(){return g&&!v},onEvent(E){return f.add(E),()=>f.delete(E)},dispose:C,expand(E){C();let P={...n};return typeof E=="string"?P.detail=E:Object.assign(P,E),r(mn(P))},[Symbol.asyncIterator](){return{next(){return J.length>0?Promise.resolve({value:J.shift(),done:!1}):G?Promise.resolve({value:void 0,done:!0}):new Promise(E=>H.push(E))},return(){return C(),Promise.resolve({value:void 0,done:!0})}}}};return n.format!=null&&this._attachFormatLogger(oe,n),oe}_attachFormatLogger(e,n){let r=n.format;if(r==null)return;let o=n.logger??(l=>console.log(l)),s=n.includeTypes?new Set(n.includeTypes):null,i=n.excludeTypes?new Set(n.excludeTypes):null,a=s==null&&i==null?()=>!0:l=>(s==null||s.has(l))&&(i==null||!i.has(l)),d=Vr(n.theme),u=r==="stage-log"?de():0,c=l=>l==null?"":n.stageLabels?.[l]??l,p=(l,b)=>l.length>b?`${l.slice(0,b-1)}\u2026`:l,h=l=>l.type==="data"||l.type==="error"?p(et(l.data),120):"",f=l=>{if(r==="stage-log"){let g=(de()-u)/1e9,v=c(l.path).padEnd(9);if(l.type==="data"){let k=h(l);return`[${g.toFixed(3)}s] ${v} \u2190${k?` ${k}`:""}`}if(l.type==="error"){let k=h(l);return`[${g.toFixed(3)}s] ${v} \u2717${k?` ${k}`:""}`}return l.type==="complete"?`[${g.toFixed(3)}s] ${v} \u25A0 complete`:`[${g.toFixed(3)}s] ${v} ${l.type}`}if(r==="json")try{return JSON.stringify(l)}catch{return JSON.stringify({type:l.type,path:l.path,data:"[unserializable]"})}let b=d[l.type]??"",m=l.path?`${d.path}${l.path}${d.reset} `:"",x=l.type==="data"||l.type==="error",_=l.type==="pause"||l.type==="resume",y=x?` ${et(l.data)}`:_?` ${et(l.lockId)}`:"",w=l.type==="data"||l.type==="resolved"||l.type==="derived"?l:void 0,O=w?.trigger_dep_name!=null?` <- ${w.trigger_dep_name}`:w?.trigger_dep_index!=null?` <- #${w.trigger_dep_index}`:"",T=l.in_batch?" [batch]":"";return`${m}${b}${l.type.toUpperCase()}${d.reset}${y}${O}${T}`};e.onEvent(l=>{a(l.type)&&o(f(l),l)})}addDisposer(e){return this._disposers.add(e),()=>{this._disposers.delete(e)}}destroy(){hn(this._disposers,this.name),this.signal([[U]],{internal:!0}),hn(this._storageDisposers,this.name);for(let e of[...this._mounts.values()])e._parent=void 0,e._destroyClearOnly();this._mounts.clear(),this._nodes.clear(),this._parent=void 0,this._destroyed=!0}get destroyed(){return this._destroyed}_destroyClearOnly(){for(let e of[...this._mounts.values()])e._parent=void 0,e._destroyClearOnly();this._mounts.clear(),this._nodes.clear(),this._parent=void 0,this._destroyed=!0}snapshot(e){let{expand:n,...r}=this.describe({detail:"full"}),o={};for(let a of Object.keys(r.nodes).sort()){let{lastMutation:d,guard:u,...c}=r.nodes[a];o[a]=c}let s=[...r.subgraphs].sort(),i={...r,version:1,nodes:o,subgraphs:s};if(e?.format==null)return i;if(e.format==="json-string")return JSON.stringify(i);if(e.format==="bytes"){if(e.codec==null)throw new Error("snapshot({format: 'bytes'}) requires a `codec` name");let a=this.config.lookupCodec(e.codec);if(a==null)throw new Error(`snapshot: codec "${e.codec}" is not registered on this graph's config. Call config.registerCodec(...) before creating nodes.`);return Gt(a,a.encode(i))}throw new Error(`snapshot: unknown format "${String(e.format)}"`)}static decode(e,n){let r=n?.config??ke,{codec:o,codecVersion:s,payload:i}=Lt(e,r);return o.decode(i,s)}restore(e,n){if(gn(e),e.name!==this.name)throw new Error(`Graph "${this.name}": restore snapshot name "${e.name}" does not match this graph`);let r=n?.only==null?null:(Array.isArray(n.only)?n.only:[n.only]).map(s=>Qe(s)),o=n?.includeProducers===!0;for(let s of Object.keys(e.nodes).sort()){if(r!==null&&!r.some(a=>a.test(s)))continue;let i=e.nodes[s];if(i!==void 0){if(!("value"in i)||i.value===void 0){"value"in i&&i.value===void 0&&n?.onError?.(s,new Error(`restore: slice.value is undefined for "${s}" (undefined is the global SENTINEL; not valid DATA)`));continue}if(!(i.type==="derived"||i.type==="effect")&&!(i.type==="producer"&&!o)){if(i.v!=null){let d=this.tryResolve(s)?.v;if(d!=null&&d.id===i.v.id&&d.version===i.v.version)continue}try{this.set(s,i.value)}catch(a){n?.onError?.(s,a)}}}}}static fromSnapshot(e,n){gn(e);let r=typeof n=="function"?n:n?.build,o=typeof n=="function"?void 0:n?.factories,s=new t(e.name);if(r)return r(s),s.restore(e),s;for(let f of[...e.subgraphs].sort((l,b)=>{let m=l.split(F).length,x=b.split(F).length;return m!==x?m-x:l<b?-1:l>b?1:0})){let l=f.split(F),b=s;for(let m of l)b._mounts.has(m)||b.mount(m,new t(m)),b=b._mounts.get(m)}let i=o?Object.entries(o).map(([f,l])=>({re:Qe(f),factory:l})):[],a=f=>{for(let l of i)if(l.re.test(f))return l.factory},d=f=>{let l=f.split(F),b=l.pop();if(b==null||b.length===0)throw new Error(`invalid snapshot path "${f}"`);let m=s;for(let x of l){let _=m._mounts.get(x);if(!_)throw new Error(`unknown mount "${x}" in path "${f}"`);m=_}return[m,b]},u=Object.entries(e.nodes).filter(([f])=>!f.includes(`${F}${se}${F}`)).sort((f,l)=>f[0]<l[0]?-1:f[0]>l[0]?1:0),c=new Map(u),p=new Map,h=!0;for(;c.size>0&&h;){h=!1;for(let[f,l]of[...c.entries()]){let b=l?.deps??[];if(!b.every(O=>p.has(O)))continue;let[m,x]=d(f),_={...l?.meta??{}},y=a(f),w;if(l?.type==="state")w=re(l.value,{meta:_});else{if(y==null)continue;w=y(x,{path:f,type:l.type,value:l.value,meta:_,deps:b,resolvedDeps:b.map(O=>p.get(O))})}m.add(w,{name:x}),p.set(f,w),c.delete(f),h=!0}}if(c.size>0){let f=[...c.keys()].sort().join(", ");throw new Error(`Graph.fromSnapshot could not reconstruct nodes without build callback: ${f}. Pass matching factories via fromSnapshot(data, { factories: { pattern: factoryFn } }).`)}return s.restore(e),s}toJSON(){return this.snapshot()}attachSnapshotStorage(e,n={}){let r=e.map(u=>({tier:u,debounceMs:Math.max(0,u.debounceMs??0),compactEvery:Math.max(1,u.compactEvery??10),timer:void 0,seq:0,lastSnapshot:void 0,lastFingerprint:"",disposed:!1,savePending:void 0}));n.autoRestore===!0&&this._cascadeRestore(e,n.onError);let o=(u,c)=>{if(u.disposed)return;let p=Nr(c.nodes);if(u.lastSnapshot!=null&&p!==""&&p===u.lastFingerprint)return;let h=u.seq+1,f=le(),m=u.lastSnapshot==null||h%u.compactEvery===0?{name:this.name,mode:"full",snapshot:c,seq:h,timestamp_ns:f,format_version:Re}:{name:this.name,mode:"diff",diff:Hr(u.lastSnapshot,c),seq:h,timestamp_ns:f,format_version:Re};if(u.tier.filter&&!u.tier.filter(m))return;let x;try{x=u.tier.save(m)}catch(_){n.onError?.(_,u.tier);return}if(x&&typeof x.then=="function"){let w=(u.savePending??Promise.resolve()).then(()=>x,()=>x).then(()=>{u.disposed||(u.seq=h,u.lastSnapshot=c,u.lastFingerprint=p)},O=>{n.onError?.(O,u.tier)});u.savePending=w.finally(()=>{u.savePending===w&&(u.savePending=void 0)})}else u.seq=h,u.lastSnapshot=c,u.lastFingerprint=p},s=(u,c)=>{try{o(u,c)}catch(p){n.onError?.(p,u.tier)}},i=(u,c)=>{if(!c.some(l=>{let b=this.config.messageTier(l[0]);return b>=3&&b<5}))return;if(n.filter){let l=this.tryResolve(u);if(l==null)return;let b=yt(l,Be("standard"));if(!n.filter(u,b))return}let h,f=()=>(h==null&&(h=this.snapshot()),h);for(let l of r)l.disposed||(l.debounceMs===0?s(l,f()):(l.timer==null&&(l.timer=new Ue),l.timer.start(l.debounceMs,()=>{l.disposed||s(l,this.snapshot())})))},a;if(n.paths!=null){let c=(typeof n.paths=="string"?this._pathsMatching(n.paths):n.paths).map(p=>{let h=this.tryResolve(p);return h==null?()=>{}:h.subscribe(f=>i(p,f))});a=()=>{for(let p of c)p()}}else a=this.observe().subscribe((u,c)=>i(u,c));let d=()=>{a();for(let u of r)u.disposed=!0,u.timer?.cancel();this._storageDisposers.delete(d)};return this._storageDisposers.add(d),{dispose:d}}async _cascadeRestore(e,n){for(let r of e){let o;try{o=await r.load?.()}catch(i){n?.(i,r);continue}if(o==null||typeof o!="object"||Array.isArray(o))continue;let s=o;try{if(s.mode==="full"&&s.snapshot!=null)return this.restore(s.snapshot),!0;if(s.version===Re&&s.nodes!=null)return this.restore(s),!0}catch(i){n?.(i,r)}}return!1}static async fromStorage(e,n,r){for(let o of n){let s;try{s=await o.load?.()}catch(d){r?.onError?.(d,o);continue}if(s==null||typeof s!="object"||Array.isArray(s))continue;let i=s,a=i.mode==="full"&&i.snapshot!=null?i.snapshot:i.version===Re&&i.nodes!=null?i:void 0;if(a!=null)try{return t.fromSnapshot(a,r)}catch(d){r?.onError?.(d,o)}}throw new Error(`Graph.fromStorage: no tier held a restorable record for "${e}" across ${n.length} tier(s)`)}_annotations=new Map;_traceRing;trace(e,n,r){if(e!=null&&n!=null){if(this.tryResolve(e)==null)return;if(this._annotations.set(e,n),this.config.inspectorEnabled){let o={path:e,annotation:n,timestamp_ns:de(),...r?.actor!=null?{actor:r.actor}:{}};this._traceRing.push(o)}return}return e!=null?this.config.inspectorEnabled?this._annotations.get(e):void 0:this.config.inspectorEnabled?this._traceRing.toArray():[]}annotation(e){return this._annotations.get(e)}clearTrace(){this._annotations.clear(),this._traceRing.clear()}pruneTrace(e){let n=this._traceRing.toArray().filter(o=>!e(o)),r=this._traceRing.size-n.length;this._traceRing.clear();for(let o of n)this._traceRing.push(o);return r}static diff(e,n){let r=new Set(Object.keys(e.nodes)),o=new Set(Object.keys(n.nodes)),s=[...o].filter(_=>!r.has(_)).sort(),i=[...r].filter(_=>!o.has(_)).sort(),a=[],d=[];for(let _ of r){if(!o.has(_))continue;let y=e.nodes[_],w=n.nodes[_],O=y.v,T=w.v;O!=null&&T!=null&&O.id===T.id&&O.version!==T.version&&d.push({path:_,id:O.id,from:O.version,to:T.version});let g=O!=null&&T!=null&&O.id===T.id&&O.version===T.version;for(let v of["type","status","sentinel"]){let k=y[v],S=w[v];k!==S&&a.push({path:_,field:v,from:k,to:S})}if(!g)for(let v of["value","meta"]){let k=y[v],S=w[v];Er(k,S)||a.push({path:_,field:v,from:k,to:S})}}let u=_=>`${_.from} ${_.to}`,c=new Set(e.edges.map(u)),p=new Set(n.edges.map(u)),h=n.edges.filter(_=>!c.has(u(_))),f=e.edges.filter(_=>!p.has(u(_))),l=new Set(e.subgraphs),b=new Set(n.subgraphs),m=[...b].filter(_=>!l.has(_)).sort(),x=[...l].filter(_=>!b.has(_)).sort();return{nodesAdded:s,nodesRemoved:i,nodesChanged:a,versionChanges:d,edgesAdded:h,edgesRemoved:f,subgraphsAdded:m,subgraphsRemoved:x}}};function Hr(t,e){let n=Ne.diff(t,e),r={};for(let o of n.nodesAdded){let s=e.nodes[o];s!=null&&(r[o]=s)}return{...n,nodesAddedFull:r}}function bn(t,e,n,r={}){let o={paths:[],depths:new Map,truncated:!1};if(!e)return r.withDetail?o:[];if(!r.both&&n!=="upstream"&&n!=="downstream")throw new Error('reachable: direction must be "upstream" or "downstream"');let s=r.maxDepth;if(s!=null&&(!Number.isInteger(s)||s<0))throw new Error("reachable: maxDepth must be an integer >= 0");if(s===0)return r.withDetail?o:[];let i=new Map,a=new Map,d=new Map,u=new Map,c=new Set;for(let[y,w]of Object.entries(t.nodes)){if(!y)continue;c.add(y);let O=w.deps??[];i.set(y,O);for(let T of O)T&&(c.add(T),a.has(T)||a.set(T,new Set),a.get(T).add(y))}for(let y of t.edges){if(y==null||typeof y!="object")continue;let w=typeof y.from=="string"?y.from:"",O=typeof y.to=="string"?y.to:"";!w||!O||(c.add(w),c.add(O),u.has(w)||u.set(w,new Set),u.get(w).add(O),d.has(O)||d.set(O,new Set),d.get(O).add(w))}if(!c.has(e))return r.withDetail?o:[];let p=r.both===!0,h=y=>{if(p){let g=i.get(y)??[],v=d.get(y),k=a.get(y),S=u.get(y),R=[...g];return v&&R.push(...v),k&&R.push(...k),S&&R.push(...S),R}if(n==="upstream"){let g=i.get(y)??[],v=d.get(y);return v?[...g,...v]:g}let w=a.get(y),O=u.get(y),T=w?[...w]:[];return O&&T.push(...O),T},f=new Set([e]),l=new Map,b=[{path:e,depth:0}],m=0,x=!1;for(;m<b.length;){let y=b[m++];if(s!=null&&y.depth>=s){h(y.path).length>0&&(x=!0);continue}for(let w of h(y.path))!w||f.has(w)||(f.add(w),l.set(w,y.depth+1),b.push({path:w,depth:y.depth+1}))}let _=[...l.keys()].sort((y,w)=>y<w?-1:y>w?1:0);return r.withDetail?{paths:_,depths:l,truncated:x}:_}function Wr(t,e){if(t.length!==e.length)return!1;for(let n=0;n<t.length;n++){let r=t[n],o=e[n];if(r.path!==o.path||r.type!==o.type||r.status!==o.status||r.hop!==o.hop||r.dep_index!==o.dep_index||r.annotation!==o.annotation||r.value!==o.value||r.lastMutation!==o.lastMutation)return!1;let s=r.v,i=o.v;if(s!==i&&(s==null||i==null||s.id!==i.id||s.version!==i.version))return!1}return!0}we();xe();Me();me();we();me();be();He();var Rt=class{_version=0;_maxSize;_buf;_head=0;_size=0;constructor(e,n){if(n!==void 0&&n<1)throw new RangeError("maxSize must be >= 1");if(this._maxSize=n,n!==void 0){if(this._buf=new Array(n),e&&e.length>0){let r=Math.min(e.length,n),o=e.length-r;for(let s=0;s<r;s++)this._buf[s]=e[o+s];this._size=r}}else this._buf=e?[...e]:[],this._size=this._buf.length}get version(){return this._version}get size(){return this._size}at(e){if(!Number.isInteger(e))return;let n=e>=0?e:this._size+e;if(!(n<0||n>=this._size))return this._maxSize!==void 0?this._buf[(this._head+n)%this._maxSize]:this._buf[n]}append(e){this._rawAppend(e),this._version+=1}appendMany(e){if(e.length===0)return;let n=this._maxSize!==void 0&&e.length>this._maxSize?e.length-this._maxSize:0;for(let r=n;r<e.length;r++)this._rawAppend(e[r]);this._version+=1}clear(){if(this._size===0)return 0;let e=this._size;if(this._maxSize===void 0)this._buf.length=0;else for(let n=0;n<e;n++)this._buf[(this._head+n)%this._maxSize]=void 0;return this._head=0,this._size=0,this._version+=1,e}trimHead(e){if(!Number.isInteger(e)||e<0)throw new RangeError(`trimHead: n must be a non-negative integer (got ${e})`);if(e===0||this._size===0)return 0;let n=Math.min(e,this._size);if(this._maxSize===void 0)this._buf.splice(0,n);else{for(let r=0;r<n;r++)this._buf[(this._head+r)%this._maxSize]=void 0;this._head=(this._head+n)%this._maxSize}return this._size-=n,this._version+=1,n}slice(e,n){if(!Number.isInteger(e)||e<0)throw new RangeError(`slice: start must be a non-negative integer (got ${e})`);if(n!==void 0&&(!Number.isInteger(n)||n<0))throw new RangeError(`slice: stop must be a non-negative integer or undefined (got ${n})`);let r=n===void 0?this._size:Math.min(Math.max(n,0),this._size),o=Math.min(e,this._size);if(o>=r)return[];let s=r-o;if(this._maxSize===void 0)return this._buf.slice(o,r);let i=new Array(s);for(let a=0;a<s;a++)i[a]=this._buf[(this._head+o+a)%this._maxSize];return i}tail(e){if(!Number.isInteger(e)||e<0)throw new RangeError(`tail: n must be a non-negative integer (got ${e})`);if(e===0||this._size===0)return[];let n=Math.min(e,this._size);return this.slice(this._size-n,this._size)}toArray(){if(this._maxSize===void 0)return[...this._buf];let e=new Array(this._size);for(let n=0;n<this._size;n++)e[n]=this._buf[(this._head+n)%this._maxSize];return e}snapshot(){return this.toArray()}restore(e){if(this._maxSize===void 0){this._buf.length=0;for(let n=0;n<e.length;n++)this._buf.push(e[n]);this._size=this._buf.length}else{let n=this._maxSize;for(let s=0;s<n;s++)this._buf[s]=void 0;this._head=0;let r=Math.min(e.length,n),o=e.length-r;for(let s=0;s<r;s++)this._buf[s]=e[o+s];this._size=r}this._version+=1}_rawAppend(e){if(this._maxSize===void 0){this._buf.push(e),this._size=this._buf.length;return}this._size<this._maxSize?(this._buf[(this._head+this._size)%this._maxSize]=e,this._size+=1):(this._buf[this._head]=e,this._head=(this._head+1)%this._maxSize)}};function Le(t){return t.subscribe(()=>{})}var Ur=64;function Tn(t,e={}){let{name:n,maxSize:r,versioning:o,guard:s,backend:i}=e,a=i??new Rt(t,r),d=re(a.toArray(),{name:n,describeKind:"state",equals:(g,v)=>g===v,...o!=null?{versioning:o}:{},...s!=null?{guard:s}:{}});function u(){let g=a.toArray();ue(()=>{d.down([[Y]],{internal:!0}),d.down([[I,g]],{internal:!0})})}let c=new Map,p=new Map,h=new Map;function f(g,v){return`${g}:${v===void 0?"END":v}`}function l(g){if(g.size<Ur)return;let v=g.keys().next();if(v.done)return;let k=g.get(v.value);k!==void 0&&k.dispose(),g.delete(v.value)}function b(g){let v=a.version;try{return g()}finally{a.version!==v&&u()}}function m(g){if(!Number.isInteger(g)||g<0)throw new RangeError(`tail: n must be a non-negative integer (got ${g})`);let v=c.get(g);if(v!==void 0)return c.delete(g),c.set(g,v),v.node;l(c);let k=Z([d],([R])=>{let A=R;return g===0||A.length===0?[]:A.slice(Math.max(0,A.length-g))},{initial:a.tail(g),describeKind:"derived"}),S=Le(k);return c.set(g,{node:k,dispose:S}),k}function x(g,v){if(!Number.isInteger(g)||g<0)throw new RangeError(`slice: start must be a non-negative integer (got ${g})`);if(v!==void 0&&(!Number.isInteger(v)||v<0))throw new RangeError(`slice: stop must be a non-negative integer or undefined (got ${v})`);let k=f(g,v),S=p.get(k);if(S!==void 0)return p.delete(k),p.set(k,S),S.node;l(p);let R=Z([d],([N])=>{let D=N;return v===void 0?D.slice(g):D.slice(g,v)},{initial:a.slice(g,v),describeKind:"derived"}),A=Le(R);return p.set(k,{node:R,dispose:A}),R}function _(g){let v=h.get(g);if(v!==void 0)return v.node;let k=Z([d,g],([R,A])=>{let N=R,D=Math.max(0,Math.trunc(A??0));return N.slice(D)},{initial:[],describeKind:"derived"}),S=Le(k);return h.set(g,{node:k,dispose:S}),k}let y,w;function O(){y===void 0&&(y=ce([d],(g,v,k)=>{let S=g[0],A=S!=null&&S.length>0?S.at(-1):k.prevData[0];if(A==null||A.length===0){v.down([[W]]);return}v.emit(A[A.length-1])},{name:n!=null?`${n}::lastValue`:"lastValue",describeKind:"derived",initial:a.size===0?void 0:a.at(a.size-1)}),w=Z([d],([g])=>g.length>0,{name:n!=null?`${n}::hasLatest`:"hasLatest",describeKind:"derived",initial:a.size>0}),Le(y),Le(w))}let T={entries:d,get size(){return a.size},at(g){return a.at(g)},append(g){b(()=>a.append(g))},appendMany(g){g.length!==0&&b(()=>a.appendMany(g))},clear(){b(()=>a.clear())},trimHead(g){b(()=>a.trimHead(g))},withLatest(){return O(),d},get lastValue(){return O(),y},get hasLatest(){return O(),w},view(g){switch(g.kind){case"tail":return m(g.n);case"slice":return x(g.start,g.stop);case"fromCursor":return _(g.cursor)}},attach(g){let v=g.subscribe(k=>{for(let S of k)S[0]===I&&T.append(S[1])});return()=>v()},attachStorage(g){if(g.length===0)return()=>{};let v=new Map;for(let S of g)v.set(S,a.size);(async()=>{for(let S of g)if(typeof S.loadEntries=="function")try{let R=await Promise.resolve(S.loadEntries());R.entries.length>0&&a.size===0&&(a.restore(R.entries),v.set(S,R.entries.length),u());break}catch{}})();let k=d.subscribe(S=>{for(let R of S){if(R[0]!==I)continue;let A=R[1];for(let N of g){let D=v.get(N)??0;if(A.length<D){try{let j=N.appendEntries(A);j instanceof Promise&&j.catch(()=>{})}catch{}v.set(N,A.length);continue}if(A.length===D)continue;let B=A.slice(D);v.set(N,A.length);try{let j=N.appendEntries(B);j instanceof Promise&&j.catch(()=>{})}catch{}}}});return()=>k()},disposeAllViews(){for(let g of c.values())g.dispose();c.clear();for(let g of p.values())g.dispose();p.clear();for(let g of h.values())g.dispose();h.clear()},dispose(){for(let g of c.values())g.dispose();c.clear();for(let g of p.values())g.dispose();p.clear();for(let g of h.values())g.dispose();h.clear()}};return T}var Kr=Ct((t,e)=>{t("observe"),t("signal"),e("write")});function kn(t){let e=Tn([],{name:t.name,maxSize:t.retainedLimit??1024,guard:t.guard??Kr,...t.versioning!=null?{versioning:t.versioning}:{}});return e.withLatest(),t.graph&&t.graph.add(e.entries,{name:t.name}),e}function Rn(t){if(t===null||typeof t!="object"||Object.isFrozen(t))return t;for(let e of Object.keys(t))Rn(t[e]);return Object.freeze(t)}function qr(t){let e=t.cache,r=(typeof e=="number"&&Number.isFinite(e)?e:0)+1;return t.down([[Y],[I,r]]),r}function On(t,e,n,r,o,s){let i=e(n,r,o);if(i===void 0)return;let a=s!=null?{...i,handlerVersion:s}:i;t.append(a)}function Ee(t,e){let n=e.freeze??!0;return function(...o){let s=n?o.map(Rn):o,i=le(),a,d,u=!1,c;try{ue(()=>{e.seq&&(c=qr(e.seq));try{a=t(...s),e.onSuccess&&On(e.audit,e.onSuccess,s,a,{t_ns:i,seq:c},e.handlerVersion)}catch(p){throw d=p,u=!0,p}})}catch(p){if(u&&e.onFailure){let h=d instanceof Error?d.name:typeof d;On(e.audit,e.onFailure,s,d,{t_ns:i,seq:c,errorType:h},e.handlerVersion)}throw u?d:p}return a}}function Nn(t,e,n){return{[t]:!0,[`${t}_type`]:e,...n??{}}}function Ie(t,e){return Nn("orchestration",t,e)}var En=t=>t.action,Pe=class extends Ne{constructor(e,n){super(e,n)}task(e,n,r={}){let o=(r.deps??[]).map(i=>this._resolveStep(i)),s=Z(o,n,{name:e,describeKind:"derived",meta:Ie("task",r.meta)});return this.add(s,{name:e}),s}classify(e,n,r,o={}){let s=this._resolveStep(n),i=Z([s],([a])=>{try{return{tag:r(a),value:a}}catch(d){return{tag:"error",value:a,error:d}}},{name:e,describeKind:"derived",meta:Ie("classify",o.meta)});return this.add(i,{name:e}),i}combine(e,n,r={}){let o=Object.keys(n),s=o.map(a=>this._resolveStep(n[a])),i=Z(s,a=>{let d={};for(let u=0;u<o.length;u++)d[o[u]]=a[u];return d},{name:e,describeKind:"derived",meta:Ie("combine",r.meta)});return this.add(i,{name:e}),i}gate(e,n,r={}){let o=r.maxPending??1e3;if(o<1&&o!==Number.POSITIVE_INFINITY)throw new RangeError("gate: maxPending must be >= 1");let s=r.startOpen??!1;typeof n!="string"&&this.nameOf(n)===void 0&&this.add(n,{name:`${e}/source`});let i=this._resolveStep(n),a=new Ne(`${e}_state`),d=re([],{name:"pending",equals:()=>!1}),u=re(s,{name:"isOpen"}),c=Z([d],([M])=>M.length,{name:"count"}),p=re(0,{name:"droppedCount"}),h=kn({name:"decisions",retainedLimit:1024,graph:a});a.add(d,{name:"pending"}),a.add(u,{name:"isOpen"}),a.add(c,{name:"count"}),a.add(p,{name:"droppedCount"}),this.mount(`${e}_state`,a);let f=[],l=!1,b=!1,m=s,x=u.subscribe(M=>{for(let G of M)G[0]===I&&(m=G[1])});this.addDisposer(x);function _(){d.emit([...f])}function y(M,G,C){h.append({action:M,t_ns:le(),...G!==void 0?{items:G,count:G.length}:{},...C!==void 0?{unflushed:C}:{},...r.handlerVersion!=null?{handlerVersion:r.handlerVersion}:{}})}function w(M){if(f.push(M),f.length>o){let G=f.shift();p.emit(p.cache+1),y("drop",[G])}_()}function O(M){let G=f.splice(0,M);return _(),G}let T=ce([i],(M,G,C)=>{let J=C.terminalDeps[0];if(J!==void 0){l=!0;let oe=f.length;f=[],_(),y("teardown",void 0,oe),G.down(J===!0?[[K]]:[[$,J]]);return}let H=M[0];if(H==null||H.length===0){G.down([[W]]);return}for(let oe of H)m?G.emit(oe):(w(oe),G.down([[W]]))},{name:e,describeKind:"derived",meta:Ie("gate",r.meta)});if(this.add(T,{name:e}),r.approver!=null){r.approver.cache&&(u.emit(!0),m=!0,r.onceOnly&&(b=!0));let G=r.approver.subscribe(C=>{for(let J of C){if(J[0]!==I)continue;let H=!!J[1];if(H&&!m){if(r.onceOnly){if(b)continue;b=!0}ue(()=>{u.emit(!0);let oe=O(f.length);y("open",oe);for(let E of oe){if(l)break;T.emit(E)}})}else if(!H&&m){if(r.onceOnly&&b)continue;ue(()=>{u.emit(!1),y("close")})}}});this.addDisposer(G)}let g=M=>{if(l)throw new Error(`gate: ${M}() called after gate was torn down`)},v=(M=1)=>{g("approve");let G=O(M);for(let C of G){if(l)break;T.emit(C)}},k=(M=1)=>{g("reject"),O(M)},S=(M,G=1)=>{g("modify");let C=[...f],J=O(G);for(let H=0;H<J.length&&!l;H++)T.emit(M(J[H],H,C))},R=()=>{g("open"),u.emit(!0);let M=O(f.length);for(let G of M){if(l)break;T.emit(G)}},A=()=>{g("close"),!(r.onceOnly&&b)&&u.emit(!1)},N=Ee(v,{audit:h,freeze:!1,onSuccess:(M,G,C)=>({action:"approve",count:M[0]??1,t_ns:C.t_ns,...r.handlerVersion!=null?{handlerVersion:r.handlerVersion}:{}}),onFailure:(M,G,C)=>({action:"drop",t_ns:C.t_ns,errorType:C.errorType,...r.handlerVersion!=null?{handlerVersion:r.handlerVersion}:{}})}),D=Ee(k,{audit:h,freeze:!1,onSuccess:(M,G,C)=>({action:"reject",count:M[0]??1,t_ns:C.t_ns,...r.handlerVersion!=null?{handlerVersion:r.handlerVersion}:{}}),onFailure:(M,G,C)=>({action:"drop",t_ns:C.t_ns,errorType:C.errorType,...r.handlerVersion!=null?{handlerVersion:r.handlerVersion}:{}})}),B=Ee(S,{audit:h,freeze:!1,onSuccess:(M,G,C)=>({action:"modify",count:M[1]??1,t_ns:C.t_ns,...r.handlerVersion!=null?{handlerVersion:r.handlerVersion}:{}}),onFailure:(M,G,C)=>({action:"drop",t_ns:C.t_ns,errorType:C.errorType,...r.handlerVersion!=null?{handlerVersion:r.handlerVersion}:{}})}),j=Ee(R,{audit:h,freeze:!1,onSuccess:(M,G,C)=>({action:"open",t_ns:C.t_ns,...r.handlerVersion!=null?{handlerVersion:r.handlerVersion}:{}}),onFailure:(M,G,C)=>({action:"drop",t_ns:C.t_ns,errorType:C.errorType,...r.handlerVersion!=null?{handlerVersion:r.handlerVersion}:{}})}),ae=Ee(A,{audit:h,freeze:!1,onSuccess:(M,G,C)=>({action:"close",t_ns:C.t_ns,...r.handlerVersion!=null?{handlerVersion:r.handlerVersion}:{}}),onFailure:(M,G,C)=>({action:"drop",t_ns:C.t_ns,errorType:C.errorType,...r.handlerVersion!=null?{handlerVersion:r.handlerVersion}:{}})});return this.addDisposer(c.subscribe(()=>{})),{node:T,pending:d,count:c,isOpen:u,droppedCount:p,decisions:h,audit:h,approve:N,reject:D,modify:B,open:j,close:ae}}approval(e,n,r,o={}){return this.gate(e,n,{...o,approver:r,maxPending:1})}catch(e,n,r,o={}){let s=this._resolveStep(n),i=o.on??"error",a=ce([s],(d,u,c)=>{let p=c.terminalDeps[0];if(p!==void 0){let f=p===!0?{kind:"complete"}:{kind:"error",error:p};if(i==="terminal"||i===f.kind){u.emit(r(f,u));return}u.down(f.kind==="complete"?[[K]]:[[$,f.error]]);return}let h=d[0];if(h==null||h.length===0){u.down([[W]]);return}for(let f of h)u.emit(f)},{name:e,describeKind:"derived",completeWhenDepsComplete:o.completeWhenDepsComplete??!(i==="complete"||i==="terminal"),errorWhenDepsError:!(i==="error"||i==="terminal"),meta:Ie("catch",o.meta)});return this.add(a,{name:e}),a}_resolveStep(e){if(typeof e=="string")return this.resolve(e);if(this.nameOf(e)===void 0)throw new Error(`PipelineGraph "${this.name}": Node dep is not registered. Pass a string path or call graph.add(node) first.`);return e}};function Sn(t,e){let n=new Pe(t,e),{factory:r,factoryArgs:o,...s}=e??{};return n.tagFactory("pipelineGraph",Wt(s)),n}0&&(module.exports={PipelineGraph,decisionKeyOf,pipelineGraph});
|
|
@@ -1,9 +1,9 @@
|
|
|
1
|
-
export { C as CatchOptions, a as ClassifyResult, D as Decision, b as DecisionAction, G as GateController, c as GateOptions, P as PipelineGraph, S as StepRef, T as TerminalCause, d as decisionKeyOf, p as pipelineGraph } from '../../pipeline-graph-
|
|
1
|
+
export { C as CatchOptions, a as ClassifyResult, D as Decision, b as DecisionAction, G as GateController, c as GateOptions, P as PipelineGraph, S as StepRef, T as TerminalCause, d as decisionKeyOf, p as pipelineGraph } from '../../pipeline-graph-DuHpXSOn.cjs';
|
|
2
2
|
import '../../node-fSc-hCv8.cjs';
|
|
3
3
|
import '../../sugar-DgaGJcI6.cjs';
|
|
4
|
-
import '../../reactive-log-
|
|
4
|
+
import '../../reactive-log-C3IMAGpT.cjs';
|
|
5
5
|
import '../../extra/storage-tiers.cjs';
|
|
6
|
-
import '../../graph-
|
|
7
|
-
import '../../meta-
|
|
6
|
+
import '../../graph-CHsVwf9S.cjs';
|
|
7
|
+
import '../../meta-DreaEM_a.cjs';
|
|
8
8
|
import '../../extra/storage-core.cjs';
|
|
9
9
|
import '../../imperative-audit-ahAE65a9.cjs';
|
|
@@ -1,9 +1,9 @@
|
|
|
1
|
-
export { C as CatchOptions, a as ClassifyResult, D as Decision, b as DecisionAction, G as GateController, c as GateOptions, P as PipelineGraph, S as StepRef, T as TerminalCause, d as decisionKeyOf, p as pipelineGraph } from '../../pipeline-graph-
|
|
1
|
+
export { C as CatchOptions, a as ClassifyResult, D as Decision, b as DecisionAction, G as GateController, c as GateOptions, P as PipelineGraph, S as StepRef, T as TerminalCause, d as decisionKeyOf, p as pipelineGraph } from '../../pipeline-graph-9JBbmRxA.js';
|
|
2
2
|
import '../../node-fSc-hCv8.js';
|
|
3
3
|
import '../../sugar-D13E2M_z.js';
|
|
4
|
-
import '../../reactive-log-
|
|
4
|
+
import '../../reactive-log-BgWSA1fg.js';
|
|
5
5
|
import '../../extra/storage-tiers.js';
|
|
6
|
-
import '../../graph-
|
|
7
|
-
import '../../meta-
|
|
6
|
+
import '../../graph-BjW1taJl.js';
|
|
7
|
+
import '../../meta-BYqlATmg.js';
|
|
8
8
|
import '../../extra/storage-core.js';
|
|
9
9
|
import '../../imperative-audit-ahAE65a9.js';
|
|
@@ -1 +1 @@
|
|
|
1
|
-
import{a,b,c}from"../../chunk-
|
|
1
|
+
import{a,b,c}from"../../chunk-QOJFR6GS.js";import"../../chunk-NN3QPJ6U.js";import"../../chunk-O32GJOUJ.js";import"../../chunk-QMC2PLNM.js";import"../../chunk-SGS4OJGS.js";import"../../chunk-ESMPEKEV.js";import"../../chunk-DQJLC6YY.js";import"../../chunk-7KZZLWZ6.js";import"../../chunk-RZ5HKPGI.js";import"../../chunk-LYCLF26R.js";import"../../chunk-CK2E7BTU.js";import"../../chunk-QYADASLV.js";export{b as PipelineGraph,a as decisionKeyOf,c as pipelineGraph};
|