mirror of
https://github.com/vim/vim.git
synced 2025-09-27 04:14:06 -04:00
patch 7.4.1835
Problem: When splitting and closing a window the status height changes. Solution: Compute the frame height correctly. (Hirohito Higashi)
This commit is contained in:
@@ -32,3 +32,4 @@ source test_tagjump.vim
|
|||||||
source test_timers.vim
|
source test_timers.vim
|
||||||
source test_undolevels.vim
|
source test_undolevels.vim
|
||||||
source test_unlet.vim
|
source test_unlet.vim
|
||||||
|
source test_window_cmd.vim
|
||||||
|
37
src/testdir/test_window_cmd.vim
Normal file
37
src/testdir/test_window_cmd.vim
Normal file
@@ -0,0 +1,37 @@
|
|||||||
|
" Tests for window cmd (:wincmd, :split, :vsplit, :resize and etc...)
|
||||||
|
|
||||||
|
func Test_window_cmd_ls0_with_split()
|
||||||
|
set ls=0
|
||||||
|
set splitbelow
|
||||||
|
split
|
||||||
|
quit
|
||||||
|
call assert_equal(0, &lines - &cmdheight - winheight(0))
|
||||||
|
new | only!
|
||||||
|
"
|
||||||
|
set splitbelow&vim
|
||||||
|
botright split
|
||||||
|
quit
|
||||||
|
call assert_equal(0, &lines - &cmdheight - winheight(0))
|
||||||
|
new | only!
|
||||||
|
set ls&vim
|
||||||
|
endfunc
|
||||||
|
|
||||||
|
func Test_window_cmd_cmdwin_with_vsp()
|
||||||
|
let efmt='Expected 0 but got %d (in ls=%d, %s window)'
|
||||||
|
for v in range(0, 2)
|
||||||
|
exec "set ls=" . v
|
||||||
|
vsplit
|
||||||
|
call feedkeys("q:\<CR>")
|
||||||
|
let ac = &lines - (&cmdheight + winheight(0) + !!v)
|
||||||
|
let emsg = printf(efmt, ac, v, 'left')
|
||||||
|
call assert_equal(0, ac, emsg)
|
||||||
|
wincmd w
|
||||||
|
let ac = &lines - (&cmdheight + winheight(0) + !!v)
|
||||||
|
let emsg = printf(efmt, ac, v, 'right')
|
||||||
|
call assert_equal(0, ac, emsg)
|
||||||
|
new | only!
|
||||||
|
endfor
|
||||||
|
set ls&vim
|
||||||
|
endfunc
|
||||||
|
|
||||||
|
" vim: sw=2 et
|
@@ -753,6 +753,8 @@ static char *(features[]) =
|
|||||||
|
|
||||||
static int included_patches[] =
|
static int included_patches[] =
|
||||||
{ /* Add new patch number below this line */
|
{ /* Add new patch number below this line */
|
||||||
|
/**/
|
||||||
|
1835,
|
||||||
/**/
|
/**/
|
||||||
1834,
|
1834,
|
||||||
/**/
|
/**/
|
||||||
|
18
src/window.c
18
src/window.c
@@ -1165,8 +1165,13 @@ win_split_ins(
|
|||||||
* one row for the status line */
|
* one row for the status line */
|
||||||
win_new_height(wp, new_size);
|
win_new_height(wp, new_size);
|
||||||
if (flags & (WSP_TOP | WSP_BOT))
|
if (flags & (WSP_TOP | WSP_BOT))
|
||||||
frame_new_height(curfrp, curfrp->fr_height
|
{
|
||||||
- (new_size + STATUS_HEIGHT), flags & WSP_TOP, FALSE);
|
int new_fr_height = curfrp->fr_height - new_size;
|
||||||
|
|
||||||
|
if (!((flags & WSP_BOT) && p_ls == 0))
|
||||||
|
new_fr_height -= STATUS_HEIGHT;
|
||||||
|
frame_new_height(curfrp, new_fr_height, flags & WSP_TOP, FALSE);
|
||||||
|
}
|
||||||
else
|
else
|
||||||
win_new_height(oldwin, oldwin_height - (new_size + STATUS_HEIGHT));
|
win_new_height(oldwin, oldwin_height - (new_size + STATUS_HEIGHT));
|
||||||
if (before) /* new window above current one */
|
if (before) /* new window above current one */
|
||||||
@@ -1179,18 +1184,13 @@ win_split_ins(
|
|||||||
{
|
{
|
||||||
wp->w_winrow = oldwin->w_winrow + oldwin->w_height + STATUS_HEIGHT;
|
wp->w_winrow = oldwin->w_winrow + oldwin->w_height + STATUS_HEIGHT;
|
||||||
wp->w_status_height = oldwin->w_status_height;
|
wp->w_status_height = oldwin->w_status_height;
|
||||||
/* Don't set the status_height for oldwin yet, this might break
|
if (!(flags & WSP_BOT))
|
||||||
* frame_fix_height(oldwin), therefore will be set below. */
|
oldwin->w_status_height = STATUS_HEIGHT;
|
||||||
}
|
}
|
||||||
if (flags & WSP_BOT)
|
if (flags & WSP_BOT)
|
||||||
frame_add_statusline(curfrp);
|
frame_add_statusline(curfrp);
|
||||||
frame_fix_height(wp);
|
frame_fix_height(wp);
|
||||||
frame_fix_height(oldwin);
|
frame_fix_height(oldwin);
|
||||||
|
|
||||||
if (!before)
|
|
||||||
/* new window above current one, set the status_height after
|
|
||||||
* frame_fix_height(oldwin) */
|
|
||||||
oldwin->w_status_height = STATUS_HEIGHT;
|
|
||||||
}
|
}
|
||||||
|
|
||||||
if (flags & (WSP_TOP | WSP_BOT))
|
if (flags & (WSP_TOP | WSP_BOT))
|
||||||
|
Reference in New Issue
Block a user