annotate gcc/testsuite/c-c++-common/Wmultistatement-macros-10.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 /* PR c/80116 */
kono
parents:
diff changeset
2 /* { dg-options "-Wmultistatement-macros" } */
kono
parents:
diff changeset
3 /* { dg-do compile } */
kono
parents:
diff changeset
4
kono
parents:
diff changeset
5 #define SWAP(x, y) \
kono
parents:
diff changeset
6 tmp = x; /* { dg-warning "macro expands to multiple statements" } */ \
kono
parents:
diff changeset
7 x = y; \
kono
parents:
diff changeset
8 y = tmp
kono
parents:
diff changeset
9
kono
parents:
diff changeset
10 #define M1 \
kono
parents:
diff changeset
11 switch (x) /* { dg-message "not guarded by this 'switch' clause" } */ \
kono
parents:
diff changeset
12 case 1: \
kono
parents:
diff changeset
13 SWAP (x, y) /* { dg-message "in expansion of macro .SWAP." } */
kono
parents:
diff changeset
14
kono
parents:
diff changeset
15 #define M2 \
kono
parents:
diff changeset
16 switch (x) \
kono
parents:
diff changeset
17 case 1: \
kono
parents:
diff changeset
18 x++
kono
parents:
diff changeset
19
kono
parents:
diff changeset
20 #define M3 \
kono
parents:
diff changeset
21 switch (x) \
kono
parents:
diff changeset
22 case 1: \
kono
parents:
diff changeset
23 x++;;
kono
parents:
diff changeset
24
kono
parents:
diff changeset
25 #define M4 \
kono
parents:
diff changeset
26 switch (x) /* { dg-message "not guarded by this 'switch' clause" } */ \
kono
parents:
diff changeset
27 L1: \
kono
parents:
diff changeset
28 case 1: \
kono
parents:
diff changeset
29 SWAP (x, y) /* { dg-message "in expansion of macro .SWAP." } */
kono
parents:
diff changeset
30
kono
parents:
diff changeset
31 #define INC \
kono
parents:
diff changeset
32 x++;;
kono
parents:
diff changeset
33
kono
parents:
diff changeset
34 int x, y, tmp;
kono
parents:
diff changeset
35
kono
parents:
diff changeset
36 void
kono
parents:
diff changeset
37 fn0 (void)
kono
parents:
diff changeset
38 {
kono
parents:
diff changeset
39 switch (x) /* { dg-message "not guarded by this 'switch' clause" } */
kono
parents:
diff changeset
40 case 1:
kono
parents:
diff changeset
41 SWAP (x, y); /* { dg-message "in expansion of macro .SWAP." } */
kono
parents:
diff changeset
42
kono
parents:
diff changeset
43 switch (x) /* { dg-message "not guarded by this 'switch' clause" } */
kono
parents:
diff changeset
44 case 1:
kono
parents:
diff changeset
45 case 2:
kono
parents:
diff changeset
46 case 3:
kono
parents:
diff changeset
47 case 4:
kono
parents:
diff changeset
48 case 5:
kono
parents:
diff changeset
49 SWAP (x, y); /* { dg-message "in expansion of macro .SWAP." } */
kono
parents:
diff changeset
50 }
kono
parents:
diff changeset
51
kono
parents:
diff changeset
52 void
kono
parents:
diff changeset
53 fn1 (void)
kono
parents:
diff changeset
54 {
kono
parents:
diff changeset
55 M1; /* { dg-message "in expansion of macro .M1." } */
kono
parents:
diff changeset
56 M2;
kono
parents:
diff changeset
57 M3;
kono
parents:
diff changeset
58 M4; /* { dg-message "in expansion of macro .M4." } */
kono
parents:
diff changeset
59 goto L1;
kono
parents:
diff changeset
60 }
kono
parents:
diff changeset
61
kono
parents:
diff changeset
62 void
kono
parents:
diff changeset
63 fn2 (void)
kono
parents:
diff changeset
64 {
kono
parents:
diff changeset
65 switch (x)
kono
parents:
diff changeset
66 case 1:
kono
parents:
diff changeset
67 INC
kono
parents:
diff changeset
68
kono
parents:
diff changeset
69 switch (x)
kono
parents:
diff changeset
70 case 1:
kono
parents:
diff changeset
71 ({ x = 10; x++; });
kono
parents:
diff changeset
72 }
kono
parents:
diff changeset
73
kono
parents:
diff changeset
74 void
kono
parents:
diff changeset
75 fn3 (void)
kono
parents:
diff changeset
76 {
kono
parents:
diff changeset
77 switch (x)
kono
parents:
diff changeset
78 {
kono
parents:
diff changeset
79 case 1:
kono
parents:
diff changeset
80 SWAP (x, y);
kono
parents:
diff changeset
81 }
kono
parents:
diff changeset
82 }