checkclass: refactoring
This commit is contained in:
parent
159332fde4
commit
8c3e3faa07
|
@ -476,7 +476,7 @@ void CheckClass::privateFunctions()
|
|||
|
||||
// The class implementation must be available..
|
||||
const std::string classconstructor(classname + " :: " + classname);
|
||||
if (!Token::findmatch(_tokenizer->tokens(), classconstructor.c_str()))
|
||||
if (tok1->fileIndex()>0 && !Token::findmatch(_tokenizer->tokens(), classconstructor.c_str()))
|
||||
continue;
|
||||
|
||||
// Get private functions..
|
||||
|
@ -549,13 +549,13 @@ void CheckClass::privateFunctions()
|
|||
{
|
||||
if (ftok->str() == "{")
|
||||
++indent_level;
|
||||
if (ftok->str() == "}")
|
||||
else if (ftok->str() == "}")
|
||||
{
|
||||
if (indent_level <= 1)
|
||||
break;
|
||||
--indent_level;
|
||||
}
|
||||
if (Token::Match(ftok->next(), "("))
|
||||
else if (Token::Match(ftok, "%var% ("))
|
||||
{
|
||||
// Remove function from FuncList
|
||||
for (std::list<const Token *>::iterator it = FuncList.begin(); it != FuncList.end(); ++it)
|
||||
|
|
|
@ -36,6 +36,7 @@ private:
|
|||
void run()
|
||||
{
|
||||
TEST_CASE(test1);
|
||||
TEST_CASE(test2);
|
||||
|
||||
// [ 2236547 ] False positive --style unused function, called via pointer
|
||||
TEST_CASE(func_pointer);
|
||||
|
@ -81,6 +82,26 @@ private:
|
|||
}
|
||||
|
||||
|
||||
void test2()
|
||||
{
|
||||
check("class A {\n"
|
||||
"public:\n"
|
||||
" A();\n"
|
||||
"\n"
|
||||
" void a() const\n"
|
||||
" { b(); }\n"
|
||||
"private:\n"
|
||||
" void b( ) const\n"
|
||||
" { }\n"
|
||||
"};\n"
|
||||
"\n"
|
||||
"A::A()\n"
|
||||
"{ }\n");
|
||||
ASSERT_EQUALS(std::string(""), errout.str());
|
||||
}
|
||||
|
||||
|
||||
|
||||
|
||||
|
||||
|
||||
|
|
Loading…
Reference in New Issue