symgraph
Semantic code intelligence MCP server - build knowledge graphs of codebases to enhance AI-assisted code exploration.
symgraph is a rust implementation of https://github.com/colbymchenry/codegraph. Why? Ongoing exploration of compiled binary deployment of MCP Servers.
Features
- Multi-language support: Rust, TypeScript, JavaScript, Python, Go, Java, C, C++
- Symbol extraction: functions, classes, methods, structs, interfaces, traits, enums, constants
- Relationship tracking: calls, contains, imports, exports, extends, implements
- Impact analysis: trace the effect of changes through the codebase
- Advanced code intelligence:
- Find call paths between functions
- Detect unused/dead code
- Explore class hierarchies
- Locate all interface implementations
- Analyze change impact by line range
- Incremental indexing: only re-indexes changed files using content hashing
- Dual transport: stdio (default) and HTTP server modes
Installation
macOS & Linux
|
To also configure symgraph as an MCP server for Claude Code and Claude Desktop:
|
Install a specific version:
SYMGRAPH_VERSION=2026.3.30 |
Windows (PowerShell)
irm https://raw.githubusercontent.com/grahambrooks/symgraph/main/install.ps1 -OutFile install.ps1; .\install.ps1
To also configure symgraph as an MCP server for Claude Code and Claude Desktop:
irm https://raw.githubusercontent.com/grahambrooks/symgraph/main/install.ps1 -OutFile install.ps1; .\install.ps1 -Mcp
Install a specific version:
$env:SYMGRAPH_VERSION="2026.3.30"; irm https://raw.githubusercontent.com/grahambrooks/symgraph/main/install.ps1 -OutFile install.ps1; .\install.ps1
Both scripts install to ~/.symgraph/bin/ by default. Override with SYMGRAPH_INSTALL_DIR.
Claude Desktop (MCPB Bundle)
Download and install the MCPB bundle for your platform:
| Platform | Download |
|---|---|
| macOS (Apple Silicon) | symgraph-x.x.x-darwin-arm64.mcpb |
| macOS (Intel) | symgraph-x.x.x-darwin-x64.mcpb |
| Windows | symgraph-x.x.x-windows-x64.mcpb |
| Linux | symgraph-x.x.x-linux-x64.mcpb |
- Download the
.mcpbfile for your platform from Releases - Open Claude Desktop
- Drag and drop the
.mcpbfile onto Claude Desktop, or use File > Install MCP Server - Configure the project root when prompted
From Source
Usage
Index a Codebase
# Index current directory
# Index specific directory
Start MCP Server
# Start with stdio transport (for Claude Desktop)
# Start with HTTP transport
CLI Commands
MCP Tools
Core Tools
| Tool | Description |
|---|---|
symgraph-context |
Build focused code context for a specific task |
symgraph-search |
Quick symbol search by name |
symgraph-callers |
Find all callers of a symbol |
symgraph-callees |
Find all callees of a symbol |
symgraph-impact |
Analyze the impact radius of changes |
symgraph-node |
Get detailed symbol information |
symgraph-definition |
Get the full source code of a symbol with context |
symgraph-file |
List all symbols defined in a specific file |
symgraph-references |
Find all references to a symbol |
symgraph-reindex |
Trigger incremental reindexing of changed files |
symgraph-status |
Get index statistics |
Advanced Tools
| Tool | Description |
|---|---|
symgraph-hierarchy |
Get class/module hierarchy (parent/child relationships) |
symgraph-path |
Find call paths between two symbols |
symgraph-unused |
Find unused/dead code with no incoming references |
symgraph-implementations |
Find all implementations of an interface/trait |
symgraph-diff-impact |
Analyze the impact of changing a specific code region |
Example Use Cases
Find dead code for cleanup:
Use symgraph-unused to find all unused functions and classes
Understand function call chains:
Use symgraph-path with from="main" and to="database_query" to see how data flows
Assess change impact:
Use symgraph-diff-impact with file_path="src/auth.rs" start_line=45 end_line=60
to see what would be affected by changes in that region
Explore OOP hierarchies:
Use symgraph-hierarchy with symbol="BaseHandler" to see all parent/child relationships
Find all trait implementations:
Use symgraph-implementations with symbol="Iterator" to find all structs implementing Iterator
Project Setup
Add symgraph to your project in two steps: index your code, then configure your AI tool.
Step 1: Index Your Project
This creates a .symgraph/ directory containing the SQLite knowledge graph. Add .symgraph/ to your .gitignore.
Re-run symgraph index after significant code changes, or use the symgraph-reindex MCP tool to incrementally update from within your AI tool.
Step 2: Configure Your AI Tool
Claude Code
Register symgraph as an MCP server for your project:
Or add .mcp.json to your project root:
Optional: Add the /explore-code skill for guided code exploration:
Then use it in Claude Code:
/explore-code how does the authentication middleware work?
/explore-code what would break if I changed the User struct?
Claude Desktop
Via MCPB bundle (easiest):
- Download the
.mcpbfile for your platform from Releases - Drag and drop onto Claude Desktop, or use File > Install MCP Server
- Set the project root when prompted
Via manual config — add to claude_desktop_config.json:
GitHub Copilot
Per-repository — add .copilot/mcp.json to your project:
VS Code user settings — add to settings.json:
See GitHub Copilot MCP documentation for more details.
OpenAI Codex
Or add to ~/.codex/config.toml:
[]
= "symgraph"
= ["serve"]
See OpenAI Codex MCP documentation for more details.
HTTP Mode (Any MCP Client)
For shared or remote setups, run symgraph as an HTTP server:
Then point your MCP client at http://localhost:8080/mcp.
Environment Variables
| Variable | Description | Default |
|---|---|---|
SYMGRAPH_ROOT |
Project root directory | Current directory |
Architecture
symgraph/
├── src/
│ ├── main.rs # CLI entry point
│ ├── lib.rs # Core indexing logic
│ ├── types.rs # Type definitions (Node, Edge, etc.)
│ ├── db/ # SQLite database operations
│ ├── extraction/ # Tree-sitter code extraction
│ ├── graph/ # Graph traversal algorithms
│ ├── context/ # Context building for AI tasks
│ └── mcp/ # MCP protocol handlers
└── .symgraph/
└── index.db # SQLite database (per-project)
Core Concepts
- Node: A code symbol (function, class, method, etc.)
- Edge: A relationship between nodes (calls, contains, imports, etc.)
- Knowledge Graph: The complete set of nodes and edges for a codebase
Development
Prerequisites
- Rust 1.70+
- SQLite (bundled via rusqlite)
Building
Project Structure
| Module | Description |
|---|---|
types |
Core type definitions (NodeKind, EdgeKind, Language, etc.) |
db |
SQLite database schema and operations |
extraction |
Tree-sitter based code parsing and symbol extraction |
graph |
Graph algorithms (callers, callees, impact analysis) |
context |
Context builder for AI task assistance |
mcp |
MCP protocol server implementation |
License
MIT