mcp-context-memory
A local semantic memory and code-indexer that uses AST parsing for structural understanding and persists architectural decisions to help AI assistants bypass context window limits.
README
Semantic Project Brain MCP Server
A high-end Python-based MCP (Model Context Protocol) server that provides a local, semantic memory and code-indexer. It uses tree-sitter for AST-based parsing of source code to understand class definitions, method signatures, and structures, rather than naive text chunking. It also acts as a "Long-Term Memory" to help AI assistants bypass context window limits by persisting architectural decisions across sessions.
The server uses ChromaDB for fast, local embedding storage, and stores its data in a .context_db folder within your current project directory.
Prerequisites
You need uv installed to run the server without managing virtual environments manually.
# Install uv if you haven't already
curl -LsSf https://astral.sh/uv/install.sh | sh
Available Tools
The server provides three MCP tools:
index_project(path: str = "."): Scans a directory, parses code semantically using AST (Python, Java, PHP, TS, JS, HTML), and indexes it. Defaults to current directory.search_context(query: str): A unified search over AST nodes and past project decisions.remember_decision(topic: str, context: str): Saves manual architectural notes or reasoning (e.g., "Why we chose framework X").
Usage with AI Assistants
You can use uvx (part of uv) to run this server directly from PyPI. This is the recommended way to use the Semantic Project Brain as it handles all dependencies automatically.
Claude Desktop Integration
To install and use this MCP server with Claude Desktop, add the following to your claude_desktop_config.json:
{
"mcpServers": {
"semantic-brain": {
"command": "uvx",
"args": ["mcp-context-memory"],
"alwaysAllow": [
"index_project",
"search_context",
"remember_decision"
]
}
}
}
Cursor Integration
In Cursor, go to Settings > Features > MCP and add a new MCP Server:
- Name: Semantic Brain
- Type:
command - Command:
uvx mcp-context-memory
Bootstrapping an Existing Project
To get the most out of the Semantic Project Brain in an existing codebase, follow these steps to seed it with relevant context:
-
Initial Semantic Indexing: Run the indexing tool to build the initial AST-based map of your code:
index_project(path=".")This allows the brain to immediately understand your classes, methods, and structural HTML. -
Capturing Core Architecture: Use
remember_decisionto document the foundational "Why" of the project. Good candidates for initial entries include:- Tech Stack Choice:
remember_decision(topic="Tech Stack", context="We use Symfony 7 with PHP 8.3 because...") - Database Schema:
remember_decision(topic="Data Model", context="The 'Orders' table is partitioned by year to handle high volume...") - Authentication Flow:
remember_decision(topic="Auth", context="JWT tokens are handled via LexikJWTAuthenticationBundle with a 1-hour TTL...")
- Tech Stack Choice:
-
Indexing Documentation: If you have existing
DOCS.mdorARCHITECTURE.mdfiles, you can copy-paste their key insights intoremember_decisionto make them semantically searchable alongside the code. -
Verification: Test the brain's "memory" by asking it a question through
search_context(query="How is authentication handled?"). If it returns your stored decisions, it's ready to assist.
Instructions for AI Agents (AGENTS.md)
Copy the following block and paste it into your project's .cursorrules, AGENTS.md, or GEMINI.md to instruct the LLM on how to use this server:
# Semantic Project Brain Usage Guidelines
You have access to the `semantic-brain` MCP server. Follow these rules rigorously:
1. **Re-indexing:**
- If you make significant structural changes (e.g., creating a new module, renaming classes, or refactoring), you MUST trigger `index_project(path=".")` when you finish to keep the AST index up to date.
- If you cannot find expected code in `search_context`, trigger an index update first.
2. **Understanding the Codebase:**
- Use `search_context(query="ClassName")` to understand class hierarchies, locate method definitions, and retrieve precise semantic chunks of code instead of grepping the entire workspace.
3. **Remembering Decisions:**
- Before completing a task that involved a notable architectural decision, tradeoff, or complex logic, you are OBLIGATED to call `remember_decision(topic="...", context="...")`.
- Store "Why" something was built a certain way, so you and other agents can retrieve it in future sessions using `search_context`.
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.