Skip to main content

Terminal Shell Integration

Terminal Shell Integration is a key feature that enables Roo Code to execute commands in your terminal and intelligently process their output. This bidirectional communication between the AI and your development environment unlocks powerful automation capabilities.

What is Shell Integration?

Shell integration is automatically enabled in Roo Code and connects directly to your terminal's command execution lifecycle without requiring any setup from you. This built-in feature allows Roo to:

  • Execute commands on your behalf through the execute_command tool
  • Read command output in real-time without manual copy-pasting
  • Automatically detect and fix errors in running applications
  • Observe command exit codes to determine success or failure
  • Track working directory changes as you navigate your project
  • React intelligently to terminal output without user intervention
  • Stop running commands directly from the chat interface using the stop button that appears next to the command execution message.
Stop Command Button in Chat UI

When you ask Roo to perform tasks like installing dependencies, starting a development server, or analyzing build errors, shell integration works behind the scenes to make these interactions smooth and effective.

Troubleshooting Shell Integration

Shell integration is built into Roo Code and works automatically in most cases. If you see "Shell Integration Unavailable" messages or experience issues with command execution, try these solutions:

  1. Update VSCode/Cursor to the latest version (VSCode 1.93+ required)
  2. Ensure a compatible shell is selected: Command Palette (Ctrl+Shift+P or Cmd+Shift+P) → "Terminal: Select Default Profile" → Choose bash, zsh, PowerShell, or fish
  3. Windows PowerShell users: Run Set-ExecutionPolicy RemoteSigned -Scope CurrentUser then restart VSCode
  4. WSL users: Add . "$(code --locate-shell-integration-path bash)" to your ~/.bashrc

Command Execution Fallback

Roo Code has a fallback mechanism for executing commands. This is most relevant if you have chosen to use VS Code's terminal integration (by UNCHECKING the Disable terminal shell integration setting) and that integration then fails.

  • How it works: If Roo Code is configured to use VS Code's terminal integration but cannot connect or encounters issues, it may automatically attempt to execute the command directly using a background process. This is a fallback to ensure the command still attempts to run.
  • Notification: You might see a notification in the chat if this fallback is used, indicating that the command is running without the full features of either Roo's inline terminal or VS Code's shell integration (e.g., real-time output streaming or precise exit code detection might be limited).
Command execution fallback notification example
  • Resolution: If you encounter this fallback, it typically indicates an issue with your VS Code shell integration setup. Review the troubleshooting steps in this document or consider using Roo Code's recommended inline terminal by ensuring the Disable terminal shell integration setting is CHECKED.
Roo Code's recommended inline terminal in action

Example of Roo Code's recommended inline terminal.

Terminal Integration Settings

Roo Code provides settings to fine-tune how it interacts with terminals. To access these settings:

  1. Click the icon in the top-right corner of the Roo Code sidebar.
  2. In the settings pane that opens, select the "Terminal" group from the left-hand menu.

Basic Settings

Terminal Output Limit

Terminal output limit slider set to 500

This setting controls how much output Roo Code captures from your commands. Consider lowering it if you're concerned about token usage or if Roo seems slow processing very long outputs (you'll still get the beginning and end). Consider increasing it if you frequently need more middle content from long commands directly in Roo's context, but be mindful of potential token costs. Default: 500 lines.

Compress progress bar output

Compress progress bar output checkbox

Keep this enabled (default) for cleaner output and token savings. It makes Roo Code process dynamic output like progress bars or spinners more like a real terminal, showing only the final state. Disable this only in rare cases where you specifically need to debug the intermediate, raw output of a progress bar or similar dynamic display.

Advanced Settings

Important

Terminal restart required for these settings

