mirror of
https://github.com/kevinbentley/Descent3.git
synced 2025-01-22 19:55:23 +00:00
286 lines
14 KiB
C
286 lines
14 KiB
C
/*
|
|
* $Logfile: /DescentIII/Main/lib/pserror.h $
|
|
* $Revision: 25 $
|
|
* $Date: 3/20/00 12:26p $
|
|
* $Author: Matt $
|
|
*
|
|
* error functions
|
|
*
|
|
* $Log: /DescentIII/Main/lib/pserror.h $
|
|
*
|
|
* 25 3/20/00 12:26p Matt
|
|
* Merge of Duane's post-1.3 changes.
|
|
* Mac include and assert changes
|
|
*
|
|
* 24 10/21/99 9:28p Jeff
|
|
* B.A. Macintosh code merge
|
|
*
|
|
* 23 7/28/99 3:13p Kevin
|
|
* Mac
|
|
*
|
|
* 22 5/10/99 10:53p Ardussi
|
|
* changes to compile on Mac
|
|
*
|
|
* 21 4/14/99 10:46a Kevin
|
|
* Removed OutrageMessageBox from release builds
|
|
*
|
|
* 20 4/01/99 4:50p Matt
|
|
* Took out Warning() function, chaning those calls to mprintf()
|
|
*
|
|
* 19 1/09/99 4:39p Jeff
|
|
* added some ifdefs and fixes to get files to compile under Linux
|
|
*
|
|
* 18 10/18/98 8:52p Matt
|
|
* Revamped debug/error system.
|
|
*
|
|
* 17 10/13/98 12:03p Kevin
|
|
* Changed use of preprocessors for debug, etc.
|
|
*
|
|
* 16 10/12/98 10:20a Samir
|
|
* added parameter to debug init.
|
|
*
|
|
* 15 6/23/98 2:40p Matt
|
|
* Added Yes/No/Cancel type to OutrageMessageBox() and
|
|
* Debug_MesssageBox(), and changed return value from a bool to an
|
|
* integer.
|
|
*
|
|
* 14 6/01/98 4:28p Samir
|
|
* added HEAPCHECK macro.
|
|
*
|
|
* 13 4/23/98 4:14a Samir
|
|
* added warning system.
|
|
*
|
|
* 12 4/08/98 7:19p Samir
|
|
* Added runtime debugging option.
|
|
*
|
|
* 11 4/07/98 9:20p Samir
|
|
* Changes to debug stuff.
|
|
*
|
|
* 10 4/03/98 5:15p Samir
|
|
* Implemented simple debug message filtering.
|
|
*
|
|
* 9 3/20/98 2:43p Samir
|
|
* Some better Int3 support.
|
|
*
|
|
* 8 3/19/98 11:27a Samir
|
|
* Better error checking.
|
|
*
|
|
* 7 3/17/98 2:37p Samir
|
|
* Added debug callback support for assert.
|
|
*
|
|
* 6 3/10/98 5:16p Samir
|
|
* Got debug callbacks working when you hit an Int3.
|
|
*
|
|
* 5 2/20/98 12:11p Matt
|
|
* Changed ASSERT() to print its own mono message and call debug_break
|
|
* directly, instead of using Int3().
|
|
*
|
|
* 4 12/01/97 2:12p Samir
|
|
* Int3 for assertions.
|
|
*
|
|
* 3 9/16/97 5:07p Matt
|
|
* Disable Int3() when _DEBUG not set
|
|
*
|
|
* 2 9/04/97 12:02p Matt
|
|
* Changed the simple form OutrageMessageBox() to be void (instead of
|
|
* bool) since it wasn't returning a meaningful value anyway
|
|
*
|
|
* 19 6/11/97 1:11p Samir
|
|
* Implemented new Debug system
|
|
*
|
|
* 18 3/14/97 4:15p Matt
|
|
* Changed title of OutrageMessageBox() dialogs
|
|
*
|
|
* 17 3/10/97 11:13a Samir
|
|
* Changes made to reflect deletion of OSDebug class from system
|
|
*
|
|
* 16 3/04/97 1:00p Samir
|
|
* Fixed return type prototype errors.
|
|
*
|
|
* 15 3/04/97 12:55p Samir
|
|
* Added yesno and ok messageboxes.
|
|
*
|
|
* 14 3/03/97 5:22p Samir
|
|
* Pass debug object to error_init.
|
|
*
|
|
* 13 2/26/97 7:06p Samir
|
|
* call err_Break instead of Int3 to keep PC code out of pserror.h
|
|
*
|
|
* 12 2/26/97 4:49 PM Jeremy
|
|
* Put "assert.h" as <assert.h> since it's an ANSI file not one of ours.
|
|
*
|
|
* 11 2/06/97 6:32p Samir
|
|
* Int3 now tells us where we broke.
|
|
*
|
|
* 10 2/06/97 11:28a Matt
|
|
* Put do..while around Int3 definition so Int3() acts like a normal
|
|
* statement.
|
|
*
|
|
* 9 1/31/97 2:12p Samir
|
|
* Fixed prototype for error_init
|
|
*
|
|
* 8 1/31/97 1:52p Samir
|
|
* added error_init function
|
|
*
|
|
* 7 1/30/97 6:02p Samir
|
|
* Added DEBUG_STACK macro
|
|
*
|
|
* $NoKeywords: $
|
|
*/
|
|
#ifndef PSERROR_H
|
|
#define PSERROR_H
|
|
#include <assert.h>
|
|
#include "debug.h"
|
|
#include "mono.h"
|
|
// initializes error handler.
|
|
bool error_Init(bool debugger, bool mono_debug, const char *app_title);
|
|
// exits the application and prints out a standard error message
|
|
void Error(char *fmt, ...);
|
|
// prints out an assertion error
|
|
void AssertionFailed(char *expstr, char *file, int line);
|
|
// Brings up an error message for an int3
|
|
void Int3MessageBox(char *file, int line);
|
|
// Message box functions
|
|
#define MBOX_OK 1
|
|
#define MBOX_YESNO 2
|
|
#define MBOX_YESNOCANCEL 3
|
|
#define MBOX_ABORTRETRYIGNORE 4
|
|
#ifndef RELEASE
|
|
// prints out a standard OS messagebox
|
|
void OutrageMessageBox(char *str, ...);
|
|
int OutrageMessageBox(int type, char *str, ...);
|
|
#endif
|
|
// Sets the title for future OutrageMessageBox() dialogs
|
|
void SetMessageBoxTitle(char *title);
|
|
// Write a block of text to the system clipboard
|
|
void DumpTextToClipboard(char *text);
|
|
//////////////////////////////////////////////////////////////////////////////
|
|
// development debugging functions
|
|
// adds a function to be called when a debug break occurs.
|
|
// undefine any ASSERT macro previously defined.
|
|
#ifdef ASSERT
|
|
#undef ASSERT
|
|
#endif
|
|
// this callback is invoked when a DEBUG_BREAK macro is used.
|
|
// arguments
|
|
// style = 1 if ASSERT
|
|
// = 0 if Int3 debugger break.
|
|
extern void (*DebugBreak_callback_stop)();
|
|
extern void (*DebugBreak_callback_resume)();
|
|
// set DEBUG_BREAK callback
|
|
inline void SetDebugBreakHandlers(void (*stop)(), void (*resume)()) {
|
|
DebugBreak_callback_stop = stop;
|
|
DebugBreak_callback_resume = resume;
|
|
}
|
|
// DEBUG_BREAK()
|
|
// Calls the debug_break() macro surrounded by calls to the debug callbacks (to turn off & on graphics)
|
|
// ASSERT()
|
|
// Like the standard C assert(), but if the condition failed and debugging on,
|
|
// does a DEBUG_BREAK(). If debugging on, brings up a dialog.
|
|
// Int3()
|
|
// Does a DEBUG_BREAK() if debugging is turned on. Also does an mprintf().
|
|
// Define the macros
|
|
#ifndef RELEASE
|
|
#if defined(MACOSX)
|
|
#include <sys/malloc.h>
|
|
#else
|
|
#include <malloc.h>
|
|
#endif
|
|
#if defined(WIN32)
|
|
#define DEBUG_BREAK() \
|
|
do { \
|
|
if (DebugBreak_callback_stop) \
|
|
(*DebugBreak_callback_stop)(); \
|
|
debug_break(); \
|
|
if (DebugBreak_callback_resume) \
|
|
(*DebugBreak_callback_resume)(); \
|
|
} while (0)
|
|
#define ASSERT(x) \
|
|
do { \
|
|
if (!(unsigned)(x)) { \
|
|
mprintf((0, "Assertion failed (%s) in %s line %d.\n", #x, __FILE__, __LINE__)); \
|
|
if (Debug_break) \
|
|
DEBUG_BREAK(); \
|
|
else \
|
|
AssertionFailed(#x, __FILE__, __LINE__); \
|
|
} \
|
|
} while (0)
|
|
#define Int3() \
|
|
do { \
|
|
mprintf((0, "Int3 at %s line %d.\n", __FILE__, __LINE__)); \
|
|
if (Debug_break) \
|
|
DEBUG_BREAK(); \
|
|
else \
|
|
Int3MessageBox(__FILE__, __LINE__); \
|
|
} while (0)
|
|
#define HEAPCHECK() \
|
|
do { \
|
|
if (_heapchk() != _HEAPOK) \
|
|
Int3(); \
|
|
} while (0)
|
|
#elif defined(LINUX)
|
|
// For some reason Linux doesn't like the \ continuation character, so I have to uglify this
|
|
#define DEBUG_BREAK() \
|
|
do { \
|
|
if (DebugBreak_callback_stop) \
|
|
(*DebugBreak_callback_stop)(); \
|
|
debug_break(); \
|
|
if (DebugBreak_callback_resume) \
|
|
(*DebugBreak_callback_resume)(); \
|
|
} while (0)
|
|
#define ASSERT(x) \
|
|
do { \
|
|
if (!(unsigned long long)(x)) { \
|
|
mprintf((0, "Assertion failed (%s) in %s line %d.\n", #x, __FILE__, __LINE__)); \
|
|
if (Debug_break) \
|
|
DEBUG_BREAK(); \
|
|
else \
|
|
AssertionFailed(#x, __FILE__, __LINE__); \
|
|
} \
|
|
} while (0)
|
|
#define Int3() \
|
|
do { \
|
|
mprintf((0, "Int3 at %s line %d.\n", __FILE__, __LINE__)); \
|
|
if (Debug_break) \
|
|
DEBUG_BREAK(); \
|
|
else \
|
|
Int3MessageBox(__FILE__, __LINE__); \
|
|
} while (0)
|
|
#define HEAPCHECK()
|
|
#elif defined(MACINTOSH)
|
|
#define DEBUG_BREAK() \
|
|
do { \
|
|
if (DebugBreak_callback_stop) \
|
|
(*DebugBreak_callback_stop)(); \
|
|
debug_break(); \
|
|
if (DebugBreak_callback_resume) \
|
|
(*DebugBreak_callback_resume)(); \
|
|
} while (0)
|
|
///#define ASSERT(x) assert(x)
|
|
#define ASSERT(x) \
|
|
do { \
|
|
if (!(unsigned)(x)) { \
|
|
mprintf((2, "Assertion failed (%s) in %s line %d.\n", #x, __FILE__, __LINE__)); \
|
|
if (Debug_break) \
|
|
DEBUG_BREAK(); \
|
|
else \
|
|
AssertionFailed(#x, __FILE__, __LINE__); \
|
|
} \
|
|
} while (0)
|
|
#define Int3() \
|
|
do { \
|
|
mprintf((0, "Int3 at %s line %d.\n", __FILE__, __LINE__)); \
|
|
if (Debug_break) \
|
|
DEBUG_BREAK(); \
|
|
else \
|
|
Int3MessageBox(__FILE__, __LINE__); \
|
|
} while (0)
|
|
#define HEAPCHECK()
|
|
#endif
|
|
#else
|
|
#define DEBUG_BREAK()
|
|
#define ASSERT(x)
|
|
#define Int3()
|
|
#define HEAPCHECK()
|
|
#endif
|
|
#endif |