Native MC Mapping MCP Server
Enables AI agents to search Minecraft obfuscated name mappings (class, method, field) across 38 versions, aiding modding, plugin development, and reflection.
README
Native MC Mapping MCP Server
An MCP (Model Context Protocol) server that provides Minecraft obfuscated name mapping lookups. Helps AI coding agents work with Minecraft's obfuscated Java internals — for modding, plugin development, Mixin, Access Transformers, reflection-based scripting, and more.
What It Does
Minecraft's Java code is obfuscated at runtime — class, method, and field names are replaced with short meaningless identifiers (aed, func_70091_d, m_91087_). This MCP server lets your AI agent:
- Search obfuscated ↔ deobfuscated mappings across 38 Minecraft versions (1.7.10 – 1.20.1)
- Auto-build mapping caches on first use — downloads from NeoForge Maven and Mojang servers
- Boolean expression search —
Entity&Player,{Block|Item}&client,func_149645
Use Cases
| Scenario | How This Helps |
|---|---|
| Forge / NeoForge modding | Look up obfuscated method/field names when writing mixins or AT configs |
| Fabric modding | Find intermediary ↔ named mappings for access wideners |
| Spigot / Paper plugins | Resolve NMS (net.minecraft.server) class names across versions |
| Mixin / Access Transformers | Discover the exact obfuscated name to target |
| Reflection-based code | Find field/method names for getDeclaredField, getMethod, etc. |
| Scripting engines | Resolve native Minecraft API names (CustomNPCs, CraftTweaker, etc.) |
| Porting mods | Compare mappings between MC versions to find renamed APIs |
MCP Tools
| Tool | Description |
|---|---|
search |
Search Minecraft obfuscated class/method/field name mappings |
Quick Install (MCP Client)
Prerequisites
- Node.js ≥ 18
Step 1: Clone & Build
git clone https://github.com/SaltfishSheep/AI-MCP-NativeMinecraftAccess.git
cd AI-MCP-NativeMinecraftAccess
npm install
npm run build
Step 2: Add to Your MCP Client
Add the following to your MCP client configuration:
Claude Desktop (claude_desktop_config.json):
{
"mcpServers": {
"native-mc-access": {
"command": "node",
"args": ["/absolute/path/to/AI-MCP-NativeMinecraftAccess/dist/index.js"]
}
}
}
OpenCode (opencode.json):
{
"mcp": {
"native-mc-access": {
"type": "local",
"command": ["node", "/absolute/path/to/AI-MCP-NativeMinecraftAccess/dist/index.js"],
"enabled": true
}
}
}
Cursor (.cursor/mcp.json):
{
"mcpServers": {
"native-mc-access": {
"command": "node",
"args": ["/absolute/path/to/AI-MCP-NativeMinecraftAccess/dist/index.js"]
}
}
}
Windsurf (~/.codeium/windsurf/mcp_config.json):
{
"mcpServers": {
"native-mc-access": {
"command": "node",
"args": ["/absolute/path/to/AI-MCP-NativeMinecraftAccess/dist/index.js"]
}
}
}
Replace
/absolute/path/to/with the actual path where you cloned the repo.
Usage
Once configured, your AI agent can call the search tool:
search(mc_version="1.12.2", expression="Entity&Player")
Example queries:
| Query | Description |
|---|---|
Entity&Player |
Entries containing both "Entity" AND "Player" |
Entity::classname |
Class name exactly "Entity" |
walk:method |
Methods with "walk" in name |
static::modifier |
is_static or access exactly "static" |
Potion:classname&Duration:name |
Class name "Potion", name "Duration" |
{Block|Item}&client |
Client-side Block or Item entries |
func_70091_d |
Find a specific SRG method name by ID |
KeyBinding |
All entries mentioning KeyBinding |
output="%deobf_class%" |
Deduplicated class list |
Expression syntax:
| Syntax | Meaning | Example |
|---|---|---|
term |
Case-insensitive substring match (exact case scores higher) | KeyBinding |
term:modifier |
Restrict search to specific columns | Potion:classname, walk:method |
term::modifier |
Strong modifier — exact match required | Entity::classname |
net.minecraft.Entity |
Dot notation — matches net/minecraft/Entity and net/minecraft$Entity |
net.minecraft.entity.Entity |
& |
AND (both must match, higher precedence) | Entity&Living |
| |
OR (either must match) | Entity|Player |
{} |
Grouping | {a|b}&c |
Modifiers:
| Modifier | Searches | Description |
|---|---|---|
all |
all columns | Default — searches everything |
class |
obf_class, deobf_class | Full class path (e.g. net/minecraft/entity/Entity) |
classname |
deobf_class (after last /) |
Class name only (e.g. Entity from net/minecraft/entity/Entity) |
package |
deobf_class (before last /) |
Package only (e.g. net/minecraft/entity) |
name |
obf_name, deobf_name, srg_name | Field/method names (methods+fields only) |
method |
obf_name, deobf_name, srg_name | Method names only (filters type=method) |
field |
obf_name, deobf_name, srg_name | Field names only (filters type=field) |
desc |
obf_desc, deobf_desc | Method descriptors |
modifier |
access, is_static | Access level and static status |
side |
sideonly | Side filter (common/server/client) |
Tips: Use Player&Entity instead of PlayerEntity for cross-version compatibility, as naming conventions differ across MC versions.
Supported Versions
38 Minecraft versions across 4 workflow types:
| Workflow | Versions | Data Sources |
|---|---|---|
| Legacy SRG | 1.7.10, 1.8–1.11.2 | SRG ZIP + MCP Stable CSV |
| Legacy TSRGv1 | 1.12.2–1.15.2 | TSRGv1 + MCP Stable CSV + static_methods + constructors |
| Legacy ProGuard | 1.16.1–1.16.5 | TSRGv1 + Mojang ProGuard |
| Modern | 1.17–1.20.1 | TSRGv2 + Mojang ProGuard |
How It Works
- On first search for a given MC version, the server downloads mapping data from NeoForge Maven and Mojang
- It parses SRG/TSRG/ProGuard formats and merges them with MCP CSV data
- The merged cache is stored as
.mapping-caches/<version>.csv - Subsequent searches use the cached data (validated against
package.jsonversion) - Boolean expressions are parsed into an AST and evaluated against all CSV rows
Output Format
Found 382 results for "Entity&Player" in MC 1.12.2 (page 1/39)
1. [method] aed.cD -> net/minecraft/entity/player/EntityPlayer.getAbsorptionAmount srg=func_110139_bj desc=()F sideonly=common match=2.0 mismatch=42
2. [method] aed.bM -> net/minecraft/entity/player/EntityPlayer.applyEntityAttributes srg=func_110147_ax desc=()V sideonly=common match=2.0 mismatch=42
...
Project Structure
AI-MCP-NativeMinecraftAccess/
├── package.json
├── tsconfig.json
├── src/
│ ├── index.ts # MCP server entry point
│ ├── types.ts # TypeScript type definitions
│ ├── util.ts # Shared utilities (CSV parsing, package version)
│ ├── version-table.ts # URL mapping table for 38 MC versions
│ ├── builder/
│ │ ├── index.ts # buildMappingCache entry point
│ │ ├── download.ts # HTTP fetch + minimal ZIP reader
│ │ ├── parsers.ts # SRG, TSRGv1, TSRGv2, ProGuard, CSV parsers
│ │ ├── workflows.ts # 4 merge workflow builders
│ │ └── cache.ts # CSV cache writer + validator
│ └── search/
│ ├── index.ts # Re-exports
│ ├── expression.ts # Boolean expression parser (AND/OR/braces)
│ └── csv-reader.ts # CSV reader + paginated search
├── dist/ # Built JavaScript (entry: dist/index.js)
└── .mapping-caches/ # Generated cache files (gitignored)
License
MIT License — see LICENSE.
Third-Party Data
- Mojang mappings — Provided under Mojang's custom license. This server fetches them at runtime; it does NOT redistribute them.
- MCP mappings — Maintained by the Mod Coder Pack community, distributed via NeoForge Maven.
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.