
mcp-language-server
Model Context Protocol (MCP) server that interacts with a Language Server
3 years
Works with Finder
3
Github Watches
14
Github Forks
162
Github Stars
MCP Language Server
A Model Context Protocol (MCP) server that runs a language server and provides tools for communicating with it.
Motivation
Claude desktop with the filesystem server feels like magic when working on small projects. This starts to fall apart after you add a few files and imports. With this project, I want to create that experience when working with large projects.
Language servers excel at tasks that LLMs often struggle with, such as precisely understanding types, understanding relationships, and providing accurate symbol references. This project aims to makes bring those tools to LLMs. LSP also seems like a clear inspiration for MCP so why not jam them together?
Status
⚠️ Pre-beta Quality ⚠️
I have tested this server with the following language servers
- pyright (Python)
- tsserver (TypeScript)
- gopls (Go)
- rust-analyzer (Rust)
But it should be compatible with many more.
Tools
-
read_definition
: Retrieves the complete source code definition of any symbol (function, type, constant, etc.) from your codebase. -
find_references
: Locates all usages and references of a symbol throughout the codebase. -
get_diagnostics
: Provides diagnostic information for a specific file, including warnings and errors. -
get_codelens
: Retrieves code lens hints for additional context and actions on your code. -
execute_codelens
: Runs a code lens action. -
apply_text_edit
: Allows making multiple text edits to a file programmatically.
Behind the scenes, this MCP server can act on workspace/applyEdit
requests from the language server, so it can apply things like refactor requests, adding imports, formatting code, etc.
Each tool supports various options for customizing output, such as including line numbers or additional context. See the tool documentation for detailed usage. Line numbers are necessary for apply_text_edit
to be able to make accurate edits.
About
This codebase makes use of edited code from gopls to handle LSP communication. See ATTRIBUTION for details.
mcp-golang is used for MCP communication.
Prerequisites
Install Go: Follow instructions at https://golang.org/doc/install
Fetch or update this server:
go install github.com/isaacphi/mcp-language-server@latest
Install a language server for your codebase:
- Python (pyright):
npm install -g pyright
- TypeScript (tsserver):
npm install -g typescript typescript-language-server
- Go (gopls):
go install golang.org/x/tools/gopls@latest
- Rust (rust-analyzer):
rustup component add rust-analyzer
- Or use any language server
Setup
Add something like the following configuration to your Claude Desktop settings (or similar MCP-enabled client):
{
"mcpServers": {
"language-server": {
"command": "go",
"args": [
"run",
"github.com/isaacphi/mcp-language-server@latest",
"--workspace",
"/Users/you/dev/yourcodebase",
"--lsp",
"/opt/homebrew/bin/pyright-langserver",
"--",
"--stdio"
],
"env": {
"DEBUG": "1"
}
}
}
}
Replace:
-
/Users/you/dev/yourcodebase
with the absolute path to your project -
/opt/homebrew/bin/pyright-langserver
with the path to your language server (found usingwhich
command e.g.which pyright-langserver
) - Any aruments after
--
are sent as arguments to your language server. - Any env variables are passed on to the language server. Some may be necessary for you language server. For example,
gopls
requiredGOPATH
andGOCACHE
in order for me to get it working properly. -
DEBUG=1
is optional. See below.
Development
Clone the repository:
git clone https://github.com/isaacphi/mcp-language-server.git
cd mcp-language-server
Install dev dependencies:
go mod download
Build:
go build
Configure your Claude Desktop (or similar) to use the local binary:
{
"mcpServers": {
"language-server": {
"command": "/full/path/to/your/clone/mcp-language-server/mcp-language-server",
"args": [
"--workspace",
"/path/to/workspace",
"--lsp",
"/path/to/language/server"
],
"env": {
"DEBUG": "1"
}
}
}
}
Rebuild after making changes.
Feedback
Include
env: {
"DEBUG": 1
}
To get detailed LSP and application logs. Please include as much information as possible when opening issues.
The following features are on my radar:
- Read definition
- Get references
- Apply edit
- Get diagnostics
- Code lens
- Hover info
- Code actions
- Better handling of context and cancellation
- Add LSP server configuration options and presets for common languages
- Make a more consistent and scalable API for tools (pagination, etc.)
- Create tools at a higher level of abstraction, combining diagnostics, code lens, hover, and code actions when reading definitions or references.
相关推荐
I find academic articles and books for research and literature reviews.
Confidential guide on numerology and astrology, based of GG33 Public information
Embark on a thrilling diplomatic quest across a galaxy on the brink of war. Navigate complex politics and alien cultures to forge peace and avert catastrophe in this immersive interstellar adventure.
Converts Figma frames into front-end code for various mobile frameworks.
Advanced software engineer GPT that excels through nailing the basics.
💬 MaxKB is a ready-to-use AI chatbot that integrates Retrieval-Augmented Generation (RAG) pipelines, supports robust workflows, and provides advanced MCP tool-use capabilities.
Micropython I2C-based manipulation of the MCP series GPIO expander, derived from Adafruit_MCP230xx
MCP server to provide Figma layout information to AI coding agents like Cursor
Python code to use the MCP3008 analog to digital converter with a Raspberry Pi or BeagleBone black.
The all-in-one Desktop & Docker AI application with built-in RAG, AI agents, No-code agent builder, MCP compatibility, and more.
Put an end to hallucinations! GitMCP is a free, open-source, remote MCP server for any GitHub project
Reviews

user_9bD415lt
I've been using the mcp-language-server by isaacphi and I'm thoroughly impressed. The tool has significantly improved my workflow, offering brilliant language support and seamless integration. It's a must-have for any developer looking to streamline their coding process. Check it out here: https://github.com/isaacphi/mcp-language-server