@averyyy/pi-coding-agent 0.80.3-piclient.3

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 (824) hide show
  1. package/CHANGELOG.md +4848 -0
  2. package/README.md +689 -0
  3. package/dist/bun/cli.d.ts +3 -0
  4. package/dist/bun/cli.d.ts.map +1 -0
  5. package/dist/bun/cli.js +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 +17 -0
  12. package/dist/bun/restore-sandbox-env.d.ts.map +1 -0
  13. package/dist/bun/restore-sandbox-env.js +36 -0
  14. package/dist/bun/restore-sandbox-env.js.map +1 -0
  15. package/dist/cli/args.d.ts +57 -0
  16. package/dist/cli/args.d.ts.map +1 -0
  17. package/dist/cli/args.js +379 -0
  18. package/dist/cli/args.js.map +1 -0
  19. package/dist/cli/config-selector.d.ts +14 -0
  20. package/dist/cli/config-selector.d.ts.map +1 -0
  21. package/dist/cli/config-selector.js +31 -0
  22. package/dist/cli/config-selector.js.map +1 -0
  23. package/dist/cli/file-processor.d.ts +15 -0
  24. package/dist/cli/file-processor.d.ts.map +1 -0
  25. package/dist/cli/file-processor.js +70 -0
  26. package/dist/cli/file-processor.js.map +1 -0
  27. package/dist/cli/initial-message.d.ts +18 -0
  28. package/dist/cli/initial-message.d.ts.map +1 -0
  29. package/dist/cli/initial-message.js +22 -0
  30. package/dist/cli/initial-message.js.map +1 -0
  31. package/dist/cli/list-models.d.ts +9 -0
  32. package/dist/cli/list-models.d.ts.map +1 -0
  33. package/dist/cli/list-models.js +98 -0
  34. package/dist/cli/list-models.js.map +1 -0
  35. package/dist/cli/project-trust.d.ts +10 -0
  36. package/dist/cli/project-trust.d.ts.map +1 -0
  37. package/dist/cli/project-trust.js +48 -0
  38. package/dist/cli/project-trust.js.map +1 -0
  39. package/dist/cli/session-picker.d.ts +10 -0
  40. package/dist/cli/session-picker.d.ts.map +1 -0
  41. package/dist/cli/session-picker.js +36 -0
  42. package/dist/cli/session-picker.js.map +1 -0
  43. package/dist/cli/startup-ui.d.ts +20 -0
  44. package/dist/cli/startup-ui.d.ts.map +1 -0
  45. package/dist/cli/startup-ui.js +184 -0
  46. package/dist/cli/startup-ui.js.map +1 -0
  47. package/dist/cli.d.ts +3 -0
  48. package/dist/cli.d.ts.map +1 -0
  49. package/dist/cli.js +18 -0
  50. package/dist/cli.js.map +1 -0
  51. package/dist/config.d.ts +96 -0
  52. package/dist/config.d.ts.map +1 -0
  53. package/dist/config.js +455 -0
  54. package/dist/config.js.map +1 -0
  55. package/dist/core/agent-session-runtime.d.ts +119 -0
  56. package/dist/core/agent-session-runtime.d.ts.map +1 -0
  57. package/dist/core/agent-session-runtime.js +307 -0
  58. package/dist/core/agent-session-runtime.js.map +1 -0
  59. package/dist/core/agent-session-services.d.ts +88 -0
  60. package/dist/core/agent-session-services.d.ts.map +1 -0
  61. package/dist/core/agent-session-services.js +119 -0
  62. package/dist/core/agent-session-services.js.map +1 -0
  63. package/dist/core/agent-session.d.ts +620 -0
  64. package/dist/core/agent-session.d.ts.map +1 -0
  65. package/dist/core/agent-session.js +2728 -0
  66. package/dist/core/agent-session.js.map +1 -0
  67. package/dist/core/auth-guidance.d.ts +5 -0
  68. package/dist/core/auth-guidance.d.ts.map +1 -0
  69. package/dist/core/auth-guidance.js +21 -0
  70. package/dist/core/auth-guidance.js.map +1 -0
  71. package/dist/core/auth-storage.d.ts +140 -0
  72. package/dist/core/auth-storage.d.ts.map +1 -0
  73. package/dist/core/auth-storage.js +434 -0
  74. package/dist/core/auth-storage.js.map +1 -0
  75. package/dist/core/bash-executor.d.ts +32 -0
  76. package/dist/core/bash-executor.d.ts.map +1 -0
  77. package/dist/core/bash-executor.js +111 -0
  78. package/dist/core/bash-executor.js.map +1 -0
  79. package/dist/core/compaction/branch-summarization.d.ts +92 -0
  80. package/dist/core/compaction/branch-summarization.d.ts.map +1 -0
  81. package/dist/core/compaction/branch-summarization.js +241 -0
  82. package/dist/core/compaction/branch-summarization.js.map +1 -0
  83. package/dist/core/compaction/compaction.d.ts +123 -0
  84. package/dist/core/compaction/compaction.d.ts.map +1 -0
  85. package/dist/core/compaction/compaction.js +682 -0
  86. package/dist/core/compaction/compaction.js.map +1 -0
  87. package/dist/core/compaction/index.d.ts +7 -0
  88. package/dist/core/compaction/index.d.ts.map +1 -0
  89. package/dist/core/compaction/index.js +7 -0
  90. package/dist/core/compaction/index.js.map +1 -0
  91. package/dist/core/compaction/utils.d.ts +38 -0
  92. package/dist/core/compaction/utils.d.ts.map +1 -0
  93. package/dist/core/compaction/utils.js +153 -0
  94. package/dist/core/compaction/utils.js.map +1 -0
  95. package/dist/core/defaults.d.ts +3 -0
  96. package/dist/core/defaults.d.ts.map +1 -0
  97. package/dist/core/defaults.js +2 -0
  98. package/dist/core/defaults.js.map +1 -0
  99. package/dist/core/diagnostics.d.ts +15 -0
  100. package/dist/core/diagnostics.d.ts.map +1 -0
  101. package/dist/core/diagnostics.js +2 -0
  102. package/dist/core/diagnostics.js.map +1 -0
  103. package/dist/core/event-bus.d.ts +9 -0
  104. package/dist/core/event-bus.d.ts.map +1 -0
  105. package/dist/core/event-bus.js +25 -0
  106. package/dist/core/event-bus.js.map +1 -0
  107. package/dist/core/exec.d.ts +29 -0
  108. package/dist/core/exec.d.ts.map +1 -0
  109. package/dist/core/exec.js +75 -0
  110. package/dist/core/exec.js.map +1 -0
  111. package/dist/core/experimental.d.ts +2 -0
  112. package/dist/core/experimental.d.ts.map +1 -0
  113. package/dist/core/experimental.js +4 -0
  114. package/dist/core/experimental.js.map +1 -0
  115. package/dist/core/export-html/ansi-to-html.d.ts +22 -0
  116. package/dist/core/export-html/ansi-to-html.d.ts.map +1 -0
  117. package/dist/core/export-html/ansi-to-html.js +249 -0
  118. package/dist/core/export-html/ansi-to-html.js.map +1 -0
  119. package/dist/core/export-html/index.d.ts +37 -0
  120. package/dist/core/export-html/index.d.ts.map +1 -0
  121. package/dist/core/export-html/index.js +226 -0
  122. package/dist/core/export-html/index.js.map +1 -0
  123. package/dist/core/export-html/template.css +1066 -0
  124. package/dist/core/export-html/template.html +55 -0
  125. package/dist/core/export-html/template.js +1864 -0
  126. package/dist/core/export-html/tool-renderer.d.ts +34 -0
  127. package/dist/core/export-html/tool-renderer.d.ts.map +1 -0
  128. package/dist/core/export-html/tool-renderer.js +108 -0
  129. package/dist/core/export-html/tool-renderer.js.map +1 -0
  130. package/dist/core/export-html/vendor/highlight.min.js +1213 -0
  131. package/dist/core/export-html/vendor/marked.min.js +78 -0
  132. package/dist/core/extensions/index.d.ts +12 -0
  133. package/dist/core/extensions/index.d.ts.map +1 -0
  134. package/dist/core/extensions/index.js +9 -0
  135. package/dist/core/extensions/index.js.map +1 -0
  136. package/dist/core/extensions/loader.d.ts +23 -0
  137. package/dist/core/extensions/loader.d.ts.map +1 -0
  138. package/dist/core/extensions/loader.js +535 -0
  139. package/dist/core/extensions/loader.js.map +1 -0
  140. package/dist/core/extensions/runner.d.ts +166 -0
  141. package/dist/core/extensions/runner.d.ts.map +1 -0
  142. package/dist/core/extensions/runner.js +876 -0
  143. package/dist/core/extensions/runner.js.map +1 -0
  144. package/dist/core/extensions/types.d.ts +1216 -0
  145. package/dist/core/extensions/types.d.ts.map +1 -0
  146. package/dist/core/extensions/types.js +45 -0
  147. package/dist/core/extensions/types.js.map +1 -0
  148. package/dist/core/extensions/wrapper.d.ts +20 -0
  149. package/dist/core/extensions/wrapper.d.ts.map +1 -0
  150. package/dist/core/extensions/wrapper.js +22 -0
  151. package/dist/core/extensions/wrapper.js.map +1 -0
  152. package/dist/core/footer-data-provider.d.ts +54 -0
  153. package/dist/core/footer-data-provider.d.ts.map +1 -0
  154. package/dist/core/footer-data-provider.js +338 -0
  155. package/dist/core/footer-data-provider.js.map +1 -0
  156. package/dist/core/http-dispatcher.d.ts +22 -0
  157. package/dist/core/http-dispatcher.d.ts.map +1 -0
  158. package/dist/core/http-dispatcher.js +91 -0
  159. package/dist/core/http-dispatcher.js.map +1 -0
  160. package/dist/core/index.d.ts +13 -0
  161. package/dist/core/index.d.ts.map +1 -0
  162. package/dist/core/index.js +13 -0
  163. package/dist/core/index.js.map +1 -0
  164. package/dist/core/keybindings.d.ts +353 -0
  165. package/dist/core/keybindings.d.ts.map +1 -0
  166. package/dist/core/keybindings.js +295 -0
  167. package/dist/core/keybindings.js.map +1 -0
  168. package/dist/core/messages.d.ts +77 -0
  169. package/dist/core/messages.d.ts.map +1 -0
  170. package/dist/core/messages.js +123 -0
  171. package/dist/core/messages.js.map +1 -0
  172. package/dist/core/model-registry.d.ts +151 -0
  173. package/dist/core/model-registry.d.ts.map +1 -0
  174. package/dist/core/model-registry.js +750 -0
  175. package/dist/core/model-registry.js.map +1 -0
  176. package/dist/core/model-resolver.d.ts +111 -0
  177. package/dist/core/model-resolver.d.ts.map +1 -0
  178. package/dist/core/model-resolver.js +534 -0
  179. package/dist/core/model-resolver.js.map +1 -0
  180. package/dist/core/output-guard.d.ts +7 -0
  181. package/dist/core/output-guard.d.ts.map +1 -0
  182. package/dist/core/output-guard.js +89 -0
  183. package/dist/core/output-guard.js.map +1 -0
  184. package/dist/core/package-manager.d.ts +207 -0
  185. package/dist/core/package-manager.d.ts.map +1 -0
  186. package/dist/core/package-manager.js +2088 -0
  187. package/dist/core/package-manager.js.map +1 -0
  188. package/dist/core/pi-server-client.d.ts +47 -0
  189. package/dist/core/pi-server-client.d.ts.map +1 -0
  190. package/dist/core/pi-server-client.js +571 -0
  191. package/dist/core/pi-server-client.js.map +1 -0
  192. package/dist/core/pi-server-request.d.ts +14 -0
  193. package/dist/core/pi-server-request.d.ts.map +1 -0
  194. package/dist/core/pi-server-request.js +204 -0
  195. package/dist/core/pi-server-request.js.map +1 -0
  196. package/dist/core/project-trust.d.ts +15 -0
  197. package/dist/core/project-trust.d.ts.map +1 -0
  198. package/dist/core/project-trust.js +59 -0
  199. package/dist/core/project-trust.js.map +1 -0
  200. package/dist/core/prompt-templates.d.ts +53 -0
  201. package/dist/core/prompt-templates.d.ts.map +1 -0
  202. package/dist/core/prompt-templates.js +236 -0
  203. package/dist/core/prompt-templates.js.map +1 -0
  204. package/dist/core/provider-attribution.d.ts +4 -0
  205. package/dist/core/provider-attribution.d.ts.map +1 -0
  206. package/dist/core/provider-attribution.js +82 -0
  207. package/dist/core/provider-attribution.js.map +1 -0
  208. package/dist/core/provider-display-names.d.ts +2 -0
  209. package/dist/core/provider-display-names.d.ts.map +1 -0
  210. package/dist/core/provider-display-names.js +36 -0
  211. package/dist/core/provider-display-names.js.map +1 -0
  212. package/dist/core/resolve-config-value.d.ts +30 -0
  213. package/dist/core/resolve-config-value.d.ts.map +1 -0
  214. package/dist/core/resolve-config-value.js +247 -0
  215. package/dist/core/resolve-config-value.js.map +1 -0
  216. package/dist/core/resource-loader.d.ts +206 -0
  217. package/dist/core/resource-loader.d.ts.map +1 -0
  218. package/dist/core/resource-loader.js +817 -0
  219. package/dist/core/resource-loader.js.map +1 -0
  220. package/dist/core/sdk.d.ts +109 -0
  221. package/dist/core/sdk.d.ts.map +1 -0
  222. package/dist/core/sdk.js +313 -0
  223. package/dist/core/sdk.js.map +1 -0
  224. package/dist/core/session-cwd.d.ts +19 -0
  225. package/dist/core/session-cwd.d.ts.map +1 -0
  226. package/dist/core/session-cwd.js +38 -0
  227. package/dist/core/session-cwd.js.map +1 -0
  228. package/dist/core/session-manager.d.ts +334 -0
  229. package/dist/core/session-manager.d.ts.map +1 -0
  230. package/dist/core/session-manager.js +1284 -0
  231. package/dist/core/session-manager.js.map +1 -0
  232. package/dist/core/settings-manager.d.ts +291 -0
  233. package/dist/core/settings-manager.d.ts.map +1 -0
  234. package/dist/core/settings-manager.js +893 -0
  235. package/dist/core/settings-manager.js.map +1 -0
  236. package/dist/core/skills.d.ts +60 -0
  237. package/dist/core/skills.d.ts.map +1 -0
  238. package/dist/core/skills.js +387 -0
  239. package/dist/core/skills.js.map +1 -0
  240. package/dist/core/slash-commands.d.ts +14 -0
  241. package/dist/core/slash-commands.d.ts.map +1 -0
  242. package/dist/core/slash-commands.js +26 -0
  243. package/dist/core/slash-commands.js.map +1 -0
  244. package/dist/core/source-info.d.ts +18 -0
  245. package/dist/core/source-info.d.ts.map +1 -0
  246. package/dist/core/source-info.js +19 -0
  247. package/dist/core/source-info.js.map +1 -0
  248. package/dist/core/system-prompt.d.ts +28 -0
  249. package/dist/core/system-prompt.d.ts.map +1 -0
  250. package/dist/core/system-prompt.js +120 -0
  251. package/dist/core/system-prompt.js.map +1 -0
  252. package/dist/core/telemetry.d.ts +3 -0
  253. package/dist/core/telemetry.d.ts.map +1 -0
  254. package/dist/core/telemetry.js +9 -0
  255. package/dist/core/telemetry.js.map +1 -0
  256. package/dist/core/timings.d.ts +10 -0
  257. package/dist/core/timings.d.ts.map +1 -0
  258. package/dist/core/timings.js +41 -0
  259. package/dist/core/timings.js.map +1 -0
  260. package/dist/core/tools/bash.d.ts +68 -0
  261. package/dist/core/tools/bash.d.ts.map +1 -0
  262. package/dist/core/tools/bash.js +361 -0
  263. package/dist/core/tools/bash.js.map +1 -0
  264. package/dist/core/tools/edit-diff.d.ts +106 -0
  265. package/dist/core/tools/edit-diff.d.ts.map +1 -0
  266. package/dist/core/tools/edit-diff.js +424 -0
  267. package/dist/core/tools/edit-diff.js.map +1 -0
  268. package/dist/core/tools/edit.d.ts +51 -0
  269. package/dist/core/tools/edit.d.ts.map +1 -0
  270. package/dist/core/tools/edit.js +284 -0
  271. package/dist/core/tools/edit.js.map +1 -0
  272. package/dist/core/tools/file-mutation-queue.d.ts +6 -0
  273. package/dist/core/tools/file-mutation-queue.d.ts.map +1 -0
  274. package/dist/core/tools/file-mutation-queue.js +52 -0
  275. package/dist/core/tools/file-mutation-queue.js.map +1 -0
  276. package/dist/core/tools/find.d.ts +35 -0
  277. package/dist/core/tools/find.d.ts.map +1 -0
  278. package/dist/core/tools/find.js +305 -0
  279. package/dist/core/tools/find.js.map +1 -0
  280. package/dist/core/tools/grep.d.ts +37 -0
  281. package/dist/core/tools/grep.d.ts.map +1 -0
  282. package/dist/core/tools/grep.js +304 -0
  283. package/dist/core/tools/grep.js.map +1 -0
  284. package/dist/core/tools/index.d.ts +40 -0
  285. package/dist/core/tools/index.d.ts.map +1 -0
  286. package/dist/core/tools/index.js +112 -0
  287. package/dist/core/tools/index.js.map +1 -0
  288. package/dist/core/tools/ls.d.ts +37 -0
  289. package/dist/core/tools/ls.d.ts.map +1 -0
  290. package/dist/core/tools/ls.js +167 -0
  291. package/dist/core/tools/ls.js.map +1 -0
  292. package/dist/core/tools/output-accumulator.d.ts +52 -0
  293. package/dist/core/tools/output-accumulator.d.ts.map +1 -0
  294. package/dist/core/tools/output-accumulator.js +184 -0
  295. package/dist/core/tools/output-accumulator.js.map +1 -0
  296. package/dist/core/tools/path-utils.d.ts +10 -0
  297. package/dist/core/tools/path-utils.d.ts.map +1 -0
  298. package/dist/core/tools/path-utils.js +99 -0
  299. package/dist/core/tools/path-utils.js.map +1 -0
  300. package/dist/core/tools/read.d.ts +35 -0
  301. package/dist/core/tools/read.d.ts.map +1 -0
  302. package/dist/core/tools/read.js +276 -0
  303. package/dist/core/tools/read.js.map +1 -0
  304. package/dist/core/tools/render-utils.d.ts +24 -0
  305. package/dist/core/tools/render-utils.d.ts.map +1 -0
  306. package/dist/core/tools/render-utils.js +65 -0
  307. package/dist/core/tools/render-utils.js.map +1 -0
  308. package/dist/core/tools/tool-definition-wrapper.d.ts +14 -0
  309. package/dist/core/tools/tool-definition-wrapper.d.ts.map +1 -0
  310. package/dist/core/tools/tool-definition-wrapper.js +34 -0
  311. package/dist/core/tools/tool-definition-wrapper.js.map +1 -0
  312. package/dist/core/tools/truncate.d.ts +70 -0
  313. package/dist/core/tools/truncate.d.ts.map +1 -0
  314. package/dist/core/tools/truncate.js +215 -0
  315. package/dist/core/tools/truncate.js.map +1 -0
  316. package/dist/core/tools/write.d.ts +26 -0
  317. package/dist/core/tools/write.d.ts.map +1 -0
  318. package/dist/core/tools/write.js +197 -0
  319. package/dist/core/tools/write.js.map +1 -0
  320. package/dist/core/trust-manager.d.ts +36 -0
  321. package/dist/core/trust-manager.d.ts.map +1 -0
  322. package/dist/core/trust-manager.js +202 -0
  323. package/dist/core/trust-manager.js.map +1 -0
  324. package/dist/index.d.ts +33 -0
  325. package/dist/index.d.ts.map +1 -0
  326. package/dist/index.js +46 -0
  327. package/dist/index.js.map +1 -0
  328. package/dist/main.d.ts +12 -0
  329. package/dist/main.d.ts.map +1 -0
  330. package/dist/main.js +699 -0
  331. package/dist/main.js.map +1 -0
  332. package/dist/migrations.d.ts +33 -0
  333. package/dist/migrations.d.ts.map +1 -0
  334. package/dist/migrations.js +281 -0
  335. package/dist/migrations.js.map +1 -0
  336. package/dist/modes/index.d.ts +9 -0
  337. package/dist/modes/index.d.ts.map +1 -0
  338. package/dist/modes/index.js +8 -0
  339. package/dist/modes/index.js.map +1 -0
  340. package/dist/modes/interactive/assets/clankolas.png +0 -0
  341. package/dist/modes/interactive/components/armin.d.ts +34 -0
  342. package/dist/modes/interactive/components/armin.d.ts.map +1 -0
  343. package/dist/modes/interactive/components/armin.js +333 -0
  344. package/dist/modes/interactive/components/armin.js.map +1 -0
  345. package/dist/modes/interactive/components/assistant-message.d.ts +22 -0
  346. package/dist/modes/interactive/components/assistant-message.d.ts.map +1 -0
  347. package/dist/modes/interactive/components/assistant-message.js +129 -0
  348. package/dist/modes/interactive/components/assistant-message.js.map +1 -0
  349. package/dist/modes/interactive/components/bash-execution.d.ts +34 -0
  350. package/dist/modes/interactive/components/bash-execution.d.ts.map +1 -0
  351. package/dist/modes/interactive/components/bash-execution.js +175 -0
  352. package/dist/modes/interactive/components/bash-execution.js.map +1 -0
  353. package/dist/modes/interactive/components/bordered-loader.d.ts +16 -0
  354. package/dist/modes/interactive/components/bordered-loader.d.ts.map +1 -0
  355. package/dist/modes/interactive/components/bordered-loader.js +54 -0
  356. package/dist/modes/interactive/components/bordered-loader.js.map +1 -0
  357. package/dist/modes/interactive/components/branch-summary-message.d.ts +16 -0
  358. package/dist/modes/interactive/components/branch-summary-message.d.ts.map +1 -0
  359. package/dist/modes/interactive/components/branch-summary-message.js +44 -0
  360. package/dist/modes/interactive/components/branch-summary-message.js.map +1 -0
  361. package/dist/modes/interactive/components/compaction-summary-message.d.ts +16 -0
  362. package/dist/modes/interactive/components/compaction-summary-message.d.ts.map +1 -0
  363. package/dist/modes/interactive/components/compaction-summary-message.js +45 -0
  364. package/dist/modes/interactive/components/compaction-summary-message.js.map +1 -0
  365. package/dist/modes/interactive/components/config-selector.d.ts +71 -0
  366. package/dist/modes/interactive/components/config-selector.d.ts.map +1 -0
  367. package/dist/modes/interactive/components/config-selector.js +506 -0
  368. package/dist/modes/interactive/components/config-selector.js.map +1 -0
  369. package/dist/modes/interactive/components/countdown-timer.d.ts +14 -0
  370. package/dist/modes/interactive/components/countdown-timer.d.ts.map +1 -0
  371. package/dist/modes/interactive/components/countdown-timer.js +33 -0
  372. package/dist/modes/interactive/components/countdown-timer.js.map +1 -0
  373. package/dist/modes/interactive/components/custom-editor.d.ts +21 -0
  374. package/dist/modes/interactive/components/custom-editor.d.ts.map +1 -0
  375. package/dist/modes/interactive/components/custom-editor.js +70 -0
  376. package/dist/modes/interactive/components/custom-editor.js.map +1 -0
  377. package/dist/modes/interactive/components/custom-message.d.ts +20 -0
  378. package/dist/modes/interactive/components/custom-message.d.ts.map +1 -0
  379. package/dist/modes/interactive/components/custom-message.js +79 -0
  380. package/dist/modes/interactive/components/custom-message.js.map +1 -0
  381. package/dist/modes/interactive/components/daxnuts.d.ts +23 -0
  382. package/dist/modes/interactive/components/daxnuts.d.ts.map +1 -0
  383. package/dist/modes/interactive/components/daxnuts.js +140 -0
  384. package/dist/modes/interactive/components/daxnuts.js.map +1 -0
  385. package/dist/modes/interactive/components/diff.d.ts +12 -0
  386. package/dist/modes/interactive/components/diff.d.ts.map +1 -0
  387. package/dist/modes/interactive/components/diff.js +133 -0
  388. package/dist/modes/interactive/components/diff.js.map +1 -0
  389. package/dist/modes/interactive/components/dynamic-border.d.ts +15 -0
  390. package/dist/modes/interactive/components/dynamic-border.d.ts.map +1 -0
  391. package/dist/modes/interactive/components/dynamic-border.js +21 -0
  392. package/dist/modes/interactive/components/dynamic-border.js.map +1 -0
  393. package/dist/modes/interactive/components/earendil-announcement.d.ts +5 -0
  394. package/dist/modes/interactive/components/earendil-announcement.d.ts.map +1 -0
  395. package/dist/modes/interactive/components/earendil-announcement.js +40 -0
  396. package/dist/modes/interactive/components/earendil-announcement.js.map +1 -0
  397. package/dist/modes/interactive/components/extension-editor.d.ts +22 -0
  398. package/dist/modes/interactive/components/extension-editor.d.ts.map +1 -0
  399. package/dist/modes/interactive/components/extension-editor.js +128 -0
  400. package/dist/modes/interactive/components/extension-editor.js.map +1 -0
  401. package/dist/modes/interactive/components/extension-input.d.ts +23 -0
  402. package/dist/modes/interactive/components/extension-input.d.ts.map +1 -0
  403. package/dist/modes/interactive/components/extension-input.js +61 -0
  404. package/dist/modes/interactive/components/extension-input.js.map +1 -0
  405. package/dist/modes/interactive/components/extension-selector.d.ts +26 -0
  406. package/dist/modes/interactive/components/extension-selector.d.ts.map +1 -0
  407. package/dist/modes/interactive/components/extension-selector.js +83 -0
  408. package/dist/modes/interactive/components/extension-selector.js.map +1 -0
  409. package/dist/modes/interactive/components/first-time-setup.d.ts +25 -0
  410. package/dist/modes/interactive/components/first-time-setup.d.ts.map +1 -0
  411. package/dist/modes/interactive/components/first-time-setup.js +103 -0
  412. package/dist/modes/interactive/components/first-time-setup.js.map +1 -0
  413. package/dist/modes/interactive/components/footer.d.ts +28 -0
  414. package/dist/modes/interactive/components/footer.d.ts.map +1 -0
  415. package/dist/modes/interactive/components/footer.js +221 -0
  416. package/dist/modes/interactive/components/footer.js.map +1 -0
  417. package/dist/modes/interactive/components/index.d.ts +34 -0
  418. package/dist/modes/interactive/components/index.d.ts.map +1 -0
  419. package/dist/modes/interactive/components/index.js +35 -0
  420. package/dist/modes/interactive/components/index.js.map +1 -0
  421. package/dist/modes/interactive/components/keybinding-hints.d.ts +13 -0
  422. package/dist/modes/interactive/components/keybinding-hints.d.ts.map +1 -0
  423. package/dist/modes/interactive/components/keybinding-hints.js +36 -0
  424. package/dist/modes/interactive/components/keybinding-hints.js.map +1 -0
  425. package/dist/modes/interactive/components/login-dialog.d.ts +52 -0
  426. package/dist/modes/interactive/components/login-dialog.d.ts.map +1 -0
  427. package/dist/modes/interactive/components/login-dialog.js +179 -0
  428. package/dist/modes/interactive/components/login-dialog.js.map +1 -0
  429. package/dist/modes/interactive/components/model-selector.d.ts +47 -0
  430. package/dist/modes/interactive/components/model-selector.d.ts.map +1 -0
  431. package/dist/modes/interactive/components/model-selector.js +279 -0
  432. package/dist/modes/interactive/components/model-selector.js.map +1 -0
  433. package/dist/modes/interactive/components/oauth-selector.d.ts +31 -0
  434. package/dist/modes/interactive/components/oauth-selector.d.ts.map +1 -0
  435. package/dist/modes/interactive/components/oauth-selector.js +165 -0
  436. package/dist/modes/interactive/components/oauth-selector.js.map +1 -0
  437. package/dist/modes/interactive/components/scoped-models-selector.d.ts +42 -0
  438. package/dist/modes/interactive/components/scoped-models-selector.d.ts.map +1 -0
  439. package/dist/modes/interactive/components/scoped-models-selector.js +293 -0
  440. package/dist/modes/interactive/components/scoped-models-selector.js.map +1 -0
  441. package/dist/modes/interactive/components/session-selector-search.d.ts +23 -0
  442. package/dist/modes/interactive/components/session-selector-search.d.ts.map +1 -0
  443. package/dist/modes/interactive/components/session-selector-search.js +155 -0
  444. package/dist/modes/interactive/components/session-selector-search.js.map +1 -0
  445. package/dist/modes/interactive/components/session-selector.d.ts +95 -0
  446. package/dist/modes/interactive/components/session-selector.d.ts.map +1 -0
  447. package/dist/modes/interactive/components/session-selector.js +867 -0
  448. package/dist/modes/interactive/components/session-selector.js.map +1 -0
  449. package/dist/modes/interactive/components/settings-selector.d.ts +75 -0
  450. package/dist/modes/interactive/components/settings-selector.d.ts.map +1 -0
  451. package/dist/modes/interactive/components/settings-selector.js +582 -0
  452. package/dist/modes/interactive/components/settings-selector.js.map +1 -0
  453. package/dist/modes/interactive/components/show-images-selector.d.ts +10 -0
  454. package/dist/modes/interactive/components/show-images-selector.d.ts.map +1 -0
  455. package/dist/modes/interactive/components/show-images-selector.js +39 -0
  456. package/dist/modes/interactive/components/show-images-selector.js.map +1 -0
  457. package/dist/modes/interactive/components/skill-invocation-message.d.ts +17 -0
  458. package/dist/modes/interactive/components/skill-invocation-message.d.ts.map +1 -0
  459. package/dist/modes/interactive/components/skill-invocation-message.js +47 -0
  460. package/dist/modes/interactive/components/skill-invocation-message.js.map +1 -0
  461. package/dist/modes/interactive/components/status-indicator.d.ts +28 -0
  462. package/dist/modes/interactive/components/status-indicator.d.ts.map +1 -0
  463. package/dist/modes/interactive/components/status-indicator.js +60 -0
  464. package/dist/modes/interactive/components/status-indicator.js.map +1 -0
  465. package/dist/modes/interactive/components/theme-selector.d.ts +11 -0
  466. package/dist/modes/interactive/components/theme-selector.d.ts.map +1 -0
  467. package/dist/modes/interactive/components/theme-selector.js +50 -0
  468. package/dist/modes/interactive/components/theme-selector.js.map +1 -0
  469. package/dist/modes/interactive/components/thinking-selector.d.ts +11 -0
  470. package/dist/modes/interactive/components/thinking-selector.d.ts.map +1 -0
  471. package/dist/modes/interactive/components/thinking-selector.js +51 -0
  472. package/dist/modes/interactive/components/thinking-selector.js.map +1 -0
  473. package/dist/modes/interactive/components/tool-execution.d.ts +63 -0
  474. package/dist/modes/interactive/components/tool-execution.d.ts.map +1 -0
  475. package/dist/modes/interactive/components/tool-execution.js +317 -0
  476. package/dist/modes/interactive/components/tool-execution.js.map +1 -0
  477. package/dist/modes/interactive/components/tree-selector.d.ts +89 -0
  478. package/dist/modes/interactive/components/tree-selector.d.ts.map +1 -0
  479. package/dist/modes/interactive/components/tree-selector.js +1208 -0
  480. package/dist/modes/interactive/components/tree-selector.js.map +1 -0
  481. package/dist/modes/interactive/components/trust-selector.d.ts +23 -0
  482. package/dist/modes/interactive/components/trust-selector.d.ts.map +1 -0
  483. package/dist/modes/interactive/components/trust-selector.js +91 -0
  484. package/dist/modes/interactive/components/trust-selector.js.map +1 -0
  485. package/dist/modes/interactive/components/user-message-selector.d.ts +30 -0
  486. package/dist/modes/interactive/components/user-message-selector.d.ts.map +1 -0
  487. package/dist/modes/interactive/components/user-message-selector.js +114 -0
  488. package/dist/modes/interactive/components/user-message-selector.js.map +1 -0
  489. package/dist/modes/interactive/components/user-message.d.ts +14 -0
  490. package/dist/modes/interactive/components/user-message.d.ts.map +1 -0
  491. package/dist/modes/interactive/components/user-message.js +42 -0
  492. package/dist/modes/interactive/components/user-message.js.map +1 -0
  493. package/dist/modes/interactive/components/visual-truncate.d.ts +24 -0
  494. package/dist/modes/interactive/components/visual-truncate.d.ts.map +1 -0
  495. package/dist/modes/interactive/components/visual-truncate.js +33 -0
  496. package/dist/modes/interactive/components/visual-truncate.js.map +1 -0
  497. package/dist/modes/interactive/interactive-mode.d.ts +380 -0
  498. package/dist/modes/interactive/interactive-mode.d.ts.map +1 -0
  499. package/dist/modes/interactive/interactive-mode.js +4782 -0
  500. package/dist/modes/interactive/interactive-mode.js.map +1 -0
  501. package/dist/modes/interactive/model-search.d.ts +12 -0
  502. package/dist/modes/interactive/model-search.d.ts.map +1 -0
  503. package/dist/modes/interactive/model-search.js +15 -0
  504. package/dist/modes/interactive/model-search.js.map +1 -0
  505. package/dist/modes/interactive/theme/dark.json +86 -0
  506. package/dist/modes/interactive/theme/light.json +85 -0
  507. package/dist/modes/interactive/theme/theme-controller.d.ts +29 -0
  508. package/dist/modes/interactive/theme/theme-controller.d.ts.map +1 -0
  509. package/dist/modes/interactive/theme/theme-controller.js +102 -0
  510. package/dist/modes/interactive/theme/theme-controller.js.map +1 -0
  511. package/dist/modes/interactive/theme/theme-schema.json +336 -0
  512. package/dist/modes/interactive/theme/theme.d.ts +119 -0
  513. package/dist/modes/interactive/theme/theme.d.ts.map +1 -0
  514. package/dist/modes/interactive/theme/theme.js +1056 -0
  515. package/dist/modes/interactive/theme/theme.js.map +1 -0
  516. package/dist/modes/print-mode.d.ts +28 -0
  517. package/dist/modes/print-mode.d.ts.map +1 -0
  518. package/dist/modes/print-mode.js +132 -0
  519. package/dist/modes/print-mode.js.map +1 -0
  520. package/dist/modes/rpc/jsonl.d.ts +17 -0
  521. package/dist/modes/rpc/jsonl.d.ts.map +1 -0
  522. package/dist/modes/rpc/jsonl.js +49 -0
  523. package/dist/modes/rpc/jsonl.js.map +1 -0
  524. package/dist/modes/rpc/rpc-client.d.ts +242 -0
  525. package/dist/modes/rpc/rpc-client.d.ts.map +1 -0
  526. package/dist/modes/rpc/rpc-client.js +481 -0
  527. package/dist/modes/rpc/rpc-client.js.map +1 -0
  528. package/dist/modes/rpc/rpc-mode.d.ts +20 -0
  529. package/dist/modes/rpc/rpc-mode.d.ts.map +1 -0
  530. package/dist/modes/rpc/rpc-mode.js +632 -0
  531. package/dist/modes/rpc/rpc-mode.js.map +1 -0
  532. package/dist/modes/rpc/rpc-types.d.ts +446 -0
  533. package/dist/modes/rpc/rpc-types.d.ts.map +1 -0
  534. package/dist/modes/rpc/rpc-types.js +8 -0
  535. package/dist/modes/rpc/rpc-types.js.map +1 -0
  536. package/dist/package-manager-cli.d.ts +8 -0
  537. package/dist/package-manager-cli.d.ts.map +1 -0
  538. package/dist/package-manager-cli.js +659 -0
  539. package/dist/package-manager-cli.js.map +1 -0
  540. package/dist/pi-client-cli.d.ts +3 -0
  541. package/dist/pi-client-cli.d.ts.map +1 -0
  542. package/dist/pi-client-cli.js +10 -0
  543. package/dist/pi-client-cli.js.map +1 -0
  544. package/dist/rpc-entry.d.ts +3 -0
  545. package/dist/rpc-entry.d.ts.map +1 -0
  546. package/dist/rpc-entry.js +10 -0
  547. package/dist/rpc-entry.js.map +1 -0
  548. package/dist/utils/ansi.d.ts +2 -0
  549. package/dist/utils/ansi.d.ts.map +1 -0
  550. package/dist/utils/ansi.js +52 -0
  551. package/dist/utils/ansi.js.map +1 -0
  552. package/dist/utils/changelog.d.ts +22 -0
  553. package/dist/utils/changelog.d.ts.map +1 -0
  554. package/dist/utils/changelog.js +165 -0
  555. package/dist/utils/changelog.js.map +1 -0
  556. package/dist/utils/child-process.d.ts +18 -0
  557. package/dist/utils/child-process.d.ts.map +1 -0
  558. package/dist/utils/child-process.js +106 -0
  559. package/dist/utils/child-process.js.map +1 -0
  560. package/dist/utils/clipboard-image.d.ts +11 -0
  561. package/dist/utils/clipboard-image.d.ts.map +1 -0
  562. package/dist/utils/clipboard-image.js +245 -0
  563. package/dist/utils/clipboard-image.js.map +1 -0
  564. package/dist/utils/clipboard-native.d.ts +10 -0
  565. package/dist/utils/clipboard-native.d.ts.map +1 -0
  566. package/dist/utils/clipboard-native.js +20 -0
  567. package/dist/utils/clipboard-native.js.map +1 -0
  568. package/dist/utils/clipboard.d.ts +2 -0
  569. package/dist/utils/clipboard.d.ts.map +1 -0
  570. package/dist/utils/clipboard.js +117 -0
  571. package/dist/utils/clipboard.js.map +1 -0
  572. package/dist/utils/deprecation.d.ts +4 -0
  573. package/dist/utils/deprecation.d.ts.map +1 -0
  574. package/dist/utils/deprecation.js +13 -0
  575. package/dist/utils/deprecation.js.map +1 -0
  576. package/dist/utils/exif-orientation.d.ts +5 -0
  577. package/dist/utils/exif-orientation.d.ts.map +1 -0
  578. package/dist/utils/exif-orientation.js +158 -0
  579. package/dist/utils/exif-orientation.js.map +1 -0
  580. package/dist/utils/frontmatter.d.ts +8 -0
  581. package/dist/utils/frontmatter.d.ts.map +1 -0
  582. package/dist/utils/frontmatter.js +26 -0
  583. package/dist/utils/frontmatter.js.map +1 -0
  584. package/dist/utils/fs-watch.d.ts +5 -0
  585. package/dist/utils/fs-watch.d.ts.map +1 -0
  586. package/dist/utils/fs-watch.js +25 -0
  587. package/dist/utils/fs-watch.js.map +1 -0
  588. package/dist/utils/git.d.ts +26 -0
  589. package/dist/utils/git.d.ts.map +1 -0
  590. package/dist/utils/git.js +195 -0
  591. package/dist/utils/git.js.map +1 -0
  592. package/dist/utils/html.d.ts +7 -0
  593. package/dist/utils/html.d.ts.map +1 -0
  594. package/dist/utils/html.js +40 -0
  595. package/dist/utils/html.js.map +1 -0
  596. package/dist/utils/image-convert.d.ts +10 -0
  597. package/dist/utils/image-convert.d.ts.map +1 -0
  598. package/dist/utils/image-convert.js +45 -0
  599. package/dist/utils/image-convert.js.map +1 -0
  600. package/dist/utils/image-process.d.ts +18 -0
  601. package/dist/utils/image-process.d.ts.map +1 -0
  602. package/dist/utils/image-process.js +83 -0
  603. package/dist/utils/image-process.js.map +1 -0
  604. package/dist/utils/image-resize-core.d.ts +30 -0
  605. package/dist/utils/image-resize-core.d.ts.map +1 -0
  606. package/dist/utils/image-resize-core.js +124 -0
  607. package/dist/utils/image-resize-core.js.map +1 -0
  608. package/dist/utils/image-resize-worker.d.ts +2 -0
  609. package/dist/utils/image-resize-worker.d.ts.map +1 -0
  610. package/dist/utils/image-resize-worker.js +31 -0
  611. package/dist/utils/image-resize-worker.js.map +1 -0
  612. package/dist/utils/image-resize.d.ts +16 -0
  613. package/dist/utils/image-resize.d.ts.map +1 -0
  614. package/dist/utils/image-resize.js +97 -0
  615. package/dist/utils/image-resize.js.map +1 -0
  616. package/dist/utils/json.d.ts +3 -0
  617. package/dist/utils/json.d.ts.map +1 -0
  618. package/dist/utils/json.js +7 -0
  619. package/dist/utils/json.js.map +1 -0
  620. package/dist/utils/mime.d.ts +3 -0
  621. package/dist/utils/mime.d.ts.map +1 -0
  622. package/dist/utils/mime.js +110 -0
  623. package/dist/utils/mime.js.map +1 -0
  624. package/dist/utils/open-browser.d.ts +9 -0
  625. package/dist/utils/open-browser.d.ts.map +1 -0
  626. package/dist/utils/open-browser.js +22 -0
  627. package/dist/utils/open-browser.js.map +1 -0
  628. package/dist/utils/paths.d.ts +31 -0
  629. package/dist/utils/paths.d.ts.map +1 -0
  630. package/dist/utils/paths.js +92 -0
  631. package/dist/utils/paths.js.map +1 -0
  632. package/dist/utils/photon.d.ts +21 -0
  633. package/dist/utils/photon.d.ts.map +1 -0
  634. package/dist/utils/photon.js +121 -0
  635. package/dist/utils/photon.js.map +1 -0
  636. package/dist/utils/pi-user-agent.d.ts +2 -0
  637. package/dist/utils/pi-user-agent.d.ts.map +1 -0
  638. package/dist/utils/pi-user-agent.js +5 -0
  639. package/dist/utils/pi-user-agent.js.map +1 -0
  640. package/dist/utils/shell.d.ts +31 -0
  641. package/dist/utils/shell.d.ts.map +1 -0
  642. package/dist/utils/shell.js +202 -0
  643. package/dist/utils/shell.js.map +1 -0
  644. package/dist/utils/sleep.d.ts +5 -0
  645. package/dist/utils/sleep.d.ts.map +1 -0
  646. package/dist/utils/sleep.js +17 -0
  647. package/dist/utils/sleep.js.map +1 -0
  648. package/dist/utils/syntax-highlight.d.ts +12 -0
  649. package/dist/utils/syntax-highlight.d.ts.map +1 -0
  650. package/dist/utils/syntax-highlight.js +118 -0
  651. package/dist/utils/syntax-highlight.js.map +1 -0
  652. package/dist/utils/tools-manager.d.ts +3 -0
  653. package/dist/utils/tools-manager.d.ts.map +1 -0
  654. package/dist/utils/tools-manager.js +328 -0
  655. package/dist/utils/tools-manager.js.map +1 -0
  656. package/dist/utils/version-check.d.ts +15 -0
  657. package/dist/utils/version-check.d.ts.map +1 -0
  658. package/dist/utils/version-check.js +59 -0
  659. package/dist/utils/version-check.js.map +1 -0
  660. package/dist/utils/windows-self-update.d.ts +3 -0
  661. package/dist/utils/windows-self-update.d.ts.map +1 -0
  662. package/dist/utils/windows-self-update.js +77 -0
  663. package/dist/utils/windows-self-update.js.map +1 -0
  664. package/docs/compaction.md +396 -0
  665. package/docs/containerization.md +111 -0
  666. package/docs/custom-provider.md +737 -0
  667. package/docs/development.md +71 -0
  668. package/docs/docs.json +156 -0
  669. package/docs/extensions.md +2695 -0
  670. package/docs/images/doom-extension.png +0 -0
  671. package/docs/images/exy.png +0 -0
  672. package/docs/images/interactive-mode.png +0 -0
  673. package/docs/images/tree-view.png +0 -0
  674. package/docs/index.md +82 -0
  675. package/docs/json.md +82 -0
  676. package/docs/keybindings.md +197 -0
  677. package/docs/models.md +495 -0
  678. package/docs/packages.md +227 -0
  679. package/docs/prompt-templates.md +95 -0
  680. package/docs/providers.md +275 -0
  681. package/docs/quickstart.md +165 -0
  682. package/docs/rpc.md +1470 -0
  683. package/docs/sdk.md +1143 -0
  684. package/docs/security.md +59 -0
  685. package/docs/session-format.md +412 -0
  686. package/docs/sessions.md +145 -0
  687. package/docs/settings.md +318 -0
  688. package/docs/shell-aliases.md +13 -0
  689. package/docs/skills.md +231 -0
  690. package/docs/terminal-setup.md +142 -0
  691. package/docs/termux.md +127 -0
  692. package/docs/themes.md +295 -0
  693. package/docs/tmux.md +63 -0
  694. package/docs/tui.md +927 -0
  695. package/docs/usage.md +308 -0
  696. package/docs/windows.md +17 -0
  697. package/examples/README.md +25 -0
  698. package/examples/extensions/README.md +211 -0
  699. package/examples/extensions/auto-commit-on-exit.ts +49 -0
  700. package/examples/extensions/bash-spawn-hook.ts +30 -0
  701. package/examples/extensions/bookmark.ts +50 -0
  702. package/examples/extensions/border-status-editor.ts +150 -0
  703. package/examples/extensions/built-in-tool-renderer.ts +249 -0
  704. package/examples/extensions/claude-rules.ts +86 -0
  705. package/examples/extensions/commands.ts +72 -0
  706. package/examples/extensions/confirm-destructive.ts +59 -0
  707. package/examples/extensions/custom-compaction.ts +128 -0
  708. package/examples/extensions/custom-footer.ts +64 -0
  709. package/examples/extensions/custom-header.ts +73 -0
  710. package/examples/extensions/custom-provider-anthropic/index.ts +604 -0
  711. package/examples/extensions/custom-provider-anthropic/package-lock.json +24 -0
  712. package/examples/extensions/custom-provider-anthropic/package.json +19 -0
  713. package/examples/extensions/custom-provider-gitlab-duo/index.ts +404 -0
  714. package/examples/extensions/custom-provider-gitlab-duo/package.json +16 -0
  715. package/examples/extensions/custom-provider-gitlab-duo/test.ts +82 -0
  716. package/examples/extensions/dirty-repo-guard.ts +56 -0
  717. package/examples/extensions/doom-overlay/README.md +46 -0
  718. package/examples/extensions/doom-overlay/doom/build/doom.js +21 -0
  719. package/examples/extensions/doom-overlay/doom/build/doom.wasm +0 -0
  720. package/examples/extensions/doom-overlay/doom/build.sh +152 -0
  721. package/examples/extensions/doom-overlay/doom/doomgeneric_pi.c +72 -0
  722. package/examples/extensions/doom-overlay/doom-component.ts +132 -0
  723. package/examples/extensions/doom-overlay/doom-engine.ts +173 -0
  724. package/examples/extensions/doom-overlay/doom-keys.ts +104 -0
  725. package/examples/extensions/doom-overlay/index.ts +74 -0
  726. package/examples/extensions/doom-overlay/wad-finder.ts +51 -0
  727. package/examples/extensions/dynamic-resources/SKILL.md +8 -0
  728. package/examples/extensions/dynamic-resources/dynamic.json +79 -0
  729. package/examples/extensions/dynamic-resources/dynamic.md +5 -0
  730. package/examples/extensions/dynamic-resources/index.ts +15 -0
  731. package/examples/extensions/dynamic-tools.ts +74 -0
  732. package/examples/extensions/event-bus.ts +43 -0
  733. package/examples/extensions/file-trigger.ts +41 -0
  734. package/examples/extensions/git-checkpoint.ts +53 -0
  735. package/examples/extensions/git-merge-and-resolve.ts +115 -0
  736. package/examples/extensions/github-issue-autocomplete.ts +185 -0
  737. package/examples/extensions/gondolin/index.ts +531 -0
  738. package/examples/extensions/gondolin/package-lock.json +185 -0
  739. package/examples/extensions/gondolin/package.json +19 -0
  740. package/examples/extensions/handoff.ts +191 -0
  741. package/examples/extensions/hello.ts +26 -0
  742. package/examples/extensions/hidden-thinking-label.ts +53 -0
  743. package/examples/extensions/inline-bash.ts +94 -0
  744. package/examples/extensions/input-transform-streaming.ts +39 -0
  745. package/examples/extensions/input-transform.ts +43 -0
  746. package/examples/extensions/interactive-shell.ts +196 -0
  747. package/examples/extensions/mac-system-theme.ts +47 -0
  748. package/examples/extensions/message-renderer.ts +59 -0
  749. package/examples/extensions/minimal-mode.ts +426 -0
  750. package/examples/extensions/modal-editor.ts +85 -0
  751. package/examples/extensions/model-status.ts +31 -0
  752. package/examples/extensions/notify.ts +55 -0
  753. package/examples/extensions/overlay-qa-tests.ts +1450 -0
  754. package/examples/extensions/overlay-test.ts +153 -0
  755. package/examples/extensions/permission-gate.ts +34 -0
  756. package/examples/extensions/pirate.ts +47 -0
  757. package/examples/extensions/plan-mode/README.md +66 -0
  758. package/examples/extensions/plan-mode/index.ts +390 -0
  759. package/examples/extensions/plan-mode/utils.ts +168 -0
  760. package/examples/extensions/preset.ts +436 -0
  761. package/examples/extensions/project-trust.ts +64 -0
  762. package/examples/extensions/prompt-customizer.ts +97 -0
  763. package/examples/extensions/protected-paths.ts +30 -0
  764. package/examples/extensions/provider-payload.ts +18 -0
  765. package/examples/extensions/qna.ts +122 -0
  766. package/examples/extensions/question.ts +285 -0
  767. package/examples/extensions/questionnaire.ts +448 -0
  768. package/examples/extensions/rainbow-editor.ts +88 -0
  769. package/examples/extensions/reload-runtime.ts +37 -0
  770. package/examples/extensions/rpc-demo.ts +118 -0
  771. package/examples/extensions/sandbox/index.ts +321 -0
  772. package/examples/extensions/sandbox/package-lock.json +92 -0
  773. package/examples/extensions/sandbox/package.json +19 -0
  774. package/examples/extensions/send-user-message.ts +97 -0
  775. package/examples/extensions/session-name.ts +27 -0
  776. package/examples/extensions/shutdown-command.ts +63 -0
  777. package/examples/extensions/snake.ts +343 -0
  778. package/examples/extensions/space-invaders.ts +560 -0
  779. package/examples/extensions/ssh.ts +220 -0
  780. package/examples/extensions/status-line.ts +32 -0
  781. package/examples/extensions/structured-output.ts +65 -0
  782. package/examples/extensions/subagent/README.md +175 -0
  783. package/examples/extensions/subagent/agents/planner.md +37 -0
  784. package/examples/extensions/subagent/agents/reviewer.md +35 -0
  785. package/examples/extensions/subagent/agents/scout.md +50 -0
  786. package/examples/extensions/subagent/agents/worker.md +24 -0
  787. package/examples/extensions/subagent/agents.ts +126 -0
  788. package/examples/extensions/subagent/index.ts +1015 -0
  789. package/examples/extensions/subagent/prompts/implement-and-review.md +10 -0
  790. package/examples/extensions/subagent/prompts/implement.md +10 -0
  791. package/examples/extensions/subagent/prompts/scout-and-plan.md +9 -0
  792. package/examples/extensions/summarize.ts +207 -0
  793. package/examples/extensions/system-prompt-header.ts +17 -0
  794. package/examples/extensions/tic-tac-toe.ts +1008 -0
  795. package/examples/extensions/timed-confirm.ts +70 -0
  796. package/examples/extensions/titlebar-spinner.ts +58 -0
  797. package/examples/extensions/todo.ts +297 -0
  798. package/examples/extensions/tool-override.ts +144 -0
  799. package/examples/extensions/tools.ts +146 -0
  800. package/examples/extensions/trigger-compact.ts +50 -0
  801. package/examples/extensions/truncated-tool.ts +195 -0
  802. package/examples/extensions/widget-placement.ts +9 -0
  803. package/examples/extensions/with-deps/index.ts +32 -0
  804. package/examples/extensions/with-deps/package-lock.json +31 -0
  805. package/examples/extensions/with-deps/package.json +22 -0
  806. package/examples/extensions/working-indicator.ts +123 -0
  807. package/examples/extensions/working-message-test.ts +25 -0
  808. package/examples/rpc-extension-ui.ts +632 -0
  809. package/examples/sdk/01-minimal.ts +26 -0
  810. package/examples/sdk/02-custom-model.ts +53 -0
  811. package/examples/sdk/03-custom-prompt.ts +75 -0
  812. package/examples/sdk/04-skills.ts +55 -0
  813. package/examples/sdk/05-tools.ts +48 -0
  814. package/examples/sdk/06-extensions.ts +99 -0
  815. package/examples/sdk/07-context-files.ts +47 -0
  816. package/examples/sdk/08-prompt-templates.ts +51 -0
  817. package/examples/sdk/09-api-keys-and-oauth.ts +52 -0
  818. package/examples/sdk/10-settings.ts +53 -0
  819. package/examples/sdk/11-sessions.ts +52 -0
  820. package/examples/sdk/12-full-control.ts +77 -0
  821. package/examples/sdk/13-session-runtime.ts +67 -0
  822. package/examples/sdk/README.md +144 -0
  823. package/npm-shrinkwrap.json +1824 -0
  824. package/package.json +103 -0
