annotate gcc/testsuite/g++.dg/concepts/class.C @ 111:04ced10e8804

gcc 7
author kono
date Fri, 27 Oct 2017 22:46:09 +0900
parents
children 84e7813d76e9
Ignore whitespace changes - Everywhere: Within whitespace: At end of lines:
rev   line source
111
kono
parents:
diff changeset
1 // { dg-options "-std=c++17 -fconcepts" }
kono
parents:
diff changeset
2
kono
parents:
diff changeset
3 template<typename T>
kono
parents:
diff changeset
4 concept bool Class() { return __is_class(T); }
kono
parents:
diff changeset
5
kono
parents:
diff changeset
6 template<typename T>
kono
parents:
diff changeset
7 concept bool Union() { return __is_union(T); }
kono
parents:
diff changeset
8
kono
parents:
diff changeset
9
kono
parents:
diff changeset
10 // Check ordering of specializations
kono
parents:
diff changeset
11 template<typename T>
kono
parents:
diff changeset
12 concept bool One() { return sizeof(T) >= 4; }
kono
parents:
diff changeset
13
kono
parents:
diff changeset
14 template<typename T>
kono
parents:
diff changeset
15 concept bool Two() { return One<T>() && sizeof(T) >= 8; }
kono
parents:
diff changeset
16
kono
parents:
diff changeset
17 // Check non-overlapping specializations
kono
parents:
diff changeset
18 template<typename T>
kono
parents:
diff changeset
19 struct S1 { static const int value = 0; };
kono
parents:
diff changeset
20
kono
parents:
diff changeset
21 template<Class T>
kono
parents:
diff changeset
22 struct S1<T> { static const int value = 1; };
kono
parents:
diff changeset
23
kono
parents:
diff changeset
24 template<Union T>
kono
parents:
diff changeset
25 struct S1<T> { static const int value = 2; };
kono
parents:
diff changeset
26
kono
parents:
diff changeset
27 struct S { };
kono
parents:
diff changeset
28 union U { };
kono
parents:
diff changeset
29
kono
parents:
diff changeset
30 static_assert(S1<int>::value == 0, "");
kono
parents:
diff changeset
31 static_assert(S1<S>::value == 1, "");
kono
parents:
diff changeset
32 static_assert(S1<U>::value == 2, "");
kono
parents:
diff changeset
33
kono
parents:
diff changeset
34
kono
parents:
diff changeset
35 // Check ordering of partial specializaitons
kono
parents:
diff changeset
36 template<typename T>
kono
parents:
diff changeset
37 struct S2 { static const int value = 0; };
kono
parents:
diff changeset
38
kono
parents:
diff changeset
39 template<One T>
kono
parents:
diff changeset
40 struct S2<T> { static const int value = 1; };
kono
parents:
diff changeset
41
kono
parents:
diff changeset
42 template<Two T>
kono
parents:
diff changeset
43 struct S2<T> { static const int value = 2; };
kono
parents:
diff changeset
44
kono
parents:
diff changeset
45 struct one_type { char x[4]; };
kono
parents:
diff changeset
46 struct two_type { char x[8]; };
kono
parents:
diff changeset
47
kono
parents:
diff changeset
48 static_assert(S2<char>::value == 0, "");
kono
parents:
diff changeset
49 static_assert(S2<one_type>::value == 1, "");
kono
parents:
diff changeset
50 static_assert(S2<two_type>::value == 2, "");
kono
parents:
diff changeset
51
kono
parents:
diff changeset
52 int main() { }