]> www.fi.muni.cz Git - evince.git/blobdiff - shell/ev-window-title.c
Added. Returns whether the animation has everything necessary to run. Do
[evince.git] / shell / ev-window-title.c
index 574ace3ea67f12c408dce61a0a90cba6f6f68d49..b43775a62e122b1af4932b0f2358c88106016173 100644 (file)
  * Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA 02111-1307, USA.
  */
 
+#include <config.h>
 #include "ev-window-title.h"
-#include "ev-document-factory.h"
+#include "ev-backends-manager.h"
 
+#include <gio/gio.h>
 #include <glib/gi18n.h>
-#include <libgnomevfs/gnome-vfs-utils.h>
+
+/* 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,8 @@ 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" }
 };
 
@@ -58,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;
 }
@@ -72,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);
@@ -99,27 +107,29 @@ ev_window_title_update (EvWindowTitle *window_title)
        EvPageCache *page_cache;
 
        if (window_title->document != NULL) {
-               const char *doc_title;
+               char *doc_title;
 
                page_cache = ev_page_cache_get (window_title->document);
                g_return_if_fail (page_cache != NULL);
-               doc_title = ev_page_cache_get_title (page_cache);
+               doc_title = (char *)ev_page_cache_get_title (page_cache);
 
                /* Make sure we get a valid title back */
-               if (doc_title && doc_title[0] != '\000' &&
-                   g_utf8_validate (doc_title, -1, NULL)) {
-                       title = g_strdup (doc_title);
+               if (doc_title != NULL) {
+                       doc_title = g_strstrip (doc_title);
+
+                       if (doc_title[0] != '\0' &&
+                           g_utf8_validate (doc_title, -1, NULL)) {
+                               title = g_strdup (doc_title);
+                       }
                }
        }
 
-       if (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) {
@@ -137,6 +147,8 @@ ev_window_title_update (EvWindowTitle *window_title)
                g_free (password_title);
                break;
        }
+
+       g_free (title);
 }
 
 void