@ -16,34 +16,77 @@
*/
/**************************************************************************
*
* This component contains various macros and functions used to ease the
* debugging of the FreeType engine . Its main purpose is in assertion
* checking , tracing , and error detection .
*
* There are now three debugging modes :
*
* - trace mode
*
* Error and trace messages are sent to the log file ( which can be the
* standard error output ) .
*
* - error mode
*
* Only error messages are generated .
*
* - release mode :
*
* No error message is sent or generated . The code is free from any
* debugging parts .
*
*/
# include <freetype/freetype.h>
# include <freetype/internal/ftdebug.h>
# ifdef FT_LOGGING
/**************************************************************************
*
* This component contains various macros and functions used to ease the
* debugging of the FreeType engine . Its main purpose is in assertion
* checking , tracing , and error detection .
* Variable used when FT_LOGGING is enabled to control logging :
*
* 1. ft_default_trace_level : stores the value of trace levels which are
* provided to FreeType using FT2_DEBUG environment variable .
*
* There are now three debugging modes :
* 2. ft_fileptr : store the FILE *
*
* - trace mode
* 3. ft_component : a string that holds the name of FT_COMPONENT
*
* Error and trace messages are sent to the log file ( which can be the
* standard error output ) .
* 4. ft_component_flag : a flag when true , prints the name of
* FT_COMPONENT along with actual log message .
*
* - error mode
* 5. ft_timestamp_flag : a flag when true , prints time along with log
* actual log message .
*
* Only error messages are generated .
* 6. ft_have_newline_char : It is used to differentiate between a log
* message with ' \n ' char and log message without ' \n ' char
*
* - release mode :
* 7. ft_custom_trace_level : stores the value of custom trace level which
* is provided by user at run - time .
*
* No error message is sent or generated . The code is free from any
* debugging parts .
* Static Variables are defined here to remove [ - Wunused - variable ]
* warning
*
*/
static const char * ft_default_trace_level = NULL ;
static FILE * ft_fileptr = NULL ;
static const char * ft_component = NULL ;
static bool ft_component_flag = false ;
static bool ft_timestamp_flag = false ;
static bool ft_have_newline_char = true ;
static const char * ft_custom_trace_level = NULL ;
/* declared in ftdebug.h */
# include <freetype/freetype.h>
# include <freetype/internal/ftdebug.h>
dlg_handler ft_default_log_handler = NULL ;
FT_Custom_Log_Handler custom_output_handler = NULL ;
# endif
# ifdef FT_DEBUG_LEVEL_ERROR
@ -54,51 +97,51 @@
# include <windows.h>
/* documentation is in ftdebug.h */
/* documentation is in ftdebug.h */
FT_BASE_DEF ( void )
FT_Message ( const char * fmt ,
. . . )
{
static char buf [ 8192 ] ;
va_list ap ;
FT_BASE_DEF ( void )
FT_Message ( const char * fmt ,
. . . )
{
static char buf [ 8192 ] ;
va_list ap ;
va_start ( ap , fmt ) ;
vfprintf ( stderr , fmt , ap ) ;
/* send the string to the debugger as well */
vsprintf ( buf , fmt , ap ) ;
OutputDebugStringA ( buf ) ;
va_end ( ap ) ;
}
va_start ( ap , fmt ) ;
vfprintf ( stderr , fmt , ap ) ;
/* send the string to the debugger as well */
vsprintf ( buf , fmt , ap ) ;
OutputDebugStringA ( buf ) ;
va_end ( ap ) ;
}
/* documentation is in ftdebug.h */
/* documentation is in ftdebug.h */
FT_BASE_DEF ( void )
FT_Panic ( const char * fmt ,
. . . )
{
static char buf [ 8192 ] ;
va_list ap ;
FT_BASE_DEF ( void )
FT_Panic ( const char * fmt ,
. . . )
{
static char buf [ 8192 ] ;
va_list ap ;
va_start ( ap , fmt ) ;
vsprintf ( buf , fmt , ap ) ;
OutputDebugStringA ( buf ) ;
va_end ( ap ) ;
va_start ( ap , fmt ) ;
vsprintf ( buf , fmt , ap ) ;
OutputDebugStringA ( buf ) ;
va_end ( ap ) ;
exit ( EXIT_FAILURE ) ;
}
exit ( EXIT_FAILURE ) ;
}
/* documentation is in ftdebug.h */
/* documentation is in ftdebug.h */
FT_BASE_DEF ( int )
FT_Throw ( FT_Error error ,
int line ,
const char * file )
{
FT_BASE_DEF ( int )
FT_Throw ( FT_Error error ,
int line ,
const char * file )
{
#if 0
/* activating the code in this block makes FreeType very chatty */
fprintf ( stderr ,
@ -108,223 +151,392 @@
error ,
FT_Error_String ( error ) ) ;
# else
FT_UNUSED ( error ) ;
FT_UNUSED ( line ) ;
FT_UNUSED ( file ) ;
FT_UNUSED ( error ) ;
FT_UNUSED ( line ) ;
FT_UNUSED ( file ) ;
# endif
return 0 ;
}
return 0 ;
}
# endif /* FT_DEBUG_LEVEL_ERROR */
# ifdef FT_DEBUG_LEVEL_TRACE
/* array of trace levels, initialized to 0; */
/* this gets adjusted at run-time */
static int ft_trace_levels_enabled [ trace_count ] ;
/* array of trace levels, initialized to 0; */
/* this gets adjusted at run-time */
static int ft_trace_levels_enabled [ trace_count ] ;
/* array of trace levels, always initialized to 0 */
static int ft_trace_levels_disabled [ trace_count ] ;
/* array of trace levels, always initialized to 0 */
static int ft_trace_levels_disabled [ trace_count ] ;
/* a pointer to either `ft_trace_levels_enabled' */
/* or `ft_trace_levels_disabled' */
int * ft_trace_levels ;
/* a pointer to either `ft_trace_levels_enabled' */
/* or `ft_trace_levels_disabled' */
int * ft_trace_levels ;
/* define array of trace toggle names */
/* define array of trace toggle names */
# define FT_TRACE_DEF( x ) #x ,
static const char * ft_trace_toggles [ trace_count + 1 ] =
{
static const char * ft_trace_toggles [ trace_count + 1 ] =
{
# include <freetype/internal/fttrace.h>
NULL
} ;
} ;
# undef FT_TRACE_DEF
/* documentation is in ftdebug.h */
/* documentation is in ftdebug.h */
FT_BASE_DEF ( FT_Int )
FT_Trace_Get_Count ( void )
{
return trace_count ;
}
FT_BASE_DEF ( FT_Int )
FT_Trace_Get_Count ( void )
{
return trace_count ;
}
/* documentation is in ftdebug.h */
/* documentation is in ftdebug.h */
FT_BASE_DEF ( const char * )
FT_Trace_Get_Name ( FT_Int idx )
{
int max = FT_Trace_Get_Count ( ) ;
FT_BASE_DEF ( const char * )
FT_Trace_Get_Name ( FT_Int idx )
{
int max = FT_Trace_Get_Count ( ) ;
if ( idx < max )
return ft_trace_toggles [ idx ] ;
else
return NULL ;
}
if ( idx < max )
return ft_trace_toggles [ idx ] ;
else
return NULL ;
}
/* documentation is in ftdebug.h */
/* documentation is in ftdebug.h */
FT_BASE_DEF ( void )
FT_Trace_Disable ( void )
{
ft_trace_levels = ft_trace_levels_disabled ;
}
FT_BASE_DEF ( void )
FT_Trace_Disable ( void )
{
ft_trace_levels = ft_trace_levels_disabled ;
}
/* documentation is in ftdebug.h */
/* documentation is in ftdebug.h */
FT_BASE_DEF ( void )
FT_Trace_Enable ( void )
{
ft_trace_levels = ft_trace_levels_enabled ;
}
FT_BASE_DEF ( void )
FT_Trace_Enable ( void )
{
ft_trace_levels = ft_trace_levels_enabled ;
}
/**************************************************************************
*
* Initialize the tracing sub - system . This is done by retrieving the
* value of the ` FT2_DEBUG ' environment variable . It must be a list of
* toggles , separated by spaces , ` ; ' , or ` , ' . Example :
*
* export FT2_DEBUG = " any:3 memory:7 stream:5 "
*
* This requests that all levels be set to 3 , except the trace level for
* the memory and stream components which are set to 7 and 5 ,
* respectively .
*
* See the file ` include / freetype / internal / fttrace . h ' for details of
* the available toggle names .
*
* The level must be between 0 and 7 ; 0 means quiet ( except for serious
* runtime errors ) , and 7 means _very_ verbose .
*/
FT_BASE_DEF ( void )
ft_debug_init ( void )
{
const char * ft2_debug = getenv ( " FT2_DEBUG " ) ;
/**************************************************************************
*
* Initialize the tracing sub - system . This is done by retrieving the
* value of the ` FT2_DEBUG ' environment variable . It must be a list of
* toggles , separated by spaces , ` ; ' , or ` , ' . Example :
*
* export FT2_DEBUG = " any:3 memory:7 stream:5 "
*
* This requests that all levels be set to 3 , except the trace level for
* the memory and stream components which are set to 7 and 5 ,
* respectively .
*
* See the file ` include / freetype / internal / fttrace . h ' for details of
* the available toggle names .
*
* The level must be between 0 and 7 ; 0 means quiet ( except for serious
* runtime errors ) , and 7 means _very_ verbose .
*/
FT_BASE_DEF ( void )
ft_debug_init ( void )
{
const char * ft2_debug = NULL ;
if ( ft2_debug )
{
const char * p = ft2_debug ;
const char * q ;
# ifdef FT_LOGGING
if ( ft_custom_trace_level ! = NULL )
ft2_debug = ft_custom_trace_level ;
else
ft2_debug = ft_default_trace_level ;
for ( ; * p ; p + + )
{
/* skip leading whitespace and separators */
if ( * p = = ' ' | | * p = = ' \t ' | | * p = = ' , ' | | * p = = ' ; ' | | * p = = ' = ' )
continue ;
# else
ft2_debug = ft_getenv ( " FT2_DEBUG " ) ;
# endif /* FT_LOGGIGN */
/* read toggle name, followed by ':' */
q = p ;
while ( * p & & * p ! = ' : ' )
p + + ;
if ( ft2_debug )
{
const char * p = ft2_debug ;
const char * q ;
if ( ! * p )
break ;
for ( ; * p ; p + + )
{
/* skip leading whitespace and separators */
if ( * p = = ' ' | | * p = = ' \t ' | | * p = = ' , ' | | * p = = ' ; ' | | * p = = ' = ' )
continue ;
if ( * p = = ' : ' & & p > q )
# ifdef FT_LOGGING
/* check extra arguments for logging */
if ( * p = = ' - ' )
{
FT_Int n , i , len = ( FT_Int ) ( p - q ) ;
FT_Int level = - 1 , found = - 1 ;
const char * r = + + p ;
if ( * r = = ' v ' )
{
ft_component_flag = true ;
const char * s = + + r ;
if ( * s = = ' t ' )
{
ft_timestamp_flag = true ;
p + + ;
}
p + + ;
}
else if ( * r = = ' t ' )
{
ft_timestamp_flag = true ;
const char * s = + + r ;
if ( * s = = ' v ' )
{
ft_component_flag = true ;
p + + ;
}
p + + ;
}
}
# endif /* FT_LOGGING */
/* read toggle name, followed by ':' */
q = p ;
while ( * p & & * p ! = ' : ' )
p + + ;
for ( n = 0 ; n < trace_count ; n + + )
{
const char * toggle = ft_trace_toggles [ n ] ;
if ( ! * p )
break ;
if ( * p = = ' : ' & & p > q )
{
FT_Int n , i , len = ( FT_Int ) ( p - q ) ;
FT_Int level = - 1 , found = - 1 ;
for ( i = 0 ; i < len ; i + + )
{
if ( toggle [ i ] ! = q [ i ] )
break ;
}
if ( i = = len & & toggle [ i ] = = 0 )
{
found = n ;
for ( n = 0 ; n < trace_count ; n + + )
{
const char * toggle = ft_trace_toggles [ n ] ;
for ( i = 0 ; i < len ; i + + )
{
if ( toggle [ i ] ! = q [ i ] )
break ;
}
}
/* read level */
p + + ;
if ( * p )
if ( i = = len & & toggle [ i ] = = 0 )
{
level = * p - ' 0 ' ;
if ( level < 0 | | level > 7 )
level = - 1 ;
found = n ;
break ;
}
}
if ( found > = 0 & & level > = 0 )
/* read level */
p + + ;
if ( * p )
{
level = * p - ' 0 ' ;
if ( level < 0 | | level > 7 )
level = - 1 ;
}
if ( found > = 0 & & level > = 0 )
{
if ( found = = trace_any )
{
if ( found = = trace_any )
{
/* special case for `any' */
for ( n = 0 ; n < trace_count ; n + + )
ft_trace_levels_enabled [ n ] = level ;
}
else
ft_trace_levels_enabled [ found ] = level ;
/* special case for `any' */
for ( n = 0 ; n < trace_count ; n + + )
ft_trace_levels_enabled [ n ] = level ;
}
else
ft_trace_levels_enabled [ found ] = level ;
}
}
}
ft_trace_levels = ft_trace_levels_enabled ;
}
ft_trace_levels = ft_trace_levels_enabled ;
}
# else /* !FT_DEBUG_LEVEL_TRACE */
FT_BASE_DEF ( void )
ft_debug_init ( void )
{
/* nothing */
}
FT_BASE_DEF ( FT_Int )
FT_Trace_Get_Count ( void )
{
return 0 ;
}
FT_BASE_DEF ( const char * )
FT_Trace_Get_Name ( FT_Int idx )
{
FT_UNUSED ( idx ) ;
return NULL ;
}
FT_BASE_DEF ( void )
FT_Trace_Disable ( void )
{
/* nothing */
}
/* documentation is in ftdebug.h */
FT_BASE_DEF ( void )
FT_Trace_Enable ( void )
{
/* nothing */
}
# endif /* !FT_DEBUG_LEVEL_TRACE */
# ifdef FT_LOGGING
/**************************************************************************
*
* If FT_LOGGING is enabled , FreeType needs to initialize all logging
* variables to write logs .
* Therefore it uses ` ft_logging_init ( ) ` function to initialize a
* loggging variables and ` ft_logging_deinit ( ) ` to un - initialize the
* logging variables .
*
*/
FT_BASE_DEF ( void )
ft_debug_init ( void )
ft_loggin g_init ( void )
{
/* nothing */
}
ft_default_log_handler = ft_log_handler ;
ft_default_trace_level = ft_getenv ( " FT2_DEBUG " ) ;
if ( ft_getenv ( " FT_LOGGING_FILE " ) )
ft_fileptr = fopen ( ft_getenv ( " FT_LOGGING_FILE " ) , " w " ) ;
else
ft_fileptr = stderr ;
ft_debug_init ( ) ;
/* We need to set the default FreeType specific dlg's output handler */
dlg_set_handler ( ft_default_log_handler , NULL ) ;
FT_BASE_DEF ( FT_Int )
FT_Trace_Get_Count ( void )
{
return 0 ;
}
FT_BASE_DEF ( void )
ft_logging_deinit ( void )
{
fclose ( ft_fileptr ) ;
}
FT_BASE_DEF ( const char * )
FT_Trace_Get_Name ( FT_Int idx )
/*************************************************************************
*
* An Output log handler specific to FreeType used by dlg library .
*
*/
FT_BASE_DEF ( void )
ft_log_handler ( const struct dlg_origin * origin ,
const char * string , void * data )
{
FT_UNUSED ( idx ) ;
( void ) data ;
const char * features ;
if ( ft_timestamp_flag & & ft_component_flag & & ft_have_newline_char )
features = " [%h:%m %t] %c " ;
else if ( ft_component_flag & & ft_have_newline_char )
features = " [%t] %c " ;
else if ( ft_timestamp_flag & & ft_have_newline_char )
features = " [%h:%m] %c " ;
else
features = " %c " ;
dlg_generic_outputf_stream ( ft_fileptr , features , origin , string ,
dlg_default_output_styles , true ) ;
if ( strchr ( string , ' \n ' ) )
ft_have_newline_char = true ;
else
ft_have_newline_char = false ;
return NULL ;
}
/* documentation is in ftdebug.h */
FT_BASE_DEF ( void )
ft_add_tag ( const char * tag )
{
ft_component = tag ;
dlg_add_tag ( tag , NULL ) ;
}
/* documentation is in ftdebug.h */
FT_BASE_DEF ( void )
FT_Trace_Disable ( void )
ft_remove_tag ( const char * tag )
{
/* nothing */
dlg_remove_tag ( tag , NULL ) ;
}
/* documentation is in ftlogging.h */
/* documentation is in ftdebug.h */
FT_EXPORT_DEF ( void )
FT_Trace_Set_Level ( const char * level )
{
ft_component_flag = NULL ;
ft_timestamp_flag = NULL ;
ft_custom_trace_level = level ;
ft_debug_init ( ) ;
}
FT_BASE_DEF ( void )
FT_Trace_Enable ( void )
/* documentation is in ftlogging.h */
FT_EXPORT_DEF ( void )
FT_Trace_Set_Default_Level ( void )
{
/* nothing */
ft_component_flag = NULL ;
ft_timestamp_flag = NULL ;
ft_custom_trace_level = NULL ;
ft_debug_init ( ) ;
}
/****************************************************************************
*
* Functions to handle custom log handler :
*
*/
# endif /* !FT_DEBUG_LEVEL_TRACE */
FT_EXPORT_DEF ( void )
FT_Set_Log_Handler ( FT_Custom_Log_Handler handler )
{
custom_output_handler = handler ;
}
FT_EXPORT_DEF ( void )
FT_Set_Default_Log_Handler ( )
{
custom_output_handler = NULL ;
}
FT_BASE_DEF ( void )
FT_Callback ( const char * fmt , . . . )
{
va_list ap ;
va_start ( ap , fmt ) ;
custom_output_handler ( ft_component , fmt , ap ) ;
va_end ( ap ) ;
}
# endif /* FT_LOGGING */
/* END */