aboutsummaryrefslogtreecommitdiff
path: root/gdb/tracepoint.h
diff options
context:
space:
mode:
authorSimon Marchi <simon.marchi@polymtl.ca>2018-04-07 14:03:12 -0400
committerSimon Marchi <simon.marchi@polymtl.ca>2018-04-07 14:03:12 -0400
commit6f14adc55864818ec3754460f5df4150c2addf42 (patch)
tree5ed8e7dccc5aeb3cc905394943a56fb21dddfaf9 /gdb/tracepoint.h
parentb2bdb8cf395f491319264cda42e41538f55a86d9 (diff)
downloadbinutils-6f14adc55864818ec3754460f5df4150c2addf42.zip
binutils-6f14adc55864818ec3754460f5df4150c2addf42.tar.gz
binutils-6f14adc55864818ec3754460f5df4150c2addf42.tar.bz2
Replace make_cleanup_restore_current_traceframe with RAII class
I put the constructor in tracepoint.c because it needs to read traceframe_number, and I prefer to do that than to expose traceframe_number. gdb/ChangeLog: * tracepoint.c (struct current_traceframe_cleanup): Remove. (do_restore_current_traceframe_cleanup): Remove. (restore_current_traceframe_cleanup_dtor): Remove. (make_cleanup_restore_current_traceframe): Remove. (scoped_restore_current_traceframe::scoped_restore_current_traceframe): New. * tracepoint.h (struct scoped_restore_current_traceframe): New. * infrun.c (fetch_inferior_event): Use scoped_restore_current_traceframe.
Diffstat (limited to 'gdb/tracepoint.h')
-rw-r--r--gdb/tracepoint.h17
1 files changed, 16 insertions, 1 deletions
diff --git a/gdb/tracepoint.h b/gdb/tracepoint.h
index 8613cb2..02f4bf7 100644
--- a/gdb/tracepoint.h
+++ b/gdb/tracepoint.h
@@ -321,7 +321,22 @@ extern int get_tracepoint_number (void);
etc.). */
extern void set_current_traceframe (int num);
-struct cleanup *make_cleanup_restore_current_traceframe (void);
+struct scoped_restore_current_traceframe
+{
+ scoped_restore_current_traceframe ();
+
+ ~scoped_restore_current_traceframe ()
+ {
+ set_current_traceframe (m_traceframe_number);
+ }
+
+ DISABLE_COPY_AND_ASSIGN (scoped_restore_current_traceframe);
+
+private:
+
+ /* The traceframe we were inspecting. */
+ int m_traceframe_number;
+};
void free_actions (struct breakpoint *);