Improved fix for #4455, no false negatives if variable is used before first memset
This commit is contained in:
parent
cf75e2bb28
commit
b2798e929d
|
@ -629,6 +629,17 @@ void CheckOther::checkRedundantAssignment()
|
||||||
varAssignments.clear();
|
varAssignments.clear();
|
||||||
memAssignments.clear();
|
memAssignments.clear();
|
||||||
} else if (tok->type() == Token::eVariable) {
|
} else if (tok->type() == Token::eVariable) {
|
||||||
|
// Set initialization flag
|
||||||
|
if (!Token::Match(tok, "%var% ["))
|
||||||
|
initialized.insert(tok->varId());
|
||||||
|
else {
|
||||||
|
const Token *tok2 = tok->next();
|
||||||
|
while (tok2 && tok2->str() == "[")
|
||||||
|
tok2 = tok2->link()->next();
|
||||||
|
if (tok2 && tok2->str() != ";")
|
||||||
|
initialized.insert(tok->varId());
|
||||||
|
}
|
||||||
|
|
||||||
std::map<unsigned int, const Token*>::iterator it = varAssignments.find(tok->varId());
|
std::map<unsigned int, const Token*>::iterator it = varAssignments.find(tok->varId());
|
||||||
if (tok->next()->isAssignmentOp() && Token::Match(tok->previous(), "[;{}]")) { // Assignment
|
if (tok->next()->isAssignmentOp() && Token::Match(tok->previous(), "[;{}]")) { // Assignment
|
||||||
if (it != varAssignments.end()) {
|
if (it != varAssignments.end()) {
|
||||||
|
|
|
@ -5956,6 +5956,13 @@ private:
|
||||||
" strcpy(buf, string);\n"
|
" strcpy(buf, string);\n"
|
||||||
"}");
|
"}");
|
||||||
ASSERT_EQUALS("", errout.str());
|
ASSERT_EQUALS("", errout.str());
|
||||||
|
|
||||||
|
check("void f(void) {\n"
|
||||||
|
" char buf[10] = {0};\n"
|
||||||
|
" memset(buf, 0, 10);\n"
|
||||||
|
" strcpy(buf, string);\n"
|
||||||
|
"}");
|
||||||
|
ASSERT_EQUALS("[test.cpp:3] -> [test.cpp:4]: (performance) Buffer 'buf' is being written before its old content has been used.\n", errout.str());
|
||||||
}
|
}
|
||||||
|
|
||||||
void varFuncNullUB() { // #4482
|
void varFuncNullUB() { // #4482
|
||||||
|
|
Loading…
Reference in New Issue