lazy-calculator
A deliberately broken calculator MCP server that always returns double the correct answer, designed as a learning exercise for MCP server implementation.
README
🦥 Lazy Calculator MCP Server
A Model Context Protocol (MCP) server that creates a hilariously wrong calculator - it always doubles the actual answer! Built as a learning exercise for understanding MCP server implementation with Claude Desktop.
📋 Table of Contents
- Overview
- What You'll Learn
- Prerequisites
- Installation
- Claude Desktop Configuration
- Troubleshooting Guide
- Developer Cheat Sheet
- Architecture Deep Dive
- Common Issues & Solutions
🎯 Overview
The Lazy Calculator is an MCP server that:
- Parses natural language math questions
- Calculates the correct answer
- Returns double the actual result (because it's "lazy")
- Demonstrates proper MCP server implementation patterns
Example Usage
- Input: "What is 5 + 5?"
- Output: "The answer is 20 (definitely not 10... wink)"
🎓 What You'll Learn
This repository demonstrates:
- MCP Server Implementation - Using the standard MCP SDK (not FastMCP)
- Python Virtual Environments - Required for macOS due to system Python restrictions
- Safe Math Expression Evaluation - Using Python's AST module
- Natural Language Processing - Basic pattern matching for math questions
- Claude Desktop Integration - Proper configuration and debugging
📦 Prerequisites
System Requirements
- macOS (tested) or Linux/Windows (may need path adjustments)
- Python 3.8+ (Python 3.13 tested)
- Claude Desktop app installed
- Homebrew (for macOS users)
Required Software
# Check Python version
python3 --version
# Install Python via Homebrew if needed (macOS)
brew install python@3.13
🚀 Installation
Step 1: Clone the Repository
git clone https://github.com/YOUR_USERNAME/lazy-calculator-mcp.git
cd lazy-calculator-mcp
Step 2: Create Virtual Environment
# Create virtual environment (REQUIRED on macOS)
python3 -m venv mcp_venv
# Activate the virtual environment
source mcp_venv/bin/activate
# Install dependencies
pip install mcp
Step 3: Make Scripts Executable
chmod +x lazy_calculator_server.py
chmod +x run_lazy_calculator.sh
Step 4: Update the Wrapper Script
Edit run_lazy_calculator.sh and update the path to match your installation:
#!/bin/bash
cd "/path/to/your/lazy-calculator-mcp" # UPDATE THIS PATH
source mcp_venv/bin/activate
exec python lazy_calculator_server.py
⚙️ Claude Desktop Configuration
Configuration File Location
- macOS:
~/Library/Application Support/Claude/claude_desktop_config.json - Windows:
%APPDATA%\Claude\claude_desktop_config.json - Linux:
~/.config/Claude/claude_desktop_config.json
Add to Configuration
{
"mcpServers": {
"lazy-calculator": {
"command": "/path/to/your/lazy-calculator-mcp/run_lazy_calculator.sh",
"args": [],
"env": {}
}
}
}
⚠️ IMPORTANT: Update the path to match where you cloned this repository!
Restart Claude Desktop
After updating the configuration, completely quit and restart Claude Desktop.
🔍 Troubleshooting Guide
Critical Log File Locations
When debugging MCP servers with Claude Desktop, these are the essential files:
1. Main Application Log
# macOS
~/Library/Logs/Claude/main.log
# View recent entries
tail -f ~/Library/Logs/Claude/main.log
2. MCP Server Specific Log
# macOS - Each MCP server gets its own log
~/Library/Logs/Claude/mcp-server-lazy-calculator.log
# Monitor in real-time
tail -f ~/Library/Logs/Claude/mcp-server-lazy-calculator.log
3. Configuration File
# View current configuration
cat ~/Library/Application\ Support/Claude/claude_desktop_config.json
# Edit configuration
nano ~/Library/Application\ Support/Claude/claude_desktop_config.json
Common Error Messages & Solutions
Error: "spawn python ENOENT"
Problem: System can't find python command
Solution: Use python3 or full path /opt/homebrew/bin/python3
Error: "ModuleNotFoundError: No module named 'mcp'"
Problem: MCP not installed or wrong Python environment Solution: Ensure virtual environment is activated and mcp is installed
Error: "unhandled errors in a TaskGroup"
Problem: FastMCP compatibility issue or missing initialization parameters
Solution: Use standard MCP SDK with proper capabilities field
Error: "Extension lazy-calculator not found in installed extensions"
Problem: Normal warning - custom servers aren't "extensions" Solution: This can be safely ignored
Testing Your Server Manually
# Test the server directly
cd /path/to/lazy-calculator-mcp
source mcp_venv/bin/activate
echo '{"jsonrpc": "2.0", "method": "initialize", "params": {"protocolVersion": "2025-06-18", "capabilities": {}, "clientInfo": {"name": "test", "version": "1.0"}}, "id": 1}' | python lazy_calculator_server.py
Expected response:
{"jsonrpc":"2.0","id":1,"result":{"protocolVersion":"2025-06-18","capabilities":{"tools":{}},"serverInfo":{"name":"lazy-calculator","version":"1.0.0"}}}
🛠️ Developer Cheat Sheet
Quick Commands for Claude Code Assistance
When working with Claude Code to debug MCP servers, provide these paths:
## Paths for Claude Code Debugging
### View MCP Server Log
/Users/YOUR_USERNAME/Library/Logs/Claude/mcp-server-lazy-calculator.log
### View Main Application Log
/Users/YOUR_USERNAME/Library/Logs/Claude/main.log
### Edit Configuration
/Users/YOUR_USERNAME/Library/Application Support/Claude/claude_desktop_config.json
### Server Location
/path/to/your/lazy-calculator-mcp/lazy_calculator_server.py
Debugging Workflow
-
Check if server is listed in Claude Desktop
- Look for "lazy-calculator" in the MCP servers section
-
Monitor logs during connection
# Terminal 1: Watch main log tail -f ~/Library/Logs/Claude/main.log | grep lazy-calculator # Terminal 2: Watch server log tail -f ~/Library/Logs/Claude/mcp-server-lazy-calculator.log -
Test server independently
cd /path/to/lazy-calculator-mcp ./run_lazy_calculator.sh # Should run without errors
🏗️ Architecture Deep Dive
File Structure
lazy-calculator-mcp/
├── lazy_calculator_server.py # Main MCP server implementation
├── run_lazy_calculator.sh # Wrapper script for virtual environment
├── requirements.txt # Python dependencies (just 'mcp')
├── mcp_venv/ # Virtual environment (created during setup)
└── README.md # This file
Key Components
1. Server Initialization
from mcp.server import Server
from mcp.server.models import InitializationOptions
from mcp.types import ServerCapabilities
server = Server("lazy-calculator")
# Critical: Must include capabilities field
InitializationOptions(
server_name="lazy-calculator",
server_version="1.0.0",
capabilities=ServerCapabilities(tools={})
)
2. Tool Registration
@server.list_tools()
async def handle_list_tools() -> list[Tool]:
return [Tool(...)]
@server.call_tool()
async def handle_call_tool(name: str, arguments: dict) -> list[TextContent]:
# Handle tool execution
3. Safe Math Evaluation
- Uses Python's
astmodule for safe expression parsing - No
eval()orexec()- prevents code injection - Whitelist of allowed operations and functions
4. Natural Language Processing
- Regex-based pattern matching
- Word-to-number conversion
- Operation keyword detection
MCP Protocol Flow
- Initialize → Server receives protocol version and capabilities
- List Tools → Server returns available tools
- Call Tool → Server executes requested tool with arguments
- Return Result → Server sends formatted response
🐛 Common Issues & Solutions
Issue 1: Python Path Problems on macOS
The Journey:
- macOS uses system Python which is protected
pip installfails with "externally-managed-environment"- Must use virtual environments
Solution: Always use virtual environment with full path in wrapper script
Issue 2: FastMCP vs Standard MCP
The Journey:
- FastMCP has simpler syntax but caused "TaskGroup" errors
- Standard MCP requires more boilerplate but is more stable
Solution: Use standard MCP SDK with proper initialization
Issue 3: Configuration Not Taking Effect
The Journey:
- Claude Desktop caches configurations
- Hot-reload doesn't always work
Solution: Completely quit Claude Desktop (Cmd+Q) and restart
Issue 4: Server Connects but Immediately Disconnects
The Journey:
- Missing required fields in initialization
- Incorrect protocol version
Solution:
Ensure capabilities field is included in InitializationOptions
📝 Lessons Learned
- Always use virtual environments on macOS - System Python is protected
- Log files are your best friend - Check both main.log and server-specific logs
- Test servers independently first - Use echo/pipe to test before Claude Desktop
- FastMCP isn't always faster to implement - Standard SDK is more reliable
- Wrapper scripts solve environment issues - Activate venv before running Python
- Configuration requires full restart - Claude Desktop doesn't hot-reload MCP servers
🤝 Contributing
Feel free to submit issues and enhancement requests!
📄 License
MIT License - See LICENSE file for details
🙏 Acknowledgments
- Built while learning MCP with Claude Code
- Thanks to Anthropic for the MCP protocol
- Inspired by the need to understand MCP server implementation
Remember: This calculator is intentionally wrong! It's a learning tool, not for actual calculations. 🦥
Quick Start for Claude Code Users
If you're using Claude Code to work with this repository:
- Clone the repo
- Tell Claude Code these paths:
Config: ~/Library/Application Support/Claude/claude_desktop_config.json Logs: ~/Library/Logs/Claude/mcp-server-lazy-calculator.log - Let Claude Code handle the debugging!
推荐服务器
Baidu Map
百度地图核心API现已全面兼容MCP协议,是国内首家兼容MCP协议的地图服务商。
Playwright MCP Server
一个模型上下文协议服务器,它使大型语言模型能够通过结构化的可访问性快照与网页进行交互,而无需视觉模型或屏幕截图。
Magic Component Platform (MCP)
一个由人工智能驱动的工具,可以从自然语言描述生成现代化的用户界面组件,并与流行的集成开发环境(IDE)集成,从而简化用户界面开发流程。
Audiense Insights MCP Server
通过模型上下文协议启用与 Audiense Insights 账户的交互,从而促进营销洞察和受众数据的提取和分析,包括人口统计信息、行为和影响者互动。
VeyraX
一个单一的 MCP 工具,连接你所有喜爱的工具:Gmail、日历以及其他 40 多个工具。
graphlit-mcp-server
模型上下文协议 (MCP) 服务器实现了 MCP 客户端与 Graphlit 服务之间的集成。 除了网络爬取之外,还可以将任何内容(从 Slack 到 Gmail 再到播客订阅源)导入到 Graphlit 项目中,然后从 MCP 客户端检索相关内容。
Kagi MCP Server
一个 MCP 服务器,集成了 Kagi 搜索功能和 Claude AI,使 Claude 能够在回答需要最新信息的问题时执行实时网络搜索。
e2b-mcp-server
使用 MCP 通过 e2b 运行代码。
Neon MCP Server
用于与 Neon 管理 API 和数据库交互的 MCP 服务器
Exa MCP Server
模型上下文协议(MCP)服务器允许像 Claude 这样的 AI 助手使用 Exa AI 搜索 API 进行网络搜索。这种设置允许 AI 模型以安全和受控的方式获取实时的网络信息。