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 | ||||
| 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 | ||||
|  | ||||
| @ -704,6 +704,8 @@ static char *(features[]) = | ||||
|  | ||||
| static int included_patches[] = | ||||
| {   /* Add new patch number below this line */ | ||||
| /**/ | ||||
|     19, | ||||
| /**/ | ||||
|     18, | ||||
| /**/ | ||||
|  | ||||
| @ -7131,17 +7131,17 @@ command_height(void) | ||||
|  | ||||
|     // If the space for the command line is already more than 'cmdheight' there | ||||
|     // 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) | ||||
| 	return; | ||||
|  | ||||
|     // Update cmdline_row to what it should be: just below the last window. | ||||
|     cmdline_row = topframe->fr_height + tabline_height(); | ||||
|  | ||||
|     // If cmdline_row is smaller than what it is supposed to be for 'cmdheight' | ||||
|     // then set old_p_ch to what it would be, so that the windows get resized | ||||
|     // old_p_ch may be unreliable, because of the early return above, so | ||||
|     // set old_p_ch to what it would be, so that the windows get resized | ||||
|     // 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. | ||||
|     frp = lastwin->w_frame; | ||||
|  | ||||
		Reference in New Issue
	
	Block a user