Codevira MCP
Integrates with Git to bootstrap project roadmaps from commit history and uses post-commit hooks to automatically trigger reindexing of the codebase.
Provides Google Antigravity agents with access to a persistent context graph and roadmap, ensuring continuity and reducing token overhead in coding tasks.
Click on "Install Server".
Wait a few minutes for the server to deploy. Once ready, it will show a "Started" state.
In the chat, type
@followed by the MCP server name and your instructions, e.g., "@Codevira MCPShow me the current project roadmap and any pending changesets."
That's it! The server will respond to your query, and you can continue using it as needed.
Here is a step-by-step guide with screenshots.
Codevira MCP
Persistent adaptive memory for AI coding agents — learns from every session, works with every tool, remembers across every project.
Works with: Claude Code · Cursor · Windsurf · Google Antigravity · any MCP-compatible AI tool
The Problem
Every time you start a new AI coding session, your agent starts from zero.
It re-reads files it has seen before. It re-discovers patterns already established. It makes decisions that contradict last week's decisions. It has no idea what phase the project is in, what's already been tried, or why certain files are off-limits.
You end up spending thousands of tokens on re-discovery — every single session.
Codevira fixes this.
What It Does
Codevira is a Model Context Protocol server you drop into any project. It gives every AI agent that works on your codebase a shared, persistent memory:
Capability | What It Means |
Live auto-watch | Background file watcher auto-reindexes on every save — no manual trigger or git commit needed |
Context graph | Every source file has a node: role, rules, dependencies, stability, |
Semantic code search | Natural language search across your codebase — no grep, no file reading |
Roadmap | Phase-based tracker so agents always know what phase you're in and what comes next |
Changeset tracking | Multi-file changes tracked atomically; sessions resume cleanly after interruption |
Decision log | Every session writes a structured log; past decisions are searchable by any future agent |
Adaptive learning | Outcome tracking, confidence scoring, developer preference learning, and automatic rule inference — memory that gets smarter over time |
Cross-tool continuity | Single "catch me up" call for seamless switching between Cursor, Claude Code, Windsurf, and Antigravity |
Agent personas | Seven role definitions (Planner, Developer, Reviewer, Tester, Builder, Documenter, Orchestrator) with explicit protocols |
The result: ~1,400 tokens of overhead per session instead of 15,000+ tokens of re-discovery.
How It Works
Agent Session Lifecycle
flowchart TB
Start([Start Session])
subgraph Orientation
A[Check Open Changesets]
B[Get Project Roadmap]
C[Search Past Decisions]
D[Load Graph Context\nget_node • get_impact]
end
subgraph Execution
E[Plan Task]
F[Implement Code]
G[Run Tests / Validation]
end
subgraph Completion
H[Update Graph Metadata]
I[Write Session Log]
J[Complete Changeset]
end
Start --> A
A --> B
B --> C
C --> D
D --> E
E --> F
F --> G
G --> H
H --> I
I --> JCode Intelligence Model
flowchart TB
A[Source Code]
subgraph Structural Analysis
B[AST Parser]
C[Function / Class Extraction]
D[Dependency Analysis]
end
subgraph Knowledge Stores
E[(Semantic Index<br/>ChromaDB)]
F[(Context Graph<br/>SQLite DB)]
end
subgraph Runtime Access
G[MCP Query Layer<br/>search_codebase • get_node • get_impact]
end
H[AI Coding Agent<br/>Claude Code • Cursor]
A --> B
B --> C
C --> E
B --> D
D --> F
E --> G
F --> G
G --> HQuick Start
1. Install
pip install codevira-mcp2. Initialize in your project
cd your-project
codevira initThis single command:
Creates
.codevira/with config, graph, and log directoriesAdds
.codevira/to.gitignore(index is auto-regenerated, no need to commit)Prompts for project name, language, source directories (comma-separated), and file extensions
Builds the full code index using SHA-256 content hashing (only changed files are re-indexed)
Auto-generates graph stubs for all source files
Bootstraps
.codevira/roadmap.yamlfrom git historyInstalls a
post-commitgit hook for automatic reindexingPrints the MCP config block to paste into your AI tool
Live Auto-Watch: When the MCP server starts, it automatically launches a background file watcher. Every time you save a source file, the index is updated within 2 seconds — no manual commands needed. The
post-commithook andcodevira indexCLI remain available as alternatives.
3. Connect to your AI tool
Depending on your IDE and environment, codevira-mcp may not automatically be in your PATH.
You can use uvx (the easiest option) or provide the absolute path to your Python virtual environment.
Option A: Using uvx (Recommended for all IDEs without local install)
If you use uv, you can run the MCP server seamlessly without managing virtual environments per project.
Claude Code (.claude/settings.json), Cursor / Windsurf (Settings → MCP):
{
"mcpServers": {
"codevira": {
"command": "uvx",
"args": ["codevira-mcp", "--project-dir", "/path/to/your-project"]
}
}
}Option B: Using Local Venv (Recommended, works everywhere)
Point your AI tool directly to the Python runtime inside your .venv where codevira-mcp is installed.
Claude Code (.claude/settings.json) or Cursor / Windsurf (Settings → MCP):
{
"mcpServers": {
"codevira": {
"command": "/path/to/your-project/.venv/bin/python",
"args": ["-m", "mcp_server", "--project-dir", "/path/to/your-project"]
}
}
}Google Antigravity — add to ~/.gemini/antigravity/mcp_config.json:
{
"mcpServers": {
"codevira": {
"$typeName": "exa.cascade_plugins_pb.CascadePluginCommandTemplate",
"command": "/path/to/your-project/.venv/bin/python",
"args": ["-m", "mcp_server", "--project-dir", "/path/to/your-project"]
}
}
}⚠️ IMPORTANT: Using Global Clients (Antigravity / Claude Desktop) with Multiple Projects
Unlike Cursor, which spins up isolated MCP servers per project automatically, global clients like Antigravity share a single
mcp_config.jsonacross all your open projects.If you configure
codeviraonce forProject A, and then ask a question aboutProject B, the agent will read the graph and roadmap fromProject A.To fix this: You must register uniquely named servers for each project in your global config. The AI will dynamically choose the right tool prefix based on your conversation context:
{ "mcpServers": { "codevira-project-a": { "$typeName": "exa.cascade_plugins_pb.CascadePluginCommandTemplate", "command": "uvx", "args": ["codevira-mcp", "--project-dir", "/path/to/project-a"] }, "codevira-project-b": { "$typeName": "exa.cascade_plugins_pb.CascadePluginCommandTemplate", "command": "uvx", "args": ["codevira-mcp", "--project-dir", "/path/to/project-b"] } } }
4. Verify
Ask your agent to call get_roadmap() — it should return your current phase and next action.
Project structure after init
your-project/
├── src/ ← your code (indexed)
├── .codevira/ ← Codevira data directory (git-ignored)
│ ├── config.yaml ← project configuration
│ ├── roadmap.yaml ← project roadmap (auto-generated, human-enrichable)
│ ├── codeindex/ ← ChromaDB index (auto-regenerated)
│ └── graph/ ← context graph and session memory
│ ├── graph.db ← SQLite database for nodes, edges, logs, and decisions
│ └── changesets/ ← active multi-file change records
└── requirements.txt ← add: codevira-mcp>=1.0.0Roadmap lifecycle: The roadmap is auto-generated during init and updated by the agent through MCP tool calls. See docs/roadmap.md for the full lifecycle guide, manual editing steps, and troubleshooting.
Session Protocol
Every agent session follows a simple protocol. Set it up once in your agent's system prompt — then your agents handle the rest.
Session start (mandatory):
list_open_changesets() → resume any unfinished work first
get_roadmap() → current phase, next action
search_decisions("topic") → check what's already been decided
get_node("src/service.py") → read rules before touching a file
get_impact("src/service.py") → check blast radiusSession end (mandatory):
complete_changeset(id, decisions=[...])
update_node(file_path, changes)
update_next_action("what the next agent should do")
write_session_log(...)This loop keeps every session fast, focused, and resumable.
33 MCP Tools
Graph Tools
Tool | Description |
| Metadata, rules, connections, staleness for any file |
| BFS blast-radius — which files depend on this one (powered by real import edges) |
| Query nodes by attribute |
| Register a new file in the graph |
| Append rules, connections, key_functions |
| Auto-generate stubs for unregistered files |
| Re-embed specific files in ChromaDB |
| Export dependency graph as Mermaid or DOT diagram |
| Show changed nodes, stability flags, and blast radius between git refs |
Roadmap Tools
Tool | Description |
| Current phase, next action, open changesets |
| Complete history: all phases, decisions, deferred |
| Full details of any phase by number |
| Set what the next agent should do |
| Mark phase in_progress / blocked |
| Queue new upcoming work |
| Mark done, auto-advance to next |
| Move a phase to the deferred list |
Changeset Tools
Tool | Description |
| All in-progress changesets |
| Full detail: files done, files pending, blocker |
| Open a multi-file changeset |
| Close and record decisions |
| Mid-session checkpoint |
Search Tools
Tool | Description |
| Semantic search over source code |
| Search all past session decisions; optionally filter to a specific session |
| All sessions that touched a file |
| Write structured session record |
Adaptive Learning Tools (v1.4)
Tool | Description |
| Outcome-based reliability scores — how often past decisions were kept vs reverted |
| Learned developer style preferences from post-edit corrections |
| Auto-generated rules from observed patterns (test pairing, import hotspots, co-changes) |
| 0–100 intelligence score combining sessions, coverage, confidence, rules, preferences |
| Single "catch me up" call for cross-tool continuity (Cursor ↔ Claude Code ↔ Antigravity) |
Code Reader Tools
Tool | Description |
| All public symbols, signatures, line numbers |
| Full source of one function or class |
Playbook Tool
Tool | Description |
| Curated rules for a task: |
Agent Personas
Seven role definitions in agents/ tell each agent exactly what to do and when:
Agent | Invoked When | Key Responsibility |
| Every session start | Classify task, select pipeline |
| Large or ambiguous tasks | Decompose into ordered steps |
| All code changes | Write code within graph rules |
|
| Flag rule violations |
| After every code change | Run the test suite |
| After tests pass | Lint, type-check |
| End of every session | Update graph, roadmap, log |
Project Structure
.agents/
├── PROTOCOL.md # Session protocol — read this first
├── config.example.yaml # Config template
├── config.yaml # Your config (git-ignored)
├── roadmap.yaml # Phase tracker (auto-created, git-ignored)
├── mcp-server/
│ ├── server.py # MCP server entry point
│ └── tools/
│ ├── graph.py
│ ├── roadmap.py
│ ├── changesets.py
│ ├── search.py
│ ├── playbook.py
│ └── code_reader.py
├── indexer/
│ ├── index_codebase.py # Build/update ChromaDB index + background file watcher
│ ├── chunker.py # AST-based code chunker
│ ├── treesitter_parser.py # Multi-language AST parsing (16+ languages)
│ ├── sqlite_graph.py # SQLite graph database backend
│ └── graph_generator.py # Auto-generate graph stubs
├── requirements.txt # Python dependencies
├── agents/ # Role definitions
│ ├── orchestrator.md
│ ├── planner.md
│ ├── developer.md
│ ├── reviewer.md
│ ├── tester.md
│ ├── builder.md
│ └── documenter.md
├── rules/ # Engineering standards
│ ├── master_rule.md
│ ├── coding-standards.md
│ ├── testing-standards.md
│ └── ...13 more
├── graph/
│ ├── graph.db # SQLite Context Graph and Session Memory (git-ignored)
│ └── changesets/
├── hooks/
│ └── install-hooks.sh
└── codeindex/ # ChromaDB files (git-ignored)Language Support
Feature | Python | TypeScript | Go | Rust | 10+ Others (Java, C#, Ruby, PHP, C++) |
Semantic code search | ✅ | ✅ | ✅ | ✅ | ✅ |
Context graph + blast radius | ✅ | ✅ | ✅ | ✅ | ✅ |
Roadmap + changesets | ✅ | ✅ | ✅ | ✅ | ✅ |
Session logs + decision search | ✅ | ✅ | ✅ | ✅ | ✅ |
| ✅ | ✅ | ✅ | ✅ | |
Auto-generated graph stubs | ✅ | ✅ | ✅ | ✅ | |
AST-based chunking | ✅ | ✅ | ✅ | ✅ |
All session management, graph, roadmap, and search features work for any language. Code parsing and extraction (search, graph generation, signature reads) are powered by robust ast and Tree-Sitter integrations.
Requirements
Python 3.10+
ChromaDB
sentence-transformers
PyYAML
pip install -r .agents/requirements.txtBackground
Want to understand the full story behind why this was built, the design decisions, what didn't work, and how it compares to other tools in the ecosystem?
Read the full write-up: How We Cut AI Coding Agent Token Usage by 92%
Contributing
Contributions are welcome — this is an early-stage open source project and there's a lot of room to grow.
Read CONTRIBUTING.md for the full guide: forking, branch naming, commit format, and PR process.
Good first areas:
Graph visualization exports (Dot/Mermaid)
Additional playbook entries for common task types
IDE-specific setup guides
Bug reports and edge case fixes
Reporting a bug? → Open a bug report
Requesting a feature? → Open a feature request
Found a security issue? → Read SECURITY.md — please don't use public issues for vulnerabilities.
Please open an issue before submitting a large PR so we can discuss the approach first.
FAQ
Common questions about setup, usage, architecture, and troubleshooting — see FAQ.md.
Roadmap
See what's built, what's coming next, and what's being considered — see ROADMAP.md.
Want to influence priorities? Open a feature request or upvote existing ones.
Code of Conduct
This project follows the Contributor Covenant Code of Conduct. By participating, you agree to maintain a respectful and welcoming environment.
License
MIT — free to use, modify, and distribute.
This server cannot be installed
Resources
Unclaimed servers have limited discoverability.
Looking for Admin?
If you are the server author, to access and configure the admin panel.
Latest Blog Posts
MCP directory API
We provide all the information about MCP servers via our MCP API.
curl -X GET 'https://glama.ai/api/mcp/v1/servers/sachinshelke/codevira'
If you have feedback or need assistance with the MCP directory API, please join our Discord server