Git Stuff Server
This repository contains a Node.js application that acts as an MCP (Model Context Protocol) server to provide Git-related functionalities. Currently, it offers a tool to generate the diff for a Git merge commit against its first parent.
Features
- MCP Server: Runs as a standard MCP server using stdio for communication.
get_git_merge_diffTool:- Accepts a Git merge commit hash.
- Executes the
GenerateMergeDiff.ps1PowerShell script. - Returns the textual diff content generated by
git show -m --first-parent <commitHash>.
Prerequisites
- Node.js (Version supporting ES Modules, check
enginesin package.json if specified, otherwise checktsconfig.jsontarget - ES2022) - npm (usually comes with Node.js)
- Git installed and accessible in the system’s PATH.
- PowerShell (Windows) or
pwsh(Linux/macOS) installed and accessible in the system’s PATH.
Installation
- Clone the repository:
git clone <your-repo-url> cd GitStuffServer - Install dependencies:
npm install
Usage
Build the TypeScript code:
npm run buildThis compiles the TypeScript code from
src/to JavaScript inbuild/.Run the server:
- To run the compiled code:
npm start - To build and run in development mode:
npm run dev
- To run the compiled code:
The server will start and listen for MCP requests on standard input/output.
Using the get_git_merge_diff Tool
When connected via an MCP client, you can call the get_git_merge_diff tool with the following input:
commitHash(string): The Git commit hash (SHA) of the merge commit you want to diff.
The tool will return the diff content as text.
How it Works
- The MCP server (
src/index.ts) receives a request for theget_git_merge_difftool. - It validates the
commitHashinput. - It executes the
GenerateMergeDiff.ps1PowerShell script, passing thecommitHash. - The PowerShell script runs
git show -m --first-parent <commitHash>and saves the output (including any errors) to a temporary file namedmerge_changes.diffin the server’s current working directory. - The Node.js server reads the content of
merge_changes.diff. - The server deletes the temporary
merge_changes.difffile. - The server returns the diff content (or an error message) to the MCP client.
Configuration
Key configuration points are defined as constants within src/index.ts:
SERVER_NAME: The name registered by the MCP server.SCRIPT_NAME: The filename of the PowerShell script to execute.OUTPUT_DIFF_FILE: The name of the temporary diff file created by the script.
License
This project is licensed under the MIT License - see the package.json file for details.
Git Stuff Server
Project Details
- skurekjakub/GitStuffServer
- Last Updated: 5/10/2025
Recomended MCP Servers
alpaca-mcp using stdio/stdout
A universal RPC layer for AI agents. Connect to any function, any language, any framework, in minutes.
A Model Context Protocol (MCP) server for the Open Library API that enables AI assistants to search for...
The EduBase MCP server enables Claude and other LLMs to interact with EduBase's comprehensive e-learning platform through the...
Model Context Protocol Servers
A Model Context Protocol (MCP) server implementation for the Portkey AI platform, providing a standardized interface for managing...
Model Context Protocol Server for PocketBase





