diff options
| author | phintuka <phintuka> | 2007-01-01 06:49:20 +0000 | 
|---|---|---|
| committer | phintuka <phintuka> | 2007-01-01 06:49:20 +0000 | 
| commit | 7d79b8d7b26fe4095df25c083873d430323ab39f (patch) | |
| tree | 73644c88973d77c8b5033c38b378f1479f9b3242 | |
| parent | 2ceee702e2ad86f1f174057f78f6296bce9e60cc (diff) | |
| download | xineliboutput-7d79b8d7b26fe4095df25c083873d430323ab39f.tar.gz xineliboutput-7d79b8d7b26fe4095df25c083873d430323ab39f.tar.bz2 | |
cleanup
define static x_syslog when requested with NEED_x_syslog
| -rw-r--r-- | logdefs.h | 83 | 
1 files changed, 59 insertions, 24 deletions
| @@ -4,46 +4,64 @@   * See the main source file 'xineliboutput.c' for copyright information and   * how to reach the author.   * - * $Id: logdefs.h,v 1.4 2006-10-23 19:22:14 phintuka Exp $ + * $Id: logdefs.h,v 1.5 2007-01-01 06:49:20 phintuka Exp $   *   */  #ifndef _LOGDEFS_H_ +/* + * Default module name (goes to every log line) + */ +  #ifndef LOG_MODULENAME  #  define LOG_MODULENAME "[xine..put] "  #endif -#define TRACELINE LOGDBG("at %s:%d %s", __FILE__, __LINE__, __FUNCTION__) - +/* + * Logging functions, should not be used directly + */ -#if defined(XINELIBOUTPUT_DEBUG_STDOUT) -#  /* logging --> stdout */ -#  include <stdio.h> -#  define x_syslog(l,x...) do { printf(LOG_MODULENAME x); \ -                                printf("\n"); \ -                           } while(0) +#if defined(esyslog) || (defined(VDRVERSNUM) && VDRVERSNUM >= 10343) +#  define x_syslog(l,x...) syslog_with_tid(l, LOG_MODULENAME x) +#else -#elif defined(XINELIBOUTPUT_DEBUG_STDERR) -#  /* logging --> stderr */ -#  include <stdio.h> -#  define x_syslog(l,x...) do { fprintf(stderr, LOG_MODULENAME x); \ -                                fprintf(stderr,"\n"); \ -                           } while(0) +   /* from xine_frontend.c or vdr tools.c: */ +   extern int SysLogLevel; /* errors, info, debug */ -#else -#  /* logging --> syslog */ -#  include <syslog.h> -#  if defined(VDRVERSNUM) && VDRVERSNUM >= 10343 -#    define x_syslog(l,x...) syslog_with_tid(l, LOG_MODULENAME x) -#  else -#    define x_syslog(l,x...) syslog(l, LOG_MODULENAME x) +#  ifndef LogToSysLog +   extern int LogToSysLog; /* xine_frontend_c, log to syslog instead of console */  #  endif -#endif + +#  if defined(NEED_x_syslog) +#    include <syslog.h> +#    include <sys/syscall.h> +#    include <stdarg.h> +     static void x_syslog(int level, const char *fmt, ...) __attribute__ ((format (printf, 2, 3))); +     static void x_syslog(int level, const char *fmt, ...) +     {  +       va_list argp; +       char buf[512]; +       va_start(argp, fmt); +       vsnprintf(buf, 512, fmt, argp); +       if(!LogToSysLog) { +	 fprintf(stderr,"[%ld] " LOG_MODULENAME "%s\n", syscall(__NR_gettid), buf); +       } else { +	 syslog(level, "[%ld] " LOG_MODULENAME "%s", syscall(__NR_gettid), buf); +       } +       va_end(argp); +     } +#  endif /* NEED_x_syslog */ +#endif /* VDR */ + + +/* + * Macros used for logging + */  #include <errno.h> -#define LOG_ERRNO  x_syslog(LOG_ERR, "ERROR (%s,%d): %s", \ +#define LOG_ERRNO  x_syslog(LOG_ERR, "   (ERROR (%s,%d): %s)", \                     __FILE__, __LINE__, strerror(errno))  #define LOGERR(x...) do { \ @@ -56,6 +74,13 @@  #define LOGMSG(x...) do{ if(SysLogLevel > 1) x_syslog(LOG_INFO,  x); } while(0)  #define LOGDBG(x...) do{ if(SysLogLevel > 2) x_syslog(LOG_DEBUG, x); } while(0) +#define TRACELINE LOGDBG("at %s:%d %s", __FILE__, __LINE__, __FUNCTION__) + + + +/* + * ASSERT + */  #ifdef NDEBUG  #  define ASSERT(expr) @@ -72,6 +97,10 @@  #endif +/* + * Plugin (call)trace + */ +  #ifdef XINELIBOUTPUT_DEBUG  # ifdef __cplusplus  # @@ -104,6 +133,12 @@  #  define TRACEF(x)  #endif + +/* + * Execution time tracker:  + * log a message when function execution takes longer than expected + */ +  #ifdef __cplusplus  #  ifdef TRACK_EXEC_TIME       class cTimeTracker  | 
