2012-04-29 20:52:25 +02:00
|
|
|
//
|
|
|
|
// Observer.h
|
|
|
|
//
|
|
|
|
// Library: Foundation
|
|
|
|
// Package: Notifications
|
|
|
|
// Module: NotificationCenter
|
|
|
|
//
|
|
|
|
// Definition of the Observer class template.
|
|
|
|
//
|
|
|
|
// Copyright (c) 2004-2006, Applied Informatics Software Engineering GmbH.
|
|
|
|
// and Contributors.
|
|
|
|
//
|
2014-05-04 21:02:42 +02:00
|
|
|
// SPDX-License-Identifier: BSL-1.0
|
2012-04-29 20:52:25 +02:00
|
|
|
//
|
|
|
|
|
|
|
|
|
|
|
|
#ifndef Foundation_Observer_INCLUDED
|
|
|
|
#define Foundation_Observer_INCLUDED
|
|
|
|
|
|
|
|
|
|
|
|
#include "Poco/Foundation.h"
|
|
|
|
#include "Poco/AbstractObserver.h"
|
|
|
|
#include "Poco/Mutex.h"
|
|
|
|
|
|
|
|
|
|
|
|
namespace Poco {
|
|
|
|
|
|
|
|
|
|
|
|
template <class C, class N>
|
|
|
|
class Observer: public AbstractObserver
|
|
|
|
/// This template class implements an adapter that sits between
|
|
|
|
/// a NotificationCenter and an object receiving notifications
|
|
|
|
/// from it. It is quite similar in concept to the
|
|
|
|
/// RunnableAdapter, but provides some NotificationCenter
|
|
|
|
/// specific additional methods.
|
|
|
|
/// See the NotificationCenter class for information on how
|
|
|
|
/// to use this template class.
|
|
|
|
///
|
|
|
|
/// Instead of the Observer class template, you might want to
|
|
|
|
/// use the NObserver class template, which uses an AutoPtr to
|
|
|
|
/// pass the Notification to the callback function, thus freeing
|
|
|
|
/// you from memory management issues.
|
|
|
|
{
|
|
|
|
public:
|
|
|
|
typedef void (C::*Callback)(N*);
|
|
|
|
|
|
|
|
Observer(C& object, Callback method):
|
|
|
|
_pObject(&object),
|
|
|
|
_method(method)
|
|
|
|
{
|
|
|
|
}
|
|
|
|
|
|
|
|
Observer(const Observer& observer):
|
|
|
|
AbstractObserver(observer),
|
|
|
|
_pObject(observer._pObject),
|
|
|
|
_method(observer._method)
|
|
|
|
{
|
|
|
|
}
|
|
|
|
|
|
|
|
~Observer()
|
|
|
|
{
|
|
|
|
}
|
|
|
|
|
|
|
|
Observer& operator = (const Observer& observer)
|
|
|
|
{
|
|
|
|
if (&observer != this)
|
|
|
|
{
|
|
|
|
_pObject = observer._pObject;
|
|
|
|
_method = observer._method;
|
|
|
|
}
|
|
|
|
return *this;
|
|
|
|
}
|
2018-04-27 02:17:49 +02:00
|
|
|
|
2012-04-29 20:52:25 +02:00
|
|
|
void notify(Notification* pNf) const
|
|
|
|
{
|
|
|
|
Poco::Mutex::ScopedLock lock(_mutex);
|
|
|
|
|
|
|
|
if (_pObject)
|
|
|
|
{
|
|
|
|
N* pCastNf = dynamic_cast<N*>(pNf);
|
|
|
|
if (pCastNf)
|
|
|
|
{
|
|
|
|
pCastNf->duplicate();
|
|
|
|
(_pObject->*_method)(pCastNf);
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
bool equals(const AbstractObserver& abstractObserver) const
|
|
|
|
{
|
|
|
|
const Observer* pObs = dynamic_cast<const Observer*>(&abstractObserver);
|
|
|
|
return pObs && pObs->_pObject == _pObject && pObs->_method == _method;
|
|
|
|
}
|
|
|
|
|
2021-06-23 08:33:45 +02:00
|
|
|
bool accepts(Notification* pNf, const char* pName = 0) const
|
2012-04-29 20:52:25 +02:00
|
|
|
{
|
2021-06-23 08:33:45 +02:00
|
|
|
return dynamic_cast<N*>(pNf) && (!pName || pNf->name() == pName);
|
2012-04-29 20:52:25 +02:00
|
|
|
}
|
|
|
|
|
|
|
|
AbstractObserver* clone() const
|
|
|
|
{
|
|
|
|
return new Observer(*this);
|
|
|
|
}
|
|
|
|
|
|
|
|
void disable()
|
|
|
|
{
|
|
|
|
Poco::Mutex::ScopedLock lock(_mutex);
|
|
|
|
|
|
|
|
_pObject = 0;
|
|
|
|
}
|
|
|
|
|
|
|
|
private:
|
|
|
|
Observer();
|
|
|
|
|
|
|
|
C* _pObject;
|
|
|
|
Callback _method;
|
|
|
|
mutable Poco::Mutex _mutex;
|
|
|
|
};
|
|
|
|
|
|
|
|
|
|
|
|
} // namespace Poco
|
|
|
|
|
|
|
|
|
|
|
|
#endif // Foundation_Observer_INCLUDED
|