Skip to main content
Glama
DarkMatterProductions

mcp-project-context-server

MCP Project Context Server

License PyPI Python Version
Downloads Coverage Last Commit Issues


๐Ÿ“– About the Server

MCP Project Context Server provides a robust, production-ready Model Context Protocol (MCP) server implementation designed to give Large Language Models (LLMs) persistent, searchable access to your project's contextual information.

Core Capabilities

  • ๐Ÿ” Semantic Search Engine: Query your project documentation using natural language

  • ๐Ÿ“š Persistent Knowledge Base: Store and retrieve information from .context/ directory structure

  • ๐Ÿ—๏ธ Modular Architecture: Clean 4-layer design following SOLID principles

  • ๐ŸŽฏ ADR Integration: Full support for Architecture Decision Records with lifecycle management

  • ๐Ÿ“ Session Tracking: Record and retrieve session notes for future reference

  • ๐Ÿ’พ Vector Store Backend: ChromaDB for fast, persistent, embedded vector storage

  • ๐Ÿ”„ Easy Reindexing: Rebuild your knowledge base with a single command

Key Features

  • โœ… Model-Agnostic: Works with any LLM model via Ollama (Other providers coming)

  • โœ… Configuration-Free: Environment variable-based setup, no hardcoded paths

  • โœ… Cross-Platform: POSIX path normalization ensures consistency across OS

  • โœ… Async-First: All operations use async/await for performance and scalability

  • โœ… Error-Resilient: Graceful error handling with informative messaging


Related MCP server: kontexta

๐Ÿš€ Getting Started

Prerequisites

Before installing, ensure you have:

  • Python 3.11+ installed

  • Ollama running with an embedding model (e.g., nomic-embed-text)

  • At least 2GB RAM available

  • 4.5GB disk space for ChromaDB (minimum)

Installation

pip install mcp-project-context-server

Option 2: From Source

git clone https://github.com/your-org/mcp-project-context-server.git
cd mcp-project-context-server
pip install -e ".[dev]"  # Install with development dependencies

Configuration

Set the following environment variables:

# Ollama Configuration (Required)
export OLLAMA_HOST="http://localhost:11434"
export EMBED_MODEL="nomic-embed-text"

# ChromaDB Configuration (Optional)
export CHROMA_DIR="$HOME/.mcp-data/chroma"

# Runtime Configuration
export EMBED_CONCURRENCY="4"           # Max concurrent embeddings
export PROJECT_PATH="/path/to/project" # Optional, defaults to CWD

๐Ÿ–ฅ๏ธ Client Setup

Universal MCP Client Integration

The server follows the standard MCP protocol, making it compatible with any MCP client that supports stdio transport.

Supported MCP Clients

Client

Status

Setup Instructions

Claude Desktop

โœ… Tested

See Claude Desktop Setup

Claude Code

โœ… Tested

See Claude Code Setup

Cursor

โœ… Tested

See Cursor Setup

Continue

โœ… Tested

See Continue Setup

Windsurf

โœ… Compatible

See Windsurf Setup

VS Code Copilot

โœ… Compatible

See VS Code Copilot Setup

Claude Desktop Setup

  1. Install the server (see Installation)

  2. Locate the config file for your OS:

    OS

    Config File Location

    Windows

    %APPDATA%\Claude\claude_desktop_config.json

    macOS

    ~/Library/Application Support/Claude/claude_desktop_config.json

    Linux

    ~/.config/Claude/claude_desktop_config.json

  3. Configure MCP settings in claude_desktop_config.json:

    Windows:

    {
      "mcpServers": {
        "project-context": {
          "command": "python",
          "args": ["-m", "mcp_project_context_server"],
          "env": {
            "OLLAMA_HOST": "http://localhost:11434",
            "EMBED_MODEL": "nomic-embed-text",
            "CHROMA_DIR": "%USERPROFILE%\\.mcp-data\\chroma"
          }
        }
      }
    }

    macOS / Linux:

    {
      "mcpServers": {
        "project-context": {
          "command": "python",
          "args": ["-m", "mcp_project_context_server"],
          "env": {
            "OLLAMA_HOST": "http://localhost:11434",
            "EMBED_MODEL": "nomic-embed-text",
            "CHROMA_DIR": "~/.mcp-data/chroma"
          }
        }
      }
    }
  4. Verify the server is connected:

    claude mcp list
  5. Use in Claude Code by referencing the tools directly in your session, or asking questions about your project context.

    • Try asking: "What was the decision in ADR-00001?"

    • Verify semantic search works with project-specific queries

