annotate gcc/testsuite/c-c++-common/Wimplicit-fallthrough-6.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/7652 */
kono
parents:
diff changeset
2 /* { dg-do compile } */
kono
parents:
diff changeset
3 /* { dg-options "-Wimplicit-fallthrough" } */
kono
parents:
diff changeset
4
kono
parents:
diff changeset
5 extern void bar (int);
kono
parents:
diff changeset
6
kono
parents:
diff changeset
7 /* Test nested scopes. */
kono
parents:
diff changeset
8
kono
parents:
diff changeset
9 void
kono
parents:
diff changeset
10 f (int i)
kono
parents:
diff changeset
11 {
kono
parents:
diff changeset
12 switch (i)
kono
parents:
diff changeset
13 {
kono
parents:
diff changeset
14 case 1:
kono
parents:
diff changeset
15 {
kono
parents:
diff changeset
16 int j;
kono
parents:
diff changeset
17 }
kono
parents:
diff changeset
18 case 2:
kono
parents:
diff changeset
19 bar (99);
kono
parents:
diff changeset
20 }
kono
parents:
diff changeset
21
kono
parents:
diff changeset
22 switch (i)
kono
parents:
diff changeset
23 {
kono
parents:
diff changeset
24 case 1:
kono
parents:
diff changeset
25 {
kono
parents:
diff changeset
26 int j = 10; /* { dg-warning "statement may fall through" } */
kono
parents:
diff changeset
27 }
kono
parents:
diff changeset
28 case 2:
kono
parents:
diff changeset
29 bar (99);
kono
parents:
diff changeset
30 }
kono
parents:
diff changeset
31
kono
parents:
diff changeset
32 switch (i)
kono
parents:
diff changeset
33 {
kono
parents:
diff changeset
34 case 1:
kono
parents:
diff changeset
35 {
kono
parents:
diff changeset
36 int k = 9;
kono
parents:
diff changeset
37 k++;
kono
parents:
diff changeset
38 {
kono
parents:
diff changeset
39 int j = 10;
kono
parents:
diff changeset
40 j++; /* { dg-warning "statement may fall through" } */
kono
parents:
diff changeset
41 }
kono
parents:
diff changeset
42 }
kono
parents:
diff changeset
43 case 2:
kono
parents:
diff changeset
44 bar (99);
kono
parents:
diff changeset
45 }
kono
parents:
diff changeset
46
kono
parents:
diff changeset
47 switch (i)
kono
parents:
diff changeset
48 {
kono
parents:
diff changeset
49 case 1:
kono
parents:
diff changeset
50 {
kono
parents:
diff changeset
51 int k = 9;
kono
parents:
diff changeset
52 k++;
kono
parents:
diff changeset
53 {
kono
parents:
diff changeset
54 int j = 10;
kono
parents:
diff changeset
55 j++;
kono
parents:
diff changeset
56 {
kono
parents:
diff changeset
57 bar (1); /* { dg-warning "statement may fall through" } */
kono
parents:
diff changeset
58 }
kono
parents:
diff changeset
59 }
kono
parents:
diff changeset
60 }
kono
parents:
diff changeset
61 case 2:
kono
parents:
diff changeset
62 bar (99);
kono
parents:
diff changeset
63 }
kono
parents:
diff changeset
64
kono
parents:
diff changeset
65 switch (i)
kono
parents:
diff changeset
66 {
kono
parents:
diff changeset
67 case 1:
kono
parents:
diff changeset
68 {
kono
parents:
diff changeset
69 int j = 0;
kono
parents:
diff changeset
70 bar (j);
kono
parents:
diff changeset
71 __attribute__((fallthrough));
kono
parents:
diff changeset
72 }
kono
parents:
diff changeset
73 case 2:
kono
parents:
diff changeset
74 bar (99);
kono
parents:
diff changeset
75 }
kono
parents:
diff changeset
76
kono
parents:
diff changeset
77 switch (i)
kono
parents:
diff changeset
78 {
kono
parents:
diff changeset
79 case 1:
kono
parents:
diff changeset
80 {
kono
parents:
diff changeset
81 int j = 0;
kono
parents:
diff changeset
82 {
kono
parents:
diff changeset
83 int k = j + 5;
kono
parents:
diff changeset
84 bar (k);
kono
parents:
diff changeset
85 __attribute__((fallthrough));
kono
parents:
diff changeset
86 }
kono
parents:
diff changeset
87 }
kono
parents:
diff changeset
88 case 2:
kono
parents:
diff changeset
89 bar (99);
kono
parents:
diff changeset
90 }
kono
parents:
diff changeset
91
kono
parents:
diff changeset
92 switch (i)
kono
parents:
diff changeset
93 {
kono
parents:
diff changeset
94 case 1:
kono
parents:
diff changeset
95 {
kono
parents:
diff changeset
96 int j = 0;
kono
parents:
diff changeset
97 bar (j);
kono
parents:
diff changeset
98 return;
kono
parents:
diff changeset
99 }
kono
parents:
diff changeset
100 case 2:
kono
parents:
diff changeset
101 bar (99);
kono
parents:
diff changeset
102 }
kono
parents:
diff changeset
103
kono
parents:
diff changeset
104 switch (i)
kono
parents:
diff changeset
105 {
kono
parents:
diff changeset
106 case 1:
kono
parents:
diff changeset
107 {
kono
parents:
diff changeset
108 int j = 0;
kono
parents:
diff changeset
109 bar (j);
kono
parents:
diff changeset
110 goto L1;
kono
parents:
diff changeset
111 }
kono
parents:
diff changeset
112 L1:
kono
parents:
diff changeset
113 case 2:
kono
parents:
diff changeset
114 bar (99);
kono
parents:
diff changeset
115 }
kono
parents:
diff changeset
116
kono
parents:
diff changeset
117 switch (i)
kono
parents:
diff changeset
118 {
kono
parents:
diff changeset
119 case 1:
kono
parents:
diff changeset
120 { /* { dg-warning "statement may fall through" "" { target c } } */
kono
parents:
diff changeset
121 int j = 0;
kono
parents:
diff changeset
122 bar (j);
kono
parents:
diff changeset
123 if (j == 8)
kono
parents:
diff changeset
124 return; /* { dg-warning "statement may fall through" "" { target c++ } } */
kono
parents:
diff changeset
125 }
kono
parents:
diff changeset
126 case 2:
kono
parents:
diff changeset
127 bar (99);
kono
parents:
diff changeset
128 }
kono
parents:
diff changeset
129
kono
parents:
diff changeset
130 switch (i)
kono
parents:
diff changeset
131 {
kono
parents:
diff changeset
132 case 1:
kono
parents:
diff changeset
133 {
kono
parents:
diff changeset
134 int j = 0;
kono
parents:
diff changeset
135 bar (j);
kono
parents:
diff changeset
136 if (j == 8)
kono
parents:
diff changeset
137 return;
kono
parents:
diff changeset
138 else
kono
parents:
diff changeset
139 return;
kono
parents:
diff changeset
140 }
kono
parents:
diff changeset
141 case 2:
kono
parents:
diff changeset
142 bar (99);
kono
parents:
diff changeset
143 }
kono
parents:
diff changeset
144
kono
parents:
diff changeset
145 switch (i)
kono
parents:
diff changeset
146 {
kono
parents:
diff changeset
147 case 1:
kono
parents:
diff changeset
148 { /* { dg-warning "statement may fall through" "" { target c } } */
kono
parents:
diff changeset
149 int j = 0;
kono
parents:
diff changeset
150 bar (j);
kono
parents:
diff changeset
151 if (j == 8)
kono
parents:
diff changeset
152 bar (1);
kono
parents:
diff changeset
153 else
kono
parents:
diff changeset
154 return; /* { dg-warning "statement may fall through" "" { target c++ } } */
kono
parents:
diff changeset
155 }
kono
parents:
diff changeset
156 case 2:
kono
parents:
diff changeset
157 bar (99);
kono
parents:
diff changeset
158 }
kono
parents:
diff changeset
159
kono
parents:
diff changeset
160 switch (i)
kono
parents:
diff changeset
161 {
kono
parents:
diff changeset
162 case 1:
kono
parents:
diff changeset
163 {
kono
parents:
diff changeset
164 int j = 0;
kono
parents:
diff changeset
165 bar (j);
kono
parents:
diff changeset
166 if (j == 8)
kono
parents:
diff changeset
167 return;
kono
parents:
diff changeset
168 else
kono
parents:
diff changeset
169 bar (2); /* { dg-warning "statement may fall through" } */
kono
parents:
diff changeset
170 }
kono
parents:
diff changeset
171 case 2:
kono
parents:
diff changeset
172 bar (99);
kono
parents:
diff changeset
173 }
kono
parents:
diff changeset
174
kono
parents:
diff changeset
175 switch (i)
kono
parents:
diff changeset
176 {
kono
parents:
diff changeset
177 case 1:
kono
parents:
diff changeset
178 { /* { dg-warning "statement may fall through" "" { target c } } */
kono
parents:
diff changeset
179 int j = 0;
kono
parents:
diff changeset
180 bar (j);
kono
parents:
diff changeset
181 if (j == 8)
kono
parents:
diff changeset
182 bar (1);
kono
parents:
diff changeset
183 else
kono
parents:
diff changeset
184 bar (2); /* { dg-warning "statement may fall through" "" { target c++ } } */
kono
parents:
diff changeset
185 }
kono
parents:
diff changeset
186 case 2:
kono
parents:
diff changeset
187 bar (99);
kono
parents:
diff changeset
188 }
kono
parents:
diff changeset
189
kono
parents:
diff changeset
190 switch (i)
kono
parents:
diff changeset
191 {
kono
parents:
diff changeset
192 case 1:
kono
parents:
diff changeset
193 {
kono
parents:
diff changeset
194 int j = 0;
kono
parents:
diff changeset
195 bar (j);
kono
parents:
diff changeset
196 if (j == 8)
kono
parents:
diff changeset
197 return;
kono
parents:
diff changeset
198 }
kono
parents:
diff changeset
199 break;
kono
parents:
diff changeset
200 case 2:
kono
parents:
diff changeset
201 bar (99);
kono
parents:
diff changeset
202 }
kono
parents:
diff changeset
203
kono
parents:
diff changeset
204 switch (i)
kono
parents:
diff changeset
205 {
kono
parents:
diff changeset
206 case 1:
kono
parents:
diff changeset
207 {
kono
parents:
diff changeset
208 int j = 0;
kono
parents:
diff changeset
209 bar (j);
kono
parents:
diff changeset
210 if (j == 8)
kono
parents:
diff changeset
211 return;
kono
parents:
diff changeset
212 else
kono
parents:
diff changeset
213 return;
kono
parents:
diff changeset
214 }
kono
parents:
diff changeset
215 break;
kono
parents:
diff changeset
216 case 2:
kono
parents:
diff changeset
217 bar (99);
kono
parents:
diff changeset
218 }
kono
parents:
diff changeset
219
kono
parents:
diff changeset
220 switch (i)
kono
parents:
diff changeset
221 {
kono
parents:
diff changeset
222 case 1:
kono
parents:
diff changeset
223 {
kono
parents:
diff changeset
224 int j = 0;
kono
parents:
diff changeset
225 bar (j);
kono
parents:
diff changeset
226 if (j == 8)
kono
parents:
diff changeset
227 bar (1);
kono
parents:
diff changeset
228 else
kono
parents:
diff changeset
229 return;
kono
parents:
diff changeset
230 }
kono
parents:
diff changeset
231 break;
kono
parents:
diff changeset
232 case 2:
kono
parents:
diff changeset
233 bar (99);
kono
parents:
diff changeset
234 }
kono
parents:
diff changeset
235
kono
parents:
diff changeset
236 switch (i)
kono
parents:
diff changeset
237 {
kono
parents:
diff changeset
238 case 1:
kono
parents:
diff changeset
239 {
kono
parents:
diff changeset
240 int j = 0;
kono
parents:
diff changeset
241 bar (j);
kono
parents:
diff changeset
242 if (j == 8)
kono
parents:
diff changeset
243 return;
kono
parents:
diff changeset
244 else
kono
parents:
diff changeset
245 bar (2);
kono
parents:
diff changeset
246 }
kono
parents:
diff changeset
247 break;
kono
parents:
diff changeset
248 case 2:
kono
parents:
diff changeset
249 bar (99);
kono
parents:
diff changeset
250 }
kono
parents:
diff changeset
251
kono
parents:
diff changeset
252 switch (i)
kono
parents:
diff changeset
253 {
kono
parents:
diff changeset
254 case 1:
kono
parents:
diff changeset
255 {
kono
parents:
diff changeset
256 int j = 0;
kono
parents:
diff changeset
257 bar (j);
kono
parents:
diff changeset
258 if (j == 8)
kono
parents:
diff changeset
259 bar (1);
kono
parents:
diff changeset
260 else
kono
parents:
diff changeset
261 bar (2);
kono
parents:
diff changeset
262 }
kono
parents:
diff changeset
263 break;
kono
parents:
diff changeset
264 case 2:
kono
parents:
diff changeset
265 bar (99);
kono
parents:
diff changeset
266 }
kono
parents:
diff changeset
267
kono
parents:
diff changeset
268 switch (i)
kono
parents:
diff changeset
269 {
kono
parents:
diff changeset
270 case 1:
kono
parents:
diff changeset
271 {
kono
parents:
diff changeset
272 int j = 9;
kono
parents:
diff changeset
273 while (1);
kono
parents:
diff changeset
274 }
kono
parents:
diff changeset
275 case 2:
kono
parents:
diff changeset
276 bar (99);
kono
parents:
diff changeset
277 }
kono
parents:
diff changeset
278
kono
parents:
diff changeset
279 switch (i)
kono
parents:
diff changeset
280 {
kono
parents:
diff changeset
281 case 1:
kono
parents:
diff changeset
282 { /* { dg-warning "statement may fall through" "" { target c } } */
kono
parents:
diff changeset
283 int j = 9;
kono
parents:
diff changeset
284 switch (j); /* { dg-warning "statement may fall through" "" { target c++ } } */
kono
parents:
diff changeset
285 }
kono
parents:
diff changeset
286 case 2:
kono
parents:
diff changeset
287 bar (99);
kono
parents:
diff changeset
288 }
kono
parents:
diff changeset
289
kono
parents:
diff changeset
290 switch (i)
kono
parents:
diff changeset
291 {
kono
parents:
diff changeset
292 case 1:
kono
parents:
diff changeset
293 {
kono
parents:
diff changeset
294 int j = 0;
kono
parents:
diff changeset
295 bar (j);
kono
parents:
diff changeset
296 if (j == 8)
kono
parents:
diff changeset
297 bar (1);
kono
parents:
diff changeset
298 else
kono
parents:
diff changeset
299 bar (2);
kono
parents:
diff changeset
300 __attribute__((fallthrough));
kono
parents:
diff changeset
301 }
kono
parents:
diff changeset
302 case 2:
kono
parents:
diff changeset
303 bar (99);
kono
parents:
diff changeset
304 }
kono
parents:
diff changeset
305 }