// 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 #include #include #include #include #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