// // FunctionDelegate.h // // $Id: //poco/1.4/Foundation/include/Poco/FunctionDelegate.h#4 $ // // Library: Foundation // Package: Events // Module: FunctionDelegate // // Implementation of the FunctionDelegate template. // // Copyright (c) 2006-2011, Applied Informatics Software Engineering GmbH. // and Contributors. // // SPDX-License-Identifier: BSL-1.0 // #ifndef Foundation_FunctionDelegate_INCLUDED #define Foundation_FunctionDelegate_INCLUDED #include "Poco/Foundation.h" #include "Poco/AbstractDelegate.h" #include "Poco/Mutex.h" namespace Poco { template class FunctionDelegate: public AbstractDelegate /// Wraps a freestanding function or static member function /// for use as a Delegate. { public: typedef void (*NotifyMethod)(const void*, TArgs&); FunctionDelegate(NotifyMethod method): _receiverMethod(method) { } FunctionDelegate(const FunctionDelegate& delegate): AbstractDelegate(delegate), _receiverMethod(delegate._receiverMethod) { } ~FunctionDelegate() { } FunctionDelegate& operator = (const FunctionDelegate& delegate) { if (&delegate != this) { this->_pTarget = delegate._pTarget; this->_receiverMethod = delegate._receiverMethod; } return *this; } bool notify(const void* sender, TArgs& arguments) { Mutex::ScopedLock lock(_mutex); if (_receiverMethod) { (*_receiverMethod)(sender, arguments); return true; } else return false; } bool equals(const AbstractDelegate& other) const { const FunctionDelegate* pOtherDelegate = dynamic_cast(other.unwrap()); return pOtherDelegate && _receiverMethod == pOtherDelegate->_receiverMethod; } AbstractDelegate* clone() const { return new FunctionDelegate(*this); } void disable() { Mutex::ScopedLock lock(_mutex); _receiverMethod = 0; } protected: NotifyMethod _receiverMethod; Mutex _mutex; private: FunctionDelegate(); }; template class FunctionDelegate: public AbstractDelegate { public: typedef void (*NotifyMethod)(void*, TArgs&); FunctionDelegate(NotifyMethod method): _receiverMethod(method) { } FunctionDelegate(const FunctionDelegate& delegate): AbstractDelegate(delegate), _receiverMethod(delegate._receiverMethod) { } ~FunctionDelegate() { } FunctionDelegate& operator = (const FunctionDelegate& delegate) { if (&delegate != this) { this->_pTarget = delegate._pTarget; this->_receiverMethod = delegate._receiverMethod; } return *this; } bool notify(const void* sender, TArgs& arguments) { Mutex::ScopedLock lock(_mutex); if (_receiverMethod) { (*_receiverMethod)(const_cast(sender), arguments); return true; } else return false; } bool equals(const AbstractDelegate& other) const { const FunctionDelegate* pOtherDelegate = dynamic_cast(other.unwrap()); return pOtherDelegate && _receiverMethod == pOtherDelegate->_receiverMethod; } AbstractDelegate* clone() const { return new FunctionDelegate(*this); } void disable() { Mutex::ScopedLock lock(_mutex); _receiverMethod = 0; } protected: NotifyMethod _receiverMethod; Mutex _mutex; private: FunctionDelegate(); }; template class FunctionDelegate: public AbstractDelegate { public: typedef void (*NotifyMethod)(TArgs&); FunctionDelegate(NotifyMethod method): _receiverMethod(method) { } FunctionDelegate(const FunctionDelegate& delegate): AbstractDelegate(delegate), _receiverMethod(delegate._receiverMethod) { } ~FunctionDelegate() { } FunctionDelegate& operator = (const FunctionDelegate& delegate) { if (&delegate != this) { this->_pTarget = delegate._pTarget; this->_receiverMethod = delegate._receiverMethod; } return *this; } bool notify(const void* /*sender*/, TArgs& arguments) { Mutex::ScopedLock lock(_mutex); if (_receiverMethod) { (*_receiverMethod)(arguments); return true; } else return false; } bool equals(const AbstractDelegate& other) const { const FunctionDelegate* pOtherDelegate = dynamic_cast(other.unwrap()); return pOtherDelegate && _receiverMethod == pOtherDelegate->_receiverMethod; } AbstractDelegate* clone() const { return new FunctionDelegate(*this); } void disable() { Mutex::ScopedLock lock(_mutex); _receiverMethod = 0; } protected: NotifyMethod _receiverMethod; Mutex _mutex; private: FunctionDelegate(); }; template <> class FunctionDelegate: public AbstractDelegate /// Wraps a freestanding function or static member function /// for use as a Delegate. { public: typedef void (*NotifyMethod)(const void*); FunctionDelegate(NotifyMethod method): _receiverMethod(method) { } FunctionDelegate(const FunctionDelegate& delegate): AbstractDelegate(delegate), _receiverMethod(delegate._receiverMethod) { } ~FunctionDelegate() { } FunctionDelegate& operator = (const FunctionDelegate& delegate) { if (&delegate != this) { //this->_pTarget = delegate._pTarget; this->_receiverMethod = delegate._receiverMethod; } return *this; } bool notify(const void* sender) { Mutex::ScopedLock lock(_mutex); if (_receiverMethod) { (*_receiverMethod)(sender); return true; } else return false; } bool equals(const AbstractDelegate& other) const { const FunctionDelegate* pOtherDelegate = dynamic_cast(other.unwrap()); return pOtherDelegate && _receiverMethod == pOtherDelegate->_receiverMethod; } AbstractDelegate* clone() const { return new FunctionDelegate(*this); } void disable() { Mutex::ScopedLock lock(_mutex); _receiverMethod = 0; } protected: NotifyMethod _receiverMethod; Mutex _mutex; private: FunctionDelegate(); }; template <> class FunctionDelegate: public AbstractDelegate { public: typedef void (*NotifyMethod)(void*); FunctionDelegate(NotifyMethod method): _receiverMethod(method) { } FunctionDelegate(const FunctionDelegate& delegate): AbstractDelegate(delegate), _receiverMethod(delegate._receiverMethod) { } ~FunctionDelegate() { } FunctionDelegate& operator = (const FunctionDelegate& delegate) { if (&delegate != this) { //this->_pTarget = delegate._pTarget; this->_receiverMethod = delegate._receiverMethod; } return *this; } bool notify(const void* sender) { Mutex::ScopedLock lock(_mutex); if (_receiverMethod) { (*_receiverMethod)(const_cast(sender)); return true; } else return false; } bool equals(const AbstractDelegate& other) const { const FunctionDelegate* pOtherDelegate = dynamic_cast(other.unwrap()); return pOtherDelegate && _receiverMethod == pOtherDelegate->_receiverMethod; } AbstractDelegate* clone() const { return new FunctionDelegate(*this); } void disable() { Mutex::ScopedLock lock(_mutex); _receiverMethod = 0; } protected: NotifyMethod _receiverMethod; Mutex _mutex; private: FunctionDelegate(); }; template class FunctionDelegate: public AbstractDelegate { public: typedef void (*NotifyMethod)(); FunctionDelegate(NotifyMethod method): _receiverMethod(method) { } FunctionDelegate(const FunctionDelegate& delegate): AbstractDelegate(delegate), _receiverMethod(delegate._receiverMethod) { } ~FunctionDelegate() { } FunctionDelegate& operator = (const FunctionDelegate& delegate) { if (&delegate != this) { //this->_pTarget = delegate._pTarget; this->_receiverMethod = delegate._receiverMethod; } return *this; } bool notify(const void* /*sender*/) { Mutex::ScopedLock lock(_mutex); if (_receiverMethod) { (*_receiverMethod)(); return true; } else return false; } bool equals(const AbstractDelegate& other) const { const FunctionDelegate* pOtherDelegate = dynamic_cast(other.unwrap()); return pOtherDelegate && _receiverMethod == pOtherDelegate->_receiverMethod; } AbstractDelegate* clone() const { return new FunctionDelegate(*this); } void disable() { Mutex::ScopedLock lock(_mutex); _receiverMethod = 0; } protected: NotifyMethod _receiverMethod; Mutex _mutex; private: FunctionDelegate(); }; } // namespace Poco #endif // Foundation_FunctionDelegate_INCLUDED