feat(aliases): Add support for prepare rename

This commit is contained in:
Myzel394 2024-09-07 21:02:43 +02:00
parent 40a570809d
commit ad1a8e0d95
No known key found for this signature in database
GPG Key ID: DEC4AAB876F73185
3 changed files with 92 additions and 0 deletions

View File

@ -0,0 +1,45 @@
package lsp
import (
"config-lsp/handlers/aliases"
"config-lsp/handlers/aliases/ast"
"config-lsp/handlers/aliases/handlers"
"github.com/tliron/glsp"
protocol "github.com/tliron/glsp/protocol_3_16"
)
func TextDocumentPrepareRename(context *glsp.Context, params *protocol.PrepareRenameParams) (any, error) {
d := aliases.DocumentParserMap[params.TextDocument.URI]
character := params.Position.Character
line := params.Position.Line
rawEntry, found := d.Parser.Aliases.Get(line)
if !found {
return nil, nil
}
entry := rawEntry.(*ast.AliasEntry)
if character >= entry.Key.Location.Start.Character && character <= entry.Key.Location.End.Character {
return entry.Key.Location.ToLSPRange(), nil
}
if entry.Values != nil && character >= entry.Values.Location.Start.Character && character <= entry.Values.Location.End.Character {
rawValue := handlers.GetValueAtCursor(character, entry)
if rawValue == nil {
return nil, nil
}
switch (*rawValue).(type) {
case ast.AliasValueUser:
userValue := (*rawValue).(ast.AliasValueUser)
return userValue.Location.ToLSPRange(), nil
}
}
return nil, nil
}

View File

@ -30,6 +30,7 @@ func SetUpRootHandler() {
TextDocumentDefinition: TextDocumentDefinition, TextDocumentDefinition: TextDocumentDefinition,
WorkspaceExecuteCommand: WorkspaceExecuteCommand, WorkspaceExecuteCommand: WorkspaceExecuteCommand,
TextDocumentRename: TextDocumentRename, TextDocumentRename: TextDocumentRename,
TextDocumentPrepareRename: TextDocumentPrepareRename,
} }
server := server.NewServer(&lspHandler, lsName, false) server := server.NewServer(&lspHandler, lsName, false)
@ -41,6 +42,14 @@ func initialize(context *glsp.Context, params *protocol.InitializeParams) (any,
capabilities := lspHandler.CreateServerCapabilities() capabilities := lspHandler.CreateServerCapabilities()
capabilities.TextDocumentSync = protocol.TextDocumentSyncKindFull capabilities.TextDocumentSync = protocol.TextDocumentSyncKindFull
if (*params.Capabilities.TextDocument.Rename.PrepareSupport) == true {
// Client supports rename preparation
prepareRename := true
capabilities.RenameProvider = protocol.RenameOptions{
PrepareProvider: &prepareRename,
}
}
return protocol.InitializeResult{ return protocol.InitializeResult{
Capabilities: capabilities, Capabilities: capabilities,
ServerInfo: &protocol.InitializeResultServerInfo{ ServerInfo: &protocol.InitializeResultServerInfo{

View File

@ -0,0 +1,38 @@
package roothandler
import (
"github.com/tliron/glsp"
aliases "config-lsp/handlers/aliases/lsp"
protocol "github.com/tliron/glsp/protocol_3_16"
)
func TextDocumentPrepareRename(context *glsp.Context, params *protocol.PrepareRenameParams) (any, error) {
language := rootHandler.GetLanguageForDocument(params.TextDocument.URI)
if language == nil {
showParseError(
context,
params.TextDocument.URI,
undetectableError,
)
return nil, undetectableError.Err
}
switch *language {
case LanguageHosts:
return nil, nil
case LanguageSSHDConfig:
return nil, nil
case LanguageFstab:
return nil, nil
case LanguageWireguard:
return nil, nil
case LanguageAliases:
return aliases.TextDocumentPrepareRename(context, params)
}
panic("root-handler/TextDocumentPrepareRename: unexpected language" + *language)
}