mirror of
https://github.com/espressif/binutils-gdb.git
synced 2025-06-02 04:20:46 +08:00
more making TRY/CATCH callers look more like real C++ try/catch blocks
All these were caught by actually making TRY/CATCH use try/catch behind the scenes, which then resulted in the build failing (on x86_64 Fedora 20) because there was code between the try and catch blocks. gdb/ChangeLog: 2015-03-07 Pedro Alves <palves@redhat.com> * breakpoint.c (save_breakpoints): Adjust to avoid code between TRY and CATCH. * gdbtypes.c (safe_parse_type): Remove empty line. (types_deeply_equal): * guile/scm-frame.c (gdbscm_frame_name): * linux-thread-db.c (find_new_threads_once): * python/py-breakpoint.c (bppy_get_commands): * record-btrace.c (record_btrace_insert_breakpoint) (record_btrace_remove_breakpoint, record_btrace_start_replaying) (record_btrace_start_replaying): Adjust to avoid code between TRY and CATCH.
This commit is contained in:
@ -2309,7 +2309,6 @@ safe_parse_type (struct gdbarch *gdbarch, char *p, int length)
|
||||
{
|
||||
type = parse_and_eval_type (p, length);
|
||||
}
|
||||
|
||||
CATCH (except, RETURN_MASK_ERROR)
|
||||
{
|
||||
type = builtin_type (gdbarch)->builtin_void;
|
||||
@ -3237,6 +3236,7 @@ check_types_worklist (VEC (type_equality_entry_d) **worklist,
|
||||
int
|
||||
types_deeply_equal (struct type *type1, struct type *type2)
|
||||
{
|
||||
struct gdb_exception except = exception_none;
|
||||
int result = 0;
|
||||
struct bcache *cache;
|
||||
VEC (type_equality_entry_d) *worklist = NULL;
|
||||
@ -3254,23 +3254,27 @@ types_deeply_equal (struct type *type1, struct type *type2)
|
||||
entry.type2 = type2;
|
||||
VEC_safe_push (type_equality_entry_d, worklist, &entry);
|
||||
|
||||
/* check_types_worklist calls several nested helper functions, some
|
||||
of which can raise a GDB exception, so we just check and rethrow
|
||||
here. If there is a GDB exception, a comparison is not capable
|
||||
(or trusted), so exit. */
|
||||
TRY
|
||||
{
|
||||
result = check_types_worklist (&worklist, cache);
|
||||
}
|
||||
/* check_types_worklist calls several nested helper functions,
|
||||
some of which can raise a GDB Exception, so we just check
|
||||
and rethrow here. If there is a GDB exception, a comparison
|
||||
is not capable (or trusted), so exit. */
|
||||
bcache_xfree (cache);
|
||||
VEC_free (type_equality_entry_d, worklist);
|
||||
/* Rethrow if there was a problem. */
|
||||
CATCH (except, RETURN_MASK_ALL)
|
||||
CATCH (ex, RETURN_MASK_ALL)
|
||||
{
|
||||
throw_exception (except);
|
||||
except = ex;
|
||||
}
|
||||
END_CATCH
|
||||
|
||||
bcache_xfree (cache);
|
||||
VEC_free (type_equality_entry_d, worklist);
|
||||
|
||||
/* Rethrow if there was a problem. */
|
||||
if (except.reason < 0)
|
||||
throw_exception (except);
|
||||
|
||||
return result;
|
||||
}
|
||||
|
||||
|
Reference in New Issue
Block a user