2012-03-02 Tom Tromey <tromey@redhat.com>
[deliverable/binutils-gdb.git] / gdb / c-lang.c
CommitLineData
c906108c 1/* C language support routines for GDB, the GNU debugger.
ce27fb25 2
0b302171
JB
3 Copyright (C) 1992-1996, 1998-2000, 2002-2005, 2007-2012 Free
4 Software Foundation, Inc.
c906108c 5
c5aa993b 6 This file is part of GDB.
c906108c 7
c5aa993b
JM
8 This program is free software; you can redistribute it and/or modify
9 it under the terms of the GNU General Public License as published by
a9762ec7 10 the Free Software Foundation; either version 3 of the License, or
c5aa993b 11 (at your option) any later version.
c906108c 12
c5aa993b
JM
13 This program is distributed in the hope that it will be useful,
14 but WITHOUT ANY WARRANTY; without even the implied warranty of
15 MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
16 GNU General Public License for more details.
c906108c 17
c5aa993b 18 You should have received a copy of the GNU General Public License
a9762ec7 19 along with this program. If not, see <http://www.gnu.org/licenses/>. */
c906108c
SS
20
21#include "defs.h"
22#include "symtab.h"
23#include "gdbtypes.h"
24#include "expression.h"
25#include "parser-defs.h"
26#include "language.h"
27#include "c-lang.h"
745b8ca0 28#include "valprint.h"
84f0252a
JB
29#include "macroscope.h"
30#include "gdb_assert.h"
234b45d4 31#include "charset.h"
a15ef5f5 32#include "gdb_string.h"
9a3d7dfd 33#include "demangle.h"
b18be20d 34#include "cp-abi.h"
1fcb5155 35#include "cp-support.h"
6c7a06a3
TT
36#include "gdb_obstack.h"
37#include <ctype.h>
621c8364 38#include "exceptions.h"
c906108c 39
a14ed312 40extern void _initialize_c_language (void);
6c7a06a3
TT
41
42/* Given a C string type, STR_TYPE, return the corresponding target
43 character set name. */
44
45static const char *
e17a4113 46charset_for_string_type (enum c_string_type str_type,
f870a310 47 struct gdbarch *gdbarch)
6c7a06a3
TT
48{
49 switch (str_type & ~C_CHAR)
50 {
51 case C_STRING:
f870a310 52 return target_charset (gdbarch);
6c7a06a3 53 case C_WIDE_STRING:
f870a310 54 return target_wide_charset (gdbarch);
6c7a06a3 55 case C_STRING_16:
b8899f2b 56 /* FIXME: UTF-16 is not always correct. */
f870a310 57 if (gdbarch_byte_order (gdbarch) == BFD_ENDIAN_BIG)
b8899f2b 58 return "UTF-16BE";
6c7a06a3 59 else
b8899f2b 60 return "UTF-16LE";
6c7a06a3 61 case C_STRING_32:
b8899f2b 62 /* FIXME: UTF-32 is not always correct. */
f870a310 63 if (gdbarch_byte_order (gdbarch) == BFD_ENDIAN_BIG)
b8899f2b 64 return "UTF-32BE";
6c7a06a3 65 else
b8899f2b 66 return "UTF-32LE";
6c7a06a3 67 }
9b20d036 68 internal_error (__FILE__, __LINE__, _("unhandled c_string_type"));
6c7a06a3
TT
69}
70
71/* Classify ELTTYPE according to what kind of character it is. Return
72 the enum constant representing the character type. Also set
73 *ENCODING to the name of the character set to use when converting
aff410f1
MS
74 characters of this type in target BYTE_ORDER to the host character
75 set. */
6c7a06a3
TT
76
77static enum c_string_type
f870a310 78classify_type (struct type *elttype, struct gdbarch *gdbarch,
e17a4113 79 const char **encoding)
6c7a06a3 80{
6c7a06a3
TT
81 enum c_string_type result;
82
85e306ed
TT
83 /* We loop because ELTTYPE may be a typedef, and we want to
84 successively peel each typedef until we reach a type we
85 understand. We don't use CHECK_TYPEDEF because that will strip
86 all typedefs at once -- but in C, wchar_t is itself a typedef, so
87 that would do the wrong thing. */
88 while (elttype)
6c7a06a3 89 {
0d5cff50 90 const char *name = TYPE_NAME (elttype);
6c7a06a3
TT
91
92 if (TYPE_CODE (elttype) == TYPE_CODE_CHAR || !name)
93 {
94 result = C_CHAR;
95 goto done;
96 }
97
98 if (!strcmp (name, "wchar_t"))
99 {
100 result = C_WIDE_CHAR;
101 goto done;
102 }
103
104 if (!strcmp (name, "char16_t"))
105 {
106 result = C_CHAR_16;
107 goto done;
108 }
109
110 if (!strcmp (name, "char32_t"))
111 {
112 result = C_CHAR_32;
113 goto done;
114 }
115
85e306ed
TT
116 if (TYPE_CODE (elttype) != TYPE_CODE_TYPEDEF)
117 break;
118
119 /* Call for side effects. */
120 check_typedef (elttype);
121
122 if (TYPE_TARGET_TYPE (elttype))
123 elttype = TYPE_TARGET_TYPE (elttype);
124 else
125 {
126 /* Perhaps check_typedef did not update the target type. In
127 this case, force the lookup again and hope it works out.
128 It never will for C, but it might for C++. */
129 CHECK_TYPEDEF (elttype);
130 }
6c7a06a3 131 }
6c7a06a3
TT
132
133 /* Punt. */
134 result = C_CHAR;
135
136 done:
e17a4113 137 if (encoding)
f870a310 138 *encoding = charset_for_string_type (result, gdbarch);
e17a4113 139
6c7a06a3
TT
140 return result;
141}
142
aff410f1
MS
143/* Print the character C on STREAM as part of the contents of a
144 literal string whose delimiter is QUOTER. Note that that format
145 for printing characters and strings is language specific. */
c906108c 146
6aecb9c2
JB
147void
148c_emit_char (int c, struct type *type,
149 struct ui_file *stream, int quoter)
c906108c 150{
6c7a06a3 151 const char *encoding;
234b45d4 152
f870a310 153 classify_type (type, get_type_arch (type), &encoding);
3b2b8fea 154 generic_emit_char (c, type, stream, quoter, encoding);
c906108c
SS
155}
156
157void
6c7a06a3 158c_printchar (int c, struct type *type, struct ui_file *stream)
c906108c 159{
6c7a06a3 160 enum c_string_type str_type;
6c7a06a3 161
f870a310 162 str_type = classify_type (type, get_type_arch (type), NULL);
6c7a06a3
TT
163 switch (str_type)
164 {
165 case C_CHAR:
166 break;
167 case C_WIDE_CHAR:
168 fputc_filtered ('L', stream);
169 break;
170 case C_CHAR_16:
171 fputc_filtered ('u', stream);
172 break;
173 case C_CHAR_32:
174 fputc_filtered ('U', stream);
175 break;
176 }
177
c906108c 178 fputc_filtered ('\'', stream);
6c7a06a3 179 LA_EMIT_CHAR (c, type, stream, '\'');
c906108c
SS
180 fputc_filtered ('\'', stream);
181}
182
aff410f1
MS
183/* Print the character string STRING, printing at most LENGTH
184 characters. LENGTH is -1 if the string is nul terminated. Each
185 character is WIDTH bytes long. Printing stops early if the number
186 hits print_max; repeat counts are printed as appropriate. Print
187 ellipses at the end if we had to stop before printing LENGTH
188 characters, or if FORCE_ELLIPSES. */
c906108c
SS
189
190void
aff410f1
MS
191c_printstr (struct ui_file *stream, struct type *type,
192 const gdb_byte *string, unsigned int length,
193 const char *user_encoding, int force_ellipses,
79a45b7d 194 const struct value_print_options *options)
c906108c 195{
3b2b8fea
TT
196 enum c_string_type str_type;
197 const char *type_encoding;
198 const char *encoding;
199
e17a4113 200 enum bfd_endian byte_order = gdbarch_byte_order (get_type_arch (type));
f86f5ca3 201 unsigned int i;
c906108c
SS
202 unsigned int things_printed = 0;
203 int in_quotes = 0;
204 int need_comma = 0;
6c7a06a3
TT
205 int width = TYPE_LENGTH (type);
206 struct obstack wchar_buf, output;
207 struct cleanup *cleanup;
6c7a06a3
TT
208 struct wchar_iterator *iter;
209 int finished = 0;
210 int need_escape = 0;
c906108c 211
f870a310
TT
212 str_type = (classify_type (type, get_type_arch (type), &type_encoding)
213 & ~C_CHAR);
6c7a06a3
TT
214 switch (str_type)
215 {
216 case C_STRING:
217 break;
218 case C_WIDE_STRING:
219 fputs_filtered ("L", stream);
220 break;
221 case C_STRING_16:
222 fputs_filtered ("u", stream);
223 break;
224 case C_STRING_32:
225 fputs_filtered ("U", stream);
226 break;
227 }
228
3b2b8fea 229 encoding = (user_encoding && *user_encoding) ? user_encoding : type_encoding;
6c7a06a3 230
3b2b8fea
TT
231 generic_printstr (stream, type, string, length, encoding, force_ellipses,
232 '"', 1, options);
c906108c 233}
ae6a3a4c
TJB
234
235/* Obtain a C string from the inferior storing it in a newly allocated
aff410f1
MS
236 buffer in BUFFER, which should be freed by the caller. If the in-
237 and out-parameter *LENGTH is specified at -1, the string is read
fbb8f299 238 until a null character of the appropriate width is found, otherwise
aff410f1
MS
239 the string is read to the length of characters specified. The size
240 of a character is determined by the length of the target type of
241 the pointer or array. If VALUE is an array with a known length,
242 the function will not read past the end of the array. On
243 completion, *LENGTH will be set to the size of the string read in
fbb8f299
PM
244 characters. (If a length of -1 is specified, the length returned
245 will not include the null character). CHARSET is always set to the
246 target charset. */
ae6a3a4c
TJB
247
248void
aff410f1
MS
249c_get_string (struct value *value, gdb_byte **buffer,
250 int *length, struct type **char_type,
251 const char **charset)
ae6a3a4c
TJB
252{
253 int err, width;
254 unsigned int fetchlimit;
255 struct type *type = check_typedef (value_type (value));
256 struct type *element_type = TYPE_TARGET_TYPE (type);
fbb8f299 257 int req_length = *length;
aff410f1
MS
258 enum bfd_endian byte_order
259 = gdbarch_byte_order (get_type_arch (type));
96c07c5b 260 enum c_string_type kind;
ae6a3a4c
TJB
261
262 if (element_type == NULL)
263 goto error;
264
265 if (TYPE_CODE (type) == TYPE_CODE_ARRAY)
266 {
aff410f1
MS
267 /* If we know the size of the array, we can use it as a limit on
268 the number of characters to be fetched. */
ae6a3a4c
TJB
269 if (TYPE_NFIELDS (type) == 1
270 && TYPE_CODE (TYPE_FIELD_TYPE (type, 0)) == TYPE_CODE_RANGE)
271 {
272 LONGEST low_bound, high_bound;
273
274 get_discrete_bounds (TYPE_FIELD_TYPE (type, 0),
275 &low_bound, &high_bound);
276 fetchlimit = high_bound - low_bound + 1;
277 }
278 else
279 fetchlimit = UINT_MAX;
280 }
281 else if (TYPE_CODE (type) == TYPE_CODE_PTR)
282 fetchlimit = UINT_MAX;
283 else
284 /* We work only with arrays and pointers. */
285 goto error;
286
96c07c5b 287 if (! c_textual_element_type (element_type, 0))
ae6a3a4c 288 goto error;
96c07c5b 289 kind = classify_type (element_type,
f870a310 290 get_type_arch (element_type),
96c07c5b 291 charset);
ae6a3a4c
TJB
292 width = TYPE_LENGTH (element_type);
293
aff410f1
MS
294 /* If the string lives in GDB's memory instead of the inferior's,
295 then we just need to copy it to BUFFER. Also, since such strings
296 are arrays with known size, FETCHLIMIT will hold the size of the
297 array. */
ae6a3a4c
TJB
298 if ((VALUE_LVAL (value) == not_lval
299 || VALUE_LVAL (value) == lval_internalvar)
300 && fetchlimit != UINT_MAX)
301 {
302 int i;
303 const gdb_byte *contents = value_contents (value);
304
fbb8f299
PM
305 /* If a length is specified, use that. */
306 if (*length >= 0)
307 i = *length;
308 else
309 /* Otherwise, look for a null character. */
310 for (i = 0; i < fetchlimit; i++)
aff410f1
MS
311 if (extract_unsigned_integer (contents + i * width,
312 width, byte_order) == 0)
fbb8f299
PM
313 break;
314
315 /* I is now either a user-defined length, the number of non-null
316 characters, or FETCHLIMIT. */
ae6a3a4c
TJB
317 *length = i * width;
318 *buffer = xmalloc (*length);
319 memcpy (*buffer, contents, *length);
320 err = 0;
321 }
322 else
323 {
621c8364
TT
324 CORE_ADDR addr = value_as_address (value);
325
326 err = read_string (addr, *length, width, fetchlimit,
327 byte_order, buffer, length);
ae6a3a4c
TJB
328 if (err)
329 {
8ea5dfdf 330 xfree (*buffer);
621c8364
TT
331 if (err == EIO)
332 throw_error (MEMORY_ERROR, "Address %s out of bounds",
333 paddress (get_type_arch (type), addr));
334 else
335 error (_("Error reading string from inferior: %s"),
336 safe_strerror (err));
ae6a3a4c
TJB
337 }
338 }
339
fbb8f299
PM
340 /* If the LENGTH is specified at -1, we want to return the string
341 length up to the terminating null character. If an actual length
342 was specified, we want to return the length of exactly what was
343 read. */
344 if (req_length == -1)
345 /* If the last character is null, subtract it from LENGTH. */
346 if (*length > 0
aff410f1
MS
347 && extract_unsigned_integer (*buffer + *length - width,
348 width, byte_order) == 0)
fbb8f299
PM
349 *length -= width;
350
351 /* The read_string function will return the number of bytes read.
352 If length returned from read_string was > 0, return the number of
353 characters read by dividing the number of bytes by width. */
354 if (*length != 0)
355 *length = *length / width;
ae6a3a4c 356
96c07c5b 357 *char_type = element_type;
ae6a3a4c
TJB
358
359 return;
360
361 error:
362 {
363 char *type_str;
364
365 type_str = type_to_string (type);
366 if (type_str)
367 {
368 make_cleanup (xfree, type_str);
369 error (_("Trying to read string with inappropriate type `%s'."),
370 type_str);
371 }
372 else
373 error (_("Trying to read string with inappropriate type."));
374 }
375}
376
c906108c 377\f
6c7a06a3
TT
378/* Evaluating C and C++ expressions. */
379
380/* Convert a UCN. The digits of the UCN start at P and extend no
381 farther than LIMIT. DEST_CHARSET is the name of the character set
382 into which the UCN should be converted. The results are written to
383 OUTPUT. LENGTH is the maximum length of the UCN, either 4 or 8.
384 Returns a pointer to just after the final digit of the UCN. */
385
386static char *
387convert_ucn (char *p, char *limit, const char *dest_charset,
388 struct obstack *output, int length)
389{
390 unsigned long result = 0;
391 gdb_byte data[4];
392 int i;
393
394 for (i = 0; i < length && p < limit && isxdigit (*p); ++i, ++p)
395 result = (result << 4) + host_hex_value (*p);
396
397 for (i = 3; i >= 0; --i)
398 {
399 data[i] = result & 0xff;
400 result >>= 8;
401 }
402
aff410f1
MS
403 convert_between_encodings ("UTF-32BE", dest_charset, data,
404 4, 4, output, translit_none);
6c7a06a3
TT
405
406 return p;
407}
408
409/* Emit a character, VALUE, which was specified numerically, to
410 OUTPUT. TYPE is the target character type. */
411
412static void
413emit_numeric_character (struct type *type, unsigned long value,
414 struct obstack *output)
415{
416 gdb_byte *buffer;
417
418 buffer = alloca (TYPE_LENGTH (type));
419 pack_long (buffer, type, value);
420 obstack_grow (output, buffer, TYPE_LENGTH (type));
421}
422
423/* Convert an octal escape sequence. TYPE is the target character
424 type. The digits of the escape sequence begin at P and extend no
425 farther than LIMIT. The result is written to OUTPUT. Returns a
426 pointer to just after the final digit of the escape sequence. */
427
428static char *
aff410f1
MS
429convert_octal (struct type *type, char *p,
430 char *limit, struct obstack *output)
6c7a06a3 431{
30b66ecc 432 int i;
6c7a06a3
TT
433 unsigned long value = 0;
434
30b66ecc
TT
435 for (i = 0;
436 i < 3 && p < limit && isdigit (*p) && *p != '8' && *p != '9';
437 ++i)
6c7a06a3
TT
438 {
439 value = 8 * value + host_hex_value (*p);
440 ++p;
441 }
442
443 emit_numeric_character (type, value, output);
444
445 return p;
446}
447
448/* Convert a hex escape sequence. TYPE is the target character type.
449 The digits of the escape sequence begin at P and extend no farther
450 than LIMIT. The result is written to OUTPUT. Returns a pointer to
451 just after the final digit of the escape sequence. */
452
453static char *
aff410f1
MS
454convert_hex (struct type *type, char *p,
455 char *limit, struct obstack *output)
6c7a06a3
TT
456{
457 unsigned long value = 0;
458
459 while (p < limit && isxdigit (*p))
460 {
461 value = 16 * value + host_hex_value (*p);
462 ++p;
463 }
464
465 emit_numeric_character (type, value, output);
466
467 return p;
468}
469
470#define ADVANCE \
471 do { \
472 ++p; \
473 if (p == limit) \
474 error (_("Malformed escape sequence")); \
475 } while (0)
476
477/* Convert an escape sequence to a target format. TYPE is the target
478 character type to use, and DEST_CHARSET is the name of the target
479 character set. The backslash of the escape sequence is at *P, and
480 the escape sequence will not extend past LIMIT. The results are
481 written to OUTPUT. Returns a pointer to just past the final
482 character of the escape sequence. */
483
484static char *
485convert_escape (struct type *type, const char *dest_charset,
486 char *p, char *limit, struct obstack *output)
487{
488 /* Skip the backslash. */
489 ADVANCE;
490
491 switch (*p)
492 {
493 case '\\':
494 obstack_1grow (output, '\\');
495 ++p;
496 break;
497
498 case 'x':
499 ADVANCE;
500 if (!isxdigit (*p))
501 error (_("\\x used with no following hex digits."));
502 p = convert_hex (type, p, limit, output);
503 break;
504
505 case '0':
506 case '1':
507 case '2':
508 case '3':
509 case '4':
510 case '5':
511 case '6':
512 case '7':
513 p = convert_octal (type, p, limit, output);
514 break;
515
516 case 'u':
517 case 'U':
518 {
519 int length = *p == 'u' ? 4 : 8;
c5504eaf 520
6c7a06a3
TT
521 ADVANCE;
522 if (!isxdigit (*p))
523 error (_("\\u used with no following hex digits"));
524 p = convert_ucn (p, limit, dest_charset, output, length);
525 }
526 }
527
528 return p;
529}
530
531/* Given a single string from a (C-specific) OP_STRING list, convert
532 it to a target string, handling escape sequences specially. The
533 output is written to OUTPUT. DATA is the input string, which has
534 length LEN. DEST_CHARSET is the name of the target character set,
535 and TYPE is the type of target character to use. */
536
537static void
538parse_one_string (struct obstack *output, char *data, int len,
539 const char *dest_charset, struct type *type)
540{
541 char *limit;
542
543 limit = data + len;
544
545 while (data < limit)
546 {
547 char *p = data;
c5504eaf 548
6c7a06a3
TT
549 /* Look for next escape, or the end of the input. */
550 while (p < limit && *p != '\\')
551 ++p;
552 /* If we saw a run of characters, convert them all. */
553 if (p > data)
554 convert_between_encodings (host_charset (), dest_charset,
aff410f1
MS
555 data, p - data, 1,
556 output, translit_none);
6c7a06a3
TT
557 /* If we saw an escape, convert it. */
558 if (p < limit)
559 p = convert_escape (type, dest_charset, p, limit, output);
560 data = p;
561 }
562}
563
564/* Expression evaluator for the C language family. Most operations
565 are delegated to evaluate_subexp_standard; see that function for a
566 description of the arguments. */
567
f4b8a18d 568struct value *
6c7a06a3
TT
569evaluate_subexp_c (struct type *expect_type, struct expression *exp,
570 int *pos, enum noside noside)
571{
572 enum exp_opcode op = exp->elts[*pos].opcode;
573
574 switch (op)
575 {
576 case OP_STRING:
577 {
578 int oplen, limit;
579 struct type *type;
580 struct obstack output;
581 struct cleanup *cleanup;
582 struct value *result;
583 enum c_string_type dest_type;
584 const char *dest_charset;
c50491a7 585 int satisfy_expected = 0;
6c7a06a3
TT
586
587 obstack_init (&output);
588 cleanup = make_cleanup_obstack_free (&output);
589
590 ++*pos;
591 oplen = longest_to_int (exp->elts[*pos].longconst);
592
593 ++*pos;
594 limit = *pos + BYTES_TO_EXP_ELEM (oplen + 1);
595 dest_type
596 = (enum c_string_type) longest_to_int (exp->elts[*pos].longconst);
597 switch (dest_type & ~C_CHAR)
598 {
599 case C_STRING:
d80b854b
UW
600 type = language_string_char_type (exp->language_defn,
601 exp->gdbarch);
6c7a06a3
TT
602 break;
603 case C_WIDE_STRING:
e6c014f2
UW
604 type = lookup_typename (exp->language_defn, exp->gdbarch,
605 "wchar_t", NULL, 0);
6c7a06a3
TT
606 break;
607 case C_STRING_16:
e6c014f2
UW
608 type = lookup_typename (exp->language_defn, exp->gdbarch,
609 "char16_t", NULL, 0);
6c7a06a3
TT
610 break;
611 case C_STRING_32:
e6c014f2
UW
612 type = lookup_typename (exp->language_defn, exp->gdbarch,
613 "char32_t", NULL, 0);
6c7a06a3
TT
614 break;
615 default:
9b20d036 616 internal_error (__FILE__, __LINE__, _("unhandled c_string_type"));
6c7a06a3 617 }
546e879e
TT
618
619 /* Ensure TYPE_LENGTH is valid for TYPE. */
620 check_typedef (type);
621
c50491a7
TT
622 /* If the caller expects an array of some integral type,
623 satisfy them. If something odder is expected, rely on the
624 caller to cast. */
625 if (expect_type && TYPE_CODE (expect_type) == TYPE_CODE_ARRAY)
626 {
627 struct type *element_type
628 = check_typedef (TYPE_TARGET_TYPE (expect_type));
629
630 if (TYPE_CODE (element_type) == TYPE_CODE_INT
631 || TYPE_CODE (element_type) == TYPE_CODE_CHAR)
632 {
633 type = element_type;
634 satisfy_expected = 1;
635 }
636 }
637
f870a310 638 dest_charset = charset_for_string_type (dest_type, exp->gdbarch);
6c7a06a3
TT
639
640 ++*pos;
641 while (*pos < limit)
642 {
643 int len;
644
645 len = longest_to_int (exp->elts[*pos].longconst);
646
647 ++*pos;
648 if (noside != EVAL_SKIP)
649 parse_one_string (&output, &exp->elts[*pos].string, len,
650 dest_charset, type);
651 *pos += BYTES_TO_EXP_ELEM (len);
652 }
653
654 /* Skip the trailing length and opcode. */
655 *pos += 2;
656
657 if (noside == EVAL_SKIP)
334cc82d
TT
658 {
659 /* Return a dummy value of the appropriate type. */
c50491a7
TT
660 if (expect_type != NULL)
661 result = allocate_value (expect_type);
662 else if ((dest_type & C_CHAR) != 0)
334cc82d
TT
663 result = allocate_value (type);
664 else
3b7538c0 665 result = value_cstring ("", 0, type);
334cc82d
TT
666 do_cleanups (cleanup);
667 return result;
668 }
6c7a06a3
TT
669
670 if ((dest_type & C_CHAR) != 0)
671 {
672 LONGEST value;
673
674 if (obstack_object_size (&output) != TYPE_LENGTH (type))
3e43a32a
MS
675 error (_("Could not convert character "
676 "constant to target character set"));
6c7a06a3
TT
677 value = unpack_long (type, obstack_base (&output));
678 result = value_from_longest (type, value);
679 }
680 else
681 {
682 int i;
c5504eaf 683
6c7a06a3
TT
684 /* Write the terminating character. */
685 for (i = 0; i < TYPE_LENGTH (type); ++i)
686 obstack_1grow (&output, 0);
c50491a7
TT
687
688 if (satisfy_expected)
689 {
690 LONGEST low_bound, high_bound;
691 int element_size = TYPE_LENGTH (type);
692
693 if (get_discrete_bounds (TYPE_INDEX_TYPE (expect_type),
694 &low_bound, &high_bound) < 0)
695 {
696 low_bound = 0;
697 high_bound = (TYPE_LENGTH (expect_type) / element_size) - 1;
698 }
699 if (obstack_object_size (&output) / element_size
700 > (high_bound - low_bound + 1))
701 error (_("Too many array elements"));
702
703 result = allocate_value (expect_type);
704 memcpy (value_contents_raw (result), obstack_base (&output),
705 obstack_object_size (&output));
706 }
707 else
708 result = value_cstring (obstack_base (&output),
709 obstack_object_size (&output),
710 type);
6c7a06a3
TT
711 }
712 do_cleanups (cleanup);
713 return result;
714 }
715 break;
716
717 default:
718 break;
719 }
720 return evaluate_subexp_standard (expect_type, exp, pos, noside);
721}
c5aa993b 722
84f0252a 723
84f0252a 724\f
c906108c
SS
725/* Table mapping opcodes into strings for printing operators
726 and precedences of the operators. */
727
728const struct op_print c_op_print_tab[] =
c5aa993b
JM
729{
730 {",", BINOP_COMMA, PREC_COMMA, 0},
731 {"=", BINOP_ASSIGN, PREC_ASSIGN, 1},
732 {"||", BINOP_LOGICAL_OR, PREC_LOGICAL_OR, 0},
733 {"&&", BINOP_LOGICAL_AND, PREC_LOGICAL_AND, 0},
734 {"|", BINOP_BITWISE_IOR, PREC_BITWISE_IOR, 0},
735 {"^", BINOP_BITWISE_XOR, PREC_BITWISE_XOR, 0},
736 {"&", BINOP_BITWISE_AND, PREC_BITWISE_AND, 0},
737 {"==", BINOP_EQUAL, PREC_EQUAL, 0},
738 {"!=", BINOP_NOTEQUAL, PREC_EQUAL, 0},
739 {"<=", BINOP_LEQ, PREC_ORDER, 0},
740 {">=", BINOP_GEQ, PREC_ORDER, 0},
741 {">", BINOP_GTR, PREC_ORDER, 0},
742 {"<", BINOP_LESS, PREC_ORDER, 0},
743 {">>", BINOP_RSH, PREC_SHIFT, 0},
744 {"<<", BINOP_LSH, PREC_SHIFT, 0},
745 {"+", BINOP_ADD, PREC_ADD, 0},
746 {"-", BINOP_SUB, PREC_ADD, 0},
747 {"*", BINOP_MUL, PREC_MUL, 0},
748 {"/", BINOP_DIV, PREC_MUL, 0},
749 {"%", BINOP_REM, PREC_MUL, 0},
750 {"@", BINOP_REPEAT, PREC_REPEAT, 0},
751 {"-", UNOP_NEG, PREC_PREFIX, 0},
752 {"!", UNOP_LOGICAL_NOT, PREC_PREFIX, 0},
753 {"~", UNOP_COMPLEMENT, PREC_PREFIX, 0},
754 {"*", UNOP_IND, PREC_PREFIX, 0},
755 {"&", UNOP_ADDR, PREC_PREFIX, 0},
756 {"sizeof ", UNOP_SIZEOF, PREC_PREFIX, 0},
757 {"++", UNOP_PREINCREMENT, PREC_PREFIX, 0},
758 {"--", UNOP_PREDECREMENT, PREC_PREFIX, 0},
c5aa993b 759 {NULL, 0, 0, 0}
c906108c
SS
760};
761\f
685419e2
AC
762enum c_primitive_types {
763 c_primitive_type_int,
764 c_primitive_type_long,
765 c_primitive_type_short,
766 c_primitive_type_char,
767 c_primitive_type_float,
768 c_primitive_type_double,
769 c_primitive_type_void,
770 c_primitive_type_long_long,
771 c_primitive_type_signed_char,
772 c_primitive_type_unsigned_char,
773 c_primitive_type_unsigned_short,
774 c_primitive_type_unsigned_int,
775 c_primitive_type_unsigned_long,
776 c_primitive_type_unsigned_long_long,
777 c_primitive_type_long_double,
778 c_primitive_type_complex,
779 c_primitive_type_double_complex,
213e4dc2
TJB
780 c_primitive_type_decfloat,
781 c_primitive_type_decdouble,
782 c_primitive_type_declong,
685419e2
AC
783 nr_c_primitive_types
784};
785
e9667a65 786void
685419e2
AC
787c_language_arch_info (struct gdbarch *gdbarch,
788 struct language_arch_info *lai)
789{
790 const struct builtin_type *builtin = builtin_type (gdbarch);
c5504eaf 791
e9667a65 792 lai->string_char_type = builtin->builtin_char;
685419e2
AC
793 lai->primitive_type_vector
794 = GDBARCH_OBSTACK_CALLOC (gdbarch, nr_c_primitive_types + 1,
795 struct type *);
796 lai->primitive_type_vector [c_primitive_type_int] = builtin->builtin_int;
797 lai->primitive_type_vector [c_primitive_type_long] = builtin->builtin_long;
798 lai->primitive_type_vector [c_primitive_type_short] = builtin->builtin_short;
799 lai->primitive_type_vector [c_primitive_type_char] = builtin->builtin_char;
800 lai->primitive_type_vector [c_primitive_type_float] = builtin->builtin_float;
801 lai->primitive_type_vector [c_primitive_type_double] = builtin->builtin_double;
802 lai->primitive_type_vector [c_primitive_type_void] = builtin->builtin_void;
803 lai->primitive_type_vector [c_primitive_type_long_long] = builtin->builtin_long_long;
804 lai->primitive_type_vector [c_primitive_type_signed_char] = builtin->builtin_signed_char;
805 lai->primitive_type_vector [c_primitive_type_unsigned_char] = builtin->builtin_unsigned_char;
806 lai->primitive_type_vector [c_primitive_type_unsigned_short] = builtin->builtin_unsigned_short;
807 lai->primitive_type_vector [c_primitive_type_unsigned_int] = builtin->builtin_unsigned_int;
808 lai->primitive_type_vector [c_primitive_type_unsigned_long] = builtin->builtin_unsigned_long;
809 lai->primitive_type_vector [c_primitive_type_unsigned_long_long] = builtin->builtin_unsigned_long_long;
810 lai->primitive_type_vector [c_primitive_type_long_double] = builtin->builtin_long_double;
811 lai->primitive_type_vector [c_primitive_type_complex] = builtin->builtin_complex;
812 lai->primitive_type_vector [c_primitive_type_double_complex] = builtin->builtin_double_complex;
213e4dc2
TJB
813 lai->primitive_type_vector [c_primitive_type_decfloat] = builtin->builtin_decfloat;
814 lai->primitive_type_vector [c_primitive_type_decdouble] = builtin->builtin_decdouble;
815 lai->primitive_type_vector [c_primitive_type_declong] = builtin->builtin_declong;
fbb06eb1
UW
816
817 lai->bool_type_default = builtin->builtin_int;
cad351d1 818}
685419e2 819
6aecb9c2 820const struct exp_descriptor exp_descriptor_c =
6c7a06a3
TT
821{
822 print_subexp_standard,
823 operator_length_standard,
c0201579 824 operator_check_standard,
6c7a06a3
TT
825 op_name_standard,
826 dump_subexp_body_standard,
827 evaluate_subexp_c
828};
829
c5aa993b
JM
830const struct language_defn c_language_defn =
831{
c906108c
SS
832 "c", /* Language name */
833 language_c,
c906108c
SS
834 range_check_off,
835 type_check_off,
63872f9d 836 case_sensitive_on,
7ca2d3a3 837 array_row_major,
9a044a89 838 macro_expansion_c,
6c7a06a3 839 &exp_descriptor_c,
7c8adf68 840 c_parse,
c906108c 841 c_error,
e85c3284 842 null_post_parser,
c906108c
SS
843 c_printchar, /* Print a character constant */
844 c_printstr, /* Function to print string constant */
845 c_emit_char, /* Print a single char */
c906108c 846 c_print_type, /* Print a type using appropriate syntax */
5c6ce71d 847 c_print_typedef, /* Print a typedef using appropriate syntax */
c906108c
SS
848 c_val_print, /* Print a value using appropriate syntax */
849 c_value_print, /* Print a top-level value */
f636b87d 850 NULL, /* Language specific skip_trampoline */
2b2d9e11 851 NULL, /* name_of_this */
5f9a71c3 852 basic_lookup_symbol_nonlocal, /* lookup_symbol_nonlocal */
b368761e 853 basic_lookup_transparent_type,/* lookup_transparent_type */
9a3d7dfd 854 NULL, /* Language specific symbol demangler */
aff410f1
MS
855 NULL, /* Language specific
856 class_name_from_physname */
c906108c
SS
857 c_op_print_tab, /* expression operators for printing */
858 1, /* c-style arrays */
859 0, /* String lower bound */
6084f43a 860 default_word_break_characters,
41d27058 861 default_make_symbol_completion_list,
685419e2 862 c_language_arch_info,
e79af960 863 default_print_array_index,
41f1b697 864 default_pass_by_reference,
ae6a3a4c 865 c_get_string,
1a119f36 866 NULL, /* la_get_symbol_name_cmp */
f8eba3c6 867 iterate_over_symbols,
c906108c
SS
868 LANG_MAGIC
869};
870
cad351d1
UW
871enum cplus_primitive_types {
872 cplus_primitive_type_int,
873 cplus_primitive_type_long,
874 cplus_primitive_type_short,
875 cplus_primitive_type_char,
876 cplus_primitive_type_float,
877 cplus_primitive_type_double,
878 cplus_primitive_type_void,
879 cplus_primitive_type_long_long,
880 cplus_primitive_type_signed_char,
881 cplus_primitive_type_unsigned_char,
882 cplus_primitive_type_unsigned_short,
883 cplus_primitive_type_unsigned_int,
884 cplus_primitive_type_unsigned_long,
885 cplus_primitive_type_unsigned_long_long,
886 cplus_primitive_type_long_double,
887 cplus_primitive_type_complex,
888 cplus_primitive_type_double_complex,
889 cplus_primitive_type_bool,
213e4dc2
TJB
890 cplus_primitive_type_decfloat,
891 cplus_primitive_type_decdouble,
892 cplus_primitive_type_declong,
cad351d1 893 nr_cplus_primitive_types
c906108c
SS
894};
895
cad351d1
UW
896static void
897cplus_language_arch_info (struct gdbarch *gdbarch,
898 struct language_arch_info *lai)
899{
900 const struct builtin_type *builtin = builtin_type (gdbarch);
c5504eaf 901
cad351d1
UW
902 lai->string_char_type = builtin->builtin_char;
903 lai->primitive_type_vector
904 = GDBARCH_OBSTACK_CALLOC (gdbarch, nr_cplus_primitive_types + 1,
905 struct type *);
906 lai->primitive_type_vector [cplus_primitive_type_int]
907 = builtin->builtin_int;
908 lai->primitive_type_vector [cplus_primitive_type_long]
909 = builtin->builtin_long;
910 lai->primitive_type_vector [cplus_primitive_type_short]
911 = builtin->builtin_short;
912 lai->primitive_type_vector [cplus_primitive_type_char]
913 = builtin->builtin_char;
914 lai->primitive_type_vector [cplus_primitive_type_float]
915 = builtin->builtin_float;
916 lai->primitive_type_vector [cplus_primitive_type_double]
917 = builtin->builtin_double;
918 lai->primitive_type_vector [cplus_primitive_type_void]
919 = builtin->builtin_void;
920 lai->primitive_type_vector [cplus_primitive_type_long_long]
921 = builtin->builtin_long_long;
922 lai->primitive_type_vector [cplus_primitive_type_signed_char]
923 = builtin->builtin_signed_char;
924 lai->primitive_type_vector [cplus_primitive_type_unsigned_char]
925 = builtin->builtin_unsigned_char;
926 lai->primitive_type_vector [cplus_primitive_type_unsigned_short]
927 = builtin->builtin_unsigned_short;
928 lai->primitive_type_vector [cplus_primitive_type_unsigned_int]
929 = builtin->builtin_unsigned_int;
930 lai->primitive_type_vector [cplus_primitive_type_unsigned_long]
931 = builtin->builtin_unsigned_long;
932 lai->primitive_type_vector [cplus_primitive_type_unsigned_long_long]
933 = builtin->builtin_unsigned_long_long;
934 lai->primitive_type_vector [cplus_primitive_type_long_double]
935 = builtin->builtin_long_double;
936 lai->primitive_type_vector [cplus_primitive_type_complex]
937 = builtin->builtin_complex;
938 lai->primitive_type_vector [cplus_primitive_type_double_complex]
939 = builtin->builtin_double_complex;
940 lai->primitive_type_vector [cplus_primitive_type_bool]
941 = builtin->builtin_bool;
213e4dc2
TJB
942 lai->primitive_type_vector [cplus_primitive_type_decfloat]
943 = builtin->builtin_decfloat;
944 lai->primitive_type_vector [cplus_primitive_type_decdouble]
945 = builtin->builtin_decdouble;
946 lai->primitive_type_vector [cplus_primitive_type_declong]
947 = builtin->builtin_declong;
fbb06eb1
UW
948
949 lai->bool_type_symbol = "bool";
950 lai->bool_type_default = builtin->builtin_bool;
cad351d1
UW
951}
952
c5aa993b
JM
953const struct language_defn cplus_language_defn =
954{
955 "c++", /* Language name */
c906108c 956 language_cplus,
c906108c
SS
957 range_check_off,
958 type_check_off,
63872f9d 959 case_sensitive_on,
7ca2d3a3 960 array_row_major,
9a044a89 961 macro_expansion_c,
6c7a06a3 962 &exp_descriptor_c,
7c8adf68 963 c_parse,
c906108c 964 c_error,
e85c3284 965 null_post_parser,
c906108c
SS
966 c_printchar, /* Print a character constant */
967 c_printstr, /* Function to print string constant */
968 c_emit_char, /* Print a single char */
c906108c 969 c_print_type, /* Print a type using appropriate syntax */
5c6ce71d 970 c_print_typedef, /* Print a typedef using appropriate syntax */
c906108c
SS
971 c_val_print, /* Print a value using appropriate syntax */
972 c_value_print, /* Print a top-level value */
b18be20d 973 cplus_skip_trampoline, /* Language specific skip_trampoline */
2b2d9e11 974 "this", /* name_of_this */
1fcb5155 975 cp_lookup_symbol_nonlocal, /* lookup_symbol_nonlocal */
b368761e 976 cp_lookup_transparent_type, /* lookup_transparent_type */
9a3d7dfd 977 cplus_demangle, /* Language specific symbol demangler */
aff410f1
MS
978 cp_class_name_from_physname, /* Language specific
979 class_name_from_physname */
c906108c
SS
980 c_op_print_tab, /* expression operators for printing */
981 1, /* c-style arrays */
982 0, /* String lower bound */
6084f43a 983 default_word_break_characters,
41d27058 984 default_make_symbol_completion_list,
cad351d1 985 cplus_language_arch_info,
e79af960 986 default_print_array_index,
41f1b697 987 cp_pass_by_reference,
ae6a3a4c 988 c_get_string,
1a119f36 989 NULL, /* la_get_symbol_name_cmp */
f8eba3c6 990 iterate_over_symbols,
c906108c
SS
991 LANG_MAGIC
992};
993
c5aa993b
JM
994const struct language_defn asm_language_defn =
995{
c906108c
SS
996 "asm", /* Language name */
997 language_asm,
c906108c
SS
998 range_check_off,
999 type_check_off,
63872f9d 1000 case_sensitive_on,
7ca2d3a3 1001 array_row_major,
9a044a89 1002 macro_expansion_c,
6c7a06a3 1003 &exp_descriptor_c,
7c8adf68 1004 c_parse,
c906108c 1005 c_error,
e85c3284 1006 null_post_parser,
c906108c
SS
1007 c_printchar, /* Print a character constant */
1008 c_printstr, /* Function to print string constant */
1009 c_emit_char, /* Print a single char */
c906108c 1010 c_print_type, /* Print a type using appropriate syntax */
5c6ce71d 1011 c_print_typedef, /* Print a typedef using appropriate syntax */
c906108c
SS
1012 c_val_print, /* Print a value using appropriate syntax */
1013 c_value_print, /* Print a top-level value */
f636b87d 1014 NULL, /* Language specific skip_trampoline */
2b2d9e11 1015 NULL, /* name_of_this */
5f9a71c3 1016 basic_lookup_symbol_nonlocal, /* lookup_symbol_nonlocal */
b368761e 1017 basic_lookup_transparent_type,/* lookup_transparent_type */
9a3d7dfd 1018 NULL, /* Language specific symbol demangler */
aff410f1
MS
1019 NULL, /* Language specific
1020 class_name_from_physname */
c906108c
SS
1021 c_op_print_tab, /* expression operators for printing */
1022 1, /* c-style arrays */
1023 0, /* String lower bound */
6084f43a 1024 default_word_break_characters,
41d27058 1025 default_make_symbol_completion_list,
aff410f1 1026 c_language_arch_info, /* FIXME: la_language_arch_info. */
e79af960 1027 default_print_array_index,
41f1b697 1028 default_pass_by_reference,
ae6a3a4c 1029 c_get_string,
1a119f36 1030 NULL, /* la_get_symbol_name_cmp */
f8eba3c6 1031 iterate_over_symbols,
c906108c
SS
1032 LANG_MAGIC
1033};
1034
20a0e81d
JB
1035/* The following language_defn does not represent a real language.
1036 It just provides a minimal support a-la-C that should allow users
1037 to do some simple operations when debugging applications that use
1038 a language currently not supported by GDB. */
1039
1040const struct language_defn minimal_language_defn =
1041{
1042 "minimal", /* Language name */
1043 language_minimal,
20a0e81d
JB
1044 range_check_off,
1045 type_check_off,
1046 case_sensitive_on,
7ca2d3a3 1047 array_row_major,
9a044a89 1048 macro_expansion_c,
6c7a06a3 1049 &exp_descriptor_c,
7c8adf68 1050 c_parse,
20a0e81d 1051 c_error,
e85c3284 1052 null_post_parser,
20a0e81d
JB
1053 c_printchar, /* Print a character constant */
1054 c_printstr, /* Function to print string constant */
1055 c_emit_char, /* Print a single char */
20a0e81d 1056 c_print_type, /* Print a type using appropriate syntax */
5c6ce71d 1057 c_print_typedef, /* Print a typedef using appropriate syntax */
20a0e81d
JB
1058 c_val_print, /* Print a value using appropriate syntax */
1059 c_value_print, /* Print a top-level value */
1060 NULL, /* Language specific skip_trampoline */
2b2d9e11 1061 NULL, /* name_of_this */
5f9a71c3 1062 basic_lookup_symbol_nonlocal, /* lookup_symbol_nonlocal */
b368761e 1063 basic_lookup_transparent_type,/* lookup_transparent_type */
20a0e81d 1064 NULL, /* Language specific symbol demangler */
aff410f1
MS
1065 NULL, /* Language specific
1066 class_name_from_physname */
20a0e81d
JB
1067 c_op_print_tab, /* expression operators for printing */
1068 1, /* c-style arrays */
1069 0, /* String lower bound */
6084f43a 1070 default_word_break_characters,
41d27058 1071 default_make_symbol_completion_list,
e9667a65 1072 c_language_arch_info,
e79af960 1073 default_print_array_index,
41f1b697 1074 default_pass_by_reference,
ae6a3a4c 1075 c_get_string,
1a119f36 1076 NULL, /* la_get_symbol_name_cmp */
f8eba3c6 1077 iterate_over_symbols,
20a0e81d
JB
1078 LANG_MAGIC
1079};
1080
c906108c 1081void
fba45db2 1082_initialize_c_language (void)
c906108c
SS
1083{
1084 add_language (&c_language_defn);
1085 add_language (&cplus_language_defn);
1086 add_language (&asm_language_defn);
20a0e81d 1087 add_language (&minimal_language_defn);
c906108c 1088}
This page took 0.835702 seconds and 4 git commands to generate.