From d6a0b8c8e5ff91b7229bbcf5952d63253eab82c4 Mon Sep 17 00:00:00 2001 From: Dawid Drozd Date: Sun, 4 Sep 2016 17:10:46 +0200 Subject: [PATCH] Fix bug with getUniqueId Improve API Update old code --- src/Notification.cpp | 7 +++++ src/Notification.h | 65 +++++++++++++++++++++----------------------- src/Notifier.h | 45 +++++++++++++++++++++++++----- 3 files changed, 76 insertions(+), 41 deletions(-) create mode 100644 src/Notification.cpp diff --git a/src/Notification.cpp b/src/Notification.cpp new file mode 100644 index 0000000..17d17b9 --- /dev/null +++ b/src/Notification.cpp @@ -0,0 +1,7 @@ +// +// Created by Dawid Drozd aka Gelldur on 9/4/16. +// + +#include "Notification.h" + +int Dexode::_::_BaseNotification::_idGenerator = 0; diff --git a/src/Notification.h b/src/Notification.h index 06eb389..54ef00f 100644 --- a/src/Notification.h +++ b/src/Notification.h @@ -11,56 +11,53 @@ enum NotificationConst UNUSED_TAG = 0 }; -inline int getUniqueId() +namespace _ //Hide from autocomplete { - static int id = NotificationConst::UNUSED_TAG + 1; - return ++id; -} +class _BaseNotification +{ +public: + _BaseNotification() + : tag(++_idGenerator) + { + } -inline int getToken() -{ - return getUniqueId(); -} + virtual ~_BaseNotification() = default; + _BaseNotification& operator=(const _BaseNotification&) = delete; -template -inline int getTokenForType() -{ - static int id_for_type = getUniqueId(); - return id_for_type; + _BaseNotification& operator=(_BaseNotification&& notification) + { + tag = notification.tag; + return *this; + } + + _BaseNotification(const _BaseNotification& notification) + : tag(notification.tag) + { + } + + _BaseNotification(_BaseNotification&& notification) + : tag(notification.tag) + { + } + + int tag = NotificationConst::UNUSED_TAG; +private: + static int _idGenerator; +}; } template -class Notification +class Notification : public _::_BaseNotification { public: using Callback = std::function; //dummyInt used only for prevent creating unused notifications you should use MAKE_NOTIFICATION Notification(int dummyInt) - : tag(getUniqueId()) { assert(dummyInt == 691283); } - Notification& operator=(const Notification&) = delete; - - Notification& operator=(Notification&& notification) - { - tag = notification.tag; - return *this; - } - - Notification(const Notification& notification) - : tag(notification.tag) - { - } - - Notification(Notification&& notification) - : tag(notification.tag) - { - } - - int tag = NotificationConst::UNUSED_TAG; }; template diff --git a/src/Notifier.h b/src/Notifier.h index ada1c81..4760238 100644 --- a/src/Notifier.h +++ b/src/Notifier.h @@ -9,12 +9,16 @@ namespace Dexode { +template +struct notifier_traits +{ + typedef T type; +}; + class Notifier { public: - Notifier() - { - } + Notifier() = default; virtual ~Notifier() { @@ -38,10 +42,31 @@ public: return globalNotifier; } + /** + * Register listener for notification. Returns token used to unregister + * + * @param notification - pass notification like "getNotificationXYZ()" + * @param callback - your callback to handle notification + * @return token used to unregister + */ + template + int listen(const Notification& notification + , typename notifier_traits&>::type callback) + { + const int token = ++_tokener; + listen(token, notification, callback); + return token; + } + + /** + * @param token - unique token for identification receiver. Simply pass token from @see Notifier::listen + * @param notification - pass notification like "getNotificationXYZ()" + * @param callback - your callback to handle notification + */ template void listen(const int token - , const Notification& notification - , const std::function& callback) + , const Notification& notification + , typename notifier_traits&>::type callback) { using CallbackType = std::function; @@ -60,6 +85,9 @@ public: pVector->container.emplace_back(std::make_pair(callback, token)); } + /** + * @param token - token from Notifier::listen + */ void unlistenAll(const int token) { for (auto&& element : _callbacks) @@ -68,6 +96,10 @@ public: } } + /** + * @param token - token from Notifier::listen + * @param notification - notification you wan't to unlisten. @see Notiier::listen + */ template void unlisten(const int token, const NotificationType& notification) { @@ -103,9 +135,7 @@ public: } } -//////////////////////////////////////////////////////////////////////////////////////////////////// private: - struct VectorInterface { virtual ~VectorInterface() @@ -143,6 +173,7 @@ private: } }; + int _tokener = 0; std::map _callbacks; };