@prometheus-ai/agent 0.5.4 → 0.5.8

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 (1145) hide show
  1. package/CHANGELOG.md +30 -0
  2. package/dist/cli.js +25110 -0
  3. package/dist/types/async/index.d.ts +0 -1
  4. package/dist/types/async/job-manager.d.ts +33 -0
  5. package/dist/types/autolearn/controller.d.ts +25 -0
  6. package/dist/types/autolearn/managed-skills.d.ts +45 -0
  7. package/dist/types/autoresearch/state.d.ts +1 -1
  8. package/dist/types/autoresearch/tools/init-experiment.d.ts +1 -1
  9. package/dist/types/autoresearch/tools/log-experiment.d.ts +1 -1
  10. package/dist/types/autoresearch/tools/run-experiment.d.ts +1 -1
  11. package/dist/types/autoresearch/tools/update-notes.d.ts +1 -1
  12. package/dist/types/autoresearch/types.d.ts +1 -1
  13. package/dist/types/capability/context-file.d.ts +0 -13
  14. package/dist/types/capability/mcp.d.ts +1 -0
  15. package/dist/types/capability/rule-buckets.d.ts +1 -1
  16. package/dist/types/capability/rule.d.ts +6 -1
  17. package/dist/types/capability/types.d.ts +0 -4
  18. package/dist/types/cli/args.d.ts +23 -3
  19. package/dist/types/cli/bench-cli.d.ts +78 -0
  20. package/dist/types/cli/claude-trace-cli.d.ts +7 -0
  21. package/dist/types/cli/dry-balance-cli.d.ts +16 -2
  22. package/dist/types/cli/gallery-cli.d.ts +43 -0
  23. package/dist/types/cli/gallery-fixtures/agentic.d.ts +2 -0
  24. package/dist/types/cli/gallery-fixtures/codeintel.d.ts +3 -0
  25. package/dist/types/cli/gallery-fixtures/edit.d.ts +3 -0
  26. package/dist/types/cli/gallery-fixtures/fs.d.ts +2 -0
  27. package/dist/types/cli/gallery-fixtures/index.d.ts +4 -0
  28. package/dist/types/cli/gallery-fixtures/interaction.d.ts +3 -0
  29. package/dist/types/cli/gallery-fixtures/memory.d.ts +2 -0
  30. package/dist/types/cli/gallery-fixtures/misc.d.ts +3 -0
  31. package/dist/types/cli/gallery-fixtures/search.d.ts +3 -0
  32. package/dist/types/cli/gallery-fixtures/shell.d.ts +3 -0
  33. package/dist/types/cli/gallery-fixtures/types.d.ts +55 -0
  34. package/dist/types/cli/gallery-fixtures/web.d.ts +2 -0
  35. package/dist/types/cli/gallery-screenshot.d.ts +35 -0
  36. package/dist/types/cli/grievances-cli.d.ts +1 -1
  37. package/dist/types/cli/list-models.d.ts +6 -14
  38. package/dist/types/cli/models-cli.d.ts +49 -0
  39. package/dist/types/cli/session-picker.d.ts +1 -1
  40. package/dist/types/cli/setup-cli.d.ts +1 -1
  41. package/dist/types/cli/setup-model-picker.d.ts +14 -0
  42. package/dist/types/cli/startup-cwd.d.ts +2 -0
  43. package/dist/types/cli/update-cli.d.ts +13 -40
  44. package/dist/types/cli/usage-cli.d.ts +81 -0
  45. package/dist/types/cli-commands.d.ts +12 -0
  46. package/dist/types/collab/crypto.d.ts +7 -0
  47. package/dist/types/collab/guest.d.ts +37 -0
  48. package/dist/types/collab/host.d.ts +29 -0
  49. package/dist/types/collab/protocol.d.ts +119 -0
  50. package/dist/types/collab/relay-client.d.ts +22 -0
  51. package/dist/types/commands/bench.d.ts +29 -0
  52. package/dist/types/commands/gallery.d.ts +47 -0
  53. package/dist/types/commands/install.d.ts +1 -1
  54. package/dist/types/commands/join.d.ts +12 -0
  55. package/dist/types/commands/launch.d.ts +8 -4
  56. package/dist/types/commands/models.d.ts +33 -0
  57. package/dist/types/commands/read.d.ts +1 -1
  58. package/dist/types/commands/say.d.ts +24 -0
  59. package/dist/types/commands/token.d.ts +25 -0
  60. package/dist/types/commands/usage.d.ts +34 -0
  61. package/dist/types/commit/agentic/tools/analyze-file.d.ts +1 -1
  62. package/dist/types/commit/agentic/tools/git-file-diff.d.ts +1 -1
  63. package/dist/types/commit/agentic/tools/git-hunk.d.ts +1 -1
  64. package/dist/types/commit/agentic/tools/git-overview.d.ts +1 -1
  65. package/dist/types/commit/agentic/tools/propose-changelog.d.ts +1 -1
  66. package/dist/types/commit/agentic/tools/propose-commit.d.ts +1 -1
  67. package/dist/types/commit/agentic/tools/recent-commits.d.ts +1 -1
  68. package/dist/types/commit/agentic/tools/schemas.d.ts +1 -1
  69. package/dist/types/commit/agentic/tools/split-commit.d.ts +1 -1
  70. package/dist/types/commit/analysis/conventional.d.ts +2 -2
  71. package/dist/types/commit/analysis/summary.d.ts +2 -2
  72. package/dist/types/commit/changelog/generate.d.ts +3 -3
  73. package/dist/types/commit/changelog/index.d.ts +2 -2
  74. package/dist/types/commit/map-reduce/index.d.ts +3 -3
  75. package/dist/types/commit/map-reduce/map-phase.d.ts +2 -2
  76. package/dist/types/commit/map-reduce/reduce-phase.d.ts +2 -2
  77. package/dist/types/commit/model-selection.d.ts +10 -4
  78. package/dist/types/commit/shared-llm.d.ts +1 -1
  79. package/dist/types/config/api-key-resolver.d.ts +43 -0
  80. package/dist/types/config/append-only-context-mode.d.ts +2 -1
  81. package/dist/types/config/keybindings.d.ts +12 -7
  82. package/dist/types/config/model-discovery.d.ts +57 -0
  83. package/dist/types/config/model-equivalence.d.ts +1 -1
  84. package/dist/types/config/model-registry.d.ts +86 -222
  85. package/dist/types/config/model-resolver.d.ts +43 -12
  86. package/dist/types/config/model-roles.d.ts +29 -0
  87. package/dist/types/config/models-config-schema.d.ts +536 -43
  88. package/dist/types/config/models-config.d.ts +391 -0
  89. package/dist/types/config/settings-schema.d.ts +1202 -324
  90. package/dist/types/config/settings.d.ts +15 -3
  91. package/dist/types/dap/config.d.ts +14 -1
  92. package/dist/types/dap/types.d.ts +10 -0
  93. package/dist/types/debug/log-viewer.d.ts +1 -1
  94. package/dist/types/debug/raw-sse.d.ts +1 -1
  95. package/dist/types/debug/report-bundle.d.ts +3 -0
  96. package/dist/types/debug/terminal-info.d.ts +0 -1
  97. package/dist/types/discovery/at-imports.d.ts +15 -0
  98. package/dist/types/discovery/prometheus-extension-roots.d.ts +7 -7
  99. package/dist/types/edit/diff.d.ts +3 -2
  100. package/dist/types/edit/file-snapshot-store.d.ts +18 -0
  101. package/dist/types/edit/hashline/noop-loop-guard.d.ts +72 -0
  102. package/dist/types/edit/hashline/params.d.ts +1 -1
  103. package/dist/types/edit/index.d.ts +0 -1
  104. package/dist/types/edit/modes/apply-patch.d.ts +1 -1
  105. package/dist/types/edit/modes/patch.d.ts +1 -1
  106. package/dist/types/edit/modes/replace.d.ts +1 -1
  107. package/dist/types/edit/renderer.d.ts +1 -0
  108. package/dist/types/eval/__tests__/completion-bridge.test.d.ts +1 -0
  109. package/dist/types/eval/__tests__/helpers-local-roots.test.d.ts +1 -0
  110. package/dist/types/eval/__tests__/js-context-manager.test.d.ts +1 -0
  111. package/dist/types/eval/backend.d.ts +7 -2
  112. package/dist/types/eval/bridge-timeout.d.ts +1 -1
  113. package/dist/types/eval/completion-bridge.d.ts +25 -0
  114. package/dist/types/eval/idle-timeout.d.ts +1 -5
  115. package/dist/types/eval/js/context-manager.d.ts +1 -0
  116. package/dist/types/eval/js/executor.d.ts +2 -0
  117. package/dist/types/eval/js/index.d.ts +1 -1
  118. package/dist/types/eval/js/shared/helpers.d.ts +7 -1
  119. package/dist/types/eval/js/shared/rewrite-imports.d.ts +6 -6
  120. package/dist/types/eval/js/shared/runtime.d.ts +6 -1
  121. package/dist/types/eval/js/worker-protocol.d.ts +6 -0
  122. package/dist/types/eval/py/__tests__/prelude.test.d.ts +1 -0
  123. package/dist/types/eval/py/executor.d.ts +12 -0
  124. package/dist/types/eval/py/index.d.ts +1 -1
  125. package/dist/types/eval/py/kernel.d.ts +6 -1
  126. package/dist/types/eval/py/runtime.d.ts +9 -0
  127. package/dist/types/exa/index.d.ts +1 -19
  128. package/dist/types/exa/mcp-client.d.ts +10 -3
  129. package/dist/types/exa/types.d.ts +0 -83
  130. package/dist/types/exec/bash-executor.d.ts +7 -0
  131. package/dist/types/export/custom-share.d.ts +1 -2
  132. package/dist/types/export/html/index.d.ts +39 -0
  133. package/dist/types/export/html/template-js.d.ts +2 -0
  134. package/dist/types/export/share.d.ts +61 -0
  135. package/dist/types/export/ttsr.d.ts +14 -0
  136. package/dist/types/extensibility/custom-commands/types.d.ts +9 -4
  137. package/dist/types/extensibility/custom-tools/loader.d.ts +30 -4
  138. package/dist/types/extensibility/custom-tools/types.d.ts +16 -8
  139. package/dist/types/extensibility/extensions/index.d.ts +1 -1
  140. package/dist/types/extensibility/extensions/loader.d.ts +20 -1
  141. package/dist/types/extensibility/extensions/model-api.d.ts +17 -0
  142. package/dist/types/extensibility/extensions/runner.d.ts +5 -2
  143. package/dist/types/extensibility/extensions/types.d.ts +72 -11
  144. package/dist/types/extensibility/hooks/index.d.ts +2 -1
  145. package/dist/types/extensibility/hooks/loader.d.ts +1 -1
  146. package/dist/types/extensibility/hooks/types.d.ts +11 -5
  147. package/dist/types/extensibility/{legacy-pi-ai-shim.d.ts → legacy-package-ai-shim.d.ts} +2 -2
  148. package/dist/types/extensibility/plugins/{legacy-pi-compat.d.ts → legacy-package-compat.d.ts} +20 -3
  149. package/dist/types/extensibility/plugins/loader.d.ts +11 -0
  150. package/dist/types/extensibility/plugins/marketplace-auto-update.d.ts +8 -0
  151. package/dist/types/extensibility/plugins/types.d.ts +2 -2
  152. package/dist/types/extensibility/shared-events.d.ts +3 -3
  153. package/dist/types/extensibility/skills.d.ts +10 -0
  154. package/dist/types/extensibility/slash-commands.d.ts +1 -11
  155. package/dist/types/goals/guided-setup.d.ts +18 -0
  156. package/dist/types/goals/state.d.ts +1 -1
  157. package/dist/types/goals/tools/goal-tool.d.ts +1 -1
  158. package/dist/types/hindsight/mental-models.d.ts +17 -8
  159. package/dist/types/hindsight/transcript.d.ts +1 -1
  160. package/dist/types/index.d.ts +5 -0
  161. package/dist/types/internal-urls/artifact-protocol.d.ts +2 -2
  162. package/dist/types/internal-urls/history-protocol.d.ts +14 -0
  163. package/dist/types/internal-urls/index.d.ts +1 -0
  164. package/dist/types/internal-urls/local-protocol.d.ts +14 -2
  165. package/dist/types/internal-urls/types.d.ts +1 -1
  166. package/dist/types/irc/bus.d.ts +79 -0
  167. package/dist/types/lib/xai-http.d.ts +1 -1
  168. package/dist/types/lsp/client.d.ts +10 -0
  169. package/dist/types/lsp/config.d.ts +2 -2
  170. package/dist/types/lsp/edits.d.ts +9 -0
  171. package/dist/types/lsp/format-options.d.ts +32 -0
  172. package/dist/types/lsp/index.d.ts +2 -7
  173. package/dist/types/lsp/types.d.ts +13 -1
  174. package/dist/types/lsp/utils.d.ts +6 -2
  175. package/dist/types/main.d.ts +23 -8
  176. package/dist/types/mcp/json-rpc.d.ts +5 -0
  177. package/dist/types/mcp/manager.d.ts +8 -0
  178. package/dist/types/mcp/oauth-discovery.d.ts +6 -1
  179. package/dist/types/mcp/oauth-flow.d.ts +13 -3
  180. package/dist/types/mcp/startup-events.d.ts +11 -0
  181. package/dist/types/mcp/tool-bridge.d.ts +2 -0
  182. package/dist/types/mcp/transports/stdio.d.ts +13 -0
  183. package/dist/types/mcp/types.d.ts +2 -0
  184. package/dist/types/memories/index.d.ts +7 -15
  185. package/dist/types/memories/storage.d.ts +0 -10
  186. package/dist/types/memory-backend/index.d.ts +3 -1
  187. package/dist/types/memory-backend/local-backend.d.ts +4 -3
  188. package/dist/types/memory-backend/resolve.d.ts +2 -2
  189. package/dist/types/memory-backend/runtime.d.ts +4 -0
  190. package/dist/types/memory-backend/types.d.ts +67 -2
  191. package/dist/types/mnemopi/config.d.ts +31 -1
  192. package/dist/types/mnemopi/state.d.ts +40 -2
  193. package/dist/types/modes/acp/acp-agent.d.ts +1 -2
  194. package/dist/types/modes/components/agent-dashboard.d.ts +17 -1
  195. package/dist/types/modes/components/agent-hub.d.ts +82 -0
  196. package/dist/types/modes/components/assistant-message.d.ts +5 -12
  197. package/dist/types/modes/components/bash-execution.d.ts +1 -1
  198. package/dist/types/modes/components/chat-block.d.ts +64 -0
  199. package/dist/types/modes/components/collab-prompt-message.d.ts +10 -0
  200. package/dist/types/modes/components/compaction-summary-message.d.ts +25 -5
  201. package/dist/types/modes/components/copy-selector.d.ts +1 -1
  202. package/dist/types/modes/components/custom-editor.d.ts +49 -2
  203. package/dist/types/modes/components/custom-editor.test.d.ts +1 -0
  204. package/dist/types/modes/components/dynamic-border.d.ts +1 -1
  205. package/dist/types/modes/components/extensions/extension-dashboard.d.ts +1 -1
  206. package/dist/types/modes/components/extensions/extension-list.d.ts +1 -1
  207. package/dist/types/modes/components/extensions/inspector-panel.d.ts +1 -1
  208. package/dist/types/modes/components/footer.d.ts +1 -1
  209. package/dist/types/modes/components/hook-editor.d.ts +5 -0
  210. package/dist/types/modes/components/hook-input.d.ts +4 -0
  211. package/dist/types/modes/components/hook-selector.d.ts +5 -7
  212. package/dist/types/modes/components/index.d.ts +1 -0
  213. package/dist/types/modes/components/late-diagnostics-message.d.ts +20 -0
  214. package/dist/types/modes/components/logout-account-selector.d.ts +8 -0
  215. package/dist/types/modes/components/mcp-add-wizard.d.ts +2 -1
  216. package/dist/types/modes/components/model-selector.d.ts +1 -1
  217. package/dist/types/modes/components/oauth-selector.d.ts +10 -1
  218. package/dist/types/modes/components/overlay-box.d.ts +17 -0
  219. package/dist/types/modes/components/plan-review-overlay.d.ts +61 -0
  220. package/dist/types/modes/components/plan-toc.d.ts +41 -0
  221. package/dist/types/modes/components/read-tool-group.d.ts +8 -0
  222. package/dist/types/modes/components/reset-usage-selector.d.ts +12 -0
  223. package/dist/types/modes/components/segment-track.d.ts +11 -6
  224. package/dist/types/modes/components/session-selector.d.ts +18 -9
  225. package/dist/types/modes/components/settings-defs.d.ts +9 -2
  226. package/dist/types/modes/components/settings-selector.d.ts +17 -4
  227. package/dist/types/modes/components/snapcompact-shape-preview.d.ts +31 -0
  228. package/dist/types/modes/components/status-line/component.d.ts +61 -0
  229. package/dist/types/modes/components/status-line/index.d.ts +1 -0
  230. package/dist/types/modes/components/status-line/types.d.ts +47 -3
  231. package/dist/types/modes/components/tiny-title-download-progress.d.ts +1 -1
  232. package/dist/types/modes/components/tool-execution.d.ts +49 -2
  233. package/dist/types/modes/components/transcript-container.d.ts +76 -26
  234. package/dist/types/modes/components/tree-selector.d.ts +2 -2
  235. package/dist/types/modes/components/ttsr-notification.d.ts +5 -1
  236. package/dist/types/modes/components/usage-row.d.ts +3 -0
  237. package/dist/types/modes/components/user-message-selector.d.ts +1 -1
  238. package/dist/types/modes/components/user-message.d.ts +2 -1
  239. package/dist/types/modes/components/visual-truncate.d.ts +1 -1
  240. package/dist/types/modes/components/welcome.d.ts +12 -2
  241. package/dist/types/modes/controllers/command-controller.d.ts +3 -2
  242. package/dist/types/modes/controllers/event-controller.d.ts +7 -1
  243. package/dist/types/modes/controllers/extension-ui-controller.d.ts +0 -1
  244. package/dist/types/modes/controllers/input-controller.d.ts +25 -3
  245. package/dist/types/modes/controllers/mcp-command-controller.d.ts +8 -0
  246. package/dist/types/modes/controllers/selector-controller.d.ts +5 -2
  247. package/dist/types/modes/controllers/session-focus-controller.d.ts +31 -0
  248. package/dist/types/modes/controllers/streaming-reveal.d.ts +22 -0
  249. package/dist/types/modes/controllers/tan-command-controller.d.ts +6 -0
  250. package/dist/types/modes/controllers/tool-args-reveal.d.ts +43 -0
  251. package/dist/types/modes/gradient-highlight.d.ts +9 -4
  252. package/dist/types/modes/image-references.d.ts +14 -3
  253. package/dist/types/modes/index.d.ts +8 -7
  254. package/dist/types/modes/interactive-mode.d.ts +92 -16
  255. package/dist/types/modes/magic-keywords.d.ts +14 -2
  256. package/dist/types/modes/markdown-prose.d.ts +1 -1
  257. package/dist/types/modes/oauth-manual-input.d.ts +7 -0
  258. package/dist/types/modes/rpc/rpc-client.d.ts +48 -2
  259. package/dist/types/modes/rpc/rpc-mode.d.ts +67 -2
  260. package/dist/types/modes/rpc/rpc-subagents.d.ts +24 -0
  261. package/dist/types/modes/rpc/rpc-types.d.ts +113 -1
  262. package/dist/types/modes/runtime-init.d.ts +4 -0
  263. package/dist/types/modes/session-observer-registry.d.ts +9 -0
  264. package/dist/types/modes/setup-version.d.ts +11 -0
  265. package/dist/types/modes/setup-wizard/index.d.ts +7 -2
  266. package/dist/types/modes/setup-wizard/lazy.d.ts +2 -0
  267. package/dist/types/modes/setup-wizard/scenes/sign-in.d.ts +4 -1
  268. package/dist/types/modes/setup-wizard/scenes/types.d.ts +11 -2
  269. package/dist/types/modes/setup-wizard/scenes/web-search.d.ts +6 -2
  270. package/dist/types/modes/setup-wizard/wizard-overlay.d.ts +1 -1
  271. package/dist/types/modes/theme/theme.d.ts +42 -7
  272. package/dist/types/modes/types.d.ts +62 -13
  273. package/dist/types/modes/utils/context-usage.d.ts +6 -1
  274. package/dist/types/modes/utils/copy-targets.d.ts +21 -1
  275. package/dist/types/modes/utils/ui-helpers.d.ts +4 -4
  276. package/dist/types/modes/workflow.d.ts +3 -3
  277. package/dist/types/plan-mode/approved-plan.d.ts +27 -8
  278. package/dist/types/plan-mode/plan-protection.d.ts +4 -4
  279. package/dist/types/registry/agent-lifecycle.d.ts +51 -0
  280. package/dist/types/registry/agent-registry.d.ts +33 -5
  281. package/dist/types/sdk.d.ts +46 -4
  282. package/dist/types/secrets/index.d.ts +1 -1
  283. package/dist/types/secrets/obfuscator.d.ts +9 -3
  284. package/dist/types/session/agent-session.d.ts +136 -66
  285. package/dist/types/session/agent-storage.d.ts +2 -1
  286. package/dist/types/session/auth-broker-config.d.ts +4 -0
  287. package/dist/types/session/auth-storage.d.ts +1 -1
  288. package/dist/types/session/codex-auto-reset.d.ts +111 -0
  289. package/dist/types/session/indexed-session-storage.d.ts +3 -3
  290. package/dist/types/session/messages.d.ts +26 -15
  291. package/dist/types/session/session-context.d.ts +39 -0
  292. package/dist/types/session/session-entries.d.ts +159 -0
  293. package/dist/types/session/session-history-format.d.ts +12 -0
  294. package/dist/types/session/session-listing.d.ts +69 -0
  295. package/dist/types/session/session-loader.d.ts +16 -0
  296. package/dist/types/session/session-manager.d.ts +107 -440
  297. package/dist/types/session/session-migrations.d.ts +12 -0
  298. package/dist/types/session/session-paths.d.ts +25 -0
  299. package/dist/types/session/session-persistence.d.ts +8 -0
  300. package/dist/types/session/session-storage.d.ts +11 -7
  301. package/dist/types/session/snapcompact-inline.d.ts +145 -0
  302. package/dist/types/session/snapcompact-savings-journal.d.ts +46 -0
  303. package/dist/types/session/streaming-output.d.ts +46 -0
  304. package/dist/types/session/tool-choice-queue.d.ts +6 -6
  305. package/dist/types/session/yield-queue.d.ts +10 -1
  306. package/dist/types/slash-commands/acp-builtins.d.ts +16 -0
  307. package/dist/types/slash-commands/available-commands.d.ts +34 -0
  308. package/dist/types/slash-commands/builtin-registry.d.ts +10 -0
  309. package/dist/types/slash-commands/helpers/active-oauth-account.d.ts +14 -0
  310. package/dist/types/slash-commands/helpers/logout.d.ts +15 -0
  311. package/dist/types/slash-commands/helpers/reset-usage.d.ts +27 -0
  312. package/dist/types/slash-commands/helpers/stats-dashboard.d.ts +13 -0
  313. package/dist/types/slash-commands/types.d.ts +5 -9
  314. package/dist/types/ssh/connection-manager.d.ts +8 -0
  315. package/dist/types/stt/asr-client.d.ts +90 -0
  316. package/dist/types/stt/asr-protocol.d.ts +97 -0
  317. package/dist/types/stt/asr-worker.d.ts +2 -0
  318. package/dist/types/stt/downloader.d.ts +38 -0
  319. package/dist/types/stt/endpointer.d.ts +59 -0
  320. package/dist/types/stt/index.d.ts +5 -1
  321. package/dist/types/stt/models.d.ts +120 -0
  322. package/dist/types/stt/recorder.d.ts +17 -0
  323. package/dist/types/stt/stt-controller.d.ts +6 -0
  324. package/dist/types/stt/transcriber.d.ts +5 -7
  325. package/dist/types/stt/wav.d.ts +29 -0
  326. package/dist/types/system-prompt.d.ts +9 -1
  327. package/dist/types/task/commands.d.ts +1 -1
  328. package/dist/types/task/discovery.d.ts +1 -2
  329. package/dist/types/task/executor.d.ts +61 -2
  330. package/dist/types/task/index.d.ts +37 -6
  331. package/dist/types/task/output-manager.d.ts +0 -7
  332. package/dist/types/task/parallel.d.ts +2 -2
  333. package/dist/types/task/prometheus-command.d.ts +2 -2
  334. package/dist/types/task/render.d.ts +20 -7
  335. package/dist/types/task/repair-args.d.ts +8 -7
  336. package/dist/types/task/types.d.ts +109 -52
  337. package/dist/types/task/worktree.d.ts +2 -0
  338. package/dist/types/telemetry-export.d.ts +2 -2
  339. package/dist/types/thinking.d.ts +4 -0
  340. package/dist/types/tiny/models.d.ts +1 -1
  341. package/dist/types/tiny/title-client.d.ts +12 -1
  342. package/dist/types/tiny/title-protocol.d.ts +1 -0
  343. package/dist/types/tools/archive-reader.d.ts +5 -0
  344. package/dist/types/tools/ask.d.ts +6 -1
  345. package/dist/types/tools/ast-edit.d.ts +4 -1
  346. package/dist/types/tools/ast-grep.d.ts +4 -1
  347. package/dist/types/tools/bash.d.ts +5 -2
  348. package/dist/types/tools/browser/attach.d.ts +4 -4
  349. package/dist/types/tools/browser/cmux/cmux-tab.d.ts +202 -0
  350. package/dist/types/tools/browser/cmux/rpc.d.ts +70 -0
  351. package/dist/types/tools/browser/cmux/socket-client.d.ts +19 -0
  352. package/dist/types/tools/browser/registry.d.ts +17 -3
  353. package/dist/types/tools/browser/render.d.ts +2 -0
  354. package/dist/types/tools/browser/tab-protocol.d.ts +2 -0
  355. package/dist/types/tools/browser/tab-supervisor.d.ts +16 -4
  356. package/dist/types/tools/browser/tab-worker.d.ts +18 -1
  357. package/dist/types/tools/browser.d.ts +3 -1
  358. package/dist/types/tools/checkpoint.d.ts +1 -1
  359. package/dist/types/tools/conflict-detect.d.ts +16 -0
  360. package/dist/types/tools/debug.d.ts +1 -1
  361. package/dist/types/tools/eval-render.d.ts +1 -8
  362. package/dist/types/tools/eval.d.ts +9 -1
  363. package/dist/types/tools/fetch.d.ts +17 -8
  364. package/dist/types/tools/find.d.ts +1 -8
  365. package/dist/types/tools/gh-cache-invalidation.d.ts +6 -0
  366. package/dist/types/tools/gh.d.ts +4 -1
  367. package/dist/types/tools/github-cache.d.ts +19 -0
  368. package/dist/types/tools/grouped-file-output.d.ts +46 -12
  369. package/dist/types/tools/image-gen.d.ts +1 -1
  370. package/dist/types/tools/index.d.ts +89 -8
  371. package/dist/types/tools/inspect-image.d.ts +1 -1
  372. package/dist/types/tools/irc.d.ts +79 -39
  373. package/dist/types/tools/job.d.ts +8 -2
  374. package/dist/types/tools/learn.d.ts +51 -0
  375. package/dist/types/tools/manage-skill.d.ts +40 -0
  376. package/dist/types/tools/memory-edit.d.ts +2 -2
  377. package/dist/types/tools/memory-recall.d.ts +1 -1
  378. package/dist/types/tools/memory-reflect.d.ts +1 -1
  379. package/dist/types/tools/memory-render.d.ts +4 -1
  380. package/dist/types/tools/memory-retain.d.ts +1 -1
  381. package/dist/types/tools/path-utils.d.ts +17 -5
  382. package/dist/types/tools/plan-mode-guard.d.ts +18 -9
  383. package/dist/types/tools/read.d.ts +3 -2
  384. package/dist/types/tools/render-mermaid.d.ts +1 -1
  385. package/dist/types/tools/render-utils.d.ts +47 -27
  386. package/dist/types/tools/renderers.d.ts +10 -2
  387. package/dist/types/tools/report-tool-issue.d.ts +6 -1
  388. package/dist/types/tools/resolve.d.ts +1 -1
  389. package/dist/types/tools/review.d.ts +1 -1
  390. package/dist/types/tools/search-tool-bm25.d.ts +1 -1
  391. package/dist/types/tools/search.d.ts +7 -3
  392. package/dist/types/tools/sqlite-reader.d.ts +4 -0
  393. package/dist/types/tools/ssh.d.ts +2 -1
  394. package/dist/types/tools/todo.d.ts +7 -15
  395. package/dist/types/tools/tool-result.d.ts +2 -0
  396. package/dist/types/tools/tool-timeouts.d.ts +1 -1
  397. package/dist/types/tools/tts.d.ts +26 -1
  398. package/dist/types/tools/write.d.ts +6 -3
  399. package/dist/types/tools/yield.d.ts +8 -0
  400. package/dist/types/tts/downloader.d.ts +20 -0
  401. package/dist/types/tts/index.d.ts +8 -0
  402. package/dist/types/tts/models.d.ts +82 -0
  403. package/dist/types/tts/player.d.ts +32 -0
  404. package/dist/types/tts/runtime.d.ts +6 -0
  405. package/dist/types/tts/streaming-player.d.ts +41 -0
  406. package/dist/types/tts/tts-client.d.ts +93 -0
  407. package/dist/types/tts/tts-protocol.d.ts +95 -0
  408. package/dist/types/tts/tts-worker.d.ts +2 -0
  409. package/dist/types/tts/vocalizer.d.ts +41 -0
  410. package/dist/types/tts/wav.d.ts +8 -0
  411. package/dist/types/tui/code-cell.d.ts +0 -2
  412. package/dist/types/tui/hyperlink.d.ts +13 -7
  413. package/dist/types/tui/output-block.d.ts +16 -22
  414. package/dist/types/tui/status-line.d.ts +3 -0
  415. package/dist/types/utils/block-context.d.ts +35 -0
  416. package/dist/types/utils/changelog.d.ts +8 -0
  417. package/dist/types/utils/clipboard.d.ts +4 -3
  418. package/dist/types/utils/enhanced-paste.d.ts +20 -0
  419. package/dist/types/utils/file-mentions.d.ts +7 -0
  420. package/dist/types/utils/git.d.ts +22 -3
  421. package/dist/types/utils/image-loading.d.ts +30 -1
  422. package/dist/types/utils/session-color.d.ts +15 -3
  423. package/dist/types/utils/thinking-display.d.ts +17 -0
  424. package/dist/types/utils/title-generator.d.ts +3 -2
  425. package/dist/types/utils/tool-choice.d.ts +8 -0
  426. package/dist/types/utils/tools-manager.d.ts +2 -1
  427. package/dist/types/web/kagi.d.ts +2 -2
  428. package/dist/types/web/parallel.d.ts +3 -0
  429. package/dist/types/web/scrapers/github.d.ts +22 -0
  430. package/dist/types/web/scrapers/readthedocs.d.ts +3 -0
  431. package/dist/types/web/scrapers/types.d.ts +12 -0
  432. package/dist/types/web/search/index.d.ts +1 -1
  433. package/dist/types/web/search/providers/anthropic.d.ts +2 -1
  434. package/dist/types/web/search/providers/base.d.ts +2 -1
  435. package/dist/types/web/search/providers/brave.d.ts +2 -1
  436. package/dist/types/web/search/providers/codex.d.ts +2 -1
  437. package/dist/types/web/search/providers/exa.d.ts +2 -1
  438. package/dist/types/web/search/providers/gemini.d.ts +10 -6
  439. package/dist/types/web/search/providers/jina.d.ts +7 -2
  440. package/dist/types/web/search/providers/kagi.d.ts +7 -2
  441. package/dist/types/web/search/providers/kimi.d.ts +7 -2
  442. package/dist/types/web/search/providers/parallel.d.ts +2 -1
  443. package/dist/types/web/search/providers/perplexity.d.ts +10 -2
  444. package/dist/types/web/search/providers/searxng.d.ts +2 -1
  445. package/dist/types/web/search/providers/synthetic.d.ts +7 -3
  446. package/dist/types/web/search/providers/tavily.d.ts +2 -1
  447. package/dist/types/web/search/providers/zai.d.ts +2 -1
  448. package/dist/types/web/search/types.d.ts +1 -1
  449. package/examples/extensions/api-demo.ts +2 -2
  450. package/package.json +41 -15
  451. package/scripts/bench-guard.ts +71 -0
  452. package/scripts/build-binary.ts +24 -25
  453. package/scripts/bundle-dist.ts +97 -0
  454. package/scripts/generate-share-viewer.ts +34 -0
  455. package/scripts/prometheus +42 -0
  456. package/scripts/prometheus.ts +20 -0
  457. package/src/async/index.ts +0 -1
  458. package/src/async/job-manager.ts +106 -3
  459. package/src/auto-thinking/classifier.ts +2 -1
  460. package/src/autolearn/controller.ts +139 -0
  461. package/src/autolearn/managed-skills.ts +257 -0
  462. package/src/autoresearch/dashboard.ts +1 -1
  463. package/src/autoresearch/prompt-setup.md +6 -6
  464. package/src/autoresearch/prompt.md +6 -6
  465. package/src/autoresearch/state.ts +1 -1
  466. package/src/autoresearch/storage.ts +2 -1
  467. package/src/autoresearch/tools/init-experiment.ts +1 -1
  468. package/src/autoresearch/tools/log-experiment.ts +1 -1
  469. package/src/autoresearch/tools/run-experiment.ts +1 -1
  470. package/src/autoresearch/tools/update-notes.ts +1 -1
  471. package/src/autoresearch/types.ts +1 -1
  472. package/src/capability/context-file.ts +0 -14
  473. package/src/capability/fs.ts +10 -0
  474. package/src/capability/index.ts +1 -6
  475. package/src/capability/mcp.ts +1 -0
  476. package/src/capability/rule-buckets.ts +4 -2
  477. package/src/capability/rule.ts +10 -1
  478. package/src/capability/types.ts +0 -4
  479. package/src/cli/args.ts +66 -13
  480. package/src/cli/auth-broker-cli.ts +6 -7
  481. package/src/cli/auth-gateway-cli.ts +8 -9
  482. package/src/cli/bench-cli.ts +437 -0
  483. package/src/cli/claude-trace-cli.ts +28 -50
  484. package/src/cli/completion-gen.ts +28 -28
  485. package/src/cli/dry-balance-cli.ts +56 -23
  486. package/src/cli/gallery-cli.ts +231 -0
  487. package/src/cli/gallery-fixtures/agentic.ts +407 -0
  488. package/src/cli/gallery-fixtures/codeintel.ts +187 -0
  489. package/src/cli/gallery-fixtures/edit.ts +194 -0
  490. package/src/cli/gallery-fixtures/fs.ts +220 -0
  491. package/src/cli/gallery-fixtures/index.ts +40 -0
  492. package/src/cli/gallery-fixtures/interaction.ts +49 -0
  493. package/src/cli/gallery-fixtures/memory.ts +81 -0
  494. package/src/cli/gallery-fixtures/misc.ts +250 -0
  495. package/src/cli/gallery-fixtures/search.ts +213 -0
  496. package/src/cli/gallery-fixtures/shell.ts +167 -0
  497. package/src/cli/gallery-fixtures/types.ts +57 -0
  498. package/src/cli/gallery-fixtures/web.ts +158 -0
  499. package/src/cli/gallery-screenshot.ts +279 -0
  500. package/src/cli/grievances-cli.ts +1 -1
  501. package/src/cli/list-models.ts +16 -174
  502. package/src/cli/models-cli.ts +429 -0
  503. package/src/cli/session-picker.ts +2 -1
  504. package/src/cli/setup-cli.ts +148 -47
  505. package/src/cli/setup-model-picker.ts +43 -0
  506. package/src/cli/startup-cwd.ts +68 -0
  507. package/src/cli/update-cli.ts +144 -272
  508. package/src/cli/usage-cli.ts +774 -0
  509. package/src/cli-commands.ts +36 -0
  510. package/src/cli.ts +141 -32
  511. package/src/collab/crypto.ts +63 -0
  512. package/src/collab/guest.ts +451 -0
  513. package/src/collab/host.ts +565 -0
  514. package/src/collab/protocol.ts +241 -0
  515. package/src/collab/relay-client.ts +216 -0
  516. package/src/commands/bench.ts +42 -0
  517. package/src/commands/complete.ts +1 -1
  518. package/src/commands/gallery.ts +52 -0
  519. package/src/commands/install.ts +1 -1
  520. package/src/commands/join.ts +39 -0
  521. package/src/commands/launch.ts +8 -4
  522. package/src/commands/models.ts +61 -0
  523. package/src/commands/read.ts +6 -3
  524. package/src/commands/say.ts +102 -0
  525. package/src/commands/setup.ts +1 -1
  526. package/src/commands/token.ts +89 -0
  527. package/src/commands/usage.ts +43 -0
  528. package/src/commit/agentic/agent.ts +2 -1
  529. package/src/commit/agentic/tools/analyze-file.ts +42 -20
  530. package/src/commit/agentic/tools/git-file-diff.ts +1 -1
  531. package/src/commit/agentic/tools/git-hunk.ts +1 -1
  532. package/src/commit/agentic/tools/git-overview.ts +1 -1
  533. package/src/commit/agentic/tools/propose-changelog.ts +1 -1
  534. package/src/commit/agentic/tools/propose-commit.ts +1 -1
  535. package/src/commit/agentic/tools/recent-commits.ts +1 -1
  536. package/src/commit/agentic/tools/schemas.ts +1 -1
  537. package/src/commit/agentic/tools/split-commit.ts +9 -2
  538. package/src/commit/analysis/conventional.ts +2 -2
  539. package/src/commit/analysis/summary.ts +3 -3
  540. package/src/commit/changelog/generate.ts +3 -3
  541. package/src/commit/changelog/index.ts +2 -2
  542. package/src/commit/map-reduce/index.ts +3 -3
  543. package/src/commit/map-reduce/map-phase.ts +2 -2
  544. package/src/commit/map-reduce/reduce-phase.ts +2 -2
  545. package/src/commit/model-selection.ts +35 -12
  546. package/src/commit/pipeline.ts +4 -4
  547. package/src/commit/shared-llm.ts +1 -1
  548. package/src/config/api-key-resolver.ts +67 -0
  549. package/src/config/append-only-context-mode.ts +6 -12
  550. package/src/config/keybindings.ts +9 -4
  551. package/src/config/mcp-schema.json +4 -0
  552. package/src/config/model-discovery.ts +574 -0
  553. package/src/config/model-equivalence.ts +5 -4
  554. package/src/config/model-registry.ts +659 -1093
  555. package/src/config/model-resolver.ts +374 -174
  556. package/src/config/model-roles.ts +88 -0
  557. package/src/config/models-config-schema.ts +61 -9
  558. package/src/config/models-config.ts +130 -0
  559. package/src/config/settings-schema.ts +1441 -387
  560. package/src/config/settings.ts +261 -69
  561. package/src/dap/client.ts +138 -53
  562. package/src/dap/config.ts +41 -2
  563. package/src/dap/defaults.json +1 -0
  564. package/src/dap/session.ts +263 -161
  565. package/src/dap/types.ts +10 -0
  566. package/src/debug/index.ts +50 -60
  567. package/src/debug/log-viewer.ts +1 -1
  568. package/src/debug/protocol-probe.ts +1 -1
  569. package/src/debug/raw-sse-buffer.ts +7 -4
  570. package/src/debug/raw-sse.ts +1 -1
  571. package/src/debug/report-bundle.ts +9 -0
  572. package/src/debug/terminal-info.ts +0 -3
  573. package/src/discovery/agents-md.ts +25 -21
  574. package/src/discovery/agents.ts +9 -15
  575. package/src/discovery/at-imports.ts +273 -0
  576. package/src/discovery/builtin-rules/index.ts +4 -0
  577. package/src/discovery/builtin-rules/ts-no-test-timers.md +55 -0
  578. package/src/discovery/builtin-rules/ts-redundant-clear-guard.md +75 -0
  579. package/src/discovery/builtin.ts +45 -23
  580. package/src/discovery/claude-plugins.ts +44 -5
  581. package/src/discovery/helpers.ts +50 -9
  582. package/src/discovery/prometheus-extension-roots.ts +10 -10
  583. package/src/discovery/prometheus-plugins.ts +10 -10
  584. package/src/edit/diff.ts +191 -4
  585. package/src/edit/file-snapshot-store.ts +34 -1
  586. package/src/edit/hashline/block-resolver.ts +20 -1
  587. package/src/edit/hashline/diff.ts +123 -2
  588. package/src/edit/hashline/execute.ts +60 -4
  589. package/src/edit/hashline/filesystem.ts +2 -1
  590. package/src/edit/hashline/noop-loop-guard.ts +99 -0
  591. package/src/edit/hashline/params.ts +1 -1
  592. package/src/edit/index.ts +47 -18
  593. package/src/edit/modes/apply-patch.ts +1 -1
  594. package/src/edit/modes/patch.ts +59 -3
  595. package/src/edit/modes/replace.ts +58 -24
  596. package/src/edit/notebook.ts +22 -2
  597. package/src/edit/renderer.ts +315 -151
  598. package/src/eval/__tests__/agent-bridge.test.ts +105 -39
  599. package/src/eval/__tests__/budget-bridge.test.ts +1 -1
  600. package/src/eval/__tests__/completion-bridge.test.ts +412 -0
  601. package/src/eval/__tests__/helpers-local-roots.test.ts +58 -0
  602. package/src/eval/__tests__/js-context-manager.test.ts +241 -0
  603. package/src/eval/__tests__/llm-bridge.test.ts +6 -4
  604. package/src/eval/__tests__/shared-executors.test.ts +34 -92
  605. package/src/eval/agent-bridge.ts +39 -23
  606. package/src/eval/backend.ts +15 -2
  607. package/src/eval/bridge-timeout.ts +1 -1
  608. package/src/eval/completion-bridge.ts +203 -0
  609. package/src/eval/idle-timeout.ts +3 -10
  610. package/src/eval/js/context-manager.ts +108 -31
  611. package/src/eval/js/executor.ts +9 -2
  612. package/src/eval/js/index.ts +7 -3
  613. package/src/eval/js/shared/helpers.ts +59 -13
  614. package/src/eval/js/shared/local-module-loader.ts +2 -2
  615. package/src/eval/js/shared/prelude.txt +167 -30
  616. package/src/eval/js/shared/rewrite-imports.ts +58 -34
  617. package/src/eval/js/shared/runtime.ts +24 -16
  618. package/src/eval/js/tool-bridge.ts +4 -0
  619. package/src/eval/js/worker-core.ts +1 -0
  620. package/src/eval/js/worker-entry.ts +6 -0
  621. package/src/eval/js/worker-protocol.ts +6 -0
  622. package/src/eval/llm-bridge.ts +2 -1
  623. package/src/eval/py/__tests__/prelude.test.ts +19 -0
  624. package/src/eval/py/executor.ts +70 -26
  625. package/src/eval/py/index.ts +13 -4
  626. package/src/eval/py/kernel.ts +48 -9
  627. package/src/eval/py/prelude.py +73 -24
  628. package/src/eval/py/runner.py +133 -28
  629. package/src/eval/py/runtime.ts +38 -1
  630. package/src/exa/index.ts +1 -26
  631. package/src/exa/mcp-client.ts +10 -10
  632. package/src/exa/types.ts +0 -97
  633. package/src/exec/bash-executor.ts +104 -7
  634. package/src/export/custom-share.ts +1 -1
  635. package/src/export/html/index.ts +119 -17
  636. package/src/export/html/share-loader.js +102 -0
  637. package/src/export/html/template-js.ts +6 -0
  638. package/src/export/html/template.css +745 -459
  639. package/src/export/html/template.css.d.ts +2 -0
  640. package/src/export/html/template.html +6 -3
  641. package/src/export/html/template.js +277 -891
  642. package/src/export/html/tool-views.generated.d.ts +2 -0
  643. package/src/export/html/tool-views.generated.js +38 -0
  644. package/src/export/share.ts +269 -0
  645. package/src/export/ttsr.ts +122 -1
  646. package/src/extensibility/custom-commands/loader.ts +7 -4
  647. package/src/extensibility/custom-commands/types.ts +9 -4
  648. package/src/extensibility/custom-tools/loader.ts +51 -23
  649. package/src/extensibility/custom-tools/types.ts +16 -8
  650. package/src/extensibility/extensions/get-commands-handler.ts +2 -1
  651. package/src/extensibility/extensions/index.ts +1 -0
  652. package/src/extensibility/extensions/loader.ts +70 -20
  653. package/src/extensibility/extensions/model-api.ts +41 -0
  654. package/src/extensibility/extensions/runner.ts +12 -2
  655. package/src/extensibility/extensions/types.ts +83 -11
  656. package/src/extensibility/extensions/wrapper.ts +41 -5
  657. package/src/extensibility/hooks/index.ts +2 -1
  658. package/src/extensibility/hooks/loader.ts +6 -3
  659. package/src/extensibility/hooks/types.ts +11 -5
  660. package/src/extensibility/{legacy-pi-ai-shim.ts → legacy-package-ai-shim.ts} +2 -2
  661. package/src/extensibility/plugins/doctor.ts +1 -2
  662. package/src/extensibility/plugins/installer.ts +2 -2
  663. package/src/extensibility/plugins/{legacy-pi-compat.ts → legacy-package-compat.ts} +165 -77
  664. package/src/extensibility/plugins/loader.ts +34 -23
  665. package/src/extensibility/plugins/manager.ts +226 -95
  666. package/src/extensibility/plugins/marketplace-auto-update.ts +49 -0
  667. package/src/extensibility/plugins/types.ts +3 -3
  668. package/src/extensibility/shared-events.ts +3 -3
  669. package/src/extensibility/skills.ts +113 -9
  670. package/src/extensibility/slash-commands.ts +1 -97
  671. package/src/goals/guided-setup.ts +133 -0
  672. package/src/goals/state.ts +1 -1
  673. package/src/goals/tools/goal-tool.ts +38 -28
  674. package/src/hindsight/bank.ts +17 -2
  675. package/src/hindsight/client.ts +27 -2
  676. package/src/hindsight/mental-models.ts +59 -12
  677. package/src/hindsight/state.ts +12 -3
  678. package/src/hindsight/transcript.ts +1 -1
  679. package/src/index.ts +5 -0
  680. package/src/internal-urls/artifact-protocol.ts +11 -2
  681. package/src/internal-urls/docs-index.generated.ts +9 -7
  682. package/src/internal-urls/history-protocol.ts +113 -0
  683. package/src/internal-urls/index.ts +1 -0
  684. package/src/internal-urls/issue-pr-protocol.ts +22 -9
  685. package/src/internal-urls/local-protocol.ts +42 -7
  686. package/src/internal-urls/memory-protocol.ts +4 -31
  687. package/src/internal-urls/router.ts +3 -1
  688. package/src/internal-urls/types.ts +1 -1
  689. package/src/irc/bus.ts +303 -0
  690. package/src/lib/xai-http.ts +3 -3
  691. package/src/lsp/client.ts +245 -104
  692. package/src/lsp/clients/biome-client.ts +101 -39
  693. package/src/lsp/clients/lsp-linter-client.ts +2 -10
  694. package/src/lsp/config.ts +15 -5
  695. package/src/lsp/defaults.json +6 -0
  696. package/src/lsp/edits.ts +143 -95
  697. package/src/lsp/format-options.ts +119 -0
  698. package/src/lsp/index.ts +233 -93
  699. package/src/lsp/render.ts +11 -35
  700. package/src/lsp/types.ts +13 -1
  701. package/src/lsp/utils.ts +31 -12
  702. package/src/main.ts +396 -216
  703. package/src/mcp/config-writer.ts +7 -3
  704. package/src/mcp/json-rpc.ts +35 -5
  705. package/src/mcp/manager.ts +31 -16
  706. package/src/mcp/oauth-discovery.ts +34 -4
  707. package/src/mcp/oauth-flow.ts +61 -8
  708. package/src/mcp/render.ts +7 -1
  709. package/src/mcp/startup-events.ts +21 -0
  710. package/src/mcp/tool-bridge.ts +2 -0
  711. package/src/mcp/transports/stdio.ts +224 -4
  712. package/src/mcp/types.ts +2 -0
  713. package/src/memories/index.ts +174 -1128
  714. package/src/memories/storage.ts +2 -41
  715. package/src/memory-backend/index.ts +14 -1
  716. package/src/memory-backend/local-backend.ts +18 -3
  717. package/src/memory-backend/off-backend.ts +9 -0
  718. package/src/memory-backend/resolve.ts +4 -6
  719. package/src/memory-backend/runtime.ts +66 -0
  720. package/src/memory-backend/types.ts +82 -2
  721. package/src/mnemopi/backend.ts +220 -28
  722. package/src/mnemopi/config.ts +138 -33
  723. package/src/mnemopi/state.ts +91 -11
  724. package/src/modes/acp/acp-agent.ts +149 -142
  725. package/src/modes/acp/acp-event-mapper.ts +5 -1
  726. package/src/modes/components/agent-dashboard.ts +17 -11
  727. package/src/modes/components/agent-hub.ts +1346 -0
  728. package/src/modes/components/assistant-message.ts +190 -80
  729. package/src/modes/components/bash-execution.ts +1 -1
  730. package/src/modes/components/btw-panel.ts +5 -1
  731. package/src/modes/components/chat-block.ts +111 -0
  732. package/src/modes/components/collab-prompt-message.ts +30 -0
  733. package/src/modes/components/compaction-summary-message.ts +168 -33
  734. package/src/modes/components/copy-selector.ts +2 -45
  735. package/src/modes/components/custom-editor.test.ts +96 -0
  736. package/src/modes/components/custom-editor.ts +405 -118
  737. package/src/modes/components/custom-message.ts +1 -3
  738. package/src/modes/components/diff.ts +13 -2
  739. package/src/modes/components/dynamic-border.ts +12 -3
  740. package/src/modes/components/execution-shared.ts +1 -2
  741. package/src/modes/components/extensions/extension-dashboard.ts +8 -5
  742. package/src/modes/components/extensions/extension-list.ts +1 -1
  743. package/src/modes/components/extensions/inspector-panel.ts +7 -3
  744. package/src/modes/components/extensions/state-manager.ts +36 -41
  745. package/src/modes/components/footer.ts +4 -2
  746. package/src/modes/components/history-search.ts +1 -1
  747. package/src/modes/components/hook-editor.ts +8 -0
  748. package/src/modes/components/hook-input.ts +8 -0
  749. package/src/modes/components/hook-message.ts +1 -3
  750. package/src/modes/components/hook-selector.ts +6 -7
  751. package/src/modes/components/index.ts +1 -0
  752. package/src/modes/components/late-diagnostics-message.ts +60 -0
  753. package/src/modes/components/login-dialog.ts +1 -1
  754. package/src/modes/components/logout-account-selector.ts +130 -0
  755. package/src/modes/components/mcp-add-wizard.ts +14 -1
  756. package/src/modes/components/model-selector.ts +177 -75
  757. package/src/modes/components/oauth-selector.ts +102 -16
  758. package/src/modes/components/overlay-box.ts +108 -0
  759. package/src/modes/components/plan-review-overlay.ts +845 -0
  760. package/src/modes/components/plan-toc.ts +138 -0
  761. package/src/modes/components/plugin-settings.ts +22 -5
  762. package/src/modes/components/read-tool-group.ts +442 -39
  763. package/src/modes/components/reset-usage-selector.ts +161 -0
  764. package/src/modes/components/segment-track.ts +44 -7
  765. package/src/modes/components/session-selector.ts +97 -37
  766. package/src/modes/components/settings-defs.ts +28 -6
  767. package/src/modes/components/settings-selector.ts +541 -93
  768. package/src/modes/components/skill-message.ts +0 -1
  769. package/src/modes/components/snapcompact-shape-preview-doc.md +11 -0
  770. package/src/modes/components/snapcompact-shape-preview.ts +193 -0
  771. package/src/modes/components/{status-line.ts → status-line/component.ts} +205 -168
  772. package/src/modes/components/status-line/index.ts +1 -0
  773. package/src/modes/components/status-line/presets.ts +3 -3
  774. package/src/modes/components/status-line/segments.ts +26 -7
  775. package/src/modes/components/status-line/types.ts +40 -9
  776. package/src/modes/components/tiny-title-download-progress.ts +1 -1
  777. package/src/modes/components/tips.txt +7 -3
  778. package/src/modes/components/todo-reminder.ts +0 -2
  779. package/src/modes/components/tool-execution.ts +236 -103
  780. package/src/modes/components/transcript-container.ts +724 -99
  781. package/src/modes/components/tree-selector.ts +19 -4
  782. package/src/modes/components/ttsr-notification.ts +72 -30
  783. package/src/modes/components/usage-row.ts +18 -0
  784. package/src/modes/components/user-message-selector.ts +1 -1
  785. package/src/modes/components/user-message.ts +28 -12
  786. package/src/modes/components/visual-truncate.ts +1 -1
  787. package/src/modes/components/welcome.ts +80 -22
  788. package/src/modes/controllers/command-controller-shared.ts +7 -6
  789. package/src/modes/controllers/command-controller.ts +210 -180
  790. package/src/modes/controllers/event-controller.ts +352 -142
  791. package/src/modes/controllers/extension-ui-controller.ts +167 -208
  792. package/src/modes/controllers/input-controller.ts +778 -162
  793. package/src/modes/controllers/mcp-command-controller.ts +232 -80
  794. package/src/modes/controllers/selector-controller.ts +284 -145
  795. package/src/modes/controllers/session-focus-controller.ts +112 -0
  796. package/src/modes/controllers/ssh-command-controller.ts +2 -2
  797. package/src/modes/controllers/streaming-reveal.ts +295 -0
  798. package/src/modes/controllers/tan-command-controller.ts +173 -0
  799. package/src/modes/controllers/tool-args-reveal.ts +174 -0
  800. package/src/modes/gradient-highlight.ts +21 -9
  801. package/src/modes/image-references.ts +33 -7
  802. package/src/modes/index.ts +8 -25
  803. package/src/modes/interactive-mode.ts +840 -186
  804. package/src/modes/magic-keywords.ts +28 -6
  805. package/src/modes/markdown-prose.ts +1 -1
  806. package/src/modes/oauth-manual-input.ts +30 -3
  807. package/src/modes/rpc/rpc-client.ts +186 -3
  808. package/src/modes/rpc/rpc-mode.ts +318 -24
  809. package/src/modes/rpc/rpc-subagents.ts +265 -0
  810. package/src/modes/rpc/rpc-types.ts +111 -2
  811. package/src/modes/runtime-init.ts +28 -3
  812. package/src/modes/session-observer-registry.ts +72 -3
  813. package/src/modes/setup-version.ts +11 -0
  814. package/src/modes/setup-wizard/index.ts +16 -4
  815. package/src/modes/setup-wizard/lazy.ts +16 -0
  816. package/src/modes/setup-wizard/scenes/glyph.ts +25 -7
  817. package/src/modes/setup-wizard/scenes/providers.ts +45 -12
  818. package/src/modes/setup-wizard/scenes/sign-in.ts +14 -13
  819. package/src/modes/setup-wizard/scenes/splash.ts +1 -1
  820. package/src/modes/setup-wizard/scenes/theme.ts +29 -2
  821. package/src/modes/setup-wizard/scenes/types.ts +11 -2
  822. package/src/modes/setup-wizard/scenes/web-search.ts +26 -9
  823. package/src/modes/setup-wizard/wizard-overlay.ts +40 -3
  824. package/src/modes/shared.ts +2 -0
  825. package/src/modes/theme/defaults/dark-poimandres.json +1 -1
  826. package/src/modes/theme/defaults/light-poimandres.json +1 -1
  827. package/src/modes/theme/shimmer.ts +20 -9
  828. package/src/modes/theme/theme-schema.json +1 -1
  829. package/src/modes/theme/theme.ts +342 -82
  830. package/src/modes/types.ts +60 -18
  831. package/src/modes/utils/context-usage.ts +88 -8
  832. package/src/modes/utils/copy-targets.ts +133 -27
  833. package/src/modes/utils/hotkeys-markdown.ts +3 -2
  834. package/src/modes/utils/ui-helpers.ts +191 -110
  835. package/src/modes/workflow.ts +10 -10
  836. package/src/plan-mode/approved-plan.ts +66 -43
  837. package/src/plan-mode/plan-protection.ts +4 -4
  838. package/src/priority.json +5 -1
  839. package/src/prompts/agents/designer.md +1 -1
  840. package/src/prompts/agents/explore.md +3 -3
  841. package/src/prompts/agents/librarian.md +2 -3
  842. package/src/prompts/agents/oracle.md +2 -2
  843. package/src/prompts/agents/plan.md +6 -6
  844. package/src/prompts/agents/reviewer.md +1 -1
  845. package/src/prompts/agents/task.md +6 -5
  846. package/src/prompts/bench.md +12 -0
  847. package/src/prompts/ci-green-request.md +5 -7
  848. package/src/prompts/goals/goal-budget-limit.md +2 -2
  849. package/src/prompts/goals/goal-continuation.md +4 -4
  850. package/src/prompts/goals/goal-mode-active.md +1 -1
  851. package/src/prompts/goals/guided-goal-interview.md +8 -0
  852. package/src/prompts/goals/guided-goal-system.md +12 -0
  853. package/src/prompts/memories/consolidation.md +2 -7
  854. package/src/prompts/memories/consolidation_system.md +4 -0
  855. package/src/prompts/memories/identity_review.md +2 -2
  856. package/src/prompts/memories/read-path.md +11 -10
  857. package/src/prompts/memories/stage_one_system.md +2 -2
  858. package/src/prompts/review-custom-request.md +1 -1
  859. package/src/prompts/system/agent-creation-architect.md +2 -2
  860. package/src/prompts/system/auto-continue.md +1 -1
  861. package/src/prompts/system/autolearn-guidance-learn.md +1 -0
  862. package/src/prompts/system/autolearn-guidance.md +7 -0
  863. package/src/prompts/system/autolearn-nudge.md +3 -0
  864. package/src/prompts/system/background-tan-dispatch.md +8 -0
  865. package/src/prompts/system/btw-user.md +2 -2
  866. package/src/prompts/system/commit-message-system.md +13 -1
  867. package/src/prompts/system/custom-system-prompt.md +1 -1
  868. package/src/prompts/system/eager-task.md +7 -0
  869. package/src/prompts/system/eager-todo.md +11 -6
  870. package/src/prompts/system/empty-stop-retry.md +4 -6
  871. package/src/prompts/system/irc-autoreply.md +6 -0
  872. package/src/prompts/system/irc-incoming.md +3 -4
  873. package/src/prompts/system/manual-continue.md +7 -0
  874. package/src/prompts/system/omfg-user.md +3 -4
  875. package/src/prompts/system/orchestrate-notice.md +10 -10
  876. package/src/prompts/system/personalities/default.md +26 -0
  877. package/src/prompts/system/personalities/friendly.md +17 -0
  878. package/src/prompts/system/personalities/pragmatic.md +15 -0
  879. package/src/prompts/system/plan-mode-active.md +70 -77
  880. package/src/prompts/system/plan-mode-approved.md +1 -1
  881. package/src/prompts/system/plan-mode-subagent.md +4 -5
  882. package/src/prompts/system/plan-mode-tool-decision-reminder.md +1 -1
  883. package/src/prompts/system/project-prompt.md +2 -2
  884. package/src/prompts/system/snapcompact-context-frames-note.md +1 -0
  885. package/src/prompts/system/snapcompact-context-stub.md +1 -0
  886. package/src/prompts/system/snapcompact-system-frames-note.md +1 -0
  887. package/src/prompts/system/snapcompact-system-stub.md +1 -0
  888. package/src/prompts/system/snapcompact-toolresult-note.md +1 -0
  889. package/src/prompts/system/subagent-system-prompt.md +7 -8
  890. package/src/prompts/system/system-prompt.md +28 -57
  891. package/src/prompts/system/tiny-title-system.md +1 -1
  892. package/src/prompts/system/title-marker-instruction.md +1 -0
  893. package/src/prompts/system/title-system-marker.md +16 -0
  894. package/src/prompts/system/title-system.md +16 -3
  895. package/src/prompts/system/ttsr-tool-reminder.md +1 -1
  896. package/src/prompts/system/workflow-notice.md +4 -4
  897. package/src/prompts/tools/ast-edit.md +1 -1
  898. package/src/prompts/tools/ast-grep.md +2 -2
  899. package/src/prompts/tools/bash.md +16 -8
  900. package/src/prompts/tools/browser.md +33 -43
  901. package/src/prompts/tools/debug.md +1 -1
  902. package/src/prompts/tools/eval.md +31 -51
  903. package/src/prompts/tools/find.md +0 -1
  904. package/src/prompts/tools/github.md +8 -7
  905. package/src/prompts/tools/goal.md +1 -1
  906. package/src/prompts/tools/image-gen.md +1 -1
  907. package/src/prompts/tools/inspect-image-system.md +1 -1
  908. package/src/prompts/tools/irc.md +39 -31
  909. package/src/prompts/tools/job.md +2 -1
  910. package/src/prompts/tools/learn.md +7 -0
  911. package/src/prompts/tools/lsp-late-diagnostic.md +8 -0
  912. package/src/prompts/tools/lsp.md +2 -2
  913. package/src/prompts/tools/manage-skill.md +9 -0
  914. package/src/prompts/tools/memory-edit.md +1 -1
  915. package/src/prompts/tools/patch.md +2 -2
  916. package/src/prompts/tools/read.md +31 -39
  917. package/src/prompts/tools/recall.md +1 -1
  918. package/src/prompts/tools/reflect.md +1 -1
  919. package/src/prompts/tools/render-mermaid.md +2 -2
  920. package/src/prompts/tools/replace.md +4 -10
  921. package/src/prompts/tools/rewind.md +2 -2
  922. package/src/prompts/tools/search-tool-bm25.md +1 -9
  923. package/src/prompts/tools/search.md +0 -1
  924. package/src/prompts/tools/ssh.md +0 -4
  925. package/src/prompts/tools/task-summary.md +5 -16
  926. package/src/prompts/tools/task.md +47 -31
  927. package/src/prompts/tools/todo.md +6 -3
  928. package/src/registry/agent-lifecycle.ts +218 -0
  929. package/src/registry/agent-registry.ts +46 -5
  930. package/src/sdk.ts +692 -219
  931. package/src/secrets/index.ts +8 -1
  932. package/src/secrets/obfuscator.ts +40 -19
  933. package/src/session/agent-session.ts +1577 -806
  934. package/src/session/agent-storage.ts +18 -9
  935. package/src/session/auth-broker-config.ts +30 -1
  936. package/src/session/auth-storage.ts +6 -0
  937. package/src/session/codex-auto-reset.ts +202 -0
  938. package/src/session/history-storage.ts +3 -2
  939. package/src/session/indexed-session-storage.ts +7 -10
  940. package/src/session/messages.ts +59 -95
  941. package/src/session/session-context.ts +352 -0
  942. package/src/session/session-dump-format.ts +12 -3
  943. package/src/session/session-entries.ts +194 -0
  944. package/src/session/session-history-format.ts +246 -0
  945. package/src/session/session-listing.ts +588 -0
  946. package/src/session/session-loader.ts +106 -0
  947. package/src/session/session-manager.ts +1003 -2920
  948. package/src/session/session-migrations.ts +78 -0
  949. package/src/session/session-paths.ts +193 -0
  950. package/src/session/session-persistence.ts +131 -0
  951. package/src/session/session-storage.ts +91 -30
  952. package/src/session/snapcompact-inline.ts +542 -0
  953. package/src/session/snapcompact-savings-journal.ts +113 -0
  954. package/src/session/streaming-output.ts +248 -11
  955. package/src/session/tool-choice-queue.ts +23 -11
  956. package/src/session/yield-queue.ts +20 -2
  957. package/src/slash-commands/acp-builtins.ts +25 -1
  958. package/src/slash-commands/available-commands.ts +105 -0
  959. package/src/slash-commands/builtin-registry.ts +575 -49
  960. package/src/slash-commands/helpers/active-oauth-account.ts +44 -0
  961. package/src/slash-commands/helpers/context-report.ts +28 -1
  962. package/src/slash-commands/helpers/logout.ts +88 -0
  963. package/src/slash-commands/helpers/reset-usage.ts +66 -0
  964. package/src/slash-commands/helpers/stats-dashboard.ts +85 -0
  965. package/src/slash-commands/helpers/usage-report.ts +38 -3
  966. package/src/slash-commands/types.ts +5 -9
  967. package/src/ssh/connection-manager.ts +27 -0
  968. package/src/ssh/ssh-executor.ts +60 -4
  969. package/src/stt/asr-client.ts +520 -0
  970. package/src/stt/asr-protocol.ts +65 -0
  971. package/src/stt/asr-worker.ts +790 -0
  972. package/src/stt/downloader.ts +107 -47
  973. package/src/stt/endpointer.ts +259 -0
  974. package/src/stt/index.ts +5 -1
  975. package/src/stt/models.ts +150 -0
  976. package/src/stt/recorder.ts +254 -67
  977. package/src/stt/stt-controller.ts +201 -22
  978. package/src/stt/transcriber.ts +37 -68
  979. package/src/stt/wav.ts +173 -0
  980. package/src/system-prompt.ts +52 -10
  981. package/src/task/agents.ts +3 -4
  982. package/src/task/commands.ts +3 -2
  983. package/src/task/discovery.ts +17 -24
  984. package/src/task/executor.ts +1054 -529
  985. package/src/task/index.ts +862 -757
  986. package/src/task/output-manager.ts +0 -11
  987. package/src/task/parallel.ts +3 -3
  988. package/src/task/prometheus-command.ts +2 -2
  989. package/src/task/render.ts +529 -182
  990. package/src/task/repair-args.ts +21 -9
  991. package/src/task/types.ts +144 -66
  992. package/src/task/worktree.ts +64 -56
  993. package/src/telemetry-export.ts +27 -9
  994. package/src/thinking.ts +9 -7
  995. package/src/tiny/models.ts +2 -2
  996. package/src/tiny/text.ts +5 -1
  997. package/src/tiny/title-client.ts +72 -20
  998. package/src/tiny/title-protocol.ts +1 -1
  999. package/src/tiny/worker.ts +23 -99
  1000. package/src/tool-discovery/tool-index.ts +2 -0
  1001. package/src/tools/archive-reader.ts +94 -2
  1002. package/src/tools/ask.ts +234 -177
  1003. package/src/tools/ast-edit.ts +136 -80
  1004. package/src/tools/ast-grep.ts +41 -45
  1005. package/src/tools/auto-generated-guard.ts +20 -3
  1006. package/src/tools/bash-interactive.ts +28 -8
  1007. package/src/tools/bash.ts +198 -35
  1008. package/src/tools/browser/attach.ts +26 -7
  1009. package/src/tools/browser/cmux/cmux-tab.ts +1264 -0
  1010. package/src/tools/browser/cmux/rpc.ts +156 -0
  1011. package/src/tools/browser/cmux/socket-client.ts +309 -0
  1012. package/src/tools/browser/launch.ts +11 -2
  1013. package/src/tools/browser/readable.ts +19 -2
  1014. package/src/tools/browser/registry.ts +52 -5
  1015. package/src/tools/browser/render.ts +13 -5
  1016. package/src/tools/browser/tab-protocol.ts +2 -0
  1017. package/src/tools/browser/tab-supervisor.ts +256 -34
  1018. package/src/tools/browser/tab-worker.ts +259 -91
  1019. package/src/tools/browser.ts +44 -2
  1020. package/src/tools/checkpoint.ts +1 -1
  1021. package/src/tools/conflict-detect.ts +50 -4
  1022. package/src/tools/debug.ts +27 -12
  1023. package/src/tools/eval-render.ts +32 -35
  1024. package/src/tools/eval.ts +26 -12
  1025. package/src/tools/fetch.ts +450 -99
  1026. package/src/tools/find.ts +182 -142
  1027. package/src/tools/gh-cache-invalidation.ts +255 -0
  1028. package/src/tools/gh-renderer.ts +104 -51
  1029. package/src/tools/gh.ts +232 -37
  1030. package/src/tools/github-cache.ts +97 -7
  1031. package/src/tools/grouped-file-output.ts +159 -52
  1032. package/src/tools/image-gen.ts +237 -132
  1033. package/src/tools/index.ts +147 -26
  1034. package/src/tools/inspect-image-renderer.ts +74 -45
  1035. package/src/tools/inspect-image.ts +12 -6
  1036. package/src/tools/irc.ts +626 -173
  1037. package/src/tools/job.ts +106 -29
  1038. package/src/tools/learn.ts +144 -0
  1039. package/src/tools/manage-skill.ts +104 -0
  1040. package/src/tools/memory-edit.ts +4 -4
  1041. package/src/tools/memory-recall.ts +7 -9
  1042. package/src/tools/memory-reflect.ts +5 -9
  1043. package/src/tools/memory-render.ts +23 -6
  1044. package/src/tools/memory-retain.ts +4 -4
  1045. package/src/tools/path-utils.ts +102 -48
  1046. package/src/tools/plan-mode-guard.ts +101 -40
  1047. package/src/tools/read.ts +475 -120
  1048. package/src/tools/render-mermaid.ts +1 -1
  1049. package/src/tools/render-utils.ts +132 -76
  1050. package/src/tools/renderers.ts +12 -1
  1051. package/src/tools/report-tool-issue.ts +14 -6
  1052. package/src/tools/resolve.ts +20 -3
  1053. package/src/tools/review.ts +2 -2
  1054. package/src/tools/search-tool-bm25.ts +37 -24
  1055. package/src/tools/search.ts +233 -115
  1056. package/src/tools/sqlite-reader.ts +26 -17
  1057. package/src/tools/ssh.ts +20 -14
  1058. package/src/tools/todo.ts +197 -191
  1059. package/src/tools/tool-result.ts +8 -0
  1060. package/src/tools/tool-timeouts.ts +1 -1
  1061. package/src/tools/tts.ts +205 -74
  1062. package/src/tools/write.ts +291 -155
  1063. package/src/tools/yield.ts +10 -1
  1064. package/src/tts/downloader.ts +64 -0
  1065. package/src/tts/index.ts +8 -0
  1066. package/src/tts/models.ts +137 -0
  1067. package/src/tts/player.ts +137 -0
  1068. package/src/tts/runtime.ts +21 -0
  1069. package/src/tts/streaming-player.ts +266 -0
  1070. package/src/tts/tts-client.ts +647 -0
  1071. package/src/tts/tts-protocol.ts +60 -0
  1072. package/src/tts/tts-worker.ts +505 -0
  1073. package/src/tts/vocalizer.ts +162 -0
  1074. package/src/tts/wav.ts +58 -0
  1075. package/src/tui/code-cell.ts +2 -7
  1076. package/src/tui/hyperlink.ts +40 -26
  1077. package/src/tui/output-block.ts +60 -108
  1078. package/src/tui/status-line.ts +5 -1
  1079. package/src/utils/block-context.ts +312 -0
  1080. package/src/utils/changelog.ts +27 -1
  1081. package/src/utils/clipboard.ts +91 -22
  1082. package/src/utils/commit-message-generator.ts +8 -3
  1083. package/src/utils/enhanced-paste.ts +230 -0
  1084. package/src/utils/file-mentions.ts +3 -1
  1085. package/src/utils/git.ts +315 -15
  1086. package/src/utils/image-loading.ts +65 -4
  1087. package/src/utils/session-color.ts +83 -9
  1088. package/src/utils/thinking-display.ts +37 -0
  1089. package/src/utils/title-generator.ts +73 -10
  1090. package/src/utils/tool-choice.ts +16 -0
  1091. package/src/utils/tools-manager.ts +19 -1
  1092. package/src/web/kagi.ts +28 -26
  1093. package/src/web/parallel.ts +7 -3
  1094. package/src/web/scrapers/arxiv.ts +1 -1
  1095. package/src/web/scrapers/github.ts +351 -3
  1096. package/src/web/scrapers/go-pkg.ts +1 -1
  1097. package/src/web/scrapers/iacr.ts +1 -1
  1098. package/src/web/scrapers/readthedocs.ts +1 -1
  1099. package/src/web/scrapers/twitter.ts +2 -1
  1100. package/src/web/scrapers/types.ts +87 -8
  1101. package/src/web/scrapers/wikipedia.ts +1 -1
  1102. package/src/web/scrapers/youtube.ts +9 -3
  1103. package/src/web/search/index.ts +15 -2
  1104. package/src/web/search/providers/anthropic.ts +62 -21
  1105. package/src/web/search/providers/base.ts +2 -1
  1106. package/src/web/search/providers/brave.ts +5 -2
  1107. package/src/web/search/providers/codex.ts +87 -51
  1108. package/src/web/search/providers/exa.ts +101 -10
  1109. package/src/web/search/providers/gemini.ts +49 -24
  1110. package/src/web/search/providers/jina.ts +15 -5
  1111. package/src/web/search/providers/kagi.ts +9 -2
  1112. package/src/web/search/providers/kimi.ts +45 -20
  1113. package/src/web/search/providers/parallel.ts +39 -24
  1114. package/src/web/search/providers/perplexity.ts +226 -63
  1115. package/src/web/search/providers/searxng.ts +19 -3
  1116. package/src/web/search/providers/synthetic.ts +16 -11
  1117. package/src/web/search/providers/tavily.ts +12 -9
  1118. package/src/web/search/providers/zai.ts +22 -9
  1119. package/src/web/search/render.ts +59 -64
  1120. package/src/web/search/types.ts +5 -1
  1121. package/dist/types/discovery/context-files.d.ts +0 -17
  1122. package/dist/types/exa/factory.d.ts +0 -13
  1123. package/dist/types/exa/render.d.ts +0 -19
  1124. package/dist/types/exa/researcher.d.ts +0 -9
  1125. package/dist/types/exa/search.d.ts +0 -9
  1126. package/dist/types/exa/websets.d.ts +0 -9
  1127. package/dist/types/export/html/template.generated.d.ts +0 -1
  1128. package/dist/types/modes/components/session-observer-overlay.d.ts +0 -11
  1129. package/dist/types/modes/components/status-line.d.ts +0 -77
  1130. package/dist/types/slash-commands/headless-plan.d.ts +0 -3
  1131. package/dist/types/stt/setup.d.ts +0 -18
  1132. package/scripts/generate-template.ts +0 -33
  1133. package/src/discovery/context-files.ts +0 -49
  1134. package/src/exa/factory.ts +0 -60
  1135. package/src/exa/render.ts +0 -244
  1136. package/src/exa/researcher.ts +0 -36
  1137. package/src/exa/search.ts +0 -47
  1138. package/src/exa/websets.ts +0 -248
  1139. package/src/export/html/template.generated.ts +0 -2
  1140. package/src/modes/components/session-observer-overlay.ts +0 -852
  1141. package/src/slash-commands/headless-plan.ts +0 -142
  1142. package/src/stt/setup.ts +0 -52
  1143. package/src/stt/transcribe.py +0 -70
  1144. /package/dist/types/extensibility/{legacy-pi-coding-agent-shim.d.ts → legacy-package-agent-shim.d.ts} +0 -0
  1145. /package/src/extensibility/{legacy-pi-coding-agent-shim.ts → legacy-package-agent-shim.ts} +0 -0
