mirror of
https://github.com/simon987/sist2.git
synced 2025-04-24 12:45:56 +00:00
126 lines
3.2 KiB
C
126 lines
3.2 KiB
C
#include "log.h"
|
|
|
|
#include <pthread.h>
|
|
#include <stdarg.h>
|
|
|
|
const char *log_colors[] = {
|
|
"\033[34m", "\033[01;34m", "\033[01;33m", "\033[0m", "\033[31m", "\033[01;31m"
|
|
};
|
|
|
|
const char *log_levels[] = {
|
|
"DEBUG", "INFO", "WARNING", "ERROR", "FATAL"
|
|
};
|
|
|
|
void vsist_logf(const char *filepath, int level, char *format, va_list ap) {
|
|
|
|
static int is_tty = -1;
|
|
if (is_tty == -1) {
|
|
is_tty = isatty(STDERR_FILENO);
|
|
}
|
|
|
|
char log_str[LOG_MAX_LENGTH];
|
|
|
|
unsigned long long pid = (unsigned long long) pthread_self();
|
|
|
|
char datetime[32];
|
|
time_t t;
|
|
struct tm result;
|
|
t = time(NULL);
|
|
localtime_r(&t, &result);
|
|
strftime(datetime, sizeof(datetime), "%Y-%m-%d %H:%M:%S", &result);
|
|
|
|
int log_len;
|
|
if (is_tty) {
|
|
log_len = snprintf(
|
|
log_str, sizeof(log_str),
|
|
"\033[%dm[%04llX]%s [%s] [%s %s] ",
|
|
31 + ((unsigned int) (pid)) % 7, pid, log_colors[level],
|
|
datetime, log_levels[level], filepath
|
|
);
|
|
} else {
|
|
log_len = snprintf(
|
|
log_str, sizeof(log_str),
|
|
"[%04llX] [%s] [%s %s] ",
|
|
pid, datetime, log_levels[level], filepath
|
|
);
|
|
}
|
|
|
|
size_t maxsize = sizeof(log_str) - log_len;
|
|
log_len += vsnprintf(log_str + log_len, maxsize, format, ap);
|
|
|
|
if (log_len >= maxsize) {
|
|
fprintf(stderr, "([%s] FIXME: Log string is too long to display: %dB)\n",
|
|
log_levels[level], log_len);
|
|
return;
|
|
}
|
|
|
|
if (is_tty) {
|
|
log_len += sprintf(log_str + log_len, "\033[0m\n");
|
|
} else {
|
|
*(log_str + log_len) = '\n';
|
|
log_len += 1;
|
|
}
|
|
|
|
if (PrintingProgressBar) {
|
|
PrintingProgressBar = FALSE;
|
|
memmove(log_str + 1, log_str, log_len);
|
|
log_str[0] = '\n';
|
|
log_len += 1;
|
|
}
|
|
|
|
write(STDERR_FILENO, log_str, log_len);
|
|
}
|
|
|
|
void sist_logf(const char *filepath, int level, char *format, ...) {
|
|
va_list ap;
|
|
va_start(ap, format);
|
|
vsist_logf(filepath, level, format, ap);
|
|
va_end(ap);
|
|
}
|
|
|
|
void sist_log(const char *filepath, int level, char *str) {
|
|
|
|
static int is_tty = -1;
|
|
if (is_tty == -1) {
|
|
is_tty = isatty(STDERR_FILENO);
|
|
}
|
|
|
|
char log_str[LOG_MAX_LENGTH];
|
|
|
|
unsigned long long pid = (unsigned long long) pthread_self();
|
|
|
|
char datetime[32];
|
|
time_t t;
|
|
struct tm result;
|
|
t = time(NULL);
|
|
localtime_r(&t, &result);
|
|
strftime(datetime, sizeof(datetime), "%Y-%m-%d %H:%M:%S", &result);
|
|
|
|
int log_len;
|
|
if (is_tty) {
|
|
log_len = snprintf(
|
|
log_str, sizeof(log_str),
|
|
"\033[%dm[%04llX]%s [%s] [%s %s] %s \033[0m\n",
|
|
31 + ((unsigned int) (pid)) % 7, pid, log_colors[level],
|
|
datetime, log_levels[level], filepath,
|
|
str
|
|
);
|
|
} else {
|
|
log_len = snprintf(
|
|
log_str, sizeof(log_str),
|
|
"[%04llX] [%s] [%s %s] %s \n",
|
|
pid, datetime, log_levels[level], filepath,
|
|
str
|
|
);
|
|
}
|
|
|
|
if (PrintingProgressBar) {
|
|
PrintingProgressBar = FALSE;
|
|
memmove(log_str + 1, log_str, log_len);
|
|
log_str[0] = '\n';
|
|
log_len += 1;
|
|
}
|
|
|
|
write(STDERR_FILENO, log_str, log_len);
|
|
}
|