diff options
author | Ulrich Weigand <uweigand@de.ibm.com> | 2008-09-11 14:19:44 +0000 |
---|---|---|
committer | Ulrich Weigand <uweigand@de.ibm.com> | 2008-09-11 14:19:44 +0000 |
commit | 8ca1c40ee1951a585d1fce1d78709979872acf81 (patch) | |
tree | 1d632a90e2616347962c8056ff2666a90133bcdc /gdb/ada-valprint.c | |
parent | 3cb382c9d3229a1c130a798240a908c683dacf1a (diff) | |
download | binutils-8ca1c40ee1951a585d1fce1d78709979872acf81.zip binutils-8ca1c40ee1951a585d1fce1d78709979872acf81.tar.gz binutils-8ca1c40ee1951a585d1fce1d78709979872acf81.tar.bz2 |
* ada-valprint.c: Include "objfiles.h".
(ada_val_print_1): Use the gdbarch associated with the objfile whether
a System.Address type is defined to retrieve the proper pointer type
to use to print it.
Diffstat (limited to 'gdb/ada-valprint.c')
-rw-r--r-- | gdb/ada-valprint.c | 16 |
1 files changed, 13 insertions, 3 deletions
diff --git a/gdb/ada-valprint.c b/gdb/ada-valprint.c index dbce8d3..0972367 100644 --- a/gdb/ada-valprint.c +++ b/gdb/ada-valprint.c @@ -33,6 +33,7 @@ #include "c-lang.h" #include "infcall.h" #include "exceptions.h" +#include "objfiles.h" /* Encapsulates arguments to ada_val_print. */ struct ada_val_print_args @@ -792,18 +793,27 @@ ada_val_print_1 (struct type *type, const gdb_byte *valaddr0, { print_scalar_formatted (valaddr, type, format, 0, stream); } - else if (ada_is_system_address_type (type)) + else if (ada_is_system_address_type (type) + && TYPE_OBJFILE (type) != NULL) { /* FIXME: We want to print System.Address variables using the same format as for any access type. But for some reason GNAT encodes the System.Address type as an int, so we have to work-around this deficiency by handling - System.Address values as a special case. */ + System.Address values as a special case. + + We do this only for System.Address types defined in an + objfile. For the built-in version of System.Address we + have installed the proper type to begin with. */ + + struct gdbarch *gdbarch = get_objfile_arch (TYPE_OBJFILE (type)); + struct type *ptr_type = builtin_type (gdbarch)->builtin_data_ptr; + fprintf_filtered (stream, "("); type_print (type, "", stream, -1); fprintf_filtered (stream, ") "); fputs_filtered (paddress (extract_typed_address - (valaddr, builtin_type_void_data_ptr)), + (valaddr, ptr_type)), stream); } else |