X-Git-Url: https://www.fi.muni.cz/~kas/git//home/kas/public_html/git/?a=blobdiff_plain;f=shell%2Fev-document-types.c;h=7133295285ffa796d4eeb1d85e5085ec7709e195;hb=0b77ab6efe83e32698b0f1390916c1a7d7738261;hp=a373d18180b9e81c195fbcf11eaef1caaeaa64f3;hpb=a5e3f1314e7e27fb0e765b3b9b8e1deb92c7c536;p=evince.git diff --git a/shell/ev-document-types.c b/shell/ev-document-types.c index a373d181..71332952 100644 --- a/shell/ev-document-types.c +++ b/shell/ev-document-types.c @@ -27,6 +27,7 @@ /* The various document type backends: */ #include "ev-poppler.h" #include "pixbuf-document.h" +#include "tiff-document.h" #include "ps-document.h" #ifdef ENABLE_DVI #include "dvi-document.h" @@ -36,6 +37,7 @@ #endif #include +#include #include #include #include @@ -56,6 +58,11 @@ const EvDocumentType document_types[] = { {"application/x-gzpostscript", ps_document_get_type}, {"image/x-eps", ps_document_get_type}, +#ifdef ENABLE_TIFF + /* Tiff: */ + {"image/tiff", tiff_document_get_type}, +#endif + #ifdef ENABLE_DJVU /* djvu: */ {"image/vnd.djvu", djvu_document_get_type}, @@ -105,32 +112,13 @@ mime_type_supported_by_gdk_pixbuf (const gchar *mime_type) return retval; } -static char * -get_slow_mime_type (const char *uri) -{ - GnomeVFSFileInfo *info; - char *mime_type; - GnomeVFSResult result; - - info = gnome_vfs_file_info_new (); - result = gnome_vfs_get_file_info (uri, info, - GNOME_VFS_FILE_INFO_GET_MIME_TYPE | - GNOME_VFS_FILE_INFO_FORCE_SLOW_MIME_TYPE | - GNOME_VFS_FILE_INFO_FOLLOW_LINKS); - if (info->mime_type == NULL || result != GNOME_VFS_OK) { - mime_type = NULL; - } else { - mime_type = g_strdup (info->mime_type); - } - gnome_vfs_file_info_unref (info); - - return mime_type; -} static GType -get_document_type_from_mime (const char *mime_type) +ev_document_type_from_from_mime (const char *mime_type) { int i; + + g_return_val_if_fail (mime_type, G_TYPE_INVALID); for (i = 0; i < G_N_ELEMENTS (document_types); i++) { if (strcmp (mime_type, document_types[i].mime_type) == 0) { @@ -146,32 +134,82 @@ get_document_type_from_mime (const char *mime_type) return G_TYPE_INVALID; } -GType -ev_document_type_lookup (const char *uri, char **mime_type) +/** + * ev_document_type_get_type: + * @uri: String with uri + * @slow: Do we need to check slow gnome-vfs mime type + * @mime_type: If we've found handled type, the mime_type string is returned here. + * @error: Information about error occured + * + * Return value: G_TYPE_INVALID on error, G_TYPE_NONE when we are not sure about + * mime type, and type of EvDocument implementation when we've found document. + **/ +static GType +ev_document_type_get_type (const char *uri, gboolean slow, gchar **mime_type, GError **error) { - GType type = G_TYPE_INVALID; - char *mime; - - g_return_val_if_fail (uri, G_TYPE_INVALID); + GnomeVFSFileInfo *info; + GnomeVFSResult result; - mime = gnome_vfs_get_mime_type (uri); - if (mime) { - type = get_document_type_from_mime (mime); + GType type = G_TYPE_INVALID; + + info = gnome_vfs_file_info_new (); + result = gnome_vfs_get_file_info (uri, info, + GNOME_VFS_FILE_INFO_GET_MIME_TYPE | + GNOME_VFS_FILE_INFO_FOLLOW_LINKS | + (slow ? GNOME_VFS_FILE_INFO_FORCE_SLOW_MIME_TYPE : 0)); + if (result != GNOME_VFS_OK) { + g_set_error (error, + EV_DOCUMENT_ERROR, + 0, + gnome_vfs_result_to_string (result)); + gnome_vfs_file_info_unref (info); + return G_TYPE_INVALID; + } + + if (info->mime_type == NULL) { + g_set_error (error, + EV_DOCUMENT_ERROR, + 0, + _("Unknown MIME Type")); + gnome_vfs_file_info_unref (info); + return slow ? G_TYPE_INVALID : G_TYPE_NONE; } - + + type = ev_document_type_from_from_mime (info->mime_type); + if (type == G_TYPE_INVALID) { - g_free (mime); - mime = get_slow_mime_type (uri); - if (mime) { - type = get_document_type_from_mime (mime); - } + g_set_error (error, + EV_DOCUMENT_ERROR, + 0, + _("Unhandled MIME type: '%s'"), info->mime_type); + gnome_vfs_file_info_unref (info); + return slow ? G_TYPE_INVALID : G_TYPE_NONE; + } + + if (mime_type != NULL) { + *mime_type = g_strdup (info->mime_type); } + gnome_vfs_file_info_unref (info); + + return type; +} - if (mime_type) { - *mime_type = mime; - } else { - g_free (mime); +GType +ev_document_type_lookup (const char *uri, gchar **mime_type, GError **error) +{ + GType type = G_TYPE_INVALID; + + type = ev_document_type_get_type (uri, FALSE, mime_type, error); + + if (type != G_TYPE_NONE) + return type; + + if (error) { + g_error_free (*error); + *error = NULL; } + type = ev_document_type_get_type (uri, TRUE, mime_type, error); + return type; }