annotate gcc/testsuite/gcc.dg/precedence-1.c @ 111:04ced10e8804

gcc 7
author kono
date Fri, 27 Oct 2017 22:46:09 +0900
parents
children
Ignore whitespace changes - Everywhere: Within whitespace: At end of lines:
rev   line source
111
kono
parents:
diff changeset
1 /* Test precedence and associativity in expressions. */
kono
parents:
diff changeset
2 /* Origin: Joseph Myers <joseph@codesourcery.com> */
kono
parents:
diff changeset
3 /* { dg-do compile } */
kono
parents:
diff changeset
4 /* { dg-options "" } */
kono
parents:
diff changeset
5
kono
parents:
diff changeset
6 struct s { int *a; } *p, q, *r[2], *g();
kono
parents:
diff changeset
7 int *i[2];
kono
parents:
diff changeset
8 int j[2];
kono
parents:
diff changeset
9 _Complex double c[2];
kono
parents:
diff changeset
10
kono
parents:
diff changeset
11 void
kono
parents:
diff changeset
12 f (void)
kono
parents:
diff changeset
13 {
kono
parents:
diff changeset
14 #define ASSERT(expr) do { char x[(expr) ? 1 : -1]; } while (0)
kono
parents:
diff changeset
15 /* Postfix and unary operators and casts. */
kono
parents:
diff changeset
16 *p++;
kono
parents:
diff changeset
17 *p--;
kono
parents:
diff changeset
18 *p->a;
kono
parents:
diff changeset
19 *q.a;
kono
parents:
diff changeset
20 *r[1];
kono
parents:
diff changeset
21 (*g()).a;
kono
parents:
diff changeset
22 ++i[0];
kono
parents:
diff changeset
23 --i[0];
kono
parents:
diff changeset
24 +j[0];
kono
parents:
diff changeset
25 -j[0];
kono
parents:
diff changeset
26 ~j[0];
kono
parents:
diff changeset
27 !j[0];
kono
parents:
diff changeset
28 __real__ c[1];
kono
parents:
diff changeset
29 __imag__ c[1];
kono
parents:
diff changeset
30 ASSERT ((sizeof p++) == (sizeof p));
kono
parents:
diff changeset
31 ASSERT ((sizeof (int) + 1) == ((sizeof (int)) + 1));
kono
parents:
diff changeset
32 ASSERT ((__alignof p++) == (__alignof p));
kono
parents:
diff changeset
33 ASSERT ((__alignof (int) + 1) == ((__alignof (int)) + 1));
kono
parents:
diff changeset
34 ASSERT ((sizeof __extension__ 1 + 1) == ((sizeof 1) + 1));
kono
parents:
diff changeset
35 /* Binary operators. */
kono
parents:
diff changeset
36 ASSERT (((_Bool) 1 * 2) == 2);
kono
parents:
diff changeset
37 ASSERT (((_Bool) 8 / 4) == 0);
kono
parents:
diff changeset
38 ASSERT (((_Bool) 8 % 4) == 1);
kono
parents:
diff changeset
39 #define ASSERT_BIN(C1, O1, C2, O2, C3, V1, V2, V3) \
kono
parents:
diff changeset
40 do { \
kono
parents:
diff changeset
41 ASSERT ((C1 O1 C2 O2 C3) == V1); \
kono
parents:
diff changeset
42 ASSERT (((C1 O1 C2) O2 C3) == V2); \
kono
parents:
diff changeset
43 ASSERT ((C1 O1 (C2 O2 C3)) == V3); \
kono
parents:
diff changeset
44 } while (0);
kono
parents:
diff changeset
45 ASSERT_BIN (1, *, 2, *, 3, 6, 6, 6);
kono
parents:
diff changeset
46 ASSERT_BIN (2, *, 2, /, 3, 1, 1, 0);
kono
parents:
diff changeset
47 ASSERT_BIN (2, *, 2, %, 3, 1, 1, 4);
kono
parents:
diff changeset
48 ASSERT_BIN (2, /, 2, *, 3, 3, 3, 0);
kono
parents:
diff changeset
49 ASSERT_BIN (2, /, 2, /, 2, 0, 0, 2);
kono
parents:
diff changeset
50 ASSERT_BIN (2, /, 4, %, 3, 0, 0, 2);
kono
parents:
diff changeset
51 ASSERT_BIN (2, %, 2, *, 3, 0, 0, 2);
kono
parents:
diff changeset
52 ASSERT_BIN (2, %, 9, /, 3, 0, 0, 2);
kono
parents:
diff changeset
53 ASSERT_BIN (2, %, 4, %, 3, 2, 2, 0);
kono
parents:
diff changeset
54 ASSERT_BIN (2, *, 3, +, 4, 10, 10, 14);
kono
parents:
diff changeset
55 ASSERT_BIN (2, *, 3, -, 4, 2, 2, -2);
kono
parents:
diff changeset
56 ASSERT_BIN (2, /, 3, +, 4, 4, 4, 0);
kono
parents:
diff changeset
57 ASSERT_BIN (2, /, 3, -, 4, -4, -4, -2);
kono
parents:
diff changeset
58 ASSERT_BIN (2, %, 3, +, 4, 6, 6, 2);
kono
parents:
diff changeset
59 ASSERT_BIN (2, %, 3, -, 4, -2, -2, 0);
kono
parents:
diff changeset
60 ASSERT_BIN (2, +, 3, *, 4, 14, 20, 14);
kono
parents:
diff changeset
61 ASSERT_BIN (2, +, 3, /, 4, 2, 1, 2);
kono
parents:
diff changeset
62 ASSERT_BIN (2, +, 3, %, 4, 5, 1, 5);
kono
parents:
diff changeset
63 ASSERT_BIN (2, -, 3, *, 4, -10, -4, -10);
kono
parents:
diff changeset
64 ASSERT_BIN (2, -, 3, /, 4, 2, 0, 2);
kono
parents:
diff changeset
65 ASSERT_BIN (2, -, 4, %, 4, 2, -2, 2);
kono
parents:
diff changeset
66 ASSERT_BIN (2, +, 3, +, 4, 9, 9, 9);
kono
parents:
diff changeset
67 ASSERT_BIN (2, +, 3, -, 4, 1, 1, 1);
kono
parents:
diff changeset
68 ASSERT_BIN (2, -, 3, +, 4, 3, 3, -5);
kono
parents:
diff changeset
69 ASSERT_BIN (2, -, 3, -, 4, -5, -5, 3);
kono
parents:
diff changeset
70 ASSERT_BIN (3, +, 2, <<, 4, 80, 80, 35);
kono
parents:
diff changeset
71 ASSERT_BIN (3, +, 2, >>, 4, 0, 0, 3);
kono
parents:
diff changeset
72 ASSERT_BIN (3, -, 2, <<, 4, 16, 16, -29);
kono
parents:
diff changeset
73 ASSERT_BIN (3, -, 2, >>, 4, 0, 0, 3);
kono
parents:
diff changeset
74 ASSERT_BIN (2, <<, 4, +, 3, 256, 35, 256);
kono
parents:
diff changeset
75 ASSERT_BIN (2, <<, 4, -, 3, 4, 29, 4);
kono
parents:
diff changeset
76 ASSERT_BIN (2, >>, 4, +, 3, 0, 3, 0);
kono
parents:
diff changeset
77 ASSERT_BIN (2, >>, 4, -, 3, 1, -3, 1);
kono
parents:
diff changeset
78 ASSERT_BIN (4L, <<, 2L, <<, 3L, 128L, 128L, 262144L);
kono
parents:
diff changeset
79 ASSERT_BIN (4L, <<, 2L, >>, 3L, 2L, 2L, 4L);
kono
parents:
diff changeset
80 ASSERT_BIN (4L, >>, 2L, <<, 3L, 8L, 8L, 0L);
kono
parents:
diff changeset
81 ASSERT_BIN (4L, >>, 2L, >>, 3L, 0L, 0L, 4L);
kono
parents:
diff changeset
82 ASSERT_BIN (2, <<, 5, <, 4, 0, 0, 2);
kono
parents:
diff changeset
83 ASSERT_BIN (2, <<, 5, >, 4, 1, 1, 4);
kono
parents:
diff changeset
84 ASSERT_BIN (2, <<, 5, <=, 4, 0, 0, 2);
kono
parents:
diff changeset
85 ASSERT_BIN (2, <<, 5, >=, 4, 1, 1, 4);
kono
parents:
diff changeset
86 ASSERT_BIN (2, >>, 5, <, 4, 1, 1, 2);
kono
parents:
diff changeset
87 ASSERT_BIN (2, >>, 5, >, 4, 0, 0, 1);
kono
parents:
diff changeset
88 ASSERT_BIN (2, >>, 5, <=, 4, 1, 1, 2);
kono
parents:
diff changeset
89 ASSERT_BIN (2, >>, 5, >=, 4, 0, 0, 1);
kono
parents:
diff changeset
90 ASSERT_BIN (4, <, 3, <<, 2, 1, 0, 1);
kono
parents:
diff changeset
91 ASSERT_BIN (4, <, 20, >>, 2, 1, 0, 1);
kono
parents:
diff changeset
92 ASSERT_BIN (4, >, 3, <<, 2, 0, 4, 0);
kono
parents:
diff changeset
93 ASSERT_BIN (4, >, 3, >>, 2, 1, 0, 1);
kono
parents:
diff changeset
94 ASSERT_BIN (4, <=, 3, <<, 2, 1, 0, 1);
kono
parents:
diff changeset
95 ASSERT_BIN (4, <=, 20, >>, 2, 1, 0, 1);
kono
parents:
diff changeset
96 ASSERT_BIN (4, >=, 3, <<, 2, 0, 4, 0);
kono
parents:
diff changeset
97 ASSERT_BIN (4, >=, 3, >>, 2, 1, 0, 1);
kono
parents:
diff changeset
98 ASSERT_BIN (1, <, 2, <, 3, 1, 1, 0);
kono
parents:
diff changeset
99 ASSERT_BIN (1, <, 2, >, 0, 1, 1, 0);
kono
parents:
diff changeset
100 ASSERT_BIN (1, <, 2, <=, 3, 1, 1, 0);
kono
parents:
diff changeset
101 ASSERT_BIN (0, <, 4, >=, 3, 0, 0, 1);
kono
parents:
diff changeset
102 ASSERT_BIN (1, >, 2, <, 3, 1, 1, 0);
kono
parents:
diff changeset
103 ASSERT_BIN (1, >, 2, >, 3, 0, 0, 1);
kono
parents:
diff changeset
104 ASSERT_BIN (1, >, 2, <=, 3, 1, 1, 0);
kono
parents:
diff changeset
105 ASSERT_BIN (1, >, 2, >=, 3, 0, 0, 1);
kono
parents:
diff changeset
106 ASSERT_BIN (3, <=, 2, <, 3, 1, 1, 0);
kono
parents:
diff changeset
107 ASSERT_BIN (2, <=, 3, >, 0, 1, 1, 0);
kono
parents:
diff changeset
108 ASSERT_BIN (2, <=, 3, <=, 4, 1, 1, 0);
kono
parents:
diff changeset
109 ASSERT_BIN (2, <=, 3, >=, 1, 1, 1, 0);
kono
parents:
diff changeset
110 ASSERT_BIN (0, >=, 2, <, 3, 1, 1, 0);
kono
parents:
diff changeset
111 ASSERT_BIN (1, >=, 2, >, 3, 0, 0, 1);
kono
parents:
diff changeset
112 ASSERT_BIN (0, >=, 2, <=, 3, 1, 1, 0);
kono
parents:
diff changeset
113 ASSERT_BIN (1, >=, 2, >=, 3, 0, 0, 1);
kono
parents:
diff changeset
114 ASSERT_BIN (-1, <, 2, ==, 3, 0, 0, 1);
kono
parents:
diff changeset
115 ASSERT_BIN (1, <, 2, !=, 3, 1, 1, 0);
kono
parents:
diff changeset
116 ASSERT_BIN (1, >, 2, ==, 3, 0, 0, 1);
kono
parents:
diff changeset
117 ASSERT_BIN (1, >, 2, !=, 3, 1, 1, 0);
kono
parents:
diff changeset
118 ASSERT_BIN (0, <=, 2, ==, 3, 0, 0, 1);
kono
parents:
diff changeset
119 ASSERT_BIN (2, <=, 2, !=, 3, 1, 1, 0);
kono
parents:
diff changeset
120 ASSERT_BIN (1, >=, 2, ==, 3, 0, 0, 1);
kono
parents:
diff changeset
121 ASSERT_BIN (0, >=, 2, !=, 3, 1, 1, 0);
kono
parents:
diff changeset
122 ASSERT_BIN (1, ==, 3, <, 2, 0, 1, 0);
kono
parents:
diff changeset
123 ASSERT_BIN (1, ==, 3, >, 2, 1, 0, 1);
kono
parents:
diff changeset
124 ASSERT_BIN (1, ==, 3, <=, 2, 0, 1, 0);
kono
parents:
diff changeset
125 ASSERT_BIN (1, ==, 3, >=, 2, 1, 0, 1);
kono
parents:
diff changeset
126 ASSERT_BIN (1, !=, 2, <, 3, 0, 1, 0);
kono
parents:
diff changeset
127 ASSERT_BIN (1, !=, 2, >, 3, 1, 0, 1);
kono
parents:
diff changeset
128 ASSERT_BIN (1, !=, 2, <=, 3, 0, 1, 0);
kono
parents:
diff changeset
129 ASSERT_BIN (1, !=, 2, >=, 3, 1, 0, 1);
kono
parents:
diff changeset
130 ASSERT_BIN (1, ==, 2, ==, 0, 1, 1, 0);
kono
parents:
diff changeset
131 ASSERT_BIN (1, ==, 2, !=, 0, 0, 0, 1);
kono
parents:
diff changeset
132 ASSERT_BIN (1, !=, 2, ==, 3, 0, 0, 1);
kono
parents:
diff changeset
133 ASSERT_BIN (1, !=, 2, !=, 3, 1, 1, 0);
kono
parents:
diff changeset
134 ASSERT_BIN (0, ==, 2, &, 1, 0, 0, 1);
kono
parents:
diff changeset
135 ASSERT_BIN (0, !=, 2, &, 1, 1, 1, 0);
kono
parents:
diff changeset
136 ASSERT_BIN (1, &, 2, ==, 0, 0, 1, 0);
kono
parents:
diff changeset
137 ASSERT_BIN (1, &, 2, !=, 0, 1, 0, 1);
kono
parents:
diff changeset
138 ASSERT_BIN (1, &, 2, ^, 3, 3, 3, 1);
kono
parents:
diff changeset
139 ASSERT_BIN (3, ^, 2, &, 1, 3, 1, 3);
kono
parents:
diff changeset
140 ASSERT_BIN (3, ^, 2, |, 1, 1, 1, 0);
kono
parents:
diff changeset
141 ASSERT_BIN (3, |, 2, ^, 1, 3, 2, 3);
kono
parents:
diff changeset
142 ASSERT_BIN (2, |, 0, &&, 2, 1, 1, 2);
kono
parents:
diff changeset
143 ASSERT_BIN (2, &&, 0, |, 2, 1, 2, 1);
kono
parents:
diff changeset
144 ASSERT_BIN (0, &&, 0, ||, 1, 1, 1, 0);
kono
parents:
diff changeset
145 ASSERT_BIN (1, ||, 0, &&, 0, 1, 0, 1);
kono
parents:
diff changeset
146 /* Conditional expressions. */
kono
parents:
diff changeset
147 ASSERT ((1 || 2 ? 3 : 4) == 3);
kono
parents:
diff changeset
148 ASSERT ((1 || (2 ? 3 : 4)) == 1);
kono
parents:
diff changeset
149 /* Assignment expressions. */
kono
parents:
diff changeset
150 p = p = p;
kono
parents:
diff changeset
151 /* Expressions. */
kono
parents:
diff changeset
152 p, p = p;
kono
parents:
diff changeset
153 }