Gå til innholdet

LSP Servere

opencode integreres med LSP-serverne dine.

OpenCode integreres med din Language Server Protocol (LSP) for å hjelpe LLM med å samhandle med kodebasen din. Den bruker diagnostikk for å gi tilbakemelding til LLM.


Innebygd

OpenCode kommer med flere innebygde LSP-servere for populære språk:

LSP ServerUtvidelserKrav
astro.astroAutoinstallasjoner for Astro-prosjekter
bash.sh, .bash, .zsh, .kshAutoinstallerer bash-language-server
clangd.c, .cpp, .cc, .cxx, .c++, .h, .hpp, .hh, .hxx, .h++Autoinstallasjoner for C/C++-prosjekter
csharp.cs.NET SDK installert
clojure-lsp.clj, .cljs, .cljc, .ednclojure-lsp kommando tilgjengelig
dart.dartdart kommando tilgjengelig
deno.ts, .tsx, .js, .jsx, .mjsdeno kommando tilgjengelig (automatisk oppdager deno.json/deno.jsonc)
elixir-ls.ex, .exselixir kommando tilgjengelig
eslint.ts, .tsx, .js, .jsx, .mjs, .cjs, .mts, .cts, .vueeslint avhengighet i prosjekt
fsharp.fs, .fsi, .fsx, .fsscript.NET SDK installert
gleam.gleamgleam kommando tilgjengelig
gopls.gogo kommando tilgjengelig
hls.hs, .lhshaskell-language-server-wrapper kommando tilgjengelig
jdtls.javaJava SDK (version 21+) installert
kotlin-ls.kt, .ktsAutoinstallasjoner for Kotlin-prosjekter
lua-ls.luaAutoinstallasjoner for Lua-prosjekter
nixd.nixnixd kommando tilgjengelig
ocaml-lsp.ml, .mliocamllsp kommando tilgjengelig
oxlint.ts, .tsx, .js, .jsx, .mjs, .cjs, .mts, .cts, .vue, .astro, .svelteoxlint avhengighet i prosjekt
php intelephense.phpAutoinstallasjoner for PHP-prosjekter
prisma.prismaprisma kommando tilgjengelig
pyright.py, .pyipyright avhengighet installert
ruby-lsp (rubocop).rb, .rake, .gemspec, .ruruby og gem kommandoer tilgjengelig
rust.rsrust-analyzer kommando tilgjengelig
sourcekit-lsp.swift, .objc, .objcppswift installert (xcode på macOS)
svelte.svelteAutoinstallasjoner for Svelte-prosjekter
terraform.tf, .tfvarsAutomatiske installasjoner fra GitHub-utgivelser
tinymist.typ, .typcAutomatiske installasjoner fra GitHub-utgivelser
typescript.ts, .tsx, .js, .jsx, .mjs, .cjs, .mts, .ctstypescript avhengighet i prosjekt
vue.vueAutoinstallasjoner for Vue-prosjekter
yaml-ls.yaml, .ymlAutoinstallerer Red Hat yaml-language-server
zls.zig, .zonzig kommando tilgjengelig

LSP-servere aktiveres automatisk når en av filtypene ovenfor oppdages og kravene oppfylles.


Hvordan det fungerer

Når opencode åpner en fil, gjør den:

  1. Kontrollerer filtypen mot alle aktiverte LSP-servere.
  2. Starter den riktige LSP-serveren hvis den ikke allerede kjører.

Konfigurer

Du kan tilpasse LSP-servere gjennom lsp-delen i OpenCode-konfigurasjonen.

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

Hver LSP-server støtter følgende:

PropertyTypeBeskrivelse
disabledbooleanSett dette til true for å deaktivere LSP-serveren
commandstring[]Kommandoen for å starte LSP-serveren
extensionsstring[]Filutvidelser denne LSP-serveren skal håndtere
envobjectMiljøvariabler som skal angis når serveren startes
initializationobjectInitialiseringsalternativer for å sende til LSP-serveren

La oss se på noen eksempler.


Miljøvariabler

Bruk egenskapen env til å angi miljøvariabler når du starter LSP-serveren:

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

Initialiseringsalternativer

Bruk egenskapen initialization til å sende initialiseringsalternativer til LSP-serveren. Dette er serverspesifikke innstillinger sendt under LSP initialize-forespørselen:

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

Deaktiverer LSP-servere

For å deaktivere alle LSP servere globalt, sett lsp til false:

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

For å deaktivere en spesifikk LSP-server, sett disabled til true:

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

Egendefinerte LSP-servere

Du kan legge til egendefinerte LSP-servere ved å spesifisere kommandoen og filtypene:

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

Tilleggsinformasjon

PHP Intelephense

PHP Intelephense tilbyr førsteklasses funksjoner gjennom en lisensnøkkel. Du kan oppgi en lisensnøkkel ved å plassere (bare) nøkkelen i en tekstfil på:

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

Filen skal bare inneholde lisensnøkkelen uten ekstra innhold.