Fix issue 8884: Regression: False positive: Variable 'f' is reassigned a value before the old one has been used (#1513)
This commit is contained in:
parent
0ab378b9cf
commit
6953dddfa6
|
@ -491,6 +491,9 @@ void CheckOther::checkRedundantAssignment()
|
|||
if (!nextAssign)
|
||||
continue;
|
||||
|
||||
if (nextAssign == tok)
|
||||
continue;
|
||||
|
||||
// there is redundant assignment. Is there a case between the assignments?
|
||||
bool hasCase = false;
|
||||
for (const Token *tok2 = tok; tok2 != nextAssign; tok2 = tok2->next()) {
|
||||
|
|
|
@ -5968,6 +5968,14 @@ private:
|
|||
" memptr = 0;\n"
|
||||
"}");
|
||||
ASSERT_EQUALS("[test.cpp:3] -> [test.cpp:4]: (style) Variable 'memptr' is reassigned a value before the old one has been used.\n", errout.str());
|
||||
|
||||
// issue #8884
|
||||
check("template <class F, class... Ts>\n"
|
||||
"auto foo(F f, Ts... xs) {\n"
|
||||
" auto x = f(xs...);\n"
|
||||
" return x;\n"
|
||||
"}\n");
|
||||
ASSERT_EQUALS("", errout.str());
|
||||
}
|
||||
|
||||
void redundantVarAssignment_struct() {
|
||||
|
|
Loading…
Reference in New Issue