# mcp-debugger
<div align="center">
<img src="assets/logo.png" alt="MCP Debugger Logo - A stylized circuit board with debug breakpoints" width="400" height="400">
</div>
**MCP server for multi-language debugging β give your AI agents debugging superpowers** π
[](https://github.com/debugmcp/mcp-debugger/actions/workflows/ci.yml)
[](https://codecov.io/gh/debugmcp/mcp-debugger)
[](https://www.npmjs.com/package/@debugmcp/mcp-debugger)
[](https://hub.docker.com/r/debugmcp/mcp-debugger)
[](./LICENSE)
## π― Overview
mcp-debugger is a Model Context Protocol (MCP) server that provides debugging tools as structured API calls. It enables AI agents to perform step-through debugging of multiple programming languages using the Debug Adapter Protocol (DAP).
> π Version 0.17.0: Rust debugging support (Alpha)! Debug Rust programs with CodeLLDB, including Cargo projects, async code, and full variable inspectionβplus step commands now return the active source context so agents keep their place automatically.
> π₯ Version 0.16.0: JavaScript/Node.js debugging support (Alpha)! Full debugging capabilities with bundled js-debug, TypeScript support, and zero-runtime dependencies via improved npx distribution.
> π¬ **Demo Video**: See the debugger in action!
>
> *Recording in progress - This will show an AI agent discovering and fixing the variable swap bug in real-time*
>
> <!-- To capture this demo, see examples/visualizer/demo_script.md -->
> <!-- Uncomment when demo.gif is available:
> <div align="center">
> <img src="assets/demo.gif" alt="MCP Debugger Demo - AI agent debugging Python code">
> <br>
> <em>AI agent discovering and fixing a variable swap bug in real-time</em>
> </div>
> -->
## β¨ Key Features
- π **Multi-language support** β Clean adapter pattern for any language
- π **Python debugging via debugpy** β Full DAP protocol support
- π¨ **JavaScript (Node.js) debugging via js-debug** β VSCode's proven debugger (Alpha)
- π¦ **Rust debugging via CodeLLDB** β Debug Rust & Cargo projects (Alpha)
> WARNING: On Windows, use the GNU toolchain for full variable inspection. Run `mcp-debugger check-rust-binary <path-to-exe>` to verify your build and see [Rust Debugging on Windows](docs/rust-debugging-windows.md) for detailed guidance.
> NOTE: The published npm bundle ships the Linux x64 CodeLLDB runtime to stay under registry size limits. On macOS or Windows, point the `CODELLDB_PATH` environment variable at an existing CodeLLDB installation (for example from the VSCode extension) or clone the repo and run `pnpm --filter @debugmcp/adapter-rust run build:adapter` to vendor your platform binaries locally.
### Windows Rust Setup Script
If you're on Windows and want the quickest path to a working GNU toolchain + dlltool configuration, run:
```powershell
pwsh scripts/setup/windows-rust-debug.ps1
```
The script installs the `stable-gnu` toolchain (via rustup), exposes `dlltool.exe` from rustup's self-contained directory, builds the bundled Rust examples, and (optionally) runs the Rust smoke tests. Add `-UpdateUserPath` if you want the dlltool path persisted to your user PATH/DLLTOOL variables.
The script will also attempt to provision an MSYS2-based MinGW-w64 toolchain (via winget + pacman) so `cargo +stable-gnu` has a fully functional `dlltool/ld/as` stack. If MSYS2 is already installed, it simply reuses it; otherwise it guides you through installing it (or warns so you can install manually).
- π§ͺ **Mock adapter for testing** β Test without external dependencies
- π **STDIO and SSE transport modes** β Works with any MCP client
- π¦ **Zero-runtime dependencies** β Self-contained bundles via tsup (~3 MB)
- β‘ **npx ready** β Run directly with `npx @debugmcp/mcp-debugger` - no installation needed
- π **1019 tests passing** β battle-tested end-to-end
- π³ **Docker and npm packages** β Deploy anywhere
- π€ **Built for AI agents** β Structured JSON responses for easy parsing
- π‘οΈ **Path validation** β Prevents crashes from non-existent files
- π **AI-aware line context** β Intelligent breakpoint placement with code context
## π Quick Start
### For MCP Clients (Claude Desktop, etc.)
Add to your MCP settings configuration:
```json
{
"mcpServers": {
"mcp-debugger": {
"command": "node",
"args": ["C:/path/to/mcp-debugger/dist/index.js", "--log-level", "debug", "--log-file", "C:/path/to/logs/debug-mcp-server.log"],
"disabled": false,
"autoApprove": ["create_debug_session", "set_breakpoint", "get_variables"]
}
}
}
```
### For Claude Code CLI
For Claude Code users, we provide an automated installation script:
```bash
# Clone the repository
git clone https://github.com/yourusername/mcp-debugger.git
cd mcp-debugger
# Run the installation script
./scripts/install-claude-mcp.sh
# Verify the connection
/home/ubuntu/.claude/local/claude mcp list
```
**Important**: The `stdio` argument is required to prevent console output from corrupting the JSON-RPC protocol. See [CLAUDE.md](CLAUDE.md) for detailed setup and [docs/MCP_CLAUDE_CODE_INTEGRATION.md](docs/MCP_CLAUDE_CODE_INTEGRATION.md) for troubleshooting.
### Using Docker
```bash
docker run -v $(pwd):/workspace debugmcp/mcp-debugger:latest
```
> β οΈ The Docker image intentionally ships only the Python and JavaScript adapters. Rust debugging requires the local, SSE, or packed deployments where the adapter runs next to your toolchain.
### Using npm
```bash
npm install -g @debugmcp/mcp-debugger
mcp-debugger --help
```
Or use without installation via npx:
```bash
npx @debugmcp/mcp-debugger --help
```
> πΈ **Screenshot**: *MCP Integration in Action*
>
> This screenshot will show real-time MCP protocol communication with tool calls and JSON responses flowing between the AI agent and debugger.
>
> <!-- To capture this screenshot, see examples/visualizer/capture_guide.md -->
> <!-- Uncomment when mcp-integration.png is available:
> 
> *Real-time MCP protocol communication showing tool calls and responses*
> -->
## π How It Works
mcp-debugger exposes debugging operations as MCP tools that can be called with structured JSON parameters:
```json
// Tool: create_debug_session
// Request:
{
"language": "python", // or "javascript", "rust", or "mock" for testing
"name": "My Debug Session"
}
// Response:
{
"success": true,
"sessionId": "a4d1acc8-84a8-44fe-a13e-28628c5b33c7",
"message": "Created python debug session: My Debug Session"
}
```
> πΈ **Screenshot**: *Active Debugging Session*
>
> This screenshot will show the debugger paused at a breakpoint with the stack trace visible in the left panel, local variables in the right panel, and source code with line highlighting in the center.
>
> <!-- To capture this screenshot, see examples/visualizer/capture_guide.md -->
> <!-- Uncomment when debugging-session.png is available:
> 
> *Active debugging session paused at a breakpoint with stack trace visible*
> -->
## π οΈ Available Tools
| Tool | Description | Status |
|------|-------------|--------|
| `create_debug_session` | Create a new debugging session | β
Implemented |
| `list_debug_sessions` | List all active sessions | β
Implemented |
| `set_breakpoint` | Set a breakpoint in a file | β
Implemented |
| `start_debugging` | Start debugging a script | β
Implemented |
| `get_stack_trace` | Get the current stack trace | β
Implemented |
| `get_scopes` | Get variable scopes for a frame | β
Implemented |
| `get_variables` | Get variables in a scope | β
Implemented |
| `step_over` | Step over the current line | β
Implemented |
| `step_into` | Step into a function | β
Implemented |
| `step_out` | Step out of a function | β
Implemented |
| `continue_execution` | Continue running | β
Implemented |
| `close_debug_session` | Close a session | β
Implemented |
| `pause_execution` | Pause running execution | β Not Implemented |
| `evaluate_expression` | Evaluate expressions | β Not Implemented |
| `get_source_context` | Get source code context | β
Implemented |
> πΈ **Screenshot**: *Multi-Session Debugging*
>
> This screenshot will show the debugger managing multiple concurrent debug sessions, demonstrating how AI agents can debug different scripts simultaneously with isolated session management.
>
> <!-- To capture this screenshot, see examples/visualizer/capture_guide.md -->
> <!-- Uncomment when multi-session.png is available:
> 
> *Managing multiple debug sessions simultaneously*
> -->
## ποΈ Architecture: Dynamic Adapter Loading
Version 0.10.0 introduces a clean adapter pattern that separates language-agnostic core functionality from language-specific implementations:
```
βββββββββββββββ ββββββββββββββββ βββββββββββββββββββ
β MCP Client ββββββΆβ SessionManagerββββββΆβ AdapterRegistry β
βββββββββββββββ ββββββββββββββββ βββββββββββββββββββ
β β
βΌ βΌ
ββββββββββββββββ βββββββββββββββββββ
β ProxyManager ββββββββ Language Adapterβ
ββββββββββββββββ βββββββββββββββββββ
β
ββββββββββββββββ΄ββββββββββββββββ
β β
βββββββΌβββββββ ββββββββΌβββββββ βββββββΌβββββββ
βPython β βJavaScript β βMock β
βAdapter β βAdapter β βAdapter β
ββββββββββββββ βββββββββββββββ ββββββββββββββ
```
### Adding Language Support
Want to add debugging support for your favorite language? Check out the [Adapter Development Guide](./docs/architecture/adapter-development-guide.md)!
## π‘ Example: Debugging Python Code
Here's a complete debugging session example:
```python
# buggy_swap.py
def swap_variables(a, b):
a = b # Bug: loses original value of 'a'
b = a # Bug: 'b' gets the new value of 'a'
return a, b
```
### Step 1: Create a Debug Session
```json
// Tool: create_debug_session
// Request:
{
"language": "python",
"name": "Swap Bug Investigation"
}
// Response:
{
"success": true,
"sessionId": "a4d1acc8-84a8-44fe-a13e-28628c5b33c7",
"message": "Created python debug session: Swap Bug Investigation"
}
```
### Step 2: Set Breakpoints
```json
// Tool: set_breakpoint
// Request:
{
"sessionId": "a4d1acc8-84a8-44fe-a13e-28628c5b33c7",
"file": "buggy_swap.py",
"line": 2
}
// Response:
{
"success": true,
"breakpointId": "28e06119-619e-43c0-b029-339cec2615df",
"file": "C:\\path\\to\\buggy_swap.py",
"line": 2,
"verified": false,
"message": "Breakpoint set at C:\\path\\to\\buggy_swap.py:2"
}
```
### Step 3: Start Debugging
```json
// Tool: start_debugging
// Request:
{
"sessionId": "a4d1acc8-84a8-44fe-a13e-28628c5b33c7",
"scriptPath": "buggy_swap.py"
}
// Response:
{
"success": true,
"state": "paused",
"message": "Debugging started for buggy_swap.py. Current state: paused",
"data": {
"message": "Debugging started for buggy_swap.py. Current state: paused",
"reason": "breakpoint"
}
}
```
### Step 4: Inspect Variables
First, get the scopes:
```json
// Tool: get_scopes
// Request:
{
"sessionId": "a4d1acc8-84a8-44fe-a13e-28628c5b33c7",
"frameId": 3
}
// Response:
{
"success": true,
"scopes": [
{
"name": "Locals",
"variablesReference": 5,
"expensive": false,
"presentationHint": "locals",
"source": {}
},
{
"name": "Globals",
"variablesReference": 6,
"expensive": false,
"source": {}
}
]
}
```
Then get the local variables:
```json
// Tool: get_variables
// Request:
{
"sessionId": "a4d1acc8-84a8-44fe-a13e-28628c5b33c7",
"scope": 5
}
// Response:
{
"success": true,
"variables": [
{"name": "a", "value": "10", "type": "int", "variablesReference": 0, "expandable": false},
{"name": "b", "value": "20", "type": "int", "variablesReference": 0, "expandable": false}
],
"count": 2,
"variablesReference": 5
}
```
> πΈ **Screenshot**: *Variable Inspection Reveals the Bug*
>
> This screenshot will show the TUI visualizer after stepping over line 4, where both variables incorrectly show value 20, clearly demonstrating the variable swap bug. The left panel shows the execution state, the center shows the highlighted code, and the right panel displays the incorrect variable values.
>
> <!-- To capture this screenshot, see examples/visualizer/capture_guide.md -->
> <!-- Uncomment when variable-inspection.png is available:
> 
> *After stepping over line 4, both variables incorrectly show value 20*
> -->
## π Documentation
- π [Tool Reference](./docs/tool-reference.md) β Complete API documentation
- π¦ [Getting Started Guide](./docs/getting-started.md) β First-time setup
- ποΈ [Architecture Overview](./docs/architecture/README.md) β Multi-language design
- π§ [Adapter Development](./docs/architecture/adapter-development-guide.md) β Add new languages
- π [Dynamic Loading Architecture](./docs/architecture/dynamic-loading-architecture.md) β Runtime discovery, lazy loading, caching
- π§© [Adapter API Reference](./docs/architecture/adapter-api-reference.md) β Adapter, factory, loader, and registry contracts
- π [Migration Guide](./docs/migration-guide.md) β Upgrading to v0.15.0 (dynamic loading)
- π [Python Debugging Guide](./docs/python/README.md) β Python-specific features
- π¨ [JavaScript Debugging Guide](./docs/javascript/README.md) β JavaScript/TypeScript features
- [Rust Debugging on Windows](docs/rust-debugging-windows.md) - Toolchain requirements and troubleshooting
- π€ [AI Integration Guide](./docs/ai-integration.md) β Leverage AI-friendly features
- π§ [Troubleshooting](./docs/troubleshooting.md) β Common issues & solutions
## π€ Contributing
We welcome contributions! See [CONTRIBUTING.md](./CONTRIBUTING.md) for guidelines.
```bash
# Development setup
git clone https://github.com/debugmcp/mcp-debugger.git
cd mcp-debugger
# Install dependencies and vendor debug adapters
pnpm install
# All debug adapters (JavaScript js-debug, Rust CodeLLDB) are automatically downloaded
# Build the project
pnpm build
# Run tests
pnpm test
# Check adapter vendoring status
pnpm vendor:status
# Force re-vendor all adapters (if needed)
pnpm vendor:force
```
### Debug Adapter Vendoring
The project automatically vendors debug adapters during `pnpm install`:
- **JavaScript**: Downloads Microsoft's js-debug from GitHub releases
- **Rust**: Downloads CodeLLDB binaries for the current platform
- **CI Environment**: Set `SKIP_ADAPTER_VENDOR=true` to skip vendoring
To manually manage adapters:
```bash
# Check current vendoring status
pnpm vendor:status
# Re-vendor all adapters
pnpm vendor
# Clean and re-vendor (force)
pnpm vendor:force
# Clean vendor directories only
pnpm clean:vendor
```
### Running Container Tests Locally
We use [Act](https://github.com/nektos/act) to run GitHub Actions workflows locally:
```bash
# Build the Docker image first
docker build -t mcp-debugger:local .
# Run tests with Act (use WSL2 on Windows)
act -j build-and-test --matrix os:ubuntu-latest
```
See [tests/README.md](./tests/README.md) for detailed testing instructions.
## π Project Status
- β
**Production Ready**: v0.17.0 with Rust adapter (Alpha), richer stepping responses, and polished JavaScript distribution
- β
**1019 tests** passing end-to-end
- β
**Clean architecture** with adapter pattern
- π¨ **JavaScript/Node.js**: Alpha support with full debugging loop
- π§ **Coming Soon**: Go, Ruby, and more language adapters
- π **Active Development**: Regular updates and improvements
See [Roadmap.md](./Roadmap.md) for planned features.
## π License
MIT License - see [LICENSE](./LICENSE) for details.
## π Acknowledgments
Built with:
- [Model Context Protocol](https://github.com/anthropics/model-context-protocol) by Anthropic
- [Debug Adapter Protocol](https://microsoft.github.io/debug-adapter-protocol/) by Microsoft
- [debugpy](https://github.com/microsoft/debugpy) for Python debugging
---
**Give your AI the power to debug like a developer β in any language!** π―