forked from augcampos/asterisk-cpp
-
Notifications
You must be signed in to change notification settings - Fork 0
Expand file tree
/
Copy pathLogHandler.cpp
More file actions
114 lines (94 loc) · 2.82 KB
/
LogHandler.cpp
File metadata and controls
114 lines (94 loc) · 2.82 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
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
/*
* LogHandler.cpp
*
* Created on: 29 de Jun de 2011
* Author: augcampos
*/
#include <log4cplus/configurator.h>
#include <log4cplus/logger.h>
#include "asteriskcpp/utils/LogHandler.h"
namespace asteriskcpp {
LogHandler::LogHandler() {
log4cplus::BasicConfigurator::doConfigure();
log4cplus::Logger::getRoot().setLogLevel(log4cplus::TRACE_LOG_LEVEL);
}
LogHandler::LogHandler(const std::string& confFile) :
confFile(confFile) {
if (confFile.empty()) {
log4cplus::BasicConfigurator::doConfigure();
log4cplus::Logger::getRoot().setLogLevel(log4cplus::TRACE_LOG_LEVEL);
} else {
log4cplus::PropertyConfigurator::doConfigure(confFile);
}
}
LogHandler::~LogHandler() {
}
void LogHandler::setLevel(const LogLevel& level) {
switch (level) {
case LL_TRACE:
{
log4cplus::Logger::getRoot().setLogLevel(log4cplus::TRACE_LOG_LEVEL);
}
break;
case LL_DEBUG:
{
log4cplus::Logger::getRoot().setLogLevel(log4cplus::DEBUG_LOG_LEVEL);
}
break;
case LL_INFO:
{
log4cplus::Logger::getRoot().setLogLevel(log4cplus::INFO_LOG_LEVEL);
}
break;
case LL_WARN:
{
log4cplus::Logger::getRoot().setLogLevel(log4cplus::WARN_LOG_LEVEL);
}
break;
case LL_ERROR:
{
log4cplus::Logger::getRoot().setLogLevel(log4cplus::ERROR_LOG_LEVEL);
}
break;
case LL_FATAL:
{
log4cplus::Logger::getRoot().setLogLevel(log4cplus::FATAL_LOG_LEVEL);
}
break;
}
}
void LogHandler::log(const std::string& line, LogLevel level) {
switch (level) {
case LL_TRACE:
{
LOG4CPLUS_TRACE_STR(log4cplus::Logger::getRoot(), line);
}
break;
case LL_DEBUG:
{
LOG4CPLUS_DEBUG_STR(log4cplus::Logger::getRoot(), line);
}
break;
case LL_INFO:
{
LOG4CPLUS_INFO_STR(log4cplus::Logger::getRoot(), line);
}
break;
case LL_WARN:
{
LOG4CPLUS_WARN_STR(log4cplus::Logger::getRoot(), line);
}
break;
case LL_ERROR:
{
LOG4CPLUS_ERROR_STR(log4cplus::Logger::getRoot(), line);
}
break;
case LL_FATAL:
{
LOG4CPLUS_FATAL_STR(log4cplus::Logger::getRoot(), line);
}
break;
}
}
}