Calculator MCP Server
Provides basic arithmetic operations (add, multiply, divide) for AI assistants through the Model Context Protocol.
README
Calculator MCP Server
A Model Context Protocol (MCP) server that provides mathematical calculation tools for AI assistants.
Features
This MCP server provides three core mathematical operations:
- Add - Add two numbers together with calculation history tracking
- Multiply - Multiply two numbers with optimized performance
- Divide - Divide numbers with comprehensive zero-division protection
The server maintains a calculation history and provides robust error handling for all mathematical operations.
Prerequisites
- Node.js (version 14 or higher)
- npm or yarn package manager
Installation
-
Clone or download this repository
-
Navigate to the project directory:
cd my-first-mcp-server -
Install dependencies:
npm install -
Build the TypeScript code:
npm run build
Running the Server
Development Mode
For development and testing:
npm run dev
Production Mode
For production use:
npm run start
Testing the Server
You can test if the server is working by sending an MCP request:
echo '{"jsonrpc": "2.0", "id": 1, "method": "tools/list"}' | node dist/server.js
This should return a JSON response listing the available tools.
Integration with AI Clients
Cursor IDE
-
Create a
.cursor/mcp.jsonfile in your project root:{ "mcpServers": { "calculator": { "command": "node", "args": [ "/absolute/path/to/my-first-mcp-server/dist/server.js" ], "env": {} } } } -
Replace
/absolute/path/to/my-first-mcp-server/with the actual path to this directory -
Restart Cursor IDE
-
The calculator tools will be available to the AI assistant
Claude Desktop
-
Create or edit
~/Library/Application Support/Claude/claude_desktop_config.json:{ "mcpServers": { "calculator": { "command": "node", "args": ["/absolute/path/to/my-first-mcp-server/dist/server.js"] } } } -
Replace the path with your actual directory path
-
Restart Claude Desktop
Development
To modify or extend the calculator functionality:
- Edit the source files in the
src/directory - Rebuild the project:
npm run build - Test your changes:
npm run dev
Configuration
The server can be configured using environment variables. Copy .env.example to .env and modify as needed.
Available configuration options:
NODE_ENV: Environment mode (development/production)PORT: Server port (default: 3000)LOG_LEVEL: Logging verbosityDB_*: Database connection settings
Docker Support
You can run the entire stack using Docker Compose:
docker-compose up -d
This will start:
- Calculator MCP Server
- PostgreSQL database (for calculation history)
- Redis cache
- Database administration interface
Contributing
- Fork the repository
- Create a feature branch
- Make your changes
- Add tests for new functionality
- Submit a pull request
License
This project is licensed under the ISC License.
Available Tools
add
Adds two numbers together.
Parameters:
a(number): First numberb(number): Second number
Example: add(25, 17) returns 42
multiply
Multiplies two numbers.
Parameters:
a(number): First numberb(number): Second number
Example: multiply(6, 7) returns 42
divide
Divides the first number by the second number.
Parameters:
a(number): Dividend (number to divide)b(number): Divisor (divide by this)
Example: divide(84, 2) returns 42
Note: Division by zero will return an error.
Using in Other Projects
Option 1: Absolute Path Reference
In any project where you want to use this calculator:
- Create
.cursor/mcp.jsonin that project's root - Reference the absolute path to this server's
dist/server.js - Restart your IDE
Option 2: Copy to Project
# Copy the entire MCP server to your project
cp -r /path/to/my-first-mcp-server /path/to/your-project/mcp-servers/calculator
# Update .cursor/mcp.json to use relative path:
{
"mcpServers": {
"calculator": {
"command": "node",
"args": ["./mcp-servers/calculator/dist/server.js"],
"env": {}
}
}
}
Option 3: NPM Package (Advanced)
You can publish this as an npm package for easier distribution:
- Update
package.jsonwith your package details - Run
npm publish - In other projects:
npm install your-calculator-mcp - Use
npx your-calculator-mcpin MCP configuration
Development
Scripts
npm run build- Compile TypeScript to JavaScriptnpm run dev- Run in development mode with tsxnpm run start- Run the compiled server
File Structure
my-first-mcp-server/
├── src/
│ └── server.ts # Main server implementation
├── dist/
│ └── server.js # Compiled JavaScript (generated)
├── .cursor/
│ └── mcp.json # Local MCP configuration
├── package.json # Node.js dependencies and scripts
├── tsconfig.json # TypeScript configuration
└── README.md # This file
Troubleshooting
Server Not Connecting
- Ensure the path in
.cursor/mcp.jsonis correct and absolute - Verify the server builds successfully:
npm run build - Test the server manually:
echo '{"jsonrpc": "2.0", "id": 1, "method": "tools/list"}' | node dist/server.js - Restart your IDE after configuration changes
Tools Not Available
- Check that
.cursor/mcp.jsonis in the root of your working project - Ensure you're opening the correct project in your IDE
- Wait a few seconds after opening for MCP to initialize
- Check IDE developer console for MCP-related errors
Permission Issues
# Make sure the server file is executable
chmod +x dist/server.js
Server Details
- Protocol: Model Context Protocol (MCP)
- Transport: Standard I/O (stdio)
- Language: TypeScript/Node.js
- Framework: @modelcontextprotocol/sdk
License
ISC
Contributing
Feel free to extend this server with additional mathematical operations or features!
Recommended Servers
playwright-mcp
A Model Context Protocol server that enables LLMs to interact with web pages through structured accessibility snapshots without requiring vision models or screenshots.
Magic Component Platform (MCP)
An AI-powered tool that generates modern UI components from natural language descriptions, integrating with popular IDEs to streamline UI development workflow.
Audiense Insights MCP Server
Enables interaction with Audiense Insights accounts via the Model Context Protocol, facilitating the extraction and analysis of marketing insights and audience data including demographics, behavior, and influencer engagement.
VeyraX MCP
Single MCP tool to connect all your favorite tools: Gmail, Calendar and 40 more.
graphlit-mcp-server
The Model Context Protocol (MCP) Server enables integration between MCP clients and the Graphlit service. Ingest anything from Slack to Gmail to podcast feeds, in addition to web crawling, into a Graphlit project - and then retrieve relevant contents from the MCP client.
Kagi MCP Server
An MCP server that integrates Kagi search capabilities with Claude AI, enabling Claude to perform real-time web searches when answering questions that require up-to-date information.
E2B
Using MCP to run code via e2b.
Neon Database
MCP server for interacting with Neon Management API and databases
Exa Search
A Model Context Protocol (MCP) server lets AI assistants like Claude use the Exa AI Search API for web searches. This setup allows AI models to get real-time web information in a safe and controlled way.
Qdrant Server
This repository is an example of how to create a MCP server for Qdrant, a vector search engine.