summaryrefslogtreecommitdiffstats
path: root/commands/command_edit.h
diff options
context:
space:
mode:
authorGravatar Berthold Stoeger <bstoeger@mail.tuwien.ac.at>2020-03-21 18:10:54 +0100
committerGravatar bstoeger <32835590+bstoeger@users.noreply.github.com>2020-03-31 21:53:19 +0200
commitea813938a838be57d6a616b0175d5d650fb8c2a2 (patch)
treef49d0bb9c6108d39da9ff9e1969699dbcc9aa751 /commands/command_edit.h
parentad540ce5e8f928c69ba8061dd9886bdb2936ed61 (diff)
downloadsubsurface-ea813938a838be57d6a616b0175d5d650fb8c2a2.tar.gz
undo: autogenerate trivial set() and data() functions by a template
Some dive-editing undo commands have trivial setter and getter functions: they simply read and write a struct dive member. Autogenerate these in a template to which we pass a pointer to member as template argument. For the invalid-flag we have to turn the edit command from int to bool, since that is how the flag is store in the dive struct. Sadly, quite a number of the setters do funky things and we cannot autogenerate them. Signed-off-by: Berthold Stoeger <bstoeger@mail.tuwien.ac.at>
Diffstat (limited to 'commands/command_edit.h')
-rw-r--r--commands/command_edit.h53
1 files changed, 24 insertions, 29 deletions
diff --git a/commands/command_edit.h b/commands/command_edit.h
index 8e9ca90e7..073853254 100644
--- a/commands/command_edit.h
+++ b/commands/command_edit.h
@@ -74,6 +74,16 @@ private:
DiveField fieldId() const override final; // final prevents further overriding - then just don't use this template
};
+// Automatically generate getter and setter in the case of simple assignments.
+// The third parameter is a pointer to a member of the dive structure.
+template <typename T, DiveField::Flags ID, T dive::*PTR>
+class EditDefaultSetter : public EditTemplate<T, ID> {
+private:
+ using EditTemplate<T, ID>::EditTemplate;
+ void set(struct dive *d, T) const override final; // final prevents further overriding - then just don't use this template
+ T data(struct dive *d) const override final; // final prevents further overriding - then just don't use this template
+};
+
class EditNotes : public EditTemplate<QString, DiveField::NOTES> {
public:
using EditTemplate::EditTemplate; // Use constructor of base class.
@@ -90,52 +100,39 @@ public:
QString fieldName() const override;
};
-class EditRating : public EditTemplate<int, DiveField::RATING> {
+class EditRating : public EditDefaultSetter<int, DiveField::RATING, &dive::rating> {
public:
- using EditTemplate::EditTemplate; // Use constructor of base class.
- void set(struct dive *d, int value) const override;
- int data(struct dive *d) const override;
+ using EditDefaultSetter::EditDefaultSetter; // Use constructor of base class.
QString fieldName() const override;
};
-class EditVisibility : public EditTemplate<int, DiveField::VISIBILITY> {
+class EditVisibility : public EditDefaultSetter<int, DiveField::VISIBILITY, &dive::visibility> {
public:
- using EditTemplate::EditTemplate; // Use constructor of base class.
- void set(struct dive *d, int value) const override;
- int data(struct dive *d) const override;
+ using EditDefaultSetter::EditDefaultSetter; // Use constructor of base class.
QString fieldName() const override;
};
-
-class EditWaveSize : public EditTemplate<int, DiveField::WAVESIZE> {
+class EditWaveSize : public EditDefaultSetter<int, DiveField::WAVESIZE, &dive::wavesize> {
public:
- using EditTemplate::EditTemplate; // Use constructor of base class.
- void set(struct dive *d, int value) const override;
- int data(struct dive *d) const override;
+ using EditDefaultSetter::EditDefaultSetter; // Use constructor of base class.
QString fieldName() const override;
};
-class EditCurrent : public EditTemplate<int, DiveField::CURRENT> {
+class EditCurrent : public EditDefaultSetter<int, DiveField::CURRENT, &dive::current> {
public:
- using EditTemplate::EditTemplate; // Use constructor of base class.
- void set(struct dive *d, int value) const override;
- int data(struct dive *d) const override;
+ using EditDefaultSetter::EditDefaultSetter; // Use constructor of base class.
QString fieldName() const override;
};
-class EditSurge : public EditTemplate<int, DiveField::SURGE> {
+class EditSurge : public EditDefaultSetter<int, DiveField::SURGE, &dive::surge> {
public:
- using EditTemplate::EditTemplate; // Use constructor of base class.
- void set(struct dive *d, int value) const override;
- int data(struct dive *d) const override;
+ using EditDefaultSetter::EditDefaultSetter; // Use constructor of base class.
QString fieldName() const override;
};
-class EditChill : public EditTemplate<int, DiveField::CHILL> {
+class EditChill : public EditDefaultSetter<int, DiveField::CHILL, &dive::chill> {
public:
- using EditTemplate::EditTemplate; // Use constructor of base class.
- void set(struct dive *d, int value) const override;
- int data(struct dive *d) const override;
+ using EditDefaultSetter::EditDefaultSetter; // Use constructor of base class.
QString fieldName() const override;
};
@@ -219,11 +216,9 @@ public:
QString fieldName() const override;
};
-class EditInvalid : public EditTemplate<int, DiveField::INVALID> {
+class EditInvalid : public EditDefaultSetter<bool, DiveField::INVALID, &dive::invalid> {
public:
- using EditTemplate::EditTemplate; // Use constructor of base class.
- void set(struct dive *d, int number) const override;
- int data(struct dive *d) const override;
+ using EditDefaultSetter::EditDefaultSetter; // Use constructor of base class.
QString fieldName() const override;
};