diff options
author | Bram Moolenaar <Bram@vim.org> | 2022-11-19 11:41:30 +0000 |
---|---|---|
committer | Bram Moolenaar <Bram@vim.org> | 2022-11-19 11:41:30 +0000 |
commit | d63a85592cef0ee4f0fec5efe2f8d66b31f01f05 (patch) | |
tree | 0b1f1312b6d54ccd334f1931f62399640c42aaa9 /src/ex_docmd.c | |
parent | ff95ce0930e6db0037fe8d1fc875a6522b054582 (diff) |
patch 9.0.0907: restoring window after WinScrolled may failv9.0.0907
Problem: Restoring window after WinScrolled may fail.
Solution: Lock the window layout when triggering WinScrolled.
Diffstat (limited to 'src/ex_docmd.c')
-rw-r--r-- | src/ex_docmd.c | 18 |
1 files changed, 13 insertions, 5 deletions
diff --git a/src/ex_docmd.c b/src/ex_docmd.c index d5037a4561..ac4012725b 100644 --- a/src/ex_docmd.c +++ b/src/ex_docmd.c @@ -6055,6 +6055,8 @@ ex_win_close( emsg(_(e_cannot_close_autocmd_or_popup_window)); return; } + if (window_layout_locked()) + return; need_hide = (bufIsChanged(buf) && buf->b_nwindows <= 1); if (need_hide && !buf_hide(buf) && !forceit) @@ -6227,7 +6229,7 @@ ex_tabclose(exarg_T *eap) cmdwin_result = K_IGNORE; else if (first_tabpage->tp_next == NULL) emsg(_(e_cannot_close_last_tab_page)); - else + else if (!window_layout_locked()) { tab_number = get_tabpage_arg(eap); if (eap->errmsg == NULL) @@ -6263,7 +6265,7 @@ ex_tabonly(exarg_T *eap) cmdwin_result = K_IGNORE; else if (first_tabpage->tp_next == NULL) msg(_("Already only one tab page")); - else + else if (!window_layout_locked()) { tab_number = get_tabpage_arg(eap); if (eap->errmsg == NULL) @@ -6296,6 +6298,9 @@ ex_tabonly(exarg_T *eap) void tabpage_close(int forceit) { + if (window_layout_locked()) + return; + // First close all the windows but the current one. If that worked then // close the last window in this tab, that will close it. if (!ONE_WINDOW) @@ -6341,14 +6346,15 @@ tabpage_close_other(tabpage_T *tp, int forceit) static void ex_only(exarg_T *eap) { - win_T *wp; - int wnr; + if (window_layout_locked()) + return; # ifdef FEAT_GUI need_mouse_correct = TRUE; # endif if (eap->addr_count > 0) { - wnr = eap->line2; + win_T *wp; + int wnr = eap->line2; for (wp = firstwin; --wnr > 0; ) { if (wp->w_next == NULL) @@ -6367,6 +6373,8 @@ ex_hide(exarg_T *eap UNUSED) // ":hide" or ":hide | cmd": hide current window if (!eap->skip) { + if (window_layout_locked()) + return; #ifdef FEAT_GUI need_mouse_correct = TRUE; #endif |