зеркало из https://github.com/microsoft/clang-1.git
Don't try to parse class template specializations in C. It can only
lead to heartache. Fixes <rdar://problem/8044088>. git-svn-id: https://llvm.org/svn/llvm-project/cfe/trunk@105178 91177308-0d34-0410-b5e6-96231b3b80d8
This commit is contained in:
Родитель
c53a844e22
Коммит
5ee3734c0b
|
@ -670,7 +670,7 @@ void Parser::ParseClassSpecifier(tok::TokenKind TagTokKind,
|
|||
Name = Tok.getIdentifierInfo();
|
||||
NameLoc = ConsumeToken();
|
||||
|
||||
if (Tok.is(tok::less)) {
|
||||
if (Tok.is(tok::less) && getLang().CPlusPlus) {
|
||||
// The name was supposed to refer to a template, but didn't.
|
||||
// Eat the template argument list and try to continue parsing this as
|
||||
// a class (or template thereof).
|
||||
|
@ -713,8 +713,6 @@ void Parser::ParseClassSpecifier(tok::TokenKind TagTokKind,
|
|||
const_cast<ParsedTemplateInfo&>(TemplateInfo).ExternLoc
|
||||
= SourceLocation();
|
||||
}
|
||||
|
||||
|
||||
}
|
||||
} else if (Tok.is(tok::annot_template_id)) {
|
||||
TemplateId = static_cast<TemplateIdAnnotation *>(Tok.getAnnotationValue());
|
||||
|
|
|
@ -83,3 +83,6 @@ void test12() {
|
|||
|
||||
// rdar://7608537
|
||||
struct test13 { int a; } (test13x);
|
||||
|
||||
// <rdar://problem/8044088>
|
||||
struct X<foo::int> { }; // expected-error{{expected identifier or '('}}
|
||||
|
|
Загрузка…
Ссылка в новой задаче