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