fix(#2126): custom window pickers may create windows (#2140)

call nvim_list_wins again after the picker is run
This commit is contained in:
Anshuman Medhi 2023-04-16 13:58:10 +08:00 committed by GitHub
parent a8a4834e1a
commit 8f392fa763
No known key found for this signature in database
GPG Key ID: 4AEE18F83AFDEB23
2 changed files with 9 additions and 9 deletions

View File

@ -1121,6 +1121,7 @@ Configuration for various actions.
Change the default window picker, can be a string `"default"` or a function.
The function should return the window id that will open the node,
or `nil` if an invalid window is picked or user cancelled the action.
The picker may create a new window.
Type: `string` | `function`, Default: `"default"`
e.g. s1n7ax/nvim-window-picker plugin: >
window_picker = {

View File

@ -164,13 +164,13 @@ local function on_preview(buf_loaded)
view.focus()
end
local function get_target_winid(mode, win_ids)
local function get_target_winid(mode)
local target_winid
if not M.window_picker.enable or mode == "edit_no_picker" then
target_winid = lib.target_winid
-- first available window
if not vim.tbl_contains(win_ids, target_winid) then
if not vim.tbl_contains(vim.api.nvim_tabpage_list_wins(0), target_winid) then
target_winid = first_win_id()
end
else
@ -201,20 +201,21 @@ local function set_current_win_no_autocmd(winid, autocmd)
vim.opt.eventignore = eventignore
end
local function open_in_new_window(filename, mode, win_ids)
local function open_in_new_window(filename, mode)
if type(mode) ~= "string" then
mode = ""
end
local target_winid = get_target_winid(mode, win_ids)
local target_winid = get_target_winid(mode)
if not target_winid then
return
end
local create_new_window = #vim.api.nvim_list_wins() == 1
local win_ids = vim.api.nvim_list_wins()
local create_new_window = #win_ids == 1 -- This implies that the nvim-tree window is the only one
local new_window_side = (view.View.side == "right") and "aboveleft" or "belowright"
-- Target is invalid or window does not exist in current tabpage: create new window
-- Target is invalid: create new window
if not vim.tbl_contains(win_ids, target_winid) then
vim.cmd(new_window_side .. " vsplit")
target_winid = vim.api.nvim_get_current_win()
@ -287,8 +288,6 @@ function M.fn(mode, filename)
return edit_in_current_buf(filename)
end
local tabpage = vim.api.nvim_get_current_tabpage()
local win_ids = vim.api.nvim_tabpage_list_wins(tabpage)
local buf_loaded = is_already_loaded(filename)
local found_win = utils.get_win_buf_from_path(filename)
@ -297,7 +296,7 @@ function M.fn(mode, filename)
end
if not found_win then
open_in_new_window(filename, mode, win_ids)
open_in_new_window(filename, mode)
else
vim.api.nvim_set_current_win(found_win)
vim.bo.bufhidden = ""