Partial fix ticket #3385 ('throw' isn't removed if the argument of the function is type 'struct|class').
This commit is contained in:
parent
4884a1dfe0
commit
eb5fe250ab
|
@ -8816,16 +8816,24 @@ void Tokenizer::removeExceptionSpecifications(Token *tok) const
|
||||||
tok->deleteNext();
|
tok->deleteNext();
|
||||||
}
|
}
|
||||||
|
|
||||||
else if (Token::Match(tok, "class|namespace|struct %type%")) {
|
else if (Token::Match(tok, "class|namespace|struct %type% :|{")) {
|
||||||
|
tok = tok->tokAt(2);
|
||||||
while (tok && !Token::Match(tok, "[;{=]"))
|
while (tok && !Token::Match(tok, "[;{=]"))
|
||||||
tok = tok->next();
|
tok = tok->next();
|
||||||
if (tok && tok->str() == "{") {
|
if (tok && tok->str() == "{") {
|
||||||
removeExceptionSpecifications(tok->next());
|
removeExceptionSpecifications(tok->next());
|
||||||
tok = tok->link();
|
tok = tok->link();
|
||||||
}
|
} else
|
||||||
|
continue;
|
||||||
}
|
}
|
||||||
|
|
||||||
tok = tok ? tok->next() : 0;
|
else if (Token::simpleMatch(tok, "namespace {")) {
|
||||||
|
tok = tok->next();
|
||||||
|
removeExceptionSpecifications(tok->next());
|
||||||
|
tok = tok->link();
|
||||||
|
}
|
||||||
|
|
||||||
|
tok = tok->next();
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
|
@ -297,6 +297,8 @@ private:
|
||||||
TEST_CASE(removeExceptionSpecification1);
|
TEST_CASE(removeExceptionSpecification1);
|
||||||
TEST_CASE(removeExceptionSpecification2);
|
TEST_CASE(removeExceptionSpecification2);
|
||||||
TEST_CASE(removeExceptionSpecification3);
|
TEST_CASE(removeExceptionSpecification3);
|
||||||
|
TEST_CASE(removeExceptionSpecification4);
|
||||||
|
TEST_CASE(removeExceptionSpecification5);
|
||||||
|
|
||||||
TEST_CASE(gt); // use "<" comparisons instead of ">"
|
TEST_CASE(gt); // use "<" comparisons instead of ">"
|
||||||
|
|
||||||
|
@ -4852,6 +4854,29 @@ private:
|
||||||
ASSERT_EQUALS(expected, tokenizeAndStringify(code));
|
ASSERT_EQUALS(expected, tokenizeAndStringify(code));
|
||||||
}
|
}
|
||||||
|
|
||||||
|
void removeExceptionSpecification4() {
|
||||||
|
const char code[] = "namespace {\n"
|
||||||
|
" void B() throw ();\n"
|
||||||
|
"};";
|
||||||
|
|
||||||
|
const char expected[] = "namespace {\n"
|
||||||
|
"void B ( ) ;\n"
|
||||||
|
"} ;";
|
||||||
|
|
||||||
|
ASSERT_EQUALS(expected, tokenizeAndStringify(code));
|
||||||
|
}
|
||||||
|
|
||||||
|
void removeExceptionSpecification5() {
|
||||||
|
ASSERT_EQUALS("void foo ( struct S ) ;",
|
||||||
|
tokenizeAndStringify("void foo (struct S) throw();"));
|
||||||
|
ASSERT_EQUALS("void foo ( struct S , int ) ;",
|
||||||
|
tokenizeAndStringify("void foo (struct S, int) throw();"));
|
||||||
|
ASSERT_EQUALS("void foo ( int , struct S ) ;",
|
||||||
|
tokenizeAndStringify("void foo (int, struct S) throw();"));
|
||||||
|
ASSERT_EQUALS("void foo ( struct S1 , struct S2 ) ;",
|
||||||
|
tokenizeAndStringify("void foo (struct S1, struct S2) throw();"));
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
void gt() {
|
void gt() {
|
||||||
ASSERT_EQUALS("( i < 10 )", tokenizeAndStringify("(10>i)"));
|
ASSERT_EQUALS("( i < 10 )", tokenizeAndStringify("(10>i)"));
|
||||||
|
|
Loading…
Reference in New Issue