fix: stale lnum in buffer previewer (#1229)
* fix: lnum to jump to might be stale eg when resuming buffer picker after changes
This commit is contained in:
@@ -452,6 +452,7 @@ function make_entry.gen_from_buffer(opts)
|
||||
local readonly = vim.api.nvim_buf_get_option(entry.bufnr, "readonly") and "=" or " "
|
||||
local changed = entry.info.changed == 1 and "+" or " "
|
||||
local indicator = entry.flag .. hidden .. readonly .. changed
|
||||
local line_count = vim.api.nvim_buf_line_count(entry.bufnr)
|
||||
|
||||
return {
|
||||
valid = true,
|
||||
@@ -462,8 +463,8 @@ function make_entry.gen_from_buffer(opts)
|
||||
|
||||
bufnr = entry.bufnr,
|
||||
filename = bufname,
|
||||
|
||||
lnum = entry.info.lnum ~= 0 and entry.info.lnum or 1,
|
||||
-- account for potentially stale lnum as getbufinfo might not be updated or from resuming buffers picker
|
||||
lnum = entry.info.lnum ~= 0 and math.max(math.min(entry.info.lnum, line_count), 1) or 1,
|
||||
indicator = indicator,
|
||||
}
|
||||
end
|
||||
|
||||
@@ -956,12 +956,13 @@ end, {})
|
||||
previewers.buffers = defaulter(function(opts)
|
||||
opts = opts or {}
|
||||
local cwd = opts.cwd or vim.loop.cwd()
|
||||
local previewer_active = true -- decouple provider from preview_win
|
||||
local previewer_active -- decouple provider from preview_win
|
||||
return Previewer:new {
|
||||
title = function()
|
||||
return "Buffers"
|
||||
end,
|
||||
setup = function(_, status)
|
||||
previewer_active = true
|
||||
local win_id = status.picker.original_win_id
|
||||
-- required because of see `:h local-options` as
|
||||
-- buffers not yet attached to a current window take the options from the `minimal` popup ...
|
||||
@@ -1030,16 +1031,20 @@ previewers.buffers = defaulter(function(opts)
|
||||
preview_fn = function(self, entry, status)
|
||||
if vim.api.nvim_buf_is_valid(entry.bufnr) then
|
||||
vim.api.nvim_win_set_buf(status.preview_win, entry.bufnr)
|
||||
self.state.bufnr = entry.bufnr
|
||||
vim.api.nvim_win_set_option(status.preview_win, "winhl", "Normal:TelescopePreviewNormal")
|
||||
vim.api.nvim_win_set_option(status.preview_win, "signcolumn", "no")
|
||||
vim.api.nvim_win_set_option(status.preview_win, "foldlevel", 100)
|
||||
vim.api.nvim_win_set_option(status.preview_win, "wrap", false)
|
||||
self.state.bufnr = entry.bufnr
|
||||
|
||||
if self.state.previewed_buffers[entry.bufnr] ~= true then
|
||||
if entry.lnum then
|
||||
local lnum, col = unpack(vim.api.nvim_win_get_cursor(status.preview_win))
|
||||
entry.lnum = lnum
|
||||
if not entry.col then
|
||||
local _, col = unpack(vim.api.nvim_win_get_cursor(status.preview_win))
|
||||
entry.col = col + 1
|
||||
end
|
||||
if self.state.previewed_buffers[entry.bufnr] ~= true then
|
||||
end
|
||||
self.state.previewed_buffers[entry.bufnr] = true
|
||||
end
|
||||
end
|
||||
|
||||
Reference in New Issue
Block a user