Planet
navi homePPSaboutscreenshotsdownloaddevelopmentforum

source: code/branches/core3/src/core/Core.cc @ 1975

Last change on this file since 1975 was 1610, checked in by landauf, 17 years ago
  • fixed bug #1 in ConfigValueContainer (callback not being called the first time)
  • fixed another bug in XMLPort, caused by the recently added support for extern types
  • Property svn:eol-style set to native
File size: 7.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 Core.cc
31    @brief Implementation of the Core class.
32*/
33
34#include "Core.h"
35#include "Language.h"
36#include "CoreIncludes.h"
37#include "ConfigValueIncludes.h"
38#include "input/InputManager.h"
39#include "TclThreadManager.h"
40
41namespace orxonox
42{
43    /**
44        @brief Constructor: Registers the object and sets the config-values.
45        @param A reference to a global variable, used to avoid an infinite recursion in getSoftDebugLevel()
46    */
47    Core::Core()
48    {
49        RegisterRootObject(Core);
50        this->setConfigValues();
51    }
52
53    /**
54        @brief Sets the bool to true to avoid static functions accessing a deleted object.
55    */
56    Core::~Core()
57    {
58        isCreatingCoreSettings() = true;
59    }
60
61    /**
62        @brief Returns true if the Core instance is not yet ready and the static functions have to return a default value.
63    */
64    bool& Core::isCreatingCoreSettings()
65    {
66        static bool bCreatingCoreSettings = true;
67        static bool bFirstTime = true;
68        if (bFirstTime)
69        {
70            bFirstTime = false;
71            Core::getInstance();
72        }
73        return bCreatingCoreSettings;
74    }
75
76    /**
77        @brief Returns a unique instance of Core.
78        @return The instance
79    */
80    Core& Core::getInstance()
81    {
82        static Core instance = Core();
83
84        // If bCreatingSoftDebugLevelObject is true, we're just about to create an instance of the DebugLevel class
85        if (Core::isCreatingCoreSettings())
86        {
87            isCreatingCoreSettings() = false;
88            instance.setConfigValues();
89        }
90        return instance;
91    }
92
93    /**
94        @brief Function to collect the SetConfigValue-macro calls.
95    */
96    void Core::setConfigValues()
97    {
98        SetConfigValue(softDebugLevelConsole_, 3).description("The maximal level of debug output shown in the console").callback(this, &Core::debugLevelChanged);
99        SetConfigValue(softDebugLevelLogfile_, 3).description("The maximal level of debug output shown in the logfile").callback(this, &Core::debugLevelChanged);
100        SetConfigValue(softDebugLevelShell_, 1).description("The maximal level of debug output shown in the ingame shell").callback(this, &Core::debugLevelChanged);
101        SetConfigValue(language_, Language::getLanguage().defaultLanguage_).description("The language of the ingame text").callback(this, &Core::languageChanged);
102    }
103
104    /**
105        @brief Callback function if the debug level has changed.
106    */
107    void Core::debugLevelChanged()
108    {
109        // softDebugLevel_ is the maximum of the 3 variables
110        this->softDebugLevel_ = this->softDebugLevelConsole_;
111        if (this->softDebugLevelLogfile_ > this->softDebugLevel_)
112            this->softDebugLevel_ = this->softDebugLevelLogfile_;
113        if (this->softDebugLevelShell_ > this->softDebugLevel_)
114            this->softDebugLevel_ = this->softDebugLevelShell_;
115
116        OutputHandler::setSoftDebugLevel(OutputHandler::LD_All,     this->softDebugLevel_);
117        OutputHandler::setSoftDebugLevel(OutputHandler::LD_Console, this->softDebugLevelConsole_);
118        OutputHandler::setSoftDebugLevel(OutputHandler::LD_Logfile, this->softDebugLevelLogfile_);
119        OutputHandler::setSoftDebugLevel(OutputHandler::LD_Shell,   this->softDebugLevelShell_);
120    }
121
122    /**
123        @brief Callback function if the language has changed.
124    */
125    void Core::languageChanged()
126    {
127        // Read the translation file after the language was configured
128        Language::getLanguage().readTranslatedLanguageFile();
129    }
130
131    /**
132        @brief Returns the softDebugLevel for the given device (returns a default-value if the class ist right about to be created).
133        @param device The device
134        @return The softDebugLevel
135    */
136    int Core::getSoftDebugLevel(OutputHandler::OutputDevice device)
137    {
138        if (!Core::isCreatingCoreSettings())
139        {
140            if (device == OutputHandler::LD_All)
141                return Core::getInstance().softDebugLevel_;
142            else if (device == OutputHandler::LD_Console)
143                return Core::getInstance().softDebugLevelConsole_;
144            else if (device == OutputHandler::LD_Logfile)
145                return Core::getInstance().softDebugLevelLogfile_;
146            else if (device == OutputHandler::LD_Shell)
147                return Core::getInstance().softDebugLevelShell_;
148        }
149
150        // Return a constant value while we're creating the object
151        return 2;
152    }
153
154     /**
155        @brief Sets the softDebugLevel for the given device. Please use this only temporary and restore the value afterwards, as it overrides the configured value.
156        @param device The device
157        @param level The level
158    */
159     void Core::setSoftDebugLevel(OutputHandler::OutputDevice device, int level)
160     {
161        if (!Core::isCreatingCoreSettings())
162        {
163            if (device == OutputHandler::LD_All)
164                Core::getInstance().softDebugLevel_ = level;
165            else if (device == OutputHandler::LD_Console)
166                Core::getInstance().softDebugLevelConsole_ = level;
167            else if (device == OutputHandler::LD_Logfile)
168                Core::getInstance().softDebugLevelLogfile_ = level;
169            else if (device == OutputHandler::LD_Shell)
170                Core::getInstance().softDebugLevelShell_ = level;
171
172            OutputHandler::setSoftDebugLevel(device, level);
173        }
174     }
175
176    /**
177        @brief Returns the configured language.
178    */
179    const std::string& Core::getLanguage()
180    {
181        if (!Core::isCreatingCoreSettings())
182            return Core::getInstance().language_;
183
184        return Language::getLanguage().defaultLanguage_;
185    }
186
187    /**
188        @brief Sets the language in the config-file back to the default.
189    */
190    void Core::resetLanguage()
191    {
192        Core::getInstance().resetLanguageIntern();
193    }
194
195    /**
196        @brief Sets the language in the config-file back to the default.
197    */
198    void Core::resetLanguageIntern()
199    {
200        ResetConfigValue(language_);
201    }
202
203    /**
204        @brief Ticks every core class in a specified sequence. Has to be called
205               every Orxonox tick!
206        @param dt Delta Time
207    */
208    void Core::tick(float dt)
209    {
210        TclThreadManager::getInstance().tick(dt);
211        InputManager::tick(dt);
212    }
213}
Note: See TracBrowser for help on using the repository browser.