-
Notifications
You must be signed in to change notification settings - Fork 0
/
logger.c
64 lines (55 loc) · 1.57 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
#include "logger.h"
logLevel_t logLevel = DEBUG;
/**
* @brief Debug Level Name
* @param [in] selectLogLevel
* @return [const char*] Debug Level String
*/
static const char *debugLevelGetString(logLevel_t selectLogLevel)
{
if (selectLogLevel <= ERROR)
return "ERROR";
else if (selectLogLevel <= WARNING)
return "WARN";
else if (selectLogLevel <= INFO)
return "INFO";
return "DEBG";
}
void logger(logLevel_t selectLogLevel, const char *format, ...)
{
va_list va;
va_start(va, format);
if (selectLogLevel <= logLevel)
{
char timeBuf[30];
time_t TIME = time(NULL);
struct tm *timenow = gmtime(&TIME);
strftime(timeBuf, sizeof(timeBuf), "%Y/%m/%d %X", timenow);
fprintf(stdout, "[%s]: %s ", debugLevelGetString(selectLogLevel), timeBuf);
vfprintf(stdout, format, va);
}
va_end(va);
return;
}
void flogger(logLevel_t selectLogLevel, const char *format, ...)
{
va_list va;
va_start(va, format);
if (selectLogLevel <= logLevel)
{
char filename[60];
char timeBuf[30];
time_t TIME = time(NULL);
struct tm *timenow = gmtime(&TIME);
strftime(filename, sizeof(filename), "deviceLogs/%Y_%m_%d_App.log", timenow);
strftime(timeBuf, sizeof(timeBuf), "%Y/%m/%d %X", timenow);
FILE *file = fopen(filename, "a");
fprintf(file, "[%s]: %s ", debugLevelGetString(selectLogLevel),timeBuf);
vfprintf(file, format, va);
va_end(va);
fclose(file);
return;
}
va_end(va);
return;
}