Local MCP server for Cities: Skylines II game knowledge and modding workflows.
Project description
Cities2-MCP
Cities2-MCP — a local MCP server for Cities: Skylines II game knowledge and modding tools.
It gives AI assistants access to a prepared local corpus of Cities: Skylines II Wiki text, plus tools for creating, inspecting, building, and packaging CS2 mod projects.
What It Can Do
Search Game And Modding Information
The server includes a prepared text corpus from the Cities: Skylines II Wiki. An AI assistant can:
- search the bundled wiki corpus
- fetch full pages by page id
- retrieve reference-style snippets for game systems and modding topics
- answer questions without browsing the live wiki during your session
This is useful for questions about game mechanics, modding APIs, toolchain setup, project structure, localization, UI mods, and related CS2 development topics.
Search The Local Game Encyclopedia
When Cities: Skylines II is installed locally, Cities2-MCP also tries to read the in-game Encyclopedia from the user's own game files. This source is enabled by default when the server can find Cities2_Data/Content/Game/Locale.cok, especially for standard Steam installs.
The extracted Encyclopedia index is cached locally on the user's machine and rebuilt only when the source game file, detected Steam build id, locale, or extractor version changes. Extracted game text is not committed to this repository, shipped in releases, or part of the redistributed wiki corpus.
If the game install is not found automatically, set CITIES2_GAME_DIR to the Cities: Skylines II install directory or CITIES2_LOCALE_COK to the full Locale.cok path.
Help With Mod Project Workflows
The server also includes local workflow tools for CS2 mod projects. An AI assistant can:
- scaffold C# code, UI, or hybrid mod project templates
- write files inside configured workspaces
- list project trees
- run project builds and analyzers
- package project output
- dry-run launching Cities: Skylines II with selected flags
These tools are meant for local development workflows. They can write files and run commands, so configure workspaces deliberately.
Use Slash Commands
Cities2-MCP ships two slash-command skills that teach compatible agents how to query and interpret the MCP sources effectively:
cities2-knowledgeanswers gameplay, city-system, and player-facing patch/update questions from both the bundled wiki corpus and the local game Encyclopedia.cities2-moddinganswers modding questions and guides local mod project workflows.
These skills are stored in skills/. Install or copy them into your agent's skill directory if your client supports Agent Skills. They are the recommended way to get natural answers to questions like "how do I grow office demand?" or "what changed in the latest patch?" because they tell the agent to use keyword queries, fetch full pages or entries, compare source authority, synthesize an answer, and include compact source notes naming the Game Encyclopedia entries and linked wiki pages used.
Licensing
The MCP server code is licensed under the MIT License. The internal retrieval layer includes code originally split out as wiki-mcp; its MIT notice is preserved in THIRD_PARTY_NOTICES.md. The included cities2_mcp/data corpus is licensed under Creative Commons Attribution-ShareAlike 3.0; source attribution and transformation notes are in cities2_mcp/data/ATTRIBUTION.md.
Quick Install
The packaged server includes the bundled wiki corpus and can be launched by MCP
clients through uvx:
{
"mcpServers": {
"cities2-mcp": {
"command": "uvx",
"args": [
"cities2-mcp",
"--workspace",
"/absolute/path/to/trusted/mod/workspace"
]
}
}
}
Omit --workspace if you only want wiki and local Encyclopedia search. Add one
or more --workspace entries when you want the project workflow tools to write,
analyze, build, or package local mod projects.
Prerequisites
Clone the repository:
git clone https://github.com/mayor-modder/Cities2-MCP.git
The wiki retrieval code is included directly under cities2_mcp/retrieval, so no submodule setup is required.
Optional mod build/package workflows need the Cities: Skylines II modding
toolchain, dotnet, and a .NET 6 runtime. Check with:
dotnet --list-runtimes
Look for Microsoft.NETCore.App 6.. This is only required for tools that build,
post-process, or package CS2 mods; wiki search and project scaffolding do not
need it.
Install In Claude Desktop, Claude Code, Codex, Cursor, etc.
See INSTALL.md for step-by-step setup instructions. The install guide covers client detection, config file locations, and troubleshooting for supported platforms.
Reference config templates with placeholders are also available at:
mcp.config.example.jsonfor JSON clientsINSTALL.mdincludes the Codex TOML shape
Start MCP Server
Run from the repository root:
CITIES2_MODS_DIR="$HOME/Library/Application Support/Colossal Order/Cities Skylines II/Mods" \
python3 server/mcp_server.py \
--workspace .
Transport is stdio with Content-Length framing. The server also accepts newline-delimited JSON for compatibility.
Repeat --workspace to allow additional project roots. Relative tool paths resolve from the first workspace. Absolute project paths must live inside one of the configured workspaces.
Included Wiki Corpus
The packaged server reads the prepared corpus from cities2_mcp/data by default. The corpus contains page metadata and JSONL indexes used by the MCP retrieval tools.
Corpus layout:
cities2_mcp/data/LICENSEcities2_mcp/data/ATTRIBUTION.mdcities2_mcp/data/manifest.jsoncities2_mcp/data/index/pages.jsonlcities2_mcp/data/index/chunks.jsonl
MCP Tools
Game and modding knowledge:
search(query, limit=5)get_page(page_id)query_reference(query, limit=5)get_snippets(query, limit=3)search_encyclopedia(query, limit=5)get_encyclopedia_entry(entry_id)source_status()
Mod project workflow:
scaffold_project(name, template, target_dir?, metadata?, options?)write_project_file(project_dir, relative_path, content, mode=create|replace|upsert)list_project_tree(project_dir, glob="**/*", include_hidden=false, max_files=2000)build_project(project_dir, profile=debug|release, steps?, clean=false, package=false, timeout_sec=300)analyze_project(project_dir, profile=auto|cities2-csharp|cities2-ui|cities2-hybrid, strict=true)package_project(project_dir, output_dir?, package_name?, exclude_globs?)launch_cities2(executable?, flags?, platform=auto|mac|windows|linux, dry_run=true)
Slash Commands
Skills live under skills/:
skills/cities2-knowledge/SKILL.mdskills/cities2-modding/SKILL.md
Install them into a compatible client's skill folder, or keep them in the repo as project-level guidance where supported. The skills depend on the cities2-mcp MCP server being configured. Gameplay and update answers should include compact source notes that mention the local Game Encyclopedia entries and link to the relevant CS2 Wiki pages when available.
Project templates are stored at:
cities2_mcp/templates/cities2-csharpcities2_mcp/templates/cities2-uicities2_mcp/templates/cities2-hybrid
Migration From Older Tool Names
create_mod_project->scaffold_projectadd_file/update_file->write_project_filelist_project_files->list_project_treebuild_mod->build_projectcheck_errors-> integrated inbuild_projectdiagnostics outputpackage_mod->package_projectexport_mod_copy-> removed; usepackage_projectplus an external copy step if neededlaunch_game_with_flags->launch_cities2
Smoke Test
python3 tests/smoke_mcp.py
The smoke test validates MCP initialize/list plus wiki retrieval and mod workflow tools end-to-end.
Direct CLI
python3 scripts/workbench_cli.py list-tools
python3 scripts/workbench_cli.py scaffold "My Mod" cities2-csharp
python3 scripts/workbench_cli.py analyze mods/my-mod --profile auto --strict
python3 scripts/workbench_cli.py build mods/my-mod --profile release --steps ui,dotnet
Project details
Release history Release notifications | RSS feed
Download files
Download the file for your platform. If you're not sure which to choose, learn more about installing packages.
Source Distribution
Built Distribution
Filter files by name, interpreter, ABI, and platform.
If you're not sure about the file name format, learn more about wheel file names.
Copy a direct link to the current filters
File details
Details for the file cities2_mcp-0.1.6.tar.gz.
File metadata
- Download URL: cities2_mcp-0.1.6.tar.gz
- Upload date:
- Size: 469.1 kB
- Tags: Source
- Uploaded using Trusted Publishing? Yes
- Uploaded via: twine/6.1.0 CPython/3.13.12
File hashes
| Algorithm | Hash digest | |
|---|---|---|
| SHA256 |
72e7113aef9410f5c07cc36abd790582a74a92a4ef1829647af11c5d485dc664
|
|
| MD5 |
1ef39a4500ef647d582e0cb8905fa560
|
|
| BLAKE2b-256 |
b290c04febd40af993a1ccbcc1466581ddb2ac67752711f4b336ceebd770d811
|
Provenance
The following attestation bundles were made for cities2_mcp-0.1.6.tar.gz:
Publisher:
release.yml on mayor-modder/Cities2-MCP
-
Statement:
-
Statement type:
https://in-toto.io/Statement/v1 -
Predicate type:
https://docs.pypi.org/attestations/publish/v1 -
Subject name:
cities2_mcp-0.1.6.tar.gz -
Subject digest:
72e7113aef9410f5c07cc36abd790582a74a92a4ef1829647af11c5d485dc664 - Sigstore transparency entry: 1659050234
- Sigstore integration time:
-
Permalink:
mayor-modder/Cities2-MCP@2bd95e4112733b67b26f3c7cb1c8eadd3446cacd -
Branch / Tag:
refs/tags/v0.1.6 - Owner: https://github.com/mayor-modder
-
Access:
public
-
Token Issuer:
https://token.actions.githubusercontent.com -
Runner Environment:
github-hosted -
Publication workflow:
release.yml@2bd95e4112733b67b26f3c7cb1c8eadd3446cacd -
Trigger Event:
push
-
Statement type:
File details
Details for the file cities2_mcp-0.1.6-py3-none-any.whl.
File metadata
- Download URL: cities2_mcp-0.1.6-py3-none-any.whl
- Upload date:
- Size: 458.2 kB
- Tags: Python 3
- Uploaded using Trusted Publishing? Yes
- Uploaded via: twine/6.1.0 CPython/3.13.12
File hashes
| Algorithm | Hash digest | |
|---|---|---|
| SHA256 |
6b9c489535728b69d7fa6dc48f3b2b6c6469836f22a857df60596abec4f3c734
|
|
| MD5 |
697f035c8f5cf3ee7d95c13f90214a63
|
|
| BLAKE2b-256 |
a73c43240d4dd686c8461b9b61256f7bf73ae3498bfaca0f131e68e39a20f5e3
|
Provenance
The following attestation bundles were made for cities2_mcp-0.1.6-py3-none-any.whl:
Publisher:
release.yml on mayor-modder/Cities2-MCP
-
Statement:
-
Statement type:
https://in-toto.io/Statement/v1 -
Predicate type:
https://docs.pypi.org/attestations/publish/v1 -
Subject name:
cities2_mcp-0.1.6-py3-none-any.whl -
Subject digest:
6b9c489535728b69d7fa6dc48f3b2b6c6469836f22a857df60596abec4f3c734 - Sigstore transparency entry: 1659050338
- Sigstore integration time:
-
Permalink:
mayor-modder/Cities2-MCP@2bd95e4112733b67b26f3c7cb1c8eadd3446cacd -
Branch / Tag:
refs/tags/v0.1.6 - Owner: https://github.com/mayor-modder
-
Access:
public
-
Token Issuer:
https://token.actions.githubusercontent.com -
Runner Environment:
github-hosted -
Publication workflow:
release.yml@2bd95e4112733b67b26f3c7cb1c8eadd3446cacd -
Trigger Event:
push
-
Statement type: