Code Index MCP
Intelligent code indexing and analysis for Large Language Models, enabling advanced search, file analysis, and real-time monitoring of codebases.
README
Code Index MCP
<div align="center">
Intelligent code indexing and analysis for Large Language Models
Transform how AI understands your codebase with advanced search, analysis, and navigation capabilities.
</div>
<a href="https://glama.ai/mcp/servers/@johnhuang316/code-index-mcp"> <img width="380" height="200" src="https://glama.ai/mcp/servers/@johnhuang316/code-index-mcp/badge" alt="code-index-mcp MCP server" /> </a>
Overview
Code Index MCP is a Model Context Protocol server that bridges the gap between AI models and complex codebases. It provides intelligent indexing, advanced search capabilities, and detailed code analysis to help AI assistants understand and navigate your projects effectively.
Perfect for: Code review, refactoring, documentation generation, debugging assistance, and architectural analysis.
Key Features
π Intelligent Search & Analysis
- Advanced Search: Auto-detects and uses the best available tool (ugrep, ripgrep, ag, or grep)
- Regex Support: Full regex pattern matching with ReDoS attack prevention
- Fuzzy Search: True fuzzy matching with edit distance (ugrep) or word boundary patterns
- File Analysis: Deep insights into structure, imports, classes, methods, and complexity metrics
ποΈ Multi-Language Support
- Mainstream Languages: Java, Python, JavaScript/TypeScript, C/C++, Go, Rust, C#
- Mobile Development: Swift, Kotlin, Objective-C/C++, React Native
- Web Frontend: Vue, React, Svelte, Astro, HTML, CSS, SCSS
- Database: SQL (MySQL, PostgreSQL, SQLite), NoSQL, stored procedures, migrations
- Scripting: Ruby, PHP, Shell, PowerShell, Bash
- Systems: C/C++, Rust, Go, Zig
- JVM Ecosystem: Java, Kotlin, Scala, Groovy
- Others: Lua, Perl, R, MATLAB, configuration files
- 50+ File Types Total - View complete list
β‘ Real-time Monitoring & Auto-refresh
- File Watcher: Automatic index updates when files change
- Cross-platform: Native OS file system monitoring (inotify, FSEvents, ReadDirectoryChangesW)
- Smart Debouncing: Batches rapid changes to prevent excessive rebuilds (default: 6 seconds)
- Thread-safe: Non-blocking background operations with ThreadPoolExecutor
β‘ Performance & Efficiency
- Smart Indexing: Recursively scans with intelligent filtering of build directories
- Persistent Caching: Stores indexes for lightning-fast subsequent access
- Lazy Loading: Tools detected only when needed for optimal startup
- Memory Efficient: Intelligent caching strategies for large codebases
Supported File Types
<details> <summary><strong>π Programming Languages (Click to expand)</strong></summary>
System & Low-Level:
- C/C++ (
.c,.cpp,.h,.hpp) - Rust (
.rs) - Zig (
.zig) - Go (
.go)
Object-Oriented:
- Java (
.java) - C# (
.cs) - Kotlin (
.kt) - Scala (
.scala) - Objective-C/C++ (
.m,.mm) - Swift (
.swift)
Scripting & Dynamic:
- Python (
.py) - JavaScript/TypeScript (
.js,.ts,.jsx,.tsx,.mjs,.cjs) - Ruby (
.rb) - PHP (
.php) - Shell (
.sh,.bash)
</details>
<details> <summary><strong>π Web & Frontend (Click to expand)</strong></summary>
Frameworks & Libraries:
- Vue (
.vue) - Svelte (
.svelte) - Astro (
.astro)
Styling:
- CSS (
.css,.scss,.less,.sass,.stylus,.styl) - HTML (
.html)
Templates:
- Handlebars (
.hbs,.handlebars) - EJS (
.ejs) - Pug (
.pug)
</details>
<details> <summary><strong>ποΈ Database & SQL (Click to expand)</strong></summary>
SQL Variants:
- Standard SQL (
.sql,.ddl,.dml) - Database-specific (
.mysql,.postgresql,.psql,.sqlite,.mssql,.oracle,.ora,.db2)
Database Objects:
- Procedures & Functions (
.proc,.procedure,.func,.function) - Views & Triggers (
.view,.trigger,.index)
Migration & Tools:
- Migration files (
.migration,.seed,.fixture,.schema) - Tool-specific (
.liquibase,.flyway)
NoSQL & Modern:
- Graph & Query (
.cql,.cypher,.sparql,.gql)
</details>
<details> <summary><strong>π Documentation & Config (Click to expand)</strong></summary>
- Markdown (
.md,.mdx) - Configuration (
.json,.xml,.yml,.yaml)
</details>
Quick Start
π Recommended Setup (Most Users)
The easiest way to get started with any MCP-compatible application:
Prerequisites: Python 3.10+ and uv
-
Add to your MCP configuration (e.g.,
claude_desktop_config.jsonor~/.claude.json):{ "mcpServers": { "code-index": { "command": "uvx", "args": ["code-index-mcp"] } } } -
Restart your application β
uvxautomatically handles installation and execution
π οΈ Development Setup
For contributing or local development:
-
Clone and install:
git clone https://github.com/johnhuang316/code-index-mcp.git cd code-index-mcp uv sync -
Configure for local development:
{ "mcpServers": { "code-index": { "command": "uv", "args": ["run", "code-index-mcp"] } } } -
Debug with MCP Inspector:
npx @modelcontextprotocol/inspector uv run code-index-mcp
<details> <summary><strong>Alternative: Manual pip Installation</strong></summary>
If you prefer traditional pip management:
pip install code-index-mcp
Then configure:
{
"mcpServers": {
"code-index": {
"command": "code-index-mcp",
"args": []
}
}
}
</details>
Available Tools
ποΈ Project Management
| Tool | Description |
|---|---|
set_project_path |
Initialize indexing for a project directory |
refresh_index |
Rebuild the project index after file changes |
get_settings_info |
View current project configuration and status |
π Search & Discovery
| Tool | Description |
|---|---|
search_code_advanced |
Smart search with regex, fuzzy matching, and file filtering |
find_files |
Locate files using glob patterns (e.g., **/*.py) |
get_file_summary |
Analyze file structure, functions, imports, and complexity |
π Monitoring & Auto-refresh
| Tool | Description |
|---|---|
get_file_watcher_status |
Check file watcher status and configuration |
configure_file_watcher |
Enable/disable auto-refresh and configure settings |
π οΈ System & Maintenance
| Tool | Description |
|---|---|
create_temp_directory |
Set up storage directory for index data |
check_temp_directory |
Verify index storage location and permissions |
clear_settings |
Reset all cached data and configurations |
refresh_search_tools |
Re-detect available search tools (ugrep, ripgrep, etc.) |
Usage Examples
π― Quick Start Workflow
1. Initialize Your Project
Set the project path to /Users/dev/my-react-app
Automatically indexes your codebase and creates searchable cache
2. Explore Project Structure
Find all TypeScript component files in src/components
Uses: find_files with pattern src/components/**/*.tsx
3. Analyze Key Files
Give me a summary of src/api/userService.ts
Uses: get_file_summary to show functions, imports, and complexity
π Advanced Search Examples
<details> <summary><strong>Code Pattern Search</strong></summary>
Search for all function calls matching "get.*Data" using regex
Finds: getData(), getUserData(), getFormData(), etc.
</details>
<details> <summary><strong>Fuzzy Function Search</strong></summary>
Find authentication-related functions with fuzzy search for 'authUser'
Matches: authenticateUser, authUserToken, userAuthCheck, etc.
</details>
<details> <summary><strong>Language-Specific Search</strong></summary>
Search for "API_ENDPOINT" only in Python files
Uses: search_code_advanced with file_pattern: "*.py"
</details>
<details> <summary><strong>Auto-refresh Configuration</strong></summary>
Configure automatic index updates when files change
Uses: configure_file_watcher to enable/disable monitoring and set debounce timing
</details>
<details> <summary><strong>Project Maintenance</strong></summary>
I added new components, please refresh the project index
Uses: refresh_index to update the searchable cache
</details>
Troubleshooting
π Auto-refresh Not Working
If automatic index updates aren't working when files change, try:
pip install watchdog(may resolve environment isolation issues)- Use manual refresh: Call the
refresh_indextool after making file changes - Check file watcher status: Use
get_file_watcher_statusto verify monitoring is active
Development & Contributing
π§ Building from Source
git clone https://github.com/johnhuang316/code-index-mcp.git
cd code-index-mcp
uv sync
uv run code-index-mcp
π Debugging
npx @modelcontextprotocol/inspector uvx code-index-mcp
π€ Contributing
Contributions are welcome! Please feel free to submit a Pull Request.
π License
π Translations
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.