mirror of
https://github.com/neovim/neovim.git
synced 2025-09-07 03:48:18 +00:00
fix(diagnostic): clear stale cache on reset (#21454)
The BufWipeout autocmd is not 100% reliable and may leave stale entries in the cache. This is sort of a hack/workaround to ensure `vim.diagnostic.reset` calls don't fail if there are stale cache entries but instead clears them Fixes errors like Error executing vim.schedule lua callback: /usr/share/nvim/runtime/lua/vim/diagnostic.lua:1458: Invalid buffer id: 22 stack traceback: [C]: in function 'nvim_exec_autocmds' /usr/share/nvim/runtime/lua/vim/diagnostic.lua:1458: in function 'reset'
This commit is contained in:

committed by
GitHub

parent
1c4794944d
commit
1743359235
@@ -160,6 +160,24 @@ describe('vim.diagnostic', function()
|
||||
]])
|
||||
end)
|
||||
|
||||
it('removes diagnostic from stale cache on reset', function()
|
||||
local diagnostics = exec_lua [[
|
||||
vim.diagnostic.set(diagnostic_ns, diagnostic_bufnr, {
|
||||
make_error('Diagnostic #1', 1, 1, 1, 1),
|
||||
make_error('Diagnostic #2', 2, 1, 2, 1),
|
||||
})
|
||||
local other_bufnr = vim.fn.bufadd('test | test')
|
||||
vim.cmd('noautocmd bwipeout! ' .. diagnostic_bufnr)
|
||||
return vim.diagnostic.get(diagnostic_bufnr)
|
||||
]]
|
||||
eq(2, #diagnostics)
|
||||
diagnostics = exec_lua [[
|
||||
vim.diagnostic.reset()
|
||||
return vim.diagnostic.get()
|
||||
]]
|
||||
eq(0, #diagnostics)
|
||||
end)
|
||||
|
||||
it('resolves buffer number 0 to the current buffer', function()
|
||||
eq(2, exec_lua [[
|
||||
vim.api.nvim_set_current_buf(diagnostic_bufnr)
|
||||
|
Reference in New Issue
Block a user