widget: Insist on proper vfunc calling
Insist that ->show() is only called for invisible and ->hide only for visible widgets.
This commit is contained in:
@@ -3137,8 +3137,8 @@ gtk_widget_real_show (GtkWidget *widget)
|
||||
{
|
||||
GtkWidgetPrivate *priv = gtk_widget_get_instance_private (widget);
|
||||
|
||||
if (!_gtk_widget_get_visible (widget))
|
||||
{
|
||||
g_return_if_fail (!_gtk_widget_get_visible (widget));
|
||||
|
||||
priv->visible = TRUE;
|
||||
|
||||
if (priv->parent &&
|
||||
@@ -3147,7 +3147,6 @@ gtk_widget_real_show (GtkWidget *widget)
|
||||
!_gtk_widget_get_mapped (widget))
|
||||
gtk_widget_map (widget);
|
||||
}
|
||||
}
|
||||
|
||||
/**
|
||||
* gtk_widget_hide:
|
||||
@@ -3204,14 +3203,13 @@ gtk_widget_real_hide (GtkWidget *widget)
|
||||
{
|
||||
GtkWidgetPrivate *priv = gtk_widget_get_instance_private (widget);
|
||||
|
||||
if (_gtk_widget_get_visible (widget))
|
||||
{
|
||||
g_return_if_fail (_gtk_widget_get_visible (widget));
|
||||
|
||||
priv->visible = FALSE;
|
||||
|
||||
if (_gtk_widget_get_mapped (widget))
|
||||
gtk_widget_unmap (widget);
|
||||
}
|
||||
}
|
||||
|
||||
static void
|
||||
update_cursor_on_state_change (GtkWidget *widget)
|
||||
|
||||
Reference in New Issue
Block a user