From c98ee1ec396ccd8cb4c87780ee08adad88fdf3e3 Mon Sep 17 00:00:00 2001 From: Benjamin Otte Date: Tue, 13 Nov 2012 21:51:29 +0100 Subject: [PATCH] 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 51043edb9..eff854f20 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 d098e402f..f7597ebb7 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 939f9cb61..60c061bdf 100644 --- a/gtk/gtksizerequestcacheprivate.h +++ b/gtk/gtksizerequestcacheprivate.h @@ -26,7 +26,6 @@ #define __GTK_SIZE_REQUEST_CACHE_PRIVATE_H__ #include -#include 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 -- 2.43.2