source: src/CodePatterns/Observer/Notification.hpp@ b09709

Last change on this file since b09709 was 454bc54, checked in by Frederik Heber <heber@…>, 10 years ago

Added new pattern ObservedValue, contrary to Cacheable.

  • essentially updates immediately and caches a value for off-line use, safe- guard with mutexes.
  • added unit test for ObservedValue.
  • factored threeNumbers stub out of CacheableUnitTest, also used the stub in ObservedValueUnitTest.
  • we may now signOn() to Notification with a priority.
  • Cacheable can also update now via notification channels not just for global updates.
  • Observable can now also instantiate the channels directly if given a list. This was necessary as Cacheable or ObservedValue are instantiated in the constructor, too, and if listening to channels, these must already be present.
  • FIX: Channels::addChannels() used NDEBUG wrong way round.
  • ObservedValue::get() returns reference.
  • Property mode set to 100644
File size: 2.3 KB
Line 
1/*
2 * Notification.hpp
3 *
4 * Created on: Dec 1, 2011
5 * Author: heber
6 */
7
8#ifndef NOTIFICATION_HPP_
9#define NOTIFICATION_HPP_
10
11// include config.h
12#ifdef HAVE_CONFIG_H
13#include <config.h>
14#endif
15
16#include <set>
17
18#include <boost/thread/recursive_mutex.hpp>
19
20class Channels;
21class Observable;
22class Observer;
23class Relay;
24
25/** Notifications are sort of news channels of an Observable.
26 * Via the NOTIFY() macro updates can be transmitted in a specific channel.
27 * Observers can subscribe to Notification in much the same way as they can to
28 * the Observable itself. Usually, Notifications are used along
29 * with the usual OBSERVE() macro to generate both the specific and
30 * the global message of change.
31 *
32 * \note Notification::subjectKilled() needs to be called by owning Channels.
33 * We use the passed on Observable instance to let Observers that have only
34 * signed on to single channel know when their observable has died.
35 */
36class Notification {
37public:
38 Notification(size_t _channelno);
39 virtual ~Notification();
40
41 size_t getChannelNo() const { return channelno; }
42
43protected:
44
45 void addObserver(Observer *target, const int priority);
46 void removeObserver(Observer *target);
47
48private:
49 //!> grant Observable access to notifyAll() and subjectKilled()
50 friend class Observable;
51 //!> grant Channels access to notifyAll() and subjectKilled()
52 friend class Channels;
53 //!> grant Relay access to notifyAll()
54 friend class Relay;
55
56 void notifyAll(Observable * const publisher);
57
58 /** Informs channel subscribers about dstor call.
59 *
60 * This is meant to be called from Observable only.
61 * Channels and Notifications are strictly attached to an Observable. Hence,
62 * it makes no sense to inform them on their own. Especially, neither has
63 * any knowledge on the publisher.
64 *
65 * \param *publisher Observable about to be destroyed
66 */
67 void subjectKilled(Observable * const publisher);
68
69 /** Getter for the number of Observer for this notification (channel).
70 *
71 * \return number of added observers
72 */
73 size_t getNumberOfObservers() const
74 { return targets.size(); }
75
76private:
77 typedef std::multimap<int,Observer*> targets_t;
78 targets_t targets;
79 const size_t channelno;
80
81 mutable boost::recursive_mutex TargetsLock; //!< a lock for the pointer of the instance
82};
83
84
85
86#endif /* NOTIFICATION_HPP_ */
Note: See TracBrowser for help on using the repository browser.