Fixed #9926 (False positive assertWithSideEffects, calling method that has no side effects)
This commit is contained in:
parent
3e16367a97
commit
b8b6be48d9
|
@ -59,12 +59,13 @@ void CheckAssert::assertWithSideEffects()
|
||||||
continue;
|
continue;
|
||||||
|
|
||||||
const Function* f = tmp->function();
|
const Function* f = tmp->function();
|
||||||
if (f->nestedIn->isClassOrStruct() && !f->isStatic() && !f->isConst()) {
|
const Scope* scope = f->functionScope;
|
||||||
sideEffectInAssertError(tmp, f->name()); // Non-const member function called
|
if (!scope) {
|
||||||
|
// guess that const method doesn't have side effects
|
||||||
|
if (f->nestedIn->isClassOrStruct() && !f->isConst() && !f->isStatic())
|
||||||
|
sideEffectInAssertError(tmp, f->name()); // Non-const member function called, assume it has side effects
|
||||||
continue;
|
continue;
|
||||||
}
|
}
|
||||||
const Scope* scope = f->functionScope;
|
|
||||||
if (!scope) continue;
|
|
||||||
|
|
||||||
for (const Token *tok2 = scope->bodyStart; tok2 != scope->bodyEnd; tok2 = tok2->next()) {
|
for (const Token *tok2 = scope->bodyStart; tok2 != scope->bodyEnd; tok2 = tok2->next()) {
|
||||||
if (!tok2->isAssignmentOp() && tok2->tokType() != Token::eIncDecOp)
|
if (!tok2->isAssignmentOp() && tok2->tokType() != Token::eIncDecOp)
|
||||||
|
|
|
@ -133,6 +133,17 @@ private:
|
||||||
" assert( !SquarePack::isRank1Or8(push2) );\n"
|
" assert( !SquarePack::isRank1Or8(push2) );\n"
|
||||||
"}");
|
"}");
|
||||||
ASSERT_EQUALS("", errout.str());
|
ASSERT_EQUALS("", errout.str());
|
||||||
|
|
||||||
|
check("struct Geometry {\n"
|
||||||
|
" int nbv;\n"
|
||||||
|
" int empty() { return (nbv == 0); }\n"
|
||||||
|
" void ReadGeometry();\n"
|
||||||
|
"};\n"
|
||||||
|
"\n"
|
||||||
|
"void Geometry::ReadGeometry() {\n"
|
||||||
|
" assert(empty());\n"
|
||||||
|
"}");
|
||||||
|
ASSERT_EQUALS("", errout.str());
|
||||||
}
|
}
|
||||||
|
|
||||||
void memberFunctionCallInAssert() {
|
void memberFunctionCallInAssert() {
|
||||||
|
@ -145,7 +156,7 @@ private:
|
||||||
ASSERT_EQUALS("[test.cpp:5]: (warning) Assert statement calls a function which may have desired side effects: 'Foo'.\n", errout.str());
|
ASSERT_EQUALS("[test.cpp:5]: (warning) Assert statement calls a function which may have desired side effects: 'Foo'.\n", errout.str());
|
||||||
|
|
||||||
check("struct SquarePack {\n"
|
check("struct SquarePack {\n"
|
||||||
" void Foo() const;\n"
|
" int Foo() const;\n"
|
||||||
"};\n"
|
"};\n"
|
||||||
"void foo(SquarePack* s) {\n"
|
"void foo(SquarePack* s) {\n"
|
||||||
" assert( s->Foo() );\n"
|
" assert( s->Foo() );\n"
|
||||||
|
@ -153,7 +164,7 @@ private:
|
||||||
ASSERT_EQUALS("", errout.str());
|
ASSERT_EQUALS("", errout.str());
|
||||||
|
|
||||||
check("struct SquarePack {\n"
|
check("struct SquarePack {\n"
|
||||||
" static void Foo();\n"
|
" static int Foo();\n"
|
||||||
"};\n"
|
"};\n"
|
||||||
"void foo(SquarePack* s) {\n"
|
"void foo(SquarePack* s) {\n"
|
||||||
" assert( s->Foo() );\n"
|
" assert( s->Foo() );\n"
|
||||||
|
|
Loading…
Reference in New Issue