put some old stuff back in, eliminate duplicate error messages
authorBradley Bell <btb@icculus.org>
Tue, 8 Apr 2003 00:59:17 +0000 (00:59 +0000)
committerBradley Bell <btb@icculus.org>
Tue, 8 Apr 2003 00:59:17 +0000 (00:59 +0000)
ChangeLog
include/error.h
misc/error.c

index a656728..93367bf 100644 (file)
--- a/ChangeLog
+++ b/ChangeLog
@@ -1,5 +1,8 @@
 2003-04-07  Bradley Bell  <btb@icculus.org>
 
+       * include/error.h, misc/error.c: put some old stuff back in,
+       eliminate duplicate error messages
+
        * main/text.c: don't die on text not found
        formatting
 
index b7b1639..f366890 100644 (file)
@@ -1,4 +1,4 @@
-/* $Id: error.h,v 1.7 2003-01-15 02:42:41 btb Exp $ */
+/* $Id: error.h,v 1.8 2003-04-08 00:59:17 btb Exp $ */
 /*
 THE COMPUTER CODE CONTAINED HEREIN IS THE SOLE PROPERTY OF PARALLAX
 SOFTWARE CORPORATION ("PARALLAX").  PARALLAX, IN DISTRIBUTING THE CODE TO
@@ -69,7 +69,7 @@ COPYRIGHT 1993-1998 PARALLAX SOFTWARE CORPORATION.  ALL RIGHTS RESERVED.
 #define __format
 #endif
 
-int error_init(char *fmt,...);                 //init error system, set default message, returns 0=ok
+int error_init(void (*func)(char *), char *fmt,...);    //init error system, set default message, returns 0=ok
 void set_exit_message(char *fmt,...);  //specify message to print at exit
 void Warning(char *fmt,...);                           //print out warning message to user
 void set_warn_func(void (*f)(char *s));//specifies the function to call with warning messages
index dce3507..09967b5 100644 (file)
@@ -1,4 +1,4 @@
-/* $Id: error.c,v 1.5 2003-04-03 07:16:57 btb Exp $ */
+/* $Id: error.c,v 1.6 2003-04-08 00:59:17 btb Exp $ */
 /*
 THE COMPUTER CODE CONTAINED HEREIN IS THE SOLE PROPERTY OF PARALLAX
 SOFTWARE CORPORATION ("PARALLAX").  PARALLAX, IN DISTRIBUTING THE CODE TO
@@ -61,7 +61,7 @@ COPYRIGHT 1993-1998 PARALLAX SOFTWARE CORPORATION.  ALL RIGHTS RESERVED.
 #endif
 
 #ifdef RCS
-static char rcsid[] = "$Id: error.c,v 1.5 2003-04-03 07:16:57 btb Exp $";
+static char rcsid[] = "$Id: error.c,v 1.6 2003-04-08 00:59:17 btb Exp $";
 #endif
 
 #include <stdio.h>
@@ -71,6 +71,7 @@ static char rcsid[] = "$Id: error.c,v 1.5 2003-04-03 07:16:57 btb Exp $";
 
 #include "pstypes.h"
 #include "console.h"
+#include "mono.h"
 #include "error.h"
 
 #define MAX_MSG_LEN 256
@@ -79,13 +80,15 @@ static char rcsid[] = "$Id: error.c,v 1.5 2003-04-03 07:16:57 btb Exp $";
 int err_initialized=0;
 //end edit -MM
 
+static void (*ErrorPrintFunc)(char *);
+
 char exit_message[MAX_MSG_LEN]="";
 char warn_message[MAX_MSG_LEN];
 
 //takes string in register, calls printf with string on stack
 void warn_printf(char *s)
 {
-       printf("%s\n",s);
+       con_printf(CON_URGENT, "%s\n",s);
 }
 
 void (*warn_func)(char *s)=warn_printf;
@@ -124,7 +127,23 @@ void _Assert(int expr,char *expr_text,char *filename,int linenum)
 void print_exit_message(void)
 {
        if (*exit_message)
-               con_printf(CON_CRITICAL, "%s\n",exit_message);
+       {
+               if (ErrorPrintFunc)
+               {
+                       (*ErrorPrintFunc)(exit_message);
+               }
+               else
+               {
+#if (defined(MACINTOSH) && defined(NDEBUG) && defined(RELEASE))
+                       c2pstr(exit_message);
+                       ShowCursor();
+                       ParamText(exit_message, "\p", "\p", "\p");
+                       StopAlert(ERROR_ALERT, nil);
+#else
+                       con_printf(CON_CRITICAL, "%s\n",exit_message);
+#endif
+               }
+       }
 }
 
 //terminates with error code 1, printing message
@@ -132,13 +151,18 @@ void Error(char *fmt,...)
 {
        va_list arglist;
 
+#if (defined(MACINTOSH) && defined(NDEBUG) && defined(RELEASE))
+       strcpy(exit_message,"Error: "); // don't put the new line in for dialog output
+#else
        strcpy(exit_message,"\nError: ");
-
+#endif
        va_start(arglist,fmt);
        vsprintf(exit_message+strlen(exit_message),fmt,arglist);
        va_end(arglist);
 
-       con_printf(CON_CRITICAL, exit_message);
+       Int3();
+
+       if (!err_initialized) print_exit_message();
 
        exit(1);
 }
@@ -157,18 +181,21 @@ void Warning(char *fmt,...)
        vsprintf(warn_message+strlen(warn_message),fmt,arglist);
        va_end(arglist);
 
-       con_printf(CON_URGENT, warn_message);
+       mprintf((0, "%s\n", warn_message));
+       (*warn_func)(warn_message);
 
 }
 
 //initialize error handling system, and set default message. returns 0=ok
-int error_init(char *fmt,...)
+int error_init(void (*func)(char *), char *fmt, ...)
 {
        va_list arglist;
        int len;
 
        atexit(print_exit_message);             //last thing at exit is print message
 
+       ErrorPrintFunc = func;          // Set Error Print Functions
+
        if (fmt != NULL) {
                va_start(arglist,fmt);
                len = vsprintf(exit_message,fmt,arglist);