Claude-Code-Game-Studios consistency-check
Scan all GDDs against the entity registry to detect cross-document inconsistencies: same entity with different stats, same item with different values, same formula with different variables. Grep-first approach — reads registry then targets only conflicting GDD sections rather than full document reads.
git clone https://github.com/Donchitos/Claude-Code-Game-Studios
T=$(mktemp -d) && git clone --depth=1 https://github.com/Donchitos/Claude-Code-Game-Studios "$T" && mkdir -p ~/.claude/skills && cp -r "$T/.claude/skills/consistency-check" ~/.claude/skills/donchitos-claude-code-game-studios-consistency-check && rm -rf "$T"
.claude/skills/consistency-check/SKILL.mdConsistency Check
Detects cross-document inconsistencies by comparing all GDDs against the entity registry (
design/registry/entities.yaml). Uses a grep-first approach:
reads the registry once, then targets only the GDD sections that mention
registered names — no full document reads unless a conflict needs investigation.
This skill is the write-time safety net. It catches what
/design-system's
per-section checks may have missed and what /review-all-gdds's holistic review
catches too late.
When to run:
- After writing each new GDD (before moving to the next system)
- Before
(so that skill starts with a clean baseline)/review-all-gdds - Before
(inconsistencies poison downstream ADRs)/create-architecture - On demand:
to check one entity specifically/consistency-check entity:[name]
Output: Conflict report + optional registry corrections
Phase 1: Parse Arguments and Load Registry
Modes:
- No argument /
— check all registered entries against all GDDsfull
— check only GDDs modified since the last review reportsince-last-review
— check one specific entity across all GDDsentity:<name>
— check one specific item across all GDDsitem:<name>
Load the registry:
Read path="design/registry/entities.yaml"
If the file does not exist or has no entries:
"Entity registry is empty. Run
to write GDDs — the registry is populated automatically after each GDD is completed. Nothing to check yet."/design-system
Stop and exit.
Build four lookup tables from the registry:
- entity_map:
{ name → { source, attributes, referenced_by } } - item_map:
{ name → { source, value_gold, weight, ... } } - formula_map:
{ name → { source, variables, output_range } } - constant_map:
{ name → { source, value, unit } }
Count total registered entries. Report:
Registry loaded: [N] entities, [N] items, [N] formulas, [N] constants Scope: [full | since-last-review | entity:name]
Phase 2: Locate In-Scope GDDs
Glob pattern="design/gdd/*.md"
Exclude:
game-concept.md, systems-index.md, game-pillars.md — these are
not system GDDs.
For
since-last-review mode:
git log --name-only --pretty=format: -- design/gdd/ | grep "\.md$" | sort -u
Limit to GDDs modified since the most recent
design/gdd/gdd-cross-review-*.md
file's creation date.
Report the in-scope GDD list before scanning.
Phase 3: Grep-First Conflict Scan
For each registered entry, grep every in-scope GDD for the entry's name. Do NOT do full reads — extract only the matching lines and their immediate context (-C 3 lines).
This is the core optimization: instead of reading 10 GDDs × 400 lines each (4,000 lines), you grep 50 entity names × 10 GDDs (50 targeted searches, each returning ~10 lines on a hit).
3a: Entity Scan
For each entity in entity_map:
Grep pattern="[entity_name]" glob="design/gdd/*.md" output_mode="content" -C 3
For each GDD hit, extract the values mentioned near the entity name:
- any numeric attributes (counts, costs, durations, ranges, rates)
- any categorical attributes (types, tiers, categories)
- any derived values (totals, outputs, results)
- any other attributes registered in entity_map
Compare extracted values against the registry entry.
Conflict detection:
- Registry says
. GDD says[entity_name].[attribute] = [value_A]
. → CONFLICT[entity_name] has [value_B] - Registry says
. GDD says[item_name].[attribute] = [value_A]
. → CONFLICT[item_name] is [value_B] - GDD mentions
but doesn't specify the attribute. → NOTE (no conflict, just unverifiable)[entity_name]
3b: Item Scan
For each item in item_map, grep all GDDs for the item name. Extract:
- sell price / value / gold value
- weight
- stack rules (stackable / non-stackable)
- category
Compare against registry entry values.
3c: Formula Scan
For each formula in formula_map, grep all GDDs for the formula name. Extract:
- variable names mentioned near the formula
- output range or cap values mentioned
Compare against registry entry:
- Different variable names → CONFLICT
- Output range stated differently → CONFLICT
3d: Constant Scan
For each constant in constant_map, grep all GDDs for the constant name. Extract:
- Any numeric value mentioned near the constant name
Compare against registry value:
- Different number → CONFLICT
Phase 4: Deep Investigation (Conflicts Only)
For each conflict found in Phase 3, do a targeted full-section read of the conflicting GDD to get precise context:
Read path="design/gdd/[conflicting_gdd].md"
(Or use Grep with wider context if the file is large)
Confirm the conflict with full context. Determine:
- Which GDD is correct? Check the
field in the registry — the source GDD is the authoritative owner. Any other GDD that contradicts it is the one that needs updating.source: - Is the registry itself out of date? If the source GDD was updated after the registry entry was written (check git log), the registry may be stale.
- Is this a genuine design change? If the conflict represents an intentional design decision, the resolution is: update the source GDD, update the registry, then fix all other GDDs.
For each conflict, classify:
- 🔴 CONFLICT — same named entity/item/formula/constant with different values in different GDDs. Must resolve before architecture begins.
- ⚠️ STALE REGISTRY — source GDD value changed but registry not updated. Registry needs updating; other GDDs may be correct already.
- ℹ️ UNVERIFIABLE — entity mentioned but no comparable attribute stated. Not a conflict; just noting the reference.
Phase 5: Output Report
## Consistency Check Report Date: [date] Registry entries checked: [N entities, N items, N formulas, N constants] GDDs scanned: [N] ([list names]) --- ### Conflicts Found (must resolve before architecture) 🔴 [Entity/Item/Formula/Constant Name] Registry (source: [gdd]): [attribute] = [value] Conflict in [other_gdd].md: [attribute] = [different_value] → Resolution needed: [which doc to change and to what] --- ### Stale Registry Entries (registry behind the GDD) ⚠️ [Entry Name] Registry says: [value] (written [date]) Source GDD now says: [new value] → Update registry entry to match source GDD, then check referenced_by docs. --- ### Unverifiable References (no conflict, informational) ℹ️ [gdd].md mentions [entity_name] but states no comparable attributes. No conflict detected. No action required. --- ### Clean Entries (no issues found) ✅ [N] registry entries verified across all GDDs with no conflicts. --- Verdict: PASS | CONFLICTS FOUND
Verdict:
- PASS — no conflicts. Registry and GDDs agree on all checked values.
- CONFLICTS FOUND — one or more conflicts detected. List resolution steps.
Phase 6: Registry Corrections
If stale registry entries were found, ask:
"May I update
to fix the [N] stale entries?"design/registry/entities.yaml
For each stale entry:
- Update the
/ attribute fieldvalue - Set
to today's daterevised: - Add a YAML comment with the old value:
# was: [old_value] before [date]
If new entries were found in GDDs that are not in the registry, ask:
"Found [N] entities/items mentioned in GDDs that aren't in the registry yet. May I add them to
?"design/registry/entities.yaml
Only add entries that appear in more than one GDD (true cross-system facts).
Never delete registry entries. Set
status: deprecated if an entry is removed
from all GDDs.
After writing: Verdict: COMPLETE — consistency check finished. If conflicts remain unresolved: Verdict: BLOCKED — [N] conflicts need manual resolution before architecture begins.
6b: Append to Reflexion Log
If any 🔴 CONFLICT entries were found (regardless of whether they were resolved), append an entry to
docs/consistency-failures.md for each conflict:
### [YYYY-MM-DD] — /consistency-check — 🔴 CONFLICT **Domain**: [system domain(s) involved] **Documents involved**: [source GDD] vs [conflicting GDD] **What happened**: [specific conflict — entity name, attribute, differing values] **Resolution**: [how it was fixed, or "Unresolved — manual action needed"] **Pattern**: [generalised lesson, e.g. "Item values defined in combat GDD were not referenced in economy GDD before authoring — always check entities.yaml first"]
Only append if
docs/consistency-failures.md exists. If the file is missing,
skip this step silently — do not create the file from this skill.
Next Steps
- If PASS: Run
for holistic design-theory review, or/review-all-gdds
if all MVP GDDs are complete./create-architecture - If CONFLICTS FOUND: Fix the flagged GDDs, then re-run
to confirm resolution./consistency-check - If STALE REGISTRY: Update the registry (Phase 6), then re-run to verify.
- Run
after writing each new GDD to catch issues early, not at architecture time./consistency-check