annotate gcc/testsuite/gcc.dg/tree-ssa/20040209-1.c @ 158:494b0b89df80 default tip

...
author Shinji KONO <kono@ie.u-ryukyu.ac.jp>
date Mon, 25 May 2020 18:13:55 +0900
parents 04ced10e8804
children
Ignore whitespace changes - Everywhere: Within whitespace: At end of lines:
rev   line source
111
kono
parents:
diff changeset
1 /* { dg-do compile } */
kono
parents:
diff changeset
2 /* { dg-options "-O2 -Wuninitialized" } */
kono
parents:
diff changeset
3
kono
parents:
diff changeset
4 typedef union tree_node *tree;
kono
parents:
diff changeset
5
kono
parents:
diff changeset
6 struct tree_common
kono
parents:
diff changeset
7 {
kono
parents:
diff changeset
8 tree chain;
kono
parents:
diff changeset
9 };
kono
parents:
diff changeset
10
kono
parents:
diff changeset
11 struct tree_decl
kono
parents:
diff changeset
12 {
kono
parents:
diff changeset
13 struct tree_common common;
kono
parents:
diff changeset
14 tree name;
kono
parents:
diff changeset
15 };
kono
parents:
diff changeset
16
kono
parents:
diff changeset
17
kono
parents:
diff changeset
18 union tree_node
kono
parents:
diff changeset
19 {
kono
parents:
diff changeset
20 struct tree_common common;
kono
parents:
diff changeset
21 struct tree_decl decl;
kono
parents:
diff changeset
22 };
kono
parents:
diff changeset
23
kono
parents:
diff changeset
24 int pedantic;
kono
parents:
diff changeset
25 void foo (tree);
kono
parents:
diff changeset
26 void bar1 (tree *);
kono
parents:
diff changeset
27
kono
parents:
diff changeset
28 void
kono
parents:
diff changeset
29 finish_struct (tree t, tree fieldlist, tree attributes)
kono
parents:
diff changeset
30 {
kono
parents:
diff changeset
31 union tree_node * x;
kono
parents:
diff changeset
32
kono
parents:
diff changeset
33 if (pedantic)
kono
parents:
diff changeset
34 {
kono
parents:
diff changeset
35 x = fieldlist;
kono
parents:
diff changeset
36 if (x->decl.name == 0)
kono
parents:
diff changeset
37 {
kono
parents:
diff changeset
38 while (x)
kono
parents:
diff changeset
39 x = x->common.chain;
kono
parents:
diff changeset
40 foo (fieldlist);
kono
parents:
diff changeset
41 }
kono
parents:
diff changeset
42 }
kono
parents:
diff changeset
43
kono
parents:
diff changeset
44 x = fieldlist;
kono
parents:
diff changeset
45 if (x)
kono
parents:
diff changeset
46 {
kono
parents:
diff changeset
47 do
kono
parents:
diff changeset
48 {
kono
parents:
diff changeset
49 x = x->common.chain;
kono
parents:
diff changeset
50 } while (x != 0);
kono
parents:
diff changeset
51 }
kono
parents:
diff changeset
52
kono
parents:
diff changeset
53 bar1 (&fieldlist);
kono
parents:
diff changeset
54 }