xref: /aosp_15_r20/external/clang/test/CoverageMapping/classtemplate.cpp (revision 67e74705e28f6214e480b399dd47ea732279e315)
1*67e74705SXin Li // RUN: %clang_cc1 -triple %itanium_abi_triple -fprofile-instrument=clang -fcoverage-mapping -dump-coverage-mapping -emit-llvm-only -main-file-name classtemplate.cpp %s > %tmapping
2*67e74705SXin Li // RUN: FileCheck -input-file %tmapping %s --check-prefix=CHECK-CONSTRUCTOR
3*67e74705SXin Li // RUN: FileCheck -input-file %tmapping %s --check-prefix=CHECK-GETTER
4*67e74705SXin Li // RUN: FileCheck -input-file %tmapping %s --check-prefix=CHECK-SETTER
5*67e74705SXin Li 
6*67e74705SXin Li template<class TT>
7*67e74705SXin Li class Test {
8*67e74705SXin Li public:
9*67e74705SXin Li   enum BaseType {
10*67e74705SXin Li     A, C, G, T, Invalid
11*67e74705SXin Li   };
12*67e74705SXin Li   const static int BaseCount = 4;
13*67e74705SXin Li   double bases[BaseCount];
14*67e74705SXin Li 
15*67e74705SXin Li                                         // CHECK-CONSTRUCTOR: _ZN4TestIjEC
Test()16*67e74705SXin Li   Test() { }                            // CHECK-CONSTRUCTOR: File 0, [[@LINE]]:10 -> [[@LINE]]:13 = #0
17*67e74705SXin Li 
18*67e74705SXin Li   // FIXME: It would be nice to emit no-coverage for get, but trying to do this
19*67e74705SXin Li   // runs afoul of cases like Test3::unmangleable below.
20*67e74705SXin Li                                         // FIXME-GETTER: _ZNK4TestIjE3get
get(TT position) const21*67e74705SXin Li   double get(TT position) const {       // FIXME-GETTER: File 0, [[@LINE]]:33 -> [[@LINE+2]]:4 = 0
22*67e74705SXin Li     return bases[position];
23*67e74705SXin Li   }
24*67e74705SXin Li                                         // CHECK-SETTER: _ZN4TestIjE3set
set(TT position,double value)25*67e74705SXin Li   void set(TT position, double value) { // CHECK-SETTER: File 0, [[@LINE]]:39 -> [[@LINE+2]]:4 = #0
26*67e74705SXin Li     bases[position] = value;
27*67e74705SXin Li   }
28*67e74705SXin Li };
29*67e74705SXin Li 
30*67e74705SXin Li class Test2 {
31*67e74705SXin Li                                         // CHECK-CONSTRUCTOR: _ZN5Test2C
Test2()32*67e74705SXin Li   Test2() { }                           // CHECK-CONSTRUCTOR: File 0, [[@LINE]]:11 -> [[@LINE]]:14 = 0
33*67e74705SXin Li                                         // CHECK-GETTER: _ZNK5Test23get
get(unsigned position) const34*67e74705SXin Li   double get(unsigned position) const { // CHECK-GETTER: File 0, [[@LINE]]:39 -> [[@LINE+2]]:4 = 0
35*67e74705SXin Li     return 0.0;
36*67e74705SXin Li   }
37*67e74705SXin Li };
38*67e74705SXin Li 
39*67e74705SXin Li // Test3::unmangleable can't be mangled, since there isn't a complete type for
40*67e74705SXin Li // the __is_final type trait expression. This would cause errors if we try to
41*67e74705SXin Li // emit a no-coverage mapping for the method.
42*67e74705SXin Li template <class T, bool = __is_final(T)> class UninstantiatedClassWithTraits {};
43*67e74705SXin Li template <class T> class Test3 {
unmangleable(UninstantiatedClassWithTraits<T> x)44*67e74705SXin Li   void unmangleable(UninstantiatedClassWithTraits<T> x) {}
45*67e74705SXin Li };
46*67e74705SXin Li 
main()47*67e74705SXin Li int main() {
48*67e74705SXin Li   Test<unsigned> t;
49*67e74705SXin Li   t.set(Test<unsigned>::A, 5.5);
50*67e74705SXin Li   t.set(Test<unsigned>::T, 5.6);
51*67e74705SXin Li   t.set(Test<unsigned>::G, 5.7);
52*67e74705SXin Li   t.set(Test<unsigned>::C, 5.8);
53*67e74705SXin Li   return 0;
54*67e74705SXin Li }
55