-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathlogger.cpp
124 lines (114 loc) · 3.78 KB
/
logger.cpp
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
115
116
117
118
119
120
121
122
123
124
#include "logger.h"
/* Return static logger instance */
Logger&
Logger::get_instance(void)
{
static Logger instance;
return instance;
}
/* Basic log level parser */
void
Logger::log(Level level, const std::string& message, opcuac::jobsptr job)
{
auto local = std::dynamic_pointer_cast<open62541::JobDecNode>(job);
std::string prefix = actual_time();
switch(level)
{
case Level::LINFO:
std::cout << FONT_LIGHT_BLUE << prefix << FONT_GREEN
<< std::setw(20) << std::left << " info/cab" << FONT_RESET
<< message
<< std::endl;
break;
case Level::LWARNING:
std::cout << FONT_LIGHT_BLUE << prefix << FONT_YELLOW
<< std::setw(20) << std::left << " warn/cab" << FONT_RESET
<< message
<< std::endl;
break;
case Level::LERROR:
std::cout << FONT_LIGHT_BLUE << prefix << FONT_RED
<< std::setw(20) << std::left << " error/cab" << FONT_RESET
<< message
<< std::endl;
break;
case Level::LJOB:
if(local == nullptr)
{
std::cout << FONT_LIGHT_BLUE << prefix << FONT_BLUE
<< std::setw(20) << std::left << " job/cab" << FONT_RESET
<< message
<< " | "
<< "job nullptr!"
<< std::endl;
}
else
{
std::string dummy = local->get_info(PRAEFIX_INIT);
if(dummy.size() > 30)
{
dummy = dummy.substr(0, 30) + "...";
}
std::cout << FONT_LIGHT_BLUE << prefix << FONT_BLUE
<< std::setw(20) << std::left << " job/cab" << FONT_RESET
<< message
<< " | "
<< dummy
<< std::endl;
}
break;
case Level::LDATA:
if(local == nullptr)
{
std::cout << FONT_LIGHT_BLUE << prefix << FONT_BLUE
<< std::setw(20) << std::left << " job/cab" << FONT_RESET
<< message
<< " | "
<< "job nullptr!"
<< std::endl;
}
else
{
auto obj = local->get_data(DATA_READ);
auto data = static_cast<open62541::Data*>(obj.get());
if(obj == nullptr)
{
std::cout << FONT_LIGHT_BLUE << prefix << FONT_BLUE
<< std::setw(20) << std::left << " job/cab" << FONT_RESET
<< message
<< " | "
<< "data nullptr!"
<< std::endl;
}
else
{
std::cout << FONT_LIGHT_BLUE << prefix << FONT_BLUE
<< std::setw(20) << std::left << " job/cab" << FONT_RESET
<< message
<< " | "
<< data->type()
<< " - "
<< *data
<< std::endl;
}
}
break;
}
}
/* Time function */
std::string
Logger::actual_time(void)
{
auto now = std::chrono::system_clock::now();
auto now_as_time_t = std::chrono::system_clock::to_time_t(now);
auto now_ms = std::chrono::duration_cast<std::chrono::milliseconds>(now.time_since_epoch()) % 1000;
std::tm now_tm;
oswrapper::localtime(&now_as_time_t, &now_tm);
std::ostringstream oss;
oss << std::put_time(&now_tm, "[%Y-%m-%d %H:%M:%S.");
oss << std::setfill('0') << std::setw(3) << now_ms.count();
/* Fixed timezone */
oss << " (UTC+0100)]";
return oss.str();
}
/* Eof */