add switches to disable rad, analyze and ppm

vips has built-in support for rad, analyze and ppm ... add configure
switches to disable these readers

useful to reduce the attack surface in some applications
This commit is contained in:
John Cupitt 2016-03-12 16:48:27 +00:00
parent 42224b6b0e
commit 6368ab0649
13 changed files with 100 additions and 9 deletions

View File

@ -18,6 +18,7 @@
- more vips_resize() tuning, a bit quicker now - more vips_resize() tuning, a bit quicker now
- better behaviour for vips_cast() shift of non-int types (thanks apacheark) - better behaviour for vips_cast() shift of non-int types (thanks apacheark)
- python .bandrank() now works like .bandjoin() - python .bandrank() now works like .bandjoin()
- switches to disable PPM, Rad and Analyze support
27/1/16 started 8.2.3 27/1/16 started 8.2.3
- fix a crash with SPARC byte-order labq vips images - fix a crash with SPARC byte-order labq vips images

View File

@ -618,6 +618,33 @@ if test x"$with_matio" != "xno"; then
]) ])
fi fi
# not external libraries, but have options to disable them, helps to
# reduce attack surface
AC_ARG_WITH([ppm],
AS_HELP_STRING([--without-ppm], [build without ppm (default: with)]))
if test x"$with_ppm" != "xno"; then
AC_DEFINE(HAVE_PPM,1,[define to build ppm support.])
with_ppm=yes
fi
AC_ARG_WITH([analyze],
AS_HELP_STRING([--without-analyze], [build without analyze (default: with)]))
if test x"$with_analyze" != "xno"; then
AC_DEFINE(HAVE_ANALYZE,1,[define to build analyze support.])
with_analyze=yes
fi
AC_ARG_WITH([radiance],
AS_HELP_STRING([--without-radiance], [build without radiance (default: with)]))
if test x"$with_radiance" != "xno"; then
AC_DEFINE(HAVE_RADIANCE,1,[define to build radiance support.])
with_radiance=yes
fi
# cfitsio # cfitsio
AC_ARG_WITH([cfitsio], AC_ARG_WITH([cfitsio],
AS_HELP_STRING([--without-cfitsio], [build without cfitsio (default: test)])) AS_HELP_STRING([--without-cfitsio], [build without cfitsio (default: test)]))
@ -911,6 +938,9 @@ gobject introspection: $found_introspection
build vips7 Python binding: $with_python build vips7 Python binding: $with_python
install vips8 Python overrides: $enable_pyvips8 install vips8 Python overrides: $enable_pyvips8
(requires pygobject-3.12.0 or later) (requires pygobject-3.12.0 or later)
build radiance support: $with_radiance
build analyze support: $with_analyze
build PPM support: $with_ppm
* optional dependencies * optional dependencies
use fftw3 for FFT: $with_fftw use fftw3 for FFT: $with_fftw

View File

@ -42,9 +42,6 @@
#include <vips/vips.h> #include <vips/vips.h>
#include "../foreign/dbh.h"
#include "../foreign/analyze2vips.h"
static VipsFormatFlags static VipsFormatFlags
analyze_flags( const char *filename ) analyze_flags( const char *filename )
{ {
@ -61,7 +58,15 @@ isanalyze( const char *filename )
int int
im_analyze2vips( const char *filename, IMAGE *out ) im_analyze2vips( const char *filename, IMAGE *out )
{ {
return( vips__analyze_read( filename, out ) ); VipsImage *t;
if( vips_analyzeload( filename, &t, NULL ) )
return( -1 );
if( vips_image_write( t, out ) ) {
g_object_unref( t );
return( -1 );
}
g_object_unref( t );
return( 0 ); return( 0 );
} }

View File

@ -50,6 +50,8 @@
#endif /*HAVE_CONFIG_H*/ #endif /*HAVE_CONFIG_H*/
#include <vips/intl.h> #include <vips/intl.h>
#ifdef HAVE_ANALYZE
#include <ctype.h> #include <ctype.h>
#include <stdio.h> #include <stdio.h>
#include <string.h> #include <string.h>
@ -594,3 +596,4 @@ vips__analyze_read( const char *filename, VipsImage *out )
return( 0 ); return( 0 );
} }
#endif /*HAVE_ANALYZE*/

