mirror of
https://github.com/servalproject/serval-dna.git
synced 2024-12-19 13:17:56 +00:00
95 lines
2.3 KiB
C
95 lines
2.3 KiB
C
|
/*
|
||
|
Serval logging to standard error
|
||
|
Copyright 2014 Serval Project Inc.
|
||
|
|
||
|
This program is free software; you can redistribute it and/or
|
||
|
modify it under the terms of the GNU General Public License
|
||
|
as published by the Free Software Foundation; either version 2
|
||
|
of the License, or (at your option) any later version.
|
||
|
|
||
|
This program is distributed in the hope that it will be useful,
|
||
|
but WITHOUT ANY WARRANTY; without even the implied warranty of
|
||
|
MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
|
||
|
GNU General Public License for more details.
|
||
|
|
||
|
You should have received a copy of the GNU General Public License
|
||
|
along with this program; if not, write to the Free Software
|
||
|
Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301, USA.
|
||
|
*/
|
||
|
|
||
|
#include <stdio.h>
|
||
|
#include <time.h>
|
||
|
#include <sys/time.h>
|
||
|
#include "log.h"
|
||
|
|
||
|
/* An implementation of the Serval logging API that writes directly to standard error
|
||
|
* using stdio buffered output.
|
||
|
*/
|
||
|
|
||
|
static const char *_trimbuildpath(const char *path)
|
||
|
{
|
||
|
/* Remove common path prefix */
|
||
|
int lastsep = 0;
|
||
|
int i;
|
||
|
for (i = 0; __FILE__[i] && path[i]; ++i) {
|
||
|
if (i && path[i - 1] == '/')
|
||
|
lastsep = i;
|
||
|
if (__FILE__[i] != path[i])
|
||
|
break;
|
||
|
}
|
||
|
return &path[lastsep];
|
||
|
}
|
||
|
|
||
|
void vlogMessage(int level, struct __sourceloc whence, const char *fmt, va_list ap)
|
||
|
{
|
||
|
const char *levelstr = "UNKWN:";
|
||
|
switch (level) {
|
||
|
case LOG_LEVEL_FATAL:
|
||
|
levelstr = "FATAL:";
|
||
|
break;
|
||
|
case LOG_LEVEL_ERROR:
|
||
|
levelstr = "ERROR:";
|
||
|
break;
|
||
|
case LOG_LEVEL_INFO:
|
||
|
levelstr = "INFO:";
|
||
|
break;
|
||
|
case LOG_LEVEL_WARN:
|
||
|
levelstr = "WARN:";
|
||
|
break;
|
||
|
case LOG_LEVEL_DEBUG:
|
||
|
levelstr = "DEBUG:";
|
||
|
break;
|
||
|
}
|
||
|
|
||
|
struct timeval tv;
|
||
|
struct tm tm;
|
||
|
gettimeofday(&tv, NULL);
|
||
|
localtime_r(&tv.tv_sec, &tm);
|
||
|
char buf[50];
|
||
|
strftime(buf, sizeof buf, "%T", &tm);
|
||
|
fprintf(stderr, "%s.%03u ", buf, (unsigned int)tv.tv_usec / 1000);
|
||
|
|
||
|
fprintf(stderr, "%s ", levelstr);
|
||
|
if (whence.file) {
|
||
|
fprintf(stderr, "%s", _trimbuildpath(whence.file));
|
||
|
if (whence.line)
|
||
|
fprintf(stderr, ":%u", whence.line);
|
||
|
if (whence.function)
|
||
|
fprintf(stderr, ":%s()", whence.function);
|
||
|
fputc(' ', stderr);
|
||
|
} else if (whence.function) {
|
||
|
fprintf(stderr, "%s() ", whence.function);
|
||
|
}
|
||
|
vfprintf(stderr, fmt, ap);
|
||
|
fputc('\n', stderr);
|
||
|
}
|
||
|
|
||
|
void logFlush()
|
||
|
{
|
||
|
fflush(stderr);
|
||
|
}
|
||
|
|
||
|
void logConfigChanged()
|
||
|
{
|
||
|
}
|