Skip to main content

MCP server for multi-language debugging with AI agents via DAP (Python, Go, Rust, Node.js)

Project description

polybugger-mcp

PyPI version License: MIT Tests Python 3.10+

A lightweight, pure-Python MCP server for interactive debugging. Uses debugpy (VS Code's debugger) under the hood for reliable, battle-tested debugging.

Install in Cursor Install in VS Code

Demo

polybugger-mcp demo

Why polybugger-mcp?

Feature polybugger-mcp Other MCP debuggers
Session Recovery Resume debugging after server restart Not available
Watch Expressions Track values across debug steps Planned for 2026
Pure Python Single pip install, no Node.js Requires Node.js runtime
HTTP API Use independently of MCP MCP-only
Lightweight ~50KB, minimal dependencies ~3MB+ bundled

Key Features

  • Session Recovery - Persist debug state and resume after server restart
  • Watch Expressions - Define expressions to track across every debug step
  • Smart Data Inspection - Intelligent preview of DataFrames, NumPy arrays, dicts, and lists
  • Call Hierarchy - Visualize the complete call chain with source context
  • Full Interactive Debugging - Breakpoints, stepping, pause/continue
  • Variable Inspection - View locals, globals, evaluate arbitrary expressions
  • Rich TUI Output - ASCII box-drawn tables and diagrams for better visualization
  • Pure Python - No Node.js required, just pip install
  • Dual Interface - Use via MCP or standalone HTTP API
  • Multi-Client Support - Cursor, VS Code, Claude Desktop, and more

Installation

Quick Install (no clone required)

Using uvx (recommended):

uvx polybugger-mcp

Using pipx:

pipx run polybugger-mcp

Using pip:

pip install polybugger-mcp
polybugger-mcp

MCP Client Configuration

Configure your MCP client to use one of these commands:

Cursor

Add to ~/.cursor/mcp.json:

{
  "mcpServers": {
    "python-debugger": {
      "command": "uvx",
      "args": ["polybugger-mcp"]
    }
  }
}
Alternative: using pip install
{
  "mcpServers": {
    "python-debugger": {
      "command": "python",
      "args": ["-m", "polybugger_mcp.mcp_server"]
    }
  }
}
VS Code

Use the VS Code CLI:

code --add-mcp '{"name":"python-debugger","command":"uvx","args":["polybugger-mcp"]}'

Or add to your MCP settings manually.

Claude Code
claude mcp add python-debugger -- uvx polybugger-mcp
Claude Desktop

Add to your Claude Desktop config (~/Library/Application Support/Claude/claude_desktop_config.json on macOS):

{
  "mcpServers": {
    "python-debugger": {
      "command": "uvx",
      "args": ["polybugger-mcp"]
    }
  }
}
OpenCode

Add to ~/.config/opencode/opencode.json:

{
  "mcp": {
    "python-debugger": {
      "type": "local",
      "command": ["uvx", "polybugger-mcp"],
      "enabled": true
    }
  }
}
Windsurf

Add to your Windsurf MCP config:

{
  "mcpServers": {
    "python-debugger": {
      "command": "uvx",
      "args": ["polybugger-mcp"]
    }
  }
}
Cline

Add to your cline_mcp_settings.json:

{
  "mcpServers": {
    "python-debugger": {
      "command": "uvx",
      "args": ["polybugger-mcp"],
      "disabled": false
    }
  }
}
Goose

Go to Settings > Extensions > Add custom extension:

  • Type: STDIO
  • Command: uvx polybugger-mcp
Docker
docker run -i --rm ghcr.io/wilfoa/polybugger-mcp

Or in your MCP config:

{
  "mcpServers": {
    "python-debugger": {
      "command": "docker",
      "args": ["run", "-i", "--rm", "ghcr.io/wilfoa/polybugger-mcp"]
    }
  }
}

Available Tools (23 tools)

Session Management

Tool Description
debug_create_session Create a new debug session for a project
debug_list_sessions List all active debug sessions
debug_get_session Get detailed session information
debug_terminate_session End a debug session and clean up

Breakpoints

Tool Description
debug_set_breakpoints Set breakpoints in source files (with optional conditions)
debug_get_breakpoints List all breakpoints for a session
debug_clear_breakpoints Remove breakpoints from files

Execution Control

Tool Description
debug_launch Launch a Python program for debugging
debug_continue Continue execution until next breakpoint
debug_step Step execution: mode="over" (next line), "into" (enter function), "out" (exit function)
debug_pause Pause a running program

Inspection

Tool Description
debug_get_stacktrace Get the current call stack (supports TUI format)
debug_get_scopes Get variable scopes (locals, globals)
debug_get_variables Get variables in a scope (supports TUI format)
debug_evaluate Evaluate a Python expression
debug_inspect_variable Smart inspection of DataFrames, arrays, dicts with metadata
debug_get_call_chain Call hierarchy with source context for each frame

Watch Expressions

Tool Description
debug_watch Manage watches: action="add", "remove", or "list"
debug_evaluate_watches Evaluate all watch expressions

Events & Output

Tool Description
debug_poll_events Poll for debug events (stopped, terminated, etc.)
debug_get_output Get program stdout/stderr

Recovery

Tool Description
debug_list_recoverable List sessions that can be recovered
debug_recover_session Recover a session from previous server run

Quick Start

  1. Install the package:

    pip install polybugger-mcp
    
  2. Configure your MCP client (see Installation above)

  3. Start debugging: Ask your AI assistant:

    "Debug my script.py - set a breakpoint on line 15 and show me the variables when it stops"

Example Workflows

Basic Debugging

You: Debug tests/test_example.py - I want to see why the calculate function returns wrong results

AI: I'll create a debug session and set breakpoints in the calculate function.
    [Creates session, sets breakpoints, launches program]

    The program stopped at line 23. Here are the local variables:
    - x = 10
    - y = 5
    - result = 50  # This should be 15!

    I see the issue - you're using multiplication instead of addition on line 24.

Data Science Debugging

You: Debug my data pipeline and inspect the DataFrame at line 45

AI: [Sets breakpoint, launches program]

    The DataFrame `df` has 1000 rows x 5 columns (78.1 KB):

    ┌────────────┬────────────────┬────────┐
    │ Name       │ Type           │ Nulls  │
    ├────────────┼────────────────┼────────┤
    │ id         │ int64          │ -      │
    │ name       │ object         │ 5      │
    │ value      │ float64        │ 12     │
    └────────────┴────────────────┴────────┘

    I found 17 null values. The `value` column has NaN entries that may cause issues.

Call Hierarchy Visualization

You: Show me how we got to this breakpoint

AI: [Uses debug_get_call_chain with format="tui"]

    CALL CHAIN (4 frames)
    ════════════════════════════════════════════════════════════

    main (app.py:50)
    │ >> 50 │     result = process_order(order)
    │
    └─▶ process_order (orders.py:76)
        │ >> 76 │     pricing = apply_pricing(items, tier)
        │
        └─▶ apply_pricing (pricing.py:58)
            │ >> 58 │     discount = calculate_discount(subtotal)
            │
            └─▶ calculate_discount (pricing.py:23)  ◀── YOU ARE HERE
                │ >> 23 │     return base * rate

Configuration

Environment variables (prefix with PYBUGGER_MCP_):

Variable Default Description
HOST 127.0.0.1 Server bind address
PORT 5679 Server port (for HTTP mode)
MAX_SESSIONS 10 Maximum concurrent debug sessions
SESSION_TIMEOUT_SECONDS 3600 Session idle timeout (1 hour)
DATA_DIR ~/.polybugger-mcp Data directory for persistence
LOG_LEVEL INFO Logging level

Development

# Clone and setup
git clone https://github.com/wilfoa/polybugger-mcp.git
cd polybugger-mcp
python -m venv .venv
source .venv/bin/activate
pip install -e ".[dev]"

# Run tests
make test

# Run linter
make lint

# Run type checker
make typecheck

Architecture

AI Agent  <-->  MCP Server  <-->  debugpy (DAP)  <-->  Python Process

The MCP server translates tool calls to Debug Adapter Protocol (DAP) messages, enabling full debugging capabilities through natural language.

Requirements

  • Python 3.10 or higher
  • Works on macOS, Linux, and Windows

Contributing

Contributions are welcome! Please see CONTRIBUTING.md for guidelines.

License

MIT License - see LICENSE for details.

Project details


Download files

Download the file for your platform. If you're not sure which to choose, learn more about installing packages.

Source Distribution

polybugger_mcp-1.6.0.tar.gz (72.1 kB view details)

Uploaded Source

Built Distribution

If you're not sure about the file name format, learn more about wheel file names.

polybugger_mcp-1.6.0-py3-none-any.whl (93.8 kB view details)

Uploaded Python 3

File details

Details for the file polybugger_mcp-1.6.0.tar.gz.

File metadata

  • Download URL: polybugger_mcp-1.6.0.tar.gz
  • Upload date:
  • Size: 72.1 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/6.1.0 CPython/3.13.7

File hashes

Hashes for polybugger_mcp-1.6.0.tar.gz
Algorithm Hash digest
SHA256 e8ed2f35c1d6debfa796b02cb65908ca62dd3fad952c61ab43cf8310dc1931f5
MD5 b4b053ced31bbadeb4d0252dc8728b1b
BLAKE2b-256 8c9ae386d8904ce9ed91ac9a4fd34de8ba8bbe7f311b80e2cd66f4addbba5193

See more details on using hashes here.

File details

Details for the file polybugger_mcp-1.6.0-py3-none-any.whl.

File metadata

  • Download URL: polybugger_mcp-1.6.0-py3-none-any.whl
  • Upload date:
  • Size: 93.8 kB
  • Tags: Python 3
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/6.1.0 CPython/3.13.7

File hashes

Hashes for polybugger_mcp-1.6.0-py3-none-any.whl
Algorithm Hash digest
SHA256 348630ac45c5a5fc885571bb3a10601140845da669b39d2b5fd6ced0736f5aff
MD5 1dd2926f64a9c9ac1176bdcbad6fd924
BLAKE2b-256 19aa4c6d23b435d772ba7af385696f82a589312454fbae1d1b3bfa08ea761389

See more details on using hashes here.

Supported by

AWS Cloud computing and Security Sponsor Datadog Monitoring Depot Continuous Integration Fastly CDN Google Download Analytics Pingdom Monitoring Sentry Error logging StatusPage Status page