summaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
authorGravatar Berthold Stoeger <bstoeger@mail.tuwien.ac.at>2018-07-18 18:42:01 +0200
committerGravatar Lubomir I. Ivanov <neolit123@gmail.com>2018-07-19 02:43:08 +0300
commitb51e616b6a2af91f63cfa32d641d5898b10314ff (patch)
tree94d59245a3c09d829c258c84e5b3fd829ad1f60b
parent6c95714b9fc6af72b6d82564ac6f7f7148b8e5ed (diff)
downloadsubsurface-b51e616b6a2af91f63cfa32d641d5898b10314ff.tar.gz
Undo: clear list of trips to be recreated in UndoDeleteDive::undo()
UndoDeleteDive::tripList kept track of the trips to be recreated on undo. But the list wasn't cleared on undo, thus on subsequent redo the same trip was readded to the list, leading to double-free. This could trivially be reproduced by repeated CTRL-Z, CTRL-SHIFT-Z pairs. Signed-off-by: Berthold Stoeger <bstoeger@mail.tuwien.ac.at>
-rw-r--r--desktop-widgets/undocommands.cpp4
1 files changed, 3 insertions, 1 deletions
diff --git a/desktop-widgets/undocommands.cpp b/desktop-widgets/undocommands.cpp
index 2ac046d1c..0c1a4b541 100644
--- a/desktop-widgets/undocommands.cpp
+++ b/desktop-widgets/undocommands.cpp
@@ -33,6 +33,7 @@ void UndoDeleteDive::undo()
record_dive(diveList.at(i));
}
mark_divelist_changed(true);
+ tripList.clear();
MainWindow::instance()->refreshDisplay();
}
@@ -56,9 +57,10 @@ void UndoDeleteDive::redo()
undo_trip->dives = NULL;
// update all the dives who were in this trip to point to the copy of the
// trip that we are about to delete implicitly when deleting its last dive below
- Q_FOREACH(struct dive *inner_dive, newList)
+ Q_FOREACH(struct dive *inner_dive, newList) {
if (inner_dive->divetrip == d->divetrip)
inner_dive->divetrip = undo_trip;
+ }
d->divetrip = undo_trip;
tripList.append(undo_trip);
}