Planet
navi homePPSaboutscreenshotsdownloaddevelopmentforum

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

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

activating a scopelistener right after registering may not be the best idea after all because some other stuff (e.g. an identifier) may not yet be registered if this happens during static initialization. added helper function instead (not yet used, but this will soon happen)

  • Property svn:eol-style set to native
File size: 3.1 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. */
67            void addListener(ScopeListener* listener, ScopeID::Value scope);
68            /** Unregisters a listener for the given scope. */
69            void removeListener(ScopeListener* listener, ScopeID::Value scope);
70
71            /**
72             * Checks for all listeners if their activity matches the activity of the scope.
73             * If not, listeners are activated or deactivated depending on their state.
74             */
75            void updateListeners();
76
77        private:
78            void activateListenersForScope(ScopeID::Value scope);
79            void deactivateListenersForScope(ScopeID::Value scope);
80
81            void activateListener(ScopeListener* listener);
82            void deactivateListener(ScopeListener* listener);
83
84            std::set<ScopeID::Value> activeScopes_;
85            std::map<ScopeID::Value, std::set<ScopeListener*> > listeners_; //!< Stores all listeners for a scope
86    };
87}
88
89#endif /* __ScopeManager_H__ */
Note: See TracBrowser for help on using the repository browser.