sootsim 0.1.133 → 0.1.135

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (153) hide show
  1. package/detox/gestures.ts +2 -2
  2. package/detox/index.ts +211 -9
  3. package/dist-cli/bin.js +3 -3
  4. package/dist-cli/chunks/{agent-HUV6ZDVC.js → agent-EV3LMTI2.js} +2 -2
  5. package/dist-cli/chunks/{agent-wrapper-DWQ4YJ2L.js → agent-wrapper-GOUAYJWS.js} +2 -2
  6. package/dist-cli/chunks/{app-fonts-KZU5WKNH.js → app-fonts-7ZGCVBWL.js} +2 -2
  7. package/dist-cli/chunks/{assert-O6MCNH6B.js → assert-CZPAVBXB.js} +2 -2
  8. package/dist-cli/chunks/auto-bootstrap-PRFJ44RD.js +2 -0
  9. package/dist-cli/chunks/beta-HNHNY7GJ.js +2 -0
  10. package/dist-cli/chunks/chunk-2RQ5M6MJ.js +13 -0
  11. package/dist-cli/chunks/{chunk-A34CFM2J.js → chunk-2VUPH4SQ.js} +1 -1
  12. package/dist-cli/chunks/{chunk-Q3GCZEPC.js → chunk-45Z6VTEC.js} +1 -1
  13. package/dist-cli/chunks/{chunk-KUTTVAMM.js → chunk-4PJFJ77U.js} +1 -1
  14. package/dist-cli/chunks/{chunk-HSNSCKU6.js → chunk-56LSJ5RZ.js} +2 -2
  15. package/dist-cli/chunks/{chunk-KFN2YKGC.js → chunk-5HFMOWG3.js} +1 -1
  16. package/dist-cli/chunks/{chunk-KHC77NFP.js → chunk-5JSVHUKF.js} +3 -3
  17. package/dist-cli/chunks/{chunk-XEGM2NRW.js → chunk-5PB5X45Q.js} +2 -2
  18. package/dist-cli/chunks/{chunk-THJDQ2EB.js → chunk-7TWZYT4A.js} +1 -1
  19. package/dist-cli/chunks/{chunk-R4PCQVBM.js → chunk-7WF23EDW.js} +2 -2
  20. package/dist-cli/chunks/{chunk-GCNZ32Y7.js → chunk-AQ6QT2DY.js} +2 -2
  21. package/dist-cli/chunks/{chunk-FJRIG6HG.js → chunk-ASXKBNRL.js} +2 -2
  22. package/dist-cli/chunks/{chunk-GMHBZDQA.js → chunk-CLO4G4ZK.js} +1 -1
  23. package/dist-cli/chunks/{chunk-2NV5VDY3.js → chunk-CYELNMX7.js} +2 -2
  24. package/dist-cli/chunks/{chunk-IMG7XQRR.js → chunk-DNF7AILW.js} +2 -2
  25. package/dist-cli/chunks/{chunk-2OST4PMS.js → chunk-EKZJFBGU.js} +2 -2
  26. package/dist-cli/chunks/{chunk-LK6Y3IGB.js → chunk-G7W4URXX.js} +2 -2
  27. package/dist-cli/chunks/{chunk-4CQXBMKU.js → chunk-GBBGAIOO.js} +1 -1
  28. package/dist-cli/chunks/chunk-GGLJLJ7P.js +1 -0
  29. package/dist-cli/chunks/{chunk-VO3QIOCT.js → chunk-IJU5JVF2.js} +1 -1
  30. package/dist-cli/chunks/{chunk-G4OBKVUY.js → chunk-MLNENEA4.js} +1 -1
  31. package/dist-cli/chunks/{chunk-7BCTUWOM.js → chunk-MLVYS3AE.js} +2 -2
  32. package/dist-cli/chunks/{chunk-YZVZA6IX.js → chunk-OC5UQFLJ.js} +1 -1
  33. package/dist-cli/chunks/{chunk-SKF4RZDK.js → chunk-OODLGJLZ.js} +2 -2
  34. package/dist-cli/chunks/{chunk-PZSY7LCJ.js → chunk-PVWYEMAR.js} +1 -1
  35. package/dist-cli/chunks/{chunk-AKIYNT56.js → chunk-PWRO2WPW.js} +1 -1
  36. package/dist-cli/chunks/{chunk-GDHDUANQ.js → chunk-QDGNAEBR.js} +2 -2
  37. package/dist-cli/chunks/{chunk-VZB6MROZ.js → chunk-QDRAULAC.js} +2 -2
  38. package/dist-cli/chunks/{chunk-RPQCGJI7.js → chunk-QLXTTGJD.js} +2 -2
  39. package/dist-cli/chunks/{chunk-BHPSNVNR.js → chunk-QMUNA6VQ.js} +3 -3
  40. package/dist-cli/chunks/{chunk-UJBMEBQF.js → chunk-S5ZKCSJZ.js} +1 -1
  41. package/dist-cli/chunks/chunk-TVCTN2EF.js +2 -0
  42. package/dist-cli/chunks/{chunk-BC357P2N.js → chunk-TXDUBB6W.js} +2 -2
  43. package/dist-cli/chunks/{chunk-MTXMNE75.js → chunk-U6TZCGUB.js} +1 -1
  44. package/dist-cli/chunks/{chunk-YL3KKAZR.js → chunk-UM7EEN26.js} +1 -1
  45. package/dist-cli/chunks/{chunk-OO3C2GYN.js → chunk-UNM45I7B.js} +2 -2
  46. package/dist-cli/chunks/{chunk-FXB2ETM3.js → chunk-UOBTAOWL.js} +2 -2
  47. package/dist-cli/chunks/chunk-VH4VPAMR.js +1 -0
  48. package/dist-cli/chunks/{chunk-HEOJB2Q7.js → chunk-XAVQLMY7.js} +2 -2
  49. package/dist-cli/chunks/{chunk-TTCMDOP6.js → chunk-XMZJQZFB.js} +2 -2
  50. package/dist-cli/chunks/{chunk-QGPM7UTZ.js → chunk-XOK53FNY.js} +1 -1
  51. package/dist-cli/chunks/{chunk-DYNVMRON.js → chunk-YQM3RWNV.js} +2 -2
  52. package/dist-cli/chunks/{chunk-ROINTL2P.js → chunk-Z5WZKI7J.js} +2 -2
  53. package/dist-cli/chunks/chunk-ZANDDBFJ.js +1 -0
  54. package/dist-cli/chunks/{chunk-NNRWRRI5.js → chunk-ZFDBEITH.js} +3 -3
  55. package/dist-cli/chunks/cli-version-EOI7UVCS.js +2 -0
  56. package/dist-cli/chunks/{compat-3BWLNHPY.js → compat-DZRWNMC2.js} +3 -3
  57. package/dist-cli/chunks/{config-H7YEVE5J.js → config-JNO26BKX.js} +2 -2
  58. package/dist-cli/chunks/{control-ZFU3T2LE.js → control-GWQ44GVR.js} +2 -2
  59. package/dist-cli/chunks/{cpu-profile-XYCDA5GM.js → cpu-profile-2VSK3E45.js} +2 -2
  60. package/dist-cli/chunks/{daemon-TBN5MRVC.js → daemon-QMFDDXFF.js} +2 -2
  61. package/dist-cli/chunks/{debug-2WAJZ4C7.js → debug-Q3K4TXLC.js} +3 -3
  62. package/dist-cli/chunks/demo-app-registry-LDTURANL.js +2 -0
  63. package/dist-cli/chunks/{detox-JLJPKRA3.js → detox-TX4AUV2W.js} +2 -2
  64. package/dist-cli/chunks/{device-WPWC2KSY.js → device-E5RRT67Y.js} +2 -2
  65. package/dist-cli/chunks/{diagnose-PYBIEZFD.js → diagnose-CGHRCXKF.js} +2 -2
  66. package/dist-cli/chunks/drivers-WF5OT6EA.js +2 -0
  67. package/dist-cli/chunks/{electron-ZW7YMV37.js → electron-YSY7HZBI.js} +3 -3
  68. package/dist-cli/chunks/flow-PV4WV3DZ.js +2 -0
  69. package/dist-cli/chunks/help-RZ2M7P7U.js +2 -0
  70. package/dist-cli/chunks/{hints-3YQNXM27.js → hints-V7M7GKXL.js} +2 -2
  71. package/dist-cli/chunks/{home-paths-SBGRHOZC.js → home-paths-KYTBCLPQ.js} +2 -2
  72. package/dist-cli/chunks/{inspect-YXTS4PR6.js → inspect-ZUYLUCRJ.js} +3 -3
  73. package/dist-cli/chunks/install-XLJ4CJUN.js +2 -0
  74. package/dist-cli/chunks/{install-desktop-27SPMPUV.js → install-desktop-HKLVDL7Q.js} +3 -3
  75. package/dist-cli/chunks/{keys-Y7OJXBGI.js → keys-QJDWORM5.js} +2 -2
  76. package/dist-cli/chunks/{launch-OUG2GFLO.js → launch-CBIYGOV7.js} +3 -3
  77. package/dist-cli/chunks/{login-XXJQHPWA.js → login-II2EWFHY.js} +4 -4
  78. package/dist-cli/chunks/{logout-FHJ26UTW.js → logout-E52753SB.js} +2 -2
  79. package/dist-cli/chunks/{maestro-P4ZVR2I4.js → maestro-DUIODHYF.js} +2 -2
  80. package/dist-cli/chunks/{preview-6ONBLQBI.js → preview-LSVZXF7S.js} +2 -2
  81. package/dist-cli/chunks/{profile-LQOEBIPK.js → profile-2LUO56EX.js} +2 -2
  82. package/dist-cli/chunks/{react-R4KJVWDA.js → react-KPNHGOQ3.js} +2 -2
  83. package/dist-cli/chunks/{record-OBJJDTFN.js → record-LLNZNJSY.js} +2 -2
  84. package/dist-cli/chunks/runtime-B3RQF5NL.js +2 -0
  85. package/dist-cli/chunks/{runtime-delivery-LEU6ABXJ.js → runtime-delivery-A2PZCEPU.js} +2 -2
  86. package/dist-cli/chunks/{screenshot-AKU27ZTJ.js → screenshot-OEIH2ETO.js} +2 -2
  87. package/dist-cli/chunks/{screenshot-mode-XPJM2SRF.js → screenshot-mode-3TDLGZPT.js} +2 -2
  88. package/dist-cli/chunks/{screenshots-SJY4LH2Q.js → screenshots-GCJW22B5.js} +2 -2
  89. package/dist-cli/chunks/{server-2SSM3BKA.js → server-CBH2UYLT.js} +3 -3
  90. package/dist-cli/chunks/setup-repo-U7XMVCQA.js +2 -0
  91. package/dist-cli/chunks/{skills-C7ZVO6AF.js → skills-DVPCRUUO.js} +2 -2
  92. package/dist-cli/chunks/{start-5BFFCFOT.js → start-2T5QRVL2.js} +4 -4
  93. package/dist-cli/chunks/store-WIQ4ZE4Z.js +2 -0
  94. package/dist-cli/chunks/telemetry-2XPV6PVU.js +2 -0
  95. package/dist-cli/chunks/{test-5YTOB2K7.js → test-ZGUHV3XE.js} +3 -3
  96. package/dist-cli/chunks/{three-mode-ZTVDFRRN.js → three-mode-3BUTKBTR.js} +2 -2
  97. package/dist-cli/chunks/{timeline-ZSHW5COY.js → timeline-WS2FXPG2.js} +2 -2
  98. package/dist-cli/chunks/{upgrade-DU2VLCLD.js → upgrade-FFTCNLCI.js} +2 -2
  99. package/dist-cli/chunks/upload-JQMTDQMQ.js +2 -0
  100. package/dist-cli/chunks/{version-G7MFHWDO.js → version-OQOFXNMZ.js} +2 -2
  101. package/dist-cli/chunks/web-Y2ZMUXP4.js +2 -0
  102. package/dist-cli/chunks/{what-happened-ZYPPAPQM.js → what-happened-5A2RUC6V.js} +2 -2
  103. package/dist-cli/chunks/{whoami-U4JDM3X4.js → whoami-ZVM5A34Z.js} +2 -2
  104. package/dist-lib/agent-daemon-client.cjs +1 -1
  105. package/dist-lib/agent-events.cjs +1 -1
  106. package/dist-lib/agent-sessions.cjs +1 -1
  107. package/dist-lib/attached-projects.cjs +1 -1
  108. package/dist-lib/auth/shared-session.cjs +1 -1
  109. package/dist-lib/backend-origin.cjs +1 -1
  110. package/dist-lib/beta.cjs +1 -1
  111. package/dist-lib/beta.mjs +1 -1
  112. package/dist-lib/bridge-constants.cjs +1 -1
  113. package/dist-lib/cli-constants.cjs +1 -1
  114. package/dist-lib/config.cjs +1 -1
  115. package/dist-lib/detox/index.cjs +169 -11
  116. package/dist-lib/dev-bundle-resolution.cjs +30 -1
  117. package/dist-lib/home-paths.cjs +1 -1
  118. package/dist-lib/host/bridge-host.cjs +1 -1
  119. package/dist-lib/host/fetch-proxy-handler.cjs +1 -1
  120. package/dist-lib/host/fetch-proxy-overrides.cjs +1 -1
  121. package/dist-lib/host/fetch-proxy-overrides.mjs +1 -1
  122. package/dist-lib/host/websocket-proxy.cjs +1 -1
  123. package/dist-lib/index.cjs +1 -1
  124. package/dist-lib/metro.cjs +1 -1
  125. package/dist-lib/profiles.cjs +1 -1
  126. package/dist-lib/render-mode.cjs +1 -1
  127. package/dist-lib/scripts/demo-app-registry.cjs +1 -1
  128. package/dist-lib/scripts/dev-server-scanner.cjs +1 -1
  129. package/dist-lib/sdk.cjs +1 -1
  130. package/dist-lib/sdk.mjs +1 -1
  131. package/dist-lib/skills.cjs +5 -5
  132. package/dist-lib/vite.cjs +1 -1
  133. package/package.json +1 -1
  134. package/src/dev-bundle-resolution.ts +64 -0
  135. package/dist-cli/chunks/auto-bootstrap-LTOQSXRM.js +0 -2
  136. package/dist-cli/chunks/beta-Y2OJHTRQ.js +0 -2
  137. package/dist-cli/chunks/chunk-7SYFZZK3.js +0 -2
  138. package/dist-cli/chunks/chunk-AEYD4ODQ.js +0 -1
  139. package/dist-cli/chunks/chunk-D3OLBBEO.js +0 -1
  140. package/dist-cli/chunks/chunk-ESQVUOW2.js +0 -13
  141. package/dist-cli/chunks/chunk-YP4W6KI5.js +0 -1
  142. package/dist-cli/chunks/cli-version-RQJHNNYX.js +0 -2
  143. package/dist-cli/chunks/demo-app-registry-JXOXYWFT.js +0 -2
  144. package/dist-cli/chunks/drivers-XPCQOVAR.js +0 -2
  145. package/dist-cli/chunks/flow-SWXVIYST.js +0 -2
  146. package/dist-cli/chunks/help-HAITGXVU.js +0 -2
  147. package/dist-cli/chunks/install-VFUIM3QH.js +0 -2
  148. package/dist-cli/chunks/runtime-6JVXVZ4K.js +0 -2
  149. package/dist-cli/chunks/setup-repo-X6WRLPI5.js +0 -2
  150. package/dist-cli/chunks/store-5FCKCDEL.js +0 -2
  151. package/dist-cli/chunks/telemetry-N6DCFUGB.js +0 -2
  152. package/dist-cli/chunks/upload-QLV4POAH.js +0 -2
  153. package/dist-cli/chunks/web-66TKNXN5.js +0 -2
