finish fixing #2624 (better function pointer support needed)

This commit is contained in:
Robert Reif 2011-03-05 21:41:58 -05:00
parent 7d2fb2ecde
commit 0debba4409
2 changed files with 35 additions and 3 deletions

View File

@ -5385,7 +5385,39 @@ void Tokenizer:: simplifyFunctionPointers()
{ {
for (Token *tok = _tokens; tok; tok = tok->next()) for (Token *tok = _tokens; tok; tok = tok->next())
{ {
if (tok->previous() && !Token::Match(tok->previous(), "{|}|;|(|public:|protected:|private:")) // check for function pointer cast
if (Token::Match(tok, "( %type% *| *| ( * ) (") ||
Token::Match(tok, "( %type% %type% *| *| ( * ) (") ||
Token::Match(tok, "static_cast < %type% *| *| ( * ) (") ||
Token::Match(tok, "static_cast < %type% %type% *| *| ( * ) ("))
{
Token *tok1 = tok;
if (tok1->str() == "static_cast")
tok1 = tok1->next();
tok1 = tok1->next();
if (Token::Match(tok1->next(), "%type%"))
tok1 = tok1->next();
while (tok1->next()->str() == "*")
tok1 = tok1->next();
// check that the cast ends
if (!Token::Match(tok1->tokAt(4)->link(), ") )|>"))
continue;
// ok simplify this function pointer cast to an ordinary pointer cast
tok1->deleteNext();
tok1->next()->deleteNext();
const Token *tok2 = tok1->tokAt(2)->link();
Token::eraseTokens(tok1->next(), tok2 ? tok2->next() : 0);
continue;
}
// check for start of statement
else if (tok->previous() && !Token::Match(tok->previous(), "{|}|;|(|public:|protected:|private:"))
continue; continue;
if (Token::Match(tok, "%type% *| *| ( * %var% ) (")) if (Token::Match(tok, "%type% *| *| ( * %var% ) ("))

View File

@ -3576,7 +3576,7 @@ private:
"; " "; "
"void g ( int * f ) " "void g ( int * f ) "
"{ " "{ "
"int * f2 ; f2 = ( int ( * ) ( ) ) f ; " "int * f2 ; f2 = ( int * ) f ; "
"}"; "}";
ASSERT_EQUALS(expected, tok(code, false)); ASSERT_EQUALS(expected, tok(code, false));
@ -3593,7 +3593,7 @@ private:
"; " "; "
"void g ( int * f ) " "void g ( int * f ) "
"{ " "{ "
"int * f2 ; f2 = static_cast < int ( * ) ( ) > ( f ) ; " "int * f2 ; f2 = static_cast < int * > ( f ) ; "
"}"; "}";
ASSERT_EQUALS(expected, tok(code, false)); ASSERT_EQUALS(expected, tok(code, false));