annotate gcc/testsuite/g++.dg/cpp0x/pr65398.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
111
kono
parents:
diff changeset
1 // PR c++/65398
kono
parents:
diff changeset
2 // { dg-do compile { target c++11 } }
kono
parents:
diff changeset
3
kono
parents:
diff changeset
4 #define SA(X) static_assert((X),#X)
kono
parents:
diff changeset
5
kono
parents:
diff changeset
6 constexpr char s[] = "abc";
kono
parents:
diff changeset
7 constexpr char c1 = *(&s[0] + 0);
kono
parents:
diff changeset
8 constexpr char c2 = *(&s[0] + 1);
kono
parents:
diff changeset
9 constexpr char c3 = *(&s[1] + 0);
kono
parents:
diff changeset
10 constexpr char c4 = *(&s[1] + 1);
kono
parents:
diff changeset
11 constexpr char c5 = *(&s[2] + 0);
kono
parents:
diff changeset
12 constexpr char c6 = *(&s[0] + 2);
kono
parents:
diff changeset
13 constexpr char c7 = *(&s[2] + 1);
kono
parents:
diff changeset
14
kono
parents:
diff changeset
15 constexpr char d1 = *(&s[4] - 0); // { dg-error "array subscript" }
kono
parents:
diff changeset
16 constexpr char d2 = *(&s[4] - 1);
kono
parents:
diff changeset
17 constexpr char d3 = *(&s[4] - 2);
kono
parents:
diff changeset
18 constexpr char d4 = *(&s[4] - 3);
kono
parents:
diff changeset
19 constexpr char d5 = *(&s[4] - 4);
kono
parents:
diff changeset
20 constexpr char d6 = *(&s[4] - 5); // { dg-error "array subscript" }
kono
parents:
diff changeset
21
kono
parents:
diff changeset
22 /* Don't accept invalid stuff. */
kono
parents:
diff changeset
23 constexpr char e1 = *(&s[5] - 1); // { dg-error "array subscript" }
kono
parents:
diff changeset
24 constexpr char e2 = *(&s[5] - 2); // { dg-error "array subscript" }
kono
parents:
diff changeset
25 constexpr char e3 = *(&s[5] - 3); // { dg-error "array subscript" }
kono
parents:
diff changeset
26
kono
parents:
diff changeset
27 SA (c1 == 'a');
kono
parents:
diff changeset
28 SA (c2 == 'b');
kono
parents:
diff changeset
29 SA (c3 == 'b');
kono
parents:
diff changeset
30 SA (c4 == 'c');
kono
parents:
diff changeset
31 SA (c5 == 'c');
kono
parents:
diff changeset
32 SA (c6 == 'c');
kono
parents:
diff changeset
33 SA (c7 == '\0');
kono
parents:
diff changeset
34 SA (d2 == '\0');
kono
parents:
diff changeset
35 SA (d3 == 'c');
kono
parents:
diff changeset
36 SA (d4 == 'b');
kono
parents:
diff changeset
37 SA (d5 == 'a');
kono
parents:
diff changeset
38
kono
parents:
diff changeset
39 constexpr int l[] = { 'c', 'd', 'e', '\0' };
kono
parents:
diff changeset
40 constexpr int i1 = *(&l[0] + 0);
kono
parents:
diff changeset
41 constexpr int i2 = *(&l[0] + 1);
kono
parents:
diff changeset
42 constexpr int i3 = *(&l[1] + 0);
kono
parents:
diff changeset
43 constexpr int i4 = *(&l[1] + 1);
kono
parents:
diff changeset
44 constexpr int i5 = *(&l[2] + 0);
kono
parents:
diff changeset
45 constexpr int i6 = *(&l[0] + 2);
kono
parents:
diff changeset
46 constexpr int i7 = *(&l[2] + 1);
kono
parents:
diff changeset
47
kono
parents:
diff changeset
48 constexpr char j1 = *(&l[4] - 0); // { dg-error "array subscript" }
kono
parents:
diff changeset
49 constexpr char j2 = *(&l[4] - 1);
kono
parents:
diff changeset
50 constexpr char j3 = *(&l[4] - 2);
kono
parents:
diff changeset
51 constexpr char j4 = *(&l[4] - 3);
kono
parents:
diff changeset
52 constexpr char j5 = *(&l[4] - 4);
kono
parents:
diff changeset
53 constexpr char j6 = *(&l[4] - 5); // { dg-error "array subscript" }
kono
parents:
diff changeset
54
kono
parents:
diff changeset
55 /* Don't accept invalid stuff. */
kono
parents:
diff changeset
56 constexpr char k1 = *(&l[5] - 1); // { dg-error "array subscript" }
kono
parents:
diff changeset
57 constexpr char k2 = *(&l[5] - 2); // { dg-error "array subscript" }
kono
parents:
diff changeset
58 constexpr char k3 = *(&l[5] - 3); // { dg-error "array subscript" }
kono
parents:
diff changeset
59
kono
parents:
diff changeset
60 SA (i1 == 'c');
kono
parents:
diff changeset
61 SA (i2 == 'd');
kono
parents:
diff changeset
62 SA (i3 == 'd');
kono
parents:
diff changeset
63 SA (i4 == 'e');
kono
parents:
diff changeset
64 SA (i5 == 'e');
kono
parents:
diff changeset
65 SA (i6 == 'e');
kono
parents:
diff changeset
66 SA (i7 == '\0');
kono
parents:
diff changeset
67 SA (j2 == '\0');
kono
parents:
diff changeset
68 SA (j3 == 'e');
kono
parents:
diff changeset
69 SA (j4 == 'd');
kono
parents:
diff changeset
70 SA (j5 == 'c');