[v2,06/11] gdbserver: use unique_ptr for thread_info's regcache
Commit Message
Store the regcache pointer in thread_info as a unique_ptr. This
allows us delete the thread_info destructor.
---
gdbserver/gdbthread.h | 12 ++++--------
gdbserver/regcache.cc | 1 -
2 files changed, 4 insertions(+), 9 deletions(-)
@@ -21,6 +21,7 @@
#include "gdbsupport/function-view.h"
#include "gdbsupport/intrusive_list.h"
+#include <memory>
struct btrace_target_info;
struct regcache;
@@ -31,20 +32,15 @@ struct thread_info : public intrusive_list_node<thread_info>
: id (id), m_process (process), m_target_data (target_data)
{}
- ~thread_info ()
- {
- delete m_regcache;
- }
-
/* Return the process owning this thread. */
process_info *process () const
{ return m_process; }
struct regcache *regcache ()
- { return m_regcache; }
+ { return m_regcache.get (); }
void set_regcache (struct regcache *regcache)
- { m_regcache = regcache; }
+ { m_regcache.reset (regcache); }
void *target_data ()
{ return m_target_data; }
@@ -94,7 +90,7 @@ struct thread_info : public intrusive_list_node<thread_info>
private:
process_info *m_process;
- struct regcache *m_regcache = nullptr;
+ std::unique_ptr<struct regcache> m_regcache = nullptr;
void *m_target_data;
};
@@ -245,7 +245,6 @@ free_register_cache_thread (thread_info *thread)
if (regcache != NULL)
{
regcache_invalidate_thread (thread);
- delete regcache;
thread->set_regcache (nullptr);
}
}