diff options
author | Tom Tromey <tom@tromey.com> | 2017-08-19 22:26:20 -0600 |
---|---|---|
committer | Tom Tromey <tom@tromey.com> | 2017-08-22 09:38:07 -0600 |
commit | b270e6f9e09814c82e198859f218b37118eaf098 (patch) | |
tree | 1f123a9b425950be050f19ce29eedd9916832d58 /gdb/break-catch-sig.c | |
parent | 36bd8eaaa0afe3ff8e8b1b1b9edc9686f5c159e6 (diff) | |
download | binutils-b270e6f9e09814c82e198859f218b37118eaf098.zip binutils-b270e6f9e09814c82e198859f218b37118eaf098.tar.gz binutils-b270e6f9e09814c82e198859f218b37118eaf098.tar.bz2 |
Change install_breakpoint to take a std::unique_ptr
This changes install_breakpoint to take a std::unique_ptr rvalue-ref
argument. This makes it clear that install_breakpoint takes ownership
of the pointer, and prevents bugs like the one fixed by the previous
patch.
ChangeLog
2017-08-22 Tom Tromey <tom@tromey.com>
* breakpoint.h (install_breakpoint): Update.
* breakpoint.c (add_solib_catchpoint): Update.
(install_breakpoint): Change argument to a std::unique_ptr.
(create_fork_vfork_event_catchpoint): Use std::unique_ptr.
(create_breakpoint_sal, create_breakpoint): Update.
(watch_command_1, catch_exec_command_1)
(strace_marker_create_breakpoints_sal): Use std::unique_ptr.
(add_to_breakpoint_chain): Change argument to a std::unique_ptr.
Return the breakpoint.
(set_raw_breakpoint_without_location, set_raw_breakpoint)
(new_single_step_breakpoint): Update.
* break-catch-throw.c (handle_gnu_v3_exceptions): Use
std::unique_ptr.
* break-catch-syscall.c (create_syscall_event_catchpoint): Use
std::unique_ptr.
* break-catch-sig.c (create_signal_catchpoint): Use
std::unique_ptr.
* ada-lang.c (create_ada_exception_catchpoint): Use
std::unique_ptr.
Diffstat (limited to 'gdb/break-catch-sig.c')
-rw-r--r-- | gdb/break-catch-sig.c | 7 |
1 files changed, 3 insertions, 4 deletions
diff --git a/gdb/break-catch-sig.c b/gdb/break-catch-sig.c index 98888c9..9b8cf64 100644 --- a/gdb/break-catch-sig.c +++ b/gdb/break-catch-sig.c @@ -317,15 +317,14 @@ static void create_signal_catchpoint (int tempflag, std::vector<gdb_signal> &&filter, bool catch_all) { - struct signal_catchpoint *c; struct gdbarch *gdbarch = get_current_arch (); - c = new signal_catchpoint (); - init_catchpoint (c, gdbarch, tempflag, NULL, &signal_catchpoint_ops); + std::unique_ptr<signal_catchpoint> c (new signal_catchpoint ()); + init_catchpoint (c.get (), gdbarch, tempflag, NULL, &signal_catchpoint_ops); c->signals_to_be_caught = std::move (filter); c->catch_all = catch_all; - install_breakpoint (0, c, 1); + install_breakpoint (0, std::move (c), 1); } |