summaryrefslogtreecommitdiffstats
path: root/desktop-widgets/divelistview.cpp
diff options
context:
space:
mode:
Diffstat (limited to 'desktop-widgets/divelistview.cpp')
-rw-r--r--desktop-widgets/divelistview.cpp34
1 files changed, 11 insertions, 23 deletions
diff --git a/desktop-widgets/divelistview.cpp b/desktop-widgets/divelistview.cpp
index 27b7e3ed9..4d68baca2 100644
--- a/desktop-widgets/divelistview.cpp
+++ b/desktop-widgets/divelistview.cpp
@@ -20,7 +20,7 @@
#include <QMessageBox>
#include <QHeaderView>
#include "core/qthelper.h"
-#include "desktop-widgets/undocommands.h"
+#include "desktop-widgets/command.h"
#include "desktop-widgets/divelistview.h"
#include "qt-models/divepicturemodel.h"
#include "core/metrics.h"
@@ -633,10 +633,8 @@ void DiveListView::mergeDives()
if (current_batch.count() > 1)
merge_batches.append(current_batch);
- for (const QVector<dive *> &batch: merge_batches) {
- UndoMergeDives *undoCommand = new UndoMergeDives(batch);
- MainWindow::instance()->undoStack->push(undoCommand);
- }
+ for (const QVector<dive *> &batch: merge_batches)
+ Command::mergeDives(batch);
}
void DiveListView::splitDives()
@@ -650,10 +648,8 @@ void DiveListView::splitDives()
if (dive->selected)
dives.append(dive);
}
- for (struct dive *d: dives) {
- UndoSplitDives *undoCommand = new UndoSplitDives(d, duration_t{-1});
- MainWindow::instance()->undoStack->push(undoCommand);
- }
+ for (struct dive *d: dives)
+ Command::splitDives(d, duration_t{-1});
}
void DiveListView::renumberDives()
@@ -671,8 +667,7 @@ void DiveListView::merge_trip(const QModelIndex &a, int offset)
dive_trip_t *trip_b = (dive_trip_t *)b.data(DiveTripModel::TRIP_ROLE).value<void *>();
if (trip_a == trip_b || !trip_a || !trip_b)
return;
- UndoMergeTrips *undoCommand = new UndoMergeTrips(trip_a, trip_b);
- MainWindow::instance()->undoStack->push(undoCommand);
+ Command::mergeTrips(trip_a, trip_b);
rememberSelection();
reload(currentLayout, false);
restoreSelection();
@@ -700,11 +695,7 @@ void DiveListView::removeFromTrip()
if (d->selected && d->divetrip)
divesToRemove.append(d);
}
- if (divesToRemove.isEmpty())
- return;
-
- UndoRemoveDivesFromTrip *undoCommand = new UndoRemoveDivesFromTrip(divesToRemove);
- MainWindow::instance()->undoStack->push(undoCommand);
+ Command::removeDivesFromTrip(divesToRemove);
rememberSelection();
reload(currentLayout, false);
@@ -725,8 +716,7 @@ void DiveListView::newTripAbove()
if (d->selected)
dives.append(d);
}
- UndoCreateTrip *undoCommand = new UndoCreateTrip(dives);
- MainWindow::instance()->undoStack->push(undoCommand);
+ Command::createTrip(dives);
reload(currentLayout, false);
mark_divelist_changed(true);
@@ -774,8 +764,7 @@ void DiveListView::addToTrip(int delta)
dives.append(d);
}
}
- UndoAddDivesToTrip *undoEntry = new UndoAddDivesToTrip(dives, trip);
- MainWindow::instance()->undoStack->push(undoEntry);
+ Command::addDivesToTrip(dives, trip);
reload(currentLayout, false);
restoreSelection();
@@ -814,7 +803,7 @@ void DiveListView::deleteDive()
int i;
int lastDiveNr = -1;
- QVector<struct dive*> deletedDives; //a list of all deleted dives to be stored in the undo command
+ QVector<struct dive*> deletedDives;
for_each_dive (i, d) {
if (!d->selected)
continue;
@@ -822,8 +811,7 @@ void DiveListView::deleteDive()
lastDiveNr = i;
}
// the actual dive deletion is happening in the redo command that is implicitly triggered
- UndoDeleteDive *undoEntry = new UndoDeleteDive(deletedDives);
- MainWindow::instance()->undoStack->push(undoEntry);
+ Command::deleteDive(deletedDives);
if (amount_selected == 0) {
MainWindow::instance()->cleanUpEmpty();
}