summaryrefslogtreecommitdiff
path: root/plugins/WinterSpeak/src/Subject.cpp
diff options
context:
space:
mode:
authorPhilip Schell <github.com@blubbfish.net>2013-10-19 13:05:02 +0000
committerPhilip Schell <github.com@blubbfish.net>2013-10-19 13:05:02 +0000
commit397e25f2b71347c7c83495fe5b25496ff3b02b75 (patch)
tree71f6ad2ef525218541a7a35cc659b4fb7bf047d6 /plugins/WinterSpeak/src/Subject.cpp
parent9e786b686fae94e71279a797047a91ffdc4b0443 (diff)
WinterSpeak: ticket:269 WinterSpeak now rewritten
git-svn-id: http://svn.miranda-ng.org/main/trunk@6532 1316c22d-e87f-b044-9b9b-93d7a3e3ba9c
Diffstat (limited to 'plugins/WinterSpeak/src/Subject.cpp')
-rw-r--r--plugins/WinterSpeak/src/Subject.cpp55
1 files changed, 55 insertions, 0 deletions
diff --git a/plugins/WinterSpeak/src/Subject.cpp b/plugins/WinterSpeak/src/Subject.cpp
new file mode 100644
index 0000000000..b502aac4fb
--- /dev/null
+++ b/plugins/WinterSpeak/src/Subject.cpp
@@ -0,0 +1,55 @@
+#include "Common.h"
+#include "Subject.h"
+#include "Observer.h"
+
+
+//------------------------------------------------------------------------------
+// public:
+//------------------------------------------------------------------------------
+Subject::Subject() : m_observer_list()
+{
+}
+
+//------------------------------------------------------------------------------
+Subject::~Subject()
+{
+}
+
+//------------------------------------------------------------------------------
+void Subject::notify()
+{
+ // call update for all observers in the list
+ for (std::list<Observer *>::iterator iter = m_observer_list.begin(); iter != m_observer_list.end(); ++iter)
+ {
+ (*iter)->update(*this);
+ }
+}
+
+//------------------------------------------------------------------------------
+void Subject::attach(Observer &observer)
+{
+ for (std::list<Observer *>::iterator iter = m_observer_list.begin(); iter != m_observer_list.end(); ++iter)
+ {
+ if (*iter == &observer)
+ {
+ return;
+ }
+ }
+ m_observer_list.push_back(&observer);
+}
+
+//------------------------------------------------------------------------------
+void Subject::detach(const Observer &observer)
+{
+ for (std::list<Observer *>::iterator iter = m_observer_list.begin(); iter != m_observer_list.end(); ++iter)
+ {
+ if (*iter == &observer)
+ {
+ m_observer_list.erase(iter);
+ }
+ }
+}
+
+//==============================================================================
+
+