Blame logging.h

Packit 96c956
/*
Packit 96c956
  chronyd/chronyc - Programs for keeping computer clocks accurate.
Packit 96c956
Packit 96c956
 **********************************************************************
Packit 96c956
 * Copyright (C) Richard P. Curnow  1997-2002
Packit 96c956
 * Copyright (C) Miroslav Lichvar  2013-2015
Packit 96c956
 * 
Packit 96c956
 * This program is free software; you can redistribute it and/or modify
Packit 96c956
 * it under the terms of version 2 of the GNU General Public License as
Packit 96c956
 * published by the Free Software Foundation.
Packit 96c956
 * 
Packit 96c956
 * This program is distributed in the hope that it will be useful, but
Packit 96c956
 * WITHOUT ANY WARRANTY; without even the implied warranty of
Packit 96c956
 * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the GNU
Packit 96c956
 * General Public License for more details.
Packit 96c956
 * 
Packit 96c956
 * You should have received a copy of the GNU General Public License along
Packit 96c956
 * with this program; if not, write to the Free Software Foundation, Inc.,
Packit 96c956
 * 51 Franklin Street, Fifth Floor, Boston, MA  02110-1301, USA.
Packit 96c956
 * 
Packit 96c956
 **********************************************************************
Packit 96c956
Packit 96c956
  =======================================================================
Packit 96c956
Packit 96c956
  Header file for diagnostic logging module
Packit 96c956
Packit 96c956
  */
Packit 96c956
Packit 96c956
#ifndef GOT_LOGGING_H
Packit 96c956
#define GOT_LOGGING_H
Packit 96c956
Packit 96c956
#include "sysincl.h"
Packit 96c956
Packit 96c956
/* Flag indicating whether debug messages are logged */
Packit 96c956
extern int log_debug_enabled;
Packit 96c956
Packit 96c956
/* Line logging macros.  If the compiler is GNU C, we take advantage of
Packit 96c956
   being able to get the function name also. */
Packit 96c956
Packit 96c956
#ifdef __GNUC__
Packit 96c956
#define FUNCTION_NAME __FUNCTION__
Packit 96c956
#define FORMAT_ATTRIBUTE_PRINTF(str, first) __attribute__ ((format (printf, str, first)))
Packit 96c956
#else
Packit 96c956
#define FUNCTION_NAME ""
Packit 96c956
#define FORMAT_ATTRIBUTE_PRINTF(str, first)
Packit 96c956
#endif
Packit 96c956
Packit 96c956
#if DEBUG > 0
Packit 96c956
#define LOG_MESSAGE(severity, ...) \
Packit 96c956
  LOG_Message(severity, __LINE__, __FILE__, FUNCTION_NAME, __VA_ARGS__)
Packit 96c956
#else
Packit 96c956
#define LOG_MESSAGE(severity, ...) \
Packit 96c956
  LOG_Message(severity, __VA_ARGS__)
Packit 96c956
#endif
Packit 96c956
Packit 96c956
#define DEBUG_LOG(...) \
Packit 96c956
  do { \
Packit 96c956
    if (DEBUG && log_debug_enabled) \
Packit 96c956
      LOG_MESSAGE(LOGS_DEBUG, __VA_ARGS__); \
Packit 96c956
  } while (0)
Packit 96c956
Packit 96c956
#define LOG_FATAL(...) \
Packit 96c956
  do { \
Packit 96c956
    LOG_MESSAGE(LOGS_FATAL, __VA_ARGS__); \
Packit 96c956
    exit(1); \
Packit 96c956
  } while (0)
Packit 96c956
Packit 96c956
#define LOG(severity, ...) LOG_MESSAGE(severity, __VA_ARGS__)
Packit 96c956
Packit 96c956
/* Definition of severity */
Packit 96c956
typedef enum {
Packit 96c956
  LOGS_INFO,
Packit 96c956
  LOGS_WARN,
Packit 96c956
  LOGS_ERR,
Packit 96c956
  LOGS_FATAL,
Packit 96c956
  LOGS_DEBUG
Packit 96c956
} LOG_Severity;
Packit 96c956
Packit 96c956
/* Init function */
Packit 96c956
extern void LOG_Initialise(void);
Packit 96c956
Packit 96c956
/* Fini function */
Packit 96c956
extern void LOG_Finalise(void);
Packit 96c956
Packit 96c956
/* Line logging function */
Packit 96c956
#if DEBUG > 0
Packit 96c956
FORMAT_ATTRIBUTE_PRINTF(5, 6)
Packit 96c956
extern void LOG_Message(LOG_Severity severity, int line_number, const char *filename,
Packit 96c956
                        const char *function_name, const char *format, ...);
Packit 96c956
#else
Packit 96c956
FORMAT_ATTRIBUTE_PRINTF(2, 3)
Packit 96c956
extern void LOG_Message(LOG_Severity severity, const char *format, ...);
Packit 96c956
#endif
Packit 96c956
Packit 96c956
/* Set debug level:
Packit 96c956
   0, 1 - only non-debug messages are logged
Packit 96c956
   2    - debug messages are logged too, all messages are prefixed with
Packit 96c956
          filename, line, and function name
Packit 96c956
   */
Packit 96c956
extern void LOG_SetDebugLevel(int level);
Packit 96c956
Packit 96c956
/* Log messages to a file instead of stderr, or stderr again if NULL */
Packit 96c956
extern void LOG_OpenFileLog(const char *log_file);
Packit 96c956
Packit 96c956
/* Log messages to syslog instead of stderr */
Packit 96c956
extern void LOG_OpenSystemLog(void);
Packit 96c956
Packit 96c956
/* Stop using stderr and send fatal message to the foreground process */
Packit 96c956
extern void LOG_SetParentFd(int fd);
Packit 96c956
Packit 96c956
/* Close the pipe to the foreground process so it can exit */
Packit 96c956
extern void LOG_CloseParentFd(void);
Packit 96c956
Packit 96c956
/* File logging functions */
Packit 96c956
Packit 96c956
typedef int LOG_FileID;
Packit 96c956
Packit 96c956
extern LOG_FileID LOG_FileOpen(const char *name, const char *banner);
Packit 96c956
Packit 96c956
FORMAT_ATTRIBUTE_PRINTF(2, 3)
Packit 96c956
extern void LOG_FileWrite(LOG_FileID id, const char *format, ...);
Packit 96c956
Packit 96c956
extern void LOG_CycleLogFiles(void);
Packit 96c956
Packit 96c956
#endif /* GOT_LOGGING_H */