diff options
-rw-r--r-- | gdk-pixbuf/ChangeLog | 7 | ||||
-rw-r--r-- | gdk-pixbuf/io-jpeg.c | 29 |
2 files changed, 23 insertions, 13 deletions
diff --git a/gdk-pixbuf/ChangeLog b/gdk-pixbuf/ChangeLog index eb3cbaa70e..2b853f6cf2 100644 --- a/gdk-pixbuf/ChangeLog +++ b/gdk-pixbuf/ChangeLog @@ -1,3 +1,10 @@ +Wed Mar 28 15:27:35 2007 Tim Janik <timj@imendio.com> + + * io-jpeg.c: applied JPEG loader fix from maemo. this fix makes sure + stop_load() doesn't forget about its return value, and it pulls the + check for infinite looping out of an else branch in load_increment() + so it runs unconditionally, fixes #397643. + 2007-03-08 Matthias Clasen <mclasen@redhat.com> * gdk-pixbuf-scaled-anim.[hc]: Implement an animation diff --git a/gdk-pixbuf/io-jpeg.c b/gdk-pixbuf/io-jpeg.c index cd11ebc9cf..462a99d1df 100644 --- a/gdk-pixbuf/io-jpeg.c +++ b/gdk-pixbuf/io-jpeg.c @@ -518,6 +518,7 @@ static gboolean gdk_pixbuf__jpeg_image_stop_load (gpointer data, GError **error) { JpegProgContext *context = (JpegProgContext *) data; + gboolean retval; g_return_val_if_fail (context != NULL, TRUE); @@ -530,12 +531,14 @@ gdk_pixbuf__jpeg_image_stop_load (gpointer data, GError **error) /* if we have an error? */ if (sigsetjmp (context->jerr.setjmp_buffer, 1)) { - jpeg_destroy_decompress (&context->cinfo); + retval = FALSE; } else { - jpeg_finish_decompress(&context->cinfo); - jpeg_destroy_decompress(&context->cinfo); + jpeg_finish_decompress (&context->cinfo); + retval = TRUE; } + jpeg_destroy_decompress (&context->cinfo); + if (context->cinfo.src) { my_src_ptr src = (my_src_ptr) context->cinfo.src; @@ -544,7 +547,7 @@ gdk_pixbuf__jpeg_image_stop_load (gpointer data, GError **error) g_free (context); - return TRUE; + return retval; } @@ -686,17 +689,17 @@ gdk_pixbuf__jpeg_image_load_increment (gpointer data, src->pub.bytes_in_buffer += num_copy; bufhd += num_copy; num_left -= num_copy; - } else { - /* did anything change from last pass, if not return */ - if (first) { - last_bytes_left = src->pub.bytes_in_buffer; - first = FALSE; - } else if (src->pub.bytes_in_buffer == last_bytes_left) - spinguard++; - else - last_bytes_left = src->pub.bytes_in_buffer; } + /* did anything change from last pass, if not return */ + if (first) { + last_bytes_left = src->pub.bytes_in_buffer; + first = FALSE; + } else if (src->pub.bytes_in_buffer == last_bytes_left) + spinguard++; + else + last_bytes_left = src->pub.bytes_in_buffer; + /* should not go through twice and not pull bytes out of buf */ if (spinguard > 2) return TRUE; |