Prettier log time format
This commit is contained in:
parent
33d88529c6
commit
9a7571051f
|
@ -5,11 +5,12 @@
|
||||||
|
|
||||||
#include <string.h>
|
#include <string.h>
|
||||||
#include <stdio.h>
|
#include <stdio.h>
|
||||||
|
#include <stdint.h>
|
||||||
|
#include <stdbool.h>
|
||||||
|
#include <time.h>
|
||||||
#include <errno.h>
|
#include <errno.h>
|
||||||
#include <unistd.h>
|
#include <unistd.h>
|
||||||
#include <fcntl.h>
|
#include <fcntl.h>
|
||||||
#include <stdint.h>
|
|
||||||
#include <stdbool.h>
|
|
||||||
#include <sys/types.h>
|
#include <sys/types.h>
|
||||||
#include <sys/stat.h>
|
#include <sys/stat.h>
|
||||||
#include <sys/time.h>
|
#include <sys/time.h>
|
||||||
|
@ -62,8 +63,8 @@ static bool first_before_second(const struct log_line *line1, const struct log_l
|
||||||
int write_logs_to_file(const char *file_name, const struct log *log1, const char *tag1, const struct log *log2, const char *tag2)
|
int write_logs_to_file(const char *file_name, const struct log *log1, const char *tag1, const struct log *log2, const char *tag2)
|
||||||
{
|
{
|
||||||
uint32_t i1, i2, len1 = log1->header.len, len2 = log2->header.len;
|
uint32_t i1, i2, len1 = log1->header.len, len2 = log2->header.len;
|
||||||
char buf[MAX_LOG_LINE_LENGTH];
|
|
||||||
FILE *file;
|
FILE *file;
|
||||||
|
int ret;
|
||||||
|
|
||||||
if (len1 > MAX_LINES)
|
if (len1 > MAX_LINES)
|
||||||
len1 = MAX_LINES;
|
len1 = MAX_LINES;
|
||||||
|
@ -75,6 +76,8 @@ int write_logs_to_file(const char *file_name, const struct log *log1, const char
|
||||||
return -errno;
|
return -errno;
|
||||||
|
|
||||||
for (i1 = 0, i2 = 0;;) {
|
for (i1 = 0, i2 = 0;;) {
|
||||||
|
struct tm tm;
|
||||||
|
char buf[MAX_LOG_LINE_LENGTH];
|
||||||
const struct log_line *line1 = &log1->lines[(log1->header.first + i1) % MAX_LINES];
|
const struct log_line *line1 = &log1->lines[(log1->header.first + i1) % MAX_LINES];
|
||||||
const struct log_line *line2 = &log2->lines[(log2->header.first + i2) % MAX_LINES];
|
const struct log_line *line2 = &log2->lines[(log2->header.first + i2) % MAX_LINES];
|
||||||
const struct log_line *line;
|
const struct log_line *line;
|
||||||
|
@ -91,17 +94,24 @@ int write_logs_to_file(const char *file_name, const struct log *log1, const char
|
||||||
} else {
|
} else {
|
||||||
break;
|
break;
|
||||||
}
|
}
|
||||||
|
|
||||||
memcpy(buf, line->line, MAX_LOG_LINE_LENGTH);
|
memcpy(buf, line->line, MAX_LOG_LINE_LENGTH);
|
||||||
buf[MAX_LOG_LINE_LENGTH - 1] = '\0';
|
buf[MAX_LOG_LINE_LENGTH - 1] = '\0';
|
||||||
if (fprintf(file, "%lu.%06d: [%s] %s\n", line->tv.tv_sec, line->tv.tv_usec, tag, buf) < 0) {
|
if (!localtime_r(&line->tv.tv_sec, &tm))
|
||||||
int ret = -errno;
|
goto err;
|
||||||
|
if (fprintf(file, "%04d-%02d-%02d %02d:%02d:%02d.%06d: [%s] %s\n",
|
||||||
|
tm.tm_year + 1900, tm.tm_mon + 1, tm.tm_mday,
|
||||||
|
tm.tm_hour, tm.tm_min, tm.tm_sec, line->tv.tv_usec,
|
||||||
|
tag, buf) < 0)
|
||||||
|
goto err;
|
||||||
|
}
|
||||||
|
errno = 0;
|
||||||
|
|
||||||
|
err:
|
||||||
|
ret = -errno;
|
||||||
fclose(file);
|
fclose(file);
|
||||||
return ret;
|
return ret;
|
||||||
}
|
}
|
||||||
}
|
|
||||||
fclose(file);
|
|
||||||
return 0;
|
|
||||||
}
|
|
||||||
|
|
||||||
struct log *open_log(const char *file_name)
|
struct log *open_log(const char *file_name)
|
||||||
{
|
{
|
||||||
|
|
Loading…
Reference in New Issue