patch 9.1.0103: 'breakindentopt' "min" not correct with 'signcolumn'
Problem:  'breakindentopt' "min" works incorrectly with 'signcolumn'.
Solution: Use win_col_off() and win_col_off2().
          (zeertzjq)
closes: #14014
Signed-off-by: zeertzjq <zeertzjq@outlook.com>
Signed-off-by: Christian Brabandt <cb@256bit.org>
			
			
This commit is contained in:
		
				
					committed by
					
						 Christian Brabandt
						Christian Brabandt
					
				
			
			
				
	
			
			
			
						parent
						
							b47fbb4083
						
					
				
				
					commit
					f0a9d65e0a
				
			| @ -935,9 +935,7 @@ get_breakindent_win( | |||||||
|     int		    bri = 0; |     int		    bri = 0; | ||||||
|     // window width minus window margin space, i.e. what rests for text |     // window width minus window margin space, i.e. what rests for text | ||||||
|     const int	    eff_wwidth = wp->w_width |     const int	    eff_wwidth = wp->w_width | ||||||
| 			    - ((wp->w_p_nu || wp->w_p_rnu) | 					  - win_col_off(wp) + win_col_off2(wp); | ||||||
| 				&& (vim_strchr(p_cpo, CPO_NUMCOL) == NULL) |  | ||||||
| 						? number_width(wp) + 1 : 0); |  | ||||||
|  |  | ||||||
|     // In list mode, if 'listchars' "tab" isn't set, a TAB is displayed as ^I. |     // In list mode, if 'listchars' "tab" isn't set, a TAB is displayed as ^I. | ||||||
|     int no_ts = wp->w_p_list && wp->w_lcs_chars.tab1 == NUL; |     int no_ts = wp->w_p_list && wp->w_lcs_chars.tab1 == NUL; | ||||||
|  | |||||||
| @ -733,7 +733,7 @@ func Test_breakindent20_list() | |||||||
| 	\ "shall make no law   ", | 	\ "shall make no law   ", | ||||||
| 	\ ] | 	\ ] | ||||||
|   call s:compare_lines(expect, lines) |   call s:compare_lines(expect, lines) | ||||||
|   " set minimum indent |   " set minimum text width | ||||||
|   setl briopt=min:5 |   setl briopt=min:5 | ||||||
|   redraw! |   redraw! | ||||||
|   let lines = s:screen_lines2(1, 6, 20) |   let lines = s:screen_lines2(1, 6, 20) | ||||||
| @ -1133,4 +1133,36 @@ func Test_breakindent_list_split() | |||||||
|   bwipe! |   bwipe! | ||||||
| endfunc | endfunc | ||||||
|  |  | ||||||
|  | func Test_breakindent_min_with_signcol() | ||||||
|  |   call s:test_windows('setl briopt=min:15 signcolumn=yes') | ||||||
|  |   redraw! | ||||||
|  |   let expect = [ | ||||||
|  |         \ "      abcdefghijklmn", | ||||||
|  |         \ "     opqrstuvwxyzABC", | ||||||
|  |         \ "     DEFGHIJKLMNOP  " | ||||||
|  |         \ ] | ||||||
|  |   let lines = s:screen_lines(line('.'), 20) | ||||||
|  |   call s:compare_lines(expect, lines) | ||||||
|  |   setl briopt=min:17 | ||||||
|  |   redraw! | ||||||
|  |   let expect = [ | ||||||
|  |         \ "      abcdefghijklmn", | ||||||
|  |         \ "   opqrstuvwxyzABCDE", | ||||||
|  |         \ "   FGHIJKLMNOP      " | ||||||
|  |         \ ] | ||||||
|  |   let lines = s:screen_lines(line('.'), 20) | ||||||
|  |   call s:compare_lines(expect, lines) | ||||||
|  |   setl briopt=min:19 | ||||||
|  |   redraw! | ||||||
|  |   let expect = [ | ||||||
|  |         \ "      abcdefghijklmn", | ||||||
|  |         \ "  opqrstuvwxyzABCDEF", | ||||||
|  |         \ "  GHIJKLMNOP        " | ||||||
|  |         \ ] | ||||||
|  |   let lines = s:screen_lines(line('.'), 20) | ||||||
|  |   call s:compare_lines(expect, lines) | ||||||
|  |  | ||||||
|  |   call s:close_windows() | ||||||
|  | endfunc | ||||||
|  |  | ||||||
| " vim: shiftwidth=2 sts=2 expandtab | " vim: shiftwidth=2 sts=2 expandtab | ||||||
|  | |||||||
| @ -1133,7 +1133,7 @@ func Test_diff_breakindent_after_filler() | |||||||
|   CheckScreendump |   CheckScreendump | ||||||
|  |  | ||||||
|   let lines =<< trim END |   let lines =<< trim END | ||||||
|     set laststatus=0 diffopt+=followwrap breakindent |     set laststatus=0 diffopt+=followwrap breakindent breakindentopt=min:0 | ||||||
|     call setline(1, ['a', '  ' .. repeat('c', 50)]) |     call setline(1, ['a', '  ' .. repeat('c', 50)]) | ||||||
|     vnew |     vnew | ||||||
|     call setline(1, ['a', 'b', '  ' .. repeat('c', 50)]) |     call setline(1, ['a', 'b', '  ' .. repeat('c', 50)]) | ||||||
|  | |||||||
| @ -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 */ | ||||||
|  | /**/ | ||||||
|  |     103, | ||||||
| /**/ | /**/ | ||||||
|     102, |     102, | ||||||
| /**/ | /**/ | ||||||
|  | |||||||
		Reference in New Issue
	
	Block a user