]> www.fi.muni.cz Git - evince.git/blobdiff - backend/ev-document.c
Check for incorrect dvi files. Fix parsing dvi on AMD64 platform. Thanks
[evince.git] / backend / ev-document.c
index 6aa0504cfbca4af500e3fa3dc5d171ae75f8fb2e..9bccc4cab7ee2d09ed99e5024ac3144a6cea4456 100644 (file)
@@ -23,7 +23,6 @@
 #include "ev-document.h"
 
 #include "ev-backend-marshalers.h"
-#include "ev-job-queue.h"
 
 static void ev_document_class_init (gpointer g_class);
 
@@ -67,30 +66,6 @@ ev_document_error_quark (void)
 static void
 ev_document_class_init (gpointer g_class)
 {
-       g_object_interface_install_property (g_class,
-                               g_param_spec_string ("title",
-                                                    "Document Title",
-                                                    "The title of the document",
-                                                    NULL,
-                                                    G_PARAM_READABLE));
-}
-
-#define PAGE_CACHE_STRING "ev-page-cache"
-
-EvPageCache *
-ev_document_get_page_cache (EvDocument *document)
-{
-       EvPageCache *page_cache;
-
-       g_return_val_if_fail (EV_IS_DOCUMENT (document), NULL);
-
-       page_cache = g_object_get_data (G_OBJECT (document), PAGE_CACHE_STRING);
-       if (page_cache == NULL) {
-               page_cache = _ev_page_cache_new (document);
-               g_object_set_data_full (G_OBJECT (document), PAGE_CACHE_STRING, page_cache, g_object_unref);
-       }
-
-       return page_cache;
 }
 
 GMutex *
@@ -102,6 +77,19 @@ ev_document_get_doc_mutex (void)
        return ev_doc_mutex;
 }
 
+void
+ev_document_doc_mutex_lock (void)
+{
+       g_mutex_lock (ev_document_get_doc_mutex ());
+}
+
+void
+ev_document_doc_mutex_unlock (void)
+{
+       g_mutex_unlock (ev_document_get_doc_mutex ());
+}
+
+
 
 gboolean
 ev_document_load (EvDocument  *document,
@@ -113,10 +101,6 @@ ev_document_load (EvDocument  *document,
        LOG ("ev_document_load");
        retval = iface->load (document, uri, error);
 
-       /* Call this to make the initial cached copy */
-       if (retval)
-               ev_document_get_page_cache (document);
-
        return retval;
 }
 
@@ -134,17 +118,6 @@ ev_document_save (EvDocument  *document,
        return retval;
 }
 
-char *
-ev_document_get_title (EvDocument  *document)
-{
-       char *title;
-
-       LOG ("ev_document_get_title");
-       g_object_get (document, "title", &title, NULL);
-
-       return title;
-}
-
 int
 ev_document_get_n_pages (EvDocument  *document)
 {
@@ -190,6 +163,14 @@ ev_document_can_get_text (EvDocument  *document)
        return iface->can_get_text (document);
 }
 
+EvDocumentInfo *
+ev_document_get_info (EvDocument *document)
+{
+       EvDocumentIface *iface = EV_DOCUMENT_GET_IFACE (document);
+
+       return iface->get_info (document);
+}
+
 char *
 ev_document_get_text (EvDocument  *document,
                      int          page,
@@ -237,21 +218,35 @@ ev_document_render_pixbuf (EvDocument *document,
        return retval;
 }
 
-
-EvDocumentInfo *
-ev_document_render_get_info (EvDocument *document)
+EvOrientation
+ev_document_get_orientation (EvDocument *document)
 {
        EvDocumentIface *iface = EV_DOCUMENT_GET_IFACE (document);
-       EvDocumentInfo *retval = NULL;
 
-       LOG ("ev_document_render_pixbuf");
+       return iface->get_orientation (document);
+}
+
+void
+ev_document_set_orientation (EvDocument     *document,
+                            EvOrientation   orientation)
+{
+       EvDocumentIface *iface = EV_DOCUMENT_GET_IFACE (document);
 
-       if (iface->get_info != NULL)
-               retval = iface->get_info (document);
+       iface->set_orientation (document, orientation);
+}
 
-       if (retval == NULL)
-               retval = g_new0 (EvDocumentInfo, 1);
+void
+ev_document_info_free (EvDocumentInfo *info)
+{
+       if (info == NULL)
+               return;
 
-       return retval;
+       g_free (info->title);
+       g_free (info->format);
+       g_free (info->author);
+       g_free (info->subject);
+       g_free (info->keywords);
+       g_free (info->security);
 
+       g_free (info);
 }