diff options
-rw-r--r-- | lib/Sema/SemaLookup.cpp | 10 | ||||
-rw-r--r-- | test/Index/complete-properties.m | 5 |
2 files changed, 14 insertions, 1 deletions
diff --git a/lib/Sema/SemaLookup.cpp b/lib/Sema/SemaLookup.cpp index ec633d177c..68eccfc280 100644 --- a/lib/Sema/SemaLookup.cpp +++ b/lib/Sema/SemaLookup.cpp @@ -2484,7 +2484,17 @@ static void LookupVisibleDecls(DeclContext *Ctx, LookupResult &Result, Visited.add(*P); } } + } else if (ObjCClassDecl *Class = dyn_cast<ObjCClassDecl>(*D)) { + for (ObjCClassDecl::iterator I = Class->begin(), IEnd = Class->end(); + I != IEnd; ++I) { + ObjCInterfaceDecl *IFace = I->getInterface(); + if (Result.isAcceptableDecl(IFace)) { + Consumer.FoundDecl(IFace, Visited.checkHidden(IFace), InBaseClass); + Visited.add(IFace); + } + } } + // Visit transparent contexts and inline namespaces inside this context. if (DeclContext *InnerCtx = dyn_cast<DeclContext>(*D)) { if (InnerCtx->isTransparentContext() || InnerCtx->isInlineNamespace()) diff --git a/test/Index/complete-properties.m b/test/Index/complete-properties.m index 0a19f11133..725f180f7c 100644 --- a/test/Index/complete-properties.m +++ b/test/Index/complete-properties.m @@ -1,6 +1,6 @@ /* Note: the RUN lines are near the end of the file, since line/column matter for this test. */ - +@class MyClass; @interface I1 { id StoredProp3; @@ -54,3 +54,6 @@ id test(I3 *i3) { // CHECK-CC5-NEXT: ObjCPropertyDecl:{ResultType id}{TypedText Prop3} (35) // CHECK-CC5-NEXT: ObjCPropertyDecl:{ResultType id}{TypedText Prop4} (35) +// RUN: c-index-test -code-completion-at=%s:9:11 %s | FileCheck -check-prefix=CHECK-CC6 %s +// CHECK-CC6: ObjCInterfaceDecl:{TypedText MyClass} (50) + |