summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
-rw-r--r--gdk-pixbuf/ChangeLog9
-rw-r--r--gdk-pixbuf/io-tiff.c30
2 files changed, 32 insertions, 7 deletions
diff --git a/gdk-pixbuf/ChangeLog b/gdk-pixbuf/ChangeLog
index 6d0003d301..f72862b77d 100644
--- a/gdk-pixbuf/ChangeLog
+++ b/gdk-pixbuf/ChangeLog
@@ -1,3 +1,12 @@
+2002-07-06 Matthias Clasen <maclas@gmx.de>
+
+ * io-tiff.c (tiff_set_error): Handle global_error == NULL
+ better.
+ (tiff_image_parse): Don't trust TIFFRGBAImageBegin to set
+ the "put" routine. (Fixes #87384)
+ (gdk_pixbuf__tiff_image_stop_load): Don't call TIFFClose too
+ early.
+
2002-07-02 Matthias Clasen <maclas@gmx.de>
Miscellaneous bmp loader fixes (#85448, #86286, #86287):
diff --git a/gdk-pixbuf/io-tiff.c b/gdk-pixbuf/io-tiff.c
index a8365fa961..deae12bd77 100644
--- a/gdk-pixbuf/io-tiff.c
+++ b/gdk-pixbuf/io-tiff.c
@@ -119,16 +119,20 @@ tiff_set_error (GError **error,
/* Take the error message from libtiff and merge it with
* some context we provide.
*/
- g_set_error (error,
- GDK_PIXBUF_ERROR,
- error_code,
- "%s%s%s",
- msg, global_error ? ": " : "", global_error);
-
if (global_error) {
+ g_set_error (error,
+ GDK_PIXBUF_ERROR,
+ error_code,
+ "%s%s%s", msg, ": ", global_error);
+
g_free (global_error);
global_error = NULL;
}
+ else {
+ g_set_error (error,
+ GDK_PIXBUF_ERROR,
+ error_code, msg);
+ }
}
@@ -256,6 +260,14 @@ tiff_image_parse (TIFF *tiff, TiffContext *context, GError **error)
return NULL;
}
+ if (img.put.any == NULL) {
+ tiff_set_error (error,
+ GDK_PIXBUF_ERROR_FAILED,
+ _("Unsupported TIFF variant"));
+ g_object_unref (pixbuf);
+ return NULL;
+ }
+
if (img.isContig) {
tiff_put_contig = img.put.contig;
img.put.contig = put_contig;
@@ -476,16 +488,20 @@ gdk_pixbuf__tiff_image_stop_load (gpointer data,
if (pixbuf)
g_object_unref (pixbuf);
retval = pixbuf != NULL;
- TIFFClose (tiff);
if (global_error)
{
tiff_set_error (error,
GDK_PIXBUF_ERROR_FAILED,
_("Failed to load TIFF image"));
+ tiff_pop_handlers ();
+
retval = FALSE;
}
}
+ if (tiff)
+ TIFFClose (tiff);
+
g_assert (!global_error);
g_free (context->buffer);