Fixed #4239 (segmentation fault of cppcheck (invalid code))

This commit is contained in:
Alexander Mai 2012-09-27 06:35:36 +02:00 committed by Daniel Marjamäki
parent b15cb09af6
commit 074b7781b2
2 changed files with 18 additions and 10 deletions

View File

@ -1016,6 +1016,7 @@ void Tokenizer::simplifyTypedef()
if (!func)
continue;
if (func->previous()) { // Ticket #4239
/** @todo add support for multi-token operators */
if (func->previous()->str() == "operator")
func = func->previous();
@ -1030,6 +1031,7 @@ void Tokenizer::simplifyTypedef()
}
}
}
}
// check for entering a new namespace
else if (Token::Match(tok2, "namespace %any% {")) {

View File

@ -57,6 +57,7 @@ private:
TEST_CASE(tokenize22); // special marker $ from preprocessor
TEST_CASE(tokenize23); // tokenize "return - __LINE__;"
TEST_CASE(tokenize24); // #4195 (segmentation fault)
TEST_CASE(tokenize25); // #4239 (segmentation fault)
// don't freak out when the syntax is wrong
TEST_CASE(wrong_syntax1);
@ -651,6 +652,11 @@ private:
tokenizeAndStringify("enum { int f ( ) { return = } r = f ( ) ; }");
}
// #4239 - segfault for "f ( struct { int typedef T x ; } ) { }"
void tokenize25() {
tokenizeAndStringify("f ( struct { int typedef T x ; } ) { }");
}
void wrong_syntax1() {
{
const std::string code("TR(kvmpio, PROTO(int rw), ARGS(rw), TP_(aa->rw;))");