]> www.fi.muni.cz Git - evince.git/blobdiff - shell/ev-page-cache.c
Use cairo image surfaces instead of GDK pixbufs for drawing pages and
[evince.git] / shell / ev-page-cache.c
index a6d7bd9e99fc713fe8ed2f1c1ff1270bd9da6678..ebf0de7f9b69f8d2409e51d69f75dabb0438d4aa 100644 (file)
@@ -108,13 +108,43 @@ ev_page_cache_finalize (GObject *object)
 
        page_cache = EV_PAGE_CACHE (object);
 
-       g_free (page_cache->title);
-       g_free (page_cache->size_cache);
-       g_free (page_cache->height_to_page);
-       g_free (page_cache->dual_height_to_page);
-       g_strfreev (page_cache->page_labels);
+       if (page_cache->title) {
+               g_free (page_cache->title);
+               page_cache->title = NULL;
+       }
+
+       if (page_cache->size_cache) {
+               g_free (page_cache->size_cache);
+               page_cache->size_cache = NULL;
+       }
+
+       if (page_cache->height_to_page) {
+               g_free (page_cache->height_to_page);
+               page_cache->height_to_page = NULL;
+       }
+
+       if (page_cache->dual_height_to_page) {
+               g_free (page_cache->dual_height_to_page);
+               page_cache->dual_height_to_page = NULL;
+       }
+
+       if (page_cache->page_labels) {
+               gint i;
+
+               for (i = 0; i < page_cache->n_pages; i++) {
+                       if (page_cache->page_labels[i])
+                               g_free (page_cache->page_labels[i]);
+               }
+               g_free (page_cache->page_labels);
+               page_cache->page_labels = NULL;
+       }
 
-       ev_document_info_free (page_cache->page_info);
+       if (page_cache->page_info) {
+               ev_document_info_free (page_cache->page_info);
+               page_cache->page_info = NULL;
+       }
+
+       G_OBJECT_CLASS (ev_page_cache_parent_class)->finalize (object);
 }
 
 static void
@@ -340,9 +370,9 @@ void
 ev_page_cache_set_current_page_history (EvPageCache *page_cache,
                                        int          page)
 {
-       if (page != page_cache->current_page)
+       if (abs (page - page_cache->current_page) > 1)
                g_signal_emit (page_cache, signals [HISTORY_CHANGED], 0, page);
-               
+       
        ev_page_cache_set_current_page (page_cache, page);
 }