From a626888daa7215f5ffc15d100fde21a0b0ad55cb Mon Sep 17 00:00:00 2001 From: Diadlo Date: Tue, 5 Sep 2017 23:28:51 +0300 Subject: [PATCH] refactor(interface): Add connectTo_* virtual method instead of signals --- src/model/about/aboutfriend.cpp | 2 +- src/model/about/aboutfriend.h | 23 +++++++++++++++++++++++ src/model/about/iaboutfriend.h | 19 ++++++++++--------- src/model/interface.h | 19 +++++++++++++++++++ 4 files changed, 53 insertions(+), 10 deletions(-) create mode 100644 src/model/interface.h diff --git a/src/model/about/aboutfriend.cpp b/src/model/about/aboutfriend.cpp index 718a5bd1c..1524ddd26 100644 --- a/src/model/about/aboutfriend.cpp +++ b/src/model/about/aboutfriend.cpp @@ -89,7 +89,7 @@ void AboutFriend::setAutoGroupInvite(bool enabled) const ToxPk pk = f->getPublicKey(); Settings::getInstance().setAutoGroupInvite(pk, enabled); Settings::getInstance().savePersonal(); - emit autoGroupInviteChaged(enabled); + emit autoGroupInviteChanged(enabled); } bool AboutFriend::clearHistory() diff --git a/src/model/about/aboutfriend.h b/src/model/about/aboutfriend.h index 8cd98ccce..1e4b7fc9a 100644 --- a/src/model/about/aboutfriend.h +++ b/src/model/about/aboutfriend.h @@ -34,6 +34,29 @@ public: bool clearHistory() override; + CHANGED_SIGNAL_IMPL(QString, AboutFriend, name) + CHANGED_SIGNAL_IMPL(QString, AboutFriend, status) + CHANGED_SIGNAL_IMPL(QString, AboutFriend, publicKey) + + CHANGED_SIGNAL_IMPL(QPixmap, AboutFriend, avatar) + CHANGED_SIGNAL_IMPL(QString, AboutFriend, note) + + CHANGED_SIGNAL_IMPL(QString, AboutFriend, autoAcceptDir) + CHANGED_SIGNAL_IMPL(AutoAcceptCallFlags, AboutFriend, autoAcceptCall) + CHANGED_SIGNAL_IMPL(bool, AboutFriend, autoGroupInvite) + +signals: + void nameChanged(const QString& name); + void statusChanged(const QString& status); + void publicKeyChanged(const QString& pk); + + void avatarChanged(const QPixmap& avatar); + void noteChanged(const QString& val); + + void autoAcceptDirChanged(const QString& path); + void autoAcceptCallChanged(const AutoAcceptCallFlags& flag); + void autoGroupInviteChanged(const bool& enabled); + private: const Friend* const f; }; diff --git a/src/model/about/iaboutfriend.h b/src/model/about/iaboutfriend.h index 48d302b45..7e5233467 100644 --- a/src/model/about/iaboutfriend.h +++ b/src/model/about/iaboutfriend.h @@ -1,6 +1,7 @@ #ifndef I_ABOUT_FRIEND_H #define I_ABOUT_FRIEND_H +#include "src/model/interface.h" #include class IAboutFriend : public QObject @@ -37,17 +38,17 @@ public: virtual bool clearHistory() = 0; -signals: - void nameChanged(const QString& name) const; - void statusChanged(const QString& status) const; - void publicKeyChanged(const QString& pk) const; + /* signals */ + CHANGED_SIGNAL(QString, name); + CHANGED_SIGNAL(QString, status); + CHANGED_SIGNAL(QString, publicKey); - void avatarChanged(const QPixmap& avatar) const; - void noteChanged(const QString& note) const; + CHANGED_SIGNAL(QPixmap, avatar); + CHANGED_SIGNAL(QString, note); - void autoAcceptDirChanged(const QString& dir); - void autoAcceptCallChanged(AutoAcceptCall flag); - void autoGroupInviteChaged(bool enabled); + CHANGED_SIGNAL(QString, autoAcceptDir); + CHANGED_SIGNAL(AutoAcceptCallFlags, autoAcceptCall); + CHANGED_SIGNAL(bool, autoGroupInvite); }; #endif // I_ABOUT_FRIEND_H diff --git a/src/model/interface.h b/src/model/interface.h new file mode 100644 index 000000000..5bb68b3d1 --- /dev/null +++ b/src/model/interface.h @@ -0,0 +1,19 @@ +#ifndef INTERFACE_H +#define INTERFACE_H + +#include + +#define CHANGED_SIGNAL(type, name) \ + using Slot_##name = std::function; \ + virtual void connectTo_##name##Changed(Slot_##name slot) = 0; \ + virtual void connectTo_##name##Changed(QObject* handler, Slot_##name slot) = 0 + +#define CHANGED_SIGNAL_IMPL(type, classname, name) \ + void connectTo_##name##Changed(Slot_##name slot) override { \ + connect(this, &classname::name##Changed, slot); \ + } \ + void connectTo_##name##Changed(QObject* handler, Slot_##name slot) override { \ + connect(this, &classname::name##Changed, handler, slot); \ + } + +#endif // INTERFACE_H