0
0
mirror of https://github.com/vim/vim.git synced 2025-10-18 07:54:29 -04:00

patch 9.0.1373: wrong text displayed when using both 'linebreak' and 'list'

Problem:    Wrong text displayed when using both 'linebreak' and 'list'.
Solution:   Only set "c_extra" to NUL when "p_extra" is not empty. (Hirohito
            Higashi, closes #12065)
This commit is contained in:
h-east
2023-03-02 18:49:09 +00:00
committed by Bram Moolenaar
parent db1887ce40
commit 194555c001
3 changed files with 28 additions and 1 deletions

View File

@@ -3095,7 +3095,8 @@ win_line(
? wp->w_lcs_chars.tab3
: wp->w_lcs_chars.tab1;
#ifdef FEAT_LINEBREAK
if (wp->w_p_lbr && wlv.p_extra != NULL)
if (wp->w_p_lbr && wlv.p_extra != NULL
&& *wlv.p_extra != NUL)
wlv.c_extra = NUL; // using p_extra from above
else
#endif

View File

@@ -73,6 +73,30 @@ func Test_linebreak_with_nolist()
call s:close_windows()
endfunc
func Test_linebreak_with_list_and_number()
call s:test_windows('setl list listchars+=tab:>-')
call setline(1, ["abcdefg\thijklmnopqrstu", "v"])
let lines = s:screen_lines([1, 4], winwidth(0))
let expect_nonumber = [
\ "abcdefg>------------",
\ "hijklmnopqrstu$ ",
\ "v$ ",
\ "~ ",
\ ]
call s:compare_lines(expect_nonumber, lines)
setl number
let lines = s:screen_lines([1, 4], winwidth(0))
let expect_number = [
\ " 1 abcdefg>--------",
\ " hijklmnopqrstu$ ",
\ " 2 v$ ",
\ "~ ",
\ ]
call s:compare_lines(expect_number, lines)
call s:close_windows()
endfunc
func Test_should_break()
call s:test_windows('setl sbr=+ nolist')
call setline(1, "1\t" . repeat('a', winwidth(0)-2))

View File

@@ -695,6 +695,8 @@ static char *(features[]) =
static int included_patches[] =
{ /* Add new patch number below this line */
/**/
1373,
/**/
1372,
/**/