patch 8.0.1848: 'termwinscroll' does not work properly
Problem:    'termwinscroll' does not work properly. (Dominique Pelle)
Solution:   Subtract removed scrollback from the scrollback count.  Add a test
            for 'termwinscroll'. (closes #2909)
			
			
This commit is contained in:
		| @ -46,6 +46,7 @@ | |||||||
|  * - Win32: Redirecting output works but includes escape sequences. |  * - Win32: Redirecting output works but includes escape sequences. | ||||||
|  * - Win32: Make terminal used for :!cmd in the GUI work better.  Allow for |  * - Win32: Make terminal used for :!cmd in the GUI work better.  Allow for | ||||||
|  *   redirection. |  *   redirection. | ||||||
|  |  * - terminal API: Add more functionality? (Ozaki Kiichi 2018 May 13, #2907) | ||||||
|  * - When the job only outputs lines, we could handle resizing the terminal |  * - When the job only outputs lines, we could handle resizing the terminal | ||||||
|  *   better: store lines separated by line breaks, instead of screen lines, |  *   better: store lines separated by line breaks, instead of screen lines, | ||||||
|  *   then when the window is resized redraw those lines. |  *   then when the window is resized redraw those lines. | ||||||
| @ -2727,6 +2728,7 @@ handle_pushline(int cols, const VTermScreenCell *cells, void *user) | |||||||
| 	mch_memmove(term->tl_scrollback.ga_data, | 	mch_memmove(term->tl_scrollback.ga_data, | ||||||
| 	    (sb_line_T *)term->tl_scrollback.ga_data + todo, | 	    (sb_line_T *)term->tl_scrollback.ga_data + todo, | ||||||
| 	    sizeof(sb_line_T) * term->tl_scrollback.ga_len); | 	    sizeof(sb_line_T) * term->tl_scrollback.ga_len); | ||||||
|  | 	term->tl_scrollback_scrolled -= todo; | ||||||
|     } |     } | ||||||
|  |  | ||||||
|     if (ga_grow(&term->tl_scrollback, 1) == OK) |     if (ga_grow(&term->tl_scrollback, 1) == OK) | ||||||
|  | |||||||
| @ -1507,3 +1507,30 @@ func Test_terminal_out_err() | |||||||
|   call delete('Xechoerrout.sh') |   call delete('Xechoerrout.sh') | ||||||
|   call delete(outfile) |   call delete(outfile) | ||||||
| endfunc | endfunc | ||||||
|  |  | ||||||
|  | func Test_terminwinscroll() | ||||||
|  |   if !has('unix') | ||||||
|  |     return | ||||||
|  |   endif | ||||||
|  |  | ||||||
|  |   " Let the terminal output more than 'termwinscroll' lines, some at the start | ||||||
|  |   " will be dropped. | ||||||
|  |   exe 'set termwinscroll=' . &lines | ||||||
|  |   let buf = term_start('/bin/sh') | ||||||
|  |   for i in range(1, &lines) | ||||||
|  |     call feedkeys("echo " . i . "\<CR>", 'xt') | ||||||
|  |     call WaitForAssert({-> assert_match(string(i), term_getline(buf, term_getcursor(buf)[0] - 1))}) | ||||||
|  |   endfor | ||||||
|  |   " Go to Terminal-Normal mode to update the buffer. | ||||||
|  |   call feedkeys("\<C-W>N", 'xt') | ||||||
|  |   call assert_inrange(&lines, &lines * 110 / 100 + winheight(0), line('$')) | ||||||
|  |  | ||||||
|  |   " Every "echo nr" must only appear once | ||||||
|  |   let lines = getline(1, line('$')) | ||||||
|  |   for i in range(&lines - len(lines) / 2 + 2, &lines) | ||||||
|  |     let filtered = filter(copy(lines), {idx, val -> val =~ 'echo ' . i . '\>'}) | ||||||
|  |     call assert_equal(1, len(filtered), 'for "echo ' . i . '"') | ||||||
|  |   endfor | ||||||
|  |  | ||||||
|  |   exe buf . 'bwipe!' | ||||||
|  | endfunc | ||||||
|  | |||||||
| @ -761,6 +761,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 */ | ||||||
|  | /**/ | ||||||
|  |     1848, | ||||||
| /**/ | /**/ | ||||||
|     1847, |     1847, | ||||||
| /**/ | /**/ | ||||||
|  | |||||||
		Reference in New Issue
	
	Block a user