Saltearse al contenido

Servidores LSP

OpenCode se integra con sus servidores LSP.

OpenCode puede integrarse con servidores Language Server Protocol (LSP) para usar diagnósticos como feedback para el agente.


Incorporados

OpenCode viene con varios servidores LSP integrados para idiomas populares:

Servidor LSPExtensionesRequisitos
astro.astroAutoinstalaciones para proyectos Astro
bash.sh, .bash, .zsh, .kshAutoinstala el servidor en lenguaje bash
clangd.c, .cpp, .cc, .cxx, .c++, .h, .hpp, .hh, .hxx, .h++Instalaciones automáticas para proyectos C/C++
csharp.cs.NET SDK instalado
clojure-lsp.clj, .cljs, .cljc, .ednComando clojure-lsp disponible
dart.dartComando dart disponible
deno.ts, .tsx, .js, .jsx, .mjsComando deno disponible (detecta automáticamente deno.json/deno.jsonc)
elixir-ls.ex, .exsComando elixir disponible
eslint.ts, .tsx, .js, .jsx, .mjs, .cjs, .mts, .cts, .vueeslint dependencia en proyecto
fsharp.fs, .fsi, .fsx, .fsscript.NET SDK instalado
gleam.gleamComando gleam disponible
gopls.goComando go disponible
hls.hs, .lhsComando haskell-language-server-wrapper disponible
jdtls.javaJava SDK (version 21+) instalado
julials.jljulia y LanguageServer.jl instalados
kotlin-ls.kt, .ktsAutoinstalaciones para proyectos Kotlin
lua-ls.luaAutoinstalaciones para proyectos Lua
nixd.nixComando nixd disponible
ocaml-lsp.ml, .mliComando ocamllsp disponible
oxlint.ts, .tsx, .js, .jsx, .mjs, .cjs, .mts, .cts, .vue, .astro, .svelteoxlint dependencia en proyecto
php intelephense.phpAutoinstalaciones para proyectos PHP
prisma.prismaComando prisma disponible
pyright.py, .pyiDependencia pyright instalada
ruby-lsp (rubocop).rb, .rake, .gemspec, .ruComandos ruby y gem disponibles
rust.rsComando rust-analyzer disponible
sourcekit-lsp.swift, .objc, .objcppswift instalado (xcode en macOS)
svelte.svelteAutoinstalaciones para proyectos Svelte
terraform.tf, .tfvarsInstalaciones automáticas desde versiones GitHub
tinymist.typ, .typcInstalaciones automáticas desde versiones GitHub
typescript.ts, .tsx, .js, .jsx, .mjs, .cjs, .mts, .ctstypescript dependencia en proyecto
vue.vueAutoinstalaciones para proyectos Vue
yaml-ls.yaml, .ymlAutoinstala Red Hat yaml-language-server
zls.zig, .zonComando zig disponible

LSP está deshabilitado por defecto. Cuando está habilitado, los servidores se inician cuando se detecta una de las extensiones de archivo anteriores y se cumplen los requisitos.


Cómo funciona

Cuando LSP está habilitado y opencode abre un archivo:

  1. Comprueba la extensión del archivo con todos los servidores LSP habilitados.
  2. Inicia el servidor LSP apropiado si aún no se está ejecutando.

Buenas prácticas

LSP puede ayudar al agente a encontrar y corregir problemas proporcionando diagnósticos de los servidores de lenguaje. Esto es útil en algunos proyectos, pero no siempre es una mejora neta.

Los servidores de lenguaje pueden desincronizarse, usar bastante memoria, variar según la versión o el proyecto y ralentizar los flujos de trabajo del agente. En muchos proyectos es mejor hacer que el agente ejecute lint, typecheck u otras herramientas CLI de diagnóstico directamente, para que los errores vuelvan al ciclo del agente sin esas compensaciones. Documenta esos comandos en archivos de instrucciones como AGENTS.md o skills para que el agente sepa qué ejecutar. Habilita LSP cuando tu proyecto se beneficie de feedback adicional del servidor de lenguaje.


Configuración

Puede habilitar y personalizar los servidores LSP a través de la sección lsp en su configuración opencode.

Para habilitar todos los servidores LSP integrados, configure lsp como true.

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

Use un objeto para mantener habilitados los servidores integrados mientras configura anulaciones o servidores personalizados.

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

Cada servidor LSP admite lo siguiente:

PropiedadTipoDescripción
disabledbooleanoEstablezca esto en true para deshabilitar el servidor LSP
commandcadena[]El comando para iniciar el servidor LSP
extensionscadena[]Extensiones de archivo que este servidor LSP debería manejar
envobjetoVariables de entorno para configurar al iniciar el servidor
initializationobjetoOpciones de inicialización para enviar al servidor LSP

Veamos algunos ejemplos.


Variables de entorno

Utilice la propiedad env para establecer variables de entorno al iniciar el servidor LSP:

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

Opciones de inicialización

Utilice la propiedad initialization para pasar opciones de inicialización al servidor LSP. Estas son configuraciones específicas del servidor enviadas durante la solicitud LSP initialize:

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

Deshabilitar servidores LSP

Si se omite lsp, todos los servidores LSP están deshabilitados. Para deshabilitar todos los servidores LSP después de que otra configuración los haya habilitado, configure lsp en false:

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

Para deshabilitar un servidor LSP específico, configure disabled en true:

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

Servidores LSP personalizados

Puede agregar servidores LSP personalizados especificando el comando y las extensiones de archivo:

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

Información adicional

PHP Intelephense

PHP Intelephense ofrece funciones premium a través de una clave de licencia. Puede proporcionar una clave de licencia colocando (únicamente) la clave en un archivo de texto en:

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

El archivo debe contener sólo la clave de licencia sin contenido adicional.