blob: c2b5817c73b3fe9de26a0f3e46d7d4abbe198924 [file] [log] [blame]
John McCalld1e40d52011-10-02 01:16:38 +00001// RUN: %clang_cc1 -fobjc-arc -fobjc-runtime-has-weak -emit-llvm -o - %s | FileCheck %s
John McCallf85e1932011-06-15 23:02:42 +00002
3// CHECK: define void @_Z1fPU8__strongP11objc_object(i8**)
4void f(__strong id *) {}
5// CHECK: define void @_Z1fPU6__weakP11objc_object(i8**)
6void f(__weak id *) {}
7// CHECK: define void @_Z1fPU15__autoreleasingP11objc_object(i8**)
8void f(__autoreleasing id *) {}
Douglas Gregorc22d6992011-06-17 22:26:49 +00009// CHECK: define void @_Z1fPP11objc_object(i8**)
John McCallf85e1932011-06-15 23:02:42 +000010void f(__unsafe_unretained id *) {}
11// CHECK: define void @_Z1fPKU8__strongP11objc_object(i8**)
12void f(const __strong id *) {}
13// CHECK: define void @_Z1fPKU6__weakP11objc_object(i8**)
14void f(const __weak id *) {}
15// CHECK: define void @_Z1fPKU15__autoreleasingP11objc_object(i8**)
16void f(const __autoreleasing id *) {}
Douglas Gregorc22d6992011-06-17 22:26:49 +000017// CHECK: define void @_Z1fPKP11objc_object(i8**)
John McCallf85e1932011-06-15 23:02:42 +000018void f(const __unsafe_unretained id *) {}
19
20
21template<unsigned N> struct unsigned_c { };
22
23// CHECK: define weak_odr void @_Z1gIKvEvP10unsigned_cIXplszv1U8__bridgecvPT_v1U8__bridgecvP11objc_objectcvS3_Li0ELi1EEE
24template<typename T>void g(unsigned_c<sizeof((__bridge T*)(__bridge id)(T*)0) + 1>*) {}
25template void g<const void>(unsigned_c<sizeof(id) + 1> *);