Saltearse al contenido

LSP Servidores

OpenCode se integra con sus servidores LSP.

OpenCode se integra con su protocolo de servidor de idiomas (LSP) para ayudar a LLM a interactuar con su código base. Utiliza diagnósticos para proporcionar retroalimentación al LLM.


Incorporado

OpenCode viene con varios servidores LSP integrados para idiomas populares:

LSP ServidorExtensionesRequisitos
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
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

Los servidores LSP se habilitan automáticamente cuando se detecta una de las extensiones de archivo anteriores y se cumplen los requisitos.


Cómo funciona

Cuando 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.

Configurar

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

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

Para deshabilitar todos los servidores LSP globalmente, 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 Intelefense

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:

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

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