@graphrefly/graphrefly 0.39.0 → 0.41.0
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/dist/{cascading-g2_rhhaM.d.ts → cascading-BNfxffgc.d.ts} +1 -1
- package/dist/{cascading-BzuxW0_w.d.cts → cascading-Cxs1eztH.d.cts} +1 -1
- package/dist/chunk-2W553JJC.js +1 -0
- package/dist/{chunk-5LK7XMEV.js → chunk-33N4TU3X.js} +1 -1
- package/dist/chunk-4MKL6Q3K.js +1 -0
- package/dist/chunk-5B3JDG5F.js +1 -0
- package/dist/chunk-5QSXEMXG.js +1 -0
- package/dist/{chunk-R75BMDLA.js → chunk-5TEFC2ZX.js} +1 -1
- package/dist/chunk-5TOPVRN6.js +1 -0
- package/dist/{chunk-INHC33EH.js → chunk-5VEZLQFN.js} +1 -1
- package/dist/{chunk-NQI2C36M.js → chunk-7PQLZMOG.js} +1 -1
- package/dist/{chunk-7NZMZJMW.js → chunk-AI7QC7J6.js} +1 -1
- package/dist/{chunk-L7WY6TZS.js → chunk-AK5RHMC5.js} +1 -1
- package/dist/{chunk-ZOX3LBRV.js → chunk-CGNOWGV6.js} +1 -1
- package/dist/{chunk-INH6FS2G.js → chunk-CYOSWFT2.js} +1 -1
- package/dist/{chunk-GX5LSSRE.js → chunk-EC2WNSZ7.js} +1 -1
- package/dist/{chunk-HAWKGIXM.js → chunk-ELAASRBT.js} +1 -1
- package/dist/{chunk-7QFRK3N3.js → chunk-F7VUYPP6.js} +1 -1
- package/dist/{chunk-LQNOXGET.js → chunk-G3M3IMEV.js} +1 -1
- package/dist/{chunk-HX3EGQ5Z.js → chunk-GI4Q7PNY.js} +1 -1
- package/dist/{chunk-XQ55HO5N.js → chunk-H5SCWHWP.js} +1 -1
- package/dist/{chunk-CGDMTXSY.js → chunk-KNVCCBIU.js} +1 -1
- package/dist/{chunk-IA7DUNGB.js → chunk-L77I47VU.js} +1 -1
- package/dist/{chunk-JNMC2WJ6.js → chunk-M3FQSXEW.js} +1 -1
- package/dist/{chunk-D47YVDR5.js → chunk-OLIKJUKI.js} +1 -1
- package/dist/{chunk-SC7BQDNP.js → chunk-OV5AA6HJ.js} +1 -1
- package/dist/{chunk-7JRF5YEK.js → chunk-POXANAJ6.js} +1 -1
- package/dist/chunk-RSMEXK53.js +43 -0
- package/dist/{chunk-KD4NHLMU.js → chunk-SC27WTSG.js} +1 -1
- package/dist/chunk-TSOYJ743.js +1 -0
- package/dist/{chunk-AU7YTQX7.js → chunk-TT4C7DXW.js} +1 -1
- package/dist/{chunk-TFPZLQ5H.js → chunk-UISPDFJ3.js} +1 -1
- package/dist/{chunk-N7UIBZCW.js → chunk-URJ2VFNC.js} +1 -1
- package/dist/{chunk-GEAO3TL3.js → chunk-VV62MIG4.js} +1 -1
- package/dist/{chunk-VJJLIEAL.js → chunk-VXPLLA4P.js} +1 -1
- package/dist/{chunk-WHIZM6JV.js → chunk-WZYB3JQS.js} +1 -1
- package/dist/{chunk-S2U57TFC.js → chunk-X7QKTXXC.js} +1 -1
- package/dist/{chunk-7SD73DS6.js → chunk-YQRN4CIV.js} +1 -1
- package/dist/chunk-Z6X7B6A4.js +61 -0
- package/dist/{chunk-RF3QZP6D.js → chunk-ZAJ7J7TO.js} +1 -1
- package/dist/compat/index.d.cts +6 -6
- package/dist/compat/index.d.ts +6 -6
- package/dist/compat/index.js +1 -1
- package/dist/compat/nestjs/index.d.cts +4 -4
- package/dist/compat/nestjs/index.d.ts +4 -4
- package/dist/compat/nestjs/index.js +1 -1
- 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/{composite-DGatA-JK.d.ts → decay-BnrlbxSv.d.ts} +38 -2
- package/dist/{composite-CKd0e2vz.d.cts → decay-C25AyNAj.d.cts} +38 -2
- package/dist/extra/index.cjs +15 -15
- package/dist/extra/index.d.cts +6 -6
- package/dist/extra/index.d.ts +6 -6
- package/dist/extra/index.js +1 -1
- package/dist/extra/node.js +1 -1
- package/dist/extra/operators.js +1 -1
- package/dist/extra/reactive.d.cts +1 -1
- package/dist/extra/reactive.d.ts +1 -1
- package/dist/extra/reactive.js +1 -1
- package/dist/extra/render/index.d.cts +1 -1
- package/dist/extra/render/index.d.ts +1 -1
- package/dist/extra/sources.cjs +1 -1
- package/dist/extra/sources.js +1 -1
- 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-30XSgtVX.d.ts → graph-BkIkog4h.d.ts} +1 -1
- package/dist/{graph-BUwMAxJI.d.cts → graph-E6likq7w.d.cts} +1 -1
- package/dist/{index-BXd6OMEy.d.ts → index-3k4Gg6-n.d.ts} +2 -2
- package/dist/{index-DszPlZzK.d.ts → index-40ZT4MHj.d.ts} +1 -1
- package/dist/index-8s-Qm-gz.d.ts +218 -0
- package/dist/{index-K-vl_c6A.d.cts → index-A3U3CSve.d.cts} +1 -1
- package/dist/{index-jKLph6cu.d.ts → index-B6iTqKtJ.d.ts} +1 -1
- package/dist/{index-WyFKER-c.d.ts → index-B72TQQHd.d.cts} +3 -3
- package/dist/{index-CmqiJZKM.d.ts → index-BAQrjuZF.d.ts} +64 -6
- package/dist/{index-CusEP3Sv.d.ts → index-BQ1fR4li.d.ts} +1 -1
- package/dist/{index-jr6PuSBt.d.ts → index-BaA-xpSw.d.ts} +2 -2
- package/dist/{index-FVoPvhAu.d.cts → index-Bd91Nmf4.d.cts} +2 -2
- package/dist/{index-PqbnoScQ.d.ts → index-BgjS2b8N.d.ts} +2 -2
- package/dist/{index-DCbE8fFM.d.cts → index-BiHUBEKq.d.cts} +2 -2
- package/dist/{index-DlgHqQxW.d.cts → index-BilOa6AE.d.cts} +6 -32
- package/dist/{index-DoYc8BWK.d.cts → index-BmSQLAZo.d.cts} +2 -2
- package/dist/{index-DlrWu9Hs.d.cts → index-C-dkXOpB.d.cts} +1 -1
- package/dist/{index-C7VV_qOs.d.ts → index-C5cQ7Gfx.d.ts} +2 -2
- package/dist/{index-CPhBvRJU.d.ts → index-C6ZUaos7.d.ts} +1 -1
- package/dist/{index-PlJ3MraE.d.ts → index-CAP3UGsq.d.ts} +1 -1
- package/dist/{index-B41Asm7D.d.ts → index-CD2dBMet.d.ts} +2 -2
- package/dist/{index-C19qqa38.d.ts → index-CG33HeBW.d.ts} +19 -4
- package/dist/index-CGhMJNHb.d.cts +128 -0
- package/dist/{index-BAlaVimV.d.ts → index-CQtWm7jS.d.ts} +2 -2
- package/dist/{index-8R1vzNOx.d.cts → index-CRm0YIzC.d.cts} +2 -2
- package/dist/index-CUIkE1l9.d.cts +230 -0
- package/dist/{index-KlZ_ZUip.d.cts → index-Cczxgd2D.d.ts} +3 -3
- package/dist/{index-DIHcMLr6.d.cts → index-CgnCFhr2.d.cts} +1 -1
- package/dist/{index-BC9VybQs.d.ts → index-Ck35nA-T.d.ts} +2 -2
- package/dist/{index-BndG0cpK.d.cts → index-Cnr1WrlX.d.cts} +1 -1
- package/dist/{index-H_I66pav.d.cts → index-CtFNGe-m.d.cts} +2 -2
- package/dist/index-CuPUehFa.d.cts +218 -0
- package/dist/index-D1Gc7wV5.d.ts +230 -0
- package/dist/{index-CWHtYmSh.d.cts → index-D4uimgee.d.cts} +1 -1
- package/dist/{index-xZYcDqFH.d.cts → index-DGD4_fj6.d.cts} +19 -4
- package/dist/{index-CwP_KAMS.d.cts → index-DGTo1yka.d.cts} +64 -6
- package/dist/{index-BUPVld1w.d.ts → index-DH4fm2Ck.d.ts} +2 -2
- package/dist/{index-DyM4tFAe.d.cts → index-DQQCOIt8.d.cts} +2 -2
- package/dist/{index-BJ26eEjs.d.cts → index-DVAlsmEU.d.cts} +2 -2
- package/dist/{index-DINuaZlJ.d.cts → index-DVDapw2k.d.cts} +1 -1
- package/dist/{index-iTX5IqSP.d.ts → index-DfOK_oL5.d.ts} +208 -203
- package/dist/{index-DTtBpuQy.d.cts → index-DgJc8Zgc.d.cts} +5 -3
- package/dist/{index-BKMdnYnk.d.ts → index-DhLyOHYZ.d.ts} +1 -1
- package/dist/{index-89FczVZ_.d.ts → index-DhnsQfa3.d.ts} +77 -51
- package/dist/{index-L8XI8Zql.d.cts → index-DktLSZOc.d.cts} +2 -2
- package/dist/{index-pVDQcbar.d.cts → index-DpiGqtrs.d.cts} +77 -51
- package/dist/{index-mNwgxC21.d.cts → index-DuRsN9ae.d.cts} +208 -203
- package/dist/{index-B9fmw5n2.d.ts → index-I1cCY3ZI.d.ts} +5 -3
- package/dist/index-N2MAxt7_.d.ts +128 -0
- package/dist/{index-Br3WnqEn.d.ts → index-WSlcjhQF.d.ts} +6 -32
- package/dist/{index-DQUVq1_d.d.ts → index-bXXLSvor.d.ts} +2 -2
- package/dist/{index-BhUaMYm_.d.ts → index-da2V5vPy.d.ts} +1 -1
- package/dist/{index-PsVHpPwP.d.cts → index-t6L2qpHh.d.cts} +2 -2
- package/dist/{index-IwFqHxCs.d.cts → index-tV3AA9hI.d.cts} +1 -1
- package/dist/index.cjs +48 -48
- package/dist/index.d.cts +33 -33
- package/dist/index.d.ts +33 -33
- package/dist/index.js +1 -1
- package/dist/patterns/ai/browser.cjs +5 -5
- package/dist/patterns/ai/browser.d.cts +2 -2
- package/dist/patterns/ai/browser.d.ts +2 -2
- package/dist/patterns/ai/browser.js +1 -1
- package/dist/patterns/ai/index.cjs +14 -14
- package/dist/patterns/ai/index.d.cts +11 -11
- package/dist/patterns/ai/index.d.ts +11 -11
- package/dist/patterns/ai/index.js +1 -1
- package/dist/patterns/ai/node.js +1 -1
- 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.d.cts +3 -3
- package/dist/patterns/cqrs/index.d.ts +3 -3
- package/dist/patterns/cqrs/index.js +1 -1
- 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.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.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 +3 -3
- 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 +8 -8
- package/dist/patterns/harness/index.d.cts +7 -7
- package/dist/patterns/harness/index.d.ts +7 -7
- package/dist/patterns/harness/index.js +1 -1
- package/dist/patterns/job-queue/index.cjs +3 -3
- package/dist/patterns/job-queue/index.d.cts +3 -3
- package/dist/patterns/job-queue/index.d.ts +3 -3
- package/dist/patterns/job-queue/index.js +1 -1
- package/dist/patterns/lens/index.cjs +3 -3
- package/dist/patterns/lens/index.d.cts +3 -4
- package/dist/patterns/lens/index.d.ts +3 -4
- package/dist/patterns/lens/index.js +1 -1
- package/dist/patterns/memory/index.cjs +1 -1
- package/dist/patterns/memory/index.d.cts +3 -3
- package/dist/patterns/memory/index.d.ts +3 -3
- package/dist/patterns/memory/index.js +1 -1
- 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.d.cts +3 -3
- package/dist/patterns/orchestration/index.d.ts +3 -3
- package/dist/patterns/orchestration/index.js +1 -1
- package/dist/patterns/process/index.d.cts +4 -4
- package/dist/patterns/process/index.d.ts +4 -4
- package/dist/patterns/process/index.js +1 -1
- 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.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.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.cjs +3 -1
- package/dist/patterns/resilient-pipeline/index.d.cts +7 -3
- package/dist/patterns/resilient-pipeline/index.d.ts +7 -3
- package/dist/patterns/resilient-pipeline/index.js +1 -1
- 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-D8vKcO_p.d.ts → pipeline-graph-CB4La-UW.d.ts} +2 -2
- package/dist/{pipeline-graph-BQPr2Lqs.d.cts → pipeline-graph-MWrQZXCq.d.cts} +2 -2
- package/dist/{reactive-layout-8CSc0tiA.d.cts → reactive-layout-BtZfUKuL.d.cts} +1 -1
- package/dist/{reactive-layout-DkTXxtSy.d.ts → reactive-layout-KJj4E2dT.d.ts} +1 -1
- package/dist/{reactive-map-B2qfD3hb.d.cts → reactive-map-6P_k3AQM.d.cts} +1 -1
- package/dist/{reactive-map-jFIsE6Kt.d.ts → reactive-map-CjXByDV-.d.ts} +1 -1
- package/dist/{resilience-HTF2LBRS.js → resilience-JISHQD2F.js} +1 -1
- package/dist/{topology-tree-B5Ngw3j0.d.cts → topology-tree-3LBKFsUo.d.cts} +1 -1
- package/dist/{topology-tree-BtvbgMXJ.d.ts → topology-tree-mF7Emqzm.d.ts} +1 -1
- package/package.json +1 -1
- package/dist/chunk-5XRI6RM3.js +0 -1
- package/dist/chunk-73PBQNST.js +0 -1
- package/dist/chunk-A6ZSKGUG.js +0 -1
- package/dist/chunk-EWF7KCDJ.js +0 -61
- package/dist/chunk-IUB4NYI2.js +0 -1
- package/dist/chunk-MC4UYY2X.js +0 -1
- package/dist/chunk-XEUANKBO.js +0 -43
- package/dist/chunk-ZJ7SM3G2.js +0 -1
- package/dist/index-BEHmxORq.d.ts +0 -135
- package/dist/index-BM9szD8n.d.cts +0 -113
- package/dist/index-BskfDoZ_.d.ts +0 -113
- package/dist/index-CIRG8Hxp.d.cts +0 -135
- package/dist/index-Cey6VTnX.d.ts +0 -166
- package/dist/index-CpLpJb6A.d.cts +0 -166
|
@@ -1,3 +1,3 @@
|
|
|
1
|
-
"use strict";var rt=Object.defineProperty;var Tn=Object.getOwnPropertyDescriptor;var On=Object.getOwnPropertyNames;var Nn=Object.prototype.hasOwnProperty;var z=(r,e)=>()=>(r&&(e=r(r=0)),e);var kn=(r,e)=>{for(var t in e)rt(r,t,{get:e[t],enumerable:!0})},xn=(r,e,t,n)=>{if(e&&typeof e=="object"||typeof e=="function")for(let s of On(e))!Nn.call(r,s)&&s!==t&&rt(r,s,{get:()=>e[s],enumerable:!(n=Tn(e,s))||n.enumerable});return r};var En=r=>xn(rt({},"__esModule",{value:!0}),r);function Mt(r,e){let t=new TextEncoder().encode(r.name);if(t.length===0||t.length>255)throw new Error(`encodeEnvelope: codec name "${r.name}" encodes to ${t.length} bytes (must be 1\u2013255)`);let n=r.version;if(!Number.isInteger(n)||n<0||n>65535)throw new Error(`encodeEnvelope: codec.version ${n} out of u16 range (expected integer 0\u201365535)`);let s=2+t.length+2+e.length;if(s>4294967295)throw new Error(`encodeEnvelope: total envelope size ${s} exceeds 2^32-1 bytes (payload ${e.length} bytes)`);let o=new Uint8Array(s),i=0;return o[i++]=st,o[i++]=t.length,o.set(t,i),i+=t.length,o[i++]=n>>>8&255,o[i++]=n&255,o.set(e,i),o}function Pt(r,e){if(r.length<Gt)throw new Error(`decodeEnvelope: bytes too short (${r.length} < ${Gt})`);let t=0,n=r[t++];if(n!==st)throw new Error(`decodeEnvelope: unsupported envelope version ${n} (expected ${st})`);let s=r[t++];if(s===0)throw new Error("decodeEnvelope: name_len must be >= 1");if(t+s+2>r.length)throw new Error(`decodeEnvelope: envelope truncated (need ${t+s+2} bytes, have ${r.length})`);let o=new TextDecoder().decode(r.subarray(t,t+s));t+=s;let i=(r[t]<<8|r[t+1])>>>0;t+=2;let a=r.subarray(t),d=e.lookupCodec(o);if(d==null)throw new Error(`decodeEnvelope: codec "${o}" not registered (envelope codec_v=${i})`);return{codec:d,codecVersion:i,payload:a}}function $t(r){r.registerCodec(Dn)}var Dn,st,Gt,ot=z(()=>{"use strict";Dn={name:"json",version:1,contentType:"application/json",encode(r){let e=JSON.stringify(r);return new TextEncoder().encode(e)},decode(r,e){let t=new TextDecoder().decode(r);return JSON.parse(t)}},st=1,Gt=4});function $e(r){if(r==null)return he;let{type:e,id:t,...n}=r;return{type:e??"system",id:t??"",...n}}var he,Ie=z(()=>{"use strict";he={type:"system",id:""}});function Le(){return ge>0||Ne}function zt(){return ge>0}function be(r){ge>0?ke.push(r):r()}function ue(r){ge+=1;let e=!1;try{r()}catch(t){throw e=!0,t}finally{if(ge-=1,ge===0)if(e){if(!Ne){let t=ke.splice(0);for(let n of t)try{n()}catch{}ae.length=0,de.length=0,me.length=0}}else Pn()}}function Pn(){let r=!Ne;r&&(Ne=!0);let e=[],t=0;try{for(;ae.length>0||de.length>0||me.length>0||r&&ke.length>0;){if(r&&ke.length>0){let o=ke.splice(0);for(let i of o)try{i()}catch(a){e.push(a)}continue}if(t+=1,t>1e3)throw ae.length=0,de.length=0,me.length=0,new Error("batch drain exceeded 1000 iterations \u2014 likely a reactive cycle");let s=(ae.length>0?ae:de.length>0?de:me).splice(0);for(let o of s)try{o()}catch(i){e.push(i)}}}finally{r&&(Ne=!1)}if(e.length===1)throw e[0];if(e.length>1)throw new AggregateError(e,"batch drain: multiple callbacks threw")}function Fe(r,e,t){if(e.length===0)return;if(e.length===1){let u=t(e[0][0]);if(u<3||!Le()){r(e);return}(u>=5?me:u===4?de:ae).push(()=>r(e));return}let n=e.length,s=n,o=n,i=n,a=0;for(;a<n&&t(e[a][0])<3;)a++;for(s=a;a<n&&t(e[a][0])===3;)a++;for(o=a;a<n&&t(e[a][0])===4;)a++;i=a;let d=Le();if(s>0){let u=e.slice(0,s);r(u)}if(o>s){let u=e.slice(s,o);d?ae.push(()=>r(u)):r(u)}if(i>o){let u=e.slice(o,i);d?de.push(()=>r(u)):r(u)}if(n>i){let u=e.slice(i,n);d?me.push(()=>r(u)):r(u)}}var ge,Ne,ae,de,me,ke,xe=z(()=>{"use strict";ge=0,Ne=!1,ae=[],de=[],me=[],ke=[]});function Z(){return Math.trunc(performance.now()*1e6)}function ye(){return Date.now()*1e6}var Ee=z(()=>{"use strict"});function jt(r){return Array.isArray(r)?[...r]:[r]}function $n(r,e){return r.has(e)||r.has("*")}function In(r){let e=[];return r((s,o)=>{e.push({kind:"allow",actions:new Set(jt(s)),where:o?.where??(()=>!0)})},(s,o)=>{e.push({kind:"deny",actions:new Set(jt(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 it(r){return In((e,t)=>{for(let n of r){let s=n.actorType==null?null:new Set(Array.isArray(n.actorType)?n.actorType:[n.actorType]),o=n.actorId==null?null:new Set(Array.isArray(n.actorId)?n.actorId:[n.actorId]),i=Object.entries(n.claims??{}),a=d=>{if(s!==null&&!s.has(String(d.type))||o!==null&&!o.has(String(d.id??"")))return!1;for(let[u,l]of i)if(d[u]!==l)return!1;return!0};n.effect==="deny"?t(n.action,{where:a}):e(n.action,{where:a})}})}function at(r){let e=Ln.filter(t=>r({type:t,id:""},"write"));return e.length===0?"restricted":e.includes("human")&&e.includes("llm")&&e.every(t=>t==="human"||t==="llm"||t==="system")?"both":e.length===1?e[0]:e.join("+")}var Y,Ln,ve=z(()=>{"use strict";Y=class extends Error{actor;action;nodeName;constructor(e,t){super(t??`GuardDenied: action "${String(e.action)}" denied for actor type "${String(e.actor.type)}"`),this.name="GuardDenied",this.actor=e.actor,this.action=e.action,this.nodeName=e.nodeName}get node(){return this.nodeName}};Ln=["human","llm","wallet","system"]});var _e,C,U,W,J,Q,ne,F,V,$,ce,Ve,Ht,ze,Bt,Ut,je,dt,ut,ct,He,oe=z(()=>{"use strict";_e=Symbol.for("graphrefly/START"),C=Symbol.for("graphrefly/DATA"),U=Symbol.for("graphrefly/DIRTY"),W=Symbol.for("graphrefly/RESOLVED"),J=Symbol.for("graphrefly/INVALIDATE"),Q=Symbol.for("graphrefly/PAUSE"),ne=Symbol.for("graphrefly/RESUME"),F=Symbol.for("graphrefly/TEARDOWN"),V=Symbol.for("graphrefly/COMPLETE"),$=Symbol.for("graphrefly/ERROR"),ce=Object.freeze([U]),Ve=Object.freeze([W]),Ht=Object.freeze([J]),ze=Object.freeze([_e]),Bt=Object.freeze([V]),Ut=Object.freeze([F]),je=Object.freeze([ce]),dt=Object.freeze([Ve]),ut=Object.freeze([Ht]),ct=Object.freeze([Bt]),He=Object.freeze([Ut])});function Wt(r){r.registerMessageType(_e,{tier:0,wireCrossing:!1}),r.registerMessageType(U,{tier:1,wireCrossing:!1}),r.registerMessageType(J,{tier:1,wireCrossing:!1,metaPassthrough:!1}),r.registerMessageType(Q,{tier:2,wireCrossing:!1}),r.registerMessageType(ne,{tier:2,wireCrossing:!1}),r.registerMessageType(C,{tier:3,wireCrossing:!0}),r.registerMessageType(W,{tier:3,wireCrossing:!0}),r.registerMessageType(V,{tier:4,wireCrossing:!0,metaPassthrough:!1}),r.registerMessageType($,{tier:4,wireCrossing:!0,metaPassthrough:!1}),r.registerMessageType(F,{tier:5,wireCrossing:!0,metaPassthrough:!1})}var Be,Kt=z(()=>{"use strict";oe();Be=class{_messageTypes=new Map;_codecs=new Map;_onMessage;_onSubscribe;_defaultVersioning;_defaultHashFn;_inspectorEnabled=!(typeof process<"u"&&process.env?.NODE_ENV==="production");_globalInspector;_rigorRecorder;_frozen=!1;tierOf;constructor(e){this._onMessage=e.onMessage,this._onSubscribe=e.onSubscribe,this._defaultVersioning=e.defaultVersioning,this._defaultHashFn=e.defaultHashFn,this.tierOf=t=>{let n=this._messageTypes.get(t);return n!=null?n.tier:1}}get onMessage(){return this._frozen=!0,this._onMessage}get onSubscribe(){return this._frozen=!0,this._onSubscribe}set onMessage(e){this._assertUnfrozen(),this._onMessage=e}set onSubscribe(e){this._assertUnfrozen(),this._onSubscribe=e}get defaultVersioning(){return this._defaultVersioning}set defaultVersioning(e){this._assertUnfrozen(),this._defaultVersioning=e}get defaultHashFn(){return this._defaultHashFn}set defaultHashFn(e){this._assertUnfrozen(),this._defaultHashFn=e}get inspectorEnabled(){return this._inspectorEnabled}set inspectorEnabled(e){this._inspectorEnabled=e}get globalInspector(){return this._globalInspector}set globalInspector(e){this._globalInspector=e}get rigorRecorder(){return this._rigorRecorder}set rigorRecorder(e){this._rigorRecorder=e}registerMessageType(e,t){return this._assertUnfrozen(),this._messageTypes.set(e,{tier:t.tier,wireCrossing:t.wireCrossing??t.tier>=3,metaPassthrough:t.metaPassthrough??!0}),this}messageTier(e){let t=this._messageTypes.get(e);return t!=null?t.tier:1}isWireCrossing(e){let t=this._messageTypes.get(e);return t!=null?t.wireCrossing:!0}isLocalOnly(e){return!this.isWireCrossing(e)}isMetaPassthrough(e){let t=this._messageTypes.get(e);return t!=null?t.metaPassthrough:!0}isKnownMessageType(e){return this._messageTypes.has(e)}registerCodec(e){return this._assertUnfrozen(),this._codecs.set(e.name,e),this}lookupCodec(e){return this._codecs.get(e)}_isFrozen(){return this._frozen}_assertUnfrozen(){if(this._frozen)throw new Error("GraphReFlyConfig is frozen: a node has already captured this config. Register custom types and set hooks before creating any node.")}}});function lt(r){if(r===void 0)return null;if(typeof r=="number"){if(!Number.isFinite(r))throw new TypeError(`Cannot hash non-finite number: ${r}`);if(Number.isInteger(r)&&!Number.isSafeInteger(r))throw new TypeError(`Cannot hash integer outside safe range (|n| > 2^53-1): ${r}. Cross-language cid parity is not guaranteed for unsafe integers.`);return r}if(typeof r=="string"||typeof r=="boolean"||r===null)return r;if(Array.isArray(r))return r.map(lt);if(typeof r=="object"&&r!==null){let e={};for(let t of Object.keys(r).sort())e[t]=lt(r[t]);return e}return null}function zn(r){let e=Vn.encode(r),t=e.length,n=t*8,s=t+9+63&-64,o=new Uint8Array(s);o.set(e),o[t]=128;let i=new DataView(o.buffer);i.setUint32(s-4,n>>>0,!1),i.setUint32(s-8,Math.floor(n/4294967296)>>>0,!1);let a=1779033703,d=3144134277,u=1013904242,l=2773480762,g=1359893119,f=2600822924,h=528734635,c=1541459225,_=new Uint32Array(64),p=(v,b)=>v>>>b|v<<32-b;for(let v=0;v<s;v+=64){for(let N=0;N<16;N++)_[N]=i.getUint32(v+N*4,!1);for(let N=16;N<64;N++){let S=_[N-15],D=_[N-2],R=p(S,7)^p(S,18)^S>>>3,se=p(D,17)^p(D,19)^D>>>10;_[N]=_[N-16]+R+_[N-7]+se>>>0}let b=a,y=d,w=u,k=l,m=g,O=f,x=h,A=c;for(let N=0;N<64;N++){let S=p(m,6)^p(m,11)^p(m,25),D=m&O^~m&x,R=A+S+D+Fn[N]+_[N]>>>0,se=p(b,2)^p(b,13)^p(b,22),te=b&y^b&w^y&w,De=se+te>>>0;A=x,x=O,O=m,m=k+R>>>0,k=w,w=y,y=b,b=R+De>>>0}a=a+b>>>0,d=d+y>>>0,u=u+w>>>0,l=l+k>>>0,g=g+m>>>0,f=f+O>>>0,h=h+x>>>0,c=c+A>>>0}let T=v=>v.toString(16).padStart(8,"0");return T(a)+T(d)+T(u)+T(l)+T(g)+T(f)+T(h)+T(c)}function pt(r){let e=lt(r??null),t=JSON.stringify(e);return zn(t).slice(0,16)}function jn(){let r=globalThis.crypto;if(r?.randomUUID)return r.randomUUID();let e=()=>Math.floor(Math.random()*4294967296).toString(16).padStart(8,"0"),t=e()+e()+e()+e();return`${t.slice(0,8)}-${t.slice(8,12)}-4${t.slice(13,16)}-${(parseInt(t.slice(16,17),16)&3|8).toString(16)}${t.slice(17,20)}-${t.slice(20,32)}`}function ft(r,e,t){let n=t?.id??jn();if(r===0)return{id:n,version:0};let o=(t?.hash??pt)(e);return{id:n,version:0,cid:o,prev:null}}function qt(r,e,t){r.version+=1,"cid"in r&&(r.prev=r.cid,r.cid=t(e))}var Fn,Vn,Yt=z(()=>{"use strict";Fn=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]),Vn=new TextEncoder});function Zt(r){return{node:r,unsub:null,prevData:void 0,dirty:!1,involvedThisWave:!1,dataBatch:[],terminal:void 0}}function ht(r){r.prevData=void 0,r.dirty=!1,r.involvedThisWave=!1,r.dataBatch.length=0,r.terminal=void 0}function Ue(r){return r.length===0?r:typeof r[0]=="symbol"?[r]:r}function Te(r,e,t){let n=Qt(r)?r:[],s=typeof r=="function"?r:typeof e=="function"?e:void 0,o={};return Qt(r)?o=(gt(e)?e:t)??{}:gt(r)?o=r:o=(gt(e)?e:t)??{},new I(n,s,o)}var Jt,Xt,Hn,Bn,we,I,Qt,gt,le=z(()=>{"use strict";ot();Ie();xe();Ee();Kt();ve();oe();Yt();Jt=()=>{},Xt=100;Hn=(r,e,t,n)=>{t.direction==="down-in"&&r._onDepMessage(t.depIndex,e)},Bn=(r,e,t,n)=>{let s=r;if(s._status==="completed"||s._status==="errored")return;let o=s._cached,i=o===void 0?[ze]:[ze,[C,o]];s._status==="dirty"&&i.push(ce),Fe(e,i,s._config.tierOf)},we=new Be({onMessage:Hn,onSubscribe:Bn});Wt(we);$t(we);I=class r{_optsName;_describeKind;meta;_hasMeta;_config;_deps;_sinks=null;_sinkCount=0;_cached;_status;_cleanup;_store={};_waveHasNewData=!1;_hasNewTerminal=!1;_hasCalledFnOnce=!1;_paused=!1;_pendingWave=!1;_isExecutingFn=!1;_pendingRerun=!1;_rerunDepth=0;_dirtyDepCount=0;_batchPendingMessages=null;_pauseLocks=null;_pauseBuffer=null;_fn;_equals;_resubscribable;_resetOnTeardown;_autoComplete;_autoError;_pausable;_partial;_guard;_extraGuards;_hashFn;_versioning;_versioningLevel;_lastMutation;_inspectorHooks;_actions;constructor(e,t,n){this._config=n.config??we,this._config.onMessage,this._optsName=n.name,this._describeKind=n.describeKind,this._equals=n.equals??Object.is,this._resubscribable=n.resubscribable??!1,this._resetOnTeardown=n.resetOnTeardown??!1,this._autoComplete=n.completeWhenDepsComplete??!0,this._autoError=n.errorWhenDepsError??!0,this._pausable=n.pausable??!0,this._guard=n.guard,this._fn=t,this._partial=n.partial??!1,this._cached=n.initial!==void 0?n.initial:void 0,this._status=e.length===0&&t==null&&this._cached!==void 0?"settled":"sentinel",this._hashFn=n.versioningHash??this._config.defaultHashFn??pt;let s=n.versioning??this._config.defaultVersioning;this._versioningLevel=s,this._versioning=s!=null?ft(s,this._cached===void 0?void 0:this._cached,{id:n.versioningId,hash:this._hashFn}):void 0,this._deps=e.map(Zt);let o={};for(let[a,d]of Object.entries(n.meta??{})){let u={initial:d,name:`${n.name??"node"}:meta:${a}`,describeKind:"state",config:this._config};n.guard!=null&&(u.guard=n.guard),o[a]=new r([],void 0,u)}Object.freeze(o),this.meta=o,this._hasMeta=Object.keys(o).length>0;let i=this;this._actions={emit(a){i._emit([[C,a]])},down(a){i._emit(Ue(a))},up(a){i._emitUp(Ue(a))}},this.down=this.down.bind(this),this.up=this.up.bind(this)}get _isTerminal(){return this._status==="completed"||this._status==="errored"}get name(){return this._optsName}get status(){return this._status}get cache(){return this._cached===void 0?void 0:this._cached}get lastMutation(){return this._lastMutation}get v(){return this._versioning}hasGuard(){return this._guard!=null}_applyVersioning(e,t){if(this._isExecutingFn)throw new Error(`Node "${this.name}": _applyVersioning cannot run mid-fn \u2014 call it outside of \`_execFn\` (typically at graph setup time before the first subscribe).`);let n=this._versioningLevel;if(n!=null&&e<=n)return;let s=t?.hash??this._hashFn;s!==this._hashFn&&(this._hashFn=s);let o=this._cached===void 0?void 0:this._cached,i=this._versioning,a=i?.id??t?.id,d=i?.version??0,u=ft(e,o,{id:a,hash:s});u.version=d,this._versioning=u,this._versioningLevel=e}_setInspectorHook(e){return e==null?()=>{}:(this._inspectorHooks==null&&(this._inspectorHooks=new Set),this._inspectorHooks.add(e),()=>{this._inspectorHooks?.delete(e),this._inspectorHooks?.size===0&&(this._inspectorHooks=void 0)})}_pushGuard(e){return this._extraGuards==null&&(this._extraGuards=new Set),this._extraGuards.add(e),()=>{this._extraGuards?.delete(e),this._extraGuards?.size===0&&(this._extraGuards=void 0)}}allowsObserve(e){if(this._guard==null&&this._extraGuards==null)return!0;let t=$e(e);if(this._guard!=null&&!this._guard(t,"observe"))return!1;if(this._extraGuards!=null){for(let n of this._extraGuards)if(!n(t,"observe"))return!1}return!0}_checkGuard(e){if(e?.internal)return;let t=this._guard!=null||this._extraGuards!=null,n=e?.actor!=null;if(!t&&!n)return;let s=$e(e?.actor),o=e?.delivery==="signal"?"signal":"write";if(this._guard!=null&&!this._guard(s,o))throw new Y({actor:s,action:o,nodeName:this.name});if(this._extraGuards!=null){for(let i of this._extraGuards)if(!i(s,o))throw new Y({actor:s,action:o,nodeName:this.name})}this._lastMutation={actor:s,timestamp_ns:ye()}}down(e,t){let n=Ue(e);n.length!==0&&(this._checkGuard(t),this._emit(n))}emit(e,t){this._checkGuard(t),this._emit([[C,e]])}up(e,t){if(this._deps.length===0)return;let n=Ue(e);if(n.length===0)return;this._checkGuard(t);let s=t??{internal:!0};this._validateUpTiers(n);for(let o of this._deps)o.node.up?.(n,s)}_emitUp(e){if(this._deps.length!==0&&e.length!==0){this._validateUpTiers(e);for(let t of this._deps)t.node.up?.(e,{internal:!0})}}_validateUpTiers(e){let t=this._config.tierOf;for(let n of e){let s=t(n[0]);if(s===3||s===4)throw new Error(`Node "${this.name}": tier-${s} messages cannot flow up \u2014 DATA/RESOLVED/COMPLETE/ERROR are downstream-only. Use \`down(...)\` for value delivery; \`up(...)\` is for control signals (DIRTY, INVALIDATE, PAUSE, RESUME, TEARDOWN).`)}}subscribe(e,t){if(t!=null&&this._guard!=null){let d=$e(t);if(!this._guard(d,"observe"))throw new Y({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)ht(d);if(this._partial===!1){for(let d of this._deps)if(d.prevData!==void 0||d.dataBatch.length!==0||d.terminal!==void 0||d.dirty)throw new Error(`resubscribable-reset invariant: DepRecord not fully reset for node ${this._optsName??"(anonymous)"}`)}}this._sinkCount+=1;let o;try{o=this._config.onSubscribe(this,e,{sinkCount:this._sinkCount,afterTerminalReset:s},this._actions)}catch(d){throw this._sinkCount-=1,d}this._sinks==null?this._sinks=e:typeof this._sinks=="function"?this._sinks=new Set([this._sinks,e]):this._sinks.add(e);let i=this._isTerminal;if(this._sinkCount===1&&!i)try{this._activate()}catch(d){if(this._sinkCount-=1,this._removeSink(e),this._sinkCount===0&&(this._status="sentinel"),typeof o=="function")try{o()}catch{}throw d}this._status==="sentinel"&&this._cached===void 0&&(this._status="pending");let a=!1;return()=>{a||(a=!0,this._sinkCount-=1,this._removeSink(e),typeof o=="function"&&o(),this._sinks==null&&this._deactivate())}}_removeSink(e){if(this._sinks===e)this._sinks=null;else if(this._sinks!=null&&typeof this._sinks!="function")if(this._sinks.delete(e),this._sinks.size===1){let[t]=this._sinks;this._sinks=t}else this._sinks.size===0&&(this._sinks=null)}_activate(){if(this._deps.length===0){this._fn&&this._execFn();return}this._dirtyDepCount=0;let e=this._deps.length,t=0;try{for(let n=0;n<e;n++){let s=n,o=this._deps[n];o.unsub=Jt,o.unsub=o.node.subscribe(i=>{if(o.unsub===null)return;let a=this._config.tierOf,d=!1;for(let u of i)a(u[0])>=3&&(d=!0),this._config.onMessage(this,u,{direction:"down-in",depIndex:s},this._actions);d&&this._maybeRunFnOnSettlement()}),t++}}catch(n){this._deps[t].unsub=null;for(let s=0;s<t;s++){let o=this._deps[s];if(o.unsub!=null){let i=o.unsub;o.unsub=null;try{i()}catch{}ht(o)}}throw this._dirtyDepCount=0,n}}_addDep(e){for(let s=0;s<this._deps.length;s++)if(this._deps[s].node===e)return s;let t=this._deps.length,n=Zt(e);if(this._deps.push(n),this._sinks==null)return t;n.dirty=!0,this._dirtyDepCount++,this._status!=="dirty"&&this._emit(je),n.unsub=Jt;try{n.unsub=e.subscribe(s=>{if(n.unsub===null)return;let o=this._config.tierOf,i=!1;for(let a of s)o(a[0])>=3&&(i=!0),this._config.onMessage(this,a,{direction:"down-in",depIndex:t},this._actions);i&&this._maybeRunFnOnSettlement()})}catch(s){throw n.unsub=null,this._deps.pop(),this._dirtyDepCount--,s}return t}_deactivate(e=!1){let t=this._cleanup;if(this._cleanup=void 0,typeof t=="function")try{t()}catch(n){this._emit([[$,this._wrapFnError("cleanup threw",n)]])}else if(t!=null&&typeof t=="object"){let n=t.deactivate;if(typeof n=="function")try{n()}catch(s){this._emit([[$,this._wrapFnError("cleanup.deactivate threw",s)]])}}for(let n of this._deps){if(n.unsub!=null){let s=n.unsub;n.unsub=null;try{s()}catch{}}ht(n)}this._waveHasNewData=!1,this._hasNewTerminal=!1,this._hasCalledFnOnce=!1,this._paused=!1,this._pendingWave=!1,this._pendingRerun=!1,this._rerunDepth=0,this._store={},this._dirtyDepCount=0,this._pauseLocks=null,this._pauseBuffer=null,this._fn!=null&&(this._cached=void 0),e||(this._fn!=null||this._deps.length>0)&&(!this._isTerminal||this._resubscribable)&&(this._status="sentinel")}_onDepMessage(e,t){let n=this._deps[e],s=t[0];if(this._inspectorHooks!=null){let o={kind:"dep_message",depIndex:e,message:t};for(let i of this._inspectorHooks)i(o)}if(s!==_e){if(s===U){this._depDirtied(n);return}if(s===J){if(this._depInvalidated(n),this._cached===void 0)return;this._emit(ut);return}if(s===Q||s===ne){this._emit([t]);return}if(s===F){this._emit(He);return}if(s===C)this._depSettledAsData(n,t[1]);else if(s===W)this._depSettledAsResolved(n);else if(s===V)this._depSettledAsTerminal(n,!0);else if(s===$)this._depSettledAsTerminal(n,t[1]);else{this._emit([t]);return}if(!this._fn){(s===C||s===W)&&this._emit([t]),(s===V||s===$)&&this._maybeAutoTerminalAfterWave();return}}}_depDirtied(e){e.dirty||(e.dirty=!0,e.involvedThisWave=!0,this._dirtyDepCount++,this._status!=="dirty"&&this._emit(je))}_depSettledAsData(e,t){e.dirty&&(e.dirty=!1,this._dirtyDepCount--),e.involvedThisWave=!0,e.dataBatch.push(t),this._waveHasNewData=!0}_depSettledAsResolved(e){e.dirty&&(e.dirty=!1,this._dirtyDepCount--)}_depSettledAsTerminal(e,t){e.dirty&&(e.dirty=!1,this._dirtyDepCount--),e.terminal=t,e.involvedThisWave=!0,this._hasNewTerminal=!0}_depInvalidated(e){e.prevData=void 0,e.terminal=void 0,e.dataBatch.length=0,e.dirty?e.involvedThisWave=!1:(e.dirty=!0,e.involvedThisWave=!0,this._dirtyDepCount++)}_maybeRunFnOnSettlement(){if(!(this._isTerminal&&!this._resubscribable)&&!(this._dirtyDepCount>0)){if(!this._partial&&!this._hasCalledFnOnce)for(let e=0;e<this._deps.length;e++){let t=this._deps[e];if(t.dataBatch.length===0&&t.prevData===void 0&&t.terminal===void 0){this._maybeAutoTerminalAfterWave();return}}if(this._paused){this._pendingWave=!0;return}if(!this._waveHasNewData&&!this._hasNewTerminal&&this._hasCalledFnOnce){this._clearWaveFlags(),this._emit(dt),this._maybeAutoTerminalAfterWave();return}this._fn&&this._execFn(),this._maybeAutoTerminalAfterWave()}}_maybeAutoTerminalAfterWave(){if(this._deps.length===0||this._isTerminal)return;let e=this._deps.find(t=>t.terminal!==void 0&&t.terminal!==!0);if(e!=null){this._autoError&&this._emit([[$,e.terminal]]);return}this._autoComplete&&this._deps.every(t=>t.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([[$,this._wrapFnError("cleanup threw",i)]]);return}}else if(e!=null&&typeof e=="object"){let i=e.beforeRun;if(typeof i=="function"){e.beforeRun=void 0;try{i()}catch(a){this._emit([[$,this._wrapFnError("cleanup.beforeRun threw",a)]]);return}}}let t=this._deps.map(i=>i.involvedThisWave?i.dataBatch.length>0?[...i.dataBatch]:[]:void 0),n=this._deps.map(i=>i.prevData);for(let i=0;i<this._deps.length;i++){let a=t[i];a!=null&&a.length>0&&(this._deps[i].prevData=a[a.length-1])}let s=this._deps.map(i=>i.terminal),o={prevData:n,terminalDeps:s,store:this._store};if(this._hasCalledFnOnce=!0,this._clearWaveFlags(),this._inspectorHooks!=null){let i={kind:"run",batchData:t,prevData:n};for(let a of this._inspectorHooks)a(i)}this._isExecutingFn=!0;try{let i=this._fn(t,this._actions,o);if(typeof i=="function")this._cleanup=i;else if(i!=null&&typeof i=="object"){let a=i;(typeof a.beforeRun=="function"||typeof a.deactivate=="function"||typeof a.invalidate=="function")&&(this._cleanup=i)}}catch(i){this._emit([[$,this._wrapFnError("fn threw",i)]])}finally{this._isExecutingFn=!1,this._pendingRerun?(this._pendingRerun=!1,this._rerunDepth+=1,this._rerunDepth>Xt?(this._rerunDepth=0,this._emit([[$,new Error(`Node "${this.name}": _pendingRerun depth exceeded ${Xt} \u2014 likely a reactive cycle`)]])):this._maybeRunFnOnSettlement()):this._rerunDepth=0,this._clearWaveFlags()}}_clearWaveFlags(){this._waveHasNewData=!1,this._hasNewTerminal=!1;for(let e of this._deps)e.involvedThisWave=!1,e.dataBatch.length=0}_wrapFnError(e,t){let n=t instanceof Error?t.message:String(t);return new Error(`Node "${this.name}": ${e}: ${n}`,{cause:t})}_frameBatch(e){let t=this._config.tierOf;if(e.length===1)return t(e[0][0])===3&&this._status!=="dirty"?[ce,e[0]]:e;let n=!0,s=!1,o=!1,i=-1;for(let d of e){let u=t(d[0]);u<i&&(n=!1),u===3&&(s=!0),d[0]===U&&(o=!0),i=u}let a=e;if(!n){let d=e.map((u,l)=>({m:u,i:l,tier:t(u[0])}));d.sort((u,l)=>u.tier-l.tier||u.i-l.i),a=d.map(u=>u.m)}if(s&&!o&&this._status!=="dirty"){let d=0;for(;d<a.length&&t(a[d][0])===0;)d++;return d===0?[ce,...a]:[...a.slice(0,d),ce,...a.slice(d)]}return a}_emit(e){if(e.length===0)return;for(let a=0;a<e.length;a++){let d=e[a];if(d[0]===$&&d[1]===void 0)throw new TypeError('[ERROR, payload] requires a non-undefined payload (spec \xA71.2). Pass an Error object or domain tag instead \u2014 e.g. node.down([[ERROR, new Error("reason")]])')}let t=e;if(this._isTerminal&&!this._resubscribable){let a=e.filter(d=>d[0]===F||d[0]===J);if(a.length===0)return;t=a}t=this._frameBatch(t);let s=null;for(let a=0;a<t.length;a++){let d=t[a],u=d[0];if(u!==Q&&u!==ne){s?.push(d);continue}if(d.length<2)throw new Error(`Node "${this.name}": [[${u===Q?"PAUSE":"RESUME"}]] must carry a lockId payload \u2014 bare PAUSE/RESUME is a protocol violation (C0 rule). Use \`[[PAUSE, lockId]]\` / \`[[RESUME, lockId]]\`.`);let l=!0;if(this._pausable!==!1){let g=d[1];if(u===Q)this._pauseLocks==null&&(this._pauseLocks=new Set),this._pauseLocks.add(g),this._paused=!0,this._pausable==="resumeAll"&&this._pauseBuffer==null&&(this._pauseBuffer=[]);else if(this._pauseLocks==null||!this._pauseLocks.has(g))l=!1;else if(this._pauseLocks.delete(g),this._pauseLocks.size===0){if(this._paused=!1,this._pauseBuffer!=null&&this._pauseBuffer.length>0){let f=this._pauseBuffer;this._pauseBuffer=[],this._emit(f)}this._pendingWave&&(this._pendingWave=!1,this._maybeRunFnOnSettlement())}}l?s?.push(d):s==null&&(s=t.slice(0,a))}if(s!=null){if(s.length===0)return;t=s}if(this._hasMeta&&t.some(a=>a[0]===F))for(let a of Object.keys(this.meta))try{this.meta[a]._emit(He)}catch{}let{finalMessages:o,equalsError:i}=this._updateState(t);if(o.length>0&&this._config.inspectorEnabled){let a=this._config.globalInspector;if(a!=null)try{a({kind:"emit",node:this,messages:o})}catch{}}if(o.length>0)if(this._paused&&this._pausable==="resumeAll"&&this._pauseBuffer!=null){let a=this._config.tierOf,d=[];for(let u of o)a(u[0])===3?this._pauseBuffer.push(u):d.push(u);d.length>0&&this._dispatchOrAccumulate(d)}else this._dispatchOrAccumulate(o);i!=null&&this._emit([[$,i]])}_updateState(e){let t=this._config.tierOf,n,s,o=-1,i=0;for(let l of e)t(l[0])===3&&i++;let a=i<=1,d=-1;if(this._versioning!=null&&i>1){for(let l=e.length-1;l>=0;l--)if(e[l][0]===C){d=l;break}}for(let l=0;l<e.length;l++){let g=e[l],f=g[0];if(f===C){if(g.length>=2){let h=!1;if(a&&this._cached!==void 0)try{h=this._equals(this._cached,g[1])}catch(c){s=this._wrapFnError("equals threw",c),o=l;break}if(h){n==null&&(n=e.slice(0,l)),n.push(Ve),this._status="resolved";continue}this._cached=g[1],this._versioning!=null&&(d<0||l===d)&&qt(this._versioning,g[1],this._hashFn)}this._status="settled",n?.push(g)}else if(n?.push(g),f===U)this._status="dirty";else if(f===W)this._status="resolved";else if(f===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(f===$){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(f===J){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 f===F&&(this._resetOnTeardown&&(this._cached=void 0),this._deactivate(!0),this._status="sentinel")}let u=o>=0?n??e.slice(0,o):n??e;return s!=null?{finalMessages:u,equalsError:s}:{finalMessages:u}}_deliverToSinks=e=>{if(this._sinks==null)return;if(typeof this._sinks=="function"){this._sinks(e);return}let t=[...this._sinks];for(let n of t)n(e)};_dispatchOrAccumulate(e){if(zt()){this._batchPendingMessages===null&&(this._batchPendingMessages=[],be(()=>this._flushBatchPending()));for(let t of e)this._batchPendingMessages.push(t);return}Fe(this._deliverToSinks,e,this._config.tierOf)}_flushBatchPending(){let e=this._batchPendingMessages;if(e===null||(this._batchPendingMessages=null,e.length===0))return;let t=this._frameBatch(e);Fe(this._deliverToSinks,t,this._config.tierOf)}},Qt=r=>Array.isArray(r),gt=r=>typeof r=="object"&&r!=null&&!Array.isArray(r)});function bt(r,e){if(e!=null&&e.length>0)return new Set(e);switch(r){case"standard":return new Set(["type","status","value","deps","meta","v"]);case"full":return null;case"spec":return new Set(["type","deps","meta","value"]);default:return new Set(["type","deps"])}}function Un(r){return r._describeKind!=null?r._describeKind:r._deps.length>0?"derived":r._fn!=null?"producer":"state"}function en(r){let e=new WeakSet,t={};for(let[n,s]of tn(r))t[n]=mt(s,e);return t}function mt(r,e){if(r==null)return r;let t=typeof r;if(t==="boolean"||t==="number"||t==="string")return r;if(t==="function")return"<function>";if(Array.isArray(r))return e.has(r)?"<cycle>":(e.add(r),r.map(n=>mt(n,e)));if(t==="object"){let n=r;if(e.has(n))return"<cycle>";e.add(n);try{if(typeof n.subscribe=="function"&&"cache"in n)return"<Node>"}catch{return"<unserializable>"}let s={};for(let[o,i]of tn(n))s[o]=mt(i,e);return s}return"<unserializable>"}function tn(r){let e=[],t;try{t=Object.keys(r)}catch{return e}for(let n of t)try{e.push([n,r[n]])}catch{e.push([n,"<unserializable>"])}return e}function Wn(r){let e={};for(let[t,n]of Object.entries(r.meta))try{e[t]=n.cache}catch{}return e}function yt(r,e,t){let n=e==null,s=!n&&e!=null?[...e].filter(l=>l.startsWith("meta.")).map(l=>l.slice(5)):null,o=n||e.has("meta")||s!=null&&s.length>0,i="state",a=[];r instanceof I&&(i=Un(r),a=r._deps.map(l=>l.node.name??""));let d={type:i,deps:a};(n||e.has("status"))&&(d.status=r.status);let u=r instanceof I?r._guard:void 0;if(o){let l={...Wn(r)};if(u!=null&&l.access===void 0&&(l.access=at(u)),s!=null&&s.length>0&&!e.has("meta")){let g={};for(let f of s)f in l&&(g[f]=l[f]);d.meta=g}else d.meta=l}if(r.name!=null&&(d.name=r.name),(n||e.has("value"))&&(!t||i==="state")){r.status==="sentinel"&&(d.sentinel=!0);try{d.value=r.cache}catch{}}if((n||e.has("v"))&&r.v!=null){let l={id:r.v.id,version:r.v.version};"cid"in r.v&&(l.cid=r.v.cid,l.prev=r.v.prev),d.v=l}return(n||e.has("guard"))&&u!=null&&(d.guard=at(u)),(n||e.has("lastMutation"))&&r.lastMutation!=null&&(d.lastMutation=r.lastMutation),d}var vt=z(()=>{"use strict";ve();le()});function ee(r,e){return Te([],{...e,initial:r})}function We(r,e){return Te((n,s,o)=>r(s,o)??void 0,{describeKind:"producer",...e})}function H(r,e,t){return Te(r,(s,o,i)=>{let a=s.map((d,u)=>d!=null&&d.length>0?d.at(-1):i.prevData[u]);o.emit(e(a,i))},{describeKind:"derived",...t})}var Ae=z(()=>{"use strict";le()});function re(r){return r.subscribe(()=>{})}var rn=z(()=>{"use strict"});var Ke=z(()=>{"use strict";rn()});var qe,sn=z(()=>{"use strict";qe=class{_timer;_gen=0;start(e,t){this.cancel(),this._gen+=1;let n=this._gen;this._timer=setTimeout(()=>{this._timer=void 0,n===this._gen&&t()},e)}cancel(){this._timer!==void 0&&(clearTimeout(this._timer),this._timer=void 0)}get pending(){return this._timer!==void 0}}});var Se,on=z(()=>{"use strict";Se=class{constructor(e){this.capacity=e;if(!Number.isInteger(e)||e<=0)throw new Error(`RingBuffer capacity must be a positive integer (got ${e})`);this.buf=new Array(e)}buf;head=0;_size=0;get size(){return this._size}get maxSize(){return this.capacity}push(e){let t=(this.head+this._size)%this.capacity;this.buf[t]=e,this._size<this.capacity?this._size++:this.head=(this.head+1)%this.capacity}shift(){if(this._size===0)return;let e=this.buf[this.head];return this.buf[this.head]=void 0,this.head=(this.head+1)%this.capacity,this._size--,e}at(e){if(this._size===0)return;let t=e<0?this._size+e:e;if(!(t<0||t>=this._size))return this.buf[(this.head+t)%this.capacity]}toArray(){let e=new Array(this._size);for(let t=0;t<this._size;t++)e[t]=this.buf[(this.head+t)%this.capacity];return e}clear(){for(let e=0;e<this._size;e++)this.buf[(this.head+e)%this.capacity]=void 0;this.head=0,this._size=0}}});function Je(r,e,t){return{[r]:!0,[`${r}_type`]:e,...t??{}}}var xt=z(()=>{"use strict"});var dr={};kn(dr,{GuardedExecutionGraph:()=>Ze,guardedExecution:()=>ar});module.exports=En(dr);var L={object:56,array:64,string:40,number:8,boolean:4,null:0,undefined:0,symbol:40,bigint:16,function:120,map:72,set:72,mapEntry:40,setEntry:24,date:24,regexp:48,error:64,url:80,promise:48,weakmap:40,weakset:40},An=Symbol.for("sizeof");function Ct(r){let e=new WeakSet,t=new WeakSet,n=[r],s=0;for(;n.length>0;){let o=n.pop();s+=Sn(o,e,t,n)}return s}function Sn(r,e,t,n){if(r==null)return 0;switch(typeof r){case"number":return L.number;case"boolean":return L.boolean;case"string":return L.string+r.length*2;case"bigint":return L.bigint+Rn(r);case"symbol":return L.symbol;case"function":return e.has(r)?0:(e.add(r),L.function);case"undefined":return 0}let o=r;if(e.has(o))return 0;e.add(o);let i=o[An];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 L.date;if(o instanceof RegExp)return L.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 L.error+u+l}if(typeof URL<"u"&&o instanceof URL)return L.url+o.href.length*2;if(typeof Promise<"u"&&o instanceof Promise)return L.promise;if(o instanceof WeakMap)return L.weakmap;if(o instanceof WeakSet)return L.weakset;if(o instanceof Map){let u=L.map;for(let[l,g]of o)u+=L.mapEntry,n.push(l),n.push(g);return u}if(o instanceof Set){let u=L.set;for(let l of o)u+=L.setEntry,n.push(l);return u}if(Array.isArray(o)){let u=L.array+o.length*8;for(let l of o)n.push(l);return u}if(o instanceof ArrayBuffer)return t.has(o)?0:(t.add(o),o.byteLength);if(ArrayBuffer.isView(o)){let u=o;return t.has(u.buffer)?48:(t.add(u.buffer),u.buffer.byteLength+48)}let a=L.object,d=Object.keys(o);for(let u of d){a+=L.string+u.length*2;try{n.push(o[u])}catch{}}return a}function Rn(r){let e=r<0n?-r:r;if(e===0n)return 0;let t=e.toString(2).length;return Math.ceil(t/32)*8}function It(r,e,t,n={}){let s=e in r.nodes,o=t in r.nodes;if(!s)return Ge(e,t,"no-such-from");if(!o)return Ge(e,t,"no-such-to");let i=n.maxDepth;if(i!=null&&(!Number.isInteger(i)||i<0))throw new Error("explainPath: maxDepth must be an integer >= 0");if(e===t){if(n.findCycle===!0){let u=Cn(r,e,n);if(u!=null)return u}let d=Me(e,r.nodes[e],0,n);return Pe(e,t,[d])}if(i===0)return Ge(e,t,"no-path");let a=Lt(r,e,t,i);return a.found?Pe(e,t,Ft(r,a.pathOrder,n)):Ge(e,t,a.truncated?"max-depth-exceeded":"no-path")}function Lt(r,e,t,n){let s=new Map,o=[{path:t,depth:0}],i=new Set([t]),a=0,d=!1;for(;a<o.length;){let g=o[a++];if(g.path===e)break;if(n!=null&&g.depth>=n){let _=r.nodes[g.path];_?.deps&&_.deps.length>0&&(d=!0);continue}let f=r.nodes[g.path];if(f==null)continue;let h=f.deps??[],c=new Map;for(let _=0;_<h.length;_++){let p=h[_];if(!p)continue;let T=c.get(p);T==null&&(T=[],c.set(p,T)),T.push(_)}for(let[_,p]of c)i.has(_)||(i.add(_),s.set(_,{from:g.path,depIndices:p}),o.push({path:_,depth:g.depth+1}))}if(!s.has(e))return{found:!1,pathOrder:[],truncated:d};let u=[{path:e}],l=e;for(;l!==t;){let g=s.get(l);if(g==null)return{found:!1,pathOrder:[],truncated:!1};u[u.length-1].depIndices=g.depIndices,u.push({path:g.from}),l=g.from}return{found:!0,pathOrder:u,truncated:!1}}function Cn(r,e,t){let n=r.nodes[e];if(n==null)return null;let s=n.deps??[],o=[];for(let a=0;a<s.length;a++)s[a]===e&&o.push(a);if(o.length>0){let a=Me(e,n,0,t);a.dep_index=o[0];let d=Me(e,n,1,t);return Pe(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=Lt(r,d,e,t.maxDepth);u.found&&(i==null||u.pathOrder.length<i.pathOrder.length)&&(i=u,i={found:!0,pathOrder:[{path:e,depIndices:[a]},...u.pathOrder],truncated:!1})}return i==null?null:Pe(e,e,Ft(r,i.pathOrder,t))}function Ft(r,e,t){return e.map((n,s)=>{let o=r.nodes[n.path],i=Me(n.path,o,s,t);return n.depIndices!=null&&n.depIndices.length>0&&(i.dep_index=n.depIndices[0],n.depIndices.length>1&&(i.dep_indices=[...n.depIndices])),i})}function Me(r,e,t,n){let s={path:r,type:e.type,hop:t};e.status!==void 0&&(s.status=e.status),"value"in e&&(s.value=e.value),e.v!=null&&(s.v=e.v);let o=n.annotations?.get(r)??e.annotation;o!=null&&(s.annotation=o);let i=n.lastMutations?.get(r)??e.lastMutation;return i!=null&&(s.lastMutation=i),s}function Pe(r,e,t){return Vt(r,e,!0,"ok",t)}function Ge(r,e,t){return Vt(r,e,!1,t,[])}function Vt(r,e,t,n,s){let o=Gn(r,e,t,n,s);return{from:r,to:e,found:t,reason:n,steps:s,text:o,toJSON(){return{from:r,to:e,found:t,reason:n,steps:s}}}}function Gn(r,e,t,n,s){if(!t)switch(n){case"no-such-from":return`explainPath: no node named "${r}"`;case"no-such-to":return`explainPath: no node named "${e}"`;case"max-depth-exceeded":return`explainPath: no path from "${r}" to "${e}" within maxDepth`;default:return`explainPath: no path from "${r}" to "${e}"`}let o=[`Causal path: ${r} \u2192 ${e} (${s.length} step(s))`];for(let i of s){let d=` ${i.hop===0?"\xB7":"\u2193"} ${i.path} (${i.type}${i.status?`/${i.status}`:""})`;if(o.push(d),"value"in i&&o.push(` value: ${Mn(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 ln(r){if(r.version!==pe)throw new Error(`unsupported snapshot version ${String(r.version)} (expected ${pe})`);for(let e of["name","nodes","edges","subgraphs"])if(!(e in r))throw new Error(`snapshot missing required key "${e}"`);if(typeof r.name!="string")throw new TypeError("snapshot 'name' must be a string");if(typeof r.nodes!="object"||r.nodes===null||Array.isArray(r.nodes))throw new TypeError("snapshot 'nodes' must be an object");if(!Array.isArray(r.edges))throw new TypeError("snapshot 'edges' must be an array");if(!Array.isArray(r.subgraphs))throw new TypeError("snapshot 'subgraphs' must be an array")}function Yn(r,e){let t=new WeakMap,n=(s,o)=>{if(Object.is(s,o))return!0;if(s==null||o==null||typeof s!="object"||typeof o!="object")return!1;let i=t.get(s);if(i==null&&(i=new WeakSet,t.set(s,i)),i.has(o))return!0;i.add(o);let a=s.constructor,d=o.constructor;if(a!==d)return!1;if(s instanceof Date)return s.getTime()===o.getTime();if(s instanceof RegExp)return s.source===o.source&&s.flags===o.flags;if(Array.isArray(s)){let f=o;if(s.length!==f.length)return!1;for(let h=0;h<s.length;h++)if(!n(s[h],f[h]))return!1;return!0}if(s instanceof Map){let f=o;if(s.size!==f.size)return!1;for(let[h,c]of s)if(!f.has(h)||!n(c,f.get(h)))return!1;return!0}if(s instanceof Set){let f=o;if(s.size!==f.size)return!1;for(let h of s){let c=!1;for(let _ of f)if(n(h,_)){c=!0;break}if(!c)return!1}return!0}if(ArrayBuffer.isView(s)){let f=s,h=o;if(f.length!==h.length)return!1;for(let c=0;c<f.length;c++)if(f[c]!==h[c])return!1;return!0}let u=Object.keys(s),l=Object.keys(o);if(u.length!==l.length)return!1;let g=new Set(l);for(let f of u)if(!g.has(f)||!n(s[f],o[f]))return!1;return!0};return n(r,e)}function Jn(r){return r.replace(/[.*+?^${}()|[\]\\]/g,"\\$&")}function Ye(r){let e="^";for(let t=0;t<r.length;t+=1){let n=r[t];if(n==="*"){e+=".*";continue}if(n==="?"){e+=".";continue}if(n==="["){let s=r.indexOf("]",t+1);if(s<=t+1){e+="\\[";continue}let o=r.slice(t+1,s);o.startsWith("!")&&(o=`^${o.slice(1)}`),o=o.replace(/\\/g,"\\\\"),e+=`[${o}]`,t=s;continue}e+=Jn(n)}return e+="$",new RegExp(e)}var Xn={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"},Zn={data:"",dirty:"",resolved:"",invalidate:"",pause:"",resume:"",complete:"",error:"",teardown:"",derived:"",path:"",reset:""};function Tt(r){if(typeof r=="string")return JSON.stringify(r);if(typeof r=="number"||typeof r=="boolean"||r==null)return String(r);try{return JSON.stringify(r)}catch{return"[unserializable]"}}function Qn(r){return r==="none"?Zn:r==="ansi"||r==null?Xn:{data:r.data??"",dirty:r.dirty??"",resolved:r.resolved??"",invalidate:r.invalidate??"",pause:r.pause??"",resume:r.resume??"",complete:r.complete??"",error:r.error??"",teardown:r.teardown??"",derived:r.derived??"",path:r.path??"",reset:r.reset??""}}function pn(r){if(r==null)return{};let e=r.detail;return e==="full"?{...r,structured:r.structured??!0,timeline:r.timeline??!0,causal:r.causal??!0,derived:r.derived??!0}:e==="minimal"?{...r,structured:r.structured??!0}:r.format==="stage-log"?{...r,structured:r.structured??!0,timeline:r.timeline??!0}:r}function er(r,e,t){for(let n=0;n<r.length;n++){let s=r.charCodeAt(n);if(s<32||s===127)throw new Error(`Graph "${e}": ${t} "${r}" must not contain control character (U+${s.toString(16).padStart(4,"0").toUpperCase()} at index ${n})`)}}function Ot(r,e,t){if(r==="")throw new Error(`Graph "${e}": ${t} name must be non-empty`);if(r.includes(P))throw new Error(`Graph "${e}": ${t} "${r}" must not contain '${P}' (path separator)`);if(r===X)throw new Error(`Graph "${e}": ${t} name "${X}" is reserved for meta companion paths`);er(r,e,t)}function tr(r,e){if(r==="")throw new Error(`Graph "${e}": resolve path must be non-empty`);let t=r.split(P);for(let n of t)if(n==="")throw new Error(`Graph "${e}": resolve path has empty segment`);return t}function nr(r,e){let t=!1;for(let s of r)if(!e.isMetaPassthrough(s[0])){t=!0;break}return t?r.filter(s=>e.isMetaPassthrough(s[0])):r}function hn(r){for(let e of r._mounts.values())hn(e);for(let e of r._nodes.values())try{e.down([[F]],{internal:!0})}catch{}}var B=class r{name;opts;config;_nodes=new Map;_nodeToName=new WeakMap;_mounts=new Map;_parent=void 0;_storageDisposers=new Set;_disposers=new Set;_destroyed=!1;_topology;_topologyEmitters=new Set;_factory;_factoryArgs;constructor(e,t){if(e==="")throw new Error("Graph name must be non-empty");if(e.includes(P))throw new Error(`Graph name must not contain '${P}' (got "${e}")`);if(e===X)throw new Error(`Graph name "${X}" is reserved for meta companion paths`);this.name=e,this.opts=Object.freeze({...t??{}}),this.config=t?.config??we,this._traceRing=new Se(t?.traceCapacity??1e3),t?.versioning!=null&&this.setVersioning(t.versioning),typeof t?.factory=="string"&&(this._factory=t.factory,t.factoryArgs!==void 0&&(this._factoryArgs=t.factoryArgs))}tagFactory(e,t){return this._factory=e,this._factoryArgs=t,this}ancestors(e=!0){let t=[],n=e?this:this._parent;for(;n!=null;)t.push(n),n=n._parent;return t}get topology(){return this._topology==null&&(this._topology=We(e=>{let t=n=>{e.emit(n)};return this._topologyEmitters.add(t),()=>{this._topologyEmitters.delete(t)}},{name:`${this.name}_topology`})),this._topology}_emitTopology(e){if(!(this._topology==null||this._topologyEmitters.size===0))for(let t of this._topologyEmitters)t(e)}nameOf(e){return this._nodeToName.get(e)}add(e,t){let n=e.name,s=t?.name??n;if(s==null||s==="")throw new Error(`Graph "${this.name}": graph.add requires a non-empty name \u2014 pass via opts.name or set it on the node (e.g. state(0, { name: "x" }))`);let o=s,i=t?.annotation;if(Ot(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:Z()})),e}setVersioning(e){if(e!=null)for(let t of this._nodes.values())t instanceof I&&t._applyVersioning(e)}remove(e){Ot(e,this.name,"remove");let t=this._mounts.get(e);if(t){let o={kind:"mount",nodes:[],mounts:[]},i=[];t._collectObserveTargets("",i);for(let[a,d]of i)a.includes(`${P}${X}${P}`)||o.nodes.push(a);return o.nodes.sort(),o.mounts.push(e),o.mounts.push(...t._collectSubgraphs(`${e}${P}`)),this._mounts.delete(e),t._parent=void 0,hn(t),this._emitTopology({kind:"removed",name:e,nodeKind:"mount",audit:o}),o}let n=this._nodes.get(e);if(!n)throw new Error(`Graph "${this.name}": unknown node or mount "${e}"`);this._nodes.delete(e),this._nodeToName.delete(n),n.down([[F]],{internal:!0});let s={kind:"node",nodes:[e],mounts:[]};return this._emitTopology({kind:"removed",name:e,nodeKind:"node",audit:s}),s}removeAll(e){let t=typeof e=="function"?e:(()=>{let o=Ye(e);return i=>o.test(i)})(),n={kind:"mount",nodes:[],mounts:[]},s=[...this._nodes.keys(),...this._mounts.keys()].filter(o=>t(o));for(let o of s){let i=this.remove(o);n.nodes.push(...i.nodes),n.mounts.push(...i.mounts)}return n.nodes.sort(),n.mounts.sort(),n}[Symbol.iterator](){let e=[...this._nodes.keys()].sort(),t=this._nodes,n=0;return{[Symbol.iterator](){return this},next(){if(n>=e.length)return{value:void 0,done:!0};let s=e[n++];return{value:[s,t.get(s)],done:!1}}}}node(e){if(e==="")throw new Error(`Graph "${this.name}": node name must be non-empty`);if(e.includes(P))return this.resolve(e);let t=this._nodes.get(e);if(!t)throw new Error(`Graph "${this.name}": unknown node "${e}"`);return t}get(e){return this.node(e).cache}set(e,t,n){let s=n?.internal===!0;this.node(e).down([[C,t]],{actor:n?.actor,internal:s,delivery:"write"})}setAll(e,t){let n=Symbol.iterator in e?e:Object.entries(e);ue(()=>{for(let[s,o]of n)this.set(s,o,t)})}invalidate(e,t){let n=t?.internal===!0;this.node(e).down([[J]],{actor:t?.actor,internal:n,delivery:"write"})}error(e,t,n){let s=n?.internal===!0;this.node(e).down([[$,t]],{actor:n?.actor,internal:s,delivery:"write"})}complete(e,t){let n=t?.internal===!0;this.node(e).down([[V]],{actor:t?.actor,internal:n,delivery:"write"})}edges(e){let t=e?.recursive===!0,n=new Map;if(!t){for(let[d,u]of this._nodes)n.set(u,d);let a=[];for(let[d,u]of this._nodes)if(u instanceof I)for(let l of u._deps){let g=n.get(l.node);g!=null&&a.push([g,d])}return a.sort((d,u)=>d[0]<u[0]?-1:d[0]>u[0]?1:d[1]<u[1]?-1:d[1]>u[1]?1:0),a}let s=[];this._collectObserveTargets("",s);let o=new Map;for(let[a,d]of s)o.set(d,a);let i=[];for(let[a,d]of s)if(d instanceof I)for(let u of d._deps){let l=o.get(u.node);l!=null&&i.push([l,a])}return i.sort((a,d)=>a[0]<d[0]?-1:a[0]>d[0]?1:a[1]<d[1]?-1:a[1]>d[1]?1:0),i}mount(e,t){if(t===void 0){let s=new r(e);return this.mount(e,s)}if(typeof t=="function"){let s=new r(e);return t(s),this.mount(e,s)}let n=t;if(Ot(e,this.name,"mount"),this._nodes.has(e))throw new Error(`Graph "${this.name}": cannot mount at "${e}" \u2014 node with that name exists`);if(this._mounts.has(e))throw new Error(`Graph "${this.name}": mount "${e}" already exists`);if(n===this)throw new Error(`Graph "${this.name}": cannot mount a graph into itself`);if(n._parent!=null)throw new Error(`Graph "${this.name}": this child graph is already mounted on "${n._parent.name}"`);for(let s=this;s!=null;s=s._parent)if(s===n)throw new Error(`Graph "${this.name}": mount("${e}", \u2026) would create a mount cycle`);return this._mounts.set(e,n),n._parent=this,this._emitTopology({kind:"added",name:e,nodeKind:"mount"}),n}resolve(e){let t=tr(e,this.name);return this._resolveFromSegments(t)}tryResolve(e){try{return this.resolve(e)}catch{return}}_resolveFromSegments(e){let t=e;if(t[0]===this.name&&(t=t.slice(1),t.length===0))throw new Error(`Graph "${this.name}": resolve path ends at graph name only`);let n=t[0],s=t.slice(1);if(s.length===0){let a=this._nodes.get(n);if(a)return a;throw this._mounts.has(n)?new Error(`Graph "${this.name}": path ends at subgraph "${n}" \u2014 not a node (GRAPHREFLY-SPEC \xA73.5)`):new Error(`Graph "${this.name}": unknown name "${n}"`)}let o=this._nodes.get(n);if(o&&s.length>0&&s[0]===X)return this._resolveMetaChainFromNode(o,s,t.join(P));let i=this._mounts.get(n);if(!i)throw this._nodes.has(n)?new Error(`Graph "${this.name}": "${n}" is a node; trailing path "${s.join(P)}" is invalid`):new Error(`Graph "${this.name}": unknown mount or node "${n}"`);return i.resolve(s.join(P))}_resolveMetaChainFromNode(e,t,n){let s=e,o=0,i=[...t];for(;o<i.length;){if(i[o]!==X)throw new Error(`Graph "${this.name}": expected ${X} segment in meta path "${n}"`);if(o+1>=i.length)throw new Error(`Graph "${this.name}": meta path requires a key after ${X} in "${n}"`);let a=i[o+1],d=s.meta[a];if(!d)throw new Error(`Graph "${this.name}": unknown meta "${a}" in path "${n}"`);s=d,o+=2}return s}signal(e,t){if(t?.internal!==!0){for(let s of e)if(this.config.messageTier(s[0])===3)throw new Error(`Graph "${this.name}": Graph.signal() rejects tier-3 messages (DATA / RESOLVED). Broadcast is for control-plane tiers (START / DIRTY / INVALIDATE / PAUSE / RESUME / COMPLETE / ERROR / TEARDOWN). For per-node value writes, use Graph.set or graph.node(name).down(...).`)}let n=[];if(this._signalDeliver(e,t??{},new Set,n),n.length>0)throw n[0]}_signalDeliver(e,t,n,s){for(let d of this._mounts.values())d._signalDeliver(e,t,n,s);let i=t.internal===!0?{internal:!0}:{actor:t.actor,delivery:"signal"},a=nr(e,this.config);for(let d of[...this._nodes.keys()].sort()){let u=this._nodes.get(d);if(!n.has(u)){n.add(u);try{u.down(e,i)}catch(l){if(l instanceof Y)throw l;s.push(l)}a.length!==0&&this._signalMetaSubtree(u,a,n,i,s)}}}_signalMetaSubtree(e,t,n,s,o){for(let i of Object.keys(e.meta).sort()){let a=e.meta[i];if(!n.has(a)){n.add(a);try{a.down(t,s)}catch(d){if(d instanceof Y)throw d;o.push(d)}this._signalMetaSubtree(a,t,n,s,o)}}}describe(e){if(e?.reactive==="diff")return this._describeReactiveDiff(e);if(e?.reactive===!0)return this._describeReactive(e);let t=Kn(e?.actor),n=e?.filter;if(e?.detail!=null&&e?.fields!=null)throw new TypeError("Graph.describe(): pass either `detail` or `fields`, not both. `detail: 'spec'` is the canonical spec projection; use `fields` only when you need a custom subset.");let s=bt(e?.detail,e?.fields),o=e?.detail==="spec",i=s,a=[];this._collectObserveTargets("",a);let d=new Map;for(let[y,w]of a)d.set(w,y);let u=[];{let y=a.map(([,m])=>m),w=new Set(d.values()),k=0;for(;y.length>0;){let m=y.shift();if(m instanceof I)for(let O of m._deps){let x=O.node;if(d.has(x))continue;let A=x.name??"",N=A;if(!N||w.has(N))if(A){let S=2;for(;w.has(`${A}#${S}`);)S++;N=`${A}#${S}`}else for(N=`__internal__/${k++}`;w.has(N);)N=`__internal__/${k++}`;d.set(x,N),w.add(N),u.push([N,x]),y.push(x)}}}let l=[...a,...u],g={};for(let[y,w]of l){if(t!=null&&!w.allowsObserve(t))continue;let k=yt(w,i,o),m=w instanceof I?w._deps.map(N=>d.get(N.node)??N.node.name??""):[],{name:O,...x}=k,A={...x,deps:m};if(!o){let N=this._annotations.get(y);N!=null&&(A.annotation=N)}if(n!=null)if(typeof n=="function"){let N=n;if(!(N.length>=2?N(y,A):N(A)))continue}else{let N=!0;for(let[S,D]of Object.entries(n)){let R=S==="deps_includes"?"depsIncludes":S==="meta_has"?"metaHas":S;if(R==="depsIncludes"){if(!A.deps.includes(String(D))){N=!1;break}continue}if(R==="metaHas"){if(!Object.hasOwn(A.meta??{},String(D))){N=!1;break}continue}if(A[R]!==D){N=!1;break}}if(!N)continue}g[y]=A}let f=new Set(Object.keys(g)),h=[];for(let[y,w]of l)if(w instanceof I)for(let k of w._deps){let m=d.get(k.node);m!=null&&h.push([m,y])}h.sort((y,w)=>y[0]<w[0]?-1:y[0]>w[0]?1:y[1]<w[1]?-1:y[1]>w[1]?1:0);let c=h.map(([y,w])=>({from:y,to:w}));(t!=null||n!=null)&&(c=c.filter(y=>f.has(y.from)&&f.has(y.to)));let _=this._collectSubgraphs(""),p=t!=null||n!=null?_.filter(y=>{let w=`${y}${P}`;return[...f].some(k=>k===y||k.startsWith(w))}):_,T=this,v=e;return{name:this.name,nodes:g,edges:c,subgraphs:p,...this._factory!==void 0?{factory:this._factory}:{},...this._factoryArgs!==void 0?{factoryArgs:this._factoryArgs}:{},expand(y){let w={...v};return Array.isArray(y)?(w.fields=y,w.detail=void 0):(w.detail=y,w.fields=void 0),T.describe(w)}}}_collectSubgraphs(e){let t=[];for(let n of[...this._mounts.keys()].sort()){let s=e===""?n:`${e}${n}`;t.push(s),t.push(...this._mounts.get(n)._collectSubgraphs(`${s}${P}`))}return t}resourceProfile(e){return an(this,e)}reachable(e,t,n={}){return n.withDetail===!0?Nt(this.describe(),e,t,{...n,withDetail:!0}):Nt(this.describe(),e,t,n)}explain(e,t,n){return n?.reactive===!0?this._explainReactive(e,t,n):this._explainStatic(ie(e),ie(t),{...n?.maxDepth!==void 0?{maxDepth:un(n.maxDepth)}:{},...n?.findCycle!==void 0?{findCycle:cn(n.findCycle)}:{}})}_explainStatic(e,t,n){let s=this.describe({detail:"full"}),o=new Map(this._annotations),i=new Map;for(let[a,d]of Object.entries(s.nodes))d.lastMutation!=null&&i.set(a,d.lastMutation);return It(s,e,t,{...n?.maxDepth!=null?{maxDepth:n.maxDepth}:{},...n?.findCycle===!0?{findCycle:!0}:{},annotations:o,lastMutations:i})}_describeReactive(e){let t={...e,reactive:!1},n=e.reactiveName??"describe",s=0,o=ee(s,{name:`${n}_version`}),i=this.observe({timeline:!0,structured:!0}),a=!1,d=!1,u=()=>{a||d||(a=!0,be(()=>{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()}),g=[],f=new WeakSet,h=v=>{if(f.has(v)||d)return;f.add(v);let b=v.topology.subscribe(y=>{for(let w of y){if(w[0]!==C)continue;let k=w[1];if(u(),k.kind==="added"&&k.nodeKind==="mount"){let m=v._mounts.get(k.name);m!=null&&h(m)}}});g.push(b);for(let y of v._mounts.keys()){let w=v._mounts.get(y);w!=null&&h(w)}};h(this);let c,_=e.actor;fn(_)&&(c=_.subscribe(v=>{let b=!1,y=!1;for(let w of v){let k=w[0];k===C?b=!0:(k===V||k===$||k===F)&&(y=!0)}b&&u(),y&&(c?.(),c=void 0,u())}));let p;try{p=H([o],()=>this.describe(t),{name:n,describeKind:"derived",meta:{domain:"audit",kind:"describe"},equals:(v,b)=>v===b})}catch(v){l(),c?.();for(let b of g)b();throw i.dispose(),v}let T=re(p);return{node:p,dispose(){d=!0,l(),c?.();for(let v of g)v();g.length=0,i.dispose(),T()}}}_describeReactiveDiff(e){let t={...e,reactive:!1},n=e.reactiveName??"describe-diff",s={name:this.name,nodes:{},edges:[],subgraphs:[]},o=this.describe(t),i=wt(s,o),a=ee(i,{name:n,meta:{domain:"audit",kind:"describe-diff"},equals:(f,h)=>f===h}),d=this._describeReactive({...e,reactiveName:void 0}),u=!1,l=d.node.subscribe(f=>{if(!u)for(let h of f){if(h[0]!==C)continue;let c=h[1],_=wt(o,c);o=c,_.events.length!==0&&a.emit(_)}}),g=re(a);return{node:a,dispose(){u=!0,l(),d.dispose(),a.down([[F,"describe-diff disposed"]]),g()}}}_explainReactive(e,t,n){let s=0,o=ee(s,{name:"explain_version"}),i=this.observe({timeline:!0,structured:!0}),a=!1,d=!1,u=()=>{a||d||(a=!0,be(()=>{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()}),g=[];e!=null&&fe(e)&&g.push(e),t!=null&&fe(t)&&g.push(t),n?.maxDepth!=null&&fe(n.maxDepth)&&g.push(n.maxDepth),n?.findCycle!=null&&fe(n.findCycle)&&g.push(n.findCycle);let f=()=>{for(let v of g)if(v.cache===void 0)return!1;return!0},h=()=>{let v=ie(e),b=ie(t);return{from:v,to:b,found:!1,reason:"pending",steps:[],text:"(awaiting reactive args)",toJSON:()=>({from:v,to:b,found:!1,reason:"pending",steps:[]})}},c;try{c=H([o],()=>{if(!f())return h();let v=ie(e),b=ie(t),y={...n?.maxDepth!==void 0?{maxDepth:un(n.maxDepth)}:{},...n?.findCycle!==void 0?{findCycle:cn(n.findCycle)}:{}};return this._explainStatic(v,b,y)},{name:n?.name??"explain",describeKind:"derived",meta:{domain:"audit",kind:"explain_path",from:ie(e),to:ie(t)},equals:(v,b)=>v.found===b.found&&v.reason===b.reason&&v.steps.length===b.steps.length&&rr(v.steps,b.steps)})}catch(v){throw l(),i.dispose(),v}let _=re(c),p=[],T=v=>{let b;return b=v.subscribe(y=>{let w=!1,k=!1;for(let m of y){let O=m[0];O===C?w=!0:(O===V||O===$||O===F)&&(k=!0)}(w||k)&&u(),k&&b&&(b(),b=void 0)}),()=>{b&&(b(),b=void 0)}};for(let v of g)p.push(T(v));return{node:c,dispose(){d=!0,l();for(let v of p)v?.();p.length=0,i.dispose(),_()}}}_pathsMatching(e){let t=Ye(e),n=[];return this._collectObserveTargets("",n),n.map(([s])=>s).filter(s=>t.test(s))}_collectObserveTargets(e,t){for(let n of[...this._mounts.keys()].sort()){let s=e===""?n:`${e}${P}${n}`;this._mounts.get(n)._collectObserveTargets(s,t)}for(let n of[...this._nodes.keys()].sort()){let s=this._nodes.get(n),o=e===""?n:`${e}${P}${n}`;t.push([o,s]),this._appendMetaObserveTargets(o,s,t)}}_appendMetaObserveTargets(e,t,n){for(let s of Object.keys(t.meta).sort()){let o=t.meta[s],i=`${e}${P}${X}${P}${s}`;n.push([i,o]),this._appendMetaObserveTargets(i,o,n)}}observe(e,t){let n=typeof e=="string",o=pn(n?t:e);if(o.reactive===!0)return this._observeReactive(n?e:void 0,o);let i=o.structured===!0||o.timeline===!0||o.causal===!0||o.derived===!0||o.detail==="minimal"||o.detail==="full"||o.format!=null,a=o.actor;if(n){let l=e,g=this.resolve(l);if(a!=null&&!g.allowsObserve(a))throw new Y({actor:a,action:"observe",nodeName:l});return i?this._buildStructuredObserver([[l,g]],o,"one"):{subscribe(f){return g.subscribe(f)},up(f){try{g.up?.(f)}catch(h){if(h instanceof Y)return;throw h}}}}let d=[];this._collectObserveTargets("",d),d.sort((l,g)=>l[0]<g[0]?-1:l[0]>g[0]?1:0);let u=a==null?d:d.filter(([,l])=>l.allowsObserve(a));return i?this._buildStructuredObserver(u,o,"all"):{subscribe:l=>{let g=u.map(([f,h])=>h.subscribe(c=>{l(f,c)}));return()=>{for(let f of g)f()}},up:(l,g)=>{try{this.resolve(l).up?.(g)}catch(f){if(f instanceof Y)return;throw f}}}}_observeReactive(e,t){let n=t.tiers,s=n!=null?new Set(n):null,o=t.reactiveName??"observe";return We(i=>{let a=[],d=!1,u=!1,l=()=>{if(a.length===0||u)return;let _={events:a.slice(),flushedAt_ns:Z()};a.length=0,i.emit(_)},g={...t,reactive:!1,structured:!0,timeline:!0},f=e!=null?this.observe(e,g):this.observe(g),h=_=>{u||(a.push(_),!d&&(d=!0,be(()=>{d=!1,l()})))};for(let _ of f.events)h(_);let c=f.onEvent(h);return()=>{u=!0,c(),f.dispose()}},{name:o,meta:{domain:"audit",kind:"observe-reactive"}})}_buildStructuredObserver(e,t,n){let s=n==="one"?e[0]?.[0]:void 0,o=i=>{if(n==="one"&&s!=null){let l=this.resolve(s);return this._buildStructuredObserver([[s,l]],i,"one")}let a=[];this._collectObserveTargets("",a),a.sort((l,g)=>l[0]<g[0]?-1:l[0]>g[0]?1:0);let d=i.actor,u=d==null?a:a.filter(([,l])=>l.allowsObserve(d));return this._buildStructuredObserver(u,i,"all")};return this._createObserveResult(e,t,o)}_createObserveResult(e,t,n){let s=t.timeline===!0,o=t.causal===!0,i=t.derived===!0,a=t.detail==="minimal",d=this.config.inspectorEnabled,u=(o||i)&&d,l=t.maxEvents,g=l!=null&&l>0?new Se(l):null,f=[],h=new Set,c=t.tiers!=null?new Set(t.tiers):null,_={},p=new Set,T=0,v=0,b=0,y=0,w=0,k=0,m=!1,O=!1,x=0,A=new Map,N=new Map,S=new Map,D=E=>{if(!(c!=null&&!c.has(E.type))){g?g.push(E):f.push(E);for(let M of h)M(E)}},R=E=>c==null||c.has(E),se=()=>s?{timestamp_ns:Z(),in_batch:Le(),batch_id:x}:{},te=(E,M)=>{if(!(!u||!(E instanceof I)))return E._setInspectorHook(K=>{if(K.kind==="dep_message")A.set(E,K.depIndex);else if(K.kind==="run"){let Oe=K.batchData.map((G,j)=>G!=null&&G.length>0?G.at(-1):K.prevData[j]);N.set(E,Oe);let q=K.batchData.map(G=>G!=null?[...G]:void 0);S.set(E,q),i&&D({type:"derived",path:M,dep_values:Oe,dep_batches:q,...se()})}})},De=E=>{let M=A.get(E),K=N.get(E);if(!o||K==null)return{};let q=(M!=null&&M>=0&&E instanceof I?E._deps[M]:void 0)?.node,G=q?.v,j=S.get(E);return{trigger_dep_index:M,trigger_dep_name:q?.name,...G!=null?{trigger_version:{id:G.id,version:G.version}}:{},dep_values:[...K],...j!=null?{dep_batches:j}:{}}},St=[],Rt=[];for(let[E,M]of e){let K=te(M,E);K&&St.push(K),Rt.push(M.subscribe(Oe=>{x++;for(let q of Oe){let G=q[0],j=se();if(G===C){_[E]=q[1];let nt=M instanceof I?M.lastMutation?.actor??he:he;D({type:"data",path:E,data:q[1],actor:nt,...j,...De(M)})}else if(a)G===U?R("dirty")&&T++:G===W?R("resolved")&&v++:G===J?R("invalidate")&&b++:G===Q?R("pause")&&y++:G===ne?R("resume")&&w++:G===F?R("teardown")&&k++:G===V&&!p.has(E)?R("complete")&&(m=!0):G===$&&R("error")&&(O=!0,p.add(E));else if(G===U)R("dirty")&&T++,D({type:"dirty",path:E,...j});else if(G===W)R("resolved")&&v++,D({type:"resolved",path:E,...j,...De(M)});else if(G===J)R("invalidate")&&b++,D({type:"invalidate",path:E,...j});else if(G===Q)R("pause")&&y++,D({type:"pause",path:E,lockId:q[1],...j});else if(G===ne)R("resume")&&w++,D({type:"resume",path:E,lockId:q[1],...j});else if(G===V)R("complete")&&!p.has(E)&&(m=!0),D({type:"complete",path:E,...j});else if(G===$){R("error")&&(O=!0,p.add(E));let nt=M instanceof I?M.lastMutation?.actor??he:he;D({type:"error",path:E,data:q[1],actor:nt,...j})}else G===F&&(R("teardown")&&k++,D({type:"teardown",path:E,...j}))}}))}let Qe=!1,et=()=>{if(!Qe){Qe=!0;for(let E of Rt)E();for(let E of St)E();for(let E of Ce)E({value:void 0,done:!0});Ce.length=0}},tt=[],Ce=[];h.add(E=>{let M=Ce.shift();M?M({value:E,done:!1}):tt.push(E)});let Dt={get values(){return _},get dirtyCount(){return T},get resolvedCount(){return v},get invalidateCount(){return b},get pauseCount(){return y},get resumeCount(){return w},get teardownCount(){return k},get events(){return g?g.toArray():[...f]},get anyCompletedCleanly(){return m},get anyErrored(){return O},get completedWithoutErrors(){return m&&!O},onEvent(E){return h.add(E),()=>h.delete(E)},dispose:et,expand(E){et();let M={...t};return typeof E=="string"?M.detail=E:Object.assign(M,E),n(pn(M))},[Symbol.asyncIterator](){return{next(){return tt.length>0?Promise.resolve({value:tt.shift(),done:!1}):Qe?Promise.resolve({value:void 0,done:!0}):new Promise(E=>Ce.push(E))},return(){return et(),Promise.resolve({value:void 0,done:!0})}}}};return t.format!=null&&this._attachFormatLogger(Dt,t),Dt}_attachFormatLogger(e,t){let n=t.format;if(n==null)return;let s=t.logger??(c=>console.log(c)),o=t.includeTypes?new Set(t.includeTypes):null,i=t.excludeTypes?new Set(t.excludeTypes):null,a=o==null&&i==null?()=>!0:c=>(o==null||o.has(c))&&(i==null||!i.has(c)),d=Qn(t.theme),u=n==="stage-log"?Z():0,l=c=>c==null?"":t.stageLabels?.[c]??c,g=(c,_)=>c.length>_?`${c.slice(0,_-1)}\u2026`:c,f=c=>c.type==="data"||c.type==="error"?g(Tt(c.data),120):"",h=c=>{if(n==="stage-log"){let m=(Z()-u)/1e9,O=l(c.path).padEnd(9);if(c.type==="data"){let x=f(c);return`[${m.toFixed(3)}s] ${O} \u2190${x?` ${x}`:""}`}if(c.type==="error"){let x=f(c);return`[${m.toFixed(3)}s] ${O} \u2717${x?` ${x}`:""}`}return c.type==="complete"?`[${m.toFixed(3)}s] ${O} \u25A0 complete`:`[${m.toFixed(3)}s] ${O} ${c.type}`}if(n==="json")try{return JSON.stringify(c)}catch{return JSON.stringify({type:c.type,path:c.path,data:"[unserializable]"})}let _=d[c.type]??"",p=c.path?`${d.path}${c.path}${d.reset} `:"",T=c.type==="data"||c.type==="error",v=c.type==="pause"||c.type==="resume",b=T?` ${Tt(c.data)}`:v?` ${Tt(c.lockId)}`:"",y=c.type==="data"||c.type==="resolved"||c.type==="derived"?c:void 0,w=y?.trigger_dep_name!=null?` <- ${y.trigger_dep_name}`:y?.trigger_dep_index!=null?` <- #${y.trigger_dep_index}`:"",k=c.in_batch?" [batch]":"";return`${p}${_}${c.type.toUpperCase()}${d.reset}${b}${w}${k}`};e.onEvent(c=>{a(c.type)&&s(h(c),c)})}addDisposer(e){return this._disposers.add(e),()=>{this._disposers.delete(e)}}destroy(){dn(this._disposers,this.name),this.signal([[F]],{internal:!0}),dn(this._storageDisposers,this.name);for(let e of[...this._mounts.values()])e._parent=void 0,e._destroyClearOnly();this._mounts.clear(),this._nodes.clear(),this._parent=void 0,this._destroyed=!0}get destroyed(){return this._destroyed}_destroyClearOnly(){for(let e of[...this._mounts.values()])e._parent=void 0,e._destroyClearOnly();this._mounts.clear(),this._nodes.clear(),this._parent=void 0,this._destroyed=!0}snapshot(e){let{expand:t,...n}=this.describe({detail:"full"}),s={};for(let a of Object.keys(n.nodes).sort()){let{lastMutation:d,guard:u,...l}=n.nodes[a];s[a]=l}let o=[...n.subgraphs].sort(),i={...n,version:1,nodes:s,subgraphs:o};if(e?.format==null)return i;if(e.format==="json-string")return JSON.stringify(i);if(e.format==="bytes"){if(e.codec==null)throw new Error("snapshot({format: 'bytes'}) requires a `codec` name");let a=this.config.lookupCodec(e.codec);if(a==null)throw new Error(`snapshot: codec "${e.codec}" is not registered on this graph's config. Call config.registerCodec(...) before creating nodes.`);return Mt(a,a.encode(i))}throw new Error(`snapshot: unknown format "${String(e.format)}"`)}static decode(e,t){let n=t?.config??we,{codec:s,codecVersion:o,payload:i}=Pt(e,n);return s.decode(i,o)}restore(e,t){if(ln(e),e.name!==this.name)throw new Error(`Graph "${this.name}": restore snapshot name "${e.name}" does not match this graph`);let n=t?.only==null?null:(Array.isArray(t.only)?t.only:[t.only]).map(o=>Ye(o)),s=t?.includeProducers===!0;for(let o of Object.keys(e.nodes).sort()){if(n!==null&&!n.some(a=>a.test(o)))continue;let i=e.nodes[o];if(i!==void 0){if(!("value"in i)||i.value===void 0){"value"in i&&i.value===void 0&&t?.onError?.(o,new Error(`restore: slice.value is undefined for "${o}" (undefined is the global SENTINEL; not valid DATA)`));continue}if(!(i.type==="derived"||i.type==="effect")&&!(i.type==="producer"&&!s)){if(i.v!=null){let d=this.tryResolve(o)?.v;if(d!=null&&d.id===i.v.id&&d.version===i.v.version)continue}try{this.set(o,i.value)}catch(a){t?.onError?.(o,a)}}}}}static fromSnapshot(e,t){ln(e);let n=typeof t=="function"?t:t?.build,s=typeof t=="function"?void 0:t?.factories,o=new r(e.name);if(n)return n(o),o.restore(e),o;for(let h of[...e.subgraphs].sort((c,_)=>{let p=c.split(P).length,T=_.split(P).length;return p!==T?p-T:c<_?-1:c>_?1:0})){let c=h.split(P),_=o;for(let p of c)_._mounts.has(p)||_.mount(p,new r(p)),_=_._mounts.get(p)}let i=s?Object.entries(s).map(([h,c])=>({re:Ye(h),factory:c})):[],a=h=>{for(let c of i)if(c.re.test(h))return c.factory},d=h=>{let c=h.split(P),_=c.pop();if(_==null||_.length===0)throw new Error(`invalid snapshot path "${h}"`);let p=o;for(let T of c){let v=p._mounts.get(T);if(!v)throw new Error(`unknown mount "${T}" in path "${h}"`);p=v}return[p,_]},u=Object.entries(e.nodes).filter(([h])=>!h.includes(`${P}${X}${P}`)).sort((h,c)=>h[0]<c[0]?-1:h[0]>c[0]?1:0),l=new Map(u),g=new Map,f=!0;for(;l.size>0&&f;){f=!1;for(let[h,c]of[...l.entries()]){let _=c?.deps??[];if(!_.every(w=>g.has(w)))continue;let[p,T]=d(h),v={...c?.meta??{}},b=a(h),y;if(c?.type==="state")y=ee(c.value,{meta:v});else{if(b==null)continue;y=b(T,{path:h,type:c.type,value:c.value,meta:v,deps:_,resolvedDeps:_.map(w=>g.get(w))})}p.add(y,{name:T}),g.set(h,y),l.delete(h),f=!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,t={}){let n=e.map(u=>({tier:u,debounceMs:Math.max(0,u.debounceMs??0),compactEvery:Math.max(1,u.compactEvery??10),timer:void 0,seq:0,lastSnapshot:void 0,lastFingerprint:"",disposed:!1,savePending:void 0}));t.autoRestore===!0&&this._cascadeRestore(e,t.onError);let s=(u,l)=>{if(u.disposed)return;let g=qn(l.nodes);if(u.lastSnapshot!=null&&g!==""&&g===u.lastFingerprint)return;let f=u.seq+1,h=ye(),p=u.lastSnapshot==null||f%u.compactEvery===0?{name:this.name,mode:"full",snapshot:l,seq:f,timestamp_ns:h,format_version:pe}:{name:this.name,mode:"diff",diff:gn(u.lastSnapshot,l),seq:f,timestamp_ns:h,format_version:pe};if(u.tier.filter&&!u.tier.filter(p))return;let T;try{T=u.tier.save(p)}catch(v){t.onError?.(v,u.tier);return}if(T&&typeof T.then=="function"){let y=(u.savePending??Promise.resolve()).then(()=>T,()=>T).then(()=>{u.disposed||(u.seq=f,u.lastSnapshot=l,u.lastFingerprint=g)},w=>{t.onError?.(w,u.tier)});u.savePending=y.finally(()=>{u.savePending===y&&(u.savePending=void 0)})}else u.seq=f,u.lastSnapshot=l,u.lastFingerprint=g},o=(u,l)=>{try{s(u,l)}catch(g){t.onError?.(g,u.tier)}},i=(u,l)=>{if(!l.some(c=>{let _=this.config.messageTier(c[0]);return _>=3&&_<5}))return;if(t.filter){let c=this.tryResolve(u);if(c==null)return;let _=yt(c,bt("standard"));if(!t.filter(u,_))return}let f,h=()=>(f==null&&(f=this.snapshot()),f);for(let c of n)c.disposed||(c.debounceMs===0?o(c,h()):(c.timer==null&&(c.timer=new qe),c.timer.start(c.debounceMs,()=>{c.disposed||o(c,this.snapshot())})))},a;if(t.paths!=null){let l=(typeof t.paths=="string"?this._pathsMatching(t.paths):t.paths).map(g=>{let f=this.tryResolve(g);return f==null?()=>{}:f.subscribe(h=>i(g,h))});a=()=>{for(let g of l)g()}}else a=this.observe().subscribe((u,l)=>i(u,l));let d=()=>{a();for(let u of n)u.disposed=!0,u.timer?.cancel();this._storageDisposers.delete(d)};return this._storageDisposers.add(d),{dispose:d}}async _cascadeRestore(e,t){for(let n of e){let s;try{s=await n.load?.()}catch(i){t?.(i,n);continue}if(s==null||typeof s!="object"||Array.isArray(s))continue;let o=s;try{if(o.mode==="full"&&o.snapshot!=null)return this.restore(o.snapshot),!0;if(o.version===pe&&o.nodes!=null)return this.restore(o),!0}catch(i){t?.(i,n)}}return!1}static async fromStorage(e,t,n){for(let s of t){let o;try{o=await s.load?.()}catch(d){n?.onError?.(d,s);continue}if(o==null||typeof o!="object"||Array.isArray(o))continue;let i=o,a=i.mode==="full"&&i.snapshot!=null?i.snapshot:i.version===pe&&i.nodes!=null?i:void 0;if(a!=null)try{return r.fromSnapshot(a,n)}catch(d){n?.onError?.(d,s)}}throw new Error(`Graph.fromStorage: no tier held a restorable record for "${e}" across ${t.length} tier(s)`)}_annotations=new Map;_traceRing;trace(e,t,n){if(e!=null&&t!=null){if(this.tryResolve(e)==null)return;if(this._annotations.set(e,t),this.config.inspectorEnabled){let s={path:e,annotation:t,timestamp_ns:Z(),...n?.actor!=null?{actor:n.actor}:{}};this._traceRing.push(s)}return}return e!=null?this.config.inspectorEnabled?this._annotations.get(e):void 0:this.config.inspectorEnabled?this._traceRing.toArray():[]}annotation(e){return this._annotations.get(e)}clearTrace(){this._annotations.clear(),this._traceRing.clear()}pruneTrace(e){let t=this._traceRing.toArray().filter(s=>!e(s)),n=this._traceRing.size-t.length;this._traceRing.clear();for(let s of t)this._traceRing.push(s);return n}static diff(e,t){let n=new Set(Object.keys(e.nodes)),s=new Set(Object.keys(t.nodes)),o=[...s].filter(v=>!n.has(v)).sort(),i=[...n].filter(v=>!s.has(v)).sort(),a=[],d=[];for(let v of n){if(!s.has(v))continue;let b=e.nodes[v],y=t.nodes[v],w=b.v,k=y.v;w!=null&&k!=null&&w.id===k.id&&w.version!==k.version&&d.push({path:v,id:w.id,from:w.version,to:k.version});let m=w!=null&&k!=null&&w.id===k.id&&w.version===k.version;for(let O of["type","status","sentinel"]){let x=b[O],A=y[O];x!==A&&a.push({path:v,field:O,from:x,to:A})}if(!m)for(let O of["value","meta"]){let x=b[O],A=y[O];Yn(x,A)||a.push({path:v,field:O,from:x,to:A})}}let u=v=>`${v.from} ${v.to}`,l=new Set(e.edges.map(u)),g=new Set(t.edges.map(u)),f=t.edges.filter(v=>!l.has(u(v))),h=e.edges.filter(v=>!g.has(u(v))),c=new Set(e.subgraphs),_=new Set(t.subgraphs),p=[..._].filter(v=>!c.has(v)).sort(),T=[...c].filter(v=>!_.has(v)).sort();return{nodesAdded:o,nodesRemoved:i,nodesChanged:a,versionChanges:d,edgesAdded:f,edgesRemoved:h,subgraphsAdded:p,subgraphsRemoved:T}}};function gn(r,e){let t=B.diff(r,e),n={};for(let s of t.nodesAdded){let o=e.nodes[s];o!=null&&(n[s]=o)}return{...t,nodesAddedFull:n}}function Nt(r,e,t,n={}){let s={paths:[],depths:new Map,truncated:!1};if(!e)return n.withDetail?s:[];if(!n.both&&t!=="upstream"&&t!=="downstream")throw new Error('reachable: direction must be "upstream" or "downstream"');let o=n.maxDepth;if(o!=null&&(!Number.isInteger(o)||o<0))throw new Error("reachable: maxDepth must be an integer >= 0");if(o===0)return n.withDetail?s:[];let i=new Map,a=new Map,d=new Map,u=new Map,l=new Set;for(let[b,y]of Object.entries(r.nodes)){if(!b)continue;l.add(b);let w=y.deps??[];i.set(b,w);for(let k of w)k&&(l.add(k),a.has(k)||a.set(k,new Set),a.get(k).add(b))}for(let b of r.edges){if(b==null||typeof b!="object")continue;let y=typeof b.from=="string"?b.from:"",w=typeof b.to=="string"?b.to:"";!y||!w||(l.add(y),l.add(w),u.has(y)||u.set(y,new Set),u.get(y).add(w),d.has(w)||d.set(w,new Set),d.get(w).add(y))}if(!l.has(e))return n.withDetail?s:[];let g=n.both===!0,f=b=>{if(g){let m=i.get(b)??[],O=d.get(b),x=a.get(b),A=u.get(b),N=[...m];return O&&N.push(...O),x&&N.push(...x),A&&N.push(...A),N}if(t==="upstream"){let m=i.get(b)??[],O=d.get(b);return O?[...m,...O]:m}let y=a.get(b),w=u.get(b),k=y?[...y]:[];return w&&k.push(...w),k},h=new Set([e]),c=new Map,_=[{path:e,depth:0}],p=0,T=!1;for(;p<_.length;){let b=_[p++];if(o!=null&&b.depth>=o){f(b.path).length>0&&(T=!0);continue}for(let y of f(b.path))!y||h.has(y)||(h.add(y),c.set(y,b.depth+1),_.push({path:y,depth:b.depth+1}))}let v=[...c.keys()].sort((b,y)=>b<y?-1:b>y?1:0);return n.withDetail?{paths:v,depths:c,truncated:T}:v}function rr(r,e){if(r.length!==e.length)return!1;for(let t=0;t<r.length;t++){let n=r[t],s=e[t];if(n.path!==s.path||n.type!==s.type||n.status!==s.status||n.hop!==s.hop||n.dep_index!==s.dep_index||n.annotation!==s.annotation||n.value!==s.value||n.lastMutation!==s.lastMutation)return!1;let o=n.v,i=s.v;if(o!==i&&(o==null||i==null||o.id!==i.id||o.version!==i.version))return!1}return!0}oe();function kt(r,e){let t=new Map,n=(s,o)=>{if(t.has(s))return;let i={off:()=>{},prefix:o};t.set(s,i);let a=s.topology.subscribe(d=>{for(let u of d){if(u[0]!==C)continue;let l=u[1];if(e(l,s,o),l.kind==="added"&&l.nodeKind==="mount"){let g=s._mounts.get(l.name);if(g instanceof B){let f=`${o}${l.name}::`;n(g,f)}}else if(l.kind==="removed"&&l.nodeKind==="mount"){let g=`${o}${l.name}::`;for(let[f,h]of Array.from(t.entries()))f!==r&&h.prefix.startsWith(g)&&(h.off(),t.delete(f))}}});i.off=a;for(let[d,u]of s._mounts)if(u instanceof B){let l=`${o}${d}::`;n(u,l)}};return n(r,""),()=>{for(let s of t.values())s.off();t.clear()}}xe();Ee();ve();oe();vt();le();Ae();xt();xe();oe();le();Ae();var Et=class{_version=0;_maxSize;_buf;_head=0;_size=0;constructor(e,t){if(t!==void 0&&t<1)throw new RangeError("maxSize must be >= 1");if(this._maxSize=t,t!==void 0){if(this._buf=new Array(t),e&&e.length>0){let n=Math.min(e.length,t),s=e.length-n;for(let o=0;o<n;o++)this._buf[o]=e[s+o];this._size=n}}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 t=e>=0?e:this._size+e;if(!(t<0||t>=this._size))return this._maxSize!==void 0?this._buf[(this._head+t)%this._maxSize]:this._buf[t]}append(e){this._rawAppend(e),this._version+=1}appendMany(e){if(e.length===0)return;let t=this._maxSize!==void 0&&e.length>this._maxSize?e.length-this._maxSize:0;for(let n=t;n<e.length;n++)this._rawAppend(e[n]);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 t=0;t<e;t++)this._buf[(this._head+t)%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 t=Math.min(e,this._size);if(this._maxSize===void 0)this._buf.splice(0,t);else{for(let n=0;n<t;n++)this._buf[(this._head+n)%this._maxSize]=void 0;this._head=(this._head+t)%this._maxSize}return this._size-=t,this._version+=1,t}slice(e,t){if(!Number.isInteger(e)||e<0)throw new RangeError(`slice: start must be a non-negative integer (got ${e})`);if(t!==void 0&&(!Number.isInteger(t)||t<0))throw new RangeError(`slice: stop must be a non-negative integer or undefined (got ${t})`);let n=t===void 0?this._size:Math.min(Math.max(t,0),this._size),s=Math.min(e,this._size);if(s>=n)return[];let o=n-s;if(this._maxSize===void 0)return this._buf.slice(s,n);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 t=Math.min(e,this._size);return this.slice(this._size-t,this._size)}toArray(){if(this._maxSize===void 0)return[...this._buf];let e=new Array(this._size);for(let t=0;t<this._size;t++)e[t]=this._buf[(this._head+t)%this._maxSize];return e}snapshot(){return this.toArray()}restore(e){if(this._maxSize===void 0){this._buf.length=0;for(let t=0;t<e.length;t++)this._buf.push(e[t]);this._size=this._buf.length}else{let t=this._maxSize;for(let o=0;o<t;o++)this._buf[o]=void 0;this._head=0;let n=Math.min(e.length,t),s=e.length-n;for(let o=0;o<n;o++)this._buf[o]=e[s+o];this._size=n}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 Re(r){return r.subscribe(()=>{})}var sr=64;function mn(r,e={}){let{name:t,maxSize:n,versioning:s,guard:o,backend:i}=e,a=i??new Et(r,n),d=ee(a.toArray(),{name:t,describeKind:"state",equals:(m,O)=>m===O,...s!=null?{versioning:s}:{},...o!=null?{guard:o}:{}});function u(){let m=a.toArray();ue(()=>{d.down([[U]],{internal:!0}),d.down([[C,m]],{internal:!0})})}let l=new Map,g=new Map,f=new Map;function h(m,O){return`${m}:${O===void 0?"END":O}`}function c(m){if(m.size<sr)return;let O=m.keys().next();if(O.done)return;let x=m.get(O.value);x!==void 0&&x.dispose(),m.delete(O.value)}function _(m){let O=a.version;try{return m()}finally{a.version!==O&&u()}}function p(m){if(!Number.isInteger(m)||m<0)throw new RangeError(`tail: n must be a non-negative integer (got ${m})`);let O=l.get(m);if(O!==void 0)return l.delete(m),l.set(m,O),O.node;c(l);let x=H([d],([N])=>{let S=N;return m===0||S.length===0?[]:S.slice(Math.max(0,S.length-m))},{initial:a.tail(m),describeKind:"derived"}),A=Re(x);return l.set(m,{node:x,dispose:A}),x}function T(m,O){if(!Number.isInteger(m)||m<0)throw new RangeError(`slice: start must be a non-negative integer (got ${m})`);if(O!==void 0&&(!Number.isInteger(O)||O<0))throw new RangeError(`slice: stop must be a non-negative integer or undefined (got ${O})`);let x=h(m,O),A=g.get(x);if(A!==void 0)return g.delete(x),g.set(x,A),A.node;c(g);let N=H([d],([D])=>{let R=D;return O===void 0?R.slice(m):R.slice(m,O)},{initial:a.slice(m,O),describeKind:"derived"}),S=Re(N);return g.set(x,{node:N,dispose:S}),N}function v(m){let O=f.get(m);if(O!==void 0)return O.node;let x=H([d,m],([N,S])=>{let D=N,R=Math.max(0,Math.trunc(S??0));return D.slice(R)},{initial:[],describeKind:"derived"}),A=Re(x);return f.set(m,{node:x,dispose:A}),x}let b,y;function w(){b===void 0&&(b=Te([d],(m,O,x)=>{let A=m[0],S=A!=null&&A.length>0?A.at(-1):x.prevData[0];if(S==null||S.length===0){O.down([[W]]);return}O.emit(S[S.length-1])},{name:t!=null?`${t}::lastValue`:"lastValue",describeKind:"derived",initial:a.size===0?void 0:a.at(a.size-1)}),y=H([d],([m])=>m.length>0,{name:t!=null?`${t}::hasLatest`:"hasLatest",describeKind:"derived",initial:a.size>0}),Re(b),Re(y))}let k={entries:d,get size(){return a.size},at(m){return a.at(m)},append(m){_(()=>a.append(m))},appendMany(m){m.length!==0&&_(()=>a.appendMany(m))},clear(){_(()=>a.clear())},trimHead(m){_(()=>a.trimHead(m))},withLatest(){return w(),d},get lastValue(){return w(),b},get hasLatest(){return w(),y},view(m){switch(m.kind){case"tail":return p(m.n);case"slice":return T(m.start,m.stop);case"fromCursor":return v(m.cursor)}},attach(m){let O=m.subscribe(x=>{for(let A of x)A[0]===C&&k.append(A[1])});return()=>O()},attachStorage(m){if(m.length===0)return()=>{};let O=new Map;for(let A of m)O.set(A,a.size);(async()=>{for(let A of m)if(typeof A.loadEntries=="function")try{let N=await Promise.resolve(A.loadEntries());N.entries.length>0&&a.size===0&&(a.restore(N.entries),O.set(A,N.entries.length),u());break}catch{}})();let x=d.subscribe(A=>{for(let N of A){if(N[0]!==C)continue;let S=N[1];for(let D of m){let R=O.get(D)??0;if(S.length<R){try{let te=D.appendEntries(S);te instanceof Promise&&te.catch(()=>{})}catch{}O.set(D,S.length);continue}if(S.length===R)continue;let se=S.slice(R);O.set(D,S.length);try{let te=D.appendEntries(se);te instanceof Promise&&te.catch(()=>{})}catch{}}}});return()=>x()},disposeAllViews(){for(let m of l.values())m.dispose();l.clear();for(let m of g.values())m.dispose();g.clear();for(let m of f.values())m.dispose();f.clear()},dispose(){for(let m of l.values())m.dispose();l.clear();for(let m of g.values())m.dispose();g.clear();for(let m of f.values())m.dispose();f.clear()}};return k}Ke();Ie();ve();oe();Ae();xt();Ke();function bn(r,e){return Je("messaging",r,e)}var or=1024,Xe=class extends B{_log;events;latest;hasLatest;constructor(e,t={}){super(e,t.graph),this._log=mn([],{name:"events",maxSize:t.retainedLimit??or}),this._log.withLatest(),this.events=this._log.entries,this.add(this.events,{name:"events"}),this.latest=H([this.events],([n])=>{let s=n;return s.length===0?null:s[s.length-1]},{name:"latest",describeKind:"derived",meta:bn("topic_latest")}),this.add(this.latest,{name:"latest"}),this.addDisposer(re(this.latest)),this.hasLatest=H([this.events],([n])=>n.length>0,{name:"hasLatest",describeKind:"derived",meta:bn("topic_has_latest")}),this.add(this.hasLatest,{name:"hasLatest"}),this.addDisposer(re(this.hasLatest)),this.addDisposer(()=>{this.events.down([[V]])}),this.addDisposer(()=>this._log.disposeAllViews())}publish(e){if(e===void 0)throw new TypeError(`TopicGraph "${this.name}": publish(undefined) is not allowed (spec \xA75.12 SENTINEL).`);this._log.append(e)}attachEventStorage(e){return this._log.attachStorage(e)}retained(){return this.events.cache}get _logBundle(){return this._log}};function ir(r,e){return Je("audit",r,e)}var At=class extends B{policies;violations;violationCount;_target;_mode;_currentGuard;constructor(e,t,n){super(n.name??`${e.name}_policy`,n.graph),this._target=e,this._mode=n.mode??"audit";let s=yn(t)?t:ee(t,{name:"policies"});this.policies=s,this.add(this.policies,{name:"policies"}),this.violations=new Xe("violations",{retainedLimit:n.violationsLimit??1e3}),this.mount("violations",this.violations),this.violationCount=H([this.violations.events],([c])=>c.length,{name:"violationCount",describeKind:"derived",meta:ir("policy_violation_count")}),this.add(this.violationCount,{name:"violationCount"}),this.addDisposer(re(this.violationCount));let i=s.cache??[];this._currentGuard=it(i);let a=s.subscribe(c=>{for(let _ of c)_[0]===C&&(i=_[1]??[],this._currentGuard=it(i))});this.addDisposer(a);let d=n.paths,u=yn(d)?d:void 0,l=d!=null,f=u!=null?u.cache??[]:l?[...d]:void 0,h=f??_n(e);if(this._mode!=="enforce"&&u!=null){let c=u.subscribe(_=>{for(let p of _)p[0]===C&&(f=p[1]??[])});this.addDisposer(c)}if(this._mode==="enforce"){let c=new Map,_=p=>{if(c.has(p))return;let T=vn(e,p);if(!(T instanceof I))return;let v=(b,y)=>{let w=this._currentGuard(b,y);return w||this._publishViolation(b,y,p,"blocked"),w};c.set(p,T._pushGuard(v))};for(let p of h)_(p);if(u!=null){let p=u.subscribe(T=>{for(let v of T){if(v[0]!==C)continue;let b=v[1]??[],y=new Set(b),w=new Set(f??[]);ue(()=>{for(let k of w){if(y.has(k))continue;let m=c.get(k);m!=null&&(m(),c.delete(k))}for(let k of y)w.has(k)||_(k);f=b})}});this.addDisposer(p)}if(l){let p=e.topology.subscribe(T=>{for(let v of T){if(v[0]!==C)continue;let b=v[1];if(b.kind!=="removed"||b.nodeKind!=="node")continue;let y=c.get(b.name);y!=null&&(y(),c.delete(b.name))}});this.addDisposer(p)}else{let p=kt(e,(T,v,b)=>{if(T.kind==="added")if(T.nodeKind==="node")_(`${b}${T.name}`);else{let y=v._mounts.get(T.name);if(!(y instanceof B))return;let w=`${b}${T.name}::`,k=_n(y);for(let m of k)_(m===""?`${b}${T.name}`:`${w}${m}`)}else if(T.kind==="removed")if(T.nodeKind==="node"){let y=`${b}${T.name}`,w=c.get(y);w!=null&&(w(),c.delete(y))}else{let y=`${b}${T.name}`,w=`${y}::`;for(let[k,m]of c)(k===y||k.startsWith(w))&&(m(),c.delete(k))}});this.addDisposer(p)}this.addDisposer(()=>{for(let p of c.values())p();c.clear()})}else{let c=e.observe({timeline:!0,structured:!0}),_=c.onEvent(p=>{if(p.type!=="data"&&p.type!=="error")return;let T=p.path??"";if(!T||f!=null&&!f.includes(T))return;let v=p.actor??vn(e,T)?.lastMutation?.actor;if(v==null)return;let b="write";this._currentGuard(v,b)||this._publishViolation(v,b,T,"observed")});this.addDisposer(()=>{_(),c.dispose()})}}_publishViolation(e,t,n,s){this.violations.publish({timestamp_ns:Z(),wall_clock_ns:ye(),path:n,actor:e,action:t,mode:this._mode,result:s})}all(){return this.violations.retained()}get mode(){return this._mode}get target(){return this._target}};function wn(r,e,t={}){let n=new At(r,e,t);return n.tagFactory("policyGate",en(t)),n}function yn(r){return typeof r=="object"&&r!==null&&"subscribe"in r}function vn(r,e){try{return r.node(e)}catch{return}}function _n(r){let e=r.describe({detail:"minimal"});return Object.keys(e.nodes)}var Ze=class extends B{enforcer;violations;_target;_defaultActor;constructor(e,t){super(t.name??`${e.name}_guarded`,t.graph),this._target=e,this._defaultActor=t.actor;let n={mode:t.mode??"enforce",name:"enforcer"};t.violationsLimit!=null&&(n.violationsLimit=t.violationsLimit),this.enforcer=wn(e,t.policies,n),this.violations=this.enforcer.violations,this.mount("enforcer",this.enforcer)}scopedDescribe(e){let t=e?.actor??this._defaultActor,n={...e,...t!=null?{actor:t}:{}};return this._target.describe(n)}get target(){return this._target}};function ar(r,e){return new Ze(r,e)}0&&(module.exports={GuardedExecutionGraph,guardedExecution});
|
|
1
|
+
"use strict";var st=Object.defineProperty;var On=Object.getOwnPropertyDescriptor;var Nn=Object.getOwnPropertyNames;var kn=Object.prototype.hasOwnProperty;var j=(r,e)=>()=>(r&&(e=r(r=0)),e);var xn=(r,e)=>{for(var t in e)st(r,t,{get:e[t],enumerable:!0})},En=(r,e,t,n)=>{if(e&&typeof e=="object"||typeof e=="function")for(let s of Nn(e))!kn.call(r,s)&&s!==t&&st(r,s,{get:()=>e[s],enumerable:!(n=On(e,s))||n.enumerable});return r};var An=r=>En(st({},"__esModule",{value:!0}),r);function W(){return Math.trunc(performance.now()*1e6)}function he(){return Date.now()*1e6}var ge=j(()=>{"use strict"});var me,D,K,q,X,ee,re,F,V,$,ae,$e,Ct,Ie,Mt,Pt,Le,ot,it,at,Fe,se=j(()=>{"use strict";me=Symbol.for("graphrefly/START"),D=Symbol.for("graphrefly/DATA"),K=Symbol.for("graphrefly/DIRTY"),q=Symbol.for("graphrefly/RESOLVED"),X=Symbol.for("graphrefly/INVALIDATE"),ee=Symbol.for("graphrefly/PAUSE"),re=Symbol.for("graphrefly/RESUME"),F=Symbol.for("graphrefly/TEARDOWN"),V=Symbol.for("graphrefly/COMPLETE"),$=Symbol.for("graphrefly/ERROR"),ae=Object.freeze([K]),$e=Object.freeze([q]),Ct=Object.freeze([X]),Ie=Object.freeze([me]),Mt=Object.freeze([V]),Pt=Object.freeze([F]),Le=Object.freeze([ae]),ot=Object.freeze([$e]),it=Object.freeze([Ct]),at=Object.freeze([Mt]),Fe=Object.freeze([Pt])});function It(r,e){let t=new TextEncoder().encode(r.name);if(t.length===0||t.length>255)throw new Error(`encodeEnvelope: codec name "${r.name}" encodes to ${t.length} bytes (must be 1\u2013255)`);let n=r.version;if(!Number.isInteger(n)||n<0||n>65535)throw new Error(`encodeEnvelope: codec.version ${n} out of u16 range (expected integer 0\u201365535)`);let s=2+t.length+2+e.length;if(s>4294967295)throw new Error(`encodeEnvelope: total envelope size ${s} exceeds 2^32-1 bytes (payload ${e.length} bytes)`);let o=new Uint8Array(s),i=0;return o[i++]=dt,o[i++]=t.length,o.set(t,i),i+=t.length,o[i++]=n>>>8&255,o[i++]=n&255,o.set(e,i),o}function Lt(r,e){if(r.length<$t)throw new Error(`decodeEnvelope: bytes too short (${r.length} < ${$t})`);let t=0,n=r[t++];if(n!==dt)throw new Error(`decodeEnvelope: unsupported envelope version ${n} (expected ${dt})`);let s=r[t++];if(s===0)throw new Error("decodeEnvelope: name_len must be >= 1");if(t+s+2>r.length)throw new Error(`decodeEnvelope: envelope truncated (need ${t+s+2} bytes, have ${r.length})`);let o=new TextDecoder().decode(r.subarray(t,t+s));t+=s;let i=(r[t]<<8|r[t+1])>>>0;t+=2;let a=r.subarray(t),d=e.lookupCodec(o);if(d==null)throw new Error(`decodeEnvelope: codec "${o}" not registered (envelope codec_v=${i})`);return{codec:d,codecVersion:i,payload:a}}function Ft(r){r.registerCodec(Sn)}var Sn,dt,$t,ut=j(()=>{"use strict";Sn={name:"json",version:1,contentType:"application/json",encode(r){let e=JSON.stringify(r);return new TextEncoder().encode(e)},decode(r,e){let t=new TextDecoder().decode(r);return JSON.parse(t)}},dt=1,$t=4});function Ve(r){if(r==null)return be;let{type:e,id:t,...n}=r;return{type:e??"system",id:t??"",...n}}var be,ze=j(()=>{"use strict";be={type:"system",id:""}});function je(){return ye>0||Ae}function Vt(){return ye>0}function _e(r){ye>0?Se.push(r):r()}function ce(r){ye+=1;let e=!1;try{r()}catch(t){throw e=!0,t}finally{if(ye-=1,ye===0)if(e){if(!Ae){let t=Se.splice(0);for(let n of t)try{n()}catch{}de.length=0,ue.length=0,ve.length=0}}else Rn()}}function Rn(){let r=!Ae;r&&(Ae=!0);let e=[],t=0;try{for(;de.length>0||ue.length>0||ve.length>0||r&&Se.length>0;){if(r&&Se.length>0){let o=Se.splice(0);for(let i of o)try{i()}catch(a){e.push(a)}continue}if(t+=1,t>1e3)throw de.length=0,ue.length=0,ve.length=0,new Error("batch drain exceeded 1000 iterations \u2014 likely a reactive cycle");let s=(de.length>0?de:ue.length>0?ue:ve).splice(0);for(let o of s)try{o()}catch(i){e.push(i)}}}finally{r&&(Ae=!1)}if(e.length===1)throw e[0];if(e.length>1)throw new AggregateError(e,"batch drain: multiple callbacks threw")}function He(r,e,t){if(e.length===0)return;if(e.length===1){let u=t(e[0][0]);if(u<3||!je()){r(e);return}(u>=5?ve:u===4?ue:de).push(()=>r(e));return}let n=e.length,s=n,o=n,i=n,a=0;for(;a<n&&t(e[a][0])<3;)a++;for(s=a;a<n&&t(e[a][0])===3;)a++;for(o=a;a<n&&t(e[a][0])===4;)a++;i=a;let d=je();if(s>0){let u=e.slice(0,s);r(u)}if(o>s){let u=e.slice(s,o);d?de.push(()=>r(u)):r(u)}if(i>o){let u=e.slice(o,i);d?ue.push(()=>r(u)):r(u)}if(n>i){let u=e.slice(i,n);d?ve.push(()=>r(u)):r(u)}}var ye,Ae,de,ue,ve,Se,Re=j(()=>{"use strict";ye=0,Ae=!1,de=[],ue=[],ve=[],Se=[]});function zt(r){r.registerMessageType(me,{tier:0,wireCrossing:!1}),r.registerMessageType(K,{tier:1,wireCrossing:!1}),r.registerMessageType(X,{tier:1,wireCrossing:!1,metaPassthrough:!1}),r.registerMessageType(ee,{tier:2,wireCrossing:!1}),r.registerMessageType(re,{tier:2,wireCrossing:!1}),r.registerMessageType(D,{tier:3,wireCrossing:!0}),r.registerMessageType(q,{tier:3,wireCrossing:!0}),r.registerMessageType(V,{tier:4,wireCrossing:!0,metaPassthrough:!1}),r.registerMessageType($,{tier:4,wireCrossing:!0,metaPassthrough:!1}),r.registerMessageType(F,{tier:5,wireCrossing:!0,metaPassthrough:!1})}var Be,jt=j(()=>{"use strict";se();Be=class{_messageTypes=new Map;_codecs=new Map;_onMessage;_onSubscribe;_defaultVersioning;_defaultHashFn;_inspectorEnabled=!(typeof process<"u"&&process.env?.NODE_ENV==="production");_globalInspector;_rigorRecorder;_frozen=!1;tierOf;constructor(e){this._onMessage=e.onMessage,this._onSubscribe=e.onSubscribe,this._defaultVersioning=e.defaultVersioning,this._defaultHashFn=e.defaultHashFn,this.tierOf=t=>{let n=this._messageTypes.get(t);return n!=null?n.tier:1}}get onMessage(){return this._frozen=!0,this._onMessage}get onSubscribe(){return this._frozen=!0,this._onSubscribe}set onMessage(e){this._assertUnfrozen(),this._onMessage=e}set onSubscribe(e){this._assertUnfrozen(),this._onSubscribe=e}get defaultVersioning(){return this._defaultVersioning}set defaultVersioning(e){this._assertUnfrozen(),this._defaultVersioning=e}get defaultHashFn(){return this._defaultHashFn}set defaultHashFn(e){this._assertUnfrozen(),this._defaultHashFn=e}get inspectorEnabled(){return this._inspectorEnabled}set inspectorEnabled(e){this._inspectorEnabled=e}get globalInspector(){return this._globalInspector}set globalInspector(e){this._globalInspector=e}get rigorRecorder(){return this._rigorRecorder}set rigorRecorder(e){this._rigorRecorder=e}registerMessageType(e,t){return this._assertUnfrozen(),this._messageTypes.set(e,{tier:t.tier,wireCrossing:t.wireCrossing??t.tier>=3,metaPassthrough:t.metaPassthrough??!0}),this}messageTier(e){let t=this._messageTypes.get(e);return t!=null?t.tier:1}isWireCrossing(e){let t=this._messageTypes.get(e);return t!=null?t.wireCrossing:!0}isLocalOnly(e){return!this.isWireCrossing(e)}isMetaPassthrough(e){let t=this._messageTypes.get(e);return t!=null?t.metaPassthrough:!0}isKnownMessageType(e){return this._messageTypes.has(e)}registerCodec(e){return this._assertUnfrozen(),this._codecs.set(e.name,e),this}lookupCodec(e){return this._codecs.get(e)}_isFrozen(){return this._frozen}_assertUnfrozen(){if(this._frozen)throw new Error("GraphReFlyConfig is frozen: a node has already captured this config. Register custom types and set hooks before creating any node.")}}});function Ht(r){return Array.isArray(r)?[...r]:[r]}function Dn(r,e){return r.has(e)||r.has("*")}function Gn(r){let e=[];return r((s,o)=>{e.push({kind:"allow",actions:new Set(Ht(s)),where:o?.where??(()=>!0)})},(s,o)=>{e.push({kind:"deny",actions:new Set(Ht(s)),where:o?.where??(()=>!0)})}),(s,o)=>{let i=!1,a=!1;for(let d of e)Dn(d.actions,o)&&d.where(s)&&(d.kind==="deny"?i=!0:a=!0);return i?!1:a}}function ct(r){return Gn((e,t)=>{for(let n of r){let s=n.actorType==null?null:new Set(Array.isArray(n.actorType)?n.actorType:[n.actorType]),o=n.actorId==null?null:new Set(Array.isArray(n.actorId)?n.actorId:[n.actorId]),i=Object.entries(n.claims??{}),a=d=>{if(s!==null&&!s.has(String(d.type))||o!==null&&!o.has(String(d.id??"")))return!1;for(let[u,l]of i)if(d[u]!==l)return!1;return!0};n.effect==="deny"?t(n.action,{where:a}):e(n.action,{where:a})}})}function lt(r){let e=Cn.filter(t=>r({type:t,id:""},"write"));return e.length===0?"restricted":e.includes("human")&&e.includes("llm")&&e.every(t=>t==="human"||t==="llm"||t==="system")?"both":e.length===1?e[0]:e.join("+")}var Z,Cn,we=j(()=>{"use strict";Z=class extends Error{actor;action;nodeName;constructor(e,t){super(t??`GuardDenied: action "${String(e.action)}" denied for actor type "${String(e.actor.type)}"`),this.name="GuardDenied",this.actor=e.actor,this.action=e.action,this.nodeName=e.nodeName}get node(){return this.nodeName}};Cn=["human","llm","wallet","system"]});function pt(r){if(r===void 0)return null;if(typeof r=="number"){if(!Number.isFinite(r))throw new TypeError(`Cannot hash non-finite number: ${r}`);if(Number.isInteger(r)&&!Number.isSafeInteger(r))throw new TypeError(`Cannot hash integer outside safe range (|n| > 2^53-1): ${r}. Cross-language cid parity is not guaranteed for unsafe integers.`);return r}if(typeof r=="string"||typeof r=="boolean"||r===null)return r;if(Array.isArray(r))return r.map(pt);if(typeof r=="object"&&r!==null){let e={};for(let t of Object.keys(r).sort())e[t]=pt(r[t]);return e}return null}function $n(r){let e=Pn.encode(r),t=e.length,n=t*8,s=t+9+63&-64,o=new Uint8Array(s);o.set(e),o[t]=128;let i=new DataView(o.buffer);i.setUint32(s-4,n>>>0,!1),i.setUint32(s-8,Math.floor(n/4294967296)>>>0,!1);let a=1779033703,d=3144134277,u=1013904242,l=2773480762,g=1359893119,f=2600822924,h=528734635,c=1541459225,_=new Uint32Array(64),p=(v,b)=>v>>>b|v<<32-b;for(let v=0;v<s;v+=64){for(let N=0;N<16;N++)_[N]=i.getUint32(v+N*4,!1);for(let N=16;N<64;N++){let S=_[N-15],G=_[N-2],R=p(S,7)^p(S,18)^S>>>3,oe=p(G,17)^p(G,19)^G>>>10;_[N]=_[N-16]+R+_[N-7]+oe>>>0}let b=a,y=d,w=u,k=l,m=g,O=f,x=h,A=c;for(let N=0;N<64;N++){let S=p(m,6)^p(m,11)^p(m,25),G=m&O^~m&x,R=A+S+G+Mn[N]+_[N]>>>0,oe=p(b,2)^p(b,13)^p(b,22),ne=b&y^b&w^y&w,Me=oe+ne>>>0;A=x,x=O,O=m,m=k+R>>>0,k=w,w=y,y=b,b=R+Me>>>0}a=a+b>>>0,d=d+y>>>0,u=u+w>>>0,l=l+k>>>0,g=g+m>>>0,f=f+O>>>0,h=h+x>>>0,c=c+A>>>0}let T=v=>v.toString(16).padStart(8,"0");return T(a)+T(d)+T(u)+T(l)+T(g)+T(f)+T(h)+T(c)}function ft(r){let e=pt(r??null),t=JSON.stringify(e);return $n(t).slice(0,16)}function In(){let r=globalThis.crypto;if(r?.randomUUID)return r.randomUUID();let e=()=>Math.floor(Math.random()*4294967296).toString(16).padStart(8,"0"),t=e()+e()+e()+e();return`${t.slice(0,8)}-${t.slice(8,12)}-4${t.slice(13,16)}-${(parseInt(t.slice(16,17),16)&3|8).toString(16)}${t.slice(17,20)}-${t.slice(20,32)}`}function ht(r,e,t){let n=t?.id??In();if(r===0)return{id:n,version:0};let o=(t?.hash??ft)(e);return{id:n,version:0,cid:o,prev:null}}function Bt(r,e,t){r.version+=1,"cid"in r&&(r.prev=r.cid,r.cid=t(e))}var Mn,Pn,Ut=j(()=>{"use strict";Mn=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]),Pn=new TextEncoder});function qt(r){return{node:r,unsub:null,prevData:void 0,dirty:!1,involvedThisWave:!1,dataBatch:[],terminal:void 0}}function gt(r){r.prevData=void 0,r.dirty=!1,r.involvedThisWave=!1,r.dataBatch.length=0,r.terminal=void 0}function Ue(r){return r.length===0?r:typeof r[0]=="symbol"?[r]:r}function Oe(r,e,t){let n=Yt(r)?r:[],s=typeof r=="function"?r:typeof e=="function"?e:void 0,o={};return Yt(r)?o=(mt(e)?e:t)??{}:mt(r)?o=r:o=(mt(e)?e:t)??{},new I(n,s,o)}var Wt,Kt,Ln,Fn,Te,I,Yt,mt,le=j(()=>{"use strict";ut();ze();Re();ge();jt();we();se();Ut();Wt=()=>{},Kt=100;Ln=(r,e,t,n)=>{t.direction==="down-in"&&r._onDepMessage(t.depIndex,e)},Fn=(r,e,t,n)=>{let s=r;if(s._status==="completed"||s._status==="errored")return;let o=s._cached,i=o===void 0?[Ie]:[Ie,[D,o]];s._status==="dirty"&&i.push(ae),He(e,i,s._config.tierOf)},Te=new Be({onMessage:Ln,onSubscribe:Fn});zt(Te);Ft(Te);I=class r{_optsName;_describeKind;meta;_hasMeta;_config;_deps;_sinks=null;_sinkCount=0;_cached;_status;_cleanup;_store={};_waveHasNewData=!1;_hasNewTerminal=!1;_hasCalledFnOnce=!1;_paused=!1;_pendingWave=!1;_isExecutingFn=!1;_pendingRerun=!1;_rerunDepth=0;_dirtyDepCount=0;_batchPendingMessages=null;_pauseLocks=null;_pauseBuffer=null;_fn;_equals;_resubscribable;_resetOnTeardown;_autoComplete;_autoError;_pausable;_partial;_guard;_extraGuards;_hashFn;_versioning;_versioningLevel;_lastMutation;_inspectorHooks;_actions;constructor(e,t,n){this._config=n.config??Te,this._config.onMessage,this._optsName=n.name,this._describeKind=n.describeKind,this._equals=n.equals??Object.is,this._resubscribable=n.resubscribable??!1,this._resetOnTeardown=n.resetOnTeardown??!1,this._autoComplete=n.completeWhenDepsComplete??!0,this._autoError=n.errorWhenDepsError??!0,this._pausable=n.pausable??!0,this._guard=n.guard,this._fn=t,this._partial=n.partial??!1,this._cached=n.initial!==void 0?n.initial:void 0,this._status=e.length===0&&t==null&&this._cached!==void 0?"settled":"sentinel",this._hashFn=n.versioningHash??this._config.defaultHashFn??ft;let s=n.versioning??this._config.defaultVersioning;this._versioningLevel=s,this._versioning=s!=null?ht(s,this._cached===void 0?void 0:this._cached,{id:n.versioningId,hash:this._hashFn}):void 0,this._deps=e.map(qt);let o={};for(let[a,d]of Object.entries(n.meta??{})){let u={initial:d,name:`${n.name??"node"}:meta:${a}`,describeKind:"state",config:this._config};n.guard!=null&&(u.guard=n.guard),o[a]=new r([],void 0,u)}Object.freeze(o),this.meta=o,this._hasMeta=Object.keys(o).length>0;let i=this;this._actions={emit(a){i._emit([[D,a]])},down(a){i._emit(Ue(a))},up(a){i._emitUp(Ue(a))}},this.down=this.down.bind(this),this.up=this.up.bind(this)}get _isTerminal(){return this._status==="completed"||this._status==="errored"}get name(){return this._optsName}get status(){return this._status}get cache(){return this._cached===void 0?void 0:this._cached}get lastMutation(){return this._lastMutation}get v(){return this._versioning}hasGuard(){return this._guard!=null}_applyVersioning(e,t){if(this._isExecutingFn)throw new Error(`Node "${this.name}": _applyVersioning cannot run mid-fn \u2014 call it outside of \`_execFn\` (typically at graph setup time before the first subscribe).`);let n=this._versioningLevel;if(n!=null&&e<=n)return;let s=t?.hash??this._hashFn;s!==this._hashFn&&(this._hashFn=s);let o=this._cached===void 0?void 0:this._cached,i=this._versioning,a=i?.id??t?.id,d=i?.version??0,u=ht(e,o,{id:a,hash:s});u.version=d,this._versioning=u,this._versioningLevel=e}_setInspectorHook(e){return e==null?()=>{}:(this._inspectorHooks==null&&(this._inspectorHooks=new Set),this._inspectorHooks.add(e),()=>{this._inspectorHooks?.delete(e),this._inspectorHooks?.size===0&&(this._inspectorHooks=void 0)})}_pushGuard(e){return this._extraGuards==null&&(this._extraGuards=new Set),this._extraGuards.add(e),()=>{this._extraGuards?.delete(e),this._extraGuards?.size===0&&(this._extraGuards=void 0)}}allowsObserve(e){if(this._guard==null&&this._extraGuards==null)return!0;let t=Ve(e);if(this._guard!=null&&!this._guard(t,"observe"))return!1;if(this._extraGuards!=null){for(let n of this._extraGuards)if(!n(t,"observe"))return!1}return!0}_checkGuard(e){if(e?.internal)return;let t=this._guard!=null||this._extraGuards!=null,n=e?.actor!=null;if(!t&&!n)return;let s=Ve(e?.actor),o=e?.delivery==="signal"?"signal":"write";if(this._guard!=null&&!this._guard(s,o))throw new Z({actor:s,action:o,nodeName:this.name});if(this._extraGuards!=null){for(let i of this._extraGuards)if(!i(s,o))throw new Z({actor:s,action:o,nodeName:this.name})}this._lastMutation={actor:s,timestamp_ns:he()}}down(e,t){let n=Ue(e);n.length!==0&&(this._checkGuard(t),this._emit(n))}emit(e,t){this._checkGuard(t),this._emit([[D,e]])}up(e,t){if(this._deps.length===0)return;let n=Ue(e);if(n.length===0)return;this._checkGuard(t);let s=t??{internal:!0};this._validateUpTiers(n);for(let o of this._deps)o.node.up?.(n,s)}_emitUp(e){if(this._deps.length!==0&&e.length!==0){this._validateUpTiers(e);for(let t of this._deps)t.node.up?.(e,{internal:!0})}}_validateUpTiers(e){let t=this._config.tierOf;for(let n of e){let s=t(n[0]);if(s===3||s===4)throw new Error(`Node "${this.name}": tier-${s} messages cannot flow up \u2014 DATA/RESOLVED/COMPLETE/ERROR are downstream-only. Use \`down(...)\` for value delivery; \`up(...)\` is for control signals (DIRTY, INVALIDATE, PAUSE, RESUME, TEARDOWN).`)}}subscribe(e,t){if(t!=null&&this._guard!=null){let d=Ve(t);if(!this._guard(d,"observe"))throw new Z({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)gt(d);if(this._partial===!1){for(let d of this._deps)if(d.prevData!==void 0||d.dataBatch.length!==0||d.terminal!==void 0||d.dirty)throw new Error(`resubscribable-reset invariant: DepRecord not fully reset for node ${this._optsName??"(anonymous)"}`)}}this._sinkCount+=1;let o;try{o=this._config.onSubscribe(this,e,{sinkCount:this._sinkCount,afterTerminalReset:s},this._actions)}catch(d){throw this._sinkCount-=1,d}this._sinks==null?this._sinks=e:typeof this._sinks=="function"?this._sinks=new Set([this._sinks,e]):this._sinks.add(e);let i=this._isTerminal;if(this._sinkCount===1&&!i)try{this._activate()}catch(d){if(this._sinkCount-=1,this._removeSink(e),this._sinkCount===0&&(this._status="sentinel"),typeof o=="function")try{o()}catch{}throw d}this._status==="sentinel"&&this._cached===void 0&&(this._status="pending");let a=!1;return()=>{a||(a=!0,this._sinkCount-=1,this._removeSink(e),typeof o=="function"&&o(),this._sinks==null&&this._deactivate())}}_removeSink(e){if(this._sinks===e)this._sinks=null;else if(this._sinks!=null&&typeof this._sinks!="function")if(this._sinks.delete(e),this._sinks.size===1){let[t]=this._sinks;this._sinks=t}else this._sinks.size===0&&(this._sinks=null)}_activate(){if(this._deps.length===0){this._fn&&this._execFn();return}this._dirtyDepCount=0;let e=this._deps.length,t=0;try{for(let n=0;n<e;n++){let s=n,o=this._deps[n];o.unsub=Wt,o.unsub=o.node.subscribe(i=>{if(o.unsub===null)return;let a=this._config.tierOf,d=!1;for(let u of i)a(u[0])>=3&&(d=!0),this._config.onMessage(this,u,{direction:"down-in",depIndex:s},this._actions);d&&this._maybeRunFnOnSettlement()}),t++}}catch(n){this._deps[t].unsub=null;for(let s=0;s<t;s++){let o=this._deps[s];if(o.unsub!=null){let i=o.unsub;o.unsub=null;try{i()}catch{}gt(o)}}throw this._dirtyDepCount=0,n}}_addDep(e){for(let s=0;s<this._deps.length;s++)if(this._deps[s].node===e)return s;let t=this._deps.length,n=qt(e);if(this._deps.push(n),this._sinks==null)return t;n.dirty=!0,this._dirtyDepCount++,this._status!=="dirty"&&this._emit(Le),n.unsub=Wt;try{n.unsub=e.subscribe(s=>{if(n.unsub===null)return;let o=this._config.tierOf,i=!1;for(let a of s)o(a[0])>=3&&(i=!0),this._config.onMessage(this,a,{direction:"down-in",depIndex:t},this._actions);i&&this._maybeRunFnOnSettlement()})}catch(s){throw n.unsub=null,this._deps.pop(),this._dirtyDepCount--,s}return t}_deactivate(e=!1){let t=this._cleanup;if(this._cleanup=void 0,typeof t=="function")try{t()}catch(n){this._emit([[$,this._wrapFnError("cleanup threw",n)]])}else if(t!=null&&typeof t=="object"){let n=t.deactivate;if(typeof n=="function")try{n()}catch(s){this._emit([[$,this._wrapFnError("cleanup.deactivate threw",s)]])}}for(let n of this._deps){if(n.unsub!=null){let s=n.unsub;n.unsub=null;try{s()}catch{}}gt(n)}this._waveHasNewData=!1,this._hasNewTerminal=!1,this._hasCalledFnOnce=!1,this._paused=!1,this._pendingWave=!1,this._pendingRerun=!1,this._rerunDepth=0,this._store={},this._dirtyDepCount=0,this._pauseLocks=null,this._pauseBuffer=null,this._fn!=null&&(this._cached=void 0),e||(this._fn!=null||this._deps.length>0)&&(!this._isTerminal||this._resubscribable)&&(this._status="sentinel")}_onDepMessage(e,t){let n=this._deps[e],s=t[0];if(this._inspectorHooks!=null){let o={kind:"dep_message",depIndex:e,message:t};for(let i of this._inspectorHooks)i(o)}if(s!==me){if(s===K){this._depDirtied(n);return}if(s===X){if(this._depInvalidated(n),this._cached===void 0)return;this._emit(it);return}if(s===ee||s===re){this._emit([t]);return}if(s===F){this._emit(Fe);return}if(s===D)this._depSettledAsData(n,t[1]);else if(s===q)this._depSettledAsResolved(n);else if(s===V)this._depSettledAsTerminal(n,!0);else if(s===$)this._depSettledAsTerminal(n,t[1]);else{this._emit([t]);return}if(!this._fn){(s===D||s===q)&&this._emit([t]),(s===V||s===$)&&this._maybeAutoTerminalAfterWave();return}}}_depDirtied(e){e.dirty||(e.dirty=!0,e.involvedThisWave=!0,this._dirtyDepCount++,this._status!=="dirty"&&this._emit(Le))}_depSettledAsData(e,t){e.dirty&&(e.dirty=!1,this._dirtyDepCount--),e.involvedThisWave=!0,e.dataBatch.push(t),this._waveHasNewData=!0}_depSettledAsResolved(e){e.dirty&&(e.dirty=!1,this._dirtyDepCount--)}_depSettledAsTerminal(e,t){e.dirty&&(e.dirty=!1,this._dirtyDepCount--),e.terminal=t,e.involvedThisWave=!0,this._hasNewTerminal=!0}_depInvalidated(e){e.prevData=void 0,e.terminal=void 0,e.dataBatch.length=0,e.dirty?e.involvedThisWave=!1:(e.dirty=!0,e.involvedThisWave=!0,this._dirtyDepCount++)}_maybeRunFnOnSettlement(){if(!(this._isTerminal&&!this._resubscribable)&&!(this._dirtyDepCount>0)){if(!this._partial&&!this._hasCalledFnOnce)for(let e=0;e<this._deps.length;e++){let t=this._deps[e];if(t.dataBatch.length===0&&t.prevData===void 0&&t.terminal===void 0){this._maybeAutoTerminalAfterWave();return}}if(this._paused){this._pendingWave=!0;return}if(!this._waveHasNewData&&!this._hasNewTerminal&&this._hasCalledFnOnce){this._clearWaveFlags(),this._emit(ot),this._maybeAutoTerminalAfterWave();return}this._fn&&this._execFn(),this._maybeAutoTerminalAfterWave()}}_maybeAutoTerminalAfterWave(){if(this._deps.length===0||this._isTerminal)return;let e=this._deps.find(t=>t.terminal!==void 0&&t.terminal!==!0);if(e!=null){this._autoError&&this._emit([[$,e.terminal]]);return}this._autoComplete&&this._deps.every(t=>t.terminal!==void 0)&&this._emit(at)}_execFn(){if(!this._fn||this._isTerminal&&!this._resubscribable)return;if(this._isExecutingFn){this._pendingRerun=!0;return}let e=this._cleanup;if(typeof e=="function"){this._cleanup=void 0;try{e()}catch(i){this._emit([[$,this._wrapFnError("cleanup threw",i)]]);return}}else if(e!=null&&typeof e=="object"){let i=e.beforeRun;if(typeof i=="function"){e.beforeRun=void 0;try{i()}catch(a){this._emit([[$,this._wrapFnError("cleanup.beforeRun threw",a)]]);return}}}let t=this._deps.map(i=>i.involvedThisWave?i.dataBatch.length>0?[...i.dataBatch]:[]:void 0),n=this._deps.map(i=>i.prevData);for(let i=0;i<this._deps.length;i++){let a=t[i];a!=null&&a.length>0&&(this._deps[i].prevData=a[a.length-1])}let s=this._deps.map(i=>i.terminal),o={prevData:n,terminalDeps:s,store:this._store};if(this._hasCalledFnOnce=!0,this._clearWaveFlags(),this._inspectorHooks!=null){let i={kind:"run",batchData:t,prevData:n};for(let a of this._inspectorHooks)a(i)}this._isExecutingFn=!0;try{let i=this._fn(t,this._actions,o);if(typeof i=="function")this._cleanup=i;else if(i!=null&&typeof i=="object"){let a=i;(typeof a.beforeRun=="function"||typeof a.deactivate=="function"||typeof a.invalidate=="function")&&(this._cleanup=i)}}catch(i){this._emit([[$,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([[$,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,t){let n=t instanceof Error?t.message:String(t);return new Error(`Node "${this.name}": ${e}: ${n}`,{cause:t})}_frameBatch(e){let t=this._config.tierOf;if(e.length===1)return t(e[0][0])===3&&this._status!=="dirty"?[ae,e[0]]:e;let n=!0,s=!1,o=!1,i=-1;for(let d of e){let u=t(d[0]);u<i&&(n=!1),u===3&&(s=!0),d[0]===K&&(o=!0),i=u}let a=e;if(!n){let d=e.map((u,l)=>({m:u,i:l,tier:t(u[0])}));d.sort((u,l)=>u.tier-l.tier||u.i-l.i),a=d.map(u=>u.m)}if(s&&!o&&this._status!=="dirty"){let d=0;for(;d<a.length&&t(a[d][0])===0;)d++;return d===0?[ae,...a]:[...a.slice(0,d),ae,...a.slice(d)]}return a}_emit(e){if(e.length===0)return;for(let a=0;a<e.length;a++){let d=e[a];if(d[0]===$&&d[1]===void 0)throw new TypeError('[ERROR, payload] requires a non-undefined payload (spec \xA71.2). Pass an Error object or domain tag instead \u2014 e.g. node.down([[ERROR, new Error("reason")]])')}let t=e;if(this._isTerminal&&!this._resubscribable){let a=e.filter(d=>d[0]===F||d[0]===X);if(a.length===0)return;t=a}t=this._frameBatch(t);let s=null;for(let a=0;a<t.length;a++){let d=t[a],u=d[0];if(u!==ee&&u!==re){s?.push(d);continue}if(d.length<2)throw new Error(`Node "${this.name}": [[${u===ee?"PAUSE":"RESUME"}]] must carry a lockId payload \u2014 bare PAUSE/RESUME is a protocol violation (C0 rule). Use \`[[PAUSE, lockId]]\` / \`[[RESUME, lockId]]\`.`);let l=!0;if(this._pausable!==!1){let g=d[1];if(u===ee)this._pauseLocks==null&&(this._pauseLocks=new Set),this._pauseLocks.add(g),this._paused=!0,this._pausable==="resumeAll"&&this._pauseBuffer==null&&(this._pauseBuffer=[]);else if(this._pauseLocks==null||!this._pauseLocks.has(g))l=!1;else if(this._pauseLocks.delete(g),this._pauseLocks.size===0){if(this._paused=!1,this._pauseBuffer!=null&&this._pauseBuffer.length>0){let f=this._pauseBuffer;this._pauseBuffer=[],this._emit(f)}this._pendingWave&&(this._pendingWave=!1,this._maybeRunFnOnSettlement())}}l?s?.push(d):s==null&&(s=t.slice(0,a))}if(s!=null){if(s.length===0)return;t=s}if(this._hasMeta&&t.some(a=>a[0]===F))for(let a of Object.keys(this.meta))try{this.meta[a]._emit(Fe)}catch{}let{finalMessages:o,equalsError:i}=this._updateState(t);if(o.length>0&&this._config.inspectorEnabled){let a=this._config.globalInspector;if(a!=null)try{a({kind:"emit",node:this,messages:o})}catch{}}if(o.length>0)if(this._paused&&this._pausable==="resumeAll"&&this._pauseBuffer!=null){let a=this._config.tierOf,d=[];for(let u of o)a(u[0])===3?this._pauseBuffer.push(u):d.push(u);d.length>0&&this._dispatchOrAccumulate(d)}else this._dispatchOrAccumulate(o);i!=null&&this._emit([[$,i]])}_updateState(e){let t=this._config.tierOf,n,s,o=-1,i=0;for(let l of e)t(l[0])===3&&i++;let a=i<=1,d=-1;if(this._versioning!=null&&i>1){for(let l=e.length-1;l>=0;l--)if(e[l][0]===D){d=l;break}}for(let l=0;l<e.length;l++){let g=e[l],f=g[0];if(f===D){if(g.length>=2){let h=!1;if(a&&this._cached!==void 0)try{h=this._equals(this._cached,g[1])}catch(c){s=this._wrapFnError("equals threw",c),o=l;break}if(h){n==null&&(n=e.slice(0,l)),n.push($e),this._status="resolved";continue}this._cached=g[1],this._versioning!=null&&(d<0||l===d)&&Bt(this._versioning,g[1],this._hashFn)}this._status="settled",n?.push(g)}else if(n?.push(g),f===K)this._status="dirty";else if(f===q)this._status="resolved";else if(f===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(f===$){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(f===X){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 f===F&&(this._resetOnTeardown&&(this._cached=void 0),this._deactivate(!0),this._status="sentinel")}let u=o>=0?n??e.slice(0,o):n??e;return s!=null?{finalMessages:u,equalsError:s}:{finalMessages:u}}_deliverToSinks=e=>{if(this._sinks==null)return;if(typeof this._sinks=="function"){this._sinks(e);return}let t=[...this._sinks];for(let n of t)n(e)};_dispatchOrAccumulate(e){if(Vt()){this._batchPendingMessages===null&&(this._batchPendingMessages=[],_e(()=>this._flushBatchPending()));for(let t of e)this._batchPendingMessages.push(t);return}He(this._deliverToSinks,e,this._config.tierOf)}_flushBatchPending(){let e=this._batchPendingMessages;if(e===null||(this._batchPendingMessages=null,e.length===0))return;let t=this._frameBatch(e);He(this._deliverToSinks,t,this._config.tierOf)}},Yt=r=>Array.isArray(r),mt=r=>typeof r=="object"&&r!=null&&!Array.isArray(r)});function H(r,e){return Oe([],{...e,initial:r})}function We(r,e){return Oe((n,s,o)=>r(s,o)??void 0,{describeKind:"producer",...e})}function z(r,e,t){return Oe(r,(s,o,i)=>{let a=s.map((d,u)=>d!=null&&d.length>0?d.at(-1):i.prevData[u]);o.emit(e(a,i))},{describeKind:"derived",...t})}var Ne=j(()=>{"use strict";le()});function ke(r,e,t){return{[r]:!0,[`${r}_type`]:e,...t??{}}}var Ke=j(()=>{"use strict"});function te(r){return r.subscribe(()=>{})}var Jt=j(()=>{"use strict"});var De=j(()=>{"use strict";Jt()});function yt(r,e){if(e!=null&&e.length>0)return new Set(e);switch(r){case"standard":return new Set(["type","status","value","deps","meta","v"]);case"full":return null;case"spec":return new Set(["type","deps","meta","value"]);default:return new Set(["type","deps"])}}function Wn(r){return r._describeKind!=null?r._describeKind:r._deps.length>0?"derived":r._fn!=null?"producer":"state"}function nn(r){let e=new WeakSet,t={};for(let[n,s]of rn(r))t[n]=bt(s,e);return t}function bt(r,e){if(r==null)return r;let t=typeof r;if(t==="boolean"||t==="number"||t==="string")return r;if(t==="function")return"<function>";if(Array.isArray(r))return e.has(r)?"<cycle>":(e.add(r),r.map(n=>bt(n,e)));if(t==="object"){let n=r;if(e.has(n))return"<cycle>";e.add(n);try{if(typeof n.subscribe=="function"&&"cache"in n)return"<Node>"}catch{return"<unserializable>"}let s={};for(let[o,i]of rn(n))s[o]=bt(i,e);return s}return"<unserializable>"}function rn(r){let e=[],t;try{t=Object.keys(r)}catch{return e}for(let n of t)try{e.push([n,r[n]])}catch{e.push([n,"<unserializable>"])}return e}function Kn(r){let e={};for(let[t,n]of Object.entries(r.meta))try{e[t]=n.cache}catch{}return e}function vt(r,e,t){let n=e==null,s=!n&&e!=null?[...e].filter(l=>l.startsWith("meta.")).map(l=>l.slice(5)):null,o=n||e.has("meta")||s!=null&&s.length>0,i="state",a=[];r instanceof I&&(i=Wn(r),a=r._deps.map(l=>l.node.name??""));let d={type:i,deps:a};(n||e.has("status"))&&(d.status=r.status);let u=r instanceof I?r._guard:void 0;if(o){let l={...Kn(r)};if(u!=null&&l.access===void 0&&(l.access=lt(u)),s!=null&&s.length>0&&!e.has("meta")){let g={};for(let f of s)f in l&&(g[f]=l[f]);d.meta=g}else d.meta=l}if(r.name!=null&&(d.name=r.name),(n||e.has("value"))&&(!t||i==="state")){r.status==="sentinel"&&(d.sentinel=!0);try{d.value=r.cache}catch{}}if((n||e.has("v"))&&r.v!=null){let l={id:r.v.id,version:r.v.version};"cid"in r.v&&(l.cid=r.v.cid,l.prev=r.v.prev),d.v=l}return(n||e.has("guard"))&&u!=null&&(d.guard=lt(u)),(n||e.has("lastMutation"))&&r.lastMutation!=null&&(d.lastMutation=r.lastMutation),d}var _t=j(()=>{"use strict";we();le()});var Xe,on=j(()=>{"use strict";Xe=class{_timer;_gen=0;start(e,t){this.cancel(),this._gen+=1;let n=this._gen;this._timer=setTimeout(()=>{this._timer=void 0,n===this._gen&&t()},e)}cancel(){this._timer!==void 0&&(clearTimeout(this._timer),this._timer=void 0)}get pending(){return this._timer!==void 0}}});var Ge,an=j(()=>{"use strict";Ge=class{constructor(e){this.capacity=e;if(!Number.isInteger(e)||e<=0)throw new Error(`RingBuffer capacity must be a positive integer (got ${e})`);this.buf=new Array(e)}buf;head=0;_size=0;get size(){return this._size}get maxSize(){return this.capacity}push(e){let t=(this.head+this._size)%this.capacity;this.buf[t]=e,this._size<this.capacity?this._size++:this.head=(this.head+1)%this.capacity}shift(){if(this._size===0)return;let e=this.buf[this.head];return this.buf[this.head]=void 0,this.head=(this.head+1)%this.capacity,this._size--,e}at(e){if(this._size===0)return;let t=e<0?this._size+e:e;if(!(t<0||t>=this._size))return this.buf[(this.head+t)%this.capacity]}toArray(){let e=new Array(this._size);for(let t=0;t<this._size;t++)e[t]=this.buf[(this.head+t)%this.capacity];return e}clear(){for(let e=0;e<this._size;e++)this.buf[(this.head+e)%this.capacity]=void 0;this.head=0,this._size=0}}});var cr={};xn(cr,{GuardedExecutionGraph:()=>Qe,guardedExecution:()=>ur});module.exports=An(cr);ge();se();Ne();Ke();De();var L={object:56,array:64,string:40,number:8,boolean:4,null:0,undefined:0,symbol:40,bigint:16,function:120,map:72,set:72,mapEntry:40,setEntry:24,date:24,regexp:48,error:64,url:80,promise:48,weakmap:40,weakset:40},Vn=Symbol.for("sizeof");function Xt(r){let e=new WeakSet,t=new WeakSet,n=[r],s=0;for(;n.length>0;){let o=n.pop();s+=zn(o,e,t,n)}return s}function zn(r,e,t,n){if(r==null)return 0;switch(typeof r){case"number":return L.number;case"boolean":return L.boolean;case"string":return L.string+r.length*2;case"bigint":return L.bigint+jn(r);case"symbol":return L.symbol;case"function":return e.has(r)?0:(e.add(r),L.function);case"undefined":return 0}let o=r;if(e.has(o))return 0;e.add(o);let i=o[Vn];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 L.date;if(o instanceof RegExp)return L.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 L.error+u+l}if(typeof URL<"u"&&o instanceof URL)return L.url+o.href.length*2;if(typeof Promise<"u"&&o instanceof Promise)return L.promise;if(o instanceof WeakMap)return L.weakmap;if(o instanceof WeakSet)return L.weakset;if(o instanceof Map){let u=L.map;for(let[l,g]of o)u+=L.mapEntry,n.push(l),n.push(g);return u}if(o instanceof Set){let u=L.set;for(let l of o)u+=L.setEntry,n.push(l);return u}if(Array.isArray(o)){let u=L.array+o.length*8;for(let l of o)n.push(l);return u}if(o instanceof ArrayBuffer)return t.has(o)?0:(t.add(o),o.byteLength);if(ArrayBuffer.isView(o)){let u=o;return t.has(u.buffer)?48:(t.add(u.buffer),u.buffer.byteLength+48)}let a=L.object,d=Object.keys(o);for(let u of d){a+=L.string+u.length*2;try{n.push(o[u])}catch{}}return a}function jn(r){let e=r<0n?-r:r;if(e===0n)return 0;let t=e.toString(2).length;return Math.ceil(t/32)*8}function Zt(r,e,t,n={}){let s=e in r.nodes,o=t in r.nodes;if(!s)return qe(e,t,"no-such-from");if(!o)return qe(e,t,"no-such-to");let i=n.maxDepth;if(i!=null&&(!Number.isInteger(i)||i<0))throw new Error("explainPath: maxDepth must be an integer >= 0");if(e===t){if(n.findCycle===!0){let u=Hn(r,e,n);if(u!=null)return u}let d=Ye(e,r.nodes[e],0,n);return Je(e,t,[d])}if(i===0)return qe(e,t,"no-path");let a=Qt(r,e,t,i);return a.found?Je(e,t,en(r,a.pathOrder,n)):qe(e,t,a.truncated?"max-depth-exceeded":"no-path")}function Qt(r,e,t,n){let s=new Map,o=[{path:t,depth:0}],i=new Set([t]),a=0,d=!1;for(;a<o.length;){let g=o[a++];if(g.path===e)break;if(n!=null&&g.depth>=n){let _=r.nodes[g.path];_?.deps&&_.deps.length>0&&(d=!0);continue}let f=r.nodes[g.path];if(f==null)continue;let h=f.deps??[],c=new Map;for(let _=0;_<h.length;_++){let p=h[_];if(!p)continue;let T=c.get(p);T==null&&(T=[],c.set(p,T)),T.push(_)}for(let[_,p]of c)i.has(_)||(i.add(_),s.set(_,{from:g.path,depIndices:p}),o.push({path:_,depth:g.depth+1}))}if(!s.has(e))return{found:!1,pathOrder:[],truncated:d};let u=[{path:e}],l=e;for(;l!==t;){let g=s.get(l);if(g==null)return{found:!1,pathOrder:[],truncated:!1};u[u.length-1].depIndices=g.depIndices,u.push({path:g.from}),l=g.from}return{found:!0,pathOrder:u,truncated:!1}}function Hn(r,e,t){let n=r.nodes[e];if(n==null)return null;let s=n.deps??[],o=[];for(let a=0;a<s.length;a++)s[a]===e&&o.push(a);if(o.length>0){let a=Ye(e,n,0,t);a.dep_index=o[0];let d=Ye(e,n,1,t);return Je(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=Qt(r,d,e,t.maxDepth);u.found&&(i==null||u.pathOrder.length<i.pathOrder.length)&&(i=u,i={found:!0,pathOrder:[{path:e,depIndices:[a]},...u.pathOrder],truncated:!1})}return i==null?null:Je(e,e,en(r,i.pathOrder,t))}function en(r,e,t){return e.map((n,s)=>{let o=r.nodes[n.path],i=Ye(n.path,o,s,t);return n.depIndices!=null&&n.depIndices.length>0&&(i.dep_index=n.depIndices[0],n.depIndices.length>1&&(i.dep_indices=[...n.depIndices])),i})}function Ye(r,e,t,n){let s={path:r,type:e.type,hop:t};e.status!==void 0&&(s.status=e.status),"value"in e&&(s.value=e.value),e.v!=null&&(s.v=e.v);let o=n.annotations?.get(r)??e.annotation;o!=null&&(s.annotation=o);let i=n.lastMutations?.get(r)??e.lastMutation;return i!=null&&(s.lastMutation=i),s}function Je(r,e,t){return tn(r,e,!0,"ok",t)}function qe(r,e,t){return tn(r,e,!1,t,[])}function tn(r,e,t,n,s){let o=Bn(r,e,t,n,s);return{from:r,to:e,found:t,reason:n,steps:s,text:o,toJSON(){return{from:r,to:e,found:t,reason:n,steps:s}}}}function Bn(r,e,t,n,s){if(!t)switch(n){case"no-such-from":return`explainPath: no node named "${r}"`;case"no-such-to":return`explainPath: no node named "${e}"`;case"max-depth-exceeded":return`explainPath: no path from "${r}" to "${e}" within maxDepth`;default:return`explainPath: no path from "${r}" to "${e}"`}let o=[`Causal path: ${r} \u2192 ${e} (${s.length} step(s))`];for(let i of s){let d=` ${i.hop===0?"\xB7":"\u2193"} ${i.path} (${i.type}${i.status?`/${i.status}`:""})`;if(o.push(d),"value"in i&&o.push(` value: ${Un(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 Un(r){if(r===void 0)return"<sentinel>";if(r===null)return"null";if(typeof r=="string")return JSON.stringify(r);if(typeof r=="number"||typeof r=="boolean"||typeof r=="bigint")return String(r);try{let e=JSON.stringify(r);return e.length>80?`${e.slice(0,77)}...`:e}catch{return String(r)}}ze();Re();ge();we();se();_t();le();Ne();ge();function wt(r,e){if(Object.is(r,e))return!0;if(r==null||e==null||typeof r!="object"||typeof e!="object")return!1;if(Array.isArray(r)){if(!Array.isArray(e)||r.length!==e.length)return!1;for(let o=0;o<r.length;o++)if(!wt(r[o],e[o]))return!1;return!0}if(Array.isArray(e))return!1;let t=Object.keys(r),n=Object.keys(e);if(t.length!==n.length)return!1;let s=new Set(n);for(let o of t)if(!s.has(o)||!wt(r[o],e[o]))return!1;return!0}function sn(r,e){return`${r}\0${e}`}function Tt(r,e){let t=[],n=new Set(r.subgraphs),s=new Set(e.subgraphs),o=[];for(let p of s)n.has(p)||o.push(p);o.sort();for(let p of o)t.push({type:"subgraph-mounted",path:p});let i=new Set(Object.keys(r.nodes)),a=new Set(Object.keys(e.nodes)),d=[];for(let p of a)i.has(p)||d.push(p);d.sort();for(let p of d)t.push({type:"node-added",path:p,node:{...e.nodes[p]}});let u=[];for(let p of a){if(!i.has(p))continue;let T=r.nodes[p]?.meta,v=e.nodes[p]?.meta;T==null&&v==null||wt(T??{},v??{})||u.push(p)}u.sort();for(let p of u)t.push({type:"node-meta-changed",path:p,prevMeta:r.nodes[p]?.meta??{},nextMeta:e.nodes[p]?.meta??{}});let l=new Map;for(let p of r.edges)l.set(sn(p.from,p.to),p);let g=new Map;for(let p of e.edges)g.set(sn(p.from,p.to),p);let f=[];for(let[p,T]of g)l.has(p)||f.push(T);f.sort((p,T)=>p.from<T.from?-1:p.from>T.from?1:p.to<T.to?-1:p.to>T.to?1:0);for(let p of f)t.push({type:"edge-added",from:p.from,to:p.to});let h=[];for(let[p,T]of l)g.has(p)||h.push(T);h.sort((p,T)=>p.from<T.from?-1:p.from>T.from?1:p.to<T.to?-1:p.to>T.to?1:0);for(let p of h)t.push({type:"edge-removed",from:p.from,to:p.to});let c=[];for(let p of i)a.has(p)||c.push(p);c.sort();for(let p of c)t.push({type:"node-removed",path:p});let _=[];for(let p of n)s.has(p)||_.push(p);_.sort();for(let p of _)t.push({type:"subgraph-unmounted",path:p});return{events:t,flushedAt_ns:W()}}De();on();an();ut();le();function dn(r,e){let t=e?.topN??10,n=r.describe({detail:"standard"}),s=[],o=r._collectObserveTargets;typeof o=="function"&&o.call(r,"",s);let i=new Map;for(let[f,h]of s)i.set(f,h);let a=[];for(let[f,h]of Object.entries(n.nodes)){let c=i.get(f),_=c instanceof I?c:null,p=_?Xt(_.cache):0,T=_?_._sinkCount:0,v=h.deps?.length??0,b=h.type==="effect"&&T===0,y=T===0?h.type==="effect"?"orphan-effect":h.type==="derived"?"idle-derived":h.type==="producer"?"idle-producer":null:null;a.push({path:f,type:h.type,status:h.status??"unknown",valueSizeBytes:p,subscriberCount:T,depCount:v,isOrphanEffect:b,orphanKind:y})}let d=a.reduce((f,h)=>f+h.valueSizeBytes,0),u=(f,h)=>[...a].sort(h??((c,_)=>_[f]-c[f])).slice(0,t),l=a.filter(f=>f.orphanKind!=null),g=a.filter(f=>f.isOrphanEffect);return{nodeCount:a.length,edgeCount:n.edges.length,subgraphCount:n.subgraphs.length,nodes:a,totalValueSizeBytes:d,hotspots:{byValueSize:u("valueSizeBytes"),bySubscriberCount:u("subscriberCount"),byDepCount:u("depCount")},orphans:l,orphanEffects:g}}var P="::",Q="__meta__",pe=1;function un(r,e){let t=Math.max(16,r.size*4),n=0;for(;r.size>0;){if(n++>=t){console.error(`[Graph "${e}".destroy] disposer drain exceeded cap (${t}); ${r.size} disposer(s) discarded`),r.clear();return}let s=r.values().next();if(s.done)return;let o=s.value;r.delete(o);try{o()}catch(i){console.error(`[Graph "${e}".destroy] disposer threw:`,i)}}}function hn(r){return r!=null&&typeof r=="object"&&"cache"in r&&typeof r.subscribe=="function"&&typeof r.down=="function"}function qn(r){if(r!=null)return hn(r)?r.cache:r}function fe(r){return r!=null&&typeof r=="object"&&"cache"in r&&typeof r.subscribe=="function"&&typeof r.down=="function"}function ie(r){return fe(r)?r.cache??"":r}function cn(r){return fe(r)?r.cache??0:r}function ln(r){return fe(r)?r.cache??!1:r}function Yn(r){let e=[];for(let t of Object.keys(r).sort()){let n=r[t].v;n!=null&&e.push(`${t} ${n.id} ${n.version}`)}return e.join(`
|
|
3
|
+
`)}function pn(r){if(r.version!==pe)throw new Error(`unsupported snapshot version ${String(r.version)} (expected ${pe})`);for(let e of["name","nodes","edges","subgraphs"])if(!(e in r))throw new Error(`snapshot missing required key "${e}"`);if(typeof r.name!="string")throw new TypeError("snapshot 'name' must be a string");if(typeof r.nodes!="object"||r.nodes===null||Array.isArray(r.nodes))throw new TypeError("snapshot 'nodes' must be an object");if(!Array.isArray(r.edges))throw new TypeError("snapshot 'edges' must be an array");if(!Array.isArray(r.subgraphs))throw new TypeError("snapshot 'subgraphs' must be an array")}function Jn(r,e){let t=new WeakMap,n=(s,o)=>{if(Object.is(s,o))return!0;if(s==null||o==null||typeof s!="object"||typeof o!="object")return!1;let i=t.get(s);if(i==null&&(i=new WeakSet,t.set(s,i)),i.has(o))return!0;i.add(o);let a=s.constructor,d=o.constructor;if(a!==d)return!1;if(s instanceof Date)return s.getTime()===o.getTime();if(s instanceof RegExp)return s.source===o.source&&s.flags===o.flags;if(Array.isArray(s)){let f=o;if(s.length!==f.length)return!1;for(let h=0;h<s.length;h++)if(!n(s[h],f[h]))return!1;return!0}if(s instanceof Map){let f=o;if(s.size!==f.size)return!1;for(let[h,c]of s)if(!f.has(h)||!n(c,f.get(h)))return!1;return!0}if(s instanceof Set){let f=o;if(s.size!==f.size)return!1;for(let h of s){let c=!1;for(let _ of f)if(n(h,_)){c=!0;break}if(!c)return!1}return!0}if(ArrayBuffer.isView(s)){let f=s,h=o;if(f.length!==h.length)return!1;for(let c=0;c<f.length;c++)if(f[c]!==h[c])return!1;return!0}let u=Object.keys(s),l=Object.keys(o);if(u.length!==l.length)return!1;let g=new Set(l);for(let f of u)if(!g.has(f)||!n(s[f],o[f]))return!1;return!0};return n(r,e)}function Xn(r){return r.replace(/[.*+?^${}()|[\]\\]/g,"\\$&")}function Ze(r){let e="^";for(let t=0;t<r.length;t+=1){let n=r[t];if(n==="*"){e+=".*";continue}if(n==="?"){e+=".";continue}if(n==="["){let s=r.indexOf("]",t+1);if(s<=t+1){e+="\\[";continue}let o=r.slice(t+1,s);o.startsWith("!")&&(o=`^${o.slice(1)}`),o=o.replace(/\\/g,"\\\\"),e+=`[${o}]`,t=s;continue}e+=Xn(n)}return e+="$",new RegExp(e)}var Zn={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"},Qn={data:"",dirty:"",resolved:"",invalidate:"",pause:"",resume:"",complete:"",error:"",teardown:"",derived:"",path:"",reset:""};function Ot(r){if(typeof r=="string")return JSON.stringify(r);if(typeof r=="number"||typeof r=="boolean"||r==null)return String(r);try{return JSON.stringify(r)}catch{return"[unserializable]"}}function er(r){return r==="none"?Qn:r==="ansi"||r==null?Zn:{data:r.data??"",dirty:r.dirty??"",resolved:r.resolved??"",invalidate:r.invalidate??"",pause:r.pause??"",resume:r.resume??"",complete:r.complete??"",error:r.error??"",teardown:r.teardown??"",derived:r.derived??"",path:r.path??"",reset:r.reset??""}}function fn(r){if(r==null)return{};let e=r.detail;return e==="full"?{...r,structured:r.structured??!0,timeline:r.timeline??!0,causal:r.causal??!0,derived:r.derived??!0}:e==="minimal"?{...r,structured:r.structured??!0}:r.format==="stage-log"?{...r,structured:r.structured??!0,timeline:r.timeline??!0}:r}function tr(r,e,t){for(let n=0;n<r.length;n++){let s=r.charCodeAt(n);if(s<32||s===127)throw new Error(`Graph "${e}": ${t} "${r}" must not contain control character (U+${s.toString(16).padStart(4,"0").toUpperCase()} at index ${n})`)}}function Nt(r,e,t){if(r==="")throw new Error(`Graph "${e}": ${t} name must be non-empty`);if(r.includes(P))throw new Error(`Graph "${e}": ${t} "${r}" must not contain '${P}' (path separator)`);if(r===Q)throw new Error(`Graph "${e}": ${t} name "${Q}" is reserved for meta companion paths`);tr(r,e,t)}function nr(r,e){if(r==="")throw new Error(`Graph "${e}": resolve path must be non-empty`);let t=r.split(P);for(let n of t)if(n==="")throw new Error(`Graph "${e}": resolve path has empty segment`);return t}function rr(r,e){let t=!1;for(let s of r)if(!e.isMetaPassthrough(s[0])){t=!0;break}return t?r.filter(s=>e.isMetaPassthrough(s[0])):r}function gn(r){for(let e of r._mounts.values())gn(e);for(let e of r._nodes.values())try{e.down([[F]],{internal:!0})}catch{}}var U=class r{name;opts;config;_nodes=new Map;_nodeToName=new WeakMap;_mounts=new Map;_parent=void 0;_storageDisposers=new Set;_disposers=new Set;_destroyed=!1;_topology;_topologyEmitters=new Set;_factory;_factoryArgs;constructor(e,t){if(e==="")throw new Error("Graph name must be non-empty");if(e.includes(P))throw new Error(`Graph name must not contain '${P}' (got "${e}")`);if(e===Q)throw new Error(`Graph name "${Q}" is reserved for meta companion paths`);this.name=e,this.opts=Object.freeze({...t??{}}),this.config=t?.config??Te,this._traceRing=new Ge(t?.traceCapacity??1e3),t?.versioning!=null&&this.setVersioning(t.versioning),typeof t?.factory=="string"&&(this._factory=t.factory,t.factoryArgs!==void 0&&(this._factoryArgs=t.factoryArgs))}tagFactory(e,t){return this._factory=e,this._factoryArgs=t,this}ancestors(e=!0){let t=[],n=e?this:this._parent;for(;n!=null;)t.push(n),n=n._parent;return t}get topology(){return this._topology==null&&(this._topology=We(e=>{let t=n=>{e.emit(n)};return this._topologyEmitters.add(t),()=>{this._topologyEmitters.delete(t)}},{name:`${this.name}_topology`})),this._topology}_emitTopology(e){if(!(this._topology==null||this._topologyEmitters.size===0))for(let t of this._topologyEmitters)t(e)}nameOf(e){return this._nodeToName.get(e)}add(e,t){let n=e.name,s=t?.name??n;if(s==null||s==="")throw new Error(`Graph "${this.name}": graph.add requires a non-empty name \u2014 pass via opts.name or set it on the node (e.g. state(0, { name: "x" }))`);let o=s,i=t?.annotation;if(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:W()})),e}setVersioning(e){if(e!=null)for(let t of this._nodes.values())t instanceof I&&t._applyVersioning(e)}remove(e){Nt(e,this.name,"remove");let t=this._mounts.get(e);if(t){let o={kind:"mount",nodes:[],mounts:[]},i=[];t._collectObserveTargets("",i);for(let[a,d]of i)a.includes(`${P}${Q}${P}`)||o.nodes.push(a);return o.nodes.sort(),o.mounts.push(e),o.mounts.push(...t._collectSubgraphs(`${e}${P}`)),this._mounts.delete(e),t._parent=void 0,gn(t),this._emitTopology({kind:"removed",name:e,nodeKind:"mount",audit:o}),o}let n=this._nodes.get(e);if(!n)throw new Error(`Graph "${this.name}": unknown node or mount "${e}"`);this._nodes.delete(e),this._nodeToName.delete(n),n.down([[F]],{internal:!0});let s={kind:"node",nodes:[e],mounts:[]};return this._emitTopology({kind:"removed",name:e,nodeKind:"node",audit:s}),s}removeAll(e){let t=typeof e=="function"?e:(()=>{let o=Ze(e);return i=>o.test(i)})(),n={kind:"mount",nodes:[],mounts:[]},s=[...this._nodes.keys(),...this._mounts.keys()].filter(o=>t(o));for(let o of s){let i=this.remove(o);n.nodes.push(...i.nodes),n.mounts.push(...i.mounts)}return n.nodes.sort(),n.mounts.sort(),n}[Symbol.iterator](){let e=[...this._nodes.keys()].sort(),t=this._nodes,n=0;return{[Symbol.iterator](){return this},next(){if(n>=e.length)return{value:void 0,done:!0};let s=e[n++];return{value:[s,t.get(s)],done:!1}}}}node(e){if(e==="")throw new Error(`Graph "${this.name}": node name must be non-empty`);if(e.includes(P))return this.resolve(e);let t=this._nodes.get(e);if(!t)throw new Error(`Graph "${this.name}": unknown node "${e}"`);return t}get(e){return this.node(e).cache}set(e,t,n){let s=n?.internal===!0;this.node(e).down([[D,t]],{actor:n?.actor,internal:s,delivery:"write"})}setAll(e,t){let n=Symbol.iterator in e?e:Object.entries(e);ce(()=>{for(let[s,o]of n)this.set(s,o,t)})}invalidate(e,t){let n=t?.internal===!0;this.node(e).down([[X]],{actor:t?.actor,internal:n,delivery:"write"})}error(e,t,n){let s=n?.internal===!0;this.node(e).down([[$,t]],{actor:n?.actor,internal:s,delivery:"write"})}complete(e,t){let n=t?.internal===!0;this.node(e).down([[V]],{actor:t?.actor,internal:n,delivery:"write"})}edges(e){let t=e?.recursive===!0,n=new Map;if(!t){for(let[d,u]of this._nodes)n.set(u,d);let a=[];for(let[d,u]of this._nodes)if(u instanceof I)for(let l of u._deps){let g=n.get(l.node);g!=null&&a.push([g,d])}return a.sort((d,u)=>d[0]<u[0]?-1:d[0]>u[0]?1:d[1]<u[1]?-1:d[1]>u[1]?1:0),a}let s=[];this._collectObserveTargets("",s);let o=new Map;for(let[a,d]of s)o.set(d,a);let i=[];for(let[a,d]of s)if(d instanceof I)for(let u of d._deps){let l=o.get(u.node);l!=null&&i.push([l,a])}return i.sort((a,d)=>a[0]<d[0]?-1:a[0]>d[0]?1:a[1]<d[1]?-1:a[1]>d[1]?1:0),i}mount(e,t){if(t===void 0){let s=new r(e);return this.mount(e,s)}if(typeof t=="function"){let s=new r(e);return t(s),this.mount(e,s)}let n=t;if(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(n===this)throw new Error(`Graph "${this.name}": cannot mount a graph into itself`);if(n._parent!=null)throw new Error(`Graph "${this.name}": this child graph is already mounted on "${n._parent.name}"`);for(let s=this;s!=null;s=s._parent)if(s===n)throw new Error(`Graph "${this.name}": mount("${e}", \u2026) would create a mount cycle`);return this._mounts.set(e,n),n._parent=this,this._emitTopology({kind:"added",name:e,nodeKind:"mount"}),n}resolve(e){let t=nr(e,this.name);return this._resolveFromSegments(t)}tryResolve(e){try{return this.resolve(e)}catch{return}}_resolveFromSegments(e){let t=e;if(t[0]===this.name&&(t=t.slice(1),t.length===0))throw new Error(`Graph "${this.name}": resolve path ends at graph name only`);let n=t[0],s=t.slice(1);if(s.length===0){let a=this._nodes.get(n);if(a)return a;throw this._mounts.has(n)?new Error(`Graph "${this.name}": path ends at subgraph "${n}" \u2014 not a node (GRAPHREFLY-SPEC \xA73.5)`):new Error(`Graph "${this.name}": unknown name "${n}"`)}let o=this._nodes.get(n);if(o&&s.length>0&&s[0]===Q)return this._resolveMetaChainFromNode(o,s,t.join(P));let i=this._mounts.get(n);if(!i)throw this._nodes.has(n)?new Error(`Graph "${this.name}": "${n}" is a node; trailing path "${s.join(P)}" is invalid`):new Error(`Graph "${this.name}": unknown mount or node "${n}"`);return i.resolve(s.join(P))}_resolveMetaChainFromNode(e,t,n){let s=e,o=0,i=[...t];for(;o<i.length;){if(i[o]!==Q)throw new Error(`Graph "${this.name}": expected ${Q} segment in meta path "${n}"`);if(o+1>=i.length)throw new Error(`Graph "${this.name}": meta path requires a key after ${Q} in "${n}"`);let a=i[o+1],d=s.meta[a];if(!d)throw new Error(`Graph "${this.name}": unknown meta "${a}" in path "${n}"`);s=d,o+=2}return s}signal(e,t){if(t?.internal!==!0){for(let s of e)if(this.config.messageTier(s[0])===3)throw new Error(`Graph "${this.name}": Graph.signal() rejects tier-3 messages (DATA / RESOLVED). Broadcast is for control-plane tiers (START / DIRTY / INVALIDATE / PAUSE / RESUME / COMPLETE / ERROR / TEARDOWN). For per-node value writes, use Graph.set or graph.node(name).down(...).`)}let n=[];if(this._signalDeliver(e,t??{},new Set,n),n.length>0)throw n[0]}_signalDeliver(e,t,n,s){for(let d of this._mounts.values())d._signalDeliver(e,t,n,s);let i=t.internal===!0?{internal:!0}:{actor:t.actor,delivery:"signal"},a=rr(e,this.config);for(let d of[...this._nodes.keys()].sort()){let u=this._nodes.get(d);if(!n.has(u)){n.add(u);try{u.down(e,i)}catch(l){if(l instanceof Z)throw l;s.push(l)}a.length!==0&&this._signalMetaSubtree(u,a,n,i,s)}}}_signalMetaSubtree(e,t,n,s,o){for(let i of Object.keys(e.meta).sort()){let a=e.meta[i];if(!n.has(a)){n.add(a);try{a.down(t,s)}catch(d){if(d instanceof Z)throw d;o.push(d)}this._signalMetaSubtree(a,t,n,s,o)}}}describe(e){if(e?.reactive==="diff")return this._describeReactiveDiff(e);if(e?.reactive===!0)return this._describeReactive(e);let t=qn(e?.actor),n=e?.filter;if(e?.detail!=null&&e?.fields!=null)throw new TypeError("Graph.describe(): pass either `detail` or `fields`, not both. `detail: 'spec'` is the canonical spec projection; use `fields` only when you need a custom subset.");let s=yt(e?.detail,e?.fields),o=e?.detail==="spec",i=s,a=[];this._collectObserveTargets("",a);let d=new Map;for(let[y,w]of a)d.set(w,y);let u=[];{let y=a.map(([,m])=>m),w=new Set(d.values()),k=0;for(;y.length>0;){let m=y.shift();if(m instanceof I)for(let O of m._deps){let x=O.node;if(d.has(x))continue;let A=x.name??"",N=A;if(!N||w.has(N))if(A){let S=2;for(;w.has(`${A}#${S}`);)S++;N=`${A}#${S}`}else for(N=`__internal__/${k++}`;w.has(N);)N=`__internal__/${k++}`;d.set(x,N),w.add(N),u.push([N,x]),y.push(x)}}}let l=[...a,...u],g={};for(let[y,w]of l){if(t!=null&&!w.allowsObserve(t))continue;let k=vt(w,i,o),m=w instanceof I?w._deps.map(N=>d.get(N.node)??N.node.name??""):[],{name:O,...x}=k,A={...x,deps:m};if(!o){let N=this._annotations.get(y);N!=null&&(A.annotation=N)}if(n!=null)if(typeof n=="function"){let N=n;if(!(N.length>=2?N(y,A):N(A)))continue}else{let N=!0;for(let[S,G]of Object.entries(n)){let R=S==="deps_includes"?"depsIncludes":S==="meta_has"?"metaHas":S;if(R==="depsIncludes"){if(!A.deps.includes(String(G))){N=!1;break}continue}if(R==="metaHas"){if(!Object.hasOwn(A.meta??{},String(G))){N=!1;break}continue}if(A[R]!==G){N=!1;break}}if(!N)continue}g[y]=A}let f=new Set(Object.keys(g)),h=[];for(let[y,w]of l)if(w instanceof I)for(let k of w._deps){let m=d.get(k.node);m!=null&&h.push([m,y])}h.sort((y,w)=>y[0]<w[0]?-1:y[0]>w[0]?1:y[1]<w[1]?-1:y[1]>w[1]?1:0);let c=h.map(([y,w])=>({from:y,to:w}));(t!=null||n!=null)&&(c=c.filter(y=>f.has(y.from)&&f.has(y.to)));let _=this._collectSubgraphs(""),p=t!=null||n!=null?_.filter(y=>{let w=`${y}${P}`;return[...f].some(k=>k===y||k.startsWith(w))}):_,T=this,v=e;return{name:this.name,nodes:g,edges:c,subgraphs:p,...this._factory!==void 0?{factory:this._factory}:{},...this._factoryArgs!==void 0?{factoryArgs:this._factoryArgs}:{},expand(y){let w={...v};return Array.isArray(y)?(w.fields=y,w.detail=void 0):(w.detail=y,w.fields=void 0),T.describe(w)}}}_collectSubgraphs(e){let t=[];for(let n of[...this._mounts.keys()].sort()){let s=e===""?n:`${e}${n}`;t.push(s),t.push(...this._mounts.get(n)._collectSubgraphs(`${s}${P}`))}return t}resourceProfile(e){return dn(this,e)}reachable(e,t,n={}){return n.withDetail===!0?kt(this.describe(),e,t,{...n,withDetail:!0}):kt(this.describe(),e,t,n)}explain(e,t,n){return n?.reactive===!0?this._explainReactive(e,t,n):this._explainStatic(ie(e),ie(t),{...n?.maxDepth!==void 0?{maxDepth:cn(n.maxDepth)}:{},...n?.findCycle!==void 0?{findCycle:ln(n.findCycle)}:{}})}_explainStatic(e,t,n){let s=this.describe({detail:"full"}),o=new Map(this._annotations),i=new Map;for(let[a,d]of Object.entries(s.nodes))d.lastMutation!=null&&i.set(a,d.lastMutation);return Zt(s,e,t,{...n?.maxDepth!=null?{maxDepth:n.maxDepth}:{},...n?.findCycle===!0?{findCycle:!0}:{},annotations:o,lastMutations:i})}_describeReactive(e){let t={...e,reactive:!1},n=e.reactiveName??"describe",s=0,o=H(s,{name:`${n}_version`}),i=this.observe({timeline:!0,structured:!0}),a=!1,d=!1,u=()=>{a||d||(a=!0,_e(()=>{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()}),g=[],f=new WeakSet,h=v=>{if(f.has(v)||d)return;f.add(v);let b=v.topology.subscribe(y=>{for(let w of y){if(w[0]!==D)continue;let k=w[1];if(u(),k.kind==="added"&&k.nodeKind==="mount"){let m=v._mounts.get(k.name);m!=null&&h(m)}}});g.push(b);for(let y of v._mounts.keys()){let w=v._mounts.get(y);w!=null&&h(w)}};h(this);let c,_=e.actor;hn(_)&&(c=_.subscribe(v=>{let b=!1,y=!1;for(let w of v){let k=w[0];k===D?b=!0:(k===V||k===$||k===F)&&(y=!0)}b&&u(),y&&(c?.(),c=void 0,u())}));let p;try{p=z([o],()=>this.describe(t),{name:n,describeKind:"derived",meta:{domain:"audit",kind:"describe"},equals:(v,b)=>v===b})}catch(v){l(),c?.();for(let b of g)b();throw i.dispose(),v}let T=te(p);return{node:p,dispose(){d=!0,l(),c?.();for(let v of g)v();g.length=0,i.dispose(),T()}}}_describeReactiveDiff(e){let t={...e,reactive:!1},n=e.reactiveName??"describe-diff",s={name:this.name,nodes:{},edges:[],subgraphs:[]},o=this.describe(t),i=Tt(s,o),a=H(i,{name:n,meta:{domain:"audit",kind:"describe-diff"},equals:(f,h)=>f===h}),d=this._describeReactive({...e,reactiveName:void 0}),u=!1,l=d.node.subscribe(f=>{if(!u)for(let h of f){if(h[0]!==D)continue;let c=h[1],_=Tt(o,c);o=c,_.events.length!==0&&a.emit(_)}}),g=te(a);return{node:a,dispose(){u=!0,l(),d.dispose(),a.down([[F,"describe-diff disposed"]]),g()}}}_explainReactive(e,t,n){let s=0,o=H(s,{name:"explain_version"}),i=this.observe({timeline:!0,structured:!0}),a=!1,d=!1,u=()=>{a||d||(a=!0,_e(()=>{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()}),g=[];e!=null&&fe(e)&&g.push(e),t!=null&&fe(t)&&g.push(t),n?.maxDepth!=null&&fe(n.maxDepth)&&g.push(n.maxDepth),n?.findCycle!=null&&fe(n.findCycle)&&g.push(n.findCycle);let f=()=>{for(let v of g)if(v.cache===void 0)return!1;return!0},h=()=>{let v=ie(e),b=ie(t);return{from:v,to:b,found:!1,reason:"pending",steps:[],text:"(awaiting reactive args)",toJSON:()=>({from:v,to:b,found:!1,reason:"pending",steps:[]})}},c;try{c=z([o],()=>{if(!f())return h();let v=ie(e),b=ie(t),y={...n?.maxDepth!==void 0?{maxDepth:cn(n.maxDepth)}:{},...n?.findCycle!==void 0?{findCycle:ln(n.findCycle)}:{}};return this._explainStatic(v,b,y)},{name:n?.name??"explain",describeKind:"derived",meta:{domain:"audit",kind:"explain_path",from:ie(e),to:ie(t)},equals:(v,b)=>v.found===b.found&&v.reason===b.reason&&v.steps.length===b.steps.length&&sr(v.steps,b.steps)})}catch(v){throw l(),i.dispose(),v}let _=te(c),p=[],T=v=>{let b;return b=v.subscribe(y=>{let w=!1,k=!1;for(let m of y){let O=m[0];O===D?w=!0:(O===V||O===$||O===F)&&(k=!0)}(w||k)&&u(),k&&b&&(b(),b=void 0)}),()=>{b&&(b(),b=void 0)}};for(let v of g)p.push(T(v));return{node:c,dispose(){d=!0,l();for(let v of p)v?.();p.length=0,i.dispose(),_()}}}_pathsMatching(e){let t=Ze(e),n=[];return this._collectObserveTargets("",n),n.map(([s])=>s).filter(s=>t.test(s))}_collectObserveTargets(e,t){for(let n of[...this._mounts.keys()].sort()){let s=e===""?n:`${e}${P}${n}`;this._mounts.get(n)._collectObserveTargets(s,t)}for(let n of[...this._nodes.keys()].sort()){let s=this._nodes.get(n),o=e===""?n:`${e}${P}${n}`;t.push([o,s]),this._appendMetaObserveTargets(o,s,t)}}_appendMetaObserveTargets(e,t,n){for(let s of Object.keys(t.meta).sort()){let o=t.meta[s],i=`${e}${P}${Q}${P}${s}`;n.push([i,o]),this._appendMetaObserveTargets(i,o,n)}}observe(e,t){let n=typeof e=="string",o=fn(n?t:e);if(o.reactive===!0)return this._observeReactive(n?e:void 0,o);let i=o.structured===!0||o.timeline===!0||o.causal===!0||o.derived===!0||o.detail==="minimal"||o.detail==="full"||o.format!=null,a=o.actor;if(n){let l=e,g=this.resolve(l);if(a!=null&&!g.allowsObserve(a))throw new Z({actor:a,action:"observe",nodeName:l});return i?this._buildStructuredObserver([[l,g]],o,"one"):{subscribe(f){return g.subscribe(f)},up(f){try{g.up?.(f)}catch(h){if(h instanceof Z)return;throw h}}}}let d=[];this._collectObserveTargets("",d),d.sort((l,g)=>l[0]<g[0]?-1:l[0]>g[0]?1:0);let u=a==null?d:d.filter(([,l])=>l.allowsObserve(a));return i?this._buildStructuredObserver(u,o,"all"):{subscribe:l=>{let g=u.map(([f,h])=>h.subscribe(c=>{l(f,c)}));return()=>{for(let f of g)f()}},up:(l,g)=>{try{this.resolve(l).up?.(g)}catch(f){if(f instanceof Z)return;throw f}}}}_observeReactive(e,t){let n=t.tiers,s=n!=null?new Set(n):null,o=t.reactiveName??"observe";return We(i=>{let a=[],d=!1,u=!1,l=()=>{if(a.length===0||u)return;let _={events:a.slice(),flushedAt_ns:W()};a.length=0,i.emit(_)},g={...t,reactive:!1,structured:!0,timeline:!0},f=e!=null?this.observe(e,g):this.observe(g),h=_=>{u||(a.push(_),!d&&(d=!0,_e(()=>{d=!1,l()})))};for(let _ of f.events)h(_);let c=f.onEvent(h);return()=>{u=!0,c(),f.dispose()}},{name:o,meta:{domain:"audit",kind:"observe-reactive"}})}_buildStructuredObserver(e,t,n){let s=n==="one"?e[0]?.[0]:void 0,o=i=>{if(n==="one"&&s!=null){let l=this.resolve(s);return this._buildStructuredObserver([[s,l]],i,"one")}let a=[];this._collectObserveTargets("",a),a.sort((l,g)=>l[0]<g[0]?-1:l[0]>g[0]?1:0);let d=i.actor,u=d==null?a:a.filter(([,l])=>l.allowsObserve(d));return this._buildStructuredObserver(u,i,"all")};return this._createObserveResult(e,t,o)}_createObserveResult(e,t,n){let s=t.timeline===!0,o=t.causal===!0,i=t.derived===!0,a=t.detail==="minimal",d=this.config.inspectorEnabled,u=(o||i)&&d,l=t.maxEvents,g=l!=null&&l>0?new Ge(l):null,f=[],h=new Set,c=t.tiers!=null?new Set(t.tiers):null,_={},p=new Set,T=0,v=0,b=0,y=0,w=0,k=0,m=!1,O=!1,x=0,A=new Map,N=new Map,S=new Map,G=E=>{if(!(c!=null&&!c.has(E.type))){g?g.push(E):f.push(E);for(let M of h)M(E)}},R=E=>c==null||c.has(E),oe=()=>s?{timestamp_ns:W(),in_batch:je(),batch_id:x}:{},ne=(E,M)=>{if(!(!u||!(E instanceof I)))return E._setInspectorHook(Y=>{if(Y.kind==="dep_message")A.set(E,Y.depIndex);else if(Y.kind==="run"){let Ee=Y.batchData.map((C,B)=>C!=null&&C.length>0?C.at(-1):Y.prevData[B]);N.set(E,Ee);let J=Y.batchData.map(C=>C!=null?[...C]:void 0);S.set(E,J),i&&G({type:"derived",path:M,dep_values:Ee,dep_batches:J,...oe()})}})},Me=E=>{let M=A.get(E),Y=N.get(E);if(!o||Y==null)return{};let J=(M!=null&&M>=0&&E instanceof I?E._deps[M]:void 0)?.node,C=J?.v,B=S.get(E);return{trigger_dep_index:M,trigger_dep_name:J?.name,...C!=null?{trigger_version:{id:C.id,version:C.version}}:{},dep_values:[...Y],...B!=null?{dep_batches:B}:{}}},Rt=[],Dt=[];for(let[E,M]of e){let Y=ne(M,E);Y&&Rt.push(Y),Dt.push(M.subscribe(Ee=>{x++;for(let J of Ee){let C=J[0],B=oe();if(C===D){_[E]=J[1];let rt=M instanceof I?M.lastMutation?.actor??be:be;G({type:"data",path:E,data:J[1],actor:rt,...B,...Me(M)})}else if(a)C===K?R("dirty")&&T++:C===q?R("resolved")&&v++:C===X?R("invalidate")&&b++:C===ee?R("pause")&&y++:C===re?R("resume")&&w++:C===F?R("teardown")&&k++:C===V&&!p.has(E)?R("complete")&&(m=!0):C===$&&R("error")&&(O=!0,p.add(E));else if(C===K)R("dirty")&&T++,G({type:"dirty",path:E,...B});else if(C===q)R("resolved")&&v++,G({type:"resolved",path:E,...B,...Me(M)});else if(C===X)R("invalidate")&&b++,G({type:"invalidate",path:E,...B});else if(C===ee)R("pause")&&y++,G({type:"pause",path:E,lockId:J[1],...B});else if(C===re)R("resume")&&w++,G({type:"resume",path:E,lockId:J[1],...B});else if(C===V)R("complete")&&!p.has(E)&&(m=!0),G({type:"complete",path:E,...B});else if(C===$){R("error")&&(O=!0,p.add(E));let rt=M instanceof I?M.lastMutation?.actor??be:be;G({type:"error",path:E,data:J[1],actor:rt,...B})}else C===F&&(R("teardown")&&k++,G({type:"teardown",path:E,...B}))}}))}let et=!1,tt=()=>{if(!et){et=!0;for(let E of Dt)E();for(let E of Rt)E();for(let E of Pe)E({value:void 0,done:!0});Pe.length=0}},nt=[],Pe=[];h.add(E=>{let M=Pe.shift();M?M({value:E,done:!1}):nt.push(E)});let Gt={get values(){return _},get dirtyCount(){return T},get resolvedCount(){return v},get invalidateCount(){return b},get pauseCount(){return y},get resumeCount(){return w},get teardownCount(){return k},get events(){return g?g.toArray():[...f]},get anyCompletedCleanly(){return m},get anyErrored(){return O},get completedWithoutErrors(){return m&&!O},onEvent(E){return h.add(E),()=>h.delete(E)},dispose:tt,expand(E){tt();let M={...t};return typeof E=="string"?M.detail=E:Object.assign(M,E),n(fn(M))},[Symbol.asyncIterator](){return{next(){return nt.length>0?Promise.resolve({value:nt.shift(),done:!1}):et?Promise.resolve({value:void 0,done:!0}):new Promise(E=>Pe.push(E))},return(){return tt(),Promise.resolve({value:void 0,done:!0})}}}};return t.format!=null&&this._attachFormatLogger(Gt,t),Gt}_attachFormatLogger(e,t){let n=t.format;if(n==null)return;let s=t.logger??(c=>console.log(c)),o=t.includeTypes?new Set(t.includeTypes):null,i=t.excludeTypes?new Set(t.excludeTypes):null,a=o==null&&i==null?()=>!0:c=>(o==null||o.has(c))&&(i==null||!i.has(c)),d=er(t.theme),u=n==="stage-log"?W():0,l=c=>c==null?"":t.stageLabels?.[c]??c,g=(c,_)=>c.length>_?`${c.slice(0,_-1)}\u2026`:c,f=c=>c.type==="data"||c.type==="error"?g(Ot(c.data),120):"",h=c=>{if(n==="stage-log"){let m=(W()-u)/1e9,O=l(c.path).padEnd(9);if(c.type==="data"){let x=f(c);return`[${m.toFixed(3)}s] ${O} \u2190${x?` ${x}`:""}`}if(c.type==="error"){let x=f(c);return`[${m.toFixed(3)}s] ${O} \u2717${x?` ${x}`:""}`}return c.type==="complete"?`[${m.toFixed(3)}s] ${O} \u25A0 complete`:`[${m.toFixed(3)}s] ${O} ${c.type}`}if(n==="json")try{return JSON.stringify(c)}catch{return JSON.stringify({type:c.type,path:c.path,data:"[unserializable]"})}let _=d[c.type]??"",p=c.path?`${d.path}${c.path}${d.reset} `:"",T=c.type==="data"||c.type==="error",v=c.type==="pause"||c.type==="resume",b=T?` ${Ot(c.data)}`:v?` ${Ot(c.lockId)}`:"",y=c.type==="data"||c.type==="resolved"||c.type==="derived"?c:void 0,w=y?.trigger_dep_name!=null?` <- ${y.trigger_dep_name}`:y?.trigger_dep_index!=null?` <- #${y.trigger_dep_index}`:"",k=c.in_batch?" [batch]":"";return`${p}${_}${c.type.toUpperCase()}${d.reset}${b}${w}${k}`};e.onEvent(c=>{a(c.type)&&s(h(c),c)})}addDisposer(e){return this._disposers.add(e),()=>{this._disposers.delete(e)}}destroy(){un(this._disposers,this.name),this.signal([[F]],{internal:!0}),un(this._storageDisposers,this.name);for(let e of[...this._mounts.values()])e._parent=void 0,e._destroyClearOnly();this._mounts.clear(),this._nodes.clear(),this._parent=void 0,this._destroyed=!0}get destroyed(){return this._destroyed}_destroyClearOnly(){for(let e of[...this._mounts.values()])e._parent=void 0,e._destroyClearOnly();this._mounts.clear(),this._nodes.clear(),this._parent=void 0,this._destroyed=!0}snapshot(e){let{expand:t,...n}=this.describe({detail:"full"}),s={};for(let a of Object.keys(n.nodes).sort()){let{lastMutation:d,guard:u,...l}=n.nodes[a];s[a]=l}let o=[...n.subgraphs].sort(),i={...n,version:1,nodes:s,subgraphs:o};if(e?.format==null)return i;if(e.format==="json-string")return JSON.stringify(i);if(e.format==="bytes"){if(e.codec==null)throw new Error("snapshot({format: 'bytes'}) requires a `codec` name");let a=this.config.lookupCodec(e.codec);if(a==null)throw new Error(`snapshot: codec "${e.codec}" is not registered on this graph's config. Call config.registerCodec(...) before creating nodes.`);return It(a,a.encode(i))}throw new Error(`snapshot: unknown format "${String(e.format)}"`)}static decode(e,t){let n=t?.config??Te,{codec:s,codecVersion:o,payload:i}=Lt(e,n);return s.decode(i,o)}restore(e,t){if(pn(e),e.name!==this.name)throw new Error(`Graph "${this.name}": restore snapshot name "${e.name}" does not match this graph`);let n=t?.only==null?null:(Array.isArray(t.only)?t.only:[t.only]).map(o=>Ze(o)),s=t?.includeProducers===!0;for(let o of Object.keys(e.nodes).sort()){if(n!==null&&!n.some(a=>a.test(o)))continue;let i=e.nodes[o];if(i!==void 0){if(!("value"in i)||i.value===void 0){"value"in i&&i.value===void 0&&t?.onError?.(o,new Error(`restore: slice.value is undefined for "${o}" (undefined is the global SENTINEL; not valid DATA)`));continue}if(!(i.type==="derived"||i.type==="effect")&&!(i.type==="producer"&&!s)){if(i.v!=null){let d=this.tryResolve(o)?.v;if(d!=null&&d.id===i.v.id&&d.version===i.v.version)continue}try{this.set(o,i.value)}catch(a){t?.onError?.(o,a)}}}}}static fromSnapshot(e,t){pn(e);let n=typeof t=="function"?t:t?.build,s=typeof t=="function"?void 0:t?.factories,o=new r(e.name);if(n)return n(o),o.restore(e),o;for(let h of[...e.subgraphs].sort((c,_)=>{let p=c.split(P).length,T=_.split(P).length;return p!==T?p-T:c<_?-1:c>_?1:0})){let c=h.split(P),_=o;for(let p of c)_._mounts.has(p)||_.mount(p,new r(p)),_=_._mounts.get(p)}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(P),_=c.pop();if(_==null||_.length===0)throw new Error(`invalid snapshot path "${h}"`);let p=o;for(let T of c){let v=p._mounts.get(T);if(!v)throw new Error(`unknown mount "${T}" in path "${h}"`);p=v}return[p,_]},u=Object.entries(e.nodes).filter(([h])=>!h.includes(`${P}${Q}${P}`)).sort((h,c)=>h[0]<c[0]?-1:h[0]>c[0]?1:0),l=new Map(u),g=new Map,f=!0;for(;l.size>0&&f;){f=!1;for(let[h,c]of[...l.entries()]){let _=c?.deps??[];if(!_.every(w=>g.has(w)))continue;let[p,T]=d(h),v={...c?.meta??{}},b=a(h),y;if(c?.type==="state")y=H(c.value,{meta:v});else{if(b==null)continue;y=b(T,{path:h,type:c.type,value:c.value,meta:v,deps:_,resolvedDeps:_.map(w=>g.get(w))})}p.add(y,{name:T}),g.set(h,y),l.delete(h),f=!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,t={}){let n=e.map(u=>({tier:u,debounceMs:Math.max(0,u.debounceMs??0),compactEvery:Math.max(1,u.compactEvery??10),timer:void 0,seq:0,lastSnapshot:void 0,lastFingerprint:"",disposed:!1,savePending:void 0}));t.autoRestore===!0&&this._cascadeRestore(e,t.onError);let s=(u,l)=>{if(u.disposed)return;let g=Yn(l.nodes);if(u.lastSnapshot!=null&&g!==""&&g===u.lastFingerprint)return;let f=u.seq+1,h=he(),p=u.lastSnapshot==null||f%u.compactEvery===0?{name:this.name,mode:"full",snapshot:l,seq:f,timestamp_ns:h,format_version:pe}:{name:this.name,mode:"diff",diff:mn(u.lastSnapshot,l),seq:f,timestamp_ns:h,format_version:pe};if(u.tier.filter&&!u.tier.filter(p))return;let T;try{T=u.tier.save(p)}catch(v){t.onError?.(v,u.tier);return}if(T&&typeof T.then=="function"){let y=(u.savePending??Promise.resolve()).then(()=>T,()=>T).then(()=>{u.disposed||(u.seq=f,u.lastSnapshot=l,u.lastFingerprint=g)},w=>{t.onError?.(w,u.tier)});u.savePending=y.finally(()=>{u.savePending===y&&(u.savePending=void 0)})}else u.seq=f,u.lastSnapshot=l,u.lastFingerprint=g},o=(u,l)=>{try{s(u,l)}catch(g){t.onError?.(g,u.tier)}},i=(u,l)=>{if(!l.some(c=>{let _=this.config.messageTier(c[0]);return _>=3&&_<5}))return;if(t.filter){let c=this.tryResolve(u);if(c==null)return;let _=vt(c,yt("standard"));if(!t.filter(u,_))return}let f,h=()=>(f==null&&(f=this.snapshot()),f);for(let c of n)c.disposed||(c.debounceMs===0?o(c,h()):(c.timer==null&&(c.timer=new Xe),c.timer.start(c.debounceMs,()=>{c.disposed||o(c,this.snapshot())})))},a;if(t.paths!=null){let l=(typeof t.paths=="string"?this._pathsMatching(t.paths):t.paths).map(g=>{let f=this.tryResolve(g);return f==null?()=>{}:f.subscribe(h=>i(g,h))});a=()=>{for(let g of l)g()}}else a=this.observe().subscribe((u,l)=>i(u,l));let d=()=>{a();for(let u of n)u.disposed=!0,u.timer?.cancel();this._storageDisposers.delete(d)};return this._storageDisposers.add(d),{dispose:d}}async _cascadeRestore(e,t){for(let n of e){let s;try{s=await n.load?.()}catch(i){t?.(i,n);continue}if(s==null||typeof s!="object"||Array.isArray(s))continue;let o=s;try{if(o.mode==="full"&&o.snapshot!=null)return this.restore(o.snapshot),!0;if(o.version===pe&&o.nodes!=null)return this.restore(o),!0}catch(i){t?.(i,n)}}return!1}static async fromStorage(e,t,n){for(let s of t){let o;try{o=await s.load?.()}catch(d){n?.onError?.(d,s);continue}if(o==null||typeof o!="object"||Array.isArray(o))continue;let i=o,a=i.mode==="full"&&i.snapshot!=null?i.snapshot:i.version===pe&&i.nodes!=null?i:void 0;if(a!=null)try{return r.fromSnapshot(a,n)}catch(d){n?.onError?.(d,s)}}throw new Error(`Graph.fromStorage: no tier held a restorable record for "${e}" across ${t.length} tier(s)`)}_annotations=new Map;_traceRing;trace(e,t,n){if(e!=null&&t!=null){if(this.tryResolve(e)==null)return;if(this._annotations.set(e,t),this.config.inspectorEnabled){let s={path:e,annotation:t,timestamp_ns:W(),...n?.actor!=null?{actor:n.actor}:{}};this._traceRing.push(s)}return}return e!=null?this.config.inspectorEnabled?this._annotations.get(e):void 0:this.config.inspectorEnabled?this._traceRing.toArray():[]}annotation(e){return this._annotations.get(e)}clearTrace(){this._annotations.clear(),this._traceRing.clear()}pruneTrace(e){let t=this._traceRing.toArray().filter(s=>!e(s)),n=this._traceRing.size-t.length;this._traceRing.clear();for(let s of t)this._traceRing.push(s);return n}static diff(e,t){let n=new Set(Object.keys(e.nodes)),s=new Set(Object.keys(t.nodes)),o=[...s].filter(v=>!n.has(v)).sort(),i=[...n].filter(v=>!s.has(v)).sort(),a=[],d=[];for(let v of n){if(!s.has(v))continue;let b=e.nodes[v],y=t.nodes[v],w=b.v,k=y.v;w!=null&&k!=null&&w.id===k.id&&w.version!==k.version&&d.push({path:v,id:w.id,from:w.version,to:k.version});let m=w!=null&&k!=null&&w.id===k.id&&w.version===k.version;for(let O of["type","status","sentinel"]){let x=b[O],A=y[O];x!==A&&a.push({path:v,field:O,from:x,to:A})}if(!m)for(let O of["value","meta"]){let x=b[O],A=y[O];Jn(x,A)||a.push({path:v,field:O,from:x,to:A})}}let u=v=>`${v.from} ${v.to}`,l=new Set(e.edges.map(u)),g=new Set(t.edges.map(u)),f=t.edges.filter(v=>!l.has(u(v))),h=e.edges.filter(v=>!g.has(u(v))),c=new Set(e.subgraphs),_=new Set(t.subgraphs),p=[..._].filter(v=>!c.has(v)).sort(),T=[...c].filter(v=>!_.has(v)).sort();return{nodesAdded:o,nodesRemoved:i,nodesChanged:a,versionChanges:d,edgesAdded:f,edgesRemoved:h,subgraphsAdded:p,subgraphsRemoved:T}}};function mn(r,e){let t=U.diff(r,e),n={};for(let s of t.nodesAdded){let o=e.nodes[s];o!=null&&(n[s]=o)}return{...t,nodesAddedFull:n}}function kt(r,e,t,n={}){let s={paths:[],depths:new Map,truncated:!1};if(!e)return n.withDetail?s:[];if(!n.both&&t!=="upstream"&&t!=="downstream")throw new Error('reachable: direction must be "upstream" or "downstream"');let o=n.maxDepth;if(o!=null&&(!Number.isInteger(o)||o<0))throw new Error("reachable: maxDepth must be an integer >= 0");if(o===0)return n.withDetail?s:[];let i=new Map,a=new Map,d=new Map,u=new Map,l=new Set;for(let[b,y]of Object.entries(r.nodes)){if(!b)continue;l.add(b);let w=y.deps??[];i.set(b,w);for(let k of w)k&&(l.add(k),a.has(k)||a.set(k,new Set),a.get(k).add(b))}for(let b of r.edges){if(b==null||typeof b!="object")continue;let y=typeof b.from=="string"?b.from:"",w=typeof b.to=="string"?b.to:"";!y||!w||(l.add(y),l.add(w),u.has(y)||u.set(y,new Set),u.get(y).add(w),d.has(w)||d.set(w,new Set),d.get(w).add(y))}if(!l.has(e))return n.withDetail?s:[];let g=n.both===!0,f=b=>{if(g){let m=i.get(b)??[],O=d.get(b),x=a.get(b),A=u.get(b),N=[...m];return O&&N.push(...O),x&&N.push(...x),A&&N.push(...A),N}if(t==="upstream"){let m=i.get(b)??[],O=d.get(b);return O?[...m,...O]:m}let y=a.get(b),w=u.get(b),k=y?[...y]:[];return w&&k.push(...w),k},h=new Set([e]),c=new Map,_=[{path:e,depth:0}],p=0,T=!1;for(;p<_.length;){let b=_[p++];if(o!=null&&b.depth>=o){f(b.path).length>0&&(T=!0);continue}for(let y of f(b.path))!y||h.has(y)||(h.add(y),c.set(y,b.depth+1),_.push({path:y,depth:b.depth+1}))}let v=[...c.keys()].sort((b,y)=>b<y?-1:b>y?1:0);return n.withDetail?{paths:v,depths:c,truncated:T}:v}function sr(r,e){if(r.length!==e.length)return!1;for(let t=0;t<r.length;t++){let n=r[t],s=e[t];if(n.path!==s.path||n.type!==s.type||n.status!==s.status||n.hop!==s.hop||n.dep_index!==s.dep_index||n.annotation!==s.annotation||n.value!==s.value||n.lastMutation!==s.lastMutation)return!1;let o=n.v,i=s.v;if(o!==i&&(o==null||i==null||o.id!==i.id||o.version!==i.version))return!1}return!0}se();function xt(r,e){let t=new Map,n=(s,o)=>{if(t.has(s))return;let i={off:()=>{},prefix:o};t.set(s,i);let a=s.topology.subscribe(d=>{for(let u of d){if(u[0]!==D)continue;let l=u[1];if(e(l,s,o),l.kind==="added"&&l.nodeKind==="mount"){let g=s._mounts.get(l.name);if(g instanceof U){let f=`${o}${l.name}::`;n(g,f)}}else if(l.kind==="removed"&&l.nodeKind==="mount"){let g=`${o}${l.name}::`;for(let[f,h]of Array.from(t.entries()))f!==r&&h.prefix.startsWith(g)&&(h.off(),t.delete(f))}}});i.off=a;for(let[d,u]of s._mounts)if(u instanceof U){let l=`${o}${d}::`;n(u,l)}};return n(r,""),()=>{for(let s of t.values())s.off();t.clear()}}Re();ge();we();se();_t();le();Ne();Ke();Re();se();le();Ne();var Et=class{_version=0;_maxSize;_buf;_head=0;_size=0;constructor(e,t){if(t!==void 0&&t<1)throw new RangeError("maxSize must be >= 1");if(this._maxSize=t,t!==void 0){if(this._buf=new Array(t),e&&e.length>0){let n=Math.min(e.length,t),s=e.length-n;for(let o=0;o<n;o++)this._buf[o]=e[s+o];this._size=n}}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 t=e>=0?e:this._size+e;if(!(t<0||t>=this._size))return this._maxSize!==void 0?this._buf[(this._head+t)%this._maxSize]:this._buf[t]}append(e){this._rawAppend(e),this._version+=1}appendMany(e){if(e.length===0)return;let t=this._maxSize!==void 0&&e.length>this._maxSize?e.length-this._maxSize:0;for(let n=t;n<e.length;n++)this._rawAppend(e[n]);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 t=0;t<e;t++)this._buf[(this._head+t)%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 t=Math.min(e,this._size);if(this._maxSize===void 0)this._buf.splice(0,t);else{for(let n=0;n<t;n++)this._buf[(this._head+n)%this._maxSize]=void 0;this._head=(this._head+t)%this._maxSize}return this._size-=t,this._version+=1,t}slice(e,t){if(!Number.isInteger(e)||e<0)throw new RangeError(`slice: start must be a non-negative integer (got ${e})`);if(t!==void 0&&(!Number.isInteger(t)||t<0))throw new RangeError(`slice: stop must be a non-negative integer or undefined (got ${t})`);let n=t===void 0?this._size:Math.min(Math.max(t,0),this._size),s=Math.min(e,this._size);if(s>=n)return[];let o=n-s;if(this._maxSize===void 0)return this._buf.slice(s,n);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 t=Math.min(e,this._size);return this.slice(this._size-t,this._size)}toArray(){if(this._maxSize===void 0)return[...this._buf];let e=new Array(this._size);for(let t=0;t<this._size;t++)e[t]=this._buf[(this._head+t)%this._maxSize];return e}snapshot(){return this.toArray()}restore(e){if(this._maxSize===void 0){this._buf.length=0;for(let t=0;t<e.length;t++)this._buf.push(e[t]);this._size=this._buf.length}else{let t=this._maxSize;for(let o=0;o<t;o++)this._buf[o]=void 0;this._head=0;let n=Math.min(e.length,t),s=e.length-n;for(let o=0;o<n;o++)this._buf[o]=e[s+o];this._size=n}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 Ce(r){return r.subscribe(()=>{})}var or=64;function bn(r,e={}){let{name:t,maxSize:n,versioning:s,guard:o,backend:i}=e,a=i??new Et(r,n),d=H(a.toArray(),{name:t,describeKind:"state",equals:(m,O)=>m===O,...s!=null?{versioning:s}:{},...o!=null?{guard:o}:{}});function u(){let m=a.toArray();ce(()=>{d.down([[K]],{internal:!0}),d.down([[D,m]],{internal:!0})})}let l=new Map,g=new Map,f=new Map;function h(m,O){return`${m}:${O===void 0?"END":O}`}function c(m){if(m.size<or)return;let O=m.keys().next();if(O.done)return;let x=m.get(O.value);x!==void 0&&x.dispose(),m.delete(O.value)}function _(m){let O=a.version;try{return m()}finally{a.version!==O&&u()}}function p(m){if(!Number.isInteger(m)||m<0)throw new RangeError(`tail: n must be a non-negative integer (got ${m})`);let O=l.get(m);if(O!==void 0)return l.delete(m),l.set(m,O),O.node;c(l);let x=z([d],([N])=>{let S=N;return m===0||S.length===0?[]:S.slice(Math.max(0,S.length-m))},{initial:a.tail(m),describeKind:"derived"}),A=Ce(x);return l.set(m,{node:x,dispose:A}),x}function T(m,O){if(!Number.isInteger(m)||m<0)throw new RangeError(`slice: start must be a non-negative integer (got ${m})`);if(O!==void 0&&(!Number.isInteger(O)||O<0))throw new RangeError(`slice: stop must be a non-negative integer or undefined (got ${O})`);let x=h(m,O),A=g.get(x);if(A!==void 0)return g.delete(x),g.set(x,A),A.node;c(g);let N=z([d],([G])=>{let R=G;return O===void 0?R.slice(m):R.slice(m,O)},{initial:a.slice(m,O),describeKind:"derived"}),S=Ce(N);return g.set(x,{node:N,dispose:S}),N}function v(m){let O=f.get(m);if(O!==void 0)return O.node;let x=z([d,m],([N,S])=>{let G=N,R=Math.max(0,Math.trunc(S??0));return G.slice(R)},{initial:[],describeKind:"derived"}),A=Ce(x);return f.set(m,{node:x,dispose:A}),x}let b,y;function w(){b===void 0&&(b=Oe([d],(m,O,x)=>{let A=m[0],S=A!=null&&A.length>0?A.at(-1):x.prevData[0];if(S==null||S.length===0){O.down([[q]]);return}O.emit(S[S.length-1])},{name:t!=null?`${t}::lastValue`:"lastValue",describeKind:"derived",initial:a.size===0?void 0:a.at(a.size-1)}),y=z([d],([m])=>m.length>0,{name:t!=null?`${t}::hasLatest`:"hasLatest",describeKind:"derived",initial:a.size>0}),Ce(b),Ce(y))}let k={entries:d,get size(){return a.size},at(m){return a.at(m)},append(m){_(()=>a.append(m))},appendMany(m){m.length!==0&&_(()=>a.appendMany(m))},clear(){_(()=>a.clear())},trimHead(m){_(()=>a.trimHead(m))},withLatest(){return w(),d},get lastValue(){return w(),b},get hasLatest(){return w(),y},view(m){switch(m.kind){case"tail":return p(m.n);case"slice":return T(m.start,m.stop);case"fromCursor":return v(m.cursor)}},attach(m){let O=m.subscribe(x=>{for(let A of x)A[0]===D&&k.append(A[1])});return()=>O()},attachStorage(m){if(m.length===0)return()=>{};let O=new Map;for(let A of m)O.set(A,a.size);(async()=>{for(let A of m)if(typeof A.loadEntries=="function")try{let N=await Promise.resolve(A.loadEntries());N.entries.length>0&&a.size===0&&(a.restore(N.entries),O.set(A,N.entries.length),u());break}catch{}})();let x=d.subscribe(A=>{for(let N of A){if(N[0]!==D)continue;let S=N[1];for(let G of m){let R=O.get(G)??0;if(S.length<R){try{let ne=G.appendEntries(S);ne instanceof Promise&&ne.catch(()=>{})}catch{}O.set(G,S.length);continue}if(S.length===R)continue;let oe=S.slice(R);O.set(G,S.length);try{let ne=G.appendEntries(oe);ne instanceof Promise&&ne.catch(()=>{})}catch{}}}});return()=>x()},disposeAllViews(){for(let m of l.values())m.dispose();l.clear();for(let m of g.values())m.dispose();g.clear();for(let m of f.values())m.dispose();f.clear()},dispose(){for(let m of l.values())m.dispose();l.clear();for(let m of g.values())m.dispose();g.clear();for(let m of f.values())m.dispose();f.clear()}};return k}De();ze();we();se();Ne();Ke();De();function yn(r,e){return ke("messaging",r,e)}var ir=1024,xe=class extends U{_log;events;latest;hasLatest;constructor(e,t={}){super(e,t.graph),this._log=bn([],{name:"events",maxSize:t.retainedLimit??ir}),this._log.withLatest(),this.events=this._log.entries,this.add(this.events,{name:"events"}),this.latest=z([this.events],([n])=>{let s=n;return s.length===0?null:s[s.length-1]},{name:"latest",describeKind:"derived",meta:yn("topic_latest")}),this.add(this.latest,{name:"latest"}),this.addDisposer(te(this.latest)),this.hasLatest=z([this.events],([n])=>n.length>0,{name:"hasLatest",describeKind:"derived",meta:yn("topic_has_latest")}),this.add(this.hasLatest,{name:"hasLatest"}),this.addDisposer(te(this.hasLatest)),this.addDisposer(()=>{this.events.down([[V]])}),this.addDisposer(()=>this._log.disposeAllViews())}publish(e){if(e===void 0)throw new TypeError(`TopicGraph "${this.name}": publish(undefined) is not allowed (spec \xA75.12 SENTINEL).`);this._log.append(e)}attachEventStorage(e){return this._log.attachStorage(e)}retained(){return this.events.cache}get _logBundle(){return this._log}};function ar(r,e){return ke("audit",r,e)}var At=class extends U{policies;violations;violationCount;_target;_mode;_currentGuard;constructor(e,t,n){super(n.name??`${e.name}_policy`,n.graph),this._target=e,this._mode=n.mode??"audit";let s=vn(t)?t:H(t,{name:"policies"});this.policies=s,this.add(this.policies,{name:"policies"}),this.violations=new xe("violations",{retainedLimit:n.violationsLimit??1e3}),this.mount("violations",this.violations),this.violationCount=z([this.violations.events],([c])=>c.length,{name:"violationCount",describeKind:"derived",meta:ar("policy_violation_count")}),this.add(this.violationCount,{name:"violationCount"}),this.addDisposer(te(this.violationCount));let i=s.cache??[];this._currentGuard=ct(i);let a=s.subscribe(c=>{for(let _ of c)_[0]===D&&(i=_[1]??[],this._currentGuard=ct(i))});this.addDisposer(a);let d=n.paths,u=vn(d)?d:void 0,l=d!=null,f=u!=null?u.cache??[]:l?[...d]:void 0,h=f??wn(e);if(this._mode!=="enforce"&&u!=null){let c=u.subscribe(_=>{for(let p of _)p[0]===D&&(f=p[1]??[])});this.addDisposer(c)}if(this._mode==="enforce"){let c=new Map,_=p=>{if(c.has(p))return;let T=_n(e,p);if(!(T instanceof I))return;let v=(b,y)=>{let w=this._currentGuard(b,y);return w||this._publishViolation(b,y,p,"blocked"),w};c.set(p,T._pushGuard(v))};for(let p of h)_(p);if(u!=null){let p=u.subscribe(T=>{for(let v of T){if(v[0]!==D)continue;let b=v[1]??[],y=new Set(b),w=new Set(f??[]);ce(()=>{for(let k of w){if(y.has(k))continue;let m=c.get(k);m!=null&&(m(),c.delete(k))}for(let k of y)w.has(k)||_(k);f=b})}});this.addDisposer(p)}if(l){let p=e.topology.subscribe(T=>{for(let v of T){if(v[0]!==D)continue;let b=v[1];if(b.kind!=="removed"||b.nodeKind!=="node")continue;let y=c.get(b.name);y!=null&&(y(),c.delete(b.name))}});this.addDisposer(p)}else{let p=xt(e,(T,v,b)=>{if(T.kind==="added")if(T.nodeKind==="node")_(`${b}${T.name}`);else{let y=v._mounts.get(T.name);if(!(y instanceof U))return;let w=`${b}${T.name}::`,k=wn(y);for(let m of k)_(m===""?`${b}${T.name}`:`${w}${m}`)}else if(T.kind==="removed")if(T.nodeKind==="node"){let y=`${b}${T.name}`,w=c.get(y);w!=null&&(w(),c.delete(y))}else{let y=`${b}${T.name}`,w=`${y}::`;for(let[k,m]of c)(k===y||k.startsWith(w))&&(m(),c.delete(k))}});this.addDisposer(p)}this.addDisposer(()=>{for(let p of c.values())p();c.clear()})}else{let c=e.observe({timeline:!0,structured:!0}),_=c.onEvent(p=>{if(p.type!=="data"&&p.type!=="error")return;let T=p.path??"";if(!T||f!=null&&!f.includes(T))return;let v=p.actor??_n(e,T)?.lastMutation?.actor;if(v==null)return;let b="write";this._currentGuard(v,b)||this._publishViolation(v,b,T,"observed")});this.addDisposer(()=>{_(),c.dispose()})}}_publishViolation(e,t,n,s){this.violations.publish({timestamp_ns:W(),wall_clock_ns:he(),path:n,actor:e,action:t,mode:this._mode,result:s})}all(){return this.violations.retained()}get mode(){return this._mode}get target(){return this._target}};function Tn(r,e,t={}){let n=new At(r,e,t);return n.tagFactory("policyGate",nn(t)),n}function vn(r){return typeof r=="object"&&r!==null&&"subscribe"in r}function _n(r,e){try{return r.node(e)}catch{return}}function wn(r){let e=r.describe({detail:"minimal"});return Object.keys(e.nodes)}function St(r){return typeof r=="object"&&r!==null&&"subscribe"in r&&"down"in r}function dr(r){return ke("guarded",r)}var Qe=class extends U{enforcer;violations;lints;scope;scopedDescribe;_target;_actorNode;_mode;_firedLintKinds=new Set;constructor(e,t){super(t.name??`${e.name}_guarded`,t.graph),this._target=e,this._mode=t.mode??"enforce";let n=t.policies,s=St(n);if(!s&&this._mode==="enforce"&&n.length===0)throw new RangeError('guardedExecution: empty `policies` in `mode: "enforce"` denies every action. Pass at least `{ effect: "allow", action: "*" }` and layer deny rules on top.');this.lints=new xe("lints",{retainedLimit:t.lintsLimit??64}),this.mount("lints",this.lints);let o=t.actor;o==null?this._actorNode=H(null,{name:"actor"}):St(o)?this._actorNode=z([o],([d])=>d??null,{name:"actor",initial:null}):this._actorNode=H(o,{name:"actor"});let i={mode:this._mode,name:"enforcer"};if(t.violationsLimit!=null&&(i.violationsLimit=t.violationsLimit),this.enforcer=Tn(e,t.policies,i),this.violations=this.enforcer.violations,this.mount("enforcer",this.enforcer),s&&this._mode==="enforce"){let d=n,u=d.cache;u!=null&&u.length===0&&this._fireLint("empty-policies",'`policies` Node cached an empty array in `mode: "enforce"` \u2014 every action will be denied. Add at least one allow rule.');let l=d.subscribe(g=>{for(let f of g){if(f[0]!==D)continue;let h=f[1];(h==null||h.length===0)&&this._fireLint("empty-policies",'`policies` Node emitted an empty array in `mode: "enforce"` \u2014 every action will be denied. Add at least one allow rule.')}});this.addDisposer(l)}if(this._mode==="audit"){let d=e.describe({detail:"full"});Object.values(d.nodes).some(l=>l.guard!=null)||this._fireLint("audit-no-effect",'`mode: "audit"` + target has no per-node guards \u2014 `scopedDescribeNode` filters by per-node guards only, so policy rules will not affect describe() visibility. Policies still populate the `violations` topic on writes.')}o==null&&this._fireLint("no-actor","no actor configured \u2014 `wrapper.scopedDescribe` and `scopedDescribeNode()` will return an unscoped describe (full visibility) unless a per-call actor is supplied."),this.scope=z([this._actorNode,this.enforcer.policies],([d,u])=>({actor:d??null,mode:this._mode,policiesCount:u.length}),{name:"scope",describeKind:"derived",meta:dr("scope")}),this.add(this.scope,{name:"scope"}),this.addDisposer(te(this.scope));let a=e.describe({reactive:!0,actor:this._actorNode,reactiveName:"scopedDescribe"});this.scopedDescribe=a.node,this.add(this.scopedDescribe,{name:"scopedDescribe"}),this.addDisposer(a.dispose)}_fireLint(e,t){this._firedLintKinds.has(e)||(this._firedLintKinds.add(e),this.lints.publish({kind:e,message:t,timestamp_ns:W()}))}scopedDescribeNode(e,t){let n=e==null?this._actorNode:St(e)?e:H(e,{name:"actor_override"}),s=this._target.describe({reactive:!0,actor:n,...t??{}});return this.addDisposer(s.dispose),{node:s.node,dispose:s.dispose}}get target(){return this._target}};function ur(r,e){return new Qe(r,e)}0&&(module.exports={GuardedExecutionGraph,guardedExecution});
|
|
@@ -1,8 +1,8 @@
|
|
|
1
1
|
import '../../node-BYInONRr.cjs';
|
|
2
|
-
export { D as DescribeFilter } from '../../graph-
|
|
3
|
-
import '../../index-
|
|
4
|
-
import '../../index-
|
|
5
|
-
export { G as GuardedExecutionGraph, a as GuardedExecutionOptions, g as guardedExecution } from '../../index-
|
|
2
|
+
export { D as DescribeFilter } from '../../graph-E6likq7w.cjs';
|
|
3
|
+
import '../../index-BmSQLAZo.cjs';
|
|
4
|
+
import '../../index-Cnr1WrlX.cjs';
|
|
5
|
+
export { G as GuardedExecutionGraph, a as GuardedExecutionLint, b as GuardedExecutionOptions, c as GuardedScope, g as guardedExecution } from '../../index-CuPUehFa.cjs';
|
|
6
6
|
import '../../meta-Ct9nqQS5.cjs';
|
|
7
7
|
import '../../extra/storage-core.cjs';
|
|
8
8
|
import '../../extra/storage-tiers.cjs';
|
|
@@ -1,8 +1,8 @@
|
|
|
1
1
|
import '../../node-BYInONRr.js';
|
|
2
|
-
export { D as DescribeFilter } from '../../graph-
|
|
3
|
-
import '../../index-
|
|
4
|
-
import '../../index-
|
|
5
|
-
export { G as GuardedExecutionGraph, a as GuardedExecutionOptions, g as guardedExecution } from '../../index-
|
|
2
|
+
export { D as DescribeFilter } from '../../graph-BkIkog4h.js';
|
|
3
|
+
import '../../index-Ck35nA-T.js';
|
|
4
|
+
import '../../index-40ZT4MHj.js';
|
|
5
|
+
export { G as GuardedExecutionGraph, a as GuardedExecutionLint, b as GuardedExecutionOptions, c as GuardedScope, g as guardedExecution } from '../../index-8s-Qm-gz.js';
|
|
6
6
|
import '../../meta-D8OyedKp.js';
|
|
7
7
|
import '../../extra/storage-core.js';
|
|
8
8
|
import '../../extra/storage-tiers.js';
|
|
@@ -1 +1 @@
|
|
|
1
|
-
import{a,b}from"../../chunk-
|
|
1
|
+
import{a,b}from"../../chunk-2W553JJC.js";import"../../chunk-EC2WNSZ7.js";import"../../chunk-URJ2VFNC.js";import"../../chunk-4I45FVQS.js";import"../../chunk-5TEFC2ZX.js";import"../../chunk-3G5U5QNE.js";import"../../chunk-C72GO4IZ.js";import"../../chunk-L6NSJVJZ.js";import"../../chunk-TT4C7DXW.js";import"../../chunk-POXANAJ6.js";import"../../chunk-SGS4OJGS.js";import"../../chunk-ESMPEKEV.js";import"../../chunk-L77I47VU.js";import"../../chunk-35JTVPOX.js";import"../../chunk-LYCLF26R.js";import"../../chunk-CK2E7BTU.js";import"../../chunk-QYADASLV.js";export{a as GuardedExecutionGraph,b as guardedExecution};
|