Built using Python to provide Game Boy emulation capabilities through PyBoy, enabling LLMs to load ROMs, control games, capture screens, and manage save states.
MCP PyBoy Emulator Server
An MCP (Model Context Protocol) server that enables LLMs to interact with Game Boy games through PyBoy emulation.
Overview
This server provides LLMs with the ability to:
- 🎮 Load and play Game Boy ROM files
- 🎯 Control games through button inputs and sequences
- 📸 Capture and analyze game screens
- 💾 Save and load game states
- 📝 Maintain persistent knowledge about games
Prerequisites
- Python 3.10 or higher
- uv - Fast Python package manager
- A compatible LLM client that supports MCP protocol
Installation
1. Install uv (if not already installed)
2. Clone the repository
3. Set up the development environment
4. Verify installation
Quick Start
Running the Server
Project Structure
Development
Development Tools
This project uses modern Python development tools:
- uv - Fast dependency management
- Black - Code formatting (88 char line length)
- Ruff - Linting and import sorting
- MyPy - Static type checking
- pytest - Testing framework
Common Development Commands
VS Code Integration
This project includes VS Code configuration for optimal development:
.vscode/settings.json
- Workspace settings with Black/Ruff integration.vscode/extensions.json
- Recommended extensions
The configuration ensures:
- Black handles all formatting
- Ruff handles linting only (no formatting conflicts)
- Proper Python interpreter from virtual environment
MCP Tools Available
Once fully implemented, the server will provide these tools:
Emulation Control
load_rom
- Load a Game Boy ROM filereset_game
- Reset the current gameset_emulation_speed
- Control game speed
Input Control
press_button
- Press a Game Boy buttonhold_button
- Hold a button downrelease_button
- Release a held buttonsend_input_sequence
- Execute a sequence of inputs
Screen and State
capture_screen
- Get current game screensave_state
- Save current game stateload_state
- Load a saved statelist_states
- List available save states
Knowledge Management
create_note
- Create a note about the gameupdate_note
- Update existing notesearch_notes
- Search game knowledgelist_notes
- List all notes for current game
Architecture
For detailed architecture documentation, see:
Contributing
This project is under active development. See the MVP Roadmap for current progress and planned features.
License
[License information to be added]
Acknowledgments
- Built on PyBoy - Game Boy emulator
- Uses MCP - Model Context Protocol
- Developed with Claude Code assistance
This server cannot be installed
A Model Context Protocol server that allows LLMs to interact with Game Boy games through PyBoy emulation, providing capabilities to load ROMs, control games, capture screens, save/load states, and maintain game knowledge.
Related MCP Servers
- AsecurityFlicenseAqualityA Model Context Protocol server that allows LLMs to interact with Python environments, execute code, and manage files within a specified working directory.Last updated -942Python
- -security-license-qualityA Python implementation of the Model Context Protocol that allows applications to provide standardized context for LLMs, enabling creation of servers that expose data and functionality to LLM applications through resources, tools, and prompts.Last updated -PythonMIT License
- -security-license-qualityA Model Context Protocol server that interfaces with PokeAPI to provide Pokémon information to LLM applications through JSON-RPC over stdio.Last updated -TypeScript
- AsecurityAlicenseAqualityA Model Context Protocol server that enables LLMs to interact with a GameBoy emulator, providing tools for controlling the GameBoy, loading ROMs, and retrieving screen frames.Last updated -135TypeScriptMIT License