Changes to advanced terminal settings only take effect after restarting your terminals. To restart a terminal:

  1. Click the trash icon in the terminal panel to close the current terminal
  2. Open a new terminal with Terminal → New Terminal or Ctrl+` (backtick)

Always restart all open terminals after changing any of these settings.

Inherit environment variables

Inherit environment variables checkbox

This setting controls whether Roo Code's terminal sessions use the same environment variables (like PATH, API keys, etc.) as your main VSCode/Cursor environment. It directly mirrors the VSCode global setting terminal.integrated.inheritEnv. Keep this enabled (default for VSCode) if you want Roo commands to operate with the same context and tools available in your regular VSCode terminal. Consider disabling it only if you need a completely clean, isolated environment for Roo's terminal tasks or are troubleshooting complex environment variable conflicts.

Runtime Environment

On macOS (and possibly other operating systems) the environment provided to VSCode, and consequently Roo Code, can differ depending on how VSCode is launched.
If launched from the command line vscode command, VSCode and Roo Code will inherit the environment from the shell that launched it, and all will (usually) be well. If launched from the Finder, Dock, or Spotlight, environment exported from .zshrc, or .zprofile will likely be missing. If you have environment variables set in one of those files, and find they are missing when running VSCode, move them to .zshenv, and log out and back in again, so the window manager will pick up the new environment settings.

Disable terminal shell integration

Disable terminal shell integration checkbox

This setting determines how Roo Code executes terminal commands.

  • Keep this checkbox CHECKED (recommended): Roo Code will execute commands using its built-in inline terminal, displaying output directly within the chat interface. This method is generally robust, provides clear output, and is the preferred way for most users to interact with terminal commands through Roo Code. It ensures commands run in a consistent environment managed by Roo Code.

    Roo Code's inline terminal with 'Disable terminal shell integration' CHECKED

    Roo Code's inline terminal, active when "Disable terminal shell integration" is CHECKED.

  • UNCHECK this checkbox (to use VS Code's terminal integration): Roo Code will attempt to run commands directly within your active VS Code terminal panel. This alternative method might be useful for specific edge cases where you explicitly need commands to run within your fully customized VS Code shell environment or require interaction with the VS Code terminal's specific features for a command. However, this can sometimes be less reliable depending on your shell setup and VS Code version.

The following settings are advanced options that apply only if you have UNCHECKED 'Disable terminal shell integration' (choosing to use VS Code's terminal integration instead of Roo Code's recommended inline terminal):

Terminal shell integration timeout
Terminal shell integration timeout slider set to 15s

If shell integration is enabled but you still see 'Shell Integration Unavailable,' especially with complex shell setups (e.g., Zsh with many plugins, or a slow-loading corporate environment), your shell might be taking too long to initialize. Increase this value to give your shell more time to signal its readiness to Roo Code. Try increments of 5-10 seconds. Default: 15s (as shown in UI).

Terminal command delay
Terminal command delay slider set to 0ms

If command output appears incomplete or Roo seems to miss the end of a command's output (even with shell integration enabled), a small delay might help. Introduce a small delay (e.g., 50ms or 100ms). This gives the terminal more time to flush all output before Roo Code considers the command complete. This is a workaround for potential timing issues in VSCode's terminal or certain shells (see VSCode bug #237208). Default: 0ms.

Enable PowerShell counter workaround
Enable PowerShell counter workaround checkbox

Specific to PowerShell users. Enable this if you find Roo Code struggles to run the exact same PowerShell command multiple times in a row, or if output capture from PowerShell commands is unreliable. This adds a unique counter to commands to help PowerShell differentiate them.

Clear ZSH EOL mark
Clear ZSH EOL mark checkbox

Specific to Zsh users. Zsh sometimes adds a special character (often %) at the end of a line if it doesn't end with a newline. Enable this if Roo Code seems to misinterpret or get confused by the output of Zsh commands, particularly if the last line of output appears to include an unexpected character. This attempts to remove that marker (PROMPT_EOL_MARK='').

Enable Oh My Zsh integration
Enable Oh My Zsh integration checkbox

For users of the popular Oh My Zsh framework for Zsh. Enable this if you use Oh My Zsh and experience general issues with terminal command execution or output rendering that aren't solved by other settings. This helps Roo Code align with Oh My Zsh's specific shell integration mechanisms by setting ITERM_SHELL_INTEGRATION_INSTALLED=Yes. Restarting the IDE might be necessary.

Enable Powerlevel10k integration
Enable Powerlevel10k integration checkbox

For users of the Powerlevel10k theme for Zsh. Enable this if your Powerlevel10k prompt (which can be quite complex) seems to interfere with Roo Code's ability to correctly detect command boundaries, parse output, or track the current working directory. This sets POWERLEVEL9K_TERM_SHELL_INTEGRATION=true.

Enable ZDOTDIR handling
Enable ZDOTDIR handling checkbox

An advanced option for Zsh users with customized Zsh startup file locations. Enable this if you use ZDOTDIR to specify a custom directory for your Zsh configuration files (like .zshrc). This setting helps Roo Code work correctly with such setups by creating an isolated, temporary ZDOTDIR for its own integration scripts, preventing conflicts with your personal Zsh environment.

How Shell Integration Works

Shell integration connects Roo to your terminal's command execution process in real-time:

  1. Connection: When you open a terminal, VS Code establishes a special connection with your shell.

  2. Command Tracking: VS Code monitors your terminal activities by detecting:

    • When a new prompt appears
    • When you enter a command
    • When the command starts running
    • When the command finishes (and whether it succeeded or failed)
    • What directory you're currently in
  3. Different Shells, Same Result: Each shell type (Bash, Zsh, PowerShell, Fish) implements this slightly differently behind the scenes, but they all provide the same functionality to Roo.

  4. Information Gathering: Roo can see what commands are running, where they're running, how long they take, whether they succeed, and their complete output - all without you having to copy and paste anything.

Troubleshooting Shell Integration

PowerShell Execution Policy (Windows)

PowerShell restricts script execution by default. To configure:

  1. Open PowerShell as Administrator
  2. Check current policy: Get-ExecutionPolicy
  3. Set appropriate policy: Set-ExecutionPolicy RemoteSigned -Scope CurrentUser

Common policies:

  • Restricted: No scripts allowed (default)
  • RemoteSigned: Local scripts can run; downloaded scripts need signing
  • Unrestricted: All scripts run with warnings
  • AllSigned: All scripts must be signed

Manual Shell Integration Installation

If automatic integration fails, add the appropriate line to your shell configuration:

Bash (~/.bashrc):

[[ "$TERM_PROGRAM" == "vscode" ]] && . "$(code --locate-shell-integration-path bash)"

Zsh (~/.zshrc):

[[ "$TERM_PROGRAM" == "vscode" ]] && . "$(code --locate-shell-integration-path zsh)"

PowerShell ($Profile):

if ($env:TERM_PROGRAM -eq "vscode") { . "$(code --locate-shell-integration-path pwsh)" }

Fish (~/.config/fish/config.fish):

string match -q "$TERM_PROGRAM" "vscode"; and . (code --locate-shell-integration-path fish)

Terminal Customization Issues

If you use terminal customization tools:

Powerlevel10k:

# Add before sourcing powerlevel10k in ~/.zshrc
typeset -g POWERLEVEL9K_TERM_SHELL_INTEGRATION=true

Alternative: Enable the Powerlevel10k Integration setting in Roo Code.

Verifying Shell Integration Status

Confirm shell integration is active with these commands:

Bash:

set | grep -i '[16]33;'
echo "$PROMPT_COMMAND" | grep vsc
trap -p DEBUG | grep vsc

Zsh:

functions | grep -i vsc
typeset -p precmd_functions preexec_functions

PowerShell:

Get-Command -Name "*VSC*" -CommandType Function
Get-Content Function:\Prompt | Select-String "VSCode"

Fish:

functions | grep -i vsc
functions fish_prompt | grep -i vsc

Visual indicators of active shell integration:

  1. Shell integration indicator in terminal title bar
  2. Command detection highlighting
  3. Working directory updates in terminal title
  4. Command duration and exit code reporting

WSL Terminal Integration Methods

When using Windows Subsystem for Linux (WSL), there are two distinct ways to use VSCode with WSL, each with different implications for shell integration:

Method 1: VSCode Windows with WSL Terminal

In this setup:

  • VSCode runs natively in Windows
  • You use the WSL terminal integration feature in VSCode
  • Shell commands are executed through the WSL bridge
  • May experience additional latency due to Windows-WSL communication
  • Shell integration markers may be affected by the WSL-Windows boundary: you must make sure that source "$(code --locate-shell-integration-path <shell>)" is loaded for your shell within the WSL environment because it may not get automatically loaded; see above.

Method 2: VSCode Running Within WSL

In this setup:

  • You launch VSCode directly from within WSL using code .
  • VSCode server runs natively in the Linux environment
  • Direct access to Linux filesystem and tools
  • Better performance and reliability for shell integration
  • Shell integration is loaded automatically since VSCode runs natively in the Linux environment
  • Recommended approach for WSL development

For optimal shell integration with WSL, we recommend:

  1. Open your WSL distribution
  2. Navigate to your project directory
  3. Launch VSCode using code .
  4. Use the integrated terminal within VSCode

Known Issues and Workarounds

VS Code Shell Integration for Fish + Cygwin on Windows

For fellow Windows users running Fish terminal within a Cygwin environment, here's how VS Code's shell integration works:

  1. (Optional) Locate the Shell Integration Script: Open your Fish terminal within VS Code and run the following command:

    code --locate-shell-integration-path fish

    This will output the path to the shellIntegration.fish script. Note down this path.

  2. Update Your Fish Configuration: Edit your config.fish file (usually located at ~/.config/fish/config.fish within your Cygwin home directory). Add the following line, preferably within an if status is-interactive block or at the very end of the file:

    # Example config.fish structure
    if status is-interactive
    # Your other interactive shell configurations...
    # automatic locate integration script:
    string match -q "$TERM_PROGRAM" "vscode"; and . (code --locate-shell-integration-path fish)

    # Or if the above fails for you:
    # Source the VS Code shell integration script
    # IMPORTANT: Replace the example path below with the actual path you found in Step 1.
    # Make sure the path is in a format Cygwin can understand (e.g., using /cygdrive/c/...).
    # source "/cygdrive/c/Users/YourUser/.vscode/extensions/..../shellIntegration.fish"
    end

    Remember to replace the example path with the actual path from Step 1, correctly formatted for Cygwin.

  3. Configure VS Code Terminal Profile: Open your VS Code settings.json file (Ctrl+Shift+P -> "Preferences: Open User Settings (JSON)"). Update or add the Fish profile under terminal.integrated.profiles.windows like this:

    {
    // ... other settings ...

    "terminal.integrated.profiles.windows": {
    // ... other profiles ...

    // Recommended: Use bash.exe to launch fish as a login shell
    "fish": {
    "path": "C:\\cygwin64\\bin\\bash.exe", // Or your Cygwin bash path
    "args": [
    "--login", // Ensures login scripts run (important for Cygwin environment)
    "-i", // Ensures bash runs interactively
    "-c",
    "exec fish" // Replace bash process with fish
    ],
    "icon": "terminal-bash" // Optional: Use a recognizable icon
    }
    // Alternative (if the above fails): Launch fish directly
    "fish-direct": {
    "path": "C:\\cygwin64\\bin\\fish.exe", // Ensure this is in your Windows PATH or provide full path
    // Use 'options' here instead of 'args'; otherwise, you might encounter the error "terminal process terminated exit code 1".
    "options": ["-l", "-c"], // Example: login and interactive flags.
    "icon": "terminal-fish" // Optional: Use a fish icon
    }
    },

    // Optional: Set fish as your default if desired
    // "terminal.integrated.defaultProfile.windows": "fish", // or "fish-direct" depending what you use.

    // ... other settings ...
    }

    Note: Using bash.exe --login -i -c "exec fish" is often more reliable in Cygwin environments for ensuring the correct environment setup before fish starts. However, if that approach doesn't work, try the fish-direct profile configuration.

  4. Restart VS Code: Close and reopen Visual Studio Code completely to apply the changes.

  5. Verify: Open a new Fish terminal in VS Code. The shell integration features (like command decorations, better command history navigation, etc.) should now be active. You can test basic functionality by running simple commands like echo "Hello from integrated Fish!". Fish Cygwin Integration Example

This setup works reliably on Windows systems using Cygwin, Fish, and the Starship prompt, and should assist users with similar configurations.

Shell Integration Failures After VSCode 1.98

Issue: After VSCode updates beyond version 1.98, shell integration may fail with the error "VSCE output start escape sequence (]633;C or ]133;C) not received".

Solutions:

  1. Set Terminal Command Delay:

    • Set the Terminal Command Delay to 50ms in Roo Code settings
    • Restart all terminals after changing this setting
    • This matches older default behavior and may resolve the issue, however some users have reported that a value of 0ms works better. This is a workaround for upstream VSCode problems.
  2. Roll Back VSCode Version:

    • Download VSCode v1.98 from VSCode Updates
    • Replace your current VSCode installation
    • No backup of Roo settings needed
  3. WSL-Specific Workaround:

    • If using WSL, ensure you launch VSCode from within WSL using code .
  4. ZSH Users:

    • Try enabling some or all ZSH-related workarounds in Roo settings
    • These settings can help regardless of your operating system

Known Issues and Workarounds

Ctrl+C Behavior

Issue: If text is already typed in the terminal when Roo tries to run a command, Roo will press Ctrl+C first to clear the line, which can interrupt running processes.

Workaround: Make sure your terminal prompt is empty (no partial commands typed) before asking Roo to execute terminal commands.

Multi-line Command Issues

Issue: Commands that span multiple lines can confuse Roo and may show output from previous commands mixed in with current output.

Workaround: Instead of multi-line commands, use command chaining with && to keep everything on one line (e.g., echo a && echo b instead of typing each command on a separate line).

PowerShell-Specific Issues

  1. Premature Completion: PowerShell sometimes tells Roo a command is finished before all the output has been shown.
  2. Repeated Commands: PowerShell may refuse to run the same command twice in a row.

Workaround: Enable the "PowerShell counter workaround" setting and set a terminal command delay of 150ms in the settings to give commands more time to complete.

Incomplete Terminal Output

Issue: Sometimes VS Code doesn't show or capture all the output from a command.

Workaround: If you notice missing output, try closing and reopening the terminal tab, then run the command again. This refreshes the terminal connection.

Troubleshooting Resources

Checking Debug Logs

When shell integration issues occur, check the debug logs:

  1. Open Help → Toggle Developer Tools → Console
  2. Set "Show All Levels" to see all log messages
  3. Look for messages containing [Terminal Process]
  4. Check preOutput content in error messages:
    • Empty preOutput ('') means VSCode sent no data
    • This indicates a potential VSCode shell integration issue, or an upstream bug that is out of our control
    • The absence of shell integration markers may require adjusting settings to work around possible upstream bugs or local workstation configuration issues related to shell initialization and VSCode's loading of special shell integration hooks

Using the VSCode Terminal Integration Test Extension

The VSCode Terminal Integration Test Extension helps diagnose shell integration issues by testing different settings combinations:

  1. When Commands Stall:

    • If you see "command already running" warnings, click "Reset Stats" to reset the terminal state
    • These warnings indicate shell integration is not working
    • Try different settings combinations until you find one that works
    • If it really gets stuck, restart the extension by closing the window and pressing F5
  2. Testing Settings:

    • Systematically try different combinations of:
      • Terminal Command Delay
      • Shell Integration settings
    • Document which combinations succeed or fail
    • This helps identify patterns in shell integration issues
  3. Reporting Issues:

    • Once you find a problematic configuration
    • Document the exact settings combination
    • Note your environment (OS, VSCode version, shell, and any shell prompt customization)
    • Open an issue with these details to help improve shell integration

Additional Resources

Support

If you're still having issues:

  1. Check Roo Code GitHub Issues
  2. Create a new issue with:
    • OS and VSCode version
    • Shell type
    • Steps to reproduce
    • Error messages

For additional help, join our Discord.