codebase-index
Quickly index and understand a codebase's architecture. Use at session start to get up to speed fast. Finds entry points, API routes, classes, models, configs, and patterns.
allowed_tools: Bash, Read, Grep, Glob
$ Installieren
git clone https://github.com/Roger-Parkinson-EHP/agentic /tmp/agentic && cp -r /tmp/agentic/5.2-Coding-Assistants/5.2.1-Claude-Code/skills/codebase-index ~/.claude/skills/agentic// tip: Run this command in your terminal to install the skill
SKILL.md
name: codebase-index description: Quickly index and understand a codebase's architecture. Use at session start to get up to speed fast. Finds entry points, API routes, classes, models, configs, and patterns. allowed-tools: Bash, Read, Grep, Glob
Codebase Index - Fast Architecture Discovery
Get up to speed on any codebase in seconds, not minutes.
When to Use
- Session startup - First thing after entering a new repo
- Context recovery - After compaction, understand what you're working with
- New project - Quickly map an unfamiliar codebase
- Architecture review - Find patterns and structure
Quick Start Commands
Run these in sequence to build a mental map:
1. Entry Points (Where does it start?)
# Python entry points
rg "if __name__.*main" --type py -l
# Node/TypeScript entry points
rg "^(export default|module\.exports)" --type ts --type js -l | head -20
# Main files
ls -la **/main.* **/index.* **/app.* 2>/dev/null | head -20
2. API Endpoints (What does it expose?)
# FastAPI routes
rg "@(app|router)\.(get|post|put|delete|patch)" --type py -n | head -30
# Flask routes
rg "@.*\.route\(" --type py -n | head -30
# Express routes
rg "(app|router)\.(get|post|put|delete)\(" --type js --type ts -n | head -30
# Cloud Functions
rg "functions_framework|@functions\." --type py -n
3. Classes & Core Definitions
# Python classes
rg "^class \w+" --type py -n | head -40
# TypeScript/JS classes and interfaces
rg "^(export )?(class|interface|type) \w+" --type ts -n | head -40
# Python functions (top-level only)
rg "^def \w+" --type py -n | head -40
4. Database Models
# SQLAlchemy models
rg "class.*\(.*Base\)|class.*Model\):" --type py -n
# Prisma models
rg "^model \w+" --glob "*.prisma"
# Django models
rg "class.*models\.Model" --type py -n
# Pydantic models
rg "class.*\(.*BaseModel\)" --type py -n
5. Configuration & Environment
# Find config files
fd -e yaml -e yml -e toml -e ini -e json -e env 2>/dev/null | grep -i config | head -20
# Environment variable usage
rg "os\.environ|os\.getenv|process\.env" -n | head -30
# Settings/config classes
rg "class.*(Config|Settings)" --type py -n
6. Tests Structure
# Find test files
fd -e py -e ts -e js | grep -i test | head -20
# Test classes and functions
rg "^(class Test|def test_|describe\(|it\()" --type py --type ts --type js -n | head -30
7. Key Imports (Dependencies)
# Most imported packages (Python)
rg "^(from|import) " --type py | cut -d' ' -f2 | cut -d'.' -f1 | sort | uniq -c | sort -rn | head -20
# Package.json dependencies
cat package.json 2>/dev/null | grep -A 50 '"dependencies"' | head -30
8. Architecture Patterns
# Decorators (Python)
rg "^@\w+" --type py | cut -d':' -f2 | sort | uniq -c | sort -rn | head -15
# Dependency injection
rg "Depends\(|@inject|@Inject" --type py --type ts -n
# Error handling patterns
rg "class.*Exception|class.*Error\(" --type py -n
# Logging setup
rg "logging\.(getLogger|basicConfig)|logger = " --type py -n | head -15
Language-Specific Quick Indexes
Python Project
# One-liner: core structure
rg "^(class |def |@app\.|@router\.)" --type py -n | head -50
TypeScript/Node Project
# One-liner: core structure
rg "^(export |class |interface |function |\s*(get|post)\()" --type ts -n | head -50
Go Project
# One-liner: core structure
rg "^(func |type .* struct)" --type go -n | head -50
Full Codebase Snapshot
Run this to get a complete picture:
echo "=== ENTRY POINTS ===" && rg "if __name__|^func main" --type py --type go -l 2>/dev/null
echo "=== API ROUTES ===" && rg "@(app|router)\.(get|post|put|delete)" --type py -c 2>/dev/null
echo "=== CLASSES ===" && rg "^class " --type py -c 2>/dev/null | head -10
echo "=== CONFIG FILES ===" && fd -e yaml -e toml -e env 2>/dev/null | head -10
echo "=== TEST FILES ===" && fd test --type f 2>/dev/null | wc -l
Pro Tips
| Tip | Why |
|---|---|
Use -c (count) first | See scope before diving in |
Use -l (files only) | Find relevant files, then read them |
Pipe to head | Don't overwhelm context with output |
Chain with grep -i topic | Filter results to what you care about |
Use --type flags | Focus on relevant file types |
Token Efficiency
All commands return summaries, not full files. A complete codebase index typically uses <500 tokens while giving you the mental map to know exactly what to read next.
Related Skills
- index-docs: Markdown heading extraction
- search-history: Find past discussions about this codebase
- post-compact: Full context recovery workflow
Repository

Roger-Parkinson-EHP
Author
Roger-Parkinson-EHP/agentic/5.2-Coding-Assistants/5.2.1-Claude-Code/skills/codebase-index
0
Stars
0
Forks
Updated3h ago
Added1w ago