Claude Code Setup

  1. Install the server (see Installation)

  2. Add the MCP server using one of two methods:

    Option A โ€” CLI (Recommended):

    claude mcp add project-context python -- -m mcp_project_context_server

    To include environment variables:

    claude mcp add project-context \
      -e OLLAMA_HOST=http://localhost:11434 \
      -e EMBED_MODEL=nomic-embed-text \
      -e CHROMA_DIR=~/.mcp-data/chroma \
      -- python -m mcp_project_context_server

    Option B โ€” Config file:

    Claude Code supports both user-level and project-level configuration:

    Scope

    Location

    User (global)

    ~/.claude.json

    Project

    .claude/settings.json (in project root)

    Add the following to the mcpServers key:

    {
      "mcpServers": {
        "project-context": {
          "command": "python",
          "args": ["-m", "mcp_project_context_server"],
          "env": {
            "OLLAMA_HOST": "http://localhost:11434",
            "EMBED_MODEL": "nomic-embed-text",
            "CHROMA_DIR": "~/.mcp-data/chroma"
          }
        }
      }
    }
  3. Verify the server is connected:

  4. Use in Claude Code by referencing the tools directly in your session, or asking questions about your project context.

Cursor Setup

  1. Install the MCP server (see Installation)

  2. Choose a config scope โ€” Cursor supports both global and project-level MCP configuration:

    Scope

    Windows

    macOS / Linux

    Global

    %USERPROFILE%\.cursor\mcp.json

    ~/.cursor/mcp.json

    Project

    .cursor\mcp.json (in project root)

    .cursor/mcp.json (in project root)

  3. Configure in mcp.json:

    {
      "mcpServers": {
        "project-context": {
          "command": "python",
          "args": [
            "-m",
            "mcp_project_context_server"
          ],
          "env": {
            "OLLAMA_HOST": "http://localhost:11434",
            "EMBED_MODEL": "nomic-embed-text",
            "CHROMA_DIR": "~/.mcp-data/chroma"
          }
        }
      }
    }
  4. Test functionality:

    • Use @project-context in chat

    • Ask context-aware questions about your project

    • Access ADRs and documentation via natural language

Continue Setup

  1. Install the Continue VS Code or JetBrains extension

  2. Locate the config file for your OS:

    OS

    Config File Location

    Windows

    %USERPROFILE%\.continue\config.yaml

    macOS / Linux

    ~/.continue/config.yaml

    Continue also supports config.json for legacy setups, but config.yaml is the current default.

  3. Add to config.yaml:

    mcpServers:
      - name: project-context
        command: python
        args:
          - "-m"
          - mcp_project_context_server
        env:
          OLLAMA_HOST: "http://localhost:11434"
          EMBED_MODEL: "nomic-embed-text"
          CHROMA_DIR: "~/.mcp-data/chroma"

    Or if using config.json:

    {
      "mcpServers": [
        {
          "name": "project-context",
          "command": "python",
          "args": ["-m", "mcp_project_context_server"],
          "env": {
            "OLLAMA_HOST": "http://localhost:11434",
            "EMBED_MODEL": "nomic-embed-text",
            "CHROMA_DIR": "~/.mcp-data/chroma"
          }
        }
      ]
    }
  4. Usage:

    • Trigger context queries in the chat panel

    • Access project documentation mid-conversation

    • Maintain context across multi-turn conversations

