| name | document-guideline |
| description | Instructs AI agents on documentation standards for design docs, folder READMEs, source code interfaces, and test cases |
Document Guideline
This skill instructs AI agents on how to maintain comprehensive documentation throughout the development lifecycle. It defines documentation standards that are enforced via pre-commit linting for structural requirements, while providing guidance on content quality and workflow integration.
Documentation Philosophy
Good documentation is:
- Comprehensive: Covers all code files, folders, and high-level designs
- Enforced: Structural requirements validated automatically via pre-commit linting
- Design-first: Documentation written before implementation (following TDD approach)
- Milestone-friendly: Documentation-code inconsistency acceptable during incremental development
- Self-descriptive: Each file, folder, and component documents its purpose and interfaces
Documentation Types
This project maintains three levels of documentation:
- High-level design documents (
docs/*) - Architecture and design decisions - Folder organization (folder
README.mdfiles) - Purpose and file organization - Code interface documentation (
.mdcompanions to source files) - External and internal APIs
High-Level Design Documentation
Location: docs/* directory
Purpose: Document architectural decisions, design rationale, and high-level project structure.
When to create/update:
- During planning phase (before implementation)
- When making architectural decisions
- When introducing new subsystems or major features
- When documenting workflows or processes
Not enforced by linting: Creating design documents requires human judgment about what constitutes a "high-level design" versus implementation details.
Content guidelines:
- Focus on the "why" (design rationale) not just the "what"
- Document alternatives considered and trade-offs
- Include diagrams, workflows, or examples where helpful
- Keep design docs synchronized with actual implementation
Examples of good design documents:
docs/git-msg-tags.md- Documents commit message tag standardsdocs/developer.md- Developer workflow and contribution guidelinesdocs/options.md- SDK configuration options and usage
When NOT to create design docs:
- For simple implementation details (put in code
.mdfiles instead) - For temporary decisions or experiments
- For information that duplicates existing documentation
Folder Organization Documentation
Requirement: Every folder (except hidden folders like .git) MUST have a README.md file.
Enforced by: Pre-commit linting (scripts/lint-documentation.sh)
Purpose: Document folder purpose and file organization so developers can quickly understand the codebase structure.
When to create:
- When creating a new folder in the project
- Before committing any code that introduces a new directory
Required content:
- Folder purpose: What is this folder for? (1-2 sentences)
- File organization: What types of files are in this folder?
- Key files: Brief description of important files (optional)
Examples of good folder README.md:
# Skills Directory
This directory contains all Claude Code skills that define AI agent behavior.
## Organization
Each skill is in its own subdirectory with a `SKILL.md` file:
- `commit-msg/` - Skill for creating meaningful git commits
- `fork-dev-branch/` - Skill for creating development branches
- `milestone/` - Skill for incremental implementation with milestone commits
## Adding New Skills
Create a new subdirectory and add a `SKILL.md` file with frontmatter defining
the skill name and description.
Format flexibility:
- Can be brief (3-5 lines) for simple folders
- Can be detailed for complex subsystems
- Should reference key files if there are many files
Source Code Interface Documentation
Requirement: Every source code file MUST have a corresponding .md file documenting its interfaces.
File types requiring documentation (enforced by linting):
- Python:
*.py→*.md - C/C++:
*.c,*.cpp,*.cxx,*.cc→*.md
Enforced by: Pre-commit linting (scripts/lint-documentation.sh)
Naming convention: Same prefix as source file
foo.py→foo.mdbar.cpp→bar.mdbaz.c→baz.md
Required sections:
1. External Interfaces (Public APIs)
Document all interfaces exposed to external callers:
- Public functions/methods with signatures
- Public classes/structures with key attributes
- Module-level exports or entry points
- Expected inputs and outputs
- Error conditions and exceptions
2. Internal Helpers (Private APIs)
Document internal implementation details:
- Private functions and their purpose
- Internal data structures
- Helper utilities
- Algorithms or complex logic explanations
Example interface documentation:
# validate_target_dir.sh
Script for validating target directories before SDK initialization.
## External Interface
### Command-line usage
```bash
./validate_target_dir.sh <target_dir> <mode>
Parameters:
target_dir: Path to directory to validatemode: Either "init" or "update"
Exit codes:
- 0: Validation passed
- 1: Validation failed (directory issues)
- 2: Invalid arguments
Output: Error messages to stderr listing validation failures
Internal Helpers
check_directory_exists()
Validates that the target directory exists.
check_write_permissions()
Validates that the user has write access to the directory.
check_conflicting_files()
Scans for files that would conflict with SDK initialization. Returns list of conflicting file paths.
validate_init_mode()
Specific validation for "init" mode (directory must be empty or non-existent).
validate_update_mode()
Specific validation for "update" mode (directory must have existing SDK structure).
**When implementation changes**:
- Update interface documentation to match
- During milestones, temporary doc-code mismatch is acceptable (see below)
- Before final delivery, all documentation must match implementation
## Test Documentation
**Requirement**: Every test case **MUST** have documentation explaining what it tests.
**Enforced by**: Pre-commit linting (`scripts/lint-documentation.sh`)
**Format options**:
1. **Inline comments** within the test file (preferred for simple tests)
2. **Companion `.md` file** (for complex test suites)
**Required content**:
- What is being tested (feature or behavior)
- Expected outcome
- Any setup or preconditions
**Example with inline comments**:
```bash
#!/bin/bash
# Test suite for documentation linting
# Tests that the linter correctly identifies missing documentation
set -e
# Test 1: Linter passes with complete documentation
# Expected: Exit code 0, no errors
test_complete_documentation() {
# Setup: Create temporary directory with all docs present
...
}
# Test 2: Linter fails when folder missing README.md
# Expected: Exit code 1, error message lists folder
test_missing_folder_readme() {
...
}
Example with companion .md file:
For test_documentation_lint.sh, create test_documentation_lint.md:
# Documentation Linter Test Suite
Tests for `scripts/lint-documentation.sh` to verify it correctly validates
documentation completeness.
## Test Cases
### test_complete_documentation
**Purpose**: Verify linter passes when all documentation is present
**Setup**: Temporary directory with source files and corresponding .md files
**Expected**: Exit code 0, no error output
### test_missing_folder_readme
**Purpose**: Verify linter catches folders without README.md
**Setup**: Create folder without README.md
**Expected**: Exit code 1, error message listing the folder
...
Linting check:
- For bash test files (
test_*.sh), linter checks for either:- Inline comments following pattern
# Test N:or# Test:or function comments - Companion
.mdfile with same prefix
- Inline comments following pattern
Documentation-Code Consistency During Milestones
Design-First TDD Workflow
This project follows strict design-first test-driven development:
- Phase 1: Documentation - Update all relevant documentation first
- Phase 2: Tests - Write test cases based on documentation
- Phase 3: Implementation - Write code to make tests pass
Acceptable Documentation-Code Inconsistency
During milestone commits, documentation and code may be temporarily inconsistent:
Why this happens:
- Documentation describes the final intended state
- Implementation is incrementally catching up to match documentation
- Tests are written based on documentation (may not all pass yet)
When it's acceptable:
- During milestone commits: Documentation complete, implementation in progress
- On development branches: Work is ongoing, not ready for final delivery
- With explicit test status: Milestone commits show
N/M tests passed
When it's NOT acceptable:
- Final delivery commits: All tests must pass, docs must match code
- Merging to main branch: Complete consistency required
- Production releases: Documentation must accurately reflect implementation
Pre-commit Linting and Milestones
The documentation linter (scripts/lint-documentation.sh) runs as part of the
pre-commit hook and validates:
- All folders have
README.md - All source files have corresponding
.mdfiles - All test files have documentation
Bypassing the linter:
For milestone commits where documentation is complete but implementation is incomplete:
git commit --no-verify -m "milestone: ..."
The --no-verify flag bypasses all pre-commit hooks, including:
- Documentation linting
- Test execution
IMPORTANT: Only bypass for milestone commits on development branches. Never bypass for final delivery commits or commits to main branch.
Milestone progression example:
Milestone 1: Documentation complete (bypass linting OK)
- All .md files created and document final interfaces
- Implementation: 0% complete
- Tests: 0/10 passed (expected, no implementation yet)
- Commit with: --no-verify
Milestone 2: Partial implementation (bypass linting OK)
- Documentation: Still accurate for final state
- Implementation: 60% complete
- Tests: 6/10 passed
- Commit with: --no-verify
Delivery: All tests pass (NO bypass)
- Documentation: Matches implementation exactly
- Implementation: 100% complete
- Tests: 10/10 passed
- Commit without: --no-verify (linter must pass)
Integration with Other Skills
This documentation guideline integrates with other project skills:
Integration with plan-guideline skill
When creating implementation plans, the plan-guideline skill references these
documentation standards:
- Step 1 in plans should always be documentation updates
- Plans should list specific
.mdfiles to create/update - Plans should note which documentation is enforced by linting
Integration with milestone skill
The milestone skill uses these guidelines for incremental development:
- Milestone 1 always creates documentation first
--no-verifybypass acceptable for milestone commits- Milestone commits track test progress (N/M tests passed)
- Final delivery requires all linting to pass
Integration with commit-msg skill
The commit-msg skill considers documentation standards:
- Commits updating only documentation use
[docs]tag - Milestone commits note test status in message
- Delivery commits confirm all lints pass
Summary
Enforced by linting (structural requirements):
- ✅ Folder
README.mdexistence - ✅ Source code
.mdfile correspondence - ✅ Test documentation presence
Guided by skill (content quality):
- High-level design document creation
- Interface documentation completeness
- Explanation clarity and usefulness
Workflow integration:
- Documentation written first (design-first TDD)
- Temporary doc-code mismatch OK during milestones
- All documentation must match code at delivery