]> www.fi.muni.cz Git - evince.git/blobdiff - backend/ev-document.c
use the new tiff2ps interfaces
[evince.git] / backend / ev-document.c
index 3793050d3750d4cb7b9e5874edd2df34f48f9652..3395bf7c4ac40173364190840fb53483db9fbeab 100644 (file)
@@ -23,7 +23,6 @@
 #include "ev-document.h"
 
 #include "ev-backend-marshalers.h"
 #include "ev-document.h"
 
 #include "ev-backend-marshalers.h"
-#include "ev-job-queue.h"
 
 static void ev_document_class_init (gpointer g_class);
 
 
 static void ev_document_class_init (gpointer g_class);
 
@@ -69,24 +68,6 @@ ev_document_class_init (gpointer g_class)
 {
 }
 
 {
 }
 
-#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 *
 ev_document_get_doc_mutex (void)
 {
 GMutex *
 ev_document_get_doc_mutex (void)
 {
@@ -120,10 +101,6 @@ ev_document_load (EvDocument  *document,
        LOG ("ev_document_load");
        retval = iface->load (document, uri, error);
 
        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;
 }
 
        return retval;
 }
 
@@ -226,9 +203,8 @@ ev_document_get_links (EvDocument *document,
 
 
 GdkPixbuf *
 
 
 GdkPixbuf *
-ev_document_render_pixbuf (EvDocument *document,
-                          int         page,
-                          double      scale)
+ev_document_render_pixbuf (EvDocument      *document,
+                          EvRenderContext *rc)
 {
        EvDocumentIface *iface = EV_DOCUMENT_GET_IFACE (document);
        GdkPixbuf *retval;
 {
        EvDocumentIface *iface = EV_DOCUMENT_GET_IFACE (document);
        GdkPixbuf *retval;
@@ -236,11 +212,28 @@ ev_document_render_pixbuf (EvDocument *document,
        LOG ("ev_document_render_pixbuf");
        g_assert (iface->render_pixbuf);
 
        LOG ("ev_document_render_pixbuf");
        g_assert (iface->render_pixbuf);
 
-       retval = iface->render_pixbuf (document, page, scale);
+       retval = iface->render_pixbuf (document, rc);
 
        return retval;
 }
 
 
        return retval;
 }
 
+EvOrientation
+ev_document_get_orientation (EvDocument *document)
+{
+       EvDocumentIface *iface = EV_DOCUMENT_GET_IFACE (document);
+
+       return iface->get_orientation (document);
+}
+
+void
+ev_document_set_orientation (EvDocument     *document,
+                            EvOrientation   orientation)
+{
+       EvDocumentIface *iface = EV_DOCUMENT_GET_IFACE (document);
+
+       iface->set_orientation (document, orientation);
+}
+
 void
 ev_document_info_free (EvDocumentInfo *info)
 {
 void
 ev_document_info_free (EvDocumentInfo *info)
 {
@@ -256,3 +249,22 @@ ev_document_info_free (EvDocumentInfo *info)
 
        g_free (info);
 }
 
        g_free (info);
 }
+
+
+/* Compares two rects.  returns 0 if they're equal */
+#define EPSILON 0.0000001
+
+gint
+ev_rect_cmp (EvRectangle *a,
+            EvRectangle *b)
+{
+       if (a == b)
+               return 0;
+       if (a == NULL || b == NULL)
+               return 1;
+
+       return ! ((ABS (a->x1 - b->x1) < EPSILON) &&
+                 (ABS (a->y1 - b->y1) < EPSILON) &&
+                 (ABS (a->x2 - b->x2) < EPSILON) &&
+                 (ABS (a->y2 - b->y2) < EPSILON));
+}