////////////////////////////////////////////////////////////////// // File : dbg.h // Purpose : MACRO definition for showing debug message // // // Copyright(c) 1991-1997, Microsoft Corp. All rights reserved // ////////////////////////////////////////////////////////////////// #ifndef _DBG_H_ #define _DBG_H_ #ifdef __cplusplus # define InlineFunc inline #else # define InlineFunc __inline #endif //---------------------------------------------------------------- // Callback function prototype //---------------------------------------------------------------- typedef VOID (WINAPI *LPFNDBGCALLBACKA)(LPSTR lpstr); typedef VOID (WINAPI *LPFNDBGCALLBACKW)(LPWSTR lpwstr); //------------------------------------------------------- //MACRO function prototype declare. //It is valid only if compliled with _DEBUG definition. //------------------------------------------------------- ////////////////////////////////////////////////////////////////// // Function : DBGSetCallback // Type : VOID // Purpose : Set debug callback function. // callback function has set, when DBG() has called, // call this callback function with formatted message string. // Args : // : LPFNDBGCALLBACKA lpfnDbgCallbackA // : LPFNDBGCALLBACKW lpfnDbgCallbackW // Return : VOID // DATE : Tue Jan 06 12:21:05 1998 ////////////////////////////////////////////////////////////////// //VOID DBGSetCallback(LPFNDBGCALLBACKA lpfnDbgCallbackA, LPFNDBGCALLBACKW lpfnDbgCallbackW); ////////////////////////////////////////////////////////////////// // Function : DBGEnableOutput // Type : VOID // Purpose : On off OutputDebugString to COM. // Args : // : BOOL fOn // Return : // DATE : Fri Apr 03 17:33:21 1998 // Author : ////////////////////////////////////////////////////////////////// //VOID DBGEnableOutput(BOOL fEnable) ////////////////////////////////////////////////////////////////// // Function : DBGIsOutputEnable // Type : BOOL // Purpose : // Args : None // Return : // DATE : Fri Apr 03 17:58:28 1998 // Author : ////////////////////////////////////////////////////////////////// //BOOL DBGIsOutputEnable(VOID) //////////////////////////////////////////////////////// // Function : DBG // Type : VOID // Purpose : Printing ANSI debug message with same usage as printf() // Args : // : LPSTR lpstrFuncName // : ... // Example : DBGW(("Error occured data[%d]", i)); // CAUTION : Must use DOUBLE Blaket to remove in Release version!!! ///////////////////////////////////////////////////////// //VOID DBG((LPSTR lpstrFuncName, ...)); //////////////////////////////////////////////////////// // Function: DBGW // Type : VOID // Purpose : Printing Unicode debug message with same usage as printf() // Args : // : LPWSTR lpstrFuncName // : ... // CAUTION : Shold use DOUBLE Blaket!!! // Example : DBGW(("Error occured data[%d]", i)); ///////////////////////////////////////////////////////// //VOID DBGW((LPWSTR lpstrFuncName, ...)); ////////////////////////////////////////////////////////////////// // Function : DBGMsgBox // Type : VOID // Purpose : // Args : // : LPSTR lpstrFmt // : ... // CAUTION : Shold use DOUBLE Blaket!!! // Example : DBGMsgBox(("Error occured data[%d]", i)); ////////////////////////////////////////////////////////////////// //VOID DBGMsgBox((LPSTR lpstrFmt, ...)) ////////////////////////////////////////////////////////////////// // Function : DBGAssert // Type : VOID // Purpose : // Args : // : BOOL fError // Return : // DATE : Fri Jan 09 17:17:31 1998 ////////////////////////////////////////////////////////////////// //VOID DBGAssert(BOOL fError) ////////////////////////////////////////////////////////////////// // Function : DBGSTR // Type : VOID // Purpose : // Args : // : LPSTR lpstr ////////////////////////////////////////////////////////////////// //VOID DBGSTR(LPSTR lpstr); ////////////////////////////////////////////////////////////////// // Function : DBGGetErrorString // Type : VOID // Purpose : Get error message from WIN32 Error code. // Args : // : INT errorCode ////////////////////////////////////////////////////////////////// //LPSTR DBGGetErrorString(INT errorCode) ////////////////////////////////////////////////////////////////// // Function : DBGGetWinClass // Type : LPSTR // Purpose : Get class name string from specified window. // Args : // : HWND hwnd ////////////////////////////////////////////////////////////////// //LPSTR DBGGetWinClass(HWND hwnd) ////////////////////////////////////////////////////////////////// // Function : DBGGetWinText // Type : LPSTR // Purpose : Get title text string from specified window. // Args : // : HWND hwnd ////////////////////////////////////////////////////////////////// //LPSTR DBGGetWinText(HWND hwnd) #ifdef _DEBUG //---------------------------------------------------------------- //Function prototype declare //---------------------------------------------------------------- extern VOID _ddbtnDbgEnableOutput (BOOL fEnable); extern BOOL _ddbtnDbgIsOutputEnable (VOID); extern VOID _ddbtnDbgSetCallback (LPFNDBGCALLBACKA lpfnCBA, LPFNDBGCALLBACKW lpfnCBW); extern VOID _ddbtnDbgA (LPSTR lpstrFile, INT lineNo, LPSTR lpstrMsg); extern VOID _ddbtnDbgW (LPWSTR lpstrFile, INT lineNo, LPWSTR lpstrMsg); extern VOID _ddbtnDbgMsgBoxA (LPSTR lpstrFile, INT lineNo, LPSTR lpstrMsg); extern VOID _ddbtnDbgAssert (LPSTR lpstrFile, INT lineNo, BOOL fError, LPSTR lpstrMsg); extern VOID _ddbtnDbgPrintfA (LPSTR lpstrFmt, ...); extern VOID _ddbtnDbgPrintfW (LPWSTR lpstrFmt, ...); extern VOID _ddbtnDbgOutStrA (LPSTR lpstr); extern VOID _ddbtnDbgOutStrW (LPWSTR lpwstr); extern LPSTR _ddbtnDbgVaStrA (LPSTR lpstrFmt, ...); extern LPWSTR _ddbtnDbgVaStrW (LPWSTR lpstrFmt, ...); extern LPWSTR _ddbtnDbgMulti2Wide (LPSTR lpstr); extern LPSTR _ddbtnDbgGetWinClass (HWND hwnd); extern LPSTR _ddbtnDbgGetWinText (HWND hwnd); extern LPSTR _ddbtnDbgGetErrorString (INT errorCode); extern LPSTR _ddbtnDbgGetVkStr (INT virtKey); //---------------------------------------------------------------- // Macro definition //---------------------------------------------------------------- # define DBGSetCallback(a,b) _ddbtnDbgSetCallback(a, b) # define DBGEnableOutput(a) _ddbtnDbgEnableOutput(a) # define DBGIsOutputEnable() _ddbtnDbgIsOutputEnable() # define Dbg(a) _ddbtnDbgA(__FILE__, __LINE__, _ddbtnDbgVaStrA a) # define DBGA(a) _ddbtnDbgA(__FILE__, __LINE__, _ddbtnDbgVaStrA a) # define DBGW(a) _ddbtnDbgW( _ddbtnDbgMulti2Wide(__FILE__), __LINE__, _ddbtnDbgVaStrW a) # define DBGMsgBox(a) _ddbtnDbgMsgBoxA(__FILE__, __LINE__, _ddbtnDbgVaStrA a) # define DBGAssert(a) _ddbtnDbgAssert(__FILE__, __LINE__, a, #a) # define DBGAssertSz(a,b) _ddbtnDbgAssert(__FILE__, __LINE__, a, b) # define DBGOutStr(a) _ddbtnDbgOutStrA(a) # define DBGOutStrA(a) _ddbtnDbgOutStrA(a) # define DBGOutStrW(a) _ddbtnDbgOutStrW(a) # define DBGP(a) _ddbtnDbgOutStrA(_ddbtnDbgVaStrA a) # define DBGPA(a) _ddbtnDbgOutStrA(_ddbtnDbgVaStrA a) # define DBGPW(a) _ddbtnDbgOutStrW(_ddbtnDbgVaStrW a) # define DBGGetErrorString(a) _ddbtnDbgGetErrorString(a) # define DBGGetWinClass(a) _ddbtnDbgGetWinClass(a) # define DBGGetWinText(a) _ddbtnDbgGetWinText(a) # define DBGGetVirtKeyStr(a) _ddbtnDbgGetVkStr(a) #else //!_DEBUG //in Release version, these will disapear... # define DBGSetCallback(a,b) # define DBGEnableOutput(a) # define DBGIsOutputEnable() # define Dbg(a) # define DBGW(a) # define DBGA(a) # define DBGP(a) # define DBGPA(a) # define DBGPW(a) # define DBGAssert(a) # define DBGAssertSz(a,b) # define DBGMsgBox(a) # define DBGOutStr(a) # define DBGOutStrA(a) # define DBGOutStrW(a) # define DBGGetErrorString(a) # define DBGGetWinClass(a) # define DBGGetWinText(a) # define DBGGetVirtKeyStr(a) #endif //_DEBUG //---------------------------------------------------------------- //These function use variable argument, so we cannot define //"Normal" MACRO for them. //so, Use inline function that do nothing if _DEBUG is NOT set. //---------------------------------------------------------------- InlineFunc VOID DBGDoNothingA(LPSTR lpstrFmt, ...) {lpstrFmt;} InlineFunc VOID DBGDoNothingW(LPWSTR lpstrFmt, ...) {lpstrFmt;} #ifdef _DEBUG #define DBGPrintf _ddbtnDbgPrintfA #define DBGPrintfA _ddbtnDbgPrintfA #define DBGPrintfW _ddbtnDbgPrintfW #else #define DBGPrintf DBGDoNothingA #define DBGPrintfA DBGDoNothingA #define DBGPrintfW DBGDoNothingW #endif //---------------------------------------------------------------- //This is helper inline function for outputs debug string in //Retail version. if FORCE_DEBUG is defined this function works. //Some time, we met bugs than occurs only retail version, //and would like to out debug message. //---------------------------------------------------------------- #ifdef FORCE_DEBUG #include ////////////////////////////////////////////////////////////////// // Function : FDbg // Type : InlineFunc VOID // Purpose : // Args : // : // : LPSTR lpstrFmt // : ... // Return : // DATE : Tue Jan 06 19:06:19 1998 ////////////////////////////////////////////////////////////////// InlineFunc VOID FDbg(LPSTR lpstrFmt, ...) { CHAR szBuf[512]; va_list ap; va_start(ap, lpstrFmt); wvsprintfA(szBuf, lpstrFmt, ap); va_end(ap); OutputDebugStringA(szBuf); return; } #else //FORCE_DEBUG InlineFunc VOID FDbg(LPSTR lpstrFmt, ...) {lpstrFmt;} #endif #endif //_DBG_H_