forked from aniani/vim
patch 8.0.0049
Problem: When a match ends in part of concealed text highlighting, it might mess up concealing by resetting prev_syntax_id. Solution: Do not reset prev_syntax_id and add a test to verify. (Christian Brabandt, closes #1092)
This commit is contained in:
@@ -3981,9 +3981,6 @@ win_line(
|
|||||||
else if (v == (long)shl->endcol)
|
else if (v == (long)shl->endcol)
|
||||||
{
|
{
|
||||||
shl->attr_cur = 0;
|
shl->attr_cur = 0;
|
||||||
#ifdef FEAT_CONCEAL
|
|
||||||
prev_syntax_id = 0;
|
|
||||||
#endif
|
|
||||||
next_search_hl(wp, shl, lnum, (colnr_T)v,
|
next_search_hl(wp, shl, lnum, (colnr_T)v,
|
||||||
shl == &search_hl ? NULL : cur);
|
shl == &search_hl ? NULL : cur);
|
||||||
pos_inprogress = cur == NULL || cur->pos.cur == 0
|
pos_inprogress = cur == NULL || cur->pos.cur == 0
|
||||||
|
@@ -264,3 +264,25 @@ function! Test_matchadd_repeat_conceal_with_syntax_off()
|
|||||||
|
|
||||||
quit!
|
quit!
|
||||||
endfunction
|
endfunction
|
||||||
|
|
||||||
|
function! Test_matchadd_and_syn_conceal()
|
||||||
|
new
|
||||||
|
let cnt='Inductive bool : Type := | true : bool | false : bool.'
|
||||||
|
let expect = 'Inductive - : Type := | true : - | false : -.'
|
||||||
|
0put =cnt
|
||||||
|
" set filetype and :syntax on to change screenattr()
|
||||||
|
set cole=1 cocu=nv
|
||||||
|
hi link CheckedByCoq WarningMsg
|
||||||
|
syntax on
|
||||||
|
syntax keyword coqKwd bool conceal cchar=-
|
||||||
|
redraw!
|
||||||
|
call assert_equal(expect, s:screenline(1))
|
||||||
|
call assert_notequal(screenattr(1, 10) , screenattr(1, 11))
|
||||||
|
call assert_notequal(screenattr(1, 11) , screenattr(1, 12))
|
||||||
|
call assert_equal(screenattr(1, 11) , screenattr(1, 32))
|
||||||
|
call matchadd('CheckedByCoq', '\%<2l\%>9c\%<16c')
|
||||||
|
call assert_equal(expect, s:screenline(1))
|
||||||
|
call assert_notequal(screenattr(1, 10) , screenattr(1, 11))
|
||||||
|
call assert_notequal(screenattr(1, 11) , screenattr(1, 12))
|
||||||
|
call assert_equal(screenattr(1, 11) , screenattr(1, 32))
|
||||||
|
endfunction
|
||||||
|
@@ -764,6 +764,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 */
|
||||||
|
/**/
|
||||||
|
49,
|
||||||
/**/
|
/**/
|
||||||
48,
|
48,
|
||||||
/**/
|
/**/
|
||||||
|
Reference in New Issue
Block a user