Home | History | Annotate | Download | only in CodeGenCXX
      1 // RUN: %clang_cc1 %s -triple=x86_64-pc-linux -emit-llvm -o %t
      2 // RUN: %clang_cc1 %s -triple=x86_64-apple-darwin10 -disable-llvm-optzns -O3 -emit-llvm -o %t.opt
      3 // RUN: FileCheck --check-prefix=CHECK %s < %t
      4 // RUN: FileCheck --check-prefix=CHECK-OPT %s < %t.opt
      5 
      6 namespace {
      7   struct A {
      8     virtual void f() { }
      9   };
     10 }
     11 
     12 void f() { A b; }
     13 
     14 struct B {
     15   B();
     16   virtual void f();
     17 };
     18 
     19 B::B() { }
     20 
     21 struct C : virtual B {
     22   C();
     23   virtual void f() { }
     24 };
     25 
     26 C::C() { }
     27 
     28 struct D {
     29   virtual void f();
     30 };
     31 
     32 void D::f() { }
     33 
     34 static struct : D { } e;
     35 
     36 // The destructor is the key function.
     37 template<typename T>
     38 struct E {
     39   virtual ~E();
     40 };
     41 
     42 template<typename T> E<T>::~E() { }
     43 
     44 // Anchor is the key function
     45 template<>
     46 struct E<char> {
     47   virtual void anchor();
     48 };
     49 
     50 void E<char>::anchor() { }
     51 
     52 template struct E<short>;
     53 extern template struct E<int>;
     54 
     55 void use_E() {
     56   E<int> ei;
     57   (void)ei;
     58   E<long> el;
     59   (void)el;
     60 }
     61 
     62 // No key function
     63 template<typename T>
     64 struct F {
     65   virtual void foo() { }
     66 };
     67 
     68 // No key function
     69 template<>
     70 struct F<char> {
     71   virtual void foo() { }
     72 };
     73 
     74 template struct F<short>;
     75 extern template struct F<int>;
     76 
     77 void use_F() {
     78   F<char> fc;
     79   fc.foo();
     80   F<int> fi;
     81   fi.foo();
     82   F<long> fl;
     83   (void)fl;
     84 }
     85 
     86 // B has a key function that is not defined in this translation unit so its vtable
     87 // has external linkage.
     88 // CHECK-DAG: @_ZTV1B = external unnamed_addr constant
     89 
     90 // C has no key function, so its vtable should have weak_odr linkage
     91 // and hidden visibility (rdar://problem/7523229).
     92 // CHECK-DAG: @_ZTV1C = linkonce_odr unnamed_addr constant {{.*}}, comdat,
     93 // CHECK-DAG: @_ZTS1C = linkonce_odr constant {{.*}}, comdat{{$}}
     94 // CHECK-DAG: @_ZTI1C = linkonce_odr constant {{.*}}, comdat{{$}}
     95 // CHECK-DAG: @_ZTT1C = linkonce_odr unnamed_addr constant {{.*}}, comdat{{$}}
     96 
     97 // D has a key function that is defined in this translation unit so its vtable is
     98 // defined in the translation unit.
     99 // CHECK-DAG: @_ZTV1D = unnamed_addr constant
    100 // CHECK-DAG: @_ZTS1D = constant
    101 // CHECK-DAG: @_ZTI1D = constant
    102 
    103 // E<char> is an explicit specialization with a key function defined
    104 // in this translation unit, so its vtable should have external
    105 // linkage.
    106 // CHECK-DAG: @_ZTV1EIcE = unnamed_addr constant
    107 // CHECK-DAG: @_ZTS1EIcE = constant
    108 // CHECK-DAG: @_ZTI1EIcE = constant
    109 
    110 // E<short> is an explicit template instantiation with a key function
    111 // defined in this translation unit, so its vtable should have
    112 // weak_odr linkage.
    113 // CHECK-DAG: @_ZTV1EIsE = weak_odr unnamed_addr constant {{.*}}, comdat,
    114 // CHECK-DAG: @_ZTS1EIsE = weak_odr constant {{.*}}, comdat{{$}}
    115 // CHECK-DAG: @_ZTI1EIsE = weak_odr constant {{.*}}, comdat{{$}}
    116 
    117 // F<short> is an explicit template instantiation without a key
    118 // function, so its vtable should have weak_odr linkage
    119 // CHECK-DAG: @_ZTV1FIsE = weak_odr unnamed_addr constant {{.*}}, comdat,
    120 // CHECK-DAG: @_ZTS1FIsE = weak_odr constant {{.*}}, comdat{{$}}
    121 // CHECK-DAG: @_ZTI1FIsE = weak_odr constant {{.*}}, comdat{{$}}
    122 
    123 // E<long> is an implicit template instantiation with a key function
    124 // defined in this translation unit, so its vtable should have
    125 // linkonce_odr linkage.
    126 // CHECK-DAG: @_ZTV1EIlE = linkonce_odr unnamed_addr constant {{.*}}, comdat,
    127 // CHECK-DAG: @_ZTS1EIlE = linkonce_odr constant {{.*}}, comdat{{$}}
    128 // CHECK-DAG: @_ZTI1EIlE = linkonce_odr constant {{.*}}, comdat{{$}}
    129 
    130 // F<long> is an implicit template instantiation with no key function,
    131 // so its vtable should have linkonce_odr linkage.
    132 // CHECK-DAG: @_ZTV1FIlE = linkonce_odr unnamed_addr constant {{.*}}, comdat,
    133 // CHECK-DAG: @_ZTS1FIlE = linkonce_odr constant {{.*}}, comdat{{$}}
    134 // CHECK-DAG: @_ZTI1FIlE = linkonce_odr constant {{.*}}, comdat{{$}}
    135 
    136 // F<int> is an explicit template instantiation declaration without a
    137 // key function, so its vtable should have external linkage.
    138 // CHECK-DAG: @_ZTV1FIiE = external unnamed_addr constant
    139 // CHECK-OPT-DAG: @_ZTV1FIiE = external unnamed_addr constant
    140 
    141 // E<int> is an explicit template instantiation declaration. It has a
    142 // key function that is not instantiated, so we should only reference
    143 // its vtable, not define it.
    144 // CHECK-DAG: @_ZTV1EIiE = external unnamed_addr constant
    145 // CHECK-OPT-DAG: @_ZTV1EIiE = external unnamed_addr constant
    146 
    147 // The anonymous struct for e has no linkage, so the vtable should have
    148 // internal linkage.
    149 // CHECK-DAG: @"_ZTV3$_0" = internal unnamed_addr constant
    150 // CHECK-DAG: @"_ZTS3$_0" = internal constant
    151 // CHECK-DAG: @"_ZTI3$_0" = internal constant
    152 
    153 // The A vtable should have internal linkage since it is inside an anonymous
    154 // namespace.
    155 // CHECK-DAG: @_ZTVN12_GLOBAL__N_11AE = internal unnamed_addr constant
    156 // CHECK-DAG: @_ZTSN12_GLOBAL__N_11AE = internal constant
    157 // CHECK-DAG: @_ZTIN12_GLOBAL__N_11AE = internal constant
    158 
    159 // F<char> is an explicit specialization without a key function, so
    160 // its vtable should have linkonce_odr linkage.
    161 // CHECK-DAG: @_ZTV1FIcE = linkonce_odr unnamed_addr constant {{.*}}, comdat,
    162 // CHECK-DAG: @_ZTS1FIcE = linkonce_odr constant {{.*}}, comdat{{$}}
    163 // CHECK-DAG: @_ZTI1FIcE = linkonce_odr constant {{.*}}, comdat{{$}}
    164 
    165 // CHECK-DAG: @_ZTV1GIiE = linkonce_odr unnamed_addr constant {{.*}}, comdat,
    166 template <typename T>
    167 class G {
    168 public:
    169   G() {}
    170   virtual void f0();
    171   virtual void f1();
    172 };
    173 template <>
    174 void G<int>::f1() {}
    175 template <typename T>
    176 void G<T>::f0() {}
    177 void G_f0()  { new G<int>(); }
    178 
    179 // H<int> has a key function without a body but it's a template instantiation
    180 // so its VTable must be emitted.
    181 // CHECK-DAG: @_ZTV1HIiE = linkonce_odr unnamed_addr constant {{.*}}, comdat,
    182 template <typename T>
    183 class H {
    184 public:
    185   virtual ~H();
    186 };
    187 
    188 void use_H() {
    189   H<int> h;
    190 }
    191 
    192 // I<int> has an explicit instantiation declaration and needs a VTT and
    193 // construction vtables.
    194 
    195 // CHECK-DAG: @_ZTV1IIiE = external unnamed_addr constant
    196 // CHECK-DAG: @_ZTT1IIiE = external unnamed_addr constant
    197 // CHECK-NOT: @_ZTC1IIiE
    198 //
    199 // CHECK-OPT-DAG: @_ZTV1IIiE = external unnamed_addr constant
    200 // CHECK-OPT-DAG: @_ZTT1IIiE = external unnamed_addr constant
    201 struct VBase1 { virtual void f(); }; struct VBase2 : virtual VBase1 {};
    202 template<typename T>
    203 struct I : VBase2 {};
    204 extern template struct I<int>;
    205 I<int> i;
    206