codemap is a code analysis tool designed to generate a compact, structured "brain map" of your codebase for large language models (LLMs) to understand instantly. By providing architectural context without burning tokens, codemap helps developers and AI systems work more efficiently together.
Key Features:
Generates an architectural overview of your codebase for LLMs in one command.
Supports multiple modes for analysis:
Diff Mode: Visualizes changes in the codebase compared to a reference branch.
Dependency Flow: Maps how different parts of the codebase interact and depend on each other.
Skyline Mode: Provides a visual representation of the project's structure as a city skyline.
Works with over 18 programming languages, including Go, Python, JavaScript, TypeScript, Rust, and more.
Audience & Benefit:
Ideal for developers, AI researchers, and teams leveraging LLMs to analyze or generate code. By providing instant context, codemap saves time, reduces token usage, and enhances collaboration between humans and AI systems. It is particularly beneficial for projects where understanding the codebase's structure is critical for efficient development and integration with AI tools.
codemap can be installed via winget on Windows, making it accessible across different operating systems.
README
codemap šŗļø
> codemap ā a project brain for your AI.
> Give LLMs instant architectural context without burning tokens.
Install
# macOS/Linux
brew tap JordanCoin/tap && brew install codemap
# Windows
scoop bucket add codemap https://github.com/JordanCoin/scoop-codemap
scoop install codemap
> Other options: Releases | go install | Build from source
Recommended Setup (Hooks + Daemon + Config)
No repo clone is required for normal users.
Run setup from your git repo root (not a subdirectory), or hooks may not resolve project context.
# install codemap first (package manager)
brew tap JordanCoin/tap && brew install codemap
# then run setup inside your project
cd /path/to/your/project
codemap setup
codemap setup is the default onboarding path and configures the pieces that make codemap most useful with Claude:
creates .codemap/config.json (if missing) with auto-detected language filters
installs codemap hooks into .claude/settings.local.json (project-local by default)
hooks automatically start/read daemon state on session start
Use global Claude settings instead of project-local settings:
At session start, you should see codemap project context.
Edit a file and confirm pre/post edit hook context appears.
Daily Commands
codemap . # Fast tree/context view (respects .codemap/config.json)
codemap --diff # What changed vs main
codemap handoff . # Save layered handoff for cross-agent continuation
codemap --deps . # Dependency flow (requires ast-grep)
codemap skill list # Show available skills
codemap context # Universal JSON context for any AI tool
codemap mcp # Run Codemap MCP server on stdio
codemap plugin install # Install the Codemap Codex plugin
codemap serve # HTTP API for non-MCP integrations
Uses a shallow clone to a temp directory (fast, no history, auto-cleanup). If you already have the repo cloned locally, codemap will use your local copy instead.
.codemap/handoff.metrics.log (append-only metrics stream, one JSON line per save)
Save defaults:
CLI saves by default; use --no-save to make generation read-only.
MCP does not save by default; set save=true to persist artifacts.
Compatibility note:
legacy top-level fields (changed_files, risk_files, etc.) are still included for compatibility and will be removed in a future schema version after migration.
Why this matters:
default transport is compact stubs (low context cost)
full per-file context is lazy-loaded only when needed (--detail / file=...)
output is deterministic and budgeted to reduce context churn across agent turns
Hook integration:
session-stop writes .codemap/handoff.latest.json
session-start shows a compact recent handoff summary (24h freshness window)
CLAUDE.md ā Add to your project root to teach Claude when to run codemap:
cp /path/to/codemap/CLAUDE.md your-project/
Project Config
Set per-project defaults in .codemap/config.json so you don't need to pass --only/--exclude/--depth every time. Hooks also respect this config.
codemap config init # Auto-detect top extensions, write config
codemap config show # Display current config
All fields are optional. CLI flags always override config values.
Hook-specific policy fields are optional and bounded by safe defaults.
Skills
codemap ships with a skills framework ā markdown files that provide context-aware guidance to AI agents. Skills are automatically matched against your intent, the files you mention, and the languages in your project.
codemap skill list # Show all available skills
codemap skill show hub-safety # Print full skill content
codemap skill init # Create a custom skill template
Builtin Skills
Skill
Activates When
hub-safety
Editing hub files (3+ importers)
refactor
Restructuring, renaming, moving code
test-first
Writing tests, TDD workflows
explore
Understanding how code works
handoff
Switching between AI agents
Custom Skills
Drop a .md file in .codemap/skills/ with YAML frontmatter:
---
name: my-skill
description: When this skill should activate
keywords: ["relevant", "keywords"]
languages: ["go"]
---
# Instructions for the AI agent
Project-local skills override builtins. No Go code needed ā just markdown.
MCP Tools
Skills are also available via MCP: list_skills (metadata) and get_skill (full body).
Intelligent Routing
The prompt-submit hook performs intent classification on every prompt ā detecting whether you're refactoring, fixing a bug, exploring, testing, or building a feature. It then:
Surfaces risk analysis based on hub file involvement
Shows your working set (files edited this session)
Emits structured JSON markers (``) for tool consumption
Matches relevant skills and tells you which to pull (codemap skill show )
Warns about documentation drift when docs are stale
Context Protocol
A single command that gives any AI tool codemap's full intelligence:
codemap context # Full JSON envelope
codemap context --for "refactor auth" # With pre-classified intent + matched skills
codemap context --compact # Minimal for token-constrained agents
The output is a ContextEnvelope containing project metadata, intent classification, working set, matched skills, and handoff reference. Cursor, Windsurf, Codex, custom agents ā anything that can shell out gets code-aware intelligence.
HTTP API
For tools that prefer HTTP over CLI:
codemap serve --port 9471
Endpoint
Returns
GET /api/context?intent=refactor+auth
Full context envelope
GET /api/context?compact=true
Minimal envelope
GET /api/skills
All skills with metadata
GET /api/skills?language=go&category=refactor
Filtered skill matches
GET /api/skills/
Full skill body
GET /api/working-set
Current session's active files
GET /api/health
Server health check
Binds to 127.0.0.1 by default. Use --host 0.0.0.0 to expose to network.
Agent-Aware Handoff
When you switch between AI agents (Claude ā Codex ā Cursor), codemap tracks who worked and what they did: