Planet
navi homePPSaboutscreenshotsdownloaddevelopmentforum

source: code/branches/core7/src/libraries/core/singleton/ScopeManager.h @ 10538

Last change on this file since 10538 was 10538, checked in by landauf, 9 years ago

now that the order of initialization is well defined (first identifiers, then singletons) we can safely create singletons right after they are registered (and unload them again when they are unregistered). this reverts changes from r10517

  • Property svn:eol-style set to native
File size: 3.0 KB
Line 
1/*
2 *   ORXONOX - the hottest 3D action shooter ever to exist
3 *                    > www.orxonox.net <
4 *
5 *
6 *   License notice:
7 *
8 *   This program is free software; you can redistribute it and/or
9 *   modify it under the terms of the GNU General Public License
10 *   as published by the Free Software Foundation; either version 2
11 *   of the License, or (at your option) any later version.
12 *
13 *   This program is distributed in the hope that it will be useful,
14 *   but WITHOUT ANY WARRANTY; without even the implied warranty of
15 *   MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
16 *   GNU General Public License for more details.
17 *
18 *   You should have received a copy of the GNU General Public License
19 *   along with this program; if not, write to the Free Software
20 *   Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA  02110-1301, USA.
21 *
22 *   Author:
23 *      Fabian 'x3n' Landau
24 *   Co-authors:
25 *      ...
26 *
27 */
28
29/**
30@file
31@ingroup SingletonScope
32@brief Declaration of orxonox::ScopeManager.
33*/
34
35#ifndef __ScopeManager_H__
36#define __ScopeManager_H__
37
38#include "core/CorePrereqs.h"
39
40#include <map>
41#include <set>
42
43namespace orxonox
44{
45    /**
46        @brief The ScopeManager stores the variables of the Scope templates in a statically linked context.
47
48        If all Scope objects are managed by this class, they are statically linked in the core library.
49        Without this, a new instance of Scope<T> for each T would be created in every library of Orxonox,
50        which is of course not the desired behavior.
51
52        @see See @ref Scope "this description" for details about the interrelationship of Scope, ScopeListener, and ScopeManager.
53    */
54    class _CoreExport ScopeManager
55    {
56        public:
57            static ScopeManager& getInstance();
58
59            /** Adds a scope and activates all listeners which are registered for this scope */
60            void addScope(ScopeID::Value scope);
61            /** Removes a scope and deactivates all listeners which are registered for this scope */
62            void removeScope(ScopeID::Value scope);
63            /** Returns true if this scope is active */
64            bool isActive(ScopeID::Value scope);
65
66            /** Registers a listener for the given scope. If the scope is already active, the listener is activate immediately. */
67            void addListener(ScopeListener* listener, ScopeID::Value scope);
68            /** Unregisters a listener for the given scope. If the scope is still active, the listener is deactivated before removal. */
69            void removeListener(ScopeListener* listener, ScopeID::Value scope);
70
71        private:
72            void activateListenersForScope(ScopeID::Value scope);
73            void deactivateListenersForScope(ScopeID::Value scope);
74
75            void activateListener(ScopeListener* listener);
76            void deactivateListener(ScopeListener* listener);
77
78            std::set<ScopeID::Value> activeScopes_;
79            std::map<ScopeID::Value, std::set<ScopeListener*> > listeners_; //!< Stores all listeners for a scope
80    };
81}
82
83#endif /* __ScopeManager_H__ */
Note: See TracBrowser for help on using the repository browser.