From 448ff1e7c64bba3e9f74448a9380f6580406909a Mon Sep 17 00:00:00 2001 From: luozhiya Date: Sun, 28 Jul 2024 18:12:10 +0800 Subject: [PATCH] Support multi-line virtual text preview --- README.md | 3 ++- lua/fittencode/sources/cmp/source.lua | 30 ++++++++++----------------- 2 files changed, 13 insertions(+), 20 deletions(-) diff --git a/README.md b/README.md index f030422f..b0c679f9 100644 --- a/README.md +++ b/README.md @@ -237,7 +237,8 @@ require('fittencode').setup({ require('cmp').setup({ sources = { name = 'fittencode', group_index = 1 }, mapping = { - [''] = cmp.mapping.confirm({ behavior = cmp.ConfirmBehavior.Insert, select = false }), + -- Accept multi-line completion + [''] = cmp.mapping.confirm({ behavior = cmp.ConfirmBehavior.Insert, select = false }), } }) ``` diff --git a/lua/fittencode/sources/cmp/source.lua b/lua/fittencode/sources/cmp/source.lua index c1ef36a0..8b833cf1 100644 --- a/lua/fittencode/sources/cmp/source.lua +++ b/lua/fittencode/sources/cmp/source.lua @@ -60,32 +60,23 @@ end -- Use `get_word` so that the word is the same as in `core.confirm` -- https://github.com/hrsh7th/nvim-cmp/pull/1860 ----@param suggestions string +-- https://github.com/hrsh7th/nvim-cmp/pull/2002 +---@param suggestions string[] ---@return lsp.CompletionResponse? local function convert_to_lsp_completion_response(line, character, cursor_before_line, suggestions) cursor_before_line = cursor_before_line or '' local LABEL_LIMIT = 80 - local label = cursor_before_line .. suggestions - if #label > LABEL_LIMIT then - label = string.sub(label, 1, LABEL_LIMIT) - end - label = label:gsub('\n', '<\\n>') + local text = cursor_before_line .. table.concat(suggestions, '\n') + local first = suggestions[1] + local label = (#first > LABEL_LIMIT or #suggestions > 1) and string.sub(first, 1, LABEL_LIMIT - 3) .. '...' or first local items = {} table.insert(items, { - label = label, - word = label, - textEdit = { - range = { - start = { line = line, character = character }, - ['end'] = { line = line, character = character }, - }, - newText = suggestions, - }, + label = cursor_before_line .. label, + insertText = text, documentation = { kind = 'markdown', - value = '```' .. vim.bo.ft .. '\n' .. cursor_before_line .. suggestions .. '\n```', + value = '```' .. vim.bo.ft .. '\n' .. text .. '\n```', }, - insertTextMode = 1, cmp = { kind_hl_group = 'CmpItemKindFittenCode', kind_text = 'FittenCode', @@ -105,11 +96,12 @@ function source:complete(request, callback) return end Engine.generate_one_stage(row, col, true, 0, function(suggestions) - if not suggestions then + -- We skip the suggestion where the first element is empty, as nvim-cmp trim the completion item + -- Ref: `lazy/nvim-cmp/lua/cmp/entry.lua` + if not suggestions or #suggestions == 0 or suggestions[1] == '' then callback() return end - suggestions = table.concat(suggestions, '\n') local cursor_before_line = request.context.cursor_before_line:sub(request.offset) local line = request.context.cursor.line local character = request.context.cursor.character