patch 9.1.1062: terminal: E315 when dragging the terminal with the mouse
Problem:  terminal: E315 when dragging the terminal with the mouse
          (user202729)
Solution: call update_topline() and validate_cursor() when clicking
          on the status line with the mouse (Hirohito Higashi)
fixes: #16024
fixes: #16211
closes: #16552
Signed-off-by: Hirohito Higashi <h.east.727@gmail.com>
Signed-off-by: Christian Brabandt <cb@256bit.org>
			
			
This commit is contained in:
		
				
					committed by
					
						 Christian Brabandt
						Christian Brabandt
					
				
			
			
				
	
			
			
			
						parent
						
							7c930eb61a
						
					
				
				
					commit
					3219da514c
				
			
							
								
								
									
										10
									
								
								src/mouse.c
									
									
									
									
									
								
							
							
						
						
									
										10
									
								
								src/mouse.c
									
									
									
									
									
								
							| @ -1902,6 +1902,16 @@ retnomove: | ||||
| 	    // Drag the status line | ||||
| 	    count = row - W_WINROW(dragwin) - dragwin->w_height + 1 | ||||
| 							     - on_status_line; | ||||
| #ifdef FEAT_TERMINAL | ||||
| 	    if (bt_terminal(dragwin->w_buffer)) | ||||
| 	    { | ||||
| 		win_T *curwin_save = curwin; | ||||
| 		curwin = dragwin; | ||||
| 		update_topline(); | ||||
| 		validate_cursor(); | ||||
| 		curwin = curwin_save; | ||||
| 	    } | ||||
| #endif | ||||
| 	    win_drag_status_line(dragwin, count); | ||||
| 	    did_drag |= count; | ||||
| 	} | ||||
|  | ||||
| @ -289,6 +289,61 @@ func Test_termwinscroll_topline() | ||||
|   set termwinscroll& mouse& | ||||
| endfunc | ||||
|  | ||||
| func Test_termwinscroll_topline2() | ||||
|   let g:test_is_flaky = 1 | ||||
|   set termwinscroll=75000 mouse=a | ||||
|   if !has('win32') | ||||
|     set shell=sh | ||||
|   endif | ||||
|   let norm_winid = win_getid() | ||||
|   terminal | ||||
|   call assert_equal(2, winnr('$')) | ||||
|   let buf = bufnr() | ||||
|   let win = winnr() | ||||
|   call WaitFor({-> !empty(term_getline(buf, 1))}) | ||||
|  | ||||
|   let num1 = &termwinscroll / 1000 * 999 | ||||
|   call writefile(range(num1), 'Xtext', 'D') | ||||
|   if has('win32') | ||||
|     call term_sendkeys(buf, "type Xtext\<CR>") | ||||
|   else | ||||
|     call term_sendkeys(buf, "cat Xtext\<CR>") | ||||
|   endif | ||||
|   let rows = term_getsize(buf)[0] | ||||
|   " It may take a while to finish on a slow system | ||||
|   call term_wait(buf, 1000 * g:run_nr) | ||||
|   " On MS-Windows there is an empty line, check both last line and above it. | ||||
|   call WaitForAssert({-> assert_match(string(num1 - 1), term_getline(buf, rows - 1) .. '\|' .. term_getline(buf, rows - 2))}) | ||||
|   call feedkeys("\<C-W>N", 'xt') | ||||
|   call feedkeys("i", 'xt') | ||||
|  | ||||
|   let num2 = &termwinscroll / 1000 * 8 | ||||
|   call writefile(range(num2), 'Xtext', 'D') | ||||
|   if has('win32') | ||||
|     call term_sendkeys(buf, "timeout /t 2 && type Xtext\<CR>") | ||||
|   else | ||||
|     call term_sendkeys(buf, "sleep 2; cat Xtext\<CR>") | ||||
|   endif | ||||
|   let winrow = get(get(filter(getwininfo(), 'v:val.winid == norm_winid'), 0, {}), 'winrow', -1) | ||||
|  | ||||
|   call test_setmouse(winrow, 1) | ||||
|   call feedkeys("\<LeftMouse>", "xt") | ||||
|   call WaitForAssert({-> assert_notequal(buf, bufnr())}) | ||||
|  | ||||
|   " Change the terminal window row size | ||||
|   call win_move_statusline(win,1) | ||||
|   " Before the fix, E340 and E315 would occur multiple times at this point. | ||||
|   let winrow2 = get(get(filter(getwininfo(), 'v:val.winid == norm_winid'), 0, {}), 'winrow', -1) | ||||
|   call assert_equal(winrow + 1, winrow2) | ||||
|  | ||||
|   call test_setmouse(1, 1) | ||||
|   call feedkeys("\<LeftMouse>", "xt") | ||||
|   call WaitForAssert({-> assert_equal(buf, bufnr())}) | ||||
|  | ||||
|   exe buf . 'bwipe!' | ||||
|   set termwinscroll& mouse& sh& | ||||
| endfunc | ||||
|  | ||||
| " Resizing the terminal window caused an ml_get error. | ||||
| " TODO: This does not reproduce the original problem. | ||||
| " TODO: This test starts timing out in Github CI Gui test, why???? | ||||
|  | ||||
| @ -704,6 +704,8 @@ static char *(features[]) = | ||||
|  | ||||
| static int included_patches[] = | ||||
| {   /* Add new patch number below this line */ | ||||
| /**/ | ||||
|     1062, | ||||
| /**/ | ||||
|     1061, | ||||
| /**/ | ||||
|  | ||||
		Reference in New Issue
	
	Block a user