On Thu, Feb 26, 2015 at 8:11 PM, Dirk Hohndel <[email protected]> wrote:

> Hi Grace...
>
>
> Would you mind redoing / resubmitting the patch?
>

Attached is the corrected patch.


>
> Thanks
>
> /D
>
From aa416922cb0b9a25fe2a02ef96576752645db4c9 Mon Sep 17 00:00:00 2001
From: Grace Karanja <[email protected]>
Date: Sat, 28 Feb 2015 07:42:37 +0300
Subject: [PATCH] Add ability to undo renumbering of dives

Expand the undo feature by storing a list of renumbered dives' ids
and numbers so that the original numbers can be restored if needed.

Signed-off-by: Grace Karanja <[email protected]>
---
 qt-ui/simplewidgets.cpp | 13 +++++++++++--
 qt-ui/undocommands.cpp  | 31 +++++++++++++++++++++++++++++++
 qt-ui/undocommands.h    | 12 ++++++++++++
 3 files changed, 54 insertions(+), 2 deletions(-)

diff --git a/qt-ui/simplewidgets.cpp b/qt-ui/simplewidgets.cpp
index f7944c9..003fc05 100644
--- a/qt-ui/simplewidgets.cpp
+++ b/qt-ui/simplewidgets.cpp
@@ -142,8 +142,17 @@ void RenumberDialog::renumberOnlySelected(bool selected)
 
 void RenumberDialog::buttonClicked(QAbstractButton *button)
 {
-	if (ui.buttonBox->buttonRole(button) == QDialogButtonBox::AcceptRole)
-		renumber_dives(ui.spinBox->value(), selectedOnly);
+	if (ui.buttonBox->buttonRole(button) == QDialogButtonBox::AcceptRole) {
+		QMap<int,int> renumberedDives;
+		int i;
+		struct dive *dive = NULL;
+		for_each_dive (i, dive) {
+			if (!selectedOnly || dive->selected)
+				renumberedDives.insert(dive->id, dive->number);
+		}
+		UndoRenumberDives *undoCommand = new UndoRenumberDives(renumberedDives, ui.spinBox->value());
+		MainWindow::instance()->undoStack->push(undoCommand);
+	}
 }
 
 RenumberDialog::RenumberDialog(QWidget *parent) : QDialog(parent), selectedOnly(false)
diff --git a/qt-ui/undocommands.cpp b/qt-ui/undocommands.cpp
index 316def4..6a15f7e 100644
--- a/qt-ui/undocommands.cpp
+++ b/qt-ui/undocommands.cpp
@@ -62,3 +62,34 @@ void UndoShiftTime::redo()
 	mark_divelist_changed(true);
 	MainWindow::instance()->refreshDisplay();
 }
+
+
+UndoRenumberDives::UndoRenumberDives(QMap<int, int> originalNumbers, int startNumber)
+{
+	oldNumbers = originalNumbers;
+	start = startNumber;
+	setText("renumber dive");
+	if (oldNumbers.count() > 1)
+		setText(QString("renumber %1 dives").arg(QString::number(oldNumbers.count())));
+}
+
+void UndoRenumberDives::undo()
+{
+	foreach (int key, oldNumbers.keys()) {
+		struct dive* d = get_dive_by_uniq_id(key);
+		d->number = oldNumbers.value(key);
+	}
+	mark_divelist_changed(true);
+	MainWindow::instance()->refreshDisplay();
+}
+
+void UndoRenumberDives::redo()
+{
+	int i = start;
+	foreach (int key, oldNumbers.keys()) {
+		struct dive* d = get_dive_by_uniq_id(key);
+		d->number = i++;
+	}
+	mark_divelist_changed(true);
+	MainWindow::instance()->refreshDisplay();
+}
diff --git a/qt-ui/undocommands.h b/qt-ui/undocommands.h
index addef81..36c789f 100644
--- a/qt-ui/undocommands.h
+++ b/qt-ui/undocommands.h
@@ -2,6 +2,7 @@
 #define UNDOCOMMANDS_H
 
 #include <QUndoCommand>
+#include <QMap>
 #include "dive.h"
 
 class UndoDeleteDive : public QUndoCommand {
@@ -25,4 +26,15 @@ private:
 	int timeChanged;
 };
 
+class UndoRenumberDives : public QUndoCommand {
+public:
+	UndoRenumberDives(QMap<int,int> originalNumbers, int startNumber);
+	virtual void undo();
+	virtual void redo();
+
+private:
+	QMap<int,int> oldNumbers;
+	int start;
+};
+
 #endif // UNDOCOMMANDS_H
-- 
2.1.0

_______________________________________________
subsurface mailing list
[email protected]
http://lists.subsurface-divelog.org/cgi-bin/mailman/listinfo/subsurface

Reply via email to