Skip to content

Commit

Permalink
fix(ghost_text): ensure multiline indent is correct
Browse files Browse the repository at this point in the history
  • Loading branch information
xzbdmw committed Jan 7, 2025
1 parent 47efef8 commit 80fd925
Show file tree
Hide file tree
Showing 2 changed files with 37 additions and 1 deletion.
3 changes: 2 additions & 1 deletion lua/blink/cmp/completion/windows/ghost_text.lua
Original file line number Diff line number Diff line change
Expand Up @@ -71,7 +71,8 @@ function ghost_text.draw_preview(bufnr)

if ghost_text.selected_item.insertTextFormat == vim.lsp.protocol.InsertTextFormat.Snippet then
local expanded_snippet = snippets_utils.safe_parse(text_edit.newText)
text_edit.newText = expanded_snippet and tostring(expanded_snippet) or text_edit.newText
text_edit.newText = expanded_snippet and snippets_utils.append_to_snippet(tostring(expanded_snippet))
or text_edit.newText
end

local display_lines = vim.split(get_still_untyped_text(text_edit), '\n', { plain = true }) or {}
Expand Down
35 changes: 35 additions & 0 deletions lua/blink/cmp/sources/snippets/utils.lua
Original file line number Diff line number Diff line change
Expand Up @@ -65,6 +65,41 @@ function utils.read_snippet(snippet, fallback)
return snippets
end

local function text_to_lines(text)
text = type(text) == 'string' and { text } or text
--- @cast text string[]
return vim.split(table.concat(text), '\n', { plain = true })
end

-- - Appends the given text to the snippet, taking care of indentation.
-- -
-- - @param text string|string[]
function utils.append_to_snippet(text)
local base_indent = vim.api.nvim_get_current_line():match('^%s*') or ''
local snippet_lines = text_to_lines(text)
-- Get the base indentation based on the current line and the last line of the snippet.
if #snippet_lines > 0 then
base_indent = base_indent .. (snippet_lines[#snippet_lines]:match('(^%s+)%S') or '') --- @type string
end

local shiftwidth = vim.fn.shiftwidth()
local curbuf = vim.api.nvim_get_current_buf()
local expandtab = vim.bo[curbuf].expandtab

local lines = {} --- @type string[]
for i, line in ipairs(text_to_lines(text)) do
-- Replace tabs by spaces.
if expandtab then
line = line:gsub('\t', (' '):rep(shiftwidth)) --- @type string
end
-- Add the base indentation.
if i > 1 then line = base_indent .. line end
lines[#lines + 1] = line
end

return table.concat(lines, '\n')
end

function utils.get_tab_stops(snippet)
local expanded_snippet = require('blink.cmp.sources.snippets.utils').safe_parse(snippet)
if not expanded_snippet then return end
Expand Down

0 comments on commit 80fd925

Please sign in to comment.