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