@graphrefly/graphrefly 0.36.0 → 0.37.0

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (187) hide show
  1. package/dist/{chunk-PYEIPRSZ.js → chunk-2C4NESZE.js} +1 -1
  2. package/dist/{chunk-44QWWUA3.js → chunk-4EATTNAE.js} +1 -1
  3. package/dist/{chunk-5RTZ6DXG.js → chunk-6SVKZ7VI.js} +1 -1
  4. package/dist/chunk-B4L5X2QO.js +7 -0
  5. package/dist/{chunk-TQSTS3BY.js → chunk-C5CBVOCB.js} +1 -1
  6. package/dist/{chunk-J6TGRQUP.js → chunk-CZIQ6JCE.js} +1 -1
  7. package/dist/chunk-FJ6IEMOS.js +1 -0
  8. package/dist/{chunk-5Z3AFBN7.js → chunk-FMI4CWFL.js} +1 -1
  9. package/dist/{chunk-DBPFMCVH.js → chunk-G6Q3DUMJ.js} +1 -1
  10. package/dist/{chunk-3U7IIQB2.js → chunk-GDDPCDLG.js} +1 -1
  11. package/dist/{chunk-5CZ3KIRJ.js → chunk-GFOT6UBB.js} +1 -1
  12. package/dist/{chunk-KL7CILPL.js → chunk-K2WYIVHM.js} +1 -1
  13. package/dist/{chunk-I57VSGRB.js → chunk-K6ZFJ473.js} +1 -1
  14. package/dist/{chunk-YBA5N4XY.js → chunk-KTWBUJO5.js} +1 -1
  15. package/dist/{chunk-7LYIKMW5.js → chunk-LOQRPP4Y.js} +1 -1
  16. package/dist/{chunk-KCE6WWJE.js → chunk-MC5LZG3U.js} +1 -1
  17. package/dist/{chunk-N2GCKKKH.js → chunk-NKKUUKPD.js} +1 -1
  18. package/dist/{chunk-GWOKTENT.js → chunk-QKBCTKH7.js} +1 -1
  19. package/dist/{chunk-YOUAVGHJ.js → chunk-QP5TH523.js} +1 -1
  20. package/dist/{chunk-T6RPUERH.js → chunk-QWVQIL3T.js} +1 -1
  21. package/dist/{chunk-6G5YD37E.js → chunk-T4U24DXX.js} +1 -1
  22. package/dist/{chunk-AACJX2L7.js → chunk-TFK4P4CX.js} +1 -1
  23. package/dist/{chunk-K5ZXJPWU.js → chunk-TLS7M7H4.js} +1 -1
  24. package/dist/{chunk-AQC53OWG.js → chunk-U3COB5WU.js} +1 -1
  25. package/dist/{chunk-F36TA3ET.js → chunk-UODQF4EY.js} +1 -1
  26. package/dist/{chunk-QKUWS7CO.js → chunk-WGST56ZH.js} +1 -1
  27. package/dist/{chunk-XINLP35X.js → chunk-WSLN4JFO.js} +1 -1
  28. package/dist/{chunk-LO3LO2TO.js → chunk-XIJKEXWR.js} +1 -1
  29. package/dist/{chunk-JUJEPZOI.js → chunk-YVYSO5CW.js} +1 -1
  30. package/dist/compat/index.cjs +9 -9
  31. package/dist/compat/index.d.cts +5 -5
  32. package/dist/compat/index.d.ts +5 -5
  33. package/dist/compat/index.js +1 -1
  34. package/dist/compat/nestjs/index.cjs +11 -11
  35. package/dist/compat/nestjs/index.d.cts +3 -3
  36. package/dist/compat/nestjs/index.d.ts +3 -3
  37. package/dist/compat/nestjs/index.js +1 -1
  38. package/dist/compat/zustand/index.cjs +7 -7
  39. package/dist/compat/zustand/index.d.cts +2 -2
  40. package/dist/compat/zustand/index.d.ts +2 -2
  41. package/dist/compat/zustand/index.js +1 -1
  42. package/dist/extra/index.cjs +15 -15
  43. package/dist/extra/index.d.cts +2 -2
  44. package/dist/extra/index.d.ts +2 -2
  45. package/dist/extra/index.js +1 -1
  46. package/dist/graph/index.cjs +7 -7
  47. package/dist/graph/index.d.cts +3 -3
  48. package/dist/graph/index.d.ts +3 -3
  49. package/dist/graph/index.js +1 -1
  50. package/dist/{graph-kTltt95s.d.cts → graph-CaNXUc3c.d.cts} +26 -1
  51. package/dist/{graph-Cv-8x0ZI.d.ts → graph-YQXDndFy.d.ts} +26 -1
  52. package/dist/{index-CVhBdCMf.d.ts → index-0qOD-421.d.ts} +2 -2
  53. package/dist/{index-BC-xjOrd.d.cts → index-4IwO4mH2.d.cts} +5 -5
  54. package/dist/{index-kBUQj-rT.d.ts → index-9mbs_PIG.d.ts} +1 -1
  55. package/dist/{index-DSSsxS7B.d.ts → index-Ae6L8liv.d.ts} +2 -2
  56. package/dist/{index-BhkPzu-Z.d.cts → index-B1IcU--K.d.cts} +2 -2
  57. package/dist/{index-jA_OwwNg.d.ts → index-B46GWgk3.d.ts} +1 -1
  58. package/dist/{index-EfPb77rT.d.cts → index-B9qJmmv3.d.cts} +1 -1
  59. package/dist/{index-CI_yjtua.d.ts → index-BCq12BqB.d.ts} +1 -1
  60. package/dist/{index-2URa-V4S.d.cts → index-BECJ8M0T.d.cts} +1 -1
  61. package/dist/{index-DFe2Pk2u.d.ts → index-BOfHwQc1.d.ts} +1 -1
  62. package/dist/{index-BTJxM-wZ.d.ts → index-BhLA9feT.d.ts} +1 -1
  63. package/dist/{index-Pu1Wa7en.d.ts → index-BmLkcDlj.d.ts} +5 -5
  64. package/dist/{index-XxSeddWP.d.cts → index-BokynmA4.d.cts} +1 -1
  65. package/dist/{index-DtSVSKnd.d.ts → index-Bpzw8hx3.d.ts} +1 -1
  66. package/dist/{index-PluovH45.d.cts → index-BwtIbzSV.d.cts} +2 -2
  67. package/dist/{index-BZ1V5GzX.d.ts → index-C-pFD_FV.d.ts} +2 -2
  68. package/dist/{index-Cot94_82.d.ts → index-C0tga1_x.d.ts} +2 -2
  69. package/dist/{index-BlRVj-7Q.d.cts → index-C4N-dg5U.d.cts} +2 -2
  70. package/dist/{index-B4s70vYf.d.ts → index-CKcnuQ2c.d.ts} +2 -2
  71. package/dist/{index-HCp5ua_i.d.cts → index-CLPQyYY5.d.cts} +3 -3
  72. package/dist/{index-BuMzxRO2.d.ts → index-CRycrNfn.d.ts} +1 -1
  73. package/dist/{index-CvUrRb4m.d.cts → index-CU3z8Cel.d.cts} +2 -2
  74. package/dist/{index-CZAixNU3.d.ts → index-CUTHDZ7Q.d.ts} +3 -3
  75. package/dist/{index-DzCQt2FJ.d.cts → index-C_qi0WlF.d.cts} +1 -1
  76. package/dist/{index-BBdwz2BW.d.ts → index-CajEOoAN.d.ts} +2 -2
  77. package/dist/{index-BVNGEX7d.d.cts → index-Ci358GSC.d.cts} +2 -2
  78. package/dist/{index-DHv2M7s8.d.cts → index-CkN8CZlT.d.cts} +5 -5
  79. package/dist/{index-ZhKyR8co.d.cts → index-CrpjECS6.d.cts} +2 -2
  80. package/dist/{index-isdlyeeO.d.ts → index-CzIWlnPp.d.ts} +5 -5
  81. package/dist/{index-DxxvGTXp.d.ts → index-D0ZxFXYl.d.ts} +1 -1
  82. package/dist/{index-k67aNfqC.d.cts → index-D11pGlaI.d.cts} +2 -2
  83. package/dist/{index-DlccEIi3.d.ts → index-D1E1tqHT.d.ts} +1 -1
  84. package/dist/{index-Cjrpx2Mg.d.cts → index-D6pwWiOc.d.cts} +1 -1
  85. package/dist/{index-BsZlbHM5.d.cts → index-D6tRNEKz.d.cts} +1 -1
  86. package/dist/{index-33mF4XyU.d.cts → index-DAKm44My.d.cts} +1 -1
  87. package/dist/{index-BWH17rK_.d.cts → index-DCAuN9u5.d.cts} +1 -1
  88. package/dist/{index-CsD0fqnO.d.ts → index-DPqR3wdW.d.ts} +2 -2
  89. package/dist/{index-GaW6Welt.d.cts → index-DTYIRT_v.d.cts} +2 -2
  90. package/dist/{index-DXSLMoma.d.ts → index-DXz9uwcs.d.ts} +1 -1
  91. package/dist/{index-DmtWMP0X.d.cts → index-D_DThl_J.d.cts} +1 -1
  92. package/dist/{index-BwYGLgmI.d.ts → index-D_d1erkR.d.ts} +2 -2
  93. package/dist/{index-D9qoEOj_.d.cts → index-DbWwMWiB.d.cts} +1 -1
  94. package/dist/{index-C4ig7whw.d.cts → index-DcWbx58m.d.cts} +2 -2
  95. package/dist/{index-DzYTXMBz.d.ts → index-DfAo9WKr.d.ts} +1 -1
  96. package/dist/{index-RJIY7QVW.d.cts → index-DqtXA3yX.d.cts} +1 -1
  97. package/dist/{index-KeBhbNg3.d.ts → index-DuhOdNyg.d.ts} +1 -1
  98. package/dist/{index-DKp1CIbG.d.cts → index-e1m3ZHgc.d.cts} +1 -1
  99. package/dist/{index-DLyQC5Ww.d.ts → index-fHKHdAso.d.ts} +2 -2
  100. package/dist/index.cjs +41 -41
  101. package/dist/index.d.cts +28 -28
  102. package/dist/index.d.ts +28 -28
  103. package/dist/index.js +1 -1
  104. package/dist/patterns/ai/index.cjs +19 -19
  105. package/dist/patterns/ai/index.d.cts +6 -6
  106. package/dist/patterns/ai/index.d.ts +6 -6
  107. package/dist/patterns/ai/index.js +1 -1
  108. package/dist/patterns/audit/index.cjs +7 -7
  109. package/dist/patterns/audit/index.d.cts +3 -3
  110. package/dist/patterns/audit/index.d.ts +3 -3
  111. package/dist/patterns/audit/index.js +1 -1
  112. package/dist/patterns/cqrs/index.cjs +7 -7
  113. package/dist/patterns/cqrs/index.d.cts +2 -2
  114. package/dist/patterns/cqrs/index.d.ts +2 -2
  115. package/dist/patterns/cqrs/index.js +1 -1
  116. package/dist/patterns/demo-shell/index.cjs +8 -8
  117. package/dist/patterns/demo-shell/index.d.cts +3 -3
  118. package/dist/patterns/demo-shell/index.d.ts +3 -3
  119. package/dist/patterns/demo-shell/index.js +1 -1
  120. package/dist/patterns/domain-templates/index.cjs +7 -7
  121. package/dist/patterns/domain-templates/index.d.cts +2 -2
  122. package/dist/patterns/domain-templates/index.d.ts +2 -2
  123. package/dist/patterns/domain-templates/index.js +1 -1
  124. package/dist/patterns/graphspec/index.cjs +17 -17
  125. package/dist/patterns/graphspec/index.d.cts +2 -2
  126. package/dist/patterns/graphspec/index.d.ts +2 -2
  127. package/dist/patterns/graphspec/index.js +1 -1
  128. package/dist/patterns/guarded-execution/index.cjs +7 -7
  129. package/dist/patterns/guarded-execution/index.d.cts +4 -4
  130. package/dist/patterns/guarded-execution/index.d.ts +4 -4
  131. package/dist/patterns/guarded-execution/index.js +1 -1
  132. package/dist/patterns/harness/index.cjs +10 -10
  133. package/dist/patterns/harness/index.d.cts +6 -6
  134. package/dist/patterns/harness/index.d.ts +6 -6
  135. package/dist/patterns/harness/index.js +1 -1
  136. package/dist/patterns/job-queue/index.cjs +7 -7
  137. package/dist/patterns/job-queue/index.d.cts +2 -2
  138. package/dist/patterns/job-queue/index.d.ts +2 -2
  139. package/dist/patterns/job-queue/index.js +1 -1
  140. package/dist/patterns/lens/index.cjs +7 -7
  141. package/dist/patterns/lens/index.d.cts +3 -3
  142. package/dist/patterns/lens/index.d.ts +3 -3
  143. package/dist/patterns/lens/index.js +1 -1
  144. package/dist/patterns/memory/index.cjs +7 -7
  145. package/dist/patterns/memory/index.d.cts +2 -2
  146. package/dist/patterns/memory/index.d.ts +2 -2
  147. package/dist/patterns/memory/index.js +1 -1
  148. package/dist/patterns/messaging/index.cjs +7 -7
  149. package/dist/patterns/messaging/index.d.cts +2 -2
  150. package/dist/patterns/messaging/index.d.ts +2 -2
  151. package/dist/patterns/messaging/index.js +1 -1
  152. package/dist/patterns/orchestration/index.cjs +7 -7
  153. package/dist/patterns/orchestration/index.d.cts +2 -2
  154. package/dist/patterns/orchestration/index.d.ts +2 -2
  155. package/dist/patterns/orchestration/index.js +1 -1
  156. package/dist/patterns/process/index.cjs +1 -1
  157. package/dist/patterns/process/index.d.cts +3 -3
  158. package/dist/patterns/process/index.d.ts +3 -3
  159. package/dist/patterns/process/index.js +1 -1
  160. package/dist/patterns/reactive-layout/index.cjs +8 -8
  161. package/dist/patterns/reactive-layout/index.d.cts +3 -3
  162. package/dist/patterns/reactive-layout/index.d.ts +3 -3
  163. package/dist/patterns/reactive-layout/index.js +1 -1
  164. package/dist/patterns/reduction/index.cjs +7 -7
  165. package/dist/patterns/reduction/index.d.cts +2 -2
  166. package/dist/patterns/reduction/index.d.ts +2 -2
  167. package/dist/patterns/reduction/index.js +1 -1
  168. package/dist/patterns/refine-loop/index.cjs +8 -8
  169. package/dist/patterns/refine-loop/index.d.cts +3 -3
  170. package/dist/patterns/refine-loop/index.d.ts +3 -3
  171. package/dist/patterns/refine-loop/index.js +1 -1
  172. package/dist/patterns/resilient-pipeline/index.d.cts +3 -3
  173. package/dist/patterns/resilient-pipeline/index.d.ts +3 -3
  174. package/dist/patterns/resilient-pipeline/index.js +1 -1
  175. package/dist/patterns/surface/index.cjs +10 -10
  176. package/dist/patterns/surface/index.d.cts +3 -3
  177. package/dist/patterns/surface/index.d.ts +3 -3
  178. package/dist/patterns/surface/index.js +1 -1
  179. package/dist/{pipeline-graph-BlLBWSZ2.d.cts → pipeline-graph-BrrYGjuZ.d.cts} +1 -1
  180. package/dist/{pipeline-graph-DdBoRu37.d.ts → pipeline-graph-DX2Twdj-.d.ts} +1 -1
  181. package/dist/{reactive-layout-Btv0-efV.d.ts → reactive-layout-BDdngW56.d.ts} +1 -1
  182. package/dist/{reactive-layout-D9zqqaqK.d.cts → reactive-layout-DrGjuwyC.d.cts} +1 -1
  183. package/dist/{topology-tree-CJsT24DP.d.ts → topology-tree-BI665P0L.d.ts} +1 -1
  184. package/dist/{topology-tree-C50l9ARE.d.cts → topology-tree-BkhmMg2a.d.cts} +1 -1
  185. package/package.json +1 -1
  186. package/dist/chunk-5KPIYVCC.js +0 -7
  187. package/dist/chunk-CGA5RXO6.js +0 -1
