annotate gcc/testsuite/g++.dg/cpp0x/rv8p.C @ 145:1830386684a0

gcc-9.2.0
author anatofuz
date Thu, 13 Feb 2020 11:34:05 +0900
parents 04ced10e8804
children
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
kono
parents:
diff changeset
8 template <bool> struct sa;
kono
parents:
diff changeset
9 template <> struct sa<true> {};
kono
parents:
diff changeset
10
kono
parents:
diff changeset
11 struct one {long x[1];};
kono
parents:
diff changeset
12 struct two {long x[2];};
kono
parents:
diff changeset
13 struct three {long x[3];};
kono
parents:
diff changeset
14 struct four {long x[4];};
kono
parents:
diff changeset
15 struct five {long x[5];};
kono
parents:
diff changeset
16 struct six {long x[6];};
kono
parents:
diff changeset
17 struct seven {long x[7];};
kono
parents:
diff changeset
18 struct eight {long x[8];};
kono
parents:
diff changeset
19
kono
parents:
diff changeset
20 struct A
kono
parents:
diff changeset
21 {
kono
parents:
diff changeset
22 A();
kono
parents:
diff changeset
23 A(const volatile A&&);
kono
parents:
diff changeset
24 };
kono
parents:
diff changeset
25
kono
parents:
diff changeset
26 A source();
kono
parents:
diff changeset
27 const A c_source();
145
1830386684a0 gcc-9.2.0
anatofuz
parents: 111
diff changeset
28 volatile A v_source(); // { dg-warning "deprecated" "" { target c++2a } }
1830386684a0 gcc-9.2.0
anatofuz
parents: 111
diff changeset
29 const volatile A cv_source(); // { dg-warning "deprecated" "" { target c++2a } }
111
kono
parents:
diff changeset
30
kono
parents:
diff changeset
31 // 8 at a time
kono
parents:
diff changeset
32
kono
parents:
diff changeset
33 one sink_8_12345678( A&);
kono
parents:
diff changeset
34 two sink_8_12345678(const A&);
kono
parents:
diff changeset
35 three sink_8_12345678(volatile A&);
kono
parents:
diff changeset
36 four sink_8_12345678(const volatile A&);
kono
parents:
diff changeset
37 five sink_8_12345678( A&&);
kono
parents:
diff changeset
38 six sink_8_12345678(const A&&);
kono
parents:
diff changeset
39 seven sink_8_12345678(volatile A&&);
kono
parents:
diff changeset
40 eight sink_8_12345678(const volatile A&&);
kono
parents:
diff changeset
41
kono
parents:
diff changeset
42 int test8_12345678()
kono
parents:
diff changeset
43 {
kono
parents:
diff changeset
44 A a;
kono
parents:
diff changeset
45 const A ca;
kono
parents:
diff changeset
46 volatile A va;
kono
parents:
diff changeset
47 const volatile A cva;
kono
parents:
diff changeset
48 sa<sizeof(sink_8_12345678(a)) == 1 * sizeof(long)> t1;
kono
parents:
diff changeset
49 sa<sizeof(sink_8_12345678(ca)) == 2 * sizeof(long)> t2;
kono
parents:
diff changeset
50 sa<sizeof(sink_8_12345678(va)) == 3 * sizeof(long)> t3;
kono
parents:
diff changeset
51 sa<sizeof(sink_8_12345678(cva)) == 4 * sizeof(long)> t4;
kono
parents:
diff changeset
52 sa<sizeof(sink_8_12345678(source())) == 5 * sizeof(long)> t5;
kono
parents:
diff changeset
53 sa<sizeof(sink_8_12345678(c_source())) == 6 * sizeof(long)> t6;
kono
parents:
diff changeset
54 sa<sizeof(sink_8_12345678(v_source())) == 7 * sizeof(long)> t7;
kono
parents:
diff changeset
55 sa<sizeof(sink_8_12345678(cv_source())) == 8 * sizeof(long)> t8;
kono
parents:
diff changeset
56 return 0;
kono
parents:
diff changeset
57 }
kono
parents:
diff changeset
58
kono
parents:
diff changeset
59 int main()
kono
parents:
diff changeset
60 {
kono
parents:
diff changeset
61 return test8_12345678();
kono
parents:
diff changeset
62 }