mirror of
				https://github.com/vim/vim.git
				synced 2025-10-30 09:47:20 -04:00 
			
		
		
		
	patch 9.1.0759: screenpos() may return invalid position
Problem:  screenpos() may return invalid position
          after switching buffers (Greg Hurrell)
Solution: reset w_leftcol if wrapping has been set
          after copying wrap option
fixes: #15792
closes: #15803
Signed-off-by: Christian Brabandt <cb@256bit.org>
			
			
This commit is contained in:
		| @@ -6737,6 +6737,11 @@ win_copy_options(win_T *wp_from, win_T *wp_to) | |||||||
|     void |     void | ||||||
| after_copy_winopt(win_T *wp) | after_copy_winopt(win_T *wp) | ||||||
| { | { | ||||||
|  |     // Set w_leftcol or w_skipcol to zero. | ||||||
|  |     if (wp->w_p_wrap) | ||||||
|  | 	wp->w_leftcol = 0; | ||||||
|  |     else | ||||||
|  | 	wp->w_skipcol = 0; | ||||||
| #ifdef FEAT_LINEBREAK | #ifdef FEAT_LINEBREAK | ||||||
|     briopt_check(wp); |     briopt_check(wp); | ||||||
| #endif | #endif | ||||||
|   | |||||||
| @@ -279,6 +279,21 @@ func Test_screenpos_number() | |||||||
|   bwipe! |   bwipe! | ||||||
| endfunc | endfunc | ||||||
|  |  | ||||||
|  | func Test_screenpos_edit_newfile() | ||||||
|  |   new | ||||||
|  |   20vsp | ||||||
|  |   setl nowrap | ||||||
|  |   call setline(1, 'abcdefghijklmnopqrstuvwxyz') | ||||||
|  |   call cursor(1, 10) | ||||||
|  |   norm! 5zl | ||||||
|  |   call assert_equal(#{col: 5, row: 1, endcol: 5, curscol: 5}, screenpos(win_getid(), 1, 10)) | ||||||
|  |   enew! | ||||||
|  |   call assert_equal(1, &l:wrap) | ||||||
|  |   call assert_equal(#{col: 1, row: 1, endcol: 1, curscol: 1}, screenpos(win_getid(), 1, 1)) | ||||||
|  |  | ||||||
|  |   bwipe! | ||||||
|  | endfunc | ||||||
|  |  | ||||||
| " Save the visual start character position | " Save the visual start character position | ||||||
| func SaveVisualStartCharPos() | func SaveVisualStartCharPos() | ||||||
|   call add(g:VisualStartPos, getcharpos('v')) |   call add(g:VisualStartPos, getcharpos('v')) | ||||||
|   | |||||||
| @@ -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 */ | ||||||
|  | /**/ | ||||||
|  |     759, | ||||||
| /**/ | /**/ | ||||||
|     758, |     758, | ||||||
| /**/ | /**/ | ||||||
|   | |||||||
		Reference in New Issue
	
	Block a user