mirror of
https://github.com/reactos/reactos.git
synced 2025-01-17 19:58:27 +00:00
54 lines
1.2 KiB
C
54 lines
1.2 KiB
C
|
/////////////////////////////////////////////////////////////////////////////
|
||
|
// Diagnostic Trace
|
||
|
//
|
||
|
#include <stdio.h>
|
||
|
#include <stdarg.h>
|
||
|
#define WIN32_LEAN_AND_MEAN
|
||
|
#include <windows.h>
|
||
|
#include <tchar.h>
|
||
|
#include "trace.h"
|
||
|
|
||
|
|
||
|
#ifdef _DEBUG
|
||
|
|
||
|
#undef THIS_FILE
|
||
|
static char THIS_FILE[] = __FILE__;
|
||
|
|
||
|
void _DebugBreak(void)
|
||
|
{
|
||
|
DebugBreak();
|
||
|
}
|
||
|
|
||
|
void Trace(TCHAR* lpszFormat, ...)
|
||
|
{
|
||
|
va_list args;
|
||
|
int nBuf;
|
||
|
TCHAR szBuffer[512];
|
||
|
|
||
|
va_start(args, lpszFormat);
|
||
|
nBuf = _vsntprintf(szBuffer, sizeof(szBuffer)/sizeof(TCHAR), lpszFormat, args);
|
||
|
OutputDebugString(szBuffer);
|
||
|
// was there an error? was the expanded string too long?
|
||
|
//ASSERT(nBuf >= 0);
|
||
|
va_end(args);
|
||
|
}
|
||
|
|
||
|
void Assert(void* assert, TCHAR* file, int line, void* msg)
|
||
|
{
|
||
|
if (msg == NULL) {
|
||
|
printf("ASSERT -- %s occured on line %u of file %s.\n",
|
||
|
assert, line, file);
|
||
|
} else {
|
||
|
printf("ASSERT -- %s occured on line %u of file %s: Message = %s.\n",
|
||
|
assert, line, file, msg);
|
||
|
}
|
||
|
}
|
||
|
|
||
|
#else
|
||
|
|
||
|
void Trace(TCHAR* lpszFormat, ...) { };
|
||
|
void Assert(void* assert, TCHAR* file, int line, void* msg) { };
|
||
|
|
||
|
#endif //_DEBUG
|
||
|
/////////////////////////////////////////////////////////////////////////////
|