]> git.ipfire.org Git - thirdparty/binutils-gdb.git/blob - gdb/ch-typeprint.c
* config/sh/tm-sh.h (BELIEVE_PCC_PROMOTION): Define, so that
[thirdparty/binutils-gdb.git] / gdb / ch-typeprint.c
1 /* Support for printing Chill types for GDB, the GNU debugger.
2 Copyright 1986, 1988, 1989, 1991 Free Software Foundation, Inc.
3
4 This file is part of GDB.
5
6 This program is free software; you can redistribute it and/or modify
7 it under the terms of the GNU General Public License as published by
8 the Free Software Foundation; either version 2 of the License, or
9 (at your option) any later version.
10
11 This program is distributed in the hope that it will be useful,
12 but WITHOUT ANY WARRANTY; without even the implied warranty of
13 MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
14 GNU General Public License for more details.
15
16 You should have received a copy of the GNU General Public License
17 along with this program; if not, write to the Free Software
18 Foundation, Inc., 59 Temple Place - Suite 330, Boston, MA 02111-1307, USA. */
19
20 #include "defs.h"
21 #include "obstack.h"
22 #include "bfd.h" /* Binary File Description */
23 #include "symtab.h"
24 #include "gdbtypes.h"
25 #include "expression.h"
26 #include "value.h"
27 #include "gdbcore.h"
28 #include "target.h"
29 #include "command.h"
30 #include "gdbcmd.h"
31 #include "language.h"
32 #include "demangle.h"
33 #include "ch-lang.h"
34 #include "typeprint.h"
35
36 #include "gdb_string.h"
37 #include <errno.h>
38
39 static void
40 chill_type_print_base PARAMS ((struct type *, GDB_FILE *, int, int));
41
42 void
43 chill_print_type (type, varstring, stream, show, level)
44 struct type *type;
45 char *varstring;
46 GDB_FILE *stream;
47 int show;
48 int level;
49 {
50 if (varstring != NULL && *varstring != '\0')
51 {
52 fputs_filtered (varstring, stream);
53 fputs_filtered (" ", stream);
54 }
55 chill_type_print_base (type, stream, show, level);
56 }
57
58 /* Print the name of the type (or the ultimate pointer target,
59 function value or array element).
60
61 SHOW nonzero means don't print this type as just its name;
62 show its real definition even if it has a name.
63 SHOW zero means print just typename or tag if there is one
64 SHOW negative means abbreviate structure elements.
65 SHOW is decremented for printing of structure elements.
66
67 LEVEL is the depth to indent by.
68 We increase it for some recursive calls. */
69
70 static void
71 chill_type_print_base (type, stream, show, level)
72 struct type *type;
73 GDB_FILE *stream;
74 int show;
75 int level;
76 {
77 register int len;
78 register int i;
79 struct type *index_type;
80 struct type *range_type;
81 LONGEST low_bound;
82 LONGEST high_bound;
83
84 QUIT;
85
86 wrap_here (" ");
87 if (type == NULL)
88 {
89 fputs_filtered ("<type unknown>", stream);
90 return;
91 }
92
93 /* When SHOW is zero or less, and there is a valid type name, then always
94 just print the type name directly from the type. */
95
96 if ((show <= 0) && (TYPE_NAME (type) != NULL))
97 {
98 fputs_filtered (TYPE_NAME (type), stream);
99 return;
100 }
101
102 if (TYPE_CODE (type) != TYPE_CODE_TYPEDEF)
103 CHECK_TYPEDEF (type);
104
105 switch (TYPE_CODE (type))
106 {
107 case TYPE_CODE_TYPEDEF:
108 chill_type_print_base (TYPE_TARGET_TYPE (type), stream, 0, level);
109 break;
110 case TYPE_CODE_PTR:
111 if (TYPE_CODE (TYPE_TARGET_TYPE (type)) == TYPE_CODE_VOID)
112 {
113 fprintf_filtered (stream,
114 TYPE_NAME (type) ? TYPE_NAME (type) : "PTR");
115 break;
116 }
117 fprintf_filtered (stream, "REF ");
118 chill_type_print_base (TYPE_TARGET_TYPE (type), stream, 0, level);
119 break;
120
121 case TYPE_CODE_BOOL:
122 /* FIXME: we should probably just print the TYPE_NAME, in case
123 anyone ever fixes the compiler to give us the real names
124 in the presence of the chill equivalent of typedef (assuming
125 there is one). */
126 fprintf_filtered (stream,
127 TYPE_NAME (type) ? TYPE_NAME (type) : "BOOL");
128 break;
129
130 case TYPE_CODE_ARRAY:
131 fputs_filtered ("ARRAY (", stream);
132 range_type = TYPE_FIELD_TYPE (type, 0);
133 if (TYPE_CODE (range_type) != TYPE_CODE_RANGE)
134 chill_print_type (range_type, "", stream, 0, level);
135 else
136 {
137 index_type = TYPE_TARGET_TYPE (range_type);
138 low_bound = TYPE_FIELD_BITPOS (range_type, 0);
139 high_bound = TYPE_FIELD_BITPOS (range_type, 1);
140 print_type_scalar (index_type, low_bound, stream);
141 fputs_filtered (":", stream);
142 print_type_scalar (index_type, high_bound, stream);
143 }
144 fputs_filtered (") ", stream);
145 chill_print_type (TYPE_TARGET_TYPE (type), "", stream, 0, level);
146 break;
147
148 case TYPE_CODE_BITSTRING:
149 fprintf_filtered (stream, "BOOLS (%d)",
150 TYPE_FIELD_BITPOS (TYPE_FIELD_TYPE(type,0), 1) + 1);
151 break;
152
153 case TYPE_CODE_SET:
154 fputs_filtered ("POWERSET ", stream);
155 chill_print_type (TYPE_INDEX_TYPE (type), "", stream,
156 show - 1, level);
157 break;
158
159 case TYPE_CODE_STRING:
160 range_type = TYPE_FIELD_TYPE (type, 0);
161 index_type = TYPE_TARGET_TYPE (range_type);
162 high_bound = TYPE_FIELD_BITPOS (range_type, 1);
163 fputs_filtered ("CHARS (", stream);
164 print_type_scalar (index_type, high_bound + 1, stream);
165 fputs_filtered (")", stream);
166 break;
167
168 case TYPE_CODE_MEMBER:
169 fprintf_filtered (stream, "MEMBER ");
170 chill_type_print_base (TYPE_TARGET_TYPE (type), stream, 0, level);
171 break;
172 case TYPE_CODE_REF:
173 fprintf_filtered (stream, "/*LOC*/ ");
174 chill_type_print_base (TYPE_TARGET_TYPE (type), stream, show, level);
175 break;
176 case TYPE_CODE_FUNC:
177 fprintf_filtered (stream, "PROC (");
178 len = TYPE_NFIELDS (type);
179 for (i = 0; i < len; i++)
180 {
181 struct type *param_type = TYPE_FIELD_TYPE (type, i);
182 if (i > 0)
183 {
184 fputs_filtered (", ", stream);
185 wrap_here (" ");
186 }
187 if (TYPE_CODE (param_type) == TYPE_CODE_REF)
188 {
189 chill_type_print_base (TYPE_TARGET_TYPE (param_type),
190 stream, 0, level);
191 fputs_filtered (" LOC", stream);
192 }
193 else
194 chill_type_print_base (param_type, stream, show, level);
195 }
196 fprintf_filtered (stream, ")");
197 if (TYPE_CODE (TYPE_TARGET_TYPE (type)) != TYPE_CODE_VOID)
198 {
199 fputs_filtered (" RETURNS (", stream);
200 chill_type_print_base (TYPE_TARGET_TYPE (type), stream, 0, level);
201 fputs_filtered (")", stream);
202 }
203 break;
204
205 case TYPE_CODE_STRUCT:
206 if (chill_varying_type (type))
207 {
208 chill_type_print_base (TYPE_FIELD_TYPE (type, 1),
209 stream, 0, level);
210 fputs_filtered (" VARYING", stream);
211 }
212 else
213 {
214 fprintf_filtered (stream, "STRUCT ");
215
216 fprintf_filtered (stream, "(\n");
217 if ((TYPE_NFIELDS (type) == 0) && (TYPE_NFN_FIELDS (type) == 0))
218 {
219 if (TYPE_FLAGS (type) & TYPE_FLAG_STUB)
220 {
221 fprintfi_filtered (level + 4, stream, "<incomplete type>\n");
222 }
223 else
224 {
225 fprintfi_filtered (level + 4, stream, "<no data fields>\n");
226 }
227 }
228 else
229 {
230 len = TYPE_NFIELDS (type);
231 for (i = TYPE_N_BASECLASSES (type); i < len; i++)
232 {
233 struct type *field_type = TYPE_FIELD_TYPE (type, i);
234 QUIT;
235 print_spaces_filtered (level + 4, stream);
236 if (TYPE_CODE (field_type) == TYPE_CODE_UNION)
237 { int j; /* variant number */
238 fputs_filtered ("CASE OF\n", stream);
239 for (j = 0; j < TYPE_NFIELDS (field_type); j++)
240 { int k; /* variant field index */
241 struct type *variant_type
242 = TYPE_FIELD_TYPE (field_type, j);
243 int var_len = TYPE_NFIELDS (variant_type);
244 print_spaces_filtered (level + 4, stream);
245 if (strcmp (TYPE_FIELD_NAME (field_type, j),
246 "else") == 0)
247 fputs_filtered ("ELSE\n", stream);
248 else
249 fputs_filtered (":\n", stream);
250 if (TYPE_CODE (variant_type) != TYPE_CODE_STRUCT)
251 error ("variant record confusion");
252 for (k = 0; k < var_len; k++)
253 {
254 print_spaces_filtered (level + 8, stream);
255 chill_print_type (TYPE_FIELD_TYPE (variant_type, k),
256 TYPE_FIELD_NAME (variant_type, k),
257 stream, show - 1, level + 8);
258 if (k < (var_len - 1))
259 fputs_filtered (",", stream);
260 fputs_filtered ("\n", stream);
261 }
262 }
263 print_spaces_filtered (level + 4, stream);
264 fputs_filtered ("ESAC", stream);
265 }
266 else
267 chill_print_type (field_type,
268 TYPE_FIELD_NAME (type, i),
269 stream, show - 1, level + 4);
270 if (i < (len - 1))
271 {
272 fputs_filtered (",", stream);
273 }
274 fputs_filtered ("\n", stream);
275 }
276 }
277 fprintfi_filtered (level, stream, ")");
278 }
279 break;
280
281 case TYPE_CODE_RANGE:
282 {
283 struct type *target = TYPE_TARGET_TYPE (type);
284 if (target && TYPE_NAME (target))
285 fputs_filtered (TYPE_NAME (target), stream);
286 else
287 fputs_filtered ("RANGE", stream);
288 if (target == NULL)
289 target = builtin_type_long;
290 fputs_filtered (" (", stream);
291 print_type_scalar (target, TYPE_LOW_BOUND (type), stream);
292 fputs_filtered (":", stream);
293 print_type_scalar (target, TYPE_HIGH_BOUND (type), stream);
294 fputs_filtered (")", stream);
295 }
296 break;
297
298 case TYPE_CODE_ENUM:
299 {
300 register int lastval = 0;
301 fprintf_filtered (stream, "SET (");
302 len = TYPE_NFIELDS (type);
303 for (i = 0; i < len; i++)
304 {
305 QUIT;
306 if (i) fprintf_filtered (stream, ", ");
307 wrap_here (" ");
308 fputs_filtered (TYPE_FIELD_NAME (type, i), stream);
309 if (lastval != TYPE_FIELD_BITPOS (type, i))
310 {
311 fprintf_filtered (stream, " = %d", TYPE_FIELD_BITPOS (type, i));
312 lastval = TYPE_FIELD_BITPOS (type, i);
313 }
314 lastval++;
315 }
316 fprintf_filtered (stream, ")");
317 }
318 break;
319
320 case TYPE_CODE_VOID:
321 case TYPE_CODE_UNDEF:
322 case TYPE_CODE_ERROR:
323 case TYPE_CODE_UNION:
324 case TYPE_CODE_METHOD:
325 error ("missing language support in chill_type_print_base");
326 break;
327
328 default:
329
330 /* Handle types not explicitly handled by the other cases,
331 such as fundamental types. For these, just print whatever
332 the type name is, as recorded in the type itself. If there
333 is no type name, then complain. */
334
335 if (TYPE_NAME (type) != NULL)
336 {
337 fputs_filtered (TYPE_NAME (type), stream);
338 }
339 else
340 {
341 error ("Unrecognized type code (%d) in symbol table.",
342 TYPE_CODE (type));
343 }
344 break;
345 }
346 }