12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455565758596061626364656667686970717273 |
- /*********************************************************************
- * Copyright 1993, UCAR/Unidata
- * See netcdf/COPYRIGHT file for copying and redistribution conditions.
- * $Header: /upc/share/CVS/netcdf-3/libncdap3/dapdebug.h,v 1.33 2009/12/03 18:53:16 dmh Exp $
- *********************************************************************/
- #ifndef DEBUG_H
- #define DEBUG_H
- #include "ocdebug.h"
- #ifdef DAPDEBUG
- # define DEBUG
- # if DAPDEBUG > 0
- # define DEBUG1
- # endif
- # if DAPDEBUG > 1
- # define DEBUG2
- # endif
- # if DAPDEBUG > 2
- # define DEBUG3
- # endif
- #endif
- #undef PARSEDEBUG
- #include <stdarg.h>
- #include <assert.h>
- /* Warning: setting CATCHERROR has significant performance impact */
- #undef CATCHERROR
- #ifdef DEBUG
- #undef CATCHERROR
- #define CATCHERROR
- #endif
- #define PANIC(msg) assert(dappanic(msg));
- #define PANIC1(msg,arg) assert(dappanic(msg,arg));
- #define PANIC2(msg,arg1,arg2) assert(dappanic(msg,arg1,arg2));
- #define ASSERT(expr) if(!(expr)) {PANIC(#expr);} else {}
- extern int ncdap3debug;
- extern int dappanic(const char* fmt, ...);
- #define MEMCHECK(var,throw) {if((var)==NULL) return (throw);}
- #ifdef CATCHERROR
- /* Place breakpoint on dapbreakpoint to catch errors close to where they occur*/
- #define THROW(e) dapthrow(e)
- #define THROWCHK(e) (void)dapthrow(e)
- extern int dapbreakpoint(int err);
- extern int dapthrow(int err);
- #else
- #define THROW(e) (e)
- #define THROWCHK(e)
- #endif
- #ifdef DEBUG
- #define SHOWFETCH (1)
- #define LOG0(level,msg) fprintf(stderr,msg)
- #define LOG1(level,msg,a1) fprintf(stderr,msg,a1)
- #define LOG2(level,msg,a1,a2) fprintf(stderr,msg,a1,a2)
- #else
- #define SHOWFETCH FLAGSET(nccomm->controls,NCF_SHOWFETCH)
- #define LOG0(level,msg) nclog(level,msg)
- #define LOG1(level,msg,a1) nclog(level,msg,a1)
- #define LOG2(level,msg,a1,a2) nclog(level,msg,a1,a2)
- #endif
- #endif /*DEBUG_H*/
|