mcp-server-mercurial
Enables AI assistants to interact with Mercurial repositories, supporting status checks, commits, topic-based workflows, and advanced operations like rebase and evolve.
README
Mercurial MCP Server
A Model Context Protocol server for Mercurial repository interaction and automation. This server provides tools to read, search, and manipulate Mercurial repositories via Large Language Models, with a focus on topic-based development workflows.
Features
Core Operations
hg_status- Shows working directory statushg_diff- Shows uncommitted changeshg_diff_staged- Shows all uncommitted changes (Mercurial has no staging area)hg_diff_rev- Shows changes introduced by a specific changesethg_commit- Records changes to the repositoryhg_add- Adds new files to version controlhg_remove- Removes files from version controlhg_move- Moves or renames fileshg_revert- Reverts uncommitted changeshg_log- Shows commit history
Topic-Based Development (Recommended)
hg_topic- Creates a new topichg_topics- Lists all topicshg_topic_current- Shows the current topichg_update- Updates to a different topic, branch, or revisionhg_stack- Shows the current topic stack
Advanced Operations
hg_rebase- Rebases changes onto a destination (preferred over merge)hg_evolve- Evolves the repository to resolve instabilities
Installation
From source
git clone <repository>
cd mcp-mercurial-server
npm install
npm run build
npm link
Configuration
Claude Desktop
If you installed from source:
{
"mcpServers": {
"mercurial": {
"command": "mcp-server-mercurial"
}
}
}
Usage Examples
Basic Workflow
1. Check status: hg_status
2. View changes: hg_diff
3. Add new files: hg_add (files: ["file1.cpp"])
4. Remove files: hg_remove (files: ["file3.cpp"])
5. Move/rename files: hg_move (source: "file2.cpp", destination: "file4.cpp")
6. Commit with detailed message and explicit files:
hg_commit (
message: "Your commit message\n\n- Added a #1 file\n- Got rid of a file named 3 because it was useless\n- Fixed naming of file 4",
files: ["file1.cpp", "file3.cpp", "file4.cpp"]
)
Checking Current State
# Get the current topic
hg_topic_current
# See the last 5 commits (default)
hg_log
# Get topic name using template
hg_log (max_count: 1, template: "{topic}")
Topic-Based Development
1. Create topic: hg_topic (topic_name: "feature-xyz")
2. Work on changes...
3. Commit to topic: hg_commit (message: "Implement feature XYZ", files: ["feature.cpp"])
4. Rebase topic: hg_rebase (destination: "default")
Requirements
- Node.js 18 or higher
- Mercurial installed and available in PATH
- Mercurial extensions (recommended):
topicsextension for topic-based workflowsevolveextension for history management
Development
# Install dependencies
npm install
# Run in development mode
npm run dev
# Build
npm run build
# Run tests
npm test
# Lint
npm run lint
# Format
npm run format
Debugging
Use the MCP inspector to debug the server:
npx @modelcontextprotocol/inspector npx mcp-server-mercurial
Key Differences from Git
- No Staging Area: All changes are committed directly
- Topics: Lightweight branches for feature development
- Rebase Preferred: Use rebase instead of merge for cleaner history
- Evolve: Safe history editing with the evolve extension
Best Practices
-
Always list files explicitly in commits - Don't rely on implicit file selection
-
Use multi-line commit messages with bullet points for clarity:
Main description - First change detail - Second change detail - Third change detail -
Prefer topics over branches for feature development
-
Check current topic before starting work:
hg_topic_current -
Review recent commits with
hg_log(defaults to last 5)
License
MIT
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
Qdrant Server
This repository is an example of how to create a MCP server for Qdrant, a vector search engine.
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.