Skip to main content

A code intelligence graph that gives AI coding agents deep, token-efficient understanding of your codebase.

Project description

Code Atlas

A code intelligence graph that gives AI coding agents deep, token-efficient understanding of your codebase — structure, docs, and dependencies in one searchable graph.

Map your codebase. Search it three ways. Feed it to agents.

License Python Ruff MCP


The Problem

Every time an AI agent touches your codebase, it burns tokens just figuring out where things are. Grep for a function name. Read five files to understand the call chain. Search docs for context. Repeat — across every task, every session. On a large project, agents can spend 30–50% of their context window on orientation before they write a single line of code.

Many tools solve one piece of this: semantic search, or graph traversal, or keyword lookup. But a developer doesn't understand a codebase through one lens — they build a mental model that connects structure, meaning, and names simultaneously. Agents need the same thing.

Code Atlas is that mental model, externalized as a graph.

What Is This?

Code Atlas builds a graph database of your entire codebase — code structure, documentation, and dependencies — and exposes it via MCP tools that AI coding agents can use to understand, navigate, and reason about your code.

Three search types, one system:

  • Graph traversal — follow relationships: who calls this function? What does this class inherit from? What services depend on this library?
  • Semantic search — find code by meaning: "authentication middleware" finds relevant code even if it's named verify_token_chain
  • BM25 keyword search — exact matches: find that specific error message, config key, or function name

All powered by Memgraph as a single backend.

Key Features

  • Monorepo-native — auto-detects sub-projects, tracks cross-project dependencies, scoped queries
  • Documentation as first-class — indexes markdown docs, ADRs, and READMEs with links to the code they describe
  • AST-level incremental indexing — only re-indexes the entities that actually changed, not entire files
  • Pattern detection — pluggable detectors for decorator routing, event handlers, DI, test→code mappings, and more
  • Library awareness — lightweight stubs for external dependencies, full indexing for internal libraries
  • Self-hosted — runs locally with Docker. No data leaves your machine
  • No additional API costs — agent-first design means all intelligence runs through your existing subscription; local embeddings via TEI, no extra API keys
  • Token-efficient — budget-aware context assembly that prioritizes what matters most
  • Pluggable AI — TEI for embeddings, LiteLLM for LLM calls, or bring your own
  • MCP server — works with Claude Code, Cursor, Windsurf, or any MCP-compatible client

How Does This Compare?

Several excellent tools exist in this space — graph-based analyzers, semantic search engines, wiki generators, and IDE-integrated indexers. Code Atlas builds on their ideas while addressing a gap: no single tool combines graph traversal, semantic search, and BM25 keyword search with documentation intelligence and MCP exposure.

For a detailed comparison covering DeepWiki, Cursor, Sourcegraph Cody, Kit, code-graph-rag, codegraph-rust, and more, see docs/landscape.md.

MCP Tools

15 tools exposed via the Model Context Protocol, designed to minimize context window overhead.

Tool What it does Search Full Latency (avg / p95)
Search
hybrid_search Primary tool — fuses graph + BM25 + vector via RRF. Auto-adjusts weights by query shape. ~117 ~497 548 / 677 ms
text_search BM25 keyword search. Quoted phrases, wildcards, field-specific queries. ~90 ~275 34 / 36 ms
vector_search Semantic similarity via embeddings. Finds code by meaning, not name. ~67 ~297 102 / 125 ms
get_node Find entities by name. Cascade: exact (uid + name) → partial (suffix > prefix > contains). ~100 ~254 7 / 8 ms
Navigation
get_context Expand a node's neighborhood: parent, siblings, callers, callees, docs. ~64 ~273 34 / 36 ms
cypher_query Run read-only Cypher against the graph. Auto-limited, write-protected. ~59 ~168 3 / 3 ms
Analysis
analyze_repo Structure, centrality, dependencies, pattern, or quality analysis. ~41 ~266 22 / 23 ms
generate_diagram Mermaid diagrams: packages, imports, inheritance, module detail. ~37 ~254 3 / 3 ms
Guidance
get_usage_guide Quick-start or topic-specific guidance for the agent. ~35 ~106 < 1 / < 1 ms
plan_search_strategy Recommends which search tool + params for a question. ~40 ~97 < 1 / < 1 ms
validate_cypher Catches Cypher errors before execution. ~58 ~116 1 / 2 ms
schema_info Full graph schema: labels, relationships, Cypher examples. ~75 ~96 < 1 / < 1 ms
Status
index_status Projects, entity counts, schema version, index health. ~72 ~93 22 / 23 ms
list_projects Monorepo project list with dependency relationships. ~56 ~77 12 / 13 ms
health_check Infrastructure diagnostics: Memgraph, TEI, Valkey, schema. ~55 ~76 218 / 264 ms

