diff --git a/lib/tokenize.cpp b/lib/tokenize.cpp index f55423a45..d64fc0ab1 100644 --- a/lib/tokenize.cpp +++ b/lib/tokenize.cpp @@ -1323,7 +1323,7 @@ void Tokenizer::simplifyTemplates() continue; if (Token::Match(tok2->previous(), "[;{}=]") && - !Token::Match(tok2, (pattern + (isfunc ? "(" : "%var%")).c_str())) + !Token::Match(tok2, (pattern + (isfunc ? "(" : "*| %var%")).c_str())) continue; // New type.. diff --git a/test/testsimplifytokens.cpp b/test/testsimplifytokens.cpp index f31418baf..a3591707a 100644 --- a/test/testsimplifytokens.cpp +++ b/test/testsimplifytokens.cpp @@ -95,6 +95,7 @@ private: TEST_CASE(template15); TEST_CASE(template16); TEST_CASE(template17); + TEST_CASE(template18); TEST_CASE(template_default_parameter); TEST_CASE(template_default_type); TEST_CASE(template_typename); @@ -1459,6 +1460,18 @@ private: sizeof_(code); } + void template18() + { + const char code[] = "template class foo { T a; };\n" + "foo *f;"; + + const std::string expected("; ; " + "foo * f ; " + "class foo { int a ; }"); + + ASSERT_EQUALS(expected, sizeof_(code)); + } + void template_default_parameter() { {