aboutsummaryrefslogtreecommitdiffstats
path: root/contrib/libs/poco/Foundation/include/Poco/NObserver.h
diff options
context:
space:
mode:
authorDevtools Arcadia <arcadia-devtools@yandex-team.ru>2022-02-07 18:08:42 +0300
committerDevtools Arcadia <arcadia-devtools@mous.vla.yp-c.yandex.net>2022-02-07 18:08:42 +0300
commit1110808a9d39d4b808aef724c861a2e1a38d2a69 (patch)
treee26c9fed0de5d9873cce7e00bc214573dc2195b7 /contrib/libs/poco/Foundation/include/Poco/NObserver.h
downloadydb-1110808a9d39d4b808aef724c861a2e1a38d2a69.tar.gz
intermediate changes
ref:cde9a383711a11544ce7e107a78147fb96cc4029
Diffstat (limited to 'contrib/libs/poco/Foundation/include/Poco/NObserver.h')
-rw-r--r--contrib/libs/poco/Foundation/include/Poco/NObserver.h126
1 files changed, 126 insertions, 0 deletions
diff --git a/contrib/libs/poco/Foundation/include/Poco/NObserver.h b/contrib/libs/poco/Foundation/include/Poco/NObserver.h
new file mode 100644
index 0000000000..8b5106c8b0
--- /dev/null
+++ b/contrib/libs/poco/Foundation/include/Poco/NObserver.h
@@ -0,0 +1,126 @@
+//
+// NObserver.h
+//
+// Library: Foundation
+// Package: Notifications
+// Module: NotificationCenter
+//
+// Definition of the NObserver class template.
+//
+// Copyright (c) 2006, Applied Informatics Software Engineering GmbH.
+// and Contributors.
+//
+// SPDX-License-Identifier: BSL-1.0
+//
+
+
+#ifndef Foundation_NObserver_INCLUDED
+#define Foundation_NObserver_INCLUDED
+
+
+#include "Poco/Foundation.h"
+#include "Poco/AbstractObserver.h"
+#include "Poco/Mutex.h"
+
+
+namespace Poco {
+
+
+template <class C, class N>
+class NObserver: 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.
+ ///
+ /// This class template is quite similar to the Observer class
+ /// template. The only difference is that the NObserver
+ /// expects the callback function to accept a const AutoPtr&
+ /// instead of a plain pointer as argument, thus simplifying memory
+ /// management.
+{
+public:
+ typedef AutoPtr<N> NotificationPtr;
+ typedef void (C::*Callback)(const NotificationPtr&);
+
+ NObserver(C& object, Callback method):
+ _pObject(&object),
+ _method(method)
+ {
+ }
+
+ NObserver(const NObserver& observer):
+ AbstractObserver(observer),
+ _pObject(observer._pObject),
+ _method(observer._method)
+ {
+ }
+
+ ~NObserver()
+ {
+ }
+
+ NObserver& operator = (const NObserver& observer)
+ {
+ if (&observer != this)
+ {
+ _pObject = observer._pObject;
+ _method = observer._method;
+ }
+ return *this;
+ }
+
+ void notify(Notification* pNf) const
+ {
+ Poco::Mutex::ScopedLock lock(_mutex);
+
+ if (_pObject)
+ {
+ N* pCastNf = dynamic_cast<N*>(pNf);
+ if (pCastNf)
+ {
+ NotificationPtr ptr(pCastNf, true);
+ (_pObject->*_method)(ptr);
+ }
+ }
+ }
+
+ bool equals(const AbstractObserver& abstractObserver) const
+ {
+ const NObserver* pObs = dynamic_cast<const NObserver*>(&abstractObserver);
+ return pObs && pObs->_pObject == _pObject && pObs->_method == _method;
+ }
+
+ bool accepts(Notification* pNf) const
+ {
+ return dynamic_cast<N*>(pNf) != 0;
+ }
+
+ AbstractObserver* clone() const
+ {
+ return new NObserver(*this);
+ }
+
+ void disable()
+ {
+ Poco::Mutex::ScopedLock lock(_mutex);
+
+ _pObject = 0;
+ }
+
+private:
+ NObserver();
+
+ C* _pObject;
+ Callback _method;
+ mutable Poco::Mutex _mutex;
+};
+
+
+} // namespace Poco
+
+
+#endif // Foundation_NObserver_INCLUDED