@vandeepunk/pi-coding-agent 0.0.1

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 (595) hide show
  1. package/CHANGELOG.md +2564 -0
  2. package/README.md +555 -0
  3. package/dist/cli/args.d.ts +47 -0
  4. package/dist/cli/args.d.ts.map +1 -0
  5. package/dist/cli/args.js +286 -0
  6. package/dist/cli/args.js.map +1 -0
  7. package/dist/cli/config-selector.d.ts +14 -0
  8. package/dist/cli/config-selector.d.ts.map +1 -0
  9. package/dist/cli/config-selector.js +31 -0
  10. package/dist/cli/config-selector.js.map +1 -0
  11. package/dist/cli/file-processor.d.ts +15 -0
  12. package/dist/cli/file-processor.d.ts.map +1 -0
  13. package/dist/cli/file-processor.js +79 -0
  14. package/dist/cli/file-processor.js.map +1 -0
  15. package/dist/cli/list-models.d.ts +9 -0
  16. package/dist/cli/list-models.d.ts.map +1 -0
  17. package/dist/cli/list-models.js +92 -0
  18. package/dist/cli/list-models.js.map +1 -0
  19. package/dist/cli/session-picker.d.ts +9 -0
  20. package/dist/cli/session-picker.d.ts.map +1 -0
  21. package/dist/cli/session-picker.js +34 -0
  22. package/dist/cli/session-picker.js.map +1 -0
  23. package/dist/cli.d.ts +3 -0
  24. package/dist/cli.d.ts.map +1 -0
  25. package/dist/cli.js +11 -0
  26. package/dist/cli.js.map +1 -0
  27. package/dist/config.d.ts +68 -0
  28. package/dist/config.d.ts.map +1 -0
  29. package/dist/config.js +203 -0
  30. package/dist/config.js.map +1 -0
  31. package/dist/core/agent-session.d.ts +574 -0
  32. package/dist/core/agent-session.d.ts.map +1 -0
  33. package/dist/core/agent-session.js +2260 -0
  34. package/dist/core/agent-session.js.map +1 -0
  35. package/dist/core/auth-storage.d.ts +102 -0
  36. package/dist/core/auth-storage.d.ts.map +1 -0
  37. package/dist/core/auth-storage.js +282 -0
  38. package/dist/core/auth-storage.js.map +1 -0
  39. package/dist/core/bash-executor.d.ts +47 -0
  40. package/dist/core/bash-executor.d.ts.map +1 -0
  41. package/dist/core/bash-executor.js +212 -0
  42. package/dist/core/bash-executor.js.map +1 -0
  43. package/dist/core/compaction/branch-summarization.d.ts +86 -0
  44. package/dist/core/compaction/branch-summarization.d.ts.map +1 -0
  45. package/dist/core/compaction/branch-summarization.js +242 -0
  46. package/dist/core/compaction/branch-summarization.js.map +1 -0
  47. package/dist/core/compaction/compaction.d.ts +121 -0
  48. package/dist/core/compaction/compaction.d.ts.map +1 -0
  49. package/dist/core/compaction/compaction.js +607 -0
  50. package/dist/core/compaction/compaction.js.map +1 -0
  51. package/dist/core/compaction/index.d.ts +7 -0
  52. package/dist/core/compaction/index.d.ts.map +1 -0
  53. package/dist/core/compaction/index.js +7 -0
  54. package/dist/core/compaction/index.js.map +1 -0
  55. package/dist/core/compaction/utils.d.ts +35 -0
  56. package/dist/core/compaction/utils.d.ts.map +1 -0
  57. package/dist/core/compaction/utils.js +138 -0
  58. package/dist/core/compaction/utils.js.map +1 -0
  59. package/dist/core/defaults.d.ts +3 -0
  60. package/dist/core/defaults.d.ts.map +1 -0
  61. package/dist/core/defaults.js +2 -0
  62. package/dist/core/defaults.js.map +1 -0
  63. package/dist/core/diagnostics.d.ts +15 -0
  64. package/dist/core/diagnostics.d.ts.map +1 -0
  65. package/dist/core/diagnostics.js +2 -0
  66. package/dist/core/diagnostics.js.map +1 -0
  67. package/dist/core/event-bus.d.ts +9 -0
  68. package/dist/core/event-bus.d.ts.map +1 -0
  69. package/dist/core/event-bus.js +25 -0
  70. package/dist/core/event-bus.js.map +1 -0
  71. package/dist/core/exec.d.ts +29 -0
  72. package/dist/core/exec.d.ts.map +1 -0
  73. package/dist/core/exec.js +71 -0
  74. package/dist/core/exec.js.map +1 -0
  75. package/dist/core/export-html/ansi-to-html.d.ts +22 -0
  76. package/dist/core/export-html/ansi-to-html.d.ts.map +1 -0
  77. package/dist/core/export-html/ansi-to-html.js +249 -0
  78. package/dist/core/export-html/ansi-to-html.js.map +1 -0
  79. package/dist/core/export-html/index.d.ts +34 -0
  80. package/dist/core/export-html/index.d.ts.map +1 -0
  81. package/dist/core/export-html/index.js +222 -0
  82. package/dist/core/export-html/index.js.map +1 -0
  83. package/dist/core/export-html/template.css +909 -0
  84. package/dist/core/export-html/template.html +54 -0
  85. package/dist/core/export-html/template.js +1549 -0
  86. package/dist/core/export-html/tool-renderer.d.ts +35 -0
  87. package/dist/core/export-html/tool-renderer.d.ts.map +1 -0
  88. package/dist/core/export-html/tool-renderer.js +57 -0
  89. package/dist/core/export-html/tool-renderer.js.map +1 -0
  90. package/dist/core/export-html/vendor/highlight.min.js +1213 -0
  91. package/dist/core/export-html/vendor/marked.min.js +6 -0
  92. package/dist/core/extensions/index.d.ts +11 -0
  93. package/dist/core/extensions/index.d.ts.map +1 -0
  94. package/dist/core/extensions/index.js +9 -0
  95. package/dist/core/extensions/index.js.map +1 -0
  96. package/dist/core/extensions/loader.d.ts +25 -0
  97. package/dist/core/extensions/loader.d.ts.map +1 -0
  98. package/dist/core/extensions/loader.js +400 -0
  99. package/dist/core/extensions/loader.js.map +1 -0
  100. package/dist/core/extensions/runner.d.ts +129 -0
  101. package/dist/core/extensions/runner.d.ts.map +1 -0
  102. package/dist/core/extensions/runner.js +576 -0
  103. package/dist/core/extensions/runner.js.map +1 -0
  104. package/dist/core/extensions/types.d.ts +928 -0
  105. package/dist/core/extensions/types.d.ts.map +1 -0
  106. package/dist/core/extensions/types.js +35 -0
  107. package/dist/core/extensions/types.js.map +1 -0
  108. package/dist/core/extensions/wrapper.d.ts +27 -0
  109. package/dist/core/extensions/wrapper.d.ts.map +1 -0
  110. package/dist/core/extensions/wrapper.js +102 -0
  111. package/dist/core/extensions/wrapper.js.map +1 -0
  112. package/dist/core/footer-data-provider.d.ts +32 -0
  113. package/dist/core/footer-data-provider.d.ts.map +1 -0
  114. package/dist/core/footer-data-provider.js +134 -0
  115. package/dist/core/footer-data-provider.js.map +1 -0
  116. package/dist/core/index.d.ts +9 -0
  117. package/dist/core/index.d.ts.map +1 -0
  118. package/dist/core/index.js +9 -0
  119. package/dist/core/index.js.map +1 -0
  120. package/dist/core/keybindings.d.ts +55 -0
  121. package/dist/core/keybindings.d.ts.map +1 -0
  122. package/dist/core/keybindings.js +153 -0
  123. package/dist/core/keybindings.js.map +1 -0
  124. package/dist/core/messages.d.ts +77 -0
  125. package/dist/core/messages.d.ts.map +1 -0
  126. package/dist/core/messages.js +123 -0
  127. package/dist/core/messages.js.map +1 -0
  128. package/dist/core/model-registry.d.ts +100 -0
  129. package/dist/core/model-registry.d.ts.map +1 -0
  130. package/dist/core/model-registry.js +419 -0
  131. package/dist/core/model-registry.js.map +1 -0
  132. package/dist/core/model-resolver.d.ts +76 -0
  133. package/dist/core/model-resolver.d.ts.map +1 -0
  134. package/dist/core/model-resolver.js +313 -0
  135. package/dist/core/model-resolver.js.map +1 -0
  136. package/dist/core/package-manager.d.ts +131 -0
  137. package/dist/core/package-manager.d.ts.map +1 -0
  138. package/dist/core/package-manager.js +1290 -0
  139. package/dist/core/package-manager.js.map +1 -0
  140. package/dist/core/prompt-templates.d.ts +50 -0
  141. package/dist/core/prompt-templates.d.ts.map +1 -0
  142. package/dist/core/prompt-templates.js +251 -0
  143. package/dist/core/prompt-templates.js.map +1 -0
  144. package/dist/core/resolve-config-value.d.ts +17 -0
  145. package/dist/core/resolve-config-value.d.ts.map +1 -0
  146. package/dist/core/resolve-config-value.js +59 -0
  147. package/dist/core/resolve-config-value.js.map +1 -0
  148. package/dist/core/resource-loader.d.ts +184 -0
  149. package/dist/core/resource-loader.d.ts.map +1 -0
  150. package/dist/core/resource-loader.js +673 -0
  151. package/dist/core/resource-loader.js.map +1 -0
  152. package/dist/core/sdk.d.ts +90 -0
  153. package/dist/core/sdk.d.ts.map +1 -0
  154. package/dist/core/sdk.js +234 -0
  155. package/dist/core/sdk.js.map +1 -0
  156. package/dist/core/session-manager.d.ts +323 -0
  157. package/dist/core/session-manager.d.ts.map +1 -0
  158. package/dist/core/session-manager.js +1091 -0
  159. package/dist/core/session-manager.js.map +1 -0
  160. package/dist/core/settings-manager.d.ts +187 -0
  161. package/dist/core/settings-manager.d.ts.map +1 -0
  162. package/dist/core/settings-manager.js +552 -0
  163. package/dist/core/settings-manager.js.map +1 -0
  164. package/dist/core/skills.d.ts +58 -0
  165. package/dist/core/skills.d.ts.map +1 -0
  166. package/dist/core/skills.js +310 -0
  167. package/dist/core/skills.js.map +1 -0
  168. package/dist/core/slash-commands.d.ts +15 -0
  169. package/dist/core/slash-commands.d.ts.map +1 -0
  170. package/dist/core/slash-commands.js +21 -0
  171. package/dist/core/slash-commands.js.map +1 -0
  172. package/dist/core/system-prompt.d.ts +24 -0
  173. package/dist/core/system-prompt.d.ts.map +1 -0
  174. package/dist/core/system-prompt.js +137 -0
  175. package/dist/core/system-prompt.js.map +1 -0
  176. package/dist/core/timings.d.ts +7 -0
  177. package/dist/core/timings.d.ts.map +1 -0
  178. package/dist/core/timings.js +25 -0
  179. package/dist/core/timings.js.map +1 -0
  180. package/dist/core/tools/bash.d.ts +55 -0
  181. package/dist/core/tools/bash.d.ts.map +1 -0
  182. package/dist/core/tools/bash.js +242 -0
  183. package/dist/core/tools/bash.js.map +1 -0
  184. package/dist/core/tools/edit-diff.d.ts +63 -0
  185. package/dist/core/tools/edit-diff.d.ts.map +1 -0
  186. package/dist/core/tools/edit-diff.js +243 -0
  187. package/dist/core/tools/edit-diff.js.map +1 -0
  188. package/dist/core/tools/edit.d.ts +39 -0
  189. package/dist/core/tools/edit.d.ts.map +1 -0
  190. package/dist/core/tools/edit.js +146 -0
  191. package/dist/core/tools/edit.js.map +1 -0
  192. package/dist/core/tools/find.d.ts +39 -0
  193. package/dist/core/tools/find.d.ts.map +1 -0
  194. package/dist/core/tools/find.js +206 -0
  195. package/dist/core/tools/find.js.map +1 -0
  196. package/dist/core/tools/grep.d.ts +45 -0
  197. package/dist/core/tools/grep.d.ts.map +1 -0
  198. package/dist/core/tools/grep.js +239 -0
  199. package/dist/core/tools/grep.js.map +1 -0
  200. package/dist/core/tools/index.d.ts +73 -0
  201. package/dist/core/tools/index.d.ts.map +1 -0
  202. package/dist/core/tools/index.js +61 -0
  203. package/dist/core/tools/index.js.map +1 -0
  204. package/dist/core/tools/ls.d.ts +40 -0
  205. package/dist/core/tools/ls.d.ts.map +1 -0
  206. package/dist/core/tools/ls.js +118 -0
  207. package/dist/core/tools/ls.js.map +1 -0
  208. package/dist/core/tools/path-utils.d.ts +8 -0
  209. package/dist/core/tools/path-utils.d.ts.map +1 -0
  210. package/dist/core/tools/path-utils.js +81 -0
  211. package/dist/core/tools/path-utils.js.map +1 -0
  212. package/dist/core/tools/read.d.ts +39 -0
  213. package/dist/core/tools/read.d.ts.map +1 -0
  214. package/dist/core/tools/read.js +166 -0
  215. package/dist/core/tools/read.js.map +1 -0
  216. package/dist/core/tools/truncate.d.ts +70 -0
  217. package/dist/core/tools/truncate.d.ts.map +1 -0
  218. package/dist/core/tools/truncate.js +205 -0
  219. package/dist/core/tools/truncate.js.map +1 -0
  220. package/dist/core/tools/write.d.ts +29 -0
  221. package/dist/core/tools/write.d.ts.map +1 -0
  222. package/dist/core/tools/write.js +78 -0
  223. package/dist/core/tools/write.js.map +1 -0
  224. package/dist/index.d.ts +27 -0
  225. package/dist/index.d.ts.map +1 -0
  226. package/dist/index.js +42 -0
  227. package/dist/index.js.map +1 -0
  228. package/dist/main.d.ts +8 -0
  229. package/dist/main.d.ts.map +1 -0
  230. package/dist/main.js +623 -0
  231. package/dist/main.js.map +1 -0
  232. package/dist/migrations.d.ts +33 -0
  233. package/dist/migrations.d.ts.map +1 -0
  234. package/dist/migrations.js +261 -0
  235. package/dist/migrations.js.map +1 -0
  236. package/dist/modes/index.d.ts +9 -0
  237. package/dist/modes/index.d.ts.map +1 -0
  238. package/dist/modes/index.js +8 -0
  239. package/dist/modes/index.js.map +1 -0
  240. package/dist/modes/interactive/components/armin.d.ts +34 -0
  241. package/dist/modes/interactive/components/armin.d.ts.map +1 -0
  242. package/dist/modes/interactive/components/armin.js +333 -0
  243. package/dist/modes/interactive/components/armin.js.map +1 -0
  244. package/dist/modes/interactive/components/assistant-message.d.ts +16 -0
  245. package/dist/modes/interactive/components/assistant-message.d.ts.map +1 -0
  246. package/dist/modes/interactive/components/assistant-message.js +91 -0
  247. package/dist/modes/interactive/components/assistant-message.js.map +1 -0
  248. package/dist/modes/interactive/components/bash-execution.d.ts +35 -0
  249. package/dist/modes/interactive/components/bash-execution.d.ts.map +1 -0
  250. package/dist/modes/interactive/components/bash-execution.js +162 -0
  251. package/dist/modes/interactive/components/bash-execution.js.map +1 -0
  252. package/dist/modes/interactive/components/bordered-loader.d.ts +16 -0
  253. package/dist/modes/interactive/components/bordered-loader.d.ts.map +1 -0
  254. package/dist/modes/interactive/components/bordered-loader.js +51 -0
  255. package/dist/modes/interactive/components/bordered-loader.js.map +1 -0
  256. package/dist/modes/interactive/components/branch-summary-message.d.ts +16 -0
  257. package/dist/modes/interactive/components/branch-summary-message.d.ts.map +1 -0
  258. package/dist/modes/interactive/components/branch-summary-message.js +44 -0
  259. package/dist/modes/interactive/components/branch-summary-message.js.map +1 -0
  260. package/dist/modes/interactive/components/compaction-summary-message.d.ts +16 -0
  261. package/dist/modes/interactive/components/compaction-summary-message.d.ts.map +1 -0
  262. package/dist/modes/interactive/components/compaction-summary-message.js +45 -0
  263. package/dist/modes/interactive/components/compaction-summary-message.js.map +1 -0
  264. package/dist/modes/interactive/components/config-selector.d.ts +71 -0
  265. package/dist/modes/interactive/components/config-selector.d.ts.map +1 -0
  266. package/dist/modes/interactive/components/config-selector.js +479 -0
  267. package/dist/modes/interactive/components/config-selector.js.map +1 -0
  268. package/dist/modes/interactive/components/countdown-timer.d.ts +14 -0
  269. package/dist/modes/interactive/components/countdown-timer.d.ts.map +1 -0
  270. package/dist/modes/interactive/components/countdown-timer.js +33 -0
  271. package/dist/modes/interactive/components/countdown-timer.js.map +1 -0
  272. package/dist/modes/interactive/components/custom-editor.d.ts +21 -0
  273. package/dist/modes/interactive/components/custom-editor.d.ts.map +1 -0
  274. package/dist/modes/interactive/components/custom-editor.js +70 -0
  275. package/dist/modes/interactive/components/custom-editor.js.map +1 -0
  276. package/dist/modes/interactive/components/custom-message.d.ts +20 -0
  277. package/dist/modes/interactive/components/custom-message.d.ts.map +1 -0
  278. package/dist/modes/interactive/components/custom-message.js +79 -0
  279. package/dist/modes/interactive/components/custom-message.js.map +1 -0
  280. package/dist/modes/interactive/components/daxnuts.d.ts +23 -0
  281. package/dist/modes/interactive/components/daxnuts.d.ts.map +1 -0
  282. package/dist/modes/interactive/components/daxnuts.js +140 -0
  283. package/dist/modes/interactive/components/daxnuts.js.map +1 -0
  284. package/dist/modes/interactive/components/diff.d.ts +12 -0
  285. package/dist/modes/interactive/components/diff.d.ts.map +1 -0
  286. package/dist/modes/interactive/components/diff.js +133 -0
  287. package/dist/modes/interactive/components/diff.js.map +1 -0
  288. package/dist/modes/interactive/components/dynamic-border.d.ts +15 -0
  289. package/dist/modes/interactive/components/dynamic-border.d.ts.map +1 -0
  290. package/dist/modes/interactive/components/dynamic-border.js +21 -0
  291. package/dist/modes/interactive/components/dynamic-border.js.map +1 -0
  292. package/dist/modes/interactive/components/extension-editor.d.ts +17 -0
  293. package/dist/modes/interactive/components/extension-editor.d.ts.map +1 -0
  294. package/dist/modes/interactive/components/extension-editor.js +102 -0
  295. package/dist/modes/interactive/components/extension-editor.js.map +1 -0
  296. package/dist/modes/interactive/components/extension-input.d.ts +23 -0
  297. package/dist/modes/interactive/components/extension-input.d.ts.map +1 -0
  298. package/dist/modes/interactive/components/extension-input.js +61 -0
  299. package/dist/modes/interactive/components/extension-input.js.map +1 -0
  300. package/dist/modes/interactive/components/extension-selector.d.ts +24 -0
  301. package/dist/modes/interactive/components/extension-selector.d.ts.map +1 -0
  302. package/dist/modes/interactive/components/extension-selector.js +78 -0
  303. package/dist/modes/interactive/components/extension-selector.js.map +1 -0
  304. package/dist/modes/interactive/components/footer.d.ts +26 -0
  305. package/dist/modes/interactive/components/footer.d.ts.map +1 -0
  306. package/dist/modes/interactive/components/footer.js +220 -0
  307. package/dist/modes/interactive/components/footer.js.map +1 -0
  308. package/dist/modes/interactive/components/index.d.ts +32 -0
  309. package/dist/modes/interactive/components/index.d.ts.map +1 -0
  310. package/dist/modes/interactive/components/index.js +33 -0
  311. package/dist/modes/interactive/components/index.js.map +1 -0
  312. package/dist/modes/interactive/components/keybinding-hints.d.ts +41 -0
  313. package/dist/modes/interactive/components/keybinding-hints.d.ts.map +1 -0
  314. package/dist/modes/interactive/components/keybinding-hints.js +61 -0
  315. package/dist/modes/interactive/components/keybinding-hints.js.map +1 -0
  316. package/dist/modes/interactive/components/login-dialog.d.ts +42 -0
  317. package/dist/modes/interactive/components/login-dialog.d.ts.map +1 -0
  318. package/dist/modes/interactive/components/login-dialog.js +145 -0
  319. package/dist/modes/interactive/components/login-dialog.js.map +1 -0
  320. package/dist/modes/interactive/components/model-selector.d.ts +47 -0
  321. package/dist/modes/interactive/components/model-selector.d.ts.map +1 -0
  322. package/dist/modes/interactive/components/model-selector.js +266 -0
  323. package/dist/modes/interactive/components/model-selector.js.map +1 -0
  324. package/dist/modes/interactive/components/oauth-selector.d.ts +19 -0
  325. package/dist/modes/interactive/components/oauth-selector.d.ts.map +1 -0
  326. package/dist/modes/interactive/components/oauth-selector.js +97 -0
  327. package/dist/modes/interactive/components/oauth-selector.js.map +1 -0
  328. package/dist/modes/interactive/components/scoped-models-selector.d.ts +49 -0
  329. package/dist/modes/interactive/components/scoped-models-selector.d.ts.map +1 -0
  330. package/dist/modes/interactive/components/scoped-models-selector.js +270 -0
  331. package/dist/modes/interactive/components/scoped-models-selector.js.map +1 -0
  332. package/dist/modes/interactive/components/session-selector-search.d.ts +23 -0
  333. package/dist/modes/interactive/components/session-selector-search.d.ts.map +1 -0
  334. package/dist/modes/interactive/components/session-selector-search.js +155 -0
  335. package/dist/modes/interactive/components/session-selector-search.js.map +1 -0
  336. package/dist/modes/interactive/components/session-selector.d.ts +95 -0
  337. package/dist/modes/interactive/components/session-selector.d.ts.map +1 -0
  338. package/dist/modes/interactive/components/session-selector.js +851 -0
  339. package/dist/modes/interactive/components/session-selector.js.map +1 -0
  340. package/dist/modes/interactive/components/settings-selector.d.ts +53 -0
  341. package/dist/modes/interactive/components/settings-selector.d.ts.map +1 -0
  342. package/dist/modes/interactive/components/settings-selector.js +277 -0
  343. package/dist/modes/interactive/components/settings-selector.js.map +1 -0
  344. package/dist/modes/interactive/components/show-images-selector.d.ts +10 -0
  345. package/dist/modes/interactive/components/show-images-selector.d.ts.map +1 -0
  346. package/dist/modes/interactive/components/show-images-selector.js +35 -0
  347. package/dist/modes/interactive/components/show-images-selector.js.map +1 -0
  348. package/dist/modes/interactive/components/skill-invocation-message.d.ts +17 -0
  349. package/dist/modes/interactive/components/skill-invocation-message.d.ts.map +1 -0
  350. package/dist/modes/interactive/components/skill-invocation-message.js +47 -0
  351. package/dist/modes/interactive/components/skill-invocation-message.js.map +1 -0
  352. package/dist/modes/interactive/components/theme-selector.d.ts +11 -0
  353. package/dist/modes/interactive/components/theme-selector.d.ts.map +1 -0
  354. package/dist/modes/interactive/components/theme-selector.js +46 -0
  355. package/dist/modes/interactive/components/theme-selector.js.map +1 -0
  356. package/dist/modes/interactive/components/thinking-selector.d.ts +11 -0
  357. package/dist/modes/interactive/components/thinking-selector.d.ts.map +1 -0
  358. package/dist/modes/interactive/components/thinking-selector.js +47 -0
  359. package/dist/modes/interactive/components/thinking-selector.js.map +1 -0
  360. package/dist/modes/interactive/components/tool-execution.d.ts +70 -0
  361. package/dist/modes/interactive/components/tool-execution.d.ts.map +1 -0
  362. package/dist/modes/interactive/components/tool-execution.js +621 -0
  363. package/dist/modes/interactive/components/tool-execution.js.map +1 -0
  364. package/dist/modes/interactive/components/tree-selector.d.ts +68 -0
  365. package/dist/modes/interactive/components/tree-selector.d.ts.map +1 -0
  366. package/dist/modes/interactive/components/tree-selector.js +934 -0
  367. package/dist/modes/interactive/components/tree-selector.js.map +1 -0
  368. package/dist/modes/interactive/components/user-message-selector.d.ts +30 -0
  369. package/dist/modes/interactive/components/user-message-selector.d.ts.map +1 -0
  370. package/dist/modes/interactive/components/user-message-selector.js +113 -0
  371. package/dist/modes/interactive/components/user-message-selector.js.map +1 -0
  372. package/dist/modes/interactive/components/user-message.d.ts +8 -0
  373. package/dist/modes/interactive/components/user-message.d.ts.map +1 -0
  374. package/dist/modes/interactive/components/user-message.js +16 -0
  375. package/dist/modes/interactive/components/user-message.js.map +1 -0
  376. package/dist/modes/interactive/components/visual-truncate.d.ts +24 -0
  377. package/dist/modes/interactive/components/visual-truncate.d.ts.map +1 -0
  378. package/dist/modes/interactive/components/visual-truncate.js +33 -0
  379. package/dist/modes/interactive/components/visual-truncate.js.map +1 -0
  380. package/dist/modes/interactive/interactive-mode.d.ts +313 -0
  381. package/dist/modes/interactive/interactive-mode.d.ts.map +1 -0
  382. package/dist/modes/interactive/interactive-mode.js +3664 -0
  383. package/dist/modes/interactive/interactive-mode.js.map +1 -0
  384. package/dist/modes/interactive/theme/dark.json +85 -0
  385. package/dist/modes/interactive/theme/light.json +84 -0
  386. package/dist/modes/interactive/theme/theme-schema.json +335 -0
  387. package/dist/modes/interactive/theme/theme.d.ts +78 -0
  388. package/dist/modes/interactive/theme/theme.d.ts.map +1 -0
  389. package/dist/modes/interactive/theme/theme.js +944 -0
  390. package/dist/modes/interactive/theme/theme.js.map +1 -0
  391. package/dist/modes/print-mode.d.ts +28 -0
  392. package/dist/modes/print-mode.d.ts.map +1 -0
  393. package/dist/modes/print-mode.js +98 -0
  394. package/dist/modes/print-mode.js.map +1 -0
  395. package/dist/modes/rpc/rpc-client.d.ts +217 -0
  396. package/dist/modes/rpc/rpc-client.d.ts.map +1 -0
  397. package/dist/modes/rpc/rpc-client.js +405 -0
  398. package/dist/modes/rpc/rpc-client.js.map +1 -0
  399. package/dist/modes/rpc/rpc-mode.d.ts +20 -0
  400. package/dist/modes/rpc/rpc-mode.d.ts.map +1 -0
  401. package/dist/modes/rpc/rpc-mode.js +500 -0
  402. package/dist/modes/rpc/rpc-mode.js.map +1 -0
  403. package/dist/modes/rpc/rpc-types.d.ts +409 -0
  404. package/dist/modes/rpc/rpc-types.d.ts.map +1 -0
  405. package/dist/modes/rpc/rpc-types.js +8 -0
  406. package/dist/modes/rpc/rpc-types.js.map +1 -0
  407. package/dist/utils/changelog.d.ts +21 -0
  408. package/dist/utils/changelog.d.ts.map +1 -0
  409. package/dist/utils/changelog.js +87 -0
  410. package/dist/utils/changelog.js.map +1 -0
  411. package/dist/utils/clipboard-image.d.ts +11 -0
  412. package/dist/utils/clipboard-image.d.ts.map +1 -0
  413. package/dist/utils/clipboard-image.js +162 -0
  414. package/dist/utils/clipboard-image.js.map +1 -0
  415. package/dist/utils/clipboard-native.d.ts +7 -0
  416. package/dist/utils/clipboard-native.d.ts.map +1 -0
  417. package/dist/utils/clipboard-native.js +14 -0
  418. package/dist/utils/clipboard-native.js.map +1 -0
  419. package/dist/utils/clipboard.d.ts +2 -0
  420. package/dist/utils/clipboard.d.ts.map +1 -0
  421. package/dist/utils/clipboard.js +67 -0
  422. package/dist/utils/clipboard.js.map +1 -0
  423. package/dist/utils/frontmatter.d.ts +8 -0
  424. package/dist/utils/frontmatter.d.ts.map +1 -0
  425. package/dist/utils/frontmatter.js +26 -0
  426. package/dist/utils/frontmatter.js.map +1 -0
  427. package/dist/utils/git.d.ts +2 -0
  428. package/dist/utils/git.d.ts.map +1 -0
  429. package/dist/utils/git.js +6 -0
  430. package/dist/utils/git.js.map +1 -0
  431. package/dist/utils/image-convert.d.ts +9 -0
  432. package/dist/utils/image-convert.d.ts.map +1 -0
  433. package/dist/utils/image-convert.js +35 -0
  434. package/dist/utils/image-convert.js.map +1 -0
  435. package/dist/utils/image-resize.d.ts +36 -0
  436. package/dist/utils/image-resize.d.ts.map +1 -0
  437. package/dist/utils/image-resize.js +181 -0
  438. package/dist/utils/image-resize.js.map +1 -0
  439. package/dist/utils/mime.d.ts +2 -0
  440. package/dist/utils/mime.d.ts.map +1 -0
  441. package/dist/utils/mime.js +26 -0
  442. package/dist/utils/mime.js.map +1 -0
  443. package/dist/utils/photon.d.ts +21 -0
  444. package/dist/utils/photon.d.ts.map +1 -0
  445. package/dist/utils/photon.js +121 -0
  446. package/dist/utils/photon.js.map +1 -0
  447. package/dist/utils/shell.d.ts +26 -0
  448. package/dist/utils/shell.d.ts.map +1 -0
  449. package/dist/utils/shell.js +186 -0
  450. package/dist/utils/shell.js.map +1 -0
  451. package/dist/utils/sleep.d.ts +5 -0
  452. package/dist/utils/sleep.d.ts.map +1 -0
  453. package/dist/utils/sleep.js +17 -0
  454. package/dist/utils/sleep.js.map +1 -0
  455. package/dist/utils/tools-manager.d.ts +3 -0
  456. package/dist/utils/tools-manager.d.ts.map +1 -0
  457. package/dist/utils/tools-manager.js +201 -0
  458. package/dist/utils/tools-manager.js.map +1 -0
  459. package/docs/compaction.md +390 -0
  460. package/docs/custom-provider.md +539 -0
  461. package/docs/development.md +69 -0
  462. package/docs/extensions.md +1827 -0
  463. package/docs/images/doom-extension.png +0 -0
  464. package/docs/images/exy.png +0 -0
  465. package/docs/images/interactive-mode.png +0 -0
  466. package/docs/images/tree-view.png +0 -0
  467. package/docs/json.md +79 -0
  468. package/docs/keybindings.md +174 -0
  469. package/docs/models.md +254 -0
  470. package/docs/packages.md +191 -0
  471. package/docs/prompt-templates.md +67 -0
  472. package/docs/providers.md +168 -0
  473. package/docs/rpc.md +1311 -0
  474. package/docs/sdk.md +957 -0
  475. package/docs/session.md +412 -0
  476. package/docs/settings.md +221 -0
  477. package/docs/shell-aliases.md +13 -0
  478. package/docs/skills.md +227 -0
  479. package/docs/terminal-setup.md +70 -0
  480. package/docs/termux.md +127 -0
  481. package/docs/themes.md +295 -0
  482. package/docs/tree.md +219 -0
  483. package/docs/tui.md +887 -0
  484. package/docs/windows.md +17 -0
  485. package/examples/README.md +25 -0
  486. package/examples/extensions/README.md +202 -0
  487. package/examples/extensions/antigravity-image-gen.ts +413 -0
  488. package/examples/extensions/auto-commit-on-exit.ts +49 -0
  489. package/examples/extensions/bash-spawn-hook.ts +30 -0
  490. package/examples/extensions/bookmark.ts +50 -0
  491. package/examples/extensions/claude-rules.ts +86 -0
  492. package/examples/extensions/commands.ts +72 -0
  493. package/examples/extensions/confirm-destructive.ts +59 -0
  494. package/examples/extensions/custom-compaction.ts +114 -0
  495. package/examples/extensions/custom-footer.ts +64 -0
  496. package/examples/extensions/custom-header.ts +73 -0
  497. package/examples/extensions/custom-provider-anthropic/index.ts +604 -0
  498. package/examples/extensions/custom-provider-anthropic/package-lock.json +24 -0
  499. package/examples/extensions/custom-provider-anthropic/package.json +19 -0
  500. package/examples/extensions/custom-provider-gitlab-duo/index.ts +349 -0
  501. package/examples/extensions/custom-provider-gitlab-duo/package.json +16 -0
  502. package/examples/extensions/custom-provider-gitlab-duo/test.ts +82 -0
  503. package/examples/extensions/custom-provider-qwen-cli/index.ts +345 -0
  504. package/examples/extensions/custom-provider-qwen-cli/package.json +16 -0
  505. package/examples/extensions/dirty-repo-guard.ts +56 -0
  506. package/examples/extensions/doom-overlay/README.md +46 -0
  507. package/examples/extensions/doom-overlay/doom/build/doom.js +21 -0
  508. package/examples/extensions/doom-overlay/doom/build/doom.wasm +0 -0
  509. package/examples/extensions/doom-overlay/doom/build.sh +152 -0
  510. package/examples/extensions/doom-overlay/doom/doomgeneric_pi.c +72 -0
  511. package/examples/extensions/doom-overlay/doom-component.ts +132 -0
  512. package/examples/extensions/doom-overlay/doom-engine.ts +173 -0
  513. package/examples/extensions/doom-overlay/doom-keys.ts +104 -0
  514. package/examples/extensions/doom-overlay/index.ts +74 -0
  515. package/examples/extensions/doom-overlay/wad-finder.ts +51 -0
  516. package/examples/extensions/dynamic-resources/SKILL.md +8 -0
  517. package/examples/extensions/dynamic-resources/dynamic.json +79 -0
  518. package/examples/extensions/dynamic-resources/dynamic.md +5 -0
  519. package/examples/extensions/dynamic-resources/index.ts +15 -0
  520. package/examples/extensions/event-bus.ts +43 -0
  521. package/examples/extensions/file-trigger.ts +41 -0
  522. package/examples/extensions/git-checkpoint.ts +53 -0
  523. package/examples/extensions/handoff.ts +150 -0
  524. package/examples/extensions/hello.ts +25 -0
  525. package/examples/extensions/inline-bash.ts +94 -0
  526. package/examples/extensions/input-transform.ts +43 -0
  527. package/examples/extensions/interactive-shell.ts +196 -0
  528. package/examples/extensions/mac-system-theme.ts +47 -0
  529. package/examples/extensions/message-renderer.ts +59 -0
  530. package/examples/extensions/minimal-mode.ts +426 -0
  531. package/examples/extensions/modal-editor.ts +85 -0
  532. package/examples/extensions/model-status.ts +31 -0
  533. package/examples/extensions/notify.ts +55 -0
  534. package/examples/extensions/overlay-qa-tests.ts +881 -0
  535. package/examples/extensions/overlay-test.ts +150 -0
  536. package/examples/extensions/permission-gate.ts +34 -0
  537. package/examples/extensions/pirate.ts +47 -0
  538. package/examples/extensions/plan-mode/README.md +65 -0
  539. package/examples/extensions/plan-mode/index.ts +340 -0
  540. package/examples/extensions/plan-mode/utils.ts +168 -0
  541. package/examples/extensions/preset.ts +398 -0
  542. package/examples/extensions/protected-paths.ts +30 -0
  543. package/examples/extensions/qna.ts +119 -0
  544. package/examples/extensions/question.ts +264 -0
  545. package/examples/extensions/questionnaire.ts +427 -0
  546. package/examples/extensions/rainbow-editor.ts +88 -0
  547. package/examples/extensions/rpc-demo.ts +124 -0
  548. package/examples/extensions/sandbox/index.ts +318 -0
  549. package/examples/extensions/sandbox/package-lock.json +92 -0
  550. package/examples/extensions/sandbox/package.json +19 -0
  551. package/examples/extensions/send-user-message.ts +97 -0
  552. package/examples/extensions/session-name.ts +27 -0
  553. package/examples/extensions/shutdown-command.ts +63 -0
  554. package/examples/extensions/snake.ts +343 -0
  555. package/examples/extensions/space-invaders.ts +560 -0
  556. package/examples/extensions/ssh.ts +220 -0
  557. package/examples/extensions/status-line.ts +40 -0
  558. package/examples/extensions/subagent/README.md +172 -0
  559. package/examples/extensions/subagent/agents/planner.md +37 -0
  560. package/examples/extensions/subagent/agents/reviewer.md +35 -0
  561. package/examples/extensions/subagent/agents/scout.md +50 -0
  562. package/examples/extensions/subagent/agents/worker.md +24 -0
  563. package/examples/extensions/subagent/agents.ts +127 -0
  564. package/examples/extensions/subagent/index.ts +963 -0
  565. package/examples/extensions/subagent/prompts/implement-and-review.md +10 -0
  566. package/examples/extensions/subagent/prompts/implement.md +10 -0
  567. package/examples/extensions/subagent/prompts/scout-and-plan.md +9 -0
  568. package/examples/extensions/summarize.ts +195 -0
  569. package/examples/extensions/system-prompt-header.ts +17 -0
  570. package/examples/extensions/timed-confirm.ts +70 -0
  571. package/examples/extensions/titlebar-spinner.ts +58 -0
  572. package/examples/extensions/todo.ts +299 -0
  573. package/examples/extensions/tool-override.ts +143 -0
  574. package/examples/extensions/tools.ts +146 -0
  575. package/examples/extensions/trigger-compact.ts +40 -0
  576. package/examples/extensions/truncated-tool.ts +192 -0
  577. package/examples/extensions/widget-placement.ts +17 -0
  578. package/examples/extensions/with-deps/index.ts +36 -0
  579. package/examples/extensions/with-deps/package-lock.json +31 -0
  580. package/examples/extensions/with-deps/package.json +22 -0
  581. package/examples/rpc-extension-ui.ts +632 -0
  582. package/examples/sdk/01-minimal.ts +22 -0
  583. package/examples/sdk/02-custom-model.ts +49 -0
  584. package/examples/sdk/03-custom-prompt.ts +55 -0
  585. package/examples/sdk/04-skills.ts +46 -0
  586. package/examples/sdk/05-tools.ts +56 -0
  587. package/examples/sdk/06-extensions.ts +88 -0
  588. package/examples/sdk/07-context-files.ts +40 -0
  589. package/examples/sdk/08-prompt-templates.ts +47 -0
  590. package/examples/sdk/09-api-keys-and-oauth.ts +48 -0
  591. package/examples/sdk/10-settings.ts +38 -0
  592. package/examples/sdk/11-sessions.ts +48 -0
  593. package/examples/sdk/12-full-control.ts +82 -0
  594. package/examples/sdk/README.md +144 -0
  595. package/package.json +97 -0
