forked from aniani/vim
patch 9.0.2144: Text properties causes wrong line wrapping
Problem: Text properties causes wrong line wrapping to be drawn. Solution: Find the index of the last text property that inserts text. closes: #13611 Signed-off-by: zeertzjq <zeertzjq@outlook.com> Signed-off-by: Christian Brabandt <cb@256bit.org>
This commit is contained in:
committed by
Christian Brabandt
parent
c089c3816b
commit
4e26a9aab6
@@ -1149,6 +1149,7 @@ win_line(
|
|||||||
#ifdef FEAT_PROP_POPUP
|
#ifdef FEAT_PROP_POPUP
|
||||||
int did_line = FALSE; // set to TRUE when line text done
|
int did_line = FALSE; // set to TRUE when line text done
|
||||||
int text_prop_count;
|
int text_prop_count;
|
||||||
|
int last_textprop_text_idx = -1;
|
||||||
int text_prop_next = 0; // next text property to use
|
int text_prop_next = 0; // next text property to use
|
||||||
textprop_T *text_props = NULL;
|
textprop_T *text_props = NULL;
|
||||||
int *text_prop_idxs = NULL;
|
int *text_prop_idxs = NULL;
|
||||||
@@ -1616,6 +1617,11 @@ win_line(
|
|||||||
area_highlighting = TRUE;
|
area_highlighting = TRUE;
|
||||||
extra_check = TRUE;
|
extra_check = TRUE;
|
||||||
|
|
||||||
|
/* Find the last text property that inserts text. */
|
||||||
|
for (int i = 0; i < text_prop_count; ++i)
|
||||||
|
if (text_props[i].tp_id < 0)
|
||||||
|
last_textprop_text_idx = i;
|
||||||
|
|
||||||
// When skipping virtual text the props need to be sorted. The
|
// When skipping virtual text the props need to be sorted. The
|
||||||
// order is reversed!
|
// order is reversed!
|
||||||
if (lnum == wp->w_topline && wp->w_skipcol > 0)
|
if (lnum == wp->w_topline && wp->w_skipcol > 0)
|
||||||
@@ -3791,7 +3797,7 @@ win_line(
|
|||||||
|| (wlv.n_extra > 0 && (wlv.c_extra != NUL
|
|| (wlv.n_extra > 0 && (wlv.c_extra != NUL
|
||||||
|| *wlv.p_extra != NUL))
|
|| *wlv.p_extra != NUL))
|
||||||
#ifdef FEAT_PROP_POPUP
|
#ifdef FEAT_PROP_POPUP
|
||||||
|| text_prop_next < text_prop_count
|
|| text_prop_next <= last_textprop_text_idx
|
||||||
#endif
|
#endif
|
||||||
))
|
))
|
||||||
{
|
{
|
||||||
@@ -4083,7 +4089,7 @@ win_line(
|
|||||||
#endif
|
#endif
|
||||||
#ifdef FEAT_PROP_POPUP
|
#ifdef FEAT_PROP_POPUP
|
||||||
|| text_prop_above || text_prop_follows
|
|| text_prop_above || text_prop_follows
|
||||||
|| text_prop_next < text_prop_count
|
|| text_prop_next <= last_textprop_text_idx
|
||||||
#endif
|
#endif
|
||||||
|| (wp->w_p_list && wp->w_lcs_chars.eol != NUL
|
|| (wp->w_p_list && wp->w_lcs_chars.eol != NUL
|
||||||
&& wlv.p_extra != at_end_str)
|
&& wlv.p_extra != at_end_str)
|
||||||
|
20
src/testdir/dumps/Test_prop_in_empty_popup.dump
Normal file
20
src/testdir/dumps/Test_prop_in_empty_popup.dump
Normal file
@@ -0,0 +1,20 @@
|
|||||||
|
> +0&#ffffff0@39
|
||||||
|
|~+0#4040ff13&| @38
|
||||||
|
|~| @38
|
||||||
|
|~| @38
|
||||||
|
|~| @7|╔+0#0000000&|═@19|╗| +0#4040ff13&@8
|
||||||
|
|~| @7|║+0#0000000&| +8#af5f00255&@1|1| | +8#e000002&@15|║+0#0000000&| +0#4040ff13&@8
|
||||||
|
|~| @7|║+0#0000000&| +0#4040ff13&@19|║+0#0000000&| +0#4040ff13&@8
|
||||||
|
|~| @7|║+0#0000000&| +0#4040ff13&@19|║+0#0000000&| +0#4040ff13&@8
|
||||||
|
|~| @7|║+0#0000000&| +0#4040ff13&@19|║+0#0000000&| +0#4040ff13&@8
|
||||||
|
|~| @7|║+0#0000000&| +0#4040ff13&@19|║+0#0000000&| +0#4040ff13&@8
|
||||||
|
|~| @7|║+0#0000000&| +0#4040ff13&@19|║+0#0000000&| +0#4040ff13&@8
|
||||||
|
|~| @7|║+0#0000000&| +0#4040ff13&@19|║+0#0000000&| +0#4040ff13&@8
|
||||||
|
|~| @7|║+0#0000000&| +0#4040ff13&@19|║+0#0000000&| +0#4040ff13&@8
|
||||||
|
|~| @7|║+0#0000000&| +0#4040ff13&@19|║+0#0000000&| +0#4040ff13&@8
|
||||||
|
|~| @7|║+0#0000000&| +0#4040ff13&@19|║+0#0000000&| +0#4040ff13&@8
|
||||||
|
|~| @7|╚+0#0000000&|═@19|╝| +0#4040ff13&@8
|
||||||
|
|~| @38
|
||||||
|
|~| @38
|
||||||
|
|~| @38
|
||||||
|
| +0#0000000&@21|0|,|0|-|1| @8|A|l@1|
|
@@ -1424,6 +1424,43 @@ func Test_textprop_text_priority()
|
|||||||
call StopVimInTerminal(buf)
|
call StopVimInTerminal(buf)
|
||||||
endfunc
|
endfunc
|
||||||
|
|
||||||
|
func Test_textprop_in_empty_popup()
|
||||||
|
CheckScreendump
|
||||||
|
|
||||||
|
let lines =<< trim END
|
||||||
|
vim9script
|
||||||
|
|
||||||
|
hi def link FilterMenuMatch Constant
|
||||||
|
prop_type_add('FilterMenuMatch', {
|
||||||
|
highlight: "FilterMenuMatch",
|
||||||
|
override: true,
|
||||||
|
priority: 1000,
|
||||||
|
combine: true,
|
||||||
|
})
|
||||||
|
|
||||||
|
var winid = popup_create([{text: "hello", props: [
|
||||||
|
{col: 1, length: 1, type: 'FilterMenuMatch'},
|
||||||
|
{col: 2, length: 1, type: 'FilterMenuMatch'},
|
||||||
|
]}], {
|
||||||
|
minwidth: 20,
|
||||||
|
minheight: 10,
|
||||||
|
cursorline: false,
|
||||||
|
highlight: "None",
|
||||||
|
border: [],
|
||||||
|
})
|
||||||
|
|
||||||
|
win_execute(winid, "setl nu cursorline cursorlineopt=both")
|
||||||
|
popup_settext(winid, [])
|
||||||
|
redraw
|
||||||
|
END
|
||||||
|
call writefile(lines, 'XtestPropEmptyPopup', 'D')
|
||||||
|
let buf = RunVimInTerminal('-S XtestPropEmptyPopup', #{rows: 20, cols: 40})
|
||||||
|
call VerifyScreenDump(buf, 'Test_prop_in_empty_popup', {})
|
||||||
|
|
||||||
|
" clean up
|
||||||
|
call StopVimInTerminal(buf)
|
||||||
|
endfunc
|
||||||
|
|
||||||
func Test_textprop_with_syntax()
|
func Test_textprop_with_syntax()
|
||||||
CheckScreendump
|
CheckScreendump
|
||||||
|
|
||||||
|
@@ -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 */
|
||||||
|
/**/
|
||||||
|
2144,
|
||||||
/**/
|
/**/
|
||||||
2143,
|
2143,
|
||||||
/**/
|
/**/
|
||||||
|
Reference in New Issue
Block a user