@graphrefly/graphrefly 0.30.0 → 0.31.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.
Files changed (178) hide show
  1. package/dist/{cascading-dNCtjW8j.d.cts → cascading-BfQmSmjU.d.cts} +21 -2
  2. package/dist/{cascading-BszPheHD.d.ts → cascading-D3sapjue.d.ts} +21 -2
  3. package/dist/{chunk-T5SHIKJD.js → chunk-3JRKP4BH.js} +1 -1
  4. package/dist/{chunk-GJR3P6JG.js → chunk-3Q2WXM6X.js} +1 -1
  5. package/dist/chunk-4KAUNEKV.js +3 -0
  6. package/dist/{chunk-SLMYTGTU.js → chunk-4UUDNFYG.js} +1 -1
  7. package/dist/chunk-4VXL3UZK.js +1 -0
  8. package/dist/{chunk-AV3PIDFQ.js → chunk-4ZPO2EL5.js} +1 -1
  9. package/dist/{chunk-VWPRPPKR.js → chunk-5LJAQTSS.js} +1 -1
  10. package/dist/{chunk-W4TSQ6RJ.js → chunk-7AJKUA36.js} +1 -1
  11. package/dist/{chunk-RD52SNH2.js → chunk-7EJTWGKW.js} +1 -1
  12. package/dist/{chunk-GNCBXARM.js → chunk-7EQPXQ7H.js} +1 -1
  13. package/dist/chunk-7QMVU3IX.js +1 -0
  14. package/dist/{chunk-BA5URFYW.js → chunk-A4JT4SAD.js} +1 -1
  15. package/dist/chunk-ASDKRNOJ.js +60 -0
  16. package/dist/{chunk-Y32RJO24.js → chunk-CZVYLXFK.js} +1 -1
  17. package/dist/{chunk-567NWZ3T.js → chunk-DWIAG62L.js} +1 -1
  18. package/dist/{chunk-33FA6V4B.js → chunk-EBQ6FXKW.js} +1 -1
  19. package/dist/chunk-FTA5TB2A.js +1 -0
  20. package/dist/{chunk-P7JXGKDO.js → chunk-GF5T7PGC.js} +1 -1
  21. package/dist/{chunk-WANIEEKV.js → chunk-I4U3TPK2.js} +1 -1
  22. package/dist/{chunk-KA6MMXIY.js → chunk-JMGGCSIC.js} +1 -1
  23. package/dist/chunk-JXRZXP3N.js +1 -0
  24. package/dist/{chunk-5Z4HDCO6.js → chunk-K54OKWNY.js} +1 -1
  25. package/dist/{chunk-DDPYNMGG.js → chunk-KN4Q5MQO.js} +1 -1
  26. package/dist/chunk-LWGLBCMU.js +1 -0
  27. package/dist/{chunk-TWMEGG45.js → chunk-N2KKISCE.js} +1 -1
  28. package/dist/{chunk-4OFIQ66T.js → chunk-OKQUPJRY.js} +1 -1
  29. package/dist/chunk-PNTBXOQ6.js +5 -0
  30. package/dist/chunk-PSQNYY72.js +7 -0
  31. package/dist/{chunk-XHVB6G6M.js → chunk-PZP4MEXK.js} +1 -1
  32. package/dist/{chunk-7TDOES3L.js → chunk-Q2SY7M7K.js} +1 -1
  33. package/dist/{chunk-OL33ZI6R.js → chunk-RWGJQQLT.js} +1 -1
  34. package/dist/chunk-SGS4OJGS.js +1 -0
  35. package/dist/chunk-UMH3HSP7.js +1 -0
  36. package/dist/{chunk-BZP5T4X6.js → chunk-W6FQIFVE.js} +1 -1
  37. package/dist/{chunk-SHYH5SXV.js → chunk-WLPVGXQ6.js} +1 -1
  38. package/dist/chunk-WQ7I7JVU.js +1 -0
  39. package/dist/{chunk-XQAXYVXX.js → chunk-WYJTXYWX.js} +1 -1
  40. package/dist/{chunk-3NEPQO2E.js → chunk-X2VHDT26.js} +1 -1
  41. package/dist/{chunk-GLSM33ZM.js → chunk-XEFAMCEA.js} +1 -1
  42. package/dist/{chunk-AUY2YKCO.js → chunk-XRSHMHEG.js} +1 -1
  43. package/dist/chunk-Y26UN6J5.js +18 -0
  44. package/dist/{chunk-BKPLTBL5.js → chunk-YQJPYEAL.js} +1 -1
  45. package/dist/{chunk-73Z3W2RN.js → chunk-YZ6VYLFD.js} +1 -1
  46. package/dist/{chunk-4JJCCD5S.js → chunk-YZKGGMPT.js} +1 -1
  47. package/dist/chunk-Z3UWIJ3A.js +1 -0
  48. package/dist/{chunk-Y36UZ5VS.js → chunk-ZM7C2FUM.js} +1 -1
  49. package/dist/compat/index.cjs +1 -1
  50. package/dist/compat/index.js +1 -1
  51. package/dist/compat/jotai/index.cjs +1 -1
  52. package/dist/compat/jotai/index.js +1 -1
  53. package/dist/compat/nanostores/index.cjs +1 -1
  54. package/dist/compat/nanostores/index.js +1 -1
  55. package/dist/compat/nestjs/index.cjs +5 -5
  56. package/dist/compat/nestjs/index.js +1 -1
  57. package/dist/compat/zustand/index.cjs +1 -1
  58. package/dist/compat/zustand/index.js +1 -1
  59. package/dist/{composite-DGspwCqk.d.ts → composite-BY9hMxN7.d.ts} +1 -1
  60. package/dist/{composite-nrRumJ7l.d.cts → composite-CH0S8DFn.d.cts} +1 -1
  61. package/dist/content-addressed-storage-BUiREIuj.d.ts +124 -0
  62. package/dist/content-addressed-storage-DqIWCmZG.d.cts +124 -0
  63. package/dist/core/index.cjs +1 -1
  64. package/dist/core/index.js +1 -1
  65. package/dist/extra/browser.cjs +1 -1
  66. package/dist/extra/browser.js +1 -1
  67. package/dist/extra/index.cjs +18 -18
  68. package/dist/extra/index.d.cts +6 -5
  69. package/dist/extra/index.d.ts +6 -5
  70. package/dist/extra/index.js +1 -1
  71. package/dist/extra/node.cjs +2 -2
  72. package/dist/extra/node.js +1 -1
  73. package/dist/extra/operators.cjs +1 -1
  74. package/dist/extra/operators.d.cts +41 -1
  75. package/dist/extra/operators.d.ts +41 -1
  76. package/dist/extra/operators.js +1 -1
  77. package/dist/extra/reactive.cjs +1 -1
  78. package/dist/extra/reactive.d.cts +1 -1
  79. package/dist/extra/reactive.d.ts +1 -1
  80. package/dist/extra/reactive.js +1 -1
  81. package/dist/extra/sources.cjs +1 -1
  82. package/dist/extra/sources.d.cts +62 -2
  83. package/dist/extra/sources.d.ts +62 -2
  84. package/dist/extra/sources.js +1 -1
  85. package/dist/extra/storage-browser.cjs +1 -1
  86. package/dist/extra/storage-browser.js +1 -1
  87. package/dist/{fallback-BaTS7vVY.d.cts → fallback-Cb3GH1O7.d.cts} +6 -14
  88. package/dist/{fallback-eOm3LNxP.d.ts → fallback-DRjJ_ZM8.d.ts} +6 -14
  89. package/dist/graph/index.cjs +4 -4
  90. package/dist/graph/index.js +1 -1
  91. package/dist/{index-ClB7TCfL.d.cts → index-BMe3pCom.d.cts} +1 -1
  92. package/dist/{index-Dljd76bC.d.ts → index-BXzl1NDD.d.ts} +1 -1
  93. package/dist/{index-ClgKmOHe.d.ts → index-Bd6oFZqO.d.ts} +223 -115
  94. package/dist/{index-BJHQUCZx.d.ts → index-CJymKyzT.d.ts} +81 -6
  95. package/dist/{index-D6ajK8Mh.d.cts → index-CZChc85Q.d.cts} +223 -115
  96. package/dist/{index-BXbQUn4n.d.ts → index-CcS0t-l2.d.ts} +1 -1
  97. package/dist/{index-B2HBxvMb.d.ts → index-CwhcFzTA.d.ts} +1 -1
  98. package/dist/{index-B8Aj_z8S.d.cts → index-D-kHVedZ.d.cts} +1 -1
  99. package/dist/{index-ybtSyjWB.d.cts → index-DD7RhHNJ.d.cts} +1 -1
  100. package/dist/{index-BHu_Wba0.d.cts → index-Dm3_D5Ta.d.cts} +1 -1
  101. package/dist/{index-Cc8VQIgL.d.ts → index-DxMS0cHM.d.ts} +1 -1
  102. package/dist/{index-BS220yqj.d.cts → index-gJQqJTKx.d.cts} +81 -6
  103. package/dist/index.cjs +99 -121
  104. package/dist/index.d.cts +14 -13
  105. package/dist/index.d.ts +14 -13
  106. package/dist/index.js +1 -1
  107. package/dist/patterns/ai/browser.cjs +5 -22
  108. package/dist/patterns/ai/browser.d.cts +3 -3
  109. package/dist/patterns/ai/browser.d.ts +3 -3
  110. package/dist/patterns/ai/browser.js +1 -1
  111. package/dist/patterns/ai/index.cjs +27 -44
  112. package/dist/patterns/ai/index.d.cts +9 -7
  113. package/dist/patterns/ai/index.d.ts +9 -7
  114. package/dist/patterns/ai/index.js +1 -1
  115. package/dist/patterns/ai/node.cjs +2 -2
  116. package/dist/patterns/ai/node.d.cts +5 -4
  117. package/dist/patterns/ai/node.d.ts +5 -4
  118. package/dist/patterns/ai/node.js +1 -1
  119. package/dist/patterns/audit/index.cjs +3 -3
  120. package/dist/patterns/audit/index.js +1 -1
  121. package/dist/patterns/cqrs/index.cjs +6 -6
  122. package/dist/patterns/cqrs/index.js +1 -1
  123. package/dist/patterns/demo-shell/index.cjs +1 -1
  124. package/dist/patterns/demo-shell/index.js +1 -1
  125. package/dist/patterns/domain-templates/index.cjs +4 -4
  126. package/dist/patterns/domain-templates/index.js +1 -1
  127. package/dist/patterns/graphspec/index.cjs +6 -6
  128. package/dist/patterns/graphspec/index.d.cts +2 -2
  129. package/dist/patterns/graphspec/index.d.ts +2 -2
  130. package/dist/patterns/graphspec/index.js +1 -1
  131. package/dist/patterns/guarded-execution/index.cjs +7 -7
  132. package/dist/patterns/guarded-execution/index.js +1 -1
  133. package/dist/patterns/harness/index.cjs +11 -11
  134. package/dist/patterns/harness/index.d.cts +2 -2
  135. package/dist/patterns/harness/index.d.ts +2 -2
  136. package/dist/patterns/harness/index.js +1 -1
  137. package/dist/patterns/job-queue/index.cjs +5 -5
  138. package/dist/patterns/job-queue/index.js +1 -1
  139. package/dist/patterns/lens/index.cjs +5 -5
  140. package/dist/patterns/lens/index.d.cts +2 -2
  141. package/dist/patterns/lens/index.d.ts +2 -2
  142. package/dist/patterns/lens/index.js +1 -1
  143. package/dist/patterns/memory/index.cjs +4 -4
  144. package/dist/patterns/memory/index.js +1 -1
  145. package/dist/patterns/messaging/index.cjs +5 -5
  146. package/dist/patterns/messaging/index.js +1 -1
  147. package/dist/patterns/orchestration/index.cjs +1 -1
  148. package/dist/patterns/orchestration/index.js +1 -1
  149. package/dist/patterns/reactive-layout/index.cjs +1 -1
  150. package/dist/patterns/reactive-layout/index.js +1 -1
  151. package/dist/patterns/reduction/index.cjs +5 -5
  152. package/dist/patterns/reduction/index.js +1 -1
  153. package/dist/patterns/refine-loop/index.cjs +8 -8
  154. package/dist/patterns/refine-loop/index.js +1 -1
  155. package/dist/patterns/resilient-pipeline/index.cjs +1 -1
  156. package/dist/patterns/resilient-pipeline/index.js +1 -1
  157. package/dist/patterns/surface/index.cjs +7 -7
  158. package/dist/patterns/surface/index.d.cts +3 -3
  159. package/dist/patterns/surface/index.d.ts +3 -3
  160. package/dist/patterns/surface/index.js +1 -1
  161. package/dist/{reactive-map-BvDrRuwt.d.ts → reactive-map-CtRaCddO.d.ts} +59 -1
  162. package/dist/{reactive-map-CmlPPKHN.d.cts → reactive-map-IJIfZxoh.d.cts} +59 -1
  163. package/dist/{resilience-XRUF267O.js → resilience-IVNDYORD.js} +1 -1
  164. package/dist/{types-O3GzJY2U.d.cts → types-BgMqbc7N.d.cts} +41 -14
  165. package/dist/{types-u64Ose53.d.ts → types-CdfO2QTt.d.ts} +41 -14
  166. package/package.json +1 -1
  167. package/dist/chunk-2GQREQ6C.js +0 -1
  168. package/dist/chunk-4C2OR2GH.js +0 -18
  169. package/dist/chunk-5JDE5JHE.js +0 -1
  170. package/dist/chunk-7JDLFI6N.js +0 -1
  171. package/dist/chunk-AMBYCIOH.js +0 -3
  172. package/dist/chunk-ISCENNXS.js +0 -1
  173. package/dist/chunk-IUK4EFCE.js +0 -1
  174. package/dist/chunk-KASHOCF5.js +0 -1
  175. package/dist/chunk-LI3E75VE.js +0 -64
  176. package/dist/chunk-MGKAO4EK.js +0 -7
  177. package/dist/chunk-NSG4C6BF.js +0 -23
  178. package/dist/chunk-VIEUJSTT.js +0 -1
