python mudlib using telnetlib3
Implement V3 restore opcode: - Add QuetzalParser.load_from_bytes() to parse save data from memory - Wire op_restore to call filesystem.restore_game() and parse result - Validate IFhd matches current story (release/serial/checksum) - Restore dynamic memory, call stack, and program counter - Branch true on success, false on failure/cancellation Fix IFF chunk padding bug: - Add padding byte to odd-length chunks in QuetzalWriter - Ensures proper chunk alignment for parser compatibility Add comprehensive tests: - Branch false when filesystem returns None - Branch false without zmachine reference - Branch true on successful restore - Verify memory state matches saved values - Handle malformed save data gracefully |
||
|---|---|---|
| .claude | ||
| content | ||
| docs | ||
| scripts | ||
| src/mudlib | ||
| tests | ||
| worlds/earth | ||
| .dockerignore | ||
| .gitignore | ||
| compose.yml | ||
| demo_terrain.py | ||
| Dockerfile | ||
| DREAMBOOK.md | ||
| justfile | ||
| mud.tin | ||
| pyproject.toml | ||
| README.md | ||
| uv.lock | ||
mudlib
A telnet MUD engine. No client needed — just telnet and you're in.
Built on telnetlib3, Python 3.12+, managed with uv.
Quickstart
uv sync
just run
Then connect: telnet localhost 6789
Commands
just check # lint + typecheck + test
just run # start the server
just debug # start with debug logging
just render # generate world map HTML
What's in here
src/mudlib/— the engine (commands, world, combat, rendering, storage)tests/— pytest testsworlds/— world definitions (yaml/toml)docs/— internal knowledge baseDREAMBOOK.md— vision and wild ideas
How it works
The world is a toroidal 2D grid of terrain tiles, not discrete rooms. Players see a viewport centered on their position. Terrain types have mechanics — shallow water slows you, mountains block you, forests hide you.
Combat is timing-based with telegraphed moves and cooldown management, not turn-based.
The server runs a tick-based async game loop alongside the telnet server. SQLite handles persistence. Session mode stacks filter what reaches the player depending on context (exploring, fighting, composing, solving puzzles).