checkclass: refactoring

This commit is contained in:
Daniel Marjamäki 2009-02-24 17:48:11 +00:00
parent 159332fde4
commit 8c3e3faa07
2 changed files with 24 additions and 3 deletions

View File

@ -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)

View File

@ -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());
}