@travisennis/acai 0.0.4 → 0.0.6

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 (433) hide show
  1. package/README.md +229 -8
  2. package/dist/agent/index.d.ts +119 -0
  3. package/dist/agent/index.d.ts.map +1 -0
  4. package/dist/agent/index.js +406 -0
  5. package/dist/agent/manual-loop.d.ts +41 -0
  6. package/dist/agent/manual-loop.d.ts.map +1 -0
  7. package/dist/agent/manual-loop.js +278 -0
  8. package/dist/api/exa/index.d.ts +177 -0
  9. package/dist/api/exa/index.d.ts.map +1 -0
  10. package/dist/api/exa/index.js +439 -0
  11. package/dist/cli.d.ts +5 -2
  12. package/dist/cli.d.ts.map +1 -0
  13. package/dist/cli.js +27 -33
  14. package/dist/commands/add-directory-command.d.ts +3 -0
  15. package/dist/commands/add-directory-command.d.ts.map +1 -0
  16. package/dist/commands/add-directory-command.js +85 -0
  17. package/dist/commands/application-log-command.d.ts +1 -0
  18. package/dist/commands/application-log-command.d.ts.map +1 -0
  19. package/dist/commands/application-log-command.js +39 -3
  20. package/dist/commands/clear-command.d.ts +1 -0
  21. package/dist/commands/clear-command.d.ts.map +1 -0
  22. package/dist/commands/clear-command.js +10 -3
  23. package/dist/commands/compact-command.d.ts +1 -0
  24. package/dist/commands/compact-command.d.ts.map +1 -0
  25. package/dist/commands/compact-command.js +16 -3
  26. package/dist/commands/context-command.d.ts +3 -0
  27. package/dist/commands/context-command.d.ts.map +1 -0
  28. package/dist/commands/context-command.js +183 -0
  29. package/dist/commands/copy-command.d.ts +1 -0
  30. package/dist/commands/copy-command.d.ts.map +1 -0
  31. package/dist/commands/copy-command.js +31 -2
  32. package/dist/commands/edit-command.d.ts +1 -0
  33. package/dist/commands/edit-command.d.ts.map +1 -0
  34. package/dist/commands/edit-command.js +40 -5
  35. package/dist/commands/edit-prompt-command.d.ts +2 -1
  36. package/dist/commands/edit-prompt-command.d.ts.map +1 -0
  37. package/dist/commands/edit-prompt-command.js +43 -7
  38. package/dist/commands/exit-command.d.ts +13 -2
  39. package/dist/commands/exit-command.d.ts.map +1 -0
  40. package/dist/commands/exit-command.js +34 -2
  41. package/dist/commands/files-command.d.ts +1 -0
  42. package/dist/commands/files-command.d.ts.map +1 -0
  43. package/dist/commands/files-command.js +66 -8
  44. package/dist/commands/generate-rules-command.d.ts +1 -0
  45. package/dist/commands/generate-rules-command.d.ts.map +1 -0
  46. package/dist/commands/generate-rules-command.js +315 -4
  47. package/dist/commands/handoff-command.d.ts +3 -0
  48. package/dist/commands/handoff-command.d.ts.map +1 -0
  49. package/dist/commands/handoff-command.js +202 -0
  50. package/dist/commands/health-command.d.ts +3 -1
  51. package/dist/commands/health-command.d.ts.map +1 -0
  52. package/dist/commands/health-command.js +160 -6
  53. package/dist/commands/help-command.d.ts +1 -0
  54. package/dist/commands/help-command.d.ts.map +1 -0
  55. package/dist/commands/help-command.js +30 -3
  56. package/dist/commands/history-command.d.ts +3 -0
  57. package/dist/commands/history-command.d.ts.map +1 -0
  58. package/dist/commands/history-command.js +534 -0
  59. package/dist/commands/init-command.d.ts +2 -1
  60. package/dist/commands/init-command.d.ts.map +1 -0
  61. package/dist/commands/init-command.js +56 -20
  62. package/dist/commands/last-log-command.d.ts +1 -0
  63. package/dist/commands/last-log-command.d.ts.map +1 -0
  64. package/dist/commands/last-log-command.js +39 -17
  65. package/dist/commands/list-directories-command.d.ts +3 -0
  66. package/dist/commands/list-directories-command.d.ts.map +1 -0
  67. package/dist/commands/list-directories-command.js +48 -0
  68. package/dist/commands/list-tools-command.d.ts +3 -0
  69. package/dist/commands/list-tools-command.d.ts.map +1 -0
  70. package/dist/commands/list-tools-command.js +124 -0
  71. package/dist/commands/manager.d.ts +20 -3
  72. package/dist/commands/manager.d.ts.map +1 -0
  73. package/dist/commands/manager.js +123 -26
  74. package/dist/commands/model-command.d.ts +23 -0
  75. package/dist/commands/model-command.d.ts.map +1 -0
  76. package/dist/commands/model-command.js +261 -5
  77. package/dist/commands/paste-command.d.ts +1 -0
  78. package/dist/commands/paste-command.d.ts.map +1 -0
  79. package/dist/commands/paste-command.js +98 -5
  80. package/dist/commands/pickup-command.d.ts +3 -0
  81. package/dist/commands/pickup-command.d.ts.map +1 -0
  82. package/dist/commands/pickup-command.js +161 -0
  83. package/dist/commands/prompt-command.d.ts +2 -1
  84. package/dist/commands/prompt-command.d.ts.map +1 -0
  85. package/dist/commands/prompt-command.js +178 -9
  86. package/dist/commands/remove-directory-command.d.ts +3 -0
  87. package/dist/commands/remove-directory-command.d.ts.map +1 -0
  88. package/dist/commands/remove-directory-command.js +87 -0
  89. package/dist/commands/reset-command.d.ts +2 -1
  90. package/dist/commands/reset-command.d.ts.map +1 -0
  91. package/dist/commands/reset-command.js +14 -3
  92. package/dist/commands/rules-command.d.ts +1 -0
  93. package/dist/commands/rules-command.d.ts.map +1 -0
  94. package/dist/commands/rules-command.js +70 -3
  95. package/dist/commands/save-command.d.ts +1 -0
  96. package/dist/commands/save-command.d.ts.map +1 -0
  97. package/dist/commands/save-command.js +13 -1
  98. package/dist/commands/shell-command.d.ts +3 -0
  99. package/dist/commands/shell-command.d.ts.map +1 -0
  100. package/dist/commands/shell-command.js +128 -0
  101. package/dist/commands/types.d.ts +16 -8
  102. package/dist/commands/types.d.ts.map +1 -0
  103. package/dist/commands/usage-command.d.ts +1 -0
  104. package/dist/commands/usage-command.d.ts.map +1 -0
  105. package/dist/commands/usage-command.js +24 -3
  106. package/dist/config.d.ts +21 -34
  107. package/dist/config.d.ts.map +1 -0
  108. package/dist/config.js +55 -15
  109. package/dist/dedent.d.ts +1 -0
  110. package/dist/dedent.d.ts.map +1 -0
  111. package/dist/execution/index.d.ts +112 -0
  112. package/dist/execution/index.d.ts.map +1 -0
  113. package/dist/execution/index.js +432 -0
  114. package/dist/formatting.d.ts +107 -10
  115. package/dist/formatting.d.ts.map +1 -0
  116. package/dist/formatting.js +150 -62
  117. package/dist/index.d.ts +8 -2
  118. package/dist/index.d.ts.map +1 -0
  119. package/dist/index.js +150 -38
  120. package/dist/logger.d.ts +1 -0
  121. package/dist/logger.d.ts.map +1 -0
  122. package/dist/logger.js +47 -18
  123. package/dist/mentions.d.ts +6 -1
  124. package/dist/mentions.d.ts.map +1 -0
  125. package/dist/mentions.js +58 -11
  126. package/dist/messages.d.ts +16 -20
  127. package/dist/messages.d.ts.map +1 -0
  128. package/dist/messages.js +89 -72
  129. package/dist/middleware/audit-message.d.ts +1 -0
  130. package/dist/middleware/audit-message.d.ts.map +1 -0
  131. package/dist/middleware/cache.d.ts +3 -0
  132. package/dist/middleware/cache.d.ts.map +1 -0
  133. package/dist/middleware/cache.js +53 -0
  134. package/dist/middleware/index.d.ts +2 -0
  135. package/dist/middleware/index.d.ts.map +1 -0
  136. package/dist/middleware/index.js +1 -0
  137. package/dist/middleware/rate-limit.d.ts +1 -0
  138. package/dist/middleware/rate-limit.d.ts.map +1 -0
  139. package/dist/models/ai-config.d.ts +5 -2
  140. package/dist/models/ai-config.d.ts.map +1 -0
  141. package/dist/models/ai-config.js +12 -2
  142. package/dist/models/anthropic-provider.d.ts +1 -0
  143. package/dist/models/anthropic-provider.d.ts.map +1 -0
  144. package/dist/models/anthropic-provider.js +3 -60
  145. package/dist/models/deepseek-provider.d.ts +1 -0
  146. package/dist/models/deepseek-provider.d.ts.map +1 -0
  147. package/dist/models/google-provider.d.ts +1 -0
  148. package/dist/models/google-provider.d.ts.map +1 -0
  149. package/dist/models/groq-provider.d.ts +20 -0
  150. package/dist/models/groq-provider.d.ts.map +1 -0
  151. package/dist/models/groq-provider.js +31 -0
  152. package/dist/models/manager.d.ts +3 -1
  153. package/dist/models/manager.d.ts.map +1 -0
  154. package/dist/models/manager.js +26 -2
  155. package/dist/models/openai-provider.d.ts +2 -1
  156. package/dist/models/openai-provider.d.ts.map +1 -0
  157. package/dist/models/openrouter-provider.d.ts +25 -23
  158. package/dist/models/openrouter-provider.d.ts.map +1 -0
  159. package/dist/models/openrouter-provider.js +181 -122
  160. package/dist/models/providers.d.ts +4 -5
  161. package/dist/models/providers.d.ts.map +1 -0
  162. package/dist/models/providers.js +7 -3
  163. package/dist/models/xai-provider.d.ts +1 -0
  164. package/dist/models/xai-provider.d.ts.map +1 -0
  165. package/dist/parsing.d.ts +2 -1
  166. package/dist/parsing.d.ts.map +1 -0
  167. package/dist/prompts/manager.d.ts +14 -2
  168. package/dist/prompts/manager.d.ts.map +1 -0
  169. package/dist/prompts.d.ts +2 -0
  170. package/dist/prompts.d.ts.map +1 -0
  171. package/dist/prompts.js +65 -12
  172. package/dist/repl/display-tool-messages.d.ts +4 -0
  173. package/dist/repl/display-tool-messages.d.ts.map +1 -0
  174. package/dist/repl/display-tool-messages.js +58 -0
  175. package/dist/repl/display-tool-use.d.ts +14 -0
  176. package/dist/repl/display-tool-use.d.ts.map +1 -0
  177. package/dist/repl/display-tool-use.js +63 -0
  178. package/dist/repl/get-prompt-header.d.ts +8 -0
  179. package/dist/repl/get-prompt-header.d.ts.map +1 -0
  180. package/dist/repl/get-prompt-header.js +9 -0
  181. package/dist/repl/project-status-line.d.ts +2 -0
  182. package/dist/repl/project-status-line.d.ts.map +1 -0
  183. package/dist/repl/project-status-line.js +31 -0
  184. package/dist/repl/prompt.d.ts +21 -0
  185. package/dist/repl/prompt.d.ts.map +1 -0
  186. package/dist/{repl-prompt.js → repl/prompt.js} +119 -22
  187. package/dist/repl/tool-call-repair.d.ts +4 -0
  188. package/dist/repl/tool-call-repair.d.ts.map +1 -0
  189. package/dist/repl/tool-call-repair.js +54 -0
  190. package/dist/repl-new.d.ts +53 -0
  191. package/dist/repl-new.d.ts.map +1 -0
  192. package/dist/repl-new.js +374 -0
  193. package/dist/repl.d.ts +9 -7
  194. package/dist/repl.d.ts.map +1 -0
  195. package/dist/repl.js +142 -378
  196. package/dist/terminal/ansi-styles.d.ts +77 -0
  197. package/dist/terminal/ansi-styles.d.ts.map +1 -0
  198. package/dist/terminal/ansi-styles.js +215 -0
  199. package/dist/terminal/checkbox-prompt.d.ts +36 -0
  200. package/dist/terminal/checkbox-prompt.d.ts.map +1 -0
  201. package/dist/terminal/checkbox-prompt.js +368 -0
  202. package/dist/terminal/default-theme.d.ts +6 -0
  203. package/dist/terminal/default-theme.d.ts.map +1 -0
  204. package/dist/terminal/default-theme.js +182 -0
  205. package/dist/terminal/east-asian-width.d.ts +8 -0
  206. package/dist/terminal/east-asian-width.d.ts.map +1 -0
  207. package/dist/terminal/east-asian-width.js +409 -0
  208. package/dist/terminal/editor-prompt.d.ts +10 -0
  209. package/dist/terminal/editor-prompt.d.ts.map +1 -0
  210. package/dist/terminal/editor-prompt.js +61 -0
  211. package/dist/terminal/errors.d.ts +19 -0
  212. package/dist/terminal/errors.d.ts.map +1 -0
  213. package/dist/terminal/errors.js +37 -0
  214. package/dist/terminal/formatting.d.ts +1 -11
  215. package/dist/terminal/formatting.d.ts.map +1 -0
  216. package/dist/terminal/formatting.js +4 -20
  217. package/dist/terminal/highlight/index.d.ts +53 -0
  218. package/dist/terminal/highlight/index.d.ts.map +1 -0
  219. package/dist/terminal/highlight/index.js +90 -0
  220. package/dist/terminal/highlight/theme.d.ts +233 -0
  221. package/dist/terminal/highlight/theme.d.ts.map +1 -0
  222. package/dist/terminal/highlight/theme.js +83 -0
  223. package/dist/terminal/index.d.ts +23 -9
  224. package/dist/terminal/index.d.ts.map +1 -0
  225. package/dist/terminal/index.js +136 -126
  226. package/dist/terminal/input-prompt.d.ts +17 -0
  227. package/dist/terminal/input-prompt.d.ts.map +1 -0
  228. package/dist/terminal/input-prompt.js +181 -0
  229. package/dist/terminal/markdown-utils.d.ts +1 -0
  230. package/dist/terminal/markdown-utils.d.ts.map +1 -0
  231. package/dist/terminal/markdown.d.ts +1 -0
  232. package/dist/terminal/markdown.d.ts.map +1 -0
  233. package/dist/terminal/markdown.js +20 -12
  234. package/dist/terminal/search-prompt.d.ts +20 -0
  235. package/dist/terminal/search-prompt.d.ts.map +1 -0
  236. package/dist/terminal/search-prompt.js +280 -0
  237. package/dist/terminal/select-prompt.d.ts +26 -0
  238. package/dist/terminal/select-prompt.d.ts.map +1 -0
  239. package/dist/terminal/select-prompt.js +306 -0
  240. package/dist/terminal/string-width.d.ts +7 -0
  241. package/dist/terminal/string-width.d.ts.map +1 -0
  242. package/dist/terminal/string-width.js +61 -0
  243. package/dist/terminal/strip-ansi.d.ts +2 -0
  244. package/dist/terminal/strip-ansi.d.ts.map +1 -0
  245. package/dist/terminal/strip-ansi.js +20 -0
  246. package/dist/terminal/style.d.ts +191 -0
  247. package/dist/terminal/style.d.ts.map +1 -0
  248. package/dist/terminal/style.js +259 -0
  249. package/dist/terminal/supports-color.d.ts +1 -0
  250. package/dist/terminal/supports-color.d.ts.map +1 -0
  251. package/dist/terminal/supports-hyperlinks.d.ts +1 -3
  252. package/dist/terminal/supports-hyperlinks.d.ts.map +1 -0
  253. package/dist/terminal/supports-hyperlinks.js +1 -1
  254. package/dist/terminal/types.d.ts +1 -37
  255. package/dist/terminal/types.d.ts.map +1 -0
  256. package/dist/terminal/wrap-ansi.d.ts +8 -0
  257. package/dist/terminal/wrap-ansi.d.ts.map +1 -0
  258. package/dist/terminal/wrap-ansi.js +190 -0
  259. package/dist/{token-utils.d.ts → tokens/counter.d.ts} +1 -0
  260. package/dist/tokens/counter.d.ts.map +1 -0
  261. package/dist/{token-utils.js → tokens/counter.js} +1 -1
  262. package/dist/tokens/threshold.d.ts +35 -0
  263. package/dist/tokens/threshold.d.ts.map +1 -0
  264. package/dist/tokens/threshold.js +85 -0
  265. package/dist/{token-tracker.d.ts → tokens/tracker.d.ts} +1 -0
  266. package/dist/tokens/tracker.d.ts.map +1 -0
  267. package/dist/tools/advanced-edit-file.d.ts +69 -0
  268. package/dist/tools/advanced-edit-file.d.ts.map +1 -0
  269. package/dist/tools/advanced-edit-file.js +281 -0
  270. package/dist/tools/agent.d.ts +19 -7
  271. package/dist/tools/agent.d.ts.map +1 -0
  272. package/dist/tools/agent.js +70 -54
  273. package/dist/tools/bash-utils.d.ts +7 -0
  274. package/dist/tools/bash-utils.d.ts.map +1 -0
  275. package/dist/tools/bash-utils.js +220 -0
  276. package/dist/tools/bash.d.ts +25 -14
  277. package/dist/tools/bash.d.ts.map +1 -0
  278. package/dist/tools/bash.js +87 -251
  279. package/dist/tools/code-interpreter.d.ts +22 -10
  280. package/dist/tools/code-interpreter.d.ts.map +1 -0
  281. package/dist/tools/code-interpreter.js +146 -210
  282. package/dist/tools/delete-file.d.ts +18 -9
  283. package/dist/tools/delete-file.d.ts.map +1 -0
  284. package/dist/tools/delete-file.js +55 -85
  285. package/dist/tools/directory-tree.d.ts +26 -6
  286. package/dist/tools/directory-tree.d.ts.map +1 -0
  287. package/dist/tools/directory-tree.js +109 -28
  288. package/dist/tools/dynamic-tool-loader.d.ts +22 -0
  289. package/dist/tools/dynamic-tool-loader.d.ts.map +1 -0
  290. package/dist/tools/dynamic-tool-loader.js +272 -0
  291. package/dist/tools/dynamic-tool-parser.d.ts +21 -0
  292. package/dist/tools/dynamic-tool-parser.d.ts.map +1 -0
  293. package/dist/tools/dynamic-tool-parser.js +22 -0
  294. package/dist/tools/edit-file.d.ts +41 -13
  295. package/dist/tools/edit-file.d.ts.map +1 -0
  296. package/dist/tools/edit-file.js +173 -96
  297. package/dist/tools/filesystem-utils.d.ts +7 -21
  298. package/dist/tools/filesystem-utils.d.ts.map +1 -0
  299. package/dist/tools/filesystem-utils.js +111 -149
  300. package/dist/tools/git-utils.d.ts +1 -0
  301. package/dist/tools/git-utils.d.ts.map +1 -0
  302. package/dist/tools/glob.d.ts +36 -0
  303. package/dist/tools/glob.d.ts.map +1 -0
  304. package/dist/tools/glob.js +143 -0
  305. package/dist/tools/grep.d.ts +76 -13
  306. package/dist/tools/grep.d.ts.map +1 -0
  307. package/dist/tools/grep.js +420 -135
  308. package/dist/tools/index.d.ts +207 -133
  309. package/dist/tools/index.d.ts.map +1 -0
  310. package/dist/tools/index.js +245 -127
  311. package/dist/tools/llm-edit-fixer.d.ts +25 -0
  312. package/dist/tools/llm-edit-fixer.d.ts.map +1 -0
  313. package/dist/tools/llm-edit-fixer.js +150 -0
  314. package/dist/tools/move-file.d.ts +20 -7
  315. package/dist/tools/move-file.d.ts.map +1 -0
  316. package/dist/tools/move-file.js +43 -29
  317. package/dist/tools/read-file.d.ts +49 -10
  318. package/dist/tools/read-file.d.ts.map +1 -0
  319. package/dist/tools/read-file.js +79 -67
  320. package/dist/tools/read-multiple-files.d.ts +19 -7
  321. package/dist/tools/read-multiple-files.d.ts.map +1 -0
  322. package/dist/tools/read-multiple-files.js +117 -33
  323. package/dist/tools/save-file.d.ts +46 -11
  324. package/dist/tools/save-file.d.ts.map +1 -0
  325. package/dist/tools/save-file.js +63 -78
  326. package/dist/tools/think.d.ts +16 -7
  327. package/dist/tools/think.d.ts.map +1 -0
  328. package/dist/tools/think.js +34 -22
  329. package/dist/tools/types.d.ts +18 -11
  330. package/dist/tools/types.d.ts.map +1 -0
  331. package/dist/tools/types.js +9 -0
  332. package/dist/tools/utils.d.ts +14 -0
  333. package/dist/tools/utils.d.ts.map +1 -0
  334. package/dist/tools/utils.js +16 -0
  335. package/dist/tools/web-fetch.d.ts +15 -6
  336. package/dist/tools/web-fetch.d.ts.map +1 -0
  337. package/dist/tools/web-fetch.js +40 -39
  338. package/dist/tools/web-search.d.ts +17 -7
  339. package/dist/tools/web-search.d.ts.map +1 -0
  340. package/dist/tools/web-search.js +86 -33
  341. package/dist/tui/autocomplete.d.ts +44 -0
  342. package/dist/tui/autocomplete.d.ts.map +1 -0
  343. package/dist/tui/autocomplete.js +466 -0
  344. package/dist/tui/components/assistant-message.d.ts +18 -0
  345. package/dist/tui/components/assistant-message.d.ts.map +1 -0
  346. package/dist/tui/components/assistant-message.js +29 -0
  347. package/dist/tui/components/editor.d.ts +51 -0
  348. package/dist/tui/components/editor.d.ts.map +1 -0
  349. package/dist/tui/components/editor.js +758 -0
  350. package/dist/tui/components/footer.d.ts +24 -0
  351. package/dist/tui/components/footer.d.ts.map +1 -0
  352. package/dist/tui/components/footer.js +197 -0
  353. package/dist/tui/components/input.d.ts +14 -0
  354. package/dist/tui/components/input.d.ts.map +1 -0
  355. package/dist/tui/components/input.js +122 -0
  356. package/dist/tui/components/loader.d.ts +19 -0
  357. package/dist/tui/components/loader.d.ts.map +1 -0
  358. package/dist/tui/components/loader.js +45 -0
  359. package/dist/tui/components/markdown.d.ts +103 -0
  360. package/dist/tui/components/markdown.d.ts.map +1 -0
  361. package/dist/tui/components/markdown.js +533 -0
  362. package/dist/tui/components/modal.d.ts +40 -0
  363. package/dist/tui/components/modal.d.ts.map +1 -0
  364. package/dist/tui/components/modal.js +292 -0
  365. package/dist/tui/components/prompt-status.d.ts +16 -0
  366. package/dist/tui/components/prompt-status.d.ts.map +1 -0
  367. package/dist/tui/components/prompt-status.js +21 -0
  368. package/dist/tui/components/select-list.d.ts +22 -0
  369. package/dist/tui/components/select-list.d.ts.map +1 -0
  370. package/dist/tui/components/select-list.js +143 -0
  371. package/dist/tui/components/spacer.d.ts +16 -0
  372. package/dist/tui/components/spacer.d.ts.map +1 -0
  373. package/dist/tui/components/spacer.js +27 -0
  374. package/dist/tui/components/text.d.ts +26 -0
  375. package/dist/tui/components/text.d.ts.map +1 -0
  376. package/dist/tui/components/text.js +143 -0
  377. package/dist/tui/components/thinking-block.d.ts +14 -0
  378. package/dist/tui/components/thinking-block.d.ts.map +1 -0
  379. package/dist/tui/components/thinking-block.js +30 -0
  380. package/dist/tui/components/tool-execution.d.ts +17 -0
  381. package/dist/tui/components/tool-execution.d.ts.map +1 -0
  382. package/dist/tui/components/tool-execution.js +153 -0
  383. package/dist/tui/components/user-message.d.ts +9 -0
  384. package/dist/tui/components/user-message.d.ts.map +1 -0
  385. package/dist/tui/components/user-message.js +21 -0
  386. package/dist/tui/components/welcome.d.ts +6 -0
  387. package/dist/tui/components/welcome.d.ts.map +1 -0
  388. package/dist/tui/components/welcome.js +30 -0
  389. package/dist/tui/index.d.ts +14 -0
  390. package/dist/tui/index.d.ts.map +1 -0
  391. package/dist/tui/index.js +18 -0
  392. package/dist/tui/terminal.d.ts +37 -0
  393. package/dist/tui/terminal.d.ts.map +1 -0
  394. package/dist/tui/terminal.js +104 -0
  395. package/dist/tui/tui.d.ts +67 -0
  396. package/dist/tui/tui.d.ts.map +1 -0
  397. package/dist/tui/tui.js +184 -0
  398. package/dist/tui/utils.d.ts +19 -0
  399. package/dist/tui/utils.d.ts.map +1 -0
  400. package/dist/tui/utils.js +31 -0
  401. package/dist/utils/filesystem.d.ts +23 -0
  402. package/dist/utils/filesystem.d.ts.map +1 -0
  403. package/dist/utils/filesystem.js +140 -0
  404. package/dist/utils/filetype-detection.d.ts +3 -0
  405. package/dist/utils/filetype-detection.d.ts.map +1 -0
  406. package/dist/utils/filetype-detection.js +112 -0
  407. package/dist/utils/generators.d.ts +3 -0
  408. package/dist/utils/generators.d.ts.map +1 -0
  409. package/dist/utils/generators.js +25 -0
  410. package/dist/utils/glob.d.ts +52 -0
  411. package/dist/utils/glob.d.ts.map +1 -0
  412. package/dist/utils/glob.js +376 -0
  413. package/dist/utils/ignore.d.ts +104 -0
  414. package/dist/utils/ignore.d.ts.map +1 -0
  415. package/dist/utils/ignore.js +649 -0
  416. package/dist/utils/iterables.d.ts +2 -0
  417. package/dist/utils/iterables.d.ts.map +1 -0
  418. package/dist/utils/iterables.js +6 -0
  419. package/dist/utils/process.d.ts +3 -2
  420. package/dist/utils/process.d.ts.map +1 -0
  421. package/dist/utils/process.js +17 -2
  422. package/dist/utils/zod-utils.d.ts +4 -0
  423. package/dist/utils/zod-utils.d.ts.map +1 -0
  424. package/dist/utils/zod-utils.js +7 -0
  425. package/dist/version.d.ts +1 -0
  426. package/dist/version.d.ts.map +1 -0
  427. package/package.json +34 -32
  428. package/dist/conversation-analyzer.d.ts +0 -10
  429. package/dist/conversation-analyzer.js +0 -88
  430. package/dist/repl-prompt.d.ts +0 -14
  431. package/dist/tools/command-validation.d.ts +0 -11
  432. package/dist/tools/command-validation.js +0 -45
  433. /package/dist/{token-tracker.js → tokens/tracker.js} +0 -0