Token counts measured from MCP JSON tool definitions (tiktoken cl100k_base). Search = name + description (~966 total); Full = name + description + parameter schema with field descriptions, enums, and constraints (~2,945 total). All parameters are self-documented — agents can one-shot any tool without calling get_usage_guide first. Latency measured with local TEI embeddings on the code-atlas repo (~1,400 entities), 5 iterations, warm embedding cache. See scripts/profile_query.py.

Quick Start

Prerequisites

  • Docker and Docker Compose
  • uv (Python package manager)

1. Start infrastructure

Download the compose file and start Memgraph + Valkey:

curl -O https://raw.githubusercontent.com/SerPeter/code-atlas/main/docker-compose.yml
docker compose up -d

Optional — add local embeddings (no API keys needed):

docker compose --profile tei up -d

2. Index your project

uvx --from code-atlas-mcp atlas index /path/to/your/project
uvx --from code-atlas-mcp atlas status

3. Connect to your AI agent

Claude Code:

claude mcp add code-atlas -- uvx --from code-atlas-mcp atlas mcp

Cursor / other MCP clients — add to your MCP config:

{
  "mcpServers": {
    "code-atlas": {
      "command": "uvx",
      "args": ["--from", "code-atlas-mcp", "atlas", "mcp"]
    }
  }
}

See CLI usage guide for more commands and options.

Development

If you want to contribute or run from source:

git clone https://github.com/SerPeter/code-atlas.git
cd code-atlas
uv sync --group dev
uv run pre-commit install

Performance

Metric Value
Full index (107 files) 55s (local TEI)
Parse-only throughput 600–700 files/sec
get_node / text_search 7 ms / 34 ms
vector_search 102 ms
Concurrent QPS 238 (zero errors)

Full index includes parsing, graph upserts, and embedding via local TEI (8 concurrent workers). Parse-only is raw tree-sitter CPU time without I/O. Query latencies are averages from scripts/profile_query.py. Full benchmark tables: docs/benchmarks.md

Documentation

Supporting Code Atlas

I built Code Atlas because my AI agents kept burning half their context just figuring out where things are in larger codebases. Nothing combined the search types I needed in one place, so I built it and open-sourced it so you can benefit as well.

If Code Atlas saves you time, tokens, or makes your agents noticeably better — consider sponsoring the project.

Sponsor

License

Apache License 2.0

Project details


Download files

Download the file for your platform. If you're not sure which to choose, learn more about installing packages.

Source Distribution

code_atlas_mcp-0.3.1.tar.gz (427.1 kB view details)

Uploaded Source

Built Distribution

If you're not sure about the file name format, learn more about wheel file names.

code_atlas_mcp-0.3.1-py3-none-any.whl (190.9 kB view details)

Uploaded Python 3

File details

Details for the file code_atlas_mcp-0.3.1.tar.gz.

File metadata

  • Download URL: code_atlas_mcp-0.3.1.tar.gz
  • Upload date:
  • Size: 427.1 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? Yes
  • Uploaded via: twine/6.1.0 CPython/3.13.7

File hashes

Hashes for code_atlas_mcp-0.3.1.tar.gz
Algorithm Hash digest
SHA256 cbc91f4656e5b9ecae0a24448f62bc4760b69be53a00195e7b5c91dbbc350367
MD5 8a5dc0c5b7db077409aa5243630734d5
BLAKE2b-256 68e8deec2ecd61dce5bb02a88b13f335069fb3043626d8ef530d5217df0ad9c8

See more details on using hashes here.

Provenance

The following attestation bundles were made for code_atlas_mcp-0.3.1.tar.gz:

Publisher: release.yml on SerPeter/code-atlas

Attestations: Values shown here reflect the state when the release was signed and may no longer be current.

File details

Details for the file code_atlas_mcp-0.3.1-py3-none-any.whl.

File metadata

  • Download URL: code_atlas_mcp-0.3.1-py3-none-any.whl
  • Upload date:
  • Size: 190.9 kB
  • Tags: Python 3
  • Uploaded using Trusted Publishing? Yes
  • Uploaded via: twine/6.1.0 CPython/3.13.7

File hashes

Hashes for code_atlas_mcp-0.3.1-py3-none-any.whl
Algorithm Hash digest
SHA256 62560858f39838e7d905bb5bae4e6b5c5944ea98ed9bcc0ce4b113d9b12c1050
MD5 6970fb054711a82f902a411771dac05e
BLAKE2b-256 33dd4e935dbf955ffa87b5315696fe1e114d641d178b9e5343ab39c19e539336

See more details on using hashes here.

Provenance

The following attestation bundles were made for code_atlas_mcp-0.3.1-py3-none-any.whl:

Publisher: release.yml on SerPeter/code-atlas

Attestations: Values shown here reflect the state when the release was signed and may no longer be current.

Supported by

AWS Cloud computing and Security Sponsor Datadog Monitoring Depot Continuous Integration Fastly CDN Google Download Analytics Pingdom Monitoring Sentry Error logging StatusPage Status page