lsp-mcp-server

lsp-mcp-server

Exposes type-aware code navigation and fast file search to AI agents via language servers, enabling definitions, references, symbols, and file lookup without reading entire codebases.

Category
Visit Server

README

lsp-mcp-server

A lightweight MCP server that exposes type-aware code navigation and fast file search to AI agents via language servers. It manages language server processes on demand, routes LSP requests from MCP tool calls, and returns structured results — letting agents jump to definitions, find references, list symbols, and locate files without reading entire codebases.

Installation

Option 1: Claude Code Plugin (recommended)

One command to clone, install, and register as a Claude Code plugin:

git clone https://github.com/garretpremo/lsp-mcp-server.git ~/.local/share/lsp-mcp-server \
  && cd ~/.local/share/lsp-mcp-server && bun install \
  && bash scripts/install-plugin.sh

Restart Claude Code (or run /reload-plugins) to activate. The plugin adds a skill that guides Claude on when to use each tool, plus the MCP server runs automatically for each project.

Option 2: Per-session (no install)

git clone https://github.com/garretpremo/lsp-mcp-server.git ~/tools/lsp-mcp-server \
  && cd ~/tools/lsp-mcp-server && bun install

Then start Claude Code with:

claude --plugin-dir ~/tools/lsp-mcp-server/plugin

Option 3: Manual MCP config

Add to your project's .mcp.json or ~/.claude/settings.json:

{
  "mcpServers": {
    "lsp-mcp-server": {
      "command": "bun",
      "args": ["run", "/path/to/lsp-mcp-server/src/index.ts", "--project", "."]
    }
  }
}

Option 4: Standalone (any MCP client)

bun run src/index.ts --project /path/to/your/project

Communicates via stdio JSON-RPC — works with any MCP-compatible client.

Available Tools

Tool Description
find_file Fuzzy file name search against the project file index
reindex Rebuild the file index (full project or a subdirectory)
go_to_definition Jump to the definition of a symbol at a given file position
find_references Find all references to a symbol at a given file position
document_symbols List all symbols (classes, functions, etc.) in a file
workspace_symbol Search for symbols by name across the entire project

All LSP navigation tools accept optional enrichment flags: includeKind, includeContainer, and includeDocstring.

Configuration

Place a config.json in your project root to override language server commands or the request timeout:

{
  "requestTimeout": 15000,
  "languageServers": {
    "typescript": {
      "command": "typescript-language-server",
      "args": ["--stdio"]
    },
    "java": {
      "command": "jdtls",
      "args": []
    }
  }
}

If no config.json is found, defaults are used. requestTimeout is in milliseconds (default: 10000).

Benchmarks: lsp-mcp-server vs JetBrains MCP

Tested against a 4,381-file Angular/TypeScript project (Nx monorepo).

File Search — "document-viewer"

lsp-mcp-server JetBrains MCP
Response size ~1,500 chars 9,792 chars
Results 10 files, ranked by relevance 40 items (files + dirs), unranked, duplicated by worktrees
Format Absolute + relative paths Flat path list with worktree duplicates

Document Symbols — reports.service.ts

lsp-mcp-server JetBrains MCP
Response size ~5,200 chars 4,486 chars
Result type 31 structured symbols (name, kind, container, snippet) Raw file text (no symbols tool available)
Structured Yes — class, method, property with hierarchy No — LLM must parse symbols from raw text

Go To Definition — HttpClient import

lsp-mcp-server JetBrains MCP
Response size ~550 chars 34,868 chars
Result type 1 precise definition location 50 text matches (grep-style, not semantic)
Semantic Yes — LSP-powered, type-aware No — text search with search_in_files_by_text

Agent Token Usage (identical tasks, Sonnet model)

lsp-mcp-server JetBrains MCP
Total tokens 18,910 25,994
Tool calls 3 10

Summary

  • 6.5x smaller file search responses
  • 63x smaller definition lookup responses
  • 27% fewer tokens consumed by the agent
  • Structured symbol data vs raw text
  • True LSP semantics vs text-based grep

Prerequisites

The following language servers must be installed and available on your PATH:

Language servers are started lazily — only when a file of the matching type is first accessed.

License

MIT

Recommended Servers

playwright-mcp

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.

Official
Featured
TypeScript
Magic Component Platform (MCP)

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.

Official
Featured
Local
TypeScript
Audiense Insights MCP Server

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.

Official
Featured
Local
TypeScript
VeyraX MCP

VeyraX MCP

Single MCP tool to connect all your favorite tools: Gmail, Calendar and 40 more.

Official
Featured
Local
graphlit-mcp-server

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.

Official
Featured
TypeScript
Kagi MCP Server

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.

Official
Featured
Python
E2B

E2B

Using MCP to run code via e2b.

Official
Featured
Neon Database

Neon Database

MCP server for interacting with Neon Management API and databases

Official
Featured
Exa Search

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.

Official
Featured
Qdrant Server

Qdrant Server

This repository is an example of how to create a MCP server for Qdrant, a vector search engine.

Official
Featured