From 05c50a70d50fad1f83e10bba6c714d5507bf713d Mon Sep 17 00:00:00 2001 From: Tadeas Uhlir Date: Sun, 31 Mar 2024 13:15:22 +0200 Subject: [PATCH] fix(lsp): fix trigger completion of zk LSP (#397) --- internal/adapter/lsp/document.go | 3 +++ internal/adapter/lsp/server.go | 27 ++++++++++++++++++++++----- 2 files changed, 25 insertions(+), 5 deletions(-) diff --git a/internal/adapter/lsp/document.go b/internal/adapter/lsp/document.go index 4eff87b7..2b8b55c0 100644 --- a/internal/adapter/lsp/document.go +++ b/internal/adapter/lsp/document.go @@ -281,6 +281,9 @@ func (d *document) IsTagPosition(position protocol.Position, noteContentParser c if targetWord == "" { return false } + if string(targetWord[0]) == "#" { + targetWord = targetWord[1:] + } content := strings.Join(lines, "\n") note, err := noteContentParser.ParseNoteContent(content) diff --git a/internal/adapter/lsp/server.go b/internal/adapter/lsp/server.go index f5141025..f679b32e 100644 --- a/internal/adapter/lsp/server.go +++ b/internal/adapter/lsp/server.go @@ -643,10 +643,16 @@ func (s *Server) refreshDiagnosticsOfDocument(doc *document, notify glsp.NotifyF // buildInvokedCompletionList builds the completion item response for a // completion started automatically when typing an identifier, or manually. func (s *Server) buildInvokedCompletionList(notebook *core.Notebook, doc *document, position protocol.Position) ([]protocol.CompletionItem, error) { - if !doc.IsTagPosition(position, notebook.Parser) { - return nil, nil + currentWord := doc.WordAt(position) + if strings.HasPrefix(doc.LookBehind(position, len(currentWord)+2), "[[") { + return s.buildLinkCompletionList(notebook, doc, position) } - return s.buildTagCompletionList(notebook, doc.WordAt(position)) + + if doc.IsTagPosition(position, notebook.Parser) { + return s.buildTagCompletionList(notebook, doc.WordAt(position)) + } + + return nil, nil } // buildTriggerCompletionList builds the completion item response for a @@ -804,12 +810,18 @@ func (s *Server) newCompletionItem(notebook *core.Notebook, note core.MinimalNot if s.useAdditionalTextEditsWithNotebook(notebook) { addTextEdits := []protocol.TextEdit{} + startOffset := -2 + if doc.LookBehind(pos, 2) != "[[" { + currentWord := doc.WordAt(pos) + startOffset = -2 - len(currentWord) + } + // Some LSP clients (e.g. VSCode) don't support deleting the trigger // characters with the main TextEdit. So let's add an additional // TextEdit for that. addTextEdits = append(addTextEdits, protocol.TextEdit{ NewText: "", - Range: rangeFromPosition(pos, -2, 0), + Range: rangeFromPosition(pos, startOffset, 0), }) item.AdditionalTextEdits = addTextEdits @@ -836,7 +848,12 @@ func (s *Server) newTextEditForLink(notebook *core.Notebook, note core.MinimalNo // Overwrite [[ trigger directly if the additional text edits are disabled. startOffset := 0 if !s.useAdditionalTextEditsWithNotebook(notebook) { - startOffset = -2 + if doc.LookBehind(pos, 2) == "[[" { + startOffset = -2 + } else { + currentWord := doc.WordAt(pos) + startOffset = -2 - len(currentWord) + } } // Some LSP clients (e.g. VSCode) auto-pair brackets, so we need to