summaryrefslogtreecommitdiffstats
path: root/rwsdk/include/d3d8/rpdbgerr.h
diff options
context:
space:
mode:
Diffstat (limited to '')
-rw-r--r--rwsdk/include/d3d8/rpdbgerr.h278
1 files changed, 278 insertions, 0 deletions
diff --git a/rwsdk/include/d3d8/rpdbgerr.h b/rwsdk/include/d3d8/rpdbgerr.h
new file mode 100644
index 00000000..6918469a
--- /dev/null
+++ b/rwsdk/include/d3d8/rpdbgerr.h
@@ -0,0 +1,278 @@
+/***************************************************************************
+ * *
+ * Module : badebug.h *
+ * *
+ * Purpose : Debug handling *
+ * *
+ **************************************************************************/
+
+#ifndef RWDEBUG_H
+#define RWDEBUG_H
+
+#if (defined(RWDEBUG) && defined(RWVERBOSE))
+#if (defined(_MSC_VER))
+#if (_MSC_VER>=1000)
+
+/* Pick up _ASSERTE macro */
+#ifdef _XBOX
+#include <xtl.h>
+#else /* _XBOX */
+#include <windows.h>
+#endif /* _XBOX */
+#if (defined(RWMEMDEBUG) && !defined(_CRTDBG_MAP_ALLOC))
+#define _CRTDBG_MAP_ALLOC
+#endif /* defined(RWMEMDEBUG) && !defined(_CRTDBG_MAP_ALLOC)) */
+#include <crtdbg.h>
+#undef RWASSERTE
+#define RWASSERTE(_condition) _ASSERTE(_condition)
+#endif /* (_MSC_VER>=1000) */
+#endif /* (defined(_MSC_VER)) */
+#endif /* (defined(RWDEBUG) && defined(RWVERBOSE)) */
+
+#if (!defined(RWASSERTE))
+#define RWASSERTE(_condition) /* No-Op */
+#endif /* (!defined(RWASSERTE)) */
+
+#if (!defined(RWPENTER))
+#define RWPENTER(_func) /* No-Op */
+#endif /* (!defined(RWPENTER)) */
+
+#if (!defined(RWPEXIT))
+#define RWPEXIT(_func) /* No-Op */
+#endif /* (!defined(RWPEXIT)) */
+
+/****************************************************************************
+ Includes
+ */
+
+#include <rwcore.h>
+
+#include "rpplugin.h"
+
+/****************************************************************************
+ Defines
+ */
+
+#ifdef RWDEBUG
+
+#if (!(defined(RWDEBUGSTACKDEPTH)))
+#define RWDEBUGSTACKDEPTH (RWSRCGLOBAL(debugStackDepth))
+#endif /* (!(defined(RWDEBUGSTACKDEPTH))) */
+
+/* Message macros */
+
+#ifdef RWTRACE
+
+/* Note RWTRACE should only be defined for internal builds. It should
+ * also only be used rarely. It will cause the generation of Trace
+ * messages for all functions. Not just those directly called from
+ * the application
+ */
+
+#define RWAPIFUNCTION(function) \
+static const RwChar __dbFunctionName[] = function; \
+const RwInt32 startstackdepth = RWDEBUGSTACKDEPTH++; \
+RWPENTER(__dbFunctionName); \
+if (RWSRCGLOBAL(debugTrace)) \
+{ \
+ RwDebugSendMessage(rwDEBUGTRACE, \
+ __dbFunctionName, \
+ _rwdbsprintf("Enter %s [Depth %d]", \
+ (startstackdepth)?"SPI":"API", \
+ (int)startstackdepth)); \
+}
+
+#define RWFUNCTION(function) RWAPIFUNCTION(function)
+
+#define RWRETURN(result) \
+do \
+{ \
+ RwInt32 _validateStackDepth = --RWDEBUGSTACKDEPTH; \
+ if (_validateStackDepth != startstackdepth) \
+ { \
+ RwDebugSendMessage(rwDEBUGERROR, \
+ __dbFunctionName, \
+ _rwdberrcommon(E_RW_DEBUGSTACK)); \
+ RWDEBUGSTACKDEPTH = startstackdepth; \
+ } \
+ if (RWSRCGLOBAL(debugTrace)) \
+ { \
+ RwDebugSendMessage(rwDEBUGTRACE, \
+ __dbFunctionName, RWSTRING("Exit")); \
+ } \
+ RWASSERTE(_validateStackDepth == startstackdepth); \
+ RWPEXIT(__dbFunctionName); \
+ return (result); \
+} \
+while (0)
+
+#define RWRETURNVOID() \
+do \
+{ \
+ RwInt32 _validateStackDepth = --RWDEBUGSTACKDEPTH; \
+ if (_validateStackDepth != startstackdepth) \
+ { \
+ RwDebugSendMessage(rwDEBUGERROR, \
+ __dbFunctionName, \
+ _rwdberrcommon (E_RW_DEBUGSTACK)); \
+ RWDEBUGSTACKDEPTH = startstackdepth; \
+ } \
+ if (RWSRCGLOBAL(debugTrace)) \
+ { \
+ RwDebugSendMessage(rwDEBUGTRACE, \
+ __dbFunctionName, RWSTRING("Exit")); \
+ } \
+ RWASSERTE(_validateStackDepth == startstackdepth); \
+ RWPEXIT(__dbFunctionName); \
+ return; \
+} \
+while(0)
+
+#else /* RWTRACE */
+
+#define RWAPIFUNCTION(function) \
+static const RwChar __dbFunctionName[] = function; \
+const RwInt32 startstackdepth = RWDEBUGSTACKDEPTH++; \
+RWPENTER(__dbFunctionName); \
+if (RWSRCGLOBAL(debugTrace) && !startstackdepth) \
+{ \
+ RwDebugSendMessage(rwDEBUGTRACE, \
+ __dbFunctionName, RWSTRING("Enter")); \
+}
+
+#define RWFUNCTION(function) RWAPIFUNCTION(function)
+
+#define RWRETURN(result) \
+do \
+{ \
+ RwInt32 _validateStackDepth = --RWDEBUGSTACKDEPTH; \
+ if (_validateStackDepth != startstackdepth) \
+ { \
+ RwDebugSendMessage(rwDEBUGERROR, \
+ __dbFunctionName, \
+ _rwdberrcommon(E_RW_DEBUGSTACK)); \
+ RWDEBUGSTACKDEPTH = startstackdepth; \
+ } \
+ if (RWSRCGLOBAL(debugTrace) && (!startstackdepth)) \
+ { \
+ RwDebugSendMessage(rwDEBUGTRACE, \
+ __dbFunctionName, RWSTRING("Exit")); \
+ } \
+ RWASSERTE(_validateStackDepth == startstackdepth); \
+ RWPEXIT(__dbFunctionName); \
+ return (result); \
+} \
+while (0)
+
+#define RWRETURNVOID() \
+do \
+{ \
+ RwInt32 _validateStackDepth = --RWDEBUGSTACKDEPTH; \
+ if (_validateStackDepth != startstackdepth) \
+ { \
+ RwDebugSendMessage(rwDEBUGERROR, \
+ __dbFunctionName, \
+ _rwdberrcommon (E_RW_DEBUGSTACK)); \
+ RWDEBUGSTACKDEPTH = startstackdepth; \
+ } \
+ if (RWSRCGLOBAL(debugTrace) && (!startstackdepth)) \
+ { \
+ RwDebugSendMessage(rwDEBUGTRACE, \
+ __dbFunctionName, RWSTRING("Exit")); \
+ } \
+ RWASSERTE(_validateStackDepth == startstackdepth); \
+ RWPEXIT(__dbFunctionName); \
+ return; \
+} \
+while(0)
+
+#endif /* RWTRACE */
+
+#define RWERROR(ecode) \
+do \
+{ \
+ RwError _rwErrorCode; \
+ \
+ _rwErrorCode.pluginID = rwPLUGIN_ID; \
+ _rwErrorCode.errorCode = _rwerror ecode; \
+ \
+ RwErrorSet(&_rwErrorCode); \
+ \
+ if (_rwErrorCode.errorCode & 0x80000000) \
+ { \
+ RwDebugSendMessage(rwDEBUGERROR, \
+ __dbFunctionName, \
+ _rwdberrcommon ecode); \
+ } \
+ else \
+ { \
+ RwDebugSendMessage(rwDEBUGERROR, \
+ __dbFunctionName, \
+ rwPLUGIN_ERRFUNC ecode); \
+ } \
+} \
+while(0);
+
+#define RWMESSAGE(args) \
+do \
+{ \
+ RwDebugSendMessage(rwDEBUGMESSAGE, \
+ __dbFunctionName, \
+ _rwdbsprintf args); \
+} \
+while (0)
+
+#define RWASSERT(condition) \
+do \
+{ \
+ if (!(condition)) \
+ { \
+ RwDebugSendMessage(rwDEBUGASSERT, \
+ __dbFunctionName, \
+ RWSTRING(#condition)); \
+ } \
+ RWASSERTE(condition); \
+} \
+while (0)
+
+#else /* RWDEBUG */
+
+#define RWRETURN(value) return(value)
+#define RWRETURNVOID() return
+#define RWERROR(errorcode) \
+do \
+{ \
+ RwError _rwErrorCode; \
+ \
+ _rwErrorCode.pluginID = rwPLUGIN_ID; \
+ _rwErrorCode.errorCode = _rwerror errorcode; \
+ \
+ RwErrorSet(&_rwErrorCode); \
+} \
+while (0)
+#define RWFUNCTION(name)
+#define RWAPIFUNCTION(name)
+#define RWASSERT(condition)
+#define RWMESSAGE(args)
+
+#endif
+
+#define RWVALIDATEDEBUGSTACKDEPTH() \
+ RWASSERT(1 == (RWDEBUGSTACKDEPTH - startstackdepth))
+
+/****************************************************************************
+ Functions
+ */
+
+#ifdef __cplusplus
+extern "C"
+{
+#endif /* __cplusplus */
+
+RwChar *rwPLUGIN_ERRFUNC(RwInt32 code, ...);
+
+#ifdef __cplusplus
+}
+#endif /* __cplusplus */
+
+#endif /* RWDEBUG_H */