codemap
npx skills add https://github.com/azidan/codemap --skill codemap
Agent 安装分布
Skill 文档
CodeMap – Codebase Structural Index
Navigate codebases efficiently using pre-built structural indexes stored in .codemap/ directories.
When to Use This Skill
USE CodeMap when:
- Finding where a class, function, method, or type is defined
- Understanding a file’s structure before reading it
- Searching for symbols by name
- Reducing token usage during codebase exploration
READ full files when:
- Understanding implementation details
- Making edits to code
- The symbol isn’t in the index (new/untracked file)
Quick Reference
# Find a symbol by name (case-insensitive)
codemap find "SymbolName"
# Filter by type
codemap find "handle" --type method
codemap find "User" --type class
codemap find "Config" --type interface
# Show file structure with all symbols
codemap show path/to/file.ts
# Check if index is up-to-date
codemap validate
# View index statistics
codemap stats
Workflow: Finding Code
Step 1: Find Symbol Location
codemap find "UserService"
Output:
src/services/user.ts:15-189 [class] UserService
(config: Config)
Step 2: Read Only Relevant Lines
Instead of reading the entire file, read just lines 15-189:
Read src/services/user.ts lines 15-189
Step 3: Explore Nested Symbols
codemap show src/services/user.ts
Output:
File: src/services/user.ts (hash: a3f2b8c1)
Lines: 542
Language: typescript
Symbols:
- UserService [class] L15-189
- constructor [method] L20-35
- getUser [method] L37-98
(userId: string) : Promise<User>
- createUser [async_method] L100-145
(data: CreateUserDto) : Promise<User>
Symbol Types
| Type | Description |
|---|---|
class |
Class declaration |
function |
Function declaration |
method |
Class method |
async_function |
Async function |
async_method |
Async class method |
interface |
TypeScript interface |
type |
TypeScript type alias |
enum |
Enum declaration |
Index Structure
The .codemap/ directory mirrors the project structure:
.codemap/
âââ .codemap.json # Root manifest
âââ _root.codemap.json # Files in project root
âââ src/
â âââ .codemap.json # Files in src/
â âââ services/
â âââ .codemap.json # Files in src/services/
Direct JSON Access
For programmatic access, read the JSON files directly:
cat .codemap/src/services/.codemap.json
Validation
Before trusting cached line numbers (especially after context compaction):
codemap validate path/to/file.ts
- “up to date”: Line ranges are valid
- “stale”: File changed, re-read or run
codemap update
Setup (If Not Initialized)
If a project doesn’t have a .codemap/ directory:
Prerequisites
- Python 3.10+ and pip must be installed
- Verify with:
python3 --version && pip --version
Installation
# Install codemap from GitHub (NOT from PyPI - there's a different package there)
pip install git+https://github.com/AZidan/codemap.git
# Initialize index
codemap init .
IMPORTANT: Do NOT use pip install codemap – that installs a different package from PyPI. Always use the GitHub URL above.
Start Watch Mode (Recommended)
Start watch mode in the background to keep the index automatically updated:
codemap watch . &
This runs in the background and updates the index whenever files change. No need to manually run codemap update.
To stop watch mode later:
pkill -f "codemap watch"
Best Practices
- Search before scanning: Always try
codemap findbefore grep/glob - Use line ranges: Read specific line ranges instead of full files
- Check freshness: Use
codemap validatebefore trusting cached line numbers - Explore structure first: Use
codemap showto understand file layout before diving in
Example Session
Task: “Fix the authentication bug in the login handler”
# 1. Find relevant symbols
codemap find "login"
# â src/auth/handlers.ts:45-92 [function] handleLogin
# 2. Check file structure
codemap show src/auth/handlers.ts
# Shows handleLogin and related functions with line ranges
# 3. Read only the relevant function (lines 45-92)
# ... make your fix ...
# 4. If you need related code, find it
codemap find "validateToken"
# â src/auth/utils.ts:12-38 [function] validateToken