summaryrefslogtreecommitdiff
path: root/gdb/value.c
diff options
context:
space:
mode:
authorPedro Alves <palves@redhat.com>2011-09-02 12:18:27 +0000
committerPedro Alves <palves@redhat.com>2011-09-02 12:18:27 +0000
commitc709acd150761fffe3536bf9e6a0b32870f41ca3 (patch)
tree14191338cf67ccd74fc3c6f324e6364179628fc8 /gdb/value.c
parent86362dfd53fe65250e184a2bc443ea186a42f98f (diff)
downloadbinutils-gdb-c709acd150761fffe3536bf9e6a0b32870f41ca3.tar.gz
2011-09-02 Pedro Alves <pedro@codesourcery.com>
gdb/ * value.c (show_convenience): Catch errors thrown while printing each internal variable. * infrun.c (validate_siginfo_access): New function. (siginfo_value_read, siginfo_value_write): Call it.
Diffstat (limited to 'gdb/value.c')
-rw-r--r--gdb/value.c14
1 files changed, 12 insertions, 2 deletions
diff --git a/gdb/value.c b/gdb/value.c
index 5a8cc1f2634..087cdfd5c25 100644
--- a/gdb/value.c
+++ b/gdb/value.c
@@ -2095,13 +2095,23 @@ show_convenience (char *ignore, int from_tty)
get_user_print_options (&opts);
for (var = internalvars; var; var = var->next)
{
+ volatile struct gdb_exception ex;
+
if (!varseen)
{
varseen = 1;
}
printf_filtered (("$%s = "), var->name);
- value_print (value_of_internalvar (gdbarch, var), gdb_stdout,
- &opts);
+
+ TRY_CATCH (ex, RETURN_MASK_ERROR)
+ {
+ struct value *val;
+
+ val = value_of_internalvar (gdbarch, var);
+ value_print (val, gdb_stdout, &opts);
+ }
+ if (ex.reason < 0)
+ fprintf_filtered (gdb_stdout, _("<error: %s>"), ex.message);
printf_filtered (("\n"));
}
if (!varseen)