1
mirror of https://github.com/mpv-player/mpv synced 2025-01-20 21:07:29 +01:00
mpv/Gui/error.c
arpi 9f6529b3d3 GUI version n-1
git-svn-id: svn://svn.mplayerhq.hu/mplayer/trunk@1694 b3059339-0415-0410-9bf9-f77b7e298cf2
2001-08-25 21:04:29 +00:00

62 lines
1.1 KiB
C

#include <stdlib.h>
#include <stdio.h>
#include <stdarg.h>
#include "error.h"
int debug_level = 6;
FILE * debug_file;
int debug_stderr = 0;
void defaultErrorHandler( int critical,const char * format, ... )
{
char * p;
va_list ap;
if ( (p=(char *)malloc( 512 ) ) == NULL ) return;
va_start( ap,format );
vsnprintf( p,512,format,ap );
va_end( ap );
fprintf( stderr,"%s",p );
free( p );
if ( critical ) exit( 1 );
}
void defaultDebugHandler( int critical,const char * format, ... )
{
char * p;
va_list ap;
if ( critical >= debug_level ) return;
if ( (p=(char *)malloc( 512 ) ) == NULL ) return;
va_start( ap,format );
vsnprintf( p,512,format,ap );
va_end( ap );
fprintf( debug_file,"%s",p );
free( p );
}
errorTHandler message = defaultErrorHandler;
errorTHandler dbprintf = defaultDebugHandler;
void initDebug( char * name )
{
if ( name )
{
if ( ( debug_file=fopen( name,"wt+" ) ) != NULL )
{
debug_stderr=0;
return;
}
}
debug_file=stderr;
debug_stderr=1;
}
void doneDebug( void )
{
if ( !debug_stderr ) fclose( debug_file );
debug_file=stderr;
debug_stderr=1;
}