summaryrefslogtreecommitdiffstats
path: root/desktop-widgets/command_divelist.h
diff options
context:
space:
mode:
authorGravatar Berthold Stoeger <bstoeger@mail.tuwien.ac.at>2019-11-13 15:08:40 +0100
committerGravatar bstoeger <32835590+bstoeger@users.noreply.github.com>2019-11-14 21:02:07 +0100
commit5e29245e689fe9401ee1c33ebb07c601ce25e8c6 (patch)
treea656bcb0e9357b8cab78c5ad196fc6e5a4da4c31 /desktop-widgets/command_divelist.h
parent685b92b9c2ddd6575ae5df7c95b928e60fcd7005 (diff)
downloadsubsurface-5e29245e689fe9401ee1c33ebb07c601ce25e8c6.tar.gz
Refactoring: move undo commands to top level
In the future we might want to use undo-commands for mobile as well (even if not implementing undo). Therefore, move the undo-command source from desktop-widgets to their own commands top-level folder. Signed-off-by: Berthold Stoeger <bstoeger@mail.tuwien.ac.at>
Diffstat (limited to 'desktop-widgets/command_divelist.h')
-rw-r--r--desktop-widgets/command_divelist.h285
1 files changed, 0 insertions, 285 deletions
diff --git a/desktop-widgets/command_divelist.h b/desktop-widgets/command_divelist.h
deleted file mode 100644
index 20d031f54..000000000
--- a/desktop-widgets/command_divelist.h
+++ /dev/null
@@ -1,285 +0,0 @@
-// SPDX-License-Identifier: GPL-2.0
-// Note: this header file is used by the undo-machinery and should not be included elsewhere.
-
-#ifndef COMMAND_DIVELIST_H
-#define COMMAND_DIVELIST_H
-
-#include "command_base.h"
-
-#include <QVector>
-
-// We put everything in a namespace, so that we can shorten names without polluting the global namespace
-namespace Command {
-
-// This helper structure describes a dive that we want to add.
-struct DiveToAdd {
- OwningDivePtr dive; // Dive to add
- dive_trip *trip; // Trip the dive belongs to, may be null
- dive_site *site; // Site the dive is associated with, may be null
-};
-
-// Multiple trips, dives and dive sites that have to be added for a command
-struct DivesAndTripsToAdd {
- std::vector<DiveToAdd> dives;
- std::vector<OwningTripPtr> trips;
- std::vector<OwningDiveSitePtr> sites;
-};
-
-// Dives and sites that have to be removed for a command
-struct DivesAndSitesToRemove {
- std::vector<dive *> dives;
- std::vector<dive_site *> sites;
-};
-
-// This helper structure describes a dive that should be moved to / removed from
-// a trip. If the "trip" member is null, the dive is removed from its trip (if
-// it is in a trip, that is)
-struct DiveToTrip
-{
- struct dive *dive;
- dive_trip *trip;
-};
-
-// This helper structure describes a number of dives to add to / remove from /
-// move between trips.
-// It has ownership of the trips (if any) that have to be added before hand.
-struct DivesToTrip
-{
- std::vector<DiveToTrip> divesToMove; // If dive_trip is null, remove from trip
- std::vector<OwningTripPtr> tripsToAdd;
-};
-
-// All divelist commands derive from a common base class. It keeps track
-// of dive site counts that may have changed.
-// Derived classes implement the virtual methods redoit() and undoit()
-// [Yes, the names could be more expressive].
-class DiveListBase : public Base {
-protected:
- // These are helper functions to add / remove dive from the C-core structures.
- DiveToAdd removeDive(struct dive *d, std::vector<OwningTripPtr> &tripsToAdd);
- dive *addDive(DiveToAdd &d);
- DivesAndTripsToAdd removeDives(DivesAndSitesToRemove &divesAndSitesToDelete);
- DivesAndSitesToRemove addDives(DivesAndTripsToAdd &toAdd);
-
- // Register dive sites where counts changed so that we can signal the frontend later.
- void diveSiteCountChanged(struct dive_site *ds);
-
-private:
- // Keep track of dive sites where the number of dives changed
- std::vector<dive_site *> sitesCountChanged;
- void initWork();
- void finishWork(); // update dive site counts
- void undo() override;
- void redo() override;
- virtual void redoit() = 0;
- virtual void undoit() = 0;
-};
-
-class AddDive : public DiveListBase {
-public:
- AddDive(dive *dive, bool autogroup, bool newNumber);
-private:
- void undoit() override;
- void redoit() override;
- bool workToBeDone() override;
-
- // For redo
- // Note: we a multi-dive structure even though we add only a single dive, so
- // that we can reuse the multi-dive functions of the other commands.
- DivesAndTripsToAdd divesToAdd;
-
- // For undo
- DivesAndSitesToRemove divesAndSitesToRemove;
- std::vector<dive *> selection;
- dive * currentDive;
-};
-
-class ImportDives : public DiveListBase {
-public:
- // Note: dives and trips are consumed - after the call they will be empty.
- ImportDives(struct dive_table *dives, struct trip_table *trips, struct dive_site_table *sites, int flags, const QString &source);
-private:
- void undoit() override;
- void redoit() override;
- bool workToBeDone() override;
-
- // For redo and undo
- DivesAndTripsToAdd divesToAdd;
- DivesAndSitesToRemove divesAndSitesToRemove;
-
- // For redo
- std::vector<OwningDiveSitePtr> sitesToAdd;
-
- // For undo
- std::vector<dive_site *> sitesToRemove;
- std::vector<dive *> selection;
- dive * currentDive;
-};
-
-class DeleteDive : public DiveListBase {
-public:
- DeleteDive(const QVector<dive *> &divesToDelete);
-private:
- void undoit() override;
- void redoit() override;
- bool workToBeDone() override;
-
- // For redo
- DivesAndSitesToRemove divesToDelete;
-
- std::vector<OwningTripPtr> tripsToAdd;
- DivesAndTripsToAdd divesToAdd;
-};
-
-class ShiftTime : public DiveListBase {
-public:
- ShiftTime(const QVector<dive *> &changedDives, int amount);
-private:
- void undoit() override;
- void redoit() override;
- bool workToBeDone() override;
-
- // For redo and undo
- QVector<dive *> diveList;
- int timeChanged;
-};
-
-class RenumberDives : public DiveListBase {
-public:
- RenumberDives(const QVector<QPair<dive *, int>> &divesToRenumber);
-private:
- void undoit() override;
- void redoit() override;
- bool workToBeDone() override;
-
- // For redo and undo: pairs of dive-id / new number
- QVector<QPair<dive *, int>> divesToRenumber;
-};
-
-// The classes RemoveDivesFromTrip, RemoveAutogenTrips, CreateTrip, AutogroupDives
-// and MergeTrips all do the same thing, just the intialization differs.
-// Therefore, define a base class with the proper data-structures, redo()
-// and undo() functions and derive to specialize the initialization.
-class TripBase : public DiveListBase {
-protected:
- void undoit() override;
- void redoit() override;
- bool workToBeDone() override;
-
- // For redo and undo
- DivesToTrip divesToMove;
-};
-struct RemoveDivesFromTrip : public TripBase {
- RemoveDivesFromTrip(const QVector<dive *> &divesToRemove);
-};
-struct RemoveAutogenTrips : public TripBase {
- RemoveAutogenTrips();
-};
-struct AddDivesToTrip : public TripBase {
- AddDivesToTrip(const QVector<dive *> &divesToAdd, dive_trip *trip);
-};
-struct CreateTrip : public TripBase {
- CreateTrip(const QVector<dive *> &divesToAdd);
-};
-struct AutogroupDives : public TripBase {
- AutogroupDives();
-};
-struct MergeTrips : public TripBase {
- MergeTrips(dive_trip *trip1, dive_trip *trip2);
-};
-
-class SplitDivesBase : public DiveListBase {
-protected:
- SplitDivesBase(dive *old, std::array<dive *, 2> newDives);
-private:
- void undoit() override;
- void redoit() override;
- bool workToBeDone() override;
-
- // For redo
- // For each dive to split, we remove one from and put two dives into the backend
- // Note: we use a vector even though we split only a single dive, so
- // that we can reuse the multi-dive functions of the other commands.
- DivesAndSitesToRemove diveToSplit;
- DivesAndTripsToAdd splitDives;
-
- // For undo
- // For each dive to unsplit, we remove two dives from and add one into the backend
- // Note: we use a multi-dive structure even though we unsplit only a single dive, so
- // that we can reuse the multi-dive functions of the other commands.
- DivesAndTripsToAdd unsplitDive;
- DivesAndSitesToRemove divesToUnsplit;
-};
-
-class SplitDives : public SplitDivesBase {
-public:
- // If time is < 0, split at first surface interval
- SplitDives(dive *d, duration_t time);
-};
-
-class SplitDiveComputer : public SplitDivesBase {
-public:
- // If time is < 0, split at first surface interval
- SplitDiveComputer(dive *d, int dc_num);
-};
-
-// When manipulating dive computers (moving, deleting) we go the ineffective,
-// but simple and robust way: We keep two full copies of the dive (before and after).
-// Removing and readding assures that the dive stays at the correct
-// position in the list (the dive computer list is used for sorting dives).
-class DiveComputerBase : public DiveListBase {
-protected:
- // old_dive must be a dive known to the core.
- // new_dive must be new dive whose ownership is taken.
- DiveComputerBase(dive *old_dive, dive *new_dive, int dc_nr_after);
-private:
- void undoit() override;
- void redoit() override;
- bool workToBeDone() override;
-
-protected:
- // For redo and undo
- DivesAndTripsToAdd diveToAdd;
- DivesAndSitesToRemove diveToRemove;
- int dc_nr_before, dc_nr_after;
-};
-
-class MoveDiveComputerToFront : public DiveComputerBase {
-public:
- MoveDiveComputerToFront(dive *d, int dc_num);
-};
-
-class DeleteDiveComputer : public DiveComputerBase {
-public:
- DeleteDiveComputer(dive *d, int dc_num);
-};
-
-class MergeDives : public DiveListBase {
-public:
- MergeDives(const QVector<dive *> &dives);
-private:
- void undoit() override;
- void redoit() override;
- bool workToBeDone() override;
-
- // For redo
- // Add one and remove a batch of dives
- // Note: we use a multi-dives structure even though we add only a single dive, so
- // that we can reuse the multi-dive functions of the other commands.
- DivesAndTripsToAdd mergedDive;
- DivesAndSitesToRemove divesToMerge;
-
- // For undo
- // Remove one and add a batch of dives
- // Note: we use a vector even though we remove only a single dive, so
- // that we can reuse the multi-dive functions of the other commands.
- DivesAndSitesToRemove diveToUnmerge;
- DivesAndTripsToAdd unmergedDives;
-
- // For undo and redo
- QVector<QPair<dive *, int>> divesToRenumber;
-};
-
-} // namespace Command
-
-#endif // COMMAND_DIVELIST_H