/*
 * $Id: aug_debug.h,v 1.1.10.1 2005/07/20 17:11:52 andrei Exp $
 *
 * POSTGRES module, portions of this code were templated using
 * the mysql module, thus it's similarity.
 *
 *
 * Copyright (C) 2003 August.Net Services, LLC
 *
 * This file is part of ser, a free SIP server.
 *
 * ser is free software; you can redistribute it and/or modify
 * it under the terms of the GNU General Public License as published by
 * the Free Software Foundation; either version 2 of the License, or
 * (at your option) any later version
 *
 * For a license to use the ser software under conditions
 * other than those described here, or to purchase support for this
 * software, please contact iptel.org by e-mail at the following addresses:
 *    info@iptel.org
 *
 * ser is distributed in the hope that it will be useful,
 * but WITHOUT ANY WARRANTY; without even the implied warranty of
 * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
 * GNU General Public License for more details.
 *
 * You should have received a copy of the GNU General Public License 
 * along with this program; if not, write to the Free Software 
 * Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA  02111-1307  USA
 *
 * ---
 *
 * History
 * -------
 * 2003-04-06 initial code written (Greg Fausak/Andy Fullford)
 *
 */
/*
** ________________________________________________________________________
**
**
**                      $RCSfile: aug_debug.h,v $
**                     $Revision: 1.1.10.1 $
**
**             Last change $Date: 2005/07/20 17:11:52 $
**           Last change $Author: andrei $
**                        $State: Exp $
**                       $Locker:  $
**
**               Original author: Andrew Fullford
**
**           Copyright (C) August Associates  1995
**
** ________________________________________________________________________
*/

/*  AM_TYPE: (INSTALL_INC)  */

#ifndef AUG_DEBUG_H
#define AUG_DEBUG_H


#ifdef DEBUG

#define augDAB_DEBUG	augTRUE

#ifdef __FILE__
#define augDAB__FILE__	__FILE__
#else
#define augDAB__FILE__	""
#endif
#ifdef __LINE__
#define augDAB__LINE__	__LINE__
#else
#define augDAB__LINE__	0
#endif

#else

#define augDAB_DEBUG	augFALSE
#define augDAB__FILE__	""
#define augDAB__LINE__	0

#endif /* DEBUG */

/*
**  Debugging levels.
**
**  Each function is tagged with a debugging level.  The initial
**  state is ``don't know'' which will trigger a match, a relatively
**  slow operation.  The result of the match is recorded so future
**  accesses will occur at integer test instruction speed.
*/
#define DAB_UNKNOWN	-1		/* Need to perform match */
#define DAB_OFF		0		/* Matched, but debugs disabled */
#define DAB_TRACE	25		/* Level implied by DABTRACE() macro */
#define DAB_STD		50		/* Level implied by DAB() macro */
#define DAB_BULK	75		/* Level implied by DABBULK() macro */

#if augDAB_DEBUG == augTRUE

#define DABNAME(name)	static char *aug_dab_func=name,			\
				    aug_dab_file[]=augDAB__FILE__;	\
			static short aug_dab_level=DAB_UNKNOWN, aug_dab_dummy

#define DABLEVEL(lev)							\
	(aug_dab_enabled &&						\
	 ((aug_dab_level == DAB_UNKNOWN &&				\
	   aug_dab_match(aug_dab_func,aug_dab_file,			\
			 augDAB__LINE__,&aug_dab_level) >= (lev)) ||	\
	  aug_dab_level >= (lev)) &&					\
	 aug_dab_pushinfo(aug_dab_func,aug_dab_file,augDAB__LINE__))

#define DABL(lev)	aug_dab_dummy = DABLEVEL(lev) && aug_dab_fmt
#define DAB		DABL(DAB_STD)
#define DABTRACE	DABL(DAB_TRACE)
#define DABBULK		DABL(DAB_BULK)
#define DABTEXT		aug_dab_text
#define DABDUMP		aug_dab_dump

#define DABSET(line)	aug_dab_set(line)
#define DABRESET()	aug_dab_reset()
#define DABLOAD(file)	aug_dab_load(file)

extern augBool aug_dab_enabled;

#else

#ifdef __SUNPRO_C
	#define DABL_NOP(...) /* ignore */
#else
	#define DABL_NOP(args...) /* ignore */
#endif
#define DABNAME(name)
#define DABLEVEL(lev)	(augFALSE)
#define DABL(lev)	 DABL_NOP
#define DAB		DABL(0)
#define DABTRACE	DABL(0)
#define DABBULK		DABL(0)
#define DABTEXT		DABL(0)
#define DABDUMP		DABL(0)

#define DABSET(line)
#define DABRESET()
#define DABLOAD(file)

#endif /* augDAB_DEBUG */

extern int aug_dab_match(char *func, char *file, int line, short *plevel);
extern augBool aug_dab_pushinfo(char *func, char *file, int line);
extern augBool aug_dab_fmt(char *fmt, ...);
extern void aug_dab_text(char *text);
extern void aug_dab_dump(char *data, int size);
extern void aug_dab_reset(void);
extern augBool aug_dab_set(char *line);
extern void aug_dab_load(char *file);

#endif /* AUG_DEBUG_H */


syntax highlighted by Code2HTML, v. 0.9.1