fixed: add a comment for gtk_style_context_set_background()
And wrap it with G_GNUC_IGNORE_DEPRECATIONS. Unfortunately we can't stop rendering the background altogether here. Also, gtk_style_context_set_background() should really be called every time the style is updated. Fix that.
This commit is contained in:
parent
74f2d9448f
commit
380ebbf76d
@ -94,6 +94,7 @@ static void gtk_fixed_get_preferred_height (GtkWidget *widget,
|
|||||||
gint *natural);
|
gint *natural);
|
||||||
static void gtk_fixed_size_allocate (GtkWidget *widget,
|
static void gtk_fixed_size_allocate (GtkWidget *widget,
|
||||||
GtkAllocation *allocation);
|
GtkAllocation *allocation);
|
||||||
|
static void gtk_fixed_style_updated (GtkWidget *widget);
|
||||||
static gboolean gtk_fixed_draw (GtkWidget *widget,
|
static gboolean gtk_fixed_draw (GtkWidget *widget,
|
||||||
cairo_t *cr);
|
cairo_t *cr);
|
||||||
static void gtk_fixed_add (GtkContainer *container,
|
static void gtk_fixed_add (GtkContainer *container,
|
||||||
@ -133,6 +134,7 @@ gtk_fixed_class_init (GtkFixedClass *class)
|
|||||||
widget_class->get_preferred_height = gtk_fixed_get_preferred_height;
|
widget_class->get_preferred_height = gtk_fixed_get_preferred_height;
|
||||||
widget_class->size_allocate = gtk_fixed_size_allocate;
|
widget_class->size_allocate = gtk_fixed_size_allocate;
|
||||||
widget_class->draw = gtk_fixed_draw;
|
widget_class->draw = gtk_fixed_draw;
|
||||||
|
widget_class->style_updated = gtk_fixed_style_updated;
|
||||||
|
|
||||||
container_class->add = gtk_fixed_add;
|
container_class->add = gtk_fixed_add;
|
||||||
container_class->remove = gtk_fixed_remove;
|
container_class->remove = gtk_fixed_remove;
|
||||||
@ -344,6 +346,31 @@ gtk_fixed_get_child_property (GtkContainer *container,
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
static void
|
||||||
|
set_background (GtkWidget *widget)
|
||||||
|
{
|
||||||
|
if (gtk_widget_get_realized (widget))
|
||||||
|
{
|
||||||
|
/* We still need to call gtk_style_context_set_background() here for
|
||||||
|
* GtkFixed, since subclasses like EmacsFixed depend on the X window
|
||||||
|
* background to be set.
|
||||||
|
* This should be revisited next time we have a major API break.
|
||||||
|
*/
|
||||||
|
G_GNUC_BEGIN_IGNORE_DEPRECATIONS;
|
||||||
|
gtk_style_context_set_background (gtk_widget_get_style_context (widget),
|
||||||
|
gtk_widget_get_window (widget));
|
||||||
|
G_GNUC_END_IGNORE_DEPRECATIONS;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
static void
|
||||||
|
gtk_fixed_style_updated (GtkWidget *widget)
|
||||||
|
{
|
||||||
|
GTK_WIDGET_CLASS (gtk_fixed_parent_class)->style_updated (widget);
|
||||||
|
|
||||||
|
set_background (widget);
|
||||||
|
}
|
||||||
|
|
||||||
static void
|
static void
|
||||||
gtk_fixed_realize (GtkWidget *widget)
|
gtk_fixed_realize (GtkWidget *widget)
|
||||||
{
|
{
|
||||||
@ -377,8 +404,7 @@ gtk_fixed_realize (GtkWidget *widget)
|
|||||||
gtk_widget_set_window (widget, window);
|
gtk_widget_set_window (widget, window);
|
||||||
gtk_widget_register_window (widget, window);
|
gtk_widget_register_window (widget, window);
|
||||||
|
|
||||||
gtk_style_context_set_background (gtk_widget_get_style_context (widget),
|
set_background (widget);
|
||||||
window);
|
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
Loading…
Reference in New Issue
Block a user