@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,539 @@
1
+ # Custom Providers
2
+
3
+ Extensions can register custom model providers via `pi.registerProvider()`. This enables:
4
+
5
+ - **Proxies** - Route requests through corporate proxies or API gateways
6
+ - **Custom endpoints** - Use self-hosted or private model deployments
7
+ - **OAuth/SSO** - Add authentication flows for enterprise providers
8
+ - **Custom APIs** - Implement streaming for non-standard LLM APIs
9
+
10
+ ## Table of Contents
11
+
12
+ - [Quick Reference](#quick-reference)
13
+ - [Override Existing Provider](#override-existing-provider)
14
+ - [Register New Provider](#register-new-provider)
15
+ - [OAuth Support](#oauth-support)
16
+ - [Custom Streaming API](#custom-streaming-api)
17
+ - [Testing Your Implementation](#testing-your-implementation)
18
+ - [Config Reference](#config-reference)
19
+ - [Model Definition Reference](#model-definition-reference)
20
+
21
+ ## Quick Reference
22
+
23
+ ```typescript
24
+ import type { ExtensionAPI } from "@mariozechner/pi-coding-agent";
25
+
26
+ export default function (pi: ExtensionAPI) {
27
+ // Override baseUrl for existing provider
28
+ pi.registerProvider("anthropic", {
29
+ baseUrl: "https://proxy.example.com"
30
+ });
31
+
32
+ // Register new provider with models
33
+ pi.registerProvider("my-provider", {
34
+ baseUrl: "https://api.example.com",
35
+ apiKey: "MY_API_KEY",
36
+ api: "openai-completions",
37
+ models: [
38
+ {
39
+ id: "my-model",
40
+ name: "My Model",
41
+ reasoning: false,
42
+ input: ["text", "image"],
43
+ cost: { input: 0, output: 0, cacheRead: 0, cacheWrite: 0 },
44
+ contextWindow: 128000,
45
+ maxTokens: 4096
46
+ }
47
+ ]
48
+ });
49
+ }
50
+ ```
51
+
52
+ ## Override Existing Provider
53
+
54
+ The simplest use case: redirect an existing provider through a proxy.
55
+
56
+ ```typescript
57
+ // All Anthropic requests now go through your proxy
58
+ pi.registerProvider("anthropic", {
59
+ baseUrl: "https://proxy.example.com"
60
+ });
61
+
62
+ // Add custom headers to OpenAI requests
63
+ pi.registerProvider("openai", {
64
+ headers: {
65
+ "X-Custom-Header": "value"
66
+ }
67
+ });
68
+
69
+ // Both baseUrl and headers
70
+ pi.registerProvider("google", {
71
+ baseUrl: "https://ai-gateway.corp.com/google",
72
+ headers: {
73
+ "X-Corp-Auth": "CORP_AUTH_TOKEN" // env var or literal
74
+ }
75
+ });
76
+ ```
77
+
78
+ When only `baseUrl` and/or `headers` are provided (no `models`), all existing models for that provider are preserved with the new endpoint.
79
+
80
+ ## Register New Provider
81
+
82
+ To add a completely new provider, specify `models` along with the required configuration.
83
+
84
+ ```typescript
85
+ pi.registerProvider("my-llm", {
86
+ baseUrl: "https://api.my-llm.com/v1",
87
+ apiKey: "MY_LLM_API_KEY", // env var name or literal value
88
+ api: "openai-completions", // which streaming API to use
89
+ models: [
90
+ {
91
+ id: "my-llm-large",
92
+ name: "My LLM Large",
93
+ reasoning: true, // supports extended thinking
94
+ input: ["text", "image"],
95
+ cost: {
96
+ input: 3.0, // $/million tokens
97
+ output: 15.0,
98
+ cacheRead: 0.3,
99
+ cacheWrite: 3.75
100
+ },
101
+ contextWindow: 200000,
102
+ maxTokens: 16384
103
+ }
104
+ ]
105
+ });
106
+ ```
107
+
108
+ When `models` is provided, it **replaces** all existing models for that provider.
109
+
110
+ ### API Types
111
+
112
+ The `api` field determines which streaming implementation is used:
113
+
114
+ | API | Use for |
115
+ |-----|---------|
116
+ | `anthropic-messages` | Anthropic Claude API and compatibles |
117
+ | `openai-completions` | OpenAI Chat Completions API and compatibles |
118
+ | `openai-responses` | OpenAI Responses API |
119
+ | `azure-openai-responses` | Azure OpenAI Responses API |
120
+ | `openai-codex-responses` | OpenAI Codex Responses API |
121
+ | `google-generative-ai` | Google Generative AI API |
122
+ | `google-gemini-cli` | Google Cloud Code Assist API |
123
+ | `google-vertex` | Google Vertex AI API |
124
+ | `bedrock-converse-stream` | Amazon Bedrock Converse API |
125
+
126
+ Most OpenAI-compatible providers work with `openai-completions`. Use `compat` for quirks:
127
+
128
+ ```typescript
129
+ models: [{
130
+ id: "custom-model",
131
+ // ...
132
+ compat: {
133
+ supportsDeveloperRole: false, // use "system" instead of "developer"
134
+ supportsReasoningEffort: false, // disable reasoning_effort param
135
+ maxTokensField: "max_tokens", // instead of "max_completion_tokens"
136
+ requiresToolResultName: true, // tool results need name field
137
+ requiresMistralToolIds: true // tool IDs must be 9 alphanumeric chars
138
+ thinkingFormat: "qwen" // uses enable_thinking: true
139
+ }
140
+ }]
141
+ ```
142
+
143
+ ### Auth Header
144
+
145
+ If your provider expects `Authorization: Bearer <key>` but doesn't use a standard API, set `authHeader: true`:
146
+
147
+ ```typescript
148
+ pi.registerProvider("custom-api", {
149
+ baseUrl: "https://api.example.com",
150
+ apiKey: "MY_API_KEY",
151
+ authHeader: true, // adds Authorization: Bearer header
152
+ api: "openai-completions",
153
+ models: [...]
154
+ });
155
+ ```
156
+
157
+ ## OAuth Support
158
+
159
+ Add OAuth/SSO authentication that integrates with `/login`:
160
+
161
+ ```typescript
162
+ import type { OAuthCredentials, OAuthLoginCallbacks } from "@mariozechner/pi-ai";
163
+
164
+ pi.registerProvider("corporate-ai", {
165
+ baseUrl: "https://ai.corp.com/v1",
166
+ api: "openai-responses",
167
+ models: [...],
168
+ oauth: {
169
+ name: "Corporate AI (SSO)",
170
+
171
+ async login(callbacks: OAuthLoginCallbacks): Promise<OAuthCredentials> {
172
+ // Option 1: Browser-based OAuth
173
+ callbacks.onAuth({ url: "https://sso.corp.com/authorize?..." });
174
+
175
+ // Option 2: Device code flow
176
+ callbacks.onDeviceCode({
177
+ userCode: "ABCD-1234",
178
+ verificationUri: "https://sso.corp.com/device"
179
+ });
180
+
181
+ // Option 3: Prompt for token/code
182
+ const code = await callbacks.onPrompt({ message: "Enter SSO code:" });
183
+
184
+ // Exchange for tokens (your implementation)
185
+ const tokens = await exchangeCodeForTokens(code);
186
+
187
+ return {
188
+ refresh: tokens.refreshToken,
189
+ access: tokens.accessToken,
190
+ expires: Date.now() + tokens.expiresIn * 1000
191
+ };
192
+ },
193
+
194
+ async refreshToken(credentials: OAuthCredentials): Promise<OAuthCredentials> {
195
+ const tokens = await refreshAccessToken(credentials.refresh);
196
+ return {
197
+ refresh: tokens.refreshToken ?? credentials.refresh,
198
+ access: tokens.accessToken,
199
+ expires: Date.now() + tokens.expiresIn * 1000
200
+ };
201
+ },
202
+
203
+ getApiKey(credentials: OAuthCredentials): string {
204
+ return credentials.access;
205
+ },
206
+
207
+ // Optional: modify models based on user's subscription
208
+ modifyModels(models, credentials) {
209
+ const region = decodeRegionFromToken(credentials.access);
210
+ return models.map(m => ({
211
+ ...m,
212
+ baseUrl: `https://${region}.ai.corp.com/v1`
213
+ }));
214
+ }
215
+ }
216
+ });
217
+ ```
218
+
219
+ After registration, users can authenticate via `/login corporate-ai`.
220
+
221
+ ### OAuthLoginCallbacks
222
+
223
+ The `callbacks` object provides three ways to authenticate:
224
+
225
+ ```typescript
226
+ interface OAuthLoginCallbacks {
227
+ // Open URL in browser (for OAuth redirects)
228
+ onAuth(params: { url: string }): void;
229
+
230
+ // Show device code (for device authorization flow)
231
+ onDeviceCode(params: { userCode: string; verificationUri: string }): void;
232
+
233
+ // Prompt user for input (for manual token entry)
234
+ onPrompt(params: { message: string }): Promise<string>;
235
+ }
236
+ ```
237
+
238
+ ### OAuthCredentials
239
+
240
+ Credentials are persisted in `~/.pi/agent/auth.json`:
241
+
242
+ ```typescript
243
+ interface OAuthCredentials {
244
+ refresh: string; // Refresh token (for refreshToken())
245
+ access: string; // Access token (returned by getApiKey())
246
+ expires: number; // Expiration timestamp in milliseconds
247
+ }
248
+ ```
249
+
250
+ ## Custom Streaming API
251
+
252
+ For providers with non-standard APIs, implement `streamSimple`. Study the existing provider implementations before writing your own:
253
+
254
+ **Reference implementations:**
255
+ - [anthropic.ts](https://github.com/badlogic/pi-mono/blob/main/packages/ai/src/providers/anthropic.ts) - Anthropic Messages API
256
+ - [openai-completions.ts](https://github.com/badlogic/pi-mono/blob/main/packages/ai/src/providers/openai-completions.ts) - OpenAI Chat Completions
257
+ - [openai-responses.ts](https://github.com/badlogic/pi-mono/blob/main/packages/ai/src/providers/openai-responses.ts) - OpenAI Responses API
258
+ - [google.ts](https://github.com/badlogic/pi-mono/blob/main/packages/ai/src/providers/google.ts) - Google Generative AI
259
+ - [amazon-bedrock.ts](https://github.com/badlogic/pi-mono/blob/main/packages/ai/src/providers/amazon-bedrock.ts) - AWS Bedrock
260
+
261
+ ### Stream Pattern
262
+
263
+ All providers follow the same pattern:
264
+
265
+ ```typescript
266
+ import {
267
+ type AssistantMessage,
268
+ type AssistantMessageEventStream,
269
+ type Context,
270
+ type Model,
271
+ type SimpleStreamOptions,
272
+ calculateCost,
273
+ createAssistantMessageEventStream,
274
+ } from "@mariozechner/pi-ai";
275
+
276
+ function streamMyProvider(
277
+ model: Model<any>,
278
+ context: Context,
279
+ options?: SimpleStreamOptions
280
+ ): AssistantMessageEventStream {
281
+ const stream = createAssistantMessageEventStream();
282
+
283
+ (async () => {
284
+ // Initialize output message
285
+ const output: AssistantMessage = {
286
+ role: "assistant",
287
+ content: [],
288
+ api: model.api,
289
+ provider: model.provider,
290
+ model: model.id,
291
+ usage: {
292
+ input: 0,
293
+ output: 0,
294
+ cacheRead: 0,
295
+ cacheWrite: 0,
296
+ totalTokens: 0,
297
+ cost: { input: 0, output: 0, cacheRead: 0, cacheWrite: 0, total: 0 },
298
+ },
299
+ stopReason: "stop",
300
+ timestamp: Date.now(),
301
+ };
302
+
303
+ try {
304
+ // Push start event
305
+ stream.push({ type: "start", partial: output });
306
+
307
+ // Make API request and process response...
308
+ // Push content events as they arrive...
309
+
310
+ // Push done event
311
+ stream.push({
312
+ type: "done",
313
+ reason: output.stopReason as "stop" | "length" | "toolUse",
314
+ message: output
315
+ });
316
+ stream.end();
317
+ } catch (error) {
318
+ output.stopReason = options?.signal?.aborted ? "aborted" : "error";
319
+ output.errorMessage = error instanceof Error ? error.message : String(error);
320
+ stream.push({ type: "error", reason: output.stopReason, error: output });
321
+ stream.end();
322
+ }
323
+ })();
324
+
325
+ return stream;
326
+ }
327
+ ```
328
+
329
+ ### Event Types
330
+
331
+ Push events via `stream.push()` in this order:
332
+
333
+ 1. `{ type: "start", partial: output }` - Stream started
334
+
335
+ 2. Content events (repeatable, track `contentIndex` for each block):
336
+ - `{ type: "text_start", contentIndex, partial }` - Text block started
337
+ - `{ type: "text_delta", contentIndex, delta, partial }` - Text chunk
338
+ - `{ type: "text_end", contentIndex, content, partial }` - Text block ended
339
+ - `{ type: "thinking_start", contentIndex, partial }` - Thinking started
340
+ - `{ type: "thinking_delta", contentIndex, delta, partial }` - Thinking chunk
341
+ - `{ type: "thinking_end", contentIndex, content, partial }` - Thinking ended
342
+ - `{ type: "toolcall_start", contentIndex, partial }` - Tool call started
343
+ - `{ type: "toolcall_delta", contentIndex, delta, partial }` - Tool call JSON chunk
344
+ - `{ type: "toolcall_end", contentIndex, toolCall, partial }` - Tool call ended
345
+
346
+ 3. `{ type: "done", reason, message }` or `{ type: "error", reason, error }` - Stream ended
347
+
348
+ The `partial` field in each event contains the current `AssistantMessage` state. Update `output.content` as you receive data, then include `output` as the `partial`.
349
+
350
+ ### Content Blocks
351
+
352
+ Add content blocks to `output.content` as they arrive:
353
+
354
+ ```typescript
355
+ // Text block
356
+ output.content.push({ type: "text", text: "" });
357
+ stream.push({ type: "text_start", contentIndex: output.content.length - 1, partial: output });
358
+
359
+ // As text arrives
360
+ const block = output.content[contentIndex];
361
+ if (block.type === "text") {
362
+ block.text += delta;
363
+ stream.push({ type: "text_delta", contentIndex, delta, partial: output });
364
+ }
365
+
366
+ // When block completes
367
+ stream.push({ type: "text_end", contentIndex, content: block.text, partial: output });
368
+ ```
369
+
370
+ ### Tool Calls
371
+
372
+ Tool calls require accumulating JSON and parsing:
373
+
374
+ ```typescript
375
+ // Start tool call
376
+ output.content.push({
377
+ type: "toolCall",
378
+ id: toolCallId,
379
+ name: toolName,
380
+ arguments: {}
381
+ });
382
+ stream.push({ type: "toolcall_start", contentIndex: output.content.length - 1, partial: output });
383
+
384
+ // Accumulate JSON
385
+ let partialJson = "";
386
+ partialJson += jsonDelta;
387
+ try {
388
+ block.arguments = JSON.parse(partialJson);
389
+ } catch {}
390
+ stream.push({ type: "toolcall_delta", contentIndex, delta: jsonDelta, partial: output });
391
+
392
+ // Complete
393
+ stream.push({
394
+ type: "toolcall_end",
395
+ contentIndex,
396
+ toolCall: { type: "toolCall", id, name, arguments: block.arguments },
397
+ partial: output
398
+ });
399
+ ```
400
+
401
+ ### Usage and Cost
402
+
403
+ Update usage from API response and calculate cost:
404
+
405
+ ```typescript
406
+ output.usage.input = response.usage.input_tokens;
407
+ output.usage.output = response.usage.output_tokens;
408
+ output.usage.cacheRead = response.usage.cache_read_tokens ?? 0;
409
+ output.usage.cacheWrite = response.usage.cache_write_tokens ?? 0;
410
+ output.usage.totalTokens = output.usage.input + output.usage.output +
411
+ output.usage.cacheRead + output.usage.cacheWrite;
412
+ calculateCost(model, output.usage);
413
+ ```
414
+
415
+ ### Registration
416
+
417
+ Register your stream function:
418
+
419
+ ```typescript
420
+ pi.registerProvider("my-provider", {
421
+ baseUrl: "https://api.example.com",
422
+ apiKey: "MY_API_KEY",
423
+ api: "my-custom-api",
424
+ models: [...],
425
+ streamSimple: streamMyProvider
426
+ });
427
+ ```
428
+
429
+ ## Testing Your Implementation
430
+
431
+ Test your provider against the same test suites used by built-in providers. Copy and adapt these test files from [packages/ai/test/](https://github.com/badlogic/pi-mono/tree/main/packages/ai/test):
432
+
433
+ | Test | Purpose |
434
+ |------|---------|
435
+ | `stream.test.ts` | Basic streaming, text output |
436
+ | `tokens.test.ts` | Token counting and usage |
437
+ | `abort.test.ts` | AbortSignal handling |
438
+ | `empty.test.ts` | Empty/minimal responses |
439
+ | `context-overflow.test.ts` | Context window limits |
440
+ | `image-limits.test.ts` | Image input handling |
441
+ | `unicode-surrogate.test.ts` | Unicode edge cases |
442
+ | `tool-call-without-result.test.ts` | Tool call edge cases |
443
+ | `image-tool-result.test.ts` | Images in tool results |
444
+ | `total-tokens.test.ts` | Total token calculation |
445
+ | `cross-provider-handoff.test.ts` | Context handoff between providers |
446
+
447
+ Run tests with your provider/model pairs to verify compatibility.
448
+
449
+ ## Config Reference
450
+
451
+ ```typescript
452
+ interface ProviderConfig {
453
+ /** API endpoint URL. Required when defining models. */
454
+ baseUrl?: string;
455
+
456
+ /** API key or environment variable name. Required when defining models (unless oauth). */
457
+ apiKey?: string;
458
+
459
+ /** API type for streaming. Required at provider or model level when defining models. */
460
+ api?: Api;
461
+
462
+ /** Custom streaming implementation for non-standard APIs. */
463
+ streamSimple?: (
464
+ model: Model<Api>,
465
+ context: Context,
466
+ options?: SimpleStreamOptions
467
+ ) => AssistantMessageEventStream;
468
+
469
+ /** Custom headers to include in requests. Values can be env var names. */
470
+ headers?: Record<string, string>;
471
+
472
+ /** If true, adds Authorization: Bearer header with the resolved API key. */
473
+ authHeader?: boolean;
474
+
475
+ /** Models to register. If provided, replaces all existing models for this provider. */
476
+ models?: ProviderModelConfig[];
477
+
478
+ /** OAuth provider for /login support. */
479
+ oauth?: {
480
+ name: string;
481
+ login(callbacks: OAuthLoginCallbacks): Promise<OAuthCredentials>;
482
+ refreshToken(credentials: OAuthCredentials): Promise<OAuthCredentials>;
483
+ getApiKey(credentials: OAuthCredentials): string;
484
+ modifyModels?(models: Model<Api>[], credentials: OAuthCredentials): Model<Api>[];
485
+ };
486
+ }
487
+ ```
488
+
489
+ ## Model Definition Reference
490
+
491
+ ```typescript
492
+ interface ProviderModelConfig {
493
+ /** Model ID (e.g., "claude-sonnet-4-20250514"). */
494
+ id: string;
495
+
496
+ /** Display name (e.g., "Claude 4 Sonnet"). */
497
+ name: string;
498
+
499
+ /** API type override for this specific model. */
500
+ api?: Api;
501
+
502
+ /** Whether the model supports extended thinking. */
503
+ reasoning: boolean;
504
+
505
+ /** Supported input types. */
506
+ input: ("text" | "image")[];
507
+
508
+ /** Cost per million tokens (for usage tracking). */
509
+ cost: {
510
+ input: number;
511
+ output: number;
512
+ cacheRead: number;
513
+ cacheWrite: number;
514
+ };
515
+
516
+ /** Maximum context window size in tokens. */
517
+ contextWindow: number;
518
+
519
+ /** Maximum output tokens. */
520
+ maxTokens: number;
521
+
522
+ /** Custom headers for this specific model. */
523
+ headers?: Record<string, string>;
524
+
525
+ /** OpenAI compatibility settings for openai-completions API. */
526
+ compat?: {
527
+ supportsStore?: boolean;
528
+ supportsDeveloperRole?: boolean;
529
+ supportsReasoningEffort?: boolean;
530
+ supportsUsageInStreaming?: boolean;
531
+ maxTokensField?: "max_completion_tokens" | "max_tokens";
532
+ requiresToolResultName?: boolean;
533
+ requiresAssistantAfterToolResult?: boolean;
534
+ requiresThinkingAsText?: boolean;
535
+ requiresMistralToolIds?: boolean;
536
+ thinkingFormat?: "openai" | "zai" | "qwen";
537
+ };
538
+ }
539
+ ```
@@ -0,0 +1,69 @@
1
+ # Development
2
+
3
+ See [AGENTS.md](../../../AGENTS.md) for additional guidelines.
4
+
5
+ ## Setup
6
+
7
+ ```bash
8
+ git clone https://github.com/badlogic/pi-mono
9
+ cd pi-mono
10
+ npm install
11
+ npm run build
12
+ ```
13
+
14
+ Run from source:
15
+
16
+ ```bash
17
+ ./pi-test.sh
18
+ ```
19
+
20
+ ## Forking / Rebranding
21
+
22
+ Configure via `package.json`:
23
+
24
+ ```json
25
+ {
26
+ "piConfig": {
27
+ "name": "pi",
28
+ "configDir": ".pi"
29
+ }
30
+ }
31
+ ```
32
+
33
+ Change `name`, `configDir`, and `bin` field for your fork. Affects CLI banner, config paths, and environment variable names.
34
+
35
+ ## Path Resolution
36
+
37
+ Three execution modes: npm install, standalone binary, tsx from source.
38
+
39
+ **Always use `src/config.ts`** for package assets:
40
+
41
+ ```typescript
42
+ import { getPackageDir, getThemeDir } from "./config.js";
43
+ ```
44
+
45
+ Never use `__dirname` directly for package assets.
46
+
47
+ ## Debug Command
48
+
49
+ `/debug` (hidden) writes to `~/.pi/agent/pi-debug.log`:
50
+ - Rendered TUI lines with ANSI codes
51
+ - Last messages sent to the LLM
52
+
53
+ ## Testing
54
+
55
+ ```bash
56
+ ./test.sh # Run non-LLM tests (no API keys needed)
57
+ npm test # Run all tests
58
+ npm test -- test/specific.test.ts # Run specific test
59
+ ```
60
+
61
+ ## Project Structure
62
+
63
+ ```
64
+ packages/
65
+ ai/ # LLM provider abstraction
66
+ agent/ # Agent loop and message types
67
+ tui/ # Terminal UI components
68
+ coding-agent/ # CLI and interactive mode
69
+ ```