diff options
author | Tom Tromey <tromey@redhat.com> | 2013-04-15 18:13:00 +0000 |
---|---|---|
committer | Tom Tromey <tromey@redhat.com> | 2013-04-15 18:13:00 +0000 |
commit | 37d0d838c6e9e7b9a6464afdecce2cdbfdae4413 (patch) | |
tree | c48de9ea76e7b95d90a049c8241fec69e32527a8 /gdb/cp-abi.c | |
parent | 28af0d6627b6dd8059011ea5ba8ca81ce6530673 (diff) | |
download | gdb-37d0d838c6e9e7b9a6464afdecce2cdbfdae4413.tar.gz |
PR c++/13588:
* NEWS: Update.
* break-catch-throw.c (struct exception_catchpoint)
<exception_rx, pattern>: New fields.
(fetch_probe_arguments, dtor_exception_catchpoint)
(check_status_exception_catchpoint)
(print_one_detail_exception_catchpoint): New functions.
(handle_gnu_v3_exceptions): Add "except_rx" argument.
Compile regular expression if needed.
(extract_exception_regexp): New function.
(catch_exception_command_1): Use extract_exception_regexp.
(compute_exception): Use fetch_probe_arguments.
(initialize_throw_catchpoint_ops): Set dtor, print_one_detail,
and check_status fields.
* cp-abi.c (cplus_typename_from_type_info): New function.
* cp-abi.h (cplus_typename_from_type_info): Declare.
(struct cp_abi_ops) <get_typename_from_type_info>: New field.
* gdb_regex.h (compile_rx_or_error): Declare.
* gnu-v3-abi.c (gnuv3_get_typename_from_type_info): Update
comment.
(init_gnuv3_ops): Set get_type_from_type_info field.
* probe.c (compile_rx_or_error): Move...
* utils.c (compile_rx_or_error): ... here.
gdb/doc
* gdb.texinfo (Set Catchpoints): Document regexp syntax for
exception catchpoints.
gdb/testsuite
* gdb.cp/exceptprint.exp: Add regexp catchpoint tests.
Diffstat (limited to 'gdb/cp-abi.c')
-rw-r--r-- | gdb/cp-abi.c | 11 |
1 files changed, 11 insertions, 0 deletions
diff --git a/gdb/cp-abi.c b/gdb/cp-abi.c index a15e35902a0..2540eca17aa 100644 --- a/gdb/cp-abi.c +++ b/gdb/cp-abi.c @@ -209,6 +209,17 @@ cplus_type_from_type_info (struct value *value) return (*current_cp_abi.get_type_from_type_info) (value); } +/* See cp-abi.h. */ + +char * +cplus_typename_from_type_info (struct value *value) +{ + if (current_cp_abi.get_typename_from_type_info == NULL) + error (_("GDB cannot find the type name " + "from a std::type_info on this target")); + return (*current_cp_abi.get_typename_from_type_info) (value); +} + int cp_pass_by_reference (struct type *type) { |