forked from OSchip/llvm-project
Use the 'declaration does not declare anything' error when we see an anonymous struct/union declaration outside of a struct or union in C
llvm-svn: 66303
This commit is contained in:
parent
f5d0613ce9
commit
2e7cba6208
|
@ -1215,8 +1215,6 @@ DIAG(err_anonymous_union_with_storage_spec, ERROR,
|
|||
"anonymous union at class scope must not have a storage specifier")
|
||||
DIAG(err_anonymous_struct_not_member, ERROR,
|
||||
"anonymous %select{structs|structs and classes}0 must be %select{struct or union|class}0 members")
|
||||
DIAG(err_anonymous_union_not_member, ERROR,
|
||||
"anonymous unions must be struct or union members")
|
||||
DIAG(err_anonymous_union_member_redecl, ERROR,
|
||||
"member of anonymous union redeclares %0")
|
||||
DIAG(err_anonymous_struct_member_redecl, ERROR,
|
||||
|
|
|
@ -922,8 +922,14 @@ Sema::DeclTy *Sema::ParsedFreeStandingDeclSpec(Scope *S, DeclSpec &DS) {
|
|||
|
||||
if (RecordDecl *Record = dyn_cast_or_null<RecordDecl>(Tag)) {
|
||||
if (!Record->getDeclName() && Record->isDefinition() &&
|
||||
DS.getStorageClassSpec() != DeclSpec::SCS_typedef)
|
||||
return BuildAnonymousStructOrUnion(S, DS, Record);
|
||||
DS.getStorageClassSpec() != DeclSpec::SCS_typedef) {
|
||||
if (getLangOptions().CPlusPlus ||
|
||||
Record->getDeclContext()->isRecord())
|
||||
return BuildAnonymousStructOrUnion(S, DS, Record);
|
||||
|
||||
Diag(DS.getSourceRange().getBegin(), diag::err_no_declarators)
|
||||
<< DS.getSourceRange();
|
||||
}
|
||||
|
||||
// Microsoft allows unnamed struct/union fields. Don't complain
|
||||
// about them.
|
||||
|
@ -1102,14 +1108,7 @@ Sema::DeclTy *Sema::BuildAnonymousStructOrUnion(Scope *S, DeclSpec &DS,
|
|||
Invalid = true;
|
||||
}
|
||||
}
|
||||
} else {
|
||||
// FIXME: Check GNU C semantics
|
||||
if (Record->isUnion() && !Owner->isRecord()) {
|
||||
Diag(Record->getLocation(), diag::err_anonymous_union_not_member)
|
||||
<< (int)getLangOptions().CPlusPlus;
|
||||
Invalid = true;
|
||||
}
|
||||
}
|
||||
}
|
||||
|
||||
if (!Record->isUnion() && !Owner->isRecord()) {
|
||||
Diag(Record->getLocation(), diag::err_anonymous_struct_not_member)
|
||||
|
|
|
@ -50,12 +50,12 @@ struct Redecl {
|
|||
void zz(); // expected-error{{duplicate member 'zz'}}
|
||||
};
|
||||
|
||||
union { // expected-error{{anonymous unions must be struct or union members}}
|
||||
union { // expected-error{{declaration does not declare anything}}
|
||||
int int_val;
|
||||
float float_val;
|
||||
};
|
||||
|
||||
static union { // expected-error{{anonymous unions must be struct or union members}}
|
||||
static union { // expected-error{{declaration does not declare anything}}
|
||||
int int_val2;
|
||||
float float_val2;
|
||||
};
|
||||
|
@ -66,7 +66,7 @@ void f() {
|
|||
}
|
||||
|
||||
void g() {
|
||||
union { // expected-error{{anonymous unions must be struct or union members}}
|
||||
union { // expected-error{{declaration does not declare anything}}
|
||||
int i;
|
||||
float f2;
|
||||
};
|
||||
|
@ -87,3 +87,5 @@ struct s1 {
|
|||
int f0; // expected-error{{member of anonymous union redeclares 'f0'}}
|
||||
};
|
||||
};
|
||||
|
||||
struct {}; // expected-error{{declaration does not declare anything}}
|
||||
|
|
Loading…
Reference in New Issue