2002-06-27 00:45:49 +02:00
|
|
|
/*
|
|
|
|
* log.h
|
|
|
|
* Logging facilities.
|
|
|
|
*
|
|
|
|
* Matej Pfajfar <mp292@cam.ac.uk>
|
|
|
|
*/
|
|
|
|
|
|
|
|
#ifndef __LOG_H
|
|
|
|
|
|
|
|
#include <syslog.h>
|
|
|
|
|
2003-06-18 00:14:44 +02:00
|
|
|
/* magic to make GCC check for proper format strings. */
|
|
|
|
#ifdef __GNUC__
|
|
|
|
#define CHECK_PRINTF(formatIdx, firstArg) \
|
|
|
|
__attribute__ ((format (printf, formatIdx, firstArg)))
|
|
|
|
#else
|
|
|
|
#define CHECK_PRINTF(formatIdx, firstArg)
|
|
|
|
#endif
|
|
|
|
|
2002-06-27 00:45:49 +02:00
|
|
|
/* Outputs a message to stdout and also logs the same message using syslog. */
|
2003-06-18 00:14:44 +02:00
|
|
|
void log(int severity, const char *format, ...) CHECK_PRINTF(2,3);
|
2002-06-27 00:45:49 +02:00
|
|
|
|
2003-05-09 04:41:27 +02:00
|
|
|
#ifdef __GNUC__
|
2003-06-18 00:14:44 +02:00
|
|
|
void _log_fn(int severity, const char *funcname, const char *format, ...)
|
|
|
|
CHECK_PRINTF(3,4);
|
2003-06-17 23:15:25 +02:00
|
|
|
#define log_fn(severity, args...) \
|
2003-06-17 23:36:44 +02:00
|
|
|
_log_fn(severity, __PRETTY_FUNCTION__, args)
|
2003-05-09 04:25:37 +02:00
|
|
|
#else
|
|
|
|
#define log_fn log
|
|
|
|
#endif
|
|
|
|
|
2002-06-27 00:45:49 +02:00
|
|
|
# define __LOG_H
|
|
|
|
#endif
|