X-Git-Url: https://git.sur5r.net/?a=blobdiff_plain;f=include%2Fldap_log.h;h=eb902986207323636fc6f96d1c2845702eba9295;hb=52a827466a88825b2b4a325783c8f7ec3a74bfba;hp=08dab9cd081b230bacebbf1c5df62ac31317a16b;hpb=43f29c3cb85f252b3c6aaf39e85a5d02bffb51e0;p=openldap diff --git a/include/ldap_log.h b/include/ldap_log.h index 08dab9cd08..eb90298620 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-2005 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,54 +26,106 @@ #ifndef _LDAP_LOG_H #define _LDAP_LOG_H +#include #include LDAP_BEGIN_DECL +/* + * 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 +#define LDAP_DEBUG_ARGS 0x0004 +#define LDAP_DEBUG_CONNS 0x0008 +#define LDAP_DEBUG_BER 0x0010 +#define LDAP_DEBUG_FILTER 0x0020 +#define LDAP_DEBUG_CONFIG 0x0040 +#define LDAP_DEBUG_ACL 0x0080 +#define LDAP_DEBUG_STATS 0x0100 +#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 -extern int ldap_debug; -#ifdef LDAP_SYSLOG -extern int ldap_syslog; -extern int ldap_syslog_level; -#endif /* LDAP_SYSLOG */ - -#define LDAP_DEBUG_TRACE 0x001 -#define LDAP_DEBUG_PACKETS 0x002 -#define LDAP_DEBUG_ARGS 0x004 -#define LDAP_DEBUG_CONNS 0x008 -#define LDAP_DEBUG_BER 0x010 -#define LDAP_DEBUG_FILTER 0x020 -#define LDAP_DEBUG_CONFIG 0x040 -#define LDAP_DEBUG_ACL 0x080 -#define LDAP_DEBUG_STATS 0x100 -#define LDAP_DEBUG_STATS2 0x200 -#define LDAP_DEBUG_SHELL 0x400 -#define LDAP_DEBUG_PARSE 0x800 -#define LDAP_DEBUG_ANY 0xffff + /* + * 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 */