Ticket #5214: Don't read out of bounds upon invalid ternary operator.
This commit is contained in:
parent
e2bc99aa24
commit
02dc49624d
|
@ -2566,6 +2566,8 @@ static Token *skipTernaryOp(Token *tok)
|
|||
if (Token::Match(tok->next(), "[{};]"))
|
||||
break;
|
||||
}
|
||||
if (colonlevel) // Ticket #5214: Make sure the ':' matches the proper '?'
|
||||
return 0;
|
||||
return tok;
|
||||
}
|
||||
|
||||
|
@ -2606,7 +2608,12 @@ bool Tokenizer::simplifyLabelsCaseDefault()
|
|||
if (tok->str() == "(" || tok->str() == "[") {
|
||||
tok = tok->link();
|
||||
} else if (tok->str() == "?") {
|
||||
tok = skipTernaryOp(tok);
|
||||
Token *tok1 = skipTernaryOp(tok);
|
||||
if(!tok1) {
|
||||
syntaxError(tok);
|
||||
return false;
|
||||
}
|
||||
tok = tok1;
|
||||
}
|
||||
if (Token::Match(tok->next(),"[:{};]"))
|
||||
break;
|
||||
|
|
|
@ -75,6 +75,7 @@ private:
|
|||
TEST_CASE(garbageCode3); // #4869
|
||||
TEST_CASE(garbageCode4); // #4887
|
||||
TEST_CASE(garbageCode5); // #5168
|
||||
TEST_CASE(garbageCode6); // #5214
|
||||
|
||||
TEST_CASE(simplifyFileAndLineMacro); // tokenize "return - __LINE__;"
|
||||
|
||||
|
@ -982,6 +983,11 @@ private:
|
|||
tokenizeAndStringify("( asm : ; void : );");
|
||||
}
|
||||
|
||||
void garbageCode6() { // #5214
|
||||
tokenizeAndStringify("int b = ( 0 ? ? ) 1 : 0 ;", /*simplify=*/true);
|
||||
tokenizeAndStringify("int a = int b = ( 0 ? ? ) 1 : 0 ;", /*simplify=*/true);
|
||||
}
|
||||
|
||||
void simplifyFileAndLineMacro() { // tokenize 'return - __LINE__' correctly
|
||||
ASSERT_EQUALS("\"test.cpp\"", tokenizeAndStringify("__FILE__"));
|
||||
ASSERT_EQUALS("return -1 ;", tokenizeAndStringify("return - __LINE__;"));
|
||||
|
|
Loading…
Reference in New Issue