RSC  0.17.1
ConsoleLogger.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 "ConsoleLogger.h"
28 
29 #include <iostream>
30 
31 #include "../misc/langutils.h"
32 
33 using namespace std;
34 
35 namespace rsc {
36 namespace logging {
37 
38 ConsoleLogger::ConsoleLogger(const string& name) :
39  name(name), level(LEVEL_INFO) {
40 
41 }
42 
43 ConsoleLogger::ConsoleLogger(const string& name, const Level& level) :
44  name(name), level(level) {
45 }
46 
48 }
49 
51  boost::recursive_mutex::scoped_lock lock(mutex);
52  return level;
53 }
54 
56  boost::recursive_mutex::scoped_lock lock(mutex);
57  this->level = level;
58 }
59 
60 string ConsoleLogger::getName() const {
61  boost::recursive_mutex::scoped_lock lock(mutex);
62  return name;
63 }
64 
65 void ConsoleLogger::setName(const string& name) {
66  boost::recursive_mutex::scoped_lock lock(mutex);
67  this->name = name;
68 }
69 
70 ostream& ConsoleLogger::printHeader(ostream& stream, const Level& level) {
71  return stream << rsc::misc::currentTimeMillis() << " " << this->name
72  << " [" << level << "]: ";
73 }
74 
75 void ConsoleLogger::log(const Level& level, const string& msg) {
76  boost::recursive_mutex::scoped_lock lock(mutex);
77  if (isEnabledFor(level)) {
78  printHeader(cerr, level);
79  cerr << msg << endl;
80  }
81 }
82 
83 }
84 }
boost::recursive_mutex mutex
Definition: ConsoleLogger.h:76
void setLevel(const Level &level)
virtual bool isEnabledFor(const Level &level) const
Definition: Logger.cpp:91
STL namespace.
boost::uint64_t currentTimeMillis()
Returns the current system time as milliseconds.
Definition: langutils.cpp:64
Level
Possible logging levels.
Definition: Logger.h:63
ConsoleLogger(const std::string &name)
Creates a new logger with the given name and level INFO.
Level getLevel() const
Returns the currently defined level of the logger.
std::string getName() const
Returns the hierarchical name of the logger.
std::ostream & printHeader(std::ostream &stream, const Level &level)
Prints a generic header for this logger to the stream.
void log(const Level &level, const std::string &msg)
void setName(const std::string &name)
Sets the name of the logger.