// SwiftShader Software Renderer | |
// | |
// Copyright(c) 2005-2011 TransGaming Inc. | |
// | |
// All rights reserved. No part of this software may be copied, distributed, transmitted, | |
// transcribed, stored in a retrieval system, translated into any human or computer | |
// language by any means, or disclosed to third parties without the explicit written | |
// agreement of TransGaming Inc. Without such an agreement, no rights or licenses, express | |
// or implied, including but not limited to any patent rights, are granted to you. | |
// | |
#ifndef Debug_hpp | |
#define Debug_hpp | |
#ifndef WIN32_LEAN_AND_MEAN | |
#define WIN32_LEAN_AND_MEAN | |
#endif | |
#include <windows.h> | |
#include <d3d9.h> | |
#include <stdio.h> | |
#include <guiddef.h> | |
#include <assert.h> | |
#define APPEND(x, y) x ## y | |
#define MACRO_APPEND(x, y) APPEND(x, y) | |
#define UNIQUE_IDENTIFIER(prefix) MACRO_APPEND(prefix, __COUNTER__) | |
struct Trace | |
{ | |
Trace(const char *format, ...) | |
{ | |
if(false) | |
{ | |
FILE *file = fopen("debug.txt", "a"); | |
if(file) | |
{ | |
for(int i = 0; i < indent; i++) fprintf(file, " "); | |
va_list vararg; | |
va_start(vararg, format); | |
vfprintf(file, format, vararg); | |
va_end(vararg); | |
fclose(file); | |
} | |
} | |
indent++; | |
} | |
~Trace() | |
{ | |
indent--; | |
} | |
static int indent; | |
}; | |
#ifndef NDEBUG | |
#define TRACE(format, ...) Trace UNIQUE_IDENTIFIER(_tracer_)("[0x%0.8X]%s("format")\n", this, __FUNCTION__, __VA_ARGS__) | |
#define GTRACE(format, ...) Trace("%s("format")\n", __FUNCTION__, __VA_ARGS__) | |
#else | |
#define TRACE(...) ((void)0) | |
#define GTRACE(...) ((void)0) | |
#endif | |
#ifndef NDEBUG | |
#define ASSERT(expression) {if(!(expression)) Trace("\t! Assert failed in %s(%d): "#expression"\n", __FUNCTION__, __LINE__); assert(expression);} | |
#else | |
#define ASSERT assert | |
#endif | |
#ifndef NDEBUG | |
#define UNIMPLEMENTED() {Trace("\t! Unimplemented: %s(%d)\n", __FUNCTION__, __LINE__); ASSERT(false);} | |
#else | |
#define UNIMPLEMENTED() ((void)0) | |
#endif | |
#ifndef NDEBUG | |
#define NOINTERFACE(iid) _NOINTERFACE(__FUNCTION__, iid) | |
inline long _NOINTERFACE(const char *function, const IID &iid) | |
{ | |
Trace("\t! No interface {0x%0.8X, 0x%0.4X, 0x%0.4X, 0x%0.2X, 0x%0.2X, 0x%0.2X, 0x%0.2X, 0x%0.2X, 0x%0.2X, 0x%0.2X, 0x%0.2X} for %s\n", iid.Data1, iid.Data2, iid.Data3, iid.Data4[0], iid.Data4[1], iid.Data4[2], iid.Data4[3], iid.Data4[4], iid.Data4[5], iid.Data4[6], iid.Data4[7], function); | |
return E_NOINTERFACE; | |
} | |
#else | |
#define NOINTERFACE(iid) E_NOINTERFACE | |
#endif | |
#ifndef NDEBUG | |
inline long INVALIDCALL() | |
{ | |
Trace("\t! D3DERR_INVALIDCALL\n"); | |
return D3DERR_INVALIDCALL; | |
} | |
#else | |
#define INVALIDCALL() D3DERR_INVALIDCALL | |
#endif | |
#ifndef NDEBUG | |
inline long OUTOFMEMORY() | |
{ | |
Trace("\t! E_OUTOFMEMORY\n"); | |
return E_OUTOFMEMORY; | |
} | |
#else | |
#define OUTOFMEMORY() E_OUTOFMEMORY | |
#endif | |
#ifndef NDEBUG | |
inline long OUTOFVIDEOMEMORY() | |
{ | |
Trace("\t! D3DERR_OUTOFVIDEOMEMORY\n"); | |
return D3DERR_OUTOFVIDEOMEMORY; | |
} | |
#else | |
#define OUTOFVIDEOMEMORY() D3DERR_OUTOFVIDEOMEMORY | |
#endif | |
#ifndef NDEBUG | |
inline long NOTAVAILABLE() | |
{ | |
Trace("\t! D3DERR_NOTAVAILABLE\n"); | |
return D3DERR_NOTAVAILABLE; | |
} | |
#else | |
#define NOTAVAILABLE() D3DERR_NOTAVAILABLE | |
#endif | |
#ifndef NDEBUG | |
inline long NOTFOUND() | |
{ | |
Trace("\t! D3DERR_NOTFOUND\n"); | |
return D3DERR_NOTFOUND; | |
} | |
#else | |
#define NOTFOUND() D3DERR_NOTFOUND | |
#endif | |
#ifndef NDEBUG | |
inline long MOREDATA() | |
{ | |
Trace("\t! D3DERR_MOREDATA\n"); | |
return D3DERR_MOREDATA; | |
} | |
#else | |
#define MOREDATA() D3DERR_MOREDATA | |
#endif | |
#ifndef NDEBUG | |
inline long FAIL() | |
{ | |
Trace("\t! E_FAIL\n"); | |
return E_FAIL; | |
} | |
#else | |
#define FAIL() E_FAIL | |
#endif | |
#endif // Debug_hpp |