| // RUN: %clang_cc1 %s -triple=x86_64-apple-darwin10 -std=c++11 -emit-llvm -fblocks -o - | FileCheck %s | 
 |  | 
 | // CHECK: @"_ZZ11+[A shared]E1a" = internal global | 
 | // CHECK: @"_ZZ11-[A(Foo) f]E1a" = internal global | 
 | // CHECK: v56@0:8i16i20i24i28i32i36i40i44^i48 | 
 |  | 
 | @interface A | 
 | @end | 
 |  | 
 | @implementation A | 
 |  | 
 | + (A *)shared { | 
 |   static A* a; | 
 |    | 
 |   return a; | 
 | } | 
 |  | 
 | @end | 
 |  | 
 | @interface A(Foo) | 
 | @end | 
 |  | 
 | @implementation A(Foo) | 
 | - (int)f { | 
 |   // FIXME: Add a member function to s and make sure that it's mangled correctly. | 
 |   struct s { | 
 |   }; | 
 |    | 
 |   static s a; | 
 |  | 
 |   return 0; | 
 | } | 
 | @end | 
 |  | 
 | // PR6468 | 
 | @interface Test | 
 | - (void) process: (int)r3 :(int)r4 :(int)r5 :(int)r6 :(int)r7 :(int)r8 :(int)r9 :(int)r10 :(int &)i; | 
 | @end | 
 |  | 
 | @implementation Test | 
 | - (void) process: (int)r3 :(int)r4 :(int)r5 :(int)r6 :(int)r7 :(int)r8 :(int)r9 :(int)r10 :(int &)i { | 
 | } | 
 | @end | 
 |  | 
 | // rdar://9566314 | 
 | @interface NX | 
 | - (void)Meth; | 
 | @end | 
 |  | 
 | @implementation NX | 
 | - (void)Meth { | 
 |   void uiIsVisible(); | 
 | // CHECK: call void @_Z11uiIsVisiblev | 
 |   uiIsVisible(); | 
 | } | 
 | @end | 
 |  | 
 | // rdar://13434937 | 
 | // | 
 | // Don't crash when mangling an enum whose semantic context | 
 | // is a class extension (which looks anonymous in the AST). | 
 | // The other tests here are just for coverage. | 
 | @interface Test2 @end | 
 | @interface Test2 () | 
 | @property (assign) enum { T2x, T2y, T2z } axis; | 
 | @end | 
 | @interface Test2 (a) | 
 | @property (assign) enum { T2i, T2j, T2k } dimension; | 
 | @end | 
 | @implementation Test2 { | 
 | @public | 
 |   enum { T2a, T2b, T2c } alt_axis; | 
 | } | 
 | @end | 
 | template <class T> struct Test2Template { Test2Template() {} }; // must have a member that we'll instantiate and mangle | 
 | void test2(Test2 *t) { | 
 |   Test2Template<decltype(t.axis)> t0; | 
 |   Test2Template<decltype(t.dimension)> t1; | 
 |   Test2Template<decltype(t->alt_axis)> t2; | 
 | } | 
 |  | 
 | @protocol P; | 
 | void overload1(A<P>*) {} | 
 | // CHECK-LABEL: define void @_Z9overload1PU11objcproto1P1A | 
 | void overload1(const A<P>*) {} | 
 | // CHECK-LABEL: define void @_Z9overload1PKU11objcproto1P1A | 
 | void overload1(A<P>**) {} | 
 | // CHECK-LABEL: define void @_Z9overload1PPU11objcproto1P1A | 
 | void overload1(A<P>*const*) {} | 
 | // CHECK-LABEL: define void @_Z9overload1PKPU11objcproto1P1A | 
 | void overload1(A<P>***) {} | 
 | // CHECK-LABEL: define void @_Z9overload1PPPU11objcproto1P1A | 
 | void overload1(void (f)(A<P>*)) {} | 
 | // CHECK-LABEL: define void @_Z9overload1PFvPU11objcproto1P1AE | 
 |  | 
 | template<typename T> struct X { void f(); }; | 
 | template<> void X<A*>::f() {} | 
 | // CHECK-LABEL: define void @_ZN1XIP1AE1fEv | 
 | template<> void X<A<P>*>::f() {} | 
 | // CHECK-LABEL: define void @_ZN1XIPU11objcproto1P1AE1fEv | 
 |  | 
 | // CHECK-LABEL: define void @_Z12kindof_test2PU8__kindof5Test2 | 
 | void kindof_test2(__kindof Test2 *t2) { } | 
 |  | 
 | @interface Parameterized<T, U> : A | 
 | @end | 
 |  | 
 | // CHECK-LABEL: define void @_Z19parameterized_test1P13ParameterizedIP1AP4TestE | 
 | void parameterized_test1(Parameterized<A *, Test *> *p) {} | 
 |  | 
 | // CHECK-LABEL: define void @_Z19parameterized_test2PU8__kindof13ParameterizedIP1AP4TestE | 
 | void parameterized_test2(__kindof Parameterized<A *, Test *> *p) {} | 
 |  | 
 | // CHECK-LABEL: define void @_Z19parameterized_test3P13Parameterized | 
 | void parameterized_test3(Parameterized *p) {} | 
 |  | 
 | // CHECK-LABEL: define {{.*}}void @_Z1fP11objc_object | 
 | void f(__attribute__((ns_consumed)) id) {} | 
 | // CHECK-LABEL: define {{.*}}void @_Z1fPFP11objc_objectS0_S0_E | 
 | void f(id (*fn)(__attribute__((ns_consumed)) id, id)) {} | 
 | // CHECK-LABEL: define {{.*}}void @_Z1fU13block_pointerFvP11objc_objectE | 
 | void f(void (^)(__attribute__((ns_consumed)) id)) {} |