mirror of
https://github.com/neovim/neovim.git
synced 2025-02-25 18:55:25 -06:00
fix(lua): stop pending highlight.on_yank timer, if any (#18824)
When yanking another range while previous yank is still highlighted, the pending timer could clear the highlight almost immediately (especially when using larger `timeout`, i.e. 2000)
This commit is contained in:
parent
285f6518e6
commit
d5651a4183
@ -64,6 +64,7 @@ function M.range(bufnr, ns, higroup, start, finish, opts)
|
||||
end
|
||||
|
||||
local yank_ns = api.nvim_create_namespace('hlyank')
|
||||
local yank_timer
|
||||
--- Highlight the yanked region
|
||||
---
|
||||
--- use from init.vim via
|
||||
@ -113,6 +114,9 @@ function M.on_yank(opts)
|
||||
|
||||
local bufnr = api.nvim_get_current_buf()
|
||||
api.nvim_buf_clear_namespace(bufnr, yank_ns, 0, -1)
|
||||
if yank_timer then
|
||||
yank_timer:close()
|
||||
end
|
||||
|
||||
local pos1 = vim.fn.getpos("'[")
|
||||
local pos2 = vim.fn.getpos("']")
|
||||
@ -129,7 +133,8 @@ function M.on_yank(opts)
|
||||
{ regtype = event.regtype, inclusive = event.inclusive, priority = M.priorities.user }
|
||||
)
|
||||
|
||||
vim.defer_fn(function()
|
||||
yank_timer = vim.defer_fn(function()
|
||||
yank_timer = nil
|
||||
if api.nvim_buf_is_valid(bufnr) then
|
||||
api.nvim_buf_clear_namespace(bufnr, yank_ns, 0, -1)
|
||||
end
|
||||
|
Loading…
Reference in New Issue
Block a user