summaryrefslogtreecommitdiffstats
path: root/commands/command_edit.cpp
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.cpp
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.cpp')
-rw-r--r--commands/command_edit.cpp84
1 files changed, 14 insertions, 70 deletions
diff --git a/commands/command_edit.cpp b/commands/command_edit.cpp
index 999396db2..d41f595dc 100644
--- a/commands/command_edit.cpp
+++ b/commands/command_edit.cpp
@@ -26,6 +26,18 @@ DiveField EditTagsTemplate<ID>::fieldId() const
return ID;
}
+template <typename T, DiveField::Flags ID, T dive::*PTR>
+void EditDefaultSetter<T, ID, PTR>::set(struct dive *d, T v) const
+{
+ d->*PTR = v;
+}
+
+template <typename T, DiveField::Flags ID, T dive::*PTR>
+T EditDefaultSetter<T, ID, PTR>::data(struct dive *d) const
+{
+ return d->*PTR;
+}
+
static std::vector<dive *> getDives(bool currentDiveOnly)
{
if (currentDiveOnly)
@@ -147,6 +159,8 @@ EditBase<QString>::EditBase(QString newValue, bool currentDiveOnly);
template
EditBase<int>::EditBase(int newValue, bool currentDiveOnly);
template
+EditBase<bool>::EditBase(bool newValue, bool currentDiveOnly);
+template
EditBase<struct dive_site *>::EditBase(struct dive_site *newValue, bool currentDiveOnly);
// Undo and redo do the same as just the stored value is exchanged
@@ -196,96 +210,36 @@ QString EditSuit::fieldName() const
}
// ***** Rating *****
-void EditRating::set(struct dive *d, int value) const
-{
- d->rating = value;
-}
-
-int EditRating::data(struct dive *d) const
-{
- return d->rating;
-}
-
QString EditRating::fieldName() const
{
return Command::Base::tr("rating");
}
// ***** Visibility *****
-void EditVisibility::set(struct dive *d, int value) const
-{
- d->visibility = value;
-}
-
-int EditVisibility::data(struct dive *d) const
-{
- return d->visibility;
-}
-
QString EditVisibility::fieldName() const
{
return Command::Base::tr("visibility");
}
// ***** WaveSize *****
-void EditWaveSize::set(struct dive *d, int value) const
-{
- d->wavesize = value;
-}
-
-int EditWaveSize::data(struct dive *d) const
-{
- return d->wavesize;
-}
-
QString EditWaveSize::fieldName() const
{
return Command::Base::tr("wavesize");
}
// ***** Current *****
-void EditCurrent::set(struct dive *d, int value) const
-{
- d->current = value;
-}
-
-int EditCurrent::data(struct dive *d) const
-{
- return d->current;
-}
-
QString EditCurrent::fieldName() const
{
return Command::Base::tr("current");
}
// ***** Surge *****
-void EditSurge::set(struct dive *d, int value) const
-{
- d->surge = value;
-}
-
-int EditSurge::data(struct dive *d) const
-{
- return d->surge;
-}
-
QString EditSurge::fieldName() const
{
return Command::Base::tr("surge");
}
// ***** Chill *****
-void EditChill::set(struct dive *d, int value) const
-{
- d->chill = value;
-}
-
-int EditChill::data(struct dive *d) const
-{
- return d->chill;
-}
-
QString EditChill::fieldName() const
{
return Command::Base::tr("chill");
@@ -507,16 +461,6 @@ QString EditMode::fieldName() const
}
// ***** Invalid *****
-void EditInvalid::set(struct dive *d, int invalid) const
-{
- d->invalid = invalid;
-}
-
-int EditInvalid::data(struct dive *d) const
-{
- return d->invalid;
-}
-
QString EditInvalid::fieldName() const
{
return Command::Base::tr("invalid");