@graphrefly/graphrefly 0.36.0 → 0.37.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-PYEIPRSZ.js → chunk-2C4NESZE.js} +1 -1
- package/dist/{chunk-44QWWUA3.js → chunk-4EATTNAE.js} +1 -1
- package/dist/{chunk-5RTZ6DXG.js → chunk-6SVKZ7VI.js} +1 -1
- package/dist/chunk-B4L5X2QO.js +7 -0
- package/dist/{chunk-TQSTS3BY.js → chunk-C5CBVOCB.js} +1 -1
- package/dist/{chunk-J6TGRQUP.js → chunk-CZIQ6JCE.js} +1 -1
- package/dist/chunk-FJ6IEMOS.js +1 -0
- package/dist/{chunk-5Z3AFBN7.js → chunk-FMI4CWFL.js} +1 -1
- package/dist/{chunk-DBPFMCVH.js → chunk-G6Q3DUMJ.js} +1 -1
- package/dist/{chunk-3U7IIQB2.js → chunk-GDDPCDLG.js} +1 -1
- package/dist/{chunk-5CZ3KIRJ.js → chunk-GFOT6UBB.js} +1 -1
- package/dist/{chunk-KL7CILPL.js → chunk-K2WYIVHM.js} +1 -1
- package/dist/{chunk-I57VSGRB.js → chunk-K6ZFJ473.js} +1 -1
- package/dist/{chunk-YBA5N4XY.js → chunk-KTWBUJO5.js} +1 -1
- package/dist/{chunk-7LYIKMW5.js → chunk-LOQRPP4Y.js} +1 -1
- package/dist/{chunk-KCE6WWJE.js → chunk-MC5LZG3U.js} +1 -1
- package/dist/{chunk-N2GCKKKH.js → chunk-NKKUUKPD.js} +1 -1
- package/dist/{chunk-GWOKTENT.js → chunk-QKBCTKH7.js} +1 -1
- package/dist/{chunk-YOUAVGHJ.js → chunk-QP5TH523.js} +1 -1
- package/dist/{chunk-T6RPUERH.js → chunk-QWVQIL3T.js} +1 -1
- package/dist/{chunk-6G5YD37E.js → chunk-T4U24DXX.js} +1 -1
- package/dist/{chunk-AACJX2L7.js → chunk-TFK4P4CX.js} +1 -1
- package/dist/{chunk-K5ZXJPWU.js → chunk-TLS7M7H4.js} +1 -1
- package/dist/{chunk-AQC53OWG.js → chunk-U3COB5WU.js} +1 -1
- package/dist/{chunk-F36TA3ET.js → chunk-UODQF4EY.js} +1 -1
- package/dist/{chunk-QKUWS7CO.js → chunk-WGST56ZH.js} +1 -1
- package/dist/{chunk-XINLP35X.js → chunk-WSLN4JFO.js} +1 -1
- package/dist/{chunk-LO3LO2TO.js → chunk-XIJKEXWR.js} +1 -1
- package/dist/{chunk-JUJEPZOI.js → chunk-YVYSO5CW.js} +1 -1
- package/dist/compat/index.cjs +9 -9
- package/dist/compat/index.d.cts +5 -5
- package/dist/compat/index.d.ts +5 -5
- package/dist/compat/index.js +1 -1
- package/dist/compat/nestjs/index.cjs +11 -11
- package/dist/compat/nestjs/index.d.cts +3 -3
- package/dist/compat/nestjs/index.d.ts +3 -3
- package/dist/compat/nestjs/index.js +1 -1
- package/dist/compat/zustand/index.cjs +7 -7
- package/dist/compat/zustand/index.d.cts +2 -2
- package/dist/compat/zustand/index.d.ts +2 -2
- package/dist/compat/zustand/index.js +1 -1
- package/dist/extra/index.cjs +15 -15
- package/dist/extra/index.d.cts +2 -2
- package/dist/extra/index.d.ts +2 -2
- package/dist/extra/index.js +1 -1
- package/dist/graph/index.cjs +7 -7
- package/dist/graph/index.d.cts +3 -3
- package/dist/graph/index.d.ts +3 -3
- package/dist/graph/index.js +1 -1
- package/dist/{graph-kTltt95s.d.cts → graph-CaNXUc3c.d.cts} +26 -1
- package/dist/{graph-Cv-8x0ZI.d.ts → graph-YQXDndFy.d.ts} +26 -1
- package/dist/{index-CVhBdCMf.d.ts → index-0qOD-421.d.ts} +2 -2
- package/dist/{index-BC-xjOrd.d.cts → index-4IwO4mH2.d.cts} +5 -5
- package/dist/{index-kBUQj-rT.d.ts → index-9mbs_PIG.d.ts} +1 -1
- package/dist/{index-DSSsxS7B.d.ts → index-Ae6L8liv.d.ts} +2 -2
- package/dist/{index-BhkPzu-Z.d.cts → index-B1IcU--K.d.cts} +2 -2
- package/dist/{index-jA_OwwNg.d.ts → index-B46GWgk3.d.ts} +1 -1
- package/dist/{index-EfPb77rT.d.cts → index-B9qJmmv3.d.cts} +1 -1
- package/dist/{index-CI_yjtua.d.ts → index-BCq12BqB.d.ts} +1 -1
- package/dist/{index-2URa-V4S.d.cts → index-BECJ8M0T.d.cts} +1 -1
- package/dist/{index-DFe2Pk2u.d.ts → index-BOfHwQc1.d.ts} +1 -1
- package/dist/{index-BTJxM-wZ.d.ts → index-BhLA9feT.d.ts} +1 -1
- package/dist/{index-Pu1Wa7en.d.ts → index-BmLkcDlj.d.ts} +5 -5
- package/dist/{index-XxSeddWP.d.cts → index-BokynmA4.d.cts} +1 -1
- package/dist/{index-DtSVSKnd.d.ts → index-Bpzw8hx3.d.ts} +1 -1
- package/dist/{index-PluovH45.d.cts → index-BwtIbzSV.d.cts} +2 -2
- package/dist/{index-BZ1V5GzX.d.ts → index-C-pFD_FV.d.ts} +2 -2
- package/dist/{index-Cot94_82.d.ts → index-C0tga1_x.d.ts} +2 -2
- package/dist/{index-BlRVj-7Q.d.cts → index-C4N-dg5U.d.cts} +2 -2
- package/dist/{index-B4s70vYf.d.ts → index-CKcnuQ2c.d.ts} +2 -2
- package/dist/{index-HCp5ua_i.d.cts → index-CLPQyYY5.d.cts} +3 -3
- package/dist/{index-BuMzxRO2.d.ts → index-CRycrNfn.d.ts} +1 -1
- package/dist/{index-CvUrRb4m.d.cts → index-CU3z8Cel.d.cts} +2 -2
- package/dist/{index-CZAixNU3.d.ts → index-CUTHDZ7Q.d.ts} +3 -3
- package/dist/{index-DzCQt2FJ.d.cts → index-C_qi0WlF.d.cts} +1 -1
- package/dist/{index-BBdwz2BW.d.ts → index-CajEOoAN.d.ts} +2 -2
- package/dist/{index-BVNGEX7d.d.cts → index-Ci358GSC.d.cts} +2 -2
- package/dist/{index-DHv2M7s8.d.cts → index-CkN8CZlT.d.cts} +5 -5
- package/dist/{index-ZhKyR8co.d.cts → index-CrpjECS6.d.cts} +2 -2
- package/dist/{index-isdlyeeO.d.ts → index-CzIWlnPp.d.ts} +5 -5
- package/dist/{index-DxxvGTXp.d.ts → index-D0ZxFXYl.d.ts} +1 -1
- package/dist/{index-k67aNfqC.d.cts → index-D11pGlaI.d.cts} +2 -2
- package/dist/{index-DlccEIi3.d.ts → index-D1E1tqHT.d.ts} +1 -1
- package/dist/{index-Cjrpx2Mg.d.cts → index-D6pwWiOc.d.cts} +1 -1
- package/dist/{index-BsZlbHM5.d.cts → index-D6tRNEKz.d.cts} +1 -1
- package/dist/{index-33mF4XyU.d.cts → index-DAKm44My.d.cts} +1 -1
- package/dist/{index-BWH17rK_.d.cts → index-DCAuN9u5.d.cts} +1 -1
- package/dist/{index-CsD0fqnO.d.ts → index-DPqR3wdW.d.ts} +2 -2
- package/dist/{index-GaW6Welt.d.cts → index-DTYIRT_v.d.cts} +2 -2
- package/dist/{index-DXSLMoma.d.ts → index-DXz9uwcs.d.ts} +1 -1
- package/dist/{index-DmtWMP0X.d.cts → index-D_DThl_J.d.cts} +1 -1
- package/dist/{index-BwYGLgmI.d.ts → index-D_d1erkR.d.ts} +2 -2
- package/dist/{index-D9qoEOj_.d.cts → index-DbWwMWiB.d.cts} +1 -1
- package/dist/{index-C4ig7whw.d.cts → index-DcWbx58m.d.cts} +2 -2
- package/dist/{index-DzYTXMBz.d.ts → index-DfAo9WKr.d.ts} +1 -1
- package/dist/{index-RJIY7QVW.d.cts → index-DqtXA3yX.d.cts} +1 -1
- package/dist/{index-KeBhbNg3.d.ts → index-DuhOdNyg.d.ts} +1 -1
- package/dist/{index-DKp1CIbG.d.cts → index-e1m3ZHgc.d.cts} +1 -1
- package/dist/{index-DLyQC5Ww.d.ts → index-fHKHdAso.d.ts} +2 -2
- package/dist/index.cjs +41 -41
- package/dist/index.d.cts +28 -28
- package/dist/index.d.ts +28 -28
- package/dist/index.js +1 -1
- package/dist/patterns/ai/index.cjs +19 -19
- package/dist/patterns/ai/index.d.cts +6 -6
- package/dist/patterns/ai/index.d.ts +6 -6
- package/dist/patterns/ai/index.js +1 -1
- package/dist/patterns/audit/index.cjs +7 -7
- package/dist/patterns/audit/index.d.cts +3 -3
- package/dist/patterns/audit/index.d.ts +3 -3
- package/dist/patterns/audit/index.js +1 -1
- package/dist/patterns/cqrs/index.cjs +7 -7
- package/dist/patterns/cqrs/index.d.cts +2 -2
- package/dist/patterns/cqrs/index.d.ts +2 -2
- 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 +3 -3
- package/dist/patterns/demo-shell/index.d.ts +3 -3
- 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 +2 -2
- package/dist/patterns/domain-templates/index.d.ts +2 -2
- package/dist/patterns/domain-templates/index.js +1 -1
- package/dist/patterns/graphspec/index.cjs +17 -17
- package/dist/patterns/graphspec/index.d.cts +2 -2
- package/dist/patterns/graphspec/index.d.ts +2 -2
- 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 +4 -4
- package/dist/patterns/guarded-execution/index.d.ts +4 -4
- package/dist/patterns/guarded-execution/index.js +1 -1
- package/dist/patterns/harness/index.cjs +10 -10
- package/dist/patterns/harness/index.d.cts +6 -6
- package/dist/patterns/harness/index.d.ts +6 -6
- 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 +2 -2
- package/dist/patterns/job-queue/index.d.ts +2 -2
- package/dist/patterns/job-queue/index.js +1 -1
- package/dist/patterns/lens/index.cjs +7 -7
- package/dist/patterns/lens/index.d.cts +3 -3
- package/dist/patterns/lens/index.d.ts +3 -3
- package/dist/patterns/lens/index.js +1 -1
- package/dist/patterns/memory/index.cjs +7 -7
- package/dist/patterns/memory/index.d.cts +2 -2
- package/dist/patterns/memory/index.d.ts +2 -2
- package/dist/patterns/memory/index.js +1 -1
- package/dist/patterns/messaging/index.cjs +7 -7
- package/dist/patterns/messaging/index.d.cts +2 -2
- package/dist/patterns/messaging/index.d.ts +2 -2
- package/dist/patterns/messaging/index.js +1 -1
- package/dist/patterns/orchestration/index.cjs +7 -7
- package/dist/patterns/orchestration/index.d.cts +2 -2
- package/dist/patterns/orchestration/index.d.ts +2 -2
- package/dist/patterns/orchestration/index.js +1 -1
- package/dist/patterns/process/index.cjs +1 -1
- package/dist/patterns/process/index.d.cts +3 -3
- package/dist/patterns/process/index.d.ts +3 -3
- 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 +3 -3
- package/dist/patterns/reactive-layout/index.d.ts +3 -3
- package/dist/patterns/reactive-layout/index.js +1 -1
- package/dist/patterns/reduction/index.cjs +7 -7
- package/dist/patterns/reduction/index.d.cts +2 -2
- package/dist/patterns/reduction/index.d.ts +2 -2
- 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 +3 -3
- package/dist/patterns/refine-loop/index.d.ts +3 -3
- package/dist/patterns/refine-loop/index.js +1 -1
- package/dist/patterns/resilient-pipeline/index.d.cts +3 -3
- package/dist/patterns/resilient-pipeline/index.d.ts +3 -3
- package/dist/patterns/resilient-pipeline/index.js +1 -1
- package/dist/patterns/surface/index.cjs +10 -10
- package/dist/patterns/surface/index.d.cts +3 -3
- package/dist/patterns/surface/index.d.ts +3 -3
- package/dist/patterns/surface/index.js +1 -1
- package/dist/{pipeline-graph-BlLBWSZ2.d.cts → pipeline-graph-BrrYGjuZ.d.cts} +1 -1
- package/dist/{pipeline-graph-DdBoRu37.d.ts → pipeline-graph-DX2Twdj-.d.ts} +1 -1
- package/dist/{reactive-layout-Btv0-efV.d.ts → reactive-layout-BDdngW56.d.ts} +1 -1
- package/dist/{reactive-layout-D9zqqaqK.d.cts → reactive-layout-DrGjuwyC.d.cts} +1 -1
- package/dist/{topology-tree-CJsT24DP.d.ts → topology-tree-BI665P0L.d.ts} +1 -1
- package/dist/{topology-tree-C50l9ARE.d.cts → topology-tree-BkhmMg2a.d.cts} +1 -1
- package/package.json +1 -1
- package/dist/chunk-5KPIYVCC.js +0 -7
- package/dist/chunk-CGA5RXO6.js +0 -1
|
@@ -1,7 +1,7 @@
|
|
|
1
|
-
"use strict";var ut=Object.defineProperty;var Mn=Object.getOwnPropertyDescriptor;var Dn=Object.getOwnPropertyNames;var Cn=Object.prototype.hasOwnProperty;var Y=(t,e)=>()=>(t&&(e=t(t=0)),e);var Gn=(t,e)=>{for(var n in e)ut(t,n,{get:e[n],enumerable:!0})},Ln=(t,e,n,r)=>{if(e&&typeof e=="object"||typeof e=="function")for(let s of Dn(e))!Cn.call(t,s)&&s!==n&&ut(t,s,{get:()=>e[s],enumerable:!(r=Mn(e,s))||r.enumerable});return t};var In=t=>Ln(ut({},"__esModule",{value:!0}),t);function te(){return Math.trunc(performance.now()*1e6)}function ne(){return Date.now()*1e6}var Ne=Y(()=>{"use strict"});function Le(t){if(t==null)return _e;let{type:e,id:n,...r}=t;return{type:e??"system",id:n??"",...r}}var _e,Ie=Y(()=>{"use strict";_e={type:"system",id:""}});function Se(){return we>0||ke}function At(){return we>0}function Ae(t){we>0?Re.push(t):t()}function K(t){we+=1;let e=!1;try{t()}catch(n){throw e=!0,n}finally{if(we-=1,we===0)if(e){if(!ke){let n=Re.splice(0);for(let r of n)try{r()}catch{}ce.length=0,fe.length=0,xe.length=0}}else Pn()}}function Pn(){let t=!ke;t&&(ke=!0);let e=[],n=0;try{for(;ce.length>0||fe.length>0||xe.length>0||t&&Re.length>0;){if(t&&Re.length>0){let o=Re.splice(0);for(let i of o)try{i()}catch(a){e.push(a)}continue}if(n+=1,n>1e3)throw ce.length=0,fe.length=0,xe.length=0,new Error("batch drain exceeded 1000 iterations \u2014 likely a reactive cycle");let s=(ce.length>0?ce:fe.length>0?fe:xe).splice(0);for(let o of s)try{o()}catch(i){e.push(i)}}}finally{t&&(ke=!1)}if(e.length===1)throw e[0];if(e.length>1)throw new AggregateError(e,"batch drain: multiple callbacks threw")}function Me(t,e,n){if(e.length===0)return;if(e.length===1){let u=n(e[0][0]);if(u<3||!Se()){t(e);return}(u>=5?xe:u===4?fe:ce).push(()=>t(e));return}let r=e.length,s=r,o=r,i=r,a=0;for(;a<r&&n(e[a][0])<3;)a++;for(s=a;a<r&&n(e[a][0])===3;)a++;for(o=a;a<r&&n(e[a][0])===4;)a++;i=a;let d=Se();if(s>0){let u=e.slice(0,s);t(u)}if(o>s){let u=e.slice(s,o);d?ce.push(()=>t(u)):t(u)}if(i>o){let u=e.slice(o,i);d?fe.push(()=>t(u)):t(u)}if(r>i){let u=e.slice(i,r);d?xe.push(()=>t(u)):t(u)}}var we,ke,ce,fe,xe,Re,pe=Y(()=>{"use strict";we=0,ke=!1,ce=[],fe=[],xe=[],Re=[]});var he,G,F,q,Q,re,se,B,z,C,ge,Pe,Mt,$e,Dt,Ct,Fe,dt,lt,ct,Ve,oe=Y(()=>{"use strict";he=Symbol.for("graphrefly/START"),G=Symbol.for("graphrefly/DATA"),F=Symbol.for("graphrefly/DIRTY"),q=Symbol.for("graphrefly/RESOLVED"),Q=Symbol.for("graphrefly/INVALIDATE"),re=Symbol.for("graphrefly/PAUSE"),se=Symbol.for("graphrefly/RESUME"),B=Symbol.for("graphrefly/TEARDOWN"),z=Symbol.for("graphrefly/COMPLETE"),C=Symbol.for("graphrefly/ERROR"),ge=Object.freeze([F]),Pe=Object.freeze([q]),Mt=Object.freeze([Q]),$e=Object.freeze([he]),Dt=Object.freeze([z]),Ct=Object.freeze([B]),Fe=Object.freeze([ge]),dt=Object.freeze([Pe]),lt=Object.freeze([Mt]),ct=Object.freeze([Dt]),Ve=Object.freeze([Ct])});function Gt(t){t.registerMessageType(he,{tier:0,wireCrossing:!1}),t.registerMessageType(F,{tier:1,wireCrossing:!1}),t.registerMessageType(Q,{tier:1,wireCrossing:!1,metaPassthrough:!1}),t.registerMessageType(re,{tier:2,wireCrossing:!1}),t.registerMessageType(se,{tier:2,wireCrossing:!1}),t.registerMessageType(G,{tier:3,wireCrossing:!0}),t.registerMessageType(q,{tier:3,wireCrossing:!0}),t.registerMessageType(z,{tier:4,wireCrossing:!0,metaPassthrough:!1}),t.registerMessageType(C,{tier:4,wireCrossing:!0,metaPassthrough:!1}),t.registerMessageType(B,{tier:5,wireCrossing:!0,metaPassthrough:!1})}var ze,Lt=Y(()=>{"use strict";oe();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 It(t){return Array.isArray(t)?[...t]:[t]}function $n(t,e){return t.has(e)||t.has("*")}function Pt(t){let e=[];return t((s,o)=>{e.push({kind:"allow",actions:new Set(It(s)),where:o?.where??(()=>!0)})},(s,o)=>{e.push({kind:"deny",actions:new Set(It(s)),where:o?.where??(()=>!0)})}),(s,o)=>{let i=!1,a=!1;for(let d of e)$n(d.actions,o)&&d.where(s)&&(d.kind==="deny"?i=!0:a=!0);return i?!1:a}}function ft(t){let e=Fn.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 X,Fn,Te=Y(()=>{"use strict";X=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}};Fn=["human","llm","wallet","system"]});function Ft(t,e){let n=new TextEncoder().encode(t.name);if(n.length===0||n.length>255)throw new Error(`encodeEnvelope: codec name "${t.name}" encodes to ${n.length} bytes (must be 1\u2013255)`);let r=t.version;if(!Number.isInteger(r)||r<0||r>65535)throw new Error(`encodeEnvelope: codec.version ${r} out of u16 range (expected integer 0\u201365535)`);let s=2+n.length+2+e.length;if(s>4294967295)throw new Error(`encodeEnvelope: total envelope size ${s} exceeds 2^32-1 bytes (payload ${e.length} bytes)`);let o=new Uint8Array(s),i=0;return o[i++]=pt,o[i++]=n.length,o.set(n,i),i+=n.length,o[i++]=r>>>8&255,o[i++]=r&255,o.set(e,i),o}function Vt(t,e){if(t.length<$t)throw new Error(`decodeEnvelope: bytes too short (${t.length} < ${$t})`);let n=0,r=t[n++];if(r!==pt)throw new Error(`decodeEnvelope: unsupported envelope version ${r} (expected ${pt})`);let s=t[n++];if(s===0)throw new Error("decodeEnvelope: name_len must be >= 1");if(n+s+2>t.length)throw new Error(`decodeEnvelope: envelope truncated (need ${n+s+2} bytes, have ${t.length})`);let o=new TextDecoder().decode(t.subarray(n,n+s));n+=s;let i=(t[n]<<8|t[n+1])>>>0;n+=2;let a=t.subarray(n),d=e.lookupCodec(o);if(d==null)throw new Error(`decodeEnvelope: codec "${o}" not registered (envelope codec_v=${i})`);return{codec:d,codecVersion:i,payload:a}}function zt(t){t.registerCodec(Vn)}var Vn,pt,$t,ht=Y(()=>{"use strict";Vn={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)}},pt=1,$t=4});function gt(t){if(t===void 0)return null;if(typeof t=="number"){if(!Number.isFinite(t))throw new TypeError(`Cannot hash non-finite number: ${t}`);if(Number.isInteger(t)&&!Number.isSafeInteger(t))throw new TypeError(`Cannot hash integer outside safe range (|n| > 2^53-1): ${t}. Cross-language cid parity is not guaranteed for unsafe integers.`);return t}if(typeof t=="string"||typeof t=="boolean"||t===null)return t;if(Array.isArray(t))return t.map(gt);if(typeof t=="object"&&t!==null){let e={};for(let n of Object.keys(t).sort())e[n]=gt(t[n]);return e}return null}function Bn(t){let e=jn.encode(t),n=e.length,r=n*8,s=n+9+63&-64,o=new Uint8Array(s);o.set(e),o[n]=128;let i=new DataView(o.buffer);i.setUint32(s-4,r>>>0,!1),i.setUint32(s-8,Math.floor(r/4294967296)>>>0,!1);let a=1779033703,d=3144134277,u=1013904242,l=2773480762,f=1359893119,p=2600822924,h=528734635,c=1541459225,m=new Uint32Array(64),v=(x,_)=>x>>>_|x<<32-_;for(let x=0;x<s;x+=64){for(let N=0;N<16;N++)m[N]=i.getUint32(x+N*4,!1);for(let N=16;N<64;N++){let k=m[N-15],S=m[N-2],M=v(k,7)^v(k,18)^k>>>3,j=v(S,17)^v(S,19)^S>>>10;m[N]=m[N-16]+M+m[N-7]+j>>>0}let _=a,w=d,O=u,E=l,g=f,y=p,T=h,R=c;for(let N=0;N<64;N++){let k=v(g,6)^v(g,11)^v(g,25),S=g&y^~g&T,M=R+k+S+zn[N]+m[N]>>>0,j=v(_,2)^v(_,13)^v(_,22),V=_&w^_&O^w&O,le=j+V>>>0;R=T,T=y,y=g,g=E+M>>>0,E=O,O=w,w=_,_=M+le>>>0}a=a+_>>>0,d=d+w>>>0,u=u+O>>>0,l=l+E>>>0,f=f+g>>>0,p=p+y>>>0,h=h+T>>>0,c=c+R>>>0}let b=x=>x.toString(16).padStart(8,"0");return b(a)+b(d)+b(u)+b(l)+b(f)+b(p)+b(h)+b(c)}function mt(t){let e=gt(t??null),n=JSON.stringify(e);return Bn(n).slice(0,16)}function Hn(){let t=globalThis.crypto;if(t?.randomUUID)return t.randomUUID();let e=()=>Math.floor(Math.random()*4294967296).toString(16).padStart(8,"0"),n=e()+e()+e()+e();return`${n.slice(0,8)}-${n.slice(8,12)}-4${n.slice(13,16)}-${(parseInt(n.slice(16,17),16)&3|8).toString(16)}${n.slice(17,20)}-${n.slice(20,32)}`}function bt(t,e,n){let r=n?.id??Hn();if(t===0)return{id:r,version:0};let o=(n?.hash??mt)(e);return{id:r,version:0,cid:o,prev:null}}function jt(t,e,n){t.version+=1,"cid"in t&&(t.prev=t.cid,t.cid=n(e))}var zn,jn,Bt=Y(()=>{"use strict";zn=new Uint32Array([1116352408,1899447441,3049323471,3921009573,961987163,1508970993,2453635748,2870763221,3624381080,310598401,607225278,1426881987,1925078388,2162078206,2614888103,3248222580,3835390401,4022224774,264347078,604807628,770255983,1249150122,1555081692,1996064986,2554220882,2821834349,2952996808,3210313671,3336571891,3584528711,113926993,338241895,666307205,773529912,1294757372,1396182291,1695183700,1986661051,2177026350,2456956037,2730485921,2820302411,3259730800,3345764771,3516065817,3600352804,4094571909,275423344,430227734,506948616,659060556,883997877,958139571,1322822218,1537002063,1747873779,1955562222,2024104815,2227730452,2361852424,2428436474,2756734187,3204031479,3329325298]),jn=new TextEncoder});function qt(t){return{node:t,unsub:null,prevData:void 0,dirty:!1,involvedThisWave:!1,dataBatch:[],terminal:void 0}}function yt(t){t.prevData=void 0,t.dirty=!1,t.involvedThisWave=!1,t.dataBatch.length=0,t.terminal=void 0}function je(t){return t.length===0?t:typeof t[0]=="symbol"?[t]:t}function ie(t,e,n){let r=Wt(t)?t:[],s=typeof t=="function"?t:typeof e=="function"?e:void 0,o={};return Wt(t)?o=(vt(e)?e:n)??{}:vt(t)?o=t:o=(vt(e)?e:n)??{},new P(r,s,o)}var Ht,Kt,Kn,qn,Ee,P,Wt,vt,me=Y(()=>{"use strict";ht();Ie();pe();Ne();Lt();Te();oe();Bt();Ht=()=>{},Kt=100;Kn=(t,e,n,r)=>{n.direction==="down-in"&&t._onDepMessage(n.depIndex,e)},qn=(t,e,n,r)=>{let s=t;if(s._status==="completed"||s._status==="errored")return;let o=s._cached,i=o===void 0?[$e]:[$e,[G,o]];s._status==="dirty"&&i.push(ge),Me(e,i,s._config.tierOf)},Ee=new ze({onMessage:Kn,onSubscribe:qn});Gt(Ee);zt(Ee);P=class t{_optsName;_describeKind;meta;_hasMeta;_config;_deps;_sinks=null;_sinkCount=0;_cached;_status;_cleanup;_store={};_waveHasNewData=!1;_hasNewTerminal=!1;_hasCalledFnOnce=!1;_paused=!1;_pendingWave=!1;_isExecutingFn=!1;_pendingRerun=!1;_rerunDepth=0;_dirtyDepCount=0;_batchPendingMessages=null;_pauseLocks=null;_pauseBuffer=null;_fn;_equals;_resubscribable;_resetOnTeardown;_autoComplete;_autoError;_pausable;_partial;_guard;_extraGuards;_hashFn;_versioning;_versioningLevel;_lastMutation;_inspectorHooks;_actions;constructor(e,n,r){this._config=r.config??Ee,this._config.onMessage,this._optsName=r.name,this._describeKind=r.describeKind,this._equals=r.equals??Object.is,this._resubscribable=r.resubscribable??!1,this._resetOnTeardown=r.resetOnTeardown??!1,this._autoComplete=r.completeWhenDepsComplete??!0,this._autoError=r.errorWhenDepsError??!0,this._pausable=r.pausable??!0,this._guard=r.guard,this._fn=n,this._partial=r.partial??!1,this._cached=r.initial!==void 0?r.initial:void 0,this._status=e.length===0&&n==null&&this._cached!==void 0?"settled":"sentinel",this._hashFn=r.versioningHash??this._config.defaultHashFn??mt;let s=r.versioning??this._config.defaultVersioning;this._versioningLevel=s,this._versioning=s!=null?bt(s,this._cached===void 0?void 0:this._cached,{id:r.versioningId,hash:this._hashFn}):void 0,this._deps=e.map(qt);let o={};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),o[a]=new t([],void 0,u)}Object.freeze(o),this.meta=o,this._hasMeta=Object.keys(o).length>0;let i=this;this._actions={emit(a){i._emit([[G,a]])},down(a){i._emit(je(a))},up(a){i._emitUp(je(a))}},this.down=this.down.bind(this),this.up=this.up.bind(this)}get _isTerminal(){return this._status==="completed"||this._status==="errored"}get name(){return this._optsName}get status(){return this._status}get cache(){return this._cached===void 0?void 0:this._cached}get lastMutation(){return this._lastMutation}get v(){return this._versioning}hasGuard(){return this._guard!=null}_applyVersioning(e,n){if(this._isExecutingFn)throw new Error(`Node "${this.name}": _applyVersioning cannot run mid-fn \u2014 call it outside of \`_execFn\` (typically at graph setup time before the first subscribe).`);let r=this._versioningLevel;if(r!=null&&e<=r)return;let s=n?.hash??this._hashFn;s!==this._hashFn&&(this._hashFn=s);let o=this._cached===void 0?void 0:this._cached,i=this._versioning,a=i?.id??n?.id,d=i?.version??0,u=bt(e,o,{id:a,hash:s});u.version=d,this._versioning=u,this._versioningLevel=e}_setInspectorHook(e){return e==null?()=>{}:(this._inspectorHooks==null&&(this._inspectorHooks=new Set),this._inspectorHooks.add(e),()=>{this._inspectorHooks?.delete(e),this._inspectorHooks?.size===0&&(this._inspectorHooks=void 0)})}_pushGuard(e){return this._extraGuards==null&&(this._extraGuards=new Set),this._extraGuards.add(e),()=>{this._extraGuards?.delete(e),this._extraGuards?.size===0&&(this._extraGuards=void 0)}}allowsObserve(e){if(this._guard==null&&this._extraGuards==null)return!0;let n=Le(e);if(this._guard!=null&&!this._guard(n,"observe"))return!1;if(this._extraGuards!=null){for(let r of this._extraGuards)if(!r(n,"observe"))return!1}return!0}_checkGuard(e){if(e?.internal)return;let n=this._guard!=null||this._extraGuards!=null,r=e?.actor!=null;if(!n&&!r)return;let s=Le(e?.actor),o=e?.delivery==="signal"?"signal":"write";if(this._guard!=null&&!this._guard(s,o))throw new X({actor:s,action:o,nodeName:this.name});if(this._extraGuards!=null){for(let i of this._extraGuards)if(!i(s,o))throw new X({actor:s,action:o,nodeName:this.name})}this._lastMutation={actor:s,timestamp_ns:ne()}}down(e,n){let r=je(e);r.length!==0&&(this._checkGuard(n),this._emit(r))}emit(e,n){this._checkGuard(n),this._emit([[G,e]])}up(e,n){if(this._deps.length===0)return;let r=je(e);if(r.length===0)return;this._checkGuard(n);let s=n??{internal:!0};this._validateUpTiers(r);for(let o of this._deps)o.node.up?.(r,s)}_emitUp(e){if(this._deps.length!==0&&e.length!==0){this._validateUpTiers(e);for(let n of this._deps)n.node.up?.(e,{internal:!0})}}_validateUpTiers(e){let n=this._config.tierOf;for(let r of e){let s=n(r[0]);if(s===3||s===4)throw new Error(`Node "${this.name}": tier-${s} messages cannot flow up \u2014 DATA/RESOLVED/COMPLETE/ERROR are downstream-only. Use \`down(...)\` for value delivery; \`up(...)\` is for control signals (DIRTY, INVALIDATE, PAUSE, RESUME, TEARDOWN).`)}}subscribe(e,n){if(n!=null&&this._guard!=null){let d=Le(n);if(!this._guard(d,"observe"))throw new X({actor:d,action:"observe",nodeName:this.name})}let s=this._isTerminal&&this._resubscribable;if(s){this._cached=void 0,this._status="sentinel",this._store={},this._hasCalledFnOnce=!1,this._waveHasNewData=!1,this._hasNewTerminal=!1,this._paused=!1,this._pendingWave=!1,this._pendingRerun=!1,this._isExecutingFn=!1,this._rerunDepth=0,this._dirtyDepCount=0,this._pauseLocks=null,this._pauseBuffer=null;for(let d of this._deps)yt(d);if(this._partial===!1){for(let d of this._deps)if(d.prevData!==void 0||d.dataBatch.length!==0||d.terminal!==void 0||d.dirty)throw new Error(`resubscribable-reset invariant: DepRecord not fully reset for node ${this._optsName??"(anonymous)"}`)}}this._sinkCount+=1;let o;try{o=this._config.onSubscribe(this,e,{sinkCount:this._sinkCount,afterTerminalReset:s},this._actions)}catch(d){throw this._sinkCount-=1,d}this._sinks==null?this._sinks=e:typeof this._sinks=="function"?this._sinks=new Set([this._sinks,e]):this._sinks.add(e);let i=this._isTerminal;if(this._sinkCount===1&&!i)try{this._activate()}catch(d){if(this._sinkCount-=1,this._removeSink(e),this._sinkCount===0&&(this._status="sentinel"),typeof o=="function")try{o()}catch{}throw d}this._status==="sentinel"&&this._cached===void 0&&(this._status="pending");let a=!1;return()=>{a||(a=!0,this._sinkCount-=1,this._removeSink(e),typeof o=="function"&&o(),this._sinks==null&&this._deactivate())}}_removeSink(e){if(this._sinks===e)this._sinks=null;else if(this._sinks!=null&&typeof this._sinks!="function")if(this._sinks.delete(e),this._sinks.size===1){let[n]=this._sinks;this._sinks=n}else this._sinks.size===0&&(this._sinks=null)}_activate(){if(this._deps.length===0){this._fn&&this._execFn();return}this._dirtyDepCount=0;let e=this._deps.length,n=0;try{for(let r=0;r<e;r++){let s=r,o=this._deps[r];o.unsub=Ht,o.unsub=o.node.subscribe(i=>{if(o.unsub===null)return;let a=this._config.tierOf,d=!1;for(let u of i)a(u[0])>=3&&(d=!0),this._config.onMessage(this,u,{direction:"down-in",depIndex:s},this._actions);d&&this._maybeRunFnOnSettlement()}),n++}}catch(r){this._deps[n].unsub=null;for(let s=0;s<n;s++){let o=this._deps[s];if(o.unsub!=null){let i=o.unsub;o.unsub=null;try{i()}catch{}yt(o)}}throw this._dirtyDepCount=0,r}}_addDep(e){for(let s=0;s<this._deps.length;s++)if(this._deps[s].node===e)return s;let n=this._deps.length,r=qt(e);if(this._deps.push(r),this._sinks==null)return n;r.dirty=!0,this._dirtyDepCount++,this._status!=="dirty"&&this._emit(Fe),r.unsub=Ht;try{r.unsub=e.subscribe(s=>{if(r.unsub===null)return;let o=this._config.tierOf,i=!1;for(let a of s)o(a[0])>=3&&(i=!0),this._config.onMessage(this,a,{direction:"down-in",depIndex:n},this._actions);i&&this._maybeRunFnOnSettlement()})}catch(s){throw r.unsub=null,this._deps.pop(),this._dirtyDepCount--,s}return n}_deactivate(e=!1){let n=this._cleanup;if(this._cleanup=void 0,typeof n=="function")try{n()}catch(r){this._emit([[C,this._wrapFnError("cleanup threw",r)]])}else if(n!=null&&typeof n=="object"){let r=n.deactivate;if(typeof r=="function")try{r()}catch(s){this._emit([[C,this._wrapFnError("cleanup.deactivate threw",s)]])}}for(let r of this._deps){if(r.unsub!=null){let s=r.unsub;r.unsub=null;try{s()}catch{}}yt(r)}this._waveHasNewData=!1,this._hasNewTerminal=!1,this._hasCalledFnOnce=!1,this._paused=!1,this._pendingWave=!1,this._pendingRerun=!1,this._rerunDepth=0,this._store={},this._dirtyDepCount=0,this._pauseLocks=null,this._pauseBuffer=null,this._fn!=null&&(this._cached=void 0),e||(this._fn!=null||this._deps.length>0)&&(!this._isTerminal||this._resubscribable)&&(this._status="sentinel")}_onDepMessage(e,n){let r=this._deps[e],s=n[0];if(this._inspectorHooks!=null){let o={kind:"dep_message",depIndex:e,message:n};for(let i of this._inspectorHooks)i(o)}if(s!==he){if(s===F){this._depDirtied(r);return}if(s===Q){if(this._depInvalidated(r),this._cached===void 0)return;this._emit(lt);return}if(s===re||s===se){this._emit([n]);return}if(s===B){this._emit(Ve);return}if(s===G)this._depSettledAsData(r,n[1]);else if(s===q)this._depSettledAsResolved(r);else if(s===z)this._depSettledAsTerminal(r,!0);else if(s===C)this._depSettledAsTerminal(r,n[1]);else{this._emit([n]);return}if(!this._fn){(s===G||s===q)&&this._emit([n]),(s===z||s===C)&&this._maybeAutoTerminalAfterWave();return}}}_depDirtied(e){e.dirty||(e.dirty=!0,e.involvedThisWave=!0,this._dirtyDepCount++,this._status!=="dirty"&&this._emit(Fe))}_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(dt),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([[C,e.terminal]]);return}this._autoComplete&&this._deps.every(n=>n.terminal!==void 0)&&this._emit(ct)}_execFn(){if(!this._fn||this._isTerminal&&!this._resubscribable)return;if(this._isExecutingFn){this._pendingRerun=!0;return}let e=this._cleanup;if(typeof e=="function"){this._cleanup=void 0;try{e()}catch(i){this._emit([[C,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([[C,this._wrapFnError("cleanup.beforeRun threw",a)]]);return}}}let n=this._deps.map(i=>i.involvedThisWave?i.dataBatch.length>0?[...i.dataBatch]:[]:void 0),r=this._deps.map(i=>i.prevData);for(let i=0;i<this._deps.length;i++){let a=n[i];a!=null&&a.length>0&&(this._deps[i].prevData=a[a.length-1])}let s=this._deps.map(i=>i.terminal),o={prevData:r,terminalDeps:s,store:this._store};if(this._hasCalledFnOnce=!0,this._clearWaveFlags(),this._inspectorHooks!=null){let i={kind:"run",batchData:n,prevData:r};for(let a of this._inspectorHooks)a(i)}this._isExecutingFn=!0;try{let i=this._fn(n,this._actions,o);if(typeof i=="function")this._cleanup=i;else if(i!=null&&typeof i=="object"){let a=i;(typeof a.beforeRun=="function"||typeof a.deactivate=="function"||typeof a.invalidate=="function")&&(this._cleanup=i)}}catch(i){this._emit([[C,this._wrapFnError("fn threw",i)]])}finally{this._isExecutingFn=!1,this._pendingRerun?(this._pendingRerun=!1,this._rerunDepth+=1,this._rerunDepth>Kt?(this._rerunDepth=0,this._emit([[C,new Error(`Node "${this.name}": _pendingRerun depth exceeded ${Kt} \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"?[ge,e[0]]:e;let r=!0,s=!1,o=!1,i=-1;for(let d of e){let u=n(d[0]);u<i&&(r=!1),u===3&&(s=!0),d[0]===F&&(o=!0),i=u}let a=e;if(!r){let d=e.map((u,l)=>({m:u,i:l,tier:n(u[0])}));d.sort((u,l)=>u.tier-l.tier||u.i-l.i),a=d.map(u=>u.m)}if(s&&!o&&this._status!=="dirty"){let d=0;for(;d<a.length&&n(a[d][0])===0;)d++;return d===0?[ge,...a]:[...a.slice(0,d),ge,...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]===C&&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]===B||d[0]===Q);if(a.length===0)return;n=a}n=this._frameBatch(n);let s=null;for(let a=0;a<n.length;a++){let d=n[a],u=d[0];if(u!==re&&u!==se){s?.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 l=!0;if(this._pausable!==!1){let f=d[1];if(u===re)this._pauseLocks==null&&(this._pauseLocks=new Set),this._pauseLocks.add(f),this._paused=!0,this._pausable==="resumeAll"&&this._pauseBuffer==null&&(this._pauseBuffer=[]);else if(this._pauseLocks==null||!this._pauseLocks.has(f))l=!1;else if(this._pauseLocks.delete(f),this._pauseLocks.size===0){if(this._paused=!1,this._pauseBuffer!=null&&this._pauseBuffer.length>0){let p=this._pauseBuffer;this._pauseBuffer=[],this._emit(p)}this._pendingWave&&(this._pendingWave=!1,this._maybeRunFnOnSettlement())}}l?s?.push(d):s==null&&(s=n.slice(0,a))}if(s!=null){if(s.length===0)return;n=s}if(this._hasMeta&&n.some(a=>a[0]===B))for(let a of Object.keys(this.meta))try{this.meta[a]._emit(Ve)}catch{}let{finalMessages:o,equalsError:i}=this._updateState(n);if(o.length>0&&this._config.inspectorEnabled){let a=this._config.globalInspector;if(a!=null)try{a({kind:"emit",node:this,messages:o})}catch{}}if(o.length>0)if(this._paused&&this._pausable==="resumeAll"&&this._pauseBuffer!=null){let a=this._config.tierOf,d=[];for(let u of o)a(u[0])===3?this._pauseBuffer.push(u):d.push(u);d.length>0&&this._dispatchOrAccumulate(d)}else this._dispatchOrAccumulate(o);i!=null&&this._emit([[C,i]])}_updateState(e){let n=this._config.tierOf,r,s,o=-1,i=0;for(let l of e)n(l[0])===3&&i++;let a=i<=1,d=-1;if(this._versioning!=null&&i>1){for(let l=e.length-1;l>=0;l--)if(e[l][0]===G){d=l;break}}for(let l=0;l<e.length;l++){let f=e[l],p=f[0];if(p===G){if(f.length>=2){let h=!1;if(a&&this._cached!==void 0)try{h=this._equals(this._cached,f[1])}catch(c){s=this._wrapFnError("equals threw",c),o=l;break}if(h){r==null&&(r=e.slice(0,l)),r.push(Pe),this._status="resolved";continue}this._cached=f[1],this._versioning!=null&&(d<0||l===d)&&jt(this._versioning,f[1],this._hashFn)}this._status="settled",r?.push(f)}else if(r?.push(f),p===F)this._status="dirty";else if(p===q)this._status="resolved";else if(p===z){this._status="completed";{let h=this._config.rigorRecorder;if(h!=null)try{h.onTerminalTransition(this,"completed",this._autoComplete,this._autoError,this._deps.length>0)}catch{}}}else if(p===C){this._status="errored";{let h=this._config.rigorRecorder;if(h!=null)try{h.onTerminalTransition(this,"errored",this._autoComplete,this._autoError,this._deps.length>0)}catch{}}}else if(p===Q){if(this._cached!==void 0){let c=this._config.rigorRecorder;if(c!=null)try{c.onNonVacuousInvalidate(this,this._cached)}catch{}}this._cached=void 0,this._status="dirty";let h=this._cleanup;if(typeof h=="function"){this._cleanup=void 0;try{h()}catch{}}else if(h!=null&&typeof h=="object"){let c=h.invalidate;if(typeof c=="function")try{c()}catch{}}}else p===B&&(this._resetOnTeardown&&(this._cached=void 0),this._deactivate(!0),this._status="sentinel")}let u=o>=0?r??e.slice(0,o):r??e;return s!=null?{finalMessages:u,equalsError:s}:{finalMessages:u}}_deliverToSinks=e=>{if(this._sinks==null)return;if(typeof this._sinks=="function"){this._sinks(e);return}let n=[...this._sinks];for(let r of n)r(e)};_dispatchOrAccumulate(e){if(At()){this._batchPendingMessages===null&&(this._batchPendingMessages=[],Ae(()=>this._flushBatchPending()));for(let n of e)this._batchPendingMessages.push(n);return}Me(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);Me(this._deliverToSinks,n,this._config.tierOf)}},Wt=t=>Array.isArray(t),vt=t=>typeof t=="object"&&t!=null&&!Array.isArray(t)});function W(t,e){return ie([],{...e,initial:t})}function be(t,e){return ie((r,s,o)=>t(s,o)??void 0,{describeKind:"producer",...e})}function Z(t,e,n){return ie(t,(s,o,i)=>{let a=s.map((d,u)=>d!=null&&d.length>0?d.at(-1):i.prevData[u]);o.emit(e(a,i))},{describeKind:"derived",...n})}var ue=Y(()=>{"use strict";me()});function xt(t){return{describeKind:"producer",...t}}function Jt(t,e){return be(n=>{let r=!1;try{for(let s of t){if(r)return;n.emit(s)}r||n.down([[z]])}catch(s){r||n.down([[C,s]])}return()=>{r=!0}},xt(e))}function Jn(t){return t!=null&&typeof t.then=="function"}function Yn(t,e){let{signal:n,...r}=e??{};return be(s=>{let o=!1,i=()=>{o||(o=!0,s.down([[C,n.reason]]))};if(n?.aborted){i();return}return n?.addEventListener("abort",i,{once:!0}),Promise.resolve(t).then(a=>{o||(o=!0,n?.removeEventListener("abort",i),s.emit(a),s.down([[z]]))},a=>{o||(o=!0,n?.removeEventListener("abort",i),s.down([[C,a]]))}),()=>{o=!0,n?.removeEventListener("abort",i)}},xt(r))}function Qn(t,e){let{signal:n,...r}=e??{};return be(s=>{let o=new AbortController,i=()=>o.abort(n?.reason);n?.aborted?o.abort(n.reason):n?.addEventListener("abort",i,{once:!0});let a=n??o.signal,d=!1,u=t[Symbol.asyncIterator](),l=()=>{d||a.aborted||Promise.resolve(u.next()).then(f=>{if(!(d||a.aborted)){if(f.done){s.down([[z]]);return}s.emit(f.value),l()}},f=>{!d&&!a.aborted&&s.down([[C,f]])})};return l(),()=>{d=!0,n?.removeEventListener("abort",i),o.abort(),Promise.resolve(u.return?.()).catch(()=>{})}},xt(r))}function Xn(t){return t!=null&&typeof t=="object"&&"cache"in t&&typeof t.subscribe=="function"}function Yt(t,e){if(Xn(t))return t;if(Jn(t))return Yn(t,e);if(t!=null){let n=t;if(typeof n[Symbol.asyncIterator]=="function")return Qn(t,e);if(typeof n[Symbol.iterator]=="function")return Jt(t,e)}return Zn(t)}function Zn(...t){return Jt(t,void 0)}function ae(t){return t.subscribe(()=>{})}var He=Y(()=>{"use strict";oe();ue()});var Je,rn=Y(()=>{"use strict";Je=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 Xr={};Gn(Xr,{JobFlowGraph:()=>rt,JobQueueGraph:()=>nt,jobEventKeyOf:()=>Yr,jobFlow:()=>Qr,jobQueue:()=>An});module.exports=In(Xr);Ne();Ie();pe();Te();oe();Te();me();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;default:return new Set(["type","deps"])}}function Wn(t){return t._describeKind!=null?t._describeKind:t._deps.length>0?"derived":t._fn!=null?"producer":"state"}function Un(t){let e={};for(let[n,r]of Object.entries(t.meta))try{e[n]=r.cache}catch{}return e}function _t(t,e){let n=e==null,r=!n&&e!=null?[...e].filter(u=>u.startsWith("meta.")).map(u=>u.slice(5)):null,s=n||e.has("meta")||r!=null&&r.length>0,o="state",i=[];t instanceof P&&(o=Wn(t),i=t._deps.map(u=>u.node.name??""));let a={type:o,deps:i};(n||e.has("status"))&&(a.status=t.status);let d=t instanceof P?t._guard:void 0;if(s){let u={...Un(t)};if(d!=null&&u.access===void 0&&(u.access=ft(d)),r!=null&&r.length>0&&!e.has("meta")){let l={};for(let f of r)f in u&&(l[f]=u[f]);a.meta=l}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=ft(d)),(n||e.has("lastMutation"))&&t.lastMutation!=null&&(a.lastMutation=t.lastMutation),a}ue();me();pe();oe();ue();var wt=class{_version=0;_buf;constructor(e){this._buf=e?[...e]:[]}get version(){return this._version}get size(){return this._buf.length}at(e){if(!Number.isInteger(e))return;let n=e>=0?e:this._buf.length+e;if(!(n<0||n>=this._buf.length))return this._buf[n]}append(e){this._buf.push(e),this._version+=1}appendMany(e){if(e.length===0)return;let n=this._buf.length;this._buf.length=n+e.length;for(let r=0;r<e.length;r++)this._buf[n+r]=e[r];this._version+=1}insert(e,n){if(!Number.isInteger(e)||e<0||e>this._buf.length)throw new RangeError(`insert: index ${e} out of range [0, ${this._buf.length}]`);this._buf.splice(e,0,n),this._version+=1}insertMany(e,n){if(!Number.isInteger(e)||e<0||e>this._buf.length)throw new RangeError(`insertMany: index ${e} out of range [0, ${this._buf.length}]`);n.length!==0&&(this._buf.splice(e,0,...n),this._version+=1)}pop(e){if(this._buf.length===0)throw new RangeError("pop from empty list");if(!Number.isInteger(e))throw new RangeError(`pop: index ${e} must be an integer`);let n=e>=0?e:this._buf.length+e;if(n<0||n>=this._buf.length)throw new RangeError(`pop: index ${e} out of range`);let[r]=this._buf.splice(n,1);return this._version+=1,r}clear(){let e=this._buf.length;return e===0?0:(this._buf.length=0,this._version+=1,e)}toArray(){return[...this._buf]}};function Ut(t,e={}){let{name:n,versioning:r,backend:s}=e,o=s??new wt(t),i=W(o.toArray(),{name:n,describeKind:"state",equals:(u,l)=>u===l,...r!=null?{versioning:r}:{}});function a(){let u=o.toArray();K(()=>{i.down([[F]]),i.down([[G,u]])})}function d(u){let l=o.version;try{return u()}finally{o.version!==l&&a()}}return{items:i,get size(){return o.size},at(u){return o.at(u)},append(u){d(()=>o.append(u))},appendMany(u){d(()=>o.appendMany(u))},insert(u,l){d(()=>o.insert(u,l))},insertMany(u,l){d(()=>o.insertMany(u,l))},pop(u=-1){return d(()=>o.pop(u))},clear(){d(()=>o.clear())},dispose(){}}}pe();oe();me();ue();var Tt=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),s=e.length-r;for(let o=0;o<r;o++)this._buf[o]=e[s+o];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),s=Math.min(e,this._size);if(s>=r)return[];let o=r-s;if(this._maxSize===void 0)return this._buf.slice(s,r);let i=new Array(o);for(let a=0;a<o;a++)i[a]=this._buf[(this._head+s+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 o=0;o<n;o++)this._buf[o]=void 0;this._head=0;let r=Math.min(e.length,n),s=e.length-r;for(let o=0;o<r;o++)this._buf[o]=e[s+o];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 De(t){return t.subscribe(()=>{})}var er=64;function Ke(t,e={}){let{name:n,maxSize:r,versioning:s,guard:o,backend:i}=e,a=i??new Tt(t,r),d=W(a.toArray(),{name:n,describeKind:"state",equals:(g,y)=>g===y,...s!=null?{versioning:s}:{},...o!=null?{guard:o}:{}});function u(){let g=a.toArray();K(()=>{d.down([[F]],{internal:!0}),d.down([[G,g]],{internal:!0})})}let l=new Map,f=new Map,p=new Map;function h(g,y){return`${g}:${y===void 0?"END":y}`}function c(g){if(g.size<er)return;let y=g.keys().next();if(y.done)return;let T=g.get(y.value);T!==void 0&&T.dispose(),g.delete(y.value)}function m(g){let y=a.version;try{return g()}finally{a.version!==y&&u()}}function v(g){if(!Number.isInteger(g)||g<0)throw new RangeError(`tail: n must be a non-negative integer (got ${g})`);let y=l.get(g);if(y!==void 0)return l.delete(g),l.set(g,y),y.node;c(l);let T=Z([d],([N])=>{let k=N;return g===0||k.length===0?[]:k.slice(Math.max(0,k.length-g))},{initial:a.tail(g),describeKind:"derived"}),R=De(T);return l.set(g,{node:T,dispose:R}),T}function b(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 T=h(g,y),R=f.get(T);if(R!==void 0)return f.delete(T),f.set(T,R),R.node;c(f);let N=Z([d],([S])=>{let M=S;return y===void 0?M.slice(g):M.slice(g,y)},{initial:a.slice(g,y),describeKind:"derived"}),k=De(N);return f.set(T,{node:N,dispose:k}),N}function x(g){let y=p.get(g);if(y!==void 0)return y.node;let T=Z([d,g],([N,k])=>{let S=N,M=Math.max(0,Math.trunc(k??0));return S.slice(M)},{initial:[],describeKind:"derived"}),R=De(T);return p.set(g,{node:T,dispose:R}),T}let _,w;function O(){_===void 0&&(_=ie([d],(g,y,T)=>{let R=g[0],k=R!=null&&R.length>0?R.at(-1):T.prevData[0];if(k==null||k.length===0){y.down([[q]]);return}y.emit(k[k.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}),De(_),De(w))}let E={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 O(),d},get lastValue(){return O(),_},get hasLatest(){return O(),w},view(g){switch(g.kind){case"tail":return v(g.n);case"slice":return b(g.start,g.stop);case"fromCursor":return x(g.cursor)}},attach(g){let y=g.subscribe(T=>{for(let R of T)R[0]===G&&E.append(R[1])});return()=>y()},attachStorage(g){if(g.length===0)return()=>{};let y=new Map;for(let R of g)y.set(R,a.size);(async()=>{for(let R of g)if(typeof R.loadEntries=="function")try{let N=await Promise.resolve(R.loadEntries());N.entries.length>0&&a.size===0&&(a.restore(N.entries),y.set(R,N.entries.length),u());break}catch{}})();let T=d.subscribe(R=>{for(let N of R){if(N[0]!==G)continue;let k=N[1];for(let S of g){let M=y.get(S)??0;if(k.length<M){try{let V=S.appendEntries(k);V instanceof Promise&&V.catch(()=>{})}catch{}y.set(S,k.length);continue}if(k.length===M)continue;let j=k.slice(M);y.set(S,k.length);try{let V=S.appendEntries(j);V instanceof Promise&&V.catch(()=>{})}catch{}}}});return()=>T()},disposeAllViews(){for(let g of l.values())g.dispose();l.clear();for(let g of f.values())g.dispose();f.clear();for(let g of p.values())g.dispose();p.clear()},dispose(){for(let g of l.values())g.dispose();l.clear();for(let g of f.values())g.dispose();f.clear();for(let g of p.values())g.dispose();p.clear()}};return E}pe();Ne();oe();ue();var Et=class{_version=0;_store=new Map;_maxSize;_defaultTtl;constructor(e={}){let{maxSize:n,defaultTtl:r}=e;if(n!==void 0&&n<1)throw new RangeError("maxSize must be >= 1");if(r!==void 0&&r<=0)throw new RangeError("defaultTtl must be positive");this._maxSize=n,this._defaultTtl=r}get version(){return this._version}get size(){return this._store.size}has(e){let n=this._store.get(e);return n===void 0?!1:this._isExpired(n)?(this._store.delete(e),this._version+=1,!1):(this._touchLru(e,n),!0)}get(e){let n=this._store.get(e);if(n!==void 0){if(this._isExpired(n)){this._store.delete(e),this._version+=1;return}return this._touchLru(e,n),n.value}}set(e,n,r){let s=this._resolveExpiresAt(r);this._store.has(e)&&this._store.delete(e),this._store.set(e,{value:n,expiresAt:s}),this._evictLruWhileOver(),this._version+=1}setMany(e,n){let r=this._resolveExpiresAt(n),s=0;try{for(let[o,i]of e)this._store.has(o)&&this._store.delete(o),this._store.set(o,{value:i,expiresAt:r}),s+=1}finally{s>0&&(this._evictLruWhileOver(),this._version+=1)}}delete(e){let n=this._store.delete(e);return n&&(this._version+=1),n}deleteMany(e){let n=0;try{for(let r of e)this._store.delete(r)&&(n+=1)}finally{n>0&&(this._version+=1)}return n}clear(){let e=this._store.size;return e===0?0:(this._store.clear(),this._version+=1,e)}pruneExpired(){let e=te(),n=0;for(let[r,s]of this._store)this._isExpired(s,e)&&(this._store.delete(r),n+=1);return n>0&&(this._version+=1),n}toMap(){let e=te(),n=new Map;for(let[r,s]of this._store)this._isExpired(s,e)||n.set(r,s.value);return n}_resolveExpiresAt(e){let n=e??this._defaultTtl;if(n!==void 0){if(!Number.isFinite(n)||n<=0)throw new RangeError(`MapBackend: ttl must be a positive finite number (got ${n})`);return te()+n*1e9}}_isExpired(e,n){return e.expiresAt===void 0?!1:(n??te())>=e.expiresAt}_touchLru(e,n){this._store.delete(e),this._store.set(e,n)}_evictLruWhileOver(){if(this._maxSize!==void 0)for(;this._store.size>this._maxSize;){let e=this._store.keys().next().value;if(e===void 0)break;this._store.delete(e)}}};function Qt(t={}){let{name:e,maxSize:n,defaultTtl:r,versioning:s,backend:o,retention:i}=t;if(i&&n!==void 0)throw new RangeError("reactiveMap: `maxSize` (LRU) and `retention` (score-based) are mutually exclusive. Pick one eviction policy.");if(i&&i.archiveThreshold===void 0&&i.maxSize===void 0)throw new RangeError("reactiveMap: `retention` requires at least one of `archiveThreshold` or `maxSize` to trigger archival.");let a=o??new Et({maxSize:n,defaultTtl:r}),d=W(a.toMap(),{name:e,describeKind:"state",equals:(p,h)=>p===h,...s!=null?{versioning:s}:{}});function u(){let p=a.toMap();K(()=>{d.down([[F]]),d.down([[G,p]])})}function l(){if(!i)return;let p=a.toMap(),h=i.archiveThreshold,c=i.maxSize,m=[];for(let[b,x]of p)m.push({key:b,value:x,score:i.score(b,x)});m.sort((b,x)=>b.score-x.score);let v=new Set;if(h!==void 0)for(let b of m)if(b.score<h)v.add(b.key);else break;if(c!==void 0&&m.length-v.size>c)for(let b of m){if(m.length-v.size<=c)break;v.has(b.key)||v.add(b.key)}if(v.size!==0)for(let b of m)v.has(b.key)&&(i.onArchive?.(b.key,b.value,b.score),a.delete(b.key))}function f(p,h="mutation"){let c=a.version;try{return p()}finally{a.version!==c&&(h==="mutation"&&l(),u())}}return{entries:d,has(p){return f(()=>a.has(p),"read")},get(p){return f(()=>a.get(p),"read")},set(p,h,c){f(()=>a.set(p,h,c?.ttl))},setMany(p,h){f(()=>a.setMany(p,h?.ttl))},delete(p){f(()=>a.delete(p))},deleteMany(p){f(()=>a.deleteMany(p))},clear(){f(()=>a.clear())},pruneExpired(){f(()=>a.pruneExpired())},get size(){return a.size},dispose(){}}}He();var $={object:56,array:64,string:40,number:8,boolean:4,null:0,undefined:0,symbol:40,bigint:16,function:120,map:72,set:72,mapEntry:40,setEntry:24,date:24,regexp:48,error:64,url:80,promise:48,weakmap:40,weakset:40},tr=Symbol.for("sizeof");function Xt(t){let e=new WeakSet,n=new WeakSet,r=[t],s=0;for(;r.length>0;){let o=r.pop();s+=nr(o,e,n,r)}return s}function nr(t,e,n,r){if(t==null)return 0;switch(typeof t){case"number":return $.number;case"boolean":return $.boolean;case"string":return $.string+t.length*2;case"bigint":return $.bigint+rr(t);case"symbol":return $.symbol;case"function":return e.has(t)?0:(e.add(t),$.function);case"undefined":return 0}let o=t;if(e.has(o))return 0;e.add(o);let i=o[tr];if(typeof i=="function")try{let u=i.call(o);if(typeof u=="number"&&Number.isFinite(u))return u}catch{}if(o instanceof Date)return $.date;if(o instanceof RegExp)return $.regexp+o.source.length*2;if(o instanceof Error){let u=o.message?o.message.length*2:0,l=o.stack?o.stack.length*2:0;return $.error+u+l}if(typeof URL<"u"&&o instanceof URL)return $.url+o.href.length*2;if(typeof Promise<"u"&&o instanceof Promise)return $.promise;if(o instanceof WeakMap)return $.weakmap;if(o instanceof WeakSet)return $.weakset;if(o instanceof Map){let u=$.map;for(let[l,f]of o)u+=$.mapEntry,r.push(l),r.push(f);return u}if(o instanceof Set){let u=$.set;for(let l of o)u+=$.setEntry,r.push(l);return u}if(Array.isArray(o)){let u=$.array+o.length*8;for(let l of o)r.push(l);return u}if(o instanceof ArrayBuffer)return n.has(o)?0:(n.add(o),o.byteLength);if(ArrayBuffer.isView(o)){let u=o;return n.has(u.buffer)?48:(n.add(u.buffer),u.buffer.byteLength+48)}let a=$.object,d=Object.keys(o);for(let u of d){a+=$.string+u.length*2;try{r.push(o[u])}catch{}}return a}function rr(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 Zt(t,e,n,r={}){let s=e in t.nodes,o=n in t.nodes;if(!s)return qe(e,n,"no-such-from");if(!o)return qe(e,n,"no-such-to");let i=r.maxDepth;if(i!=null&&(!Number.isInteger(i)||i<0))throw new Error("explainPath: maxDepth must be an integer >= 0");if(e===n){if(r.findCycle===!0){let u=sr(t,e,r);if(u!=null)return u}let d=We(e,t.nodes[e],0,r);return Ue(e,n,[d])}if(i===0)return qe(e,n,"no-path");let a=en(t,e,n,i);return a.found?Ue(e,n,tn(t,a.pathOrder,r)):qe(e,n,a.truncated?"max-depth-exceeded":"no-path")}function en(t,e,n,r){let s=new Map,o=[{path:n,depth:0}],i=new Set([n]),a=0,d=!1;for(;a<o.length;){let f=o[a++];if(f.path===e)break;if(r!=null&&f.depth>=r){let m=t.nodes[f.path];m?.deps&&m.deps.length>0&&(d=!0);continue}let p=t.nodes[f.path];if(p==null)continue;let h=p.deps??[],c=new Map;for(let m=0;m<h.length;m++){let v=h[m];if(!v)continue;let b=c.get(v);b==null&&(b=[],c.set(v,b)),b.push(m)}for(let[m,v]of c)i.has(m)||(i.add(m),s.set(m,{from:f.path,depIndices:v}),o.push({path:m,depth:f.depth+1}))}if(!s.has(e))return{found:!1,pathOrder:[],truncated:d};let u=[{path:e}],l=e;for(;l!==n;){let f=s.get(l);if(f==null)return{found:!1,pathOrder:[],truncated:!1};u[u.length-1].depIndices=f.depIndices,u.push({path:f.from}),l=f.from}return{found:!0,pathOrder:u,truncated:!1}}function sr(t,e,n){let r=t.nodes[e];if(r==null)return null;let s=r.deps??[],o=[];for(let a=0;a<s.length;a++)s[a]===e&&o.push(a);if(o.length>0){let a=We(e,r,0,n);a.dep_index=o[0];let d=We(e,r,1,n);return Ue(e,e,[a,d])}let i=null;for(let a=0;a<s.length;a++){let d=s[a];if(!d||d===e)continue;let u=en(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:Ue(e,e,tn(t,i.pathOrder,n))}function tn(t,e,n){return e.map((r,s)=>{let o=t.nodes[r.path],i=We(r.path,o,s,n);return r.depIndices!=null&&r.depIndices.length>0&&(i.dep_index=r.depIndices[0],r.depIndices.length>1&&(i.dep_indices=[...r.depIndices])),i})}function We(t,e,n,r){let s={path:t,type:e.type,hop:n};e.status!==void 0&&(s.status=e.status),"value"in e&&(s.value=e.value),e.v!=null&&(s.v=e.v);let o=r.annotations?.get(t)??e.annotation;o!=null&&(s.annotation=o);let i=r.lastMutations?.get(t)??e.lastMutation;return i!=null&&(s.lastMutation=i),s}function Ue(t,e,n){return nn(t,e,!0,"ok",n)}function qe(t,e,n){return nn(t,e,!1,n,[])}function nn(t,e,n,r,s){let o=or(t,e,n,r,s);return{from:t,to:e,found:n,reason:r,steps:s,text:o,toJSON(){return{from:t,to:e,found:n,reason:r,steps:s}}}}function or(t,e,n,r,s){if(!n)switch(r){case"no-such-from":return`explainPath: no node named "${t}"`;case"no-such-to":return`explainPath: no node named "${e}"`;case"max-depth-exceeded":return`explainPath: no path from "${t}" to "${e}" within maxDepth`;default:return`explainPath: no path from "${t}" to "${e}"`}let o=[`Causal path: ${t} \u2192 ${e} (${s.length} step(s))`];for(let i of s){let d=` ${i.hop===0?"\xB7":"\u2193"} ${i.path} (${i.type}${i.status?`/${i.status}`:""})`;if(o.push(d),"value"in i&&o.push(` value: ${ir(i.value)}`),i.annotation!=null&&o.push(` annotation: ${i.annotation}`),i.lastMutation!=null){let u=i.lastMutation.actor;o.push(` actor: ${u.type}${u.id?`:${u.id}`:""}`)}}return o.join(`
|
|
2
|
-
`)}function
|
|
3
|
-
`)}function dr(t,e,n,r,s){let{x:o,y:i,w:a,h:d}=r;if(a<2||d<2){d>0&&on(t,e,o,i,a,s);return}de(t,e,o,i,n.boxTL);for(let l=o+1;l<o+a-1;l+=1)de(t,e,l,i,n.boxH);de(t,e,o+a-1,i,n.boxTR);for(let l=i+1;l<i+d-1;l+=1){de(t,e,o,l,n.boxV);for(let f=o+1;f<o+a-1;f+=1)ln(t,e,f,l," ","empty");de(t,e,o+a-1,l,n.boxV)}de(t,e,o,i+d-1,n.boxBL);for(let l=o+1;l<o+a-1;l+=1)de(t,e,l,i+d-1,n.boxH);de(t,e,o+a-1,i+d-1,n.boxBR);let u=i+Math.floor(d/2);on(t,e,o+1,u,a-2,s)}function de(t,e,n,r,s){ln(t,e,n,r,s,s===" "?"empty":s==="\u2500"||s==="-"?"boxH":s==="\u2502"||s==="|"?"boxV":"boxCorner")}function ln(t,e,n,r,s,o){if(r<0||r>=t.length)return;let i=t[r];n<0||n>=i.length||(i[n]=s,e[r][n]=o)}function on(t,e,n,r,s,o){if(r<0||r>=t.length)return;let i=n,a=s;for(let d of o){let u=Ye(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 lr(t,e,n,r){let s=r.points;if(s.length<2)return;for(let d=0;d+1<s.length;d+=1)cr(t,e,n,s[d],s[d+1]);for(let d=1;d+1<s.length;d+=1){let u=s[d-1],l=s[d],f=s[d+1],p=fr(u,l,f,n);p&&un(t,e,l.x,l.y,p,"edgeCorner")}let o=s[s.length-1],i=s[s.length-2],a=pr(i,o,n);a&&un(t,e,o.x,o.y,a,"arrow")}function cr(t,e,n,r,s){if(!(r.x===s.x&&r.y===s.y)){if(r.y===s.y){let o=r.y,i=Math.min(r.x,s.x),a=Math.max(r.x,s.x);for(let d=i;d<=a;d+=1)an(t,e,d,o,n,"h")}else if(r.x===s.x){let o=r.x,i=Math.min(r.y,s.y),a=Math.max(r.y,s.y);for(let d=i;d<=a;d+=1)an(t,e,o,d,n,"v")}}}function an(t,e,n,r,s,o){if(r<0||r>=t.length)return;let i=t[r];if(n<0||n>=i.length)return;let a=e[r][n];if(!(a==="boxH"||a==="boxV"||a==="boxCorner"||a==="label")){if(a==="empty"){i[n]=o==="h"?s.horizontal:s.vertical,e[r][n]=o==="h"?"edgeH":"edgeV";return}if(a==="edgeH"&&o==="v"){i[n]=s.cross,e[r][n]="edgeCorner";return}if(a==="edgeV"&&o==="h"){i[n]=s.cross,e[r][n]="edgeCorner";return}}}function un(t,e,n,r,s,o){if(r<0||r>=t.length)return;let i=t[r];if(n<0||n>=i.length)return;let a=e[r][n];a==="boxH"||a==="boxV"||a==="boxCorner"||a==="label"||(i[n]=s,e[r][n]=o)}function fr(t,e,n,r){let s=t.y===e.y,o=e.y===n.y;if(s===o)return;if(s){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 pr(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 hr(t){let e=t.length;for(;e>0&&t.charCodeAt(e-1)===32;)e-=1;return t.slice(0,e)}function pn(t){let e=gr(t);mr(e),br(e),yr(e),vr(e,t);let n=xr(e,t),{width:r,height:s}=Er(e),o=[];for(let i of e.layers)for(let a of i)a.isVirtual||o.push({id:a.id,layer:a.layer,order:a.order,x:a.x,y:a.y,w:a.w,h:a.h});return{boxes:o,edges:n,width:r,height:s}}function gr(t){let e=new Map;for(let s of t.nodes)e.set(s,{id:s,isVirtual:!1,layer:-1,order:0,x:0,y:0,w:t.widthCells(s),h:t.heightCells(s),in:[],out:[]});let n=[],r=0;for(let s of t.edges){if(s.from===s.to)continue;let o=e.get(s.from),i=e.get(s.to);if(!o||!i)continue;let a={chainId:r++,chainFrom:s.from,chainTo:s.to,fromId:s.from,toId:s.to,hopIndex:0,chainLen:1};o.out.push(a),i.in.push(a),n.push(a)}return{nodes:e,layers:[],hops:n}}function mr(t){let e=new Map;for(let o of t.nodes.values())e.set(o.id,o.in.length);let n=[];for(let o of t.nodes.values())(e.get(o.id)??0)===0&&(o.layer=0,n.push(o));let r=new Set,s=0;for(;s<n.length;){let o=n[s++];if(!r.has(o.id)){r.add(o.id);for(let i of o.out){let a=t.nodes.get(i.toId);a.layer=Math.max(a.layer,o.layer+1);let d=(e.get(a.id)??0)-1;e.set(a.id,d),d<=0&&n.push(a)}}}for(let o of t.nodes.values())o.layer<0&&(o.layer=0)}function br(t){let e=Math.max(0,...Array.from(t.nodes.values(),o=>o.layer)),n=Array.from({length:e+1},()=>[]);for(let o of t.nodes.values())n[o.layer].push(o);let r=[],s=0;for(let o of t.hops){let i=t.nodes.get(o.fromId),a=t.nodes.get(o.toId),d=a.layer-i.layer;if(d<=0){i.out=i.out.filter(f=>f!==o),a.in=a.in.filter(f=>f!==o);continue}if(d===1){o.hopIndex=0,o.chainLen=1,r.push(o);continue}i.out=i.out.filter(f=>f!==o),a.in=a.in.filter(f=>f!==o);let u=i;for(let f=1;f<d;f+=1){let p=`__virt_${s++}__`,h={id:p,isVirtual:!0,layer:i.layer+f,order:0,x:0,y:0,w:0,h:1,in:[],out:[]};t.nodes.set(p,h),n[h.layer].push(h);let c={chainId:o.chainId,chainFrom:o.chainFrom,chainTo:o.chainTo,fromId:u.id,toId:p,hopIndex:f-1,chainLen:d};u.out.push(c),h.in.push(c),r.push(c),u=h}let l={chainId:o.chainId,chainFrom:o.chainFrom,chainTo:o.chainTo,fromId:u.id,toId:a.id,hopIndex:d-1,chainLen:d};u.out.push(l),a.in.push(l),r.push(l)}for(let o of n)for(let i=0;i<o.length;i+=1)o[i].order=i;t.layers=n,t.hops=r}function yr(t){for(let n=0;n<4;n+=1){for(let r=1;r<t.layers.length;r+=1)cn(t,t.layers[r],"in"),Qe(t.layers[r]);for(let r=t.layers.length-2;r>=0;r-=1)cn(t,t.layers[r],"out"),Qe(t.layers[r])}for(let n=0;n<2;n+=1){let r=!1;for(let s=1;s<t.layers.length;s+=1){let o=t.layers[s];for(let i=0;i+1<o.length;i+=1){let a=fn(t,o[i],o[i+1],"in");[o[i],o[i+1]]=[o[i+1],o[i]],Qe(o),fn(t,o[i],o[i+1],"in")<a?r=!0:([o[i],o[i+1]]=[o[i+1],o[i]],Qe(o))}}if(!r)break}}function cn(t,e,n){let r=new Map;for(let s of e){let o=n==="in"?s.in:s.out;if(o.length===0){r.set(s.id,s.order);continue}let i=0,a=0;for(let d of o){let u=t.nodes.get(n==="in"?d.fromId:d.toId);u&&(i+=u.order,a+=1)}r.set(s.id,a===0?s.order:i/a)}e.sort((s,o)=>{let i=r.get(s.id),a=r.get(o.id);return i!==a?i-a:s.order-o.order})}function Qe(t){for(let e=0;e<t.length;e+=1)t[e].order=e}function fn(t,e,n,r){let s=r==="in"?e.in:e.out,o=r==="in"?n.in:n.out,i=0;for(let a of s)for(let d of o){let u=t.nodes.get(r==="in"?a.fromId:a.toId)?.order??0,l=t.nodes.get(r==="in"?d.fromId:d.toId)?.order??0;(e.order<n.order&&u>l||e.order>n.order&&u<l)&&(i+=1)}return i}function vr(t,e){e.direction==="LR"?_r(t,e):wr(t,e)}function _r(t,e){let n=[],r=0;for(let s=0;s<t.layers.length;s+=1){n.push(r);let o=0;for(let i of t.layers[s])o=Math.max(o,i.w);r+=o+e.layerGap}for(let s=0;s<t.layers.length;s+=1)for(let o of t.layers[s])o.x=n[s];for(let s of t.layers){let o=0;for(let i of s)i.y=o,o+=i.h+e.nodeGap}hn(t,e,"y")}function wr(t,e){let n=[],r=0;for(let s=0;s<t.layers.length;s+=1){n.push(r);let o=0;for(let i of t.layers[s])o=Math.max(o,i.h);r+=o+e.layerGap}for(let s=0;s<t.layers.length;s+=1)for(let o of t.layers[s])o.y=n[s];for(let s of t.layers){let o=0;for(let i of s)i.x=o,o+=i.w+e.nodeGap}hn(t,e,"x")}function hn(t,e,n){let r=o=>n==="y"?o.h:o.w,s=e.nodeGap;for(let o=0;o<2;o+=1){let i=o===0?t.layers.slice(1):t.layers.slice(0,-1).reverse();for(let a of i){let d=new Map;for(let l of a){let f=o===0?l.in:l.out;if(f.length===0)continue;let p=[];for(let c of f){let m=t.nodes.get(o===0?c.fromId:c.toId);if(!m)continue;let v=n==="y"?m.y:m.x;p.push(v+Math.floor(r(m)/2))}if(p.length===0)continue;p.sort((c,m)=>c-m);let h=p[Math.floor(p.length/2)];d.set(l.id,h-Math.floor(r(l)/2))}let u=0;for(let l of a){let f=d.get(l.id),p=n==="y"?l.y:l.x,c=Math.max(f??p,u);n==="y"?l.y=c:l.x=c,u=c+r(l)+s}}}}function xr(t,e){let n=new Map;for(let u of t.hops){let l=n.get(u.chainId);l?l.push(u):n.set(u.chainId,[u])}for(let u of n.values())u.sort((l,f)=>l.hopIndex-f.hopIndex);let r=e.direction==="LR",s=u=>r?u.x:u.y,o=u=>r?u.w:u.h,i=u=>r?u.y+Math.floor(u.h/2):u.x+Math.floor(u.w/2),a=new Map;for(let u=0;u+1<t.layers.length;u+=1){let l=t.layers[u],f=t.layers[u+1],p=0;for(let y of l)p=Math.max(p,s(y)+o(y));let h=Number.POSITIVE_INFINITY;for(let y of f)h=Math.min(h,s(y));let c=Number.isFinite(h)?h-1:p,m=Math.max(1,c-p+1),v=[];for(let y of l)for(let T of y.out)v.push(T);v.sort((y,T)=>{let R=i(t.nodes.get(y.fromId)),N=i(t.nodes.get(T.fromId));if(R!==N)return R-N;let k=i(t.nodes.get(y.toId)),S=i(t.nodes.get(T.toId));return k-S});let b=[],x=new Map;for(let y of v){let T=i(t.nodes.get(y.fromId)),R=i(t.nodes.get(y.toId)),N=Math.min(T,R),k=Math.max(T,R),S=-1;for(let M=0;M<b.length;M+=1){let j=b[M],V=!0;for(let le of j)if(le.lo<=k&&N<=le.hi){V=!1;break}if(V){j.push({lo:N,hi:k}),S=M;break}}S<0&&(b.push([{lo:N,hi:k}]),S=b.length-1),x.set(y,S)}let _=b.length,w=m>=Math.max(3,_+2),O=w?p+1:p,E=w?c-1:c,g=Math.max(1,E-O+1);for(let y of v){let T=x.get(y),R;if(_<=1)R=O+Math.floor(g/2);else{let N=(g-1)/(_-1);R=O+Math.floor(T*N)}a.set(y,Math.max(p,Math.min(c,R)))}}let d=[];for(let[,u]of n){let l=[];for(let p=0;p<u.length;p+=1){let h=u[p],c=t.nodes.get(h.fromId),m=t.nodes.get(h.toId),v=a.get(h),b=c.isVirtual?s(c):s(c)+o(c),x=m.isVirtual?s(m):s(m)-1,_=i(c),w=i(m);p===0&&Xe(l,r,b,_),_!==w&&(Xe(l,r,v,_),Xe(l,r,v,w)),Xe(l,r,x,w)}let f=u[0];d.push({from:f.chainFrom,to:f.chainTo,points:Tr(l)})}return d}function Xe(t,e,n,r){t.push(e?{x:n,y:r}:{x:r,y:n})}function Tr(t){let e=[];for(let n of t){let r=e[e.length-1];(!r||r.x!==n.x||r.y!==n.y)&&e.push(n)}return e}function Er(t){let e=0,n=0;for(let r of t.layers)for(let s of r)e=Math.max(e,s.x+s.w),n=Math.max(n,s.y+s.h);return{width:e,height:n}}var Or=24,Nr=4,kr=1,Rr=3;function gn(t,e){let n=Sr(e.direction),r=Math.max(3,e.maxLabelWidth??Or),s=e.asciiCharset??"unicode",o=Object.keys(t.nodes).sort(),i=new Set(o),a=t.edges.filter(h=>i.has(h.from)&&i.has(h.to)),d=new Map,u=new Map;for(let h of o){let c=sn(h,r);d.set(h,c),u.set(h,Ye(c)+4)}let l=pn({nodes:o,edges:a,widthCells:h=>u.get(h)??3,heightCells:()=>Rr,layerGap:Nr,nodeGap:kr,direction:n}),f=dn(l,{charset:s,labelOf:h=>d.get(h)??h}),p=e.logger;return p&&p(f),f}function Sr(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)}`)}me();function mn(t,e){let n=e?.topN??10,r=t.describe({detail:"standard"}),s=[],o=t._collectObserveTargets;typeof o=="function"&&o.call(t,"",s);let i=new Map;for(let[p,h]of s)i.set(p,h);let a=[];for(let[p,h]of Object.entries(r.nodes)){let c=i.get(p),m=c instanceof P?c:null,v=m?Xt(m.cache):0,b=m?m._sinkCount:0,x=h.deps?.length??0,_=h.type==="effect"&&b===0,w=b===0?h.type==="effect"?"orphan-effect":h.type==="derived"?"idle-derived":h.type==="producer"?"idle-producer":null:null;a.push({path:p,type:h.type,status:h.status??"unknown",valueSizeBytes:v,subscriberCount:b,depCount:x,isOrphanEffect:_,orphanKind:w})}let d=a.reduce((p,h)=>p+h.valueSizeBytes,0),u=(p,h)=>[...a].sort(h??((c,m)=>m[p]-c[p])).slice(0,n),l=a.filter(p=>p.orphanKind!=null),f=a.filter(p=>p.isOrphanEffect);return{nodeCount:a.length,edgeCount:r.edges.length,subgraphCount:r.subgraphs.length,nodes:a,totalValueSizeBytes:d,hotspots:{byValueSize:u("valueSizeBytes"),bySubscriberCount:u("subscriberCount"),byDepCount:u("depCount")},orphans:l,orphanEffects:f}}var I="::",ee="__meta__",ye=1;function bn(t,e){let n=Math.max(16,t.size*4),r=0;for(;t.size>0;){if(r++>=n){console.error(`[Graph "${e}".destroy] disposer drain exceeded cap (${n}); ${t.size} disposer(s) discarded`),t.clear();return}let s=t.values().next();if(s.done)return;let o=s.value;t.delete(o);try{o()}catch(i){console.error(`[Graph "${e}".destroy] disposer threw:`,i)}}}function Ar(t){let e=[];for(let n of Object.keys(t).sort()){let r=t[n].v;r!=null&&e.push(`${n} ${r.id} ${r.version}`)}return e.join(`
|
|
4
|
-
`)}function yn(t){if(t.version!==ye)throw new Error(`unsupported snapshot version ${String(t.version)} (expected ${ye})`);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
|
|
5
|
-
`);return e.logger?.(o),o}function
|
|
6
|
-
`)}function
|
|
7
|
-
`)}function Fr(t){return t.replace(/[.*+?^${}()|[\]\\]/g,"\\$&")}function Ze(t){let e="^";for(let n=0;n<t.length;n+=1){let r=t[n];if(r==="*"){e+=".*";continue}if(r==="?"){e+=".";continue}if(r==="["){let s=t.indexOf("]",n+1);if(s<=n+1){e+="\\[";continue}let o=t.slice(n+1,s);o.startsWith("!")&&(o=`^${o.slice(1)}`),o=o.replace(/\\/g,"\\\\"),e+=`[${o}]`,n=s;continue}e+=Fr(r)}return e+="$",new RegExp(e)}var Vr={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"},zr={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 jr(t){return t==="none"?zr:t==="ansi"||t==null?Vr:{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 vn(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 Br(t,e,n){for(let r=0;r<t.length;r++){let s=t.charCodeAt(r);if(s<32||s===127)throw new Error(`Graph "${e}": ${n} "${t}" must not contain control character (U+${s.toString(16).padStart(4,"0").toUpperCase()} at index ${r})`)}}function Nt(t,e,n){if(t==="")throw new Error(`Graph "${e}": ${n} name must be non-empty`);if(t.includes(I))throw new Error(`Graph "${e}": ${n} "${t}" must not contain '${I}' (path separator)`);if(t===ee)throw new Error(`Graph "${e}": ${n} name "${ee}" is reserved for meta companion paths`);Br(t,e,n)}function Hr(t,e){if(t==="")throw new Error(`Graph "${e}": resolve path must be non-empty`);let n=t.split(I);for(let r of n)if(r==="")throw new Error(`Graph "${e}": resolve path has empty segment`);return n}function Kr(t,e){let n=!1;for(let s of t)if(!e.isMetaPassthrough(s[0])){n=!0;break}return n?t.filter(s=>e.isMetaPassthrough(s[0])):t}function En(t){for(let e of t._mounts.values())En(e);for(let e of t._nodes.values())try{e.down([[B]],{internal:!0})}catch{}}var ve=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(I))throw new Error(`Graph name must not contain '${I}' (got "${e}")`);if(e===ee)throw new Error(`Graph name "${ee}" is reserved for meta companion paths`);this.name=e,this.opts=Object.freeze({...n??{}}),this.config=n?.config??Ee,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=be(e=>{let n=r=>{e.emit(r)};return this._topologyEmitters.add(n),()=>{this._topologyEmitters.delete(n)}},{name:`${this.name}_topology`})),this._topology}_emitTopology(e){if(!(this._topology==null||this._topologyEmitters.size===0))for(let n of this._topologyEmitters)n(e)}nameOf(e){return this._nodeToName.get(e)}add(e,n){let r=e.name,s=n?.name??r;if(s==null||s==="")throw new Error(`Graph "${this.name}": graph.add requires a non-empty name \u2014 pass via opts.name or set it on the node (e.g. state(0, { name: "x" }))`);let o=s,i=n?.annotation;if(Nt(o,this.name,"add"),this._mounts.has(o))throw new Error(`Graph "${this.name}": name "${o}" is already a mount point`);if(this._nodes.has(o))throw new Error(`Graph "${this.name}": node "${o}" already exists`);let a=this._nodeToName.get(e);if(a!==void 0)throw new Error(`Graph "${this.name}": node instance already registered as "${a}"`);return this._nodes.set(o,e),this._nodeToName.set(e,o),this._emitTopology({kind:"added",name:o,nodeKind:"node"}),i!=null&&(this._annotations.set(o,i),this.config.inspectorEnabled&&this._traceRing.push({path:o,annotation:i,timestamp_ns:te()})),e}setVersioning(e){if(e!=null)for(let n of this._nodes.values())n instanceof P&&n._applyVersioning(e)}remove(e){Nt(e,this.name,"remove");let n=this._mounts.get(e);if(n){let o={kind:"mount",nodes:[],mounts:[]},i=[];n._collectObserveTargets("",i);for(let[a,d]of i)a.includes(`${I}${ee}${I}`)||o.nodes.push(a);return o.nodes.sort(),o.mounts.push(e),o.mounts.push(...n._collectSubgraphs(`${e}${I}`)),this._mounts.delete(e),n._parent=void 0,En(n),this._emitTopology({kind:"removed",name:e,nodeKind:"mount",audit:o}),o}let r=this._nodes.get(e);if(!r)throw new Error(`Graph "${this.name}": unknown node or mount "${e}"`);this._nodes.delete(e),this._nodeToName.delete(r),r.down([[B]],{internal:!0});let s={kind:"node",nodes:[e],mounts:[]};return this._emitTopology({kind:"removed",name:e,nodeKind:"node",audit:s}),s}removeAll(e){let n=typeof e=="function"?e:(()=>{let o=Ze(e);return i=>o.test(i)})(),r={kind:"mount",nodes:[],mounts:[]},s=[...this._nodes.keys(),...this._mounts.keys()].filter(o=>n(o));for(let o of s){let i=this.remove(o);r.nodes.push(...i.nodes),r.mounts.push(...i.mounts)}return r.nodes.sort(),r.mounts.sort(),r}[Symbol.iterator](){let e=[...this._nodes.keys()].sort(),n=this._nodes,r=0;return{[Symbol.iterator](){return this},next(){if(r>=e.length)return{value:void 0,done:!0};let s=e[r++];return{value:[s,n.get(s)],done:!1}}}}node(e){if(e==="")throw new Error(`Graph "${this.name}": node name must be non-empty`);if(e.includes(I))return this.resolve(e);let n=this._nodes.get(e);if(!n)throw new Error(`Graph "${this.name}": unknown node "${e}"`);return n}get(e){return this.node(e).cache}set(e,n,r){let s=r?.internal===!0;this.node(e).down([[G,n]],{actor:r?.actor,internal:s,delivery:"write"})}setAll(e,n){let r=Symbol.iterator in e?e:Object.entries(e);K(()=>{for(let[s,o]of r)this.set(s,o,n)})}invalidate(e,n){let r=n?.internal===!0;this.node(e).down([[Q]],{actor:n?.actor,internal:r,delivery:"write"})}error(e,n,r){let s=r?.internal===!0;this.node(e).down([[C,n]],{actor:r?.actor,internal:s,delivery:"write"})}complete(e,n){let r=n?.internal===!0;this.node(e).down([[z]],{actor:n?.actor,internal:r,delivery:"write"})}edges(e){let n=e?.recursive===!0,r=new Map;if(!n){for(let[d,u]of this._nodes)r.set(u,d);let a=[];for(let[d,u]of this._nodes)if(u instanceof P)for(let l of u._deps){let f=r.get(l.node);f!=null&&a.push([f,d])}return a.sort((d,u)=>d[0]<u[0]?-1:d[0]>u[0]?1:d[1]<u[1]?-1:d[1]>u[1]?1:0),a}let s=[];this._collectObserveTargets("",s);let o=new Map;for(let[a,d]of s)o.set(d,a);let i=[];for(let[a,d]of s)if(d instanceof P)for(let u of d._deps){let l=o.get(u.node);l!=null&&i.push([l,a])}return i.sort((a,d)=>a[0]<d[0]?-1:a[0]>d[0]?1:a[1]<d[1]?-1:a[1]>d[1]?1:0),i}mount(e,n){if(n===void 0){let s=new t(e);return this.mount(e,s)}if(typeof n=="function"){let s=new t(e);return n(s),this.mount(e,s)}let r=n;if(Nt(e,this.name,"mount"),this._nodes.has(e))throw new Error(`Graph "${this.name}": cannot mount at "${e}" \u2014 node with that name exists`);if(this._mounts.has(e))throw new Error(`Graph "${this.name}": mount "${e}" already exists`);if(r===this)throw new Error(`Graph "${this.name}": cannot mount a graph into itself`);if(r._parent!=null)throw new Error(`Graph "${this.name}": this child graph is already mounted on "${r._parent.name}"`);for(let s=this;s!=null;s=s._parent)if(s===r)throw new Error(`Graph "${this.name}": mount("${e}", \u2026) would create a mount cycle`);return this._mounts.set(e,r),r._parent=this,this._emitTopology({kind:"added",name:e,nodeKind:"mount"}),r}resolve(e){let n=Hr(e,this.name);return this._resolveFromSegments(n)}tryResolve(e){try{return this.resolve(e)}catch{return}}_resolveFromSegments(e){let n=e;if(n[0]===this.name&&(n=n.slice(1),n.length===0))throw new Error(`Graph "${this.name}": resolve path ends at graph name only`);let r=n[0],s=n.slice(1);if(s.length===0){let a=this._nodes.get(r);if(a)return a;throw this._mounts.has(r)?new Error(`Graph "${this.name}": path ends at subgraph "${r}" \u2014 not a node (GRAPHREFLY-SPEC \xA73.5)`):new Error(`Graph "${this.name}": unknown name "${r}"`)}let o=this._nodes.get(r);if(o&&s.length>0&&s[0]===ee)return this._resolveMetaChainFromNode(o,s,n.join(I));let i=this._mounts.get(r);if(!i)throw this._nodes.has(r)?new Error(`Graph "${this.name}": "${r}" is a node; trailing path "${s.join(I)}" is invalid`):new Error(`Graph "${this.name}": unknown mount or node "${r}"`);return i.resolve(s.join(I))}_resolveMetaChainFromNode(e,n,r){let s=e,o=0,i=[...n];for(;o<i.length;){if(i[o]!==ee)throw new Error(`Graph "${this.name}": expected ${ee} segment in meta path "${r}"`);if(o+1>=i.length)throw new Error(`Graph "${this.name}": meta path requires a key after ${ee} in "${r}"`);let a=i[o+1],d=s.meta[a];if(!d)throw new Error(`Graph "${this.name}": unknown meta "${a}" in path "${r}"`);s=d,o+=2}return s}signal(e,n){if(n?.internal!==!0){for(let s of e)if(this.config.messageTier(s[0])===3)throw new Error(`Graph "${this.name}": Graph.signal() rejects tier-3 messages (DATA / RESOLVED). Broadcast is for control-plane tiers (START / DIRTY / INVALIDATE / PAUSE / RESUME / COMPLETE / ERROR / TEARDOWN). For per-node value writes, use Graph.set or graph.node(name).down(...).`)}let r=[];if(this._signalDeliver(e,n??{},new Set,r),r.length>0)throw r[0]}_signalDeliver(e,n,r,s){for(let d of this._mounts.values())d._signalDeliver(e,n,r,s);let i=n.internal===!0?{internal:!0}:{actor:n.actor,delivery:"signal"},a=Kr(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(l){if(l instanceof X)throw l;s.push(l)}a.length!==0&&this._signalMetaSubtree(u,a,r,i,s)}}}_signalMetaSubtree(e,n,r,s,o){for(let i of Object.keys(e.meta).sort()){let a=e.meta[i];if(!r.has(a)){r.add(a);try{a.down(n,s)}catch(d){if(d instanceof X)throw d;o.push(d)}this._signalMetaSubtree(a,n,r,s,o)}}}describe(e){if(e?.reactive===!0)return this._describeReactive(e);let n=e?.actor,r=e?.filter,s=Be(e?.detail,e?.fields),o=e?.format==="spec",i=o?Be("minimal"):s,a=[];this._collectObserveTargets("",a);let d=new Map;for(let[E,g]of a)d.set(g,E);let u=[];{let E=a.map(([,T])=>T),g=new Set(d.values()),y=0;for(;E.length>0;){let T=E.shift();if(T instanceof P)for(let R of T._deps){let N=R.node;if(d.has(N))continue;let k=N.name??"",S=k;if(!S||g.has(S))if(k){let M=2;for(;g.has(`${k}#${M}`);)M++;S=`${k}#${M}`}else for(S=`__internal__/${y++}`;g.has(S);)S=`__internal__/${y++}`;d.set(N,S),g.add(S),u.push([S,N]),E.push(N)}}}let l=[...a,...u],f={};for(let[E,g]of l){if(n!=null&&!g.allowsObserve(n))continue;let y=_t(g,i),T=g instanceof P?g._deps.map(S=>d.get(S.node)??S.node.name??""):[],{name:R,...N}=y,k={...N,deps:T};if(!o){let S=this._annotations.get(E);S!=null&&(k.annotation=S)}if(r!=null)if(typeof r=="function"){let S=r;if(!(S.length>=2?S(E,k):S(k)))continue}else{let S=!0;for(let[M,j]of Object.entries(r)){let V=M==="deps_includes"?"depsIncludes":M==="meta_has"?"metaHas":M;if(V==="depsIncludes"){if(!k.deps.includes(String(j))){S=!1;break}continue}if(V==="metaHas"){if(!Object.hasOwn(k.meta??{},String(j))){S=!1;break}continue}if(k[V]!==j){S=!1;break}}if(!S)continue}f[E]=k}let p=new Set(Object.keys(f)),h=[];for(let[E,g]of l)if(g instanceof P)for(let y of g._deps){let T=d.get(y.node);T!=null&&h.push([T,E])}h.sort((E,g)=>E[0]<g[0]?-1:E[0]>g[0]?1:E[1]<g[1]?-1:E[1]>g[1]?1:0);let c=h.map(([E,g])=>({from:E,to:g}));(n!=null||r!=null)&&(c=c.filter(E=>p.has(E.from)&&p.has(E.to)));let m=this._collectSubgraphs(""),v=n!=null||r!=null?m.filter(E=>{let g=`${E}${I}`;return[...p].some(y=>y===E||y.startsWith(g))}):m,b=this,x=e,_={name:this.name,nodes:f,edges:c,subgraphs:v,expand(E){let g={...x,format:void 0};return Array.isArray(E)?(g.fields=E,g.detail=void 0):(g.detail=E,g.fields=void 0),b.describe(g)}},w=e??{},O=w.format;return O==="json"?Lr(_,w):O==="pretty"?Ir(_,w):O==="mermaid"?xn(_,w):O==="mermaid-url"?Pr(_,w):O==="d2"?$r(_,w):O==="ascii"?gn(_,w):_}_collectSubgraphs(e){let n=[];for(let r of[...this._mounts.keys()].sort()){let s=e===""?r:`${e}${r}`;n.push(s),n.push(...this._mounts.get(r)._collectSubgraphs(`${s}${I}`))}return n}resourceProfile(e){return mn(this,e)}reachable(e,n,r={}){return r.withDetail===!0?Rt(this.describe(),e,n,{...r,withDetail:!0}):Rt(this.describe(),e,n,r)}explain(e,n,r){return r?.reactive===!0?this._explainReactive(e,n,r):this._explainStatic(e,n,r)}_explainStatic(e,n,r){let s=this.describe({detail:"full"}),o=new Map(this._annotations),i=new Map;for(let[a,d]of Object.entries(s.nodes))d.lastMutation!=null&&i.set(a,d.lastMutation);return Zt(s,e,n,{...r?.maxDepth!=null?{maxDepth:r.maxDepth}:{},...r?.findCycle===!0?{findCycle:!0}:{},annotations:o,lastMutations:i})}_describeReactive(e){let n={...e,reactive:!1},r=e.reactiveName??"describe",s=0,o=W(s,{name:`${r}_version`}),i=this.observe({timeline:!0,structured:!0}),a=!1,d=!1,u=()=>{a||d||(a=!0,Ae(()=>{a=!1,!d&&(s+=1,o.emit(s))}))},l=i.onEvent(v=>{let b=v.type;b!=="data"&&b!=="error"&&b!=="complete"&&b!=="teardown"||u()}),f=[],p=new WeakSet,h=v=>{if(p.has(v)||d)return;p.add(v);let b=v.topology.subscribe(x=>{for(let _ of x){if(_[0]!==G)continue;let w=_[1];if(u(),w.kind==="added"&&w.nodeKind==="mount"){let O=v._mounts.get(w.name);O!=null&&h(O)}}});f.push(b);for(let x of v._mounts.keys()){let _=v._mounts.get(x);_!=null&&h(_)}};h(this);let c;try{c=Z([o],()=>this.describe(n),{name:r,describeKind:"derived",meta:{domain:"audit",kind:"describe"},equals:(v,b)=>v===b})}catch(v){l();for(let b of f)b();throw i.dispose(),v}let m=ae(c);return{node:c,dispose(){d=!0,l();for(let v of f)v();f.length=0,i.dispose(),m()}}}_explainReactive(e,n,r){let s=0,o=W(s,{name:"explain_version"}),i=this.observe({timeline:!0,structured:!0}),a=!1,d=!1,u=i.onEvent(h=>{let c=h.type;c!=="data"&&c!=="error"&&c!=="complete"&&c!=="teardown"||a||d||(a=!0,Ae(()=>{a=!1,!d&&(s+=1,o.emit(s))}))}),l={...r?.maxDepth!=null?{maxDepth:r.maxDepth}:{},...r?.findCycle===!0?{findCycle:!0}:{}},f;try{f=Z([o],()=>this._explainStatic(e,n,l),{name:r?.name??"explain",describeKind:"derived",meta:{domain:"audit",kind:"explain_path",from:e,to:n},equals:(h,c)=>h.found===c.found&&h.reason===c.reason&&h.steps.length===c.steps.length&&qr(h.steps,c.steps)})}catch(h){throw u(),i.dispose(),h}let p=ae(f);return{node:f,dispose(){d=!0,u(),i.dispose(),p()}}}_pathsMatching(e){let n=Ze(e),r=[];return this._collectObserveTargets("",r),r.map(([s])=>s).filter(s=>n.test(s))}_collectObserveTargets(e,n){for(let r of[...this._mounts.keys()].sort()){let s=e===""?r:`${e}${I}${r}`;this._mounts.get(r)._collectObserveTargets(s,n)}for(let r of[...this._nodes.keys()].sort()){let s=this._nodes.get(r),o=e===""?r:`${e}${I}${r}`;n.push([o,s]),this._appendMetaObserveTargets(o,s,n)}}_appendMetaObserveTargets(e,n,r){for(let s of Object.keys(n.meta).sort()){let o=n.meta[s],i=`${e}${I}${ee}${I}${s}`;r.push([i,o]),this._appendMetaObserveTargets(i,o,r)}}observe(e,n){let r=typeof e=="string",o=vn(r?n:e),i=o.structured===!0||o.timeline===!0||o.causal===!0||o.derived===!0||o.detail==="minimal"||o.detail==="full"||o.format!=null,a=o.actor;if(r){let l=e,f=this.resolve(l);if(a!=null&&!f.allowsObserve(a))throw new X({actor:a,action:"observe",nodeName:l});return i?this._buildStructuredObserver([[l,f]],o,"one"):{subscribe(p){return f.subscribe(p)},up(p){try{f.up?.(p)}catch(h){if(h instanceof X)return;throw h}}}}let d=[];this._collectObserveTargets("",d),d.sort((l,f)=>l[0]<f[0]?-1:l[0]>f[0]?1:0);let u=a==null?d:d.filter(([,l])=>l.allowsObserve(a));return i?this._buildStructuredObserver(u,o,"all"):{subscribe:l=>{let f=u.map(([p,h])=>h.subscribe(c=>{l(p,c)}));return()=>{for(let p of f)p()}},up:(l,f)=>{try{this.resolve(l).up?.(f)}catch(p){if(p instanceof X)return;throw p}}}}_buildStructuredObserver(e,n,r){let s=r==="one"?e[0]?.[0]:void 0,o=i=>{if(r==="one"&&s!=null){let l=this.resolve(s);return this._buildStructuredObserver([[s,l]],i,"one")}let a=[];this._collectObserveTargets("",a),a.sort((l,f)=>l[0]<f[0]?-1:l[0]>f[0]?1:0);let d=i.actor,u=d==null?a:a.filter(([,l])=>l.allowsObserve(d));return this._buildStructuredObserver(u,i,"all")};return this._createObserveResult(e,n,o)}_createObserveResult(e,n,r){let s=n.timeline===!0,o=n.causal===!0,i=n.derived===!0,a=n.detail==="minimal",d=this.config.inspectorEnabled,u=(o||i)&&d,l=n.maxEvents,f=l!=null&&l>0?new Ce(l):null,p=[],h=new Set,c={},m=new Set,v=0,b=0,x=0,_=0,w=0,O=0,E=!1,g=!1,y=0,T=new Map,R=new Map,N=new Map,k=A=>{f?f.push(A):p.push(A);for(let L of h)L(A)},S=()=>s?{timestamp_ns:te(),in_batch:Se(),batch_id:y}:{},M=(A,L)=>{if(!(!u||!(A instanceof P)))return A._setInspectorHook(U=>{if(U.kind==="dep_message")T.set(A,U.depIndex);else if(U.kind==="run"){let Oe=U.batchData.map((D,H)=>D!=null&&D.length>0?D.at(-1):U.prevData[H]);R.set(A,Oe);let J=U.batchData.map(D=>D!=null?[...D]:void 0);N.set(A,J),i&&k({type:"derived",path:L,dep_values:Oe,dep_batches:J,...S()})}})},j=A=>{let L=T.get(A),U=R.get(A);if(!o||U==null)return{};let J=(L!=null&&L>=0&&A instanceof P?A._deps[L]:void 0)?.node,D=J?.v,H=N.get(A);return{trigger_dep_index:L,trigger_dep_name:J?.name,...D!=null?{trigger_version:{id:D.id,version:D.version}}:{},dep_values:[...U],...H!=null?{dep_batches:H}:{}}},V=[],le=[];for(let[A,L]of e){let U=M(L,A);U&&V.push(U),le.push(L.subscribe(Oe=>{y++;for(let J of Oe){let D=J[0],H=S();if(D===G){c[A]=J[1];let at=L instanceof P?L.lastMutation?.actor??_e:_e;k({type:"data",path:A,data:J[1],actor:at,...H,...j(L)})}else if(a)D===F?v++:D===q?b++:D===Q?x++:D===re?_++:D===se?w++:D===B?O++:D===z&&!m.has(A)?E=!0:D===C&&(g=!0,m.add(A));else if(D===F)v++,k({type:"dirty",path:A,...H});else if(D===q)b++,k({type:"resolved",path:A,...H,...j(L)});else if(D===Q)x++,k({type:"invalidate",path:A,...H});else if(D===re)_++,k({type:"pause",path:A,lockId:J[1],...H});else if(D===se)w++,k({type:"resume",path:A,lockId:J[1],...H});else if(D===z)m.has(A)||(E=!0),k({type:"complete",path:A,...H});else if(D===C){g=!0,m.add(A);let at=L instanceof P?L.lastMutation?.actor??_e:_e;k({type:"error",path:A,data:J[1],actor:at,...H})}else D===B&&(O++,k({type:"teardown",path:A,...H}))}}))}let st=!1,ot=()=>{if(!st){st=!0;for(let A of le)A();for(let A of V)A();for(let A of Ge)A({value:void 0,done:!0});Ge.length=0}},it=[],Ge=[];h.add(A=>{let L=Ge.shift();L?L({value:A,done:!1}):it.push(A)});let St={get values(){return c},get dirtyCount(){return v},get resolvedCount(){return b},get invalidateCount(){return x},get pauseCount(){return _},get resumeCount(){return w},get teardownCount(){return O},get events(){return f?f.toArray():[...p]},get anyCompletedCleanly(){return E},get anyErrored(){return g},get completedWithoutErrors(){return E&&!g},onEvent(A){return h.add(A),()=>h.delete(A)},dispose:ot,expand(A){ot();let L={...n};return typeof A=="string"?L.detail=A:Object.assign(L,A),r(vn(L))},[Symbol.asyncIterator](){return{next(){return it.length>0?Promise.resolve({value:it.shift(),done:!1}):st?Promise.resolve({value:void 0,done:!0}):new Promise(A=>Ge.push(A))},return(){return ot(),Promise.resolve({value:void 0,done:!0})}}}};return n.format!=null&&this._attachFormatLogger(St,n),St}_attachFormatLogger(e,n){let r=n.format;if(r==null)return;let s=n.logger??(c=>console.log(c)),o=n.includeTypes?new Set(n.includeTypes):null,i=n.excludeTypes?new Set(n.excludeTypes):null,a=o==null&&i==null?()=>!0:c=>(o==null||o.has(c))&&(i==null||!i.has(c)),d=jr(n.theme),u=r==="stage-log"?te():0,l=c=>c==null?"":n.stageLabels?.[c]??c,f=(c,m)=>c.length>m?`${c.slice(0,m-1)}\u2026`:c,p=c=>c.type==="data"||c.type==="error"?f(et(c.data),120):"",h=c=>{if(r==="stage-log"){let g=(te()-u)/1e9,y=l(c.path).padEnd(9);if(c.type==="data"){let T=p(c);return`[${g.toFixed(3)}s] ${y} \u2190${T?` ${T}`:""}`}if(c.type==="error"){let T=p(c);return`[${g.toFixed(3)}s] ${y} \u2717${T?` ${T}`:""}`}return c.type==="complete"?`[${g.toFixed(3)}s] ${y} \u25A0 complete`:`[${g.toFixed(3)}s] ${y} ${c.type}`}if(r==="json")try{return JSON.stringify(c)}catch{return JSON.stringify({type:c.type,path:c.path,data:"[unserializable]"})}let m=d[c.type]??"",v=c.path?`${d.path}${c.path}${d.reset} `:"",b=c.type==="data"||c.type==="error",x=c.type==="pause"||c.type==="resume",_=b?` ${et(c.data)}`:x?` ${et(c.lockId)}`:"",w=c.type==="data"||c.type==="resolved"||c.type==="derived"?c:void 0,O=w?.trigger_dep_name!=null?` <- ${w.trigger_dep_name}`:w?.trigger_dep_index!=null?` <- #${w.trigger_dep_index}`:"",E=c.in_batch?" [batch]":"";return`${v}${m}${c.type.toUpperCase()}${d.reset}${_}${O}${E}`};e.onEvent(c=>{a(c.type)&&s(h(c),c)})}addDisposer(e){return this._disposers.add(e),()=>{this._disposers.delete(e)}}destroy(){bn(this._disposers,this.name),this.signal([[B]],{internal:!0}),bn(this._storageDisposers,this.name);for(let e of[...this._mounts.values()])e._parent=void 0,e._destroyClearOnly();this._mounts.clear(),this._nodes.clear(),this._parent=void 0,this._destroyed=!0}get destroyed(){return this._destroyed}_destroyClearOnly(){for(let e of[...this._mounts.values()])e._parent=void 0,e._destroyClearOnly();this._mounts.clear(),this._nodes.clear(),this._parent=void 0,this._destroyed=!0}snapshot(e){let{expand:n,...r}=this.describe({detail:"full"}),s={};for(let a of Object.keys(r.nodes).sort()){let{lastMutation:d,guard:u,...l}=r.nodes[a];s[a]=l}let o=[...r.subgraphs].sort(),i={...r,version:1,nodes:s,subgraphs:o};if(e?.format==null)return i;if(e.format==="json-string")return JSON.stringify(i);if(e.format==="bytes"){if(e.codec==null)throw new Error("snapshot({format: 'bytes'}) requires a `codec` name");let a=this.config.lookupCodec(e.codec);if(a==null)throw new Error(`snapshot: codec "${e.codec}" is not registered on this graph's config. Call config.registerCodec(...) before creating nodes.`);return Ft(a,a.encode(i))}throw new Error(`snapshot: unknown format "${String(e.format)}"`)}static decode(e,n){let r=n?.config??Ee,{codec:s,codecVersion:o,payload:i}=Vt(e,r);return s.decode(i,o)}restore(e,n){if(yn(e),e.name!==this.name)throw new Error(`Graph "${this.name}": restore snapshot name "${e.name}" does not match this graph`);let r=n?.only==null?null:(Array.isArray(n.only)?n.only:[n.only]).map(o=>Ze(o)),s=n?.includeProducers===!0;for(let o of Object.keys(e.nodes).sort()){if(r!==null&&!r.some(a=>a.test(o)))continue;let i=e.nodes[o];if(i!==void 0){if(!("value"in i)||i.value===void 0){"value"in i&&i.value===void 0&&n?.onError?.(o,new Error(`restore: slice.value is undefined for "${o}" (undefined is the global SENTINEL; not valid DATA)`));continue}if(!(i.type==="derived"||i.type==="effect")&&!(i.type==="producer"&&!s)){if(i.v!=null){let d=this.tryResolve(o)?.v;if(d!=null&&d.id===i.v.id&&d.version===i.v.version)continue}try{this.set(o,i.value)}catch(a){n?.onError?.(o,a)}}}}}static fromSnapshot(e,n){yn(e);let r=typeof n=="function"?n:n?.build,s=typeof n=="function"?void 0:n?.factories,o=new t(e.name);if(r)return r(o),o.restore(e),o;for(let h of[...e.subgraphs].sort((c,m)=>{let v=c.split(I).length,b=m.split(I).length;return v!==b?v-b:c<m?-1:c>m?1:0})){let c=h.split(I),m=o;for(let v of c)m._mounts.has(v)||m.mount(v,new t(v)),m=m._mounts.get(v)}let i=s?Object.entries(s).map(([h,c])=>({re:Ze(h),factory:c})):[],a=h=>{for(let c of i)if(c.re.test(h))return c.factory},d=h=>{let c=h.split(I),m=c.pop();if(m==null||m.length===0)throw new Error(`invalid snapshot path "${h}"`);let v=o;for(let b of c){let x=v._mounts.get(b);if(!x)throw new Error(`unknown mount "${b}" in path "${h}"`);v=x}return[v,m]},u=Object.entries(e.nodes).filter(([h])=>!h.includes(`${I}${ee}${I}`)).sort((h,c)=>h[0]<c[0]?-1:h[0]>c[0]?1:0),l=new Map(u),f=new Map,p=!0;for(;l.size>0&&p;){p=!1;for(let[h,c]of[...l.entries()]){let m=c?.deps??[];if(!m.every(O=>f.has(O)))continue;let[v,b]=d(h),x={...c?.meta??{}},_=a(h),w;if(c?.type==="state")w=W(c.value,{meta:x});else{if(_==null)continue;w=_(b,{path:h,type:c.type,value:c.value,meta:x,deps:m,resolvedDeps:m.map(O=>f.get(O))})}v.add(w,{name:b}),f.set(h,w),l.delete(h),p=!0}}if(l.size>0){let h=[...l.keys()].sort().join(", ");throw new Error(`Graph.fromSnapshot could not reconstruct nodes without build callback: ${h}. Pass matching factories via fromSnapshot(data, { factories: { pattern: factoryFn } }).`)}return o.restore(e),o}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 s=(u,l)=>{if(u.disposed)return;let f=Ar(l.nodes);if(u.lastSnapshot!=null&&f!==""&&f===u.lastFingerprint)return;let p=u.seq+1,h=ne(),v=u.lastSnapshot==null||p%u.compactEvery===0?{name:this.name,mode:"full",snapshot:l,seq:p,timestamp_ns:h,format_version:ye}:{name:this.name,mode:"diff",diff:On(u.lastSnapshot,l),seq:p,timestamp_ns:h,format_version:ye};if(u.tier.filter&&!u.tier.filter(v))return;let b;try{b=u.tier.save(v)}catch(x){n.onError?.(x,u.tier);return}if(b&&typeof b.then=="function"){let w=(u.savePending??Promise.resolve()).then(()=>b,()=>b).then(()=>{u.disposed||(u.seq=p,u.lastSnapshot=l,u.lastFingerprint=f)},O=>{n.onError?.(O,u.tier)});u.savePending=w.finally(()=>{u.savePending===w&&(u.savePending=void 0)})}else u.seq=p,u.lastSnapshot=l,u.lastFingerprint=f},o=(u,l)=>{try{s(u,l)}catch(f){n.onError?.(f,u.tier)}},i=(u,l)=>{if(!l.some(c=>{let m=this.config.messageTier(c[0]);return m>=3&&m<5}))return;if(n.filter){let c=this.tryResolve(u);if(c==null)return;let m=_t(c,Be("standard"));if(!n.filter(u,m))return}let p,h=()=>(p==null&&(p=this.snapshot()),p);for(let c of r)c.disposed||(c.debounceMs===0?o(c,h()):(c.timer==null&&(c.timer=new Je),c.timer.start(c.debounceMs,()=>{c.disposed||o(c,this.snapshot())})))},a;if(n.paths!=null){let l=(typeof n.paths=="string"?this._pathsMatching(n.paths):n.paths).map(f=>{let p=this.tryResolve(f);return p==null?()=>{}:p.subscribe(h=>i(f,h))});a=()=>{for(let f of l)f()}}else a=this.observe().subscribe((u,l)=>i(u,l));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 s;try{s=await r.load?.()}catch(i){n?.(i,r);continue}if(s==null||typeof s!="object"||Array.isArray(s))continue;let o=s;try{if(o.mode==="full"&&o.snapshot!=null)return this.restore(o.snapshot),!0;if(o.version===ye&&o.nodes!=null)return this.restore(o),!0}catch(i){n?.(i,r)}}return!1}static async fromStorage(e,n,r){for(let s of n){let o;try{o=await s.load?.()}catch(d){r?.onError?.(d,s);continue}if(o==null||typeof o!="object"||Array.isArray(o))continue;let i=o,a=i.mode==="full"&&i.snapshot!=null?i.snapshot:i.version===ye&&i.nodes!=null?i:void 0;if(a!=null)try{return t.fromSnapshot(a,r)}catch(d){r?.onError?.(d,s)}}throw new Error(`Graph.fromStorage: no tier held a restorable record for "${e}" across ${n.length} tier(s)`)}_annotations=new Map;_traceRing;trace(e,n,r){if(e!=null&&n!=null){if(this.tryResolve(e)==null)return;if(this._annotations.set(e,n),this.config.inspectorEnabled){let s={path:e,annotation:n,timestamp_ns:te(),...r?.actor!=null?{actor:r.actor}:{}};this._traceRing.push(s)}return}return e!=null?this.config.inspectorEnabled?this._annotations.get(e):void 0:this.config.inspectorEnabled?this._traceRing.toArray():[]}annotation(e){return this._annotations.get(e)}clearTrace(){this._annotations.clear(),this._traceRing.clear()}pruneTrace(e){let n=this._traceRing.toArray().filter(s=>!e(s)),r=this._traceRing.size-n.length;this._traceRing.clear();for(let s of n)this._traceRing.push(s);return r}static diff(e,n){let r=new Set(Object.keys(e.nodes)),s=new Set(Object.keys(n.nodes)),o=[...s].filter(x=>!r.has(x)).sort(),i=[...r].filter(x=>!s.has(x)).sort(),a=[],d=[];for(let x of r){if(!s.has(x))continue;let _=e.nodes[x],w=n.nodes[x],O=_.v,E=w.v;O!=null&&E!=null&&O.id===E.id&&O.version!==E.version&&d.push({path:x,id:O.id,from:O.version,to:E.version});let g=O!=null&&E!=null&&O.id===E.id&&O.version===E.version;for(let y of["type","status","sentinel"]){let T=_[y],R=w[y];T!==R&&a.push({path:x,field:y,from:T,to:R})}if(!g)for(let y of["value","meta"]){let T=_[y],R=w[y];Mr(T,R)||a.push({path:x,field:y,from:T,to:R})}}let u=x=>`${x.from} ${x.to}`,l=new Set(e.edges.map(u)),f=new Set(n.edges.map(u)),p=n.edges.filter(x=>!l.has(u(x))),h=e.edges.filter(x=>!f.has(u(x))),c=new Set(e.subgraphs),m=new Set(n.subgraphs),v=[...m].filter(x=>!c.has(x)).sort(),b=[...c].filter(x=>!m.has(x)).sort();return{nodesAdded:o,nodesRemoved:i,nodesChanged:a,versionChanges:d,edgesAdded:p,edgesRemoved:h,subgraphsAdded:v,subgraphsRemoved:b}}};function On(t,e){let n=ve.diff(t,e),r={};for(let s of n.nodesAdded){let o=e.nodes[s];o!=null&&(r[s]=o)}return{...n,nodesAddedFull:r}}function Rt(t,e,n,r={}){let s={paths:[],depths:new Map,truncated:!1};if(!e)return r.withDetail?s:[];if(!r.both&&n!=="upstream"&&n!=="downstream")throw new Error('reachable: direction must be "upstream" or "downstream"');let o=r.maxDepth;if(o!=null&&(!Number.isInteger(o)||o<0))throw new Error("reachable: maxDepth must be an integer >= 0");if(o===0)return r.withDetail?s:[];let i=new Map,a=new Map,d=new Map,u=new Map,l=new Set;for(let[_,w]of Object.entries(t.nodes)){if(!_)continue;l.add(_);let O=w.deps??[];i.set(_,O);for(let E of O)E&&(l.add(E),a.has(E)||a.set(E,new Set),a.get(E).add(_))}for(let _ of t.edges){if(_==null||typeof _!="object")continue;let w=typeof _.from=="string"?_.from:"",O=typeof _.to=="string"?_.to:"";!w||!O||(l.add(w),l.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(!l.has(e))return r.withDetail?s:[];let f=r.both===!0,p=_=>{if(f){let g=i.get(_)??[],y=d.get(_),T=a.get(_),R=u.get(_),N=[...g];return y&&N.push(...y),T&&N.push(...T),R&&N.push(...R),N}if(n==="upstream"){let g=i.get(_)??[],y=d.get(_);return y?[...g,...y]:g}let w=a.get(_),O=u.get(_),E=w?[...w]:[];return O&&E.push(...O),E},h=new Set([e]),c=new Map,m=[{path:e,depth:0}],v=0,b=!1;for(;v<m.length;){let _=m[v++];if(o!=null&&_.depth>=o){p(_.path).length>0&&(b=!0);continue}for(let w of p(_.path))!w||h.has(w)||(h.add(w),c.set(w,_.depth+1),m.push({path:w,depth:_.depth+1}))}let x=[...c.keys()].sort((_,w)=>_<w?-1:_>w?1:0);return r.withDetail?{paths:x,depths:c,truncated:b}:x}function qr(t,e){if(t.length!==e.length)return!1;for(let n=0;n<t.length;n++){let r=t[n],s=e[n];if(r.path!==s.path||r.type!==s.type||r.status!==s.status||r.hop!==s.hop||r.dep_index!==s.dep_index||r.annotation!==s.annotation||r.value!==s.value||r.lastMutation!==s.lastMutation)return!1;let o=r.v,i=s.v;if(o!==i&&(o==null||i==null||o.id!==i.id||o.version!==i.version))return!1}return!0}Te();ue();var Wr=Pt((t,e)=>{t("observe"),t("signal"),e("write")});function Nn(t){let e=Ke([],{name:t.name,maxSize:t.retainedLimit??1024,guard:t.guard??Wr,...t.versioning!=null?{versioning:t.versioning}:{}});return e.withLatest(),t.graph&&t.graph.add(e.entries,{name:t.name}),e}function kn(t,e,n=0){let r=W(n,{name:e,describeKind:"state"});return t.add(r,{name:e}),r}He();function Rn(t,e,n){return{[t]:!0,[`${t}_type`]:e,...n??{}}}var Ur=256,Jr=1024;function Sn(t,e){if(!Number.isFinite(t)||!Number.isInteger(t)||t<0)throw new Error(`${e} must be a non-negative integer`);return t}function tt(t,e){return Rn("job_queue",t,e)}var Yr=t=>t.action,nt=class extends ve{_pending;_jobs;_seqCursor;pending;jobs;depth;events;audit;constructor(e,n={}){super(e,n.graph),this._pending=Ut([],{name:"pending"}),this._jobs=Qt({name:"jobs"}),this.pending=this._pending.items,this.jobs=this._jobs.entries,this.add(this.pending,{name:"pending"}),this.add(this.jobs,{name:"jobs"}),this.depth=Z([this.pending],([r])=>r.length,{name:"depth",describeKind:"derived",meta:tt("queue_depth"),initial:0}),this.add(this.depth,{name:"depth"}),this.addDisposer(ae(this.depth)),this.events=Nn({name:"events",retainedLimit:1024,graph:this}),this.audit=this.events,this._seqCursor=kn(this,"seq",0)}_bumpSeq(){let n=(this._seqCursor.cache??0)+1;return this._seqCursor.emit(n),n}attachEventStorage(e){return this.events.attachStorage(e)}enqueue(e,n={}){let r=this._bumpSeq(),s=n.id??`${this.name}-${r}`;if(this._jobs.get(s)!==void 0)throw new Error(`jobQueue("${this.name}"): duplicate job id "${s}"`);let o={id:s,payload:e,attempts:0,metadata:Object.freeze({...n.metadata??{}}),state:"queued"};return this._jobs.set(s,o),this._pending.append(s),this.events.append({action:"enqueue",id:s,payload:e,t_ns:ne(),seq:r}),s}claim(e=1){let n=Sn(e,"job queue claim limit");if(n===0)return[];let r=[];for(;r.length<n&&this.pending.cache.length!==0;){let o=this._pending.pop(0),i=this._jobs.get(o);if(!i||i.state!=="queued")continue;let a={...i,state:"inflight",attempts:i.attempts+1};this._jobs.set(o,a),r.push(a),this.events.append({action:"claim",id:o,attempts:a.attempts,t_ns:ne(),seq:this._bumpSeq()})}return r}ack(e){let n=this._jobs.get(e);return!n||n.state!=="inflight"?!1:(this._jobs.delete(e),this.events.append({action:"ack",id:e,attempts:n.attempts,t_ns:ne(),seq:this._bumpSeq()}),!0)}nack(e,n={}){let r=this._jobs.get(e);return!r||r.state!=="inflight"?!1:n.requeue??!0?(this._jobs.set(e,{...r,state:"queued"}),this._pending.append(e),this.events.append({action:"nack",id:e,attempts:r.attempts,t_ns:ne(),seq:this._bumpSeq()}),!0):(this._jobs.delete(e),this.events.append({action:"nack",id:e,attempts:r.attempts,t_ns:ne(),seq:this._bumpSeq()}),!0)}removeById(e){let n=this._jobs.get(e);if(!n)return!1;if(n.state==="queued"){let s=this.pending.cache.indexOf(e);s>=0&&this._pending.pop(s)}return this._jobs.delete(e),this.events.append({action:"remove",id:e,attempts:n.attempts,t_ns:ne(),seq:this._bumpSeq()}),!0}consumeFrom(e,n){return e.subscribe(r=>{for(let s of r){if(s[0]!==G)continue;let o=s[1];this.enqueue(o,n?{metadata:n.metadata}:void 0)}})}},rt=class extends ve{_stageNames;_stageWorkFns;_queues=new Map;_completed;completed;completedCount;constructor(e,n={}){super(e,n.graph);let r=n.stages??["incoming","processing","done"],s=[],o=new Map;for(let d of r){let u=typeof d=="string"?d.trim():d.name.trim();typeof d!="string"&&d.work&&o.set(u,d.work),s.push(u)}if(s.length<2)throw new Error(`jobFlow("${e}"): requires at least 2 stages`);if(new Set(s).size!==s.length)throw new Error(`jobFlow("${e}"): stage names must be unique`);this._stageNames=Object.freeze([...s]),this._stageWorkFns=o;for(let d of this._stageNames){let u=An(`${e}-${d}`);this._queues.set(d,u),this.mount(d,u)}this._completed=Ke([],{name:"completed",maxSize:Jr}),this.completed=this._completed.entries,this.add(this.completed,{name:"completed"}),this.completedCount=Z([this.completed],([d])=>d.length,{name:"completedCount",describeKind:"derived",meta:tt("job_flow_completed_count"),initial:0}),this.add(this.completedCount,{name:"completedCount"}),this.addDisposer(ae(this.completedCount));let a=Math.max(1,Sn(n.maxPerPump??Ur,"job flow maxPerPump"));for(let d=0;d<this._stageNames.length;d+=1){let u=this._stageNames[d],l=this.queue(u),f=d+1<this._stageNames.length?this.queue(this._stageNames[d+1]):null,p=this._stageWorkFns.get(u),h=f===null;if(p){let c=ie([l.pending],()=>{let m=0;for(;m<a;){let v=l.claim(1);if(v.length===0)break;let b=v[0];if(!b)break;let _=[...b.metadata.job_flow_path??[],u],w;try{w=p(b)}catch{l.nack(b.id,{requeue:!1}),m+=1;continue}let O=Yt(w),E=!1,g;g=O.subscribe(y=>{if(!E){for(let T of y)if(T[0]===G){E=!0,g?g():Promise.resolve().then(()=>g?.());let R=T[1],N={...b.metadata,job_flow_path:_};if(h){let k={...b,payload:R,metadata:Object.freeze(N)};K(()=>{l.ack(b.id),this._completed.append(k)})}else K(()=>{l.ack(b.id),f.enqueue(R,{metadata:N})});return}else if(T[0]===C){E=!0,g?g():Promise.resolve().then(()=>g?.()),l.nack(b.id,{requeue:!1});return}}}),m+=1}},{name:`pump_${u}`,describeKind:"effect",meta:tt("job_flow_pump",{stage:u,has_work:!0})});this.add(c,{name:`pump_${u}`}),this.addDisposer(ae(c))}else{let c=ie([l.pending],()=>{let m=0;for(;m<a;){let v=l.claim(1);if(v.length===0)break;let b=v[0];if(!b)break;let _=[...b.metadata.job_flow_path??[],u],w={...b.metadata,job_flow_path:_};if(h){let O={...b,metadata:Object.freeze(w)};K(()=>{l.ack(b.id),this._completed.append(O)})}else K(()=>{l.ack(b.id),f.enqueue(b.payload,{metadata:w})});m+=1}},{name:`pump_${u}`,describeKind:"effect",meta:tt("job_flow_pump",{stage:u,has_work:!1})});this.add(c,{name:`pump_${u}`}),this.addDisposer(ae(c))}}}stages(){return this._stageNames}queue(e){let n=this._queues.get(e);if(!n)throw new Error(`jobFlow("${this.name}"): unknown stage "${e}"`);return n}enqueue(e,n={}){return this.queue(this._stageNames[0]).enqueue(e,n)}retainedCompleted(){return this.completed.cache}};function An(t,e){return new nt(t,e)}function Qr(t,e){return new rt(t,e)}0&&(module.exports={JobFlowGraph,JobQueueGraph,jobEventKeyOf,jobFlow,jobQueue});
|
|
1
|
+
"use strict";var ut=Object.defineProperty;var Dn=Object.getOwnPropertyDescriptor;var Cn=Object.getOwnPropertyNames;var Gn=Object.prototype.hasOwnProperty;var Y=(t,e)=>()=>(t&&(e=t(t=0)),e);var Ln=(t,e)=>{for(var n in e)ut(t,n,{get:e[n],enumerable:!0})},In=(t,e,n,r)=>{if(e&&typeof e=="object"||typeof e=="function")for(let s of Cn(e))!Gn.call(t,s)&&s!==n&&ut(t,s,{get:()=>e[s],enumerable:!(r=Dn(e,s))||r.enumerable});return t};var Pn=t=>In(ut({},"__esModule",{value:!0}),t);function te(){return Math.trunc(performance.now()*1e6)}function ne(){return Date.now()*1e6}var Ne=Y(()=>{"use strict"});function Le(t){if(t==null)return _e;let{type:e,id:n,...r}=t;return{type:e??"system",id:n??"",...r}}var _e,Ie=Y(()=>{"use strict";_e={type:"system",id:""}});function Se(){return we>0||ke}function At(){return we>0}function Ae(t){we>0?Re.push(t):t()}function K(t){we+=1;let e=!1;try{t()}catch(n){throw e=!0,n}finally{if(we-=1,we===0)if(e){if(!ke){let n=Re.splice(0);for(let r of n)try{r()}catch{}ce.length=0,fe.length=0,xe.length=0}}else $n()}}function $n(){let t=!ke;t&&(ke=!0);let e=[],n=0;try{for(;ce.length>0||fe.length>0||xe.length>0||t&&Re.length>0;){if(t&&Re.length>0){let o=Re.splice(0);for(let i of o)try{i()}catch(a){e.push(a)}continue}if(n+=1,n>1e3)throw ce.length=0,fe.length=0,xe.length=0,new Error("batch drain exceeded 1000 iterations \u2014 likely a reactive cycle");let s=(ce.length>0?ce:fe.length>0?fe:xe).splice(0);for(let o of s)try{o()}catch(i){e.push(i)}}}finally{t&&(ke=!1)}if(e.length===1)throw e[0];if(e.length>1)throw new AggregateError(e,"batch drain: multiple callbacks threw")}function Me(t,e,n){if(e.length===0)return;if(e.length===1){let u=n(e[0][0]);if(u<3||!Se()){t(e);return}(u>=5?xe:u===4?fe:ce).push(()=>t(e));return}let r=e.length,s=r,o=r,i=r,a=0;for(;a<r&&n(e[a][0])<3;)a++;for(s=a;a<r&&n(e[a][0])===3;)a++;for(o=a;a<r&&n(e[a][0])===4;)a++;i=a;let d=Se();if(s>0){let u=e.slice(0,s);t(u)}if(o>s){let u=e.slice(s,o);d?ce.push(()=>t(u)):t(u)}if(i>o){let u=e.slice(o,i);d?fe.push(()=>t(u)):t(u)}if(r>i){let u=e.slice(i,r);d?xe.push(()=>t(u)):t(u)}}var we,ke,ce,fe,xe,Re,pe=Y(()=>{"use strict";we=0,ke=!1,ce=[],fe=[],xe=[],Re=[]});var he,G,F,q,Q,re,se,j,V,D,ge,Pe,Mt,$e,Dt,Ct,Fe,dt,lt,ct,Ve,oe=Y(()=>{"use strict";he=Symbol.for("graphrefly/START"),G=Symbol.for("graphrefly/DATA"),F=Symbol.for("graphrefly/DIRTY"),q=Symbol.for("graphrefly/RESOLVED"),Q=Symbol.for("graphrefly/INVALIDATE"),re=Symbol.for("graphrefly/PAUSE"),se=Symbol.for("graphrefly/RESUME"),j=Symbol.for("graphrefly/TEARDOWN"),V=Symbol.for("graphrefly/COMPLETE"),D=Symbol.for("graphrefly/ERROR"),ge=Object.freeze([F]),Pe=Object.freeze([q]),Mt=Object.freeze([Q]),$e=Object.freeze([he]),Dt=Object.freeze([V]),Ct=Object.freeze([j]),Fe=Object.freeze([ge]),dt=Object.freeze([Pe]),lt=Object.freeze([Mt]),ct=Object.freeze([Dt]),Ve=Object.freeze([Ct])});function Gt(t){t.registerMessageType(he,{tier:0,wireCrossing:!1}),t.registerMessageType(F,{tier:1,wireCrossing:!1}),t.registerMessageType(Q,{tier:1,wireCrossing:!1,metaPassthrough:!1}),t.registerMessageType(re,{tier:2,wireCrossing:!1}),t.registerMessageType(se,{tier:2,wireCrossing:!1}),t.registerMessageType(G,{tier:3,wireCrossing:!0}),t.registerMessageType(q,{tier:3,wireCrossing:!0}),t.registerMessageType(V,{tier:4,wireCrossing:!0,metaPassthrough:!1}),t.registerMessageType(D,{tier:4,wireCrossing:!0,metaPassthrough:!1}),t.registerMessageType(j,{tier:5,wireCrossing:!0,metaPassthrough:!1})}var ze,Lt=Y(()=>{"use strict";oe();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 It(t){return Array.isArray(t)?[...t]:[t]}function Fn(t,e){return t.has(e)||t.has("*")}function Pt(t){let e=[];return t((s,o)=>{e.push({kind:"allow",actions:new Set(It(s)),where:o?.where??(()=>!0)})},(s,o)=>{e.push({kind:"deny",actions:new Set(It(s)),where:o?.where??(()=>!0)})}),(s,o)=>{let i=!1,a=!1;for(let d of e)Fn(d.actions,o)&&d.where(s)&&(d.kind==="deny"?i=!0:a=!0);return i?!1:a}}function ft(t){let e=Vn.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 X,Vn,Te=Y(()=>{"use strict";X=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}};Vn=["human","llm","wallet","system"]});function Ft(t,e){let n=new TextEncoder().encode(t.name);if(n.length===0||n.length>255)throw new Error(`encodeEnvelope: codec name "${t.name}" encodes to ${n.length} bytes (must be 1\u2013255)`);let r=t.version;if(!Number.isInteger(r)||r<0||r>65535)throw new Error(`encodeEnvelope: codec.version ${r} out of u16 range (expected integer 0\u201365535)`);let s=2+n.length+2+e.length;if(s>4294967295)throw new Error(`encodeEnvelope: total envelope size ${s} exceeds 2^32-1 bytes (payload ${e.length} bytes)`);let o=new Uint8Array(s),i=0;return o[i++]=pt,o[i++]=n.length,o.set(n,i),i+=n.length,o[i++]=r>>>8&255,o[i++]=r&255,o.set(e,i),o}function Vt(t,e){if(t.length<$t)throw new Error(`decodeEnvelope: bytes too short (${t.length} < ${$t})`);let n=0,r=t[n++];if(r!==pt)throw new Error(`decodeEnvelope: unsupported envelope version ${r} (expected ${pt})`);let s=t[n++];if(s===0)throw new Error("decodeEnvelope: name_len must be >= 1");if(n+s+2>t.length)throw new Error(`decodeEnvelope: envelope truncated (need ${n+s+2} bytes, have ${t.length})`);let o=new TextDecoder().decode(t.subarray(n,n+s));n+=s;let i=(t[n]<<8|t[n+1])>>>0;n+=2;let a=t.subarray(n),d=e.lookupCodec(o);if(d==null)throw new Error(`decodeEnvelope: codec "${o}" not registered (envelope codec_v=${i})`);return{codec:d,codecVersion:i,payload:a}}function zt(t){t.registerCodec(zn)}var zn,pt,$t,ht=Y(()=>{"use strict";zn={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)}},pt=1,$t=4});function gt(t){if(t===void 0)return null;if(typeof t=="number"){if(!Number.isFinite(t))throw new TypeError(`Cannot hash non-finite number: ${t}`);if(Number.isInteger(t)&&!Number.isSafeInteger(t))throw new TypeError(`Cannot hash integer outside safe range (|n| > 2^53-1): ${t}. Cross-language cid parity is not guaranteed for unsafe integers.`);return t}if(typeof t=="string"||typeof t=="boolean"||t===null)return t;if(Array.isArray(t))return t.map(gt);if(typeof t=="object"&&t!==null){let e={};for(let n of Object.keys(t).sort())e[n]=gt(t[n]);return e}return null}function Hn(t){let e=Bn.encode(t),n=e.length,r=n*8,s=n+9+63&-64,o=new Uint8Array(s);o.set(e),o[n]=128;let i=new DataView(o.buffer);i.setUint32(s-4,r>>>0,!1),i.setUint32(s-8,Math.floor(r/4294967296)>>>0,!1);let a=1779033703,d=3144134277,u=1013904242,l=2773480762,f=1359893119,p=2600822924,h=528734635,c=1541459225,m=new Uint32Array(64),x=(_,b)=>_>>>b|_<<32-b;for(let _=0;_<s;_+=64){for(let N=0;N<16;N++)m[N]=i.getUint32(_+N*4,!1);for(let N=16;N<64;N++){let k=m[N-15],S=m[N-2],M=x(k,7)^x(k,18)^k>>>3,B=x(S,17)^x(S,19)^S>>>10;m[N]=m[N-16]+M+m[N-7]+B>>>0}let b=a,w=d,O=u,T=l,g=f,y=p,E=h,R=c;for(let N=0;N<64;N++){let k=x(g,6)^x(g,11)^x(g,25),S=g&y^~g&E,M=R+k+S+jn[N]+m[N]>>>0,B=x(b,2)^x(b,13)^x(b,22),z=b&w^b&O^w&O,le=B+z>>>0;R=E,E=y,y=g,g=T+M>>>0,T=O,O=w,w=b,b=M+le>>>0}a=a+b>>>0,d=d+w>>>0,u=u+O>>>0,l=l+T>>>0,f=f+g>>>0,p=p+y>>>0,h=h+E>>>0,c=c+R>>>0}let v=_=>_.toString(16).padStart(8,"0");return v(a)+v(d)+v(u)+v(l)+v(f)+v(p)+v(h)+v(c)}function mt(t){let e=gt(t??null),n=JSON.stringify(e);return Hn(n).slice(0,16)}function Kn(){let t=globalThis.crypto;if(t?.randomUUID)return t.randomUUID();let e=()=>Math.floor(Math.random()*4294967296).toString(16).padStart(8,"0"),n=e()+e()+e()+e();return`${n.slice(0,8)}-${n.slice(8,12)}-4${n.slice(13,16)}-${(parseInt(n.slice(16,17),16)&3|8).toString(16)}${n.slice(17,20)}-${n.slice(20,32)}`}function bt(t,e,n){let r=n?.id??Kn();if(t===0)return{id:r,version:0};let o=(n?.hash??mt)(e);return{id:r,version:0,cid:o,prev:null}}function jt(t,e,n){t.version+=1,"cid"in t&&(t.prev=t.cid,t.cid=n(e))}var jn,Bn,Bt=Y(()=>{"use strict";jn=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]),Bn=new TextEncoder});function qt(t){return{node:t,unsub:null,prevData:void 0,dirty:!1,involvedThisWave:!1,dataBatch:[],terminal:void 0}}function yt(t){t.prevData=void 0,t.dirty=!1,t.involvedThisWave=!1,t.dataBatch.length=0,t.terminal=void 0}function je(t){return t.length===0?t:typeof t[0]=="symbol"?[t]:t}function ie(t,e,n){let r=Wt(t)?t:[],s=typeof t=="function"?t:typeof e=="function"?e:void 0,o={};return Wt(t)?o=(vt(e)?e:n)??{}:vt(t)?o=t:o=(vt(e)?e:n)??{},new P(r,s,o)}var Ht,Kt,qn,Wn,Ee,P,Wt,vt,me=Y(()=>{"use strict";ht();Ie();pe();Ne();Lt();Te();oe();Bt();Ht=()=>{},Kt=100;qn=(t,e,n,r)=>{n.direction==="down-in"&&t._onDepMessage(n.depIndex,e)},Wn=(t,e,n,r)=>{let s=t;if(s._status==="completed"||s._status==="errored")return;let o=s._cached,i=o===void 0?[$e]:[$e,[G,o]];s._status==="dirty"&&i.push(ge),Me(e,i,s._config.tierOf)},Ee=new ze({onMessage:qn,onSubscribe:Wn});Gt(Ee);zt(Ee);P=class t{_optsName;_describeKind;meta;_hasMeta;_config;_deps;_sinks=null;_sinkCount=0;_cached;_status;_cleanup;_store={};_waveHasNewData=!1;_hasNewTerminal=!1;_hasCalledFnOnce=!1;_paused=!1;_pendingWave=!1;_isExecutingFn=!1;_pendingRerun=!1;_rerunDepth=0;_dirtyDepCount=0;_batchPendingMessages=null;_pauseLocks=null;_pauseBuffer=null;_fn;_equals;_resubscribable;_resetOnTeardown;_autoComplete;_autoError;_pausable;_partial;_guard;_extraGuards;_hashFn;_versioning;_versioningLevel;_lastMutation;_inspectorHooks;_actions;constructor(e,n,r){this._config=r.config??Ee,this._config.onMessage,this._optsName=r.name,this._describeKind=r.describeKind,this._equals=r.equals??Object.is,this._resubscribable=r.resubscribable??!1,this._resetOnTeardown=r.resetOnTeardown??!1,this._autoComplete=r.completeWhenDepsComplete??!0,this._autoError=r.errorWhenDepsError??!0,this._pausable=r.pausable??!0,this._guard=r.guard,this._fn=n,this._partial=r.partial??!1,this._cached=r.initial!==void 0?r.initial:void 0,this._status=e.length===0&&n==null&&this._cached!==void 0?"settled":"sentinel",this._hashFn=r.versioningHash??this._config.defaultHashFn??mt;let s=r.versioning??this._config.defaultVersioning;this._versioningLevel=s,this._versioning=s!=null?bt(s,this._cached===void 0?void 0:this._cached,{id:r.versioningId,hash:this._hashFn}):void 0,this._deps=e.map(qt);let o={};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),o[a]=new t([],void 0,u)}Object.freeze(o),this.meta=o,this._hasMeta=Object.keys(o).length>0;let i=this;this._actions={emit(a){i._emit([[G,a]])},down(a){i._emit(je(a))},up(a){i._emitUp(je(a))}},this.down=this.down.bind(this),this.up=this.up.bind(this)}get _isTerminal(){return this._status==="completed"||this._status==="errored"}get name(){return this._optsName}get status(){return this._status}get cache(){return this._cached===void 0?void 0:this._cached}get lastMutation(){return this._lastMutation}get v(){return this._versioning}hasGuard(){return this._guard!=null}_applyVersioning(e,n){if(this._isExecutingFn)throw new Error(`Node "${this.name}": _applyVersioning cannot run mid-fn \u2014 call it outside of \`_execFn\` (typically at graph setup time before the first subscribe).`);let r=this._versioningLevel;if(r!=null&&e<=r)return;let s=n?.hash??this._hashFn;s!==this._hashFn&&(this._hashFn=s);let o=this._cached===void 0?void 0:this._cached,i=this._versioning,a=i?.id??n?.id,d=i?.version??0,u=bt(e,o,{id:a,hash:s});u.version=d,this._versioning=u,this._versioningLevel=e}_setInspectorHook(e){return e==null?()=>{}:(this._inspectorHooks==null&&(this._inspectorHooks=new Set),this._inspectorHooks.add(e),()=>{this._inspectorHooks?.delete(e),this._inspectorHooks?.size===0&&(this._inspectorHooks=void 0)})}_pushGuard(e){return this._extraGuards==null&&(this._extraGuards=new Set),this._extraGuards.add(e),()=>{this._extraGuards?.delete(e),this._extraGuards?.size===0&&(this._extraGuards=void 0)}}allowsObserve(e){if(this._guard==null&&this._extraGuards==null)return!0;let n=Le(e);if(this._guard!=null&&!this._guard(n,"observe"))return!1;if(this._extraGuards!=null){for(let r of this._extraGuards)if(!r(n,"observe"))return!1}return!0}_checkGuard(e){if(e?.internal)return;let n=this._guard!=null||this._extraGuards!=null,r=e?.actor!=null;if(!n&&!r)return;let s=Le(e?.actor),o=e?.delivery==="signal"?"signal":"write";if(this._guard!=null&&!this._guard(s,o))throw new X({actor:s,action:o,nodeName:this.name});if(this._extraGuards!=null){for(let i of this._extraGuards)if(!i(s,o))throw new X({actor:s,action:o,nodeName:this.name})}this._lastMutation={actor:s,timestamp_ns:ne()}}down(e,n){let r=je(e);r.length!==0&&(this._checkGuard(n),this._emit(r))}emit(e,n){this._checkGuard(n),this._emit([[G,e]])}up(e,n){if(this._deps.length===0)return;let r=je(e);if(r.length===0)return;this._checkGuard(n);let s=n??{internal:!0};this._validateUpTiers(r);for(let o of this._deps)o.node.up?.(r,s)}_emitUp(e){if(this._deps.length!==0&&e.length!==0){this._validateUpTiers(e);for(let n of this._deps)n.node.up?.(e,{internal:!0})}}_validateUpTiers(e){let n=this._config.tierOf;for(let r of e){let s=n(r[0]);if(s===3||s===4)throw new Error(`Node "${this.name}": tier-${s} messages cannot flow up \u2014 DATA/RESOLVED/COMPLETE/ERROR are downstream-only. Use \`down(...)\` for value delivery; \`up(...)\` is for control signals (DIRTY, INVALIDATE, PAUSE, RESUME, TEARDOWN).`)}}subscribe(e,n){if(n!=null&&this._guard!=null){let d=Le(n);if(!this._guard(d,"observe"))throw new X({actor:d,action:"observe",nodeName:this.name})}let s=this._isTerminal&&this._resubscribable;if(s){this._cached=void 0,this._status="sentinel",this._store={},this._hasCalledFnOnce=!1,this._waveHasNewData=!1,this._hasNewTerminal=!1,this._paused=!1,this._pendingWave=!1,this._pendingRerun=!1,this._isExecutingFn=!1,this._rerunDepth=0,this._dirtyDepCount=0,this._pauseLocks=null,this._pauseBuffer=null;for(let d of this._deps)yt(d);if(this._partial===!1){for(let d of this._deps)if(d.prevData!==void 0||d.dataBatch.length!==0||d.terminal!==void 0||d.dirty)throw new Error(`resubscribable-reset invariant: DepRecord not fully reset for node ${this._optsName??"(anonymous)"}`)}}this._sinkCount+=1;let o;try{o=this._config.onSubscribe(this,e,{sinkCount:this._sinkCount,afterTerminalReset:s},this._actions)}catch(d){throw this._sinkCount-=1,d}this._sinks==null?this._sinks=e:typeof this._sinks=="function"?this._sinks=new Set([this._sinks,e]):this._sinks.add(e);let i=this._isTerminal;if(this._sinkCount===1&&!i)try{this._activate()}catch(d){if(this._sinkCount-=1,this._removeSink(e),this._sinkCount===0&&(this._status="sentinel"),typeof o=="function")try{o()}catch{}throw d}this._status==="sentinel"&&this._cached===void 0&&(this._status="pending");let a=!1;return()=>{a||(a=!0,this._sinkCount-=1,this._removeSink(e),typeof o=="function"&&o(),this._sinks==null&&this._deactivate())}}_removeSink(e){if(this._sinks===e)this._sinks=null;else if(this._sinks!=null&&typeof this._sinks!="function")if(this._sinks.delete(e),this._sinks.size===1){let[n]=this._sinks;this._sinks=n}else this._sinks.size===0&&(this._sinks=null)}_activate(){if(this._deps.length===0){this._fn&&this._execFn();return}this._dirtyDepCount=0;let e=this._deps.length,n=0;try{for(let r=0;r<e;r++){let s=r,o=this._deps[r];o.unsub=Ht,o.unsub=o.node.subscribe(i=>{if(o.unsub===null)return;let a=this._config.tierOf,d=!1;for(let u of i)a(u[0])>=3&&(d=!0),this._config.onMessage(this,u,{direction:"down-in",depIndex:s},this._actions);d&&this._maybeRunFnOnSettlement()}),n++}}catch(r){this._deps[n].unsub=null;for(let s=0;s<n;s++){let o=this._deps[s];if(o.unsub!=null){let i=o.unsub;o.unsub=null;try{i()}catch{}yt(o)}}throw this._dirtyDepCount=0,r}}_addDep(e){for(let s=0;s<this._deps.length;s++)if(this._deps[s].node===e)return s;let n=this._deps.length,r=qt(e);if(this._deps.push(r),this._sinks==null)return n;r.dirty=!0,this._dirtyDepCount++,this._status!=="dirty"&&this._emit(Fe),r.unsub=Ht;try{r.unsub=e.subscribe(s=>{if(r.unsub===null)return;let o=this._config.tierOf,i=!1;for(let a of s)o(a[0])>=3&&(i=!0),this._config.onMessage(this,a,{direction:"down-in",depIndex:n},this._actions);i&&this._maybeRunFnOnSettlement()})}catch(s){throw r.unsub=null,this._deps.pop(),this._dirtyDepCount--,s}return n}_deactivate(e=!1){let n=this._cleanup;if(this._cleanup=void 0,typeof n=="function")try{n()}catch(r){this._emit([[D,this._wrapFnError("cleanup threw",r)]])}else if(n!=null&&typeof n=="object"){let r=n.deactivate;if(typeof r=="function")try{r()}catch(s){this._emit([[D,this._wrapFnError("cleanup.deactivate threw",s)]])}}for(let r of this._deps){if(r.unsub!=null){let s=r.unsub;r.unsub=null;try{s()}catch{}}yt(r)}this._waveHasNewData=!1,this._hasNewTerminal=!1,this._hasCalledFnOnce=!1,this._paused=!1,this._pendingWave=!1,this._pendingRerun=!1,this._rerunDepth=0,this._store={},this._dirtyDepCount=0,this._pauseLocks=null,this._pauseBuffer=null,this._fn!=null&&(this._cached=void 0),e||(this._fn!=null||this._deps.length>0)&&(!this._isTerminal||this._resubscribable)&&(this._status="sentinel")}_onDepMessage(e,n){let r=this._deps[e],s=n[0];if(this._inspectorHooks!=null){let o={kind:"dep_message",depIndex:e,message:n};for(let i of this._inspectorHooks)i(o)}if(s!==he){if(s===F){this._depDirtied(r);return}if(s===Q){if(this._depInvalidated(r),this._cached===void 0)return;this._emit(lt);return}if(s===re||s===se){this._emit([n]);return}if(s===j){this._emit(Ve);return}if(s===G)this._depSettledAsData(r,n[1]);else if(s===q)this._depSettledAsResolved(r);else if(s===V)this._depSettledAsTerminal(r,!0);else if(s===D)this._depSettledAsTerminal(r,n[1]);else{this._emit([n]);return}if(!this._fn){(s===G||s===q)&&this._emit([n]),(s===V||s===D)&&this._maybeAutoTerminalAfterWave();return}}}_depDirtied(e){e.dirty||(e.dirty=!0,e.involvedThisWave=!0,this._dirtyDepCount++,this._status!=="dirty"&&this._emit(Fe))}_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(dt),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([[D,e.terminal]]);return}this._autoComplete&&this._deps.every(n=>n.terminal!==void 0)&&this._emit(ct)}_execFn(){if(!this._fn||this._isTerminal&&!this._resubscribable)return;if(this._isExecutingFn){this._pendingRerun=!0;return}let e=this._cleanup;if(typeof e=="function"){this._cleanup=void 0;try{e()}catch(i){this._emit([[D,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([[D,this._wrapFnError("cleanup.beforeRun threw",a)]]);return}}}let n=this._deps.map(i=>i.involvedThisWave?i.dataBatch.length>0?[...i.dataBatch]:[]:void 0),r=this._deps.map(i=>i.prevData);for(let i=0;i<this._deps.length;i++){let a=n[i];a!=null&&a.length>0&&(this._deps[i].prevData=a[a.length-1])}let s=this._deps.map(i=>i.terminal),o={prevData:r,terminalDeps:s,store:this._store};if(this._hasCalledFnOnce=!0,this._clearWaveFlags(),this._inspectorHooks!=null){let i={kind:"run",batchData:n,prevData:r};for(let a of this._inspectorHooks)a(i)}this._isExecutingFn=!0;try{let i=this._fn(n,this._actions,o);if(typeof i=="function")this._cleanup=i;else if(i!=null&&typeof i=="object"){let a=i;(typeof a.beforeRun=="function"||typeof a.deactivate=="function"||typeof a.invalidate=="function")&&(this._cleanup=i)}}catch(i){this._emit([[D,this._wrapFnError("fn threw",i)]])}finally{this._isExecutingFn=!1,this._pendingRerun?(this._pendingRerun=!1,this._rerunDepth+=1,this._rerunDepth>Kt?(this._rerunDepth=0,this._emit([[D,new Error(`Node "${this.name}": _pendingRerun depth exceeded ${Kt} \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"?[ge,e[0]]:e;let r=!0,s=!1,o=!1,i=-1;for(let d of e){let u=n(d[0]);u<i&&(r=!1),u===3&&(s=!0),d[0]===F&&(o=!0),i=u}let a=e;if(!r){let d=e.map((u,l)=>({m:u,i:l,tier:n(u[0])}));d.sort((u,l)=>u.tier-l.tier||u.i-l.i),a=d.map(u=>u.m)}if(s&&!o&&this._status!=="dirty"){let d=0;for(;d<a.length&&n(a[d][0])===0;)d++;return d===0?[ge,...a]:[...a.slice(0,d),ge,...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&&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]===j||d[0]===Q);if(a.length===0)return;n=a}n=this._frameBatch(n);let s=null;for(let a=0;a<n.length;a++){let d=n[a],u=d[0];if(u!==re&&u!==se){s?.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 l=!0;if(this._pausable!==!1){let f=d[1];if(u===re)this._pauseLocks==null&&(this._pauseLocks=new Set),this._pauseLocks.add(f),this._paused=!0,this._pausable==="resumeAll"&&this._pauseBuffer==null&&(this._pauseBuffer=[]);else if(this._pauseLocks==null||!this._pauseLocks.has(f))l=!1;else if(this._pauseLocks.delete(f),this._pauseLocks.size===0){if(this._paused=!1,this._pauseBuffer!=null&&this._pauseBuffer.length>0){let p=this._pauseBuffer;this._pauseBuffer=[],this._emit(p)}this._pendingWave&&(this._pendingWave=!1,this._maybeRunFnOnSettlement())}}l?s?.push(d):s==null&&(s=n.slice(0,a))}if(s!=null){if(s.length===0)return;n=s}if(this._hasMeta&&n.some(a=>a[0]===j))for(let a of Object.keys(this.meta))try{this.meta[a]._emit(Ve)}catch{}let{finalMessages:o,equalsError:i}=this._updateState(n);if(o.length>0&&this._config.inspectorEnabled){let a=this._config.globalInspector;if(a!=null)try{a({kind:"emit",node:this,messages:o})}catch{}}if(o.length>0)if(this._paused&&this._pausable==="resumeAll"&&this._pauseBuffer!=null){let a=this._config.tierOf,d=[];for(let u of o)a(u[0])===3?this._pauseBuffer.push(u):d.push(u);d.length>0&&this._dispatchOrAccumulate(d)}else this._dispatchOrAccumulate(o);i!=null&&this._emit([[D,i]])}_updateState(e){let n=this._config.tierOf,r,s,o=-1,i=0;for(let l of e)n(l[0])===3&&i++;let a=i<=1,d=-1;if(this._versioning!=null&&i>1){for(let l=e.length-1;l>=0;l--)if(e[l][0]===G){d=l;break}}for(let l=0;l<e.length;l++){let f=e[l],p=f[0];if(p===G){if(f.length>=2){let h=!1;if(a&&this._cached!==void 0)try{h=this._equals(this._cached,f[1])}catch(c){s=this._wrapFnError("equals threw",c),o=l;break}if(h){r==null&&(r=e.slice(0,l)),r.push(Pe),this._status="resolved";continue}this._cached=f[1],this._versioning!=null&&(d<0||l===d)&&jt(this._versioning,f[1],this._hashFn)}this._status="settled",r?.push(f)}else if(r?.push(f),p===F)this._status="dirty";else if(p===q)this._status="resolved";else if(p===V){this._status="completed";{let h=this._config.rigorRecorder;if(h!=null)try{h.onTerminalTransition(this,"completed",this._autoComplete,this._autoError,this._deps.length>0)}catch{}}}else if(p===D){this._status="errored";{let h=this._config.rigorRecorder;if(h!=null)try{h.onTerminalTransition(this,"errored",this._autoComplete,this._autoError,this._deps.length>0)}catch{}}}else if(p===Q){if(this._cached!==void 0){let c=this._config.rigorRecorder;if(c!=null)try{c.onNonVacuousInvalidate(this,this._cached)}catch{}}this._cached=void 0,this._status="dirty";let h=this._cleanup;if(typeof h=="function"){this._cleanup=void 0;try{h()}catch{}}else if(h!=null&&typeof h=="object"){let c=h.invalidate;if(typeof c=="function")try{c()}catch{}}}else p===j&&(this._resetOnTeardown&&(this._cached=void 0),this._deactivate(!0),this._status="sentinel")}let u=o>=0?r??e.slice(0,o):r??e;return s!=null?{finalMessages:u,equalsError:s}:{finalMessages:u}}_deliverToSinks=e=>{if(this._sinks==null)return;if(typeof this._sinks=="function"){this._sinks(e);return}let n=[...this._sinks];for(let r of n)r(e)};_dispatchOrAccumulate(e){if(At()){this._batchPendingMessages===null&&(this._batchPendingMessages=[],Ae(()=>this._flushBatchPending()));for(let n of e)this._batchPendingMessages.push(n);return}Me(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);Me(this._deliverToSinks,n,this._config.tierOf)}},Wt=t=>Array.isArray(t),vt=t=>typeof t=="object"&&t!=null&&!Array.isArray(t)});function W(t,e){return ie([],{...e,initial:t})}function be(t,e){return ie((r,s,o)=>t(s,o)??void 0,{describeKind:"producer",...e})}function Z(t,e,n){return ie(t,(s,o,i)=>{let a=s.map((d,u)=>d!=null&&d.length>0?d.at(-1):i.prevData[u]);o.emit(e(a,i))},{describeKind:"derived",...n})}var ue=Y(()=>{"use strict";me()});function xt(t){return{describeKind:"producer",...t}}function Jt(t,e){return be(n=>{let r=!1;try{for(let s of t){if(r)return;n.emit(s)}r||n.down([[V]])}catch(s){r||n.down([[D,s]])}return()=>{r=!0}},xt(e))}function Yn(t){return t!=null&&typeof t.then=="function"}function Qn(t,e){let{signal:n,...r}=e??{};return be(s=>{let o=!1,i=()=>{o||(o=!0,s.down([[D,n.reason]]))};if(n?.aborted){i();return}return n?.addEventListener("abort",i,{once:!0}),Promise.resolve(t).then(a=>{o||(o=!0,n?.removeEventListener("abort",i),s.emit(a),s.down([[V]]))},a=>{o||(o=!0,n?.removeEventListener("abort",i),s.down([[D,a]]))}),()=>{o=!0,n?.removeEventListener("abort",i)}},xt(r))}function Xn(t,e){let{signal:n,...r}=e??{};return be(s=>{let o=new AbortController,i=()=>o.abort(n?.reason);n?.aborted?o.abort(n.reason):n?.addEventListener("abort",i,{once:!0});let a=n??o.signal,d=!1,u=t[Symbol.asyncIterator](),l=()=>{d||a.aborted||Promise.resolve(u.next()).then(f=>{if(!(d||a.aborted)){if(f.done){s.down([[V]]);return}s.emit(f.value),l()}},f=>{!d&&!a.aborted&&s.down([[D,f]])})};return l(),()=>{d=!0,n?.removeEventListener("abort",i),o.abort(),Promise.resolve(u.return?.()).catch(()=>{})}},xt(r))}function Zn(t){return t!=null&&typeof t=="object"&&"cache"in t&&typeof t.subscribe=="function"}function Yt(t,e){if(Zn(t))return t;if(Yn(t))return Qn(t,e);if(t!=null){let n=t;if(typeof n[Symbol.asyncIterator]=="function")return Xn(t,e);if(typeof n[Symbol.iterator]=="function")return Jt(t,e)}return er(t)}function er(...t){return Jt(t,void 0)}function ae(t){return t.subscribe(()=>{})}var He=Y(()=>{"use strict";oe();ue()});var Je,rn=Y(()=>{"use strict";Je=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 es={};Ln(es,{JobFlowGraph:()=>rt,JobQueueGraph:()=>nt,jobEventKeyOf:()=>Xr,jobFlow:()=>Zr,jobQueue:()=>Mn});module.exports=Pn(es);Ne();Ie();pe();Te();oe();Te();me();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;default:return new Set(["type","deps"])}}function Un(t){return t._describeKind!=null?t._describeKind:t._deps.length>0?"derived":t._fn!=null?"producer":"state"}function Jn(t){let e={};for(let[n,r]of Object.entries(t.meta))try{e[n]=r.cache}catch{}return e}function _t(t,e){let n=e==null,r=!n&&e!=null?[...e].filter(u=>u.startsWith("meta.")).map(u=>u.slice(5)):null,s=n||e.has("meta")||r!=null&&r.length>0,o="state",i=[];t instanceof P&&(o=Un(t),i=t._deps.map(u=>u.node.name??""));let a={type:o,deps:i};(n||e.has("status"))&&(a.status=t.status);let d=t instanceof P?t._guard:void 0;if(s){let u={...Jn(t)};if(d!=null&&u.access===void 0&&(u.access=ft(d)),r!=null&&r.length>0&&!e.has("meta")){let l={};for(let f of r)f in u&&(l[f]=u[f]);a.meta=l}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=ft(d)),(n||e.has("lastMutation"))&&t.lastMutation!=null&&(a.lastMutation=t.lastMutation),a}ue();me();pe();oe();ue();var wt=class{_version=0;_buf;constructor(e){this._buf=e?[...e]:[]}get version(){return this._version}get size(){return this._buf.length}at(e){if(!Number.isInteger(e))return;let n=e>=0?e:this._buf.length+e;if(!(n<0||n>=this._buf.length))return this._buf[n]}append(e){this._buf.push(e),this._version+=1}appendMany(e){if(e.length===0)return;let n=this._buf.length;this._buf.length=n+e.length;for(let r=0;r<e.length;r++)this._buf[n+r]=e[r];this._version+=1}insert(e,n){if(!Number.isInteger(e)||e<0||e>this._buf.length)throw new RangeError(`insert: index ${e} out of range [0, ${this._buf.length}]`);this._buf.splice(e,0,n),this._version+=1}insertMany(e,n){if(!Number.isInteger(e)||e<0||e>this._buf.length)throw new RangeError(`insertMany: index ${e} out of range [0, ${this._buf.length}]`);n.length!==0&&(this._buf.splice(e,0,...n),this._version+=1)}pop(e){if(this._buf.length===0)throw new RangeError("pop from empty list");if(!Number.isInteger(e))throw new RangeError(`pop: index ${e} must be an integer`);let n=e>=0?e:this._buf.length+e;if(n<0||n>=this._buf.length)throw new RangeError(`pop: index ${e} out of range`);let[r]=this._buf.splice(n,1);return this._version+=1,r}clear(){let e=this._buf.length;return e===0?0:(this._buf.length=0,this._version+=1,e)}toArray(){return[...this._buf]}};function Ut(t,e={}){let{name:n,versioning:r,backend:s}=e,o=s??new wt(t),i=W(o.toArray(),{name:n,describeKind:"state",equals:(u,l)=>u===l,...r!=null?{versioning:r}:{}});function a(){let u=o.toArray();K(()=>{i.down([[F]]),i.down([[G,u]])})}function d(u){let l=o.version;try{return u()}finally{o.version!==l&&a()}}return{items:i,get size(){return o.size},at(u){return o.at(u)},append(u){d(()=>o.append(u))},appendMany(u){d(()=>o.appendMany(u))},insert(u,l){d(()=>o.insert(u,l))},insertMany(u,l){d(()=>o.insertMany(u,l))},pop(u=-1){return d(()=>o.pop(u))},clear(){d(()=>o.clear())},dispose(){}}}pe();oe();me();ue();var Tt=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),s=e.length-r;for(let o=0;o<r;o++)this._buf[o]=e[s+o];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),s=Math.min(e,this._size);if(s>=r)return[];let o=r-s;if(this._maxSize===void 0)return this._buf.slice(s,r);let i=new Array(o);for(let a=0;a<o;a++)i[a]=this._buf[(this._head+s+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 o=0;o<n;o++)this._buf[o]=void 0;this._head=0;let r=Math.min(e.length,n),s=e.length-r;for(let o=0;o<r;o++)this._buf[o]=e[s+o];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 De(t){return t.subscribe(()=>{})}var tr=64;function Ke(t,e={}){let{name:n,maxSize:r,versioning:s,guard:o,backend:i}=e,a=i??new Tt(t,r),d=W(a.toArray(),{name:n,describeKind:"state",equals:(g,y)=>g===y,...s!=null?{versioning:s}:{},...o!=null?{guard:o}:{}});function u(){let g=a.toArray();K(()=>{d.down([[F]],{internal:!0}),d.down([[G,g]],{internal:!0})})}let l=new Map,f=new Map,p=new Map;function h(g,y){return`${g}:${y===void 0?"END":y}`}function c(g){if(g.size<tr)return;let y=g.keys().next();if(y.done)return;let E=g.get(y.value);E!==void 0&&E.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=l.get(g);if(y!==void 0)return l.delete(g),l.set(g,y),y.node;c(l);let E=Z([d],([N])=>{let k=N;return g===0||k.length===0?[]:k.slice(Math.max(0,k.length-g))},{initial:a.tail(g),describeKind:"derived"}),R=De(E);return l.set(g,{node:E,dispose:R}),E}function v(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 E=h(g,y),R=f.get(E);if(R!==void 0)return f.delete(E),f.set(E,R),R.node;c(f);let N=Z([d],([S])=>{let M=S;return y===void 0?M.slice(g):M.slice(g,y)},{initial:a.slice(g,y),describeKind:"derived"}),k=De(N);return f.set(E,{node:N,dispose:k}),N}function _(g){let y=p.get(g);if(y!==void 0)return y.node;let E=Z([d,g],([N,k])=>{let S=N,M=Math.max(0,Math.trunc(k??0));return S.slice(M)},{initial:[],describeKind:"derived"}),R=De(E);return p.set(g,{node:E,dispose:R}),E}let b,w;function O(){b===void 0&&(b=ie([d],(g,y,E)=>{let R=g[0],k=R!=null&&R.length>0?R.at(-1):E.prevData[0];if(k==null||k.length===0){y.down([[q]]);return}y.emit(k[k.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}),De(b),De(w))}let T={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 O(),d},get lastValue(){return O(),b},get hasLatest(){return O(),w},view(g){switch(g.kind){case"tail":return x(g.n);case"slice":return v(g.start,g.stop);case"fromCursor":return _(g.cursor)}},attach(g){let y=g.subscribe(E=>{for(let R of E)R[0]===G&&T.append(R[1])});return()=>y()},attachStorage(g){if(g.length===0)return()=>{};let y=new Map;for(let R of g)y.set(R,a.size);(async()=>{for(let R of g)if(typeof R.loadEntries=="function")try{let N=await Promise.resolve(R.loadEntries());N.entries.length>0&&a.size===0&&(a.restore(N.entries),y.set(R,N.entries.length),u());break}catch{}})();let E=d.subscribe(R=>{for(let N of R){if(N[0]!==G)continue;let k=N[1];for(let S of g){let M=y.get(S)??0;if(k.length<M){try{let z=S.appendEntries(k);z instanceof Promise&&z.catch(()=>{})}catch{}y.set(S,k.length);continue}if(k.length===M)continue;let B=k.slice(M);y.set(S,k.length);try{let z=S.appendEntries(B);z instanceof Promise&&z.catch(()=>{})}catch{}}}});return()=>E()},disposeAllViews(){for(let g of l.values())g.dispose();l.clear();for(let g of f.values())g.dispose();f.clear();for(let g of p.values())g.dispose();p.clear()},dispose(){for(let g of l.values())g.dispose();l.clear();for(let g of f.values())g.dispose();f.clear();for(let g of p.values())g.dispose();p.clear()}};return T}pe();Ne();oe();ue();var Et=class{_version=0;_store=new Map;_maxSize;_defaultTtl;constructor(e={}){let{maxSize:n,defaultTtl:r}=e;if(n!==void 0&&n<1)throw new RangeError("maxSize must be >= 1");if(r!==void 0&&r<=0)throw new RangeError("defaultTtl must be positive");this._maxSize=n,this._defaultTtl=r}get version(){return this._version}get size(){return this._store.size}has(e){let n=this._store.get(e);return n===void 0?!1:this._isExpired(n)?(this._store.delete(e),this._version+=1,!1):(this._touchLru(e,n),!0)}get(e){let n=this._store.get(e);if(n!==void 0){if(this._isExpired(n)){this._store.delete(e),this._version+=1;return}return this._touchLru(e,n),n.value}}set(e,n,r){let s=this._resolveExpiresAt(r);this._store.has(e)&&this._store.delete(e),this._store.set(e,{value:n,expiresAt:s}),this._evictLruWhileOver(),this._version+=1}setMany(e,n){let r=this._resolveExpiresAt(n),s=0;try{for(let[o,i]of e)this._store.has(o)&&this._store.delete(o),this._store.set(o,{value:i,expiresAt:r}),s+=1}finally{s>0&&(this._evictLruWhileOver(),this._version+=1)}}delete(e){let n=this._store.delete(e);return n&&(this._version+=1),n}deleteMany(e){let n=0;try{for(let r of e)this._store.delete(r)&&(n+=1)}finally{n>0&&(this._version+=1)}return n}clear(){let e=this._store.size;return e===0?0:(this._store.clear(),this._version+=1,e)}pruneExpired(){let e=te(),n=0;for(let[r,s]of this._store)this._isExpired(s,e)&&(this._store.delete(r),n+=1);return n>0&&(this._version+=1),n}toMap(){let e=te(),n=new Map;for(let[r,s]of this._store)this._isExpired(s,e)||n.set(r,s.value);return n}_resolveExpiresAt(e){let n=e??this._defaultTtl;if(n!==void 0){if(!Number.isFinite(n)||n<=0)throw new RangeError(`MapBackend: ttl must be a positive finite number (got ${n})`);return te()+n*1e9}}_isExpired(e,n){return e.expiresAt===void 0?!1:(n??te())>=e.expiresAt}_touchLru(e,n){this._store.delete(e),this._store.set(e,n)}_evictLruWhileOver(){if(this._maxSize!==void 0)for(;this._store.size>this._maxSize;){let e=this._store.keys().next().value;if(e===void 0)break;this._store.delete(e)}}};function Qt(t={}){let{name:e,maxSize:n,defaultTtl:r,versioning:s,backend:o,retention:i}=t;if(i&&n!==void 0)throw new RangeError("reactiveMap: `maxSize` (LRU) and `retention` (score-based) are mutually exclusive. Pick one eviction policy.");if(i&&i.archiveThreshold===void 0&&i.maxSize===void 0)throw new RangeError("reactiveMap: `retention` requires at least one of `archiveThreshold` or `maxSize` to trigger archival.");let a=o??new Et({maxSize:n,defaultTtl:r}),d=W(a.toMap(),{name:e,describeKind:"state",equals:(p,h)=>p===h,...s!=null?{versioning:s}:{}});function u(){let p=a.toMap();K(()=>{d.down([[F]]),d.down([[G,p]])})}function l(){if(!i)return;let p=a.toMap(),h=i.archiveThreshold,c=i.maxSize,m=[];for(let[v,_]of p)m.push({key:v,value:_,score:i.score(v,_)});m.sort((v,_)=>v.score-_.score);let x=new Set;if(h!==void 0)for(let v of m)if(v.score<h)x.add(v.key);else break;if(c!==void 0&&m.length-x.size>c)for(let v of m){if(m.length-x.size<=c)break;x.has(v.key)||x.add(v.key)}if(x.size!==0)for(let v of m)x.has(v.key)&&(i.onArchive?.(v.key,v.value,v.score),a.delete(v.key))}function f(p,h="mutation"){let c=a.version;try{return p()}finally{a.version!==c&&(h==="mutation"&&l(),u())}}return{entries:d,has(p){return f(()=>a.has(p),"read")},get(p){return f(()=>a.get(p),"read")},set(p,h,c){f(()=>a.set(p,h,c?.ttl))},setMany(p,h){f(()=>a.setMany(p,h?.ttl))},delete(p){f(()=>a.delete(p))},deleteMany(p){f(()=>a.deleteMany(p))},clear(){f(()=>a.clear())},pruneExpired(){f(()=>a.pruneExpired())},get size(){return a.size},dispose(){}}}He();var $={object:56,array:64,string:40,number:8,boolean:4,null:0,undefined:0,symbol:40,bigint:16,function:120,map:72,set:72,mapEntry:40,setEntry:24,date:24,regexp:48,error:64,url:80,promise:48,weakmap:40,weakset:40},nr=Symbol.for("sizeof");function Xt(t){let e=new WeakSet,n=new WeakSet,r=[t],s=0;for(;r.length>0;){let o=r.pop();s+=rr(o,e,n,r)}return s}function rr(t,e,n,r){if(t==null)return 0;switch(typeof t){case"number":return $.number;case"boolean":return $.boolean;case"string":return $.string+t.length*2;case"bigint":return $.bigint+sr(t);case"symbol":return $.symbol;case"function":return e.has(t)?0:(e.add(t),$.function);case"undefined":return 0}let o=t;if(e.has(o))return 0;e.add(o);let i=o[nr];if(typeof i=="function")try{let u=i.call(o);if(typeof u=="number"&&Number.isFinite(u))return u}catch{}if(o instanceof Date)return $.date;if(o instanceof RegExp)return $.regexp+o.source.length*2;if(o instanceof Error){let u=o.message?o.message.length*2:0,l=o.stack?o.stack.length*2:0;return $.error+u+l}if(typeof URL<"u"&&o instanceof URL)return $.url+o.href.length*2;if(typeof Promise<"u"&&o instanceof Promise)return $.promise;if(o instanceof WeakMap)return $.weakmap;if(o instanceof WeakSet)return $.weakset;if(o instanceof Map){let u=$.map;for(let[l,f]of o)u+=$.mapEntry,r.push(l),r.push(f);return u}if(o instanceof Set){let u=$.set;for(let l of o)u+=$.setEntry,r.push(l);return u}if(Array.isArray(o)){let u=$.array+o.length*8;for(let l of o)r.push(l);return u}if(o instanceof ArrayBuffer)return n.has(o)?0:(n.add(o),o.byteLength);if(ArrayBuffer.isView(o)){let u=o;return n.has(u.buffer)?48:(n.add(u.buffer),u.buffer.byteLength+48)}let a=$.object,d=Object.keys(o);for(let u of d){a+=$.string+u.length*2;try{r.push(o[u])}catch{}}return a}function sr(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 Zt(t,e,n,r={}){let s=e in t.nodes,o=n in t.nodes;if(!s)return qe(e,n,"no-such-from");if(!o)return qe(e,n,"no-such-to");let i=r.maxDepth;if(i!=null&&(!Number.isInteger(i)||i<0))throw new Error("explainPath: maxDepth must be an integer >= 0");if(e===n){if(r.findCycle===!0){let u=or(t,e,r);if(u!=null)return u}let d=We(e,t.nodes[e],0,r);return Ue(e,n,[d])}if(i===0)return qe(e,n,"no-path");let a=en(t,e,n,i);return a.found?Ue(e,n,tn(t,a.pathOrder,r)):qe(e,n,a.truncated?"max-depth-exceeded":"no-path")}function en(t,e,n,r){let s=new Map,o=[{path:n,depth:0}],i=new Set([n]),a=0,d=!1;for(;a<o.length;){let f=o[a++];if(f.path===e)break;if(r!=null&&f.depth>=r){let m=t.nodes[f.path];m?.deps&&m.deps.length>0&&(d=!0);continue}let p=t.nodes[f.path];if(p==null)continue;let h=p.deps??[],c=new Map;for(let m=0;m<h.length;m++){let x=h[m];if(!x)continue;let v=c.get(x);v==null&&(v=[],c.set(x,v)),v.push(m)}for(let[m,x]of c)i.has(m)||(i.add(m),s.set(m,{from:f.path,depIndices:x}),o.push({path:m,depth:f.depth+1}))}if(!s.has(e))return{found:!1,pathOrder:[],truncated:d};let u=[{path:e}],l=e;for(;l!==n;){let f=s.get(l);if(f==null)return{found:!1,pathOrder:[],truncated:!1};u[u.length-1].depIndices=f.depIndices,u.push({path:f.from}),l=f.from}return{found:!0,pathOrder:u,truncated:!1}}function or(t,e,n){let r=t.nodes[e];if(r==null)return null;let s=r.deps??[],o=[];for(let a=0;a<s.length;a++)s[a]===e&&o.push(a);if(o.length>0){let a=We(e,r,0,n);a.dep_index=o[0];let d=We(e,r,1,n);return Ue(e,e,[a,d])}let i=null;for(let a=0;a<s.length;a++){let d=s[a];if(!d||d===e)continue;let u=en(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:Ue(e,e,tn(t,i.pathOrder,n))}function tn(t,e,n){return e.map((r,s)=>{let o=t.nodes[r.path],i=We(r.path,o,s,n);return r.depIndices!=null&&r.depIndices.length>0&&(i.dep_index=r.depIndices[0],r.depIndices.length>1&&(i.dep_indices=[...r.depIndices])),i})}function We(t,e,n,r){let s={path:t,type:e.type,hop:n};e.status!==void 0&&(s.status=e.status),"value"in e&&(s.value=e.value),e.v!=null&&(s.v=e.v);let o=r.annotations?.get(t)??e.annotation;o!=null&&(s.annotation=o);let i=r.lastMutations?.get(t)??e.lastMutation;return i!=null&&(s.lastMutation=i),s}function Ue(t,e,n){return nn(t,e,!0,"ok",n)}function qe(t,e,n){return nn(t,e,!1,n,[])}function nn(t,e,n,r,s){let o=ir(t,e,n,r,s);return{from:t,to:e,found:n,reason:r,steps:s,text:o,toJSON(){return{from:t,to:e,found:n,reason:r,steps:s}}}}function ir(t,e,n,r,s){if(!n)switch(r){case"no-such-from":return`explainPath: no node named "${t}"`;case"no-such-to":return`explainPath: no node named "${e}"`;case"max-depth-exceeded":return`explainPath: no path from "${t}" to "${e}" within maxDepth`;default:return`explainPath: no path from "${t}" to "${e}"`}let o=[`Causal path: ${t} \u2192 ${e} (${s.length} step(s))`];for(let i of s){let d=` ${i.hop===0?"\xB7":"\u2193"} ${i.path} (${i.type}${i.status?`/${i.status}`:""})`;if(o.push(d),"value"in i&&o.push(` value: ${ar(i.value)}`),i.annotation!=null&&o.push(` annotation: ${i.annotation}`),i.lastMutation!=null){let u=i.lastMutation.actor;o.push(` actor: ${u.type}${u.id?`:${u.id}`:""}`)}}return o.join(`
|
|
2
|
+
`)}function ar(t){if(t===void 0)return"<sentinel>";if(t===null)return"null";if(typeof t=="string")return JSON.stringify(t);if(typeof t=="number"||typeof t=="boolean"||typeof t=="bigint")return String(t);try{let e=JSON.stringify(t);return e.length>80?`${e.slice(0,77)}...`:e}catch{return String(t)}}Ie();pe();Ne();Te();oe();me();ue();He();rn();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}};ht();function Ot(t){return t>=768&&t<=879||t>=1155&&t<=1161||t>=1425&&t<=1469||t>=1552&&t<=1562||t>=1611&&t<=1631||t>=1648&&t===1648||t>=1750&&t<=1756||t>=1759&&t<=1764||t>=1767&&t<=1768||t>=1770&&t<=1773||t>=1840&&t<=1866||t>=1958&&t<=1968||t>=2304&&t<=2307||t>=2362&&t<=2383||t>=2385&&t<=2391||t>=2402&&t<=2403||t>=2433&&t<=2435||t>=2492&&t<=2509||t>=2561&&t<=2563||t>=2620&&t<=2641||t>=2672&&t<=2673||t>=2677&&t===2677||t>=3633&&t===3633||t>=3636&&t<=3642||t>=3655&&t<=3662||t>=3761&&t===3761||t>=3764&&t<=3772||t>=3784&&t<=3790||t>=7616&&t<=7679||t>=8400&&t<=8447||t>=65024&&t<=65039||t>=65056&&t<=65071||t===8205?0:t>=4352&&t<=4447||t>=8986&&t<=8987||t>=9001&&t<=9002||t>=9193&&t<=9203||t>=9208&&t<=9210||t>=9725&&t<=9726||t>=9748&&t<=9749||t>=9800&&t<=9811||t===9855||t===9875||t===9889||t>=9898&&t<=9899||t>=9917&&t<=9918||t>=9924&&t<=9925||t===9934||t===9940||t===9962||t>=9970&&t<=9971||t===9973||t===9978||t===9981||t===9986||t===9989||t>=9992&&t<=9997||t===9999||t>=10067&&t<=10069||t===10071||t>=10133&&t<=10135||t===10160||t===10175||t>=10548&&t<=10549||t>=11013&&t<=11015||t>=11035&&t<=11036||t===11088||t===11093||t>=11904&&t<=12350||t>=12352&&t<=12447||t>=12448&&t<=12543||t>=12549&&t<=12591||t>=12593&&t<=12686||t>=12688&&t<=12771||t>=12784&&t<=12830||t>=12832&&t<=12871||t>=12880&&t<=19903||t>=19968&&t<=40959||t>=43360&&t<=43388||t>=44032&&t<=55203||t>=63744&&t<=64255||t>=65040&&t<=65049||t>=65072&&t<=65131||t>=65281&&t<=65376||t>=65504&&t<=65510||t>=126980&&t===126980||t===127183||t>=127344&&t<=127345||t===127358||t===127359||t===127374||t>=127377&&t<=127386||t>=127456&&t<=127487||t>=127488&&t<=127490||t===127514||t===127535||t>=127538&&t<=127546||t>=127568&&t<=127569||t>=127744&&t<=129535||t>=129536&&t<=129791||t>=129792&&t<=130047||t>=131072&&t<=196605||t>=196608&&t<=262141?2:1}function Ye(t){let e=0;for(let n of t)e+=Ot(n.codePointAt(0));return e}function sn(t,e){if(e<=0)return"";let n=0,r="";for(let s of t){let o=Ot(s.codePointAt(0));if(n+o>e){if(e<=1)return"\u2026";for(;n+1>e&&r.length>0;){let i=[...r].pop();r=r.slice(0,-i.length),n-=Ot(i.codePointAt(0))}return`${r}\u2026`}r+=s,n+=o}return r}var ur={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"},dr={horizontal:"-",vertical:"|",cornerTL:"+",cornerTR:"+",cornerBL:"+",cornerBR:"+",tDown:"+",tUp:"+",tRight:"+",tLeft:"+",cross:"+",arrowRight:">",arrowDown:"v",arrowLeft:"<",arrowUp:"^",boxTL:"+",boxTR:"+",boxBL:"+",boxBR:"+",boxH:"-",boxV:"|"};function dn(t,e){let n=e.charset==="ascii"?dr:ur,r=t.width,s=t.height,o=Array.from({length:s},()=>Array.from({length:r},()=>" ")),i=Array.from({length:s},()=>Array.from({length:r},()=>"empty"));for(let a of t.edges)cr(o,i,n,a);for(let a of t.boxes)lr(o,i,n,a,e.labelOf(a.id));return o.map(a=>gr(a.join(""))).join(`
|
|
3
|
+
`)}function lr(t,e,n,r,s){let{x:o,y:i,w:a,h:d}=r;if(a<2||d<2){d>0&&on(t,e,o,i,a,s);return}de(t,e,o,i,n.boxTL);for(let l=o+1;l<o+a-1;l+=1)de(t,e,l,i,n.boxH);de(t,e,o+a-1,i,n.boxTR);for(let l=i+1;l<i+d-1;l+=1){de(t,e,o,l,n.boxV);for(let f=o+1;f<o+a-1;f+=1)ln(t,e,f,l," ","empty");de(t,e,o+a-1,l,n.boxV)}de(t,e,o,i+d-1,n.boxBL);for(let l=o+1;l<o+a-1;l+=1)de(t,e,l,i+d-1,n.boxH);de(t,e,o+a-1,i+d-1,n.boxBR);let u=i+Math.floor(d/2);on(t,e,o+1,u,a-2,s)}function de(t,e,n,r,s){ln(t,e,n,r,s,s===" "?"empty":s==="\u2500"||s==="-"?"boxH":s==="\u2502"||s==="|"?"boxV":"boxCorner")}function ln(t,e,n,r,s,o){if(r<0||r>=t.length)return;let i=t[r];n<0||n>=i.length||(i[n]=s,e[r][n]=o)}function on(t,e,n,r,s,o){if(r<0||r>=t.length)return;let i=n,a=s;for(let d of o){let u=Ye(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 cr(t,e,n,r){let s=r.points;if(s.length<2)return;for(let d=0;d+1<s.length;d+=1)fr(t,e,n,s[d],s[d+1]);for(let d=1;d+1<s.length;d+=1){let u=s[d-1],l=s[d],f=s[d+1],p=pr(u,l,f,n);p&&un(t,e,l.x,l.y,p,"edgeCorner")}let o=s[s.length-1],i=s[s.length-2],a=hr(i,o,n);a&&un(t,e,o.x,o.y,a,"arrow")}function fr(t,e,n,r,s){if(!(r.x===s.x&&r.y===s.y)){if(r.y===s.y){let o=r.y,i=Math.min(r.x,s.x),a=Math.max(r.x,s.x);for(let d=i;d<=a;d+=1)an(t,e,d,o,n,"h")}else if(r.x===s.x){let o=r.x,i=Math.min(r.y,s.y),a=Math.max(r.y,s.y);for(let d=i;d<=a;d+=1)an(t,e,o,d,n,"v")}}}function an(t,e,n,r,s,o){if(r<0||r>=t.length)return;let i=t[r];if(n<0||n>=i.length)return;let a=e[r][n];if(!(a==="boxH"||a==="boxV"||a==="boxCorner"||a==="label")){if(a==="empty"){i[n]=o==="h"?s.horizontal:s.vertical,e[r][n]=o==="h"?"edgeH":"edgeV";return}if(a==="edgeH"&&o==="v"){i[n]=s.cross,e[r][n]="edgeCorner";return}if(a==="edgeV"&&o==="h"){i[n]=s.cross,e[r][n]="edgeCorner";return}}}function un(t,e,n,r,s,o){if(r<0||r>=t.length)return;let i=t[r];if(n<0||n>=i.length)return;let a=e[r][n];a==="boxH"||a==="boxV"||a==="boxCorner"||a==="label"||(i[n]=s,e[r][n]=o)}function pr(t,e,n,r){let s=t.y===e.y,o=e.y===n.y;if(s===o)return;if(s){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 hr(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 gr(t){let e=t.length;for(;e>0&&t.charCodeAt(e-1)===32;)e-=1;return t.slice(0,e)}function pn(t){let e=mr(t);br(e),yr(e),vr(e),_r(e,t);let n=Tr(e,t),{width:r,height:s}=Or(e),o=[];for(let i of e.layers)for(let a of i)a.isVirtual||o.push({id:a.id,layer:a.layer,order:a.order,x:a.x,y:a.y,w:a.w,h:a.h});return{boxes:o,edges:n,width:r,height:s}}function mr(t){let e=new Map;for(let s of t.nodes)e.set(s,{id:s,isVirtual:!1,layer:-1,order:0,x:0,y:0,w:t.widthCells(s),h:t.heightCells(s),in:[],out:[]});let n=[],r=0;for(let s of t.edges){if(s.from===s.to)continue;let o=e.get(s.from),i=e.get(s.to);if(!o||!i)continue;let a={chainId:r++,chainFrom:s.from,chainTo:s.to,fromId:s.from,toId:s.to,hopIndex:0,chainLen:1};o.out.push(a),i.in.push(a),n.push(a)}return{nodes:e,layers:[],hops:n}}function br(t){let e=new Map;for(let o of t.nodes.values())e.set(o.id,o.in.length);let n=[];for(let o of t.nodes.values())(e.get(o.id)??0)===0&&(o.layer=0,n.push(o));let r=new Set,s=0;for(;s<n.length;){let o=n[s++];if(!r.has(o.id)){r.add(o.id);for(let i of o.out){let a=t.nodes.get(i.toId);a.layer=Math.max(a.layer,o.layer+1);let d=(e.get(a.id)??0)-1;e.set(a.id,d),d<=0&&n.push(a)}}}for(let o of t.nodes.values())o.layer<0&&(o.layer=0)}function yr(t){let e=Math.max(0,...Array.from(t.nodes.values(),o=>o.layer)),n=Array.from({length:e+1},()=>[]);for(let o of t.nodes.values())n[o.layer].push(o);let r=[],s=0;for(let o of t.hops){let i=t.nodes.get(o.fromId),a=t.nodes.get(o.toId),d=a.layer-i.layer;if(d<=0){i.out=i.out.filter(f=>f!==o),a.in=a.in.filter(f=>f!==o);continue}if(d===1){o.hopIndex=0,o.chainLen=1,r.push(o);continue}i.out=i.out.filter(f=>f!==o),a.in=a.in.filter(f=>f!==o);let u=i;for(let f=1;f<d;f+=1){let p=`__virt_${s++}__`,h={id:p,isVirtual:!0,layer:i.layer+f,order:0,x:0,y:0,w:0,h:1,in:[],out:[]};t.nodes.set(p,h),n[h.layer].push(h);let c={chainId:o.chainId,chainFrom:o.chainFrom,chainTo:o.chainTo,fromId:u.id,toId:p,hopIndex:f-1,chainLen:d};u.out.push(c),h.in.push(c),r.push(c),u=h}let l={chainId:o.chainId,chainFrom:o.chainFrom,chainTo:o.chainTo,fromId:u.id,toId:a.id,hopIndex:d-1,chainLen:d};u.out.push(l),a.in.push(l),r.push(l)}for(let o of n)for(let i=0;i<o.length;i+=1)o[i].order=i;t.layers=n,t.hops=r}function vr(t){for(let n=0;n<4;n+=1){for(let r=1;r<t.layers.length;r+=1)cn(t,t.layers[r],"in"),Qe(t.layers[r]);for(let r=t.layers.length-2;r>=0;r-=1)cn(t,t.layers[r],"out"),Qe(t.layers[r])}for(let n=0;n<2;n+=1){let r=!1;for(let s=1;s<t.layers.length;s+=1){let o=t.layers[s];for(let i=0;i+1<o.length;i+=1){let a=fn(t,o[i],o[i+1],"in");[o[i],o[i+1]]=[o[i+1],o[i]],Qe(o),fn(t,o[i],o[i+1],"in")<a?r=!0:([o[i],o[i+1]]=[o[i+1],o[i]],Qe(o))}}if(!r)break}}function cn(t,e,n){let r=new Map;for(let s of e){let o=n==="in"?s.in:s.out;if(o.length===0){r.set(s.id,s.order);continue}let i=0,a=0;for(let d of o){let u=t.nodes.get(n==="in"?d.fromId:d.toId);u&&(i+=u.order,a+=1)}r.set(s.id,a===0?s.order:i/a)}e.sort((s,o)=>{let i=r.get(s.id),a=r.get(o.id);return i!==a?i-a:s.order-o.order})}function Qe(t){for(let e=0;e<t.length;e+=1)t[e].order=e}function fn(t,e,n,r){let s=r==="in"?e.in:e.out,o=r==="in"?n.in:n.out,i=0;for(let a of s)for(let d of o){let u=t.nodes.get(r==="in"?a.fromId:a.toId)?.order??0,l=t.nodes.get(r==="in"?d.fromId:d.toId)?.order??0;(e.order<n.order&&u>l||e.order>n.order&&u<l)&&(i+=1)}return i}function _r(t,e){e.direction==="LR"?wr(t,e):xr(t,e)}function wr(t,e){let n=[],r=0;for(let s=0;s<t.layers.length;s+=1){n.push(r);let o=0;for(let i of t.layers[s])o=Math.max(o,i.w);r+=o+e.layerGap}for(let s=0;s<t.layers.length;s+=1)for(let o of t.layers[s])o.x=n[s];for(let s of t.layers){let o=0;for(let i of s)i.y=o,o+=i.h+e.nodeGap}hn(t,e,"y")}function xr(t,e){let n=[],r=0;for(let s=0;s<t.layers.length;s+=1){n.push(r);let o=0;for(let i of t.layers[s])o=Math.max(o,i.h);r+=o+e.layerGap}for(let s=0;s<t.layers.length;s+=1)for(let o of t.layers[s])o.y=n[s];for(let s of t.layers){let o=0;for(let i of s)i.x=o,o+=i.w+e.nodeGap}hn(t,e,"x")}function hn(t,e,n){let r=o=>n==="y"?o.h:o.w,s=e.nodeGap;for(let o=0;o<2;o+=1){let i=o===0?t.layers.slice(1):t.layers.slice(0,-1).reverse();for(let a of i){let d=new Map;for(let l of a){let f=o===0?l.in:l.out;if(f.length===0)continue;let p=[];for(let c of f){let m=t.nodes.get(o===0?c.fromId:c.toId);if(!m)continue;let x=n==="y"?m.y:m.x;p.push(x+Math.floor(r(m)/2))}if(p.length===0)continue;p.sort((c,m)=>c-m);let h=p[Math.floor(p.length/2)];d.set(l.id,h-Math.floor(r(l)/2))}let u=0;for(let l of a){let f=d.get(l.id),p=n==="y"?l.y:l.x,c=Math.max(f??p,u);n==="y"?l.y=c:l.x=c,u=c+r(l)+s}}}}function Tr(t,e){let n=new Map;for(let u of t.hops){let l=n.get(u.chainId);l?l.push(u):n.set(u.chainId,[u])}for(let u of n.values())u.sort((l,f)=>l.hopIndex-f.hopIndex);let r=e.direction==="LR",s=u=>r?u.x:u.y,o=u=>r?u.w:u.h,i=u=>r?u.y+Math.floor(u.h/2):u.x+Math.floor(u.w/2),a=new Map;for(let u=0;u+1<t.layers.length;u+=1){let l=t.layers[u],f=t.layers[u+1],p=0;for(let y of l)p=Math.max(p,s(y)+o(y));let h=Number.POSITIVE_INFINITY;for(let y of f)h=Math.min(h,s(y));let c=Number.isFinite(h)?h-1:p,m=Math.max(1,c-p+1),x=[];for(let y of l)for(let E of y.out)x.push(E);x.sort((y,E)=>{let R=i(t.nodes.get(y.fromId)),N=i(t.nodes.get(E.fromId));if(R!==N)return R-N;let k=i(t.nodes.get(y.toId)),S=i(t.nodes.get(E.toId));return k-S});let v=[],_=new Map;for(let y of x){let E=i(t.nodes.get(y.fromId)),R=i(t.nodes.get(y.toId)),N=Math.min(E,R),k=Math.max(E,R),S=-1;for(let M=0;M<v.length;M+=1){let B=v[M],z=!0;for(let le of B)if(le.lo<=k&&N<=le.hi){z=!1;break}if(z){B.push({lo:N,hi:k}),S=M;break}}S<0&&(v.push([{lo:N,hi:k}]),S=v.length-1),_.set(y,S)}let b=v.length,w=m>=Math.max(3,b+2),O=w?p+1:p,T=w?c-1:c,g=Math.max(1,T-O+1);for(let y of x){let E=_.get(y),R;if(b<=1)R=O+Math.floor(g/2);else{let N=(g-1)/(b-1);R=O+Math.floor(E*N)}a.set(y,Math.max(p,Math.min(c,R)))}}let d=[];for(let[,u]of n){let l=[];for(let p=0;p<u.length;p+=1){let h=u[p],c=t.nodes.get(h.fromId),m=t.nodes.get(h.toId),x=a.get(h),v=c.isVirtual?s(c):s(c)+o(c),_=m.isVirtual?s(m):s(m)-1,b=i(c),w=i(m);p===0&&Xe(l,r,v,b),b!==w&&(Xe(l,r,x,b),Xe(l,r,x,w)),Xe(l,r,_,w)}let f=u[0];d.push({from:f.chainFrom,to:f.chainTo,points:Er(l)})}return d}function Xe(t,e,n,r){t.push(e?{x:n,y:r}:{x:r,y:n})}function Er(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 Or(t){let e=0,n=0;for(let r of t.layers)for(let s of r)e=Math.max(e,s.x+s.w),n=Math.max(n,s.y+s.h);return{width:e,height:n}}var Nr=24,kr=4,Rr=1,Sr=3;function gn(t,e){let n=Ar(e.direction),r=Math.max(3,e.maxLabelWidth??Nr),s=e.asciiCharset??"unicode",o=Object.keys(t.nodes).sort(),i=new Set(o),a=t.edges.filter(h=>i.has(h.from)&&i.has(h.to)),d=new Map,u=new Map;for(let h of o){let c=sn(h,r);d.set(h,c),u.set(h,Ye(c)+4)}let l=pn({nodes:o,edges:a,widthCells:h=>u.get(h)??3,heightCells:()=>Sr,layerGap:kr,nodeGap:Rr,direction:n}),f=dn(l,{charset:s,labelOf:h=>d.get(h)??h}),p=e.logger;return p&&p(f),f}function Ar(t){if(t===void 0||t==="LR")return"LR";if(t==="TD")return"TD";throw new Error(`ascii describe supports direction "LR" or "TD" only; got ${String(t)}`)}me();function mn(t,e){let n=e?.topN??10,r=t.describe({detail:"standard"}),s=[],o=t._collectObserveTargets;typeof o=="function"&&o.call(t,"",s);let i=new Map;for(let[p,h]of s)i.set(p,h);let a=[];for(let[p,h]of Object.entries(r.nodes)){let c=i.get(p),m=c instanceof P?c:null,x=m?Xt(m.cache):0,v=m?m._sinkCount:0,_=h.deps?.length??0,b=h.type==="effect"&&v===0,w=v===0?h.type==="effect"?"orphan-effect":h.type==="derived"?"idle-derived":h.type==="producer"?"idle-producer":null:null;a.push({path:p,type:h.type,status:h.status??"unknown",valueSizeBytes:x,subscriberCount:v,depCount:_,isOrphanEffect:b,orphanKind:w})}let d=a.reduce((p,h)=>p+h.valueSizeBytes,0),u=(p,h)=>[...a].sort(h??((c,m)=>m[p]-c[p])).slice(0,n),l=a.filter(p=>p.orphanKind!=null),f=a.filter(p=>p.isOrphanEffect);return{nodeCount:a.length,edgeCount:r.edges.length,subgraphCount:r.subgraphs.length,nodes:a,totalValueSizeBytes:d,hotspots:{byValueSize:u("valueSizeBytes"),bySubscriberCount:u("subscriberCount"),byDepCount:u("depCount")},orphans:l,orphanEffects:f}}var I="::",ee="__meta__",ye=1;function bn(t,e){let n=Math.max(16,t.size*4),r=0;for(;t.size>0;){if(r++>=n){console.error(`[Graph "${e}".destroy] disposer drain exceeded cap (${n}); ${t.size} disposer(s) discarded`),t.clear();return}let s=t.values().next();if(s.done)return;let o=s.value;t.delete(o);try{o()}catch(i){console.error(`[Graph "${e}".destroy] disposer threw:`,i)}}}function _n(t){return t!=null&&typeof t=="object"&&"cache"in t&&typeof t.subscribe=="function"&&typeof t.down=="function"}function Mr(t){if(t!=null)return _n(t)?t.cache:t}function Dr(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 yn(t){if(t.version!==ye)throw new Error(`unsupported snapshot version ${String(t.version)} (expected ${ye})`);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 Cr(t,e){let n=new WeakMap,r=(s,o)=>{if(Object.is(s,o))return!0;if(s==null||o==null||typeof s!="object"||typeof o!="object")return!1;let i=n.get(s);if(i==null&&(i=new WeakSet,n.set(s,i)),i.has(o))return!0;i.add(o);let a=s.constructor,d=o.constructor;if(a!==d)return!1;if(s instanceof Date)return s.getTime()===o.getTime();if(s instanceof RegExp)return s.source===o.source&&s.flags===o.flags;if(Array.isArray(s)){let p=o;if(s.length!==p.length)return!1;for(let h=0;h<s.length;h++)if(!r(s[h],p[h]))return!1;return!0}if(s instanceof Map){let p=o;if(s.size!==p.size)return!1;for(let[h,c]of s)if(!p.has(h)||!r(c,p.get(h)))return!1;return!0}if(s instanceof Set){let p=o;if(s.size!==p.size)return!1;for(let h of s){let c=!1;for(let m of p)if(r(h,m)){c=!0;break}if(!c)return!1}return!0}if(ArrayBuffer.isView(s)){let p=s,h=o;if(p.length!==h.length)return!1;for(let c=0;c<p.length;c++)if(p[c]!==h[c])return!1;return!0}let u=Object.keys(s),l=Object.keys(o);if(u.length!==l.length)return!1;let f=new Set(l);for(let p of u)if(!f.has(p)||!r(s[p],o[p]))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 s of n)r[s]=kt(e[s]);return r}function Gr(t){return t.replaceAll("\\","\\\\").replaceAll('"','\\"')}function Lr(t){return t.replaceAll("\\","\\\\").replaceAll('"','\\"')}function Ir(t){return t==="TD"?"down":t==="BT"?"up":t==="RL"?"left":"right"}function wn(t){let e=new Set,n=[];function r(s,o){let i=`${s}\0${o}`;e.has(i)||(e.add(i),n.push([s,o]))}for(let[s,o]of Object.entries(t.nodes)){let i=o.deps;if(i)for(let a of i)r(a,s)}for(let s of t.edges)r(s.from,s.to);return n}function xn(t){if(t===void 0)return"LR";if(t==="TD"||t==="LR"||t==="BT"||t==="RL")return t;throw new Error(`invalid diagram direction ${String(t)}; expected one of: TD, LR, BT, RL`)}function Pr(t,e){let n=e.includeEdges??!0,r=e.includeSubgraphs??!0,{expand:s,...o}=t,i={...o,edges:n?t.edges:[],subgraphs:r?t.subgraphs:[]},a=JSON.stringify(kt(i),null,e.indent??2);return e.logger?.(a),a}function $r(t,e){let n=e.includeEdges??!0,r=e.includeSubgraphs??!0,s=[];s.push(`Graph ${t.name}`),s.push("Nodes:");for(let i of Object.keys(t.nodes).sort()){let a=t.nodes[i];s.push(`- ${i} (${a.type}/${a.status}): ${et(a.value)}`)}if(n){s.push("Edges:");for(let i of t.edges)s.push(`- ${i.from} -> ${i.to}`)}if(r){s.push("Subgraphs:");for(let i of t.subgraphs)s.push(`- ${i}`)}let o=s.join(`
|
|
5
|
+
`);return e.logger?.(o),o}function Tn(t,e){let n=xn(e.direction),r=Object.keys(t.nodes).sort(),s=new Map;for(let i=0;i<r.length;i+=1)s.set(r[i],`n${i}`);let o=[`flowchart ${n}`];for(let i of r){let a=s.get(i);o.push(` ${a}["${Gr(i)}"]`)}for(let[i,a]of wn(t)){let d=s.get(i),u=s.get(a);!d||!u||o.push(` ${d} --> ${u}`)}return o.join(`
|
|
6
|
+
`)}function Fr(t,e){let n=Tn(t,e);return En(n)}function En(t,e){let n=e?.theme??"default",r=e?.autoSync??!0,o=JSON.stringify({code:t,mermaid:{theme:n},autoSync:r}),i=new TextEncoder().encode(o),a="";for(let u=0;u<i.length;u++)a+=String.fromCharCode(i[u]);return`https://mermaid.live/edit#base64:${globalThis.btoa(a).replace(/\+/g,"-").replace(/\//g,"_").replace(/=+$/,"")}`}function Vr(t,e){let n=xn(e.direction),r=Object.keys(t.nodes).sort(),s=new Map;for(let i=0;i<r.length;i+=1)s.set(r[i],`n${i}`);let o=[`direction: ${Ir(n)}`];for(let i of r){let a=s.get(i);o.push(`${a}: "${Lr(i)}"`)}for(let[i,a]of wn(t)){let d=s.get(i),u=s.get(a);!d||!u||o.push(`${d} -> ${u}`)}return o.join(`
|
|
7
|
+
`)}function zr(t){return t.replace(/[.*+?^${}()|[\]\\]/g,"\\$&")}function Ze(t){let e="^";for(let n=0;n<t.length;n+=1){let r=t[n];if(r==="*"){e+=".*";continue}if(r==="?"){e+=".";continue}if(r==="["){let s=t.indexOf("]",n+1);if(s<=n+1){e+="\\[";continue}let o=t.slice(n+1,s);o.startsWith("!")&&(o=`^${o.slice(1)}`),o=o.replace(/\\/g,"\\\\"),e+=`[${o}]`,n=s;continue}e+=zr(r)}return e+="$",new RegExp(e)}var jr={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"},Br={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 Hr(t){return t==="none"?Br:t==="ansi"||t==null?jr:{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 vn(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 Kr(t,e,n){for(let r=0;r<t.length;r++){let s=t.charCodeAt(r);if(s<32||s===127)throw new Error(`Graph "${e}": ${n} "${t}" must not contain control character (U+${s.toString(16).padStart(4,"0").toUpperCase()} at index ${r})`)}}function Nt(t,e,n){if(t==="")throw new Error(`Graph "${e}": ${n} name must be non-empty`);if(t.includes(I))throw new Error(`Graph "${e}": ${n} "${t}" must not contain '${I}' (path separator)`);if(t===ee)throw new Error(`Graph "${e}": ${n} name "${ee}" is reserved for meta companion paths`);Kr(t,e,n)}function qr(t,e){if(t==="")throw new Error(`Graph "${e}": resolve path must be non-empty`);let n=t.split(I);for(let r of n)if(r==="")throw new Error(`Graph "${e}": resolve path has empty segment`);return n}function Wr(t,e){let n=!1;for(let s of t)if(!e.isMetaPassthrough(s[0])){n=!0;break}return n?t.filter(s=>e.isMetaPassthrough(s[0])):t}function On(t){for(let e of t._mounts.values())On(e);for(let e of t._nodes.values())try{e.down([[j]],{internal:!0})}catch{}}var ve=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(I))throw new Error(`Graph name must not contain '${I}' (got "${e}")`);if(e===ee)throw new Error(`Graph name "${ee}" is reserved for meta companion paths`);this.name=e,this.opts=Object.freeze({...n??{}}),this.config=n?.config??Ee,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=be(e=>{let n=r=>{e.emit(r)};return this._topologyEmitters.add(n),()=>{this._topologyEmitters.delete(n)}},{name:`${this.name}_topology`})),this._topology}_emitTopology(e){if(!(this._topology==null||this._topologyEmitters.size===0))for(let n of this._topologyEmitters)n(e)}nameOf(e){return this._nodeToName.get(e)}add(e,n){let r=e.name,s=n?.name??r;if(s==null||s==="")throw new Error(`Graph "${this.name}": graph.add requires a non-empty name \u2014 pass via opts.name or set it on the node (e.g. state(0, { name: "x" }))`);let o=s,i=n?.annotation;if(Nt(o,this.name,"add"),this._mounts.has(o))throw new Error(`Graph "${this.name}": name "${o}" is already a mount point`);if(this._nodes.has(o))throw new Error(`Graph "${this.name}": node "${o}" already exists`);let a=this._nodeToName.get(e);if(a!==void 0)throw new Error(`Graph "${this.name}": node instance already registered as "${a}"`);return this._nodes.set(o,e),this._nodeToName.set(e,o),this._emitTopology({kind:"added",name:o,nodeKind:"node"}),i!=null&&(this._annotations.set(o,i),this.config.inspectorEnabled&&this._traceRing.push({path:o,annotation:i,timestamp_ns:te()})),e}setVersioning(e){if(e!=null)for(let n of this._nodes.values())n instanceof P&&n._applyVersioning(e)}remove(e){Nt(e,this.name,"remove");let n=this._mounts.get(e);if(n){let o={kind:"mount",nodes:[],mounts:[]},i=[];n._collectObserveTargets("",i);for(let[a,d]of i)a.includes(`${I}${ee}${I}`)||o.nodes.push(a);return o.nodes.sort(),o.mounts.push(e),o.mounts.push(...n._collectSubgraphs(`${e}${I}`)),this._mounts.delete(e),n._parent=void 0,On(n),this._emitTopology({kind:"removed",name:e,nodeKind:"mount",audit:o}),o}let r=this._nodes.get(e);if(!r)throw new Error(`Graph "${this.name}": unknown node or mount "${e}"`);this._nodes.delete(e),this._nodeToName.delete(r),r.down([[j]],{internal:!0});let s={kind:"node",nodes:[e],mounts:[]};return this._emitTopology({kind:"removed",name:e,nodeKind:"node",audit:s}),s}removeAll(e){let n=typeof e=="function"?e:(()=>{let o=Ze(e);return i=>o.test(i)})(),r={kind:"mount",nodes:[],mounts:[]},s=[...this._nodes.keys(),...this._mounts.keys()].filter(o=>n(o));for(let o of s){let i=this.remove(o);r.nodes.push(...i.nodes),r.mounts.push(...i.mounts)}return r.nodes.sort(),r.mounts.sort(),r}[Symbol.iterator](){let e=[...this._nodes.keys()].sort(),n=this._nodes,r=0;return{[Symbol.iterator](){return this},next(){if(r>=e.length)return{value:void 0,done:!0};let s=e[r++];return{value:[s,n.get(s)],done:!1}}}}node(e){if(e==="")throw new Error(`Graph "${this.name}": node name must be non-empty`);if(e.includes(I))return this.resolve(e);let n=this._nodes.get(e);if(!n)throw new Error(`Graph "${this.name}": unknown node "${e}"`);return n}get(e){return this.node(e).cache}set(e,n,r){let s=r?.internal===!0;this.node(e).down([[G,n]],{actor:r?.actor,internal:s,delivery:"write"})}setAll(e,n){let r=Symbol.iterator in e?e:Object.entries(e);K(()=>{for(let[s,o]of r)this.set(s,o,n)})}invalidate(e,n){let r=n?.internal===!0;this.node(e).down([[Q]],{actor:n?.actor,internal:r,delivery:"write"})}error(e,n,r){let s=r?.internal===!0;this.node(e).down([[D,n]],{actor:r?.actor,internal:s,delivery:"write"})}complete(e,n){let r=n?.internal===!0;this.node(e).down([[V]],{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 P)for(let l of u._deps){let f=r.get(l.node);f!=null&&a.push([f,d])}return a.sort((d,u)=>d[0]<u[0]?-1:d[0]>u[0]?1:d[1]<u[1]?-1:d[1]>u[1]?1:0),a}let s=[];this._collectObserveTargets("",s);let o=new Map;for(let[a,d]of s)o.set(d,a);let i=[];for(let[a,d]of s)if(d instanceof P)for(let u of d._deps){let l=o.get(u.node);l!=null&&i.push([l,a])}return i.sort((a,d)=>a[0]<d[0]?-1:a[0]>d[0]?1:a[1]<d[1]?-1:a[1]>d[1]?1:0),i}mount(e,n){if(n===void 0){let s=new t(e);return this.mount(e,s)}if(typeof n=="function"){let s=new t(e);return n(s),this.mount(e,s)}let r=n;if(Nt(e,this.name,"mount"),this._nodes.has(e))throw new Error(`Graph "${this.name}": cannot mount at "${e}" \u2014 node with that name exists`);if(this._mounts.has(e))throw new Error(`Graph "${this.name}": mount "${e}" already exists`);if(r===this)throw new Error(`Graph "${this.name}": cannot mount a graph into itself`);if(r._parent!=null)throw new Error(`Graph "${this.name}": this child graph is already mounted on "${r._parent.name}"`);for(let s=this;s!=null;s=s._parent)if(s===r)throw new Error(`Graph "${this.name}": mount("${e}", \u2026) would create a mount cycle`);return this._mounts.set(e,r),r._parent=this,this._emitTopology({kind:"added",name:e,nodeKind:"mount"}),r}resolve(e){let n=qr(e,this.name);return this._resolveFromSegments(n)}tryResolve(e){try{return this.resolve(e)}catch{return}}_resolveFromSegments(e){let n=e;if(n[0]===this.name&&(n=n.slice(1),n.length===0))throw new Error(`Graph "${this.name}": resolve path ends at graph name only`);let r=n[0],s=n.slice(1);if(s.length===0){let a=this._nodes.get(r);if(a)return a;throw this._mounts.has(r)?new Error(`Graph "${this.name}": path ends at subgraph "${r}" \u2014 not a node (GRAPHREFLY-SPEC \xA73.5)`):new Error(`Graph "${this.name}": unknown name "${r}"`)}let o=this._nodes.get(r);if(o&&s.length>0&&s[0]===ee)return this._resolveMetaChainFromNode(o,s,n.join(I));let i=this._mounts.get(r);if(!i)throw this._nodes.has(r)?new Error(`Graph "${this.name}": "${r}" is a node; trailing path "${s.join(I)}" is invalid`):new Error(`Graph "${this.name}": unknown mount or node "${r}"`);return i.resolve(s.join(I))}_resolveMetaChainFromNode(e,n,r){let s=e,o=0,i=[...n];for(;o<i.length;){if(i[o]!==ee)throw new Error(`Graph "${this.name}": expected ${ee} segment in meta path "${r}"`);if(o+1>=i.length)throw new Error(`Graph "${this.name}": meta path requires a key after ${ee} in "${r}"`);let a=i[o+1],d=s.meta[a];if(!d)throw new Error(`Graph "${this.name}": unknown meta "${a}" in path "${r}"`);s=d,o+=2}return s}signal(e,n){if(n?.internal!==!0){for(let s of e)if(this.config.messageTier(s[0])===3)throw new Error(`Graph "${this.name}": Graph.signal() rejects tier-3 messages (DATA / RESOLVED). Broadcast is for control-plane tiers (START / DIRTY / INVALIDATE / PAUSE / RESUME / COMPLETE / ERROR / TEARDOWN). For per-node value writes, use Graph.set or graph.node(name).down(...).`)}let r=[];if(this._signalDeliver(e,n??{},new Set,r),r.length>0)throw r[0]}_signalDeliver(e,n,r,s){for(let d of this._mounts.values())d._signalDeliver(e,n,r,s);let i=n.internal===!0?{internal:!0}:{actor:n.actor,delivery:"signal"},a=Wr(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(l){if(l instanceof X)throw l;s.push(l)}a.length!==0&&this._signalMetaSubtree(u,a,r,i,s)}}}_signalMetaSubtree(e,n,r,s,o){for(let i of Object.keys(e.meta).sort()){let a=e.meta[i];if(!r.has(a)){r.add(a);try{a.down(n,s)}catch(d){if(d instanceof X)throw d;o.push(d)}this._signalMetaSubtree(a,n,r,s,o)}}}describe(e){if(e?.reactive===!0)return this._describeReactive(e);let n=Mr(e?.actor),r=e?.filter,s=Be(e?.detail,e?.fields),o=e?.format==="spec",i=o?Be("minimal"):s,a=[];this._collectObserveTargets("",a);let d=new Map;for(let[T,g]of a)d.set(g,T);let u=[];{let T=a.map(([,E])=>E),g=new Set(d.values()),y=0;for(;T.length>0;){let E=T.shift();if(E instanceof P)for(let R of E._deps){let N=R.node;if(d.has(N))continue;let k=N.name??"",S=k;if(!S||g.has(S))if(k){let M=2;for(;g.has(`${k}#${M}`);)M++;S=`${k}#${M}`}else for(S=`__internal__/${y++}`;g.has(S);)S=`__internal__/${y++}`;d.set(N,S),g.add(S),u.push([S,N]),T.push(N)}}}let l=[...a,...u],f={};for(let[T,g]of l){if(n!=null&&!g.allowsObserve(n))continue;let y=_t(g,i),E=g instanceof P?g._deps.map(S=>d.get(S.node)??S.node.name??""):[],{name:R,...N}=y,k={...N,deps:E};if(!o){let S=this._annotations.get(T);S!=null&&(k.annotation=S)}if(r!=null)if(typeof r=="function"){let S=r;if(!(S.length>=2?S(T,k):S(k)))continue}else{let S=!0;for(let[M,B]of Object.entries(r)){let z=M==="deps_includes"?"depsIncludes":M==="meta_has"?"metaHas":M;if(z==="depsIncludes"){if(!k.deps.includes(String(B))){S=!1;break}continue}if(z==="metaHas"){if(!Object.hasOwn(k.meta??{},String(B))){S=!1;break}continue}if(k[z]!==B){S=!1;break}}if(!S)continue}f[T]=k}let p=new Set(Object.keys(f)),h=[];for(let[T,g]of l)if(g instanceof P)for(let y of g._deps){let E=d.get(y.node);E!=null&&h.push([E,T])}h.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 c=h.map(([T,g])=>({from:T,to:g}));(n!=null||r!=null)&&(c=c.filter(T=>p.has(T.from)&&p.has(T.to)));let m=this._collectSubgraphs(""),x=n!=null||r!=null?m.filter(T=>{let g=`${T}${I}`;return[...p].some(y=>y===T||y.startsWith(g))}):m,v=this,_=e,b={name:this.name,nodes:f,edges:c,subgraphs:x,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),v.describe(g)}},w=e??{},O=w.format;return O==="json"?Pr(b,w):O==="pretty"?$r(b,w):O==="mermaid"?Tn(b,w):O==="mermaid-url"?Fr(b,w):O==="d2"?Vr(b,w):O==="ascii"?gn(b,w):b}_collectSubgraphs(e){let n=[];for(let r of[...this._mounts.keys()].sort()){let s=e===""?r:`${e}${r}`;n.push(s),n.push(...this._mounts.get(r)._collectSubgraphs(`${s}${I}`))}return n}resourceProfile(e){return mn(this,e)}reachable(e,n,r={}){return r.withDetail===!0?Rt(this.describe(),e,n,{...r,withDetail:!0}):Rt(this.describe(),e,n,r)}explain(e,n,r){return r?.reactive===!0?this._explainReactive(e,n,r):this._explainStatic(e,n,r)}_explainStatic(e,n,r){let s=this.describe({detail:"full"}),o=new Map(this._annotations),i=new Map;for(let[a,d]of Object.entries(s.nodes))d.lastMutation!=null&&i.set(a,d.lastMutation);return Zt(s,e,n,{...r?.maxDepth!=null?{maxDepth:r.maxDepth}:{},...r?.findCycle===!0?{findCycle:!0}:{},annotations:o,lastMutations:i})}_describeReactive(e){let n={...e,reactive:!1},r=e.reactiveName??"describe",s=0,o=W(s,{name:`${r}_version`}),i=this.observe({timeline:!0,structured:!0}),a=!1,d=!1,u=()=>{a||d||(a=!0,Ae(()=>{a=!1,!d&&(s+=1,o.emit(s))}))},l=i.onEvent(_=>{let b=_.type;b!=="data"&&b!=="error"&&b!=="complete"&&b!=="teardown"||u()}),f=[],p=new WeakSet,h=_=>{if(p.has(_)||d)return;p.add(_);let b=_.topology.subscribe(w=>{for(let O of w){if(O[0]!==G)continue;let T=O[1];if(u(),T.kind==="added"&&T.nodeKind==="mount"){let g=_._mounts.get(T.name);g!=null&&h(g)}}});f.push(b);for(let w of _._mounts.keys()){let O=_._mounts.get(w);O!=null&&h(O)}};h(this);let c,m=e.actor;_n(m)&&(c=m.subscribe(_=>{let b=!1,w=!1;for(let O of _){let T=O[0];T===G?b=!0:(T===V||T===D||T===j)&&(w=!0)}b&&u(),w&&(c?.(),c=void 0,u())}));let x;try{x=Z([o],()=>this.describe(n),{name:r,describeKind:"derived",meta:{domain:"audit",kind:"describe"},equals:(_,b)=>_===b})}catch(_){l(),c?.();for(let b of f)b();throw i.dispose(),_}let v=ae(x);return{node:x,dispose(){d=!0,l(),c?.();for(let _ of f)_();f.length=0,i.dispose(),v()}}}_explainReactive(e,n,r){let s=0,o=W(s,{name:"explain_version"}),i=this.observe({timeline:!0,structured:!0}),a=!1,d=!1,u=i.onEvent(h=>{let c=h.type;c!=="data"&&c!=="error"&&c!=="complete"&&c!=="teardown"||a||d||(a=!0,Ae(()=>{a=!1,!d&&(s+=1,o.emit(s))}))}),l={...r?.maxDepth!=null?{maxDepth:r.maxDepth}:{},...r?.findCycle===!0?{findCycle:!0}:{}},f;try{f=Z([o],()=>this._explainStatic(e,n,l),{name:r?.name??"explain",describeKind:"derived",meta:{domain:"audit",kind:"explain_path",from:e,to:n},equals:(h,c)=>h.found===c.found&&h.reason===c.reason&&h.steps.length===c.steps.length&&Ur(h.steps,c.steps)})}catch(h){throw u(),i.dispose(),h}let p=ae(f);return{node:f,dispose(){d=!0,u(),i.dispose(),p()}}}_pathsMatching(e){let n=Ze(e),r=[];return this._collectObserveTargets("",r),r.map(([s])=>s).filter(s=>n.test(s))}_collectObserveTargets(e,n){for(let r of[...this._mounts.keys()].sort()){let s=e===""?r:`${e}${I}${r}`;this._mounts.get(r)._collectObserveTargets(s,n)}for(let r of[...this._nodes.keys()].sort()){let s=this._nodes.get(r),o=e===""?r:`${e}${I}${r}`;n.push([o,s]),this._appendMetaObserveTargets(o,s,n)}}_appendMetaObserveTargets(e,n,r){for(let s of Object.keys(n.meta).sort()){let o=n.meta[s],i=`${e}${I}${ee}${I}${s}`;r.push([i,o]),this._appendMetaObserveTargets(i,o,r)}}observe(e,n){let r=typeof e=="string",o=vn(r?n:e),i=o.structured===!0||o.timeline===!0||o.causal===!0||o.derived===!0||o.detail==="minimal"||o.detail==="full"||o.format!=null,a=o.actor;if(r){let l=e,f=this.resolve(l);if(a!=null&&!f.allowsObserve(a))throw new X({actor:a,action:"observe",nodeName:l});return i?this._buildStructuredObserver([[l,f]],o,"one"):{subscribe(p){return f.subscribe(p)},up(p){try{f.up?.(p)}catch(h){if(h instanceof X)return;throw h}}}}let d=[];this._collectObserveTargets("",d),d.sort((l,f)=>l[0]<f[0]?-1:l[0]>f[0]?1:0);let u=a==null?d:d.filter(([,l])=>l.allowsObserve(a));return i?this._buildStructuredObserver(u,o,"all"):{subscribe:l=>{let f=u.map(([p,h])=>h.subscribe(c=>{l(p,c)}));return()=>{for(let p of f)p()}},up:(l,f)=>{try{this.resolve(l).up?.(f)}catch(p){if(p instanceof X)return;throw p}}}}_buildStructuredObserver(e,n,r){let s=r==="one"?e[0]?.[0]:void 0,o=i=>{if(r==="one"&&s!=null){let l=this.resolve(s);return this._buildStructuredObserver([[s,l]],i,"one")}let a=[];this._collectObserveTargets("",a),a.sort((l,f)=>l[0]<f[0]?-1:l[0]>f[0]?1:0);let d=i.actor,u=d==null?a:a.filter(([,l])=>l.allowsObserve(d));return this._buildStructuredObserver(u,i,"all")};return this._createObserveResult(e,n,o)}_createObserveResult(e,n,r){let s=n.timeline===!0,o=n.causal===!0,i=n.derived===!0,a=n.detail==="minimal",d=this.config.inspectorEnabled,u=(o||i)&&d,l=n.maxEvents,f=l!=null&&l>0?new Ce(l):null,p=[],h=new Set,c={},m=new Set,x=0,v=0,_=0,b=0,w=0,O=0,T=!1,g=!1,y=0,E=new Map,R=new Map,N=new Map,k=A=>{f?f.push(A):p.push(A);for(let L of h)L(A)},S=()=>s?{timestamp_ns:te(),in_batch:Se(),batch_id:y}:{},M=(A,L)=>{if(!(!u||!(A instanceof P)))return A._setInspectorHook(U=>{if(U.kind==="dep_message")E.set(A,U.depIndex);else if(U.kind==="run"){let Oe=U.batchData.map((C,H)=>C!=null&&C.length>0?C.at(-1):U.prevData[H]);R.set(A,Oe);let J=U.batchData.map(C=>C!=null?[...C]:void 0);N.set(A,J),i&&k({type:"derived",path:L,dep_values:Oe,dep_batches:J,...S()})}})},B=A=>{let L=E.get(A),U=R.get(A);if(!o||U==null)return{};let J=(L!=null&&L>=0&&A instanceof P?A._deps[L]:void 0)?.node,C=J?.v,H=N.get(A);return{trigger_dep_index:L,trigger_dep_name:J?.name,...C!=null?{trigger_version:{id:C.id,version:C.version}}:{},dep_values:[...U],...H!=null?{dep_batches:H}:{}}},z=[],le=[];for(let[A,L]of e){let U=M(L,A);U&&z.push(U),le.push(L.subscribe(Oe=>{y++;for(let J of Oe){let C=J[0],H=S();if(C===G){c[A]=J[1];let at=L instanceof P?L.lastMutation?.actor??_e:_e;k({type:"data",path:A,data:J[1],actor:at,...H,...B(L)})}else if(a)C===F?x++:C===q?v++:C===Q?_++:C===re?b++:C===se?w++:C===j?O++:C===V&&!m.has(A)?T=!0:C===D&&(g=!0,m.add(A));else if(C===F)x++,k({type:"dirty",path:A,...H});else if(C===q)v++,k({type:"resolved",path:A,...H,...B(L)});else if(C===Q)_++,k({type:"invalidate",path:A,...H});else if(C===re)b++,k({type:"pause",path:A,lockId:J[1],...H});else if(C===se)w++,k({type:"resume",path:A,lockId:J[1],...H});else if(C===V)m.has(A)||(T=!0),k({type:"complete",path:A,...H});else if(C===D){g=!0,m.add(A);let at=L instanceof P?L.lastMutation?.actor??_e:_e;k({type:"error",path:A,data:J[1],actor:at,...H})}else C===j&&(O++,k({type:"teardown",path:A,...H}))}}))}let st=!1,ot=()=>{if(!st){st=!0;for(let A of le)A();for(let A of z)A();for(let A of Ge)A({value:void 0,done:!0});Ge.length=0}},it=[],Ge=[];h.add(A=>{let L=Ge.shift();L?L({value:A,done:!1}):it.push(A)});let St={get values(){return c},get dirtyCount(){return x},get resolvedCount(){return v},get invalidateCount(){return _},get pauseCount(){return b},get resumeCount(){return w},get teardownCount(){return O},get events(){return f?f.toArray():[...p]},get anyCompletedCleanly(){return T},get anyErrored(){return g},get completedWithoutErrors(){return T&&!g},onEvent(A){return h.add(A),()=>h.delete(A)},dispose:ot,expand(A){ot();let L={...n};return typeof A=="string"?L.detail=A:Object.assign(L,A),r(vn(L))},[Symbol.asyncIterator](){return{next(){return it.length>0?Promise.resolve({value:it.shift(),done:!1}):st?Promise.resolve({value:void 0,done:!0}):new Promise(A=>Ge.push(A))},return(){return ot(),Promise.resolve({value:void 0,done:!0})}}}};return n.format!=null&&this._attachFormatLogger(St,n),St}_attachFormatLogger(e,n){let r=n.format;if(r==null)return;let s=n.logger??(c=>console.log(c)),o=n.includeTypes?new Set(n.includeTypes):null,i=n.excludeTypes?new Set(n.excludeTypes):null,a=o==null&&i==null?()=>!0:c=>(o==null||o.has(c))&&(i==null||!i.has(c)),d=Hr(n.theme),u=r==="stage-log"?te():0,l=c=>c==null?"":n.stageLabels?.[c]??c,f=(c,m)=>c.length>m?`${c.slice(0,m-1)}\u2026`:c,p=c=>c.type==="data"||c.type==="error"?f(et(c.data),120):"",h=c=>{if(r==="stage-log"){let g=(te()-u)/1e9,y=l(c.path).padEnd(9);if(c.type==="data"){let E=p(c);return`[${g.toFixed(3)}s] ${y} \u2190${E?` ${E}`:""}`}if(c.type==="error"){let E=p(c);return`[${g.toFixed(3)}s] ${y} \u2717${E?` ${E}`:""}`}return c.type==="complete"?`[${g.toFixed(3)}s] ${y} \u25A0 complete`:`[${g.toFixed(3)}s] ${y} ${c.type}`}if(r==="json")try{return JSON.stringify(c)}catch{return JSON.stringify({type:c.type,path:c.path,data:"[unserializable]"})}let m=d[c.type]??"",x=c.path?`${d.path}${c.path}${d.reset} `:"",v=c.type==="data"||c.type==="error",_=c.type==="pause"||c.type==="resume",b=v?` ${et(c.data)}`:_?` ${et(c.lockId)}`:"",w=c.type==="data"||c.type==="resolved"||c.type==="derived"?c:void 0,O=w?.trigger_dep_name!=null?` <- ${w.trigger_dep_name}`:w?.trigger_dep_index!=null?` <- #${w.trigger_dep_index}`:"",T=c.in_batch?" [batch]":"";return`${x}${m}${c.type.toUpperCase()}${d.reset}${b}${O}${T}`};e.onEvent(c=>{a(c.type)&&s(h(c),c)})}addDisposer(e){return this._disposers.add(e),()=>{this._disposers.delete(e)}}destroy(){bn(this._disposers,this.name),this.signal([[j]],{internal:!0}),bn(this._storageDisposers,this.name);for(let e of[...this._mounts.values()])e._parent=void 0,e._destroyClearOnly();this._mounts.clear(),this._nodes.clear(),this._parent=void 0,this._destroyed=!0}get destroyed(){return this._destroyed}_destroyClearOnly(){for(let e of[...this._mounts.values()])e._parent=void 0,e._destroyClearOnly();this._mounts.clear(),this._nodes.clear(),this._parent=void 0,this._destroyed=!0}snapshot(e){let{expand:n,...r}=this.describe({detail:"full"}),s={};for(let a of Object.keys(r.nodes).sort()){let{lastMutation:d,guard:u,...l}=r.nodes[a];s[a]=l}let o=[...r.subgraphs].sort(),i={...r,version:1,nodes:s,subgraphs:o};if(e?.format==null)return i;if(e.format==="json-string")return JSON.stringify(i);if(e.format==="bytes"){if(e.codec==null)throw new Error("snapshot({format: 'bytes'}) requires a `codec` name");let a=this.config.lookupCodec(e.codec);if(a==null)throw new Error(`snapshot: codec "${e.codec}" is not registered on this graph's config. Call config.registerCodec(...) before creating nodes.`);return Ft(a,a.encode(i))}throw new Error(`snapshot: unknown format "${String(e.format)}"`)}static decode(e,n){let r=n?.config??Ee,{codec:s,codecVersion:o,payload:i}=Vt(e,r);return s.decode(i,o)}restore(e,n){if(yn(e),e.name!==this.name)throw new Error(`Graph "${this.name}": restore snapshot name "${e.name}" does not match this graph`);let r=n?.only==null?null:(Array.isArray(n.only)?n.only:[n.only]).map(o=>Ze(o)),s=n?.includeProducers===!0;for(let o of Object.keys(e.nodes).sort()){if(r!==null&&!r.some(a=>a.test(o)))continue;let i=e.nodes[o];if(i!==void 0){if(!("value"in i)||i.value===void 0){"value"in i&&i.value===void 0&&n?.onError?.(o,new Error(`restore: slice.value is undefined for "${o}" (undefined is the global SENTINEL; not valid DATA)`));continue}if(!(i.type==="derived"||i.type==="effect")&&!(i.type==="producer"&&!s)){if(i.v!=null){let d=this.tryResolve(o)?.v;if(d!=null&&d.id===i.v.id&&d.version===i.v.version)continue}try{this.set(o,i.value)}catch(a){n?.onError?.(o,a)}}}}}static fromSnapshot(e,n){yn(e);let r=typeof n=="function"?n:n?.build,s=typeof n=="function"?void 0:n?.factories,o=new t(e.name);if(r)return r(o),o.restore(e),o;for(let h of[...e.subgraphs].sort((c,m)=>{let x=c.split(I).length,v=m.split(I).length;return x!==v?x-v:c<m?-1:c>m?1:0})){let c=h.split(I),m=o;for(let x of c)m._mounts.has(x)||m.mount(x,new t(x)),m=m._mounts.get(x)}let i=s?Object.entries(s).map(([h,c])=>({re:Ze(h),factory:c})):[],a=h=>{for(let c of i)if(c.re.test(h))return c.factory},d=h=>{let c=h.split(I),m=c.pop();if(m==null||m.length===0)throw new Error(`invalid snapshot path "${h}"`);let x=o;for(let v of c){let _=x._mounts.get(v);if(!_)throw new Error(`unknown mount "${v}" in path "${h}"`);x=_}return[x,m]},u=Object.entries(e.nodes).filter(([h])=>!h.includes(`${I}${ee}${I}`)).sort((h,c)=>h[0]<c[0]?-1:h[0]>c[0]?1:0),l=new Map(u),f=new Map,p=!0;for(;l.size>0&&p;){p=!1;for(let[h,c]of[...l.entries()]){let m=c?.deps??[];if(!m.every(O=>f.has(O)))continue;let[x,v]=d(h),_={...c?.meta??{}},b=a(h),w;if(c?.type==="state")w=W(c.value,{meta:_});else{if(b==null)continue;w=b(v,{path:h,type:c.type,value:c.value,meta:_,deps:m,resolvedDeps:m.map(O=>f.get(O))})}x.add(w,{name:v}),f.set(h,w),l.delete(h),p=!0}}if(l.size>0){let h=[...l.keys()].sort().join(", ");throw new Error(`Graph.fromSnapshot could not reconstruct nodes without build callback: ${h}. Pass matching factories via fromSnapshot(data, { factories: { pattern: factoryFn } }).`)}return o.restore(e),o}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 s=(u,l)=>{if(u.disposed)return;let f=Dr(l.nodes);if(u.lastSnapshot!=null&&f!==""&&f===u.lastFingerprint)return;let p=u.seq+1,h=ne(),x=u.lastSnapshot==null||p%u.compactEvery===0?{name:this.name,mode:"full",snapshot:l,seq:p,timestamp_ns:h,format_version:ye}:{name:this.name,mode:"diff",diff:Nn(u.lastSnapshot,l),seq:p,timestamp_ns:h,format_version:ye};if(u.tier.filter&&!u.tier.filter(x))return;let v;try{v=u.tier.save(x)}catch(_){n.onError?.(_,u.tier);return}if(v&&typeof v.then=="function"){let w=(u.savePending??Promise.resolve()).then(()=>v,()=>v).then(()=>{u.disposed||(u.seq=p,u.lastSnapshot=l,u.lastFingerprint=f)},O=>{n.onError?.(O,u.tier)});u.savePending=w.finally(()=>{u.savePending===w&&(u.savePending=void 0)})}else u.seq=p,u.lastSnapshot=l,u.lastFingerprint=f},o=(u,l)=>{try{s(u,l)}catch(f){n.onError?.(f,u.tier)}},i=(u,l)=>{if(!l.some(c=>{let m=this.config.messageTier(c[0]);return m>=3&&m<5}))return;if(n.filter){let c=this.tryResolve(u);if(c==null)return;let m=_t(c,Be("standard"));if(!n.filter(u,m))return}let p,h=()=>(p==null&&(p=this.snapshot()),p);for(let c of r)c.disposed||(c.debounceMs===0?o(c,h()):(c.timer==null&&(c.timer=new Je),c.timer.start(c.debounceMs,()=>{c.disposed||o(c,this.snapshot())})))},a;if(n.paths!=null){let l=(typeof n.paths=="string"?this._pathsMatching(n.paths):n.paths).map(f=>{let p=this.tryResolve(f);return p==null?()=>{}:p.subscribe(h=>i(f,h))});a=()=>{for(let f of l)f()}}else a=this.observe().subscribe((u,l)=>i(u,l));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 s;try{s=await r.load?.()}catch(i){n?.(i,r);continue}if(s==null||typeof s!="object"||Array.isArray(s))continue;let o=s;try{if(o.mode==="full"&&o.snapshot!=null)return this.restore(o.snapshot),!0;if(o.version===ye&&o.nodes!=null)return this.restore(o),!0}catch(i){n?.(i,r)}}return!1}static async fromStorage(e,n,r){for(let s of n){let o;try{o=await s.load?.()}catch(d){r?.onError?.(d,s);continue}if(o==null||typeof o!="object"||Array.isArray(o))continue;let i=o,a=i.mode==="full"&&i.snapshot!=null?i.snapshot:i.version===ye&&i.nodes!=null?i:void 0;if(a!=null)try{return t.fromSnapshot(a,r)}catch(d){r?.onError?.(d,s)}}throw new Error(`Graph.fromStorage: no tier held a restorable record for "${e}" across ${n.length} tier(s)`)}_annotations=new Map;_traceRing;trace(e,n,r){if(e!=null&&n!=null){if(this.tryResolve(e)==null)return;if(this._annotations.set(e,n),this.config.inspectorEnabled){let s={path:e,annotation:n,timestamp_ns:te(),...r?.actor!=null?{actor:r.actor}:{}};this._traceRing.push(s)}return}return e!=null?this.config.inspectorEnabled?this._annotations.get(e):void 0:this.config.inspectorEnabled?this._traceRing.toArray():[]}annotation(e){return this._annotations.get(e)}clearTrace(){this._annotations.clear(),this._traceRing.clear()}pruneTrace(e){let n=this._traceRing.toArray().filter(s=>!e(s)),r=this._traceRing.size-n.length;this._traceRing.clear();for(let s of n)this._traceRing.push(s);return r}static diff(e,n){let r=new Set(Object.keys(e.nodes)),s=new Set(Object.keys(n.nodes)),o=[...s].filter(_=>!r.has(_)).sort(),i=[...r].filter(_=>!s.has(_)).sort(),a=[],d=[];for(let _ of r){if(!s.has(_))continue;let b=e.nodes[_],w=n.nodes[_],O=b.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 y of["type","status","sentinel"]){let E=b[y],R=w[y];E!==R&&a.push({path:_,field:y,from:E,to:R})}if(!g)for(let y of["value","meta"]){let E=b[y],R=w[y];Cr(E,R)||a.push({path:_,field:y,from:E,to:R})}}let u=_=>`${_.from} ${_.to}`,l=new Set(e.edges.map(u)),f=new Set(n.edges.map(u)),p=n.edges.filter(_=>!l.has(u(_))),h=e.edges.filter(_=>!f.has(u(_))),c=new Set(e.subgraphs),m=new Set(n.subgraphs),x=[...m].filter(_=>!c.has(_)).sort(),v=[...c].filter(_=>!m.has(_)).sort();return{nodesAdded:o,nodesRemoved:i,nodesChanged:a,versionChanges:d,edgesAdded:p,edgesRemoved:h,subgraphsAdded:x,subgraphsRemoved:v}}};function Nn(t,e){let n=ve.diff(t,e),r={};for(let s of n.nodesAdded){let o=e.nodes[s];o!=null&&(r[s]=o)}return{...n,nodesAddedFull:r}}function Rt(t,e,n,r={}){let s={paths:[],depths:new Map,truncated:!1};if(!e)return r.withDetail?s:[];if(!r.both&&n!=="upstream"&&n!=="downstream")throw new Error('reachable: direction must be "upstream" or "downstream"');let o=r.maxDepth;if(o!=null&&(!Number.isInteger(o)||o<0))throw new Error("reachable: maxDepth must be an integer >= 0");if(o===0)return r.withDetail?s:[];let i=new Map,a=new Map,d=new Map,u=new Map,l=new Set;for(let[b,w]of Object.entries(t.nodes)){if(!b)continue;l.add(b);let O=w.deps??[];i.set(b,O);for(let T of O)T&&(l.add(T),a.has(T)||a.set(T,new Set),a.get(T).add(b))}for(let b of t.edges){if(b==null||typeof b!="object")continue;let w=typeof b.from=="string"?b.from:"",O=typeof b.to=="string"?b.to:"";!w||!O||(l.add(w),l.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(!l.has(e))return r.withDetail?s:[];let f=r.both===!0,p=b=>{if(f){let g=i.get(b)??[],y=d.get(b),E=a.get(b),R=u.get(b),N=[...g];return y&&N.push(...y),E&&N.push(...E),R&&N.push(...R),N}if(n==="upstream"){let g=i.get(b)??[],y=d.get(b);return y?[...g,...y]:g}let w=a.get(b),O=u.get(b),T=w?[...w]:[];return O&&T.push(...O),T},h=new Set([e]),c=new Map,m=[{path:e,depth:0}],x=0,v=!1;for(;x<m.length;){let b=m[x++];if(o!=null&&b.depth>=o){p(b.path).length>0&&(v=!0);continue}for(let w of p(b.path))!w||h.has(w)||(h.add(w),c.set(w,b.depth+1),m.push({path:w,depth:b.depth+1}))}let _=[...c.keys()].sort((b,w)=>b<w?-1:b>w?1:0);return r.withDetail?{paths:_,depths:c,truncated:v}:_}function Ur(t,e){if(t.length!==e.length)return!1;for(let n=0;n<t.length;n++){let r=t[n],s=e[n];if(r.path!==s.path||r.type!==s.type||r.status!==s.status||r.hop!==s.hop||r.dep_index!==s.dep_index||r.annotation!==s.annotation||r.value!==s.value||r.lastMutation!==s.lastMutation)return!1;let o=r.v,i=s.v;if(o!==i&&(o==null||i==null||o.id!==i.id||o.version!==i.version))return!1}return!0}Te();ue();var Jr=Pt((t,e)=>{t("observe"),t("signal"),e("write")});function kn(t){let e=Ke([],{name:t.name,maxSize:t.retainedLimit??1024,guard:t.guard??Jr,...t.versioning!=null?{versioning:t.versioning}:{}});return e.withLatest(),t.graph&&t.graph.add(e.entries,{name:t.name}),e}function Rn(t,e,n=0){let r=W(n,{name:e,describeKind:"state"});return t.add(r,{name:e}),r}He();function Sn(t,e,n){return{[t]:!0,[`${t}_type`]:e,...n??{}}}var Yr=256,Qr=1024;function An(t,e){if(!Number.isFinite(t)||!Number.isInteger(t)||t<0)throw new Error(`${e} must be a non-negative integer`);return t}function tt(t,e){return Sn("job_queue",t,e)}var Xr=t=>t.action,nt=class extends ve{_pending;_jobs;_seqCursor;pending;jobs;depth;events;audit;constructor(e,n={}){super(e,n.graph),this._pending=Ut([],{name:"pending"}),this._jobs=Qt({name:"jobs"}),this.pending=this._pending.items,this.jobs=this._jobs.entries,this.add(this.pending,{name:"pending"}),this.add(this.jobs,{name:"jobs"}),this.depth=Z([this.pending],([r])=>r.length,{name:"depth",describeKind:"derived",meta:tt("queue_depth"),initial:0}),this.add(this.depth,{name:"depth"}),this.addDisposer(ae(this.depth)),this.events=kn({name:"events",retainedLimit:1024,graph:this}),this.audit=this.events,this._seqCursor=Rn(this,"seq",0)}_bumpSeq(){let n=(this._seqCursor.cache??0)+1;return this._seqCursor.emit(n),n}attachEventStorage(e){return this.events.attachStorage(e)}enqueue(e,n={}){let r=this._bumpSeq(),s=n.id??`${this.name}-${r}`;if(this._jobs.get(s)!==void 0)throw new Error(`jobQueue("${this.name}"): duplicate job id "${s}"`);let o={id:s,payload:e,attempts:0,metadata:Object.freeze({...n.metadata??{}}),state:"queued"};return this._jobs.set(s,o),this._pending.append(s),this.events.append({action:"enqueue",id:s,payload:e,t_ns:ne(),seq:r}),s}claim(e=1){let n=An(e,"job queue claim limit");if(n===0)return[];let r=[];for(;r.length<n&&this.pending.cache.length!==0;){let o=this._pending.pop(0),i=this._jobs.get(o);if(!i||i.state!=="queued")continue;let a={...i,state:"inflight",attempts:i.attempts+1};this._jobs.set(o,a),r.push(a),this.events.append({action:"claim",id:o,attempts:a.attempts,t_ns:ne(),seq:this._bumpSeq()})}return r}ack(e){let n=this._jobs.get(e);return!n||n.state!=="inflight"?!1:(this._jobs.delete(e),this.events.append({action:"ack",id:e,attempts:n.attempts,t_ns:ne(),seq:this._bumpSeq()}),!0)}nack(e,n={}){let r=this._jobs.get(e);return!r||r.state!=="inflight"?!1:n.requeue??!0?(this._jobs.set(e,{...r,state:"queued"}),this._pending.append(e),this.events.append({action:"nack",id:e,attempts:r.attempts,t_ns:ne(),seq:this._bumpSeq()}),!0):(this._jobs.delete(e),this.events.append({action:"nack",id:e,attempts:r.attempts,t_ns:ne(),seq:this._bumpSeq()}),!0)}removeById(e){let n=this._jobs.get(e);if(!n)return!1;if(n.state==="queued"){let s=this.pending.cache.indexOf(e);s>=0&&this._pending.pop(s)}return this._jobs.delete(e),this.events.append({action:"remove",id:e,attempts:n.attempts,t_ns:ne(),seq:this._bumpSeq()}),!0}consumeFrom(e,n){return e.subscribe(r=>{for(let s of r){if(s[0]!==G)continue;let o=s[1];this.enqueue(o,n?{metadata:n.metadata}:void 0)}})}},rt=class extends ve{_stageNames;_stageWorkFns;_queues=new Map;_completed;completed;completedCount;constructor(e,n={}){super(e,n.graph);let r=n.stages??["incoming","processing","done"],s=[],o=new Map;for(let d of r){let u=typeof d=="string"?d.trim():d.name.trim();typeof d!="string"&&d.work&&o.set(u,d.work),s.push(u)}if(s.length<2)throw new Error(`jobFlow("${e}"): requires at least 2 stages`);if(new Set(s).size!==s.length)throw new Error(`jobFlow("${e}"): stage names must be unique`);this._stageNames=Object.freeze([...s]),this._stageWorkFns=o;for(let d of this._stageNames){let u=Mn(`${e}-${d}`);this._queues.set(d,u),this.mount(d,u)}this._completed=Ke([],{name:"completed",maxSize:Qr}),this.completed=this._completed.entries,this.add(this.completed,{name:"completed"}),this.completedCount=Z([this.completed],([d])=>d.length,{name:"completedCount",describeKind:"derived",meta:tt("job_flow_completed_count"),initial:0}),this.add(this.completedCount,{name:"completedCount"}),this.addDisposer(ae(this.completedCount));let a=Math.max(1,An(n.maxPerPump??Yr,"job flow maxPerPump"));for(let d=0;d<this._stageNames.length;d+=1){let u=this._stageNames[d],l=this.queue(u),f=d+1<this._stageNames.length?this.queue(this._stageNames[d+1]):null,p=this._stageWorkFns.get(u),h=f===null;if(p){let c=ie([l.pending],()=>{let m=0;for(;m<a;){let x=l.claim(1);if(x.length===0)break;let v=x[0];if(!v)break;let b=[...v.metadata.job_flow_path??[],u],w;try{w=p(v)}catch{l.nack(v.id,{requeue:!1}),m+=1;continue}let O=Yt(w),T=!1,g;g=O.subscribe(y=>{if(!T){for(let E of y)if(E[0]===G){T=!0,g?g():Promise.resolve().then(()=>g?.());let R=E[1],N={...v.metadata,job_flow_path:b};if(h){let k={...v,payload:R,metadata:Object.freeze(N)};K(()=>{l.ack(v.id),this._completed.append(k)})}else K(()=>{l.ack(v.id),f.enqueue(R,{metadata:N})});return}else if(E[0]===D){T=!0,g?g():Promise.resolve().then(()=>g?.()),l.nack(v.id,{requeue:!1});return}}}),m+=1}},{name:`pump_${u}`,describeKind:"effect",meta:tt("job_flow_pump",{stage:u,has_work:!0})});this.add(c,{name:`pump_${u}`}),this.addDisposer(ae(c))}else{let c=ie([l.pending],()=>{let m=0;for(;m<a;){let x=l.claim(1);if(x.length===0)break;let v=x[0];if(!v)break;let b=[...v.metadata.job_flow_path??[],u],w={...v.metadata,job_flow_path:b};if(h){let O={...v,metadata:Object.freeze(w)};K(()=>{l.ack(v.id),this._completed.append(O)})}else K(()=>{l.ack(v.id),f.enqueue(v.payload,{metadata:w})});m+=1}},{name:`pump_${u}`,describeKind:"effect",meta:tt("job_flow_pump",{stage:u,has_work:!1})});this.add(c,{name:`pump_${u}`}),this.addDisposer(ae(c))}}}stages(){return this._stageNames}queue(e){let n=this._queues.get(e);if(!n)throw new Error(`jobFlow("${this.name}"): unknown stage "${e}"`);return n}enqueue(e,n={}){return this.queue(this._stageNames[0]).enqueue(e,n)}retainedCompleted(){return this.completed.cache}};function Mn(t,e){return new nt(t,e)}function Zr(t,e){return new rt(t,e)}0&&(module.exports={JobFlowGraph,JobQueueGraph,jobEventKeyOf,jobFlow,jobQueue});
|
|
@@ -2,8 +2,8 @@ import '../../node-fSc-hCv8.cjs';
|
|
|
2
2
|
import '../../reactive-log-ScpWyqny.cjs';
|
|
3
3
|
import '../../extra/sources.cjs';
|
|
4
4
|
import '../../extra/storage-tiers.cjs';
|
|
5
|
-
import '../../graph-
|
|
5
|
+
import '../../graph-CaNXUc3c.cjs';
|
|
6
6
|
import '../../imperative-audit-ahAE65a9.cjs';
|
|
7
|
-
export { a as JobEnvelope, b as JobEvent, c as JobEventAction, d as JobFlowGraph, e as JobFlowOptions, J as JobQueueGraph, f as JobQueueOptions, g as JobState, S as StageDef, W as WorkFn, j as jobEventKeyOf, h as jobFlow, k as jobQueue } from '../../index-
|
|
7
|
+
export { a as JobEnvelope, b as JobEvent, c as JobEventAction, d as JobFlowGraph, e as JobFlowOptions, J as JobQueueGraph, f as JobQueueOptions, g as JobState, S as StageDef, W as WorkFn, j as jobEventKeyOf, h as jobFlow, k as jobQueue } from '../../index-D6pwWiOc.cjs';
|
|
8
8
|
import '../../meta-BGO6C7K9.cjs';
|
|
9
9
|
import '../../extra/storage-core.cjs';
|
|
@@ -2,8 +2,8 @@ import '../../node-fSc-hCv8.js';
|
|
|
2
2
|
import '../../reactive-log-jirQsxMY.js';
|
|
3
3
|
import '../../extra/sources.js';
|
|
4
4
|
import '../../extra/storage-tiers.js';
|
|
5
|
-
import '../../graph-
|
|
5
|
+
import '../../graph-YQXDndFy.js';
|
|
6
6
|
import '../../imperative-audit-ahAE65a9.js';
|
|
7
|
-
export { a as JobEnvelope, b as JobEvent, c as JobEventAction, d as JobFlowGraph, e as JobFlowOptions, J as JobQueueGraph, f as JobQueueOptions, g as JobState, S as StageDef, W as WorkFn, j as jobEventKeyOf, h as jobFlow, k as jobQueue } from '../../index-
|
|
7
|
+
export { a as JobEnvelope, b as JobEvent, c as JobEventAction, d as JobFlowGraph, e as JobFlowOptions, J as JobQueueGraph, f as JobQueueOptions, g as JobState, S as StageDef, W as WorkFn, j as jobEventKeyOf, h as jobFlow, k as jobQueue } from '../../index-9mbs_PIG.js';
|
|
8
8
|
import '../../meta-CC6EPdpK.js';
|
|
9
9
|
import '../../extra/storage-core.js';
|
|
@@ -1 +1 @@
|
|
|
1
|
-
import{a,b,c,d,e}from"../../chunk-
|
|
1
|
+
import{a,b,c,d,e}from"../../chunk-K2WYIVHM.js";import"../../chunk-FJ6IEMOS.js";import"../../chunk-O32GJOUJ.js";import"../../chunk-QWVQIL3T.js";import"../../chunk-M27MVZCP.js";import"../../chunk-B4L5X2QO.js";import"../../chunk-SGS4OJGS.js";import"../../chunk-ESMPEKEV.js";import"../../chunk-533RQFF6.js";import"../../chunk-KGKJCHEK.js";import"../../chunk-TZQPPQEQ.js";import"../../chunk-KUVDFOJH.js";import"../../chunk-MQZWA3DF.js";import"../../chunk-LYCLF26R.js";import"../../chunk-CK2E7BTU.js";import"../../chunk-QYADASLV.js";export{c as JobFlowGraph,b as JobQueueGraph,a as jobEventKeyOf,e as jobFlow,d as jobQueue};
|