From 82ab19ebf79c1839d7351f2fed213d1af13a598e Mon Sep 17 00:00:00 2001 From: des-b <66919647+des-b@users.noreply.github.com> Date: Sat, 2 Nov 2024 02:07:42 +0100 Subject: [PATCH] fix(#2954): resolve occasional tree flashing on diagnostics, set tree buffer options in deterministic order (#2980) * fix(#2954): set buffer options in deterministic order This ensures related autocmd's (e.g. on FileType) will be called in a similar environment. * fix(#2954): redraw only for diagnostics if source buffer is 'buflisted' is_buf_valid has been inlined since it is only used for diagnostics and its name is misleading. --- lua/nvim-tree/diagnostics.lua | 8 +++++++- lua/nvim-tree/view.lua | 25 +++++++++++-------------- 2 files changed, 18 insertions(+), 15 deletions(-) diff --git a/lua/nvim-tree/diagnostics.lua b/lua/nvim-tree/diagnostics.lua index 05845ba274b..87d9edb26f5 100644 --- a/lua/nvim-tree/diagnostics.lua +++ b/lua/nvim-tree/diagnostics.lua @@ -165,7 +165,13 @@ function M.update() end end log.profile_end(profile) - if view.is_buf_valid(view.get_bufnr()) then + + local bufnr = view.get_bufnr() + local should_draw = bufnr + and vim.api.nvim_buf_is_valid(bufnr) + and vim.api.nvim_buf_is_loaded(bufnr) + and vim.api.nvim_get_option_value("buflisted", { buf = bufnr }) + if should_draw then local explorer = core.get_explorer() if explorer then explorer.renderer:draw() diff --git a/lua/nvim-tree/view.lua b/lua/nvim-tree/view.lua index a39df75a684..408584d1bbc 100644 --- a/lua/nvim-tree/view.lua +++ b/lua/nvim-tree/view.lua @@ -65,13 +65,15 @@ local tabinitial = { } local BUFNR_PER_TAB = {} + +---@type { name: string, value: any }[] local BUFFER_OPTIONS = { - swapfile = false, - buftype = "nofile", - modifiable = false, - filetype = "NvimTree", - bufhidden = "wipe", - buflisted = false, + { name = "bufhidden", value = "wipe" }, + { name = "buflisted", value = false }, + { name = "buftype", value = "nofile" }, + { name = "filetype", value = "NvimTree" }, + { name = "modifiable", value = false }, + { name = "swapfile", value = false }, } ---@param bufnr integer @@ -101,8 +103,9 @@ local function create_buffer(bufnr) BUFNR_PER_TAB[tab] = bufnr or vim.api.nvim_create_buf(false, false) vim.api.nvim_buf_set_name(M.get_bufnr(), "NvimTree_" .. tab) - for option, value in pairs(BUFFER_OPTIONS) do - vim.bo[M.get_bufnr()][option] = value + bufnr = M.get_bufnr() + for _, option in ipairs(BUFFER_OPTIONS) do + vim.api.nvim_set_option_value(option.name, option.value, { buf = bufnr }) end require("nvim-tree.keymap").on_attach(M.get_bufnr()) @@ -497,12 +500,6 @@ function M.get_bufnr() return BUFNR_PER_TAB[vim.api.nvim_get_current_tabpage()] end ----@param bufnr number ----@return boolean -function M.is_buf_valid(bufnr) - return bufnr and vim.api.nvim_buf_is_valid(bufnr) and vim.api.nvim_buf_is_loaded(bufnr) -end - function M._prevent_buffer_override() local view_winnr = M.get_winnr() local view_bufnr = M.get_bufnr()