SystemLog.c++
上传用户:weiyuanprp
上传日期:2020-05-20
资源大小:1169k
文件大小:3k
源码类别:

传真(Fax)编程

开发平台:

C/C++

  1. /* $Id: SystemLog.c++,v 1.1.1.1 2005/11/11 21:32:03 faxguy Exp $ */
  2. /*
  3.  * Copyright (c) 1995-1996 Sam Leffler
  4.  * Copyright (c) 1995-1996 Silicon Graphics, Inc.
  5.  * HylaFAX is a trademark of Silicon Graphics
  6.  *
  7.  * Permission to use, copy, modify, distribute, and sell this software and 
  8.  * its documentation for any purpose is hereby granted without fee, provided
  9.  * that (i) the above copyright notices and this permission notice appear in
  10.  * all copies of the software and related documentation, and (ii) the names of
  11.  * Sam Leffler and Silicon Graphics may not be used in any advertising or
  12.  * publicity relating to the software without the specific, prior written
  13.  * permission of Sam Leffler and Silicon Graphics.
  14.  * 
  15.  * THE SOFTWARE IS PROVIDED "AS-IS" AND WITHOUT WARRANTY OF ANY KIND, 
  16.  * EXPRESS, IMPLIED OR OTHERWISE, INCLUDING WITHOUT LIMITATION, ANY 
  17.  * WARRANTY OF MERCHANTABILITY OR FITNESS FOR A PARTICULAR PURPOSE.  
  18.  * 
  19.  * IN NO EVENT SHALL SAM LEFFLER OR SILICON GRAPHICS BE LIABLE FOR
  20.  * ANY SPECIAL, INCIDENTAL, INDIRECT OR CONSEQUENTIAL DAMAGES OF ANY KIND,
  21.  * OR ANY DAMAGES WHATSOEVER RESULTING FROM LOSS OF USE, DATA OR PROFITS,
  22.  * WHETHER OR NOT ADVISED OF THE POSSIBILITY OF DAMAGE, AND ON ANY THEORY OF 
  23.  * LIABILITY, ARISING OUT OF OR IN CONNECTION WITH THE USE OR PERFORMANCE 
  24.  * OF THIS SOFTWARE.
  25.  */
  26. #include "port.h"
  27. #include "config.h"
  28. #include "SystemLog.h"
  29. /*
  30.  * Logging and error routines.
  31.  */
  32. extern "C" int cvtFacility(const char*, int*);
  33. int SystemLog::facility = LOG_DAEMON;
  34. const char* SystemLog::appName = "FaxApp"; // generic, override
  35. void
  36. SystemLog::setupLogging(const char* name)
  37. {
  38.     appName = name;
  39.     openlog(name, LOG_PID|LOG_ODELAY, facility);
  40. }
  41. void
  42. SystemLog::setupLogging(void)
  43. {
  44.     // NB: LOG_NDELAY 'cuz of chroot done by hfaxd
  45.     openlog(appName, LOG_PID|LOG_NDELAY, facility);
  46. }
  47. void SystemLog::closeLogging(void) { closelog(); }
  48. void
  49. SystemLog::setLogFacility(const char* fac)
  50. {
  51.     if (!cvtFacility(fac, &facility))
  52. logError("Unknown syslog facility name "%s"", fac);
  53. }
  54. void vlogInfo(const char* fmt, va_list ap)
  55.     { vsyslog(LOG_INFO|SystemLog::getLogFacility(), fmt, ap); }
  56. void
  57. logInfo(const char* fmt ...)
  58. {
  59.     va_list ap;
  60.     va_start(ap, fmt);
  61.     vlogInfo(fmt, ap);
  62.     va_end(ap);
  63. }
  64. void vlogError(const char* fmt, va_list ap)
  65.     { vsyslog(LOG_ERR|SystemLog::getLogFacility(), fmt, ap); }
  66. void
  67. logError(const char* fmt ...)
  68. {
  69.     va_list ap;
  70.     va_start(ap, fmt);
  71.     vlogError(fmt, ap);
  72.     va_end(ap);
  73. }
  74. void vlogNotice(const char* fmt, va_list ap)
  75.     { vsyslog(LOG_NOTICE|SystemLog::getLogFacility(), fmt, ap); }
  76. void
  77. logNotice(const char* fmt ...)
  78. {
  79.     va_list ap;
  80.     va_start(ap, fmt);
  81.     vlogNotice(fmt, ap);
  82.     va_end(ap);
  83. }
  84. void vlogDebug(const char* fmt, va_list ap)
  85.     { vsyslog(LOG_DEBUG|SystemLog::getLogFacility(), fmt, ap); }
  86. void
  87. logDebug(const char* fmt ...)
  88. {
  89.     va_list ap;
  90.     va_start(ap, fmt);
  91.     vlogDebug(fmt, ap);
  92.     va_end(ap);
  93. }
  94. void vlogWarning(const char* fmt, va_list ap)
  95.     { vsyslog(LOG_WARNING|SystemLog::getLogFacility(), fmt, ap); }
  96. void
  97. logWarning(const char* fmt ...)
  98. {
  99.     va_list ap;
  100.     va_start(ap, fmt);
  101.     vlogWarning(fmt, ap);
  102.     va_end(ap);
  103. }