⭐ 欢迎来到虫虫下载站! | 📦 资源下载 📁 资源专辑 ℹ️ 关于我们
⭐ 虫虫下载站

📄 log.c

📁 MODBUS/TCP to RS-232/485 MODBUS/RTU gateway server
💻 C
字号:
/* * OpenMODBUS/TCP to RS-232/485 MODBUS RTU gateway * * log.c - debug logging facility * * Copyright (c) 2002-2003, Victor Antonovich (avmlink@vlink.ru) *  * 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.4 2003/10/26 19:26:08 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 log(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) printf("%s", str);  if (*logfullname == '\0') return;  log_app(logfullname, str);}#endif

⌨️ 快捷键说明

复制代码 Ctrl + C
搜索代码 Ctrl + F
全屏模式 F11
切换主题 Ctrl + Shift + D
显示快捷键 ?
增大字号 Ctrl + =
减小字号 Ctrl + -