@@ -0,0 +1,928 @@
1
+ /**
2
+ * Extension system types.
3
+ *
4
+ * Extensions are TypeScript modules that can:
5
+ * - Subscribe to agent lifecycle events
6
+ * - Register LLM-callable tools
7
+ * - Register commands, keyboard shortcuts, and CLI flags
8
+ * - Interact with the user via UI primitives
9
+ */
10
+ import type { AgentMessage, AgentToolResult, AgentToolUpdateCallback, ThinkingLevel } from "@mariozechner/pi-agent-core";
11
+ import type { Api, AssistantMessageEventStream, Context, ImageContent, Model, OAuthCredentials, OAuthLoginCallbacks, SimpleStreamOptions, TextContent, ToolResultMessage } from "@mariozechner/pi-ai";
12
+ import type { AutocompleteItem, Component, EditorComponent, EditorTheme, KeyId, OverlayHandle, OverlayOptions, TUI } from "@mariozechner/pi-tui";
13
+ import type { Static, TSchema } from "@sinclair/typebox";
14
+ import type { Theme } from "../../modes/interactive/theme/theme.js";
15
+ import type { BashResult } from "../bash-executor.js";
16
+ import type { CompactionPreparation, CompactionResult } from "../compaction/index.js";
17
+ import type { EventBus } from "../event-bus.js";
18
+ import type { ExecOptions, ExecResult } from "../exec.js";
19
+ import type { ReadonlyFooterDataProvider } from "../footer-data-provider.js";
20
+ import type { KeybindingsManager } from "../keybindings.js";
21
+ import type { CustomMessage } from "../messages.js";
22
+ import type { ModelRegistry } from "../model-registry.js";
23
+ import type { BranchSummaryEntry, CompactionEntry, ReadonlySessionManager, SessionEntry, SessionManager } from "../session-manager.js";
24
+ import type { SlashCommandInfo } from "../slash-commands.js";
25
+ import type { BashOperations } from "../tools/bash.js";
26
+ import type { EditToolDetails } from "../tools/edit.js";
27
+ import type { BashToolDetails, BashToolInput, EditToolInput, FindToolDetails, FindToolInput, GrepToolDetails, GrepToolInput, LsToolDetails, LsToolInput, ReadToolDetails, ReadToolInput, WriteToolInput } from "../tools/index.js";
28
+ export type { ExecOptions, ExecResult } from "../exec.js";
29
+ export type { AgentToolResult, AgentToolUpdateCallback };
30
+ export type { AppAction, KeybindingsManager } from "../keybindings.js";
31
+ /** Options for extension UI dialogs. */
32
+ export interface ExtensionUIDialogOptions {
33
+ /** AbortSignal to programmatically dismiss the dialog. */
34
+ signal?: AbortSignal;
35
+ /** Timeout in milliseconds. Dialog auto-dismisses with live countdown display. */
36
+ timeout?: number;
37
+ }
38
+ /** Placement for extension widgets. */
39
+ export type WidgetPlacement = "aboveEditor" | "belowEditor";
40
+ /** Options for extension widgets. */
41
+ export interface ExtensionWidgetOptions {
42
+ /** Where the widget is rendered. Defaults to "aboveEditor". */
43
+ placement?: WidgetPlacement;
44
+ }
45
+ /**
46
+ * UI context for extensions to request interactive UI.
47
+ * Each mode (interactive, RPC, print) provides its own implementation.
48
+ */
49
+ export interface ExtensionUIContext {
50
+ /** Show a selector and return the user's choice. */
51
+ select(title: string, options: string[], opts?: ExtensionUIDialogOptions): Promise<string | undefined>;
52
+ /** Show a confirmation dialog. */
53
+ confirm(title: string, message: string, opts?: ExtensionUIDialogOptions): Promise<boolean>;
54
+ /** Show a text input dialog. */
55
+ input(title: string, placeholder?: string, opts?: ExtensionUIDialogOptions): Promise<string | undefined>;
56
+ /** Show a notification to the user. */
57
+ notify(message: string, type?: "info" | "warning" | "error"): void;
58
+ /** Set status text in the footer/status bar. Pass undefined to clear. */
59
+ setStatus(key: string, text: string | undefined): void;
60
+ /** Set the working/loading message shown during streaming. Call with no argument to restore default. */
61
+ setWorkingMessage(message?: string): void;
62
+ /** Set a widget to display above or below the editor. Accepts string array or component factory. */
63
+ setWidget(key: string, content: string[] | undefined, options?: ExtensionWidgetOptions): void;
64
+ setWidget(key: string, content: ((tui: TUI, theme: Theme) => Component & {
65
+ dispose?(): void;
66
+ }) | undefined, options?: ExtensionWidgetOptions): void;
67
+ /** Set a custom footer component, or undefined to restore the built-in footer.
68
+ *
69
+ * The factory receives a FooterDataProvider for data not otherwise accessible:
70
+ * git branch and extension statuses from setStatus(). Token stats, model info,
71
+ * etc. are available via ctx.sessionManager and ctx.model.
72
+ */
73
+ setFooter(factory: ((tui: TUI, theme: Theme, footerData: ReadonlyFooterDataProvider) => Component & {
74
+ dispose?(): void;
75
+ }) | undefined): void;
76
+ /** Set a custom header component (shown at startup, above chat), or undefined to restore the built-in header. */
77
+ setHeader(factory: ((tui: TUI, theme: Theme) => Component & {
78
+ dispose?(): void;
79
+ }) | undefined): void;
80
+ /** Set the terminal window/tab title. */
81
+ setTitle(title: string): void;
82
+ /** Show a custom component with keyboard focus. */
83
+ custom<T>(factory: (tui: TUI, theme: Theme, keybindings: KeybindingsManager, done: (result: T) => void) => (Component & {
84
+ dispose?(): void;
85
+ }) | Promise<Component & {
86
+ dispose?(): void;
87
+ }>, options?: {
88
+ overlay?: boolean;
89
+ /** Overlay positioning/sizing options. Can be static or a function for dynamic updates. */
90
+ overlayOptions?: OverlayOptions | (() => OverlayOptions);
91
+ /** Called with the overlay handle after the overlay is shown. Use to control visibility. */
92
+ onHandle?: (handle: OverlayHandle) => void;
93
+ }): Promise<T>;
94
+ /** Set the text in the core input editor. */
95
+ setEditorText(text: string): void;
96
+ /** Get the current text from the core input editor. */
97
+ getEditorText(): string;
98
+ /** Show a multi-line editor for text editing. */
99
+ editor(title: string, prefill?: string): Promise<string | undefined>;
100
+ /**
101
+ * Set a custom editor component via factory function.
102
+ * Pass undefined to restore the default editor.
103
+ *
104
+ * The factory receives:
105
+ * - `theme`: EditorTheme for styling borders and autocomplete
106
+ * - `keybindings`: KeybindingsManager for app-level keybindings
107
+ *
108
+ * For full app keybinding support (escape, ctrl+d, model switching, etc.),
109
+ * extend `CustomEditor` from `@mariozechner/pi-coding-agent` and call
110
+ * `super.handleInput(data)` for keys you don't handle.
111
+ *
112
+ * @example
113
+ * ```ts
114
+ * import { CustomEditor } from "@mariozechner/pi-coding-agent";
115
+ *
116
+ * class VimEditor extends CustomEditor {
117
+ * private mode: "normal" | "insert" = "insert";
118
+ *
119
+ * handleInput(data: string): void {
120
+ * if (this.mode === "normal") {
121
+ * // Handle vim normal mode keys...
122
+ * if (data === "i") { this.mode = "insert"; return; }
123
+ * }
124
+ * super.handleInput(data); // App keybindings + text editing
125
+ * }
126
+ * }
127
+ *
128
+ * ctx.ui.setEditorComponent((tui, theme, keybindings) =>
129
+ * new VimEditor(tui, theme, keybindings)
130
+ * );
131
+ * ```
132
+ */
133
+ setEditorComponent(factory: ((tui: TUI, theme: EditorTheme, keybindings: KeybindingsManager) => EditorComponent) | undefined): void;
134
+ /** Get the current theme for styling. */
135
+ readonly theme: Theme;
136
+ /** Get all available themes with their names and file paths. */
137
+ getAllThemes(): {
138
+ name: string;
139
+ path: string | undefined;
140
+ }[];
141
+ /** Load a theme by name without switching to it. Returns undefined if not found. */
142
+ getTheme(name: string): Theme | undefined;
143
+ /** Set the current theme by name or Theme object. */
144
+ setTheme(theme: string | Theme): {
145
+ success: boolean;
146
+ error?: string;
147
+ };
148
+ /** Get current tool output expansion state. */
149
+ getToolsExpanded(): boolean;
150
+ /** Set tool output expansion state. */
151
+ setToolsExpanded(expanded: boolean): void;
152
+ }
153
+ export interface ContextUsage {
154
+ tokens: number;
155
+ contextWindow: number;
156
+ percent: number;
157
+ usageTokens: number;
158
+ trailingTokens: number;
159
+ lastUsageIndex: number | null;
160
+ }
161
+ export interface CompactOptions {
162
+ customInstructions?: string;
163
+ onComplete?: (result: CompactionResult) => void;
164
+ onError?: (error: Error) => void;
165
+ }
166
+ /**
167
+ * Context passed to extension event handlers.
168
+ */
169
+ export interface ExtensionContext {
170
+ /** UI methods for user interaction */
171
+ ui: ExtensionUIContext;
172
+ /** Whether UI is available (false in print/RPC mode) */
173
+ hasUI: boolean;
174
+ /** Current working directory */
175
+ cwd: string;
176
+ /** Session manager (read-only) */
177
+ sessionManager: ReadonlySessionManager;
178
+ /** Model registry for API key resolution */
179
+ modelRegistry: ModelRegistry;
180
+ /** Current model (may be undefined) */
181
+ model: Model<any> | undefined;
182
+ /** Whether the agent is idle (not streaming) */
183
+ isIdle(): boolean;
184
+ /** Abort the current agent operation */
185
+ abort(): void;
186
+ /** Whether there are queued messages waiting */
187
+ hasPendingMessages(): boolean;
188
+ /** Gracefully shutdown pi and exit. Available in all contexts. */
189
+ shutdown(): void;
190
+ /** Get current context usage for the active model. */
191
+ getContextUsage(): ContextUsage | undefined;
192
+ /** Trigger compaction without awaiting completion. */
193
+ compact(options?: CompactOptions): void;
194
+ /** Get the current effective system prompt. */
195
+ getSystemPrompt(): string;
196
+ }
197
+ /**
198
+ * Extended context for command handlers.
199
+ * Includes session control methods only safe in user-initiated commands.
200
+ */
201
+ export interface ExtensionCommandContext extends ExtensionContext {
202
+ /** Wait for the agent to finish streaming */
203
+ waitForIdle(): Promise<void>;
204
+ /** Start a new session, optionally with initialization. */
205
+ newSession(options?: {
206
+ parentSession?: string;
207
+ setup?: (sessionManager: SessionManager) => Promise<void>;
208
+ }): Promise<{
209
+ cancelled: boolean;
210
+ }>;
211
+ /** Fork from a specific entry, creating a new session file. */
212
+ fork(entryId: string): Promise<{
213
+ cancelled: boolean;
214
+ }>;
215
+ /** Navigate to a different point in the session tree. */
216
+ navigateTree(targetId: string, options?: {
217
+ summarize?: boolean;
218
+ customInstructions?: string;
219
+ replaceInstructions?: boolean;
220
+ label?: string;
221
+ }): Promise<{
222
+ cancelled: boolean;
223
+ }>;
224
+ /** Switch to a different session file. */
225
+ switchSession(sessionPath: string): Promise<{
226
+ cancelled: boolean;
227
+ }>;
228
+ }
229
+ /** Rendering options for tool results */
230
+ export interface ToolRenderResultOptions {
231
+ /** Whether the result view is expanded */
232
+ expanded: boolean;
233
+ /** Whether this is a partial/streaming result */
234
+ isPartial: boolean;
235
+ }
236
+ /**
237
+ * Tool definition for registerTool().
238
+ */
239
+ export interface ToolDefinition<TParams extends TSchema = TSchema, TDetails = unknown> {
240
+ /** Tool name (used in LLM tool calls) */
241
+ name: string;
242
+ /** Human-readable label for UI */
243
+ label: string;
244
+ /** Description for LLM */
245
+ description: string;
246
+ /** Parameter schema (TypeBox) */
247
+ parameters: TParams;
248
+ /** Execute the tool. */
249
+ execute(toolCallId: string, params: Static<TParams>, signal: AbortSignal | undefined, onUpdate: AgentToolUpdateCallback<TDetails> | undefined, ctx: ExtensionContext): Promise<AgentToolResult<TDetails>>;
250
+ /** Custom rendering for tool call display */
251
+ renderCall?: (args: Static<TParams>, theme: Theme) => Component;
252
+ /** Custom rendering for tool result display */
253
+ renderResult?: (result: AgentToolResult<TDetails>, options: ToolRenderResultOptions, theme: Theme) => Component;
254
+ }
255
+ /** Fired after session_start to allow extensions to provide additional resource paths. */
256
+ export interface ResourcesDiscoverEvent {
257
+ type: "resources_discover";
258
+ cwd: string;
259
+ reason: "startup" | "reload";
260
+ }
261
+ /** Result from resources_discover event handler */
262
+ export interface ResourcesDiscoverResult {
263
+ skillPaths?: string[];
264
+ promptPaths?: string[];
265
+ themePaths?: string[];
266
+ }
267
+ /** Fired on initial session load */
268
+ export interface SessionStartEvent {
269
+ type: "session_start";
270
+ }
271
+ /** Fired before switching to another session (can be cancelled) */
272
+ export interface SessionBeforeSwitchEvent {
273
+ type: "session_before_switch";
274
+ reason: "new" | "resume";
275
+ targetSessionFile?: string;
276
+ }
277
+ /** Fired after switching to another session */
278
+ export interface SessionSwitchEvent {
279
+ type: "session_switch";
280
+ reason: "new" | "resume";
281
+ previousSessionFile: string | undefined;
282
+ }
283
+ /** Fired before forking a session (can be cancelled) */
284
+ export interface SessionBeforeForkEvent {
285
+ type: "session_before_fork";
286
+ entryId: string;
287
+ }
288
+ /** Fired after forking a session */
289
+ export interface SessionForkEvent {
290
+ type: "session_fork";
291
+ previousSessionFile: string | undefined;
292
+ }
293
+ /** Fired before context compaction (can be cancelled or customized) */
294
+ export interface SessionBeforeCompactEvent {
295
+ type: "session_before_compact";
296
+ preparation: CompactionPreparation;
297
+ branchEntries: SessionEntry[];
298
+ customInstructions?: string;
299
+ signal: AbortSignal;
300
+ }
301
+ /** Fired after context compaction */
302
+ export interface SessionCompactEvent {
303
+ type: "session_compact";
304
+ compactionEntry: CompactionEntry;
305
+ fromExtension: boolean;
306
+ }
307
+ /** Fired on process exit */
308
+ export interface SessionShutdownEvent {
309
+ type: "session_shutdown";
310
+ }
311
+ /** Preparation data for tree navigation */
312
+ export interface TreePreparation {
313
+ targetId: string;
314
+ oldLeafId: string | null;
315
+ commonAncestorId: string | null;
316
+ entriesToSummarize: SessionEntry[];
317
+ userWantsSummary: boolean;
318
+ /** Custom instructions for summarization */
319
+ customInstructions?: string;
320
+ /** If true, customInstructions replaces the default prompt instead of being appended */
321
+ replaceInstructions?: boolean;
322
+ /** Label to attach to the branch summary entry */
323
+ label?: string;
324
+ }
325
+ /** Fired before navigating in the session tree (can be cancelled) */
326
+ export interface SessionBeforeTreeEvent {
327
+ type: "session_before_tree";
328
+ preparation: TreePreparation;
329
+ signal: AbortSignal;
330
+ }
331
+ /** Fired after navigating in the session tree */
332
+ export interface SessionTreeEvent {
333
+ type: "session_tree";
334
+ newLeafId: string | null;
335
+ oldLeafId: string | null;
336
+ summaryEntry?: BranchSummaryEntry;
337
+ fromExtension?: boolean;
338
+ }
339
+ export type SessionEvent = SessionStartEvent | SessionBeforeSwitchEvent | SessionSwitchEvent | SessionBeforeForkEvent | SessionForkEvent | SessionBeforeCompactEvent | SessionCompactEvent | SessionShutdownEvent | SessionBeforeTreeEvent | SessionTreeEvent;
340
+ /** Fired before each LLM call. Can modify messages. */
341
+ export interface ContextEvent {
342
+ type: "context";
343
+ messages: AgentMessage[];
344
+ }
345
+ /** Fired after user submits prompt but before agent loop. */
346
+ export interface BeforeAgentStartEvent {
347
+ type: "before_agent_start";
348
+ prompt: string;
349
+ images?: ImageContent[];
350
+ systemPrompt: string;
351
+ }
352
+ /** Fired when an agent loop starts */
353
+ export interface AgentStartEvent {
354
+ type: "agent_start";
355
+ }
356
+ /** Fired when an agent loop ends */
357
+ export interface AgentEndEvent {
358
+ type: "agent_end";
359
+ messages: AgentMessage[];
360
+ }
361
+ /** Fired at the start of each turn */
362
+ export interface TurnStartEvent {
363
+ type: "turn_start";
364
+ turnIndex: number;
365
+ timestamp: number;
366
+ }
367
+ /** Fired at the end of each turn */
368
+ export interface TurnEndEvent {
369
+ type: "turn_end";
370
+ turnIndex: number;
371
+ message: AgentMessage;
372
+ toolResults: ToolResultMessage[];
373
+ }
374
+ export type ModelSelectSource = "set" | "cycle" | "restore";
375
+ /** Fired when a new model is selected */
376
+ export interface ModelSelectEvent {
377
+ type: "model_select";
378
+ model: Model<any>;
379
+ previousModel: Model<any> | undefined;
380
+ source: ModelSelectSource;
381
+ }
382
+ /** Fired when user executes a bash command via ! or !! prefix */
383
+ export interface UserBashEvent {
384
+ type: "user_bash";
385
+ /** The command to execute */
386
+ command: string;
387
+ /** True if !! prefix was used (excluded from LLM context) */
388
+ excludeFromContext: boolean;
389
+ /** Current working directory */
390
+ cwd: string;
391
+ }
392
+ /** Source of user input */
393
+ export type InputSource = "interactive" | "rpc" | "extension";
394
+ /** Fired when user input is received, before agent processing */
395
+ export interface InputEvent {
396
+ type: "input";
397
+ /** The input text */
398
+ text: string;
399
+ /** Attached images, if any */
400
+ images?: ImageContent[];
401
+ /** Where the input came from */
402
+ source: InputSource;
403
+ }
404
+ /** Result from input event handler */
405
+ export type InputEventResult = {
406
+ action: "continue";
407
+ } | {
408
+ action: "transform";
409
+ text: string;
410
+ images?: ImageContent[];
411
+ } | {
412
+ action: "handled";
413
+ };
414
+ interface ToolCallEventBase {
415
+ type: "tool_call";
416
+ toolCallId: string;
417
+ }
418
+ export interface BashToolCallEvent extends ToolCallEventBase {
419
+ toolName: "bash";
420
+ input: BashToolInput;
421
+ }
422
+ export interface ReadToolCallEvent extends ToolCallEventBase {
423
+ toolName: "read";
424
+ input: ReadToolInput;
425
+ }
426
+ export interface EditToolCallEvent extends ToolCallEventBase {
427
+ toolName: "edit";
428
+ input: EditToolInput;
429
+ }
430
+ export interface WriteToolCallEvent extends ToolCallEventBase {
431
+ toolName: "write";
432
+ input: WriteToolInput;
433
+ }
434
+ export interface GrepToolCallEvent extends ToolCallEventBase {
435
+ toolName: "grep";
436
+ input: GrepToolInput;
437
+ }
438
+ export interface FindToolCallEvent extends ToolCallEventBase {
439
+ toolName: "find";
440
+ input: FindToolInput;
441
+ }
442
+ export interface LsToolCallEvent extends ToolCallEventBase {
443
+ toolName: "ls";
444
+ input: LsToolInput;
445
+ }
446
+ export interface CustomToolCallEvent extends ToolCallEventBase {
447
+ toolName: string;
448
+ input: Record<string, unknown>;
449
+ }
450
+ /** Fired before a tool executes. Can block. */
451
+ export type ToolCallEvent = BashToolCallEvent | ReadToolCallEvent | EditToolCallEvent | WriteToolCallEvent | GrepToolCallEvent | FindToolCallEvent | LsToolCallEvent | CustomToolCallEvent;
452
+ interface ToolResultEventBase {
453
+ type: "tool_result";
454
+ toolCallId: string;
455
+ input: Record<string, unknown>;
456
+ content: (TextContent | ImageContent)[];
457
+ isError: boolean;
458
+ }
459
+ export interface BashToolResultEvent extends ToolResultEventBase {
460
+ toolName: "bash";
461
+ details: BashToolDetails | undefined;
462
+ }
463
+ export interface ReadToolResultEvent extends ToolResultEventBase {
464
+ toolName: "read";
465
+ details: ReadToolDetails | undefined;
466
+ }
467
+ export interface EditToolResultEvent extends ToolResultEventBase {
468
+ toolName: "edit";
469
+ details: EditToolDetails | undefined;
470
+ }
471
+ export interface WriteToolResultEvent extends ToolResultEventBase {
472
+ toolName: "write";
473
+ details: undefined;
474
+ }
475
+ export interface GrepToolResultEvent extends ToolResultEventBase {
476
+ toolName: "grep";
477
+ details: GrepToolDetails | undefined;
478
+ }
479
+ export interface FindToolResultEvent extends ToolResultEventBase {
480
+ toolName: "find";
481
+ details: FindToolDetails | undefined;
482
+ }
483
+ export interface LsToolResultEvent extends ToolResultEventBase {
484
+ toolName: "ls";
485
+ details: LsToolDetails | undefined;
486
+ }
487
+ export interface CustomToolResultEvent extends ToolResultEventBase {
488
+ toolName: string;
489
+ details: unknown;
490
+ }
491
+ /** Fired after a tool executes. Can modify result. */
492
+ export type ToolResultEvent = BashToolResultEvent | ReadToolResultEvent | EditToolResultEvent | WriteToolResultEvent | GrepToolResultEvent | FindToolResultEvent | LsToolResultEvent | CustomToolResultEvent;
493
+ export declare function isBashToolResult(e: ToolResultEvent): e is BashToolResultEvent;
494
+ export declare function isReadToolResult(e: ToolResultEvent): e is ReadToolResultEvent;
495
+ export declare function isEditToolResult(e: ToolResultEvent): e is EditToolResultEvent;
496
+ export declare function isWriteToolResult(e: ToolResultEvent): e is WriteToolResultEvent;
497
+ export declare function isGrepToolResult(e: ToolResultEvent): e is GrepToolResultEvent;
498
+ export declare function isFindToolResult(e: ToolResultEvent): e is FindToolResultEvent;
499
+ export declare function isLsToolResult(e: ToolResultEvent): e is LsToolResultEvent;
500
+ /**
501
+ * Type guard for narrowing ToolCallEvent by tool name.
502
+ *
503
+ * Built-in tools narrow automatically (no type params needed):
504
+ * ```ts
505
+ * if (isToolCallEventType("bash", event)) {
506
+ * event.input.command; // string
507
+ * }
508
+ * ```
509
+ *
510
+ * Custom tools require explicit type parameters:
511
+ * ```ts
512
+ * if (isToolCallEventType<"my_tool", MyToolInput>("my_tool", event)) {
513
+ * event.input.action; // typed
514
+ * }
515
+ * ```
516
+ *
517
+ * Note: Direct narrowing via `event.toolName === "bash"` doesn't work because
518
+ * CustomToolCallEvent.toolName is `string` which overlaps with all literals.
519
+ */
520
+ export declare function isToolCallEventType(toolName: "bash", event: ToolCallEvent): event is BashToolCallEvent;
521
+ export declare function isToolCallEventType(toolName: "read", event: ToolCallEvent): event is ReadToolCallEvent;
522
+ export declare function isToolCallEventType(toolName: "edit", event: ToolCallEvent): event is EditToolCallEvent;
523
+ export declare function isToolCallEventType(toolName: "write", event: ToolCallEvent): event is WriteToolCallEvent;
524
+ export declare function isToolCallEventType(toolName: "grep", event: ToolCallEvent): event is GrepToolCallEvent;
525
+ export declare function isToolCallEventType(toolName: "find", event: ToolCallEvent): event is FindToolCallEvent;
526
+ export declare function isToolCallEventType(toolName: "ls", event: ToolCallEvent): event is LsToolCallEvent;
527
+ export declare function isToolCallEventType<TName extends string, TInput extends Record<string, unknown>>(toolName: TName, event: ToolCallEvent): event is ToolCallEvent & {
528
+ toolName: TName;
529
+ input: TInput;
530
+ };
531
+ /** Union of all event types */
532
+ export type ExtensionEvent = ResourcesDiscoverEvent | SessionEvent | ContextEvent | BeforeAgentStartEvent | AgentStartEvent | AgentEndEvent | TurnStartEvent | TurnEndEvent | ModelSelectEvent | UserBashEvent | InputEvent | ToolCallEvent | ToolResultEvent;
533
+ export interface ContextEventResult {
534
+ messages?: AgentMessage[];
535
+ }
536
+ export interface ToolCallEventResult {
537
+ block?: boolean;
538
+ reason?: string;
539
+ }
540
+ /** Result from user_bash event handler */
541
+ export interface UserBashEventResult {
542
+ /** Custom operations to use for execution */
543
+ operations?: BashOperations;
544
+ /** Full replacement: extension handled execution, use this result */
545
+ result?: BashResult;
546
+ }
547
+ export interface ToolResultEventResult {
548
+ content?: (TextContent | ImageContent)[];
549
+ details?: unknown;
550
+ isError?: boolean;
551
+ }
552
+ export interface BeforeAgentStartEventResult {
553
+ message?: Pick<CustomMessage, "customType" | "content" | "display" | "details">;
554
+ /** Replace the system prompt for this turn. If multiple extensions return this, they are chained. */
555
+ systemPrompt?: string;
556
+ }
557
+ export interface SessionBeforeSwitchResult {
558
+ cancel?: boolean;
559
+ }
560
+ export interface SessionBeforeForkResult {
561
+ cancel?: boolean;
562
+ skipConversationRestore?: boolean;
563
+ }
564
+ export interface SessionBeforeCompactResult {
565
+ cancel?: boolean;
566
+ compaction?: CompactionResult;
567
+ }
568
+ export interface SessionBeforeTreeResult {
569
+ cancel?: boolean;
570
+ summary?: {
571
+ summary: string;
572
+ details?: unknown;
573
+ };
574
+ /** Override custom instructions for summarization */
575
+ customInstructions?: string;
576
+ /** Override whether customInstructions replaces the default prompt */
577
+ replaceInstructions?: boolean;
578
+ /** Override label to attach to the branch summary entry */
579
+ label?: string;
580
+ }
581
+ export interface MessageRenderOptions {
582
+ expanded: boolean;
583
+ }
584
+ export type MessageRenderer<T = unknown> = (message: CustomMessage<T>, options: MessageRenderOptions, theme: Theme) => Component | undefined;
585
+ export interface RegisteredCommand {
586
+ name: string;
587
+ description?: string;
588
+ getArgumentCompletions?: (argumentPrefix: string) => AutocompleteItem[] | null;
589
+ handler: (args: string, ctx: ExtensionCommandContext) => Promise<void>;
590
+ }
591
+ /** Handler function type for events */
592
+ export type ExtensionHandler<E, R = undefined> = (event: E, ctx: ExtensionContext) => Promise<R | void> | R | void;
593
+ /**
594
+ * ExtensionAPI passed to extension factory functions.
595
+ */
596
+ export interface ExtensionAPI {
597
+ on(event: "resources_discover", handler: ExtensionHandler<ResourcesDiscoverEvent, ResourcesDiscoverResult>): void;
598
+ on(event: "session_start", handler: ExtensionHandler<SessionStartEvent>): void;
599
+ on(event: "session_before_switch", handler: ExtensionHandler<SessionBeforeSwitchEvent, SessionBeforeSwitchResult>): void;
600
+ on(event: "session_switch", handler: ExtensionHandler<SessionSwitchEvent>): void;
601
+ on(event: "session_before_fork", handler: ExtensionHandler<SessionBeforeForkEvent, SessionBeforeForkResult>): void;
602
+ on(event: "session_fork", handler: ExtensionHandler<SessionForkEvent>): void;
603
+ on(event: "session_before_compact", handler: ExtensionHandler<SessionBeforeCompactEvent, SessionBeforeCompactResult>): void;
604
+ on(event: "session_compact", handler: ExtensionHandler<SessionCompactEvent>): void;
605
+ on(event: "session_shutdown", handler: ExtensionHandler<SessionShutdownEvent>): void;
606
+ on(event: "session_before_tree", handler: ExtensionHandler<SessionBeforeTreeEvent, SessionBeforeTreeResult>): void;
607
+ on(event: "session_tree", handler: ExtensionHandler<SessionTreeEvent>): void;
608
+ on(event: "context", handler: ExtensionHandler<ContextEvent, ContextEventResult>): void;
609
+ on(event: "before_agent_start", handler: ExtensionHandler<BeforeAgentStartEvent, BeforeAgentStartEventResult>): void;
610
+ on(event: "agent_start", handler: ExtensionHandler<AgentStartEvent>): void;
611
+ on(event: "agent_end", handler: ExtensionHandler<AgentEndEvent>): void;
612
+ on(event: "turn_start", handler: ExtensionHandler<TurnStartEvent>): void;
613
+ on(event: "turn_end", handler: ExtensionHandler<TurnEndEvent>): void;
614
+ on(event: "model_select", handler: ExtensionHandler<ModelSelectEvent>): void;
615
+ on(event: "tool_call", handler: ExtensionHandler<ToolCallEvent, ToolCallEventResult>): void;
616
+ on(event: "tool_result", handler: ExtensionHandler<ToolResultEvent, ToolResultEventResult>): void;
617
+ on(event: "user_bash", handler: ExtensionHandler<UserBashEvent, UserBashEventResult>): void;
618
+ on(event: "input", handler: ExtensionHandler<InputEvent, InputEventResult>): void;
619
+ /** Register a tool that the LLM can call. */
620
+ registerTool<TParams extends TSchema = TSchema, TDetails = unknown>(tool: ToolDefinition<TParams, TDetails>): void;
621
+ /** Register a custom command. */
622
+ registerCommand(name: string, options: Omit<RegisteredCommand, "name">): void;
623
+ /** Register a keyboard shortcut. */
624
+ registerShortcut(shortcut: KeyId, options: {
625
+ description?: string;
626
+ handler: (ctx: ExtensionContext) => Promise<void> | void;
627
+ }): void;
628
+ /** Register a CLI flag. */
629
+ registerFlag(name: string, options: {
630
+ description?: string;
631
+ type: "boolean" | "string";
632
+ default?: boolean | string;
633
+ }): void;
634
+ /** Get the value of a registered CLI flag. */
635
+ getFlag(name: string): boolean | string | undefined;
636
+ /** Register a custom renderer for CustomMessageEntry. */
637
+ registerMessageRenderer<T = unknown>(customType: string, renderer: MessageRenderer<T>): void;
638
+ /** Send a custom message to the session. */
639
+ sendMessage<T = unknown>(message: Pick<CustomMessage<T>, "customType" | "content" | "display" | "details">, options?: {
640
+ triggerTurn?: boolean;
641
+ deliverAs?: "steer" | "followUp" | "nextTurn";
642
+ }): void;
643
+ /**
644
+ * Send a user message to the agent. Always triggers a turn.
645
+ * When the agent is streaming, use deliverAs to specify how to queue the message.
646
+ */
647
+ sendUserMessage(content: string | (TextContent | ImageContent)[], options?: {
648
+ deliverAs?: "steer" | "followUp";
649
+ }): void;
650
+ /** Append a custom entry to the session for state persistence (not sent to LLM). */
651
+ appendEntry<T = unknown>(customType: string, data?: T): void;
652
+ /** Set the session display name (shown in session selector). */
653
+ setSessionName(name: string): void;
654
+ /** Get the current session name, if set. */
655
+ getSessionName(): string | undefined;
656
+ /** Set or clear a label on an entry. Labels are user-defined markers for bookmarking/navigation. */
657
+ setLabel(entryId: string, label: string | undefined): void;
658
+ /** Execute a shell command. */
659
+ exec(command: string, args: string[], options?: ExecOptions): Promise<ExecResult>;
660
+ /** Get the list of currently active tool names. */
661
+ getActiveTools(): string[];
662
+ /** Get all configured tools with name and description. */
663
+ getAllTools(): ToolInfo[];
664
+ /** Set the active tools by name. */
665
+ setActiveTools(toolNames: string[]): void;
666
+ /** Get available slash commands in the current session. */
667
+ getCommands(): SlashCommandInfo[];
668
+ /** Set the current model. Returns false if no API key available. */
669
+ setModel(model: Model<any>): Promise<boolean>;
670
+ /** Get current thinking level. */
671
+ getThinkingLevel(): ThinkingLevel;
672
+ /** Set thinking level (clamped to model capabilities). */
673
+ setThinkingLevel(level: ThinkingLevel): void;
674
+ /**
675
+ * Register or override a model provider.
676
+ *
677
+ * If `models` is provided: replaces all existing models for this provider.
678
+ * If only `baseUrl` is provided: overrides the URL for existing models.
679
+ * If `oauth` is provided: registers OAuth provider for /login support.
680
+ * If `streamSimple` is provided: registers a custom API stream handler.
681
+ *
682
+ * @example
683
+ * // Register a new provider with custom models
684
+ * pi.registerProvider("my-proxy", {
685
+ * baseUrl: "https://proxy.example.com",
686
+ * apiKey: "PROXY_API_KEY",
687
+ * api: "anthropic-messages",
688
+ * models: [
689
+ * {
690
+ * id: "claude-sonnet-4-20250514",
691
+ * name: "Claude 4 Sonnet (proxy)",
692
+ * reasoning: false,
693
+ * input: ["text", "image"],
694
+ * cost: { input: 0, output: 0, cacheRead: 0, cacheWrite: 0 },
695
+ * contextWindow: 200000,
696
+ * maxTokens: 16384
697
+ * }
698
+ * ]
699
+ * });
700
+ *
701
+ * @example
702
+ * // Override baseUrl for an existing provider
703
+ * pi.registerProvider("anthropic", {
704
+ * baseUrl: "https://proxy.example.com"
705
+ * });
706
+ *
707
+ * @example
708
+ * // Register provider with OAuth support
709
+ * pi.registerProvider("corporate-ai", {
710
+ * baseUrl: "https://ai.corp.com",
711
+ * api: "openai-responses",
712
+ * models: [...],
713
+ * oauth: {
714
+ * name: "Corporate AI (SSO)",
715
+ * async login(callbacks) { ... },
716
+ * async refreshToken(credentials) { ... },
717
+ * getApiKey(credentials) { return credentials.access; }
718
+ * }
719
+ * });
720
+ */
721
+ registerProvider(name: string, config: ProviderConfig): void;
722
+ /** Shared event bus for extension communication. */
723
+ events: EventBus;
724
+ }
725
+ /** Configuration for registering a provider via pi.registerProvider(). */
726
+ export interface ProviderConfig {
727
+ /** Base URL for the API endpoint. Required when defining models. */
728
+ baseUrl?: string;
729
+ /** API key or environment variable name. Required when defining models (unless oauth provided). */
730
+ apiKey?: string;
731
+ /** API type. Required at provider or model level when defining models. */
732
+ api?: Api;
733
+ /** Optional streamSimple handler for custom APIs. */
734
+ streamSimple?: (model: Model<Api>, context: Context, options?: SimpleStreamOptions) => AssistantMessageEventStream;
735
+ /** Custom headers to include in requests. */
736
+ headers?: Record<string, string>;
737
+ /** If true, adds Authorization: Bearer header with the resolved API key. */
738
+ authHeader?: boolean;
739
+ /** Models to register. If provided, replaces all existing models for this provider. */
740
+ models?: ProviderModelConfig[];
741
+ /** OAuth provider for /login support. The `id` is set automatically from the provider name. */
742
+ oauth?: {
743
+ /** Display name for the provider in login UI. */
744
+ name: string;
745
+ /** Run the login flow, return credentials to persist. */
746
+ login(callbacks: OAuthLoginCallbacks): Promise<OAuthCredentials>;
747
+ /** Refresh expired credentials, return updated credentials to persist. */
748
+ refreshToken(credentials: OAuthCredentials): Promise<OAuthCredentials>;
749
+ /** Convert credentials to API key string for the provider. */
750
+ getApiKey(credentials: OAuthCredentials): string;
751
+ /** Optional: modify models for this provider (e.g., update baseUrl based on credentials). */
752
+ modifyModels?(models: Model<Api>[], credentials: OAuthCredentials): Model<Api>[];
753
+ };
754
+ }
755
+ /** Configuration for a model within a provider. */
756
+ export interface ProviderModelConfig {
757
+ /** Model ID (e.g., "claude-sonnet-4-20250514"). */
758
+ id: string;
759
+ /** Display name (e.g., "Claude 4 Sonnet"). */
760
+ name: string;
761
+ /** API type override for this model. */
762
+ api?: Api;
763
+ /** Whether the model supports extended thinking. */
764
+ reasoning: boolean;
765
+ /** Supported input types. */
766
+ input: ("text" | "image")[];
767
+ /** Cost per token (for tracking, can be 0). */
768
+ cost: {
769
+ input: number;
770
+ output: number;
771
+ cacheRead: number;
772
+ cacheWrite: number;
773
+ };
774
+ /** Maximum context window size in tokens. */
775
+ contextWindow: number;
776
+ /** Maximum output tokens. */
777
+ maxTokens: number;
778
+ /** Custom headers for this model. */
779
+ headers?: Record<string, string>;
780
+ /** OpenAI compatibility settings. */
781
+ compat?: Model<Api>["compat"];
782
+ }
783
+ /** Extension factory function type. Supports both sync and async initialization. */
784
+ export type ExtensionFactory = (pi: ExtensionAPI) => void | Promise<void>;
785
+ export interface RegisteredTool {
786
+ definition: ToolDefinition;
787
+ extensionPath: string;
788
+ }
789
+ export interface ExtensionFlag {
790
+ name: string;
791
+ description?: string;
792
+ type: "boolean" | "string";
793
+ default?: boolean | string;
794
+ extensionPath: string;
795
+ }
796
+ export interface ExtensionShortcut {
797
+ shortcut: KeyId;
798
+ description?: string;
799
+ handler: (ctx: ExtensionContext) => Promise<void> | void;
800
+ extensionPath: string;
801
+ }
802
+ type HandlerFn = (...args: unknown[]) => Promise<unknown>;
803
+ export type SendMessageHandler = <T = unknown>(message: Pick<CustomMessage<T>, "customType" | "content" | "display" | "details">, options?: {
804
+ triggerTurn?: boolean;
805
+ deliverAs?: "steer" | "followUp" | "nextTurn";
806
+ }) => void;
807
+ export type SendUserMessageHandler = (content: string | (TextContent | ImageContent)[], options?: {
808
+ deliverAs?: "steer" | "followUp";
809
+ }) => void;
810
+ export type AppendEntryHandler = <T = unknown>(customType: string, data?: T) => void;
811
+ export type SetSessionNameHandler = (name: string) => void;
812
+ export type GetSessionNameHandler = () => string | undefined;
813
+ export type GetActiveToolsHandler = () => string[];
814
+ /** Tool info with name and description */
815
+ export type ToolInfo = Pick<ToolDefinition, "name" | "description">;
816
+ export type GetAllToolsHandler = () => ToolInfo[];
817
+ export type GetCommandsHandler = () => SlashCommandInfo[];
818
+ export type SetActiveToolsHandler = (toolNames: string[]) => void;
819
+ export type SetModelHandler = (model: Model<any>) => Promise<boolean>;
820
+ export type GetThinkingLevelHandler = () => ThinkingLevel;
821
+ export type SetThinkingLevelHandler = (level: ThinkingLevel) => void;
822
+ export type SetLabelHandler = (entryId: string, label: string | undefined) => void;
823
+ /**
824
+ * Shared state created by loader, used during registration and runtime.
825
+ * Contains flag values (defaults set during registration, CLI values set after).
826
+ */
827
+ export interface ExtensionRuntimeState {
828
+ flagValues: Map<string, boolean | string>;
829
+ /** Provider registrations queued during extension loading, processed when runner binds */
830
+ pendingProviderRegistrations: Array<{
831
+ name: string;
832
+ config: ProviderConfig;
833
+ }>;
834
+ }
835
+ /**
836
+ * Action implementations for pi.* API methods.
837
+ * Provided to runner.initialize(), copied into the shared runtime.
838
+ */
839
+ export interface ExtensionActions {
840
+ sendMessage: SendMessageHandler;
841
+ sendUserMessage: SendUserMessageHandler;
842
+ appendEntry: AppendEntryHandler;
843
+ setSessionName: SetSessionNameHandler;
844
+ getSessionName: GetSessionNameHandler;
845
+ setLabel: SetLabelHandler;
846
+ getActiveTools: GetActiveToolsHandler;
847
+ getAllTools: GetAllToolsHandler;
848
+ setActiveTools: SetActiveToolsHandler;
849
+ getCommands: GetCommandsHandler;
850
+ setModel: SetModelHandler;
851
+ getThinkingLevel: GetThinkingLevelHandler;
852
+ setThinkingLevel: SetThinkingLevelHandler;
853
+ }
854
+ /**
855
+ * Actions for ExtensionContext (ctx.* in event handlers).
856
+ * Required by all modes.
857
+ */
858
+ export interface ExtensionContextActions {
859
+ getModel: () => Model<any> | undefined;
860
+ isIdle: () => boolean;
861
+ abort: () => void;
862
+ hasPendingMessages: () => boolean;
863
+ shutdown: () => void;
864
+ getContextUsage: () => ContextUsage | undefined;
865
+ compact: (options?: CompactOptions) => void;
866
+ getSystemPrompt: () => string;
867
+ }
868
+ /**
869
+ * Actions for ExtensionCommandContext (ctx.* in command handlers).
870
+ * Only needed for interactive mode where extension commands are invokable.
871
+ */
872
+ export interface ExtensionCommandContextActions {
873
+ waitForIdle: () => Promise<void>;
874
+ newSession: (options?: {
875
+ parentSession?: string;
876
+ setup?: (sessionManager: SessionManager) => Promise<void>;
877
+ }) => Promise<{
878
+ cancelled: boolean;
879
+ }>;
880
+ fork: (entryId: string) => Promise<{
881
+ cancelled: boolean;
882
+ }>;
883
+ navigateTree: (targetId: string, options?: {
884
+ summarize?: boolean;
885
+ customInstructions?: string;
886
+ replaceInstructions?: boolean;
887
+ label?: string;
888
+ }) => Promise<{
889
+ cancelled: boolean;
890
+ }>;
891
+ switchSession: (sessionPath: string) => Promise<{
892
+ cancelled: boolean;
893
+ }>;
894
+ }
895
+ /**
896
+ * Full runtime = state + actions.
897
+ * Created by loader with throwing action stubs, completed by runner.initialize().
898
+ */
899
+ export interface ExtensionRuntime extends ExtensionRuntimeState, ExtensionActions {
900
+ }
901
+ /** Loaded extension with all registered items. */
902
+ export interface Extension {
903
+ path: string;
904
+ resolvedPath: string;
905
+ handlers: Map<string, HandlerFn[]>;
906
+ tools: Map<string, RegisteredTool>;
907
+ messageRenderers: Map<string, MessageRenderer>;
908
+ commands: Map<string, RegisteredCommand>;
909
+ flags: Map<string, ExtensionFlag>;
910
+ shortcuts: Map<KeyId, ExtensionShortcut>;
911
+ }
912
+ /** Result of loading extensions. */
913
+ export interface LoadExtensionsResult {
914
+ extensions: Extension[];
915
+ errors: Array<{
916
+ path: string;
917
+ error: string;
918
+ }>;
919
+ /** Shared runtime - actions are throwing stubs until runner.initialize() */
920
+ runtime: ExtensionRuntime;
921
+ }
922
+ export interface ExtensionError {
923
+ extensionPath: string;
924
+ event: string;
925
+ error: string;
926
+ stack?: string;
927
+ }
928
+ //# sourceMappingURL=types.d.ts.map