mirror of
https://github.com/vim/vim.git
synced 2025-09-23 03:43:49 -04:00
patch 9.0.0190: the way 'cmdheight' can be made zero is inconsistent
Problem: The way 'cmdheight' can be made zero is inconsistent. Solution: Only make 'cmdheight' zero when setting it explicitly, not when resizing windows. (closes #10890)
This commit is contained in:
8
src/testdir/dumps/Test_changing_cmdheight_1.dump
Normal file
8
src/testdir/dumps/Test_changing_cmdheight_1.dump
Normal file
@@ -0,0 +1,8 @@
|
|||||||
|
> +0&#ffffff0@74
|
||||||
|
|~+0#4040ff13&| @73
|
||||||
|
|~| @73
|
||||||
|
|[+3#0000000&|N|o| |N|a|m|e|]| @47|0|,|0|-|1| @9|A|l@1
|
||||||
|
| +0&&@74
|
||||||
|
@75
|
||||||
|
@75
|
||||||
|
|:|r|e|s|i|z|e| |-|3| @64
|
8
src/testdir/dumps/Test_changing_cmdheight_2.dump
Normal file
8
src/testdir/dumps/Test_changing_cmdheight_2.dump
Normal file
@@ -0,0 +1,8 @@
|
|||||||
|
> +0&#ffffff0@74
|
||||||
|
|~+0#4040ff13&| @73
|
||||||
|
|~| @73
|
||||||
|
|[+3#0000000&|N|o| |N|a|m|e|]| @47|0|,|0|-|1| @9|A|l@1
|
||||||
|
|:+0&&|s|e|t| |c|m|d|h|e|i|g|h|t|+|=|3| @57
|
||||||
|
@75
|
||||||
|
@75
|
||||||
|
@75
|
8
src/testdir/dumps/Test_changing_cmdheight_3.dump
Normal file
8
src/testdir/dumps/Test_changing_cmdheight_3.dump
Normal file
@@ -0,0 +1,8 @@
|
|||||||
|
> +0&#ffffff0@74
|
||||||
|
|~+0#4040ff13&| @73
|
||||||
|
|[+3#0000000&|N|o| |N|a|m|e|]| @47|0|,|0|-|1| @9|A|l@1
|
||||||
|
| +0&&@74
|
||||||
|
@75
|
||||||
|
@75
|
||||||
|
@75
|
||||||
|
@75
|
8
src/testdir/dumps/Test_changing_cmdheight_4.dump
Normal file
8
src/testdir/dumps/Test_changing_cmdheight_4.dump
Normal file
@@ -0,0 +1,8 @@
|
|||||||
|
> +0&#ffffff0@74
|
||||||
|
|~+0#4040ff13&| @73
|
||||||
|
|~| @73
|
||||||
|
|~| @73
|
||||||
|
|[+3#0000000&|N|o| |N|a|m|e|]| @47|0|,|0|-|1| @9|A|l@1
|
||||||
|
| +0&&@74
|
||||||
|
@75
|
||||||
|
@75
|
@@ -215,6 +215,35 @@ func Test_redraw_in_autocmd()
|
|||||||
call delete('XTest_redraw')
|
call delete('XTest_redraw')
|
||||||
endfunc
|
endfunc
|
||||||
|
|
||||||
|
func Test_changing_cmdheight()
|
||||||
|
CheckScreendump
|
||||||
|
|
||||||
|
let lines =<< trim END
|
||||||
|
set cmdheight=1 laststatus=2
|
||||||
|
END
|
||||||
|
call writefile(lines, 'XTest_cmdheight')
|
||||||
|
|
||||||
|
let buf = RunVimInTerminal('-S XTest_cmdheight', {'rows': 8})
|
||||||
|
call term_sendkeys(buf, ":resize -3\<CR>")
|
||||||
|
call VerifyScreenDump(buf, 'Test_changing_cmdheight_1', {})
|
||||||
|
|
||||||
|
" using the space available doesn't change the status line
|
||||||
|
call term_sendkeys(buf, ":set cmdheight+=3\<CR>")
|
||||||
|
call VerifyScreenDump(buf, 'Test_changing_cmdheight_2', {})
|
||||||
|
|
||||||
|
" using more space moves the status line up
|
||||||
|
call term_sendkeys(buf, ":set cmdheight+=1\<CR>")
|
||||||
|
call VerifyScreenDump(buf, 'Test_changing_cmdheight_3', {})
|
||||||
|
|
||||||
|
" reducing cmdheight moves status line down
|
||||||
|
call term_sendkeys(buf, ":set cmdheight-=2\<CR>")
|
||||||
|
call VerifyScreenDump(buf, 'Test_changing_cmdheight_4', {})
|
||||||
|
|
||||||
|
" clean up
|
||||||
|
call StopVimInTerminal(buf)
|
||||||
|
call delete('XTest_cmdheight')
|
||||||
|
endfunc
|
||||||
|
|
||||||
func Test_map_completion()
|
func Test_map_completion()
|
||||||
call feedkeys(":map <unique> <si\<Tab>\<Home>\"\<CR>", 'xt')
|
call feedkeys(":map <unique> <si\<Tab>\<Home>\"\<CR>", 'xt')
|
||||||
call assert_equal('"map <unique> <silent>', getreg(':'))
|
call assert_equal('"map <unique> <silent>', getreg(':'))
|
||||||
|
@@ -735,6 +735,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 */
|
||||||
|
/**/
|
||||||
|
190,
|
||||||
/**/
|
/**/
|
||||||
189,
|
189,
|
||||||
/**/
|
/**/
|
||||||
|
17
src/window.c
17
src/window.c
@@ -5702,7 +5702,7 @@ frame_setheight(frame_T *curfrp, int height)
|
|||||||
|
|
||||||
if (curfrp->fr_parent == NULL)
|
if (curfrp->fr_parent == NULL)
|
||||||
{
|
{
|
||||||
// topframe: can only change the command line
|
// topframe: can only change the command line height
|
||||||
if (height > ROWS_AVAIL)
|
if (height > ROWS_AVAIL)
|
||||||
// If height is greater than the available space, try to create
|
// If height is greater than the available space, try to create
|
||||||
// space for the frame by reducing 'cmdheight' if possible, while
|
// space for the frame by reducing 'cmdheight' if possible, while
|
||||||
@@ -6089,6 +6089,12 @@ win_drag_status_line(win_T *dragwin, int offset)
|
|||||||
int row;
|
int row;
|
||||||
int up; // if TRUE, drag status line up, otherwise down
|
int up; // if TRUE, drag status line up, otherwise down
|
||||||
int n;
|
int n;
|
||||||
|
static int p_ch_was_zero = FALSE;
|
||||||
|
|
||||||
|
// If the user explicitly set 'cmdheight' to zero, then allow for dragging
|
||||||
|
// the status line making it zero again.
|
||||||
|
if (p_ch == 0)
|
||||||
|
p_ch_was_zero = TRUE;
|
||||||
|
|
||||||
fr = dragwin->w_frame;
|
fr = dragwin->w_frame;
|
||||||
curfr = fr;
|
curfr = fr;
|
||||||
@@ -6147,6 +6153,8 @@ win_drag_status_line(win_T *dragwin, int offset)
|
|||||||
room = Rows - cmdline_row;
|
room = Rows - cmdline_row;
|
||||||
if (curfr->fr_next != NULL)
|
if (curfr->fr_next != NULL)
|
||||||
room -= p_ch;
|
room -= p_ch;
|
||||||
|
else if (!p_ch_was_zero)
|
||||||
|
--room;
|
||||||
if (room < 0)
|
if (room < 0)
|
||||||
room = 0;
|
room = 0;
|
||||||
// sum up the room of frames below of the current one
|
// sum up the room of frames below of the current one
|
||||||
@@ -6196,7 +6204,7 @@ win_drag_status_line(win_T *dragwin, int offset)
|
|||||||
row = win_comp_pos();
|
row = win_comp_pos();
|
||||||
screen_fill(row, cmdline_row, 0, (int)Columns, ' ', ' ', 0);
|
screen_fill(row, cmdline_row, 0, (int)Columns, ' ', ' ', 0);
|
||||||
cmdline_row = row;
|
cmdline_row = row;
|
||||||
p_ch = MAX(Rows - cmdline_row, 0);
|
p_ch = MAX(Rows - cmdline_row, p_ch_was_zero ? 0 : 1);
|
||||||
curtab->tp_ch_used = p_ch;
|
curtab->tp_ch_used = p_ch;
|
||||||
redraw_all_later(SOME_VALID);
|
redraw_all_later(SOME_VALID);
|
||||||
showmode();
|
showmode();
|
||||||
@@ -6542,6 +6550,11 @@ command_height(void)
|
|||||||
// p_ch was changed in another tab page.
|
// p_ch was changed in another tab page.
|
||||||
curtab->tp_ch_used = p_ch;
|
curtab->tp_ch_used = p_ch;
|
||||||
|
|
||||||
|
// If the space for the command line is already more than 'cmdheight' there
|
||||||
|
// is nothing to do (window size must have decreased).
|
||||||
|
if (p_ch > old_p_ch && cmdline_row <= Rows - p_ch)
|
||||||
|
return;
|
||||||
|
|
||||||
// Find bottom frame with width of screen.
|
// Find bottom frame with width of screen.
|
||||||
frp = lastwin->w_frame;
|
frp = lastwin->w_frame;
|
||||||
while (frp->fr_width != Columns && frp->fr_parent != NULL)
|
while (frp->fr_width != Columns && frp->fr_parent != NULL)
|
||||||
|
Reference in New Issue
Block a user