https://github.com/wonderwhy-er/DesktopCommanderMCP
This is MCP server for Claude that gives it terminal control, file system search and diff file editing capabilities
https://github.com/wonderwhy-er/DesktopCommanderMCP
Last synced: 12 months ago
JSON representation
This is MCP server for Claude that gives it terminal control, file system search and diff file editing capabilities
- Host: GitHub
- URL: https://github.com/wonderwhy-er/DesktopCommanderMCP
- Owner: wonderwhy-er
- License: mit
- Created: 2024-12-04T08:26:08.000Z (over 1 year ago)
- Default Branch: main
- Last Pushed: 2025-03-27T13:04:13.000Z (12 months ago)
- Last Synced: 2025-03-27T14:22:53.328Z (12 months ago)
- Language: TypeScript
- Homepage:
- Size: 1.3 MB
- Stars: 1,106
- Watchers: 23
- Forks: 113
- Open Issues: 18
-
Metadata Files:
- Readme: README.md
- License: LICENSE
Awesome Lists containing this project
- awesome-mcp - wonderwhy-er/DesktopCommanderMCP
- awesome - wonderwhy-er/DesktopCommanderMCP - This is MCP server for Claude that gives it terminal control, file system search and diff file editing capabilities (TypeScript)
- awesome-mcp-servers - Desktop Commander MCP - A feature-rich MCP Server that can manage and execute programs, as well as read, write, search, and edit code and text files across desktop platforms. Includes implementation by wonderwhy-er. ([Read more](/details/desktop-commander-mcp.md)) `mcp` `desktop` `code-execution` `automation` `file-management` (Code Execution & Automation MCP Servers)
- awesome-devops-mcp-servers - wonderwhy-er/DesktopCommanderMCP - A swiss-army-knife that can manage/execute programs and read/write/search/edit code and text files. (Cloud Infrastructure / 🖥️ Command Line)
- awesome-mcp - wonderwhy-er/DesktopCommanderMCP - er/DesktopCommanderMCP?style=social) <img src="https://cdn.simpleicons.org/typescript/3178C6" width="16" height="16"/> <img src="https://cdn.simpleicons.org/homeassistant/41BDF5" width="16" height="16"/> <img src="https://cdn.simpleicons.org/apple/999" width="16" height="16"/> <img src="https://cdn.simpleicons.org/linux/999" width="16" height="16"/> - 提供终端控制、文件系统搜索和精细代码编辑功能的MCP服务器。使AI能够执行终端命令、管理进程并通过基于模式的替换编辑文件。 (服务器实现 / 系统与硬件)
- awesome-ai-agents - wonderwhy-er/DesktopCommanderMCP - Desktop Commander MCP is a server that integrates with the Claude desktop app to provide terminal control, file system search, and diff-based file editing capabilities, enabling advanced AI-assisted desktop management. (GUI & Computer Control AI Agents / Desktop Automation)
- StarryDivineSky - wonderwhy-er/DesktopCommanderMCP
- awesome-llm-os - Desktop Commander MCP
- awesome-AI-driven-development - Desktop Commander MCP - MCP server for Claude that gives it terminal control, file system search and diff file editing capabilities (MCP Servers & Integrations / Other IDEs)
- awesome-mcp-servers - **DesktopCommanderMCP** - This is MCP server for Claude that gives it terminal control, file system search and diff file editing capabilities `javascript` `agent` `ai` `code-analysis` `code-generation` `npm install wonderwhy-er/DesktopCommanderMCP` (🤖 AI/ML)
- awesome-mcp-servers - wonderwhy-er/DesktopCommanderMCP - プログラムの管理/実行、コードやテキストファイルの読み取り/書き込み/検索/編集ができるスイス・アーミー・ナイフ。 (サーバー実装 / 🖥️ <a name="command-line"></a>コマンドライン)
- awesome-mcp-registry - wonderwhy-er/DesktopCommanderMCP
- metorial-index - Desktop Commander - Execute terminal commands, manage processes, and perform advanced file editing tasks, including text replacements and file rewrites. Enhance development workflows by automating repetitive tasks and running processes efficiently. (Code Execution)
- awesome-mcp-zh - wonderwhy-er/DesktopCommanderMCP
- awesome-mcpb - Desktop Commander - Terminal control, file operations, and diff-based code editing. (Developer Tools)
- awesome-mcp - wonderwhy-er/DesktopCommanderMCP - Desktop Commander MCP is an MCP server for Claude that integrates AI with terminal control, file system search, and file editing capabilities, enabling advanced desktop automation and development workflows. (MCP Servers / Desktop Automation)
- best-of-mcp-servers - GitHub - 49% open · ⏱️ 24.02.2026) (Command Line)
- awesome-mcp-servers - wonderwhy-er/DesktopCommanderMCP - プログラムの管理/実行、コードやテキストファイルの読み取り/書き込み/検索/編集ができるスイス・アーミー・ナイフ。 (サーバー実装 / 🖥️ <a name="command-line"></a>コマンドライン)
- awesome-mcp-security - wonderwhy-er/DesktopCommanderMCP - A swiss-army-knife that can manage/execute programs and read/write/search/edit code and text files. (Cloud Infrastructure / 🖥️ Command Line)
README
# Desktop Commander MCP
[](https://www.npmjs.com/package/@wonderwhy-er/desktop-commander)
[](https://smithery.ai/server/@wonderwhy-er/desktop-commander)
[](https://www.buymeacoffee.com/wonderwhyer)
[](https://discord.gg/kQ27sNnZr7)
Short version. Two key things. Terminal commands and diff based file editing.

## Table of Contents
- [Features](#features)
- [Installation](#installation)
- [Usage](#usage)
- [Handling Long-Running Commands](#handling-long-running-commands)
- [Work in Progress and TODOs](#work-in-progress-and-todos)
- [Media links](#media)
- [Testimonials](#testimonials)
- [Frequently Asked Questions](#frequently-asked-questions)
- [Contributing](#contributing)
- [License](#license)
This is server that allows Claude desktop app to execute long-running terminal commands on your computer and manage processes through Model Context Protocol (MCP) + Built on top of [MCP Filesystem Server](https://github.com/modelcontextprotocol/servers/tree/main/src/filesystem) to provide additional search and replace file editing capabilities .
## Features
- Execute terminal commands with output streaming
- Command timeout and background execution support
- Process management (list and kill processes)
- Session management for long-running commands
- Full filesystem operations:
- Read/write files
- Create/list directories
- Move files/directories
- Search files
- Get file metadata
- Code editing capabilities:
- Surgical text replacements for small changes
- Full file rewrites for major changes
- Multiple file support
- Pattern-based replacements
- vscode-ripgrep based recursive code or text search in folders
## Installation
First, ensure you've downloaded and installed the [Claude Desktop app](https://claude.ai/download) and you have [npm installed](https://docs.npmjs.com/downloading-and-installing-node-js-and-npm).
### Option 1: Install through npx
Just run this in terminal
```
npx @wonderwhy-er/desktop-commander@latest setup
```
Restart Claude if running
### Option 2: Installing via Smithery
To install Desktop Commander for Claude Desktop automatically via [Smithery](https://smithery.ai/server/@wonderwhy-er/desktop-commander):
```bash
npx -y @smithery/cli install @wonderwhy-er/desktop-commander --client claude
```
### Option 3: Add to claude_desktop_config by hand
Add this entry to your claude_desktop_config.json:
- On Mac: `~/Library/Application\ Support/Claude/claude_desktop_config.json`
- On Windows: `%APPDATA%\Claude\claude_desktop_config.json`
- On Linux: `~/.config/Claude/claude_desktop_config.json`
```json
{
"mcpServers": {
"desktop-commander": {
"command": "npx",
"args": [
"-y",
"@wonderwhy-er/desktop-commander"
]
}
}
}
```
Restart Claude if running
### Option 4: Checkout locally
1. Clone and build:
```bash
git clone https://github.com/wonderwhy-er/ClaudeComputerCommander.git
cd ClaudeComputerCommander
npm run setup
```
Restart Claude if running
The setup command will:
- Install dependencies
- Build the server
- Configure Claude's desktop app
- Add MCP servers to Claude's config if needed
## Usage
The server provides these tool categories:
### Terminal Tools
- `execute_command`: Run commands with configurable timeout
- `read_output`: Get output from long-running commands
- `force_terminate`: Stop running command sessions
- `list_sessions`: View active command sessions
- `list_processes`: View system processes
- `kill_process`: Terminate processes by PID
- `block_command`/`unblock_command`: Manage command blacklist
### Filesystem Tools
- `read_file`/`write_file`: File operations
- `create_directory`/`list_directory`: Directory management
- `move_file`: Move/rename files
- `search_files`: Pattern-based file search
- `get_file_info`: File metadata
- `search_code`: Recursive ripgrep based text and code search
### Edit Tools
- `edit_block`: Apply surgical text replacements (best for changes <20% of file size)
- `write_file`: Complete file rewrites (best for large changes >20% or when edit_block fails)
Search/Replace Block Format:
```
filepath.ext
<<<<<<< SEARCH
content to find
=======
new content
>>>>>>> REPLACE
```
Example:
```
src/main.js
<<<<<<< SEARCH
console.log("old message");
=======
console.log("new message");
>>>>>>> REPLACE
```
## Handling Long-Running Commands
For commands that may take a while:
1. `execute_command` returns after timeout with initial output
2. Command continues in background
3. Use `read_output` with PID to get new output
4. Use `force_terminate` to stop if needed
## Model Context Protocol Integration
This project extends the MCP Filesystem Server to enable:
- Local server support in Claude Desktop
- Full system command execution
- Process management
- File operations
- Code editing with search/replace blocks
Created as part of exploring Claude MCPs: https://youtube.com/live/TlbjFDbl5Us
## DONE
- **28-03-2025 Fixed "Watching /" JSON error** - Implemented custom stdio transport to handle non-JSON messages and prevent server crashes
- **25-03-2025 Better code search** ([merged](https://github.com/wonderwhy-er/ClaudeDesktopCommander/pull/17)) - Enhanced code exploration with context-aware results
## Work in Progress and TODOs
The following features are currently being developed or planned:
- **Better configurations** ([in progress](https://github.com/wonderwhy-er/ClaudeDesktopCommander/pull/16)) - Improved settings for allowed paths, commands and shell environment
- **Windows environment fixes** ([in progress](https://github.com/wonderwhy-er/ClaudeDesktopCommander/pull/13)) - Resolving issues specific to Windows platforms
- **Linux improvements** ([in progress](https://github.com/wonderwhy-er/ClaudeDesktopCommander/pull/12)) - Enhancing compatibility with various Linux distributions
- **Support for WSL** - Windows Subsystem for Linux integration
- **Support for SSH** - Remote server command execution
- **Installation troubleshooting guide** - Comprehensive help for setup issues
## Website
Visit our official website at [https://desktopcommander.app/](https://desktopcommander.app/) for the latest information, documentation, and updates.
## Media
Learn more about this project through these resources:
### Article
[Claude with MCPs replaced Cursor & Windsurf. How did that happen?](https://wonderwhy-er.medium.com/claude-with-mcps-replaced-cursor-windsurf-how-did-that-happen-c1d1e2795e96) - A detailed exploration of how Claude with Model Context Protocol capabilities is changing developer workflows.
### Video
[Claude Desktop Commander Video Tutorial](https://www.youtube.com/watch?v=ly3bed99Dy8) - Watch how to set up and use the Commander effectively.
### Publication at AnalyticsIndiaMag
[
This Developer Ditched Windsurf, Cursor Using Claude with MCPs](https://analyticsindiamag.com/ai-features/this-developer-ditched-windsurf-cursor-using-claude-with-mcps/)
### Community
Join our [Discord server](https://discord.gg/kQ27sNnZr7) to get help, share feedback, and connect with other users.
## Testimonials
[ https://www.youtube.com/watch?v=ly3bed99Dy8&lc=UgyyBt6_ShdDX_rIOad4AaABAg
](https://www.youtube.com/watch?v=ly3bed99Dy8&lc=UgyyBt6_ShdDX_rIOad4AaABAg
)
[
https://www.youtube.com/watch?v=ly3bed99Dy8&lc=UgztdHvDMqTb9jiqnf54AaABAg](https://www.youtube.com/watch?v=ly3bed99Dy8&lc=UgztdHvDMqTb9jiqnf54AaABAg
)
[
https://www.youtube.com/watch?v=ly3bed99Dy8&lc=UgyQFTmYLJ4VBwIlmql4AaABAg](https://www.youtube.com/watch?v=ly3bed99Dy8&lc=UgyQFTmYLJ4VBwIlmql4AaABAg)
[
https://www.youtube.com/watch?v=ly3bed99Dy8&lc=Ugy4-exy166_Ma7TH-h4AaABAg](https://www.youtube.com/watch?v=ly3bed99Dy8&lc=Ugy4-exy166_Ma7TH-h4AaABAg)
[
https://medium.com/@pharmx/you-sir-are-my-hero-62cff5836a3e](https://medium.com/@pharmx/you-sir-are-my-hero-62cff5836a3e)
## Contributing
If you find this project useful, please consider giving it a ⭐ star on GitHub! This helps others discover the project and encourages further development.
We welcome contributions from the community! Whether you've found a bug, have a feature request, or want to contribute code, here's how you can help:
- **Found a bug?** Open an issue at [github.com/wonderwhy-er/ClaudeComputerCommander/issues](https://github.com/wonderwhy-er/ClaudeComputerCommander/issues)
- **Have a feature idea?** Submit a feature request in the issues section
- **Want to contribute code?** Fork the repository, create a branch, and submit a pull request
- **Questions or discussions?** Start a discussion in the GitHub Discussions tab
All contributions, big or small, are greatly appreciated!
If you find this tool valuable for your workflow, please consider [supporting the project](https://www.buymeacoffee.com/wonderwhyer).
## Frequently Asked Questions
Here are answers to some common questions. For a more comprehensive FAQ, see our [detailed FAQ document](FAQ.md).
### What is Claude Desktop Commander?
It's an MCP tool that enables Claude Desktop to access your file system and terminal, turning Claude into a versatile assistant for coding, automation, codebase exploration, and more.
### How is this different from Cursor/Windsurf?
Unlike IDE-focused tools, Claude Desktop Commander provides a solution-centric approach that works with your entire OS, not just within a coding environment. Claude reads files in full rather than chunking them, can work across multiple projects simultaneously, and executes changes in one go rather than requiring constant review.
### Do I need to pay for API credits?
No. This tool works with Claude Desktop's standard Pro subscription ($20/month), not with API calls, so you won't incur additional costs beyond the subscription fee.
### What are the most common use cases?
- Exploring and understanding complex codebases
- Generating diagrams and documentation
- Automating tasks across your system
- Working with multiple projects simultaneously
- Making surgical code changes with precise control
### I'm having trouble installing or using the tool. Where can I get help?
Join our [Discord server](https://discord.gg/kQ27sNnZr7) for community support, check the [GitHub issues](https://github.com/wonderwhy-er/ClaudeComputerCommander/issues) for known problems, or review the [full FAQ](FAQ.md) for troubleshooting tips. You can also visit our [website FAQ section](https://desktopcommander.app#faq) for a more user-friendly experience. If you encounter a new issue, please consider [opening a GitHub issue](https://github.com/wonderwhy-er/ClaudeComputerCommander/issues/new) with details about your problem.
## Data Collection
During installation and setup, Desktop Commander collects anonymous usage data to help improve the tool. This includes:
- Operating system information
- Node.js and NPM versions
- Installation method and shell environment
- Error messages (if any occur during setup)
This data is collected using PostHog analytics and is associated with a machine-generated unique ID. No personal information is collected. This helps us understand how the tool is being used and identify common issues.
We are currently working on adding a built-in opt-out option for this data collection in an upcoming release. For now, if you wish to opt out, you can block network connections to `eu.i.posthog.com` in your firewall settings.
## License
MIT