-
Notifications
You must be signed in to change notification settings - Fork 1
Expand file tree
/
Copy pathBoxTrace.h
More file actions
124 lines (104 loc) · 2.6 KB
/
BoxTrace.h
File metadata and controls
124 lines (104 loc) · 2.6 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
115
116
117
118
119
120
121
122
123
124
#ifndef BOX_TRACE_H
#define BOX_TRACE_H
#if defined(DEBUG_MODE) || defined(PRINT_DEBUG_MODE)
#include "BoxInfo.h"
#include "Data.h"
#include "File.h"
#include <thread>
#include <list>
#include <string>
#define TRACE_MAX_INFO (256)
class BoxTrace {
public:
void open(char *name);
void add(char *traceGroup, char *info);
void addTrace(std::string traceGroup);
void print(char *traceGroup, char *info);
private:
void addEntry(char *traceGroup, char *info);
bool traceExist(std::string traceGroup);
File file;
std::list<std::string> traceList;
};
void BoxTrace::addTrace(std::string traceGroup)
{
traceList.push_front(traceGroup);
}
bool BoxTrace::traceExist(std::string traceGroup)
{
std::list<std::string>::iterator it = traceList.begin();
while (true)
{
if (it == traceList.end())
return false;
if (*it == traceGroup)
return true;
it++;
}
return false;
}
void BoxTrace::open(char *name)
{
char logNameFull[256];
sprintf(logNameFull, "%s.log", name);
file.open(logNameFull, FILE_WRITE, 0);
}
void BoxTrace::addEntry(char *traceGroup, char *info)
{
Data data(BOX_STRING);
char logEntry[TRACE_MAX_INFO];
time_t timeVar;
time(&timeVar);
struct tm *time = localtime(&timeVar);
sprintf(logEntry, "(%d:%d:%d) [%s] %s\n", time->tm_hour,
time->tm_min,
time->tm_sec,
traceGroup,
info);
data.setAddress(logEntry);
file.write(&data);
}
void BoxTrace::add(char *traceGroup, char *info)
{
if (traceExist(traceGroup))
{
std::thread t1([&] { addEntry(traceGroup, info); });
t1.join();
}
}
void BoxTrace::print(char *traceGroup, char *info)
{
char logEntry[TRACE_MAX_INFO];
time_t timeVar;
if (traceExist(traceGroup))
{
time(&timeVar);
struct tm *time = localtime(&timeVar);
printf("(%d:%d:%d) [%s] %s\n",
time->tm_hour,
time->tm_min,
time->tm_sec,
traceGroup,
info);
}
}
BoxTrace boxTrace;
char freeText[TRACE_MAX_INFO];
#endif
#if defined(DEBUG_MODE) || defined(PRINT_DEBUG_MODE)
#define ADD_TRACE(__GROUP) boxTrace.addTrace(__GROUP);
#else
#define ADD_TRACE(__GROUP) ;
#endif
#if defined(DEBUG_MODE)
#define TRACE(__GROUP, __FORMAT, ...) \
sprintf(freeText, __FORMAT, __VA_ARGS__); \
boxTrace.add(__GROUP, freeText);
#elif defined(PRINT_DEBUG_MODE)
#define TRACE(__GROUP, __FORMAT, ...) \
sprintf(freeText, __FORMAT, __VA_ARGS__); \
boxTrace.print(__GROUP, freeText);
#else
#define TRACE(__GROUP, __FORMAT, ...) ;
#endif
#endif