This repository was archived by the owner on Mar 10, 2026. It is now read-only.
-
Notifications
You must be signed in to change notification settings - Fork 0
Expand file tree
/
Copy pathstdout_logger.cpp
More file actions
74 lines (64 loc) · 2.14 KB
/
stdout_logger.cpp
File metadata and controls
74 lines (64 loc) · 2.14 KB
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
/*------------------------------------------------------------------------------
*
* Logger which outputs all messages to stdout.
*
* Author: matt.amos@mapquest.com
*
* Copyright 2010-1 Mapquest, Inc. All Rights reserved.
*
*
* This library is free software; you can redistribute it and/or
* modify it under the terms of the GNU Lesser General Public
* License as published by the Free Software Foundation; either
* version 2.1 of the License, or (at your option) any later version.
*
* This library is distributed in the hope that it will be useful,
* but WITHOUT ANY WARRANTY; without even the implied warranty of
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
* Lesser General Public License for more details.
*
* You should have received a copy of the GNU Lesser General Public
* License along with this library; if not, write to the Free Software
* Foundation, Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA
*
*-----------------------------------------------------------------------------*/
#include "stdout_logger.hpp"
#include <boost/date_time/posix_time/posix_time.hpp>
#include <boost/date_time/microsec_time_clock.hpp>
#include <sstream>
#include <cstdio>
using std::ostringstream;
namespace bt = boost::posix_time;
namespace {
logging::logger *create_stdout_logger(const boost::property_tree::ptree &)
{
return new logging::stdout_logger();
}
static const bool registered = logging::register_logger("stdout", create_stdout_logger);
}
namespace logging {
void
stdout_logger::log(log_level::type level, const std::string &msg)
{
ostringstream ostr;
ostr << bt::microsec_clock::local_time() <<
log::get_utc_offset_string() << " ";
if (level == log_level::finer) {
ostr << "[FINER] ";
} else if (level == log_level::debug) {
ostr << "[DEBUG] ";
} else if (level == log_level::info) {
ostr << "[INFO] ";
} else if (level == log_level::warning) {
ostr << "[WARN] ";
} else {
ostr << "[ERROR] ";
}
ostr << msg << "\n";
fprintf(stdout, "%s", ostr.str().c_str());
fflush(stdout);
}
stdout_logger::~stdout_logger()
{
}
} // namespace logging