better file format sniffing

and vips_error_freeze/thaw() to stop errors from sniffing
being logged

plus better matrix sniffing
This commit is contained in:
John Cupitt 2013-07-04 09:43:57 +01:00
parent 0180a61be4
commit 1ba188dc83
10 changed files with 96 additions and 18 deletions

View File

@ -3,6 +3,8 @@
- rename image arrays as image matrices ... INTERPRETATION_ARRAY -> - rename image arrays as image matrices ... INTERPRETATION_ARRAY ->
INTERPRETATION_MATRIX etc. INTERPRETATION_MATRIX etc.
- convert im_buildlut(), im_identity*() to classes - convert im_buildlut(), im_identity*() to classes
- added vips_error_freeze()/vips_error_thaw()
- used freeze()/thaw() to stop file format sniffers logging spurious errors
3/7/13 started 7.34.2 3/7/13 started 7.34.2
- lower priority for Matlab load to reduce segvs from Mat_Open(), thanks - lower priority for Matlab load to reduce segvs from Mat_Open(), thanks

View File

@ -492,24 +492,29 @@ vips__isanalyze( const char *filename )
int width, height; int width, height;
int bands; int bands;
VipsBandFormat fmt; VipsBandFormat fmt;
int result;
generate_filenames( filename, header, image ); generate_filenames( filename, header, image );
if( !vips_existsf( "%s", header ) ) if( !vips_existsf( "%s", header ) )
return( 0 ); return( 0 );
if( !(d = read_header( header )) )
vips_error_freeze();
d = read_header( header );
vips_error_thaw();
if( !d )
return( 0 ); return( 0 );
#ifdef DEBUG #ifdef DEBUG
print_dsr( d ); print_dsr( d );
#endif /*DEBUG*/ #endif /*DEBUG*/
if( get_vips_properties( d, &width, &height, &bands, &fmt ) ) { vips_error_freeze();
vips_free( d ); result = get_vips_properties( d, &width, &height, &bands, &fmt );
return( 0 ); vips_error_thaw();
}
vips_free( d ); vips_free( d );
return( 1 ); return( result == 0 );
} }
int int

View File

