sootsim 0.1.134 → 0.1.136

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 (151) hide show
  1. package/dist-cli/bin.js +3 -3
  2. package/dist-cli/chunks/{agent-VMB2RUAT.js → agent-Z47FMBGS.js} +2 -2
  3. package/dist-cli/chunks/{agent-wrapper-Z3ROMZQZ.js → agent-wrapper-ESYBFZN7.js} +2 -2
  4. package/dist-cli/chunks/{app-fonts-NMKBEO3H.js → app-fonts-Z2YSKHFH.js} +2 -2
  5. package/dist-cli/chunks/{assert-6TFSLJZZ.js → assert-3H3DFPDQ.js} +2 -2
  6. package/dist-cli/chunks/auto-bootstrap-W63W5Q3Z.js +2 -0
  7. package/dist-cli/chunks/beta-RIKXONND.js +2 -0
  8. package/dist-cli/chunks/{chunk-M63L7MMI.js → chunk-3HVTBL4H.js} +2 -2
  9. package/dist-cli/chunks/{chunk-IGMJFER4.js → chunk-3VL2XNWI.js} +1 -1
  10. package/dist-cli/chunks/{chunk-T3LSXEVR.js → chunk-5GHFE4JT.js} +2 -2
  11. package/dist-cli/chunks/chunk-5TG4K3TR.js +1 -0
  12. package/dist-cli/chunks/{chunk-646XDTEN.js → chunk-6BIRBGY6.js} +2 -2
  13. package/dist-cli/chunks/{chunk-ELJTZV3R.js → chunk-742YG3IE.js} +1 -1
  14. package/dist-cli/chunks/{chunk-OXEBJWSX.js → chunk-757RMVXH.js} +1 -1
  15. package/dist-cli/chunks/{chunk-6BSDH5L3.js → chunk-A2AMW43L.js} +1 -1
  16. package/dist-cli/chunks/{chunk-T3FWQAUS.js → chunk-AS72GP5Y.js} +1 -1
  17. package/dist-cli/chunks/{chunk-CFZAP564.js → chunk-DGJZU2LN.js} +1 -1
  18. package/dist-cli/chunks/{chunk-KFH6ED7B.js → chunk-DW3HVPKN.js} +2 -2
  19. package/dist-cli/chunks/{chunk-R33YPSKP.js → chunk-F4SSY3GJ.js} +3 -3
  20. package/dist-cli/chunks/{chunk-Y4KIVYC7.js → chunk-FOKVJYYA.js} +3 -3
  21. package/dist-cli/chunks/chunk-FZP6MPAE.js +13 -0
  22. package/dist-cli/chunks/{chunk-535S34EI.js → chunk-GGIBZD6K.js} +1 -1
  23. package/dist-cli/chunks/{chunk-SUQFTSA4.js → chunk-GHGQ5WA7.js} +1 -1
  24. package/dist-cli/chunks/{chunk-7AW6PBDV.js → chunk-GZCMIXKT.js} +2 -2
  25. package/dist-cli/chunks/{chunk-M6PYEFZ2.js → chunk-GZXT4PPI.js} +2 -2
  26. package/dist-cli/chunks/{chunk-BXVFVTB7.js → chunk-H4BJYOOT.js} +2 -2
  27. package/dist-cli/chunks/{chunk-ORHN5FYU.js → chunk-HB72CXZ4.js} +2 -2
  28. package/dist-cli/chunks/{chunk-QAQTDA4L.js → chunk-HTNHSK7V.js} +2 -2
  29. package/dist-cli/chunks/{chunk-WFKQBUVT.js → chunk-IJ7AGY35.js} +1 -1
  30. package/dist-cli/chunks/{chunk-IVDZ3W6A.js → chunk-KLX6XOAJ.js} +2 -2
  31. package/dist-cli/chunks/{chunk-YHX465ER.js → chunk-KUBNI6M2.js} +1 -1
  32. package/dist-cli/chunks/{chunk-GKW7BY7I.js → chunk-LAPRL7BT.js} +1 -1
  33. package/dist-cli/chunks/{chunk-5YFJRLU5.js → chunk-LE7U5EPL.js} +2 -2
  34. package/dist-cli/chunks/{chunk-SFXCDLYK.js → chunk-MEI27O2C.js} +2 -2
  35. package/dist-cli/chunks/{chunk-I2VRBQ5H.js → chunk-MGUW4DHE.js} +2 -2
  36. package/dist-cli/chunks/{chunk-UKGEBJO7.js → chunk-MQJFCVAU.js} +1 -1
  37. package/dist-cli/chunks/{chunk-A4XRRJER.js → chunk-NMDPFJ6R.js} +2 -2
  38. package/dist-cli/chunks/{chunk-SOK4CAR5.js → chunk-OLKMRTTF.js} +1 -1
  39. package/dist-cli/chunks/{chunk-33MZ6O5D.js → chunk-PAQXRPVE.js} +2 -2
  40. package/dist-cli/chunks/{chunk-T2OFKNEP.js → chunk-PC7IKEWJ.js} +2 -2
  41. package/dist-cli/chunks/{chunk-HXR6XU6C.js → chunk-PHXNJVFA.js} +2 -2
  42. package/dist-cli/chunks/{chunk-YY7XLGEP.js → chunk-QN7IXMHM.js} +3 -3
  43. package/dist-cli/chunks/chunk-QS2GK73L.js +1 -0
  44. package/dist-cli/chunks/{chunk-ZLITT2QF.js → chunk-SA3KB4DV.js} +1 -1
  45. package/dist-cli/chunks/{chunk-L35AUO7S.js → chunk-TP5ACT5R.js} +2 -2
  46. package/dist-cli/chunks/chunk-UG7ZYVOI.js +1 -0
  47. package/dist-cli/chunks/chunk-UGBFB6OS.js +2 -0
  48. package/dist-cli/chunks/{chunk-DUWCLIV5.js → chunk-V57MZQIF.js} +2 -2
  49. package/dist-cli/chunks/{chunk-VT26XQSW.js → chunk-VNO7XU3Q.js} +2 -2
  50. package/dist-cli/chunks/{chunk-45XY4F6P.js → chunk-WMOWWFXR.js} +2 -2
  51. package/dist-cli/chunks/{chunk-DWLMWYVM.js → chunk-XEFBVJBB.js} +1 -1
  52. package/dist-cli/chunks/{chunk-M7Y6N4P6.js → chunk-Z3Y5X6MZ.js} +1 -1
  53. package/dist-cli/chunks/cli-version-FXLE2IW7.js +2 -0
  54. package/dist-cli/chunks/{compat-RQSP3A4K.js → compat-NPOE74MS.js} +3 -3
  55. package/dist-cli/chunks/{config-GPQXM7XD.js → config-EFVC2GE5.js} +2 -2
  56. package/dist-cli/chunks/{control-OPM5UT5V.js → control-BIJSN3JS.js} +2 -2
  57. package/dist-cli/chunks/{cpu-profile-SSK4NTBF.js → cpu-profile-ZGDKOGR5.js} +2 -2
  58. package/dist-cli/chunks/{daemon-5SXKDVTQ.js → daemon-CAMRYSKP.js} +2 -2
  59. package/dist-cli/chunks/{debug-VRDAVGN6.js → debug-OJ6HQQEQ.js} +3 -3
  60. package/dist-cli/chunks/demo-app-registry-KTP6SHEF.js +2 -0
  61. package/dist-cli/chunks/{detox-IER2FXXY.js → detox-5OSAFETJ.js} +2 -2
  62. package/dist-cli/chunks/{device-XH546AFN.js → device-WUVRLDGC.js} +2 -2
  63. package/dist-cli/chunks/{diagnose-IQVAFQGI.js → diagnose-2ANUXINR.js} +2 -2
  64. package/dist-cli/chunks/drivers-E2Y4XSAO.js +2 -0
  65. package/dist-cli/chunks/{electron-DGAACAIN.js → electron-V7JRRTHL.js} +3 -3
  66. package/dist-cli/chunks/flow-SZ5IAZQW.js +2 -0
  67. package/dist-cli/chunks/help-75ZJ2TZS.js +2 -0
  68. package/dist-cli/chunks/{hints-27ZUR5TJ.js → hints-XXGTFGLV.js} +2 -2
  69. package/dist-cli/chunks/{home-paths-6O3WRSPE.js → home-paths-P5KQ3JIF.js} +2 -2
  70. package/dist-cli/chunks/{inspect-ADZLCQTO.js → inspect-LSZFMBAB.js} +4 -4
  71. package/dist-cli/chunks/install-YV56G2UB.js +2 -0
  72. package/dist-cli/chunks/{install-desktop-MZ47Z4X5.js → install-desktop-D5U55OH5.js} +3 -3
  73. package/dist-cli/chunks/{keys-AU777KZN.js → keys-HGM7GWZQ.js} +2 -2
  74. package/dist-cli/chunks/{launch-E34RMXXP.js → launch-6U6GSX6C.js} +3 -3
  75. package/dist-cli/chunks/{login-J7W3QNG5.js → login-PEUGXKJI.js} +4 -4
  76. package/dist-cli/chunks/{logout-J2YBTA5E.js → logout-FV4LPMPP.js} +2 -2
  77. package/dist-cli/chunks/{maestro-EZ62M2VG.js → maestro-2YYUJYRW.js} +2 -2
  78. package/dist-cli/chunks/{preview-KRDPFRKF.js → preview-HFHZFFG7.js} +2 -2
  79. package/dist-cli/chunks/{profile-75A7BSOQ.js → profile-3MFIYEHX.js} +2 -2
  80. package/dist-cli/chunks/{react-UCAXWTQU.js → react-XGBIAED7.js} +2 -2
  81. package/dist-cli/chunks/{record-JIDVPW3G.js → record-RXZ2CYST.js} +2 -2
  82. package/dist-cli/chunks/runtime-Y6PI5HDT.js +2 -0
  83. package/dist-cli/chunks/{runtime-delivery-J7XQ4ZFI.js → runtime-delivery-Y46UCBE3.js} +2 -2
  84. package/dist-cli/chunks/{screenshot-IASSDVSN.js → screenshot-IRXAVC3E.js} +2 -2
  85. package/dist-cli/chunks/{screenshot-mode-N5QGF5RE.js → screenshot-mode-EWM67SVU.js} +2 -2
  86. package/dist-cli/chunks/{screenshots-T5YPBSYI.js → screenshots-XHLQ43M4.js} +2 -2
  87. package/dist-cli/chunks/{server-OUOF3SW4.js → server-ABK2L55N.js} +3 -3
  88. package/dist-cli/chunks/setup-repo-SYDWRZLF.js +2 -0
  89. package/dist-cli/chunks/{skills-3XZ5EHZS.js → skills-UF6CDUY7.js} +2 -2
  90. package/dist-cli/chunks/{start-NLEY3RB2.js → start-EQRETDQJ.js} +4 -4
  91. package/dist-cli/chunks/store-ASI7CNVJ.js +2 -0
  92. package/dist-cli/chunks/telemetry-WIBU6D2C.js +2 -0
  93. package/dist-cli/chunks/{test-MHLSSGM7.js → test-KLWHINUS.js} +3 -3
  94. package/dist-cli/chunks/{three-mode-E6FNRWW2.js → three-mode-T3OOCCEE.js} +2 -2
  95. package/dist-cli/chunks/{timeline-2TORZFTW.js → timeline-M2BIPHEF.js} +2 -2
  96. package/dist-cli/chunks/{upgrade-FT3QFFOF.js → upgrade-YEWSG62V.js} +2 -2
  97. package/dist-cli/chunks/upload-EIQM7DIX.js +2 -0
  98. package/dist-cli/chunks/{version-WYYMIGAV.js → version-JWC47XUM.js} +2 -2
  99. package/dist-cli/chunks/web-UOT72C34.js +2 -0
  100. package/dist-cli/chunks/{what-happened-UVBUSMG3.js → what-happened-HJSOVFU7.js} +2 -2
  101. package/dist-cli/chunks/{whoami-2Y422P77.js → whoami-Z4QAYBKZ.js} +2 -2
  102. package/dist-lib/agent-daemon-client.cjs +1 -1
  103. package/dist-lib/agent-events.cjs +1 -1
  104. package/dist-lib/agent-sessions.cjs +1 -1
  105. package/dist-lib/attached-projects.cjs +1 -1
  106. package/dist-lib/auth/shared-session.cjs +1 -1
  107. package/dist-lib/backend-origin.cjs +1 -1
  108. package/dist-lib/beta.cjs +1 -1
  109. package/dist-lib/beta.mjs +1 -1
  110. package/dist-lib/bridge-constants.cjs +1 -1
  111. package/dist-lib/cli-constants.cjs +1 -1
  112. package/dist-lib/config.cjs +1 -1
  113. package/dist-lib/detox/index.cjs +1 -1
  114. package/dist-lib/dev-bundle-resolution.cjs +30 -1
  115. package/dist-lib/home-paths.cjs +1 -1
  116. package/dist-lib/host/bridge-host.cjs +1 -1
  117. package/dist-lib/host/fetch-proxy-handler.cjs +1 -1
  118. package/dist-lib/host/fetch-proxy-overrides.cjs +1 -1
  119. package/dist-lib/host/fetch-proxy-overrides.mjs +1 -1
  120. package/dist-lib/host/websocket-proxy.cjs +1 -1
  121. package/dist-lib/index.cjs +1 -1
  122. package/dist-lib/metro.cjs +1 -1
  123. package/dist-lib/profiles.cjs +1 -1
  124. package/dist-lib/render-mode.cjs +1 -1
  125. package/dist-lib/scripts/demo-app-registry.cjs +1 -1
  126. package/dist-lib/scripts/dev-server-scanner.cjs +1 -1
  127. package/dist-lib/sdk.cjs +1 -1
  128. package/dist-lib/sdk.mjs +1 -1
  129. package/dist-lib/skills.cjs +5 -5
  130. package/dist-lib/vite.cjs +1 -1
  131. package/package.json +1 -1
  132. package/src/dev-bundle-resolution.ts +64 -0
  133. package/dist-cli/chunks/auto-bootstrap-JD7JT5JS.js +0 -2
  134. package/dist-cli/chunks/beta-OJZBBTGE.js +0 -2
  135. package/dist-cli/chunks/chunk-6EO76DWY.js +0 -1
  136. package/dist-cli/chunks/chunk-IZN3MCHO.js +0 -1
  137. package/dist-cli/chunks/chunk-KE3EJA7O.js +0 -1
  138. package/dist-cli/chunks/chunk-LAJCBUZT.js +0 -13
  139. package/dist-cli/chunks/chunk-WYDL2H2W.js +0 -2
  140. package/dist-cli/chunks/cli-version-D3EINJYQ.js +0 -2
  141. package/dist-cli/chunks/demo-app-registry-JJVMXHLB.js +0 -2
  142. package/dist-cli/chunks/drivers-2HTFK23W.js +0 -2
  143. package/dist-cli/chunks/flow-3ZYT4CYB.js +0 -2
  144. package/dist-cli/chunks/help-AS4Z2FND.js +0 -2
  145. package/dist-cli/chunks/install-P6K5SUCS.js +0 -2
  146. package/dist-cli/chunks/runtime-ACX43ZIT.js +0 -2
  147. package/dist-cli/chunks/setup-repo-LJIDHL6S.js +0 -2
  148. package/dist-cli/chunks/store-GTC6V2PO.js +0 -2
  149. package/dist-cli/chunks/telemetry-6BJJFDDX.js +0 -2
  150. package/dist-cli/chunks/upload-ZAAQ5XTC.js +0 -2
  151. package/dist-cli/chunks/web-NUISI4HO.js +0 -2