@@ -1,15 +1,15 @@
1
- "use strict";var rt=Object.defineProperty;var Dn=Object.getOwnPropertyDescriptor;var Cn=Object.getOwnPropertyNames;var Gn=Object.prototype.hasOwnProperty;var q=(t,e)=>()=>(t&&(e=t(t=0)),e);var Mn=(t,e)=>{for(var n in e)rt(t,n,{get:e[n],enumerable:!0})},$n=(t,e,n,r)=>{if(e&&typeof e=="object"||typeof e=="function")for(let o of Cn(e))!Gn.call(t,o)&&o!==n&&rt(t,o,{get:()=>e[o],enumerable:!(r=Dn(e,o))||r.enumerable});return t};var Pn=t=>$n(rt({},"__esModule",{value:!0}),t);function Rt(t,e){let n=new TextEncoder().encode(t.name);if(n.length===0||n.length>255)throw new Error(`encodeEnvelope: codec name "${t.name}" encodes to ${n.length} bytes (must be 1\u2013255)`);let r=t.version;if(!Number.isInteger(r)||r<0||r>65535)throw new Error(`encodeEnvelope: codec.version ${r} out of u16 range (expected integer 0\u201365535)`);let o=2+n.length+2+e.length;if(o>4294967295)throw new Error(`encodeEnvelope: total envelope size ${o} exceeds 2^32-1 bytes (payload ${e.length} bytes)`);let s=new Uint8Array(o),i=0;return s[i++]=ot,s[i++]=n.length,s.set(n,i),i+=n.length,s[i++]=r>>>8&255,s[i++]=r&255,s.set(e,i),s}function At(t,e){if(t.length<kt)throw new Error(`decodeEnvelope: bytes too short (${t.length} < ${kt})`);let n=0,r=t[n++];if(r!==ot)throw new Error(`decodeEnvelope: unsupported envelope version ${r} (expected ${ot})`);let o=t[n++];if(o===0)throw new Error("decodeEnvelope: name_len must be >= 1");if(n+o+2>t.length)throw new Error(`decodeEnvelope: envelope truncated (need ${n+o+2} bytes, have ${t.length})`);let s=new TextDecoder().decode(t.subarray(n,n+o));n+=o;let i=(t[n]<<8|t[n+1])>>>0;n+=2;let a=t.subarray(n),c=e.lookupCodec(s);if(c==null)throw new Error(`decodeEnvelope: codec "${s}" not registered (envelope codec_v=${i})`);return{codec:c,codecVersion:i,payload:a}}function Dt(t){t.registerCodec(Ln)}var Ln,ot,kt,st=q(()=>{"use strict";Ln={name:"json",version:1,contentType:"application/json",encode(t){let e=JSON.stringify(t);return new TextEncoder().encode(e)},decode(t,e){let n=new TextDecoder().decode(t);return JSON.parse(n)}},ot=1,kt=4});function Ae(t){if(t==null)return le;let{type:e,id:n,...r}=t;return{type:e??"system",id:n??"",...r}}var le,it=q(()=>{"use strict";le={type:"system",id:""}});function De(){return fe>0||_e}function Ct(){return fe>0}function Se(t){fe>0?xe.push(t):t()}function Ce(t){fe+=1;let e=!1;try{t()}catch(n){throw e=!0,n}finally{if(fe-=1,fe===0)if(e){if(!_e){let n=xe.splice(0);for(let r of n)try{r()}catch{}ie.length=0,ae.length=0,pe.length=0}}else Fn()}}function Fn(){let t=!_e;t&&(_e=!0);let e=[],n=0;try{for(;ie.length>0||ae.length>0||pe.length>0||t&&xe.length>0;){if(t&&xe.length>0){let s=xe.splice(0);for(let i of s)try{i()}catch(a){e.push(a)}continue}if(n+=1,n>1e3)throw ie.length=0,ae.length=0,pe.length=0,new Error("batch drain exceeded 1000 iterations \u2014 likely a reactive cycle");let o=(ie.length>0?ie:ae.length>0?ae:pe).splice(0);for(let s of o)try{s()}catch(i){e.push(i)}}}finally{t&&(_e=!1)}if(e.length===1)throw e[0];if(e.length>1)throw new AggregateError(e,"batch drain: multiple callbacks threw")}function Ge(t,e,n){if(e.length===0)return;if(e.length===1){let u=n(e[0][0]);if(u<3||!De()){t(e);return}(u>=5?pe:u===4?ae:ie).push(()=>t(e));return}let r=e.length,o=r,s=r,i=r,a=0;for(;a<r&&n(e[a][0])<3;)a++;for(o=a;a<r&&n(e[a][0])===3;)a++;for(s=a;a<r&&n(e[a][0])===4;)a++;i=a;let c=De();if(o>0){let u=e.slice(0,o);t(u)}if(s>o){let u=e.slice(o,s);c?ie.push(()=>t(u)):t(u)}if(i>s){let u=e.slice(s,i);c?ae.push(()=>t(u)):t(u)}if(r>i){let u=e.slice(i,r);c?pe.push(()=>t(u)):t(u)}}var fe,_e,ie,ae,pe,xe,Me=q(()=>{"use strict";fe=0,_e=!1,ie=[],ae=[],pe=[],xe=[]});function he(){return Math.trunc(performance.now()*1e6)}function ge(){return Date.now()*1e6}var $e=q(()=>{"use strict"});var Oe,L,z,W,Z,Q,ee,V,j,M,me,at,In,ct,jn,Bn,ut,Gt,Mt,$t,dt,ce=q(()=>{"use strict";Oe=Symbol.for("graphrefly/START"),L=Symbol.for("graphrefly/DATA"),z=Symbol.for("graphrefly/DIRTY"),W=Symbol.for("graphrefly/RESOLVED"),Z=Symbol.for("graphrefly/INVALIDATE"),Q=Symbol.for("graphrefly/PAUSE"),ee=Symbol.for("graphrefly/RESUME"),V=Symbol.for("graphrefly/TEARDOWN"),j=Symbol.for("graphrefly/COMPLETE"),M=Symbol.for("graphrefly/ERROR"),me=Object.freeze([z]),at=Object.freeze([W]),In=Object.freeze([Z]),ct=Object.freeze([Oe]),jn=Object.freeze([j]),Bn=Object.freeze([V]),ut=Object.freeze([me]),Gt=Object.freeze([at]),Mt=Object.freeze([In]),$t=Object.freeze([jn]),dt=Object.freeze([Bn])});function Pt(t){t.registerMessageType(Oe,{tier:0,wireCrossing:!1}),t.registerMessageType(z,{tier:1,wireCrossing:!1}),t.registerMessageType(Z,{tier:1,wireCrossing:!1,metaPassthrough:!1}),t.registerMessageType(Q,{tier:2,wireCrossing:!1}),t.registerMessageType(ee,{tier:2,wireCrossing:!1}),t.registerMessageType(L,{tier:3,wireCrossing:!0}),t.registerMessageType(W,{tier:3,wireCrossing:!0}),t.registerMessageType(j,{tier:4,wireCrossing:!0,metaPassthrough:!1}),t.registerMessageType(M,{tier:4,wireCrossing:!0,metaPassthrough:!1}),t.registerMessageType(V,{tier:5,wireCrossing:!0,metaPassthrough:!1})}var Pe,Lt=q(()=>{"use strict";ce();Pe=class{_messageTypes=new Map;_codecs=new Map;_onMessage;_onSubscribe;_defaultVersioning;_defaultHashFn;_inspectorEnabled=!(typeof process<"u"&&process.env?.NODE_ENV==="production");_globalInspector;_frozen=!1;tierOf;constructor(e){this._onMessage=e.onMessage,this._onSubscribe=e.onSubscribe,this._defaultVersioning=e.defaultVersioning,this._defaultHashFn=e.defaultHashFn,this.tierOf=n=>{let r=this._messageTypes.get(n);return r!=null?r.tier:1}}get onMessage(){return this._frozen=!0,this._onMessage}get onSubscribe(){return this._frozen=!0,this._onSubscribe}set onMessage(e){this._assertUnfrozen(),this._onMessage=e}set onSubscribe(e){this._assertUnfrozen(),this._onSubscribe=e}get defaultVersioning(){return this._defaultVersioning}set defaultVersioning(e){this._assertUnfrozen(),this._defaultVersioning=e}get defaultHashFn(){return this._defaultHashFn}set defaultHashFn(e){this._assertUnfrozen(),this._defaultHashFn=e}get inspectorEnabled(){return this._inspectorEnabled}set inspectorEnabled(e){this._inspectorEnabled=e}get globalInspector(){return this._globalInspector}set globalInspector(e){this._globalInspector=e}registerMessageType(e,n){return this._assertUnfrozen(),this._messageTypes.set(e,{tier:n.tier,wireCrossing:n.wireCrossing??n.tier>=3,metaPassthrough:n.metaPassthrough??!0}),this}messageTier(e){let n=this._messageTypes.get(e);return n!=null?n.tier:1}isWireCrossing(e){let n=this._messageTypes.get(e);return n!=null?n.wireCrossing:!0}isLocalOnly(e){return!this.isWireCrossing(e)}isMetaPassthrough(e){let n=this._messageTypes.get(e);return n!=null?n.metaPassthrough:!0}isKnownMessageType(e){return this._messageTypes.has(e)}registerCodec(e){return this._assertUnfrozen(),this._codecs.set(e.name,e),this}lookupCodec(e){return this._codecs.get(e)}_isFrozen(){return this._frozen}_assertUnfrozen(){if(this._frozen)throw new Error("GraphReFlyConfig is frozen: a node has already captured this config. Register custom types and set hooks before creating any node.")}}});function lt(t){let e=Vn.filter(n=>t({type:n,id:""},"write"));return e.length===0?"restricted":e.includes("human")&&e.includes("llm")&&e.every(n=>n==="human"||n==="llm"||n==="system")?"both":e.length===1?e[0]:e.join("+")}var J,Vn,Le=q(()=>{"use strict";J=class extends Error{actor;action;nodeName;constructor(e,n){super(n??`GuardDenied: action "${String(e.action)}" denied for actor type "${String(e.actor.type)}"`),this.name="GuardDenied",this.actor=e.actor,this.action=e.action,this.nodeName=e.nodeName}get node(){return this.nodeName}},Vn=["human","llm","wallet","system"]});function ft(t){if(t===void 0)return null;if(typeof t=="number"){if(!Number.isFinite(t))throw new TypeError(`Cannot hash non-finite number: ${t}`);if(Number.isInteger(t)&&!Number.isSafeInteger(t))throw new TypeError(`Cannot hash integer outside safe range (|n| > 2^53-1): ${t}. Cross-language cid parity is not guaranteed for unsafe integers.`);return t}if(typeof t=="string"||typeof t=="boolean"||t===null)return t;if(Array.isArray(t))return t.map(ft);if(typeof t=="object"&&t!==null){let e={};for(let n of Object.keys(t).sort())e[n]=ft(t[n]);return e}return null}function Wn(t){let e=zn.encode(t),n=e.length,r=n*8,o=n+9+63&-64,s=new Uint8Array(o);s.set(e),s[n]=128;let i=new DataView(s.buffer);i.setUint32(o-4,r>>>0,!1),i.setUint32(o-8,Math.floor(r/4294967296)>>>0,!1);let a=1779033703,c=3144134277,u=1013904242,l=2773480762,p=1359893119,h=2600822924,f=528734635,d=1541459225,g=new Uint32Array(64),m=(y,v)=>y>>>v|y<<32-v;for(let y=0;y<o;y+=64){for(let T=0;T<16;T++)g[T]=i.getUint32(y+T*4,!1);for(let T=16;T<64;T++){let R=g[T-15],N=g[T-2],C=m(R,7)^m(R,18)^R>>>3,H=m(N,17)^m(N,19)^N>>>10;g[T]=g[T-16]+C+g[T-7]+H>>>0}let v=a,x=c,O=u,S=l,w=p,_=h,k=f,A=d;for(let T=0;T<64;T++){let R=m(w,6)^m(w,11)^m(w,25),N=w&_^~w&k,C=A+R+N+Hn[T]+g[T]>>>0,H=m(v,2)^m(v,13)^m(v,22),X=v&x^v&O^x&O,se=H+X>>>0;A=k,k=_,_=w,w=S+C>>>0,S=O,O=x,x=v,v=C+se>>>0}a=a+v>>>0,c=c+x>>>0,u=u+O>>>0,l=l+S>>>0,p=p+w>>>0,h=h+_>>>0,f=f+k>>>0,d=d+A>>>0}let b=y=>y.toString(16).padStart(8,"0");return b(a)+b(c)+b(u)+b(l)+b(p)+b(h)+b(f)+b(d)}function pt(t){let e=ft(t??null),n=JSON.stringify(e);return Wn(n).slice(0,16)}function Un(){let t=globalThis.crypto;if(t?.randomUUID)return t.randomUUID();let e=()=>Math.floor(Math.random()*4294967296).toString(16).padStart(8,"0"),n=e()+e()+e()+e();return`${n.slice(0,8)}-${n.slice(8,12)}-4${n.slice(13,16)}-${(parseInt(n.slice(16,17),16)&3|8).toString(16)}${n.slice(17,20)}-${n.slice(20,32)}`}function ht(t,e,n){let r=n?.id??Un();if(t===0)return{id:r,version:0};let s=(n?.hash??pt)(e);return{id:r,version:0,cid:s,prev:null}}function Ft(t,e,n){t.version+=1,"cid"in t&&(t.prev=t.cid,t.cid=n(e))}var Hn,zn,It=q(()=>{"use strict";Hn=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]),zn=new TextEncoder});function Vt(t){return{node:t,unsub:null,prevData:void 0,dirty:!1,involvedThisWave:!1,dataBatch:[],terminal:void 0}}function gt(t){t.prevData=void 0,t.dirty=!1,t.involvedThisWave=!1,t.dataBatch.length=0,t.terminal=void 0}function Fe(t){return t.length===0?t:typeof t[0]=="symbol"?[t]:t}function ue(t,e,n){let r=Ht(t)?t:[],o=typeof t=="function"?t:typeof e=="function"?e:void 0,s={};return Ht(t)?s=(mt(e)?e:n)??{}:mt(t)?s=t:s=(mt(e)?e:n)??{},new F(r,o,s)}var jt,Bt,Kn,qn,ye,F,Ht,mt,be=q(()=>{"use strict";st();it();Me();$e();Lt();Le();ce();It();jt=()=>{},Bt=100;Kn=(t,e,n,r)=>{n.direction==="down-in"&&t._onDepMessage(n.depIndex,e)},qn=(t,e,n,r)=>{let o=t;if(o._status==="completed"||o._status==="errored")return;let s=o._cached,i=s===void 0?[ct]:[ct,[L,s]];o._status==="dirty"&&i.push(me),Ge(e,i,o._config.tierOf)},ye=new Pe({onMessage:Kn,onSubscribe:qn});Pt(ye);Dt(ye);F=class t{_optsName;_describeKind;meta;_hasMeta;_config;_deps;_sinks=null;_sinkCount=0;_cached;_status;_cleanup;_store={};_waveHasNewData=!1;_hasNewTerminal=!1;_hasCalledFnOnce=!1;_paused=!1;_pendingWave=!1;_isExecutingFn=!1;_pendingRerun=!1;_rerunDepth=0;_dirtyDepCount=0;_batchPendingMessages=null;_pauseLocks=null;_pauseBuffer=null;_fn;_equals;_resubscribable;_resetOnTeardown;_autoComplete;_autoError;_pausable;_partial;_guard;_extraGuards;_hashFn;_versioning;_versioningLevel;_lastMutation;_inspectorHooks;_actions;constructor(e,n,r){this._config=r.config??ye,this._config.onMessage,this._optsName=r.name,this._describeKind=r.describeKind,this._equals=r.equals??Object.is,this._resubscribable=r.resubscribable??!1,this._resetOnTeardown=r.resetOnTeardown??!1,this._autoComplete=r.completeWhenDepsComplete??!0,this._autoError=r.errorWhenDepsError??!0,this._pausable=r.pausable??!0,this._guard=r.guard,this._fn=n,this._partial=r.partial??!1,this._cached=r.initial!==void 0?r.initial:void 0,this._status=e.length===0&&n==null&&this._cached!==void 0?"settled":"sentinel",this._hashFn=r.versioningHash??this._config.defaultHashFn??pt;let o=r.versioning??this._config.defaultVersioning;this._versioningLevel=o,this._versioning=o!=null?ht(o,this._cached===void 0?void 0:this._cached,{id:r.versioningId,hash:this._hashFn}):void 0,this._deps=e.map(Vt);let s={};for(let[a,c]of Object.entries(r.meta??{})){let u={initial:c,name:`${r.name??"node"}:meta:${a}`,describeKind:"state",config:this._config};r.guard!=null&&(u.guard=r.guard),s[a]=new t([],void 0,u)}Object.freeze(s),this.meta=s,this._hasMeta=Object.keys(s).length>0;let i=this;this._actions={emit(a){i._emit([[L,a]])},down(a){i._emit(Fe(a))},up(a){i._emitUp(Fe(a))}},this.down=this.down.bind(this),this.up=this.up.bind(this)}get _isTerminal(){return this._status==="completed"||this._status==="errored"}get name(){return this._optsName}get status(){return this._status}get cache(){return this._cached===void 0?void 0:this._cached}get lastMutation(){return this._lastMutation}get v(){return this._versioning}hasGuard(){return this._guard!=null}_applyVersioning(e,n){if(this._isExecutingFn)throw new Error(`Node "${this.name}": _applyVersioning cannot run mid-fn \u2014 call it outside of \`_execFn\` (typically at graph setup time before the first subscribe).`);let r=this._versioningLevel;if(r!=null&&e<=r)return;let o=n?.hash??this._hashFn;o!==this._hashFn&&(this._hashFn=o);let s=this._cached===void 0?void 0:this._cached,i=this._versioning,a=i?.id??n?.id,c=i?.version??0,u=ht(e,s,{id:a,hash:o});u.version=c,this._versioning=u,this._versioningLevel=e}_setInspectorHook(e){return e==null?()=>{}:(this._inspectorHooks==null&&(this._inspectorHooks=new Set),this._inspectorHooks.add(e),()=>{this._inspectorHooks?.delete(e),this._inspectorHooks?.size===0&&(this._inspectorHooks=void 0)})}_pushGuard(e){return this._extraGuards==null&&(this._extraGuards=new Set),this._extraGuards.add(e),()=>{this._extraGuards?.delete(e),this._extraGuards?.size===0&&(this._extraGuards=void 0)}}allowsObserve(e){if(this._guard==null&&this._extraGuards==null)return!0;let n=Ae(e);if(this._guard!=null&&!this._guard(n,"observe"))return!1;if(this._extraGuards!=null){for(let r of this._extraGuards)if(!r(n,"observe"))return!1}return!0}_checkGuard(e){if(e?.internal)return;let n=this._guard!=null||this._extraGuards!=null,r=e?.actor!=null;if(!n&&!r)return;let o=Ae(e?.actor),s=e?.delivery==="signal"?"signal":"write";if(this._guard!=null&&!this._guard(o,s))throw new J({actor:o,action:s,nodeName:this.name});if(this._extraGuards!=null){for(let i of this._extraGuards)if(!i(o,s))throw new J({actor:o,action:s,nodeName:this.name})}this._lastMutation={actor:o,timestamp_ns:ge()}}down(e,n){let r=Fe(e);r.length!==0&&(this._checkGuard(n),this._emit(r))}emit(e,n){this._checkGuard(n),this._emit([[L,e]])}up(e,n){if(this._deps.length===0)return;let r=Fe(e);if(r.length===0)return;this._checkGuard(n);let o=n??{internal:!0};this._validateUpTiers(r);for(let s of this._deps)s.node.up?.(r,o)}_emitUp(e){if(this._deps.length!==0&&e.length!==0){this._validateUpTiers(e);for(let n of this._deps)n.node.up?.(e,{internal:!0})}}_validateUpTiers(e){let n=this._config.tierOf;for(let r of e){let o=n(r[0]);if(o===3||o===4)throw new Error(`Node "${this.name}": tier-${o} messages cannot flow up \u2014 DATA/RESOLVED/COMPLETE/ERROR are downstream-only. Use \`down(...)\` for value delivery; \`up(...)\` is for control signals (DIRTY, INVALIDATE, PAUSE, RESUME, TEARDOWN).`)}}subscribe(e,n){if(n!=null&&this._guard!=null){let c=Ae(n);if(!this._guard(c,"observe"))throw new J({actor:c,action:"observe",nodeName:this.name})}let o=this._isTerminal&&this._resubscribable;if(o){this._cached=void 0,this._status="sentinel",this._store={},this._hasCalledFnOnce=!1,this._waveHasNewData=!1,this._hasNewTerminal=!1,this._paused=!1,this._pendingWave=!1,this._pendingRerun=!1,this._isExecutingFn=!1,this._rerunDepth=0,this._dirtyDepCount=0,this._pauseLocks=null,this._pauseBuffer=null;for(let c of this._deps)gt(c);if(this._partial===!1){for(let c of this._deps)if(c.prevData!==void 0||c.dataBatch.length!==0||c.terminal!==void 0||c.dirty)throw new Error(`resubscribable-reset invariant: DepRecord not fully reset for node ${this._optsName??"(anonymous)"}`)}}this._sinkCount+=1;let s;try{s=this._config.onSubscribe(this,e,{sinkCount:this._sinkCount,afterTerminalReset:o},this._actions)}catch(c){throw this._sinkCount-=1,c}this._sinks==null?this._sinks=e:typeof this._sinks=="function"?this._sinks=new Set([this._sinks,e]):this._sinks.add(e);let i=this._isTerminal;if(this._sinkCount===1&&!i)try{this._activate()}catch(c){if(this._sinkCount-=1,this._removeSink(e),this._sinkCount===0&&(this._status="sentinel"),typeof s=="function")try{s()}catch{}throw c}this._status==="sentinel"&&this._cached===void 0&&(this._status="pending");let a=!1;return()=>{a||(a=!0,this._sinkCount-=1,this._removeSink(e),typeof s=="function"&&s(),this._sinks==null&&this._deactivate())}}_removeSink(e){if(this._sinks===e)this._sinks=null;else if(this._sinks!=null&&typeof this._sinks!="function")if(this._sinks.delete(e),this._sinks.size===1){let[n]=this._sinks;this._sinks=n}else this._sinks.size===0&&(this._sinks=null)}_activate(){if(this._deps.length===0){this._fn&&this._execFn();return}this._dirtyDepCount=0;let e=this._deps.length,n=0;try{for(let r=0;r<e;r++){let o=r,s=this._deps[r];s.unsub=jt,s.unsub=s.node.subscribe(i=>{if(s.unsub===null)return;let a=this._config.tierOf,c=!1;for(let u of i)a(u[0])>=3&&(c=!0),this._config.onMessage(this,u,{direction:"down-in",depIndex:o},this._actions);c&&this._maybeRunFnOnSettlement()}),n++}}catch(r){this._deps[n].unsub=null;for(let o=0;o<n;o++){let s=this._deps[o];if(s.unsub!=null){let i=s.unsub;s.unsub=null;try{i()}catch{}gt(s)}}throw this._dirtyDepCount=0,r}}_addDep(e){for(let o=0;o<this._deps.length;o++)if(this._deps[o].node===e)return o;let n=this._deps.length,r=Vt(e);if(this._deps.push(r),this._sinks==null)return n;r.dirty=!0,this._dirtyDepCount++,this._status!=="dirty"&&this._emit(ut),r.unsub=jt;try{r.unsub=e.subscribe(o=>{if(r.unsub===null)return;let s=this._config.tierOf,i=!1;for(let a of o)s(a[0])>=3&&(i=!0),this._config.onMessage(this,a,{direction:"down-in",depIndex:n},this._actions);i&&this._maybeRunFnOnSettlement()})}catch(o){throw r.unsub=null,this._deps.pop(),this._dirtyDepCount--,o}return n}_deactivate(e=!1){let n=this._cleanup;if(this._cleanup=void 0,typeof n=="function")try{n()}catch(r){this._emit([[M,this._wrapFnError("cleanup threw",r)]])}else if(n!=null&&typeof n=="object"){let r=n.deactivate;if(typeof r=="function")try{r()}catch(o){this._emit([[M,this._wrapFnError("cleanup.deactivate threw",o)]])}}for(let r of this._deps){if(r.unsub!=null){let o=r.unsub;r.unsub=null;try{o()}catch{}}gt(r)}this._waveHasNewData=!1,this._hasNewTerminal=!1,this._hasCalledFnOnce=!1,this._paused=!1,this._pendingWave=!1,this._pendingRerun=!1,this._rerunDepth=0,this._store={},this._dirtyDepCount=0,this._pauseLocks=null,this._pauseBuffer=null,this._fn!=null&&(this._cached=void 0),e||(this._fn!=null||this._deps.length>0)&&(!this._isTerminal||this._resubscribable)&&(this._status="sentinel")}_onDepMessage(e,n){let r=this._deps[e],o=n[0];if(this._inspectorHooks!=null){let s={kind:"dep_message",depIndex:e,message:n};for(let i of this._inspectorHooks)i(s)}if(o!==Oe){if(o===z){this._depDirtied(r);return}if(o===Z){this._depInvalidated(r),this._emit(Mt);return}if(o===Q||o===ee){this._emit([n]);return}if(o===V){this._emit(dt);return}if(o===L)this._depSettledAsData(r,n[1]);else if(o===W)this._depSettledAsResolved(r);else if(o===j)this._depSettledAsTerminal(r,!0);else if(o===M)this._depSettledAsTerminal(r,n[1]);else{this._emit([n]);return}if(!this._fn){(o===L||o===W)&&this._emit([n]),(o===j||o===M)&&this._maybeAutoTerminalAfterWave();return}}}_depDirtied(e){e.dirty||(e.dirty=!0,e.involvedThisWave=!0,this._dirtyDepCount++,this._status!=="dirty"&&this._emit(ut))}_depSettledAsData(e,n){e.dirty&&(e.dirty=!1,this._dirtyDepCount--),e.involvedThisWave=!0,e.dataBatch.push(n),this._waveHasNewData=!0}_depSettledAsResolved(e){e.dirty&&(e.dirty=!1,this._dirtyDepCount--)}_depSettledAsTerminal(e,n){e.dirty&&(e.dirty=!1,this._dirtyDepCount--),e.terminal=n,e.involvedThisWave=!0,this._hasNewTerminal=!0}_depInvalidated(e){e.prevData=void 0,e.terminal=void 0,e.dataBatch.length=0,e.dirty?e.involvedThisWave=!1:(e.dirty=!0,e.involvedThisWave=!0,this._dirtyDepCount++)}_maybeRunFnOnSettlement(){if(!(this._isTerminal&&!this._resubscribable)&&!(this._dirtyDepCount>0)){if(!this._partial&&!this._hasCalledFnOnce)for(let e=0;e<this._deps.length;e++){let n=this._deps[e];if(n.dataBatch.length===0&&n.prevData===void 0&&n.terminal===void 0){this._maybeAutoTerminalAfterWave();return}}if(this._paused){this._pendingWave=!0;return}if(!this._waveHasNewData&&!this._hasNewTerminal&&this._hasCalledFnOnce){this._clearWaveFlags(),this._emit(Gt),this._maybeAutoTerminalAfterWave();return}this._fn&&this._execFn(),this._maybeAutoTerminalAfterWave()}}_maybeAutoTerminalAfterWave(){if(this._deps.length===0||this._isTerminal)return;let e=this._deps.find(n=>n.terminal!==void 0&&n.terminal!==!0);if(e!=null){this._autoError&&this._emit([[M,e.terminal]]);return}this._autoComplete&&this._deps.every(n=>n.terminal!==void 0)&&this._emit($t)}_execFn(){if(!this._fn||this._isTerminal&&!this._resubscribable)return;if(this._isExecutingFn){this._pendingRerun=!0;return}let e=this._cleanup;if(typeof e=="function"){this._cleanup=void 0;try{e()}catch(i){this._emit([[M,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([[M,this._wrapFnError("cleanup.beforeRun threw",a)]]);return}}}let n=this._deps.map(i=>i.involvedThisWave?i.dataBatch.length>0?[...i.dataBatch]:[]:void 0),r=this._deps.map(i=>i.prevData);for(let i=0;i<this._deps.length;i++){let a=n[i];a!=null&&a.length>0&&(this._deps[i].prevData=a[a.length-1])}let o=this._deps.map(i=>i.terminal),s={prevData:r,terminalDeps:o,store:this._store};if(this._hasCalledFnOnce=!0,this._clearWaveFlags(),this._inspectorHooks!=null){let i={kind:"run",batchData:n,prevData:r};for(let a of this._inspectorHooks)a(i)}this._isExecutingFn=!0;try{let i=this._fn(n,this._actions,s);if(typeof i=="function")this._cleanup=i;else if(i!=null&&typeof i=="object"){let a=i;(typeof a.beforeRun=="function"||typeof a.deactivate=="function"||typeof a.invalidate=="function")&&(this._cleanup=i)}}catch(i){this._emit([[M,this._wrapFnError("fn threw",i)]])}finally{this._isExecutingFn=!1,this._pendingRerun?(this._pendingRerun=!1,this._rerunDepth+=1,this._rerunDepth>Bt?(this._rerunDepth=0,this._emit([[M,new Error(`Node "${this.name}": _pendingRerun depth exceeded ${Bt} \u2014 likely a reactive cycle`)]])):this._maybeRunFnOnSettlement()):this._rerunDepth=0,this._clearWaveFlags()}}_clearWaveFlags(){this._waveHasNewData=!1,this._hasNewTerminal=!1;for(let e of this._deps)e.involvedThisWave=!1,e.dataBatch.length=0}_wrapFnError(e,n){let r=n instanceof Error?n.message:String(n);return new Error(`Node "${this.name}": ${e}: ${r}`,{cause:n})}_frameBatch(e){let n=this._config.tierOf;if(e.length===1)return n(e[0][0])===3&&this._status!=="dirty"?[me,e[0]]:e;let r=!0,o=!1,s=!1,i=-1;for(let c of e){let u=n(c[0]);u<i&&(r=!1),u===3&&(o=!0),c[0]===z&&(s=!0),i=u}let a=e;if(!r){let c=e.map((u,l)=>({m:u,i:l,tier:n(u[0])}));c.sort((u,l)=>u.tier-l.tier||u.i-l.i),a=c.map(u=>u.m)}if(o&&!s&&this._status!=="dirty"){let c=0;for(;c<a.length&&n(a[c][0])===0;)c++;return c===0?[me,...a]:[...a.slice(0,c),me,...a.slice(c)]}return a}_emit(e){if(e.length===0)return;for(let a=0;a<e.length;a++){let c=e[a];if(c[0]===M&&c[1]===void 0)throw new TypeError('[ERROR, payload] requires a non-undefined payload (spec \xA71.2). Pass an Error object or domain tag instead \u2014 e.g. node.down([[ERROR, new Error("reason")]])')}let n=e;if(this._isTerminal&&!this._resubscribable){let a=e.filter(c=>c[0]===V||c[0]===Z);if(a.length===0)return;n=a}n=this._frameBatch(n);let o=null;for(let a=0;a<n.length;a++){let c=n[a],u=c[0];if(u!==Q&&u!==ee){o?.push(c);continue}if(c.length<2)throw new Error(`Node "${this.name}": [[${u===Q?"PAUSE":"RESUME"}]] must carry a lockId payload \u2014 bare PAUSE/RESUME is a protocol violation (C0 rule). Use \`[[PAUSE, lockId]]\` / \`[[RESUME, lockId]]\`.`);let l=!0;if(this._pausable!==!1){let p=c[1];if(u===Q)this._pauseLocks==null&&(this._pauseLocks=new Set),this._pauseLocks.add(p),this._paused=!0,this._pausable==="resumeAll"&&this._pauseBuffer==null&&(this._pauseBuffer=[]);else if(this._pauseLocks==null||!this._pauseLocks.has(p))l=!1;else if(this._pauseLocks.delete(p),this._pauseLocks.size===0){if(this._paused=!1,this._pauseBuffer!=null&&this._pauseBuffer.length>0){let h=this._pauseBuffer;this._pauseBuffer=[],this._emit(h)}this._pendingWave&&(this._pendingWave=!1,this._maybeRunFnOnSettlement())}}l?o?.push(c):o==null&&(o=n.slice(0,a))}if(o!=null){if(o.length===0)return;n=o}if(this._hasMeta&&n.some(a=>a[0]===V))for(let a of Object.keys(this.meta))try{this.meta[a]._emit(dt)}catch{}let{finalMessages:s,equalsError:i}=this._updateState(n);if(s.length>0&&this._config.inspectorEnabled){let a=this._config.globalInspector;if(a!=null)try{a({kind:"emit",node:this,messages:s})}catch{}}if(s.length>0)if(this._paused&&this._pausable==="resumeAll"&&this._pauseBuffer!=null){let a=this._config.tierOf,c=[];for(let u of s)a(u[0])===3?this._pauseBuffer.push(u):c.push(u);c.length>0&&this._dispatchOrAccumulate(c)}else this._dispatchOrAccumulate(s);i!=null&&this._emit([[M,i]])}_updateState(e){let n=this._config.tierOf,r,o,s=-1,i=0;for(let l of e)n(l[0])===3&&i++;let a=i<=1,c=-1;if(this._versioning!=null&&i>1){for(let l=e.length-1;l>=0;l--)if(e[l][0]===L){c=l;break}}for(let l=0;l<e.length;l++){let p=e[l],h=p[0];if(h===L){if(p.length>=2){let f=!1;if(a&&this._cached!==void 0)try{f=this._equals(this._cached,p[1])}catch(d){o=this._wrapFnError("equals threw",d),s=l;break}if(f){r==null&&(r=e.slice(0,l)),r.push(at),this._status="resolved";continue}this._cached=p[1],this._versioning!=null&&(c<0||l===c)&&Ft(this._versioning,p[1],this._hashFn)}this._status="settled",r?.push(p)}else if(r?.push(p),h===z)this._status="dirty";else if(h===W)this._status="resolved";else if(h===j)this._status="completed";else if(h===M)this._status="errored";else if(h===Z){this._cached=void 0,this._status="dirty";let f=this._cleanup;if(typeof f=="function"){this._cleanup=void 0;try{f()}catch{}}else if(f!=null&&typeof f=="object"){let d=f.invalidate;if(typeof d=="function")try{d()}catch{}}}else h===V&&(this._resetOnTeardown&&(this._cached=void 0),this._deactivate(!0),this._status="sentinel")}let u=s>=0?r??e.slice(0,s):r??e;return o!=null?{finalMessages:u,equalsError:o}:{finalMessages:u}}_deliverToSinks=e=>{if(this._sinks==null)return;if(typeof this._sinks=="function"){this._sinks(e);return}let n=[...this._sinks];for(let r of n)r(e)};_dispatchOrAccumulate(e){if(Ct()){this._batchPendingMessages===null&&(this._batchPendingMessages=[],Se(()=>this._flushBatchPending()));for(let n of e)this._batchPendingMessages.push(n);return}Ge(this._deliverToSinks,e,this._config.tierOf)}_flushBatchPending(){let e=this._batchPendingMessages;if(e===null||(this._batchPendingMessages=null,e.length===0))return;let n=this._frameBatch(e);Ge(this._deliverToSinks,n,this._config.tierOf)}},Ht=t=>Array.isArray(t),mt=t=>typeof t=="object"&&t!=null&&!Array.isArray(t)});function te(t,e){return ue([],{...e,initial:t})}function Te(t,e){return ue((r,o,s)=>t(o,s)??void 0,{describeKind:"producer",...e})}function de(t,e,n){return ue(t,(o,s,i)=>{let a=o.map((c,u)=>c!=null&&c.length>0?c.at(-1):i.prevData[u]);s.emit(e(a,i))},{describeKind:"derived",...n})}function Ie(t,e,n){return ue(t,(o,s,i)=>{let a=o.map((c,u)=>c!=null&&c.length>0?c.at(-1):i.prevData[u]);return e(a,s,i)??void 0},{describeKind:"effect",...n})}var je=q(()=>{"use strict";be()});function ve(t){return t.subscribe(()=>{})}var bt=q(()=>{"use strict"});var Ve,zt=q(()=>{"use strict";Ve=class{_timer;_gen=0;start(e,n){this.cancel(),this._gen+=1;let r=this._gen;this._timer=setTimeout(()=>{this._timer=void 0,r===this._gen&&n()},e)}cancel(){this._timer!==void 0&&(clearTimeout(this._timer),this._timer=void 0)}get pending(){return this._timer!==void 0}}});var Qr={};Mn(Qr,{SNAPSHOT_WIRE_VERSION:()=>Nt,SurfaceError:()=>D,asSurfaceError:()=>On,createGraph:()=>Xe,deleteSnapshot:()=>An,diffSnapshots:()=>kn,listSnapshots:()=>Rn,restoreSnapshot:()=>En,runReduction:()=>Tn,saveSnapshot:()=>Nn});module.exports=Pn(Qr);je();it();Me();$e();Le();ce();Le();be();function Be(t,e){if(e!=null&&e.length>0)return new Set(e);switch(t){case"standard":return new Set(["type","status","value","deps","meta","v"]);case"full":return null;default:return new Set(["type","deps"])}}function Jn(t){return t._describeKind!=null?t._describeKind:t._deps.length>0?"derived":t._fn!=null?"producer":"state"}function Yn(t){let e={};for(let[n,r]of Object.entries(t.meta))try{e[n]=r.cache}catch{}return e}function yt(t,e){let n=e==null,r=!n&&e!=null?[...e].filter(u=>u.startsWith("meta.")).map(u=>u.slice(5)):null,o=n||e.has("meta")||r!=null&&r.length>0,s="state",i=[];t instanceof F&&(s=Jn(t),i=t._deps.map(u=>u.node.name??""));let a={type:s,deps:i};(n||e.has("status"))&&(a.status=t.status);let c=t instanceof F?t._guard:void 0;if(o){let u={...Yn(t)};if(c!=null&&u.access===void 0&&(u.access=lt(c)),r!=null&&r.length>0&&!e.has("meta")){let l={};for(let p of r)p in u&&(l[p]=u[p]);a.meta=l}else a.meta=u}if(t.name!=null&&(a.name=t.name),n||e.has("value")){t.status==="sentinel"&&(a.sentinel=!0);try{a.value=t.cache}catch{}}if((n||e.has("v"))&&t.v!=null){let u={id:t.v.id,version:t.v.version};"cid"in t.v&&(u.cid=t.v.cid,u.prev=t.v.prev),a.v=u}return(n||e.has("guard"))&&c!=null&&(a.guard=lt(c)),(n||e.has("lastMutation"))&&t.lastMutation!=null&&(a.lastMutation=t.lastMutation),a}be();je();bt();zt();var Ne=class{constructor(e){this.capacity=e;if(!Number.isInteger(e)||e<=0)throw new Error(`RingBuffer capacity must be a positive integer (got ${e})`);this.buf=new Array(e)}buf;head=0;_size=0;get size(){return this._size}get maxSize(){return this.capacity}push(e){let n=(this.head+this._size)%this.capacity;this.buf[n]=e,this._size<this.capacity?this._size++:this.head=(this.head+1)%this.capacity}shift(){if(this._size===0)return;let e=this.buf[this.head];return this.buf[this.head]=void 0,this.head=(this.head+1)%this.capacity,this._size--,e}at(e){if(this._size===0)return;let n=e<0?this._size+e:e;if(!(n<0||n>=this._size))return this.buf[(this.head+n)%this.capacity]}toArray(){let e=new Array(this._size);for(let n=0;n<this._size;n++)e[n]=this.buf[(this.head+n)%this.capacity];return e}clear(){for(let e=0;e<this._size;e++)this.buf[(this.head+e)%this.capacity]=void 0;this.head=0,this._size=0}};st();function vt(t){return t>=768&&t<=879||t>=1155&&t<=1161||t>=1425&&t<=1469||t>=1552&&t<=1562||t>=1611&&t<=1631||t>=1648&&t===1648||t>=1750&&t<=1756||t>=1759&&t<=1764||t>=1767&&t<=1768||t>=1770&&t<=1773||t>=1840&&t<=1866||t>=1958&&t<=1968||t>=2304&&t<=2307||t>=2362&&t<=2383||t>=2385&&t<=2391||t>=2402&&t<=2403||t>=2433&&t<=2435||t>=2492&&t<=2509||t>=2561&&t<=2563||t>=2620&&t<=2641||t>=2672&&t<=2673||t>=2677&&t===2677||t>=3633&&t===3633||t>=3636&&t<=3642||t>=3655&&t<=3662||t>=3761&&t===3761||t>=3764&&t<=3772||t>=3784&&t<=3790||t>=7616&&t<=7679||t>=8400&&t<=8447||t>=65024&&t<=65039||t>=65056&&t<=65071||t===8205?0:t>=4352&&t<=4447||t>=8986&&t<=8987||t>=9001&&t<=9002||t>=9193&&t<=9203||t>=9208&&t<=9210||t>=9725&&t<=9726||t>=9748&&t<=9749||t>=9800&&t<=9811||t===9855||t===9875||t===9889||t>=9898&&t<=9899||t>=9917&&t<=9918||t>=9924&&t<=9925||t===9934||t===9940||t===9962||t>=9970&&t<=9971||t===9973||t===9978||t===9981||t===9986||t===9989||t>=9992&&t<=9997||t===9999||t>=10067&&t<=10069||t===10071||t>=10133&&t<=10135||t===10160||t===10175||t>=10548&&t<=10549||t>=11013&&t<=11015||t>=11035&&t<=11036||t===11088||t===11093||t>=11904&&t<=12350||t>=12352&&t<=12447||t>=12448&&t<=12543||t>=12549&&t<=12591||t>=12593&&t<=12686||t>=12688&&t<=12771||t>=12784&&t<=12830||t>=12832&&t<=12871||t>=12880&&t<=19903||t>=19968&&t<=40959||t>=43360&&t<=43388||t>=44032&&t<=55203||t>=63744&&t<=64255||t>=65040&&t<=65049||t>=65072&&t<=65131||t>=65281&&t<=65376||t>=65504&&t<=65510||t>=126980&&t===126980||t===127183||t>=127344&&t<=127345||t===127358||t===127359||t===127374||t>=127377&&t<=127386||t>=127456&&t<=127487||t>=127488&&t<=127490||t===127514||t===127535||t>=127538&&t<=127546||t>=127568&&t<=127569||t>=127744&&t<=129535||t>=129536&&t<=129791||t>=129792&&t<=130047||t>=131072&&t<=196605||t>=196608&&t<=262141?2:1}function He(t){let e=0;for(let n of t)e+=vt(n.codePointAt(0));return e}function Wt(t,e){if(e<=0)return"";let n=0,r="";for(let o of t){let s=vt(o.codePointAt(0));if(n+s>e){if(e<=1)return"\u2026";for(;n+1>e&&r.length>0;){let i=[...r].pop();r=r.slice(0,-i.length),n-=vt(i.codePointAt(0))}return`${r}\u2026`}r+=o,n+=s}return r}var Xn={horizontal:"\u2500",vertical:"\u2502",cornerTL:"\u250C",cornerTR:"\u2510",cornerBL:"\u2514",cornerBR:"\u2518",tDown:"\u252C",tUp:"\u2534",tRight:"\u251C",tLeft:"\u2524",cross:"\u253C",arrowRight:"\u25B6",arrowDown:"\u25BC",arrowLeft:"\u25C0",arrowUp:"\u25B2",boxTL:"\u250C",boxTR:"\u2510",boxBL:"\u2514",boxBR:"\u2518",boxH:"\u2500",boxV:"\u2502"},Zn={horizontal:"-",vertical:"|",cornerTL:"+",cornerTR:"+",cornerBL:"+",cornerBR:"+",tDown:"+",tUp:"+",tRight:"+",tLeft:"+",cross:"+",arrowRight:">",arrowDown:"v",arrowLeft:"<",arrowUp:"^",boxTL:"+",boxTR:"+",boxBL:"+",boxBR:"+",boxH:"-",boxV:"|"};function Jt(t,e){let n=e.charset==="ascii"?Zn:Xn,r=t.width,o=t.height,s=Array.from({length:o},()=>Array.from({length:r},()=>" ")),i=Array.from({length:o},()=>Array.from({length:r},()=>"empty"));for(let a of t.edges)er(s,i,n,a);for(let a of t.boxes)Qn(s,i,n,a,e.labelOf(a.id));return s.map(a=>or(a.join(""))).join(`
2
- `)}function Qn(t,e,n,r,o){let{x:s,y:i,w:a,h:c}=r;if(a<2||c<2){c>0&&Ut(t,e,s,i,a,o);return}re(t,e,s,i,n.boxTL);for(let l=s+1;l<s+a-1;l+=1)re(t,e,l,i,n.boxH);re(t,e,s+a-1,i,n.boxTR);for(let l=i+1;l<i+c-1;l+=1){re(t,e,s,l,n.boxV);for(let p=s+1;p<s+a-1;p+=1)Yt(t,e,p,l," ","empty");re(t,e,s+a-1,l,n.boxV)}re(t,e,s,i+c-1,n.boxBL);for(let l=s+1;l<s+a-1;l+=1)re(t,e,l,i+c-1,n.boxH);re(t,e,s+a-1,i+c-1,n.boxBR);let u=i+Math.floor(c/2);Ut(t,e,s+1,u,a-2,o)}function re(t,e,n,r,o){Yt(t,e,n,r,o,o===" "?"empty":o==="\u2500"||o==="-"?"boxH":o==="\u2502"||o==="|"?"boxV":"boxCorner")}function Yt(t,e,n,r,o,s){if(r<0||r>=t.length)return;let i=t[r];n<0||n>=i.length||(i[n]=o,e[r][n]=s)}function Ut(t,e,n,r,o,s){if(r<0||r>=t.length)return;let i=n,a=o;for(let c of s){let u=He(c);if(u!==0){if(a<u)break;i>=0&&i<t[r].length&&(t[r][i]=c,e[r][i]="label",u===2&&i+1<t[r].length&&(t[r][i+1]="",e[r][i+1]="label")),i+=u,a-=u}}for(;a>0;)i>=0&&i<t[r].length&&(t[r][i]=" ",e[r][i]="empty"),i+=1,a-=1}function er(t,e,n,r){let o=r.points;if(o.length<2)return;for(let c=0;c+1<o.length;c+=1)tr(t,e,n,o[c],o[c+1]);for(let c=1;c+1<o.length;c+=1){let u=o[c-1],l=o[c],p=o[c+1],h=nr(u,l,p,n);h&&qt(t,e,l.x,l.y,h,"edgeCorner")}let s=o[o.length-1],i=o[o.length-2],a=rr(i,s,n);a&&qt(t,e,s.x,s.y,a,"arrow")}function tr(t,e,n,r,o){if(!(r.x===o.x&&r.y===o.y)){if(r.y===o.y){let s=r.y,i=Math.min(r.x,o.x),a=Math.max(r.x,o.x);for(let c=i;c<=a;c+=1)Kt(t,e,c,s,n,"h")}else if(r.x===o.x){let s=r.x,i=Math.min(r.y,o.y),a=Math.max(r.y,o.y);for(let c=i;c<=a;c+=1)Kt(t,e,s,c,n,"v")}}}function Kt(t,e,n,r,o,s){if(r<0||r>=t.length)return;let i=t[r];if(n<0||n>=i.length)return;let a=e[r][n];if(!(a==="boxH"||a==="boxV"||a==="boxCorner"||a==="label")){if(a==="empty"){i[n]=s==="h"?o.horizontal:o.vertical,e[r][n]=s==="h"?"edgeH":"edgeV";return}if(a==="edgeH"&&s==="v"){i[n]=o.cross,e[r][n]="edgeCorner";return}if(a==="edgeV"&&s==="h"){i[n]=o.cross,e[r][n]="edgeCorner";return}}}function qt(t,e,n,r,o,s){if(r<0||r>=t.length)return;let i=t[r];if(n<0||n>=i.length)return;let a=e[r][n];a==="boxH"||a==="boxV"||a==="boxCorner"||a==="label"||(i[n]=o,e[r][n]=s)}function nr(t,e,n,r){let o=t.y===e.y,s=e.y===n.y;if(o===s)return;if(o){let c=t.x<e.x,u=n.y>e.y;return c&&u?r.cornerTR:c&&!u?r.cornerBR:!c&&u?r.cornerTL:r.cornerBL}let i=t.y<e.y,a=n.x>e.x;return i&&a?r.cornerBL:i&&!a?r.cornerBR:!i&&a?r.cornerTL:r.cornerTR}function rr(t,e,n){if(e.x>t.x)return n.arrowRight;if(e.x<t.x)return n.arrowLeft;if(e.y>t.y)return n.arrowDown;if(e.y<t.y)return n.arrowUp}function or(t){let e=t.length;for(;e>0&&t.charCodeAt(e-1)===32;)e-=1;return t.slice(0,e)}function Qt(t){let e=sr(t);ir(e),ar(e),cr(e),ur(e,t);let n=fr(e,t),{width:r,height:o}=hr(e),s=[];for(let i of e.layers)for(let a of i)a.isVirtual||s.push({id:a.id,layer:a.layer,order:a.order,x:a.x,y:a.y,w:a.w,h:a.h});return{boxes:s,edges:n,width:r,height:o}}function sr(t){let e=new Map;for(let o of t.nodes)e.set(o,{id:o,isVirtual:!1,layer:-1,order:0,x:0,y:0,w:t.widthCells(o),h:t.heightCells(o),in:[],out:[]});let n=[],r=0;for(let o of t.edges){if(o.from===o.to)continue;let s=e.get(o.from),i=e.get(o.to);if(!s||!i)continue;let a={chainId:r++,chainFrom:o.from,chainTo:o.to,fromId:o.from,toId:o.to,hopIndex:0,chainLen:1};s.out.push(a),i.in.push(a),n.push(a)}return{nodes:e,layers:[],hops:n}}function ir(t){let e=new Map;for(let s of t.nodes.values())e.set(s.id,s.in.length);let n=[];for(let s of t.nodes.values())(e.get(s.id)??0)===0&&(s.layer=0,n.push(s));let r=new Set,o=0;for(;o<n.length;){let s=n[o++];if(!r.has(s.id)){r.add(s.id);for(let i of s.out){let a=t.nodes.get(i.toId);a.layer=Math.max(a.layer,s.layer+1);let c=(e.get(a.id)??0)-1;e.set(a.id,c),c<=0&&n.push(a)}}}for(let s of t.nodes.values())s.layer<0&&(s.layer=0)}function ar(t){let e=Math.max(0,...Array.from(t.nodes.values(),s=>s.layer)),n=Array.from({length:e+1},()=>[]);for(let s of t.nodes.values())n[s.layer].push(s);let r=[],o=0;for(let s of t.hops){let i=t.nodes.get(s.fromId),a=t.nodes.get(s.toId),c=a.layer-i.layer;if(c<=0){i.out=i.out.filter(p=>p!==s),a.in=a.in.filter(p=>p!==s);continue}if(c===1){s.hopIndex=0,s.chainLen=1,r.push(s);continue}i.out=i.out.filter(p=>p!==s),a.in=a.in.filter(p=>p!==s);let u=i;for(let p=1;p<c;p+=1){let h=`__virt_${o++}__`,f={id:h,isVirtual:!0,layer:i.layer+p,order:0,x:0,y:0,w:0,h:1,in:[],out:[]};t.nodes.set(h,f),n[f.layer].push(f);let d={chainId:s.chainId,chainFrom:s.chainFrom,chainTo:s.chainTo,fromId:u.id,toId:h,hopIndex:p-1,chainLen:c};u.out.push(d),f.in.push(d),r.push(d),u=f}let l={chainId:s.chainId,chainFrom:s.chainFrom,chainTo:s.chainTo,fromId:u.id,toId:a.id,hopIndex:c-1,chainLen:c};u.out.push(l),a.in.push(l),r.push(l)}for(let s of n)for(let i=0;i<s.length;i+=1)s[i].order=i;t.layers=n,t.hops=r}function cr(t){for(let n=0;n<4;n+=1){for(let r=1;r<t.layers.length;r+=1)Xt(t,t.layers[r],"in"),ze(t.layers[r]);for(let r=t.layers.length-2;r>=0;r-=1)Xt(t,t.layers[r],"out"),ze(t.layers[r])}for(let n=0;n<2;n+=1){let r=!1;for(let o=1;o<t.layers.length;o+=1){let s=t.layers[o];for(let i=0;i+1<s.length;i+=1){let a=Zt(t,s[i],s[i+1],"in");[s[i],s[i+1]]=[s[i+1],s[i]],ze(s),Zt(t,s[i],s[i+1],"in")<a?r=!0:([s[i],s[i+1]]=[s[i+1],s[i]],ze(s))}}if(!r)break}}function Xt(t,e,n){let r=new Map;for(let o of e){let s=n==="in"?o.in:o.out;if(s.length===0){r.set(o.id,o.order);continue}let i=0,a=0;for(let c of s){let u=t.nodes.get(n==="in"?c.fromId:c.toId);u&&(i+=u.order,a+=1)}r.set(o.id,a===0?o.order:i/a)}e.sort((o,s)=>{let i=r.get(o.id),a=r.get(s.id);return i!==a?i-a:o.order-s.order})}function ze(t){for(let e=0;e<t.length;e+=1)t[e].order=e}function Zt(t,e,n,r){let o=r==="in"?e.in:e.out,s=r==="in"?n.in:n.out,i=0;for(let a of o)for(let c of s){let u=t.nodes.get(r==="in"?a.fromId:a.toId)?.order??0,l=t.nodes.get(r==="in"?c.fromId:c.toId)?.order??0;(e.order<n.order&&u>l||e.order>n.order&&u<l)&&(i+=1)}return i}function ur(t,e){e.direction==="LR"?dr(t,e):lr(t,e)}function dr(t,e){let n=[],r=0;for(let o=0;o<t.layers.length;o+=1){n.push(r);let s=0;for(let i of t.layers[o])s=Math.max(s,i.w);r+=s+e.layerGap}for(let o=0;o<t.layers.length;o+=1)for(let s of t.layers[o])s.x=n[o];for(let o of t.layers){let s=0;for(let i of o)i.y=s,s+=i.h+e.nodeGap}en(t,e,"y")}function lr(t,e){let n=[],r=0;for(let o=0;o<t.layers.length;o+=1){n.push(r);let s=0;for(let i of t.layers[o])s=Math.max(s,i.h);r+=s+e.layerGap}for(let o=0;o<t.layers.length;o+=1)for(let s of t.layers[o])s.y=n[o];for(let o of t.layers){let s=0;for(let i of o)i.x=s,s+=i.w+e.nodeGap}en(t,e,"x")}function en(t,e,n){let r=s=>n==="y"?s.h:s.w,o=e.nodeGap;for(let s=0;s<2;s+=1){let i=s===0?t.layers.slice(1):t.layers.slice(0,-1).reverse();for(let a of i){let c=new Map;for(let l of a){let p=s===0?l.in:l.out;if(p.length===0)continue;let h=[];for(let d of p){let g=t.nodes.get(s===0?d.fromId:d.toId);if(!g)continue;let m=n==="y"?g.y:g.x;h.push(m+Math.floor(r(g)/2))}if(h.length===0)continue;h.sort((d,g)=>d-g);let f=h[Math.floor(h.length/2)];c.set(l.id,f-Math.floor(r(l)/2))}let u=0;for(let l of a){let p=c.get(l.id),h=n==="y"?l.y:l.x,d=Math.max(p??h,u);n==="y"?l.y=d:l.x=d,u=d+r(l)+o}}}}function fr(t,e){let n=new Map;for(let u of t.hops){let l=n.get(u.chainId);l?l.push(u):n.set(u.chainId,[u])}for(let u of n.values())u.sort((l,p)=>l.hopIndex-p.hopIndex);let r=e.direction==="LR",o=u=>r?u.x:u.y,s=u=>r?u.w:u.h,i=u=>r?u.y+Math.floor(u.h/2):u.x+Math.floor(u.w/2),a=new Map;for(let u=0;u+1<t.layers.length;u+=1){let l=t.layers[u],p=t.layers[u+1],h=0;for(let _ of l)h=Math.max(h,o(_)+s(_));let f=Number.POSITIVE_INFINITY;for(let _ of p)f=Math.min(f,o(_));let d=Number.isFinite(f)?f-1:h,g=Math.max(1,d-h+1),m=[];for(let _ of l)for(let k of _.out)m.push(k);m.sort((_,k)=>{let A=i(t.nodes.get(_.fromId)),T=i(t.nodes.get(k.fromId));if(A!==T)return A-T;let R=i(t.nodes.get(_.toId)),N=i(t.nodes.get(k.toId));return R-N});let b=[],y=new Map;for(let _ of m){let k=i(t.nodes.get(_.fromId)),A=i(t.nodes.get(_.toId)),T=Math.min(k,A),R=Math.max(k,A),N=-1;for(let C=0;C<b.length;C+=1){let H=b[C],X=!0;for(let se of H)if(se.lo<=R&&T<=se.hi){X=!1;break}if(X){H.push({lo:T,hi:R}),N=C;break}}N<0&&(b.push([{lo:T,hi:R}]),N=b.length-1),y.set(_,N)}let v=b.length,x=g>=Math.max(3,v+2),O=x?h+1:h,S=x?d-1:d,w=Math.max(1,S-O+1);for(let _ of m){let k=y.get(_),A;if(v<=1)A=O+Math.floor(w/2);else{let T=(w-1)/(v-1);A=O+Math.floor(k*T)}a.set(_,Math.max(h,Math.min(d,A)))}}let c=[];for(let[,u]of n){let l=[];for(let h=0;h<u.length;h+=1){let f=u[h],d=t.nodes.get(f.fromId),g=t.nodes.get(f.toId),m=a.get(f),b=d.isVirtual?o(d):o(d)+s(d),y=g.isVirtual?o(g):o(g)-1,v=i(d),x=i(g);h===0&&We(l,r,b,v),v!==x&&(We(l,r,m,v),We(l,r,m,x)),We(l,r,y,x)}let p=u[0];c.push({from:p.chainFrom,to:p.chainTo,points:pr(l)})}return c}function We(t,e,n,r){t.push(e?{x:n,y:r}:{x:r,y:n})}function pr(t){let e=[];for(let n of t){let r=e[e.length-1];(!r||r.x!==n.x||r.y!==n.y)&&e.push(n)}return e}function hr(t){let e=0,n=0;for(let r of t.layers)for(let o of r)e=Math.max(e,o.x+o.w),n=Math.max(n,o.y+o.h);return{width:e,height:n}}var gr=24,mr=4,yr=1,br=3;function tn(t,e){let n=vr(e.direction),r=Math.max(3,e.maxLabelWidth??gr),o=e.asciiCharset??"unicode",s=Object.keys(t.nodes).sort(),i=new Set(s),a=t.edges.filter(f=>i.has(f.from)&&i.has(f.to)),c=new Map,u=new Map;for(let f of s){let d=Wt(f,r);c.set(f,d),u.set(f,He(d)+4)}let l=Qt({nodes:s,edges:a,widthCells:f=>u.get(f)??3,heightCells:()=>br,layerGap:mr,nodeGap:yr,direction:n}),p=Jt(l,{charset:o,labelOf:f=>c.get(f)??f}),h=e.logger;return h&&h(p),p}function vr(t){if(t===void 0||t==="LR")return"LR";if(t==="TD")return"TD";throw new Error(`ascii describe supports direction "LR" or "TD" only; got ${String(t)}`)}function nn(t,e,n,r={}){let o=e in t.nodes,s=n in t.nodes;if(!o)return Ue(e,n,"no-such-from");if(!s)return Ue(e,n,"no-such-to");let i=r.maxDepth;if(i!=null&&(!Number.isInteger(i)||i<0))throw new Error("explainPath: maxDepth must be an integer >= 0");if(e===n){if(r.findCycle===!0){let u=wr(t,e,r);if(u!=null)return u}let c=Ke(e,t.nodes[e],0,r);return qe(e,n,[c])}if(i===0)return Ue(e,n,"no-path");let a=rn(t,e,n,i);return a.found?qe(e,n,on(t,a.pathOrder,r)):Ue(e,n,a.truncated?"max-depth-exceeded":"no-path")}function rn(t,e,n,r){let o=new Map,s=[{path:n,depth:0}],i=new Set([n]),a=0,c=!1;for(;a<s.length;){let p=s[a++];if(p.path===e)break;if(r!=null&&p.depth>=r){let g=t.nodes[p.path];g?.deps&&g.deps.length>0&&(c=!0);continue}let h=t.nodes[p.path];if(h==null)continue;let f=h.deps??[],d=new Map;for(let g=0;g<f.length;g++){let m=f[g];if(!m)continue;let b=d.get(m);b==null&&(b=[],d.set(m,b)),b.push(g)}for(let[g,m]of d)i.has(g)||(i.add(g),o.set(g,{from:p.path,depIndices:m}),s.push({path:g,depth:p.depth+1}))}if(!o.has(e))return{found:!1,pathOrder:[],truncated:c};let u=[{path:e}],l=e;for(;l!==n;){let p=o.get(l);if(p==null)return{found:!1,pathOrder:[],truncated:!1};u[u.length-1].depIndices=p.depIndices,u.push({path:p.from}),l=p.from}return{found:!0,pathOrder:u,truncated:!1}}function wr(t,e,n){let r=t.nodes[e];if(r==null)return null;let o=r.deps??[],s=[];for(let a=0;a<o.length;a++)o[a]===e&&s.push(a);if(s.length>0){let a=Ke(e,r,0,n);a.dep_index=s[0];let c=Ke(e,r,1,n);return qe(e,e,[a,c])}let i=null;for(let a=0;a<o.length;a++){let c=o[a];if(!c||c===e)continue;let u=rn(t,c,e,n.maxDepth);u.found&&(i==null||u.pathOrder.length<i.pathOrder.length)&&(i=u,i={found:!0,pathOrder:[{path:e,depIndices:[a]},...u.pathOrder],truncated:!1})}return i==null?null:qe(e,e,on(t,i.pathOrder,n))}function on(t,e,n){return e.map((r,o)=>{let s=t.nodes[r.path],i=Ke(r.path,s,o,n);return r.depIndices!=null&&r.depIndices.length>0&&(i.dep_index=r.depIndices[0],r.depIndices.length>1&&(i.dep_indices=[...r.depIndices])),i})}function Ke(t,e,n,r){let o={path:t,type:e.type,hop:n};e.status!==void 0&&(o.status=e.status),"value"in e&&(o.value=e.value),e.v!=null&&(o.v=e.v);let s=r.annotations?.get(t)??e.annotation;s!=null&&(o.annotation=s);let i=r.lastMutations?.get(t)??e.lastMutation;return i!=null&&(o.lastMutation=i),o}function qe(t,e,n){return sn(t,e,!0,"ok",n)}function Ue(t,e,n){return sn(t,e,!1,n,[])}function sn(t,e,n,r,o){let s=_r(t,e,n,r,o);return{from:t,to:e,found:n,reason:r,steps:o,text:s,toJSON(){return{from:t,to:e,found:n,reason:r,steps:o}}}}function _r(t,e,n,r,o){if(!n)switch(r){case"no-such-from":return`explainPath: no node named "${t}"`;case"no-such-to":return`explainPath: no node named "${e}"`;case"max-depth-exceeded":return`explainPath: no path from "${t}" to "${e}" within maxDepth`;default:return`explainPath: no path from "${t}" to "${e}"`}let s=[`Causal path: ${t} \u2192 ${e} (${o.length} step(s))`];for(let i of o){let c=` ${i.hop===0?"\xB7":"\u2193"} ${i.path} (${i.type}${i.status?`/${i.status}`:""})`;if(s.push(c),"value"in i&&s.push(` value: ${xr(i.value)}`),i.annotation!=null&&s.push(` annotation: ${i.annotation}`),i.lastMutation!=null){let u=i.lastMutation.actor;s.push(` actor: ${u.type}${u.id?`:${u.id}`:""}`)}}return s.join(`
1
+ "use strict";var rt=Object.defineProperty;var Cn=Object.getOwnPropertyDescriptor;var Dn=Object.getOwnPropertyNames;var Gn=Object.prototype.hasOwnProperty;var q=(t,e)=>()=>(t&&(e=t(t=0)),e);var Mn=(t,e)=>{for(var n in e)rt(t,n,{get:e[n],enumerable:!0})},$n=(t,e,n,r)=>{if(e&&typeof e=="object"||typeof e=="function")for(let o of Dn(e))!Gn.call(t,o)&&o!==n&&rt(t,o,{get:()=>e[o],enumerable:!(r=Cn(e,o))||r.enumerable});return t};var Pn=t=>$n(rt({},"__esModule",{value:!0}),t);function Rt(t,e){let n=new TextEncoder().encode(t.name);if(n.length===0||n.length>255)throw new Error(`encodeEnvelope: codec name "${t.name}" encodes to ${n.length} bytes (must be 1\u2013255)`);let r=t.version;if(!Number.isInteger(r)||r<0||r>65535)throw new Error(`encodeEnvelope: codec.version ${r} out of u16 range (expected integer 0\u201365535)`);let o=2+n.length+2+e.length;if(o>4294967295)throw new Error(`encodeEnvelope: total envelope size ${o} exceeds 2^32-1 bytes (payload ${e.length} bytes)`);let s=new Uint8Array(o),i=0;return s[i++]=ot,s[i++]=n.length,s.set(n,i),i+=n.length,s[i++]=r>>>8&255,s[i++]=r&255,s.set(e,i),s}function At(t,e){if(t.length<kt)throw new Error(`decodeEnvelope: bytes too short (${t.length} < ${kt})`);let n=0,r=t[n++];if(r!==ot)throw new Error(`decodeEnvelope: unsupported envelope version ${r} (expected ${ot})`);let o=t[n++];if(o===0)throw new Error("decodeEnvelope: name_len must be >= 1");if(n+o+2>t.length)throw new Error(`decodeEnvelope: envelope truncated (need ${n+o+2} bytes, have ${t.length})`);let s=new TextDecoder().decode(t.subarray(n,n+o));n+=o;let i=(t[n]<<8|t[n+1])>>>0;n+=2;let a=t.subarray(n),c=e.lookupCodec(s);if(c==null)throw new Error(`decodeEnvelope: codec "${s}" not registered (envelope codec_v=${i})`);return{codec:c,codecVersion:i,payload:a}}function Ct(t){t.registerCodec(Ln)}var Ln,ot,kt,st=q(()=>{"use strict";Ln={name:"json",version:1,contentType:"application/json",encode(t){let e=JSON.stringify(t);return new TextEncoder().encode(e)},decode(t,e){let n=new TextDecoder().decode(t);return JSON.parse(n)}},ot=1,kt=4});function Ae(t){if(t==null)return le;let{type:e,id:n,...r}=t;return{type:e??"system",id:n??"",...r}}var le,it=q(()=>{"use strict";le={type:"system",id:""}});function Ce(){return fe>0||_e}function Dt(){return fe>0}function Se(t){fe>0?xe.push(t):t()}function De(t){fe+=1;let e=!1;try{t()}catch(n){throw e=!0,n}finally{if(fe-=1,fe===0)if(e){if(!_e){let n=xe.splice(0);for(let r of n)try{r()}catch{}ie.length=0,ae.length=0,pe.length=0}}else Fn()}}function Fn(){let t=!_e;t&&(_e=!0);let e=[],n=0;try{for(;ie.length>0||ae.length>0||pe.length>0||t&&xe.length>0;){if(t&&xe.length>0){let s=xe.splice(0);for(let i of s)try{i()}catch(a){e.push(a)}continue}if(n+=1,n>1e3)throw ie.length=0,ae.length=0,pe.length=0,new Error("batch drain exceeded 1000 iterations \u2014 likely a reactive cycle");let o=(ie.length>0?ie:ae.length>0?ae:pe).splice(0);for(let s of o)try{s()}catch(i){e.push(i)}}}finally{t&&(_e=!1)}if(e.length===1)throw e[0];if(e.length>1)throw new AggregateError(e,"batch drain: multiple callbacks threw")}function Ge(t,e,n){if(e.length===0)return;if(e.length===1){let u=n(e[0][0]);if(u<3||!Ce()){t(e);return}(u>=5?pe:u===4?ae:ie).push(()=>t(e));return}let r=e.length,o=r,s=r,i=r,a=0;for(;a<r&&n(e[a][0])<3;)a++;for(o=a;a<r&&n(e[a][0])===3;)a++;for(s=a;a<r&&n(e[a][0])===4;)a++;i=a;let c=Ce();if(o>0){let u=e.slice(0,o);t(u)}if(s>o){let u=e.slice(o,s);c?ie.push(()=>t(u)):t(u)}if(i>s){let u=e.slice(s,i);c?ae.push(()=>t(u)):t(u)}if(r>i){let u=e.slice(i,r);c?pe.push(()=>t(u)):t(u)}}var fe,_e,ie,ae,pe,xe,Me=q(()=>{"use strict";fe=0,_e=!1,ie=[],ae=[],pe=[],xe=[]});function he(){return Math.trunc(performance.now()*1e6)}function ge(){return Date.now()*1e6}var $e=q(()=>{"use strict"});var Oe,L,z,U,Z,Q,ee,V,j,M,me,at,In,ct,jn,Bn,ut,Gt,Mt,$t,dt,ce=q(()=>{"use strict";Oe=Symbol.for("graphrefly/START"),L=Symbol.for("graphrefly/DATA"),z=Symbol.for("graphrefly/DIRTY"),U=Symbol.for("graphrefly/RESOLVED"),Z=Symbol.for("graphrefly/INVALIDATE"),Q=Symbol.for("graphrefly/PAUSE"),ee=Symbol.for("graphrefly/RESUME"),V=Symbol.for("graphrefly/TEARDOWN"),j=Symbol.for("graphrefly/COMPLETE"),M=Symbol.for("graphrefly/ERROR"),me=Object.freeze([z]),at=Object.freeze([U]),In=Object.freeze([Z]),ct=Object.freeze([Oe]),jn=Object.freeze([j]),Bn=Object.freeze([V]),ut=Object.freeze([me]),Gt=Object.freeze([at]),Mt=Object.freeze([In]),$t=Object.freeze([jn]),dt=Object.freeze([Bn])});function Pt(t){t.registerMessageType(Oe,{tier:0,wireCrossing:!1}),t.registerMessageType(z,{tier:1,wireCrossing:!1}),t.registerMessageType(Z,{tier:1,wireCrossing:!1,metaPassthrough:!1}),t.registerMessageType(Q,{tier:2,wireCrossing:!1}),t.registerMessageType(ee,{tier:2,wireCrossing:!1}),t.registerMessageType(L,{tier:3,wireCrossing:!0}),t.registerMessageType(U,{tier:3,wireCrossing:!0}),t.registerMessageType(j,{tier:4,wireCrossing:!0,metaPassthrough:!1}),t.registerMessageType(M,{tier:4,wireCrossing:!0,metaPassthrough:!1}),t.registerMessageType(V,{tier:5,wireCrossing:!0,metaPassthrough:!1})}var Pe,Lt=q(()=>{"use strict";ce();Pe=class{_messageTypes=new Map;_codecs=new Map;_onMessage;_onSubscribe;_defaultVersioning;_defaultHashFn;_inspectorEnabled=!(typeof process<"u"&&process.env?.NODE_ENV==="production");_globalInspector;_frozen=!1;tierOf;constructor(e){this._onMessage=e.onMessage,this._onSubscribe=e.onSubscribe,this._defaultVersioning=e.defaultVersioning,this._defaultHashFn=e.defaultHashFn,this.tierOf=n=>{let r=this._messageTypes.get(n);return r!=null?r.tier:1}}get onMessage(){return this._frozen=!0,this._onMessage}get onSubscribe(){return this._frozen=!0,this._onSubscribe}set onMessage(e){this._assertUnfrozen(),this._onMessage=e}set onSubscribe(e){this._assertUnfrozen(),this._onSubscribe=e}get defaultVersioning(){return this._defaultVersioning}set defaultVersioning(e){this._assertUnfrozen(),this._defaultVersioning=e}get defaultHashFn(){return this._defaultHashFn}set defaultHashFn(e){this._assertUnfrozen(),this._defaultHashFn=e}get inspectorEnabled(){return this._inspectorEnabled}set inspectorEnabled(e){this._inspectorEnabled=e}get globalInspector(){return this._globalInspector}set globalInspector(e){this._globalInspector=e}registerMessageType(e,n){return this._assertUnfrozen(),this._messageTypes.set(e,{tier:n.tier,wireCrossing:n.wireCrossing??n.tier>=3,metaPassthrough:n.metaPassthrough??!0}),this}messageTier(e){let n=this._messageTypes.get(e);return n!=null?n.tier:1}isWireCrossing(e){let n=this._messageTypes.get(e);return n!=null?n.wireCrossing:!0}isLocalOnly(e){return!this.isWireCrossing(e)}isMetaPassthrough(e){let n=this._messageTypes.get(e);return n!=null?n.metaPassthrough:!0}isKnownMessageType(e){return this._messageTypes.has(e)}registerCodec(e){return this._assertUnfrozen(),this._codecs.set(e.name,e),this}lookupCodec(e){return this._codecs.get(e)}_isFrozen(){return this._frozen}_assertUnfrozen(){if(this._frozen)throw new Error("GraphReFlyConfig is frozen: a node has already captured this config. Register custom types and set hooks before creating any node.")}}});function lt(t){let e=Vn.filter(n=>t({type:n,id:""},"write"));return e.length===0?"restricted":e.includes("human")&&e.includes("llm")&&e.every(n=>n==="human"||n==="llm"||n==="system")?"both":e.length===1?e[0]:e.join("+")}var J,Vn,Le=q(()=>{"use strict";J=class extends Error{actor;action;nodeName;constructor(e,n){super(n??`GuardDenied: action "${String(e.action)}" denied for actor type "${String(e.actor.type)}"`),this.name="GuardDenied",this.actor=e.actor,this.action=e.action,this.nodeName=e.nodeName}get node(){return this.nodeName}},Vn=["human","llm","wallet","system"]});function ft(t){if(t===void 0)return null;if(typeof t=="number"){if(!Number.isFinite(t))throw new TypeError(`Cannot hash non-finite number: ${t}`);if(Number.isInteger(t)&&!Number.isSafeInteger(t))throw new TypeError(`Cannot hash integer outside safe range (|n| > 2^53-1): ${t}. Cross-language cid parity is not guaranteed for unsafe integers.`);return t}if(typeof t=="string"||typeof t=="boolean"||t===null)return t;if(Array.isArray(t))return t.map(ft);if(typeof t=="object"&&t!==null){let e={};for(let n of Object.keys(t).sort())e[n]=ft(t[n]);return e}return null}function Un(t){let e=zn.encode(t),n=e.length,r=n*8,o=n+9+63&-64,s=new Uint8Array(o);s.set(e),s[n]=128;let i=new DataView(s.buffer);i.setUint32(o-4,r>>>0,!1),i.setUint32(o-8,Math.floor(r/4294967296)>>>0,!1);let a=1779033703,c=3144134277,u=1013904242,l=2773480762,p=1359893119,h=2600822924,f=528734635,d=1541459225,g=new Uint32Array(64),m=(y,v)=>y>>>v|y<<32-v;for(let y=0;y<o;y+=64){for(let T=0;T<16;T++)g[T]=i.getUint32(y+T*4,!1);for(let T=16;T<64;T++){let R=g[T-15],N=g[T-2],D=m(R,7)^m(R,18)^R>>>3,H=m(N,17)^m(N,19)^N>>>10;g[T]=g[T-16]+D+g[T-7]+H>>>0}let v=a,x=c,O=u,S=l,w=p,_=h,k=f,A=d;for(let T=0;T<64;T++){let R=m(w,6)^m(w,11)^m(w,25),N=w&_^~w&k,D=A+R+N+Hn[T]+g[T]>>>0,H=m(v,2)^m(v,13)^m(v,22),X=v&x^v&O^x&O,se=H+X>>>0;A=k,k=_,_=w,w=S+D>>>0,S=O,O=x,x=v,v=D+se>>>0}a=a+v>>>0,c=c+x>>>0,u=u+O>>>0,l=l+S>>>0,p=p+w>>>0,h=h+_>>>0,f=f+k>>>0,d=d+A>>>0}let b=y=>y.toString(16).padStart(8,"0");return b(a)+b(c)+b(u)+b(l)+b(p)+b(h)+b(f)+b(d)}function pt(t){let e=ft(t??null),n=JSON.stringify(e);return Un(n).slice(0,16)}function Wn(){let t=globalThis.crypto;if(t?.randomUUID)return t.randomUUID();let e=()=>Math.floor(Math.random()*4294967296).toString(16).padStart(8,"0"),n=e()+e()+e()+e();return`${n.slice(0,8)}-${n.slice(8,12)}-4${n.slice(13,16)}-${(parseInt(n.slice(16,17),16)&3|8).toString(16)}${n.slice(17,20)}-${n.slice(20,32)}`}function ht(t,e,n){let r=n?.id??Wn();if(t===0)return{id:r,version:0};let s=(n?.hash??pt)(e);return{id:r,version:0,cid:s,prev:null}}function Ft(t,e,n){t.version+=1,"cid"in t&&(t.prev=t.cid,t.cid=n(e))}var Hn,zn,It=q(()=>{"use strict";Hn=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]),zn=new TextEncoder});function Vt(t){return{node:t,unsub:null,prevData:void 0,dirty:!1,involvedThisWave:!1,dataBatch:[],terminal:void 0}}function gt(t){t.prevData=void 0,t.dirty=!1,t.involvedThisWave=!1,t.dataBatch.length=0,t.terminal=void 0}function Fe(t){return t.length===0?t:typeof t[0]=="symbol"?[t]:t}function ue(t,e,n){let r=Ht(t)?t:[],o=typeof t=="function"?t:typeof e=="function"?e:void 0,s={};return Ht(t)?s=(mt(e)?e:n)??{}:mt(t)?s=t:s=(mt(e)?e:n)??{},new F(r,o,s)}var jt,Bt,Kn,qn,ye,F,Ht,mt,be=q(()=>{"use strict";st();it();Me();$e();Lt();Le();ce();It();jt=()=>{},Bt=100;Kn=(t,e,n,r)=>{n.direction==="down-in"&&t._onDepMessage(n.depIndex,e)},qn=(t,e,n,r)=>{let o=t;if(o._status==="completed"||o._status==="errored")return;let s=o._cached,i=s===void 0?[ct]:[ct,[L,s]];o._status==="dirty"&&i.push(me),Ge(e,i,o._config.tierOf)},ye=new Pe({onMessage:Kn,onSubscribe:qn});Pt(ye);Ct(ye);F=class t{_optsName;_describeKind;meta;_hasMeta;_config;_deps;_sinks=null;_sinkCount=0;_cached;_status;_cleanup;_store={};_waveHasNewData=!1;_hasNewTerminal=!1;_hasCalledFnOnce=!1;_paused=!1;_pendingWave=!1;_isExecutingFn=!1;_pendingRerun=!1;_rerunDepth=0;_dirtyDepCount=0;_batchPendingMessages=null;_pauseLocks=null;_pauseBuffer=null;_fn;_equals;_resubscribable;_resetOnTeardown;_autoComplete;_autoError;_pausable;_partial;_guard;_extraGuards;_hashFn;_versioning;_versioningLevel;_lastMutation;_inspectorHooks;_actions;constructor(e,n,r){this._config=r.config??ye,this._config.onMessage,this._optsName=r.name,this._describeKind=r.describeKind,this._equals=r.equals??Object.is,this._resubscribable=r.resubscribable??!1,this._resetOnTeardown=r.resetOnTeardown??!1,this._autoComplete=r.completeWhenDepsComplete??!0,this._autoError=r.errorWhenDepsError??!0,this._pausable=r.pausable??!0,this._guard=r.guard,this._fn=n,this._partial=r.partial??!1,this._cached=r.initial!==void 0?r.initial:void 0,this._status=e.length===0&&n==null&&this._cached!==void 0?"settled":"sentinel",this._hashFn=r.versioningHash??this._config.defaultHashFn??pt;let o=r.versioning??this._config.defaultVersioning;this._versioningLevel=o,this._versioning=o!=null?ht(o,this._cached===void 0?void 0:this._cached,{id:r.versioningId,hash:this._hashFn}):void 0,this._deps=e.map(Vt);let s={};for(let[a,c]of Object.entries(r.meta??{})){let u={initial:c,name:`${r.name??"node"}:meta:${a}`,describeKind:"state",config:this._config};r.guard!=null&&(u.guard=r.guard),s[a]=new t([],void 0,u)}Object.freeze(s),this.meta=s,this._hasMeta=Object.keys(s).length>0;let i=this;this._actions={emit(a){i._emit([[L,a]])},down(a){i._emit(Fe(a))},up(a){i._emitUp(Fe(a))}},this.down=this.down.bind(this),this.up=this.up.bind(this)}get _isTerminal(){return this._status==="completed"||this._status==="errored"}get name(){return this._optsName}get status(){return this._status}get cache(){return this._cached===void 0?void 0:this._cached}get lastMutation(){return this._lastMutation}get v(){return this._versioning}hasGuard(){return this._guard!=null}_applyVersioning(e,n){if(this._isExecutingFn)throw new Error(`Node "${this.name}": _applyVersioning cannot run mid-fn \u2014 call it outside of \`_execFn\` (typically at graph setup time before the first subscribe).`);let r=this._versioningLevel;if(r!=null&&e<=r)return;let o=n?.hash??this._hashFn;o!==this._hashFn&&(this._hashFn=o);let s=this._cached===void 0?void 0:this._cached,i=this._versioning,a=i?.id??n?.id,c=i?.version??0,u=ht(e,s,{id:a,hash:o});u.version=c,this._versioning=u,this._versioningLevel=e}_setInspectorHook(e){return e==null?()=>{}:(this._inspectorHooks==null&&(this._inspectorHooks=new Set),this._inspectorHooks.add(e),()=>{this._inspectorHooks?.delete(e),this._inspectorHooks?.size===0&&(this._inspectorHooks=void 0)})}_pushGuard(e){return this._extraGuards==null&&(this._extraGuards=new Set),this._extraGuards.add(e),()=>{this._extraGuards?.delete(e),this._extraGuards?.size===0&&(this._extraGuards=void 0)}}allowsObserve(e){if(this._guard==null&&this._extraGuards==null)return!0;let n=Ae(e);if(this._guard!=null&&!this._guard(n,"observe"))return!1;if(this._extraGuards!=null){for(let r of this._extraGuards)if(!r(n,"observe"))return!1}return!0}_checkGuard(e){if(e?.internal)return;let n=this._guard!=null||this._extraGuards!=null,r=e?.actor!=null;if(!n&&!r)return;let o=Ae(e?.actor),s=e?.delivery==="signal"?"signal":"write";if(this._guard!=null&&!this._guard(o,s))throw new J({actor:o,action:s,nodeName:this.name});if(this._extraGuards!=null){for(let i of this._extraGuards)if(!i(o,s))throw new J({actor:o,action:s,nodeName:this.name})}this._lastMutation={actor:o,timestamp_ns:ge()}}down(e,n){let r=Fe(e);r.length!==0&&(this._checkGuard(n),this._emit(r))}emit(e,n){this._checkGuard(n),this._emit([[L,e]])}up(e,n){if(this._deps.length===0)return;let r=Fe(e);if(r.length===0)return;this._checkGuard(n);let o=n??{internal:!0};this._validateUpTiers(r);for(let s of this._deps)s.node.up?.(r,o)}_emitUp(e){if(this._deps.length!==0&&e.length!==0){this._validateUpTiers(e);for(let n of this._deps)n.node.up?.(e,{internal:!0})}}_validateUpTiers(e){let n=this._config.tierOf;for(let r of e){let o=n(r[0]);if(o===3||o===4)throw new Error(`Node "${this.name}": tier-${o} messages cannot flow up \u2014 DATA/RESOLVED/COMPLETE/ERROR are downstream-only. Use \`down(...)\` for value delivery; \`up(...)\` is for control signals (DIRTY, INVALIDATE, PAUSE, RESUME, TEARDOWN).`)}}subscribe(e,n){if(n!=null&&this._guard!=null){let c=Ae(n);if(!this._guard(c,"observe"))throw new J({actor:c,action:"observe",nodeName:this.name})}let o=this._isTerminal&&this._resubscribable;if(o){this._cached=void 0,this._status="sentinel",this._store={},this._hasCalledFnOnce=!1,this._waveHasNewData=!1,this._hasNewTerminal=!1,this._paused=!1,this._pendingWave=!1,this._pendingRerun=!1,this._isExecutingFn=!1,this._rerunDepth=0,this._dirtyDepCount=0,this._pauseLocks=null,this._pauseBuffer=null;for(let c of this._deps)gt(c);if(this._partial===!1){for(let c of this._deps)if(c.prevData!==void 0||c.dataBatch.length!==0||c.terminal!==void 0||c.dirty)throw new Error(`resubscribable-reset invariant: DepRecord not fully reset for node ${this._optsName??"(anonymous)"}`)}}this._sinkCount+=1;let s;try{s=this._config.onSubscribe(this,e,{sinkCount:this._sinkCount,afterTerminalReset:o},this._actions)}catch(c){throw this._sinkCount-=1,c}this._sinks==null?this._sinks=e:typeof this._sinks=="function"?this._sinks=new Set([this._sinks,e]):this._sinks.add(e);let i=this._isTerminal;if(this._sinkCount===1&&!i)try{this._activate()}catch(c){if(this._sinkCount-=1,this._removeSink(e),this._sinkCount===0&&(this._status="sentinel"),typeof s=="function")try{s()}catch{}throw c}this._status==="sentinel"&&this._cached===void 0&&(this._status="pending");let a=!1;return()=>{a||(a=!0,this._sinkCount-=1,this._removeSink(e),typeof s=="function"&&s(),this._sinks==null&&this._deactivate())}}_removeSink(e){if(this._sinks===e)this._sinks=null;else if(this._sinks!=null&&typeof this._sinks!="function")if(this._sinks.delete(e),this._sinks.size===1){let[n]=this._sinks;this._sinks=n}else this._sinks.size===0&&(this._sinks=null)}_activate(){if(this._deps.length===0){this._fn&&this._execFn();return}this._dirtyDepCount=0;let e=this._deps.length,n=0;try{for(let r=0;r<e;r++){let o=r,s=this._deps[r];s.unsub=jt,s.unsub=s.node.subscribe(i=>{if(s.unsub===null)return;let a=this._config.tierOf,c=!1;for(let u of i)a(u[0])>=3&&(c=!0),this._config.onMessage(this,u,{direction:"down-in",depIndex:o},this._actions);c&&this._maybeRunFnOnSettlement()}),n++}}catch(r){this._deps[n].unsub=null;for(let o=0;o<n;o++){let s=this._deps[o];if(s.unsub!=null){let i=s.unsub;s.unsub=null;try{i()}catch{}gt(s)}}throw this._dirtyDepCount=0,r}}_addDep(e){for(let o=0;o<this._deps.length;o++)if(this._deps[o].node===e)return o;let n=this._deps.length,r=Vt(e);if(this._deps.push(r),this._sinks==null)return n;r.dirty=!0,this._dirtyDepCount++,this._status!=="dirty"&&this._emit(ut),r.unsub=jt;try{r.unsub=e.subscribe(o=>{if(r.unsub===null)return;let s=this._config.tierOf,i=!1;for(let a of o)s(a[0])>=3&&(i=!0),this._config.onMessage(this,a,{direction:"down-in",depIndex:n},this._actions);i&&this._maybeRunFnOnSettlement()})}catch(o){throw r.unsub=null,this._deps.pop(),this._dirtyDepCount--,o}return n}_deactivate(e=!1){let n=this._cleanup;if(this._cleanup=void 0,typeof n=="function")try{n()}catch(r){this._emit([[M,this._wrapFnError("cleanup threw",r)]])}else if(n!=null&&typeof n=="object"){let r=n.deactivate;if(typeof r=="function")try{r()}catch(o){this._emit([[M,this._wrapFnError("cleanup.deactivate threw",o)]])}}for(let r of this._deps){if(r.unsub!=null){let o=r.unsub;r.unsub=null;try{o()}catch{}}gt(r)}this._waveHasNewData=!1,this._hasNewTerminal=!1,this._hasCalledFnOnce=!1,this._paused=!1,this._pendingWave=!1,this._pendingRerun=!1,this._rerunDepth=0,this._store={},this._dirtyDepCount=0,this._pauseLocks=null,this._pauseBuffer=null,this._fn!=null&&(this._cached=void 0),e||(this._fn!=null||this._deps.length>0)&&(!this._isTerminal||this._resubscribable)&&(this._status="sentinel")}_onDepMessage(e,n){let r=this._deps[e],o=n[0];if(this._inspectorHooks!=null){let s={kind:"dep_message",depIndex:e,message:n};for(let i of this._inspectorHooks)i(s)}if(o!==Oe){if(o===z){this._depDirtied(r);return}if(o===Z){if(this._depInvalidated(r),this._cached===void 0)return;this._emit(Mt);return}if(o===Q||o===ee){this._emit([n]);return}if(o===V){this._emit(dt);return}if(o===L)this._depSettledAsData(r,n[1]);else if(o===U)this._depSettledAsResolved(r);else if(o===j)this._depSettledAsTerminal(r,!0);else if(o===M)this._depSettledAsTerminal(r,n[1]);else{this._emit([n]);return}if(!this._fn){(o===L||o===U)&&this._emit([n]),(o===j||o===M)&&this._maybeAutoTerminalAfterWave();return}}}_depDirtied(e){e.dirty||(e.dirty=!0,e.involvedThisWave=!0,this._dirtyDepCount++,this._status!=="dirty"&&this._emit(ut))}_depSettledAsData(e,n){e.dirty&&(e.dirty=!1,this._dirtyDepCount--),e.involvedThisWave=!0,e.dataBatch.push(n),this._waveHasNewData=!0}_depSettledAsResolved(e){e.dirty&&(e.dirty=!1,this._dirtyDepCount--)}_depSettledAsTerminal(e,n){e.dirty&&(e.dirty=!1,this._dirtyDepCount--),e.terminal=n,e.involvedThisWave=!0,this._hasNewTerminal=!0}_depInvalidated(e){e.prevData=void 0,e.terminal=void 0,e.dataBatch.length=0,e.dirty?e.involvedThisWave=!1:(e.dirty=!0,e.involvedThisWave=!0,this._dirtyDepCount++)}_maybeRunFnOnSettlement(){if(!(this._isTerminal&&!this._resubscribable)&&!(this._dirtyDepCount>0)){if(!this._partial&&!this._hasCalledFnOnce)for(let e=0;e<this._deps.length;e++){let n=this._deps[e];if(n.dataBatch.length===0&&n.prevData===void 0&&n.terminal===void 0){this._maybeAutoTerminalAfterWave();return}}if(this._paused){this._pendingWave=!0;return}if(!this._waveHasNewData&&!this._hasNewTerminal&&this._hasCalledFnOnce){this._clearWaveFlags(),this._emit(Gt),this._maybeAutoTerminalAfterWave();return}this._fn&&this._execFn(),this._maybeAutoTerminalAfterWave()}}_maybeAutoTerminalAfterWave(){if(this._deps.length===0||this._isTerminal)return;let e=this._deps.find(n=>n.terminal!==void 0&&n.terminal!==!0);if(e!=null){this._autoError&&this._emit([[M,e.terminal]]);return}this._autoComplete&&this._deps.every(n=>n.terminal!==void 0)&&this._emit($t)}_execFn(){if(!this._fn||this._isTerminal&&!this._resubscribable)return;if(this._isExecutingFn){this._pendingRerun=!0;return}let e=this._cleanup;if(typeof e=="function"){this._cleanup=void 0;try{e()}catch(i){this._emit([[M,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([[M,this._wrapFnError("cleanup.beforeRun threw",a)]]);return}}}let n=this._deps.map(i=>i.involvedThisWave?i.dataBatch.length>0?[...i.dataBatch]:[]:void 0),r=this._deps.map(i=>i.prevData);for(let i=0;i<this._deps.length;i++){let a=n[i];a!=null&&a.length>0&&(this._deps[i].prevData=a[a.length-1])}let o=this._deps.map(i=>i.terminal),s={prevData:r,terminalDeps:o,store:this._store};if(this._hasCalledFnOnce=!0,this._clearWaveFlags(),this._inspectorHooks!=null){let i={kind:"run",batchData:n,prevData:r};for(let a of this._inspectorHooks)a(i)}this._isExecutingFn=!0;try{let i=this._fn(n,this._actions,s);if(typeof i=="function")this._cleanup=i;else if(i!=null&&typeof i=="object"){let a=i;(typeof a.beforeRun=="function"||typeof a.deactivate=="function"||typeof a.invalidate=="function")&&(this._cleanup=i)}}catch(i){this._emit([[M,this._wrapFnError("fn threw",i)]])}finally{this._isExecutingFn=!1,this._pendingRerun?(this._pendingRerun=!1,this._rerunDepth+=1,this._rerunDepth>Bt?(this._rerunDepth=0,this._emit([[M,new Error(`Node "${this.name}": _pendingRerun depth exceeded ${Bt} \u2014 likely a reactive cycle`)]])):this._maybeRunFnOnSettlement()):this._rerunDepth=0,this._clearWaveFlags()}}_clearWaveFlags(){this._waveHasNewData=!1,this._hasNewTerminal=!1;for(let e of this._deps)e.involvedThisWave=!1,e.dataBatch.length=0}_wrapFnError(e,n){let r=n instanceof Error?n.message:String(n);return new Error(`Node "${this.name}": ${e}: ${r}`,{cause:n})}_frameBatch(e){let n=this._config.tierOf;if(e.length===1)return n(e[0][0])===3&&this._status!=="dirty"?[me,e[0]]:e;let r=!0,o=!1,s=!1,i=-1;for(let c of e){let u=n(c[0]);u<i&&(r=!1),u===3&&(o=!0),c[0]===z&&(s=!0),i=u}let a=e;if(!r){let c=e.map((u,l)=>({m:u,i:l,tier:n(u[0])}));c.sort((u,l)=>u.tier-l.tier||u.i-l.i),a=c.map(u=>u.m)}if(o&&!s&&this._status!=="dirty"){let c=0;for(;c<a.length&&n(a[c][0])===0;)c++;return c===0?[me,...a]:[...a.slice(0,c),me,...a.slice(c)]}return a}_emit(e){if(e.length===0)return;for(let a=0;a<e.length;a++){let c=e[a];if(c[0]===M&&c[1]===void 0)throw new TypeError('[ERROR, payload] requires a non-undefined payload (spec \xA71.2). Pass an Error object or domain tag instead \u2014 e.g. node.down([[ERROR, new Error("reason")]])')}let n=e;if(this._isTerminal&&!this._resubscribable){let a=e.filter(c=>c[0]===V||c[0]===Z);if(a.length===0)return;n=a}n=this._frameBatch(n);let o=null;for(let a=0;a<n.length;a++){let c=n[a],u=c[0];if(u!==Q&&u!==ee){o?.push(c);continue}if(c.length<2)throw new Error(`Node "${this.name}": [[${u===Q?"PAUSE":"RESUME"}]] must carry a lockId payload \u2014 bare PAUSE/RESUME is a protocol violation (C0 rule). Use \`[[PAUSE, lockId]]\` / \`[[RESUME, lockId]]\`.`);let l=!0;if(this._pausable!==!1){let p=c[1];if(u===Q)this._pauseLocks==null&&(this._pauseLocks=new Set),this._pauseLocks.add(p),this._paused=!0,this._pausable==="resumeAll"&&this._pauseBuffer==null&&(this._pauseBuffer=[]);else if(this._pauseLocks==null||!this._pauseLocks.has(p))l=!1;else if(this._pauseLocks.delete(p),this._pauseLocks.size===0){if(this._paused=!1,this._pauseBuffer!=null&&this._pauseBuffer.length>0){let h=this._pauseBuffer;this._pauseBuffer=[],this._emit(h)}this._pendingWave&&(this._pendingWave=!1,this._maybeRunFnOnSettlement())}}l?o?.push(c):o==null&&(o=n.slice(0,a))}if(o!=null){if(o.length===0)return;n=o}if(this._hasMeta&&n.some(a=>a[0]===V))for(let a of Object.keys(this.meta))try{this.meta[a]._emit(dt)}catch{}let{finalMessages:s,equalsError:i}=this._updateState(n);if(s.length>0&&this._config.inspectorEnabled){let a=this._config.globalInspector;if(a!=null)try{a({kind:"emit",node:this,messages:s})}catch{}}if(s.length>0)if(this._paused&&this._pausable==="resumeAll"&&this._pauseBuffer!=null){let a=this._config.tierOf,c=[];for(let u of s)a(u[0])===3?this._pauseBuffer.push(u):c.push(u);c.length>0&&this._dispatchOrAccumulate(c)}else this._dispatchOrAccumulate(s);i!=null&&this._emit([[M,i]])}_updateState(e){let n=this._config.tierOf,r,o,s=-1,i=0;for(let l of e)n(l[0])===3&&i++;let a=i<=1,c=-1;if(this._versioning!=null&&i>1){for(let l=e.length-1;l>=0;l--)if(e[l][0]===L){c=l;break}}for(let l=0;l<e.length;l++){let p=e[l],h=p[0];if(h===L){if(p.length>=2){let f=!1;if(a&&this._cached!==void 0)try{f=this._equals(this._cached,p[1])}catch(d){o=this._wrapFnError("equals threw",d),s=l;break}if(f){r==null&&(r=e.slice(0,l)),r.push(at),this._status="resolved";continue}this._cached=p[1],this._versioning!=null&&(c<0||l===c)&&Ft(this._versioning,p[1],this._hashFn)}this._status="settled",r?.push(p)}else if(r?.push(p),h===z)this._status="dirty";else if(h===U)this._status="resolved";else if(h===j)this._status="completed";else if(h===M)this._status="errored";else if(h===Z){this._cached=void 0,this._status="dirty";let f=this._cleanup;if(typeof f=="function"){this._cleanup=void 0;try{f()}catch{}}else if(f!=null&&typeof f=="object"){let d=f.invalidate;if(typeof d=="function")try{d()}catch{}}}else h===V&&(this._resetOnTeardown&&(this._cached=void 0),this._deactivate(!0),this._status="sentinel")}let u=s>=0?r??e.slice(0,s):r??e;return o!=null?{finalMessages:u,equalsError:o}:{finalMessages:u}}_deliverToSinks=e=>{if(this._sinks==null)return;if(typeof this._sinks=="function"){this._sinks(e);return}let n=[...this._sinks];for(let r of n)r(e)};_dispatchOrAccumulate(e){if(Dt()){this._batchPendingMessages===null&&(this._batchPendingMessages=[],Se(()=>this._flushBatchPending()));for(let n of e)this._batchPendingMessages.push(n);return}Ge(this._deliverToSinks,e,this._config.tierOf)}_flushBatchPending(){let e=this._batchPendingMessages;if(e===null||(this._batchPendingMessages=null,e.length===0))return;let n=this._frameBatch(e);Ge(this._deliverToSinks,n,this._config.tierOf)}},Ht=t=>Array.isArray(t),mt=t=>typeof t=="object"&&t!=null&&!Array.isArray(t)});function te(t,e){return ue([],{...e,initial:t})}function Te(t,e){return ue((r,o,s)=>t(o,s)??void 0,{describeKind:"producer",...e})}function de(t,e,n){return ue(t,(o,s,i)=>{let a=o.map((c,u)=>c!=null&&c.length>0?c.at(-1):i.prevData[u]);s.emit(e(a,i))},{describeKind:"derived",...n})}function Ie(t,e,n){return ue(t,(o,s,i)=>{let a=o.map((c,u)=>c!=null&&c.length>0?c.at(-1):i.prevData[u]);return e(a,s,i)??void 0},{describeKind:"effect",...n})}var je=q(()=>{"use strict";be()});function ve(t){return t.subscribe(()=>{})}var bt=q(()=>{"use strict"});var Ve,zt=q(()=>{"use strict";Ve=class{_timer;_gen=0;start(e,n){this.cancel(),this._gen+=1;let r=this._gen;this._timer=setTimeout(()=>{this._timer=void 0,r===this._gen&&n()},e)}cancel(){this._timer!==void 0&&(clearTimeout(this._timer),this._timer=void 0)}get pending(){return this._timer!==void 0}}});var Qr={};Mn(Qr,{SNAPSHOT_WIRE_VERSION:()=>Nt,SurfaceError:()=>C,asSurfaceError:()=>On,createGraph:()=>Xe,deleteSnapshot:()=>An,diffSnapshots:()=>kn,listSnapshots:()=>Rn,restoreSnapshot:()=>En,runReduction:()=>Tn,saveSnapshot:()=>Nn});module.exports=Pn(Qr);je();it();Me();$e();Le();ce();Le();be();function Be(t,e){if(e!=null&&e.length>0)return new Set(e);switch(t){case"standard":return new Set(["type","status","value","deps","meta","v"]);case"full":return null;default:return new Set(["type","deps"])}}function Jn(t){return t._describeKind!=null?t._describeKind:t._deps.length>0?"derived":t._fn!=null?"producer":"state"}function Yn(t){let e={};for(let[n,r]of Object.entries(t.meta))try{e[n]=r.cache}catch{}return e}function yt(t,e){let n=e==null,r=!n&&e!=null?[...e].filter(u=>u.startsWith("meta.")).map(u=>u.slice(5)):null,o=n||e.has("meta")||r!=null&&r.length>0,s="state",i=[];t instanceof F&&(s=Jn(t),i=t._deps.map(u=>u.node.name??""));let a={type:s,deps:i};(n||e.has("status"))&&(a.status=t.status);let c=t instanceof F?t._guard:void 0;if(o){let u={...Yn(t)};if(c!=null&&u.access===void 0&&(u.access=lt(c)),r!=null&&r.length>0&&!e.has("meta")){let l={};for(let p of r)p in u&&(l[p]=u[p]);a.meta=l}else a.meta=u}if(t.name!=null&&(a.name=t.name),n||e.has("value")){t.status==="sentinel"&&(a.sentinel=!0);try{a.value=t.cache}catch{}}if((n||e.has("v"))&&t.v!=null){let u={id:t.v.id,version:t.v.version};"cid"in t.v&&(u.cid=t.v.cid,u.prev=t.v.prev),a.v=u}return(n||e.has("guard"))&&c!=null&&(a.guard=lt(c)),(n||e.has("lastMutation"))&&t.lastMutation!=null&&(a.lastMutation=t.lastMutation),a}be();je();bt();zt();var Ne=class{constructor(e){this.capacity=e;if(!Number.isInteger(e)||e<=0)throw new Error(`RingBuffer capacity must be a positive integer (got ${e})`);this.buf=new Array(e)}buf;head=0;_size=0;get size(){return this._size}get maxSize(){return this.capacity}push(e){let n=(this.head+this._size)%this.capacity;this.buf[n]=e,this._size<this.capacity?this._size++:this.head=(this.head+1)%this.capacity}shift(){if(this._size===0)return;let e=this.buf[this.head];return this.buf[this.head]=void 0,this.head=(this.head+1)%this.capacity,this._size--,e}at(e){if(this._size===0)return;let n=e<0?this._size+e:e;if(!(n<0||n>=this._size))return this.buf[(this.head+n)%this.capacity]}toArray(){let e=new Array(this._size);for(let n=0;n<this._size;n++)e[n]=this.buf[(this.head+n)%this.capacity];return e}clear(){for(let e=0;e<this._size;e++)this.buf[(this.head+e)%this.capacity]=void 0;this.head=0,this._size=0}};st();function vt(t){return t>=768&&t<=879||t>=1155&&t<=1161||t>=1425&&t<=1469||t>=1552&&t<=1562||t>=1611&&t<=1631||t>=1648&&t===1648||t>=1750&&t<=1756||t>=1759&&t<=1764||t>=1767&&t<=1768||t>=1770&&t<=1773||t>=1840&&t<=1866||t>=1958&&t<=1968||t>=2304&&t<=2307||t>=2362&&t<=2383||t>=2385&&t<=2391||t>=2402&&t<=2403||t>=2433&&t<=2435||t>=2492&&t<=2509||t>=2561&&t<=2563||t>=2620&&t<=2641||t>=2672&&t<=2673||t>=2677&&t===2677||t>=3633&&t===3633||t>=3636&&t<=3642||t>=3655&&t<=3662||t>=3761&&t===3761||t>=3764&&t<=3772||t>=3784&&t<=3790||t>=7616&&t<=7679||t>=8400&&t<=8447||t>=65024&&t<=65039||t>=65056&&t<=65071||t===8205?0:t>=4352&&t<=4447||t>=8986&&t<=8987||t>=9001&&t<=9002||t>=9193&&t<=9203||t>=9208&&t<=9210||t>=9725&&t<=9726||t>=9748&&t<=9749||t>=9800&&t<=9811||t===9855||t===9875||t===9889||t>=9898&&t<=9899||t>=9917&&t<=9918||t>=9924&&t<=9925||t===9934||t===9940||t===9962||t>=9970&&t<=9971||t===9973||t===9978||t===9981||t===9986||t===9989||t>=9992&&t<=9997||t===9999||t>=10067&&t<=10069||t===10071||t>=10133&&t<=10135||t===10160||t===10175||t>=10548&&t<=10549||t>=11013&&t<=11015||t>=11035&&t<=11036||t===11088||t===11093||t>=11904&&t<=12350||t>=12352&&t<=12447||t>=12448&&t<=12543||t>=12549&&t<=12591||t>=12593&&t<=12686||t>=12688&&t<=12771||t>=12784&&t<=12830||t>=12832&&t<=12871||t>=12880&&t<=19903||t>=19968&&t<=40959||t>=43360&&t<=43388||t>=44032&&t<=55203||t>=63744&&t<=64255||t>=65040&&t<=65049||t>=65072&&t<=65131||t>=65281&&t<=65376||t>=65504&&t<=65510||t>=126980&&t===126980||t===127183||t>=127344&&t<=127345||t===127358||t===127359||t===127374||t>=127377&&t<=127386||t>=127456&&t<=127487||t>=127488&&t<=127490||t===127514||t===127535||t>=127538&&t<=127546||t>=127568&&t<=127569||t>=127744&&t<=129535||t>=129536&&t<=129791||t>=129792&&t<=130047||t>=131072&&t<=196605||t>=196608&&t<=262141?2:1}function He(t){let e=0;for(let n of t)e+=vt(n.codePointAt(0));return e}function Ut(t,e){if(e<=0)return"";let n=0,r="";for(let o of t){let s=vt(o.codePointAt(0));if(n+s>e){if(e<=1)return"\u2026";for(;n+1>e&&r.length>0;){let i=[...r].pop();r=r.slice(0,-i.length),n-=vt(i.codePointAt(0))}return`${r}\u2026`}r+=o,n+=s}return r}var Xn={horizontal:"\u2500",vertical:"\u2502",cornerTL:"\u250C",cornerTR:"\u2510",cornerBL:"\u2514",cornerBR:"\u2518",tDown:"\u252C",tUp:"\u2534",tRight:"\u251C",tLeft:"\u2524",cross:"\u253C",arrowRight:"\u25B6",arrowDown:"\u25BC",arrowLeft:"\u25C0",arrowUp:"\u25B2",boxTL:"\u250C",boxTR:"\u2510",boxBL:"\u2514",boxBR:"\u2518",boxH:"\u2500",boxV:"\u2502"},Zn={horizontal:"-",vertical:"|",cornerTL:"+",cornerTR:"+",cornerBL:"+",cornerBR:"+",tDown:"+",tUp:"+",tRight:"+",tLeft:"+",cross:"+",arrowRight:">",arrowDown:"v",arrowLeft:"<",arrowUp:"^",boxTL:"+",boxTR:"+",boxBL:"+",boxBR:"+",boxH:"-",boxV:"|"};function Jt(t,e){let n=e.charset==="ascii"?Zn:Xn,r=t.width,o=t.height,s=Array.from({length:o},()=>Array.from({length:r},()=>" ")),i=Array.from({length:o},()=>Array.from({length:r},()=>"empty"));for(let a of t.edges)er(s,i,n,a);for(let a of t.boxes)Qn(s,i,n,a,e.labelOf(a.id));return s.map(a=>or(a.join(""))).join(`
2
+ `)}function Qn(t,e,n,r,o){let{x:s,y:i,w:a,h:c}=r;if(a<2||c<2){c>0&&Wt(t,e,s,i,a,o);return}re(t,e,s,i,n.boxTL);for(let l=s+1;l<s+a-1;l+=1)re(t,e,l,i,n.boxH);re(t,e,s+a-1,i,n.boxTR);for(let l=i+1;l<i+c-1;l+=1){re(t,e,s,l,n.boxV);for(let p=s+1;p<s+a-1;p+=1)Yt(t,e,p,l," ","empty");re(t,e,s+a-1,l,n.boxV)}re(t,e,s,i+c-1,n.boxBL);for(let l=s+1;l<s+a-1;l+=1)re(t,e,l,i+c-1,n.boxH);re(t,e,s+a-1,i+c-1,n.boxBR);let u=i+Math.floor(c/2);Wt(t,e,s+1,u,a-2,o)}function re(t,e,n,r,o){Yt(t,e,n,r,o,o===" "?"empty":o==="\u2500"||o==="-"?"boxH":o==="\u2502"||o==="|"?"boxV":"boxCorner")}function Yt(t,e,n,r,o,s){if(r<0||r>=t.length)return;let i=t[r];n<0||n>=i.length||(i[n]=o,e[r][n]=s)}function Wt(t,e,n,r,o,s){if(r<0||r>=t.length)return;let i=n,a=o;for(let c of s){let u=He(c);if(u!==0){if(a<u)break;i>=0&&i<t[r].length&&(t[r][i]=c,e[r][i]="label",u===2&&i+1<t[r].length&&(t[r][i+1]="",e[r][i+1]="label")),i+=u,a-=u}}for(;a>0;)i>=0&&i<t[r].length&&(t[r][i]=" ",e[r][i]="empty"),i+=1,a-=1}function er(t,e,n,r){let o=r.points;if(o.length<2)return;for(let c=0;c+1<o.length;c+=1)tr(t,e,n,o[c],o[c+1]);for(let c=1;c+1<o.length;c+=1){let u=o[c-1],l=o[c],p=o[c+1],h=nr(u,l,p,n);h&&qt(t,e,l.x,l.y,h,"edgeCorner")}let s=o[o.length-1],i=o[o.length-2],a=rr(i,s,n);a&&qt(t,e,s.x,s.y,a,"arrow")}function tr(t,e,n,r,o){if(!(r.x===o.x&&r.y===o.y)){if(r.y===o.y){let s=r.y,i=Math.min(r.x,o.x),a=Math.max(r.x,o.x);for(let c=i;c<=a;c+=1)Kt(t,e,c,s,n,"h")}else if(r.x===o.x){let s=r.x,i=Math.min(r.y,o.y),a=Math.max(r.y,o.y);for(let c=i;c<=a;c+=1)Kt(t,e,s,c,n,"v")}}}function Kt(t,e,n,r,o,s){if(r<0||r>=t.length)return;let i=t[r];if(n<0||n>=i.length)return;let a=e[r][n];if(!(a==="boxH"||a==="boxV"||a==="boxCorner"||a==="label")){if(a==="empty"){i[n]=s==="h"?o.horizontal:o.vertical,e[r][n]=s==="h"?"edgeH":"edgeV";return}if(a==="edgeH"&&s==="v"){i[n]=o.cross,e[r][n]="edgeCorner";return}if(a==="edgeV"&&s==="h"){i[n]=o.cross,e[r][n]="edgeCorner";return}}}function qt(t,e,n,r,o,s){if(r<0||r>=t.length)return;let i=t[r];if(n<0||n>=i.length)return;let a=e[r][n];a==="boxH"||a==="boxV"||a==="boxCorner"||a==="label"||(i[n]=o,e[r][n]=s)}function nr(t,e,n,r){let o=t.y===e.y,s=e.y===n.y;if(o===s)return;if(o){let c=t.x<e.x,u=n.y>e.y;return c&&u?r.cornerTR:c&&!u?r.cornerBR:!c&&u?r.cornerTL:r.cornerBL}let i=t.y<e.y,a=n.x>e.x;return i&&a?r.cornerBL:i&&!a?r.cornerBR:!i&&a?r.cornerTL:r.cornerTR}function rr(t,e,n){if(e.x>t.x)return n.arrowRight;if(e.x<t.x)return n.arrowLeft;if(e.y>t.y)return n.arrowDown;if(e.y<t.y)return n.arrowUp}function or(t){let e=t.length;for(;e>0&&t.charCodeAt(e-1)===32;)e-=1;return t.slice(0,e)}function Qt(t){let e=sr(t);ir(e),ar(e),cr(e),ur(e,t);let n=fr(e,t),{width:r,height:o}=hr(e),s=[];for(let i of e.layers)for(let a of i)a.isVirtual||s.push({id:a.id,layer:a.layer,order:a.order,x:a.x,y:a.y,w:a.w,h:a.h});return{boxes:s,edges:n,width:r,height:o}}function sr(t){let e=new Map;for(let o of t.nodes)e.set(o,{id:o,isVirtual:!1,layer:-1,order:0,x:0,y:0,w:t.widthCells(o),h:t.heightCells(o),in:[],out:[]});let n=[],r=0;for(let o of t.edges){if(o.from===o.to)continue;let s=e.get(o.from),i=e.get(o.to);if(!s||!i)continue;let a={chainId:r++,chainFrom:o.from,chainTo:o.to,fromId:o.from,toId:o.to,hopIndex:0,chainLen:1};s.out.push(a),i.in.push(a),n.push(a)}return{nodes:e,layers:[],hops:n}}function ir(t){let e=new Map;for(let s of t.nodes.values())e.set(s.id,s.in.length);let n=[];for(let s of t.nodes.values())(e.get(s.id)??0)===0&&(s.layer=0,n.push(s));let r=new Set,o=0;for(;o<n.length;){let s=n[o++];if(!r.has(s.id)){r.add(s.id);for(let i of s.out){let a=t.nodes.get(i.toId);a.layer=Math.max(a.layer,s.layer+1);let c=(e.get(a.id)??0)-1;e.set(a.id,c),c<=0&&n.push(a)}}}for(let s of t.nodes.values())s.layer<0&&(s.layer=0)}function ar(t){let e=Math.max(0,...Array.from(t.nodes.values(),s=>s.layer)),n=Array.from({length:e+1},()=>[]);for(let s of t.nodes.values())n[s.layer].push(s);let r=[],o=0;for(let s of t.hops){let i=t.nodes.get(s.fromId),a=t.nodes.get(s.toId),c=a.layer-i.layer;if(c<=0){i.out=i.out.filter(p=>p!==s),a.in=a.in.filter(p=>p!==s);continue}if(c===1){s.hopIndex=0,s.chainLen=1,r.push(s);continue}i.out=i.out.filter(p=>p!==s),a.in=a.in.filter(p=>p!==s);let u=i;for(let p=1;p<c;p+=1){let h=`__virt_${o++}__`,f={id:h,isVirtual:!0,layer:i.layer+p,order:0,x:0,y:0,w:0,h:1,in:[],out:[]};t.nodes.set(h,f),n[f.layer].push(f);let d={chainId:s.chainId,chainFrom:s.chainFrom,chainTo:s.chainTo,fromId:u.id,toId:h,hopIndex:p-1,chainLen:c};u.out.push(d),f.in.push(d),r.push(d),u=f}let l={chainId:s.chainId,chainFrom:s.chainFrom,chainTo:s.chainTo,fromId:u.id,toId:a.id,hopIndex:c-1,chainLen:c};u.out.push(l),a.in.push(l),r.push(l)}for(let s of n)for(let i=0;i<s.length;i+=1)s[i].order=i;t.layers=n,t.hops=r}function cr(t){for(let n=0;n<4;n+=1){for(let r=1;r<t.layers.length;r+=1)Xt(t,t.layers[r],"in"),ze(t.layers[r]);for(let r=t.layers.length-2;r>=0;r-=1)Xt(t,t.layers[r],"out"),ze(t.layers[r])}for(let n=0;n<2;n+=1){let r=!1;for(let o=1;o<t.layers.length;o+=1){let s=t.layers[o];for(let i=0;i+1<s.length;i+=1){let a=Zt(t,s[i],s[i+1],"in");[s[i],s[i+1]]=[s[i+1],s[i]],ze(s),Zt(t,s[i],s[i+1],"in")<a?r=!0:([s[i],s[i+1]]=[s[i+1],s[i]],ze(s))}}if(!r)break}}function Xt(t,e,n){let r=new Map;for(let o of e){let s=n==="in"?o.in:o.out;if(s.length===0){r.set(o.id,o.order);continue}let i=0,a=0;for(let c of s){let u=t.nodes.get(n==="in"?c.fromId:c.toId);u&&(i+=u.order,a+=1)}r.set(o.id,a===0?o.order:i/a)}e.sort((o,s)=>{let i=r.get(o.id),a=r.get(s.id);return i!==a?i-a:o.order-s.order})}function ze(t){for(let e=0;e<t.length;e+=1)t[e].order=e}function Zt(t,e,n,r){let o=r==="in"?e.in:e.out,s=r==="in"?n.in:n.out,i=0;for(let a of o)for(let c of s){let u=t.nodes.get(r==="in"?a.fromId:a.toId)?.order??0,l=t.nodes.get(r==="in"?c.fromId:c.toId)?.order??0;(e.order<n.order&&u>l||e.order>n.order&&u<l)&&(i+=1)}return i}function ur(t,e){e.direction==="LR"?dr(t,e):lr(t,e)}function dr(t,e){let n=[],r=0;for(let o=0;o<t.layers.length;o+=1){n.push(r);let s=0;for(let i of t.layers[o])s=Math.max(s,i.w);r+=s+e.layerGap}for(let o=0;o<t.layers.length;o+=1)for(let s of t.layers[o])s.x=n[o];for(let o of t.layers){let s=0;for(let i of o)i.y=s,s+=i.h+e.nodeGap}en(t,e,"y")}function lr(t,e){let n=[],r=0;for(let o=0;o<t.layers.length;o+=1){n.push(r);let s=0;for(let i of t.layers[o])s=Math.max(s,i.h);r+=s+e.layerGap}for(let o=0;o<t.layers.length;o+=1)for(let s of t.layers[o])s.y=n[o];for(let o of t.layers){let s=0;for(let i of o)i.x=s,s+=i.w+e.nodeGap}en(t,e,"x")}function en(t,e,n){let r=s=>n==="y"?s.h:s.w,o=e.nodeGap;for(let s=0;s<2;s+=1){let i=s===0?t.layers.slice(1):t.layers.slice(0,-1).reverse();for(let a of i){let c=new Map;for(let l of a){let p=s===0?l.in:l.out;if(p.length===0)continue;let h=[];for(let d of p){let g=t.nodes.get(s===0?d.fromId:d.toId);if(!g)continue;let m=n==="y"?g.y:g.x;h.push(m+Math.floor(r(g)/2))}if(h.length===0)continue;h.sort((d,g)=>d-g);let f=h[Math.floor(h.length/2)];c.set(l.id,f-Math.floor(r(l)/2))}let u=0;for(let l of a){let p=c.get(l.id),h=n==="y"?l.y:l.x,d=Math.max(p??h,u);n==="y"?l.y=d:l.x=d,u=d+r(l)+o}}}}function fr(t,e){let n=new Map;for(let u of t.hops){let l=n.get(u.chainId);l?l.push(u):n.set(u.chainId,[u])}for(let u of n.values())u.sort((l,p)=>l.hopIndex-p.hopIndex);let r=e.direction==="LR",o=u=>r?u.x:u.y,s=u=>r?u.w:u.h,i=u=>r?u.y+Math.floor(u.h/2):u.x+Math.floor(u.w/2),a=new Map;for(let u=0;u+1<t.layers.length;u+=1){let l=t.layers[u],p=t.layers[u+1],h=0;for(let _ of l)h=Math.max(h,o(_)+s(_));let f=Number.POSITIVE_INFINITY;for(let _ of p)f=Math.min(f,o(_));let d=Number.isFinite(f)?f-1:h,g=Math.max(1,d-h+1),m=[];for(let _ of l)for(let k of _.out)m.push(k);m.sort((_,k)=>{let A=i(t.nodes.get(_.fromId)),T=i(t.nodes.get(k.fromId));if(A!==T)return A-T;let R=i(t.nodes.get(_.toId)),N=i(t.nodes.get(k.toId));return R-N});let b=[],y=new Map;for(let _ of m){let k=i(t.nodes.get(_.fromId)),A=i(t.nodes.get(_.toId)),T=Math.min(k,A),R=Math.max(k,A),N=-1;for(let D=0;D<b.length;D+=1){let H=b[D],X=!0;for(let se of H)if(se.lo<=R&&T<=se.hi){X=!1;break}if(X){H.push({lo:T,hi:R}),N=D;break}}N<0&&(b.push([{lo:T,hi:R}]),N=b.length-1),y.set(_,N)}let v=b.length,x=g>=Math.max(3,v+2),O=x?h+1:h,S=x?d-1:d,w=Math.max(1,S-O+1);for(let _ of m){let k=y.get(_),A;if(v<=1)A=O+Math.floor(w/2);else{let T=(w-1)/(v-1);A=O+Math.floor(k*T)}a.set(_,Math.max(h,Math.min(d,A)))}}let c=[];for(let[,u]of n){let l=[];for(let h=0;h<u.length;h+=1){let f=u[h],d=t.nodes.get(f.fromId),g=t.nodes.get(f.toId),m=a.get(f),b=d.isVirtual?o(d):o(d)+s(d),y=g.isVirtual?o(g):o(g)-1,v=i(d),x=i(g);h===0&&Ue(l,r,b,v),v!==x&&(Ue(l,r,m,v),Ue(l,r,m,x)),Ue(l,r,y,x)}let p=u[0];c.push({from:p.chainFrom,to:p.chainTo,points:pr(l)})}return c}function Ue(t,e,n,r){t.push(e?{x:n,y:r}:{x:r,y:n})}function pr(t){let e=[];for(let n of t){let r=e[e.length-1];(!r||r.x!==n.x||r.y!==n.y)&&e.push(n)}return e}function hr(t){let e=0,n=0;for(let r of t.layers)for(let o of r)e=Math.max(e,o.x+o.w),n=Math.max(n,o.y+o.h);return{width:e,height:n}}var gr=24,mr=4,yr=1,br=3;function tn(t,e){let n=vr(e.direction),r=Math.max(3,e.maxLabelWidth??gr),o=e.asciiCharset??"unicode",s=Object.keys(t.nodes).sort(),i=new Set(s),a=t.edges.filter(f=>i.has(f.from)&&i.has(f.to)),c=new Map,u=new Map;for(let f of s){let d=Ut(f,r);c.set(f,d),u.set(f,He(d)+4)}let l=Qt({nodes:s,edges:a,widthCells:f=>u.get(f)??3,heightCells:()=>br,layerGap:mr,nodeGap:yr,direction:n}),p=Jt(l,{charset:o,labelOf:f=>c.get(f)??f}),h=e.logger;return h&&h(p),p}function vr(t){if(t===void 0||t==="LR")return"LR";if(t==="TD")return"TD";throw new Error(`ascii describe supports direction "LR" or "TD" only; got ${String(t)}`)}function nn(t,e,n,r={}){let o=e in t.nodes,s=n in t.nodes;if(!o)return We(e,n,"no-such-from");if(!s)return We(e,n,"no-such-to");let i=r.maxDepth;if(i!=null&&(!Number.isInteger(i)||i<0))throw new Error("explainPath: maxDepth must be an integer >= 0");if(e===n){if(r.findCycle===!0){let u=wr(t,e,r);if(u!=null)return u}let c=Ke(e,t.nodes[e],0,r);return qe(e,n,[c])}if(i===0)return We(e,n,"no-path");let a=rn(t,e,n,i);return a.found?qe(e,n,on(t,a.pathOrder,r)):We(e,n,a.truncated?"max-depth-exceeded":"no-path")}function rn(t,e,n,r){let o=new Map,s=[{path:n,depth:0}],i=new Set([n]),a=0,c=!1;for(;a<s.length;){let p=s[a++];if(p.path===e)break;if(r!=null&&p.depth>=r){let g=t.nodes[p.path];g?.deps&&g.deps.length>0&&(c=!0);continue}let h=t.nodes[p.path];if(h==null)continue;let f=h.deps??[],d=new Map;for(let g=0;g<f.length;g++){let m=f[g];if(!m)continue;let b=d.get(m);b==null&&(b=[],d.set(m,b)),b.push(g)}for(let[g,m]of d)i.has(g)||(i.add(g),o.set(g,{from:p.path,depIndices:m}),s.push({path:g,depth:p.depth+1}))}if(!o.has(e))return{found:!1,pathOrder:[],truncated:c};let u=[{path:e}],l=e;for(;l!==n;){let p=o.get(l);if(p==null)return{found:!1,pathOrder:[],truncated:!1};u[u.length-1].depIndices=p.depIndices,u.push({path:p.from}),l=p.from}return{found:!0,pathOrder:u,truncated:!1}}function wr(t,e,n){let r=t.nodes[e];if(r==null)return null;let o=r.deps??[],s=[];for(let a=0;a<o.length;a++)o[a]===e&&s.push(a);if(s.length>0){let a=Ke(e,r,0,n);a.dep_index=s[0];let c=Ke(e,r,1,n);return qe(e,e,[a,c])}let i=null;for(let a=0;a<o.length;a++){let c=o[a];if(!c||c===e)continue;let u=rn(t,c,e,n.maxDepth);u.found&&(i==null||u.pathOrder.length<i.pathOrder.length)&&(i=u,i={found:!0,pathOrder:[{path:e,depIndices:[a]},...u.pathOrder],truncated:!1})}return i==null?null:qe(e,e,on(t,i.pathOrder,n))}function on(t,e,n){return e.map((r,o)=>{let s=t.nodes[r.path],i=Ke(r.path,s,o,n);return r.depIndices!=null&&r.depIndices.length>0&&(i.dep_index=r.depIndices[0],r.depIndices.length>1&&(i.dep_indices=[...r.depIndices])),i})}function Ke(t,e,n,r){let o={path:t,type:e.type,hop:n};e.status!==void 0&&(o.status=e.status),"value"in e&&(o.value=e.value),e.v!=null&&(o.v=e.v);let s=r.annotations?.get(t)??e.annotation;s!=null&&(o.annotation=s);let i=r.lastMutations?.get(t)??e.lastMutation;return i!=null&&(o.lastMutation=i),o}function qe(t,e,n){return sn(t,e,!0,"ok",n)}function We(t,e,n){return sn(t,e,!1,n,[])}function sn(t,e,n,r,o){let s=_r(t,e,n,r,o);return{from:t,to:e,found:n,reason:r,steps:o,text:s,toJSON(){return{from:t,to:e,found:n,reason:r,steps:o}}}}function _r(t,e,n,r,o){if(!n)switch(r){case"no-such-from":return`explainPath: no node named "${t}"`;case"no-such-to":return`explainPath: no node named "${e}"`;case"max-depth-exceeded":return`explainPath: no path from "${t}" to "${e}" within maxDepth`;default:return`explainPath: no path from "${t}" to "${e}"`}let s=[`Causal path: ${t} \u2192 ${e} (${o.length} step(s))`];for(let i of o){let c=` ${i.hop===0?"\xB7":"\u2193"} ${i.path} (${i.type}${i.status?`/${i.status}`:""})`;if(s.push(c),"value"in i&&s.push(` value: ${xr(i.value)}`),i.annotation!=null&&s.push(` annotation: ${i.annotation}`),i.lastMutation!=null){let u=i.lastMutation.actor;s.push(` actor: ${u.type}${u.id?`:${u.id}`:""}`)}}return s.join(`
3
3
  `)}function xr(t){if(t===void 0)return"<sentinel>";if(t===null)return"null";if(typeof t=="string")return JSON.stringify(t);if(typeof t=="number"||typeof t=="boolean"||typeof t=="bigint")return String(t);try{let e=JSON.stringify(t);return e.length>80?`${e.slice(0,77)}...`:e}catch{return String(t)}}be();var I={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},Sr=Symbol.for("sizeof");function an(t){let e=new WeakSet,n=new WeakSet,r=[t],o=0;for(;r.length>0;){let s=r.pop();o+=Or(s,e,n,r)}return o}function Or(t,e,n,r){if(t==null)return 0;switch(typeof t){case"number":return I.number;case"boolean":return I.boolean;case"string":return I.string+t.length*2;case"bigint":return I.bigint+Tr(t);case"symbol":return I.symbol;case"function":return e.has(t)?0:(e.add(t),I.function);case"undefined":return 0}let s=t;if(e.has(s))return 0;e.add(s);let i=s[Sr];if(typeof i=="function")try{let u=i.call(s);if(typeof u=="number"&&Number.isFinite(u))return u}catch{}if(s instanceof Date)return I.date;if(s instanceof RegExp)return I.regexp+s.source.length*2;if(s instanceof Error){let u=s.message?s.message.length*2:0,l=s.stack?s.stack.length*2:0;return I.error+u+l}if(typeof URL<"u"&&s instanceof URL)return I.url+s.href.length*2;if(typeof Promise<"u"&&s instanceof Promise)return I.promise;if(s instanceof WeakMap)return I.weakmap;if(s instanceof WeakSet)return I.weakset;if(s instanceof Map){let u=I.map;for(let[l,p]of s)u+=I.mapEntry,r.push(l),r.push(p);return u}if(s instanceof Set){let u=I.set;for(let l of s)u+=I.setEntry,r.push(l);return u}if(Array.isArray(s)){let u=I.array+s.length*8;for(let l of s)r.push(l);return u}if(s instanceof ArrayBuffer)return n.has(s)?0:(n.add(s),s.byteLength);if(ArrayBuffer.isView(s)){let u=s;return n.has(u.buffer)?48:(n.add(u.buffer),u.buffer.byteLength+48)}let a=I.object,c=Object.keys(s);for(let u of c){a+=I.string+u.length*2;try{r.push(s[u])}catch{}}return a}function Tr(t){let e=t<0n?-t:t;if(e===0n)return 0;let n=e.toString(2).length;return Math.ceil(n/32)*8}function cn(t,e){let n=e?.topN??10,r=t.describe({detail:"standard"}),o=[],s=t._collectObserveTargets;typeof s=="function"&&s.call(t,"",o);let i=new Map;for(let[h,f]of o)i.set(h,f);let a=[];for(let[h,f]of Object.entries(r.nodes)){let d=i.get(h),g=d instanceof F?d:null,m=g?an(g.cache):0,b=g?g._sinkCount:0,y=f.deps?.length??0,v=f.type==="effect"&&b===0,x=b===0?f.type==="effect"?"orphan-effect":f.type==="derived"?"idle-derived":f.type==="producer"?"idle-producer":null:null;a.push({path:h,type:f.type,status:f.status??"unknown",valueSizeBytes:m,subscriberCount:b,depCount:y,isOrphanEffect:v,orphanKind:x})}let c=a.reduce((h,f)=>h+f.valueSizeBytes,0),u=(h,f)=>[...a].sort(f??((d,g)=>g[h]-d[h])).slice(0,n),l=a.filter(h=>h.orphanKind!=null),p=a.filter(h=>h.isOrphanEffect);return{nodeCount:a.length,edgeCount:r.edges.length,subgraphCount:r.subgraphs.length,nodes:a,totalValueSizeBytes:c,hotspots:{byValueSize:u("valueSizeBytes"),bySubscriberCount:u("subscriberCount"),byDepCount:u("depCount")},orphans:l,orphanEffects:p}}var P="::",Y="__meta__",oe=1;function un(t,e){let n=Math.max(16,t.size*4),r=0;for(;t.size>0;){if(r++>=n){console.error(`[Graph "${e}".destroy] disposer drain exceeded cap (${n}); ${t.size} disposer(s) discarded`),t.clear();return}let o=t.values().next();if(o.done)return;let s=o.value;t.delete(s);try{s()}catch(i){console.error(`[Graph "${e}".destroy] disposer threw:`,i)}}}function Nr(t){let e=[];for(let n of Object.keys(t).sort()){let r=t[n].v;r!=null&&e.push(`${n} ${r.id} ${r.version}`)}return e.join(`
4
- `)}function dn(t){if(t.version!==oe)throw new Error(`unsupported snapshot version ${String(t.version)} (expected ${oe})`);for(let e of["name","nodes","edges","subgraphs"])if(!(e in t))throw new Error(`snapshot missing required key "${e}"`);if(typeof t.name!="string")throw new TypeError("snapshot 'name' must be a string");if(typeof t.nodes!="object"||t.nodes===null||Array.isArray(t.nodes))throw new TypeError("snapshot 'nodes' must be an object");if(!Array.isArray(t.edges))throw new TypeError("snapshot 'edges' must be an array");if(!Array.isArray(t.subgraphs))throw new TypeError("snapshot 'subgraphs' must be an array")}function Er(t,e){let n=new WeakMap,r=(o,s)=>{if(Object.is(o,s))return!0;if(o==null||s==null||typeof o!="object"||typeof s!="object")return!1;let i=n.get(o);if(i==null&&(i=new WeakSet,n.set(o,i)),i.has(s))return!0;i.add(s);let a=o.constructor,c=s.constructor;if(a!==c)return!1;if(o instanceof Date)return o.getTime()===s.getTime();if(o instanceof RegExp)return o.source===s.source&&o.flags===s.flags;if(Array.isArray(o)){let h=s;if(o.length!==h.length)return!1;for(let f=0;f<o.length;f++)if(!r(o[f],h[f]))return!1;return!0}if(o instanceof Map){let h=s;if(o.size!==h.size)return!1;for(let[f,d]of o)if(!h.has(f)||!r(d,h.get(f)))return!1;return!0}if(o instanceof Set){let h=s;if(o.size!==h.size)return!1;for(let f of o){let d=!1;for(let g of h)if(r(f,g)){d=!0;break}if(!d)return!1}return!0}if(ArrayBuffer.isView(o)){let h=o,f=s;if(h.length!==f.length)return!1;for(let d=0;d<h.length;d++)if(h[d]!==f[d])return!1;return!0}let u=Object.keys(o),l=Object.keys(s);if(u.length!==l.length)return!1;let p=new Set(l);for(let h of u)if(!p.has(h)||!r(o[h],s[h]))return!1;return!0};return r(t,e)}function _t(t){if(t===null||typeof t!="object")return t;if(Array.isArray(t))return t.map(_t);let e=t,n=Object.keys(e).sort(),r={};for(let o of n)r[o]=_t(e[o]);return r}function kr(t){return t.replaceAll("\\","\\\\").replaceAll('"','\\"')}function Rr(t){return t.replaceAll("\\","\\\\").replaceAll('"','\\"')}function Ar(t){return t==="TD"?"down":t==="BT"?"up":t==="RL"?"left":"right"}function pn(t){let e=new Set,n=[];function r(o,s){let i=`${o}\0${s}`;e.has(i)||(e.add(i),n.push([o,s]))}for(let[o,s]of Object.entries(t.nodes)){let i=s.deps;if(i)for(let a of i)r(a,o)}for(let o of t.edges)r(o.from,o.to);return n}function hn(t){if(t===void 0)return"LR";if(t==="TD"||t==="LR"||t==="BT"||t==="RL")return t;throw new Error(`invalid diagram direction ${String(t)}; expected one of: TD, LR, BT, RL`)}function Dr(t,e){let n=e.includeEdges??!0,r=e.includeSubgraphs??!0,{expand:o,...s}=t,i={...s,edges:n?t.edges:[],subgraphs:r?t.subgraphs:[]},a=JSON.stringify(_t(i),null,e.indent??2);return e.logger?.(a),a}function Cr(t,e){let n=e.includeEdges??!0,r=e.includeSubgraphs??!0,o=[];o.push(`Graph ${t.name}`),o.push("Nodes:");for(let i of Object.keys(t.nodes).sort()){let a=t.nodes[i];o.push(`- ${i} (${a.type}/${a.status}): ${Ye(a.value)}`)}if(n){o.push("Edges:");for(let i of t.edges)o.push(`- ${i.from} -> ${i.to}`)}if(r){o.push("Subgraphs:");for(let i of t.subgraphs)o.push(`- ${i}`)}let s=o.join(`
4
+ `)}function dn(t){if(t.version!==oe)throw new Error(`unsupported snapshot version ${String(t.version)} (expected ${oe})`);for(let e of["name","nodes","edges","subgraphs"])if(!(e in t))throw new Error(`snapshot missing required key "${e}"`);if(typeof t.name!="string")throw new TypeError("snapshot 'name' must be a string");if(typeof t.nodes!="object"||t.nodes===null||Array.isArray(t.nodes))throw new TypeError("snapshot 'nodes' must be an object");if(!Array.isArray(t.edges))throw new TypeError("snapshot 'edges' must be an array");if(!Array.isArray(t.subgraphs))throw new TypeError("snapshot 'subgraphs' must be an array")}function Er(t,e){let n=new WeakMap,r=(o,s)=>{if(Object.is(o,s))return!0;if(o==null||s==null||typeof o!="object"||typeof s!="object")return!1;let i=n.get(o);if(i==null&&(i=new WeakSet,n.set(o,i)),i.has(s))return!0;i.add(s);let a=o.constructor,c=s.constructor;if(a!==c)return!1;if(o instanceof Date)return o.getTime()===s.getTime();if(o instanceof RegExp)return o.source===s.source&&o.flags===s.flags;if(Array.isArray(o)){let h=s;if(o.length!==h.length)return!1;for(let f=0;f<o.length;f++)if(!r(o[f],h[f]))return!1;return!0}if(o instanceof Map){let h=s;if(o.size!==h.size)return!1;for(let[f,d]of o)if(!h.has(f)||!r(d,h.get(f)))return!1;return!0}if(o instanceof Set){let h=s;if(o.size!==h.size)return!1;for(let f of o){let d=!1;for(let g of h)if(r(f,g)){d=!0;break}if(!d)return!1}return!0}if(ArrayBuffer.isView(o)){let h=o,f=s;if(h.length!==f.length)return!1;for(let d=0;d<h.length;d++)if(h[d]!==f[d])return!1;return!0}let u=Object.keys(o),l=Object.keys(s);if(u.length!==l.length)return!1;let p=new Set(l);for(let h of u)if(!p.has(h)||!r(o[h],s[h]))return!1;return!0};return r(t,e)}function _t(t){if(t===null||typeof t!="object")return t;if(Array.isArray(t))return t.map(_t);let e=t,n=Object.keys(e).sort(),r={};for(let o of n)r[o]=_t(e[o]);return r}function kr(t){return t.replaceAll("\\","\\\\").replaceAll('"','\\"')}function Rr(t){return t.replaceAll("\\","\\\\").replaceAll('"','\\"')}function Ar(t){return t==="TD"?"down":t==="BT"?"up":t==="RL"?"left":"right"}function pn(t){let e=new Set,n=[];function r(o,s){let i=`${o}\0${s}`;e.has(i)||(e.add(i),n.push([o,s]))}for(let[o,s]of Object.entries(t.nodes)){let i=s.deps;if(i)for(let a of i)r(a,o)}for(let o of t.edges)r(o.from,o.to);return n}function hn(t){if(t===void 0)return"LR";if(t==="TD"||t==="LR"||t==="BT"||t==="RL")return t;throw new Error(`invalid diagram direction ${String(t)}; expected one of: TD, LR, BT, RL`)}function Cr(t,e){let n=e.includeEdges??!0,r=e.includeSubgraphs??!0,{expand:o,...s}=t,i={...s,edges:n?t.edges:[],subgraphs:r?t.subgraphs:[]},a=JSON.stringify(_t(i),null,e.indent??2);return e.logger?.(a),a}function Dr(t,e){let n=e.includeEdges??!0,r=e.includeSubgraphs??!0,o=[];o.push(`Graph ${t.name}`),o.push("Nodes:");for(let i of Object.keys(t.nodes).sort()){let a=t.nodes[i];o.push(`- ${i} (${a.type}/${a.status}): ${Ye(a.value)}`)}if(n){o.push("Edges:");for(let i of t.edges)o.push(`- ${i.from} -> ${i.to}`)}if(r){o.push("Subgraphs:");for(let i of t.subgraphs)o.push(`- ${i}`)}let s=o.join(`
5
5
  `);return e.logger?.(s),s}function gn(t,e){let n=hn(e.direction),r=Object.keys(t.nodes).sort(),o=new Map;for(let i=0;i<r.length;i+=1)o.set(r[i],`n${i}`);let s=[`flowchart ${n}`];for(let i of r){let a=o.get(i);s.push(` ${a}["${kr(i)}"]`)}for(let[i,a]of pn(t)){let c=o.get(i),u=o.get(a);!c||!u||s.push(` ${c} --> ${u}`)}return s.join(`
6
6
  `)}function Gr(t,e){let n=gn(t,e);return Mr(n)}function Mr(t,e){let n=e?.theme??"default",r=e?.autoSync??!0,s=JSON.stringify({code:t,mermaid:{theme:n},autoSync:r}),i=new TextEncoder().encode(s),a="";for(let u=0;u<i.length;u++)a+=String.fromCharCode(i[u]);return`https://mermaid.live/edit#base64:${globalThis.btoa(a).replace(/\+/g,"-").replace(/\//g,"_").replace(/=+$/,"")}`}function $r(t,e){let n=hn(e.direction),r=Object.keys(t.nodes).sort(),o=new Map;for(let i=0;i<r.length;i+=1)o.set(r[i],`n${i}`);let s=[`direction: ${Ar(n)}`];for(let i of r){let a=o.get(i);s.push(`${a}: "${Rr(i)}"`)}for(let[i,a]of pn(t)){let c=o.get(i),u=o.get(a);!c||!u||s.push(`${c} -> ${u}`)}return s.join(`
7
- `)}function Pr(t){return t.replace(/[.*+?^${}()|[\]\\]/g,"\\$&")}function Je(t){let e="^";for(let n=0;n<t.length;n+=1){let r=t[n];if(r==="*"){e+=".*";continue}if(r==="?"){e+=".";continue}if(r==="["){let o=t.indexOf("]",n+1);if(o<=n+1){e+="\\[";continue}let s=t.slice(n+1,o);s.startsWith("!")&&(s=`^${s.slice(1)}`),s=s.replace(/\\/g,"\\\\"),e+=`[${s}]`,n=o;continue}e+=Pr(r)}return e+="$",new RegExp(e)}var Lr={data:"\x1B[32m",dirty:"\x1B[33m",resolved:"\x1B[36m",invalidate:"\x1B[93m",pause:"\x1B[90m",resume:"\x1B[96m",complete:"\x1B[34m",error:"\x1B[31m",teardown:"\x1B[91m",derived:"\x1B[35m",path:"\x1B[90m",reset:"\x1B[0m"},Fr={data:"",dirty:"",resolved:"",invalidate:"",pause:"",resume:"",complete:"",error:"",teardown:"",derived:"",path:"",reset:""};function Ye(t){if(typeof t=="string")return JSON.stringify(t);if(typeof t=="number"||typeof t=="boolean"||t==null)return String(t);try{return JSON.stringify(t)}catch{return"[unserializable]"}}function Ir(t){return t==="none"?Fr:t==="ansi"||t==null?Lr:{data:t.data??"",dirty:t.dirty??"",resolved:t.resolved??"",invalidate:t.invalidate??"",pause:t.pause??"",resume:t.resume??"",complete:t.complete??"",error:t.error??"",teardown:t.teardown??"",derived:t.derived??"",path:t.path??"",reset:t.reset??""}}function ln(t){if(t==null)return{};let e=t.detail;return e==="full"?{...t,structured:t.structured??!0,timeline:t.timeline??!0,causal:t.causal??!0,derived:t.derived??!0}:e==="minimal"?{...t,structured:t.structured??!0}:t.format==="stage-log"?{...t,structured:t.structured??!0,timeline:t.timeline??!0}:t}function jr(t,e,n){for(let r=0;r<t.length;r++){let o=t.charCodeAt(r);if(o<32||o===127)throw new Error(`Graph "${e}": ${n} "${t}" must not contain control character (U+${o.toString(16).padStart(4,"0").toUpperCase()} at index ${r})`)}}function wt(t,e,n){if(t==="")throw new Error(`Graph "${e}": ${n} name must be non-empty`);if(t.includes(P))throw new Error(`Graph "${e}": ${n} "${t}" must not contain '${P}' (path separator)`);if(t===Y)throw new Error(`Graph "${e}": ${n} name "${Y}" is reserved for meta companion paths`);jr(t,e,n)}function Br(t,e){if(t==="")throw new Error(`Graph "${e}": resolve path must be non-empty`);let n=t.split(P);for(let r of n)if(r==="")throw new Error(`Graph "${e}": resolve path has empty segment`);return n}function Vr(t,e){let n=!1;for(let o of t)if(!e.isMetaPassthrough(o[0])){n=!0;break}return n?t.filter(o=>e.isMetaPassthrough(o[0])):t}function mn(t){for(let e of t._mounts.values())mn(e);for(let e of t._nodes.values())try{e.down([[V]],{internal:!0})}catch{}}var ne=class t{name;opts;config;_nodes=new Map;_nodeToName=new WeakMap;_mounts=new Map;_parent=void 0;_storageDisposers=new Set;_disposers=new Set;_topology;_topologyEmitters=new Set;constructor(e,n){if(e==="")throw new Error("Graph name must be non-empty");if(e.includes(P))throw new Error(`Graph name must not contain '${P}' (got "${e}")`);if(e===Y)throw new Error(`Graph name "${Y}" is reserved for meta companion paths`);this.name=e,this.opts=Object.freeze({...n??{}}),this.config=n?.config??ye,this._traceRing=new Ne(n?.traceCapacity??1e3),n?.versioning!=null&&this.setVersioning(n.versioning)}ancestors(e=!0){let n=[],r=e?this:this._parent;for(;r!=null;)n.push(r),r=r._parent;return n}get topology(){return this._topology==null&&(this._topology=Te(e=>{let n=r=>{e.emit(r)};return this._topologyEmitters.add(n),()=>{this._topologyEmitters.delete(n)}},{name:`${this.name}_topology`})),this._topology}_emitTopology(e){if(!(this._topology==null||this._topologyEmitters.size===0))for(let n of this._topologyEmitters)n(e)}add(e,n){let r=e.name,o=n?.name??r;if(o==null||o==="")throw new Error(`Graph "${this.name}": graph.add requires a non-empty name \u2014 pass via opts.name or set it on the node (e.g. state(0, { name: "x" }))`);let s=o,i=n?.annotation;if(wt(s,this.name,"add"),this._mounts.has(s))throw new Error(`Graph "${this.name}": name "${s}" is already a mount point`);if(this._nodes.has(s))throw new Error(`Graph "${this.name}": node "${s}" already exists`);let a=this._nodeToName.get(e);if(a!==void 0)throw new Error(`Graph "${this.name}": node instance already registered as "${a}"`);return this._nodes.set(s,e),this._nodeToName.set(e,s),this._emitTopology({kind:"added",name:s,nodeKind:"node"}),i!=null&&(this._annotations.set(s,i),this.config.inspectorEnabled&&this._traceRing.push({path:s,annotation:i,timestamp_ns:he()})),e}setVersioning(e){if(e!=null)for(let n of this._nodes.values())n instanceof F&&n._applyVersioning(e)}remove(e){wt(e,this.name,"remove");let n=this._mounts.get(e);if(n){let s={kind:"mount",nodes:[],mounts:[]},i=[];n._collectObserveTargets("",i);for(let[a,c]of i)a.includes(`${P}${Y}${P}`)||s.nodes.push(a);return s.nodes.sort(),s.mounts.push(e),s.mounts.push(...n._collectSubgraphs(`${e}${P}`)),this._mounts.delete(e),n._parent=void 0,mn(n),this._emitTopology({kind:"removed",name:e,nodeKind:"mount",audit:s}),s}let r=this._nodes.get(e);if(!r)throw new Error(`Graph "${this.name}": unknown node or mount "${e}"`);this._nodes.delete(e),this._nodeToName.delete(r),r.down([[V]],{internal:!0});let o={kind:"node",nodes:[e],mounts:[]};return this._emitTopology({kind:"removed",name:e,nodeKind:"node",audit:o}),o}removeAll(e){let n=typeof e=="function"?e:(()=>{let s=Je(e);return i=>s.test(i)})(),r={kind:"mount",nodes:[],mounts:[]},o=[...this._nodes.keys(),...this._mounts.keys()].filter(s=>n(s));for(let s of o){let i=this.remove(s);r.nodes.push(...i.nodes),r.mounts.push(...i.mounts)}return r.nodes.sort(),r.mounts.sort(),r}[Symbol.iterator](){let e=[...this._nodes.keys()].sort(),n=this._nodes,r=0;return{[Symbol.iterator](){return this},next(){if(r>=e.length)return{value:void 0,done:!0};let o=e[r++];return{value:[o,n.get(o)],done:!1}}}}node(e){if(e==="")throw new Error(`Graph "${this.name}": node name must be non-empty`);if(e.includes(P))return this.resolve(e);let n=this._nodes.get(e);if(!n)throw new Error(`Graph "${this.name}": unknown node "${e}"`);return n}get(e){return this.node(e).cache}set(e,n,r){let o=r?.internal===!0;this.node(e).down([[L,n]],{actor:r?.actor,internal:o,delivery:"write"})}setAll(e,n){let r=Symbol.iterator in e?e:Object.entries(e);Ce(()=>{for(let[o,s]of r)this.set(o,s,n)})}invalidate(e,n){let r=n?.internal===!0;this.node(e).down([[Z]],{actor:n?.actor,internal:r,delivery:"write"})}error(e,n,r){let o=r?.internal===!0;this.node(e).down([[M,n]],{actor:r?.actor,internal:o,delivery:"write"})}complete(e,n){let r=n?.internal===!0;this.node(e).down([[j]],{actor:n?.actor,internal:r,delivery:"write"})}edges(e){let n=e?.recursive===!0,r=new Map;if(!n){for(let[c,u]of this._nodes)r.set(u,c);let a=[];for(let[c,u]of this._nodes)if(u instanceof F)for(let l of u._deps){let p=r.get(l.node);p!=null&&a.push([p,c])}return a.sort((c,u)=>c[0]<u[0]?-1:c[0]>u[0]?1:c[1]<u[1]?-1:c[1]>u[1]?1:0),a}let o=[];this._collectObserveTargets("",o);let s=new Map;for(let[a,c]of o)s.set(c,a);let i=[];for(let[a,c]of o)if(c instanceof F)for(let u of c._deps){let l=s.get(u.node);l!=null&&i.push([l,a])}return i.sort((a,c)=>a[0]<c[0]?-1:a[0]>c[0]?1:a[1]<c[1]?-1:a[1]>c[1]?1:0),i}mount(e,n){if(wt(e,this.name,"mount"),this._nodes.has(e))throw new Error(`Graph "${this.name}": cannot mount at "${e}" \u2014 node with that name exists`);if(this._mounts.has(e))throw new Error(`Graph "${this.name}": mount "${e}" already exists`);if(n===this)throw new Error(`Graph "${this.name}": cannot mount a graph into itself`);if(n._parent!=null)throw new Error(`Graph "${this.name}": this child graph is already mounted on "${n._parent.name}"`);for(let r=this;r!=null;r=r._parent)if(r===n)throw new Error(`Graph "${this.name}": mount("${e}", \u2026) would create a mount cycle`);return this._mounts.set(e,n),n._parent=this,this._emitTopology({kind:"added",name:e,nodeKind:"mount"}),n}resolve(e){let n=Br(e,this.name);return this._resolveFromSegments(n)}tryResolve(e){try{return this.resolve(e)}catch{return}}_resolveFromSegments(e){let n=e;if(n[0]===this.name&&(n=n.slice(1),n.length===0))throw new Error(`Graph "${this.name}": resolve path ends at graph name only`);let r=n[0],o=n.slice(1);if(o.length===0){let a=this._nodes.get(r);if(a)return a;throw this._mounts.has(r)?new Error(`Graph "${this.name}": path ends at subgraph "${r}" \u2014 not a node (GRAPHREFLY-SPEC \xA73.5)`):new Error(`Graph "${this.name}": unknown name "${r}"`)}let s=this._nodes.get(r);if(s&&o.length>0&&o[0]===Y)return this._resolveMetaChainFromNode(s,o,n.join(P));let i=this._mounts.get(r);if(!i)throw this._nodes.has(r)?new Error(`Graph "${this.name}": "${r}" is a node; trailing path "${o.join(P)}" is invalid`):new Error(`Graph "${this.name}": unknown mount or node "${r}"`);return i.resolve(o.join(P))}_resolveMetaChainFromNode(e,n,r){let o=e,s=0,i=[...n];for(;s<i.length;){if(i[s]!==Y)throw new Error(`Graph "${this.name}": expected ${Y} segment in meta path "${r}"`);if(s+1>=i.length)throw new Error(`Graph "${this.name}": meta path requires a key after ${Y} in "${r}"`);let a=i[s+1],c=o.meta[a];if(!c)throw new Error(`Graph "${this.name}": unknown meta "${a}" in path "${r}"`);o=c,s+=2}return o}signal(e,n){if(n?.internal!==!0){for(let o of e)if(this.config.messageTier(o[0])===3)throw new Error(`Graph "${this.name}": Graph.signal() rejects tier-3 messages (DATA / RESOLVED). Broadcast is for control-plane tiers (START / DIRTY / INVALIDATE / PAUSE / RESUME / COMPLETE / ERROR / TEARDOWN). For per-node value writes, use Graph.set or graph.node(name).down(...).`)}let r=[];if(this._signalDeliver(e,n??{},new Set,r),r.length>0)throw r[0]}_signalDeliver(e,n,r,o){for(let c of this._mounts.values())c._signalDeliver(e,n,r,o);let i=n.internal===!0?{internal:!0}:{actor:n.actor,delivery:"signal"},a=Vr(e,this.config);for(let c of[...this._nodes.keys()].sort()){let u=this._nodes.get(c);if(!r.has(u)){r.add(u);try{u.down(e,i)}catch(l){if(l instanceof J)throw l;o.push(l)}a.length!==0&&this._signalMetaSubtree(u,a,r,i,o)}}}_signalMetaSubtree(e,n,r,o,s){for(let i of Object.keys(e.meta).sort()){let a=e.meta[i];if(!r.has(a)){r.add(a);try{a.down(n,o)}catch(c){if(c instanceof J)throw c;s.push(c)}this._signalMetaSubtree(a,n,r,o,s)}}}describe(e){if(e?.reactive===!0)return this._describeReactive(e);let n=e?.actor,r=e?.filter,o=Be(e?.detail,e?.fields),s=e?.format==="spec",i=s?Be("minimal"):o,a=[];this._collectObserveTargets("",a);let c=new Map;for(let[S,w]of a)c.set(w,S);let u=[];{let S=a.map(([,k])=>k),w=new Set(c.values()),_=0;for(;S.length>0;){let k=S.shift();if(k instanceof F)for(let A of k._deps){let T=A.node;if(c.has(T))continue;let R=T.name??"",N=R;if(!N||w.has(N))if(R){let C=2;for(;w.has(`${R}#${C}`);)C++;N=`${R}#${C}`}else for(N=`__internal__/${_++}`;w.has(N);)N=`__internal__/${_++}`;c.set(T,N),w.add(N),u.push([N,T]),S.push(T)}}}let l=[...a,...u],p={};for(let[S,w]of l){if(n!=null&&!w.allowsObserve(n))continue;let _=yt(w,i),k=w instanceof F?w._deps.map(N=>c.get(N.node)??N.node.name??""):[],{name:A,...T}=_,R={...T,deps:k};if(!s){let N=this._annotations.get(S);N!=null&&(R.annotation=N)}if(r!=null)if(typeof r=="function"){let N=r;if(!(N.length>=2?N(S,R):N(R)))continue}else{let N=!0;for(let[C,H]of Object.entries(r)){let X=C==="deps_includes"?"depsIncludes":C==="meta_has"?"metaHas":C;if(X==="depsIncludes"){if(!R.deps.includes(String(H))){N=!1;break}continue}if(X==="metaHas"){if(!Object.hasOwn(R.meta??{},String(H))){N=!1;break}continue}if(R[X]!==H){N=!1;break}}if(!N)continue}p[S]=R}let h=new Set(Object.keys(p)),f=[];for(let[S,w]of l)if(w instanceof F)for(let _ of w._deps){let k=c.get(_.node);k!=null&&f.push([k,S])}f.sort((S,w)=>S[0]<w[0]?-1:S[0]>w[0]?1:S[1]<w[1]?-1:S[1]>w[1]?1:0);let d=f.map(([S,w])=>({from:S,to:w}));(n!=null||r!=null)&&(d=d.filter(S=>h.has(S.from)&&h.has(S.to)));let g=this._collectSubgraphs(""),m=n!=null||r!=null?g.filter(S=>{let w=`${S}${P}`;return[...h].some(_=>_===S||_.startsWith(w))}):g,b=this,y=e,v={name:this.name,nodes:p,edges:d,subgraphs:m,expand(S){let w={...y,format:void 0};return Array.isArray(S)?(w.fields=S,w.detail=void 0):(w.detail=S,w.fields=void 0),b.describe(w)}},x=e??{},O=x.format;return O==="json"?Dr(v,x):O==="pretty"?Cr(v,x):O==="mermaid"?gn(v,x):O==="mermaid-url"?Gr(v,x):O==="d2"?$r(v,x):O==="ascii"?tn(v,x):v}_collectSubgraphs(e){let n=[];for(let r of[...this._mounts.keys()].sort()){let o=e===""?r:`${e}${r}`;n.push(o),n.push(...this._mounts.get(r)._collectSubgraphs(`${o}${P}`))}return n}resourceProfile(e){return cn(this,e)}reachable(e,n,r={}){return r.withDetail===!0?fn(this.describe(),e,n,{...r,withDetail:!0}):fn(this.describe(),e,n,r)}explain(e,n,r){return r?.reactive===!0?this._explainReactive(e,n,r):this._explainStatic(e,n,r)}_explainStatic(e,n,r){let o=this.describe({detail:"full"}),s=new Map(this._annotations),i=new Map;for(let[a,c]of Object.entries(o.nodes))c.lastMutation!=null&&i.set(a,c.lastMutation);return nn(o,e,n,{...r?.maxDepth!=null?{maxDepth:r.maxDepth}:{},...r?.findCycle===!0?{findCycle:!0}:{},annotations:s,lastMutations:i})}_describeReactive(e){let n={...e,reactive:!1},r=e.reactiveName??"describe",o=0,s=te(o,{name:`${r}_version`}),i=this.observe({timeline:!0,structured:!0}),a=!1,c=!1,u=()=>{a||c||(a=!0,Se(()=>{a=!1,!c&&(o+=1,s.emit(o))}))},l=i.onEvent(m=>{let b=m.type;b!=="data"&&b!=="error"&&b!=="complete"&&b!=="teardown"||u()}),p=[],h=new WeakSet,f=m=>{if(h.has(m)||c)return;h.add(m);let b=m.topology.subscribe(y=>{for(let v of y){if(v[0]!==L)continue;let x=v[1];if(u(),x.kind==="added"&&x.nodeKind==="mount"){let O=m._mounts.get(x.name);O!=null&&f(O)}}});p.push(b);for(let y of m._mounts.keys()){let v=m._mounts.get(y);v!=null&&f(v)}};f(this);let d;try{d=de([s],()=>this.describe(n),{name:r,describeKind:"derived",meta:{domain:"audit",kind:"describe"},equals:(m,b)=>m===b})}catch(m){l();for(let b of p)b();throw i.dispose(),m}let g=ve(d);return{node:d,dispose(){c=!0,l();for(let m of p)m();p.length=0,i.dispose(),g()}}}_explainReactive(e,n,r){let o=0,s=te(o,{name:"explain_version"}),i=this.observe({timeline:!0,structured:!0}),a=!1,c=!1,u=i.onEvent(f=>{let d=f.type;d!=="data"&&d!=="error"&&d!=="complete"&&d!=="teardown"||a||c||(a=!0,Se(()=>{a=!1,!c&&(o+=1,s.emit(o))}))}),l={...r?.maxDepth!=null?{maxDepth:r.maxDepth}:{},...r?.findCycle===!0?{findCycle:!0}:{}},p;try{p=de([s],()=>this._explainStatic(e,n,l),{name:r?.name??"explain",describeKind:"derived",meta:{domain:"audit",kind:"explain_path",from:e,to:n},equals:(f,d)=>f.found===d.found&&f.reason===d.reason&&f.steps.length===d.steps.length&&zr(f.steps,d.steps)})}catch(f){throw u(),i.dispose(),f}let h=ve(p);return{node:p,dispose(){c=!0,u(),i.dispose(),h()}}}_pathsMatching(e){let n=Je(e),r=[];return this._collectObserveTargets("",r),r.map(([o])=>o).filter(o=>n.test(o))}_collectObserveTargets(e,n){for(let r of[...this._mounts.keys()].sort()){let o=e===""?r:`${e}${P}${r}`;this._mounts.get(r)._collectObserveTargets(o,n)}for(let r of[...this._nodes.keys()].sort()){let o=this._nodes.get(r),s=e===""?r:`${e}${P}${r}`;n.push([s,o]),this._appendMetaObserveTargets(s,o,n)}}_appendMetaObserveTargets(e,n,r){for(let o of Object.keys(n.meta).sort()){let s=n.meta[o],i=`${e}${P}${Y}${P}${o}`;r.push([i,s]),this._appendMetaObserveTargets(i,s,r)}}observe(e,n){let r=typeof e=="string",s=ln(r?n:e),i=s.structured===!0||s.timeline===!0||s.causal===!0||s.derived===!0||s.detail==="minimal"||s.detail==="full"||s.format!=null,a=s.actor;if(r){let l=e,p=this.resolve(l);if(a!=null&&!p.allowsObserve(a))throw new J({actor:a,action:"observe",nodeName:l});return i?this._buildStructuredObserver([[l,p]],s,"one"):{subscribe(h){return p.subscribe(h)},up(h){try{p.up?.(h)}catch(f){if(f instanceof J)return;throw f}}}}let c=[];this._collectObserveTargets("",c),c.sort((l,p)=>l[0]<p[0]?-1:l[0]>p[0]?1:0);let u=a==null?c:c.filter(([,l])=>l.allowsObserve(a));return i?this._buildStructuredObserver(u,s,"all"):{subscribe:l=>{let p=u.map(([h,f])=>f.subscribe(d=>{l(h,d)}));return()=>{for(let h of p)h()}},up:(l,p)=>{try{this.resolve(l).up?.(p)}catch(h){if(h instanceof J)return;throw h}}}}_buildStructuredObserver(e,n,r){let o=r==="one"?e[0]?.[0]:void 0,s=i=>{if(r==="one"&&o!=null){let l=this.resolve(o);return this._buildStructuredObserver([[o,l]],i,"one")}let a=[];this._collectObserveTargets("",a),a.sort((l,p)=>l[0]<p[0]?-1:l[0]>p[0]?1:0);let c=i.actor,u=c==null?a:a.filter(([,l])=>l.allowsObserve(c));return this._buildStructuredObserver(u,i,"all")};return this._createObserveResult(e,n,s)}_createObserveResult(e,n,r){let o=n.timeline===!0,s=n.causal===!0,i=n.derived===!0,a=n.detail==="minimal",c=this.config.inspectorEnabled,u=(s||i)&&c,l=n.maxEvents,p=l!=null&&l>0?new Ne(l):null,h=[],f=new Set,d={},g=new Set,m=0,b=0,y=0,v=0,x=0,O=0,S=!1,w=!1,_=0,k=new Map,A=new Map,T=new Map,R=E=>{p?p.push(E):h.push(E);for(let $ of f)$(E)},N=()=>o?{timestamp_ns:he(),in_batch:De(),batch_id:_}:{},C=(E,$)=>{if(!(!u||!(E instanceof F)))return E._setInspectorHook(U=>{if(U.kind==="dep_message")k.set(E,U.depIndex);else if(U.kind==="run"){let we=U.batchData.map((G,B)=>G!=null&&G.length>0?G.at(-1):U.prevData[B]);A.set(E,we);let K=U.batchData.map(G=>G!=null?[...G]:void 0);T.set(E,K),i&&R({type:"derived",path:$,dep_values:we,dep_batches:K,...N()})}})},H=E=>{let $=k.get(E),U=A.get(E);if(!s||U==null)return{};let K=($!=null&&$>=0&&E instanceof F?E._deps[$]:void 0)?.node,G=K?.v,B=T.get(E);return{trigger_dep_index:$,trigger_dep_name:K?.name,...G!=null?{trigger_version:{id:G.id,version:G.version}}:{},dep_values:[...U],...B!=null?{dep_batches:B}:{}}},X=[],se=[];for(let[E,$]of e){let U=C($,E);U&&X.push(U),se.push($.subscribe(we=>{_++;for(let K of we){let G=K[0],B=N();if(G===L){d[E]=K[1];let nt=$ instanceof F?$.lastMutation?.actor??le:le;R({type:"data",path:E,data:K[1],actor:nt,...B,...H($)})}else if(a)G===z?m++:G===W?b++:G===Z?y++:G===Q?v++:G===ee?x++:G===V?O++:G===j&&!g.has(E)?S=!0:G===M&&(w=!0,g.add(E));else if(G===z)m++,R({type:"dirty",path:E,...B});else if(G===W)b++,R({type:"resolved",path:E,...B,...H($)});else if(G===Z)y++,R({type:"invalidate",path:E,...B});else if(G===Q)v++,R({type:"pause",path:E,lockId:K[1],...B});else if(G===ee)x++,R({type:"resume",path:E,lockId:K[1],...B});else if(G===j)g.has(E)||(S=!0),R({type:"complete",path:E,...B});else if(G===M){w=!0,g.add(E);let nt=$ instanceof F?$.lastMutation?.actor??le:le;R({type:"error",path:E,data:K[1],actor:nt,...B})}else G===V&&(O++,R({type:"teardown",path:E,...B}))}}))}let Qe=!1,et=()=>{if(!Qe){Qe=!0;for(let E of se)E();for(let E of X)E();for(let E of Re)E({value:void 0,done:!0});Re.length=0}},tt=[],Re=[];f.add(E=>{let $=Re.shift();$?$({value:E,done:!1}):tt.push(E)});let Et={get values(){return d},get dirtyCount(){return m},get resolvedCount(){return b},get invalidateCount(){return y},get pauseCount(){return v},get resumeCount(){return x},get teardownCount(){return O},get events(){return p?p.toArray():[...h]},get anyCompletedCleanly(){return S},get anyErrored(){return w},get completedWithoutErrors(){return S&&!w},onEvent(E){return f.add(E),()=>f.delete(E)},dispose:et,expand(E){et();let $={...n};return typeof E=="string"?$.detail=E:Object.assign($,E),r(ln($))},[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=>Re.push(E))},return(){return et(),Promise.resolve({value:void 0,done:!0})}}}};return n.format!=null&&this._attachFormatLogger(Et,n),Et}_attachFormatLogger(e,n){let r=n.format;if(r==null)return;let o=n.logger??(d=>console.log(d)),s=n.includeTypes?new Set(n.includeTypes):null,i=n.excludeTypes?new Set(n.excludeTypes):null,a=s==null&&i==null?()=>!0:d=>(s==null||s.has(d))&&(i==null||!i.has(d)),c=Ir(n.theme),u=r==="stage-log"?he():0,l=d=>d==null?"":n.stageLabels?.[d]??d,p=(d,g)=>d.length>g?`${d.slice(0,g-1)}\u2026`:d,h=d=>d.type==="data"||d.type==="error"?p(Ye(d.data),120):"",f=d=>{if(r==="stage-log"){let w=(he()-u)/1e9,_=l(d.path).padEnd(9);if(d.type==="data"){let k=h(d);return`[${w.toFixed(3)}s] ${_} \u2190${k?` ${k}`:""}`}if(d.type==="error"){let k=h(d);return`[${w.toFixed(3)}s] ${_} \u2717${k?` ${k}`:""}`}return d.type==="complete"?`[${w.toFixed(3)}s] ${_} \u25A0 complete`:`[${w.toFixed(3)}s] ${_} ${d.type}`}if(r==="json")try{return JSON.stringify(d)}catch{return JSON.stringify({type:d.type,path:d.path,data:"[unserializable]"})}let g=c[d.type]??"",m=d.path?`${c.path}${d.path}${c.reset} `:"",b=d.type==="data"||d.type==="error",y=d.type==="pause"||d.type==="resume",v=b?` ${Ye(d.data)}`:y?` ${Ye(d.lockId)}`:"",x=d.type==="data"||d.type==="resolved"||d.type==="derived"?d:void 0,O=x?.trigger_dep_name!=null?` <- ${x.trigger_dep_name}`:x?.trigger_dep_index!=null?` <- #${x.trigger_dep_index}`:"",S=d.in_batch?" [batch]":"";return`${m}${g}${d.type.toUpperCase()}${c.reset}${v}${O}${S}`};e.onEvent(d=>{a(d.type)&&o(f(d),d)})}addDisposer(e){return this._disposers.add(e),()=>{this._disposers.delete(e)}}destroy(){un(this._disposers,this.name),this.signal([[V]],{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}_destroyClearOnly(){for(let e of[...this._mounts.values()])e._parent=void 0,e._destroyClearOnly();this._mounts.clear(),this._nodes.clear(),this._parent=void 0}snapshot(e){let{expand:n,...r}=this.describe({detail:"full"}),o={};for(let a of Object.keys(r.nodes).sort()){let{lastMutation:c,guard:u,...l}=r.nodes[a];o[a]=l}let s=[...r.subgraphs].sort(),i={...r,version:1,nodes:o,subgraphs:s};if(e?.format==null)return i;if(e.format==="json-string")return JSON.stringify(i);if(e.format==="bytes"){if(e.codec==null)throw new Error("snapshot({format: 'bytes'}) requires a `codec` name");let a=this.config.lookupCodec(e.codec);if(a==null)throw new Error(`snapshot: codec "${e.codec}" is not registered on this graph's config. Call config.registerCodec(...) before creating nodes.`);return Rt(a,a.encode(i))}throw new Error(`snapshot: unknown format "${String(e.format)}"`)}static decode(e,n){let r=n?.config??ye,{codec:o,codecVersion:s,payload:i}=At(e,r);return o.decode(i,s)}restore(e,n){if(dn(e),e.name!==this.name)throw new Error(`Graph "${this.name}": restore snapshot name "${e.name}" does not match this graph`);let r=n?.only==null?null:(Array.isArray(n.only)?n.only:[n.only]).map(s=>Je(s)),o=n?.includeProducers===!0;for(let s of Object.keys(e.nodes).sort()){if(r!==null&&!r.some(a=>a.test(s)))continue;let i=e.nodes[s];if(i!==void 0){if(!("value"in i)||i.value===void 0){"value"in i&&i.value===void 0&&n?.onError?.(s,new Error(`restore: slice.value is undefined for "${s}" (undefined is the global SENTINEL; not valid DATA)`));continue}if(!(i.type==="derived"||i.type==="effect")&&!(i.type==="producer"&&!o)){if(i.v!=null){let c=this.tryResolve(s)?.v;if(c!=null&&c.id===i.v.id&&c.version===i.v.version)continue}try{this.set(s,i.value)}catch(a){n?.onError?.(s,a)}}}}}static fromSnapshot(e,n){dn(e);let r=typeof n=="function"?n:n?.build,o=typeof n=="function"?void 0:n?.factories,s=new t(e.name);if(r)return r(s),s.restore(e),s;for(let f of[...e.subgraphs].sort((d,g)=>{let m=d.split(P).length,b=g.split(P).length;return m!==b?m-b:d<g?-1:d>g?1:0})){let d=f.split(P),g=s;for(let m of d)g._mounts.has(m)||g.mount(m,new t(m)),g=g._mounts.get(m)}let i=o?Object.entries(o).map(([f,d])=>({re:Je(f),factory:d})):[],a=f=>{for(let d of i)if(d.re.test(f))return d.factory},c=f=>{let d=f.split(P),g=d.pop();if(g==null||g.length===0)throw new Error(`invalid snapshot path "${f}"`);let m=s;for(let b of d){let y=m._mounts.get(b);if(!y)throw new Error(`unknown mount "${b}" in path "${f}"`);m=y}return[m,g]},u=Object.entries(e.nodes).filter(([f])=>!f.includes(`${P}${Y}${P}`)).sort((f,d)=>f[0]<d[0]?-1:f[0]>d[0]?1:0),l=new Map(u),p=new Map,h=!0;for(;l.size>0&&h;){h=!1;for(let[f,d]of[...l.entries()]){let g=d?.deps??[];if(!g.every(O=>p.has(O)))continue;let[m,b]=c(f),y={...d?.meta??{}},v=a(f),x;if(d?.type==="state")x=te(d.value,{meta:y});else{if(v==null)continue;x=v(b,{path:f,type:d.type,value:d.value,meta:y,deps:g,resolvedDeps:g.map(O=>p.get(O))})}m.add(x,{name:b}),p.set(f,x),l.delete(f),h=!0}}if(l.size>0){let f=[...l.keys()].sort().join(", ");throw new Error(`Graph.fromSnapshot could not reconstruct nodes without build callback: ${f}. Pass matching factories via fromSnapshot(data, { factories: { pattern: factoryFn } }).`)}return s.restore(e),s}toJSON(){return this.snapshot()}attachStorage(e,n={}){let r=e.map(u=>({tier:u,debounceMs:Math.max(0,u.debounceMs??0),compactEvery:Math.max(1,u.compactEvery??10),timer:void 0,seq:0,lastSnapshot:void 0,lastFingerprint:"",disposed:!1,savePending:void 0}));n.autoRestore===!0&&this._cascadeRestore(e,n.onError);let o=(u,l)=>{if(u.disposed)return;let p=Nr(l.nodes);if(u.lastSnapshot!=null&&p!==""&&p===u.lastFingerprint)return;let h=u.seq+1,f=ge(),m=u.lastSnapshot==null||h%u.compactEvery===0?{mode:"full",snapshot:l,seq:h,timestamp_ns:f,format_version:oe}:{mode:"diff",diff:Hr(u.lastSnapshot,l),seq:h,timestamp_ns:f,format_version:oe};if(u.tier.filter&&!u.tier.filter(this.name,m))return;let b;try{b=u.tier.save(this.name,m)}catch(y){n.onError?.(y,u.tier);return}if(b&&typeof b.then=="function"){let x=(u.savePending??Promise.resolve()).then(()=>b,()=>b).then(()=>{u.disposed||(u.seq=h,u.lastSnapshot=l,u.lastFingerprint=p)},O=>{n.onError?.(O,u.tier)});u.savePending=x.finally(()=>{u.savePending===x&&(u.savePending=void 0)})}else u.seq=h,u.lastSnapshot=l,u.lastFingerprint=p},s=(u,l)=>{try{o(u,l)}catch(p){n.onError?.(p,u.tier)}},i=(u,l)=>{if(!l.some(d=>{let g=this.config.messageTier(d[0]);return g>=3&&g<5}))return;if(n.filter){let d=this.tryResolve(u);if(d==null)return;let g=yt(d,Be("standard"));if(!n.filter(u,g))return}let h,f=()=>(h==null&&(h=this.snapshot()),h);for(let d of r)d.disposed||(d.debounceMs===0?s(d,f()):(d.timer==null&&(d.timer=new Ve),d.timer.start(d.debounceMs,()=>{d.disposed||s(d,this.snapshot())})))},a;if(n.paths!=null){let l=(typeof n.paths=="string"?this._pathsMatching(n.paths):n.paths).map(p=>{let h=this.tryResolve(p);return h==null?()=>{}:h.subscribe(f=>i(p,f))});a=()=>{for(let p of l)p()}}else a=this.observe().subscribe((u,l)=>i(u,l));let c=()=>{a();for(let u of r)u.disposed=!0,u.timer?.cancel();this._storageDisposers.delete(c)};return this._storageDisposers.add(c),{dispose:c}}async _cascadeRestore(e,n){for(let r of e){let o;try{o=await r.load(this.name)}catch(i){n?.(i,r);continue}if(o==null||typeof o!="object"||Array.isArray(o))continue;let s=o;try{if(s.mode==="full"&&s.snapshot!=null)return this.restore(s.snapshot),!0;if(s.version===oe&&s.nodes!=null)return this.restore(s),!0}catch(i){n?.(i,r)}}return!1}static async fromStorage(e,n,r){for(let o of n){let s;try{s=await o.load(e)}catch(c){r?.onError?.(c,o);continue}if(s==null||typeof s!="object"||Array.isArray(s))continue;let i=s,a=i.mode==="full"&&i.snapshot!=null?i.snapshot:i.version===oe&&i.nodes!=null?i:void 0;if(a!=null)try{return t.fromSnapshot(a,r)}catch(c){r?.onError?.(c,o)}}throw new Error(`Graph.fromStorage: no tier held a restorable record for "${e}" across ${n.length} tier(s)`)}_annotations=new Map;_traceRing;trace(e,n,r){if(e!=null&&n!=null){if(this.tryResolve(e)==null)return;if(this._annotations.set(e,n),this.config.inspectorEnabled){let o={path:e,annotation:n,timestamp_ns:he(),...r?.actor!=null?{actor:r.actor}:{}};this._traceRing.push(o)}return}return e!=null?this.config.inspectorEnabled?this._annotations.get(e):void 0:this.config.inspectorEnabled?this._traceRing.toArray():[]}annotation(e){return this._annotations.get(e)}clearTrace(){this._annotations.clear(),this._traceRing.clear()}pruneTrace(e){let n=this._traceRing.toArray().filter(o=>!e(o)),r=this._traceRing.size-n.length;this._traceRing.clear();for(let o of n)this._traceRing.push(o);return r}static diff(e,n){let r=new Set(Object.keys(e.nodes)),o=new Set(Object.keys(n.nodes)),s=[...o].filter(y=>!r.has(y)).sort(),i=[...r].filter(y=>!o.has(y)).sort(),a=[],c=[];for(let y of r){if(!o.has(y))continue;let v=e.nodes[y],x=n.nodes[y],O=v.v,S=x.v;O!=null&&S!=null&&O.id===S.id&&O.version!==S.version&&c.push({path:y,id:O.id,from:O.version,to:S.version});let w=O!=null&&S!=null&&O.id===S.id&&O.version===S.version;for(let _ of["type","status","sentinel"]){let k=v[_],A=x[_];k!==A&&a.push({path:y,field:_,from:k,to:A})}if(!w)for(let _ of["value","meta"]){let k=v[_],A=x[_];Er(k,A)||a.push({path:y,field:_,from:k,to:A})}}let u=y=>`${y.from} ${y.to}`,l=new Set(e.edges.map(u)),p=new Set(n.edges.map(u)),h=n.edges.filter(y=>!l.has(u(y))),f=e.edges.filter(y=>!p.has(u(y))),d=new Set(e.subgraphs),g=new Set(n.subgraphs),m=[...g].filter(y=>!d.has(y)).sort(),b=[...d].filter(y=>!g.has(y)).sort();return{nodesAdded:s,nodesRemoved:i,nodesChanged:a,versionChanges:c,edgesAdded:h,edgesRemoved:f,subgraphsAdded:m,subgraphsRemoved:b}}};function Hr(t,e){let n=ne.diff(t,e),r={};for(let o of n.nodesAdded){let s=e.nodes[o];s!=null&&(r[o]=s)}return{...n,nodesAddedFull:r}}function fn(t,e,n,r={}){let o={paths:[],depths:new Map,truncated:!1};if(!e)return r.withDetail?o:[];if(!r.both&&n!=="upstream"&&n!=="downstream")throw new Error('reachable: direction must be "upstream" or "downstream"');let s=r.maxDepth;if(s!=null&&(!Number.isInteger(s)||s<0))throw new Error("reachable: maxDepth must be an integer >= 0");if(s===0)return r.withDetail?o:[];let i=new Map,a=new Map,c=new Map,u=new Map,l=new Set;for(let[v,x]of Object.entries(t.nodes)){if(!v)continue;l.add(v);let O=x.deps??[];i.set(v,O);for(let S of O)S&&(l.add(S),a.has(S)||a.set(S,new Set),a.get(S).add(v))}for(let v of t.edges){if(v==null||typeof v!="object")continue;let x=typeof v.from=="string"?v.from:"",O=typeof v.to=="string"?v.to:"";!x||!O||(l.add(x),l.add(O),u.has(x)||u.set(x,new Set),u.get(x).add(O),c.has(O)||c.set(O,new Set),c.get(O).add(x))}if(!l.has(e))return r.withDetail?o:[];let p=r.both===!0,h=v=>{if(p){let w=i.get(v)??[],_=c.get(v),k=a.get(v),A=u.get(v),T=[...w];return _&&T.push(..._),k&&T.push(...k),A&&T.push(...A),T}if(n==="upstream"){let w=i.get(v)??[],_=c.get(v);return _?[...w,..._]:w}let x=a.get(v),O=u.get(v),S=x?[...x]:[];return O&&S.push(...O),S},f=new Set([e]),d=new Map,g=[{path:e,depth:0}],m=0,b=!1;for(;m<g.length;){let v=g[m++];if(s!=null&&v.depth>=s){h(v.path).length>0&&(b=!0);continue}for(let x of h(v.path))!x||f.has(x)||(f.add(x),d.set(x,v.depth+1),g.push({path:x,depth:v.depth+1}))}let y=[...d.keys()].sort((v,x)=>v<x?-1:v>x?1:0);return r.withDetail?{paths:y,depths:d,truncated:b}:y}function zr(t,e){if(t.length!==e.length)return!1;for(let n=0;n<t.length;n++){let r=t[n],o=e[n];if(r.path!==o.path||r.type!==o.type||r.status!==o.status||r.hop!==o.hop||r.dep_index!==o.dep_index||r.annotation!==o.annotation||r.value!==o.value||r.lastMutation!==o.lastMutation)return!1;let s=r.v,i=o.v;if(s!==i&&(s==null||i==null||s.id!==i.id||s.version!==i.version))return!1}return!0}Me();ce();be();je();ce();bt();function yn(t,e){let n=t.cache??0;return n>=e?!1:(t.down([[z],[L,n+1]]),!0)}function bn(t,e,n){return{[t]:!0,[`${t}_type`]:e,...n??{}}}function vn(t,e){return bn("reduction",t,e)}function wn(t,e,n,r){let o=r?.maxIterations??10,s=`__feedback_${e}`,i=te(0,{meta:vn("feedback_counter",{maxIterations:o,feedbackFrom:e,feedbackTo:n})});t.add(i,{name:s});let a=t.resolve(e),c=t.resolve(n),u=`__feedback_effect_${e}`,l=ue([],(p,h)=>{let f=a.subscribe(d=>{for(let g of d){let m=g[0];if(m===L){let b=g[1];if(b==null)return;Ce(()=>{yn(i,o)&&c.emit(b)})}else if(m===j||m===M){let b=m===M&&g.length>1?[M,g[1]]:[m];i.down([b])}}});return()=>f()},{name:u,describeKind:"effect",meta:{...vn("feedback_effect",{feedbackFrom:e,feedbackTo:n}),_internal:!0}});return t.add(l,{name:u}),t.addDisposer(ve(l)),t}function xn(t){return typeof t=="object"&&t!==null&&"factory"in t}function Wr(t){return typeof t=="object"&&t!==null&&"factory"in t}function Ur(t){return xn(t)?t.factory:t}function Kr(t){return Wr(t)?t.factory:t}function St(t,e){let n=[],r=new Set(Object.keys(e.fns??{})),o=new Set(Object.keys(e.sources??{}));for(let[s,i]of Object.entries(t.nodes)){if(i.type==="template")continue;let a=i;if(a.fn&&r.size>0&&!r.has(a.fn))if(o.has(a.fn))n.push(`Node "${s}": fn "${a.fn}" is a source, not a function. Use it as a producer source instead, or use a function from: ${[...r].join(", ")}`);else{let c=xt(a.fn,r);n.push(`Node "${s}": fn "${a.fn}" not found in catalog`+(c?`. Did you mean "${c}"?`:""))}if(a.source&&o.size>0&&!o.has(a.source))if(r.has(a.source))n.push(`Node "${s}": source "${a.source}" is a function, not a source. Use it as fn instead, or use a source from: ${[...o].join(", ")}`);else{let c=xt(a.source,o);n.push(`Node "${s}": source "${a.source}" not found in catalog`+(c?`. Did you mean "${c}"?`:""))}if(a.fn&&a.config&&e.fns?.[a.fn]){let c=e.fns[a.fn];if(xn(c)&&c.configSchema){for(let[u,l]of Object.entries(c.configSchema))if(l.required!==!1&&!(u in a.config)&&n.push(`Node "${s}": config missing required field "${u}"`),u in a.config&&l.enum){let p=a.config[u];l.enum.includes(p)||n.push(`Node "${s}": config.${u} = ${JSON.stringify(p)}, expected one of: ${l.enum.join(", ")}`)}}}}if(t.templates){for(let[s,i]of Object.entries(t.templates))for(let[a,c]of Object.entries(i.nodes))if(c.fn&&r.size>0&&!r.has(c.fn)){let u=xt(c.fn,r);n.push(`Template "${s}" node "${a}": fn "${c.fn}" not found in catalog`+(u?`. Did you mean "${u}"?`:""))}}return{valid:n.length===0,errors:n}}function xt(t,e){let n=null,r=1/0,o=t.toLowerCase();for(let s of e){let i=qr(o,s.toLowerCase());i<r&&i<=Math.max(3,Math.floor(t.length/2))&&(r=i,n=s)}return n}function qr(t,e){let n=t.length,r=e.length,o=Array.from({length:n+1},(s,i)=>Array.from({length:r+1},(a,c)=>i===0?c:c===0?i:0));for(let s=1;s<=n;s++)for(let i=1;i<=r;i++)o[s][i]=t[s-1]===e[i-1]?o[s-1][i-1]:1+Math.min(o[s-1][i],o[s][i-1],o[s-1][i-1]);return o[n][r]}var _n=new Set(["state","producer","derived","effect","operator","template"]),Jr=new Set(["state","producer","derived","effect","operator"]);function Ot(t){let e=[];if(t==null||typeof t!="object")return{valid:!1,errors:["GraphSpec must be a non-null object"]};let n=t;if((typeof n.name!="string"||n.name.length===0)&&e.push("Missing or empty 'name' field"),n.nodes==null||typeof n.nodes!="object"||Array.isArray(n.nodes))return e.push("Missing or invalid 'nodes' field (must be an object)"),{valid:!1,errors:e};let r=new Set(Object.keys(n.nodes)),o=new Map,s=new Map;if(n.templates!=null&&typeof n.templates=="object"&&!Array.isArray(n.templates)){for(let[i,a]of Object.entries(n.templates))if(a!=null&&typeof a=="object"){let c=a;s.set(i,{params:Array.isArray(c.params)?c.params:[]})}}if(n.templates!=null)if(typeof n.templates!="object"||Array.isArray(n.templates))e.push("'templates' must be an object");else for(let[i,a]of Object.entries(n.templates)){if(a==null||typeof a!="object"){e.push(`Template "${i}": must be an object`);continue}let c=a;if(Array.isArray(c.params)||e.push(`Template "${i}": missing 'params' array`),c.nodes==null||typeof c.nodes!="object"||Array.isArray(c.nodes))e.push(`Template "${i}": missing or invalid 'nodes' object`);else{let u=new Set(Array.isArray(c.params)?c.params:[]),l=new Set(Object.keys(c.nodes));for(let[p,h]of Object.entries(c.nodes)){if(h==null||typeof h!="object"){e.push(`Template "${i}" node "${p}": must be an object`);continue}let f=h;if((typeof f.type!="string"||!Jr.has(f.type))&&e.push(`Template "${i}" node "${p}": invalid type`),Array.isArray(f.deps))for(let d of f.deps)!l.has(d)&&!u.has(d)&&e.push(`Template "${i}" node "${p}": dep "${d}" is not an inner node or param`)}typeof c.output!="string"?e.push(`Template "${i}": missing 'output' string`):c.nodes[c.output]||e.push(`Template "${i}": output "${c.output}" is not a declared node`)}}for(let[i,a]of Object.entries(n.nodes)){if(a==null||typeof a!="object"){e.push(`Node "${i}": must be an object`);continue}let c=a;if(typeof c.type!="string"||!_n.has(c.type)){e.push(`Node "${i}": invalid type "${String(c.type)}" (expected: ${[..._n].join(", ")})`);continue}if(o.set(i,c.type),c.type==="template")if(typeof c.template!="string"||!s.has(c.template))e.push(`Node "${i}": template "${String(c.template)}" not found in templates`);else if(c.bind==null||typeof c.bind!="object"||Array.isArray(c.bind))e.push(`Node "${i}": template ref requires 'bind' object`);else{let u=s.get(c.template),l=c.bind;for(let p of u.params)p in l||e.push(`Node "${i}": template param "${p}" is not bound (template "${c.template}")`);for(let[,p]of Object.entries(l))typeof p=="string"&&!r.has(p)&&e.push(`Node "${i}": bind target "${p}" does not reference an existing node`)}else{if(Array.isArray(c.deps))for(let u of c.deps)u===i?e.push(`Node "${i}": self-referencing dep`):r.has(u)||e.push(`Node "${i}": dep "${u}" does not reference an existing node`);(c.type==="derived"||c.type==="effect"||c.type==="operator")&&!Array.isArray(c.deps)&&e.push(`Node "${i}": ${c.type} node should have a 'deps' array`)}}if(n.feedback!=null)if(!Array.isArray(n.feedback))e.push("'feedback' must be an array");else for(let i=0;i<n.feedback.length;i++){let a=n.feedback[i];if(a==null||typeof a!="object"){e.push(`Feedback [${i}]: must be an object`);continue}let c=a;(typeof c.from!="string"||!r.has(c.from))&&e.push(`Feedback [${i}]: 'from' "${String(c.from)}" does not reference an existing node`),typeof c.from=="string"&&c.from===c.to&&e.push(`Feedback [${i}]: 'from' and 'to' must be different nodes`),typeof c.to!="string"||!r.has(c.to)?e.push(`Feedback [${i}]: 'to' "${String(c.to)}" does not reference an existing node`):typeof c.to=="string"&&o.get(c.to)!=="state"&&e.push(`Feedback [${i}]: 'to' node "${c.to}" must be a state node (got "${o.get(c.to)??"unknown"}")`)}return{valid:e.length===0,errors:e}}function Sn(t,e){let n=Ot(t);if(!n.valid)throw new Error(`compileSpec: invalid GraphSpec:
7
+ `)}function Pr(t){return t.replace(/[.*+?^${}()|[\]\\]/g,"\\$&")}function Je(t){let e="^";for(let n=0;n<t.length;n+=1){let r=t[n];if(r==="*"){e+=".*";continue}if(r==="?"){e+=".";continue}if(r==="["){let o=t.indexOf("]",n+1);if(o<=n+1){e+="\\[";continue}let s=t.slice(n+1,o);s.startsWith("!")&&(s=`^${s.slice(1)}`),s=s.replace(/\\/g,"\\\\"),e+=`[${s}]`,n=o;continue}e+=Pr(r)}return e+="$",new RegExp(e)}var Lr={data:"\x1B[32m",dirty:"\x1B[33m",resolved:"\x1B[36m",invalidate:"\x1B[93m",pause:"\x1B[90m",resume:"\x1B[96m",complete:"\x1B[34m",error:"\x1B[31m",teardown:"\x1B[91m",derived:"\x1B[35m",path:"\x1B[90m",reset:"\x1B[0m"},Fr={data:"",dirty:"",resolved:"",invalidate:"",pause:"",resume:"",complete:"",error:"",teardown:"",derived:"",path:"",reset:""};function Ye(t){if(typeof t=="string")return JSON.stringify(t);if(typeof t=="number"||typeof t=="boolean"||t==null)return String(t);try{return JSON.stringify(t)}catch{return"[unserializable]"}}function Ir(t){return t==="none"?Fr:t==="ansi"||t==null?Lr:{data:t.data??"",dirty:t.dirty??"",resolved:t.resolved??"",invalidate:t.invalidate??"",pause:t.pause??"",resume:t.resume??"",complete:t.complete??"",error:t.error??"",teardown:t.teardown??"",derived:t.derived??"",path:t.path??"",reset:t.reset??""}}function ln(t){if(t==null)return{};let e=t.detail;return e==="full"?{...t,structured:t.structured??!0,timeline:t.timeline??!0,causal:t.causal??!0,derived:t.derived??!0}:e==="minimal"?{...t,structured:t.structured??!0}:t.format==="stage-log"?{...t,structured:t.structured??!0,timeline:t.timeline??!0}:t}function jr(t,e,n){for(let r=0;r<t.length;r++){let o=t.charCodeAt(r);if(o<32||o===127)throw new Error(`Graph "${e}": ${n} "${t}" must not contain control character (U+${o.toString(16).padStart(4,"0").toUpperCase()} at index ${r})`)}}function wt(t,e,n){if(t==="")throw new Error(`Graph "${e}": ${n} name must be non-empty`);if(t.includes(P))throw new Error(`Graph "${e}": ${n} "${t}" must not contain '${P}' (path separator)`);if(t===Y)throw new Error(`Graph "${e}": ${n} name "${Y}" is reserved for meta companion paths`);jr(t,e,n)}function Br(t,e){if(t==="")throw new Error(`Graph "${e}": resolve path must be non-empty`);let n=t.split(P);for(let r of n)if(r==="")throw new Error(`Graph "${e}": resolve path has empty segment`);return n}function Vr(t,e){let n=!1;for(let o of t)if(!e.isMetaPassthrough(o[0])){n=!0;break}return n?t.filter(o=>e.isMetaPassthrough(o[0])):t}function mn(t){for(let e of t._mounts.values())mn(e);for(let e of t._nodes.values())try{e.down([[V]],{internal:!0})}catch{}}var ne=class t{name;opts;config;_nodes=new Map;_nodeToName=new WeakMap;_mounts=new Map;_parent=void 0;_storageDisposers=new Set;_disposers=new Set;_topology;_topologyEmitters=new Set;constructor(e,n){if(e==="")throw new Error("Graph name must be non-empty");if(e.includes(P))throw new Error(`Graph name must not contain '${P}' (got "${e}")`);if(e===Y)throw new Error(`Graph name "${Y}" is reserved for meta companion paths`);this.name=e,this.opts=Object.freeze({...n??{}}),this.config=n?.config??ye,this._traceRing=new Ne(n?.traceCapacity??1e3),n?.versioning!=null&&this.setVersioning(n.versioning)}ancestors(e=!0){let n=[],r=e?this:this._parent;for(;r!=null;)n.push(r),r=r._parent;return n}get topology(){return this._topology==null&&(this._topology=Te(e=>{let n=r=>{e.emit(r)};return this._topologyEmitters.add(n),()=>{this._topologyEmitters.delete(n)}},{name:`${this.name}_topology`})),this._topology}_emitTopology(e){if(!(this._topology==null||this._topologyEmitters.size===0))for(let n of this._topologyEmitters)n(e)}add(e,n){let r=e.name,o=n?.name??r;if(o==null||o==="")throw new Error(`Graph "${this.name}": graph.add requires a non-empty name \u2014 pass via opts.name or set it on the node (e.g. state(0, { name: "x" }))`);let s=o,i=n?.annotation;if(wt(s,this.name,"add"),this._mounts.has(s))throw new Error(`Graph "${this.name}": name "${s}" is already a mount point`);if(this._nodes.has(s))throw new Error(`Graph "${this.name}": node "${s}" already exists`);let a=this._nodeToName.get(e);if(a!==void 0)throw new Error(`Graph "${this.name}": node instance already registered as "${a}"`);return this._nodes.set(s,e),this._nodeToName.set(e,s),this._emitTopology({kind:"added",name:s,nodeKind:"node"}),i!=null&&(this._annotations.set(s,i),this.config.inspectorEnabled&&this._traceRing.push({path:s,annotation:i,timestamp_ns:he()})),e}setVersioning(e){if(e!=null)for(let n of this._nodes.values())n instanceof F&&n._applyVersioning(e)}remove(e){wt(e,this.name,"remove");let n=this._mounts.get(e);if(n){let s={kind:"mount",nodes:[],mounts:[]},i=[];n._collectObserveTargets("",i);for(let[a,c]of i)a.includes(`${P}${Y}${P}`)||s.nodes.push(a);return s.nodes.sort(),s.mounts.push(e),s.mounts.push(...n._collectSubgraphs(`${e}${P}`)),this._mounts.delete(e),n._parent=void 0,mn(n),this._emitTopology({kind:"removed",name:e,nodeKind:"mount",audit:s}),s}let r=this._nodes.get(e);if(!r)throw new Error(`Graph "${this.name}": unknown node or mount "${e}"`);this._nodes.delete(e),this._nodeToName.delete(r),r.down([[V]],{internal:!0});let o={kind:"node",nodes:[e],mounts:[]};return this._emitTopology({kind:"removed",name:e,nodeKind:"node",audit:o}),o}removeAll(e){let n=typeof e=="function"?e:(()=>{let s=Je(e);return i=>s.test(i)})(),r={kind:"mount",nodes:[],mounts:[]},o=[...this._nodes.keys(),...this._mounts.keys()].filter(s=>n(s));for(let s of o){let i=this.remove(s);r.nodes.push(...i.nodes),r.mounts.push(...i.mounts)}return r.nodes.sort(),r.mounts.sort(),r}[Symbol.iterator](){let e=[...this._nodes.keys()].sort(),n=this._nodes,r=0;return{[Symbol.iterator](){return this},next(){if(r>=e.length)return{value:void 0,done:!0};let o=e[r++];return{value:[o,n.get(o)],done:!1}}}}node(e){if(e==="")throw new Error(`Graph "${this.name}": node name must be non-empty`);if(e.includes(P))return this.resolve(e);let n=this._nodes.get(e);if(!n)throw new Error(`Graph "${this.name}": unknown node "${e}"`);return n}get(e){return this.node(e).cache}set(e,n,r){let o=r?.internal===!0;this.node(e).down([[L,n]],{actor:r?.actor,internal:o,delivery:"write"})}setAll(e,n){let r=Symbol.iterator in e?e:Object.entries(e);De(()=>{for(let[o,s]of r)this.set(o,s,n)})}invalidate(e,n){let r=n?.internal===!0;this.node(e).down([[Z]],{actor:n?.actor,internal:r,delivery:"write"})}error(e,n,r){let o=r?.internal===!0;this.node(e).down([[M,n]],{actor:r?.actor,internal:o,delivery:"write"})}complete(e,n){let r=n?.internal===!0;this.node(e).down([[j]],{actor:n?.actor,internal:r,delivery:"write"})}edges(e){let n=e?.recursive===!0,r=new Map;if(!n){for(let[c,u]of this._nodes)r.set(u,c);let a=[];for(let[c,u]of this._nodes)if(u instanceof F)for(let l of u._deps){let p=r.get(l.node);p!=null&&a.push([p,c])}return a.sort((c,u)=>c[0]<u[0]?-1:c[0]>u[0]?1:c[1]<u[1]?-1:c[1]>u[1]?1:0),a}let o=[];this._collectObserveTargets("",o);let s=new Map;for(let[a,c]of o)s.set(c,a);let i=[];for(let[a,c]of o)if(c instanceof F)for(let u of c._deps){let l=s.get(u.node);l!=null&&i.push([l,a])}return i.sort((a,c)=>a[0]<c[0]?-1:a[0]>c[0]?1:a[1]<c[1]?-1:a[1]>c[1]?1:0),i}mount(e,n){if(wt(e,this.name,"mount"),this._nodes.has(e))throw new Error(`Graph "${this.name}": cannot mount at "${e}" \u2014 node with that name exists`);if(this._mounts.has(e))throw new Error(`Graph "${this.name}": mount "${e}" already exists`);if(n===this)throw new Error(`Graph "${this.name}": cannot mount a graph into itself`);if(n._parent!=null)throw new Error(`Graph "${this.name}": this child graph is already mounted on "${n._parent.name}"`);for(let r=this;r!=null;r=r._parent)if(r===n)throw new Error(`Graph "${this.name}": mount("${e}", \u2026) would create a mount cycle`);return this._mounts.set(e,n),n._parent=this,this._emitTopology({kind:"added",name:e,nodeKind:"mount"}),n}resolve(e){let n=Br(e,this.name);return this._resolveFromSegments(n)}tryResolve(e){try{return this.resolve(e)}catch{return}}_resolveFromSegments(e){let n=e;if(n[0]===this.name&&(n=n.slice(1),n.length===0))throw new Error(`Graph "${this.name}": resolve path ends at graph name only`);let r=n[0],o=n.slice(1);if(o.length===0){let a=this._nodes.get(r);if(a)return a;throw this._mounts.has(r)?new Error(`Graph "${this.name}": path ends at subgraph "${r}" \u2014 not a node (GRAPHREFLY-SPEC \xA73.5)`):new Error(`Graph "${this.name}": unknown name "${r}"`)}let s=this._nodes.get(r);if(s&&o.length>0&&o[0]===Y)return this._resolveMetaChainFromNode(s,o,n.join(P));let i=this._mounts.get(r);if(!i)throw this._nodes.has(r)?new Error(`Graph "${this.name}": "${r}" is a node; trailing path "${o.join(P)}" is invalid`):new Error(`Graph "${this.name}": unknown mount or node "${r}"`);return i.resolve(o.join(P))}_resolveMetaChainFromNode(e,n,r){let o=e,s=0,i=[...n];for(;s<i.length;){if(i[s]!==Y)throw new Error(`Graph "${this.name}": expected ${Y} segment in meta path "${r}"`);if(s+1>=i.length)throw new Error(`Graph "${this.name}": meta path requires a key after ${Y} in "${r}"`);let a=i[s+1],c=o.meta[a];if(!c)throw new Error(`Graph "${this.name}": unknown meta "${a}" in path "${r}"`);o=c,s+=2}return o}signal(e,n){if(n?.internal!==!0){for(let o of e)if(this.config.messageTier(o[0])===3)throw new Error(`Graph "${this.name}": Graph.signal() rejects tier-3 messages (DATA / RESOLVED). Broadcast is for control-plane tiers (START / DIRTY / INVALIDATE / PAUSE / RESUME / COMPLETE / ERROR / TEARDOWN). For per-node value writes, use Graph.set or graph.node(name).down(...).`)}let r=[];if(this._signalDeliver(e,n??{},new Set,r),r.length>0)throw r[0]}_signalDeliver(e,n,r,o){for(let c of this._mounts.values())c._signalDeliver(e,n,r,o);let i=n.internal===!0?{internal:!0}:{actor:n.actor,delivery:"signal"},a=Vr(e,this.config);for(let c of[...this._nodes.keys()].sort()){let u=this._nodes.get(c);if(!r.has(u)){r.add(u);try{u.down(e,i)}catch(l){if(l instanceof J)throw l;o.push(l)}a.length!==0&&this._signalMetaSubtree(u,a,r,i,o)}}}_signalMetaSubtree(e,n,r,o,s){for(let i of Object.keys(e.meta).sort()){let a=e.meta[i];if(!r.has(a)){r.add(a);try{a.down(n,o)}catch(c){if(c instanceof J)throw c;s.push(c)}this._signalMetaSubtree(a,n,r,o,s)}}}describe(e){if(e?.reactive===!0)return this._describeReactive(e);let n=e?.actor,r=e?.filter,o=Be(e?.detail,e?.fields),s=e?.format==="spec",i=s?Be("minimal"):o,a=[];this._collectObserveTargets("",a);let c=new Map;for(let[S,w]of a)c.set(w,S);let u=[];{let S=a.map(([,k])=>k),w=new Set(c.values()),_=0;for(;S.length>0;){let k=S.shift();if(k instanceof F)for(let A of k._deps){let T=A.node;if(c.has(T))continue;let R=T.name??"",N=R;if(!N||w.has(N))if(R){let D=2;for(;w.has(`${R}#${D}`);)D++;N=`${R}#${D}`}else for(N=`__internal__/${_++}`;w.has(N);)N=`__internal__/${_++}`;c.set(T,N),w.add(N),u.push([N,T]),S.push(T)}}}let l=[...a,...u],p={};for(let[S,w]of l){if(n!=null&&!w.allowsObserve(n))continue;let _=yt(w,i),k=w instanceof F?w._deps.map(N=>c.get(N.node)??N.node.name??""):[],{name:A,...T}=_,R={...T,deps:k};if(!s){let N=this._annotations.get(S);N!=null&&(R.annotation=N)}if(r!=null)if(typeof r=="function"){let N=r;if(!(N.length>=2?N(S,R):N(R)))continue}else{let N=!0;for(let[D,H]of Object.entries(r)){let X=D==="deps_includes"?"depsIncludes":D==="meta_has"?"metaHas":D;if(X==="depsIncludes"){if(!R.deps.includes(String(H))){N=!1;break}continue}if(X==="metaHas"){if(!Object.hasOwn(R.meta??{},String(H))){N=!1;break}continue}if(R[X]!==H){N=!1;break}}if(!N)continue}p[S]=R}let h=new Set(Object.keys(p)),f=[];for(let[S,w]of l)if(w instanceof F)for(let _ of w._deps){let k=c.get(_.node);k!=null&&f.push([k,S])}f.sort((S,w)=>S[0]<w[0]?-1:S[0]>w[0]?1:S[1]<w[1]?-1:S[1]>w[1]?1:0);let d=f.map(([S,w])=>({from:S,to:w}));(n!=null||r!=null)&&(d=d.filter(S=>h.has(S.from)&&h.has(S.to)));let g=this._collectSubgraphs(""),m=n!=null||r!=null?g.filter(S=>{let w=`${S}${P}`;return[...h].some(_=>_===S||_.startsWith(w))}):g,b=this,y=e,v={name:this.name,nodes:p,edges:d,subgraphs:m,expand(S){let w={...y,format:void 0};return Array.isArray(S)?(w.fields=S,w.detail=void 0):(w.detail=S,w.fields=void 0),b.describe(w)}},x=e??{},O=x.format;return O==="json"?Cr(v,x):O==="pretty"?Dr(v,x):O==="mermaid"?gn(v,x):O==="mermaid-url"?Gr(v,x):O==="d2"?$r(v,x):O==="ascii"?tn(v,x):v}_collectSubgraphs(e){let n=[];for(let r of[...this._mounts.keys()].sort()){let o=e===""?r:`${e}${r}`;n.push(o),n.push(...this._mounts.get(r)._collectSubgraphs(`${o}${P}`))}return n}resourceProfile(e){return cn(this,e)}reachable(e,n,r={}){return r.withDetail===!0?fn(this.describe(),e,n,{...r,withDetail:!0}):fn(this.describe(),e,n,r)}explain(e,n,r){return r?.reactive===!0?this._explainReactive(e,n,r):this._explainStatic(e,n,r)}_explainStatic(e,n,r){let o=this.describe({detail:"full"}),s=new Map(this._annotations),i=new Map;for(let[a,c]of Object.entries(o.nodes))c.lastMutation!=null&&i.set(a,c.lastMutation);return nn(o,e,n,{...r?.maxDepth!=null?{maxDepth:r.maxDepth}:{},...r?.findCycle===!0?{findCycle:!0}:{},annotations:s,lastMutations:i})}_describeReactive(e){let n={...e,reactive:!1},r=e.reactiveName??"describe",o=0,s=te(o,{name:`${r}_version`}),i=this.observe({timeline:!0,structured:!0}),a=!1,c=!1,u=()=>{a||c||(a=!0,Se(()=>{a=!1,!c&&(o+=1,s.emit(o))}))},l=i.onEvent(m=>{let b=m.type;b!=="data"&&b!=="error"&&b!=="complete"&&b!=="teardown"||u()}),p=[],h=new WeakSet,f=m=>{if(h.has(m)||c)return;h.add(m);let b=m.topology.subscribe(y=>{for(let v of y){if(v[0]!==L)continue;let x=v[1];if(u(),x.kind==="added"&&x.nodeKind==="mount"){let O=m._mounts.get(x.name);O!=null&&f(O)}}});p.push(b);for(let y of m._mounts.keys()){let v=m._mounts.get(y);v!=null&&f(v)}};f(this);let d;try{d=de([s],()=>this.describe(n),{name:r,describeKind:"derived",meta:{domain:"audit",kind:"describe"},equals:(m,b)=>m===b})}catch(m){l();for(let b of p)b();throw i.dispose(),m}let g=ve(d);return{node:d,dispose(){c=!0,l();for(let m of p)m();p.length=0,i.dispose(),g()}}}_explainReactive(e,n,r){let o=0,s=te(o,{name:"explain_version"}),i=this.observe({timeline:!0,structured:!0}),a=!1,c=!1,u=i.onEvent(f=>{let d=f.type;d!=="data"&&d!=="error"&&d!=="complete"&&d!=="teardown"||a||c||(a=!0,Se(()=>{a=!1,!c&&(o+=1,s.emit(o))}))}),l={...r?.maxDepth!=null?{maxDepth:r.maxDepth}:{},...r?.findCycle===!0?{findCycle:!0}:{}},p;try{p=de([s],()=>this._explainStatic(e,n,l),{name:r?.name??"explain",describeKind:"derived",meta:{domain:"audit",kind:"explain_path",from:e,to:n},equals:(f,d)=>f.found===d.found&&f.reason===d.reason&&f.steps.length===d.steps.length&&zr(f.steps,d.steps)})}catch(f){throw u(),i.dispose(),f}let h=ve(p);return{node:p,dispose(){c=!0,u(),i.dispose(),h()}}}_pathsMatching(e){let n=Je(e),r=[];return this._collectObserveTargets("",r),r.map(([o])=>o).filter(o=>n.test(o))}_collectObserveTargets(e,n){for(let r of[...this._mounts.keys()].sort()){let o=e===""?r:`${e}${P}${r}`;this._mounts.get(r)._collectObserveTargets(o,n)}for(let r of[...this._nodes.keys()].sort()){let o=this._nodes.get(r),s=e===""?r:`${e}${P}${r}`;n.push([s,o]),this._appendMetaObserveTargets(s,o,n)}}_appendMetaObserveTargets(e,n,r){for(let o of Object.keys(n.meta).sort()){let s=n.meta[o],i=`${e}${P}${Y}${P}${o}`;r.push([i,s]),this._appendMetaObserveTargets(i,s,r)}}observe(e,n){let r=typeof e=="string",s=ln(r?n:e),i=s.structured===!0||s.timeline===!0||s.causal===!0||s.derived===!0||s.detail==="minimal"||s.detail==="full"||s.format!=null,a=s.actor;if(r){let l=e,p=this.resolve(l);if(a!=null&&!p.allowsObserve(a))throw new J({actor:a,action:"observe",nodeName:l});return i?this._buildStructuredObserver([[l,p]],s,"one"):{subscribe(h){return p.subscribe(h)},up(h){try{p.up?.(h)}catch(f){if(f instanceof J)return;throw f}}}}let c=[];this._collectObserveTargets("",c),c.sort((l,p)=>l[0]<p[0]?-1:l[0]>p[0]?1:0);let u=a==null?c:c.filter(([,l])=>l.allowsObserve(a));return i?this._buildStructuredObserver(u,s,"all"):{subscribe:l=>{let p=u.map(([h,f])=>f.subscribe(d=>{l(h,d)}));return()=>{for(let h of p)h()}},up:(l,p)=>{try{this.resolve(l).up?.(p)}catch(h){if(h instanceof J)return;throw h}}}}_buildStructuredObserver(e,n,r){let o=r==="one"?e[0]?.[0]:void 0,s=i=>{if(r==="one"&&o!=null){let l=this.resolve(o);return this._buildStructuredObserver([[o,l]],i,"one")}let a=[];this._collectObserveTargets("",a),a.sort((l,p)=>l[0]<p[0]?-1:l[0]>p[0]?1:0);let c=i.actor,u=c==null?a:a.filter(([,l])=>l.allowsObserve(c));return this._buildStructuredObserver(u,i,"all")};return this._createObserveResult(e,n,s)}_createObserveResult(e,n,r){let o=n.timeline===!0,s=n.causal===!0,i=n.derived===!0,a=n.detail==="minimal",c=this.config.inspectorEnabled,u=(s||i)&&c,l=n.maxEvents,p=l!=null&&l>0?new Ne(l):null,h=[],f=new Set,d={},g=new Set,m=0,b=0,y=0,v=0,x=0,O=0,S=!1,w=!1,_=0,k=new Map,A=new Map,T=new Map,R=E=>{p?p.push(E):h.push(E);for(let $ of f)$(E)},N=()=>o?{timestamp_ns:he(),in_batch:Ce(),batch_id:_}:{},D=(E,$)=>{if(!(!u||!(E instanceof F)))return E._setInspectorHook(W=>{if(W.kind==="dep_message")k.set(E,W.depIndex);else if(W.kind==="run"){let we=W.batchData.map((G,B)=>G!=null&&G.length>0?G.at(-1):W.prevData[B]);A.set(E,we);let K=W.batchData.map(G=>G!=null?[...G]:void 0);T.set(E,K),i&&R({type:"derived",path:$,dep_values:we,dep_batches:K,...N()})}})},H=E=>{let $=k.get(E),W=A.get(E);if(!s||W==null)return{};let K=($!=null&&$>=0&&E instanceof F?E._deps[$]:void 0)?.node,G=K?.v,B=T.get(E);return{trigger_dep_index:$,trigger_dep_name:K?.name,...G!=null?{trigger_version:{id:G.id,version:G.version}}:{},dep_values:[...W],...B!=null?{dep_batches:B}:{}}},X=[],se=[];for(let[E,$]of e){let W=D($,E);W&&X.push(W),se.push($.subscribe(we=>{_++;for(let K of we){let G=K[0],B=N();if(G===L){d[E]=K[1];let nt=$ instanceof F?$.lastMutation?.actor??le:le;R({type:"data",path:E,data:K[1],actor:nt,...B,...H($)})}else if(a)G===z?m++:G===U?b++:G===Z?y++:G===Q?v++:G===ee?x++:G===V?O++:G===j&&!g.has(E)?S=!0:G===M&&(w=!0,g.add(E));else if(G===z)m++,R({type:"dirty",path:E,...B});else if(G===U)b++,R({type:"resolved",path:E,...B,...H($)});else if(G===Z)y++,R({type:"invalidate",path:E,...B});else if(G===Q)v++,R({type:"pause",path:E,lockId:K[1],...B});else if(G===ee)x++,R({type:"resume",path:E,lockId:K[1],...B});else if(G===j)g.has(E)||(S=!0),R({type:"complete",path:E,...B});else if(G===M){w=!0,g.add(E);let nt=$ instanceof F?$.lastMutation?.actor??le:le;R({type:"error",path:E,data:K[1],actor:nt,...B})}else G===V&&(O++,R({type:"teardown",path:E,...B}))}}))}let Qe=!1,et=()=>{if(!Qe){Qe=!0;for(let E of se)E();for(let E of X)E();for(let E of Re)E({value:void 0,done:!0});Re.length=0}},tt=[],Re=[];f.add(E=>{let $=Re.shift();$?$({value:E,done:!1}):tt.push(E)});let Et={get values(){return d},get dirtyCount(){return m},get resolvedCount(){return b},get invalidateCount(){return y},get pauseCount(){return v},get resumeCount(){return x},get teardownCount(){return O},get events(){return p?p.toArray():[...h]},get anyCompletedCleanly(){return S},get anyErrored(){return w},get completedWithoutErrors(){return S&&!w},onEvent(E){return f.add(E),()=>f.delete(E)},dispose:et,expand(E){et();let $={...n};return typeof E=="string"?$.detail=E:Object.assign($,E),r(ln($))},[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=>Re.push(E))},return(){return et(),Promise.resolve({value:void 0,done:!0})}}}};return n.format!=null&&this._attachFormatLogger(Et,n),Et}_attachFormatLogger(e,n){let r=n.format;if(r==null)return;let o=n.logger??(d=>console.log(d)),s=n.includeTypes?new Set(n.includeTypes):null,i=n.excludeTypes?new Set(n.excludeTypes):null,a=s==null&&i==null?()=>!0:d=>(s==null||s.has(d))&&(i==null||!i.has(d)),c=Ir(n.theme),u=r==="stage-log"?he():0,l=d=>d==null?"":n.stageLabels?.[d]??d,p=(d,g)=>d.length>g?`${d.slice(0,g-1)}\u2026`:d,h=d=>d.type==="data"||d.type==="error"?p(Ye(d.data),120):"",f=d=>{if(r==="stage-log"){let w=(he()-u)/1e9,_=l(d.path).padEnd(9);if(d.type==="data"){let k=h(d);return`[${w.toFixed(3)}s] ${_} \u2190${k?` ${k}`:""}`}if(d.type==="error"){let k=h(d);return`[${w.toFixed(3)}s] ${_} \u2717${k?` ${k}`:""}`}return d.type==="complete"?`[${w.toFixed(3)}s] ${_} \u25A0 complete`:`[${w.toFixed(3)}s] ${_} ${d.type}`}if(r==="json")try{return JSON.stringify(d)}catch{return JSON.stringify({type:d.type,path:d.path,data:"[unserializable]"})}let g=c[d.type]??"",m=d.path?`${c.path}${d.path}${c.reset} `:"",b=d.type==="data"||d.type==="error",y=d.type==="pause"||d.type==="resume",v=b?` ${Ye(d.data)}`:y?` ${Ye(d.lockId)}`:"",x=d.type==="data"||d.type==="resolved"||d.type==="derived"?d:void 0,O=x?.trigger_dep_name!=null?` <- ${x.trigger_dep_name}`:x?.trigger_dep_index!=null?` <- #${x.trigger_dep_index}`:"",S=d.in_batch?" [batch]":"";return`${m}${g}${d.type.toUpperCase()}${c.reset}${v}${O}${S}`};e.onEvent(d=>{a(d.type)&&o(f(d),d)})}addDisposer(e){return this._disposers.add(e),()=>{this._disposers.delete(e)}}destroy(){un(this._disposers,this.name),this.signal([[V]],{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}_destroyClearOnly(){for(let e of[...this._mounts.values()])e._parent=void 0,e._destroyClearOnly();this._mounts.clear(),this._nodes.clear(),this._parent=void 0}snapshot(e){let{expand:n,...r}=this.describe({detail:"full"}),o={};for(let a of Object.keys(r.nodes).sort()){let{lastMutation:c,guard:u,...l}=r.nodes[a];o[a]=l}let s=[...r.subgraphs].sort(),i={...r,version:1,nodes:o,subgraphs:s};if(e?.format==null)return i;if(e.format==="json-string")return JSON.stringify(i);if(e.format==="bytes"){if(e.codec==null)throw new Error("snapshot({format: 'bytes'}) requires a `codec` name");let a=this.config.lookupCodec(e.codec);if(a==null)throw new Error(`snapshot: codec "${e.codec}" is not registered on this graph's config. Call config.registerCodec(...) before creating nodes.`);return Rt(a,a.encode(i))}throw new Error(`snapshot: unknown format "${String(e.format)}"`)}static decode(e,n){let r=n?.config??ye,{codec:o,codecVersion:s,payload:i}=At(e,r);return o.decode(i,s)}restore(e,n){if(dn(e),e.name!==this.name)throw new Error(`Graph "${this.name}": restore snapshot name "${e.name}" does not match this graph`);let r=n?.only==null?null:(Array.isArray(n.only)?n.only:[n.only]).map(s=>Je(s)),o=n?.includeProducers===!0;for(let s of Object.keys(e.nodes).sort()){if(r!==null&&!r.some(a=>a.test(s)))continue;let i=e.nodes[s];if(i!==void 0){if(!("value"in i)||i.value===void 0){"value"in i&&i.value===void 0&&n?.onError?.(s,new Error(`restore: slice.value is undefined for "${s}" (undefined is the global SENTINEL; not valid DATA)`));continue}if(!(i.type==="derived"||i.type==="effect")&&!(i.type==="producer"&&!o)){if(i.v!=null){let c=this.tryResolve(s)?.v;if(c!=null&&c.id===i.v.id&&c.version===i.v.version)continue}try{this.set(s,i.value)}catch(a){n?.onError?.(s,a)}}}}}static fromSnapshot(e,n){dn(e);let r=typeof n=="function"?n:n?.build,o=typeof n=="function"?void 0:n?.factories,s=new t(e.name);if(r)return r(s),s.restore(e),s;for(let f of[...e.subgraphs].sort((d,g)=>{let m=d.split(P).length,b=g.split(P).length;return m!==b?m-b:d<g?-1:d>g?1:0})){let d=f.split(P),g=s;for(let m of d)g._mounts.has(m)||g.mount(m,new t(m)),g=g._mounts.get(m)}let i=o?Object.entries(o).map(([f,d])=>({re:Je(f),factory:d})):[],a=f=>{for(let d of i)if(d.re.test(f))return d.factory},c=f=>{let d=f.split(P),g=d.pop();if(g==null||g.length===0)throw new Error(`invalid snapshot path "${f}"`);let m=s;for(let b of d){let y=m._mounts.get(b);if(!y)throw new Error(`unknown mount "${b}" in path "${f}"`);m=y}return[m,g]},u=Object.entries(e.nodes).filter(([f])=>!f.includes(`${P}${Y}${P}`)).sort((f,d)=>f[0]<d[0]?-1:f[0]>d[0]?1:0),l=new Map(u),p=new Map,h=!0;for(;l.size>0&&h;){h=!1;for(let[f,d]of[...l.entries()]){let g=d?.deps??[];if(!g.every(O=>p.has(O)))continue;let[m,b]=c(f),y={...d?.meta??{}},v=a(f),x;if(d?.type==="state")x=te(d.value,{meta:y});else{if(v==null)continue;x=v(b,{path:f,type:d.type,value:d.value,meta:y,deps:g,resolvedDeps:g.map(O=>p.get(O))})}m.add(x,{name:b}),p.set(f,x),l.delete(f),h=!0}}if(l.size>0){let f=[...l.keys()].sort().join(", ");throw new Error(`Graph.fromSnapshot could not reconstruct nodes without build callback: ${f}. Pass matching factories via fromSnapshot(data, { factories: { pattern: factoryFn } }).`)}return s.restore(e),s}toJSON(){return this.snapshot()}attachStorage(e,n={}){let r=e.map(u=>({tier:u,debounceMs:Math.max(0,u.debounceMs??0),compactEvery:Math.max(1,u.compactEvery??10),timer:void 0,seq:0,lastSnapshot:void 0,lastFingerprint:"",disposed:!1,savePending:void 0}));n.autoRestore===!0&&this._cascadeRestore(e,n.onError);let o=(u,l)=>{if(u.disposed)return;let p=Nr(l.nodes);if(u.lastSnapshot!=null&&p!==""&&p===u.lastFingerprint)return;let h=u.seq+1,f=ge(),m=u.lastSnapshot==null||h%u.compactEvery===0?{mode:"full",snapshot:l,seq:h,timestamp_ns:f,format_version:oe}:{mode:"diff",diff:Hr(u.lastSnapshot,l),seq:h,timestamp_ns:f,format_version:oe};if(u.tier.filter&&!u.tier.filter(this.name,m))return;let b;try{b=u.tier.save(this.name,m)}catch(y){n.onError?.(y,u.tier);return}if(b&&typeof b.then=="function"){let x=(u.savePending??Promise.resolve()).then(()=>b,()=>b).then(()=>{u.disposed||(u.seq=h,u.lastSnapshot=l,u.lastFingerprint=p)},O=>{n.onError?.(O,u.tier)});u.savePending=x.finally(()=>{u.savePending===x&&(u.savePending=void 0)})}else u.seq=h,u.lastSnapshot=l,u.lastFingerprint=p},s=(u,l)=>{try{o(u,l)}catch(p){n.onError?.(p,u.tier)}},i=(u,l)=>{if(!l.some(d=>{let g=this.config.messageTier(d[0]);return g>=3&&g<5}))return;if(n.filter){let d=this.tryResolve(u);if(d==null)return;let g=yt(d,Be("standard"));if(!n.filter(u,g))return}let h,f=()=>(h==null&&(h=this.snapshot()),h);for(let d of r)d.disposed||(d.debounceMs===0?s(d,f()):(d.timer==null&&(d.timer=new Ve),d.timer.start(d.debounceMs,()=>{d.disposed||s(d,this.snapshot())})))},a;if(n.paths!=null){let l=(typeof n.paths=="string"?this._pathsMatching(n.paths):n.paths).map(p=>{let h=this.tryResolve(p);return h==null?()=>{}:h.subscribe(f=>i(p,f))});a=()=>{for(let p of l)p()}}else a=this.observe().subscribe((u,l)=>i(u,l));let c=()=>{a();for(let u of r)u.disposed=!0,u.timer?.cancel();this._storageDisposers.delete(c)};return this._storageDisposers.add(c),{dispose:c}}async _cascadeRestore(e,n){for(let r of e){let o;try{o=await r.load(this.name)}catch(i){n?.(i,r);continue}if(o==null||typeof o!="object"||Array.isArray(o))continue;let s=o;try{if(s.mode==="full"&&s.snapshot!=null)return this.restore(s.snapshot),!0;if(s.version===oe&&s.nodes!=null)return this.restore(s),!0}catch(i){n?.(i,r)}}return!1}static async fromStorage(e,n,r){for(let o of n){let s;try{s=await o.load(e)}catch(c){r?.onError?.(c,o);continue}if(s==null||typeof s!="object"||Array.isArray(s))continue;let i=s,a=i.mode==="full"&&i.snapshot!=null?i.snapshot:i.version===oe&&i.nodes!=null?i:void 0;if(a!=null)try{return t.fromSnapshot(a,r)}catch(c){r?.onError?.(c,o)}}throw new Error(`Graph.fromStorage: no tier held a restorable record for "${e}" across ${n.length} tier(s)`)}_annotations=new Map;_traceRing;trace(e,n,r){if(e!=null&&n!=null){if(this.tryResolve(e)==null)return;if(this._annotations.set(e,n),this.config.inspectorEnabled){let o={path:e,annotation:n,timestamp_ns:he(),...r?.actor!=null?{actor:r.actor}:{}};this._traceRing.push(o)}return}return e!=null?this.config.inspectorEnabled?this._annotations.get(e):void 0:this.config.inspectorEnabled?this._traceRing.toArray():[]}annotation(e){return this._annotations.get(e)}clearTrace(){this._annotations.clear(),this._traceRing.clear()}pruneTrace(e){let n=this._traceRing.toArray().filter(o=>!e(o)),r=this._traceRing.size-n.length;this._traceRing.clear();for(let o of n)this._traceRing.push(o);return r}static diff(e,n){let r=new Set(Object.keys(e.nodes)),o=new Set(Object.keys(n.nodes)),s=[...o].filter(y=>!r.has(y)).sort(),i=[...r].filter(y=>!o.has(y)).sort(),a=[],c=[];for(let y of r){if(!o.has(y))continue;let v=e.nodes[y],x=n.nodes[y],O=v.v,S=x.v;O!=null&&S!=null&&O.id===S.id&&O.version!==S.version&&c.push({path:y,id:O.id,from:O.version,to:S.version});let w=O!=null&&S!=null&&O.id===S.id&&O.version===S.version;for(let _ of["type","status","sentinel"]){let k=v[_],A=x[_];k!==A&&a.push({path:y,field:_,from:k,to:A})}if(!w)for(let _ of["value","meta"]){let k=v[_],A=x[_];Er(k,A)||a.push({path:y,field:_,from:k,to:A})}}let u=y=>`${y.from} ${y.to}`,l=new Set(e.edges.map(u)),p=new Set(n.edges.map(u)),h=n.edges.filter(y=>!l.has(u(y))),f=e.edges.filter(y=>!p.has(u(y))),d=new Set(e.subgraphs),g=new Set(n.subgraphs),m=[...g].filter(y=>!d.has(y)).sort(),b=[...d].filter(y=>!g.has(y)).sort();return{nodesAdded:s,nodesRemoved:i,nodesChanged:a,versionChanges:c,edgesAdded:h,edgesRemoved:f,subgraphsAdded:m,subgraphsRemoved:b}}};function Hr(t,e){let n=ne.diff(t,e),r={};for(let o of n.nodesAdded){let s=e.nodes[o];s!=null&&(r[o]=s)}return{...n,nodesAddedFull:r}}function fn(t,e,n,r={}){let o={paths:[],depths:new Map,truncated:!1};if(!e)return r.withDetail?o:[];if(!r.both&&n!=="upstream"&&n!=="downstream")throw new Error('reachable: direction must be "upstream" or "downstream"');let s=r.maxDepth;if(s!=null&&(!Number.isInteger(s)||s<0))throw new Error("reachable: maxDepth must be an integer >= 0");if(s===0)return r.withDetail?o:[];let i=new Map,a=new Map,c=new Map,u=new Map,l=new Set;for(let[v,x]of Object.entries(t.nodes)){if(!v)continue;l.add(v);let O=x.deps??[];i.set(v,O);for(let S of O)S&&(l.add(S),a.has(S)||a.set(S,new Set),a.get(S).add(v))}for(let v of t.edges){if(v==null||typeof v!="object")continue;let x=typeof v.from=="string"?v.from:"",O=typeof v.to=="string"?v.to:"";!x||!O||(l.add(x),l.add(O),u.has(x)||u.set(x,new Set),u.get(x).add(O),c.has(O)||c.set(O,new Set),c.get(O).add(x))}if(!l.has(e))return r.withDetail?o:[];let p=r.both===!0,h=v=>{if(p){let w=i.get(v)??[],_=c.get(v),k=a.get(v),A=u.get(v),T=[...w];return _&&T.push(..._),k&&T.push(...k),A&&T.push(...A),T}if(n==="upstream"){let w=i.get(v)??[],_=c.get(v);return _?[...w,..._]:w}let x=a.get(v),O=u.get(v),S=x?[...x]:[];return O&&S.push(...O),S},f=new Set([e]),d=new Map,g=[{path:e,depth:0}],m=0,b=!1;for(;m<g.length;){let v=g[m++];if(s!=null&&v.depth>=s){h(v.path).length>0&&(b=!0);continue}for(let x of h(v.path))!x||f.has(x)||(f.add(x),d.set(x,v.depth+1),g.push({path:x,depth:v.depth+1}))}let y=[...d.keys()].sort((v,x)=>v<x?-1:v>x?1:0);return r.withDetail?{paths:y,depths:d,truncated:b}:y}function zr(t,e){if(t.length!==e.length)return!1;for(let n=0;n<t.length;n++){let r=t[n],o=e[n];if(r.path!==o.path||r.type!==o.type||r.status!==o.status||r.hop!==o.hop||r.dep_index!==o.dep_index||r.annotation!==o.annotation||r.value!==o.value||r.lastMutation!==o.lastMutation)return!1;let s=r.v,i=o.v;if(s!==i&&(s==null||i==null||s.id!==i.id||s.version!==i.version))return!1}return!0}Me();ce();be();je();ce();bt();function yn(t,e){let n=t.cache??0;return n>=e?!1:(t.down([[z],[L,n+1]]),!0)}function bn(t,e,n){return{[t]:!0,[`${t}_type`]:e,...n??{}}}function vn(t,e){return bn("reduction",t,e)}function wn(t,e,n,r){let o=r?.maxIterations??10,s=`__feedback_${e}`,i=te(0,{meta:vn("feedback_counter",{maxIterations:o,feedbackFrom:e,feedbackTo:n})});t.add(i,{name:s});let a=t.resolve(e),c=t.resolve(n),u=`__feedback_effect_${e}`,l=ue([],(p,h)=>{let f=a.subscribe(d=>{for(let g of d){let m=g[0];if(m===L){let b=g[1];if(b==null)return;De(()=>{yn(i,o)&&c.emit(b)})}else if(m===j||m===M){let b=m===M&&g.length>1?[M,g[1]]:[m];i.down([b])}}});return()=>f()},{name:u,describeKind:"effect",meta:{...vn("feedback_effect",{feedbackFrom:e,feedbackTo:n}),_internal:!0}});return t.add(l,{name:u}),t.addDisposer(ve(l)),t}function xn(t){return typeof t=="object"&&t!==null&&"factory"in t}function Ur(t){return typeof t=="object"&&t!==null&&"factory"in t}function Wr(t){return xn(t)?t.factory:t}function Kr(t){return Ur(t)?t.factory:t}function St(t,e){let n=[],r=new Set(Object.keys(e.fns??{})),o=new Set(Object.keys(e.sources??{}));for(let[s,i]of Object.entries(t.nodes)){if(i.type==="template")continue;let a=i;if(a.fn&&r.size>0&&!r.has(a.fn))if(o.has(a.fn))n.push(`Node "${s}": fn "${a.fn}" is a source, not a function. Use it as a producer source instead, or use a function from: ${[...r].join(", ")}`);else{let c=xt(a.fn,r);n.push(`Node "${s}": fn "${a.fn}" not found in catalog`+(c?`. Did you mean "${c}"?`:""))}if(a.source&&o.size>0&&!o.has(a.source))if(r.has(a.source))n.push(`Node "${s}": source "${a.source}" is a function, not a source. Use it as fn instead, or use a source from: ${[...o].join(", ")}`);else{let c=xt(a.source,o);n.push(`Node "${s}": source "${a.source}" not found in catalog`+(c?`. Did you mean "${c}"?`:""))}if(a.fn&&a.config&&e.fns?.[a.fn]){let c=e.fns[a.fn];if(xn(c)&&c.configSchema){for(let[u,l]of Object.entries(c.configSchema))if(l.required!==!1&&!(u in a.config)&&n.push(`Node "${s}": config missing required field "${u}"`),u in a.config&&l.enum){let p=a.config[u];l.enum.includes(p)||n.push(`Node "${s}": config.${u} = ${JSON.stringify(p)}, expected one of: ${l.enum.join(", ")}`)}}}}if(t.templates){for(let[s,i]of Object.entries(t.templates))for(let[a,c]of Object.entries(i.nodes))if(c.fn&&r.size>0&&!r.has(c.fn)){let u=xt(c.fn,r);n.push(`Template "${s}" node "${a}": fn "${c.fn}" not found in catalog`+(u?`. Did you mean "${u}"?`:""))}}return{valid:n.length===0,errors:n}}function xt(t,e){let n=null,r=1/0,o=t.toLowerCase();for(let s of e){let i=qr(o,s.toLowerCase());i<r&&i<=Math.max(3,Math.floor(t.length/2))&&(r=i,n=s)}return n}function qr(t,e){let n=t.length,r=e.length,o=Array.from({length:n+1},(s,i)=>Array.from({length:r+1},(a,c)=>i===0?c:c===0?i:0));for(let s=1;s<=n;s++)for(let i=1;i<=r;i++)o[s][i]=t[s-1]===e[i-1]?o[s-1][i-1]:1+Math.min(o[s-1][i],o[s][i-1],o[s-1][i-1]);return o[n][r]}var _n=new Set(["state","producer","derived","effect","operator","template"]),Jr=new Set(["state","producer","derived","effect","operator"]);function Ot(t){let e=[];if(t==null||typeof t!="object")return{valid:!1,errors:["GraphSpec must be a non-null object"]};let n=t;if((typeof n.name!="string"||n.name.length===0)&&e.push("Missing or empty 'name' field"),n.nodes==null||typeof n.nodes!="object"||Array.isArray(n.nodes))return e.push("Missing or invalid 'nodes' field (must be an object)"),{valid:!1,errors:e};let r=new Set(Object.keys(n.nodes)),o=new Map,s=new Map;if(n.templates!=null&&typeof n.templates=="object"&&!Array.isArray(n.templates)){for(let[i,a]of Object.entries(n.templates))if(a!=null&&typeof a=="object"){let c=a;s.set(i,{params:Array.isArray(c.params)?c.params:[]})}}if(n.templates!=null)if(typeof n.templates!="object"||Array.isArray(n.templates))e.push("'templates' must be an object");else for(let[i,a]of Object.entries(n.templates)){if(a==null||typeof a!="object"){e.push(`Template "${i}": must be an object`);continue}let c=a;if(Array.isArray(c.params)||e.push(`Template "${i}": missing 'params' array`),c.nodes==null||typeof c.nodes!="object"||Array.isArray(c.nodes))e.push(`Template "${i}": missing or invalid 'nodes' object`);else{let u=new Set(Array.isArray(c.params)?c.params:[]),l=new Set(Object.keys(c.nodes));for(let[p,h]of Object.entries(c.nodes)){if(h==null||typeof h!="object"){e.push(`Template "${i}" node "${p}": must be an object`);continue}let f=h;if((typeof f.type!="string"||!Jr.has(f.type))&&e.push(`Template "${i}" node "${p}": invalid type`),Array.isArray(f.deps))for(let d of f.deps)!l.has(d)&&!u.has(d)&&e.push(`Template "${i}" node "${p}": dep "${d}" is not an inner node or param`)}typeof c.output!="string"?e.push(`Template "${i}": missing 'output' string`):c.nodes[c.output]||e.push(`Template "${i}": output "${c.output}" is not a declared node`)}}for(let[i,a]of Object.entries(n.nodes)){if(a==null||typeof a!="object"){e.push(`Node "${i}": must be an object`);continue}let c=a;if(typeof c.type!="string"||!_n.has(c.type)){e.push(`Node "${i}": invalid type "${String(c.type)}" (expected: ${[..._n].join(", ")})`);continue}if(o.set(i,c.type),c.type==="template")if(typeof c.template!="string"||!s.has(c.template))e.push(`Node "${i}": template "${String(c.template)}" not found in templates`);else if(c.bind==null||typeof c.bind!="object"||Array.isArray(c.bind))e.push(`Node "${i}": template ref requires 'bind' object`);else{let u=s.get(c.template),l=c.bind;for(let p of u.params)p in l||e.push(`Node "${i}": template param "${p}" is not bound (template "${c.template}")`);for(let[,p]of Object.entries(l))typeof p=="string"&&!r.has(p)&&e.push(`Node "${i}": bind target "${p}" does not reference an existing node`)}else{if(Array.isArray(c.deps))for(let u of c.deps)u===i?e.push(`Node "${i}": self-referencing dep`):r.has(u)||e.push(`Node "${i}": dep "${u}" does not reference an existing node`);(c.type==="derived"||c.type==="effect"||c.type==="operator")&&!Array.isArray(c.deps)&&e.push(`Node "${i}": ${c.type} node should have a 'deps' array`)}}if(n.feedback!=null)if(!Array.isArray(n.feedback))e.push("'feedback' must be an array");else for(let i=0;i<n.feedback.length;i++){let a=n.feedback[i];if(a==null||typeof a!="object"){e.push(`Feedback [${i}]: must be an object`);continue}let c=a;(typeof c.from!="string"||!r.has(c.from))&&e.push(`Feedback [${i}]: 'from' "${String(c.from)}" does not reference an existing node`),typeof c.from=="string"&&c.from===c.to&&e.push(`Feedback [${i}]: 'from' and 'to' must be different nodes`),typeof c.to!="string"||!r.has(c.to)?e.push(`Feedback [${i}]: 'to' "${String(c.to)}" does not reference an existing node`):typeof c.to=="string"&&o.get(c.to)!=="state"&&e.push(`Feedback [${i}]: 'to' node "${c.to}" must be a state node (got "${o.get(c.to)??"unknown"}")`)}return{valid:e.length===0,errors:e}}function Sn(t,e){let n=Ot(t);if(!n.valid)throw new Error(`compileSpec: invalid GraphSpec:
8
8
  ${n.errors.join(`
9
9
  `)}`);let r=e?.catalog??{},o=new ne(t.name),s=t.templates??{},i=St(t,r);if(!i.valid)throw new Error(`compileSpec: catalog validation errors:
10
10
  ${i.errors.join(`
11
- `)}`);let a=f=>{let d=r.fns?.[f];return d?Ur(d):void 0},c=f=>{let d=r.sources?.[f];return d?Kr(d):void 0},u=new Map,l=[];for(let[f,d]of Object.entries(t.nodes)){if(d.type==="template")continue;let g=d;if(g.type==="state"){let m=te(g.initial,{name:f,meta:g.meta?{...g.meta}:void 0});o.add(m,{name:f}),u.set(f,m)}else if(g.type==="producer"){let m=g.source?c(g.source):void 0,b=g.fn?a(g.fn):void 0;if(m){let y=m(g.config??{});o.add(y,{name:f}),u.set(f,y)}else if(b){let y=b([],g.config??{});o.add(y,{name:f}),u.set(f,y)}else{let y=Te(()=>{},{name:f,meta:{...g.meta,_specFn:g.fn,_specSource:g.source}});o.add(y,{name:f}),u.set(f,y)}}else l.push([f,g])}let p=!0,h=new Map(l);for(;h.size>0&&p;){p=!1;for(let[f,d]of[...h.entries()]){let g=d.deps??[];if(!g.every(v=>u.has(v)))continue;let m=g.map(v=>u.get(v)),b=d.fn?a(d.fn):void 0,y;b?y=b(m,d.config??{}):d.type==="effect"?y=Ie(m,()=>{}):y=de(m,v=>v[0]),o.add(y,{name:f}),u.set(f,y),h.delete(f),p=!0}}if(h.size>0){let f=[...h.keys()].sort().join(", ");throw new Error(`compileSpec: unresolvable deps for nodes: ${f}`)}for(let[f,d]of Object.entries(t.nodes)){if(d.type!=="template")continue;let g=d,m=s[g.template],b=new ne(f),y=new Map,v=[];for(let[w,_]of Object.entries(m.nodes)){let k=(_.deps??[]).map(T=>T.startsWith("$")&&g.bind[T]?g.bind[T]:T),A={..._,deps:k};if(_.type==="state"){let T=te(_.initial,{name:w,meta:_.meta?{..._.meta}:void 0});b.add(T,{name:w}),y.set(w,T)}else if(_.type==="producer"){let T=_.source?c(_.source):void 0,R=_.fn?a(_.fn):void 0;if(T){let N=T(_.config??{});b.add(N,{name:w}),y.set(w,N)}else if(R){let N=R([],_.config??{});b.add(N,{name:w}),y.set(w,N)}else{let N=Te(()=>{},{name:w,meta:{..._.meta,_specFn:_.fn,_specSource:_.source}});b.add(N,{name:w}),y.set(w,N)}}else v.push([w,A])}let x=!0,O=new Map(v);for(;O.size>0&&x;){x=!1;for(let[w,_]of[...O.entries()]){let k=_.deps??[];if(!k.every(C=>y.has(C)||u.has(C)))continue;let T=k.map(C=>y.get(C)??u.get(C)),R=_.fn?a(_.fn):void 0,N;R?N=R(T,_.config??{}):_.type==="effect"?N=Ie(T,()=>{}):N=de(T,C=>C[0]),b.add(N,{name:w}),y.set(w,N),O.delete(w),x=!0}}if(O.size>0){let w=[...O.keys()].sort().join(", ");throw new Error(`compileSpec: template "${g.template}" has unresolvable deps: ${w}`)}o.mount(f,b);let S=`${f}::${m.output}`;u.set(f,o.resolve(S));try{let w=o.resolve(S);w.meta._templateName?.emit(g.template),w.meta._templateBind?.emit(g.bind)}catch{}}for(let f of t.feedback??[])wn(o,f.from,f.to,{maxIterations:f.maxIterations});return o}var D=class extends Error{code;details;constructor(e,n,r){super(n),this.name="SurfaceError",this.code=e,r!==void 0&&(this.details=r)}toJSON(){let e={code:this.code,message:this.message};if(this.details!==void 0){let n=Yr(this.details);n!==void 0&&(e.details=n)}return e}};function Yr(t){try{return JSON.parse(JSON.stringify(t))}catch{return}}function On(t,e="internal-error"){if(t instanceof D)return t;let n=t instanceof Error?t.message:String(t);return new D(e,n)}function Xe(t,e){let n=Ot(t);if(!n.valid)throw new D("invalid-spec",`GraphSpec validation failed:
11
+ `)}`);let a=f=>{let d=r.fns?.[f];return d?Wr(d):void 0},c=f=>{let d=r.sources?.[f];return d?Kr(d):void 0},u=new Map,l=[];for(let[f,d]of Object.entries(t.nodes)){if(d.type==="template")continue;let g=d;if(g.type==="state"){let m=te(g.initial,{name:f,meta:g.meta?{...g.meta}:void 0});o.add(m,{name:f}),u.set(f,m)}else if(g.type==="producer"){let m=g.source?c(g.source):void 0,b=g.fn?a(g.fn):void 0;if(m){let y=m(g.config??{});o.add(y,{name:f}),u.set(f,y)}else if(b){let y=b([],g.config??{});o.add(y,{name:f}),u.set(f,y)}else{let y=Te(()=>{},{name:f,meta:{...g.meta,_specFn:g.fn,_specSource:g.source}});o.add(y,{name:f}),u.set(f,y)}}else l.push([f,g])}let p=!0,h=new Map(l);for(;h.size>0&&p;){p=!1;for(let[f,d]of[...h.entries()]){let g=d.deps??[];if(!g.every(v=>u.has(v)))continue;let m=g.map(v=>u.get(v)),b=d.fn?a(d.fn):void 0,y;b?y=b(m,d.config??{}):d.type==="effect"?y=Ie(m,()=>{}):y=de(m,v=>v[0]),o.add(y,{name:f}),u.set(f,y),h.delete(f),p=!0}}if(h.size>0){let f=[...h.keys()].sort().join(", ");throw new Error(`compileSpec: unresolvable deps for nodes: ${f}`)}for(let[f,d]of Object.entries(t.nodes)){if(d.type!=="template")continue;let g=d,m=s[g.template],b=new ne(f),y=new Map,v=[];for(let[w,_]of Object.entries(m.nodes)){let k=(_.deps??[]).map(T=>T.startsWith("$")&&g.bind[T]?g.bind[T]:T),A={..._,deps:k};if(_.type==="state"){let T=te(_.initial,{name:w,meta:_.meta?{..._.meta}:void 0});b.add(T,{name:w}),y.set(w,T)}else if(_.type==="producer"){let T=_.source?c(_.source):void 0,R=_.fn?a(_.fn):void 0;if(T){let N=T(_.config??{});b.add(N,{name:w}),y.set(w,N)}else if(R){let N=R([],_.config??{});b.add(N,{name:w}),y.set(w,N)}else{let N=Te(()=>{},{name:w,meta:{..._.meta,_specFn:_.fn,_specSource:_.source}});b.add(N,{name:w}),y.set(w,N)}}else v.push([w,A])}let x=!0,O=new Map(v);for(;O.size>0&&x;){x=!1;for(let[w,_]of[...O.entries()]){let k=_.deps??[];if(!k.every(D=>y.has(D)||u.has(D)))continue;let T=k.map(D=>y.get(D)??u.get(D)),R=_.fn?a(_.fn):void 0,N;R?N=R(T,_.config??{}):_.type==="effect"?N=Ie(T,()=>{}):N=de(T,D=>D[0]),b.add(N,{name:w}),y.set(w,N),O.delete(w),x=!0}}if(O.size>0){let w=[...O.keys()].sort().join(", ");throw new Error(`compileSpec: template "${g.template}" has unresolvable deps: ${w}`)}o.mount(f,b);let S=`${f}::${m.output}`;u.set(f,o.resolve(S));try{let w=o.resolve(S);w.meta._templateName?.emit(g.template),w.meta._templateBind?.emit(g.bind)}catch{}}for(let f of t.feedback??[])wn(o,f.from,f.to,{maxIterations:f.maxIterations});return o}var C=class extends Error{code;details;constructor(e,n,r){super(n),this.name="SurfaceError",this.code=e,r!==void 0&&(this.details=r)}toJSON(){let e={code:this.code,message:this.message};if(this.details!==void 0){let n=Yr(this.details);n!==void 0&&(e.details=n)}return e}};function Yr(t){try{return JSON.parse(JSON.stringify(t))}catch{return}}function On(t,e="internal-error"){if(t instanceof C)return t;let n=t instanceof Error?t.message:String(t);return new C(e,n)}function Xe(t,e){let n=Ot(t);if(!n.valid)throw new C("invalid-spec",`GraphSpec validation failed:
12
12
  ${n.errors.join(`
13
- `)}`,{errors:n.errors});let r=e?.catalog??{},o=St(t,r);if(!o.valid)throw new D("catalog-error",`Catalog validation failed:
13
+ `)}`,{errors:n.errors});let r=e?.catalog??{},o=St(t,r);if(!o.valid)throw new C("catalog-error",`Catalog validation failed:
14
14
  ${o.errors.join(`
15
- `)}`,{errors:o.errors});try{return Sn(t,e)}catch(s){let i=s instanceof Error?s.message:String(s);throw new D("catalog-error",i)}}ce();var Xr=3e4;async function Tn(t,e,n){let r=n?.inputPath??"input",o=n?.outputPath??"output",s=n?.timeoutMs??Xr,i=Xe(t,{catalog:n?.catalog}),a;try{a=i.resolve(o)}catch{throw i.destroy(),new D("node-not-found",`reduce: output path "${o}" is not registered`,{path:o})}try{i.resolve(r)}catch{throw i.destroy(),new D("node-not-found",`reduce: input path "${r}" is not registered`,{path:r})}try{return await new Promise((c,u)=>{let l=!1,p=!1,h,f,d=!1,g=m=>{p||(p=!0,h!==void 0&&clearTimeout(h),f!==void 0?(f(),f=void 0):d=!0,m())};f=a.subscribe(m=>{for(let b of m){if(p)return;if(l){if(b[0]===L){g(()=>c(b[1]));return}if(b[0]===W){let y=a.cache;g(()=>c(y));return}if(b[0]===M){let y=b[1],v=y instanceof Error?y.message:String(y),x=y instanceof Error?y:void 0;g(()=>u(new D("internal-error",`reduce: output emitted ERROR: ${v}`,x!=null?{cause:x}:void 0)));return}if(b[0]===j){g(()=>u(new D("internal-error","reduce: output COMPLETEd without a post-push DATA")));return}}}}),d&&(f?.(),f=void 0),l=!0;try{i.set(r,e)}catch(m){let b=m instanceof Error?m.message:String(m),y=m instanceof Error?m:void 0;g(()=>u(new D("internal-error",`reduce: failed to set input on "${r}": ${b}`,y!=null?{path:r,cause:y}:{path:r})));return}!p&&Number.isFinite(s)&&s>0&&(h=setTimeout(()=>{g(()=>u(new D("reduce-timeout",`reduce: no output emitted within ${s}ms`,{timeoutMs:s,outputPath:o})))},s),h.unref?.())})}finally{i.destroy()}}$e();var Nt=oe,Ee="snapshot:";function ke(t){if(t.startsWith(Ee))throw new D("snapshot-failed",`snapshot id must not start with "${Ee}" (reserved); got "${t}"`,{snapshotId:t})}function Ze(t){return`${Ee}${t}`}function Zr(t){return t.startsWith(Ee)?t.slice(Ee.length):void 0}function Tt(t,e){if(t==null||typeof t!="object")throw new D("snapshot-not-found",`snapshot "${e}" not found in tier`,{snapshotId:e});let n=t;if("mode"in n){if(n.mode==="full"&&"snapshot"in n)return n.snapshot;throw n.mode==="diff"?new D("restore-failed",`snapshot "${e}" is a diff record; restore the baseline and replay WAL instead`,{snapshotId:e,mode:"diff"}):new D("restore-failed",`snapshot "${e}" has unknown mode "${String(n.mode)}"`,{snapshotId:e,mode:String(n.mode)})}if("nodes"in n&&"edges"in n&&"subgraphs"in n&&"name"in n)return n;throw new D("restore-failed",`snapshot "${e}" payload is not a GraphCheckpointRecord or GraphPersistSnapshot`,{snapshotId:e})}async function Nn(t,e,n){ke(e);let r;try{r=t.snapshot()}catch(s){let i=s instanceof Error?s.message:String(s);throw new D("snapshot-failed",`snapshot "${e}" serialization failed: ${i}`,{snapshotId:e})}let o={mode:"full",seq:0,timestamp_ns:ge(),format_version:Nt,snapshot:r};try{await n.save(Ze(e),o)}catch(s){let i=s instanceof Error?s.message:String(s);throw new D("snapshot-failed",`snapshot "${e}" save failed: ${i}`,{snapshotId:e})}return{snapshotId:e,timestamp_ns:o.timestamp_ns}}async function En(t,e,n){ke(t);let r=Ze(t),o=await e.load(r);o==null&&(o=await e.load(t));let s=Tt(o,t);try{return ne.fromSnapshot(s,n?.factories?{factories:n.factories}:void 0)}catch(i){let a=i instanceof Error?i.message:String(i);throw new D("restore-failed",`snapshot "${t}" restore failed: ${a}`,{snapshotId:t})}}async function kn(t,e,n){ke(t),ke(e);let r=async c=>{let u=Ze(c),l=await n.load(u);return l==null&&(l=await n.load(c)),l},[o,s]=await Promise.all([r(t),r(e)]),i=Tt(o,t),a=Tt(s,e);return ne.diff(i,a)}async function Rn(t,e){if(typeof t.list!="function")throw new D("tier-no-list","StorageTier does not implement list(); wrap the tier with an enumerator or use a different backend");let n=await t.list(),r=[],o=e?.includeUnprefixed===!0;for(let s of n){let i=Zr(s);i!==void 0?r.push(i):o&&r.push(s)}return r}async function An(t,e){if(ke(t),typeof e.clear!="function")throw new D("snapshot-failed",`StorageTier is append-only (no clear()); cannot delete "${t}"`,{snapshotId:t});try{await e.clear(Ze(t))}catch(n){let r=n instanceof Error?n.message:String(n);throw new D("snapshot-failed",`snapshot "${t}" delete failed: ${r}`,{snapshotId:t})}}0&&(module.exports={SNAPSHOT_WIRE_VERSION,SurfaceError,asSurfaceError,createGraph,deleteSnapshot,diffSnapshots,listSnapshots,restoreSnapshot,runReduction,saveSnapshot});
15
+ `)}`,{errors:o.errors});try{return Sn(t,e)}catch(s){let i=s instanceof Error?s.message:String(s);throw new C("catalog-error",i)}}ce();var Xr=3e4;async function Tn(t,e,n){let r=n?.inputPath??"input",o=n?.outputPath??"output",s=n?.timeoutMs??Xr,i=Xe(t,{catalog:n?.catalog}),a;try{a=i.resolve(o)}catch{throw i.destroy(),new C("node-not-found",`reduce: output path "${o}" is not registered`,{path:o})}try{i.resolve(r)}catch{throw i.destroy(),new C("node-not-found",`reduce: input path "${r}" is not registered`,{path:r})}try{return await new Promise((c,u)=>{let l=!1,p=!1,h,f,d=!1,g=m=>{p||(p=!0,h!==void 0&&clearTimeout(h),f!==void 0?(f(),f=void 0):d=!0,m())};f=a.subscribe(m=>{for(let b of m){if(p)return;if(l){if(b[0]===L){g(()=>c(b[1]));return}if(b[0]===U){let y=a.cache;g(()=>c(y));return}if(b[0]===M){let y=b[1],v=y instanceof Error?y.message:String(y),x=y instanceof Error?y:void 0;g(()=>u(new C("internal-error",`reduce: output emitted ERROR: ${v}`,x!=null?{cause:x}:void 0)));return}if(b[0]===j){g(()=>u(new C("internal-error","reduce: output COMPLETEd without a post-push DATA")));return}}}}),d&&(f?.(),f=void 0),l=!0;try{i.set(r,e)}catch(m){let b=m instanceof Error?m.message:String(m),y=m instanceof Error?m:void 0;g(()=>u(new C("internal-error",`reduce: failed to set input on "${r}": ${b}`,y!=null?{path:r,cause:y}:{path:r})));return}!p&&Number.isFinite(s)&&s>0&&(h=setTimeout(()=>{g(()=>u(new C("reduce-timeout",`reduce: no output emitted within ${s}ms`,{timeoutMs:s,outputPath:o})))},s),h.unref?.())})}finally{i.destroy()}}$e();var Nt=oe,Ee="snapshot:";function ke(t){if(t.startsWith(Ee))throw new C("snapshot-failed",`snapshot id must not start with "${Ee}" (reserved); got "${t}"`,{snapshotId:t})}function Ze(t){return`${Ee}${t}`}function Zr(t){return t.startsWith(Ee)?t.slice(Ee.length):void 0}function Tt(t,e){if(t==null||typeof t!="object")throw new C("snapshot-not-found",`snapshot "${e}" not found in tier`,{snapshotId:e});let n=t;if("mode"in n){if(n.mode==="full"&&"snapshot"in n)return n.snapshot;throw n.mode==="diff"?new C("restore-failed",`snapshot "${e}" is a diff record; restore the baseline and replay WAL instead`,{snapshotId:e,mode:"diff"}):new C("restore-failed",`snapshot "${e}" has unknown mode "${String(n.mode)}"`,{snapshotId:e,mode:String(n.mode)})}if("nodes"in n&&"edges"in n&&"subgraphs"in n&&"name"in n)return n;throw new C("restore-failed",`snapshot "${e}" payload is not a GraphCheckpointRecord or GraphPersistSnapshot`,{snapshotId:e})}async function Nn(t,e,n){ke(e);let r;try{r=t.snapshot()}catch(s){let i=s instanceof Error?s.message:String(s);throw new C("snapshot-failed",`snapshot "${e}" serialization failed: ${i}`,{snapshotId:e})}let o={mode:"full",seq:0,timestamp_ns:ge(),format_version:Nt,snapshot:r};try{await n.save(Ze(e),o)}catch(s){let i=s instanceof Error?s.message:String(s);throw new C("snapshot-failed",`snapshot "${e}" save failed: ${i}`,{snapshotId:e})}return{snapshotId:e,timestamp_ns:o.timestamp_ns}}async function En(t,e,n){ke(t);let r=Ze(t),o=await e.load(r);o==null&&(o=await e.load(t));let s=Tt(o,t);try{return ne.fromSnapshot(s,n?.factories?{factories:n.factories}:void 0)}catch(i){let a=i instanceof Error?i.message:String(i);throw new C("restore-failed",`snapshot "${t}" restore failed: ${a}`,{snapshotId:t})}}async function kn(t,e,n){ke(t),ke(e);let r=async c=>{let u=Ze(c),l=await n.load(u);return l==null&&(l=await n.load(c)),l},[o,s]=await Promise.all([r(t),r(e)]),i=Tt(o,t),a=Tt(s,e);return ne.diff(i,a)}async function Rn(t,e){if(typeof t.list!="function")throw new C("tier-no-list","StorageTier does not implement list(); wrap the tier with an enumerator or use a different backend");let n=await t.list(),r=[],o=e?.includeUnprefixed===!0;for(let s of n){let i=Zr(s);i!==void 0?r.push(i):o&&r.push(s)}return r}async function An(t,e){if(ke(t),typeof e.clear!="function")throw new C("snapshot-failed",`StorageTier is append-only (no clear()); cannot delete "${t}"`,{snapshotId:t});try{await e.clear(Ze(t))}catch(n){let r=n instanceof Error?n.message:String(n);throw new C("snapshot-failed",`snapshot "${t}" delete failed: ${r}`,{snapshotId:t})}}0&&(module.exports={SNAPSHOT_WIRE_VERSION,SurfaceError,asSurfaceError,createGraph,deleteSnapshot,diffSnapshots,listSnapshots,restoreSnapshot,runReduction,saveSnapshot});
@@ -1,8 +1,8 @@
1
- export { C as CatalogFnEntry, a as CatalogSourceEntry, b as ConfigFieldSchema, F as FnFactory, G as GraphSpec, c as GraphSpecCatalog, d as GraphSpecFeedbackEdge, e as GraphSpecNode, f as GraphSpecTemplate, g as GraphSpecTemplateRef, h as GraphSpecValidation, S as SourceFactory } from '../../index-B8Aj_z8S.cjs';
2
- export { C as CreateGraphOptions, R as ReduceOptions, a as RestoreSnapshotOptions, S as SNAPSHOT_WIRE_VERSION, b as SaveSnapshotResult, c as SurfaceError, d as SurfaceErrorCode, e as SurfaceErrorPayload, f as asSurfaceError, g as createGraph, h as deleteSnapshot, i as diffSnapshots, l as listSnapshots, r as restoreSnapshot, j as runReduction, s as saveSnapshot } from '../../index-ClB7TCfL.cjs';
1
+ export { C as CatalogFnEntry, a as CatalogSourceEntry, b as ConfigFieldSchema, F as FnFactory, G as GraphSpec, c as GraphSpecCatalog, d as GraphSpecFeedbackEdge, e as GraphSpecNode, f as GraphSpecTemplate, g as GraphSpecTemplateRef, h as GraphSpecValidation, S as SourceFactory } from '../../index-D-kHVedZ.cjs';
2
+ export { C as CreateGraphOptions, R as ReduceOptions, a as RestoreSnapshotOptions, S as SNAPSHOT_WIRE_VERSION, b as SaveSnapshotResult, c as SurfaceError, d as SurfaceErrorCode, e as SurfaceErrorPayload, f as asSurfaceError, g as createGraph, h as deleteSnapshot, i as diffSnapshots, l as listSnapshots, r as restoreSnapshot, j as runReduction, s as saveSnapshot } from '../../index-BMe3pCom.cjs';
3
3
  import '../../node-BVV7G1bq.cjs';
