diff options
Diffstat (limited to 'gdb/break-catch-throw.c')
-rw-r--r-- | gdb/break-catch-throw.c | 13 |
1 files changed, 10 insertions, 3 deletions
diff --git a/gdb/break-catch-throw.c b/gdb/break-catch-throw.c index 927176f..9449aa5 100644 --- a/gdb/break-catch-throw.c +++ b/gdb/break-catch-throw.c @@ -35,6 +35,7 @@ #include "cp-abi.h" #include "gdb_regex.h" #include "cp-support.h" +#include "location.h" /* Enums for exception-handling support. */ enum exception_event_kind @@ -210,25 +211,31 @@ re_set_exception_catchpoint (struct breakpoint *self) struct symtabs_and_lines sals_end = {0}; struct cleanup *cleanup; enum exception_event_kind kind = classify_exception_breakpoint (self); + struct event_location *location; /* We first try to use the probe interface. */ TRY { char *spec = ASTRDUP (exception_functions[kind].probe); - sals = parse_probes (&spec, NULL); + location = new_linespec_location (&spec); + cleanup = make_cleanup_delete_event_location (location); + sals = parse_probes (location, NULL); + do_cleanups (cleanup); } CATCH (e, RETURN_MASK_ERROR) { - /* Using the probe interface failed. Let's fallback to the normal catchpoint mode. */ TRY { char *spec = ASTRDUP (exception_functions[kind].function); - self->ops->decode_location (self, &spec, &sals); + location = new_linespec_location (&spec); + cleanup = make_cleanup_delete_event_location (location); + self->ops->decode_location (self, location, &sals); + do_cleanups (cleanup); } CATCH (ex, RETURN_MASK_ERROR) { |