@lenylvt/pi-coding-agent 0.64.0

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (770) hide show
  1. package/CHANGELOG.md +3331 -0
  2. package/README.md +48 -0
  3. package/dist/bun/cli.d.ts +3 -0
  4. package/dist/bun/cli.d.ts.map +1 -0
  5. package/dist/bun/cli.js +5 -0
  6. package/dist/bun/cli.js.map +1 -0
  7. package/dist/cli/args.d.ts +49 -0
  8. package/dist/cli/args.d.ts.map +1 -0
  9. package/dist/cli/args.js +292 -0
  10. package/dist/cli/args.js.map +1 -0
  11. package/dist/cli/config-selector.d.ts +14 -0
  12. package/dist/cli/config-selector.d.ts.map +1 -0
  13. package/dist/cli/config-selector.js +31 -0
  14. package/dist/cli/config-selector.js.map +1 -0
  15. package/dist/cli/file-processor.d.ts +15 -0
  16. package/dist/cli/file-processor.d.ts.map +1 -0
  17. package/dist/cli/file-processor.js +83 -0
  18. package/dist/cli/file-processor.js.map +1 -0
  19. package/dist/cli/initial-message.d.ts +18 -0
  20. package/dist/cli/initial-message.d.ts.map +1 -0
  21. package/dist/cli/initial-message.js +22 -0
  22. package/dist/cli/initial-message.js.map +1 -0
  23. package/dist/cli/list-models.d.ts +9 -0
  24. package/dist/cli/list-models.d.ts.map +1 -0
  25. package/dist/cli/list-models.js +92 -0
  26. package/dist/cli/list-models.js.map +1 -0
  27. package/dist/cli/session-picker.d.ts +9 -0
  28. package/dist/cli/session-picker.d.ts.map +1 -0
  29. package/dist/cli/session-picker.js +35 -0
  30. package/dist/cli/session-picker.js.map +1 -0
  31. package/dist/cli.d.ts +3 -0
  32. package/dist/cli.d.ts.map +1 -0
  33. package/dist/cli.js +14 -0
  34. package/dist/cli.js.map +1 -0
  35. package/dist/config.d.ts +69 -0
  36. package/dist/config.d.ts.map +1 -0
  37. package/dist/config.js +178 -0
  38. package/dist/config.js.map +1 -0
  39. package/dist/core/agent-session.d.ts +622 -0
  40. package/dist/core/agent-session.d.ts.map +1 -0
  41. package/dist/core/agent-session.js +2688 -0
  42. package/dist/core/agent-session.js.map +1 -0
  43. package/dist/core/auth-storage.d.ts +132 -0
  44. package/dist/core/auth-storage.d.ts.map +1 -0
  45. package/dist/core/auth-storage.js +422 -0
  46. package/dist/core/auth-storage.js.map +1 -0
  47. package/dist/core/bash-executor.d.ts +46 -0
  48. package/dist/core/bash-executor.d.ts.map +1 -0
  49. package/dist/core/bash-executor.js +113 -0
  50. package/dist/core/bash-executor.js.map +1 -0
  51. package/dist/core/compaction/branch-summarization.d.ts +88 -0
  52. package/dist/core/compaction/branch-summarization.d.ts.map +1 -0
  53. package/dist/core/compaction/branch-summarization.js +243 -0
  54. package/dist/core/compaction/branch-summarization.js.map +1 -0
  55. package/dist/core/compaction/compaction.d.ts +121 -0
  56. package/dist/core/compaction/compaction.d.ts.map +1 -0
  57. package/dist/core/compaction/compaction.js +613 -0
  58. package/dist/core/compaction/compaction.js.map +1 -0
  59. package/dist/core/compaction/index.d.ts +7 -0
  60. package/dist/core/compaction/index.d.ts.map +1 -0
  61. package/dist/core/compaction/index.js +7 -0
  62. package/dist/core/compaction/index.js.map +1 -0
  63. package/dist/core/compaction/utils.d.ts +38 -0
  64. package/dist/core/compaction/utils.d.ts.map +1 -0
  65. package/dist/core/compaction/utils.js +153 -0
  66. package/dist/core/compaction/utils.js.map +1 -0
  67. package/dist/core/defaults.d.ts +3 -0
  68. package/dist/core/defaults.d.ts.map +1 -0
  69. package/dist/core/defaults.js +2 -0
  70. package/dist/core/defaults.js.map +1 -0
  71. package/dist/core/diagnostics.d.ts +15 -0
  72. package/dist/core/diagnostics.d.ts.map +1 -0
  73. package/dist/core/diagnostics.js +2 -0
  74. package/dist/core/diagnostics.js.map +1 -0
  75. package/dist/core/event-bus.d.ts +9 -0
  76. package/dist/core/event-bus.d.ts.map +1 -0
  77. package/dist/core/event-bus.js +25 -0
  78. package/dist/core/event-bus.js.map +1 -0
  79. package/dist/core/exec.d.ts +29 -0
  80. package/dist/core/exec.d.ts.map +1 -0
  81. package/dist/core/exec.js +75 -0
  82. package/dist/core/exec.js.map +1 -0
  83. package/dist/core/export-html/ansi-to-html.d.ts +22 -0
  84. package/dist/core/export-html/ansi-to-html.d.ts.map +1 -0
  85. package/dist/core/export-html/ansi-to-html.js +249 -0
  86. package/dist/core/export-html/ansi-to-html.js.map +1 -0
  87. package/dist/core/export-html/index.d.ts +37 -0
  88. package/dist/core/export-html/index.d.ts.map +1 -0
  89. package/dist/core/export-html/index.js +224 -0
  90. package/dist/core/export-html/index.js.map +1 -0
  91. package/dist/core/export-html/template.css +1001 -0
  92. package/dist/core/export-html/template.html +55 -0
  93. package/dist/core/export-html/template.js +1690 -0
  94. package/dist/core/export-html/tool-renderer.d.ts +38 -0
  95. package/dist/core/export-html/tool-renderer.d.ts.map +1 -0
  96. package/dist/core/export-html/tool-renderer.js +95 -0
  97. package/dist/core/export-html/tool-renderer.js.map +1 -0
  98. package/dist/core/export-html/vendor/highlight.min.js +1213 -0
  99. package/dist/core/export-html/vendor/marked.min.js +6 -0
  100. package/dist/core/extensions/index.d.ts +12 -0
  101. package/dist/core/extensions/index.d.ts.map +1 -0
  102. package/dist/core/extensions/index.js +9 -0
  103. package/dist/core/extensions/index.js.map +1 -0
  104. package/dist/core/extensions/loader.d.ts +25 -0
  105. package/dist/core/extensions/loader.d.ts.map +1 -0
  106. package/dist/core/extensions/loader.js +436 -0
  107. package/dist/core/extensions/loader.js.map +1 -0
  108. package/dist/core/extensions/runner.d.ts +148 -0
  109. package/dist/core/extensions/runner.d.ts.map +1 -0
  110. package/dist/core/extensions/runner.js +700 -0
  111. package/dist/core/extensions/runner.js.map +1 -0
  112. package/dist/core/extensions/types.d.ts +1085 -0
  113. package/dist/core/extensions/types.d.ts.map +1 -0
  114. package/dist/core/extensions/types.js +35 -0
  115. package/dist/core/extensions/types.js.map +1 -0
  116. package/dist/core/extensions/wrapper.d.ts +20 -0
  117. package/dist/core/extensions/wrapper.d.ts.map +1 -0
  118. package/dist/core/extensions/wrapper.js +22 -0
  119. package/dist/core/extensions/wrapper.js.map +1 -0
  120. package/dist/core/footer-data-provider.d.ts +44 -0
  121. package/dist/core/footer-data-provider.d.ts.map +1 -0
  122. package/dist/core/footer-data-provider.js +252 -0
  123. package/dist/core/footer-data-provider.js.map +1 -0
  124. package/dist/core/index.d.ts +10 -0
  125. package/dist/core/index.d.ts.map +1 -0
  126. package/dist/core/index.js +10 -0
  127. package/dist/core/index.js.map +1 -0
  128. package/dist/core/keybindings.d.ts +275 -0
  129. package/dist/core/keybindings.d.ts.map +1 -0
  130. package/dist/core/keybindings.js +241 -0
  131. package/dist/core/keybindings.js.map +1 -0
  132. package/dist/core/messages.d.ts +77 -0
  133. package/dist/core/messages.d.ts.map +1 -0
  134. package/dist/core/messages.js +123 -0
  135. package/dist/core/messages.js.map +1 -0
  136. package/dist/core/model-registry.d.ts +132 -0
  137. package/dist/core/model-registry.d.ts.map +1 -0
  138. package/dist/core/model-registry.js +565 -0
  139. package/dist/core/model-registry.js.map +1 -0
  140. package/dist/core/model-resolver.d.ts +110 -0
  141. package/dist/core/model-resolver.d.ts.map +1 -0
  142. package/dist/core/model-resolver.js +464 -0
  143. package/dist/core/model-resolver.js.map +1 -0
  144. package/dist/core/output-guard.d.ts +6 -0
  145. package/dist/core/output-guard.d.ts.map +1 -0
  146. package/dist/core/output-guard.js +59 -0
  147. package/dist/core/output-guard.js.map +1 -0
  148. package/dist/core/package-manager.d.ts +172 -0
  149. package/dist/core/package-manager.d.ts.map +1 -0
  150. package/dist/core/package-manager.js +1801 -0
  151. package/dist/core/package-manager.js.map +1 -0
  152. package/dist/core/prompt-templates.d.ts +51 -0
  153. package/dist/core/prompt-templates.d.ts.map +1 -0
  154. package/dist/core/prompt-templates.js +249 -0
  155. package/dist/core/prompt-templates.js.map +1 -0
  156. package/dist/core/resolve-config-value.d.ts +23 -0
  157. package/dist/core/resolve-config-value.d.ts.map +1 -0
  158. package/dist/core/resolve-config-value.js +126 -0
  159. package/dist/core/resolve-config-value.js.map +1 -0
  160. package/dist/core/resource-loader.d.ts +185 -0
  161. package/dist/core/resource-loader.d.ts.map +1 -0
  162. package/dist/core/resource-loader.js +698 -0
  163. package/dist/core/resource-loader.js.map +1 -0
  164. package/dist/core/sdk.d.ts +90 -0
  165. package/dist/core/sdk.d.ts.map +1 -0
  166. package/dist/core/sdk.js +233 -0
  167. package/dist/core/sdk.js.map +1 -0
  168. package/dist/core/self-update.d.ts +3 -0
  169. package/dist/core/self-update.d.ts.map +1 -0
  170. package/dist/core/self-update.js +46 -0
  171. package/dist/core/self-update.js.map +1 -0
  172. package/dist/core/session-manager.d.ts +329 -0
  173. package/dist/core/session-manager.d.ts.map +1 -0
  174. package/dist/core/session-manager.js +1097 -0
  175. package/dist/core/session-manager.js.map +1 -0
  176. package/dist/core/settings-manager.d.ts +237 -0
  177. package/dist/core/settings-manager.d.ts.map +1 -0
  178. package/dist/core/settings-manager.js +708 -0
  179. package/dist/core/settings-manager.js.map +1 -0
  180. package/dist/core/skills.d.ts +60 -0
  181. package/dist/core/skills.d.ts.map +1 -0
  182. package/dist/core/skills.js +409 -0
  183. package/dist/core/skills.js.map +1 -0
  184. package/dist/core/slash-commands.d.ts +14 -0
  185. package/dist/core/slash-commands.d.ts.map +1 -0
  186. package/dist/core/slash-commands.js +22 -0
  187. package/dist/core/slash-commands.js.map +1 -0
  188. package/dist/core/source-info.d.ts +18 -0
  189. package/dist/core/source-info.d.ts.map +1 -0
  190. package/dist/core/source-info.js +19 -0
  191. package/dist/core/source-info.js.map +1 -0
  192. package/dist/core/system-prompt.d.ts +28 -0
  193. package/dist/core/system-prompt.d.ts.map +1 -0
  194. package/dist/core/system-prompt.js +116 -0
  195. package/dist/core/system-prompt.js.map +1 -0
  196. package/dist/core/timings.d.ts +8 -0
  197. package/dist/core/timings.d.ts.map +1 -0
  198. package/dist/core/timings.js +31 -0
  199. package/dist/core/timings.js.map +1 -0
  200. package/dist/core/tools/bash.d.ts +73 -0
  201. package/dist/core/tools/bash.d.ts.map +1 -0
  202. package/dist/core/tools/bash.js +342 -0
  203. package/dist/core/tools/bash.js.map +1 -0
  204. package/dist/core/tools/edit-diff.d.ts +85 -0
  205. package/dist/core/tools/edit-diff.d.ts.map +1 -0
  206. package/dist/core/tools/edit-diff.js +337 -0
  207. package/dist/core/tools/edit-diff.js.map +1 -0
  208. package/dist/core/tools/edit.d.ts +53 -0
  209. package/dist/core/tools/edit.d.ts.map +1 -0
  210. package/dist/core/tools/edit.js +196 -0
  211. package/dist/core/tools/edit.js.map +1 -0
  212. package/dist/core/tools/file-mutation-queue.d.ts +6 -0
  213. package/dist/core/tools/file-mutation-queue.d.ts.map +1 -0
  214. package/dist/core/tools/file-mutation-queue.js +37 -0
  215. package/dist/core/tools/file-mutation-queue.js.map +1 -0
  216. package/dist/core/tools/find.d.ts +46 -0
  217. package/dist/core/tools/find.d.ts.map +1 -0
  218. package/dist/core/tools/find.js +258 -0
  219. package/dist/core/tools/find.js.map +1 -0
  220. package/dist/core/tools/grep.d.ts +56 -0
  221. package/dist/core/tools/grep.d.ts.map +1 -0
  222. package/dist/core/tools/grep.js +293 -0
  223. package/dist/core/tools/grep.js.map +1 -0
  224. package/dist/core/tools/index.d.ts +115 -0
  225. package/dist/core/tools/index.d.ts.map +1 -0
  226. package/dist/core/tools/index.js +86 -0
  227. package/dist/core/tools/index.js.map +1 -0
  228. package/dist/core/tools/ls.d.ts +46 -0
  229. package/dist/core/tools/ls.d.ts.map +1 -0
  230. package/dist/core/tools/ls.js +172 -0
  231. package/dist/core/tools/ls.js.map +1 -0
  232. package/dist/core/tools/path-utils.d.ts +8 -0
  233. package/dist/core/tools/path-utils.d.ts.map +1 -0
  234. package/dist/core/tools/path-utils.js +81 -0
  235. package/dist/core/tools/path-utils.js.map +1 -0
  236. package/dist/core/tools/read.d.ts +46 -0
  237. package/dist/core/tools/read.d.ts.map +1 -0
  238. package/dist/core/tools/read.js +225 -0
  239. package/dist/core/tools/read.js.map +1 -0
  240. package/dist/core/tools/render-utils.d.ts +21 -0
  241. package/dist/core/tools/render-utils.d.ts.map +1 -0
  242. package/dist/core/tools/render-utils.js +49 -0
  243. package/dist/core/tools/render-utils.js.map +1 -0
  244. package/dist/core/tools/tool-definition-wrapper.d.ts +14 -0
  245. package/dist/core/tools/tool-definition-wrapper.d.ts.map +1 -0
  246. package/dist/core/tools/tool-definition-wrapper.js +32 -0
  247. package/dist/core/tools/tool-definition-wrapper.js.map +1 -0
  248. package/dist/core/tools/truncate.d.ts +70 -0
  249. package/dist/core/tools/truncate.d.ts.map +1 -0
  250. package/dist/core/tools/truncate.js +205 -0
  251. package/dist/core/tools/truncate.js.map +1 -0
  252. package/dist/core/tools/write.d.ts +35 -0
  253. package/dist/core/tools/write.d.ts.map +1 -0
  254. package/dist/core/tools/write.js +216 -0
  255. package/dist/core/tools/write.js.map +1 -0
  256. package/dist/core/version-check.d.ts +2 -0
  257. package/dist/core/version-check.d.ts.map +1 -0
  258. package/dist/core/version-check.js +73 -0
  259. package/dist/core/version-check.js.map +1 -0
  260. package/dist/index.d.ts +28 -0
  261. package/dist/index.d.ts.map +1 -0
  262. package/dist/index.js +43 -0
  263. package/dist/index.js.map +1 -0
  264. package/dist/main.d.ts +8 -0
  265. package/dist/main.d.ts.map +1 -0
  266. package/dist/main.js +811 -0
  267. package/dist/main.js.map +1 -0
  268. package/dist/migrations.d.ts +32 -0
  269. package/dist/migrations.d.ts.map +1 -0
  270. package/dist/migrations.js +258 -0
  271. package/dist/migrations.js.map +1 -0
  272. package/dist/modes/index.d.ts +9 -0
  273. package/dist/modes/index.d.ts.map +1 -0
  274. package/dist/modes/index.js +8 -0
  275. package/dist/modes/index.js.map +1 -0
  276. package/dist/modes/interactive/components/armin.d.ts +34 -0
  277. package/dist/modes/interactive/components/armin.d.ts.map +1 -0
  278. package/dist/modes/interactive/components/armin.js +333 -0
  279. package/dist/modes/interactive/components/armin.js.map +1 -0
  280. package/dist/modes/interactive/components/assistant-message.d.ts +18 -0
  281. package/dist/modes/interactive/components/assistant-message.d.ts.map +1 -0
  282. package/dist/modes/interactive/components/assistant-message.js +107 -0
  283. package/dist/modes/interactive/components/assistant-message.js.map +1 -0
  284. package/dist/modes/interactive/components/bash-execution.d.ts +34 -0
  285. package/dist/modes/interactive/components/bash-execution.d.ts.map +1 -0
  286. package/dist/modes/interactive/components/bash-execution.js +175 -0
  287. package/dist/modes/interactive/components/bash-execution.js.map +1 -0
  288. package/dist/modes/interactive/components/bordered-loader.d.ts +16 -0
  289. package/dist/modes/interactive/components/bordered-loader.d.ts.map +1 -0
  290. package/dist/modes/interactive/components/bordered-loader.js +51 -0
  291. package/dist/modes/interactive/components/bordered-loader.js.map +1 -0
  292. package/dist/modes/interactive/components/branch-summary-message.d.ts +16 -0
  293. package/dist/modes/interactive/components/branch-summary-message.d.ts.map +1 -0
  294. package/dist/modes/interactive/components/branch-summary-message.js +44 -0
  295. package/dist/modes/interactive/components/branch-summary-message.js.map +1 -0
  296. package/dist/modes/interactive/components/compaction-summary-message.d.ts +16 -0
  297. package/dist/modes/interactive/components/compaction-summary-message.d.ts.map +1 -0
  298. package/dist/modes/interactive/components/compaction-summary-message.js +45 -0
  299. package/dist/modes/interactive/components/compaction-summary-message.js.map +1 -0
  300. package/dist/modes/interactive/components/config-selector.d.ts +71 -0
  301. package/dist/modes/interactive/components/config-selector.d.ts.map +1 -0
  302. package/dist/modes/interactive/components/config-selector.js +479 -0
  303. package/dist/modes/interactive/components/config-selector.js.map +1 -0
  304. package/dist/modes/interactive/components/countdown-timer.d.ts +14 -0
  305. package/dist/modes/interactive/components/countdown-timer.d.ts.map +1 -0
  306. package/dist/modes/interactive/components/countdown-timer.js +33 -0
  307. package/dist/modes/interactive/components/countdown-timer.js.map +1 -0
  308. package/dist/modes/interactive/components/custom-editor.d.ts +21 -0
  309. package/dist/modes/interactive/components/custom-editor.d.ts.map +1 -0
  310. package/dist/modes/interactive/components/custom-editor.js +70 -0
  311. package/dist/modes/interactive/components/custom-editor.js.map +1 -0
  312. package/dist/modes/interactive/components/custom-message.d.ts +20 -0
  313. package/dist/modes/interactive/components/custom-message.d.ts.map +1 -0
  314. package/dist/modes/interactive/components/custom-message.js +79 -0
  315. package/dist/modes/interactive/components/custom-message.js.map +1 -0
  316. package/dist/modes/interactive/components/diff.d.ts +12 -0
  317. package/dist/modes/interactive/components/diff.d.ts.map +1 -0
  318. package/dist/modes/interactive/components/diff.js +133 -0
  319. package/dist/modes/interactive/components/diff.js.map +1 -0
  320. package/dist/modes/interactive/components/dynamic-border.d.ts +15 -0
  321. package/dist/modes/interactive/components/dynamic-border.d.ts.map +1 -0
  322. package/dist/modes/interactive/components/dynamic-border.js +21 -0
  323. package/dist/modes/interactive/components/dynamic-border.js.map +1 -0
  324. package/dist/modes/interactive/components/extension-editor.d.ts +20 -0
  325. package/dist/modes/interactive/components/extension-editor.d.ts.map +1 -0
  326. package/dist/modes/interactive/components/extension-editor.js +111 -0
  327. package/dist/modes/interactive/components/extension-editor.js.map +1 -0
  328. package/dist/modes/interactive/components/extension-input.d.ts +23 -0
  329. package/dist/modes/interactive/components/extension-input.d.ts.map +1 -0
  330. package/dist/modes/interactive/components/extension-input.js +61 -0
  331. package/dist/modes/interactive/components/extension-input.js.map +1 -0
  332. package/dist/modes/interactive/components/extension-selector.d.ts +24 -0
  333. package/dist/modes/interactive/components/extension-selector.d.ts.map +1 -0
  334. package/dist/modes/interactive/components/extension-selector.js +78 -0
  335. package/dist/modes/interactive/components/extension-selector.js.map +1 -0
  336. package/dist/modes/interactive/components/footer.d.ts +26 -0
  337. package/dist/modes/interactive/components/footer.d.ts.map +1 -0
  338. package/dist/modes/interactive/components/footer.js +198 -0
  339. package/dist/modes/interactive/components/footer.js.map +1 -0
  340. package/dist/modes/interactive/components/index.d.ts +31 -0
  341. package/dist/modes/interactive/components/index.d.ts.map +1 -0
  342. package/dist/modes/interactive/components/index.js +32 -0
  343. package/dist/modes/interactive/components/index.js.map +1 -0
  344. package/dist/modes/interactive/components/keybinding-hints.d.ts +8 -0
  345. package/dist/modes/interactive/components/keybinding-hints.d.ts.map +1 -0
  346. package/dist/modes/interactive/components/keybinding-hints.js +22 -0
  347. package/dist/modes/interactive/components/keybinding-hints.js.map +1 -0
  348. package/dist/modes/interactive/components/login-dialog.d.ts +42 -0
  349. package/dist/modes/interactive/components/login-dialog.d.ts.map +1 -0
  350. package/dist/modes/interactive/components/login-dialog.js +145 -0
  351. package/dist/modes/interactive/components/login-dialog.js.map +1 -0
  352. package/dist/modes/interactive/components/model-selector.d.ts +47 -0
  353. package/dist/modes/interactive/components/model-selector.d.ts.map +1 -0
  354. package/dist/modes/interactive/components/model-selector.js +275 -0
  355. package/dist/modes/interactive/components/model-selector.js.map +1 -0
  356. package/dist/modes/interactive/components/oauth-selector.d.ts +19 -0
  357. package/dist/modes/interactive/components/oauth-selector.d.ts.map +1 -0
  358. package/dist/modes/interactive/components/oauth-selector.js +97 -0
  359. package/dist/modes/interactive/components/oauth-selector.js.map +1 -0
  360. package/dist/modes/interactive/components/scoped-models-selector.d.ts +49 -0
  361. package/dist/modes/interactive/components/scoped-models-selector.d.ts.map +1 -0
  362. package/dist/modes/interactive/components/scoped-models-selector.js +275 -0
  363. package/dist/modes/interactive/components/scoped-models-selector.js.map +1 -0
  364. package/dist/modes/interactive/components/session-selector-search.d.ts +23 -0
  365. package/dist/modes/interactive/components/session-selector-search.d.ts.map +1 -0
  366. package/dist/modes/interactive/components/session-selector-search.js +155 -0
  367. package/dist/modes/interactive/components/session-selector-search.js.map +1 -0
  368. package/dist/modes/interactive/components/session-selector.d.ts +95 -0
  369. package/dist/modes/interactive/components/session-selector.d.ts.map +1 -0
  370. package/dist/modes/interactive/components/session-selector.js +848 -0
  371. package/dist/modes/interactive/components/session-selector.js.map +1 -0
  372. package/dist/modes/interactive/components/settings-selector.d.ts +58 -0
  373. package/dist/modes/interactive/components/settings-selector.d.ts.map +1 -0
  374. package/dist/modes/interactive/components/settings-selector.js +301 -0
  375. package/dist/modes/interactive/components/settings-selector.js.map +1 -0
  376. package/dist/modes/interactive/components/show-images-selector.d.ts +10 -0
  377. package/dist/modes/interactive/components/show-images-selector.d.ts.map +1 -0
  378. package/dist/modes/interactive/components/show-images-selector.js +39 -0
  379. package/dist/modes/interactive/components/show-images-selector.js.map +1 -0
  380. package/dist/modes/interactive/components/skill-invocation-message.d.ts +17 -0
  381. package/dist/modes/interactive/components/skill-invocation-message.d.ts.map +1 -0
  382. package/dist/modes/interactive/components/skill-invocation-message.js +47 -0
  383. package/dist/modes/interactive/components/skill-invocation-message.js.map +1 -0
  384. package/dist/modes/interactive/components/theme-selector.d.ts +11 -0
  385. package/dist/modes/interactive/components/theme-selector.d.ts.map +1 -0
  386. package/dist/modes/interactive/components/theme-selector.js +50 -0
  387. package/dist/modes/interactive/components/theme-selector.js.map +1 -0
  388. package/dist/modes/interactive/components/thinking-selector.d.ts +11 -0
  389. package/dist/modes/interactive/components/thinking-selector.d.ts.map +1 -0
  390. package/dist/modes/interactive/components/thinking-selector.js +51 -0
  391. package/dist/modes/interactive/components/thinking-selector.js.map +1 -0
  392. package/dist/modes/interactive/components/tool-execution.d.ts +58 -0
  393. package/dist/modes/interactive/components/tool-execution.d.ts.map +1 -0
  394. package/dist/modes/interactive/components/tool-execution.js +274 -0
  395. package/dist/modes/interactive/components/tool-execution.js.map +1 -0
  396. package/dist/modes/interactive/components/tree-selector.d.ts +87 -0
  397. package/dist/modes/interactive/components/tree-selector.d.ts.map +1 -0
  398. package/dist/modes/interactive/components/tree-selector.js +1051 -0
  399. package/dist/modes/interactive/components/tree-selector.js.map +1 -0
  400. package/dist/modes/interactive/components/user-message-selector.d.ts +30 -0
  401. package/dist/modes/interactive/components/user-message-selector.d.ts.map +1 -0
  402. package/dist/modes/interactive/components/user-message-selector.js +113 -0
  403. package/dist/modes/interactive/components/user-message-selector.js.map +1 -0
  404. package/dist/modes/interactive/components/user-message.d.ts +9 -0
  405. package/dist/modes/interactive/components/user-message.d.ts.map +1 -0
  406. package/dist/modes/interactive/components/user-message.js +28 -0
  407. package/dist/modes/interactive/components/user-message.js.map +1 -0
  408. package/dist/modes/interactive/components/visual-truncate.d.ts +24 -0
  409. package/dist/modes/interactive/components/visual-truncate.d.ts.map +1 -0
  410. package/dist/modes/interactive/components/visual-truncate.js +33 -0
  411. package/dist/modes/interactive/components/visual-truncate.js.map +1 -0
  412. package/dist/modes/interactive/interactive-mode.d.ts +311 -0
  413. package/dist/modes/interactive/interactive-mode.d.ts.map +1 -0
  414. package/dist/modes/interactive/interactive-mode.js +3798 -0
  415. package/dist/modes/interactive/interactive-mode.js.map +1 -0
  416. package/dist/modes/interactive/theme/dark.json +85 -0
  417. package/dist/modes/interactive/theme/light.json +84 -0
  418. package/dist/modes/interactive/theme/theme-schema.json +335 -0
  419. package/dist/modes/interactive/theme/theme.d.ts +81 -0
  420. package/dist/modes/interactive/theme/theme.d.ts.map +1 -0
  421. package/dist/modes/interactive/theme/theme.js +975 -0
  422. package/dist/modes/interactive/theme/theme.js.map +1 -0
  423. package/dist/modes/print-mode.d.ts +28 -0
  424. package/dist/modes/print-mode.d.ts.map +1 -0
  425. package/dist/modes/print-mode.js +107 -0
  426. package/dist/modes/print-mode.js.map +1 -0
  427. package/dist/modes/rpc/jsonl.d.ts +17 -0
  428. package/dist/modes/rpc/jsonl.d.ts.map +1 -0
  429. package/dist/modes/rpc/jsonl.js +49 -0
  430. package/dist/modes/rpc/jsonl.js.map +1 -0
  431. package/dist/modes/rpc/rpc-client.d.ts +217 -0
  432. package/dist/modes/rpc/rpc-client.d.ts.map +1 -0
  433. package/dist/modes/rpc/rpc-client.js +401 -0
  434. package/dist/modes/rpc/rpc-client.js.map +1 -0
  435. package/dist/modes/rpc/rpc-mode.d.ts +20 -0
  436. package/dist/modes/rpc/rpc-mode.d.ts.map +1 -0
  437. package/dist/modes/rpc/rpc-mode.js +522 -0
  438. package/dist/modes/rpc/rpc-mode.js.map +1 -0
  439. package/dist/modes/rpc/rpc-types.d.ts +408 -0
  440. package/dist/modes/rpc/rpc-types.d.ts.map +1 -0
  441. package/dist/modes/rpc/rpc-types.js +8 -0
  442. package/dist/modes/rpc/rpc-types.js.map +1 -0
  443. package/dist/utils/changelog.d.ts +21 -0
  444. package/dist/utils/changelog.d.ts.map +1 -0
  445. package/dist/utils/changelog.js +87 -0
  446. package/dist/utils/changelog.js.map +1 -0
  447. package/dist/utils/child-process.d.ts +11 -0
  448. package/dist/utils/child-process.d.ts.map +1 -0
  449. package/dist/utils/child-process.js +78 -0
  450. package/dist/utils/child-process.js.map +1 -0
  451. package/dist/utils/clipboard-image.d.ts +11 -0
  452. package/dist/utils/clipboard-image.d.ts.map +1 -0
  453. package/dist/utils/clipboard-image.js +245 -0
  454. package/dist/utils/clipboard-image.js.map +1 -0
  455. package/dist/utils/clipboard-native.d.ts +8 -0
  456. package/dist/utils/clipboard-native.d.ts.map +1 -0
  457. package/dist/utils/clipboard-native.js +14 -0
  458. package/dist/utils/clipboard-native.js.map +1 -0
  459. package/dist/utils/clipboard.d.ts +2 -0
  460. package/dist/utils/clipboard.d.ts.map +1 -0
  461. package/dist/utils/clipboard.js +78 -0
  462. package/dist/utils/clipboard.js.map +1 -0
  463. package/dist/utils/exif-orientation.d.ts +5 -0
  464. package/dist/utils/exif-orientation.d.ts.map +1 -0
  465. package/dist/utils/exif-orientation.js +158 -0
  466. package/dist/utils/exif-orientation.js.map +1 -0
  467. package/dist/utils/frontmatter.d.ts +8 -0
  468. package/dist/utils/frontmatter.d.ts.map +1 -0
  469. package/dist/utils/frontmatter.js +26 -0
  470. package/dist/utils/frontmatter.js.map +1 -0
  471. package/dist/utils/git.d.ts +26 -0
  472. package/dist/utils/git.d.ts.map +1 -0
  473. package/dist/utils/git.js +163 -0
  474. package/dist/utils/git.js.map +1 -0
  475. package/dist/utils/image-convert.d.ts +9 -0
  476. package/dist/utils/image-convert.d.ts.map +1 -0
  477. package/dist/utils/image-convert.js +39 -0
  478. package/dist/utils/image-convert.js.map +1 -0
  479. package/dist/utils/image-resize.d.ts +36 -0
  480. package/dist/utils/image-resize.d.ts.map +1 -0
  481. package/dist/utils/image-resize.js +137 -0
  482. package/dist/utils/image-resize.js.map +1 -0
  483. package/dist/utils/mime.d.ts +2 -0
  484. package/dist/utils/mime.d.ts.map +1 -0
  485. package/dist/utils/mime.js +26 -0
  486. package/dist/utils/mime.js.map +1 -0
  487. package/dist/utils/photon.d.ts +21 -0
  488. package/dist/utils/photon.d.ts.map +1 -0
  489. package/dist/utils/photon.js +121 -0
  490. package/dist/utils/photon.js.map +1 -0
  491. package/dist/utils/shell.d.ts +26 -0
  492. package/dist/utils/shell.d.ts.map +1 -0
  493. package/dist/utils/shell.js +186 -0
  494. package/dist/utils/shell.js.map +1 -0
  495. package/dist/utils/sleep.d.ts +5 -0
  496. package/dist/utils/sleep.d.ts.map +1 -0
  497. package/dist/utils/sleep.js +17 -0
  498. package/dist/utils/sleep.js.map +1 -0
  499. package/dist/utils/tools-manager.d.ts +3 -0
  500. package/dist/utils/tools-manager.d.ts.map +1 -0
  501. package/dist/utils/tools-manager.js +252 -0
  502. package/dist/utils/tools-manager.js.map +1 -0
  503. package/docs/compaction.md +394 -0
  504. package/docs/custom-provider.md +327 -0
  505. package/docs/extensions.md +2229 -0
  506. package/docs/images/doom-extension.png +0 -0
  507. package/docs/images/exy.png +0 -0
  508. package/docs/images/interactive-mode.png +0 -0
  509. package/docs/images/tree-view.png +0 -0
  510. package/docs/json.md +82 -0
  511. package/docs/keybindings.md +173 -0
  512. package/docs/models.md +197 -0
  513. package/docs/packages.md +218 -0
  514. package/docs/prompt-templates.md +67 -0
  515. package/docs/providers.md +98 -0
  516. package/docs/release.md +40 -0
  517. package/docs/rpc.md +1377 -0
  518. package/docs/sdk.md +971 -0
  519. package/docs/session.md +412 -0
  520. package/docs/settings.md +149 -0
  521. package/docs/shell-aliases.md +13 -0
  522. package/docs/skills.md +232 -0
  523. package/docs/terminal-setup.md +106 -0
  524. package/docs/termux.md +127 -0
  525. package/docs/themes.md +295 -0
  526. package/docs/tmux.md +61 -0
  527. package/docs/tree.md +228 -0
  528. package/docs/tui.md +887 -0
  529. package/docs/windows.md +17 -0
  530. package/examples/README.md +25 -0
  531. package/examples/extensions/README.md +204 -0
  532. package/examples/extensions/auto-commit-on-exit.ts +49 -0
  533. package/examples/extensions/bash-spawn-hook.ts +30 -0
  534. package/examples/extensions/bookmark.ts +50 -0
  535. package/examples/extensions/built-in-tool-renderer.ts +246 -0
  536. package/examples/extensions/claude-rules.ts +86 -0
  537. package/examples/extensions/commands.ts +72 -0
  538. package/examples/extensions/confirm-destructive.ts +59 -0
  539. package/examples/extensions/custom-compaction.ts +127 -0
  540. package/examples/extensions/custom-footer.ts +64 -0
  541. package/examples/extensions/custom-header.ts +73 -0
  542. package/examples/extensions/custom-provider-anthropic/index.ts +604 -0
  543. package/examples/extensions/custom-provider-anthropic/package.json +19 -0
  544. package/examples/extensions/custom-provider-gitlab-duo/index.ts +349 -0
  545. package/examples/extensions/custom-provider-gitlab-duo/package.json +16 -0
  546. package/examples/extensions/custom-provider-gitlab-duo/test.ts +82 -0
  547. package/examples/extensions/dirty-repo-guard.ts +56 -0
  548. package/examples/extensions/doom-overlay/README.md +46 -0
  549. package/examples/extensions/doom-overlay/doom/build/doom.js +21 -0
  550. package/examples/extensions/doom-overlay/doom/build/doom.wasm +0 -0
  551. package/examples/extensions/doom-overlay/doom/build.sh +152 -0
  552. package/examples/extensions/doom-overlay/doom/doomgeneric_pi.c +72 -0
  553. package/examples/extensions/doom-overlay/doom-component.ts +132 -0
  554. package/examples/extensions/doom-overlay/doom-engine.ts +173 -0
  555. package/examples/extensions/doom-overlay/doom-keys.ts +104 -0
  556. package/examples/extensions/doom-overlay/index.ts +74 -0
  557. package/examples/extensions/doom-overlay/wad-finder.ts +51 -0
  558. package/examples/extensions/dynamic-resources/SKILL.md +8 -0
  559. package/examples/extensions/dynamic-resources/dynamic.json +79 -0
  560. package/examples/extensions/dynamic-resources/dynamic.md +5 -0
  561. package/examples/extensions/dynamic-resources/index.ts +15 -0
  562. package/examples/extensions/dynamic-tools.ts +74 -0
  563. package/examples/extensions/event-bus.ts +43 -0
  564. package/examples/extensions/file-trigger.ts +41 -0
  565. package/examples/extensions/git-checkpoint.ts +53 -0
  566. package/examples/extensions/handoff.ts +153 -0
  567. package/examples/extensions/hello.ts +25 -0
  568. package/examples/extensions/hidden-thinking-label.ts +57 -0
  569. package/examples/extensions/inline-bash.ts +94 -0
  570. package/examples/extensions/input-transform.ts +43 -0
  571. package/examples/extensions/interactive-shell.ts +196 -0
  572. package/examples/extensions/mac-system-theme.ts +47 -0
  573. package/examples/extensions/message-renderer.ts +59 -0
  574. package/examples/extensions/minimal-mode.ts +426 -0
  575. package/examples/extensions/modal-editor.ts +85 -0
  576. package/examples/extensions/model-status.ts +31 -0
  577. package/examples/extensions/notify.ts +55 -0
  578. package/examples/extensions/overlay-qa-tests.ts +1348 -0
  579. package/examples/extensions/overlay-test.ts +150 -0
  580. package/examples/extensions/permission-gate.ts +34 -0
  581. package/examples/extensions/pirate.ts +47 -0
  582. package/examples/extensions/plan-mode/README.md +65 -0
  583. package/examples/extensions/plan-mode/index.ts +340 -0
  584. package/examples/extensions/plan-mode/utils.ts +166 -0
  585. package/examples/extensions/preset.ts +397 -0
  586. package/examples/extensions/protected-paths.ts +30 -0
  587. package/examples/extensions/provider-payload.ts +14 -0
  588. package/examples/extensions/qna.ts +122 -0
  589. package/examples/extensions/question.ts +264 -0
  590. package/examples/extensions/questionnaire.ts +427 -0
  591. package/examples/extensions/rainbow-editor.ts +88 -0
  592. package/examples/extensions/reload-runtime.ts +37 -0
  593. package/examples/extensions/rpc-demo.ts +124 -0
  594. package/examples/extensions/sandbox/index.ts +321 -0
  595. package/examples/extensions/sandbox/package.json +19 -0
  596. package/examples/extensions/send-user-message.ts +97 -0
  597. package/examples/extensions/session-name.ts +27 -0
  598. package/examples/extensions/shutdown-command.ts +63 -0
  599. package/examples/extensions/snake.ts +343 -0
  600. package/examples/extensions/space-invaders.ts +560 -0
  601. package/examples/extensions/ssh.ts +220 -0
  602. package/examples/extensions/status-line.ts +40 -0
  603. package/examples/extensions/subagent/README.md +172 -0
  604. package/examples/extensions/subagent/agents/planner.md +37 -0
  605. package/examples/extensions/subagent/agents/reviewer.md +35 -0
  606. package/examples/extensions/subagent/agents/scout.md +50 -0
  607. package/examples/extensions/subagent/agents/worker.md +24 -0
  608. package/examples/extensions/subagent/agents.ts +126 -0
  609. package/examples/extensions/subagent/index.ts +986 -0
  610. package/examples/extensions/subagent/prompts/implement-and-review.md +10 -0
  611. package/examples/extensions/subagent/prompts/implement.md +10 -0
  612. package/examples/extensions/subagent/prompts/scout-and-plan.md +9 -0
  613. package/examples/extensions/summarize.ts +206 -0
  614. package/examples/extensions/system-prompt-header.ts +17 -0
  615. package/examples/extensions/timed-confirm.ts +70 -0
  616. package/examples/extensions/titlebar-spinner.ts +58 -0
  617. package/examples/extensions/todo.ts +299 -0
  618. package/examples/extensions/tool-override.ts +144 -0
  619. package/examples/extensions/tools.ts +146 -0
  620. package/examples/extensions/trigger-compact.ts +50 -0
  621. package/examples/extensions/truncated-tool.ts +195 -0
  622. package/examples/extensions/widget-placement.ts +17 -0
  623. package/examples/extensions/with-deps/index.ts +32 -0
  624. package/examples/extensions/with-deps/package.json +22 -0
  625. package/examples/rpc-extension-ui.ts +632 -0
  626. package/examples/sdk/01-minimal.ts +22 -0
  627. package/examples/sdk/02-custom-model.ts +49 -0
  628. package/examples/sdk/03-custom-prompt.ts +55 -0
  629. package/examples/sdk/04-skills.ts +52 -0
  630. package/examples/sdk/05-tools.ts +56 -0
  631. package/examples/sdk/06-extensions.ts +88 -0
  632. package/examples/sdk/07-context-files.ts +40 -0
  633. package/examples/sdk/08-prompt-templates.ts +48 -0
  634. package/examples/sdk/09-api-keys-and-oauth.ts +48 -0
  635. package/examples/sdk/10-settings.ts +51 -0
  636. package/examples/sdk/11-sessions.ts +48 -0
  637. package/examples/sdk/12-full-control.ts +81 -0
  638. package/examples/sdk/README.md +144 -0
  639. package/package.json +95 -0
  640. package/src/bun/cli.ts +5 -0
  641. package/src/cli/args.ts +309 -0
  642. package/src/cli/config-selector.ts +52 -0
  643. package/src/cli/file-processor.ts +100 -0
  644. package/src/cli/initial-message.ts +43 -0
  645. package/src/cli/list-models.ts +104 -0
  646. package/src/cli/session-picker.ts +52 -0
  647. package/src/cli.ts +16 -0
  648. package/src/config.ts +214 -0
  649. package/src/core/agent-session.ts +3279 -0
  650. package/src/core/auth-storage.ts +488 -0
  651. package/src/core/bash-executor.ts +158 -0
  652. package/src/core/compaction/branch-summarization.ts +355 -0
  653. package/src/core/compaction/compaction.ts +823 -0
  654. package/src/core/compaction/index.ts +7 -0
  655. package/src/core/compaction/utils.ts +170 -0
  656. package/src/core/defaults.ts +3 -0
  657. package/src/core/diagnostics.ts +15 -0
  658. package/src/core/event-bus.ts +33 -0
  659. package/src/core/exec.ts +107 -0
  660. package/src/core/export-html/ansi-to-html.ts +258 -0
  661. package/src/core/export-html/index.ts +314 -0
  662. package/src/core/export-html/template.css +1001 -0
  663. package/src/core/export-html/template.html +55 -0
  664. package/src/core/export-html/template.js +1690 -0
  665. package/src/core/export-html/tool-renderer.ts +156 -0
  666. package/src/core/export-html/vendor/highlight.min.js +1213 -0
  667. package/src/core/export-html/vendor/marked.min.js +6 -0
  668. package/src/core/extensions/index.ts +168 -0
  669. package/src/core/extensions/loader.ts +557 -0
  670. package/src/core/extensions/runner.ts +915 -0
  671. package/src/core/extensions/types.ts +1461 -0
  672. package/src/core/extensions/wrapper.ts +27 -0
  673. package/src/core/footer-data-provider.ts +273 -0
  674. package/src/core/index.ts +61 -0
  675. package/src/core/keybindings.ts +302 -0
  676. package/src/core/messages.ts +195 -0
  677. package/src/core/model-registry.ts +766 -0
  678. package/src/core/model-resolver.ts +606 -0
  679. package/src/core/output-guard.ts +74 -0
  680. package/src/core/package-manager.ts +2222 -0
  681. package/src/core/prompt-templates.ts +294 -0
  682. package/src/core/resolve-config-value.ts +142 -0
  683. package/src/core/resource-loader.ts +886 -0
  684. package/src/core/sdk.ts +360 -0
  685. package/src/core/self-update.ts +57 -0
  686. package/src/core/session-manager.ts +1410 -0
  687. package/src/core/settings-manager.ts +973 -0
  688. package/src/core/skills.ts +508 -0
  689. package/src/core/slash-commands.ts +37 -0
  690. package/src/core/source-info.ts +40 -0
  691. package/src/core/system-prompt.ts +168 -0
  692. package/src/core/timings.ts +31 -0
  693. package/src/core/tools/bash.ts +431 -0
  694. package/src/core/tools/edit-diff.ts +445 -0
  695. package/src/core/tools/edit.ts +307 -0
  696. package/src/core/tools/file-mutation-queue.ts +39 -0
  697. package/src/core/tools/find.ts +314 -0
  698. package/src/core/tools/grep.ts +375 -0
  699. package/src/core/tools/index.ts +193 -0
  700. package/src/core/tools/ls.ts +233 -0
  701. package/src/core/tools/path-utils.ts +94 -0
  702. package/src/core/tools/read.ts +269 -0
  703. package/src/core/tools/render-utils.ts +64 -0
  704. package/src/core/tools/tool-definition-wrapper.ts +43 -0
  705. package/src/core/tools/truncate.ts +265 -0
  706. package/src/core/tools/write.ts +285 -0
  707. package/src/core/version-check.ts +85 -0
  708. package/src/index.ts +348 -0
  709. package/src/main.ts +958 -0
  710. package/src/migrations.ts +290 -0
  711. package/src/modes/index.ts +9 -0
  712. package/src/modes/interactive/components/armin.ts +382 -0
  713. package/src/modes/interactive/components/assistant-message.ts +130 -0
  714. package/src/modes/interactive/components/bash-execution.ts +218 -0
  715. package/src/modes/interactive/components/bordered-loader.ts +66 -0
  716. package/src/modes/interactive/components/branch-summary-message.ts +58 -0
  717. package/src/modes/interactive/components/compaction-summary-message.ts +59 -0
  718. package/src/modes/interactive/components/config-selector.ts +592 -0
  719. package/src/modes/interactive/components/countdown-timer.ts +38 -0
  720. package/src/modes/interactive/components/custom-editor.ts +80 -0
  721. package/src/modes/interactive/components/custom-message.ts +99 -0
  722. package/src/modes/interactive/components/diff.ts +147 -0
  723. package/src/modes/interactive/components/dynamic-border.ts +25 -0
  724. package/src/modes/interactive/components/extension-editor.ts +147 -0
  725. package/src/modes/interactive/components/extension-input.ts +87 -0
  726. package/src/modes/interactive/components/extension-selector.ts +107 -0
  727. package/src/modes/interactive/components/footer.ts +216 -0
  728. package/src/modes/interactive/components/index.ts +31 -0
  729. package/src/modes/interactive/components/keybinding-hints.ts +24 -0
  730. package/src/modes/interactive/components/login-dialog.ts +178 -0
  731. package/src/modes/interactive/components/model-selector.ts +328 -0
  732. package/src/modes/interactive/components/oauth-selector.ts +121 -0
  733. package/src/modes/interactive/components/scoped-models-selector.ts +346 -0
  734. package/src/modes/interactive/components/session-selector-search.ts +194 -0
  735. package/src/modes/interactive/components/session-selector.ts +1010 -0
  736. package/src/modes/interactive/components/settings-selector.ts +432 -0
  737. package/src/modes/interactive/components/show-images-selector.ts +50 -0
  738. package/src/modes/interactive/components/skill-invocation-message.ts +55 -0
  739. package/src/modes/interactive/components/theme-selector.ts +67 -0
  740. package/src/modes/interactive/components/thinking-selector.ts +74 -0
  741. package/src/modes/interactive/components/tool-execution.ts +328 -0
  742. package/src/modes/interactive/components/tree-selector.ts +1197 -0
  743. package/src/modes/interactive/components/user-message-selector.ts +143 -0
  744. package/src/modes/interactive/components/user-message.ts +33 -0
  745. package/src/modes/interactive/components/visual-truncate.ts +50 -0
  746. package/src/modes/interactive/interactive-mode.ts +4501 -0
  747. package/src/modes/interactive/theme/dark.json +85 -0
  748. package/src/modes/interactive/theme/light.json +84 -0
  749. package/src/modes/interactive/theme/theme-schema.json +335 -0
  750. package/src/modes/interactive/theme/theme.ts +1137 -0
  751. package/src/modes/print-mode.ts +131 -0
  752. package/src/modes/rpc/jsonl.ts +58 -0
  753. package/src/modes/rpc/rpc-client.ts +505 -0
  754. package/src/modes/rpc/rpc-mode.ts +654 -0
  755. package/src/modes/rpc/rpc-types.ts +262 -0
  756. package/src/utils/changelog.ts +99 -0
  757. package/src/utils/child-process.ts +86 -0
  758. package/src/utils/clipboard-image.ts +300 -0
  759. package/src/utils/clipboard-native.ts +22 -0
  760. package/src/utils/clipboard.ts +81 -0
  761. package/src/utils/exif-orientation.ts +183 -0
  762. package/src/utils/frontmatter.ts +39 -0
  763. package/src/utils/git.ts +192 -0
  764. package/src/utils/image-convert.ts +41 -0
  765. package/src/utils/image-resize.ts +176 -0
  766. package/src/utils/mime.ts +30 -0
  767. package/src/utils/photon.ts +139 -0
  768. package/src/utils/shell.ts +202 -0
  769. package/src/utils/sleep.ts +18 -0
  770. package/src/utils/tools-manager.ts +287 -0
