]> www.fi.muni.cz Git - evince.git/blobdiff - backend/ev-page-cache.c
Do not draw the border in fulscreen
[evince.git] / backend / ev-page-cache.c
index 08d1be459029c4414cc8e1879b703d7560328b44..46ecbc170045e82b1fdb40eb239117d13ab5b60c 100644 (file)
@@ -5,8 +5,8 @@
 
 typedef struct _EvPageCacheInfo
 {
-       gint width;
-       gint height;
+       double width;
+       double height;
 }
 EvPageCacheInfo;
 
@@ -21,8 +21,8 @@ struct _EvPageCache
        char **page_labels;
 
        gboolean uniform;
-       gint uniform_width;
-       gint uniform_height;
+       double uniform_width;
+       double uniform_height;
 
        EvPageCacheInfo *size_cache;
 };
@@ -51,7 +51,7 @@ G_DEFINE_TYPE (EvPageCache, ev_page_cache, G_TYPE_OBJECT)
 static void
 ev_page_cache_init (EvPageCache *page_cache)
 {
-       page_cache->current_page = 0;
+       page_cache->current_page = -1;
 }
 
 static void
@@ -105,10 +105,9 @@ _ev_page_cache_new (EvDocument *document)
        page_cache->title = ev_document_get_title (document);
        page_cache->page_labels = g_new0 (char *, page_cache->n_pages);
 
-       ev_document_set_scale (document, 1.0);
        for (i = 0; i < page_cache->n_pages; i++) {
-               gint page_width = 0;
-               gint page_height = 0;
+               double page_width = 0;
+               double page_height = 0;
 
                ev_document_get_page_size (document, i, &page_width, &page_height);
                page_cache->page_labels[i] = ev_document_get_page_label (document, i);
@@ -124,17 +123,17 @@ _ev_page_cache_new (EvDocument *document)
 
                        page_cache->size_cache = g_new0 (EvPageCacheInfo, page_cache->n_pages);
 
-                       for (j = 1; j < i; j++) {
-                               info = &(page_cache->size_cache [j - 1]);
-                               info->width = page_width;
-                               info->height = page_height;
+                       for (j = 0; j < i; j++) {
+                               info = &(page_cache->size_cache [j]);
+                               info->width = page_cache->uniform_width;
+                               info->height = page_cache->uniform_height;
                        }
                        page_cache->uniform = FALSE;
 
                }
 
                if (! page_cache->uniform) {
-                       info = &(page_cache->size_cache [i - 1]);
+                       info = &(page_cache->size_cache [i]);
 
                        info->width = page_width;
                        info->height = page_height;
@@ -142,11 +141,8 @@ _ev_page_cache_new (EvDocument *document)
        }
 
        /* make some sanity check assertions */
-       g_assert (page_cache->n_pages > 0);
        if (! page_cache->uniform)
                g_assert (page_cache->size_cache != NULL);
-       if (page_cache->uniform)
-               g_assert (page_cache->uniform_width > 0 && page_cache->uniform_height > 0);
 
        g_mutex_unlock (EV_DOC_MUTEX);
 
@@ -291,7 +287,7 @@ ev_page_cache_next_page (EvPageCache *page_cache)
 {
        g_return_val_if_fail (EV_IS_PAGE_CACHE (page_cache), FALSE);
 
-       if (page_cache->current_page > page_cache->n_pages)
+       if (page_cache->current_page >= page_cache->n_pages - 1)
                return FALSE;
 
        ev_page_cache_set_current_page (page_cache, page_cache->current_page + 1);