-
Notifications
You must be signed in to change notification settings - Fork 1
/
Copy pathwrite_log.c
70 lines (52 loc) · 2.08 KB
/
write_log.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
//
// Created by liushan on 19-11-28.
//
#include "write_log.h"
int get_log_grade_by_level(const char * level_name);
int get_log_grade_by_level(const char * cur_log_level)
{
int cur_level_grade = -1;
// 获取最小记录日志名称对应的级别
if (strcmp(cur_log_level, log_write_level.info.level_name) == 0)
cur_level_grade = log_write_level.info.grade;
else if (strcmp(cur_log_level, log_write_level.notice.level_name) == 0)
cur_level_grade = log_write_level.notice.grade;
else if (strcmp(cur_log_level, log_write_level.warn.level_name) == 0)
cur_level_grade = log_write_level.warn.grade;
else if (strcmp(cur_log_level, log_write_level.error.level_name) == 0)
cur_level_grade = log_write_level.error.grade;
return cur_level_grade;
}
void write_log(const char * cur_log_level, const char * log_level, const char * log_msg, FILE * f_log_file)
{
char cur_date[CUR_DATE_LEN]; // 时间字符串
int cur_level_grade, level_grade; //记录日志的最小级别
if ( (cur_level_grade = get_log_grade_by_level(cur_log_level) ) < 0)
{
printf("error! log_level_para \"%s\" is not legal\n", cur_log_level);
exit(EXIT_FAILURE);
}
if ( (level_grade = get_log_grade_by_level(log_level) ) < 0)
{
printf("error! log_level_para \"%s\" is not legal\n", log_level);
exit(EXIT_FAILURE);
}
// 记录日志级别大于等于最小日志记录级别时,则记录日志
if (cur_level_grade >= level_grade)
{
write_log_get_cur_date(cur_date); //获取当前时间
// 时间字符串,保留23位,写死的
fprintf(f_log_file, LOG_FORMAT, cur_date, cur_log_level, log_msg);
fflush(f_log_file);
}
}
void write_log_get_cur_date(char *cur_date)
{
char * wday[] = {"Sun", "Mon", "Tue", "Wed", "Thu", "Fri", "Sat"};
time_t timep;
struct tm * p;
time(&timep);
p = localtime(&timep);
sprintf(cur_date, "%d/%d/%d %s %d:%d:%d", 1900 + p->tm_year, 1 + p->tm_mon, p->tm_mday,
wday[p->tm_wday], p->tm_hour, p->tm_min, p->tm_sec);
}