Pular para o conteúdo

Servidores LSP

O opencode integra-se aos seus servidores LSP.

O opencode pode se integrar a servidores Language Server Protocol (LSP) para usar diagnósticos como feedback para o agente.


Integrados

O 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
julials.jljulia e LanguageServer.jl instalados
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

O LSP fica desabilitado por padrão. Quando habilitado, os servidores iniciam quando uma das extensões de arquivo acima é detectada e os requisitos são atendidos.


Como Funciona

Quando o LSP está habilitado e 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.

Boas práticas

O LSP pode ajudar o agente a encontrar e corrigir problemas fornecendo diagnósticos dos servidores de linguagem. Isso é útil em alguns projetos, mas nem sempre é um ganho líquido.

Servidores de linguagem podem ficar fora de sincronia, usar bastante memória, variar por versão ou projeto e desacelerar fluxos de trabalho do agente. Em muitos projetos, é melhor fazer o agente executar lint, typecheck ou outras ferramentas CLI de diagnóstico diretamente, para que os erros voltem ao ciclo do agente sem essas compensações. Documente esses comandos em arquivos de instruções como AGENTS.md ou skills, para que o agente saiba o que executar. Habilite o LSP quando seu projeto se beneficiar de feedback adicional do servidor de linguagem.


Configuração

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

Para habilitar todos os servidores LSP integrados, defina lsp como true.

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

Use um objeto para manter os servidores integrados habilitados enquanto configura substituições ou servidores personalizados.

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

Se lsp for omitido, todos os servidores LSP ficam desabilitados. Para desabilitar todos os servidores LSP depois que outra configuração os habilitou, 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.