run_shell_command
)This document describes the run_shell_command
tool for the Gemini CLI.
Use run_shell_command
to interact with the underlying system, run scripts, or perform command-line operations. run_shell_command
executes a given shell command. On Windows, the command will be executed with cmd.exe /c
. On other platforms, the command will be executed with bash -c
.
run_shell_command
takes the following 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.run_shell_command
with the Gemini CLIWhen using run_shell_command
, the command is executed as a subprocess. run_shell_command
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.Usage:
run_shell_command(command="Your commands.", description="Your description of the command.", directory="Your execution directory.")
run_shell_command
examplesList files in the current directory:
run_shell_command(command="ls -la")
Run a script in a specific directory:
run_shell_command(command="./my_script.sh", directory="scripts", description="Run my custom script")
Start a background server:
run_shell_command(command="npm run dev &", description="Start development server in background")
npm init -y
).Stderr
, Error
, and Exit Code
fields to determine if a command executed successfully.&
, 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.When run_shell_command
executes a command, it sets the GEMINI_CLI=1
environment variable in the subprocess’s environment. This allows scripts or tools to detect if they are being run from within the Gemini CLI.
You can restrict the commands that can be executed by the run_shell_command
tool by using the coreTools
and excludeTools
settings in your configuration file.
coreTools
: To restrict run_shell_command
to a specific set of commands, add entries to the coreTools
list in the format run_shell_command(<command>)
. For example, "coreTools": ["run_shell_command(git)"]
will only allow git
commands. Including the generic run_shell_command
acts as a wildcard, allowing any command not explicitly blocked.excludeTools
: To block specific commands, add entries to the excludeTools
list in the format run_shell_command(<command>)
. For example, "excludeTools": ["run_shell_command(rm)"]
will block rm
commands.The validation logic is designed to be secure and flexible:
&&
, ||
, or ;
and validates each part separately. If any part of the chain is disallowed, the entire command is blocked.git
, you can run git status
or git log
.excludeTools
list is always checked first. If a command matches a blocked prefix, it will be denied, even if it also matches an allowed prefix in coreTools
.Allow only specific command prefixes
To allow only git
and npm
commands, and block all others:
{
"coreTools": ["run_shell_command(git)", "run_shell_command(npm)"]
}
git status
: Allowednpm install
: Allowedls -l
: BlockedBlock specific command prefixes
To block rm
and allow all other commands:
{
"coreTools": ["run_shell_command"],
"excludeTools": ["run_shell_command(rm)"]
}
rm -rf /
: Blockedgit status
: Allowednpm install
: AllowedBlocklist takes precedence
If a command prefix is in both coreTools
and excludeTools
, it will be blocked.
{
"coreTools": ["run_shell_command(git)"],
"excludeTools": ["run_shell_command(git push)"]
}
git push origin main
: Blockedgit status
: AllowedBlock all shell commands
To block all shell commands, add the run_shell_command
wildcard to excludeTools
:
{
"excludeTools": ["run_shell_command"]
}
ls -l
: Blockedany other command
: BlockedexcludeTools
Command-specific restrictions in excludeTools
for run_shell_command
are based on simple string matching and can be easily bypassed. This feature is not a security mechanism and should not be relied upon to safely execute untrusted code. It is recommended to use coreTools
to explicitly select commands
that can be executed.