1*67e74705SXin Li// RUN: %clang_cc1 -fsyntax-only -x objective-c++ -fobjc-arc -verify -Wno-objc-root-class %s 2*67e74705SXin Li// rdar://16756639 3*67e74705SXin Li 4*67e74705SXin Litypedef struct __attribute__ ((objc_bridge(NSError))) __CFErrorRef * CFErrorRef; // expected-note 3 {{declared here}} 5*67e74705SXin Li 6*67e74705SXin Litypedef struct __attribute__ ((objc_bridge(MyError))) __CFMyErrorRef * CFMyErrorRef; // expected-note 1 {{declared here}} 7*67e74705SXin Li 8*67e74705SXin Litypedef struct __attribute__((objc_bridge(12))) __CFMyColor *CFMyColorRef; // expected-error {{parameter of 'objc_bridge' attribute must be a single name of an Objective-C class}} 9*67e74705SXin Li 10*67e74705SXin Litypedef struct __attribute__ ((objc_bridge)) __CFArray *CFArrayRef; // expected-error {{'objc_bridge' attribute takes one argument}} 11*67e74705SXin Li 12*67e74705SXin Litypedef struct __attribute__((objc_bridge(NSLocale, NSError))) __CFLocale *CFLocaleRef;// expected-error {{use of undeclared identifier 'NSError'}} 13*67e74705SXin Li 14*67e74705SXin Litypedef struct __attribute__((objc_bridge(NSDictionary))) __CFDictionary * CFDictionaryRef; 15*67e74705SXin Li 16*67e74705SXin Litypedef union __attribute__((objc_bridge(NSUColor))) __CFUPrimeColor XXX; 17*67e74705SXin Litypedef XXX *CFUColor2Ref; 18*67e74705SXin Li 19*67e74705SXin Li@interface I 20*67e74705SXin Li{ 21*67e74705SXin Li} 22*67e74705SXin Li@end 23*67e74705SXin Li 24*67e74705SXin Li@protocol NSTesting @end 25*67e74705SXin Li@class NSString; 26*67e74705SXin Li 27*67e74705SXin Litypedef struct __attribute__((objc_bridge(NSTesting))) __CFError *CFTestingRef; // expected-note {{declared here}} 28*67e74705SXin Li 29*67e74705SXin Liid Test1(CFTestingRef cf) { 30*67e74705SXin Li return static_cast<NSString *>(cf); // expected-error {{CF object of type 'CFTestingRef' (aka '__CFError *') is bridged to 'NSTesting', which is not an Objective-C class}} \ 31*67e74705SXin Li // expected-error {{cast of C pointer type 'CFTestingRef' (aka '__CFError *') to Objective-C pointer type 'NSString *' requires a bridged cast}} \ 32*67e74705SXin Li // expected-note {{use __bridge with C-style cast to convert directly (no change in ownership)}} \ 33*67e74705SXin Li // expected-note {{use __bridge_transfer with C-style cast to transfer ownership of a +1 'CFTestingRef' (aka '__CFError *') into ARC}} 34*67e74705SXin Li} 35*67e74705SXin Li 36*67e74705SXin Litypedef CFErrorRef CFErrorRef1; 37*67e74705SXin Li 38*67e74705SXin Litypedef CFErrorRef1 CFErrorRef2; // expected-note 1 {{declared here}} 39*67e74705SXin Li 40*67e74705SXin Li@protocol P1 @end 41*67e74705SXin Li@protocol P2 @end 42*67e74705SXin Li@protocol P3 @end 43*67e74705SXin Li@protocol P4 @end 44*67e74705SXin Li@protocol P5 @end 45*67e74705SXin Li 46*67e74705SXin Li@interface NSError<P1, P2, P3> @end // expected-note 3 {{declared here}} 47*67e74705SXin Li 48*67e74705SXin Li@interface MyError : NSError // expected-note 1 {{declared here}} 49*67e74705SXin Li@end 50*67e74705SXin Li 51*67e74705SXin Li@interface NSUColor @end 52*67e74705SXin Li 53*67e74705SXin Li@class NSString; 54*67e74705SXin Li 55*67e74705SXin Livoid Test2(CFErrorRef2 cf, NSError *ns, NSString *str, Class c, CFUColor2Ref cf2) { 56*67e74705SXin Li (void)static_cast<NSString *>(cf); // expected-warning {{'CFErrorRef2' (aka '__CFErrorRef *') bridges to NSError, not 'NSString'}} \ 57*67e74705SXin Li // expected-error {{cast of C pointer type 'CFErrorRef2' (aka '__CFErrorRef *') to Objective-C pointer type 'NSString *' requires a bridged cast}} \ 58*67e74705SXin Li // expected-note {{__bridge with C-style cast to convert directly (no change in ownership)}} \ 59*67e74705SXin Li // expected-note {{use __bridge_transfer with C-style cast to transfer ownership of a +1 'CFErrorRef2' (aka '__CFErrorRef *') into ARC}} 60*67e74705SXin Li (void)static_cast<NSError *>(cf); // expected-error {{cast of C pointer type 'CFErrorRef2' (aka '__CFErrorRef *') to Objective-C pointer type 'NSError *' requires a bridged cast}} \ 61*67e74705SXin Li // expected-note {{use __bridge with C-style cast to convert directly (no change in ownership)}} \ 62*67e74705SXin Li // expected-note {{use __bridge_transfer with C-style cast to transfer ownership of a +1 'CFErrorRef2' (aka '__CFErrorRef *') into ARC}} 63*67e74705SXin Li (void)static_cast<MyError*>(cf); // expected-error {{cast of C pointer type 'CFErrorRef2' (aka '__CFErrorRef *') to Objective-C pointer type 'MyError *' requires a bridged cast}} \ 64*67e74705SXin Li // expected-note {{use __bridge with C-style cast to convert directly (no change in ownership)}} \ 65*67e74705SXin Li // expected-note {{use __bridge_transfer with C-style cast to transfer ownership of a +1 'CFErrorRef2' (aka '__CFErrorRef *') into ARC}} \ 66*67e74705SXin Li // expected-warning {{'CFErrorRef2' (aka '__CFErrorRef *') bridges to NSError, not 'MyError'}} 67*67e74705SXin Li (void)static_cast<NSUColor *>(cf2); // expected-error {{cast of C pointer type 'CFUColor2Ref' (aka '__CFUPrimeColor *') to Objective-C pointer type 'NSUColor *' requires a bridged cast}} \ 68*67e74705SXin Li // expected-note {{use __bridge with C-style cast to convert directly (no change in ownership)}} \ 69*67e74705SXin Li // expected-note {{use __bridge_transfer with C-style cast to transfer ownership of a +1 'CFUColor2Ref' (aka '__CFUPrimeColor *') into ARC}} 70*67e74705SXin Li (void)static_cast<CFErrorRef>(ns); // expected-error {{cast of Objective-C pointer type 'NSError *' to C pointer type 'CFErrorRef' (aka '__CFErrorRef *') requires a bridged cast}} \ 71*67e74705SXin Li // expected-note {{use __bridge with C-style cast to convert directly (no change in ownership)}} \ 72*67e74705SXin Li // expected-note {{use __bridge_retained with C-style cast to make an ARC object available as a +1 'CFErrorRef' (aka '__CFErrorRef *')}} 73*67e74705SXin Li (void)static_cast<CFErrorRef>(str); // expected-warning {{'NSString' cannot bridge to 'CFErrorRef' (aka '__CFErrorRef *')}} \\ 74*67e74705SXin Li // expected-error {{cast of Objective-C pointer type 'NSString *' to C pointer type 'CFErrorRef' (aka '__CFErrorRef *') requires a bridged cast}} \ 75*67e74705SXin Li // expected-note {{use __bridge with C-style cast to convert directly (no change in ownership)}} \ 76*67e74705SXin Li // expected-note {{use __bridge_retained with C-style cast to make an ARC object available as a +1 'CFErrorRef' (aka '__CFErrorRef *')}} 77*67e74705SXin Li (void)static_cast<Class>(cf); // expected-warning {{'CFErrorRef2' (aka '__CFErrorRef *') bridges to NSError, not 'Class'}} \\ 78*67e74705SXin Li // expected-error {{cast of C pointer type 'CFErrorRef2' (aka '__CFErrorRef *') to Objective-C pointer type 'Class' requires a bridged cast}} \ 79*67e74705SXin Li // expected-note {{use __bridge with C-style cast to convert directly (no change in ownership)}} \ 80*67e74705SXin Li // expected-note {{use __bridge_transfer with C-style cast to transfer ownership of a +1 'CFErrorRef2' (aka '__CFErrorRef *') into ARC}} 81*67e74705SXin Li (void)static_cast<CFErrorRef>(c); // expected-warning {{'Class' cannot bridge to 'CFErrorRef' (aka '__CFErrorRef *}} \\ 82*67e74705SXin Li // expected-error {{cast of Objective-C pointer type 'Class' to C pointer type 'CFErrorRef' (aka '__CFErrorRef *') requires a bridged cast}} \ 83*67e74705SXin Li // expected-note {{use __bridge with C-style cast to convert directly (no change in ownership)}} \ 84*67e74705SXin Li // expected-note {{use __bridge_retained with C-style cast to make an ARC object available as a +1 'CFErrorRef' (aka '__CFErrorRef *')}} 85*67e74705SXin Li} 86*67e74705SXin Li 87*67e74705SXin Li 88*67e74705SXin Livoid Test3(CFErrorRef cf, NSError *ns) { 89*67e74705SXin Li (void)static_cast<id>(cf); // expected-error {{cast of C pointer type 'CFErrorRef' (aka '__CFErrorRef *') to Objective-C pointer type 'id' requires a bridged cast}} \ 90*67e74705SXin Li // expected-note {{use __bridge with C-style cast to convert directly (no change in ownership)}} \ 91*67e74705SXin Li // expected-note {{use __bridge_transfer with C-style cast to transfer ownership of a +1 'CFErrorRef' (aka '__CFErrorRef *') into ARC}} 92*67e74705SXin Li (void)static_cast< id<P1, P2> >(cf); // expected-error {{cast of C pointer type 'CFErrorRef' (aka '__CFErrorRef *') to Objective-C pointer type 'id<P1,P2>' requires a bridged cast}} \ 93*67e74705SXin Li // expected-note {{use __bridge with C-style cast to convert directly (no change in ownership)}} \ 94*67e74705SXin Li // expected-note {{use __bridge_transfer with C-style cast to transfer ownership of a +1 'CFErrorRef' (aka '__CFErrorRef *') into ARC}} 95*67e74705SXin Li (void)static_cast< id<P1, P2, P4> >(cf); // expected-warning {{'CFErrorRef' (aka '__CFErrorRef *') bridges to NSError, not 'id<P1,P2,P4>'}} \ 96*67e74705SXin Li // expected-error {{cast of C pointer type 'CFErrorRef' (aka '__CFErrorRef *') to Objective-C pointer type 'id<P1,P2,P4>' requires a bridged cast}} \ 97*67e74705SXin Li // expected-note {{use __bridge with C-style cast to convert directly (no change in ownership)}} \ 98*67e74705SXin Li // expected-note {{use __bridge_transfer with C-style cast to transfer ownership of a +1 'CFErrorRef' (aka '__CFErrorRef *') into ARC}} 99*67e74705SXin Li} 100*67e74705SXin Li 101*67e74705SXin Livoid Test4(CFMyErrorRef cf) { 102*67e74705SXin Li (void)static_cast<id>(cf); // expected-error {{cast of C pointer type 'CFMyErrorRef' (aka '__CFMyErrorRef *') to Objective-C pointer type 'id' requires a bridged cast}} \ 103*67e74705SXin Li // expected-note {{use __bridge with C-style cast to convert directly (no change in ownership)}} \ 104*67e74705SXin Li // expected-note {{use __bridge_transfer with C-style cast to transfer ownership of a +1 'CFMyErrorRef' (aka '__CFMyErrorRef *') into ARC}} 105*67e74705SXin Li (void)static_cast< id<P1, P2> >(cf); // expected-error {{cast of C pointer type 'CFMyErrorRef' (aka '__CFMyErrorRef *') to Objective-C pointer type 'id<P1,P2>' requires a bridged cast}} \ 106*67e74705SXin Li // expected-note {{use __bridge with C-style cast to convert directly (no change in ownership)}} \ 107*67e74705SXin Li // expected-note {{use __bridge_transfer with C-style cast to transfer ownership of a +1 'CFMyErrorRef' (aka '__CFMyErrorRef *') into ARC}} 108*67e74705SXin Li (void)static_cast< id<P1, P2, P3> >(cf); // expected-error {{cast of C pointer type 'CFMyErrorRef' (aka '__CFMyErrorRef *') to Objective-C pointer type 'id<P1,P2,P3>' requires a bridged cast}} \ 109*67e74705SXin Li // expected-note {{use __bridge with C-style cast to convert directly (no change in ownership)}} \ 110*67e74705SXin Li // expected-note {{use __bridge_transfer with C-style cast to transfer ownership of a +1 'CFMyErrorRef' (aka '__CFMyErrorRef *') into ARC}} 111*67e74705SXin Li (void)static_cast< id<P2, P3> >(cf); // expected-error {{cast of C pointer type 'CFMyErrorRef' (aka '__CFMyErrorRef *') to Objective-C pointer type 'id<P2,P3>' requires a bridged cast}} \ 112*67e74705SXin Li // expected-note {{use __bridge with C-style cast to convert directly (no change in ownership)}} \ 113*67e74705SXin Li // expected-note {{use __bridge_transfer with C-style cast to transfer ownership of a +1 'CFMyErrorRef' (aka '__CFMyErrorRef *') into ARC}} 114*67e74705SXin Li (void)static_cast< id<P1, P2, P4> >(cf); // expected-warning {{'CFMyErrorRef' (aka '__CFMyErrorRef *') bridges to MyError, not 'id<P1,P2,P4>'}} \ 115*67e74705SXin Li // expected-error {{cast of C pointer type 'CFMyErrorRef' (aka '__CFMyErrorRef *') to Objective-C pointer type 'id<P1,P2,P4>' requires a bridged cast}} \ 116*67e74705SXin Li // expected-note {{use __bridge with C-style cast to convert directly (no change in ownership)}} \ 117*67e74705SXin Li // expected-note {{use __bridge_transfer with C-style cast to transfer ownership of a +1 'CFMyErrorRef' (aka '__CFMyErrorRef *') into ARC}} 118*67e74705SXin Li} 119*67e74705SXin Li 120*67e74705SXin Livoid Test5(id<P1, P2, P3> P123, id ID, id<P1, P2, P3, P4> P1234, id<P1, P2> P12, id<P2, P3> P23) { 121*67e74705SXin Li (void)static_cast<CFErrorRef>(ID); // expected-error {{cast of Objective-C pointer type 'id' to C pointer type 'CFErrorRef' (aka '__CFErrorRef *') requires a bridged cast}} \ 122*67e74705SXin Li // expected-note {{use __bridge with C-style cast to convert directly (no change in ownership)}} \ 123*67e74705SXin Li // expected-note {{use __bridge_retained with C-style cast to make an ARC object available as a +1 'CFErrorRef' (aka '__CFErrorRef *')}} 124*67e74705SXin Li (void)static_cast<CFErrorRef>(P123); // expected-error {{cast of Objective-C pointer type 'id<P1,P2,P3>' to C pointer type 'CFErrorRef' (aka '__CFErrorRef *') requires a bridged cast}} \ 125*67e74705SXin Li // expected-note {{use __bridge with C-style cast to convert directly (no change in ownership)}} \ 126*67e74705SXin Li // expected-note {{use __bridge_retained with C-style cast to make an ARC object available as a +1 'CFErrorRef' (aka '__CFErrorRef *')}} 127*67e74705SXin Li (void)static_cast<CFErrorRef>(P1234); // expected-error {{cast of Objective-C pointer type 'id<P1,P2,P3,P4>' to C pointer type 'CFErrorRef' (aka '__CFErrorRef *') requires a bridged cast}} \ 128*67e74705SXin Li // expected-note {{use __bridge with C-style cast to convert directly (no change in ownership)}} \ 129*67e74705SXin Li // expected-note {{use __bridge_retained with C-style cast to make an ARC object available as a +1 'CFErrorRef' (aka '__CFErrorRef *')}} 130*67e74705SXin Li (void)static_cast<CFErrorRef>(P12); // expected-error {{cast of Objective-C pointer type 'id<P1,P2>' to C pointer type 'CFErrorRef' (aka '__CFErrorRef *') requires a bridged cast}} \ 131*67e74705SXin Li // expected-note {{use __bridge with C-style cast to convert directly (no change in ownership)}} \ 132*67e74705SXin Li // expected-note {{use __bridge_retained with C-style cast to make an ARC object available as a +1 'CFErrorRef' (aka '__CFErrorRef *')}} 133*67e74705SXin Li (void)static_cast<CFErrorRef>(P23); // expected-error {{cast of Objective-C pointer type 'id<P2,P3>' to C pointer type 'CFErrorRef' (aka '__CFErrorRef *') requires a bridged cast}} \ 134*67e74705SXin Li // expected-note {{use __bridge with C-style cast to convert directly (no change in ownership)}} \ 135*67e74705SXin Li // expected-note {{use __bridge_retained with C-style cast to make an ARC object available as a +1 'CFErrorRef' (aka '__CFErrorRef *')}} 136*67e74705SXin Li} 137