ValueFlow: Better handling of Known/Possible values after conditional unknown function call

This commit is contained in:
Daniel Marjamäki 2015-07-21 17:56:40 +02:00
parent 7f6b6e43b1
commit ffc707246b
2 changed files with 18 additions and 0 deletions

View File

@ -279,6 +279,17 @@ static bool isVariableChanged(const Token *start, const Token *end, const unsign
if (Token::Match(tok->tokAt(-2), "[(,] & %var% [,)]")) if (Token::Match(tok->tokAt(-2), "[(,] & %var% [,)]"))
return true; // TODO: check if function parameter is const return true; // TODO: check if function parameter is const
if (Token::Match(tok->previous(), "[(,] %var% [,)]")) {
const Token *parent = tok->astParent();
while (parent && parent->str() == ",")
parent = parent->astParent();
if (parent && parent->str() == "(") {
if (parent->astOperand1()->isName() && !parent->astOperand1()->function())
return true;
// TODO: check if function parameter is non-const reference etc..
}
}
const Token *parent = tok->astParent(); const Token *parent = tok->astParent();
while (Token::Match(parent, ".|::")) while (Token::Match(parent, ".|::"))
parent = parent->astParent(); parent = parent->astParent();

View File

@ -1579,6 +1579,13 @@ private:
ASSERT_EQUALS(9, value.intvalue); ASSERT_EQUALS(9, value.intvalue);
ASSERT_EQUALS(ValueFlow::Value::ValueKind::Possible, value.valueKind); ASSERT_EQUALS(ValueFlow::Value::ValueKind::Possible, value.valueKind);
code = "void f() {\n"
" int x = 0;\n"
" if (y) { dostuff(x); }\n"
" if (!x) {}\n"
"}\n";
ASSERT(isNotKnownValues(code, "!"));
code = "void f() {\n" code = "void f() {\n"
" int x = 0;\n" " int x = 0;\n"
" for (int i = 0; i < 10; i++) {\n" " for (int i = 0; i < 10; i++) {\n"