Source code of Windows XP (NT5)
You can not select more than 25 topics
Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
|
|
/*****************************************************************************\
* MODULE: debug.h * * Header file for (debug.cxx). * * Double braces are needed for output macros. * * DBGMSG(DBG_LEV_ERROR, ("Error code %d", Error)); * * This is because we can't use variable parameter lists in macros. * The statement gets pre-processed to a semi-colon in non-debug mode. * * Set the global variable GLOBAL_DEBUG_FLAGS via the debugger. * Setting the flag in the low word causes that level to be printed; * setting the high word causes a break into the debugger. * E.g. setting it to 0x00040006 will print out all warning and error * messages, and break on errors. * * * Copyright (C) 1996-1998 Microsoft Corporation. * Copyright (C) 1996-1998 Hewlett Packard Company. * * History: * 07-Oct-1996 HWP-Guys Initiated port from win95 to winNT * \*****************************************************************************/
#ifdef DEBUG
extern DWORD gdwDbgLevel;
// Maximum size of debug string
//
#define DBG_MAX_TEXT 256
// Debug output levels. By masking in the various levels, you can receive
// all levels of output.
//
#define DBG_LEV_INFO 0x00000001
#define DBG_LEV_CALLTREE 0x00000002
#define DBG_LEV_WARN 0x00000004
#define DBG_LEV_ERROR 0x00000008
#define DBG_LEV_FATAL 0x00000010
#define DBG_LEV_ALL 0x0000001F
// Function prototype for debug-routine (debug.c)
//
VOID CDECL DbgMsgOut( LPCTSTR lpszMsgFormat, ...);
// Handy macros for use throughout the source.
//
#define DBG_BREAKPOINT() DebugBreak();
#define DBG_MSG(Lev, MsgArgs) {if (Lev & gdwDbgLevel) {DbgMsgOut MsgArgs;}}
#define DBG_ASSERT(Expr, MsgArgs) {if (!Expr) {DbgMsgOut MsgArgs; DebugBreak();}}
#else
#define DBG_BREAKPOINT()
#define DBG_MSG(Lev, MsgArgs)
#define DBG_ASSERT(Expr, MsgArgs)
#endif
|