annotate gcc/testsuite/g++.dg/concepts/explicit-spec4.C @ 131:84e7813d76e9

gcc-8.2
author mir3636
date Thu, 25 Oct 2018 07:37:49 +0900
parents 04ced10e8804
children
Ignore whitespace changes - Everywhere: Within whitespace: At end of lines:
rev   line source
131
84e7813d76e9 gcc-8.2
mir3636
parents: 111
diff changeset
1 // { dg-do run { target c++17 } }
84e7813d76e9 gcc-8.2
mir3636
parents: 111
diff changeset
2 // { dg-options "-fconcepts" }
111
kono
parents:
diff changeset
3
kono
parents:
diff changeset
4 #include <cassert>
kono
parents:
diff changeset
5
kono
parents:
diff changeset
6 template<typename T>
kono
parents:
diff changeset
7 concept bool C() { return __is_class(T); }
kono
parents:
diff changeset
8
kono
parents:
diff changeset
9 template<typename T>
kono
parents:
diff changeset
10 concept bool D() { return C<T>() && __is_empty(T); }
kono
parents:
diff changeset
11
kono
parents:
diff changeset
12 struct X { } x;
kono
parents:
diff changeset
13 struct Y { int n; } y;
kono
parents:
diff changeset
14
kono
parents:
diff changeset
15 int called = 0;
kono
parents:
diff changeset
16
kono
parents:
diff changeset
17 template<typename T>
kono
parents:
diff changeset
18 struct S {
kono
parents:
diff changeset
19 void f() { called = 0; } // #1
kono
parents:
diff changeset
20 void f() requires C<T>() { called = 0; } // #2
kono
parents:
diff changeset
21
kono
parents:
diff changeset
22 void g() requires C<T>() { } // #1
kono
parents:
diff changeset
23 void g() requires D<T>() { } // #2
kono
parents:
diff changeset
24 };
kono
parents:
diff changeset
25
kono
parents:
diff changeset
26 template<> void S<int>::f() { called = 1; } // Spec of #1
kono
parents:
diff changeset
27 template<> void S<X>::f() { called = 2; } // Spec of #2
kono
parents:
diff changeset
28
kono
parents:
diff changeset
29 template<> void S<X>::g() { called = 3; } // Spec of #2
kono
parents:
diff changeset
30 template<> void S<Y>::g() { called = 4; } // Spec of #1
kono
parents:
diff changeset
31
kono
parents:
diff changeset
32 int main() {
kono
parents:
diff changeset
33 S<double> sd;
kono
parents:
diff changeset
34 S<int> si;
kono
parents:
diff changeset
35 S<X> sx;
kono
parents:
diff changeset
36 S<Y> sy;
kono
parents:
diff changeset
37
kono
parents:
diff changeset
38 sd.f();
kono
parents:
diff changeset
39 assert(called == 0);
kono
parents:
diff changeset
40 si.f();
kono
parents:
diff changeset
41 assert(called == 1);
kono
parents:
diff changeset
42 sx.f();
kono
parents:
diff changeset
43 assert(called == 2);
kono
parents:
diff changeset
44 sy.f();
kono
parents:
diff changeset
45 assert(called == 0);
kono
parents:
diff changeset
46
kono
parents:
diff changeset
47 sx.g();
kono
parents:
diff changeset
48 assert(called == 3);
kono
parents:
diff changeset
49 sy.g();
kono
parents:
diff changeset
50 assert(called == 4);
kono
parents:
diff changeset
51 }