Yellhorn Gemini Integration
STDIOMCP server exposing Gemini and OpenAI capabilities for software development with codebase context.
MCP server exposing Gemini and OpenAI capabilities for software development with codebase context.
A Model Context Protocol (MCP) server that exposes Gemini 2.5 Pro and OpenAI capabilities to Claude Code for software development tasks using your entire codebase in the prompt. This pattern is highly useful for defining work to be done by code assistants like Claude Code or other MCP compatible coding agents, and reviewing the results ensuring they meet the exactly specified original requirements.
.yellhornignore
files to exclude specific files and directories from the AI context, similar to .gitignore
# Install from PyPI pip install yellhorn-mcp # Install from source git clone https://github.com/msnidal/yellhorn-mcp.git cd yellhorn-mcp pip install -e .
The server requires the following environment variables:
GEMINI_API_KEY
: Your Gemini API key (required for Gemini models)OPENAI_API_KEY
: Your OpenAI API key (required for OpenAI models)REPO_PATH
: Path to your repository (defaults to current directory)YELLHORN_MCP_MODEL
: Model to use (defaults to "gemini-2.5-pro-preview-05-06"). Available options:
YELLHORN_MCP_SEARCH
: Enable/disable Google Search Grounding (defaults to "on" for Gemini models). Options:
The server also requires the GitHub CLI (gh
) to be installed and authenticated.
To configure Yellhorn MCP in VSCode or Cursor, create a .vscode/mcp.json
file at the root of your workspace with the following content:
{ "inputs": [ { "type": "promptString", "id": "gemini-api-key", "description": "Gemini API Key" } ], "servers": { "yellhorn-mcp": { "type": "stdio", "command": "/Users/msnidal/.pyenv/shims/yellhorn-mcp", "args": [], "env": { "GEMINI_API_KEY": "${input:gemini-api-key}", "REPO_PATH": "${workspaceFolder}" } } } }
To configure Yellhorn MCP with Claude Code directly, add a root-level .mcp.json
file in your project with the following content:
{ "mcpServers": { "yellhorn-mcp": { "type": "stdio", "command": "yellhorn-mcp", "args": ["--model", "o3"], "env": { "YELLHORN_MCP_SEARCH": "on" } } } }
Creates a GitHub issue with a detailed workplan based on the title and detailed description.
Input:
title
: Title for the GitHub issue (will be used as issue title and header)detailed_description
: Detailed description for the workplan. Any URLs provided here will be extracted and included in a References section.codebase_reasoning
: (optional) Control whether AI enhancement is performed:
"full"
: (default) Use AI to enhance the workplan with full codebase context"lsp"
: Use AI with lightweight codebase context (function/method signatures, class attributes and struct fields for Python and Go)"none"
: Skip AI enhancement, use the provided description as-isdebug
: (optional) If set to true
, adds a comment to the issue with the full prompt used for generationdisable_search_grounding
: (optional) If set to true
, disables Google Search Grounding for this requestOutput:
issue_url
: URL to the created GitHub issueissue_number
: The GitHub issue numberRetrieves the workplan content (GitHub issue body) associated with a workplan.
Input:
issue_number
: The GitHub issue number for the workplan.disable_search_grounding
: (optional) If set to true
, disables Google Search Grounding for this requestOutput:
Triggers an asynchronous code judgement comparing two git refs (branches or commits) against a workplan described in a GitHub issue. Creates a placeholder GitHub sub-issue immediately and then processes the AI judgement asynchronously, updating the sub-issue with results.
Input:
issue_number
: The GitHub issue number for the workplan.base_ref
: Base Git ref (commit SHA, branch name, tag) for comparison. Defaults to 'main'.head_ref
: Head Git ref (commit SHA, branch name, tag) for comparison. Defaults to 'HEAD'.codebase_reasoning
: (optional) Control which codebase context is provided:
"full"
: (default) Use full codebase context"lsp"
: Use lighter codebase context (only function signatures for Python and Go, plus full diff files)"file_structure"
: Use only directory structure without file contents for faster processing"none"
: Skip codebase context completely for fastest processingdebug
: (optional) If set to true
, adds a comment to the sub-issue with the full prompt used for generationdisable_search_grounding
: (optional) If set to true
, disables Google Search Grounding for this requestAny URLs mentioned in the workplan will be extracted and preserved in a References section in the judgement.
Output:
message
: Confirmation that the judgement task has been initiatedsubissue_url
: URL to the created placeholder sub-issue where results will be postedsubissue_number
: The GitHub issue number of the placeholder sub-issueYellhorn MCP also implements the standard MCP resource API to provide access to workplans:
list-resources
: Lists all workplans (GitHub issues with the yellhorn-mcp label)get-resource
: Retrieves the content of a specific workplan by issue numberThese can be accessed via the standard MCP CLI commands:
# List all workplans mcp list-resources yellhorn-mcp # Get a specific workplan by issue number mcp get-resource yellhorn-mcp 123
# Install development dependencies pip install -e ".[dev]" # Run tests pytest # Run tests with coverage report pytest --cov=yellhorn_mcp --cov-report term-missing
The project uses GitHub Actions for continuous integration and deployment:
Testing: Runs automatically on pull requests and pushes to the main branch
Publishing: Automatically publishes to PyPI when a version tag is pushed
To release a new version:
git commit -am "Bump version to X.Y.Z"
git tag vX.Y.Z
git push && git push --tags
For a history of changes, see the Changelog.
For more detailed instructions, see the Usage Guide.
MIT