İçeriğe geç

LSP Sunucuları

OpenCode, LSP sunucularınızla bütünleşir.

OpenCode, tanılamayı agent için geri bildirim olarak kullanmak üzere Language Server Protocol (LSP) sunucularıyla bütünleşebilir.


Yerleşik

OpenCode, popüler diller için çeşitli yerleşik LSP sunucularıyla birlikte gelir:

LSP SunucuUzantılarGereksinimler
astro.astroAstro projeleri için otomatik kurulumlar
bash.sh, .bash, .zsh, .kshbash-language-server’ı otomatik olarak yükler
clangd.c, .cpp, .cc, .cxx, .c++, .h, .hpp, .hh, .hxx, .h++C/C++ projeleri için otomatik kurulumlar
csharp.cs.NET SDK kurulu
clojure-lsp.clj, .cljs, .cljc, .ednclojure-lsp komutu mevcut
dart.dartdart komutu mevcut
deno.ts, .tsx, .js, .jsx, .mjsdeno komutu mevcut (deno.json/deno.jsonc otomatik olarak algılanır)
elixir-ls.ex, .exselixir komutu mevcut
eslint.ts, .tsx, .js, .jsx, .mjs, .cjs, .mts, .cts, .vueProjede eslint bağımlılığı
fsharp.fs, .fsi, .fsx, .fsscript.NET SDK kurulu
gleam.gleamgleam komutu mevcut
gopls.gogo komutu mevcut
hls.hs, .lhshaskell-language-server-wrapper komutu mevcut
jdtls.javaJava SDK (version 21+) kurulu
julials.jljulia ve LanguageServer.jl kurulu
kotlin-ls.kt, .ktsKotlin projeleri için otomatik kurulumlar
lua-ls.luaLua projeleri için otomatik kurulumlar
nixd.nixnixd komutu mevcut
ocaml-lsp.ml, .mliocamllsp komutu mevcut
oxlint.ts, .tsx, .js, .jsx, .mjs, .cjs, .mts, .cts, .vue, .astro, .svelteProjede oxlint bağımlılığı
php intelephense.phpPHP projeleri için otomatik yüklemeler
prisma.prismaprisma komutu mevcut
pyright.py, .pyipyright bağımlılığı kurulu
ruby-lsp (rubocop).rb, .rake, .gemspec, .ruruby ve gem komutları mevcut
rust.rsrust-analyzer komutu mevcut
sourcekit-lsp.swift, .objc, .objcppswift kurulu (macOS’ta xcode)
svelte.svelteSvelte projeleri için otomatik kurulumlar
terraform.tf, .tfvarsGitHub sürümlerinden otomatik yüklemeler
tinymist.typ, .typcGitHub sürümlerinden otomatik yüklemeler
typescript.ts, .tsx, .js, .jsx, .mjs, .cjs, .mts, .ctsProjede typescript bağımlılığı
vue.vueVue projeleri için otomatik yüklemeler
yaml-ls.yaml, .ymlRed Hat yaml-language-server’ı otomatik olarak yükler
zls.zig, .zonzig komutu mevcut

LSP varsayılan olarak devre dışıdır. Etkinleştirildiğinde, yukarıdaki dosya uzantılarından biri tespit edilir ve gereksinimler karşılanırsa sunucular başlatılır.


Nasıl Çalışır?

LSP etkinleştirildiğinde ve opencode bir dosyayı açtığında:

  1. Dosya uzantısını tüm etkin LSP sunucularına göre kontrol eder.
  2. Henüz çalışmıyorsa uygun LSP sunucusunu başlatır.

En İyi Uygulamalar

LSP, dil sunucularından tanılama sağlayarak agent’ın sorunları bulup düzeltmesine yardımcı olabilir. Bu bazı projelerde yararlıdır, ancak her zaman net bir kazanç değildir.

Dil sunucuları senkronizasyonu kaybedebilir, önemli miktarda bellek kullanabilir, sürüme veya projeye göre değişebilir ve agent iş akışlarını yavaşlatabilir. Birçok projede agent’ın lint, typecheck veya diğer tanılama CLI araçlarını doğrudan çalıştırması daha iyidir; böylece hatalar bu ödünleşimler olmadan agent döngüsüne geri beslenir. Agent’ın ne çalıştıracağını bilmesi için bu komutları AGENTS.md veya skills gibi talimat dosyalarında belgeleyin. Projeniz ek dil sunucusu geri bildiriminden yararlanıyorsa LSP’yi etkinleştirin.


Yapılandırma

LSP sunucularını, opencode yapılandırmanızdaki lsp bölümü aracılığıyla etkinleştirebilir ve özelleştirebilirsiniz.

Tüm yerleşik LSP sunucularını etkinleştirmek için lsp değerini true olarak ayarlayın.

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

Yerleşik sunucuları etkin tutarken geçersiz kılmaları veya özel sunucuları yapılandırmak için bir nesne kullanın.

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

Her LSP sunucusu aşağıdakileri destekler:

ÖzellikTipAçıklama
disabledbooleanLSP sunucusunu devre dışı bırakmak için bunu true olarak ayarlayın
commandstring[]LSP sunucusunu başlatma komutu
extensionsstring[]Bu LSP sunucusunun işlemesi gereken dosya uzantıları
envobjectSunucuyu başlatırken ayarlanacak ortam değişkenleri
initializationobjectLSP sunucusuna gönderilecek başlatma seçenekleri

Bazı örneklere bakalım.


Ortam değişkenleri

LSP sunucusunu başlatırken ortam değişkenlerini ayarlamak için env özelliğini kullanın:

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

Başlatma seçenekleri

Başlatma seçeneklerini LSP sunucusuna iletmek için initialization özelliğini kullanın. Bunlar LSP initialize isteği sırasında gönderilen sunucuya özel ayarlardır:

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

LSP sunucularını devre dışı bırakma

lsp atlanırsa tüm LSP sunucuları devre dışı kalır. Başka bir yapılandırma etkinleştirdikten sonra tüm LSP sunucularını devre dışı bırakmak için lsp değerini false olarak ayarlayın:

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

Belirli bir LSP sunucusunu devre dışı bırakmak için disabled’yi true olarak ayarlayın:

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

Özel LSP sunucuları

Komutu ve dosya uzantılarını belirterek özel LSP sunucuları ekleyebilirsiniz:

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

Ek Bilgiler

PHP Intelephense

PHP Intelephense, bir lisans anahtarı aracılığıyla premium özellikler sunar. Anahtarı (yalnızca) şu adresteki bir metin dosyasına yerleştirerek bir lisans anahtarı sağlayabilirsiniz:

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

Dosya, ek içerik olmadan yalnızca lisans anahtarını içermelidir.