mcp-server-if
Enables AI assistants to play interactive fiction games (Glulx and Z-machine) through the Model Context Protocol, with automatic save/restore and optional journaling mode.
README
mcp-server-if
An MCP (Model Context Protocol) server for playing interactive fiction games. Enables AI assistants like Claude to play text adventure games through a standardized interface.
Features
- Play Glulx (.ulx, .gblorb) and Z-machine (.z3-.z8, .zblorb) games
- Automatic game state persistence (save/restore between sessions)
- Download games directly from the IF Archive
- Optional journaling mode for reflective playthroughs
- Works with Claude Desktop, Claude Code, and other MCP clients
- Bundled interpreters (glulxe for Glulx, bocfel for Z-machine)
Installation
# Using uvx (recommended)
uvx mcp-server-if
# Or install with pip
pip install mcp-server-if
The package includes pre-compiled interpreters. No additional setup required.
Configuration
Environment Variables
| Variable | Description | Default |
|---|---|---|
IF_GAMES_DIR |
Directory to store games | ~/.mcp-server-if/games |
IF_GLULXE_PATH |
Override path to glulxe binary | Bundled binary |
IF_BOCFEL_PATH |
Override path to bocfel binary | Bundled binary |
IF_REQUIRE_JOURNAL |
Require journal reflections | false |
Command Line Arguments
mcp-server-if --help
Options:
--games-dir PATH Directory to store games
--glulxe-path PATH Path to glulxe binary (overrides bundled)
--require-journal Require journal reflections between turns
Usage with Claude Desktop
Add to your Claude Desktop configuration (~/Library/Application Support/Claude/claude_desktop_config.json on macOS or %APPDATA%\Claude\claude_desktop_config.json on Windows):
{
"mcpServers": {
"interactive-fiction": {
"command": "uvx",
"args": ["mcp-server-if"]
}
}
}
Usage with Claude Code
claude mcp add interactive-fiction -- uvx mcp-server-if
Available Tools
play_if
Play a turn of interactive fiction.
play_if(game="zork", command="go north")
play_if(game="zork", command="", journal="...reflection...") # with journaling
list_games
List available games and their save state status.
download_game
Download a game from the IF Archive or any URL.
download_game(name="advent", url="advent.ulx")
download_game(name="bronze", url="https://example.com/Bronze.gblorb")
reset_game
Reset a game to start fresh (clears save state, preserves journal).
read_journal
Read the playthrough journal for a game.
read_journal(game="zork", recent=10) # last 10 entries
search_journal
Search journal entries by keyword.
search_journal(game="zork", query="treasure")
Supported Game Formats
Glulx (modern, uses glulxe interpreter):
.ulx- Raw Glulx game files.gblorb- Blorb containers with Glulx games
Z-machine (classic Infocom format, uses bocfel interpreter):
.z3,.z4,.z5,.z7,.z8- Z-code game files.zblorb- Blorb containers with Z-machine games
Find games at the IF Archive: Glulx games, Z-code games.
Journaling Mode
Enable with --require-journal or IF_REQUIRE_JOURNAL=true. In this mode:
- After playing your first command, subsequent turns require a journal entry
- Journal entries must be at least 100 words
- Entries are saved to
{game}/journal.jsonl - Use
read_journalandsearch_journalto review your playthrough
This encourages thoughtful, reflective gameplay rather than rushing through.
How It Works
-
Games are stored in
~/.mcp-server-if/games/{name}/ -
Each game directory contains:
- The game file (
.ulx,.gblorb,.z5, etc.) state/- autosave data (persists between sessions)metadata.json- session metadatajournal.jsonl- playthrough journal (if enabled)
- The game file (
-
The server selects the appropriate interpreter based on file format:
- Glulx games → glulxe
- Z-machine games → bocfel
-
Both interpreters use RemGlk for JSON-based I/O
-
Game state is automatically saved after each turn
Development
Requires uv, a C compiler (gcc or clang), a C++ compiler (g++ or clang++), make, and git.
git clone --recursive https://github.com/davidar/mcp-server-if.git
cd mcp-server-if
uv sync --group dev
uv run pytest -v
uv sync compiles the bundled interpreters (glulxe and bocfel) from source automatically. If binaries are missing after a fresh clone, run uv sync --reinstall-package mcp-server-if to force recompilation.
Troubleshooting
"glulxe binary not found"
This shouldn't happen with pip/uvx installs. If it does:
- Try reinstalling:
pip install --force-reinstall mcp-server-iforuv sync --reinstall-package mcp-server-if - Or set
IF_GLULXE_PATHto a manually installed glulxe
"Game file not found"
Use list_games to see available games, or download_game to get new ones.
Save/restore commands don't work
In-game save/restore triggers file dialogs that aren't supported. Use the automatic autosave system instead - your game state persists between sessions automatically.
License
MIT License - see LICENSE for details.
Credits
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
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.
Qdrant Server
This repository is an example of how to create a MCP server for Qdrant, a vector search engine.