4
4
  import '../../graph-C4Uxwv0T.cjs';
5
5
  import '../../meta-COtmHLwT.cjs';
6
6
  import '../../extra/storage-core.cjs';
7
- import '../../types-O3GzJY2U.cjs';
7
+ import '../../types-BgMqbc7N.cjs';
8
8
  import '../../extra/sources.cjs';
@@ -1,8 +1,8 @@
1
- export { C as CatalogFnEntry, a as CatalogSourceEntry, b as ConfigFieldSchema, F as FnFactory, G as GraphSpec, c as GraphSpecCatalog, d as GraphSpecFeedbackEdge, e as GraphSpecNode, f as GraphSpecTemplate, g as GraphSpecTemplateRef, h as GraphSpecValidation, S as SourceFactory } from '../../index-BXbQUn4n.js';
2
- export { C as CreateGraphOptions, R as ReduceOptions, a as RestoreSnapshotOptions, S as SNAPSHOT_WIRE_VERSION, b as SaveSnapshotResult, c as SurfaceError, d as SurfaceErrorCode, e as SurfaceErrorPayload, f as asSurfaceError, g as createGraph, h as deleteSnapshot, i as diffSnapshots, l as listSnapshots, r as restoreSnapshot, j as runReduction, s as saveSnapshot } from '../../index-Cc8VQIgL.js';
1
+ export { C as CatalogFnEntry, a as CatalogSourceEntry, b as ConfigFieldSchema, F as FnFactory, G as GraphSpec, c as GraphSpecCatalog, d as GraphSpecFeedbackEdge, e as GraphSpecNode, f as GraphSpecTemplate, g as GraphSpecTemplateRef, h as GraphSpecValidation, S as SourceFactory } from '../../index-CcS0t-l2.js';
2
+ export { C as CreateGraphOptions, R as ReduceOptions, a as RestoreSnapshotOptions, S as SNAPSHOT_WIRE_VERSION, b as SaveSnapshotResult, c as SurfaceError, d as SurfaceErrorCode, e as SurfaceErrorPayload, f as asSurfaceError, g as createGraph, h as deleteSnapshot, i as diffSnapshots, l as listSnapshots, r as restoreSnapshot, j as runReduction, s as saveSnapshot } from '../../index-DxMS0cHM.js';
3
3
  import '../../node-BVV7G1bq.js';
