mirror of
https://github.com/capstone-engine/llvm-capstone.git
synced 2024-11-23 13:50:11 +00:00
[Clang][ObjC] Add optionality to property attribute strings. (#66507)
Add a new attribute, "?", to the property attribute string for properties of protocols that are declared @optional. (Previously https://reviews.llvm.org/D135273) rdar://100463524
This commit is contained in:
parent
7fe8e0a7c5
commit
06f10b8084
@ -7890,6 +7890,7 @@ ASTContext::getObjCPropertyImplDeclForPropertyDecl(
|
||||
/// kPropertyWeak = 'W' // 'weak' property
|
||||
/// kPropertyStrong = 'P' // property GC'able
|
||||
/// kPropertyNonAtomic = 'N' // property non-atomic
|
||||
/// kPropertyOptional = '?' // property optional
|
||||
/// };
|
||||
/// @endcode
|
||||
std::string
|
||||
@ -7915,6 +7916,9 @@ ASTContext::getObjCEncodingForPropertyDecl(const ObjCPropertyDecl *PD,
|
||||
// closely resembles encoding of ivars.
|
||||
getObjCEncodingForPropertyType(PD->getType(), S);
|
||||
|
||||
if (PD->isOptional())
|
||||
S += ",?";
|
||||
|
||||
if (PD->isReadOnly()) {
|
||||
S += ",R";
|
||||
if (PD->getPropertyAttributes() & ObjCPropertyAttribute::kind_copy)
|
||||
|
@ -1,4 +1,4 @@
|
||||
// RUN: %clang_cc1 -emit-llvm -triple x86_64-apple-darwin %s -o - | FileCheck %s
|
||||
// RUN: %clang_cc1 -Wno-objc-root-class -emit-llvm -triple x86_64-apple-darwin %s -o - | FileCheck %s
|
||||
|
||||
__attribute__((objc_runtime_name("MySecretNamespace.Protocol")))
|
||||
@protocol Protocol
|
||||
@ -10,6 +10,10 @@ __attribute__((objc_runtime_name("MySecretNamespace.Protocol2")))
|
||||
@protocol Protocol2
|
||||
- (void) MethodP2;
|
||||
+ (void) ClsMethodP2;
|
||||
|
||||
@optional
|
||||
@property(retain) id optionalProp;
|
||||
|
||||
@end
|
||||
|
||||
__attribute__((objc_runtime_name("MySecretNamespace.Protocol3")))
|
||||
@ -57,6 +61,10 @@ id Test16877359(void) {
|
||||
// CHECK: @"OBJC_CLASS_$_MySecretNamespace.Message" ={{.*}} global %struct._class_t
|
||||
// CHECK: @"OBJC_METACLASS_$_MySecretNamespace.Message" ={{.*}} global %struct._class_t
|
||||
|
||||
// CHECK: @OBJC_PROP_NAME_ATTR_ = private unnamed_addr constant [13 x i8] c"optionalProp\00"
|
||||
// CHECK-NEXT: @OBJC_PROP_NAME_ATTR_.11 = private unnamed_addr constant [7 x i8] c"T@,?,&\00"
|
||||
// CHECK: @"_OBJC_$_PROP_LIST_MySecretNamespace.Protocol2" ={{.*}} [%struct._prop_t { ptr @OBJC_PROP_NAME_ATTR_, ptr @OBJC_PROP_NAME_ATTR_.11 }]
|
||||
|
||||
// CHECK: private unnamed_addr constant [42 x i8] c"T@\22MySecretNamespace.Message\22,&,V_msgProp\00"
|
||||
// CHECK: private unnamed_addr constant [76 x i8] c"T@\22MySecretNamespace.Message<MySecretNamespace.Protocol3>\22,&,V_msgProtoProp\00"
|
||||
// CHECK: private unnamed_addr constant [50 x i8] c"T@\22<MySecretNamespace.Protocol3>\22,&,V_idProtoProp\00"
|
||||
|
Loading…
Reference in New Issue
Block a user