Web   ·   Wiki   ·   Activities   ·   Blog   ·   Lists   ·   Chat   ·   Meeting   ·   Bugs   ·   Git   ·   Translate   ·   Archive   ·   People   ·   Donate
summaryrefslogtreecommitdiffstats
path: root/libdocument/ev-document-factory.c
diff options
context:
space:
mode:
authorCarlos Garcia Campos <carlosgc@gnome.org>2008-01-25 12:30:28 (GMT)
committer Carlos Garcia Campos <carlosgc@src.gnome.org>2008-01-25 12:30:28 (GMT)
commite912e532fd67211aa87ac79414efb30f30a00fab (patch)
tree7a4a5fd318af1bcae3659ffea4e0cd3ed0eae4a8 /libdocument/ev-document-factory.c
parentefb48b86f60fbaa6ab7e6cb1edb9b1994f5575b3 (diff)
Port to gio and drop gnome-vfs dependency. Fixes bug #510401. Based on
2008-01-25 Carlos Garcia Campos <carlosgc@gnome.org> * configure.ac: * backend/comics/comics-document.c: (comics_document_load): * libdocument/ev-attachment.[ch]: (ev_attachment_finalize), (ev_attachment_set_property), (ev_attachment_init), (ev_attachment_save), (ev_attachment_launch_app), (ev_attachment_open): * libdocument/ev-document-factory.c: (get_document_from_uri): * libdocument/ev-file-helpers.[ch]: (ev_tmp_file_get), (ev_tmp_file_unlink), (ev_tmp_uri_unlink), (ev_xfer_uri_simple),: * shell/ev-jobs.c: * shell/ev-password.c: (ev_password_dialog_set_property), (ev_password_dialog_save_password): * shell/ev-sidebar-attachments.c: (ev_sidebar_attachments_drag_data_get): * shell/ev-window-title.c: (get_filename_from_uri): * shell/ev-window.c: (ev_window_clear_temp_file), (ev_window_load_job_cb), (window_open_file_copy_ready_cb), (ev_window_open_uri), (window_save_file_copy_ready_cb), (ev_window_save_remote), (ev_window_cmd_save_as), (launch_action), (launch_external_uri), (image_save_dialog_response_cb), (attachment_save_dialog_response_cb): * shell/main.c: (load_files), (load_files_remote), (main): * thumbnailer/evince-thumbnailer.c: (main): Port to gio and drop gnome-vfs dependency. Fixes bug #510401. Based on patch by Cosimo Cecchi. svn path=/trunk/; revision=2858
Diffstat (limited to 'libdocument/ev-document-factory.c')
-rw-r--r--libdocument/ev-document-factory.c50
1 files changed, 25 insertions, 25 deletions
diff --git a/libdocument/ev-document-factory.c b/libdocument/ev-document-factory.c
index 21e0b4a..1bc67ef 100644
--- a/libdocument/ev-document-factory.c
+++ b/libdocument/ev-document-factory.c
@@ -23,11 +23,9 @@
#endif
#include <string.h>
+#include <gio/gio.h>
#include <glib/gstdio.h>
#include <glib/gi18n.h>
-#include <libgnomevfs/gnome-vfs-mime-utils.h>
-#include <libgnomevfs/gnome-vfs-file-info.h>
-#include <libgnomevfs/gnome-vfs-ops.h>
#include <gtk/gtkfilechooserdialog.h>
#include "ev-backends-manager.h"
@@ -112,55 +110,57 @@ get_document_from_uri (const char *uri,
GError **error)
{
EvDocument *document = NULL;
- GnomeVFSFileInfo *info;
- GnomeVFSResult result;
+ GFile *file;
+ GFileInfo *file_info;
+ const gchar *mime_type;
*compression = EV_COMPRESSION_NONE;
- 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) {
+ file = g_file_new_for_uri (uri);
+ file_info = g_file_query_info (file,
+ G_FILE_ATTRIBUTE_STANDARD_CONTENT_TYPE,
+ 0, NULL, NULL);
+ g_object_unref (file);
+
+ if (file_info == NULL) {
g_set_error (error,
EV_DOCUMENT_ERROR,
0,
- gnome_vfs_result_to_string (result));
- gnome_vfs_file_info_unref (info);
+ _("Failed to get info for document"));
return NULL;
- }
-
- if (info->mime_type == NULL) {
+ }
+ mime_type = g_file_info_get_content_type (file_info);
+
+ if (mime_type == NULL) {
g_set_error (error,
EV_DOCUMENT_ERROR,
0,
_("Unknown MIME Type"));
- gnome_vfs_file_info_unref (info);
+ g_object_unref (file_info);
return NULL;
}
#ifdef ENABLE_PIXBUF
- if (mime_type_supported_by_gdk_pixbuf (info->mime_type)) {
+ if (mime_type_supported_by_gdk_pixbuf (mime_type))
document = ev_backends_manager_get_document ("image/*");
- } else
- document = ev_backends_manager_get_document (info->mime_type);
+ else
+ document = ev_backends_manager_get_document (mime_type);
#else
- document = ev_backends_manager_get_document (info->mime_type);
+ document = ev_backends_manager_get_document (mime_type);
#endif /* ENABLE_PIXBUF */
if (document == NULL) {
g_set_error (error,
EV_DOCUMENT_ERROR,
0,
- _("Unhandled MIME type: ā€œ%sā€"), info->mime_type);
- gnome_vfs_file_info_unref (info);
+ _("Unhandled MIME type: ā€œ%sā€"), mime_type);
+ g_object_unref (file_info);
return NULL;
}
- *compression = get_compression_from_mime_type (info->mime_type);
+ *compression = get_compression_from_mime_type (mime_type);
- gnome_vfs_file_info_unref (info);
+ g_object_unref (file_info);
return document;
}