@graphrefly/graphrefly 0.31.0 → 0.32.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 (177) hide show
  1. package/dist/chunk-2JNT5NDF.js +61 -0
  2. package/dist/{chunk-KN4Q5MQO.js → chunk-2RH4QNDQ.js} +1 -1
  3. package/dist/chunk-4JBKKUCJ.js +7 -0
  4. package/dist/{chunk-WLPVGXQ6.js → chunk-4YGJ7KZ6.js} +1 -1
  5. package/dist/{chunk-3Q2WXM6X.js → chunk-5PBXUVHI.js} +1 -1
  6. package/dist/{chunk-WYJTXYWX.js → chunk-7EMUF2RY.js} +1 -1
  7. package/dist/chunk-7JZ3YORY.js +80 -0
  8. package/dist/{chunk-I4U3TPK2.js → chunk-7QS77X6G.js} +1 -1
  9. package/dist/{chunk-ZM7C2FUM.js → chunk-BU4SUZSA.js} +1 -1
  10. package/dist/{chunk-GF5T7PGC.js → chunk-CNXUW2CU.js} +1 -1
  11. package/dist/{chunk-Z3UWIJ3A.js → chunk-EIFHFDFD.js} +1 -1
  12. package/dist/{chunk-3JRKP4BH.js → chunk-JAHAJU4G.js} +1 -1
  13. package/dist/{chunk-4ZPO2EL5.js → chunk-JYMNVEH6.js} +1 -1
  14. package/dist/{chunk-4KAUNEKV.js → chunk-KD3IYBTD.js} +1 -1
  15. package/dist/{chunk-X2VHDT26.js → chunk-LG73TUF4.js} +2 -2
  16. package/dist/{chunk-JXRZXP3N.js → chunk-LJGPOJHS.js} +1 -1
  17. package/dist/{chunk-YQJPYEAL.js → chunk-M2VFLRPJ.js} +1 -1
  18. package/dist/{chunk-7EQPXQ7H.js → chunk-MFNOZ5E6.js} +1 -1
  19. package/dist/{chunk-YZ6VYLFD.js → chunk-PWKLZ2XU.js} +1 -1
  20. package/dist/{chunk-OKQUPJRY.js → chunk-TOCCHQI6.js} +1 -1
  21. package/dist/{chunk-PZP4MEXK.js → chunk-UXEB35L4.js} +1 -1
  22. package/dist/{chunk-EBQ6FXKW.js → chunk-VXJX3ZZP.js} +1 -1
  23. package/dist/{chunk-7EJTWGKW.js → chunk-WE32AFFA.js} +1 -1
  24. package/dist/{chunk-JMGGCSIC.js → chunk-WF3V5X2L.js} +1 -1
  25. package/dist/{chunk-YZKGGMPT.js → chunk-X4OOM6QU.js} +1 -1
  26. package/dist/{chunk-5LJAQTSS.js → chunk-ZWETYYQG.js} +1 -1
  27. package/dist/compat/index.cjs +1 -1
  28. package/dist/compat/index.d.cts +5 -5
  29. package/dist/compat/index.d.ts +5 -5
  30. package/dist/compat/index.js +1 -1
  31. package/dist/compat/nestjs/index.cjs +1 -1
  32. package/dist/compat/nestjs/index.d.cts +3 -3
  33. package/dist/compat/nestjs/index.d.ts +3 -3
  34. package/dist/compat/nestjs/index.js +1 -1
  35. package/dist/compat/zustand/index.cjs +1 -1
  36. package/dist/compat/zustand/index.d.cts +2 -2
  37. package/dist/compat/zustand/index.d.ts +2 -2
  38. package/dist/compat/zustand/index.js +1 -1
  39. package/dist/extra/index.cjs +1 -1
  40. package/dist/extra/index.d.cts +2 -2
  41. package/dist/extra/index.d.ts +2 -2
  42. package/dist/extra/index.js +1 -1
  43. package/dist/graph/index.cjs +1 -1
  44. package/dist/graph/index.d.cts +3 -3
  45. package/dist/graph/index.d.ts +3 -3
  46. package/dist/graph/index.js +1 -1
  47. package/dist/{graph-CWeI0aHd.d.ts → graph-BOhEGJ6E.d.ts} +10 -0
  48. package/dist/{graph-C4Uxwv0T.d.cts → graph-CdJeX7O7.d.cts} +10 -0
  49. package/dist/{index-B-z8WaSd.d.cts → index-BDLy6CQ9.d.cts} +1 -1
  50. package/dist/{index-iBp74eGU.d.cts → index-BJDXj9Wf.d.cts} +2 -2
  51. package/dist/{index-BBINVimG.d.ts → index-BUZPTPSQ.d.ts} +2 -2
  52. package/dist/{index-DnrZghBB.d.ts → index-BbcSZCAG.d.ts} +1 -1
  53. package/dist/{index-lKuLYmHO.d.cts → index-BiGeETJs.d.cts} +1 -1
  54. package/dist/{index-Dm3_D5Ta.d.cts → index-BmZb8fNF.d.cts} +2 -2
  55. package/dist/{index-Docdiu9a.d.ts → index-Bnmttu35.d.ts} +1 -1
  56. package/dist/{index-CZChc85Q.d.cts → index-BuN2wGJs.d.cts} +297 -22
  57. package/dist/{index-Cy7eFeIX.d.cts → index-BwdPDWI4.d.cts} +1 -1
  58. package/dist/{index-DylQCKEL.d.cts → index-BzxU4yhV.d.cts} +11 -2
  59. package/dist/{index-D9Y_u6BG.d.cts → index-C-Gsh-0a.d.cts} +2 -2
  60. package/dist/{index-DD7RhHNJ.d.cts → index-C22aTC1X.d.cts} +4 -4
  61. package/dist/{index-yIdWFo2b.d.cts → index-C4QTaDli.d.cts} +2 -2
  62. package/dist/{index-CJymKyzT.d.ts → index-C7RqYbOZ.d.ts} +1 -1
  63. package/dist/{index-C5Ghnp5B.d.ts → index-C9qCLIN4.d.ts} +2 -2
  64. package/dist/{index-DVNLe3pS.d.cts → index-CCdg0JLX.d.cts} +1 -1
  65. package/dist/{index-B5iVOD7w.d.ts → index-CEoU-r-g.d.ts} +2 -2
  66. package/dist/{index-CfFYyLR8.d.ts → index-CHfBm51k.d.ts} +11 -2
  67. package/dist/{index-BXzl1NDD.d.ts → index-CNyiYQWF.d.ts} +4 -4
  68. package/dist/{index-C6NBfXj-.d.ts → index-CVevMZ0n.d.ts} +2 -2
  69. package/dist/{index-DGb1awva.d.ts → index-CZUzi6Dy.d.ts} +2 -2
  70. package/dist/{index-FrYrV-Vf.d.ts → index-Ckl03Q0s.d.ts} +1 -1
  71. package/dist/{index-Bvi5uJxX.d.ts → index-CmSjld-4.d.ts} +1 -1
  72. package/dist/{index-9iguV3bF.d.cts → index-CnjUhRbs.d.cts} +2 -2
  73. package/dist/{index-C98oJsEs.d.cts → index-D3HcdZ4d.d.cts} +1 -1
  74. package/dist/{index-IZ3l_vQ9.d.ts → index-DD1czHj3.d.ts} +1 -1
  75. package/dist/{index-gJQqJTKx.d.cts → index-DNhTQReY.d.cts} +1 -1
  76. package/dist/{index-UZO988ox.d.cts → index-DSawGt8n.d.cts} +2 -2
  77. package/dist/{index-CcpEvuPl.d.cts → index-DUkuH3jP.d.cts} +1 -1
  78. package/dist/{index-CRAkoq-y.d.cts → index-DY2QbdoP.d.cts} +1 -1
  79. package/dist/{index-CvS9IuTG.d.ts → index-Dbmj0iYR.d.ts} +1 -1
  80. package/dist/{index-Bd6oFZqO.d.ts → index-DhlAMlm9.d.ts} +297 -22
  81. package/dist/{index-BMe3pCom.d.cts → index-DlGaEBW5.d.cts} +2 -2
  82. package/dist/{index-CotRMjtJ.d.ts → index-Dp_pS7Bw.d.ts} +1 -1
  83. package/dist/{index-DxMS0cHM.d.ts → index-Dxk-pUQI.d.ts} +2 -2
  84. package/dist/{index-DBQUKh59.d.cts → index-EGjF6iSY.d.cts} +3 -3
  85. package/dist/{index-D9HrBx2J.d.ts → index-LGzAYqdR.d.ts} +1 -1
  86. package/dist/{index-DR3gf_DG.d.cts → index-LzCJ0kMT.d.cts} +2 -2
  87. package/dist/{index-RQg6lTrN.d.ts → index-MV2yGIAq.d.ts} +2 -2
  88. package/dist/{index-Bs3-LC83.d.cts → index-_BXz9K7b.d.cts} +1 -1
  89. package/dist/{index-SSGqF8mI.d.cts → index-aBqZUx3B.d.cts} +1 -1
  90. package/dist/{index-CFW32Dy1.d.ts → index-eYHRkoK-.d.ts} +1 -1
  91. package/dist/{index-CwhcFzTA.d.ts → index-gXTVbSax.d.ts} +2 -2
  92. package/dist/{index-D-kHVedZ.d.cts → index-j33Lfb1G.d.cts} +22 -1
  93. package/dist/{index-BEpRsvhg.d.ts → index-lpGUhTBn.d.ts} +3 -3
  94. package/dist/{index-CcS0t-l2.d.ts → index-zMQIQuDu.d.ts} +22 -1
  95. package/dist/index.cjs +53 -50
  96. package/dist/index.d.cts +26 -26
  97. package/dist/index.d.ts +26 -26
  98. package/dist/index.js +1 -1
  99. package/dist/patterns/ai/index.cjs +21 -18
  100. package/dist/patterns/ai/index.d.cts +6 -6
  101. package/dist/patterns/ai/index.d.ts +6 -6
  102. package/dist/patterns/ai/index.js +1 -1
  103. package/dist/patterns/audit/index.cjs +1 -1
  104. package/dist/patterns/audit/index.d.cts +3 -3
  105. package/dist/patterns/audit/index.d.ts +3 -3
  106. package/dist/patterns/audit/index.js +1 -1
  107. package/dist/patterns/cqrs/index.cjs +1 -1
  108. package/dist/patterns/cqrs/index.d.cts +2 -2
  109. package/dist/patterns/cqrs/index.d.ts +2 -2
  110. package/dist/patterns/cqrs/index.js +1 -1
  111. package/dist/patterns/demo-shell/index.cjs +1 -1
  112. package/dist/patterns/demo-shell/index.d.cts +3 -3
  113. package/dist/patterns/demo-shell/index.d.ts +3 -3
  114. package/dist/patterns/demo-shell/index.js +1 -1
  115. package/dist/patterns/domain-templates/index.cjs +5 -5
  116. package/dist/patterns/domain-templates/index.d.cts +2 -2
  117. package/dist/patterns/domain-templates/index.d.ts +2 -2
  118. package/dist/patterns/domain-templates/index.js +1 -1
  119. package/dist/patterns/graphspec/index.cjs +27 -25
  120. package/dist/patterns/graphspec/index.d.cts +2 -2
  121. package/dist/patterns/graphspec/index.d.ts +2 -2
  122. package/dist/patterns/graphspec/index.js +1 -1
  123. package/dist/patterns/guarded-execution/index.cjs +5 -5
  124. package/dist/patterns/guarded-execution/index.d.cts +4 -4
  125. package/dist/patterns/guarded-execution/index.d.ts +4 -4
  126. package/dist/patterns/guarded-execution/index.js +1 -1
  127. package/dist/patterns/harness/index.cjs +12 -11
  128. package/dist/patterns/harness/index.d.cts +5 -5
  129. package/dist/patterns/harness/index.d.ts +5 -5
  130. package/dist/patterns/harness/index.js +1 -1
  131. package/dist/patterns/job-queue/index.cjs +1 -1
  132. package/dist/patterns/job-queue/index.d.cts +2 -2
  133. package/dist/patterns/job-queue/index.d.ts +2 -2
  134. package/dist/patterns/job-queue/index.js +1 -1
  135. package/dist/patterns/lens/index.cjs +1 -1
  136. package/dist/patterns/lens/index.d.cts +3 -3
  137. package/dist/patterns/lens/index.d.ts +3 -3
  138. package/dist/patterns/lens/index.js +1 -1
  139. package/dist/patterns/memory/index.cjs +1 -1
  140. package/dist/patterns/memory/index.d.cts +2 -2
  141. package/dist/patterns/memory/index.d.ts +2 -2
  142. package/dist/patterns/memory/index.js +1 -1
  143. package/dist/patterns/messaging/index.cjs +1 -1
  144. package/dist/patterns/messaging/index.d.cts +2 -2
  145. package/dist/patterns/messaging/index.d.ts +2 -2
  146. package/dist/patterns/messaging/index.js +1 -1
  147. package/dist/patterns/orchestration/index.cjs +7 -7
  148. package/dist/patterns/orchestration/index.d.cts +2 -2
  149. package/dist/patterns/orchestration/index.d.ts +2 -2
  150. package/dist/patterns/orchestration/index.js +1 -1
  151. package/dist/patterns/reactive-layout/index.cjs +1 -1
  152. package/dist/patterns/reactive-layout/index.d.cts +3 -3
  153. package/dist/patterns/reactive-layout/index.d.ts +3 -3
  154. package/dist/patterns/reactive-layout/index.js +1 -1
  155. package/dist/patterns/reduction/index.cjs +1 -1
  156. package/dist/patterns/reduction/index.d.cts +2 -2
  157. package/dist/patterns/reduction/index.d.ts +2 -2
  158. package/dist/patterns/reduction/index.js +1 -1
  159. package/dist/patterns/refine-loop/index.cjs +3 -3
  160. package/dist/patterns/refine-loop/index.d.cts +3 -3
  161. package/dist/patterns/refine-loop/index.d.ts +3 -3
  162. package/dist/patterns/refine-loop/index.js +1 -1
  163. package/dist/patterns/resilient-pipeline/index.d.cts +3 -3
  164. package/dist/patterns/resilient-pipeline/index.d.ts +3 -3
  165. package/dist/patterns/resilient-pipeline/index.js +1 -1
  166. package/dist/patterns/surface/index.cjs +15 -13
  167. package/dist/patterns/surface/index.d.cts +3 -3
  168. package/dist/patterns/surface/index.d.ts +3 -3
  169. package/dist/patterns/surface/index.js +1 -1
  170. package/dist/{reactive-layout-BAr6-_o5.d.ts → reactive-layout-Bq0rA2Wb.d.ts} +1 -1
  171. package/dist/{reactive-layout-5oEn8lHM.d.cts → reactive-layout-Dhhe54Oj.d.cts} +1 -1
  172. package/dist/{topology-tree-CVREibAc.d.cts → topology-tree-CpSjvIXp.d.cts} +1 -1
  173. package/dist/{topology-tree-CkjojcB6.d.ts → topology-tree-DAbCV2Yw.d.ts} +1 -1
  174. package/package.json +1 -1
  175. package/dist/chunk-ASDKRNOJ.js +0 -60
  176. package/dist/chunk-PSQNYY72.js +0 -7
  177. package/dist/chunk-XEFAMCEA.js +0 -78
