annotate gcc/testsuite/g++.dg/concepts/fn9.C @ 145:1830386684a0

gcc-9.2.0
author anatofuz
date Thu, 13 Feb 2020 11:34:05 +0900
parents 84e7813d76e9
children
Ignore whitespace changes - Everywhere: Within whitespace: At end of lines:
rev   line source
145
1830386684a0 gcc-9.2.0
anatofuz
parents: 131
diff changeset
1 // { dg-do compile { target c++17_only } }
131
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 Class() { return __is_class(T); }
kono
parents:
diff changeset
8
kono
parents:
diff changeset
9 template<typename T>
kono
parents:
diff changeset
10 concept bool Empty() { return Class<T>() and __is_empty(T); }
kono
parents:
diff changeset
11
kono
parents:
diff changeset
12 template<Class T> int f(T) { return 1; }
kono
parents:
diff changeset
13 template<Empty T> int f(T) { return 2; }
kono
parents:
diff changeset
14
kono
parents:
diff changeset
15 struct S {
kono
parents:
diff changeset
16 template<Class T> int f(T) { return 1; }
kono
parents:
diff changeset
17 template<Empty T> int f(T) { return 2; }
kono
parents:
diff changeset
18 } s;
kono
parents:
diff changeset
19
kono
parents:
diff changeset
20 struct X { } x;
kono
parents:
diff changeset
21 struct Y { X x; } y;
kono
parents:
diff changeset
22
kono
parents:
diff changeset
23 int main () {
kono
parents:
diff changeset
24 auto p1 = &f<X>; // Empty f
kono
parents:
diff changeset
25 assert(p1(x) == 2);
kono
parents:
diff changeset
26
kono
parents:
diff changeset
27 auto p2 = &f<Y>; // Class f
kono
parents:
diff changeset
28 assert(p2(y) == 1);
kono
parents:
diff changeset
29
kono
parents:
diff changeset
30 auto p3 = &S::template f<X>; // Empty f
kono
parents:
diff changeset
31 assert((s.*p3)(x) == 2);
kono
parents:
diff changeset
32
kono
parents:
diff changeset
33 auto p4 = &S::template f<Y>; // Empty f
kono
parents:
diff changeset
34 assert((s.*p4)(y) == 1);
kono
parents:
diff changeset
35 }