/install lsp
LSP Code Navigation
Multi-language LSP client that manages per-language background daemons. Auto-detects the language from file extension and routes queries to the correct server. Each server lazy-starts on first use and idles out after 5 minutes of inactivity.
Use this instead of grep/read when you need to:
- Find where something is defined
- Find all usages of a symbol
- Get type signatures or docstrings
- List all classes/functions in a file
- Check for type errors before running code
- Search for a symbol across an entire workspace
Supported Languages
| Language | Server | Extensions | Install |
|---|---|---|---|
| Python | pyright-langserver |
.py, .pyi, .pyx | npm install -g pyright |
| TypeScript/JS | typescript-language-server |
.ts, .tsx, .js, .jsx, .mjs, .cjs | npm install -g typescript-language-server typescript |
| Rust | rust-analyzer |
.rs | rustup component add rust-analyzer |
| Go | gopls |
.go | go install golang.org/x/tools/gopls@latest |
| C/C++ | clangd |
.c, .h, .cpp, .cc, .hpp | apt install clangd or brew install llvm |
| Bash | bash-language-server |
.sh, .bash, .zsh | npm install -g bash-language-server |
| Java | jdtls |
.java | eclipse.jdt.ls |
| CSS | vscode-css-language-server |
.css, .scss, .less | npm install -g vscode-langservers-extracted |
| HTML | vscode-html-language-server |
.html, .htm | npm install -g vscode-langservers-extracted |
| JSON | vscode-json-language-server |
.json, .jsonc | npm install -g vscode-langservers-extracted |
Only install the servers you need. The skill auto-detects which are available and reports helpful install commands for missing ones.
Setup
Prerequisites
- Python 3.10+ (for the client script itself -- stdlib only, no pip deps)
- At least one language server installed (see table above)
Installation
The skill includes a Python script at {baseDir}/scripts/lsp-query.py. This is the LSP client -- it manages background daemons and handles all queries.
To make it callable as lsp-query from anywhere, symlink it into your PATH:
ln -sf {baseDir}/scripts/lsp-query.py /usr/local/bin/lsp-query
# or:
ln -sf {baseDir}/scripts/lsp-query.py ~/.npm-global/bin/lsp-query
Alternatively, invoke it directly:
{baseDir}/scripts/lsp-query.py \x3Ccommand> [args...]
Configuration
Set LSP_WORKSPACE to the repo root before querying. If unset, defaults to the git root or cwd.
Commands
All line and column numbers are 1-indexed (human-friendly, matching editor display).
Go to Definition
lsp-query definition /path/to/file.py \x3Cline> \x3Ccol>
Find References
lsp-query references /path/to/file.py \x3Cline> \x3Ccol>
Hover (Type Info)
lsp-query hover /path/to/file.py \x3Cline> \x3Ccol>
Document Symbols
lsp-query symbols /path/to/file.py
Workspace Symbol Search
lsp-query workspace-symbols "ClassName"
Diagnostics
lsp-query diagnostics /path/to/file.py
Completions
lsp-query completions /path/to/file.py \x3Cline> \x3Ccol>
Signature Help
lsp-query signature /path/to/file.py \x3Cline> \x3Ccol>
Rename Preview
lsp-query rename /path/to/file.py \x3Cline> \x3Ccol> new_name
Server Management
lsp-query languages # Show all supported languages + install status
lsp-query servers # List running language daemons
lsp-query shutdown # Stop all daemons
lsp-query shutdown python # Stop just the Python daemon
What's Included
{baseDir}/
├── SKILL.md # This file
└── scripts/
└── lsp-query.py # Python script -- multi-language LSP client + daemon manager
lsp-query.py is a self-contained Python script (~850 lines, stdlib only, no pip dependencies). It:
- Forks a single background daemon process on first use
- The daemon lazy-starts language servers as needed (e.g., pyright for .py, typescript-language-server for .ts)
- Communicates with the daemon over a Unix socket (
~/.cache/lsp-query/daemon.sock) - Translates CLI commands into LSP JSON-RPC requests and prints human-readable results
- Each language server auto-stops after 5 minutes idle; the daemon itself stops when all servers are idle
Environment Variables
| Variable | Default | Description |
|---|---|---|
LSP_WORKSPACE |
git root or cwd | Workspace root for LSP servers |
LSP_SERVER |
auto per language | Override server command for ALL languages |
LSP_LANG |
auto from extension | Force a specific language (bypass detection) |
LSP_TIMEOUT |
300 |
Server idle timeout in seconds |
LSP_SOCK |
~/.cache/lsp-query/daemon.sock |
Unix socket path |
Examples
export LSP_WORKSPACE=/path/to/repo
# Python
lsp-query symbols src/model.py
lsp-query hover src/model.py 42 10
lsp-query references src/model.py 42 10
# TypeScript (auto-detected from .ts extension)
lsp-query symbols src/index.ts
lsp-query definition src/app.tsx 15 8
# Rust
lsp-query symbols src/main.rs
lsp-query diagnostics src/lib.rs
# Check what's available
lsp-query languages
lsp-query servers
Troubleshooting
- "Server not found for X": The language server binary isn't installed. The error message includes the install command.
- "could not connect to LSP daemon": Daemon failed to start. Verify Python 3.10+ is available.
- Import errors in diagnostics: Expected when packages aren't installed in the current Python environment. These resolve on machines with the correct venv.
- Stale results: Run
lsp-query shutdownto restart all servers fresh. - Slow first query per language: Each server takes 1-2 seconds to cold-start. Subsequent queries to the same language are ~200ms.
- Wrong language detected: Use
LSP_LANG=rust lsp-query symbols myfileto force.
- 确保已安装 OpenClaw(本地或 Docker 部署)
- 在对话框中输入安装命令:
/install lsp - 安装完成后,直接呼叫该 Skill 的名称或使用
/lsp触发 - 根据 Skill 的参数说明提供必要输入,即可获得结构化输出
LSP Code Navigation 是什么?
Multi-language code navigation via persistent LSP daemons. Supports Python (pyright), TypeScript/JS, Rust, Go, C/C++, Bash, Java, CSS, HTML, JSON. Auto-detec... 它是一个面向 Claude Code / OpenClaw 的 AI Agent Skill 插件,目前累计下载 490 次。
如何安装 LSP Code Navigation?
在 OpenClaw 或 Claude Code 对话框中运行命令「/install lsp」即可一键安装,无需额外配置。
LSP Code Navigation 是免费的吗?
是的,LSP Code Navigation 完全免费(开源免费),可自由下载、安装和使用。
LSP Code Navigation 支持哪些平台?
LSP Code Navigation 跨平台运行,可在任意部署了 OpenClaw / Claude Code 的环境中使用(cross-platform)。
谁开发了 LSP Code Navigation?
由 AdamNaghs(@adamnaghs)开发并维护,当前版本 v2.0.0。