[gtk+] sizerequestcache: Make clear_cache clear all the cache



commit c98ee1ec396ccd8cb4c87780ee08adad88fdf3e3
Author: Benjamin Otte <otte redhat com>
Date:   Tue Nov 13 21:51:29 2012 +0100

    sizerequestcache: Make clear_cache clear all the cache

 gtk/gtksizerequest.c             |    8 ++---
 gtk/gtksizerequestcache.c        |   51 +++++++++++++------------------------
 gtk/gtksizerequestcacheprivate.h |    4 +--
 3 files changed, 22 insertions(+), 41 deletions(-)
---
diff --git a/gtk/gtksizerequest.c b/gtk/gtksizerequest.c
index 51043ed..eff854f 100644
--- a/gtk/gtksizerequest.c
+++ b/gtk/gtksizerequest.c
@@ -95,11 +95,9 @@ init_cache (GtkWidget        *widget)
 
   cache = _gtk_widget_peek_request_cache (widget);
 
-  if (_gtk_widget_get_width_request_needed (widget))
-    _gtk_size_request_cache_clear (cache, GTK_SIZE_GROUP_HORIZONTAL);
-  
-  if (_gtk_widget_get_height_request_needed (widget))
-    _gtk_size_request_cache_clear (cache, GTK_SIZE_GROUP_VERTICAL);
+  if (_gtk_widget_get_width_request_needed (widget) ||
+      _gtk_widget_get_height_request_needed (widget))
+    _gtk_size_request_cache_clear (cache);
 
   return cache;
 }
diff --git a/gtk/gtksizerequestcache.c b/gtk/gtksizerequestcache.c
index d098e40..f7597eb 100644
--- a/gtk/gtksizerequestcache.c
+++ b/gtk/gtksizerequestcache.c
@@ -31,46 +31,31 @@ _gtk_size_request_cache_init (SizeRequestCache *cache)
   memset (cache, 0, sizeof (SizeRequestCache));
 }
 
+static void
+free_sizes (SizeRequest **sizes)
+{
+  gint i;
+
+  for (i = 0; i < GTK_SIZE_REQUEST_CACHED_SIZES && sizes[i] != NULL; i++)
+    g_slice_free (SizeRequest, sizes[i]);
+      
+  g_slice_free1 (sizeof (SizeRequest *) * GTK_SIZE_REQUEST_CACHED_SIZES, sizes);
+}
+
 void
 _gtk_size_request_cache_free (SizeRequestCache *cache)
 {
-  _gtk_size_request_cache_clear (cache, GTK_SIZE_GROUP_HORIZONTAL);
-  _gtk_size_request_cache_clear (cache, GTK_SIZE_GROUP_VERTICAL);
+  if (cache->widths)
+    free_sizes (cache->widths);
+  if (cache->heights)
+    free_sizes (cache->heights);
 }
 
 void
-_gtk_size_request_cache_clear (SizeRequestCache *cache,
-	                       GtkSizeGroupMode  orientation)
+_gtk_size_request_cache_clear (SizeRequestCache *cache)
                                
 {
-  SizeRequest **sizes;
-  gint          i;
-
-  if (orientation == GTK_SIZE_GROUP_HORIZONTAL)
-    {
-      sizes = cache->widths;
-
-      cache->widths            = NULL;
-      cache->cached_widths     = 0;
-      cache->last_cached_width = 0;
-      cache->cached_base_width = FALSE;
-    }
-  else
-    {
-      sizes = cache->heights;
-
-      cache->heights            = NULL;
-      cache->cached_heights     = 0;
-      cache->last_cached_height = 0; 
-      cache->cached_base_height = FALSE;
-   }
-
-  if (sizes)
-    {
-      for (i = 0; i < GTK_SIZE_REQUEST_CACHED_SIZES && sizes[i] != NULL; i++)
-	g_slice_free (SizeRequest, sizes[i]);
-      
-      g_slice_free1 (sizeof (SizeRequest *) * GTK_SIZE_REQUEST_CACHED_SIZES, sizes);
-    }
+  _gtk_size_request_cache_free (cache);
+  _gtk_size_request_cache_init (cache);
 }
 
diff --git a/gtk/gtksizerequestcacheprivate.h b/gtk/gtksizerequestcacheprivate.h
index 939f9cb..60c061b 100644
--- a/gtk/gtksizerequestcacheprivate.h
+++ b/gtk/gtksizerequestcacheprivate.h
@@ -26,7 +26,6 @@
 #define __GTK_SIZE_REQUEST_CACHE_PRIVATE_H__
 
 #include <glib.h>
-#include <gtk/gtkenums.h>
 
 G_BEGIN_DECLS
 
@@ -68,8 +67,7 @@ typedef struct {
 void            _gtk_size_request_cache_init                    (SizeRequestCache       *cache);
 void            _gtk_size_request_cache_free                    (SizeRequestCache       *cache);
 
-void            _gtk_size_request_cache_clear                   (SizeRequestCache       *cache,
-	                                                         GtkSizeGroupMode        orientation);
+void            _gtk_size_request_cache_clear                   (SizeRequestCache       *cache);
 
 G_END_DECLS
 



[Date Prev][Date Next]   [Thread Prev][Thread Next]   [Thread Index] [Date Index] [Author Index]