@@ -1,2 +0,0 @@
1
- /*! sootsim v0.1.133 | (c) 2026 Tamagui LLC | Proprietary — see LICENSE */
2
- var t="http://localhost:5173/";export{t as a};
@@ -1 +0,0 @@
1
- /*! sootsim v0.1.133 | (c) 2026 Tamagui LLC | Proprietary — see LICENSE */
@@ -1 +0,0 @@
1
- /*! sootsim v0.1.133 | (c) 2026 Tamagui LLC | Proprietary — see LICENSE */
@@ -1,13 +0,0 @@
1
- /*! sootsim v0.1.133 | (c) 2026 Tamagui LLC | Proprietary — see LICENSE */
2
- import{a as D,b as q,c as de,d as me}from"./chunk-RPQCGJI7.js";import{m as B}from"./chunk-HEOJB2Q7.js";import{m as le,o as ce}from"./chunk-PZSY7LCJ.js";import{a as pe,b as fe,c as ge}from"./chunk-YZVZA6IX.js";import{b as ae,c as I,d as v,e as x}from"./chunk-2OST4PMS.js";import{g as G}from"./chunk-DYNVMRON.js";import{a as M,b as V}from"./chunk-UJBMEBQF.js";import{c as ue}from"./chunk-ROINTL2P.js";import{d as j}from"./chunk-GMHBZDQA.js";import{d as k,e as w,f as T}from"./chunk-THJDQ2EB.js";import{a as ie}from"./chunk-7SYFZZK3.js";import{G as re,H as se}from"./chunk-YL3KKAZR.js";import Y from"node:fs";import Ae from"node:os";import P from"node:path";function Re(e){return e.replace(/^\[|\]$/g,"").toLowerCase()}function J(e){let o=Re(e);return o==="localhost"||o.endsWith(".localhost")||o==="0.0.0.0"||o==="::1"||/^127(?:\.\d{1,3}){3}$/.test(o)}function he(e){return new Error(`could not resolve a native bundle for ${e}. pass an explicit bundle URL or open Connect and choose the app there.`)}function Oe(e,o){return e?.includes("/one/metro-entry.bundle")?"one":typeof o=="string"&&o?"expo":"unknown"}function ye(e,o,t){return`${e}//${o}:${t}`}function Ue(e){if(typeof window>"u")return!1;try{let o=new URL(e);return J(o.hostname)&&J(window.location.hostname)&&o.origin!==window.location.origin}catch{return!1}}async function we(e,o){let t={...o,cache:o?.cache??"no-store"};return Ue(e)?fetch(`/__fetch-proxy?url=${encodeURIComponent(e)}`,t):fetch(e,t)}function Be(e){return e==="https:"?443:80}function De(e){let o=e.pathname||"/";return(o==="/"||o==="")&&!e.search&&!e.hash}async function ve(e,o){let t=e.replace(/\/+$/,"");try{let n=await we(`${t}/`,{headers:{"expo-platform":"ios"}});if(n.ok){let r=await n.json(),s=r?.extra?.expoClient||r?.extra||{},a=typeof r?.launchAsset?.url=="string"?r.launchAsset.url:void 0;if(a||s.name)return{bundleUrl:de(a||`${t}${q}`),port:o,framework:Oe(a,s.sdkVersion),projectName:s.name}}}catch{}try{let n=await we(`${t}/status`);if(n.ok&&(await n.text()).includes("packager-status:running"))return{bundleUrl:`${t}${q}`,port:o,framework:"metro"}}catch{}return null}async function be(e){return ve(ye("http:","localhost",e),e)}async function Se(e){let o=e.trim();if(/^\d+$/.test(o)){let i=parseInt(o,10),l=await be(i);if(l)return l;let c=3;for(let d=1;d<=c;d++){let m=await be(i+d);if(m)return m}throw he(`localhost:${i} (also scanned +1..+${c})`)}let t=o.startsWith("http")?o:`http://${o}`,n;try{n=new URL(t)}catch{throw new Error(`could not parse "${e}". pass a dev-server port, a dev-server base URL, or a full bundle URL.`)}let r=n.protocol||"http:",s=n.port?parseInt(n.port,10):Be(r),a=ye(r,n.hostname,s);if(De(n)){let i=await ve(a,s);if(i)return i;throw he(a)}return{bundleUrl:n.toString(),port:s,framework:"unknown"}}function vt(){console.error(" no sootsim desktop companion found."),console.error(""),console.error(" install the desktop app:"),console.error(" sootsim install-desktop"),console.error(""),console.error(" or wire sootsim into your own project so your dev server hosts the bridge:"),console.error(" sootsim setup-repo"),console.error("")}function $e(e){let o=M();if(console.log(` note: no sootsim bridge detected on port ${e}`),o){console.log(" launch the installed companion with:"),console.log(" sootsim electron");return}console.log(""),console.log(" to get a bridge running, either:"),console.log(" sootsim install-desktop # download the electron app"),console.log(" sootsim setup-repo # wire sootsim into your own project")}function Le(e){console.error(""),console.error(` no sim is connected to the sootsim bridge on port ${e}.`),console.error(""),console.error(" start your app dev server, then open it in sootsim:"),console.error(" npx expo start --localhost --port 8081"),console.error(" sootsim open 8081"),console.error(""),console.error(" then inspect the live app:"),console.error(" sootsim describe")}async function St(e,o,t){let n=[];try{n=await e.listSims()}catch{}if(console.error(""),n.length===0){Le(o);return}console.error(` no sim with id "${t}" is connected to the bridge on port ${o}.`),console.error(""),console.error(" connected sims:");for(let r of n){let s=[r.isPrimary?"primary":null,r.readyState,r.userVisible===!1?"hidden":r.userVisible===!0?"visible":null,r.userFocused?"focused":null].filter(Boolean).join(", ");console.error(` ${r.id} (${s})`)}console.error(""),console.error(" pass a valid --sim id, or run `sootsim list` to see all sessions.")}var Ne=12e4,Ie=500,Fe=5e3,He={rn:"/rn",connectrn:"/rn","connect-rn":"/rn",clock:"/app/clock","native-ui":"/app/native-ui",tamagui:"/app/tamagui",settings:"/app/settings",photos:"/app/photos",camera:"/app/camera"};function S(e){return new Promise(o=>setTimeout(o,e))}function xe(e){let o=process.env[e]?.trim();if(!o)return null;let t=Number(o);return Number.isInteger(t)&&t>0?t:null}function Ke(){let e=xe("SOOTSIM_DRIVER_CONNECT_TIMEOUT_MS")??xe("SOOTSIM_PW_CONNECT_TIMEOUT_MS")??Ne;return{timeoutMs:e,hostTimeoutMs:e+Fe,intervalMs:Ie,attempts:Math.max(1,Math.ceil(e/Ie))}}function We(e){return e==="chromium"||e==="electron"||e==="playwright"||e==="system"}function N(e){return e.trim()}function X(e){try{let o=new URL(e),t=o.pathname.replace(/\/+$/,"")||"/";return o.searchParams.has("open")||o.searchParams.has("port")||o.searchParams.has("bundle")||o.searchParams.has("demo")||o.pathname.includes("/sootsim/index.html")||t==="/sootsim"||o.pathname==="/__soot"||o.pathname==="/__soot/"||t==="/rn"||/^\/rn\/[^/]+$/i.test(t)||/^\/app\/[^/]+$/i.test(t)||t==="/__soot/rn"||/^\/__soot\/rn\/[^/]+$/i.test(t)||/^\/__soot\/app\/[^/]+$/i.test(t)}catch{return!1}}function ze(e){try{let o=new URL(e).pathname.replace(/\/+$/,"")||"/";return/^\/preview\/[^/]+$/.test(o)||/^\/build\/.+/.test(o)}catch{return!1}}async function Ht(e){let o=N(e);return(await Te(o)).bundleUrl}function je(e){try{let o=new URL(e.startsWith("http")?e:`http://${e}`),t=o.pathname||"/";if(t!=="/"&&t!==""||o.search||o.hash||!/^(localhost|127\.0\.0\.1|\[::1\]|::1)$/i.test(o.hostname))return null;let n=o.port?Number(o.port):o.protocol==="https:"?443:80;return Number.isFinite(n)&&n>0?n:null}catch{return null}}async function Te(e){let o=N(e),t=/^\d+$/.test(o)?Number(o):je(o);if(t&&t>0){let n=await me(t);if(n)return{bundleUrl:n.bundleUrl,port:n.port,framework:n.framework,projectName:n.projectName}}return Se(o)}function Z(e){let o=e.replace(/\/+$/,"")||"/";return o==="/__soot"||o.startsWith("/__soot/")?"/__soot":""}function qe(e,o){let t=N(e),n=new URL(o),r=Z(n.pathname);return n.pathname=`${r}/rn`,n.searchParams.delete("bundle"),n.searchParams.delete("demo"),n.searchParams.delete("app"),n.searchParams.delete("open"),n.searchParams.delete("port"),/^\d+$/.test(t)?n.pathname=`${r}/rn/${t}`:(n.pathname=`${r}/rn`,n.searchParams.set("open",t)),n.toString()}function Ve(e){let o=N(e);return/^\d+$/.test(o)||/^https?:\/\//i.test(o)?!0:/^(localhost|127\.0\.0\.1|\[::1\]|[^/]+\.localhost):\d+(?:\/.*)?$/i.test(o)}async function Ge(e,o){let t=await Te(e),n=new URL(o),r=Z(n.pathname);return n.pathname=`${r}/rn`,n.searchParams.delete("open"),n.searchParams.delete("port"),n.searchParams.delete("demo"),n.searchParams.delete("app"),n.searchParams.set("bundle",t.bundleUrl),n.toString()}function Je(e){return e.startsWith("~/")?P.join(Ae.homedir(),e.slice(2)):P.isAbsolute(e)?e:P.resolve(process.cwd(),e)}function Qe(e){let o={};for(let t=0;t<e.length;t++){if(e[t]!=="--replace")continue;let n=e[t+1];n||(console.error(" sootsim open: --replace expects <module>=<file>"),process.exit(1));let r=n.indexOf("=");(r<=0||r===n.length-1)&&(console.error(" sootsim open: --replace expects <module>=<file>"),process.exit(1));let s=n.slice(0,r).trim(),a=Je(n.slice(r+1).trim());Y.existsSync(a)||(console.error(` sootsim open: replacement file not found: ${a}`),process.exit(1)),o[s]={file:a},t++}return Object.keys(o).length>0?{modules:o}:void 0}function Me(){let e=re();return se(e)&&e.runtimePort>0?`http://localhost:${e.runtimePort}/`:ie}async function Xe(e){try{let o=new URL(e),t=o.searchParams.get("bundle")||"";if(!t)return e;let n=process.env.SOOT_REPO_DIR||await fe(t)||void 0,r=pe({bundleUrl:t,repoDir:n});if(r.length===0)return e;let s=await Ye(r);return s.length===0?e:(o.searchParams.set("appFonts",ge(s)),o.toString())}catch{return e}}async function Ye(e){let o=await Promise.all(e.map(async n=>{let r=new AbortController,s=setTimeout(()=>r.abort(),1500);try{let a=await fetch(n.url,{method:"HEAD",signal:r.signal});return a.status>=200&&a.status<400?n:null}catch{return null}finally{clearTimeout(s)}})),t=[];for(let n of o)n!==null&&t.push(n);return t}async function Ze(e,o){if(!e)return new URL(o).toString();if(X(e))return new URL(e).toString();let t=He[e.toLowerCase()];if(t){let n=new URL(o),r=Z(n.pathname);return n.pathname=`${r}${t}`,n.toString()}return Ve(e)?Ge(e,o):qe(e,o)}async function A(e,o=Me()){let t=await Ze(e,o);return Xe(t)}function Pe(e,o){let t=e?.url||e?.origin||o;try{let n=new URL(t);return n.searchParams.delete("bundle"),n.searchParams.delete("demo"),n.searchParams.delete("app"),n.searchParams.delete("open"),n.searchParams.delete("port"),n.searchParams.delete("inspectOpen"),n.searchParams.delete("appFonts"),n.toString()}catch{return o}}async function et(e,o,t){let n=new URL(await A(e,o));return n.searchParams.set("inspectOpen",t),n.toString()}async function tt(e,o,t,n={}){let r=n.attempts??30,s=n.intervalMs??500,a=n.minNodeCount??10;for(let i=0;i<r;i++){let l=v(e,{commandTimeoutMs:o,simId:t,simIdSource:"flag"});try{let c=await l.send({type:"evaluate",code:"(async () => (await window.__sootsimTest?.getNodeCount()) || 0)()"});if(typeof c=="number"&&c>a)return{bridge:l,count:c}}catch{}l.close(),await S(s)}return null}function ot(e){if(!e)return null;try{let o=new URL(e);if(o.searchParams.has("bundle")){let t=o.searchParams.get("bundle")||"";try{let n=new URL(t),r=n.pathname.length>36?`...${n.pathname.slice(-36)}`:n.pathname;return`bundle ${n.host}${r}`}catch{return"bundle"}}return o.searchParams.has("port")?`connect :${o.searchParams.get("port")||""}`:o.searchParams.has("open")?`connect ${o.searchParams.get("open")||""}`:o.searchParams.has("demo")?`demo ${o.searchParams.get("demo")||"default"}`:o.pathname.includes("/sootsim/index.html")||o.pathname==="/sootsim/"||o.pathname==="/sootsim"?"embedded sootsim":null}catch{return null}}function nt(e){let o=e.indexOf(":");if(o<=0)return e.length>24?`${e.slice(0,21)}\u2026`:e;let t=e.slice(0,o),n=e.slice(o+1),r=n.length>12?`${n.slice(0,8)}\u2026`:n;return t==="CLAUDE_CODE_SESSION_ID"||t==="CODEX_THREAD_ID"?`agent ${r}`:`${t} ${r}`}function rt(e,o){if(e.length===0){console.log(" no sims connected");return}console.log(` connected sims (${e.length}):
3
- `);for(let t of e){let n=t.lockedBy&&t.lockExpiresAt?`locked by ${nt(t.lockedBy)} (${Math.max(0,Math.round((t.lockExpiresAt-Date.now())/1e3))}s)`:"",r=[t.isPrimary?"primary":"",t.id===o?"selected":"",t.readyState,t.userVisible===!1?"hidden":t.userVisible===!0?"visible":"",t.attachedCliCount&&t.attachedCliCount>0?"in use":"",t.userFocused?"focused":"",n].filter(Boolean);console.log(` ${t.id}${r.length?` [${r.join(", ")}]`:""}`);let s=ot(t.url);if(s)console.log(` loaded: ${s}`);else if(t.url){let i=t.url.length>96?`${t.url.slice(0,93)}\u2026`:t.url;console.log(` url: ${i}`)}else t.origin&&console.log(` origin: ${t.origin}`);let a=st(t);a&&console.log(` engine: ${a}`),t.title&&console.log(` title: ${t.title}`),t.visibilityState&&t.visibilityState!=="visible"&&console.log(` visibility: ${t.visibilityState}`),console.log(` connected: ${Ce(Date.now()-t.connectedAt)}`),t.lastActiveAt&&t.lastActiveAt>0&&console.log(` last active: ${Ce(Date.now()-t.lastActiveAt)}`)}}function st(e){let o=e.url||e.origin||"";if(!o)return null;try{let t=new URL(o).port;return t==="5173"?"dev \u2014 local source (:5173)":t==="3000"?"soot app embedded (:3000)":`runtime \u2014 published engine (:${t||"?"})`}catch{return null}}function Ce(e){let o=Math.max(0,Math.round(e/1e3));return o<60?`${o}s ago`:o<3600?`${Math.round(o/60)}m ago`:o<86400?`${Math.round(o/3600)}h ago`:`${Math.round(o/86400)}d ago`}async function L(e,o,t,n={}){let r=n.attempts??30,s=n.intervalMs??500;for(let a=0;a<r;a++){let i=v(e,{commandTimeoutMs:o});try{let c=(await i.listSims()).find(t);if(c)return c}catch{}finally{i.close()}await S(s)}return null}async function it(e,o,t,n={}){let r=n.attempts??20,s=n.intervalMs??250;for(let a=0;a<r;a++){let i=v(e,{commandTimeoutMs:o});try{let c=(await i.listSims()).find(d=>d.id===t);if(!c||c.readyState!=="open")return!0}catch{return!0}finally{i.close()}await S(s)}return!1}function at(e){let o=e.meta;if(!o||o.sootsimHostDriver!=="playwright")return null;let t=Number(o.sootsimHostPid);return!Number.isInteger(t)||t<=1||t===process.pid?null:t}function lt(e){if(!e.connectAckFile)return!1;try{return Y.writeFileSync(e.connectAckFile,`${JSON.stringify({connectedAt:Date.now(),pid:e.pid??null})}
4
- `,{flag:"w"}),!0}catch{return!1}}function ct(e){if(e.diagnosticLogPath)try{let o=Y.readFileSync(e.diagnosticLogPath,"utf8").trim();if(!o){console.error(` ${P.basename(e.diagnosticLogPath)} was empty`);return}let t=o.length>4e3?`\u2026
5
- ${o.slice(-4e3)}`:o;console.error(` ${P.basename(e.diagnosticLogPath)}:`),console.error(t)}catch(o){let t=o instanceof Error?o.message:String(o);console.error(` failed to read ${P.basename(e.diagnosticLogPath)}: ${t}`)}}function ke(e){try{return process.kill(e,0),!0}catch(o){return o?.code==="EPERM"}}async function dt(e,o=2500){let t=Date.now()+o;for(;Date.now()<t;){if(!ke(e))return!0;await S(100)}return!ke(e)}async function Q(e,o){let t=new Set(o),n=new Set;for(let r of e){if(!t.has(r.id))continue;let s=at(r);s&&n.add(s)}for(let r of n){try{process.kill(r,"SIGTERM")}catch{}if(await dt(r)){console.log(` closed playwright host process ${r}`);continue}try{process.kill(r,"SIGKILL"),console.log(` force-closed playwright host process ${r}`)}catch{}}}function F(e,o){if(o){let r=o.trim(),s=e.find(a=>a.id===r);if(!s)throw new Error(`no sim connected with id ${r}`);return s}let t=e.find(r=>r.isPrimary&&r.readyState==="open");if(t)return t;let n=e.find(r=>r.readyState==="open");if(n)return n;throw new Error("no sim connected")}function _(e,o,t){console.log(` ${t==="current sim"?"loaded":"opened"}: ${e} [${t}]`),console.log(` current sim: ${o.id}`),console.log(JSON.stringify({simId:o.id,url:o.url},null,2))}async function E(e,o,t){if(t.includes("--no-describe"))return;let n=process.env.SOOTSIM_QUIET_TARGET_NOTICE;process.env.SOOTSIM_QUIET_TARGET_NOTICE="1";try{await mt(e,o,{stableMs:150,maxMs:400});let r=v(e,{commandTimeoutMs:3e3,simId:o,cliLabel:"open --describe",simIdSource:"flag"});try{let s=null;try{s=await r.send({type:"evaluate",code:le})}catch{}if(s&&!(s.flag===!0&&!s.loadingText&&ce(s))){let d=s.loadingText?`still showing "${s.loadingText}"`:s.flag!==!0?"guest ready event has not fired":s.targets<=0?"no visible app content is inspectable yet":"app tree is still stabilizing";console.log(` app still loading: ${d} (nodes: ${s.nodes}, targets: ${s.targets})`),console.log(" before interacting, run: sootsim wait ready --max-ms 120000")}let i=`(async () => {
6
- const t = window.__sootsimTest
7
- const ms = window.SootSim?.bridges?.mainShell
8
- if (!t) return null
9
- let shell = null
10
- try { shell = ms?.getState ? await ms.getState() : null } catch {}
11
- const tree = await t.dumpTree(12, ${JSON.stringify({describe:!0,verbose:!1,filter:""})})
12
- return { tree, shell }
13
- })()`,l=await r.send({type:"evaluate",code:i});if(!l?.tree)return;if(console.log(""),l.shell?.state){let c=[`state=${l.shell.state}`,l.shell.activeApp?`app=${l.shell.activeApp}`:null].filter(Boolean);console.log(` shell: ${c.join(" ")}`)}console.log(l.tree)}finally{r.close()}}catch{}finally{n===void 0?delete process.env.SOOTSIM_QUIET_TARGET_NOTICE:process.env.SOOTSIM_QUIET_TARGET_NOTICE=n}}async function mt(e,o,t){let n=Date.now()+t.maxMs,r="(async () => (await window.__sootsimTest?.getNodeCount?.()) || 0)()",s=v(e,{commandTimeoutMs:2e3,simId:o,simIdSource:"flag"});try{let a=-1,i=0;for(;Date.now()<n;){let l=-1;try{let c=await s.send({type:"evaluate",code:r});typeof c=="number"&&(l=c)}catch{}if(l>=0&&l===a){if(Date.now()-i>=t.stableMs)return}else a=l,i=Date.now();await S(50)}}finally{s.close()}}async function Kt(e,o={}){let t=I(e,{port:o.port,commandTimeoutMs:o.timeoutMs}),n=x(t);try{let r=await n.listSims();rt(r,t.simId)}finally{n.close()}}async function Wt(e,o={}){let t=I(e,{port:o.port,commandTimeoutMs:o.timeoutMs,stripBooleanFlags:["--new","--headless","--ephemeral"],stripValueFlags:["--base-url","--replace","--driver","--profile","--cdp-port"]}),n=e.find((u,p)=>e[p-1]==="--profile"),r=e.includes("--ephemeral"),s=e.find((u,p)=>e[p-1]==="--cdp-port"),a=s?Number(s):void 0;s&&(!Number.isFinite(a)||a<=0)&&(console.error(` sootsim open: --cdp-port must be a positive port number, got "${s}"`),process.exit(1)),n&&r&&(console.error(" sootsim open: --profile cannot be combined with --ephemeral"),process.exit(1));let i=n?ue(n).id:void 0,l=!!i||r,c=e.includes("--new")||l,d=Qe(e);c&&t.simIdSource==="flag"&&(console.error(" sootsim open: --new, --profile, and --ephemeral cannot be combined with --sim"),process.exit(1));let m=t.positional[0]||"";if(ze(m)){let u=(()=>{try{return/^(localhost|127\.0\.0\.1|\[::1\]|::1)$/i.test(new URL(m).hostname)}catch{return!1}})();console.log(" that\u2019s a SootSim preview/build link \u2014 a full player page, not a driveable sim."),console.log(" opening it in your browser for viewing\u2026");try{await j(m,{background:!1})}catch(p){console.error(` could not launch a browser: ${p instanceof Error?p.message:String(p)}`),console.error(` open it yourself: ${m}`),process.exit(1)}console.log(u?" to drive it under the CLI, point `sootsim open` at the app\u2019s dev port instead (e.g. `sootsim open 8081`).":" the CLI can\u2019t drive a remote preview (the engine only attaches to the local bridge from localhost). to drive the app, run it locally and `sootsim open <port>`.");return}let h=e.find((u,p)=>e[p-1]==="--driver")||"",H=e.includes("--headless");a&&h!=="playwright"&&(console.error(" sootsim open: --cdp-port is only honored by the playwright driver \u2014 add `--driver playwright`"),process.exit(1));let C=e.find((u,p)=>e[p-1]==="--base-url")||Me(),ee=e.includes("--base-url"),te=k();if(!h&&!c&&(t.simIdSource==="flag"||t.simIdSource==="saved"&&!!te)){let u=x(t),p=t.simId?` --sim ${t.simId}`:"",f=!1;try{let g=null;try{let y=await u.listSims();if(t.simIdSource==="saved"?(g=y.find($=>$.id===te&&$.readyState==="open")??null,g||T()):g=F(y,t.simId),!g)if(t.simIdSource==="saved")f=!0;else throw new Error("no sim connected");if(!f&&g){let $=ee||X(m)?C:Pe(g,C),U=await A(m,D($,d));u.send({type:"evaluate",simId:g.id,code:`window.location.href = ${JSON.stringify(U)}`}).catch(()=>{})}}catch(y){console.error(` open failed: ${y instanceof Error?y.message:String(y)}`),await B(u,{errorsCommand:`sootsim get errors 5${p}`,warningsCommand:`sootsim get warnings 5${p}`,requestsCommand:`sootsim get requests 5${p}`}),process.exit(1)}if(!f&&g){await S(1500);let y=await tt(t.wsPort,t.commandTimeoutMs,g.id);y||(console.error(" timed out waiting for current sim to load target"),process.exit(1)),y.bridge.close(),w(g.id);let $=ee||X(m)?C:Pe(g,C),U=await A(m,D($,d));_(U,{...g,url:U},"current sim"),await E(t.wsPort,g.id,e);return}}finally{u.close()}}let oe=D(C,d),Ee=await A(m,oe),ne=`cli-${Date.now().toString(36)}-${Math.random().toString(36).slice(2,8)}`,b=await et(m,oe,ne),K={newWindow:!0},R=u=>u.url?.includes(`inspectOpen=${ne}`)??!1;if(h){We(h)||(console.error(` unknown driver "${h}" \u2014 run \`sootsim list --drivers\``),process.exit(1));let u=G(h);u||(console.error(` unknown driver "${h}" \u2014 run \`sootsim list --drivers\``),process.exit(1));let p=Ke(),f=await u.launch({url:b,headless:H,newWindow:K.newWindow,profileId:i,ephemeralProfile:r,cdpPort:a,connectTimeoutMs:p.hostTimeoutMs});f.launched||(console.error(` ${u.name} driver: ${f.message}`),process.exit(1));let g=await L(t.wsPort,t.commandTimeoutMs,R,{attempts:p.attempts,intervalMs:p.intervalMs});if(!g){if(f.pid)try{process.kill(f.pid,"SIGTERM"),console.error(` closed ${u.name} host process ${f.pid}`)}catch{}ct(f),console.error(` timed out after ${p.timeoutMs}ms waiting for opened sim to connect`),process.exit(1)}w(g.id),lt(f),_(b,g,`${u.name} driver`),await E(t.wsPort,g.id,e);return}if(l){let u=M();u||(console.error(" profiles require electron or playwright; install the desktop companion or use `--driver playwright`"),process.exit(1));try{(await V(b,u,{profileId:i,ephemeralProfile:r})).launched||(console.error(" desktop companion failed to start"),process.exit(1))}catch(f){console.error(` desktop companion failed: ${f instanceof Error?f.message:String(f)}`),process.exit(1)}let p=await L(t.wsPort,t.commandTimeoutMs,R,{attempts:40,intervalMs:500});p||(console.error(" timed out waiting for profiled sim to connect"),process.exit(1)),w(p.id),_(b,p,"desktop companion"),await E(t.wsPort,p.id,e);return}let W=!1,z=!1;try{let u=v(t.wsPort,{commandTimeoutMs:2e3});try{await u.listSims(),W=!0}finally{u.close()}}catch{}if(W)try{let u=v(t.wsPort,{commandTimeoutMs:3e3});try{await u.openUrl(b,K),z=!0}finally{u.close()}}catch{}if(!z){let u=M();if(u)try{if((await V(b,u)).launched){let f=await L(t.wsPort,t.commandTimeoutMs,R,{attempts:20,intervalMs:500});if(f){w(f.id),_(b,f,"desktop companion"),await E(t.wsPort,f.id,e);return}}}catch{}try{await j(b,K)}catch(p){console.error(` open failed: ${p instanceof Error?p.message:String(p)}`),G("playwright")?.availability().available?console.error(" no system browser found \u2014 retry with `sootsim open \u2026 --driver playwright` for a headless sim."):console.error(" run `sootsim list --drivers` to see available drivers."),process.exit(1)}if(!W){console.log(` opened: ${Ee}`),$e(t.wsPort);return}}let O=await L(t.wsPort,t.commandTimeoutMs,R,{attempts:30,intervalMs:500});O||(console.error(" timed out waiting for opened sim to connect"),process.exit(1)),w(O.id),_(b,O,z?"bridge":"direct shell open"),await E(t.wsPort,O.id,e)}async function _e(e,o={}){let t=I(e,{port:o.port,commandTimeoutMs:o.timeoutMs,stripBooleanFlags:["--force"]}),n=e.includes("--force"),r=x(t),s=t.simId?` --sim ${t.simId}`:"";try{try{let a=await r.listSims(),i=F(a,t.positional[0]||t.simId);if(i.lockedBy&&i.lockExpiresAt&&i.lockExpiresAt>Date.now()){let l=Math.max(0,Math.round((i.lockExpiresAt-Date.now())/1e3));i.lockedByKind==="user-active"&&(console.error(` refused: ${i.id} is locked by the active user (${l}s) \u2014 that's a live human tab`),console.error(" run `sootsim open --new` for a fresh investigation sim"),process.exit(1)),n||(console.error(` refused: ${i.id} is leased by ${i.lockedBy} (${l}s)`),console.error(` \`sootsim use ${i.id} --force\` to take it, or \`sootsim open --new\` for a fresh sim`),process.exit(1))}await r.focusSim(i.id),w(i.id),console.log(` using: ${i.id}`)}catch(a){console.error(` use failed: ${a instanceof Error?a.message:String(a)}`),await B(r,{errorsCommand:`sootsim get errors 5${s}`,warningsCommand:`sootsim get warnings 5${s}`,requestsCommand:`sootsim get requests 5${s}`}),process.exit(1)}}finally{r.close()}}async function zt(e,o={}){await _e(e,o)}async function jt(e,o={}){await _e(e,o)}async function qt(e,o={}){let t=I(e,{port:o.port,commandTimeoutMs:o.timeoutMs,stripBooleanFlags:["--force"]}),n=e.includes("--force"),r=x(t);try{try{let s=await r.listSims(),a=F(s,t.positional[0]||t.simId),i=n&&a.lockedBy&&a.lockedByKind!=="user-active"?a.lockedBy:null,l=await r.claim(a.id,{force:n});w(a.id);let c=Math.max(0,Math.round((l.lockExpiresAt-Date.now())/1e3)),d=l.bootedCount>0?` (booted ${l.bootedCount})`:"";console.log(` claimed: ${l.simId} [${c}s]${d}`),i&&console.log(` took over from: ${i}`)}catch(s){if(s instanceof ae){let a=Math.max(0,Math.round(s.lock.expiresInMs/1e3));console.error(` claim failed: locked by ${s.lock.by} for ${a}s more`),console.error(" use --force to take it, or `sootsim open --new` for a fresh sim"),process.exit(1)}console.error(` claim failed: ${s instanceof Error?s.message:String(s)}`),process.exit(1)}}finally{r.close()}}async function ut(e,o,t,n){if(n.length===0)return{closed:[],remaining:[]};await Promise.all(n.map(s=>e.closeSim(s).catch(()=>{})));let r=new Set(n);for(let s=0;s<40;s++){let a=[];try{let i=v(o,{commandTimeoutMs:t});try{a=(await i.listSims()).filter(c=>r.has(c.id)&&c.readyState==="open").map(c=>c.id)}finally{i.close()}}catch{a=[]}if(a.length===0)return{closed:[...r],remaining:[]};if(s===39)return{closed:[...r].filter(i=>!a.includes(i)),remaining:a};await S(250)}return{closed:[...r],remaining:[]}}function pt(e,o){let t=e.filter(m=>m.readyState==="open"),n=t.map(m=>m.id),r=o.explicitKeepId?.trim()||"",s=o.savedKeepId?.trim()||"",a=s?t.some(m=>m.id===s):!1,i=s&&!a?s:null,l=null,c=null,d=null;if(o.closeOthers)if(r){let m=t.find(h=>h.id===r);m?l=m.id:c=r}else if(s&&a)l=s;else{let m=t.find(h=>h.isPrimary)??t[0]??null;m&&(l=m.id,s&&!a&&(d=m.id))}return{openIds:n,keepId:l,targets:c?[]:n.filter(m=>m!==l),staleSavedId:i,missingExplicitKeepId:c,fallbackKeepId:d}}async function Vt(e,o={}){let t=I(e,{port:o.port,commandTimeoutMs:o.timeoutMs,stripBooleanFlags:["--all","--others"]}),n=x(t),r=t.simId?` --sim ${t.simId}`:"",s=e.includes("--all"),a=e.includes("--others");if(s||a){try{let i=await n.listSims(),l=k(),c=t.positional[0]||(t.simIdSource==="flag"?t.simId:void 0),d=pt(i,{closeOthers:a,explicitKeepId:c,savedKeepId:l});if(d.staleSavedId&&T(),d.fallbackKeepId&&(w(d.fallbackKeepId),console.log(` saved sim ${d.staleSavedId} is gone \u2014 keeping primary ${d.fallbackKeepId}`)),d.missingExplicitKeepId&&(console.error(` close failed: keep sim ${d.missingExplicitKeepId} is not connected; not closing other sims`),process.exit(1)),d.targets.length===0){console.log(d.keepId?` nothing to close \u2014 only the kept sim ${d.keepId} is connected`:d.staleSavedId?` nothing to close \u2014 no sims connected (cleared stale current sim ${d.staleSavedId})`:" nothing to close \u2014 no sims connected");return}let m=await ut(n,t.wsPort,t.commandTimeoutMs,d.targets);await Q(i,d.targets);let h=k();h&&m.closed.includes(h)&&(d.keepId?w(d.keepId):T());let H=` closed ${m.closed.length} sim(s)${d.keepId?` (kept ${d.keepId})`:""}`;console.log(H),m.remaining.length>0&&(console.error(` close failed: still connected: ${m.remaining.join(", ")}`),process.exit(1))}catch(i){console.error(` close failed: ${i instanceof Error?i.message:String(i)}`),process.exit(1)}finally{n.close()}return}try{try{let i=await n.listSims(),l=F(i,t.positional[0]||t.simId),c=i.find(m=>m.id!==l.id&&m.readyState==="open");await n.closeSim(l.id),await it(t.wsPort,t.commandTimeoutMs,l.id)||(await Q(i,[l.id]),console.error(` close failed: ${l.id} is still connected`),process.exit(1)),await Q(i,[l.id]),k()===l.id&&(c?w(c.id):T()),console.log(` closed: ${l.id}`)}catch(i){console.error(` close failed: ${i instanceof Error?i.message:String(i)}`),await B(n,{errorsCommand:`sootsim get errors 5${r}`,warningsCommand:`sootsim get warnings 5${r}`,requestsCommand:`sootsim get requests 5${r}`}),process.exit(1)}}finally{n.close()}}export{vt as a,Le as b,St as c,Ke as d,Ht as e,Me as f,A as g,et as h,ot as i,rt as j,L as k,at as l,lt as m,Q as n,Kt as o,Wt as p,zt as q,jt as r,qt as s,ut as t,pt as u,Vt as v};
@@ -1 +0,0 @@
1
- /*! sootsim v0.1.133 | (c) 2026 Tamagui LLC | Proprietary — see LICENSE */
@@ -1,2 +0,0 @@
1
- /*! sootsim v0.1.133 | (c) 2026 Tamagui LLC | Proprietary — see LICENSE */
2
- import{a}from"./chunk-4CQXBMKU.js";import"./chunk-Q3GCZEPC.js";export{a as getCliVersion};
@@ -1,2 +0,0 @@
1
- /*! sootsim v0.1.133 | (c) 2026 Tamagui LLC | Proprietary — see LICENSE */
2
- import{a}from"./chunk-LK6Y3IGB.js";import"./chunk-Q3GCZEPC.js";export{a as APPS};
@@ -1,2 +0,0 @@
1
- /*! sootsim v0.1.133 | (c) 2026 Tamagui LLC | Proprietary — see LICENSE */
2
- import"./chunk-YP4W6KI5.js";import{a,b,c,d,e,f,g,h,i}from"./chunk-DYNVMRON.js";import"./chunk-UJBMEBQF.js";import"./chunk-ROINTL2P.js";import"./chunk-AEYD4ODQ.js";import"./chunk-GMHBZDQA.js";import"./chunk-THJDQ2EB.js";import"./chunk-YL3KKAZR.js";import"./chunk-Q3GCZEPC.js";export{e as ALL_DRIVERS,i as buildDriverListRows,a as chromiumDriver,b as electronDriver,f as getAllDrivers,g as getDriver,c as playwrightDriver,h as resolveDriver,d as systemDriver};
@@ -1,2 +0,0 @@
1
- /*! sootsim v0.1.133 | (c) 2026 Tamagui LLC | Proprietary — see LICENSE */
2
- import{a as c,b as d,c as e,d as f}from"./chunk-KHC77NFP.js";import"./chunk-SKF4RZDK.js";import"./chunk-D3OLBBEO.js";import"./chunk-GCNZ32Y7.js";import"./chunk-OO3C2GYN.js";import"./chunk-R4PCQVBM.js";import{d as a,e as b}from"./chunk-VZB6MROZ.js";import"./chunk-ESQVUOW2.js";import"./chunk-RPQCGJI7.js";import"./chunk-HEOJB2Q7.js";import"./chunk-PZSY7LCJ.js";import"./chunk-YZVZA6IX.js";import"./chunk-2OST4PMS.js";import"./chunk-LK6Y3IGB.js";import"./chunk-DYNVMRON.js";import"./chunk-UJBMEBQF.js";import"./chunk-ROINTL2P.js";import"./chunk-AEYD4ODQ.js";import"./chunk-GMHBZDQA.js";import"./chunk-THJDQ2EB.js";import"./chunk-IMG7XQRR.js";import"./chunk-XEGM2NRW.js";import"./chunk-2NV5VDY3.js";import"./chunk-7SYFZZK3.js";import"./chunk-QGPM7UTZ.js";import"./chunk-7BCTUWOM.js";import"./chunk-KUTTVAMM.js";import"./chunk-YL3KKAZR.js";import"./chunk-Q3GCZEPC.js";export{c as discoverSootsimUrl,e as hoistLeadingSimFlag,a as parseFlowFile,f as runFlow,d as runFlowPlayback,b as validateFlowFile};
@@ -1,2 +0,0 @@
1
- /*! sootsim v0.1.133 | (c) 2026 Tamagui LLC | Proprietary — see LICENSE */
2
- import{a,b,c}from"./chunk-FJRIG6HG.js";import"./chunk-2NV5VDY3.js";import"./chunk-AKIYNT56.js";import"./chunk-7SYFZZK3.js";import"./chunk-QGPM7UTZ.js";import"./chunk-4CQXBMKU.js";import"./chunk-VO3QIOCT.js";import"./chunk-KUTTVAMM.js";import"./chunk-YL3KKAZR.js";import"./chunk-Q3GCZEPC.js";export{c as printCommandHelp,b as printGroupHelp,a as printHelp};
@@ -1,2 +0,0 @@
1
- /*! sootsim v0.1.133 | (c) 2026 Tamagui LLC | Proprietary — see LICENSE */
2
- import{a as o}from"./chunk-GDHDUANQ.js";import"./chunk-G4OBKVUY.js";import"./chunk-NNRWRRI5.js";import"./chunk-2OST4PMS.js";import"./chunk-THJDQ2EB.js";import"./chunk-IMG7XQRR.js";import"./chunk-XEGM2NRW.js";import"./chunk-QGPM7UTZ.js";import"./chunk-YL3KKAZR.js";import"./chunk-Q3GCZEPC.js";async function t(n){console.error(" note: `sootsim install` is now `sootsim setup-repo`. forwarding\u2026\n"),await o(n)}export{t as runInstall};
@@ -1,2 +0,0 @@
1
- /*! sootsim v0.1.133 | (c) 2026 Tamagui LLC | Proprietary — see LICENSE */
2
- import{a,b}from"./chunk-BHPSNVNR.js";import"./chunk-2OST4PMS.js";import"./chunk-THJDQ2EB.js";import"./chunk-QGPM7UTZ.js";import"./chunk-TTCMDOP6.js";import"./chunk-YL3KKAZR.js";import"./chunk-Q3GCZEPC.js";export{b as formatReleaseEntry,a as runRuntime};
@@ -1,2 +0,0 @@
1
- /*! sootsim v0.1.133 | (c) 2026 Tamagui LLC | Proprietary — see LICENSE */
2
- import{a}from"./chunk-GDHDUANQ.js";import"./chunk-G4OBKVUY.js";import"./chunk-NNRWRRI5.js";import"./chunk-2OST4PMS.js";import"./chunk-THJDQ2EB.js";import"./chunk-IMG7XQRR.js";import"./chunk-XEGM2NRW.js";import"./chunk-QGPM7UTZ.js";import"./chunk-YL3KKAZR.js";import"./chunk-Q3GCZEPC.js";export{a as runSetupRepo};
@@ -1,2 +0,0 @@
1
- /*! sootsim v0.1.133 | (c) 2026 Tamagui LLC | Proprietary — see LICENSE */
2
- import{a}from"./chunk-7BCTUWOM.js";import"./chunk-KUTTVAMM.js";import"./chunk-Q3GCZEPC.js";export{a as settingsStore};
@@ -1,2 +0,0 @@
1
- /*! sootsim v0.1.133 | (c) 2026 Tamagui LLC | Proprietary — see LICENSE */
2
- import{a,b}from"./chunk-IMG7XQRR.js";import"./chunk-XEGM2NRW.js";import"./chunk-YL3KKAZR.js";import"./chunk-Q3GCZEPC.js";export{b as flushCliTelemetry,a as trackCliEvent};
@@ -1,2 +0,0 @@
1
- /*! sootsim v0.1.133 | (c) 2026 Tamagui LLC | Proprietary — see LICENSE */
2
- import{a,b,c}from"./chunk-OO3C2GYN.js";import"./chunk-R4PCQVBM.js";import"./chunk-YZVZA6IX.js";import"./chunk-2OST4PMS.js";import"./chunk-AEYD4ODQ.js";import"./chunk-GMHBZDQA.js";import"./chunk-THJDQ2EB.js";import"./chunk-IMG7XQRR.js";import"./chunk-XEGM2NRW.js";import"./chunk-QGPM7UTZ.js";import"./chunk-YL3KKAZR.js";import"./chunk-Q3GCZEPC.js";export{a as resolveDefaultUploadOrigin,b as resolvePublicPreviewOrigin,c as runUpload};