View File

@ -48,6 +48,8 @@
#include <vips/buf.h> #include <vips/buf.h>
#include <vips/internal.h> #include <vips/internal.h>
#ifdef HAVE_ANALYZE
#include "analyze2vips.h" #include "analyze2vips.h"
typedef struct _VipsForeignLoadAnalyze { typedef struct _VipsForeignLoadAnalyze {
@ -142,6 +144,8 @@ vips_foreign_load_analyze_init( VipsForeignLoadAnalyze *analyze )
{ {
} }
#endif /*HAVE_ANALYZE*/
/** /**
* vips_analyzeload: * vips_analyzeload:
* @filename: file to load * @filename: file to load

View File

@ -1665,22 +1665,31 @@ vips_foreign_operation_init( void )
extern GType vips_foreign_load_gif_file_get_type( void ); extern GType vips_foreign_load_gif_file_get_type( void );
extern GType vips_foreign_load_gif_buffer_get_type( void ); extern GType vips_foreign_load_gif_buffer_get_type( void );
vips_foreign_load_rad_get_type();
vips_foreign_save_rad_get_type();
vips_foreign_load_ppm_get_type();
vips_foreign_save_ppm_get_type();
vips_foreign_load_csv_get_type(); vips_foreign_load_csv_get_type();
vips_foreign_save_csv_get_type(); vips_foreign_save_csv_get_type();
vips_foreign_load_matrix_get_type(); vips_foreign_load_matrix_get_type();
vips_foreign_save_matrix_get_type(); vips_foreign_save_matrix_get_type();
vips_foreign_print_matrix_get_type(); vips_foreign_print_matrix_get_type();
vips_foreign_load_analyze_get_type();
vips_foreign_load_raw_get_type(); vips_foreign_load_raw_get_type();
vips_foreign_save_raw_get_type(); vips_foreign_save_raw_get_type();
vips_foreign_save_raw_fd_get_type(); vips_foreign_save_raw_fd_get_type();
vips_foreign_load_vips_get_type(); vips_foreign_load_vips_get_type();
vips_foreign_save_vips_get_type(); vips_foreign_save_vips_get_type();
#ifdef HAVE_ANALYZE
vips_foreign_load_analyze_get_type();
#endif /*HAVE_ANALYZE*/
#ifdef HAVE_PPM
vips_foreign_load_ppm_get_type();
vips_foreign_save_ppm_get_type();
#endif /*HAVE_PPM*/
#ifdef HAVE_RADIANCE
vips_foreign_load_rad_get_type();
vips_foreign_save_rad_get_type();
#endif /*HAVE_RADIANCE*/
#ifdef HAVE_POPPLER #ifdef HAVE_POPPLER
vips_foreign_load_pdf_get_type(); vips_foreign_load_pdf_get_type();
vips_foreign_load_pdf_file_get_type(); vips_foreign_load_pdf_file_get_type();

View File

@ -68,6 +68,8 @@
#endif /*HAVE_CONFIG_H*/ #endif /*HAVE_CONFIG_H*/
#include <vips/intl.h> #include <vips/intl.h>
#ifdef HAVE_PPM
#include <ctype.h> #include <ctype.h>
#include <stdio.h> #include <stdio.h>
#include <string.h> #include <string.h>
@ -825,3 +827,5 @@ vips__ppm_save( VipsImage *in, const char *filename,
return( 0 ); return( 0 );
} }
#endif /*HAVE_PPM*/

View File

@ -48,6 +48,8 @@
#include <vips/buf.h> #include <vips/buf.h>
#include <vips/internal.h> #include <vips/internal.h>
#ifdef HAVE_PPM
#include "ppm.h" #include "ppm.h"
typedef struct _VipsForeignLoadPpm { typedef struct _VipsForeignLoadPpm {
@ -142,6 +144,8 @@ vips_foreign_load_ppm_init( VipsForeignLoadPpm *ppm )
{ {
} }
#endif /*HAVE_PPM*/
/** /**
* vips_ppmload: * vips_ppmload:
* @filename: file to load * @filename: file to load

View File

@ -47,6 +47,8 @@
#include <vips/vips.h> #include <vips/vips.h>
#ifdef HAVE_PPM
#include "ppm.h" #include "ppm.h"
typedef struct _VipsForeignSavePpm { typedef struct _VipsForeignSavePpm {
@ -144,6 +146,8 @@ vips_foreign_save_ppm_init( VipsForeignSavePpm *ppm )
{ {
} }
#endif /*HAVE_PPM*/
/** /**
* vips_ppmsave: * vips_ppmsave:
* @in: image to save * @in: image to save

View File

@ -127,6 +127,8 @@
#endif /*HAVE_CONFIG_H*/ #endif /*HAVE_CONFIG_H*/
#include <vips/intl.h> #include <vips/intl.h>
#ifdef HAVE_RADIANCE
#include <stdio.h> #include <stdio.h>
#include <assert.h> #include <assert.h>
#include <stdlib.h> #include <stdlib.h>
@ -1303,3 +1305,5 @@ vips__rad_save( VipsImage *in, const char *filename )
} }
const char *vips__rad_suffs[] = { ".hdr", NULL }; const char *vips__rad_suffs[] = { ".hdr", NULL };
#endif /*HAVE_RADIANCE*/

View File

@ -48,6 +48,8 @@
#include <vips/buf.h> #include <vips/buf.h>
#include <vips/internal.h> #include <vips/internal.h>
#ifdef HAVE_RADIANCE
#include "radiance.h" #include "radiance.h"
typedef struct _VipsForeignLoadRad { typedef struct _VipsForeignLoadRad {
@ -145,6 +147,8 @@ vips_foreign_load_rad_init( VipsForeignLoadRad *rad )
{ {
} }
#endif /*HAVE_RADIANCE*/
/** /**
* vips_radload: * vips_radload:
* @filename: file to load * @filename: file to load

View File

@ -47,6 +47,8 @@
#include <vips/vips.h> #include <vips/vips.h>
#ifdef HAVE_RADIANCE
#include "radiance.h" #include "radiance.h"
typedef struct _VipsForeignSaveRad { typedef struct _VipsForeignSaveRad {
@ -129,6 +131,8 @@ vips_foreign_save_rad_init( VipsForeignSaveRad *rad )
{ {
} }
#endif /*HAVE_RADIANCE*/
/** /**
* vips_radsave: * vips_radsave:
* @in: image to save * @in: image to save

View File

@ -267,6 +267,11 @@ class TestForeign(unittest.TestCase):
self.save_load("%s.webp", self.colour) self.save_load("%s.webp", self.colour)
def test_analyzeload(self): def test_analyzeload(self):
x = Vips.type_find("VipsForeign", "analyzeload")
if not x.is_instantiatable():
print("no analyze support in this vips, skipping test")
return
def analyze_valid(self, im): def analyze_valid(self, im):
a = im(10, 10) a = im(10, 10)
self.assertAlmostEqual(a[0], 3335) self.assertAlmostEqual(a[0], 3335)
@ -416,10 +421,20 @@ class TestForeign(unittest.TestCase):
self.save_load("%s.mat", self.mono) self.save_load("%s.mat", self.mono)
def test_ppm(self): def test_ppm(self):
x = Vips.type_find("VipsForeign", "ppmload")
if not x.is_instantiatable():
print("no PPM support in this vips, skipping test")
return
self.save_load("%s.ppm", self.mono) self.save_load("%s.ppm", self.mono)
self.save_load("%s.ppm", self.colour) self.save_load("%s.ppm", self.colour)
def test_rad(self): def test_rad(self):
x = Vips.type_find("VipsForeign", "radload")
if not x.is_instantiatable():
print("no Radiance support in this vips, skipping test")
return
self.save_load("%s.hdr", self.colour) self.save_load("%s.hdr", self.colour)
def test_dzsave(self): def test_dzsave(self):