summaryrefslogtreecommitdiffstats
path: root/qt-ui/undocommands.cpp
diff options
context:
space:
mode:
authorGravatar Dirk Hohndel <dirk@hohndel.org>2015-06-14 21:49:34 -0700
committerGravatar Dirk Hohndel <dirk@hohndel.org>2015-06-14 21:49:34 -0700
commit8d05c71ca2aaffeae46d41ecc7c854d33b0bcc8e (patch)
treee03383cfe649c7054337e4b6f0c0cace27da40d5 /qt-ui/undocommands.cpp
parenta524c01c3ff571641172a3bc393bb425dd15bc53 (diff)
downloadsubsurface-8d05c71ca2aaffeae46d41ecc7c854d33b0bcc8e.tar.gz
Fix renumbering of dives
The implementation in commit 182fe790c9e8 ("Add ability to undo renumbering of dives") looks perfectly reasonable, but it depends on an implementation detail: it assumes that the keys of the QMap are returned in the same order in which they were placed there. Which apparently isn't the case for some version of Qt. With this commit we simply remember both the old and the new number for each dive and therefore the order in which they are processed doesn't matter. Signed-off-by: Dirk Hohndel <dirk@hohndel.org>
Diffstat (limited to 'qt-ui/undocommands.cpp')
-rw-r--r--qt-ui/undocommands.cpp11
1 files changed, 5 insertions, 6 deletions
diff --git a/qt-ui/undocommands.cpp b/qt-ui/undocommands.cpp
index aad264e24..d7bae75a9 100644
--- a/qt-ui/undocommands.cpp
+++ b/qt-ui/undocommands.cpp
@@ -63,20 +63,20 @@ void UndoShiftTime::redo()
}
-UndoRenumberDives::UndoRenumberDives(QMap<int, int> originalNumbers, int startNumber)
+UndoRenumberDives::UndoRenumberDives(QMap<int, QPair<int, int> > originalNumbers)
{
oldNumbers = originalNumbers;
- start = startNumber;
- setText("renumber dive");
if (oldNumbers.count() > 1)
setText(QString("renumber %1 dives").arg(QString::number(oldNumbers.count())));
+ else
+ setText("renumber dive");
}
void UndoRenumberDives::undo()
{
foreach (int key, oldNumbers.keys()) {
struct dive* d = get_dive_by_uniq_id(key);
- d->number = oldNumbers.value(key);
+ d->number = oldNumbers.value(key).first;
}
mark_divelist_changed(true);
MainWindow::instance()->refreshDisplay();
@@ -84,10 +84,9 @@ void UndoRenumberDives::undo()
void UndoRenumberDives::redo()
{
- int i = start;
foreach (int key, oldNumbers.keys()) {
struct dive* d = get_dive_by_uniq_id(key);
- d->number = i++;
+ d->number = oldNumbers.value(key).second;
}
mark_divelist_changed(true);
MainWindow::instance()->refreshDisplay();