-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathLogger.C
112 lines (87 loc) · 1.39 KB
/
Logger.C
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
//
// CLASS Logger
// Logger.C
//
//
// Date: 2007-12-28
//
#include "Logger.H"
Logger* Logger::p_Logger = NULL;
Logger* Logger::p_OldLogger = NULL;
Logger::Logger()
{
p_Out = NULL;
b_Init = false;
}
Logger::~Logger()
{
Cleanup();
}
void Logger::Cleanup()
{
if (p_Out)
{
fclose(p_Out);
p_Out = NULL;
b_Init = false;
}
}
Logger*& Logger::GetLogger()
{
if (p_Logger == NULL)
p_Logger = new Logger();
return p_Logger;
}
void Logger::CleanupLogger(Logger*& pLogger)
{
pLogger->Cleanup();
delete pLogger;
pLogger = NULL;
}
int Logger::ChangeLogger(const char* zOutFile)
{
assert(p_OldLogger==NULL);
p_OldLogger = p_Logger;
p_Logger = NULL;
return GetLogger()->Init(zOutFile);
}
void Logger::RevertLogger(Logger* pOldLogger)
{
CleanupLogger(p_Logger);
if (pOldLogger==NULL)
{
p_Logger = p_OldLogger;
p_OldLogger = NULL;
}
else
{
p_Logger = pOldLogger;
}
}
int Logger::Init(FILE* pFD)
{
if (b_Init) return 1;
p_Out = pFD;
b_Init = true;
return 1;
}
int Logger::Init(const char* zOutFile)
{
printf("Log file %s\n", zOutFile);
if (b_Init) return 1;
p_Out = fopen(zOutFile, "w");
if (p_Out == NULL)
return 0;
b_Init = true;
return 1;
}
void Logger::Log(int iLevel, char* zFormat, ...)
{
va_list ap;
va_start(ap, zFormat);
if (p_Out==NULL || b_Init==false)
vprintf(zFormat, ap);
else
vfprintf(p_Out, zFormat, ap);
va_end(ap);
}