Pular para o conteúdo

Servidores LSP

opencode integra-se aos seus servidores LSP.

opencode integra-se ao seu Protocolo de Servidor de Linguagem (LSP) para ajudar o LLM a interagir com sua base de código. Ele usa diagnósticos para fornecer feedback ao LLM.


Integrado

opencode vem com vários servidores LSP integrados para linguagens populares:

Servidor LSPExtensõesRequisitos
astro.astroInstala automaticamente para projetos Astro
bash.sh, .bash, .zsh, .kshInstala automaticamente bash-language-server
clangd.c, .cpp, .cc, .cxx, .c++, .h, .hpp, .hh, .hxx, .h++Instala automaticamente para projetos C/C++
csharp.cs.NET SDK instalado
clojure-lsp.clj, .cljs, .cljc, .ednComando clojure-lsp disponível
dart.dartComando dart disponível
deno.ts, .tsx, .js, .jsx, .mjsComando deno disponível (detecta automaticamente deno.json/deno.jsonc)
elixir-ls.ex, .exsComando elixir disponível
eslint.ts, .tsx, .js, .jsx, .mjs, .cjs, .mts, .cts, .vueDependência eslint no projeto
fsharp.fs, .fsi, .fsx, .fsscript.NET SDK instalado
gleam.gleamComando gleam disponível
gopls.goComando go disponível
hls.hs, .lhsComando haskell-language-server-wrapper disponível
jdtls.javaJava SDK (version 21+) instalado
kotlin-ls.kt, .ktsInstala automaticamente para projetos Kotlin
lua-ls.luaInstala automaticamente para projetos Lua
nixd.nixComando nixd disponível
ocaml-lsp.ml, .mliComando ocamllsp disponível
oxlint.ts, .tsx, .js, .jsx, .mjs, .cjs, .mts, .cts, .vue, .astro, .svelteDependência oxlint no projeto
php intelephense.phpInstala automaticamente para projetos PHP
prisma.prismaComando prisma disponível
pyright.py, .pyiDependência pyright instalada
ruby-lsp (rubocop).rb, .rake, .gemspec, .ruComandos ruby e gem disponíveis
rust.rsComando rust-analyzer disponível
sourcekit-lsp.swift, .objc, .objcppswift instalado (xcode no macOS)
svelte.svelteInstala automaticamente para projetos Svelte
terraform.tf, .tfvarsInstala automaticamente a partir de lançamentos do GitHub
tinymist.typ, .typcInstala automaticamente a partir de lançamentos do GitHub
typescript.ts, .tsx, .js, .jsx, .mjs, .cjs, .mts, .ctsDependência typescript no projeto
vue.vueInstala automaticamente para projetos Vue
yaml-ls.yaml, .ymlInstala automaticamente o servidor yaml-language-server da Red Hat
zls.zig, .zonComando zig disponível

Os servidores LSP são habilitados automaticamente quando uma das extensões de arquivo acima é detectada e os requisitos são atendidos.


Como Funciona

Quando o opencode abre um arquivo, ele:

  1. Verifica a extensão do arquivo em relação a todos os servidores LSP habilitados.
  2. Inicia o servidor LSP apropriado se não estiver em execução.

Configurar

Você pode personalizar os servidores LSP através da seção lsp na sua configuração do opencode.

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

Cada servidor LSP suporta o seguinte:

PropriedadeTipoDescrição
disabledbooleanDefina como true para desabilitar o servidor LSP
commandstring[]O comando para iniciar o servidor LSP
extensionsstring[]Extensões de arquivo que este servidor LSP deve manipular
envobjectVariáveis de ambiente a serem definidas ao iniciar o servidor
initializationobjectOpções de inicialização a serem enviadas ao servidor LSP

Vamos ver alguns exemplos.


Variáveis de ambiente

Use a propriedade env para definir variáveis de ambiente ao iniciar o servidor LSP:

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

Opções de inicialização

Use a propriedade initialization para passar opções de inicialização ao servidor LSP. Estas são configurações específicas do servidor enviadas durante a solicitação initialize do LSP:

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

Desabilitando servidores LSP

Para desabilitar todos os servidores LSP globalmente, defina lsp como false:

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

Para desabilitar um servidor LSP específico, defina disabled como true:

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

Servidores LSP personalizados

Você pode adicionar servidores LSP personalizados especificando o comando e as extensões de arquivo:

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

Informações Adicionais

PHP Intelephense

PHP Intelephense oferece recursos premium através de uma chave de licença. Você pode fornecer uma chave de licença colocando (apenas) a chave em um arquivo de texto em:

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

O arquivo deve conter apenas a chave de licença sem conteúdo adicional.