CtrlK
BlogDocsLog inGet started
Tessl Logo

code-graph

AST-based code graph for fast symbol lookup, dependency analysis, and blast radius via codebase-memory-mcp MCP server

56

Quality

47%

Does it follow best practices?

Impact

Pending

No eval scenarios have been run

SecuritybySnyk

Passed

No known issues

Optimize this skill with Tessl

npx tessl skill review --optimize ./skills/code-graph/SKILL.md
SKILL.md
Quality
Evals
Security

Code Graph Skill

Load with: base.md

Purpose: Use the code graph (codebase-memory-mcp) for sub-millisecond symbol lookup, function search, dependency analysis, and blast radius detection. This replaces brute-force grep and file reading for code navigation.


Core Principle

Graph first, file second. Before reading files or grepping, query the code graph. Only read full files when you need to modify them or need context beyond what the graph provides.

Consider graph when planning. When planning any change — feature, refactor, bug fix — start by querying the graph to understand scope, dependencies, and blast radius. This applies to thinking and planning phases, not just implementation. Grep is still the right tool for searching string literals, log messages, config values, and content that lives outside code structure.

┌────────────────────────────────────────────────────────────────┐
│  GRAPH FIRST, FILE SECOND                                      │
│  ─────────────────────────────────────────────────────────────│
│  The code graph indexes your entire codebase as a persistent   │
│  knowledge graph. Claude queries it via MCP for instant         │
│  symbol lookup, dependency chains, and blast radius — instead   │
│  of reading hundreds of files.                                 │
│                                                                │
│  14 MCP tools │ 64 languages │ sub-ms queries │ zero deps      │
│  ~99% fewer tokens for navigation vs brute-force file reads    │
├────────────────────────────────────────────────────────────────┤
│  AUTO-UPDATED                                                  │
│  ─────────────────────────────────────────────────────────────│
│  File watcher keeps graph in sync. Post-commit hook ensures    │
│  freshness. No manual rebuild needed.                          │
└────────────────────────────────────────────────────────────────┘

When to Use Graph vs Direct Read

TaskUse Graph ToolUse Direct Read?
Find function/class definitionsearch_graphNo
Get function signature + docsget_code_snippetNo
Find all callers of a functiontrace_call_pathNo
Trace dependency chainquery_graphNo
Determine blast radius of changedetect_changesNo
Understand project architectureget_architectureNo
Search for code patternssearch_codeNo
Read full implementation to modifysearch_graph to locate, then Read fileYes
Understand business logic contextget_code_snippet for overview, then ReadYes

Rule: If a graph tool can answer the question, use it. Only open files when you need the full source to make edits.


Available MCP Tools

Indexing & Status

ToolPurposeWhen to Use
index_repositoryBuild/rebuild graph for a projectFirst setup, or after major restructure
index_statusCheck if graph is currentBefore querying, if unsure of freshness
list_projectsList all indexed projectsMulti-project navigation

Querying & Navigation

ToolPurposeWhen to Use
search_graphFind symbols by name (fuzzy)"Find auth-related functions"
search_codeText search across indexed codebase"Find TODO comments", pattern matching
get_code_snippetGet source code for a specific symbolNeed signature, docstring, implementation
get_graph_schemaUnderstand graph structure and relationshipsExploring what data is available
query_graphRun structured graph queriesComplex dependency/relationship queries

Analysis

ToolPurposeWhen to Use
trace_call_pathTrace caller/callee chains"Who calls sendEmail?", "What does init() trigger?"
detect_changesIdentify changed files and blast radiusBefore/after code changes, PR review
get_architectureHigh-level module/package structureOnboarding, understanding project layout

Management

ToolPurposeWhen to Use
delete_projectRemove a project from the graphCleanup, project restructure
manage_adrArchitecture decision recordsDocument architectural decisions
ingest_tracesImport runtime tracesPerformance analysis, dead code detection

Workflow: Before Any Code Change

0. PLAN       → get_architecture + search_graph to understand scope before planning
1. LOCATE     → search_graph to find the symbol
2. UNDERSTAND → get_code_snippet for context
3. BLAST      → detect_changes to assess impact
4. TRACE      → trace_call_path to find all affected callers
5. CHANGE     → Read file, make edit
6. VERIFY     → detect_changes again to confirm scope

Step 0 applies to planning, not just coding. When the user asks you to plan a feature, refactor, or fix — query the graph first to understand what exists, what depends on what, and what the scope looks like. This prevents plans based on wrong assumptions about the codebase.

Never skip step 3. Blast radius analysis prevents unexpected breakage from changes to shared code.


Graph Data & Freshness

The graph stays fresh automatically through 3 layers — no manual rebuild needed:

LayerTriggerWhat Happens
File watcherEvery file savecodebase-memory-mcp detects changes and re-indexes affected files in real-time
Auto-indexSession startauto_index: true ensures graph is current when Claude Code starts
Post-commit hookEvery git commitTouches .code-graph/.needs-update marker — file watcher picks it up (~10ms, non-blocking)

You do NOT need to manually re-index unless you do a major restructure (rename entire directories, switch branches with massive diffs). In that case: index_repository once, then the 3 layers keep it fresh.

  • Storage: .code-graph/ directory (auto-created, gitignored)
  • MCP config: .mcp.json at project root (committed, shared with team)

MCP Configuration

The code graph MCP server is configured in .mcp.json at project root:

{
  "mcpServers": {
    "codebase-memory": {
      "command": "codebase-memory-mcp",
      "args": []
    }
  }
}

Installation: ~/.claude/install-graph-tools.sh


Decision Framework

Need to find a symbol/function?
  → search_graph (sub-ms, structured result)
  → NOT: grep -r "functionName" (slow, unstructured)

Need to understand dependencies?
  → query_graph or trace_call_path (complete, traversable)
  → NOT: manually reading import statements

Need to assess change impact?
  → detect_changes (comprehensive, instant)
  → NOT: searching for usages manually across files

Need to understand architecture?
  → get_architecture (high-level overview)
  → NOT: reading every directory listing

Need to read/modify code?
  → search_graph to locate, then Read the specific file
  → NOT: reading entire directories hoping to find it

Anti-Patterns

Anti-PatternDo This Instead
Grepping for function namessearch_graph with the function name
Reading entire files to find a signatureget_code_snippet for the specific symbol
Manually tracing import chainstrace_call_path or query_graph
Making changes without checking impactdetect_changes before every edit to shared code
Reading all files in a directoryget_architecture for structure, search_graph for specifics
Ignoring graph staleness warningsCheck index_status, re-index if needed
Re-indexing on every queryTrust the file watcher; only manual re-index after major restructure
Repository
alinaqi/claude-bootstrap
Last updated
Created

Is this your skill?

If you maintain this skill, you can claim it as your own. Once claimed, you can manage eval scenarios, bundle related skills, attach documentation or rules, and ensure cross-agent compatibility.