2013-09-28 04:21:48 +08:00
|
|
|
// RUN: %clang_cc1 -triple x86_64-apple-darwin10 -emit-llvm -g %s -o - | FileCheck %s
|
2013-02-22 04:42:11 +08:00
|
|
|
__attribute((objc_root_class)) @interface NSObject {
|
|
|
|
id isa;
|
|
|
|
}
|
|
|
|
+ (id)alloc;
|
|
|
|
- (id)init;
|
|
|
|
- (id)retain;
|
|
|
|
@end
|
|
|
|
|
|
|
|
void NSLog(id, ...);
|
|
|
|
|
|
|
|
@protocol MyProtocol
|
|
|
|
|
|
|
|
-(const char *)hello;
|
|
|
|
|
|
|
|
@end
|
|
|
|
|
|
|
|
@interface MyClass : NSObject {
|
|
|
|
}
|
|
|
|
|
|
|
|
@property (nonatomic, assign) id <MyProtocol> bad_carrier;
|
|
|
|
@property (nonatomic, assign) id good_carrier;
|
|
|
|
|
|
|
|
@end
|
|
|
|
|
|
|
|
@implementation MyClass
|
|
|
|
@end
|
|
|
|
|
|
|
|
int main()
|
|
|
|
{
|
|
|
|
@autoreleasepool
|
|
|
|
{
|
|
|
|
MyClass *my_class = [MyClass alloc];
|
|
|
|
NSLog(@"%p\n", my_class.bad_carrier);
|
|
|
|
NSLog(@"%p\n", my_class.good_carrier);
|
|
|
|
}
|
|
|
|
}
|
|
|
|
// Verify that the debug type for both variables is 'id'.
|
2013-08-19 11:37:48 +08:00
|
|
|
// CHECK: metadata !{i32 {{[0-9]+}}, metadata !{{[0-9]+}}, metadata !"bad_carrier", null, i32 {{[0-9]+}}, metadata ![[IDTYPE:[0-9]+]], i32 0, i32 0} ; [ DW_TAG_arg_variable ] [bad_carrier] [line 0]
|
|
|
|
// CHECK: metadata !{i32 {{[0-9]+}}, metadata !{{[0-9]+}}, metadata !"good_carrier", null, i32 {{[0-9]+}}, metadata !{{.*}}[[IDTYPE]], i32 0, i32 0} ; [ DW_TAG_arg_variable ] [good_carrier] [line 0]
|
2013-02-22 04:42:11 +08:00
|
|
|
// CHECK !{{.*}}[[IDTYPE]] = metadata !{i32 {{[0-9]+}}, null, metadata !"id", metadata !{{[0-9]+}}, i32 !{{[0-9]+}}, i64 0, i64 0, i64 0, i32 0, metadata !{{[0-9]+}}} ; [ DW_TAG_typedef ] [id]
|