@@ -1,8 +1,8 @@
1
- "use strict";var Xe=Object.defineProperty;var cn=Object.getOwnPropertyDescriptor;var fn=Object.getOwnPropertyNames;var hn=Object.prototype.hasOwnProperty;var Q=(t,e)=>()=>(t&&(e=t(t=0)),e);var pn=(t,e)=>{for(var n in e)Xe(t,n,{get:e[n],enumerable:!0})},gn=(t,e,n,r)=>{if(e&&typeof e=="object"||typeof e=="function")for(let s of fn(e))!hn.call(t,s)&&s!==n&&Xe(t,s,{get:()=>e[s],enumerable:!(r=cn(e,s))||r.enumerable});return t};var mn=t=>gn(Xe({},"__esModule",{value:!0}),t);function De(){return fe>0||we}function vt(){return fe>0}function Te(t){fe>0?_e.push(t):t()}function Ae(t){fe+=1;let e=!1;try{t()}catch(n){throw e=!0,n}finally{if(fe-=1,fe===0)if(e){if(!we){let n=_e.splice(0);for(let r of n)try{r()}catch{}de.length=0,ce.length=0,he.length=0}}else bn()}}function bn(){let t=!we;t&&(we=!0);let e=[],n=0;try{for(;de.length>0||ce.length>0||he.length>0||t&&_e.length>0;){if(t&&_e.length>0){let o=_e.splice(0);for(let i of o)try{i()}catch(a){e.push(a)}continue}if(n+=1,n>1e3)throw de.length=0,ce.length=0,he.length=0,new Error("batch drain exceeded 1000 iterations \u2014 likely a reactive cycle");let s=(de.length>0?de:ce.length>0?ce:he).splice(0);for(let o of s)try{o()}catch(i){e.push(i)}}}finally{t&&(we=!1)}if(e.length===1)throw e[0];if(e.length>1)throw new AggregateError(e,"batch drain: multiple callbacks threw")}function Me(t,e,n){if(e.length===0)return;if(e.length===1){let l=n(e[0][0]);if(l<3||!De()){t(e);return}(l>=5?he:l===4?ce:de).push(()=>t(e));return}let r=e.length,s=r,o=r,i=r,a=0;for(;a<r&&n(e[a][0])<3;)a++;for(s=a;a<r&&n(e[a][0])===3;)a++;for(o=a;a<r&&n(e[a][0])===4;)a++;i=a;let u=De();if(s>0){let l=e.slice(0,s);t(l)}if(o>s){let l=e.slice(s,o);u?de.push(()=>t(l)):t(l)}if(i>o){let l=e.slice(o,i);u?ce.push(()=>t(l)):t(l)}if(r>i){let l=e.slice(i,r);u?he.push(()=>t(l)):t(l)}}var fe,we,de,ce,he,_e,Ge=Q(()=>{"use strict";fe=0,we=!1,de=[],ce=[],he=[],_e=[]});function Ze(t){let e=yn.filter(n=>t({type:n,id:""},"write"));return e.length===0?"restricted":e.includes("human")&&e.includes("llm")&&e.every(n=>n==="human"||n==="llm"||n==="system")?"both":e.length===1?e[0]:e.join("+")}var ee,yn,Ie=Q(()=>{"use strict";ee=class extends Error{actor;action;nodeName;constructor(e,n){super(n??`GuardDenied: action "${String(e.action)}" denied for actor type "${String(e.actor.type)}"`),this.name="GuardDenied",this.actor=e.actor,this.action=e.action,this.nodeName=e.nodeName}get node(){return this.nodeName}},yn=["human","llm","wallet","system"]});function wt(t,e){let n=new TextEncoder().encode(t.name);if(n.length===0||n.length>255)throw new Error(`encodeEnvelope: codec name "${t.name}" encodes to ${n.length} bytes (must be 1\u2013255)`);let r=t.version;if(!Number.isInteger(r)||r<0||r>65535)throw new Error(`encodeEnvelope: codec.version ${r} out of u16 range (expected integer 0\u201365535)`);let s=2+n.length+2+e.length;if(s>4294967295)throw new Error(`encodeEnvelope: total envelope size ${s} exceeds 2^32-1 bytes (payload ${e.length} bytes)`);let o=new Uint8Array(s),i=0;return o[i++]=Qe,o[i++]=n.length,o.set(n,i),i+=n.length,o[i++]=r>>>8&255,o[i++]=r&255,o.set(e,i),o}function _t(t,e){if(t.length<xt)throw new Error(`decodeEnvelope: bytes too short (${t.length} < ${xt})`);let n=0,r=t[n++];if(r!==Qe)throw new Error(`decodeEnvelope: unsupported envelope version ${r} (expected ${Qe})`);let s=t[n++];if(s===0)throw new Error("decodeEnvelope: name_len must be >= 1");if(n+s+2>t.length)throw new Error(`decodeEnvelope: envelope truncated (need ${n+s+2} bytes, have ${t.length})`);let o=new TextDecoder().decode(t.subarray(n,n+s));n+=s;let i=(t[n]<<8|t[n+1])>>>0;n+=2;let a=t.subarray(n),u=e.lookupCodec(o);if(u==null)throw new Error(`decodeEnvelope: codec "${o}" not registered (envelope codec_v=${i})`);return{codec:u,codecVersion:i,payload:a}}function Tt(t){t.registerCodec(vn)}var vn,Qe,xt,et=Q(()=>{"use strict";vn={name:"json",version:1,contentType:"application/json",encode(t){let e=JSON.stringify(t);return new TextEncoder().encode(e)},decode(t,e){let n=new TextDecoder().decode(t);return JSON.parse(n)}},Qe=1,xt=4});function Le(t){if(t==null)return pe;let{type:e,id:n,...r}=t;return{type:e??"system",id:n??"",...r}}var pe,tt=Q(()=>{"use strict";pe={type:"system",id:""}});function ge(){return Math.trunc(performance.now()*1e6)}function Pe(){return Date.now()*1e6}var nt=Q(()=>{"use strict"});var ke,J,oe,ie,ne,ae,ue,X,re,V,me,rt,xn,st,wn,_n,ot,kt,St,Ot,it,$e=Q(()=>{"use strict";ke=Symbol.for("graphrefly/START"),J=Symbol.for("graphrefly/DATA"),oe=Symbol.for("graphrefly/DIRTY"),ie=Symbol.for("graphrefly/RESOLVED"),ne=Symbol.for("graphrefly/INVALIDATE"),ae=Symbol.for("graphrefly/PAUSE"),ue=Symbol.for("graphrefly/RESUME"),X=Symbol.for("graphrefly/TEARDOWN"),re=Symbol.for("graphrefly/COMPLETE"),V=Symbol.for("graphrefly/ERROR"),me=Object.freeze([oe]),rt=Object.freeze([ie]),xn=Object.freeze([ne]),st=Object.freeze([ke]),wn=Object.freeze([re]),_n=Object.freeze([X]),ot=Object.freeze([me]),kt=Object.freeze([rt]),St=Object.freeze([xn]),Ot=Object.freeze([wn]),it=Object.freeze([_n])});function Nt(t){t.registerMessageType(ke,{tier:0,wireCrossing:!1}),t.registerMessageType(oe,{tier:1,wireCrossing:!1}),t.registerMessageType(ne,{tier:1,wireCrossing:!1,metaPassthrough:!1}),t.registerMessageType(ae,{tier:2,wireCrossing:!1}),t.registerMessageType(ue,{tier:2,wireCrossing:!1}),t.registerMessageType(J,{tier:3,wireCrossing:!0}),t.registerMessageType(ie,{tier:3,wireCrossing:!0}),t.registerMessageType(re,{tier:4,wireCrossing:!0,metaPassthrough:!1}),t.registerMessageType(V,{tier:4,wireCrossing:!0,metaPassthrough:!1}),t.registerMessageType(X,{tier:5,wireCrossing:!0,metaPassthrough:!1})}var Fe,Et=Q(()=>{"use strict";$e();Fe=class{_messageTypes=new Map;_codecs=new Map;_onMessage;_onSubscribe;_defaultVersioning;_defaultHashFn;_inspectorEnabled=!(typeof process<"u"&&process.env?.NODE_ENV==="production");_globalInspector;_rigorRecorder;_frozen=!1;tierOf;constructor(e){this._onMessage=e.onMessage,this._onSubscribe=e.onSubscribe,this._defaultVersioning=e.defaultVersioning,this._defaultHashFn=e.defaultHashFn,this.tierOf=n=>{let r=this._messageTypes.get(n);return r!=null?r.tier:1}}get onMessage(){return this._frozen=!0,this._onMessage}get onSubscribe(){return this._frozen=!0,this._onSubscribe}set onMessage(e){this._assertUnfrozen(),this._onMessage=e}set onSubscribe(e){this._assertUnfrozen(),this._onSubscribe=e}get defaultVersioning(){return this._defaultVersioning}set defaultVersioning(e){this._assertUnfrozen(),this._defaultVersioning=e}get defaultHashFn(){return this._defaultHashFn}set defaultHashFn(e){this._assertUnfrozen(),this._defaultHashFn=e}get inspectorEnabled(){return this._inspectorEnabled}set inspectorEnabled(e){this._inspectorEnabled=e}get globalInspector(){return this._globalInspector}set globalInspector(e){this._globalInspector=e}get rigorRecorder(){return this._rigorRecorder}set rigorRecorder(e){this._rigorRecorder=e}registerMessageType(e,n){return this._assertUnfrozen(),this._messageTypes.set(e,{tier:n.tier,wireCrossing:n.wireCrossing??n.tier>=3,metaPassthrough:n.metaPassthrough??!0}),this}messageTier(e){let n=this._messageTypes.get(e);return n!=null?n.tier:1}isWireCrossing(e){let n=this._messageTypes.get(e);return n!=null?n.wireCrossing:!0}isLocalOnly(e){return!this.isWireCrossing(e)}isMetaPassthrough(e){let n=this._messageTypes.get(e);return n!=null?n.metaPassthrough:!0}isKnownMessageType(e){return this._messageTypes.has(e)}registerCodec(e){return this._assertUnfrozen(),this._codecs.set(e.name,e),this}lookupCodec(e){return this._codecs.get(e)}_isFrozen(){return this._frozen}_assertUnfrozen(){if(this._frozen)throw new Error("GraphReFlyConfig is frozen: a node has already captured this config. Register custom types and set hooks before creating any node.")}}});function at(t){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(at);if(typeof t=="object"&&t!==null){let e={};for(let n of Object.keys(t).sort())e[n]=at(t[n]);return e}return null}function Sn(t){let e=kn.encode(t),n=e.length,r=n*8,s=n+9+63&-64,o=new Uint8Array(s);o.set(e),o[n]=128;let i=new DataView(o.buffer);i.setUint32(s-4,r>>>0,!1),i.setUint32(s-8,Math.floor(r/4294967296)>>>0,!1);let a=1779033703,u=3144134277,l=1013904242,d=2773480762,f=1359893119,p=2600822924,h=528734635,c=1541459225,m=new Uint32Array(64),w=(y,x)=>y>>>x|y<<32-x;for(let y=0;y<s;y+=64){for(let E=0;E<16;E++)m[E]=i.getUint32(y+E*4,!1);for(let E=16;E<64;E++){let C=m[E-15],R=m[E-2],$=w(C,7)^w(C,18)^C>>>3,U=w(R,17)^w(R,19)^R>>>10;m[E]=m[E-16]+$+m[E-7]+U>>>0}let x=a,T=u,g=l,b=d,_=f,k=p,N=h,A=c;for(let E=0;E<64;E++){let C=w(_,6)^w(_,11)^w(_,25),R=_&k^~_&N,$=A+C+R+Tn[E]+m[E]>>>0,U=w(x,2)^w(x,13)^w(x,22),Z=x&T^x&g^T&g,O=U+Z>>>0;A=N,N=k,k=_,_=b+$>>>0,b=g,g=T,T=x,x=$+O>>>0}a=a+x>>>0,u=u+T>>>0,l=l+g>>>0,d=d+b>>>0,f=f+_>>>0,p=p+k>>>0,h=h+N>>>0,c=c+A>>>0}let v=y=>y.toString(16).padStart(8,"0");return v(a)+v(u)+v(l)+v(d)+v(f)+v(p)+v(h)+v(c)}function ut(t){let e=at(t??null),n=JSON.stringify(e);return Sn(n).slice(0,16)}function On(){let t=globalThis.crypto;if(t?.randomUUID)return t.randomUUID();let e=()=>Math.floor(Math.random()*4294967296).toString(16).padStart(8,"0"),n=e()+e()+e()+e();return`${n.slice(0,8)}-${n.slice(8,12)}-4${n.slice(13,16)}-${(parseInt(n.slice(16,17),16)&3|8).toString(16)}${n.slice(17,20)}-${n.slice(20,32)}`}function lt(t,e,n){let r=n?.id??On();if(t===0)return{id:r,version:0};let o=(n?.hash??ut)(e);return{id:r,version:0,cid:o,prev:null}}function Rt(t,e,n){t.version+=1,"cid"in t&&(t.prev=t.cid,t.cid=n(e))}var Tn,kn,Ct=Q(()=>{"use strict";Tn=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]),kn=new TextEncoder});function Mt(t){return{node:t,unsub:null,prevData:void 0,dirty:!1,involvedThisWave:!1,dataBatch:[],terminal:void 0}}function dt(t){t.prevData=void 0,t.dirty=!1,t.involvedThisWave=!1,t.dataBatch.length=0,t.terminal=void 0}function He(t){return t.length===0?t:typeof t[0]=="symbol"?[t]:t}function Se(t,e,n){let r=Gt(t)?t:[],s=typeof t=="function"?t:typeof e=="function"?e:void 0,o={};return Gt(t)?o=(ct(e)?e:n)??{}:ct(t)?o=t:o=(ct(e)?e:n)??{},new H(r,s,o)}var Dt,At,Nn,En,be,H,Gt,ct,Oe=Q(()=>{"use strict";et();tt();Ge();nt();Et();Ie();$e();Ct();Dt=()=>{},At=100;Nn=(t,e,n,r)=>{n.direction==="down-in"&&t._onDepMessage(n.depIndex,e)},En=(t,e,n,r)=>{let s=t;if(s._status==="completed"||s._status==="errored")return;let o=s._cached,i=o===void 0?[st]:[st,[J,o]];s._status==="dirty"&&i.push(me),Me(e,i,s._config.tierOf)},be=new Fe({onMessage:Nn,onSubscribe:En});Nt(be);Tt(be);H=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??be,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??ut;let s=r.versioning??this._config.defaultVersioning;this._versioningLevel=s,this._versioning=s!=null?lt(s,this._cached===void 0?void 0:this._cached,{id:r.versioningId,hash:this._hashFn}):void 0,this._deps=e.map(Mt);let o={};for(let[a,u]of Object.entries(r.meta??{})){let l={initial:u,name:`${r.name??"node"}:meta:${a}`,describeKind:"state",config:this._config};r.guard!=null&&(l.guard=r.guard),o[a]=new t([],void 0,l)}Object.freeze(o),this.meta=o,this._hasMeta=Object.keys(o).length>0;let i=this;this._actions={emit(a){i._emit([[J,a]])},down(a){i._emit(He(a))},up(a){i._emitUp(He(a))}},this.down=this.down.bind(this),this.up=this.up.bind(this)}get _isTerminal(){return this._status==="completed"||this._status==="errored"}get name(){return this._optsName}get status(){return this._status}get cache(){return this._cached===void 0?void 0:this._cached}get lastMutation(){return this._lastMutation}get v(){return this._versioning}hasGuard(){return this._guard!=null}_applyVersioning(e,n){if(this._isExecutingFn)throw new Error(`Node "${this.name}": _applyVersioning cannot run mid-fn \u2014 call it outside of \`_execFn\` (typically at graph setup time before the first subscribe).`);let r=this._versioningLevel;if(r!=null&&e<=r)return;let s=n?.hash??this._hashFn;s!==this._hashFn&&(this._hashFn=s);let o=this._cached===void 0?void 0:this._cached,i=this._versioning,a=i?.id??n?.id,u=i?.version??0,l=lt(e,o,{id:a,hash:s});l.version=u,this._versioning=l,this._versioningLevel=e}_setInspectorHook(e){return e==null?()=>{}:(this._inspectorHooks==null&&(this._inspectorHooks=new Set),this._inspectorHooks.add(e),()=>{this._inspectorHooks?.delete(e),this._inspectorHooks?.size===0&&(this._inspectorHooks=void 0)})}_pushGuard(e){return this._extraGuards==null&&(this._extraGuards=new Set),this._extraGuards.add(e),()=>{this._extraGuards?.delete(e),this._extraGuards?.size===0&&(this._extraGuards=void 0)}}allowsObserve(e){if(this._guard==null&&this._extraGuards==null)return!0;let n=Le(e);if(this._guard!=null&&!this._guard(n,"observe"))return!1;if(this._extraGuards!=null){for(let r of this._extraGuards)if(!r(n,"observe"))return!1}return!0}_checkGuard(e){if(e?.internal)return;let n=this._guard!=null||this._extraGuards!=null,r=e?.actor!=null;if(!n&&!r)return;let s=Le(e?.actor),o=e?.delivery==="signal"?"signal":"write";if(this._guard!=null&&!this._guard(s,o))throw new ee({actor:s,action:o,nodeName:this.name});if(this._extraGuards!=null){for(let i of this._extraGuards)if(!i(s,o))throw new ee({actor:s,action:o,nodeName:this.name})}this._lastMutation={actor:s,timestamp_ns:Pe()}}down(e,n){let r=He(e);r.length!==0&&(this._checkGuard(n),this._emit(r))}emit(e,n){this._checkGuard(n),this._emit([[J,e]])}up(e,n){if(this._deps.length===0)return;let r=He(e);if(r.length===0)return;this._checkGuard(n);let s=n??{internal:!0};this._validateUpTiers(r);for(let o of this._deps)o.node.up?.(r,s)}_emitUp(e){if(this._deps.length!==0&&e.length!==0){this._validateUpTiers(e);for(let n of this._deps)n.node.up?.(e,{internal:!0})}}_validateUpTiers(e){let n=this._config.tierOf;for(let r of e){let s=n(r[0]);if(s===3||s===4)throw new Error(`Node "${this.name}": tier-${s} messages cannot flow up \u2014 DATA/RESOLVED/COMPLETE/ERROR are downstream-only. Use \`down(...)\` for value delivery; \`up(...)\` is for control signals (DIRTY, INVALIDATE, PAUSE, RESUME, TEARDOWN).`)}}subscribe(e,n){if(n!=null&&this._guard!=null){let u=Le(n);if(!this._guard(u,"observe"))throw new ee({actor:u,action:"observe",nodeName:this.name})}let s=this._isTerminal&&this._resubscribable;if(s){this._cached=void 0,this._status="sentinel",this._store={},this._hasCalledFnOnce=!1,this._waveHasNewData=!1,this._hasNewTerminal=!1,this._paused=!1,this._pendingWave=!1,this._pendingRerun=!1,this._isExecutingFn=!1,this._rerunDepth=0,this._dirtyDepCount=0,this._pauseLocks=null,this._pauseBuffer=null;for(let u of this._deps)dt(u);if(this._partial===!1){for(let u of this._deps)if(u.prevData!==void 0||u.dataBatch.length!==0||u.terminal!==void 0||u.dirty)throw new Error(`resubscribable-reset invariant: DepRecord not fully reset for node ${this._optsName??"(anonymous)"}`)}}this._sinkCount+=1;let o;try{o=this._config.onSubscribe(this,e,{sinkCount:this._sinkCount,afterTerminalReset:s},this._actions)}catch(u){throw this._sinkCount-=1,u}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(u){if(this._sinkCount-=1,this._removeSink(e),this._sinkCount===0&&(this._status="sentinel"),typeof o=="function")try{o()}catch{}throw u}this._status==="sentinel"&&this._cached===void 0&&(this._status="pending");let a=!1;return()=>{a||(a=!0,this._sinkCount-=1,this._removeSink(e),typeof o=="function"&&o(),this._sinks==null&&this._deactivate())}}_removeSink(e){if(this._sinks===e)this._sinks=null;else if(this._sinks!=null&&typeof this._sinks!="function")if(this._sinks.delete(e),this._sinks.size===1){let[n]=this._sinks;this._sinks=n}else this._sinks.size===0&&(this._sinks=null)}_activate(){if(this._deps.length===0){this._fn&&this._execFn();return}this._dirtyDepCount=0;let e=this._deps.length,n=0;try{for(let r=0;r<e;r++){let s=r,o=this._deps[r];o.unsub=Dt,o.unsub=o.node.subscribe(i=>{if(o.unsub===null)return;let a=this._config.tierOf,u=!1;for(let l of i)a(l[0])>=3&&(u=!0),this._config.onMessage(this,l,{direction:"down-in",depIndex:s},this._actions);u&&this._maybeRunFnOnSettlement()}),n++}}catch(r){this._deps[n].unsub=null;for(let s=0;s<n;s++){let o=this._deps[s];if(o.unsub!=null){let i=o.unsub;o.unsub=null;try{i()}catch{}dt(o)}}throw this._dirtyDepCount=0,r}}_addDep(e){for(let s=0;s<this._deps.length;s++)if(this._deps[s].node===e)return s;let n=this._deps.length,r=Mt(e);if(this._deps.push(r),this._sinks==null)return n;r.dirty=!0,this._dirtyDepCount++,this._status!=="dirty"&&this._emit(ot),r.unsub=Dt;try{r.unsub=e.subscribe(s=>{if(r.unsub===null)return;let o=this._config.tierOf,i=!1;for(let a of s)o(a[0])>=3&&(i=!0),this._config.onMessage(this,a,{direction:"down-in",depIndex:n},this._actions);i&&this._maybeRunFnOnSettlement()})}catch(s){throw r.unsub=null,this._deps.pop(),this._dirtyDepCount--,s}return n}_deactivate(e=!1){let n=this._cleanup;if(this._cleanup=void 0,typeof n=="function")try{n()}catch(r){this._emit([[V,this._wrapFnError("cleanup threw",r)]])}else if(n!=null&&typeof n=="object"){let r=n.deactivate;if(typeof r=="function")try{r()}catch(s){this._emit([[V,this._wrapFnError("cleanup.deactivate threw",s)]])}}for(let r of this._deps){if(r.unsub!=null){let s=r.unsub;r.unsub=null;try{s()}catch{}}dt(r)}this._waveHasNewData=!1,this._hasNewTerminal=!1,this._hasCalledFnOnce=!1,this._paused=!1,this._pendingWave=!1,this._pendingRerun=!1,this._rerunDepth=0,this._store={},this._dirtyDepCount=0,this._pauseLocks=null,this._pauseBuffer=null,this._fn!=null&&(this._cached=void 0),e||(this._fn!=null||this._deps.length>0)&&(!this._isTerminal||this._resubscribable)&&(this._status="sentinel")}_onDepMessage(e,n){let r=this._deps[e],s=n[0];if(this._inspectorHooks!=null){let o={kind:"dep_message",depIndex:e,message:n};for(let i of this._inspectorHooks)i(o)}if(s!==ke){if(s===oe){this._depDirtied(r);return}if(s===ne){if(this._depInvalidated(r),this._cached===void 0)return;this._emit(St);return}if(s===ae||s===ue){this._emit([n]);return}if(s===X){this._emit(it);return}if(s===J)this._depSettledAsData(r,n[1]);else if(s===ie)this._depSettledAsResolved(r);else if(s===re)this._depSettledAsTerminal(r,!0);else if(s===V)this._depSettledAsTerminal(r,n[1]);else{this._emit([n]);return}if(!this._fn){(s===J||s===ie)&&this._emit([n]),(s===re||s===V)&&this._maybeAutoTerminalAfterWave();return}}}_depDirtied(e){e.dirty||(e.dirty=!0,e.involvedThisWave=!0,this._dirtyDepCount++,this._status!=="dirty"&&this._emit(ot))}_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(kt),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([[V,e.terminal]]);return}this._autoComplete&&this._deps.every(n=>n.terminal!==void 0)&&this._emit(Ot)}_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([[V,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([[V,this._wrapFnError("cleanup.beforeRun threw",a)]]);return}}}let n=this._deps.map(i=>i.involvedThisWave?i.dataBatch.length>0?[...i.dataBatch]:[]:void 0),r=this._deps.map(i=>i.prevData);for(let i=0;i<this._deps.length;i++){let a=n[i];a!=null&&a.length>0&&(this._deps[i].prevData=a[a.length-1])}let s=this._deps.map(i=>i.terminal),o={prevData:r,terminalDeps:s,store:this._store};if(this._hasCalledFnOnce=!0,this._clearWaveFlags(),this._inspectorHooks!=null){let i={kind:"run",batchData:n,prevData:r};for(let a of this._inspectorHooks)a(i)}this._isExecutingFn=!0;try{let i=this._fn(n,this._actions,o);if(typeof i=="function")this._cleanup=i;else if(i!=null&&typeof i=="object"){let a=i;(typeof a.beforeRun=="function"||typeof a.deactivate=="function"||typeof a.invalidate=="function")&&(this._cleanup=i)}}catch(i){this._emit([[V,this._wrapFnError("fn threw",i)]])}finally{this._isExecutingFn=!1,this._pendingRerun?(this._pendingRerun=!1,this._rerunDepth+=1,this._rerunDepth>At?(this._rerunDepth=0,this._emit([[V,new Error(`Node "${this.name}": _pendingRerun depth exceeded ${At} \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,s=!1,o=!1,i=-1;for(let u of e){let l=n(u[0]);l<i&&(r=!1),l===3&&(s=!0),u[0]===oe&&(o=!0),i=l}let a=e;if(!r){let u=e.map((l,d)=>({m:l,i:d,tier:n(l[0])}));u.sort((l,d)=>l.tier-d.tier||l.i-d.i),a=u.map(l=>l.m)}if(s&&!o&&this._status!=="dirty"){let u=0;for(;u<a.length&&n(a[u][0])===0;)u++;return u===0?[me,...a]:[...a.slice(0,u),me,...a.slice(u)]}return a}_emit(e){if(e.length===0)return;for(let a=0;a<e.length;a++){let u=e[a];if(u[0]===V&&u[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(u=>u[0]===X||u[0]===ne);if(a.length===0)return;n=a}n=this._frameBatch(n);let s=null;for(let a=0;a<n.length;a++){let u=n[a],l=u[0];if(l!==ae&&l!==ue){s?.push(u);continue}if(u.length<2)throw new Error(`Node "${this.name}": [[${l===ae?"PAUSE":"RESUME"}]] must carry a lockId payload \u2014 bare PAUSE/RESUME is a protocol violation (C0 rule). Use \`[[PAUSE, lockId]]\` / \`[[RESUME, lockId]]\`.`);let d=!0;if(this._pausable!==!1){let f=u[1];if(l===ae)this._pauseLocks==null&&(this._pauseLocks=new Set),this._pauseLocks.add(f),this._paused=!0,this._pausable==="resumeAll"&&this._pauseBuffer==null&&(this._pauseBuffer=[]);else if(this._pauseLocks==null||!this._pauseLocks.has(f))d=!1;else if(this._pauseLocks.delete(f),this._pauseLocks.size===0){if(this._paused=!1,this._pauseBuffer!=null&&this._pauseBuffer.length>0){let p=this._pauseBuffer;this._pauseBuffer=[],this._emit(p)}this._pendingWave&&(this._pendingWave=!1,this._maybeRunFnOnSettlement())}}d?s?.push(u):s==null&&(s=n.slice(0,a))}if(s!=null){if(s.length===0)return;n=s}if(this._hasMeta&&n.some(a=>a[0]===X))for(let a of Object.keys(this.meta))try{this.meta[a]._emit(it)}catch{}let{finalMessages:o,equalsError:i}=this._updateState(n);if(o.length>0&&this._config.inspectorEnabled){let a=this._config.globalInspector;if(a!=null)try{a({kind:"emit",node:this,messages:o})}catch{}}if(o.length>0)if(this._paused&&this._pausable==="resumeAll"&&this._pauseBuffer!=null){let a=this._config.tierOf,u=[];for(let l of o)a(l[0])===3?this._pauseBuffer.push(l):u.push(l);u.length>0&&this._dispatchOrAccumulate(u)}else this._dispatchOrAccumulate(o);i!=null&&this._emit([[V,i]])}_updateState(e){let n=this._config.tierOf,r,s,o=-1,i=0;for(let d of e)n(d[0])===3&&i++;let a=i<=1,u=-1;if(this._versioning!=null&&i>1){for(let d=e.length-1;d>=0;d--)if(e[d][0]===J){u=d;break}}for(let d=0;d<e.length;d++){let f=e[d],p=f[0];if(p===J){if(f.length>=2){let h=!1;if(a&&this._cached!==void 0)try{h=this._equals(this._cached,f[1])}catch(c){s=this._wrapFnError("equals threw",c),o=d;break}if(h){r==null&&(r=e.slice(0,d)),r.push(rt),this._status="resolved";continue}this._cached=f[1],this._versioning!=null&&(u<0||d===u)&&Rt(this._versioning,f[1],this._hashFn)}this._status="settled",r?.push(f)}else if(r?.push(f),p===oe)this._status="dirty";else if(p===ie)this._status="resolved";else if(p===re){this._status="completed";{let h=this._config.rigorRecorder;if(h!=null)try{h.onTerminalTransition(this,"completed",this._autoComplete,this._autoError,this._deps.length>0)}catch{}}}else if(p===V){this._status="errored";{let h=this._config.rigorRecorder;if(h!=null)try{h.onTerminalTransition(this,"errored",this._autoComplete,this._autoError,this._deps.length>0)}catch{}}}else if(p===ne){if(this._cached!==void 0){let c=this._config.rigorRecorder;if(c!=null)try{c.onNonVacuousInvalidate(this,this._cached)}catch{}}this._cached=void 0,this._status="dirty";let h=this._cleanup;if(typeof h=="function"){this._cleanup=void 0;try{h()}catch{}}else if(h!=null&&typeof h=="object"){let c=h.invalidate;if(typeof c=="function")try{c()}catch{}}}else p===X&&(this._resetOnTeardown&&(this._cached=void 0),this._deactivate(!0),this._status="sentinel")}let l=o>=0?r??e.slice(0,o):r??e;return s!=null?{finalMessages:l,equalsError:s}:{finalMessages:l}}_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(vt()){this._batchPendingMessages===null&&(this._batchPendingMessages=[],Te(()=>this._flushBatchPending()));for(let n of e)this._batchPendingMessages.push(n);return}Me(this._deliverToSinks,e,this._config.tierOf)}_flushBatchPending(){let e=this._batchPendingMessages;if(e===null||(this._batchPendingMessages=null,e.length===0))return;let n=this._frameBatch(e);Me(this._deliverToSinks,n,this._config.tierOf)}},Gt=t=>Array.isArray(t),ct=t=>typeof t=="object"&&t!=null&&!Array.isArray(t)});function Y(t,e){return Se([],{...e,initial:t})}function It(t,e){return Se((r,s,o)=>t(s,o)??void 0,{describeKind:"producer",...e})}function j(t,e,n){return Se(t,(s,o,i)=>{let a=s.map((u,l)=>u!=null&&u.length>0?u.at(-1):i.prevData[l]);o.emit(e(a,i))},{describeKind:"derived",...n})}function Be(t,e,n){return Se(t,(s,o,i)=>{let a=s.map((u,l)=>u!=null&&u.length>0?u.at(-1):i.prevData[l]);return e(a,o,i)??void 0},{describeKind:"effect",...n})}var ft=Q(()=>{"use strict";Oe()});function ht(t){return t.subscribe(()=>{})}var Lt=Q(()=>{"use strict"});var Ve,Pt=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 Cr={};pn(Cr,{demoShell:()=>Rr});module.exports=mn(Cr);Ge();Ie();Oe();function ye(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 Rn(t){return t._describeKind!=null?t._describeKind:t._deps.length>0?"derived":t._fn!=null?"producer":"state"}function Cn(t){let e={};for(let[n,r]of Object.entries(t.meta))try{e[n]=r.cache}catch{}return e}function Ne(t,e){let n=e==null,r=!n&&e!=null?[...e].filter(l=>l.startsWith("meta.")).map(l=>l.slice(5)):null,s=n||e.has("meta")||r!=null&&r.length>0,o="state",i=[];t instanceof H&&(o=Rn(t),i=t._deps.map(l=>l.node.name??""));let a={type:o,deps:i};(n||e.has("status"))&&(a.status=t.status);let u=t instanceof H?t._guard:void 0;if(s){let l={...Cn(t)};if(u!=null&&l.access===void 0&&(l.access=Ze(u)),r!=null&&r.length>0&&!e.has("meta")){let d={};for(let f of r)f in l&&(d[f]=l[f]);a.meta=d}else a.meta=l}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 l={id:t.v.id,version:t.v.version};"cid"in t.v&&(l.cid=t.v.cid,l.prev=t.v.prev),a.v=l}return(n||e.has("guard"))&&u!=null&&(a.guard=Ze(u)),(n||e.has("lastMutation"))&&t.lastMutation!=null&&(a.lastMutation=t.lastMutation),a}ft();tt();Ge();nt();Ie();$e();Oe();ft();Lt();Pt();var Ee=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}};et();function pt(t){return t>=768&&t<=879||t>=1155&&t<=1161||t>=1425&&t<=1469||t>=1552&&t<=1562||t>=1611&&t<=1631||t>=1648&&t===1648||t>=1750&&t<=1756||t>=1759&&t<=1764||t>=1767&&t<=1768||t>=1770&&t<=1773||t>=1840&&t<=1866||t>=1958&&t<=1968||t>=2304&&t<=2307||t>=2362&&t<=2383||t>=2385&&t<=2391||t>=2402&&t<=2403||t>=2433&&t<=2435||t>=2492&&t<=2509||t>=2561&&t<=2563||t>=2620&&t<=2641||t>=2672&&t<=2673||t>=2677&&t===2677||t>=3633&&t===3633||t>=3636&&t<=3642||t>=3655&&t<=3662||t>=3761&&t===3761||t>=3764&&t<=3772||t>=3784&&t<=3790||t>=7616&&t<=7679||t>=8400&&t<=8447||t>=65024&&t<=65039||t>=65056&&t<=65071||t===8205?0:t>=4352&&t<=4447||t>=8986&&t<=8987||t>=9001&&t<=9002||t>=9193&&t<=9203||t>=9208&&t<=9210||t>=9725&&t<=9726||t>=9748&&t<=9749||t>=9800&&t<=9811||t===9855||t===9875||t===9889||t>=9898&&t<=9899||t>=9917&&t<=9918||t>=9924&&t<=9925||t===9934||t===9940||t===9962||t>=9970&&t<=9971||t===9973||t===9978||t===9981||t===9986||t===9989||t>=9992&&t<=9997||t===9999||t>=10067&&t<=10069||t===10071||t>=10133&&t<=10135||t===10160||t===10175||t>=10548&&t<=10549||t>=11013&&t<=11015||t>=11035&&t<=11036||t===11088||t===11093||t>=11904&&t<=12350||t>=12352&&t<=12447||t>=12448&&t<=12543||t>=12549&&t<=12591||t>=12593&&t<=12686||t>=12688&&t<=12771||t>=12784&&t<=12830||t>=12832&&t<=12871||t>=12880&&t<=19903||t>=19968&&t<=40959||t>=43360&&t<=43388||t>=44032&&t<=55203||t>=63744&&t<=64255||t>=65040&&t<=65049||t>=65072&&t<=65131||t>=65281&&t<=65376||t>=65504&&t<=65510||t>=126980&&t===126980||t===127183||t>=127344&&t<=127345||t===127358||t===127359||t===127374||t>=127377&&t<=127386||t>=127456&&t<=127487||t>=127488&&t<=127490||t===127514||t===127535||t>=127538&&t<=127546||t>=127568&&t<=127569||t>=127744&&t<=129535||t>=129536&&t<=129791||t>=129792&&t<=130047||t>=131072&&t<=196605||t>=196608&&t<=262141?2:1}function je(t){let e=0;for(let n of t)e+=pt(n.codePointAt(0));return e}function $t(t,e){if(e<=0)return"";let n=0,r="";for(let s of t){let o=pt(s.codePointAt(0));if(n+o>e){if(e<=1)return"\u2026";for(;n+1>e&&r.length>0;){let i=[...r].pop();r=r.slice(0,-i.length),n-=pt(i.codePointAt(0))}return`${r}\u2026`}r+=s,n+=o}return r}var Dn={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"},An={horizontal:"-",vertical:"|",cornerTL:"+",cornerTR:"+",cornerBL:"+",cornerBR:"+",tDown:"+",tUp:"+",tRight:"+",tLeft:"+",cross:"+",arrowRight:">",arrowDown:"v",arrowLeft:"<",arrowUp:"^",boxTL:"+",boxTR:"+",boxBL:"+",boxBR:"+",boxH:"-",boxV:"|"};function Vt(t,e){let n=e.charset==="ascii"?An:Dn,r=t.width,s=t.height,o=Array.from({length:s},()=>Array.from({length:r},()=>" ")),i=Array.from({length:s},()=>Array.from({length:r},()=>"empty"));for(let a of t.edges)Gn(o,i,n,a);for(let a of t.boxes)Mn(o,i,n,a,e.labelOf(a.id));return o.map(a=>$n(a.join(""))).join(`
2
- `)}function Mn(t,e,n,r,s){let{x:o,y:i,w:a,h:u}=r;if(a<2||u<2){u>0&&Ft(t,e,o,i,a,s);return}le(t,e,o,i,n.boxTL);for(let d=o+1;d<o+a-1;d+=1)le(t,e,d,i,n.boxH);le(t,e,o+a-1,i,n.boxTR);for(let d=i+1;d<i+u-1;d+=1){le(t,e,o,d,n.boxV);for(let f=o+1;f<o+a-1;f+=1)jt(t,e,f,d," ","empty");le(t,e,o+a-1,d,n.boxV)}le(t,e,o,i+u-1,n.boxBL);for(let d=o+1;d<o+a-1;d+=1)le(t,e,d,i+u-1,n.boxH);le(t,e,o+a-1,i+u-1,n.boxBR);let l=i+Math.floor(u/2);Ft(t,e,o+1,l,a-2,s)}function le(t,e,n,r,s){jt(t,e,n,r,s,s===" "?"empty":s==="\u2500"||s==="-"?"boxH":s==="\u2502"||s==="|"?"boxV":"boxCorner")}function jt(t,e,n,r,s,o){if(r<0||r>=t.length)return;let i=t[r];n<0||n>=i.length||(i[n]=s,e[r][n]=o)}function Ft(t,e,n,r,s,o){if(r<0||r>=t.length)return;let i=n,a=s;for(let u of o){let l=je(u);if(l!==0){if(a<l)break;i>=0&&i<t[r].length&&(t[r][i]=u,e[r][i]="label",l===2&&i+1<t[r].length&&(t[r][i+1]="",e[r][i+1]="label")),i+=l,a-=l}}for(;a>0;)i>=0&&i<t[r].length&&(t[r][i]=" ",e[r][i]="empty"),i+=1,a-=1}function Gn(t,e,n,r){let s=r.points;if(s.length<2)return;for(let u=0;u+1<s.length;u+=1)In(t,e,n,s[u],s[u+1]);for(let u=1;u+1<s.length;u+=1){let l=s[u-1],d=s[u],f=s[u+1],p=Ln(l,d,f,n);p&&Bt(t,e,d.x,d.y,p,"edgeCorner")}let o=s[s.length-1],i=s[s.length-2],a=Pn(i,o,n);a&&Bt(t,e,o.x,o.y,a,"arrow")}function In(t,e,n,r,s){if(!(r.x===s.x&&r.y===s.y)){if(r.y===s.y){let o=r.y,i=Math.min(r.x,s.x),a=Math.max(r.x,s.x);for(let u=i;u<=a;u+=1)Ht(t,e,u,o,n,"h")}else if(r.x===s.x){let o=r.x,i=Math.min(r.y,s.y),a=Math.max(r.y,s.y);for(let u=i;u<=a;u+=1)Ht(t,e,o,u,n,"v")}}}function Ht(t,e,n,r,s,o){if(r<0||r>=t.length)return;let i=t[r];if(n<0||n>=i.length)return;let a=e[r][n];if(!(a==="boxH"||a==="boxV"||a==="boxCorner"||a==="label")){if(a==="empty"){i[n]=o==="h"?s.horizontal:s.vertical,e[r][n]=o==="h"?"edgeH":"edgeV";return}if(a==="edgeH"&&o==="v"){i[n]=s.cross,e[r][n]="edgeCorner";return}if(a==="edgeV"&&o==="h"){i[n]=s.cross,e[r][n]="edgeCorner";return}}}function Bt(t,e,n,r,s,o){if(r<0||r>=t.length)return;let i=t[r];if(n<0||n>=i.length)return;let a=e[r][n];a==="boxH"||a==="boxV"||a==="boxCorner"||a==="label"||(i[n]=s,e[r][n]=o)}function Ln(t,e,n,r){let s=t.y===e.y,o=e.y===n.y;if(s===o)return;if(s){let u=t.x<e.x,l=n.y>e.y;return u&&l?r.cornerTR:u&&!l?r.cornerBR:!u&&l?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 Pn(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 $n(t){let e=t.length;for(;e>0&&t.charCodeAt(e-1)===32;)e-=1;return t.slice(0,e)}function Ut(t){let e=Fn(t);Hn(e),Bn(e),Vn(e),jn(e,t);let n=Un(e,t),{width:r,height:s}=qn(e),o=[];for(let i of e.layers)for(let a of i)a.isVirtual||o.push({id:a.id,layer:a.layer,order:a.order,x:a.x,y:a.y,w:a.w,h:a.h});return{boxes:o,edges:n,width:r,height:s}}function Fn(t){let e=new Map;for(let s of t.nodes)e.set(s,{id:s,isVirtual:!1,layer:-1,order:0,x:0,y:0,w:t.widthCells(s),h:t.heightCells(s),in:[],out:[]});let n=[],r=0;for(let s of t.edges){if(s.from===s.to)continue;let o=e.get(s.from),i=e.get(s.to);if(!o||!i)continue;let a={chainId:r++,chainFrom:s.from,chainTo:s.to,fromId:s.from,toId:s.to,hopIndex:0,chainLen:1};o.out.push(a),i.in.push(a),n.push(a)}return{nodes:e,layers:[],hops:n}}function Hn(t){let e=new Map;for(let o of t.nodes.values())e.set(o.id,o.in.length);let n=[];for(let o of t.nodes.values())(e.get(o.id)??0)===0&&(o.layer=0,n.push(o));let r=new Set,s=0;for(;s<n.length;){let o=n[s++];if(!r.has(o.id)){r.add(o.id);for(let i of o.out){let a=t.nodes.get(i.toId);a.layer=Math.max(a.layer,o.layer+1);let u=(e.get(a.id)??0)-1;e.set(a.id,u),u<=0&&n.push(a)}}}for(let o of t.nodes.values())o.layer<0&&(o.layer=0)}function Bn(t){let e=Math.max(0,...Array.from(t.nodes.values(),o=>o.layer)),n=Array.from({length:e+1},()=>[]);for(let o of t.nodes.values())n[o.layer].push(o);let r=[],s=0;for(let o of t.hops){let i=t.nodes.get(o.fromId),a=t.nodes.get(o.toId),u=a.layer-i.layer;if(u<=0){i.out=i.out.filter(f=>f!==o),a.in=a.in.filter(f=>f!==o);continue}if(u===1){o.hopIndex=0,o.chainLen=1,r.push(o);continue}i.out=i.out.filter(f=>f!==o),a.in=a.in.filter(f=>f!==o);let l=i;for(let f=1;f<u;f+=1){let p=`__virt_${s++}__`,h={id:p,isVirtual:!0,layer:i.layer+f,order:0,x:0,y:0,w:0,h:1,in:[],out:[]};t.nodes.set(p,h),n[h.layer].push(h);let c={chainId:o.chainId,chainFrom:o.chainFrom,chainTo:o.chainTo,fromId:l.id,toId:p,hopIndex:f-1,chainLen:u};l.out.push(c),h.in.push(c),r.push(c),l=h}let d={chainId:o.chainId,chainFrom:o.chainFrom,chainTo:o.chainTo,fromId:l.id,toId:a.id,hopIndex:u-1,chainLen:u};l.out.push(d),a.in.push(d),r.push(d)}for(let o of n)for(let i=0;i<o.length;i+=1)o[i].order=i;t.layers=n,t.hops=r}function Vn(t){for(let n=0;n<4;n+=1){for(let r=1;r<t.layers.length;r+=1)Wt(t,t.layers[r],"in"),We(t.layers[r]);for(let r=t.layers.length-2;r>=0;r-=1)Wt(t,t.layers[r],"out"),We(t.layers[r])}for(let n=0;n<2;n+=1){let r=!1;for(let s=1;s<t.layers.length;s+=1){let o=t.layers[s];for(let i=0;i+1<o.length;i+=1){let a=zt(t,o[i],o[i+1],"in");[o[i],o[i+1]]=[o[i+1],o[i]],We(o),zt(t,o[i],o[i+1],"in")<a?r=!0:([o[i],o[i+1]]=[o[i+1],o[i]],We(o))}}if(!r)break}}function Wt(t,e,n){let r=new Map;for(let s of e){let o=n==="in"?s.in:s.out;if(o.length===0){r.set(s.id,s.order);continue}let i=0,a=0;for(let u of o){let l=t.nodes.get(n==="in"?u.fromId:u.toId);l&&(i+=l.order,a+=1)}r.set(s.id,a===0?s.order:i/a)}e.sort((s,o)=>{let i=r.get(s.id),a=r.get(o.id);return i!==a?i-a:s.order-o.order})}function We(t){for(let e=0;e<t.length;e+=1)t[e].order=e}function zt(t,e,n,r){let s=r==="in"?e.in:e.out,o=r==="in"?n.in:n.out,i=0;for(let a of s)for(let u of o){let l=t.nodes.get(r==="in"?a.fromId:a.toId)?.order??0,d=t.nodes.get(r==="in"?u.fromId:u.toId)?.order??0;(e.order<n.order&&l>d||e.order>n.order&&l<d)&&(i+=1)}return i}function jn(t,e){e.direction==="LR"?Wn(t,e):zn(t,e)}function Wn(t,e){let n=[],r=0;for(let s=0;s<t.layers.length;s+=1){n.push(r);let o=0;for(let i of t.layers[s])o=Math.max(o,i.w);r+=o+e.layerGap}for(let s=0;s<t.layers.length;s+=1)for(let o of t.layers[s])o.x=n[s];for(let s of t.layers){let o=0;for(let i of s)i.y=o,o+=i.h+e.nodeGap}Kt(t,e,"y")}function zn(t,e){let n=[],r=0;for(let s=0;s<t.layers.length;s+=1){n.push(r);let o=0;for(let i of t.layers[s])o=Math.max(o,i.h);r+=o+e.layerGap}for(let s=0;s<t.layers.length;s+=1)for(let o of t.layers[s])o.y=n[s];for(let s of t.layers){let o=0;for(let i of s)i.x=o,o+=i.w+e.nodeGap}Kt(t,e,"x")}function Kt(t,e,n){let r=o=>n==="y"?o.h:o.w,s=e.nodeGap;for(let o=0;o<2;o+=1){let i=o===0?t.layers.slice(1):t.layers.slice(0,-1).reverse();for(let a of i){let u=new Map;for(let d of a){let f=o===0?d.in:d.out;if(f.length===0)continue;let p=[];for(let c of f){let m=t.nodes.get(o===0?c.fromId:c.toId);if(!m)continue;let w=n==="y"?m.y:m.x;p.push(w+Math.floor(r(m)/2))}if(p.length===0)continue;p.sort((c,m)=>c-m);let h=p[Math.floor(p.length/2)];u.set(d.id,h-Math.floor(r(d)/2))}let l=0;for(let d of a){let f=u.get(d.id),p=n==="y"?d.y:d.x,c=Math.max(f??p,l);n==="y"?d.y=c:d.x=c,l=c+r(d)+s}}}}function Un(t,e){let n=new Map;for(let l of t.hops){let d=n.get(l.chainId);d?d.push(l):n.set(l.chainId,[l])}for(let l of n.values())l.sort((d,f)=>d.hopIndex-f.hopIndex);let r=e.direction==="LR",s=l=>r?l.x:l.y,o=l=>r?l.w:l.h,i=l=>r?l.y+Math.floor(l.h/2):l.x+Math.floor(l.w/2),a=new Map;for(let l=0;l+1<t.layers.length;l+=1){let d=t.layers[l],f=t.layers[l+1],p=0;for(let k of d)p=Math.max(p,s(k)+o(k));let h=Number.POSITIVE_INFINITY;for(let k of f)h=Math.min(h,s(k));let c=Number.isFinite(h)?h-1:p,m=Math.max(1,c-p+1),w=[];for(let k of d)for(let N of k.out)w.push(N);w.sort((k,N)=>{let A=i(t.nodes.get(k.fromId)),E=i(t.nodes.get(N.fromId));if(A!==E)return A-E;let C=i(t.nodes.get(k.toId)),R=i(t.nodes.get(N.toId));return C-R});let v=[],y=new Map;for(let k of w){let N=i(t.nodes.get(k.fromId)),A=i(t.nodes.get(k.toId)),E=Math.min(N,A),C=Math.max(N,A),R=-1;for(let $=0;$<v.length;$+=1){let U=v[$],Z=!0;for(let O of U)if(O.lo<=C&&E<=O.hi){Z=!1;break}if(Z){U.push({lo:E,hi:C}),R=$;break}}R<0&&(v.push([{lo:E,hi:C}]),R=v.length-1),y.set(k,R)}let x=v.length,T=m>=Math.max(3,x+2),g=T?p+1:p,b=T?c-1:c,_=Math.max(1,b-g+1);for(let k of w){let N=y.get(k),A;if(x<=1)A=g+Math.floor(_/2);else{let E=(_-1)/(x-1);A=g+Math.floor(N*E)}a.set(k,Math.max(p,Math.min(c,A)))}}let u=[];for(let[,l]of n){let d=[];for(let p=0;p<l.length;p+=1){let h=l[p],c=t.nodes.get(h.fromId),m=t.nodes.get(h.toId),w=a.get(h),v=c.isVirtual?s(c):s(c)+o(c),y=m.isVirtual?s(m):s(m)-1,x=i(c),T=i(m);p===0&&ze(d,r,v,x),x!==T&&(ze(d,r,w,x),ze(d,r,w,T)),ze(d,r,y,T)}let f=l[0];u.push({from:f.chainFrom,to:f.chainTo,points:Kn(d)})}return u}function ze(t,e,n,r){t.push(e?{x:n,y:r}:{x:r,y:n})}function Kn(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 qn(t){let e=0,n=0;for(let r of t.layers)for(let s of r)e=Math.max(e,s.x+s.w),n=Math.max(n,s.y+s.h);return{width:e,height:n}}var Yn=24,Jn=4,Xn=1,Zn=3;function qt(t,e){let n=Qn(e.direction),r=Math.max(3,e.maxLabelWidth??Yn),s=e.asciiCharset??"unicode",o=Object.keys(t.nodes).sort(),i=new Set(o),a=t.edges.filter(h=>i.has(h.from)&&i.has(h.to)),u=new Map,l=new Map;for(let h of o){let c=$t(h,r);u.set(h,c),l.set(h,je(c)+4)}let d=Ut({nodes:o,edges:a,widthCells:h=>l.get(h)??3,heightCells:()=>Zn,layerGap:Jn,nodeGap:Xn,direction:n}),f=Vt(d,{charset:s,labelOf:h=>u.get(h)??h}),p=e.logger;return p&&p(f),f}function Qn(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 Yt(t,e,n,r={}){let s=e in t.nodes,o=n in t.nodes;if(!s)return Ue(e,n,"no-such-from");if(!o)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 l=er(t,e,r);if(l!=null)return l}let u=Ke(e,t.nodes[e],0,r);return qe(e,n,[u])}if(i===0)return Ue(e,n,"no-path");let a=Jt(t,e,n,i);return a.found?qe(e,n,Xt(t,a.pathOrder,r)):Ue(e,n,a.truncated?"max-depth-exceeded":"no-path")}function Jt(t,e,n,r){let s=new Map,o=[{path:n,depth:0}],i=new Set([n]),a=0,u=!1;for(;a<o.length;){let f=o[a++];if(f.path===e)break;if(r!=null&&f.depth>=r){let m=t.nodes[f.path];m?.deps&&m.deps.length>0&&(u=!0);continue}let p=t.nodes[f.path];if(p==null)continue;let h=p.deps??[],c=new Map;for(let m=0;m<h.length;m++){let w=h[m];if(!w)continue;let v=c.get(w);v==null&&(v=[],c.set(w,v)),v.push(m)}for(let[m,w]of c)i.has(m)||(i.add(m),s.set(m,{from:f.path,depIndices:w}),o.push({path:m,depth:f.depth+1}))}if(!s.has(e))return{found:!1,pathOrder:[],truncated:u};let l=[{path:e}],d=e;for(;d!==n;){let f=s.get(d);if(f==null)return{found:!1,pathOrder:[],truncated:!1};l[l.length-1].depIndices=f.depIndices,l.push({path:f.from}),d=f.from}return{found:!0,pathOrder:l,truncated:!1}}function er(t,e,n){let r=t.nodes[e];if(r==null)return null;let s=r.deps??[],o=[];for(let a=0;a<s.length;a++)s[a]===e&&o.push(a);if(o.length>0){let a=Ke(e,r,0,n);a.dep_index=o[0];let u=Ke(e,r,1,n);return qe(e,e,[a,u])}let i=null;for(let a=0;a<s.length;a++){let u=s[a];if(!u||u===e)continue;let l=Jt(t,u,e,n.maxDepth);l.found&&(i==null||l.pathOrder.length<i.pathOrder.length)&&(i=l,i={found:!0,pathOrder:[{path:e,depIndices:[a]},...l.pathOrder],truncated:!1})}return i==null?null:qe(e,e,Xt(t,i.pathOrder,n))}function Xt(t,e,n){return e.map((r,s)=>{let o=t.nodes[r.path],i=Ke(r.path,o,s,n);return r.depIndices!=null&&r.depIndices.length>0&&(i.dep_index=r.depIndices[0],r.depIndices.length>1&&(i.dep_indices=[...r.depIndices])),i})}function Ke(t,e,n,r){let s={path:t,type:e.type,hop:n};e.status!==void 0&&(s.status=e.status),"value"in e&&(s.value=e.value),e.v!=null&&(s.v=e.v);let o=r.annotations?.get(t)??e.annotation;o!=null&&(s.annotation=o);let i=r.lastMutations?.get(t)??e.lastMutation;return i!=null&&(s.lastMutation=i),s}function qe(t,e,n){return Zt(t,e,!0,"ok",n)}function Ue(t,e,n){return Zt(t,e,!1,n,[])}function Zt(t,e,n,r,s){let o=tr(t,e,n,r,s);return{from:t,to:e,found:n,reason:r,steps:s,text:o,toJSON(){return{from:t,to:e,found:n,reason:r,steps:s}}}}function tr(t,e,n,r,s){if(!n)switch(r){case"no-such-from":return`explainPath: no node named "${t}"`;case"no-such-to":return`explainPath: no node named "${e}"`;case"max-depth-exceeded":return`explainPath: no path from "${t}" to "${e}" within maxDepth`;default:return`explainPath: no path from "${t}" to "${e}"`}let o=[`Causal path: ${t} \u2192 ${e} (${s.length} step(s))`];for(let i of s){let u=` ${i.hop===0?"\xB7":"\u2193"} ${i.path} (${i.type}${i.status?`/${i.status}`:""})`;if(o.push(u),"value"in i&&o.push(` value: ${nr(i.value)}`),i.annotation!=null&&o.push(` annotation: ${i.annotation}`),i.lastMutation!=null){let l=i.lastMutation.actor;o.push(` actor: ${l.type}${l.id?`:${l.id}`:""}`)}}return o.join(`
3
- `)}function nr(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)}}Oe();var B={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},rr=Symbol.for("sizeof");function Qt(t){let e=new WeakSet,n=new WeakSet,r=[t],s=0;for(;r.length>0;){let o=r.pop();s+=sr(o,e,n,r)}return s}function sr(t,e,n,r){if(t==null)return 0;switch(typeof t){case"number":return B.number;case"boolean":return B.boolean;case"string":return B.string+t.length*2;case"bigint":return B.bigint+or(t);case"symbol":return B.symbol;case"function":return e.has(t)?0:(e.add(t),B.function);case"undefined":return 0}let o=t;if(e.has(o))return 0;e.add(o);let i=o[rr];if(typeof i=="function")try{let l=i.call(o);if(typeof l=="number"&&Number.isFinite(l))return l}catch{}if(o instanceof Date)return B.date;if(o instanceof RegExp)return B.regexp+o.source.length*2;if(o instanceof Error){let l=o.message?o.message.length*2:0,d=o.stack?o.stack.length*2:0;return B.error+l+d}if(typeof URL<"u"&&o instanceof URL)return B.url+o.href.length*2;if(typeof Promise<"u"&&o instanceof Promise)return B.promise;if(o instanceof WeakMap)return B.weakmap;if(o instanceof WeakSet)return B.weakset;if(o instanceof Map){let l=B.map;for(let[d,f]of o)l+=B.mapEntry,r.push(d),r.push(f);return l}if(o instanceof Set){let l=B.set;for(let d of o)l+=B.setEntry,r.push(d);return l}if(Array.isArray(o)){let l=B.array+o.length*8;for(let d of o)r.push(d);return l}if(o instanceof ArrayBuffer)return n.has(o)?0:(n.add(o),o.byteLength);if(ArrayBuffer.isView(o)){let l=o;return n.has(l.buffer)?48:(n.add(l.buffer),l.buffer.byteLength+48)}let a=B.object,u=Object.keys(o);for(let l of u){a+=B.string+l.length*2;try{r.push(o[l])}catch{}}return a}function or(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 en(t,e){let n=e?.topN??10,r=t.describe({detail:"standard"}),s=[],o=t._collectObserveTargets;typeof o=="function"&&o.call(t,"",s);let i=new Map;for(let[p,h]of s)i.set(p,h);let a=[];for(let[p,h]of Object.entries(r.nodes)){let c=i.get(p),m=c instanceof H?c:null,w=m?Qt(m.cache):0,v=m?m._sinkCount:0,y=h.deps?.length??0,x=h.type==="effect"&&v===0,T=v===0?h.type==="effect"?"orphan-effect":h.type==="derived"?"idle-derived":h.type==="producer"?"idle-producer":null:null;a.push({path:p,type:h.type,status:h.status??"unknown",valueSizeBytes:w,subscriberCount:v,depCount:y,isOrphanEffect:x,orphanKind:T})}let u=a.reduce((p,h)=>p+h.valueSizeBytes,0),l=(p,h)=>[...a].sort(h??((c,m)=>m[p]-c[p])).slice(0,n),d=a.filter(p=>p.orphanKind!=null),f=a.filter(p=>p.isOrphanEffect);return{nodeCount:a.length,edgeCount:r.edges.length,subgraphCount:r.subgraphs.length,nodes:a,totalValueSizeBytes:u,hotspots:{byValueSize:l("valueSizeBytes"),bySubscriberCount:l("subscriberCount"),byDepCount:l("depCount")},orphans:d,orphanEffects:f}}var P="::",se="__meta__",ve=1;function tn(t,e){let n=Math.max(16,t.size*4),r=0;for(;t.size>0;){if(r++>=n){console.error(`[Graph "${e}".destroy] disposer drain exceeded cap (${n}); ${t.size} disposer(s) discarded`),t.clear();return}let s=t.values().next();if(s.done)return;let o=s.value;t.delete(o);try{o()}catch(i){console.error(`[Graph "${e}".destroy] disposer threw:`,i)}}}function ir(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 nn(t){if(t.version!==ve)throw new Error(`unsupported snapshot version ${String(t.version)} (expected ${ve})`);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 ar(t,e){let n=new WeakMap,r=(s,o)=>{if(Object.is(s,o))return!0;if(s==null||o==null||typeof s!="object"||typeof o!="object")return!1;let i=n.get(s);if(i==null&&(i=new WeakSet,n.set(s,i)),i.has(o))return!0;i.add(o);let a=s.constructor,u=o.constructor;if(a!==u)return!1;if(s instanceof Date)return s.getTime()===o.getTime();if(s instanceof RegExp)return s.source===o.source&&s.flags===o.flags;if(Array.isArray(s)){let p=o;if(s.length!==p.length)return!1;for(let h=0;h<s.length;h++)if(!r(s[h],p[h]))return!1;return!0}if(s instanceof Map){let p=o;if(s.size!==p.size)return!1;for(let[h,c]of s)if(!p.has(h)||!r(c,p.get(h)))return!1;return!0}if(s instanceof Set){let p=o;if(s.size!==p.size)return!1;for(let h of s){let c=!1;for(let m of p)if(r(h,m)){c=!0;break}if(!c)return!1}return!0}if(ArrayBuffer.isView(s)){let p=s,h=o;if(p.length!==h.length)return!1;for(let c=0;c<p.length;c++)if(p[c]!==h[c])return!1;return!0}let l=Object.keys(s),d=Object.keys(o);if(l.length!==d.length)return!1;let f=new Set(d);for(let p of l)if(!f.has(p)||!r(s[p],o[p]))return!1;return!0};return r(t,e)}function mt(t){if(t===null||typeof t!="object")return t;if(Array.isArray(t))return t.map(mt);let e=t,n=Object.keys(e).sort(),r={};for(let s of n)r[s]=mt(e[s]);return r}function ur(t){return t.replaceAll("\\","\\\\").replaceAll('"','\\"')}function lr(t){return t.replaceAll("\\","\\\\").replaceAll('"','\\"')}function dr(t){return t==="TD"?"down":t==="BT"?"up":t==="RL"?"left":"right"}function on(t){let e=new Set,n=[];function r(s,o){let i=`${s}\0${o}`;e.has(i)||(e.add(i),n.push([s,o]))}for(let[s,o]of Object.entries(t.nodes)){let i=o.deps;if(i)for(let a of i)r(a,s)}for(let s of t.edges)r(s.from,s.to);return n}function an(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:s,...o}=t,i={...o,edges:n?t.edges:[],subgraphs:r?t.subgraphs:[]},a=JSON.stringify(mt(i),null,e.indent??2);return e.logger?.(a),a}function fr(t,e){let n=e.includeEdges??!0,r=e.includeSubgraphs??!0,s=[];s.push(`Graph ${t.name}`),s.push("Nodes:");for(let i of Object.keys(t.nodes).sort()){let a=t.nodes[i];s.push(`- ${i} (${a.type}/${a.status}): ${Je(a.value)}`)}if(n){s.push("Edges:");for(let i of t.edges)s.push(`- ${i.from} -> ${i.to}`)}if(r){s.push("Subgraphs:");for(let i of t.subgraphs)s.push(`- ${i}`)}let o=s.join(`
5
- `);return e.logger?.(o),o}function un(t,e){let n=an(e.direction),r=Object.keys(t.nodes).sort(),s=new Map;for(let i=0;i<r.length;i+=1)s.set(r[i],`n${i}`);let o=[`flowchart ${n}`];for(let i of r){let a=s.get(i);o.push(` ${a}["${ur(i)}"]`)}for(let[i,a]of on(t)){let u=s.get(i),l=s.get(a);!u||!l||o.push(` ${u} --> ${l}`)}return o.join(`
6
- `)}function hr(t,e){let n=un(t,e);return pr(n)}function pr(t,e){let n=e?.theme??"default",r=e?.autoSync??!0,o=JSON.stringify({code:t,mermaid:{theme:n},autoSync:r}),i=new TextEncoder().encode(o),a="";for(let l=0;l<i.length;l++)a+=String.fromCharCode(i[l]);return`https://mermaid.live/edit#base64:${globalThis.btoa(a).replace(/\+/g,"-").replace(/\//g,"_").replace(/=+$/,"")}`}function gr(t,e){let n=an(e.direction),r=Object.keys(t.nodes).sort(),s=new Map;for(let i=0;i<r.length;i+=1)s.set(r[i],`n${i}`);let o=[`direction: ${dr(n)}`];for(let i of r){let a=s.get(i);o.push(`${a}: "${lr(i)}"`)}for(let[i,a]of on(t)){let u=s.get(i),l=s.get(a);!u||!l||o.push(`${u} -> ${l}`)}return o.join(`
7
- `)}function mr(t){return t.replace(/[.*+?^${}()|[\]\\]/g,"\\$&")}function Ye(t){let e="^";for(let n=0;n<t.length;n+=1){let r=t[n];if(r==="*"){e+=".*";continue}if(r==="?"){e+=".";continue}if(r==="["){let s=t.indexOf("]",n+1);if(s<=n+1){e+="\\[";continue}let o=t.slice(n+1,s);o.startsWith("!")&&(o=`^${o.slice(1)}`),o=o.replace(/\\/g,"\\\\"),e+=`[${o}]`,n=s;continue}e+=mr(r)}return e+="$",new RegExp(e)}var br={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"},yr={data:"",dirty:"",resolved:"",invalidate:"",pause:"",resume:"",complete:"",error:"",teardown:"",derived:"",path:"",reset:""};function Je(t){if(typeof t=="string")return JSON.stringify(t);if(typeof t=="number"||typeof t=="boolean"||t==null)return String(t);try{return JSON.stringify(t)}catch{return"[unserializable]"}}function vr(t){return t==="none"?yr:t==="ansi"||t==null?br:{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 rn(t){if(t==null)return{};let e=t.detail;return e==="full"?{...t,structured:t.structured??!0,timeline:t.timeline??!0,causal:t.causal??!0,derived:t.derived??!0}:e==="minimal"?{...t,structured:t.structured??!0}:t.format==="stage-log"?{...t,structured:t.structured??!0,timeline:t.timeline??!0}:t}function xr(t,e,n){for(let r=0;r<t.length;r++){let s=t.charCodeAt(r);if(s<32||s===127)throw new Error(`Graph "${e}": ${n} "${t}" must not contain control character (U+${s.toString(16).padStart(4,"0").toUpperCase()} at index ${r})`)}}function gt(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===se)throw new Error(`Graph "${e}": ${n} name "${se}" is reserved for meta companion paths`);xr(t,e,n)}function wr(t,e){if(t==="")throw new Error(`Graph "${e}": resolve path must be non-empty`);let n=t.split(P);for(let r of n)if(r==="")throw new Error(`Graph "${e}": resolve path has empty segment`);return n}function _r(t,e){let n=!1;for(let s of t)if(!e.isMetaPassthrough(s[0])){n=!0;break}return n?t.filter(s=>e.isMetaPassthrough(s[0])):t}function ln(t){for(let e of t._mounts.values())ln(e);for(let e of t._nodes.values())try{e.down([[X]],{internal:!0})}catch{}}var Re=class t{name;opts;config;_nodes=new Map;_nodeToName=new WeakMap;_mounts=new Map;_parent=void 0;_storageDisposers=new Set;_disposers=new Set;_destroyed=!1;_topology;_topologyEmitters=new Set;constructor(e,n){if(e==="")throw new Error("Graph name must be non-empty");if(e.includes(P))throw new Error(`Graph name must not contain '${P}' (got "${e}")`);if(e===se)throw new Error(`Graph name "${se}" is reserved for meta companion paths`);this.name=e,this.opts=Object.freeze({...n??{}}),this.config=n?.config??be,this._traceRing=new Ee(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=It(e=>{let n=r=>{e.emit(r)};return this._topologyEmitters.add(n),()=>{this._topologyEmitters.delete(n)}},{name:`${this.name}_topology`})),this._topology}_emitTopology(e){if(!(this._topology==null||this._topologyEmitters.size===0))for(let n of this._topologyEmitters)n(e)}nameOf(e){return this._nodeToName.get(e)}add(e,n){let r=e.name,s=n?.name??r;if(s==null||s==="")throw new Error(`Graph "${this.name}": graph.add requires a non-empty name \u2014 pass via opts.name or set it on the node (e.g. state(0, { name: "x" }))`);let o=s,i=n?.annotation;if(gt(o,this.name,"add"),this._mounts.has(o))throw new Error(`Graph "${this.name}": name "${o}" is already a mount point`);if(this._nodes.has(o))throw new Error(`Graph "${this.name}": node "${o}" already exists`);let a=this._nodeToName.get(e);if(a!==void 0)throw new Error(`Graph "${this.name}": node instance already registered as "${a}"`);return this._nodes.set(o,e),this._nodeToName.set(e,o),this._emitTopology({kind:"added",name:o,nodeKind:"node"}),i!=null&&(this._annotations.set(o,i),this.config.inspectorEnabled&&this._traceRing.push({path:o,annotation:i,timestamp_ns:ge()})),e}setVersioning(e){if(e!=null)for(let n of this._nodes.values())n instanceof H&&n._applyVersioning(e)}remove(e){gt(e,this.name,"remove");let n=this._mounts.get(e);if(n){let o={kind:"mount",nodes:[],mounts:[]},i=[];n._collectObserveTargets("",i);for(let[a,u]of i)a.includes(`${P}${se}${P}`)||o.nodes.push(a);return o.nodes.sort(),o.mounts.push(e),o.mounts.push(...n._collectSubgraphs(`${e}${P}`)),this._mounts.delete(e),n._parent=void 0,ln(n),this._emitTopology({kind:"removed",name:e,nodeKind:"mount",audit:o}),o}let r=this._nodes.get(e);if(!r)throw new Error(`Graph "${this.name}": unknown node or mount "${e}"`);this._nodes.delete(e),this._nodeToName.delete(r),r.down([[X]],{internal:!0});let s={kind:"node",nodes:[e],mounts:[]};return this._emitTopology({kind:"removed",name:e,nodeKind:"node",audit:s}),s}removeAll(e){let n=typeof e=="function"?e:(()=>{let o=Ye(e);return i=>o.test(i)})(),r={kind:"mount",nodes:[],mounts:[]},s=[...this._nodes.keys(),...this._mounts.keys()].filter(o=>n(o));for(let o of s){let i=this.remove(o);r.nodes.push(...i.nodes),r.mounts.push(...i.mounts)}return r.nodes.sort(),r.mounts.sort(),r}[Symbol.iterator](){let e=[...this._nodes.keys()].sort(),n=this._nodes,r=0;return{[Symbol.iterator](){return this},next(){if(r>=e.length)return{value:void 0,done:!0};let s=e[r++];return{value:[s,n.get(s)],done:!1}}}}node(e){if(e==="")throw new Error(`Graph "${this.name}": node name must be non-empty`);if(e.includes(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 s=r?.internal===!0;this.node(e).down([[J,n]],{actor:r?.actor,internal:s,delivery:"write"})}setAll(e,n){let r=Symbol.iterator in e?e:Object.entries(e);Ae(()=>{for(let[s,o]of r)this.set(s,o,n)})}invalidate(e,n){let r=n?.internal===!0;this.node(e).down([[ne]],{actor:n?.actor,internal:r,delivery:"write"})}error(e,n,r){let s=r?.internal===!0;this.node(e).down([[V,n]],{actor:r?.actor,internal:s,delivery:"write"})}complete(e,n){let r=n?.internal===!0;this.node(e).down([[re]],{actor:n?.actor,internal:r,delivery:"write"})}edges(e){let n=e?.recursive===!0,r=new Map;if(!n){for(let[u,l]of this._nodes)r.set(l,u);let a=[];for(let[u,l]of this._nodes)if(l instanceof H)for(let d of l._deps){let f=r.get(d.node);f!=null&&a.push([f,u])}return a.sort((u,l)=>u[0]<l[0]?-1:u[0]>l[0]?1:u[1]<l[1]?-1:u[1]>l[1]?1:0),a}let s=[];this._collectObserveTargets("",s);let o=new Map;for(let[a,u]of s)o.set(u,a);let i=[];for(let[a,u]of s)if(u instanceof H)for(let l of u._deps){let d=o.get(l.node);d!=null&&i.push([d,a])}return i.sort((a,u)=>a[0]<u[0]?-1:a[0]>u[0]?1:a[1]<u[1]?-1:a[1]>u[1]?1:0),i}mount(e,n){if(n===void 0){let s=new t(e);return this.mount(e,s)}if(typeof n=="function"){let s=new t(e);return n(s),this.mount(e,s)}let r=n;if(gt(e,this.name,"mount"),this._nodes.has(e))throw new Error(`Graph "${this.name}": cannot mount at "${e}" \u2014 node with that name exists`);if(this._mounts.has(e))throw new Error(`Graph "${this.name}": mount "${e}" already exists`);if(r===this)throw new Error(`Graph "${this.name}": cannot mount a graph into itself`);if(r._parent!=null)throw new Error(`Graph "${this.name}": this child graph is already mounted on "${r._parent.name}"`);for(let s=this;s!=null;s=s._parent)if(s===r)throw new Error(`Graph "${this.name}": mount("${e}", \u2026) would create a mount cycle`);return this._mounts.set(e,r),r._parent=this,this._emitTopology({kind:"added",name:e,nodeKind:"mount"}),r}resolve(e){let n=wr(e,this.name);return this._resolveFromSegments(n)}tryResolve(e){try{return this.resolve(e)}catch{return}}_resolveFromSegments(e){let n=e;if(n[0]===this.name&&(n=n.slice(1),n.length===0))throw new Error(`Graph "${this.name}": resolve path ends at graph name only`);let r=n[0],s=n.slice(1);if(s.length===0){let a=this._nodes.get(r);if(a)return a;throw this._mounts.has(r)?new Error(`Graph "${this.name}": path ends at subgraph "${r}" \u2014 not a node (GRAPHREFLY-SPEC \xA73.5)`):new Error(`Graph "${this.name}": unknown name "${r}"`)}let o=this._nodes.get(r);if(o&&s.length>0&&s[0]===se)return this._resolveMetaChainFromNode(o,s,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 "${s.join(P)}" is invalid`):new Error(`Graph "${this.name}": unknown mount or node "${r}"`);return i.resolve(s.join(P))}_resolveMetaChainFromNode(e,n,r){let s=e,o=0,i=[...n];for(;o<i.length;){if(i[o]!==se)throw new Error(`Graph "${this.name}": expected ${se} segment in meta path "${r}"`);if(o+1>=i.length)throw new Error(`Graph "${this.name}": meta path requires a key after ${se} in "${r}"`);let a=i[o+1],u=s.meta[a];if(!u)throw new Error(`Graph "${this.name}": unknown meta "${a}" in path "${r}"`);s=u,o+=2}return s}signal(e,n){if(n?.internal!==!0){for(let s of e)if(this.config.messageTier(s[0])===3)throw new Error(`Graph "${this.name}": Graph.signal() rejects tier-3 messages (DATA / RESOLVED). Broadcast is for control-plane tiers (START / DIRTY / INVALIDATE / PAUSE / RESUME / COMPLETE / ERROR / TEARDOWN). For per-node value writes, use Graph.set or graph.node(name).down(...).`)}let r=[];if(this._signalDeliver(e,n??{},new Set,r),r.length>0)throw r[0]}_signalDeliver(e,n,r,s){for(let u of this._mounts.values())u._signalDeliver(e,n,r,s);let i=n.internal===!0?{internal:!0}:{actor:n.actor,delivery:"signal"},a=_r(e,this.config);for(let u of[...this._nodes.keys()].sort()){let l=this._nodes.get(u);if(!r.has(l)){r.add(l);try{l.down(e,i)}catch(d){if(d instanceof ee)throw d;s.push(d)}a.length!==0&&this._signalMetaSubtree(l,a,r,i,s)}}}_signalMetaSubtree(e,n,r,s,o){for(let i of Object.keys(e.meta).sort()){let a=e.meta[i];if(!r.has(a)){r.add(a);try{a.down(n,s)}catch(u){if(u instanceof ee)throw u;o.push(u)}this._signalMetaSubtree(a,n,r,s,o)}}}describe(e){if(e?.reactive===!0)return this._describeReactive(e);let n=e?.actor,r=e?.filter,s=ye(e?.detail,e?.fields),o=e?.format==="spec",i=o?ye("minimal"):s,a=[];this._collectObserveTargets("",a);let u=new Map;for(let[b,_]of a)u.set(_,b);let l=[];{let b=a.map(([,N])=>N),_=new Set(u.values()),k=0;for(;b.length>0;){let N=b.shift();if(N instanceof H)for(let A of N._deps){let E=A.node;if(u.has(E))continue;let C=E.name??"",R=C;if(!R||_.has(R))if(C){let $=2;for(;_.has(`${C}#${$}`);)$++;R=`${C}#${$}`}else for(R=`__internal__/${k++}`;_.has(R);)R=`__internal__/${k++}`;u.set(E,R),_.add(R),l.push([R,E]),b.push(E)}}}let d=[...a,...l],f={};for(let[b,_]of d){if(n!=null&&!_.allowsObserve(n))continue;let k=Ne(_,i),N=_ instanceof H?_._deps.map(R=>u.get(R.node)??R.node.name??""):[],{name:A,...E}=k,C={...E,deps:N};if(!o){let R=this._annotations.get(b);R!=null&&(C.annotation=R)}if(r!=null)if(typeof r=="function"){let R=r;if(!(R.length>=2?R(b,C):R(C)))continue}else{let R=!0;for(let[$,U]of Object.entries(r)){let Z=$==="deps_includes"?"depsIncludes":$==="meta_has"?"metaHas":$;if(Z==="depsIncludes"){if(!C.deps.includes(String(U))){R=!1;break}continue}if(Z==="metaHas"){if(!Object.hasOwn(C.meta??{},String(U))){R=!1;break}continue}if(C[Z]!==U){R=!1;break}}if(!R)continue}f[b]=C}let p=new Set(Object.keys(f)),h=[];for(let[b,_]of d)if(_ instanceof H)for(let k of _._deps){let N=u.get(k.node);N!=null&&h.push([N,b])}h.sort((b,_)=>b[0]<_[0]?-1:b[0]>_[0]?1:b[1]<_[1]?-1:b[1]>_[1]?1:0);let c=h.map(([b,_])=>({from:b,to:_}));(n!=null||r!=null)&&(c=c.filter(b=>p.has(b.from)&&p.has(b.to)));let m=this._collectSubgraphs(""),w=n!=null||r!=null?m.filter(b=>{let _=`${b}${P}`;return[...p].some(k=>k===b||k.startsWith(_))}):m,v=this,y=e,x={name:this.name,nodes:f,edges:c,subgraphs:w,expand(b){let _={...y,format:void 0};return Array.isArray(b)?(_.fields=b,_.detail=void 0):(_.detail=b,_.fields=void 0),v.describe(_)}},T=e??{},g=T.format;return g==="json"?cr(x,T):g==="pretty"?fr(x,T):g==="mermaid"?un(x,T):g==="mermaid-url"?hr(x,T):g==="d2"?gr(x,T):g==="ascii"?qt(x,T):x}_collectSubgraphs(e){let n=[];for(let r of[...this._mounts.keys()].sort()){let s=e===""?r:`${e}${r}`;n.push(s),n.push(...this._mounts.get(r)._collectSubgraphs(`${s}${P}`))}return n}resourceProfile(e){return en(this,e)}reachable(e,n,r={}){return r.withDetail===!0?sn(this.describe(),e,n,{...r,withDetail:!0}):sn(this.describe(),e,n,r)}explain(e,n,r){return r?.reactive===!0?this._explainReactive(e,n,r):this._explainStatic(e,n,r)}_explainStatic(e,n,r){let s=this.describe({detail:"full"}),o=new Map(this._annotations),i=new Map;for(let[a,u]of Object.entries(s.nodes))u.lastMutation!=null&&i.set(a,u.lastMutation);return Yt(s,e,n,{...r?.maxDepth!=null?{maxDepth:r.maxDepth}:{},...r?.findCycle===!0?{findCycle:!0}:{},annotations:o,lastMutations:i})}_describeReactive(e){let n={...e,reactive:!1},r=e.reactiveName??"describe",s=0,o=Y(s,{name:`${r}_version`}),i=this.observe({timeline:!0,structured:!0}),a=!1,u=!1,l=()=>{a||u||(a=!0,Te(()=>{a=!1,!u&&(s+=1,o.emit(s))}))},d=i.onEvent(w=>{let v=w.type;v!=="data"&&v!=="error"&&v!=="complete"&&v!=="teardown"||l()}),f=[],p=new WeakSet,h=w=>{if(p.has(w)||u)return;p.add(w);let v=w.topology.subscribe(y=>{for(let x of y){if(x[0]!==J)continue;let T=x[1];if(l(),T.kind==="added"&&T.nodeKind==="mount"){let g=w._mounts.get(T.name);g!=null&&h(g)}}});f.push(v);for(let y of w._mounts.keys()){let x=w._mounts.get(y);x!=null&&h(x)}};h(this);let c;try{c=j([o],()=>this.describe(n),{name:r,describeKind:"derived",meta:{domain:"audit",kind:"describe"},equals:(w,v)=>w===v})}catch(w){d();for(let v of f)v();throw i.dispose(),w}let m=ht(c);return{node:c,dispose(){u=!0,d();for(let w of f)w();f.length=0,i.dispose(),m()}}}_explainReactive(e,n,r){let s=0,o=Y(s,{name:"explain_version"}),i=this.observe({timeline:!0,structured:!0}),a=!1,u=!1,l=i.onEvent(h=>{let c=h.type;c!=="data"&&c!=="error"&&c!=="complete"&&c!=="teardown"||a||u||(a=!0,Te(()=>{a=!1,!u&&(s+=1,o.emit(s))}))}),d={...r?.maxDepth!=null?{maxDepth:r.maxDepth}:{},...r?.findCycle===!0?{findCycle:!0}:{}},f;try{f=j([o],()=>this._explainStatic(e,n,d),{name:r?.name??"explain",describeKind:"derived",meta:{domain:"audit",kind:"explain_path",from:e,to:n},equals:(h,c)=>h.found===c.found&&h.reason===c.reason&&h.steps.length===c.steps.length&&kr(h.steps,c.steps)})}catch(h){throw l(),i.dispose(),h}let p=ht(f);return{node:f,dispose(){u=!0,l(),i.dispose(),p()}}}_pathsMatching(e){let n=Ye(e),r=[];return this._collectObserveTargets("",r),r.map(([s])=>s).filter(s=>n.test(s))}_collectObserveTargets(e,n){for(let r of[...this._mounts.keys()].sort()){let s=e===""?r:`${e}${P}${r}`;this._mounts.get(r)._collectObserveTargets(s,n)}for(let r of[...this._nodes.keys()].sort()){let s=this._nodes.get(r),o=e===""?r:`${e}${P}${r}`;n.push([o,s]),this._appendMetaObserveTargets(o,s,n)}}_appendMetaObserveTargets(e,n,r){for(let s of Object.keys(n.meta).sort()){let o=n.meta[s],i=`${e}${P}${se}${P}${s}`;r.push([i,o]),this._appendMetaObserveTargets(i,o,r)}}observe(e,n){let r=typeof e=="string",o=rn(r?n:e),i=o.structured===!0||o.timeline===!0||o.causal===!0||o.derived===!0||o.detail==="minimal"||o.detail==="full"||o.format!=null,a=o.actor;if(r){let d=e,f=this.resolve(d);if(a!=null&&!f.allowsObserve(a))throw new ee({actor:a,action:"observe",nodeName:d});return i?this._buildStructuredObserver([[d,f]],o,"one"):{subscribe(p){return f.subscribe(p)},up(p){try{f.up?.(p)}catch(h){if(h instanceof ee)return;throw h}}}}let u=[];this._collectObserveTargets("",u),u.sort((d,f)=>d[0]<f[0]?-1:d[0]>f[0]?1:0);let l=a==null?u:u.filter(([,d])=>d.allowsObserve(a));return i?this._buildStructuredObserver(l,o,"all"):{subscribe:d=>{let f=l.map(([p,h])=>h.subscribe(c=>{d(p,c)}));return()=>{for(let p of f)p()}},up:(d,f)=>{try{this.resolve(d).up?.(f)}catch(p){if(p instanceof ee)return;throw p}}}}_buildStructuredObserver(e,n,r){let s=r==="one"?e[0]?.[0]:void 0,o=i=>{if(r==="one"&&s!=null){let d=this.resolve(s);return this._buildStructuredObserver([[s,d]],i,"one")}let a=[];this._collectObserveTargets("",a),a.sort((d,f)=>d[0]<f[0]?-1:d[0]>f[0]?1:0);let u=i.actor,l=u==null?a:a.filter(([,d])=>d.allowsObserve(u));return this._buildStructuredObserver(l,i,"all")};return this._createObserveResult(e,n,o)}_createObserveResult(e,n,r){let s=n.timeline===!0,o=n.causal===!0,i=n.derived===!0,a=n.detail==="minimal",u=this.config.inspectorEnabled,l=(o||i)&&u,d=n.maxEvents,f=d!=null&&d>0?new Ee(d):null,p=[],h=new Set,c={},m=new Set,w=0,v=0,y=0,x=0,T=0,g=0,b=!1,_=!1,k=0,N=new Map,A=new Map,E=new Map,C=S=>{f?f.push(S):p.push(S);for(let G of h)G(S)},R=()=>s?{timestamp_ns:ge(),in_batch:De(),batch_id:k}:{},$=(S,G)=>{if(!(!l||!(S instanceof H)))return S._setInspectorHook(W=>{if(W.kind==="dep_message")N.set(S,W.depIndex);else if(W.kind==="run"){let te=W.batchData.map((I,K)=>I!=null&&I.length>0?I.at(-1):W.prevData[K]);A.set(S,te);let z=W.batchData.map(I=>I!=null?[...I]:void 0);E.set(S,z),i&&C({type:"derived",path:G,dep_values:te,dep_batches:z,...R()})}})},U=S=>{let G=N.get(S),W=A.get(S);if(!o||W==null)return{};let z=(G!=null&&G>=0&&S instanceof H?S._deps[G]:void 0)?.node,I=z?.v,K=E.get(S);return{trigger_dep_index:G,trigger_dep_name:z?.name,...I!=null?{trigger_version:{id:I.id,version:I.version}}:{},dep_values:[...W],...K!=null?{dep_batches:K}:{}}},Z=[],O=[];for(let[S,G]of e){let W=$(G,S);W&&Z.push(W),O.push(G.subscribe(te=>{k++;for(let z of te){let I=z[0],K=R();if(I===J){c[S]=z[1];let xe=G instanceof H?G.lastMutation?.actor??pe:pe;C({type:"data",path:S,data:z[1],actor:xe,...K,...U(G)})}else if(a)I===oe?w++:I===ie?v++:I===ne?y++:I===ae?x++:I===ue?T++:I===X?g++:I===re&&!m.has(S)?b=!0:I===V&&(_=!0,m.add(S));else if(I===oe)w++,C({type:"dirty",path:S,...K});else if(I===ie)v++,C({type:"resolved",path:S,...K,...U(G)});else if(I===ne)y++,C({type:"invalidate",path:S,...K});else if(I===ae)x++,C({type:"pause",path:S,lockId:z[1],...K});else if(I===ue)T++,C({type:"resume",path:S,lockId:z[1],...K});else if(I===re)m.has(S)||(b=!0),C({type:"complete",path:S,...K});else if(I===V){_=!0,m.add(S);let xe=G instanceof H?G.lastMutation?.actor??pe:pe;C({type:"error",path:S,data:z[1],actor:xe,...K})}else I===X&&(g++,C({type:"teardown",path:S,...K}))}}))}let M=!1,D=()=>{if(!M){M=!0;for(let S of O)S();for(let S of Z)S();for(let S of L)S({value:void 0,done:!0});L.length=0}},q=[],L=[];h.add(S=>{let G=L.shift();G?G({value:S,done:!1}):q.push(S)});let F={get values(){return c},get dirtyCount(){return w},get resolvedCount(){return v},get invalidateCount(){return y},get pauseCount(){return x},get resumeCount(){return T},get teardownCount(){return g},get events(){return f?f.toArray():[...p]},get anyCompletedCleanly(){return b},get anyErrored(){return _},get completedWithoutErrors(){return b&&!_},onEvent(S){return h.add(S),()=>h.delete(S)},dispose:D,expand(S){D();let G={...n};return typeof S=="string"?G.detail=S:Object.assign(G,S),r(rn(G))},[Symbol.asyncIterator](){return{next(){return q.length>0?Promise.resolve({value:q.shift(),done:!1}):M?Promise.resolve({value:void 0,done:!0}):new Promise(S=>L.push(S))},return(){return D(),Promise.resolve({value:void 0,done:!0})}}}};return n.format!=null&&this._attachFormatLogger(F,n),F}_attachFormatLogger(e,n){let r=n.format;if(r==null)return;let s=n.logger??(c=>console.log(c)),o=n.includeTypes?new Set(n.includeTypes):null,i=n.excludeTypes?new Set(n.excludeTypes):null,a=o==null&&i==null?()=>!0:c=>(o==null||o.has(c))&&(i==null||!i.has(c)),u=vr(n.theme),l=r==="stage-log"?ge():0,d=c=>c==null?"":n.stageLabels?.[c]??c,f=(c,m)=>c.length>m?`${c.slice(0,m-1)}\u2026`:c,p=c=>c.type==="data"||c.type==="error"?f(Je(c.data),120):"",h=c=>{if(r==="stage-log"){let _=(ge()-l)/1e9,k=d(c.path).padEnd(9);if(c.type==="data"){let N=p(c);return`[${_.toFixed(3)}s] ${k} \u2190${N?` ${N}`:""}`}if(c.type==="error"){let N=p(c);return`[${_.toFixed(3)}s] ${k} \u2717${N?` ${N}`:""}`}return c.type==="complete"?`[${_.toFixed(3)}s] ${k} \u25A0 complete`:`[${_.toFixed(3)}s] ${k} ${c.type}`}if(r==="json")try{return JSON.stringify(c)}catch{return JSON.stringify({type:c.type,path:c.path,data:"[unserializable]"})}let m=u[c.type]??"",w=c.path?`${u.path}${c.path}${u.reset} `:"",v=c.type==="data"||c.type==="error",y=c.type==="pause"||c.type==="resume",x=v?` ${Je(c.data)}`:y?` ${Je(c.lockId)}`:"",T=c.type==="data"||c.type==="resolved"||c.type==="derived"?c:void 0,g=T?.trigger_dep_name!=null?` <- ${T.trigger_dep_name}`:T?.trigger_dep_index!=null?` <- #${T.trigger_dep_index}`:"",b=c.in_batch?" [batch]":"";return`${w}${m}${c.type.toUpperCase()}${u.reset}${x}${g}${b}`};e.onEvent(c=>{a(c.type)&&s(h(c),c)})}addDisposer(e){return this._disposers.add(e),()=>{this._disposers.delete(e)}}destroy(){tn(this._disposers,this.name),this.signal([[X]],{internal:!0}),tn(this._storageDisposers,this.name);for(let e of[...this._mounts.values()])e._parent=void 0,e._destroyClearOnly();this._mounts.clear(),this._nodes.clear(),this._parent=void 0,this._destroyed=!0}get destroyed(){return this._destroyed}_destroyClearOnly(){for(let e of[...this._mounts.values()])e._parent=void 0,e._destroyClearOnly();this._mounts.clear(),this._nodes.clear(),this._parent=void 0,this._destroyed=!0}snapshot(e){let{expand:n,...r}=this.describe({detail:"full"}),s={};for(let a of Object.keys(r.nodes).sort()){let{lastMutation:u,guard:l,...d}=r.nodes[a];s[a]=d}let o=[...r.subgraphs].sort(),i={...r,version:1,nodes:s,subgraphs:o};if(e?.format==null)return i;if(e.format==="json-string")return JSON.stringify(i);if(e.format==="bytes"){if(e.codec==null)throw new Error("snapshot({format: 'bytes'}) requires a `codec` name");let a=this.config.lookupCodec(e.codec);if(a==null)throw new Error(`snapshot: codec "${e.codec}" is not registered on this graph's config. Call config.registerCodec(...) before creating nodes.`);return wt(a,a.encode(i))}throw new Error(`snapshot: unknown format "${String(e.format)}"`)}static decode(e,n){let r=n?.config??be,{codec:s,codecVersion:o,payload:i}=_t(e,r);return s.decode(i,o)}restore(e,n){if(nn(e),e.name!==this.name)throw new Error(`Graph "${this.name}": restore snapshot name "${e.name}" does not match this graph`);let r=n?.only==null?null:(Array.isArray(n.only)?n.only:[n.only]).map(o=>Ye(o)),s=n?.includeProducers===!0;for(let o of Object.keys(e.nodes).sort()){if(r!==null&&!r.some(a=>a.test(o)))continue;let i=e.nodes[o];if(i!==void 0){if(!("value"in i)||i.value===void 0){"value"in i&&i.value===void 0&&n?.onError?.(o,new Error(`restore: slice.value is undefined for "${o}" (undefined is the global SENTINEL; not valid DATA)`));continue}if(!(i.type==="derived"||i.type==="effect")&&!(i.type==="producer"&&!s)){if(i.v!=null){let u=this.tryResolve(o)?.v;if(u!=null&&u.id===i.v.id&&u.version===i.v.version)continue}try{this.set(o,i.value)}catch(a){n?.onError?.(o,a)}}}}}static fromSnapshot(e,n){nn(e);let r=typeof n=="function"?n:n?.build,s=typeof n=="function"?void 0:n?.factories,o=new t(e.name);if(r)return r(o),o.restore(e),o;for(let h of[...e.subgraphs].sort((c,m)=>{let w=c.split(P).length,v=m.split(P).length;return w!==v?w-v:c<m?-1:c>m?1:0})){let c=h.split(P),m=o;for(let w of c)m._mounts.has(w)||m.mount(w,new t(w)),m=m._mounts.get(w)}let i=s?Object.entries(s).map(([h,c])=>({re:Ye(h),factory:c})):[],a=h=>{for(let c of i)if(c.re.test(h))return c.factory},u=h=>{let c=h.split(P),m=c.pop();if(m==null||m.length===0)throw new Error(`invalid snapshot path "${h}"`);let w=o;for(let v of c){let y=w._mounts.get(v);if(!y)throw new Error(`unknown mount "${v}" in path "${h}"`);w=y}return[w,m]},l=Object.entries(e.nodes).filter(([h])=>!h.includes(`${P}${se}${P}`)).sort((h,c)=>h[0]<c[0]?-1:h[0]>c[0]?1:0),d=new Map(l),f=new Map,p=!0;for(;d.size>0&&p;){p=!1;for(let[h,c]of[...d.entries()]){let m=c?.deps??[];if(!m.every(g=>f.has(g)))continue;let[w,v]=u(h),y={...c?.meta??{}},x=a(h),T;if(c?.type==="state")T=Y(c.value,{meta:y});else{if(x==null)continue;T=x(v,{path:h,type:c.type,value:c.value,meta:y,deps:m,resolvedDeps:m.map(g=>f.get(g))})}w.add(T,{name:v}),f.set(h,T),d.delete(h),p=!0}}if(d.size>0){let h=[...d.keys()].sort().join(", ");throw new Error(`Graph.fromSnapshot could not reconstruct nodes without build callback: ${h}. Pass matching factories via fromSnapshot(data, { factories: { pattern: factoryFn } }).`)}return o.restore(e),o}toJSON(){return this.snapshot()}attachSnapshotStorage(e,n={}){let r=e.map(l=>({tier:l,debounceMs:Math.max(0,l.debounceMs??0),compactEvery:Math.max(1,l.compactEvery??10),timer:void 0,seq:0,lastSnapshot:void 0,lastFingerprint:"",disposed:!1,savePending:void 0}));n.autoRestore===!0&&this._cascadeRestore(e,n.onError);let s=(l,d)=>{if(l.disposed)return;let f=ir(d.nodes);if(l.lastSnapshot!=null&&f!==""&&f===l.lastFingerprint)return;let p=l.seq+1,h=Pe(),w=l.lastSnapshot==null||p%l.compactEvery===0?{name:this.name,mode:"full",snapshot:d,seq:p,timestamp_ns:h,format_version:ve}:{name:this.name,mode:"diff",diff:Tr(l.lastSnapshot,d),seq:p,timestamp_ns:h,format_version:ve};if(l.tier.filter&&!l.tier.filter(w))return;let v;try{v=l.tier.save(w)}catch(y){n.onError?.(y,l.tier);return}if(v&&typeof v.then=="function"){let T=(l.savePending??Promise.resolve()).then(()=>v,()=>v).then(()=>{l.disposed||(l.seq=p,l.lastSnapshot=d,l.lastFingerprint=f)},g=>{n.onError?.(g,l.tier)});l.savePending=T.finally(()=>{l.savePending===T&&(l.savePending=void 0)})}else l.seq=p,l.lastSnapshot=d,l.lastFingerprint=f},o=(l,d)=>{try{s(l,d)}catch(f){n.onError?.(f,l.tier)}},i=(l,d)=>{if(!d.some(c=>{let m=this.config.messageTier(c[0]);return m>=3&&m<5}))return;if(n.filter){let c=this.tryResolve(l);if(c==null)return;let m=Ne(c,ye("standard"));if(!n.filter(l,m))return}let p,h=()=>(p==null&&(p=this.snapshot()),p);for(let c of r)c.disposed||(c.debounceMs===0?o(c,h()):(c.timer==null&&(c.timer=new Ve),c.timer.start(c.debounceMs,()=>{c.disposed||o(c,this.snapshot())})))},a;if(n.paths!=null){let d=(typeof n.paths=="string"?this._pathsMatching(n.paths):n.paths).map(f=>{let p=this.tryResolve(f);return p==null?()=>{}:p.subscribe(h=>i(f,h))});a=()=>{for(let f of d)f()}}else a=this.observe().subscribe((l,d)=>i(l,d));let u=()=>{a();for(let l of r)l.disposed=!0,l.timer?.cancel();this._storageDisposers.delete(u)};return this._storageDisposers.add(u),{dispose:u}}async _cascadeRestore(e,n){for(let r of e){let s;try{s=await r.load?.()}catch(i){n?.(i,r);continue}if(s==null||typeof s!="object"||Array.isArray(s))continue;let o=s;try{if(o.mode==="full"&&o.snapshot!=null)return this.restore(o.snapshot),!0;if(o.version===ve&&o.nodes!=null)return this.restore(o),!0}catch(i){n?.(i,r)}}return!1}static async fromStorage(e,n,r){for(let s of n){let o;try{o=await s.load?.()}catch(u){r?.onError?.(u,s);continue}if(o==null||typeof o!="object"||Array.isArray(o))continue;let i=o,a=i.mode==="full"&&i.snapshot!=null?i.snapshot:i.version===ve&&i.nodes!=null?i:void 0;if(a!=null)try{return t.fromSnapshot(a,r)}catch(u){r?.onError?.(u,s)}}throw new Error(`Graph.fromStorage: no tier held a restorable record for "${e}" across ${n.length} tier(s)`)}_annotations=new Map;_traceRing;trace(e,n,r){if(e!=null&&n!=null){if(this.tryResolve(e)==null)return;if(this._annotations.set(e,n),this.config.inspectorEnabled){let s={path:e,annotation:n,timestamp_ns:ge(),...r?.actor!=null?{actor:r.actor}:{}};this._traceRing.push(s)}return}return e!=null?this.config.inspectorEnabled?this._annotations.get(e):void 0:this.config.inspectorEnabled?this._traceRing.toArray():[]}annotation(e){return this._annotations.get(e)}clearTrace(){this._annotations.clear(),this._traceRing.clear()}pruneTrace(e){let n=this._traceRing.toArray().filter(s=>!e(s)),r=this._traceRing.size-n.length;this._traceRing.clear();for(let s of n)this._traceRing.push(s);return r}static diff(e,n){let r=new Set(Object.keys(e.nodes)),s=new Set(Object.keys(n.nodes)),o=[...s].filter(y=>!r.has(y)).sort(),i=[...r].filter(y=>!s.has(y)).sort(),a=[],u=[];for(let y of r){if(!s.has(y))continue;let x=e.nodes[y],T=n.nodes[y],g=x.v,b=T.v;g!=null&&b!=null&&g.id===b.id&&g.version!==b.version&&u.push({path:y,id:g.id,from:g.version,to:b.version});let _=g!=null&&b!=null&&g.id===b.id&&g.version===b.version;for(let k of["type","status","sentinel"]){let N=x[k],A=T[k];N!==A&&a.push({path:y,field:k,from:N,to:A})}if(!_)for(let k of["value","meta"]){let N=x[k],A=T[k];ar(N,A)||a.push({path:y,field:k,from:N,to:A})}}let l=y=>`${y.from} ${y.to}`,d=new Set(e.edges.map(l)),f=new Set(n.edges.map(l)),p=n.edges.filter(y=>!d.has(l(y))),h=e.edges.filter(y=>!f.has(l(y))),c=new Set(e.subgraphs),m=new Set(n.subgraphs),w=[...m].filter(y=>!c.has(y)).sort(),v=[...c].filter(y=>!m.has(y)).sort();return{nodesAdded:o,nodesRemoved:i,nodesChanged:a,versionChanges:u,edgesAdded:p,edgesRemoved:h,subgraphsAdded:w,subgraphsRemoved:v}}};function Tr(t,e){let n=Re.diff(t,e),r={};for(let s of n.nodesAdded){let o=e.nodes[s];o!=null&&(r[s]=o)}return{...n,nodesAddedFull:r}}function sn(t,e,n,r={}){let s={paths:[],depths:new Map,truncated:!1};if(!e)return r.withDetail?s:[];if(!r.both&&n!=="upstream"&&n!=="downstream")throw new Error('reachable: direction must be "upstream" or "downstream"');let o=r.maxDepth;if(o!=null&&(!Number.isInteger(o)||o<0))throw new Error("reachable: maxDepth must be an integer >= 0");if(o===0)return r.withDetail?s:[];let i=new Map,a=new Map,u=new Map,l=new Map,d=new Set;for(let[x,T]of Object.entries(t.nodes)){if(!x)continue;d.add(x);let g=T.deps??[];i.set(x,g);for(let b of g)b&&(d.add(b),a.has(b)||a.set(b,new Set),a.get(b).add(x))}for(let x of t.edges){if(x==null||typeof x!="object")continue;let T=typeof x.from=="string"?x.from:"",g=typeof x.to=="string"?x.to:"";!T||!g||(d.add(T),d.add(g),l.has(T)||l.set(T,new Set),l.get(T).add(g),u.has(g)||u.set(g,new Set),u.get(g).add(T))}if(!d.has(e))return r.withDetail?s:[];let f=r.both===!0,p=x=>{if(f){let _=i.get(x)??[],k=u.get(x),N=a.get(x),A=l.get(x),E=[..._];return k&&E.push(...k),N&&E.push(...N),A&&E.push(...A),E}if(n==="upstream"){let _=i.get(x)??[],k=u.get(x);return k?[..._,...k]:_}let T=a.get(x),g=l.get(x),b=T?[...T]:[];return g&&b.push(...g),b},h=new Set([e]),c=new Map,m=[{path:e,depth:0}],w=0,v=!1;for(;w<m.length;){let x=m[w++];if(o!=null&&x.depth>=o){p(x.path).length>0&&(v=!0);continue}for(let T of p(x.path))!T||h.has(T)||(h.add(T),c.set(T,x.depth+1),m.push({path:T,depth:x.depth+1}))}let y=[...c.keys()].sort((x,T)=>x<T?-1:x>T?1:0);return r.withDetail?{paths:y,depths:c,truncated:v}:y}function kr(t,e){if(t.length!==e.length)return!1;for(let n=0;n<t.length;n++){let r=t[n],s=e[n];if(r.path!==s.path||r.type!==s.type||r.status!==s.status||r.hop!==s.hop||r.dep_index!==s.dep_index||r.annotation!==s.annotation||r.value!==s.value||r.lastMutation!==s.lastMutation)return!1;let o=r.v,i=s.v;if(o!==i&&(o==null||i==null||o.id!==i.id||o.version!==i.version))return!1}return!0}function Sr(t){for(let e of t){let n=e.codePointAt(0);if(n>=19968&&n<=40959||n>=13312&&n<=19903||n>=12288&&n<=12351||n>=12352&&n<=12447||n>=12448&&n<=12543||n>=44032&&n<=55215||n>=65280&&n<=65519)return!0}return!1}var dn=new Set(["\uFF0C","\uFF0E","\uFF01","\uFF1A","\uFF1B","\uFF1F","\u3001","\u3002","\u30FB","\uFF09","\u3015","\u3009","\u300B","\u300D","\u300F","\u3011"]),Or=new Set([".",",","!","?",":",";",")","]","}","%",'"',"\u201D","\u2019","\xBB","\u203A","\u2026"]);function Nr(t){return t.replace(/[\t\n\r\f ]+/g," ").replace(/^ | $/g,"")}function Er(t){let e=new Intl.Segmenter(void 0,{granularity:"word"}),n=[];for(let r of e.segment(t)){let s=r.segment,o=r.isWordLike??!1,i=[],a=[],u=[],l="",d=null;for(let f of s){let p;f===" "?p="space":f==="\u200B"?p="zero-width-break":f==="\xAD"?p="soft-hyphen":f===`
8
- `?p="hard-break":p="text",d!==null&&p===d?l+=f:(d!==null&&(i.push(l),a.push(d==="text"&&o),u.push(d)),l=f,d=p)}d!==null&&(i.push(l),a.push(d==="text"&&o),u.push(d)),n.push({texts:i,isWordLike:a,kinds:u})}return n}function bt(t,e,n,r,s){let o=Nr(t);if(o.length===0)return[];let i=Er(o),a=new Intl.Segmenter(void 0,{granularity:"grapheme"}),u=[],l=[],d=[];for(let v of i)for(let y=0;y<v.texts.length;y++)u.push(v.texts[y]),l.push(v.kinds[y]),d.push(v.isWordLike[y]);let f=[],p=[],h=[];for(let v=0;v<u.length;v++){let y=u[v],x=l[v],T=d[v];if(x==="text"&&!T&&f.length>0&&p[p.length-1]==="text"&&y.length===1&&(Or.has(y)||dn.has(y))){f[f.length-1]+=y;continue}if(y==="-"&&f.length>0&&p[p.length-1]==="text"&&h[h.length-1]){f[f.length-1]+=y;continue}f.push(y),p.push(x),h.push(T)}let c=r.get(e);c||(c=new Map,r.set(e,c));function m(v){let y=c.get(v);if(y===void 0){s&&(s.misses+=1);let x=n.measureSegment(v,e).width;y=Number.isFinite(x)&&x>=0?x:0,c.set(v,y)}else s&&(s.hits+=1);return y}let w=[];for(let v=0;v<f.length;v++){let y=f[v],x=p[v];if(x!=="text"){w.push({text:y,width:x==="space"?m(" ")*y.length:0,kind:x,graphemeWidths:null});continue}if(Sr(y)){let b="";for(let _ of a.segment(y)){let k=_.segment;if(b.length>0&&dn.has(k)){b+=k;continue}if(b.length>0){let N=m(b);w.push({text:b,width:N,kind:"text",graphemeWidths:null})}b=k}if(b.length>0){let _=m(b);w.push({text:b,width:_,kind:"text",graphemeWidths:null})}continue}let T=m(y),g=null;if(h[v]&&y.length>1){let b=[];for(let _ of a.segment(y))b.push(m(_.segment));b.length>1&&(g=b)}w.push({text:y,width:T,kind:"text",graphemeWidths:g})}return w}function yt(t,e,n,r,s){if(t.length===0)return{lines:[],lineCount:0};let o=[],i=0,a=!1,u=0,l=0,d=0,f=0,p=-1,h=0,c=s.get(r);c||(c=new Map,s.set(r,c));let m=c.get("-");m===void 0&&(m=n.measureSegment("-",r).width,c.set("-",m));function w(g=d,b=f,_=i){let k="";for(let N=u;N<g;N++){let A=t[N];if(!(A.kind==="soft-hyphen"||A.kind==="hard-break"))if(N===u&&l>0&&A.graphemeWidths){let C=[...new Intl.Segmenter(void 0,{granularity:"grapheme"}).segment(A.text)].map(R=>R.segment);k+=C.slice(l).join("")}else k+=A.text}if(b>0&&g<t.length){let N=t[g],E=[...new Intl.Segmenter(void 0,{granularity:"grapheme"}).segment(N.text)].map(R=>R.segment),C=u===g?l:0;k+=E.slice(C,b).join("")}g>0&&t[g-1]?.kind==="soft-hyphen"&&!(u===g&&l>0)&&(k+="-"),o.push({text:k,width:_,startSegment:u,startGrapheme:l,endSegment:g,endGrapheme:b}),i=0,a=!1,p=-1,h=0}function v(g){return g==="space"||g==="zero-width-break"||g==="soft-hyphen"}function y(g,b,_){a=!0,u=g,l=b,d=g+1,f=0,i=_}function x(g,b,_){a=!0,u=g,l=b,d=g,f=b+1,i=_}for(let g=0;g<t.length;g++){let b=t[g];if(b.kind==="hard-break"){a?w():o.push({text:"",width:0,startSegment:g,startGrapheme:0,endSegment:g,endGrapheme:0}),u=g+1,l=0;continue}let _=b.width;if(!a){_>e&&b.graphemeWidths?T(g,0,b.graphemeWidths):y(g,0,_),v(b.kind)&&(p=g+1,h=b.kind==="space"?i-_:i);continue}let k=i+_;if(k>e+.005){if(v(b.kind)){i+=_,d=g+1,f=0,w(g+1,0,b.kind==="space"?i-_:i);continue}if(p>=0){w(p,0,h),g--;continue}if(_>e&&b.graphemeWidths){w(),T(g,0,b.graphemeWidths);continue}w(),g--;continue}i=k,d=g+1,f=0,v(b.kind)&&(p=g+1,h=b.kind==="space"?i-_:i)}return a&&w(),{lines:o,lineCount:o.length};function T(g,b,_){for(let k=b;k<_.length;k++){let N=_[k];if(!a){x(g,k,N);continue}i+N>e+.005?(w(),x(g,k,N)):(i+=N,d=g,f=k+1)}a&&d===g&&f===_.length&&(d=g+1,f=0)}}function Ce(t){return Math.max(0,Math.min(1,t))}function Rr(t){let e=Ce(t?.mainRatio??.65),n=Ce(t?.sideSplit??.5),r=Math.max(0,t?.viewportWidth??1280),s=t?.nodeRegistry??new Map,o=t?.adapter??null,i=t?.layoutFont??"14px monospace",a=t?.onHighlight,u=new Re("demo-shell"),l=Y(e,{name:"pane/main-ratio"}),d=Y(n,{name:"pane/side-split"}),f=Y(null,{name:"pane/fullscreen"}),p=Y(r,{name:"viewport/width"});u.add(l,{name:"pane/main-ratio"}),u.add(d,{name:"pane/side-split"}),u.add(f,{name:"pane/fullscreen"}),u.add(p,{name:"viewport/width"});let h=j([l,p,f],([O,M,D])=>{let q=O,L=M,F=D;return F==="main"?L:F==="graph"||F==="code"?0:Math.round(L*q)},{name:"pane/main-width"}),c=j([h,p,f],([O,M,D])=>{let q=D,L=M;return q==="main"?0:q==="graph"||q==="code"?L:L-O},{name:"pane/side-width"}),m=j([d,f],([O,M])=>{let D=M;return D==="graph"?1:D==="code"||D==="main"?0:Ce(O)},{name:"pane/graph-height-ratio"}),w=j([m,f],([O,M])=>{let D=M;return D==="code"?1:D==="graph"||D==="main"?0:1-O},{name:"pane/code-height-ratio"});u.add(h,{name:"pane/main-width"}),u.add(c,{name:"pane/side-width"}),u.add(m,{name:"pane/graph-height-ratio"}),u.add(w,{name:"pane/code-height-ratio"});let v=Y(null,{name:"demo/graph-ref"}),y=Y(0,{name:"demo/graph-tick"});u.add(v,{name:"demo/graph-ref"}),u.add(y,{name:"demo/graph-tick"});let x=j([v,y],([O,M])=>{let D=O;return D?D.describe({format:"mermaid"}):""},{name:"graph/mermaid"}),T=j([v,y],([O,M])=>{let D=O;if(!D)return null;let{expand:q,...L}=D.describe({detail:"standard"});return L},{name:"graph/describe"});u.add(x,{name:"graph/mermaid"}),u.add(T,{name:"graph/describe"});let g=Y(null,{name:"hover/target"});u.add(g,{name:"hover/target"});let b=j([g],([O])=>{let M=O;if(!M)return null;let D=s.get(M.id);return D?D.codeLine:null},{name:"highlight/code-scroll"}),_=j([g],([O])=>{let M=O;if(!M)return null;let D=s.get(M.id);return D?D.visualSelector:null},{name:"highlight/visual"}),k=j([g],([O])=>{let M=O;return M?M.id:null},{name:"highlight/graph"});if(u.add(b,{name:"highlight/code-scroll"}),u.add(_,{name:"highlight/visual"}),u.add(k,{name:"highlight/graph"}),a?.codeScroll){let O=a.codeScroll,M=Be([b],([D])=>{O(D)});u.add(M,{name:"highlight/apply-code-scroll"})}if(a?.visual){let O=a.visual,M=Be([_],([D])=>{O(D)});u.add(M,{name:"highlight/apply-visual"})}if(a?.graph){let O=a.graph,M=Be([k],([D])=>{O(D)});u.add(M,{name:"highlight/apply-graph"})}let N=Y(null,{name:"inspect/selected-node"});u.add(N,{name:"inspect/selected-node"});let A=ye("standard"),E=j([N,v,y],([O,M,D])=>{let q=M,L=O;if(!q||!L)return null;try{let F=q.resolve(L),S=Ne(F,A);return{path:L,...S,value:F.cache}}catch{return null}},{name:"inspect/node-detail"}),C=j([v,y],([O,M])=>{let D=O;return D?D.trace():[]},{name:"inspect/trace-log"});u.add(E,{name:"inspect/node-detail"}),u.add(C,{name:"inspect/trace-log"});let R=Y(!1,{name:"meta/debug"});u.add(R,{name:"meta/debug"});let $=j([R,y],([O,M])=>O?u.describe({format:"mermaid"}):"",{name:"meta/shell-mermaid"});u.add($,{name:"meta/shell-mermaid"});let U=Y("",{name:"layout/code-text"});if(u.add(U,{name:"layout/code-text"}),o){let O=new Map,M=j([T],([L])=>{let F=L;if(!F)return new Map;let S=new Map;for(let[G]of Object.entries(F.nodes)){let W=bt(G,i,o,O),te=yt(W,1/0,o,i,O),z=te.lines.reduce((K,xe)=>Math.max(K,xe.width),0),I=te.lineCount*20;S.set(G,{width:z,height:I})}return S},{name:"layout/graph-labels",equals:(L,F)=>{if(L===F)return!0;let S=L,G=F;if(S.size!==G.size)return!1;for(let[W,te]of S){let z=G.get(W);if(!z||z.width!==te.width||z.height!==te.height)return!1}return!0}}),D=j([U,c],([L,F])=>{let S=L;if(!S)return{lineCount:0,lines:[]};let G=bt(S,i,o,O),W=F-40;return yt(G,Math.max(100,W),o,i,O)},{name:"layout/code-lines"}),q=j([M],([L])=>{let F=L;if(F.size===0)return 200;let S=0;for(let{width:G}of F.values())G>S&&(S=G);return Math.max(200,Math.round(S+80))},{name:"layout/side-width-hint"});u.add(M,{name:"layout/graph-labels"}),u.add(D,{name:"layout/code-lines"}),u.add(q,{name:"layout/side-width-hint"})}let Z=0;return{graph:u,setMainRatio(O){u.set("pane/main-ratio",Ce(O))},setSideSplit(O){u.set("pane/side-split",Ce(O))},setFullscreen(O){u.set("pane/fullscreen",O)},setViewportWidth(O){u.set("viewport/width",Math.max(0,O))},setHoverTarget(O){u.set("hover/target",O)},setDemoGraph(O){u.set("demo/graph-ref",O)},bumpGraphTick(){u.set("demo/graph-tick",++Z)},selectNode(O){u.set("inspect/selected-node",O)},setMetaDebug(O){u.set("meta/debug",O)},setCodeText(O){u.set("layout/code-text",O)},batch(O){Ae(O)},destroy(){u.destroy()}}}0&&(module.exports={demoShell});
1
+ "use strict";var Xe=Object.defineProperty;var fn=Object.getOwnPropertyDescriptor;var hn=Object.getOwnPropertyNames;var pn=Object.prototype.hasOwnProperty;var Q=(t,e)=>()=>(t&&(e=t(t=0)),e);var gn=(t,e)=>{for(var n in e)Xe(t,n,{get:e[n],enumerable:!0})},mn=(t,e,n,r)=>{if(e&&typeof e=="object"||typeof e=="function")for(let s of hn(e))!pn.call(t,s)&&s!==n&&Xe(t,s,{get:()=>e[s],enumerable:!(r=fn(e,s))||r.enumerable});return t};var bn=t=>mn(Xe({},"__esModule",{value:!0}),t);function Ae(){return fe>0||we}function vt(){return fe>0}function Te(t){fe>0?_e.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(!we){let n=_e.splice(0);for(let r of n)try{r()}catch{}de.length=0,ce.length=0,he.length=0}}else yn()}}function yn(){let t=!we;t&&(we=!0);let e=[],n=0;try{for(;de.length>0||ce.length>0||he.length>0||t&&_e.length>0;){if(t&&_e.length>0){let o=_e.splice(0);for(let i of o)try{i()}catch(a){e.push(a)}continue}if(n+=1,n>1e3)throw de.length=0,ce.length=0,he.length=0,new Error("batch drain exceeded 1000 iterations \u2014 likely a reactive cycle");let s=(de.length>0?de:ce.length>0?ce:he).splice(0);for(let o of s)try{o()}catch(i){e.push(i)}}}finally{t&&(we=!1)}if(e.length===1)throw e[0];if(e.length>1)throw new AggregateError(e,"batch drain: multiple callbacks threw")}function Me(t,e,n){if(e.length===0)return;if(e.length===1){let l=n(e[0][0]);if(l<3||!Ae()){t(e);return}(l>=5?he:l===4?ce:de).push(()=>t(e));return}let r=e.length,s=r,o=r,i=r,a=0;for(;a<r&&n(e[a][0])<3;)a++;for(s=a;a<r&&n(e[a][0])===3;)a++;for(o=a;a<r&&n(e[a][0])===4;)a++;i=a;let u=Ae();if(s>0){let l=e.slice(0,s);t(l)}if(o>s){let l=e.slice(s,o);u?de.push(()=>t(l)):t(l)}if(i>o){let l=e.slice(o,i);u?ce.push(()=>t(l)):t(l)}if(r>i){let l=e.slice(i,r);u?he.push(()=>t(l)):t(l)}}var fe,we,de,ce,he,_e,Ge=Q(()=>{"use strict";fe=0,we=!1,de=[],ce=[],he=[],_e=[]});function Ze(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 ee,vn,Ie=Q(()=>{"use strict";ee=class extends Error{actor;action;nodeName;constructor(e,n){super(n??`GuardDenied: action "${String(e.action)}" denied for actor type "${String(e.actor.type)}"`),this.name="GuardDenied",this.actor=e.actor,this.action=e.action,this.nodeName=e.nodeName}get node(){return this.nodeName}},vn=["human","llm","wallet","system"]});function wt(t,e){let n=new TextEncoder().encode(t.name);if(n.length===0||n.length>255)throw new Error(`encodeEnvelope: codec name "${t.name}" encodes to ${n.length} bytes (must be 1\u2013255)`);let r=t.version;if(!Number.isInteger(r)||r<0||r>65535)throw new Error(`encodeEnvelope: codec.version ${r} out of u16 range (expected integer 0\u201365535)`);let s=2+n.length+2+e.length;if(s>4294967295)throw new Error(`encodeEnvelope: total envelope size ${s} exceeds 2^32-1 bytes (payload ${e.length} bytes)`);let o=new Uint8Array(s),i=0;return o[i++]=Qe,o[i++]=n.length,o.set(n,i),i+=n.length,o[i++]=r>>>8&255,o[i++]=r&255,o.set(e,i),o}function _t(t,e){if(t.length<xt)throw new Error(`decodeEnvelope: bytes too short (${t.length} < ${xt})`);let n=0,r=t[n++];if(r!==Qe)throw new Error(`decodeEnvelope: unsupported envelope version ${r} (expected ${Qe})`);let s=t[n++];if(s===0)throw new Error("decodeEnvelope: name_len must be >= 1");if(n+s+2>t.length)throw new Error(`decodeEnvelope: envelope truncated (need ${n+s+2} bytes, have ${t.length})`);let o=new TextDecoder().decode(t.subarray(n,n+s));n+=s;let i=(t[n]<<8|t[n+1])>>>0;n+=2;let a=t.subarray(n),u=e.lookupCodec(o);if(u==null)throw new Error(`decodeEnvelope: codec "${o}" not registered (envelope codec_v=${i})`);return{codec:u,codecVersion:i,payload:a}}function Tt(t){t.registerCodec(xn)}var xn,Qe,xt,et=Q(()=>{"use strict";xn={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)}},Qe=1,xt=4});function Le(t){if(t==null)return pe;let{type:e,id:n,...r}=t;return{type:e??"system",id:n??"",...r}}var pe,tt=Q(()=>{"use strict";pe={type:"system",id:""}});function ge(){return Math.trunc(performance.now()*1e6)}function Pe(){return Date.now()*1e6}var nt=Q(()=>{"use strict"});var ke,Y,oe,ie,re,ae,ue,J,te,H,me,rt,wn,st,_n,Tn,ot,kt,St,Ot,it,$e=Q(()=>{"use strict";ke=Symbol.for("graphrefly/START"),Y=Symbol.for("graphrefly/DATA"),oe=Symbol.for("graphrefly/DIRTY"),ie=Symbol.for("graphrefly/RESOLVED"),re=Symbol.for("graphrefly/INVALIDATE"),ae=Symbol.for("graphrefly/PAUSE"),ue=Symbol.for("graphrefly/RESUME"),J=Symbol.for("graphrefly/TEARDOWN"),te=Symbol.for("graphrefly/COMPLETE"),H=Symbol.for("graphrefly/ERROR"),me=Object.freeze([oe]),rt=Object.freeze([ie]),wn=Object.freeze([re]),st=Object.freeze([ke]),_n=Object.freeze([te]),Tn=Object.freeze([J]),ot=Object.freeze([me]),kt=Object.freeze([rt]),St=Object.freeze([wn]),Ot=Object.freeze([_n]),it=Object.freeze([Tn])});function Nt(t){t.registerMessageType(ke,{tier:0,wireCrossing:!1}),t.registerMessageType(oe,{tier:1,wireCrossing:!1}),t.registerMessageType(re,{tier:1,wireCrossing:!1,metaPassthrough:!1}),t.registerMessageType(ae,{tier:2,wireCrossing:!1}),t.registerMessageType(ue,{tier:2,wireCrossing:!1}),t.registerMessageType(Y,{tier:3,wireCrossing:!0}),t.registerMessageType(ie,{tier:3,wireCrossing:!0}),t.registerMessageType(te,{tier:4,wireCrossing:!0,metaPassthrough:!1}),t.registerMessageType(H,{tier:4,wireCrossing:!0,metaPassthrough:!1}),t.registerMessageType(J,{tier:5,wireCrossing:!0,metaPassthrough:!1})}var Fe,Et=Q(()=>{"use strict";$e();Fe=class{_messageTypes=new Map;_codecs=new Map;_onMessage;_onSubscribe;_defaultVersioning;_defaultHashFn;_inspectorEnabled=!(typeof process<"u"&&process.env?.NODE_ENV==="production");_globalInspector;_rigorRecorder;_frozen=!1;tierOf;constructor(e){this._onMessage=e.onMessage,this._onSubscribe=e.onSubscribe,this._defaultVersioning=e.defaultVersioning,this._defaultHashFn=e.defaultHashFn,this.tierOf=n=>{let r=this._messageTypes.get(n);return r!=null?r.tier:1}}get onMessage(){return this._frozen=!0,this._onMessage}get onSubscribe(){return this._frozen=!0,this._onSubscribe}set onMessage(e){this._assertUnfrozen(),this._onMessage=e}set onSubscribe(e){this._assertUnfrozen(),this._onSubscribe=e}get defaultVersioning(){return this._defaultVersioning}set defaultVersioning(e){this._assertUnfrozen(),this._defaultVersioning=e}get defaultHashFn(){return this._defaultHashFn}set defaultHashFn(e){this._assertUnfrozen(),this._defaultHashFn=e}get inspectorEnabled(){return this._inspectorEnabled}set inspectorEnabled(e){this._inspectorEnabled=e}get globalInspector(){return this._globalInspector}set globalInspector(e){this._globalInspector=e}get rigorRecorder(){return this._rigorRecorder}set rigorRecorder(e){this._rigorRecorder=e}registerMessageType(e,n){return this._assertUnfrozen(),this._messageTypes.set(e,{tier:n.tier,wireCrossing:n.wireCrossing??n.tier>=3,metaPassthrough:n.metaPassthrough??!0}),this}messageTier(e){let n=this._messageTypes.get(e);return n!=null?n.tier:1}isWireCrossing(e){let n=this._messageTypes.get(e);return n!=null?n.wireCrossing:!0}isLocalOnly(e){return!this.isWireCrossing(e)}isMetaPassthrough(e){let n=this._messageTypes.get(e);return n!=null?n.metaPassthrough:!0}isKnownMessageType(e){return this._messageTypes.has(e)}registerCodec(e){return this._assertUnfrozen(),this._codecs.set(e.name,e),this}lookupCodec(e){return this._codecs.get(e)}_isFrozen(){return this._frozen}_assertUnfrozen(){if(this._frozen)throw new Error("GraphReFlyConfig is frozen: a node has already captured this config. Register custom types and set hooks before creating any node.")}}});function at(t){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(at);if(typeof t=="object"&&t!==null){let e={};for(let n of Object.keys(t).sort())e[n]=at(t[n]);return e}return null}function On(t){let e=Sn.encode(t),n=e.length,r=n*8,s=n+9+63&-64,o=new Uint8Array(s);o.set(e),o[n]=128;let i=new DataView(o.buffer);i.setUint32(s-4,r>>>0,!1),i.setUint32(s-8,Math.floor(r/4294967296)>>>0,!1);let a=1779033703,u=3144134277,l=1013904242,d=2773480762,f=1359893119,p=2600822924,h=528734635,c=1541459225,v=new Uint32Array(64),T=(g,y)=>g>>>y|g<<32-y;for(let g=0;g<s;g+=64){for(let E=0;E<16;E++)v[E]=i.getUint32(g+E*4,!1);for(let E=16;E<64;E++){let C=v[E-15],R=v[E-2],$=T(C,7)^T(C,18)^C>>>3,U=T(R,17)^T(R,19)^R>>>10;v[E]=v[E-16]+$+v[E-7]+U>>>0}let y=a,_=u,m=l,b=d,x=f,k=p,N=h,D=c;for(let E=0;E<64;E++){let C=T(x,6)^T(x,11)^T(x,25),R=x&k^~x&N,$=D+C+R+kn[E]+v[E]>>>0,U=T(y,2)^T(y,13)^T(y,22),Z=y&_^y&m^_&m,O=U+Z>>>0;D=N,N=k,k=x,x=b+$>>>0,b=m,m=_,_=y,y=$+O>>>0}a=a+y>>>0,u=u+_>>>0,l=l+m>>>0,d=d+b>>>0,f=f+x>>>0,p=p+k>>>0,h=h+N>>>0,c=c+D>>>0}let w=g=>g.toString(16).padStart(8,"0");return w(a)+w(u)+w(l)+w(d)+w(f)+w(p)+w(h)+w(c)}function ut(t){let e=at(t??null),n=JSON.stringify(e);return On(n).slice(0,16)}function Nn(){let t=globalThis.crypto;if(t?.randomUUID)return t.randomUUID();let e=()=>Math.floor(Math.random()*4294967296).toString(16).padStart(8,"0"),n=e()+e()+e()+e();return`${n.slice(0,8)}-${n.slice(8,12)}-4${n.slice(13,16)}-${(parseInt(n.slice(16,17),16)&3|8).toString(16)}${n.slice(17,20)}-${n.slice(20,32)}`}function lt(t,e,n){let r=n?.id??Nn();if(t===0)return{id:r,version:0};let o=(n?.hash??ut)(e);return{id:r,version:0,cid:o,prev:null}}function Rt(t,e,n){t.version+=1,"cid"in t&&(t.prev=t.cid,t.cid=n(e))}var kn,Sn,Ct=Q(()=>{"use strict";kn=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]),Sn=new TextEncoder});function Mt(t){return{node:t,unsub:null,prevData:void 0,dirty:!1,involvedThisWave:!1,dataBatch:[],terminal:void 0}}function dt(t){t.prevData=void 0,t.dirty=!1,t.involvedThisWave=!1,t.dataBatch.length=0,t.terminal=void 0}function He(t){return t.length===0?t:typeof t[0]=="symbol"?[t]:t}function Se(t,e,n){let r=Gt(t)?t:[],s=typeof t=="function"?t:typeof e=="function"?e:void 0,o={};return Gt(t)?o=(ct(e)?e:n)??{}:ct(t)?o=t:o=(ct(e)?e:n)??{},new B(r,s,o)}var At,Dt,En,Rn,be,B,Gt,ct,Oe=Q(()=>{"use strict";et();tt();Ge();nt();Et();Ie();$e();Ct();At=()=>{},Dt=100;En=(t,e,n,r)=>{n.direction==="down-in"&&t._onDepMessage(n.depIndex,e)},Rn=(t,e,n,r)=>{let s=t;if(s._status==="completed"||s._status==="errored")return;let o=s._cached,i=o===void 0?[st]:[st,[Y,o]];s._status==="dirty"&&i.push(me),Me(e,i,s._config.tierOf)},be=new Fe({onMessage:En,onSubscribe:Rn});Nt(be);Tt(be);B=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??be,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??ut;let s=r.versioning??this._config.defaultVersioning;this._versioningLevel=s,this._versioning=s!=null?lt(s,this._cached===void 0?void 0:this._cached,{id:r.versioningId,hash:this._hashFn}):void 0,this._deps=e.map(Mt);let o={};for(let[a,u]of Object.entries(r.meta??{})){let l={initial:u,name:`${r.name??"node"}:meta:${a}`,describeKind:"state",config:this._config};r.guard!=null&&(l.guard=r.guard),o[a]=new t([],void 0,l)}Object.freeze(o),this.meta=o,this._hasMeta=Object.keys(o).length>0;let i=this;this._actions={emit(a){i._emit([[Y,a]])},down(a){i._emit(He(a))},up(a){i._emitUp(He(a))}},this.down=this.down.bind(this),this.up=this.up.bind(this)}get _isTerminal(){return this._status==="completed"||this._status==="errored"}get name(){return this._optsName}get status(){return this._status}get cache(){return this._cached===void 0?void 0:this._cached}get lastMutation(){return this._lastMutation}get v(){return this._versioning}hasGuard(){return this._guard!=null}_applyVersioning(e,n){if(this._isExecutingFn)throw new Error(`Node "${this.name}": _applyVersioning cannot run mid-fn \u2014 call it outside of \`_execFn\` (typically at graph setup time before the first subscribe).`);let r=this._versioningLevel;if(r!=null&&e<=r)return;let s=n?.hash??this._hashFn;s!==this._hashFn&&(this._hashFn=s);let o=this._cached===void 0?void 0:this._cached,i=this._versioning,a=i?.id??n?.id,u=i?.version??0,l=lt(e,o,{id:a,hash:s});l.version=u,this._versioning=l,this._versioningLevel=e}_setInspectorHook(e){return e==null?()=>{}:(this._inspectorHooks==null&&(this._inspectorHooks=new Set),this._inspectorHooks.add(e),()=>{this._inspectorHooks?.delete(e),this._inspectorHooks?.size===0&&(this._inspectorHooks=void 0)})}_pushGuard(e){return this._extraGuards==null&&(this._extraGuards=new Set),this._extraGuards.add(e),()=>{this._extraGuards?.delete(e),this._extraGuards?.size===0&&(this._extraGuards=void 0)}}allowsObserve(e){if(this._guard==null&&this._extraGuards==null)return!0;let n=Le(e);if(this._guard!=null&&!this._guard(n,"observe"))return!1;if(this._extraGuards!=null){for(let r of this._extraGuards)if(!r(n,"observe"))return!1}return!0}_checkGuard(e){if(e?.internal)return;let n=this._guard!=null||this._extraGuards!=null,r=e?.actor!=null;if(!n&&!r)return;let s=Le(e?.actor),o=e?.delivery==="signal"?"signal":"write";if(this._guard!=null&&!this._guard(s,o))throw new ee({actor:s,action:o,nodeName:this.name});if(this._extraGuards!=null){for(let i of this._extraGuards)if(!i(s,o))throw new ee({actor:s,action:o,nodeName:this.name})}this._lastMutation={actor:s,timestamp_ns:Pe()}}down(e,n){let r=He(e);r.length!==0&&(this._checkGuard(n),this._emit(r))}emit(e,n){this._checkGuard(n),this._emit([[Y,e]])}up(e,n){if(this._deps.length===0)return;let r=He(e);if(r.length===0)return;this._checkGuard(n);let s=n??{internal:!0};this._validateUpTiers(r);for(let o of this._deps)o.node.up?.(r,s)}_emitUp(e){if(this._deps.length!==0&&e.length!==0){this._validateUpTiers(e);for(let n of this._deps)n.node.up?.(e,{internal:!0})}}_validateUpTiers(e){let n=this._config.tierOf;for(let r of e){let s=n(r[0]);if(s===3||s===4)throw new Error(`Node "${this.name}": tier-${s} messages cannot flow up \u2014 DATA/RESOLVED/COMPLETE/ERROR are downstream-only. Use \`down(...)\` for value delivery; \`up(...)\` is for control signals (DIRTY, INVALIDATE, PAUSE, RESUME, TEARDOWN).`)}}subscribe(e,n){if(n!=null&&this._guard!=null){let u=Le(n);if(!this._guard(u,"observe"))throw new ee({actor:u,action:"observe",nodeName:this.name})}let s=this._isTerminal&&this._resubscribable;if(s){this._cached=void 0,this._status="sentinel",this._store={},this._hasCalledFnOnce=!1,this._waveHasNewData=!1,this._hasNewTerminal=!1,this._paused=!1,this._pendingWave=!1,this._pendingRerun=!1,this._isExecutingFn=!1,this._rerunDepth=0,this._dirtyDepCount=0,this._pauseLocks=null,this._pauseBuffer=null;for(let u of this._deps)dt(u);if(this._partial===!1){for(let u of this._deps)if(u.prevData!==void 0||u.dataBatch.length!==0||u.terminal!==void 0||u.dirty)throw new Error(`resubscribable-reset invariant: DepRecord not fully reset for node ${this._optsName??"(anonymous)"}`)}}this._sinkCount+=1;let o;try{o=this._config.onSubscribe(this,e,{sinkCount:this._sinkCount,afterTerminalReset:s},this._actions)}catch(u){throw this._sinkCount-=1,u}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(u){if(this._sinkCount-=1,this._removeSink(e),this._sinkCount===0&&(this._status="sentinel"),typeof o=="function")try{o()}catch{}throw u}this._status==="sentinel"&&this._cached===void 0&&(this._status="pending");let a=!1;return()=>{a||(a=!0,this._sinkCount-=1,this._removeSink(e),typeof o=="function"&&o(),this._sinks==null&&this._deactivate())}}_removeSink(e){if(this._sinks===e)this._sinks=null;else if(this._sinks!=null&&typeof this._sinks!="function")if(this._sinks.delete(e),this._sinks.size===1){let[n]=this._sinks;this._sinks=n}else this._sinks.size===0&&(this._sinks=null)}_activate(){if(this._deps.length===0){this._fn&&this._execFn();return}this._dirtyDepCount=0;let e=this._deps.length,n=0;try{for(let r=0;r<e;r++){let s=r,o=this._deps[r];o.unsub=At,o.unsub=o.node.subscribe(i=>{if(o.unsub===null)return;let a=this._config.tierOf,u=!1;for(let l of i)a(l[0])>=3&&(u=!0),this._config.onMessage(this,l,{direction:"down-in",depIndex:s},this._actions);u&&this._maybeRunFnOnSettlement()}),n++}}catch(r){this._deps[n].unsub=null;for(let s=0;s<n;s++){let o=this._deps[s];if(o.unsub!=null){let i=o.unsub;o.unsub=null;try{i()}catch{}dt(o)}}throw this._dirtyDepCount=0,r}}_addDep(e){for(let s=0;s<this._deps.length;s++)if(this._deps[s].node===e)return s;let n=this._deps.length,r=Mt(e);if(this._deps.push(r),this._sinks==null)return n;r.dirty=!0,this._dirtyDepCount++,this._status!=="dirty"&&this._emit(ot),r.unsub=At;try{r.unsub=e.subscribe(s=>{if(r.unsub===null)return;let o=this._config.tierOf,i=!1;for(let a of s)o(a[0])>=3&&(i=!0),this._config.onMessage(this,a,{direction:"down-in",depIndex:n},this._actions);i&&this._maybeRunFnOnSettlement()})}catch(s){throw r.unsub=null,this._deps.pop(),this._dirtyDepCount--,s}return n}_deactivate(e=!1){let n=this._cleanup;if(this._cleanup=void 0,typeof n=="function")try{n()}catch(r){this._emit([[H,this._wrapFnError("cleanup threw",r)]])}else if(n!=null&&typeof n=="object"){let r=n.deactivate;if(typeof r=="function")try{r()}catch(s){this._emit([[H,this._wrapFnError("cleanup.deactivate threw",s)]])}}for(let r of this._deps){if(r.unsub!=null){let s=r.unsub;r.unsub=null;try{s()}catch{}}dt(r)}this._waveHasNewData=!1,this._hasNewTerminal=!1,this._hasCalledFnOnce=!1,this._paused=!1,this._pendingWave=!1,this._pendingRerun=!1,this._rerunDepth=0,this._store={},this._dirtyDepCount=0,this._pauseLocks=null,this._pauseBuffer=null,this._fn!=null&&(this._cached=void 0),e||(this._fn!=null||this._deps.length>0)&&(!this._isTerminal||this._resubscribable)&&(this._status="sentinel")}_onDepMessage(e,n){let r=this._deps[e],s=n[0];if(this._inspectorHooks!=null){let o={kind:"dep_message",depIndex:e,message:n};for(let i of this._inspectorHooks)i(o)}if(s!==ke){if(s===oe){this._depDirtied(r);return}if(s===re){if(this._depInvalidated(r),this._cached===void 0)return;this._emit(St);return}if(s===ae||s===ue){this._emit([n]);return}if(s===J){this._emit(it);return}if(s===Y)this._depSettledAsData(r,n[1]);else if(s===ie)this._depSettledAsResolved(r);else if(s===te)this._depSettledAsTerminal(r,!0);else if(s===H)this._depSettledAsTerminal(r,n[1]);else{this._emit([n]);return}if(!this._fn){(s===Y||s===ie)&&this._emit([n]),(s===te||s===H)&&this._maybeAutoTerminalAfterWave();return}}}_depDirtied(e){e.dirty||(e.dirty=!0,e.involvedThisWave=!0,this._dirtyDepCount++,this._status!=="dirty"&&this._emit(ot))}_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(kt),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([[H,e.terminal]]);return}this._autoComplete&&this._deps.every(n=>n.terminal!==void 0)&&this._emit(Ot)}_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([[H,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([[H,this._wrapFnError("cleanup.beforeRun threw",a)]]);return}}}let n=this._deps.map(i=>i.involvedThisWave?i.dataBatch.length>0?[...i.dataBatch]:[]:void 0),r=this._deps.map(i=>i.prevData);for(let i=0;i<this._deps.length;i++){let a=n[i];a!=null&&a.length>0&&(this._deps[i].prevData=a[a.length-1])}let s=this._deps.map(i=>i.terminal),o={prevData:r,terminalDeps:s,store:this._store};if(this._hasCalledFnOnce=!0,this._clearWaveFlags(),this._inspectorHooks!=null){let i={kind:"run",batchData:n,prevData:r};for(let a of this._inspectorHooks)a(i)}this._isExecutingFn=!0;try{let i=this._fn(n,this._actions,o);if(typeof i=="function")this._cleanup=i;else if(i!=null&&typeof i=="object"){let a=i;(typeof a.beforeRun=="function"||typeof a.deactivate=="function"||typeof a.invalidate=="function")&&(this._cleanup=i)}}catch(i){this._emit([[H,this._wrapFnError("fn threw",i)]])}finally{this._isExecutingFn=!1,this._pendingRerun?(this._pendingRerun=!1,this._rerunDepth+=1,this._rerunDepth>Dt?(this._rerunDepth=0,this._emit([[H,new Error(`Node "${this.name}": _pendingRerun depth exceeded ${Dt} \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,s=!1,o=!1,i=-1;for(let u of e){let l=n(u[0]);l<i&&(r=!1),l===3&&(s=!0),u[0]===oe&&(o=!0),i=l}let a=e;if(!r){let u=e.map((l,d)=>({m:l,i:d,tier:n(l[0])}));u.sort((l,d)=>l.tier-d.tier||l.i-d.i),a=u.map(l=>l.m)}if(s&&!o&&this._status!=="dirty"){let u=0;for(;u<a.length&&n(a[u][0])===0;)u++;return u===0?[me,...a]:[...a.slice(0,u),me,...a.slice(u)]}return a}_emit(e){if(e.length===0)return;for(let a=0;a<e.length;a++){let u=e[a];if(u[0]===H&&u[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(u=>u[0]===J||u[0]===re);if(a.length===0)return;n=a}n=this._frameBatch(n);let s=null;for(let a=0;a<n.length;a++){let u=n[a],l=u[0];if(l!==ae&&l!==ue){s?.push(u);continue}if(u.length<2)throw new Error(`Node "${this.name}": [[${l===ae?"PAUSE":"RESUME"}]] must carry a lockId payload \u2014 bare PAUSE/RESUME is a protocol violation (C0 rule). Use \`[[PAUSE, lockId]]\` / \`[[RESUME, lockId]]\`.`);let d=!0;if(this._pausable!==!1){let f=u[1];if(l===ae)this._pauseLocks==null&&(this._pauseLocks=new Set),this._pauseLocks.add(f),this._paused=!0,this._pausable==="resumeAll"&&this._pauseBuffer==null&&(this._pauseBuffer=[]);else if(this._pauseLocks==null||!this._pauseLocks.has(f))d=!1;else if(this._pauseLocks.delete(f),this._pauseLocks.size===0){if(this._paused=!1,this._pauseBuffer!=null&&this._pauseBuffer.length>0){let p=this._pauseBuffer;this._pauseBuffer=[],this._emit(p)}this._pendingWave&&(this._pendingWave=!1,this._maybeRunFnOnSettlement())}}d?s?.push(u):s==null&&(s=n.slice(0,a))}if(s!=null){if(s.length===0)return;n=s}if(this._hasMeta&&n.some(a=>a[0]===J))for(let a of Object.keys(this.meta))try{this.meta[a]._emit(it)}catch{}let{finalMessages:o,equalsError:i}=this._updateState(n);if(o.length>0&&this._config.inspectorEnabled){let a=this._config.globalInspector;if(a!=null)try{a({kind:"emit",node:this,messages:o})}catch{}}if(o.length>0)if(this._paused&&this._pausable==="resumeAll"&&this._pauseBuffer!=null){let a=this._config.tierOf,u=[];for(let l of o)a(l[0])===3?this._pauseBuffer.push(l):u.push(l);u.length>0&&this._dispatchOrAccumulate(u)}else this._dispatchOrAccumulate(o);i!=null&&this._emit([[H,i]])}_updateState(e){let n=this._config.tierOf,r,s,o=-1,i=0;for(let d of e)n(d[0])===3&&i++;let a=i<=1,u=-1;if(this._versioning!=null&&i>1){for(let d=e.length-1;d>=0;d--)if(e[d][0]===Y){u=d;break}}for(let d=0;d<e.length;d++){let f=e[d],p=f[0];if(p===Y){if(f.length>=2){let h=!1;if(a&&this._cached!==void 0)try{h=this._equals(this._cached,f[1])}catch(c){s=this._wrapFnError("equals threw",c),o=d;break}if(h){r==null&&(r=e.slice(0,d)),r.push(rt),this._status="resolved";continue}this._cached=f[1],this._versioning!=null&&(u<0||d===u)&&Rt(this._versioning,f[1],this._hashFn)}this._status="settled",r?.push(f)}else if(r?.push(f),p===oe)this._status="dirty";else if(p===ie)this._status="resolved";else if(p===te){this._status="completed";{let h=this._config.rigorRecorder;if(h!=null)try{h.onTerminalTransition(this,"completed",this._autoComplete,this._autoError,this._deps.length>0)}catch{}}}else if(p===H){this._status="errored";{let h=this._config.rigorRecorder;if(h!=null)try{h.onTerminalTransition(this,"errored",this._autoComplete,this._autoError,this._deps.length>0)}catch{}}}else if(p===re){if(this._cached!==void 0){let c=this._config.rigorRecorder;if(c!=null)try{c.onNonVacuousInvalidate(this,this._cached)}catch{}}this._cached=void 0,this._status="dirty";let h=this._cleanup;if(typeof h=="function"){this._cleanup=void 0;try{h()}catch{}}else if(h!=null&&typeof h=="object"){let c=h.invalidate;if(typeof c=="function")try{c()}catch{}}}else p===J&&(this._resetOnTeardown&&(this._cached=void 0),this._deactivate(!0),this._status="sentinel")}let l=o>=0?r??e.slice(0,o):r??e;return s!=null?{finalMessages:l,equalsError:s}:{finalMessages:l}}_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(vt()){this._batchPendingMessages===null&&(this._batchPendingMessages=[],Te(()=>this._flushBatchPending()));for(let n of e)this._batchPendingMessages.push(n);return}Me(this._deliverToSinks,e,this._config.tierOf)}_flushBatchPending(){let e=this._batchPendingMessages;if(e===null||(this._batchPendingMessages=null,e.length===0))return;let n=this._frameBatch(e);Me(this._deliverToSinks,n,this._config.tierOf)}},Gt=t=>Array.isArray(t),ct=t=>typeof t=="object"&&t!=null&&!Array.isArray(t)});function X(t,e){return Se([],{...e,initial:t})}function It(t,e){return Se((r,s,o)=>t(s,o)??void 0,{describeKind:"producer",...e})}function j(t,e,n){return Se(t,(s,o,i)=>{let a=s.map((u,l)=>u!=null&&u.length>0?u.at(-1):i.prevData[l]);o.emit(e(a,i))},{describeKind:"derived",...n})}function Be(t,e,n){return Se(t,(s,o,i)=>{let a=s.map((u,l)=>u!=null&&u.length>0?u.at(-1):i.prevData[l]);return e(a,o,i)??void 0},{describeKind:"effect",...n})}var ft=Q(()=>{"use strict";Oe()});function ht(t){return t.subscribe(()=>{})}var Lt=Q(()=>{"use strict"});var Ve,Pt=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 Dr={};gn(Dr,{demoShell:()=>Ar});module.exports=bn(Dr);Ge();Ie();Oe();function ye(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 Cn(t){return t._describeKind!=null?t._describeKind:t._deps.length>0?"derived":t._fn!=null?"producer":"state"}function An(t){let e={};for(let[n,r]of Object.entries(t.meta))try{e[n]=r.cache}catch{}return e}function Ne(t,e){let n=e==null,r=!n&&e!=null?[...e].filter(l=>l.startsWith("meta.")).map(l=>l.slice(5)):null,s=n||e.has("meta")||r!=null&&r.length>0,o="state",i=[];t instanceof B&&(o=Cn(t),i=t._deps.map(l=>l.node.name??""));let a={type:o,deps:i};(n||e.has("status"))&&(a.status=t.status);let u=t instanceof B?t._guard:void 0;if(s){let l={...An(t)};if(u!=null&&l.access===void 0&&(l.access=Ze(u)),r!=null&&r.length>0&&!e.has("meta")){let d={};for(let f of r)f in l&&(d[f]=l[f]);a.meta=d}else a.meta=l}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 l={id:t.v.id,version:t.v.version};"cid"in t.v&&(l.cid=t.v.cid,l.prev=t.v.prev),a.v=l}return(n||e.has("guard"))&&u!=null&&(a.guard=Ze(u)),(n||e.has("lastMutation"))&&t.lastMutation!=null&&(a.lastMutation=t.lastMutation),a}ft();tt();Ge();nt();Ie();$e();Oe();ft();Lt();Pt();var Ee=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}};et();function pt(t){return t>=768&&t<=879||t>=1155&&t<=1161||t>=1425&&t<=1469||t>=1552&&t<=1562||t>=1611&&t<=1631||t>=1648&&t===1648||t>=1750&&t<=1756||t>=1759&&t<=1764||t>=1767&&t<=1768||t>=1770&&t<=1773||t>=1840&&t<=1866||t>=1958&&t<=1968||t>=2304&&t<=2307||t>=2362&&t<=2383||t>=2385&&t<=2391||t>=2402&&t<=2403||t>=2433&&t<=2435||t>=2492&&t<=2509||t>=2561&&t<=2563||t>=2620&&t<=2641||t>=2672&&t<=2673||t>=2677&&t===2677||t>=3633&&t===3633||t>=3636&&t<=3642||t>=3655&&t<=3662||t>=3761&&t===3761||t>=3764&&t<=3772||t>=3784&&t<=3790||t>=7616&&t<=7679||t>=8400&&t<=8447||t>=65024&&t<=65039||t>=65056&&t<=65071||t===8205?0:t>=4352&&t<=4447||t>=8986&&t<=8987||t>=9001&&t<=9002||t>=9193&&t<=9203||t>=9208&&t<=9210||t>=9725&&t<=9726||t>=9748&&t<=9749||t>=9800&&t<=9811||t===9855||t===9875||t===9889||t>=9898&&t<=9899||t>=9917&&t<=9918||t>=9924&&t<=9925||t===9934||t===9940||t===9962||t>=9970&&t<=9971||t===9973||t===9978||t===9981||t===9986||t===9989||t>=9992&&t<=9997||t===9999||t>=10067&&t<=10069||t===10071||t>=10133&&t<=10135||t===10160||t===10175||t>=10548&&t<=10549||t>=11013&&t<=11015||t>=11035&&t<=11036||t===11088||t===11093||t>=11904&&t<=12350||t>=12352&&t<=12447||t>=12448&&t<=12543||t>=12549&&t<=12591||t>=12593&&t<=12686||t>=12688&&t<=12771||t>=12784&&t<=12830||t>=12832&&t<=12871||t>=12880&&t<=19903||t>=19968&&t<=40959||t>=43360&&t<=43388||t>=44032&&t<=55203||t>=63744&&t<=64255||t>=65040&&t<=65049||t>=65072&&t<=65131||t>=65281&&t<=65376||t>=65504&&t<=65510||t>=126980&&t===126980||t===127183||t>=127344&&t<=127345||t===127358||t===127359||t===127374||t>=127377&&t<=127386||t>=127456&&t<=127487||t>=127488&&t<=127490||t===127514||t===127535||t>=127538&&t<=127546||t>=127568&&t<=127569||t>=127744&&t<=129535||t>=129536&&t<=129791||t>=129792&&t<=130047||t>=131072&&t<=196605||t>=196608&&t<=262141?2:1}function je(t){let e=0;for(let n of t)e+=pt(n.codePointAt(0));return e}function $t(t,e){if(e<=0)return"";let n=0,r="";for(let s of t){let o=pt(s.codePointAt(0));if(n+o>e){if(e<=1)return"\u2026";for(;n+1>e&&r.length>0;){let i=[...r].pop();r=r.slice(0,-i.length),n-=pt(i.codePointAt(0))}return`${r}\u2026`}r+=s,n+=o}return r}var Dn={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"},Mn={horizontal:"-",vertical:"|",cornerTL:"+",cornerTR:"+",cornerBL:"+",cornerBR:"+",tDown:"+",tUp:"+",tRight:"+",tLeft:"+",cross:"+",arrowRight:">",arrowDown:"v",arrowLeft:"<",arrowUp:"^",boxTL:"+",boxTR:"+",boxBL:"+",boxBR:"+",boxH:"-",boxV:"|"};function Vt(t,e){let n=e.charset==="ascii"?Mn:Dn,r=t.width,s=t.height,o=Array.from({length:s},()=>Array.from({length:r},()=>" ")),i=Array.from({length:s},()=>Array.from({length:r},()=>"empty"));for(let a of t.edges)In(o,i,n,a);for(let a of t.boxes)Gn(o,i,n,a,e.labelOf(a.id));return o.map(a=>Fn(a.join(""))).join(`
2
+ `)}function Gn(t,e,n,r,s){let{x:o,y:i,w:a,h:u}=r;if(a<2||u<2){u>0&&Ft(t,e,o,i,a,s);return}le(t,e,o,i,n.boxTL);for(let d=o+1;d<o+a-1;d+=1)le(t,e,d,i,n.boxH);le(t,e,o+a-1,i,n.boxTR);for(let d=i+1;d<i+u-1;d+=1){le(t,e,o,d,n.boxV);for(let f=o+1;f<o+a-1;f+=1)jt(t,e,f,d," ","empty");le(t,e,o+a-1,d,n.boxV)}le(t,e,o,i+u-1,n.boxBL);for(let d=o+1;d<o+a-1;d+=1)le(t,e,d,i+u-1,n.boxH);le(t,e,o+a-1,i+u-1,n.boxBR);let l=i+Math.floor(u/2);Ft(t,e,o+1,l,a-2,s)}function le(t,e,n,r,s){jt(t,e,n,r,s,s===" "?"empty":s==="\u2500"||s==="-"?"boxH":s==="\u2502"||s==="|"?"boxV":"boxCorner")}function jt(t,e,n,r,s,o){if(r<0||r>=t.length)return;let i=t[r];n<0||n>=i.length||(i[n]=s,e[r][n]=o)}function Ft(t,e,n,r,s,o){if(r<0||r>=t.length)return;let i=n,a=s;for(let u of o){let l=je(u);if(l!==0){if(a<l)break;i>=0&&i<t[r].length&&(t[r][i]=u,e[r][i]="label",l===2&&i+1<t[r].length&&(t[r][i+1]="",e[r][i+1]="label")),i+=l,a-=l}}for(;a>0;)i>=0&&i<t[r].length&&(t[r][i]=" ",e[r][i]="empty"),i+=1,a-=1}function In(t,e,n,r){let s=r.points;if(s.length<2)return;for(let u=0;u+1<s.length;u+=1)Ln(t,e,n,s[u],s[u+1]);for(let u=1;u+1<s.length;u+=1){let l=s[u-1],d=s[u],f=s[u+1],p=Pn(l,d,f,n);p&&Bt(t,e,d.x,d.y,p,"edgeCorner")}let o=s[s.length-1],i=s[s.length-2],a=$n(i,o,n);a&&Bt(t,e,o.x,o.y,a,"arrow")}function Ln(t,e,n,r,s){if(!(r.x===s.x&&r.y===s.y)){if(r.y===s.y){let o=r.y,i=Math.min(r.x,s.x),a=Math.max(r.x,s.x);for(let u=i;u<=a;u+=1)Ht(t,e,u,o,n,"h")}else if(r.x===s.x){let o=r.x,i=Math.min(r.y,s.y),a=Math.max(r.y,s.y);for(let u=i;u<=a;u+=1)Ht(t,e,o,u,n,"v")}}}function Ht(t,e,n,r,s,o){if(r<0||r>=t.length)return;let i=t[r];if(n<0||n>=i.length)return;let a=e[r][n];if(!(a==="boxH"||a==="boxV"||a==="boxCorner"||a==="label")){if(a==="empty"){i[n]=o==="h"?s.horizontal:s.vertical,e[r][n]=o==="h"?"edgeH":"edgeV";return}if(a==="edgeH"&&o==="v"){i[n]=s.cross,e[r][n]="edgeCorner";return}if(a==="edgeV"&&o==="h"){i[n]=s.cross,e[r][n]="edgeCorner";return}}}function Bt(t,e,n,r,s,o){if(r<0||r>=t.length)return;let i=t[r];if(n<0||n>=i.length)return;let a=e[r][n];a==="boxH"||a==="boxV"||a==="boxCorner"||a==="label"||(i[n]=s,e[r][n]=o)}function Pn(t,e,n,r){let s=t.y===e.y,o=e.y===n.y;if(s===o)return;if(s){let u=t.x<e.x,l=n.y>e.y;return u&&l?r.cornerTR:u&&!l?r.cornerBR:!u&&l?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 $n(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 Fn(t){let e=t.length;for(;e>0&&t.charCodeAt(e-1)===32;)e-=1;return t.slice(0,e)}function Ut(t){let e=Hn(t);Bn(e),Vn(e),jn(e),Wn(e,t);let n=Kn(e,t),{width:r,height:s}=Yn(e),o=[];for(let i of e.layers)for(let a of i)a.isVirtual||o.push({id:a.id,layer:a.layer,order:a.order,x:a.x,y:a.y,w:a.w,h:a.h});return{boxes:o,edges:n,width:r,height:s}}function Hn(t){let e=new Map;for(let s of t.nodes)e.set(s,{id:s,isVirtual:!1,layer:-1,order:0,x:0,y:0,w:t.widthCells(s),h:t.heightCells(s),in:[],out:[]});let n=[],r=0;for(let s of t.edges){if(s.from===s.to)continue;let o=e.get(s.from),i=e.get(s.to);if(!o||!i)continue;let a={chainId:r++,chainFrom:s.from,chainTo:s.to,fromId:s.from,toId:s.to,hopIndex:0,chainLen:1};o.out.push(a),i.in.push(a),n.push(a)}return{nodes:e,layers:[],hops:n}}function Bn(t){let e=new Map;for(let o of t.nodes.values())e.set(o.id,o.in.length);let n=[];for(let o of t.nodes.values())(e.get(o.id)??0)===0&&(o.layer=0,n.push(o));let r=new Set,s=0;for(;s<n.length;){let o=n[s++];if(!r.has(o.id)){r.add(o.id);for(let i of o.out){let a=t.nodes.get(i.toId);a.layer=Math.max(a.layer,o.layer+1);let u=(e.get(a.id)??0)-1;e.set(a.id,u),u<=0&&n.push(a)}}}for(let o of t.nodes.values())o.layer<0&&(o.layer=0)}function Vn(t){let e=Math.max(0,...Array.from(t.nodes.values(),o=>o.layer)),n=Array.from({length:e+1},()=>[]);for(let o of t.nodes.values())n[o.layer].push(o);let r=[],s=0;for(let o of t.hops){let i=t.nodes.get(o.fromId),a=t.nodes.get(o.toId),u=a.layer-i.layer;if(u<=0){i.out=i.out.filter(f=>f!==o),a.in=a.in.filter(f=>f!==o);continue}if(u===1){o.hopIndex=0,o.chainLen=1,r.push(o);continue}i.out=i.out.filter(f=>f!==o),a.in=a.in.filter(f=>f!==o);let l=i;for(let f=1;f<u;f+=1){let p=`__virt_${s++}__`,h={id:p,isVirtual:!0,layer:i.layer+f,order:0,x:0,y:0,w:0,h:1,in:[],out:[]};t.nodes.set(p,h),n[h.layer].push(h);let c={chainId:o.chainId,chainFrom:o.chainFrom,chainTo:o.chainTo,fromId:l.id,toId:p,hopIndex:f-1,chainLen:u};l.out.push(c),h.in.push(c),r.push(c),l=h}let d={chainId:o.chainId,chainFrom:o.chainFrom,chainTo:o.chainTo,fromId:l.id,toId:a.id,hopIndex:u-1,chainLen:u};l.out.push(d),a.in.push(d),r.push(d)}for(let o of n)for(let i=0;i<o.length;i+=1)o[i].order=i;t.layers=n,t.hops=r}function jn(t){for(let n=0;n<4;n+=1){for(let r=1;r<t.layers.length;r+=1)Wt(t,t.layers[r],"in"),We(t.layers[r]);for(let r=t.layers.length-2;r>=0;r-=1)Wt(t,t.layers[r],"out"),We(t.layers[r])}for(let n=0;n<2;n+=1){let r=!1;for(let s=1;s<t.layers.length;s+=1){let o=t.layers[s];for(let i=0;i+1<o.length;i+=1){let a=zt(t,o[i],o[i+1],"in");[o[i],o[i+1]]=[o[i+1],o[i]],We(o),zt(t,o[i],o[i+1],"in")<a?r=!0:([o[i],o[i+1]]=[o[i+1],o[i]],We(o))}}if(!r)break}}function Wt(t,e,n){let r=new Map;for(let s of e){let o=n==="in"?s.in:s.out;if(o.length===0){r.set(s.id,s.order);continue}let i=0,a=0;for(let u of o){let l=t.nodes.get(n==="in"?u.fromId:u.toId);l&&(i+=l.order,a+=1)}r.set(s.id,a===0?s.order:i/a)}e.sort((s,o)=>{let i=r.get(s.id),a=r.get(o.id);return i!==a?i-a:s.order-o.order})}function We(t){for(let e=0;e<t.length;e+=1)t[e].order=e}function zt(t,e,n,r){let s=r==="in"?e.in:e.out,o=r==="in"?n.in:n.out,i=0;for(let a of s)for(let u of o){let l=t.nodes.get(r==="in"?a.fromId:a.toId)?.order??0,d=t.nodes.get(r==="in"?u.fromId:u.toId)?.order??0;(e.order<n.order&&l>d||e.order>n.order&&l<d)&&(i+=1)}return i}function Wn(t,e){e.direction==="LR"?zn(t,e):Un(t,e)}function zn(t,e){let n=[],r=0;for(let s=0;s<t.layers.length;s+=1){n.push(r);let o=0;for(let i of t.layers[s])o=Math.max(o,i.w);r+=o+e.layerGap}for(let s=0;s<t.layers.length;s+=1)for(let o of t.layers[s])o.x=n[s];for(let s of t.layers){let o=0;for(let i of s)i.y=o,o+=i.h+e.nodeGap}Kt(t,e,"y")}function Un(t,e){let n=[],r=0;for(let s=0;s<t.layers.length;s+=1){n.push(r);let o=0;for(let i of t.layers[s])o=Math.max(o,i.h);r+=o+e.layerGap}for(let s=0;s<t.layers.length;s+=1)for(let o of t.layers[s])o.y=n[s];for(let s of t.layers){let o=0;for(let i of s)i.x=o,o+=i.w+e.nodeGap}Kt(t,e,"x")}function Kt(t,e,n){let r=o=>n==="y"?o.h:o.w,s=e.nodeGap;for(let o=0;o<2;o+=1){let i=o===0?t.layers.slice(1):t.layers.slice(0,-1).reverse();for(let a of i){let u=new Map;for(let d of a){let f=o===0?d.in:d.out;if(f.length===0)continue;let p=[];for(let c of f){let v=t.nodes.get(o===0?c.fromId:c.toId);if(!v)continue;let T=n==="y"?v.y:v.x;p.push(T+Math.floor(r(v)/2))}if(p.length===0)continue;p.sort((c,v)=>c-v);let h=p[Math.floor(p.length/2)];u.set(d.id,h-Math.floor(r(d)/2))}let l=0;for(let d of a){let f=u.get(d.id),p=n==="y"?d.y:d.x,c=Math.max(f??p,l);n==="y"?d.y=c:d.x=c,l=c+r(d)+s}}}}function Kn(t,e){let n=new Map;for(let l of t.hops){let d=n.get(l.chainId);d?d.push(l):n.set(l.chainId,[l])}for(let l of n.values())l.sort((d,f)=>d.hopIndex-f.hopIndex);let r=e.direction==="LR",s=l=>r?l.x:l.y,o=l=>r?l.w:l.h,i=l=>r?l.y+Math.floor(l.h/2):l.x+Math.floor(l.w/2),a=new Map;for(let l=0;l+1<t.layers.length;l+=1){let d=t.layers[l],f=t.layers[l+1],p=0;for(let k of d)p=Math.max(p,s(k)+o(k));let h=Number.POSITIVE_INFINITY;for(let k of f)h=Math.min(h,s(k));let c=Number.isFinite(h)?h-1:p,v=Math.max(1,c-p+1),T=[];for(let k of d)for(let N of k.out)T.push(N);T.sort((k,N)=>{let D=i(t.nodes.get(k.fromId)),E=i(t.nodes.get(N.fromId));if(D!==E)return D-E;let C=i(t.nodes.get(k.toId)),R=i(t.nodes.get(N.toId));return C-R});let w=[],g=new Map;for(let k of T){let N=i(t.nodes.get(k.fromId)),D=i(t.nodes.get(k.toId)),E=Math.min(N,D),C=Math.max(N,D),R=-1;for(let $=0;$<w.length;$+=1){let U=w[$],Z=!0;for(let O of U)if(O.lo<=C&&E<=O.hi){Z=!1;break}if(Z){U.push({lo:E,hi:C}),R=$;break}}R<0&&(w.push([{lo:E,hi:C}]),R=w.length-1),g.set(k,R)}let y=w.length,_=v>=Math.max(3,y+2),m=_?p+1:p,b=_?c-1:c,x=Math.max(1,b-m+1);for(let k of T){let N=g.get(k),D;if(y<=1)D=m+Math.floor(x/2);else{let E=(x-1)/(y-1);D=m+Math.floor(N*E)}a.set(k,Math.max(p,Math.min(c,D)))}}let u=[];for(let[,l]of n){let d=[];for(let p=0;p<l.length;p+=1){let h=l[p],c=t.nodes.get(h.fromId),v=t.nodes.get(h.toId),T=a.get(h),w=c.isVirtual?s(c):s(c)+o(c),g=v.isVirtual?s(v):s(v)-1,y=i(c),_=i(v);p===0&&ze(d,r,w,y),y!==_&&(ze(d,r,T,y),ze(d,r,T,_)),ze(d,r,g,_)}let f=l[0];u.push({from:f.chainFrom,to:f.chainTo,points:qn(d)})}return u}function ze(t,e,n,r){t.push(e?{x:n,y:r}:{x:r,y:n})}function qn(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 Yn(t){let e=0,n=0;for(let r of t.layers)for(let s of r)e=Math.max(e,s.x+s.w),n=Math.max(n,s.y+s.h);return{width:e,height:n}}var Jn=24,Xn=4,Zn=1,Qn=3;function qt(t,e){let n=er(e.direction),r=Math.max(3,e.maxLabelWidth??Jn),s=e.asciiCharset??"unicode",o=Object.keys(t.nodes).sort(),i=new Set(o),a=t.edges.filter(h=>i.has(h.from)&&i.has(h.to)),u=new Map,l=new Map;for(let h of o){let c=$t(h,r);u.set(h,c),l.set(h,je(c)+4)}let d=Ut({nodes:o,edges:a,widthCells:h=>l.get(h)??3,heightCells:()=>Qn,layerGap:Xn,nodeGap:Zn,direction:n}),f=Vt(d,{charset:s,labelOf:h=>u.get(h)??h}),p=e.logger;return p&&p(f),f}function er(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 Yt(t,e,n,r={}){let s=e in t.nodes,o=n in t.nodes;if(!s)return Ue(e,n,"no-such-from");if(!o)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 l=tr(t,e,r);if(l!=null)return l}let u=Ke(e,t.nodes[e],0,r);return qe(e,n,[u])}if(i===0)return Ue(e,n,"no-path");let a=Jt(t,e,n,i);return a.found?qe(e,n,Xt(t,a.pathOrder,r)):Ue(e,n,a.truncated?"max-depth-exceeded":"no-path")}function Jt(t,e,n,r){let s=new Map,o=[{path:n,depth:0}],i=new Set([n]),a=0,u=!1;for(;a<o.length;){let f=o[a++];if(f.path===e)break;if(r!=null&&f.depth>=r){let v=t.nodes[f.path];v?.deps&&v.deps.length>0&&(u=!0);continue}let p=t.nodes[f.path];if(p==null)continue;let h=p.deps??[],c=new Map;for(let v=0;v<h.length;v++){let T=h[v];if(!T)continue;let w=c.get(T);w==null&&(w=[],c.set(T,w)),w.push(v)}for(let[v,T]of c)i.has(v)||(i.add(v),s.set(v,{from:f.path,depIndices:T}),o.push({path:v,depth:f.depth+1}))}if(!s.has(e))return{found:!1,pathOrder:[],truncated:u};let l=[{path:e}],d=e;for(;d!==n;){let f=s.get(d);if(f==null)return{found:!1,pathOrder:[],truncated:!1};l[l.length-1].depIndices=f.depIndices,l.push({path:f.from}),d=f.from}return{found:!0,pathOrder:l,truncated:!1}}function tr(t,e,n){let r=t.nodes[e];if(r==null)return null;let s=r.deps??[],o=[];for(let a=0;a<s.length;a++)s[a]===e&&o.push(a);if(o.length>0){let a=Ke(e,r,0,n);a.dep_index=o[0];let u=Ke(e,r,1,n);return qe(e,e,[a,u])}let i=null;for(let a=0;a<s.length;a++){let u=s[a];if(!u||u===e)continue;let l=Jt(t,u,e,n.maxDepth);l.found&&(i==null||l.pathOrder.length<i.pathOrder.length)&&(i=l,i={found:!0,pathOrder:[{path:e,depIndices:[a]},...l.pathOrder],truncated:!1})}return i==null?null:qe(e,e,Xt(t,i.pathOrder,n))}function Xt(t,e,n){return e.map((r,s)=>{let o=t.nodes[r.path],i=Ke(r.path,o,s,n);return r.depIndices!=null&&r.depIndices.length>0&&(i.dep_index=r.depIndices[0],r.depIndices.length>1&&(i.dep_indices=[...r.depIndices])),i})}function Ke(t,e,n,r){let s={path:t,type:e.type,hop:n};e.status!==void 0&&(s.status=e.status),"value"in e&&(s.value=e.value),e.v!=null&&(s.v=e.v);let o=r.annotations?.get(t)??e.annotation;o!=null&&(s.annotation=o);let i=r.lastMutations?.get(t)??e.lastMutation;return i!=null&&(s.lastMutation=i),s}function qe(t,e,n){return Zt(t,e,!0,"ok",n)}function Ue(t,e,n){return Zt(t,e,!1,n,[])}function Zt(t,e,n,r,s){let o=nr(t,e,n,r,s);return{from:t,to:e,found:n,reason:r,steps:s,text:o,toJSON(){return{from:t,to:e,found:n,reason:r,steps:s}}}}function nr(t,e,n,r,s){if(!n)switch(r){case"no-such-from":return`explainPath: no node named "${t}"`;case"no-such-to":return`explainPath: no node named "${e}"`;case"max-depth-exceeded":return`explainPath: no path from "${t}" to "${e}" within maxDepth`;default:return`explainPath: no path from "${t}" to "${e}"`}let o=[`Causal path: ${t} \u2192 ${e} (${s.length} step(s))`];for(let i of s){let u=` ${i.hop===0?"\xB7":"\u2193"} ${i.path} (${i.type}${i.status?`/${i.status}`:""})`;if(o.push(u),"value"in i&&o.push(` value: ${rr(i.value)}`),i.annotation!=null&&o.push(` annotation: ${i.annotation}`),i.lastMutation!=null){let l=i.lastMutation.actor;o.push(` actor: ${l.type}${l.id?`:${l.id}`:""}`)}}return o.join(`
3
+ `)}function rr(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)}}Oe();var V={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 Qt(t){let e=new WeakSet,n=new WeakSet,r=[t],s=0;for(;r.length>0;){let o=r.pop();s+=or(o,e,n,r)}return s}function or(t,e,n,r){if(t==null)return 0;switch(typeof t){case"number":return V.number;case"boolean":return V.boolean;case"string":return V.string+t.length*2;case"bigint":return V.bigint+ir(t);case"symbol":return V.symbol;case"function":return e.has(t)?0:(e.add(t),V.function);case"undefined":return 0}let o=t;if(e.has(o))return 0;e.add(o);let i=o[sr];if(typeof i=="function")try{let l=i.call(o);if(typeof l=="number"&&Number.isFinite(l))return l}catch{}if(o instanceof Date)return V.date;if(o instanceof RegExp)return V.regexp+o.source.length*2;if(o instanceof Error){let l=o.message?o.message.length*2:0,d=o.stack?o.stack.length*2:0;return V.error+l+d}if(typeof URL<"u"&&o instanceof URL)return V.url+o.href.length*2;if(typeof Promise<"u"&&o instanceof Promise)return V.promise;if(o instanceof WeakMap)return V.weakmap;if(o instanceof WeakSet)return V.weakset;if(o instanceof Map){let l=V.map;for(let[d,f]of o)l+=V.mapEntry,r.push(d),r.push(f);return l}if(o instanceof Set){let l=V.set;for(let d of o)l+=V.setEntry,r.push(d);return l}if(Array.isArray(o)){let l=V.array+o.length*8;for(let d of o)r.push(d);return l}if(o instanceof ArrayBuffer)return n.has(o)?0:(n.add(o),o.byteLength);if(ArrayBuffer.isView(o)){let l=o;return n.has(l.buffer)?48:(n.add(l.buffer),l.buffer.byteLength+48)}let a=V.object,u=Object.keys(o);for(let l of u){a+=V.string+l.length*2;try{r.push(o[l])}catch{}}return a}function ir(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 en(t,e){let n=e?.topN??10,r=t.describe({detail:"standard"}),s=[],o=t._collectObserveTargets;typeof o=="function"&&o.call(t,"",s);let i=new Map;for(let[p,h]of s)i.set(p,h);let a=[];for(let[p,h]of Object.entries(r.nodes)){let c=i.get(p),v=c instanceof B?c:null,T=v?Qt(v.cache):0,w=v?v._sinkCount:0,g=h.deps?.length??0,y=h.type==="effect"&&w===0,_=w===0?h.type==="effect"?"orphan-effect":h.type==="derived"?"idle-derived":h.type==="producer"?"idle-producer":null:null;a.push({path:p,type:h.type,status:h.status??"unknown",valueSizeBytes:T,subscriberCount:w,depCount:g,isOrphanEffect:y,orphanKind:_})}let u=a.reduce((p,h)=>p+h.valueSizeBytes,0),l=(p,h)=>[...a].sort(h??((c,v)=>v[p]-c[p])).slice(0,n),d=a.filter(p=>p.orphanKind!=null),f=a.filter(p=>p.isOrphanEffect);return{nodeCount:a.length,edgeCount:r.edges.length,subgraphCount:r.subgraphs.length,nodes:a,totalValueSizeBytes:u,hotspots:{byValueSize:l("valueSizeBytes"),bySubscriberCount:l("subscriberCount"),byDepCount:l("depCount")},orphans:d,orphanEffects:f}}var P="::",se="__meta__",ve=1;function tn(t,e){let n=Math.max(16,t.size*4),r=0;for(;t.size>0;){if(r++>=n){console.error(`[Graph "${e}".destroy] disposer drain exceeded cap (${n}); ${t.size} disposer(s) discarded`),t.clear();return}let s=t.values().next();if(s.done)return;let o=s.value;t.delete(o);try{o()}catch(i){console.error(`[Graph "${e}".destroy] disposer threw:`,i)}}}function on(t){return t!=null&&typeof t=="object"&&"cache"in t&&typeof t.subscribe=="function"&&typeof t.down=="function"}function ar(t){if(t!=null)return on(t)?t.cache:t}function ur(t){let e=[];for(let n of Object.keys(t).sort()){let r=t[n].v;r!=null&&e.push(`${n} ${r.id} ${r.version}`)}return e.join(`
4
+ `)}function nn(t){if(t.version!==ve)throw new Error(`unsupported snapshot version ${String(t.version)} (expected ${ve})`);for(let e of["name","nodes","edges","subgraphs"])if(!(e in t))throw new Error(`snapshot missing required key "${e}"`);if(typeof t.name!="string")throw new TypeError("snapshot 'name' must be a string");if(typeof t.nodes!="object"||t.nodes===null||Array.isArray(t.nodes))throw new TypeError("snapshot 'nodes' must be an object");if(!Array.isArray(t.edges))throw new TypeError("snapshot 'edges' must be an array");if(!Array.isArray(t.subgraphs))throw new TypeError("snapshot 'subgraphs' must be an array")}function lr(t,e){let n=new WeakMap,r=(s,o)=>{if(Object.is(s,o))return!0;if(s==null||o==null||typeof s!="object"||typeof o!="object")return!1;let i=n.get(s);if(i==null&&(i=new WeakSet,n.set(s,i)),i.has(o))return!0;i.add(o);let a=s.constructor,u=o.constructor;if(a!==u)return!1;if(s instanceof Date)return s.getTime()===o.getTime();if(s instanceof RegExp)return s.source===o.source&&s.flags===o.flags;if(Array.isArray(s)){let p=o;if(s.length!==p.length)return!1;for(let h=0;h<s.length;h++)if(!r(s[h],p[h]))return!1;return!0}if(s instanceof Map){let p=o;if(s.size!==p.size)return!1;for(let[h,c]of s)if(!p.has(h)||!r(c,p.get(h)))return!1;return!0}if(s instanceof Set){let p=o;if(s.size!==p.size)return!1;for(let h of s){let c=!1;for(let v of p)if(r(h,v)){c=!0;break}if(!c)return!1}return!0}if(ArrayBuffer.isView(s)){let p=s,h=o;if(p.length!==h.length)return!1;for(let c=0;c<p.length;c++)if(p[c]!==h[c])return!1;return!0}let l=Object.keys(s),d=Object.keys(o);if(l.length!==d.length)return!1;let f=new Set(d);for(let p of l)if(!f.has(p)||!r(s[p],o[p]))return!1;return!0};return r(t,e)}function mt(t){if(t===null||typeof t!="object")return t;if(Array.isArray(t))return t.map(mt);let e=t,n=Object.keys(e).sort(),r={};for(let s of n)r[s]=mt(e[s]);return r}function dr(t){return t.replaceAll("\\","\\\\").replaceAll('"','\\"')}function cr(t){return t.replaceAll("\\","\\\\").replaceAll('"','\\"')}function fr(t){return t==="TD"?"down":t==="BT"?"up":t==="RL"?"left":"right"}function an(t){let e=new Set,n=[];function r(s,o){let i=`${s}\0${o}`;e.has(i)||(e.add(i),n.push([s,o]))}for(let[s,o]of Object.entries(t.nodes)){let i=o.deps;if(i)for(let a of i)r(a,s)}for(let s of t.edges)r(s.from,s.to);return n}function un(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 hr(t,e){let n=e.includeEdges??!0,r=e.includeSubgraphs??!0,{expand:s,...o}=t,i={...o,edges:n?t.edges:[],subgraphs:r?t.subgraphs:[]},a=JSON.stringify(mt(i),null,e.indent??2);return e.logger?.(a),a}function pr(t,e){let n=e.includeEdges??!0,r=e.includeSubgraphs??!0,s=[];s.push(`Graph ${t.name}`),s.push("Nodes:");for(let i of Object.keys(t.nodes).sort()){let a=t.nodes[i];s.push(`- ${i} (${a.type}/${a.status}): ${Je(a.value)}`)}if(n){s.push("Edges:");for(let i of t.edges)s.push(`- ${i.from} -> ${i.to}`)}if(r){s.push("Subgraphs:");for(let i of t.subgraphs)s.push(`- ${i}`)}let o=s.join(`
5
+ `);return e.logger?.(o),o}function ln(t,e){let n=un(e.direction),r=Object.keys(t.nodes).sort(),s=new Map;for(let i=0;i<r.length;i+=1)s.set(r[i],`n${i}`);let o=[`flowchart ${n}`];for(let i of r){let a=s.get(i);o.push(` ${a}["${dr(i)}"]`)}for(let[i,a]of an(t)){let u=s.get(i),l=s.get(a);!u||!l||o.push(` ${u} --> ${l}`)}return o.join(`
6
+ `)}function gr(t,e){let n=ln(t,e);return mr(n)}function mr(t,e){let n=e?.theme??"default",r=e?.autoSync??!0,o=JSON.stringify({code:t,mermaid:{theme:n},autoSync:r}),i=new TextEncoder().encode(o),a="";for(let l=0;l<i.length;l++)a+=String.fromCharCode(i[l]);return`https://mermaid.live/edit#base64:${globalThis.btoa(a).replace(/\+/g,"-").replace(/\//g,"_").replace(/=+$/,"")}`}function br(t,e){let n=un(e.direction),r=Object.keys(t.nodes).sort(),s=new Map;for(let i=0;i<r.length;i+=1)s.set(r[i],`n${i}`);let o=[`direction: ${fr(n)}`];for(let i of r){let a=s.get(i);o.push(`${a}: "${cr(i)}"`)}for(let[i,a]of an(t)){let u=s.get(i),l=s.get(a);!u||!l||o.push(`${u} -> ${l}`)}return o.join(`
7
+ `)}function yr(t){return t.replace(/[.*+?^${}()|[\]\\]/g,"\\$&")}function Ye(t){let e="^";for(let n=0;n<t.length;n+=1){let r=t[n];if(r==="*"){e+=".*";continue}if(r==="?"){e+=".";continue}if(r==="["){let s=t.indexOf("]",n+1);if(s<=n+1){e+="\\[";continue}let o=t.slice(n+1,s);o.startsWith("!")&&(o=`^${o.slice(1)}`),o=o.replace(/\\/g,"\\\\"),e+=`[${o}]`,n=s;continue}e+=yr(r)}return e+="$",new RegExp(e)}var vr={data:"\x1B[32m",dirty:"\x1B[33m",resolved:"\x1B[36m",invalidate:"\x1B[93m",pause:"\x1B[90m",resume:"\x1B[96m",complete:"\x1B[34m",error:"\x1B[31m",teardown:"\x1B[91m",derived:"\x1B[35m",path:"\x1B[90m",reset:"\x1B[0m"},xr={data:"",dirty:"",resolved:"",invalidate:"",pause:"",resume:"",complete:"",error:"",teardown:"",derived:"",path:"",reset:""};function Je(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 wr(t){return t==="none"?xr:t==="ansi"||t==null?vr:{data:t.data??"",dirty:t.dirty??"",resolved:t.resolved??"",invalidate:t.invalidate??"",pause:t.pause??"",resume:t.resume??"",complete:t.complete??"",error:t.error??"",teardown:t.teardown??"",derived:t.derived??"",path:t.path??"",reset:t.reset??""}}function rn(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 _r(t,e,n){for(let r=0;r<t.length;r++){let s=t.charCodeAt(r);if(s<32||s===127)throw new Error(`Graph "${e}": ${n} "${t}" must not contain control character (U+${s.toString(16).padStart(4,"0").toUpperCase()} at index ${r})`)}}function gt(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===se)throw new Error(`Graph "${e}": ${n} name "${se}" is reserved for meta companion paths`);_r(t,e,n)}function Tr(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 kr(t,e){let n=!1;for(let s of t)if(!e.isMetaPassthrough(s[0])){n=!0;break}return n?t.filter(s=>e.isMetaPassthrough(s[0])):t}function dn(t){for(let e of t._mounts.values())dn(e);for(let e of t._nodes.values())try{e.down([[J]],{internal:!0})}catch{}}var Re=class t{name;opts;config;_nodes=new Map;_nodeToName=new WeakMap;_mounts=new Map;_parent=void 0;_storageDisposers=new Set;_disposers=new Set;_destroyed=!1;_topology;_topologyEmitters=new Set;constructor(e,n){if(e==="")throw new Error("Graph name must be non-empty");if(e.includes(P))throw new Error(`Graph name must not contain '${P}' (got "${e}")`);if(e===se)throw new Error(`Graph name "${se}" is reserved for meta companion paths`);this.name=e,this.opts=Object.freeze({...n??{}}),this.config=n?.config??be,this._traceRing=new Ee(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=It(e=>{let n=r=>{e.emit(r)};return this._topologyEmitters.add(n),()=>{this._topologyEmitters.delete(n)}},{name:`${this.name}_topology`})),this._topology}_emitTopology(e){if(!(this._topology==null||this._topologyEmitters.size===0))for(let n of this._topologyEmitters)n(e)}nameOf(e){return this._nodeToName.get(e)}add(e,n){let r=e.name,s=n?.name??r;if(s==null||s==="")throw new Error(`Graph "${this.name}": graph.add requires a non-empty name \u2014 pass via opts.name or set it on the node (e.g. state(0, { name: "x" }))`);let o=s,i=n?.annotation;if(gt(o,this.name,"add"),this._mounts.has(o))throw new Error(`Graph "${this.name}": name "${o}" is already a mount point`);if(this._nodes.has(o))throw new Error(`Graph "${this.name}": node "${o}" already exists`);let a=this._nodeToName.get(e);if(a!==void 0)throw new Error(`Graph "${this.name}": node instance already registered as "${a}"`);return this._nodes.set(o,e),this._nodeToName.set(e,o),this._emitTopology({kind:"added",name:o,nodeKind:"node"}),i!=null&&(this._annotations.set(o,i),this.config.inspectorEnabled&&this._traceRing.push({path:o,annotation:i,timestamp_ns:ge()})),e}setVersioning(e){if(e!=null)for(let n of this._nodes.values())n instanceof B&&n._applyVersioning(e)}remove(e){gt(e,this.name,"remove");let n=this._mounts.get(e);if(n){let o={kind:"mount",nodes:[],mounts:[]},i=[];n._collectObserveTargets("",i);for(let[a,u]of i)a.includes(`${P}${se}${P}`)||o.nodes.push(a);return o.nodes.sort(),o.mounts.push(e),o.mounts.push(...n._collectSubgraphs(`${e}${P}`)),this._mounts.delete(e),n._parent=void 0,dn(n),this._emitTopology({kind:"removed",name:e,nodeKind:"mount",audit:o}),o}let r=this._nodes.get(e);if(!r)throw new Error(`Graph "${this.name}": unknown node or mount "${e}"`);this._nodes.delete(e),this._nodeToName.delete(r),r.down([[J]],{internal:!0});let s={kind:"node",nodes:[e],mounts:[]};return this._emitTopology({kind:"removed",name:e,nodeKind:"node",audit:s}),s}removeAll(e){let n=typeof e=="function"?e:(()=>{let o=Ye(e);return i=>o.test(i)})(),r={kind:"mount",nodes:[],mounts:[]},s=[...this._nodes.keys(),...this._mounts.keys()].filter(o=>n(o));for(let o of s){let i=this.remove(o);r.nodes.push(...i.nodes),r.mounts.push(...i.mounts)}return r.nodes.sort(),r.mounts.sort(),r}[Symbol.iterator](){let e=[...this._nodes.keys()].sort(),n=this._nodes,r=0;return{[Symbol.iterator](){return this},next(){if(r>=e.length)return{value:void 0,done:!0};let s=e[r++];return{value:[s,n.get(s)],done:!1}}}}node(e){if(e==="")throw new Error(`Graph "${this.name}": node name must be non-empty`);if(e.includes(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 s=r?.internal===!0;this.node(e).down([[Y,n]],{actor:r?.actor,internal:s,delivery:"write"})}setAll(e,n){let r=Symbol.iterator in e?e:Object.entries(e);De(()=>{for(let[s,o]of r)this.set(s,o,n)})}invalidate(e,n){let r=n?.internal===!0;this.node(e).down([[re]],{actor:n?.actor,internal:r,delivery:"write"})}error(e,n,r){let s=r?.internal===!0;this.node(e).down([[H,n]],{actor:r?.actor,internal:s,delivery:"write"})}complete(e,n){let r=n?.internal===!0;this.node(e).down([[te]],{actor:n?.actor,internal:r,delivery:"write"})}edges(e){let n=e?.recursive===!0,r=new Map;if(!n){for(let[u,l]of this._nodes)r.set(l,u);let a=[];for(let[u,l]of this._nodes)if(l instanceof B)for(let d of l._deps){let f=r.get(d.node);f!=null&&a.push([f,u])}return a.sort((u,l)=>u[0]<l[0]?-1:u[0]>l[0]?1:u[1]<l[1]?-1:u[1]>l[1]?1:0),a}let s=[];this._collectObserveTargets("",s);let o=new Map;for(let[a,u]of s)o.set(u,a);let i=[];for(let[a,u]of s)if(u instanceof B)for(let l of u._deps){let d=o.get(l.node);d!=null&&i.push([d,a])}return i.sort((a,u)=>a[0]<u[0]?-1:a[0]>u[0]?1:a[1]<u[1]?-1:a[1]>u[1]?1:0),i}mount(e,n){if(n===void 0){let s=new t(e);return this.mount(e,s)}if(typeof n=="function"){let s=new t(e);return n(s),this.mount(e,s)}let r=n;if(gt(e,this.name,"mount"),this._nodes.has(e))throw new Error(`Graph "${this.name}": cannot mount at "${e}" \u2014 node with that name exists`);if(this._mounts.has(e))throw new Error(`Graph "${this.name}": mount "${e}" already exists`);if(r===this)throw new Error(`Graph "${this.name}": cannot mount a graph into itself`);if(r._parent!=null)throw new Error(`Graph "${this.name}": this child graph is already mounted on "${r._parent.name}"`);for(let s=this;s!=null;s=s._parent)if(s===r)throw new Error(`Graph "${this.name}": mount("${e}", \u2026) would create a mount cycle`);return this._mounts.set(e,r),r._parent=this,this._emitTopology({kind:"added",name:e,nodeKind:"mount"}),r}resolve(e){let n=Tr(e,this.name);return this._resolveFromSegments(n)}tryResolve(e){try{return this.resolve(e)}catch{return}}_resolveFromSegments(e){let n=e;if(n[0]===this.name&&(n=n.slice(1),n.length===0))throw new Error(`Graph "${this.name}": resolve path ends at graph name only`);let r=n[0],s=n.slice(1);if(s.length===0){let a=this._nodes.get(r);if(a)return a;throw this._mounts.has(r)?new Error(`Graph "${this.name}": path ends at subgraph "${r}" \u2014 not a node (GRAPHREFLY-SPEC \xA73.5)`):new Error(`Graph "${this.name}": unknown name "${r}"`)}let o=this._nodes.get(r);if(o&&s.length>0&&s[0]===se)return this._resolveMetaChainFromNode(o,s,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 "${s.join(P)}" is invalid`):new Error(`Graph "${this.name}": unknown mount or node "${r}"`);return i.resolve(s.join(P))}_resolveMetaChainFromNode(e,n,r){let s=e,o=0,i=[...n];for(;o<i.length;){if(i[o]!==se)throw new Error(`Graph "${this.name}": expected ${se} segment in meta path "${r}"`);if(o+1>=i.length)throw new Error(`Graph "${this.name}": meta path requires a key after ${se} in "${r}"`);let a=i[o+1],u=s.meta[a];if(!u)throw new Error(`Graph "${this.name}": unknown meta "${a}" in path "${r}"`);s=u,o+=2}return s}signal(e,n){if(n?.internal!==!0){for(let s of e)if(this.config.messageTier(s[0])===3)throw new Error(`Graph "${this.name}": Graph.signal() rejects tier-3 messages (DATA / RESOLVED). Broadcast is for control-plane tiers (START / DIRTY / INVALIDATE / PAUSE / RESUME / COMPLETE / ERROR / TEARDOWN). For per-node value writes, use Graph.set or graph.node(name).down(...).`)}let r=[];if(this._signalDeliver(e,n??{},new Set,r),r.length>0)throw r[0]}_signalDeliver(e,n,r,s){for(let u of this._mounts.values())u._signalDeliver(e,n,r,s);let i=n.internal===!0?{internal:!0}:{actor:n.actor,delivery:"signal"},a=kr(e,this.config);for(let u of[...this._nodes.keys()].sort()){let l=this._nodes.get(u);if(!r.has(l)){r.add(l);try{l.down(e,i)}catch(d){if(d instanceof ee)throw d;s.push(d)}a.length!==0&&this._signalMetaSubtree(l,a,r,i,s)}}}_signalMetaSubtree(e,n,r,s,o){for(let i of Object.keys(e.meta).sort()){let a=e.meta[i];if(!r.has(a)){r.add(a);try{a.down(n,s)}catch(u){if(u instanceof ee)throw u;o.push(u)}this._signalMetaSubtree(a,n,r,s,o)}}}describe(e){if(e?.reactive===!0)return this._describeReactive(e);let n=ar(e?.actor),r=e?.filter,s=ye(e?.detail,e?.fields),o=e?.format==="spec",i=o?ye("minimal"):s,a=[];this._collectObserveTargets("",a);let u=new Map;for(let[b,x]of a)u.set(x,b);let l=[];{let b=a.map(([,N])=>N),x=new Set(u.values()),k=0;for(;b.length>0;){let N=b.shift();if(N instanceof B)for(let D of N._deps){let E=D.node;if(u.has(E))continue;let C=E.name??"",R=C;if(!R||x.has(R))if(C){let $=2;for(;x.has(`${C}#${$}`);)$++;R=`${C}#${$}`}else for(R=`__internal__/${k++}`;x.has(R);)R=`__internal__/${k++}`;u.set(E,R),x.add(R),l.push([R,E]),b.push(E)}}}let d=[...a,...l],f={};for(let[b,x]of d){if(n!=null&&!x.allowsObserve(n))continue;let k=Ne(x,i),N=x instanceof B?x._deps.map(R=>u.get(R.node)??R.node.name??""):[],{name:D,...E}=k,C={...E,deps:N};if(!o){let R=this._annotations.get(b);R!=null&&(C.annotation=R)}if(r!=null)if(typeof r=="function"){let R=r;if(!(R.length>=2?R(b,C):R(C)))continue}else{let R=!0;for(let[$,U]of Object.entries(r)){let Z=$==="deps_includes"?"depsIncludes":$==="meta_has"?"metaHas":$;if(Z==="depsIncludes"){if(!C.deps.includes(String(U))){R=!1;break}continue}if(Z==="metaHas"){if(!Object.hasOwn(C.meta??{},String(U))){R=!1;break}continue}if(C[Z]!==U){R=!1;break}}if(!R)continue}f[b]=C}let p=new Set(Object.keys(f)),h=[];for(let[b,x]of d)if(x instanceof B)for(let k of x._deps){let N=u.get(k.node);N!=null&&h.push([N,b])}h.sort((b,x)=>b[0]<x[0]?-1:b[0]>x[0]?1:b[1]<x[1]?-1:b[1]>x[1]?1:0);let c=h.map(([b,x])=>({from:b,to:x}));(n!=null||r!=null)&&(c=c.filter(b=>p.has(b.from)&&p.has(b.to)));let v=this._collectSubgraphs(""),T=n!=null||r!=null?v.filter(b=>{let x=`${b}${P}`;return[...p].some(k=>k===b||k.startsWith(x))}):v,w=this,g=e,y={name:this.name,nodes:f,edges:c,subgraphs:T,expand(b){let x={...g,format:void 0};return Array.isArray(b)?(x.fields=b,x.detail=void 0):(x.detail=b,x.fields=void 0),w.describe(x)}},_=e??{},m=_.format;return m==="json"?hr(y,_):m==="pretty"?pr(y,_):m==="mermaid"?ln(y,_):m==="mermaid-url"?gr(y,_):m==="d2"?br(y,_):m==="ascii"?qt(y,_):y}_collectSubgraphs(e){let n=[];for(let r of[...this._mounts.keys()].sort()){let s=e===""?r:`${e}${r}`;n.push(s),n.push(...this._mounts.get(r)._collectSubgraphs(`${s}${P}`))}return n}resourceProfile(e){return en(this,e)}reachable(e,n,r={}){return r.withDetail===!0?sn(this.describe(),e,n,{...r,withDetail:!0}):sn(this.describe(),e,n,r)}explain(e,n,r){return r?.reactive===!0?this._explainReactive(e,n,r):this._explainStatic(e,n,r)}_explainStatic(e,n,r){let s=this.describe({detail:"full"}),o=new Map(this._annotations),i=new Map;for(let[a,u]of Object.entries(s.nodes))u.lastMutation!=null&&i.set(a,u.lastMutation);return Yt(s,e,n,{...r?.maxDepth!=null?{maxDepth:r.maxDepth}:{},...r?.findCycle===!0?{findCycle:!0}:{},annotations:o,lastMutations:i})}_describeReactive(e){let n={...e,reactive:!1},r=e.reactiveName??"describe",s=0,o=X(s,{name:`${r}_version`}),i=this.observe({timeline:!0,structured:!0}),a=!1,u=!1,l=()=>{a||u||(a=!0,Te(()=>{a=!1,!u&&(s+=1,o.emit(s))}))},d=i.onEvent(g=>{let y=g.type;y!=="data"&&y!=="error"&&y!=="complete"&&y!=="teardown"||l()}),f=[],p=new WeakSet,h=g=>{if(p.has(g)||u)return;p.add(g);let y=g.topology.subscribe(_=>{for(let m of _){if(m[0]!==Y)continue;let b=m[1];if(l(),b.kind==="added"&&b.nodeKind==="mount"){let x=g._mounts.get(b.name);x!=null&&h(x)}}});f.push(y);for(let _ of g._mounts.keys()){let m=g._mounts.get(_);m!=null&&h(m)}};h(this);let c,v=e.actor;on(v)&&(c=v.subscribe(g=>{let y=!1,_=!1;for(let m of g){let b=m[0];b===Y?y=!0:(b===te||b===H||b===J)&&(_=!0)}y&&l(),_&&(c?.(),c=void 0,l())}));let T;try{T=j([o],()=>this.describe(n),{name:r,describeKind:"derived",meta:{domain:"audit",kind:"describe"},equals:(g,y)=>g===y})}catch(g){d(),c?.();for(let y of f)y();throw i.dispose(),g}let w=ht(T);return{node:T,dispose(){u=!0,d(),c?.();for(let g of f)g();f.length=0,i.dispose(),w()}}}_explainReactive(e,n,r){let s=0,o=X(s,{name:"explain_version"}),i=this.observe({timeline:!0,structured:!0}),a=!1,u=!1,l=i.onEvent(h=>{let c=h.type;c!=="data"&&c!=="error"&&c!=="complete"&&c!=="teardown"||a||u||(a=!0,Te(()=>{a=!1,!u&&(s+=1,o.emit(s))}))}),d={...r?.maxDepth!=null?{maxDepth:r.maxDepth}:{},...r?.findCycle===!0?{findCycle:!0}:{}},f;try{f=j([o],()=>this._explainStatic(e,n,d),{name:r?.name??"explain",describeKind:"derived",meta:{domain:"audit",kind:"explain_path",from:e,to:n},equals:(h,c)=>h.found===c.found&&h.reason===c.reason&&h.steps.length===c.steps.length&&Or(h.steps,c.steps)})}catch(h){throw l(),i.dispose(),h}let p=ht(f);return{node:f,dispose(){u=!0,l(),i.dispose(),p()}}}_pathsMatching(e){let n=Ye(e),r=[];return this._collectObserveTargets("",r),r.map(([s])=>s).filter(s=>n.test(s))}_collectObserveTargets(e,n){for(let r of[...this._mounts.keys()].sort()){let s=e===""?r:`${e}${P}${r}`;this._mounts.get(r)._collectObserveTargets(s,n)}for(let r of[...this._nodes.keys()].sort()){let s=this._nodes.get(r),o=e===""?r:`${e}${P}${r}`;n.push([o,s]),this._appendMetaObserveTargets(o,s,n)}}_appendMetaObserveTargets(e,n,r){for(let s of Object.keys(n.meta).sort()){let o=n.meta[s],i=`${e}${P}${se}${P}${s}`;r.push([i,o]),this._appendMetaObserveTargets(i,o,r)}}observe(e,n){let r=typeof e=="string",o=rn(r?n:e),i=o.structured===!0||o.timeline===!0||o.causal===!0||o.derived===!0||o.detail==="minimal"||o.detail==="full"||o.format!=null,a=o.actor;if(r){let d=e,f=this.resolve(d);if(a!=null&&!f.allowsObserve(a))throw new ee({actor:a,action:"observe",nodeName:d});return i?this._buildStructuredObserver([[d,f]],o,"one"):{subscribe(p){return f.subscribe(p)},up(p){try{f.up?.(p)}catch(h){if(h instanceof ee)return;throw h}}}}let u=[];this._collectObserveTargets("",u),u.sort((d,f)=>d[0]<f[0]?-1:d[0]>f[0]?1:0);let l=a==null?u:u.filter(([,d])=>d.allowsObserve(a));return i?this._buildStructuredObserver(l,o,"all"):{subscribe:d=>{let f=l.map(([p,h])=>h.subscribe(c=>{d(p,c)}));return()=>{for(let p of f)p()}},up:(d,f)=>{try{this.resolve(d).up?.(f)}catch(p){if(p instanceof ee)return;throw p}}}}_buildStructuredObserver(e,n,r){let s=r==="one"?e[0]?.[0]:void 0,o=i=>{if(r==="one"&&s!=null){let d=this.resolve(s);return this._buildStructuredObserver([[s,d]],i,"one")}let a=[];this._collectObserveTargets("",a),a.sort((d,f)=>d[0]<f[0]?-1:d[0]>f[0]?1:0);let u=i.actor,l=u==null?a:a.filter(([,d])=>d.allowsObserve(u));return this._buildStructuredObserver(l,i,"all")};return this._createObserveResult(e,n,o)}_createObserveResult(e,n,r){let s=n.timeline===!0,o=n.causal===!0,i=n.derived===!0,a=n.detail==="minimal",u=this.config.inspectorEnabled,l=(o||i)&&u,d=n.maxEvents,f=d!=null&&d>0?new Ee(d):null,p=[],h=new Set,c={},v=new Set,T=0,w=0,g=0,y=0,_=0,m=0,b=!1,x=!1,k=0,N=new Map,D=new Map,E=new Map,C=S=>{f?f.push(S):p.push(S);for(let G of h)G(S)},R=()=>s?{timestamp_ns:ge(),in_batch:Ae(),batch_id:k}:{},$=(S,G)=>{if(!(!l||!(S instanceof B)))return S._setInspectorHook(W=>{if(W.kind==="dep_message")N.set(S,W.depIndex);else if(W.kind==="run"){let ne=W.batchData.map((I,K)=>I!=null&&I.length>0?I.at(-1):W.prevData[K]);D.set(S,ne);let z=W.batchData.map(I=>I!=null?[...I]:void 0);E.set(S,z),i&&C({type:"derived",path:G,dep_values:ne,dep_batches:z,...R()})}})},U=S=>{let G=N.get(S),W=D.get(S);if(!o||W==null)return{};let z=(G!=null&&G>=0&&S instanceof B?S._deps[G]:void 0)?.node,I=z?.v,K=E.get(S);return{trigger_dep_index:G,trigger_dep_name:z?.name,...I!=null?{trigger_version:{id:I.id,version:I.version}}:{},dep_values:[...W],...K!=null?{dep_batches:K}:{}}},Z=[],O=[];for(let[S,G]of e){let W=$(G,S);W&&Z.push(W),O.push(G.subscribe(ne=>{k++;for(let z of ne){let I=z[0],K=R();if(I===Y){c[S]=z[1];let xe=G instanceof B?G.lastMutation?.actor??pe:pe;C({type:"data",path:S,data:z[1],actor:xe,...K,...U(G)})}else if(a)I===oe?T++:I===ie?w++:I===re?g++:I===ae?y++:I===ue?_++:I===J?m++:I===te&&!v.has(S)?b=!0:I===H&&(x=!0,v.add(S));else if(I===oe)T++,C({type:"dirty",path:S,...K});else if(I===ie)w++,C({type:"resolved",path:S,...K,...U(G)});else if(I===re)g++,C({type:"invalidate",path:S,...K});else if(I===ae)y++,C({type:"pause",path:S,lockId:z[1],...K});else if(I===ue)_++,C({type:"resume",path:S,lockId:z[1],...K});else if(I===te)v.has(S)||(b=!0),C({type:"complete",path:S,...K});else if(I===H){x=!0,v.add(S);let xe=G instanceof B?G.lastMutation?.actor??pe:pe;C({type:"error",path:S,data:z[1],actor:xe,...K})}else I===J&&(m++,C({type:"teardown",path:S,...K}))}}))}let M=!1,A=()=>{if(!M){M=!0;for(let S of O)S();for(let S of Z)S();for(let S of L)S({value:void 0,done:!0});L.length=0}},q=[],L=[];h.add(S=>{let G=L.shift();G?G({value:S,done:!1}):q.push(S)});let F={get values(){return c},get dirtyCount(){return T},get resolvedCount(){return w},get invalidateCount(){return g},get pauseCount(){return y},get resumeCount(){return _},get teardownCount(){return m},get events(){return f?f.toArray():[...p]},get anyCompletedCleanly(){return b},get anyErrored(){return x},get completedWithoutErrors(){return b&&!x},onEvent(S){return h.add(S),()=>h.delete(S)},dispose:A,expand(S){A();let G={...n};return typeof S=="string"?G.detail=S:Object.assign(G,S),r(rn(G))},[Symbol.asyncIterator](){return{next(){return q.length>0?Promise.resolve({value:q.shift(),done:!1}):M?Promise.resolve({value:void 0,done:!0}):new Promise(S=>L.push(S))},return(){return A(),Promise.resolve({value:void 0,done:!0})}}}};return n.format!=null&&this._attachFormatLogger(F,n),F}_attachFormatLogger(e,n){let r=n.format;if(r==null)return;let s=n.logger??(c=>console.log(c)),o=n.includeTypes?new Set(n.includeTypes):null,i=n.excludeTypes?new Set(n.excludeTypes):null,a=o==null&&i==null?()=>!0:c=>(o==null||o.has(c))&&(i==null||!i.has(c)),u=wr(n.theme),l=r==="stage-log"?ge():0,d=c=>c==null?"":n.stageLabels?.[c]??c,f=(c,v)=>c.length>v?`${c.slice(0,v-1)}\u2026`:c,p=c=>c.type==="data"||c.type==="error"?f(Je(c.data),120):"",h=c=>{if(r==="stage-log"){let x=(ge()-l)/1e9,k=d(c.path).padEnd(9);if(c.type==="data"){let N=p(c);return`[${x.toFixed(3)}s] ${k} \u2190${N?` ${N}`:""}`}if(c.type==="error"){let N=p(c);return`[${x.toFixed(3)}s] ${k} \u2717${N?` ${N}`:""}`}return c.type==="complete"?`[${x.toFixed(3)}s] ${k} \u25A0 complete`:`[${x.toFixed(3)}s] ${k} ${c.type}`}if(r==="json")try{return JSON.stringify(c)}catch{return JSON.stringify({type:c.type,path:c.path,data:"[unserializable]"})}let v=u[c.type]??"",T=c.path?`${u.path}${c.path}${u.reset} `:"",w=c.type==="data"||c.type==="error",g=c.type==="pause"||c.type==="resume",y=w?` ${Je(c.data)}`:g?` ${Je(c.lockId)}`:"",_=c.type==="data"||c.type==="resolved"||c.type==="derived"?c:void 0,m=_?.trigger_dep_name!=null?` <- ${_.trigger_dep_name}`:_?.trigger_dep_index!=null?` <- #${_.trigger_dep_index}`:"",b=c.in_batch?" [batch]":"";return`${T}${v}${c.type.toUpperCase()}${u.reset}${y}${m}${b}`};e.onEvent(c=>{a(c.type)&&s(h(c),c)})}addDisposer(e){return this._disposers.add(e),()=>{this._disposers.delete(e)}}destroy(){tn(this._disposers,this.name),this.signal([[J]],{internal:!0}),tn(this._storageDisposers,this.name);for(let e of[...this._mounts.values()])e._parent=void 0,e._destroyClearOnly();this._mounts.clear(),this._nodes.clear(),this._parent=void 0,this._destroyed=!0}get destroyed(){return this._destroyed}_destroyClearOnly(){for(let e of[...this._mounts.values()])e._parent=void 0,e._destroyClearOnly();this._mounts.clear(),this._nodes.clear(),this._parent=void 0,this._destroyed=!0}snapshot(e){let{expand:n,...r}=this.describe({detail:"full"}),s={};for(let a of Object.keys(r.nodes).sort()){let{lastMutation:u,guard:l,...d}=r.nodes[a];s[a]=d}let o=[...r.subgraphs].sort(),i={...r,version:1,nodes:s,subgraphs:o};if(e?.format==null)return i;if(e.format==="json-string")return JSON.stringify(i);if(e.format==="bytes"){if(e.codec==null)throw new Error("snapshot({format: 'bytes'}) requires a `codec` name");let a=this.config.lookupCodec(e.codec);if(a==null)throw new Error(`snapshot: codec "${e.codec}" is not registered on this graph's config. Call config.registerCodec(...) before creating nodes.`);return wt(a,a.encode(i))}throw new Error(`snapshot: unknown format "${String(e.format)}"`)}static decode(e,n){let r=n?.config??be,{codec:s,codecVersion:o,payload:i}=_t(e,r);return s.decode(i,o)}restore(e,n){if(nn(e),e.name!==this.name)throw new Error(`Graph "${this.name}": restore snapshot name "${e.name}" does not match this graph`);let r=n?.only==null?null:(Array.isArray(n.only)?n.only:[n.only]).map(o=>Ye(o)),s=n?.includeProducers===!0;for(let o of Object.keys(e.nodes).sort()){if(r!==null&&!r.some(a=>a.test(o)))continue;let i=e.nodes[o];if(i!==void 0){if(!("value"in i)||i.value===void 0){"value"in i&&i.value===void 0&&n?.onError?.(o,new Error(`restore: slice.value is undefined for "${o}" (undefined is the global SENTINEL; not valid DATA)`));continue}if(!(i.type==="derived"||i.type==="effect")&&!(i.type==="producer"&&!s)){if(i.v!=null){let u=this.tryResolve(o)?.v;if(u!=null&&u.id===i.v.id&&u.version===i.v.version)continue}try{this.set(o,i.value)}catch(a){n?.onError?.(o,a)}}}}}static fromSnapshot(e,n){nn(e);let r=typeof n=="function"?n:n?.build,s=typeof n=="function"?void 0:n?.factories,o=new t(e.name);if(r)return r(o),o.restore(e),o;for(let h of[...e.subgraphs].sort((c,v)=>{let T=c.split(P).length,w=v.split(P).length;return T!==w?T-w:c<v?-1:c>v?1:0})){let c=h.split(P),v=o;for(let T of c)v._mounts.has(T)||v.mount(T,new t(T)),v=v._mounts.get(T)}let i=s?Object.entries(s).map(([h,c])=>({re:Ye(h),factory:c})):[],a=h=>{for(let c of i)if(c.re.test(h))return c.factory},u=h=>{let c=h.split(P),v=c.pop();if(v==null||v.length===0)throw new Error(`invalid snapshot path "${h}"`);let T=o;for(let w of c){let g=T._mounts.get(w);if(!g)throw new Error(`unknown mount "${w}" in path "${h}"`);T=g}return[T,v]},l=Object.entries(e.nodes).filter(([h])=>!h.includes(`${P}${se}${P}`)).sort((h,c)=>h[0]<c[0]?-1:h[0]>c[0]?1:0),d=new Map(l),f=new Map,p=!0;for(;d.size>0&&p;){p=!1;for(let[h,c]of[...d.entries()]){let v=c?.deps??[];if(!v.every(m=>f.has(m)))continue;let[T,w]=u(h),g={...c?.meta??{}},y=a(h),_;if(c?.type==="state")_=X(c.value,{meta:g});else{if(y==null)continue;_=y(w,{path:h,type:c.type,value:c.value,meta:g,deps:v,resolvedDeps:v.map(m=>f.get(m))})}T.add(_,{name:w}),f.set(h,_),d.delete(h),p=!0}}if(d.size>0){let h=[...d.keys()].sort().join(", ");throw new Error(`Graph.fromSnapshot could not reconstruct nodes without build callback: ${h}. Pass matching factories via fromSnapshot(data, { factories: { pattern: factoryFn } }).`)}return o.restore(e),o}toJSON(){return this.snapshot()}attachSnapshotStorage(e,n={}){let r=e.map(l=>({tier:l,debounceMs:Math.max(0,l.debounceMs??0),compactEvery:Math.max(1,l.compactEvery??10),timer:void 0,seq:0,lastSnapshot:void 0,lastFingerprint:"",disposed:!1,savePending:void 0}));n.autoRestore===!0&&this._cascadeRestore(e,n.onError);let s=(l,d)=>{if(l.disposed)return;let f=ur(d.nodes);if(l.lastSnapshot!=null&&f!==""&&f===l.lastFingerprint)return;let p=l.seq+1,h=Pe(),T=l.lastSnapshot==null||p%l.compactEvery===0?{name:this.name,mode:"full",snapshot:d,seq:p,timestamp_ns:h,format_version:ve}:{name:this.name,mode:"diff",diff:Sr(l.lastSnapshot,d),seq:p,timestamp_ns:h,format_version:ve};if(l.tier.filter&&!l.tier.filter(T))return;let w;try{w=l.tier.save(T)}catch(g){n.onError?.(g,l.tier);return}if(w&&typeof w.then=="function"){let _=(l.savePending??Promise.resolve()).then(()=>w,()=>w).then(()=>{l.disposed||(l.seq=p,l.lastSnapshot=d,l.lastFingerprint=f)},m=>{n.onError?.(m,l.tier)});l.savePending=_.finally(()=>{l.savePending===_&&(l.savePending=void 0)})}else l.seq=p,l.lastSnapshot=d,l.lastFingerprint=f},o=(l,d)=>{try{s(l,d)}catch(f){n.onError?.(f,l.tier)}},i=(l,d)=>{if(!d.some(c=>{let v=this.config.messageTier(c[0]);return v>=3&&v<5}))return;if(n.filter){let c=this.tryResolve(l);if(c==null)return;let v=Ne(c,ye("standard"));if(!n.filter(l,v))return}let p,h=()=>(p==null&&(p=this.snapshot()),p);for(let c of r)c.disposed||(c.debounceMs===0?o(c,h()):(c.timer==null&&(c.timer=new Ve),c.timer.start(c.debounceMs,()=>{c.disposed||o(c,this.snapshot())})))},a;if(n.paths!=null){let d=(typeof n.paths=="string"?this._pathsMatching(n.paths):n.paths).map(f=>{let p=this.tryResolve(f);return p==null?()=>{}:p.subscribe(h=>i(f,h))});a=()=>{for(let f of d)f()}}else a=this.observe().subscribe((l,d)=>i(l,d));let u=()=>{a();for(let l of r)l.disposed=!0,l.timer?.cancel();this._storageDisposers.delete(u)};return this._storageDisposers.add(u),{dispose:u}}async _cascadeRestore(e,n){for(let r of e){let s;try{s=await r.load?.()}catch(i){n?.(i,r);continue}if(s==null||typeof s!="object"||Array.isArray(s))continue;let o=s;try{if(o.mode==="full"&&o.snapshot!=null)return this.restore(o.snapshot),!0;if(o.version===ve&&o.nodes!=null)return this.restore(o),!0}catch(i){n?.(i,r)}}return!1}static async fromStorage(e,n,r){for(let s of n){let o;try{o=await s.load?.()}catch(u){r?.onError?.(u,s);continue}if(o==null||typeof o!="object"||Array.isArray(o))continue;let i=o,a=i.mode==="full"&&i.snapshot!=null?i.snapshot:i.version===ve&&i.nodes!=null?i:void 0;if(a!=null)try{return t.fromSnapshot(a,r)}catch(u){r?.onError?.(u,s)}}throw new Error(`Graph.fromStorage: no tier held a restorable record for "${e}" across ${n.length} tier(s)`)}_annotations=new Map;_traceRing;trace(e,n,r){if(e!=null&&n!=null){if(this.tryResolve(e)==null)return;if(this._annotations.set(e,n),this.config.inspectorEnabled){let s={path:e,annotation:n,timestamp_ns:ge(),...r?.actor!=null?{actor:r.actor}:{}};this._traceRing.push(s)}return}return e!=null?this.config.inspectorEnabled?this._annotations.get(e):void 0:this.config.inspectorEnabled?this._traceRing.toArray():[]}annotation(e){return this._annotations.get(e)}clearTrace(){this._annotations.clear(),this._traceRing.clear()}pruneTrace(e){let n=this._traceRing.toArray().filter(s=>!e(s)),r=this._traceRing.size-n.length;this._traceRing.clear();for(let s of n)this._traceRing.push(s);return r}static diff(e,n){let r=new Set(Object.keys(e.nodes)),s=new Set(Object.keys(n.nodes)),o=[...s].filter(g=>!r.has(g)).sort(),i=[...r].filter(g=>!s.has(g)).sort(),a=[],u=[];for(let g of r){if(!s.has(g))continue;let y=e.nodes[g],_=n.nodes[g],m=y.v,b=_.v;m!=null&&b!=null&&m.id===b.id&&m.version!==b.version&&u.push({path:g,id:m.id,from:m.version,to:b.version});let x=m!=null&&b!=null&&m.id===b.id&&m.version===b.version;for(let k of["type","status","sentinel"]){let N=y[k],D=_[k];N!==D&&a.push({path:g,field:k,from:N,to:D})}if(!x)for(let k of["value","meta"]){let N=y[k],D=_[k];lr(N,D)||a.push({path:g,field:k,from:N,to:D})}}let l=g=>`${g.from} ${g.to}`,d=new Set(e.edges.map(l)),f=new Set(n.edges.map(l)),p=n.edges.filter(g=>!d.has(l(g))),h=e.edges.filter(g=>!f.has(l(g))),c=new Set(e.subgraphs),v=new Set(n.subgraphs),T=[...v].filter(g=>!c.has(g)).sort(),w=[...c].filter(g=>!v.has(g)).sort();return{nodesAdded:o,nodesRemoved:i,nodesChanged:a,versionChanges:u,edgesAdded:p,edgesRemoved:h,subgraphsAdded:T,subgraphsRemoved:w}}};function Sr(t,e){let n=Re.diff(t,e),r={};for(let s of n.nodesAdded){let o=e.nodes[s];o!=null&&(r[s]=o)}return{...n,nodesAddedFull:r}}function sn(t,e,n,r={}){let s={paths:[],depths:new Map,truncated:!1};if(!e)return r.withDetail?s:[];if(!r.both&&n!=="upstream"&&n!=="downstream")throw new Error('reachable: direction must be "upstream" or "downstream"');let o=r.maxDepth;if(o!=null&&(!Number.isInteger(o)||o<0))throw new Error("reachable: maxDepth must be an integer >= 0");if(o===0)return r.withDetail?s:[];let i=new Map,a=new Map,u=new Map,l=new Map,d=new Set;for(let[y,_]of Object.entries(t.nodes)){if(!y)continue;d.add(y);let m=_.deps??[];i.set(y,m);for(let b of m)b&&(d.add(b),a.has(b)||a.set(b,new Set),a.get(b).add(y))}for(let y of t.edges){if(y==null||typeof y!="object")continue;let _=typeof y.from=="string"?y.from:"",m=typeof y.to=="string"?y.to:"";!_||!m||(d.add(_),d.add(m),l.has(_)||l.set(_,new Set),l.get(_).add(m),u.has(m)||u.set(m,new Set),u.get(m).add(_))}if(!d.has(e))return r.withDetail?s:[];let f=r.both===!0,p=y=>{if(f){let x=i.get(y)??[],k=u.get(y),N=a.get(y),D=l.get(y),E=[...x];return k&&E.push(...k),N&&E.push(...N),D&&E.push(...D),E}if(n==="upstream"){let x=i.get(y)??[],k=u.get(y);return k?[...x,...k]:x}let _=a.get(y),m=l.get(y),b=_?[..._]:[];return m&&b.push(...m),b},h=new Set([e]),c=new Map,v=[{path:e,depth:0}],T=0,w=!1;for(;T<v.length;){let y=v[T++];if(o!=null&&y.depth>=o){p(y.path).length>0&&(w=!0);continue}for(let _ of p(y.path))!_||h.has(_)||(h.add(_),c.set(_,y.depth+1),v.push({path:_,depth:y.depth+1}))}let g=[...c.keys()].sort((y,_)=>y<_?-1:y>_?1:0);return r.withDetail?{paths:g,depths:c,truncated:w}:g}function Or(t,e){if(t.length!==e.length)return!1;for(let n=0;n<t.length;n++){let r=t[n],s=e[n];if(r.path!==s.path||r.type!==s.type||r.status!==s.status||r.hop!==s.hop||r.dep_index!==s.dep_index||r.annotation!==s.annotation||r.value!==s.value||r.lastMutation!==s.lastMutation)return!1;let o=r.v,i=s.v;if(o!==i&&(o==null||i==null||o.id!==i.id||o.version!==i.version))return!1}return!0}function Nr(t){for(let e of t){let n=e.codePointAt(0);if(n>=19968&&n<=40959||n>=13312&&n<=19903||n>=12288&&n<=12351||n>=12352&&n<=12447||n>=12448&&n<=12543||n>=44032&&n<=55215||n>=65280&&n<=65519)return!0}return!1}var cn=new Set(["\uFF0C","\uFF0E","\uFF01","\uFF1A","\uFF1B","\uFF1F","\u3001","\u3002","\u30FB","\uFF09","\u3015","\u3009","\u300B","\u300D","\u300F","\u3011"]),Er=new Set([".",",","!","?",":",";",")","]","}","%",'"',"\u201D","\u2019","\xBB","\u203A","\u2026"]);function Rr(t){return t.replace(/[\t\n\r\f ]+/g," ").replace(/^ | $/g,"")}function Cr(t){let e=new Intl.Segmenter(void 0,{granularity:"word"}),n=[];for(let r of e.segment(t)){let s=r.segment,o=r.isWordLike??!1,i=[],a=[],u=[],l="",d=null;for(let f of s){let p;f===" "?p="space":f==="\u200B"?p="zero-width-break":f==="\xAD"?p="soft-hyphen":f===`
8
+ `?p="hard-break":p="text",d!==null&&p===d?l+=f:(d!==null&&(i.push(l),a.push(d==="text"&&o),u.push(d)),l=f,d=p)}d!==null&&(i.push(l),a.push(d==="text"&&o),u.push(d)),n.push({texts:i,isWordLike:a,kinds:u})}return n}function bt(t,e,n,r,s){let o=Rr(t);if(o.length===0)return[];let i=Cr(o),a=new Intl.Segmenter(void 0,{granularity:"grapheme"}),u=[],l=[],d=[];for(let w of i)for(let g=0;g<w.texts.length;g++)u.push(w.texts[g]),l.push(w.kinds[g]),d.push(w.isWordLike[g]);let f=[],p=[],h=[];for(let w=0;w<u.length;w++){let g=u[w],y=l[w],_=d[w];if(y==="text"&&!_&&f.length>0&&p[p.length-1]==="text"&&g.length===1&&(Er.has(g)||cn.has(g))){f[f.length-1]+=g;continue}if(g==="-"&&f.length>0&&p[p.length-1]==="text"&&h[h.length-1]){f[f.length-1]+=g;continue}f.push(g),p.push(y),h.push(_)}let c=r.get(e);c||(c=new Map,r.set(e,c));function v(w){let g=c.get(w);if(g===void 0){s&&(s.misses+=1);let y=n.measureSegment(w,e).width;g=Number.isFinite(y)&&y>=0?y:0,c.set(w,g)}else s&&(s.hits+=1);return g}let T=[];for(let w=0;w<f.length;w++){let g=f[w],y=p[w];if(y!=="text"){T.push({text:g,width:y==="space"?v(" ")*g.length:0,kind:y,graphemeWidths:null});continue}if(Nr(g)){let b="";for(let x of a.segment(g)){let k=x.segment;if(b.length>0&&cn.has(k)){b+=k;continue}if(b.length>0){let N=v(b);T.push({text:b,width:N,kind:"text",graphemeWidths:null})}b=k}if(b.length>0){let x=v(b);T.push({text:b,width:x,kind:"text",graphemeWidths:null})}continue}let _=v(g),m=null;if(h[w]&&g.length>1){let b=[];for(let x of a.segment(g))b.push(v(x.segment));b.length>1&&(m=b)}T.push({text:g,width:_,kind:"text",graphemeWidths:m})}return T}function yt(t,e,n,r,s){if(t.length===0)return{lines:[],lineCount:0};let o=[],i=0,a=!1,u=0,l=0,d=0,f=0,p=-1,h=0,c=s.get(r);c||(c=new Map,s.set(r,c));let v=c.get("-");v===void 0&&(v=n.measureSegment("-",r).width,c.set("-",v));function T(m=d,b=f,x=i){let k="";for(let N=u;N<m;N++){let D=t[N];if(!(D.kind==="soft-hyphen"||D.kind==="hard-break"))if(N===u&&l>0&&D.graphemeWidths){let C=[...new Intl.Segmenter(void 0,{granularity:"grapheme"}).segment(D.text)].map(R=>R.segment);k+=C.slice(l).join("")}else k+=D.text}if(b>0&&m<t.length){let N=t[m],E=[...new Intl.Segmenter(void 0,{granularity:"grapheme"}).segment(N.text)].map(R=>R.segment),C=u===m?l:0;k+=E.slice(C,b).join("")}m>0&&t[m-1]?.kind==="soft-hyphen"&&!(u===m&&l>0)&&(k+="-"),o.push({text:k,width:x,startSegment:u,startGrapheme:l,endSegment:m,endGrapheme:b}),i=0,a=!1,p=-1,h=0}function w(m){return m==="space"||m==="zero-width-break"||m==="soft-hyphen"}function g(m,b,x){a=!0,u=m,l=b,d=m+1,f=0,i=x}function y(m,b,x){a=!0,u=m,l=b,d=m,f=b+1,i=x}for(let m=0;m<t.length;m++){let b=t[m];if(b.kind==="hard-break"){a?T():o.push({text:"",width:0,startSegment:m,startGrapheme:0,endSegment:m,endGrapheme:0}),u=m+1,l=0;continue}let x=b.width;if(!a){x>e&&b.graphemeWidths?_(m,0,b.graphemeWidths):g(m,0,x),w(b.kind)&&(p=m+1,h=b.kind==="space"?i-x:i);continue}let k=i+x;if(k>e+.005){if(w(b.kind)){i+=x,d=m+1,f=0,T(m+1,0,b.kind==="space"?i-x:i);continue}if(p>=0){T(p,0,h),m--;continue}if(x>e&&b.graphemeWidths){T(),_(m,0,b.graphemeWidths);continue}T(),m--;continue}i=k,d=m+1,f=0,w(b.kind)&&(p=m+1,h=b.kind==="space"?i-x:i)}return a&&T(),{lines:o,lineCount:o.length};function _(m,b,x){for(let k=b;k<x.length;k++){let N=x[k];if(!a){y(m,k,N);continue}i+N>e+.005?(T(),y(m,k,N)):(i+=N,d=m,f=k+1)}a&&d===m&&f===x.length&&(d=m+1,f=0)}}function Ce(t){return Math.max(0,Math.min(1,t))}function Ar(t){let e=Ce(t?.mainRatio??.65),n=Ce(t?.sideSplit??.5),r=Math.max(0,t?.viewportWidth??1280),s=t?.nodeRegistry??new Map,o=t?.adapter??null,i=t?.layoutFont??"14px monospace",a=t?.onHighlight,u=new Re("demo-shell"),l=X(e,{name:"pane/main-ratio"}),d=X(n,{name:"pane/side-split"}),f=X(null,{name:"pane/fullscreen"}),p=X(r,{name:"viewport/width"});u.add(l,{name:"pane/main-ratio"}),u.add(d,{name:"pane/side-split"}),u.add(f,{name:"pane/fullscreen"}),u.add(p,{name:"viewport/width"});let h=j([l,p,f],([O,M,A])=>{let q=O,L=M,F=A;return F==="main"?L:F==="graph"||F==="code"?0:Math.round(L*q)},{name:"pane/main-width"}),c=j([h,p,f],([O,M,A])=>{let q=A,L=M;return q==="main"?0:q==="graph"||q==="code"?L:L-O},{name:"pane/side-width"}),v=j([d,f],([O,M])=>{let A=M;return A==="graph"?1:A==="code"||A==="main"?0:Ce(O)},{name:"pane/graph-height-ratio"}),T=j([v,f],([O,M])=>{let A=M;return A==="code"?1:A==="graph"||A==="main"?0:1-O},{name:"pane/code-height-ratio"});u.add(h,{name:"pane/main-width"}),u.add(c,{name:"pane/side-width"}),u.add(v,{name:"pane/graph-height-ratio"}),u.add(T,{name:"pane/code-height-ratio"});let w=X(null,{name:"demo/graph-ref"}),g=X(0,{name:"demo/graph-tick"});u.add(w,{name:"demo/graph-ref"}),u.add(g,{name:"demo/graph-tick"});let y=j([w,g],([O,M])=>{let A=O;return A?A.describe({format:"mermaid"}):""},{name:"graph/mermaid"}),_=j([w,g],([O,M])=>{let A=O;if(!A)return null;let{expand:q,...L}=A.describe({detail:"standard"});return L},{name:"graph/describe"});u.add(y,{name:"graph/mermaid"}),u.add(_,{name:"graph/describe"});let m=X(null,{name:"hover/target"});u.add(m,{name:"hover/target"});let b=j([m],([O])=>{let M=O;if(!M)return null;let A=s.get(M.id);return A?A.codeLine:null},{name:"highlight/code-scroll"}),x=j([m],([O])=>{let M=O;if(!M)return null;let A=s.get(M.id);return A?A.visualSelector:null},{name:"highlight/visual"}),k=j([m],([O])=>{let M=O;return M?M.id:null},{name:"highlight/graph"});if(u.add(b,{name:"highlight/code-scroll"}),u.add(x,{name:"highlight/visual"}),u.add(k,{name:"highlight/graph"}),a?.codeScroll){let O=a.codeScroll,M=Be([b],([A])=>{O(A)});u.add(M,{name:"highlight/apply-code-scroll"})}if(a?.visual){let O=a.visual,M=Be([x],([A])=>{O(A)});u.add(M,{name:"highlight/apply-visual"})}if(a?.graph){let O=a.graph,M=Be([k],([A])=>{O(A)});u.add(M,{name:"highlight/apply-graph"})}let N=X(null,{name:"inspect/selected-node"});u.add(N,{name:"inspect/selected-node"});let D=ye("standard"),E=j([N,w,g],([O,M,A])=>{let q=M,L=O;if(!q||!L)return null;try{let F=q.resolve(L),S=Ne(F,D);return{path:L,...S,value:F.cache}}catch{return null}},{name:"inspect/node-detail"}),C=j([w,g],([O,M])=>{let A=O;return A?A.trace():[]},{name:"inspect/trace-log"});u.add(E,{name:"inspect/node-detail"}),u.add(C,{name:"inspect/trace-log"});let R=X(!1,{name:"meta/debug"});u.add(R,{name:"meta/debug"});let $=j([R,g],([O,M])=>O?u.describe({format:"mermaid"}):"",{name:"meta/shell-mermaid"});u.add($,{name:"meta/shell-mermaid"});let U=X("",{name:"layout/code-text"});if(u.add(U,{name:"layout/code-text"}),o){let O=new Map,M=j([_],([L])=>{let F=L;if(!F)return new Map;let S=new Map;for(let[G]of Object.entries(F.nodes)){let W=bt(G,i,o,O),ne=yt(W,1/0,o,i,O),z=ne.lines.reduce((K,xe)=>Math.max(K,xe.width),0),I=ne.lineCount*20;S.set(G,{width:z,height:I})}return S},{name:"layout/graph-labels",equals:(L,F)=>{if(L===F)return!0;let S=L,G=F;if(S.size!==G.size)return!1;for(let[W,ne]of S){let z=G.get(W);if(!z||z.width!==ne.width||z.height!==ne.height)return!1}return!0}}),A=j([U,c],([L,F])=>{let S=L;if(!S)return{lineCount:0,lines:[]};let G=bt(S,i,o,O),W=F-40;return yt(G,Math.max(100,W),o,i,O)},{name:"layout/code-lines"}),q=j([M],([L])=>{let F=L;if(F.size===0)return 200;let S=0;for(let{width:G}of F.values())G>S&&(S=G);return Math.max(200,Math.round(S+80))},{name:"layout/side-width-hint"});u.add(M,{name:"layout/graph-labels"}),u.add(A,{name:"layout/code-lines"}),u.add(q,{name:"layout/side-width-hint"})}let Z=0;return{graph:u,setMainRatio(O){u.set("pane/main-ratio",Ce(O))},setSideSplit(O){u.set("pane/side-split",Ce(O))},setFullscreen(O){u.set("pane/fullscreen",O)},setViewportWidth(O){u.set("viewport/width",Math.max(0,O))},setHoverTarget(O){u.set("hover/target",O)},setDemoGraph(O){u.set("demo/graph-ref",O)},bumpGraphTick(){u.set("demo/graph-tick",++Z)},selectNode(O){u.set("inspect/selected-node",O)},setMetaDebug(O){u.set("meta/debug",O)},setCodeText(O){u.set("layout/code-text",O)},batch(O){De(O)},destroy(){u.destroy()}}}0&&(module.exports={demoShell});
@@ -1,6 +1,6 @@
1
- import '../../graph-kTltt95s.cjs';
2
- import '../../reactive-layout-D9zqqaqK.cjs';
3
- export { D as DemoShellHandle, a as DemoShellOptions, F as FullscreenPane, G as GraphLabelSize, H as HighlightCallbacks, b as HoverPaneType, c as HoverTarget, N as NodeRegistry, d as demoShell } from '../../index-PluovH45.cjs';
1
+ import '../../graph-CaNXUc3c.cjs';
2
+ import '../../reactive-layout-DrGjuwyC.cjs';
3
+ export { D as DemoShellHandle, a as DemoShellOptions, F as FullscreenPane, G as GraphLabelSize, H as HighlightCallbacks, b as HoverPaneType, c as HoverTarget, N as NodeRegistry, d as demoShell } from '../../index-BwtIbzSV.cjs';
4
4
  import '../../node-fSc-hCv8.cjs';
