forked from aniani/vim
patch 8.2.2121: internal error when using \ze before \zs in a pattern
Problem: Internal error when using \ze before \zs in a pattern. Solution: Check the end is never before the start. (closes #7442)
This commit is contained in:
@@ -4805,6 +4805,23 @@ theend:
|
|||||||
if (backpos.ga_maxlen > BACKPOS_INITIAL)
|
if (backpos.ga_maxlen > BACKPOS_INITIAL)
|
||||||
ga_clear(&backpos);
|
ga_clear(&backpos);
|
||||||
|
|
||||||
|
// Make sure the end is never before the start. Can happen when \zs and
|
||||||
|
// \ze are used.
|
||||||
|
if (REG_MULTI)
|
||||||
|
{
|
||||||
|
lpos_T *start = &rex.reg_mmatch->startpos[0];
|
||||||
|
lpos_T *end = &rex.reg_mmatch->endpos[0];
|
||||||
|
|
||||||
|
if (end->lnum < start->lnum
|
||||||
|
|| (end->lnum == start->lnum && end->col < start->col))
|
||||||
|
rex.reg_mmatch->endpos[0] = rex.reg_mmatch->startpos[0];
|
||||||
|
}
|
||||||
|
else
|
||||||
|
{
|
||||||
|
if (rex.reg_match->endp[0] < rex.reg_match->startp[0])
|
||||||
|
rex.reg_match->endp[0] = rex.reg_match->startp[0];
|
||||||
|
}
|
||||||
|
|
||||||
return retval;
|
return retval;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@@ -7225,6 +7225,23 @@ nfa_regexec_both(
|
|||||||
#endif
|
#endif
|
||||||
|
|
||||||
theend:
|
theend:
|
||||||
|
// Make sure the end is never before the start. Can happen when \zs and
|
||||||
|
// \ze are used.
|
||||||
|
if (REG_MULTI)
|
||||||
|
{
|
||||||
|
lpos_T *start = &rex.reg_mmatch->startpos[0];
|
||||||
|
lpos_T *end = &rex.reg_mmatch->endpos[0];
|
||||||
|
|
||||||
|
if (end->lnum < start->lnum
|
||||||
|
|| (end->lnum == start->lnum && end->col < start->col))
|
||||||
|
rex.reg_mmatch->endpos[0] = rex.reg_mmatch->startpos[0];
|
||||||
|
}
|
||||||
|
else
|
||||||
|
{
|
||||||
|
if (rex.reg_match->endp[0] < rex.reg_match->startp[0])
|
||||||
|
rex.reg_match->endp[0] = rex.reg_match->startp[0];
|
||||||
|
}
|
||||||
|
|
||||||
return retval;
|
return retval;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@@ -911,6 +911,13 @@ func Test_start_end_of_buffer_match()
|
|||||||
bwipe!
|
bwipe!
|
||||||
endfunc
|
endfunc
|
||||||
|
|
||||||
|
func Test_ze_before_zs()
|
||||||
|
call assert_equal('', matchstr(' ', '\%#=1\ze \zs'))
|
||||||
|
call assert_equal('', matchstr(' ', '\%#=2\ze \zs'))
|
||||||
|
call assert_equal(repeat([''], 10), matchlist(' ', '\%#=1\ze \zs'))
|
||||||
|
call assert_equal(repeat([''], 10), matchlist(' ', '\%#=2\ze \zs'))
|
||||||
|
endfunc
|
||||||
|
|
||||||
" Check for detecting error
|
" Check for detecting error
|
||||||
func Test_regexp_error()
|
func Test_regexp_error()
|
||||||
call assert_fails("call matchlist('x x', '\\%#=1 \\zs*')", 'E888:')
|
call assert_fails("call matchlist('x x', '\\%#=1 \\zs*')", 'E888:')
|
||||||
|
@@ -750,6 +750,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 */
|
||||||
|
/**/
|
||||||
|
2121,
|
||||||
/**/
|
/**/
|
||||||
2120,
|
2120,
|
||||||
/**/
|
/**/
|
||||||
|
Reference in New Issue
Block a user