[gtk+] entry: use GTK_STYLE_CLASS_IMAGE when rendering the entry icon
- From: Benjamin Otte <otte src gnome org>
- To: commits-list gnome org
- Cc:
- Subject: [gtk+] entry: use GTK_STYLE_CLASS_IMAGE when rendering the entry icon
- Date: Thu, 9 Jun 2011 21:25:01 +0000 (UTC)
commit 8efa8a067e53de929a9b42b0ab0ee2a09812d6d9
Author: Cosimo Cecchi <cosimoc gnome org>
Date: Tue May 24 21:33:14 2011 -0400
entry: use GTK_STYLE_CLASS_IMAGE when rendering the entry icon
gtk/gtkentry.c | 12 +++++++++---
1 files changed, 9 insertions(+), 3 deletions(-)
---
diff --git a/gtk/gtkentry.c b/gtk/gtkentry.c
index 59979bb..6c863ec 100644
--- a/gtk/gtkentry.c
+++ b/gtk/gtkentry.c
@@ -3350,6 +3350,8 @@ draw_icon (GtkWidget *widget,
width = gdk_window_get_width (icon_info->window);
height = gdk_window_get_height (icon_info->window);
+ context = gtk_widget_get_style_context (widget);
+
/* size_allocate hasn't been called yet. These are the default values.
*/
if (width == 1 || height == 1)
@@ -3387,7 +3389,6 @@ draw_icon (GtkWidget *widget,
else if (icon_info->prelight)
state |= GTK_STATE_FLAG_PRELIGHT;
- context = gtk_widget_get_style_context (widget);
gtk_style_context_save (context);
gtk_style_context_set_state (context, state);
temp_pixbuf = gtk_render_icon_pixbuf (context, icon_source, (GtkIconSize)-1);
@@ -6719,7 +6720,7 @@ create_normal_pixbuf (GtkStyleContext *context,
gtk_style_context_save (context);
/* Unset any state */
- gtk_style_context_set_state (context, 0);
+ gtk_style_context_set_state (context, GTK_STATE_FLAG_NORMAL);
icon_set = gtk_style_context_lookup_icon_set (context, stock_id);
pixbuf = gtk_icon_set_render_icon_pixbuf (icon_set, context, icon_size);
@@ -6749,6 +6750,9 @@ gtk_entry_ensure_pixbuf (GtkEntry *entry,
widget = GTK_WIDGET (entry);
context = gtk_widget_get_style_context (widget);
+ gtk_style_context_save (context);
+ gtk_style_context_add_class (context, GTK_STYLE_CLASS_IMAGE);
+
switch (icon_info->storage_type)
{
case GTK_IMAGE_EMPTY:
@@ -6832,7 +6836,9 @@ gtk_entry_ensure_pixbuf (GtkEntry *entry,
g_assert_not_reached ();
break;
}
-
+
+ gtk_style_context_restore (context);
+
if (icon_info->pixbuf != NULL && icon_info->window != NULL)
gdk_window_show_unraised (icon_info->window);
}
[
Date Prev][
Date Next] [
Thread Prev][
Thread Next]
[
Thread Index]
[
Date Index]
[
Author Index]