4
4
  import '../../graph-CWeI0aHd.js';
5
5
  import '../../meta-BMwx3ExI.js';
6
6
  import '../../extra/storage-core.js';
7
- import '../../types-u64Ose53.js';
7
+ import '../../types-CdfO2QTt.js';
8
8
  import '../../extra/sources.js';
@@ -1 +1 @@
1
- import{a,b,c,d,e,f,g,h,i,j}from"../../chunk-XQAXYVXX.js";import"../../chunk-GLSM33ZM.js";import"../../chunk-KA6MMXIY.js";import"../../chunk-5Z4HDCO6.js";import"../../chunk-MGKAO4EK.js";import"../../chunk-ESMPEKEV.js";import"../../chunk-TWMEGG45.js";import"../../chunk-5JDE5JHE.js";import"../../chunk-4VVTGLXJ.js";import"../../chunk-2GQREQ6C.js";import"../../chunk-KASHOCF5.js";import"../../chunk-W4TSQ6RJ.js";import"../../chunk-CK2E7BTU.js";import"../../chunk-QYADASLV.js";export{e as SNAPSHOT_WIRE_VERSION,a as SurfaceError,b as asSurfaceError,c as createGraph,j as deleteSnapshot,h as diffSnapshots,i as listSnapshots,g as restoreSnapshot,d as runReduction,f as saveSnapshot};
1
+ import{a,b,c,d,e,f,g,h,i,j}from"../../chunk-WYJTXYWX.js";import"../../chunk-XEFAMCEA.js";import"../../chunk-JMGGCSIC.js";import"../../chunk-K54OKWNY.js";import"../../chunk-LWGLBCMU.js";import"../../chunk-PSQNYY72.js";import"../../chunk-SGS4OJGS.js";import"../../chunk-ESMPEKEV.js";import"../../chunk-N2KKISCE.js";import"../../chunk-WQ7I7JVU.js";import"../../chunk-4VVTGLXJ.js";import"../../chunk-UMH3HSP7.js";import"../../chunk-7AJKUA36.js";import"../../chunk-CK2E7BTU.js";import"../../chunk-QYADASLV.js";export{e as SNAPSHOT_WIRE_VERSION,a as SurfaceError,b as asSurfaceError,c as createGraph,j as deleteSnapshot,h as diffSnapshots,i as listSnapshots,g as restoreSnapshot,d as runReduction,f as saveSnapshot};