| // Copyright 2016 The SwiftShader Authors. All Rights Reserved. | 
 | // | 
 | // Licensed under the Apache License, Version 2.0 (the "License"); | 
 | // you may not use this file except in compliance with the License. | 
 | // You may obtain a copy of the License at | 
 | // | 
 | //    http://www.apache.org/licenses/LICENSE-2.0 | 
 | // | 
 | // Unless required by applicable law or agreed to in writing, software | 
 | // distributed under the License is distributed on an "AS IS" BASIS, | 
 | // WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. | 
 | // See the License for the specific language governing permissions and | 
 | // limitations under the License. | 
 |  | 
 | #ifndef Debug_hpp | 
 | #define Debug_hpp | 
 |  | 
 | #ifndef WIN32_LEAN_AND_MEAN | 
 | 	#define WIN32_LEAN_AND_MEAN | 
 | #endif | 
 | #include <windows.h> | 
 | #include <d3d8.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 |