godot-mcp-runtime
Playwright MCP for Godot, screenshots, SceneTree manipulation, and arbitrary GDScript execution at runtime through a local UDP bridge.
Godot MCP Runtime
A lightweight MCP server that gives AI assistants direct access to a running Godot 4.x game. Not just file editing, not just scene manipulation. Actual runtime control: input simulation, screenshots, UI discovery, and live GDScript execution while the game is running.
The distinction matters: the AI doesn't just write your game, it can check its work.
When you run a project through this server, it injects a lightweight TCP bridge as an autoload, and suddenly the AI can interact with your game the same way a player would: press keys, click buttons, read what's on screen, and run arbitrary code against the live scene tree.
No addon required. Most Godot MCP servers that offer runtime support ship as a Godot addon — something you install into your project, commit to version control, and manage as a dependency. All this server needs is Node.js and a Godot executable: no addon installation, no project modifications, no cleanup.
Think of it as Playwright MCP, but for Godot. This does the same thing for games: run the project, take a screenshot, simulate input, read what's on screen, execute a script against the live scene tree. The agent closes the loop on its own changes rather than handing off to you to verify.
This is not a playtesting replacement. It doesn't catch the subtle feel issues that only a human notices, and it won't tell you if your game is fun. What it does is let an agent confirm that a scene loads, a button responds, a value updated, a script ran without errors. The ability to check work is crucial for AI driven workflows.
Each tool teaches agents how to use it through its description and response messages: what to call next, when to wait, and how to recover from errors. Every operation is its own tool with only its relevant parameters, no operation discriminators and no conditional schemas. This server is built for agents.
What It Does
Headless editing. Create scenes, add nodes, set properties, attach scripts, connect signals, manage UIDs, validate GDScript. All the standard operations, no editor window required.
Runtime bridge. When run_project or attach_project is called, the server injects McpBridge as an autoload. This opens a TCP listener on port 9900 (localhost only, override with MCP_BRIDGE_PORT) and enables:
- Screenshots: Capture the viewport — by default returns a 960x540 preview inline plus the full PNG on disk; use
responseMode: 'full'for pixel-perfect or'path_only'to skip the inline image - Input simulation: Batched sequences of key presses, mouse clicks, mouse motion, UI element clicks by name or path, Godot action events, and timed waits
- UI discovery: Walk the live scene tree and collect every visible Control node with its position, type, text content, and disabled state
- Live script execution: Compile and run arbitrary GDScript with full SceneTree access while the game is running
Background mode. Pass background: true to run_project and the Godot window moves off-screen with physical input blocked: borderless, unfocusable, mouse-passthrough. Programmatic input, screenshots, and all runtime tools work exactly the same. Useful for automated agent-driven testing where the window shouldn't be visible or interactive.
Manual attach mode. When something other than MCP launches the game (a CI pipeline, an external debugger, your own shell), call attach_project first. It injects the bridge and marks the project active without spawning Godot, so when you launch the game manually, runtime tools work against it. The tradeoff: get_debug_output is unavailable in attached mode because stdout and stderr only flow through processes MCP started itself. Use detach_project when done.
The bridge cleans itself up automatically when stop_project or detach_project is called. No leftover autoloads, no modified project files.
Quick Start
Prerequisites
That's it. No Godot addon, no project modifications.
Configure Your MCP Client
Add the following to your MCP client config. Works with Claude Code, Claude Desktop, Cursor, or any MCP-compatible client.
Zero-install via npx (recommended):
{
"mcpServers": {
"godot": {
"command": "npx",
"args": ["-y", "godot-mcp-runtime"],
"env": {
"GODOT_PATH": "<path-to-godot-executable>"
}
}
}
}
Or install globally:
npm install -g godot-mcp-runtime
{
"mcpServers": {
"godot": {
"command": "godot-mcp-runtime",
"env": {
"GODOT_PATH": "<path-to-godot-executable>"
}
}
}
}
Or clone from source:
git clone https://github.com/Erodenn/godot-mcp-runtime.git
cd godot-mcp-runtime
npm install
npm run build
{
"mcpServers": {
"godot": {
"command": "node",
"args": ["<path-to>/godot-mcp-runtime/dist/index.js"],
"env": {
"GODOT_PATH": "<path-to-godot-executable>"
}
}
}
}
If Godot is on your PATH, you can omit GODOT_PATH entirely. The server will auto-detect it. Set "DEBUG": "true" in env for verbose logging.
Verify
Ask your AI assistant to call get_project_info. If it returns a Godot version string (e.g., 4.4.stable), you're connected and working.
Tools
See docs/tools.md for the full tool reference, grouped by category. Authoring standards for adding or modifying tools live in docs/tool-authoring.md.
Architecture
src/
├── index.ts # MCP server entry point, server setup
├── dispatch.ts # Tool-name → handler dispatch table
├── tools/
│ ├── project-tools.ts # Project introspection (list_projects, get_project_info, files, search, settings, scene_dependencies)
│ ├── runtime-tools.ts # Runtime/lifecycle (run_project, attach_project, take_screenshot, etc.)
│ ├── autoload-tools.ts # Autoload management (list/add/remove/update_autoload)
│ ├── scene-tools.ts # Scene creation, node addition, sprite loading, batch ops
│ ├── node-tools.ts # Node properties, scripts, tree, duplication, signals
│ └── validate-tools.ts # GDScript and scene validation
├── scripts/
│ ├── godot_operations.gd # Headless GDScript operations
│ └── mcp_bridge.gd # TCP autoload for runtime communication
└── utils/
├── godot-runner.ts # Process spawning, output parsing, shared validation helpers
├── handler-helpers.ts # executeSceneOp wrapper for headless-op handlers
├── bridge-manager.ts # McpBridge artifact lifecycle (inject, cleanup, repair)
├── bridge-protocol.ts # TCP framing (length-prefixed frames, port resolution)
├── autoload-ini.ts # project.godot [autoload] INI primitives
└── logger.ts # logDebug / logError helpers
Headless operations spawn Godot with --headless --script godot_operations.gd, perform the operation, and return JSON. Runtime operations communicate over a long-lived TCP connection with the injected McpBridge autoload (4-byte big-endian length prefix + UTF-8 JSON frames).
How the Bridge Works
When run_project or attach_project is called:
mcp_bridge.gdis copied into the project directory- It's registered as an autoload in
project.godot - Godot launches with the bridge listening on
127.0.0.1:9900(override withMCP_BRIDGE_PORT). Withrun_project, MCP spawns the process; withattach_project, you launch it yourself. - The Node side opens a long-lived TCP connection on first runtime call and sends framed JSON commands; the bridge replies on the same connection
stop_projectordetach_projectsends ashutdowncommand (so the bridge releases the port cleanly), then removes the bridge script and autoload entry
Files generated during runtime (screenshots, executed scripts) are stored in .mcp/ inside the project directory. This directory is automatically added to .gitignore and has a .gdignore so Godot won't import it.
take_screenshot defaults to responseMode: "preview" — the full PNG is saved to .mcp/screenshots/ and a 960x540-bounded preview is returned inline. Override per call:
responseMode: "full"— return the full inline PNG when the agent needs to inspect exact pixels, small UI text, or texture detail.responseMode: "path_only"— skip the inline image entirely when another tool or human will inspect the saved file.previewMaxWidth/previewMaxHeight— override the default 960x540 preview bounds (e.g.{ "responseMode": "preview", "previewMaxWidth": 480, "previewMaxHeight": 270 }).
The response is a JSON text entry ({ responseMode, path, size, previewPath?, previewSize?, warnings? }) plus an inline image entry for full and preview.
Acknowledgments
Built on the foundation laid by Coding-Solo/godot-mcp for headless Godot operations.
Developed with Claude Code.
License
Máy chủ liên quan
Alpha Vantage MCP Server
nhà tài trợAccess financial market data: realtime & historical stock, ETF, options, forex, crypto, commodities, fundamentals, technical indicators, & more
MCPJam Inspector
A developer tool for testing and debugging MCP servers, supporting STDIO, SSE, and Streamable HTTP protocols.
Linkinator
A Model Context Protocol (MCP) server that provides link checking capabilities using linkinator. This allows AI assistants like Claude to scan webpages and local files for broken links.
DocGen MCP Server
Automated documentation generator from source files on Google Drive and GitHub.
MCP Simple OpenAI Assistant
A simple server for interacting with OpenAI assistants using an API key.
Pprof Analyzer
Analyze Go pprof performance profiles (CPU, heap, goroutine, etc.) and generate flamegraphs.
Autodocument
Automatically generates documentation for code repositories by analyzing directory structures and code files using the OpenRouter API.
android-mcp-toolkit
A growing collection of MCP tools for Android Development. Currently features a deterministic Figma-SVG-to-Android-XML converter, with plans for Gradle analysis, Resource management, and ADB integration tools.
Xcode-Studio-MCP
Unified MCP server for Xcode + iOS Simulator — build, deploy, screenshot, and interact with your iOS app from Claude Code, Cursor, or any MCP client. Built in Swift. Single binary. No Node/Python runtime required.
Model Context Protocol servers
A collection of reference implementations for the Model Context Protocol (MCP), demonstrating secure and controlled access to tools and data sources for Large Language Models (LLMs).
Claude TypeScript MCP Servers
A collection of TypeScript MCP servers to enhance Claude Desktop as a powerful development assistant using your Claude Pro/Max subscription.