跳转到内容

LSP Servers

opencode 与您的 LSP 服务器集成。

opencode 与您的语言服务器协议 (LSP) 集成,以帮助 LLM 与您的代码库交互。它使用诊断向 LLM 提供反馈。


Built-in

opencode 附带了多种适用于流行语言的内置 LSP 服务器:

LSP ServerExtensionsRequirements
astro.astroAstro 项目自动安装
bash.sh, .bash, .zsh, .ksh自动安装 bash-language-server
clangd.c, .cpp, .cc, .cxx, .c++, .h, .hpp, .hh, .hxx, .h++自动安装 C/C++ 项目
csharp.cs.NET SDK 已安装
clojure-lsp.clj, .cljs, .cljc, .ednclojure-lsp 命令可用
dart.dartdart 命令可用
deno.ts, .tsx, .js, .jsx, .mjsdeno 命令可用(自动检测 deno.json/deno.jsonc)
elixir-ls.ex, .exselixir 命令可用
eslint.ts, .tsx, .js, .jsx, .mjs, .cjs, .mts, .cts, .vueeslint 项目中的依赖项
fsharp.fs, .fsi, .fsx, .fsscript.NET SDK 已安装
gleam.gleamgleam 命令可用
gopls.gogo 命令可用
hls.hs, .lhshaskell-language-server-wrapper 命令可用
jdtls.javaJava SDK (version 21+) 已安装
kotlin-ls.kt, .ktsKotlin 项目的自动安装
lua-ls.lua自动安装 Lua 项目
nixd.nixnixd 命令可用
ocaml-lsp.ml, .mliocamllsp 命令可用
oxlint.ts, .tsx, .js, .jsx, .mjs, .cjs, .mts, .cts, .vue, .astro, .svelteoxlint 项目中的依赖项
php intelephense.phpPHP 项目的自动安装
prisma.prismaprisma 命令可用
pyright.py, .pyipyright 依赖项已安装
ruby-lsp (rubocop).rb, .rake, .gemspec, .rurubygem 命令可用
rust.rsrust-analyzer 命令可用
sourcekit-lsp.swift, .objc, .objcppswift 已安装(xcode 在 macOS 上)
svelte.svelteSvelte 项目的自动安装
terraform.tf, .tfvars从 GitHub 版本自动安装
tinymist.typ, .typc从 GitHub 版本自动安装
typescript.ts, .tsx, .js, .jsx, .mjs, .cjs, .mts, .ctstypescript 项目中的依赖项
vue.vueVue 项目自动安装
yaml-ls.yaml, .yml自动安装 Red Hat yaml-language-server
zls.zig, .zonzig 命令可用

当检测到上述文件扩展名之一并且满足要求时,LSP 服务器将自动启用。


它是如何工作的

当 opencode 打开一个文件时,它:

  1. 根据所有启用的 LSP 服务器检查文件扩展名。
  2. 如果尚未运行,则启动相应的 LSP 服务器。

Configure

您可以通过 opencode 配置中的 lsp 部分自定义 LSP 服务器。

opencode.json
{
"$schema": "https://opencode.ai/config.json",
"lsp": {}
}

每个 LSP 服务器支持以下功能:

PropertyTypeDescription
disabledboolean将其设置为 true 以禁用 LSP 服务器
commandstring[]启动 LSP 服务器的命令
extensionsstring[]此 LSP 服务器应处理的文件扩展名
envobject启动服务器时设置的环境变量
initializationobject发送到 LSP 服务器的初始化选项

让我们看一些例子。


Environment Variables

启动 LSP 服务器时使用 env 参数设置环境变量:

opencode.json
{
"$schema": "https://opencode.ai/config.json",
"lsp": {
"rust": {
"env": {
"RUST_LOG": "debug"
}
}
}
}

Initialization Options

使用 initialization 属性将初始化选项传递给 LSP 服务器。这些是在 LSP initialize 请求发送期间的服务器特定设置:

opencode.json
{
"$schema": "https://opencode.ai/config.json",
"lsp": {
"typescript": {
"initialization": {
"preferences": {
"importModuleSpecifierPreference": "relative"
}
}
}
}
}

Disabling LSP servers

要全局禁用 所有 LSP 服务,将 lsp 设置为 false

opencode.json
{
"$schema": "https://opencode.ai/config.json",
"lsp": false
}

要禁用 特定 LSP 服务器,将 disabled 设置为 true

opencode.json
{
"$schema": "https://opencode.ai/config.json",
"lsp": {
"typescript": {
"disabled": true
}
}
}

Custom LSP servers

您可以通过指定命令和文件扩展名来添加自定义 LSP 服务器:

opencode.json
{
"$schema": "https://opencode.ai/config.json",
"lsp": {
"custom-lsp": {
"command": ["custom-lsp-server", "--stdio"],
"extensions": [".custom"]
}
}
}

Additional Information

PHP Intelephense

PHP Intelephense 通过许可证密钥提供高级功能。您可以通过将(仅)密钥放置在以下位置的文本文件中来提供许可证密钥:

  • 在 macOS/Linux 上:$HOME/intelephense/license.txt
  • 在 Windows 上:%USERPROFILE%/intelephense/license.txt

该文件应仅包含许可证密钥,不包含其他内容。