Fixed #5012 (Hang when there is syntax error 'else }')

This commit is contained in:
Daniel Marjamäki 2013-09-05 06:38:07 +02:00
parent 2fe91e290c
commit 9000c233fa
2 changed files with 10 additions and 3 deletions

View File

@ -4103,9 +4103,7 @@ bool Tokenizer::simplifyAddBraces()
Token *Tokenizer::simplifyAddBracesToCommand(Token *tok) Token *Tokenizer::simplifyAddBracesToCommand(Token *tok)
{ {
Token * tokEnd=tok; Token * tokEnd=tok;
if (tok->str()=="for" || if (Token::Match(tok,"for|switch|BOOST_FOREACH")) {
tok->str()=="BOOST_FOREACH" ||
tok->str()=="switch") {
tokEnd=simplifyAddBracesPair(tok,true); tokEnd=simplifyAddBracesPair(tok,true);
} else if (tok->str()=="while") { } else if (tok->str()=="while") {
Token *tokPossibleDo=tok->previous(); Token *tokPossibleDo=tok->previous();
@ -4142,6 +4140,9 @@ Token *Tokenizer::simplifyAddBracesToCommand(Token *tok)
if (tokEndNextNext && tokEndNextNext->str()=="if") { if (tokEndNextNext && tokEndNextNext->str()=="if") {
// do not change "else if ..." to "else { if ... }" // do not change "else if ..." to "else { if ... }"
tokEnd=simplifyAddBracesToCommand(tokEndNextNext); tokEnd=simplifyAddBracesToCommand(tokEndNextNext);
} else if (Token::simpleMatch(tokEndNext, "else }")) {
syntaxError(tokEndNext);
return NULL;
} else } else
tokEnd=simplifyAddBracesPair(tokEndNext,false); tokEnd=simplifyAddBracesPair(tokEndNext,false);
} }

View File

@ -116,6 +116,7 @@ private:
TEST_CASE(ifAddBraces17); // '} else' should be in the same line TEST_CASE(ifAddBraces17); // '} else' should be in the same line
TEST_CASE(ifAddBraces18); // #3424 - if if { } else else TEST_CASE(ifAddBraces18); // #3424 - if if { } else else
TEST_CASE(ifAddBraces19); // #3928 - if for if else TEST_CASE(ifAddBraces19); // #3928 - if for if else
TEST_CASE(ifAddBraces20); // #5012 - syntax error 'else }'
TEST_CASE(whileAddBraces); TEST_CASE(whileAddBraces);
TEST_CASE(doWhileAddBraces); TEST_CASE(doWhileAddBraces);
@ -1345,6 +1346,11 @@ private:
"}", tokenizeAndStringify(code, true)); "}", tokenizeAndStringify(code, true));
} }
void ifAddBraces20() { // #5012 - syntax error 'else }'
const char code[] = "void f() { if(x) {} else }";
tokenizeAndStringify(code,true);
ASSERT_EQUALS("[test.cpp:1]: (error) syntax error\n", errout.str());
}
void whileAddBraces() { void whileAddBraces() {
const char code[] = ";while(a);"; const char code[] = ";while(a);";