diff options
| author | Olcan <[email protected]> | 2025-04-24 18:03:33 -0700 |
|---|---|---|
| committer | GitHub <[email protected]> | 2025-04-24 18:03:33 -0700 |
| commit | cbba8007b242f7212ff5bcce618c569b25235024 (patch) | |
| tree | 684cb05c218d33df6650deff9c622ba7b4f7f8b5 /packages/server/src/config/config.ts | |
| parent | a94a9ce3bf7bc015ebbd679d0d95be1c5d9762c2 (diff) | |
shell bones (#160)
* shell bones
* Merge remote-tracking branch 'origin/main' into shell_bones
* add line break
* another line break
* drop the log to avoid breaking terminals
* rename tool to be consistent with terminal
* fix build
Diffstat (limited to 'packages/server/src/config/config.ts')
| -rw-r--r-- | packages/server/src/config/config.ts | 13 |
1 files changed, 11 insertions, 2 deletions
diff --git a/packages/server/src/config/config.ts b/packages/server/src/config/config.ts index 06092b84..8a49380c 100644 --- a/packages/server/src/config/config.ts +++ b/packages/server/src/config/config.ts @@ -15,9 +15,11 @@ import { GrepTool } from '../tools/grep.js'; import { GlobTool } from '../tools/glob.js'; import { EditTool } from '../tools/edit.js'; import { TerminalTool } from '../tools/terminal.js'; +import { ShellTool } from '../tools/shell.js'; import { WriteFileTool } from '../tools/write-file.js'; import { WebFetchTool } from '../tools/web-fetch.js'; import { ReadManyFilesTool } from '../tools/read-many-files.js'; +import { BaseTool, ToolResult } from '../tools/tools.js'; const DEFAULT_PASSTHROUGH_COMMANDS = ['ls', 'git', 'npm']; @@ -132,17 +134,24 @@ function createToolRegistry(config: Config): ToolRegistry { const registry = new ToolRegistry(); const targetDir = config.getTargetDir(); - const tools = [ + const tools: Array<BaseTool<unknown, ToolResult>> = [ new LSTool(targetDir), new ReadFileTool(targetDir), new GrepTool(targetDir), new GlobTool(targetDir), new EditTool(targetDir), - new TerminalTool(targetDir, config), new WriteFileTool(targetDir), new WebFetchTool(), // Note: WebFetchTool takes no arguments new ReadManyFilesTool(targetDir), ]; + + // use ShellTool (next-gen TerminalTool) if environment variable is set + if (process.env.SHELL_TOOL) { + tools.push(new ShellTool(targetDir, config)); + } else { + tools.push(new TerminalTool(targetDir, config)); + } + for (const tool of tools) { registry.registerTool(tool); } |
