1
0
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:
Bram Moolenaar
2020-12-09 16:36:04 +01:00
parent 730677a0da
commit a7a691cc14
4 changed files with 43 additions and 0 deletions

View File

@@ -4805,6 +4805,23 @@ theend:
if (backpos.ga_maxlen > BACKPOS_INITIAL)
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;
}

View File

@@ -7225,6 +7225,23 @@ nfa_regexec_both(
#endif
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;
}

View File

@@ -911,6 +911,13 @@ func Test_start_end_of_buffer_match()
bwipe!
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
func Test_regexp_error()
call assert_fails("call matchlist('x x', '\\%#=1 \\zs*')", 'E888:')

View File

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