annotate gcc/testsuite/g++.dg/cpp0x/rv1p.C @ 131:84e7813d76e9

gcc-8.2
author mir3636
date Thu, 25 Oct 2018 07:37:49 +0900
parents 04ced10e8804
children 1830386684a0
Ignore whitespace changes - Everywhere: Within whitespace: At end of lines:
rev   line source
111
kono
parents:
diff changeset
1 // I, Howard Hinnant, hereby place this code in the public domain.
kono
parents:
diff changeset
2
kono
parents:
diff changeset
3 // Test overload resolution among reference types
kono
parents:
diff changeset
4
kono
parents:
diff changeset
5 // { dg-do compile { target c++11 } }
kono
parents:
diff changeset
6 // { dg-skip-if "packed attribute missing for struct one/three/five/seven" { "epiphany-*-*" } }
kono
parents:
diff changeset
7 // { dg-additional-options "-fno-ipa-icf" }
kono
parents:
diff changeset
8
kono
parents:
diff changeset
9 template <bool> struct sa;
kono
parents:
diff changeset
10 template <> struct sa<true> {};
kono
parents:
diff changeset
11
kono
parents:
diff changeset
12 struct one {long x[1];};
kono
parents:
diff changeset
13 struct two {long x[2];};
kono
parents:
diff changeset
14 struct three {long x[3];};
kono
parents:
diff changeset
15 struct four {long x[4];};
kono
parents:
diff changeset
16 struct five {long x[5];};
kono
parents:
diff changeset
17 struct six {long x[6];};
kono
parents:
diff changeset
18 struct seven {long x[7];};
kono
parents:
diff changeset
19 struct eight {long x[8];};
kono
parents:
diff changeset
20
kono
parents:
diff changeset
21 struct A
kono
parents:
diff changeset
22 {
kono
parents:
diff changeset
23 A();
kono
parents:
diff changeset
24 A(const volatile A&&);
kono
parents:
diff changeset
25 };
kono
parents:
diff changeset
26
kono
parents:
diff changeset
27 A source();
kono
parents:
diff changeset
28 const A c_source();
kono
parents:
diff changeset
29 volatile A v_source();
kono
parents:
diff changeset
30 const volatile A cv_source();
kono
parents:
diff changeset
31
kono
parents:
diff changeset
32 // 1 at a time
kono
parents:
diff changeset
33
kono
parents:
diff changeset
34 one sink_1_1( A&);
kono
parents:
diff changeset
35
kono
parents:
diff changeset
36 int test1_1()
kono
parents:
diff changeset
37 {
kono
parents:
diff changeset
38 A a;
kono
parents:
diff changeset
39 const A ca;
kono
parents:
diff changeset
40 volatile A va;
kono
parents:
diff changeset
41 const volatile A cva;
kono
parents:
diff changeset
42 sa<sizeof(sink_1_1(a)) == 1 * sizeof(long)> t1;
kono
parents:
diff changeset
43 return 0;
kono
parents:
diff changeset
44 }
kono
parents:
diff changeset
45
kono
parents:
diff changeset
46 two sink_1_2(const A&);
kono
parents:
diff changeset
47
kono
parents:
diff changeset
48 int test1_2()
kono
parents:
diff changeset
49 {
kono
parents:
diff changeset
50 A a;
kono
parents:
diff changeset
51 const A ca;
kono
parents:
diff changeset
52 volatile A va;
kono
parents:
diff changeset
53 const volatile A cva;
kono
parents:
diff changeset
54 sa<sizeof(sink_1_2(a)) == 2 * sizeof(long)> t1;
kono
parents:
diff changeset
55 sa<sizeof(sink_1_2(ca)) == 2 * sizeof(long)> t2;
kono
parents:
diff changeset
56 sa<sizeof(sink_1_2(source())) == 2 * sizeof(long)> t5;
kono
parents:
diff changeset
57 sa<sizeof(sink_1_2(c_source())) == 2 * sizeof(long)> t6;
kono
parents:
diff changeset
58 return 0;
kono
parents:
diff changeset
59 }
kono
parents:
diff changeset
60
kono
parents:
diff changeset
61 three sink_1_3(volatile A&);
kono
parents:
diff changeset
62
kono
parents:
diff changeset
63 int test1_3()
kono
parents:
diff changeset
64 {
kono
parents:
diff changeset
65 A a;
kono
parents:
diff changeset
66 const A ca;
kono
parents:
diff changeset
67 volatile A va;
kono
parents:
diff changeset
68 const volatile A cva;
kono
parents:
diff changeset
69 sa<sizeof(sink_1_3(a)) == 3 * sizeof(long)> t1;
kono
parents:
diff changeset
70 sa<sizeof(sink_1_3(va)) == 3 * sizeof(long)> t3;
kono
parents:
diff changeset
71 return 0;
kono
parents:
diff changeset
72 }
kono
parents:
diff changeset
73
kono
parents:
diff changeset
74 four sink_1_4(const volatile A&);
kono
parents:
diff changeset
75
kono
parents:
diff changeset
76 int test1_4()
kono
parents:
diff changeset
77 {
kono
parents:
diff changeset
78 A a;
kono
parents:
diff changeset
79 const A ca;
kono
parents:
diff changeset
80 volatile A va;
kono
parents:
diff changeset
81 const volatile A cva;
kono
parents:
diff changeset
82 sa<sizeof(sink_1_4(a)) == 4 * sizeof(long)> t1;
kono
parents:
diff changeset
83 sa<sizeof(sink_1_4(ca)) == 4 * sizeof(long)> t2;
kono
parents:
diff changeset
84 sa<sizeof(sink_1_4(va)) == 4 * sizeof(long)> t3;
kono
parents:
diff changeset
85 sa<sizeof(sink_1_4(cva)) == 4 * sizeof(long)> t4;
kono
parents:
diff changeset
86 return 0;
kono
parents:
diff changeset
87 }
kono
parents:
diff changeset
88
kono
parents:
diff changeset
89 five sink_1_5( A&&);
kono
parents:
diff changeset
90
kono
parents:
diff changeset
91 int test1_5()
kono
parents:
diff changeset
92 {
kono
parents:
diff changeset
93 A a;
kono
parents:
diff changeset
94 const A ca;
kono
parents:
diff changeset
95 volatile A va;
kono
parents:
diff changeset
96 const volatile A cva;
kono
parents:
diff changeset
97 sa<sizeof(sink_1_5(source())) == 5 * sizeof(long)> t5;
kono
parents:
diff changeset
98 return 0;
kono
parents:
diff changeset
99 }
kono
parents:
diff changeset
100
kono
parents:
diff changeset
101 six sink_1_6(const A&&);
kono
parents:
diff changeset
102
kono
parents:
diff changeset
103 int test1_6()
kono
parents:
diff changeset
104 {
kono
parents:
diff changeset
105 A a;
kono
parents:
diff changeset
106 const A ca;
kono
parents:
diff changeset
107 volatile A va;
kono
parents:
diff changeset
108 const volatile A cva;
kono
parents:
diff changeset
109 sa<sizeof(sink_1_6(source())) == 6 * sizeof(long)> t5;
kono
parents:
diff changeset
110 sa<sizeof(sink_1_6(c_source())) == 6 * sizeof(long)> t6;
kono
parents:
diff changeset
111 return 0;
kono
parents:
diff changeset
112 }
kono
parents:
diff changeset
113
kono
parents:
diff changeset
114 seven sink_1_7(volatile A&&);
kono
parents:
diff changeset
115
kono
parents:
diff changeset
116 int test1_7()
kono
parents:
diff changeset
117 {
kono
parents:
diff changeset
118 A a;
kono
parents:
diff changeset
119 const A ca;
kono
parents:
diff changeset
120 volatile A va;
kono
parents:
diff changeset
121 const volatile A cva;
kono
parents:
diff changeset
122 sa<sizeof(sink_1_7(source())) == 7 * sizeof(long)> t5;
kono
parents:
diff changeset
123 sa<sizeof(sink_1_7(v_source())) == 7 * sizeof(long)> t7;
kono
parents:
diff changeset
124 return 0;
kono
parents:
diff changeset
125 }
kono
parents:
diff changeset
126
kono
parents:
diff changeset
127 eight sink_1_8(const volatile A&&);
kono
parents:
diff changeset
128
kono
parents:
diff changeset
129 int test1_8()
kono
parents:
diff changeset
130 {
kono
parents:
diff changeset
131 A a;
kono
parents:
diff changeset
132 const A ca;
kono
parents:
diff changeset
133 volatile A va;
kono
parents:
diff changeset
134 const volatile A cva;
kono
parents:
diff changeset
135 sa<sizeof(sink_1_8(source())) == 8 * sizeof(long)> t5;
kono
parents:
diff changeset
136 sa<sizeof(sink_1_8(c_source())) == 8 * sizeof(long)> t6;
kono
parents:
diff changeset
137 sa<sizeof(sink_1_8(v_source())) == 8 * sizeof(long)> t7;
kono
parents:
diff changeset
138 sa<sizeof(sink_1_8(cv_source())) == 8 * sizeof(long)> t8;
kono
parents:
diff changeset
139 return 0;
kono
parents:
diff changeset
140 }
kono
parents:
diff changeset
141
kono
parents:
diff changeset
142 int main()
kono
parents:
diff changeset
143 {
kono
parents:
diff changeset
144 return test1_1() + test1_2() + test1_3() + test1_4() +
kono
parents:
diff changeset
145 test1_5() + test1_6() + test1_7() + test1_8();
kono
parents:
diff changeset
146 }