@graphrefly/graphrefly 0.32.0 → 0.34.0
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/dist/{cascading-D3sapjue.d.ts → cascading-Bg0a4VSf.d.ts} +2 -2
- package/dist/{cascading-BfQmSmjU.d.cts → cascading-DKIb6Pk8.d.cts} +2 -2
- package/dist/{chunk-4JBKKUCJ.js → chunk-2JO6LXFT.js} +1 -1
- package/dist/{chunk-FTA5TB2A.js → chunk-2LZ6DL45.js} +1 -1
- package/dist/chunk-3Y4BXFFR.js +1 -0
- package/dist/{chunk-WQ7I7JVU.js → chunk-4F564IPP.js} +1 -1
- package/dist/{chunk-M2VFLRPJ.js → chunk-4NYSEUKV.js} +1 -1
- package/dist/{chunk-N2KKISCE.js → chunk-533RQFF6.js} +1 -1
- package/dist/{chunk-BU4SUZSA.js → chunk-55T3K37W.js} +1 -1
- package/dist/chunk-65WWQ5CB.js +43 -0
- package/dist/chunk-6HQ6HVTF.js +1 -0
- package/dist/{chunk-4VXL3UZK.js → chunk-7Q2WPFQ7.js} +1 -1
- package/dist/chunk-A3GDELMY.js +61 -0
- package/dist/{chunk-5PBXUVHI.js → chunk-BY4WKPKM.js} +1 -1
- package/dist/{chunk-JYMNVEH6.js → chunk-C5DINHNP.js} +1 -1
- package/dist/{chunk-7QS77X6G.js → chunk-CJMFZXIZ.js} +1 -1
- package/dist/{chunk-W6FQIFVE.js → chunk-CLD3F4R5.js} +1 -1
- package/dist/{chunk-RWGJQQLT.js → chunk-FKRPIRE6.js} +1 -1
- package/dist/{chunk-UXEB35L4.js → chunk-GAOX6OPT.js} +1 -1
- package/dist/{chunk-TOCCHQI6.js → chunk-GCUYSIM4.js} +1 -1
- package/dist/{chunk-XRSHMHEG.js → chunk-HTBOCKVD.js} +1 -1
- package/dist/{chunk-LJGPOJHS.js → chunk-IB64M7VP.js} +1 -1
- package/dist/{chunk-Q2SY7M7K.js → chunk-IJFSR4NU.js} +1 -1
- package/dist/{chunk-X4OOM6QU.js → chunk-INXDSJRC.js} +1 -1
- package/dist/{chunk-4YGJ7KZ6.js → chunk-IPNJDNE7.js} +1 -1
- package/dist/{chunk-4UUDNFYG.js → chunk-KGKJCHEK.js} +1 -1
- package/dist/chunk-KN2UMFT6.js +5 -0
- package/dist/{chunk-A4JT4SAD.js → chunk-KRH66M4O.js} +1 -1
- package/dist/{chunk-K54OKWNY.js → chunk-L3KUKDZC.js} +1 -1
- package/dist/{chunk-Y26UN6J5.js → chunk-LOF5HSD3.js} +1 -1
- package/dist/chunk-LYCLF26R.js +1 -0
- package/dist/{chunk-CZVYLXFK.js → chunk-M27MVZCP.js} +1 -1
- package/dist/{chunk-DWIAG62L.js → chunk-NNKJUORL.js} +1 -1
- package/dist/{chunk-WF3V5X2L.js → chunk-PBN426RU.js} +1 -1
- package/dist/{chunk-MFNOZ5E6.js → chunk-Q46YJCQH.js} +1 -1
- package/dist/{chunk-KD3IYBTD.js → chunk-SFIM774L.js} +1 -1
- package/dist/{chunk-VXJX3ZZP.js → chunk-T2TB37TW.js} +1 -1
- package/dist/{chunk-UMH3HSP7.js → chunk-T7EQPKOP.js} +1 -1
- package/dist/{chunk-JAHAJU4G.js → chunk-TONEKQM3.js} +1 -1
- package/dist/{chunk-CNXUW2CU.js → chunk-TZLEMGAK.js} +1 -1
- package/dist/{chunk-LWGLBCMU.js → chunk-TZQPPQEQ.js} +1 -1
- package/dist/{chunk-7JZ3YORY.js → chunk-U2T2XWDA.js} +1 -1
- package/dist/{chunk-WE32AFFA.js → chunk-UF746BQ4.js} +1 -1
- package/dist/{chunk-7QMVU3IX.js → chunk-WBWBY6LI.js} +1 -1
- package/dist/{chunk-7EMUF2RY.js → chunk-Y63GWRHO.js} +1 -1
- package/dist/{chunk-PWKLZ2XU.js → chunk-YDWTVO4E.js} +1 -1
- package/dist/{chunk-EIFHFDFD.js → chunk-YUBV7EEE.js} +1 -1
- package/dist/compat/index.cjs +5 -5
- package/dist/compat/index.d.cts +14 -14
- package/dist/compat/index.d.ts +14 -14
- package/dist/compat/index.js +1 -1
- package/dist/compat/jotai/index.cjs +1 -1
- package/dist/compat/jotai/index.d.cts +2 -2
- package/dist/compat/jotai/index.d.ts +2 -2
- package/dist/compat/jotai/index.js +1 -1
- package/dist/compat/nanostores/index.cjs +1 -1
- package/dist/compat/nanostores/index.d.cts +2 -2
- package/dist/compat/nanostores/index.d.ts +2 -2
- package/dist/compat/nanostores/index.js +1 -1
- package/dist/compat/nestjs/index.cjs +5 -5
- package/dist/compat/nestjs/index.d.cts +6 -6
- package/dist/compat/nestjs/index.d.ts +6 -6
- package/dist/compat/nestjs/index.js +1 -1
- package/dist/compat/react/index.d.cts +2 -2
- package/dist/compat/react/index.d.ts +2 -2
- package/dist/compat/solid/index.d.cts +2 -2
- package/dist/compat/solid/index.d.ts +2 -2
- package/dist/compat/svelte/index.d.cts +2 -2
- package/dist/compat/svelte/index.d.ts +2 -2
- package/dist/compat/vue/index.d.cts +2 -2
- package/dist/compat/vue/index.d.ts +2 -2
- package/dist/compat/zustand/index.cjs +3 -3
- package/dist/compat/zustand/index.d.cts +4 -4
- package/dist/compat/zustand/index.d.ts +4 -4
- package/dist/compat/zustand/index.js +1 -1
- package/dist/{composite-BY9hMxN7.d.ts → composite-BPDU_XV1.d.ts} +2 -2
- package/dist/{composite-CH0S8DFn.d.cts → composite-CmvdhTJe.d.cts} +2 -2
- package/dist/core/index.cjs +1 -1
- package/dist/core/index.d.cts +4 -4
- package/dist/core/index.d.ts +4 -4
- package/dist/core/index.js +1 -1
- package/dist/extra/browser.cjs +1 -1
- package/dist/extra/browser.d.cts +1 -1
- package/dist/extra/browser.d.ts +1 -1
- package/dist/extra/browser.js +1 -1
- package/dist/extra/index.cjs +16 -16
- package/dist/extra/index.d.cts +9 -9
- package/dist/extra/index.d.ts +9 -9
- package/dist/extra/index.js +1 -1
- package/dist/extra/node.cjs +1 -1
- package/dist/extra/node.d.cts +1 -1
- package/dist/extra/node.d.ts +1 -1
- package/dist/extra/node.js +1 -1
- package/dist/extra/operators.cjs +1 -1
- package/dist/extra/operators.d.cts +1 -1
- package/dist/extra/operators.d.ts +1 -1
- package/dist/extra/operators.js +1 -1
- package/dist/extra/reactive.cjs +1 -1
- package/dist/extra/reactive.d.cts +3 -3
- package/dist/extra/reactive.d.ts +3 -3
- package/dist/extra/reactive.js +1 -1
- package/dist/extra/sources.cjs +1 -1
- package/dist/extra/sources.d.cts +1 -1
- package/dist/extra/sources.d.ts +1 -1
- package/dist/extra/sources.js +1 -1
- package/dist/extra/storage-browser.cjs +1 -1
- package/dist/extra/storage-browser.d.cts +1 -1
- package/dist/extra/storage-browser.d.ts +1 -1
- package/dist/extra/storage-browser.js +1 -1
- package/dist/{fallback-Cb3GH1O7.d.cts → fallback-9YznPvPP.d.cts} +1 -1
- package/dist/{fallback-DRjJ_ZM8.d.ts → fallback-mYSd8vQo.d.ts} +1 -1
- package/dist/graph/index.cjs +4 -4
- package/dist/graph/index.d.cts +5 -5
- package/dist/graph/index.d.ts +5 -5
- package/dist/graph/index.js +1 -1
- package/dist/{graph-BOhEGJ6E.d.ts → graph-BROUZPG9.d.ts} +2 -2
- package/dist/{graph-CdJeX7O7.d.cts → graph-DaoydJ_u.d.cts} +2 -2
- package/dist/{index-C22aTC1X.d.cts → index-3L3RC3VJ.d.ts} +578 -108
- package/dist/{index-BmZb8fNF.d.cts → index-B-KCkW4M.d.cts} +4 -4
- package/dist/{index-CDK5RsV5.d.cts → index-B1hFhK1K.d.cts} +1 -1
- package/dist/{index-C7RqYbOZ.d.ts → index-B5eS17Bz.d.ts} +7 -7
- package/dist/{index-DSawGt8n.d.cts → index-BDEhWLF4.d.cts} +3 -3
- package/dist/{index-CZUzi6Dy.d.ts → index-BFHpNSsV.d.ts} +4 -4
- package/dist/{index-DDo-eqQ4.d.cts → index-BO6t0HjV.d.cts} +1 -1
- package/dist/{index-CrC7urhX.d.ts → index-BRisOxlx.d.ts} +1 -1
- package/dist/{index-CHfBm51k.d.ts → index-BUtCR0k6.d.ts} +4 -4
- package/dist/{index-BydMDMf7.d.cts → index-BVTjuKeP.d.cts} +1 -1
- package/dist/{index-BX22kvjh.d.ts → index-BWiX5foT.d.ts} +1 -1
- package/dist/{index-Dxk-pUQI.d.ts → index-Bd2AjMQY.d.ts} +2 -2
- package/dist/{index-Dbmj0iYR.d.ts → index-Bi4ZP6Hc.d.ts} +2 -2
- package/dist/{index-j33Lfb1G.d.cts → index-BkfL5MXh.d.cts} +3 -3
- package/dist/{index-CnjUhRbs.d.cts → index-BpjQanLs.d.cts} +2 -2
- package/dist/{index-LGzAYqdR.d.ts → index-BsxqmV6u.d.ts} +2 -2
- package/dist/{index-CCdg0JLX.d.cts → index-C2Dey3L-.d.cts} +12 -3
- package/dist/{index-gXTVbSax.d.ts → index-C5uMGVJw.d.ts} +4 -4
- package/dist/{index-C-Gsh-0a.d.cts → index-C8_bnDBZ.d.cts} +3 -3
- package/dist/{index-C9qCLIN4.d.ts → index-CD7qmvSf.d.ts} +3 -3
- package/dist/{index-wIx1Jisk.d.ts → index-CI5fULSz.d.ts} +1 -1
- package/dist/{index-BUZPTPSQ.d.ts → index-CNxdDb2e.d.ts} +3 -3
- package/dist/{index-FBqTfL_S.d.cts → index-CQ1gt4rn.d.cts} +1 -1
- package/dist/{index-CNyiYQWF.d.ts → index-CQtnGFrZ.d.cts} +578 -108
- package/dist/{index-DhlAMlm9.d.ts → index-CbCNoogR.d.ts} +218 -66
- package/dist/{index-BDLy6CQ9.d.cts → index-Ccv_61jG.d.cts} +2 -2
- package/dist/{index-MV2yGIAq.d.ts → index-Ced0dphF.d.ts} +9 -9
- package/dist/{index-BzxU4yhV.d.cts → index-ChZvMC4M.d.cts} +4 -4
- package/dist/{index-zMQIQuDu.d.ts → index-Chi9IiHJ.d.ts} +3 -3
- package/dist/{index-DUkuH3jP.d.cts → index-ClJUZAOr.d.cts} +18 -3
- package/dist/{index-D7XxY1Ff.d.cts → index-ClKm7CFB.d.cts} +1 -1
- package/dist/{index-D3HcdZ4d.d.cts → index-Cn3taOmp.d.cts} +2 -2
- package/dist/{index-C4QTaDli.d.cts → index-CoR-tOZA.d.cts} +4 -4
- package/dist/{index-BpFWP7Bq.d.cts → index-Cp91Sxbo.d.cts} +5 -4
- package/dist/{index-DD1czHj3.d.ts → index-Cq7Uqgu4.d.ts} +2 -2
- package/dist/{index-EGjF6iSY.d.cts → index-D23g00HE.d.cts} +4 -4
- package/dist/{index-Bnmttu35.d.ts → index-D80nGRb9.d.ts} +3 -3
- package/dist/{index-DY2QbdoP.d.cts → index-DR3XqZlV.d.cts} +1 -1
- package/dist/{index-BANwzwBV.d.ts → index-Db21wuaD.d.ts} +5 -4
- package/dist/{index-CIXaiYDE.d.cts → index-DhWrMTI6.d.cts} +1 -1
- package/dist/{index-Dp_pS7Bw.d.ts → index-DheNs40A.d.ts} +2 -2
- package/dist/{index-CVevMZ0n.d.ts → index-Dia4yc2y.d.ts} +3 -3
- package/dist/{index-_BXz9K7b.d.cts → index-Ds3Rz9m9.d.cts} +3 -3
- package/dist/{index-Ckl03Q0s.d.ts → index-Dtpr2FIB.d.ts} +18 -3
- package/dist/{index-ByPnK85n.d.ts → index-DupIl9wI.d.ts} +1 -1
- package/dist/{index-CEoU-r-g.d.ts → index-DuvQAU02.d.ts} +2 -2
- package/dist/{index-D0C_USMR.d.ts → index-DxEcY7Om.d.ts} +1 -1
- package/dist/{index-eYHRkoK-.d.ts → index-HvJ90_tX.d.ts} +12 -3
- package/dist/{index-BuN2wGJs.d.cts → index-IxinNgAH.d.cts} +218 -66
- package/dist/{index-LzCJ0kMT.d.cts → index-Jgl7ev9I.d.cts} +9 -9
- package/dist/{index-DlGaEBW5.d.cts → index-RJX4snyi.d.cts} +2 -2
- package/dist/{index-DNhTQReY.d.cts → index-ZIQaKIdY.d.cts} +7 -7
- package/dist/{index-lpGUhTBn.d.ts → index-b4a6Sg0R.d.ts} +4 -4
- package/dist/{index-BiGeETJs.d.cts → index-iKsmdnq6.d.cts} +2 -2
- package/dist/{index-CmSjld-4.d.ts → index-nP13Qe6T.d.ts} +1 -1
- package/dist/{index-BJDXj9Wf.d.cts → index-p0bkNfby.d.cts} +3 -3
- package/dist/{index-aBqZUx3B.d.cts → index-wcfc7W-f.d.cts} +2 -2
- package/dist/{index-BwdPDWI4.d.cts → index-yJY9thRY.d.cts} +2 -2
- package/dist/{index-BbcSZCAG.d.ts → index-ygRFoyrN.d.ts} +2 -2
- package/dist/{index-Ip3q9T9x.d.ts → index-zA1uVtk0.d.ts} +1 -1
- package/dist/index.cjs +57 -57
- package/dist/index.d.cts +44 -44
- package/dist/index.d.ts +44 -44
- package/dist/index.js +1 -1
- package/dist/{meta-COtmHLwT.d.cts → meta-BdjSt8ky.d.cts} +1 -1
- package/dist/{meta-BMwx3ExI.d.ts → meta-CtDjj7cU.d.ts} +1 -1
- package/dist/{node-BVV7G1bq.d.cts → node-8qx0kgYt.d.cts} +49 -1
- package/dist/{node-BVV7G1bq.d.ts → node-8qx0kgYt.d.ts} +49 -1
- package/dist/{observable-BrUAPeH_.d.cts → observable-B6Ba-TTI.d.cts} +1 -1
- package/dist/{observable-ITikPXz3.d.ts → observable-DOniYM2B.d.ts} +1 -1
- package/dist/patterns/ai/browser.cjs +5 -5
- package/dist/patterns/ai/browser.d.cts +4 -4
- package/dist/patterns/ai/browser.d.ts +4 -4
- package/dist/patterns/ai/browser.js +1 -1
- package/dist/patterns/ai/index.cjs +19 -19
- package/dist/patterns/ai/index.d.cts +16 -16
- package/dist/patterns/ai/index.d.ts +16 -16
- package/dist/patterns/ai/index.js +1 -1
- package/dist/patterns/ai/node.cjs +2 -2
- package/dist/patterns/ai/node.d.cts +4 -4
- package/dist/patterns/ai/node.d.ts +4 -4
- package/dist/patterns/ai/node.js +1 -1
- package/dist/patterns/audit/index.cjs +7 -7
- package/dist/patterns/audit/index.d.cts +5 -5
- package/dist/patterns/audit/index.d.ts +5 -5
- package/dist/patterns/audit/index.js +1 -1
- package/dist/patterns/cqrs/index.cjs +3 -3
- package/dist/patterns/cqrs/index.d.cts +4 -4
- package/dist/patterns/cqrs/index.d.ts +4 -4
- package/dist/patterns/cqrs/index.js +1 -1
- package/dist/patterns/demo-shell/index.cjs +6 -6
- package/dist/patterns/demo-shell/index.d.cts +5 -5
- package/dist/patterns/demo-shell/index.d.ts +5 -5
- package/dist/patterns/demo-shell/index.js +1 -1
- package/dist/patterns/domain-templates/index.cjs +6 -6
- package/dist/patterns/domain-templates/index.d.cts +4 -4
- package/dist/patterns/domain-templates/index.d.ts +4 -4
- package/dist/patterns/domain-templates/index.js +1 -1
- package/dist/patterns/graphspec/index.cjs +8 -8
- package/dist/patterns/graphspec/index.d.cts +5 -5
- package/dist/patterns/graphspec/index.d.ts +5 -5
- package/dist/patterns/graphspec/index.js +1 -1
- package/dist/patterns/guarded-execution/index.cjs +7 -7
- package/dist/patterns/guarded-execution/index.d.cts +6 -6
- package/dist/patterns/guarded-execution/index.d.ts +6 -6
- package/dist/patterns/guarded-execution/index.js +1 -1
- package/dist/patterns/harness/index.cjs +12 -12
- package/dist/patterns/harness/index.d.cts +11 -10
- package/dist/patterns/harness/index.d.ts +11 -10
- package/dist/patterns/harness/index.js +1 -1
- package/dist/patterns/job-queue/index.cjs +7 -7
- package/dist/patterns/job-queue/index.d.cts +4 -4
- package/dist/patterns/job-queue/index.d.ts +4 -4
- package/dist/patterns/job-queue/index.js +1 -1
- package/dist/patterns/lens/index.cjs +5 -5
- package/dist/patterns/lens/index.d.cts +6 -6
- package/dist/patterns/lens/index.d.ts +6 -6
- package/dist/patterns/lens/index.js +1 -1
- package/dist/patterns/memory/index.cjs +4 -4
- package/dist/patterns/memory/index.d.cts +4 -4
- package/dist/patterns/memory/index.d.ts +4 -4
- package/dist/patterns/memory/index.js +1 -1
- package/dist/patterns/messaging/index.cjs +4 -4
- package/dist/patterns/messaging/index.d.cts +4 -4
- package/dist/patterns/messaging/index.d.ts +4 -4
- package/dist/patterns/messaging/index.js +1 -1
- package/dist/patterns/orchestration/index.cjs +7 -7
- package/dist/patterns/orchestration/index.d.cts +5 -5
- package/dist/patterns/orchestration/index.d.ts +5 -5
- package/dist/patterns/orchestration/index.js +1 -1
- package/dist/patterns/reactive-layout/index.cjs +1 -1
- package/dist/patterns/reactive-layout/index.d.cts +5 -5
- package/dist/patterns/reactive-layout/index.d.ts +5 -5
- package/dist/patterns/reactive-layout/index.js +1 -1
- package/dist/patterns/reduction/index.cjs +1 -1
- package/dist/patterns/reduction/index.d.cts +4 -4
- package/dist/patterns/reduction/index.d.ts +4 -4
- package/dist/patterns/reduction/index.js +1 -1
- package/dist/patterns/refine-loop/index.cjs +7 -7
- package/dist/patterns/refine-loop/index.d.cts +5 -5
- package/dist/patterns/refine-loop/index.d.ts +5 -5
- package/dist/patterns/refine-loop/index.js +1 -1
- package/dist/patterns/resilient-pipeline/index.cjs +1 -1
- package/dist/patterns/resilient-pipeline/index.d.cts +6 -6
- package/dist/patterns/resilient-pipeline/index.d.ts +6 -6
- package/dist/patterns/resilient-pipeline/index.js +1 -1
- package/dist/patterns/surface/index.cjs +7 -7
- package/dist/patterns/surface/index.d.cts +6 -6
- package/dist/patterns/surface/index.d.ts +6 -6
- package/dist/patterns/surface/index.js +1 -1
- package/dist/{reactive-layout-Bq0rA2Wb.d.ts → reactive-layout-DBJ3Vz-m.d.ts} +2 -2
- package/dist/{reactive-layout-Dhhe54Oj.d.cts → reactive-layout-Dk9AOQb_.d.cts} +2 -2
- package/dist/{reactive-log-5jFeNRmd.d.cts → reactive-log-CWC7jO4J.d.cts} +1 -1
- package/dist/{reactive-log-BOJDCI5x.d.ts → reactive-log-CqaBg8nf.d.ts} +1 -1
- package/dist/{reactive-map-IJIfZxoh.d.cts → reactive-map-Cm89Hk0c.d.cts} +1 -1
- package/dist/{reactive-map-CtRaCddO.d.ts → reactive-map-LjwjcFaW.d.ts} +1 -1
- package/dist/{resilience-IVNDYORD.js → resilience-7UZHSSGC.js} +1 -1
- package/dist/{resilience-Q6Bt_7y0.d.cts → resilience-N_VtLf7W.d.cts} +1 -1
- package/dist/{resilience-CludlzcP.d.ts → resilience-RjDIHZNZ.d.ts} +1 -1
- package/dist/{sugar-BHbAACDG.d.ts → sugar-CQkn_rxB.d.ts} +1 -1
- package/dist/{sugar-CqR6DJ7v.d.cts → sugar-DVEYhR7a.d.cts} +1 -1
- package/dist/{topology-tree-CpSjvIXp.d.cts → topology-tree-BB6oJxMz.d.cts} +1 -1
- package/dist/{topology-tree-DAbCV2Yw.d.ts → topology-tree-CAFOG5S5.d.ts} +1 -1
- package/dist/{types-CdfO2QTt.d.ts → types-B2LfBvNc.d.ts} +16 -2
- package/dist/{types-BgMqbc7N.d.cts → types-Cp_4coR_.d.cts} +16 -2
- package/package.json +1 -1
- package/dist/chunk-2JNT5NDF.js +0 -61
- package/dist/chunk-2RH4QNDQ.js +0 -1
- package/dist/chunk-7AJKUA36.js +0 -1
- package/dist/chunk-LG73TUF4.js +0 -43
- package/dist/chunk-PNTBXOQ6.js +0 -5
- package/dist/chunk-ZWETYYQG.js +0 -1
|
@@ -1,22 +1,22 @@
|
|
|
1
|
-
"use strict";var Qe=Object.defineProperty;var Sn=Object.getOwnPropertyDescriptor;var On=Object.getOwnPropertyNames;var Tn=Object.prototype.hasOwnProperty;var J=(t,e)=>()=>(t&&(e=t(t=0)),e);var Nn=(t,e)=>{for(var n in e)Qe(t,n,{get:e[n],enumerable:!0})},kn=(t,e,n,r)=>{if(e&&typeof e=="object"||typeof e=="function")for(let o of On(e))!Tn.call(t,o)&&o!==n&&Qe(t,o,{get:()=>e[o],enumerable:!(r=Sn(e,o))||r.enumerable});return t};var En=t=>kn(Qe({},"__esModule",{value:!0}),t);function Ot(t,e){let n=new TextEncoder().encode(t.name);if(n.length===0||n.length>255)throw new Error(`encodeEnvelope: codec name "${t.name}" encodes to ${n.length} bytes (must be 1\u2013255)`);let r=t.version;if(!Number.isInteger(r)||r<0||r>65535)throw new Error(`encodeEnvelope: codec.version ${r} out of u16 range (expected integer 0\u201365535)`);let o=2+n.length+2+e.length;if(o>4294967295)throw new Error(`encodeEnvelope: total envelope size ${o} exceeds 2^32-1 bytes (payload ${e.length} bytes)`);let s=new Uint8Array(o),i=0;return s[i++]=et,s[i++]=n.length,s.set(n,i),i+=n.length,s[i++]=r>>>8&255,s[i++]=r&255,s.set(e,i),s}function Tt(t,e){if(t.length<St)throw new Error(`decodeEnvelope: bytes too short (${t.length} < ${St})`);let n=0,r=t[n++];if(r!==et)throw new Error(`decodeEnvelope: unsupported envelope version ${r} (expected ${et})`);let o=t[n++];if(o===0)throw new Error("decodeEnvelope: name_len must be >= 1");if(n+o+2>t.length)throw new Error(`decodeEnvelope: envelope truncated (need ${n+o+2} bytes, have ${t.length})`);let s=new TextDecoder().decode(t.subarray(n,n+o));n+=o;let i=(t[n]<<8|t[n+1])>>>0;n+=2;let a=t.subarray(n),u=e.lookupCodec(s);if(u==null)throw new Error(`decodeEnvelope: codec "${s}" not registered (envelope codec_v=${i})`);return{codec:u,codecVersion:i,payload:a}}function Nt(t){t.registerCodec(Rn)}var Rn,et,St,tt=J(()=>{"use strict";Rn={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)}},et=1,St=4});function ke(t){if(t==null)return ae;let{type:e,id:n,...r}=t;return{type:e??"system",id:n??"",...r}}var ae,nt=J(()=>{"use strict";ae={type:"system",id:""}});function Ee(){return ce>0||ve}function kt(){return ce>0}function _e(t){ce>0?we.push(t):t()}function Re(t){ce+=1;let e=!1;try{t()}catch(n){throw e=!0,n}finally{if(ce-=1,ce===0)if(e){if(!ve){let n=we.splice(0);for(let r of n)try{r()}catch{}re.length=0,se.length=0,ue.length=0}}else An()}}function An(){let t=!ve;t&&(ve=!0);let e=[],n=0;try{for(;re.length>0||se.length>0||ue.length>0||t&&we.length>0;){if(t&&we.length>0){let s=we.splice(0);for(let i of s)try{i()}catch(a){e.push(a)}continue}if(n+=1,n>1e3)throw re.length=0,se.length=0,ue.length=0,new Error("batch drain exceeded 1000 iterations \u2014 likely a reactive cycle");let o=(re.length>0?re:se.length>0?se:ue).splice(0);for(let s of o)try{s()}catch(i){e.push(i)}}}finally{t&&(ve=!1)}if(e.length===1)throw e[0];if(e.length>1)throw new AggregateError(e,"batch drain: multiple callbacks threw")}function Ae(t,e,n){if(e.length===0)return;if(e.length===1){let c=n(e[0][0]);if(c<3||!Ee()){t(e);return}(c>=5?ue:c===4?se:re).push(()=>t(e));return}let r=e.length,o=r,s=r,i=r,a=0;for(;a<r&&n(e[a][0])<3;)a++;for(o=a;a<r&&n(e[a][0])===3;)a++;for(s=a;a<r&&n(e[a][0])===4;)a++;i=a;let u=Ee();if(o>0){let c=e.slice(0,o);t(c)}if(s>o){let c=e.slice(o,s);u?re.push(()=>t(c)):t(c)}if(i>s){let c=e.slice(s,i);u?se.push(()=>t(c)):t(c)}if(r>i){let c=e.slice(i,r);u?ue.push(()=>t(c)):t(c)}}var ce,ve,re,se,ue,we,De=J(()=>{"use strict";ce=0,ve=!1,re=[],se=[],ue=[],we=[]});function de(){return Math.trunc(performance.now()*1e6)}function Ce(){return Date.now()*1e6}var rt=J(()=>{"use strict"});var xe,j,z,X,Z,Q,ee,V,W,I,le,st,Dn,ot,Cn,Mn,it,Et,Rt,At,at,fe=J(()=>{"use strict";xe=Symbol.for("graphrefly/START"),j=Symbol.for("graphrefly/DATA"),z=Symbol.for("graphrefly/DIRTY"),X=Symbol.for("graphrefly/RESOLVED"),Z=Symbol.for("graphrefly/INVALIDATE"),Q=Symbol.for("graphrefly/PAUSE"),ee=Symbol.for("graphrefly/RESUME"),V=Symbol.for("graphrefly/TEARDOWN"),W=Symbol.for("graphrefly/COMPLETE"),I=Symbol.for("graphrefly/ERROR"),le=Object.freeze([z]),st=Object.freeze([X]),Dn=Object.freeze([Z]),ot=Object.freeze([xe]),Cn=Object.freeze([W]),Mn=Object.freeze([V]),it=Object.freeze([le]),Et=Object.freeze([st]),Rt=Object.freeze([Dn]),At=Object.freeze([Cn]),at=Object.freeze([Mn])});function Dt(t){t.registerMessageType(xe,{tier:0,wireCrossing:!1}),t.registerMessageType(z,{tier:1,wireCrossing:!1}),t.registerMessageType(Z,{tier:1,wireCrossing:!1,metaPassthrough:!1}),t.registerMessageType(Q,{tier:2,wireCrossing:!1}),t.registerMessageType(ee,{tier:2,wireCrossing:!1}),t.registerMessageType(j,{tier:3,wireCrossing:!0}),t.registerMessageType(X,{tier:3,wireCrossing:!0}),t.registerMessageType(W,{tier:4,wireCrossing:!0,metaPassthrough:!1}),t.registerMessageType(I,{tier:4,wireCrossing:!0,metaPassthrough:!1}),t.registerMessageType(V,{tier:5,wireCrossing:!0,metaPassthrough:!1})}var Me,Ct=J(()=>{"use strict";fe();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 ct(t){let e=Gn.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 Y,Gn,Ge=J(()=>{"use strict";Y=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}},Gn=["human","llm","wallet","system"]});function ut(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(ut);if(typeof t=="object"&&t!==null){let e={};for(let n of Object.keys(t).sort())e[n]=ut(t[n]);return e}return null}function In(t){let e=Ln.encode(t),n=e.length,r=n*8,o=n+9+63&-64,s=new Uint8Array(o);s.set(e),s[n]=128;let i=new DataView(s.buffer);i.setUint32(o-4,r>>>0,!1),i.setUint32(o-8,Math.floor(r/4294967296)>>>0,!1);let a=1779033703,u=3144134277,c=1013904242,l=2773480762,g=1359893119,p=2600822924,f=528734635,d=1541459225,b=new Uint32Array(64),m=(h,v)=>h>>>v|h<<32-v;for(let h=0;h<o;h+=64){for(let S=0;S<16;S++)b[S]=i.getUint32(h+S*4,!1);for(let S=16;S<64;S++){let E=b[S-15],N=b[S-2],D=m(E,7)^m(E,18)^E>>>3,L=m(N,17)^m(N,19)^N>>>10;b[S]=b[S-16]+D+b[S-7]+L>>>0}let v=a,w=u,_=c,T=l,x=g,O=p,k=f,R=d;for(let S=0;S<64;S++){let E=m(x,6)^m(x,11)^m(x,25),N=x&O^~x&k,D=R+E+N+$n[S]+b[S]>>>0,L=m(v,2)^m(v,13)^m(v,22),M=v&w^v&_^w&_,B=L+M>>>0;R=k,k=O,O=x,x=T+D>>>0,T=_,_=w,w=v,v=D+B>>>0}a=a+v>>>0,u=u+w>>>0,c=c+_>>>0,l=l+T>>>0,g=g+x>>>0,p=p+O>>>0,f=f+k>>>0,d=d+R>>>0}let y=h=>h.toString(16).padStart(8,"0");return y(a)+y(u)+y(c)+y(l)+y(g)+y(p)+y(f)+y(d)}function dt(t){let e=ut(t??null),n=JSON.stringify(e);return In(n).slice(0,16)}function Pn(){let t=globalThis.crypto;if(t?.randomUUID)return t.randomUUID();let e=()=>Math.floor(Math.random()*4294967296).toString(16).padStart(8,"0"),n=e()+e()+e()+e();return`${n.slice(0,8)}-${n.slice(8,12)}-4${n.slice(13,16)}-${(parseInt(n.slice(16,17),16)&3|8).toString(16)}${n.slice(17,20)}-${n.slice(20,32)}`}function lt(t,e,n){let r=n?.id??Pn();if(t===0)return{id:r,version:0};let s=(n?.hash??dt)(e);return{id:r,version:0,cid:s,prev:null}}function Mt(t,e,n){t.version+=1,"cid"in t&&(t.prev=t.cid,t.cid=n(e))}var $n,Ln,Gt=J(()=>{"use strict";$n=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]),Ln=new TextEncoder});function It(t){return{node:t,unsub:null,prevData:void 0,dirty:!1,involvedThisWave:!1,dataBatch:[],terminal:void 0}}function ft(t){t.prevData=void 0,t.dirty=!1,t.involvedThisWave=!1,t.dataBatch.length=0,t.terminal=void 0}function $e(t){return t.length===0?t:typeof t[0]=="symbol"?[t]:t}function oe(t,e,n){let r=Pt(t)?t:[],o=typeof t=="function"?t:typeof e=="function"?e:void 0,s={};return Pt(t)?s=(pt(e)?e:n)??{}:pt(t)?s=t:s=(pt(e)?e:n)??{},new P(r,o,s)}var $t,Lt,Fn,jn,pe,P,Pt,pt,he=J(()=>{"use strict";tt();nt();De();rt();Ct();Ge();fe();Gt();$t=()=>{},Lt=100;Fn=(t,e,n,r)=>{n.direction==="down-in"&&t._onDepMessage(n.depIndex,e)},jn=(t,e,n,r)=>{let o=t;if(o._status==="completed"||o._status==="errored")return;let s=o._cached,i=s===void 0?[ot]:[ot,[j,s]];o._status==="dirty"&&i.push(le),Ae(e,i,o._config.tierOf)},pe=new Me({onMessage:Fn,onSubscribe:jn});Dt(pe);Nt(pe);P=class t{_optsName;_describeKind;meta;_hasMeta;_config;_deps;_sinks=null;_sinkCount=0;_cached;_status;_cleanup;_store={};_waveHasNewData=!1;_hasNewTerminal=!1;_hasCalledFnOnce=!1;_paused=!1;_pendingWave=!1;_isExecutingFn=!1;_pendingRerun=!1;_rerunDepth=0;_dirtyDepCount=0;_batchPendingMessages=null;_pauseLocks=null;_pauseBuffer=null;_fn;_equals;_resubscribable;_resetOnTeardown;_autoComplete;_autoError;_pausable;_partial;_guard;_extraGuards;_hashFn;_versioning;_versioningLevel;_lastMutation;_inspectorHooks;_actions;constructor(e,n,r){this._config=r.config??pe,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??dt;let o=r.versioning??this._config.defaultVersioning;this._versioningLevel=o,this._versioning=o!=null?lt(o,this._cached===void 0?void 0:this._cached,{id:r.versioningId,hash:this._hashFn}):void 0,this._deps=e.map(It);let s={};for(let[a,u]of Object.entries(r.meta??{})){let c={initial:u,name:`${r.name??"node"}:meta:${a}`,describeKind:"state",config:this._config};r.guard!=null&&(c.guard=r.guard),s[a]=new t([],void 0,c)}Object.freeze(s),this.meta=s,this._hasMeta=Object.keys(s).length>0;let i=this;this._actions={emit(a){i._emit([[j,a]])},down(a){i._emit($e(a))},up(a){i._emitUp($e(a))}},this.down=this.down.bind(this),this.up=this.up.bind(this)}get _isTerminal(){return this._status==="completed"||this._status==="errored"}get name(){return this._optsName}get status(){return this._status}get cache(){return this._cached===void 0?void 0:this._cached}get lastMutation(){return this._lastMutation}get v(){return this._versioning}hasGuard(){return this._guard!=null}_applyVersioning(e,n){if(this._isExecutingFn)throw new Error(`Node "${this.name}": _applyVersioning cannot run mid-fn \u2014 call it outside of \`_execFn\` (typically at graph setup time before the first subscribe).`);let r=this._versioningLevel;if(r!=null&&e<=r)return;let o=n?.hash??this._hashFn;o!==this._hashFn&&(this._hashFn=o);let s=this._cached===void 0?void 0:this._cached,i=this._versioning,a=i?.id??n?.id,u=i?.version??0,c=lt(e,s,{id:a,hash:o});c.version=u,this._versioning=c,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=ke(e);if(this._guard!=null&&!this._guard(n,"observe"))return!1;if(this._extraGuards!=null){for(let r of this._extraGuards)if(!r(n,"observe"))return!1}return!0}_checkGuard(e){if(e?.internal)return;let n=this._guard!=null||this._extraGuards!=null,r=e?.actor!=null;if(!n&&!r)return;let o=ke(e?.actor),s=e?.delivery==="signal"?"signal":"write";if(this._guard!=null&&!this._guard(o,s))throw new Y({actor:o,action:s,nodeName:this.name});if(this._extraGuards!=null){for(let i of this._extraGuards)if(!i(o,s))throw new Y({actor:o,action:s,nodeName:this.name})}this._lastMutation={actor:o,timestamp_ns:Ce()}}down(e,n){let r=$e(e);r.length!==0&&(this._checkGuard(n),this._emit(r))}emit(e,n){this._checkGuard(n),this._emit([[j,e]])}up(e,n){if(this._deps.length===0)return;let r=$e(e);if(r.length===0)return;this._checkGuard(n);let o=n??{internal:!0};this._validateUpTiers(r);for(let s of this._deps)s.node.up?.(r,o)}_emitUp(e){if(this._deps.length!==0&&e.length!==0){this._validateUpTiers(e);for(let n of this._deps)n.node.up?.(e,{internal:!0})}}_validateUpTiers(e){let n=this._config.tierOf;for(let r of e){let o=n(r[0]);if(o===3||o===4)throw new Error(`Node "${this.name}": tier-${o} messages cannot flow up \u2014 DATA/RESOLVED/COMPLETE/ERROR are downstream-only. Use \`down(...)\` for value delivery; \`up(...)\` is for control signals (DIRTY, INVALIDATE, PAUSE, RESUME, TEARDOWN).`)}}subscribe(e,n){if(n!=null&&this._guard!=null){let u=ke(n);if(!this._guard(u,"observe"))throw new Y({actor:u,action:"observe",nodeName:this.name})}let o=this._isTerminal&&this._resubscribable;if(o){this._cached=void 0,this._status="sentinel",this._store={},this._hasCalledFnOnce=!1,this._waveHasNewData=!1,this._hasNewTerminal=!1,this._paused=!1,this._pendingWave=!1,this._pendingRerun=!1,this._isExecutingFn=!1,this._rerunDepth=0,this._dirtyDepCount=0,this._pauseLocks=null,this._pauseBuffer=null;for(let u of this._deps)ft(u);if(this._partial===!1){for(let u of this._deps)if(u.prevData!==void 0||u.dataBatch.length!==0||u.terminal!==void 0||u.dirty)throw new Error(`resubscribable-reset invariant: DepRecord not fully reset for node ${this._optsName??"(anonymous)"}`)}}this._sinkCount+=1;let s;try{s=this._config.onSubscribe(this,e,{sinkCount:this._sinkCount,afterTerminalReset:o},this._actions)}catch(u){throw this._sinkCount-=1,u}this._sinks==null?this._sinks=e:typeof this._sinks=="function"?this._sinks=new Set([this._sinks,e]):this._sinks.add(e);let i=this._isTerminal;if(this._sinkCount===1&&!i)try{this._activate()}catch(u){if(this._sinkCount-=1,this._removeSink(e),this._sinkCount===0&&(this._status="sentinel"),typeof s=="function")try{s()}catch{}throw u}this._status==="sentinel"&&this._cached===void 0&&(this._status="pending");let a=!1;return()=>{a||(a=!0,this._sinkCount-=1,this._removeSink(e),typeof s=="function"&&s(),this._sinks==null&&this._deactivate())}}_removeSink(e){if(this._sinks===e)this._sinks=null;else if(this._sinks!=null&&typeof this._sinks!="function")if(this._sinks.delete(e),this._sinks.size===1){let[n]=this._sinks;this._sinks=n}else this._sinks.size===0&&(this._sinks=null)}_activate(){if(this._deps.length===0){this._fn&&this._execFn();return}this._dirtyDepCount=0;let e=this._deps.length,n=0;try{for(let r=0;r<e;r++){let o=r,s=this._deps[r];s.unsub=$t,s.unsub=s.node.subscribe(i=>{if(s.unsub===null)return;let a=this._config.tierOf,u=!1;for(let c of i)a(c[0])>=3&&(u=!0),this._config.onMessage(this,c,{direction:"down-in",depIndex:o},this._actions);u&&this._maybeRunFnOnSettlement()}),n++}}catch(r){this._deps[n].unsub=null;for(let o=0;o<n;o++){let s=this._deps[o];if(s.unsub!=null){let i=s.unsub;s.unsub=null;try{i()}catch{}ft(s)}}throw this._dirtyDepCount=0,r}}_addDep(e){for(let o=0;o<this._deps.length;o++)if(this._deps[o].node===e)return o;let n=this._deps.length,r=It(e);if(this._deps.push(r),this._sinks==null)return n;r.dirty=!0,this._dirtyDepCount++,this._status!=="dirty"&&this._emit(it),r.unsub=$t;try{r.unsub=e.subscribe(o=>{if(r.unsub===null)return;let s=this._config.tierOf,i=!1;for(let a of o)s(a[0])>=3&&(i=!0),this._config.onMessage(this,a,{direction:"down-in",depIndex:n},this._actions);i&&this._maybeRunFnOnSettlement()})}catch(o){throw r.unsub=null,this._deps.pop(),this._dirtyDepCount--,o}return n}_deactivate(e=!1){let n=this._cleanup;if(this._cleanup=void 0,typeof n=="function")try{n()}catch(r){this._emit([[I,this._wrapFnError("cleanup threw",r)]])}else if(n!=null&&typeof n=="object"){let r=n.deactivate;if(typeof r=="function")try{r()}catch(o){this._emit([[I,this._wrapFnError("cleanup.deactivate threw",o)]])}}for(let r of this._deps){if(r.unsub!=null){let o=r.unsub;r.unsub=null;try{o()}catch{}}ft(r)}this._waveHasNewData=!1,this._hasNewTerminal=!1,this._hasCalledFnOnce=!1,this._paused=!1,this._pendingWave=!1,this._pendingRerun=!1,this._rerunDepth=0,this._store={},this._dirtyDepCount=0,this._pauseLocks=null,this._pauseBuffer=null,this._fn!=null&&(this._cached=void 0),e||(this._fn!=null||this._deps.length>0)&&(!this._isTerminal||this._resubscribable)&&(this._status="sentinel")}_onDepMessage(e,n){let r=this._deps[e],o=n[0];if(this._inspectorHooks!=null){let s={kind:"dep_message",depIndex:e,message:n};for(let i of this._inspectorHooks)i(s)}if(o!==xe){if(o===z){this._depDirtied(r);return}if(o===Z){if(this._depInvalidated(r),this._cached===void 0)return;this._emit(Rt);return}if(o===Q||o===ee){this._emit([n]);return}if(o===V){this._emit(at);return}if(o===j)this._depSettledAsData(r,n[1]);else if(o===X)this._depSettledAsResolved(r);else if(o===W)this._depSettledAsTerminal(r,!0);else if(o===I)this._depSettledAsTerminal(r,n[1]);else{this._emit([n]);return}if(!this._fn){(o===j||o===X)&&this._emit([n]),(o===W||o===I)&&this._maybeAutoTerminalAfterWave();return}}}_depDirtied(e){e.dirty||(e.dirty=!0,e.involvedThisWave=!0,this._dirtyDepCount++,this._status!=="dirty"&&this._emit(it))}_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(Et),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([[I,e.terminal]]);return}this._autoComplete&&this._deps.every(n=>n.terminal!==void 0)&&this._emit(At)}_execFn(){if(!this._fn||this._isTerminal&&!this._resubscribable)return;if(this._isExecutingFn){this._pendingRerun=!0;return}let e=this._cleanup;if(typeof e=="function"){this._cleanup=void 0;try{e()}catch(i){this._emit([[I,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([[I,this._wrapFnError("cleanup.beforeRun threw",a)]]);return}}}let n=this._deps.map(i=>i.involvedThisWave?i.dataBatch.length>0?[...i.dataBatch]:[]:void 0),r=this._deps.map(i=>i.prevData);for(let i=0;i<this._deps.length;i++){let a=n[i];a!=null&&a.length>0&&(this._deps[i].prevData=a[a.length-1])}let o=this._deps.map(i=>i.terminal),s={prevData:r,terminalDeps:o,store:this._store};if(this._hasCalledFnOnce=!0,this._clearWaveFlags(),this._inspectorHooks!=null){let i={kind:"run",batchData:n,prevData:r};for(let a of this._inspectorHooks)a(i)}this._isExecutingFn=!0;try{let i=this._fn(n,this._actions,s);if(typeof i=="function")this._cleanup=i;else if(i!=null&&typeof i=="object"){let a=i;(typeof a.beforeRun=="function"||typeof a.deactivate=="function"||typeof a.invalidate=="function")&&(this._cleanup=i)}}catch(i){this._emit([[I,this._wrapFnError("fn threw",i)]])}finally{this._isExecutingFn=!1,this._pendingRerun?(this._pendingRerun=!1,this._rerunDepth+=1,this._rerunDepth>Lt?(this._rerunDepth=0,this._emit([[I,new Error(`Node "${this.name}": _pendingRerun depth exceeded ${Lt} \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"?[le,e[0]]:e;let r=!0,o=!1,s=!1,i=-1;for(let u of e){let c=n(u[0]);c<i&&(r=!1),c===3&&(o=!0),u[0]===z&&(s=!0),i=c}let a=e;if(!r){let u=e.map((c,l)=>({m:c,i:l,tier:n(c[0])}));u.sort((c,l)=>c.tier-l.tier||c.i-l.i),a=u.map(c=>c.m)}if(o&&!s&&this._status!=="dirty"){let u=0;for(;u<a.length&&n(a[u][0])===0;)u++;return u===0?[le,...a]:[...a.slice(0,u),le,...a.slice(u)]}return a}_emit(e){if(e.length===0)return;for(let a=0;a<e.length;a++){let u=e[a];if(u[0]===I&&u[1]===void 0)throw new TypeError('[ERROR, payload] requires a non-undefined payload (spec \xA71.2). Pass an Error object or domain tag instead \u2014 e.g. node.down([[ERROR, new Error("reason")]])')}let n=e;if(this._isTerminal&&!this._resubscribable){let a=e.filter(u=>u[0]===V||u[0]===Z);if(a.length===0)return;n=a}n=this._frameBatch(n);let o=null;for(let a=0;a<n.length;a++){let u=n[a],c=u[0];if(c!==Q&&c!==ee){o?.push(u);continue}if(u.length<2)throw new Error(`Node "${this.name}": [[${c===Q?"PAUSE":"RESUME"}]] must carry a lockId payload \u2014 bare PAUSE/RESUME is a protocol violation (C0 rule). Use \`[[PAUSE, lockId]]\` / \`[[RESUME, lockId]]\`.`);let l=!0;if(this._pausable!==!1){let g=u[1];if(c===Q)this._pauseLocks==null&&(this._pauseLocks=new Set),this._pauseLocks.add(g),this._paused=!0,this._pausable==="resumeAll"&&this._pauseBuffer==null&&(this._pauseBuffer=[]);else if(this._pauseLocks==null||!this._pauseLocks.has(g))l=!1;else if(this._pauseLocks.delete(g),this._pauseLocks.size===0){if(this._paused=!1,this._pauseBuffer!=null&&this._pauseBuffer.length>0){let p=this._pauseBuffer;this._pauseBuffer=[],this._emit(p)}this._pendingWave&&(this._pendingWave=!1,this._maybeRunFnOnSettlement())}}l?o?.push(u):o==null&&(o=n.slice(0,a))}if(o!=null){if(o.length===0)return;n=o}if(this._hasMeta&&n.some(a=>a[0]===V))for(let a of Object.keys(this.meta))try{this.meta[a]._emit(at)}catch{}let{finalMessages:s,equalsError:i}=this._updateState(n);if(s.length>0&&this._config.inspectorEnabled){let a=this._config.globalInspector;if(a!=null)try{a({kind:"emit",node:this,messages:s})}catch{}}if(s.length>0)if(this._paused&&this._pausable==="resumeAll"&&this._pauseBuffer!=null){let a=this._config.tierOf,u=[];for(let c of s)a(c[0])===3?this._pauseBuffer.push(c):u.push(c);u.length>0&&this._dispatchOrAccumulate(u)}else this._dispatchOrAccumulate(s);i!=null&&this._emit([[I,i]])}_updateState(e){let n=this._config.tierOf,r,o,s=-1,i=0;for(let l of e)n(l[0])===3&&i++;let a=i<=1,u=-1;if(this._versioning!=null&&i>1){for(let l=e.length-1;l>=0;l--)if(e[l][0]===j){u=l;break}}for(let l=0;l<e.length;l++){let g=e[l],p=g[0];if(p===j){if(g.length>=2){let f=!1;if(a&&this._cached!==void 0)try{f=this._equals(this._cached,g[1])}catch(d){o=this._wrapFnError("equals threw",d),s=l;break}if(f){r==null&&(r=e.slice(0,l)),r.push(st),this._status="resolved";continue}this._cached=g[1],this._versioning!=null&&(u<0||l===u)&&Mt(this._versioning,g[1],this._hashFn)}this._status="settled",r?.push(g)}else if(r?.push(g),p===z)this._status="dirty";else if(p===X)this._status="resolved";else if(p===W)this._status="completed";else if(p===I)this._status="errored";else if(p===Z){this._cached=void 0,this._status="dirty";let f=this._cleanup;if(typeof f=="function"){this._cleanup=void 0;try{f()}catch{}}else if(f!=null&&typeof f=="object"){let d=f.invalidate;if(typeof d=="function")try{d()}catch{}}}else p===V&&(this._resetOnTeardown&&(this._cached=void 0),this._deactivate(!0),this._status="sentinel")}let c=s>=0?r??e.slice(0,s):r??e;return o!=null?{finalMessages:c,equalsError:o}:{finalMessages:c}}_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(kt()){this._batchPendingMessages===null&&(this._batchPendingMessages=[],_e(()=>this._flushBatchPending()));for(let n of e)this._batchPendingMessages.push(n);return}Ae(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);Ae(this._deliverToSinks,n,this._config.tierOf)}},Pt=t=>Array.isArray(t),pt=t=>typeof t=="object"&&t!=null&&!Array.isArray(t)});function te(t,e){return oe([],{...e,initial:t})}function Se(t,e){return oe((r,o,s)=>t(o,s)??void 0,{describeKind:"producer",...e})}function ie(t,e,n){return oe(t,(o,s,i)=>{let a=o.map((u,c)=>u!=null&&u.length>0?u.at(-1):i.prevData[c]);s.emit(e(a,i))},{describeKind:"derived",...n})}function Le(t,e,n){return oe(t,(o,s,i)=>{let a=o.map((u,c)=>u!=null&&u.length>0?u.at(-1):i.prevData[c]);return e(a,s,i)??void 0},{describeKind:"effect",...n})}var Ie=J(()=>{"use strict";he()});function ge(t){return t.subscribe(()=>{})}var gt=J(()=>{"use strict"});var Fe,Ft=J(()=>{"use strict";Fe=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 Ur={};Nn(Ur,{compileSpec:()=>Br,decompileGraph:()=>Vr,extractFnFactory:()=>bn,extractSourceFactory:()=>yn,generateCatalogPrompt:()=>vn,isRichFnEntry:()=>Te,isRichSourceEntry:()=>wt,llmCompose:()=>Wr,llmRefine:()=>xn,specDiff:()=>zr,validateSpec:()=>qe,validateSpecAgainstCatalog:()=>_t});module.exports=En(Ur);Ie();nt();De();rt();Ge();fe();Ge();he();function Pe(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 Bn(t){return t._describeKind!=null?t._describeKind:t._deps.length>0?"derived":t._fn!=null?"producer":"state"}function Hn(t){let e={};for(let[n,r]of Object.entries(t.meta))try{e[n]=r.cache}catch{}return e}function ht(t,e){let n=e==null,r=!n&&e!=null?[...e].filter(c=>c.startsWith("meta.")).map(c=>c.slice(5)):null,o=n||e.has("meta")||r!=null&&r.length>0,s="state",i=[];t instanceof P&&(s=Bn(t),i=t._deps.map(c=>c.node.name??""));let a={type:s,deps:i};(n||e.has("status"))&&(a.status=t.status);let u=t instanceof P?t._guard:void 0;if(o){let c={...Hn(t)};if(u!=null&&c.access===void 0&&(c.access=ct(u)),r!=null&&r.length>0&&!e.has("meta")){let l={};for(let g of r)g in c&&(l[g]=c[g]);a.meta=l}else a.meta=c}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 c={id:t.v.id,version:t.v.version};"cid"in t.v&&(c.cid=t.v.cid,c.prev=t.v.prev),a.v=c}return(n||e.has("guard"))&&u!=null&&(a.guard=ct(u)),(n||e.has("lastMutation"))&&t.lastMutation!=null&&(a.lastMutation=t.lastMutation),a}he();Ie();gt();Ft();var Oe=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}};tt();function mt(t){return t>=768&&t<=879||t>=1155&&t<=1161||t>=1425&&t<=1469||t>=1552&&t<=1562||t>=1611&&t<=1631||t>=1648&&t===1648||t>=1750&&t<=1756||t>=1759&&t<=1764||t>=1767&&t<=1768||t>=1770&&t<=1773||t>=1840&&t<=1866||t>=1958&&t<=1968||t>=2304&&t<=2307||t>=2362&&t<=2383||t>=2385&&t<=2391||t>=2402&&t<=2403||t>=2433&&t<=2435||t>=2492&&t<=2509||t>=2561&&t<=2563||t>=2620&&t<=2641||t>=2672&&t<=2673||t>=2677&&t===2677||t>=3633&&t===3633||t>=3636&&t<=3642||t>=3655&&t<=3662||t>=3761&&t===3761||t>=3764&&t<=3772||t>=3784&&t<=3790||t>=7616&&t<=7679||t>=8400&&t<=8447||t>=65024&&t<=65039||t>=65056&&t<=65071||t===8205?0:t>=4352&&t<=4447||t>=8986&&t<=8987||t>=9001&&t<=9002||t>=9193&&t<=9203||t>=9208&&t<=9210||t>=9725&&t<=9726||t>=9748&&t<=9749||t>=9800&&t<=9811||t===9855||t===9875||t===9889||t>=9898&&t<=9899||t>=9917&&t<=9918||t>=9924&&t<=9925||t===9934||t===9940||t===9962||t>=9970&&t<=9971||t===9973||t===9978||t===9981||t===9986||t===9989||t>=9992&&t<=9997||t===9999||t>=10067&&t<=10069||t===10071||t>=10133&&t<=10135||t===10160||t===10175||t>=10548&&t<=10549||t>=11013&&t<=11015||t>=11035&&t<=11036||t===11088||t===11093||t>=11904&&t<=12350||t>=12352&&t<=12447||t>=12448&&t<=12543||t>=12549&&t<=12591||t>=12593&&t<=12686||t>=12688&&t<=12771||t>=12784&&t<=12830||t>=12832&&t<=12871||t>=12880&&t<=19903||t>=19968&&t<=40959||t>=43360&&t<=43388||t>=44032&&t<=55203||t>=63744&&t<=64255||t>=65040&&t<=65049||t>=65072&&t<=65131||t>=65281&&t<=65376||t>=65504&&t<=65510||t>=126980&&t===126980||t===127183||t>=127344&&t<=127345||t===127358||t===127359||t===127374||t>=127377&&t<=127386||t>=127456&&t<=127487||t>=127488&&t<=127490||t===127514||t===127535||t>=127538&&t<=127546||t>=127568&&t<=127569||t>=127744&&t<=129535||t>=129536&&t<=129791||t>=129792&&t<=130047||t>=131072&&t<=196605||t>=196608&&t<=262141?2:1}function je(t){let e=0;for(let n of t)e+=mt(n.codePointAt(0));return e}function jt(t,e){if(e<=0)return"";let n=0,r="";for(let o of t){let s=mt(o.codePointAt(0));if(n+s>e){if(e<=1)return"\u2026";for(;n+1>e&&r.length>0;){let i=[...r].pop();r=r.slice(0,-i.length),n-=mt(i.codePointAt(0))}return`${r}\u2026`}r+=o,n+=s}return r}var Vn={horizontal:"\u2500",vertical:"\u2502",cornerTL:"\u250C",cornerTR:"\u2510",cornerBL:"\u2514",cornerBR:"\u2518",tDown:"\u252C",tUp:"\u2534",tRight:"\u251C",tLeft:"\u2524",cross:"\u253C",arrowRight:"\u25B6",arrowDown:"\u25BC",arrowLeft:"\u25C0",arrowUp:"\u25B2",boxTL:"\u250C",boxTR:"\u2510",boxBL:"\u2514",boxBR:"\u2518",boxH:"\u2500",boxV:"\u2502"},zn={horizontal:"-",vertical:"|",cornerTL:"+",cornerTR:"+",cornerBL:"+",cornerBR:"+",tDown:"+",tUp:"+",tRight:"+",tLeft:"+",cross:"+",arrowRight:">",arrowDown:"v",arrowLeft:"<",arrowUp:"^",boxTL:"+",boxTR:"+",boxBL:"+",boxBR:"+",boxH:"-",boxV:"|"};function zt(t,e){let n=e.charset==="ascii"?zn:Vn,r=t.width,o=t.height,s=Array.from({length:o},()=>Array.from({length:r},()=>" ")),i=Array.from({length:o},()=>Array.from({length:r},()=>"empty"));for(let a of t.edges)Un(s,i,n,a);for(let a of t.boxes)Wn(s,i,n,a,e.labelOf(a.id));return s.map(a=>Yn(a.join(""))).join(`
|
|
2
|
-
`)}function Wn(t,e,n,r,o){let{x:s,y:i,w:a,h:u}=r;if(a<2||u<2){u>0&&Bt(t,e,s,i,a,o);return}ne(t,e,s,i,n.boxTL);for(let l=s+1;l<s+a-1;l+=1)ne(t,e,l,i,n.boxH);ne(t,e,s+a-1,i,n.boxTR);for(let l=i+1;l<i+u-1;l+=1){ne(t,e,s,l,n.boxV);for(let g=s+1;g<s+a-1;g+=1)Wt(t,e,g,l," ","empty");ne(t,e,s+a-1,l,n.boxV)}ne(t,e,s,i+u-1,n.boxBL);for(let l=s+1;l<s+a-1;l+=1)ne(t,e,l,i+u-1,n.boxH);ne(t,e,s+a-1,i+u-1,n.boxBR);let c=i+Math.floor(u/2);Bt(t,e,s+1,c,a-2,o)}function ne(t,e,n,r,o){Wt(t,e,n,r,o,o===" "?"empty":o==="\u2500"||o==="-"?"boxH":o==="\u2502"||o==="|"?"boxV":"boxCorner")}function Wt(t,e,n,r,o,s){if(r<0||r>=t.length)return;let i=t[r];n<0||n>=i.length||(i[n]=o,e[r][n]=s)}function Bt(t,e,n,r,o,s){if(r<0||r>=t.length)return;let i=n,a=o;for(let u of s){let c=je(u);if(c!==0){if(a<c)break;i>=0&&i<t[r].length&&(t[r][i]=u,e[r][i]="label",c===2&&i+1<t[r].length&&(t[r][i+1]="",e[r][i+1]="label")),i+=c,a-=c}}for(;a>0;)i>=0&&i<t[r].length&&(t[r][i]=" ",e[r][i]="empty"),i+=1,a-=1}function Un(t,e,n,r){let o=r.points;if(o.length<2)return;for(let u=0;u+1<o.length;u+=1)Kn(t,e,n,o[u],o[u+1]);for(let u=1;u+1<o.length;u+=1){let c=o[u-1],l=o[u],g=o[u+1],p=qn(c,l,g,n);p&&Vt(t,e,l.x,l.y,p,"edgeCorner")}let s=o[o.length-1],i=o[o.length-2],a=Jn(i,s,n);a&&Vt(t,e,s.x,s.y,a,"arrow")}function Kn(t,e,n,r,o){if(!(r.x===o.x&&r.y===o.y)){if(r.y===o.y){let s=r.y,i=Math.min(r.x,o.x),a=Math.max(r.x,o.x);for(let u=i;u<=a;u+=1)Ht(t,e,u,s,n,"h")}else if(r.x===o.x){let s=r.x,i=Math.min(r.y,o.y),a=Math.max(r.y,o.y);for(let u=i;u<=a;u+=1)Ht(t,e,s,u,n,"v")}}}function Ht(t,e,n,r,o,s){if(r<0||r>=t.length)return;let i=t[r];if(n<0||n>=i.length)return;let a=e[r][n];if(!(a==="boxH"||a==="boxV"||a==="boxCorner"||a==="label")){if(a==="empty"){i[n]=s==="h"?o.horizontal:o.vertical,e[r][n]=s==="h"?"edgeH":"edgeV";return}if(a==="edgeH"&&s==="v"){i[n]=o.cross,e[r][n]="edgeCorner";return}if(a==="edgeV"&&s==="h"){i[n]=o.cross,e[r][n]="edgeCorner";return}}}function Vt(t,e,n,r,o,s){if(r<0||r>=t.length)return;let i=t[r];if(n<0||n>=i.length)return;let a=e[r][n];a==="boxH"||a==="boxV"||a==="boxCorner"||a==="label"||(i[n]=o,e[r][n]=s)}function qn(t,e,n,r){let o=t.y===e.y,s=e.y===n.y;if(o===s)return;if(o){let u=t.x<e.x,c=n.y>e.y;return u&&c?r.cornerTR:u&&!c?r.cornerBR:!u&&c?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 Jn(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 Yn(t){let e=t.length;for(;e>0&&t.charCodeAt(e-1)===32;)e-=1;return t.slice(0,e)}function qt(t){let e=Xn(t);Zn(e),Qn(e),er(e),tr(e,t);let n=sr(e,t),{width:r,height:o}=ir(e),s=[];for(let i of e.layers)for(let a of i)a.isVirtual||s.push({id:a.id,layer:a.layer,order:a.order,x:a.x,y:a.y,w:a.w,h:a.h});return{boxes:s,edges:n,width:r,height:o}}function Xn(t){let e=new Map;for(let o of t.nodes)e.set(o,{id:o,isVirtual:!1,layer:-1,order:0,x:0,y:0,w:t.widthCells(o),h:t.heightCells(o),in:[],out:[]});let n=[],r=0;for(let o of t.edges){if(o.from===o.to)continue;let s=e.get(o.from),i=e.get(o.to);if(!s||!i)continue;let a={chainId:r++,chainFrom:o.from,chainTo:o.to,fromId:o.from,toId:o.to,hopIndex:0,chainLen:1};s.out.push(a),i.in.push(a),n.push(a)}return{nodes:e,layers:[],hops:n}}function Zn(t){let e=new Map;for(let s of t.nodes.values())e.set(s.id,s.in.length);let n=[];for(let s of t.nodes.values())(e.get(s.id)??0)===0&&(s.layer=0,n.push(s));let r=new Set,o=0;for(;o<n.length;){let s=n[o++];if(!r.has(s.id)){r.add(s.id);for(let i of s.out){let a=t.nodes.get(i.toId);a.layer=Math.max(a.layer,s.layer+1);let u=(e.get(a.id)??0)-1;e.set(a.id,u),u<=0&&n.push(a)}}}for(let s of t.nodes.values())s.layer<0&&(s.layer=0)}function Qn(t){let e=Math.max(0,...Array.from(t.nodes.values(),s=>s.layer)),n=Array.from({length:e+1},()=>[]);for(let s of t.nodes.values())n[s.layer].push(s);let r=[],o=0;for(let s of t.hops){let i=t.nodes.get(s.fromId),a=t.nodes.get(s.toId),u=a.layer-i.layer;if(u<=0){i.out=i.out.filter(g=>g!==s),a.in=a.in.filter(g=>g!==s);continue}if(u===1){s.hopIndex=0,s.chainLen=1,r.push(s);continue}i.out=i.out.filter(g=>g!==s),a.in=a.in.filter(g=>g!==s);let c=i;for(let g=1;g<u;g+=1){let p=`__virt_${o++}__`,f={id:p,isVirtual:!0,layer:i.layer+g,order:0,x:0,y:0,w:0,h:1,in:[],out:[]};t.nodes.set(p,f),n[f.layer].push(f);let d={chainId:s.chainId,chainFrom:s.chainFrom,chainTo:s.chainTo,fromId:c.id,toId:p,hopIndex:g-1,chainLen:u};c.out.push(d),f.in.push(d),r.push(d),c=f}let l={chainId:s.chainId,chainFrom:s.chainFrom,chainTo:s.chainTo,fromId:c.id,toId:a.id,hopIndex:u-1,chainLen:u};c.out.push(l),a.in.push(l),r.push(l)}for(let s of n)for(let i=0;i<s.length;i+=1)s[i].order=i;t.layers=n,t.hops=r}function er(t){for(let n=0;n<4;n+=1){for(let r=1;r<t.layers.length;r+=1)Ut(t,t.layers[r],"in"),Be(t.layers[r]);for(let r=t.layers.length-2;r>=0;r-=1)Ut(t,t.layers[r],"out"),Be(t.layers[r])}for(let n=0;n<2;n+=1){let r=!1;for(let o=1;o<t.layers.length;o+=1){let s=t.layers[o];for(let i=0;i+1<s.length;i+=1){let a=Kt(t,s[i],s[i+1],"in");[s[i],s[i+1]]=[s[i+1],s[i]],Be(s),Kt(t,s[i],s[i+1],"in")<a?r=!0:([s[i],s[i+1]]=[s[i+1],s[i]],Be(s))}}if(!r)break}}function Ut(t,e,n){let r=new Map;for(let o of e){let s=n==="in"?o.in:o.out;if(s.length===0){r.set(o.id,o.order);continue}let i=0,a=0;for(let u of s){let c=t.nodes.get(n==="in"?u.fromId:u.toId);c&&(i+=c.order,a+=1)}r.set(o.id,a===0?o.order:i/a)}e.sort((o,s)=>{let i=r.get(o.id),a=r.get(s.id);return i!==a?i-a:o.order-s.order})}function Be(t){for(let e=0;e<t.length;e+=1)t[e].order=e}function Kt(t,e,n,r){let o=r==="in"?e.in:e.out,s=r==="in"?n.in:n.out,i=0;for(let a of o)for(let u of s){let c=t.nodes.get(r==="in"?a.fromId:a.toId)?.order??0,l=t.nodes.get(r==="in"?u.fromId:u.toId)?.order??0;(e.order<n.order&&c>l||e.order>n.order&&c<l)&&(i+=1)}return i}function tr(t,e){e.direction==="LR"?nr(t,e):rr(t,e)}function nr(t,e){let n=[],r=0;for(let o=0;o<t.layers.length;o+=1){n.push(r);let s=0;for(let i of t.layers[o])s=Math.max(s,i.w);r+=s+e.layerGap}for(let o=0;o<t.layers.length;o+=1)for(let s of t.layers[o])s.x=n[o];for(let o of t.layers){let s=0;for(let i of o)i.y=s,s+=i.h+e.nodeGap}Jt(t,e,"y")}function rr(t,e){let n=[],r=0;for(let o=0;o<t.layers.length;o+=1){n.push(r);let s=0;for(let i of t.layers[o])s=Math.max(s,i.h);r+=s+e.layerGap}for(let o=0;o<t.layers.length;o+=1)for(let s of t.layers[o])s.y=n[o];for(let o of t.layers){let s=0;for(let i of o)i.x=s,s+=i.w+e.nodeGap}Jt(t,e,"x")}function Jt(t,e,n){let r=s=>n==="y"?s.h:s.w,o=e.nodeGap;for(let s=0;s<2;s+=1){let i=s===0?t.layers.slice(1):t.layers.slice(0,-1).reverse();for(let a of i){let u=new Map;for(let l of a){let g=s===0?l.in:l.out;if(g.length===0)continue;let p=[];for(let d of g){let b=t.nodes.get(s===0?d.fromId:d.toId);if(!b)continue;let m=n==="y"?b.y:b.x;p.push(m+Math.floor(r(b)/2))}if(p.length===0)continue;p.sort((d,b)=>d-b);let f=p[Math.floor(p.length/2)];u.set(l.id,f-Math.floor(r(l)/2))}let c=0;for(let l of a){let g=u.get(l.id),p=n==="y"?l.y:l.x,d=Math.max(g??p,c);n==="y"?l.y=d:l.x=d,c=d+r(l)+o}}}}function sr(t,e){let n=new Map;for(let c of t.hops){let l=n.get(c.chainId);l?l.push(c):n.set(c.chainId,[c])}for(let c of n.values())c.sort((l,g)=>l.hopIndex-g.hopIndex);let r=e.direction==="LR",o=c=>r?c.x:c.y,s=c=>r?c.w:c.h,i=c=>r?c.y+Math.floor(c.h/2):c.x+Math.floor(c.w/2),a=new Map;for(let c=0;c+1<t.layers.length;c+=1){let l=t.layers[c],g=t.layers[c+1],p=0;for(let O of l)p=Math.max(p,o(O)+s(O));let f=Number.POSITIVE_INFINITY;for(let O of g)f=Math.min(f,o(O));let d=Number.isFinite(f)?f-1:p,b=Math.max(1,d-p+1),m=[];for(let O of l)for(let k of O.out)m.push(k);m.sort((O,k)=>{let R=i(t.nodes.get(O.fromId)),S=i(t.nodes.get(k.fromId));if(R!==S)return R-S;let E=i(t.nodes.get(O.toId)),N=i(t.nodes.get(k.toId));return E-N});let y=[],h=new Map;for(let O of m){let k=i(t.nodes.get(O.fromId)),R=i(t.nodes.get(O.toId)),S=Math.min(k,R),E=Math.max(k,R),N=-1;for(let D=0;D<y.length;D+=1){let L=y[D],M=!0;for(let B of L)if(B.lo<=E&&S<=B.hi){M=!1;break}if(M){L.push({lo:S,hi:E}),N=D;break}}N<0&&(y.push([{lo:S,hi:E}]),N=y.length-1),h.set(O,N)}let v=y.length,w=b>=Math.max(3,v+2),_=w?p+1:p,T=w?d-1:d,x=Math.max(1,T-_+1);for(let O of m){let k=h.get(O),R;if(v<=1)R=_+Math.floor(x/2);else{let S=(x-1)/(v-1);R=_+Math.floor(k*S)}a.set(O,Math.max(p,Math.min(d,R)))}}let u=[];for(let[,c]of n){let l=[];for(let p=0;p<c.length;p+=1){let f=c[p],d=t.nodes.get(f.fromId),b=t.nodes.get(f.toId),m=a.get(f),y=d.isVirtual?o(d):o(d)+s(d),h=b.isVirtual?o(b):o(b)-1,v=i(d),w=i(b);p===0&&He(l,r,y,v),v!==w&&(He(l,r,m,v),He(l,r,m,w)),He(l,r,h,w)}let g=c[0];u.push({from:g.chainFrom,to:g.chainTo,points:or(l)})}return u}function He(t,e,n,r){t.push(e?{x:n,y:r}:{x:r,y:n})}function or(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 ir(t){let e=0,n=0;for(let r of t.layers)for(let o of r)e=Math.max(e,o.x+o.w),n=Math.max(n,o.y+o.h);return{width:e,height:n}}var ar=24,cr=4,ur=1,dr=3;function Yt(t,e){let n=lr(e.direction),r=Math.max(3,e.maxLabelWidth??ar),o=e.asciiCharset??"unicode",s=Object.keys(t.nodes).sort(),i=new Set(s),a=t.edges.filter(f=>i.has(f.from)&&i.has(f.to)),u=new Map,c=new Map;for(let f of s){let d=jt(f,r);u.set(f,d),c.set(f,je(d)+4)}let l=qt({nodes:s,edges:a,widthCells:f=>c.get(f)??3,heightCells:()=>dr,layerGap:cr,nodeGap:ur,direction:n}),g=zt(l,{charset:o,labelOf:f=>u.get(f)??f}),p=e.logger;return p&&p(g),g}function lr(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 Xt(t,e,n,r={}){let o=e in t.nodes,s=n in t.nodes;if(!o)return Ve(e,n,"no-such-from");if(!s)return Ve(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 c=fr(t,e,r);if(c!=null)return c}let u=ze(e,t.nodes[e],0,r);return We(e,n,[u])}if(i===0)return Ve(e,n,"no-path");let a=Zt(t,e,n,i);return a.found?We(e,n,Qt(t,a.pathOrder,r)):Ve(e,n,a.truncated?"max-depth-exceeded":"no-path")}function Zt(t,e,n,r){let o=new Map,s=[{path:n,depth:0}],i=new Set([n]),a=0,u=!1;for(;a<s.length;){let g=s[a++];if(g.path===e)break;if(r!=null&&g.depth>=r){let b=t.nodes[g.path];b?.deps&&b.deps.length>0&&(u=!0);continue}let p=t.nodes[g.path];if(p==null)continue;let f=p.deps??[],d=new Map;for(let b=0;b<f.length;b++){let m=f[b];if(!m)continue;let y=d.get(m);y==null&&(y=[],d.set(m,y)),y.push(b)}for(let[b,m]of d)i.has(b)||(i.add(b),o.set(b,{from:g.path,depIndices:m}),s.push({path:b,depth:g.depth+1}))}if(!o.has(e))return{found:!1,pathOrder:[],truncated:u};let c=[{path:e}],l=e;for(;l!==n;){let g=o.get(l);if(g==null)return{found:!1,pathOrder:[],truncated:!1};c[c.length-1].depIndices=g.depIndices,c.push({path:g.from}),l=g.from}return{found:!0,pathOrder:c,truncated:!1}}function fr(t,e,n){let r=t.nodes[e];if(r==null)return null;let o=r.deps??[],s=[];for(let a=0;a<o.length;a++)o[a]===e&&s.push(a);if(s.length>0){let a=ze(e,r,0,n);a.dep_index=s[0];let u=ze(e,r,1,n);return We(e,e,[a,u])}let i=null;for(let a=0;a<o.length;a++){let u=o[a];if(!u||u===e)continue;let c=Zt(t,u,e,n.maxDepth);c.found&&(i==null||c.pathOrder.length<i.pathOrder.length)&&(i=c,i={found:!0,pathOrder:[{path:e,depIndices:[a]},...c.pathOrder],truncated:!1})}return i==null?null:We(e,e,Qt(t,i.pathOrder,n))}function Qt(t,e,n){return e.map((r,o)=>{let s=t.nodes[r.path],i=ze(r.path,s,o,n);return r.depIndices!=null&&r.depIndices.length>0&&(i.dep_index=r.depIndices[0],r.depIndices.length>1&&(i.dep_indices=[...r.depIndices])),i})}function ze(t,e,n,r){let o={path:t,type:e.type,hop:n};e.status!==void 0&&(o.status=e.status),"value"in e&&(o.value=e.value),e.v!=null&&(o.v=e.v);let s=r.annotations?.get(t)??e.annotation;s!=null&&(o.annotation=s);let i=r.lastMutations?.get(t)??e.lastMutation;return i!=null&&(o.lastMutation=i),o}function We(t,e,n){return en(t,e,!0,"ok",n)}function Ve(t,e,n){return en(t,e,!1,n,[])}function en(t,e,n,r,o){let s=pr(t,e,n,r,o);return{from:t,to:e,found:n,reason:r,steps:o,text:s,toJSON(){return{from:t,to:e,found:n,reason:r,steps:o}}}}function pr(t,e,n,r,o){if(!n)switch(r){case"no-such-from":return`explainPath: no node named "${t}"`;case"no-such-to":return`explainPath: no node named "${e}"`;case"max-depth-exceeded":return`explainPath: no path from "${t}" to "${e}" within maxDepth`;default:return`explainPath: no path from "${t}" to "${e}"`}let s=[`Causal path: ${t} \u2192 ${e} (${o.length} step(s))`];for(let i of o){let u=` ${i.hop===0?"\xB7":"\u2193"} ${i.path} (${i.type}${i.status?`/${i.status}`:""})`;if(s.push(u),"value"in i&&s.push(` value: ${hr(i.value)}`),i.annotation!=null&&s.push(` annotation: ${i.annotation}`),i.lastMutation!=null){let c=i.lastMutation.actor;s.push(` actor: ${c.type}${c.id?`:${c.id}`:""}`)}}return s.join(`
|
|
1
|
+
"use strict";var Qe=Object.defineProperty;var Sn=Object.getOwnPropertyDescriptor;var Tn=Object.getOwnPropertyNames;var On=Object.prototype.hasOwnProperty;var J=(t,e)=>()=>(t&&(e=t(t=0)),e);var Nn=(t,e)=>{for(var n in e)Qe(t,n,{get:e[n],enumerable:!0})},kn=(t,e,n,r)=>{if(e&&typeof e=="object"||typeof e=="function")for(let o of Tn(e))!On.call(t,o)&&o!==n&&Qe(t,o,{get:()=>e[o],enumerable:!(r=Sn(e,o))||r.enumerable});return t};var En=t=>kn(Qe({},"__esModule",{value:!0}),t);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 o=2+n.length+2+e.length;if(o>4294967295)throw new Error(`encodeEnvelope: total envelope size ${o} exceeds 2^32-1 bytes (payload ${e.length} bytes)`);let s=new Uint8Array(o),i=0;return s[i++]=et,s[i++]=n.length,s.set(n,i),i+=n.length,s[i++]=r>>>8&255,s[i++]=r&255,s.set(e,i),s}function Ot(t,e){if(t.length<St)throw new Error(`decodeEnvelope: bytes too short (${t.length} < ${St})`);let n=0,r=t[n++];if(r!==et)throw new Error(`decodeEnvelope: unsupported envelope version ${r} (expected ${et})`);let o=t[n++];if(o===0)throw new Error("decodeEnvelope: name_len must be >= 1");if(n+o+2>t.length)throw new Error(`decodeEnvelope: envelope truncated (need ${n+o+2} bytes, have ${t.length})`);let s=new TextDecoder().decode(t.subarray(n,n+o));n+=o;let i=(t[n]<<8|t[n+1])>>>0;n+=2;let a=t.subarray(n),u=e.lookupCodec(s);if(u==null)throw new Error(`decodeEnvelope: codec "${s}" not registered (envelope codec_v=${i})`);return{codec:u,codecVersion:i,payload:a}}function Nt(t){t.registerCodec(Rn)}var Rn,et,St,tt=J(()=>{"use strict";Rn={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)}},et=1,St=4});function ke(t){if(t==null)return ae;let{type:e,id:n,...r}=t;return{type:e??"system",id:n??"",...r}}var ae,nt=J(()=>{"use strict";ae={type:"system",id:""}});function Ee(){return ce>0||ve}function kt(){return ce>0}function _e(t){ce>0?we.push(t):t()}function Re(t){ce+=1;let e=!1;try{t()}catch(n){throw e=!0,n}finally{if(ce-=1,ce===0)if(e){if(!ve){let n=we.splice(0);for(let r of n)try{r()}catch{}re.length=0,se.length=0,ue.length=0}}else An()}}function An(){let t=!ve;t&&(ve=!0);let e=[],n=0;try{for(;re.length>0||se.length>0||ue.length>0||t&&we.length>0;){if(t&&we.length>0){let s=we.splice(0);for(let i of s)try{i()}catch(a){e.push(a)}continue}if(n+=1,n>1e3)throw re.length=0,se.length=0,ue.length=0,new Error("batch drain exceeded 1000 iterations \u2014 likely a reactive cycle");let o=(re.length>0?re:se.length>0?se:ue).splice(0);for(let s of o)try{s()}catch(i){e.push(i)}}}finally{t&&(ve=!1)}if(e.length===1)throw e[0];if(e.length>1)throw new AggregateError(e,"batch drain: multiple callbacks threw")}function Ae(t,e,n){if(e.length===0)return;if(e.length===1){let c=n(e[0][0]);if(c<3||!Ee()){t(e);return}(c>=5?ue:c===4?se:re).push(()=>t(e));return}let r=e.length,o=r,s=r,i=r,a=0;for(;a<r&&n(e[a][0])<3;)a++;for(o=a;a<r&&n(e[a][0])===3;)a++;for(s=a;a<r&&n(e[a][0])===4;)a++;i=a;let u=Ee();if(o>0){let c=e.slice(0,o);t(c)}if(s>o){let c=e.slice(o,s);u?re.push(()=>t(c)):t(c)}if(i>s){let c=e.slice(s,i);u?se.push(()=>t(c)):t(c)}if(r>i){let c=e.slice(i,r);u?ue.push(()=>t(c)):t(c)}}var ce,ve,re,se,ue,we,De=J(()=>{"use strict";ce=0,ve=!1,re=[],se=[],ue=[],we=[]});function de(){return Math.trunc(performance.now()*1e6)}function Ce(){return Date.now()*1e6}var rt=J(()=>{"use strict"});var xe,j,z,X,Z,Q,ee,H,W,L,le,st,Dn,ot,Cn,Mn,it,Et,Rt,At,at,fe=J(()=>{"use strict";xe=Symbol.for("graphrefly/START"),j=Symbol.for("graphrefly/DATA"),z=Symbol.for("graphrefly/DIRTY"),X=Symbol.for("graphrefly/RESOLVED"),Z=Symbol.for("graphrefly/INVALIDATE"),Q=Symbol.for("graphrefly/PAUSE"),ee=Symbol.for("graphrefly/RESUME"),H=Symbol.for("graphrefly/TEARDOWN"),W=Symbol.for("graphrefly/COMPLETE"),L=Symbol.for("graphrefly/ERROR"),le=Object.freeze([z]),st=Object.freeze([X]),Dn=Object.freeze([Z]),ot=Object.freeze([xe]),Cn=Object.freeze([W]),Mn=Object.freeze([H]),it=Object.freeze([le]),Et=Object.freeze([st]),Rt=Object.freeze([Dn]),At=Object.freeze([Cn]),at=Object.freeze([Mn])});function Dt(t){t.registerMessageType(xe,{tier:0,wireCrossing:!1}),t.registerMessageType(z,{tier:1,wireCrossing:!1}),t.registerMessageType(Z,{tier:1,wireCrossing:!1,metaPassthrough:!1}),t.registerMessageType(Q,{tier:2,wireCrossing:!1}),t.registerMessageType(ee,{tier:2,wireCrossing:!1}),t.registerMessageType(j,{tier:3,wireCrossing:!0}),t.registerMessageType(X,{tier:3,wireCrossing:!0}),t.registerMessageType(W,{tier:4,wireCrossing:!0,metaPassthrough:!1}),t.registerMessageType(L,{tier:4,wireCrossing:!0,metaPassthrough:!1}),t.registerMessageType(H,{tier:5,wireCrossing:!0,metaPassthrough:!1})}var Me,Ct=J(()=>{"use strict";fe();Me=class{_messageTypes=new Map;_codecs=new Map;_onMessage;_onSubscribe;_defaultVersioning;_defaultHashFn;_inspectorEnabled=!(typeof process<"u"&&process.env?.NODE_ENV==="production");_globalInspector;_rigorRecorder;_frozen=!1;tierOf;constructor(e){this._onMessage=e.onMessage,this._onSubscribe=e.onSubscribe,this._defaultVersioning=e.defaultVersioning,this._defaultHashFn=e.defaultHashFn,this.tierOf=n=>{let r=this._messageTypes.get(n);return r!=null?r.tier:1}}get onMessage(){return this._frozen=!0,this._onMessage}get onSubscribe(){return this._frozen=!0,this._onSubscribe}set onMessage(e){this._assertUnfrozen(),this._onMessage=e}set onSubscribe(e){this._assertUnfrozen(),this._onSubscribe=e}get defaultVersioning(){return this._defaultVersioning}set defaultVersioning(e){this._assertUnfrozen(),this._defaultVersioning=e}get defaultHashFn(){return this._defaultHashFn}set defaultHashFn(e){this._assertUnfrozen(),this._defaultHashFn=e}get inspectorEnabled(){return this._inspectorEnabled}set inspectorEnabled(e){this._inspectorEnabled=e}get globalInspector(){return this._globalInspector}set globalInspector(e){this._globalInspector=e}get rigorRecorder(){return this._rigorRecorder}set rigorRecorder(e){this._rigorRecorder=e}registerMessageType(e,n){return this._assertUnfrozen(),this._messageTypes.set(e,{tier:n.tier,wireCrossing:n.wireCrossing??n.tier>=3,metaPassthrough:n.metaPassthrough??!0}),this}messageTier(e){let n=this._messageTypes.get(e);return n!=null?n.tier:1}isWireCrossing(e){let n=this._messageTypes.get(e);return n!=null?n.wireCrossing:!0}isLocalOnly(e){return!this.isWireCrossing(e)}isMetaPassthrough(e){let n=this._messageTypes.get(e);return n!=null?n.metaPassthrough:!0}isKnownMessageType(e){return this._messageTypes.has(e)}registerCodec(e){return this._assertUnfrozen(),this._codecs.set(e.name,e),this}lookupCodec(e){return this._codecs.get(e)}_isFrozen(){return this._frozen}_assertUnfrozen(){if(this._frozen)throw new Error("GraphReFlyConfig is frozen: a node has already captured this config. Register custom types and set hooks before creating any node.")}}});function ct(t){let e=Gn.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 Y,Gn,Ge=J(()=>{"use strict";Y=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}},Gn=["human","llm","wallet","system"]});function ut(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(ut);if(typeof t=="object"&&t!==null){let e={};for(let n of Object.keys(t).sort())e[n]=ut(t[n]);return e}return null}function Ln(t){let e=In.encode(t),n=e.length,r=n*8,o=n+9+63&-64,s=new Uint8Array(o);s.set(e),s[n]=128;let i=new DataView(s.buffer);i.setUint32(o-4,r>>>0,!1),i.setUint32(o-8,Math.floor(r/4294967296)>>>0,!1);let a=1779033703,u=3144134277,c=1013904242,l=2773480762,g=1359893119,p=2600822924,f=528734635,d=1541459225,b=new Uint32Array(64),m=(h,v)=>h>>>v|h<<32-v;for(let h=0;h<o;h+=64){for(let S=0;S<16;S++)b[S]=i.getUint32(h+S*4,!1);for(let S=16;S<64;S++){let E=b[S-15],N=b[S-2],D=m(E,7)^m(E,18)^E>>>3,I=m(N,17)^m(N,19)^N>>>10;b[S]=b[S-16]+D+b[S-7]+I>>>0}let v=a,w=u,_=c,O=l,x=g,T=p,k=f,R=d;for(let S=0;S<64;S++){let E=m(x,6)^m(x,11)^m(x,25),N=x&T^~x&k,D=R+E+N+$n[S]+b[S]>>>0,I=m(v,2)^m(v,13)^m(v,22),M=v&w^v&_^w&_,B=I+M>>>0;R=k,k=T,T=x,x=O+D>>>0,O=_,_=w,w=v,v=D+B>>>0}a=a+v>>>0,u=u+w>>>0,c=c+_>>>0,l=l+O>>>0,g=g+x>>>0,p=p+T>>>0,f=f+k>>>0,d=d+R>>>0}let y=h=>h.toString(16).padStart(8,"0");return y(a)+y(u)+y(c)+y(l)+y(g)+y(p)+y(f)+y(d)}function dt(t){let e=ut(t??null),n=JSON.stringify(e);return Ln(n).slice(0,16)}function Pn(){let t=globalThis.crypto;if(t?.randomUUID)return t.randomUUID();let e=()=>Math.floor(Math.random()*4294967296).toString(16).padStart(8,"0"),n=e()+e()+e()+e();return`${n.slice(0,8)}-${n.slice(8,12)}-4${n.slice(13,16)}-${(parseInt(n.slice(16,17),16)&3|8).toString(16)}${n.slice(17,20)}-${n.slice(20,32)}`}function lt(t,e,n){let r=n?.id??Pn();if(t===0)return{id:r,version:0};let s=(n?.hash??dt)(e);return{id:r,version:0,cid:s,prev:null}}function Mt(t,e,n){t.version+=1,"cid"in t&&(t.prev=t.cid,t.cid=n(e))}var $n,In,Gt=J(()=>{"use strict";$n=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]),In=new TextEncoder});function Lt(t){return{node:t,unsub:null,prevData:void 0,dirty:!1,involvedThisWave:!1,dataBatch:[],terminal:void 0}}function ft(t){t.prevData=void 0,t.dirty=!1,t.involvedThisWave=!1,t.dataBatch.length=0,t.terminal=void 0}function $e(t){return t.length===0?t:typeof t[0]=="symbol"?[t]:t}function oe(t,e,n){let r=Pt(t)?t:[],o=typeof t=="function"?t:typeof e=="function"?e:void 0,s={};return Pt(t)?s=(pt(e)?e:n)??{}:pt(t)?s=t:s=(pt(e)?e:n)??{},new P(r,o,s)}var $t,It,Fn,jn,pe,P,Pt,pt,he=J(()=>{"use strict";tt();nt();De();rt();Ct();Ge();fe();Gt();$t=()=>{},It=100;Fn=(t,e,n,r)=>{n.direction==="down-in"&&t._onDepMessage(n.depIndex,e)},jn=(t,e,n,r)=>{let o=t;if(o._status==="completed"||o._status==="errored")return;let s=o._cached,i=s===void 0?[ot]:[ot,[j,s]];o._status==="dirty"&&i.push(le),Ae(e,i,o._config.tierOf)},pe=new Me({onMessage:Fn,onSubscribe:jn});Dt(pe);Nt(pe);P=class t{_optsName;_describeKind;meta;_hasMeta;_config;_deps;_sinks=null;_sinkCount=0;_cached;_status;_cleanup;_store={};_waveHasNewData=!1;_hasNewTerminal=!1;_hasCalledFnOnce=!1;_paused=!1;_pendingWave=!1;_isExecutingFn=!1;_pendingRerun=!1;_rerunDepth=0;_dirtyDepCount=0;_batchPendingMessages=null;_pauseLocks=null;_pauseBuffer=null;_fn;_equals;_resubscribable;_resetOnTeardown;_autoComplete;_autoError;_pausable;_partial;_guard;_extraGuards;_hashFn;_versioning;_versioningLevel;_lastMutation;_inspectorHooks;_actions;constructor(e,n,r){this._config=r.config??pe,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??dt;let o=r.versioning??this._config.defaultVersioning;this._versioningLevel=o,this._versioning=o!=null?lt(o,this._cached===void 0?void 0:this._cached,{id:r.versioningId,hash:this._hashFn}):void 0,this._deps=e.map(Lt);let s={};for(let[a,u]of Object.entries(r.meta??{})){let c={initial:u,name:`${r.name??"node"}:meta:${a}`,describeKind:"state",config:this._config};r.guard!=null&&(c.guard=r.guard),s[a]=new t([],void 0,c)}Object.freeze(s),this.meta=s,this._hasMeta=Object.keys(s).length>0;let i=this;this._actions={emit(a){i._emit([[j,a]])},down(a){i._emit($e(a))},up(a){i._emitUp($e(a))}},this.down=this.down.bind(this),this.up=this.up.bind(this)}get _isTerminal(){return this._status==="completed"||this._status==="errored"}get name(){return this._optsName}get status(){return this._status}get cache(){return this._cached===void 0?void 0:this._cached}get lastMutation(){return this._lastMutation}get v(){return this._versioning}hasGuard(){return this._guard!=null}_applyVersioning(e,n){if(this._isExecutingFn)throw new Error(`Node "${this.name}": _applyVersioning cannot run mid-fn \u2014 call it outside of \`_execFn\` (typically at graph setup time before the first subscribe).`);let r=this._versioningLevel;if(r!=null&&e<=r)return;let o=n?.hash??this._hashFn;o!==this._hashFn&&(this._hashFn=o);let s=this._cached===void 0?void 0:this._cached,i=this._versioning,a=i?.id??n?.id,u=i?.version??0,c=lt(e,s,{id:a,hash:o});c.version=u,this._versioning=c,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=ke(e);if(this._guard!=null&&!this._guard(n,"observe"))return!1;if(this._extraGuards!=null){for(let r of this._extraGuards)if(!r(n,"observe"))return!1}return!0}_checkGuard(e){if(e?.internal)return;let n=this._guard!=null||this._extraGuards!=null,r=e?.actor!=null;if(!n&&!r)return;let o=ke(e?.actor),s=e?.delivery==="signal"?"signal":"write";if(this._guard!=null&&!this._guard(o,s))throw new Y({actor:o,action:s,nodeName:this.name});if(this._extraGuards!=null){for(let i of this._extraGuards)if(!i(o,s))throw new Y({actor:o,action:s,nodeName:this.name})}this._lastMutation={actor:o,timestamp_ns:Ce()}}down(e,n){let r=$e(e);r.length!==0&&(this._checkGuard(n),this._emit(r))}emit(e,n){this._checkGuard(n),this._emit([[j,e]])}up(e,n){if(this._deps.length===0)return;let r=$e(e);if(r.length===0)return;this._checkGuard(n);let o=n??{internal:!0};this._validateUpTiers(r);for(let s of this._deps)s.node.up?.(r,o)}_emitUp(e){if(this._deps.length!==0&&e.length!==0){this._validateUpTiers(e);for(let n of this._deps)n.node.up?.(e,{internal:!0})}}_validateUpTiers(e){let n=this._config.tierOf;for(let r of e){let o=n(r[0]);if(o===3||o===4)throw new Error(`Node "${this.name}": tier-${o} messages cannot flow up \u2014 DATA/RESOLVED/COMPLETE/ERROR are downstream-only. Use \`down(...)\` for value delivery; \`up(...)\` is for control signals (DIRTY, INVALIDATE, PAUSE, RESUME, TEARDOWN).`)}}subscribe(e,n){if(n!=null&&this._guard!=null){let u=ke(n);if(!this._guard(u,"observe"))throw new Y({actor:u,action:"observe",nodeName:this.name})}let o=this._isTerminal&&this._resubscribable;if(o){this._cached=void 0,this._status="sentinel",this._store={},this._hasCalledFnOnce=!1,this._waveHasNewData=!1,this._hasNewTerminal=!1,this._paused=!1,this._pendingWave=!1,this._pendingRerun=!1,this._isExecutingFn=!1,this._rerunDepth=0,this._dirtyDepCount=0,this._pauseLocks=null,this._pauseBuffer=null;for(let u of this._deps)ft(u);if(this._partial===!1){for(let u of this._deps)if(u.prevData!==void 0||u.dataBatch.length!==0||u.terminal!==void 0||u.dirty)throw new Error(`resubscribable-reset invariant: DepRecord not fully reset for node ${this._optsName??"(anonymous)"}`)}}this._sinkCount+=1;let s;try{s=this._config.onSubscribe(this,e,{sinkCount:this._sinkCount,afterTerminalReset:o},this._actions)}catch(u){throw this._sinkCount-=1,u}this._sinks==null?this._sinks=e:typeof this._sinks=="function"?this._sinks=new Set([this._sinks,e]):this._sinks.add(e);let i=this._isTerminal;if(this._sinkCount===1&&!i)try{this._activate()}catch(u){if(this._sinkCount-=1,this._removeSink(e),this._sinkCount===0&&(this._status="sentinel"),typeof s=="function")try{s()}catch{}throw u}this._status==="sentinel"&&this._cached===void 0&&(this._status="pending");let a=!1;return()=>{a||(a=!0,this._sinkCount-=1,this._removeSink(e),typeof s=="function"&&s(),this._sinks==null&&this._deactivate())}}_removeSink(e){if(this._sinks===e)this._sinks=null;else if(this._sinks!=null&&typeof this._sinks!="function")if(this._sinks.delete(e),this._sinks.size===1){let[n]=this._sinks;this._sinks=n}else this._sinks.size===0&&(this._sinks=null)}_activate(){if(this._deps.length===0){this._fn&&this._execFn();return}this._dirtyDepCount=0;let e=this._deps.length,n=0;try{for(let r=0;r<e;r++){let o=r,s=this._deps[r];s.unsub=$t,s.unsub=s.node.subscribe(i=>{if(s.unsub===null)return;let a=this._config.tierOf,u=!1;for(let c of i)a(c[0])>=3&&(u=!0),this._config.onMessage(this,c,{direction:"down-in",depIndex:o},this._actions);u&&this._maybeRunFnOnSettlement()}),n++}}catch(r){this._deps[n].unsub=null;for(let o=0;o<n;o++){let s=this._deps[o];if(s.unsub!=null){let i=s.unsub;s.unsub=null;try{i()}catch{}ft(s)}}throw this._dirtyDepCount=0,r}}_addDep(e){for(let o=0;o<this._deps.length;o++)if(this._deps[o].node===e)return o;let n=this._deps.length,r=Lt(e);if(this._deps.push(r),this._sinks==null)return n;r.dirty=!0,this._dirtyDepCount++,this._status!=="dirty"&&this._emit(it),r.unsub=$t;try{r.unsub=e.subscribe(o=>{if(r.unsub===null)return;let s=this._config.tierOf,i=!1;for(let a of o)s(a[0])>=3&&(i=!0),this._config.onMessage(this,a,{direction:"down-in",depIndex:n},this._actions);i&&this._maybeRunFnOnSettlement()})}catch(o){throw r.unsub=null,this._deps.pop(),this._dirtyDepCount--,o}return n}_deactivate(e=!1){let n=this._cleanup;if(this._cleanup=void 0,typeof n=="function")try{n()}catch(r){this._emit([[L,this._wrapFnError("cleanup threw",r)]])}else if(n!=null&&typeof n=="object"){let r=n.deactivate;if(typeof r=="function")try{r()}catch(o){this._emit([[L,this._wrapFnError("cleanup.deactivate threw",o)]])}}for(let r of this._deps){if(r.unsub!=null){let o=r.unsub;r.unsub=null;try{o()}catch{}}ft(r)}this._waveHasNewData=!1,this._hasNewTerminal=!1,this._hasCalledFnOnce=!1,this._paused=!1,this._pendingWave=!1,this._pendingRerun=!1,this._rerunDepth=0,this._store={},this._dirtyDepCount=0,this._pauseLocks=null,this._pauseBuffer=null,this._fn!=null&&(this._cached=void 0),e||(this._fn!=null||this._deps.length>0)&&(!this._isTerminal||this._resubscribable)&&(this._status="sentinel")}_onDepMessage(e,n){let r=this._deps[e],o=n[0];if(this._inspectorHooks!=null){let s={kind:"dep_message",depIndex:e,message:n};for(let i of this._inspectorHooks)i(s)}if(o!==xe){if(o===z){this._depDirtied(r);return}if(o===Z){if(this._depInvalidated(r),this._cached===void 0)return;this._emit(Rt);return}if(o===Q||o===ee){this._emit([n]);return}if(o===H){this._emit(at);return}if(o===j)this._depSettledAsData(r,n[1]);else if(o===X)this._depSettledAsResolved(r);else if(o===W)this._depSettledAsTerminal(r,!0);else if(o===L)this._depSettledAsTerminal(r,n[1]);else{this._emit([n]);return}if(!this._fn){(o===j||o===X)&&this._emit([n]),(o===W||o===L)&&this._maybeAutoTerminalAfterWave();return}}}_depDirtied(e){e.dirty||(e.dirty=!0,e.involvedThisWave=!0,this._dirtyDepCount++,this._status!=="dirty"&&this._emit(it))}_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(Et),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([[L,e.terminal]]);return}this._autoComplete&&this._deps.every(n=>n.terminal!==void 0)&&this._emit(At)}_execFn(){if(!this._fn||this._isTerminal&&!this._resubscribable)return;if(this._isExecutingFn){this._pendingRerun=!0;return}let e=this._cleanup;if(typeof e=="function"){this._cleanup=void 0;try{e()}catch(i){this._emit([[L,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([[L,this._wrapFnError("cleanup.beforeRun threw",a)]]);return}}}let n=this._deps.map(i=>i.involvedThisWave?i.dataBatch.length>0?[...i.dataBatch]:[]:void 0),r=this._deps.map(i=>i.prevData);for(let i=0;i<this._deps.length;i++){let a=n[i];a!=null&&a.length>0&&(this._deps[i].prevData=a[a.length-1])}let o=this._deps.map(i=>i.terminal),s={prevData:r,terminalDeps:o,store:this._store};if(this._hasCalledFnOnce=!0,this._clearWaveFlags(),this._inspectorHooks!=null){let i={kind:"run",batchData:n,prevData:r};for(let a of this._inspectorHooks)a(i)}this._isExecutingFn=!0;try{let i=this._fn(n,this._actions,s);if(typeof i=="function")this._cleanup=i;else if(i!=null&&typeof i=="object"){let a=i;(typeof a.beforeRun=="function"||typeof a.deactivate=="function"||typeof a.invalidate=="function")&&(this._cleanup=i)}}catch(i){this._emit([[L,this._wrapFnError("fn threw",i)]])}finally{this._isExecutingFn=!1,this._pendingRerun?(this._pendingRerun=!1,this._rerunDepth+=1,this._rerunDepth>It?(this._rerunDepth=0,this._emit([[L,new Error(`Node "${this.name}": _pendingRerun depth exceeded ${It} \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"?[le,e[0]]:e;let r=!0,o=!1,s=!1,i=-1;for(let u of e){let c=n(u[0]);c<i&&(r=!1),c===3&&(o=!0),u[0]===z&&(s=!0),i=c}let a=e;if(!r){let u=e.map((c,l)=>({m:c,i:l,tier:n(c[0])}));u.sort((c,l)=>c.tier-l.tier||c.i-l.i),a=u.map(c=>c.m)}if(o&&!s&&this._status!=="dirty"){let u=0;for(;u<a.length&&n(a[u][0])===0;)u++;return u===0?[le,...a]:[...a.slice(0,u),le,...a.slice(u)]}return a}_emit(e){if(e.length===0)return;for(let a=0;a<e.length;a++){let u=e[a];if(u[0]===L&&u[1]===void 0)throw new TypeError('[ERROR, payload] requires a non-undefined payload (spec \xA71.2). Pass an Error object or domain tag instead \u2014 e.g. node.down([[ERROR, new Error("reason")]])')}let n=e;if(this._isTerminal&&!this._resubscribable){let a=e.filter(u=>u[0]===H||u[0]===Z);if(a.length===0)return;n=a}n=this._frameBatch(n);let o=null;for(let a=0;a<n.length;a++){let u=n[a],c=u[0];if(c!==Q&&c!==ee){o?.push(u);continue}if(u.length<2)throw new Error(`Node "${this.name}": [[${c===Q?"PAUSE":"RESUME"}]] must carry a lockId payload \u2014 bare PAUSE/RESUME is a protocol violation (C0 rule). Use \`[[PAUSE, lockId]]\` / \`[[RESUME, lockId]]\`.`);let l=!0;if(this._pausable!==!1){let g=u[1];if(c===Q)this._pauseLocks==null&&(this._pauseLocks=new Set),this._pauseLocks.add(g),this._paused=!0,this._pausable==="resumeAll"&&this._pauseBuffer==null&&(this._pauseBuffer=[]);else if(this._pauseLocks==null||!this._pauseLocks.has(g))l=!1;else if(this._pauseLocks.delete(g),this._pauseLocks.size===0){if(this._paused=!1,this._pauseBuffer!=null&&this._pauseBuffer.length>0){let p=this._pauseBuffer;this._pauseBuffer=[],this._emit(p)}this._pendingWave&&(this._pendingWave=!1,this._maybeRunFnOnSettlement())}}l?o?.push(u):o==null&&(o=n.slice(0,a))}if(o!=null){if(o.length===0)return;n=o}if(this._hasMeta&&n.some(a=>a[0]===H))for(let a of Object.keys(this.meta))try{this.meta[a]._emit(at)}catch{}let{finalMessages:s,equalsError:i}=this._updateState(n);if(s.length>0&&this._config.inspectorEnabled){let a=this._config.globalInspector;if(a!=null)try{a({kind:"emit",node:this,messages:s})}catch{}}if(s.length>0)if(this._paused&&this._pausable==="resumeAll"&&this._pauseBuffer!=null){let a=this._config.tierOf,u=[];for(let c of s)a(c[0])===3?this._pauseBuffer.push(c):u.push(c);u.length>0&&this._dispatchOrAccumulate(u)}else this._dispatchOrAccumulate(s);i!=null&&this._emit([[L,i]])}_updateState(e){let n=this._config.tierOf,r,o,s=-1,i=0;for(let l of e)n(l[0])===3&&i++;let a=i<=1,u=-1;if(this._versioning!=null&&i>1){for(let l=e.length-1;l>=0;l--)if(e[l][0]===j){u=l;break}}for(let l=0;l<e.length;l++){let g=e[l],p=g[0];if(p===j){if(g.length>=2){let f=!1;if(a&&this._cached!==void 0)try{f=this._equals(this._cached,g[1])}catch(d){o=this._wrapFnError("equals threw",d),s=l;break}if(f){r==null&&(r=e.slice(0,l)),r.push(st),this._status="resolved";continue}this._cached=g[1],this._versioning!=null&&(u<0||l===u)&&Mt(this._versioning,g[1],this._hashFn)}this._status="settled",r?.push(g)}else if(r?.push(g),p===z)this._status="dirty";else if(p===X)this._status="resolved";else if(p===W){this._status="completed";{let f=this._config.rigorRecorder;if(f!=null)try{f.onTerminalTransition(this,"completed",this._autoComplete,this._autoError,this._deps.length>0)}catch{}}}else if(p===L){this._status="errored";{let f=this._config.rigorRecorder;if(f!=null)try{f.onTerminalTransition(this,"errored",this._autoComplete,this._autoError,this._deps.length>0)}catch{}}}else if(p===Z){if(this._cached!==void 0){let d=this._config.rigorRecorder;if(d!=null)try{d.onNonVacuousInvalidate(this,this._cached)}catch{}}this._cached=void 0,this._status="dirty";let f=this._cleanup;if(typeof f=="function"){this._cleanup=void 0;try{f()}catch{}}else if(f!=null&&typeof f=="object"){let d=f.invalidate;if(typeof d=="function")try{d()}catch{}}}else p===H&&(this._resetOnTeardown&&(this._cached=void 0),this._deactivate(!0),this._status="sentinel")}let c=s>=0?r??e.slice(0,s):r??e;return o!=null?{finalMessages:c,equalsError:o}:{finalMessages:c}}_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(kt()){this._batchPendingMessages===null&&(this._batchPendingMessages=[],_e(()=>this._flushBatchPending()));for(let n of e)this._batchPendingMessages.push(n);return}Ae(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);Ae(this._deliverToSinks,n,this._config.tierOf)}},Pt=t=>Array.isArray(t),pt=t=>typeof t=="object"&&t!=null&&!Array.isArray(t)});function te(t,e){return oe([],{...e,initial:t})}function Se(t,e){return oe((r,o,s)=>t(o,s)??void 0,{describeKind:"producer",...e})}function ie(t,e,n){return oe(t,(o,s,i)=>{let a=o.map((u,c)=>u!=null&&u.length>0?u.at(-1):i.prevData[c]);s.emit(e(a,i))},{describeKind:"derived",...n})}function Ie(t,e,n){return oe(t,(o,s,i)=>{let a=o.map((u,c)=>u!=null&&u.length>0?u.at(-1):i.prevData[c]);return e(a,s,i)??void 0},{describeKind:"effect",...n})}var Le=J(()=>{"use strict";he()});function ge(t){return t.subscribe(()=>{})}var gt=J(()=>{"use strict"});var Fe,Ft=J(()=>{"use strict";Fe=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 Ur={};Nn(Ur,{compileSpec:()=>Br,decompileGraph:()=>Hr,extractFnFactory:()=>bn,extractSourceFactory:()=>yn,generateCatalogPrompt:()=>vn,isRichFnEntry:()=>Oe,isRichSourceEntry:()=>wt,llmCompose:()=>Wr,llmRefine:()=>xn,specDiff:()=>zr,validateSpec:()=>qe,validateSpecAgainstCatalog:()=>_t});module.exports=En(Ur);Le();nt();De();rt();Ge();fe();Ge();he();function Pe(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 Bn(t){return t._describeKind!=null?t._describeKind:t._deps.length>0?"derived":t._fn!=null?"producer":"state"}function Vn(t){let e={};for(let[n,r]of Object.entries(t.meta))try{e[n]=r.cache}catch{}return e}function ht(t,e){let n=e==null,r=!n&&e!=null?[...e].filter(c=>c.startsWith("meta.")).map(c=>c.slice(5)):null,o=n||e.has("meta")||r!=null&&r.length>0,s="state",i=[];t instanceof P&&(s=Bn(t),i=t._deps.map(c=>c.node.name??""));let a={type:s,deps:i};(n||e.has("status"))&&(a.status=t.status);let u=t instanceof P?t._guard:void 0;if(o){let c={...Vn(t)};if(u!=null&&c.access===void 0&&(c.access=ct(u)),r!=null&&r.length>0&&!e.has("meta")){let l={};for(let g of r)g in c&&(l[g]=c[g]);a.meta=l}else a.meta=c}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 c={id:t.v.id,version:t.v.version};"cid"in t.v&&(c.cid=t.v.cid,c.prev=t.v.prev),a.v=c}return(n||e.has("guard"))&&u!=null&&(a.guard=ct(u)),(n||e.has("lastMutation"))&&t.lastMutation!=null&&(a.lastMutation=t.lastMutation),a}he();Le();gt();Ft();var Te=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}};tt();function mt(t){return t>=768&&t<=879||t>=1155&&t<=1161||t>=1425&&t<=1469||t>=1552&&t<=1562||t>=1611&&t<=1631||t>=1648&&t===1648||t>=1750&&t<=1756||t>=1759&&t<=1764||t>=1767&&t<=1768||t>=1770&&t<=1773||t>=1840&&t<=1866||t>=1958&&t<=1968||t>=2304&&t<=2307||t>=2362&&t<=2383||t>=2385&&t<=2391||t>=2402&&t<=2403||t>=2433&&t<=2435||t>=2492&&t<=2509||t>=2561&&t<=2563||t>=2620&&t<=2641||t>=2672&&t<=2673||t>=2677&&t===2677||t>=3633&&t===3633||t>=3636&&t<=3642||t>=3655&&t<=3662||t>=3761&&t===3761||t>=3764&&t<=3772||t>=3784&&t<=3790||t>=7616&&t<=7679||t>=8400&&t<=8447||t>=65024&&t<=65039||t>=65056&&t<=65071||t===8205?0:t>=4352&&t<=4447||t>=8986&&t<=8987||t>=9001&&t<=9002||t>=9193&&t<=9203||t>=9208&&t<=9210||t>=9725&&t<=9726||t>=9748&&t<=9749||t>=9800&&t<=9811||t===9855||t===9875||t===9889||t>=9898&&t<=9899||t>=9917&&t<=9918||t>=9924&&t<=9925||t===9934||t===9940||t===9962||t>=9970&&t<=9971||t===9973||t===9978||t===9981||t===9986||t===9989||t>=9992&&t<=9997||t===9999||t>=10067&&t<=10069||t===10071||t>=10133&&t<=10135||t===10160||t===10175||t>=10548&&t<=10549||t>=11013&&t<=11015||t>=11035&&t<=11036||t===11088||t===11093||t>=11904&&t<=12350||t>=12352&&t<=12447||t>=12448&&t<=12543||t>=12549&&t<=12591||t>=12593&&t<=12686||t>=12688&&t<=12771||t>=12784&&t<=12830||t>=12832&&t<=12871||t>=12880&&t<=19903||t>=19968&&t<=40959||t>=43360&&t<=43388||t>=44032&&t<=55203||t>=63744&&t<=64255||t>=65040&&t<=65049||t>=65072&&t<=65131||t>=65281&&t<=65376||t>=65504&&t<=65510||t>=126980&&t===126980||t===127183||t>=127344&&t<=127345||t===127358||t===127359||t===127374||t>=127377&&t<=127386||t>=127456&&t<=127487||t>=127488&&t<=127490||t===127514||t===127535||t>=127538&&t<=127546||t>=127568&&t<=127569||t>=127744&&t<=129535||t>=129536&&t<=129791||t>=129792&&t<=130047||t>=131072&&t<=196605||t>=196608&&t<=262141?2:1}function je(t){let e=0;for(let n of t)e+=mt(n.codePointAt(0));return e}function jt(t,e){if(e<=0)return"";let n=0,r="";for(let o of t){let s=mt(o.codePointAt(0));if(n+s>e){if(e<=1)return"\u2026";for(;n+1>e&&r.length>0;){let i=[...r].pop();r=r.slice(0,-i.length),n-=mt(i.codePointAt(0))}return`${r}\u2026`}r+=o,n+=s}return r}var Hn={horizontal:"\u2500",vertical:"\u2502",cornerTL:"\u250C",cornerTR:"\u2510",cornerBL:"\u2514",cornerBR:"\u2518",tDown:"\u252C",tUp:"\u2534",tRight:"\u251C",tLeft:"\u2524",cross:"\u253C",arrowRight:"\u25B6",arrowDown:"\u25BC",arrowLeft:"\u25C0",arrowUp:"\u25B2",boxTL:"\u250C",boxTR:"\u2510",boxBL:"\u2514",boxBR:"\u2518",boxH:"\u2500",boxV:"\u2502"},zn={horizontal:"-",vertical:"|",cornerTL:"+",cornerTR:"+",cornerBL:"+",cornerBR:"+",tDown:"+",tUp:"+",tRight:"+",tLeft:"+",cross:"+",arrowRight:">",arrowDown:"v",arrowLeft:"<",arrowUp:"^",boxTL:"+",boxTR:"+",boxBL:"+",boxBR:"+",boxH:"-",boxV:"|"};function zt(t,e){let n=e.charset==="ascii"?zn:Hn,r=t.width,o=t.height,s=Array.from({length:o},()=>Array.from({length:r},()=>" ")),i=Array.from({length:o},()=>Array.from({length:r},()=>"empty"));for(let a of t.edges)Un(s,i,n,a);for(let a of t.boxes)Wn(s,i,n,a,e.labelOf(a.id));return s.map(a=>Yn(a.join(""))).join(`
|
|
2
|
+
`)}function Wn(t,e,n,r,o){let{x:s,y:i,w:a,h:u}=r;if(a<2||u<2){u>0&&Bt(t,e,s,i,a,o);return}ne(t,e,s,i,n.boxTL);for(let l=s+1;l<s+a-1;l+=1)ne(t,e,l,i,n.boxH);ne(t,e,s+a-1,i,n.boxTR);for(let l=i+1;l<i+u-1;l+=1){ne(t,e,s,l,n.boxV);for(let g=s+1;g<s+a-1;g+=1)Wt(t,e,g,l," ","empty");ne(t,e,s+a-1,l,n.boxV)}ne(t,e,s,i+u-1,n.boxBL);for(let l=s+1;l<s+a-1;l+=1)ne(t,e,l,i+u-1,n.boxH);ne(t,e,s+a-1,i+u-1,n.boxBR);let c=i+Math.floor(u/2);Bt(t,e,s+1,c,a-2,o)}function ne(t,e,n,r,o){Wt(t,e,n,r,o,o===" "?"empty":o==="\u2500"||o==="-"?"boxH":o==="\u2502"||o==="|"?"boxV":"boxCorner")}function Wt(t,e,n,r,o,s){if(r<0||r>=t.length)return;let i=t[r];n<0||n>=i.length||(i[n]=o,e[r][n]=s)}function Bt(t,e,n,r,o,s){if(r<0||r>=t.length)return;let i=n,a=o;for(let u of s){let c=je(u);if(c!==0){if(a<c)break;i>=0&&i<t[r].length&&(t[r][i]=u,e[r][i]="label",c===2&&i+1<t[r].length&&(t[r][i+1]="",e[r][i+1]="label")),i+=c,a-=c}}for(;a>0;)i>=0&&i<t[r].length&&(t[r][i]=" ",e[r][i]="empty"),i+=1,a-=1}function Un(t,e,n,r){let o=r.points;if(o.length<2)return;for(let u=0;u+1<o.length;u+=1)Kn(t,e,n,o[u],o[u+1]);for(let u=1;u+1<o.length;u+=1){let c=o[u-1],l=o[u],g=o[u+1],p=qn(c,l,g,n);p&&Ht(t,e,l.x,l.y,p,"edgeCorner")}let s=o[o.length-1],i=o[o.length-2],a=Jn(i,s,n);a&&Ht(t,e,s.x,s.y,a,"arrow")}function Kn(t,e,n,r,o){if(!(r.x===o.x&&r.y===o.y)){if(r.y===o.y){let s=r.y,i=Math.min(r.x,o.x),a=Math.max(r.x,o.x);for(let u=i;u<=a;u+=1)Vt(t,e,u,s,n,"h")}else if(r.x===o.x){let s=r.x,i=Math.min(r.y,o.y),a=Math.max(r.y,o.y);for(let u=i;u<=a;u+=1)Vt(t,e,s,u,n,"v")}}}function Vt(t,e,n,r,o,s){if(r<0||r>=t.length)return;let i=t[r];if(n<0||n>=i.length)return;let a=e[r][n];if(!(a==="boxH"||a==="boxV"||a==="boxCorner"||a==="label")){if(a==="empty"){i[n]=s==="h"?o.horizontal:o.vertical,e[r][n]=s==="h"?"edgeH":"edgeV";return}if(a==="edgeH"&&s==="v"){i[n]=o.cross,e[r][n]="edgeCorner";return}if(a==="edgeV"&&s==="h"){i[n]=o.cross,e[r][n]="edgeCorner";return}}}function Ht(t,e,n,r,o,s){if(r<0||r>=t.length)return;let i=t[r];if(n<0||n>=i.length)return;let a=e[r][n];a==="boxH"||a==="boxV"||a==="boxCorner"||a==="label"||(i[n]=o,e[r][n]=s)}function qn(t,e,n,r){let o=t.y===e.y,s=e.y===n.y;if(o===s)return;if(o){let u=t.x<e.x,c=n.y>e.y;return u&&c?r.cornerTR:u&&!c?r.cornerBR:!u&&c?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 Jn(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 Yn(t){let e=t.length;for(;e>0&&t.charCodeAt(e-1)===32;)e-=1;return t.slice(0,e)}function qt(t){let e=Xn(t);Zn(e),Qn(e),er(e),tr(e,t);let n=sr(e,t),{width:r,height:o}=ir(e),s=[];for(let i of e.layers)for(let a of i)a.isVirtual||s.push({id:a.id,layer:a.layer,order:a.order,x:a.x,y:a.y,w:a.w,h:a.h});return{boxes:s,edges:n,width:r,height:o}}function Xn(t){let e=new Map;for(let o of t.nodes)e.set(o,{id:o,isVirtual:!1,layer:-1,order:0,x:0,y:0,w:t.widthCells(o),h:t.heightCells(o),in:[],out:[]});let n=[],r=0;for(let o of t.edges){if(o.from===o.to)continue;let s=e.get(o.from),i=e.get(o.to);if(!s||!i)continue;let a={chainId:r++,chainFrom:o.from,chainTo:o.to,fromId:o.from,toId:o.to,hopIndex:0,chainLen:1};s.out.push(a),i.in.push(a),n.push(a)}return{nodes:e,layers:[],hops:n}}function Zn(t){let e=new Map;for(let s of t.nodes.values())e.set(s.id,s.in.length);let n=[];for(let s of t.nodes.values())(e.get(s.id)??0)===0&&(s.layer=0,n.push(s));let r=new Set,o=0;for(;o<n.length;){let s=n[o++];if(!r.has(s.id)){r.add(s.id);for(let i of s.out){let a=t.nodes.get(i.toId);a.layer=Math.max(a.layer,s.layer+1);let u=(e.get(a.id)??0)-1;e.set(a.id,u),u<=0&&n.push(a)}}}for(let s of t.nodes.values())s.layer<0&&(s.layer=0)}function Qn(t){let e=Math.max(0,...Array.from(t.nodes.values(),s=>s.layer)),n=Array.from({length:e+1},()=>[]);for(let s of t.nodes.values())n[s.layer].push(s);let r=[],o=0;for(let s of t.hops){let i=t.nodes.get(s.fromId),a=t.nodes.get(s.toId),u=a.layer-i.layer;if(u<=0){i.out=i.out.filter(g=>g!==s),a.in=a.in.filter(g=>g!==s);continue}if(u===1){s.hopIndex=0,s.chainLen=1,r.push(s);continue}i.out=i.out.filter(g=>g!==s),a.in=a.in.filter(g=>g!==s);let c=i;for(let g=1;g<u;g+=1){let p=`__virt_${o++}__`,f={id:p,isVirtual:!0,layer:i.layer+g,order:0,x:0,y:0,w:0,h:1,in:[],out:[]};t.nodes.set(p,f),n[f.layer].push(f);let d={chainId:s.chainId,chainFrom:s.chainFrom,chainTo:s.chainTo,fromId:c.id,toId:p,hopIndex:g-1,chainLen:u};c.out.push(d),f.in.push(d),r.push(d),c=f}let l={chainId:s.chainId,chainFrom:s.chainFrom,chainTo:s.chainTo,fromId:c.id,toId:a.id,hopIndex:u-1,chainLen:u};c.out.push(l),a.in.push(l),r.push(l)}for(let s of n)for(let i=0;i<s.length;i+=1)s[i].order=i;t.layers=n,t.hops=r}function er(t){for(let n=0;n<4;n+=1){for(let r=1;r<t.layers.length;r+=1)Ut(t,t.layers[r],"in"),Be(t.layers[r]);for(let r=t.layers.length-2;r>=0;r-=1)Ut(t,t.layers[r],"out"),Be(t.layers[r])}for(let n=0;n<2;n+=1){let r=!1;for(let o=1;o<t.layers.length;o+=1){let s=t.layers[o];for(let i=0;i+1<s.length;i+=1){let a=Kt(t,s[i],s[i+1],"in");[s[i],s[i+1]]=[s[i+1],s[i]],Be(s),Kt(t,s[i],s[i+1],"in")<a?r=!0:([s[i],s[i+1]]=[s[i+1],s[i]],Be(s))}}if(!r)break}}function Ut(t,e,n){let r=new Map;for(let o of e){let s=n==="in"?o.in:o.out;if(s.length===0){r.set(o.id,o.order);continue}let i=0,a=0;for(let u of s){let c=t.nodes.get(n==="in"?u.fromId:u.toId);c&&(i+=c.order,a+=1)}r.set(o.id,a===0?o.order:i/a)}e.sort((o,s)=>{let i=r.get(o.id),a=r.get(s.id);return i!==a?i-a:o.order-s.order})}function Be(t){for(let e=0;e<t.length;e+=1)t[e].order=e}function Kt(t,e,n,r){let o=r==="in"?e.in:e.out,s=r==="in"?n.in:n.out,i=0;for(let a of o)for(let u of s){let c=t.nodes.get(r==="in"?a.fromId:a.toId)?.order??0,l=t.nodes.get(r==="in"?u.fromId:u.toId)?.order??0;(e.order<n.order&&c>l||e.order>n.order&&c<l)&&(i+=1)}return i}function tr(t,e){e.direction==="LR"?nr(t,e):rr(t,e)}function nr(t,e){let n=[],r=0;for(let o=0;o<t.layers.length;o+=1){n.push(r);let s=0;for(let i of t.layers[o])s=Math.max(s,i.w);r+=s+e.layerGap}for(let o=0;o<t.layers.length;o+=1)for(let s of t.layers[o])s.x=n[o];for(let o of t.layers){let s=0;for(let i of o)i.y=s,s+=i.h+e.nodeGap}Jt(t,e,"y")}function rr(t,e){let n=[],r=0;for(let o=0;o<t.layers.length;o+=1){n.push(r);let s=0;for(let i of t.layers[o])s=Math.max(s,i.h);r+=s+e.layerGap}for(let o=0;o<t.layers.length;o+=1)for(let s of t.layers[o])s.y=n[o];for(let o of t.layers){let s=0;for(let i of o)i.x=s,s+=i.w+e.nodeGap}Jt(t,e,"x")}function Jt(t,e,n){let r=s=>n==="y"?s.h:s.w,o=e.nodeGap;for(let s=0;s<2;s+=1){let i=s===0?t.layers.slice(1):t.layers.slice(0,-1).reverse();for(let a of i){let u=new Map;for(let l of a){let g=s===0?l.in:l.out;if(g.length===0)continue;let p=[];for(let d of g){let b=t.nodes.get(s===0?d.fromId:d.toId);if(!b)continue;let m=n==="y"?b.y:b.x;p.push(m+Math.floor(r(b)/2))}if(p.length===0)continue;p.sort((d,b)=>d-b);let f=p[Math.floor(p.length/2)];u.set(l.id,f-Math.floor(r(l)/2))}let c=0;for(let l of a){let g=u.get(l.id),p=n==="y"?l.y:l.x,d=Math.max(g??p,c);n==="y"?l.y=d:l.x=d,c=d+r(l)+o}}}}function sr(t,e){let n=new Map;for(let c of t.hops){let l=n.get(c.chainId);l?l.push(c):n.set(c.chainId,[c])}for(let c of n.values())c.sort((l,g)=>l.hopIndex-g.hopIndex);let r=e.direction==="LR",o=c=>r?c.x:c.y,s=c=>r?c.w:c.h,i=c=>r?c.y+Math.floor(c.h/2):c.x+Math.floor(c.w/2),a=new Map;for(let c=0;c+1<t.layers.length;c+=1){let l=t.layers[c],g=t.layers[c+1],p=0;for(let T of l)p=Math.max(p,o(T)+s(T));let f=Number.POSITIVE_INFINITY;for(let T of g)f=Math.min(f,o(T));let d=Number.isFinite(f)?f-1:p,b=Math.max(1,d-p+1),m=[];for(let T of l)for(let k of T.out)m.push(k);m.sort((T,k)=>{let R=i(t.nodes.get(T.fromId)),S=i(t.nodes.get(k.fromId));if(R!==S)return R-S;let E=i(t.nodes.get(T.toId)),N=i(t.nodes.get(k.toId));return E-N});let y=[],h=new Map;for(let T of m){let k=i(t.nodes.get(T.fromId)),R=i(t.nodes.get(T.toId)),S=Math.min(k,R),E=Math.max(k,R),N=-1;for(let D=0;D<y.length;D+=1){let I=y[D],M=!0;for(let B of I)if(B.lo<=E&&S<=B.hi){M=!1;break}if(M){I.push({lo:S,hi:E}),N=D;break}}N<0&&(y.push([{lo:S,hi:E}]),N=y.length-1),h.set(T,N)}let v=y.length,w=b>=Math.max(3,v+2),_=w?p+1:p,O=w?d-1:d,x=Math.max(1,O-_+1);for(let T of m){let k=h.get(T),R;if(v<=1)R=_+Math.floor(x/2);else{let S=(x-1)/(v-1);R=_+Math.floor(k*S)}a.set(T,Math.max(p,Math.min(d,R)))}}let u=[];for(let[,c]of n){let l=[];for(let p=0;p<c.length;p+=1){let f=c[p],d=t.nodes.get(f.fromId),b=t.nodes.get(f.toId),m=a.get(f),y=d.isVirtual?o(d):o(d)+s(d),h=b.isVirtual?o(b):o(b)-1,v=i(d),w=i(b);p===0&&Ve(l,r,y,v),v!==w&&(Ve(l,r,m,v),Ve(l,r,m,w)),Ve(l,r,h,w)}let g=c[0];u.push({from:g.chainFrom,to:g.chainTo,points:or(l)})}return u}function Ve(t,e,n,r){t.push(e?{x:n,y:r}:{x:r,y:n})}function or(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 ir(t){let e=0,n=0;for(let r of t.layers)for(let o of r)e=Math.max(e,o.x+o.w),n=Math.max(n,o.y+o.h);return{width:e,height:n}}var ar=24,cr=4,ur=1,dr=3;function Yt(t,e){let n=lr(e.direction),r=Math.max(3,e.maxLabelWidth??ar),o=e.asciiCharset??"unicode",s=Object.keys(t.nodes).sort(),i=new Set(s),a=t.edges.filter(f=>i.has(f.from)&&i.has(f.to)),u=new Map,c=new Map;for(let f of s){let d=jt(f,r);u.set(f,d),c.set(f,je(d)+4)}let l=qt({nodes:s,edges:a,widthCells:f=>c.get(f)??3,heightCells:()=>dr,layerGap:cr,nodeGap:ur,direction:n}),g=zt(l,{charset:o,labelOf:f=>u.get(f)??f}),p=e.logger;return p&&p(g),g}function lr(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 Xt(t,e,n,r={}){let o=e in t.nodes,s=n in t.nodes;if(!o)return He(e,n,"no-such-from");if(!s)return He(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 c=fr(t,e,r);if(c!=null)return c}let u=ze(e,t.nodes[e],0,r);return We(e,n,[u])}if(i===0)return He(e,n,"no-path");let a=Zt(t,e,n,i);return a.found?We(e,n,Qt(t,a.pathOrder,r)):He(e,n,a.truncated?"max-depth-exceeded":"no-path")}function Zt(t,e,n,r){let o=new Map,s=[{path:n,depth:0}],i=new Set([n]),a=0,u=!1;for(;a<s.length;){let g=s[a++];if(g.path===e)break;if(r!=null&&g.depth>=r){let b=t.nodes[g.path];b?.deps&&b.deps.length>0&&(u=!0);continue}let p=t.nodes[g.path];if(p==null)continue;let f=p.deps??[],d=new Map;for(let b=0;b<f.length;b++){let m=f[b];if(!m)continue;let y=d.get(m);y==null&&(y=[],d.set(m,y)),y.push(b)}for(let[b,m]of d)i.has(b)||(i.add(b),o.set(b,{from:g.path,depIndices:m}),s.push({path:b,depth:g.depth+1}))}if(!o.has(e))return{found:!1,pathOrder:[],truncated:u};let c=[{path:e}],l=e;for(;l!==n;){let g=o.get(l);if(g==null)return{found:!1,pathOrder:[],truncated:!1};c[c.length-1].depIndices=g.depIndices,c.push({path:g.from}),l=g.from}return{found:!0,pathOrder:c,truncated:!1}}function fr(t,e,n){let r=t.nodes[e];if(r==null)return null;let o=r.deps??[],s=[];for(let a=0;a<o.length;a++)o[a]===e&&s.push(a);if(s.length>0){let a=ze(e,r,0,n);a.dep_index=s[0];let u=ze(e,r,1,n);return We(e,e,[a,u])}let i=null;for(let a=0;a<o.length;a++){let u=o[a];if(!u||u===e)continue;let c=Zt(t,u,e,n.maxDepth);c.found&&(i==null||c.pathOrder.length<i.pathOrder.length)&&(i=c,i={found:!0,pathOrder:[{path:e,depIndices:[a]},...c.pathOrder],truncated:!1})}return i==null?null:We(e,e,Qt(t,i.pathOrder,n))}function Qt(t,e,n){return e.map((r,o)=>{let s=t.nodes[r.path],i=ze(r.path,s,o,n);return r.depIndices!=null&&r.depIndices.length>0&&(i.dep_index=r.depIndices[0],r.depIndices.length>1&&(i.dep_indices=[...r.depIndices])),i})}function ze(t,e,n,r){let o={path:t,type:e.type,hop:n};e.status!==void 0&&(o.status=e.status),"value"in e&&(o.value=e.value),e.v!=null&&(o.v=e.v);let s=r.annotations?.get(t)??e.annotation;s!=null&&(o.annotation=s);let i=r.lastMutations?.get(t)??e.lastMutation;return i!=null&&(o.lastMutation=i),o}function We(t,e,n){return en(t,e,!0,"ok",n)}function He(t,e,n){return en(t,e,!1,n,[])}function en(t,e,n,r,o){let s=pr(t,e,n,r,o);return{from:t,to:e,found:n,reason:r,steps:o,text:s,toJSON(){return{from:t,to:e,found:n,reason:r,steps:o}}}}function pr(t,e,n,r,o){if(!n)switch(r){case"no-such-from":return`explainPath: no node named "${t}"`;case"no-such-to":return`explainPath: no node named "${e}"`;case"max-depth-exceeded":return`explainPath: no path from "${t}" to "${e}" within maxDepth`;default:return`explainPath: no path from "${t}" to "${e}"`}let s=[`Causal path: ${t} \u2192 ${e} (${o.length} step(s))`];for(let i of o){let u=` ${i.hop===0?"\xB7":"\u2193"} ${i.path} (${i.type}${i.status?`/${i.status}`:""})`;if(s.push(u),"value"in i&&s.push(` value: ${hr(i.value)}`),i.annotation!=null&&s.push(` annotation: ${i.annotation}`),i.lastMutation!=null){let c=i.lastMutation.actor;s.push(` actor: ${c.type}${c.id?`:${c.id}`:""}`)}}return s.join(`
|
|
3
3
|
`)}function hr(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)}}he();var F={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},gr=Symbol.for("sizeof");function tn(t){let e=new WeakSet,n=new WeakSet,r=[t],o=0;for(;r.length>0;){let s=r.pop();o+=mr(s,e,n,r)}return o}function mr(t,e,n,r){if(t==null)return 0;switch(typeof t){case"number":return F.number;case"boolean":return F.boolean;case"string":return F.string+t.length*2;case"bigint":return F.bigint+br(t);case"symbol":return F.symbol;case"function":return e.has(t)?0:(e.add(t),F.function);case"undefined":return 0}let s=t;if(e.has(s))return 0;e.add(s);let i=s[gr];if(typeof i=="function")try{let c=i.call(s);if(typeof c=="number"&&Number.isFinite(c))return c}catch{}if(s instanceof Date)return F.date;if(s instanceof RegExp)return F.regexp+s.source.length*2;if(s instanceof Error){let c=s.message?s.message.length*2:0,l=s.stack?s.stack.length*2:0;return F.error+c+l}if(typeof URL<"u"&&s instanceof URL)return F.url+s.href.length*2;if(typeof Promise<"u"&&s instanceof Promise)return F.promise;if(s instanceof WeakMap)return F.weakmap;if(s instanceof WeakSet)return F.weakset;if(s instanceof Map){let c=F.map;for(let[l,g]of s)c+=F.mapEntry,r.push(l),r.push(g);return c}if(s instanceof Set){let c=F.set;for(let l of s)c+=F.setEntry,r.push(l);return c}if(Array.isArray(s)){let c=F.array+s.length*8;for(let l of s)r.push(l);return c}if(s instanceof ArrayBuffer)return n.has(s)?0:(n.add(s),s.byteLength);if(ArrayBuffer.isView(s)){let c=s;return n.has(c.buffer)?48:(n.add(c.buffer),c.buffer.byteLength+48)}let a=F.object,u=Object.keys(s);for(let c of u){a+=F.string+c.length*2;try{r.push(s[c])}catch{}}return a}function br(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 nn(t,e){let n=e?.topN??10,r=t.describe({detail:"standard"}),o=[],s=t._collectObserveTargets;typeof s=="function"&&s.call(t,"",o);let i=new Map;for(let[p,f]of o)i.set(p,f);let a=[];for(let[p,f]of Object.entries(r.nodes)){let d=i.get(p),b=d instanceof P?d:null,m=b?tn(b.cache):0,y=b?b._sinkCount:0,h=f.deps?.length??0,v=f.type==="effect"&&y===0,w=y===0?f.type==="effect"?"orphan-effect":f.type==="derived"?"idle-derived":f.type==="producer"?"idle-producer":null:null;a.push({path:p,type:f.type,status:f.status??"unknown",valueSizeBytes:m,subscriberCount:y,depCount:h,isOrphanEffect:v,orphanKind:w})}let u=a.reduce((p,f)=>p+f.valueSizeBytes,0),c=(p,f)=>[...a].sort(f??((d,b)=>b[p]-d[p])).slice(0,n),l=a.filter(p=>p.orphanKind!=null),g=a.filter(p=>p.isOrphanEffect);return{nodeCount:a.length,edgeCount:r.edges.length,subgraphCount:r.subgraphs.length,nodes:a,totalValueSizeBytes:u,hotspots:{byValueSize:c("valueSizeBytes"),bySubscriberCount:c("subscriberCount"),byDepCount:c("depCount")},orphans:l,orphanEffects:g}}var $="::",U="__meta__",me=1;function rn(t,e){let n=Math.max(16,t.size*4),r=0;for(;t.size>0;){if(r++>=n){console.error(`[Graph "${e}".destroy] disposer drain exceeded cap (${n}); ${t.size} disposer(s) discarded`),t.clear();return}let o=t.values().next();if(o.done)return;let s=o.value;t.delete(s);try{s()}catch(i){console.error(`[Graph "${e}".destroy] disposer threw:`,i)}}}function yr(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 sn(t){if(t.version!==me)throw new Error(`unsupported snapshot version ${String(t.version)} (expected ${me})`);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 vr(t,e){let n=new WeakMap,r=(o,s)=>{if(Object.is(o,s))return!0;if(o==null||s==null||typeof o!="object"||typeof s!="object")return!1;let i=n.get(o);if(i==null&&(i=new WeakSet,n.set(o,i)),i.has(s))return!0;i.add(s);let a=o.constructor,u=s.constructor;if(a!==u)return!1;if(o instanceof Date)return o.getTime()===s.getTime();if(o instanceof RegExp)return o.source===s.source&&o.flags===s.flags;if(Array.isArray(o)){let p=s;if(o.length!==p.length)return!1;for(let f=0;f<o.length;f++)if(!r(o[f],p[f]))return!1;return!0}if(o instanceof Map){let p=s;if(o.size!==p.size)return!1;for(let[f,d]of o)if(!p.has(f)||!r(d,p.get(f)))return!1;return!0}if(o instanceof Set){let p=s;if(o.size!==p.size)return!1;for(let f of o){let d=!1;for(let b of p)if(r(f,b)){d=!0;break}if(!d)return!1}return!0}if(ArrayBuffer.isView(o)){let p=o,f=s;if(p.length!==f.length)return!1;for(let d=0;d<p.length;d++)if(p[d]!==f[d])return!1;return!0}let c=Object.keys(o),l=Object.keys(s);if(c.length!==l.length)return!1;let g=new Set(l);for(let p of c)if(!g.has(p)||!r(o[p],s[p]))return!1;return!0};return r(t,e)}function yt(t){if(t===null||typeof t!="object")return t;if(Array.isArray(t))return t.map(yt);let e=t,n=Object.keys(e).sort(),r={};for(let o of n)r[o]=yt(e[o]);return r}function wr(t){return t.replaceAll("\\","\\\\").replaceAll('"','\\"')}function _r(t){return t.replaceAll("\\","\\\\").replaceAll('"','\\"')}function xr(t){return t==="TD"?"down":t==="BT"?"up":t==="RL"?"left":"right"}function cn(t){let e=new Set,n=[];function r(o,s){let i=`${o}\0${s}`;e.has(i)||(e.add(i),n.push([o,s]))}for(let[o,s]of Object.entries(t.nodes)){let i=s.deps;if(i)for(let a of i)r(a,o)}for(let o of t.edges)r(o.from,o.to);return n}function un(t){if(t===void 0)return"LR";if(t==="TD"||t==="LR"||t==="BT"||t==="RL")return t;throw new Error(`invalid diagram direction ${String(t)}; expected one of: TD, LR, BT, RL`)}function Sr(t,e){let n=e.includeEdges??!0,r=e.includeSubgraphs??!0,{expand:o,...s}=t,i={...s,edges:n?t.edges:[],subgraphs:r?t.subgraphs:[]},a=JSON.stringify(yt(i),null,e.indent??2);return e.logger?.(a),a}function
|
|
4
|
+
`)}function sn(t){if(t.version!==me)throw new Error(`unsupported snapshot version ${String(t.version)} (expected ${me})`);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 vr(t,e){let n=new WeakMap,r=(o,s)=>{if(Object.is(o,s))return!0;if(o==null||s==null||typeof o!="object"||typeof s!="object")return!1;let i=n.get(o);if(i==null&&(i=new WeakSet,n.set(o,i)),i.has(s))return!0;i.add(s);let a=o.constructor,u=s.constructor;if(a!==u)return!1;if(o instanceof Date)return o.getTime()===s.getTime();if(o instanceof RegExp)return o.source===s.source&&o.flags===s.flags;if(Array.isArray(o)){let p=s;if(o.length!==p.length)return!1;for(let f=0;f<o.length;f++)if(!r(o[f],p[f]))return!1;return!0}if(o instanceof Map){let p=s;if(o.size!==p.size)return!1;for(let[f,d]of o)if(!p.has(f)||!r(d,p.get(f)))return!1;return!0}if(o instanceof Set){let p=s;if(o.size!==p.size)return!1;for(let f of o){let d=!1;for(let b of p)if(r(f,b)){d=!0;break}if(!d)return!1}return!0}if(ArrayBuffer.isView(o)){let p=o,f=s;if(p.length!==f.length)return!1;for(let d=0;d<p.length;d++)if(p[d]!==f[d])return!1;return!0}let c=Object.keys(o),l=Object.keys(s);if(c.length!==l.length)return!1;let g=new Set(l);for(let p of c)if(!g.has(p)||!r(o[p],s[p]))return!1;return!0};return r(t,e)}function yt(t){if(t===null||typeof t!="object")return t;if(Array.isArray(t))return t.map(yt);let e=t,n=Object.keys(e).sort(),r={};for(let o of n)r[o]=yt(e[o]);return r}function wr(t){return t.replaceAll("\\","\\\\").replaceAll('"','\\"')}function _r(t){return t.replaceAll("\\","\\\\").replaceAll('"','\\"')}function xr(t){return t==="TD"?"down":t==="BT"?"up":t==="RL"?"left":"right"}function cn(t){let e=new Set,n=[];function r(o,s){let i=`${o}\0${s}`;e.has(i)||(e.add(i),n.push([o,s]))}for(let[o,s]of Object.entries(t.nodes)){let i=s.deps;if(i)for(let a of i)r(a,o)}for(let o of t.edges)r(o.from,o.to);return n}function un(t){if(t===void 0)return"LR";if(t==="TD"||t==="LR"||t==="BT"||t==="RL")return t;throw new Error(`invalid diagram direction ${String(t)}; expected one of: TD, LR, BT, RL`)}function Sr(t,e){let n=e.includeEdges??!0,r=e.includeSubgraphs??!0,{expand:o,...s}=t,i={...s,edges:n?t.edges:[],subgraphs:r?t.subgraphs:[]},a=JSON.stringify(yt(i),null,e.indent??2);return e.logger?.(a),a}function Tr(t,e){let n=e.includeEdges??!0,r=e.includeSubgraphs??!0,o=[];o.push(`Graph ${t.name}`),o.push("Nodes:");for(let i of Object.keys(t.nodes).sort()){let a=t.nodes[i];o.push(`- ${i} (${a.type}/${a.status}): ${Ke(a.value)}`)}if(n){o.push("Edges:");for(let i of t.edges)o.push(`- ${i.from} -> ${i.to}`)}if(r){o.push("Subgraphs:");for(let i of t.subgraphs)o.push(`- ${i}`)}let s=o.join(`
|
|
5
5
|
`);return e.logger?.(s),s}function dn(t,e){let n=un(e.direction),r=Object.keys(t.nodes).sort(),o=new Map;for(let i=0;i<r.length;i+=1)o.set(r[i],`n${i}`);let s=[`flowchart ${n}`];for(let i of r){let a=o.get(i);s.push(` ${a}["${wr(i)}"]`)}for(let[i,a]of cn(t)){let u=o.get(i),c=o.get(a);!u||!c||s.push(` ${u} --> ${c}`)}return s.join(`
|
|
6
|
-
`)}function
|
|
7
|
-
`)}function Er(t){return t.replace(/[.*+?^${}()|[\]\\]/g,"\\$&")}function Ue(t){let e="^";for(let n=0;n<t.length;n+=1){let r=t[n];if(r==="*"){e+=".*";continue}if(r==="?"){e+=".";continue}if(r==="["){let o=t.indexOf("]",n+1);if(o<=n+1){e+="\\[";continue}let s=t.slice(n+1,o);s.startsWith("!")&&(s=`^${s.slice(1)}`),s=s.replace(/\\/g,"\\\\"),e+=`[${s}]`,n=o;continue}e+=Er(r)}return e+="$",new RegExp(e)}var Rr={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"},Ar={data:"",dirty:"",resolved:"",invalidate:"",pause:"",resume:"",complete:"",error:"",teardown:"",derived:"",path:"",reset:""};function Ke(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 Dr(t){return t==="none"?Ar:t==="ansi"||t==null?Rr:{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 on(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 Cr(t,e,n){for(let r=0;r<t.length;r++){let o=t.charCodeAt(r);if(o<32||o===127)throw new Error(`Graph "${e}": ${n} "${t}" must not contain control character (U+${o.toString(16).padStart(4,"0").toUpperCase()} at index ${r})`)}}function bt(t,e,n){if(t==="")throw new Error(`Graph "${e}": ${n} name must be non-empty`);if(t.includes($))throw new Error(`Graph "${e}": ${n} "${t}" must not contain '${$}' (path separator)`);if(t===U)throw new Error(`Graph "${e}": ${n} name "${U}" is reserved for meta companion paths`);Cr(t,e,n)}function Mr(t,e){if(t==="")throw new Error(`Graph "${e}": resolve path must be non-empty`);let n=t.split($);for(let r of n)if(r==="")throw new Error(`Graph "${e}": resolve path has empty segment`);return n}function Gr(t,e){let n=!1;for(let o of t)if(!e.isMetaPassthrough(o[0])){n=!0;break}return n?t.filter(o=>e.isMetaPassthrough(o[0])):t}function ln(t){for(let e of t._mounts.values())ln(e);for(let e of t._nodes.values())try{e.down([[V]],{internal:!0})}catch{}}var be=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($))throw new Error(`Graph name must not contain '${$}' (got "${e}")`);if(e===U)throw new Error(`Graph name "${U}" is reserved for meta companion paths`);this.name=e,this.opts=Object.freeze({...n??{}}),this.config=n?.config??pe,this._traceRing=new Oe(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=Se(e=>{let n=r=>{e.emit(r)};return this._topologyEmitters.add(n),()=>{this._topologyEmitters.delete(n)}},{name:`${this.name}_topology`})),this._topology}_emitTopology(e){if(!(this._topology==null||this._topologyEmitters.size===0))for(let n of this._topologyEmitters)n(e)}add(e,n){let r=e.name,o=n?.name??r;if(o==null||o==="")throw new Error(`Graph "${this.name}": graph.add requires a non-empty name \u2014 pass via opts.name or set it on the node (e.g. state(0, { name: "x" }))`);let s=o,i=n?.annotation;if(bt(s,this.name,"add"),this._mounts.has(s))throw new Error(`Graph "${this.name}": name "${s}" is already a mount point`);if(this._nodes.has(s))throw new Error(`Graph "${this.name}": node "${s}" already exists`);let a=this._nodeToName.get(e);if(a!==void 0)throw new Error(`Graph "${this.name}": node instance already registered as "${a}"`);return this._nodes.set(s,e),this._nodeToName.set(e,s),this._emitTopology({kind:"added",name:s,nodeKind:"node"}),i!=null&&(this._annotations.set(s,i),this.config.inspectorEnabled&&this._traceRing.push({path:s,annotation:i,timestamp_ns:de()})),e}setVersioning(e){if(e!=null)for(let n of this._nodes.values())n instanceof P&&n._applyVersioning(e)}remove(e){bt(e,this.name,"remove");let n=this._mounts.get(e);if(n){let s={kind:"mount",nodes:[],mounts:[]},i=[];n._collectObserveTargets("",i);for(let[a,u]of i)a.includes(`${$}${U}${$}`)||s.nodes.push(a);return s.nodes.sort(),s.mounts.push(e),s.mounts.push(...n._collectSubgraphs(`${e}${$}`)),this._mounts.delete(e),n._parent=void 0,ln(n),this._emitTopology({kind:"removed",name:e,nodeKind:"mount",audit:s}),s}let r=this._nodes.get(e);if(!r)throw new Error(`Graph "${this.name}": unknown node or mount "${e}"`);this._nodes.delete(e),this._nodeToName.delete(r),r.down([[V]],{internal:!0});let o={kind:"node",nodes:[e],mounts:[]};return this._emitTopology({kind:"removed",name:e,nodeKind:"node",audit:o}),o}removeAll(e){let n=typeof e=="function"?e:(()=>{let s=Ue(e);return i=>s.test(i)})(),r={kind:"mount",nodes:[],mounts:[]},o=[...this._nodes.keys(),...this._mounts.keys()].filter(s=>n(s));for(let s of o){let i=this.remove(s);r.nodes.push(...i.nodes),r.mounts.push(...i.mounts)}return r.nodes.sort(),r.mounts.sort(),r}[Symbol.iterator](){let e=[...this._nodes.keys()].sort(),n=this._nodes,r=0;return{[Symbol.iterator](){return this},next(){if(r>=e.length)return{value:void 0,done:!0};let o=e[r++];return{value:[o,n.get(o)],done:!1}}}}node(e){if(e==="")throw new Error(`Graph "${this.name}": node name must be non-empty`);if(e.includes($))return this.resolve(e);let n=this._nodes.get(e);if(!n)throw new Error(`Graph "${this.name}": unknown node "${e}"`);return n}get(e){return this.node(e).cache}set(e,n,r){let o=r?.internal===!0;this.node(e).down([[j,n]],{actor:r?.actor,internal:o,delivery:"write"})}setAll(e,n){let r=Symbol.iterator in e?e:Object.entries(e);Re(()=>{for(let[o,s]of r)this.set(o,s,n)})}invalidate(e,n){let r=n?.internal===!0;this.node(e).down([[Z]],{actor:n?.actor,internal:r,delivery:"write"})}error(e,n,r){let o=r?.internal===!0;this.node(e).down([[I,n]],{actor:r?.actor,internal:o,delivery:"write"})}complete(e,n){let r=n?.internal===!0;this.node(e).down([[W]],{actor:n?.actor,internal:r,delivery:"write"})}edges(e){let n=e?.recursive===!0,r=new Map;if(!n){for(let[u,c]of this._nodes)r.set(c,u);let a=[];for(let[u,c]of this._nodes)if(c instanceof P)for(let l of c._deps){let g=r.get(l.node);g!=null&&a.push([g,u])}return a.sort((u,c)=>u[0]<c[0]?-1:u[0]>c[0]?1:u[1]<c[1]?-1:u[1]>c[1]?1:0),a}let o=[];this._collectObserveTargets("",o);let s=new Map;for(let[a,u]of o)s.set(u,a);let i=[];for(let[a,u]of o)if(u instanceof P)for(let c of u._deps){let l=s.get(c.node);l!=null&&i.push([l,a])}return i.sort((a,u)=>a[0]<u[0]?-1:a[0]>u[0]?1:a[1]<u[1]?-1:a[1]>u[1]?1:0),i}mount(e,n){if(bt(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=Mr(e,this.name);return this._resolveFromSegments(n)}tryResolve(e){try{return this.resolve(e)}catch{return}}_resolveFromSegments(e){let n=e;if(n[0]===this.name&&(n=n.slice(1),n.length===0))throw new Error(`Graph "${this.name}": resolve path ends at graph name only`);let r=n[0],o=n.slice(1);if(o.length===0){let a=this._nodes.get(r);if(a)return a;throw this._mounts.has(r)?new Error(`Graph "${this.name}": path ends at subgraph "${r}" \u2014 not a node (GRAPHREFLY-SPEC \xA73.5)`):new Error(`Graph "${this.name}": unknown name "${r}"`)}let s=this._nodes.get(r);if(s&&o.length>0&&o[0]===U)return this._resolveMetaChainFromNode(s,o,n.join($));let i=this._mounts.get(r);if(!i)throw this._nodes.has(r)?new Error(`Graph "${this.name}": "${r}" is a node; trailing path "${o.join($)}" is invalid`):new Error(`Graph "${this.name}": unknown mount or node "${r}"`);return i.resolve(o.join($))}_resolveMetaChainFromNode(e,n,r){let o=e,s=0,i=[...n];for(;s<i.length;){if(i[s]!==U)throw new Error(`Graph "${this.name}": expected ${U} segment in meta path "${r}"`);if(s+1>=i.length)throw new Error(`Graph "${this.name}": meta path requires a key after ${U} in "${r}"`);let a=i[s+1],u=o.meta[a];if(!u)throw new Error(`Graph "${this.name}": unknown meta "${a}" in path "${r}"`);o=u,s+=2}return o}signal(e,n){if(n?.internal!==!0){for(let o of e)if(this.config.messageTier(o[0])===3)throw new Error(`Graph "${this.name}": Graph.signal() rejects tier-3 messages (DATA / RESOLVED). Broadcast is for control-plane tiers (START / DIRTY / INVALIDATE / PAUSE / RESUME / COMPLETE / ERROR / TEARDOWN). For per-node value writes, use Graph.set or graph.node(name).down(...).`)}let r=[];if(this._signalDeliver(e,n??{},new Set,r),r.length>0)throw r[0]}_signalDeliver(e,n,r,o){for(let u of this._mounts.values())u._signalDeliver(e,n,r,o);let i=n.internal===!0?{internal:!0}:{actor:n.actor,delivery:"signal"},a=Gr(e,this.config);for(let u of[...this._nodes.keys()].sort()){let c=this._nodes.get(u);if(!r.has(c)){r.add(c);try{c.down(e,i)}catch(l){if(l instanceof Y)throw l;o.push(l)}a.length!==0&&this._signalMetaSubtree(c,a,r,i,o)}}}_signalMetaSubtree(e,n,r,o,s){for(let i of Object.keys(e.meta).sort()){let a=e.meta[i];if(!r.has(a)){r.add(a);try{a.down(n,o)}catch(u){if(u instanceof Y)throw u;s.push(u)}this._signalMetaSubtree(a,n,r,o,s)}}}describe(e){if(e?.reactive===!0)return this._describeReactive(e);let n=e?.actor,r=e?.filter,o=Pe(e?.detail,e?.fields),s=e?.format==="spec",i=s?Pe("minimal"):o,a=[];this._collectObserveTargets("",a);let u=new Map;for(let[T,x]of a)u.set(x,T);let c=[];{let T=a.map(([,k])=>k),x=new Set(u.values()),O=0;for(;T.length>0;){let k=T.shift();if(k instanceof P)for(let R of k._deps){let S=R.node;if(u.has(S))continue;let E=S.name??"",N=E;if(!N||x.has(N))if(E){let D=2;for(;x.has(`${E}#${D}`);)D++;N=`${E}#${D}`}else for(N=`__internal__/${O++}`;x.has(N);)N=`__internal__/${O++}`;u.set(S,N),x.add(N),c.push([N,S]),T.push(S)}}}let l=[...a,...c],g={};for(let[T,x]of l){if(n!=null&&!x.allowsObserve(n))continue;let O=ht(x,i),k=x instanceof P?x._deps.map(N=>u.get(N.node)??N.node.name??""):[],{name:R,...S}=O,E={...S,deps:k};if(!s){let N=this._annotations.get(T);N!=null&&(E.annotation=N)}if(r!=null)if(typeof r=="function"){let N=r;if(!(N.length>=2?N(T,E):N(E)))continue}else{let N=!0;for(let[D,L]of Object.entries(r)){let M=D==="deps_includes"?"depsIncludes":D==="meta_has"?"metaHas":D;if(M==="depsIncludes"){if(!E.deps.includes(String(L))){N=!1;break}continue}if(M==="metaHas"){if(!Object.hasOwn(E.meta??{},String(L))){N=!1;break}continue}if(E[M]!==L){N=!1;break}}if(!N)continue}g[T]=E}let p=new Set(Object.keys(g)),f=[];for(let[T,x]of l)if(x instanceof P)for(let O of x._deps){let k=u.get(O.node);k!=null&&f.push([k,T])}f.sort((T,x)=>T[0]<x[0]?-1:T[0]>x[0]?1:T[1]<x[1]?-1:T[1]>x[1]?1:0);let d=f.map(([T,x])=>({from:T,to:x}));(n!=null||r!=null)&&(d=d.filter(T=>p.has(T.from)&&p.has(T.to)));let b=this._collectSubgraphs(""),m=n!=null||r!=null?b.filter(T=>{let x=`${T}${$}`;return[...p].some(O=>O===T||O.startsWith(x))}):b,y=this,h=e,v={name:this.name,nodes:g,edges:d,subgraphs:m,expand(T){let x={...h,format:void 0};return Array.isArray(T)?(x.fields=T,x.detail=void 0):(x.detail=T,x.fields=void 0),y.describe(x)}},w=e??{},_=w.format;return _==="json"?Sr(v,w):_==="pretty"?Or(v,w):_==="mermaid"?dn(v,w):_==="mermaid-url"?Tr(v,w):_==="d2"?kr(v,w):_==="ascii"?Yt(v,w):v}_collectSubgraphs(e){let n=[];for(let r of[...this._mounts.keys()].sort()){let o=e===""?r:`${e}${r}`;n.push(o),n.push(...this._mounts.get(r)._collectSubgraphs(`${o}${$}`))}return n}resourceProfile(e){return nn(this,e)}reachable(e,n,r={}){return r.withDetail===!0?an(this.describe(),e,n,{...r,withDetail:!0}):an(this.describe(),e,n,r)}explain(e,n,r){return r?.reactive===!0?this._explainReactive(e,n,r):this._explainStatic(e,n,r)}_explainStatic(e,n,r){let o=this.describe({detail:"full"}),s=new Map(this._annotations),i=new Map;for(let[a,u]of Object.entries(o.nodes))u.lastMutation!=null&&i.set(a,u.lastMutation);return Xt(o,e,n,{...r?.maxDepth!=null?{maxDepth:r.maxDepth}:{},...r?.findCycle===!0?{findCycle:!0}:{},annotations:s,lastMutations:i})}_describeReactive(e){let n={...e,reactive:!1},r=e.reactiveName??"describe",o=0,s=te(o,{name:`${r}_version`}),i=this.observe({timeline:!0,structured:!0}),a=!1,u=!1,c=()=>{a||u||(a=!0,_e(()=>{a=!1,!u&&(o+=1,s.emit(o))}))},l=i.onEvent(m=>{let y=m.type;y!=="data"&&y!=="error"&&y!=="complete"&&y!=="teardown"||c()}),g=[],p=new WeakSet,f=m=>{if(p.has(m)||u)return;p.add(m);let y=m.topology.subscribe(h=>{for(let v of h){if(v[0]!==j)continue;let w=v[1];if(c(),w.kind==="added"&&w.nodeKind==="mount"){let _=m._mounts.get(w.name);_!=null&&f(_)}}});g.push(y);for(let h of m._mounts.keys()){let v=m._mounts.get(h);v!=null&&f(v)}};f(this);let d;try{d=ie([s],()=>this.describe(n),{name:r,describeKind:"derived",meta:{domain:"audit",kind:"describe"},equals:(m,y)=>m===y})}catch(m){l();for(let y of g)y();throw i.dispose(),m}let b=ge(d);return{node:d,dispose(){u=!0,l();for(let m of g)m();g.length=0,i.dispose(),b()}}}_explainReactive(e,n,r){let o=0,s=te(o,{name:"explain_version"}),i=this.observe({timeline:!0,structured:!0}),a=!1,u=!1,c=i.onEvent(f=>{let d=f.type;d!=="data"&&d!=="error"&&d!=="complete"&&d!=="teardown"||a||u||(a=!0,_e(()=>{a=!1,!u&&(o+=1,s.emit(o))}))}),l={...r?.maxDepth!=null?{maxDepth:r.maxDepth}:{},...r?.findCycle===!0?{findCycle:!0}:{}},g;try{g=ie([s],()=>this._explainStatic(e,n,l),{name:r?.name??"explain",describeKind:"derived",meta:{domain:"audit",kind:"explain_path",from:e,to:n},equals:(f,d)=>f.found===d.found&&f.reason===d.reason&&f.steps.length===d.steps.length&&Lr(f.steps,d.steps)})}catch(f){throw c(),i.dispose(),f}let p=ge(g);return{node:g,dispose(){u=!0,c(),i.dispose(),p()}}}_pathsMatching(e){let n=Ue(e),r=[];return this._collectObserveTargets("",r),r.map(([o])=>o).filter(o=>n.test(o))}_collectObserveTargets(e,n){for(let r of[...this._mounts.keys()].sort()){let o=e===""?r:`${e}${$}${r}`;this._mounts.get(r)._collectObserveTargets(o,n)}for(let r of[...this._nodes.keys()].sort()){let o=this._nodes.get(r),s=e===""?r:`${e}${$}${r}`;n.push([s,o]),this._appendMetaObserveTargets(s,o,n)}}_appendMetaObserveTargets(e,n,r){for(let o of Object.keys(n.meta).sort()){let s=n.meta[o],i=`${e}${$}${U}${$}${o}`;r.push([i,s]),this._appendMetaObserveTargets(i,s,r)}}observe(e,n){let r=typeof e=="string",s=on(r?n:e),i=s.structured===!0||s.timeline===!0||s.causal===!0||s.derived===!0||s.detail==="minimal"||s.detail==="full"||s.format!=null,a=s.actor;if(r){let l=e,g=this.resolve(l);if(a!=null&&!g.allowsObserve(a))throw new Y({actor:a,action:"observe",nodeName:l});return i?this._buildStructuredObserver([[l,g]],s,"one"):{subscribe(p){return g.subscribe(p)},up(p){try{g.up?.(p)}catch(f){if(f instanceof Y)return;throw f}}}}let u=[];this._collectObserveTargets("",u),u.sort((l,g)=>l[0]<g[0]?-1:l[0]>g[0]?1:0);let c=a==null?u:u.filter(([,l])=>l.allowsObserve(a));return i?this._buildStructuredObserver(c,s,"all"):{subscribe:l=>{let g=c.map(([p,f])=>f.subscribe(d=>{l(p,d)}));return()=>{for(let p of g)p()}},up:(l,g)=>{try{this.resolve(l).up?.(g)}catch(p){if(p instanceof Y)return;throw p}}}}_buildStructuredObserver(e,n,r){let o=r==="one"?e[0]?.[0]:void 0,s=i=>{if(r==="one"&&o!=null){let l=this.resolve(o);return this._buildStructuredObserver([[o,l]],i,"one")}let a=[];this._collectObserveTargets("",a),a.sort((l,g)=>l[0]<g[0]?-1:l[0]>g[0]?1:0);let u=i.actor,c=u==null?a:a.filter(([,l])=>l.allowsObserve(u));return this._buildStructuredObserver(c,i,"all")};return this._createObserveResult(e,n,s)}_createObserveResult(e,n,r){let o=n.timeline===!0,s=n.causal===!0,i=n.derived===!0,a=n.detail==="minimal",u=this.config.inspectorEnabled,c=(s||i)&&u,l=n.maxEvents,g=l!=null&&l>0?new Oe(l):null,p=[],f=new Set,d={},b=new Set,m=0,y=0,h=0,v=0,w=0,_=0,T=!1,x=!1,O=0,k=new Map,R=new Map,S=new Map,E=A=>{g?g.push(A):p.push(A);for(let G of f)G(A)},N=()=>o?{timestamp_ns:de(),in_batch:Ee(),batch_id:O}:{},D=(A,G)=>{if(!(!c||!(A instanceof P)))return A._setInspectorHook(K=>{if(K.kind==="dep_message")k.set(A,K.depIndex);else if(K.kind==="run"){let ye=K.batchData.map((C,H)=>C!=null&&C.length>0?C.at(-1):K.prevData[H]);R.set(A,ye);let q=K.batchData.map(C=>C!=null?[...C]:void 0);S.set(A,q),i&&E({type:"derived",path:G,dep_values:ye,dep_batches:q,...N()})}})},L=A=>{let G=k.get(A),K=R.get(A);if(!s||K==null)return{};let q=(G!=null&&G>=0&&A instanceof P?A._deps[G]:void 0)?.node,C=q?.v,H=S.get(A);return{trigger_dep_index:G,trigger_dep_name:q?.name,...C!=null?{trigger_version:{id:C.id,version:C.version}}:{},dep_values:[...K],...H!=null?{dep_batches:H}:{}}},M=[],B=[];for(let[A,G]of e){let K=D(G,A);K&&M.push(K),B.push(G.subscribe(ye=>{O++;for(let q of ye){let C=q[0],H=N();if(C===j){d[A]=q[1];let Ze=G instanceof P?G.lastMutation?.actor??ae:ae;E({type:"data",path:A,data:q[1],actor:Ze,...H,...L(G)})}else if(a)C===z?m++:C===X?y++:C===Z?h++:C===Q?v++:C===ee?w++:C===V?_++:C===W&&!b.has(A)?T=!0:C===I&&(x=!0,b.add(A));else if(C===z)m++,E({type:"dirty",path:A,...H});else if(C===X)y++,E({type:"resolved",path:A,...H,...L(G)});else if(C===Z)h++,E({type:"invalidate",path:A,...H});else if(C===Q)v++,E({type:"pause",path:A,lockId:q[1],...H});else if(C===ee)w++,E({type:"resume",path:A,lockId:q[1],...H});else if(C===W)b.has(A)||(T=!0),E({type:"complete",path:A,...H});else if(C===I){x=!0,b.add(A);let Ze=G instanceof P?G.lastMutation?.actor??ae:ae;E({type:"error",path:A,data:q[1],actor:Ze,...H})}else C===V&&(_++,E({type:"teardown",path:A,...H}))}}))}let Je=!1,Ye=()=>{if(!Je){Je=!0;for(let A of B)A();for(let A of M)A();for(let A of Ne)A({value:void 0,done:!0});Ne.length=0}},Xe=[],Ne=[];f.add(A=>{let G=Ne.shift();G?G({value:A,done:!1}):Xe.push(A)});let xt={get values(){return d},get dirtyCount(){return m},get resolvedCount(){return y},get invalidateCount(){return h},get pauseCount(){return v},get resumeCount(){return w},get teardownCount(){return _},get events(){return g?g.toArray():[...p]},get anyCompletedCleanly(){return T},get anyErrored(){return x},get completedWithoutErrors(){return T&&!x},onEvent(A){return f.add(A),()=>f.delete(A)},dispose:Ye,expand(A){Ye();let G={...n};return typeof A=="string"?G.detail=A:Object.assign(G,A),r(on(G))},[Symbol.asyncIterator](){return{next(){return Xe.length>0?Promise.resolve({value:Xe.shift(),done:!1}):Je?Promise.resolve({value:void 0,done:!0}):new Promise(A=>Ne.push(A))},return(){return Ye(),Promise.resolve({value:void 0,done:!0})}}}};return n.format!=null&&this._attachFormatLogger(xt,n),xt}_attachFormatLogger(e,n){let r=n.format;if(r==null)return;let o=n.logger??(d=>console.log(d)),s=n.includeTypes?new Set(n.includeTypes):null,i=n.excludeTypes?new Set(n.excludeTypes):null,a=s==null&&i==null?()=>!0:d=>(s==null||s.has(d))&&(i==null||!i.has(d)),u=Dr(n.theme),c=r==="stage-log"?de():0,l=d=>d==null?"":n.stageLabels?.[d]??d,g=(d,b)=>d.length>b?`${d.slice(0,b-1)}\u2026`:d,p=d=>d.type==="data"||d.type==="error"?g(Ke(d.data),120):"",f=d=>{if(r==="stage-log"){let x=(de()-c)/1e9,O=l(d.path).padEnd(9);if(d.type==="data"){let k=p(d);return`[${x.toFixed(3)}s] ${O} \u2190${k?` ${k}`:""}`}if(d.type==="error"){let k=p(d);return`[${x.toFixed(3)}s] ${O} \u2717${k?` ${k}`:""}`}return d.type==="complete"?`[${x.toFixed(3)}s] ${O} \u25A0 complete`:`[${x.toFixed(3)}s] ${O} ${d.type}`}if(r==="json")try{return JSON.stringify(d)}catch{return JSON.stringify({type:d.type,path:d.path,data:"[unserializable]"})}let b=u[d.type]??"",m=d.path?`${u.path}${d.path}${u.reset} `:"",y=d.type==="data"||d.type==="error",h=d.type==="pause"||d.type==="resume",v=y?` ${Ke(d.data)}`:h?` ${Ke(d.lockId)}`:"",w=d.type==="data"||d.type==="resolved"||d.type==="derived"?d:void 0,_=w?.trigger_dep_name!=null?` <- ${w.trigger_dep_name}`:w?.trigger_dep_index!=null?` <- #${w.trigger_dep_index}`:"",T=d.in_batch?" [batch]":"";return`${m}${b}${d.type.toUpperCase()}${u.reset}${v}${_}${T}`};e.onEvent(d=>{a(d.type)&&o(f(d),d)})}addDisposer(e){return this._disposers.add(e),()=>{this._disposers.delete(e)}}destroy(){rn(this._disposers,this.name),this.signal([[V]],{internal:!0}),rn(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"}),o={};for(let a of Object.keys(r.nodes).sort()){let{lastMutation:u,guard:c,...l}=r.nodes[a];o[a]=l}let s=[...r.subgraphs].sort(),i={...r,version:1,nodes:o,subgraphs:s};if(e?.format==null)return i;if(e.format==="json-string")return JSON.stringify(i);if(e.format==="bytes"){if(e.codec==null)throw new Error("snapshot({format: 'bytes'}) requires a `codec` name");let a=this.config.lookupCodec(e.codec);if(a==null)throw new Error(`snapshot: codec "${e.codec}" is not registered on this graph's config. Call config.registerCodec(...) before creating nodes.`);return Ot(a,a.encode(i))}throw new Error(`snapshot: unknown format "${String(e.format)}"`)}static decode(e,n){let r=n?.config??pe,{codec:o,codecVersion:s,payload:i}=Tt(e,r);return o.decode(i,s)}restore(e,n){if(sn(e),e.name!==this.name)throw new Error(`Graph "${this.name}": restore snapshot name "${e.name}" does not match this graph`);let r=n?.only==null?null:(Array.isArray(n.only)?n.only:[n.only]).map(s=>Ue(s)),o=n?.includeProducers===!0;for(let s of Object.keys(e.nodes).sort()){if(r!==null&&!r.some(a=>a.test(s)))continue;let i=e.nodes[s];if(i!==void 0){if(!("value"in i)||i.value===void 0){"value"in i&&i.value===void 0&&n?.onError?.(s,new Error(`restore: slice.value is undefined for "${s}" (undefined is the global SENTINEL; not valid DATA)`));continue}if(!(i.type==="derived"||i.type==="effect")&&!(i.type==="producer"&&!o)){if(i.v!=null){let u=this.tryResolve(s)?.v;if(u!=null&&u.id===i.v.id&&u.version===i.v.version)continue}try{this.set(s,i.value)}catch(a){n?.onError?.(s,a)}}}}}static fromSnapshot(e,n){sn(e);let r=typeof n=="function"?n:n?.build,o=typeof n=="function"?void 0:n?.factories,s=new t(e.name);if(r)return r(s),s.restore(e),s;for(let f of[...e.subgraphs].sort((d,b)=>{let m=d.split($).length,y=b.split($).length;return m!==y?m-y:d<b?-1:d>b?1:0})){let d=f.split($),b=s;for(let m of d)b._mounts.has(m)||b.mount(m,new t(m)),b=b._mounts.get(m)}let i=o?Object.entries(o).map(([f,d])=>({re:Ue(f),factory:d})):[],a=f=>{for(let d of i)if(d.re.test(f))return d.factory},u=f=>{let d=f.split($),b=d.pop();if(b==null||b.length===0)throw new Error(`invalid snapshot path "${f}"`);let m=s;for(let y of d){let h=m._mounts.get(y);if(!h)throw new Error(`unknown mount "${y}" in path "${f}"`);m=h}return[m,b]},c=Object.entries(e.nodes).filter(([f])=>!f.includes(`${$}${U}${$}`)).sort((f,d)=>f[0]<d[0]?-1:f[0]>d[0]?1:0),l=new Map(c),g=new Map,p=!0;for(;l.size>0&&p;){p=!1;for(let[f,d]of[...l.entries()]){let b=d?.deps??[];if(!b.every(_=>g.has(_)))continue;let[m,y]=u(f),h={...d?.meta??{}},v=a(f),w;if(d?.type==="state")w=te(d.value,{meta:h});else{if(v==null)continue;w=v(y,{path:f,type:d.type,value:d.value,meta:h,deps:b,resolvedDeps:b.map(_=>g.get(_))})}m.add(w,{name:y}),g.set(f,w),l.delete(f),p=!0}}if(l.size>0){let f=[...l.keys()].sort().join(", ");throw new Error(`Graph.fromSnapshot could not reconstruct nodes without build callback: ${f}. Pass matching factories via fromSnapshot(data, { factories: { pattern: factoryFn } }).`)}return s.restore(e),s}toJSON(){return this.snapshot()}attachStorage(e,n={}){let r=e.map(c=>({tier:c,debounceMs:Math.max(0,c.debounceMs??0),compactEvery:Math.max(1,c.compactEvery??10),timer:void 0,seq:0,lastSnapshot:void 0,lastFingerprint:"",disposed:!1,savePending:void 0}));n.autoRestore===!0&&this._cascadeRestore(e,n.onError);let o=(c,l)=>{if(c.disposed)return;let g=yr(l.nodes);if(c.lastSnapshot!=null&&g!==""&&g===c.lastFingerprint)return;let p=c.seq+1,f=Ce(),m=c.lastSnapshot==null||p%c.compactEvery===0?{mode:"full",snapshot:l,seq:p,timestamp_ns:f,format_version:me}:{mode:"diff",diff:$r(c.lastSnapshot,l),seq:p,timestamp_ns:f,format_version:me};if(c.tier.filter&&!c.tier.filter(this.name,m))return;let y;try{y=c.tier.save(this.name,m)}catch(h){n.onError?.(h,c.tier);return}if(y&&typeof y.then=="function"){let w=(c.savePending??Promise.resolve()).then(()=>y,()=>y).then(()=>{c.disposed||(c.seq=p,c.lastSnapshot=l,c.lastFingerprint=g)},_=>{n.onError?.(_,c.tier)});c.savePending=w.finally(()=>{c.savePending===w&&(c.savePending=void 0)})}else c.seq=p,c.lastSnapshot=l,c.lastFingerprint=g},s=(c,l)=>{try{o(c,l)}catch(g){n.onError?.(g,c.tier)}},i=(c,l)=>{if(!l.some(d=>{let b=this.config.messageTier(d[0]);return b>=3&&b<5}))return;if(n.filter){let d=this.tryResolve(c);if(d==null)return;let b=ht(d,Pe("standard"));if(!n.filter(c,b))return}let p,f=()=>(p==null&&(p=this.snapshot()),p);for(let d of r)d.disposed||(d.debounceMs===0?s(d,f()):(d.timer==null&&(d.timer=new Fe),d.timer.start(d.debounceMs,()=>{d.disposed||s(d,this.snapshot())})))},a;if(n.paths!=null){let l=(typeof n.paths=="string"?this._pathsMatching(n.paths):n.paths).map(g=>{let p=this.tryResolve(g);return p==null?()=>{}:p.subscribe(f=>i(g,f))});a=()=>{for(let g of l)g()}}else a=this.observe().subscribe((c,l)=>i(c,l));let u=()=>{a();for(let c of r)c.disposed=!0,c.timer?.cancel();this._storageDisposers.delete(u)};return this._storageDisposers.add(u),{dispose:u}}async _cascadeRestore(e,n){for(let r of e){let o;try{o=await r.load(this.name)}catch(i){n?.(i,r);continue}if(o==null||typeof o!="object"||Array.isArray(o))continue;let s=o;try{if(s.mode==="full"&&s.snapshot!=null)return this.restore(s.snapshot),!0;if(s.version===me&&s.nodes!=null)return this.restore(s),!0}catch(i){n?.(i,r)}}return!1}static async fromStorage(e,n,r){for(let o of n){let s;try{s=await o.load(e)}catch(u){r?.onError?.(u,o);continue}if(s==null||typeof s!="object"||Array.isArray(s))continue;let i=s,a=i.mode==="full"&&i.snapshot!=null?i.snapshot:i.version===me&&i.nodes!=null?i:void 0;if(a!=null)try{return t.fromSnapshot(a,r)}catch(u){r?.onError?.(u,o)}}throw new Error(`Graph.fromStorage: no tier held a restorable record for "${e}" across ${n.length} tier(s)`)}_annotations=new Map;_traceRing;trace(e,n,r){if(e!=null&&n!=null){if(this.tryResolve(e)==null)return;if(this._annotations.set(e,n),this.config.inspectorEnabled){let o={path:e,annotation:n,timestamp_ns:de(),...r?.actor!=null?{actor:r.actor}:{}};this._traceRing.push(o)}return}return e!=null?this.config.inspectorEnabled?this._annotations.get(e):void 0:this.config.inspectorEnabled?this._traceRing.toArray():[]}annotation(e){return this._annotations.get(e)}clearTrace(){this._annotations.clear(),this._traceRing.clear()}pruneTrace(e){let n=this._traceRing.toArray().filter(o=>!e(o)),r=this._traceRing.size-n.length;this._traceRing.clear();for(let o of n)this._traceRing.push(o);return r}static diff(e,n){let r=new Set(Object.keys(e.nodes)),o=new Set(Object.keys(n.nodes)),s=[...o].filter(h=>!r.has(h)).sort(),i=[...r].filter(h=>!o.has(h)).sort(),a=[],u=[];for(let h of r){if(!o.has(h))continue;let v=e.nodes[h],w=n.nodes[h],_=v.v,T=w.v;_!=null&&T!=null&&_.id===T.id&&_.version!==T.version&&u.push({path:h,id:_.id,from:_.version,to:T.version});let x=_!=null&&T!=null&&_.id===T.id&&_.version===T.version;for(let O of["type","status","sentinel"]){let k=v[O],R=w[O];k!==R&&a.push({path:h,field:O,from:k,to:R})}if(!x)for(let O of["value","meta"]){let k=v[O],R=w[O];vr(k,R)||a.push({path:h,field:O,from:k,to:R})}}let c=h=>`${h.from} ${h.to}`,l=new Set(e.edges.map(c)),g=new Set(n.edges.map(c)),p=n.edges.filter(h=>!l.has(c(h))),f=e.edges.filter(h=>!g.has(c(h))),d=new Set(e.subgraphs),b=new Set(n.subgraphs),m=[...b].filter(h=>!d.has(h)).sort(),y=[...d].filter(h=>!b.has(h)).sort();return{nodesAdded:s,nodesRemoved:i,nodesChanged:a,versionChanges:u,edgesAdded:p,edgesRemoved:f,subgraphsAdded:m,subgraphsRemoved:y}}};function $r(t,e){let n=be.diff(t,e),r={};for(let o of n.nodesAdded){let s=e.nodes[o];s!=null&&(r[o]=s)}return{...n,nodesAddedFull:r}}function an(t,e,n,r={}){let o={paths:[],depths:new Map,truncated:!1};if(!e)return r.withDetail?o:[];if(!r.both&&n!=="upstream"&&n!=="downstream")throw new Error('reachable: direction must be "upstream" or "downstream"');let s=r.maxDepth;if(s!=null&&(!Number.isInteger(s)||s<0))throw new Error("reachable: maxDepth must be an integer >= 0");if(s===0)return r.withDetail?o:[];let i=new Map,a=new Map,u=new Map,c=new Map,l=new Set;for(let[v,w]of Object.entries(t.nodes)){if(!v)continue;l.add(v);let _=w.deps??[];i.set(v,_);for(let T of _)T&&(l.add(T),a.has(T)||a.set(T,new Set),a.get(T).add(v))}for(let v of t.edges){if(v==null||typeof v!="object")continue;let w=typeof v.from=="string"?v.from:"",_=typeof v.to=="string"?v.to:"";!w||!_||(l.add(w),l.add(_),c.has(w)||c.set(w,new Set),c.get(w).add(_),u.has(_)||u.set(_,new Set),u.get(_).add(w))}if(!l.has(e))return r.withDetail?o:[];let g=r.both===!0,p=v=>{if(g){let x=i.get(v)??[],O=u.get(v),k=a.get(v),R=c.get(v),S=[...x];return O&&S.push(...O),k&&S.push(...k),R&&S.push(...R),S}if(n==="upstream"){let x=i.get(v)??[],O=u.get(v);return O?[...x,...O]:x}let w=a.get(v),_=c.get(v),T=w?[...w]:[];return _&&T.push(..._),T},f=new Set([e]),d=new Map,b=[{path:e,depth:0}],m=0,y=!1;for(;m<b.length;){let v=b[m++];if(s!=null&&v.depth>=s){p(v.path).length>0&&(y=!0);continue}for(let w of p(v.path))!w||f.has(w)||(f.add(w),d.set(w,v.depth+1),b.push({path:w,depth:v.depth+1}))}let h=[...d.keys()].sort((v,w)=>v<w?-1:v>w?1:0);return r.withDetail?{paths:h,depths:d,truncated:y}:h}function Lr(t,e){if(t.length!==e.length)return!1;for(let n=0;n<t.length;n++){let r=t[n],o=e[n];if(r.path!==o.path||r.type!==o.type||r.status!==o.status||r.hop!==o.hop||r.dep_index!==o.dep_index||r.annotation!==o.annotation||r.value!==o.value||r.lastMutation!==o.lastMutation)return!1;let s=r.v,i=o.v;if(s!==i&&(s==null||i==null||s.id!==i.id||s.version!==i.version))return!1}return!0}De();fe();he();Ie();fe();gt();function fn(t,e){let n=t.cache??0;return n>=e?!1:(t.down([[z],[j,n+1]]),!0)}function pn(t,e,n){return{[t]:!0,[`${t}_type`]:e,...n??{}}}function hn(t,e){return pn("reduction",t,e)}function gn(t,e,n,r){let o=r?.maxIterations??10,s=`__feedback_${e}`,i=te(0,{meta:hn("feedback_counter",{maxIterations:o,feedbackFrom:e,feedbackTo:n})});t.add(i,{name:s});let a=t.resolve(e),u=t.resolve(n),c=`__feedback_effect_${e}`,l=oe([],(g,p)=>{let f=a.subscribe(d=>{for(let b of d){let m=b[0];if(m===j){let y=b[1];if(y==null)return;Re(()=>{fn(i,o)&&u.emit(y)})}else if(m===W||m===I){let y=m===I&&b.length>1?[I,b[1]]:[m];i.down([y])}}});return()=>f()},{name:c,describeKind:"effect",meta:{...hn("feedback_effect",{feedbackFrom:e,feedbackTo:n}),_internal:!0}});return t.add(l,{name:c}),t.addDisposer(ge(l)),t}function Te(t){return typeof t=="object"&&t!==null&&"factory"in t}function wt(t){return typeof t=="object"&&t!==null&&"factory"in t}function bn(t){return Te(t)?t.factory:t}function yn(t){return wt(t)?t.factory:t}function vn(t){let e=[];if(t.fns){let n=new Map;for(let[r,o]of Object.entries(t.fns)){let s=Te(o)?o.tags?.[0]??"Other":"Other";n.has(s)||n.set(s,[]),n.get(s).push(Ir(r,o))}for(let[r,o]of n)e.push(`${r}:
|
|
6
|
+
`)}function Or(t,e){let n=dn(t,e);return Nr(n)}function Nr(t,e){let n=e?.theme??"default",r=e?.autoSync??!0,s=JSON.stringify({code:t,mermaid:{theme:n},autoSync:r}),i=new TextEncoder().encode(s),a="";for(let c=0;c<i.length;c++)a+=String.fromCharCode(i[c]);return`https://mermaid.live/edit#base64:${globalThis.btoa(a).replace(/\+/g,"-").replace(/\//g,"_").replace(/=+$/,"")}`}function kr(t,e){let n=un(e.direction),r=Object.keys(t.nodes).sort(),o=new Map;for(let i=0;i<r.length;i+=1)o.set(r[i],`n${i}`);let s=[`direction: ${xr(n)}`];for(let i of r){let a=o.get(i);s.push(`${a}: "${_r(i)}"`)}for(let[i,a]of cn(t)){let u=o.get(i),c=o.get(a);!u||!c||s.push(`${u} -> ${c}`)}return s.join(`
|
|
7
|
+
`)}function Er(t){return t.replace(/[.*+?^${}()|[\]\\]/g,"\\$&")}function Ue(t){let e="^";for(let n=0;n<t.length;n+=1){let r=t[n];if(r==="*"){e+=".*";continue}if(r==="?"){e+=".";continue}if(r==="["){let o=t.indexOf("]",n+1);if(o<=n+1){e+="\\[";continue}let s=t.slice(n+1,o);s.startsWith("!")&&(s=`^${s.slice(1)}`),s=s.replace(/\\/g,"\\\\"),e+=`[${s}]`,n=o;continue}e+=Er(r)}return e+="$",new RegExp(e)}var Rr={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"},Ar={data:"",dirty:"",resolved:"",invalidate:"",pause:"",resume:"",complete:"",error:"",teardown:"",derived:"",path:"",reset:""};function Ke(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 Dr(t){return t==="none"?Ar:t==="ansi"||t==null?Rr:{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 on(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 Cr(t,e,n){for(let r=0;r<t.length;r++){let o=t.charCodeAt(r);if(o<32||o===127)throw new Error(`Graph "${e}": ${n} "${t}" must not contain control character (U+${o.toString(16).padStart(4,"0").toUpperCase()} at index ${r})`)}}function bt(t,e,n){if(t==="")throw new Error(`Graph "${e}": ${n} name must be non-empty`);if(t.includes($))throw new Error(`Graph "${e}": ${n} "${t}" must not contain '${$}' (path separator)`);if(t===U)throw new Error(`Graph "${e}": ${n} name "${U}" is reserved for meta companion paths`);Cr(t,e,n)}function Mr(t,e){if(t==="")throw new Error(`Graph "${e}": resolve path must be non-empty`);let n=t.split($);for(let r of n)if(r==="")throw new Error(`Graph "${e}": resolve path has empty segment`);return n}function Gr(t,e){let n=!1;for(let o of t)if(!e.isMetaPassthrough(o[0])){n=!0;break}return n?t.filter(o=>e.isMetaPassthrough(o[0])):t}function ln(t){for(let e of t._mounts.values())ln(e);for(let e of t._nodes.values())try{e.down([[H]],{internal:!0})}catch{}}var be=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($))throw new Error(`Graph name must not contain '${$}' (got "${e}")`);if(e===U)throw new Error(`Graph name "${U}" is reserved for meta companion paths`);this.name=e,this.opts=Object.freeze({...n??{}}),this.config=n?.config??pe,this._traceRing=new Te(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=Se(e=>{let n=r=>{e.emit(r)};return this._topologyEmitters.add(n),()=>{this._topologyEmitters.delete(n)}},{name:`${this.name}_topology`})),this._topology}_emitTopology(e){if(!(this._topology==null||this._topologyEmitters.size===0))for(let n of this._topologyEmitters)n(e)}add(e,n){let r=e.name,o=n?.name??r;if(o==null||o==="")throw new Error(`Graph "${this.name}": graph.add requires a non-empty name \u2014 pass via opts.name or set it on the node (e.g. state(0, { name: "x" }))`);let s=o,i=n?.annotation;if(bt(s,this.name,"add"),this._mounts.has(s))throw new Error(`Graph "${this.name}": name "${s}" is already a mount point`);if(this._nodes.has(s))throw new Error(`Graph "${this.name}": node "${s}" already exists`);let a=this._nodeToName.get(e);if(a!==void 0)throw new Error(`Graph "${this.name}": node instance already registered as "${a}"`);return this._nodes.set(s,e),this._nodeToName.set(e,s),this._emitTopology({kind:"added",name:s,nodeKind:"node"}),i!=null&&(this._annotations.set(s,i),this.config.inspectorEnabled&&this._traceRing.push({path:s,annotation:i,timestamp_ns:de()})),e}setVersioning(e){if(e!=null)for(let n of this._nodes.values())n instanceof P&&n._applyVersioning(e)}remove(e){bt(e,this.name,"remove");let n=this._mounts.get(e);if(n){let s={kind:"mount",nodes:[],mounts:[]},i=[];n._collectObserveTargets("",i);for(let[a,u]of i)a.includes(`${$}${U}${$}`)||s.nodes.push(a);return s.nodes.sort(),s.mounts.push(e),s.mounts.push(...n._collectSubgraphs(`${e}${$}`)),this._mounts.delete(e),n._parent=void 0,ln(n),this._emitTopology({kind:"removed",name:e,nodeKind:"mount",audit:s}),s}let r=this._nodes.get(e);if(!r)throw new Error(`Graph "${this.name}": unknown node or mount "${e}"`);this._nodes.delete(e),this._nodeToName.delete(r),r.down([[H]],{internal:!0});let o={kind:"node",nodes:[e],mounts:[]};return this._emitTopology({kind:"removed",name:e,nodeKind:"node",audit:o}),o}removeAll(e){let n=typeof e=="function"?e:(()=>{let s=Ue(e);return i=>s.test(i)})(),r={kind:"mount",nodes:[],mounts:[]},o=[...this._nodes.keys(),...this._mounts.keys()].filter(s=>n(s));for(let s of o){let i=this.remove(s);r.nodes.push(...i.nodes),r.mounts.push(...i.mounts)}return r.nodes.sort(),r.mounts.sort(),r}[Symbol.iterator](){let e=[...this._nodes.keys()].sort(),n=this._nodes,r=0;return{[Symbol.iterator](){return this},next(){if(r>=e.length)return{value:void 0,done:!0};let o=e[r++];return{value:[o,n.get(o)],done:!1}}}}node(e){if(e==="")throw new Error(`Graph "${this.name}": node name must be non-empty`);if(e.includes($))return this.resolve(e);let n=this._nodes.get(e);if(!n)throw new Error(`Graph "${this.name}": unknown node "${e}"`);return n}get(e){return this.node(e).cache}set(e,n,r){let o=r?.internal===!0;this.node(e).down([[j,n]],{actor:r?.actor,internal:o,delivery:"write"})}setAll(e,n){let r=Symbol.iterator in e?e:Object.entries(e);Re(()=>{for(let[o,s]of r)this.set(o,s,n)})}invalidate(e,n){let r=n?.internal===!0;this.node(e).down([[Z]],{actor:n?.actor,internal:r,delivery:"write"})}error(e,n,r){let o=r?.internal===!0;this.node(e).down([[L,n]],{actor:r?.actor,internal:o,delivery:"write"})}complete(e,n){let r=n?.internal===!0;this.node(e).down([[W]],{actor:n?.actor,internal:r,delivery:"write"})}edges(e){let n=e?.recursive===!0,r=new Map;if(!n){for(let[u,c]of this._nodes)r.set(c,u);let a=[];for(let[u,c]of this._nodes)if(c instanceof P)for(let l of c._deps){let g=r.get(l.node);g!=null&&a.push([g,u])}return a.sort((u,c)=>u[0]<c[0]?-1:u[0]>c[0]?1:u[1]<c[1]?-1:u[1]>c[1]?1:0),a}let o=[];this._collectObserveTargets("",o);let s=new Map;for(let[a,u]of o)s.set(u,a);let i=[];for(let[a,u]of o)if(u instanceof P)for(let c of u._deps){let l=s.get(c.node);l!=null&&i.push([l,a])}return i.sort((a,u)=>a[0]<u[0]?-1:a[0]>u[0]?1:a[1]<u[1]?-1:a[1]>u[1]?1:0),i}mount(e,n){if(bt(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=Mr(e,this.name);return this._resolveFromSegments(n)}tryResolve(e){try{return this.resolve(e)}catch{return}}_resolveFromSegments(e){let n=e;if(n[0]===this.name&&(n=n.slice(1),n.length===0))throw new Error(`Graph "${this.name}": resolve path ends at graph name only`);let r=n[0],o=n.slice(1);if(o.length===0){let a=this._nodes.get(r);if(a)return a;throw this._mounts.has(r)?new Error(`Graph "${this.name}": path ends at subgraph "${r}" \u2014 not a node (GRAPHREFLY-SPEC \xA73.5)`):new Error(`Graph "${this.name}": unknown name "${r}"`)}let s=this._nodes.get(r);if(s&&o.length>0&&o[0]===U)return this._resolveMetaChainFromNode(s,o,n.join($));let i=this._mounts.get(r);if(!i)throw this._nodes.has(r)?new Error(`Graph "${this.name}": "${r}" is a node; trailing path "${o.join($)}" is invalid`):new Error(`Graph "${this.name}": unknown mount or node "${r}"`);return i.resolve(o.join($))}_resolveMetaChainFromNode(e,n,r){let o=e,s=0,i=[...n];for(;s<i.length;){if(i[s]!==U)throw new Error(`Graph "${this.name}": expected ${U} segment in meta path "${r}"`);if(s+1>=i.length)throw new Error(`Graph "${this.name}": meta path requires a key after ${U} in "${r}"`);let a=i[s+1],u=o.meta[a];if(!u)throw new Error(`Graph "${this.name}": unknown meta "${a}" in path "${r}"`);o=u,s+=2}return o}signal(e,n){if(n?.internal!==!0){for(let o of e)if(this.config.messageTier(o[0])===3)throw new Error(`Graph "${this.name}": Graph.signal() rejects tier-3 messages (DATA / RESOLVED). Broadcast is for control-plane tiers (START / DIRTY / INVALIDATE / PAUSE / RESUME / COMPLETE / ERROR / TEARDOWN). For per-node value writes, use Graph.set or graph.node(name).down(...).`)}let r=[];if(this._signalDeliver(e,n??{},new Set,r),r.length>0)throw r[0]}_signalDeliver(e,n,r,o){for(let u of this._mounts.values())u._signalDeliver(e,n,r,o);let i=n.internal===!0?{internal:!0}:{actor:n.actor,delivery:"signal"},a=Gr(e,this.config);for(let u of[...this._nodes.keys()].sort()){let c=this._nodes.get(u);if(!r.has(c)){r.add(c);try{c.down(e,i)}catch(l){if(l instanceof Y)throw l;o.push(l)}a.length!==0&&this._signalMetaSubtree(c,a,r,i,o)}}}_signalMetaSubtree(e,n,r,o,s){for(let i of Object.keys(e.meta).sort()){let a=e.meta[i];if(!r.has(a)){r.add(a);try{a.down(n,o)}catch(u){if(u instanceof Y)throw u;s.push(u)}this._signalMetaSubtree(a,n,r,o,s)}}}describe(e){if(e?.reactive===!0)return this._describeReactive(e);let n=e?.actor,r=e?.filter,o=Pe(e?.detail,e?.fields),s=e?.format==="spec",i=s?Pe("minimal"):o,a=[];this._collectObserveTargets("",a);let u=new Map;for(let[O,x]of a)u.set(x,O);let c=[];{let O=a.map(([,k])=>k),x=new Set(u.values()),T=0;for(;O.length>0;){let k=O.shift();if(k instanceof P)for(let R of k._deps){let S=R.node;if(u.has(S))continue;let E=S.name??"",N=E;if(!N||x.has(N))if(E){let D=2;for(;x.has(`${E}#${D}`);)D++;N=`${E}#${D}`}else for(N=`__internal__/${T++}`;x.has(N);)N=`__internal__/${T++}`;u.set(S,N),x.add(N),c.push([N,S]),O.push(S)}}}let l=[...a,...c],g={};for(let[O,x]of l){if(n!=null&&!x.allowsObserve(n))continue;let T=ht(x,i),k=x instanceof P?x._deps.map(N=>u.get(N.node)??N.node.name??""):[],{name:R,...S}=T,E={...S,deps:k};if(!s){let N=this._annotations.get(O);N!=null&&(E.annotation=N)}if(r!=null)if(typeof r=="function"){let N=r;if(!(N.length>=2?N(O,E):N(E)))continue}else{let N=!0;for(let[D,I]of Object.entries(r)){let M=D==="deps_includes"?"depsIncludes":D==="meta_has"?"metaHas":D;if(M==="depsIncludes"){if(!E.deps.includes(String(I))){N=!1;break}continue}if(M==="metaHas"){if(!Object.hasOwn(E.meta??{},String(I))){N=!1;break}continue}if(E[M]!==I){N=!1;break}}if(!N)continue}g[O]=E}let p=new Set(Object.keys(g)),f=[];for(let[O,x]of l)if(x instanceof P)for(let T of x._deps){let k=u.get(T.node);k!=null&&f.push([k,O])}f.sort((O,x)=>O[0]<x[0]?-1:O[0]>x[0]?1:O[1]<x[1]?-1:O[1]>x[1]?1:0);let d=f.map(([O,x])=>({from:O,to:x}));(n!=null||r!=null)&&(d=d.filter(O=>p.has(O.from)&&p.has(O.to)));let b=this._collectSubgraphs(""),m=n!=null||r!=null?b.filter(O=>{let x=`${O}${$}`;return[...p].some(T=>T===O||T.startsWith(x))}):b,y=this,h=e,v={name:this.name,nodes:g,edges:d,subgraphs:m,expand(O){let x={...h,format:void 0};return Array.isArray(O)?(x.fields=O,x.detail=void 0):(x.detail=O,x.fields=void 0),y.describe(x)}},w=e??{},_=w.format;return _==="json"?Sr(v,w):_==="pretty"?Tr(v,w):_==="mermaid"?dn(v,w):_==="mermaid-url"?Or(v,w):_==="d2"?kr(v,w):_==="ascii"?Yt(v,w):v}_collectSubgraphs(e){let n=[];for(let r of[...this._mounts.keys()].sort()){let o=e===""?r:`${e}${r}`;n.push(o),n.push(...this._mounts.get(r)._collectSubgraphs(`${o}${$}`))}return n}resourceProfile(e){return nn(this,e)}reachable(e,n,r={}){return r.withDetail===!0?an(this.describe(),e,n,{...r,withDetail:!0}):an(this.describe(),e,n,r)}explain(e,n,r){return r?.reactive===!0?this._explainReactive(e,n,r):this._explainStatic(e,n,r)}_explainStatic(e,n,r){let o=this.describe({detail:"full"}),s=new Map(this._annotations),i=new Map;for(let[a,u]of Object.entries(o.nodes))u.lastMutation!=null&&i.set(a,u.lastMutation);return Xt(o,e,n,{...r?.maxDepth!=null?{maxDepth:r.maxDepth}:{},...r?.findCycle===!0?{findCycle:!0}:{},annotations:s,lastMutations:i})}_describeReactive(e){let n={...e,reactive:!1},r=e.reactiveName??"describe",o=0,s=te(o,{name:`${r}_version`}),i=this.observe({timeline:!0,structured:!0}),a=!1,u=!1,c=()=>{a||u||(a=!0,_e(()=>{a=!1,!u&&(o+=1,s.emit(o))}))},l=i.onEvent(m=>{let y=m.type;y!=="data"&&y!=="error"&&y!=="complete"&&y!=="teardown"||c()}),g=[],p=new WeakSet,f=m=>{if(p.has(m)||u)return;p.add(m);let y=m.topology.subscribe(h=>{for(let v of h){if(v[0]!==j)continue;let w=v[1];if(c(),w.kind==="added"&&w.nodeKind==="mount"){let _=m._mounts.get(w.name);_!=null&&f(_)}}});g.push(y);for(let h of m._mounts.keys()){let v=m._mounts.get(h);v!=null&&f(v)}};f(this);let d;try{d=ie([s],()=>this.describe(n),{name:r,describeKind:"derived",meta:{domain:"audit",kind:"describe"},equals:(m,y)=>m===y})}catch(m){l();for(let y of g)y();throw i.dispose(),m}let b=ge(d);return{node:d,dispose(){u=!0,l();for(let m of g)m();g.length=0,i.dispose(),b()}}}_explainReactive(e,n,r){let o=0,s=te(o,{name:"explain_version"}),i=this.observe({timeline:!0,structured:!0}),a=!1,u=!1,c=i.onEvent(f=>{let d=f.type;d!=="data"&&d!=="error"&&d!=="complete"&&d!=="teardown"||a||u||(a=!0,_e(()=>{a=!1,!u&&(o+=1,s.emit(o))}))}),l={...r?.maxDepth!=null?{maxDepth:r.maxDepth}:{},...r?.findCycle===!0?{findCycle:!0}:{}},g;try{g=ie([s],()=>this._explainStatic(e,n,l),{name:r?.name??"explain",describeKind:"derived",meta:{domain:"audit",kind:"explain_path",from:e,to:n},equals:(f,d)=>f.found===d.found&&f.reason===d.reason&&f.steps.length===d.steps.length&&Ir(f.steps,d.steps)})}catch(f){throw c(),i.dispose(),f}let p=ge(g);return{node:g,dispose(){u=!0,c(),i.dispose(),p()}}}_pathsMatching(e){let n=Ue(e),r=[];return this._collectObserveTargets("",r),r.map(([o])=>o).filter(o=>n.test(o))}_collectObserveTargets(e,n){for(let r of[...this._mounts.keys()].sort()){let o=e===""?r:`${e}${$}${r}`;this._mounts.get(r)._collectObserveTargets(o,n)}for(let r of[...this._nodes.keys()].sort()){let o=this._nodes.get(r),s=e===""?r:`${e}${$}${r}`;n.push([s,o]),this._appendMetaObserveTargets(s,o,n)}}_appendMetaObserveTargets(e,n,r){for(let o of Object.keys(n.meta).sort()){let s=n.meta[o],i=`${e}${$}${U}${$}${o}`;r.push([i,s]),this._appendMetaObserveTargets(i,s,r)}}observe(e,n){let r=typeof e=="string",s=on(r?n:e),i=s.structured===!0||s.timeline===!0||s.causal===!0||s.derived===!0||s.detail==="minimal"||s.detail==="full"||s.format!=null,a=s.actor;if(r){let l=e,g=this.resolve(l);if(a!=null&&!g.allowsObserve(a))throw new Y({actor:a,action:"observe",nodeName:l});return i?this._buildStructuredObserver([[l,g]],s,"one"):{subscribe(p){return g.subscribe(p)},up(p){try{g.up?.(p)}catch(f){if(f instanceof Y)return;throw f}}}}let u=[];this._collectObserveTargets("",u),u.sort((l,g)=>l[0]<g[0]?-1:l[0]>g[0]?1:0);let c=a==null?u:u.filter(([,l])=>l.allowsObserve(a));return i?this._buildStructuredObserver(c,s,"all"):{subscribe:l=>{let g=c.map(([p,f])=>f.subscribe(d=>{l(p,d)}));return()=>{for(let p of g)p()}},up:(l,g)=>{try{this.resolve(l).up?.(g)}catch(p){if(p instanceof Y)return;throw p}}}}_buildStructuredObserver(e,n,r){let o=r==="one"?e[0]?.[0]:void 0,s=i=>{if(r==="one"&&o!=null){let l=this.resolve(o);return this._buildStructuredObserver([[o,l]],i,"one")}let a=[];this._collectObserveTargets("",a),a.sort((l,g)=>l[0]<g[0]?-1:l[0]>g[0]?1:0);let u=i.actor,c=u==null?a:a.filter(([,l])=>l.allowsObserve(u));return this._buildStructuredObserver(c,i,"all")};return this._createObserveResult(e,n,s)}_createObserveResult(e,n,r){let o=n.timeline===!0,s=n.causal===!0,i=n.derived===!0,a=n.detail==="minimal",u=this.config.inspectorEnabled,c=(s||i)&&u,l=n.maxEvents,g=l!=null&&l>0?new Te(l):null,p=[],f=new Set,d={},b=new Set,m=0,y=0,h=0,v=0,w=0,_=0,O=!1,x=!1,T=0,k=new Map,R=new Map,S=new Map,E=A=>{g?g.push(A):p.push(A);for(let G of f)G(A)},N=()=>o?{timestamp_ns:de(),in_batch:Ee(),batch_id:T}:{},D=(A,G)=>{if(!(!c||!(A instanceof P)))return A._setInspectorHook(K=>{if(K.kind==="dep_message")k.set(A,K.depIndex);else if(K.kind==="run"){let ye=K.batchData.map((C,V)=>C!=null&&C.length>0?C.at(-1):K.prevData[V]);R.set(A,ye);let q=K.batchData.map(C=>C!=null?[...C]:void 0);S.set(A,q),i&&E({type:"derived",path:G,dep_values:ye,dep_batches:q,...N()})}})},I=A=>{let G=k.get(A),K=R.get(A);if(!s||K==null)return{};let q=(G!=null&&G>=0&&A instanceof P?A._deps[G]:void 0)?.node,C=q?.v,V=S.get(A);return{trigger_dep_index:G,trigger_dep_name:q?.name,...C!=null?{trigger_version:{id:C.id,version:C.version}}:{},dep_values:[...K],...V!=null?{dep_batches:V}:{}}},M=[],B=[];for(let[A,G]of e){let K=D(G,A);K&&M.push(K),B.push(G.subscribe(ye=>{T++;for(let q of ye){let C=q[0],V=N();if(C===j){d[A]=q[1];let Ze=G instanceof P?G.lastMutation?.actor??ae:ae;E({type:"data",path:A,data:q[1],actor:Ze,...V,...I(G)})}else if(a)C===z?m++:C===X?y++:C===Z?h++:C===Q?v++:C===ee?w++:C===H?_++:C===W&&!b.has(A)?O=!0:C===L&&(x=!0,b.add(A));else if(C===z)m++,E({type:"dirty",path:A,...V});else if(C===X)y++,E({type:"resolved",path:A,...V,...I(G)});else if(C===Z)h++,E({type:"invalidate",path:A,...V});else if(C===Q)v++,E({type:"pause",path:A,lockId:q[1],...V});else if(C===ee)w++,E({type:"resume",path:A,lockId:q[1],...V});else if(C===W)b.has(A)||(O=!0),E({type:"complete",path:A,...V});else if(C===L){x=!0,b.add(A);let Ze=G instanceof P?G.lastMutation?.actor??ae:ae;E({type:"error",path:A,data:q[1],actor:Ze,...V})}else C===H&&(_++,E({type:"teardown",path:A,...V}))}}))}let Je=!1,Ye=()=>{if(!Je){Je=!0;for(let A of B)A();for(let A of M)A();for(let A of Ne)A({value:void 0,done:!0});Ne.length=0}},Xe=[],Ne=[];f.add(A=>{let G=Ne.shift();G?G({value:A,done:!1}):Xe.push(A)});let xt={get values(){return d},get dirtyCount(){return m},get resolvedCount(){return y},get invalidateCount(){return h},get pauseCount(){return v},get resumeCount(){return w},get teardownCount(){return _},get events(){return g?g.toArray():[...p]},get anyCompletedCleanly(){return O},get anyErrored(){return x},get completedWithoutErrors(){return O&&!x},onEvent(A){return f.add(A),()=>f.delete(A)},dispose:Ye,expand(A){Ye();let G={...n};return typeof A=="string"?G.detail=A:Object.assign(G,A),r(on(G))},[Symbol.asyncIterator](){return{next(){return Xe.length>0?Promise.resolve({value:Xe.shift(),done:!1}):Je?Promise.resolve({value:void 0,done:!0}):new Promise(A=>Ne.push(A))},return(){return Ye(),Promise.resolve({value:void 0,done:!0})}}}};return n.format!=null&&this._attachFormatLogger(xt,n),xt}_attachFormatLogger(e,n){let r=n.format;if(r==null)return;let o=n.logger??(d=>console.log(d)),s=n.includeTypes?new Set(n.includeTypes):null,i=n.excludeTypes?new Set(n.excludeTypes):null,a=s==null&&i==null?()=>!0:d=>(s==null||s.has(d))&&(i==null||!i.has(d)),u=Dr(n.theme),c=r==="stage-log"?de():0,l=d=>d==null?"":n.stageLabels?.[d]??d,g=(d,b)=>d.length>b?`${d.slice(0,b-1)}\u2026`:d,p=d=>d.type==="data"||d.type==="error"?g(Ke(d.data),120):"",f=d=>{if(r==="stage-log"){let x=(de()-c)/1e9,T=l(d.path).padEnd(9);if(d.type==="data"){let k=p(d);return`[${x.toFixed(3)}s] ${T} \u2190${k?` ${k}`:""}`}if(d.type==="error"){let k=p(d);return`[${x.toFixed(3)}s] ${T} \u2717${k?` ${k}`:""}`}return d.type==="complete"?`[${x.toFixed(3)}s] ${T} \u25A0 complete`:`[${x.toFixed(3)}s] ${T} ${d.type}`}if(r==="json")try{return JSON.stringify(d)}catch{return JSON.stringify({type:d.type,path:d.path,data:"[unserializable]"})}let b=u[d.type]??"",m=d.path?`${u.path}${d.path}${u.reset} `:"",y=d.type==="data"||d.type==="error",h=d.type==="pause"||d.type==="resume",v=y?` ${Ke(d.data)}`:h?` ${Ke(d.lockId)}`:"",w=d.type==="data"||d.type==="resolved"||d.type==="derived"?d:void 0,_=w?.trigger_dep_name!=null?` <- ${w.trigger_dep_name}`:w?.trigger_dep_index!=null?` <- #${w.trigger_dep_index}`:"",O=d.in_batch?" [batch]":"";return`${m}${b}${d.type.toUpperCase()}${u.reset}${v}${_}${O}`};e.onEvent(d=>{a(d.type)&&o(f(d),d)})}addDisposer(e){return this._disposers.add(e),()=>{this._disposers.delete(e)}}destroy(){rn(this._disposers,this.name),this.signal([[H]],{internal:!0}),rn(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"}),o={};for(let a of Object.keys(r.nodes).sort()){let{lastMutation:u,guard:c,...l}=r.nodes[a];o[a]=l}let s=[...r.subgraphs].sort(),i={...r,version:1,nodes:o,subgraphs:s};if(e?.format==null)return i;if(e.format==="json-string")return JSON.stringify(i);if(e.format==="bytes"){if(e.codec==null)throw new Error("snapshot({format: 'bytes'}) requires a `codec` name");let a=this.config.lookupCodec(e.codec);if(a==null)throw new Error(`snapshot: codec "${e.codec}" is not registered on this graph's config. Call config.registerCodec(...) before creating nodes.`);return Tt(a,a.encode(i))}throw new Error(`snapshot: unknown format "${String(e.format)}"`)}static decode(e,n){let r=n?.config??pe,{codec:o,codecVersion:s,payload:i}=Ot(e,r);return o.decode(i,s)}restore(e,n){if(sn(e),e.name!==this.name)throw new Error(`Graph "${this.name}": restore snapshot name "${e.name}" does not match this graph`);let r=n?.only==null?null:(Array.isArray(n.only)?n.only:[n.only]).map(s=>Ue(s)),o=n?.includeProducers===!0;for(let s of Object.keys(e.nodes).sort()){if(r!==null&&!r.some(a=>a.test(s)))continue;let i=e.nodes[s];if(i!==void 0){if(!("value"in i)||i.value===void 0){"value"in i&&i.value===void 0&&n?.onError?.(s,new Error(`restore: slice.value is undefined for "${s}" (undefined is the global SENTINEL; not valid DATA)`));continue}if(!(i.type==="derived"||i.type==="effect")&&!(i.type==="producer"&&!o)){if(i.v!=null){let u=this.tryResolve(s)?.v;if(u!=null&&u.id===i.v.id&&u.version===i.v.version)continue}try{this.set(s,i.value)}catch(a){n?.onError?.(s,a)}}}}}static fromSnapshot(e,n){sn(e);let r=typeof n=="function"?n:n?.build,o=typeof n=="function"?void 0:n?.factories,s=new t(e.name);if(r)return r(s),s.restore(e),s;for(let f of[...e.subgraphs].sort((d,b)=>{let m=d.split($).length,y=b.split($).length;return m!==y?m-y:d<b?-1:d>b?1:0})){let d=f.split($),b=s;for(let m of d)b._mounts.has(m)||b.mount(m,new t(m)),b=b._mounts.get(m)}let i=o?Object.entries(o).map(([f,d])=>({re:Ue(f),factory:d})):[],a=f=>{for(let d of i)if(d.re.test(f))return d.factory},u=f=>{let d=f.split($),b=d.pop();if(b==null||b.length===0)throw new Error(`invalid snapshot path "${f}"`);let m=s;for(let y of d){let h=m._mounts.get(y);if(!h)throw new Error(`unknown mount "${y}" in path "${f}"`);m=h}return[m,b]},c=Object.entries(e.nodes).filter(([f])=>!f.includes(`${$}${U}${$}`)).sort((f,d)=>f[0]<d[0]?-1:f[0]>d[0]?1:0),l=new Map(c),g=new Map,p=!0;for(;l.size>0&&p;){p=!1;for(let[f,d]of[...l.entries()]){let b=d?.deps??[];if(!b.every(_=>g.has(_)))continue;let[m,y]=u(f),h={...d?.meta??{}},v=a(f),w;if(d?.type==="state")w=te(d.value,{meta:h});else{if(v==null)continue;w=v(y,{path:f,type:d.type,value:d.value,meta:h,deps:b,resolvedDeps:b.map(_=>g.get(_))})}m.add(w,{name:y}),g.set(f,w),l.delete(f),p=!0}}if(l.size>0){let f=[...l.keys()].sort().join(", ");throw new Error(`Graph.fromSnapshot could not reconstruct nodes without build callback: ${f}. Pass matching factories via fromSnapshot(data, { factories: { pattern: factoryFn } }).`)}return s.restore(e),s}toJSON(){return this.snapshot()}attachStorage(e,n={}){let r=e.map(c=>({tier:c,debounceMs:Math.max(0,c.debounceMs??0),compactEvery:Math.max(1,c.compactEvery??10),timer:void 0,seq:0,lastSnapshot:void 0,lastFingerprint:"",disposed:!1,savePending:void 0}));n.autoRestore===!0&&this._cascadeRestore(e,n.onError);let o=(c,l)=>{if(c.disposed)return;let g=yr(l.nodes);if(c.lastSnapshot!=null&&g!==""&&g===c.lastFingerprint)return;let p=c.seq+1,f=Ce(),m=c.lastSnapshot==null||p%c.compactEvery===0?{mode:"full",snapshot:l,seq:p,timestamp_ns:f,format_version:me}:{mode:"diff",diff:$r(c.lastSnapshot,l),seq:p,timestamp_ns:f,format_version:me};if(c.tier.filter&&!c.tier.filter(this.name,m))return;let y;try{y=c.tier.save(this.name,m)}catch(h){n.onError?.(h,c.tier);return}if(y&&typeof y.then=="function"){let w=(c.savePending??Promise.resolve()).then(()=>y,()=>y).then(()=>{c.disposed||(c.seq=p,c.lastSnapshot=l,c.lastFingerprint=g)},_=>{n.onError?.(_,c.tier)});c.savePending=w.finally(()=>{c.savePending===w&&(c.savePending=void 0)})}else c.seq=p,c.lastSnapshot=l,c.lastFingerprint=g},s=(c,l)=>{try{o(c,l)}catch(g){n.onError?.(g,c.tier)}},i=(c,l)=>{if(!l.some(d=>{let b=this.config.messageTier(d[0]);return b>=3&&b<5}))return;if(n.filter){let d=this.tryResolve(c);if(d==null)return;let b=ht(d,Pe("standard"));if(!n.filter(c,b))return}let p,f=()=>(p==null&&(p=this.snapshot()),p);for(let d of r)d.disposed||(d.debounceMs===0?s(d,f()):(d.timer==null&&(d.timer=new Fe),d.timer.start(d.debounceMs,()=>{d.disposed||s(d,this.snapshot())})))},a;if(n.paths!=null){let l=(typeof n.paths=="string"?this._pathsMatching(n.paths):n.paths).map(g=>{let p=this.tryResolve(g);return p==null?()=>{}:p.subscribe(f=>i(g,f))});a=()=>{for(let g of l)g()}}else a=this.observe().subscribe((c,l)=>i(c,l));let u=()=>{a();for(let c of r)c.disposed=!0,c.timer?.cancel();this._storageDisposers.delete(u)};return this._storageDisposers.add(u),{dispose:u}}async _cascadeRestore(e,n){for(let r of e){let o;try{o=await r.load(this.name)}catch(i){n?.(i,r);continue}if(o==null||typeof o!="object"||Array.isArray(o))continue;let s=o;try{if(s.mode==="full"&&s.snapshot!=null)return this.restore(s.snapshot),!0;if(s.version===me&&s.nodes!=null)return this.restore(s),!0}catch(i){n?.(i,r)}}return!1}static async fromStorage(e,n,r){for(let o of n){let s;try{s=await o.load(e)}catch(u){r?.onError?.(u,o);continue}if(s==null||typeof s!="object"||Array.isArray(s))continue;let i=s,a=i.mode==="full"&&i.snapshot!=null?i.snapshot:i.version===me&&i.nodes!=null?i:void 0;if(a!=null)try{return t.fromSnapshot(a,r)}catch(u){r?.onError?.(u,o)}}throw new Error(`Graph.fromStorage: no tier held a restorable record for "${e}" across ${n.length} tier(s)`)}_annotations=new Map;_traceRing;trace(e,n,r){if(e!=null&&n!=null){if(this.tryResolve(e)==null)return;if(this._annotations.set(e,n),this.config.inspectorEnabled){let o={path:e,annotation:n,timestamp_ns:de(),...r?.actor!=null?{actor:r.actor}:{}};this._traceRing.push(o)}return}return e!=null?this.config.inspectorEnabled?this._annotations.get(e):void 0:this.config.inspectorEnabled?this._traceRing.toArray():[]}annotation(e){return this._annotations.get(e)}clearTrace(){this._annotations.clear(),this._traceRing.clear()}pruneTrace(e){let n=this._traceRing.toArray().filter(o=>!e(o)),r=this._traceRing.size-n.length;this._traceRing.clear();for(let o of n)this._traceRing.push(o);return r}static diff(e,n){let r=new Set(Object.keys(e.nodes)),o=new Set(Object.keys(n.nodes)),s=[...o].filter(h=>!r.has(h)).sort(),i=[...r].filter(h=>!o.has(h)).sort(),a=[],u=[];for(let h of r){if(!o.has(h))continue;let v=e.nodes[h],w=n.nodes[h],_=v.v,O=w.v;_!=null&&O!=null&&_.id===O.id&&_.version!==O.version&&u.push({path:h,id:_.id,from:_.version,to:O.version});let x=_!=null&&O!=null&&_.id===O.id&&_.version===O.version;for(let T of["type","status","sentinel"]){let k=v[T],R=w[T];k!==R&&a.push({path:h,field:T,from:k,to:R})}if(!x)for(let T of["value","meta"]){let k=v[T],R=w[T];vr(k,R)||a.push({path:h,field:T,from:k,to:R})}}let c=h=>`${h.from} ${h.to}`,l=new Set(e.edges.map(c)),g=new Set(n.edges.map(c)),p=n.edges.filter(h=>!l.has(c(h))),f=e.edges.filter(h=>!g.has(c(h))),d=new Set(e.subgraphs),b=new Set(n.subgraphs),m=[...b].filter(h=>!d.has(h)).sort(),y=[...d].filter(h=>!b.has(h)).sort();return{nodesAdded:s,nodesRemoved:i,nodesChanged:a,versionChanges:u,edgesAdded:p,edgesRemoved:f,subgraphsAdded:m,subgraphsRemoved:y}}};function $r(t,e){let n=be.diff(t,e),r={};for(let o of n.nodesAdded){let s=e.nodes[o];s!=null&&(r[o]=s)}return{...n,nodesAddedFull:r}}function an(t,e,n,r={}){let o={paths:[],depths:new Map,truncated:!1};if(!e)return r.withDetail?o:[];if(!r.both&&n!=="upstream"&&n!=="downstream")throw new Error('reachable: direction must be "upstream" or "downstream"');let s=r.maxDepth;if(s!=null&&(!Number.isInteger(s)||s<0))throw new Error("reachable: maxDepth must be an integer >= 0");if(s===0)return r.withDetail?o:[];let i=new Map,a=new Map,u=new Map,c=new Map,l=new Set;for(let[v,w]of Object.entries(t.nodes)){if(!v)continue;l.add(v);let _=w.deps??[];i.set(v,_);for(let O of _)O&&(l.add(O),a.has(O)||a.set(O,new Set),a.get(O).add(v))}for(let v of t.edges){if(v==null||typeof v!="object")continue;let w=typeof v.from=="string"?v.from:"",_=typeof v.to=="string"?v.to:"";!w||!_||(l.add(w),l.add(_),c.has(w)||c.set(w,new Set),c.get(w).add(_),u.has(_)||u.set(_,new Set),u.get(_).add(w))}if(!l.has(e))return r.withDetail?o:[];let g=r.both===!0,p=v=>{if(g){let x=i.get(v)??[],T=u.get(v),k=a.get(v),R=c.get(v),S=[...x];return T&&S.push(...T),k&&S.push(...k),R&&S.push(...R),S}if(n==="upstream"){let x=i.get(v)??[],T=u.get(v);return T?[...x,...T]:x}let w=a.get(v),_=c.get(v),O=w?[...w]:[];return _&&O.push(..._),O},f=new Set([e]),d=new Map,b=[{path:e,depth:0}],m=0,y=!1;for(;m<b.length;){let v=b[m++];if(s!=null&&v.depth>=s){p(v.path).length>0&&(y=!0);continue}for(let w of p(v.path))!w||f.has(w)||(f.add(w),d.set(w,v.depth+1),b.push({path:w,depth:v.depth+1}))}let h=[...d.keys()].sort((v,w)=>v<w?-1:v>w?1:0);return r.withDetail?{paths:h,depths:d,truncated:y}:h}function Ir(t,e){if(t.length!==e.length)return!1;for(let n=0;n<t.length;n++){let r=t[n],o=e[n];if(r.path!==o.path||r.type!==o.type||r.status!==o.status||r.hop!==o.hop||r.dep_index!==o.dep_index||r.annotation!==o.annotation||r.value!==o.value||r.lastMutation!==o.lastMutation)return!1;let s=r.v,i=o.v;if(s!==i&&(s==null||i==null||s.id!==i.id||s.version!==i.version))return!1}return!0}De();fe();he();Le();fe();gt();function fn(t,e){let n=t.cache??0;return n>=e?!1:(t.down([[z],[j,n+1]]),!0)}function pn(t,e,n){return{[t]:!0,[`${t}_type`]:e,...n??{}}}function hn(t,e){return pn("reduction",t,e)}function gn(t,e,n,r){let o=r?.maxIterations??10,s=`__feedback_${e}`,i=te(0,{meta:hn("feedback_counter",{maxIterations:o,feedbackFrom:e,feedbackTo:n})});t.add(i,{name:s});let a=t.resolve(e),u=t.resolve(n),c=`__feedback_effect_${e}`,l=oe([],(g,p)=>{let f=a.subscribe(d=>{for(let b of d){let m=b[0];if(m===j){let y=b[1];if(y==null)return;Re(()=>{fn(i,o)&&u.emit(y)})}else if(m===W||m===L){let y=m===L&&b.length>1?[L,b[1]]:[m];i.down([y])}}});return()=>f()},{name:c,describeKind:"effect",meta:{...hn("feedback_effect",{feedbackFrom:e,feedbackTo:n}),_internal:!0}});return t.add(l,{name:c}),t.addDisposer(ge(l)),t}function Oe(t){return typeof t=="object"&&t!==null&&"factory"in t}function wt(t){return typeof t=="object"&&t!==null&&"factory"in t}function bn(t){return Oe(t)?t.factory:t}function yn(t){return wt(t)?t.factory:t}function vn(t){let e=[];if(t.fns){let n=new Map;for(let[r,o]of Object.entries(t.fns)){let s=Oe(o)?o.tags?.[0]??"Other":"Other";n.has(s)||n.set(s,[]),n.get(s).push(Lr(r,o))}for(let[r,o]of n)e.push(`${r}:
|
|
8
8
|
${o.join(`
|
|
9
9
|
`)}`)}if(t.sources){let n=[];for(let[r,o]of Object.entries(t.sources))n.push(Pr(r,o));n.length>0&&e.push(`Sources:
|
|
10
10
|
${n.join(`
|
|
11
11
|
`)}`)}return e.join(`
|
|
12
12
|
|
|
13
|
-
`)}function
|
|
13
|
+
`)}function Lr(t,e){if(!Oe(e))return`- ${t}`;let n=`- ${t}: ${e.description}`;if(e.configSchema){let r=Object.entries(e.configSchema).map(([o,s])=>{let i=`${o}: ${s.type}`;return s.enum&&(i+=` (${s.enum.join("|")})`),s.required===!1&&(i+="?"),i});n+=`. Config: { ${r.join(", ")} }`}return n}function Pr(t,e){if(!wt(e))return`- ${t}`;let n=`- ${t}: ${e.description}`;if(e.configSchema){let r=Object.entries(e.configSchema).map(([o,s])=>{let i=`${o}: ${s.type}`;return s.required===!1&&(i+="?"),i});n+=`. Config: { ${r.join(", ")} }`}return n}function _t(t,e){let n=[],r=new Set(Object.keys(e.fns??{})),o=new Set(Object.keys(e.sources??{}));for(let[s,i]of Object.entries(t.nodes)){if(i.type==="template")continue;let a=i;if(a.fn&&r.size>0&&!r.has(a.fn))if(o.has(a.fn))n.push(`Node "${s}": fn "${a.fn}" is a source, not a function. Use it as a producer source instead, or use a function from: ${[...r].join(", ")}`);else{let u=vt(a.fn,r);n.push(`Node "${s}": fn "${a.fn}" not found in catalog`+(u?`. Did you mean "${u}"?`:""))}if(a.source&&o.size>0&&!o.has(a.source))if(r.has(a.source))n.push(`Node "${s}": source "${a.source}" is a function, not a source. Use it as fn instead, or use a source from: ${[...o].join(", ")}`);else{let u=vt(a.source,o);n.push(`Node "${s}": source "${a.source}" not found in catalog`+(u?`. Did you mean "${u}"?`:""))}if(a.fn&&a.config&&e.fns?.[a.fn]){let u=e.fns[a.fn];if(Oe(u)&&u.configSchema){for(let[c,l]of Object.entries(u.configSchema))if(l.required!==!1&&!(c in a.config)&&n.push(`Node "${s}": config missing required field "${c}"`),c in a.config&&l.enum){let g=a.config[c];l.enum.includes(g)||n.push(`Node "${s}": config.${c} = ${JSON.stringify(g)}, expected one of: ${l.enum.join(", ")}`)}}}}if(t.templates){for(let[s,i]of Object.entries(t.templates))for(let[a,u]of Object.entries(i.nodes))if(u.fn&&r.size>0&&!r.has(u.fn)){let c=vt(u.fn,r);n.push(`Template "${s}" node "${a}": fn "${u.fn}" not found in catalog`+(c?`. Did you mean "${c}"?`:""))}}return{valid:n.length===0,errors:n,warnings:[]}}function vt(t,e){let n=null,r=1/0,o=t.toLowerCase();for(let s of e){let i=Fr(o,s.toLowerCase());i<r&&i<=Math.max(3,Math.floor(t.length/2))&&(r=i,n=s)}return n}function Fr(t,e){let n=t.length,r=e.length,o=Array.from({length:n+1},(s,i)=>Array.from({length:r+1},(a,u)=>i===0?u:u===0?i:0));for(let s=1;s<=n;s++)for(let i=1;i<=r;i++)o[s][i]=t[s-1]===e[i-1]?o[s-1][i-1]:1+Math.min(o[s-1][i],o[s][i-1],o[s-1][i-1]);return o[n][r]}var mn=new Set(["state","producer","derived","effect","operator","template"]),jr=new Set(["state","producer","derived","effect","operator"]);function qe(t){let e=[],n=[];if(t==null||typeof t!="object")return{valid:!1,errors:["GraphSpec must be a non-null object"],warnings:n};let r=t;if((typeof r.name!="string"||r.name.length===0)&&e.push("Missing or empty 'name' field"),r.nodes==null||typeof r.nodes!="object"||Array.isArray(r.nodes))return e.push("Missing or invalid 'nodes' field (must be an object)"),{valid:!1,errors:e,warnings:n};let o=new Set(Object.keys(r.nodes)),s=new Map,i=new Map;if(r.templates!=null&&typeof r.templates=="object"&&!Array.isArray(r.templates)){for(let[a,u]of Object.entries(r.templates))if(u!=null&&typeof u=="object"){let c=u;i.set(a,{params:Array.isArray(c.params)?c.params:[]})}}if(r.templates!=null)if(typeof r.templates!="object"||Array.isArray(r.templates))e.push("'templates' must be an object");else for(let[a,u]of Object.entries(r.templates)){if(u==null||typeof u!="object"){e.push(`Template "${a}": must be an object`);continue}let c=u;if(Array.isArray(c.params)||e.push(`Template "${a}": missing 'params' array`),c.nodes==null||typeof c.nodes!="object"||Array.isArray(c.nodes))e.push(`Template "${a}": missing or invalid 'nodes' object`);else{let l=new Set(Array.isArray(c.params)?c.params:[]),g=new Set(Object.keys(c.nodes));for(let[p,f]of Object.entries(c.nodes)){if(f==null||typeof f!="object"){e.push(`Template "${a}" node "${p}": must be an object`);continue}let d=f;if((typeof d.type!="string"||!jr.has(d.type))&&e.push(`Template "${a}" node "${p}": invalid type`),Array.isArray(d.deps))for(let b of d.deps)!g.has(b)&&!l.has(b)&&e.push(`Template "${a}" node "${p}": dep "${b}" is not an inner node or param`)}typeof c.output!="string"?e.push(`Template "${a}": missing 'output' string`):c.nodes[c.output]||e.push(`Template "${a}": output "${c.output}" is not a declared node`)}}for(let[a,u]of Object.entries(r.nodes)){if(u==null||typeof u!="object"){e.push(`Node "${a}": must be an object`);continue}let c=u;if(typeof c.type!="string"||!mn.has(c.type)){e.push(`Node "${a}": invalid type "${String(c.type)}" (expected: ${[...mn].join(", ")})`);continue}if(s.set(a,c.type),c.type==="template")if(typeof c.template!="string"||!i.has(c.template))e.push(`Node "${a}": template "${String(c.template)}" not found in templates`);else if(c.bind==null||typeof c.bind!="object"||Array.isArray(c.bind))e.push(`Node "${a}": template ref requires 'bind' object`);else{let l=i.get(c.template),g=c.bind;for(let p of l.params)p in g||e.push(`Node "${a}": template param "${p}" is not bound (template "${c.template}")`);for(let[,p]of Object.entries(g))typeof p=="string"&&!o.has(p)&&e.push(`Node "${a}": bind target "${p}" does not reference an existing node`)}else{if(Array.isArray(c.deps))for(let l of c.deps)l===a?e.push(`Node "${a}": self-referencing dep`):o.has(l)||e.push(`Node "${a}": dep "${l}" does not reference an existing node`);(c.type==="derived"||c.type==="effect"||c.type==="operator")&&!Array.isArray(c.deps)&&e.push(`Node "${a}": ${c.type} node should have a 'deps' array`)}}if(r.feedback!=null)if(!Array.isArray(r.feedback))e.push("'feedback' must be an array");else for(let a=0;a<r.feedback.length;a++){let u=r.feedback[a];if(u==null||typeof u!="object"){e.push(`Feedback [${a}]: must be an object`);continue}let c=u;typeof c.from!="string"||!o.has(c.from)?e.push(`Feedback [${a}]: 'from' "${String(c.from)}" does not reference an existing node`):s.get(c.from)==="effect"&&n.push(`Feedback [${a}]: 'from' "${c.from}" is an effect node \u2014 effects emit no DATA, so the feedback edge will never fire. Did you mean a derived/state node upstream?`),typeof c.from=="string"&&c.from===c.to&&e.push(`Feedback [${a}]: 'from' and 'to' must be different nodes`),typeof c.to!="string"||!o.has(c.to)?e.push(`Feedback [${a}]: 'to' "${String(c.to)}" does not reference an existing node`):typeof c.to=="string"&&s.get(c.to)!=="state"&&e.push(`Feedback [${a}]: 'to' node "${c.to}" must be a state node (got "${s.get(c.to)??"unknown"}")`)}return{valid:e.length===0,errors:e,warnings:n}}function Br(t,e){let n=qe(t);if(!n.valid)throw new Error(`compileSpec: invalid GraphSpec:
|
|
14
14
|
${n.errors.join(`
|
|
15
15
|
`)}`);let r=e?.catalog??{},o=e?.onMissing??"placeholder",s=new be(t.name),i=t.templates??{},a=_t(t,r);if(!a.valid)throw new Error(`compileSpec: catalog validation errors:
|
|
16
16
|
${a.errors.join(`
|
|
17
|
-
`)}`);let u=[],c=(m,y,h)=>{if(h){u.push({path:m,kind:"source",name:h});return}y&&u.push({path:m,kind:"fn",name:y})},l=m=>{let y=r.fns?.[m];return y?bn(y):void 0},g=m=>{let y=r.sources?.[m];return y?yn(y):void 0},p=new Map,f=[];for(let[m,y]of Object.entries(t.nodes)){if(y.type==="template")continue;let h=y;if(h.type==="state"){let v=te(h.initial,{name:m,meta:h.meta?{...h.meta}:void 0});s.add(v,{name:m}),p.set(m,v)}else if(h.type==="producer"){let v=h.source?g(h.source):void 0,w=h.fn?l(h.fn):void 0;if(v){let _=v(h.config??{});s.add(_,{name:m}),p.set(m,_)}else if(w){let _=w([],h.config??{});s.add(_,{name:m}),p.set(m,_)}else{c(m,h.fn,h.source);let _=Se(()=>{},{name:m,meta:{...h.meta,_specFn:h.fn,_specSource:h.source}});s.add(_,{name:m}),p.set(m,_)}}else f.push([m,h])}let d=!0,b=new Map(f);for(;b.size>0&&d;){d=!1;for(let[m,y]of[...b.entries()]){let h=y.deps??[];if(!h.every(
|
|
17
|
+
`)}`);let u=[],c=(m,y,h)=>{if(h){u.push({path:m,kind:"source",name:h});return}y&&u.push({path:m,kind:"fn",name:y})},l=m=>{let y=r.fns?.[m];return y?bn(y):void 0},g=m=>{let y=r.sources?.[m];return y?yn(y):void 0},p=new Map,f=[];for(let[m,y]of Object.entries(t.nodes)){if(y.type==="template")continue;let h=y;if(h.type==="state"){let v=te(h.initial,{name:m,meta:h.meta?{...h.meta}:void 0});s.add(v,{name:m}),p.set(m,v)}else if(h.type==="producer"){let v=h.source?g(h.source):void 0,w=h.fn?l(h.fn):void 0;if(v){let _=v(h.config??{});s.add(_,{name:m}),p.set(m,_)}else if(w){let _=w([],h.config??{});s.add(_,{name:m}),p.set(m,_)}else{c(m,h.fn,h.source);let _=Se(()=>{},{name:m,meta:{...h.meta,_specFn:h.fn,_specSource:h.source}});s.add(_,{name:m}),p.set(m,_)}}else f.push([m,h])}let d=!0,b=new Map(f);for(;b.size>0&&d;){d=!1;for(let[m,y]of[...b.entries()]){let h=y.deps??[];if(!h.every(O=>p.has(O)))continue;let v=h.map(O=>p.get(O)),w=y.fn?l(y.fn):void 0,_;w?_=w(v,y.config??{}):y.type==="effect"?(y.fn&&c(m,y.fn,void 0),_=Ie(v,()=>{})):(y.fn&&c(m,y.fn,void 0),_=ie(v,O=>O[0])),s.add(_,{name:m}),p.set(m,_),b.delete(m),d=!0}}if(b.size>0){let m=[...b.keys()].sort().join(", ");throw new Error(`compileSpec: unresolvable deps for nodes: ${m}`)}for(let[m,y]of Object.entries(t.nodes)){if(y.type!=="template")continue;let h=y,v=i[h.template],w=new be(m),_=new Map,O=[];for(let[R,S]of Object.entries(v.nodes)){let E=(S.deps??[]).map(D=>D.startsWith("$")&&h.bind[D]?h.bind[D]:D),N={...S,deps:E};if(S.type==="state"){let D=te(S.initial,{name:R,meta:S.meta?{...S.meta}:void 0});w.add(D,{name:R}),_.set(R,D)}else if(S.type==="producer"){let D=S.source?g(S.source):void 0,I=S.fn?l(S.fn):void 0;if(D){let M=D(S.config??{});w.add(M,{name:R}),_.set(R,M)}else if(I){let M=I([],S.config??{});w.add(M,{name:R}),_.set(R,M)}else{c(`${m}.${R}`,S.fn,S.source);let M=Se(()=>{},{name:R,meta:{...S.meta,_specFn:S.fn,_specSource:S.source}});w.add(M,{name:R}),_.set(R,M)}}else O.push([R,N])}let x=!0,T=new Map(O);for(;T.size>0&&x;){x=!1;for(let[R,S]of[...T.entries()]){let E=S.deps??[];if(!E.every(B=>_.has(B)||p.has(B)))continue;let D=E.map(B=>_.get(B)??p.get(B)),I=S.fn?l(S.fn):void 0,M;I?M=I(D,S.config??{}):S.type==="effect"?(S.fn&&c(`${m}.${R}`,S.fn,void 0),M=Ie(D,()=>{})):(S.fn&&c(`${m}.${R}`,S.fn,void 0),M=ie(D,B=>B[0])),w.add(M,{name:R}),_.set(R,M),T.delete(R),x=!0}}if(T.size>0){let R=[...T.keys()].sort().join(", ");throw new Error(`compileSpec: template "${h.template}" has unresolvable deps: ${R}`)}s.mount(m,w);let k=`${m}::${v.output}`;p.set(m,s.resolve(k));try{let R=s.resolve(k);R.meta._templateName?.emit(h.template),R.meta._templateBind?.emit(h.bind)}catch{}}for(let m of t.feedback??[])gn(s,m.from,m.to,{maxIterations:m.maxIterations});if(u.length>0){if(o==="error"){let m=u.map(y=>` - ${y.path}: missing ${y.kind} "${y.name}"`);throw new Error(`compileSpec: ${u.length} catalog entr${u.length===1?"y":"ies"} missing \u2014 pass them via opts.catalog or set opts.onMissing to "warn"/"placeholder":
|
|
18
18
|
${m.join(`
|
|
19
|
-
`)}`)}if(o==="warn"){let m=e?.onWarn??(y=>console.warn(y));for(let y of u)m(`compileSpec: ${y.path} references missing ${y.kind} "${y.name}" \u2014 substituted placeholder`)}}return s}var
|
|
19
|
+
`)}`)}if(o==="warn"){let m=e?.onWarn??(y=>console.warn(y));for(let y of u)m(`compileSpec: ${y.path} references missing ${y.kind} "${y.name}" \u2014 substituted placeholder`)}}return s}var Vr=new Set(["reduction","reduction_type","_specFn","_specSource","_templateName","_templateBind","feedbackFrom","feedbackTo","_internal"]);function Hr(t){let e=t.describe({detail:"standard"}),n={},r=[],o=`::${U}::`,s=/^__feedback_(?!effect_)(.+)$/,i=new Set;for(let f of Object.keys(e.nodes)){if(f.includes(o))continue;let d=s.exec(f);if(d){i.add(d[1]);let b=e.nodes[f]?.meta;b?.feedbackFrom&&b?.feedbackTo&&r.push({from:b.feedbackFrom,to:b.feedbackTo,...b.maxIterations?{maxIterations:b.maxIterations}:{}})}}for(let[f,d]of Object.entries(e.nodes)){if(f.includes(o)||s.test(f)||d.meta?._internal||f.startsWith("__feedback_effect_")||f.startsWith("__bridge_")||f.includes("::"))continue;let b={type:d.type};if(d.deps.length>0&&(b.deps=d.deps.filter(m=>!m.includes("::"))),d.type==="state"&&d.value!==void 0&&(b.initial=d.value),d.meta&&Object.keys(d.meta).length>0){let m={};for(let[y,h]of Object.entries(d.meta))Vr.has(y)||(m[y]=h);Object.keys(m).length>0&&(b.meta=m)}n[f]=b}let a={},u={},c=new Set;for(let f of e.subgraphs){let d=`${f}::`;for(let[b,m]of Object.entries(e.nodes)){if(!b.startsWith(d)||b.includes(o))continue;let y=m.meta;if(y?._templateName&&y?._templateBind){let h=y._templateName,v=y._templateBind;if(!a[h]){let w={},_=new Set,O=`${f}::`;for(let[E,N]of Object.entries(e.nodes)){if(!E.startsWith(O)||E.includes(o))continue;let D=E.slice(O.length);D.includes("::")||(_.add(D),w[D]={type:N.type,...N.deps.length>0?{deps:N.deps.map(I=>I.startsWith(O)?I.slice(O.length):I)}:{}})}let x=[],T=new Map;for(let E of Object.values(w))for(let N of E.deps??[])if(!_.has(N)&&!T.has(N)){let D=`$${N}`;x.push(D),T.set(N,D)}for(let E of Object.values(w))E.deps&&(E.deps=E.deps.map(N=>T.get(N)??N));let k=new Set;for(let E of Object.values(w))for(let N of E.deps??[])_.has(N)&&k.add(N);let S=[..._].filter(E=>!k.has(E))[0]??[..._].pop();a[h]={params:x,nodes:w,output:S}}delete n[f],u[f]={type:"template",template:h,bind:v},c.add(f);break}}}let l=new Map;for(let f of e.subgraphs){if(c.has(f))continue;let d={},b=`${f}::`;for(let[y,h]of Object.entries(e.nodes)){if(y.includes(o)||!y.startsWith(b))continue;let v=y.slice(b.length);v.includes("::")||(d[v]={type:h.type,...h.deps.length>0?{deps:h.deps.map(w=>w.startsWith(b)?w.slice(b.length):w)}:{}})}let m=JSON.stringify(Object.fromEntries(Object.entries(d).sort(([y],[h])=>y.localeCompare(h)).map(([y,h])=>[y,{type:h.type,deps:h.deps??[]}])));l.has(m)||l.set(m,[]),l.get(m).push({name:f,nodes:d})}for(let[,f]of l){if(f.length<2)continue;let d=`${f[0].name}_template`,b=f[0].nodes,m=new Set(Object.keys(b)),y=[],h=new Map;for(let x of Object.values(b))for(let T of x.deps??[])if(!m.has(T)&&!h.has(T)){let k=`$${T}`;y.push(k),h.set(T,k)}let v=new Set;for(let x of Object.values(b))for(let T of x.deps??[])m.has(T)&&v.add(T);let _=[...m].filter(x=>!v.has(x))[0]??[...m].pop(),O={};for(let[x,T]of Object.entries(b))O[x]={...T,deps:T.deps?.map(k=>h.get(k)??k)};a[d]={params:y,nodes:O,output:_};for(let x of f){delete n[x.name];let T={},k=new Set(Object.keys(x.nodes));for(let R of Object.values(x.nodes))for(let S of R.deps??[])if(!k.has(S)){let E=h.get(S)??`$${S}`;T[E]=S}u[x.name]={type:"template",template:d,bind:T}}}let g={...n,...u},p={name:e.name,nodes:g};return Object.keys(a).length>0&&(p.templates=a),r.length>0&&(p.feedback=r),p}function zr(t,e){let n=[];t.name!==e.name&&n.push({type:"changed",path:"name",detail:`"${t.name}" \u2192 "${e.name}"`});let r=new Set(Object.keys(t.nodes)),o=new Set(Object.keys(e.nodes));for(let h of o)if(!r.has(h)){let v=e.nodes[h];n.push({type:"added",path:`nodes.${h}`,detail:`type: ${v.type}`})}for(let h of r)o.has(h)||n.push({type:"removed",path:`nodes.${h}`});for(let h of r){if(!o.has(h))continue;let v=t.nodes[h],w=e.nodes[h];if(JSON.stringify(v)!==JSON.stringify(w)){let _=[];v.type!==w.type&&_.push(`type: ${v.type} \u2192 ${w.type}`),JSON.stringify(v.deps)!==JSON.stringify(w.deps)&&_.push("deps changed"),v.fn!==w.fn&&_.push(`fn: ${v.fn} \u2192 ${w.fn}`),JSON.stringify(v.config)!==JSON.stringify(w.config)&&_.push("config changed"),n.push({type:"changed",path:`nodes.${h}`,detail:_.join("; ")||"modified"})}}let s=t.templates??{},i=e.templates??{},a=new Set(Object.keys(s)),u=new Set(Object.keys(i));for(let h of u)a.has(h)||n.push({type:"added",path:`templates.${h}`});for(let h of a)u.has(h)||n.push({type:"removed",path:`templates.${h}`});for(let h of a)u.has(h)&&JSON.stringify(s[h])!==JSON.stringify(i[h])&&n.push({type:"changed",path:`templates.${h}`,detail:"template definition changed"});let c=t.feedback??[],l=e.feedback??[],g=new Set(c.map(h=>`${h.from}->${h.to}`)),p=new Set(l.map(h=>`${h.from}->${h.to}`));for(let h of l){let v=`${h.from}->${h.to}`;g.has(v)||n.push({type:"added",path:`feedback.${v}`,detail:`maxIterations: ${h.maxIterations??10}`})}for(let h of c){let v=`${h.from}->${h.to}`;p.has(v)||n.push({type:"removed",path:`feedback.${v}`})}for(let h of c){let v=`${h.from}->${h.to}`,w=l.find(_=>_.from===h.from&&_.to===h.to);w&&JSON.stringify(h)!==JSON.stringify(w)&&n.push({type:"changed",path:`feedback.${v}`,detail:`maxIterations: ${h.maxIterations??10} \u2192 ${w.maxIterations??10}`})}let f=n.filter(h=>h.type==="added").length,d=n.filter(h=>h.type==="removed").length,b=n.filter(h=>h.type==="changed").length,m=[];f&&m.push(`${f} added`),d&&m.push(`${d} removed`),b&&m.push(`${b} changed`);let y=m.length>0?m.join(", "):"no changes";return{entries:n,summary:y}}var wn=`You are a graph architect for GraphReFly, a reactive graph protocol.
|
|
20
20
|
|
|
21
21
|
Given a natural-language description, produce a JSON GraphSpec with this structure:
|
|
22
22
|
|
|
@@ -1,7 +1,7 @@
|
|
|
1
|
-
import '../../node-
|
|
2
|
-
import '../../graph-
|
|
3
|
-
import '../../types-
|
|
4
|
-
export { C as CatalogFnEntry, a as CatalogSourceEntry, j as CompileSpecOptions, b as ConfigFieldSchema, F as FnFactory, G as GraphSpec, c as GraphSpecCatalog, d as GraphSpecFeedbackEdge, e as GraphSpecNode, f as GraphSpecTemplate, g as GraphSpecTemplateRef, h as GraphSpecValidation, L as LLMComposeOptions, k as LLMRefineOptions, S as SourceFactory, l as SpecDiffEntry, m as SpecDiffResult, n as compileSpec, o as decompileGraph, p as extractFnFactory, q as extractSourceFactory, r as generateCatalogPrompt, s as isRichFnEntry, t as isRichSourceEntry, u as llmCompose, v as llmRefine, w as specDiff, x as validateSpec, y as validateSpecAgainstCatalog } from '../../index-
|
|
5
|
-
import '../../meta-
|
|
1
|
+
import '../../node-8qx0kgYt.cjs';
|
|
2
|
+
import '../../graph-DaoydJ_u.cjs';
|
|
3
|
+
import '../../types-Cp_4coR_.cjs';
|
|
4
|
+
export { C as CatalogFnEntry, a as CatalogSourceEntry, j as CompileSpecOptions, b as ConfigFieldSchema, F as FnFactory, G as GraphSpec, c as GraphSpecCatalog, d as GraphSpecFeedbackEdge, e as GraphSpecNode, f as GraphSpecTemplate, g as GraphSpecTemplateRef, h as GraphSpecValidation, L as LLMComposeOptions, k as LLMRefineOptions, S as SourceFactory, l as SpecDiffEntry, m as SpecDiffResult, n as compileSpec, o as decompileGraph, p as extractFnFactory, q as extractSourceFactory, r as generateCatalogPrompt, s as isRichFnEntry, t as isRichSourceEntry, u as llmCompose, v as llmRefine, w as specDiff, x as validateSpec, y as validateSpecAgainstCatalog } from '../../index-BkfL5MXh.cjs';
|
|
5
|
+
import '../../meta-BdjSt8ky.cjs';
|
|
6
6
|
import '../../extra/storage-core.cjs';
|
|
7
7
|
import '../../extra/sources.cjs';
|
|
@@ -1,7 +1,7 @@
|
|
|
1
|
-
import '../../node-
|
|
2
|
-
import '../../graph-
|
|
3
|
-
import '../../types-
|
|
4
|
-
export { C as CatalogFnEntry, a as CatalogSourceEntry, j as CompileSpecOptions, b as ConfigFieldSchema, F as FnFactory, G as GraphSpec, c as GraphSpecCatalog, d as GraphSpecFeedbackEdge, e as GraphSpecNode, f as GraphSpecTemplate, g as GraphSpecTemplateRef, h as GraphSpecValidation, L as LLMComposeOptions, k as LLMRefineOptions, S as SourceFactory, l as SpecDiffEntry, m as SpecDiffResult, n as compileSpec, o as decompileGraph, p as extractFnFactory, q as extractSourceFactory, r as generateCatalogPrompt, s as isRichFnEntry, t as isRichSourceEntry, u as llmCompose, v as llmRefine, w as specDiff, x as validateSpec, y as validateSpecAgainstCatalog } from '../../index-
|
|
5
|
-
import '../../meta-
|
|
1
|
+
import '../../node-8qx0kgYt.js';
|
|
2
|
+
import '../../graph-BROUZPG9.js';
|
|
3
|
+
import '../../types-B2LfBvNc.js';
|
|
4
|
+
export { C as CatalogFnEntry, a as CatalogSourceEntry, j as CompileSpecOptions, b as ConfigFieldSchema, F as FnFactory, G as GraphSpec, c as GraphSpecCatalog, d as GraphSpecFeedbackEdge, e as GraphSpecNode, f as GraphSpecTemplate, g as GraphSpecTemplateRef, h as GraphSpecValidation, L as LLMComposeOptions, k as LLMRefineOptions, S as SourceFactory, l as SpecDiffEntry, m as SpecDiffResult, n as compileSpec, o as decompileGraph, p as extractFnFactory, q as extractSourceFactory, r as generateCatalogPrompt, s as isRichFnEntry, t as isRichSourceEntry, u as llmCompose, v as llmRefine, w as specDiff, x as validateSpec, y as validateSpecAgainstCatalog } from '../../index-Chi9IiHJ.js';
|
|
5
|
+
import '../../meta-CtDjj7cU.js';
|
|
6
6
|
import '../../extra/storage-core.js';
|
|
7
7
|
import '../../extra/sources.js';
|
|
@@ -1 +1 @@
|
|
|
1
|
-
import{a,b,c,d,e,f,g,h,i,j,k,l}from"../../chunk-
|
|
1
|
+
import{a,b,c,d,e,f,g,h,i,j,k,l}from"../../chunk-U2T2XWDA.js";import"../../chunk-PBN426RU.js";import"../../chunk-L3KUKDZC.js";import"../../chunk-TZQPPQEQ.js";import"../../chunk-2JO6LXFT.js";import"../../chunk-SGS4OJGS.js";import"../../chunk-ESMPEKEV.js";import"../../chunk-533RQFF6.js";import"../../chunk-4F564IPP.js";import"../../chunk-4VVTGLXJ.js";import"../../chunk-T7EQPKOP.js";import"../../chunk-LYCLF26R.js";import"../../chunk-CK2E7BTU.js";import"../../chunk-QYADASLV.js";export{h as compileSpec,i as decompileGraph,c as extractFnFactory,d as extractSourceFactory,e as generateCatalogPrompt,a as isRichFnEntry,b as isRichSourceEntry,k as llmCompose,l as llmRefine,j as specDiff,g as validateSpec,f as validateSpecAgainstCatalog};
|