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.
- package/dist-cli/bin.js +3 -3
- package/dist-cli/chunks/{agent-VMB2RUAT.js → agent-Z47FMBGS.js} +2 -2
- package/dist-cli/chunks/{agent-wrapper-Z3ROMZQZ.js → agent-wrapper-ESYBFZN7.js} +2 -2
- package/dist-cli/chunks/{app-fonts-NMKBEO3H.js → app-fonts-Z2YSKHFH.js} +2 -2
- package/dist-cli/chunks/{assert-6TFSLJZZ.js → assert-3H3DFPDQ.js} +2 -2
- package/dist-cli/chunks/auto-bootstrap-W63W5Q3Z.js +2 -0
- package/dist-cli/chunks/beta-RIKXONND.js +2 -0
- package/dist-cli/chunks/{chunk-M63L7MMI.js → chunk-3HVTBL4H.js} +2 -2
- package/dist-cli/chunks/{chunk-IGMJFER4.js → chunk-3VL2XNWI.js} +1 -1
- package/dist-cli/chunks/{chunk-T3LSXEVR.js → chunk-5GHFE4JT.js} +2 -2
- package/dist-cli/chunks/chunk-5TG4K3TR.js +1 -0
- package/dist-cli/chunks/{chunk-646XDTEN.js → chunk-6BIRBGY6.js} +2 -2
- package/dist-cli/chunks/{chunk-ELJTZV3R.js → chunk-742YG3IE.js} +1 -1
- package/dist-cli/chunks/{chunk-OXEBJWSX.js → chunk-757RMVXH.js} +1 -1
- package/dist-cli/chunks/{chunk-6BSDH5L3.js → chunk-A2AMW43L.js} +1 -1
- package/dist-cli/chunks/{chunk-T3FWQAUS.js → chunk-AS72GP5Y.js} +1 -1
- package/dist-cli/chunks/{chunk-CFZAP564.js → chunk-DGJZU2LN.js} +1 -1
- package/dist-cli/chunks/{chunk-KFH6ED7B.js → chunk-DW3HVPKN.js} +2 -2
- package/dist-cli/chunks/{chunk-R33YPSKP.js → chunk-F4SSY3GJ.js} +3 -3
- package/dist-cli/chunks/{chunk-Y4KIVYC7.js → chunk-FOKVJYYA.js} +3 -3
- package/dist-cli/chunks/chunk-FZP6MPAE.js +13 -0
- package/dist-cli/chunks/{chunk-535S34EI.js → chunk-GGIBZD6K.js} +1 -1
- package/dist-cli/chunks/{chunk-SUQFTSA4.js → chunk-GHGQ5WA7.js} +1 -1
- package/dist-cli/chunks/{chunk-7AW6PBDV.js → chunk-GZCMIXKT.js} +2 -2
- package/dist-cli/chunks/{chunk-M6PYEFZ2.js → chunk-GZXT4PPI.js} +2 -2
- package/dist-cli/chunks/{chunk-BXVFVTB7.js → chunk-H4BJYOOT.js} +2 -2
- package/dist-cli/chunks/{chunk-ORHN5FYU.js → chunk-HB72CXZ4.js} +2 -2
- package/dist-cli/chunks/{chunk-QAQTDA4L.js → chunk-HTNHSK7V.js} +2 -2
- package/dist-cli/chunks/{chunk-WFKQBUVT.js → chunk-IJ7AGY35.js} +1 -1
- package/dist-cli/chunks/{chunk-IVDZ3W6A.js → chunk-KLX6XOAJ.js} +2 -2
- package/dist-cli/chunks/{chunk-YHX465ER.js → chunk-KUBNI6M2.js} +1 -1
- package/dist-cli/chunks/{chunk-GKW7BY7I.js → chunk-LAPRL7BT.js} +1 -1
- package/dist-cli/chunks/{chunk-5YFJRLU5.js → chunk-LE7U5EPL.js} +2 -2
- package/dist-cli/chunks/{chunk-SFXCDLYK.js → chunk-MEI27O2C.js} +2 -2
- package/dist-cli/chunks/{chunk-I2VRBQ5H.js → chunk-MGUW4DHE.js} +2 -2
- package/dist-cli/chunks/{chunk-UKGEBJO7.js → chunk-MQJFCVAU.js} +1 -1
- package/dist-cli/chunks/{chunk-A4XRRJER.js → chunk-NMDPFJ6R.js} +2 -2
- package/dist-cli/chunks/{chunk-SOK4CAR5.js → chunk-OLKMRTTF.js} +1 -1
- package/dist-cli/chunks/{chunk-33MZ6O5D.js → chunk-PAQXRPVE.js} +2 -2
- package/dist-cli/chunks/{chunk-T2OFKNEP.js → chunk-PC7IKEWJ.js} +2 -2
- package/dist-cli/chunks/{chunk-HXR6XU6C.js → chunk-PHXNJVFA.js} +2 -2
- package/dist-cli/chunks/{chunk-YY7XLGEP.js → chunk-QN7IXMHM.js} +3 -3
- package/dist-cli/chunks/chunk-QS2GK73L.js +1 -0
- package/dist-cli/chunks/{chunk-ZLITT2QF.js → chunk-SA3KB4DV.js} +1 -1
- package/dist-cli/chunks/{chunk-L35AUO7S.js → chunk-TP5ACT5R.js} +2 -2
- package/dist-cli/chunks/chunk-UG7ZYVOI.js +1 -0
- package/dist-cli/chunks/chunk-UGBFB6OS.js +2 -0
- package/dist-cli/chunks/{chunk-DUWCLIV5.js → chunk-V57MZQIF.js} +2 -2
- package/dist-cli/chunks/{chunk-VT26XQSW.js → chunk-VNO7XU3Q.js} +2 -2
- package/dist-cli/chunks/{chunk-45XY4F6P.js → chunk-WMOWWFXR.js} +2 -2
- package/dist-cli/chunks/{chunk-DWLMWYVM.js → chunk-XEFBVJBB.js} +1 -1
- package/dist-cli/chunks/{chunk-M7Y6N4P6.js → chunk-Z3Y5X6MZ.js} +1 -1
- package/dist-cli/chunks/cli-version-FXLE2IW7.js +2 -0
- package/dist-cli/chunks/{compat-RQSP3A4K.js → compat-NPOE74MS.js} +3 -3
- package/dist-cli/chunks/{config-GPQXM7XD.js → config-EFVC2GE5.js} +2 -2
- package/dist-cli/chunks/{control-OPM5UT5V.js → control-BIJSN3JS.js} +2 -2
- package/dist-cli/chunks/{cpu-profile-SSK4NTBF.js → cpu-profile-ZGDKOGR5.js} +2 -2
- package/dist-cli/chunks/{daemon-5SXKDVTQ.js → daemon-CAMRYSKP.js} +2 -2
- package/dist-cli/chunks/{debug-VRDAVGN6.js → debug-OJ6HQQEQ.js} +3 -3
- package/dist-cli/chunks/demo-app-registry-KTP6SHEF.js +2 -0
- package/dist-cli/chunks/{detox-IER2FXXY.js → detox-5OSAFETJ.js} +2 -2
- package/dist-cli/chunks/{device-XH546AFN.js → device-WUVRLDGC.js} +2 -2
- package/dist-cli/chunks/{diagnose-IQVAFQGI.js → diagnose-2ANUXINR.js} +2 -2
- package/dist-cli/chunks/drivers-E2Y4XSAO.js +2 -0
- package/dist-cli/chunks/{electron-DGAACAIN.js → electron-V7JRRTHL.js} +3 -3
- package/dist-cli/chunks/flow-SZ5IAZQW.js +2 -0
- package/dist-cli/chunks/help-75ZJ2TZS.js +2 -0
- package/dist-cli/chunks/{hints-27ZUR5TJ.js → hints-XXGTFGLV.js} +2 -2
- package/dist-cli/chunks/{home-paths-6O3WRSPE.js → home-paths-P5KQ3JIF.js} +2 -2
- package/dist-cli/chunks/{inspect-ADZLCQTO.js → inspect-LSZFMBAB.js} +4 -4
- package/dist-cli/chunks/install-YV56G2UB.js +2 -0
- package/dist-cli/chunks/{install-desktop-MZ47Z4X5.js → install-desktop-D5U55OH5.js} +3 -3
- package/dist-cli/chunks/{keys-AU777KZN.js → keys-HGM7GWZQ.js} +2 -2
- package/dist-cli/chunks/{launch-E34RMXXP.js → launch-6U6GSX6C.js} +3 -3
- package/dist-cli/chunks/{login-J7W3QNG5.js → login-PEUGXKJI.js} +4 -4
- package/dist-cli/chunks/{logout-J2YBTA5E.js → logout-FV4LPMPP.js} +2 -2
- package/dist-cli/chunks/{maestro-EZ62M2VG.js → maestro-2YYUJYRW.js} +2 -2
- package/dist-cli/chunks/{preview-KRDPFRKF.js → preview-HFHZFFG7.js} +2 -2
- package/dist-cli/chunks/{profile-75A7BSOQ.js → profile-3MFIYEHX.js} +2 -2
- package/dist-cli/chunks/{react-UCAXWTQU.js → react-XGBIAED7.js} +2 -2
- package/dist-cli/chunks/{record-JIDVPW3G.js → record-RXZ2CYST.js} +2 -2
- package/dist-cli/chunks/runtime-Y6PI5HDT.js +2 -0
- package/dist-cli/chunks/{runtime-delivery-J7XQ4ZFI.js → runtime-delivery-Y46UCBE3.js} +2 -2
- package/dist-cli/chunks/{screenshot-IASSDVSN.js → screenshot-IRXAVC3E.js} +2 -2
- package/dist-cli/chunks/{screenshot-mode-N5QGF5RE.js → screenshot-mode-EWM67SVU.js} +2 -2
- package/dist-cli/chunks/{screenshots-T5YPBSYI.js → screenshots-XHLQ43M4.js} +2 -2
- package/dist-cli/chunks/{server-OUOF3SW4.js → server-ABK2L55N.js} +3 -3
- package/dist-cli/chunks/setup-repo-SYDWRZLF.js +2 -0
- package/dist-cli/chunks/{skills-3XZ5EHZS.js → skills-UF6CDUY7.js} +2 -2
- package/dist-cli/chunks/{start-NLEY3RB2.js → start-EQRETDQJ.js} +4 -4
- package/dist-cli/chunks/store-ASI7CNVJ.js +2 -0
- package/dist-cli/chunks/telemetry-WIBU6D2C.js +2 -0
- package/dist-cli/chunks/{test-MHLSSGM7.js → test-KLWHINUS.js} +3 -3
- package/dist-cli/chunks/{three-mode-E6FNRWW2.js → three-mode-T3OOCCEE.js} +2 -2
- package/dist-cli/chunks/{timeline-2TORZFTW.js → timeline-M2BIPHEF.js} +2 -2
- package/dist-cli/chunks/{upgrade-FT3QFFOF.js → upgrade-YEWSG62V.js} +2 -2
- package/dist-cli/chunks/upload-EIQM7DIX.js +2 -0
- package/dist-cli/chunks/{version-WYYMIGAV.js → version-JWC47XUM.js} +2 -2
- package/dist-cli/chunks/web-UOT72C34.js +2 -0
- package/dist-cli/chunks/{what-happened-UVBUSMG3.js → what-happened-HJSOVFU7.js} +2 -2
- package/dist-cli/chunks/{whoami-2Y422P77.js → whoami-Z4QAYBKZ.js} +2 -2
- package/dist-lib/agent-daemon-client.cjs +1 -1
- package/dist-lib/agent-events.cjs +1 -1
- package/dist-lib/agent-sessions.cjs +1 -1
- package/dist-lib/attached-projects.cjs +1 -1
- package/dist-lib/auth/shared-session.cjs +1 -1
- package/dist-lib/backend-origin.cjs +1 -1
- package/dist-lib/beta.cjs +1 -1
- package/dist-lib/beta.mjs +1 -1
- package/dist-lib/bridge-constants.cjs +1 -1
- package/dist-lib/cli-constants.cjs +1 -1
- package/dist-lib/config.cjs +1 -1
- package/dist-lib/detox/index.cjs +1 -1
- package/dist-lib/dev-bundle-resolution.cjs +30 -1
- package/dist-lib/home-paths.cjs +1 -1
- package/dist-lib/host/bridge-host.cjs +1 -1
- package/dist-lib/host/fetch-proxy-handler.cjs +1 -1
- package/dist-lib/host/fetch-proxy-overrides.cjs +1 -1
- package/dist-lib/host/fetch-proxy-overrides.mjs +1 -1
- package/dist-lib/host/websocket-proxy.cjs +1 -1
- package/dist-lib/index.cjs +1 -1
- package/dist-lib/metro.cjs +1 -1
- package/dist-lib/profiles.cjs +1 -1
- package/dist-lib/render-mode.cjs +1 -1
- package/dist-lib/scripts/demo-app-registry.cjs +1 -1
- package/dist-lib/scripts/dev-server-scanner.cjs +1 -1
- package/dist-lib/sdk.cjs +1 -1
- package/dist-lib/sdk.mjs +1 -1
- package/dist-lib/skills.cjs +5 -5
- package/dist-lib/vite.cjs +1 -1
- package/package.json +1 -1
- package/src/dev-bundle-resolution.ts +64 -0
- package/dist-cli/chunks/auto-bootstrap-JD7JT5JS.js +0 -2
- package/dist-cli/chunks/beta-OJZBBTGE.js +0 -2
- package/dist-cli/chunks/chunk-6EO76DWY.js +0 -1
- package/dist-cli/chunks/chunk-IZN3MCHO.js +0 -1
- package/dist-cli/chunks/chunk-KE3EJA7O.js +0 -1
- package/dist-cli/chunks/chunk-LAJCBUZT.js +0 -13
- package/dist-cli/chunks/chunk-WYDL2H2W.js +0 -2
- package/dist-cli/chunks/cli-version-D3EINJYQ.js +0 -2
- package/dist-cli/chunks/demo-app-registry-JJVMXHLB.js +0 -2
- package/dist-cli/chunks/drivers-2HTFK23W.js +0 -2
- package/dist-cli/chunks/flow-3ZYT4CYB.js +0 -2
- package/dist-cli/chunks/help-AS4Z2FND.js +0 -2
- package/dist-cli/chunks/install-P6K5SUCS.js +0 -2
- package/dist-cli/chunks/runtime-ACX43ZIT.js +0 -2
- package/dist-cli/chunks/setup-repo-LJIDHL6S.js +0 -2
- package/dist-cli/chunks/store-GTC6V2PO.js +0 -2
- package/dist-cli/chunks/telemetry-6BJJFDDX.js +0 -2
- package/dist-cli/chunks/upload-ZAAQ5XTC.js +0 -2
- package/dist-cli/chunks/web-NUISI4HO.js +0 -2
|
@@ -1,5 +1,5 @@
|
|
|
1
|
-
/*! sootsim v0.1.
|
|
2
|
-
import{B as T,C as A,D as y,O as _,P as b,Q as S}from"./chunk-
|
|
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.
|
|
2
|
-
import{d as i}from"./chunk-
|
|
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.
|
|
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.
|
|
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.
|
|
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.
|
|
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.
|
|
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.
|
|
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.
|
|
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.
|
|
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.
|
|
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/config.cjs
CHANGED
|
@@ -1,4 +1,4 @@
|
|
|
1
|
-
/*! sootsim v0.1.
|
|
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/detox/index.cjs
CHANGED
|
@@ -1,4 +1,4 @@
|
|
|
1
|
-
/*! sootsim v0.1.
|
|
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.
|
|
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" }
|
package/dist-lib/home-paths.cjs
CHANGED
|
@@ -1,4 +1,4 @@
|
|
|
1
|
-
/*! sootsim v0.1.
|
|
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.
|
|
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.
|
|
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.
|
|
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.
|
|
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.
|
|
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/index.cjs
CHANGED
|
@@ -1,4 +1,4 @@
|
|
|
1
|
-
/*! sootsim v0.1.
|
|
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/metro.cjs
CHANGED
|
@@ -1,4 +1,4 @@
|
|
|
1
|
-
/*! sootsim v0.1.
|
|
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/profiles.cjs
CHANGED
|
@@ -1,4 +1,4 @@
|
|
|
1
|
-
/*! sootsim v0.1.
|
|
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/render-mode.cjs
CHANGED
|
@@ -1,4 +1,4 @@
|
|
|
1
|
-
/*! sootsim v0.1.
|
|
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.
|
|
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.
|
|
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.
|
|
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
package/dist-lib/skills.cjs
CHANGED
|
@@ -1,4 +1,4 @@
|
|
|
1
|
-
/*! sootsim v0.1.
|
|
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: "
|
|
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
|
|
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.
|
|
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
|
@@ -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 +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
|
-
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,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};
|