@@ -1,5 +1,5 @@
1
- /*! sootsim v0.1.134 | (c) 2026 Tamagui LLC | Proprietary — see LICENSE */
2
- import{B as T,C as A,D as y,O as _,P as b,Q as S}from"./chunk-OXEBJWSX.js";import{c as N,e as F}from"./chunk-SFXCDLYK.js";import{b as k}from"./chunk-T3FWQAUS.js";import"./chunk-535S34EI.js";import"./chunk-GKW7BY7I.js";import"./chunk-UKGEBJO7.js";function O(n){let t=[];for(let e=0;e<n.length;e++)if(n[e]==="--since"&&e+1<n.length){t.push(e,e+1);let s=n[e+1].trim(),l=/^(\d+(?:\.\d+)?)(ms|s|m)?$/.exec(s);if(l){let r=Number(l[1]),u=l[2]??"ms",v=u==="s"?r*1e3:u==="m"?r*6e4:r;return{since:Date.now()-v,consumed:t}}let i=Number(s);if(Number.isFinite(i)&&i>1e12)return{since:i,consumed:t}}return{consumed:t}}function B(n){let t=[];for(let e=0;e<n.length;e++)if(n[e]==="--kinds"&&e+1<n.length)return t.push(e,e+1),{kinds:n[e+1].split(",").map(s=>s.trim()).filter(Boolean),consumed:t};return{consumed:t}}function D(n){let t=[];for(let e=0;e<n.length;e++)if(n[e]==="--limit"&&e+1<n.length){t.push(e,e+1);let s=Number(n[e+1]);if(Number.isFinite(s)&&s>0)return{limit:s,consumed:t}}return{consumed:t}}function x(n){let t=[],e={label:"initial state",events:[],startedAt:n[0]?.t??null};t.push(e);for(let s of n)if(e.events.push(s),s.kind==="screen"||s.kind==="route"){let l=s.data,i=l?.phase;if(!i||i==="enter"||i==="appear"||i==="active"){let r=l?.name||l?.activeName||l?.path||l?.pathname||s.kind;t.length===1&&e.events.length===1?e.label=`${s.kind}: ${r}`:(e={label:`${s.kind}: ${r}`,events:[],startedAt:s.t},t.push(e))}}return t}async function J(n,t){let e=N(n,{port:t.port,stripBooleanFlags:["--summary","--all","--json","--no-advance","--help","-h","--flow","--noisy"],stripValueFlags:["--since","--kinds","--limit"]});(n.includes("--help")||n.includes("-h"))&&(console.log(`
1
+ /*! sootsim v0.1.136 | (c) 2026 Tamagui LLC | Proprietary — see LICENSE */
2
+ import{B as T,C as A,D as y,O as _,P as b,Q as S}from"./chunk-757RMVXH.js";import{c as N,e as F}from"./chunk-MEI27O2C.js";import{b as k}from"./chunk-AS72GP5Y.js";import"./chunk-GGIBZD6K.js";import"./chunk-LAPRL7BT.js";import"./chunk-MQJFCVAU.js";function O(n){let t=[];for(let e=0;e<n.length;e++)if(n[e]==="--since"&&e+1<n.length){t.push(e,e+1);let s=n[e+1].trim(),l=/^(\d+(?:\.\d+)?)(ms|s|m)?$/.exec(s);if(l){let r=Number(l[1]),u=l[2]??"ms",v=u==="s"?r*1e3:u==="m"?r*6e4:r;return{since:Date.now()-v,consumed:t}}let i=Number(s);if(Number.isFinite(i)&&i>1e12)return{since:i,consumed:t}}return{consumed:t}}function B(n){let t=[];for(let e=0;e<n.length;e++)if(n[e]==="--kinds"&&e+1<n.length)return t.push(e,e+1),{kinds:n[e+1].split(",").map(s=>s.trim()).filter(Boolean),consumed:t};return{consumed:t}}function D(n){let t=[];for(let e=0;e<n.length;e++)if(n[e]==="--limit"&&e+1<n.length){t.push(e,e+1);let s=Number(n[e+1]);if(Number.isFinite(s)&&s>0)return{limit:s,consumed:t}}return{consumed:t}}function x(n){let t=[],e={label:"initial state",events:[],startedAt:n[0]?.t??null};t.push(e);for(let s of n)if(e.events.push(s),s.kind==="screen"||s.kind==="route"){let l=s.data,i=l?.phase;if(!i||i==="enter"||i==="appear"||i==="active"){let r=l?.name||l?.activeName||l?.path||l?.pathname||s.kind;t.length===1&&e.events.length===1?e.label=`${s.kind}: ${r}`:(e={label:`${s.kind}: ${r}`,events:[],startedAt:s.t},t.push(e))}}return t}async function J(n,t){let e=N(n,{port:t.port,stripBooleanFlags:["--summary","--all","--json","--no-advance","--help","-h","--flow","--noisy"],stripValueFlags:["--since","--kinds","--limit"]});(n.includes("--help")||n.includes("-h"))&&(console.log(`
3
3
  sootsim what-happened \u2014 show recent events from the semantic timeline
4
4
 
5
5
  usage:
@@ -1,2 +1,2 @@
1
- /*! sootsim v0.1.134 | (c) 2026 Tamagui LLC | Proprietary — see LICENSE */
2
- import{d as i}from"./chunk-33MZ6O5D.js";import{d as n}from"./chunk-QAQTDA4L.js";import"./chunk-GKW7BY7I.js";import"./chunk-UKGEBJO7.js";async function u(){let o=i();if(o||(console.log(" not signed in"),console.log(" set SOOTSIM_API_KEY=sk_sootsim_\u2026 or run `sootsim login`"),process.exit(1)),o.kind==="api-key"){let r=`${o.secret.slice(0,14)}\u2026`,t=o.source==="env"?"SOOTSIM_API_KEY env var":"saved key (~/.config/sootsim/credentials.json)";console.log(` api key ${r}`),console.log(` source: ${t}`);return}if(o.kind==="github"){console.log(` github token (${o.source})`),console.log(` repo: ${o.repoId}`);return}let e=await n(),s=e?.user;console.log(` ${s?.email||s?.name||s?.id||"signed in"}`),console.log(` origin: ${e?.origin??o.origin}`),e?.updatedAt&&console.log(` updated: ${e.updatedAt}`)}export{u as runWhoami};
1
+ /*! sootsim v0.1.136 | (c) 2026 Tamagui LLC | Proprietary — see LICENSE */
2
+ import{d as i}from"./chunk-PAQXRPVE.js";import{d as n}from"./chunk-HTNHSK7V.js";import"./chunk-LAPRL7BT.js";import"./chunk-MQJFCVAU.js";async function u(){let o=i();if(o||(console.log(" not signed in"),console.log(" set SOOTSIM_API_KEY=sk_sootsim_\u2026 or run `sootsim login`"),process.exit(1)),o.kind==="api-key"){let r=`${o.secret.slice(0,14)}\u2026`,t=o.source==="env"?"SOOTSIM_API_KEY env var":"saved key (~/.config/sootsim/credentials.json)";console.log(` api key ${r}`),console.log(` source: ${t}`);return}if(o.kind==="github"){console.log(` github token (${o.source})`),console.log(` repo: ${o.repoId}`);return}let e=await n(),s=e?.user;console.log(` ${s?.email||s?.name||s?.id||"signed in"}`),console.log(` origin: ${e?.origin??o.origin}`),e?.updatedAt&&console.log(` updated: ${e.updatedAt}`)}export{u as runWhoami};
@@ -1,4 +1,4 @@
1
- /*! sootsim v0.1.134 | (c) 2026 Tamagui LLC | Proprietary — see LICENSE */
1
+ /*! sootsim v0.1.136 | (c) 2026 Tamagui LLC | Proprietary — see LICENSE */
2
2
  let __sootsim_import_meta_url = ''; try { __sootsim_import_meta_url = require('url').pathToFileURL(__filename).href; } catch {}
3
3
  "use strict";
4
4
  var __create = Object.create;
@@ -1,4 +1,4 @@
1
- /*! sootsim v0.1.134 | (c) 2026 Tamagui LLC | Proprietary — see LICENSE */
1
+ /*! sootsim v0.1.136 | (c) 2026 Tamagui LLC | Proprietary — see LICENSE */
2
2
  let __sootsim_import_meta_url = ''; try { __sootsim_import_meta_url = require('url').pathToFileURL(__filename).href; } catch {}
3
3
  "use strict";
4
4
  var __defProp = Object.defineProperty;
@@ -1,4 +1,4 @@
1
- /*! sootsim v0.1.134 | (c) 2026 Tamagui LLC | Proprietary — see LICENSE */
1
+ /*! sootsim v0.1.136 | (c) 2026 Tamagui LLC | Proprietary — see LICENSE */
2
2
  let __sootsim_import_meta_url = ''; try { __sootsim_import_meta_url = require('url').pathToFileURL(__filename).href; } catch {}
3
3
  "use strict";
4
4
  var __create = Object.create;
@@ -1,4 +1,4 @@
1
- /*! sootsim v0.1.134 | (c) 2026 Tamagui LLC | Proprietary — see LICENSE */
1
+ /*! sootsim v0.1.136 | (c) 2026 Tamagui LLC | Proprietary — see LICENSE */
2
2
  let __sootsim_import_meta_url = ''; try { __sootsim_import_meta_url = require('url').pathToFileURL(__filename).href; } catch {}
3
3
  "use strict";
4
4
  var __create = Object.create;
@@ -1,4 +1,4 @@
1
- /*! sootsim v0.1.134 | (c) 2026 Tamagui LLC | Proprietary — see LICENSE */
1
+ /*! sootsim v0.1.136 | (c) 2026 Tamagui LLC | Proprietary — see LICENSE */
2
2
  let __sootsim_import_meta_url = ''; try { __sootsim_import_meta_url = require('url').pathToFileURL(__filename).href; } catch {}
3
3
  "use strict";
4
4
  var __create = Object.create;
@@ -1,4 +1,4 @@
1
- /*! sootsim v0.1.134 | (c) 2026 Tamagui LLC | Proprietary — see LICENSE */
1
+ /*! sootsim v0.1.136 | (c) 2026 Tamagui LLC | Proprietary — see LICENSE */
2
2
  let __sootsim_import_meta_url = ''; try { __sootsim_import_meta_url = require('url').pathToFileURL(__filename).href; } catch {}
3
3
  "use strict";
4
4
  var __defProp = Object.defineProperty;
package/dist-lib/beta.cjs CHANGED
@@ -1,4 +1,4 @@
1
- /*! sootsim v0.1.134 | (c) 2026 Tamagui LLC | Proprietary — see LICENSE */
1
+ /*! sootsim v0.1.136 | (c) 2026 Tamagui LLC | Proprietary — see LICENSE */
2
2
  let __sootsim_import_meta_url = ''; try { __sootsim_import_meta_url = require('url').pathToFileURL(__filename).href; } catch {}
3
3
  "use strict";
4
4
  var __defProp = Object.defineProperty;
package/dist-lib/beta.mjs CHANGED
@@ -1,4 +1,4 @@
1
- /*! sootsim v0.1.134 | (c) 2026 Tamagui LLC | Proprietary — see LICENSE */
1
+ /*! sootsim v0.1.136 | (c) 2026 Tamagui LLC | Proprietary — see LICENSE */
2
2
 
3
3
  // src/beta.ts
4
4
  var IS_BETA = true;
@@ -1,4 +1,4 @@
1
- /*! sootsim v0.1.134 | (c) 2026 Tamagui LLC | Proprietary — see LICENSE */
1
+ /*! sootsim v0.1.136 | (c) 2026 Tamagui LLC | Proprietary — see LICENSE */
2
2
  let __sootsim_import_meta_url = ''; try { __sootsim_import_meta_url = require('url').pathToFileURL(__filename).href; } catch {}
3
3
  "use strict";
4
4
  var __defProp = Object.defineProperty;
@@ -1,4 +1,4 @@
1
- /*! sootsim v0.1.134 | (c) 2026 Tamagui LLC | Proprietary — see LICENSE */
1
+ /*! sootsim v0.1.136 | (c) 2026 Tamagui LLC | Proprietary — see LICENSE */
2
2
  let __sootsim_import_meta_url = ''; try { __sootsim_import_meta_url = require('url').pathToFileURL(__filename).href; } catch {}
3
3
  "use strict";
4
4
  var __defProp = Object.defineProperty;
@@ -1,4 +1,4 @@
1
- /*! sootsim v0.1.134 | (c) 2026 Tamagui LLC | Proprietary — see LICENSE */
1
+ /*! sootsim v0.1.136 | (c) 2026 Tamagui LLC | Proprietary — see LICENSE */
2
2
  let __sootsim_import_meta_url = ''; try { __sootsim_import_meta_url = require('url').pathToFileURL(__filename).href; } catch {}
3
3
  "use strict";
4
4
  var __defProp = Object.defineProperty;
@@ -1,4 +1,4 @@
1
- /*! sootsim v0.1.134 | (c) 2026 Tamagui LLC | Proprietary — see LICENSE */
1
+ /*! sootsim v0.1.136 | (c) 2026 Tamagui LLC | Proprietary — see LICENSE */
2
2
  let __sootsim_import_meta_url = ''; try { __sootsim_import_meta_url = require('url').pathToFileURL(__filename).href; } catch {}
3
3
  "use strict";
4
4
  var __create = Object.create;
@@ -1,4 +1,4 @@
1
- /*! sootsim v0.1.134 | (c) 2026 Tamagui LLC | Proprietary — see LICENSE */
1
+ /*! sootsim v0.1.136 | (c) 2026 Tamagui LLC | Proprietary — see LICENSE */
2
2
  let __sootsim_import_meta_url = ''; try { __sootsim_import_meta_url = require('url').pathToFileURL(__filename).href; } catch {}
3
3
  "use strict";
4
4
  var __defProp = Object.defineProperty;
@@ -108,8 +108,37 @@ function isBaseServerUrl(url) {
108
108
  const path = url.pathname || "/";
109
109
  return (path === "/" || path === "") && !url.search && !url.hash;
110
110
  }
111
+ async function resolvePortViaServerScan(port) {
112
+ try {
113
+ const res = await fetch("/__server-scan", { cache: "no-store" });
114
+ if (!res.ok) return null;
115
+ if (!(res.headers.get("content-type") || "").toLowerCase().includes("json"))
116
+ return null;
117
+ const servers = await res.json();
118
+ if (!Array.isArray(servers)) return null;
119
+ const match = servers.find(
120
+ (s) => !!s && typeof s === "object" && s.port === port && typeof s.bundleUrl === "string"
121
+ );
122
+ if (!match) return null;
123
+ return {
124
+ bundleUrl: match.bundleUrl,
125
+ port,
126
+ framework: typeof match.framework === "string" ? match.framework : "unknown",
127
+ projectName: typeof match.projectName === "string" ? match.projectName : void 0
128
+ };
129
+ } catch {
130
+ return null;
131
+ }
132
+ }
111
133
  async function probeBaseUrlBundle(baseUrl, port) {
112
134
  const normalizedBaseUrl = baseUrl.replace(/\/+$/, "");
135
+ try {
136
+ if (isLoopbackHost(new URL(normalizedBaseUrl).hostname)) {
137
+ const viaScan = await resolvePortViaServerScan(port);
138
+ if (viaScan) return viaScan;
139
+ }
140
+ } catch {
141
+ }
113
142
  try {
114
143
  const manifestRes = await fetchDevProbe(`${normalizedBaseUrl}/`, {
115
144
  headers: { "expo-platform": "ios" }
@@ -1,4 +1,4 @@
1
- /*! sootsim v0.1.134 | (c) 2026 Tamagui LLC | Proprietary — see LICENSE */
1
+ /*! sootsim v0.1.136 | (c) 2026 Tamagui LLC | Proprietary — see LICENSE */
2
2
  let __sootsim_import_meta_url = ''; try { __sootsim_import_meta_url = require('url').pathToFileURL(__filename).href; } catch {}
3
3
  "use strict";
4
4
  var __create = Object.create;
@@ -1,4 +1,4 @@
1
- /*! sootsim v0.1.134 | (c) 2026 Tamagui LLC | Proprietary — see LICENSE */
1
+ /*! sootsim v0.1.136 | (c) 2026 Tamagui LLC | Proprietary — see LICENSE */
2
2
  let __sootsim_import_meta_url = ''; try { __sootsim_import_meta_url = require('url').pathToFileURL(__filename).href; } catch {}
3
3
  "use strict";
4
4
  var __create = Object.create;
@@ -1,4 +1,4 @@
1
- /*! sootsim v0.1.134 | (c) 2026 Tamagui LLC | Proprietary — see LICENSE */
1
+ /*! sootsim v0.1.136 | (c) 2026 Tamagui LLC | Proprietary — see LICENSE */
2
2
  let __sootsim_import_meta_url = ''; try { __sootsim_import_meta_url = require('url').pathToFileURL(__filename).href; } catch {}
3
3
  "use strict";
4
4
  var __create = Object.create;
@@ -1,4 +1,4 @@
1
- /*! sootsim v0.1.134 | (c) 2026 Tamagui LLC | Proprietary — see LICENSE */
1
+ /*! sootsim v0.1.136 | (c) 2026 Tamagui LLC | Proprietary — see LICENSE */
2
2
  let __sootsim_import_meta_url = ''; try { __sootsim_import_meta_url = require('url').pathToFileURL(__filename).href; } catch {}
3
3
  "use strict";
4
4
  var __defProp = Object.defineProperty;
@@ -1,4 +1,4 @@
1
- /*! sootsim v0.1.134 | (c) 2026 Tamagui LLC | Proprietary — see LICENSE */
1
+ /*! sootsim v0.1.136 | (c) 2026 Tamagui LLC | Proprietary — see LICENSE */
2
2
 
3
3
  // src/host/fetch-proxy-overrides.ts
4
4
  var FETCH_PROXY_BROWSER_USER_AGENT = "Mozilla/5.0 (Macintosh; Intel Mac OS X 10_15_7) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/146.0.0.0 Safari/537.36";
@@ -1,4 +1,4 @@
1
- /*! sootsim v0.1.134 | (c) 2026 Tamagui LLC | Proprietary — see LICENSE */
1
+ /*! sootsim v0.1.136 | (c) 2026 Tamagui LLC | Proprietary — see LICENSE */
2
2
  let __sootsim_import_meta_url = ''; try { __sootsim_import_meta_url = require('url').pathToFileURL(__filename).href; } catch {}
3
3
  "use strict";
4
4
  var __defProp = Object.defineProperty;
@@ -1,4 +1,4 @@
1
- /*! sootsim v0.1.134 | (c) 2026 Tamagui LLC | Proprietary — see LICENSE */
1
+ /*! sootsim v0.1.136 | (c) 2026 Tamagui LLC | Proprietary — see LICENSE */
2
2
  let __sootsim_import_meta_url = ''; try { __sootsim_import_meta_url = require('url').pathToFileURL(__filename).href; } catch {}
3
3
  "use strict";
4
4
  var __create = Object.create;
@@ -1,4 +1,4 @@
1
- /*! sootsim v0.1.134 | (c) 2026 Tamagui LLC | Proprietary — see LICENSE */
1
+ /*! sootsim v0.1.136 | (c) 2026 Tamagui LLC | Proprietary — see LICENSE */
2
2
  let __sootsim_import_meta_url = ''; try { __sootsim_import_meta_url = require('url').pathToFileURL(__filename).href; } catch {}
3
3
  "use strict";
4
4
  var __create = Object.create;
@@ -1,4 +1,4 @@
1
- /*! sootsim v0.1.134 | (c) 2026 Tamagui LLC | Proprietary — see LICENSE */
1
+ /*! sootsim v0.1.136 | (c) 2026 Tamagui LLC | Proprietary — see LICENSE */
2
2
  let __sootsim_import_meta_url = ''; try { __sootsim_import_meta_url = require('url').pathToFileURL(__filename).href; } catch {}
3
3
  "use strict";
4
4
  var __create = Object.create;
@@ -1,4 +1,4 @@
1
- /*! sootsim v0.1.134 | (c) 2026 Tamagui LLC | Proprietary — see LICENSE */
1
+ /*! sootsim v0.1.136 | (c) 2026 Tamagui LLC | Proprietary — see LICENSE */
2
2
  let __sootsim_import_meta_url = ''; try { __sootsim_import_meta_url = require('url').pathToFileURL(__filename).href; } catch {}
3
3
  "use strict";
4
4
  var __defProp = Object.defineProperty;
@@ -1,4 +1,4 @@
1
- /*! sootsim v0.1.134 | (c) 2026 Tamagui LLC | Proprietary — see LICENSE */
1
+ /*! sootsim v0.1.136 | (c) 2026 Tamagui LLC | Proprietary — see LICENSE */
2
2
  let __sootsim_import_meta_url = ''; try { __sootsim_import_meta_url = require('url').pathToFileURL(__filename).href; } catch {}
3
3
  "use strict";
4
4
  var __defProp = Object.defineProperty;
@@ -1,4 +1,4 @@
1
- /*! sootsim v0.1.134 | (c) 2026 Tamagui LLC | Proprietary — see LICENSE */
1
+ /*! sootsim v0.1.136 | (c) 2026 Tamagui LLC | Proprietary — see LICENSE */
2
2
  let __sootsim_import_meta_url = ''; try { __sootsim_import_meta_url = require('url').pathToFileURL(__filename).href; } catch {}
3
3
  "use strict";
4
4
  var __create = Object.create;
package/dist-lib/sdk.cjs CHANGED
@@ -1,4 +1,4 @@
1
- /*! sootsim v0.1.134 | (c) 2026 Tamagui LLC | Proprietary — see LICENSE */
1
+ /*! sootsim v0.1.136 | (c) 2026 Tamagui LLC | Proprietary — see LICENSE */
2
2
  let __sootsim_import_meta_url = ''; try { __sootsim_import_meta_url = require('url').pathToFileURL(__filename).href; } catch {}
3
3
  "use strict";
4
4
  var __defProp = Object.defineProperty;
package/dist-lib/sdk.mjs CHANGED
@@ -1,4 +1,4 @@
1
- /*! sootsim v0.1.134 | (c) 2026 Tamagui LLC | Proprietary — see LICENSE */
1
+ /*! sootsim v0.1.136 | (c) 2026 Tamagui LLC | Proprietary — see LICENSE */
2
2
 
3
3
  // cli/commands/inspect/core.ts
4
4
  function resolveMaxMsFlag(args, fallbackMs) {
@@ -1,4 +1,4 @@
1
- /*! sootsim v0.1.134 | (c) 2026 Tamagui LLC | Proprietary — see LICENSE */
1
+ /*! sootsim v0.1.136 | (c) 2026 Tamagui LLC | Proprietary — see LICENSE */
2
2
  let __sootsim_import_meta_url = ''; try { __sootsim_import_meta_url = require('url').pathToFileURL(__filename).href; } catch {}
3
3
  "use strict";
4
4
  var __create = Object.create;
@@ -117,8 +117,8 @@ var init_registry = __esm({
117
117
  range: ">=4.0.0",
118
118
  coverage: 0.87,
119
119
  note: "screen container, stack, header config, search bar, navigation props",
120
- working: "Screen, ScreenContainer, ScreenStack, Android modal/pageSheet push fallback, Android statusBarHidden/statusBarStyle/navigationBarHidden traits, push/pop slide, zoom/fade/fade_from_bottom transitions, edge swipe-back, parallax behind-screen, large title collapse, header (back button, inline/large title, custom left/center/right/search bar subviews, crossfade), useHeaderHeight, useTransitionProgress, FullWindowOverlay, SearchBar, Tabs.Host/Screen, lifecycle callbacks (onAppear/onDisappear/onWillAppear/onWillDisappear), onDismissed",
121
- missing: "freezeEnabled/enableFreeze (always false), statusBarColor/navigationBarColor/navigationBarTranslucent ignored, replaceAnimation differentiation, formSheet detent fidelity, integrated search bar placements"
120
+ working: "Screen, ScreenContainer, ScreenStack, enableFreeze/freezeEnabled with delayed React freeze, Android modal/pageSheet push fallback, Android statusBarHidden/statusBarStyle/navigationBarHidden traits, push/pop slide, zoom/fade/fade_from_bottom transitions, edge swipe-back, parallax behind-screen, large title collapse, header (back button, inline/large title, custom left/center/right/search bar subviews, crossfade), useHeaderHeight, useTransitionProgress, FullWindowOverlay, SearchBar, Tabs.Host/Screen, lifecycle callbacks (onAppear/onDisappear/onWillAppear/onWillDisappear), onDismissed",
121
+ missing: "statusBarColor/navigationBarColor/navigationBarTranslucent ignored, replaceAnimation differentiation, formSheet detent fidelity, integrated search bar placements"
122
122
  }
123
123
  ]
124
124
  },
@@ -3478,8 +3478,8 @@ var init_registry = __esm({
3478
3478
  range: ">=6.0.0",
3479
3479
  coverage: 0.9,
3480
3480
  note: "pure JS wrapper around react-native-screens (stubbed); push/pop, header, modals, large titles all flow through screens stub",
3481
- working: "createNativeStackNavigator, Screen, Group, Navigator, header config (title, back button, large title, search bar, custom left/right), Android modal/pageSheet push fallback, modal/formSheet/pageSheet presentation, push/pop animations, gesture-driven back, useHeaderHeight",
3482
- missing: "fidelity bound by react-native-screens stub \u2014 formSheet detent fidelity, search bar placements, freezeOnBlur"
3481
+ working: "createNativeStackNavigator, Screen, Group, Navigator, header config (title, back button, large title, search bar, custom left/right), Android modal/pageSheet push fallback, modal/formSheet/pageSheet presentation, push/pop animations, gesture-driven back, freezeOnBlur via react-native-screens, useHeaderHeight",
3482
+ missing: "fidelity bound by react-native-screens stub \u2014 formSheet detent fidelity, search bar placements"
3483
3483
  }
3484
3484
  ]
3485
3485
  },
package/dist-lib/vite.cjs CHANGED
@@ -1,4 +1,4 @@
1
- /*! sootsim v0.1.134 | (c) 2026 Tamagui LLC | Proprietary — see LICENSE */
1
+ /*! sootsim v0.1.136 | (c) 2026 Tamagui LLC | Proprietary — see LICENSE */
2
2
  let __sootsim_import_meta_url = ''; try { __sootsim_import_meta_url = require('url').pathToFileURL(__filename).href; } catch {}
3
3
  "use strict";
4
4
  var __create = Object.create;
package/package.json CHANGED
@@ -1,6 +1,6 @@
1
1
  {
2
2
  "name": "sootsim",
3
- "version": "0.1.134",
3
+ "version": "0.1.136",
4
4
  "description": "sootsim CLI + vite/metro plugins + skills registry. bridge client for driving the proprietary sootsim-engine over WebSocket.",
5
5
  "author": "Tamagui LLC",
6
6
  "license": "MIT",
@@ -63,12 +63,76 @@ function isBaseServerUrl(url: URL) {
63
63
  return (path === '/' || path === '') && !url.search && !url.hash
64
64
  }
65
65
 
66
+ // resolve a loopback dev-server port through the SAME server-side scanner the
67
+ // dev-server list uses (`/__server-scan`), so an explicit port (`/rn/<port>`, a
68
+ // typed port) gets the EXACT manifest `launchAsset.url` the list resolves —
69
+ // byte-identical, one resolver.
70
+ //
71
+ // why this exists: in a browser/worker the direct manifest probe below is
72
+ // cross-origin (shell on :5173, dev server on :<port>), and a dev server
73
+ // answers a cross-origin `GET /` with its SSR HTML, not the expo manifest. so
74
+ // the manifest branch silently fails (`.json()` throws on HTML) and the probe
75
+ // falls back to a generic `/index.bundle` — a DIFFERENT metro entry point than
76
+ // the manifest's `metro-entry.bundle`, which makes metro build the same app
77
+ // twice. the scanner runs server-side (same-origin node fetch, sends the
78
+ // expo-platform header) and reads `launchAsset.url` correctly.
79
+ //
80
+ // env-agnostic by design: it just attempts `/__server-scan` and lets the result
81
+ // decide. in the tenant worker (which has no `location`) the patched fetch
82
+ // resolves the relative path to the shell origin and returns the scan json. in a
83
+ // node/bun CLI a relative-URL fetch with no base throws → null → the direct probe
84
+ // runs (correct there, since node can read the cross-origin manifest). in prod
85
+ // the path SPA-falls-back to HTML → the json content-type guard returns null →
86
+ // direct probe. so there is exactly one resolver per environment, no env sniff.
87
+ async function resolvePortViaServerScan(port: number): Promise<ResolvedDevBundle | null> {
88
+ try {
89
+ const res = await fetch('/__server-scan', { cache: 'no-store' })
90
+ if (!res.ok) return null
91
+ if (!(res.headers.get('content-type') || '').toLowerCase().includes('json'))
92
+ return null
93
+ const servers: unknown = await res.json()
94
+ if (!Array.isArray(servers)) return null
95
+ const match = servers.find(
96
+ (
97
+ s,
98
+ ): s is {
99
+ port: number
100
+ bundleUrl: string
101
+ framework?: string
102
+ projectName?: string
103
+ } =>
104
+ !!s &&
105
+ typeof s === 'object' &&
106
+ (s as { port?: unknown }).port === port &&
107
+ typeof (s as { bundleUrl?: unknown }).bundleUrl === 'string',
108
+ )
109
+ if (!match) return null
110
+ return {
111
+ bundleUrl: match.bundleUrl,
112
+ port,
113
+ framework: typeof match.framework === 'string' ? match.framework : 'unknown',
114
+ projectName: typeof match.projectName === 'string' ? match.projectName : undefined,
115
+ }
116
+ } catch {
117
+ return null
118
+ }
119
+ }
120
+
66
121
  async function probeBaseUrlBundle(
67
122
  baseUrl: string,
68
123
  port: number,
69
124
  ): Promise<ResolvedDevBundle | null> {
70
125
  const normalizedBaseUrl = baseUrl.replace(/\/+$/, '')
71
126
 
127
+ // browser/worker loopback targets resolve through the server-side scanner so
128
+ // they match the dev-server list exactly — see resolvePortViaServerScan.
129
+ try {
130
+ if (isLoopbackHost(new URL(normalizedBaseUrl).hostname)) {
131
+ const viaScan = await resolvePortViaServerScan(port)
132
+ if (viaScan) return viaScan
133
+ }
134
+ } catch {}
135
+
72
136
  try {
73
137
  const manifestRes = await fetchDevProbe(`${normalizedBaseUrl}/`, {
74
138
  headers: { 'expo-platform': 'ios' },
@@ -1,2 +0,0 @@
1
- /*! sootsim v0.1.134 | (c) 2026 Tamagui LLC | Proprietary — see LICENSE */
2
- import{a,b,c,d}from"./chunk-YY7XLGEP.js";import"./chunk-SFXCDLYK.js";import"./chunk-T3FWQAUS.js";import"./chunk-535S34EI.js";import"./chunk-GKW7BY7I.js";import"./chunk-UKGEBJO7.js";export{c as ensureDaemonRunning,a as ensureRuntimeInstalled,d as ensureSootsimReady,b as resolveBootstrapPort};
@@ -1,2 +0,0 @@
1
- /*! sootsim v0.1.134 | (c) 2026 Tamagui LLC | Proprietary — see LICENSE */
2
- import{a,b,c,d,e}from"./chunk-ELJTZV3R.js";import"./chunk-UKGEBJO7.js";export{e as BETA_ASK_HEADLINE,c as BETA_LABEL,d as BETA_TAGLINE,b as BETA_VERSION_TARGET,a as IS_BETA};
@@ -1 +0,0 @@
1
- /*! sootsim v0.1.134 | (c) 2026 Tamagui LLC | Proprietary — see LICENSE */
@@ -1 +0,0 @@
1
- /*! sootsim v0.1.134 | (c) 2026 Tamagui LLC | Proprietary — see LICENSE */
@@ -1 +0,0 @@
1
- /*! sootsim v0.1.134 | (c) 2026 Tamagui LLC | Proprietary — see LICENSE */
@@ -1,13 +0,0 @@
1
- /*! sootsim v0.1.134 | (c) 2026 Tamagui LLC | Proprietary — see LICENSE */
2
- import{a as D,b as q,c as de,d as me}from"./chunk-646XDTEN.js";import{m as B}from"./chunk-VT26XQSW.js";import{m as le,o as ce}from"./chunk-OXEBJWSX.js";import{a as pe,b as fe,c as ge}from"./chunk-SOK4CAR5.js";import{b as ae,c as I,d as v,e as x}from"./chunk-SFXCDLYK.js";import{g as G}from"./chunk-HXR6XU6C.js";import{a as M,b as V}from"./chunk-CFZAP564.js";import{c as ue}from"./chunk-5YFJRLU5.js";import{d as j}from"./chunk-YHX465ER.js";import{d as k,e as w,f as T}from"./chunk-T3FWQAUS.js";import{a as ie}from"./chunk-WYDL2H2W.js";import{G as re,H as se}from"./chunk-GKW7BY7I.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,2 +0,0 @@
1
- /*! sootsim v0.1.134 | (c) 2026 Tamagui LLC | Proprietary — see LICENSE */
2
- var t="http://localhost:5173/";export{t as a};
@@ -1,2 +0,0 @@
1
- /*! sootsim v0.1.134 | (c) 2026 Tamagui LLC | Proprietary — see LICENSE */
2
- import{a}from"./chunk-ZLITT2QF.js";import"./chunk-UKGEBJO7.js";export{a as getCliVersion};
@@ -1,2 +0,0 @@
1
- /*! sootsim v0.1.134 | (c) 2026 Tamagui LLC | Proprietary — see LICENSE */
2
- import{a}from"./chunk-A4XRRJER.js";import"./chunk-UKGEBJO7.js";export{a as APPS};
@@ -1,2 +0,0 @@
1
- /*! sootsim v0.1.134 | (c) 2026 Tamagui LLC | Proprietary — see LICENSE */
2
- import"./chunk-IZN3MCHO.js";import{a,b,c,d,e,f,g,h,i}from"./chunk-HXR6XU6C.js";import"./chunk-CFZAP564.js";import"./chunk-5YFJRLU5.js";import"./chunk-6EO76DWY.js";import"./chunk-YHX465ER.js";import"./chunk-T3FWQAUS.js";import"./chunk-GKW7BY7I.js";import"./chunk-UKGEBJO7.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.134 | (c) 2026 Tamagui LLC | Proprietary — see LICENSE */
2
- import{a as c,b as d,c as e,d as f}from"./chunk-Y4KIVYC7.js";import"./chunk-KFH6ED7B.js";import"./chunk-KE3EJA7O.js";import"./chunk-I2VRBQ5H.js";import"./chunk-BXVFVTB7.js";import"./chunk-33MZ6O5D.js";import{d as a,e as b}from"./chunk-IVDZ3W6A.js";import"./chunk-LAJCBUZT.js";import"./chunk-646XDTEN.js";import"./chunk-VT26XQSW.js";import"./chunk-OXEBJWSX.js";import"./chunk-SOK4CAR5.js";import"./chunk-SFXCDLYK.js";import"./chunk-A4XRRJER.js";import"./chunk-HXR6XU6C.js";import"./chunk-CFZAP564.js";import"./chunk-5YFJRLU5.js";import"./chunk-6EO76DWY.js";import"./chunk-YHX465ER.js";import"./chunk-T3FWQAUS.js";import"./chunk-T2OFKNEP.js";import"./chunk-QAQTDA4L.js";import"./chunk-ORHN5FYU.js";import"./chunk-WYDL2H2W.js";import"./chunk-535S34EI.js";import"./chunk-DUWCLIV5.js";import"./chunk-WFKQBUVT.js";import"./chunk-GKW7BY7I.js";import"./chunk-UKGEBJO7.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.134 | (c) 2026 Tamagui LLC | Proprietary — see LICENSE */
2
- import{a,b,c}from"./chunk-M63L7MMI.js";import"./chunk-ORHN5FYU.js";import"./chunk-DWLMWYVM.js";import"./chunk-WYDL2H2W.js";import"./chunk-535S34EI.js";import"./chunk-ZLITT2QF.js";import"./chunk-ELJTZV3R.js";import"./chunk-WFKQBUVT.js";import"./chunk-GKW7BY7I.js";import"./chunk-UKGEBJO7.js";export{c as printCommandHelp,b as printGroupHelp,a as printHelp};
@@ -1,2 +0,0 @@
1
- /*! sootsim v0.1.134 | (c) 2026 Tamagui LLC | Proprietary — see LICENSE */
2
- import{a as o}from"./chunk-M6PYEFZ2.js";import"./chunk-IGMJFER4.js";import"./chunk-YY7XLGEP.js";import"./chunk-SFXCDLYK.js";import"./chunk-T3FWQAUS.js";import"./chunk-T2OFKNEP.js";import"./chunk-QAQTDA4L.js";import"./chunk-535S34EI.js";import"./chunk-GKW7BY7I.js";import"./chunk-UKGEBJO7.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.134 | (c) 2026 Tamagui LLC | Proprietary — see LICENSE */
2
- import{a,b}from"./chunk-R33YPSKP.js";import"./chunk-SFXCDLYK.js";import"./chunk-T3FWQAUS.js";import"./chunk-535S34EI.js";import"./chunk-45XY4F6P.js";import"./chunk-GKW7BY7I.js";import"./chunk-UKGEBJO7.js";export{b as formatReleaseEntry,a as runRuntime};
@@ -1,2 +0,0 @@
1
- /*! sootsim v0.1.134 | (c) 2026 Tamagui LLC | Proprietary — see LICENSE */
2
- import{a}from"./chunk-M6PYEFZ2.js";import"./chunk-IGMJFER4.js";import"./chunk-YY7XLGEP.js";import"./chunk-SFXCDLYK.js";import"./chunk-T3FWQAUS.js";import"./chunk-T2OFKNEP.js";import"./chunk-QAQTDA4L.js";import"./chunk-535S34EI.js";import"./chunk-GKW7BY7I.js";import"./chunk-UKGEBJO7.js";export{a as runSetupRepo};
@@ -1,2 +0,0 @@
1
- /*! sootsim v0.1.134 | (c) 2026 Tamagui LLC | Proprietary — see LICENSE */
2
- import{a}from"./chunk-DUWCLIV5.js";import"./chunk-WFKQBUVT.js";import"./chunk-UKGEBJO7.js";export{a as settingsStore};
@@ -1,2 +0,0 @@
1
- /*! sootsim v0.1.134 | (c) 2026 Tamagui LLC | Proprietary — see LICENSE */
2
- import{a,b}from"./chunk-T2OFKNEP.js";import"./chunk-QAQTDA4L.js";import"./chunk-GKW7BY7I.js";import"./chunk-UKGEBJO7.js";export{b as flushCliTelemetry,a as trackCliEvent};
@@ -1,2 +0,0 @@
1
- /*! sootsim v0.1.134 | (c) 2026 Tamagui LLC | Proprietary — see LICENSE */
2
- import{a,b,c}from"./chunk-BXVFVTB7.js";import"./chunk-33MZ6O5D.js";import"./chunk-SOK4CAR5.js";import"./chunk-SFXCDLYK.js";import"./chunk-6EO76DWY.js";import"./chunk-YHX465ER.js";import"./chunk-T3FWQAUS.js";import"./chunk-T2OFKNEP.js";import"./chunk-QAQTDA4L.js";import"./chunk-535S34EI.js";import"./chunk-GKW7BY7I.js";import"./chunk-UKGEBJO7.js";export{a as resolveDefaultUploadOrigin,b as resolvePublicPreviewOrigin,c as runUpload};