Ticket #6103: Simplify "new (type)" constructs into "new type" to avoid confusion upon certain input.
This commit is contained in:
parent
36e53369cb
commit
eeeb816db9
|
@ -7108,6 +7108,13 @@ bool Tokenizer::simplifyRedundantParentheses()
|
||||||
ret = true;
|
ret = true;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
if (isCPP() && Token::simpleMatch(tok->previous(), "new (") && Token::Match(tok->link(), ") [;,{}[]")) {
|
||||||
|
// Remove the parentheses in "new (type)" constructs
|
||||||
|
tok->link()->deleteThis();
|
||||||
|
tok->deleteThis();
|
||||||
|
ret = true;
|
||||||
|
}
|
||||||
|
|
||||||
if (Token::Match(tok->previous(), "! ( %var% )")) {
|
if (Token::Match(tok->previous(), "! ( %var% )")) {
|
||||||
// Remove the parentheses
|
// Remove the parentheses
|
||||||
tok->deleteThis();
|
tok->deleteThis();
|
||||||
|
|
|
@ -384,6 +384,7 @@ private:
|
||||||
TEST_CASE(removeParentheses20); // Ticket #5479: a<b<int>>(2);
|
TEST_CASE(removeParentheses20); // Ticket #5479: a<b<int>>(2);
|
||||||
TEST_CASE(removeParentheses21); // Don't "simplify" casts
|
TEST_CASE(removeParentheses21); // Don't "simplify" casts
|
||||||
TEST_CASE(removeParentheses22);
|
TEST_CASE(removeParentheses22);
|
||||||
|
TEST_CASE(removeParentheses23); // Ticket #6103 - Infinite loop upon valid input
|
||||||
|
|
||||||
TEST_CASE(tokenize_double);
|
TEST_CASE(tokenize_double);
|
||||||
TEST_CASE(tokenize_strings);
|
TEST_CASE(tokenize_strings);
|
||||||
|
@ -5911,6 +5912,31 @@ private:
|
||||||
ASSERT_EQUALS(exp, tokenizeAndStringify(code));
|
ASSERT_EQUALS(exp, tokenizeAndStringify(code));
|
||||||
}
|
}
|
||||||
|
|
||||||
|
void removeParentheses23() { // Ticket #6103
|
||||||
|
// Reported case
|
||||||
|
{
|
||||||
|
static char code[] = "* * p f ( ) int = { new int ( * [ 2 ] ) ; void }";
|
||||||
|
static char exp[] = "* * p f ( ) int = { new int ( * [ 2 ] ) ; void }";
|
||||||
|
ASSERT_EQUALS(exp, tokenizeAndStringify(code));
|
||||||
|
}
|
||||||
|
// Various valid cases
|
||||||
|
{
|
||||||
|
static char code[] = "int * f [ 1 ] = { new ( int ) } ;";
|
||||||
|
static char exp[] = "int * f [ 1 ] = { new int } ;";
|
||||||
|
ASSERT_EQUALS(exp, tokenizeAndStringify(code));
|
||||||
|
}
|
||||||
|
{
|
||||||
|
static char code[] = "int * * f [ 1 ] = { new ( int ) [ 1 ] } ;";
|
||||||
|
static char exp[] = "int * * f [ 1 ] = { new int [ 1 ] } ;";
|
||||||
|
ASSERT_EQUALS(exp, tokenizeAndStringify(code));
|
||||||
|
}
|
||||||
|
{
|
||||||
|
static char code[] = "list < int > * f [ 1 ] = { new ( list < int > ) } ;";
|
||||||
|
static char exp[] = "list < int > * f [ 1 ] = { new list < int > } ;";
|
||||||
|
ASSERT_EQUALS(exp, tokenizeAndStringify(code));
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
void tokenize_double() {
|
void tokenize_double() {
|
||||||
const char code[] = "void f()\n"
|
const char code[] = "void f()\n"
|
||||||
"{\n"
|
"{\n"
|
||||||
|
|
Loading…
Reference in New Issue