Merge pull request #888 from simartin/ticket_7942

Don't generate invalid syntax for out of line template class constructors during instantiation
This commit is contained in:
Daniel Marjamäki 2017-04-10 22:18:20 +02:00 committed by GitHub
commit df90ff9f5e
3 changed files with 18 additions and 3 deletions

View File

@ -818,9 +818,13 @@ void TemplateSimplifier::expandTemplate(
// replace name.. // replace name..
if (Token::Match(tok3, (name + " !!<").c_str())) { if (Token::Match(tok3, (name + " !!<").c_str())) {
if (Token::Match(tok3->tokAt(-2), "> :: %name% ( )")) {
; // Ticket #7942: Replacing for out-of-line constructors generates invalid syntax
} else {
tokenlist.addtoken(newName, tok3->linenr(), tok3->fileIndex()); tokenlist.addtoken(newName, tok3->linenr(), tok3->fileIndex());
continue; continue;
} }
}
// copy // copy
tokenlist.addtoken(tok3, tok3->linenr(), tok3->fileIndex()); tokenlist.addtoken(tok3, tok3->linenr(), tok3->fileIndex());

View File

@ -183,6 +183,7 @@ private:
TEST_CASE(uninitConstVar); TEST_CASE(uninitConstVar);
TEST_CASE(constructors_crash1); // ticket #5641 TEST_CASE(constructors_crash1); // ticket #5641
TEST_CASE(classWithOperatorInName);// ticket #2827 TEST_CASE(classWithOperatorInName);// ticket #2827
TEST_CASE(templateConstructor); // ticket #7942
} }
@ -3348,6 +3349,16 @@ private:
"};"); "};");
ASSERT_EQUALS("", errout.str()); ASSERT_EQUALS("", errout.str());
} }
void templateConstructor() { // ticket #7942
check("template <class T> struct Containter {\n"
" Containter();\n"
" T* mElements;\n"
"};\n"
"template <class T> Containter<T>::Containter() : mElements(nullptr) {}\n"
"Containter<int> intContainer;");
ASSERT_EQUALS("", errout.str());
}
}; };
REGISTER_TEST(TestConstructors) REGISTER_TEST(TestConstructors)

View File

@ -184,7 +184,7 @@ private:
const char expected[] = "template < class T > Fred < T > :: Fred ( ) { } " // <- TODO: this should be removed const char expected[] = "template < class T > Fred < T > :: Fred ( ) { } " // <- TODO: this should be removed
"Fred < float > fred ; " "Fred < float > fred ; "
"class Fred < float > { } ; " "class Fred < float > { } ; "
"Fred < float > :: Fred < float > ( ) { }"; "Fred < float > :: Fred ( ) { }";
ASSERT_EQUALS(expected, tok(code)); ASSERT_EQUALS(expected, tok(code));
} }