RSC  0.17.1
Logger.cpp
Go to the documentation of this file.
1 /* ============================================================
2  *
3  * This file is a part of RSC project
4  *
5  * Copyright (C) 2010 by Johannes Wienke <jwienke at techfak dot uni-bielefeld dot de>
6  *
7  * This file may be licensed under the terms of the
8  * GNU Lesser General Public License Version 3 (the ``LGPL''),
9  * or (at your option) any later version.
10  *
11  * Software distributed under the License is distributed
12  * on an ``AS IS'' basis, WITHOUT WARRANTY OF ANY KIND, either
13  * express or implied. See the LGPL for the specific language
14  * governing rights and limitations.
15  *
16  * You should have received a copy of the LGPL along with this
17  * program. If not, go to http://www.gnu.org/licenses/lgpl.html
18  * or write to the Free Software Foundation, Inc.,
19  * 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301, USA.
20  *
21  * The development of this software was supported by:
22  * CoR-Lab, Research Institute for Cognition and Robotics
23  * Bielefeld University
24  *
25  * ============================================================ */
26 
27 #include "Logger.h"
28 
29 #include "LoggerFactory.h"
30 
31 using namespace std;
32 
33 namespace rsc {
34 namespace logging {
35 
36 Logger::~Logger() {
37 }
38 
39 LoggerPtr Logger::getLogger(const std::string& name) {
40  return LoggerFactory::getInstance().getLogger(name);
41 }
42 
43 void Logger::trace(const string& msg) {
44  this->log(LEVEL_TRACE, msg);
45 }
46 
47 void Logger::debug(const string& msg) {
48  this->log(LEVEL_DEBUG, msg);
49 }
50 
51 void Logger::info(const string& msg) {
52  this->log(LEVEL_INFO, msg);
53 }
54 
55 void Logger::warn(const string& msg) {
56  this->log(LEVEL_WARN, msg);
57 }
58 
59 void Logger::error(const string& msg) {
60  this->log(LEVEL_ERROR, msg);
61 }
62 
63 void Logger::fatal(const string& msg) {
64  this->log(LEVEL_FATAL, msg);
65 }
66 
67 bool Logger::isTraceEnabled() const {
68  return isEnabledFor(LEVEL_TRACE);
69 }
70 
71 bool Logger::isDebugEnabled() const {
72  return isEnabledFor(LEVEL_DEBUG);
73 }
74 
75 bool Logger::isInfoEnabled() const {
76  return isEnabledFor(LEVEL_INFO);
77 }
78 
79 bool Logger::isWarnEnabled() const {
80  return isEnabledFor(LEVEL_WARN);
81 }
82 
83 bool Logger::isErrorEnabled() const {
84  return isEnabledFor(LEVEL_ERROR);
85 }
86 
87 bool Logger::isFatalEnabled() const {
88  return isEnabledFor(LEVEL_FATAL);
89 }
90 
91 bool Logger::isEnabledFor(const Level& level) const {
92  return level <= getLevel();
93 }
94 
95 ostream& operator<<(ostream& stream, const Logger::Level& level) {
96  switch (level) {
97  case Logger::LEVEL_ALL:
98  stream << "ALL";
99  break;
100  case Logger::LEVEL_TRACE:
101  stream << "TRACE";
102  break;
103  case Logger::LEVEL_DEBUG:
104  stream << "DEBUG";
105  break;
106  case Logger::LEVEL_INFO:
107  stream << "INFO";
108  break;
109  case Logger::LEVEL_WARN:
110  stream << "WARN";
111  break;
112  case Logger::LEVEL_ERROR:
113  stream << "ERROR";
114  break;
115  case Logger::LEVEL_FATAL:
116  stream << "FATAL";
117  break;
118  case Logger::LEVEL_OFF:
119  stream << "OFF";
120  break;
121  default:
122  assert(false);
123  stream << "UNKNOWN-LEVEL";
124  }
125  return stream;
126 }
127 
128 }
129 }
STL namespace.
Level
Possible logging levels.
Definition: Logger.h:63
LoggerPtr getLogger()
ostream & operator<<(ostream &stream, const Logger::Level &level)
Definition: Logger.cpp:95
boost::shared_ptr< Logger > LoggerPtr
Definition: Logger.h:41