diff options
author | Paul Davis <paul@linuxaudiosystems.com> | 2008-11-24 22:48:25 +0000 |
---|---|---|
committer | Paul Davis <paul@linuxaudiosystems.com> | 2008-11-24 22:48:25 +0000 |
commit | 1f6f5da0032fb39238ad96436e7fd32840010954 (patch) | |
tree | 6ed2508a30964d403accd56b74ceae6f60f508b2 | |
parent | 510fc3ee463823b0d1e3a914060c5836b150a6f4 (diff) |
just a little something to blow your mind. comments explain all, if necessary, but if you're squeamish, i'd recommend you don't look
git-svn-id: svn://localhost/ardour2/branches/2.0-ongoing@4244 d708f5d6-7413-0410-9779-e7cbd77b26cf
-rw-r--r-- | libs/gtkmm2ext/gtkmm2ext/dndtreeview.h | 22 |
1 files changed, 22 insertions, 0 deletions
diff --git a/libs/gtkmm2ext/gtkmm2ext/dndtreeview.h b/libs/gtkmm2ext/gtkmm2ext/dndtreeview.h index 412eb69750..e7f4aeb83d 100644 --- a/libs/gtkmm2ext/gtkmm2ext/dndtreeview.h +++ b/libs/gtkmm2ext/gtkmm2ext/dndtreeview.h @@ -82,6 +82,15 @@ class DnDTreeView : public DnDTreeViewBase Gtk::TreeSelection::ListHandle_Path selection = get_selection()->get_selected_rows (); SerializedObjectPointers<DataType>* sr = serialize_pointers (get_model(), &selection, selection_data.get_target()); selection_data.set (8, (guchar*)sr, sr->size); + /* we don't need the allocated block anymore, + it will have been copied. this is wierd - + the objects we put into the block have + effectively been moved into the copy + made by Gtk::SelectionData::set(), + leaving our memory block a mere ghost. + we're just fixing a memory leak here. + */ + delete [] (reinterpret_cast<char*>(sr)); } } @@ -108,6 +117,19 @@ class DnDTreeView : public DnDTreeViewBase if (sr) { signal_object_drop (sr->type, sr->cnt, sr->data); + + /* now clean up the pointers in the blob. + Note that we make an explicit call + to the destructor rather than using + delete - the object does not own + the memory in which it lives - it + was allocated as a single contiguous + block (see below). + */ + + for (uint32_t x = 0; x < sr->cnt; ++x) { + sr->data[x].~DataType(); + } } } else { |