mirror of
https://github.com/vim/vim.git
synced 2025-09-25 03:54:15 -04:00
patch 9.1.0019: cmdline may disappear when changing 'cmdheight'
Problem: cmdline may disappear when changing 'cmdheight' (after Patch 9.0.0190, @markonm) Solution: always re-calculate the old_p_ch value, not only when cmdline_row was higher than expected fixes: #13822 closes: #13826 Signed-off-by: Christian Brabandt <cb@256bit.org>
This commit is contained in:
@@ -3742,4 +3742,17 @@ func Test_custom_completion_with_glob()
|
|||||||
delfunc TestGlobComplete
|
delfunc TestGlobComplete
|
||||||
endfunc
|
endfunc
|
||||||
|
|
||||||
|
func Test_window_size_stays_same_after_changing_cmdheight()
|
||||||
|
set laststatus=2
|
||||||
|
let expected = winheight(0)
|
||||||
|
function! Function_name() abort
|
||||||
|
call feedkeys(":"..repeat('x', &columns), 'x')
|
||||||
|
let &cmdheight=2
|
||||||
|
let &cmdheight=1
|
||||||
|
redraw
|
||||||
|
endfunction
|
||||||
|
call Function_name()
|
||||||
|
call assert_equal(expected, winheight(0))
|
||||||
|
endfunc
|
||||||
|
|
||||||
" vim: shiftwidth=2 sts=2 expandtab
|
" vim: shiftwidth=2 sts=2 expandtab
|
||||||
|
@@ -704,6 +704,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 */
|
||||||
|
/**/
|
||||||
|
19,
|
||||||
/**/
|
/**/
|
||||||
18,
|
18,
|
||||||
/**/
|
/**/
|
||||||
|
@@ -7131,16 +7131,16 @@ command_height(void)
|
|||||||
|
|
||||||
// If the space for the command line is already more than 'cmdheight' there
|
// If the space for the command line is already more than 'cmdheight' there
|
||||||
// is nothing to do (window size must have decreased).
|
// is nothing to do (window size must have decreased).
|
||||||
|
// Note: this makes curtab->tp_ch_used unreliable
|
||||||
if (p_ch > old_p_ch && cmdline_row <= Rows - p_ch)
|
if (p_ch > old_p_ch && cmdline_row <= Rows - p_ch)
|
||||||
return;
|
return;
|
||||||
|
|
||||||
// Update cmdline_row to what it should be: just below the last window.
|
// Update cmdline_row to what it should be: just below the last window.
|
||||||
cmdline_row = topframe->fr_height + tabline_height();
|
cmdline_row = topframe->fr_height + tabline_height();
|
||||||
|
|
||||||
// If cmdline_row is smaller than what it is supposed to be for 'cmdheight'
|
// old_p_ch may be unreliable, because of the early return above, so
|
||||||
// then set old_p_ch to what it would be, so that the windows get resized
|
// set old_p_ch to what it would be, so that the windows get resized
|
||||||
// properly for the new value.
|
// properly for the new value.
|
||||||
if (cmdline_row < Rows - p_ch)
|
|
||||||
old_p_ch = Rows - cmdline_row;
|
old_p_ch = Rows - cmdline_row;
|
||||||
|
|
||||||
// Find bottom frame with width of screen.
|
// Find bottom frame with width of screen.
|
||||||
|
Reference in New Issue
Block a user