aboutsummaryrefslogtreecommitdiff
path: root/lib/Sema/SemaDecl.cpp
diff options
context:
space:
mode:
authorFariborz Jahanian <fjahanian@apple.com>2008-12-17 22:21:44 +0000
committerFariborz Jahanian <fjahanian@apple.com>2008-12-17 22:21:44 +0000
commit375d37c1298def125934bbbebca535c3867a89db (patch)
tree9d17624e2a4f0ee9d5cf6d21241d354500bb4eae /lib/Sema/SemaDecl.cpp
parent2342ef75797a2ad6c9d7a784cfff220fd1a66008 (diff)
Patch to re-implement duplicate ivar checking
(which will pass duplicate-ivar-check.m test again). git-svn-id: https://llvm.org/svn/llvm-project/cfe/trunk@61161 91177308-0d34-0410-b5e6-96231b3b80d8
Diffstat (limited to 'lib/Sema/SemaDecl.cpp')
-rw-r--r--lib/Sema/SemaDecl.cpp27
1 files changed, 10 insertions, 17 deletions
diff --git a/lib/Sema/SemaDecl.cpp b/lib/Sema/SemaDecl.cpp
index 5ae266ef00..511103fa75 100644
--- a/lib/Sema/SemaDecl.cpp
+++ b/lib/Sema/SemaDecl.cpp
@@ -3029,27 +3029,20 @@ void Sema::ActOnFields(Scope* S,
ObjCIvarDecl **ClsFields = reinterpret_cast<ObjCIvarDecl**>(&RecFields[0]);
if (ObjCInterfaceDecl *ID = dyn_cast<ObjCInterfaceDecl>(EnclosingDecl)) {
ID->addInstanceVariablesToClass(ClsFields, RecFields.size(), RBrac);
-#if 0
// Must enforce the rule that ivars in the base classes may not be
// duplicates.
- FieldIDs.clear();
- RecordDecl *RD = ID->getRecordForDecl();
- for (RecordDecl::field_iterator i = RD->field_begin(),
- e = RD->field_end(); i != e; ++i) {
- FieldDecl *FD = *i;
- if (IdentifierInfo *II = FD->getIdentifier())
- if (!FieldIDs.insert(II)) {
- Diag(FD->getLocation(), diag::err_duplicate_member) << II;
- FD->setInvalidDecl();
- for (RecordDecl::field_iterator j = RD->field_begin(),
- e1 = RD->field_end(); j != e1; ++j)
- if (II == (*j)->getIdentifier()) {
- Diag((*j)->getLocation(), diag::note_previous_definition);
- break;
- }
+ if (ID->getSuperClass()) {
+ for (ObjCInterfaceDecl::ivar_iterator IVI = ID->ivar_begin(),
+ IVE = ID->ivar_end(); IVI != IVE; ++IVI) {
+ ObjCIvarDecl* Ivar = (*IVI);
+ IdentifierInfo *II = Ivar->getIdentifier();
+ ObjCIvarDecl* prevIvar = ID->getSuperClass()->FindIvarDeclaration(II);
+ if (prevIvar) {
+ Diag(Ivar->getLocation(), diag::err_duplicate_member) << II;
+ Diag(prevIvar->getLocation(), diag::note_previous_definition);
}
+ }
}
-#endif
}
else if (ObjCImplementationDecl *IMPDecl =
dyn_cast<ObjCImplementationDecl>(EnclosingDecl)) {