Merge pull request #293 from simartin/ticket_5709
Ticket #5709: Comma operator not properly tokenized.
This commit is contained in:
commit
5edb6092a1
|
@ -7086,6 +7086,7 @@ bool Tokenizer::simplifyRedundantParentheses()
|
||||||
|
|
||||||
while (Token::Match(tok->previous(), "[{([,] ( !!{") &&
|
while (Token::Match(tok->previous(), "[{([,] ( !!{") &&
|
||||||
Token::Match(tok->link(), ") [;,])]") &&
|
Token::Match(tok->link(), ") [;,])]") &&
|
||||||
|
!Token::simpleMatch(tok->tokAt(-2), "operator ,") && // Ticket #5709
|
||||||
!Token::findsimplematch(tok, ",", tok->link())) {
|
!Token::findsimplematch(tok, ",", tok->link())) {
|
||||||
// We have "( ... )", remove the parentheses
|
// We have "( ... )", remove the parentheses
|
||||||
tok->link()->deleteThis();
|
tok->link()->deleteThis();
|
||||||
|
@ -10161,7 +10162,7 @@ void Tokenizer::simplifyOperatorName()
|
||||||
}
|
}
|
||||||
done = false;
|
done = false;
|
||||||
}
|
}
|
||||||
if (Token::Match(par, ".|%op%")) {
|
if (Token::Match(par, ".|%op%|,")) {
|
||||||
op += par->str();
|
op += par->str();
|
||||||
par = par->next();
|
par = par->next();
|
||||||
done = false;
|
done = false;
|
||||||
|
|
|
@ -507,6 +507,7 @@ private:
|
||||||
TEST_CASE(simplifyOperatorName6); // ticket #3194
|
TEST_CASE(simplifyOperatorName6); // ticket #3194
|
||||||
TEST_CASE(simplifyOperatorName7); // ticket #4619
|
TEST_CASE(simplifyOperatorName7); // ticket #4619
|
||||||
TEST_CASE(simplifyOperatorName8); // ticket #5706
|
TEST_CASE(simplifyOperatorName8); // ticket #5706
|
||||||
|
TEST_CASE(simplifyOperatorName9); // ticket #5709 - comma operator not properly tokenized
|
||||||
|
|
||||||
TEST_CASE(simplifyNull);
|
TEST_CASE(simplifyNull);
|
||||||
|
|
||||||
|
@ -8173,6 +8174,11 @@ private:
|
||||||
ASSERT_EQUALS(result6, tokenizeAndStringify(code6,false));
|
ASSERT_EQUALS(result6, tokenizeAndStringify(code6,false));
|
||||||
}
|
}
|
||||||
|
|
||||||
|
void simplifyOperatorName9() { // Ticket #5709
|
||||||
|
const char code[] = "struct R { R operator, ( R b ) ; } ;";
|
||||||
|
ASSERT_EQUALS(code, tokenizeAndStringify(code));
|
||||||
|
}
|
||||||
|
|
||||||
void simplifyNull() {
|
void simplifyNull() {
|
||||||
ASSERT_EQUALS("if ( ! p )", tokenizeAndStringify("if (p==NULL)"));
|
ASSERT_EQUALS("if ( ! p )", tokenizeAndStringify("if (p==NULL)"));
|
||||||
ASSERT_EQUALS("f ( NULL ) ;", tokenizeAndStringify("f(NULL);"));
|
ASSERT_EQUALS("f ( NULL ) ;", tokenizeAndStringify("f(NULL);"));
|
||||||
|
|
Loading…
Reference in New Issue