+2006-08-17 Nickolay V. Shmyrev <nshmyrev@yandex.ru>
+
+ * backend/ev-document-factory.c:
+ (ev_document_factory_get_document):
+ * tiff/tiff-document.c: (tiff_document_finalize):
+
+ More correct handling of document loading. Fixes
+ bug #349043.
+
2006-08-14 Carlos Garcia Campos <carlosgc@gnome.org>
* backend/ev-attachment.c: (ev_attachment_save):
ev_document_factory_get_document (const char *uri, GError **error)
{
EvDocument *document;
+ int result;
document = get_document_from_uri (uri, FALSE, error);
- if (*error == NULL) {
- ev_document_load (document, uri, error);
+ if (*error != NULL) {
+ return NULL;
}
+
+ result = ev_document_load (document, uri, error);
- if (*error) {
- g_error_free (*error);
- *error = NULL;
+ if (result == FALSE || *error) {
+ if (document)
+ g_object_unref (document);
+ document = NULL;
} else {
return document;
}
+ if (*error)
+ g_error_free (*error);
+ *error = NULL;
+
document = get_document_from_uri (uri, TRUE, error);
if (*error != NULL) {
return NULL;
}
- ev_document_load (document, uri, error);
+ result = ev_document_load (document, uri, error);
+
+ if (result == FALSE || *error) {
+ if (document)
+ g_object_unref (document);
+ document = NULL;
+ }
+
+ if (result == FALSE && *error == NULL) {
+ g_set_error (error,
+ EV_DOCUMENT_ERROR,
+ 0,
+ _("Unknown MIME Type"));
+ }
return document;
}
{
TiffDocument *tiff_document = TIFF_DOCUMENT (object);
- TIFFClose (tiff_document->tiff);
- g_free (tiff_document->uri);
+ if (tiff_document->tiff)
+ TIFFClose (tiff_document->tiff);
+ if (tiff_document->uri)
+ g_free (tiff_document->uri);
G_OBJECT_CLASS (tiff_document_parent_class)->finalize (object);
}