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.
279 lines
10 KiB
279 lines
10 KiB
//////////////////////////////////////////////////////////////////
|
|
// File : cpaddbg.h
|
|
// Purpose : MACRO definition for showing debug message
|
|
//
|
|
//
|
|
// Copyright(c) 1991-1997, Microsoft Corp. All rights reserved
|
|
//
|
|
//////////////////////////////////////////////////////////////////
|
|
#ifndef __C_PAD_DBG_H_
|
|
#define __C_PAD_DBG_H_
|
|
|
|
#include "strsafe.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 _padDbgEnableOutput (BOOL fEnable);
|
|
extern BOOL _padDbgIsOutputEnable (VOID);
|
|
extern VOID _padDbgSetCallback (LPFNDBGCALLBACKA lpfnCBA, LPFNDBGCALLBACKW lpfnCBW);
|
|
extern VOID _padDbgA (LPSTR lpstrFile, INT lineNo, LPSTR lpstrMsg);
|
|
extern VOID _padDbgW (LPWSTR lpstrFile, INT lineNo, LPWSTR lpstrMsg);
|
|
extern VOID _padDbgMsgBoxA (LPSTR lpstrFile, INT lineNo, LPSTR lpstrMsg);
|
|
extern VOID _padDbgAssert (LPSTR lpstrFile, INT lineNo, BOOL fError, LPSTR lpstrMsg);
|
|
extern VOID _padDbgPrintfA (LPSTR lpstrFmt, ...);
|
|
extern VOID _padDbgPrintfW (LPWSTR lpstrFmt, ...);
|
|
extern VOID _padDbgOutStrA (LPSTR lpstr);
|
|
extern VOID _padDbgOutStrW (LPWSTR lpwstr);
|
|
extern LPSTR _padDbgVaStrA (LPSTR lpstrFmt, ...);
|
|
extern LPWSTR _padDbgVaStrW (LPWSTR lpstrFmt, ...);
|
|
extern LPWSTR _padDbgMulti2Wide (LPSTR lpstr);
|
|
extern LPSTR _padDbgGetWinClass (HWND hwnd);
|
|
extern LPSTR _padDbgGetWinText (HWND hwnd);
|
|
extern LPSTR _padDbgGetErrorString (INT errorCode);
|
|
extern LPSTR _padDbgGetVkStr (INT virtKey);
|
|
extern INT _padDbgShowError (HRESULT hr, LPSTR lpstrFunc);
|
|
//----------------------------------------------------------------
|
|
// Macro definition
|
|
//----------------------------------------------------------------
|
|
# define DBGSetCallback(a,b) _padDbgSetCallback(a, b)
|
|
# define DBGEnableOutput(a) _padDbgEnableOutput(a)
|
|
# define DBGIsOutputEnable() _padDbgIsOutputEnable()
|
|
# undef DBG
|
|
# define DBG(a) _padDbgA(__FILE__, __LINE__, _padDbgVaStrA a)
|
|
# define DBGA(a) _padDbgA(__FILE__, __LINE__, _padDbgVaStrA a)
|
|
# define DBGW(a) _padDbgW( _padDbgMulti2Wide(__FILE__), __LINE__, _padDbgVaStrW a)
|
|
# define DBGMsgBox(a) _padDbgMsgBoxA(__FILE__, __LINE__, _padDbgVaStrA a)
|
|
# define DBGAssert(a) _padDbgAssert(__FILE__, __LINE__, a, #a)
|
|
# define DBGAssertSz(a,b) _padDbgAssert(__FILE__, __LINE__, a, b)
|
|
# define DBGOutStr(a) _padDbgOutStrA(a)
|
|
# define DBGOutStrA(a) _padDbgOutStrA(a)
|
|
# define DBGOutStrW(a) _padDbgOutStrW(a)
|
|
# define DBGP(a) _padDbgOutStrA(_padDbgVaStrA a)
|
|
# define DBGPA(a) _padDbgOutStrA(_padDbgVaStrA a)
|
|
# define DBGPW(a) _padDbgOutStrW(_padDbgVaStrW a)
|
|
# define DBGGetErrorString(a) _padDbgGetErrorString(a)
|
|
# define DBGGetWinClass(a) _padDbgGetWinClass(a)
|
|
# define DBGGetWinText(a) _padDbgGetWinText(a)
|
|
# define DBGShowError(a,b) _padDbgShowError(a,b)
|
|
#else //!_DEBUG //in Release version, these will disapear...
|
|
# define DBGSetCallback(a,b)
|
|
# define DBGEnableOutput(a)
|
|
# define DBGIsOutputEnable()
|
|
# undef DBG
|
|
# 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 DBGShowError(a,b)
|
|
#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 _padDbgPrintfA
|
|
#define DBGPrintfA _padDbgPrintfA
|
|
#define DBGPrintfW _padDbgPrintfW
|
|
#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 <stdarg.h>
|
|
//////////////////////////////////////////////////////////////////
|
|
// 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);
|
|
StringCbVPrintfA(szBuf, sizeof(szBuf), lpstrFmt, ap);
|
|
va_end(ap);
|
|
OutputDebugStringA(szBuf);
|
|
return;
|
|
}
|
|
#else //FORCE_DEBUG
|
|
InlineFunc VOID FDbg(LPSTR lpstrFmt, ...) {lpstrFmt;}
|
|
#endif
|
|
|
|
#endif //_C_PAD_DBG_H_
|