Fixed false positive #5772: Use AST to check if modulo operation is preceded by an arithmetical operation.
This commit is contained in:
parent
6384aba214
commit
c0fc47643f
|
@ -3005,7 +3005,7 @@ void CheckOther::checkModuloAlwaysTrueFalse()
|
||||||
const Scope * scope = symbolDatabase->functionScopes[i];
|
const Scope * scope = symbolDatabase->functionScopes[i];
|
||||||
for (const Token* tok = scope->classStart->next(); tok != scope->classEnd; tok = tok->next()) {
|
for (const Token* tok = scope->classStart->next(); tok != scope->classEnd; tok = tok->next()) {
|
||||||
if ((Token::Match(tok, "% %num% %comp% %num%")) &&
|
if ((Token::Match(tok, "% %num% %comp% %num%")) &&
|
||||||
(!tok->tokAt(4) || !tok->tokAt(4)->isArithmeticalOp())) {
|
(!tok->tokAt(4) || !tok->tokAt(4)->isArithmeticalOp()) && (!tok->astParent() || !tok->astParent()->isArithmeticalOp())) {
|
||||||
if (MathLib::isLessEqual(tok->strAt(1), tok->strAt(3)))
|
if (MathLib::isLessEqual(tok->strAt(1), tok->strAt(3)))
|
||||||
moduloAlwaysTrueFalseError(tok, tok->strAt(1));
|
moduloAlwaysTrueFalseError(tok, tok->strAt(1));
|
||||||
}
|
}
|
||||||
|
|
|
@ -3721,6 +3721,12 @@ private:
|
||||||
ASSERT_EQUALS("[test.cpp:2]: (warning) Comparison of modulo result is predetermined, because it is always less than 5.\n"
|
ASSERT_EQUALS("[test.cpp:2]: (warning) Comparison of modulo result is predetermined, because it is always less than 5.\n"
|
||||||
"[test.cpp:3]: (warning) Comparison of modulo result is predetermined, because it is always less than 5.\n"
|
"[test.cpp:3]: (warning) Comparison of modulo result is predetermined, because it is always less than 5.\n"
|
||||||
"[test.cpp:4]: (warning) Comparison of modulo result is predetermined, because it is always less than 5.\n", errout.str());
|
"[test.cpp:4]: (warning) Comparison of modulo result is predetermined, because it is always less than 5.\n", errout.str());
|
||||||
|
|
||||||
|
check("void f() {\n"
|
||||||
|
" if (a % 2 + b % 2 == 2)\n"
|
||||||
|
" foo();\n"
|
||||||
|
"}");
|
||||||
|
ASSERT_EQUALS("", errout.str());
|
||||||
}
|
}
|
||||||
|
|
||||||
void incorrectLogicOperator1() {
|
void incorrectLogicOperator1() {
|
||||||
|
|
Loading…
Reference in New Issue