TempoGraph
Code graph context engine that parses codebases with tree-sitter (170+ languages), builds structural dependency graphs, and provides 24 MCP tools for code intelligence. One prepare_context call gives your AI agent the right files for any task. Includes focus, blast radius, hotspots, dead code detection, and hybrid search.
README
TempoGraph
<!-- mcp-name: io.github.Elmoaid/tempograph -->
<a href="https://glama.ai/mcp/servers/Elmoaid/TempoGraph"> <img src="https://glama.ai/mcp/servers/Elmoaid/TempoGraph/badges/card.svg" alt="TempoGraph MCP server" width="400"> </a>
Your AI agent finds the right files. Every time.
TempoGraph builds a dependency graph of your codebase and gives your AI coding agent exactly the files it needs before making changes. One tool call. No guessing.
<p align="center"> <img src="docs/demo.gif" alt="TempoGraph demo" width="700"> </p>
The Problem
AI coding agents guess which files to look at. They search by filename, grep for keywords, and hope for the best. In large codebases, they miss critical dependencies, break things downstream, and waste tokens reading irrelevant code.
The Fix
pip install tempograph
Add to your MCP config (Claude Code, Cursor, Windsurf, or any MCP client):
{
"mcpServers": {
"tempograph": {
"command": "tempograph-server",
"args": []
}
}
}
Your agent calls prepare_context with a task description. TempoGraph returns the exact files that matter — based on real dependency analysis, not text matching.
Does It Work?
Tested on real PRs from django, flask, httpx, fastapi, requests, and pydantic. Task: predict which files need to change.
| Model | Without TempoGraph | With TempoGraph | Improvement |
|---|---|---|---|
| GPT-4o | 21.7% F1 | 27.5% F1 | +27% |
| GPT-4o-mini | 19.2% F1 | 24.5% F1 | +28% |
| qwen2.5-coder:32b | — | — | +18.6% (p=0.049) |
Consistent improvement across every model. 2-3x more tasks helped than hurt. No other code context tool publishes retrieval benchmarks with statistical significance.
How It Works
your repo ──→ tree-sitter parse ──→ symbols + edges ──→ SQLite graph
│
AI agent calls prepare_context ─────────┘
│
◄── KEY FILES + callers + callees + risk signals
- Parses your code with tree-sitter into a structural dependency graph
- Content-hashed and stored in SQLite — only changed files get re-parsed
- Warm queries in ~21ms. Branch switching doesn't trigger a rebuild
- Knows when NOT to inject context (adaptive gating avoids harming diffuse commits)
What Else Can It Do?
Beyond prepare_context, TempoGraph exposes 24 MCP tools for deeper analysis when your agent needs it:
| Tool | When to use it |
|---|---|
blast_radius |
"What breaks if I change this file?" |
focus |
"Show me everything related to auth" |
hotspots |
"Which files are riskiest to change?" |
dead_code |
"What can I safely delete?" |
diff_context |
"What's the impact of my current changes?" |
overview |
"Orient me in this new codebase" |
<details> <summary>All 24 tools</summary>
| Tool | What it does |
|---|---|
prepare_context |
One-shot context for a task — the primary tool |
overview |
Repository orientation: size, languages, entry points |
focus |
Connected subgraph around a symbol — callers, callees |
blast_radius |
What breaks if you change this file or symbol |
diff_context |
Impact analysis of changed files |
hotspots |
Ranked risk list — complexity x coupling x size |
dead_code |
Unreferenced symbols — cleanup candidates |
lookup |
"Where is X?", "What calls X?" |
dependencies |
Circular imports, dependency layers |
architecture |
Module-level dependency view |
symbols |
Full symbol inventory |
file_map |
File tree with top symbols per file |
search_semantic |
Hybrid keyword + vector + structural search |
cochange_context |
Files that historically change together |
suggest_next |
Predicts the next useful tool call |
run_kit |
Composable multi-tool workflows |
stats |
Token budget estimates |
get_patterns |
Codebase conventions and idioms |
report_feedback |
Log whether output was useful |
learn_recommendation |
Suggestions from feedback history |
index_repo |
Build or rebuild the graph |
watch_repo / unwatch_repo |
Live incremental updates |
embed_repo |
Generate vector embeddings |
</details>
CLI
# Orient in a new repo
tempograph ./my-project --mode overview
# What's connected to auth?
tempograph ./my-project --mode focus --query "authentication"
# What breaks if I touch db.ts?
tempograph ./my-project --mode blast --file src/lib/db.ts
# Find dead code to clean up
tempograph ./my-project --mode dead
Python API
from tempograph import build_graph
graph = build_graph("./my-project")
results = graph.search_symbols("handleLogin")
importers = graph.importers_of("src/lib/db.ts")
dead = graph.find_dead_code()
Languages
Python, TypeScript, JavaScript, Rust, Go, Java, C#, and Ruby get deep extraction (custom tree-sitter handlers). 170+ additional languages are supported via generic handler. pip install tempograph[full] for everything.
Support & Sponsorship
If TempoGraph saves you time, consider sponsoring the project. Sponsors get early access to new features.
Commercial Licensing
TempoGraph is AGPL-3.0 — free to use, modify, and distribute. If you use TempoGraph in a network service (SaaS, hosted IDE, AI coding platform), AGPL requires you to open-source your service code. If that doesn't work for you, commercial licenses are available.
Contact eali@needspec.com for commercial licensing terms.
License
AGPL-3.0 — free to use. Network service use requires source disclosure, or a commercial license.
Recommended Servers
playwright-mcp
A Model Context Protocol server that enables LLMs to interact with web pages through structured accessibility snapshots without requiring vision models or screenshots.
Magic Component Platform (MCP)
An AI-powered tool that generates modern UI components from natural language descriptions, integrating with popular IDEs to streamline UI development workflow.
Audiense Insights MCP Server
Enables interaction with Audiense Insights accounts via the Model Context Protocol, facilitating the extraction and analysis of marketing insights and audience data including demographics, behavior, and influencer engagement.
VeyraX MCP
Single MCP tool to connect all your favorite tools: Gmail, Calendar and 40 more.
graphlit-mcp-server
The Model Context Protocol (MCP) Server enables integration between MCP clients and the Graphlit service. Ingest anything from Slack to Gmail to podcast feeds, in addition to web crawling, into a Graphlit project - and then retrieve relevant contents from the MCP client.
Kagi MCP Server
An MCP server that integrates Kagi search capabilities with Claude AI, enabling Claude to perform real-time web searches when answering questions that require up-to-date information.
E2B
Using MCP to run code via e2b.
Neon Database
MCP server for interacting with Neon Management API and databases
Exa Search
A Model Context Protocol (MCP) server lets AI assistants like Claude use the Exa AI Search API for web searches. This setup allows AI models to get real-time web information in a safe and controlled way.
Qdrant Server
This repository is an example of how to create a MCP server for Qdrant, a vector search engine.