patch 9.0.1836: display wrong with virttext, linebreak and breakindent
Problem: Wrong display with "above" virtual text and 'linebreak' or 'breakindent' and 'showbreak'. Solution: Exclude size of "above" virtual text when calculating them. closes: #13000 Signed-off-by: Christian Brabandt <cb@256bit.org> Co-authored-by: zeertzjq <zeertzjq@outlook.com>
This commit is contained in:
committed by
Christian Brabandt
parent
7a9d1aa878
commit
ce53e3ea55
@ -1218,8 +1218,9 @@ win_lbr_chartabsize(
|
||||
cts->cts_cur_text_width += cells;
|
||||
if (tp->tp_flags & TP_FLAG_ALIGN_ABOVE)
|
||||
cts->cts_first_char += cells;
|
||||
cts->cts_start_incl = tp->tp_flags & TP_FLAG_START_INCL;
|
||||
else
|
||||
size += cells;
|
||||
cts->cts_start_incl = tp->tp_flags & TP_FLAG_START_INCL;
|
||||
if (*s == TAB)
|
||||
{
|
||||
// tab size changes because of the inserted text
|
||||
@ -1385,6 +1386,9 @@ win_lbr_chartabsize(
|
||||
}
|
||||
}
|
||||
|
||||
# ifdef FEAT_PROP_POPUP
|
||||
size += cts->cts_first_char;
|
||||
# endif
|
||||
return size;
|
||||
# endif
|
||||
#endif
|
||||
|
@ -1650,6 +1650,18 @@ win_line(
|
||||
}
|
||||
#endif
|
||||
|
||||
#if defined(FEAT_LINEBREAK) || defined(FEAT_PROP_POPUP)
|
||||
colnr_T vcol_first_char = 0;
|
||||
if (wp->w_p_lbr && !number_only)
|
||||
{
|
||||
chartabsize_T cts;
|
||||
init_chartabsize_arg(&cts, wp, lnum, 0, line, line);
|
||||
(void)win_lbr_chartabsize(&cts, NULL);
|
||||
vcol_first_char = cts.cts_first_char;
|
||||
clear_chartabsize_arg(&cts);
|
||||
}
|
||||
#endif
|
||||
|
||||
// 'nowrap' or 'wrap' and a single line that doesn't fit: Advance to the
|
||||
// first character to be displayed.
|
||||
if (wp->w_p_wrap)
|
||||
@ -2879,7 +2891,11 @@ win_line(
|
||||
char_u *p = ptr - (mb_off + 1);
|
||||
chartabsize_T cts;
|
||||
|
||||
init_chartabsize_arg(&cts, wp, lnum, wlv.vcol, line, p);
|
||||
init_chartabsize_arg(&cts, wp, lnum, wlv.vcol
|
||||
# ifdef FEAT_PROP_POPUP
|
||||
- vcol_first_char,
|
||||
# endif
|
||||
line, p);
|
||||
# ifdef FEAT_PROP_POPUP
|
||||
// do not want virtual text counted here
|
||||
cts.cts_has_prop_with_text = FALSE;
|
||||
|
6
src/testdir/dumps/Test_prop_above_and_before_1.dump
Normal file
6
src/testdir/dumps/Test_prop_above_and_before_1.dump
Normal file
@ -0,0 +1,6 @@
|
||||
|a+0&#ffffff0| @73
|
||||
| +0#e000e06&@1|1|2|3| +0#0000000&@69
|
||||
@2|b|:+0#e000e06&| |4|5|6| +0#0000000&>c| @64
|
||||
|~+0#4040ff13&| @73
|
||||
|~| @73
|
||||
| +0#0000000&@56|2|,|5|-|8|5| @7|A|l@1|
|
6
src/testdir/dumps/Test_prop_above_and_before_2.dump
Normal file
6
src/testdir/dumps/Test_prop_above_and_before_2.dump
Normal file
@ -0,0 +1,6 @@
|
||||
|a+0&#ffffff0| @73
|
||||
| +0#e000e06&@1|1|2|3| +0#0000000&@69
|
||||
@2|b|:+0#e000e06&| |4|5|6> +0#0000000&|c| @64
|
||||
|~+0#4040ff13&| @73
|
||||
|~| @73
|
||||
| +0#0000000&@56|2|,|4|-|8|4| @7|A|l@1|
|
6
src/testdir/dumps/Test_prop_above_and_before_3.dump
Normal file
6
src/testdir/dumps/Test_prop_above_and_before_3.dump
Normal file
@ -0,0 +1,6 @@
|
||||
|a+0&#ffffff0| @73
|
||||
| +0#e000e06&@1|1|2|3| +0#0000000&@69
|
||||
@2>b|:+0#e000e06&| |4|5|6| +0#0000000&|c| @64
|
||||
|~+0#4040ff13&| @73
|
||||
|~| @73
|
||||
| +0#0000000&@56|2|,|3|-|7|8| @7|A|l@1|
|
6
src/testdir/dumps/Test_prop_above_and_before_4.dump
Normal file
6
src/testdir/dumps/Test_prop_above_and_before_4.dump
Normal file
@ -0,0 +1,6 @@
|
||||
|a+0&#ffffff0| @73
|
||||
| +0#e000e06&@1|1|2|3| +0#0000000&@69
|
||||
@1> |b|:+0#e000e06&| |4|5|6| +0#0000000&|c| @64
|
||||
|~+0#4040ff13&| @73
|
||||
|~| @73
|
||||
| +0#0000000&@56|2|,|2|-|7@1| @7|A|l@1|
|
6
src/testdir/dumps/Test_prop_above_and_before_5.dump
Normal file
6
src/testdir/dumps/Test_prop_above_and_before_5.dump
Normal file
@ -0,0 +1,6 @@
|
||||
|a+0&#ffffff0| @73
|
||||
| +0#e000e06&@1|1|2|3| +0#0000000&@69
|
||||
> @1|b|:+0#e000e06&| |4|5|6| +0#0000000&|c| @64
|
||||
|~+0#4040ff13&| @73
|
||||
|~| @73
|
||||
| +0#0000000&@56|2|,|1|-|7|6| @7|A|l@1|
|
6
src/testdir/dumps/Test_prop_above_linebreak_1.dump
Normal file
6
src/testdir/dumps/Test_prop_above_linebreak_1.dump
Normal file
@ -0,0 +1,6 @@
|
||||
|1+0#e000e06#ffffff0|2|3| +0#0000000&@71
|
||||
|a| |b| @71
|
||||
|c| >d| @71
|
||||
|~+0#4040ff13&| @73
|
||||
|~| @73
|
||||
| +0#0000000&@56|2|,|3| @10|A|l@1|
|
6
src/testdir/dumps/Test_prop_above_linebreak_2.dump
Normal file
6
src/testdir/dumps/Test_prop_above_linebreak_2.dump
Normal file
@ -0,0 +1,6 @@
|
||||
|1+0#e000e06#ffffff0|2|3| +0#0000000&@71
|
||||
|a| >b| @71
|
||||
|c| |d| @71
|
||||
|~+0#4040ff13&| @73
|
||||
|~| @73
|
||||
| +0#0000000&@56|1|,|3|-|7|8| @7|A|l@1|
|
@ -3523,6 +3523,51 @@ func Test_prop_above_with_number()
|
||||
call StopVimInTerminal(buf)
|
||||
endfunc
|
||||
|
||||
func Test_prop_above_with_linebreak()
|
||||
CheckRunVimInTerminal
|
||||
|
||||
let lines =<< trim END
|
||||
setlocal linebreak breakindent breakindentopt=shift:4
|
||||
call setline(1, ["a b", "c d"])
|
||||
call prop_type_add('theprop' , #{highlight: 'Special'})
|
||||
call prop_add(1, 0, #{type: 'theprop', text: '123', text_align: 'above'})
|
||||
normal! 2gg$
|
||||
END
|
||||
call writefile(lines, 'XscriptPropAboveLinebreak', 'D')
|
||||
let buf = RunVimInTerminal('-S XscriptPropAboveLinebreak', #{rows: 6})
|
||||
call VerifyScreenDump(buf, 'Test_prop_above_linebreak_1', {})
|
||||
call term_sendkeys(buf, 'k')
|
||||
call VerifyScreenDump(buf, 'Test_prop_above_linebreak_2', {})
|
||||
|
||||
call StopVimInTerminal(buf)
|
||||
endfunc
|
||||
|
||||
func Test_prop_above_and_before()
|
||||
CheckRunVimInTerminal
|
||||
|
||||
let lines =<< trim END
|
||||
setlocal linebreak breakindent breakindentopt=shift:2
|
||||
call setline(1, ["a", " b c"])
|
||||
call prop_type_add('theprop' , #{highlight: 'Special'})
|
||||
call prop_add(2, 0, #{type: 'theprop', text: ' 123', text_align: 'above'})
|
||||
call prop_add(2, 4, #{type: 'theprop', text: ': 456'} )
|
||||
normal! 2gg$
|
||||
END
|
||||
call writefile(lines, 'XscriptPropAboveAndBefore', 'D')
|
||||
let buf = RunVimInTerminal('-S XscriptPropAboveAndBefore', #{rows: 6})
|
||||
call VerifyScreenDump(buf, 'Test_prop_above_and_before_1', {})
|
||||
call term_sendkeys(buf, 'h')
|
||||
call VerifyScreenDump(buf, 'Test_prop_above_and_before_2', {})
|
||||
call term_sendkeys(buf, 'h')
|
||||
call VerifyScreenDump(buf, 'Test_prop_above_and_before_3', {})
|
||||
call term_sendkeys(buf, 'h')
|
||||
call VerifyScreenDump(buf, 'Test_prop_above_and_before_4', {})
|
||||
call term_sendkeys(buf, 'h')
|
||||
call VerifyScreenDump(buf, 'Test_prop_above_and_before_5', {})
|
||||
|
||||
call StopVimInTerminal(buf)
|
||||
endfunc
|
||||
|
||||
func Test_prop_below_split_line()
|
||||
CheckRunVimInTerminal
|
||||
|
||||
|
@ -759,13 +759,12 @@ text_prop_compare(const void *s1, const void *s2)
|
||||
tp2 = &text_prop_compare_props[idx2];
|
||||
col1 = tp1->tp_col;
|
||||
col2 = tp2->tp_col;
|
||||
if (col1 == MAXCOL && col2 == MAXCOL)
|
||||
if (col1 == MAXCOL || col2 == MAXCOL)
|
||||
{
|
||||
int order1 = text_prop_order(tp1->tp_flags);
|
||||
int order2 = text_prop_order(tp2->tp_flags);
|
||||
|
||||
// both props add text before or after the line, sort on order where it
|
||||
// is added
|
||||
// sort on order where it is added
|
||||
if (order1 != order2)
|
||||
return order1 < order2 ? 1 : -1;
|
||||
}
|
||||
|
@ -699,6 +699,8 @@ static char *(features[]) =
|
||||
|
||||
static int included_patches[] =
|
||||
{ /* Add new patch number below this line */
|
||||
/**/
|
||||
1836,
|
||||
/**/
|
||||
1835,
|
||||
/**/
|
||||
|
Reference in New Issue
Block a user