summaryrefslogtreecommitdiff
path: root/packages/server/src/config/config.ts
diff options
context:
space:
mode:
authorOlcan <[email protected]>2025-04-24 18:03:33 -0700
committerGitHub <[email protected]>2025-04-24 18:03:33 -0700
commitcbba8007b242f7212ff5bcce618c569b25235024 (patch)
tree684cb05c218d33df6650deff9c622ba7b4f7f8b5 /packages/server/src/config/config.ts
parenta94a9ce3bf7bc015ebbd679d0d95be1c5d9762c2 (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.ts13
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);
}