[gtk+/wip/baedert/children: 27/33] widget: Fix grab_focus for child widgets
- From: Timm Bäder <baedert src gnome org>
- To: commits-list gnome org
- Cc:
- Subject: [gtk+/wip/baedert/children: 27/33] widget: Fix grab_focus for child widgets
- Date: Thu, 1 Dec 2016 07:36:52 +0000 (UTC)
commit 6ab66008bc7e33347430bcb07be5752fd50a4f7e
Author: Timm Bäder <mail baedert org>
Date: Thu Nov 24 17:14:14 2016 +0100
widget: Fix grab_focus for child widgets
gtk/gtkwidget.c | 33 +++++++++++++++++----------------
1 files changed, 17 insertions(+), 16 deletions(-)
---
diff --git a/gtk/gtkwidget.c b/gtk/gtkwidget.c
index d63c7dd..b55d150 100644
--- a/gtk/gtkwidget.c
+++ b/gtk/gtkwidget.c
@@ -7229,19 +7229,17 @@ gtk_widget_grab_focus (GtkWidget *widget)
}
static void
-reset_focus_recurse (GtkWidget *widget,
- gpointer data)
+reset_focus_recurse (GtkWidget *widget)
{
- if (GTK_IS_CONTAINER (widget))
- {
- GtkContainer *container;
+ GtkWidget *child;
- container = GTK_CONTAINER (widget);
- gtk_container_set_focus_child (container, NULL);
+ gtk_widget_set_focus_child (widget, NULL);
- gtk_container_foreach (container,
- reset_focus_recurse,
- NULL);
+ for (child = gtk_widget_get_first_child (widget);
+ child != NULL;
+ child = gtk_widget_get_next_sibling (child))
+ {
+ reset_focus_recurse (child);
}
}
@@ -7283,7 +7281,7 @@ gtk_widget_real_grab_focus (GtkWidget *focus_widget)
while (widget->priv->parent)
{
widget = widget->priv->parent;
- gtk_container_set_focus_child (GTK_CONTAINER (widget), NULL);
+ gtk_widget_set_focus_child (widget, NULL);
if (widget == common_ancestor)
break;
}
@@ -7292,13 +7290,16 @@ gtk_widget_real_grab_focus (GtkWidget *focus_widget)
}
else if (toplevel != focus_widget)
{
+ GtkWidget *child;
/* gtk_widget_grab_focus() operates on a tree without window...
* actually, this is very questionable behavior.
*/
-
- gtk_container_foreach (GTK_CONTAINER (toplevel),
- reset_focus_recurse,
- NULL);
+ for (child = gtk_widget_get_first_child (toplevel);
+ child != NULL;
+ child = gtk_widget_get_next_sibling (child))
+ {
+ reset_focus_recurse (child);
+ }
}
/* now propagate the new focus up the widget tree and finally
@@ -7307,7 +7308,7 @@ gtk_widget_real_grab_focus (GtkWidget *focus_widget)
widget = focus_widget;
while (widget->priv->parent)
{
- gtk_container_set_focus_child (GTK_CONTAINER (widget->priv->parent), widget);
+ gtk_widget_set_focus_child (widget->priv->parent, widget);
widget = widget->priv->parent;
}
if (GTK_IS_WINDOW (widget))
[
Date Prev][
Date Next] [
Thread Prev][
Thread Next]
[
Thread Index]
[
Date Index]
[
Author Index]