Merge pull request #459 from simartin/ticket_6059
Ticket #6059: Properly handle class... in parameter lists.
This commit is contained in:
commit
81791ff55d
|
@ -240,8 +240,8 @@ unsigned int TemplateSimplifier::templateParameters(const Token *tok)
|
||||||
if (Token::Match(tok, "& ::| %var%"))
|
if (Token::Match(tok, "& ::| %var%"))
|
||||||
tok = tok->next();
|
tok = tok->next();
|
||||||
|
|
||||||
// Skip 'typename...' (Ticket #5774)
|
// Skip 'typename...' and 'class...' (Ticket #5774, #6059)
|
||||||
if (Token::simpleMatch(tok, "typename . . .")) {
|
if (Token::Match(tok, "typename|class . . .")) {
|
||||||
tok = tok->tokAt(4);
|
tok = tok->tokAt(4);
|
||||||
continue;
|
continue;
|
||||||
}
|
}
|
||||||
|
|
|
@ -4410,7 +4410,7 @@ private:
|
||||||
tokenizer.tokenize(istr, "test.cpp"); // shouldn't segfault
|
tokenizer.tokenize(istr, "test.cpp"); // shouldn't segfault
|
||||||
}
|
}
|
||||||
|
|
||||||
void syntax_error_templates_3() { // Ticket #5605, #5759, #5762, #5774, #5823
|
void syntax_error_templates_3() { // Ticket #5605, #5759, #5762, #5774, #5823, #6059
|
||||||
tokenizeAndStringify("foo() template<typename T1 = T2 = typename = unused, T5 = = unused> struct tuple Args> tuple<Args...> { } main() { foo<int,int,int,int,int,int>(); }");
|
tokenizeAndStringify("foo() template<typename T1 = T2 = typename = unused, T5 = = unused> struct tuple Args> tuple<Args...> { } main() { foo<int,int,int,int,int,int>(); }");
|
||||||
tokenizeAndStringify("( ) template < T1 = typename = unused> struct Args { } main ( ) { foo < int > ( ) ; }");
|
tokenizeAndStringify("( ) template < T1 = typename = unused> struct Args { } main ( ) { foo < int > ( ) ; }");
|
||||||
tokenizeAndStringify("() template < T = typename = x > struct a {} { f <int> () }");
|
tokenizeAndStringify("() template < T = typename = x > struct a {} { f <int> () }");
|
||||||
|
@ -4432,6 +4432,10 @@ private:
|
||||||
" C() : _a(0), _b(0) {} "
|
" C() : _a(0), _b(0) {} "
|
||||||
" int _a, _b; "
|
" int _a, _b; "
|
||||||
"};");
|
"};");
|
||||||
|
tokenizeAndStringify("template<class... T> struct A { "
|
||||||
|
" static int i; "
|
||||||
|
"}; "
|
||||||
|
"void f() { A<int>::i = 0; }");
|
||||||
}
|
}
|
||||||
|
|
||||||
void template_member_ptr() { // Ticket #5786
|
void template_member_ptr() { // Ticket #5786
|
||||||
|
|
Loading…
Reference in New Issue