doc-sync
Doc Sync
Maintains the CLAUDE.md navigation hierarchy and optional README.md architecture docs across a repository. This skill is self-contained and performs all documentation work directly.
Triggers
| Trigger Phrase | Operation |
|---|---|
sync docs |
Repository-wide CLAUDE.md audit and update |
update CLAUDE.md files |
Repository-wide index refresh |
sync docs in src/parser/ |
Directory-scoped index update |
audit documentation |
Full discovery, audit, and drift report |
update CLAUDE.md for config.py |
Single-file parent directory update |
When to Use
Use this skill when:
- CLAUDE.md files may be out of sync with actual directory contents
- New files or directories were added without index updates
- Architecture content is mixed into CLAUDE.md index files
- A doc audit is needed after significant code changes
Use direct editing instead when:
- Adding inline code comments or docstrings
- Writing function-level documentation
- Updating a single README.md with no index impact
Verification
After execution:
- Every directory in scope has a CLAUDE.md file
- All CLAUDE.md files use table-based index format (What/When columns)
- No drift remains between file system and index entries
- No architecture prose in subdirectory CLAUDE.md files (moved to README.md)
- README.md files are indexed in their parent CLAUDE.md
- Doc Sync Report generated with change summary
Scope Resolution
Determine scope FIRST:
| User Request | Scope |
|---|---|
| "sync docs" / "update documentation" / no specific path | REPOSITORY-WIDE |
| "sync docs in src/validator/" | DIRECTORY: src/validator/ and descendants |
| "update CLAUDE.md for parser.py" | FILE: single file's parent directory |
For REPOSITORY-WIDE scope, perform a full audit. For narrower scopes, operate only within the specified boundary.
CLAUDE.md Format Specification
Index Format
Use tabular format with What and When columns:
## Files
| File | What | When to read |
| ----------- | ------------------------------ | ----------------------------------------- |
| `cache.rs` | LRU cache with O(1) operations | Implementing caching, debugging evictions |
| `errors.rs` | Error types and Result aliases | Adding error variants, handling failures |
## Subdirectories
| Directory | What | When to read |
| ----------- | ----------------------------- | ----------------------------------------- |
| `config/` | Runtime configuration loading | Adding config options, modifying defaults |
| `handlers/` | HTTP request handlers | Adding endpoints, modifying request flow |
Column Guidelines
- File/Directory: Use backticks around names:
cache.rs,config/ - What: Factual description of contents (nouns, not actions)
- When to read: Task-oriented triggers using action verbs (implementing, debugging, modifying, adding, understanding)
- At least one column must have content; empty cells use
-
Trigger Quality Test
Given task "add a new validation rule", can an LLM scan the "When to read" column and identify the right file?
ROOT vs SUBDIRECTORY CLAUDE.md
ROOT CLAUDE.md:
# [Project Name]
[One sentence: what this is]
## Files
| File | What | When to read |
| ---- | ---- | ------------ |
## Subdirectories
| Directory | What | When to read |
| --------- | ---- | ------------ |
## Build
[Copy-pasteable command]
## Test
[Copy-pasteable command]
## Development
[Setup instructions, environment requirements, workflow notes]
SUBDIRECTORY CLAUDE.md:
# [directory-name]/
## Files
| File | What | When to read |
| ---- | ---- | ------------ |
## Subdirectories
| Directory | What | When to read |
| --------- | ---- | ------------ |
Critical constraint: Subdirectory CLAUDE.md files are PURE INDEX. No prose, no overview sections, no architectural explanations. Those belong in README.md.
README.md Specification
Creation Criteria (Invisible Knowledge Test)
Create README.md ONLY when the directory contains knowledge NOT visible from reading the code:
- Multiple components interact through non-obvious contracts or protocols
- Design tradeoffs were made that affect how code should be modified
- The directory's structure encodes domain knowledge (e.g., processing order matters)
- Failure modes or edge cases aren't apparent from reading individual files
- There are "rules" developers must follow that aren't enforced by the compiler/linter
DO NOT create README.md when:
- The directory is purely organizational (just groups related files)
- Code is self-explanatory with good function/module docs
- You'd be restating what CLAUDE.md index entries already convey
Content Test
For each sentence in README.md, ask: "Could a developer learn this by reading the source files?"
- If YES: delete the sentence
- If NO: keep it
README.md earns its tokens by providing INVISIBLE knowledge: the reasoning behind the code, not descriptions of the code.
README.md Structure
# [Component Name]
## Overview
[One paragraph: what problem this solves, high-level approach]
## Architecture
[How sub-components interact; data flow; key abstractions]
## Design Decisions
[Tradeoffs made and why; alternatives considered]
## Invariants
[Rules that must be maintained; constraints not enforced by code]
Workflow
Phase 1: Discovery
Map directories requiring CLAUDE.md verification:
# Find all directories (excluding .git, node_modules, __pycache__, etc.)
find . -type d \( -name .git -o -name node_modules -o -name __pycache__ -o -name .venv -o -name target -o -name dist -o -name build \) -prune -o -type d -print
For each directory in scope, record:
- Does CLAUDE.md exist?
- If yes, does it have the required table-based index structure?
- What files/subdirectories exist that need indexing?
Phase 2: Audit
For each directory, check for drift and misplaced content:
<audit_check dir="[path]">
CLAUDE.md exists: [YES/NO]
Has table-based index: [YES/NO]
Files in directory: [list]
Files in index: [list]
Missing from index: [list]
Stale in index (file deleted): [list]
Triggers are task-oriented: [YES/NO/PARTIAL]
Contains misplaced content: [YES/NO] (architecture/design docs that belong in README.md)
README.md exists: [YES/NO]
README.md warranted: [YES/NO] (invisible knowledge present?)
</audit_check>
Phase 3: Content Migration
Critical: If CLAUDE.md contains content that does NOT belong there, migrate it:
Content that MUST be moved from CLAUDE.md to README.md:
- Architecture explanations or diagrams
- Design decision documentation
- Component interaction descriptions
- Overview sections with prose (in subdirectory CLAUDE.md files)
- Invariants or rules documentation
- Any "why" explanations beyond simple triggers
Migration process:
- Identify misplaced content in CLAUDE.md
- Create or update README.md with the architectural content
- Strip CLAUDE.md down to pure index format
- Add README.md to the CLAUDE.md index table
Phase 4: Index Updates
For each directory needing work:
Creating/Updating CLAUDE.md:
- Use the appropriate template (ROOT or SUBDIRECTORY)
- Populate tables with all files and subdirectories
- Write "What" column: factual content description
- Write "When to read" column: action-oriented triggers
- If README.md exists, include it in the Files table
Creating README.md (only when warranted):
- Verify invisible knowledge criteria are met
- Document architecture, design decisions, invariants
- Apply the content test: remove anything visible from code
- Keep under ~500 tokens
Phase 5: Verification
After all updates complete, verify:
- Every directory in scope has CLAUDE.md
- All CLAUDE.md files use table-based index format
- No drift remains (files <-> index entries match)
- No misplaced content in CLAUDE.md (architecture docs moved to README.md)
- README.md files are indexed in their parent CLAUDE.md
- Subdirectory CLAUDE.md files contain no prose/overview sections
Output Format
## Doc Sync Report
### Scope: [REPOSITORY-WIDE | directory path]
### Changes Made
- CREATED: [list of new CLAUDE.md files]
- UPDATED: [list of modified CLAUDE.md files]
- MIGRATED: [list of content moved from CLAUDE.md to README.md]
- CREATED: [list of new README.md files]
- FLAGGED: [any issues requiring human decision]
### Verification
- Directories audited: [count]
- CLAUDE.md coverage: [count]/[total] (100%)
- Drift detected: [count] entries fixed
- Content migrations: [count] (architecture docs moved to README.md)
- README.md files: [count] (only where warranted)
Exclusions
DO NOT index:
- Generated files (dist/, build/, .generated., compiled outputs)
- Vendored dependencies (node_modules/, vendor/, third_party/)
- Git internals (.git/)
- IDE/editor configs (.idea/, .vscode/ unless project-specific settings)
DO index:
- Hidden config files that affect development (.eslintrc, .env.example, .gitignore)
- Test files and test directories
- Documentation files (including README.md)
Anti-Patterns
| Avoid | Why | Instead |
|---|---|---|
| Vague "When to read" triggers | Matches everything, helps nothing | Use specific action verbs: "implementing", "debugging" |
| Putting architecture prose in subdirectory CLAUDE.md | CLAUDE.md is pure index | Move to README.md, index the README |
| Recreating CLAUDE.md from memory | Misses files, wrong format | Run discovery phase, use template |
| Syncing a single file without checking parent index | Creates partial drift | Always verify parent directory index too |
| Creating README.md for simple directories | Token waste, redundant with code | Apply invisible knowledge test first |
Index Anti-Patterns (Detailed)
Too vague (matches everything):
| `config/` | Configuration | Working with configuration |
Content description instead of trigger:
| `cache.rs` | Contains the LRU cache implementation | - |
Missing action verb:
| `parser.py` | Input parsing | Input parsing and format handling |
Correct Examples
| `cache.rs` | LRU cache with O(1) get/set | Implementing caching, debugging misses, tuning eviction |
| `config/` | YAML config parsing, env overrides | Adding config options, changing defaults, debugging config loading |
When NOT to Use This Skill
- Single file documentation (inline comments, docstrings) - handle directly
- Code comments - handle directly
- Function/module docstrings - handle directly
- This skill is for CLAUDE.md/README.md synchronization specifically
Reference
For additional trigger pattern examples, see references/trigger-patterns.md.
More from rjmurillo/ai-agents
reflect
CRITICAL learning capture. Extracts HIGH/MED/LOW confidence patterns from conversations to prevent repeating mistakes and preserve what works. Use PROACTIVELY after user corrections ("no", "wrong"), after praise ("perfect", "exactly"), when discovering edge cases, or when skills are heavily used. Without reflection, valuable learnings are LOST forever. Acts as continuous improvement engine for all skills. Invoke EARLY and OFTEN - every correction is a learning opportunity.
14threat-modeling
Structured security analysis using OWASP Four-Question Framework and STRIDE methodology. Generates threat matrices with risk ratings, mitigations, and prioritization. Use for attack surface analysis, security architecture review, or when asking what can go wrong.
2chestertons-fence
Investigate historical context of existing code, patterns, or constraints before proposing changes. Automates git archaeology, PR/ADR search, and dependency analysis to prevent removing structures without understanding their purpose.
2github-url-intercept
BLOCKING INTERCEPT: When ANY github.com URL appears in user input, STOP and use this skill. Never fetch GitHub HTML pages directly - they are 5-10MB and will exhaust your context window. This skill routes URLs to efficient API calls (1-50KB). Triggers on: pull/, issues/, blob/, tree/, commit/, compare/, discussions/.
2git-advanced-workflows
Advanced Git workflows including rebasing, cherry-picking, bisect, worktrees, and reflog. Use when managing complex Git histories, collaborating on feature branches, or recovering from repository issues.
2pr-comment-responder
PR review coordinator who gathers comment context, acknowledges every
2