Merge branch '8.5'
This commit is contained in:
commit
5c6979cdcb
@ -10,6 +10,7 @@
|
|||||||
23/4/17 started 8.5.5
|
23/4/17 started 8.5.5
|
||||||
- doc polishing
|
- doc polishing
|
||||||
- more improvements for truncated PNG files, thanks juyunsang
|
- more improvements for truncated PNG files, thanks juyunsang
|
||||||
|
- improve corrupted jpg handling, thanks juyunsang
|
||||||
|
|
||||||
23/4/17 started 8.5.4
|
23/4/17 started 8.5.4
|
||||||
- don't depend on image width when setting n_lines, thanks kleisauke
|
- don't depend on image width when setting n_lines, thanks kleisauke
|
||||||
|
@ -193,7 +193,7 @@ vips_foreign_load_csv_init( VipsForeignLoadCsv *csv )
|
|||||||
* * @lines: read this many lines from file
|
* * @lines: read this many lines from file
|
||||||
* * @whitespace: set of whitespace characters
|
* * @whitespace: set of whitespace characters
|
||||||
* * @separator: set of separator characters
|
* * @separator: set of separator characters
|
||||||
* * @fail: %gboolean, fail on warnings
|
* * @fail: %gboolean, fail on errors
|
||||||
*
|
*
|
||||||
* Load a CSV (comma-separated values) file. The output image is always 1
|
* Load a CSV (comma-separated values) file. The output image is always 1
|
||||||
* band (monochrome), #VIPS_FORMAT_DOUBLE. Use vips_bandfold() to turn
|
* band (monochrome), #VIPS_FORMAT_DOUBLE. Use vips_bandfold() to turn
|
||||||
@ -221,7 +221,7 @@ vips_foreign_load_csv_init( VipsForeignLoadCsv *csv )
|
|||||||
* @separator sets the characters that separate fields.
|
* @separator sets the characters that separate fields.
|
||||||
* Default ;,<emphasis>tab</emphasis>. Separators are never run together.
|
* Default ;,<emphasis>tab</emphasis>. Separators are never run together.
|
||||||
*
|
*
|
||||||
* Setting @fail to %TRUE makes the reader fail on any warnings.
|
* Setting @fail to %TRUE makes the reader fail on any errors.
|
||||||
*
|
*
|
||||||
* See also: vips_image_new_from_file(), vips_bandfold().
|
* See also: vips_image_new_from_file(), vips_bandfold().
|
||||||
*
|
*
|
||||||
|
@ -1016,7 +1016,7 @@ vips_foreign_load_class_init( VipsForeignLoadClass *class )
|
|||||||
|
|
||||||
VIPS_ARG_BOOL( class, "fail", 11,
|
VIPS_ARG_BOOL( class, "fail", 11,
|
||||||
_( "Fail" ),
|
_( "Fail" ),
|
||||||
_( "Fail on first warning" ),
|
_( "Fail on first error" ),
|
||||||
VIPS_ARGUMENT_OPTIONAL_INPUT,
|
VIPS_ARGUMENT_OPTIONAL_INPUT,
|
||||||
G_STRUCT_OFFSET( VipsForeignLoad, fail ),
|
G_STRUCT_OFFSET( VipsForeignLoad, fail ),
|
||||||
FALSE );
|
FALSE );
|
||||||
|
@ -85,6 +85,8 @@
|
|||||||
* - don't warn for missing exif res, since we fall back to jfif now
|
* - don't warn for missing exif res, since we fall back to jfif now
|
||||||
* 17/1/17
|
* 17/1/17
|
||||||
* - invalidate operation on read error
|
* - invalidate operation on read error
|
||||||
|
* 12/5/17
|
||||||
|
* - fail aborts on error, not warning
|
||||||
*/
|
*/
|
||||||
|
|
||||||
/*
|
/*
|
||||||
@ -148,7 +150,7 @@ typedef struct _ReadJpeg {
|
|||||||
*/
|
*/
|
||||||
int shrink;
|
int shrink;
|
||||||
|
|
||||||
/* Fail on warnings.
|
/* Fail on errors.
|
||||||
*/
|
*/
|
||||||
gboolean fail;
|
gboolean fail;
|
||||||
|
|
||||||
@ -526,10 +528,10 @@ read_jpeg_generate( VipsRegion *or,
|
|||||||
|
|
||||||
int y;
|
int y;
|
||||||
|
|
||||||
#ifdef DEBUG
|
#ifdef DEBUG_VERBOSE
|
||||||
printf( "read_jpeg_generate: %p line %d, %d rows\n",
|
printf( "read_jpeg_generate: %p line %d, %d rows\n",
|
||||||
g_thread_self(), r->top, r->height );
|
g_thread_self(), r->top, r->height );
|
||||||
#endif /*DEBUG*/
|
#endif /*DEBUG_VERBOSE*/
|
||||||
|
|
||||||
VIPS_GATE_START( "read_jpeg_generate: work" );
|
VIPS_GATE_START( "read_jpeg_generate: work" );
|
||||||
|
|
||||||
@ -565,23 +567,14 @@ read_jpeg_generate( VipsRegion *or,
|
|||||||
if( setjmp( jpeg->eman.jmp ) ) {
|
if( setjmp( jpeg->eman.jmp ) ) {
|
||||||
VIPS_GATE_STOP( "read_jpeg_generate: work" );
|
VIPS_GATE_STOP( "read_jpeg_generate: work" );
|
||||||
|
|
||||||
|
#ifdef DEBUG
|
||||||
|
printf( "read_jpeg_generate: lonjmp() exit\n" );
|
||||||
|
#endif /*DEBUG*/
|
||||||
|
|
||||||
|
if( jpeg->fail )
|
||||||
return( -1 );
|
return( -1 );
|
||||||
}
|
|
||||||
|
|
||||||
/* If --fail is set, we make read fail on any warnings. This will stop
|
return( 0 );
|
||||||
* on any errors from the previous jpeg_read_scanlines().
|
|
||||||
*/
|
|
||||||
if( jpeg->eman.pub.num_warnings > 0 &&
|
|
||||||
jpeg->fail ) {
|
|
||||||
VIPS_GATE_STOP( "read_jpeg_generate: work" );
|
|
||||||
|
|
||||||
/* Only fail once.
|
|
||||||
*/
|
|
||||||
jpeg->eman.pub.num_warnings = 0;
|
|
||||||
|
|
||||||
*stop = TRUE;
|
|
||||||
|
|
||||||
return( -1 );
|
|
||||||
}
|
}
|
||||||
|
|
||||||
for( y = 0; y < r->height; y++ ) {
|
for( y = 0; y < r->height; y++ ) {
|
||||||
|
@ -328,7 +328,7 @@ vips_foreign_load_jpeg_buffer_init( VipsForeignLoadJpegBuffer *buffer )
|
|||||||
* Optional arguments:
|
* Optional arguments:
|
||||||
*
|
*
|
||||||
* * @shrink: %gint, shrink by this much on load
|
* * @shrink: %gint, shrink by this much on load
|
||||||
* * @fail: %gboolean, fail on warnings
|
* * @fail: %gboolean, fail on errors
|
||||||
* * @autorotate: %gboolean, use exif Orientation tag to rotate the image
|
* * @autorotate: %gboolean, use exif Orientation tag to rotate the image
|
||||||
* during load
|
* during load
|
||||||
*
|
*
|
||||||
@ -339,7 +339,7 @@ vips_foreign_load_jpeg_buffer_init( VipsForeignLoadJpegBuffer *buffer )
|
|||||||
* are 1, 2, 4 and 8. Shrinking during read is very much faster than
|
* are 1, 2, 4 and 8. Shrinking during read is very much faster than
|
||||||
* decompressing the whole image and then shrinking later.
|
* decompressing the whole image and then shrinking later.
|
||||||
*
|
*
|
||||||
* Setting @fail to %TRUE makes the JPEG reader fail on any warnings.
|
* Setting @fail to %TRUE makes the JPEG reader fail on any errors.
|
||||||
* This can be useful for detecting truncated files, for example. Normally
|
* This can be useful for detecting truncated files, for example. Normally
|
||||||
* reading these produces a warning, but no fatal error.
|
* reading these produces a warning, but no fatal error.
|
||||||
*
|
*
|
||||||
@ -406,7 +406,7 @@ vips_jpegload( const char *filename, VipsImage **out, ... )
|
|||||||
* Optional arguments:
|
* Optional arguments:
|
||||||
*
|
*
|
||||||
* * @shrink: %gint, shrink by this much on load
|
* * @shrink: %gint, shrink by this much on load
|
||||||
* * @fail: %gboolean, fail on warnings
|
* * @fail: %gboolean, fail on errors
|
||||||
* * @autorotate: %gboolean, use exif Orientation tag to rotate the image
|
* * @autorotate: %gboolean, use exif Orientation tag to rotate the image
|
||||||
* during load
|
* during load
|
||||||
*
|
*
|
||||||
|
@ -38,9 +38,9 @@
|
|||||||
*/
|
*/
|
||||||
|
|
||||||
/*
|
/*
|
||||||
*/
|
|
||||||
#define DEBUG_VERBOSE
|
#define DEBUG_VERBOSE
|
||||||
#define DEBUG
|
#define DEBUG
|
||||||
|
*/
|
||||||
|
|
||||||
#ifdef HAVE_CONFIG_H
|
#ifdef HAVE_CONFIG_H
|
||||||
#include <config.h>
|
#include <config.h>
|
||||||
|
Loading…
Reference in New Issue
Block a user