/* ======================================================= *
 * Copyright 1998-2005 Stephen C. Grubb                    *
 * http://ploticus.sourceforge.net                         *
 * Covered by GPL; see the file ./Copyright for details.   *
 * ======================================================= */

/* error msg handler */

#include <stdio.h>
#include <string.h>
extern int GL_sysdate(), GL_systime(), GL_slmember();

static char emode[20] = "stderr";
static char progname[80] = "";
static char errlog[256] = "";
static int progsticky = 0;
static FILE *errfp = NULL;

/* ========================================== */
int
TDH_err_initstatic()
{
strcpy( emode, "stderr" );
strcpy( progname, "" );
strcpy( errlog, "" );
errfp = NULL;
return( 0 );
}

/* ========================================== */

int
TDH_err( errno, msg, parm )
int errno;
char *msg, *parm;
{
char op[4], cp[4];
char *getenv();
int say_error;

strcpy( op, "" );
strcpy( cp, "" );
if( parm[0] != '\0' ) {
	strcpy( op, "(" );
	strcpy( cp, ")" );
	}

say_error = 1;
#ifndef BAREBONES
  if( GL_slmember( msg, "note:* warning:*" )) say_error = 0;
#endif


if( strcmp( emode, "cgi" )==0 ) {
	printf( "<br><h4>%s: %s %d: %s %s%s%s</h4><br>\n", progname, (say_error)?"error":"", errno, msg, op, parm, cp );
	fflush( stdout );
	}
else if( strcmp( emode, "stderr" )==0 ) 
	fprintf( stderr, "%s: %s %d: %s %s%s%s\n", progname, (say_error)?"error":"", errno, msg, op, parm, cp );

else 	{
	fprintf( errfp, "%s: %s %d: %s %s%s%s\n", progname, (say_error)?"error":"", errno, msg, op, parm, cp );
	fflush( errfp );
	}

/* if an error log file was specified, write a line to this file .. */
#ifndef BAREBONES
if( errlog[0] != '\0' ) {
	FILE *logfp;
	int mon, day, yr, hr, min, sec;
	GL_sysdate( &mon, &day, &yr );
	GL_systime( &hr, &min, &sec );

	logfp = fopen( errlog, "a" );
	if( logfp != NULL ) {
		fprintf( logfp, "20%02d/%02d/%02d %02d:%02d:%02d error %d: %s (%s)\n", 
                	yr, mon, day, hr, min, sec, errno, msg, parm );
		fclose( logfp );
		}
	}
#endif

return( errno );
}


/* ===================================== */
int
TDH_errprog( prog )
char *prog; 
{
if( progsticky ) return( 0 );
strcpy( progname, prog);
return( 0 );
}

/* ===================================== */
/* set the errprog.. and can only be reset via this routine (ignore subsequent errprog calls)
	...this allows user control over errprog */
int
TDH_errprogsticky( prog )
char *prog;
{
progsticky = 1;
strcpy( progname, prog);
return( 0 );
}

/* ===================================== */
int
TDH_geterrprog( prog )
char *prog; 
{
strcpy( prog, progname );
return( 0 );
}

/* ===================================== */
int
TDH_errmode( mode )
char *mode;
{
strcpy( emode, mode );
return( 0 );
}

/* ===================================== */
int
TDH_errfile( fp )
FILE *fp;
{
errfp = fp;
strcpy( emode, "file" );
return( 0 );
}

/* ===================================== */
int
TDH_geterrmode( mode )
char *mode;
{
strcpy( mode, emode );
return( 0 );
}

/* ===================================== */
int
TDH_errlogfile( filename )
char *filename;
{
strcpy( errlog, filename );
return( 0 );
}

/* ======================================================= *
 * Copyright 1998-2005 Stephen C. Grubb                    *
 * http://ploticus.sourceforge.net                         *
 * Covered by GPL; see the file ./Copyright for details.   *
 * ======================================================= */


syntax highlighted by Code2HTML, v. 0.9.1