mbusd/src/log.c

122 lines
3.2 KiB
C

/*
* OpenMODBUS/TCP to RS-232/485 MODBUS RTU gateway
*
* log.c - debug logging facility
*
* Copyright (c) 2002-2003, 2013, Victor Antonovich (v.antonovich@gmail.com)
*
* Redistribution and use in source and binary forms, with or without
* modification, are permitted provided that the following conditions
* are met:
*
* - Redistributions of source code must retain the above copyright
* notice, this list of conditions and the following disclaimer.
*
* - Redistributions in binary form must reproduce the above copyright
* notice, this list of conditions and the following disclaimer in the
* documentation and/or other materials provided with the distribution.
*
* THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS
* ``AS IS'' AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT
* LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR
* A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE REGENTS OR
* CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL,
* EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO,
* PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR
* PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF
* LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING
* NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF THIS
* SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
*
* $Id: log.c,v 1.6 2015/02/25 10:33:57 kapyar Exp $
*/
#include "log.h"
#ifdef LOG
#include "cfg.h"
/* log file full name */
char logfullname[INTBUFSIZE + 1];
int
log_init(char *logname)
{
FILE *logfile;
int maxlen = INTBUFSIZE;
/* checking log file name */
if (*logname == '/')
strncpy(logfullname, logname, maxlen);
else
{
if (!*logname)
{
/* logfile isn't needed */
*logfullname = '\0';
return RC_OK;
}
/* append default log path */
strncpy(logfullname, LOGPATH, maxlen);
maxlen -= strlen(logfullname);
strncat(logfullname, logname, maxlen);
}
logfile = fopen(logfullname, "at");
if (logfile)
{
fclose(logfile);
return RC_OK;
}
return RC_ERR;
}
/* Append message STRING to log file LOGNAME */
int
log_app(char *logname, char *string)
{
FILE *logfile;
logfile = fopen(logname, "at");
if (logfile)
{
fputs(string, logfile);
fclose(logfile);
return RC_OK;
}
return RC_ERR;
}
/* Put message with format FMT with errorlevel LEVEL to log file */
void
logw(int level, char *fmt, ...)
{
#ifdef HRDATE
time_t tt;
struct tm *t;
#else
struct timeval tv;
#endif
va_list args;
int strsize = 0;
static char str[INTBUFSIZE + 1] = {0}, *p;
if (level > cfg.dbglvl) return;
#ifdef HRDATE
tt = time(NULL);
t = localtime(&tt);
strsize += strftime(str, 32, "%d %b %Y %H:%M:%S ", t);
#else
(void)gettimeofday(&tv, NULL);
strsize += snprintf(str, 32, "%06lu:%06lu ", tv.tv_sec, tv.tv_usec);
#endif
va_start(args, fmt);
p = str + strsize;
strsize += vsnprintf(p, INTBUFSIZE - strsize, fmt, args);
va_end(args);
strcpy(str + strsize++, "\n");
if (!isdaemon) fprintf(stderr, "%s", str);
if (*logfullname == '\0') return;
log_app(logfullname, str);
}
#endif