W3 MCP LSP Server
Provides code intelligence (go to definition, hover, find references) for JavaScript files via the TypeScript Language Server.
Provides code intelligence (go to definition, hover, find references) for TypeScript files via the TypeScript Language Server.
Click on "Install Server".
Wait a few minutes for the server to deploy. Once ready, it will show a "Started" state.
In the chat, type
@followed by the MCP server name and your instructions, e.g., "@W3 MCP LSP Servershow definition ofaddin src/math.ts at line 10, column 5"
That's it! The server will respond to your query, and you can continue using it as needed.
Here is a step-by-step guide with screenshots.
W3 MCP LSP Server
Python MCP server wrapping TypeScript Language Server for JavaScript/TypeScript code intelligence.
Status: ✅ Working with real LSP protocol (not mock)
Features
lsp_goto_definition - Jump to symbol definition location
lsp_hover - Get type information and documentation
lsp_find_references - Find all references/usages of symbol
Supports JavaScript and TypeScript files via TypeScript Language Server.
Quick Start
1. Clean Setup (Important!)
cd /path/to/w3-mcp-server-lsp
# Remove old lockfile and venv
rm -rf uv.lock .venv venv
# Unset old environment variable
unset VIRTUAL_ENV2. Install Dependencies
# Install TypeScript Language Server
npm install -g typescript typescript-language-server
# Install Python dependencies (using uv)
uv sync
# Install MCP CLI dependencies
uv pip install 'mcp[cli]'3. Verify Installation
# Check typescript-language-server
which typescript-language-server
typescript-language-server --version
# Check Python env
uv run python -c "from mcp.server.fastmcp import FastMCP; print('✓ MCP ready')"4. Test with MCP Inspector
# Start MCP Inspector (interactive web UI)
uv run mcp dev server.pyOpens URL like:
http://localhost:6274/?MCP_PROXY_AUTH_TOKEN=...Features:
✅ Available tools listed in sidebar
✅ Test each tool interactively with JSON input
✅ Real-time request/response viewing
✅ Server logs and debugging
✅ No extra dependencies needed
Usage
Option A: MCP Inspector (Development)
Best way to test and debug:
cd /path/to/w3-mcp-server-lsp
# Start inspector
uv run mcp dev server.pyOpens web UI at http://localhost:5173:
See available tools
Test each tool with JSON input
View request/response in real-time
See server logs
Option B: Direct Python
# Run server (stdio mode)
uv run python server.pyOption C: Claude Code Integration
Method 1: From PyPI (Recommended)
Install from PyPI:
pip install w3-mcp-server-lsp
# or
uv pip install w3-mcp-server-lspEdit ~/.claude/claude_config.json or ~/.mcp.json:
{
"mcpServers": {
"w3-lsp": {
"type": "stdio",
"command": "uv",
"args": ["run", "--with", "w3-mcp-server-lsp", "w3-mcp-server-lsp"],
"env": {
"PROJECT_ROOT": "/path/to/your/project"
}
}
}
}Advantages:
✅ No need to clone the repo
✅ Easy version management
✅ Automatic dependency isolation
Method 2: From Local Source
Edit ~/.claude/claude_config.json:
{
"mcpServers": {
"w3-lsp": {
"type": "stdio",
"command": "uv",
"args": ["run", "server.py"],
"cwd": "/path/to/w3-mcp-server-lsp",
"env": {
"PROJECT_ROOT": "/path/to/your/project"
}
}
}
}Then restart Claude Code.
Tools Documentation
⚠️ IMPORTANT: 0-Indexed Line and Character Numbers
All tools use 0-indexed positioning (start from 0, not 1):
Editor Display | Tool Input | Formula |
Ln 5, Col 10 | line: 4 | lsp_value = editor_value - 1 |
Ln 1, Col 1 | line: 0 | character: 0 |
Ln 10, Col 5 | line: 9 | character: 4 |
Quick Reference:
Line 1 in editor =
line: 0in toolColumn 1 in editor =
character: 0in tool
How to Calculate Character Position:
Given this code line:
const greeting = "Hello";
0123456789...Position at
cinconst→character: 0Position at
oinconst→character: 1Position at
gingreeting→character: 6Position at
Hin"Hello"→character: 18
In VSCode:
Click on a character
Look at status bar:
Ln X, Col YUse:
line: X-1, character: Y-1
lsp_goto_definition
Jump to definition of symbol at specified position.
Input:
{
"file_path": "fixtures/sample.js",
"line": 4,
"character": 9
}Output:
/path/to/fixtures/sample.js:5:9lsp_hover
Get type information and documentation for symbol.
Input:
{
"file_path": "fixtures/sample.js",
"line": 5,
"character": 10
}Output:
(parameter) a: anylsp_find_references
Find all references/usages of symbol.
Input:
{
"file_path": "fixtures/sample.js",
"line": 4,
"character": 9
}Output:
Found 2 references:
/path/to/fixtures/sample.js:5:9
/path/to/fixtures/sample.js:14:22Configuration
PROJECT_ROOT
Specifies the root directory of your project. Files paths in tool calls are relative to this.
Set via:
Environment variable:
export PROJECT_ROOT="/path/to/your/project" uv run python server.pyCurrent directory (default):
cd /path/to/your/project uv run python /path/to/w3-mcp-server-lsp/server.pyIn .claude/settings.json:
"env": { "PROJECT_ROOT": "/path/to/your/project" }
Line and Character Numbers (0-indexed)
LSP uses 0-indexed positions:
VSCode shows:
Ln 5, Col 10LSP needs:
line: 4, character: 9
Formula: lsp_value = vscode_value - 1
Project Structure
w3-mcp-server-lsp/
├── server.py # MCP server entry point
├── lsp_client.py # LSP protocol implementation
├── pyproject.toml # Project config
├── fixtures/
│ └── sample.js # Sample file for testing
├── test_mcp_server.py # Integration test
├── test_lsp_debug.py # Debug test with logging
└── README.mdHow It Works
Architecture
MCP Client (Claude, IDE, etc.)
↓
MCP Server (server.py)
↓
LSP Client (lsp_client.py)
↓
TypeScript Language Server (subprocess)LSP Protocol Flow
Initialization
Send:
initializerequestReceive: server capabilities
Send:
initializednotification
Document Opening
Send:
textDocument/didOpennotificationContent provided inline
Queries
Send:
textDocument/definition,textDocument/hover, etc.Receive: results from language server
Details
Communication: JSON-RPC over stdin/stdout
Binary mode: Avoids text encoding issues
Notification handling: Skip server notifications, match message IDs
Testing
Interactive Testing (Recommended)
uv run mcp dev server.pyWeb UI opens at http://localhost:5173:
Test tools visually
See real-time results
View server logs
Direct Server
uv run python server.pyRuns in stdio mode, ready to connect from Claude Code or other MCP clients.
Troubleshooting
TypeScript Language Server not found
# Install
npm install -g typescript typescript-language-server
# Verify
which typescript-language-serverMCP module not found
# Install dependencies
pip install -e .
# Or manually
pip install mcp pydanticServer hangs on startup
Check if TypeScript Language Server is installed
Check terminal for error messages
Try:
typescript-language-server --stdiodirectly
Tool returns None or error
Verify file path is relative to PROJECT_ROOT
Check line/character numbers are 0-indexed
Check server logs output in terminal
Use MCP Inspector (
uv run mcp dev server.py) to see requests/responses
Future Enhancements
Go support (gopls language server)
Python support (pylsp/pyright)
Multiple language servers in single MCP server
Caching of responses
Batch operations
Development
Testing with MCP Inspector
uv run mcp dev server.pyWeb UI at http://localhost:5173 shows:
Available tools and schemas
Real-time request/response
Server logs
Interactive testing
Running Directly
uv run python server.pyFor debugging, check logs output in terminal.
References
License
MIT
This server cannot be installed
Maintenance
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/famtong8-dev/w3-mcp-server-lsp'
If you have feedback or need assistance with the MCP directory API, please join our Discord server