Skip to main content

MCP Server for DiscoPoP - Enables Claude to interact with DiscoPoP profiling and analysis tools

Project description

DiscoPoP MCP Server

A Model Context Protocol (MCP) server that exposes DiscoPoP functionality to Claude, enabling Claude to execute instrumented code locally and request analysis of profiling data.

Overview

The DiscoPoP MCP Server bridges the gap between Claude and DiscoPoP's profiling and analysis tools. It allows Claude to:

  • Retrieve profiling information from executed instrumented code
  • Execute pattern analysis on profiled data
  • List and discover available profiling data
  • Process results and provide recommendations

Features

  • Standalone CLI executable - Run independently via command line
  • Local deployment - Uses stdio for direct Claude integration
  • Comprehensive logging - View all incoming calls and outgoing responses
  • Type-safe - Full type hints throughout
  • Extensible - Easy to add new tools and capabilities

Installation

Option 1: Install from source (Recommended for development)

cd mcp_server
pip install -e ".[dev]"

Option 2: Install as standalone package

pip install .

Option 3: Direct script usage

python mcp_server/server.py --debug

Quick Start

Run the server

discopop-mcp-server --debug

This starts the server in stdio mode, which is used by Claude. The --debug flag enables verbose logging.

Usage Examples

From the command line

# Basic usage
discopop-mcp-server

# With debug logging
discopop-mcp-server --debug

Integration with Claude Code

Use the automated setup utility for easy integration:

./setup-mcp.sh --setup claude_code

This automatically configures Claude Code to use the server. The setup script handles:

  • Virtual environment detection
  • Configuration directory creation
  • Path resolution

See SETUP_GUIDE.md for more options or CLAUDE_INTEGRATION.md for detailed setup instructions.

Available Tools

1. get_configurations

Retrieves the list of defined execution configurations from a target project.

Parameters:

  • project_path (string, required): Path to the target project

Looks for configuration directories under <project_path>/.discopop/project/configs/.

Example:

{
  "project_path": "./my_project"
}

2. get_execution_results

Retrieves execution results from prior program executions.

Parameters:

  • project_path (string, required): Path to the target project

Reads <project_path>/.discopop/project/execution_results.json.

Example:

{
  "project_path": "./my_project"
}

Logging Output

The server logs all incoming and outgoing communication:

2026-05-19 10:30:00 - discopop-mcp - INFO - Starting DiscoPoP MCP Server (stdio mode)
2026-05-19 10:30:05 - discopop-mcp - INFO - → Incoming call: get_configurations
2026-05-19 10:30:05 - discopop-mcp - DEBUG - Arguments: {"project_path": "./my_project"}
2026-05-19 10:30:05 - discopop-mcp - INFO - ← Outgoing response: get_configurations

Enable --debug for full argument/response logging.

Testing

Run the test suite:

python -m unittest discover -s mcp_server -p "test_*.py" -v

Or with pytest:

pytest mcp_server/test_server.py -v

Architecture

Transport Mode

Uses Stdio Mode for local Claude integration:

  • Bidirectional communication via stdin/stdout
  • Lightweight, no additional dependencies
  • Direct integration with Claude Desktop

Tool Handler Flow

  1. Claude calls a tool
  2. Server logs the incoming call with arguments
  3. Handler processes the request
  4. Server logs the outgoing response
  5. Response returned to Claude

Shipping to Users

Method 1: PyPI Package (Recommended)

  1. Update version in pyproject.toml
  2. Build: python -m build
  3. Publish: python -m twine upload dist/*
  4. Users install: pip install discopop-mcp-server

Method 2: Source Distribution

Include in your DiscoPoP repository:

pip install git+https://github.com/discopop-tool/discopop.git#subdirectory=mcp_server

Method 3: Bundled Binary

Use PyInstaller to create standalone executables:

pip install pyinstaller
pyinstaller --onefile mcp_server/server.py --name discopop-mcp-server

Development

Adding New Tools

  1. Define tool schema in _register_tools():
Tool(
    name="your_tool",
    description="...",
    inputSchema={...}
)
  1. Add handler method:
def _handle_your_tool(self, arguments: dict[str, Any]) -> list[TextContent]:
    self._log_call("your_tool", arguments)
    # Implementation here
    self._log_response("your_tool", result)
    return [TextContent(type="text", text=json.dumps(result))]
  1. Register in tool call handler:
elif name == "your_tool":
    return self._handle_your_tool(arguments)

Type Checking

mypy mcp_server/server.py

Troubleshooting

Claude setup issues

  • Use the setup utility to automatically configure Claude Code:
    ./setup-mcp.sh --setup claude_code
    
  • Verify the setup with:
    ./setup-mcp.sh --verify claude_code
    
  • See CLAUDE_INTEGRATION.md for detailed troubleshooting

Server won't start

  • Check Python version (requires 3.8+)
  • Verify MCP package is installed: pip show mcp
  • Run with --debug for detailed error messages

Claude can't connect

  • Verify server is running: discopop-mcp-server --debug
  • Check claude configuration points to correct command
  • Ensure stdio mode is being used (default)
  • Use the setup utility to fix configuration:
    ./setup-mcp.sh --status
    

Missing dependencies

# Install all dependencies
pip install -e ".[dev,sse]"

License

This software is part of DiscoPoP and is licensed under the 3-Clause BSD License. See the LICENSE file in the package base directory for details.

Support

For issues, questions, or contributions:

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

discopop_mcp_server-0.0.1a1.tar.gz (5.9 kB view details)

Uploaded Source

Built Distribution

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

discopop_mcp_server-0.0.1a1-py3-none-any.whl (6.5 kB view details)

Uploaded Python 3

File details

Details for the file discopop_mcp_server-0.0.1a1.tar.gz.

File metadata

  • Download URL: discopop_mcp_server-0.0.1a1.tar.gz
  • Upload date:
  • Size: 5.9 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/6.2.0 CPython/3.12.3

File hashes

Hashes for discopop_mcp_server-0.0.1a1.tar.gz
Algorithm Hash digest
SHA256 22d6b59a12dc96f4508a9c00216620938d115a30926f722799e0d6a3cdc89e4f
MD5 0811883ee66f71ebef9f52541f4ff602
BLAKE2b-256 c8108b6ea1a4cf70e82ea3cab14c0c9f1b4fcaa2157dc36c5780178bdb393acb

See more details on using hashes here.

File details

Details for the file discopop_mcp_server-0.0.1a1-py3-none-any.whl.

File metadata

File hashes

Hashes for discopop_mcp_server-0.0.1a1-py3-none-any.whl
Algorithm Hash digest
SHA256 faef4493d3214634e6d841ca7da66cf47d58ab24b76bb231ed60c331615b6263
MD5 c2941e44afd1f45263e2fd13c5a88e7d
BLAKE2b-256 7b0471ef8d6c0bade0456533c048dead1bc9a7cf54aa9fe01fe6ece08f5af0d1

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