summaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
-rw-r--r--commands/command_edit.cpp35
-rw-r--r--commands/command_edit.h22
2 files changed, 27 insertions, 30 deletions
diff --git a/commands/command_edit.cpp b/commands/command_edit.cpp
index d41f595dc..e3ecf8cf8 100644
--- a/commands/command_edit.cpp
+++ b/commands/command_edit.cpp
@@ -38,6 +38,19 @@ T EditDefaultSetter<T, ID, PTR>::data(struct dive *d) const
return d->*PTR;
}
+template <DiveField::Flags ID, char *dive::*PTR>
+void EditStringSetter<ID, PTR>::set(struct dive *d, QString v) const
+{
+ free(d->*PTR);
+ d->*PTR = copy_qstring(v);
+}
+
+template <DiveField::Flags ID, char *dive::*PTR>
+QString EditStringSetter<ID, PTR>::data(struct dive *d) const
+{
+ return QString(d->*PTR);
+}
+
static std::vector<dive *> getDives(bool currentDiveOnly)
{
if (currentDiveOnly)
@@ -176,34 +189,12 @@ void EditBase<T>::redo()
// Implementation of virtual functions
// ***** Notes *****
-void EditNotes::set(struct dive *d, QString s) const
-{
- free(d->notes);
- d->notes = strdup(qPrintable(s));
-}
-
-QString EditNotes::data(struct dive *d) const
-{
- return QString(d->notes);
-}
-
QString EditNotes::fieldName() const
{
return Command::Base::tr("notes");
}
// ***** Suit *****
-void EditSuit::set(struct dive *d, QString s) const
-{
- free(d->suit);
- d->suit = strdup(qPrintable(s));
-}
-
-QString EditSuit::data(struct dive *d) const
-{
- return QString(d->suit);
-}
-
QString EditSuit::fieldName() const
{
return Command::Base::tr("suit");
diff --git a/commands/command_edit.h b/commands/command_edit.h
index 073853254..e10934704 100644
--- a/commands/command_edit.h
+++ b/commands/command_edit.h
@@ -84,19 +84,25 @@ private:
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> {
+// Automatically generate getter and setter in the case for string assignments.
+// The third parameter is a pointer to a C-style string in the dive structure.
+template <DiveField::Flags ID, char *dive::*PTR>
+class EditStringSetter : public EditTemplate<QString, ID> {
+private:
+ using EditTemplate<QString, ID>::EditTemplate;
+ void set(struct dive *d, QString) const override final; // final prevents further overriding - then just don't use this template
+ QString data(struct dive *d) const override final; // final prevents further overriding - then just don't use this template
+};
+
+class EditNotes : public EditStringSetter<DiveField::NOTES, &dive::notes> {
public:
- using EditTemplate::EditTemplate; // Use constructor of base class.
- void set(struct dive *d, QString s) const override;
- QString data(struct dive *d) const override;
+ using EditStringSetter::EditStringSetter; // Use constructor of base class.
QString fieldName() const override;
};
-class EditSuit : public EditTemplate<QString, DiveField::SUIT> {
+class EditSuit : public EditStringSetter<DiveField::SUIT, &dive::suit> {
public:
- using EditTemplate::EditTemplate; // Use constructor of base class.
- void set(struct dive *d, QString s) const override;
- QString data(struct dive *d) const override;
+ using EditStringSetter::EditStringSetter; // Use constructor of base class.
QString fieldName() const override;
};