Windsurf Setup

  1. Install MCP server via terminal or package manager

  2. Locate the MCP config file for your OS:

    OS

    Config File Location

    Windows

    %USERPROFILE%\.codeium\windsurf\mcp_config.json

    macOS / Linux

    ~/.codeium/windsurf/mcp_config.json

  3. Configure in mcp_config.json (create if not exists):

    {
      "mcpServers": {
        "project-context": {
          "command": "python",
          "args": ["-m", "mcp_project_context_server"],
          "env": {
            "OLLAMA_HOST": "http://localhost:11434",
            "EMBED_MODEL": "nomic-embed-text",
            "CHROMA_DIR": "~/.mcp-data/chroma"
          }
        }
      }
    }
  4. Restart Windsurf and verify the MCP server appears under Settings โ†’ MCP Servers.

VS Code Copilot Setup

MCP support is built into VS Code via GitHub Copilot (no separate extension required). Requires VS Code 1.99+ with the Copilot extension.

  1. Install the server (see Installation)

  2. Choose a config scope:

    Option A โ€” Workspace (.vscode/mcp.json):

    Create .vscode/mcp.json in your project root (works identically on all OSes):

    {
      "servers": {
        "project-context": {
          "type": "stdio",
          "command": "python",
          "args": ["-m", "mcp_project_context_server"],
          "env": {
            "OLLAMA_HOST": "http://localhost:11434",
            "EMBED_MODEL": "nomic-embed-text",
            "CHROMA_DIR": "${env:USERPROFILE}/.mcp-data/chroma"
          }
        }
      }
    }

    Note: Use ${env:USERPROFILE}/.mcp-data/chroma on Windows or ~/.mcp-data/chroma on macOS/Linux for CHROMA_DIR.

    Option B โ€” User settings (settings.json):

    Open VS Code settings (Ctrl + , / Cmd + ,) and add to settings.json:

    {
      "mcp": {
        "servers": {
          "project-context": {
            "type": "stdio",
            "command": "python",
            "args": ["-m", "mcp_project_context_server"],
            "env": {
              "OLLAMA_HOST": "http://localhost:11434",
              "EMBED_MODEL": "nomic-embed-text",
              "CHROMA_DIR": "~/.mcp-data/chroma"
            }
          }
        }
      }
    }
  3. Use in Copilot Chat by switching to Agent mode and the MCP tools will be available automatically.

IDE-Specific Best Practices

PyCharm

While PyCharm doesn't natively support MCP, you can:

  1. Use the CLI mode:

    Windows (PowerShell):

    project-context-server search "your query"

    macOS / Linux:

    project-context-server search "your query"
  2. Or use the Python interpreter:

    from mcp_project_context_server.server import run
    run()  # Start server, then connect via MCP client

Vim/Neovim (with mcp.nvim)

-- In your Neovim config (works on Windows, macOS, and Linux)
require('mcp').connect({
  name = 'project-context',
  command = 'python',
  args = {'-m', 'mcp_project_context_server'},
  env = {
    OLLAMA_HOST = 'http://localhost:11434'
  }
})

Sublime Text (with Sublime MCP)

Similar to VS Code, configure in Sublime's MCP settings file with the same JSON structure.


๐Ÿ› ๏ธ Usage Examples

Ask natural language questions about your project:

# Example: Ask about your project's architecture
# Expected: Retrieves relevant ADRs and documentation

search_project_context(
    query="How do we handle data persistence?",
    n_results=5
)

Load Full Context

Get all documentation at once:

load_project_context()
# Returns concatenated content of:
# - project.md
# - All ADRs
# - Latest session file

Save Session Notes

save_session_summary(
    summary="Investigated chunking strategy alternatives, decided on fixed-size for now"
)
# Creates: .context/sessions/YYYY-MM-DD.md

Rebuild Index

index_project_context()
# Drops existing collection and rebuilds from .context/

๐Ÿ“‚ Project Structure

