153 lines
4.0 KiB
C
Raw Normal View History

2001-01-01 00:00:00 +01:00
//+---------------------------------------------------------------------------
//
// Microsoft Windows
// Copyright (C) Microsoft Corporation, 1996 - 1998.
//
// File: debug.hxx
//
// Contents: Debugging macros
//
// History: 12-04-96 DavidMun Created
//
//----------------------------------------------------------------------------
#ifndef __DEBUG_HXX_
#define __DEBUG_HXX_
#include "stddbg.h"
#undef DEBUG_DECLARE_INSTANCE_COUNTER
#undef DEBUG_INCREMENT_INSTANCE_COUNTER
#undef DEBUG_DECREMENT_INSTANCE_COUNTER
#undef DEBUG_VERIFY_INSTANCE_COUNT
//
//We have DEB_USER1 to DEB_USER10 for custom debugging
//
#define DEB_PERF DEB_USER1 //Timer info will be shown
#define DEB_DLL DEB_USER2 //Use this for all the Sanpin
//Initialization stuff
#define DEB_SNAPIN DEB_USER3 //Used for Snapin About
#if (DBG == 1)
//============================================================================
//
// Debug version
//
//============================================================================
#define DBG_COMP roleInfoLevel
DECLARE_DEBUG(role)
#define DBG_OUT_HRESULT(hr) \
DBG_COMP.DebugErrorX(THIS_FILE, __LINE__, hr)
#define DBG_OUT_LRESULT(lr) \
DBG_COMP.DebugErrorL(THIS_FILE, __LINE__, lr)
void
SayNoItf(
PCSTR szComponent,
REFIID riid);
#define DBG_OUT_NO_INTERFACE(qi, riid) SayNoItf((qi), (riid))
// Instance counter
inline void DbgInstanceRemaining(char * pszClassName, int cInstRem)
{
char buf[100];
//Fine to truncate
if(SUCCEEDED(StringCchPrintfA(buf,sizeof(buf)/sizeof(char), "%s has %d instances left over.", pszClassName, cInstRem)))
{
//lint -save -e64
Dbg(DEB_ERROR, "Memory leak: %hs\n", buf);
//lint -restore
::MessageBoxA(NULL, buf, "OPD: Memory Leak", MB_OK);
}
}
#define DEBUG_DECLARE_INSTANCE_COUNTER(cls) \
int s_cInst_##cls = 0;
#define DEBUG_INCREMENT_INSTANCE_COUNTER(cls) \
extern int s_cInst_##cls; \
InterlockedIncrement((LPLONG) &s_cInst_##cls);
#define DEBUG_DECREMENT_INSTANCE_COUNTER(cls) \
extern int s_cInst_##cls; \
InterlockedDecrement((LPLONG) &s_cInst_##cls);
#define DEBUG_VERIFY_INSTANCE_COUNT(cls) \
extern int s_cInst_##cls; \
\
if (s_cInst_##cls) \
{ \
DbgInstanceRemaining(#cls, s_cInst_##cls); \
}
//+--------------------------------------------------------------------------
//
// Class: CTimer
//
// Purpose: Display on debugger time from ctor invocation to dtor
// invocation.
//
// History: 12-16-1996 DavidMun Created
//
//---------------------------------------------------------------------------
class CTimer
{
public:
CTimer(): m_ulStart(0) { m_wzTitle[0] = L'\0'; };
void __cdecl Init(LPCSTR pszTitleFmt, ...);
~CTimer();
private:
ULONG m_ulStart;
WCHAR m_wzTitle[512];
};
#define TIMER CTimer TempTimer; TempTimer.Init
#define PING(msg) DBG_COMP.PingDc(msg)
#else // !(DBG == 1)
//============================================================================
//
// Retail version
//
//============================================================================
#define DBG_OUT_HRESULT(hr)
#define DBG_OUT_LRESULT(lr)
#define DBG_DUMP_QUERY(title, query)
#define DBG_OUT_NO_INTERFACE(qi, riid)
#define DEBUG_DECLARE_INSTANCE_COUNTER(cls)
#define DEBUG_INCREMENT_INSTANCE_COUNTER(cls)
#define DEBUG_DECREMENT_INSTANCE_COUNTER(cls)
#define DEBUG_VERIFY_INSTANCE_COUNT(cls)
#define TIMER ConsumePrintf
#define PING(msg)
inline void __cdecl ConsumePrintf(void *fmt, ...)
{
}
#endif // !(DBG == 1)
#endif // __DEBUG_HXX_