annotate gcc/print-tree.c @ 158:494b0b89df80 default tip

...
author Shinji KONO <kono@ie.u-ryukyu.ac.jp>
date Mon, 25 May 2020 18:13:55 +0900
parents 1830386684a0
children
Ignore whitespace changes - Everywhere: Within whitespace: At end of lines:
rev   line source
0
a06113de4d67 first commit
kent <kent@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
1 /* Prints out tree in human readable form - GCC
145
1830386684a0 gcc-9.2.0
anatofuz
parents: 131
diff changeset
2 Copyright (C) 1990-2020 Free Software Foundation, Inc.
0
a06113de4d67 first commit
kent <kent@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
3
a06113de4d67 first commit
kent <kent@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
4 This file is part of GCC.
a06113de4d67 first commit
kent <kent@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
5
a06113de4d67 first commit
kent <kent@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
6 GCC is free software; you can redistribute it and/or modify it under
a06113de4d67 first commit
kent <kent@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
7 the terms of the GNU General Public License as published by the Free
a06113de4d67 first commit
kent <kent@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
8 Software Foundation; either version 3, or (at your option) any later
a06113de4d67 first commit
kent <kent@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
9 version.
a06113de4d67 first commit
kent <kent@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
10
a06113de4d67 first commit
kent <kent@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
11 GCC is distributed in the hope that it will be useful, but WITHOUT ANY
a06113de4d67 first commit
kent <kent@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
12 WARRANTY; without even the implied warranty of MERCHANTABILITY or
a06113de4d67 first commit
kent <kent@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
13 FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License
a06113de4d67 first commit
kent <kent@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
14 for more details.
a06113de4d67 first commit
kent <kent@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
15
a06113de4d67 first commit
kent <kent@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
16 You should have received a copy of the GNU General Public License
a06113de4d67 first commit
kent <kent@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
17 along with GCC; see the file COPYING3. If not see
a06113de4d67 first commit
kent <kent@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
18 <http://www.gnu.org/licenses/>. */
a06113de4d67 first commit
kent <kent@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
19
a06113de4d67 first commit
kent <kent@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
20
a06113de4d67 first commit
kent <kent@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
21 #include "config.h"
a06113de4d67 first commit
kent <kent@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
22 #include "system.h"
a06113de4d67 first commit
kent <kent@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
23 #include "coretypes.h"
a06113de4d67 first commit
kent <kent@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
24 #include "tm.h"
a06113de4d67 first commit
kent <kent@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
25 #include "tree.h"
111
kono
parents: 67
diff changeset
26 #include "cgraph.h"
kono
parents: 67
diff changeset
27 #include "diagnostic.h"
kono
parents: 67
diff changeset
28 #include "varasm.h"
kono
parents: 67
diff changeset
29 #include "print-rtl.h"
kono
parents: 67
diff changeset
30 #include "stor-layout.h"
0
a06113de4d67 first commit
kent <kent@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
31 #include "langhooks.h"
a06113de4d67 first commit
kent <kent@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
32 #include "tree-iterator.h"
111
kono
parents: 67
diff changeset
33 #include "gimple-pretty-print.h" /* FIXME */
kono
parents: 67
diff changeset
34 #include "tree-cfg.h"
kono
parents: 67
diff changeset
35 #include "dumpfile.h"
kono
parents: 67
diff changeset
36 #include "print-tree.h"
0
a06113de4d67 first commit
kent <kent@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
37
a06113de4d67 first commit
kent <kent@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
38 /* Define the hash table of nodes already seen.
a06113de4d67 first commit
kent <kent@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
39 Such nodes are not repeated; brief cross-references are used. */
a06113de4d67 first commit
kent <kent@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
40
a06113de4d67 first commit
kent <kent@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
41 #define HASH_SIZE 37
a06113de4d67 first commit
kent <kent@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
42
111
kono
parents: 67
diff changeset
43 static hash_set<tree> *table = NULL;
67
f6334be47118 update gcc from gcc-4.6-20100522 to gcc-4.6-20110318
nobuyasu <dimolto@cr.ie.u-ryukyu.ac.jp>
parents: 63
diff changeset
44
0
a06113de4d67 first commit
kent <kent@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
45 /* Print PREFIX and ADDR to FILE. */
a06113de4d67 first commit
kent <kent@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
46 void
a06113de4d67 first commit
kent <kent@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
47 dump_addr (FILE *file, const char *prefix, const void *addr)
a06113de4d67 first commit
kent <kent@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
48 {
a06113de4d67 first commit
kent <kent@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
49 if (flag_dump_noaddr || flag_dump_unnumbered)
a06113de4d67 first commit
kent <kent@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
50 fprintf (file, "%s#", prefix);
a06113de4d67 first commit
kent <kent@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
51 else
55
77e2b8dfacca update it from 4.4.3 to 4.5.0
ryoma <e075725@ie.u-ryukyu.ac.jp>
parents: 0
diff changeset
52 fprintf (file, "%s" HOST_PTR_PRINTF, prefix, addr);
0
a06113de4d67 first commit
kent <kent@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
53 }
a06113de4d67 first commit
kent <kent@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
54
131
84e7813d76e9 gcc-8.2
mir3636
parents: 111
diff changeset
55 /* Print to FILE a NODE representing a REAL_CST constant, including
84e7813d76e9 gcc-8.2
mir3636
parents: 111
diff changeset
56 Infinity and NaN. Be verbose when BFRIEF is false. */
84e7813d76e9 gcc-8.2
mir3636
parents: 111
diff changeset
57
84e7813d76e9 gcc-8.2
mir3636
parents: 111
diff changeset
58 static void
84e7813d76e9 gcc-8.2
mir3636
parents: 111
diff changeset
59 print_real_cst (FILE *file, const_tree node, bool brief)
84e7813d76e9 gcc-8.2
mir3636
parents: 111
diff changeset
60 {
84e7813d76e9 gcc-8.2
mir3636
parents: 111
diff changeset
61 if (TREE_OVERFLOW (node))
84e7813d76e9 gcc-8.2
mir3636
parents: 111
diff changeset
62 fprintf (file, " overflow");
84e7813d76e9 gcc-8.2
mir3636
parents: 111
diff changeset
63
84e7813d76e9 gcc-8.2
mir3636
parents: 111
diff changeset
64 REAL_VALUE_TYPE d = TREE_REAL_CST (node);
84e7813d76e9 gcc-8.2
mir3636
parents: 111
diff changeset
65 if (REAL_VALUE_ISINF (d))
84e7813d76e9 gcc-8.2
mir3636
parents: 111
diff changeset
66 fprintf (file, REAL_VALUE_NEGATIVE (d) ? " -Inf" : " Inf");
84e7813d76e9 gcc-8.2
mir3636
parents: 111
diff changeset
67 else if (REAL_VALUE_ISNAN (d))
84e7813d76e9 gcc-8.2
mir3636
parents: 111
diff changeset
68 {
84e7813d76e9 gcc-8.2
mir3636
parents: 111
diff changeset
69 /* Print a NaN in the format [-][Q]NaN[(significand[exponent])]
84e7813d76e9 gcc-8.2
mir3636
parents: 111
diff changeset
70 where significand is a hexadecimal string that starts with
84e7813d76e9 gcc-8.2
mir3636
parents: 111
diff changeset
71 the 0x prefix followed by 0 if the number is not canonical
84e7813d76e9 gcc-8.2
mir3636
parents: 111
diff changeset
72 and a non-zero digit if it is, and exponent is decimal. */
84e7813d76e9 gcc-8.2
mir3636
parents: 111
diff changeset
73 unsigned start = 0;
84e7813d76e9 gcc-8.2
mir3636
parents: 111
diff changeset
74 const char *psig = (const char *) d.sig;
84e7813d76e9 gcc-8.2
mir3636
parents: 111
diff changeset
75 for (unsigned i = 0; i != sizeof d.sig; ++i)
84e7813d76e9 gcc-8.2
mir3636
parents: 111
diff changeset
76 if (psig[i])
84e7813d76e9 gcc-8.2
mir3636
parents: 111
diff changeset
77 {
84e7813d76e9 gcc-8.2
mir3636
parents: 111
diff changeset
78 start = i;
84e7813d76e9 gcc-8.2
mir3636
parents: 111
diff changeset
79 break;
84e7813d76e9 gcc-8.2
mir3636
parents: 111
diff changeset
80 }
84e7813d76e9 gcc-8.2
mir3636
parents: 111
diff changeset
81
84e7813d76e9 gcc-8.2
mir3636
parents: 111
diff changeset
82 fprintf (file, " %s%sNaN", d.sign ? "-" : "",
84e7813d76e9 gcc-8.2
mir3636
parents: 111
diff changeset
83 d.signalling ? "S" : "Q");
84e7813d76e9 gcc-8.2
mir3636
parents: 111
diff changeset
84
84e7813d76e9 gcc-8.2
mir3636
parents: 111
diff changeset
85 if (brief)
84e7813d76e9 gcc-8.2
mir3636
parents: 111
diff changeset
86 return;
84e7813d76e9 gcc-8.2
mir3636
parents: 111
diff changeset
87
84e7813d76e9 gcc-8.2
mir3636
parents: 111
diff changeset
88 if (start)
84e7813d76e9 gcc-8.2
mir3636
parents: 111
diff changeset
89 fprintf (file, "(0x%s", d.canonical ? "" : "0");
84e7813d76e9 gcc-8.2
mir3636
parents: 111
diff changeset
90 else if (d.uexp)
84e7813d76e9 gcc-8.2
mir3636
parents: 111
diff changeset
91 fprintf (file, "(%s", d.canonical ? "" : "0");
84e7813d76e9 gcc-8.2
mir3636
parents: 111
diff changeset
92 else if (!d.canonical)
84e7813d76e9 gcc-8.2
mir3636
parents: 111
diff changeset
93 {
84e7813d76e9 gcc-8.2
mir3636
parents: 111
diff changeset
94 fprintf (file, "(0)");
84e7813d76e9 gcc-8.2
mir3636
parents: 111
diff changeset
95 return;
84e7813d76e9 gcc-8.2
mir3636
parents: 111
diff changeset
96 }
84e7813d76e9 gcc-8.2
mir3636
parents: 111
diff changeset
97
84e7813d76e9 gcc-8.2
mir3636
parents: 111
diff changeset
98 if (psig[start])
84e7813d76e9 gcc-8.2
mir3636
parents: 111
diff changeset
99 {
84e7813d76e9 gcc-8.2
mir3636
parents: 111
diff changeset
100 for (unsigned i = start; i != sizeof d.sig; ++i)
84e7813d76e9 gcc-8.2
mir3636
parents: 111
diff changeset
101 if (i == start)
84e7813d76e9 gcc-8.2
mir3636
parents: 111
diff changeset
102 fprintf (file, "%x", psig[i]);
84e7813d76e9 gcc-8.2
mir3636
parents: 111
diff changeset
103 else
84e7813d76e9 gcc-8.2
mir3636
parents: 111
diff changeset
104 fprintf (file, "%02x", psig[i]);
84e7813d76e9 gcc-8.2
mir3636
parents: 111
diff changeset
105 }
84e7813d76e9 gcc-8.2
mir3636
parents: 111
diff changeset
106
84e7813d76e9 gcc-8.2
mir3636
parents: 111
diff changeset
107 if (d.uexp)
84e7813d76e9 gcc-8.2
mir3636
parents: 111
diff changeset
108 fprintf (file, "%se%u)", psig[start] ? "," : "", d.uexp);
84e7813d76e9 gcc-8.2
mir3636
parents: 111
diff changeset
109 else if (psig[start])
84e7813d76e9 gcc-8.2
mir3636
parents: 111
diff changeset
110 fputc (')', file);
84e7813d76e9 gcc-8.2
mir3636
parents: 111
diff changeset
111 }
84e7813d76e9 gcc-8.2
mir3636
parents: 111
diff changeset
112 else
84e7813d76e9 gcc-8.2
mir3636
parents: 111
diff changeset
113 {
84e7813d76e9 gcc-8.2
mir3636
parents: 111
diff changeset
114 char string[64];
84e7813d76e9 gcc-8.2
mir3636
parents: 111
diff changeset
115 real_to_decimal (string, &d, sizeof (string), 0, 1);
84e7813d76e9 gcc-8.2
mir3636
parents: 111
diff changeset
116 fprintf (file, " %s", string);
84e7813d76e9 gcc-8.2
mir3636
parents: 111
diff changeset
117 }
84e7813d76e9 gcc-8.2
mir3636
parents: 111
diff changeset
118 }
84e7813d76e9 gcc-8.2
mir3636
parents: 111
diff changeset
119
0
a06113de4d67 first commit
kent <kent@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
120 /* Print a node in brief fashion, with just the code, address and name. */
a06113de4d67 first commit
kent <kent@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
121
a06113de4d67 first commit
kent <kent@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
122 void
a06113de4d67 first commit
kent <kent@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
123 print_node_brief (FILE *file, const char *prefix, const_tree node, int indent)
a06113de4d67 first commit
kent <kent@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
124 {
a06113de4d67 first commit
kent <kent@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
125 enum tree_code_class tclass;
a06113de4d67 first commit
kent <kent@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
126
a06113de4d67 first commit
kent <kent@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
127 if (node == 0)
a06113de4d67 first commit
kent <kent@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
128 return;
a06113de4d67 first commit
kent <kent@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
129
a06113de4d67 first commit
kent <kent@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
130 tclass = TREE_CODE_CLASS (TREE_CODE (node));
a06113de4d67 first commit
kent <kent@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
131
a06113de4d67 first commit
kent <kent@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
132 /* Always print the slot this node is in, and its code, address and
a06113de4d67 first commit
kent <kent@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
133 name if any. */
a06113de4d67 first commit
kent <kent@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
134 if (indent > 0)
a06113de4d67 first commit
kent <kent@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
135 fprintf (file, " ");
111
kono
parents: 67
diff changeset
136 fprintf (file, "%s <%s", prefix, get_tree_code_name (TREE_CODE (node)));
0
a06113de4d67 first commit
kent <kent@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
137 dump_addr (file, " ", node);
a06113de4d67 first commit
kent <kent@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
138
a06113de4d67 first commit
kent <kent@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
139 if (tclass == tcc_declaration)
a06113de4d67 first commit
kent <kent@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
140 {
a06113de4d67 first commit
kent <kent@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
141 if (DECL_NAME (node))
a06113de4d67 first commit
kent <kent@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
142 fprintf (file, " %s", IDENTIFIER_POINTER (DECL_NAME (node)));
a06113de4d67 first commit
kent <kent@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
143 else if (TREE_CODE (node) == LABEL_DECL
a06113de4d67 first commit
kent <kent@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
144 && LABEL_DECL_UID (node) != -1)
55
77e2b8dfacca update it from 4.4.3 to 4.5.0
ryoma <e075725@ie.u-ryukyu.ac.jp>
parents: 0
diff changeset
145 {
77e2b8dfacca update it from 4.4.3 to 4.5.0
ryoma <e075725@ie.u-ryukyu.ac.jp>
parents: 0
diff changeset
146 if (dump_flags & TDF_NOUID)
77e2b8dfacca update it from 4.4.3 to 4.5.0
ryoma <e075725@ie.u-ryukyu.ac.jp>
parents: 0
diff changeset
147 fprintf (file, " L.xxxx");
77e2b8dfacca update it from 4.4.3 to 4.5.0
ryoma <e075725@ie.u-ryukyu.ac.jp>
parents: 0
diff changeset
148 else
77e2b8dfacca update it from 4.4.3 to 4.5.0
ryoma <e075725@ie.u-ryukyu.ac.jp>
parents: 0
diff changeset
149 fprintf (file, " L.%d", (int) LABEL_DECL_UID (node));
77e2b8dfacca update it from 4.4.3 to 4.5.0
ryoma <e075725@ie.u-ryukyu.ac.jp>
parents: 0
diff changeset
150 }
0
a06113de4d67 first commit
kent <kent@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
151 else
55
77e2b8dfacca update it from 4.4.3 to 4.5.0
ryoma <e075725@ie.u-ryukyu.ac.jp>
parents: 0
diff changeset
152 {
77e2b8dfacca update it from 4.4.3 to 4.5.0
ryoma <e075725@ie.u-ryukyu.ac.jp>
parents: 0
diff changeset
153 if (dump_flags & TDF_NOUID)
77e2b8dfacca update it from 4.4.3 to 4.5.0
ryoma <e075725@ie.u-ryukyu.ac.jp>
parents: 0
diff changeset
154 fprintf (file, " %c.xxxx",
77e2b8dfacca update it from 4.4.3 to 4.5.0
ryoma <e075725@ie.u-ryukyu.ac.jp>
parents: 0
diff changeset
155 TREE_CODE (node) == CONST_DECL ? 'C' : 'D');
77e2b8dfacca update it from 4.4.3 to 4.5.0
ryoma <e075725@ie.u-ryukyu.ac.jp>
parents: 0
diff changeset
156 else
77e2b8dfacca update it from 4.4.3 to 4.5.0
ryoma <e075725@ie.u-ryukyu.ac.jp>
parents: 0
diff changeset
157 fprintf (file, " %c.%u",
77e2b8dfacca update it from 4.4.3 to 4.5.0
ryoma <e075725@ie.u-ryukyu.ac.jp>
parents: 0
diff changeset
158 TREE_CODE (node) == CONST_DECL ? 'C' : 'D',
77e2b8dfacca update it from 4.4.3 to 4.5.0
ryoma <e075725@ie.u-ryukyu.ac.jp>
parents: 0
diff changeset
159 DECL_UID (node));
77e2b8dfacca update it from 4.4.3 to 4.5.0
ryoma <e075725@ie.u-ryukyu.ac.jp>
parents: 0
diff changeset
160 }
0
a06113de4d67 first commit
kent <kent@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
161 }
a06113de4d67 first commit
kent <kent@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
162 else if (tclass == tcc_type)
a06113de4d67 first commit
kent <kent@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
163 {
a06113de4d67 first commit
kent <kent@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
164 if (TYPE_NAME (node))
a06113de4d67 first commit
kent <kent@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
165 {
a06113de4d67 first commit
kent <kent@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
166 if (TREE_CODE (TYPE_NAME (node)) == IDENTIFIER_NODE)
a06113de4d67 first commit
kent <kent@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
167 fprintf (file, " %s", IDENTIFIER_POINTER (TYPE_NAME (node)));
a06113de4d67 first commit
kent <kent@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
168 else if (TREE_CODE (TYPE_NAME (node)) == TYPE_DECL
a06113de4d67 first commit
kent <kent@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
169 && DECL_NAME (TYPE_NAME (node)))
a06113de4d67 first commit
kent <kent@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
170 fprintf (file, " %s",
a06113de4d67 first commit
kent <kent@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
171 IDENTIFIER_POINTER (DECL_NAME (TYPE_NAME (node))));
a06113de4d67 first commit
kent <kent@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
172 }
55
77e2b8dfacca update it from 4.4.3 to 4.5.0
ryoma <e075725@ie.u-ryukyu.ac.jp>
parents: 0
diff changeset
173 if (!ADDR_SPACE_GENERIC_P (TYPE_ADDR_SPACE (node)))
77e2b8dfacca update it from 4.4.3 to 4.5.0
ryoma <e075725@ie.u-ryukyu.ac.jp>
parents: 0
diff changeset
174 fprintf (file, " address-space-%d", TYPE_ADDR_SPACE (node));
0
a06113de4d67 first commit
kent <kent@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
175 }
a06113de4d67 first commit
kent <kent@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
176 if (TREE_CODE (node) == IDENTIFIER_NODE)
a06113de4d67 first commit
kent <kent@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
177 fprintf (file, " %s", IDENTIFIER_POINTER (node));
a06113de4d67 first commit
kent <kent@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
178
a06113de4d67 first commit
kent <kent@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
179 /* We might as well always print the value of an integer or real. */
a06113de4d67 first commit
kent <kent@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
180 if (TREE_CODE (node) == INTEGER_CST)
a06113de4d67 first commit
kent <kent@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
181 {
a06113de4d67 first commit
kent <kent@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
182 if (TREE_OVERFLOW (node))
a06113de4d67 first commit
kent <kent@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
183 fprintf (file, " overflow");
a06113de4d67 first commit
kent <kent@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
184
a06113de4d67 first commit
kent <kent@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
185 fprintf (file, " ");
111
kono
parents: 67
diff changeset
186 print_dec (wi::to_wide (node), file, TYPE_SIGN (TREE_TYPE (node)));
0
a06113de4d67 first commit
kent <kent@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
187 }
a06113de4d67 first commit
kent <kent@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
188 if (TREE_CODE (node) == REAL_CST)
131
84e7813d76e9 gcc-8.2
mir3636
parents: 111
diff changeset
189 print_real_cst (file, node, true);
0
a06113de4d67 first commit
kent <kent@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
190 if (TREE_CODE (node) == FIXED_CST)
a06113de4d67 first commit
kent <kent@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
191 {
a06113de4d67 first commit
kent <kent@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
192 FIXED_VALUE_TYPE f;
a06113de4d67 first commit
kent <kent@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
193 char string[60];
a06113de4d67 first commit
kent <kent@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
194
a06113de4d67 first commit
kent <kent@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
195 if (TREE_OVERFLOW (node))
a06113de4d67 first commit
kent <kent@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
196 fprintf (file, " overflow");
a06113de4d67 first commit
kent <kent@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
197
a06113de4d67 first commit
kent <kent@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
198 f = TREE_FIXED_CST (node);
a06113de4d67 first commit
kent <kent@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
199 fixed_to_decimal (string, &f, sizeof (string));
a06113de4d67 first commit
kent <kent@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
200 fprintf (file, " %s", string);
a06113de4d67 first commit
kent <kent@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
201 }
a06113de4d67 first commit
kent <kent@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
202
a06113de4d67 first commit
kent <kent@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
203 fprintf (file, ">");
a06113de4d67 first commit
kent <kent@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
204 }
a06113de4d67 first commit
kent <kent@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
205
a06113de4d67 first commit
kent <kent@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
206 void
a06113de4d67 first commit
kent <kent@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
207 indent_to (FILE *file, int column)
a06113de4d67 first commit
kent <kent@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
208 {
a06113de4d67 first commit
kent <kent@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
209 int i;
a06113de4d67 first commit
kent <kent@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
210
a06113de4d67 first commit
kent <kent@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
211 /* Since this is the long way, indent to desired column. */
a06113de4d67 first commit
kent <kent@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
212 if (column > 0)
a06113de4d67 first commit
kent <kent@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
213 fprintf (file, "\n");
a06113de4d67 first commit
kent <kent@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
214 for (i = 0; i < column; i++)
a06113de4d67 first commit
kent <kent@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
215 fprintf (file, " ");
a06113de4d67 first commit
kent <kent@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
216 }
a06113de4d67 first commit
kent <kent@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
217
a06113de4d67 first commit
kent <kent@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
218 /* Print the node NODE in full on file FILE, preceded by PREFIX,
a06113de4d67 first commit
kent <kent@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
219 starting in column INDENT. */
a06113de4d67 first commit
kent <kent@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
220
a06113de4d67 first commit
kent <kent@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
221 void
111
kono
parents: 67
diff changeset
222 print_node (FILE *file, const char *prefix, tree node, int indent,
kono
parents: 67
diff changeset
223 bool brief_for_visited)
0
a06113de4d67 first commit
kent <kent@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
224 {
111
kono
parents: 67
diff changeset
225 machine_mode mode;
0
a06113de4d67 first commit
kent <kent@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
226 enum tree_code_class tclass;
a06113de4d67 first commit
kent <kent@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
227 int len;
a06113de4d67 first commit
kent <kent@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
228 int i;
a06113de4d67 first commit
kent <kent@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
229 expanded_location xloc;
a06113de4d67 first commit
kent <kent@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
230 enum tree_code code;
a06113de4d67 first commit
kent <kent@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
231
a06113de4d67 first commit
kent <kent@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
232 if (node == 0)
a06113de4d67 first commit
kent <kent@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
233 return;
55
77e2b8dfacca update it from 4.4.3 to 4.5.0
ryoma <e075725@ie.u-ryukyu.ac.jp>
parents: 0
diff changeset
234
0
a06113de4d67 first commit
kent <kent@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
235 code = TREE_CODE (node);
145
1830386684a0 gcc-9.2.0
anatofuz
parents: 131
diff changeset
236
1830386684a0 gcc-9.2.0
anatofuz
parents: 131
diff changeset
237 /* It is unsafe to look at any other fields of a node with ERROR_MARK or
1830386684a0 gcc-9.2.0
anatofuz
parents: 131
diff changeset
238 invalid code. */
1830386684a0 gcc-9.2.0
anatofuz
parents: 131
diff changeset
239 if (code == ERROR_MARK || code >= MAX_TREE_CODES)
1830386684a0 gcc-9.2.0
anatofuz
parents: 131
diff changeset
240 {
1830386684a0 gcc-9.2.0
anatofuz
parents: 131
diff changeset
241 print_node_brief (file, prefix, node, indent);
1830386684a0 gcc-9.2.0
anatofuz
parents: 131
diff changeset
242 return;
1830386684a0 gcc-9.2.0
anatofuz
parents: 131
diff changeset
243 }
1830386684a0 gcc-9.2.0
anatofuz
parents: 131
diff changeset
244
0
a06113de4d67 first commit
kent <kent@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
245 tclass = TREE_CODE_CLASS (code);
a06113de4d67 first commit
kent <kent@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
246
a06113de4d67 first commit
kent <kent@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
247 /* Don't get too deep in nesting. If the user wants to see deeper,
a06113de4d67 first commit
kent <kent@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
248 it is easy to use the address of a lowest-level node
a06113de4d67 first commit
kent <kent@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
249 as an argument in another call to debug_tree. */
a06113de4d67 first commit
kent <kent@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
250
a06113de4d67 first commit
kent <kent@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
251 if (indent > 24)
a06113de4d67 first commit
kent <kent@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
252 {
a06113de4d67 first commit
kent <kent@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
253 print_node_brief (file, prefix, node, indent);
a06113de4d67 first commit
kent <kent@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
254 return;
a06113de4d67 first commit
kent <kent@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
255 }
a06113de4d67 first commit
kent <kent@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
256
a06113de4d67 first commit
kent <kent@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
257 if (indent > 8 && (tclass == tcc_type || tclass == tcc_declaration))
a06113de4d67 first commit
kent <kent@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
258 {
a06113de4d67 first commit
kent <kent@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
259 print_node_brief (file, prefix, node, indent);
a06113de4d67 first commit
kent <kent@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
260 return;
a06113de4d67 first commit
kent <kent@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
261 }
a06113de4d67 first commit
kent <kent@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
262
a06113de4d67 first commit
kent <kent@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
263 /* Allow this function to be called if the table is not there. */
a06113de4d67 first commit
kent <kent@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
264 if (table)
a06113de4d67 first commit
kent <kent@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
265 {
111
kono
parents: 67
diff changeset
266 /* If node is in the table, just mention its address. */
kono
parents: 67
diff changeset
267 if (table->contains (node) && brief_for_visited)
kono
parents: 67
diff changeset
268 {
kono
parents: 67
diff changeset
269 print_node_brief (file, prefix, node, indent);
kono
parents: 67
diff changeset
270 return;
kono
parents: 67
diff changeset
271 }
55
77e2b8dfacca update it from 4.4.3 to 4.5.0
ryoma <e075725@ie.u-ryukyu.ac.jp>
parents: 0
diff changeset
272
111
kono
parents: 67
diff changeset
273 table->add (node);
0
a06113de4d67 first commit
kent <kent@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
274 }
a06113de4d67 first commit
kent <kent@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
275
a06113de4d67 first commit
kent <kent@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
276 /* Indent to the specified column, since this is the long form. */
a06113de4d67 first commit
kent <kent@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
277 indent_to (file, indent);
a06113de4d67 first commit
kent <kent@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
278
a06113de4d67 first commit
kent <kent@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
279 /* Print the slot this node is in, and its code, and address. */
111
kono
parents: 67
diff changeset
280 fprintf (file, "%s <%s", prefix, get_tree_code_name (code));
0
a06113de4d67 first commit
kent <kent@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
281 dump_addr (file, " ", node);
a06113de4d67 first commit
kent <kent@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
282
a06113de4d67 first commit
kent <kent@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
283 /* Print the name, if any. */
a06113de4d67 first commit
kent <kent@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
284 if (tclass == tcc_declaration)
a06113de4d67 first commit
kent <kent@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
285 {
a06113de4d67 first commit
kent <kent@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
286 if (DECL_NAME (node))
a06113de4d67 first commit
kent <kent@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
287 fprintf (file, " %s", IDENTIFIER_POINTER (DECL_NAME (node)));
a06113de4d67 first commit
kent <kent@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
288 else if (code == LABEL_DECL
a06113de4d67 first commit
kent <kent@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
289 && LABEL_DECL_UID (node) != -1)
55
77e2b8dfacca update it from 4.4.3 to 4.5.0
ryoma <e075725@ie.u-ryukyu.ac.jp>
parents: 0
diff changeset
290 {
77e2b8dfacca update it from 4.4.3 to 4.5.0
ryoma <e075725@ie.u-ryukyu.ac.jp>
parents: 0
diff changeset
291 if (dump_flags & TDF_NOUID)
77e2b8dfacca update it from 4.4.3 to 4.5.0
ryoma <e075725@ie.u-ryukyu.ac.jp>
parents: 0
diff changeset
292 fprintf (file, " L.xxxx");
77e2b8dfacca update it from 4.4.3 to 4.5.0
ryoma <e075725@ie.u-ryukyu.ac.jp>
parents: 0
diff changeset
293 else
77e2b8dfacca update it from 4.4.3 to 4.5.0
ryoma <e075725@ie.u-ryukyu.ac.jp>
parents: 0
diff changeset
294 fprintf (file, " L.%d", (int) LABEL_DECL_UID (node));
77e2b8dfacca update it from 4.4.3 to 4.5.0
ryoma <e075725@ie.u-ryukyu.ac.jp>
parents: 0
diff changeset
295 }
0
a06113de4d67 first commit
kent <kent@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
296 else
55
77e2b8dfacca update it from 4.4.3 to 4.5.0
ryoma <e075725@ie.u-ryukyu.ac.jp>
parents: 0
diff changeset
297 {
77e2b8dfacca update it from 4.4.3 to 4.5.0
ryoma <e075725@ie.u-ryukyu.ac.jp>
parents: 0
diff changeset
298 if (dump_flags & TDF_NOUID)
77e2b8dfacca update it from 4.4.3 to 4.5.0
ryoma <e075725@ie.u-ryukyu.ac.jp>
parents: 0
diff changeset
299 fprintf (file, " %c.xxxx", code == CONST_DECL ? 'C' : 'D');
77e2b8dfacca update it from 4.4.3 to 4.5.0
ryoma <e075725@ie.u-ryukyu.ac.jp>
parents: 0
diff changeset
300 else
77e2b8dfacca update it from 4.4.3 to 4.5.0
ryoma <e075725@ie.u-ryukyu.ac.jp>
parents: 0
diff changeset
301 fprintf (file, " %c.%u", code == CONST_DECL ? 'C' : 'D',
77e2b8dfacca update it from 4.4.3 to 4.5.0
ryoma <e075725@ie.u-ryukyu.ac.jp>
parents: 0
diff changeset
302 DECL_UID (node));
77e2b8dfacca update it from 4.4.3 to 4.5.0
ryoma <e075725@ie.u-ryukyu.ac.jp>
parents: 0
diff changeset
303 }
0
a06113de4d67 first commit
kent <kent@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
304 }
a06113de4d67 first commit
kent <kent@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
305 else if (tclass == tcc_type)
a06113de4d67 first commit
kent <kent@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
306 {
a06113de4d67 first commit
kent <kent@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
307 if (TYPE_NAME (node))
a06113de4d67 first commit
kent <kent@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
308 {
a06113de4d67 first commit
kent <kent@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
309 if (TREE_CODE (TYPE_NAME (node)) == IDENTIFIER_NODE)
a06113de4d67 first commit
kent <kent@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
310 fprintf (file, " %s", IDENTIFIER_POINTER (TYPE_NAME (node)));
a06113de4d67 first commit
kent <kent@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
311 else if (TREE_CODE (TYPE_NAME (node)) == TYPE_DECL
a06113de4d67 first commit
kent <kent@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
312 && DECL_NAME (TYPE_NAME (node)))
a06113de4d67 first commit
kent <kent@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
313 fprintf (file, " %s",
a06113de4d67 first commit
kent <kent@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
314 IDENTIFIER_POINTER (DECL_NAME (TYPE_NAME (node))));
a06113de4d67 first commit
kent <kent@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
315 }
a06113de4d67 first commit
kent <kent@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
316 }
a06113de4d67 first commit
kent <kent@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
317 if (code == IDENTIFIER_NODE)
a06113de4d67 first commit
kent <kent@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
318 fprintf (file, " %s", IDENTIFIER_POINTER (node));
a06113de4d67 first commit
kent <kent@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
319
a06113de4d67 first commit
kent <kent@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
320 if (code == INTEGER_CST)
a06113de4d67 first commit
kent <kent@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
321 {
a06113de4d67 first commit
kent <kent@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
322 if (indent <= 4)
a06113de4d67 first commit
kent <kent@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
323 print_node_brief (file, "type", TREE_TYPE (node), indent + 4);
a06113de4d67 first commit
kent <kent@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
324 }
111
kono
parents: 67
diff changeset
325 else if (CODE_CONTAINS_STRUCT (code, TS_TYPED))
0
a06113de4d67 first commit
kent <kent@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
326 {
a06113de4d67 first commit
kent <kent@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
327 print_node (file, "type", TREE_TYPE (node), indent + 4);
a06113de4d67 first commit
kent <kent@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
328 if (TREE_TYPE (node))
a06113de4d67 first commit
kent <kent@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
329 indent_to (file, indent + 3);
a06113de4d67 first commit
kent <kent@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
330 }
a06113de4d67 first commit
kent <kent@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
331
a06113de4d67 first commit
kent <kent@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
332 if (!TYPE_P (node) && TREE_SIDE_EFFECTS (node))
a06113de4d67 first commit
kent <kent@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
333 fputs (" side-effects", file);
a06113de4d67 first commit
kent <kent@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
334
a06113de4d67 first commit
kent <kent@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
335 if (TYPE_P (node) ? TYPE_READONLY (node) : TREE_READONLY (node))
a06113de4d67 first commit
kent <kent@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
336 fputs (" readonly", file);
111
kono
parents: 67
diff changeset
337 if (TYPE_P (node) && TYPE_ATOMIC (node))
kono
parents: 67
diff changeset
338 fputs (" atomic", file);
0
a06113de4d67 first commit
kent <kent@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
339 if (!TYPE_P (node) && TREE_CONSTANT (node))
a06113de4d67 first commit
kent <kent@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
340 fputs (" constant", file);
a06113de4d67 first commit
kent <kent@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
341 else if (TYPE_P (node) && TYPE_SIZES_GIMPLIFIED (node))
a06113de4d67 first commit
kent <kent@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
342 fputs (" sizes-gimplified", file);
a06113de4d67 first commit
kent <kent@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
343
55
77e2b8dfacca update it from 4.4.3 to 4.5.0
ryoma <e075725@ie.u-ryukyu.ac.jp>
parents: 0
diff changeset
344 if (TYPE_P (node) && !ADDR_SPACE_GENERIC_P (TYPE_ADDR_SPACE (node)))
77e2b8dfacca update it from 4.4.3 to 4.5.0
ryoma <e075725@ie.u-ryukyu.ac.jp>
parents: 0
diff changeset
345 fprintf (file, " address-space-%d", TYPE_ADDR_SPACE (node));
77e2b8dfacca update it from 4.4.3 to 4.5.0
ryoma <e075725@ie.u-ryukyu.ac.jp>
parents: 0
diff changeset
346
0
a06113de4d67 first commit
kent <kent@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
347 if (TREE_ADDRESSABLE (node))
a06113de4d67 first commit
kent <kent@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
348 fputs (" addressable", file);
a06113de4d67 first commit
kent <kent@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
349 if (TREE_THIS_VOLATILE (node))
a06113de4d67 first commit
kent <kent@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
350 fputs (" volatile", file);
a06113de4d67 first commit
kent <kent@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
351 if (TREE_ASM_WRITTEN (node))
a06113de4d67 first commit
kent <kent@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
352 fputs (" asm_written", file);
a06113de4d67 first commit
kent <kent@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
353 if (TREE_USED (node))
a06113de4d67 first commit
kent <kent@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
354 fputs (" used", file);
a06113de4d67 first commit
kent <kent@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
355 if (TREE_NOTHROW (node))
111
kono
parents: 67
diff changeset
356 fputs (" nothrow", file);
0
a06113de4d67 first commit
kent <kent@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
357 if (TREE_PUBLIC (node))
a06113de4d67 first commit
kent <kent@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
358 fputs (" public", file);
a06113de4d67 first commit
kent <kent@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
359 if (TREE_PRIVATE (node))
a06113de4d67 first commit
kent <kent@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
360 fputs (" private", file);
a06113de4d67 first commit
kent <kent@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
361 if (TREE_PROTECTED (node))
a06113de4d67 first commit
kent <kent@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
362 fputs (" protected", file);
a06113de4d67 first commit
kent <kent@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
363 if (TREE_STATIC (node))
111
kono
parents: 67
diff changeset
364 fputs (code == CALL_EXPR ? " must-tail-call" : " static", file);
0
a06113de4d67 first commit
kent <kent@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
365 if (TREE_DEPRECATED (node))
a06113de4d67 first commit
kent <kent@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
366 fputs (" deprecated", file);
a06113de4d67 first commit
kent <kent@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
367 if (TREE_VISITED (node))
a06113de4d67 first commit
kent <kent@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
368 fputs (" visited", file);
111
kono
parents: 67
diff changeset
369
kono
parents: 67
diff changeset
370 if (code != TREE_VEC && code != INTEGER_CST && code != SSA_NAME)
kono
parents: 67
diff changeset
371 {
kono
parents: 67
diff changeset
372 if (TREE_LANG_FLAG_0 (node))
kono
parents: 67
diff changeset
373 fputs (" tree_0", file);
kono
parents: 67
diff changeset
374 if (TREE_LANG_FLAG_1 (node))
kono
parents: 67
diff changeset
375 fputs (" tree_1", file);
kono
parents: 67
diff changeset
376 if (TREE_LANG_FLAG_2 (node))
kono
parents: 67
diff changeset
377 fputs (" tree_2", file);
kono
parents: 67
diff changeset
378 if (TREE_LANG_FLAG_3 (node))
kono
parents: 67
diff changeset
379 fputs (" tree_3", file);
kono
parents: 67
diff changeset
380 if (TREE_LANG_FLAG_4 (node))
kono
parents: 67
diff changeset
381 fputs (" tree_4", file);
kono
parents: 67
diff changeset
382 if (TREE_LANG_FLAG_5 (node))
kono
parents: 67
diff changeset
383 fputs (" tree_5", file);
kono
parents: 67
diff changeset
384 if (TREE_LANG_FLAG_6 (node))
kono
parents: 67
diff changeset
385 fputs (" tree_6", file);
kono
parents: 67
diff changeset
386 }
0
a06113de4d67 first commit
kent <kent@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
387
a06113de4d67 first commit
kent <kent@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
388 /* DECL_ nodes have additional attributes. */
a06113de4d67 first commit
kent <kent@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
389
a06113de4d67 first commit
kent <kent@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
390 switch (TREE_CODE_CLASS (code))
a06113de4d67 first commit
kent <kent@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
391 {
a06113de4d67 first commit
kent <kent@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
392 case tcc_declaration:
a06113de4d67 first commit
kent <kent@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
393 if (CODE_CONTAINS_STRUCT (code, TS_DECL_COMMON))
a06113de4d67 first commit
kent <kent@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
394 {
a06113de4d67 first commit
kent <kent@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
395 if (DECL_UNSIGNED (node))
a06113de4d67 first commit
kent <kent@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
396 fputs (" unsigned", file);
a06113de4d67 first commit
kent <kent@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
397 if (DECL_IGNORED_P (node))
a06113de4d67 first commit
kent <kent@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
398 fputs (" ignored", file);
111
kono
parents: 67
diff changeset
399 if (DECL_ABSTRACT_P (node))
55
77e2b8dfacca update it from 4.4.3 to 4.5.0
ryoma <e075725@ie.u-ryukyu.ac.jp>
parents: 0
diff changeset
400 fputs (" abstract", file);
0
a06113de4d67 first commit
kent <kent@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
401 if (DECL_EXTERNAL (node))
a06113de4d67 first commit
kent <kent@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
402 fputs (" external", file);
a06113de4d67 first commit
kent <kent@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
403 if (DECL_NONLOCAL (node))
a06113de4d67 first commit
kent <kent@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
404 fputs (" nonlocal", file);
a06113de4d67 first commit
kent <kent@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
405 }
a06113de4d67 first commit
kent <kent@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
406 if (CODE_CONTAINS_STRUCT (code, TS_DECL_WITH_VIS))
a06113de4d67 first commit
kent <kent@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
407 {
a06113de4d67 first commit
kent <kent@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
408 if (DECL_WEAK (node))
a06113de4d67 first commit
kent <kent@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
409 fputs (" weak", file);
a06113de4d67 first commit
kent <kent@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
410 if (DECL_IN_SYSTEM_HEADER (node))
a06113de4d67 first commit
kent <kent@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
411 fputs (" in_system_header", file);
a06113de4d67 first commit
kent <kent@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
412 }
a06113de4d67 first commit
kent <kent@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
413 if (CODE_CONTAINS_STRUCT (code, TS_DECL_WRTL)
a06113de4d67 first commit
kent <kent@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
414 && code != LABEL_DECL
a06113de4d67 first commit
kent <kent@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
415 && code != FUNCTION_DECL
a06113de4d67 first commit
kent <kent@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
416 && DECL_REGISTER (node))
a06113de4d67 first commit
kent <kent@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
417 fputs (" regdecl", file);
a06113de4d67 first commit
kent <kent@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
418
a06113de4d67 first commit
kent <kent@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
419 if (code == TYPE_DECL && TYPE_DECL_SUPPRESS_DEBUG (node))
a06113de4d67 first commit
kent <kent@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
420 fputs (" suppress-debug", file);
a06113de4d67 first commit
kent <kent@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
421
a06113de4d67 first commit
kent <kent@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
422 if (code == FUNCTION_DECL
a06113de4d67 first commit
kent <kent@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
423 && DECL_FUNCTION_SPECIFIC_TARGET (node))
a06113de4d67 first commit
kent <kent@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
424 fputs (" function-specific-target", file);
a06113de4d67 first commit
kent <kent@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
425 if (code == FUNCTION_DECL
a06113de4d67 first commit
kent <kent@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
426 && DECL_FUNCTION_SPECIFIC_OPTIMIZATION (node))
a06113de4d67 first commit
kent <kent@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
427 fputs (" function-specific-opt", file);
a06113de4d67 first commit
kent <kent@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
428 if (code == FUNCTION_DECL && DECL_DECLARED_INLINE_P (node))
a06113de4d67 first commit
kent <kent@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
429 fputs (" autoinline", file);
131
84e7813d76e9 gcc-8.2
mir3636
parents: 111
diff changeset
430 if (code == FUNCTION_DECL && DECL_UNINLINABLE (node))
84e7813d76e9 gcc-8.2
mir3636
parents: 111
diff changeset
431 fputs (" uninlinable", file);
84e7813d76e9 gcc-8.2
mir3636
parents: 111
diff changeset
432 if (code == FUNCTION_DECL && fndecl_built_in_p (node))
0
a06113de4d67 first commit
kent <kent@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
433 fputs (" built-in", file);
55
77e2b8dfacca update it from 4.4.3 to 4.5.0
ryoma <e075725@ie.u-ryukyu.ac.jp>
parents: 0
diff changeset
434 if (code == FUNCTION_DECL && DECL_STATIC_CHAIN (node))
77e2b8dfacca update it from 4.4.3 to 4.5.0
ryoma <e075725@ie.u-ryukyu.ac.jp>
parents: 0
diff changeset
435 fputs (" static-chain", file);
111
kono
parents: 67
diff changeset
436 if (TREE_CODE (node) == FUNCTION_DECL && decl_is_tm_clone (node))
kono
parents: 67
diff changeset
437 fputs (" tm-clone", file);
0
a06113de4d67 first commit
kent <kent@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
438
a06113de4d67 first commit
kent <kent@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
439 if (code == FIELD_DECL && DECL_PACKED (node))
a06113de4d67 first commit
kent <kent@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
440 fputs (" packed", file);
a06113de4d67 first commit
kent <kent@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
441 if (code == FIELD_DECL && DECL_BIT_FIELD (node))
a06113de4d67 first commit
kent <kent@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
442 fputs (" bit-field", file);
a06113de4d67 first commit
kent <kent@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
443 if (code == FIELD_DECL && DECL_NONADDRESSABLE_P (node))
a06113de4d67 first commit
kent <kent@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
444 fputs (" nonaddressable", file);
a06113de4d67 first commit
kent <kent@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
445
55
77e2b8dfacca update it from 4.4.3 to 4.5.0
ryoma <e075725@ie.u-ryukyu.ac.jp>
parents: 0
diff changeset
446 if (code == LABEL_DECL && EH_LANDING_PAD_NR (node))
77e2b8dfacca update it from 4.4.3 to 4.5.0
ryoma <e075725@ie.u-ryukyu.ac.jp>
parents: 0
diff changeset
447 fprintf (file, " landing-pad:%d", EH_LANDING_PAD_NR (node));
0
a06113de4d67 first commit
kent <kent@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
448
a06113de4d67 first commit
kent <kent@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
449 if (code == VAR_DECL && DECL_IN_TEXT_SECTION (node))
a06113de4d67 first commit
kent <kent@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
450 fputs (" in-text-section", file);
67
f6334be47118 update gcc from gcc-4.6-20100522 to gcc-4.6-20110318
nobuyasu <dimolto@cr.ie.u-ryukyu.ac.jp>
parents: 63
diff changeset
451 if (code == VAR_DECL && DECL_IN_CONSTANT_POOL (node))
f6334be47118 update gcc from gcc-4.6-20100522 to gcc-4.6-20110318
nobuyasu <dimolto@cr.ie.u-ryukyu.ac.jp>
parents: 63
diff changeset
452 fputs (" in-constant-pool", file);
0
a06113de4d67 first commit
kent <kent@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
453 if (code == VAR_DECL && DECL_COMMON (node))
a06113de4d67 first commit
kent <kent@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
454 fputs (" common", file);
111
kono
parents: 67
diff changeset
455 if ((code == VAR_DECL || code == PARM_DECL) && DECL_READ_P (node))
kono
parents: 67
diff changeset
456 fputs (" read", file);
0
a06113de4d67 first commit
kent <kent@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
457 if (code == VAR_DECL && DECL_THREAD_LOCAL_P (node))
a06113de4d67 first commit
kent <kent@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
458 {
111
kono
parents: 67
diff changeset
459 fputs (" ", file);
kono
parents: 67
diff changeset
460 fputs (tls_model_names[DECL_TLS_MODEL (node)], file);
0
a06113de4d67 first commit
kent <kent@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
461 }
a06113de4d67 first commit
kent <kent@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
462
a06113de4d67 first commit
kent <kent@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
463 if (CODE_CONTAINS_STRUCT (code, TS_DECL_COMMON))
55
77e2b8dfacca update it from 4.4.3 to 4.5.0
ryoma <e075725@ie.u-ryukyu.ac.jp>
parents: 0
diff changeset
464 {
0
a06113de4d67 first commit
kent <kent@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
465 if (DECL_VIRTUAL_P (node))
a06113de4d67 first commit
kent <kent@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
466 fputs (" virtual", file);
a06113de4d67 first commit
kent <kent@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
467 if (DECL_PRESERVE_P (node))
a06113de4d67 first commit
kent <kent@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
468 fputs (" preserve", file);
a06113de4d67 first commit
kent <kent@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
469 if (DECL_LANG_FLAG_0 (node))
a06113de4d67 first commit
kent <kent@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
470 fputs (" decl_0", file);
a06113de4d67 first commit
kent <kent@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
471 if (DECL_LANG_FLAG_1 (node))
a06113de4d67 first commit
kent <kent@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
472 fputs (" decl_1", file);
a06113de4d67 first commit
kent <kent@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
473 if (DECL_LANG_FLAG_2 (node))
a06113de4d67 first commit
kent <kent@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
474 fputs (" decl_2", file);
a06113de4d67 first commit
kent <kent@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
475 if (DECL_LANG_FLAG_3 (node))
a06113de4d67 first commit
kent <kent@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
476 fputs (" decl_3", file);
a06113de4d67 first commit
kent <kent@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
477 if (DECL_LANG_FLAG_4 (node))
a06113de4d67 first commit
kent <kent@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
478 fputs (" decl_4", file);
a06113de4d67 first commit
kent <kent@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
479 if (DECL_LANG_FLAG_5 (node))
a06113de4d67 first commit
kent <kent@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
480 fputs (" decl_5", file);
a06113de4d67 first commit
kent <kent@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
481 if (DECL_LANG_FLAG_6 (node))
a06113de4d67 first commit
kent <kent@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
482 fputs (" decl_6", file);
a06113de4d67 first commit
kent <kent@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
483 if (DECL_LANG_FLAG_7 (node))
a06113de4d67 first commit
kent <kent@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
484 fputs (" decl_7", file);
55
77e2b8dfacca update it from 4.4.3 to 4.5.0
ryoma <e075725@ie.u-ryukyu.ac.jp>
parents: 0
diff changeset
485
0
a06113de4d67 first commit
kent <kent@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
486 mode = DECL_MODE (node);
a06113de4d67 first commit
kent <kent@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
487 fprintf (file, " %s", GET_MODE_NAME (mode));
a06113de4d67 first commit
kent <kent@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
488 }
a06113de4d67 first commit
kent <kent@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
489
55
77e2b8dfacca update it from 4.4.3 to 4.5.0
ryoma <e075725@ie.u-ryukyu.ac.jp>
parents: 0
diff changeset
490 if ((code == VAR_DECL || code == PARM_DECL || code == RESULT_DECL)
77e2b8dfacca update it from 4.4.3 to 4.5.0
ryoma <e075725@ie.u-ryukyu.ac.jp>
parents: 0
diff changeset
491 && DECL_BY_REFERENCE (node))
77e2b8dfacca update it from 4.4.3 to 4.5.0
ryoma <e075725@ie.u-ryukyu.ac.jp>
parents: 0
diff changeset
492 fputs (" passed-by-reference", file);
77e2b8dfacca update it from 4.4.3 to 4.5.0
ryoma <e075725@ie.u-ryukyu.ac.jp>
parents: 0
diff changeset
493
0
a06113de4d67 first commit
kent <kent@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
494 if (CODE_CONTAINS_STRUCT (code, TS_DECL_WITH_VIS) && DECL_DEFER_OUTPUT (node))
a06113de4d67 first commit
kent <kent@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
495 fputs (" defer-output", file);
a06113de4d67 first commit
kent <kent@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
496
a06113de4d67 first commit
kent <kent@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
497
a06113de4d67 first commit
kent <kent@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
498 xloc = expand_location (DECL_SOURCE_LOCATION (node));
111
kono
parents: 67
diff changeset
499 fprintf (file, " %s:%d:%d", xloc.file, xloc.line,
0
a06113de4d67 first commit
kent <kent@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
500 xloc.column);
a06113de4d67 first commit
kent <kent@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
501
a06113de4d67 first commit
kent <kent@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
502 if (CODE_CONTAINS_STRUCT (code, TS_DECL_COMMON))
55
77e2b8dfacca update it from 4.4.3 to 4.5.0
ryoma <e075725@ie.u-ryukyu.ac.jp>
parents: 0
diff changeset
503 {
0
a06113de4d67 first commit
kent <kent@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
504 print_node (file, "size", DECL_SIZE (node), indent + 4);
111
kono
parents: 67
diff changeset
505 print_node (file, "unit-size", DECL_SIZE_UNIT (node), indent + 4);
55
77e2b8dfacca update it from 4.4.3 to 4.5.0
ryoma <e075725@ie.u-ryukyu.ac.jp>
parents: 0
diff changeset
506
131
84e7813d76e9 gcc-8.2
mir3636
parents: 111
diff changeset
507 if (code != FUNCTION_DECL || fndecl_built_in_p (node))
0
a06113de4d67 first commit
kent <kent@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
508 indent_to (file, indent + 3);
55
77e2b8dfacca update it from 4.4.3 to 4.5.0
ryoma <e075725@ie.u-ryukyu.ac.jp>
parents: 0
diff changeset
509
0
a06113de4d67 first commit
kent <kent@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
510 if (DECL_USER_ALIGN (node))
a06113de4d67 first commit
kent <kent@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
511 fprintf (file, " user");
55
77e2b8dfacca update it from 4.4.3 to 4.5.0
ryoma <e075725@ie.u-ryukyu.ac.jp>
parents: 0
diff changeset
512
111
kono
parents: 67
diff changeset
513 fprintf (file, " align:%d warn_if_not_align:%d",
kono
parents: 67
diff changeset
514 DECL_ALIGN (node), DECL_WARN_IF_NOT_ALIGN (node));
0
a06113de4d67 first commit
kent <kent@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
515 if (code == FIELD_DECL)
a06113de4d67 first commit
kent <kent@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
516 fprintf (file, " offset_align " HOST_WIDE_INT_PRINT_UNSIGNED,
a06113de4d67 first commit
kent <kent@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
517 DECL_OFFSET_ALIGN (node));
a06113de4d67 first commit
kent <kent@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
518
131
84e7813d76e9 gcc-8.2
mir3636
parents: 111
diff changeset
519 if (code == FUNCTION_DECL && fndecl_built_in_p (node))
0
a06113de4d67 first commit
kent <kent@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
520 {
a06113de4d67 first commit
kent <kent@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
521 if (DECL_BUILT_IN_CLASS (node) == BUILT_IN_MD)
145
1830386684a0 gcc-9.2.0
anatofuz
parents: 131
diff changeset
522 fprintf (file, " built-in: BUILT_IN_MD:%d",
1830386684a0 gcc-9.2.0
anatofuz
parents: 131
diff changeset
523 DECL_MD_FUNCTION_CODE (node));
1830386684a0 gcc-9.2.0
anatofuz
parents: 131
diff changeset
524 else if (DECL_BUILT_IN_CLASS (node) == BUILT_IN_FRONTEND)
1830386684a0 gcc-9.2.0
anatofuz
parents: 131
diff changeset
525 fprintf (file, " built-in: BUILT_IN_FRONTEND:%d",
1830386684a0 gcc-9.2.0
anatofuz
parents: 131
diff changeset
526 DECL_FE_FUNCTION_CODE (node));
0
a06113de4d67 first commit
kent <kent@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
527 else
111
kono
parents: 67
diff changeset
528 fprintf (file, " built-in: %s:%s",
0
a06113de4d67 first commit
kent <kent@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
529 built_in_class_names[(int) DECL_BUILT_IN_CLASS (node)],
a06113de4d67 first commit
kent <kent@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
530 built_in_names[(int) DECL_FUNCTION_CODE (node)]);
a06113de4d67 first commit
kent <kent@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
531 }
a06113de4d67 first commit
kent <kent@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
532 }
a06113de4d67 first commit
kent <kent@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
533 if (code == FIELD_DECL)
a06113de4d67 first commit
kent <kent@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
534 {
a06113de4d67 first commit
kent <kent@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
535 print_node (file, "offset", DECL_FIELD_OFFSET (node), indent + 4);
111
kono
parents: 67
diff changeset
536 print_node (file, "bit-offset", DECL_FIELD_BIT_OFFSET (node),
0
a06113de4d67 first commit
kent <kent@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
537 indent + 4);
a06113de4d67 first commit
kent <kent@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
538 if (DECL_BIT_FIELD_TYPE (node))
a06113de4d67 first commit
kent <kent@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
539 print_node (file, "bit_field_type", DECL_BIT_FIELD_TYPE (node),
a06113de4d67 first commit
kent <kent@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
540 indent + 4);
a06113de4d67 first commit
kent <kent@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
541 }
a06113de4d67 first commit
kent <kent@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
542
a06113de4d67 first commit
kent <kent@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
543 print_node_brief (file, "context", DECL_CONTEXT (node), indent + 4);
a06113de4d67 first commit
kent <kent@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
544
55
77e2b8dfacca update it from 4.4.3 to 4.5.0
ryoma <e075725@ie.u-ryukyu.ac.jp>
parents: 0
diff changeset
545 if (CODE_CONTAINS_STRUCT (code, TS_DECL_COMMON))
0
a06113de4d67 first commit
kent <kent@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
546 {
111
kono
parents: 67
diff changeset
547 print_node (file, "attributes",
0
a06113de4d67 first commit
kent <kent@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
548 DECL_ATTRIBUTES (node), indent + 4);
a06113de4d67 first commit
kent <kent@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
549 if (code != PARM_DECL)
a06113de4d67 first commit
kent <kent@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
550 print_node_brief (file, "initial", DECL_INITIAL (node),
a06113de4d67 first commit
kent <kent@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
551 indent + 4);
a06113de4d67 first commit
kent <kent@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
552 }
a06113de4d67 first commit
kent <kent@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
553 if (CODE_CONTAINS_STRUCT (code, TS_DECL_WRTL))
a06113de4d67 first commit
kent <kent@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
554 {
a06113de4d67 first commit
kent <kent@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
555 print_node_brief (file, "abstract_origin",
a06113de4d67 first commit
kent <kent@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
556 DECL_ABSTRACT_ORIGIN (node), indent + 4);
a06113de4d67 first commit
kent <kent@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
557 }
a06113de4d67 first commit
kent <kent@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
558 if (CODE_CONTAINS_STRUCT (code, TS_DECL_NON_COMMON))
a06113de4d67 first commit
kent <kent@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
559 {
a06113de4d67 first commit
kent <kent@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
560 print_node (file, "result", DECL_RESULT_FLD (node), indent + 4);
a06113de4d67 first commit
kent <kent@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
561 }
a06113de4d67 first commit
kent <kent@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
562
a06113de4d67 first commit
kent <kent@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
563 lang_hooks.print_decl (file, node, indent);
a06113de4d67 first commit
kent <kent@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
564
a06113de4d67 first commit
kent <kent@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
565 if (DECL_RTL_SET_P (node))
a06113de4d67 first commit
kent <kent@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
566 {
a06113de4d67 first commit
kent <kent@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
567 indent_to (file, indent + 4);
a06113de4d67 first commit
kent <kent@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
568 print_rtl (file, DECL_RTL (node));
a06113de4d67 first commit
kent <kent@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
569 }
a06113de4d67 first commit
kent <kent@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
570
a06113de4d67 first commit
kent <kent@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
571 if (code == PARM_DECL)
a06113de4d67 first commit
kent <kent@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
572 {
a06113de4d67 first commit
kent <kent@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
573 print_node (file, "arg-type", DECL_ARG_TYPE (node), indent + 4);
a06113de4d67 first commit
kent <kent@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
574
a06113de4d67 first commit
kent <kent@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
575 if (DECL_INCOMING_RTL (node) != 0)
a06113de4d67 first commit
kent <kent@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
576 {
a06113de4d67 first commit
kent <kent@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
577 indent_to (file, indent + 4);
a06113de4d67 first commit
kent <kent@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
578 fprintf (file, "incoming-rtl ");
a06113de4d67 first commit
kent <kent@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
579 print_rtl (file, DECL_INCOMING_RTL (node));
a06113de4d67 first commit
kent <kent@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
580 }
a06113de4d67 first commit
kent <kent@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
581 }
a06113de4d67 first commit
kent <kent@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
582 else if (code == FUNCTION_DECL
a06113de4d67 first commit
kent <kent@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
583 && DECL_STRUCT_FUNCTION (node) != 0)
a06113de4d67 first commit
kent <kent@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
584 {
111
kono
parents: 67
diff changeset
585 print_node (file, "arguments", DECL_ARGUMENTS (node), indent + 4);
0
a06113de4d67 first commit
kent <kent@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
586 indent_to (file, indent + 4);
55
77e2b8dfacca update it from 4.4.3 to 4.5.0
ryoma <e075725@ie.u-ryukyu.ac.jp>
parents: 0
diff changeset
587 dump_addr (file, "struct-function ", DECL_STRUCT_FUNCTION (node));
0
a06113de4d67 first commit
kent <kent@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
588 }
a06113de4d67 first commit
kent <kent@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
589
a06113de4d67 first commit
kent <kent@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
590 if ((code == VAR_DECL || code == PARM_DECL)
a06113de4d67 first commit
kent <kent@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
591 && DECL_HAS_VALUE_EXPR_P (node))
a06113de4d67 first commit
kent <kent@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
592 print_node (file, "value-expr", DECL_VALUE_EXPR (node), indent + 4);
a06113de4d67 first commit
kent <kent@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
593
a06113de4d67 first commit
kent <kent@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
594 /* Print the decl chain only if decl is at second level. */
a06113de4d67 first commit
kent <kent@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
595 if (indent == 4)
a06113de4d67 first commit
kent <kent@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
596 print_node (file, "chain", TREE_CHAIN (node), indent + 4);
a06113de4d67 first commit
kent <kent@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
597 else
a06113de4d67 first commit
kent <kent@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
598 print_node_brief (file, "chain", TREE_CHAIN (node), indent + 4);
a06113de4d67 first commit
kent <kent@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
599 break;
a06113de4d67 first commit
kent <kent@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
600
a06113de4d67 first commit
kent <kent@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
601 case tcc_type:
a06113de4d67 first commit
kent <kent@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
602 if (TYPE_UNSIGNED (node))
a06113de4d67 first commit
kent <kent@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
603 fputs (" unsigned", file);
a06113de4d67 first commit
kent <kent@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
604
111
kono
parents: 67
diff changeset
605 if (TYPE_NO_FORCE_BLK (node))
0
a06113de4d67 first commit
kent <kent@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
606 fputs (" no-force-blk", file);
a06113de4d67 first commit
kent <kent@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
607
145
1830386684a0 gcc-9.2.0
anatofuz
parents: 131
diff changeset
608 if (code == ARRAY_TYPE && TYPE_STRING_FLAG (node))
0
a06113de4d67 first commit
kent <kent@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
609 fputs (" string-flag", file);
111
kono
parents: 67
diff changeset
610
0
a06113de4d67 first commit
kent <kent@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
611 if (TYPE_NEEDS_CONSTRUCTING (node))
a06113de4d67 first commit
kent <kent@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
612 fputs (" needs-constructing", file);
a06113de4d67 first commit
kent <kent@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
613
111
kono
parents: 67
diff changeset
614 if ((code == RECORD_TYPE
kono
parents: 67
diff changeset
615 || code == UNION_TYPE
kono
parents: 67
diff changeset
616 || code == QUAL_UNION_TYPE
kono
parents: 67
diff changeset
617 || code == ARRAY_TYPE)
kono
parents: 67
diff changeset
618 && TYPE_REVERSE_STORAGE_ORDER (node))
kono
parents: 67
diff changeset
619 fputs (" reverse-storage-order", file);
kono
parents: 67
diff changeset
620
145
1830386684a0 gcc-9.2.0
anatofuz
parents: 131
diff changeset
621 if ((code == RECORD_TYPE
1830386684a0 gcc-9.2.0
anatofuz
parents: 131
diff changeset
622 || code == UNION_TYPE)
1830386684a0 gcc-9.2.0
anatofuz
parents: 131
diff changeset
623 && TYPE_CXX_ODR_P (node))
1830386684a0 gcc-9.2.0
anatofuz
parents: 131
diff changeset
624 fputs (" cxx-odr-p", file);
1830386684a0 gcc-9.2.0
anatofuz
parents: 131
diff changeset
625
0
a06113de4d67 first commit
kent <kent@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
626 /* The transparent-union flag is used for different things in
a06113de4d67 first commit
kent <kent@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
627 different nodes. */
63
b7f97abdc517 update gcc from gcc-4.5.0 to gcc-4.6
ryoma <e075725@ie.u-ryukyu.ac.jp>
parents: 55
diff changeset
628 if ((code == UNION_TYPE || code == RECORD_TYPE)
b7f97abdc517 update gcc from gcc-4.5.0 to gcc-4.6
ryoma <e075725@ie.u-ryukyu.ac.jp>
parents: 55
diff changeset
629 && TYPE_TRANSPARENT_AGGR (node))
b7f97abdc517 update gcc from gcc-4.5.0 to gcc-4.6
ryoma <e075725@ie.u-ryukyu.ac.jp>
parents: 55
diff changeset
630 fputs (" transparent-aggr", file);
0
a06113de4d67 first commit
kent <kent@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
631 else if (code == ARRAY_TYPE
a06113de4d67 first commit
kent <kent@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
632 && TYPE_NONALIASED_COMPONENT (node))
a06113de4d67 first commit
kent <kent@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
633 fputs (" nonaliased-component", file);
a06113de4d67 first commit
kent <kent@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
634
a06113de4d67 first commit
kent <kent@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
635 if (TYPE_PACKED (node))
a06113de4d67 first commit
kent <kent@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
636 fputs (" packed", file);
a06113de4d67 first commit
kent <kent@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
637
a06113de4d67 first commit
kent <kent@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
638 if (TYPE_RESTRICT (node))
a06113de4d67 first commit
kent <kent@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
639 fputs (" restrict", file);
a06113de4d67 first commit
kent <kent@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
640
a06113de4d67 first commit
kent <kent@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
641 if (TYPE_LANG_FLAG_0 (node))
a06113de4d67 first commit
kent <kent@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
642 fputs (" type_0", file);
a06113de4d67 first commit
kent <kent@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
643 if (TYPE_LANG_FLAG_1 (node))
a06113de4d67 first commit
kent <kent@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
644 fputs (" type_1", file);
a06113de4d67 first commit
kent <kent@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
645 if (TYPE_LANG_FLAG_2 (node))
a06113de4d67 first commit
kent <kent@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
646 fputs (" type_2", file);
a06113de4d67 first commit
kent <kent@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
647 if (TYPE_LANG_FLAG_3 (node))
a06113de4d67 first commit
kent <kent@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
648 fputs (" type_3", file);
a06113de4d67 first commit
kent <kent@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
649 if (TYPE_LANG_FLAG_4 (node))
a06113de4d67 first commit
kent <kent@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
650 fputs (" type_4", file);
a06113de4d67 first commit
kent <kent@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
651 if (TYPE_LANG_FLAG_5 (node))
a06113de4d67 first commit
kent <kent@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
652 fputs (" type_5", file);
a06113de4d67 first commit
kent <kent@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
653 if (TYPE_LANG_FLAG_6 (node))
a06113de4d67 first commit
kent <kent@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
654 fputs (" type_6", file);
111
kono
parents: 67
diff changeset
655 if (TYPE_LANG_FLAG_7 (node))
kono
parents: 67
diff changeset
656 fputs (" type_7", file);
0
a06113de4d67 first commit
kent <kent@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
657
a06113de4d67 first commit
kent <kent@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
658 mode = TYPE_MODE (node);
a06113de4d67 first commit
kent <kent@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
659 fprintf (file, " %s", GET_MODE_NAME (mode));
a06113de4d67 first commit
kent <kent@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
660
a06113de4d67 first commit
kent <kent@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
661 print_node (file, "size", TYPE_SIZE (node), indent + 4);
111
kono
parents: 67
diff changeset
662 print_node (file, "unit-size", TYPE_SIZE_UNIT (node), indent + 4);
0
a06113de4d67 first commit
kent <kent@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
663 indent_to (file, indent + 3);
a06113de4d67 first commit
kent <kent@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
664
a06113de4d67 first commit
kent <kent@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
665 if (TYPE_USER_ALIGN (node))
a06113de4d67 first commit
kent <kent@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
666 fprintf (file, " user");
a06113de4d67 first commit
kent <kent@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
667
111
kono
parents: 67
diff changeset
668 fprintf (file, " align:%d warn_if_not_align:%d symtab:%d alias-set "
kono
parents: 67
diff changeset
669 HOST_WIDE_INT_PRINT_DEC,
kono
parents: 67
diff changeset
670 TYPE_ALIGN (node), TYPE_WARN_IF_NOT_ALIGN (node),
kono
parents: 67
diff changeset
671 TYPE_SYMTAB_ADDRESS (node),
0
a06113de4d67 first commit
kent <kent@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
672 (HOST_WIDE_INT) TYPE_ALIAS_SET (node));
a06113de4d67 first commit
kent <kent@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
673
a06113de4d67 first commit
kent <kent@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
674 if (TYPE_STRUCTURAL_EQUALITY_P (node))
111
kono
parents: 67
diff changeset
675 fprintf (file, " structural-equality");
0
a06113de4d67 first commit
kent <kent@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
676 else
111
kono
parents: 67
diff changeset
677 dump_addr (file, " canonical-type ", TYPE_CANONICAL (node));
55
77e2b8dfacca update it from 4.4.3 to 4.5.0
ryoma <e075725@ie.u-ryukyu.ac.jp>
parents: 0
diff changeset
678
0
a06113de4d67 first commit
kent <kent@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
679 print_node (file, "attributes", TYPE_ATTRIBUTES (node), indent + 4);
a06113de4d67 first commit
kent <kent@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
680
a06113de4d67 first commit
kent <kent@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
681 if (INTEGRAL_TYPE_P (node) || code == REAL_TYPE
a06113de4d67 first commit
kent <kent@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
682 || code == FIXED_POINT_TYPE)
a06113de4d67 first commit
kent <kent@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
683 {
111
kono
parents: 67
diff changeset
684 fprintf (file, " precision:%d", TYPE_PRECISION (node));
0
a06113de4d67 first commit
kent <kent@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
685 print_node_brief (file, "min", TYPE_MIN_VALUE (node), indent + 4);
a06113de4d67 first commit
kent <kent@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
686 print_node_brief (file, "max", TYPE_MAX_VALUE (node), indent + 4);
a06113de4d67 first commit
kent <kent@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
687 }
a06113de4d67 first commit
kent <kent@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
688
a06113de4d67 first commit
kent <kent@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
689 if (code == ENUMERAL_TYPE)
a06113de4d67 first commit
kent <kent@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
690 print_node (file, "values", TYPE_VALUES (node), indent + 4);
a06113de4d67 first commit
kent <kent@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
691 else if (code == ARRAY_TYPE)
a06113de4d67 first commit
kent <kent@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
692 print_node (file, "domain", TYPE_DOMAIN (node), indent + 4);
a06113de4d67 first commit
kent <kent@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
693 else if (code == VECTOR_TYPE)
131
84e7813d76e9 gcc-8.2
mir3636
parents: 111
diff changeset
694 {
84e7813d76e9 gcc-8.2
mir3636
parents: 111
diff changeset
695 fprintf (file, " nunits:");
84e7813d76e9 gcc-8.2
mir3636
parents: 111
diff changeset
696 print_dec (TYPE_VECTOR_SUBPARTS (node), file);
84e7813d76e9 gcc-8.2
mir3636
parents: 111
diff changeset
697 }
0
a06113de4d67 first commit
kent <kent@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
698 else if (code == RECORD_TYPE
a06113de4d67 first commit
kent <kent@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
699 || code == UNION_TYPE
a06113de4d67 first commit
kent <kent@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
700 || code == QUAL_UNION_TYPE)
a06113de4d67 first commit
kent <kent@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
701 print_node (file, "fields", TYPE_FIELDS (node), indent + 4);
a06113de4d67 first commit
kent <kent@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
702 else if (code == FUNCTION_TYPE
a06113de4d67 first commit
kent <kent@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
703 || code == METHOD_TYPE)
a06113de4d67 first commit
kent <kent@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
704 {
a06113de4d67 first commit
kent <kent@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
705 if (TYPE_METHOD_BASETYPE (node))
a06113de4d67 first commit
kent <kent@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
706 print_node_brief (file, "method basetype",
a06113de4d67 first commit
kent <kent@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
707 TYPE_METHOD_BASETYPE (node), indent + 4);
a06113de4d67 first commit
kent <kent@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
708 print_node (file, "arg-types", TYPE_ARG_TYPES (node), indent + 4);
a06113de4d67 first commit
kent <kent@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
709 }
a06113de4d67 first commit
kent <kent@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
710 else if (code == OFFSET_TYPE)
a06113de4d67 first commit
kent <kent@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
711 print_node_brief (file, "basetype", TYPE_OFFSET_BASETYPE (node),
a06113de4d67 first commit
kent <kent@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
712 indent + 4);
a06113de4d67 first commit
kent <kent@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
713
a06113de4d67 first commit
kent <kent@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
714 if (TYPE_CONTEXT (node))
a06113de4d67 first commit
kent <kent@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
715 print_node_brief (file, "context", TYPE_CONTEXT (node), indent + 4);
a06113de4d67 first commit
kent <kent@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
716
a06113de4d67 first commit
kent <kent@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
717 lang_hooks.print_type (file, node, indent);
a06113de4d67 first commit
kent <kent@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
718
a06113de4d67 first commit
kent <kent@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
719 if (TYPE_POINTER_TO (node) || TREE_CHAIN (node))
a06113de4d67 first commit
kent <kent@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
720 indent_to (file, indent + 3);
a06113de4d67 first commit
kent <kent@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
721
a06113de4d67 first commit
kent <kent@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
722 print_node_brief (file, "pointer_to_this", TYPE_POINTER_TO (node),
a06113de4d67 first commit
kent <kent@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
723 indent + 4);
a06113de4d67 first commit
kent <kent@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
724 print_node_brief (file, "reference_to_this", TYPE_REFERENCE_TO (node),
a06113de4d67 first commit
kent <kent@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
725 indent + 4);
a06113de4d67 first commit
kent <kent@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
726 print_node_brief (file, "chain", TREE_CHAIN (node), indent + 4);
a06113de4d67 first commit
kent <kent@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
727 break;
a06113de4d67 first commit
kent <kent@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
728
a06113de4d67 first commit
kent <kent@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
729 case tcc_expression:
a06113de4d67 first commit
kent <kent@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
730 case tcc_comparison:
a06113de4d67 first commit
kent <kent@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
731 case tcc_unary:
a06113de4d67 first commit
kent <kent@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
732 case tcc_binary:
a06113de4d67 first commit
kent <kent@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
733 case tcc_reference:
a06113de4d67 first commit
kent <kent@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
734 case tcc_statement:
a06113de4d67 first commit
kent <kent@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
735 case tcc_vl_exp:
a06113de4d67 first commit
kent <kent@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
736 if (code == BIND_EXPR)
a06113de4d67 first commit
kent <kent@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
737 {
a06113de4d67 first commit
kent <kent@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
738 print_node (file, "vars", TREE_OPERAND (node, 0), indent + 4);
a06113de4d67 first commit
kent <kent@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
739 print_node (file, "body", TREE_OPERAND (node, 1), indent + 4);
a06113de4d67 first commit
kent <kent@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
740 print_node (file, "block", TREE_OPERAND (node, 2), indent + 4);
a06113de4d67 first commit
kent <kent@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
741 break;
a06113de4d67 first commit
kent <kent@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
742 }
a06113de4d67 first commit
kent <kent@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
743 if (code == CALL_EXPR)
a06113de4d67 first commit
kent <kent@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
744 {
a06113de4d67 first commit
kent <kent@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
745 call_expr_arg_iterator iter;
a06113de4d67 first commit
kent <kent@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
746 tree arg;
a06113de4d67 first commit
kent <kent@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
747 print_node (file, "fn", CALL_EXPR_FN (node), indent + 4);
a06113de4d67 first commit
kent <kent@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
748 print_node (file, "static_chain", CALL_EXPR_STATIC_CHAIN (node),
a06113de4d67 first commit
kent <kent@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
749 indent + 4);
a06113de4d67 first commit
kent <kent@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
750 i = 0;
a06113de4d67 first commit
kent <kent@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
751 FOR_EACH_CALL_EXPR_ARG (arg, iter, node)
a06113de4d67 first commit
kent <kent@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
752 {
111
kono
parents: 67
diff changeset
753 /* Buffer big enough to format a 32-bit UINT_MAX into, plus
kono
parents: 67
diff changeset
754 the text. */
kono
parents: 67
diff changeset
755 char temp[15];
kono
parents: 67
diff changeset
756 sprintf (temp, "arg:%u", i);
0
a06113de4d67 first commit
kent <kent@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
757 print_node (file, temp, arg, indent + 4);
a06113de4d67 first commit
kent <kent@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
758 i++;
a06113de4d67 first commit
kent <kent@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
759 }
a06113de4d67 first commit
kent <kent@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
760 }
a06113de4d67 first commit
kent <kent@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
761 else
a06113de4d67 first commit
kent <kent@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
762 {
a06113de4d67 first commit
kent <kent@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
763 len = TREE_OPERAND_LENGTH (node);
a06113de4d67 first commit
kent <kent@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
764
a06113de4d67 first commit
kent <kent@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
765 for (i = 0; i < len; i++)
a06113de4d67 first commit
kent <kent@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
766 {
111
kono
parents: 67
diff changeset
767 /* Buffer big enough to format a 32-bit UINT_MAX into, plus
kono
parents: 67
diff changeset
768 the text. */
kono
parents: 67
diff changeset
769 char temp[15];
55
77e2b8dfacca update it from 4.4.3 to 4.5.0
ryoma <e075725@ie.u-ryukyu.ac.jp>
parents: 0
diff changeset
770
111
kono
parents: 67
diff changeset
771 sprintf (temp, "arg:%d", i);
0
a06113de4d67 first commit
kent <kent@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
772 print_node (file, temp, TREE_OPERAND (node, i), indent + 4);
a06113de4d67 first commit
kent <kent@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
773 }
a06113de4d67 first commit
kent <kent@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
774 }
111
kono
parents: 67
diff changeset
775 if (CODE_CONTAINS_STRUCT (code, TS_COMMON))
kono
parents: 67
diff changeset
776 print_node (file, "chain", TREE_CHAIN (node), indent + 4);
0
a06113de4d67 first commit
kent <kent@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
777 break;
a06113de4d67 first commit
kent <kent@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
778
a06113de4d67 first commit
kent <kent@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
779 case tcc_constant:
a06113de4d67 first commit
kent <kent@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
780 case tcc_exceptional:
a06113de4d67 first commit
kent <kent@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
781 switch (code)
a06113de4d67 first commit
kent <kent@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
782 {
a06113de4d67 first commit
kent <kent@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
783 case INTEGER_CST:
a06113de4d67 first commit
kent <kent@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
784 if (TREE_OVERFLOW (node))
a06113de4d67 first commit
kent <kent@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
785 fprintf (file, " overflow");
a06113de4d67 first commit
kent <kent@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
786
a06113de4d67 first commit
kent <kent@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
787 fprintf (file, " ");
111
kono
parents: 67
diff changeset
788 print_dec (wi::to_wide (node), file, TYPE_SIGN (TREE_TYPE (node)));
0
a06113de4d67 first commit
kent <kent@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
789 break;
a06113de4d67 first commit
kent <kent@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
790
a06113de4d67 first commit
kent <kent@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
791 case REAL_CST:
131
84e7813d76e9 gcc-8.2
mir3636
parents: 111
diff changeset
792 print_real_cst (file, node, false);
0
a06113de4d67 first commit
kent <kent@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
793 break;
a06113de4d67 first commit
kent <kent@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
794
a06113de4d67 first commit
kent <kent@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
795 case FIXED_CST:
a06113de4d67 first commit
kent <kent@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
796 {
a06113de4d67 first commit
kent <kent@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
797 FIXED_VALUE_TYPE f;
a06113de4d67 first commit
kent <kent@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
798 char string[64];
a06113de4d67 first commit
kent <kent@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
799
a06113de4d67 first commit
kent <kent@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
800 if (TREE_OVERFLOW (node))
a06113de4d67 first commit
kent <kent@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
801 fprintf (file, " overflow");
a06113de4d67 first commit
kent <kent@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
802
a06113de4d67 first commit
kent <kent@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
803 f = TREE_FIXED_CST (node);
a06113de4d67 first commit
kent <kent@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
804 fixed_to_decimal (string, &f, sizeof (string));
a06113de4d67 first commit
kent <kent@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
805 fprintf (file, " %s", string);
a06113de4d67 first commit
kent <kent@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
806 }
a06113de4d67 first commit
kent <kent@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
807 break;
a06113de4d67 first commit
kent <kent@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
808
a06113de4d67 first commit
kent <kent@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
809 case VECTOR_CST:
a06113de4d67 first commit
kent <kent@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
810 {
131
84e7813d76e9 gcc-8.2
mir3636
parents: 111
diff changeset
811 /* Big enough for UINT_MAX plus the string below. */
111
kono
parents: 67
diff changeset
812 char buf[32];
0
a06113de4d67 first commit
kent <kent@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
813
131
84e7813d76e9 gcc-8.2
mir3636
parents: 111
diff changeset
814 fprintf (file, " npatterns:%u nelts-per-pattern:%u",
84e7813d76e9 gcc-8.2
mir3636
parents: 111
diff changeset
815 VECTOR_CST_NPATTERNS (node),
84e7813d76e9 gcc-8.2
mir3636
parents: 111
diff changeset
816 VECTOR_CST_NELTS_PER_PATTERN (node));
84e7813d76e9 gcc-8.2
mir3636
parents: 111
diff changeset
817 unsigned int count = vector_cst_encoded_nelts (node);
84e7813d76e9 gcc-8.2
mir3636
parents: 111
diff changeset
818 for (unsigned int i = 0; i < count; ++i)
0
a06113de4d67 first commit
kent <kent@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
819 {
131
84e7813d76e9 gcc-8.2
mir3636
parents: 111
diff changeset
820 sprintf (buf, "elt:%u: ", i);
84e7813d76e9 gcc-8.2
mir3636
parents: 111
diff changeset
821 print_node (file, buf, VECTOR_CST_ENCODED_ELT (node, i),
84e7813d76e9 gcc-8.2
mir3636
parents: 111
diff changeset
822 indent + 4);
0
a06113de4d67 first commit
kent <kent@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
823 }
a06113de4d67 first commit
kent <kent@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
824 }
a06113de4d67 first commit
kent <kent@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
825 break;
a06113de4d67 first commit
kent <kent@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
826
a06113de4d67 first commit
kent <kent@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
827 case COMPLEX_CST:
a06113de4d67 first commit
kent <kent@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
828 print_node (file, "real", TREE_REALPART (node), indent + 4);
a06113de4d67 first commit
kent <kent@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
829 print_node (file, "imag", TREE_IMAGPART (node), indent + 4);
a06113de4d67 first commit
kent <kent@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
830 break;
a06113de4d67 first commit
kent <kent@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
831
a06113de4d67 first commit
kent <kent@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
832 case STRING_CST:
a06113de4d67 first commit
kent <kent@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
833 {
a06113de4d67 first commit
kent <kent@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
834 const char *p = TREE_STRING_POINTER (node);
a06113de4d67 first commit
kent <kent@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
835 int i = TREE_STRING_LENGTH (node);
a06113de4d67 first commit
kent <kent@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
836 fputs (" \"", file);
a06113de4d67 first commit
kent <kent@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
837 while (--i >= 0)
a06113de4d67 first commit
kent <kent@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
838 {
a06113de4d67 first commit
kent <kent@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
839 char ch = *p++;
a06113de4d67 first commit
kent <kent@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
840 if (ch >= ' ' && ch < 127)
a06113de4d67 first commit
kent <kent@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
841 putc (ch, file);
a06113de4d67 first commit
kent <kent@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
842 else
111
kono
parents: 67
diff changeset
843 fprintf (file, "\\%03o", ch & 0xFF);
0
a06113de4d67 first commit
kent <kent@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
844 }
a06113de4d67 first commit
kent <kent@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
845 fputc ('\"', file);
a06113de4d67 first commit
kent <kent@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
846 }
a06113de4d67 first commit
kent <kent@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
847 break;
a06113de4d67 first commit
kent <kent@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
848
131
84e7813d76e9 gcc-8.2
mir3636
parents: 111
diff changeset
849 case POLY_INT_CST:
84e7813d76e9 gcc-8.2
mir3636
parents: 111
diff changeset
850 {
84e7813d76e9 gcc-8.2
mir3636
parents: 111
diff changeset
851 char buf[10];
84e7813d76e9 gcc-8.2
mir3636
parents: 111
diff changeset
852 for (unsigned int i = 0; i < NUM_POLY_INT_COEFFS; ++i)
84e7813d76e9 gcc-8.2
mir3636
parents: 111
diff changeset
853 {
84e7813d76e9 gcc-8.2
mir3636
parents: 111
diff changeset
854 snprintf (buf, sizeof (buf), "elt%u: ", i);
84e7813d76e9 gcc-8.2
mir3636
parents: 111
diff changeset
855 print_node (file, buf, POLY_INT_CST_COEFF (node, i),
84e7813d76e9 gcc-8.2
mir3636
parents: 111
diff changeset
856 indent + 4);
84e7813d76e9 gcc-8.2
mir3636
parents: 111
diff changeset
857 }
84e7813d76e9 gcc-8.2
mir3636
parents: 111
diff changeset
858 }
84e7813d76e9 gcc-8.2
mir3636
parents: 111
diff changeset
859 break;
84e7813d76e9 gcc-8.2
mir3636
parents: 111
diff changeset
860
0
a06113de4d67 first commit
kent <kent@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
861 case IDENTIFIER_NODE:
a06113de4d67 first commit
kent <kent@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
862 lang_hooks.print_identifier (file, node, indent);
a06113de4d67 first commit
kent <kent@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
863 break;
a06113de4d67 first commit
kent <kent@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
864
a06113de4d67 first commit
kent <kent@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
865 case TREE_LIST:
a06113de4d67 first commit
kent <kent@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
866 print_node (file, "purpose", TREE_PURPOSE (node), indent + 4);
a06113de4d67 first commit
kent <kent@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
867 print_node (file, "value", TREE_VALUE (node), indent + 4);
a06113de4d67 first commit
kent <kent@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
868 print_node (file, "chain", TREE_CHAIN (node), indent + 4);
a06113de4d67 first commit
kent <kent@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
869 break;
a06113de4d67 first commit
kent <kent@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
870
a06113de4d67 first commit
kent <kent@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
871 case TREE_VEC:
a06113de4d67 first commit
kent <kent@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
872 len = TREE_VEC_LENGTH (node);
111
kono
parents: 67
diff changeset
873 fprintf (file, " length:%d", len);
0
a06113de4d67 first commit
kent <kent@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
874 for (i = 0; i < len; i++)
a06113de4d67 first commit
kent <kent@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
875 if (TREE_VEC_ELT (node, i))
a06113de4d67 first commit
kent <kent@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
876 {
111
kono
parents: 67
diff changeset
877 /* Buffer big enough to format a 32-bit UINT_MAX into, plus
kono
parents: 67
diff changeset
878 the text. */
kono
parents: 67
diff changeset
879 char temp[15];
kono
parents: 67
diff changeset
880 sprintf (temp, "elt:%d", i);
67
f6334be47118 update gcc from gcc-4.6-20100522 to gcc-4.6-20110318
nobuyasu <dimolto@cr.ie.u-ryukyu.ac.jp>
parents: 63
diff changeset
881 print_node (file, temp, TREE_VEC_ELT (node, i), indent + 4);
0
a06113de4d67 first commit
kent <kent@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
882 }
a06113de4d67 first commit
kent <kent@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
883 break;
a06113de4d67 first commit
kent <kent@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
884
a06113de4d67 first commit
kent <kent@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
885 case CONSTRUCTOR:
a06113de4d67 first commit
kent <kent@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
886 {
a06113de4d67 first commit
kent <kent@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
887 unsigned HOST_WIDE_INT cnt;
a06113de4d67 first commit
kent <kent@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
888 tree index, value;
111
kono
parents: 67
diff changeset
889 len = CONSTRUCTOR_NELTS (node);
kono
parents: 67
diff changeset
890 fprintf (file, " length:%d", len);
0
a06113de4d67 first commit
kent <kent@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
891 FOR_EACH_CONSTRUCTOR_ELT (CONSTRUCTOR_ELTS (node),
a06113de4d67 first commit
kent <kent@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
892 cnt, index, value)
a06113de4d67 first commit
kent <kent@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
893 {
111
kono
parents: 67
diff changeset
894 print_node (file, "idx", index, indent + 4, false);
kono
parents: 67
diff changeset
895 print_node (file, "val", value, indent + 4, false);
0
a06113de4d67 first commit
kent <kent@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
896 }
a06113de4d67 first commit
kent <kent@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
897 }
a06113de4d67 first commit
kent <kent@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
898 break;
a06113de4d67 first commit
kent <kent@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
899
a06113de4d67 first commit
kent <kent@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
900 case STATEMENT_LIST:
a06113de4d67 first commit
kent <kent@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
901 dump_addr (file, " head ", node->stmt_list.head);
a06113de4d67 first commit
kent <kent@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
902 dump_addr (file, " tail ", node->stmt_list.tail);
a06113de4d67 first commit
kent <kent@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
903 fprintf (file, " stmts");
a06113de4d67 first commit
kent <kent@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
904 {
a06113de4d67 first commit
kent <kent@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
905 tree_stmt_iterator i;
a06113de4d67 first commit
kent <kent@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
906 for (i = tsi_start (node); !tsi_end_p (i); tsi_next (&i))
a06113de4d67 first commit
kent <kent@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
907 {
a06113de4d67 first commit
kent <kent@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
908 /* Not printing the addresses of the (not-a-tree)
a06113de4d67 first commit
kent <kent@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
909 'struct tree_stmt_list_node's. */
a06113de4d67 first commit
kent <kent@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
910 dump_addr (file, " ", tsi_stmt (i));
a06113de4d67 first commit
kent <kent@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
911 }
a06113de4d67 first commit
kent <kent@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
912 fprintf (file, "\n");
a06113de4d67 first commit
kent <kent@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
913 for (i = tsi_start (node); !tsi_end_p (i); tsi_next (&i))
a06113de4d67 first commit
kent <kent@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
914 {
a06113de4d67 first commit
kent <kent@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
915 /* Not printing the addresses of the (not-a-tree)
a06113de4d67 first commit
kent <kent@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
916 'struct tree_stmt_list_node's. */
a06113de4d67 first commit
kent <kent@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
917 print_node (file, "stmt", tsi_stmt (i), indent + 4);
a06113de4d67 first commit
kent <kent@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
918 }
a06113de4d67 first commit
kent <kent@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
919 }
a06113de4d67 first commit
kent <kent@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
920 break;
a06113de4d67 first commit
kent <kent@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
921
a06113de4d67 first commit
kent <kent@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
922 case BLOCK:
a06113de4d67 first commit
kent <kent@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
923 print_node (file, "vars", BLOCK_VARS (node), indent + 4);
a06113de4d67 first commit
kent <kent@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
924 print_node (file, "supercontext", BLOCK_SUPERCONTEXT (node),
a06113de4d67 first commit
kent <kent@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
925 indent + 4);
a06113de4d67 first commit
kent <kent@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
926 print_node (file, "subblocks", BLOCK_SUBBLOCKS (node), indent + 4);
a06113de4d67 first commit
kent <kent@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
927 print_node (file, "chain", BLOCK_CHAIN (node), indent + 4);
a06113de4d67 first commit
kent <kent@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
928 print_node (file, "abstract_origin",
a06113de4d67 first commit
kent <kent@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
929 BLOCK_ABSTRACT_ORIGIN (node), indent + 4);
a06113de4d67 first commit
kent <kent@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
930 break;
a06113de4d67 first commit
kent <kent@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
931
a06113de4d67 first commit
kent <kent@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
932 case SSA_NAME:
a06113de4d67 first commit
kent <kent@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
933 print_node_brief (file, "var", SSA_NAME_VAR (node), indent + 4);
111
kono
parents: 67
diff changeset
934 indent_to (file, indent + 4);
0
a06113de4d67 first commit
kent <kent@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
935 fprintf (file, "def_stmt ");
111
kono
parents: 67
diff changeset
936 {
kono
parents: 67
diff changeset
937 pretty_printer buffer;
kono
parents: 67
diff changeset
938 buffer.buffer->stream = file;
131
84e7813d76e9 gcc-8.2
mir3636
parents: 111
diff changeset
939 pp_gimple_stmt_1 (&buffer, SSA_NAME_DEF_STMT (node), indent + 4,
84e7813d76e9 gcc-8.2
mir3636
parents: 111
diff changeset
940 TDF_NONE);
111
kono
parents: 67
diff changeset
941 pp_flush (&buffer);
kono
parents: 67
diff changeset
942 }
0
a06113de4d67 first commit
kent <kent@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
943
a06113de4d67 first commit
kent <kent@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
944 indent_to (file, indent + 4);
111
kono
parents: 67
diff changeset
945 fprintf (file, "version:%u", SSA_NAME_VERSION (node));
0
a06113de4d67 first commit
kent <kent@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
946 if (SSA_NAME_OCCURS_IN_ABNORMAL_PHI (node))
a06113de4d67 first commit
kent <kent@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
947 fprintf (file, " in-abnormal-phi");
a06113de4d67 first commit
kent <kent@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
948 if (SSA_NAME_IN_FREE_LIST (node))
a06113de4d67 first commit
kent <kent@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
949 fprintf (file, " in-free-list");
a06113de4d67 first commit
kent <kent@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
950
55
77e2b8dfacca update it from 4.4.3 to 4.5.0
ryoma <e075725@ie.u-ryukyu.ac.jp>
parents: 0
diff changeset
951 if (SSA_NAME_PTR_INFO (node))
0
a06113de4d67 first commit
kent <kent@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
952 {
a06113de4d67 first commit
kent <kent@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
953 indent_to (file, indent + 3);
a06113de4d67 first commit
kent <kent@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
954 if (SSA_NAME_PTR_INFO (node))
a06113de4d67 first commit
kent <kent@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
955 dump_addr (file, " ptr-info ", SSA_NAME_PTR_INFO (node));
a06113de4d67 first commit
kent <kent@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
956 }
a06113de4d67 first commit
kent <kent@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
957 break;
a06113de4d67 first commit
kent <kent@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
958
a06113de4d67 first commit
kent <kent@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
959 case OMP_CLAUSE:
a06113de4d67 first commit
kent <kent@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
960 {
a06113de4d67 first commit
kent <kent@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
961 int i;
a06113de4d67 first commit
kent <kent@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
962 fprintf (file, " %s",
a06113de4d67 first commit
kent <kent@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
963 omp_clause_code_name[OMP_CLAUSE_CODE (node)]);
a06113de4d67 first commit
kent <kent@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
964 for (i = 0; i < omp_clause_num_ops[OMP_CLAUSE_CODE (node)]; i++)
a06113de4d67 first commit
kent <kent@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
965 {
a06113de4d67 first commit
kent <kent@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
966 indent_to (file, indent + 4);
111
kono
parents: 67
diff changeset
967 fprintf (file, "op-%d:", i);
0
a06113de4d67 first commit
kent <kent@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
968 print_node_brief (file, "", OMP_CLAUSE_OPERAND (node, i), 0);
a06113de4d67 first commit
kent <kent@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
969 }
a06113de4d67 first commit
kent <kent@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
970 }
a06113de4d67 first commit
kent <kent@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
971 break;
a06113de4d67 first commit
kent <kent@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
972
a06113de4d67 first commit
kent <kent@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
973 case OPTIMIZATION_NODE:
a06113de4d67 first commit
kent <kent@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
974 cl_optimization_print (file, indent + 4, TREE_OPTIMIZATION (node));
a06113de4d67 first commit
kent <kent@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
975 break;
a06113de4d67 first commit
kent <kent@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
976
a06113de4d67 first commit
kent <kent@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
977 case TARGET_OPTION_NODE:
a06113de4d67 first commit
kent <kent@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
978 cl_target_option_print (file, indent + 4, TREE_TARGET_OPTION (node));
a06113de4d67 first commit
kent <kent@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
979 break;
a06113de4d67 first commit
kent <kent@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
980 case IMPORTED_DECL:
111
kono
parents: 67
diff changeset
981 fprintf (file, " imported-declaration");
kono
parents: 67
diff changeset
982 print_node_brief (file, "associated-declaration",
0
a06113de4d67 first commit
kent <kent@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
983 IMPORTED_DECL_ASSOCIATED_DECL (node),
a06113de4d67 first commit
kent <kent@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
984 indent + 4);
a06113de4d67 first commit
kent <kent@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
985 break;
a06113de4d67 first commit
kent <kent@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
986
111
kono
parents: 67
diff changeset
987 case TREE_BINFO:
kono
parents: 67
diff changeset
988 fprintf (file, " bases:%d",
kono
parents: 67
diff changeset
989 vec_safe_length (BINFO_BASE_BINFOS (node)));
kono
parents: 67
diff changeset
990 print_node_brief (file, "offset", BINFO_OFFSET (node), indent + 4);
kono
parents: 67
diff changeset
991 print_node_brief (file, "virtuals", BINFO_VIRTUALS (node),
kono
parents: 67
diff changeset
992 indent + 4);
kono
parents: 67
diff changeset
993 print_node_brief (file, "inheritance-chain",
kono
parents: 67
diff changeset
994 BINFO_INHERITANCE_CHAIN (node),
kono
parents: 67
diff changeset
995 indent + 4);
kono
parents: 67
diff changeset
996 break;
kono
parents: 67
diff changeset
997
0
a06113de4d67 first commit
kent <kent@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
998 default:
a06113de4d67 first commit
kent <kent@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
999 if (EXCEPTIONAL_CLASS_P (node))
a06113de4d67 first commit
kent <kent@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
1000 lang_hooks.print_xnode (file, node, indent);
a06113de4d67 first commit
kent <kent@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
1001 break;
a06113de4d67 first commit
kent <kent@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
1002 }
a06113de4d67 first commit
kent <kent@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
1003
a06113de4d67 first commit
kent <kent@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
1004 break;
a06113de4d67 first commit
kent <kent@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
1005 }
a06113de4d67 first commit
kent <kent@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
1006
a06113de4d67 first commit
kent <kent@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
1007 if (EXPR_HAS_LOCATION (node))
a06113de4d67 first commit
kent <kent@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
1008 {
a06113de4d67 first commit
kent <kent@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
1009 expanded_location xloc = expand_location (EXPR_LOCATION (node));
a06113de4d67 first commit
kent <kent@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
1010 indent_to (file, indent+4);
a06113de4d67 first commit
kent <kent@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
1011 fprintf (file, "%s:%d:%d", xloc.file, xloc.line, xloc.column);
111
kono
parents: 67
diff changeset
1012
kono
parents: 67
diff changeset
1013 /* Print the range, if any */
kono
parents: 67
diff changeset
1014 source_range r = EXPR_LOCATION_RANGE (node);
kono
parents: 67
diff changeset
1015 if (r.m_start)
kono
parents: 67
diff changeset
1016 {
kono
parents: 67
diff changeset
1017 xloc = expand_location (r.m_start);
kono
parents: 67
diff changeset
1018 fprintf (file, " start: %s:%d:%d", xloc.file, xloc.line, xloc.column);
kono
parents: 67
diff changeset
1019 }
kono
parents: 67
diff changeset
1020 else
kono
parents: 67
diff changeset
1021 {
kono
parents: 67
diff changeset
1022 fprintf (file, " start: unknown");
kono
parents: 67
diff changeset
1023 }
kono
parents: 67
diff changeset
1024 if (r.m_finish)
kono
parents: 67
diff changeset
1025 {
kono
parents: 67
diff changeset
1026 xloc = expand_location (r.m_finish);
kono
parents: 67
diff changeset
1027 fprintf (file, " finish: %s:%d:%d", xloc.file, xloc.line, xloc.column);
kono
parents: 67
diff changeset
1028 }
kono
parents: 67
diff changeset
1029 else
kono
parents: 67
diff changeset
1030 {
kono
parents: 67
diff changeset
1031 fprintf (file, " finish: unknown");
kono
parents: 67
diff changeset
1032 }
0
a06113de4d67 first commit
kent <kent@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
1033 }
a06113de4d67 first commit
kent <kent@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
1034
a06113de4d67 first commit
kent <kent@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
1035 fprintf (file, ">");
a06113de4d67 first commit
kent <kent@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
1036 }
67
f6334be47118 update gcc from gcc-4.6-20100522 to gcc-4.6-20110318
nobuyasu <dimolto@cr.ie.u-ryukyu.ac.jp>
parents: 63
diff changeset
1037
145
1830386684a0 gcc-9.2.0
anatofuz
parents: 131
diff changeset
1038 /* Print the identifier for DECL according to FLAGS. */
1830386684a0 gcc-9.2.0
anatofuz
parents: 131
diff changeset
1039
1830386684a0 gcc-9.2.0
anatofuz
parents: 131
diff changeset
1040 void
1830386684a0 gcc-9.2.0
anatofuz
parents: 131
diff changeset
1041 print_decl_identifier (FILE *file, tree decl, int flags)
1830386684a0 gcc-9.2.0
anatofuz
parents: 131
diff changeset
1042 {
1830386684a0 gcc-9.2.0
anatofuz
parents: 131
diff changeset
1043 bool needs_colon = false;
1830386684a0 gcc-9.2.0
anatofuz
parents: 131
diff changeset
1044 const char *name;
1830386684a0 gcc-9.2.0
anatofuz
parents: 131
diff changeset
1045 char c;
1830386684a0 gcc-9.2.0
anatofuz
parents: 131
diff changeset
1046
1830386684a0 gcc-9.2.0
anatofuz
parents: 131
diff changeset
1047 if (flags & PRINT_DECL_ORIGIN)
1830386684a0 gcc-9.2.0
anatofuz
parents: 131
diff changeset
1048 {
1830386684a0 gcc-9.2.0
anatofuz
parents: 131
diff changeset
1049 if (DECL_IS_BUILTIN (decl))
1830386684a0 gcc-9.2.0
anatofuz
parents: 131
diff changeset
1050 fputs ("<built-in>", file);
1830386684a0 gcc-9.2.0
anatofuz
parents: 131
diff changeset
1051 else
1830386684a0 gcc-9.2.0
anatofuz
parents: 131
diff changeset
1052 {
1830386684a0 gcc-9.2.0
anatofuz
parents: 131
diff changeset
1053 expanded_location loc
1830386684a0 gcc-9.2.0
anatofuz
parents: 131
diff changeset
1054 = expand_location (DECL_SOURCE_LOCATION (decl));
1830386684a0 gcc-9.2.0
anatofuz
parents: 131
diff changeset
1055 fprintf (file, "%s:%d:%d", loc.file, loc.line, loc.column);
1830386684a0 gcc-9.2.0
anatofuz
parents: 131
diff changeset
1056 }
1830386684a0 gcc-9.2.0
anatofuz
parents: 131
diff changeset
1057 needs_colon = true;
1830386684a0 gcc-9.2.0
anatofuz
parents: 131
diff changeset
1058 }
1830386684a0 gcc-9.2.0
anatofuz
parents: 131
diff changeset
1059
1830386684a0 gcc-9.2.0
anatofuz
parents: 131
diff changeset
1060 if (flags & PRINT_DECL_UNIQUE_NAME)
1830386684a0 gcc-9.2.0
anatofuz
parents: 131
diff changeset
1061 {
1830386684a0 gcc-9.2.0
anatofuz
parents: 131
diff changeset
1062 name = IDENTIFIER_POINTER (DECL_ASSEMBLER_NAME (decl));
1830386684a0 gcc-9.2.0
anatofuz
parents: 131
diff changeset
1063 if (!TREE_PUBLIC (decl)
1830386684a0 gcc-9.2.0
anatofuz
parents: 131
diff changeset
1064 || (DECL_WEAK (decl) && !DECL_EXTERNAL (decl)))
1830386684a0 gcc-9.2.0
anatofuz
parents: 131
diff changeset
1065 /* The symbol has internal or weak linkage so its assembler name
1830386684a0 gcc-9.2.0
anatofuz
parents: 131
diff changeset
1066 is not necessarily unique among the compilation units of the
1830386684a0 gcc-9.2.0
anatofuz
parents: 131
diff changeset
1067 program. We therefore have to further mangle it. But we can't
1830386684a0 gcc-9.2.0
anatofuz
parents: 131
diff changeset
1068 simply use DECL_SOURCE_FILE because it contains the name of the
1830386684a0 gcc-9.2.0
anatofuz
parents: 131
diff changeset
1069 file the symbol originates from so, e.g. for function templates
1830386684a0 gcc-9.2.0
anatofuz
parents: 131
diff changeset
1070 in C++ where the templates are defined in a header file, we can
1830386684a0 gcc-9.2.0
anatofuz
parents: 131
diff changeset
1071 have symbols with the same assembler name and DECL_SOURCE_FILE.
1830386684a0 gcc-9.2.0
anatofuz
parents: 131
diff changeset
1072 That's why we use the name of the top-level source file of the
1830386684a0 gcc-9.2.0
anatofuz
parents: 131
diff changeset
1073 compilation unit. ??? Unnecessary for Ada. */
1830386684a0 gcc-9.2.0
anatofuz
parents: 131
diff changeset
1074 name = ACONCAT ((main_input_filename, ":", name, NULL));
1830386684a0 gcc-9.2.0
anatofuz
parents: 131
diff changeset
1075 }
1830386684a0 gcc-9.2.0
anatofuz
parents: 131
diff changeset
1076 else if (flags & PRINT_DECL_NAME)
1830386684a0 gcc-9.2.0
anatofuz
parents: 131
diff changeset
1077 {
1830386684a0 gcc-9.2.0
anatofuz
parents: 131
diff changeset
1078 /* We don't want to print the full qualified name because it can be long,
1830386684a0 gcc-9.2.0
anatofuz
parents: 131
diff changeset
1079 so we strip the scope prefix, but we may need to deal with the suffix
1830386684a0 gcc-9.2.0
anatofuz
parents: 131
diff changeset
1080 created by the compiler. */
1830386684a0 gcc-9.2.0
anatofuz
parents: 131
diff changeset
1081 const char *suffix = strchr (IDENTIFIER_POINTER (DECL_NAME (decl)), '.');
1830386684a0 gcc-9.2.0
anatofuz
parents: 131
diff changeset
1082 name = lang_hooks.decl_printable_name (decl, 2);
1830386684a0 gcc-9.2.0
anatofuz
parents: 131
diff changeset
1083 if (suffix)
1830386684a0 gcc-9.2.0
anatofuz
parents: 131
diff changeset
1084 {
1830386684a0 gcc-9.2.0
anatofuz
parents: 131
diff changeset
1085 const char *dot = strchr (name, '.');
1830386684a0 gcc-9.2.0
anatofuz
parents: 131
diff changeset
1086 while (dot && strcasecmp (dot, suffix) != 0)
1830386684a0 gcc-9.2.0
anatofuz
parents: 131
diff changeset
1087 {
1830386684a0 gcc-9.2.0
anatofuz
parents: 131
diff changeset
1088 name = dot + 1;
1830386684a0 gcc-9.2.0
anatofuz
parents: 131
diff changeset
1089 dot = strchr (name, '.');
1830386684a0 gcc-9.2.0
anatofuz
parents: 131
diff changeset
1090 }
1830386684a0 gcc-9.2.0
anatofuz
parents: 131
diff changeset
1091 }
1830386684a0 gcc-9.2.0
anatofuz
parents: 131
diff changeset
1092 else
1830386684a0 gcc-9.2.0
anatofuz
parents: 131
diff changeset
1093 {
1830386684a0 gcc-9.2.0
anatofuz
parents: 131
diff changeset
1094 const char *dot = strrchr (name, '.');
1830386684a0 gcc-9.2.0
anatofuz
parents: 131
diff changeset
1095 if (dot)
1830386684a0 gcc-9.2.0
anatofuz
parents: 131
diff changeset
1096 name = dot + 1;
1830386684a0 gcc-9.2.0
anatofuz
parents: 131
diff changeset
1097 }
1830386684a0 gcc-9.2.0
anatofuz
parents: 131
diff changeset
1098 }
1830386684a0 gcc-9.2.0
anatofuz
parents: 131
diff changeset
1099 else
1830386684a0 gcc-9.2.0
anatofuz
parents: 131
diff changeset
1100 return;
1830386684a0 gcc-9.2.0
anatofuz
parents: 131
diff changeset
1101
1830386684a0 gcc-9.2.0
anatofuz
parents: 131
diff changeset
1102 if (needs_colon)
1830386684a0 gcc-9.2.0
anatofuz
parents: 131
diff changeset
1103 fputc (':', file);
1830386684a0 gcc-9.2.0
anatofuz
parents: 131
diff changeset
1104
1830386684a0 gcc-9.2.0
anatofuz
parents: 131
diff changeset
1105 while ((c = *name++) != '\0')
1830386684a0 gcc-9.2.0
anatofuz
parents: 131
diff changeset
1106 {
1830386684a0 gcc-9.2.0
anatofuz
parents: 131
diff changeset
1107 /* Strip double-quotes because of VCG. */
1830386684a0 gcc-9.2.0
anatofuz
parents: 131
diff changeset
1108 if (c == '"')
1830386684a0 gcc-9.2.0
anatofuz
parents: 131
diff changeset
1109 continue;
1830386684a0 gcc-9.2.0
anatofuz
parents: 131
diff changeset
1110 fputc (c, file);
1830386684a0 gcc-9.2.0
anatofuz
parents: 131
diff changeset
1111 }
1830386684a0 gcc-9.2.0
anatofuz
parents: 131
diff changeset
1112 }
1830386684a0 gcc-9.2.0
anatofuz
parents: 131
diff changeset
1113
111
kono
parents: 67
diff changeset
1114
kono
parents: 67
diff changeset
1115 /* Print the node NODE on standard error, for debugging.
kono
parents: 67
diff changeset
1116 Most nodes referred to by this one are printed recursively
kono
parents: 67
diff changeset
1117 down to a depth of six. */
kono
parents: 67
diff changeset
1118
kono
parents: 67
diff changeset
1119 DEBUG_FUNCTION void
kono
parents: 67
diff changeset
1120 debug_tree (tree node)
kono
parents: 67
diff changeset
1121 {
kono
parents: 67
diff changeset
1122 table = new hash_set<tree> (HASH_SIZE);
kono
parents: 67
diff changeset
1123 print_node (stderr, "", node, 0);
kono
parents: 67
diff changeset
1124 delete table;
kono
parents: 67
diff changeset
1125 table = NULL;
kono
parents: 67
diff changeset
1126 putc ('\n', stderr);
kono
parents: 67
diff changeset
1127 }
kono
parents: 67
diff changeset
1128
kono
parents: 67
diff changeset
1129 DEBUG_FUNCTION void
kono
parents: 67
diff changeset
1130 debug_raw (const tree_node &ref)
kono
parents: 67
diff changeset
1131 {
kono
parents: 67
diff changeset
1132 debug_tree (const_cast <tree> (&ref));
kono
parents: 67
diff changeset
1133 }
kono
parents: 67
diff changeset
1134
kono
parents: 67
diff changeset
1135 DEBUG_FUNCTION void
kono
parents: 67
diff changeset
1136 debug_raw (const tree_node *ptr)
kono
parents: 67
diff changeset
1137 {
kono
parents: 67
diff changeset
1138 if (ptr)
kono
parents: 67
diff changeset
1139 debug_raw (*ptr);
kono
parents: 67
diff changeset
1140 else
kono
parents: 67
diff changeset
1141 fprintf (stderr, "<nil>\n");
kono
parents: 67
diff changeset
1142 }
kono
parents: 67
diff changeset
1143
kono
parents: 67
diff changeset
1144 static void
kono
parents: 67
diff changeset
1145 dump_tree_via_hooks (const tree_node *ptr, dump_flags_t options)
kono
parents: 67
diff changeset
1146 {
kono
parents: 67
diff changeset
1147 if (DECL_P (ptr))
kono
parents: 67
diff changeset
1148 lang_hooks.print_decl (stderr, const_cast <tree_node*> (ptr), 0);
kono
parents: 67
diff changeset
1149 else if (TYPE_P (ptr))
kono
parents: 67
diff changeset
1150 lang_hooks.print_type (stderr, const_cast <tree_node*> (ptr), 0);
kono
parents: 67
diff changeset
1151 else if (TREE_CODE (ptr) == IDENTIFIER_NODE)
kono
parents: 67
diff changeset
1152 lang_hooks.print_identifier (stderr, const_cast <tree_node*> (ptr), 0);
kono
parents: 67
diff changeset
1153 else
kono
parents: 67
diff changeset
1154 print_generic_expr (stderr, const_cast <tree_node*> (ptr), options);
kono
parents: 67
diff changeset
1155 fprintf (stderr, "\n");
kono
parents: 67
diff changeset
1156 }
67
f6334be47118 update gcc from gcc-4.6-20100522 to gcc-4.6-20110318
nobuyasu <dimolto@cr.ie.u-ryukyu.ac.jp>
parents: 63
diff changeset
1157
111
kono
parents: 67
diff changeset
1158 DEBUG_FUNCTION void
kono
parents: 67
diff changeset
1159 debug (const tree_node &ref)
kono
parents: 67
diff changeset
1160 {
131
84e7813d76e9 gcc-8.2
mir3636
parents: 111
diff changeset
1161 dump_tree_via_hooks (&ref, TDF_NONE);
111
kono
parents: 67
diff changeset
1162 }
kono
parents: 67
diff changeset
1163
kono
parents: 67
diff changeset
1164 DEBUG_FUNCTION void
kono
parents: 67
diff changeset
1165 debug (const tree_node *ptr)
kono
parents: 67
diff changeset
1166 {
kono
parents: 67
diff changeset
1167 if (ptr)
kono
parents: 67
diff changeset
1168 debug (*ptr);
kono
parents: 67
diff changeset
1169 else
kono
parents: 67
diff changeset
1170 fprintf (stderr, "<nil>\n");
kono
parents: 67
diff changeset
1171 }
kono
parents: 67
diff changeset
1172
kono
parents: 67
diff changeset
1173 DEBUG_FUNCTION void
kono
parents: 67
diff changeset
1174 debug_head (const tree_node &ref)
kono
parents: 67
diff changeset
1175 {
kono
parents: 67
diff changeset
1176 debug (ref);
kono
parents: 67
diff changeset
1177 }
kono
parents: 67
diff changeset
1178
kono
parents: 67
diff changeset
1179 DEBUG_FUNCTION void
kono
parents: 67
diff changeset
1180 debug_head (const tree_node *ptr)
kono
parents: 67
diff changeset
1181 {
kono
parents: 67
diff changeset
1182 if (ptr)
kono
parents: 67
diff changeset
1183 debug_head (*ptr);
kono
parents: 67
diff changeset
1184 else
kono
parents: 67
diff changeset
1185 fprintf (stderr, "<nil>\n");
kono
parents: 67
diff changeset
1186 }
kono
parents: 67
diff changeset
1187
kono
parents: 67
diff changeset
1188 DEBUG_FUNCTION void
kono
parents: 67
diff changeset
1189 debug_body (const tree_node &ref)
kono
parents: 67
diff changeset
1190 {
kono
parents: 67
diff changeset
1191 if (TREE_CODE (&ref) == FUNCTION_DECL)
131
84e7813d76e9 gcc-8.2
mir3636
parents: 111
diff changeset
1192 dump_function_to_file (const_cast <tree_node*> (&ref), stderr, TDF_NONE);
111
kono
parents: 67
diff changeset
1193 else
kono
parents: 67
diff changeset
1194 debug (ref);
kono
parents: 67
diff changeset
1195 }
kono
parents: 67
diff changeset
1196
kono
parents: 67
diff changeset
1197 DEBUG_FUNCTION void
kono
parents: 67
diff changeset
1198 debug_body (const tree_node *ptr)
kono
parents: 67
diff changeset
1199 {
kono
parents: 67
diff changeset
1200 if (ptr)
kono
parents: 67
diff changeset
1201 debug_body (*ptr);
kono
parents: 67
diff changeset
1202 else
kono
parents: 67
diff changeset
1203 fprintf (stderr, "<nil>\n");
kono
parents: 67
diff changeset
1204 }
kono
parents: 67
diff changeset
1205
kono
parents: 67
diff changeset
1206 /* Print the vector of trees VEC on standard error, for debugging.
kono
parents: 67
diff changeset
1207 Most nodes referred to by this one are printed recursively
kono
parents: 67
diff changeset
1208 down to a depth of six. */
kono
parents: 67
diff changeset
1209
kono
parents: 67
diff changeset
1210 DEBUG_FUNCTION void
kono
parents: 67
diff changeset
1211 debug_raw (vec<tree, va_gc> &ref)
67
f6334be47118 update gcc from gcc-4.6-20100522 to gcc-4.6-20110318
nobuyasu <dimolto@cr.ie.u-ryukyu.ac.jp>
parents: 63
diff changeset
1212 {
f6334be47118 update gcc from gcc-4.6-20100522 to gcc-4.6-20110318
nobuyasu <dimolto@cr.ie.u-ryukyu.ac.jp>
parents: 63
diff changeset
1213 tree elt;
f6334be47118 update gcc from gcc-4.6-20100522 to gcc-4.6-20110318
nobuyasu <dimolto@cr.ie.u-ryukyu.ac.jp>
parents: 63
diff changeset
1214 unsigned ix;
f6334be47118 update gcc from gcc-4.6-20100522 to gcc-4.6-20110318
nobuyasu <dimolto@cr.ie.u-ryukyu.ac.jp>
parents: 63
diff changeset
1215
111
kono
parents: 67
diff changeset
1216 /* Print the slot this node is in, and its code, and address. */
kono
parents: 67
diff changeset
1217 fprintf (stderr, "<VEC");
kono
parents: 67
diff changeset
1218 dump_addr (stderr, " ", ref.address ());
kono
parents: 67
diff changeset
1219
kono
parents: 67
diff changeset
1220 FOR_EACH_VEC_ELT (ref, ix, elt)
kono
parents: 67
diff changeset
1221 {
kono
parents: 67
diff changeset
1222 fprintf (stderr, "elt:%d ", ix);
kono
parents: 67
diff changeset
1223 debug_raw (elt);
kono
parents: 67
diff changeset
1224 }
kono
parents: 67
diff changeset
1225 }
kono
parents: 67
diff changeset
1226
kono
parents: 67
diff changeset
1227 DEBUG_FUNCTION void
kono
parents: 67
diff changeset
1228 debug_raw (vec<tree, va_gc> *ptr)
kono
parents: 67
diff changeset
1229 {
kono
parents: 67
diff changeset
1230 if (ptr)
kono
parents: 67
diff changeset
1231 debug_raw (*ptr);
kono
parents: 67
diff changeset
1232 else
kono
parents: 67
diff changeset
1233 fprintf (stderr, "<nil>\n");
kono
parents: 67
diff changeset
1234 }
kono
parents: 67
diff changeset
1235
131
84e7813d76e9 gcc-8.2
mir3636
parents: 111
diff changeset
1236 static void
84e7813d76e9 gcc-8.2
mir3636
parents: 111
diff changeset
1237 debug_slim (tree t)
111
kono
parents: 67
diff changeset
1238 {
131
84e7813d76e9 gcc-8.2
mir3636
parents: 111
diff changeset
1239 print_node_brief (stderr, "", t, 0);
111
kono
parents: 67
diff changeset
1240 }
131
84e7813d76e9 gcc-8.2
mir3636
parents: 111
diff changeset
1241
84e7813d76e9 gcc-8.2
mir3636
parents: 111
diff changeset
1242 DEFINE_DEBUG_VEC (tree)
84e7813d76e9 gcc-8.2
mir3636
parents: 111
diff changeset
1243 DEFINE_DEBUG_HASH_SET (tree)