diff options
author | Björn Linse <bjorn.linse@gmail.com> | 2019-08-10 17:27:29 +0200 |
---|---|---|
committer | Björn Linse <bjorn.linse@gmail.com> | 2019-08-10 17:41:31 +0200 |
commit | 67664c74f8ab016e9c7aa3ede96dc66fcb4c9684 (patch) | |
tree | f1ec05b81d135a0ef5217508977159f4f51a802b /src/nvim/api/window.c | |
parent | 5f243fc68ad0ab9c3bdf484c8f2753ec9414bf37 (diff) | |
download | rneovim-67664c74f8ab016e9c7aa3ede96dc66fcb4c9684.tar.gz rneovim-67664c74f8ab016e9c7aa3ede96dc66fcb4c9684.tar.bz2 rneovim-67664c74f8ab016e9c7aa3ede96dc66fcb4c9684.zip |
api/window: disallow closing non-current window in cmdwin state
Diffstat (limited to 'src/nvim/api/window.c')
-rw-r--r-- | src/nvim/api/window.c | 17 |
1 files changed, 11 insertions, 6 deletions
diff --git a/src/nvim/api/window.c b/src/nvim/api/window.c index 0103e17176..e279edebde 100644 --- a/src/nvim/api/window.c +++ b/src/nvim/api/window.c @@ -541,14 +541,19 @@ void nvim_win_close(Window window, Boolean force, Error *err) if (!win) { return; } - tabpage_T *tabpage = win_find_tabpage(win); + if (cmdwin_type != 0) { + if (win == curwin) { + cmdwin_result = Ctrl_C; + } else { + api_set_error(err, kErrorTypeException, "%s", _(e_cmdwin)); + } + return; + } + + tabpage_T *tabpage = win_find_tabpage(win); TryState tstate; try_enter(&tstate); - if (cmdwin_type != 0 && win == curwin) { - cmdwin_result = Ctrl_C; - } else { - ex_win_close(force, win, tabpage == curtab ? NULL : tabpage); - } + ex_win_close(force, win, tabpage == curtab ? NULL : tabpage); vim_ignored = try_leave(&tstate, err); } |