mirror of
https://github.com/reactos/reactos.git
synced 2025-01-01 03:54:02 +00:00
83 lines
2.2 KiB
C
83 lines
2.2 KiB
C
|
/////////////////////////////////////////////////////////////////////////////
|
||
|
// Diagnostic Trace
|
||
|
//
|
||
|
#include <stdio.h>
|
||
|
#include <stdarg.h>
|
||
|
#define WIN32_LEAN_AND_MEAN
|
||
|
#include "windows.h"
|
||
|
#include "trace.h"
|
||
|
|
||
|
|
||
|
#ifdef _DEBUG
|
||
|
|
||
|
#ifdef WIN32
|
||
|
//#define WIN32_LEAN_AND_MEAN // Exclude rarely-used stuff from Windows headers
|
||
|
//#include <windows.h>
|
||
|
//#include <assert.h>
|
||
|
//WINBASEAPI VOID WINAPI DebugBreak(VOID);
|
||
|
//WINBASEAPI VOID WINAPI OutputDebugStringA(LPCSTR lpOutputString);
|
||
|
//WINBASEAPI VOID WINAPI OutputDebugStringW(LPCWSTR lpOutputString);
|
||
|
//void __stdcall DebugBreak(void);
|
||
|
//void __stdcall OutputDebugStringA(char* lpOutputString);
|
||
|
//void __stdcall OutputDebugStringW(wchar_t* lpOutputString);
|
||
|
#ifdef UNICODE
|
||
|
#define OutputDebugString OutputDebugStringW
|
||
|
#else
|
||
|
#define OutputDebugString OutputDebugStringA
|
||
|
#endif // !UNICODE
|
||
|
|
||
|
#else
|
||
|
#include "hardware.h"
|
||
|
#endif // WIN32
|
||
|
|
||
|
|
||
|
#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 = vsprintf(szBuffer, lpszFormat, args);
|
||
|
// nBuf = _vsntprintf(szBuffer, _countof(szBuffer), lpszFormat, args);
|
||
|
#ifdef _UNICODE
|
||
|
nBuf = _vsnwprintf(szBuffer, sizeof(szBuffer)/sizeof(TCHAR), lpszFormat, args);
|
||
|
#else
|
||
|
nBuf = _vsnprintf(szBuffer, sizeof(szBuffer)/sizeof(TCHAR), lpszFormat, args);
|
||
|
#endif
|
||
|
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
|
||
|
|
||
|
//inline void Trace(TCHAR* lpszFormat, ...) { };
|
||
|
//inline void Assert(void* assert, TCHAR* file, int line, void* msg) { };
|
||
|
void Trace(TCHAR* lpszFormat, ...) { };
|
||
|
void Assert(void* assert, TCHAR* file, int line, void* msg) { };
|
||
|
|
||
|
#endif //_DEBUG
|
||
|
/////////////////////////////////////////////////////////////////////////////
|