package/docs/rpc.md ADDED
@@ -0,0 +1,1377 @@
1
+ # RPC Mode
2
+
3
+ RPC mode enables headless operation of the coding agent via a JSON protocol over stdin/stdout. This is useful for embedding the agent in other applications, IDEs, or custom UIs.
4
+
5
+ **Note for Node.js/TypeScript users**: If you're building a Node.js application, consider using `AgentSession` directly from `@lenylvt/pi-coding-agent` instead of spawning a subprocess. See [`src/core/agent-session.ts`](../src/core/agent-session.ts) for the API. For a subprocess-based TypeScript client, see [`src/modes/rpc/rpc-client.ts`](../src/modes/rpc/rpc-client.ts).
6
+
7
+ ## Starting RPC Mode
8
+
9
+ ```bash
10
+ pi --mode rpc [options]
11
+ ```
12
+
13
+ Common options:
14
+ - `--provider <name>`: Set the LLM provider (`anthropic`, `github-copilot`, `openai-codex`, or `openrouter`)
15
+ - `--model <pattern>`: Model pattern or ID (supports `provider/id` and optional `:<thinking>`)
16
+ - `--no-session`: Disable session persistence
17
+ - `--session-dir <path>`: Custom session storage directory
18
+
19
+ ## Protocol Overview
20
+
21
+ - **Commands**: JSON objects sent to stdin, one per line
22
+ - **Responses**: JSON objects with `type: "response"` indicating command success/failure
23
+ - **Events**: Agent events streamed to stdout as JSON lines
24
+
25
+ All commands support an optional `id` field for request/response correlation. If provided, the corresponding response will include the same `id`.
26
+
27
+ ### Framing
28
+
29
+ RPC mode uses strict JSONL semantics with LF (`\n`) as the only record delimiter.
30
+
31
+ This matters for clients:
32
+ - Split records on `\n` only
33
+ - Accept optional `\r\n` input by stripping a trailing `\r`
34
+ - Do not use generic line readers that treat Unicode separators as newlines
35
+
36
+ In particular, Node `readline` is not protocol-compliant for RPC mode because it also splits on `U+2028` and `U+2029`, which are valid inside JSON strings.
37
+
38
+ ## Commands
39
+
40
+ ### Prompting
41
+
42
+ #### prompt
43
+
44
+ Send a user prompt to the agent. Returns immediately; events stream asynchronously.
45
+
46
+ ```json
47
+ {"id": "req-1", "type": "prompt", "message": "Hello, world!"}
48
+ ```
49
+
50
+ With images:
51
+ ```json
52
+ {"type": "prompt", "message": "What's in this image?", "images": [{"type": "image", "data": "base64-encoded-data", "mimeType": "image/png"}]}
53
+ ```
54
+
55
+ **During streaming**: If the agent is already streaming, you must specify `streamingBehavior` to queue the message:
56
+
57
+ ```json
58
+ {"type": "prompt", "message": "New instruction", "streamingBehavior": "steer"}
59
+ ```
60
+
61
+ - `"steer"`: Queue the message while the agent is running. It is delivered after the current assistant turn finishes executing its tool calls, before the next LLM call.
62
+ - `"followUp"`: Wait until the agent finishes. Message is delivered only when agent stops.
63
+
64
+ If the agent is streaming and no `streamingBehavior` is specified, the command returns an error.
65
+
66
+ **Extension commands**: If the message is an extension command (e.g., `/mycommand`), it executes immediately even during streaming. Extension commands manage their own LLM interaction via `pi.sendMessage()`.
67
+
68
+ **Input expansion**: Skill commands (`/skill:name`) and prompt templates (`/template`) are expanded before sending/queueing.
69
+
70
+ Response:
71
+ ```json
72
+ {"id": "req-1", "type": "response", "command": "prompt", "success": true}
73
+ ```
74
+
75
+ The `images` field is optional. Each image uses `ImageContent` format: `{"type": "image", "data": "base64-encoded-data", "mimeType": "image/png"}`.
76
+
77
+ #### steer
78
+
79
+ Queue a steering message while the agent is running. It is delivered after the current assistant turn finishes executing its tool calls, before the next LLM call. Skill commands and prompt templates are expanded. Extension commands are not allowed (use `prompt` instead).
80
+
81
+ ```json
82
+ {"type": "steer", "message": "Stop and do this instead"}
83
+ ```
84
+
85
+ With images:
86
+ ```json
87
+ {"type": "steer", "message": "Look at this instead", "images": [{"type": "image", "data": "base64-encoded-data", "mimeType": "image/png"}]}
88
+ ```
89
+
90
+ The `images` field is optional. Each image uses `ImageContent` format (same as `prompt`).
91
+
92
+ Response:
93
+ ```json
94
+ {"type": "response", "command": "steer", "success": true}
95
+ ```
96
+
97
+ See [set_steering_mode](#set_steering_mode) for controlling how steering messages are processed.
98
+
99
+ #### follow_up
100
+
101
+ Queue a follow-up message to be processed after the agent finishes. Delivered only when agent has no more tool calls or steering messages. Skill commands and prompt templates are expanded. Extension commands are not allowed (use `prompt` instead).
102
+
103
+ ```json
104
+ {"type": "follow_up", "message": "After you're done, also do this"}
105
+ ```
106
+
107
+ With images:
108
+ ```json
109
+ {"type": "follow_up", "message": "Also check this image", "images": [{"type": "image", "data": "base64-encoded-data", "mimeType": "image/png"}]}
110
+ ```
111
+
112
+ The `images` field is optional. Each image uses `ImageContent` format (same as `prompt`).
113
+
114
+ Response:
115
+ ```json
116
+ {"type": "response", "command": "follow_up", "success": true}
117
+ ```
118
+
119
+ See [set_follow_up_mode](#set_follow_up_mode) for controlling how follow-up messages are processed.
120
+
121
+ #### abort
122
+
123
+ Abort the current agent operation.
124
+
125
+ ```json
126
+ {"type": "abort"}
127
+ ```
128
+
129
+ Response:
130
+ ```json
131
+ {"type": "response", "command": "abort", "success": true}
132
+ ```
133
+
134
+ #### new_session
135
+
136
+ Start a fresh session. Can be cancelled by a `session_before_switch` extension event handler.
137
+
138
+ ```json
139
+ {"type": "new_session"}
140
+ ```
141
+
142
+ With optional parent session tracking:
143
+ ```json
144
+ {"type": "new_session", "parentSession": "/path/to/parent-session.jsonl"}
145
+ ```
146
+
147
+ Response:
148
+ ```json
149
+ {"type": "response", "command": "new_session", "success": true, "data": {"cancelled": false}}
150
+ ```
151
+
152
+ If an extension cancelled:
153
+ ```json
154
+ {"type": "response", "command": "new_session", "success": true, "data": {"cancelled": true}}
155
+ ```
156
+
157
+ ### State
158
+
159
+ #### get_state
160
+
161
+ Get current session state.
162
+
163
+ ```json
164
+ {"type": "get_state"}
165
+ ```
166
+
167
+ Response:
168
+ ```json
169
+ {
170
+ "type": "response",
171
+ "command": "get_state",
172
+ "success": true,
173
+ "data": {
174
+ "model": {...},
175
+ "thinkingLevel": "medium",
176
+ "isStreaming": false,
177
+ "isCompacting": false,
178
+ "steeringMode": "all",
179
+ "followUpMode": "one-at-a-time",
180
+ "sessionFile": "/path/to/session.jsonl",
181
+ "sessionId": "abc123",
182
+ "sessionName": "my-feature-work",
183
+ "autoCompactionEnabled": true,
184
+ "messageCount": 5,
185
+ "pendingMessageCount": 0
186
+ }
187
+ }
188
+ ```
189
+
190
+ The `model` field is a full [Model](#model) object or `null`. The `sessionName` field is the display name set via `set_session_name`, or omitted if not set.
191
+
192
+ #### get_messages
193
+
194
+ Get all messages in the conversation.
195
+
196
+ ```json
197
+ {"type": "get_messages"}
198
+ ```
199
+
200
+ Response:
201
+ ```json
202
+ {
203
+ "type": "response",
204
+ "command": "get_messages",
205
+ "success": true,
206
+ "data": {"messages": [...]}
207
+ }
208
+ ```
209
+
210
+ Messages are `AgentMessage` objects (see [Message Types](#message-types)).
211
+
212
+ ### Model
213
+
214
+ #### set_model
215
+
216
+ Switch to a specific model.
217
+
218
+ ```json
219
+ {"type": "set_model", "provider": "anthropic", "modelId": "claude-sonnet-4-20250514"}
220
+ ```
221
+
222
+ Response contains the full [Model](#model) object:
223
+ ```json
224
+ {
225
+ "type": "response",
226
+ "command": "set_model",
227
+ "success": true,
228
+ "data": {...}
229
+ }
230
+ ```
231
+
232
+ #### cycle_model
233
+
234
+ Cycle to the next available model. Returns `null` data if only one model available.
235
+
236
+ ```json
237
+ {"type": "cycle_model"}
238
+ ```
239
+
240
+ Response:
241
+ ```json
242
+ {
243
+ "type": "response",
244
+ "command": "cycle_model",
245
+ "success": true,
246
+ "data": {
247
+ "model": {...},
248
+ "thinkingLevel": "medium",
249
+ "isScoped": false
250
+ }
251
+ }
252
+ ```
253
+
254
+ The `model` field is a full [Model](#model) object.
255
+
256
+ #### get_available_models
257
+
258
+ List all configured models.
259
+
260
+ ```json
261
+ {"type": "get_available_models"}
262
+ ```
263
+
264
+ Response contains an array of full [Model](#model) objects:
265
+ ```json
266
+ {
267
+ "type": "response",
268
+ "command": "get_available_models",
269
+ "success": true,
270
+ "data": {
271
+ "models": [...]
272
+ }
273
+ }
274
+ ```
275
+
276
+ ### Thinking
277
+
278
+ #### set_thinking_level
279
+
280
+ Set the reasoning/thinking level for models that support it.
281
+
282
+ ```json
283
+ {"type": "set_thinking_level", "level": "high"}
284
+ ```
285
+
286
+ Levels: `"off"`, `"minimal"`, `"low"`, `"medium"`, `"high"`, `"xhigh"`
287
+
288
+ Note: `"xhigh"` is only supported by OpenAI codex-max models.
289
+
290
+ Response:
291
+ ```json
292
+ {"type": "response", "command": "set_thinking_level", "success": true}
293
+ ```
294
+
295
+ #### cycle_thinking_level
296
+
297
+ Cycle through available thinking levels. Returns `null` data if model doesn't support thinking.
298
+
299
+ ```json
300
+ {"type": "cycle_thinking_level"}
301
+ ```
302
+
303
+ Response:
304
+ ```json
305
+ {
306
+ "type": "response",
307
+ "command": "cycle_thinking_level",
308
+ "success": true,
309
+ "data": {"level": "high"}
310
+ }
311
+ ```
312
+
313
+ ### Queue Modes
314
+
315
+ #### set_steering_mode
316
+
317
+ Control how steering messages (from `steer`) are delivered.
318
+
319
+ ```json
320
+ {"type": "set_steering_mode", "mode": "one-at-a-time"}
321
+ ```
322
+
323
+ Modes:
324
+ - `"all"`: Deliver all steering messages after the current assistant turn finishes executing its tool calls
325
+ - `"one-at-a-time"`: Deliver one steering message per completed assistant turn (default)
326
+
327
+ Response:
328
+ ```json
329
+ {"type": "response", "command": "set_steering_mode", "success": true}
330
+ ```
331
+
332
+ #### set_follow_up_mode
333
+
334
+ Control how follow-up messages (from `follow_up`) are delivered.
335
+
336
+ ```json
337
+ {"type": "set_follow_up_mode", "mode": "one-at-a-time"}
338
+ ```
339
+
340
+ Modes:
341
+ - `"all"`: Deliver all follow-up messages when agent finishes
342
+ - `"one-at-a-time"`: Deliver one follow-up message per agent completion (default)
343
+
344
+ Response:
345
+ ```json
346
+ {"type": "response", "command": "set_follow_up_mode", "success": true}
347
+ ```
348
+
349
+ ### Compaction
350
+
351
+ #### compact
352
+
353
+ Manually compact conversation context to reduce token usage.
354
+
355
+ ```json
356
+ {"type": "compact"}
357
+ ```
358
+
359
+ With custom instructions:
360
+ ```json
361
+ {"type": "compact", "customInstructions": "Focus on code changes"}
362
+ ```
363
+
364
+ Response:
365
+ ```json
366
+ {
367
+ "type": "response",
368
+ "command": "compact",
369
+ "success": true,
370
+ "data": {
371
+ "summary": "Summary of conversation...",
372
+ "firstKeptEntryId": "abc123",
373
+ "tokensBefore": 150000,
374
+ "details": {}
375
+ }
376
+ }
377
+ ```
378
+
379
+ #### set_auto_compaction
380
+
381
+ Enable or disable automatic compaction when context is nearly full.
382
+
383
+ ```json
384
+ {"type": "set_auto_compaction", "enabled": true}
385
+ ```
386
+
387
+ Response:
388
+ ```json
389
+ {"type": "response", "command": "set_auto_compaction", "success": true}
390
+ ```
391
+
392
+ ### Retry
393
+
394
+ #### set_auto_retry
395
+
396
+ Enable or disable automatic retry on transient errors (overloaded, rate limit, 5xx).
397
+
398
+ ```json
399
+ {"type": "set_auto_retry", "enabled": true}
400
+ ```
401
+
402
+ Response:
403
+ ```json
404
+ {"type": "response", "command": "set_auto_retry", "success": true}
405
+ ```
406
+
407
+ #### abort_retry
408
+
409
+ Abort an in-progress retry (cancel the delay and stop retrying).
410
+
411
+ ```json
412
+ {"type": "abort_retry"}
413
+ ```
414
+
415
+ Response:
416
+ ```json
417
+ {"type": "response", "command": "abort_retry", "success": true}
418
+ ```
419
+
420
+ ### Bash
421
+
422
+ #### bash
423
+
424
+ Execute a shell command and add output to conversation context.
425
+
426
+ ```json
427
+ {"type": "bash", "command": "ls -la"}
428
+ ```
429
+
430
+ Response:
431
+ ```json
432
+ {
433
+ "type": "response",
434
+ "command": "bash",
435
+ "success": true,
436
+ "data": {
437
+ "output": "total 48\ndrwxr-xr-x ...",
438
+ "exitCode": 0,
439
+ "cancelled": false,
440
+ "truncated": false
441
+ }
442
+ }
443
+ ```
444
+
445
+ If output was truncated, includes `fullOutputPath`:
446
+ ```json
447
+ {
448
+ "type": "response",
449
+ "command": "bash",
450
+ "success": true,
451
+ "data": {
452
+ "output": "truncated output...",
453
+ "exitCode": 0,
454
+ "cancelled": false,
455
+ "truncated": true,
456
+ "fullOutputPath": "/tmp/pi-bash-abc123.log"
457
+ }
458
+ }
459
+ ```
460
+
461
+ **How bash results reach the LLM:**
462
+
463
+ The `bash` command executes immediately and returns a `BashResult`. Internally, a `BashExecutionMessage` is created and stored in the agent's message state. This message does NOT emit an event.
464
+
465
+ When the next `prompt` command is sent, all messages (including `BashExecutionMessage`) are transformed before being sent to the LLM. The `BashExecutionMessage` is converted to a `UserMessage` with this format:
466
+
467
+ ```
468
+ Ran `ls -la`
469
+ \`\`\`
470
+ total 48
471
+ drwxr-xr-x ...
472
+ \`\`\`
473
+ ```
474
+
475
+ This means:
476
+ 1. Bash output is included in the LLM context on the **next prompt**, not immediately
477
+ 2. Multiple bash commands can be executed before a prompt; all outputs will be included
478
+ 3. No event is emitted for the `BashExecutionMessage` itself
479
+
480
+ #### abort_bash
481
+
482
+ Abort a running bash command.
483
+
484
+ ```json
485
+ {"type": "abort_bash"}
486
+ ```
487
+
488
+ Response:
489
+ ```json
490
+ {"type": "response", "command": "abort_bash", "success": true}
491
+ ```
492
+
493
+ ### Session
494
+
495
+ #### get_session_stats
496
+
497
+ Get token usage, cost statistics, and current context window usage.
498
+
499
+ ```json
500
+ {"type": "get_session_stats"}
501
+ ```
502
+
503
+ Response:
504
+ ```json
505
+ {
506
+ "type": "response",
507
+ "command": "get_session_stats",
508
+ "success": true,
509
+ "data": {
510
+ "sessionFile": "/path/to/session.jsonl",
511
+ "sessionId": "abc123",
512
+ "userMessages": 5,
513
+ "assistantMessages": 5,
514
+ "toolCalls": 12,
515
+ "toolResults": 12,
516
+ "totalMessages": 22,
517
+ "tokens": {
518
+ "input": 50000,
519
+ "output": 10000,
520
+ "cacheRead": 40000,
521
+ "cacheWrite": 5000,
522
+ "total": 105000
523
+ },
524
+ "cost": 0.45,
525
+ "contextUsage": {
526
+ "tokens": 60000,
527
+ "contextWindow": 200000,
528
+ "percent": 30
529
+ }
530
+ }
531
+ }
532
+ ```
533
+
534
+ `tokens` contains assistant usage totals for the current session state. `contextUsage` contains the actual current context-window estimate used for compaction and footer display.
535
+
536
+ `contextUsage` is omitted when no model or context window is available. `contextUsage.tokens` and `contextUsage.percent` are `null` immediately after compaction until a fresh post-compaction assistant response provides valid usage data.
537
+
538
+ #### export_html
539
+
540
+ Export session to an HTML file.
541
+
542
+ ```json
543
+ {"type": "export_html"}
544
+ ```
545
+
546
+ With custom path:
547
+ ```json
548
+ {"type": "export_html", "outputPath": "/tmp/session.html"}
549
+ ```
550
+
551
+ Response:
552
+ ```json
553
+ {
554
+ "type": "response",
555
+ "command": "export_html",
556
+ "success": true,
557
+ "data": {"path": "/tmp/session.html"}
558
+ }
559
+ ```
560
+
561
+ #### switch_session
562
+
563
+ Load a different session file. Can be cancelled by a `session_before_switch` extension event handler.
564
+
565
+ ```json
566
+ {"type": "switch_session", "sessionPath": "/path/to/session.jsonl"}
567
+ ```
568
+
569
+ Response:
570
+ ```json
571
+ {"type": "response", "command": "switch_session", "success": true, "data": {"cancelled": false}}
572
+ ```
573
+
574
+ If an extension cancelled the switch:
575
+ ```json
576
+ {"type": "response", "command": "switch_session", "success": true, "data": {"cancelled": true}}
577
+ ```
578
+
579
+ #### fork
580
+
581
+ Create a new fork from a previous user message. Can be cancelled by a `session_before_fork` extension event handler. Returns the text of the message being forked from.
582
+
583
+ ```json
584
+ {"type": "fork", "entryId": "abc123"}
585
+ ```
586
+
587
+ Response:
588
+ ```json
589
+ {
590
+ "type": "response",
591
+ "command": "fork",
592
+ "success": true,
593
+ "data": {"text": "The original prompt text...", "cancelled": false}
594
+ }
595
+ ```
596
+
597
+ If an extension cancelled the fork:
598
+ ```json
599
+ {
600
+ "type": "response",
601
+ "command": "fork",
602
+ "success": true,
603
+ "data": {"text": "The original prompt text...", "cancelled": true}
604
+ }
605
+ ```
606
+
607
+ #### get_fork_messages
608
+
609
+ Get user messages available for forking.
610
+
611
+ ```json
612
+ {"type": "get_fork_messages"}
613
+ ```
614
+
615
+ Response:
616
+ ```json
617
+ {
618
+ "type": "response",
619
+ "command": "get_fork_messages",
620
+ "success": true,
621
+ "data": {
622
+ "messages": [
623
+ {"entryId": "abc123", "text": "First prompt..."},
624
+ {"entryId": "def456", "text": "Second prompt..."}
625
+ ]
626
+ }
627
+ }
628
+ ```
629
+
630
+ #### get_last_assistant_text
631
+
632
+ Get the text content of the last assistant message.
633
+
634
+ ```json
635
+ {"type": "get_last_assistant_text"}
636
+ ```
637
+
638
+ Response:
639
+ ```json
640
+ {
641
+ "type": "response",
642
+ "command": "get_last_assistant_text",
643
+ "success": true,
644
+ "data": {"text": "The assistant's response..."}
645
+ }
646
+ ```
647
+
648
+ Returns `{"text": null}` if no assistant messages exist.
649
+
650
+ #### set_session_name
651
+
652
+ Set a display name for the current session. The name appears in session listings and helps identify sessions.
653
+
654
+ ```json
655
+ {"type": "set_session_name", "name": "my-feature-work"}
656
+ ```
657
+
658
+ Response:
659
+ ```json
660
+ {
661
+ "type": "response",
662
+ "command": "set_session_name",
663
+ "success": true
664
+ }
665
+ ```
666
+
667
+ The current session name is available via `get_state` in the `sessionName` field.
668
+
669
+ ### Commands
670
+
671
+ #### get_commands
672
+
673
+ Get available commands (extension commands, prompt templates, and skills). These can be invoked via the `prompt` command by prefixing with `/`.
674
+
675
+ ```json
676
+ {"type": "get_commands"}
677
+ ```
678
+
679
+ Response:
680
+ ```json
681
+ {
682
+ "type": "response",
683
+ "command": "get_commands",
684
+ "success": true,
685
+ "data": {
686
+ "commands": [
687
+ {"name": "session-name", "description": "Set or clear session name", "source": "extension", "path": "/home/user/.pi/agent/extensions/session.ts"},
688
+ {"name": "fix-tests", "description": "Fix failing tests", "source": "prompt", "location": "project", "path": "/home/user/myproject/.pi/agent/prompts/fix-tests.md"},
689
+ {"name": "skill:brave-search", "description": "Web search via Brave API", "source": "skill", "location": "user", "path": "/home/user/.pi/agent/skills/brave-search/SKILL.md"}
690
+ ]
691
+ }
692
+ }
693
+ ```
694
+
695
+ Each command has:
696
+ - `name`: Command name (invoke with `/name`)
697
+ - `description`: Human-readable description (optional for extension commands)
698
+ - `source`: What kind of command:
699
+ - `"extension"`: Registered via `pi.registerCommand()` in an extension
700
+ - `"prompt"`: Loaded from a prompt template `.md` file
701
+ - `"skill"`: Loaded from a skill directory (name is prefixed with `skill:`)
702
+ - `location`: Where it was loaded from (optional, not present for extensions):
703
+ - `"user"`: User-level (`~/.pi/agent/`)
704
+ - `"project"`: Project-level (`./.pi/agent/`)
705
+ - `"path"`: Explicit path via CLI or settings
706
+ - `path`: Absolute file path to the command source (optional)
707
+
708
+ **Note**: Built-in TUI commands (`/settings`, `/hotkeys`, etc.) are not included. They are handled only in interactive mode and would not execute if sent via `prompt`.
709
+
710
+ ## Events
711
+
712
+ Events are streamed to stdout as JSON lines during agent operation. Events do NOT include an `id` field (only responses do).
713
+
714
+ ### Event Types
715
+
716
+ | Event | Description |
717
+ |-------|-------------|
718
+ | `agent_start` | Agent begins processing |
719
+ | `agent_end` | Agent completes (includes all generated messages) |
720
+ | `turn_start` | New turn begins |
721
+ | `turn_end` | Turn completes (includes assistant message and tool results) |
722
+ | `message_start` | Message begins |
723
+ | `message_update` | Streaming update (text/thinking/toolcall deltas) |
724
+ | `message_end` | Message completes |
725
+ | `tool_execution_start` | Tool begins execution |
726
+ | `tool_execution_update` | Tool execution progress (streaming output) |
727
+ | `tool_execution_end` | Tool completes |
728
+ | `queue_update` | Pending steering/follow-up queue changed |
729
+ | `compaction_start` | Compaction begins |
730
+ | `compaction_end` | Compaction completes |
731
+ | `auto_retry_start` | Auto-retry begins (after transient error) |
732
+ | `auto_retry_end` | Auto-retry completes (success or final failure) |
733
+ | `extension_error` | Extension threw an error |
734
+
735
+ ### agent_start
736
+
737
+ Emitted when the agent begins processing a prompt.
738
+
739
+ ```json
740
+ {"type": "agent_start"}
741
+ ```
742
+
743
+ ### agent_end
744
+
745
+ Emitted when the agent completes. Contains all messages generated during this run.
746
+
747
+ ```json
748
+ {
749
+ "type": "agent_end",
750
+ "messages": [...]
751
+ }
752
+ ```
753
+
754
+ ### turn_start / turn_end
755
+
756
+ A turn consists of one assistant response plus any resulting tool calls and results.
757
+
758
+ ```json
759
+ {"type": "turn_start"}
760
+ ```
761
+
762
+ ```json
763
+ {
764
+ "type": "turn_end",
765
+ "message": {...},
766
+ "toolResults": [...]
767
+ }
768
+ ```
769
+
770
+ ### message_start / message_end
771
+
772
+ Emitted when a message begins and completes. The `message` field contains an `AgentMessage`.
773
+
774
+ ```json
775
+ {"type": "message_start", "message": {...}}
776
+ {"type": "message_end", "message": {...}}
777
+ ```
778
+
779
+ ### message_update (Streaming)
780
+
781
+ Emitted during streaming of assistant messages. Contains both the partial message and a streaming delta event.
782
+
783
+ ```json
784
+ {
785
+ "type": "message_update",
786
+ "message": {...},
787
+ "assistantMessageEvent": {
788
+ "type": "text_delta",
789
+ "contentIndex": 0,
790
+ "delta": "Hello ",
791
+ "partial": {...}
792
+ }
793
+ }
794
+ ```
795
+
796
+ The `assistantMessageEvent` field contains one of these delta types:
797
+
798
+ | Type | Description |
799
+ |------|-------------|
800
+ | `start` | Message generation started |
801
+ | `text_start` | Text content block started |
802
+ | `text_delta` | Text content chunk |
803
+ | `text_end` | Text content block ended |
804
+ | `thinking_start` | Thinking block started |
805
+ | `thinking_delta` | Thinking content chunk |
806
+ | `thinking_end` | Thinking block ended |
807
+ | `toolcall_start` | Tool call started |
808
+ | `toolcall_delta` | Tool call arguments chunk |
809
+ | `toolcall_end` | Tool call ended (includes full `toolCall` object) |
810
+ | `done` | Message complete (reason: `"stop"`, `"length"`, `"toolUse"`) |
811
+ | `error` | Error occurred (reason: `"aborted"`, `"error"`) |
812
+
813
+ Example streaming a text response:
814
+ ```json
815
+ {"type":"message_update","message":{...},"assistantMessageEvent":{"type":"text_start","contentIndex":0,"partial":{...}}}
816
+ {"type":"message_update","message":{...},"assistantMessageEvent":{"type":"text_delta","contentIndex":0,"delta":"Hello","partial":{...}}}
817
+ {"type":"message_update","message":{...},"assistantMessageEvent":{"type":"text_delta","contentIndex":0,"delta":" world","partial":{...}}}
818
+ {"type":"message_update","message":{...},"assistantMessageEvent":{"type":"text_end","contentIndex":0,"content":"Hello world","partial":{...}}}
819
+ ```
820
+
821
+ ### tool_execution_start / tool_execution_update / tool_execution_end
822
+
823
+ Emitted when a tool begins, streams progress, and completes execution.
824
+
825
+ ```json
826
+ {
827
+ "type": "tool_execution_start",
828
+ "toolCallId": "call_abc123",
829
+ "toolName": "bash",
830
+ "args": {"command": "ls -la"}
831
+ }
832
+ ```
833
+
834
+ During execution, `tool_execution_update` events stream partial results (e.g., bash output as it arrives):
835
+
836
+ ```json
837
+ {
838
+ "type": "tool_execution_update",
839
+ "toolCallId": "call_abc123",
840
+ "toolName": "bash",
841
+ "args": {"command": "ls -la"},
842
+ "partialResult": {
843
+ "content": [{"type": "text", "text": "partial output so far..."}],
844
+ "details": {"truncation": null, "fullOutputPath": null}
845
+ }
846
+ }
847
+ ```
848
+
849
+ When complete:
850
+
851
+ ```json
852
+ {
853
+ "type": "tool_execution_end",
854
+ "toolCallId": "call_abc123",
855
+ "toolName": "bash",
856
+ "result": {
857
+ "content": [{"type": "text", "text": "total 48\n..."}],
858
+ "details": {...}
859
+ },
860
+ "isError": false
861
+ }
862
+ ```
863
+
864
+ Use `toolCallId` to correlate events. The `partialResult` in `tool_execution_update` contains the accumulated output so far (not just the delta), allowing clients to simply replace their display on each update.
865
+
866
+ ### queue_update
867
+
868
+ Emitted whenever the pending steering or follow-up queue changes.
869
+
870
+ ```json
871
+ {
872
+ "type": "queue_update",
873
+ "steering": ["Focus on error handling"],
874
+ "followUp": ["After that, summarize the result"]
875
+ }
876
+ ```
877
+
878
+ ### compaction_start / compaction_end
879
+
880
+ Emitted when compaction runs, whether manual or automatic.
881
+
882
+ ```json
883
+ {"type": "compaction_start", "reason": "threshold"}
884
+ ```
885
+
886
+ The `reason` field is `"manual"`, `"threshold"`, or `"overflow"`.
887
+
888
+ ```json
889
+ {
890
+ "type": "compaction_end",
891
+ "reason": "threshold",
892
+ "result": {
893
+ "summary": "Summary of conversation...",
894
+ "firstKeptEntryId": "abc123",
895
+ "tokensBefore": 150000,
896
+ "details": {}
897
+ },
898
+ "aborted": false,
899
+ "willRetry": false
900
+ }
901
+ ```
902
+
903
+ If `reason` was `"overflow"` and compaction succeeds, `willRetry` is `true` and the agent will automatically retry the prompt.
904
+
905
+ If compaction was aborted, `result` is `null` and `aborted` is `true`.
906
+
907
+ If compaction failed (e.g., API quota exceeded), `result` is `null`, `aborted` is `false`, and `errorMessage` contains the error description.
908
+
909
+ ### auto_retry_start / auto_retry_end
910
+
911
+ Emitted when automatic retry is triggered after a transient error (overloaded, rate limit, 5xx).
912
+
913
+ ```json
914
+ {
915
+ "type": "auto_retry_start",
916
+ "attempt": 1,
917
+ "maxAttempts": 3,
918
+ "delayMs": 2000,
919
+ "errorMessage": "529 {\"type\":\"error\",\"error\":{\"type\":\"overloaded_error\",\"message\":\"Overloaded\"}}"
920
+ }
921
+ ```
922
+
923
+ ```json
924
+ {
925
+ "type": "auto_retry_end",
926
+ "success": true,
927
+ "attempt": 2
928
+ }
929
+ ```
930
+
931
+ On final failure (max retries exceeded):
932
+ ```json
933
+ {
934
+ "type": "auto_retry_end",
935
+ "success": false,
936
+ "attempt": 3,
937
+ "finalError": "529 overloaded_error: Overloaded"
938
+ }
939
+ ```
940
+
941
+ ### extension_error
942
+
943
+ Emitted when an extension throws an error.
944
+
945
+ ```json
946
+ {
947
+ "type": "extension_error",
948
+ "extensionPath": "/path/to/extension.ts",
949
+ "event": "tool_call",
950
+ "error": "Error message..."
951
+ }
952
+ ```
953
+
954
+ ## Extension UI Protocol
955
+
956
+ Extensions can request user interaction via `ctx.ui.select()`, `ctx.ui.confirm()`, etc. In RPC mode, these are translated into a request/response sub-protocol on top of the base command/event flow.
957
+
958
+ There are two categories of extension UI methods:
959
+
960
+ - **Dialog methods** (`select`, `confirm`, `input`, `editor`): emit an `extension_ui_request` on stdout and block until the client sends back an `extension_ui_response` on stdin with the matching `id`.
961
+ - **Fire-and-forget methods** (`notify`, `setStatus`, `setWidget`, `setTitle`, `set_editor_text`): emit an `extension_ui_request` on stdout but do not expect a response. The client can display the information or ignore it.
962
+
963
+ If a dialog method includes a `timeout` field, the agent-side will auto-resolve with a default value when the timeout expires. The client does not need to track timeouts.
964
+
965
+ Some `ExtensionUIContext` methods are not supported or degraded in RPC mode because they require direct TUI access:
966
+ - `custom()` returns `undefined`
967
+ - `setWorkingMessage()`, `setFooter()`, `setHeader()`, `setEditorComponent()`, `setToolsExpanded()` are no-ops
968
+ - `getEditorText()` returns `""`
969
+ - `getToolsExpanded()` returns `false`
970
+ - `pasteToEditor()` delegates to `setEditorText()` (no paste/collapse handling)
971
+ - `getAllThemes()` returns `[]`
972
+ - `getTheme()` returns `undefined`
973
+ - `setTheme()` returns `{ success: false, error: "..." }`
974
+
975
+ Note: `ctx.hasUI` is `true` in RPC mode because the dialog and fire-and-forget methods are functional via the extension UI sub-protocol.
976
+
977
+ ### Extension UI Requests (stdout)
978
+
979
+ All requests have `type: "extension_ui_request"`, a unique `id`, and a `method` field.
980
+
981
+ #### select
982
+
983
+ Prompt the user to choose from a list. Dialog methods with a `timeout` field include the timeout in milliseconds; the agent auto-resolves with `undefined` if the client doesn't respond in time.
984
+
985
+ ```json
986
+ {
987
+ "type": "extension_ui_request",
988
+ "id": "uuid-1",
989
+ "method": "select",
990
+ "title": "Allow dangerous command?",
991
+ "options": ["Allow", "Block"],
992
+ "timeout": 10000
993
+ }
994
+ ```
995
+
996
+ Expected response: `extension_ui_response` with `value` (the selected option string) or `cancelled: true`.
997
+
998
+ #### confirm
999
+
1000
+ Prompt the user for yes/no confirmation.
1001
+
1002
+ ```json
1003
+ {
1004
+ "type": "extension_ui_request",
1005
+ "id": "uuid-2",
1006
+ "method": "confirm",
1007
+ "title": "Clear session?",
1008
+ "message": "All messages will be lost.",
1009
+ "timeout": 5000
1010
+ }
1011
+ ```
1012
+
1013
+ Expected response: `extension_ui_response` with `confirmed: true/false` or `cancelled: true`.
1014
+
1015
+ #### input
1016
+
1017
+ Prompt the user for free-form text.
1018
+
1019
+ ```json
1020
+ {
1021
+ "type": "extension_ui_request",
1022
+ "id": "uuid-3",
1023
+ "method": "input",
1024
+ "title": "Enter a value",
1025
+ "placeholder": "type something..."
1026
+ }
1027
+ ```
1028
+
1029
+ Expected response: `extension_ui_response` with `value` (the entered text) or `cancelled: true`.
1030
+
1031
+ #### editor
1032
+
1033
+ Open a multi-line text editor with optional prefilled content.
1034
+
1035
+ ```json
1036
+ {
1037
+ "type": "extension_ui_request",
1038
+ "id": "uuid-4",
1039
+ "method": "editor",
1040
+ "title": "Edit some text",
1041
+ "prefill": "Line 1\nLine 2\nLine 3"
1042
+ }
1043
+ ```
1044
+
1045
+ Expected response: `extension_ui_response` with `value` (the edited text) or `cancelled: true`.
1046
+
1047
+ #### notify
1048
+
1049
+ Display a notification. Fire-and-forget, no response expected.
1050
+
1051
+ ```json
1052
+ {
1053
+ "type": "extension_ui_request",
1054
+ "id": "uuid-5",
1055
+ "method": "notify",
1056
+ "message": "Command blocked by user",
1057
+ "notifyType": "warning"
1058
+ }
1059
+ ```
1060
+
1061
+ The `notifyType` field is `"info"`, `"warning"`, or `"error"`. Defaults to `"info"` if omitted.
1062
+
1063
+ #### setStatus
1064
+
1065
+ Set or clear a status entry in the footer/status bar. Fire-and-forget.
1066
+
1067
+ ```json
1068
+ {
1069
+ "type": "extension_ui_request",
1070
+ "id": "uuid-6",
1071
+ "method": "setStatus",
1072
+ "statusKey": "my-ext",
1073
+ "statusText": "Turn 3 running..."
1074
+ }
1075
+ ```
1076
+
1077
+ Send `statusText: undefined` (or omit it) to clear the status entry for that key.
1078
+
1079
+ #### setWidget
1080
+
1081
+ Set or clear a widget (block of text lines) displayed above or below the editor. Fire-and-forget.
1082
+
1083
+ ```json
1084
+ {
1085
+ "type": "extension_ui_request",
1086
+ "id": "uuid-7",
1087
+ "method": "setWidget",
1088
+ "widgetKey": "my-ext",
1089
+ "widgetLines": ["--- My Widget ---", "Line 1", "Line 2"],
1090
+ "widgetPlacement": "aboveEditor"
1091
+ }
1092
+ ```
1093
+
1094
+ Send `widgetLines: undefined` (or omit it) to clear the widget. The `widgetPlacement` field is `"aboveEditor"` (default) or `"belowEditor"`. Only string arrays are supported in RPC mode; component factories are ignored.
1095
+
1096
+ #### setTitle
1097
+
1098
+ Set the terminal window/tab title. Fire-and-forget.
1099
+
1100
+ ```json
1101
+ {
1102
+ "type": "extension_ui_request",
1103
+ "id": "uuid-8",
1104
+ "method": "setTitle",
1105
+ "title": "pi - my project"
1106
+ }
1107
+ ```
1108
+
1109
+ #### set_editor_text
1110
+
1111
+ Set the text in the input editor. Fire-and-forget.
1112
+
1113
+ ```json
1114
+ {
1115
+ "type": "extension_ui_request",
1116
+ "id": "uuid-9",
1117
+ "method": "set_editor_text",
1118
+ "text": "prefilled text for the user"
1119
+ }
1120
+ ```
1121
+
1122
+ ### Extension UI Responses (stdin)
1123
+
1124
+ Responses are sent for dialog methods only (`select`, `confirm`, `input`, `editor`). The `id` must match the request.
1125
+
1126
+ #### Value response (select, input, editor)
1127
+
1128
+ ```json
1129
+ {"type": "extension_ui_response", "id": "uuid-1", "value": "Allow"}
1130
+ ```
1131
+
1132
+ #### Confirmation response (confirm)
1133
+
1134
+ ```json
1135
+ {"type": "extension_ui_response", "id": "uuid-2", "confirmed": true}
1136
+ ```
1137
+
1138
+ #### Cancellation response (any dialog)
1139
+
1140
+ Dismiss any dialog method. The extension receives `undefined` (for select/input/editor) or `false` (for confirm).
1141
+
1142
+ ```json
1143
+ {"type": "extension_ui_response", "id": "uuid-3", "cancelled": true}
1144
+ ```
1145
+
1146
+ ## Error Handling
1147
+
1148
+ Failed commands return a response with `success: false`:
1149
+
1150
+ ```json
1151
+ {
1152
+ "type": "response",
1153
+ "command": "set_model",
1154
+ "success": false,
1155
+ "error": "Model not found: invalid/model"
1156
+ }
1157
+ ```
1158
+
1159
+ Parse errors:
1160
+
1161
+ ```json
1162
+ {
1163
+ "type": "response",
1164
+ "command": "parse",
1165
+ "success": false,
1166
+ "error": "Failed to parse command: Unexpected token..."
1167
+ }
1168
+ ```
1169
+
1170
+ ## Types
1171
+
1172
+ Source files:
1173
+ - [`packages/ai/src/types.ts`](../../ai/src/types.ts) - `Model`, `UserMessage`, `AssistantMessage`, `ToolResultMessage`
1174
+ - [`packages/agent/src/types.ts`](../../agent/src/types.ts) - `AgentMessage`, `AgentEvent`
1175
+ - [`src/core/messages.ts`](../src/core/messages.ts) - `BashExecutionMessage`
1176
+ - [`src/modes/rpc/rpc-types.ts`](../src/modes/rpc/rpc-types.ts) - RPC command/response types, extension UI request/response types
1177
+
1178
+ ### Model
1179
+
1180
+ ```json
1181
+ {
1182
+ "id": "claude-sonnet-4-20250514",
1183
+ "name": "Claude Sonnet 4",
1184
+ "api": "anthropic-messages",
1185
+ "provider": "anthropic",
1186
+ "baseUrl": "https://api.anthropic.com",
1187
+ "reasoning": true,
1188
+ "input": ["text", "image"],
1189
+ "contextWindow": 200000,
1190
+ "maxTokens": 16384,
1191
+ "cost": {
1192
+ "input": 3.0,
1193
+ "output": 15.0,
1194
+ "cacheRead": 0.3,
1195
+ "cacheWrite": 3.75
1196
+ }
1197
+ }
1198
+ ```
1199
+
1200
+ ### UserMessage
1201
+
1202
+ ```json
1203
+ {
1204
+ "role": "user",
1205
+ "content": "Hello!",
1206
+ "timestamp": 1733234567890,
1207
+ "attachments": []
1208
+ }
1209
+ ```
1210
+
1211
+ The `content` field can be a string or an array of `TextContent`/`ImageContent` blocks.
1212
+
1213
+ ### AssistantMessage
1214
+
1215
+ ```json
1216
+ {
1217
+ "role": "assistant",
1218
+ "content": [
1219
+ {"type": "text", "text": "Hello! How can I help?"},
1220
+ {"type": "thinking", "thinking": "User is greeting me..."},
1221
+ {"type": "toolCall", "id": "call_123", "name": "bash", "arguments": {"command": "ls"}}
1222
+ ],
1223
+ "api": "anthropic-messages",
1224
+ "provider": "anthropic",
1225
+ "model": "claude-sonnet-4-20250514",
1226
+ "usage": {
1227
+ "input": 100,
1228
+ "output": 50,
1229
+ "cacheRead": 0,
1230
+ "cacheWrite": 0,
1231
+ "cost": {"input": 0.0003, "output": 0.00075, "cacheRead": 0, "cacheWrite": 0, "total": 0.00105}
1232
+ },
1233
+ "stopReason": "stop",
1234
+ "timestamp": 1733234567890
1235
+ }
1236
+ ```
1237
+
1238
+ Stop reasons: `"stop"`, `"length"`, `"toolUse"`, `"error"`, `"aborted"`
1239
+
1240
+ ### ToolResultMessage
1241
+
1242
+ ```json
1243
+ {
1244
+ "role": "toolResult",
1245
+ "toolCallId": "call_123",
1246
+ "toolName": "bash",
1247
+ "content": [{"type": "text", "text": "total 48\ndrwxr-xr-x ..."}],
1248
+ "isError": false,
1249
+ "timestamp": 1733234567890
1250
+ }
1251
+ ```
1252
+
1253
+ ### BashExecutionMessage
1254
+
1255
+ Created by the `bash` RPC command (not by LLM tool calls):
1256
+
1257
+ ```json
1258
+ {
1259
+ "role": "bashExecution",
1260
+ "command": "ls -la",
1261
+ "output": "total 48\ndrwxr-xr-x ...",
1262
+ "exitCode": 0,
1263
+ "cancelled": false,
1264
+ "truncated": false,
1265
+ "fullOutputPath": null,
1266
+ "timestamp": 1733234567890
1267
+ }
1268
+ ```
1269
+
1270
+ ### Attachment
1271
+
1272
+ ```json
1273
+ {
1274
+ "id": "img1",
1275
+ "type": "image",
1276
+ "fileName": "photo.jpg",
1277
+ "mimeType": "image/jpeg",
1278
+ "size": 102400,
1279
+ "content": "base64-encoded-data...",
1280
+ "extractedText": null,
1281
+ "preview": null
1282
+ }
1283
+ ```
1284
+
1285
+ ## Example: Basic Client (Python)
1286
+
1287
+ ```python
1288
+ import subprocess
1289
+ import json
1290
+
1291
+ proc = subprocess.Popen(
1292
+ ["pi", "--mode", "rpc", "--no-session"],
1293
+ stdin=subprocess.PIPE,
1294
+ stdout=subprocess.PIPE,
1295
+ text=True
1296
+ )
1297
+
1298
+ def send(cmd):
1299
+ proc.stdin.write(json.dumps(cmd) + "\n")
1300
+ proc.stdin.flush()
1301
+
1302
+ def read_events():
1303
+ for line in proc.stdout:
1304
+ yield json.loads(line)
1305
+
1306
+ # Send prompt
1307
+ send({"type": "prompt", "message": "Hello!"})
1308
+
1309
+ # Process events
1310
+ for event in read_events():
1311
+ if event.get("type") == "message_update":
1312
+ delta = event.get("assistantMessageEvent", {})
1313
+ if delta.get("type") == "text_delta":
1314
+ print(delta["delta"], end="", flush=True)
1315
+
1316
+ if event.get("type") == "agent_end":
1317
+ print()
1318
+ break
1319
+ ```
1320
+
1321
+ ## Example: Interactive Client (Node.js)
1322
+
1323
+ See [`test/rpc-example.ts`](../test/rpc-example.ts) for a complete interactive example, or [`src/modes/rpc/rpc-client.ts`](../src/modes/rpc/rpc-client.ts) for a typed client implementation.
1324
+
1325
+ For a complete example of handling the extension UI protocol, see [`examples/rpc-extension-ui.ts`](../examples/rpc-extension-ui.ts) which pairs with the [`examples/extensions/rpc-demo.ts`](../examples/extensions/rpc-demo.ts) extension.
1326
+
1327
+ ```javascript
1328
+ const { spawn } = require("child_process");
1329
+ const { StringDecoder } = require("string_decoder");
1330
+
1331
+ const agent = spawn("pi", ["--mode", "rpc", "--no-session"]);
1332
+
1333
+ function attachJsonlReader(stream, onLine) {
1334
+ const decoder = new StringDecoder("utf8");
1335
+ let buffer = "";
1336
+
1337
+ stream.on("data", (chunk) => {
1338
+ buffer += typeof chunk === "string" ? chunk : decoder.write(chunk);
1339
+
1340
+ while (true) {
1341
+ const newlineIndex = buffer.indexOf("\n");
1342
+ if (newlineIndex === -1) break;
1343
+
1344
+ let line = buffer.slice(0, newlineIndex);
1345
+ buffer = buffer.slice(newlineIndex + 1);
1346
+ if (line.endsWith("\r")) line = line.slice(0, -1);
1347
+ onLine(line);
1348
+ }
1349
+ });
1350
+
1351
+ stream.on("end", () => {
1352
+ buffer += decoder.end();
1353
+ if (buffer.length > 0) {
1354
+ onLine(buffer.endsWith("\r") ? buffer.slice(0, -1) : buffer);
1355
+ }
1356
+ });
1357
+ }
1358
+
1359
+ attachJsonlReader(agent.stdout, (line) => {
1360
+ const event = JSON.parse(line);
1361
+
1362
+ if (event.type === "message_update") {
1363
+ const { assistantMessageEvent } = event;
1364
+ if (assistantMessageEvent.type === "text_delta") {
1365
+ process.stdout.write(assistantMessageEvent.delta);
1366
+ }
1367
+ }
1368
+ });
1369
+
1370
+ // Send prompt
1371
+ agent.stdin.write(JSON.stringify({ type: "prompt", message: "Hello" }) + "\n");
1372
+
1373
+ // Abort on Ctrl+C
1374
+ process.on("SIGINT", () => {
1375
+ agent.stdin.write(JSON.stringify({ type: "abort" }) + "\n");
1376
+ });
1377
+ ```