mcp-project-context-server/
โ”œโ”€โ”€ src/mcp_project_context_server/
โ”‚   โ”œโ”€โ”€ __init__.py
โ”‚   โ”œโ”€โ”€ __main__.py
โ”‚   โ”œโ”€โ”€ server.py              # MCP server entry point
โ”‚   โ”œโ”€โ”€ tools/
โ”‚   โ”‚   โ”œโ”€โ”€ load_context.py    # load_project_context tool
โ”‚   โ”‚   โ”œโ”€โ”€ search_context.py  # search_project_context tool
โ”‚   โ”‚   โ”œโ”€โ”€ save_session.py    # save_session_summary tool
โ”‚   โ”‚   โ””โ”€โ”€ index_context.py   # index_project_context tool
โ”‚   โ”œโ”€โ”€ integrations/
โ”‚   โ”‚   โ”œโ”€โ”€ chroma/
โ”‚   โ”‚   โ”‚   โ””โ”€โ”€ client.py      # ChromaDB client
โ”‚   โ”‚   โ””โ”€โ”€ ollama/
โ”‚   โ”‚       โ””โ”€โ”€ client.py      # Ollama client
โ”‚   โ”œโ”€โ”€ indexing/
โ”‚   โ”‚   โ”œโ”€โ”€ chroma/
โ”‚   โ”‚   โ”‚   โ””โ”€โ”€ indexer.py     # Chunking & embedding pipeline
โ”‚   โ”‚   โ””โ”€โ”€ ollama/
โ”‚   โ”‚       โ””โ”€โ”€ embedder.py    # Embedding wrappers
โ”‚   โ””โ”€โ”€ helpers/
โ”‚       โ””โ”€โ”€ context.py         # Utility functions
โ”œโ”€โ”€ .context/                   # Project context directory
โ”‚   โ”œโ”€โ”€ project.md             # Project overview
โ”‚   โ”œโ”€โ”€ sessions/              # Session notes
โ”‚   โ””โ”€โ”€ decisions/             # ADRs
โ”œโ”€โ”€ scripts/
โ”‚   โ””โ”€โ”€ test_client.py         # Integration smoke test
โ”œโ”€โ”€ README.md
โ”œโ”€โ”€ pyproject.toml
โ””โ”€โ”€ LICENSE

๐Ÿงช Testing

Manual Integration Test

python scripts/test_client.py

Development Workflow

# Install  

# Install testing dependencies
python -m pip install testsuite
# Run pytest
pytest tests/

# Test coverage
pytest --cov=src/mcp_project_context_server

# Lint and format
ruff check src/
black src/

๐ŸŒ Environment Variables Reference

Variable

Default

Description

OLLAMA_HOST

http://localhost:11434

Ollama server URL

EMBED_MODEL

nomic-embed-text

Embedding model name

CHROMA_DIR

~/.mcp-data/chroma

ChromaDB persistence directory

EMBED_CONCURRENCY

4

Max concurrent embedding requests

PROJECT_PATH

CWD

Path to project root (optional)

MCP_TOOL_PREFIX

project-context-

Prefix for tool names


๐Ÿ”ฎ Roadmap & Contributions

Planned Features

  • Auto-reindex: Watchdog-based file monitoring for automatic reindexing

  • Codebase Indexing: Repomix integration for source code analysis

  • Enhanced ADR Tools: First-class MCP tools for ADR lifecycle

  • Repository Bootstrapping: Automatic .context/ generation

  • Batch Operations: Bulk ADR updates and session imports

Community Contributions

Contributions are welcome! See CONTRIBUTING.md for detailed contribution guidelines.

  1. Fork the repository

  2. Create a feature branch

  3. Commit your changes

  4. Push to the branch

  5. Open a Pull Request


๐Ÿ“ License

This project is licensed under the GNU AFFERO GENERAL PUBLIC LICENSE Version 3 - see the LICENSE file for details.


๐Ÿ™ Acknowledgments

  • MCP Team: For the Model Context Protocol

  • ChromaDB: For the vector store implementation

  • Ollama: For the embedding model hosting


Built with โค๏ธ for better LLM project understanding

Install Server
A
license - permissive license
A
quality
B
maintenance

Maintenance

โ€“Maintainers
โ€“Response time
0dRelease cycle
5Releases (12mo)
Commit activity

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/DarkMatterProductions/mcp-project-context-server'

If you have feedback or need assistance with the MCP directory API, please join our Discord server