@@ -1,7 +1,7 @@
1
- "use strict";var Je=Object.defineProperty;var ln=Object.getOwnPropertyDescriptor;var fn=Object.getOwnPropertyNames;var pn=Object.prototype.hasOwnProperty;var K=(t,e)=>()=>(t&&(e=t(t=0)),e);var hn=(t,e)=>{for(var n in e)Je(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))!pn.call(t,s)&&s!==n&&Je(t,s,{get:()=>e[s],enumerable:!(r=ln(e,s))||r.enumerable});return t};var mn=t=>gn(Je({},"__esModule",{value:!0}),t);function ke(){return le>0||_e}function yt(){return le>0}function xe(t){le>0?we.push(t):t()}function Se(t){le+=1;let e=!1;try{t()}catch(n){throw e=!0,n}finally{if(le-=1,le===0)if(e){if(!_e){let n=we.splice(0);for(let r of n)try{r()}catch{}ie.length=0,ae.length=0,fe.length=0}}else bn()}}function bn(){let t=!_e;t&&(_e=!0);let e=[],n=0;try{for(;ie.length>0||ae.length>0||fe.length>0||t&&we.length>0;){if(t&&we.length>0){let o=we.splice(0);for(let i of o)try{i()}catch(a){e.push(a)}continue}if(n+=1,n>1e3)throw ie.length=0,ae.length=0,fe.length=0,new Error("batch drain exceeded 1000 iterations \u2014 likely a reactive cycle");let s=(ie.length>0?ie:ae.length>0?ae:fe).splice(0);for(let o of s)try{o()}catch(i){e.push(i)}}}finally{t&&(_e=!1)}if(e.length===1)throw e[0];if(e.length>1)throw new AggregateError(e,"batch drain: multiple callbacks threw")}function Re(t,e,n){if(e.length===0)return;if(e.length===1){let u=n(e[0][0]);if(u<3||!ke()){t(e);return}(u>=5?fe:u===4?ae:ie).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 c=ke();if(s>0){let u=e.slice(0,s);t(u)}if(o>s){let u=e.slice(s,o);c?ie.push(()=>t(u)):t(u)}if(i>o){let u=e.slice(o,i);c?ae.push(()=>t(u)):t(u)}if(r>i){let u=e.slice(i,r);c?fe.push(()=>t(u)):t(u)}}var le,_e,ie,ae,fe,we,De=K(()=>{"use strict";le=0,_e=!1,ie=[],ae=[],fe=[],we=[]});var Te,$,Z,F,J,Q,te,j,H,M,pe,Xe,yn,Ze,vn,_n,Qe,vt,_t,wt,et,Oe=K(()=>{"use strict";Te=Symbol.for("graphrefly/START"),$=Symbol.for("graphrefly/DATA"),Z=Symbol.for("graphrefly/DIRTY"),F=Symbol.for("graphrefly/RESOLVED"),J=Symbol.for("graphrefly/INVALIDATE"),Q=Symbol.for("graphrefly/PAUSE"),te=Symbol.for("graphrefly/RESUME"),j=Symbol.for("graphrefly/TEARDOWN"),H=Symbol.for("graphrefly/COMPLETE"),M=Symbol.for("graphrefly/ERROR"),pe=Object.freeze([Z]),Xe=Object.freeze([F]),yn=Object.freeze([J]),Ze=Object.freeze([Te]),vn=Object.freeze([H]),_n=Object.freeze([j]),Qe=Object.freeze([pe]),vt=Object.freeze([Xe]),_t=Object.freeze([yn]),wt=Object.freeze([vn]),et=Object.freeze([_n])});function Tt(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++]=tt,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 Ot(t,e){if(t.length<xt)throw new Error(`decodeEnvelope: bytes too short (${t.length} < ${xt})`);let n=0,r=t[n++];if(r!==tt)throw new Error(`decodeEnvelope: unsupported envelope version ${r} (expected ${tt})`);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),c=e.lookupCodec(o);if(c==null)throw new Error(`decodeEnvelope: codec "${o}" not registered (envelope codec_v=${i})`);return{codec:c,codecVersion:i,payload:a}}function Nt(t){t.registerCodec(wn)}var wn,tt,xt,nt=K(()=>{"use strict";wn={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)}},tt=1,xt=4});function Ae(t){if(t==null)return he;let{type:e,id:n,...r}=t;return{type:e??"system",id:n??"",...r}}var he,rt=K(()=>{"use strict";he={type:"system",id:""}});function ge(){return Math.trunc(performance.now()*1e6)}function Ce(){return Date.now()*1e6}var st=K(()=>{"use strict"});function Et(t){t.registerMessageType(Te,{tier:0,wireCrossing:!1}),t.registerMessageType(Z,{tier:1,wireCrossing:!1}),t.registerMessageType(J,{tier:1,wireCrossing:!1,metaPassthrough:!1}),t.registerMessageType(Q,{tier:2,wireCrossing:!1}),t.registerMessageType(te,{tier:2,wireCrossing:!1}),t.registerMessageType($,{tier:3,wireCrossing:!0}),t.registerMessageType(F,{tier:3,wireCrossing:!0}),t.registerMessageType(H,{tier:4,wireCrossing:!0,metaPassthrough:!1}),t.registerMessageType(M,{tier:4,wireCrossing:!0,metaPassthrough:!1}),t.registerMessageType(j,{tier:5,wireCrossing:!0,metaPassthrough:!1})}var Me,kt=K(()=>{"use strict";Oe();Me=class{_messageTypes=new Map;_codecs=new Map;_onMessage;_onSubscribe;_defaultVersioning;_defaultHashFn;_inspectorEnabled=!(typeof process<"u"&&process.env?.NODE_ENV==="production");_globalInspector;_frozen=!1;tierOf;constructor(e){this._onMessage=e.onMessage,this._onSubscribe=e.onSubscribe,this._defaultVersioning=e.defaultVersioning,this._defaultHashFn=e.defaultHashFn,this.tierOf=n=>{let r=this._messageTypes.get(n);return r!=null?r.tier:1}}get onMessage(){return this._frozen=!0,this._onMessage}get onSubscribe(){return this._frozen=!0,this._onSubscribe}set onMessage(e){this._assertUnfrozen(),this._onMessage=e}set onSubscribe(e){this._assertUnfrozen(),this._onSubscribe=e}get defaultVersioning(){return this._defaultVersioning}set defaultVersioning(e){this._assertUnfrozen(),this._defaultVersioning=e}get defaultHashFn(){return this._defaultHashFn}set defaultHashFn(e){this._assertUnfrozen(),this._defaultHashFn=e}get inspectorEnabled(){return this._inspectorEnabled}set inspectorEnabled(e){this._inspectorEnabled=e}get globalInspector(){return this._globalInspector}set globalInspector(e){this._globalInspector=e}registerMessageType(e,n){return this._assertUnfrozen(),this._messageTypes.set(e,{tier:n.tier,wireCrossing:n.wireCrossing??n.tier>=3,metaPassthrough:n.metaPassthrough??!0}),this}messageTier(e){let n=this._messageTypes.get(e);return n!=null?n.tier:1}isWireCrossing(e){let n=this._messageTypes.get(e);return n!=null?n.wireCrossing:!0}isLocalOnly(e){return!this.isWireCrossing(e)}isMetaPassthrough(e){let n=this._messageTypes.get(e);return n!=null?n.metaPassthrough:!0}isKnownMessageType(e){return this._messageTypes.has(e)}registerCodec(e){return this._assertUnfrozen(),this._codecs.set(e.name,e),this}lookupCodec(e){return this._codecs.get(e)}_isFrozen(){return this._frozen}_assertUnfrozen(){if(this._frozen)throw new Error("GraphReFlyConfig is frozen: a node has already captured this config. Register custom types and set hooks before creating any node.")}}});function ot(t){let e=xn.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 q,xn,Ge=K(()=>{"use strict";q=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}},xn=["human","llm","wallet","system"]});function it(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(it);if(typeof t=="object"&&t!==null){let e={};for(let n of Object.keys(t).sort())e[n]=it(t[n]);return e}return null}function Nn(t){let e=On.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,c=3144134277,u=1013904242,d=2773480762,p=1359893119,h=2600822924,f=528734635,l=1541459225,g=new Uint32Array(64),b=(x,m)=>x>>>m|x<<32-m;for(let x=0;x<s;x+=64){for(let k=0;k<16;k++)g[k]=i.getUint32(x+k*4,!1);for(let k=16;k<64;k++){let R=g[k-15],S=g[k-2],I=b(R,7)^b(R,18)^R>>>3,V=b(S,17)^b(S,19)^S>>>10;g[k]=g[k-16]+I+g[k-7]+V>>>0}let m=a,v=c,_=u,y=d,T=p,O=h,N=f,D=l;for(let k=0;k<64;k++){let R=b(T,6)^b(T,11)^b(T,25),S=T&O^~T&N,I=D+R+S+Tn[k]+g[k]>>>0,V=b(m,2)^b(m,13)^b(m,22),Y=m&v^m&_^v&_,oe=V+Y>>>0;D=N,N=O,O=T,T=y+I>>>0,y=_,_=v,v=m,m=I+oe>>>0}a=a+m>>>0,c=c+v>>>0,u=u+_>>>0,d=d+y>>>0,p=p+T>>>0,h=h+O>>>0,f=f+N>>>0,l=l+D>>>0}let w=x=>x.toString(16).padStart(8,"0");return w(a)+w(c)+w(u)+w(d)+w(p)+w(h)+w(f)+w(l)}function at(t){let e=it(t??null),n=JSON.stringify(e);return Nn(n).slice(0,16)}function En(){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 ut(t,e,n){let r=n?.id??En();if(t===0)return{id:r,version:0};let o=(n?.hash??at)(e);return{id:r,version:0,cid:o,prev:null}}function St(t,e,n){t.version+=1,"cid"in t&&(t.prev=t.cid,t.cid=n(e))}var Tn,On,Rt=K(()=>{"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]),On=new TextEncoder});function Ct(t){return{node:t,unsub:null,prevData:void 0,dirty:!1,involvedThisWave:!1,dataBatch:[],terminal:void 0}}function ct(t){t.prevData=void 0,t.dirty=!1,t.involvedThisWave=!1,t.dataBatch.length=0,t.terminal=void 0}function Ie(t){return t.length===0?t:typeof t[0]=="symbol"?[t]:t}function X(t,e,n){let r=Mt(t)?t:[],s=typeof t=="function"?t:typeof e=="function"?e:void 0,o={};return Mt(t)?o=(dt(e)?e:n)??{}:dt(t)?o=t:o=(dt(e)?e:n)??{},new L(r,s,o)}var Dt,At,kn,Sn,me,L,Mt,dt,be=K(()=>{"use strict";nt();rt();De();st();kt();Ge();Oe();Rt();Dt=()=>{},At=100;kn=(t,e,n,r)=>{n.direction==="down-in"&&t._onDepMessage(n.depIndex,e)},Sn=(t,e,n,r)=>{let s=t;if(s._status==="completed"||s._status==="errored")return;let o=s._cached,i=o===void 0?[Ze]:[Ze,[$,o]];s._status==="dirty"&&i.push(pe),Re(e,i,s._config.tierOf)},me=new Me({onMessage:kn,onSubscribe:Sn});Et(me);Nt(me);L=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??me,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??at;let s=r.versioning??this._config.defaultVersioning;this._versioningLevel=s,this._versioning=s!=null?ut(s,this._cached===void 0?void 0:this._cached,{id:r.versioningId,hash:this._hashFn}):void 0,this._deps=e.map(Ct);let o={};for(let[a,c]of Object.entries(r.meta??{})){let u={initial:c,name:`${r.name??"node"}:meta:${a}`,describeKind:"state",config:this._config};r.guard!=null&&(u.guard=r.guard),o[a]=new t([],void 0,u)}Object.freeze(o),this.meta=o,this._hasMeta=Object.keys(o).length>0;let i=this;this._actions={emit(a){i._emit([[$,a]])},down(a){i._emit(Ie(a))},up(a){i._emitUp(Ie(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,c=i?.version??0,u=ut(e,o,{id:a,hash:s});u.version=c,this._versioning=u,this._versioningLevel=e}_setInspectorHook(e){return e==null?()=>{}:(this._inspectorHooks==null&&(this._inspectorHooks=new Set),this._inspectorHooks.add(e),()=>{this._inspectorHooks?.delete(e),this._inspectorHooks?.size===0&&(this._inspectorHooks=void 0)})}_pushGuard(e){return this._extraGuards==null&&(this._extraGuards=new Set),this._extraGuards.add(e),()=>{this._extraGuards?.delete(e),this._extraGuards?.size===0&&(this._extraGuards=void 0)}}allowsObserve(e){if(this._guard==null&&this._extraGuards==null)return!0;let n=Ae(e);if(this._guard!=null&&!this._guard(n,"observe"))return!1;if(this._extraGuards!=null){for(let r of this._extraGuards)if(!r(n,"observe"))return!1}return!0}_checkGuard(e){if(e?.internal)return;let n=this._guard!=null||this._extraGuards!=null,r=e?.actor!=null;if(!n&&!r)return;let s=Ae(e?.actor),o=e?.delivery==="signal"?"signal":"write";if(this._guard!=null&&!this._guard(s,o))throw new q({actor:s,action:o,nodeName:this.name});if(this._extraGuards!=null){for(let i of this._extraGuards)if(!i(s,o))throw new q({actor:s,action:o,nodeName:this.name})}this._lastMutation={actor:s,timestamp_ns:Ce()}}down(e,n){let r=Ie(e);r.length!==0&&(this._checkGuard(n),this._emit(r))}emit(e,n){this._checkGuard(n),this._emit([[$,e]])}up(e,n){if(this._deps.length===0)return;let r=Ie(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 c=Ae(n);if(!this._guard(c,"observe"))throw new q({actor:c,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 c of this._deps)ct(c);if(this._partial===!1){for(let c of this._deps)if(c.prevData!==void 0||c.dataBatch.length!==0||c.terminal!==void 0||c.dirty)throw new Error(`resubscribable-reset invariant: DepRecord not fully reset for node ${this._optsName??"(anonymous)"}`)}}this._sinkCount+=1;let o;try{o=this._config.onSubscribe(this,e,{sinkCount:this._sinkCount,afterTerminalReset:s},this._actions)}catch(c){throw this._sinkCount-=1,c}this._sinks==null?this._sinks=e:typeof this._sinks=="function"?this._sinks=new Set([this._sinks,e]):this._sinks.add(e);let i=this._isTerminal;if(this._sinkCount===1&&!i)try{this._activate()}catch(c){if(this._sinkCount-=1,this._removeSink(e),this._sinkCount===0&&(this._status="sentinel"),typeof o=="function")try{o()}catch{}throw c}this._status==="sentinel"&&this._cached===void 0&&(this._status="pending");let a=!1;return()=>{a||(a=!0,this._sinkCount-=1,this._removeSink(e),typeof 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,c=!1;for(let u of i)a(u[0])>=3&&(c=!0),this._config.onMessage(this,u,{direction:"down-in",depIndex:s},this._actions);c&&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{}ct(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=Ct(e);if(this._deps.push(r),this._sinks==null)return n;r.dirty=!0,this._dirtyDepCount++,this._status!=="dirty"&&this._emit(Qe),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([[M,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([[M,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{}}ct(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!==Te){if(s===Z){this._depDirtied(r);return}if(s===J){if(this._depInvalidated(r),this._cached===void 0)return;this._emit(_t);return}if(s===Q||s===te){this._emit([n]);return}if(s===j){this._emit(et);return}if(s===$)this._depSettledAsData(r,n[1]);else if(s===F)this._depSettledAsResolved(r);else if(s===H)this._depSettledAsTerminal(r,!0);else if(s===M)this._depSettledAsTerminal(r,n[1]);else{this._emit([n]);return}if(!this._fn){(s===$||s===F)&&this._emit([n]),(s===H||s===M)&&this._maybeAutoTerminalAfterWave();return}}}_depDirtied(e){e.dirty||(e.dirty=!0,e.involvedThisWave=!0,this._dirtyDepCount++,this._status!=="dirty"&&this._emit(Qe))}_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(vt),this._maybeAutoTerminalAfterWave();return}this._fn&&this._execFn(),this._maybeAutoTerminalAfterWave()}}_maybeAutoTerminalAfterWave(){if(this._deps.length===0||this._isTerminal)return;let e=this._deps.find(n=>n.terminal!==void 0&&n.terminal!==!0);if(e!=null){this._autoError&&this._emit([[M,e.terminal]]);return}this._autoComplete&&this._deps.every(n=>n.terminal!==void 0)&&this._emit(wt)}_execFn(){if(!this._fn||this._isTerminal&&!this._resubscribable)return;if(this._isExecutingFn){this._pendingRerun=!0;return}let e=this._cleanup;if(typeof e=="function"){this._cleanup=void 0;try{e()}catch(i){this._emit([[M,this._wrapFnError("cleanup threw",i)]]);return}}else if(e!=null&&typeof e=="object"){let i=e.beforeRun;if(typeof i=="function"){e.beforeRun=void 0;try{i()}catch(a){this._emit([[M,this._wrapFnError("cleanup.beforeRun threw",a)]]);return}}}let n=this._deps.map(i=>i.involvedThisWave?i.dataBatch.length>0?[...i.dataBatch]:[]:void 0),r=this._deps.map(i=>i.prevData);for(let i=0;i<this._deps.length;i++){let a=n[i];a!=null&&a.length>0&&(this._deps[i].prevData=a[a.length-1])}let 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([[M,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([[M,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"?[pe,e[0]]:e;let r=!0,s=!1,o=!1,i=-1;for(let c of e){let u=n(c[0]);u<i&&(r=!1),u===3&&(s=!0),c[0]===Z&&(o=!0),i=u}let a=e;if(!r){let c=e.map((u,d)=>({m:u,i:d,tier:n(u[0])}));c.sort((u,d)=>u.tier-d.tier||u.i-d.i),a=c.map(u=>u.m)}if(s&&!o&&this._status!=="dirty"){let c=0;for(;c<a.length&&n(a[c][0])===0;)c++;return c===0?[pe,...a]:[...a.slice(0,c),pe,...a.slice(c)]}return a}_emit(e){if(e.length===0)return;for(let a=0;a<e.length;a++){let c=e[a];if(c[0]===M&&c[1]===void 0)throw new TypeError('[ERROR, payload] requires a non-undefined payload (spec \xA71.2). Pass an Error object or domain tag instead \u2014 e.g. node.down([[ERROR, new Error("reason")]])')}let n=e;if(this._isTerminal&&!this._resubscribable){let a=e.filter(c=>c[0]===j||c[0]===J);if(a.length===0)return;n=a}n=this._frameBatch(n);let s=null;for(let a=0;a<n.length;a++){let c=n[a],u=c[0];if(u!==Q&&u!==te){s?.push(c);continue}if(c.length<2)throw new Error(`Node "${this.name}": [[${u===Q?"PAUSE":"RESUME"}]] must carry a lockId payload \u2014 bare PAUSE/RESUME is a protocol violation (C0 rule). Use \`[[PAUSE, lockId]]\` / \`[[RESUME, lockId]]\`.`);let d=!0;if(this._pausable!==!1){let p=c[1];if(u===Q)this._pauseLocks==null&&(this._pauseLocks=new Set),this._pauseLocks.add(p),this._paused=!0,this._pausable==="resumeAll"&&this._pauseBuffer==null&&(this._pauseBuffer=[]);else if(this._pauseLocks==null||!this._pauseLocks.has(p))d=!1;else if(this._pauseLocks.delete(p),this._pauseLocks.size===0){if(this._paused=!1,this._pauseBuffer!=null&&this._pauseBuffer.length>0){let h=this._pauseBuffer;this._pauseBuffer=[],this._emit(h)}this._pendingWave&&(this._pendingWave=!1,this._maybeRunFnOnSettlement())}}d?s?.push(c):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(et)}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,c=[];for(let u of o)a(u[0])===3?this._pauseBuffer.push(u):c.push(u);c.length>0&&this._dispatchOrAccumulate(c)}else this._dispatchOrAccumulate(o);i!=null&&this._emit([[M,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,c=-1;if(this._versioning!=null&&i>1){for(let d=e.length-1;d>=0;d--)if(e[d][0]===$){c=d;break}}for(let d=0;d<e.length;d++){let p=e[d],h=p[0];if(h===$){if(p.length>=2){let f=!1;if(a&&this._cached!==void 0)try{f=this._equals(this._cached,p[1])}catch(l){s=this._wrapFnError("equals threw",l),o=d;break}if(f){r==null&&(r=e.slice(0,d)),r.push(Xe),this._status="resolved";continue}this._cached=p[1],this._versioning!=null&&(c<0||d===c)&&St(this._versioning,p[1],this._hashFn)}this._status="settled",r?.push(p)}else if(r?.push(p),h===Z)this._status="dirty";else if(h===F)this._status="resolved";else if(h===H)this._status="completed";else if(h===M)this._status="errored";else if(h===J){this._cached=void 0,this._status="dirty";let f=this._cleanup;if(typeof f=="function"){this._cleanup=void 0;try{f()}catch{}}else if(f!=null&&typeof f=="object"){let l=f.invalidate;if(typeof l=="function")try{l()}catch{}}}else h===j&&(this._resetOnTeardown&&(this._cached=void 0),this._deactivate(!0),this._status="sentinel")}let u=o>=0?r??e.slice(0,o):r??e;return s!=null?{finalMessages:u,equalsError:s}:{finalMessages:u}}_deliverToSinks=e=>{if(this._sinks==null)return;if(typeof this._sinks=="function"){this._sinks(e);return}let n=[...this._sinks];for(let r of n)r(e)};_dispatchOrAccumulate(e){if(yt()){this._batchPendingMessages===null&&(this._batchPendingMessages=[],xe(()=>this._flushBatchPending()));for(let n of e)this._batchPendingMessages.push(n);return}Re(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);Re(this._deliverToSinks,n,this._config.tierOf)}},Mt=t=>Array.isArray(t),dt=t=>typeof t=="object"&&t!=null&&!Array.isArray(t)});function ue(t,e){return X([],{...e,initial:t})}function Gt(t,e){return X((r,s,o)=>t(s,o)??void 0,{describeKind:"producer",...e})}function ce(t,e,n){return X(t,(s,o,i)=>{let a=s.map((c,u)=>c!=null&&c.length>0?c.at(-1):i.prevData[u]);o.emit(e(a,i))},{describeKind:"derived",...n})}var lt=K(()=>{"use strict";be()});function pt(t){return t.subscribe(()=>{})}var It=K(()=>{"use strict"});var Pe,Lt=K(()=>{"use strict";Pe=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 Lr={};hn(Lr,{approval:()=>Rr,branch:()=>Sr,gate:()=>Dr,join:()=>Ar,loop:()=>Cr,onFailure:()=>Ir,pipeline:()=>dn,sensor:()=>Gr,subPipeline:()=>Mr,task:()=>kr});module.exports=mn(Lr);De();Oe();be();lt();rt();De();st();Ge();Oe();Ge();be();function Le(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 Dn(t){let e={};for(let[n,r]of Object.entries(t.meta))try{e[n]=r.cache}catch{}return e}function ft(t,e){let n=e==null,r=!n&&e!=null?[...e].filter(u=>u.startsWith("meta.")).map(u=>u.slice(5)):null,s=n||e.has("meta")||r!=null&&r.length>0,o="state",i=[];t instanceof L&&(o=Rn(t),i=t._deps.map(u=>u.node.name??""));let a={type:o,deps:i};(n||e.has("status"))&&(a.status=t.status);let c=t instanceof L?t._guard:void 0;if(s){let u={...Dn(t)};if(c!=null&&u.access===void 0&&(u.access=ot(c)),r!=null&&r.length>0&&!e.has("meta")){let d={};for(let p of r)p in u&&(d[p]=u[p]);a.meta=d}else a.meta=u}if(t.name!=null&&(a.name=t.name),n||e.has("value")){t.status==="sentinel"&&(a.sentinel=!0);try{a.value=t.cache}catch{}}if((n||e.has("v"))&&t.v!=null){let u={id:t.v.id,version:t.v.version};"cid"in t.v&&(u.cid=t.v.cid,u.prev=t.v.prev),a.v=u}return(n||e.has("guard"))&&c!=null&&(a.guard=ot(c)),(n||e.has("lastMutation"))&&t.lastMutation!=null&&(a.lastMutation=t.lastMutation),a}be();lt();It();Lt();var Ne=class{constructor(e){this.capacity=e;if(!Number.isInteger(e)||e<=0)throw new Error(`RingBuffer capacity must be a positive integer (got ${e})`);this.buf=new Array(e)}buf;head=0;_size=0;get size(){return this._size}get maxSize(){return this.capacity}push(e){let n=(this.head+this._size)%this.capacity;this.buf[n]=e,this._size<this.capacity?this._size++:this.head=(this.head+1)%this.capacity}shift(){if(this._size===0)return;let e=this.buf[this.head];return this.buf[this.head]=void 0,this.head=(this.head+1)%this.capacity,this._size--,e}at(e){if(this._size===0)return;let n=e<0?this._size+e:e;if(!(n<0||n>=this._size))return this.buf[(this.head+n)%this.capacity]}toArray(){let e=new Array(this._size);for(let n=0;n<this._size;n++)e[n]=this.buf[(this.head+n)%this.capacity];return e}clear(){for(let e=0;e<this._size;e++)this.buf[(this.head+e)%this.capacity]=void 0;this.head=0,this._size=0}};nt();function ht(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 $e(t){let e=0;for(let n of t)e+=ht(n.codePointAt(0));return e}function Pt(t,e){if(e<=0)return"";let n=0,r="";for(let s of t){let o=ht(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-=ht(i.codePointAt(0))}return`${r}\u2026`}r+=s,n+=o}return r}var An={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"},Cn={horizontal:"-",vertical:"|",cornerTL:"+",cornerTR:"+",cornerBL:"+",cornerBR:"+",tDown:"+",tUp:"+",tRight:"+",tLeft:"+",cross:"+",arrowRight:">",arrowDown:"v",arrowLeft:"<",arrowUp:"^",boxTL:"+",boxTR:"+",boxBL:"+",boxBR:"+",boxH:"-",boxV:"|"};function Bt(t,e){let n=e.charset==="ascii"?Cn:An,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:c}=r;if(a<2||c<2){c>0&&$t(t,e,o,i,a,s);return}ne(t,e,o,i,n.boxTL);for(let d=o+1;d<o+a-1;d+=1)ne(t,e,d,i,n.boxH);ne(t,e,o+a-1,i,n.boxTR);for(let d=i+1;d<i+c-1;d+=1){ne(t,e,o,d,n.boxV);for(let p=o+1;p<o+a-1;p+=1)jt(t,e,p,d," ","empty");ne(t,e,o+a-1,d,n.boxV)}ne(t,e,o,i+c-1,n.boxBL);for(let d=o+1;d<o+a-1;d+=1)ne(t,e,d,i+c-1,n.boxH);ne(t,e,o+a-1,i+c-1,n.boxBR);let u=i+Math.floor(c/2);$t(t,e,o+1,u,a-2,s)}function ne(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 $t(t,e,n,r,s,o){if(r<0||r>=t.length)return;let i=n,a=s;for(let c of o){let u=$e(c);if(u!==0){if(a<u)break;i>=0&&i<t[r].length&&(t[r][i]=c,e[r][i]="label",u===2&&i+1<t[r].length&&(t[r][i+1]="",e[r][i+1]="label")),i+=u,a-=u}}for(;a>0;)i>=0&&i<t[r].length&&(t[r][i]=" ",e[r][i]="empty"),i+=1,a-=1}function Gn(t,e,n,r){let s=r.points;if(s.length<2)return;for(let c=0;c+1<s.length;c+=1)In(t,e,n,s[c],s[c+1]);for(let c=1;c+1<s.length;c+=1){let u=s[c-1],d=s[c],p=s[c+1],h=Ln(u,d,p,n);h&&Ht(t,e,d.x,d.y,h,"edgeCorner")}let o=s[s.length-1],i=s[s.length-2],a=Pn(i,o,n);a&&Ht(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 c=i;c<=a;c+=1)Ft(t,e,c,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 c=i;c<=a;c+=1)Ft(t,e,o,c,n,"v")}}}function Ft(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 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];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 c=t.x<e.x,u=n.y>e.y;return c&&u?r.cornerTR:c&&!u?r.cornerBR:!c&&u?r.cornerTL:r.cornerBL}let i=t.y<e.y,a=n.x>e.x;return i&&a?r.cornerBL:i&&!a?r.cornerBR:!i&&a?r.cornerTL:r.cornerTR}function 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),jn(e),Vn(e,t);let n=Wn(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 c=(e.get(a.id)??0)-1;e.set(a.id,c),c<=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),c=a.layer-i.layer;if(c<=0){i.out=i.out.filter(p=>p!==o),a.in=a.in.filter(p=>p!==o);continue}if(c===1){o.hopIndex=0,o.chainLen=1,r.push(o);continue}i.out=i.out.filter(p=>p!==o),a.in=a.in.filter(p=>p!==o);let u=i;for(let p=1;p<c;p+=1){let h=`__virt_${s++}__`,f={id:h,isVirtual:!0,layer:i.layer+p,order:0,x:0,y:0,w:0,h:1,in:[],out:[]};t.nodes.set(h,f),n[f.layer].push(f);let l={chainId:o.chainId,chainFrom:o.chainFrom,chainTo:o.chainTo,fromId:u.id,toId:h,hopIndex:p-1,chainLen:c};u.out.push(l),f.in.push(l),r.push(l),u=f}let d={chainId:o.chainId,chainFrom:o.chainFrom,chainTo:o.chainTo,fromId:u.id,toId:a.id,hopIndex:c-1,chainLen:c};u.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)Vt(t,t.layers[r],"in"),Fe(t.layers[r]);for(let r=t.layers.length-2;r>=0;r-=1)Vt(t,t.layers[r],"out"),Fe(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]],Fe(o),zt(t,o[i],o[i+1],"in")<a?r=!0:([o[i],o[i+1]]=[o[i+1],o[i]],Fe(o))}}if(!r)break}}function Vt(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 c of o){let u=t.nodes.get(n==="in"?c.fromId:c.toId);u&&(i+=u.order,a+=1)}r.set(s.id,a===0?s.order:i/a)}e.sort((s,o)=>{let i=r.get(s.id),a=r.get(o.id);return i!==a?i-a:s.order-o.order})}function Fe(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 c of o){let u=t.nodes.get(r==="in"?a.fromId:a.toId)?.order??0,d=t.nodes.get(r==="in"?c.fromId:c.toId)?.order??0;(e.order<n.order&&u>d||e.order>n.order&&u<d)&&(i+=1)}return i}function Vn(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}Wt(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}Wt(t,e,"x")}function Wt(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 c=new Map;for(let d of a){let p=o===0?d.in:d.out;if(p.length===0)continue;let h=[];for(let l of p){let g=t.nodes.get(o===0?l.fromId:l.toId);if(!g)continue;let b=n==="y"?g.y:g.x;h.push(b+Math.floor(r(g)/2))}if(h.length===0)continue;h.sort((l,g)=>l-g);let f=h[Math.floor(h.length/2)];c.set(d.id,f-Math.floor(r(d)/2))}let u=0;for(let d of a){let p=c.get(d.id),h=n==="y"?d.y:d.x,l=Math.max(p??h,u);n==="y"?d.y=l:d.x=l,u=l+r(d)+s}}}}function Wn(t,e){let n=new Map;for(let u of t.hops){let d=n.get(u.chainId);d?d.push(u):n.set(u.chainId,[u])}for(let u of n.values())u.sort((d,p)=>d.hopIndex-p.hopIndex);let r=e.direction==="LR",s=u=>r?u.x:u.y,o=u=>r?u.w:u.h,i=u=>r?u.y+Math.floor(u.h/2):u.x+Math.floor(u.w/2),a=new Map;for(let u=0;u+1<t.layers.length;u+=1){let d=t.layers[u],p=t.layers[u+1],h=0;for(let O of d)h=Math.max(h,s(O)+o(O));let f=Number.POSITIVE_INFINITY;for(let O of p)f=Math.min(f,s(O));let l=Number.isFinite(f)?f-1:h,g=Math.max(1,l-h+1),b=[];for(let O of d)for(let N of O.out)b.push(N);b.sort((O,N)=>{let D=i(t.nodes.get(O.fromId)),k=i(t.nodes.get(N.fromId));if(D!==k)return D-k;let R=i(t.nodes.get(O.toId)),S=i(t.nodes.get(N.toId));return R-S});let w=[],x=new Map;for(let O of b){let N=i(t.nodes.get(O.fromId)),D=i(t.nodes.get(O.toId)),k=Math.min(N,D),R=Math.max(N,D),S=-1;for(let I=0;I<w.length;I+=1){let V=w[I],Y=!0;for(let oe of V)if(oe.lo<=R&&k<=oe.hi){Y=!1;break}if(Y){V.push({lo:k,hi:R}),S=I;break}}S<0&&(w.push([{lo:k,hi:R}]),S=w.length-1),x.set(O,S)}let m=w.length,v=g>=Math.max(3,m+2),_=v?h+1:h,y=v?l-1:l,T=Math.max(1,y-_+1);for(let O of b){let N=x.get(O),D;if(m<=1)D=_+Math.floor(T/2);else{let k=(T-1)/(m-1);D=_+Math.floor(N*k)}a.set(O,Math.max(h,Math.min(l,D)))}}let c=[];for(let[,u]of n){let d=[];for(let h=0;h<u.length;h+=1){let f=u[h],l=t.nodes.get(f.fromId),g=t.nodes.get(f.toId),b=a.get(f),w=l.isVirtual?s(l):s(l)+o(l),x=g.isVirtual?s(g):s(g)-1,m=i(l),v=i(g);h===0&&He(d,r,w,m),m!==v&&(He(d,r,b,m),He(d,r,b,v)),He(d,r,x,v)}let p=u[0];c.push({from:p.chainFrom,to:p.chainTo,points:Kn(d)})}return c}function He(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 Kt(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(f=>i.has(f.from)&&i.has(f.to)),c=new Map,u=new Map;for(let f of o){let l=Pt(f,r);c.set(f,l),u.set(f,$e(l)+4)}let d=Ut({nodes:o,edges:a,widthCells:f=>u.get(f)??3,heightCells:()=>Zn,layerGap:Jn,nodeGap:Xn,direction:n}),p=Bt(d,{charset:s,labelOf:f=>c.get(f)??f}),h=e.logger;return h&&h(p),p}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 qt(t,e,n,r={}){let s=e in t.nodes,o=n in t.nodes;if(!s)return Be(e,n,"no-such-from");if(!o)return Be(e,n,"no-such-to");let i=r.maxDepth;if(i!=null&&(!Number.isInteger(i)||i<0))throw new Error("explainPath: maxDepth must be an integer >= 0");if(e===n){if(r.findCycle===!0){let u=er(t,e,r);if(u!=null)return u}let c=je(e,t.nodes[e],0,r);return Ve(e,n,[c])}if(i===0)return Be(e,n,"no-path");let a=Yt(t,e,n,i);return a.found?Ve(e,n,Jt(t,a.pathOrder,r)):Be(e,n,a.truncated?"max-depth-exceeded":"no-path")}function Yt(t,e,n,r){let s=new Map,o=[{path:n,depth:0}],i=new Set([n]),a=0,c=!1;for(;a<o.length;){let p=o[a++];if(p.path===e)break;if(r!=null&&p.depth>=r){let g=t.nodes[p.path];g?.deps&&g.deps.length>0&&(c=!0);continue}let h=t.nodes[p.path];if(h==null)continue;let f=h.deps??[],l=new Map;for(let g=0;g<f.length;g++){let b=f[g];if(!b)continue;let w=l.get(b);w==null&&(w=[],l.set(b,w)),w.push(g)}for(let[g,b]of l)i.has(g)||(i.add(g),s.set(g,{from:p.path,depIndices:b}),o.push({path:g,depth:p.depth+1}))}if(!s.has(e))return{found:!1,pathOrder:[],truncated:c};let u=[{path:e}],d=e;for(;d!==n;){let p=s.get(d);if(p==null)return{found:!1,pathOrder:[],truncated:!1};u[u.length-1].depIndices=p.depIndices,u.push({path:p.from}),d=p.from}return{found:!0,pathOrder:u,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=je(e,r,0,n);a.dep_index=o[0];let c=je(e,r,1,n);return Ve(e,e,[a,c])}let i=null;for(let a=0;a<s.length;a++){let c=s[a];if(!c||c===e)continue;let u=Yt(t,c,e,n.maxDepth);u.found&&(i==null||u.pathOrder.length<i.pathOrder.length)&&(i=u,i={found:!0,pathOrder:[{path:e,depIndices:[a]},...u.pathOrder],truncated:!1})}return i==null?null:Ve(e,e,Jt(t,i.pathOrder,n))}function Jt(t,e,n){return e.map((r,s)=>{let o=t.nodes[r.path],i=je(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 je(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 Ve(t,e,n){return Xt(t,e,!0,"ok",n)}function Be(t,e,n){return Xt(t,e,!1,n,[])}function Xt(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 c=` ${i.hop===0?"\xB7":"\u2193"} ${i.path} (${i.type}${i.status?`/${i.status}`:""})`;if(o.push(c),"value"in i&&o.push(` value: ${nr(i.value)}`),i.annotation!=null&&o.push(` annotation: ${i.annotation}`),i.lastMutation!=null){let u=i.lastMutation.actor;o.push(` actor: ${u.type}${u.id?`:${u.id}`:""}`)}}return o.join(`
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)}}be();var P={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 Zt(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 P.number;case"boolean":return P.boolean;case"string":return P.string+t.length*2;case"bigint":return P.bigint+or(t);case"symbol":return P.symbol;case"function":return e.has(t)?0:(e.add(t),P.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 u=i.call(o);if(typeof u=="number"&&Number.isFinite(u))return u}catch{}if(o instanceof Date)return P.date;if(o instanceof RegExp)return P.regexp+o.source.length*2;if(o instanceof Error){let u=o.message?o.message.length*2:0,d=o.stack?o.stack.length*2:0;return P.error+u+d}if(typeof URL<"u"&&o instanceof URL)return P.url+o.href.length*2;if(typeof Promise<"u"&&o instanceof Promise)return P.promise;if(o instanceof WeakMap)return P.weakmap;if(o instanceof WeakSet)return P.weakset;if(o instanceof Map){let u=P.map;for(let[d,p]of o)u+=P.mapEntry,r.push(d),r.push(p);return u}if(o instanceof Set){let u=P.set;for(let d of o)u+=P.setEntry,r.push(d);return u}if(Array.isArray(o)){let u=P.array+o.length*8;for(let d of o)r.push(d);return u}if(o instanceof ArrayBuffer)return n.has(o)?0:(n.add(o),o.byteLength);if(ArrayBuffer.isView(o)){let u=o;return n.has(u.buffer)?48:(n.add(u.buffer),u.buffer.byteLength+48)}let a=P.object,c=Object.keys(o);for(let u of c){a+=P.string+u.length*2;try{r.push(o[u])}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 Qt(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[h,f]of s)i.set(h,f);let a=[];for(let[h,f]of Object.entries(r.nodes)){let l=i.get(h),g=l instanceof L?l:null,b=g?Zt(g.cache):0,w=g?g._sinkCount:0,x=f.deps?.length??0,m=f.type==="effect"&&w===0,v=w===0?f.type==="effect"?"orphan-effect":f.type==="derived"?"idle-derived":f.type==="producer"?"idle-producer":null:null;a.push({path:h,type:f.type,status:f.status??"unknown",valueSizeBytes:b,subscriberCount:w,depCount:x,isOrphanEffect:m,orphanKind:v})}let c=a.reduce((h,f)=>h+f.valueSizeBytes,0),u=(h,f)=>[...a].sort(f??((l,g)=>g[h]-l[h])).slice(0,n),d=a.filter(h=>h.orphanKind!=null),p=a.filter(h=>h.isOrphanEffect);return{nodeCount:a.length,edgeCount:r.edges.length,subgraphCount:r.subgraphs.length,nodes:a,totalValueSizeBytes:c,hotspots:{byValueSize:u("valueSizeBytes"),bySubscriberCount:u("subscriberCount"),byDepCount:u("depCount")},orphans:d,orphanEffects:p}}var G="::",z="__meta__",ye=1;function en(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 tn(t){if(t.version!==ye)throw new Error(`unsupported snapshot version ${String(t.version)} (expected ${ye})`);for(let e of["name","nodes","edges","subgraphs"])if(!(e in t))throw new Error(`snapshot missing required key "${e}"`);if(typeof t.name!="string")throw new TypeError("snapshot 'name' must be a string");if(typeof t.nodes!="object"||t.nodes===null||Array.isArray(t.nodes))throw new TypeError("snapshot 'nodes' must be an object");if(!Array.isArray(t.edges))throw new TypeError("snapshot 'edges' must be an array");if(!Array.isArray(t.subgraphs))throw new TypeError("snapshot 'subgraphs' must be an array")}function 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,c=o.constructor;if(a!==c)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 h=o;if(s.length!==h.length)return!1;for(let f=0;f<s.length;f++)if(!r(s[f],h[f]))return!1;return!0}if(s instanceof Map){let h=o;if(s.size!==h.size)return!1;for(let[f,l]of s)if(!h.has(f)||!r(l,h.get(f)))return!1;return!0}if(s instanceof Set){let h=o;if(s.size!==h.size)return!1;for(let f of s){let l=!1;for(let g of h)if(r(f,g)){l=!0;break}if(!l)return!1}return!0}if(ArrayBuffer.isView(s)){let h=s,f=o;if(h.length!==f.length)return!1;for(let l=0;l<h.length;l++)if(h[l]!==f[l])return!1;return!0}let u=Object.keys(s),d=Object.keys(o);if(u.length!==d.length)return!1;let p=new Set(d);for(let h of u)if(!p.has(h)||!r(s[h],o[h]))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 cr(t){return t.replaceAll("\\","\\\\").replaceAll('"','\\"')}function dr(t){return t==="TD"?"down":t==="BT"?"up":t==="RL"?"left":"right"}function sn(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 on(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 lr(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}): ${Ue(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 an(t,e){let n=on(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 sn(t)){let c=s.get(i),u=s.get(a);!c||!u||o.push(` ${c} --> ${u}`)}return o.join(`
6
- `)}function pr(t,e){let n=an(t,e);return hr(n)}function hr(t,e){let n=e?.theme??"default",r=e?.autoSync??!0,o=JSON.stringify({code:t,mermaid:{theme:n},autoSync:r}),i=new TextEncoder().encode(o),a="";for(let u=0;u<i.length;u++)a+=String.fromCharCode(i[u]);return`https://mermaid.live/edit#base64:${globalThis.btoa(a).replace(/\+/g,"-").replace(/\//g,"_").replace(/=+$/,"")}`}function gr(t,e){let n=on(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}: "${cr(i)}"`)}for(let[i,a]of sn(t)){let c=s.get(i),u=s.get(a);!c||!u||o.push(`${c} -> ${u}`)}return o.join(`
7
- `)}function mr(t){return t.replace(/[.*+?^${}()|[\]\\]/g,"\\$&")}function ze(t){let e="^";for(let n=0;n<t.length;n+=1){let r=t[n];if(r==="*"){e+=".*";continue}if(r==="?"){e+=".";continue}if(r==="["){let s=t.indexOf("]",n+1);if(s<=n+1){e+="\\[";continue}let o=t.slice(n+1,s);o.startsWith("!")&&(o=`^${o.slice(1)}`),o=o.replace(/\\/g,"\\\\"),e+=`[${o}]`,n=s;continue}e+=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 Ue(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 nn(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(G))throw new Error(`Graph "${e}": ${n} "${t}" must not contain '${G}' (path separator)`);if(t===z)throw new Error(`Graph "${e}": ${n} name "${z}" is reserved for meta companion paths`);_r(t,e,n)}function wr(t,e){if(t==="")throw new Error(`Graph "${e}": resolve path must be non-empty`);let n=t.split(G);for(let r of n)if(r==="")throw new Error(`Graph "${e}": resolve path has empty segment`);return n}function xr(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 un(t){for(let e of t._mounts.values())un(e);for(let e of t._nodes.values())try{e.down([[j]],{internal:!0})}catch{}}var de=class t{name;opts;config;_nodes=new Map;_nodeToName=new WeakMap;_mounts=new Map;_parent=void 0;_storageDisposers=new Set;_disposers=new Set;_topology;_topologyEmitters=new Set;constructor(e,n){if(e==="")throw new Error("Graph name must be non-empty");if(e.includes(G))throw new Error(`Graph name must not contain '${G}' (got "${e}")`);if(e===z)throw new Error(`Graph name "${z}" is reserved for meta companion paths`);this.name=e,this.opts=Object.freeze({...n??{}}),this.config=n?.config??me,this._traceRing=new Ne(n?.traceCapacity??1e3),n?.versioning!=null&&this.setVersioning(n.versioning)}ancestors(e=!0){let n=[],r=e?this:this._parent;for(;r!=null;)n.push(r),r=r._parent;return n}get topology(){return this._topology==null&&(this._topology=Gt(e=>{let n=r=>{e.emit(r)};return this._topologyEmitters.add(n),()=>{this._topologyEmitters.delete(n)}},{name:`${this.name}_topology`})),this._topology}_emitTopology(e){if(!(this._topology==null||this._topologyEmitters.size===0))for(let n of this._topologyEmitters)n(e)}add(e,n){let r=e.name,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 L&&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,c]of i)a.includes(`${G}${z}${G}`)||o.nodes.push(a);return o.nodes.sort(),o.mounts.push(e),o.mounts.push(...n._collectSubgraphs(`${e}${G}`)),this._mounts.delete(e),n._parent=void 0,un(n),this._emitTopology({kind:"removed",name:e,nodeKind:"mount",audit:o}),o}let r=this._nodes.get(e);if(!r)throw new Error(`Graph "${this.name}": unknown node or mount "${e}"`);this._nodes.delete(e),this._nodeToName.delete(r),r.down([[j]],{internal:!0});let s={kind:"node",nodes:[e],mounts:[]};return this._emitTopology({kind:"removed",name:e,nodeKind:"node",audit:s}),s}removeAll(e){let n=typeof e=="function"?e:(()=>{let o=ze(e);return i=>o.test(i)})(),r={kind:"mount",nodes:[],mounts:[]},s=[...this._nodes.keys(),...this._mounts.keys()].filter(o=>n(o));for(let o of s){let i=this.remove(o);r.nodes.push(...i.nodes),r.mounts.push(...i.mounts)}return r.nodes.sort(),r.mounts.sort(),r}[Symbol.iterator](){let e=[...this._nodes.keys()].sort(),n=this._nodes,r=0;return{[Symbol.iterator](){return this},next(){if(r>=e.length)return{value:void 0,done:!0};let s=e[r++];return{value:[s,n.get(s)],done:!1}}}}node(e){if(e==="")throw new Error(`Graph "${this.name}": node name must be non-empty`);if(e.includes(G))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([[$,n]],{actor:r?.actor,internal:s,delivery:"write"})}setAll(e,n){let r=Symbol.iterator in e?e:Object.entries(e);Se(()=>{for(let[s,o]of r)this.set(s,o,n)})}invalidate(e,n){let r=n?.internal===!0;this.node(e).down([[J]],{actor:n?.actor,internal:r,delivery:"write"})}error(e,n,r){let s=r?.internal===!0;this.node(e).down([[M,n]],{actor:r?.actor,internal:s,delivery:"write"})}complete(e,n){let r=n?.internal===!0;this.node(e).down([[H]],{actor:n?.actor,internal:r,delivery:"write"})}edges(e){let n=e?.recursive===!0,r=new Map;if(!n){for(let[c,u]of this._nodes)r.set(u,c);let a=[];for(let[c,u]of this._nodes)if(u instanceof L)for(let d of u._deps){let p=r.get(d.node);p!=null&&a.push([p,c])}return a.sort((c,u)=>c[0]<u[0]?-1:c[0]>u[0]?1:c[1]<u[1]?-1:c[1]>u[1]?1:0),a}let s=[];this._collectObserveTargets("",s);let o=new Map;for(let[a,c]of s)o.set(c,a);let i=[];for(let[a,c]of s)if(c instanceof L)for(let u of c._deps){let d=o.get(u.node);d!=null&&i.push([d,a])}return i.sort((a,c)=>a[0]<c[0]?-1:a[0]>c[0]?1:a[1]<c[1]?-1:a[1]>c[1]?1:0),i}mount(e,n){if(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(n===this)throw new Error(`Graph "${this.name}": cannot mount a graph into itself`);if(n._parent!=null)throw new Error(`Graph "${this.name}": this child graph is already mounted on "${n._parent.name}"`);for(let r=this;r!=null;r=r._parent)if(r===n)throw new Error(`Graph "${this.name}": mount("${e}", \u2026) would create a mount cycle`);return this._mounts.set(e,n),n._parent=this,this._emitTopology({kind:"added",name:e,nodeKind:"mount"}),n}resolve(e){let n=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]===z)return this._resolveMetaChainFromNode(o,s,n.join(G));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(G)}" is invalid`):new Error(`Graph "${this.name}": unknown mount or node "${r}"`);return i.resolve(s.join(G))}_resolveMetaChainFromNode(e,n,r){let s=e,o=0,i=[...n];for(;o<i.length;){if(i[o]!==z)throw new Error(`Graph "${this.name}": expected ${z} segment in meta path "${r}"`);if(o+1>=i.length)throw new Error(`Graph "${this.name}": meta path requires a key after ${z} in "${r}"`);let a=i[o+1],c=s.meta[a];if(!c)throw new Error(`Graph "${this.name}": unknown meta "${a}" in path "${r}"`);s=c,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 c of this._mounts.values())c._signalDeliver(e,n,r,s);let i=n.internal===!0?{internal:!0}:{actor:n.actor,delivery:"signal"},a=xr(e,this.config);for(let c of[...this._nodes.keys()].sort()){let u=this._nodes.get(c);if(!r.has(u)){r.add(u);try{u.down(e,i)}catch(d){if(d instanceof q)throw d;s.push(d)}a.length!==0&&this._signalMetaSubtree(u,a,r,i,s)}}}_signalMetaSubtree(e,n,r,s,o){for(let i of Object.keys(e.meta).sort()){let a=e.meta[i];if(!r.has(a)){r.add(a);try{a.down(n,s)}catch(c){if(c instanceof q)throw c;o.push(c)}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=Le(e?.detail,e?.fields),o=e?.format==="spec",i=o?Le("minimal"):s,a=[];this._collectObserveTargets("",a);let c=new Map;for(let[y,T]of a)c.set(T,y);let u=[];{let y=a.map(([,N])=>N),T=new Set(c.values()),O=0;for(;y.length>0;){let N=y.shift();if(N instanceof L)for(let D of N._deps){let k=D.node;if(c.has(k))continue;let R=k.name??"",S=R;if(!S||T.has(S))if(R){let I=2;for(;T.has(`${R}#${I}`);)I++;S=`${R}#${I}`}else for(S=`__internal__/${O++}`;T.has(S);)S=`__internal__/${O++}`;c.set(k,S),T.add(S),u.push([S,k]),y.push(k)}}}let d=[...a,...u],p={};for(let[y,T]of d){if(n!=null&&!T.allowsObserve(n))continue;let O=ft(T,i),N=T instanceof L?T._deps.map(S=>c.get(S.node)??S.node.name??""):[],{name:D,...k}=O,R={...k,deps:N};if(!o){let S=this._annotations.get(y);S!=null&&(R.annotation=S)}if(r!=null)if(typeof r=="function"){let S=r;if(!(S.length>=2?S(y,R):S(R)))continue}else{let S=!0;for(let[I,V]of Object.entries(r)){let Y=I==="deps_includes"?"depsIncludes":I==="meta_has"?"metaHas":I;if(Y==="depsIncludes"){if(!R.deps.includes(String(V))){S=!1;break}continue}if(Y==="metaHas"){if(!Object.hasOwn(R.meta??{},String(V))){S=!1;break}continue}if(R[Y]!==V){S=!1;break}}if(!S)continue}p[y]=R}let h=new Set(Object.keys(p)),f=[];for(let[y,T]of d)if(T instanceof L)for(let O of T._deps){let N=c.get(O.node);N!=null&&f.push([N,y])}f.sort((y,T)=>y[0]<T[0]?-1:y[0]>T[0]?1:y[1]<T[1]?-1:y[1]>T[1]?1:0);let l=f.map(([y,T])=>({from:y,to:T}));(n!=null||r!=null)&&(l=l.filter(y=>h.has(y.from)&&h.has(y.to)));let g=this._collectSubgraphs(""),b=n!=null||r!=null?g.filter(y=>{let T=`${y}${G}`;return[...h].some(O=>O===y||O.startsWith(T))}):g,w=this,x=e,m={name:this.name,nodes:p,edges:l,subgraphs:b,expand(y){let T={...x,format:void 0};return Array.isArray(y)?(T.fields=y,T.detail=void 0):(T.detail=y,T.fields=void 0),w.describe(T)}},v=e??{},_=v.format;return _==="json"?lr(m,v):_==="pretty"?fr(m,v):_==="mermaid"?an(m,v):_==="mermaid-url"?pr(m,v):_==="d2"?gr(m,v):_==="ascii"?Kt(m,v):m}_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}${G}`))}return n}resourceProfile(e){return Qt(this,e)}reachable(e,n,r={}){return r.withDetail===!0?rn(this.describe(),e,n,{...r,withDetail:!0}):rn(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,c]of Object.entries(s.nodes))c.lastMutation!=null&&i.set(a,c.lastMutation);return qt(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=ue(s,{name:`${r}_version`}),i=this.observe({timeline:!0,structured:!0}),a=!1,c=!1,u=()=>{a||c||(a=!0,xe(()=>{a=!1,!c&&(s+=1,o.emit(s))}))},d=i.onEvent(b=>{let w=b.type;w!=="data"&&w!=="error"&&w!=="complete"&&w!=="teardown"||u()}),p=[],h=new WeakSet,f=b=>{if(h.has(b)||c)return;h.add(b);let w=b.topology.subscribe(x=>{for(let m of x){if(m[0]!==$)continue;let v=m[1];if(u(),v.kind==="added"&&v.nodeKind==="mount"){let _=b._mounts.get(v.name);_!=null&&f(_)}}});p.push(w);for(let x of b._mounts.keys()){let m=b._mounts.get(x);m!=null&&f(m)}};f(this);let l;try{l=ce([o],()=>this.describe(n),{name:r,describeKind:"derived",meta:{domain:"audit",kind:"describe"},equals:(b,w)=>b===w})}catch(b){d();for(let w of p)w();throw i.dispose(),b}let g=pt(l);return{node:l,dispose(){c=!0,d();for(let b of p)b();p.length=0,i.dispose(),g()}}}_explainReactive(e,n,r){let s=0,o=ue(s,{name:"explain_version"}),i=this.observe({timeline:!0,structured:!0}),a=!1,c=!1,u=i.onEvent(f=>{let l=f.type;l!=="data"&&l!=="error"&&l!=="complete"&&l!=="teardown"||a||c||(a=!0,xe(()=>{a=!1,!c&&(s+=1,o.emit(s))}))}),d={...r?.maxDepth!=null?{maxDepth:r.maxDepth}:{},...r?.findCycle===!0?{findCycle:!0}:{}},p;try{p=ce([o],()=>this._explainStatic(e,n,d),{name:r?.name??"explain",describeKind:"derived",meta:{domain:"audit",kind:"explain_path",from:e,to:n},equals:(f,l)=>f.found===l.found&&f.reason===l.reason&&f.steps.length===l.steps.length&&Or(f.steps,l.steps)})}catch(f){throw u(),i.dispose(),f}let h=pt(p);return{node:p,dispose(){c=!0,u(),i.dispose(),h()}}}_pathsMatching(e){let n=ze(e),r=[];return this._collectObserveTargets("",r),r.map(([s])=>s).filter(s=>n.test(s))}_collectObserveTargets(e,n){for(let r of[...this._mounts.keys()].sort()){let s=e===""?r:`${e}${G}${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}${G}${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}${G}${z}${G}${s}`;r.push([i,o]),this._appendMetaObserveTargets(i,o,r)}}observe(e,n){let r=typeof e=="string",o=nn(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,p=this.resolve(d);if(a!=null&&!p.allowsObserve(a))throw new q({actor:a,action:"observe",nodeName:d});return i?this._buildStructuredObserver([[d,p]],o,"one"):{subscribe(h){return p.subscribe(h)},up(h){try{p.up?.(h)}catch(f){if(f instanceof q)return;throw f}}}}let c=[];this._collectObserveTargets("",c),c.sort((d,p)=>d[0]<p[0]?-1:d[0]>p[0]?1:0);let u=a==null?c:c.filter(([,d])=>d.allowsObserve(a));return i?this._buildStructuredObserver(u,o,"all"):{subscribe:d=>{let p=u.map(([h,f])=>f.subscribe(l=>{d(h,l)}));return()=>{for(let h of p)h()}},up:(d,p)=>{try{this.resolve(d).up?.(p)}catch(h){if(h instanceof q)return;throw h}}}}_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,p)=>d[0]<p[0]?-1:d[0]>p[0]?1:0);let c=i.actor,u=c==null?a:a.filter(([,d])=>d.allowsObserve(c));return this._buildStructuredObserver(u,i,"all")};return this._createObserveResult(e,n,o)}_createObserveResult(e,n,r){let s=n.timeline===!0,o=n.causal===!0,i=n.derived===!0,a=n.detail==="minimal",c=this.config.inspectorEnabled,u=(o||i)&&c,d=n.maxEvents,p=d!=null&&d>0?new Ne(d):null,h=[],f=new Set,l={},g=new Set,b=0,w=0,x=0,m=0,v=0,_=0,y=!1,T=!1,O=0,N=new Map,D=new Map,k=new Map,R=E=>{p?p.push(E):h.push(E);for(let C of f)C(E)},S=()=>s?{timestamp_ns:ge(),in_batch:ke(),batch_id:O}:{},I=(E,C)=>{if(!(!u||!(E instanceof L)))return E._setInspectorHook(U=>{if(U.kind==="dep_message")N.set(E,U.depIndex);else if(U.kind==="run"){let ve=U.batchData.map((A,B)=>A!=null&&A.length>0?A.at(-1):U.prevData[B]);D.set(E,ve);let W=U.batchData.map(A=>A!=null?[...A]:void 0);k.set(E,W),i&&R({type:"derived",path:C,dep_values:ve,dep_batches:W,...S()})}})},V=E=>{let C=N.get(E),U=D.get(E);if(!o||U==null)return{};let W=(C!=null&&C>=0&&E instanceof L?E._deps[C]:void 0)?.node,A=W?.v,B=k.get(E);return{trigger_dep_index:C,trigger_dep_name:W?.name,...A!=null?{trigger_version:{id:A.id,version:A.version}}:{},dep_values:[...U],...B!=null?{dep_batches:B}:{}}},Y=[],oe=[];for(let[E,C]of e){let U=I(C,E);U&&Y.push(U),oe.push(C.subscribe(ve=>{O++;for(let W of ve){let A=W[0],B=S();if(A===$){l[E]=W[1];let Ye=C instanceof L?C.lastMutation?.actor??he:he;R({type:"data",path:E,data:W[1],actor:Ye,...B,...V(C)})}else if(a)A===Z?b++:A===F?w++:A===J?x++:A===Q?m++:A===te?v++:A===j?_++:A===H&&!g.has(E)?y=!0:A===M&&(T=!0,g.add(E));else if(A===Z)b++,R({type:"dirty",path:E,...B});else if(A===F)w++,R({type:"resolved",path:E,...B,...V(C)});else if(A===J)x++,R({type:"invalidate",path:E,...B});else if(A===Q)m++,R({type:"pause",path:E,lockId:W[1],...B});else if(A===te)v++,R({type:"resume",path:E,lockId:W[1],...B});else if(A===H)g.has(E)||(y=!0),R({type:"complete",path:E,...B});else if(A===M){T=!0,g.add(E);let Ye=C instanceof L?C.lastMutation?.actor??he:he;R({type:"error",path:E,data:W[1],actor:Ye,...B})}else A===j&&(_++,R({type:"teardown",path:E,...B}))}}))}let We=!1,Ke=()=>{if(!We){We=!0;for(let E of oe)E();for(let E of Y)E();for(let E of Ee)E({value:void 0,done:!0});Ee.length=0}},qe=[],Ee=[];f.add(E=>{let C=Ee.shift();C?C({value:E,done:!1}):qe.push(E)});let bt={get values(){return l},get dirtyCount(){return b},get resolvedCount(){return w},get invalidateCount(){return x},get pauseCount(){return m},get resumeCount(){return v},get teardownCount(){return _},get events(){return p?p.toArray():[...h]},get anyCompletedCleanly(){return y},get anyErrored(){return T},get completedWithoutErrors(){return y&&!T},onEvent(E){return f.add(E),()=>f.delete(E)},dispose:Ke,expand(E){Ke();let C={...n};return typeof E=="string"?C.detail=E:Object.assign(C,E),r(nn(C))},[Symbol.asyncIterator](){return{next(){return qe.length>0?Promise.resolve({value:qe.shift(),done:!1}):We?Promise.resolve({value:void 0,done:!0}):new Promise(E=>Ee.push(E))},return(){return Ke(),Promise.resolve({value:void 0,done:!0})}}}};return n.format!=null&&this._attachFormatLogger(bt,n),bt}_attachFormatLogger(e,n){let r=n.format;if(r==null)return;let s=n.logger??(l=>console.log(l)),o=n.includeTypes?new Set(n.includeTypes):null,i=n.excludeTypes?new Set(n.excludeTypes):null,a=o==null&&i==null?()=>!0:l=>(o==null||o.has(l))&&(i==null||!i.has(l)),c=vr(n.theme),u=r==="stage-log"?ge():0,d=l=>l==null?"":n.stageLabels?.[l]??l,p=(l,g)=>l.length>g?`${l.slice(0,g-1)}\u2026`:l,h=l=>l.type==="data"||l.type==="error"?p(Ue(l.data),120):"",f=l=>{if(r==="stage-log"){let T=(ge()-u)/1e9,O=d(l.path).padEnd(9);if(l.type==="data"){let N=h(l);return`[${T.toFixed(3)}s] ${O} \u2190${N?` ${N}`:""}`}if(l.type==="error"){let N=h(l);return`[${T.toFixed(3)}s] ${O} \u2717${N?` ${N}`:""}`}return l.type==="complete"?`[${T.toFixed(3)}s] ${O} \u25A0 complete`:`[${T.toFixed(3)}s] ${O} ${l.type}`}if(r==="json")try{return JSON.stringify(l)}catch{return JSON.stringify({type:l.type,path:l.path,data:"[unserializable]"})}let g=c[l.type]??"",b=l.path?`${c.path}${l.path}${c.reset} `:"",w=l.type==="data"||l.type==="error",x=l.type==="pause"||l.type==="resume",m=w?` ${Ue(l.data)}`:x?` ${Ue(l.lockId)}`:"",v=l.type==="data"||l.type==="resolved"||l.type==="derived"?l:void 0,_=v?.trigger_dep_name!=null?` <- ${v.trigger_dep_name}`:v?.trigger_dep_index!=null?` <- #${v.trigger_dep_index}`:"",y=l.in_batch?" [batch]":"";return`${b}${g}${l.type.toUpperCase()}${c.reset}${m}${_}${y}`};e.onEvent(l=>{a(l.type)&&s(f(l),l)})}addDisposer(e){return this._disposers.add(e),()=>{this._disposers.delete(e)}}destroy(){en(this._disposers,this.name),this.signal([[j]],{internal:!0}),en(this._storageDisposers,this.name);for(let e of[...this._mounts.values()])e._parent=void 0,e._destroyClearOnly();this._mounts.clear(),this._nodes.clear(),this._parent=void 0}_destroyClearOnly(){for(let e of[...this._mounts.values()])e._parent=void 0,e._destroyClearOnly();this._mounts.clear(),this._nodes.clear(),this._parent=void 0}snapshot(e){let{expand:n,...r}=this.describe({detail:"full"}),s={};for(let a of Object.keys(r.nodes).sort()){let{lastMutation:c,guard:u,...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 Tt(a,a.encode(i))}throw new Error(`snapshot: unknown format "${String(e.format)}"`)}static decode(e,n){let r=n?.config??me,{codec:s,codecVersion:o,payload:i}=Ot(e,r);return s.decode(i,o)}restore(e,n){if(tn(e),e.name!==this.name)throw new Error(`Graph "${this.name}": restore snapshot name "${e.name}" does not match this graph`);let r=n?.only==null?null:(Array.isArray(n.only)?n.only:[n.only]).map(o=>ze(o)),s=n?.includeProducers===!0;for(let o of Object.keys(e.nodes).sort()){if(r!==null&&!r.some(a=>a.test(o)))continue;let i=e.nodes[o];if(i!==void 0){if(!("value"in i)||i.value===void 0){"value"in i&&i.value===void 0&&n?.onError?.(o,new Error(`restore: slice.value is undefined for "${o}" (undefined is the global SENTINEL; not valid DATA)`));continue}if(!(i.type==="derived"||i.type==="effect")&&!(i.type==="producer"&&!s)){if(i.v!=null){let c=this.tryResolve(o)?.v;if(c!=null&&c.id===i.v.id&&c.version===i.v.version)continue}try{this.set(o,i.value)}catch(a){n?.onError?.(o,a)}}}}}static fromSnapshot(e,n){tn(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 f of[...e.subgraphs].sort((l,g)=>{let b=l.split(G).length,w=g.split(G).length;return b!==w?b-w:l<g?-1:l>g?1:0})){let l=f.split(G),g=o;for(let b of l)g._mounts.has(b)||g.mount(b,new t(b)),g=g._mounts.get(b)}let i=s?Object.entries(s).map(([f,l])=>({re:ze(f),factory:l})):[],a=f=>{for(let l of i)if(l.re.test(f))return l.factory},c=f=>{let l=f.split(G),g=l.pop();if(g==null||g.length===0)throw new Error(`invalid snapshot path "${f}"`);let b=o;for(let w of l){let x=b._mounts.get(w);if(!x)throw new Error(`unknown mount "${w}" in path "${f}"`);b=x}return[b,g]},u=Object.entries(e.nodes).filter(([f])=>!f.includes(`${G}${z}${G}`)).sort((f,l)=>f[0]<l[0]?-1:f[0]>l[0]?1:0),d=new Map(u),p=new Map,h=!0;for(;d.size>0&&h;){h=!1;for(let[f,l]of[...d.entries()]){let g=l?.deps??[];if(!g.every(_=>p.has(_)))continue;let[b,w]=c(f),x={...l?.meta??{}},m=a(f),v;if(l?.type==="state")v=ue(l.value,{meta:x});else{if(m==null)continue;v=m(w,{path:f,type:l.type,value:l.value,meta:x,deps:g,resolvedDeps:g.map(_=>p.get(_))})}b.add(v,{name:w}),p.set(f,v),d.delete(f),h=!0}}if(d.size>0){let f=[...d.keys()].sort().join(", ");throw new Error(`Graph.fromSnapshot could not reconstruct nodes without build callback: ${f}. Pass matching factories via fromSnapshot(data, { factories: { pattern: factoryFn } }).`)}return o.restore(e),o}toJSON(){return this.snapshot()}attachStorage(e,n={}){let r=e.map(u=>({tier:u,debounceMs:Math.max(0,u.debounceMs??0),compactEvery:Math.max(1,u.compactEvery??10),timer:void 0,seq:0,lastSnapshot:void 0,lastFingerprint:"",disposed:!1,savePending:void 0}));n.autoRestore===!0&&this._cascadeRestore(e,n.onError);let s=(u,d)=>{if(u.disposed)return;let p=ir(d.nodes);if(u.lastSnapshot!=null&&p!==""&&p===u.lastFingerprint)return;let h=u.seq+1,f=Ce(),b=u.lastSnapshot==null||h%u.compactEvery===0?{mode:"full",snapshot:d,seq:h,timestamp_ns:f,format_version:ye}:{mode:"diff",diff:Tr(u.lastSnapshot,d),seq:h,timestamp_ns:f,format_version:ye};if(u.tier.filter&&!u.tier.filter(this.name,b))return;let w;try{w=u.tier.save(this.name,b)}catch(x){n.onError?.(x,u.tier);return}if(w&&typeof w.then=="function"){let v=(u.savePending??Promise.resolve()).then(()=>w,()=>w).then(()=>{u.disposed||(u.seq=h,u.lastSnapshot=d,u.lastFingerprint=p)},_=>{n.onError?.(_,u.tier)});u.savePending=v.finally(()=>{u.savePending===v&&(u.savePending=void 0)})}else u.seq=h,u.lastSnapshot=d,u.lastFingerprint=p},o=(u,d)=>{try{s(u,d)}catch(p){n.onError?.(p,u.tier)}},i=(u,d)=>{if(!d.some(l=>{let g=this.config.messageTier(l[0]);return g>=3&&g<5}))return;if(n.filter){let l=this.tryResolve(u);if(l==null)return;let g=ft(l,Le("standard"));if(!n.filter(u,g))return}let h,f=()=>(h==null&&(h=this.snapshot()),h);for(let l of r)l.disposed||(l.debounceMs===0?o(l,f()):(l.timer==null&&(l.timer=new Pe),l.timer.start(l.debounceMs,()=>{l.disposed||o(l,this.snapshot())})))},a;if(n.paths!=null){let d=(typeof n.paths=="string"?this._pathsMatching(n.paths):n.paths).map(p=>{let h=this.tryResolve(p);return h==null?()=>{}:h.subscribe(f=>i(p,f))});a=()=>{for(let p of d)p()}}else a=this.observe().subscribe((u,d)=>i(u,d));let c=()=>{a();for(let u of r)u.disposed=!0,u.timer?.cancel();this._storageDisposers.delete(c)};return this._storageDisposers.add(c),{dispose:c}}async _cascadeRestore(e,n){for(let r of e){let s;try{s=await r.load(this.name)}catch(i){n?.(i,r);continue}if(s==null||typeof s!="object"||Array.isArray(s))continue;let o=s;try{if(o.mode==="full"&&o.snapshot!=null)return this.restore(o.snapshot),!0;if(o.version===ye&&o.nodes!=null)return this.restore(o),!0}catch(i){n?.(i,r)}}return!1}static async fromStorage(e,n,r){for(let s of n){let o;try{o=await s.load(e)}catch(c){r?.onError?.(c,s);continue}if(o==null||typeof o!="object"||Array.isArray(o))continue;let i=o,a=i.mode==="full"&&i.snapshot!=null?i.snapshot:i.version===ye&&i.nodes!=null?i:void 0;if(a!=null)try{return t.fromSnapshot(a,r)}catch(c){r?.onError?.(c,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(x=>!r.has(x)).sort(),i=[...r].filter(x=>!s.has(x)).sort(),a=[],c=[];for(let x of r){if(!s.has(x))continue;let m=e.nodes[x],v=n.nodes[x],_=m.v,y=v.v;_!=null&&y!=null&&_.id===y.id&&_.version!==y.version&&c.push({path:x,id:_.id,from:_.version,to:y.version});let T=_!=null&&y!=null&&_.id===y.id&&_.version===y.version;for(let O of["type","status","sentinel"]){let N=m[O],D=v[O];N!==D&&a.push({path:x,field:O,from:N,to:D})}if(!T)for(let O of["value","meta"]){let N=m[O],D=v[O];ar(N,D)||a.push({path:x,field:O,from:N,to:D})}}let u=x=>`${x.from} ${x.to}`,d=new Set(e.edges.map(u)),p=new Set(n.edges.map(u)),h=n.edges.filter(x=>!d.has(u(x))),f=e.edges.filter(x=>!p.has(u(x))),l=new Set(e.subgraphs),g=new Set(n.subgraphs),b=[...g].filter(x=>!l.has(x)).sort(),w=[...l].filter(x=>!g.has(x)).sort();return{nodesAdded:o,nodesRemoved:i,nodesChanged:a,versionChanges:c,edgesAdded:h,edgesRemoved:f,subgraphsAdded:b,subgraphsRemoved:w}}};function Tr(t,e){let n=de.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 rn(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,c=new Map,u=new Map,d=new Set;for(let[m,v]of Object.entries(t.nodes)){if(!m)continue;d.add(m);let _=v.deps??[];i.set(m,_);for(let y of _)y&&(d.add(y),a.has(y)||a.set(y,new Set),a.get(y).add(m))}for(let m of t.edges){if(m==null||typeof m!="object")continue;let v=typeof m.from=="string"?m.from:"",_=typeof m.to=="string"?m.to:"";!v||!_||(d.add(v),d.add(_),u.has(v)||u.set(v,new Set),u.get(v).add(_),c.has(_)||c.set(_,new Set),c.get(_).add(v))}if(!d.has(e))return r.withDetail?s:[];let p=r.both===!0,h=m=>{if(p){let T=i.get(m)??[],O=c.get(m),N=a.get(m),D=u.get(m),k=[...T];return O&&k.push(...O),N&&k.push(...N),D&&k.push(...D),k}if(n==="upstream"){let T=i.get(m)??[],O=c.get(m);return O?[...T,...O]:T}let v=a.get(m),_=u.get(m),y=v?[...v]:[];return _&&y.push(..._),y},f=new Set([e]),l=new Map,g=[{path:e,depth:0}],b=0,w=!1;for(;b<g.length;){let m=g[b++];if(o!=null&&m.depth>=o){h(m.path).length>0&&(w=!0);continue}for(let v of h(m.path))!v||f.has(v)||(f.add(v),l.set(v,m.depth+1),g.push({path:v,depth:m.depth+1}))}let x=[...l.keys()].sort((m,v)=>m<v?-1:m>v?1:0);return r.withDetail?{paths:x,depths:l,truncated:w}:x}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 cn(t,e,n){return{[t]:!0,[`${t}_type`]:e,...n??{}}}function ee(t,e){if(typeof e=="string")return{node:t.resolve(e),path:e};let n=Nr(t,e);if(!n)throw new Error("orchestration dep node must already be registered in the graph so explicit edges can be recorded; pass a string path or register the node first");return{node:e,path:n}}function Nr(t,e){let n=t.describe(),r=`::${z}::`;for(let s of Object.keys(n.nodes).sort())if(!s.includes(r))try{if(t.resolve(s)===e)return s}catch{}}function re(t,e,n,r){t.add(n,{name:e})}function se(t,e){return cn("orchestration",t,e)}function Er(t){let e=r=>{let s=r.trim();return s.length===0?0:Number(s)},n;return typeof t=="string"?n=e(t):t===null?n=0:n=Number(t),Number.isFinite(n)?Math.max(0,Math.trunc(n)):1}function dn(t,e){return new de(t,e)}function kr(t,e,n,r){let o=(r?.deps??[]).map(d=>ee(t,d)),{deps:i,...a}=r??{},c=(d,p,h)=>{let f=d.map((l,g)=>l!=null&&l.length>0?l.at(-1):h.prevData[g]);p.emit(n(f,h))},u=X(o.map(d=>d.node),c,{...a,name:e,describeKind:"derived",meta:se("task",r?.meta)});return re(t,e,u,o.flatMap(d=>d.path?[d.path]:[])),u}function Sr(t,e,n,r,s){let o=ee(t,n),i=ce([o.node],([a])=>({branch:r(a)?"then":"else",value:a}),{...s,name:e,meta:se("branch",s?.meta)});return re(t,e,i,o.path?[o.path]:[]),i}function Rr(t,e,n,r,s){let o=ee(t,n),i=ee(t,r),a=s?.isApproved??(u=>!!u),c=X([o.node,i.node],(u,d,p)=>{let h=u[0],f=u[1],l=f!=null&&f.length>0?f.at(-1):p.prevData[1];if(l===void 0||!a(l)){d.down([[F]]);return}if(h==null||h.length===0){f!=null&&f.length>0&&p.prevData[0]!==void 0?d.emit(p.prevData[0]):d.down([[F]]);return}for(let g of h)d.emit(g)},{...s,name:e,describeKind:"derived",meta:se("approval",s?.meta)});return re(t,e,c,[o.path,i.path].filter(u=>typeof u=="string")),c}function Dr(t,e,n,r){let s=r?.maxPending??1/0;if(s<1&&s!==1/0)throw new RangeError("gate: maxPending must be >= 1");let o=r?.startOpen??!1,i=ee(t,n),a=ue([],{name:"pending",equals:()=>!1}),c=ue(o,{name:"isOpen"}),u=ce([a],([_])=>_.length,{name:"count"}),d=[],p=!1,h=o,f=c.subscribe(_=>{for(let y of _)y[0]===$&&(h=y[1])});function l(){a.emit([...d])}function g(_){d.push(_),d.length>s&&d.shift(),l()}function b(_){let y=d.splice(0,_);return l(),y}function w(_){if(p)throw new Error(`gate: ${_}() called after gate was torn down`)}let x=X([i.node],(_,y,T)=>{let O=T.terminalDeps[0];if(O!==void 0){p=!0,d=[],l(),y.down(O===!0?[[H]]:[[M,O]]);return}let N=_[0];if(N==null||N.length===0){y.down([[F]]);return}for(let D of N)h?y.emit(D):(g(D),y.down([[F]]))},{name:e,describeKind:"derived",meta:se("gate",r?.meta)}),m={node:x,pending:a,count:u,isOpen:c,approve(_=1){w("approve");let y=b(_);for(let T of y){if(p)break;x.emit(T)}},reject(_=1){w("reject"),b(_)},modify(_,y=1){w("modify");let T=[...d],O=b(y);for(let N=0;N<O.length&&!p;N++)x.emit(_(O[N],N,T))},open(){w("open"),Se(()=>{c.emit(!0);let _=b(d.length);for(let y of _){if(p)break;x.emit(y)}})},close(){w("close"),c.emit(!1)}};t.addDisposer(u.subscribe(()=>{})),t.addDisposer(f),re(t,e,x,i.path?[i.path]:[]);let v=new de(`${e}_state`);return v.add(a,{name:"pending"}),v.add(c,{name:"isOpen"}),v.add(u,{name:"count"}),t.mount(`${e}_state`,v),m}function Ar(t,e,n,r){let s=n.map(i=>ee(t,i)),o=ce(s.map(i=>i.node),i=>i,{...r,name:e,meta:se("join",r?.meta)});return re(t,e,o,s.flatMap(i=>i.path?[i.path]:[])),o}function Cr(t,e,n,r,s){let o=ee(t,n),i=s?.iterations,a=typeof i=="number"||i===void 0?void 0:ee(t,i),c=typeof i=="number"?i:void 0,u=X(a?[o.node,a.node]:[o.node],(d,p,h)=>{let f=d[0],l=f!=null&&f.length>0?f.at(-1):h.prevData[0],g=a?d[1]:void 0,b=c??(a?g!=null&&g.length>0?g.at(-1):h.prevData[1]:1),w=Er(b);for(let x=0;x<w;x+=1)l=r(l,x,p);p.emit(l)},{...s,name:e,describeKind:"derived",meta:se("loop",s?.meta)});return re(t,e,u,[o.path,a?.path].filter(d=>typeof d=="string")),u}function Mr(t,e,n,r){let s=n instanceof de?n:dn(e,r);return typeof n=="function"&&n(s),t.mount(e,s),s}function Gr(t,e,n,r){let s=X([],()=>{},{...r,name:e,initial:n,describeKind:"producer",meta:se("sensor",r?.meta)});return re(t,e,s,[]),{node:s,push(o){s.emit(o)},error(o){s.down([[M,o]])},complete(){s.down([[H]])}}}function Ir(t,e,n,r,s){let o=ee(t,n),i=!1,a=X([],(c,u)=>{let d=o.node.subscribe(p=>{for(let h of p){if(i)return;if(h[0]===M)try{u.emit(r(h[1],u))}catch(f){i=!0,u.down([[M,f]])}else u.down([h]),h[0]===H&&(i=!0)}});return()=>d()},{...s,name:e,describeKind:"derived",completeWhenDepsComplete:!1,errorWhenDepsError:!1,meta:se("onFailure",s?.meta)});return re(t,e,a,o.path?[o.path]:[]),a}0&&(module.exports={approval,branch,gate,join,loop,onFailure,pipeline,sensor,subPipeline,task});
1
+ "use strict";var Je=Object.defineProperty;var ln=Object.getOwnPropertyDescriptor;var fn=Object.getOwnPropertyNames;var pn=Object.prototype.hasOwnProperty;var K=(t,e)=>()=>(t&&(e=t(t=0)),e);var hn=(t,e)=>{for(var n in e)Je(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))!pn.call(t,s)&&s!==n&&Je(t,s,{get:()=>e[s],enumerable:!(r=ln(e,s))||r.enumerable});return t};var mn=t=>gn(Je({},"__esModule",{value:!0}),t);function ke(){return le>0||_e}function yt(){return le>0}function xe(t){le>0?we.push(t):t()}function Se(t){le+=1;let e=!1;try{t()}catch(n){throw e=!0,n}finally{if(le-=1,le===0)if(e){if(!_e){let n=we.splice(0);for(let r of n)try{r()}catch{}ie.length=0,ae.length=0,fe.length=0}}else bn()}}function bn(){let t=!_e;t&&(_e=!0);let e=[],n=0;try{for(;ie.length>0||ae.length>0||fe.length>0||t&&we.length>0;){if(t&&we.length>0){let o=we.splice(0);for(let i of o)try{i()}catch(a){e.push(a)}continue}if(n+=1,n>1e3)throw ie.length=0,ae.length=0,fe.length=0,new Error("batch drain exceeded 1000 iterations \u2014 likely a reactive cycle");let s=(ie.length>0?ie:ae.length>0?ae:fe).splice(0);for(let o of s)try{o()}catch(i){e.push(i)}}}finally{t&&(_e=!1)}if(e.length===1)throw e[0];if(e.length>1)throw new AggregateError(e,"batch drain: multiple callbacks threw")}function Re(t,e,n){if(e.length===0)return;if(e.length===1){let u=n(e[0][0]);if(u<3||!ke()){t(e);return}(u>=5?fe:u===4?ae:ie).push(()=>t(e));return}let r=e.length,s=r,o=r,i=r,a=0;for(;a<r&&n(e[a][0])<3;)a++;for(s=a;a<r&&n(e[a][0])===3;)a++;for(o=a;a<r&&n(e[a][0])===4;)a++;i=a;let d=ke();if(s>0){let u=e.slice(0,s);t(u)}if(o>s){let u=e.slice(s,o);d?ie.push(()=>t(u)):t(u)}if(i>o){let u=e.slice(o,i);d?ae.push(()=>t(u)):t(u)}if(r>i){let u=e.slice(i,r);d?fe.push(()=>t(u)):t(u)}}var le,_e,ie,ae,fe,we,De=K(()=>{"use strict";le=0,_e=!1,ie=[],ae=[],fe=[],we=[]});var Te,$,Z,F,J,Q,te,j,H,M,pe,Xe,yn,Ze,vn,_n,Qe,vt,_t,wt,et,Oe=K(()=>{"use strict";Te=Symbol.for("graphrefly/START"),$=Symbol.for("graphrefly/DATA"),Z=Symbol.for("graphrefly/DIRTY"),F=Symbol.for("graphrefly/RESOLVED"),J=Symbol.for("graphrefly/INVALIDATE"),Q=Symbol.for("graphrefly/PAUSE"),te=Symbol.for("graphrefly/RESUME"),j=Symbol.for("graphrefly/TEARDOWN"),H=Symbol.for("graphrefly/COMPLETE"),M=Symbol.for("graphrefly/ERROR"),pe=Object.freeze([Z]),Xe=Object.freeze([F]),yn=Object.freeze([J]),Ze=Object.freeze([Te]),vn=Object.freeze([H]),_n=Object.freeze([j]),Qe=Object.freeze([pe]),vt=Object.freeze([Xe]),_t=Object.freeze([yn]),wt=Object.freeze([vn]),et=Object.freeze([_n])});function Tt(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++]=tt,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 Ot(t,e){if(t.length<xt)throw new Error(`decodeEnvelope: bytes too short (${t.length} < ${xt})`);let n=0,r=t[n++];if(r!==tt)throw new Error(`decodeEnvelope: unsupported envelope version ${r} (expected ${tt})`);let s=t[n++];if(s===0)throw new Error("decodeEnvelope: name_len must be >= 1");if(n+s+2>t.length)throw new Error(`decodeEnvelope: envelope truncated (need ${n+s+2} bytes, have ${t.length})`);let o=new TextDecoder().decode(t.subarray(n,n+s));n+=s;let i=(t[n]<<8|t[n+1])>>>0;n+=2;let a=t.subarray(n),d=e.lookupCodec(o);if(d==null)throw new Error(`decodeEnvelope: codec "${o}" not registered (envelope codec_v=${i})`);return{codec:d,codecVersion:i,payload:a}}function Nt(t){t.registerCodec(wn)}var wn,tt,xt,nt=K(()=>{"use strict";wn={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)}},tt=1,xt=4});function Ae(t){if(t==null)return he;let{type:e,id:n,...r}=t;return{type:e??"system",id:n??"",...r}}var he,rt=K(()=>{"use strict";he={type:"system",id:""}});function ge(){return Math.trunc(performance.now()*1e6)}function Ce(){return Date.now()*1e6}var st=K(()=>{"use strict"});function Et(t){t.registerMessageType(Te,{tier:0,wireCrossing:!1}),t.registerMessageType(Z,{tier:1,wireCrossing:!1}),t.registerMessageType(J,{tier:1,wireCrossing:!1,metaPassthrough:!1}),t.registerMessageType(Q,{tier:2,wireCrossing:!1}),t.registerMessageType(te,{tier:2,wireCrossing:!1}),t.registerMessageType($,{tier:3,wireCrossing:!0}),t.registerMessageType(F,{tier:3,wireCrossing:!0}),t.registerMessageType(H,{tier:4,wireCrossing:!0,metaPassthrough:!1}),t.registerMessageType(M,{tier:4,wireCrossing:!0,metaPassthrough:!1}),t.registerMessageType(j,{tier:5,wireCrossing:!0,metaPassthrough:!1})}var Me,kt=K(()=>{"use strict";Oe();Me=class{_messageTypes=new Map;_codecs=new Map;_onMessage;_onSubscribe;_defaultVersioning;_defaultHashFn;_inspectorEnabled=!(typeof process<"u"&&process.env?.NODE_ENV==="production");_globalInspector;_frozen=!1;tierOf;constructor(e){this._onMessage=e.onMessage,this._onSubscribe=e.onSubscribe,this._defaultVersioning=e.defaultVersioning,this._defaultHashFn=e.defaultHashFn,this.tierOf=n=>{let r=this._messageTypes.get(n);return r!=null?r.tier:1}}get onMessage(){return this._frozen=!0,this._onMessage}get onSubscribe(){return this._frozen=!0,this._onSubscribe}set onMessage(e){this._assertUnfrozen(),this._onMessage=e}set onSubscribe(e){this._assertUnfrozen(),this._onSubscribe=e}get defaultVersioning(){return this._defaultVersioning}set defaultVersioning(e){this._assertUnfrozen(),this._defaultVersioning=e}get defaultHashFn(){return this._defaultHashFn}set defaultHashFn(e){this._assertUnfrozen(),this._defaultHashFn=e}get inspectorEnabled(){return this._inspectorEnabled}set inspectorEnabled(e){this._inspectorEnabled=e}get globalInspector(){return this._globalInspector}set globalInspector(e){this._globalInspector=e}registerMessageType(e,n){return this._assertUnfrozen(),this._messageTypes.set(e,{tier:n.tier,wireCrossing:n.wireCrossing??n.tier>=3,metaPassthrough:n.metaPassthrough??!0}),this}messageTier(e){let n=this._messageTypes.get(e);return n!=null?n.tier:1}isWireCrossing(e){let n=this._messageTypes.get(e);return n!=null?n.wireCrossing:!0}isLocalOnly(e){return!this.isWireCrossing(e)}isMetaPassthrough(e){let n=this._messageTypes.get(e);return n!=null?n.metaPassthrough:!0}isKnownMessageType(e){return this._messageTypes.has(e)}registerCodec(e){return this._assertUnfrozen(),this._codecs.set(e.name,e),this}lookupCodec(e){return this._codecs.get(e)}_isFrozen(){return this._frozen}_assertUnfrozen(){if(this._frozen)throw new Error("GraphReFlyConfig is frozen: a node has already captured this config. Register custom types and set hooks before creating any node.")}}});function ot(t){let e=xn.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 q,xn,Ge=K(()=>{"use strict";q=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}},xn=["human","llm","wallet","system"]});function it(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(it);if(typeof t=="object"&&t!==null){let e={};for(let n of Object.keys(t).sort())e[n]=it(t[n]);return e}return null}function Nn(t){let e=On.encode(t),n=e.length,r=n*8,s=n+9+63&-64,o=new Uint8Array(s);o.set(e),o[n]=128;let i=new DataView(o.buffer);i.setUint32(s-4,r>>>0,!1),i.setUint32(s-8,Math.floor(r/4294967296)>>>0,!1);let a=1779033703,d=3144134277,u=1013904242,c=2773480762,p=1359893119,h=2600822924,f=528734635,l=1541459225,g=new Uint32Array(64),b=(x,m)=>x>>>m|x<<32-m;for(let x=0;x<s;x+=64){for(let k=0;k<16;k++)g[k]=i.getUint32(x+k*4,!1);for(let k=16;k<64;k++){let R=g[k-15],S=g[k-2],I=b(R,7)^b(R,18)^R>>>3,V=b(S,17)^b(S,19)^S>>>10;g[k]=g[k-16]+I+g[k-7]+V>>>0}let m=a,v=d,_=u,y=c,T=p,O=h,N=f,D=l;for(let k=0;k<64;k++){let R=b(T,6)^b(T,11)^b(T,25),S=T&O^~T&N,I=D+R+S+Tn[k]+g[k]>>>0,V=b(m,2)^b(m,13)^b(m,22),Y=m&v^m&_^v&_,oe=V+Y>>>0;D=N,N=O,O=T,T=y+I>>>0,y=_,_=v,v=m,m=I+oe>>>0}a=a+m>>>0,d=d+v>>>0,u=u+_>>>0,c=c+y>>>0,p=p+T>>>0,h=h+O>>>0,f=f+N>>>0,l=l+D>>>0}let w=x=>x.toString(16).padStart(8,"0");return w(a)+w(d)+w(u)+w(c)+w(p)+w(h)+w(f)+w(l)}function at(t){let e=it(t??null),n=JSON.stringify(e);return Nn(n).slice(0,16)}function En(){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 ut(t,e,n){let r=n?.id??En();if(t===0)return{id:r,version:0};let o=(n?.hash??at)(e);return{id:r,version:0,cid:o,prev:null}}function St(t,e,n){t.version+=1,"cid"in t&&(t.prev=t.cid,t.cid=n(e))}var Tn,On,Rt=K(()=>{"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]),On=new TextEncoder});function Ct(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 Ie(t){return t.length===0?t:typeof t[0]=="symbol"?[t]:t}function X(t,e,n){let r=Mt(t)?t:[],s=typeof t=="function"?t:typeof e=="function"?e:void 0,o={};return Mt(t)?o=(ct(e)?e:n)??{}:ct(t)?o=t:o=(ct(e)?e:n)??{},new L(r,s,o)}var Dt,At,kn,Sn,me,L,Mt,ct,be=K(()=>{"use strict";nt();rt();De();st();kt();Ge();Oe();Rt();Dt=()=>{},At=100;kn=(t,e,n,r)=>{n.direction==="down-in"&&t._onDepMessage(n.depIndex,e)},Sn=(t,e,n,r)=>{let s=t;if(s._status==="completed"||s._status==="errored")return;let o=s._cached,i=o===void 0?[Ze]:[Ze,[$,o]];s._status==="dirty"&&i.push(pe),Re(e,i,s._config.tierOf)},me=new Me({onMessage:kn,onSubscribe:Sn});Et(me);Nt(me);L=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??me,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??at;let s=r.versioning??this._config.defaultVersioning;this._versioningLevel=s,this._versioning=s!=null?ut(s,this._cached===void 0?void 0:this._cached,{id:r.versioningId,hash:this._hashFn}):void 0,this._deps=e.map(Ct);let o={};for(let[a,d]of Object.entries(r.meta??{})){let u={initial:d,name:`${r.name??"node"}:meta:${a}`,describeKind:"state",config:this._config};r.guard!=null&&(u.guard=r.guard),o[a]=new t([],void 0,u)}Object.freeze(o),this.meta=o,this._hasMeta=Object.keys(o).length>0;let i=this;this._actions={emit(a){i._emit([[$,a]])},down(a){i._emit(Ie(a))},up(a){i._emitUp(Ie(a))}},this.down=this.down.bind(this),this.up=this.up.bind(this)}get _isTerminal(){return this._status==="completed"||this._status==="errored"}get name(){return this._optsName}get status(){return this._status}get cache(){return this._cached===void 0?void 0:this._cached}get lastMutation(){return this._lastMutation}get v(){return this._versioning}hasGuard(){return this._guard!=null}_applyVersioning(e,n){if(this._isExecutingFn)throw new Error(`Node "${this.name}": _applyVersioning cannot run mid-fn \u2014 call it outside of \`_execFn\` (typically at graph setup time before the first subscribe).`);let r=this._versioningLevel;if(r!=null&&e<=r)return;let s=n?.hash??this._hashFn;s!==this._hashFn&&(this._hashFn=s);let o=this._cached===void 0?void 0:this._cached,i=this._versioning,a=i?.id??n?.id,d=i?.version??0,u=ut(e,o,{id:a,hash:s});u.version=d,this._versioning=u,this._versioningLevel=e}_setInspectorHook(e){return e==null?()=>{}:(this._inspectorHooks==null&&(this._inspectorHooks=new Set),this._inspectorHooks.add(e),()=>{this._inspectorHooks?.delete(e),this._inspectorHooks?.size===0&&(this._inspectorHooks=void 0)})}_pushGuard(e){return this._extraGuards==null&&(this._extraGuards=new Set),this._extraGuards.add(e),()=>{this._extraGuards?.delete(e),this._extraGuards?.size===0&&(this._extraGuards=void 0)}}allowsObserve(e){if(this._guard==null&&this._extraGuards==null)return!0;let n=Ae(e);if(this._guard!=null&&!this._guard(n,"observe"))return!1;if(this._extraGuards!=null){for(let r of this._extraGuards)if(!r(n,"observe"))return!1}return!0}_checkGuard(e){if(e?.internal)return;let n=this._guard!=null||this._extraGuards!=null,r=e?.actor!=null;if(!n&&!r)return;let s=Ae(e?.actor),o=e?.delivery==="signal"?"signal":"write";if(this._guard!=null&&!this._guard(s,o))throw new q({actor:s,action:o,nodeName:this.name});if(this._extraGuards!=null){for(let i of this._extraGuards)if(!i(s,o))throw new q({actor:s,action:o,nodeName:this.name})}this._lastMutation={actor:s,timestamp_ns:Ce()}}down(e,n){let r=Ie(e);r.length!==0&&(this._checkGuard(n),this._emit(r))}emit(e,n){this._checkGuard(n),this._emit([[$,e]])}up(e,n){if(this._deps.length===0)return;let r=Ie(e);if(r.length===0)return;this._checkGuard(n);let s=n??{internal:!0};this._validateUpTiers(r);for(let o of this._deps)o.node.up?.(r,s)}_emitUp(e){if(this._deps.length!==0&&e.length!==0){this._validateUpTiers(e);for(let n of this._deps)n.node.up?.(e,{internal:!0})}}_validateUpTiers(e){let n=this._config.tierOf;for(let r of e){let s=n(r[0]);if(s===3||s===4)throw new Error(`Node "${this.name}": tier-${s} messages cannot flow up \u2014 DATA/RESOLVED/COMPLETE/ERROR are downstream-only. Use \`down(...)\` for value delivery; \`up(...)\` is for control signals (DIRTY, INVALIDATE, PAUSE, RESUME, TEARDOWN).`)}}subscribe(e,n){if(n!=null&&this._guard!=null){let d=Ae(n);if(!this._guard(d,"observe"))throw new q({actor:d,action:"observe",nodeName:this.name})}let s=this._isTerminal&&this._resubscribable;if(s){this._cached=void 0,this._status="sentinel",this._store={},this._hasCalledFnOnce=!1,this._waveHasNewData=!1,this._hasNewTerminal=!1,this._paused=!1,this._pendingWave=!1,this._pendingRerun=!1,this._isExecutingFn=!1,this._rerunDepth=0,this._dirtyDepCount=0,this._pauseLocks=null,this._pauseBuffer=null;for(let d of this._deps)dt(d);if(this._partial===!1){for(let d of this._deps)if(d.prevData!==void 0||d.dataBatch.length!==0||d.terminal!==void 0||d.dirty)throw new Error(`resubscribable-reset invariant: DepRecord not fully reset for node ${this._optsName??"(anonymous)"}`)}}this._sinkCount+=1;let o;try{o=this._config.onSubscribe(this,e,{sinkCount:this._sinkCount,afterTerminalReset:s},this._actions)}catch(d){throw this._sinkCount-=1,d}this._sinks==null?this._sinks=e:typeof this._sinks=="function"?this._sinks=new Set([this._sinks,e]):this._sinks.add(e);let i=this._isTerminal;if(this._sinkCount===1&&!i)try{this._activate()}catch(d){if(this._sinkCount-=1,this._removeSink(e),this._sinkCount===0&&(this._status="sentinel"),typeof o=="function")try{o()}catch{}throw d}this._status==="sentinel"&&this._cached===void 0&&(this._status="pending");let a=!1;return()=>{a||(a=!0,this._sinkCount-=1,this._removeSink(e),typeof o=="function"&&o(),this._sinks==null&&this._deactivate())}}_removeSink(e){if(this._sinks===e)this._sinks=null;else if(this._sinks!=null&&typeof this._sinks!="function")if(this._sinks.delete(e),this._sinks.size===1){let[n]=this._sinks;this._sinks=n}else this._sinks.size===0&&(this._sinks=null)}_activate(){if(this._deps.length===0){this._fn&&this._execFn();return}this._dirtyDepCount=0;let e=this._deps.length,n=0;try{for(let r=0;r<e;r++){let s=r,o=this._deps[r];o.unsub=Dt,o.unsub=o.node.subscribe(i=>{if(o.unsub===null)return;let a=this._config.tierOf,d=!1;for(let u of i)a(u[0])>=3&&(d=!0),this._config.onMessage(this,u,{direction:"down-in",depIndex:s},this._actions);d&&this._maybeRunFnOnSettlement()}),n++}}catch(r){this._deps[n].unsub=null;for(let s=0;s<n;s++){let o=this._deps[s];if(o.unsub!=null){let i=o.unsub;o.unsub=null;try{i()}catch{}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=Ct(e);if(this._deps.push(r),this._sinks==null)return n;r.dirty=!0,this._dirtyDepCount++,this._status!=="dirty"&&this._emit(Qe),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([[M,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([[M,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!==Te){if(s===Z){this._depDirtied(r);return}if(s===J){if(this._depInvalidated(r),this._cached===void 0)return;this._emit(_t);return}if(s===Q||s===te){this._emit([n]);return}if(s===j){this._emit(et);return}if(s===$)this._depSettledAsData(r,n[1]);else if(s===F)this._depSettledAsResolved(r);else if(s===H)this._depSettledAsTerminal(r,!0);else if(s===M)this._depSettledAsTerminal(r,n[1]);else{this._emit([n]);return}if(!this._fn){(s===$||s===F)&&this._emit([n]),(s===H||s===M)&&this._maybeAutoTerminalAfterWave();return}}}_depDirtied(e){e.dirty||(e.dirty=!0,e.involvedThisWave=!0,this._dirtyDepCount++,this._status!=="dirty"&&this._emit(Qe))}_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(vt),this._maybeAutoTerminalAfterWave();return}this._fn&&this._execFn(),this._maybeAutoTerminalAfterWave()}}_maybeAutoTerminalAfterWave(){if(this._deps.length===0||this._isTerminal)return;let e=this._deps.find(n=>n.terminal!==void 0&&n.terminal!==!0);if(e!=null){this._autoError&&this._emit([[M,e.terminal]]);return}this._autoComplete&&this._deps.every(n=>n.terminal!==void 0)&&this._emit(wt)}_execFn(){if(!this._fn||this._isTerminal&&!this._resubscribable)return;if(this._isExecutingFn){this._pendingRerun=!0;return}let e=this._cleanup;if(typeof e=="function"){this._cleanup=void 0;try{e()}catch(i){this._emit([[M,this._wrapFnError("cleanup threw",i)]]);return}}else if(e!=null&&typeof e=="object"){let i=e.beforeRun;if(typeof i=="function"){e.beforeRun=void 0;try{i()}catch(a){this._emit([[M,this._wrapFnError("cleanup.beforeRun threw",a)]]);return}}}let n=this._deps.map(i=>i.involvedThisWave?i.dataBatch.length>0?[...i.dataBatch]:[]:void 0),r=this._deps.map(i=>i.prevData);for(let i=0;i<this._deps.length;i++){let a=n[i];a!=null&&a.length>0&&(this._deps[i].prevData=a[a.length-1])}let 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([[M,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([[M,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"?[pe,e[0]]:e;let r=!0,s=!1,o=!1,i=-1;for(let d of e){let u=n(d[0]);u<i&&(r=!1),u===3&&(s=!0),d[0]===Z&&(o=!0),i=u}let a=e;if(!r){let d=e.map((u,c)=>({m:u,i:c,tier:n(u[0])}));d.sort((u,c)=>u.tier-c.tier||u.i-c.i),a=d.map(u=>u.m)}if(s&&!o&&this._status!=="dirty"){let d=0;for(;d<a.length&&n(a[d][0])===0;)d++;return d===0?[pe,...a]:[...a.slice(0,d),pe,...a.slice(d)]}return a}_emit(e){if(e.length===0)return;for(let a=0;a<e.length;a++){let d=e[a];if(d[0]===M&&d[1]===void 0)throw new TypeError('[ERROR, payload] requires a non-undefined payload (spec \xA71.2). Pass an Error object or domain tag instead \u2014 e.g. node.down([[ERROR, new Error("reason")]])')}let n=e;if(this._isTerminal&&!this._resubscribable){let a=e.filter(d=>d[0]===j||d[0]===J);if(a.length===0)return;n=a}n=this._frameBatch(n);let s=null;for(let a=0;a<n.length;a++){let d=n[a],u=d[0];if(u!==Q&&u!==te){s?.push(d);continue}if(d.length<2)throw new Error(`Node "${this.name}": [[${u===Q?"PAUSE":"RESUME"}]] must carry a lockId payload \u2014 bare PAUSE/RESUME is a protocol violation (C0 rule). Use \`[[PAUSE, lockId]]\` / \`[[RESUME, lockId]]\`.`);let c=!0;if(this._pausable!==!1){let p=d[1];if(u===Q)this._pauseLocks==null&&(this._pauseLocks=new Set),this._pauseLocks.add(p),this._paused=!0,this._pausable==="resumeAll"&&this._pauseBuffer==null&&(this._pauseBuffer=[]);else if(this._pauseLocks==null||!this._pauseLocks.has(p))c=!1;else if(this._pauseLocks.delete(p),this._pauseLocks.size===0){if(this._paused=!1,this._pauseBuffer!=null&&this._pauseBuffer.length>0){let h=this._pauseBuffer;this._pauseBuffer=[],this._emit(h)}this._pendingWave&&(this._pendingWave=!1,this._maybeRunFnOnSettlement())}}c?s?.push(d):s==null&&(s=n.slice(0,a))}if(s!=null){if(s.length===0)return;n=s}if(this._hasMeta&&n.some(a=>a[0]===j))for(let a of Object.keys(this.meta))try{this.meta[a]._emit(et)}catch{}let{finalMessages:o,equalsError:i}=this._updateState(n);if(o.length>0&&this._config.inspectorEnabled){let a=this._config.globalInspector;if(a!=null)try{a({kind:"emit",node:this,messages:o})}catch{}}if(o.length>0)if(this._paused&&this._pausable==="resumeAll"&&this._pauseBuffer!=null){let a=this._config.tierOf,d=[];for(let u of o)a(u[0])===3?this._pauseBuffer.push(u):d.push(u);d.length>0&&this._dispatchOrAccumulate(d)}else this._dispatchOrAccumulate(o);i!=null&&this._emit([[M,i]])}_updateState(e){let n=this._config.tierOf,r,s,o=-1,i=0;for(let c of e)n(c[0])===3&&i++;let a=i<=1,d=-1;if(this._versioning!=null&&i>1){for(let c=e.length-1;c>=0;c--)if(e[c][0]===$){d=c;break}}for(let c=0;c<e.length;c++){let p=e[c],h=p[0];if(h===$){if(p.length>=2){let f=!1;if(a&&this._cached!==void 0)try{f=this._equals(this._cached,p[1])}catch(l){s=this._wrapFnError("equals threw",l),o=c;break}if(f){r==null&&(r=e.slice(0,c)),r.push(Xe),this._status="resolved";continue}this._cached=p[1],this._versioning!=null&&(d<0||c===d)&&St(this._versioning,p[1],this._hashFn)}this._status="settled",r?.push(p)}else if(r?.push(p),h===Z)this._status="dirty";else if(h===F)this._status="resolved";else if(h===H)this._status="completed";else if(h===M)this._status="errored";else if(h===J){this._cached=void 0,this._status="dirty";let f=this._cleanup;if(typeof f=="function"){this._cleanup=void 0;try{f()}catch{}}else if(f!=null&&typeof f=="object"){let l=f.invalidate;if(typeof l=="function")try{l()}catch{}}}else h===j&&(this._resetOnTeardown&&(this._cached=void 0),this._deactivate(!0),this._status="sentinel")}let u=o>=0?r??e.slice(0,o):r??e;return s!=null?{finalMessages:u,equalsError:s}:{finalMessages:u}}_deliverToSinks=e=>{if(this._sinks==null)return;if(typeof this._sinks=="function"){this._sinks(e);return}let n=[...this._sinks];for(let r of n)r(e)};_dispatchOrAccumulate(e){if(yt()){this._batchPendingMessages===null&&(this._batchPendingMessages=[],xe(()=>this._flushBatchPending()));for(let n of e)this._batchPendingMessages.push(n);return}Re(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);Re(this._deliverToSinks,n,this._config.tierOf)}},Mt=t=>Array.isArray(t),ct=t=>typeof t=="object"&&t!=null&&!Array.isArray(t)});function ue(t,e){return X([],{...e,initial:t})}function Gt(t,e){return X((r,s,o)=>t(s,o)??void 0,{describeKind:"producer",...e})}function de(t,e,n){return X(t,(s,o,i)=>{let a=s.map((d,u)=>d!=null&&d.length>0?d.at(-1):i.prevData[u]);o.emit(e(a,i))},{describeKind:"derived",...n})}var lt=K(()=>{"use strict";be()});function pt(t){return t.subscribe(()=>{})}var It=K(()=>{"use strict"});var Pe,Lt=K(()=>{"use strict";Pe=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 Lr={};hn(Lr,{approval:()=>Rr,branch:()=>Sr,gate:()=>Dr,join:()=>Ar,loop:()=>Cr,onFailure:()=>Ir,pipeline:()=>cn,sensor:()=>Gr,subPipeline:()=>Mr,task:()=>kr});module.exports=mn(Lr);De();Oe();be();lt();rt();De();st();Ge();Oe();Ge();be();function Le(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 Dn(t){let e={};for(let[n,r]of Object.entries(t.meta))try{e[n]=r.cache}catch{}return e}function ft(t,e){let n=e==null,r=!n&&e!=null?[...e].filter(u=>u.startsWith("meta.")).map(u=>u.slice(5)):null,s=n||e.has("meta")||r!=null&&r.length>0,o="state",i=[];t instanceof L&&(o=Rn(t),i=t._deps.map(u=>u.node.name??""));let a={type:o,deps:i};(n||e.has("status"))&&(a.status=t.status);let d=t instanceof L?t._guard:void 0;if(s){let u={...Dn(t)};if(d!=null&&u.access===void 0&&(u.access=ot(d)),r!=null&&r.length>0&&!e.has("meta")){let c={};for(let p of r)p in u&&(c[p]=u[p]);a.meta=c}else a.meta=u}if(t.name!=null&&(a.name=t.name),n||e.has("value")){t.status==="sentinel"&&(a.sentinel=!0);try{a.value=t.cache}catch{}}if((n||e.has("v"))&&t.v!=null){let u={id:t.v.id,version:t.v.version};"cid"in t.v&&(u.cid=t.v.cid,u.prev=t.v.prev),a.v=u}return(n||e.has("guard"))&&d!=null&&(a.guard=ot(d)),(n||e.has("lastMutation"))&&t.lastMutation!=null&&(a.lastMutation=t.lastMutation),a}be();lt();It();Lt();var Ne=class{constructor(e){this.capacity=e;if(!Number.isInteger(e)||e<=0)throw new Error(`RingBuffer capacity must be a positive integer (got ${e})`);this.buf=new Array(e)}buf;head=0;_size=0;get size(){return this._size}get maxSize(){return this.capacity}push(e){let n=(this.head+this._size)%this.capacity;this.buf[n]=e,this._size<this.capacity?this._size++:this.head=(this.head+1)%this.capacity}shift(){if(this._size===0)return;let e=this.buf[this.head];return this.buf[this.head]=void 0,this.head=(this.head+1)%this.capacity,this._size--,e}at(e){if(this._size===0)return;let n=e<0?this._size+e:e;if(!(n<0||n>=this._size))return this.buf[(this.head+n)%this.capacity]}toArray(){let e=new Array(this._size);for(let n=0;n<this._size;n++)e[n]=this.buf[(this.head+n)%this.capacity];return e}clear(){for(let e=0;e<this._size;e++)this.buf[(this.head+e)%this.capacity]=void 0;this.head=0,this._size=0}};nt();function ht(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 $e(t){let e=0;for(let n of t)e+=ht(n.codePointAt(0));return e}function Pt(t,e){if(e<=0)return"";let n=0,r="";for(let s of t){let o=ht(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-=ht(i.codePointAt(0))}return`${r}\u2026`}r+=s,n+=o}return r}var An={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"},Cn={horizontal:"-",vertical:"|",cornerTL:"+",cornerTR:"+",cornerBL:"+",cornerBR:"+",tDown:"+",tUp:"+",tRight:"+",tLeft:"+",cross:"+",arrowRight:">",arrowDown:"v",arrowLeft:"<",arrowUp:"^",boxTL:"+",boxTR:"+",boxBL:"+",boxBR:"+",boxH:"-",boxV:"|"};function Bt(t,e){let n=e.charset==="ascii"?Cn:An,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:d}=r;if(a<2||d<2){d>0&&$t(t,e,o,i,a,s);return}ne(t,e,o,i,n.boxTL);for(let c=o+1;c<o+a-1;c+=1)ne(t,e,c,i,n.boxH);ne(t,e,o+a-1,i,n.boxTR);for(let c=i+1;c<i+d-1;c+=1){ne(t,e,o,c,n.boxV);for(let p=o+1;p<o+a-1;p+=1)jt(t,e,p,c," ","empty");ne(t,e,o+a-1,c,n.boxV)}ne(t,e,o,i+d-1,n.boxBL);for(let c=o+1;c<o+a-1;c+=1)ne(t,e,c,i+d-1,n.boxH);ne(t,e,o+a-1,i+d-1,n.boxBR);let u=i+Math.floor(d/2);$t(t,e,o+1,u,a-2,s)}function ne(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 $t(t,e,n,r,s,o){if(r<0||r>=t.length)return;let i=n,a=s;for(let d of o){let u=$e(d);if(u!==0){if(a<u)break;i>=0&&i<t[r].length&&(t[r][i]=d,e[r][i]="label",u===2&&i+1<t[r].length&&(t[r][i+1]="",e[r][i+1]="label")),i+=u,a-=u}}for(;a>0;)i>=0&&i<t[r].length&&(t[r][i]=" ",e[r][i]="empty"),i+=1,a-=1}function Gn(t,e,n,r){let s=r.points;if(s.length<2)return;for(let d=0;d+1<s.length;d+=1)In(t,e,n,s[d],s[d+1]);for(let d=1;d+1<s.length;d+=1){let u=s[d-1],c=s[d],p=s[d+1],h=Ln(u,c,p,n);h&&Ht(t,e,c.x,c.y,h,"edgeCorner")}let o=s[s.length-1],i=s[s.length-2],a=Pn(i,o,n);a&&Ht(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 d=i;d<=a;d+=1)Ft(t,e,d,o,n,"h")}else if(r.x===s.x){let o=r.x,i=Math.min(r.y,s.y),a=Math.max(r.y,s.y);for(let d=i;d<=a;d+=1)Ft(t,e,o,d,n,"v")}}}function Ft(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 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];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 d=t.x<e.x,u=n.y>e.y;return d&&u?r.cornerTR:d&&!u?r.cornerBR:!d&&u?r.cornerTL:r.cornerBL}let i=t.y<e.y,a=n.x>e.x;return i&&a?r.cornerBL:i&&!a?r.cornerBR:!i&&a?r.cornerTL:r.cornerTR}function 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),jn(e),Vn(e,t);let n=Wn(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 d=(e.get(a.id)??0)-1;e.set(a.id,d),d<=0&&n.push(a)}}}for(let o of t.nodes.values())o.layer<0&&(o.layer=0)}function 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),d=a.layer-i.layer;if(d<=0){i.out=i.out.filter(p=>p!==o),a.in=a.in.filter(p=>p!==o);continue}if(d===1){o.hopIndex=0,o.chainLen=1,r.push(o);continue}i.out=i.out.filter(p=>p!==o),a.in=a.in.filter(p=>p!==o);let u=i;for(let p=1;p<d;p+=1){let h=`__virt_${s++}__`,f={id:h,isVirtual:!0,layer:i.layer+p,order:0,x:0,y:0,w:0,h:1,in:[],out:[]};t.nodes.set(h,f),n[f.layer].push(f);let l={chainId:o.chainId,chainFrom:o.chainFrom,chainTo:o.chainTo,fromId:u.id,toId:h,hopIndex:p-1,chainLen:d};u.out.push(l),f.in.push(l),r.push(l),u=f}let c={chainId:o.chainId,chainFrom:o.chainFrom,chainTo:o.chainTo,fromId:u.id,toId:a.id,hopIndex:d-1,chainLen:d};u.out.push(c),a.in.push(c),r.push(c)}for(let 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)Vt(t,t.layers[r],"in"),Fe(t.layers[r]);for(let r=t.layers.length-2;r>=0;r-=1)Vt(t,t.layers[r],"out"),Fe(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]],Fe(o),zt(t,o[i],o[i+1],"in")<a?r=!0:([o[i],o[i+1]]=[o[i+1],o[i]],Fe(o))}}if(!r)break}}function Vt(t,e,n){let r=new Map;for(let s of e){let o=n==="in"?s.in:s.out;if(o.length===0){r.set(s.id,s.order);continue}let i=0,a=0;for(let d of o){let u=t.nodes.get(n==="in"?d.fromId:d.toId);u&&(i+=u.order,a+=1)}r.set(s.id,a===0?s.order:i/a)}e.sort((s,o)=>{let i=r.get(s.id),a=r.get(o.id);return i!==a?i-a:s.order-o.order})}function Fe(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 d of o){let u=t.nodes.get(r==="in"?a.fromId:a.toId)?.order??0,c=t.nodes.get(r==="in"?d.fromId:d.toId)?.order??0;(e.order<n.order&&u>c||e.order>n.order&&u<c)&&(i+=1)}return i}function Vn(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}Wt(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}Wt(t,e,"x")}function Wt(t,e,n){let r=o=>n==="y"?o.h:o.w,s=e.nodeGap;for(let o=0;o<2;o+=1){let i=o===0?t.layers.slice(1):t.layers.slice(0,-1).reverse();for(let a of i){let d=new Map;for(let c of a){let p=o===0?c.in:c.out;if(p.length===0)continue;let h=[];for(let l of p){let g=t.nodes.get(o===0?l.fromId:l.toId);if(!g)continue;let b=n==="y"?g.y:g.x;h.push(b+Math.floor(r(g)/2))}if(h.length===0)continue;h.sort((l,g)=>l-g);let f=h[Math.floor(h.length/2)];d.set(c.id,f-Math.floor(r(c)/2))}let u=0;for(let c of a){let p=d.get(c.id),h=n==="y"?c.y:c.x,l=Math.max(p??h,u);n==="y"?c.y=l:c.x=l,u=l+r(c)+s}}}}function Wn(t,e){let n=new Map;for(let u of t.hops){let c=n.get(u.chainId);c?c.push(u):n.set(u.chainId,[u])}for(let u of n.values())u.sort((c,p)=>c.hopIndex-p.hopIndex);let r=e.direction==="LR",s=u=>r?u.x:u.y,o=u=>r?u.w:u.h,i=u=>r?u.y+Math.floor(u.h/2):u.x+Math.floor(u.w/2),a=new Map;for(let u=0;u+1<t.layers.length;u+=1){let c=t.layers[u],p=t.layers[u+1],h=0;for(let O of c)h=Math.max(h,s(O)+o(O));let f=Number.POSITIVE_INFINITY;for(let O of p)f=Math.min(f,s(O));let l=Number.isFinite(f)?f-1:h,g=Math.max(1,l-h+1),b=[];for(let O of c)for(let N of O.out)b.push(N);b.sort((O,N)=>{let D=i(t.nodes.get(O.fromId)),k=i(t.nodes.get(N.fromId));if(D!==k)return D-k;let R=i(t.nodes.get(O.toId)),S=i(t.nodes.get(N.toId));return R-S});let w=[],x=new Map;for(let O of b){let N=i(t.nodes.get(O.fromId)),D=i(t.nodes.get(O.toId)),k=Math.min(N,D),R=Math.max(N,D),S=-1;for(let I=0;I<w.length;I+=1){let V=w[I],Y=!0;for(let oe of V)if(oe.lo<=R&&k<=oe.hi){Y=!1;break}if(Y){V.push({lo:k,hi:R}),S=I;break}}S<0&&(w.push([{lo:k,hi:R}]),S=w.length-1),x.set(O,S)}let m=w.length,v=g>=Math.max(3,m+2),_=v?h+1:h,y=v?l-1:l,T=Math.max(1,y-_+1);for(let O of b){let N=x.get(O),D;if(m<=1)D=_+Math.floor(T/2);else{let k=(T-1)/(m-1);D=_+Math.floor(N*k)}a.set(O,Math.max(h,Math.min(l,D)))}}let d=[];for(let[,u]of n){let c=[];for(let h=0;h<u.length;h+=1){let f=u[h],l=t.nodes.get(f.fromId),g=t.nodes.get(f.toId),b=a.get(f),w=l.isVirtual?s(l):s(l)+o(l),x=g.isVirtual?s(g):s(g)-1,m=i(l),v=i(g);h===0&&He(c,r,w,m),m!==v&&(He(c,r,b,m),He(c,r,b,v)),He(c,r,x,v)}let p=u[0];d.push({from:p.chainFrom,to:p.chainTo,points:Kn(c)})}return d}function He(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 Kt(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(f=>i.has(f.from)&&i.has(f.to)),d=new Map,u=new Map;for(let f of o){let l=Pt(f,r);d.set(f,l),u.set(f,$e(l)+4)}let c=Ut({nodes:o,edges:a,widthCells:f=>u.get(f)??3,heightCells:()=>Zn,layerGap:Jn,nodeGap:Xn,direction:n}),p=Bt(c,{charset:s,labelOf:f=>d.get(f)??f}),h=e.logger;return h&&h(p),p}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 qt(t,e,n,r={}){let s=e in t.nodes,o=n in t.nodes;if(!s)return Be(e,n,"no-such-from");if(!o)return Be(e,n,"no-such-to");let i=r.maxDepth;if(i!=null&&(!Number.isInteger(i)||i<0))throw new Error("explainPath: maxDepth must be an integer >= 0");if(e===n){if(r.findCycle===!0){let u=er(t,e,r);if(u!=null)return u}let d=je(e,t.nodes[e],0,r);return Ve(e,n,[d])}if(i===0)return Be(e,n,"no-path");let a=Yt(t,e,n,i);return a.found?Ve(e,n,Jt(t,a.pathOrder,r)):Be(e,n,a.truncated?"max-depth-exceeded":"no-path")}function Yt(t,e,n,r){let s=new Map,o=[{path:n,depth:0}],i=new Set([n]),a=0,d=!1;for(;a<o.length;){let p=o[a++];if(p.path===e)break;if(r!=null&&p.depth>=r){let g=t.nodes[p.path];g?.deps&&g.deps.length>0&&(d=!0);continue}let h=t.nodes[p.path];if(h==null)continue;let f=h.deps??[],l=new Map;for(let g=0;g<f.length;g++){let b=f[g];if(!b)continue;let w=l.get(b);w==null&&(w=[],l.set(b,w)),w.push(g)}for(let[g,b]of l)i.has(g)||(i.add(g),s.set(g,{from:p.path,depIndices:b}),o.push({path:g,depth:p.depth+1}))}if(!s.has(e))return{found:!1,pathOrder:[],truncated:d};let u=[{path:e}],c=e;for(;c!==n;){let p=s.get(c);if(p==null)return{found:!1,pathOrder:[],truncated:!1};u[u.length-1].depIndices=p.depIndices,u.push({path:p.from}),c=p.from}return{found:!0,pathOrder:u,truncated:!1}}function 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=je(e,r,0,n);a.dep_index=o[0];let d=je(e,r,1,n);return Ve(e,e,[a,d])}let i=null;for(let a=0;a<s.length;a++){let d=s[a];if(!d||d===e)continue;let u=Yt(t,d,e,n.maxDepth);u.found&&(i==null||u.pathOrder.length<i.pathOrder.length)&&(i=u,i={found:!0,pathOrder:[{path:e,depIndices:[a]},...u.pathOrder],truncated:!1})}return i==null?null:Ve(e,e,Jt(t,i.pathOrder,n))}function Jt(t,e,n){return e.map((r,s)=>{let o=t.nodes[r.path],i=je(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 je(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 Ve(t,e,n){return Xt(t,e,!0,"ok",n)}function Be(t,e,n){return Xt(t,e,!1,n,[])}function Xt(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 d=` ${i.hop===0?"\xB7":"\u2193"} ${i.path} (${i.type}${i.status?`/${i.status}`:""})`;if(o.push(d),"value"in i&&o.push(` value: ${nr(i.value)}`),i.annotation!=null&&o.push(` annotation: ${i.annotation}`),i.lastMutation!=null){let u=i.lastMutation.actor;o.push(` actor: ${u.type}${u.id?`:${u.id}`:""}`)}}return o.join(`
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)}}be();var P={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 Zt(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 P.number;case"boolean":return P.boolean;case"string":return P.string+t.length*2;case"bigint":return P.bigint+or(t);case"symbol":return P.symbol;case"function":return e.has(t)?0:(e.add(t),P.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 u=i.call(o);if(typeof u=="number"&&Number.isFinite(u))return u}catch{}if(o instanceof Date)return P.date;if(o instanceof RegExp)return P.regexp+o.source.length*2;if(o instanceof Error){let u=o.message?o.message.length*2:0,c=o.stack?o.stack.length*2:0;return P.error+u+c}if(typeof URL<"u"&&o instanceof URL)return P.url+o.href.length*2;if(typeof Promise<"u"&&o instanceof Promise)return P.promise;if(o instanceof WeakMap)return P.weakmap;if(o instanceof WeakSet)return P.weakset;if(o instanceof Map){let u=P.map;for(let[c,p]of o)u+=P.mapEntry,r.push(c),r.push(p);return u}if(o instanceof Set){let u=P.set;for(let c of o)u+=P.setEntry,r.push(c);return u}if(Array.isArray(o)){let u=P.array+o.length*8;for(let c of o)r.push(c);return u}if(o instanceof ArrayBuffer)return n.has(o)?0:(n.add(o),o.byteLength);if(ArrayBuffer.isView(o)){let u=o;return n.has(u.buffer)?48:(n.add(u.buffer),u.buffer.byteLength+48)}let a=P.object,d=Object.keys(o);for(let u of d){a+=P.string+u.length*2;try{r.push(o[u])}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 Qt(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[h,f]of s)i.set(h,f);let a=[];for(let[h,f]of Object.entries(r.nodes)){let l=i.get(h),g=l instanceof L?l:null,b=g?Zt(g.cache):0,w=g?g._sinkCount:0,x=f.deps?.length??0,m=f.type==="effect"&&w===0,v=w===0?f.type==="effect"?"orphan-effect":f.type==="derived"?"idle-derived":f.type==="producer"?"idle-producer":null:null;a.push({path:h,type:f.type,status:f.status??"unknown",valueSizeBytes:b,subscriberCount:w,depCount:x,isOrphanEffect:m,orphanKind:v})}let d=a.reduce((h,f)=>h+f.valueSizeBytes,0),u=(h,f)=>[...a].sort(f??((l,g)=>g[h]-l[h])).slice(0,n),c=a.filter(h=>h.orphanKind!=null),p=a.filter(h=>h.isOrphanEffect);return{nodeCount:a.length,edgeCount:r.edges.length,subgraphCount:r.subgraphs.length,nodes:a,totalValueSizeBytes:d,hotspots:{byValueSize:u("valueSizeBytes"),bySubscriberCount:u("subscriberCount"),byDepCount:u("depCount")},orphans:c,orphanEffects:p}}var G="::",z="__meta__",ye=1;function en(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 tn(t){if(t.version!==ye)throw new Error(`unsupported snapshot version ${String(t.version)} (expected ${ye})`);for(let e of["name","nodes","edges","subgraphs"])if(!(e in t))throw new Error(`snapshot missing required key "${e}"`);if(typeof t.name!="string")throw new TypeError("snapshot 'name' must be a string");if(typeof t.nodes!="object"||t.nodes===null||Array.isArray(t.nodes))throw new TypeError("snapshot 'nodes' must be an object");if(!Array.isArray(t.edges))throw new TypeError("snapshot 'edges' must be an array");if(!Array.isArray(t.subgraphs))throw new TypeError("snapshot 'subgraphs' must be an array")}function 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,d=o.constructor;if(a!==d)return!1;if(s instanceof Date)return s.getTime()===o.getTime();if(s instanceof RegExp)return s.source===o.source&&s.flags===o.flags;if(Array.isArray(s)){let h=o;if(s.length!==h.length)return!1;for(let f=0;f<s.length;f++)if(!r(s[f],h[f]))return!1;return!0}if(s instanceof Map){let h=o;if(s.size!==h.size)return!1;for(let[f,l]of s)if(!h.has(f)||!r(l,h.get(f)))return!1;return!0}if(s instanceof Set){let h=o;if(s.size!==h.size)return!1;for(let f of s){let l=!1;for(let g of h)if(r(f,g)){l=!0;break}if(!l)return!1}return!0}if(ArrayBuffer.isView(s)){let h=s,f=o;if(h.length!==f.length)return!1;for(let l=0;l<h.length;l++)if(h[l]!==f[l])return!1;return!0}let u=Object.keys(s),c=Object.keys(o);if(u.length!==c.length)return!1;let p=new Set(c);for(let h of u)if(!p.has(h)||!r(s[h],o[h]))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 dr(t){return t.replaceAll("\\","\\\\").replaceAll('"','\\"')}function cr(t){return t==="TD"?"down":t==="BT"?"up":t==="RL"?"left":"right"}function sn(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 on(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 lr(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}): ${Ue(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 an(t,e){let n=on(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 sn(t)){let d=s.get(i),u=s.get(a);!d||!u||o.push(` ${d} --> ${u}`)}return o.join(`
6
+ `)}function pr(t,e){let n=an(t,e);return hr(n)}function hr(t,e){let n=e?.theme??"default",r=e?.autoSync??!0,o=JSON.stringify({code:t,mermaid:{theme:n},autoSync:r}),i=new TextEncoder().encode(o),a="";for(let u=0;u<i.length;u++)a+=String.fromCharCode(i[u]);return`https://mermaid.live/edit#base64:${globalThis.btoa(a).replace(/\+/g,"-").replace(/\//g,"_").replace(/=+$/,"")}`}function gr(t,e){let n=on(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: ${cr(n)}`];for(let i of r){let a=s.get(i);o.push(`${a}: "${dr(i)}"`)}for(let[i,a]of sn(t)){let d=s.get(i),u=s.get(a);!d||!u||o.push(`${d} -> ${u}`)}return o.join(`
7
+ `)}function mr(t){return t.replace(/[.*+?^${}()|[\]\\]/g,"\\$&")}function ze(t){let e="^";for(let n=0;n<t.length;n+=1){let r=t[n];if(r==="*"){e+=".*";continue}if(r==="?"){e+=".";continue}if(r==="["){let s=t.indexOf("]",n+1);if(s<=n+1){e+="\\[";continue}let o=t.slice(n+1,s);o.startsWith("!")&&(o=`^${o.slice(1)}`),o=o.replace(/\\/g,"\\\\"),e+=`[${o}]`,n=s;continue}e+=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 Ue(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 nn(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(G))throw new Error(`Graph "${e}": ${n} "${t}" must not contain '${G}' (path separator)`);if(t===z)throw new Error(`Graph "${e}": ${n} name "${z}" is reserved for meta companion paths`);_r(t,e,n)}function wr(t,e){if(t==="")throw new Error(`Graph "${e}": resolve path must be non-empty`);let n=t.split(G);for(let r of n)if(r==="")throw new Error(`Graph "${e}": resolve path has empty segment`);return n}function xr(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 un(t){for(let e of t._mounts.values())un(e);for(let e of t._nodes.values())try{e.down([[j]],{internal:!0})}catch{}}var ce=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(G))throw new Error(`Graph name must not contain '${G}' (got "${e}")`);if(e===z)throw new Error(`Graph name "${z}" is reserved for meta companion paths`);this.name=e,this.opts=Object.freeze({...n??{}}),this.config=n?.config??me,this._traceRing=new Ne(n?.traceCapacity??1e3),n?.versioning!=null&&this.setVersioning(n.versioning)}ancestors(e=!0){let n=[],r=e?this:this._parent;for(;r!=null;)n.push(r),r=r._parent;return n}get topology(){return this._topology==null&&(this._topology=Gt(e=>{let n=r=>{e.emit(r)};return this._topologyEmitters.add(n),()=>{this._topologyEmitters.delete(n)}},{name:`${this.name}_topology`})),this._topology}_emitTopology(e){if(!(this._topology==null||this._topologyEmitters.size===0))for(let n of this._topologyEmitters)n(e)}add(e,n){let r=e.name,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 L&&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,d]of i)a.includes(`${G}${z}${G}`)||o.nodes.push(a);return o.nodes.sort(),o.mounts.push(e),o.mounts.push(...n._collectSubgraphs(`${e}${G}`)),this._mounts.delete(e),n._parent=void 0,un(n),this._emitTopology({kind:"removed",name:e,nodeKind:"mount",audit:o}),o}let r=this._nodes.get(e);if(!r)throw new Error(`Graph "${this.name}": unknown node or mount "${e}"`);this._nodes.delete(e),this._nodeToName.delete(r),r.down([[j]],{internal:!0});let s={kind:"node",nodes:[e],mounts:[]};return this._emitTopology({kind:"removed",name:e,nodeKind:"node",audit:s}),s}removeAll(e){let n=typeof e=="function"?e:(()=>{let o=ze(e);return i=>o.test(i)})(),r={kind:"mount",nodes:[],mounts:[]},s=[...this._nodes.keys(),...this._mounts.keys()].filter(o=>n(o));for(let o of s){let i=this.remove(o);r.nodes.push(...i.nodes),r.mounts.push(...i.mounts)}return r.nodes.sort(),r.mounts.sort(),r}[Symbol.iterator](){let e=[...this._nodes.keys()].sort(),n=this._nodes,r=0;return{[Symbol.iterator](){return this},next(){if(r>=e.length)return{value:void 0,done:!0};let s=e[r++];return{value:[s,n.get(s)],done:!1}}}}node(e){if(e==="")throw new Error(`Graph "${this.name}": node name must be non-empty`);if(e.includes(G))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([[$,n]],{actor:r?.actor,internal:s,delivery:"write"})}setAll(e,n){let r=Symbol.iterator in e?e:Object.entries(e);Se(()=>{for(let[s,o]of r)this.set(s,o,n)})}invalidate(e,n){let r=n?.internal===!0;this.node(e).down([[J]],{actor:n?.actor,internal:r,delivery:"write"})}error(e,n,r){let s=r?.internal===!0;this.node(e).down([[M,n]],{actor:r?.actor,internal:s,delivery:"write"})}complete(e,n){let r=n?.internal===!0;this.node(e).down([[H]],{actor:n?.actor,internal:r,delivery:"write"})}edges(e){let n=e?.recursive===!0,r=new Map;if(!n){for(let[d,u]of this._nodes)r.set(u,d);let a=[];for(let[d,u]of this._nodes)if(u instanceof L)for(let c of u._deps){let p=r.get(c.node);p!=null&&a.push([p,d])}return a.sort((d,u)=>d[0]<u[0]?-1:d[0]>u[0]?1:d[1]<u[1]?-1:d[1]>u[1]?1:0),a}let s=[];this._collectObserveTargets("",s);let o=new Map;for(let[a,d]of s)o.set(d,a);let i=[];for(let[a,d]of s)if(d instanceof L)for(let u of d._deps){let c=o.get(u.node);c!=null&&i.push([c,a])}return i.sort((a,d)=>a[0]<d[0]?-1:a[0]>d[0]?1:a[1]<d[1]?-1:a[1]>d[1]?1:0),i}mount(e,n){if(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(n===this)throw new Error(`Graph "${this.name}": cannot mount a graph into itself`);if(n._parent!=null)throw new Error(`Graph "${this.name}": this child graph is already mounted on "${n._parent.name}"`);for(let r=this;r!=null;r=r._parent)if(r===n)throw new Error(`Graph "${this.name}": mount("${e}", \u2026) would create a mount cycle`);return this._mounts.set(e,n),n._parent=this,this._emitTopology({kind:"added",name:e,nodeKind:"mount"}),n}resolve(e){let n=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]===z)return this._resolveMetaChainFromNode(o,s,n.join(G));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(G)}" is invalid`):new Error(`Graph "${this.name}": unknown mount or node "${r}"`);return i.resolve(s.join(G))}_resolveMetaChainFromNode(e,n,r){let s=e,o=0,i=[...n];for(;o<i.length;){if(i[o]!==z)throw new Error(`Graph "${this.name}": expected ${z} segment in meta path "${r}"`);if(o+1>=i.length)throw new Error(`Graph "${this.name}": meta path requires a key after ${z} in "${r}"`);let a=i[o+1],d=s.meta[a];if(!d)throw new Error(`Graph "${this.name}": unknown meta "${a}" in path "${r}"`);s=d,o+=2}return s}signal(e,n){if(n?.internal!==!0){for(let s of e)if(this.config.messageTier(s[0])===3)throw new Error(`Graph "${this.name}": Graph.signal() rejects tier-3 messages (DATA / RESOLVED). Broadcast is for control-plane tiers (START / DIRTY / INVALIDATE / PAUSE / RESUME / COMPLETE / ERROR / TEARDOWN). For per-node value writes, use Graph.set or graph.node(name).down(...).`)}let r=[];if(this._signalDeliver(e,n??{},new Set,r),r.length>0)throw r[0]}_signalDeliver(e,n,r,s){for(let d of this._mounts.values())d._signalDeliver(e,n,r,s);let i=n.internal===!0?{internal:!0}:{actor:n.actor,delivery:"signal"},a=xr(e,this.config);for(let d of[...this._nodes.keys()].sort()){let u=this._nodes.get(d);if(!r.has(u)){r.add(u);try{u.down(e,i)}catch(c){if(c instanceof q)throw c;s.push(c)}a.length!==0&&this._signalMetaSubtree(u,a,r,i,s)}}}_signalMetaSubtree(e,n,r,s,o){for(let i of Object.keys(e.meta).sort()){let a=e.meta[i];if(!r.has(a)){r.add(a);try{a.down(n,s)}catch(d){if(d instanceof q)throw d;o.push(d)}this._signalMetaSubtree(a,n,r,s,o)}}}describe(e){if(e?.reactive===!0)return this._describeReactive(e);let n=e?.actor,r=e?.filter,s=Le(e?.detail,e?.fields),o=e?.format==="spec",i=o?Le("minimal"):s,a=[];this._collectObserveTargets("",a);let d=new Map;for(let[y,T]of a)d.set(T,y);let u=[];{let y=a.map(([,N])=>N),T=new Set(d.values()),O=0;for(;y.length>0;){let N=y.shift();if(N instanceof L)for(let D of N._deps){let k=D.node;if(d.has(k))continue;let R=k.name??"",S=R;if(!S||T.has(S))if(R){let I=2;for(;T.has(`${R}#${I}`);)I++;S=`${R}#${I}`}else for(S=`__internal__/${O++}`;T.has(S);)S=`__internal__/${O++}`;d.set(k,S),T.add(S),u.push([S,k]),y.push(k)}}}let c=[...a,...u],p={};for(let[y,T]of c){if(n!=null&&!T.allowsObserve(n))continue;let O=ft(T,i),N=T instanceof L?T._deps.map(S=>d.get(S.node)??S.node.name??""):[],{name:D,...k}=O,R={...k,deps:N};if(!o){let S=this._annotations.get(y);S!=null&&(R.annotation=S)}if(r!=null)if(typeof r=="function"){let S=r;if(!(S.length>=2?S(y,R):S(R)))continue}else{let S=!0;for(let[I,V]of Object.entries(r)){let Y=I==="deps_includes"?"depsIncludes":I==="meta_has"?"metaHas":I;if(Y==="depsIncludes"){if(!R.deps.includes(String(V))){S=!1;break}continue}if(Y==="metaHas"){if(!Object.hasOwn(R.meta??{},String(V))){S=!1;break}continue}if(R[Y]!==V){S=!1;break}}if(!S)continue}p[y]=R}let h=new Set(Object.keys(p)),f=[];for(let[y,T]of c)if(T instanceof L)for(let O of T._deps){let N=d.get(O.node);N!=null&&f.push([N,y])}f.sort((y,T)=>y[0]<T[0]?-1:y[0]>T[0]?1:y[1]<T[1]?-1:y[1]>T[1]?1:0);let l=f.map(([y,T])=>({from:y,to:T}));(n!=null||r!=null)&&(l=l.filter(y=>h.has(y.from)&&h.has(y.to)));let g=this._collectSubgraphs(""),b=n!=null||r!=null?g.filter(y=>{let T=`${y}${G}`;return[...h].some(O=>O===y||O.startsWith(T))}):g,w=this,x=e,m={name:this.name,nodes:p,edges:l,subgraphs:b,expand(y){let T={...x,format:void 0};return Array.isArray(y)?(T.fields=y,T.detail=void 0):(T.detail=y,T.fields=void 0),w.describe(T)}},v=e??{},_=v.format;return _==="json"?lr(m,v):_==="pretty"?fr(m,v):_==="mermaid"?an(m,v):_==="mermaid-url"?pr(m,v):_==="d2"?gr(m,v):_==="ascii"?Kt(m,v):m}_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}${G}`))}return n}resourceProfile(e){return Qt(this,e)}reachable(e,n,r={}){return r.withDetail===!0?rn(this.describe(),e,n,{...r,withDetail:!0}):rn(this.describe(),e,n,r)}explain(e,n,r){return r?.reactive===!0?this._explainReactive(e,n,r):this._explainStatic(e,n,r)}_explainStatic(e,n,r){let s=this.describe({detail:"full"}),o=new Map(this._annotations),i=new Map;for(let[a,d]of Object.entries(s.nodes))d.lastMutation!=null&&i.set(a,d.lastMutation);return qt(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=ue(s,{name:`${r}_version`}),i=this.observe({timeline:!0,structured:!0}),a=!1,d=!1,u=()=>{a||d||(a=!0,xe(()=>{a=!1,!d&&(s+=1,o.emit(s))}))},c=i.onEvent(b=>{let w=b.type;w!=="data"&&w!=="error"&&w!=="complete"&&w!=="teardown"||u()}),p=[],h=new WeakSet,f=b=>{if(h.has(b)||d)return;h.add(b);let w=b.topology.subscribe(x=>{for(let m of x){if(m[0]!==$)continue;let v=m[1];if(u(),v.kind==="added"&&v.nodeKind==="mount"){let _=b._mounts.get(v.name);_!=null&&f(_)}}});p.push(w);for(let x of b._mounts.keys()){let m=b._mounts.get(x);m!=null&&f(m)}};f(this);let l;try{l=de([o],()=>this.describe(n),{name:r,describeKind:"derived",meta:{domain:"audit",kind:"describe"},equals:(b,w)=>b===w})}catch(b){c();for(let w of p)w();throw i.dispose(),b}let g=pt(l);return{node:l,dispose(){d=!0,c();for(let b of p)b();p.length=0,i.dispose(),g()}}}_explainReactive(e,n,r){let s=0,o=ue(s,{name:"explain_version"}),i=this.observe({timeline:!0,structured:!0}),a=!1,d=!1,u=i.onEvent(f=>{let l=f.type;l!=="data"&&l!=="error"&&l!=="complete"&&l!=="teardown"||a||d||(a=!0,xe(()=>{a=!1,!d&&(s+=1,o.emit(s))}))}),c={...r?.maxDepth!=null?{maxDepth:r.maxDepth}:{},...r?.findCycle===!0?{findCycle:!0}:{}},p;try{p=de([o],()=>this._explainStatic(e,n,c),{name:r?.name??"explain",describeKind:"derived",meta:{domain:"audit",kind:"explain_path",from:e,to:n},equals:(f,l)=>f.found===l.found&&f.reason===l.reason&&f.steps.length===l.steps.length&&Or(f.steps,l.steps)})}catch(f){throw u(),i.dispose(),f}let h=pt(p);return{node:p,dispose(){d=!0,u(),i.dispose(),h()}}}_pathsMatching(e){let n=ze(e),r=[];return this._collectObserveTargets("",r),r.map(([s])=>s).filter(s=>n.test(s))}_collectObserveTargets(e,n){for(let r of[...this._mounts.keys()].sort()){let s=e===""?r:`${e}${G}${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}${G}${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}${G}${z}${G}${s}`;r.push([i,o]),this._appendMetaObserveTargets(i,o,r)}}observe(e,n){let r=typeof e=="string",o=nn(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 c=e,p=this.resolve(c);if(a!=null&&!p.allowsObserve(a))throw new q({actor:a,action:"observe",nodeName:c});return i?this._buildStructuredObserver([[c,p]],o,"one"):{subscribe(h){return p.subscribe(h)},up(h){try{p.up?.(h)}catch(f){if(f instanceof q)return;throw f}}}}let d=[];this._collectObserveTargets("",d),d.sort((c,p)=>c[0]<p[0]?-1:c[0]>p[0]?1:0);let u=a==null?d:d.filter(([,c])=>c.allowsObserve(a));return i?this._buildStructuredObserver(u,o,"all"):{subscribe:c=>{let p=u.map(([h,f])=>f.subscribe(l=>{c(h,l)}));return()=>{for(let h of p)h()}},up:(c,p)=>{try{this.resolve(c).up?.(p)}catch(h){if(h instanceof q)return;throw h}}}}_buildStructuredObserver(e,n,r){let s=r==="one"?e[0]?.[0]:void 0,o=i=>{if(r==="one"&&s!=null){let c=this.resolve(s);return this._buildStructuredObserver([[s,c]],i,"one")}let a=[];this._collectObserveTargets("",a),a.sort((c,p)=>c[0]<p[0]?-1:c[0]>p[0]?1:0);let d=i.actor,u=d==null?a:a.filter(([,c])=>c.allowsObserve(d));return this._buildStructuredObserver(u,i,"all")};return this._createObserveResult(e,n,o)}_createObserveResult(e,n,r){let s=n.timeline===!0,o=n.causal===!0,i=n.derived===!0,a=n.detail==="minimal",d=this.config.inspectorEnabled,u=(o||i)&&d,c=n.maxEvents,p=c!=null&&c>0?new Ne(c):null,h=[],f=new Set,l={},g=new Set,b=0,w=0,x=0,m=0,v=0,_=0,y=!1,T=!1,O=0,N=new Map,D=new Map,k=new Map,R=E=>{p?p.push(E):h.push(E);for(let C of f)C(E)},S=()=>s?{timestamp_ns:ge(),in_batch:ke(),batch_id:O}:{},I=(E,C)=>{if(!(!u||!(E instanceof L)))return E._setInspectorHook(U=>{if(U.kind==="dep_message")N.set(E,U.depIndex);else if(U.kind==="run"){let ve=U.batchData.map((A,B)=>A!=null&&A.length>0?A.at(-1):U.prevData[B]);D.set(E,ve);let W=U.batchData.map(A=>A!=null?[...A]:void 0);k.set(E,W),i&&R({type:"derived",path:C,dep_values:ve,dep_batches:W,...S()})}})},V=E=>{let C=N.get(E),U=D.get(E);if(!o||U==null)return{};let W=(C!=null&&C>=0&&E instanceof L?E._deps[C]:void 0)?.node,A=W?.v,B=k.get(E);return{trigger_dep_index:C,trigger_dep_name:W?.name,...A!=null?{trigger_version:{id:A.id,version:A.version}}:{},dep_values:[...U],...B!=null?{dep_batches:B}:{}}},Y=[],oe=[];for(let[E,C]of e){let U=I(C,E);U&&Y.push(U),oe.push(C.subscribe(ve=>{O++;for(let W of ve){let A=W[0],B=S();if(A===$){l[E]=W[1];let Ye=C instanceof L?C.lastMutation?.actor??he:he;R({type:"data",path:E,data:W[1],actor:Ye,...B,...V(C)})}else if(a)A===Z?b++:A===F?w++:A===J?x++:A===Q?m++:A===te?v++:A===j?_++:A===H&&!g.has(E)?y=!0:A===M&&(T=!0,g.add(E));else if(A===Z)b++,R({type:"dirty",path:E,...B});else if(A===F)w++,R({type:"resolved",path:E,...B,...V(C)});else if(A===J)x++,R({type:"invalidate",path:E,...B});else if(A===Q)m++,R({type:"pause",path:E,lockId:W[1],...B});else if(A===te)v++,R({type:"resume",path:E,lockId:W[1],...B});else if(A===H)g.has(E)||(y=!0),R({type:"complete",path:E,...B});else if(A===M){T=!0,g.add(E);let Ye=C instanceof L?C.lastMutation?.actor??he:he;R({type:"error",path:E,data:W[1],actor:Ye,...B})}else A===j&&(_++,R({type:"teardown",path:E,...B}))}}))}let We=!1,Ke=()=>{if(!We){We=!0;for(let E of oe)E();for(let E of Y)E();for(let E of Ee)E({value:void 0,done:!0});Ee.length=0}},qe=[],Ee=[];f.add(E=>{let C=Ee.shift();C?C({value:E,done:!1}):qe.push(E)});let bt={get values(){return l},get dirtyCount(){return b},get resolvedCount(){return w},get invalidateCount(){return x},get pauseCount(){return m},get resumeCount(){return v},get teardownCount(){return _},get events(){return p?p.toArray():[...h]},get anyCompletedCleanly(){return y},get anyErrored(){return T},get completedWithoutErrors(){return y&&!T},onEvent(E){return f.add(E),()=>f.delete(E)},dispose:Ke,expand(E){Ke();let C={...n};return typeof E=="string"?C.detail=E:Object.assign(C,E),r(nn(C))},[Symbol.asyncIterator](){return{next(){return qe.length>0?Promise.resolve({value:qe.shift(),done:!1}):We?Promise.resolve({value:void 0,done:!0}):new Promise(E=>Ee.push(E))},return(){return Ke(),Promise.resolve({value:void 0,done:!0})}}}};return n.format!=null&&this._attachFormatLogger(bt,n),bt}_attachFormatLogger(e,n){let r=n.format;if(r==null)return;let s=n.logger??(l=>console.log(l)),o=n.includeTypes?new Set(n.includeTypes):null,i=n.excludeTypes?new Set(n.excludeTypes):null,a=o==null&&i==null?()=>!0:l=>(o==null||o.has(l))&&(i==null||!i.has(l)),d=vr(n.theme),u=r==="stage-log"?ge():0,c=l=>l==null?"":n.stageLabels?.[l]??l,p=(l,g)=>l.length>g?`${l.slice(0,g-1)}\u2026`:l,h=l=>l.type==="data"||l.type==="error"?p(Ue(l.data),120):"",f=l=>{if(r==="stage-log"){let T=(ge()-u)/1e9,O=c(l.path).padEnd(9);if(l.type==="data"){let N=h(l);return`[${T.toFixed(3)}s] ${O} \u2190${N?` ${N}`:""}`}if(l.type==="error"){let N=h(l);return`[${T.toFixed(3)}s] ${O} \u2717${N?` ${N}`:""}`}return l.type==="complete"?`[${T.toFixed(3)}s] ${O} \u25A0 complete`:`[${T.toFixed(3)}s] ${O} ${l.type}`}if(r==="json")try{return JSON.stringify(l)}catch{return JSON.stringify({type:l.type,path:l.path,data:"[unserializable]"})}let g=d[l.type]??"",b=l.path?`${d.path}${l.path}${d.reset} `:"",w=l.type==="data"||l.type==="error",x=l.type==="pause"||l.type==="resume",m=w?` ${Ue(l.data)}`:x?` ${Ue(l.lockId)}`:"",v=l.type==="data"||l.type==="resolved"||l.type==="derived"?l:void 0,_=v?.trigger_dep_name!=null?` <- ${v.trigger_dep_name}`:v?.trigger_dep_index!=null?` <- #${v.trigger_dep_index}`:"",y=l.in_batch?" [batch]":"";return`${b}${g}${l.type.toUpperCase()}${d.reset}${m}${_}${y}`};e.onEvent(l=>{a(l.type)&&s(f(l),l)})}addDisposer(e){return this._disposers.add(e),()=>{this._disposers.delete(e)}}destroy(){en(this._disposers,this.name),this.signal([[j]],{internal:!0}),en(this._storageDisposers,this.name);for(let e of[...this._mounts.values()])e._parent=void 0,e._destroyClearOnly();this._mounts.clear(),this._nodes.clear(),this._parent=void 0,this._destroyed=!0}get destroyed(){return this._destroyed}_destroyClearOnly(){for(let e of[...this._mounts.values()])e._parent=void 0,e._destroyClearOnly();this._mounts.clear(),this._nodes.clear(),this._parent=void 0,this._destroyed=!0}snapshot(e){let{expand:n,...r}=this.describe({detail:"full"}),s={};for(let a of Object.keys(r.nodes).sort()){let{lastMutation:d,guard:u,...c}=r.nodes[a];s[a]=c}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 Tt(a,a.encode(i))}throw new Error(`snapshot: unknown format "${String(e.format)}"`)}static decode(e,n){let r=n?.config??me,{codec:s,codecVersion:o,payload:i}=Ot(e,r);return s.decode(i,o)}restore(e,n){if(tn(e),e.name!==this.name)throw new Error(`Graph "${this.name}": restore snapshot name "${e.name}" does not match this graph`);let r=n?.only==null?null:(Array.isArray(n.only)?n.only:[n.only]).map(o=>ze(o)),s=n?.includeProducers===!0;for(let o of Object.keys(e.nodes).sort()){if(r!==null&&!r.some(a=>a.test(o)))continue;let i=e.nodes[o];if(i!==void 0){if(!("value"in i)||i.value===void 0){"value"in i&&i.value===void 0&&n?.onError?.(o,new Error(`restore: slice.value is undefined for "${o}" (undefined is the global SENTINEL; not valid DATA)`));continue}if(!(i.type==="derived"||i.type==="effect")&&!(i.type==="producer"&&!s)){if(i.v!=null){let d=this.tryResolve(o)?.v;if(d!=null&&d.id===i.v.id&&d.version===i.v.version)continue}try{this.set(o,i.value)}catch(a){n?.onError?.(o,a)}}}}}static fromSnapshot(e,n){tn(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 f of[...e.subgraphs].sort((l,g)=>{let b=l.split(G).length,w=g.split(G).length;return b!==w?b-w:l<g?-1:l>g?1:0})){let l=f.split(G),g=o;for(let b of l)g._mounts.has(b)||g.mount(b,new t(b)),g=g._mounts.get(b)}let i=s?Object.entries(s).map(([f,l])=>({re:ze(f),factory:l})):[],a=f=>{for(let l of i)if(l.re.test(f))return l.factory},d=f=>{let l=f.split(G),g=l.pop();if(g==null||g.length===0)throw new Error(`invalid snapshot path "${f}"`);let b=o;for(let w of l){let x=b._mounts.get(w);if(!x)throw new Error(`unknown mount "${w}" in path "${f}"`);b=x}return[b,g]},u=Object.entries(e.nodes).filter(([f])=>!f.includes(`${G}${z}${G}`)).sort((f,l)=>f[0]<l[0]?-1:f[0]>l[0]?1:0),c=new Map(u),p=new Map,h=!0;for(;c.size>0&&h;){h=!1;for(let[f,l]of[...c.entries()]){let g=l?.deps??[];if(!g.every(_=>p.has(_)))continue;let[b,w]=d(f),x={...l?.meta??{}},m=a(f),v;if(l?.type==="state")v=ue(l.value,{meta:x});else{if(m==null)continue;v=m(w,{path:f,type:l.type,value:l.value,meta:x,deps:g,resolvedDeps:g.map(_=>p.get(_))})}b.add(v,{name:w}),p.set(f,v),c.delete(f),h=!0}}if(c.size>0){let f=[...c.keys()].sort().join(", ");throw new Error(`Graph.fromSnapshot could not reconstruct nodes without build callback: ${f}. Pass matching factories via fromSnapshot(data, { factories: { pattern: factoryFn } }).`)}return o.restore(e),o}toJSON(){return this.snapshot()}attachStorage(e,n={}){let r=e.map(u=>({tier:u,debounceMs:Math.max(0,u.debounceMs??0),compactEvery:Math.max(1,u.compactEvery??10),timer:void 0,seq:0,lastSnapshot:void 0,lastFingerprint:"",disposed:!1,savePending:void 0}));n.autoRestore===!0&&this._cascadeRestore(e,n.onError);let s=(u,c)=>{if(u.disposed)return;let p=ir(c.nodes);if(u.lastSnapshot!=null&&p!==""&&p===u.lastFingerprint)return;let h=u.seq+1,f=Ce(),b=u.lastSnapshot==null||h%u.compactEvery===0?{mode:"full",snapshot:c,seq:h,timestamp_ns:f,format_version:ye}:{mode:"diff",diff:Tr(u.lastSnapshot,c),seq:h,timestamp_ns:f,format_version:ye};if(u.tier.filter&&!u.tier.filter(this.name,b))return;let w;try{w=u.tier.save(this.name,b)}catch(x){n.onError?.(x,u.tier);return}if(w&&typeof w.then=="function"){let v=(u.savePending??Promise.resolve()).then(()=>w,()=>w).then(()=>{u.disposed||(u.seq=h,u.lastSnapshot=c,u.lastFingerprint=p)},_=>{n.onError?.(_,u.tier)});u.savePending=v.finally(()=>{u.savePending===v&&(u.savePending=void 0)})}else u.seq=h,u.lastSnapshot=c,u.lastFingerprint=p},o=(u,c)=>{try{s(u,c)}catch(p){n.onError?.(p,u.tier)}},i=(u,c)=>{if(!c.some(l=>{let g=this.config.messageTier(l[0]);return g>=3&&g<5}))return;if(n.filter){let l=this.tryResolve(u);if(l==null)return;let g=ft(l,Le("standard"));if(!n.filter(u,g))return}let h,f=()=>(h==null&&(h=this.snapshot()),h);for(let l of r)l.disposed||(l.debounceMs===0?o(l,f()):(l.timer==null&&(l.timer=new Pe),l.timer.start(l.debounceMs,()=>{l.disposed||o(l,this.snapshot())})))},a;if(n.paths!=null){let c=(typeof n.paths=="string"?this._pathsMatching(n.paths):n.paths).map(p=>{let h=this.tryResolve(p);return h==null?()=>{}:h.subscribe(f=>i(p,f))});a=()=>{for(let p of c)p()}}else a=this.observe().subscribe((u,c)=>i(u,c));let d=()=>{a();for(let u of r)u.disposed=!0,u.timer?.cancel();this._storageDisposers.delete(d)};return this._storageDisposers.add(d),{dispose:d}}async _cascadeRestore(e,n){for(let r of e){let s;try{s=await r.load(this.name)}catch(i){n?.(i,r);continue}if(s==null||typeof s!="object"||Array.isArray(s))continue;let o=s;try{if(o.mode==="full"&&o.snapshot!=null)return this.restore(o.snapshot),!0;if(o.version===ye&&o.nodes!=null)return this.restore(o),!0}catch(i){n?.(i,r)}}return!1}static async fromStorage(e,n,r){for(let s of n){let o;try{o=await s.load(e)}catch(d){r?.onError?.(d,s);continue}if(o==null||typeof o!="object"||Array.isArray(o))continue;let i=o,a=i.mode==="full"&&i.snapshot!=null?i.snapshot:i.version===ye&&i.nodes!=null?i:void 0;if(a!=null)try{return t.fromSnapshot(a,r)}catch(d){r?.onError?.(d,s)}}throw new Error(`Graph.fromStorage: no tier held a restorable record for "${e}" across ${n.length} tier(s)`)}_annotations=new Map;_traceRing;trace(e,n,r){if(e!=null&&n!=null){if(this.tryResolve(e)==null)return;if(this._annotations.set(e,n),this.config.inspectorEnabled){let s={path:e,annotation:n,timestamp_ns: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(x=>!r.has(x)).sort(),i=[...r].filter(x=>!s.has(x)).sort(),a=[],d=[];for(let x of r){if(!s.has(x))continue;let m=e.nodes[x],v=n.nodes[x],_=m.v,y=v.v;_!=null&&y!=null&&_.id===y.id&&_.version!==y.version&&d.push({path:x,id:_.id,from:_.version,to:y.version});let T=_!=null&&y!=null&&_.id===y.id&&_.version===y.version;for(let O of["type","status","sentinel"]){let N=m[O],D=v[O];N!==D&&a.push({path:x,field:O,from:N,to:D})}if(!T)for(let O of["value","meta"]){let N=m[O],D=v[O];ar(N,D)||a.push({path:x,field:O,from:N,to:D})}}let u=x=>`${x.from} ${x.to}`,c=new Set(e.edges.map(u)),p=new Set(n.edges.map(u)),h=n.edges.filter(x=>!c.has(u(x))),f=e.edges.filter(x=>!p.has(u(x))),l=new Set(e.subgraphs),g=new Set(n.subgraphs),b=[...g].filter(x=>!l.has(x)).sort(),w=[...l].filter(x=>!g.has(x)).sort();return{nodesAdded:o,nodesRemoved:i,nodesChanged:a,versionChanges:d,edgesAdded:h,edgesRemoved:f,subgraphsAdded:b,subgraphsRemoved:w}}};function Tr(t,e){let n=ce.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 rn(t,e,n,r={}){let s={paths:[],depths:new Map,truncated:!1};if(!e)return r.withDetail?s:[];if(!r.both&&n!=="upstream"&&n!=="downstream")throw new Error('reachable: direction must be "upstream" or "downstream"');let o=r.maxDepth;if(o!=null&&(!Number.isInteger(o)||o<0))throw new Error("reachable: maxDepth must be an integer >= 0");if(o===0)return r.withDetail?s:[];let i=new Map,a=new Map,d=new Map,u=new Map,c=new Set;for(let[m,v]of Object.entries(t.nodes)){if(!m)continue;c.add(m);let _=v.deps??[];i.set(m,_);for(let y of _)y&&(c.add(y),a.has(y)||a.set(y,new Set),a.get(y).add(m))}for(let m of t.edges){if(m==null||typeof m!="object")continue;let v=typeof m.from=="string"?m.from:"",_=typeof m.to=="string"?m.to:"";!v||!_||(c.add(v),c.add(_),u.has(v)||u.set(v,new Set),u.get(v).add(_),d.has(_)||d.set(_,new Set),d.get(_).add(v))}if(!c.has(e))return r.withDetail?s:[];let p=r.both===!0,h=m=>{if(p){let T=i.get(m)??[],O=d.get(m),N=a.get(m),D=u.get(m),k=[...T];return O&&k.push(...O),N&&k.push(...N),D&&k.push(...D),k}if(n==="upstream"){let T=i.get(m)??[],O=d.get(m);return O?[...T,...O]:T}let v=a.get(m),_=u.get(m),y=v?[...v]:[];return _&&y.push(..._),y},f=new Set([e]),l=new Map,g=[{path:e,depth:0}],b=0,w=!1;for(;b<g.length;){let m=g[b++];if(o!=null&&m.depth>=o){h(m.path).length>0&&(w=!0);continue}for(let v of h(m.path))!v||f.has(v)||(f.add(v),l.set(v,m.depth+1),g.push({path:v,depth:m.depth+1}))}let x=[...l.keys()].sort((m,v)=>m<v?-1:m>v?1:0);return r.withDetail?{paths:x,depths:l,truncated:w}:x}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 dn(t,e,n){return{[t]:!0,[`${t}_type`]:e,...n??{}}}function ee(t,e){if(typeof e=="string")return{node:t.resolve(e),path:e};let n=Nr(t,e);if(!n)throw new Error("orchestration dep node must already be registered in the graph so explicit edges can be recorded; pass a string path or register the node first");return{node:e,path:n}}function Nr(t,e){let n=t.describe(),r=`::${z}::`;for(let s of Object.keys(n.nodes).sort())if(!s.includes(r))try{if(t.resolve(s)===e)return s}catch{}}function re(t,e,n,r){t.add(n,{name:e})}function se(t,e){return dn("orchestration",t,e)}function Er(t){let e=r=>{let s=r.trim();return s.length===0?0:Number(s)},n;return typeof t=="string"?n=e(t):t===null?n=0:n=Number(t),Number.isFinite(n)?Math.max(0,Math.trunc(n)):1}function cn(t,e){return new ce(t,e)}function kr(t,e,n,r){let o=(r?.deps??[]).map(c=>ee(t,c)),{deps:i,...a}=r??{},d=(c,p,h)=>{let f=c.map((l,g)=>l!=null&&l.length>0?l.at(-1):h.prevData[g]);p.emit(n(f,h))},u=X(o.map(c=>c.node),d,{...a,name:e,describeKind:"derived",meta:se("task",r?.meta)});return re(t,e,u,o.flatMap(c=>c.path?[c.path]:[])),u}function Sr(t,e,n,r,s){let o=ee(t,n),i=de([o.node],([a])=>({branch:r(a)?"then":"else",value:a}),{...s,name:e,meta:se("branch",s?.meta)});return re(t,e,i,o.path?[o.path]:[]),i}function Rr(t,e,n,r,s){let o=ee(t,n),i=ee(t,r),a=s?.isApproved??(u=>!!u),d=X([o.node,i.node],(u,c,p)=>{let h=u[0],f=u[1],l=f!=null&&f.length>0?f.at(-1):p.prevData[1];if(l===void 0||!a(l)){c.down([[F]]);return}if(h==null||h.length===0){f!=null&&f.length>0&&p.prevData[0]!==void 0?c.emit(p.prevData[0]):c.down([[F]]);return}for(let g of h)c.emit(g)},{...s,name:e,describeKind:"derived",meta:se("approval",s?.meta)});return re(t,e,d,[o.path,i.path].filter(u=>typeof u=="string")),d}function Dr(t,e,n,r){let s=r?.maxPending??1/0;if(s<1&&s!==1/0)throw new RangeError("gate: maxPending must be >= 1");let o=r?.startOpen??!1,i=ee(t,n),a=ue([],{name:"pending",equals:()=>!1}),d=ue(o,{name:"isOpen"}),u=de([a],([_])=>_.length,{name:"count"}),c=[],p=!1,h=o,f=d.subscribe(_=>{for(let y of _)y[0]===$&&(h=y[1])});function l(){a.emit([...c])}function g(_){c.push(_),c.length>s&&c.shift(),l()}function b(_){let y=c.splice(0,_);return l(),y}function w(_){if(p)throw new Error(`gate: ${_}() called after gate was torn down`)}let x=X([i.node],(_,y,T)=>{let O=T.terminalDeps[0];if(O!==void 0){p=!0,c=[],l(),y.down(O===!0?[[H]]:[[M,O]]);return}let N=_[0];if(N==null||N.length===0){y.down([[F]]);return}for(let D of N)h?y.emit(D):(g(D),y.down([[F]]))},{name:e,describeKind:"derived",meta:se("gate",r?.meta)}),m={node:x,pending:a,count:u,isOpen:d,approve(_=1){w("approve");let y=b(_);for(let T of y){if(p)break;x.emit(T)}},reject(_=1){w("reject"),b(_)},modify(_,y=1){w("modify");let T=[...c],O=b(y);for(let N=0;N<O.length&&!p;N++)x.emit(_(O[N],N,T))},open(){w("open"),Se(()=>{d.emit(!0);let _=b(c.length);for(let y of _){if(p)break;x.emit(y)}})},close(){w("close"),d.emit(!1)}};t.addDisposer(u.subscribe(()=>{})),t.addDisposer(f),re(t,e,x,i.path?[i.path]:[]);let v=new ce(`${e}_state`);return v.add(a,{name:"pending"}),v.add(d,{name:"isOpen"}),v.add(u,{name:"count"}),t.mount(`${e}_state`,v),m}function Ar(t,e,n,r){let s=n.map(i=>ee(t,i)),o=de(s.map(i=>i.node),i=>i,{...r,name:e,meta:se("join",r?.meta)});return re(t,e,o,s.flatMap(i=>i.path?[i.path]:[])),o}function Cr(t,e,n,r,s){let o=ee(t,n),i=s?.iterations,a=typeof i=="number"||i===void 0?void 0:ee(t,i),d=typeof i=="number"?i:void 0,u=X(a?[o.node,a.node]:[o.node],(c,p,h)=>{let f=c[0],l=f!=null&&f.length>0?f.at(-1):h.prevData[0],g=a?c[1]:void 0,b=d??(a?g!=null&&g.length>0?g.at(-1):h.prevData[1]:1),w=Er(b);for(let x=0;x<w;x+=1)l=r(l,x,p);p.emit(l)},{...s,name:e,describeKind:"derived",meta:se("loop",s?.meta)});return re(t,e,u,[o.path,a?.path].filter(c=>typeof c=="string")),u}function Mr(t,e,n,r){let s=n instanceof ce?n:cn(e,r);return typeof n=="function"&&n(s),t.mount(e,s),s}function Gr(t,e,n,r){let s=X([],()=>{},{...r,name:e,initial:n,describeKind:"producer",meta:se("sensor",r?.meta)});return re(t,e,s,[]),{node:s,push(o){s.emit(o)},error(o){s.down([[M,o]])},complete(){s.down([[H]])}}}function Ir(t,e,n,r,s){let o=ee(t,n),i=!1,a=X([],(d,u)=>{let c=o.node.subscribe(p=>{for(let h of p){if(i)return;if(h[0]===M)try{u.emit(r(h[1],u))}catch(f){i=!0,u.down([[M,f]])}else u.down([h]),h[0]===H&&(i=!0)}});return()=>c()},{...s,name:e,describeKind:"derived",completeWhenDepsComplete:!1,errorWhenDepsError:!1,meta:se("onFailure",s?.meta)});return re(t,e,a,o.path?[o.path]:[]),a}0&&(module.exports={approval,branch,gate,join,loop,onFailure,pipeline,sensor,subPipeline,task});
@@ -1,6 +1,6 @@
1
1
  import '../../node-BVV7G1bq.cjs';
2
2
  import '../../sugar-CqR6DJ7v.cjs';
3
- import '../../graph-C4Uxwv0T.cjs';
4
- export { A as ApprovalOptions, B as BranchResult, G as GateController, a as GateOptions, L as LoopOptions, O as OrchestrationStepOptions, S as SensorControls, b as StepRef, c as SubPipelineBuilder, d as approval, e as branch, g as gate, j as join, l as loop, o as onFailure, p as pipeline, s as sensor, f as subPipeline, t as task } from '../../index-DVNLe3pS.cjs';
3
+ import '../../graph-CdJeX7O7.cjs';
4
+ export { A as ApprovalOptions, B as BranchResult, G as GateController, a as GateOptions, L as LoopOptions, O as OrchestrationStepOptions, S as SensorControls, b as StepRef, c as SubPipelineBuilder, d as approval, e as branch, g as gate, j as join, l as loop, o as onFailure, p as pipeline, s as sensor, f as subPipeline, t as task } from '../../index-CCdg0JLX.cjs';
5
5
  import '../../meta-COtmHLwT.cjs';
6
6
  import '../../extra/storage-core.cjs';
@@ -1,6 +1,6 @@
1
1
  import '../../node-BVV7G1bq.js';
2
2
  import '../../sugar-BHbAACDG.js';
3
- import '../../graph-CWeI0aHd.js';
4
- export { A as ApprovalOptions, B as BranchResult, G as GateController, a as GateOptions, L as LoopOptions, O as OrchestrationStepOptions, S as SensorControls, b as StepRef, c as SubPipelineBuilder, d as approval, e as branch, g as gate, j as join, l as loop, o as onFailure, p as pipeline, s as sensor, f as subPipeline, t as task } from '../../index-CFW32Dy1.js';
3
+ import '../../graph-BOhEGJ6E.js';
4
+ export { A as ApprovalOptions, B as BranchResult, G as GateController, a as GateOptions, L as LoopOptions, O as OrchestrationStepOptions, S as SensorControls, b as StepRef, c as SubPipelineBuilder, d as approval, e as branch, g as gate, j as join, l as loop, o as onFailure, p as pipeline, s as sensor, f as subPipeline, t as task } from '../../index-eYHRkoK-.js';
5
5
  import '../../meta-BMwx3ExI.js';
6
6
  import '../../extra/storage-core.js';
@@ -1 +1 @@
1
- import{a,b,c,d,e,f,g,h,i,j}from"../../chunk-5LJAQTSS.js";import"../../chunk-K54OKWNY.js";import"../../chunk-PSQNYY72.js";import"../../chunk-SGS4OJGS.js";import"../../chunk-ESMPEKEV.js";import"../../chunk-N2KKISCE.js";import"../../chunk-UMH3HSP7.js";import"../../chunk-7AJKUA36.js";import"../../chunk-CK2E7BTU.js";import"../../chunk-QYADASLV.js";export{d as approval,c as branch,e as gate,f as join,g as loop,j as onFailure,a as pipeline,i as sensor,h as subPipeline,b as task};
1
+ import{a,b,c,d,e,f,g,h,i,j}from"../../chunk-ZWETYYQG.js";import"../../chunk-K54OKWNY.js";import"../../chunk-4JBKKUCJ.js";import"../../chunk-SGS4OJGS.js";import"../../chunk-ESMPEKEV.js";import"../../chunk-N2KKISCE.js";import"../../chunk-UMH3HSP7.js";import"../../chunk-7AJKUA36.js";import"../../chunk-CK2E7BTU.js";import"../../chunk-QYADASLV.js";export{d as approval,c as branch,e as gate,f as join,g as loop,j as onFailure,a as pipeline,i as sensor,h as subPipeline,b as task};