@phi-code-admin/phi-code 0.74.3 → 0.75.0

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (655) hide show
  1. package/CHANGELOG.md +1186 -4
  2. package/README.md +478 -379
  3. package/dist/bun/cli.d.ts +3 -0
  4. package/dist/bun/cli.d.ts.map +1 -0
  5. package/dist/bun/cli.js +9 -0
  6. package/dist/bun/cli.js.map +1 -0
  7. package/dist/bun/register-bedrock.d.ts +2 -0
  8. package/dist/bun/register-bedrock.d.ts.map +1 -0
  9. package/dist/bun/register-bedrock.js +4 -0
  10. package/dist/bun/register-bedrock.js.map +1 -0
  11. package/dist/bun/restore-sandbox-env.d.ts +13 -0
  12. package/dist/bun/restore-sandbox-env.d.ts.map +1 -0
  13. package/dist/bun/restore-sandbox-env.js +32 -0
  14. package/dist/bun/restore-sandbox-env.js.map +1 -0
  15. package/dist/cli/args.d.ts +12 -7
  16. package/dist/cli/args.d.ts.map +1 -1
  17. package/dist/cli/args.js +87 -45
  18. package/dist/cli/args.js.map +1 -1
  19. package/dist/cli/config-selector.d.ts.map +1 -1
  20. package/dist/cli/config-selector.js.map +1 -1
  21. package/dist/cli/file-processor.d.ts.map +1 -1
  22. package/dist/cli/file-processor.js +4 -0
  23. package/dist/cli/file-processor.js.map +1 -1
  24. package/dist/cli/initial-message.d.ts +18 -0
  25. package/dist/cli/initial-message.d.ts.map +1 -0
  26. package/dist/cli/initial-message.js +22 -0
  27. package/dist/cli/initial-message.js.map +1 -0
  28. package/dist/cli/list-models.d.ts.map +1 -1
  29. package/dist/cli/list-models.js +7 -1
  30. package/dist/cli/list-models.js.map +1 -1
  31. package/dist/cli/session-picker.d.ts.map +1 -1
  32. package/dist/cli/session-picker.js +2 -1
  33. package/dist/cli/session-picker.js.map +1 -1
  34. package/dist/cli.d.ts.map +1 -1
  35. package/dist/cli.js +9 -5
  36. package/dist/cli.js.map +1 -1
  37. package/dist/config.d.ts +24 -0
  38. package/dist/config.d.ts.map +1 -1
  39. package/dist/config.js +226 -30
  40. package/dist/config.js.map +1 -1
  41. package/dist/core/agent-session-runtime.d.ts +117 -0
  42. package/dist/core/agent-session-runtime.d.ts.map +1 -0
  43. package/dist/core/agent-session-runtime.js +300 -0
  44. package/dist/core/agent-session-runtime.js.map +1 -0
  45. package/dist/core/agent-session-services.d.ts +86 -0
  46. package/dist/core/agent-session-services.d.ts.map +1 -0
  47. package/dist/core/agent-session-services.js +117 -0
  48. package/dist/core/agent-session-services.js.map +1 -0
  49. package/dist/core/agent-session.d.ts +63 -82
  50. package/dist/core/agent-session.d.ts.map +1 -1
  51. package/dist/core/agent-session.js +674 -628
  52. package/dist/core/agent-session.js.map +1 -1
  53. package/dist/core/api-key-store.d.ts +87 -0
  54. package/dist/core/api-key-store.d.ts.map +1 -0
  55. package/dist/core/api-key-store.js +168 -0
  56. package/dist/core/api-key-store.js.map +1 -0
  57. package/dist/core/auth-guidance.d.ts +5 -0
  58. package/dist/core/auth-guidance.d.ts.map +1 -0
  59. package/dist/core/auth-guidance.js +21 -0
  60. package/dist/core/auth-guidance.js.map +1 -0
  61. package/dist/core/auth-storage.d.ts +12 -5
  62. package/dist/core/auth-storage.d.ts.map +1 -1
  63. package/dist/core/auth-storage.js +34 -8
  64. package/dist/core/auth-storage.js.map +1 -1
  65. package/dist/core/bash-executor.d.ts +0 -15
  66. package/dist/core/bash-executor.d.ts.map +1 -1
  67. package/dist/core/bash-executor.js +28 -129
  68. package/dist/core/bash-executor.js.map +1 -1
  69. package/dist/core/compaction/branch-summarization.d.ts +2 -0
  70. package/dist/core/compaction/branch-summarization.d.ts.map +1 -1
  71. package/dist/core/compaction/branch-summarization.js +3 -2
  72. package/dist/core/compaction/branch-summarization.js.map +1 -1
  73. package/dist/core/compaction/compaction.d.ts +4 -4
  74. package/dist/core/compaction/compaction.d.ts.map +1 -1
  75. package/dist/core/compaction/compaction.js +32 -27
  76. package/dist/core/compaction/compaction.js.map +1 -1
  77. package/dist/core/compaction/index.d.ts.map +1 -1
  78. package/dist/core/compaction/utils.d.ts.map +1 -1
  79. package/dist/core/compaction/utils.js.map +1 -1
  80. package/dist/core/config-watcher.d.ts +47 -0
  81. package/dist/core/config-watcher.d.ts.map +1 -0
  82. package/dist/core/config-watcher.js +135 -0
  83. package/dist/core/config-watcher.js.map +1 -0
  84. package/dist/core/default-models.json +80 -0
  85. package/dist/core/defaults.d.ts.map +1 -1
  86. package/dist/core/diagnostics.d.ts.map +1 -1
  87. package/dist/core/event-bus.d.ts.map +1 -1
  88. package/dist/core/event-bus.js.map +1 -1
  89. package/dist/core/exec.d.ts.map +1 -1
  90. package/dist/core/exec.js +7 -3
  91. package/dist/core/exec.js.map +1 -1
  92. package/dist/core/export-html/ansi-to-html.d.ts.map +1 -1
  93. package/dist/core/export-html/ansi-to-html.js +1 -1
  94. package/dist/core/export-html/ansi-to-html.js.map +1 -1
  95. package/dist/core/export-html/index.d.ts +7 -4
  96. package/dist/core/export-html/index.d.ts.map +1 -1
  97. package/dist/core/export-html/index.js +15 -13
  98. package/dist/core/export-html/index.js.map +1 -1
  99. package/dist/core/export-html/template.css +112 -17
  100. package/dist/core/export-html/template.html +1 -0
  101. package/dist/core/export-html/template.js +312 -64
  102. package/dist/core/export-html/tool-renderer.d.ts +9 -10
  103. package/dist/core/export-html/tool-renderer.d.ts.map +1 -1
  104. package/dist/core/export-html/tool-renderer.js +61 -16
  105. package/dist/core/export-html/tool-renderer.js.map +1 -1
  106. package/dist/core/extensions/index.d.ts +5 -4
  107. package/dist/core/extensions/index.d.ts.map +1 -1
  108. package/dist/core/extensions/index.js +2 -2
  109. package/dist/core/extensions/index.js.map +1 -1
  110. package/dist/core/extensions/loader.d.ts +0 -1
  111. package/dist/core/extensions/loader.d.ts.map +1 -1
  112. package/dist/core/extensions/loader.js +98 -18
  113. package/dist/core/extensions/loader.js.map +1 -1
  114. package/dist/core/extensions/runner.d.ts +27 -14
  115. package/dist/core/extensions/runner.d.ts.map +1 -1
  116. package/dist/core/extensions/runner.js +299 -115
  117. package/dist/core/extensions/runner.js.map +1 -1
  118. package/dist/core/extensions/types.d.ts +200 -44
  119. package/dist/core/extensions/types.d.ts.map +1 -1
  120. package/dist/core/extensions/types.js +10 -0
  121. package/dist/core/extensions/types.js.map +1 -1
  122. package/dist/core/extensions/wrapper.d.ts +4 -11
  123. package/dist/core/extensions/wrapper.d.ts.map +1 -1
  124. package/dist/core/extensions/wrapper.js +7 -87
  125. package/dist/core/extensions/wrapper.js.map +1 -1
  126. package/dist/core/footer-data-provider.d.ts +22 -2
  127. package/dist/core/footer-data-provider.d.ts.map +1 -1
  128. package/dist/core/footer-data-provider.js +225 -49
  129. package/dist/core/footer-data-provider.js.map +1 -1
  130. package/dist/core/index.d.ts +5 -2
  131. package/dist/core/index.d.ts.map +1 -1
  132. package/dist/core/index.js +5 -2
  133. package/dist/core/index.js.map +1 -1
  134. package/dist/core/keybindings.d.ts +348 -50
  135. package/dist/core/keybindings.d.ts.map +1 -1
  136. package/dist/core/keybindings.js +276 -132
  137. package/dist/core/keybindings.js.map +1 -1
  138. package/dist/core/messages.d.ts.map +1 -1
  139. package/dist/core/messages.js.map +1 -1
  140. package/dist/core/model-registry.d.ts +41 -5
  141. package/dist/core/model-registry.d.ts.map +1 -1
  142. package/dist/core/model-registry.js +316 -136
  143. package/dist/core/model-registry.js.map +1 -1
  144. package/dist/core/model-resolver.d.ts +6 -0
  145. package/dist/core/model-resolver.d.ts.map +1 -1
  146. package/dist/core/model-resolver.js +70 -37
  147. package/dist/core/model-resolver.js.map +1 -1
  148. package/dist/core/output-guard.d.ts +6 -0
  149. package/dist/core/output-guard.d.ts.map +1 -0
  150. package/dist/core/output-guard.js +59 -0
  151. package/dist/core/output-guard.js.map +1 -0
  152. package/dist/core/package-manager.d.ts +49 -7
  153. package/dist/core/package-manager.d.ts.map +1 -1
  154. package/dist/core/package-manager.js +655 -122
  155. package/dist/core/package-manager.js.map +1 -1
  156. package/dist/core/prompt-templates.d.ts +12 -10
  157. package/dist/core/prompt-templates.d.ts.map +1 -1
  158. package/dist/core/prompt-templates.js +37 -38
  159. package/dist/core/prompt-templates.js.map +1 -1
  160. package/dist/core/provider-display-names.d.ts +2 -0
  161. package/dist/core/provider-display-names.d.ts.map +1 -0
  162. package/dist/core/provider-display-names.js +33 -0
  163. package/dist/core/provider-display-names.js.map +1 -0
  164. package/dist/core/resolve-config-value.d.ts +6 -0
  165. package/dist/core/resolve-config-value.d.ts.map +1 -1
  166. package/dist/core/resolve-config-value.js +75 -8
  167. package/dist/core/resolve-config-value.js.map +1 -1
  168. package/dist/core/resource-loader.d.ts +18 -8
  169. package/dist/core/resource-loader.d.ts.map +1 -1
  170. package/dist/core/resource-loader.js +217 -123
  171. package/dist/core/resource-loader.js.map +1 -1
  172. package/dist/core/sdk.d.ts +25 -8
  173. package/dist/core/sdk.d.ts.map +1 -1
  174. package/dist/core/sdk.js +84 -37
  175. package/dist/core/sdk.js.map +1 -1
  176. package/dist/core/session-cwd.d.ts +19 -0
  177. package/dist/core/session-cwd.d.ts.map +1 -0
  178. package/dist/core/session-cwd.js +38 -0
  179. package/dist/core/session-cwd.js.map +1 -0
  180. package/dist/core/session-manager.d.ts +11 -1
  181. package/dist/core/session-manager.d.ts.map +1 -1
  182. package/dist/core/session-manager.js +42 -27
  183. package/dist/core/session-manager.js.map +1 -1
  184. package/dist/core/settings-manager.d.ts +34 -5
  185. package/dist/core/settings-manager.d.ts.map +1 -1
  186. package/dist/core/settings-manager.js +113 -13
  187. package/dist/core/settings-manager.js.map +1 -1
  188. package/dist/core/skills.d.ts +13 -11
  189. package/dist/core/skills.d.ts.map +1 -1
  190. package/dist/core/skills.js +59 -19
  191. package/dist/core/skills.js.map +1 -1
  192. package/dist/core/slash-commands.d.ts +2 -3
  193. package/dist/core/slash-commands.d.ts.map +1 -1
  194. package/dist/core/slash-commands.js +9 -6
  195. package/dist/core/slash-commands.js.map +1 -1
  196. package/dist/core/source-info.d.ts +18 -0
  197. package/dist/core/source-info.d.ts.map +1 -0
  198. package/dist/core/source-info.js +19 -0
  199. package/dist/core/source-info.js.map +1 -0
  200. package/dist/core/system-prompt.d.ts +3 -3
  201. package/dist/core/system-prompt.d.ts.map +1 -1
  202. package/dist/core/system-prompt.js +16 -55
  203. package/dist/core/system-prompt.js.map +1 -1
  204. package/dist/core/telemetry.d.ts +3 -0
  205. package/dist/core/telemetry.d.ts.map +1 -0
  206. package/dist/core/telemetry.js +9 -0
  207. package/dist/core/telemetry.js.map +1 -0
  208. package/dist/core/timings.d.ts +1 -0
  209. package/dist/core/timings.d.ts.map +1 -1
  210. package/dist/core/timings.js +6 -0
  211. package/dist/core/timings.js.map +1 -1
  212. package/dist/core/tools/bash.d.ts +27 -14
  213. package/dist/core/tools/bash.d.ts.map +1 -1
  214. package/dist/core/tools/bash.js +301 -208
  215. package/dist/core/tools/bash.js.map +1 -1
  216. package/dist/core/tools/edit-diff.d.ts +23 -1
  217. package/dist/core/tools/edit-diff.d.ts.map +1 -1
  218. package/dist/core/tools/edit-diff.js +154 -59
  219. package/dist/core/tools/edit-diff.js.map +1 -1
  220. package/dist/core/tools/edit.d.ts +22 -12
  221. package/dist/core/tools/edit.d.ts.map +1 -1
  222. package/dist/core/tools/edit.js +243 -65
  223. package/dist/core/tools/edit.js.map +1 -1
  224. package/dist/core/tools/file-mutation-queue.d.ts +6 -0
  225. package/dist/core/tools/file-mutation-queue.d.ts.map +1 -0
  226. package/dist/core/tools/file-mutation-queue.js +37 -0
  227. package/dist/core/tools/file-mutation-queue.js.map +1 -0
  228. package/dist/core/tools/find.d.ts +10 -14
  229. package/dist/core/tools/find.d.ts.map +1 -1
  230. package/dist/core/tools/find.js +202 -110
  231. package/dist/core/tools/find.js.map +1 -1
  232. package/dist/core/tools/grep.d.ts +14 -22
  233. package/dist/core/tools/grep.d.ts.map +1 -1
  234. package/dist/core/tools/grep.js +100 -35
  235. package/dist/core/tools/grep.js.map +1 -1
  236. package/dist/core/tools/index.d.ts +27 -60
  237. package/dist/core/tools/index.d.ts.map +1 -1
  238. package/dist/core/tools/index.js +96 -45
  239. package/dist/core/tools/index.js.map +1 -1
  240. package/dist/core/tools/ls.d.ts +8 -11
  241. package/dist/core/tools/ls.d.ts.map +1 -1
  242. package/dist/core/tools/ls.js +66 -15
  243. package/dist/core/tools/ls.js.map +1 -1
  244. package/dist/core/tools/output-accumulator.d.ts +50 -0
  245. package/dist/core/tools/output-accumulator.d.ts.map +1 -0
  246. package/dist/core/tools/output-accumulator.js +178 -0
  247. package/dist/core/tools/output-accumulator.js.map +1 -0
  248. package/dist/core/tools/path-utils.d.ts.map +1 -1
  249. package/dist/core/tools/path-utils.js +1 -1
  250. package/dist/core/tools/path-utils.js.map +1 -1
  251. package/dist/core/tools/read.d.ts +9 -13
  252. package/dist/core/tools/read.d.ts.map +1 -1
  253. package/dist/core/tools/read.js +175 -52
  254. package/dist/core/tools/read.js.map +1 -1
  255. package/dist/core/tools/render-utils.d.ts +21 -0
  256. package/dist/core/tools/render-utils.d.ts.map +1 -0
  257. package/dist/core/tools/render-utils.js +49 -0
  258. package/dist/core/tools/render-utils.js.map +1 -0
  259. package/dist/core/tools/tool-definition-wrapper.d.ts +14 -0
  260. package/dist/core/tools/tool-definition-wrapper.d.ts.map +1 -0
  261. package/dist/core/tools/tool-definition-wrapper.js +34 -0
  262. package/dist/core/tools/tool-definition-wrapper.js.map +1 -0
  263. package/dist/core/tools/truncate.d.ts.map +1 -1
  264. package/dist/core/tools/truncate.js.map +1 -1
  265. package/dist/core/tools/write.d.ts +8 -11
  266. package/dist/core/tools/write.d.ts.map +1 -1
  267. package/dist/core/tools/write.js +167 -32
  268. package/dist/core/tools/write.js.map +1 -1
  269. package/dist/index.d.ts +12 -9
  270. package/dist/index.d.ts.map +1 -1
  271. package/dist/index.js +12 -10
  272. package/dist/index.js.map +1 -1
  273. package/dist/main.d.ts +5 -1
  274. package/dist/main.d.ts.map +1 -1
  275. package/dist/main.js +326 -404
  276. package/dist/main.js.map +1 -1
  277. package/dist/migrations.d.ts +2 -2
  278. package/dist/migrations.d.ts.map +1 -1
  279. package/dist/migrations.js +24 -4
  280. package/dist/migrations.js.map +1 -1
  281. package/dist/modes/index.d.ts.map +1 -1
  282. package/dist/modes/interactive/components/armin.d.ts.map +1 -1
  283. package/dist/modes/interactive/components/armin.js +10 -6
  284. package/dist/modes/interactive/components/armin.js.map +1 -1
  285. package/dist/modes/interactive/components/assistant-message.d.ts +5 -1
  286. package/dist/modes/interactive/components/assistant-message.d.ts.map +1 -1
  287. package/dist/modes/interactive/components/assistant-message.js +32 -3
  288. package/dist/modes/interactive/components/assistant-message.js.map +1 -1
  289. package/dist/modes/interactive/components/bash-execution.d.ts +0 -1
  290. package/dist/modes/interactive/components/bash-execution.d.ts.map +1 -1
  291. package/dist/modes/interactive/components/bash-execution.js +31 -12
  292. package/dist/modes/interactive/components/bash-execution.js.map +1 -1
  293. package/dist/modes/interactive/components/bordered-loader.d.ts.map +1 -1
  294. package/dist/modes/interactive/components/bordered-loader.js +7 -1
  295. package/dist/modes/interactive/components/bordered-loader.js.map +1 -1
  296. package/dist/modes/interactive/components/branch-summary-message.d.ts.map +1 -1
  297. package/dist/modes/interactive/components/branch-summary-message.js +5 -3
  298. package/dist/modes/interactive/components/branch-summary-message.js.map +1 -1
  299. package/dist/modes/interactive/components/compaction-summary-message.d.ts.map +1 -1
  300. package/dist/modes/interactive/components/compaction-summary-message.js +5 -3
  301. package/dist/modes/interactive/components/compaction-summary-message.js.map +1 -1
  302. package/dist/modes/interactive/components/config-selector.d.ts.map +1 -1
  303. package/dist/modes/interactive/components/config-selector.js +49 -16
  304. package/dist/modes/interactive/components/config-selector.js.map +1 -1
  305. package/dist/modes/interactive/components/countdown-timer.d.ts.map +1 -1
  306. package/dist/modes/interactive/components/countdown-timer.js +5 -0
  307. package/dist/modes/interactive/components/countdown-timer.js.map +1 -1
  308. package/dist/modes/interactive/components/custom-editor.d.ts +3 -3
  309. package/dist/modes/interactive/components/custom-editor.d.ts.map +1 -1
  310. package/dist/modes/interactive/components/custom-editor.js +14 -7
  311. package/dist/modes/interactive/components/custom-editor.js.map +1 -1
  312. package/dist/modes/interactive/components/custom-message.d.ts.map +1 -1
  313. package/dist/modes/interactive/components/custom-message.js +6 -1
  314. package/dist/modes/interactive/components/custom-message.js.map +1 -1
  315. package/dist/modes/interactive/components/daxnuts.d.ts.map +1 -1
  316. package/dist/modes/interactive/components/daxnuts.js +8 -6
  317. package/dist/modes/interactive/components/daxnuts.js.map +1 -1
  318. package/dist/modes/interactive/components/diff.d.ts.map +1 -1
  319. package/dist/modes/interactive/components/diff.js.map +1 -1
  320. package/dist/modes/interactive/components/dynamic-border.d.ts.map +1 -1
  321. package/dist/modes/interactive/components/dynamic-border.js +1 -0
  322. package/dist/modes/interactive/components/dynamic-border.js.map +1 -1
  323. package/dist/modes/interactive/components/earendil-announcement.d.ts +5 -0
  324. package/dist/modes/interactive/components/earendil-announcement.d.ts.map +1 -0
  325. package/dist/modes/interactive/components/earendil-announcement.js +40 -0
  326. package/dist/modes/interactive/components/earendil-announcement.js.map +1 -0
  327. package/dist/modes/interactive/components/extension-editor.d.ts.map +1 -1
  328. package/dist/modes/interactive/components/extension-editor.js +16 -10
  329. package/dist/modes/interactive/components/extension-editor.js.map +1 -1
  330. package/dist/modes/interactive/components/extension-input.d.ts.map +1 -1
  331. package/dist/modes/interactive/components/extension-input.js +13 -7
  332. package/dist/modes/interactive/components/extension-input.js.map +1 -1
  333. package/dist/modes/interactive/components/extension-selector.d.ts.map +1 -1
  334. package/dist/modes/interactive/components/extension-selector.js +18 -11
  335. package/dist/modes/interactive/components/extension-selector.js.map +1 -1
  336. package/dist/modes/interactive/components/footer.d.ts +1 -0
  337. package/dist/modes/interactive/components/footer.d.ts.map +1 -1
  338. package/dist/modes/interactive/components/footer.js +7 -2
  339. package/dist/modes/interactive/components/footer.js.map +1 -1
  340. package/dist/modes/interactive/components/index.d.ts +1 -1
  341. package/dist/modes/interactive/components/index.d.ts.map +1 -1
  342. package/dist/modes/interactive/components/index.js +1 -1
  343. package/dist/modes/interactive/components/index.js.map +1 -1
  344. package/dist/modes/interactive/components/keybinding-hints.d.ts +8 -36
  345. package/dist/modes/interactive/components/keybinding-hints.d.ts.map +1 -1
  346. package/dist/modes/interactive/components/keybinding-hints.js +23 -48
  347. package/dist/modes/interactive/components/keybinding-hints.js.map +1 -1
  348. package/dist/modes/interactive/components/login-dialog.d.ts +5 -1
  349. package/dist/modes/interactive/components/login-dialog.d.ts.map +1 -1
  350. package/dist/modes/interactive/components/login-dialog.js +35 -14
  351. package/dist/modes/interactive/components/login-dialog.js.map +1 -1
  352. package/dist/modes/interactive/components/model-selector.d.ts.map +1 -1
  353. package/dist/modes/interactive/components/model-selector.js +41 -22
  354. package/dist/modes/interactive/components/model-selector.js.map +1 -1
  355. package/dist/modes/interactive/components/oauth-selector.d.ts +18 -6
  356. package/dist/modes/interactive/components/oauth-selector.d.ts.map +1 -1
  357. package/dist/modes/interactive/components/oauth-selector.js +104 -31
  358. package/dist/modes/interactive/components/oauth-selector.js.map +1 -1
  359. package/dist/modes/interactive/components/scoped-models-selector.d.ts +5 -12
  360. package/dist/modes/interactive/components/scoped-models-selector.d.ts.map +1 -1
  361. package/dist/modes/interactive/components/scoped-models-selector.js +61 -42
  362. package/dist/modes/interactive/components/scoped-models-selector.js.map +1 -1
  363. package/dist/modes/interactive/components/session-selector-search.d.ts.map +1 -1
  364. package/dist/modes/interactive/components/session-selector-search.js.map +1 -1
  365. package/dist/modes/interactive/components/session-selector.d.ts +2 -1
  366. package/dist/modes/interactive/components/session-selector.d.ts.map +1 -1
  367. package/dist/modes/interactive/components/session-selector.js +109 -73
  368. package/dist/modes/interactive/components/session-selector.js.map +1 -1
  369. package/dist/modes/interactive/components/settings-selector.d.ts +9 -0
  370. package/dist/modes/interactive/components/settings-selector.d.ts.map +1 -1
  371. package/dist/modes/interactive/components/settings-selector.js +84 -4
  372. package/dist/modes/interactive/components/settings-selector.js.map +1 -1
  373. package/dist/modes/interactive/components/show-images-selector.d.ts.map +1 -1
  374. package/dist/modes/interactive/components/show-images-selector.js +6 -1
  375. package/dist/modes/interactive/components/show-images-selector.js.map +1 -1
  376. package/dist/modes/interactive/components/skill-invocation-message.d.ts.map +1 -1
  377. package/dist/modes/interactive/components/skill-invocation-message.js +5 -3
  378. package/dist/modes/interactive/components/skill-invocation-message.js.map +1 -1
  379. package/dist/modes/interactive/components/theme-selector.d.ts.map +1 -1
  380. package/dist/modes/interactive/components/theme-selector.js +7 -1
  381. package/dist/modes/interactive/components/theme-selector.js.map +1 -1
  382. package/dist/modes/interactive/components/thinking-selector.d.ts.map +1 -1
  383. package/dist/modes/interactive/components/thinking-selector.js +6 -1
  384. package/dist/modes/interactive/components/thinking-selector.js.map +1 -1
  385. package/dist/modes/interactive/components/tool-execution.d.ts +20 -34
  386. package/dist/modes/interactive/components/tool-execution.d.ts.map +1 -1
  387. package/dist/modes/interactive/components/tool-execution.js +158 -636
  388. package/dist/modes/interactive/components/tool-execution.js.map +1 -1
  389. package/dist/modes/interactive/components/tree-selector.d.ts +21 -2
  390. package/dist/modes/interactive/components/tree-selector.d.ts.map +1 -1
  391. package/dist/modes/interactive/components/tree-selector.js +224 -52
  392. package/dist/modes/interactive/components/tree-selector.js.map +1 -1
  393. package/dist/modes/interactive/components/user-message-selector.d.ts +2 -2
  394. package/dist/modes/interactive/components/user-message-selector.d.ts.map +1 -1
  395. package/dist/modes/interactive/components/user-message-selector.js +20 -16
  396. package/dist/modes/interactive/components/user-message-selector.js.map +1 -1
  397. package/dist/modes/interactive/components/user-message.d.ts +1 -0
  398. package/dist/modes/interactive/components/user-message.d.ts.map +1 -1
  399. package/dist/modes/interactive/components/user-message.js +8 -6
  400. package/dist/modes/interactive/components/user-message.js.map +1 -1
  401. package/dist/modes/interactive/components/visual-truncate.d.ts.map +1 -1
  402. package/dist/modes/interactive/components/visual-truncate.js.map +1 -1
  403. package/dist/modes/interactive/interactive-mode.d.ts +67 -39
  404. package/dist/modes/interactive/interactive-mode.d.ts.map +1 -1
  405. package/dist/modes/interactive/interactive-mode.js +1556 -680
  406. package/dist/modes/interactive/interactive-mode.js.map +1 -1
  407. package/dist/modes/interactive/theme/dark.json +1 -1
  408. package/dist/modes/interactive/theme/light.json +1 -1
  409. package/dist/modes/interactive/theme/theme.d.ts +3 -0
  410. package/dist/modes/interactive/theme/theme.d.ts.map +1 -1
  411. package/dist/modes/interactive/theme/theme.js +101 -72
  412. package/dist/modes/interactive/theme/theme.js.map +1 -1
  413. package/dist/modes/print-mode.d.ts +2 -2
  414. package/dist/modes/print-mode.d.ts.map +1 -1
  415. package/dist/modes/print-mode.js +107 -77
  416. package/dist/modes/print-mode.js.map +1 -1
  417. package/dist/modes/rpc/jsonl.d.ts +17 -0
  418. package/dist/modes/rpc/jsonl.d.ts.map +1 -0
  419. package/dist/modes/rpc/jsonl.js +49 -0
  420. package/dist/modes/rpc/jsonl.js.map +1 -0
  421. package/dist/modes/rpc/rpc-client.d.ts +8 -1
  422. package/dist/modes/rpc/rpc-client.d.ts.map +1 -1
  423. package/dist/modes/rpc/rpc-client.js +22 -16
  424. package/dist/modes/rpc/rpc-client.js.map +1 -1
  425. package/dist/modes/rpc/rpc-mode.d.ts +2 -2
  426. package/dist/modes/rpc/rpc-mode.d.ts.map +1 -1
  427. package/dist/modes/rpc/rpc-mode.js +184 -94
  428. package/dist/modes/rpc/rpc-mode.js.map +1 -1
  429. package/dist/modes/rpc/rpc-types.d.ts +14 -4
  430. package/dist/modes/rpc/rpc-types.d.ts.map +1 -1
  431. package/dist/modes/rpc/rpc-types.js.map +1 -1
  432. package/dist/package-manager-cli.d.ts +4 -0
  433. package/dist/package-manager-cli.d.ts.map +1 -0
  434. package/dist/package-manager-cli.js +460 -0
  435. package/dist/package-manager-cli.js.map +1 -0
  436. package/dist/utils/changelog.d.ts.map +1 -1
  437. package/dist/utils/changelog.js.map +1 -1
  438. package/dist/utils/child-process.d.ts +12 -0
  439. package/dist/utils/child-process.d.ts.map +1 -0
  440. package/dist/utils/child-process.js +86 -0
  441. package/dist/utils/child-process.js.map +1 -0
  442. package/dist/utils/clipboard-image.d.ts.map +1 -1
  443. package/dist/utils/clipboard-image.js +94 -11
  444. package/dist/utils/clipboard-image.js.map +1 -1
  445. package/dist/utils/clipboard-native.d.ts +1 -0
  446. package/dist/utils/clipboard-native.d.ts.map +1 -1
  447. package/dist/utils/clipboard-native.js.map +1 -1
  448. package/dist/utils/clipboard.d.ts +1 -1
  449. package/dist/utils/clipboard.d.ts.map +1 -1
  450. package/dist/utils/clipboard.js +96 -46
  451. package/dist/utils/clipboard.js.map +1 -1
  452. package/dist/utils/exif-orientation.d.ts +5 -0
  453. package/dist/utils/exif-orientation.d.ts.map +1 -0
  454. package/dist/utils/exif-orientation.js +158 -0
  455. package/dist/utils/exif-orientation.js.map +1 -0
  456. package/dist/utils/frontmatter.d.ts.map +1 -1
  457. package/dist/utils/frontmatter.js.map +1 -1
  458. package/dist/utils/fs-watch.d.ts +5 -0
  459. package/dist/utils/fs-watch.d.ts.map +1 -0
  460. package/dist/utils/fs-watch.js +25 -0
  461. package/dist/utils/fs-watch.js.map +1 -0
  462. package/dist/utils/git.d.ts.map +1 -1
  463. package/dist/utils/git.js.map +1 -1
  464. package/dist/utils/image-convert.d.ts.map +1 -1
  465. package/dist/utils/image-convert.js +5 -1
  466. package/dist/utils/image-convert.js.map +1 -1
  467. package/dist/utils/image-resize.d.ts +5 -5
  468. package/dist/utils/image-resize.d.ts.map +1 -1
  469. package/dist/utils/image-resize.js +51 -95
  470. package/dist/utils/image-resize.js.map +1 -1
  471. package/dist/utils/mime.d.ts.map +1 -1
  472. package/dist/utils/mime.js.map +1 -1
  473. package/dist/utils/paths.d.ts +16 -0
  474. package/dist/utils/paths.d.ts.map +1 -0
  475. package/dist/utils/paths.js +50 -0
  476. package/dist/utils/paths.js.map +1 -0
  477. package/dist/utils/photon.d.ts.map +1 -1
  478. package/dist/utils/photon.js.map +1 -1
  479. package/dist/utils/pi-user-agent.d.ts +2 -0
  480. package/dist/utils/pi-user-agent.d.ts.map +1 -0
  481. package/dist/utils/pi-user-agent.js +5 -0
  482. package/dist/utils/pi-user-agent.js.map +1 -0
  483. package/dist/utils/shell.d.ts +10 -6
  484. package/dist/utils/shell.d.ts.map +1 -1
  485. package/dist/utils/shell.js +29 -25
  486. package/dist/utils/shell.js.map +1 -1
  487. package/dist/utils/sleep.d.ts.map +1 -1
  488. package/dist/utils/sleep.js.map +1 -1
  489. package/dist/utils/tools-manager.d.ts.map +1 -1
  490. package/dist/utils/tools-manager.js +11 -6
  491. package/dist/utils/tools-manager.js.map +1 -1
  492. package/dist/utils/version-check.d.ts +14 -0
  493. package/dist/utils/version-check.d.ts.map +1 -0
  494. package/dist/utils/version-check.js +77 -0
  495. package/dist/utils/version-check.js.map +1 -0
  496. package/docs/compaction.md +394 -0
  497. package/docs/custom-provider.md +646 -0
  498. package/docs/development.md +71 -0
  499. package/docs/docs.json +148 -0
  500. package/docs/extensions.md +2596 -0
  501. package/docs/images/doom-extension.png +0 -0
  502. package/docs/images/exy.png +0 -0
  503. package/docs/images/interactive-mode.png +0 -0
  504. package/docs/images/tree-view.png +0 -0
  505. package/docs/index.md +70 -0
  506. package/docs/json.md +82 -0
  507. package/docs/keybindings.md +197 -0
  508. package/docs/models.md +474 -0
  509. package/docs/packages.md +223 -0
  510. package/docs/prompt-templates.md +88 -0
  511. package/docs/providers.md +243 -0
  512. package/docs/quickstart.md +142 -0
  513. package/docs/rpc.md +1407 -0
  514. package/docs/sdk.md +1149 -0
  515. package/docs/session-format.md +412 -0
  516. package/docs/sessions.md +137 -0
  517. package/docs/settings.md +279 -0
  518. package/docs/shell-aliases.md +13 -0
  519. package/docs/skills.md +232 -0
  520. package/docs/terminal-setup.md +106 -0
  521. package/docs/termux.md +127 -0
  522. package/docs/themes.md +295 -0
  523. package/docs/tmux.md +61 -0
  524. package/docs/tui.md +918 -0
  525. package/docs/usage.md +277 -0
  526. package/docs/windows.md +17 -0
  527. package/examples/README.md +25 -0
  528. package/examples/extensions/README.md +208 -0
  529. package/examples/extensions/auto-commit-on-exit.ts +49 -0
  530. package/examples/extensions/bash-spawn-hook.ts +30 -0
  531. package/examples/extensions/bookmark.ts +50 -0
  532. package/examples/extensions/border-status-editor.ts +150 -0
  533. package/examples/extensions/built-in-tool-renderer.ts +249 -0
  534. package/examples/extensions/claude-rules.ts +86 -0
  535. package/examples/extensions/commands.ts +72 -0
  536. package/examples/extensions/confirm-destructive.ts +59 -0
  537. package/examples/extensions/custom-compaction.ts +127 -0
  538. package/examples/extensions/custom-footer.ts +64 -0
  539. package/examples/extensions/custom-header.ts +73 -0
  540. package/examples/extensions/custom-provider-anthropic/index.ts +604 -0
  541. package/examples/extensions/custom-provider-anthropic/package-lock.json +24 -0
  542. package/examples/extensions/custom-provider-anthropic/package.json +19 -0
  543. package/examples/extensions/custom-provider-gitlab-duo/index.ts +349 -0
  544. package/examples/extensions/custom-provider-gitlab-duo/package.json +16 -0
  545. package/examples/extensions/custom-provider-gitlab-duo/test.ts +82 -0
  546. package/examples/extensions/dirty-repo-guard.ts +56 -0
  547. package/examples/extensions/doom-overlay/README.md +46 -0
  548. package/examples/extensions/doom-overlay/doom/build/doom.js +21 -0
  549. package/examples/extensions/doom-overlay/doom/build/doom.wasm +0 -0
  550. package/examples/extensions/doom-overlay/doom/build.sh +152 -0
  551. package/examples/extensions/doom-overlay/doom/doomgeneric_pi.c +72 -0
  552. package/examples/extensions/doom-overlay/doom-component.ts +132 -0
  553. package/examples/extensions/doom-overlay/doom-engine.ts +173 -0
  554. package/examples/extensions/doom-overlay/doom-keys.ts +104 -0
  555. package/examples/extensions/doom-overlay/index.ts +74 -0
  556. package/examples/extensions/doom-overlay/wad-finder.ts +51 -0
  557. package/examples/extensions/dynamic-resources/SKILL.md +8 -0
  558. package/examples/extensions/dynamic-resources/dynamic.json +79 -0
  559. package/examples/extensions/dynamic-resources/dynamic.md +5 -0
  560. package/examples/extensions/dynamic-resources/index.ts +15 -0
  561. package/examples/extensions/dynamic-tools.ts +74 -0
  562. package/examples/extensions/event-bus.ts +43 -0
  563. package/examples/extensions/file-trigger.ts +41 -0
  564. package/examples/extensions/git-checkpoint.ts +53 -0
  565. package/examples/extensions/github-issue-autocomplete.ts +185 -0
  566. package/examples/extensions/handoff.ts +191 -0
  567. package/examples/extensions/hello.ts +26 -0
  568. package/examples/extensions/hidden-thinking-label.ts +53 -0
  569. package/examples/extensions/inline-bash.ts +94 -0
  570. package/examples/extensions/input-transform.ts +43 -0
  571. package/examples/extensions/interactive-shell.ts +196 -0
  572. package/examples/extensions/mac-system-theme.ts +47 -0
  573. package/examples/extensions/message-renderer.ts +59 -0
  574. package/examples/extensions/minimal-mode.ts +426 -0
  575. package/examples/extensions/modal-editor.ts +85 -0
  576. package/examples/extensions/model-status.ts +31 -0
  577. package/examples/extensions/notify.ts +55 -0
  578. package/examples/extensions/overlay-qa-tests.ts +1348 -0
  579. package/examples/extensions/overlay-test.ts +150 -0
  580. package/examples/extensions/permission-gate.ts +34 -0
  581. package/examples/extensions/pirate.ts +47 -0
  582. package/examples/extensions/plan-mode/README.md +65 -0
  583. package/examples/extensions/plan-mode/index.ts +340 -0
  584. package/examples/extensions/plan-mode/utils.ts +168 -0
  585. package/examples/extensions/preset.ts +430 -0
  586. package/examples/extensions/prompt-customizer.ts +97 -0
  587. package/examples/extensions/protected-paths.ts +30 -0
  588. package/examples/extensions/provider-payload.ts +18 -0
  589. package/examples/extensions/qna.ts +122 -0
  590. package/examples/extensions/question.ts +264 -0
  591. package/examples/extensions/questionnaire.ts +427 -0
  592. package/examples/extensions/rainbow-editor.ts +88 -0
  593. package/examples/extensions/reload-runtime.ts +37 -0
  594. package/examples/extensions/rpc-demo.ts +118 -0
  595. package/examples/extensions/sandbox/index.ts +321 -0
  596. package/examples/extensions/sandbox/package-lock.json +92 -0
  597. package/examples/extensions/sandbox/package.json +19 -0
  598. package/examples/extensions/send-user-message.ts +97 -0
  599. package/examples/extensions/session-name.ts +27 -0
  600. package/examples/extensions/shutdown-command.ts +63 -0
  601. package/examples/extensions/snake.ts +343 -0
  602. package/examples/extensions/space-invaders.ts +560 -0
  603. package/examples/extensions/ssh.ts +220 -0
  604. package/examples/extensions/status-line.ts +32 -0
  605. package/examples/extensions/structured-output.ts +65 -0
  606. package/examples/extensions/subagent/README.md +172 -0
  607. package/examples/extensions/subagent/agents/planner.md +37 -0
  608. package/examples/extensions/subagent/agents/reviewer.md +35 -0
  609. package/examples/extensions/subagent/agents/scout.md +50 -0
  610. package/examples/extensions/subagent/agents/worker.md +24 -0
  611. package/examples/extensions/subagent/agents.ts +126 -0
  612. package/examples/extensions/subagent/index.ts +987 -0
  613. package/examples/extensions/subagent/prompts/implement-and-review.md +10 -0
  614. package/examples/extensions/subagent/prompts/implement.md +10 -0
  615. package/examples/extensions/subagent/prompts/scout-and-plan.md +9 -0
  616. package/examples/extensions/summarize.ts +206 -0
  617. package/examples/extensions/system-prompt-header.ts +17 -0
  618. package/examples/extensions/tic-tac-toe.ts +1008 -0
  619. package/examples/extensions/timed-confirm.ts +70 -0
  620. package/examples/extensions/titlebar-spinner.ts +58 -0
  621. package/examples/extensions/todo.ts +297 -0
  622. package/examples/extensions/tool-override.ts +144 -0
  623. package/examples/extensions/tools.ts +141 -0
  624. package/examples/extensions/trigger-compact.ts +50 -0
  625. package/examples/extensions/truncated-tool.ts +195 -0
  626. package/examples/extensions/widget-placement.ts +9 -0
  627. package/examples/extensions/with-deps/index.ts +32 -0
  628. package/examples/extensions/with-deps/package-lock.json +31 -0
  629. package/examples/extensions/with-deps/package.json +22 -0
  630. package/examples/extensions/working-indicator.ts +123 -0
  631. package/examples/extensions/working-message-test.ts +25 -0
  632. package/examples/rpc-extension-ui.ts +632 -0
  633. package/examples/sdk/01-minimal.ts +22 -0
  634. package/examples/sdk/02-custom-model.ts +49 -0
  635. package/examples/sdk/03-custom-prompt.ts +62 -0
  636. package/examples/sdk/04-skills.ts +55 -0
  637. package/examples/sdk/05-tools.ts +44 -0
  638. package/examples/sdk/06-extensions.ts +90 -0
  639. package/examples/sdk/07-context-files.ts +42 -0
  640. package/examples/sdk/08-prompt-templates.ts +51 -0
  641. package/examples/sdk/09-api-keys-and-oauth.ts +48 -0
  642. package/examples/sdk/10-settings.ts +53 -0
  643. package/examples/sdk/11-sessions.ts +48 -0
  644. package/examples/sdk/12-full-control.ts +73 -0
  645. package/examples/sdk/13-session-runtime.ts +67 -0
  646. package/examples/sdk/README.md +147 -0
  647. package/extensions/phi/init.ts +15 -1
  648. package/extensions/phi/keys.ts +186 -0
  649. package/extensions/phi/providers/alibaba.ts +126 -0
  650. package/extensions/phi/providers/opencode-go.ts +204 -0
  651. package/extensions/phi/setup.ts +692 -0
  652. package/extensions/phi/smart-router.ts +8 -0
  653. package/package.json +17 -12
  654. package/scripts/copy-assets.sh +0 -0
  655. package/scripts/migrate-sessions.sh +0 -0
