summaryrefslogtreecommitdiff
path: root/docs/tools/shell.md
blob: e60fb9a4b942a841ccbaa07c343bb5e7939d32b8 (plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
# Shell Tool

This document provides details on the shell tool.

## `run_shell_command`

- **Purpose:** Executes a given shell command. On Windows, this will be executed with `cmd.exe /c`. On other platforms, it will be executed with `bash -c`. This tool is essential for interacting with the underlying operating system, running scripts, or performing command-line operations.
- **Arguments:**
  - `command` (string, required): The exact shell command to execute.
  - `description` (string, optional): A brief description of the command's purpose, which will be shown to the user.
  - `directory` (string, optional): The directory (relative to the project root) in which to execute the command. If not provided, the command runs in the project root.
- **Behavior:**
  - The command is executed as a subprocess.
  - It can start background processes using `&`.
  - The tool returns detailed information about the execution, including:
    - `Command`: The command that was executed.
    - `Directory`: The directory where the command was run.
    - `Stdout`: Output from the standard output stream.
    - `Stderr`: Output from the standard error stream.
    - `Error`: Any error message reported by the subprocess.
    - `Exit Code`: The exit code of the command.
    - `Signal`: The signal number if the command was terminated by a signal.
    - `Background PIDs`: A list of PIDs for any background processes started.
- **Examples:**

  - Listing files in the current directory:

    ```

    run_shell_command(command="ls -la")
    ```

  - Running a script in a specific directory:
    ```
    run_shell_command(command="./my_script.sh", directory="scripts", description="Run my custom script")
    ```
  - Starting a background server:
    ```
    run_shell_command(command="npm run dev &", description="Start development server in background")
    ```

- **Important Notes:**
  - **Security:** Be cautious when executing commands, especially those constructed from user input, to prevent security vulnerabilities.
  - **Interactive Commands:** Avoid commands that require interactive user input, as this can cause the tool to hang. Use non-interactive flags if available (e.g., `npm init -y`).
  - **Error Handling:** Check the `Stderr`, `Error`, and `Exit Code` fields to determine if a command executed successfully.
  - **Background Processes:** When a command is run in the background with `&`, the tool will return immediately and the process will continue to run in the background. The `Background PIDs` field will contain the process ID of the background process.