NOW I do it right: #woxblox#
[divverent/netradiant.git] / libs / moduleobservers.h
1 /*
2 Copyright (C) 2001-2006, William Joseph.
3 All Rights Reserved.
4
5 This file is part of GtkRadiant.
6
7 GtkRadiant is free software; you can redistribute it and/or modify
8 it under the terms of the GNU General Public License as published by
9 the Free Software Foundation; either version 2 of the License, or
10 (at your option) any later version.
11
12 GtkRadiant is distributed in the hope that it will be useful,
13 but WITHOUT ANY WARRANTY; without even the implied warranty of
14 MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
15 GNU General Public License for more details.
16
17 You should have received a copy of the GNU General Public License
18 along with GtkRadiant; if not, write to the Free Software
19 Foundation, Inc., 51 Franklin St, Fifth Floor, Boston, MA  02110-1301  USA
20 */
21
22 #if !defined(INCLUDED_MODULEOBSERVERS_H)
23 #define INCLUDED_MODULEOBSERVERS_H
24
25 #include "debugging/debugging.h"
26 #include <set>
27 #include "moduleobserver.h"
28
29 class ModuleObservers
30 {
31   typedef std::set<ModuleObserver*> Observers;
32   Observers m_observers;
33 public:
34   ~ModuleObservers()
35   {
36     ASSERT_MESSAGE(m_observers.empty(), "ModuleObservers::~ModuleObservers: observers still attached");
37   }
38   void attach(ModuleObserver& observer)
39   {
40     ASSERT_MESSAGE(m_observers.find(&observer) == m_observers.end(), "ModuleObservers::attach: cannot attach observer");
41     m_observers.insert(&observer);
42   }
43   void detach(ModuleObserver& observer)
44   {
45     ASSERT_MESSAGE(m_observers.find(&observer) != m_observers.end(), "ModuleObservers::detach: cannot detach observer");
46     m_observers.erase(&observer);
47   }
48   void realise()
49   {
50     for(Observers::iterator i = m_observers.begin(); i != m_observers.end(); ++i)
51     {
52       (*i)->realise();
53     }
54   }
55   void unrealise()
56   {
57     for(Observers::reverse_iterator i = m_observers.rbegin(); i != m_observers.rend(); ++i)
58     {
59       (*i)->unrealise();
60     }
61   }
62 };
63
64 #endif