@@ -0,0 +1,1264 @@
1
+ import * as fs from "node:fs";
2
+ import * as os from "node:os";
3
+ import * as path from "node:path";
4
+ import { logger, Snowflake } from "@prometheus-ai/utils";
5
+ import { JsRuntime, type RuntimeHooks } from "../../../eval/js/shared/runtime";
6
+ import type { JsDisplayOutput } from "../../../eval/js/shared/types";
7
+ import { callSessionTool } from "../../../eval/js/tool-bridge";
8
+ import type { ToolSession } from "../../../sdk";
9
+ import { resizeImage } from "../../../utils/image-resize";
10
+ import { resolveToCwd } from "../../path-utils";
11
+ import { formatScreenshot } from "../../render-utils";
12
+ import { ToolAbortError, ToolError } from "../../tool-errors";
13
+ import { DEFAULT_VIEWPORT } from "../launch";
14
+ import { extractReadableFromHtml, type ReadableFormat } from "../readable";
15
+ import type { Observation, ReadyInfo, RunResultOk, ScreenshotResult, SessionSnapshot } from "../tab-protocol";
16
+ import {
17
+ type CmuxEvalResult,
18
+ type CmuxGeometry,
19
+ type CmuxScreenshotResult,
20
+ type CmuxSnapshotResult,
21
+ type CmuxUrlGetResult,
22
+ cmuxSnapshotToObservation,
23
+ GEOMETRY_SCRIPT,
24
+ mapWaitUntil,
25
+ serializeEval,
26
+ } from "./rpc";
27
+ import type { CmuxSocketClient } from "./socket-client";
28
+
29
+ interface ScreenshotOptions {
30
+ selector?: string;
31
+ fullPage?: boolean;
32
+ save?: string;
33
+ silent?: boolean;
34
+ encoding?: "base64" | "binary";
35
+ }
36
+
37
+ interface ObserveOptions {
38
+ includeAll?: boolean;
39
+ viewportOnly?: boolean;
40
+ }
41
+
42
+ interface RunContext {
43
+ session: SessionSnapshot;
44
+ displays: RunResultOk["displays"];
45
+ screenshots: ScreenshotResult[];
46
+ signal?: AbortSignal;
47
+ timeoutMs: number;
48
+ }
49
+
50
+ type WaitUntil = "load" | "domcontentloaded" | "networkidle0" | "networkidle2";
51
+ type DragTarget = string | { readonly x: number; readonly y: number };
52
+ type SelectorKind = "css" | "ref" | "text" | "aria" | "xpath" | "pierce" | "ax";
53
+
54
+ interface SelectorSpec {
55
+ kind: SelectorKind;
56
+ value: string;
57
+ raw: string;
58
+ ref?: string;
59
+ name?: string;
60
+ role?: string;
61
+ }
62
+
63
+ interface CachedElementRef {
64
+ ref: string;
65
+ name?: string;
66
+ role?: string;
67
+ }
68
+
69
+ interface BoundingBox {
70
+ x: number;
71
+ y: number;
72
+ width: number;
73
+ height: number;
74
+ }
75
+
76
+ interface FilePayload {
77
+ name: string;
78
+ type: string;
79
+ data: string;
80
+ }
81
+
82
+ interface CmuxResponseRecord {
83
+ id: number;
84
+ url: string;
85
+ status: number;
86
+ statusText: string;
87
+ headers: Record<string, string>;
88
+ body: string;
89
+ }
90
+
91
+ interface ViewportOptions {
92
+ width: number;
93
+ height: number;
94
+ deviceScaleFactor?: number;
95
+ }
96
+
97
+ const PAGE_SELECTOR_HELPERS = `
98
+ const isVisible = element => {
99
+ const style = getComputedStyle(element);
100
+ const rect = element.getBoundingClientRect();
101
+ return style.visibility !== "hidden" && style.display !== "none" && rect.width > 0 && rect.height > 0;
102
+ };
103
+ const textOf = element => (element.innerText || element.textContent || "").trim();
104
+ const allElements = () => Array.from(document.querySelectorAll("body *"));
105
+ const pierceQuery = (root, selector) => {
106
+ const direct = root.querySelector?.(selector);
107
+ if (direct) return direct;
108
+ const nodes = root.querySelectorAll ? Array.from(root.querySelectorAll("*")) : [];
109
+ for (const node of nodes) {
110
+ if (node.shadowRoot) {
111
+ const found = pierceQuery(node.shadowRoot, selector);
112
+ if (found) return found;
113
+ }
114
+ }
115
+ return null;
116
+ };
117
+ const accessibleName = element =>
118
+ (
119
+ element.getAttribute("aria-label") ||
120
+ element.getAttribute("alt") ||
121
+ element.getAttribute("title") ||
122
+ textOf(element)
123
+ ).trim();
124
+ const findElement = spec => {
125
+ if (spec.kind === "css") return document.querySelector(spec.value);
126
+ if (spec.kind === "pierce") return pierceQuery(document, spec.value);
127
+ if (spec.kind === "xpath") {
128
+ const result = document.evaluate(spec.value, document, null, XPathResult.FIRST_ORDERED_NODE_TYPE, null);
129
+ return result.singleNodeValue instanceof Element ? result.singleNodeValue : null;
130
+ }
131
+ if (spec.kind === "text") {
132
+ const wanted = spec.value.trim();
133
+ return allElements().find(element => isVisible(element) && textOf(element).includes(wanted)) || null;
134
+ }
135
+ if (spec.kind === "aria" || spec.kind === "ax") {
136
+ const wanted = (spec.name || spec.value).trim();
137
+ const role = spec.role || "";
138
+ return (
139
+ allElements().find(element => {
140
+ if (!isVisible(element)) return false;
141
+ if (role && element.getAttribute("role") !== role) return false;
142
+ const name = accessibleName(element);
143
+ return name === wanted || name.includes(wanted);
144
+ }) || null
145
+ );
146
+ }
147
+ return null;
148
+ };
149
+ const event = (target, type, init = {}) =>
150
+ target.dispatchEvent(new Event(type, { bubbles: true, cancelable: true, ...init }));
151
+ const mouseEvent = (target, type, init = {}) =>
152
+ target.dispatchEvent(new MouseEvent(type, { bubbles: true, cancelable: true, view: window, ...init }));
153
+ const inputEvent = target => {
154
+ event(target, "input");
155
+ event(target, "change");
156
+ };
157
+ const setValue = (target, value, append = false) => {
158
+ if ("value" in target) {
159
+ target.value = append ? String(target.value || "") + value : value;
160
+ inputEvent(target);
161
+ return;
162
+ }
163
+ if (target.isContentEditable) {
164
+ target.textContent = append ? String(target.textContent || "") + value : value;
165
+ inputEvent(target);
166
+ }
167
+ };
168
+ `;
169
+
170
+ const RESPONSE_OBSERVER_SCRIPT = String.raw`
171
+ (() => {
172
+ const key = "__ompCmuxResponses";
173
+ if (globalThis[key]) return true;
174
+ const state = { nextId: 1, records: [] };
175
+ Object.defineProperty(globalThis, key, { value: state, configurable: true });
176
+ const headersObject = headers => {
177
+ const out = {};
178
+ if (headers && typeof headers.forEach === "function") headers.forEach((value, name) => (out[name] = value));
179
+ return out;
180
+ };
181
+ const remember = async response => {
182
+ try {
183
+ const clone = response.clone();
184
+ const body = await clone.text().catch(() => "");
185
+ state.records.push({
186
+ id: state.nextId++,
187
+ url: response.url,
188
+ status: response.status,
189
+ statusText: response.statusText,
190
+ headers: headersObject(response.headers),
191
+ body,
192
+ });
193
+ if (state.records.length > 200) state.records.splice(0, state.records.length - 200);
194
+ } catch {
195
+ }
196
+ };
197
+ const originalFetch = globalThis.fetch;
198
+ if (typeof originalFetch === "function") {
199
+ globalThis.fetch = async (...args) => {
200
+ const response = await originalFetch(...args);
201
+ void remember(response);
202
+ return response;
203
+ };
204
+ }
205
+ const OriginalXHR = globalThis.XMLHttpRequest;
206
+ if (typeof OriginalXHR === "function") {
207
+ globalThis.XMLHttpRequest = function XMLHttpRequestProxy() {
208
+ const xhr = new OriginalXHR();
209
+ xhr.addEventListener("loadend", () => {
210
+ const rawHeaders = xhr.getAllResponseHeaders();
211
+ const headers = {};
212
+ for (const line of rawHeaders.trim().split(/[\r\n]+/)) {
213
+ const index = line.indexOf(":");
214
+ if (index > 0) headers[line.slice(0, index).trim().toLowerCase()] = line.slice(index + 1).trim();
215
+ }
216
+ state.records.push({
217
+ id: state.nextId++,
218
+ url: xhr.responseURL || "",
219
+ status: xhr.status,
220
+ statusText: xhr.statusText,
221
+ headers,
222
+ body: typeof xhr.responseText === "string" ? xhr.responseText : "",
223
+ });
224
+ if (state.records.length > 200) state.records.splice(0, state.records.length - 200);
225
+ });
226
+ return xhr;
227
+ };
228
+ }
229
+ return true;
230
+ })()
231
+ `;
232
+
233
+ export interface RunCmuxCodeOptions {
234
+ code: string;
235
+ timeoutMs: number;
236
+ signal?: AbortSignal;
237
+ session: ToolSession;
238
+ snapshot: SessionSnapshot;
239
+ }
240
+
241
+ export class CmuxTab {
242
+ readonly #client: CmuxSocketClient;
243
+ readonly #surfaceId: string;
244
+ #lastUrl = "about:blank";
245
+ #lastTitle: string | undefined;
246
+ #lastViewport: ReadyInfo["viewport"] = DEFAULT_VIEWPORT;
247
+ #runContext: RunContext | undefined;
248
+ #runtime: JsRuntime | undefined;
249
+ readonly #elementRefs = new Map<number, CachedElementRef>();
250
+ #pageFacade: CmuxPageFacade | undefined;
251
+ #browserFacade: CmuxBrowserFacade | undefined;
252
+ constructor(opts: { client: CmuxSocketClient; surfaceId: string; url?: string; title?: string }) {
253
+ this.#client = opts.client;
254
+ this.#surfaceId = opts.surfaceId;
255
+ if (opts.url) this.#lastUrl = opts.url;
256
+ this.#lastTitle = opts.title;
257
+ }
258
+
259
+ get surfaceId(): string {
260
+ return this.#surfaceId;
261
+ }
262
+
263
+ get page(): CmuxPageFacade {
264
+ this.#pageFacade ??= new CmuxPageFacade(this);
265
+ return this.#pageFacade;
266
+ }
267
+
268
+ get browser(): CmuxBrowserFacade {
269
+ this.#browserFacade ??= new CmuxBrowserFacade(this);
270
+ return this.#browserFacade;
271
+ }
272
+
273
+ viewport(): ReadyInfo["viewport"] {
274
+ return this.#lastViewport;
275
+ }
276
+
277
+ async setViewport(viewport: ViewportOptions): Promise<void> {
278
+ this.#lastViewport = {
279
+ width: viewport.width,
280
+ height: viewport.height,
281
+ deviceScaleFactor: viewport.deviceScaleFactor,
282
+ };
283
+ }
284
+
285
+ url(): string {
286
+ return this.#lastUrl;
287
+ }
288
+
289
+ async title(): Promise<string> {
290
+ const result = (await this.#request("browser.eval", { script: "document.title" })) as CmuxEvalResult;
291
+ this.#lastTitle = String(result.value ?? "");
292
+ return this.#lastTitle;
293
+ }
294
+
295
+ async readyInfo(viewport: ReadyInfo["viewport"] = DEFAULT_VIEWPORT): Promise<ReadyInfo> {
296
+ const urlResult = (await this.#request("browser.url.get", {})) as CmuxUrlGetResult;
297
+ if (typeof urlResult.url === "string" && urlResult.url.length > 0) {
298
+ this.#lastUrl = urlResult.url;
299
+ }
300
+ const geometry = await this.#readGeometry().catch(() => undefined);
301
+ this.#lastViewport = geometry
302
+ ? { width: geometry.innerWidth, height: geometry.innerHeight, deviceScaleFactor: geometry.dpr }
303
+ : viewport;
304
+ await this.title().catch(() => "");
305
+ return {
306
+ url: this.#lastUrl,
307
+ title: this.#lastTitle,
308
+ viewport: this.#lastViewport,
309
+ targetId: this.#surfaceId,
310
+ };
311
+ }
312
+
313
+ setRunContext(context: RunContext): void {
314
+ this.#runContext = context;
315
+ }
316
+
317
+ clearRunContext(): void {
318
+ this.#runContext = undefined;
319
+ }
320
+
321
+ async goto(url: string, opts?: { waitUntil?: WaitUntil; timeoutMs?: number }): Promise<void> {
322
+ const timeoutMs = opts?.timeoutMs ?? this.#runContext?.timeoutMs ?? 30_000;
323
+ const result = await this.#request("browser.navigate", { url }, timeoutMs);
324
+ const navigatedUrl = result.url;
325
+ this.#lastUrl = typeof navigatedUrl === "string" && navigatedUrl.length > 0 ? navigatedUrl : url;
326
+ if (opts?.waitUntil) {
327
+ await this.#request(
328
+ "browser.wait",
329
+ { load_state: mapWaitUntil(opts.waitUntil), timeout_ms: timeoutMs },
330
+ timeoutMs,
331
+ );
332
+ }
333
+ }
334
+
335
+ async observe(opts?: ObserveOptions): Promise<Observation> {
336
+ void opts?.viewportOnly;
337
+ const timeoutMs = Math.min(this.#runContext?.timeoutMs ?? 30_000, 30_000);
338
+ const [snapshot, geometry] = await Promise.all([
339
+ this.#request("browser.snapshot", { interactive: !opts?.includeAll, max_depth: 12 }, timeoutMs),
340
+ this.#readGeometry(timeoutMs),
341
+ ]);
342
+ const viewport = {
343
+ width: geometry.innerWidth,
344
+ height: geometry.innerHeight,
345
+ deviceScaleFactor: geometry.dpr,
346
+ };
347
+ this.#lastViewport = viewport;
348
+ const observation = cmuxSnapshotToObservation(snapshot as CmuxSnapshotResult, viewport, geometry);
349
+ this.#lastUrl = observation.url;
350
+ this.#lastTitle = observation.title;
351
+ this.#rememberObservedElements(observation);
352
+ return observation;
353
+ }
354
+
355
+ async click(selector: string): Promise<void> {
356
+ await this.#selectorAction(selector, "click");
357
+ }
358
+
359
+ async dblclick(selector: string): Promise<void> {
360
+ await this.#selectorAction(selector, "dblclick");
361
+ }
362
+
363
+ async hover(selector: string): Promise<void> {
364
+ await this.#selectorAction(selector, "hover");
365
+ }
366
+
367
+ async focus(selector: string): Promise<void> {
368
+ await this.#selectorAction(selector, "focus");
369
+ }
370
+
371
+ async check(selector: string): Promise<void> {
372
+ await this.#selectorAction(selector, "check");
373
+ }
374
+
375
+ async uncheck(selector: string): Promise<void> {
376
+ await this.#selectorAction(selector, "uncheck");
377
+ }
378
+
379
+ async type(selector: string, text: string): Promise<void> {
380
+ await this.#selectorAction(selector, "type", { text });
381
+ }
382
+
383
+ async fill(selector: string, value: string): Promise<void> {
384
+ await this.#selectorAction(selector, "fill", { value });
385
+ }
386
+
387
+ async press(key: string, opts?: { selector?: string }): Promise<void> {
388
+ if (opts?.selector) {
389
+ await this.focus(opts.selector);
390
+ }
391
+ await this.#request("browser.press", { key });
392
+ }
393
+
394
+ async scroll(dx: number, dy: number): Promise<void> {
395
+ await this.#request("browser.scroll", { dx, dy });
396
+ }
397
+
398
+ async waitFor(selector: string, opts?: { timeout?: number }): Promise<CmuxElementHandle> {
399
+ const timeoutMs = opts?.timeout ?? this.#runContext?.timeoutMs ?? 30_000;
400
+ await this.#waitForSelector(selector, timeoutMs);
401
+ return new CmuxElementHandle(this, selector);
402
+ }
403
+
404
+ async evaluate<TResult, TArgs extends unknown[]>(
405
+ fn: string | ((...args: TArgs) => TResult | Promise<TResult>),
406
+ ...args: TArgs
407
+ ): Promise<TResult> {
408
+ const result = (await this.#request("browser.eval", {
409
+ script: serializeEval(fn as string | ((...args: unknown[]) => unknown), args),
410
+ })) as CmuxEvalResult;
411
+ return result.value as TResult;
412
+ }
413
+
414
+ async scrollIntoView(selector: string): Promise<void> {
415
+ await this.#selectorAction(selector, "scrollIntoView");
416
+ }
417
+
418
+ async select(selector: string, ...values: string[]): Promise<string[]> {
419
+ return await this.#selectorAction<string[]>(selector, "select", { values });
420
+ }
421
+
422
+ async extract(format: ReadableFormat = "markdown"): Promise<string> {
423
+ const result = (await this.#request("browser.snapshot", { interactive: false })) as CmuxSnapshotResult;
424
+ const html = typeof result.page?.html === "string" ? result.page.html : "";
425
+ const url =
426
+ (typeof result.url === "string" && result.url.length > 0 ? result.url : undefined) ??
427
+ (typeof result.page?.url === "string" && result.page.url.length > 0 ? result.page.url : undefined) ??
428
+ this.#lastUrl;
429
+ const readable = await extractReadableFromHtml(html, url, format);
430
+ if (!readable) {
431
+ throw new ToolError(`tab.extract(${JSON.stringify(format)}) found no readable content on ${url}`);
432
+ }
433
+ const content = format === "markdown" ? readable.markdown : readable.text;
434
+ if (!content) {
435
+ throw new ToolError(`tab.extract(${JSON.stringify(format)}) produced empty ${format} content for ${url}`);
436
+ }
437
+ return content;
438
+ }
439
+
440
+ async screenshot(opts: ScreenshotOptions = {}): Promise<ScreenshotResult> {
441
+ const context = this.#requireRunContext("tab.screenshot()");
442
+ if (opts.selector) {
443
+ await this.scrollIntoView(opts.selector);
444
+ }
445
+ void opts.fullPage;
446
+ const result = await this.#captureScreenshotPng(context.timeoutMs);
447
+ const buffer = Buffer.from(result.png_base64, "base64");
448
+ const captureMime = "image/png";
449
+ const resized = await resizeImage(
450
+ { type: "image", data: result.png_base64, mimeType: captureMime },
451
+ {
452
+ maxWidth: 1024,
453
+ maxHeight: 1024,
454
+ maxBytes: 150 * 1024,
455
+ jpegQuality: 70,
456
+ excludeWebP: context.session.excludeWebP,
457
+ },
458
+ );
459
+ const explicitPath = opts.save ? resolveToCwd(opts.save, context.session.cwd) : undefined;
460
+ const returnedPath = typeof result.path === "string" && result.path.length > 0 ? result.path : undefined;
461
+ const saveFullRes = !!(explicitPath || context.session.browserScreenshotDir || returnedPath);
462
+ const savedBuffer = saveFullRes ? buffer : Buffer.from(resized.buffer);
463
+ const savedMimeType = saveFullRes ? captureMime : resized.mimeType;
464
+ const ext = savedMimeType === "image/webp" ? "webp" : savedMimeType === "image/jpeg" ? "jpg" : "png";
465
+ const dest =
466
+ explicitPath ??
467
+ (context.session.browserScreenshotDir
468
+ ? path.join(
469
+ context.session.browserScreenshotDir,
470
+ `screenshot-${new Date().toISOString().replace(/[:.]/g, "-").slice(0, -1)}.${ext}`,
471
+ )
472
+ : (returnedPath ?? path.join(os.tmpdir(), `prometheus-sshots-${Snowflake.next()}.${ext}`)));
473
+ await fs.promises.mkdir(path.dirname(dest), { recursive: true });
474
+ await Bun.write(dest, savedBuffer);
475
+ const info: ScreenshotResult = {
476
+ dest,
477
+ mimeType: savedMimeType,
478
+ bytes: savedBuffer.length,
479
+ width: resized.width,
480
+ height: resized.height,
481
+ };
482
+ context.screenshots.push(info);
483
+ if (!opts.silent) {
484
+ const lines = formatScreenshot({
485
+ saveFullRes,
486
+ savedMimeType,
487
+ savedByteLength: savedBuffer.length,
488
+ dest,
489
+ resized,
490
+ });
491
+ context.displays.push({ type: "text", text: lines.join("\n") });
492
+ context.displays.push({ type: "image", data: resized.data, mimeType: resized.mimeType });
493
+ }
494
+ return info;
495
+ }
496
+
497
+ async waitForUrl(pattern: string | RegExp, opts?: { timeout?: number }): Promise<string> {
498
+ const timeoutMs = opts?.timeout ?? this.#runContext?.timeoutMs ?? 30_000;
499
+ if (typeof pattern === "string") {
500
+ await this.#request("browser.wait", { url_contains: pattern, timeout_ms: timeoutMs }, timeoutMs);
501
+ const result = (await this.#request("browser.url.get", {}, timeoutMs)) as CmuxUrlGetResult;
502
+ if (typeof result.url === "string" && result.url.length > 0) {
503
+ this.#lastUrl = result.url;
504
+ }
505
+ return this.#lastUrl;
506
+ }
507
+ const deadline = Date.now() + timeoutMs;
508
+ while (Date.now() <= deadline) {
509
+ const result = (await this.#request("browser.url.get", {}, Math.min(timeoutMs, 5_000))) as CmuxUrlGetResult;
510
+ if (typeof result.url === "string" && result.url.length > 0) {
511
+ this.#lastUrl = result.url;
512
+ if (pattern.test(result.url)) return result.url;
513
+ }
514
+ await Bun.sleep(200);
515
+ }
516
+ throw new ToolError(`tab.waitForUrl() timed out after ${timeoutMs}ms`);
517
+ }
518
+
519
+ async drag(from: DragTarget, to: DragTarget): Promise<void> {
520
+ const start = await this.#dragPoint(from);
521
+ const end = await this.#dragPoint(to);
522
+ await this.#evalScript(
523
+ `(() => {
524
+ const points = ${JSON.stringify({ start, end })};
525
+ const target = document.elementFromPoint(points.start.x, points.start.y) || document.body;
526
+ const dispatch = (type, point) => target.dispatchEvent(new MouseEvent(type, {
527
+ bubbles: true,
528
+ cancelable: true,
529
+ view: window,
530
+ clientX: point.x,
531
+ clientY: point.y,
532
+ buttons: type === "mouseup" ? 0 : 1,
533
+ }));
534
+ dispatch("mousemove", points.start);
535
+ dispatch("mousedown", points.start);
536
+ dispatch("mousemove", points.end);
537
+ dispatch("mouseup", points.end);
538
+ return true;
539
+ })()`,
540
+ );
541
+ }
542
+
543
+ async uploadFile(selector: string, ...filePaths: string[]): Promise<void> {
544
+ if (!filePaths.length) throw new ToolError("tab.uploadFile() requires at least one file path");
545
+ const files: FilePayload[] = [];
546
+ for (const filePath of filePaths) {
547
+ const absolute = resolveToCwd(filePath, this.#requireRunContext("tab.uploadFile()").session.cwd);
548
+ const file = Bun.file(absolute);
549
+ const data = Buffer.from(await file.arrayBuffer()).toString("base64");
550
+ files.push({ name: path.basename(absolute), type: file.type || "application/octet-stream", data });
551
+ }
552
+ await this.#selectorAction(selector, "uploadFile", { files });
553
+ }
554
+
555
+ async waitForResponse(
556
+ pattern: string | RegExp | ((response: CmuxResponse) => boolean | Promise<boolean>),
557
+ opts?: { timeout?: number },
558
+ ): Promise<CmuxResponse> {
559
+ const timeoutMs = opts?.timeout ?? this.#runContext?.timeoutMs ?? 30_000;
560
+ await this.#installResponseObserver();
561
+ const startId = await this.#responseCursor();
562
+ const deadline = Date.now() + timeoutMs;
563
+ while (Date.now() <= deadline) {
564
+ const records = await this.#responseRecordsAfter(startId);
565
+ for (const record of records) {
566
+ const response = new CmuxResponse(record);
567
+ if (typeof pattern === "function") {
568
+ if (await pattern(response)) return response;
569
+ } else if (pattern instanceof RegExp ? pattern.test(record.url) : record.url.includes(pattern)) {
570
+ return response;
571
+ }
572
+ }
573
+ await Bun.sleep(100);
574
+ }
575
+ throw new ToolError(`tab.waitForResponse() timed out after ${timeoutMs}ms`);
576
+ }
577
+
578
+ async id(id: number): Promise<CmuxElementHandle> {
579
+ const ref = this.#elementRefs.get(id)?.ref ?? `@e${id}`;
580
+ await this.#waitForSelector(ref, this.#runContext?.timeoutMs ?? 30_000);
581
+ return new CmuxElementHandle(this, ref);
582
+ }
583
+
584
+ ensureRuntime(session: SessionSnapshot): JsRuntime {
585
+ if (!this.#runtime) {
586
+ this.#runtime = new JsRuntime({
587
+ initialCwd: session.cwd,
588
+ sessionId: `cmux-tab-${this.#surfaceId}`,
589
+ });
590
+ }
591
+ return this.#runtime;
592
+ }
593
+
594
+ async #request(
595
+ method: string,
596
+ params: Record<string, unknown>,
597
+ timeoutMs?: number,
598
+ ): Promise<Record<string, unknown>> {
599
+ return await this.#client.request(method, { surface_id: this.#surfaceId, ...params }, { timeoutMs });
600
+ }
601
+
602
+ async #readGeometry(timeoutMs?: number): Promise<CmuxGeometry> {
603
+ const result = (await this.#request("browser.eval", { script: GEOMETRY_SCRIPT }, timeoutMs)) as CmuxEvalResult;
604
+ return this.#normalizeGeometry(result.value);
605
+ }
606
+
607
+ elementHandle(selector: string): CmuxElementHandle {
608
+ return new CmuxElementHandle(this, selector);
609
+ }
610
+
611
+ async elementExists(selector: string): Promise<boolean> {
612
+ return await this.#selectorExists(this.#selectorSpec(selector));
613
+ }
614
+
615
+ async elementBox(selector: string): Promise<BoundingBox | null> {
616
+ return await this.#selectorBox(this.#selectorSpec(selector));
617
+ }
618
+
619
+ async evaluateOnSelector<TResult>(selector: string, source: string, args: unknown[]): Promise<TResult> {
620
+ const spec = this.#selectorSpec(selector);
621
+ const script = `(() => {
622
+ const spec = ${JSON.stringify(spec)};
623
+ const source = ${JSON.stringify(source)};
624
+ const args = ${JSON.stringify(args)};
625
+ ${PAGE_SELECTOR_HELPERS}
626
+ const element = findElement(spec);
627
+ if (!element) throw new Error("Element handle selector no longer resolves");
628
+ const callable = (0, eval)("(" + source + ")");
629
+ return callable(element, ...args);
630
+ })()`;
631
+ return await this.#evalScript<TResult>(script);
632
+ }
633
+
634
+ async pageContent(): Promise<string> {
635
+ return await this.#evalScript<string>("document.documentElement.outerHTML");
636
+ }
637
+
638
+ async pageScreenshot(opts: ScreenshotOptions = {}): Promise<Buffer | string> {
639
+ if (opts.selector) await this.scrollIntoView(opts.selector);
640
+ const result = await this.#captureScreenshotPng(this.#runContext?.timeoutMs ?? 30_000);
641
+ return opts.encoding === "base64" ? result.png_base64 : Buffer.from(result.png_base64, "base64");
642
+ }
643
+
644
+ async waitForFunction(
645
+ fn: string | ((...args: unknown[]) => unknown | Promise<unknown>),
646
+ opts: { timeout?: number; polling?: number } | undefined,
647
+ ...args: unknown[]
648
+ ): Promise<unknown> {
649
+ const timeoutMs = opts?.timeout ?? this.#runContext?.timeoutMs ?? 30_000;
650
+ const pollingMs = typeof opts?.polling === "number" ? opts.polling : 200;
651
+ const deadline = Date.now() + timeoutMs;
652
+ while (Date.now() <= deadline) {
653
+ const value = typeof fn === "string" ? await this.#evalScript<unknown>(fn) : await this.evaluate(fn, ...args);
654
+ if (value) return value;
655
+ await Bun.sleep(pollingMs);
656
+ }
657
+ throw new ToolError(`page.waitForFunction() timed out after ${timeoutMs}ms`);
658
+ }
659
+
660
+ async #evalScript<TResult>(script: string, timeoutMs?: number): Promise<TResult> {
661
+ const result = (await this.#request("browser.eval", { script }, timeoutMs)) as CmuxEvalResult;
662
+ return result.value as TResult;
663
+ }
664
+
665
+ async #captureScreenshotPng(timeoutMs: number): Promise<CmuxScreenshotResult & { png_base64: string }> {
666
+ const result = (await this.#request("browser.screenshot", {}, timeoutMs)) as CmuxScreenshotResult;
667
+ if (typeof result.png_base64 !== "string" || result.png_base64.length === 0) {
668
+ throw new ToolError("cmux browser screenshot response did not include png_base64");
669
+ }
670
+ return result as CmuxScreenshotResult & { png_base64: string };
671
+ }
672
+
673
+ async #selectorAction<TResult = void>(
674
+ selector: string,
675
+ action: string,
676
+ args: Record<string, unknown> = {},
677
+ ): Promise<TResult> {
678
+ const spec = this.#selectorSpec(selector);
679
+ const nativeSelector = this.#nativeSelector(spec);
680
+ if (nativeSelector && action !== "select" && action !== "uploadFile") {
681
+ switch (action) {
682
+ case "click":
683
+ await this.#request("browser.click", { selector: nativeSelector });
684
+ return undefined as TResult;
685
+ case "dblclick":
686
+ await this.#request("browser.dblclick", { selector: nativeSelector });
687
+ return undefined as TResult;
688
+ case "hover":
689
+ await this.#request("browser.hover", { selector: nativeSelector });
690
+ return undefined as TResult;
691
+ case "focus":
692
+ await this.#request("browser.focus", { selector: nativeSelector });
693
+ return undefined as TResult;
694
+ case "check":
695
+ await this.#request("browser.check", { selector: nativeSelector });
696
+ return undefined as TResult;
697
+ case "uncheck":
698
+ await this.#request("browser.uncheck", { selector: nativeSelector });
699
+ return undefined as TResult;
700
+ case "type":
701
+ await this.#request("browser.type", { selector: nativeSelector, text: String(args.text ?? "") });
702
+ return undefined as TResult;
703
+ case "fill":
704
+ await this.#request("browser.fill", { selector: nativeSelector, text: String(args.value ?? "") });
705
+ return undefined as TResult;
706
+ case "scrollIntoView":
707
+ await this.#request("browser.scroll_into_view", { selector: nativeSelector });
708
+ return undefined as TResult;
709
+ }
710
+ }
711
+ return await this.#evalSelectorAction<TResult>(spec, action, args);
712
+ }
713
+
714
+ async #evalSelectorAction<TResult>(
715
+ spec: SelectorSpec,
716
+ action: string,
717
+ args: Record<string, unknown>,
718
+ ): Promise<TResult> {
719
+ const script = `(() => {
720
+ const spec = ${JSON.stringify(spec)};
721
+ const action = ${JSON.stringify(action)};
722
+ const args = ${JSON.stringify(args)};
723
+ ${PAGE_SELECTOR_HELPERS}
724
+ const element = findElement(spec);
725
+ if (!element) throw new Error("No element matched " + spec.raw);
726
+ if (action !== "exists") element.scrollIntoView({ block: "center", inline: "center" });
727
+ switch (action) {
728
+ case "click":
729
+ mouseEvent(element, "mousedown");
730
+ mouseEvent(element, "mouseup");
731
+ if (typeof element.click === "function") element.click();
732
+ else mouseEvent(element, "click");
733
+ return true;
734
+ case "dblclick":
735
+ mouseEvent(element, "dblclick");
736
+ return true;
737
+ case "hover":
738
+ mouseEvent(element, "mouseover");
739
+ mouseEvent(element, "mouseenter");
740
+ mouseEvent(element, "mousemove");
741
+ return true;
742
+ case "focus":
743
+ if (typeof element.focus === "function") element.focus();
744
+ return true;
745
+ case "check":
746
+ element.checked = true;
747
+ inputEvent(element);
748
+ return true;
749
+ case "uncheck":
750
+ element.checked = false;
751
+ inputEvent(element);
752
+ return true;
753
+ case "type":
754
+ if (typeof element.focus === "function") element.focus();
755
+ setValue(element, String(args.text || ""), true);
756
+ return true;
757
+ case "fill":
758
+ if (typeof element.focus === "function") element.focus();
759
+ setValue(element, String(args.value || ""), false);
760
+ return true;
761
+ case "scrollIntoView":
762
+ return true;
763
+ case "select": {
764
+ const values = Array.isArray(args.values) ? args.values.map(String) : [String(args.value || "")];
765
+ if (element.tagName !== "SELECT") throw new Error("tab.select() requires a <select> element");
766
+ const wanted = new Set(values);
767
+ const selected = [];
768
+ for (const option of Array.from(element.options)) {
769
+ option.selected = wanted.has(option.value);
770
+ if (option.selected) selected.push(option.value);
771
+ }
772
+ inputEvent(element);
773
+ return selected;
774
+ }
775
+ case "uploadFile": {
776
+ if (element.tagName !== "INPUT" || element.type !== "file") {
777
+ throw new Error("tab.uploadFile() requires an <input type=file> element");
778
+ }
779
+ const transfer = new DataTransfer();
780
+ for (const file of args.files || []) {
781
+ const bytes = Uint8Array.from(atob(file.data), char => char.charCodeAt(0));
782
+ transfer.items.add(new File([bytes], file.name, { type: file.type || "application/octet-stream" }));
783
+ }
784
+ element.files = transfer.files;
785
+ inputEvent(element);
786
+ return true;
787
+ }
788
+ }
789
+ throw new Error("Unsupported selector action " + action);
790
+ })()`;
791
+ const result = (await this.#request("browser.eval", { script }, this.#runContext?.timeoutMs)) as CmuxEvalResult;
792
+ return result.value as TResult;
793
+ }
794
+
795
+ async #waitForSelector(selector: string, timeoutMs: number): Promise<void> {
796
+ const spec = this.#selectorSpec(selector);
797
+ const nativeSelector = this.#nativeSelector(spec);
798
+ if (nativeSelector) {
799
+ await this.#request("browser.wait", { selector: nativeSelector, timeout_ms: timeoutMs }, timeoutMs);
800
+ return;
801
+ }
802
+ const deadline = Date.now() + timeoutMs;
803
+ while (Date.now() <= deadline) {
804
+ if (await this.#selectorExists(spec)) return;
805
+ await Bun.sleep(100);
806
+ }
807
+ throw new ToolError(`tab.waitFor(${JSON.stringify(selector)}) timed out after ${timeoutMs}ms`);
808
+ }
809
+
810
+ async #selectorExists(spec: SelectorSpec): Promise<boolean> {
811
+ if (spec.kind === "ref") return this.#elementRefs.has(Number(spec.value));
812
+ const script = `(() => {
813
+ const spec = ${JSON.stringify(spec)};
814
+ ${PAGE_SELECTOR_HELPERS}
815
+ return !!findElement(spec);
816
+ })()`;
817
+ return !!(await this.#evalScript<unknown>(script));
818
+ }
819
+
820
+ async #selectorBox(spec: SelectorSpec): Promise<BoundingBox | null> {
821
+ if (spec.kind === "ref") return null;
822
+ const script = `(() => {
823
+ const spec = ${JSON.stringify(spec)};
824
+ ${PAGE_SELECTOR_HELPERS}
825
+ const element = findElement(spec);
826
+ if (!element) return null;
827
+ const rect = element.getBoundingClientRect();
828
+ if (rect.width <= 0 || rect.height <= 0) return null;
829
+ return { x: rect.x, y: rect.y, width: rect.width, height: rect.height };
830
+ })()`;
831
+ const value = await this.#evalScript<unknown>(script);
832
+ if (!value || typeof value !== "object") return null;
833
+ const object = value as Record<string, unknown>;
834
+ return {
835
+ x: numberFrom(object.x, 0),
836
+ y: numberFrom(object.y, 0),
837
+ width: numberFrom(object.width, 0),
838
+ height: numberFrom(object.height, 0),
839
+ };
840
+ }
841
+
842
+ async #dragPoint(target: DragTarget): Promise<{ x: number; y: number }> {
843
+ if (typeof target === "string") {
844
+ const box = await this.#selectorBox(this.#selectorSpec(target));
845
+ if (!box) throw new ToolError(`Drag selector did not resolve to a visible element: ${target}`);
846
+ return { x: box.x + box.width / 2, y: box.y + box.height / 2 };
847
+ }
848
+ if (Number.isFinite(target.x) && Number.isFinite(target.y)) {
849
+ return { x: target.x, y: target.y };
850
+ }
851
+ throw new ToolError("Drag target must be a selector string or { x: number, y: number } point");
852
+ }
853
+
854
+ async #installResponseObserver(): Promise<void> {
855
+ await this.#evalScript<boolean>(RESPONSE_OBSERVER_SCRIPT);
856
+ }
857
+
858
+ async #responseCursor(): Promise<number> {
859
+ const value = await this.#evalScript<unknown>(
860
+ "(() => Math.max(0, ((globalThis.__ompCmuxResponses && globalThis.__ompCmuxResponses.nextId) || 1) - 1))()",
861
+ );
862
+ return numberFrom(value, 0);
863
+ }
864
+
865
+ async #responseRecordsAfter(id: number): Promise<CmuxResponseRecord[]> {
866
+ const value = await this.#evalScript<unknown>(
867
+ `(() => ((globalThis.__ompCmuxResponses && globalThis.__ompCmuxResponses.records) || []).filter(record => record.id > ${JSON.stringify(id)}))()`,
868
+ );
869
+ if (!Array.isArray(value)) return [];
870
+ const records: CmuxResponseRecord[] = [];
871
+ for (const item of value) {
872
+ if (!item || typeof item !== "object") continue;
873
+ const object = item as Record<string, unknown>;
874
+ const headers = object.headers && typeof object.headers === "object" ? object.headers : {};
875
+ records.push({
876
+ id: numberFrom(object.id, 0),
877
+ url: typeof object.url === "string" ? object.url : "",
878
+ status: numberFrom(object.status, 0),
879
+ statusText: typeof object.statusText === "string" ? object.statusText : "",
880
+ headers: Object.fromEntries(
881
+ Object.entries(headers as Record<string, unknown>).map(([key, value]) => [key, String(value)]),
882
+ ),
883
+ body: typeof object.body === "string" ? object.body : "",
884
+ });
885
+ }
886
+ return records;
887
+ }
888
+
889
+ #selectorSpec(selector: string): SelectorSpec {
890
+ const raw = selector;
891
+ let normalized = selector;
892
+ if (normalized.startsWith("p-text/")) normalized = `text/${normalized.slice("p-text/".length)}`;
893
+ else if (normalized.startsWith("p-aria/")) normalized = `aria/${normalized.slice("p-aria/".length)}`;
894
+ else if (normalized.startsWith("p-xpath/")) normalized = `xpath/${normalized.slice("p-xpath/".length)}`;
895
+ else if (normalized.startsWith("p-pierce/")) normalized = `pierce/${normalized.slice("p-pierce/".length)}`;
896
+ const ref = /^@?e(\d+)$/.exec(normalized);
897
+ if (ref) return { kind: "ref", value: ref[1]!, raw, ref: `@e${ref[1]}` };
898
+ const slash = normalized.indexOf("/");
899
+ if (slash > 0) {
900
+ const prefix = normalized.slice(0, slash);
901
+ const value = normalized.slice(slash + 1);
902
+ if (prefix === "text" || prefix === "aria" || prefix === "xpath" || prefix === "pierce") {
903
+ return { kind: prefix, value, raw, name: prefix === "aria" ? value : undefined };
904
+ }
905
+ }
906
+ return { kind: "css", value: normalized, raw };
907
+ }
908
+
909
+ #nativeSelector(spec: SelectorSpec): string | undefined {
910
+ if (spec.kind === "css") return spec.value;
911
+ if (spec.kind === "ref") return spec.ref;
912
+ return undefined;
913
+ }
914
+
915
+ #rememberObservedElements(observation: Observation): void {
916
+ this.#elementRefs.clear();
917
+ for (const element of observation.elements) {
918
+ this.#elementRefs.set(element.id, {
919
+ ref: `@e${element.id}`,
920
+ name: element.name,
921
+ role: element.role,
922
+ });
923
+ }
924
+ }
925
+
926
+ #normalizeGeometry(value: unknown): CmuxGeometry {
927
+ const object = value && typeof value === "object" ? (value as Record<string, unknown>) : {};
928
+ return {
929
+ innerWidth: numberFrom(object.innerWidth, DEFAULT_VIEWPORT.width),
930
+ innerHeight: numberFrom(object.innerHeight, DEFAULT_VIEWPORT.height),
931
+ dpr: numberFrom(object.dpr, DEFAULT_VIEWPORT.deviceScaleFactor ?? 1),
932
+ scrollX: numberFrom(object.scrollX, 0),
933
+ scrollY: numberFrom(object.scrollY, 0),
934
+ scrollWidth: numberFrom(object.scrollWidth, DEFAULT_VIEWPORT.width),
935
+ scrollHeight: numberFrom(object.scrollHeight, DEFAULT_VIEWPORT.height),
936
+ };
937
+ }
938
+
939
+ #requireRunContext(operation: string): RunContext {
940
+ if (!this.#runContext) {
941
+ throw new ToolError(`${operation} requires an active cmux browser run`);
942
+ }
943
+ return this.#runContext;
944
+ }
945
+ }
946
+
947
+ class CmuxResponse {
948
+ readonly #record: CmuxResponseRecord;
949
+
950
+ constructor(record: CmuxResponseRecord) {
951
+ this.#record = record;
952
+ }
953
+
954
+ url(): string {
955
+ return this.#record.url;
956
+ }
957
+
958
+ status(): number {
959
+ return this.#record.status;
960
+ }
961
+
962
+ statusText(): string {
963
+ return this.#record.statusText;
964
+ }
965
+
966
+ headers(): Record<string, string> {
967
+ return { ...this.#record.headers };
968
+ }
969
+
970
+ async text(): Promise<string> {
971
+ return this.#record.body;
972
+ }
973
+
974
+ async json(): Promise<unknown> {
975
+ return JSON.parse(this.#record.body);
976
+ }
977
+ }
978
+
979
+ class CmuxElementHandle {
980
+ readonly #tab: CmuxTab;
981
+ readonly #selector: string;
982
+
983
+ constructor(tab: CmuxTab, selector: string) {
984
+ this.#tab = tab;
985
+ this.#selector = selector;
986
+ }
987
+
988
+ async click(): Promise<void> {
989
+ await this.#tab.click(this.#selector);
990
+ }
991
+
992
+ async type(text: string): Promise<void> {
993
+ await this.#tab.type(this.#selector, text);
994
+ }
995
+
996
+ async fill(value: string): Promise<void> {
997
+ await this.#tab.fill(this.#selector, value);
998
+ }
999
+
1000
+ async focus(): Promise<void> {
1001
+ await this.#tab.focus(this.#selector);
1002
+ }
1003
+
1004
+ async hover(): Promise<void> {
1005
+ await this.#tab.hover(this.#selector);
1006
+ }
1007
+
1008
+ async evaluate<TResult, TArgs extends unknown[]>(
1009
+ fn: (element: unknown, ...args: TArgs) => TResult | Promise<TResult>,
1010
+ ...args: TArgs
1011
+ ): Promise<TResult> {
1012
+ return await this.#tab.evaluateOnSelector<TResult>(this.#selector, fn.toString(), args);
1013
+ }
1014
+
1015
+ async boundingBox(): Promise<BoundingBox | null> {
1016
+ return await this.#tab.elementBox(this.#selector);
1017
+ }
1018
+
1019
+ async uploadFile(...paths: string[]): Promise<void> {
1020
+ await this.#tab.uploadFile(this.#selector, ...paths);
1021
+ }
1022
+
1023
+ async dispose(): Promise<void> {}
1024
+ }
1025
+
1026
+ class CmuxLocator {
1027
+ readonly #tab: CmuxTab;
1028
+ readonly #selector: string;
1029
+ #timeoutMs: number | undefined;
1030
+
1031
+ constructor(tab: CmuxTab, selector: string) {
1032
+ this.#tab = tab;
1033
+ this.#selector = selector;
1034
+ }
1035
+
1036
+ setTimeout(timeoutMs: number): this {
1037
+ this.#timeoutMs = timeoutMs;
1038
+ return this;
1039
+ }
1040
+
1041
+ async click(): Promise<void> {
1042
+ await this.#tab.waitFor(this.#selector, { timeout: this.#timeoutMs });
1043
+ await this.#tab.click(this.#selector);
1044
+ }
1045
+
1046
+ async fill(value: string): Promise<void> {
1047
+ await this.#tab.waitFor(this.#selector, { timeout: this.#timeoutMs });
1048
+ await this.#tab.fill(this.#selector, value);
1049
+ }
1050
+
1051
+ async waitHandle(): Promise<CmuxElementHandle> {
1052
+ return await this.#tab.waitFor(this.#selector, { timeout: this.#timeoutMs });
1053
+ }
1054
+ }
1055
+
1056
+ class CmuxPageFacade {
1057
+ readonly #tab: CmuxTab;
1058
+ readonly keyboard: { press: (key: string) => Promise<void> };
1059
+ readonly mouse: {
1060
+ wheel: (delta: { deltaX?: number; deltaY?: number }) => Promise<void>;
1061
+ move: (x: number, y: number) => Promise<void>;
1062
+ down: () => Promise<void>;
1063
+ up: () => Promise<void>;
1064
+ };
1065
+
1066
+ constructor(tab: CmuxTab) {
1067
+ this.#tab = tab;
1068
+ this.keyboard = { press: key => this.#tab.press(key) };
1069
+ let lastPoint = { x: 0, y: 0 };
1070
+ let dragStart: { x: number; y: number } | undefined;
1071
+ this.mouse = {
1072
+ wheel: delta => this.#tab.scroll(delta.deltaX ?? 0, delta.deltaY ?? 0),
1073
+ move: (x, y) => {
1074
+ lastPoint = { x, y };
1075
+ return Promise.resolve();
1076
+ },
1077
+ down: () => {
1078
+ dragStart = lastPoint;
1079
+ return Promise.resolve();
1080
+ },
1081
+ up: async () => {
1082
+ if (dragStart) await this.#tab.drag(dragStart, lastPoint);
1083
+ dragStart = undefined;
1084
+ },
1085
+ };
1086
+ }
1087
+
1088
+ url(): string {
1089
+ return this.#tab.url();
1090
+ }
1091
+
1092
+ async title(): Promise<string> {
1093
+ return await this.#tab.title();
1094
+ }
1095
+
1096
+ viewport(): ReadyInfo["viewport"] {
1097
+ return this.#tab.viewport();
1098
+ }
1099
+
1100
+ async setViewport(viewport: ViewportOptions): Promise<void> {
1101
+ await this.#tab.setViewport(viewport);
1102
+ }
1103
+
1104
+ async goto(url: string, opts?: { waitUntil?: WaitUntil; timeout?: number }): Promise<{ url: string }> {
1105
+ await this.#tab.goto(url, { waitUntil: opts?.waitUntil, timeoutMs: opts?.timeout });
1106
+ return { url: this.#tab.url() };
1107
+ }
1108
+
1109
+ async evaluate<TResult, TArgs extends unknown[]>(
1110
+ fn: string | ((...args: TArgs) => TResult | Promise<TResult>),
1111
+ ...args: TArgs
1112
+ ): Promise<TResult> {
1113
+ return await this.#tab.evaluate(fn, ...args);
1114
+ }
1115
+
1116
+ async content(): Promise<string> {
1117
+ return await this.#tab.pageContent();
1118
+ }
1119
+
1120
+ locator(selector: string): CmuxLocator {
1121
+ return new CmuxLocator(this.#tab, selector);
1122
+ }
1123
+
1124
+ async $(selector: string): Promise<CmuxElementHandle | null> {
1125
+ return (await this.#tab.elementExists(selector)) ? this.#tab.elementHandle(selector) : null;
1126
+ }
1127
+
1128
+ async waitForSelector(selector: string, opts?: { timeout?: number }): Promise<CmuxElementHandle> {
1129
+ return await this.#tab.waitFor(selector, opts);
1130
+ }
1131
+
1132
+ async waitForFunction(
1133
+ fn: string | ((...args: unknown[]) => unknown | Promise<unknown>),
1134
+ opts?: { timeout?: number; polling?: number },
1135
+ ...args: unknown[]
1136
+ ): Promise<unknown> {
1137
+ return await this.#tab.waitForFunction(fn, opts, ...args);
1138
+ }
1139
+
1140
+ async waitForResponse(
1141
+ pattern: string | RegExp | ((response: CmuxResponse) => boolean | Promise<boolean>),
1142
+ opts?: { timeout?: number },
1143
+ ): Promise<CmuxResponse> {
1144
+ return await this.#tab.waitForResponse(pattern, opts);
1145
+ }
1146
+
1147
+ async screenshot(opts: ScreenshotOptions = {}): Promise<Buffer | string> {
1148
+ return await this.#tab.pageScreenshot(opts);
1149
+ }
1150
+ }
1151
+
1152
+ class CmuxBrowserFacade {
1153
+ readonly #tab: CmuxTab;
1154
+ connected = true;
1155
+
1156
+ constructor(tab: CmuxTab) {
1157
+ this.#tab = tab;
1158
+ }
1159
+
1160
+ async pages(): Promise<CmuxPageFacade[]> {
1161
+ return [this.#tab.page];
1162
+ }
1163
+
1164
+ async version(): Promise<string> {
1165
+ return "cmux";
1166
+ }
1167
+
1168
+ wsEndpoint(): string {
1169
+ return `cmux://${this.#tab.surfaceId}`;
1170
+ }
1171
+
1172
+ disconnect(): void {
1173
+ this.connected = false;
1174
+ }
1175
+
1176
+ async close(): Promise<void> {
1177
+ this.connected = false;
1178
+ }
1179
+ }
1180
+
1181
+ export async function runCmuxCode(tab: CmuxTab, opts: RunCmuxCodeOptions): Promise<RunResultOk> {
1182
+ const timeoutSignal = AbortSignal.timeout(opts.timeoutMs);
1183
+ const signal = opts.signal ? AbortSignal.any([timeoutSignal, opts.signal]) : timeoutSignal;
1184
+ const displays: RunResultOk["displays"] = [];
1185
+ const screenshots: ScreenshotResult[] = [];
1186
+ const runId = crypto.randomUUID();
1187
+ tab.setRunContext({ session: opts.snapshot, displays, screenshots, signal, timeoutMs: opts.timeoutMs });
1188
+ const runtime = tab.ensureRuntime(opts.snapshot);
1189
+ runtime.setCwd(opts.snapshot.cwd);
1190
+ runtime.setRunScope({
1191
+ page: tab.page,
1192
+ browser: tab.browser,
1193
+ tab,
1194
+ assert: (cond: unknown, text?: string): void => {
1195
+ if (!cond) throw new ToolError(text ?? "Assertion failed");
1196
+ },
1197
+ wait: (ms: number): Promise<void> => Bun.sleep(ms),
1198
+ });
1199
+
1200
+ const { promise: cancelRejection, reject } = Promise.withResolvers<never>();
1201
+ const onAbort = (): void => {
1202
+ if (timeoutSignal.aborted) {
1203
+ reject(new ToolError(`Browser code execution timed out after ${opts.timeoutMs}ms`));
1204
+ } else {
1205
+ reject(new ToolAbortError());
1206
+ }
1207
+ };
1208
+ if (signal.aborted) onAbort();
1209
+ else signal.addEventListener("abort", onAbort, { once: true });
1210
+
1211
+ try {
1212
+ const hooks: RuntimeHooks = {
1213
+ onText: chunk => logger.debug(chunk.replace(/\n$/, "")),
1214
+ onDisplay: output => pushDisplay(displays, output),
1215
+ callTool: (name, args) => callSessionTool(name, args, { session: opts.session, signal }),
1216
+ };
1217
+ // Like the inline worker fallback, cmux runs user JS in-process: awaited cmux/tool calls
1218
+ // observe this abort signal, but a synchronous infinite loop cannot be interrupted here.
1219
+ const returnValue = await Promise.race([
1220
+ runtime.run(opts.code, `cmux-run-${runId}.js`, hooks, { runId, cwd: opts.snapshot.cwd }),
1221
+ cancelRejection,
1222
+ ]);
1223
+ return { displays, returnValue: cloneSafe(returnValue), screenshots };
1224
+ } finally {
1225
+ signal.removeEventListener("abort", onAbort);
1226
+ tab.clearRunContext();
1227
+ }
1228
+ }
1229
+
1230
+ function pushDisplay(displays: RunResultOk["displays"], output: JsDisplayOutput): void {
1231
+ if (output.type === "image") {
1232
+ displays.push({ type: "image", data: output.data, mimeType: output.mimeType });
1233
+ return;
1234
+ }
1235
+ if (output.type === "json") {
1236
+ displays.push({ type: "text", text: safeJsonStringify(output.data) });
1237
+ return;
1238
+ }
1239
+ displays.push({ type: "text", text: safeJsonStringify(output.event) });
1240
+ }
1241
+
1242
+ function safeJsonStringify(value: unknown): string {
1243
+ try {
1244
+ return JSON.stringify(value, null, 2);
1245
+ } catch {
1246
+ return String(value);
1247
+ }
1248
+ }
1249
+
1250
+ function cloneSafe(value: unknown): unknown {
1251
+ if (value === undefined) return undefined;
1252
+ try {
1253
+ structuredClone(value);
1254
+ return value;
1255
+ } catch {}
1256
+ try {
1257
+ return JSON.parse(JSON.stringify(value)) as unknown;
1258
+ } catch {}
1259
+ return String(value);
1260
+ }
1261
+
1262
+ function numberFrom(value: unknown, fallback: number): number {
1263
+ return typeof value === "number" && Number.isFinite(value) ? value : fallback;
1264
+ }