Partial fix for #11189 checkLibraryNoReturn with std::function parameter

This commit is contained in:
chrchr-github 2023-06-13 21:48:16 +02:00
parent 09cd3a8269
commit 457e0ce0c8
2 changed files with 11 additions and 3 deletions

View File

@ -7772,7 +7772,7 @@ bool Tokenizer::isScopeNoReturn(const Token *endScopeToken, bool *unknown) const
bool warn = true;
if (Token::simpleMatch(endScopeToken->tokAt(-2), ") ; }")) {
const Token * const ftok = endScopeToken->linkAt(-2)->previous();
if (ftok && (ftok->type() || ftok->function())) // constructor call
if (ftok && (ftok->type() || ftok->function() || ftok->variable())) // constructor call
warn = false;
}

View File

@ -2652,12 +2652,20 @@ private:
ASSERT_EQUALS("[test.cpp:5]: (error) Resource leak: file\n", errout.str());
}
void configuration6() { // #11198
check("void f() {}\n"
void configuration6() {
check("void f() {}\n" // #11198
"void g() {\n"
" f();\n"
"}\n");
ASSERT_EQUALS("", errout.str());
check("void f(std::function<void()> cb) {\n" // #11189
" cb();\n"
"}\n"
"void g(void (*cb)()) {\n"
" cb();\n"
"}\n", /*cpp*/ true);
ASSERT_EQUALS("", errout.str());
}
void ptrptr() {