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:
@@ -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;
|
||||||
|
|||||||
@@ -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;
|
||||||
|
|||||||
@@ -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,
|
||||||
/**/
|
/**/
|
||||||
|
|||||||
Reference in New Issue
Block a user