2020-09-30 16:53:55 +02:00

110 lines
2.8 KiB
C++
Raw Blame History

This file contains invisible Unicode characters

This file contains invisible Unicode characters that are indistinguishable to humans but may be processed differently by a computer. If you think that this is intentional, you can safely ignore this warning. Use the Escape button to reveal them.

#include "precomp.h"
#if defined(_DEBUG) && ! defined(_UNICODE)
#define MULTI_LEVEL_ZONES
#include <mlzdbg.h>
HDBGZONE g_hDbgZones;
void WINAPI MLZ_DbgInit(PSTR *apszZones, UINT cZones)
{
// if registry is empty, set warning flag as default
DbgInitEx(&g_hDbgZones, apszZones, cZones, ZONE_WARNING_FLAG);
// if the warning flag is not set, then set it as default
if (g_hDbgZones != NULL)
{
((PZONEINFO) g_hDbgZones)->ulZoneMask |= ZONE_WARNING_FLAG;
}
}
void WINAPI MLZ_DbgDeInit(void)
{
DbgDeInit(&g_hDbgZones);
}
void WINAPIV MLZ_WarningOut(PSTR pszFormat, ...)
{
if (g_hDbgZones != NULL &&
IS_ZONE_ENABLED(g_hDbgZones, ZONE_WARNING_FLAG))
{
va_list args;
va_start(args, pszFormat);
DbgPrintf(NULL, pszFormat, args);
va_end(args);
}
}
BOOL WINAPI MLZ_TraceZoneEnabled(int iZone)
{
return (g_hDbgZones != NULL &&
IS_ZONE_ENABLED(g_hDbgZones, ZONE_TRACE_FLAG) &&
IS_ZONE_ENABLED(g_hDbgZones, ZONE_FLAG(iZone)));
}
void WINAPIV MLZ_TraceOut(PSTR pszFormat, ...)
{
va_list args;
va_start(args, pszFormat);
DbgPrintf(NULL, pszFormat, args);
va_end(args);
}
void WINAPI MLZ_EntryOut(int iZone, PSTR pszFunName)
{
if (g_hDbgZones != NULL &&
IS_ZONE_ENABLED(g_hDbgZones, ZONE_FUNCTION_FLAG) &&
IS_ZONE_ENABLED(g_hDbgZones, ZONE_FLAG(iZone)))
{
MLZ_TraceOut("%s() entered.", pszFunName);
}
}
void WINAPI MLZ_ExitOut(int iZone, PSTR pszFunName, RCTYPE eRetCodeType, DWORD_PTR dwRetCode)
{
if (g_hDbgZones != NULL &&
IS_ZONE_ENABLED(g_hDbgZones, ZONE_FUNCTION_FLAG) &&
IS_ZONE_ENABLED(g_hDbgZones, ZONE_FLAG(iZone)))
{
PSTR pszRetCode;
char szFormat[64];
lstrcpyA(&szFormat[0], "%s() exiting...");
pszRetCode = &szFormat[0] + lstrlenA(&szFormat[0]);
if (eRetCodeType != RCTYPE_VOID)
{
lstrcpyA(pszRetCode, " rc=");
pszRetCode += lstrlenA(pszRetCode);
switch (eRetCodeType)
{
case RCTYPE_BOOL:
lstrcpyA(pszRetCode, dwRetCode ? "TRUE" : "FALSE");
break;
case RCTYPE_DWORD:
case RCTYPE_HRESULT:
wsprintf(pszRetCode, "0x%lx", (DWORD)dwRetCode);
break;
case RCTYPE_INT:
wsprintf(pszRetCode, "%ld", (LONG) dwRetCode);
break;
case RCTYPE_ULONG:
wsprintf(pszRetCode, "%lu", (ULONG) dwRetCode);
break;
case RCTYPE_PTR:
wsprintf(pszRetCode, "%p", (LPVOID) dwRetCode);
break;
default:
ASSERT(0);
break;
}
}
MLZ_TraceOut(&szFormat[0], pszFunName);
}
}
#endif // _DEBUG && ! _UNICODE