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.
295 lines
6.5 KiB
295 lines
6.5 KiB
/*++
|
|
|
|
Copyright (C) 1996-1999 Microsoft Corporation
|
|
|
|
Module Name:
|
|
|
|
LTDEBUG.H
|
|
|
|
History:
|
|
|
|
--*/
|
|
|
|
|
|
//
|
|
// Debugging facilities for Espresso 2.x. Included are augmented TRACE
|
|
// and ASSERT facilities.
|
|
//
|
|
|
|
#ifndef MITUTIL_LtDebug_h_INCLUDED
|
|
#define MITUTIL_LtDebug_h_INCLUDED
|
|
|
|
#pragma once
|
|
|
|
|
|
#if defined(_DEBUG)
|
|
#define LTTRACE_ACTIVE
|
|
#define LTASSERT_ACTIVE
|
|
|
|
#define new DEBUG_NEW
|
|
#define LTGetAllocNumber() LTGetAllocNumberImpl()
|
|
|
|
//
|
|
// Executes code only in a DEBUG build.
|
|
//
|
|
#define DEBUGONLY(x) x
|
|
|
|
#define LTDebugBreak() LTBreak()
|
|
|
|
#else // _DEBUG
|
|
|
|
#define DEBUGONLY(x)
|
|
|
|
#define LTDebugBreak() (void) 0
|
|
#define LTGetAllocNumber() 0
|
|
|
|
#endif // _DEBUG
|
|
|
|
#if defined(LTASSERT_ACTIVE) || defined (ASSERT_ALWAYS)
|
|
#ifdef ASSERT
|
|
#undef ASSERT
|
|
#endif
|
|
#ifdef VERIFY
|
|
#undef VERIFY
|
|
#endif
|
|
#define ASSERT LTASSERT
|
|
#define VERIFY LTVERIFY
|
|
|
|
#ifndef _DEBUG
|
|
#pragma message("Warning: LTASSERT Active in non-debug build")
|
|
#endif
|
|
//
|
|
// The multilevel assert macros ensure that the line numbers get expanded to
|
|
// something like "115" instead of "line" or "__LINE__"
|
|
//
|
|
// This will evaluate the expression only once, UNLESS to ask it to 'Retry'.
|
|
// Then it will re-evaluate the expression after the return from the debugger.
|
|
//
|
|
#define LTASSERTONLY(x) x
|
|
|
|
#define LTASSERT(x) LTASSERT2(x, TEXT(__FILE__), __LINE__)
|
|
|
|
#define LTASSERT2(exp, file, line) \
|
|
while (!(exp) && LTFailedAssert(TEXT(#exp), file, line)) (void) 0
|
|
|
|
#define LTVERIFY(x) LTASSERT(x)
|
|
|
|
#else // defined(_DEBUG) || defined(ASSERT_ALWAYS)
|
|
|
|
#define LTASSERTONLY(x)
|
|
#define LTASSERT(x) (void) 0
|
|
#define LTVERIFY(x) x
|
|
|
|
#endif // defined(_DEBUG) || defined(ASSERT_ALWAYS)
|
|
|
|
|
|
#ifndef MIT_NO_DEBUG
|
|
//
|
|
// Name of the project
|
|
//
|
|
#ifndef LTTRACEPROJECT
|
|
#define LTTRACEPROJECT "Borg"
|
|
#endif
|
|
|
|
//
|
|
// Default value for the exe name if one was not supplied.
|
|
//
|
|
#ifndef LTTRACEEXE
|
|
#define LTTRACEEXE MSLOC
|
|
#endif
|
|
|
|
//
|
|
// Used to put quotes around the LTTRACEEXE macro.
|
|
//
|
|
#define __stringify2(x) #x
|
|
#define __stringify(x) __stringify2(x)
|
|
|
|
//
|
|
// TODO - find a better place for this
|
|
|
|
LTAPIENTRY void CopyToClipboard(const char *szMessage);
|
|
|
|
|
|
|
|
struct LTModuleInfo
|
|
{
|
|
UINT uiPreferredLoadAddress;
|
|
UINT uiActualLoadAddress;
|
|
UINT uiModuleSize;
|
|
char szName[MAX_PATH];
|
|
};
|
|
|
|
LTAPIENTRY void LTInitDebug(void);
|
|
|
|
LTAPIENTRY void LTInstallIMallocTracking();
|
|
LTAPIENTRY void LTDumpIMallocs(void);
|
|
LTAPIENTRY void LTTrackIMalloc(BOOL f);
|
|
LTAPIENTRY void LTRevokeIMallocTracking();
|
|
|
|
LTAPIENTRY void LTShutdownDebug(void);
|
|
|
|
LTAPIENTRY BOOL LTSetAssertSilent(BOOL);
|
|
LTAPIENTRY BOOL LTFailedAssert(const TCHAR *, const TCHAR *, int);
|
|
LTAPIENTRY void LTBreak(void);
|
|
|
|
LTAPIENTRY LONG LTGetAllocNumberImpl(void);
|
|
LTAPIENTRY void LTBreakOnAlloc(const char *szFilename, int nLineNum, long nAllocNum);
|
|
|
|
LTAPIENTRY BOOL LTCheckBaseAddress(HMODULE);
|
|
LTAPIENTRY BOOL LTCheckAllBaseAddresses(void);
|
|
LTAPIENTRY void LTCheckPagesFor(HINSTANCE);
|
|
LTAPIENTRY void LTCheckPagesForAll(void);
|
|
|
|
LTAPIENTRY void LTDumpAllModules(void);
|
|
LTAPIENTRY BOOL LTLocateModule(DWORD dwAddress, HMODULE *pInstance);
|
|
LTAPIENTRY BOOL LTGetModuleInfo(HMODULE, LTModuleInfo *);
|
|
|
|
LTAPIENTRY UINT LTGenStackTrace(TCHAR *szBuffer, UINT nBuffSize,
|
|
UINT nSkip, UINT nTotal);
|
|
|
|
LTAPIENTRY void LTSetBoringModules(const char *aszBoring[]);
|
|
LTAPIENTRY void LTTrackAllocations(BOOL);
|
|
LTAPIENTRY void LTDumpAllocations(void);
|
|
|
|
LTAPIENTRY BOOL LTCheckResourceRange(HINSTANCE, WORD UniqueStart, WORD UniqueEnd,
|
|
WORD SharedStart, WORD SharedEnd);
|
|
LTAPIENTRY BOOL LTCheckAllResRanges(WORD, WORD);
|
|
|
|
#pragma warning(disable:4275)
|
|
|
|
class LTAPIENTRY CAssertFailedException : public CException
|
|
{
|
|
public:
|
|
CAssertFailedException(const TCHAR *);
|
|
CAssertFailedException(const TCHAR *, BOOL);
|
|
|
|
BOOL GetErrorMessage(LPTSTR lpszError, UINT nMaxError,
|
|
PUINT pnHelpContext = NULL);
|
|
|
|
~CAssertFailedException();
|
|
|
|
private:
|
|
CAssertFailedException();
|
|
CAssertFailedException(const CAssertFailedException &);
|
|
|
|
TCHAR *m_pszAssert;
|
|
};
|
|
|
|
|
|
|
|
class LTAPIENTRY LTTracePoint
|
|
{
|
|
public:
|
|
LTTracePoint(const TCHAR *);
|
|
|
|
~LTTracePoint();
|
|
|
|
private:
|
|
LTTracePoint();
|
|
|
|
const TCHAR *m_psz;
|
|
};
|
|
|
|
|
|
|
|
#pragma warning(default:4275)
|
|
|
|
//
|
|
// Comment this out to remove ASSERTs from retail builds
|
|
// #define LTASSERT_ACTIVE
|
|
|
|
|
|
#if defined(LTTRACE_ACTIVE)
|
|
|
|
|
|
static const TCHAR *szLTTRACEEXE = TEXT(__stringify(LTTRACEEXE));
|
|
|
|
//
|
|
// The following let us control the output dynamically. We use a function
|
|
// pointer to route our debug output, and change the function pointer to
|
|
// enable/disable tracing.
|
|
//
|
|
static void LTTRACEINIT(const TCHAR *, ...);
|
|
static void (*LTTRACE)(const TCHAR *, ...) = LTTRACEINIT;
|
|
|
|
void LTAPIENTRY LTTRACEOUT(const TCHAR *szFormat, va_list args);
|
|
void LTAPIENTRY LTTRACEON(const TCHAR *szFormat, ...);
|
|
void LTAPIENTRY LTTRACEOFF(const TCHAR *szFormat, ...);
|
|
|
|
|
|
//+++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++
|
|
//
|
|
// LTTRACE is initialized to point to this function. When first called, it
|
|
// determines if tracing should be enabled, then routes LTTRACE through the
|
|
// right handler.
|
|
//
|
|
//-----------------------------------------------------------------------------
|
|
static
|
|
void
|
|
LTTRACEINIT(
|
|
const TCHAR *szFormat, // printf style formatting string
|
|
...) // Variable argument list to format
|
|
{
|
|
BOOL fDoTrace = 1;
|
|
va_list args;
|
|
const TCHAR * const szTraceProfile = TEXT("lttrace.ini");
|
|
|
|
fDoTrace = GetPrivateProfileInt(
|
|
TEXT("ProjectTracing"),
|
|
TEXT("Default"),
|
|
fDoTrace,
|
|
szTraceProfile);
|
|
|
|
fDoTrace = GetPrivateProfileInt(
|
|
TEXT("ProjectTracing"),
|
|
TEXT(LTTRACEPROJECT),
|
|
fDoTrace,
|
|
szTraceProfile);
|
|
|
|
if (fDoTrace)
|
|
{
|
|
fDoTrace = GetPrivateProfileInt(
|
|
TEXT("ExecutableTracing"),
|
|
szLTTRACEEXE,
|
|
fDoTrace,
|
|
szTraceProfile);
|
|
}
|
|
|
|
if (fDoTrace)
|
|
{
|
|
LTTRACE = LTTRACEON;
|
|
|
|
va_start(args, szFormat);
|
|
|
|
LTTRACEOUT(szFormat, args);
|
|
}
|
|
else
|
|
{
|
|
LTTRACE = LTTRACEOFF;
|
|
}
|
|
}
|
|
|
|
|
|
#define LTTRACEPOINT(sz) LTTracePoint lttp##__LINE__(TEXT(sz))
|
|
|
|
#else // defined(LTTRACE_ACTIVE)
|
|
|
|
//
|
|
// Retail version of the debugging macros. Everything
|
|
// just 'goes away'. We use (void) 0 so that these things
|
|
// are statements in both the debug and retail builds.
|
|
//
|
|
|
|
static inline void LTNOTRACE(const TCHAR *, ...)
|
|
{}
|
|
|
|
#define LTTRACE 1 ? (void) 0 : (void) LTNOTRACE
|
|
#define LTTRACEPOINT(x) (void) 0
|
|
|
|
#endif // defined(LTTRACE_ACTIVE)
|
|
|
|
|
|
#endif // MIT_NO_DEBUG
|
|
|
|
|
|
#endif // #ifndef MITUTIL_LtDebug_h_INCLUDED
|