minecraft-modding-workbench
Minecraft Modding Workbench
Support fast, version-aware Minecraft modding. Treat the minecraft-modding
MCP server as the primary source of truth, then turn verified findings into
working code and assets.
Scope
- Supports Fabric, NeoForge, and Architectury.
- Requires the
minecraft-moddingMCP server from@adhisang/minecraft-modding-mcp. - Prefer project-aware MCP calls when a workspace exists. Reuse the repository root as
projectPath. - Use the high-level v3 entry tools first:
inspect-minecraft,analyze-symbol,compare-minecraft,validate-project,analyze-mod, andmanage-cache. - Covers Forge-style access transformers through
validate-project(taskaccess-transformer) for NeoForge, in addition to Fabric-style access wideners. - Use the NBT helpers (
nbt-to-json,json-to-nbt,nbt-apply-json-patch) when working with level.dat, chunk, playerdata, or command-driven NBT. Stay in typed JSON while editing and re-encode once at the end.
Default Behavior
- Produce runnable feature slices, not generic advice.
- Infer loader, version, mappings, modid, package, Java version, and project conventions from the workspace before asking questions.
- Ask only the minimum blocking question when the workspace is absent or contradictory.
- Prefer explicit TODOs or placeholder assets over stalling on art or balance details.
- When the user clearly requests implementation rather than explanation, default to delivering code.
- Respond in the user's language when practical, but keep the workflow and trigger logic language-agnostic.
- Separate facts by verification source when the answer will guide later
implementation:
Verified by MCP,Verified by workspace/source jar fallback,Runtime/user-observed, andUnverified.
Quick Path
- Read or build the project profile: workspace root, loader, Minecraft version, mapping, Java version, modules, and normal verification commands.
- Run MCP preflight before assuming
minecraft-moddingtools are callable. - Use one high-level MCP call first for the relevant fact.
- Choose a narrow reference route before loading bundled references. Once the task shape is known, start with its checklist section and add loader, MCP recipe, fallback, or task-specific references only when their conditions match.
- If a worker restart, timeout, or transport failure occurs, retry once with a narrower high-level payload, then switch to the matching fallback playbook.
- For invalid payloads, consult only the relevant
references/mcp-recipes.mdrecipe, correct the shape once, and retry the same high-level tool before changing tools. - For Mixins, access wideners, and access transformers, record owner, name, descriptor, namespace, config declaration, and side before editing.
- For resources, worldgen, loot, models, codecs, HUD, screens, and runtime
hooks, run the task-specific checklist instead of treating
buildas proof of runtime behavior.
MCP Preflight
Run this once near the start of a Minecraft modding task, before the first MCP-dependent claim:
- Check whether the host exposes
minecraft-moddingtools, especiallyinspect-minecraftandanalyze-symbolor their transformed callable names. - Record the available high-level tool names, workspace root to use as
projectPath, detected Minecraft version, loader, mapping, and Java version. - If neither
inspect-minecraftnoranalyze-symbolis available, sayminecraft-modding MCP unavailableonce and switch toreferences/mcp-unavailable-fallback.md. - If a named tool or argument from this skill is rejected as unknown, treat the installed MCP as older than these recipes and use the nearest older-compatible path or workspace fallback. Do not keep guessing tool names.
- If MCP is available, prefer project-aware calls with
projectPath,preferProjectVersion, andpreferProjectMappingwhen the current tool accepts those fields.
First Pass
- Detect the project shape.
- Read
gradle.properties,build.gradle,build.gradle.kts,settings.gradle,fabric.mod.json,neoforge.mods.toml, mixin configs, and nearby registration classes. - Infer loader, Minecraft version, mappings, Java version, modid, base package, whether the project already uses datagen, and whether the workspace is single-loader or Architectury multi-module.
- Record the workspace root you will pass as
projectPathto MCP tools.
- Read
- Read the existing code before writing new code.
- Match the project's naming, package layout, registration helpers, and client/server split.
- Reuse existing registries, tabs, packet patterns, and datagen providers when present.
- Prefer workspace-aware MCP resolution before manual version or mapping selection.
- Load only the relevant references using the Reference Routing section below.
- Find the closest vanilla example before implementing behavior.
- Start with
inspect-minecraftoranalyze-symbol. - Drop to low-level tools only when the high-level answer still leaves the implementation ambiguous.
- Start with
If no project exists yet, ask only for loader, Minecraft version, modid, and package name. If the task depends on an external generator or template that is not present, say so explicitly instead of fabricating generated files.
Reference Routing
Bundled references are optional, conditional context. Do not read or restate the whole reference bundle just because this skill triggered.
- Default route:
- Use
SKILL.md, the project profile, MCP preflight, and one high-level MCP lookup when available. - Read only the matching section of
references/task-checklists.mdonce the task shape is known.
- Use
- Loader route:
- Read
references/fabric.mdonly for Fabric project structure, registration, APIs, entrypoints, datagen, networking, Mixins, or pitfalls. - Read
references/neoforge.mdonly for NeoForge project structure, DeferredRegister, events, capabilities, access transformers, datagen, networking, sided access, or pitfalls. - Read
references/architectury.mdonly for Architectury multi-module placement or a slice that crosses common/platform boundaries. - Read multiple loader references only when the workspace is multi-loader and the changed slice touches those loaders.
- Read
- MCP recipe route:
- Read
references/mcp-recipes.mdonly for payload shape, high-level tool error recovery,ERR_INVALID_INPUT, old-shape/current-shape mismatch, or a supporting utility not covered by the high-level call. - If a high-level MCP answer is sufficient, do not restate unrelated recipes.
- Read
- Fallback route:
- Read
references/mcp-unavailable-fallback.mdonly after preflight shows no MCP tools, a named tool or argument is rejected as older MCP, or the failure budget routes to fallback. - Read
references/validator-fallbacks.mdonly aftervalidate-project,validate-mixin,validate-access-widener, orvalidate-access-transformeris unavailable, restarts, times out, or cannot answer.
- Read
- Task-specific route:
- Read
references/dependency-jars.mdfor dependency API source lookup. - Read
references/rendering-hud.mdfor HUD overlays, screens, projection, GUI scale, FOV, or client rendering. - Read
references/gametest.mdfor GameTest or test-harness wiring. - Read
references/bootstrap-from-template.mdonly for sparse templates. - Read
references/project-profile-template.mdwhen a durable project profile is useful. - Read
references/subagent-mcp-contract.mdonly when delegating Minecraft work to another agent.
- Read
For substantial plans, debugging explanations, eval outputs, or handoffs where reference choices affect implementation facts, include a compact reference route record: loaded references with reasons, plus skipped reference categories with reasons. Keep it short; it is provenance, not a summary of every skipped file.
MCP Guardrails
- Start with the highest-level read-only MCP call that can answer the question.
inspect-minecraft: versions, artifacts, vanilla classes, source search, raw files.analyze-symbol: existence, mappings, lifecycle, workspace compile-time names, API overview.compare-minecraft: migration and registry/class diffs.validate-project: workspace, Mixin, access widener, and Forge-style access transformer validation.analyze-mod: mod JAR summary, search, decompile, remap preview/apply.manage-cache: stale cache or index diagnosis, including theverifyaction and preview-then-apply maintenance.
- Reach for these supporting utilities directly when the entry tools do not cover the job:
get-registry-data: structured registry bodies (blocks, items, biomes, …) via the server data generator for one version.get-runtime-metrics: service counters and latency snapshots when cache, search, or index behaviour looks off.nbt-to-json,json-to-nbt,nbt-apply-json-patch: typed-JSON round-trip and RFC6902-style in-place edits for Java Edition NBT payloads.
- Drop to low-level tools only for exact code, exact descriptors, raw registry bodies, detailed validator output, or direct JAR/remap control.
- Keep version and mapping discipline.
- Pass
projectPath,preferProjectVersion=true, andpreferProjectMapping=truewhen supported. - Still pass explicit
versionto tools that require it, such asvalidate-mixin,validate-access-widener, andresolve-workspace-symbol. - Treat artifact-backed lookup as a two-step flow:
resolve-artifactfirst, thenfind-class,search-class-source,get-artifact-file, orlist-artifact-files.
- Pass
- Parallelize only independent read-only discovery calls once
projectPath, loader, version, and mapping are known.- Keep dependent chains sequential.
- Do not run
manage-cache,index-artifact, or remap/mutating flows in parallel with calls that depend on the same cache or JAR.
- If payload shape is unclear or an entry tool errors, read
references/mcp-recipes.mdbefore inventing fields or dropping to a lower-level tool. - Apply the MCP failure budget.
- If a high-level read tool fails with a worker restart, timeout, or transport error, retry once with a narrower high-level payload.
- If the narrow retry fails, stop using that tool for the current task and use the relevant workspace, source jar, Gradle, or log fallback.
- If
validate-project,validate-mixin,validate-access-widener, orvalidate-access-transformerrestarts once, do not loop. Record the validator as unavailable for this task and runreferences/validator-fallbacks.md. - If
ERR_INVALID_INPUToccurs, read the reported field errors, correct the payload once usingreferences/mcp-recipes.md, and retry the same high-level tool before changing tools. - If you fall back, mark facts from that path as fallback-verified, not MCP-verified.
Unsupported or Risky Requests
- Do not silently treat Quilt or legacy Forge as Fabric, NeoForge, or Architectury.
- For legacy Forge-only or other unsupported loaders, limit help to verified workspace facts, logs, and migration boundaries. Say that full guidance is outside this skill.
- If MCP is unavailable, misconfigured, or stale, say so immediately, fall back to workspace and log inspection, and keep any fix narrow. The same rule covers version skew: if a tool, task, or argument this skill names (for example,
manage-cacheaction: "verify",validate-projecttaskaccess-transformer,analyze-symbolapi-overview/exact-map, the nestedinspect-minecraft subject.kind: "artifact"shape, or the NBT helpers) is rejected as unknown, treat it as evidence that the installed MCP is older than what this skill's recipes target, say so explicitly, and route the request through the nearest older-compatible tool or a workspace-only fallback rather than fabricating a different payload shape. - If workspace files contradict the prompt, call out the contradiction and resolve it from checked files before coding.
- If the request depends on a symbol, event, registry entry, or vanilla hook you cannot verify, say that it is unverified or unsupported instead of inventing it. Offer the closest verified alternative.
Core Workflow
- Inspect vanilla or existing mod code that already solves the same problem.
- Translate that pattern into the user's loader, module boundary, and mapping namespace.
- If the template is too empty, bootstrap the missing project skeleton first.
- Add only the minimum entrypoints, registration classes, client hooks, and datagen wiring needed for the requested feature.
- Do not create every possible system up front.
- Implement the whole slice in one pass.
- Include registrations.
- Include client wiring when needed.
- Include required JSON resources or datagen hooks.
- Include lang keys, loot tables, blockstates, models, tags, recipes, or screen wiring when the feature needs them.
- In Architectury workspaces, keep shared gameplay logic in
commonand loader-specific wiring in platform modules unless the workspace already uses another verified pattern.
- Run the verification loop before calling the task done.
- Report assumptions, placeholders, follow-up tasks, and verification sources briefly.
Delivery Rules
- Match the current project style before introducing a new abstraction.
- Do not invent mapping names, event names, registration order, or descriptors. Verify them.
- Prefer stable loader APIs or events over Mixins when the loader already exposes a clean hook.
- When the project is template-only, create the smallest working scaffold that can compile and host the requested feature.
- In Architectury projects, keep code in
commonby default and move only loader-bound code tofabricorneoforge. - In Architectury templates that already route both loaders through a shared init method, do not add no-op platform edits just to mirror a shared content change.
- Use
@ExpectPlatform, Architectury abstractions, or a plain Java interface/service split only when the code truly needs platform-specific behavior. - Keep side separation correct. Put renderer, screen, and other client-only code behind the proper client entrypoint or event.
- Prefer datagen when the request creates repeated JSON or more than a couple of content entries.
- Preserve existing helper classes, registries, and package structure instead of replacing them wholesale.
- Keep fixes narrow during debugging. Identify the concrete failure first, then patch the cause.
Verification Loop
Run verification as part of the default workflow, not as an optional extra.
- Run
./gradlew buildafter structural code changes. - Run the loader's datagen task when datagen was added or updated, or when generated resources are the project's normal asset path.
- Fabric:
./gradlew runDatagen - NeoForge: run the project's configured datagen task or run configuration.
- Architectury: run the root build and the relevant platform datagen task when the workspace defines one.
- Fabric:
- Treat resource-heavy and runtime-heavy changes as more than compile checks.
- For worldgen, loot tables, item model definitions, biome modifiers, recipe
serializers, registry resources, access wideners, and access transformers,
do not mark the work as working from
buildalone. - Use MCP resource or project validation when available. If unavailable,
compare against at least one vanilla resource from the same Minecraft
version, then use the lightest resource-load path available: focused
GameTest, configured datagen/resource validation, platform run task, or
runClient.
- For worldgen, loot tables, item model definitions, biome modifiers, recipe
serializers, registry resources, access wideners, and access transformers,
do not mark the work as working from
- Run a client launch when the change touches rendering, menus, screens, entity models, HUD overlays, or runtime-only behavior and the environment allows it.
- Use the project's existing
runClienttask or equivalent. - In Architectury workspaces, prefer the platform-specific client run task that exercises the changed module.
- For HUD and projection work, capture runtime evidence when possible and check center, edge, behind-camera, close/far target, GUI scale, and bow/FOV states.
- Use the project's existing
- Run or extend automated tests when the project already has them or when the new logic is isolated enough to justify them.
- Prefer existing GameTests, loader test harnesses, or integration tests for gameplay behavior.
- Add focused unit tests for pure Java helpers, codecs, serializers, or data transforms.
- If a command cannot run in the current environment, say so explicitly and still perform static validation with MCP tools and code inspection.
- In sandboxed environments, retry Gradle with a writable
GRADLE_USER_HOMEbefore treating home-directory lock or cache failures as project issues.
- In sandboxed environments, retry Gradle with a writable
At minimum, aim to leave the project in a state that passes build or has a concrete, localized reason why it cannot.
Fast Debugging Order
- Mixin crash: start with
validate-project, thenvalidate-mixinif you need exact issue detail. Confirm the owner, method name, descriptor, and mapping namespace before patching code. - Access widener failure (Fabric): start with
validate-project, thenvalidate-access-widenerwith an explicitversion. Confirm that the header namespace matches the entry names. - Access transformer failure (NeoForge): start with
validate-project(taskaccess-transformer), thenvalidate-access-transformerwith an explicitversionandatNamespace. Confirm the file's entry namespace matches what the workspace expects (usuallymojangon modern NeoForge,srgon legacy projects). - Registry or missing-content issue: inspect the existing registration flow, confirm registry IDs, then check required resource files.
get-registry-datareturns the vanilla-version entry list only; absence from its output is not evidence of a missing modded, dependency, or datapack entry, so fall back to workspace registration code, dependency metadata, and datagen output for those cases. - Registry loading error: treat
Failed to parse either,No key ..., andUnknown registry key ...as resource codec or schema mismatch until proven otherwise. Compare against same-version vanilla JSON before broad edits. - Dependency API uncertainty: read
references/dependency-jars.mdbefore manual cache scanning. - HUD, screen, or projection bug: read
references/rendering-hud.mdbefore changing math or render registration. - NBT payload corruption or schema drift: decode with
nbt-to-json, edit in typed JSON (ornbt-apply-json-patch), preserveDataVersion, then re-encode withjson-to-nbtusing matching compression. - Cache or index anomalies: read
get-runtime-metricsbefore mutating anything, then runmanage-cachewithaction: "verify"in preview mode beforeprune,rebuild, ordelete. - Texture or model issue: verify resource location casing, JSON paths, generated assets, and item-block model linkage.
- Side-only crash: inspect client init, renderer registration, and
level.isClientSide()or equivalent boundaries. - Porting failure: start with
compare-minecraft, then diff the affected class signatures, then update mappings and loader-specific APIs.
When one of these categories matches, read the corresponding section in references/task-checklists.md and the loader-specific Common Pitfalls section before broad rewrites.
References
- Fabric patterns:
references/fabric.md - NeoForge patterns:
references/neoforge.md - Architectury patterns:
references/architectury.md - Template bootstrap patterns:
references/bootstrap-from-template.md - Delivery checklists by task shape:
references/task-checklists.md - MCP payload and recovery recipes:
references/mcp-recipes.md - MCP unavailable fallback:
references/mcp-unavailable-fallback.md - Dependency API source lookup:
references/dependency-jars.md - HUD and client rendering:
references/rendering-hud.md - Validator fallbacks:
references/validator-fallbacks.md - GameTest wiring:
references/gametest.md - Project profile template:
references/project-profile-template.md - Subagent MCP contract:
references/subagent-mcp-contract.md - For current upstream migration guidance, consult the official Fabric, NeoForge, and Architectury docs or release notes that match the target loader and Minecraft version instead of relying on hardcoded URLs.
More from adhi-jp/agent-skills
review-scope-guard
Use when Codex or code/plan review findings need Definition-of-Done scope triage, especially to separate must-fix issues from minimal hygiene, out-of-scope hardening, repeated noise, or self-induced refinements. Also use when codex-review-cycle invokes scope guard between validity checking and summary render. Do not use for single-shot lint or unrelated changes.
31codex-review-cycle
Use when the user explicitly asks to run an iterative Codex review cycle on a non-empty git diff, including working-tree changes, current branch vs base, explicit commit/tag/branch refs, code diffs, or Markdown planning documents. Do not use for one-shot reviews, auto-hardening, background checks, plan drafting, or empty review targets.
31writing-style-guide
Use when generating or editing user-facing prose, including docs, comments, READMEs, changelogs, commit messages, PR descriptions, and chat replies.
28review-fix-cascade-guard
Use when applying user-selected review findings after scope triage, especially inside codex-review-cycle or after a standalone Codex adversarial review, and a line-scoped fix may create follow-on valid findings. Do not use for ordinary edits, plan drafting, single-shot lint, no-review contexts, or generic refactor checklists.
16vibe-planning
>
14vibe-plan-execution
Use when the user asks to execute, implement, continue, or apply an existing vibe-planning output, implementation plan, specification, acceptance criteria, or task plan. Do not use for plan creation or coding requests with no concrete plan to bind.
14