]> git.ipfire.org Git - thirdparty/binutils-gdb.git/blame - gdb/jv-valprint.c
gdb/
[thirdparty/binutils-gdb.git] / gdb / jv-valprint.c
CommitLineData
c906108c 1/* Support for printing Java values for GDB, the GNU debugger.
1e4728e7 2
0b302171 3 Copyright (C) 1997-2005, 2007-2012 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"
309367d4 32#include "gdb_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
79a45b7d 302 if (options->pretty)
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 {
79a45b7d 344 if (options->pretty)
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
79a45b7d 355 if (options->pretty)
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 }
79a45b7d 364 if (options->inspect_it)
c906108c
SS
365 {
366 if (TYPE_CODE (TYPE_FIELD_TYPE (type, i)) == TYPE_CODE_PTR)
367 fputs_filtered ("\"( ptr \"", stream);
368 else
369 fputs_filtered ("\"( nodef \"", stream);
d6a843b5 370 if (field_is_static (&TYPE_FIELD (type, i)))
c906108c
SS
371 fputs_filtered ("static ", stream);
372 fprintf_symbol_filtered (stream, TYPE_FIELD_NAME (type, i),
373 language_cplus,
374 DMGL_PARAMS | DMGL_ANSI);
375 fputs_filtered ("\" \"", stream);
376 fprintf_symbol_filtered (stream, TYPE_FIELD_NAME (type, i),
377 language_cplus,
378 DMGL_PARAMS | DMGL_ANSI);
379 fputs_filtered ("\") \"", stream);
380 }
381 else
382 {
383 annotate_field_begin (TYPE_FIELD_TYPE (type, i));
384
d6a843b5 385 if (field_is_static (&TYPE_FIELD (type, i)))
c906108c
SS
386 fputs_filtered ("static ", stream);
387 fprintf_symbol_filtered (stream, TYPE_FIELD_NAME (type, i),
388 language_cplus,
389 DMGL_PARAMS | DMGL_ANSI);
390 annotate_field_name_end ();
391 fputs_filtered (": ", stream);
392 annotate_field_value ();
393 }
394
d6a843b5
JK
395 if (!field_is_static (&TYPE_FIELD (type, i))
396 && TYPE_FIELD_PACKED (type, i))
c906108c 397 {
75c9979e 398 struct value *v;
c906108c
SS
399
400 /* Bitfields require special handling, especially due to byte
c5aa993b 401 order problems. */
c906108c
SS
402 if (TYPE_FIELD_IGNORE (type, i))
403 {
c5aa993b 404 fputs_filtered ("<optimized out or zero length>", stream);
c906108c 405 }
8cf6f0b1
TT
406 else if (value_bits_synthetic_pointer (val,
407 TYPE_FIELD_BITPOS (type,
408 i),
409 TYPE_FIELD_BITSIZE (type,
410 i)))
411 {
412 fputs_filtered (_("<synthetic pointer>"), stream);
413 }
0e03807e
TT
414 else if (!value_bits_valid (val, TYPE_FIELD_BITPOS (type, i),
415 TYPE_FIELD_BITSIZE (type, i)))
416 {
585fdaa1 417 val_print_optimized_out (stream);
0e03807e 418 }
c906108c
SS
419 else
420 {
79a45b7d
TT
421 struct value_print_options opts;
422
5467c6c8 423 v = value_field_bitfield (type, i, valaddr, offset, val);
c906108c 424
79a45b7d
TT
425 opts = *options;
426 opts.deref_ref = 0;
427 common_val_print (v, stream, recurse + 1,
428 &opts, current_language);
c906108c
SS
429 }
430 }
431 else
432 {
433 if (TYPE_FIELD_IGNORE (type, i))
434 {
c5aa993b 435 fputs_filtered ("<optimized out or zero length>", stream);
c906108c 436 }
d6a843b5 437 else if (field_is_static (&TYPE_FIELD (type, i)))
c906108c 438 {
75c9979e 439 struct value *v = value_static_field (type, i);
e0881a8e 440
c906108c 441 if (v == NULL)
585fdaa1 442 val_print_optimized_out (stream);
c906108c
SS
443 else
444 {
79a45b7d 445 struct value_print_options opts;
df407dfe 446 struct type *t = check_typedef (value_type (v));
e0881a8e 447
c906108c
SS
448 if (TYPE_CODE (t) == TYPE_CODE_STRUCT)
449 v = value_addr (v);
79a45b7d
TT
450 opts = *options;
451 opts.deref_ref = 0;
452 common_val_print (v, stream, recurse + 1,
453 &opts, current_language);
c906108c
SS
454 }
455 }
7a292a7a
SS
456 else if (TYPE_FIELD_TYPE (type, i) == NULL)
457 fputs_filtered ("<unknown type>", stream);
c906108c
SS
458 else
459 {
79a45b7d 460 struct value_print_options opts = *options;
e0881a8e 461
79a45b7d 462 opts.deref_ref = 0;
c5aa993b 463 val_print (TYPE_FIELD_TYPE (type, i),
490f124f
PA
464 valaddr,
465 offset + TYPE_FIELD_BITPOS (type, i) / 8,
466 address, stream, recurse + 1, val, &opts,
d8ca156b 467 current_language);
c906108c
SS
468 }
469 }
470 annotate_field_end ();
471 }
472
79a45b7d 473 if (options->pretty)
c906108c
SS
474 {
475 fprintf_filtered (stream, "\n");
476 print_spaces_filtered (2 * recurse, stream);
477 }
478 }
479 fprintf_filtered (stream, "}");
480}
481
32b72a42 482/* See val_print for a description of the various parameters of this
d3eab38a 483 function; they are identical. */
c906108c 484
d3eab38a 485void
fc1a4b47 486java_val_print (struct type *type, const gdb_byte *valaddr,
a2bd3dcd 487 int embedded_offset, CORE_ADDR address,
79a45b7d 488 struct ui_file *stream, int recurse,
0e03807e 489 const struct value *val,
79a45b7d 490 const struct value_print_options *options)
c906108c 491{
5af949e3 492 struct gdbarch *gdbarch = get_type_arch (type);
1777feb0 493 unsigned int i = 0; /* Number of characters printed. */
c906108c
SS
494 struct type *target_type;
495 CORE_ADDR addr;
496
497 CHECK_TYPEDEF (type);
498 switch (TYPE_CODE (type))
499 {
500 case TYPE_CODE_PTR:
79a45b7d 501 if (options->format && options->format != 's')
c906108c 502 {
ab2188aa
PA
503 val_print_scalar_formatted (type, valaddr, embedded_offset,
504 val, options, 0, stream);
c906108c
SS
505 break;
506 }
490f124f 507 addr = unpack_pointer (type, valaddr + embedded_offset);
c906108c
SS
508 if (addr == 0)
509 {
510 fputs_filtered ("null", stream);
d3eab38a 511 return;
c906108c
SS
512 }
513 target_type = check_typedef (TYPE_TARGET_TYPE (type));
514
515 if (TYPE_CODE (target_type) == TYPE_CODE_FUNC)
516 {
517 /* Try to print what function it points to. */
edf0c1b7 518 print_address_demangle (options, gdbarch, addr, stream, demangle);
d3eab38a 519 return;
c906108c
SS
520 }
521
79a45b7d 522 if (options->addressprint && options->format != 's')
c906108c
SS
523 {
524 fputs_filtered ("@", stream);
525 print_longest (stream, 'x', 0, (ULONGEST) addr);
526 }
527
d3eab38a 528 return;
c906108c
SS
529
530 case TYPE_CODE_CHAR:
c906108c 531 case TYPE_CODE_INT:
c55a3f73
TT
532 /* Can't just call c_val_print because that prints bytes as C
533 chars. */
79a45b7d
TT
534 if (options->format || options->output_format)
535 {
536 struct value_print_options opts = *options;
e0881a8e 537
79a45b7d
TT
538 opts.format = (options->format ? options->format
539 : options->output_format);
ab2188aa
PA
540 val_print_scalar_formatted (type, valaddr, embedded_offset,
541 val, &opts, 0, stream);
79a45b7d 542 }
c55a3f73
TT
543 else if (TYPE_CODE (type) == TYPE_CODE_CHAR
544 || (TYPE_CODE (type) == TYPE_CODE_INT
545 && TYPE_LENGTH (type) == 2
546 && strcmp (TYPE_NAME (type), "char") == 0))
490f124f
PA
547 LA_PRINT_CHAR ((int) unpack_long (type, valaddr + embedded_offset),
548 type, stream);
c906108c 549 else
490f124f 550 val_print_type_code_int (type, valaddr + embedded_offset, stream);
c906108c
SS
551 break;
552
553 case TYPE_CODE_STRUCT:
490f124f
PA
554 java_print_value_fields (type, valaddr, embedded_offset,
555 address, stream, recurse, val, options);
c906108c
SS
556 break;
557
558 default:
d3eab38a
TT
559 c_val_print (type, valaddr, embedded_offset, address, stream,
560 recurse, val, options);
561 break;
c906108c 562 }
c906108c 563}