From d7d408a99e7459ec1a5fc2d9953e72924054b834 Mon Sep 17 00:00:00 2001 From: Berthold Stoeger Date: Sun, 24 Feb 2019 21:22:33 +0100 Subject: Undo: implement undo of dive trip editing This is copying the dive editing code. It uses an OO design with virtual functions for getting and setting the values. It doesn't use templates though, as both fields of strig type. This feels a bit over-engineered, but it is 1) consistent with the dive edit code and 2) the number / types of dive trip fields might increase. Signed-off-by: Berthold Stoeger --- desktop-widgets/command_edit_trip.h | 58 +++++++++++++++++++++++++++++++++++++ 1 file changed, 58 insertions(+) create mode 100644 desktop-widgets/command_edit_trip.h (limited to 'desktop-widgets/command_edit_trip.h') diff --git a/desktop-widgets/command_edit_trip.h b/desktop-widgets/command_edit_trip.h new file mode 100644 index 000000000..ae41ca252 --- /dev/null +++ b/desktop-widgets/command_edit_trip.h @@ -0,0 +1,58 @@ +// SPDX-License-Identifier: GPL-2.0 +// Note: this header file is used by the undo-machinery and should not be included elsewhere. + +#ifndef COMMAND_EDIT_TRIP_H +#define COMMAND_EDIT_TRIP_H + +#include "command_base.h" +#include "core/subsurface-qt/DiveListNotifier.h" + +#include + +// These are commands that edit individual fields of a a trip. +// The implementation follows the (rather verbose) OO-style of the dive-edit commands. +// But here, no template is used as the two fields are both of string type. + +// We put everything in a namespace, so that we can shorten names without polluting the global namespace +namespace Command { + +class EditTripBase : public Base { + bool workToBeDone() override; + + dive_trip *trip; // Trip to be edited. +public: + EditTripBase(dive_trip *trip, const QString &newValue); + +protected: + QString value; // Value to be set + void undo() override; + void redo() override; + + // Get and set functions to be overriden by sub-classes. + virtual void set(struct dive_trip *t, const QString &) const = 0; + virtual QString data(struct dive_trip *t) const = 0; + virtual QString fieldName() const = 0; // Name of the field, used to create the undo menu-entry + virtual TripField fieldId() const = 0; +}; + +class EditTripLocation : public EditTripBase { +public: + using EditTripBase::EditTripBase; // Use constructor of base class. + void set(dive_trip *t, const QString &s) const override; + QString data(dive_trip *t) const override; + QString fieldName() const override; + TripField fieldId() const override; +}; + +class EditTripNotes : public EditTripBase { +public: + using EditTripBase::EditTripBase; // Use constructor of base class. + void set(dive_trip *t, const QString &s) const override; + QString data(dive_trip *t) const override; + QString fieldName() const override; + TripField fieldId() const override; +}; + +} // namespace Command + +#endif -- cgit v1.2.3-70-g09d2