aboutsummaryrefslogtreecommitdiff
path: root/src
diff options
context:
space:
mode:
authorBjörn Linse <bjorn.linse@gmail.com>2019-08-10 17:27:29 +0200
committerBjörn Linse <bjorn.linse@gmail.com>2019-08-10 17:41:31 +0200
commit67664c74f8ab016e9c7aa3ede96dc66fcb4c9684 (patch)
treef1ec05b81d135a0ef5217508977159f4f51a802b /src
parent5f243fc68ad0ab9c3bdf484c8f2753ec9414bf37 (diff)
downloadrneovim-67664c74f8ab016e9c7aa3ede96dc66fcb4c9684.tar.gz
rneovim-67664c74f8ab016e9c7aa3ede96dc66fcb4c9684.tar.bz2
rneovim-67664c74f8ab016e9c7aa3ede96dc66fcb4c9684.zip
api/window: disallow closing non-current window in cmdwin state
Diffstat (limited to 'src')
-rw-r--r--src/nvim/api/window.c17
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);
}