fix: close nvim tree if it is the last buffer
This commit is contained in:
parent
5a0dd8ea39
commit
ffb7079a15
1 changed files with 24 additions and 6 deletions
|
@ -7,15 +7,13 @@ local function open_nvim_tree(data)
|
||||||
return
|
return
|
||||||
end
|
end
|
||||||
|
|
||||||
vim.notify(vim.loop.cwd())
|
|
||||||
|
|
||||||
-- buffer is a real file on the disk
|
-- buffer is a real file on the disk
|
||||||
local real_file = vim.fn.filereadable(data.file) == 1
|
local real_file = vim.fn.filereadable(data.file) == 1
|
||||||
|
|
||||||
-- buffer is a [No Name]
|
-- buffer is a [No Name]
|
||||||
local no_name = data.file == "" and vim.bo[data.buf].buftype == ""
|
--local no_name = data.file == "" and vim.bo[data.buf].buftype == ""
|
||||||
|
|
||||||
if not real_file and not no_name then
|
if not real_file then --and not no_name then
|
||||||
return
|
return
|
||||||
end
|
end
|
||||||
|
|
||||||
|
@ -27,11 +25,31 @@ local function open_nvim_tree(data)
|
||||||
end
|
end
|
||||||
|
|
||||||
-- open the tree, find the file but don't focus it
|
-- open the tree, find the file but don't focus it
|
||||||
api.tree.open({
|
api.tree.toggle({
|
||||||
focus = false,
|
focus = false,
|
||||||
find_file = true,
|
find_file = true,
|
||||||
path = vim.loop.cwd(),
|
path = vim.loop.cwd(),
|
||||||
})
|
})
|
||||||
end
|
end
|
||||||
|
|
||||||
vim.api.nvim_create_autocmd({ "BufAdd" }, { callback = open_nvim_tree })
|
vim.api.nvim_create_autocmd({ "BufEnter" }, { callback = open_nvim_tree })
|
||||||
|
|
||||||
|
-- From https://github.com/nvim-tree/nvim-tree.lua/issues/1368#issuecomment-1512248492
|
||||||
|
vim.api.nvim_create_autocmd("QuitPre", {
|
||||||
|
callback = function()
|
||||||
|
local invalid_win = {}
|
||||||
|
local wins = vim.api.nvim_list_wins()
|
||||||
|
for _, w in ipairs(wins) do
|
||||||
|
local bufname = vim.api.nvim_buf_get_name(vim.api.nvim_win_get_buf(w))
|
||||||
|
if bufname:match("NvimTree_") ~= nil then
|
||||||
|
table.insert(invalid_win, w)
|
||||||
|
end
|
||||||
|
end
|
||||||
|
if #invalid_win == #wins - 1 then
|
||||||
|
-- Should quit, so we close all invalid windows.
|
||||||
|
for _, w in ipairs(invalid_win) do
|
||||||
|
vim.api.nvim_win_close(w, true)
|
||||||
|
end
|
||||||
|
end
|
||||||
|
end,
|
||||||
|
})
|
||||||
|
|
Loading…
Add table
Reference in a new issue