diff options
author | Matthias Clasen <mclasen@redhat.com> | 2021-01-27 05:34:21 +0000 |
---|---|---|
committer | Matthias Clasen <mclasen@redhat.com> | 2021-01-27 05:34:21 +0000 |
commit | eeb3dd35119cb5219f95d875fe4c3f6054ec32f8 (patch) | |
tree | 8c503fedc365b144b38c50646cffd7f9b0ab4054 | |
parent | 7b0ce11e46f6917ec6c0db173b8455525148c9de (diff) | |
parent | 8ef1d6a49ca2955d152e67012f79b9ad5cc73a37 (diff) | |
download | gtk+-eeb3dd35119cb5219f95d875fe4c3f6054ec32f8.tar.gz |
Merge branch 'fix-can-focus' into 'master'
widget: Fix can-focus
Closes #3610
See merge request GNOME/gtk!3123
-rw-r--r-- | gtk/gtkwidget.c | 18 |
1 files changed, 16 insertions, 2 deletions
diff --git a/gtk/gtkwidget.c b/gtk/gtkwidget.c index 0daeef7a6d..0186968bd7 100644 --- a/gtk/gtkwidget.c +++ b/gtk/gtkwidget.c @@ -4391,12 +4391,26 @@ gtk_widget_can_activate (GtkWidget *self) } static gboolean +get_effective_can_focus (GtkWidget *widget) +{ + GtkWidgetPrivate *priv = gtk_widget_get_instance_private (widget); + + if (!priv->can_focus) + return FALSE; + + if (priv->parent) + return get_effective_can_focus (priv->parent); + + return TRUE; +} + +static gboolean gtk_widget_real_mnemonic_activate (GtkWidget *widget, gboolean group_cycling) { if (!group_cycling && gtk_widget_can_activate (widget)) gtk_widget_activate (widget); - else if (gtk_widget_get_can_focus (widget)) + else if (get_effective_can_focus (widget)) return gtk_widget_grab_focus (widget); else { @@ -4782,7 +4796,7 @@ gtk_widget_grab_focus (GtkWidget *widget) g_return_val_if_fail (GTK_IS_WIDGET (widget), FALSE); if (!gtk_widget_is_sensitive (widget) || - !gtk_widget_get_can_focus (widget) || + !get_effective_can_focus (widget) || widget->priv->root == NULL) return FALSE; |