diff --git a/clang/lib/CodeGen/CGObjCMac.cpp b/clang/lib/CodeGen/CGObjCMac.cpp index e18105fe019352..f36c28a85a68fc 100644 --- a/clang/lib/CodeGen/CGObjCMac.cpp +++ b/clang/lib/CodeGen/CGObjCMac.cpp @@ -3245,9 +3245,6 @@ PushProtocolProperties(llvm::SmallPtrSet &PropertySet, SmallVectorImpl &Properties, const ObjCProtocolDecl *Proto, bool IsClassProperty) { - for (const auto *P : Proto->protocols()) - PushProtocolProperties(PropertySet, Properties, P, IsClassProperty); - for (const auto *PD : Proto->properties()) { if (IsClassProperty != PD->isClassProperty()) continue; @@ -3255,6 +3252,9 @@ PushProtocolProperties(llvm::SmallPtrSet &PropertySet, continue; Properties.push_back(PD); } + + for (const auto *P : Proto->protocols()) + PushProtocolProperties(PropertySet, Properties, P, IsClassProperty); } /* diff --git a/clang/test/CodeGenObjC/encode-test-2.m b/clang/test/CodeGenObjC/encode-test-2.m index 2985fbda18623b..2d9593d65b0ca5 100644 --- a/clang/test/CodeGenObjC/encode-test-2.m +++ b/clang/test/CodeGenObjC/encode-test-2.m @@ -6,6 +6,9 @@ // CHECK: private unnamed_addr constant [16 x i8] c"@\22Foo\22\00", // CHECK: private unnamed_addr constant [13 x i8] c"{Intf=@@@@#}\00", +// CHECK: @[[PROP_NAME_ATTR:.*]] = private unnamed_addr constant [5 x i8] c"T@,D\00", +// CHECK: @"_OBJC_$_PROP_LIST_C0" = internal global { i32, i32, [1 x %{{.*}}] } { i32 8, i32 1, [1 x %{{.*}}] [%{{.*}} { {{.*}}, i8* getelementptr inbounds ([5 x i8], [5 x i8]* @[[PROP_NAME_ATTR]], i32 0, i32 0) }] }, + @protocol X, Y, Z; @class Foo; @@ -29,3 +32,18 @@ int main() { const char * en = @encode(Intf); } + +@protocol P0 +@property id prop0; +@end + +@protocol P1 +@property id prop0; +@end + +@interface C0 +@end + +@implementation C0 +@dynamic prop0; +@end