aboutsummaryrefslogtreecommitdiff
path: root/lib/Sema/SemaCodeComplete.cpp
diff options
context:
space:
mode:
authorDouglas Gregor <dgregor@apple.com>2010-08-11 12:19:30 +0000
committerDouglas Gregor <dgregor@apple.com>2010-08-11 12:19:30 +0000
commitdeacbdca554298ccdf636f19c6094a8825ec6b34 (patch)
treea25e20608fe132a81d48e79b4f1e09dab5936e16 /lib/Sema/SemaCodeComplete.cpp
parent018220c343c103b7dfaa117a7a474c7a7fd6d068 (diff)
Speculatively revert r110610 " Make ObjCInterfaceDecl redeclarable,
and create separate decl nodes for forward declarations and the definition," which appears to be causing significant Objective-C breakage. git-svn-id: https://llvm.org/svn/llvm-project/cfe/trunk@110803 91177308-0d34-0410-b5e6-96231b3b80d8
Diffstat (limited to 'lib/Sema/SemaCodeComplete.cpp')
-rw-r--r--lib/Sema/SemaCodeComplete.cpp26
1 files changed, 9 insertions, 17 deletions
diff --git a/lib/Sema/SemaCodeComplete.cpp b/lib/Sema/SemaCodeComplete.cpp
index f12e1839e5..52ac8dd649 100644
--- a/lib/Sema/SemaCodeComplete.cpp
+++ b/lib/Sema/SemaCodeComplete.cpp
@@ -3748,28 +3748,20 @@ static void AddInterfaceResults(DeclContext *Ctx, DeclContext *CurContext,
for (DeclContext::decl_iterator D = Ctx->decls_begin(),
DEnd = Ctx->decls_end();
D != DEnd; ++D) {
- // Record any interfaces we find. Forward declarations are never registered
- // in the lexical contest, so if we're only looking for those, don't bother.
- if (!OnlyForwardDeclarations)
- if (ObjCInterfaceDecl *Class = dyn_cast<ObjCInterfaceDecl>(*D))
- if (!OnlyUnimplemented || !Class->getImplementation())
- Results.AddResult(Result(Class, 0), CurContext, 0, false);
+ // Record any interfaces we find.
+ if (ObjCInterfaceDecl *Class = dyn_cast<ObjCInterfaceDecl>(*D))
+ if ((!OnlyForwardDeclarations || Class->isForwardDecl()) &&
+ (!OnlyUnimplemented || !Class->getImplementation()))
+ Results.AddResult(Result(Class, 0), CurContext, 0, false);
// Record any forward-declared interfaces we find.
if (ObjCClassDecl *Forward = dyn_cast<ObjCClassDecl>(*D)) {
for (ObjCClassDecl::iterator C = Forward->begin(), CEnd = Forward->end();
- C != CEnd; ++C) {
- ObjCInterfaceDecl *IDecl = C->getInterface();
- ObjCInterfaceDecl *IDef = IDecl->getDefinition();
- // If there's a definition, and we're looking for everything, then we
- // already added the decl in question above.
- if (!OnlyForwardDeclarations && !OnlyUnimplemented && IDef)
- continue;
- if ((!OnlyForwardDeclarations || !IDef) &&
- (!OnlyUnimplemented || !IDef || !IDef->getImplementation()))
- Results.AddResult(Result(IDecl, 0), CurContext,
+ C != CEnd; ++C)
+ if ((!OnlyForwardDeclarations || C->getInterface()->isForwardDecl()) &&
+ (!OnlyUnimplemented || !C->getInterface()->getImplementation()))
+ Results.AddResult(Result(C->getInterface(), 0), CurContext,
0, false);
- }
}
}
}