forked from Imagelibrary/binutils-gdb
Rewrite TRY/CATCH
This rewrites gdb's TRY/CATCH to plain C++ try/catch. The patch was largely written by script, though one change (to a comment in common-exceptions.h) was reverted by hand. gdb/ChangeLog 2019-04-08 Tom Tromey <tom@tromey.com> * xml-support.c: Use C++ exception handling. * x86-linux-nat.c: Use C++ exception handling. * windows-nat.c: Use C++ exception handling. * varobj.c: Use C++ exception handling. * value.c: Use C++ exception handling. * valprint.c: Use C++ exception handling. * valops.c: Use C++ exception handling. * unittests/parse-connection-spec-selftests.c: Use C++ exception handling. * unittests/cli-utils-selftests.c: Use C++ exception handling. * typeprint.c: Use C++ exception handling. * tui/tui.c: Use C++ exception handling. * tracefile-tfile.c: Use C++ exception handling. * top.c: Use C++ exception handling. * thread.c: Use C++ exception handling. * target.c: Use C++ exception handling. * symmisc.c: Use C++ exception handling. * symfile-mem.c: Use C++ exception handling. * stack.c: Use C++ exception handling. * sparc64-linux-tdep.c: Use C++ exception handling. * solib.c: Use C++ exception handling. * solib-svr4.c: Use C++ exception handling. * solib-spu.c: Use C++ exception handling. * solib-frv.c: Use C++ exception handling. * solib-dsbt.c: Use C++ exception handling. * selftest-arch.c: Use C++ exception handling. * s390-tdep.c: Use C++ exception handling. * rust-lang.c: Use C++ exception handling. * rust-exp.y: Use C++ exception handling. * rs6000-tdep.c: Use C++ exception handling. * rs6000-aix-tdep.c: Use C++ exception handling. * riscv-tdep.c: Use C++ exception handling. * remote.c: Use C++ exception handling. * remote-fileio.c: Use C++ exception handling. * record-full.c: Use C++ exception handling. * record-btrace.c: Use C++ exception handling. * python/python.c: Use C++ exception handling. * python/py-value.c: Use C++ exception handling. * python/py-utils.c: Use C++ exception handling. * python/py-unwind.c: Use C++ exception handling. * python/py-type.c: Use C++ exception handling. * python/py-symbol.c: Use C++ exception handling. * python/py-record.c: Use C++ exception handling. * python/py-record-btrace.c: Use C++ exception handling. * python/py-progspace.c: Use C++ exception handling. * python/py-prettyprint.c: Use C++ exception handling. * python/py-param.c: Use C++ exception handling. * python/py-objfile.c: Use C++ exception handling. * python/py-linetable.c: Use C++ exception handling. * python/py-lazy-string.c: Use C++ exception handling. * python/py-infthread.c: Use C++ exception handling. * python/py-inferior.c: Use C++ exception handling. * python/py-gdb-readline.c: Use C++ exception handling. * python/py-framefilter.c: Use C++ exception handling. * python/py-frame.c: Use C++ exception handling. * python/py-finishbreakpoint.c: Use C++ exception handling. * python/py-cmd.c: Use C++ exception handling. * python/py-breakpoint.c: Use C++ exception handling. * python/py-arch.c: Use C++ exception handling. * printcmd.c: Use C++ exception handling. * ppc-linux-tdep.c: Use C++ exception handling. * parse.c: Use C++ exception handling. * p-valprint.c: Use C++ exception handling. * objc-lang.c: Use C++ exception handling. * mi/mi-main.c: Use C++ exception handling. * mi/mi-interp.c: Use C++ exception handling. * mi/mi-cmd-stack.c: Use C++ exception handling. * mi/mi-cmd-break.c: Use C++ exception handling. * main.c: Use C++ exception handling. * linux-thread-db.c: Use C++ exception handling. * linux-tdep.c: Use C++ exception handling. * linux-nat.c: Use C++ exception handling. * linux-fork.c: Use C++ exception handling. * linespec.c: Use C++ exception handling. * language.c: Use C++ exception handling. * jit.c: Use C++ exception handling. * infrun.c: Use C++ exception handling. * infcmd.c: Use C++ exception handling. * infcall.c: Use C++ exception handling. * inf-loop.c: Use C++ exception handling. * i386-tdep.c: Use C++ exception handling. * i386-linux-tdep.c: Use C++ exception handling. * guile/scm-value.c: Use C++ exception handling. * guile/scm-type.c: Use C++ exception handling. * guile/scm-symtab.c: Use C++ exception handling. * guile/scm-symbol.c: Use C++ exception handling. * guile/scm-pretty-print.c: Use C++ exception handling. * guile/scm-ports.c: Use C++ exception handling. * guile/scm-param.c: Use C++ exception handling. * guile/scm-math.c: Use C++ exception handling. * guile/scm-lazy-string.c: Use C++ exception handling. * guile/scm-frame.c: Use C++ exception handling. * guile/scm-disasm.c: Use C++ exception handling. * guile/scm-cmd.c: Use C++ exception handling. * guile/scm-breakpoint.c: Use C++ exception handling. * guile/scm-block.c: Use C++ exception handling. * guile/guile-internal.h: Use C++ exception handling. * gnu-v3-abi.c: Use C++ exception handling. * gdbtypes.c: Use C++ exception handling. * frame.c: Use C++ exception handling. * frame-unwind.c: Use C++ exception handling. * fbsd-tdep.c: Use C++ exception handling. * f-valprint.c: Use C++ exception handling. * exec.c: Use C++ exception handling. * event-top.c: Use C++ exception handling. * event-loop.c: Use C++ exception handling. * eval.c: Use C++ exception handling. * dwarf2read.c: Use C++ exception handling. * dwarf2loc.c: Use C++ exception handling. * dwarf2-frame.c: Use C++ exception handling. * dwarf2-frame-tailcall.c: Use C++ exception handling. * dwarf-index-write.c: Use C++ exception handling. * dwarf-index-cache.c: Use C++ exception handling. * dtrace-probe.c: Use C++ exception handling. * disasm-selftests.c: Use C++ exception handling. * darwin-nat.c: Use C++ exception handling. * cp-valprint.c: Use C++ exception handling. * cp-support.c: Use C++ exception handling. * cp-abi.c: Use C++ exception handling. * corelow.c: Use C++ exception handling. * completer.c: Use C++ exception handling. * compile/compile-object-run.c: Use C++ exception handling. * compile/compile-object-load.c: Use C++ exception handling. * compile/compile-cplus-symbols.c: Use C++ exception handling. * compile/compile-c-symbols.c: Use C++ exception handling. * common/selftest.c: Use C++ exception handling. * common/new-op.c: Use C++ exception handling. * cli/cli-script.c: Use C++ exception handling. * cli/cli-interp.c: Use C++ exception handling. * cli/cli-cmds.c: Use C++ exception handling. * c-varobj.c: Use C++ exception handling. * btrace.c: Use C++ exception handling. * breakpoint.c: Use C++ exception handling. * break-catch-throw.c: Use C++ exception handling. * arch-utils.c: Use C++ exception handling. * amd64-tdep.c: Use C++ exception handling. * ada-valprint.c: Use C++ exception handling. * ada-typeprint.c: Use C++ exception handling. * ada-lang.c: Use C++ exception handling. * aarch64-tdep.c: Use C++ exception handling. gdb/gdbserver/ChangeLog 2019-04-08 Tom Tromey <tom@tromey.com> * server.c: Use C++ exception handling. * linux-low.c: Use C++ exception handling. * gdbreplay.c: Use C++ exception handling.
This commit is contained in:
30
gdb/varobj.c
30
gdb/varobj.c
@@ -314,16 +314,15 @@ varobj_create (const char *objname,
|
||||
| INNERMOST_BLOCK_FOR_REGISTERS);
|
||||
/* Wrap the call to parse expression, so we can
|
||||
return a sensible error. */
|
||||
TRY
|
||||
try
|
||||
{
|
||||
var->root->exp = parse_exp_1 (&p, pc, block, 0, &tracker);
|
||||
}
|
||||
|
||||
CATCH (except, RETURN_MASK_ERROR)
|
||||
catch (const gdb_exception_RETURN_MASK_ERROR &except)
|
||||
{
|
||||
return NULL;
|
||||
}
|
||||
END_CATCH
|
||||
|
||||
/* Don't allow variables to be created for types. */
|
||||
if (var->root->exp->elts[0].opcode == OP_TYPE
|
||||
@@ -364,11 +363,11 @@ varobj_create (const char *objname,
|
||||
/* We definitely need to catch errors here.
|
||||
If evaluate_expression succeeds we got the value we wanted.
|
||||
But if it fails, we still go on with a call to evaluate_type(). */
|
||||
TRY
|
||||
try
|
||||
{
|
||||
value = evaluate_expression (var->root->exp.get ());
|
||||
}
|
||||
CATCH (except, RETURN_MASK_ERROR)
|
||||
catch (const gdb_exception_RETURN_MASK_ERROR &except)
|
||||
{
|
||||
/* Error getting the value. Try to at least get the
|
||||
right type. */
|
||||
@@ -376,7 +375,6 @@ varobj_create (const char *objname,
|
||||
|
||||
var->type = value_type (type_only_value);
|
||||
}
|
||||
END_CATCH
|
||||
|
||||
if (value != NULL)
|
||||
{
|
||||
@@ -1034,17 +1032,16 @@ varobj_set_value (struct varobj *var, const char *expression)
|
||||
|
||||
input_radix = 10; /* ALWAYS reset to decimal temporarily. */
|
||||
expression_up exp = parse_exp_1 (&s, 0, 0, 0);
|
||||
TRY
|
||||
try
|
||||
{
|
||||
value = evaluate_expression (exp.get ());
|
||||
}
|
||||
|
||||
CATCH (except, RETURN_MASK_ERROR)
|
||||
catch (const gdb_exception_RETURN_MASK_ERROR &except)
|
||||
{
|
||||
/* We cannot proceed without a valid expression. */
|
||||
return false;
|
||||
}
|
||||
END_CATCH
|
||||
|
||||
/* All types that are editable must also be changeable. */
|
||||
gdb_assert (varobj_value_is_changeable_p (var));
|
||||
@@ -1063,16 +1060,15 @@ varobj_set_value (struct varobj *var, const char *expression)
|
||||
|
||||
/* The new value may be lazy. value_assign, or
|
||||
rather value_contents, will take care of this. */
|
||||
TRY
|
||||
try
|
||||
{
|
||||
val = value_assign (var->value.get (), value);
|
||||
}
|
||||
|
||||
CATCH (except, RETURN_MASK_ERROR)
|
||||
catch (const gdb_exception_RETURN_MASK_ERROR &except)
|
||||
{
|
||||
return false;
|
||||
}
|
||||
END_CATCH
|
||||
|
||||
/* If the value has changed, record it, so that next -var-update can
|
||||
report this change. If a variable had a value of '1', we've set it
|
||||
@@ -1311,19 +1307,18 @@ install_new_value (struct varobj *var, struct value *value, bool initial)
|
||||
else
|
||||
{
|
||||
|
||||
TRY
|
||||
try
|
||||
{
|
||||
value_fetch_lazy (value);
|
||||
}
|
||||
|
||||
CATCH (except, RETURN_MASK_ERROR)
|
||||
catch (const gdb_exception_RETURN_MASK_ERROR &except)
|
||||
{
|
||||
/* Set the value to NULL, so that for the next -var-update,
|
||||
we don't try to compare the new value with this value,
|
||||
that we couldn't even read. */
|
||||
value = NULL;
|
||||
}
|
||||
END_CATCH
|
||||
}
|
||||
}
|
||||
|
||||
@@ -2139,14 +2134,13 @@ value_of_root_1 (struct varobj **var_handle)
|
||||
|
||||
/* We need to catch errors here, because if evaluate
|
||||
expression fails we want to just return NULL. */
|
||||
TRY
|
||||
try
|
||||
{
|
||||
new_val = evaluate_expression (var->root->exp.get ());
|
||||
}
|
||||
CATCH (except, RETURN_MASK_ERROR)
|
||||
catch (const gdb_exception_RETURN_MASK_ERROR &except)
|
||||
{
|
||||
}
|
||||
END_CATCH
|
||||
}
|
||||
|
||||
return new_val;
|
||||
|
||||
Reference in New Issue
Block a user