mcp-server-analyzer
Provides comprehensive Python linting with auto-fixes using Ruff.
Click on "Install Server".
Wait a few minutes for the server to deploy. Once ready, it will show a "Started" state.
In the chat, type
@followed by the MCP server name and your instructions, e.g., "@mcp-server-analyzeranalyze code quality of my Python script"
That's it! The server will respond to your query, and you can continue using it as needed.
Here is a step-by-step guide with screenshots.
MCP Server Analyzer for Python ๐๐
A powerful Model Context Protocol (MCP) server that provides comprehensive Python code analysis using Ruff for linting, ty for type checking, and Vulture for dead code detection. Perfect for AI assistants, IDEs, and automated code review workflows.
๐ Quick Start
VS Code Integration (One-Click Install)
For quick installation, use one of the one-click install buttons below...
For manual installation, add the following JSON block to your User Settings (JSON) file in VS Code. You can do this by pressing Ctrl + Shift + P and typing Preferences: Open User Settings (JSON).
Optionally, you can add it to a file called .vscode/mcp.json in your workspace. This will allow you to share the configuration with others.
Note that the
mcpkey is needed when using themcp.jsonfile.
Using uvx (recommended):
{
"mcp": {
"servers": {
"analyzer": {
"command": "uvx",
"args": ["mcp-server-analyzer"]
}
}
}
}Using Docker:
{
"mcp": {
"servers": {
"analyzer": {
"command": "docker",
"args": ["run", "-i", "--rm", "ghcr.io/anselmoo/mcp-server-analyzer"]
}
}
}
}Universal Installation
# Install with uvx (recommended)
uvx install mcp-server-analyzer
# Install with pip
pip install mcp-server-analyzer
# Run with Docker
docker run ghcr.io/anselmoo/mcp-server-analyzer:latest
# Install from source
git clone https://github.com/anselmoo/mcp-server-analyzer.git
cd mcp-server-analyzer
uv sync --dev
uv run mcp-server-analyzer๐ Features
๐ RUFF Analysis: Comprehensive Python linting with auto-fixes
๐ง ty Type Checking: Fast Python type analysis with rule-based diagnostics
๐งน Dead Code Detection: Find unused imports, functions, and variables with VULTURE
๐ Quality Scoring: Combined analysis with quality metrics
๐ FastMCP Framework: High-performance MCP server implementation
๐ณ Docker Ready: Multi-architecture containers with security signing
๐ Secure: All releases signed with Sigstore for supply chain security
๐ Analysis Examples
RUFF Linting Preview
See comprehensive linting analysis examples: ๐ RUFF Analysis Preview
VULTURE Dead Code Detection Preview
Explore dead code detection capabilities: ๐งน VULTURE Analysis Preview
๐ ๏ธ Available Tools
Tool | Description | Use Case |
| Lint Python code with RUFF | Style violations, potential errors |
| Format Python code with RUFF | Code formatting and consistency |
| CI/CD optimized RUFF output | GitHub Actions, GitLab CI |
| Type-check Python code with ty | Type safety, incorrect return values |
| Dead code detection | Unused imports, functions, variables |
| Combined Ruff + ty + Vulture analysis | Complete code quality assessment |
๐ง Configuration
Claude Desktop
Add to your claude_desktop_config.json:
{
"mcpServers": {
"analyzer": {
"command": "uvx",
"args": ["mcp-server-analyzer"]
}
}
}Zed
Add to your Zed settings.json:
"context_servers": {
"analyzer": {
"command": "uvx",
"args": ["mcp-server-analyzer"]
}
}Claude Code (project-level)
Place .mcp.json at your project root:
{
"mcpServers": {
"analyzer": {
"command": "uvx",
"args": ["mcp-server-analyzer"]
}
}
}๐งช Development
Prerequisites
Setup
# Clone repository
git clone https://github.com/anselmoo/mcp-server-analyzer.git
cd mcp-server-analyzer
# Install dependencies
uv sync --dev
# Run tests
uv run pytest
# Run type checks
uv run ty check src tests
# Run pre-commit hooks
uv tool run pre-commit run --all-files
# Build Docker image
docker build -t mcp-server-analyzer .Testing
# Run all tests
uv run pytest tests/ -v
# Run with coverage
uv run pytest --cov=src/mcp_server_analyzer --cov-report=html
# Test specific functionality
uv run pytest tests/test_server.py::TestAnalyzers::test_ruff_with_sample_code๐ Quality Metrics
The server provides quality scoring based on:
Ruff Issues: Style violations, potential bugs, complexity metrics
ty Diagnostics: Static typing errors and warnings
Dead Code Detection: Unused imports, functions, variables
Combined Score: Weighted quality assessment (0-100)
๐ Security
Signed Releases: All releases signed with Sigstore
Container Signing: Docker images signed with Cosign
Trusted Publishing: PyPI releases use GitHub OIDC trusted publishing
Vulnerability Scanning: Automated security scanning in CI/CD
Supply Chain Security: SLSA Build Level 3 compliance
Security Policy: See SECURITY.md for vulnerability reporting
๐ Data Handling & Transparency
In-memory only: Code passed to tools is written to a temporary file, analyzed, and the file is deleted immediately โ nothing is persisted between calls.
No network calls: The server makes no outbound network connections during analysis.
No telemetry: No usage data, analytics, or crash reports are collected.
Subprocess isolation: ruff, ty, and vulture are invoked with fixed argument lists โ no shell expansion or arbitrary command execution.
๐ Documentation
Full Documentation - GitHub Pages docs
Tools Reference - Detailed tool parameters and return types
MCP Specification - Learn about Model Context Protocol
FastMCP Framework - High-performance MCP implementation
Ruff Documentation - Python linter and formatter
ty Documentation - Python type checker and language server
Vulture Documentation - Dead code finder
๐ค Contributing
Contributions are welcome! Please see CONTRIBUTING.md for details.
Fork the repository
Create a feature branch (
git checkout -b feature/amazing-feature)Commit your changes using Conventional Commits
Push to the branch (
git push origin feature/amazing-feature)Open a Pull Request
๐ License
This project is licensed under the MIT License - see the LICENSE file for details.
๐ Acknowledgments
Astral for RUFF and uv
Jendrik Seipp for VULTURE
FastMCP framework
Made with โค๏ธ for better Python code quality
Maintenance
Resources
Unclaimed servers have limited discoverability.
Looking for Admin?
If you are the server author, to access and configure the admin panel.
Latest Blog Posts
MCP directory API
We provide all the information about MCP servers via our MCP API.
curl -X GET 'https://glama.ai/api/mcp/v1/servers/Anselmoo/mcp-server-analyzer'
If you have feedback or need assistance with the MCP directory API, please join our Discord server