1
0
forked from aniani/vim

patch 8.2.2181: valgrind warnings for using uninitialized value

Problem:    Valgrind warnings for using uninitialized value.
Solution:   Do not use "start" or "end" unless there is a match.
This commit is contained in:
Bram Moolenaar
2020-12-21 18:24:00 +01:00
parent 6f17a3f023
commit a3d10a508c
3 changed files with 32 additions and 24 deletions

View File

@@ -4805,21 +4805,24 @@ 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 if (retval > 0)
// \ze are used.
if (REG_MULTI)
{ {
lpos_T *start = &rex.reg_mmatch->startpos[0]; // Make sure the end is never before the start. Can happen when \zs
lpos_T *end = &rex.reg_mmatch->endpos[0]; // 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 if (end->lnum < start->lnum
|| (end->lnum == start->lnum && end->col < start->col)) || (end->lnum == start->lnum && end->col < start->col))
rex.reg_mmatch->endpos[0] = rex.reg_mmatch->startpos[0]; rex.reg_mmatch->endpos[0] = rex.reg_mmatch->startpos[0];
} }
else else
{ {
if (rex.reg_match->endp[0] < rex.reg_match->startp[0]) if (rex.reg_match->endp[0] < rex.reg_match->startp[0])
rex.reg_match->endp[0] = rex.reg_match->startp[0]; rex.reg_match->endp[0] = rex.reg_match->startp[0];
}
} }
return retval; return retval;

View File

@@ -7227,21 +7227,24 @@ nfa_regexec_both(
#endif #endif
theend: theend:
// Make sure the end is never before the start. Can happen when \zs and if (retval > 0)
// \ze are used.
if (REG_MULTI)
{ {
lpos_T *start = &rex.reg_mmatch->startpos[0]; // Make sure the end is never before the start. Can happen when \zs and
lpos_T *end = &rex.reg_mmatch->endpos[0]; // \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 if (end->lnum < start->lnum
|| (end->lnum == start->lnum && end->col < start->col)) || (end->lnum == start->lnum && end->col < start->col))
rex.reg_mmatch->endpos[0] = rex.reg_mmatch->startpos[0]; rex.reg_mmatch->endpos[0] = rex.reg_mmatch->startpos[0];
} }
else if (retval > 0) else
{ {
if (rex.reg_match->endp[0] < rex.reg_match->startp[0]) if (rex.reg_match->endp[0] < rex.reg_match->startp[0])
rex.reg_match->endp[0] = rex.reg_match->startp[0]; rex.reg_match->endp[0] = rex.reg_match->startp[0];
}
} }
return retval; return retval;

View File

@@ -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 */
/**/
2181,
/**/ /**/
2180, 2180,
/**/ /**/