JZsdk_Logger_Init.c
6.8 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
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
150
151
152
153
154
155
156
157
158
159
160
161
162
163
164
165
166
167
168
169
170
171
172
173
174
175
176
177
178
179
180
181
182
183
184
185
186
187
188
189
190
191
192
193
194
195
196
197
198
199
200
201
202
203
204
205
206
207
208
209
210
211
212
213
214
215
216
217
218
219
220
221
222
223
224
225
226
227
228
229
230
231
232
233
234
235
236
237
238
239
240
241
242
243
#include "JZsdk_Logger.h"
#include "JZsdkLib.h"
#include <unistd.h>
#include <time.h>
#define JZSDK_LOG_PATH "/root/sdcard/JZLOG/" //sd卡存放路径
#define JZSDK_LOG_INDEX_PATH "/root/JZLOG/" //sd卡存放序号文件路径
#define JZSDK_LOG_INDEX_FILE_NAME "/root/JZLOG/thelast" //sd卡存放序号文件路径
#define JZ_LOG_FOLDER_NAME_MAX_SIZE (32)
#define JZ_LOG_MAX_COUNT (10)
#define JZ_SYSTEM_CMD_STR_MAX_SIZE (64)
#define JZSDK_LOG_MAX_COUNT 20
#define LOG_GRADE JZSDK_LOGGER_CONSOLE_LOG_LEVEL_INFO //日志等级!
/* 全局变量 ------------------------------------------------------------------*/
static struct timeval g_start_time;
static FILE *logFile = NULL;
static FILE *logFileCnt = NULL;
static int Logger_init_flag = JZ_FLAGCODE_OFF;
/* 函数声明 ------------------------------------------------------------------*/
static T_JZsdkReturnCode createJZLOGFolder()
{
// 使用系统命令检测路径是否存在
if(JZsdk_check_directory_exists_posix(JZSDK_LOG_PATH) != JZ_ERROR_SYSTEM_MODULE_CODE_SUCCESS)
{
JZsdk_Osal_Mkdir(JZSDK_LOG_PATH);
}
if(JZsdk_check_directory_exists_posix(JZSDK_LOG_INDEX_PATH) != JZ_ERROR_SYSTEM_MODULE_CODE_SUCCESS)
{
JZsdk_Osal_Mkdir(JZSDK_LOG_INDEX_PATH);
}
return JZ_ERROR_SYSTEM_MODULE_CODE_SUCCESS;
}
static T_JZsdkReturnCode JzUser_PrintConsole(const JZ_U8 *data, JZ_U16 dataLen)
{
dataLen = dataLen;
printf("%s", data);
return JZ_ERROR_SYSTEM_MODULE_CODE_SUCCESS;
}
static T_JZsdkReturnCode JzUser_LocalWrite(const JZ_U8 *data, JZ_U16 dataLen)
{
JZ_U32 realLen;
if (logFile == NULL)
{
return JZ_ERROR_SYSTEM_MODULE_CODE_INVALID_PARAMETER;
}
realLen = fwrite(data, 1, dataLen, logFile);
fflush(logFile);
if (realLen == dataLen)
{
return JZ_ERROR_SYSTEM_MODULE_CODE_SUCCESS;
}
else
{
return JZ_ERROR_SYSTEM_MODULE_CODE_FAILURE;
}
}
static T_JZsdkReturnCode JzUser_LocalWriteFsInit(const JZ_U8 *path)
{
JZ_U8 filePath[JZSDK_FILE_PATH_SIZE_MAX];
JZ_U8 systemCmd[JZ_SYSTEM_CMD_STR_MAX_SIZE];
JZ_U8 folderName[JZ_LOG_FOLDER_NAME_MAX_SIZE];
time_t currentTime = time(NULL);
struct tm *localTime = localtime(¤tTime);
uint16_t logFileIndex = 0;
uint16_t currentLogFileIndex;
uint8_t ret;
if (localTime == NULL)
{
printf("Get local time error.\r\n");
return JZ_ERROR_SYSTEM_MODULE_CODE_FAILURE;
}
logFileCnt = fopen(JZSDK_LOG_INDEX_FILE_NAME, "rb+");
if (logFileCnt == NULL)
{
logFileCnt = fopen(JZSDK_LOG_INDEX_FILE_NAME, "wb+");
if (logFileCnt == NULL)
{
return JZ_ERROR_SYSTEM_MODULE_CODE_FAILURE;
}
}
else
{
ret = fseek(logFileCnt, 0, SEEK_SET);
if (ret != 0)
{
printf("Seek log count file error.\r\n");
return JZ_ERROR_SYSTEM_MODULE_CODE_FAILURE;
}
ret = fread((uint16_t *) &logFileIndex, 1, sizeof(uint16_t), logFileCnt);
if (ret != sizeof(uint16_t))
{
printf("Read log file index error.\r\n");
}
}
currentLogFileIndex = logFileIndex;
logFileIndex++;
ret = fseek(logFileCnt, 0, SEEK_SET);
if (ret != 0) {
printf("Seek log file error, ret: %d\r\n", ret);
return JZ_ERROR_SYSTEM_MODULE_CODE_FAILURE;
}
ret = fwrite((uint16_t *) &logFileIndex, 1, sizeof(uint16_t), logFileCnt);
if (ret != sizeof(uint16_t)) {
printf("Write log file index error.\r\n");
fclose(logFileCnt);
return JZ_ERROR_SYSTEM_MODULE_CODE_FAILURE;
}
fclose(logFileCnt);
//移除sd卡的计数文件
memset(systemCmd, 0, sizeof(systemCmd));
sprintf(systemCmd, "rm -f %sthelast", JZSDK_LOG_PATH);
ret = system(systemCmd);
if (ret != 0) {
JZSDK_LOG_ERROR("Remove file error, ret:%d.\r\n", ret);
}
//复制日志计数文件到sd卡
memset(systemCmd, 0, sizeof(systemCmd));
sprintf(systemCmd, "cp %s %s", JZSDK_LOG_INDEX_FILE_NAME, JZSDK_LOG_PATH);
ret = system(systemCmd);
if (ret != 0) {
JZSDK_LOG_ERROR("Copy file error, ret:%d.\r\n", ret);
}
//开始打开log文件
sprintf(filePath, "%s_%04d_%04d%02d%02d_%02d-%02d-%02d.log", path, currentLogFileIndex,
localTime->tm_year + 1900, localTime->tm_mon + 1, localTime->tm_mday,
localTime->tm_hour, localTime->tm_min, localTime->tm_sec);
logFile = fopen(filePath, "wb+");
if (logFile == NULL) {
JZSDK_LOG_ERROR("Open filepath time error.");
return JZ_ERROR_SYSTEM_MODULE_CODE_FAILURE;
}
if (logFileIndex >= JZ_LOG_MAX_COUNT)
{
//把多余的日志删除
sprintf(systemCmd, "rm -rf %s_%04d*.log", path, currentLogFileIndex - JZ_LOG_MAX_COUNT);
ret = system(systemCmd);
if (ret != 0) {
printf("Remove file error, ret:%d.\r\n", ret);
return JZ_ERROR_SYSTEM_MODULE_CODE_FAILURE;
}
}
return JZ_ERROR_SYSTEM_MODULE_CODE_SUCCESS;
}
T_JZsdkReturnCode JZsdk_LoggerInit()
{
T_JZsdkReturnCode ReturnCode;
unsigned int logFileIndex = 0;
unsigned int currentLogFileIndex;
T_JZsdkLoggerConsole printfConsole = {
.func = JzUser_PrintConsole,
.consoleLevel = JZSDK_LOGGER_CONSOLE_LOG_LEVEL_DEBUG,
.isSupportColor = true,
};
T_JZsdkLoggerConsole localRecordConsole = {
.func = JzUser_LocalWrite,
.consoleLevel = JZSDK_LOGGER_CONSOLE_LOG_LEVEL_INFO,
.isSupportColor = true,
};
//1、检测日志文件夹是否存在,不存在则创建
ReturnCode = createJZLOGFolder();
if(ReturnCode != JZ_ERROR_SYSTEM_MODULE_CODE_SUCCESS)
{
printf("createJZLOGFolder error\n");
return JZ_ERROR_SYSTEM_MODULE_CODE_FAILURE;
}
ReturnCode = JzUser_LocalWriteFsInit(JZSDK_LOG_PATH);
if(ReturnCode != JZ_ERROR_SYSTEM_MODULE_CODE_SUCCESS)
{
printf("file system init error\n");
return JZ_ERROR_SYSTEM_MODULE_CODE_FAILURE;
}
ReturnCode = JZsdk_Logger_AddPrintConsole(&printfConsole);
if (ReturnCode != JZ_ERROR_SYSTEM_MODULE_CODE_SUCCESS)
{
printf("JZsdk Logger AddPrintConsole error\n");
return JZ_ERROR_SYSTEM_MODULE_CODE_FAILURE;
}
ReturnCode = JZsdk_Logger_AddRecordConsole(&localRecordConsole);
if (ReturnCode != JZ_ERROR_SYSTEM_MODULE_CODE_SUCCESS)
{
printf("JZsdk Logger AddRecordConsole error\n");
return JZ_ERROR_SYSTEM_MODULE_CODE_FAILURE;
}
//设立监控
JZsdk_Log_Monitor_Init();
JZSDK_LOG_INFO("Log init success.");
return JZ_ERROR_SYSTEM_MODULE_CODE_SUCCESS;
}
T_JZsdkReturnCode JZsdk_LoggerDeInit()
{
if (logFile != NULL)
{
fclose(logFile);
logFile = NULL;
}
return JZ_ERROR_SYSTEM_MODULE_CODE_SUCCESS;
}