package/docs/sdk.md ADDED
@@ -0,0 +1,1149 @@
1
+ > pi can help you use the SDK. Ask it to build an integration for your use case.
2
+
3
+ # SDK
4
+
5
+ The SDK provides programmatic access to pi's agent capabilities. Use it to embed pi in other applications, build custom interfaces, or integrate with automated workflows.
6
+
7
+ **Example use cases:**
8
+ - Build a custom UI (web, desktop, mobile)
9
+ - Integrate agent capabilities into existing applications
10
+ - Create automated pipelines with agent reasoning
11
+ - Build custom tools that spawn sub-agents
12
+ - Test agent behavior programmatically
13
+
14
+ See [examples/sdk/](../examples/sdk/) for working examples from minimal to full control.
15
+
16
+ ## Quick Start
17
+
18
+ ```typescript
19
+ import { AuthStorage, createAgentSession, ModelRegistry, SessionManager } from "@earendil-works/pi-coding-agent";
20
+
21
+ // Set up credential storage and model registry
22
+ const authStorage = AuthStorage.create();
23
+ const modelRegistry = ModelRegistry.create(authStorage);
24
+
25
+ const { session } = await createAgentSession({
26
+ sessionManager: SessionManager.inMemory(),
27
+ authStorage,
28
+ modelRegistry,
29
+ });
30
+
31
+ session.subscribe((event) => {
32
+ if (event.type === "message_update" && event.assistantMessageEvent.type === "text_delta") {
33
+ process.stdout.write(event.assistantMessageEvent.delta);
34
+ }
35
+ });
36
+
37
+ await session.prompt("What files are in the current directory?");
38
+ ```
39
+
40
+ ## Installation
41
+
42
+ ```bash
43
+ npm install @earendil-works/pi-coding-agent
44
+ ```
45
+
46
+ The SDK is included in the main package. No separate installation needed.
47
+
48
+ ## Core Concepts
49
+
50
+ ### createAgentSession()
51
+
52
+ The main factory function for a single `AgentSession`.
53
+
54
+ `createAgentSession()` uses a `ResourceLoader` to supply extensions, skills, prompt templates, themes, and context files. If you do not provide one, it uses `DefaultResourceLoader` with standard discovery.
55
+
56
+ ```typescript
57
+ import { createAgentSession } from "@earendil-works/pi-coding-agent";
58
+
59
+ // Minimal: defaults with DefaultResourceLoader
60
+ const { session } = await createAgentSession();
61
+
62
+ // Custom: override specific options
63
+ const { session } = await createAgentSession({
64
+ model: myModel,
65
+ tools: [readTool, bashTool],
66
+ sessionManager: SessionManager.inMemory(),
67
+ });
68
+ ```
69
+
70
+ ### AgentSession
71
+
72
+ The session manages agent lifecycle, message history, model state, compaction, and event streaming.
73
+
74
+ ```typescript
75
+ interface AgentSession {
76
+ // Send a prompt and wait for completion
77
+ prompt(text: string, options?: PromptOptions): Promise<void>;
78
+
79
+ // Queue messages during streaming
80
+ steer(text: string): Promise<void>;
81
+ followUp(text: string): Promise<void>;
82
+
83
+ // Subscribe to events (returns unsubscribe function)
84
+ subscribe(listener: (event: AgentSessionEvent) => void): () => void;
85
+
86
+ // Session info
87
+ sessionFile: string | undefined;
88
+ sessionId: string;
89
+
90
+ // Model control
91
+ setModel(model: Model): Promise<void>;
92
+ setThinkingLevel(level: ThinkingLevel): void;
93
+ cycleModel(): Promise<ModelCycleResult | undefined>;
94
+ cycleThinkingLevel(): ThinkingLevel | undefined;
95
+
96
+ // State access
97
+ agent: Agent;
98
+ model: Model | undefined;
99
+ thinkingLevel: ThinkingLevel;
100
+ messages: AgentMessage[];
101
+ isStreaming: boolean;
102
+
103
+ // In-place tree navigation within the current session file
104
+ navigateTree(targetId: string, options?: { summarize?: boolean; customInstructions?: string; replaceInstructions?: boolean; label?: string }): Promise<{ editorText?: string; cancelled: boolean }>;
105
+
106
+ // Compaction
107
+ compact(customInstructions?: string): Promise<CompactionResult>;
108
+ abortCompaction(): void;
109
+
110
+ // Abort current operation
111
+ abort(): Promise<void>;
112
+
113
+ // Cleanup
114
+ dispose(): void;
115
+ }
116
+ ```
117
+
118
+ Session replacement APIs such as new-session, resume, fork, and import live on `AgentSessionRuntime`, not on `AgentSession`.
119
+
120
+ ### createAgentSessionRuntime() and AgentSessionRuntime
121
+
122
+ Use the runtime API when you need to replace the active session and rebuild cwd-bound runtime state.
123
+ This is the same layer used by the built-in interactive, print, and RPC modes.
124
+
125
+ `createAgentSessionRuntime()` takes a runtime factory plus the initial cwd/session target. The factory closes over process-global fixed inputs, recreates cwd-bound services for the effective cwd, resolves session options against those services, and returns a full runtime result.
126
+
127
+ ```typescript
128
+ import {
129
+ type CreateAgentSessionRuntimeFactory,
130
+ createAgentSessionFromServices,
131
+ createAgentSessionRuntime,
132
+ createAgentSessionServices,
133
+ getAgentDir,
134
+ SessionManager,
135
+ } from "@earendil-works/pi-coding-agent";
136
+
137
+ const createRuntime: CreateAgentSessionRuntimeFactory = async ({ cwd, sessionManager, sessionStartEvent }) => {
138
+ const services = await createAgentSessionServices({ cwd });
139
+ return {
140
+ ...(await createAgentSessionFromServices({
141
+ services,
142
+ sessionManager,
143
+ sessionStartEvent,
144
+ })),
145
+ services,
146
+ diagnostics: services.diagnostics,
147
+ };
148
+ };
149
+
150
+ const runtime = await createAgentSessionRuntime(createRuntime, {
151
+ cwd: process.cwd(),
152
+ agentDir: getAgentDir(),
153
+ sessionManager: SessionManager.create(process.cwd()),
154
+ });
155
+ ```
156
+
157
+ `AgentSessionRuntime` owns replacement of the active runtime across:
158
+
159
+ - `newSession()`
160
+ - `switchSession()`
161
+ - `fork()`
162
+ - clone flows via `fork(entryId, { position: "at" })`
163
+ - `importFromJsonl()`
164
+
165
+ Important behavior:
166
+
167
+ - `runtime.session` changes after those operations
168
+ - event subscriptions are attached to a specific `AgentSession`, so re-subscribe after replacement
169
+ - if you use extensions, call `runtime.session.bindExtensions(...)` again for the new session
170
+ - creation returns diagnostics on `runtime.diagnostics`
171
+ - if runtime creation or replacement fails, the method throws and the caller decides how to handle it
172
+
173
+ ```typescript
174
+ let session = runtime.session;
175
+ let unsubscribe = session.subscribe(() => {});
176
+
177
+ await runtime.newSession();
178
+
179
+ unsubscribe();
180
+ session = runtime.session;
181
+ unsubscribe = session.subscribe(() => {});
182
+ ```
183
+
184
+ ### Prompting and Message Queueing
185
+
186
+ `PromptOptions` controls prompt expansion, queueing behavior while streaming, and prompt preflight notifications:
187
+
188
+ ```typescript
189
+ interface PromptOptions {
190
+ expandPromptTemplates?: boolean;
191
+ images?: ImageContent[];
192
+ streamingBehavior?: "steer" | "followUp";
193
+ source?: InputSource;
194
+ preflightResult?: (success: boolean) => void;
195
+ }
196
+ ```
197
+
198
+ `preflightResult` is called once per `prompt()` invocation:
199
+
200
+ - `true` when the prompt was accepted, queued, or handled immediately
201
+ - `false` when prompt preflight rejected before acceptance
202
+
203
+ It fires before `prompt()` resolves. `prompt()` still resolves only after the full accepted run finishes, including retries. Failures after acceptance are reported through the normal event and message stream, not through `preflightResult(false)`.
204
+
205
+ The `prompt()` method handles prompt templates, extension commands, and message sending:
206
+
207
+ ```typescript
208
+ // Basic prompt (when not streaming)
209
+ await session.prompt("What files are here?");
210
+
211
+ // With images
212
+ await session.prompt("What's in this image?", {
213
+ images: [{ type: "image", source: { type: "base64", mediaType: "image/png", data: "..." } }]
214
+ });
215
+
216
+ // During streaming: must specify how to queue the message
217
+ await session.prompt("Stop and do this instead", { streamingBehavior: "steer" });
218
+ await session.prompt("After you're done, also check X", { streamingBehavior: "followUp" });
219
+ ```
220
+
221
+ **Behavior:**
222
+ - **Extension commands** (e.g., `/mycommand`): Execute immediately, even during streaming. They manage their own LLM interaction via `pi.sendMessage()`.
223
+ - **File-based prompt templates** (from `.md` files): Expanded to their content before sending or queueing.
224
+ - **During streaming without `streamingBehavior`**: Throws an error. Use `steer()` or `followUp()` directly, or specify the option.
225
+ - **`preflightResult(true)`**: Means the prompt was accepted, queued, or handled immediately.
226
+ - **`preflightResult(false)`**: Means preflight rejected before acceptance.
227
+
228
+ For explicit queueing during streaming:
229
+
230
+ ```typescript
231
+ // Queue a steering message for delivery after the current assistant turn finishes its tool calls
232
+ await session.steer("New instruction");
233
+
234
+ // Wait for agent to finish (delivered only when agent stops)
235
+ await session.followUp("After you're done, also do this");
236
+ ```
237
+
238
+ Both `steer()` and `followUp()` expand file-based prompt templates but error on extension commands (extension commands cannot be queued).
239
+
240
+ ### Agent and AgentState
241
+
242
+ The `Agent` class (from `@earendil-works/pi-agent-core`) handles the core LLM interaction. Access it via `session.agent`.
243
+
244
+ ```typescript
245
+ // Access current state
246
+ const state = session.agent.state;
247
+
248
+ // state.messages: AgentMessage[] - conversation history
249
+ // state.model: Model - current model
250
+ // state.thinkingLevel: ThinkingLevel - current thinking level
251
+ // state.systemPrompt: string - system prompt
252
+ // state.tools: AgentTool[] - available tools
253
+ // state.streamingMessage?: AgentMessage - current partial assistant message
254
+ // state.errorMessage?: string - latest assistant error
255
+
256
+ // Replace messages (useful for branching or restoration)
257
+ session.agent.state.messages = messages; // copies the top-level array
258
+
259
+ // Replace tools
260
+ session.agent.state.tools = tools; // copies the top-level array
261
+
262
+ // Wait for agent to finish processing
263
+ await session.agent.waitForIdle();
264
+ ```
265
+
266
+ ### Events
267
+
268
+ Subscribe to events to receive streaming output and lifecycle notifications.
269
+
270
+ ```typescript
271
+ session.subscribe((event) => {
272
+ switch (event.type) {
273
+ // Streaming text from assistant
274
+ case "message_update":
275
+ if (event.assistantMessageEvent.type === "text_delta") {
276
+ process.stdout.write(event.assistantMessageEvent.delta);
277
+ }
278
+ if (event.assistantMessageEvent.type === "thinking_delta") {
279
+ // Thinking output (if thinking enabled)
280
+ }
281
+ break;
282
+
283
+ // Tool execution
284
+ case "tool_execution_start":
285
+ console.log(`Tool: ${event.toolName}`);
286
+ break;
287
+ case "tool_execution_update":
288
+ // Streaming tool output
289
+ break;
290
+ case "tool_execution_end":
291
+ console.log(`Result: ${event.isError ? "error" : "success"}`);
292
+ break;
293
+
294
+ // Message lifecycle
295
+ case "message_start":
296
+ // New message starting
297
+ break;
298
+ case "message_end":
299
+ // Message complete
300
+ break;
301
+
302
+ // Agent lifecycle
303
+ case "agent_start":
304
+ // Agent started processing prompt
305
+ break;
306
+ case "agent_end":
307
+ // Agent finished (event.messages contains new messages)
308
+ break;
309
+
310
+ // Turn lifecycle (one LLM response + tool calls)
311
+ case "turn_start":
312
+ break;
313
+ case "turn_end":
314
+ // event.message: assistant response
315
+ // event.toolResults: tool results from this turn
316
+ break;
317
+
318
+ // Session events (queue, compaction, retry)
319
+ case "queue_update":
320
+ console.log(event.steering, event.followUp);
321
+ break;
322
+ case "compaction_start":
323
+ case "compaction_end":
324
+ case "auto_retry_start":
325
+ case "auto_retry_end":
326
+ break;
327
+ }
328
+ });
329
+ ```
330
+
331
+ ## Options Reference
332
+
333
+ ### Directories
334
+
335
+ ```typescript
336
+ const { session } = await createAgentSession({
337
+ // Working directory for DefaultResourceLoader discovery
338
+ cwd: process.cwd(), // default
339
+
340
+ // Global config directory
341
+ agentDir: "~/.pi/agent", // default (expands ~)
342
+ });
343
+ ```
344
+
345
+ `cwd` is used by `DefaultResourceLoader` for:
346
+ - Project extensions (`.pi/extensions/`)
347
+ - Project skills:
348
+ - `.pi/skills/`
349
+ - `.agents/skills/` in `cwd` and ancestor directories (up to git repo root, or filesystem root when not in a repo)
350
+ - Project prompts (`.pi/prompts/`)
351
+ - Context files (`AGENTS.md` walking up from cwd)
352
+ - Session directory naming
353
+
354
+ `agentDir` is used by `DefaultResourceLoader` for:
355
+ - Global extensions (`extensions/`)
356
+ - Global skills:
357
+ - `skills/` under `agentDir` (for example `~/.pi/agent/skills/`)
358
+ - `~/.agents/skills/`
359
+ - Global prompts (`prompts/`)
360
+ - Global context file (`AGENTS.md`)
361
+ - Settings (`settings.json`)
362
+ - Custom models (`models.json`)
363
+ - Credentials (`auth.json`)
364
+ - Sessions (`sessions/`)
365
+
366
+ When you pass a custom `ResourceLoader`, `cwd` and `agentDir` no longer control resource discovery. They still influence session naming and tool path resolution.
367
+
368
+ ### Model
369
+
370
+ ```typescript
371
+ import { getModel } from "@earendil-works/pi-ai";
372
+ import { AuthStorage, ModelRegistry } from "@earendil-works/pi-coding-agent";
373
+
374
+ const authStorage = AuthStorage.create();
375
+ const modelRegistry = ModelRegistry.create(authStorage);
376
+
377
+ // Find specific built-in model (doesn't check if API key exists)
378
+ const opus = getModel("anthropic", "claude-opus-4-5");
379
+ if (!opus) throw new Error("Model not found");
380
+
381
+ // Find any model by provider/id, including custom models from models.json
382
+ // (doesn't check if API key exists)
383
+ const customModel = modelRegistry.find("my-provider", "my-model");
384
+
385
+ // Get only models that have valid API keys configured
386
+ const available = await modelRegistry.getAvailable();
387
+
388
+ const { session } = await createAgentSession({
389
+ model: opus,
390
+ thinkingLevel: "medium", // off, minimal, low, medium, high, xhigh
391
+
392
+ // Models for cycling (Ctrl+P in interactive mode)
393
+ scopedModels: [
394
+ { model: opus, thinkingLevel: "high" },
395
+ { model: haiku, thinkingLevel: "off" },
396
+ ],
397
+
398
+ authStorage,
399
+ modelRegistry,
400
+ });
401
+ ```
402
+
403
+ If no model is provided:
404
+ 1. Tries to restore from session (if continuing)
405
+ 2. Uses default from settings
406
+ 3. Falls back to first available model
407
+
408
+ > See [examples/sdk/02-custom-model.ts](../examples/sdk/02-custom-model.ts)
409
+
410
+ ### API Keys and OAuth
411
+
412
+ API key resolution priority (handled by AuthStorage):
413
+ 1. Runtime overrides (via `setRuntimeApiKey`, not persisted)
414
+ 2. Stored credentials in `auth.json` (API keys or OAuth tokens)
415
+ 3. Environment variables (`ANTHROPIC_API_KEY`, `OPENAI_API_KEY`, etc.)
416
+ 4. Fallback resolver (for custom provider keys from `models.json`)
417
+
418
+ ```typescript
419
+ import { AuthStorage, ModelRegistry } from "@earendil-works/pi-coding-agent";
420
+
421
+ // Default: uses ~/.pi/agent/auth.json and ~/.pi/agent/models.json
422
+ const authStorage = AuthStorage.create();
423
+ const modelRegistry = ModelRegistry.create(authStorage);
424
+
425
+ const { session } = await createAgentSession({
426
+ sessionManager: SessionManager.inMemory(),
427
+ authStorage,
428
+ modelRegistry,
429
+ });
430
+
431
+ // Runtime API key override (not persisted to disk)
432
+ authStorage.setRuntimeApiKey("anthropic", "sk-my-temp-key");
433
+
434
+ // Custom auth storage location
435
+ const customAuth = AuthStorage.create("/my/app/auth.json");
436
+ const customRegistry = ModelRegistry.create(customAuth, "/my/app/models.json");
437
+
438
+ const { session } = await createAgentSession({
439
+ sessionManager: SessionManager.inMemory(),
440
+ authStorage: customAuth,
441
+ modelRegistry: customRegistry,
442
+ });
443
+
444
+ // No custom models.json (built-in models only)
445
+ const simpleRegistry = ModelRegistry.inMemory(authStorage);
446
+ ```
447
+
448
+ > See [examples/sdk/09-api-keys-and-oauth.ts](../examples/sdk/09-api-keys-and-oauth.ts)
449
+
450
+ ### System Prompt
451
+
452
+ Use a `ResourceLoader` to override the system prompt:
453
+
454
+ ```typescript
455
+ import { createAgentSession, DefaultResourceLoader } from "@earendil-works/pi-coding-agent";
456
+
457
+ const loader = new DefaultResourceLoader({
458
+ systemPromptOverride: () => "You are a helpful assistant.",
459
+ });
460
+ await loader.reload();
461
+
462
+ const { session } = await createAgentSession({ resourceLoader: loader });
463
+ ```
464
+
465
+ > See [examples/sdk/03-custom-prompt.ts](../examples/sdk/03-custom-prompt.ts)
466
+
467
+ ### Tools
468
+
469
+ ```typescript
470
+ import {
471
+ codingTools, // read, bash, edit, write (default)
472
+ readOnlyTools, // read, grep, find, ls
473
+ readTool, bashTool, editTool, writeTool,
474
+ grepTool, findTool, lsTool,
475
+ } from "@earendil-works/pi-coding-agent";
476
+
477
+ // Use built-in tool set
478
+ const { session } = await createAgentSession({
479
+ tools: readOnlyTools,
480
+ });
481
+
482
+ // Pick specific tools
483
+ const { session } = await createAgentSession({
484
+ tools: [readTool, bashTool, grepTool],
485
+ });
486
+ ```
487
+
488
+ #### Tools with Custom cwd
489
+
490
+ **Important:** The pre-built tool instances (`readTool`, `bashTool`, etc.) use `process.cwd()` for path resolution. When you specify a custom `cwd` AND provide explicit `tools`, you must use the tool factory functions to ensure paths resolve correctly:
491
+
492
+ ```typescript
493
+ import {
494
+ createCodingTools, // Creates [read, bash, edit, write] for specific cwd
495
+ createReadOnlyTools, // Creates [read, grep, find, ls] for specific cwd
496
+ createReadTool,
497
+ createBashTool,
498
+ createEditTool,
499
+ createWriteTool,
500
+ createGrepTool,
501
+ createFindTool,
502
+ createLsTool,
503
+ } from "@earendil-works/pi-coding-agent";
504
+
505
+ const cwd = "/path/to/project";
506
+
507
+ // Use factory for tool sets
508
+ const { session } = await createAgentSession({
509
+ cwd,
510
+ tools: createCodingTools(cwd), // Tools resolve paths relative to cwd
511
+ });
512
+
513
+ // Or pick specific tools
514
+ const { session } = await createAgentSession({
515
+ cwd,
516
+ tools: [createReadTool(cwd), createBashTool(cwd), createGrepTool(cwd)],
517
+ });
518
+ ```
519
+
520
+ **When you don't need factories:**
521
+ - If you omit `tools`, pi automatically creates them with the correct `cwd`
522
+ - If you use `process.cwd()` as your `cwd`, the pre-built instances work fine
523
+
524
+ **When you must use factories:**
525
+ - When you specify both `cwd` (different from `process.cwd()`) AND `tools`
526
+
527
+ > See [examples/sdk/05-tools.ts](../examples/sdk/05-tools.ts)
528
+
529
+ ### Custom Tools
530
+
531
+ ```typescript
532
+ import { Type } from "typebox";
533
+ import { createAgentSession, defineTool } from "@earendil-works/pi-coding-agent";
534
+
535
+ // Inline custom tool
536
+ const myTool = defineTool({
537
+ name: "my_tool",
538
+ label: "My Tool",
539
+ description: "Does something useful",
540
+ parameters: Type.Object({
541
+ input: Type.String({ description: "Input value" }),
542
+ }),
543
+ execute: async (_toolCallId, params) => ({
544
+ content: [{ type: "text", text: `Result: ${params.input}` }],
545
+ details: {},
546
+ }),
547
+ });
548
+
549
+ // Pass custom tools directly
550
+ const { session } = await createAgentSession({
551
+ customTools: [myTool],
552
+ });
553
+ ```
554
+
555
+ Use `defineTool()` for standalone definitions and arrays like `customTools: [myTool]`. Inline `pi.registerTool({ ... })` already infers parameter types correctly.
556
+
557
+ Custom tools passed via `customTools` are combined with extension-registered tools. Extensions loaded by the ResourceLoader can also register tools via `pi.registerTool()`.
558
+
559
+ > See [examples/sdk/05-tools.ts](../examples/sdk/05-tools.ts)
560
+
561
+ ### Extensions
562
+
563
+ Extensions are loaded by the `ResourceLoader`. `DefaultResourceLoader` discovers extensions from `~/.pi/agent/extensions/`, `.pi/extensions/`, and settings.json extension sources.
564
+
565
+ ```typescript
566
+ import { createAgentSession, DefaultResourceLoader } from "@earendil-works/pi-coding-agent";
567
+
568
+ const loader = new DefaultResourceLoader({
569
+ additionalExtensionPaths: ["/path/to/my-extension.ts"],
570
+ extensionFactories: [
571
+ (pi) => {
572
+ pi.on("agent_start", () => {
573
+ console.log("[Inline Extension] Agent starting");
574
+ });
575
+ },
576
+ ],
577
+ });
578
+ await loader.reload();
579
+
580
+ const { session } = await createAgentSession({ resourceLoader: loader });
581
+ ```
582
+
583
+ Extensions can register tools, subscribe to events, add commands, and more. See [extensions.md](extensions.md) for the full API.
584
+
585
+ **Event Bus:** Extensions can communicate via `pi.events`. Pass a shared `eventBus` to `DefaultResourceLoader` if you need to emit or listen from outside:
586
+
587
+ ```typescript
588
+ import { createEventBus, DefaultResourceLoader } from "@earendil-works/pi-coding-agent";
589
+
590
+ const eventBus = createEventBus();
591
+ const loader = new DefaultResourceLoader({
592
+ eventBus,
593
+ });
594
+ await loader.reload();
595
+
596
+ eventBus.on("my-extension:status", (data) => console.log(data));
597
+ ```
598
+
599
+ > See [examples/sdk/06-extensions.ts](../examples/sdk/06-extensions.ts) and [docs/extensions.md](extensions.md)
600
+
601
+ ### Skills
602
+
603
+ ```typescript
604
+ import {
605
+ createAgentSession,
606
+ DefaultResourceLoader,
607
+ type Skill,
608
+ } from "@earendil-works/pi-coding-agent";
609
+
610
+ const customSkill: Skill = {
611
+ name: "my-skill",
612
+ description: "Custom instructions",
613
+ filePath: "/path/to/SKILL.md",
614
+ baseDir: "/path/to",
615
+ source: "custom",
616
+ };
617
+
618
+ const loader = new DefaultResourceLoader({
619
+ skillsOverride: (current) => ({
620
+ skills: [...current.skills, customSkill],
621
+ diagnostics: current.diagnostics,
622
+ }),
623
+ });
624
+ await loader.reload();
625
+
626
+ const { session } = await createAgentSession({ resourceLoader: loader });
627
+ ```
628
+
629
+ > See [examples/sdk/04-skills.ts](../examples/sdk/04-skills.ts)
630
+
631
+ ### Context Files
632
+
633
+ ```typescript
634
+ import { createAgentSession, DefaultResourceLoader } from "@earendil-works/pi-coding-agent";
635
+
636
+ const loader = new DefaultResourceLoader({
637
+ agentsFilesOverride: (current) => ({
638
+ agentsFiles: [
639
+ ...current.agentsFiles,
640
+ { path: "/virtual/AGENTS.md", content: "# Guidelines\n\n- Be concise" },
641
+ ],
642
+ }),
643
+ });
644
+ await loader.reload();
645
+
646
+ const { session } = await createAgentSession({ resourceLoader: loader });
647
+ ```
648
+
649
+ > See [examples/sdk/07-context-files.ts](../examples/sdk/07-context-files.ts)
650
+
651
+ ### Slash Commands
652
+
653
+ ```typescript
654
+ import {
655
+ createAgentSession,
656
+ DefaultResourceLoader,
657
+ type PromptTemplate,
658
+ } from "@earendil-works/pi-coding-agent";
659
+
660
+ const customCommand: PromptTemplate = {
661
+ name: "deploy",
662
+ description: "Deploy the application",
663
+ source: "(custom)",
664
+ content: "# Deploy\n\n1. Build\n2. Test\n3. Deploy",
665
+ };
666
+
667
+ const loader = new DefaultResourceLoader({
668
+ promptsOverride: (current) => ({
669
+ prompts: [...current.prompts, customCommand],
670
+ diagnostics: current.diagnostics,
671
+ }),
672
+ });
673
+ await loader.reload();
674
+
675
+ const { session } = await createAgentSession({ resourceLoader: loader });
676
+ ```
677
+
678
+ > See [examples/sdk/08-prompt-templates.ts](../examples/sdk/08-prompt-templates.ts)
679
+
680
+ ### Session Management
681
+
682
+ Sessions use a tree structure with `id`/`parentId` linking, enabling in-place branching.
683
+
684
+ ```typescript
685
+ import {
686
+ type CreateAgentSessionRuntimeFactory,
687
+ createAgentSession,
688
+ createAgentSessionFromServices,
689
+ createAgentSessionRuntime,
690
+ createAgentSessionServices,
691
+ getAgentDir,
692
+ SessionManager,
693
+ } from "@earendil-works/pi-coding-agent";
694
+
695
+ // In-memory (no persistence)
696
+ const { session } = await createAgentSession({
697
+ sessionManager: SessionManager.inMemory(),
698
+ });
699
+
700
+ // New persistent session
701
+ const { session: persisted } = await createAgentSession({
702
+ sessionManager: SessionManager.create(process.cwd()),
703
+ });
704
+
705
+ // Continue most recent
706
+ const { session: continued, modelFallbackMessage } = await createAgentSession({
707
+ sessionManager: SessionManager.continueRecent(process.cwd()),
708
+ });
709
+ if (modelFallbackMessage) {
710
+ console.log("Note:", modelFallbackMessage);
711
+ }
712
+
713
+ // Open specific file
714
+ const { session: opened } = await createAgentSession({
715
+ sessionManager: SessionManager.open("/path/to/session.jsonl"),
716
+ });
717
+
718
+ // List sessions
719
+ const currentProjectSessions = await SessionManager.list(process.cwd());
720
+ const allSessions = await SessionManager.listAll(process.cwd());
721
+
722
+ // Session replacement API for /new, /resume, /fork, /clone, and import flows.
723
+ const createRuntime: CreateAgentSessionRuntimeFactory = async ({ cwd, sessionManager, sessionStartEvent }) => {
724
+ const services = await createAgentSessionServices({ cwd });
725
+ return {
726
+ ...(await createAgentSessionFromServices({
727
+ services,
728
+ sessionManager,
729
+ sessionStartEvent,
730
+ })),
731
+ services,
732
+ diagnostics: services.diagnostics,
733
+ };
734
+ };
735
+
736
+ const runtime = await createAgentSessionRuntime(createRuntime, {
737
+ cwd: process.cwd(),
738
+ agentDir: getAgentDir(),
739
+ sessionManager: SessionManager.create(process.cwd()),
740
+ });
741
+
742
+ // Replace the active session with a fresh one
743
+ await runtime.newSession();
744
+
745
+ // Replace the active session with another saved session
746
+ await runtime.switchSession("/path/to/session.jsonl");
747
+
748
+ // Replace the active session with a fork from a specific user entry
749
+ await runtime.fork("entry-id");
750
+
751
+ // Clone the active path through a specific entry
752
+ await runtime.fork("entry-id", { position: "at" });
753
+ ```
754
+
755
+ **SessionManager tree API:**
756
+
757
+ ```typescript
758
+ const sm = SessionManager.open("/path/to/session.jsonl");
759
+
760
+ // Session listing
761
+ const currentProjectSessions = await SessionManager.list(process.cwd());
762
+ const allSessions = await SessionManager.listAll(process.cwd());
763
+
764
+ // Tree traversal
765
+ const entries = sm.getEntries(); // All entries (excludes header)
766
+ const tree = sm.getTree(); // Full tree structure
767
+ const path = sm.getPath(); // Path from root to current leaf
768
+ const leaf = sm.getLeafEntry(); // Current leaf entry
769
+ const entry = sm.getEntry(id); // Get entry by ID
770
+ const children = sm.getChildren(id); // Direct children of entry
771
+
772
+ // Labels
773
+ const label = sm.getLabel(id); // Get label for entry
774
+ sm.appendLabelChange(id, "checkpoint"); // Set label
775
+
776
+ // Branching
777
+ sm.branch(entryId); // Move leaf to earlier entry
778
+ sm.branchWithSummary(id, "Summary..."); // Branch with context summary
779
+ sm.createBranchedSession(leafId); // Extract path to new file
780
+ ```
781
+
782
+ > See [examples/sdk/11-sessions.ts](../examples/sdk/11-sessions.ts) and [Session Format](session-format.md)
783
+
784
+ ### Settings Management
785
+
786
+ ```typescript
787
+ import { createAgentSession, SettingsManager, SessionManager } from "@earendil-works/pi-coding-agent";
788
+
789
+ // Default: loads from files (global + project merged)
790
+ const { session } = await createAgentSession({
791
+ settingsManager: SettingsManager.create(),
792
+ });
793
+
794
+ // With overrides
795
+ const settingsManager = SettingsManager.create();
796
+ settingsManager.applyOverrides({
797
+ compaction: { enabled: false },
798
+ retry: { enabled: true, maxRetries: 5 },
799
+ });
800
+ const { session } = await createAgentSession({ settingsManager });
801
+
802
+ // In-memory (no file I/O, for testing)
803
+ const { session } = await createAgentSession({
804
+ settingsManager: SettingsManager.inMemory({ compaction: { enabled: false } }),
805
+ sessionManager: SessionManager.inMemory(),
806
+ });
807
+
808
+ // Custom directories
809
+ const { session } = await createAgentSession({
810
+ settingsManager: SettingsManager.create("/custom/cwd", "/custom/agent"),
811
+ });
812
+ ```
813
+
814
+ **Static factories:**
815
+ - `SettingsManager.create(cwd?, agentDir?)` - Load from files
816
+ - `SettingsManager.inMemory(settings?)` - No file I/O
817
+
818
+ **Project-specific settings:**
819
+
820
+ Settings load from two locations and merge:
821
+ 1. Global: `~/.pi/agent/settings.json`
822
+ 2. Project: `<cwd>/.pi/settings.json`
823
+
824
+ Project overrides global. Nested objects merge keys. Setters modify global settings by default.
825
+
826
+ **Persistence and error handling semantics:**
827
+
828
+ - Settings getters/setters are synchronous for in-memory state.
829
+ - Setters enqueue persistence writes asynchronously.
830
+ - Call `await settingsManager.flush()` when you need a durability boundary (for example, before process exit or before asserting file contents in tests).
831
+ - `SettingsManager` does not print settings I/O errors. Use `settingsManager.drainErrors()` and report them in your app layer.
832
+
833
+ > See [examples/sdk/10-settings.ts](../examples/sdk/10-settings.ts)
834
+
835
+ ## ResourceLoader
836
+
837
+ Use `DefaultResourceLoader` to discover extensions, skills, prompts, themes, and context files.
838
+
839
+ ```typescript
840
+ import {
841
+ DefaultResourceLoader,
842
+ getAgentDir,
843
+ } from "@earendil-works/pi-coding-agent";
844
+
845
+ const loader = new DefaultResourceLoader({
846
+ cwd,
847
+ agentDir: getAgentDir(),
848
+ });
849
+ await loader.reload();
850
+
851
+ const extensions = loader.getExtensions();
852
+ const skills = loader.getSkills();
853
+ const prompts = loader.getPrompts();
854
+ const themes = loader.getThemes();
855
+ const contextFiles = loader.getAgentsFiles().agentsFiles;
856
+ ```
857
+
858
+ ## Return Value
859
+
860
+ `createAgentSession()` returns:
861
+
862
+ ```typescript
863
+ interface CreateAgentSessionResult {
864
+ // The session
865
+ session: AgentSession;
866
+
867
+ // Extensions result (for runner setup)
868
+ extensionsResult: LoadExtensionsResult;
869
+
870
+ // Warning if session model couldn't be restored
871
+ modelFallbackMessage?: string;
872
+ }
873
+
874
+ interface LoadExtensionsResult {
875
+ extensions: Extension[];
876
+ errors: Array<{ path: string; error: string }>;
877
+ runtime: ExtensionRuntime;
878
+ }
879
+ ```
880
+
881
+ ## Complete Example
882
+
883
+ ```typescript
884
+ import { getModel } from "@earendil-works/pi-ai";
885
+ import { Type } from "typebox";
886
+ import {
887
+ AuthStorage,
888
+ bashTool,
889
+ createAgentSession,
890
+ DefaultResourceLoader,
891
+ defineTool,
892
+ ModelRegistry,
893
+ readTool,
894
+ SessionManager,
895
+ SettingsManager,
896
+ } from "@earendil-works/pi-coding-agent";
897
+
898
+ // Set up auth storage (custom location)
899
+ const authStorage = AuthStorage.create("/custom/agent/auth.json");
900
+
901
+ // Runtime API key override (not persisted)
902
+ if (process.env.MY_KEY) {
903
+ authStorage.setRuntimeApiKey("anthropic", process.env.MY_KEY);
904
+ }
905
+
906
+ // Model registry (no custom models.json)
907
+ const modelRegistry = ModelRegistry.create(authStorage);
908
+
909
+ // Inline tool
910
+ const statusTool = defineTool({
911
+ name: "status",
912
+ label: "Status",
913
+ description: "Get system status",
914
+ parameters: Type.Object({}),
915
+ execute: async () => ({
916
+ content: [{ type: "text", text: `Uptime: ${process.uptime()}s` }],
917
+ details: {},
918
+ }),
919
+ });
920
+
921
+ const model = getModel("anthropic", "claude-opus-4-5");
922
+ if (!model) throw new Error("Model not found");
923
+
924
+ // In-memory settings with overrides
925
+ const settingsManager = SettingsManager.inMemory({
926
+ compaction: { enabled: false },
927
+ retry: { enabled: true, maxRetries: 2 },
928
+ });
929
+
930
+ const loader = new DefaultResourceLoader({
931
+ cwd: process.cwd(),
932
+ agentDir: "/custom/agent",
933
+ settingsManager,
934
+ systemPromptOverride: () => "You are a minimal assistant. Be concise.",
935
+ });
936
+ await loader.reload();
937
+
938
+ const { session } = await createAgentSession({
939
+ cwd: process.cwd(),
940
+ agentDir: "/custom/agent",
941
+
942
+ model,
943
+ thinkingLevel: "off",
944
+ authStorage,
945
+ modelRegistry,
946
+
947
+ tools: [readTool, bashTool],
948
+ customTools: [statusTool],
949
+ resourceLoader: loader,
950
+
951
+ sessionManager: SessionManager.inMemory(),
952
+ settingsManager,
953
+ });
954
+
955
+ session.subscribe((event) => {
956
+ if (event.type === "message_update" && event.assistantMessageEvent.type === "text_delta") {
957
+ process.stdout.write(event.assistantMessageEvent.delta);
958
+ }
959
+ });
960
+
961
+ await session.prompt("Get status and list files.");
962
+ ```
963
+
964
+ ## Run Modes
965
+
966
+ The SDK exports run mode utilities for building custom interfaces on top of `createAgentSession()`:
967
+
968
+ ### InteractiveMode
969
+
970
+ Full TUI interactive mode with editor, chat history, and all built-in commands:
971
+
972
+ ```typescript
973
+ import {
974
+ type CreateAgentSessionRuntimeFactory,
975
+ createAgentSessionFromServices,
976
+ createAgentSessionRuntime,
977
+ createAgentSessionServices,
978
+ getAgentDir,
979
+ InteractiveMode,
980
+ SessionManager,
981
+ } from "@earendil-works/pi-coding-agent";
982
+
983
+ const createRuntime: CreateAgentSessionRuntimeFactory = async ({ cwd, sessionManager, sessionStartEvent }) => {
984
+ const services = await createAgentSessionServices({ cwd });
985
+ return {
986
+ ...(await createAgentSessionFromServices({ services, sessionManager, sessionStartEvent })),
987
+ services,
988
+ diagnostics: services.diagnostics,
989
+ };
990
+ };
991
+ const runtime = await createAgentSessionRuntime(createRuntime, {
992
+ cwd: process.cwd(),
993
+ agentDir: getAgentDir(),
994
+ sessionManager: SessionManager.create(process.cwd()),
995
+ });
996
+
997
+ const mode = new InteractiveMode(runtime, {
998
+ migratedProviders: [],
999
+ modelFallbackMessage: undefined,
1000
+ initialMessage: "Hello",
1001
+ initialImages: [],
1002
+ initialMessages: [],
1003
+ });
1004
+
1005
+ await mode.run();
1006
+ ```
1007
+
1008
+ ### runPrintMode
1009
+
1010
+ Single-shot mode: send prompts, output result, exit:
1011
+
1012
+ ```typescript
1013
+ import {
1014
+ type CreateAgentSessionRuntimeFactory,
1015
+ createAgentSessionFromServices,
1016
+ createAgentSessionRuntime,
1017
+ createAgentSessionServices,
1018
+ getAgentDir,
1019
+ runPrintMode,
1020
+ SessionManager,
1021
+ } from "@earendil-works/pi-coding-agent";
1022
+
1023
+ const createRuntime: CreateAgentSessionRuntimeFactory = async ({ cwd, sessionManager, sessionStartEvent }) => {
1024
+ const services = await createAgentSessionServices({ cwd });
1025
+ return {
1026
+ ...(await createAgentSessionFromServices({ services, sessionManager, sessionStartEvent })),
1027
+ services,
1028
+ diagnostics: services.diagnostics,
1029
+ };
1030
+ };
1031
+ const runtime = await createAgentSessionRuntime(createRuntime, {
1032
+ cwd: process.cwd(),
1033
+ agentDir: getAgentDir(),
1034
+ sessionManager: SessionManager.create(process.cwd()),
1035
+ });
1036
+
1037
+ await runPrintMode(runtime, {
1038
+ mode: "text",
1039
+ initialMessage: "Hello",
1040
+ initialImages: [],
1041
+ messages: ["Follow up"],
1042
+ });
1043
+ ```
1044
+
1045
+ ### runRpcMode
1046
+
1047
+ JSON-RPC mode for subprocess integration:
1048
+
1049
+ ```typescript
1050
+ import {
1051
+ type CreateAgentSessionRuntimeFactory,
1052
+ createAgentSessionFromServices,
1053
+ createAgentSessionRuntime,
1054
+ createAgentSessionServices,
1055
+ getAgentDir,
1056
+ runRpcMode,
1057
+ SessionManager,
1058
+ } from "@earendil-works/pi-coding-agent";
1059
+
1060
+ const createRuntime: CreateAgentSessionRuntimeFactory = async ({ cwd, sessionManager, sessionStartEvent }) => {
1061
+ const services = await createAgentSessionServices({ cwd });
1062
+ return {
1063
+ ...(await createAgentSessionFromServices({ services, sessionManager, sessionStartEvent })),
1064
+ services,
1065
+ diagnostics: services.diagnostics,
1066
+ };
1067
+ };
1068
+ const runtime = await createAgentSessionRuntime(createRuntime, {
1069
+ cwd: process.cwd(),
1070
+ agentDir: getAgentDir(),
1071
+ sessionManager: SessionManager.create(process.cwd()),
1072
+ });
1073
+
1074
+ await runRpcMode(runtime);
1075
+ ```
1076
+
1077
+ See [RPC documentation](rpc.md) for the JSON protocol.
1078
+
1079
+ ## RPC Mode Alternative
1080
+
1081
+ For subprocess-based integration without building with the SDK, use the CLI directly:
1082
+
1083
+ ```bash
1084
+ pi --mode rpc --no-session
1085
+ ```
1086
+
1087
+ See [RPC documentation](rpc.md) for the JSON protocol.
1088
+
1089
+ The SDK is preferred when:
1090
+ - You want type safety
1091
+ - You're in the same Node.js process
1092
+ - You need direct access to agent state
1093
+ - You want to customize tools/extensions programmatically
1094
+
1095
+ RPC mode is preferred when:
1096
+ - You're integrating from another language
1097
+ - You want process isolation
1098
+ - You're building a language-agnostic client
1099
+
1100
+ ## Exports
1101
+
1102
+ The main entry point exports:
1103
+
1104
+ ```typescript
1105
+ // Factory
1106
+ createAgentSession
1107
+ createAgentSessionRuntime
1108
+ AgentSessionRuntime
1109
+
1110
+ // Auth and Models
1111
+ AuthStorage
1112
+ ModelRegistry
1113
+
1114
+ // Resource loading
1115
+ DefaultResourceLoader
1116
+ type ResourceLoader
1117
+ createEventBus
1118
+
1119
+ // Helpers
1120
+ defineTool
1121
+
1122
+ // Session management
1123
+ SessionManager
1124
+ SettingsManager
1125
+
1126
+ // Built-in tools (use process.cwd())
1127
+ codingTools
1128
+ readOnlyTools
1129
+ readTool, bashTool, editTool, writeTool
1130
+ grepTool, findTool, lsTool
1131
+
1132
+ // Tool factories (for custom cwd)
1133
+ createCodingTools
1134
+ createReadOnlyTools
1135
+ createReadTool, createBashTool, createEditTool, createWriteTool
1136
+ createGrepTool, createFindTool, createLsTool
1137
+
1138
+ // Types
1139
+ type CreateAgentSessionOptions
1140
+ type CreateAgentSessionResult
1141
+ type ExtensionFactory
1142
+ type ExtensionAPI
1143
+ type ToolDefinition
1144
+ type Skill
1145
+ type PromptTemplate
1146
+ type Tool
1147
+ ```
1148
+
1149
+ For extension types, see [extensions.md](extensions.md) for the full API.