Revert the entire VLA series.
[deliverable/binutils-gdb.git] / gdb / jv-valprint.c
CommitLineData
c906108c 1/* Support for printing Java values for GDB, the GNU debugger.
1e4728e7 2
ecd75fc8 3 Copyright (C) 1997-2014 Free Software Foundation, Inc.
c906108c 4
c5aa993b 5 This file is part of GDB.
c906108c 6
c5aa993b
JM
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
a9762ec7 9 the Free Software Foundation; either version 3 of the License, or
c5aa993b 10 (at your option) any later version.
c906108c 11
c5aa993b
JM
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.
c906108c 16
c5aa993b 17 You should have received a copy of the GNU General Public License
a9762ec7 18 along with this program. If not, see <http://www.gnu.org/licenses/>. */
c906108c
SS
19
20#include "defs.h"
21#include "symtab.h"
22#include "gdbtypes.h"
7a292a7a 23#include "gdbcore.h"
c906108c
SS
24#include "expression.h"
25#include "value.h"
26#include "demangle.h"
27#include "valprint.h"
28#include "language.h"
29#include "jv-lang.h"
30#include "c-lang.h"
7a292a7a 31#include "annotate.h"
0e9f083f 32#include <string.h>
c906108c 33
392a587b
JM
34/* Local functions */
35
8e069a98 36void
79a45b7d
TT
37java_value_print (struct value *val, struct ui_file *stream,
38 const struct value_print_options *options)
c906108c 39{
50810684 40 struct gdbarch *gdbarch = get_type_arch (value_type (val));
e17a4113 41 enum bfd_endian byte_order = gdbarch_byte_order (gdbarch);
c906108c
SS
42 struct type *type;
43 CORE_ADDR address;
44 int i;
0d5cff50 45 const char *name;
79a45b7d 46 struct value_print_options opts;
c906108c 47
df407dfe 48 type = value_type (val);
42ae5230 49 address = value_address (val);
c906108c
SS
50
51 if (is_object_type (type))
52 {
53 CORE_ADDR obj_addr;
b7b189f3 54 struct value *tem = val;
c906108c 55
1777feb0 56 /* Get the run-time type, and cast the object into that. */
b7b189f3
TT
57 while (TYPE_CODE (value_type (tem)) == TYPE_CODE_PTR)
58 tem = value_ind (tem);
c906108c 59
b7b189f3 60 obj_addr = value_address (tem);
c906108c
SS
61
62 if (obj_addr != 0)
63 {
0daa2b63 64 type = type_from_class (gdbarch, java_class_from_object (val));
c906108c
SS
65 type = lookup_pointer_type (type);
66
00a4c844 67 val = value_at (type, address);
c906108c
SS
68 }
69 }
70
c5aa993b 71 if (TYPE_CODE (type) == TYPE_CODE_PTR && !value_logical_not (val))
c906108c
SS
72 type_print (TYPE_TARGET_TYPE (type), "", stream, -1);
73
74 name = TYPE_TAG_NAME (type);
75 if (TYPE_CODE (type) == TYPE_CODE_STRUCT && name != NULL
c5aa993b 76 && (i = strlen (name), name[i - 1] == ']'))
c906108c 77 {
c68a6671 78 gdb_byte buf4[4];
c906108c
SS
79 long length;
80 unsigned int things_printed = 0;
c5aa993b 81 int reps;
0daa2b63
UW
82 struct type *el_type
83 = java_primitive_type_from_name (gdbarch, name, i - 2);
e0881a8e 84
c906108c 85 i = 0;
45d5d5ca 86 read_memory (address + get_java_object_header_size (gdbarch), buf4, 4);
c906108c 87
e17a4113 88 length = (long) extract_signed_integer (buf4, 4, byte_order);
c906108c
SS
89 fprintf_filtered (stream, "{length: %ld", length);
90
91 if (el_type == NULL)
92 {
c65ecaf3 93 CORE_ADDR element;
1777feb0 94 CORE_ADDR next_element = -1; /* Dummy initial value. */
c906108c 95
1777feb0 96 /* Skip object header and length. */
45d5d5ca 97 address += get_java_object_header_size (gdbarch) + 4;
c906108c 98
79a45b7d 99 while (i < length && things_printed < options->print_max)
c906108c 100 {
c68a6671 101 gdb_byte *buf;
c906108c 102
45d5d5ca 103 buf = alloca (gdbarch_ptr_bit (gdbarch) / HOST_CHAR_BIT);
c906108c
SS
104 fputs_filtered (", ", stream);
105 wrap_here (n_spaces (2));
106
107 if (i > 0)
108 element = next_element;
109 else
110 {
c5aa993b 111 read_memory (address, buf, sizeof (buf));
45d5d5ca 112 address += gdbarch_ptr_bit (gdbarch) / HOST_CHAR_BIT;
b276f1bb
AC
113 /* FIXME: cagney/2003-05-24: Bogus or what. It
114 pulls a host sized pointer out of the target and
115 then extracts that as an address (while assuming
116 that the address is unsigned)! */
e17a4113
UW
117 element = extract_unsigned_integer (buf, sizeof (buf),
118 byte_order);
c906108c
SS
119 }
120
c5aa993b 121 for (reps = 1; i + reps < length; reps++)
c906108c 122 {
c5aa993b 123 read_memory (address, buf, sizeof (buf));
45d5d5ca 124 address += gdbarch_ptr_bit (gdbarch) / HOST_CHAR_BIT;
b276f1bb
AC
125 /* FIXME: cagney/2003-05-24: Bogus or what. It
126 pulls a host sized pointer out of the target and
127 then extracts that as an address (while assuming
128 that the address is unsigned)! */
e17a4113
UW
129 next_element = extract_unsigned_integer (buf, sizeof (buf),
130 byte_order);
c906108c
SS
131 if (next_element != element)
132 break;
133 }
134
135 if (reps == 1)
136 fprintf_filtered (stream, "%d: ", i);
137 else
138 fprintf_filtered (stream, "%d..%d: ", i, i + reps - 1);
139
140 if (element == 0)
141 fprintf_filtered (stream, "null");
142 else
5af949e3 143 fprintf_filtered (stream, "@%s", paddress (gdbarch, element));
c906108c
SS
144
145 things_printed++;
146 i += reps;
147 }
148 }
149 else
150 {
75c9979e
AC
151 struct value *v = allocate_value (el_type);
152 struct value *next_v = allocate_value (el_type);
c906108c 153
45d5d5ca
UW
154 set_value_address (v, (address
155 + get_java_object_header_size (gdbarch) + 4));
42ae5230 156 set_value_address (next_v, value_raw_address (v));
c906108c 157
79a45b7d 158 while (i < length && things_printed < options->print_max)
c906108c
SS
159 {
160 fputs_filtered (", ", stream);
161 wrap_here (n_spaces (2));
162
163 if (i > 0)
164 {
75c9979e 165 struct value *tmp;
c906108c
SS
166
167 tmp = next_v;
168 next_v = v;
169 v = tmp;
170 }
171 else
172 {
dfa52d88 173 set_value_lazy (v, 1);
f5cf64a7 174 set_value_offset (v, 0);
c906108c
SS
175 }
176
f5cf64a7 177 set_value_offset (next_v, value_offset (v));
c906108c 178
c5aa993b 179 for (reps = 1; i + reps < length; reps++)
c906108c 180 {
dfa52d88 181 set_value_lazy (next_v, 1);
1777feb0
MS
182 set_value_offset (next_v, value_offset (next_v)
183 + TYPE_LENGTH (el_type));
c8c1c22f
PA
184 value_fetch_lazy (next_v);
185 if (!(value_available_contents_eq
186 (v, value_embedded_offset (v),
187 next_v, value_embedded_offset (next_v),
188 TYPE_LENGTH (el_type))))
c906108c
SS
189 break;
190 }
191
192 if (reps == 1)
193 fprintf_filtered (stream, "%d: ", i);
194 else
195 fprintf_filtered (stream, "%d..%d: ", i, i + reps - 1);
196
79a45b7d
TT
197 opts = *options;
198 opts.deref_ref = 1;
199 common_val_print (v, stream, 1, &opts, current_language);
c906108c
SS
200
201 things_printed++;
202 i += reps;
203 }
204 }
205
206 if (i < length)
207 fprintf_filtered (stream, "...");
208
209 fprintf_filtered (stream, "}");
210
8e069a98 211 return;
c906108c
SS
212 }
213
1777feb0 214 /* If it's type String, print it. */
c906108c
SS
215
216 if (TYPE_CODE (type) == TYPE_CODE_PTR
217 && TYPE_TARGET_TYPE (type)
d4cad8db
TT
218 && TYPE_TAG_NAME (TYPE_TARGET_TYPE (type))
219 && strcmp (TYPE_TAG_NAME (TYPE_TARGET_TYPE (type)),
220 "java.lang.String") == 0
79a45b7d 221 && (options->format == 0 || options->format == 's')
8dccf761 222 && address != 0
1aa20aa8 223 && value_as_address (val) != 0)
c906108c 224 {
0daa2b63 225 struct type *char_type;
75c9979e 226 struct value *data_val;
c906108c 227 CORE_ADDR data;
75c9979e 228 struct value *boffset_val;
c906108c 229 unsigned long boffset;
75c9979e 230 struct value *count_val;
c906108c 231 unsigned long count;
75c9979e 232 struct value *mark;
c906108c 233
b012acdd
TT
234 fputs_filtered (" ", stream);
235
1777feb0 236 mark = value_mark (); /* Remember start of new values. */
c906108c
SS
237
238 data_val = value_struct_elt (&val, NULL, "data", NULL, NULL);
1aa20aa8 239 data = value_as_address (data_val);
c906108c
SS
240
241 boffset_val = value_struct_elt (&val, NULL, "boffset", NULL, NULL);
1aa20aa8 242 boffset = value_as_address (boffset_val);
c906108c
SS
243
244 count_val = value_struct_elt (&val, NULL, "count", NULL, NULL);
1aa20aa8 245 count = value_as_address (count_val);
c906108c 246
1777feb0 247 value_free_to_mark (mark); /* Release unnecessary values. */
c906108c 248
0daa2b63 249 char_type = builtin_java_type (gdbarch)->builtin_char;
09ca9e2e
TT
250 val_print_string (char_type, NULL, data + boffset, count, stream,
251 options);
c906108c 252
8e069a98 253 return;
c906108c
SS
254 }
255
79a45b7d
TT
256 opts = *options;
257 opts.deref_ref = 1;
8e069a98 258 common_val_print (val, stream, 0, &opts, current_language);
c906108c
SS
259}
260
79a45b7d 261/* TYPE, VALADDR, ADDRESS, STREAM, RECURSE, and OPTIONS have the
c906108c
SS
262 same meanings as in cp_print_value and c_val_print.
263
264 DONT_PRINT is an array of baseclass types that we
265 should not print, or zero if called from top level. */
266
392a587b 267static void
fc1a4b47 268java_print_value_fields (struct type *type, const gdb_byte *valaddr,
490f124f 269 int offset,
a2bd3dcd 270 CORE_ADDR address, struct ui_file *stream,
79a45b7d 271 int recurse,
0e03807e 272 const struct value *val,
79a45b7d 273 const struct value_print_options *options)
c906108c
SS
274{
275 int i, len, n_baseclasses;
276
277 CHECK_TYPEDEF (type);
278
279 fprintf_filtered (stream, "{");
280 len = TYPE_NFIELDS (type);
281 n_baseclasses = TYPE_N_BASECLASSES (type);
282
283 if (n_baseclasses > 0)
284 {
285 int i, n_baseclasses = TYPE_N_BASECLASSES (type);
286
287 for (i = 0; i < n_baseclasses; i++)
288 {
289 int boffset;
290 struct type *baseclass = check_typedef (TYPE_BASECLASS (type, i));
0d5cff50 291 const char *basename = TYPE_NAME (baseclass);
fc1a4b47 292 const gdb_byte *base_valaddr;
c5aa993b 293
c906108c
SS
294 if (BASETYPE_VIA_VIRTUAL (type, i))
295 continue;
296
297 if (basename != NULL && strcmp (basename, "java.lang.Object") == 0)
298 continue;
299
300 boffset = 0;
301
2a998fc0 302 if (options->prettyformat)
c906108c
SS
303 {
304 fprintf_filtered (stream, "\n");
c5aa993b 305 print_spaces_filtered (2 * (recurse + 1), stream);
c906108c
SS
306 }
307 fputs_filtered ("<", stream);
308 /* Not sure what the best notation is in the case where there is no
309 baseclass name. */
310 fputs_filtered (basename ? basename : "", stream);
311 fputs_filtered ("> = ", stream);
312
313 base_valaddr = valaddr;
314
490f124f
PA
315 java_print_value_fields (baseclass, base_valaddr,
316 offset + boffset, address,
0e03807e 317 stream, recurse + 1, val, options);
c906108c 318 fputs_filtered (", ", stream);
c906108c 319 }
c906108c
SS
320 }
321
322 if (!len && n_baseclasses == 1)
323 fprintf_filtered (stream, "<No data fields>");
324 else
325 {
c906108c
SS
326 int fields_seen = 0;
327
328 for (i = n_baseclasses; i < len; i++)
329 {
330 /* If requested, skip printing of static fields. */
d6a843b5 331 if (field_is_static (&TYPE_FIELD (type, i)))
c906108c 332 {
0d5cff50 333 const char *name = TYPE_FIELD_NAME (type, i);
e0881a8e 334
79a45b7d 335 if (!options->static_field_print)
c906108c
SS
336 continue;
337 if (name != NULL && strcmp (name, "class") == 0)
338 continue;
339 }
340 if (fields_seen)
341 fprintf_filtered (stream, ", ");
342 else if (n_baseclasses > 0)
343 {
2a998fc0 344 if (options->prettyformat)
c906108c
SS
345 {
346 fprintf_filtered (stream, "\n");
347 print_spaces_filtered (2 + 2 * recurse, stream);
348 fputs_filtered ("members of ", stream);
349 fputs_filtered (type_name_no_tag (type), stream);
350 fputs_filtered (": ", stream);
351 }
352 }
353 fields_seen = 1;
354
2a998fc0 355 if (options->prettyformat)
c906108c
SS
356 {
357 fprintf_filtered (stream, "\n");
358 print_spaces_filtered (2 + 2 * recurse, stream);
359 }
c5aa993b 360 else
c906108c
SS
361 {
362 wrap_here (n_spaces (2 + 2 * recurse));
363 }
e93a8774
TT
364
365 annotate_field_begin (TYPE_FIELD_TYPE (type, i));
366
367 if (field_is_static (&TYPE_FIELD (type, i)))
368 fputs_filtered ("static ", stream);
369 fprintf_symbol_filtered (stream, TYPE_FIELD_NAME (type, i),
370 language_cplus,
371 DMGL_PARAMS | DMGL_ANSI);
372 annotate_field_name_end ();
373 fputs_filtered (": ", stream);
374 annotate_field_value ();
c906108c 375
d6a843b5
JK
376 if (!field_is_static (&TYPE_FIELD (type, i))
377 && TYPE_FIELD_PACKED (type, i))
c906108c 378 {
75c9979e 379 struct value *v;
c906108c
SS
380
381 /* Bitfields require special handling, especially due to byte
c5aa993b 382 order problems. */
c906108c
SS
383 if (TYPE_FIELD_IGNORE (type, i))
384 {
c5aa993b 385 fputs_filtered ("<optimized out or zero length>", stream);
c906108c 386 }
8cf6f0b1
TT
387 else if (value_bits_synthetic_pointer (val,
388 TYPE_FIELD_BITPOS (type,
389 i),
390 TYPE_FIELD_BITSIZE (type,
391 i)))
392 {
393 fputs_filtered (_("<synthetic pointer>"), stream);
394 }
0e03807e
TT
395 else if (!value_bits_valid (val, TYPE_FIELD_BITPOS (type, i),
396 TYPE_FIELD_BITSIZE (type, i)))
397 {
901461f8 398 val_print_optimized_out (val, stream);
0e03807e 399 }
c906108c
SS
400 else
401 {
79a45b7d
TT
402 struct value_print_options opts;
403
5467c6c8 404 v = value_field_bitfield (type, i, valaddr, offset, val);
c906108c 405
79a45b7d
TT
406 opts = *options;
407 opts.deref_ref = 0;
408 common_val_print (v, stream, recurse + 1,
409 &opts, current_language);
c906108c
SS
410 }
411 }
412 else
413 {
414 if (TYPE_FIELD_IGNORE (type, i))
415 {
c5aa993b 416 fputs_filtered ("<optimized out or zero length>", stream);
c906108c 417 }
d6a843b5 418 else if (field_is_static (&TYPE_FIELD (type, i)))
c906108c 419 {
686d4def 420 struct value_print_options opts;
75c9979e 421 struct value *v = value_static_field (type, i);
686d4def 422 struct type *t = check_typedef (value_type (v));
e0881a8e 423
686d4def
PA
424 if (TYPE_CODE (t) == TYPE_CODE_STRUCT)
425 v = value_addr (v);
426 opts = *options;
427 opts.deref_ref = 0;
428 common_val_print (v, stream, recurse + 1,
429 &opts, current_language);
c906108c 430 }
7a292a7a
SS
431 else if (TYPE_FIELD_TYPE (type, i) == NULL)
432 fputs_filtered ("<unknown type>", stream);
c906108c
SS
433 else
434 {
79a45b7d 435 struct value_print_options opts = *options;
e0881a8e 436
79a45b7d 437 opts.deref_ref = 0;
c5aa993b 438 val_print (TYPE_FIELD_TYPE (type, i),
490f124f
PA
439 valaddr,
440 offset + TYPE_FIELD_BITPOS (type, i) / 8,
441 address, stream, recurse + 1, val, &opts,
d8ca156b 442 current_language);
c906108c
SS
443 }
444 }
445 annotate_field_end ();
446 }
447
2a998fc0 448 if (options->prettyformat)
c906108c
SS
449 {
450 fprintf_filtered (stream, "\n");
451 print_spaces_filtered (2 * recurse, stream);
452 }
453 }
454 fprintf_filtered (stream, "}");
455}
456
32b72a42 457/* See val_print for a description of the various parameters of this
d3eab38a 458 function; they are identical. */
c906108c 459
d3eab38a 460void
fc1a4b47 461java_val_print (struct type *type, const gdb_byte *valaddr,
a2bd3dcd 462 int embedded_offset, CORE_ADDR address,
79a45b7d 463 struct ui_file *stream, int recurse,
0e03807e 464 const struct value *val,
79a45b7d 465 const struct value_print_options *options)
c906108c 466{
5af949e3 467 struct gdbarch *gdbarch = get_type_arch (type);
c906108c
SS
468 struct type *target_type;
469 CORE_ADDR addr;
470
471 CHECK_TYPEDEF (type);
472 switch (TYPE_CODE (type))
473 {
474 case TYPE_CODE_PTR:
79a45b7d 475 if (options->format && options->format != 's')
c906108c 476 {
ab2188aa
PA
477 val_print_scalar_formatted (type, valaddr, embedded_offset,
478 val, options, 0, stream);
c906108c
SS
479 break;
480 }
490f124f 481 addr = unpack_pointer (type, valaddr + embedded_offset);
c906108c
SS
482 if (addr == 0)
483 {
484 fputs_filtered ("null", stream);
d3eab38a 485 return;
c906108c
SS
486 }
487 target_type = check_typedef (TYPE_TARGET_TYPE (type));
488
489 if (TYPE_CODE (target_type) == TYPE_CODE_FUNC)
490 {
491 /* Try to print what function it points to. */
edf0c1b7 492 print_address_demangle (options, gdbarch, addr, stream, demangle);
d3eab38a 493 return;
c906108c
SS
494 }
495
79a45b7d 496 if (options->addressprint && options->format != 's')
c906108c
SS
497 {
498 fputs_filtered ("@", stream);
499 print_longest (stream, 'x', 0, (ULONGEST) addr);
500 }
501
d3eab38a 502 return;
c906108c
SS
503
504 case TYPE_CODE_CHAR:
c906108c 505 case TYPE_CODE_INT:
c55a3f73
TT
506 /* Can't just call c_val_print because that prints bytes as C
507 chars. */
79a45b7d
TT
508 if (options->format || options->output_format)
509 {
510 struct value_print_options opts = *options;
e0881a8e 511
79a45b7d
TT
512 opts.format = (options->format ? options->format
513 : options->output_format);
ab2188aa
PA
514 val_print_scalar_formatted (type, valaddr, embedded_offset,
515 val, &opts, 0, stream);
79a45b7d 516 }
c55a3f73
TT
517 else if (TYPE_CODE (type) == TYPE_CODE_CHAR
518 || (TYPE_CODE (type) == TYPE_CODE_INT
519 && TYPE_LENGTH (type) == 2
520 && strcmp (TYPE_NAME (type), "char") == 0))
490f124f
PA
521 LA_PRINT_CHAR ((int) unpack_long (type, valaddr + embedded_offset),
522 type, stream);
c906108c 523 else
490f124f 524 val_print_type_code_int (type, valaddr + embedded_offset, stream);
c906108c
SS
525 break;
526
527 case TYPE_CODE_STRUCT:
490f124f
PA
528 java_print_value_fields (type, valaddr, embedded_offset,
529 address, stream, recurse, val, options);
c906108c
SS
530 break;
531
532 default:
d3eab38a
TT
533 c_val_print (type, valaddr, embedded_offset, address, stream,
534 recurse, val, options);
535 break;
c906108c 536 }
c906108c 537}
This page took 1.322571 seconds and 4 git commands to generate.