@@ -0,0 +1,318 @@
1
+ # Settings
2
+
3
+ Pi uses JSON settings files with project settings overriding global settings.
4
+
5
+ | Location | Scope |
6
+ |----------|-------|
7
+ | `~/.pi/agent/settings.json` | Global (all projects) |
8
+ | `.pi/settings.json` | Project (current directory) |
9
+
10
+ Edit directly or use `/settings` for common options.
11
+
12
+ ## Project Trust
13
+
14
+ On interactive startup, pi asks before trusting a project folder that contains project-local settings, resources, or project `.agents/skills` and has no saved decision for the folder or a parent folder in `~/.pi/agent/trust.json`. Trusting a project allows pi to load `.pi/settings.json` and `.pi` resources, install missing project packages, and execute project extensions.
15
+
16
+ Non-interactive modes (`-p`, `--mode json`, and `--mode rpc`) do not show a trust prompt. Without an applicable saved trust decision, they use `defaultProjectTrust` from global settings: `ask` (default) and `never` ignore those project resources, while `always` trusts them. Pass `--approve`/`-a` or `--no-approve`/`-na` to override project trust for one run.
17
+
18
+ If no extension or saved decision applies, `defaultProjectTrust` controls the fallback behavior. Set it to `"ask"`, `"always"`, or `"never"` in `~/.pi/agent/settings.json`, or change it with `/settings`.
19
+
20
+ `pi config` and package commands use the same project trust flow, except `pi update` never prompts. Pass `--approve` to trust project-local settings for one command or `--no-approve` to ignore them.
21
+
22
+ Use `/trust` in interactive mode to save a project trust decision for future sessions, including trust for the immediate parent folder. It writes `~/.pi/agent/trust.json` only; the current session is not reloaded, so restart pi for changes to take effect.
23
+
24
+ ## All Settings
25
+
26
+ ### Model & Thinking
27
+
28
+ | Setting | Type | Default | Description |
29
+ |---------|------|---------|-------------|
30
+ | `defaultProvider` | string | - | Default provider (e.g., `"anthropic"`, `"openai"`) |
31
+ | `defaultModel` | string | - | Default model ID |
32
+ | `defaultThinkingLevel` | string | - | `"off"`, `"minimal"`, `"low"`, `"medium"`, `"high"`, `"xhigh"` |
33
+ | `hideThinkingBlock` | boolean | `false` | Hide thinking blocks in output |
34
+ | `thinkingBudgets` | object | - | Custom token budgets per thinking level |
35
+
36
+ #### thinkingBudgets
37
+
38
+ ```json
39
+ {
40
+ "thinkingBudgets": {
41
+ "minimal": 1024,
42
+ "low": 4096,
43
+ "medium": 10240,
44
+ "high": 32768
45
+ }
46
+ }
47
+ ```
48
+
49
+ ### UI & Display
50
+
51
+ | Setting | Type | Default | Description |
52
+ |---------|------|---------|-------------|
53
+ | `theme` | string | `"dark"` | Theme name (`"dark"`, `"light"`, or custom) |
54
+ | `externalEditor` | string | `$VISUAL`, then `$EDITOR`, then Notepad on Windows or `nano` elsewhere | Command for Ctrl+G external editor; takes precedence over environment variables |
55
+ | `quietStartup` | boolean | `false` | Hide startup header |
56
+ | `defaultProjectTrust` | string | `"ask"` | Fallback project trust behavior: `"ask"`, `"always"`, or `"never"`. Global setting only |
57
+ | `collapseChangelog` | boolean | `false` | Show condensed changelog after updates |
58
+ | `enableInstallTelemetry` | boolean | `true` | Send an anonymous install/update version ping after first install or changelog-detected updates. This does not control update checks |
59
+ | `enableAnalytics` | boolean | `false` | Opt-in analytics data sharing. Currently only asked for during the experimental first-time setup (`PI_EXPERIMENTAL=1`) |
60
+ | `trackingId` | string | - | Analytics tracking identifier, generated when `enableAnalytics` is turned on |
61
+ | `doubleEscapeAction` | string | `"tree"` | Action for double-escape: `"tree"`, `"fork"`, or `"none"` |
62
+ | `treeFilterMode` | string | `"default"` | Default filter for `/tree`: `"default"`, `"no-tools"`, `"user-only"`, `"labeled-only"`, `"all"` |
63
+ | `editorPaddingX` | number | `0` | Horizontal padding for input editor (0-3) |
64
+ | `outputPad` | number | `1` | Horizontal padding for user messages, assistant messages, and thinking (0 or 1) |
65
+ | `autocompleteMaxVisible` | number | `5` | Max visible items in autocomplete dropdown (3-20) |
66
+ | `showHardwareCursor` | boolean | `false` | Show the terminal cursor while TUI positions it for IME support |
67
+
68
+ For VS Code, include `--wait` so pi resumes after the editor exits:
69
+
70
+ ```json
71
+ {
72
+ "externalEditor": "code --wait"
73
+ }
74
+ ```
75
+
76
+ ### Telemetry and update checks
77
+
78
+ `enableInstallTelemetry` only controls the anonymous install/update ping to `https://pi.dev/api/report-install`. Opting out of telemetry does not disable update checks; Pi can still fetch `https://pi.dev/api/latest-version` to look for the latest version.
79
+
80
+ Set `PI_SKIP_VERSION_CHECK=1` to disable the Pi version update check. Use `--offline` or `PI_OFFLINE=1` to disable all startup network operations described here, including update checks, package update checks, and install/update telemetry.
81
+
82
+ ### Network
83
+
84
+ | Setting | Type | Default | Description |
85
+ |---------|------|---------|-------------|
86
+ | `httpProxy` | string | - | HTTP proxy URL applied as `HTTP_PROXY` and `HTTPS_PROXY`. Global setting only. |
87
+
88
+ ```json
89
+ {
90
+ "httpProxy": "http://127.0.0.1:7890"
91
+ }
92
+ ```
93
+
94
+ ### Warnings
95
+
96
+ | Setting | Type | Default | Description |
97
+ |---------|------|---------|-------------|
98
+ | `warnings.anthropicExtraUsage` | boolean | `true` | Show a warning when Anthropic subscription auth may use paid extra usage |
99
+
100
+ ```json
101
+ {
102
+ "warnings": {
103
+ "anthropicExtraUsage": false
104
+ }
105
+ }
106
+ ```
107
+
108
+ ### Compaction
109
+
110
+ | Setting | Type | Default | Description |
111
+ |---------|------|---------|-------------|
112
+ | `compaction.enabled` | boolean | `true` | Enable auto-compaction |
113
+ | `compaction.reserveTokens` | number | `16384` | Tokens reserved for LLM response |
114
+ | `compaction.keepRecentTokens` | number | `20000` | Recent tokens to keep (not summarized) |
115
+
116
+ ```json
117
+ {
118
+ "compaction": {
119
+ "enabled": true,
120
+ "reserveTokens": 16384,
121
+ "keepRecentTokens": 20000
122
+ }
123
+ }
124
+ ```
125
+
126
+ ### Branch Summary
127
+
128
+ | Setting | Type | Default | Description |
129
+ |---------|------|---------|-------------|
130
+ | `branchSummary.reserveTokens` | number | `16384` | Tokens reserved for branch summarization |
131
+ | `branchSummary.skipPrompt` | boolean | `false` | Skip "Summarize branch?" prompt on `/tree` navigation (defaults to no summary) |
132
+
133
+ ### Retry
134
+
135
+ | Setting | Type | Default | Description |
136
+ |---------|------|---------|-------------|
137
+ | `retry.enabled` | boolean | `true` | Enable automatic agent-level retry on transient errors |
138
+ | `retry.maxRetries` | number | `3` | Maximum agent-level retry attempts |
139
+ | `retry.baseDelayMs` | number | `2000` | Base delay for agent-level exponential backoff (2s, 4s, 8s) |
140
+ | `retry.provider.timeoutMs` | number | SDK default | Provider/SDK request timeout in milliseconds |
141
+ | `retry.provider.maxRetries` | number | `0` | Provider/SDK retry attempts |
142
+ | `retry.provider.maxRetryDelayMs` | number | `60000` | Max server-requested delay before failing (60s) |
143
+
144
+ When a provider requests a retry delay longer than `retry.provider.maxRetryDelayMs` (e.g., Google's "quota will reset after 5h"), the request fails immediately with an informative error instead of waiting silently. Set to `0` to disable the cap.
145
+
146
+ Keep `retry.provider.maxRetries` at `0` unless provider-level retries are explicitly needed. Setting it above `0` can make SDK/provider retries handle out-of-usage-limit errors before Pi sees them, which may block the agent until the provider quota resets in some circumstances.
147
+
148
+ ```json
149
+ {
150
+ "retry": {
151
+ "enabled": true,
152
+ "maxRetries": 3,
153
+ "baseDelayMs": 2000,
154
+ "provider": {
155
+ "timeoutMs": 3600000,
156
+ "maxRetries": 0,
157
+ "maxRetryDelayMs": 60000
158
+ }
159
+ }
160
+ }
161
+ ```
162
+
163
+ ### Message Delivery
164
+
165
+ | Setting | Type | Default | Description |
166
+ |---------|------|---------|-------------|
167
+ | `steeringMode` | string | `"one-at-a-time"` | How steering messages are sent: `"all"` or `"one-at-a-time"` |
168
+ | `followUpMode` | string | `"one-at-a-time"` | How follow-up messages are sent: `"all"` or `"one-at-a-time"` |
169
+ | `transport` | string | `"auto"` | Preferred transport for providers that support multiple transports: `"sse"`, `"websocket"`, `"websocket-cached"`, or `"auto"` |
170
+ | `httpIdleTimeoutMs` | number | `300000` | HTTP header/body idle timeout in milliseconds, also used by providers with explicit stream idle timeouts. Set to `0` to disable. |
171
+ | `websocketConnectTimeoutMs` | number | `15000` | WebSocket connect/open handshake timeout in milliseconds for providers that support WebSocket transports. Set to `0` to disable. |
172
+
173
+ ### Terminal & Images
174
+
175
+ | Setting | Type | Default | Description |
176
+ |---------|------|---------|-------------|
177
+ | `terminal.showImages` | boolean | `true` | Show images in terminal (if supported) |
178
+ | `terminal.imageWidthCells` | number | `60` | Preferred inline image width in terminal cells |
179
+ | `terminal.clearOnShrink` | boolean | `false` | Clear empty rows when content shrinks (can cause flicker) |
180
+ | `images.autoResize` | boolean | `true` | Resize images to 2000x2000 max |
181
+ | `images.blockImages` | boolean | `false` | Block all images from being sent to LLM |
182
+
183
+ ### Shell
184
+
185
+ | Setting | Type | Default | Description |
186
+ |---------|------|---------|-------------|
187
+ | `shellPath` | string | - | Custom shell path (e.g., for Cygwin on Windows) |
188
+ | `shellCommandPrefix` | string | - | Prefix for every bash command (e.g., `"shopt -s expand_aliases"`) |
189
+ | `npmCommand` | string[] | - | Command argv used for npm package lookup/install operations (e.g., `["mise", "exec", "node@20", "--", "npm"]`) |
190
+
191
+ ```json
192
+ {
193
+ "npmCommand": ["mise", "exec", "node@20", "--", "npm"]
194
+ }
195
+ ```
196
+
197
+ `npmCommand` is used for all npm package-manager operations, including installs, uninstalls, and dependency installs inside git packages. User-scoped npm packages install under `~/.pi/agent/npm/`; project-scoped npm packages install under `.pi/npm/`. Use argv-style entries exactly as the process should be launched. When `npmCommand` is configured, git package dependency installs use plain `install` to avoid npm-specific flags in wrappers or alternate package managers.
198
+
199
+ ### Sessions
200
+
201
+ | Setting | Type | Default | Description |
202
+ |---------|------|---------|-------------|
203
+ | `sessionDir` | string | - | Directory where session files are stored. Accepts absolute or relative paths, plus `~`. |
204
+
205
+ ```json
206
+ { "sessionDir": ".pi/sessions" }
207
+ ```
208
+
209
+ When multiple sources specify a session directory, precedence is `--session-dir`, `PI_CODING_AGENT_SESSION_DIR`, then `sessionDir` in settings.json.
210
+
211
+ ### Model Cycling
212
+
213
+ | Setting | Type | Default | Description |
214
+ |---------|------|---------|-------------|
215
+ | `enabledModels` | string[] | - | Model patterns for Ctrl+P cycling (same format as `--models` CLI flag) |
216
+
217
+ ```json
218
+ {
219
+ "enabledModels": ["claude-*", "gpt-4o", "gemini-2*"]
220
+ }
221
+ ```
222
+
223
+ ### Markdown
224
+
225
+ | Setting | Type | Default | Description |
226
+ |---------|------|---------|-------------|
227
+ | `markdown.codeBlockIndent` | string | `" "` | Indentation for code blocks |
228
+
229
+ ### Resources
230
+
231
+ These settings define where to load extensions, skills, prompts, and themes from.
232
+
233
+ Paths in `~/.pi/agent/settings.json` resolve relative to `~/.pi/agent`. Paths in `.pi/settings.json` resolve relative to `.pi`. Absolute paths and `~` are supported.
234
+
235
+ | Setting | Type | Default | Description |
236
+ |---------|------|---------|-------------|
237
+ | `packages` | array | `[]` | npm/git packages to load resources from |
238
+ | `extensions` | string[] | `[]` | Local extension file paths or directories |
239
+ | `skills` | string[] | `[]` | Local skill file paths or directories |
240
+ | `prompts` | string[] | `[]` | Local prompt template paths or directories |
241
+ | `themes` | string[] | `[]` | Local theme file paths or directories |
242
+ | `enableSkillCommands` | boolean | `true` | Register skills as `/skill:name` commands |
243
+
244
+ Arrays support glob patterns and exclusions. Use `!pattern` to exclude. Use `+path` to force-include an exact path and `-path` to force-exclude an exact path.
245
+
246
+ #### packages
247
+
248
+ String form loads all resources from a package:
249
+
250
+ ```json
251
+ {
252
+ "packages": ["pi-skills", "@org/my-extension"]
253
+ }
254
+ ```
255
+
256
+ Object form filters which resources to load:
257
+
258
+ ```json
259
+ {
260
+ "packages": [
261
+ {
262
+ "source": "pi-skills",
263
+ "skills": ["brave-search", "transcribe"],
264
+ "extensions": []
265
+ }
266
+ ]
267
+ }
268
+ ```
269
+
270
+ See [packages.md](packages.md) for package management details.
271
+
272
+ ## Example
273
+
274
+ ```json
275
+ {
276
+ "defaultProvider": "anthropic",
277
+ "defaultModel": "claude-sonnet-4-20250514",
278
+ "defaultThinkingLevel": "medium",
279
+ "theme": "dark",
280
+ "compaction": {
281
+ "enabled": true,
282
+ "reserveTokens": 16384,
283
+ "keepRecentTokens": 20000
284
+ },
285
+ "retry": {
286
+ "enabled": true,
287
+ "maxRetries": 3
288
+ },
289
+ "enabledModels": ["claude-*", "gpt-4o"],
290
+ "warnings": {
291
+ "anthropicExtraUsage": true
292
+ },
293
+ "packages": ["pi-skills"]
294
+ }
295
+ ```
296
+
297
+ ## Project Overrides
298
+
299
+ Project settings (`.pi/settings.json`) override global settings. Nested objects are merged:
300
+
301
+ ```json
302
+ // ~/.pi/agent/settings.json (global)
303
+ {
304
+ "theme": "dark",
305
+ "compaction": { "enabled": true, "reserveTokens": 16384 }
306
+ }
307
+
308
+ // .pi/settings.json (project)
309
+ {
310
+ "compaction": { "reserveTokens": 8192 }
311
+ }
312
+
313
+ // Result
314
+ {
315
+ "theme": "dark",
316
+ "compaction": { "enabled": true, "reserveTokens": 8192 }
317
+ }
318
+ ```
@@ -0,0 +1,13 @@
1
+ # Shell Aliases
2
+
3
+ Pi runs bash in non-interactive mode (`bash -c`), which doesn't expand aliases by default.
4
+
5
+ To enable your shell aliases, add to `~/.pi/agent/settings.json`:
6
+
7
+ ```json
8
+ {
9
+ "shellCommandPrefix": "shopt -s expand_aliases\neval \"$(grep '^alias ' ~/.zshrc)\""
10
+ }
11
+ ```
12
+
13
+ Adjust the path (`~/.zshrc`, `~/.bashrc`, etc.) to match your shell config.
package/docs/skills.md ADDED
@@ -0,0 +1,231 @@
1
+ > pi can create skills. Ask it to build one for your use case.
2
+
3
+ # Skills
4
+
5
+ Skills are self-contained capability packages that the agent loads on-demand. A skill provides specialized workflows, setup instructions, helper scripts, and reference documentation for specific tasks.
6
+
7
+ Pi implements the [Agent Skills standard](https://agentskills.io/specification), warning about most violations but remaining lenient. Pi allows skill names to differ from their parent directory even though the standard disallows it; that rule is suboptimal for shared skill directories used across multiple agent harnesses.
8
+
9
+ ## Table of Contents
10
+
11
+ - [Locations](#locations)
12
+ - [How Skills Work](#how-skills-work)
13
+ - [Skill Commands](#skill-commands)
14
+ - [Skill Structure](#skill-structure)
15
+ - [Frontmatter](#frontmatter)
16
+ - [Validation](#validation)
17
+ - [Example](#example)
18
+ - [Skill Repositories](#skill-repositories)
19
+
20
+ ## Locations
21
+
22
+ > **Security:** Skills can instruct the model to perform any action and may include executable code the model invokes. Review skill content before use.
23
+
24
+ Pi loads skills from:
25
+
26
+ - Global:
27
+ - `~/.pi/agent/skills/`
28
+ - `~/.agents/skills/`
29
+ - Project (only after the project is trusted):
30
+ - `.pi/skills/`
31
+ - `.agents/skills/` in `cwd` and ancestor directories (up to git repo root, or filesystem root when not in a repo)
32
+ - Packages: `skills/` directories or `pi.skills` entries in `package.json`
33
+ - Settings: `skills` array with files or directories
34
+ - CLI: `--skill <path>` (repeatable, additive even with `--no-skills`)
35
+
36
+ Discovery rules:
37
+ - In `~/.pi/agent/skills/` and `.pi/skills/`, direct root `.md` files are discovered as individual skills
38
+ - In all skill locations, directories containing `SKILL.md` are discovered recursively
39
+ - In `~/.agents/skills/` and project `.agents/skills/`, root `.md` files are ignored
40
+
41
+ Disable discovery with `--no-skills` (explicit `--skill` paths still load).
42
+
43
+ ### Using Skills from Other Harnesses
44
+
45
+ To use skills from Claude Code or OpenAI Codex, add their directories to settings:
46
+
47
+ ```json
48
+ {
49
+ "skills": [
50
+ "~/.claude/skills",
51
+ "~/.codex/skills"
52
+ ]
53
+ }
54
+ ```
55
+
56
+ For project-level Claude Code skills, add to `.pi/settings.json`:
57
+
58
+ ```json
59
+ {
60
+ "skills": ["../.claude/skills"]
61
+ }
62
+ ```
63
+
64
+ ## How Skills Work
65
+
66
+ 1. At startup, pi scans skill locations and extracts names and descriptions
67
+ 2. The system prompt includes available skills in XML format per the [specification](https://agentskills.io/integrate-skills)
68
+ 3. When a task matches, the agent uses `read` to load the full SKILL.md (models don't always do this; use prompting or `/skill:name` to force it)
69
+ 4. The agent follows the instructions, using relative paths to reference scripts and assets
70
+
71
+ This is progressive disclosure: only descriptions are always in context, full instructions load on-demand.
72
+
73
+ ## Skill Commands
74
+
75
+ Skills register as `/skill:name` commands:
76
+
77
+ ```bash
78
+ /skill:brave-search # Load and execute the skill
79
+ /skill:pdf-tools extract # Load skill with arguments
80
+ ```
81
+
82
+ Arguments after the command are appended to the skill content as `User: <args>`.
83
+
84
+ Toggle skill commands via `/settings` in interactive mode or in `settings.json`:
85
+
86
+ ```json
87
+ {
88
+ "enableSkillCommands": true
89
+ }
90
+ ```
91
+
92
+ ## Skill Structure
93
+
94
+ A skill is a directory with a `SKILL.md` file. Everything else is freeform.
95
+
96
+ ```
97
+ my-skill/
98
+ ├── SKILL.md # Required: frontmatter + instructions
99
+ ├── scripts/ # Helper scripts
100
+ │ └── process.sh
101
+ ├── references/ # Detailed docs loaded on-demand
102
+ │ └── api-reference.md
103
+ └── assets/
104
+ └── template.json
105
+ ```
106
+
107
+ ### SKILL.md Format
108
+
109
+ ````markdown
110
+ ---
111
+ name: my-skill
112
+ description: What this skill does and when to use it. Be specific.
113
+ ---
114
+
115
+ # My Skill
116
+
117
+ ## Setup
118
+
119
+ Run once before first use:
120
+ ```bash
121
+ cd /path/to/skill && npm install
122
+ ```
123
+
124
+ ## Usage
125
+
126
+ ```bash
127
+ ./scripts/process.sh <input>
128
+ ```
129
+ ````
130
+
131
+ Use relative paths from the skill directory:
132
+
133
+ ```markdown
134
+ See [the reference guide](references/REFERENCE.md) for details.
135
+ ```
136
+
137
+ ## Frontmatter
138
+
139
+ Per the [Agent Skills specification](https://agentskills.io/specification#frontmatter-required):
140
+
141
+ | Field | Required | Description |
142
+ |-------|----------|-------------|
143
+ | `name` | Yes | Max 64 chars. Lowercase a-z, 0-9, hyphens. Unlike the standard, Pi does not require this to match the parent directory because that standard requirement is suboptimal for shared skill directories. |
144
+ | `description` | Yes | Max 1024 chars. What the skill does and when to use it. |
145
+ | `license` | No | License name or reference to bundled file. |
146
+ | `compatibility` | No | Max 500 chars. Environment requirements. |
147
+ | `metadata` | No | Arbitrary key-value mapping. |
148
+ | `allowed-tools` | No | Space-delimited list of pre-approved tools (experimental). |
149
+ | `disable-model-invocation` | No | When `true`, skill is hidden from system prompt. Users must use `/skill:name`. |
150
+
151
+ ### Name Rules
152
+
153
+ - 1-64 characters
154
+ - Lowercase letters, numbers, hyphens only
155
+ - No leading/trailing hyphens
156
+ - No consecutive hyphens
157
+ Pi does not require the name to match the parent directory. The Agent Skills standard does, but that requirement is suboptimal for shared skill directories used by multiple tools.
158
+
159
+ Valid: `pdf-processing`, `data-analysis`, `code-review`
160
+ Invalid: `PDF-Processing`, `-pdf`, `pdf--processing`
161
+
162
+ ### Description Best Practices
163
+
164
+ The description determines when the agent loads the skill. Be specific.
165
+
166
+ Good:
167
+ ```yaml
168
+ description: Extracts text and tables from PDF files, fills PDF forms, and merges multiple PDFs. Use when working with PDF documents.
169
+ ```
170
+
171
+ Poor:
172
+ ```yaml
173
+ description: Helps with PDFs.
174
+ ```
175
+
176
+ ## Validation
177
+
178
+ Pi validates skills against the Agent Skills standard. Most issues produce warnings but still load the skill:
179
+
180
+ - Name exceeds 64 characters or contains invalid characters
181
+ - Name starts/ends with hyphen or has consecutive hyphens
182
+ - Description exceeds 1024 characters
183
+
184
+ Unknown frontmatter fields are ignored.
185
+
186
+ **Exception:** Skills with missing description are not loaded.
187
+
188
+ Name collisions (same name from different locations) warn and keep the first skill found.
189
+
190
+ ## Example
191
+
192
+ ```
193
+ brave-search/
194
+ ├── SKILL.md
195
+ ├── search.js
196
+ └── content.js
197
+ ```
198
+
199
+ **SKILL.md:**
200
+ ````markdown
201
+ ---
202
+ name: brave-search
203
+ description: Web search and content extraction via Brave Search API. Use for searching documentation, facts, or any web content.
204
+ ---
205
+
206
+ # Brave Search
207
+
208
+ ## Setup
209
+
210
+ ```bash
211
+ cd /path/to/brave-search && npm install
212
+ ```
213
+
214
+ ## Search
215
+
216
+ ```bash
217
+ ./search.js "query" # Basic search
218
+ ./search.js "query" --content # Include page content
219
+ ```
220
+
221
+ ## Extract Page Content
222
+
223
+ ```bash
224
+ ./content.js https://example.com
225
+ ```
226
+ ````
227
+
228
+ ## Skill Repositories
229
+
230
+ - [Anthropic Skills](https://github.com/anthropics/skills) - Document processing (docx, pdf, pptx, xlsx), web development
231
+ - [Pi Skills](https://github.com/badlogic/pi-skills) - Web search, browser automation, Google APIs, transcription