X-Git-Url: https://www.fi.muni.cz/~kas/git//home/kas/public_html/git/?a=blobdiff_plain;f=shell%2Fev-window-title.c;h=b43775a62e122b1af4932b0f2358c88106016173;hb=f675370b1c2f1e29dfb3a3b97eda5d46f6a4a4ae;hp=64508e000362ad9e235f507df1540408c6961a23;hpb=fef2ee9eb19800b5a2bb4e7e0c97d90e84edd9af;p=evince.git diff --git a/shell/ev-window-title.c b/shell/ev-window-title.c index 64508e00..b43775a6 100644 --- a/shell/ev-window-title.c +++ b/shell/ev-window-title.c @@ -17,16 +17,21 @@ * Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA 02111-1307, USA. */ +#include #include "ev-window-title.h" -#include "ev-document-factory.h" +#include "ev-backends-manager.h" +#include #include -#include + +/* Known backends (for bad extensions fix) */ +#define EV_BACKEND_PS "psdocument" +#define EV_BACKEND_PDF "pdfdocument" typedef struct { - EvBackend backend; - const char *ext; + const gchar *backend; + const gchar *ext; } BadExtensionEntry; struct _EvWindowTitle @@ -40,6 +45,7 @@ struct _EvWindowTitle static const BadExtensionEntry bad_extensions[] = { { EV_BACKEND_PS, ".dvi" }, { EV_BACKEND_PDF, ".doc" }, + { EV_BACKEND_PDF, ".dvi" }, { EV_BACKEND_PDF, ".indd" }, { EV_BACKEND_PDF, ".rtf" } }; @@ -59,12 +65,12 @@ ev_window_title_new (EvWindow *window) static char * get_filename_from_uri (const char *uri) { + GFile *file; char *filename; - char *display_name; - - display_name = gnome_vfs_format_uri_for_display (uri); - filename = g_path_get_basename (display_name); - g_free (display_name); + + file = g_file_new_for_uri (uri); + filename = g_file_get_basename (file); + g_object_unref (file); return filename; } @@ -73,12 +79,13 @@ get_filename_from_uri (const char *uri) Let's show the filename in this case */ static void ev_window_title_sanitize_extension (EvWindowTitle *window_title, char **title) { - EvBackend backend; + const gchar *backend; int i; - backend = ev_document_factory_get_backend (window_title->document); + backend = ev_backends_manager_get_document_module_name (window_title->document); + for (i = 0; i < G_N_ELEMENTS (bad_extensions); i++) { - if (bad_extensions[i].backend == backend && + if (g_ascii_strcasecmp (bad_extensions[i].backend, backend) == 0 && g_str_has_suffix (*title, bad_extensions[i].ext)) { char *new_title; char *filename = get_filename_from_uri (window_title->uri); @@ -119,12 +126,10 @@ ev_window_title_update (EvWindowTitle *window_title) if (title && window_title->uri) { ev_window_title_sanitize_extension (window_title, &title); - } else { - if (window_title->uri) { - title = get_filename_from_uri (window_title->uri); - } else { - title = g_strdup (_("Document Viewer")); - } + } else if (window_title->uri) { + title = get_filename_from_uri (window_title->uri); + } else if (!title) { + title = g_strdup (_("Document Viewer")); } for (p = title; *p; ++p) { @@ -142,6 +147,8 @@ ev_window_title_update (EvWindowTitle *window_title) g_free (password_title); break; } + + g_free (title); } void