@@ -1,44 +1,58 @@
1
1
  import fs from "node:fs/promises";
2
- import { tool } from "ai";
3
- import chalk from "chalk";
4
2
  import { z } from "zod";
3
+ import style from "../terminal/style.js";
5
4
  import { joinWorkingDir, validatePath } from "./filesystem-utils.js";
6
5
  export const MoveFileTool = {
7
6
  name: "moveFile",
8
7
  };
9
- export const createMoveFileTool = async ({ workingDir, sendData, }) => {
10
- const allowedDirectory = workingDir;
8
+ const inputSchema = z.object({
9
+ source: z.string(),
10
+ destination: z.string(),
11
+ });
12
+ export const createMoveFileTool = async ({ workingDir, allowedDirs, }) => {
13
+ const allowedDirectory = allowedDirs ?? [workingDir];
11
14
  return {
12
- [MoveFileTool.name]: tool({
15
+ toolDef: {
13
16
  description: "Move or rename files and directories. Can move files between directories " +
14
17
  "and rename them in a single operation. If the destination exists, the " +
15
18
  "operation will fail. Works across different directories and can be used " +
16
19
  "for simple renaming within the same directory. Both source and destination must be within allowed directories.",
17
- inputSchema: z.object({
18
- source: z.string(),
19
- destination: z.string(),
20
- }),
21
- execute: async ({ source, destination }, { toolCallId }) => {
22
- try {
23
- sendData?.({
24
- id: toolCallId,
25
- event: "tool-init",
26
- data: `Moving file from ${chalk.cyan(source)} to ${chalk.cyan(destination)}`,
27
- });
28
- const validSourcePath = await validatePath(joinWorkingDir(source, workingDir), allowedDirectory);
29
- const validDestPath = await validatePath(joinWorkingDir(destination, workingDir), allowedDirectory);
30
- await fs.rename(validSourcePath, validDestPath);
31
- sendData?.({
32
- id: toolCallId,
33
- event: "tool-completion",
34
- data: "Done",
35
- });
36
- return `Successfully moved ${source} to ${destination}`;
20
+ inputSchema,
21
+ },
22
+ async *execute({ source, destination }, { toolCallId, abortSignal }) {
23
+ try {
24
+ if (abortSignal?.aborted) {
25
+ throw new Error("File move aborted");
37
26
  }
38
- catch (error) {
39
- return `Failed to move file: ${error.message}`;
27
+ yield {
28
+ name: MoveFileTool.name,
29
+ id: toolCallId,
30
+ event: "tool-init",
31
+ data: `${style.cyan(source)} => ${style.cyan(destination)}`,
32
+ };
33
+ const validSourcePath = await validatePath(joinWorkingDir(source, workingDir), allowedDirectory, { abortSignal });
34
+ const validDestPath = await validatePath(joinWorkingDir(destination, workingDir), allowedDirectory, { requireExistence: false, abortSignal });
35
+ if (abortSignal?.aborted) {
36
+ throw new Error("File move aborted before file operation");
40
37
  }
41
- },
42
- }),
38
+ await fs.rename(validSourcePath, validDestPath);
39
+ yield {
40
+ name: MoveFileTool.name,
41
+ id: toolCallId,
42
+ event: "tool-completion",
43
+ data: "File moved",
44
+ };
45
+ yield `Successfully moved ${source} to ${destination}`;
46
+ }
47
+ catch (error) {
48
+ yield {
49
+ name: MoveFileTool.name,
50
+ event: "tool-error",
51
+ id: toolCallId,
52
+ data: error.message,
53
+ };
54
+ yield `Failed to move file: ${error.message}`;
55
+ }
56
+ },
43
57
  };
44
58
  };
@@ -1,17 +1,56 @@
1
- import type { TokenCounter } from "../token-utils.ts";
2
- import type { SendData } from "./types.ts";
1
+ import type { ToolCallOptions } from "ai";
2
+ import { z } from "zod";
3
+ import type { TokenCounter } from "../tokens/counter.ts";
4
+ import type { ToolResult } from "./types.ts";
3
5
  export declare const ReadFileTool: {
4
6
  name: "readFile";
5
7
  };
6
- export declare const createReadFileTool: ({ workingDir, sendData, tokenCounter, }: {
8
+ declare const inputSchema: z.ZodObject<{
9
+ path: z.ZodString;
10
+ encoding: z.ZodEnum<{
11
+ utf8: "utf8";
12
+ ascii: "ascii";
13
+ "utf-8": "utf-8";
14
+ utf16le: "utf16le";
15
+ ucs2: "ucs2";
16
+ "ucs-2": "ucs-2";
17
+ base64: "base64";
18
+ base64url: "base64url";
19
+ latin1: "latin1";
20
+ binary: "binary";
21
+ hex: "hex";
22
+ }>;
23
+ startLine: z.ZodNullable<z.ZodCoercedNumber<unknown>>;
24
+ lineCount: z.ZodNullable<z.ZodCoercedNumber<unknown>>;
25
+ }, z.core.$strip>;
26
+ type ReadFileInputSchema = z.infer<typeof inputSchema>;
27
+ export declare const createReadFileTool: ({ workingDir, allowedDirs, tokenCounter, }: {
7
28
  workingDir: string;
8
- sendData?: SendData;
29
+ allowedDirs?: string[];
9
30
  tokenCounter: TokenCounter;
10
31
  }) => Promise<{
11
- readFile: import("ai").Tool<{
12
- path: string;
13
- encoding: "utf8" | "ascii" | "utf-8" | "utf16le" | "ucs2" | "ucs-2" | "base64" | "base64url" | "latin1" | "binary" | "hex";
14
- startLine: number | null;
15
- lineCount: number | null;
16
- }, string>;
32
+ toolDef: {
33
+ description: string;
34
+ inputSchema: z.ZodObject<{
35
+ path: z.ZodString;
36
+ encoding: z.ZodEnum<{
37
+ utf8: "utf8";
38
+ ascii: "ascii";
39
+ "utf-8": "utf-8";
40
+ utf16le: "utf16le";
41
+ ucs2: "ucs2";
42
+ "ucs-2": "ucs-2";
43
+ base64: "base64";
44
+ base64url: "base64url";
45
+ latin1: "latin1";
46
+ binary: "binary";
47
+ hex: "hex";
48
+ }>;
49
+ startLine: z.ZodNullable<z.ZodCoercedNumber<unknown>>;
50
+ lineCount: z.ZodNullable<z.ZodCoercedNumber<unknown>>;
51
+ }, z.core.$strip>;
52
+ };
53
+ execute({ path: providedPath, encoding, startLine, lineCount, }: ReadFileInputSchema, { toolCallId, abortSignal }: ToolCallOptions): AsyncGenerator<ToolResult>;
17
54
  }>;
55
+ export {};
56
+ //# sourceMappingURL=read-file.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"read-file.d.ts","sourceRoot":"","sources":["../../source/tools/read-file.ts"],"names":[],"mappings":"AAEA,OAAO,KAAK,EAAE,eAAe,EAAE,MAAM,IAAI,CAAC;AAC1C,OAAO,EAAE,CAAC,EAAE,MAAM,KAAK,CAAC;AAExB,OAAO,KAAK,EAAE,YAAY,EAAE,MAAM,sBAAsB,CAAC;AAGzD,OAAO,KAAK,EAAE,UAAU,EAAE,MAAM,YAAY,CAAC;AAG7C,eAAO,MAAM,YAAY;;CAExB,CAAC;AAEF,QAAA,MAAM,WAAW;;;;;;;;;;;;;;;;;iBAef,CAAC;AAEH,KAAK,mBAAmB,GAAG,CAAC,CAAC,KAAK,CAAC,OAAO,WAAW,CAAC,CAAC;AAEvD,eAAO,MAAM,kBAAkB,GAAU,4CAItC;IACD,UAAU,EAAE,MAAM,CAAC;IACnB,WAAW,CAAC,EAAE,MAAM,EAAE,CAAC;IACvB,YAAY,EAAE,YAAY,CAAC;CAC5B;;;;;;;;;;;;;;;;;;;;;;qEAiBQ,mBAAmB,+BACO,eAAe,GAC3C,cAAc,CAAC,UAAU,CAAC;EAoFhC,CAAC"}
@@ -1,86 +1,98 @@
1
1
  import fs from "node:fs/promises";
2
2
  import { isNumber } from "@travisennis/stdlib/typeguards";
3
- import { tool } from "ai";
4
- import chalk from "chalk";
5
3
  import { z } from "zod";
6
- import { config } from "../config.js";
4
+ import style from "../terminal/style.js";
5
+ import { manageTokenLimit } from "../tokens/threshold.js";
7
6
  import { joinWorkingDir, validatePath } from "./filesystem-utils.js";
8
7
  import { fileEncodingSchema } from "./types.js";
9
8
  export const ReadFileTool = {
10
9
  name: "readFile",
11
10
  };
12
- export const createReadFileTool = async ({ workingDir, sendData, tokenCounter, }) => {
13
- const allowedDirectory = workingDir;
11
+ const inputSchema = z.object({
12
+ path: z.string().describe("Absolute path to file to read"),
13
+ encoding: fileEncodingSchema.describe('Encoding format for reading the file. Use "utf-8" as default for text files'),
14
+ startLine: z.coerce
15
+ .number()
16
+ .nullable()
17
+ .describe("1-based line number to start reading from. Pass null to start at beginning of file"),
18
+ lineCount: z.coerce
19
+ .number()
20
+ .nullable()
21
+ .describe("Maximum number of lines to read. Pass null to get all lines."),
22
+ });
23
+ export const createReadFileTool = async ({ workingDir, allowedDirs, tokenCounter, }) => {
24
+ const allowedDirectory = allowedDirs ?? [workingDir];
14
25
  return {
15
- [ReadFileTool.name]: tool({
26
+ toolDef: {
16
27
  description: "Read the complete contents of a file from the file system unless startLine and lineCount are given to read a file selection. " +
17
28
  "Handles various text encodings and provides detailed error messages " +
18
29
  "if the file cannot be read. Use this tool when you need to examine " +
19
30
  "the contents of a single file. Only works within allowed directories.",
20
- inputSchema: z.object({
21
- path: z.string().describe("Absolute path to file to read"),
22
- encoding: fileEncodingSchema.describe('Encoding format for reading the file. Use "utf-8" as default for text files'),
23
- startLine: z
24
- .number()
25
- .nullable()
26
- .describe("1-based line number to start reading from. Pass null to start at beginning of file"),
27
- lineCount: z
28
- .number()
29
- .nullable()
30
- .describe("Maximum number of lines to read. Pass null to get all lines."),
31
- }),
32
- execute: async ({ path: providedPath, encoding, startLine, lineCount, }, { toolCallId }) => {
33
- sendData?.({
31
+ inputSchema,
32
+ },
33
+ async *execute({ path: providedPath, encoding, startLine, lineCount, }, { toolCallId, abortSignal }) {
34
+ try {
35
+ // Check if execution has been aborted
36
+ if (abortSignal?.aborted) {
37
+ throw new Error("File reading aborted");
38
+ }
39
+ yield {
40
+ name: ReadFileTool.name,
34
41
  id: toolCallId,
35
42
  event: "tool-init",
36
- data: `Reading file: ${chalk.cyan(providedPath)}${startLine ? chalk.cyan(`:${startLine}`) : ""}${lineCount ? chalk.cyan(`:${lineCount}`) : ""}`,
37
- });
38
- try {
39
- const filePath = await validatePath(joinWorkingDir(providedPath, workingDir), allowedDirectory);
40
- let file = await fs.readFile(filePath, { encoding });
41
- // Apply line-based selection if requested
42
- if (isNumber(startLine) || isNumber(lineCount)) {
43
- const lines = file.split("\n");
44
- const totalLines = lines.length;
45
- const startIndex = (startLine ?? 1) - 1; // Default to start of file if only lineCount is given
46
- const count = lineCount ?? totalLines - startIndex; // Default to read all lines from start if only startLine is given
47
- if (startIndex < 0 || startIndex >= totalLines) {
48
- return `startLine ${startLine} is out of bounds for file with ${totalLines} lines.`;
49
- }
50
- const endIndex = Math.min(startIndex + count, totalLines);
51
- file = lines.slice(startIndex, endIndex).join("\n");
52
- }
53
- let tokenCount = 0;
54
- try {
55
- // Only calculate tokens for non-image files and if encoding is text-based
56
- if (encoding.startsWith("utf")) {
57
- tokenCount = tokenCounter.count(file);
58
- }
59
- }
60
- catch (tokenError) {
61
- console.error("Error calculating token count:", tokenError);
62
- // Log or handle error, but don't block file return
63
- }
64
- const maxTokens = (await config.readProjectConfig()).tools.maxTokens;
65
- // Adjust max token check message if line selection was used
66
- const maxTokenMessage = isNumber(startLine) || isNumber(lineCount)
67
- ? `Selected file content (${tokenCount} tokens) exceeds maximum allowed tokens (${maxTokens}). Consider adjusting startLine/lineCount or using grepFiles.`
68
- : `File content (${tokenCount} tokens) exceeds maximum allowed tokens (${maxTokens}). Please use startLine and lineCount parameters to read specific portions of the file, or using grepFiles to search for specific content.`;
69
- const result = tokenCount <= maxTokens ? file : maxTokenMessage;
70
- sendData?.({
71
- id: toolCallId,
72
- event: "tool-completion",
73
- // Include token count only if calculated (i.e., for text files)
74
- data: tokenCount <= maxTokens
75
- ? `File read successfully ${tokenCount > 0 ? ` (${tokenCount} tokens)` : ""}`
76
- : result,
77
- });
78
- return result;
43
+ data: `${style.cyan(providedPath)}${startLine ? style.cyan(`:${startLine}`) : ""}${lineCount ? style.cyan(`:${lineCount}`) : ""}`,
44
+ };
45
+ const filePath = await validatePath(joinWorkingDir(providedPath, workingDir), allowedDirectory, { abortSignal });
46
+ if (abortSignal?.aborted) {
47
+ throw new Error("File reading aborted before file read");
79
48
  }
80
- catch (error) {
81
- return `Failed to read file: ${error.message}`;
49
+ let file = await fs.readFile(filePath, { encoding });
50
+ // Apply line-based selection if requested
51
+ if (isNumber(startLine) || isNumber(lineCount)) {
52
+ const lines = file.split("\n");
53
+ const totalLines = lines.length;
54
+ const startIndex = (startLine ?? 1) - 1; // Default to start of file if only lineCount is given
55
+ const count = lineCount ?? totalLines - startIndex; // Default to read all lines from start if only startLine is given
56
+ if (startIndex < 0 || startIndex >= totalLines) {
57
+ const errorMsg = `startLine ${startLine} is out of bounds for file with ${totalLines} lines.`;
58
+ yield {
59
+ name: ReadFileTool.name,
60
+ event: "tool-error",
61
+ id: toolCallId,
62
+ data: errorMsg,
63
+ };
64
+ yield errorMsg;
65
+ return;
66
+ }
67
+ const endIndex = Math.min(startIndex + count, totalLines);
68
+ file = lines.slice(startIndex, endIndex).join("\n");
82
69
  }
83
- },
84
- }),
70
+ const result = await manageTokenLimit(file, tokenCounter, "ReadFile", isNumber(startLine) || isNumber(lineCount)
71
+ ? "Consider adjusting startLine/lineCount or using grepFiles"
72
+ : "Use startLine and lineCount parameters to read specific portions, or use grepFiles for targeted access", encoding);
73
+ // Calculate line count for the returned content
74
+ const linesRead = result.content.split("\n").length;
75
+ yield {
76
+ name: ReadFileTool.name,
77
+ id: toolCallId,
78
+ event: "tool-completion",
79
+ // Include success, line count, and token count
80
+ data: !result.truncated
81
+ ? `Read ${linesRead} lines (${result.tokenCount} tokens)`
82
+ : result.content,
83
+ };
84
+ yield result.content;
85
+ }
86
+ catch (error) {
87
+ const errorMsg = `${error.message}`;
88
+ yield {
89
+ name: ReadFileTool.name,
90
+ event: "tool-error",
91
+ id: toolCallId,
92
+ data: errorMsg,
93
+ };
94
+ yield errorMsg;
95
+ }
96
+ },
85
97
  };
86
98
  };
@@ -1,14 +1,26 @@
1
- import type { TokenCounter } from "../token-utils.ts";
2
- import type { SendData } from "./types.ts";
1
+ import type { ToolCallOptions } from "ai";
2
+ import { z } from "zod";
3
+ import type { TokenCounter } from "../tokens/counter.ts";
4
+ import type { ToolResult } from "./types.ts";
3
5
  export declare const ReadMultipleFilesTool: {
4
6
  name: "readMultipleFiles";
5
7
  };
6
- export declare const createReadMultipleFilesTool: ({ workingDir, sendData, tokenCounter, }: {
8
+ declare const inputSchema: z.ZodObject<{
9
+ paths: z.ZodArray<z.ZodString>;
10
+ }, z.core.$strip>;
11
+ type ReadMultipleFilesInputSchema = z.infer<typeof inputSchema>;
12
+ export declare const createReadMultipleFilesTool: ({ workingDir, allowedDirs, tokenCounter, }: {
7
13
  workingDir: string;
8
- sendData?: SendData;
14
+ allowedDirs?: string[];
9
15
  tokenCounter: TokenCounter;
10
16
  }) => Promise<{
11
- readMultipleFiles: import("ai").Tool<{
12
- paths: string[];
13
- }, string>;
17
+ toolDef: {
18
+ description: string;
19
+ inputSchema: z.ZodObject<{
20
+ paths: z.ZodArray<z.ZodString>;
21
+ }, z.core.$strip>;
22
+ };
23
+ execute({ paths }: ReadMultipleFilesInputSchema, { toolCallId, abortSignal }: ToolCallOptions): AsyncGenerator<ToolResult>;
14
24
  }>;
25
+ export {};
26
+ //# sourceMappingURL=read-multiple-files.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"read-multiple-files.d.ts","sourceRoot":"","sources":["../../source/tools/read-multiple-files.ts"],"names":[],"mappings":"AACA,OAAO,KAAK,EAAE,eAAe,EAAE,MAAM,IAAI,CAAC;AAC1C,OAAO,EAAE,CAAC,EAAE,MAAM,KAAK,CAAC;AAGxB,OAAO,KAAK,EAAE,YAAY,EAAE,MAAM,sBAAsB,CAAC;AAGzD,OAAO,KAAK,EAAE,UAAU,EAAE,MAAM,YAAY,CAAC;AAE7C,eAAO,MAAM,qBAAqB;;CAEjC,CAAC;AAEF,QAAA,MAAM,WAAW;;iBAEf,CAAC;AAEH,KAAK,4BAA4B,GAAG,CAAC,CAAC,KAAK,CAAC,OAAO,WAAW,CAAC,CAAC;AAEhE,eAAO,MAAM,2BAA2B,GAAU,4CAI/C;IACD,UAAU,EAAE,MAAM,CAAC;IACnB,WAAW,CAAC,EAAE,MAAM,EAAE,CAAC;IACvB,YAAY,EAAE,YAAY,CAAC;CAC5B;;;;;;;uBAcgB,4BAA4B,+BACV,eAAe,GAC3C,cAAc,CAAC,UAAU,CAAC;EAwIhC,CAAC"}
@@ -1,55 +1,139 @@
1
- import { tool } from "ai";
2
- import chalk from "chalk";
1
+ import { readFile } from "node:fs/promises";
3
2
  import { z } from "zod";
4
- import { config } from "../config.js";
5
- import { readFileAndCountTokens } from "./filesystem-utils.js";
3
+ import { formatFile } from "../formatting.js";
4
+ import style from "../terminal/style.js";
5
+ import { manageTokenLimit } from "../tokens/threshold.js";
6
+ import { joinWorkingDir, validatePath } from "./filesystem-utils.js";
6
7
  export const ReadMultipleFilesTool = {
7
8
  name: "readMultipleFiles",
8
9
  };
9
- export const createReadMultipleFilesTool = async ({ workingDir, sendData, tokenCounter, }) => {
10
- const allowedDirectory = workingDir;
10
+ const inputSchema = z.object({
11
+ paths: z.array(z.string()),
12
+ });
13
+ export const createReadMultipleFilesTool = async ({ workingDir, allowedDirs, tokenCounter, }) => {
14
+ const allowedDirectory = allowedDirs ?? [workingDir];
11
15
  return {
12
- [ReadMultipleFilesTool.name]: tool({
16
+ toolDef: {
13
17
  description: "Read the contents of multiple files simultaneously. This is more " +
14
18
  "efficient than reading files one by one when you need to analyze " +
15
19
  "or compare multiple files. Each file's content is returned with its " +
16
20
  "path as a reference. Failed reads for individual files won't stop " +
17
21
  "the entire operation. Only works within allowed directories.",
18
- inputSchema: z.object({
19
- paths: z.array(z.string()),
20
- }),
21
- execute: async ({ paths }, { toolCallId }) => {
22
- sendData?.({
22
+ inputSchema,
23
+ },
24
+ async *execute({ paths }, { toolCallId, abortSignal }) {
25
+ try {
26
+ // Check if execution has been aborted
27
+ if (abortSignal?.aborted) {
28
+ throw new Error("Multiple file reading aborted");
29
+ }
30
+ yield {
31
+ name: ReadMultipleFilesTool.name,
23
32
  id: toolCallId,
24
33
  event: "tool-init",
25
- data: `Reading files: ${paths.map((p) => chalk.cyan(p)).join(", ")}`,
26
- });
27
- const maxTokens = (await config.readProjectConfig()).tools.maxTokens;
28
- const results = await Promise.all(paths.map((filePath) => readFileAndCountTokens(filePath, workingDir, allowedDirectory, tokenCounter, maxTokens)));
34
+ data: `${paths.map((p) => style.cyan(p)).join(", ")}`,
35
+ };
36
+ if (abortSignal?.aborted) {
37
+ throw new Error("Multiple file reading aborted before reading files");
38
+ }
39
+ const results = await Promise.all(paths.map(async (filePath) => {
40
+ if (abortSignal?.aborted) {
41
+ throw new Error("Multiple file reading aborted during file processing");
42
+ }
43
+ const fileResult = await validateAndReadFile(filePath, workingDir, allowedDirectory);
44
+ return fileResult;
45
+ }));
46
+ const processedResults = await Promise.all(results.map(async (result) => {
47
+ if (result.error) {
48
+ return {
49
+ path: result.path,
50
+ content: `${result.path}: Error - ${result.error}`,
51
+ tokenCount: 0,
52
+ error: result.error,
53
+ truncated: false,
54
+ };
55
+ }
56
+ // Apply token limit check to each file
57
+ const managedResult = await manageTokenLimit(result.content ?? "", tokenCounter, "ReadMultipleFiles", "Use readFile with startLine/lineCount or grepFiles for targeted access");
58
+ return {
59
+ path: result.path,
60
+ content: formatFile(result.path, managedResult.content, "markdown"),
61
+ tokenCount: managedResult.tokenCount,
62
+ error: null,
63
+ truncated: managedResult.truncated,
64
+ };
65
+ }));
66
+ const formattedResults = processedResults.map((r) => r.content);
67
+ const finalResult = await manageTokenLimit(formattedResults.join("\n---\n"), tokenCounter, "ReadMultipleFiles", "Reduce number of files or use more specific paths");
68
+ // Aggregate results with detailed breakdown
29
69
  let totalTokens = 0;
30
70
  let filesReadCount = 0;
31
- const formattedResults = results.map((result) => {
32
- if (result.error) {
33
- return `${result.path}: Error - ${result.error}`;
71
+ let filesExceededLimitCount = 0;
72
+ let filesErrorCount = 0;
73
+ for (const processedResult of processedResults) {
74
+ if (processedResult.error) {
75
+ filesErrorCount++;
76
+ }
77
+ else if (processedResult.truncated) {
78
+ filesExceededLimitCount++;
79
+ totalTokens += processedResult.tokenCount;
34
80
  }
35
- // Check if tokenCount is > 0, meaning it wasn't skipped
36
- if (result.tokenCount > 0) {
81
+ else {
37
82
  filesReadCount++;
83
+ totalTokens += processedResult.tokenCount;
38
84
  }
39
- totalTokens += result.tokenCount; // Add the token count (will be 0 for skipped files)
40
- // Return content (or max token message)
41
- return `${result.path}:\n${result.content}\n`;
42
- });
43
- const completionMessage = filesReadCount === paths.length
44
- ? `Read ${paths.length} files successfully (${totalTokens} total tokens).`
45
- : `Read ${filesReadCount} of ${paths.length} files successfully (${totalTokens} total tokens). Files exceeding token limit were skipped.`;
46
- sendData?.({
85
+ }
86
+ const parts = [];
87
+ if (filesReadCount > 0) {
88
+ parts.push(`Read ${filesReadCount} files successfully (${totalTokens} total tokens)`);
89
+ }
90
+ if (filesExceededLimitCount > 0) {
91
+ parts.push(`${filesExceededLimitCount} files exceeded token limit`);
92
+ }
93
+ if (filesErrorCount > 0) {
94
+ parts.push(`${filesErrorCount} files could not be read`);
95
+ }
96
+ if (finalResult.truncated) {
97
+ parts.push(`Combined output exceeded token limit. ${finalResult.content}`);
98
+ }
99
+ const completionMessage = `${parts.join(", ")}.`;
100
+ yield {
101
+ name: ReadMultipleFilesTool.name,
47
102
  id: toolCallId,
48
103
  event: "tool-completion",
49
104
  data: completionMessage,
50
- });
51
- return formattedResults.join("\n---\n");
52
- },
53
- }),
105
+ };
106
+ yield finalResult.content;
107
+ }
108
+ catch (error) {
109
+ const errorMsg = error.message;
110
+ yield {
111
+ name: ReadMultipleFilesTool.name,
112
+ id: toolCallId,
113
+ event: "tool-error",
114
+ data: errorMsg,
115
+ };
116
+ yield errorMsg;
117
+ }
118
+ },
54
119
  };
55
120
  };
121
+ async function validateAndReadFile(filePath, workingDir, allowedDirectory) {
122
+ try {
123
+ const validPath = await validatePath(joinWorkingDir(filePath, workingDir), allowedDirectory);
124
+ const content = await readFile(validPath, "utf-8");
125
+ return {
126
+ path: filePath,
127
+ content,
128
+ error: null,
129
+ };
130
+ }
131
+ catch (error) {
132
+ const errorMessage = error instanceof Error ? error.message : String(error);
133
+ return {
134
+ path: filePath,
135
+ content: null,
136
+ error: errorMessage,
137
+ };
138
+ }
139
+ }
@@ -1,17 +1,52 @@
1
- import type { Terminal } from "../terminal/index.ts";
2
- import { type SendData } from "./types.ts";
1
+ import type { ToolCallOptions } from "ai";
2
+ import { z } from "zod";
3
+ import { type ToolResult } from "./types.ts";
3
4
  export declare const SaveFileTool: {
4
5
  name: "saveFile";
5
6
  };
6
- export declare const createSaveFileTool: ({ workingDir, sendData, terminal, autoAcceptAll, }: {
7
+ declare const inputSchema: z.ZodObject<{
8
+ path: z.ZodString;
9
+ content: z.ZodString;
10
+ encoding: z.ZodEnum<{
11
+ utf8: "utf8";
12
+ ascii: "ascii";
13
+ "utf-8": "utf-8";
14
+ utf16le: "utf16le";
15
+ ucs2: "ucs2";
16
+ "ucs-2": "ucs-2";
17
+ base64: "base64";
18
+ base64url: "base64url";
19
+ latin1: "latin1";
20
+ binary: "binary";
21
+ hex: "hex";
22
+ }>;
23
+ }, z.core.$strip>;
24
+ type SaveFileInputSchema = z.infer<typeof inputSchema>;
25
+ export declare const createSaveFileTool: ({ workingDir, allowedDirs, }: {
7
26
  workingDir: string;
8
- sendData?: SendData;
9
- terminal?: Terminal;
10
- autoAcceptAll?: boolean;
27
+ allowedDirs?: string[];
11
28
  }) => Promise<{
12
- saveFile: import("ai").Tool<{
13
- path: string;
14
- content: string;
15
- encoding: "utf8" | "ascii" | "utf-8" | "utf16le" | "ucs2" | "ucs-2" | "base64" | "base64url" | "latin1" | "binary" | "hex";
16
- }, string>;
29
+ toolDef: {
30
+ description: string;
31
+ inputSchema: z.ZodObject<{
32
+ path: z.ZodString;
33
+ content: z.ZodString;
34
+ encoding: z.ZodEnum<{
35
+ utf8: "utf8";
36
+ ascii: "ascii";
37
+ "utf-8": "utf-8";
38
+ utf16le: "utf16le";
39
+ ucs2: "ucs2";
40
+ "ucs-2": "ucs-2";
41
+ base64: "base64";
42
+ base64url: "base64url";
43
+ latin1: "latin1";
44
+ binary: "binary";
45
+ hex: "hex";
46
+ }>;
47
+ }, z.core.$strip>;
48
+ };
49
+ execute({ path: userPath, content, encoding }: SaveFileInputSchema, { toolCallId, abortSignal }: ToolCallOptions): AsyncGenerator<ToolResult>;
17
50
  }>;
51
+ export {};
52
+ //# sourceMappingURL=save-file.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"save-file.d.ts","sourceRoot":"","sources":["../../source/tools/save-file.ts"],"names":[],"mappings":"AAEA,OAAO,KAAK,EAAE,eAAe,EAAE,MAAM,IAAI,CAAC;AAC1C,OAAO,EAAE,CAAC,EAAE,MAAM,KAAK,CAAC;AAGxB,OAAO,EAAsB,KAAK,UAAU,EAAE,MAAM,YAAY,CAAC;AAEjE,eAAO,MAAM,YAAY;;CAExB,CAAC;AAEF,QAAA,MAAM,WAAW;;;;;;;;;;;;;;;;iBAMf,CAAC;AAEH,KAAK,mBAAmB,GAAG,CAAC,CAAC,KAAK,CAAC,OAAO,WAAW,CAAC,CAAC;AAEvD,eAAO,MAAM,kBAAkB,GAAU,8BAGtC;IACD,UAAU,EAAE,MAAM,CAAC;IACnB,WAAW,CAAC,EAAE,MAAM,EAAE,CAAC;CACxB;;;;;;;;;;;;;;;;;;;;;mDAa4C,mBAAmB,+BAC7B,eAAe,GAC3C,cAAc,CAAC,UAAU,CAAC;EAuEhC,CAAC"}