X-Git-Url: https://git.sur5r.net/?a=blobdiff_plain;f=include%2Fldap_log.h;h=9863f2218ba656c6b6ac300f622b0bd83eeb0fce;hb=616d7962efc86fa844559dceef8250ef0fe0feb4;hp=d368b8f6a0c39add2b09ba00243af062e8f4fc29;hpb=a3ac3be6a7b0dd405c940ea62f7aa6af6dbe6caf;p=openldap diff --git a/include/ldap_log.h b/include/ldap_log.h index d368b8f6a0..9863f2218b 100644 --- a/include/ldap_log.h +++ b/include/ldap_log.h @@ -1,5 +1,18 @@ -/* - * Copyright (c) 1990 Regents of the University of Michigan. +/* $OpenLDAP$ */ +/* This work is part of OpenLDAP Software . + * + * Copyright 1998-2004 The OpenLDAP Foundation. + * All rights reserved. + * + * Redistribution and use in source and binary forms, with or without + * modification, are permitted only as authorized by the OpenLDAP + * Public License. + * + * A copy of this license is available in file LICENSE in the + * top-level directory of the distribution or, alternatively, at + * . + */ +/* Portions Copyright (c) 1990 Regents of the University of Michigan. * All rights reserved. * * Redistribution and use in source and binary forms are permitted @@ -13,21 +26,31 @@ #ifndef _LDAP_LOG_H #define _LDAP_LOG_H +#include #include LDAP_BEGIN_DECL -/* debugging stuff */ -#ifdef LDAP_DEBUG - -#ifndef ldap_debug -extern int ldap_debug; -#endif /* !ldap_debug */ - -#ifdef LDAP_SYSLOG -extern int ldap_syslog; -extern int ldap_syslog_level; -#endif /* LDAP_SYSLOG */ +/* + * debug reporting levels. + * + * They start with the syslog levels, and + * go down in importance. The normal + * debugging levels begin with LDAP_LEVEL_ENTRY + * + */ +#define LDAP_LEVEL_EMERG 0 +#define LDAP_LEVEL_ALERT 1 +#define LDAP_LEVEL_CRIT 2 +#define LDAP_LEVEL_ERR 3 +#define LDAP_LEVEL_WARNING 4 +#define LDAP_LEVEL_NOTICE 5 +#define LDAP_LEVEL_INFO 6 +#define LDAP_LEVEL_ENTRY 7 /* log function entry points */ +#define LDAP_LEVEL_ARGS 8 /* log function call parameters */ +#define LDAP_LEVEL_RESULTS 9 /* Log function results */ +#define LDAP_LEVEL_DETAIL1 10 /* log level 1 function operational details */ +#define LDAP_LEVEL_DETAIL2 11 /* Log level 2 function operational details */ #define LDAP_DEBUG_TRACE 0x0001 #define LDAP_DEBUG_PACKETS 0x0002 @@ -41,32 +64,68 @@ extern int ldap_syslog_level; #define LDAP_DEBUG_STATS2 0x0200 #define LDAP_DEBUG_SHELL 0x0400 #define LDAP_DEBUG_PARSE 0x0800 +#define LDAP_DEBUG_CACHE 0x1000 +#define LDAP_DEBUG_INDEX 0x2000 +#define LDAP_DEBUG_SYNC 0x4000 #define LDAP_DEBUG_NONE 0x8000 #define LDAP_DEBUG_ANY -1 +/* debugging stuff */ +#ifdef LDAP_DEBUG + /* + * This is a bogus extern declaration for the compiler. No need to ensure + * a 'proper' dllimport. + */ +# ifndef ldap_debug + extern int ldap_debug; +# endif /* !ldap_debug */ + +# ifdef LDAP_SYSLOG + extern int ldap_syslog; + extern int ldap_syslog_level; + +# ifdef HAVE_EBCDIC +# define syslog eb_syslog + extern void eb_syslog(int pri, const char *fmt, ...); +# endif + +# endif /* LDAP_SYSLOG */ + /* this doesn't below as part of ldap.h */ -#ifdef LDAP_SYSLOG -#define Debug( level, fmt, arg1, arg2, arg3 ) \ - { \ +# ifdef LDAP_SYSLOG +# define Debug( level, fmt, arg1, arg2, arg3 ) \ + do { \ if ( ldap_debug & (level) ) \ - fprintf( stderr, (fmt), (arg1), (arg2), (arg3) ); \ - if ( ldap_syslog & level ) \ + lutil_debug( ldap_debug, (level), (fmt), (arg1), (arg2), (arg3) ); \ + if ( ldap_syslog & (level) ) \ syslog( ldap_syslog_level, (fmt), (arg1), (arg2), (arg3) ); \ - } -#else /* LDAP_SYSLOG */ -#ifndef WINSOCK -#define Debug( level, fmt, arg1, arg2, arg3 ) \ + } while ( 0 ) + +# else +# define Debug( level, fmt, arg1, arg2, arg3 ) \ + do { \ if ( ldap_debug & (level) ) \ - fprintf( stderr, (fmt), (arg1), (arg2), (arg3) ); -#else /* !WINSOCK */ -extern void Debug( int level, char* fmt, ... ); -#endif /* !WINSOCK */ -#endif /* LDAP_SYSLOG */ + lutil_debug( ldap_debug, (level), (fmt), (arg1), (arg2), (arg3) ); \ + } while ( 0 ) +# endif + #else /* LDAP_DEBUG */ -#define Debug( level, fmt, arg1, arg2, arg3 ) +# define Debug( level, fmt, arg1, arg2, arg3 ) + #endif /* LDAP_DEBUG */ +#ifndef LDAP_LOG +#define LDAP_LOG(a, b, fmt, arg1, arg2, arg3) +#define LDAP_LOGS_TEST(a, b) 0 +#endif + +LDAP_LUTIL_F(int) lutil_debug_file LDAP_P(( FILE *file )); + +LDAP_LUTIL_F(void) lutil_debug LDAP_P(( + int debug, int level, + const char* fmt, ... )) LDAP_GCCATTR((format(printf, 3, 4))); + LDAP_END_DECL #endif /* _LDAP_LOG_H */