diff options
author | zeertzjq <zeertzjq@outlook.com> | 2023-04-27 09:07:30 +0800 |
---|---|---|
committer | GitHub <noreply@github.com> | 2023-04-27 09:07:30 +0800 |
commit | 1fc468aed2809a92769fbdfd6c422c2b9b12a233 (patch) | |
tree | 1b25227fa25417e6152e71dc2f033da2cf18f4fd /src | |
parent | 3b0df1780e2c8526bda5dead18ee7cc45925caba (diff) | |
download | rneovim-1fc468aed2809a92769fbdfd6c422c2b9b12a233.tar.gz rneovim-1fc468aed2809a92769fbdfd6c422c2b9b12a233.tar.bz2 rneovim-1fc468aed2809a92769fbdfd6c422c2b9b12a233.zip |
vim-patch:9.0.1491: wrong scrolling with ls=0 and :botright split (#23333)
Problem: Wrong scrolling with ls=0 and :botright split.
Solution: Add statusline before calling frame_new_height(). (closes vim/vim#12299)
https://github.com/vim/vim/commit/fbf2071ac9ef08302a1df86c15f3d4ddbe871243
Diffstat (limited to 'src')
-rw-r--r-- | src/nvim/window.c | 28 |
1 files changed, 12 insertions, 16 deletions
diff --git a/src/nvim/window.c b/src/nvim/window.c index a45ceeb611..88d9b95208 100644 --- a/src/nvim/window.c +++ b/src/nvim/window.c @@ -1448,7 +1448,7 @@ int win_split_ins(int size, int flags, win_T *new_wp, int dir) frame_fix_width(oldwin); frame_fix_width(wp); } else { - bool is_stl_global = global_stl_height() > 0; + const bool is_stl_global = global_stl_height() > 0; // width and column of new window is same as current window if (flags & (WSP_TOP | WSP_BOT)) { wp->w_wincol = 0; @@ -1464,6 +1464,7 @@ int win_split_ins(int size, int flags, win_T *new_wp, int dir) // "new_size" of the current window goes to the new window, use // one row for the status line win_new_height(wp, new_size); + const int old_status_height = oldwin->w_status_height; if (before) { wp->w_hsep_height = is_stl_global ? 1 : 0; } else { @@ -1472,15 +1473,19 @@ int win_split_ins(int size, int flags, win_T *new_wp, int dir) } if (flags & (WSP_TOP | WSP_BOT)) { int new_fr_height = curfrp->fr_height - new_size; - - if (!((flags & WSP_BOT) && p_ls == 0) && !is_stl_global) { - new_fr_height -= STATUS_HEIGHT; - } else if (is_stl_global) { + if (is_stl_global) { if (flags & WSP_BOT) { frame_add_hsep(curfrp); } else { new_fr_height -= 1; } + } else { + if (!((flags & WSP_BOT) && p_ls == 0)) { + new_fr_height -= STATUS_HEIGHT; + } + if (flags & WSP_BOT) { + frame_add_statusline(curfrp); + } } frame_new_height(curfrp, new_fr_height, flags & WSP_TOP, false); } else { @@ -1489,7 +1494,6 @@ int win_split_ins(int size, int flags, win_T *new_wp, int dir) if (before) { // new window above current one wp->w_winrow = oldwin->w_winrow; - if (is_stl_global) { wp->w_status_height = 0; oldwin->w_winrow += wp->w_height + 1; @@ -1503,15 +1507,12 @@ int win_split_ins(int size, int flags, win_T *new_wp, int dir) wp->w_status_height = 0; } else { wp->w_winrow = oldwin->w_winrow + oldwin->w_height + STATUS_HEIGHT; - wp->w_status_height = oldwin->w_status_height; + wp->w_status_height = old_status_height; if (!(flags & WSP_BOT)) { oldwin->w_status_height = STATUS_HEIGHT; } } } - if ((flags & WSP_BOT) && !is_stl_global) { - frame_add_statusline(curfrp); - } frame_fix_height(wp); frame_fix_height(oldwin); } @@ -3590,12 +3591,7 @@ static void frame_add_statusline(frame_T *frp) { if (frp->fr_layout == FR_LEAF) { win_T *wp = frp->fr_win; - if (wp->w_status_height == 0) { - if (wp->w_height - STATUS_HEIGHT >= 0) { // don't make it negative - wp->w_height -= STATUS_HEIGHT; - } - wp->w_status_height = STATUS_HEIGHT; - } + wp->w_status_height = STATUS_HEIGHT; } else if (frp->fr_layout == FR_ROW) { // Handle all the frames in the row. FOR_ALL_FRAMES(frp, frp->fr_child) { |