AVPKit
LoggerStack.cpp
1 /*******************************************************************************
2  * Copyright (c) 2024, 2026, Olivier Ayache. All rights reserved.
3  *
4  * This file is part of AVPKit.
5  *
6  * AVPKit is free software: you can redistribute it and/or modify
7  * it under the terms of the GNU Lesser General Public License as published by
8  * the Free Software Foundation, either version 3 of the License, or
9  * (at your option) any later version.
10  *
11  * AVPKit is distributed in the hope that it will be useful,
12  * but WITHOUT ANY WARRANTY; without even the implied warranty of
13  * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
14  * GNU Lesser General Public License for more details.
15  *
16  * You should have received a copy of the GNU Lesser General Public License
17  * along with AVPKit. If not, see <http://www.gnu.org/licenses/>.
18  *******************************************************************************/
19 
20 #include "LoggerStack.h"
21 #include "Logger.h"
22 
23 VS_LOG_SETUP(VS_CPP_PACKAGE);
24 
25 namespace com { namespace avpkit { namespace ferry
26  {
27 
28  LoggerStack :: LoggerStack()
29  {
30  VS_LOG_TRACE("Creating LoggerStack");
31  for(int i = 0; i < 5; i++)
32  {
33  mOrigLevel[i] = Logger::isGlobalLogging((Logger::Level)i);
34  mHasChangedLevel[i] = false;
35  }
36  }
37 
38  LoggerStack :: ~LoggerStack()
39  {
40  for(int i = 0; i<5; i++)
41  {
42  if (mHasChangedLevel[i])
43  Logger::setGlobalIsLogging((Logger::Level)i, mOrigLevel[i]);
44 
45  }
46  VS_LOG_TRACE("Destroying LoggerStack");
47  }
48 
49  void
51  {
52  // Set all levels up to an include this level to value.
53  mHasChangedLevel[level] = true;
54  Logger::setGlobalIsLogging(level, value);
55  for(int i = level; i < 5; i++)
56  {
57  mHasChangedLevel[i] = true;
58  if (value)
59  {
60  Logger::setGlobalIsLogging((Logger::Level)i, mOrigLevel[i]);
61  } else {
62  Logger::setGlobalIsLogging((Logger::Level)i, value);
63  }
64  }
65  }
66 
67  }}}
void setGlobalLevel(Logger::Level level, bool value)
If false, sets level and all lower levels to false.
Definition: LoggerStack.cpp:50
Level
Different logging levels (noiseness) supported by us.
Definition: Logger.h:54
WARNING: Do not use logging in this class, and do not set any static file variables to values other t...