import gdb-1999-05-25 snapshot
[deliverable/binutils-gdb.git] / gdb / c-lang.c
1 /* C language support routines for GDB, the GNU debugger.
2 Copyright 1992, 1993, 1994 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 "symtab.h"
22 #include "gdbtypes.h"
23 #include "expression.h"
24 #include "parser-defs.h"
25 #include "language.h"
26 #include "c-lang.h"
27
28 extern void _initialize_c_language PARAMS ((void));
29 static void c_emit_char PARAMS ((int c, GDB_FILE *stream, int quoter));
30
31 /* Print the character C on STREAM as part of the contents of a literal
32 string whose delimiter is QUOTER. Note that that format for printing
33 characters and strings is language specific. */
34
35 static void
36 c_emit_char (c, stream, quoter)
37 register int c;
38 GDB_FILE *stream;
39 int quoter;
40 {
41 c &= 0xFF; /* Avoid sign bit follies */
42
43 if (PRINT_LITERAL_FORM (c))
44 {
45 if (c == '\\' || c == quoter)
46 {
47 fputs_filtered ("\\", stream);
48 }
49 fprintf_filtered (stream, "%c", c);
50 }
51 else
52 {
53 switch (c)
54 {
55 case '\n':
56 fputs_filtered ("\\n", stream);
57 break;
58 case '\b':
59 fputs_filtered ("\\b", stream);
60 break;
61 case '\t':
62 fputs_filtered ("\\t", stream);
63 break;
64 case '\f':
65 fputs_filtered ("\\f", stream);
66 break;
67 case '\r':
68 fputs_filtered ("\\r", stream);
69 break;
70 case '\033':
71 fputs_filtered ("\\e", stream);
72 break;
73 case '\007':
74 fputs_filtered ("\\a", stream);
75 break;
76 default:
77 fprintf_filtered (stream, "\\%.3o", (unsigned int) c);
78 break;
79 }
80 }
81 }
82
83 void
84 c_printchar (c, stream)
85 int c;
86 GDB_FILE *stream;
87 {
88 fputc_filtered ('\'', stream);
89 LA_EMIT_CHAR (c, stream, '\'');
90 fputc_filtered ('\'', stream);
91 }
92
93 /* Print the character string STRING, printing at most LENGTH characters.
94 LENGTH is -1 if the string is nul terminated. Each character is WIDTH bytes
95 long. Printing stops early if the number hits print_max; repeat counts are
96 printed as appropriate. Print ellipses at the end if we had to stop before
97 printing LENGTH characters, or if FORCE_ELLIPSES. */
98
99 void
100 c_printstr (stream, string, length, width, force_ellipses)
101 GDB_FILE *stream;
102 char *string;
103 unsigned int length;
104 int width;
105 int force_ellipses;
106 {
107 register unsigned int i;
108 unsigned int things_printed = 0;
109 int in_quotes = 0;
110 int need_comma = 0;
111 extern int inspect_it;
112 extern int repeat_count_threshold;
113 extern int print_max;
114
115 /* If the string was not truncated due to `set print elements', and
116 the last byte of it is a null, we don't print that, in traditional C
117 style. */
118 if (!force_ellipses
119 && length > 0
120 && extract_unsigned_integer (string + (length - 1) * width, width) == '\0')
121 length--;
122
123 if (length == 0)
124 {
125 fputs_filtered ("\"\"", stream);
126 return;
127 }
128
129 for (i = 0; i < length && things_printed < print_max; ++i)
130 {
131 /* Position of the character we are examining
132 to see whether it is repeated. */
133 unsigned int rep1;
134 /* Number of repetitions we have detected so far. */
135 unsigned int reps;
136 unsigned long current_char;
137
138 QUIT;
139
140 if (need_comma)
141 {
142 fputs_filtered (", ", stream);
143 need_comma = 0;
144 }
145
146 current_char = extract_unsigned_integer (string + i * width, width);
147
148 rep1 = i + 1;
149 reps = 1;
150 while (rep1 < length
151 && extract_unsigned_integer (string + rep1 * width, width)
152 == current_char)
153 {
154 ++rep1;
155 ++reps;
156 }
157
158 if (reps > repeat_count_threshold)
159 {
160 if (in_quotes)
161 {
162 if (inspect_it)
163 fputs_filtered ("\\\", ", stream);
164 else
165 fputs_filtered ("\", ", stream);
166 in_quotes = 0;
167 }
168 LA_PRINT_CHAR (current_char, stream);
169 fprintf_filtered (stream, " <repeats %u times>", reps);
170 i = rep1 - 1;
171 things_printed += repeat_count_threshold;
172 need_comma = 1;
173 }
174 else
175 {
176 if (!in_quotes)
177 {
178 if (inspect_it)
179 fputs_filtered ("\\\"", stream);
180 else
181 fputs_filtered ("\"", stream);
182 in_quotes = 1;
183 }
184 LA_EMIT_CHAR (current_char, stream, '"');
185 ++things_printed;
186 }
187 }
188
189 /* Terminate the quotes if necessary. */
190 if (in_quotes)
191 {
192 if (inspect_it)
193 fputs_filtered ("\\\"", stream);
194 else
195 fputs_filtered ("\"", stream);
196 }
197
198 if (force_ellipses || i < length)
199 fputs_filtered ("...", stream);
200 }
201
202 /* Create a fundamental C type using default reasonable for the current
203 target machine.
204
205 Some object/debugging file formats (DWARF version 1, COFF, etc) do not
206 define fundamental types such as "int" or "double". Others (stabs or
207 DWARF version 2, etc) do define fundamental types. For the formats which
208 don't provide fundamental types, gdb can create such types using this
209 function.
210
211 FIXME: Some compilers distinguish explicitly signed integral types
212 (signed short, signed int, signed long) from "regular" integral types
213 (short, int, long) in the debugging information. There is some dis-
214 agreement as to how useful this feature is. In particular, gcc does
215 not support this. Also, only some debugging formats allow the
216 distinction to be passed on to a debugger. For now, we always just
217 use "short", "int", or "long" as the type name, for both the implicit
218 and explicitly signed types. This also makes life easier for the
219 gdb test suite since we don't have to account for the differences
220 in output depending upon what the compiler and debugging format
221 support. We will probably have to re-examine the issue when gdb
222 starts taking it's fundamental type information directly from the
223 debugging information supplied by the compiler. fnf@cygnus.com */
224
225 struct type *
226 c_create_fundamental_type (objfile, typeid)
227 struct objfile *objfile;
228 int typeid;
229 {
230 register struct type *type = NULL;
231
232 switch (typeid)
233 {
234 default:
235 /* FIXME: For now, if we are asked to produce a type not in this
236 language, create the equivalent of a C integer type with the
237 name "<?type?>". When all the dust settles from the type
238 reconstruction work, this should probably become an error. */
239 type = init_type (TYPE_CODE_INT,
240 TARGET_INT_BIT / TARGET_CHAR_BIT,
241 0, "<?type?>", objfile);
242 warning ("internal error: no C/C++ fundamental type %d", typeid);
243 break;
244 case FT_VOID:
245 type = init_type (TYPE_CODE_VOID,
246 TARGET_CHAR_BIT / TARGET_CHAR_BIT,
247 0, "void", objfile);
248 break;
249 case FT_BOOLEAN:
250 type = init_type (TYPE_CODE_BOOL,
251 TARGET_CHAR_BIT / TARGET_CHAR_BIT,
252 0, "bool", objfile);
253
254 break;
255 case FT_CHAR:
256 type = init_type (TYPE_CODE_INT,
257 TARGET_CHAR_BIT / TARGET_CHAR_BIT,
258 0, "char", objfile);
259 TYPE_FLAGS (type) |= TYPE_FLAG_NOSIGN;
260 break;
261 case FT_SIGNED_CHAR:
262 type = init_type (TYPE_CODE_INT,
263 TARGET_CHAR_BIT / TARGET_CHAR_BIT,
264 0, "signed char", objfile);
265 break;
266 case FT_UNSIGNED_CHAR:
267 type = init_type (TYPE_CODE_INT,
268 TARGET_CHAR_BIT / TARGET_CHAR_BIT,
269 TYPE_FLAG_UNSIGNED, "unsigned char", objfile);
270 break;
271 case FT_SHORT:
272 type = init_type (TYPE_CODE_INT,
273 TARGET_SHORT_BIT / TARGET_CHAR_BIT,
274 0, "short", objfile);
275 break;
276 case FT_SIGNED_SHORT:
277 type = init_type (TYPE_CODE_INT,
278 TARGET_SHORT_BIT / TARGET_CHAR_BIT,
279 0, "short", objfile); /* FIXME-fnf */
280 break;
281 case FT_UNSIGNED_SHORT:
282 type = init_type (TYPE_CODE_INT,
283 TARGET_SHORT_BIT / TARGET_CHAR_BIT,
284 TYPE_FLAG_UNSIGNED, "unsigned short", objfile);
285 break;
286 case FT_INTEGER:
287 type = init_type (TYPE_CODE_INT,
288 TARGET_INT_BIT / TARGET_CHAR_BIT,
289 0, "int", objfile);
290 break;
291 case FT_SIGNED_INTEGER:
292 type = init_type (TYPE_CODE_INT,
293 TARGET_INT_BIT / TARGET_CHAR_BIT,
294 0, "int", objfile); /* FIXME -fnf */
295 break;
296 case FT_UNSIGNED_INTEGER:
297 type = init_type (TYPE_CODE_INT,
298 TARGET_INT_BIT / TARGET_CHAR_BIT,
299 TYPE_FLAG_UNSIGNED, "unsigned int", objfile);
300 break;
301 case FT_LONG:
302 type = init_type (TYPE_CODE_INT,
303 TARGET_LONG_BIT / TARGET_CHAR_BIT,
304 0, "long", objfile);
305 break;
306 case FT_SIGNED_LONG:
307 type = init_type (TYPE_CODE_INT,
308 TARGET_LONG_BIT / TARGET_CHAR_BIT,
309 0, "long", objfile); /* FIXME -fnf */
310 break;
311 case FT_UNSIGNED_LONG:
312 type = init_type (TYPE_CODE_INT,
313 TARGET_LONG_BIT / TARGET_CHAR_BIT,
314 TYPE_FLAG_UNSIGNED, "unsigned long", objfile);
315 break;
316 case FT_LONG_LONG:
317 type = init_type (TYPE_CODE_INT,
318 TARGET_LONG_LONG_BIT / TARGET_CHAR_BIT,
319 0, "long long", objfile);
320 break;
321 case FT_SIGNED_LONG_LONG:
322 type = init_type (TYPE_CODE_INT,
323 TARGET_LONG_LONG_BIT / TARGET_CHAR_BIT,
324 0, "signed long long", objfile);
325 break;
326 case FT_UNSIGNED_LONG_LONG:
327 type = init_type (TYPE_CODE_INT,
328 TARGET_LONG_LONG_BIT / TARGET_CHAR_BIT,
329 TYPE_FLAG_UNSIGNED, "unsigned long long", objfile);
330 break;
331 case FT_FLOAT:
332 type = init_type (TYPE_CODE_FLT,
333 TARGET_FLOAT_BIT / TARGET_CHAR_BIT,
334 0, "float", objfile);
335 break;
336 case FT_DBL_PREC_FLOAT:
337 type = init_type (TYPE_CODE_FLT,
338 TARGET_DOUBLE_BIT / TARGET_CHAR_BIT,
339 0, "double", objfile);
340 break;
341 case FT_EXT_PREC_FLOAT:
342 type = init_type (TYPE_CODE_FLT,
343 TARGET_LONG_DOUBLE_BIT / TARGET_CHAR_BIT,
344 0, "long double", objfile);
345 break;
346 case FT_TEMPLATE_ARG:
347 type = init_type (TYPE_CODE_TEMPLATE_ARG,
348 0,
349 0, "<template arg>", objfile);
350
351 break;
352 }
353 return (type);
354 }
355
356 \f
357 /* Table mapping opcodes into strings for printing operators
358 and precedences of the operators. */
359
360 const struct op_print c_op_print_tab[] =
361 {
362 {",", BINOP_COMMA, PREC_COMMA, 0},
363 {"=", BINOP_ASSIGN, PREC_ASSIGN, 1},
364 {"||", BINOP_LOGICAL_OR, PREC_LOGICAL_OR, 0},
365 {"&&", BINOP_LOGICAL_AND, PREC_LOGICAL_AND, 0},
366 {"|", BINOP_BITWISE_IOR, PREC_BITWISE_IOR, 0},
367 {"^", BINOP_BITWISE_XOR, PREC_BITWISE_XOR, 0},
368 {"&", BINOP_BITWISE_AND, PREC_BITWISE_AND, 0},
369 {"==", BINOP_EQUAL, PREC_EQUAL, 0},
370 {"!=", BINOP_NOTEQUAL, PREC_EQUAL, 0},
371 {"<=", BINOP_LEQ, PREC_ORDER, 0},
372 {">=", BINOP_GEQ, PREC_ORDER, 0},
373 {">", BINOP_GTR, PREC_ORDER, 0},
374 {"<", BINOP_LESS, PREC_ORDER, 0},
375 {">>", BINOP_RSH, PREC_SHIFT, 0},
376 {"<<", BINOP_LSH, PREC_SHIFT, 0},
377 {"+", BINOP_ADD, PREC_ADD, 0},
378 {"-", BINOP_SUB, PREC_ADD, 0},
379 {"*", BINOP_MUL, PREC_MUL, 0},
380 {"/", BINOP_DIV, PREC_MUL, 0},
381 {"%", BINOP_REM, PREC_MUL, 0},
382 {"@", BINOP_REPEAT, PREC_REPEAT, 0},
383 {"-", UNOP_NEG, PREC_PREFIX, 0},
384 {"!", UNOP_LOGICAL_NOT, PREC_PREFIX, 0},
385 {"~", UNOP_COMPLEMENT, PREC_PREFIX, 0},
386 {"*", UNOP_IND, PREC_PREFIX, 0},
387 {"&", UNOP_ADDR, PREC_PREFIX, 0},
388 {"sizeof ", UNOP_SIZEOF, PREC_PREFIX, 0},
389 {"++", UNOP_PREINCREMENT, PREC_PREFIX, 0},
390 {"--", UNOP_PREDECREMENT, PREC_PREFIX, 0},
391 /* C++ */
392 {"::", BINOP_SCOPE, PREC_PREFIX, 0},
393 {NULL, 0, 0, 0}
394 };
395 \f
396 struct type ** CONST_PTR (c_builtin_types[]) =
397 {
398 &builtin_type_int,
399 &builtin_type_long,
400 &builtin_type_short,
401 &builtin_type_char,
402 &builtin_type_float,
403 &builtin_type_double,
404 &builtin_type_void,
405 &builtin_type_long_long,
406 &builtin_type_signed_char,
407 &builtin_type_unsigned_char,
408 &builtin_type_unsigned_short,
409 &builtin_type_unsigned_int,
410 &builtin_type_unsigned_long,
411 &builtin_type_unsigned_long_long,
412 &builtin_type_long_double,
413 &builtin_type_complex,
414 &builtin_type_double_complex,
415 0
416 };
417
418 const struct language_defn c_language_defn = {
419 "c", /* Language name */
420 language_c,
421 c_builtin_types,
422 range_check_off,
423 type_check_off,
424 c_parse,
425 c_error,
426 evaluate_subexp_standard,
427 c_printchar, /* Print a character constant */
428 c_printstr, /* Function to print string constant */
429 c_emit_char, /* Print a single char */
430 c_create_fundamental_type, /* Create fundamental type in this language */
431 c_print_type, /* Print a type using appropriate syntax */
432 c_val_print, /* Print a value using appropriate syntax */
433 c_value_print, /* Print a top-level value */
434 {"", "", "", ""}, /* Binary format info */
435 {"0%lo", "0", "o", ""}, /* Octal format info */
436 {"%ld", "", "d", ""}, /* Decimal format info */
437 {"0x%lx", "0x", "x", ""}, /* Hex format info */
438 c_op_print_tab, /* expression operators for printing */
439 1, /* c-style arrays */
440 0, /* String lower bound */
441 &builtin_type_char, /* Type of string elements */
442 LANG_MAGIC
443 };
444
445 struct type ** const (cplus_builtin_types[]) =
446 {
447 &builtin_type_int,
448 &builtin_type_long,
449 &builtin_type_short,
450 &builtin_type_char,
451 &builtin_type_float,
452 &builtin_type_double,
453 &builtin_type_void,
454 &builtin_type_long_long,
455 &builtin_type_signed_char,
456 &builtin_type_unsigned_char,
457 &builtin_type_unsigned_short,
458 &builtin_type_unsigned_int,
459 &builtin_type_unsigned_long,
460 &builtin_type_unsigned_long_long,
461 &builtin_type_long_double,
462 &builtin_type_complex,
463 &builtin_type_double_complex,
464 &builtin_type_bool,
465 0
466 };
467
468 const struct language_defn cplus_language_defn = {
469 "c++", /* Language name */
470 language_cplus,
471 cplus_builtin_types,
472 range_check_off,
473 type_check_off,
474 c_parse,
475 c_error,
476 evaluate_subexp_standard,
477 c_printchar, /* Print a character constant */
478 c_printstr, /* Function to print string constant */
479 c_emit_char, /* Print a single char */
480 c_create_fundamental_type, /* Create fundamental type in this language */
481 c_print_type, /* Print a type using appropriate syntax */
482 c_val_print, /* Print a value using appropriate syntax */
483 c_value_print, /* Print a top-level value */
484 {"", "", "", ""}, /* Binary format info */
485 {"0%lo", "0", "o", ""}, /* Octal format info */
486 {"%ld", "", "d", ""}, /* Decimal format info */
487 {"0x%lx", "0x", "x", ""}, /* Hex format info */
488 c_op_print_tab, /* expression operators for printing */
489 1, /* c-style arrays */
490 0, /* String lower bound */
491 &builtin_type_char, /* Type of string elements */
492 LANG_MAGIC
493 };
494
495 const struct language_defn asm_language_defn = {
496 "asm", /* Language name */
497 language_asm,
498 c_builtin_types,
499 range_check_off,
500 type_check_off,
501 c_parse,
502 c_error,
503 evaluate_subexp_standard,
504 c_printchar, /* Print a character constant */
505 c_printstr, /* Function to print string constant */
506 c_emit_char, /* Print a single char */
507 c_create_fundamental_type, /* Create fundamental type in this language */
508 c_print_type, /* Print a type using appropriate syntax */
509 c_val_print, /* Print a value using appropriate syntax */
510 c_value_print, /* Print a top-level value */
511 {"", "", "", ""}, /* Binary format info */
512 {"0%lo", "0", "o", ""}, /* Octal format info */
513 {"%ld", "", "d", ""}, /* Decimal format info */
514 {"0x%lx", "0x", "x", ""}, /* Hex format info */
515 c_op_print_tab, /* expression operators for printing */
516 1, /* c-style arrays */
517 0, /* String lower bound */
518 &builtin_type_char, /* Type of string elements */
519 LANG_MAGIC
520 };
521
522 void
523 _initialize_c_language ()
524 {
525 add_language (&c_language_defn);
526 add_language (&cplus_language_defn);
527 add_language (&asm_language_defn);
528 }
This page took 0.041228 seconds and 4 git commands to generate.