Parse an '@' in an Objective-C++ class member specification,

diagnosing it as an error rather than looping infinitely. Also,
explicitly disallow @defs in Objective-C++. Fixes <rdar://problem/9260136>.


git-svn-id: https://llvm.org/svn/llvm-project/cfe/trunk@129521 91177308-0d34-0410-b5e6-96231b3b80d8
This commit is contained in:
Douglas Gregor 2011-04-14 17:21:19 +00:00
Родитель 5bbcdbf36f
Коммит 8a9013d248
3 изменённых файлов: 31 добавлений и 2 удалений

Просмотреть файл

@ -120,6 +120,9 @@ def err_function_declared_typedef : Error<
def err_iboutletcollection_builtintype : Error< def err_iboutletcollection_builtintype : Error<
"type argument of iboutletcollection attribute cannot be a builtin type">; "type argument of iboutletcollection attribute cannot be a builtin type">;
def err_at_defs_cxx : Error<"@defs is not supported in Objective-C++">;
def err_at_in_class : Error<"unexpected '@' in member specification">;
def err_expected_fn_body : Error< def err_expected_fn_body : Error<
"expected function body after function declarator">; "expected function body after function declarator">;
def err_expected_method_body : Error<"expected method body">; def err_expected_method_body : Error<"expected method body">;
@ -370,8 +373,8 @@ def err_enum_template : Error<"enumeration cannot be a template">;
def err_missing_dependent_template_keyword : Error< def err_missing_dependent_template_keyword : Error<
"use 'template' keyword to treat '%0' as a dependent template name">; "use 'template' keyword to treat '%0' as a dependent template name">;
def war_missing_dependent_template_keyword : ExtWarn< def war_missing_dependent_template_keyword : ExtWarn<
"use 'template' keyword to treat '%0' as a dependent template name">; "use 'template' keyword to treat '%0' as a dependent template name">;
def warn_static_inline_explicit_inst_ignored : Warning< def warn_static_inline_explicit_inst_ignored : Warning<
"ignoring '%select{static|inline}0' keyword on explicit template " "ignoring '%select{static|inline}0' keyword on explicit template "

Просмотреть файл

@ -1374,6 +1374,17 @@ bool Parser::isCXX0XFinalKeyword() const {
void Parser::ParseCXXClassMemberDeclaration(AccessSpecifier AS, void Parser::ParseCXXClassMemberDeclaration(AccessSpecifier AS,
const ParsedTemplateInfo &TemplateInfo, const ParsedTemplateInfo &TemplateInfo,
ParsingDeclRAIIObject *TemplateDiags) { ParsingDeclRAIIObject *TemplateDiags) {
if (Tok.is(tok::at)) {
if (getLang().ObjC1 && NextToken().isObjCAtKeyword(tok::objc_defs))
Diag(Tok, diag::err_at_defs_cxx);
else
Diag(Tok, diag::err_at_in_class);
ConsumeToken();
SkipUntil(tok::r_brace);
return;
}
// Access declarations. // Access declarations.
if (!TemplateInfo.Kind && if (!TemplateInfo.Kind &&
(Tok.is(tok::identifier) || Tok.is(tok::coloncolon)) && (Tok.is(tok::identifier) || Tok.is(tok::coloncolon)) &&

15
test/Parser/objcxx-at.mm Normal file
Просмотреть файл

@ -0,0 +1,15 @@
// RUN: %clang_cc1 -fsyntax-only -verify %s
@interface B {
int i;
}
@end
struct Z {
@defs(B); // expected-error{{@defs is not supported in Objective-C++}}
};
struct Y { // expected-note{{to match this '{'}}
struct X { } // expected-error{{expected ';' after struct}}
@interface A // expected-error{{unexpected '@' in member specification}}
} // expected-error{{expected '}'}} expected-error{{expected ';' after struct}}