5
5
  import '../../meta-BGO6C7K9.cjs';
6
6
  import '../../extra/storage-core.cjs';
@@ -1,6 +1,6 @@
1
- import '../../graph-Cv-8x0ZI.js';
2
- import '../../reactive-layout-Btv0-efV.js';
3
- export { D as DemoShellHandle, a as DemoShellOptions, F as FullscreenPane, G as GraphLabelSize, H as HighlightCallbacks, b as HoverPaneType, c as HoverTarget, N as NodeRegistry, d as demoShell } from '../../index-BBdwz2BW.js';
1
+ import '../../graph-YQXDndFy.js';
2
+ import '../../reactive-layout-BDdngW56.js';
3
+ export { D as DemoShellHandle, a as DemoShellOptions, F as FullscreenPane, G as GraphLabelSize, H as HighlightCallbacks, b as HoverPaneType, c as HoverTarget, N as NodeRegistry, d as demoShell } from '../../index-CajEOoAN.js';
4
4
  import '../../node-fSc-hCv8.js';
5
5
  import '../../meta-CC6EPdpK.js';
6
6
  import '../../extra/storage-core.js';
@@ -1 +1 @@
1
- import{a}from"../../chunk-XINLP35X.js";import"../../chunk-YOUAVGHJ.js";import"../../chunk-O32GJOUJ.js";import"../../chunk-5KPIYVCC.js";import"../../chunk-SGS4OJGS.js";import"../../chunk-ESMPEKEV.js";import"../../chunk-533RQFF6.js";import"../../chunk-MQZWA3DF.js";import"../../chunk-LYCLF26R.js";import"../../chunk-CK2E7BTU.js";import"../../chunk-QYADASLV.js";export{a as demoShell};
1
+ import{a}from"../../chunk-WSLN4JFO.js";import"../../chunk-QP5TH523.js";import"../../chunk-O32GJOUJ.js";import"../../chunk-B4L5X2QO.js";import"../../chunk-SGS4OJGS.js";import"../../chunk-ESMPEKEV.js";import"../../chunk-533RQFF6.js";import"../../chunk-MQZWA3DF.js";import"../../chunk-LYCLF26R.js";import"../../chunk-CK2E7BTU.js";import"../../chunk-QYADASLV.js";export{a as demoShell};