Skip to content

LSP-servere

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


Innebygde servere

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

LSP ServerFilendelserKrav
astro.astroInstalleres automatisk for Astro-prosjekter
bash.sh, .bash, .zsh, .kshInstallerer bash-language-server automatisk
clangd.c, .cpp, .cc, .cxx, .c++, .h, .hpp, .hh, .hxx, .h++Installeres automatisk 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, .ktsInstalleres automatisk for Kotlin-prosjekter
lua-ls.luaInstalleres automatisk 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.phpInstalleres automatisk 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.svelteInstalleres automatisk for Svelte-prosjekter
terraform.tf, .tfvarsInstalleres automatisk fra GitHub-utgivelser
tinymist.typ, .typcInstalleres automatisk fra GitHub-utgivelser
typescript.ts, .tsx, .js, .jsx, .mjs, .cjs, .mts, .ctstypescript avhengighet i prosjekt
vue.vueInstalleres automatisk for Vue-prosjekter
yaml-ls.yaml, .ymlInstallerer Red Hat yaml-language-server automatisk
zls.zig, .zonzig kommando tilgjengelig

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


Slik fungerer det

Når slopcode å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.

Konfigurasjon

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

slopcode.json
{
"$schema": "https://slopcode.dev/config.json",
"lsp": {}
}

Hver LSP-server støtter følgende:

EgenskapTypeBeskrivelse
disabledbooleanSett dette til true for å deaktivere LSP-serveren
commandstring[]Kommandoen for å starte LSP-serveren
extensionsstring[]Filendelser 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:

slopcode.json
{
"$schema": "https://slopcode.dev/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:

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

Deaktivering av LSP-servere

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

slopcode.json
{
"$schema": "https://slopcode.dev/config.json",
"lsp": false
}

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

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

Egendefinerte LSP-servere

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

slopcode.json
{
"$schema": "https://slopcode.dev/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.