diff options
author | Dirk Hohndel <dirk@hohndel.org> | 2015-06-14 21:49:34 -0700 |
---|---|---|
committer | Dirk Hohndel <dirk@hohndel.org> | 2015-06-14 21:49:34 -0700 |
commit | 8d05c71ca2aaffeae46d41ecc7c854d33b0bcc8e (patch) | |
tree | e03383cfe649c7054337e4b6f0c0cace27da40d5 /qt-ui/simplewidgets.cpp | |
parent | a524c01c3ff571641172a3bc393bb425dd15bc53 (diff) | |
download | subsurface-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/simplewidgets.cpp')
-rw-r--r-- | qt-ui/simplewidgets.cpp | 8 |
1 files changed, 5 insertions, 3 deletions
diff --git a/qt-ui/simplewidgets.cpp b/qt-ui/simplewidgets.cpp index 430609c7b..d060e3892 100644 --- a/qt-ui/simplewidgets.cpp +++ b/qt-ui/simplewidgets.cpp @@ -143,14 +143,16 @@ void RenumberDialog::renumberOnlySelected(bool selected) void RenumberDialog::buttonClicked(QAbstractButton *button) { if (ui.buttonBox->buttonRole(button) == QDialogButtonBox::AcceptRole) { - QMap<int,int> renumberedDives; + // we remember a map from dive uuid to a pair of old number / new number + QMap<int,QPair<int, int> > renumberedDives; int i; + int newNr = ui.spinBox->value(); struct dive *dive = NULL; for_each_dive (i, dive) { if (!selectedOnly || dive->selected) - renumberedDives.insert(dive->id, dive->number); + renumberedDives.insert(dive->id, QPair<int,int>(dive->number, newNr++)); } - UndoRenumberDives *undoCommand = new UndoRenumberDives(renumberedDives, ui.spinBox->value()); + UndoRenumberDives *undoCommand = new UndoRenumberDives(renumberedDives); MainWindow::instance()->undoStack->push(undoCommand); } } |