2010-07-13 Emmanuel Thomé <Emmanuel.Thome@gmail.com>
[deliverable/binutils-gdb.git] / gdb / c-valprint.c
1 /* Support for printing C values for GDB, the GNU debugger.
2
3 Copyright (C) 1986, 1988, 1989, 1991, 1992, 1993, 1994, 1995, 1996, 1997,
4 1998, 1999, 2000, 2001, 2003, 2005, 2006, 2007, 2008, 2009, 2010
5 Free Software Foundation, Inc.
6
7 This file is part of GDB.
8
9 This program is free software; you can redistribute it and/or modify
10 it under the terms of the GNU General Public License as published by
11 the Free Software Foundation; either version 3 of the License, or
12 (at your option) any later version.
13
14 This program is distributed in the hope that it will be useful,
15 but WITHOUT ANY WARRANTY; without even the implied warranty of
16 MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
17 GNU General Public License for more details.
18
19 You should have received a copy of the GNU General Public License
20 along with this program. If not, see <http://www.gnu.org/licenses/>. */
21
22 #include "defs.h"
23 #include "gdb_string.h"
24 #include "symtab.h"
25 #include "gdbtypes.h"
26 #include "expression.h"
27 #include "value.h"
28 #include "valprint.h"
29 #include "language.h"
30 #include "c-lang.h"
31 #include "cp-abi.h"
32 #include "target.h"
33 \f
34
35 /* Print function pointer with inferior address ADDRESS onto stdio
36 stream STREAM. */
37
38 static void
39 print_function_pointer_address (struct gdbarch *gdbarch, CORE_ADDR address,
40 struct ui_file *stream, int addressprint)
41 {
42 CORE_ADDR func_addr = gdbarch_convert_from_func_ptr_addr (gdbarch, address,
43 &current_target);
44
45 /* If the function pointer is represented by a description, print the
46 address of the description. */
47 if (addressprint && func_addr != address)
48 {
49 fputs_filtered ("@", stream);
50 fputs_filtered (paddress (gdbarch, address), stream);
51 fputs_filtered (": ", stream);
52 }
53 print_address_demangle (gdbarch, func_addr, stream, demangle);
54 }
55
56
57 /* A helper for c_textual_element_type. This checks the name of the
58 typedef. This is bogus but it isn't apparent that the compiler
59 provides us the help we may need. */
60
61 static int
62 textual_name (const char *name)
63 {
64 return (!strcmp (name, "wchar_t")
65 || !strcmp (name, "char16_t")
66 || !strcmp (name, "char32_t"));
67 }
68
69 /* Apply a heuristic to decide whether an array of TYPE or a pointer
70 to TYPE should be printed as a textual string. Return non-zero if
71 it should, or zero if it should be treated as an array of integers
72 or pointer to integers. FORMAT is the current format letter,
73 or 0 if none.
74
75 We guess that "char" is a character. Explicitly signed and
76 unsigned character types are also characters. Integer data from
77 vector types is not. The user can override this by using the /s
78 format letter. */
79
80 int
81 c_textual_element_type (struct type *type, char format)
82 {
83 struct type *true_type, *iter_type;
84
85 if (format != 0 && format != 's')
86 return 0;
87
88 /* We also rely on this for its side effect of setting up all the
89 typedef pointers. */
90 true_type = check_typedef (type);
91
92 /* TYPE_CODE_CHAR is always textual. */
93 if (TYPE_CODE (true_type) == TYPE_CODE_CHAR)
94 return 1;
95
96 /* Any other character-like types must be integral. */
97 if (TYPE_CODE (true_type) != TYPE_CODE_INT)
98 return 0;
99
100 /* We peel typedefs one by one, looking for a match. */
101 iter_type = type;
102 while (iter_type)
103 {
104 /* Check the name of the type. */
105 if (TYPE_NAME (iter_type) && textual_name (TYPE_NAME (iter_type)))
106 return 1;
107
108 if (TYPE_CODE (iter_type) != TYPE_CODE_TYPEDEF)
109 break;
110
111 /* Peel a single typedef. If the typedef doesn't have a target
112 type, we use check_typedef and hope the result is ok -- it
113 might be for C++, where wchar_t is a built-in type. */
114 if (TYPE_TARGET_TYPE (iter_type))
115 iter_type = TYPE_TARGET_TYPE (iter_type);
116 else
117 iter_type = check_typedef (iter_type);
118 }
119
120 if (format == 's')
121 {
122 /* Print this as a string if we can manage it. For now, no
123 wide character support. */
124 if (TYPE_CODE (true_type) == TYPE_CODE_INT
125 && TYPE_LENGTH (true_type) == 1)
126 return 1;
127 }
128 else
129 {
130 /* If a one-byte TYPE_CODE_INT is missing the not-a-character
131 flag, then we treat it as text; otherwise, we assume it's
132 being used as data. */
133 if (TYPE_CODE (true_type) == TYPE_CODE_INT
134 && TYPE_LENGTH (true_type) == 1
135 && !TYPE_NOTTEXT (true_type))
136 return 1;
137 }
138
139 return 0;
140 }
141
142
143 /* Print data of type TYPE located at VALADDR (within GDB), which came from
144 the inferior at address ADDRESS, onto stdio stream STREAM according to
145 OPTIONS. The data at VALADDR is in target byte order.
146
147 If the data are a string pointer, returns the number of string characters
148 printed. */
149
150 int
151 c_val_print (struct type *type, const gdb_byte *valaddr, int embedded_offset,
152 CORE_ADDR address, struct ui_file *stream, int recurse,
153 const struct value *original_value,
154 const struct value_print_options *options)
155 {
156 struct gdbarch *gdbarch = get_type_arch (type);
157 enum bfd_endian byte_order = gdbarch_byte_order (gdbarch);
158 unsigned int i = 0; /* Number of characters printed */
159 unsigned len;
160 struct type *elttype, *unresolved_elttype;
161 struct type *unresolved_type = type;
162 unsigned eltlen;
163 LONGEST val;
164 CORE_ADDR addr;
165
166 CHECK_TYPEDEF (type);
167 switch (TYPE_CODE (type))
168 {
169 case TYPE_CODE_ARRAY:
170 unresolved_elttype = TYPE_TARGET_TYPE (type);
171 elttype = check_typedef (unresolved_elttype);
172 if (TYPE_LENGTH (type) > 0 && TYPE_LENGTH (unresolved_elttype) > 0)
173 {
174 eltlen = TYPE_LENGTH (elttype);
175 len = TYPE_LENGTH (type) / eltlen;
176 if (options->prettyprint_arrays)
177 {
178 print_spaces_filtered (2 + 2 * recurse, stream);
179 }
180
181 /* Print arrays of textual chars with a string syntax, as
182 long as the entire array is valid. */
183 if (!TYPE_VECTOR (type)
184 && c_textual_element_type (unresolved_elttype, options->format)
185 && value_bits_valid (original_value,
186 TARGET_CHAR_BIT * embedded_offset,
187 TARGET_CHAR_BIT * TYPE_LENGTH (type)))
188 {
189 /* If requested, look for the first null char and only print
190 elements up to it. */
191 if (options->stop_print_at_null)
192 {
193 unsigned int temp_len;
194
195 for (temp_len = 0;
196 (temp_len < len
197 && temp_len < options->print_max
198 && extract_unsigned_integer (valaddr + embedded_offset
199 + temp_len * eltlen,
200 eltlen, byte_order) != 0);
201 ++temp_len)
202 ;
203 len = temp_len;
204 }
205
206 LA_PRINT_STRING (stream, unresolved_elttype,
207 valaddr + embedded_offset, len,
208 NULL, 0, options);
209 i = len;
210 }
211 else
212 {
213 fprintf_filtered (stream, "{");
214 /* If this is a virtual function table, print the 0th
215 entry specially, and the rest of the members normally. */
216 if (cp_is_vtbl_ptr_type (elttype))
217 {
218 i = 1;
219 fprintf_filtered (stream, _("%d vtable entries"), len - 1);
220 }
221 else
222 {
223 i = 0;
224 }
225 val_print_array_elements (type, valaddr + embedded_offset,
226 address + embedded_offset, stream,
227 recurse, original_value, options, i);
228 fprintf_filtered (stream, "}");
229 }
230 break;
231 }
232 /* Array of unspecified length: treat like pointer to first elt. */
233 addr = address;
234 goto print_unpacked_pointer;
235
236 case TYPE_CODE_MEMBERPTR:
237 if (options->format)
238 {
239 print_scalar_formatted (valaddr + embedded_offset, type,
240 options, 0, stream);
241 break;
242 }
243 cp_print_class_member (valaddr + embedded_offset, type, stream, "&");
244 break;
245
246 case TYPE_CODE_METHODPTR:
247 cplus_print_method_ptr (valaddr + embedded_offset, type, stream);
248 break;
249
250 case TYPE_CODE_PTR:
251 if (options->format && options->format != 's')
252 {
253 print_scalar_formatted (valaddr + embedded_offset, type,
254 options, 0, stream);
255 break;
256 }
257 if (options->vtblprint && cp_is_vtbl_ptr_type (type))
258 {
259 /* Print the unmangled name if desired. */
260 /* Print vtable entry - we only get here if we ARE using
261 -fvtable_thunks. (Otherwise, look under TYPE_CODE_STRUCT.) */
262 CORE_ADDR addr
263 = extract_typed_address (valaddr + embedded_offset, type);
264
265 print_function_pointer_address (gdbarch, addr, stream,
266 options->addressprint);
267 break;
268 }
269 unresolved_elttype = TYPE_TARGET_TYPE (type);
270 elttype = check_typedef (unresolved_elttype);
271 {
272 addr = unpack_pointer (type, valaddr + embedded_offset);
273 print_unpacked_pointer:
274
275 if (TYPE_CODE (elttype) == TYPE_CODE_FUNC)
276 {
277 /* Try to print what function it points to. */
278 print_function_pointer_address (gdbarch, addr, stream,
279 options->addressprint);
280 /* Return value is irrelevant except for string pointers. */
281 return (0);
282 }
283
284 if (options->addressprint)
285 fputs_filtered (paddress (gdbarch, addr), stream);
286
287 /* For a pointer to a textual type, also print the string
288 pointed to, unless pointer is null. */
289
290 if (c_textual_element_type (unresolved_elttype, options->format)
291 && addr != 0)
292 {
293 i = val_print_string (unresolved_elttype, addr, -1, stream,
294 options);
295 }
296 else if (cp_is_vtbl_member (type))
297 {
298 /* print vtbl's nicely */
299 CORE_ADDR vt_address = unpack_pointer (type, valaddr + embedded_offset);
300
301 struct minimal_symbol *msymbol =
302 lookup_minimal_symbol_by_pc (vt_address);
303 if ((msymbol != NULL)
304 && (vt_address == SYMBOL_VALUE_ADDRESS (msymbol)))
305 {
306 fputs_filtered (" <", stream);
307 fputs_filtered (SYMBOL_PRINT_NAME (msymbol), stream);
308 fputs_filtered (">", stream);
309 }
310 if (vt_address && options->vtblprint)
311 {
312 struct value *vt_val;
313 struct symbol *wsym = (struct symbol *) NULL;
314 struct type *wtype;
315 struct block *block = (struct block *) NULL;
316 int is_this_fld;
317
318 if (msymbol != NULL)
319 wsym = lookup_symbol (SYMBOL_LINKAGE_NAME (msymbol), block,
320 VAR_DOMAIN, &is_this_fld);
321
322 if (wsym)
323 {
324 wtype = SYMBOL_TYPE (wsym);
325 }
326 else
327 {
328 wtype = unresolved_elttype;
329 }
330 vt_val = value_at (wtype, vt_address);
331 common_val_print (vt_val, stream, recurse + 1, options,
332 current_language);
333 if (options->pretty)
334 {
335 fprintf_filtered (stream, "\n");
336 print_spaces_filtered (2 + 2 * recurse, stream);
337 }
338 }
339 }
340
341 /* Return number of characters printed, including the terminating
342 '\0' if we reached the end. val_print_string takes care including
343 the terminating '\0' if necessary. */
344 return i;
345 }
346 break;
347
348 case TYPE_CODE_REF:
349 elttype = check_typedef (TYPE_TARGET_TYPE (type));
350 if (options->addressprint)
351 {
352 CORE_ADDR addr
353 = extract_typed_address (valaddr + embedded_offset, type);
354
355 fprintf_filtered (stream, "@");
356 fputs_filtered (paddress (gdbarch, addr), stream);
357 if (options->deref_ref)
358 fputs_filtered (": ", stream);
359 }
360 /* De-reference the reference. */
361 if (options->deref_ref)
362 {
363 if (TYPE_CODE (elttype) != TYPE_CODE_UNDEF)
364 {
365 struct value *deref_val =
366 value_at
367 (TYPE_TARGET_TYPE (type),
368 unpack_pointer (type, valaddr + embedded_offset));
369
370 common_val_print (deref_val, stream, recurse, options,
371 current_language);
372 }
373 else
374 fputs_filtered ("???", stream);
375 }
376 break;
377
378 case TYPE_CODE_UNION:
379 if (recurse && !options->unionprint)
380 {
381 fprintf_filtered (stream, "{...}");
382 break;
383 }
384 /* Fall through. */
385 case TYPE_CODE_STRUCT:
386 /*FIXME: Abstract this away */
387 if (options->vtblprint && cp_is_vtbl_ptr_type (type))
388 {
389 /* Print the unmangled name if desired. */
390 /* Print vtable entry - we only get here if NOT using
391 -fvtable_thunks. (Otherwise, look under TYPE_CODE_PTR.) */
392 int offset = (embedded_offset +
393 TYPE_FIELD_BITPOS (type, VTBL_FNADDR_OFFSET) / 8);
394 struct type *field_type = TYPE_FIELD_TYPE (type, VTBL_FNADDR_OFFSET);
395 CORE_ADDR addr
396 = extract_typed_address (valaddr + offset, field_type);
397
398 print_function_pointer_address (gdbarch, addr, stream,
399 options->addressprint);
400 }
401 else
402 cp_print_value_fields_rtti (type, valaddr,
403 embedded_offset, address, stream,
404 recurse, original_value, options, NULL, 0);
405 break;
406
407 case TYPE_CODE_ENUM:
408 if (options->format)
409 {
410 print_scalar_formatted (valaddr + embedded_offset, type,
411 options, 0, stream);
412 break;
413 }
414 len = TYPE_NFIELDS (type);
415 val = unpack_long (type, valaddr + embedded_offset);
416 for (i = 0; i < len; i++)
417 {
418 QUIT;
419 if (val == TYPE_FIELD_BITPOS (type, i))
420 {
421 break;
422 }
423 }
424 if (i < len)
425 {
426 fputs_filtered (TYPE_FIELD_NAME (type, i), stream);
427 }
428 else
429 {
430 print_longest (stream, 'd', 0, val);
431 }
432 break;
433
434 case TYPE_CODE_FLAGS:
435 if (options->format)
436 print_scalar_formatted (valaddr + embedded_offset, type,
437 options, 0, stream);
438 else
439 val_print_type_code_flags (type, valaddr + embedded_offset, stream);
440 break;
441
442 case TYPE_CODE_FUNC:
443 case TYPE_CODE_METHOD:
444 if (options->format)
445 {
446 print_scalar_formatted (valaddr + embedded_offset, type,
447 options, 0, stream);
448 break;
449 }
450 /* FIXME, we should consider, at least for ANSI C language, eliminating
451 the distinction made between FUNCs and POINTERs to FUNCs. */
452 fprintf_filtered (stream, "{");
453 type_print (type, "", stream, -1);
454 fprintf_filtered (stream, "} ");
455 /* Try to print what function it points to, and its address. */
456 print_address_demangle (gdbarch, address, stream, demangle);
457 break;
458
459 case TYPE_CODE_BOOL:
460 if (options->format || options->output_format)
461 {
462 struct value_print_options opts = *options;
463 opts.format = (options->format ? options->format
464 : options->output_format);
465 print_scalar_formatted (valaddr + embedded_offset, type,
466 &opts, 0, stream);
467 }
468 else
469 {
470 val = unpack_long (type, valaddr + embedded_offset);
471 if (val == 0)
472 fputs_filtered ("false", stream);
473 else if (val == 1)
474 fputs_filtered ("true", stream);
475 else
476 print_longest (stream, 'd', 0, val);
477 }
478 break;
479
480 case TYPE_CODE_RANGE:
481 /* FIXME: create_range_type does not set the unsigned bit in a
482 range type (I think it probably should copy it from the target
483 type), so we won't print values which are too large to
484 fit in a signed integer correctly. */
485 /* FIXME: Doesn't handle ranges of enums correctly. (Can't just
486 print with the target type, though, because the size of our type
487 and the target type might differ). */
488 /* FALLTHROUGH */
489
490 case TYPE_CODE_INT:
491 if (options->format || options->output_format)
492 {
493 struct value_print_options opts = *options;
494
495 opts.format = (options->format ? options->format
496 : options->output_format);
497 print_scalar_formatted (valaddr + embedded_offset, type,
498 &opts, 0, stream);
499 }
500 else
501 {
502 val_print_type_code_int (type, valaddr + embedded_offset, stream);
503 /* C and C++ has no single byte int type, char is used instead.
504 Since we don't know whether the value is really intended to
505 be used as an integer or a character, print the character
506 equivalent as well. */
507 if (c_textual_element_type (unresolved_type, options->format))
508 {
509 fputs_filtered (" ", stream);
510 LA_PRINT_CHAR ((unsigned char) unpack_long (type, valaddr + embedded_offset),
511 unresolved_type, stream);
512 }
513 }
514 break;
515
516 case TYPE_CODE_CHAR:
517 if (options->format || options->output_format)
518 {
519 struct value_print_options opts = *options;
520 opts.format = (options->format ? options->format
521 : options->output_format);
522 print_scalar_formatted (valaddr + embedded_offset, type,
523 &opts, 0, stream);
524 }
525 else
526 {
527 val = unpack_long (type, valaddr + embedded_offset);
528 if (TYPE_UNSIGNED (type))
529 fprintf_filtered (stream, "%u", (unsigned int) val);
530 else
531 fprintf_filtered (stream, "%d", (int) val);
532 fputs_filtered (" ", stream);
533 LA_PRINT_CHAR ((unsigned char) val, unresolved_type, stream);
534 }
535 break;
536
537 case TYPE_CODE_FLT:
538 if (options->format)
539 {
540 print_scalar_formatted (valaddr + embedded_offset, type,
541 options, 0, stream);
542 }
543 else
544 {
545 print_floating (valaddr + embedded_offset, type, stream);
546 }
547 break;
548
549 case TYPE_CODE_DECFLOAT:
550 if (options->format)
551 print_scalar_formatted (valaddr + embedded_offset, type,
552 options, 0, stream);
553 else
554 print_decimal_floating (valaddr + embedded_offset, type, stream);
555 break;
556
557 case TYPE_CODE_VOID:
558 fprintf_filtered (stream, "void");
559 break;
560
561 case TYPE_CODE_ERROR:
562 fprintf_filtered (stream, "%s", TYPE_ERROR_NAME (type));
563 break;
564
565 case TYPE_CODE_UNDEF:
566 /* This happens (without TYPE_FLAG_STUB set) on systems which don't use
567 dbx xrefs (NO_DBX_XREFS in gcc) if a file has a "struct foo *bar"
568 and no complete type for struct foo in that file. */
569 fprintf_filtered (stream, _("<incomplete type>"));
570 break;
571
572 case TYPE_CODE_COMPLEX:
573 if (options->format)
574 print_scalar_formatted (valaddr + embedded_offset,
575 TYPE_TARGET_TYPE (type),
576 options, 0, stream);
577 else
578 print_floating (valaddr + embedded_offset, TYPE_TARGET_TYPE (type),
579 stream);
580 fprintf_filtered (stream, " + ");
581 if (options->format)
582 print_scalar_formatted (valaddr + embedded_offset
583 + TYPE_LENGTH (TYPE_TARGET_TYPE (type)),
584 TYPE_TARGET_TYPE (type),
585 options, 0, stream);
586 else
587 print_floating (valaddr + embedded_offset
588 + TYPE_LENGTH (TYPE_TARGET_TYPE (type)),
589 TYPE_TARGET_TYPE (type),
590 stream);
591 fprintf_filtered (stream, " * I");
592 break;
593
594 default:
595 error (_("Invalid C/C++ type code %d in symbol table."), TYPE_CODE (type));
596 }
597 gdb_flush (stream);
598 return (0);
599 }
600 \f
601 int
602 c_value_print (struct value *val, struct ui_file *stream,
603 const struct value_print_options *options)
604 {
605 struct type *type, *real_type, *val_type;
606 int full, top, using_enc;
607 struct value_print_options opts = *options;
608
609 opts.deref_ref = 1;
610
611 /* If it is a pointer, indicate what it points to.
612
613 Print type also if it is a reference.
614
615 C++: if it is a member pointer, we will take care
616 of that when we print it. */
617
618 /* Preserve the original type before stripping typedefs. We prefer
619 to pass down the original type when possible, but for local
620 checks it is better to look past the typedefs. */
621 val_type = value_type (val);
622 type = check_typedef (val_type);
623
624 if (TYPE_CODE (type) == TYPE_CODE_PTR
625 || TYPE_CODE (type) == TYPE_CODE_REF)
626 {
627 /* Hack: remove (char *) for char strings. Their
628 type is indicated by the quoted string anyway.
629 (Don't use c_textual_element_type here; quoted strings
630 are always exactly (char *), (wchar_t *), or the like. */
631 if (TYPE_CODE (val_type) == TYPE_CODE_PTR
632 && TYPE_NAME (val_type) == NULL
633 && TYPE_NAME (TYPE_TARGET_TYPE (val_type)) != NULL
634 && (strcmp (TYPE_NAME (TYPE_TARGET_TYPE (val_type)), "char") == 0
635 || textual_name (TYPE_NAME (TYPE_TARGET_TYPE (val_type)))))
636 {
637 /* Print nothing */
638 }
639 else if (options->objectprint
640 && (TYPE_CODE (TYPE_TARGET_TYPE (type)) == TYPE_CODE_CLASS))
641 {
642
643 if (TYPE_CODE(type) == TYPE_CODE_REF)
644 {
645 /* Copy value, change to pointer, so we don't get an
646 * error about a non-pointer type in value_rtti_target_type
647 */
648 struct value *temparg;
649 temparg=value_copy(val);
650 deprecated_set_value_type (temparg, lookup_pointer_type (TYPE_TARGET_TYPE(type)));
651 val=temparg;
652 }
653 /* Pointer to class, check real type of object */
654 fprintf_filtered (stream, "(");
655 real_type = value_rtti_target_type (val, &full, &top, &using_enc);
656 if (real_type)
657 {
658 /* RTTI entry found */
659 if (TYPE_CODE (type) == TYPE_CODE_PTR)
660 {
661 /* create a pointer type pointing to the real type */
662 type = lookup_pointer_type (real_type);
663 }
664 else
665 {
666 /* create a reference type referencing the real type */
667 type = lookup_reference_type (real_type);
668 }
669 /* JYG: Need to adjust pointer value. */
670 /* NOTE: cagney/2005-01-02: THIS IS BOGUS. */
671 value_contents_writeable (val)[0] -= top;
672
673 /* Note: When we look up RTTI entries, we don't get any
674 information on const or volatile attributes */
675 }
676 type_print (type, "", stream, -1);
677 fprintf_filtered (stream, ") ");
678 val_type = type;
679 }
680 else
681 {
682 /* normal case */
683 fprintf_filtered (stream, "(");
684 type_print (value_type (val), "", stream, -1);
685 fprintf_filtered (stream, ") ");
686 }
687 }
688
689 if (!value_initialized (val))
690 fprintf_filtered (stream, " [uninitialized] ");
691
692 if (options->objectprint && (TYPE_CODE (type) == TYPE_CODE_CLASS))
693 {
694 /* Attempt to determine real type of object */
695 real_type = value_rtti_type (val, &full, &top, &using_enc);
696 if (real_type)
697 {
698 /* We have RTTI information, so use it */
699 val = value_full_object (val, real_type, full, top, using_enc);
700 fprintf_filtered (stream, "(%s%s) ",
701 TYPE_NAME (real_type),
702 full ? "" : _(" [incomplete object]"));
703 /* Print out object: enclosing type is same as real_type if full */
704 return val_print (value_enclosing_type (val),
705 value_contents_for_printing (val), 0,
706 value_address (val), stream, 0,
707 val, &opts, current_language);
708 /* Note: When we look up RTTI entries, we don't get any information on
709 const or volatile attributes */
710 }
711 else if (type != check_typedef (value_enclosing_type (val)))
712 {
713 /* No RTTI information, so let's do our best */
714 fprintf_filtered (stream, "(%s ?) ",
715 TYPE_NAME (value_enclosing_type (val)));
716 return val_print (value_enclosing_type (val),
717 value_contents_for_printing (val), 0,
718 value_address (val), stream, 0,
719 val, &opts, current_language);
720 }
721 /* Otherwise, we end up at the return outside this "if" */
722 }
723
724 return val_print (val_type, value_contents_for_printing (val),
725 value_embedded_offset (val),
726 value_address (val),
727 stream, 0,
728 val, &opts, current_language);
729 }
This page took 0.074412 seconds and 5 git commands to generate.