@ -482,6 +482,7 @@ read_ascii_double( FILE *fp, const char whitemap[256], double *out )
{ {
int ch; int ch;
char buf[256]; char buf[256];
char *p;
ch = skip_white( fp, whitemap ); ch = skip_white( fp, whitemap );
@ -491,6 +492,16 @@ read_ascii_double( FILE *fp, const char whitemap[256], double *out )
fetch_nonwhite( fp, whitemap, buf, 256 ); fetch_nonwhite( fp, whitemap, buf, 256 );
/* The str we fetched must contain at least 1 digit. This helps stop
* us trying to convert "MATLAB" (for example) to a number and
* getting zero.
*/
for( p = buf; *p; p++ )
if( isdigit( *p ) )
break;
if( !*p )
return( *buf );
*out = g_ascii_strtod( buf, NULL ); *out = g_ascii_strtod( buf, NULL );
return( 0 ); return( 0 );
@ -603,6 +614,23 @@ vips__matrix_read_header( const char *filename,
return( 0 ); return( 0 );
} }
int
vips__matrix_ismatrix( const char *filename )
{
int width;
int height;
double scale;
double offset;
int result;
vips_error_freeze();
result = vips__matrix_read_header( filename,
&width, &height, &scale, &offset );
vips_error_thaw();
return( result == 0 );
}
static int static int
vips__matrix_body( char *whitemap, VipsImage *out, FILE *fp ) vips__matrix_body( char *whitemap, VipsImage *out, FILE *fp )
{ {

View File

@ -47,6 +47,7 @@ int vips__csv_write( VipsImage *in, const char *filename,
int vips__matrix_read_header( const char *filename, int vips__matrix_read_header( const char *filename,
int *width, int *height, double *scale, double *offset ); int *width, int *height, double *scale, double *offset );
int vips__matrix_ismatrix( const char *filename );
VipsImage *vips__matrix_read( const char *filename ); VipsImage *vips__matrix_read( const char *filename );
int vips__matrix_write( VipsImage *in, const char *filename ); int vips__matrix_write( VipsImage *in, const char *filename );

View File

@ -73,15 +73,15 @@ static gboolean
ismagick( const char *filename ) ismagick( const char *filename )
{ {
VipsImage *t; VipsImage *t;
int result;
t = vips_image_new(); t = vips_image_new();
if( vips__magick_read_header( filename, t, FALSE ) ) { vips_error_freeze();
g_object_unref( t ); result = vips__magick_read_header( filename, t, FALSE );
return( FALSE );
}
g_object_unref( t ); g_object_unref( t );
vips_error_thaw();
return( TRUE ); return( result == 0 );
} }
static VipsForeignFlags static VipsForeignFlags

View File

@ -300,11 +300,12 @@ vips__mat_ismat( const char *filename )
{ {
mat_t *mat; mat_t *mat;
if( !(mat = Mat_Open( filename, MAT_ACC_RDONLY )) ) vips_error_freeze();
return( 0 ); mat = Mat_Open( filename, MAT_ACC_RDONLY );
Mat_Close( mat ); Mat_Close( mat );
vips_error_thaw();
return( 1 ); return( mat != NULL );
} }
const char *vips__mat_suffs[] = { ".mat", NULL }; const char *vips__mat_suffs[] = { ".mat", NULL };

View File

@ -136,6 +136,7 @@ vips_foreign_load_matrix_class_init( VipsForeignLoadMatrixClass *class )
foreign_class->suffs = vips__foreign_matrix_suffs; foreign_class->suffs = vips__foreign_matrix_suffs;
load_class->is_a = vips__matrix_ismatrix;
load_class->get_flags_filename = load_class->get_flags_filename =
vips_foreign_load_matrix_get_flags_filename; vips_foreign_load_matrix_get_flags_filename;
load_class->get_flags = vips_foreign_load_matrix_get_flags; load_class->get_flags = vips_foreign_load_matrix_get_flags;

View File

@ -107,7 +107,11 @@ vips__openslide_isslide( const char *filename )
int ok; int ok;
ok = 0; ok = 0;
if( (osr = openslide_open( filename )) ) { vips_error_freeze();
osr = openslide_open( filename );
vips_error_thaw();
if( osr ) {
const char *vendor; const char *vendor;
/* Generic tiled tiff images can be opened by openslide as /* Generic tiled tiff images can be opened by openslide as

View File

@ -38,6 +38,9 @@ extern "C" {
const char *vips_error_buffer( void ); const char *vips_error_buffer( void );
void vips_error_clear( void ); void vips_error_clear( void );
void vips_error_freeze( void );
void vips_error_thaw( void );
void vips_error( const char *domain, const char *fmt, ... ) void vips_error( const char *domain, const char *fmt, ... )
__attribute__((format(printf, 2, 3))); __attribute__((format(printf, 2, 3)));
void vips_verror( const char *domain, const char *fmt, va_list ap ); void vips_verror( const char *domain, const char *fmt, va_list ap );

View File

@ -110,10 +110,40 @@
#define VIPS_MAX_ERROR (10240) #define VIPS_MAX_ERROR (10240)
static char vips_error_text[VIPS_MAX_ERROR] = ""; static char vips_error_text[VIPS_MAX_ERROR] = "";
static VipsBuf vips_error_buf = VIPS_BUF_STATIC( vips_error_text ); static VipsBuf vips_error_buf = VIPS_BUF_STATIC( vips_error_text );
static int vips_error_freeze_count = 0;
#define IM_DIAGNOSTICS "IM_DIAGNOSTICS" #define IM_DIAGNOSTICS "IM_DIAGNOSTICS"
#define IM_WARNING "IM_WARNING" #define IM_WARNING "IM_WARNING"
/**
* vips_error_freeze:
*
* Stop errors being logged. Use vips_error_thaw() to unfreeze. You can
* nest freeze/thaw pairs.
*/
void
vips_error_freeze( void )
{
g_mutex_lock( vips__global_lock );
g_assert( vips_error_freeze_count >= 0 );
vips_error_freeze_count += 1;
g_mutex_unlock( vips__global_lock );
}
/**
* vips_error_thaw:
*
* Reenable error logging.
*/
void
vips_error_thaw( void )
{
g_mutex_lock( vips__global_lock );
vips_error_freeze_count -= 1;
g_assert( vips_error_freeze_count >= 0 );
g_mutex_unlock( vips__global_lock );
}
/** /**
* vips_error_buffer: * vips_error_buffer:
* *
@ -173,9 +203,12 @@ vips_verror( const char *domain, const char *fmt, va_list ap )
#endif /*VIPS_DEBUG*/ #endif /*VIPS_DEBUG*/
g_mutex_lock( vips__global_lock ); g_mutex_lock( vips__global_lock );
vips_buf_appendf( &vips_error_buf, "%s: ", domain ); g_assert( vips_error_freeze_count >= 0 );
vips_buf_vappendf( &vips_error_buf, fmt, ap ); if( !vips_error_freeze_count ) {
vips_buf_appends( &vips_error_buf, "\n" ); vips_buf_appendf( &vips_error_buf, "%s: ", domain );
vips_buf_vappendf( &vips_error_buf, fmt, ap );
vips_buf_appends( &vips_error_buf, "\n" );
}
g_mutex_unlock( vips__global_lock ); g_mutex_unlock( vips__global_lock );
if( vips__fatal ) if( vips__fatal )