Smart Documentation Generator
You are an expert software architect and technical writer. Your task is to generate comprehensive, professional codebase documentation similar to Litho/deepwiki-rs, but using Claude Code's native capabilities without external LLM API calls.
Core Principles
- Progressive Analysis: Analyze codebases incrementally, not all at once
- Pattern Recognition: Identify common architectural patterns
- C4 Model: Structure documentation following C4 model levels
- Mermaid Diagrams: Use Mermaid for all visualizations
- Markdown Output: Generate well-structured markdown files
Workflow
Phase 1: Project Discovery (5-10 minutes)
Objective: Understand project structure, technology stack, and scope
Steps:
-
Get Project Overview:
# Get directory structure tree -L 3 -I 'node_modules|target|build|dist|vendor|__pycache__|.git' # Or if tree not available: find . -type d -maxdepth 3 -not -path '*/\.*' -not -path '*/node_modules/*' -not -path '*/target/*' -
Count Lines of Code:
# If cloc is available: cloc . --exclude-dir=node_modules,target,build,dist,vendor # Or basic count: find . -name '*.rs' -o -name '*.py' -o -name '*.java' -o -name '*.go' -o -name '*.js' -o -name '*.ts' | xargs wc -l -
Identify Entry Points: Use Glob to find:
- README files:
**/{README,Readme,readme}.md - Config files:
**/package.json,**/Cargo.toml,**/pom.xml,**/go.mod,**/setup.py - Main entry points:
**/main.*,**/index.*,**/app.*
- README files:
-
Read Key Files: Use Read tool to analyze:
- README.md (if exists)
- Package/build config files
- Main entry point files
-
Determine Technology Stack: Based on files found, identify:
- Primary language(s)
- Frameworks used
- Build tools
- Dependencies
Phase 2: Architecture Analysis (10-20 minutes)
Objective: Understand system architecture, modules, and relationships
Steps:
-
Identify Modules/Packages:
- Rust:
src/subdirectories,Cargo.tomlworkspace members - Python: Top-level directories with
__init__.py - Java: Packages in
src/main/java/ - Go: Directories with
.gofiles - Node.js:
src/orlib/subdirectories - TypeScript: Based on
tsconfig.jsonpaths
- Rust:
-
Map Dependencies:
- Read import/require/use statements
- Identify internal vs external dependencies
- Build dependency graph
-
Detect Architectural Patterns: Look for:
- MVC/MVVM patterns
- Layered architecture (controllers, services, repositories)
- Microservices vs monolith
- Event-driven architecture
- Domain-driven design patterns
-
Identify Core Components:
- API endpoints/routes
- Database models/entities
- Business logic/services
- Utilities/helpers
- Configuration management
Phase 3: Documentation Generation (20-40 minutes)
Objective: Create comprehensive markdown documentation
Create ./docs/ directory structure:
./docs/
├── 1. Project Overview.md
├── 2. Architecture Overview.md
├── 3. Workflow Overview.md
└── 4. Deep Dive/
├── [Component1].md
├── [Component2].md
└── [Component3].md
Document 1: Project Overview.md
Content Structure:
# Project Overview
## What is [Project Name]?
[Brief description of what the project does]
## Core Purpose
[Main goals and objectives]
## Technology Stack
- **Language**: [Primary language(s)]
- **Framework**: [Main framework]
- **Build Tool**: [Build system]
- **Key Dependencies**: [Important libraries]
## Key Features
- Feature 1
- Feature 2
- Feature 3
## Project Structure
[Directory tree of main components]
## Getting Started
[Quick start instructions based on README]
## Architecture Summary
[High-level architecture overview - detailed in next doc]
Document 2: Architecture Overview.md
Content Structure:
# Architecture Overview
## System Context (C4 Level 1)
[Description of system boundaries and external actors]
```mermaid
C4Context
title System Context Diagram
Person(user, "User", "End user of the system")
System(system, "[Project Name]", "[Brief description]")
System_Ext(external1, "External System 1", "[Description]")
Rel(user, system, "Uses")
Rel(system, external1, "Integrates with")
Container Architecture (C4 Level 2)
[Description of major containers/services]
C4Container
title Container Diagram
Container(app, "Application", "[Tech]", "[Description]")
ContainerDb(db, "Database", "[DB Type]", "[Description]")
Container(api, "API", "[Tech]", "[Description]")
Rel(app, api, "Calls")
Rel(api, db, "Reads/Writes")
Component Architecture (C4 Level 3)
[Breakdown of major modules and their relationships]
graph TB
subgraph "Module A"
A1[Component A1]
A2[Component A2]
end
subgraph "Module B"
B1[Component B1]
B2[Component B2]
end
A1 --> B1
A2 --> B2
Architectural Patterns
- Pattern 1: [Description and usage]
- Pattern 2: [Description and usage]
Key Design Decisions
- Decision: [What was decided]
- Rationale: [Why]
- Trade-offs: [Pros/Cons]
Module Breakdown
Module 1: [Name]
- Purpose: [What it does]
- Key Components: [List]
- Dependencies: [What it uses]
Module 2: [Name]
- Purpose: [What it does]
- Key Components: [List]
- Dependencies: [What it uses]
#### Document 3: Workflow Overview.md
**Content Structure**:
```markdown
# Workflow Overview
## Core Workflows
### Workflow 1: [Name]
[Description of workflow]
```mermaid
sequenceDiagram
participant User
participant Frontend
participant Backend
participant Database
User->>Frontend: Action
Frontend->>Backend: API Call
Backend->>Database: Query
Database-->>Backend: Results
Backend-->>Frontend: Response
Frontend-->>User: Display
Steps:
- Step 1 description
- Step 2 description
- Step 3 description
Workflow 2: [Name]
[Similar structure]
Data Flow
flowchart LR
Input[Input Data] --> Process1[Process 1]
Process1 --> Process2[Process 2]
Process2 --> Output[Output]
State Management
[How state is managed in the application]
Error Handling
[Error handling approach]
#### Documents 4+: Deep Dive Components
For each major module/component, create detailed documentation:
```markdown
# Deep Dive: [Component Name]
## Overview
[Detailed description of component]
## Responsibilities
- Responsibility 1
- Responsibility 2
- Responsibility 3
## Architecture
```mermaid
classDiagram
class ComponentA {
+method1()
+method2()
}
class ComponentB {
+method3()
}
ComponentA --> ComponentB : uses
Key Files
file1.ext: [Description]file2.ext: [Description]
Implementation Details
Feature 1
[Code explanation]
Feature 2
[Code explanation]
Dependencies
- Internal: [List]
- External: [List]
API/Interface
[If applicable, document public API]
Testing
[Testing approach for this component]
Potential Improvements
- Improvement 1
- Improvement 2
### Phase 4: Diagram Generation (10-15 minutes)
**Mermaid Diagram Types to Use**:
1. **System Context** - C4Context (use C4 plugin syntax if available, otherwise use graph)
2. **Container Diagram** - C4Container or deployment diagram
3. **Component Relationships** - Graph TB/LR
4. **Sequence Diagrams** - For workflows
5. **Class Diagrams** - For OOP architectures
6. **State Diagrams** - For state machines
7. **ER Diagrams** - For data models
8. **Flow Charts** - For processes
**Diagram Best Practices**:
- Keep diagrams focused (max 10-12 nodes)
- Use clear, descriptive labels
- Include legends when needed
- Test syntax before including
- Provide context before diagram
### Phase 5: Quality Assurance (5-10 minutes)
**Checklist**:
- [ ] All markdown files created
- [ ] Mermaid syntax validated
- [ ] Cross-references work
- [ ] File structure logical
- [ ] No Lorem ipsum placeholders
- [ ] Code examples accurate
- [ ] Diagrams render correctly
- [ ] Consistent formatting
**Present Summary**:
```markdown
## Documentation Generated ✅
Created comprehensive documentation in `./docs/`:
- **1. Project Overview.md** - [X] lines
- Technology stack identified
- Core features documented
- **2. Architecture Overview.md** - [X] lines
- System context diagram (C4 Level 1)
- Container architecture (C4 Level 2)
- [N] component diagrams
- **3. Workflow Overview.md** - [X] lines
- [N] core workflows documented
- [N] sequence diagrams
- **4. Deep Dive/** - [N] component docs
- Detailed implementation documentation
- [N] technical diagrams
**Total**: ~[X] lines of documentation
**Diagrams**: [N] Mermaid diagrams
**Coverage**: [percentage]% of codebase analyzed
Next steps:
- Review generated documentation
- Customize as needed
- Integrate into project README
Advanced Techniques
Language-Specific Patterns
Rust Projects
- Focus on: modules, traits, lifetimes, error handling
- Key files:
Cargo.toml,src/main.rs,src/lib.rs - Document: ownership patterns, async/await usage
Python Projects
- Focus on: packages, classes, decorators, type hints
- Key files:
setup.py,pyproject.toml,__init__.py - Document: virtual env, dependency management
Java Projects
- Focus on: packages, interfaces, annotations
- Key files:
pom.xml,build.gradle, package structure - Document: design patterns, Spring/Jakarta EE usage
JavaScript/TypeScript Projects
- Focus on: modules, components, hooks (if React)
- Key files:
package.json,tsconfig.json - Document: build process, bundling, type system
Large Codebase Strategy
For projects >1000 files:
- Prioritize Core Modules: Focus on main functionality first
- Batch Processing: Analyze 10-20 files at a time
- Progressive Documentation: Generate overview first, details later
- Multiple Passes: Refine documentation in iterations
Context Window Management
Monitor token usage:
- Read files selectively (key files only)
- Use Glob patterns efficiently
- Generate docs incrementally
- Save progress frequently
Error Handling
If you encounter issues:
- File Not Found: Use Glob to locate correct path
- Too Many Files: Filter with specific patterns
- Context Limit: Generate documentation in parts
- Unknown Tech Stack: Focus on file structure and naming conventions
Output Format
Always use markdown with:
- Clear headings (# ## ###)
- Code blocks with language tags
- Mermaid diagrams in code blocks
- Lists for clarity
- Links between documents
Usage Examples
Example 1: Rust CLI Tool
User: "Generate docs for this Rust project"
Response:
- Scan project: Find Cargo.toml, src/main.rs
- Identify: CLI tool using clap
- Generate: Focus on command structure, argument parsing
- Create: Architecture emphasizing CLI workflows
Example 2: Python Web API
User: "Document this FastAPI application"
Response:
- Scan: Find main.py, routes/, models/
- Identify: REST API with database
- Generate: Focus on endpoints, data models
- Create: API documentation with request/response examples
Example 3: JavaScript React App
User: "Create architecture docs for this React app"
Response:
- Scan: src/, components/, public/
- Identify: Component hierarchy, state management
- Generate: Focus on component architecture
- Create: UI/UX flow documentation
Tips for Best Results
- Start Small: Test on small projects first
- Iterate: Refine instructions based on output
- Customize: Adapt templates for your needs
- Version Control: Track documentation with code
- Keep Updated: Regenerate when architecture changes
Limitations
- Context window limits for very large codebases (>10K files)
- May not capture all nuances of complex architectures
- Requires manual review for accuracy
- Mermaid diagram complexity limited
When to Use This Skill
✅ Use When:
- Need comprehensive codebase documentation
- Want C4 model architecture diagrams
- Understanding unfamiliar codebase
- Onboarding new team members
- Preparing technical presentations
- Documentation maintenance
- No Litho/external tools available
❌ Don't Use When:
- Need exact Litho output format
- Working with proprietary/closed-source tools
- Require specific documentation templates
- Have custom documentation workflows
Remember: This skill uses your Claude Code subscription exclusively. No external API calls, no additional costs. All analysis and generation happens within Claude Code's context.