An MCP (Model Context Protocol) server for fast local source code searching using Zoekt.
- Fast code search: Uses Zoekt's trigram-based indexing for fast substring and regex matching
- Per-directory indexes: Each indexed directory gets its own index stored in the user profile
- Rich query language: Supports regex, file filters, language filters, and boolean operators
- Cross-platform: Works on macOS and Linux
This server is available on the MCP Registry.
Download the appropriate .mcpb bundle for your platform from the GitHub Releases page:
code-index-mcp-darwin-arm64.mcpb- macOS Apple Siliconcode-index-mcp-darwin-amd64.mcpb- macOS Intelcode-index-mcp-linux-amd64.mcpb- Linux x64code-index-mcp-linux-arm64.mcpb- Linux ARM64
The .mcpb file is a ZIP archive containing the binary and manifest. You can open it directly in Claude Desktop in order to install it
In order to get the binary onto your computer, you can do one of the following:
Go to GitHub Releases and download the appropriate file (not mcpb but the tar/gzipped ones corresponding to your platform). For example:
curl -sL https://github.com/trondhindenes/code-index-mcp/releases/download/1.0.13/code-index-mcp-darwin-arm64.tar.gz | tar xz
chmod +x code-index-mcpgo install github.com/trondhindenes/code-index-mcp@latestgit clone https://github.com/trondhindenes/code-index-mcp
cd code-index-mcp
go build -o code-index-mcp .Now that you have the binary installed locally, you can register it in your tools of choice. This should not be necessary if you installed via mcpb bundle but your mileage may vary.
Add to your Claude Desktop configuration (~/Library/Application Support/Claude/claude_desktop_config.json on macOS):
{
"mcpServers": {
"code-index": {
"command": "/path/to/code-index-mcp"
}
}
}Run the following:
claude mcp add --scope user --transport stdio code-index /path/to/code-index-mcpCODE_INDEX_DIR: Override the default index storage location
Default index locations:
- macOS:
~/Library/Application Support/code-index/ - Linux:
~/.local/share/code-index/or$XDG_DATA_HOME/code-index/
Index a source code directory for fast searching.
Parameters:
directory(required): The path to the directory to index
Example:
Index the directory /Users/me/projects/myapp
Search for code across indexed directories. Returns compact grep-like output to minimize context window usage.
Parameters:
query(required): The search query using Zoekt syntaxdirectory(optional): Limit search to a specific indexed directorymax_files(optional): Maximum files to return (default: 20)max_lines_per_file(optional): Maximum matches per file (default: 3)files_only(optional): Only return file paths, no line content (default: false)
Output Format:
/path/to/file.go:42: matching line content here
/path/to/file.go:58: another matching line
... and 5 more matches in this file
Query Syntax Examples:
func main- Simple text searchfile:\.go$ func main- Search only in .go fileslang:python class.*Model- Search in Python files-test func main- Exclude files containing "test"case:yes MyFunc- Case-sensitive search
List all indexed directories and their locations.
Delete the index for a specific directory.
Parameters:
directory(required): The path to the directory whose index should be deleted
Get information about the indexing configuration, including storage location.
The following directories are automatically skipped during indexing:
- Hidden directories (starting with
.) node_modules,vendor,__pycache__target,build,distvenv,.venv,env,.env
Binary files and common non-code files are automatically skipped, including:
- Executables (
.exe,.dll,.so,.dylib) - Archives (
.zip,.tar,.gz) - Images (
.png,.jpg,.gif) - Documents (
.pdf,.doc,.docx)
MIT