Planet
navi homePPSaboutscreenshotsdownloaddevelopmentforum

source: code/branches/FICN/src/orxonox/core/DebugLevel.cc @ 696

Last change on this file since 696 was 696, checked in by landauf, 16 years ago

IdentifierMap works now on tardis (this pre-main() stuff is s* and ! f* !)

File size: 3.0 KB
Line 
1/*
2 *   ORXONOX - the hottest 3D action shooter ever to exist
3 *
4 *
5 *   License notice:
6 *
7 *   This program is free software; you can redistribute it and/or
8 *   modify it under the terms of the GNU General Public License
9 *   as published by the Free Software Foundation; either version 2
10 *   of the License, or (at your option) any later version.
11 *
12 *   This program 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 this program; if not, write to the Free Software
19 *   Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA  02110-1301, USA.
20 *
21 *   Author:
22 *      Fabian 'x3n' Landau
23 *   Co-authors:
24 *      ...
25 *
26 */
27
28/*!
29    @file DebugLevel.cc
30    @brief Implementation of the DebugLevel class.
31*/
32
33#include "CoreIncludes.h"
34#include "Debug.h"
35#include "DebugLevel.h"
36
37namespace orxonox
38{
39    /**
40        @brief Constructor: Registers the object and sets the debug level.
41        @param A reference to a global variable, used to avoid an infinite recursion in getSoftDebugLevel()
42    */
43    DebugLevel::DebugLevel(bool& bReturnSoftDebugLevel)
44    {
45        RegisterRootObject(DebugLevel);
46        this->setConfigValues();
47        bReturnSoftDebugLevel = true;
48    }
49
50    /**
51        @brief Function to collect the SetConfigValue-macro calls.
52    */
53    void DebugLevel::setConfigValues()
54    {
55        SetConfigValue(softDebugLevel_, 2);
56    }
57
58    /**
59        @brief Static function that holds the singleton.
60    */
61    int DebugLevel::getSoftDebugLevel()
62    {
63        static bool bCreatingSoftDebugLevelObject = true;   // Static variable - used to enhance the performance
64        static bool bReturnSoftDebugLevel = false;          // Static variable - used to avoid an infinite recursion
65        static DebugLevel* theOnlyDebugLevelObject = 0;     // Static variable - will contain a pointer to the only instance of the DebugLevel class
66
67        // If bReturnSoftDebugLevel is true, the instance of DebugLevel was created (it's set to true at the end of the constructor, call by reference)
68        if (bReturnSoftDebugLevel)
69            return theOnlyDebugLevelObject->softDebugLevel_;
70
71        // If bCreatingSoftDebugLevelObject is true, we're just about to create an instance of the DebugLevel class
72        if (bCreatingSoftDebugLevelObject)
73        {
74            bCreatingSoftDebugLevelObject = false;
75            theOnlyDebugLevelObject = new DebugLevel(bReturnSoftDebugLevel);
76            return theOnlyDebugLevelObject->softDebugLevel_;
77        }
78
79        // Return a constant value while we're creating the object
80        return 4;
81    }
82}
83
84/**
85    @returns the soft debug level, stored in the only existing instance of the DebugLevel class, configured in the config-file.
86*/
87int getSoftDebugLevel()
88{
89    return orxonox::DebugLevel::getSoftDebugLevel();
90}
Note: See TracBrowser for help on using the repository browser.