[gtk/wip/matthiasc/popup: 55/63] label: Bandaid fix for mnemonics
- From: Matthias Clasen <matthiasc src gnome org>
- To: commits-list gnome org
- Cc:
- Subject: [gtk/wip/matthiasc/popup: 55/63] label: Bandaid fix for mnemonics
- Date: Mon, 4 Mar 2019 04:34:31 +0000 (UTC)
commit 89b6d9b4961b5de89ab5f2d23d2b75998783fd72
Author: Matthias Clasen <mclasen redhat com>
Date: Sun Mar 3 20:02:55 2019 -0500
label: Bandaid fix for mnemonics
Avoid critical warnings from mnemonic setup code.
We still don't support mnemonics with roots other
than GtkWindow.
gtk/gtklabel.c | 16 ++++++++--------
1 file changed, 8 insertions(+), 8 deletions(-)
---
diff --git a/gtk/gtklabel.c b/gtk/gtklabel.c
index 8bbe58f7e5..b4e5fc903f 100644
--- a/gtk/gtklabel.c
+++ b/gtk/gtklabel.c
@@ -474,7 +474,7 @@ static void gtk_label_update_active_link (GtkWidget *widget,
static gboolean gtk_label_mnemonic_activate (GtkWidget *widget,
gboolean group_cycling);
static void gtk_label_setup_mnemonic (GtkLabel *label,
- GtkWidget *toplevel,
+ GtkRoot *root,
guint last_key);
static void gtk_label_drag_data_get (GtkWidget *widget,
GdkDrag *drag,
@@ -1918,7 +1918,7 @@ gtk_label_mnemonic_activate (GtkWidget *widget,
static void
gtk_label_setup_mnemonic (GtkLabel *label,
- GtkWidget *toplevel,
+ GtkRoot *root,
guint last_key)
{
GtkLabelPrivate *priv = gtk_label_get_instance_private (label);
@@ -1950,7 +1950,7 @@ gtk_label_setup_mnemonic (GtkLabel *label,
connect_mnemonics_visible_notify (GTK_LABEL (widget));
- if (toplevel && gtk_widget_is_toplevel (toplevel))
+ if (root)
{
GtkWidget *menu_shell;
@@ -1965,12 +1965,12 @@ gtk_label_setup_mnemonic (GtkLabel *label,
mnemonic_menu = menu_shell;
}
- if (!GTK_IS_MENU (menu_shell))
+ if (!GTK_IS_MENU (menu_shell) && GTK_IS_WINDOW (root))
{
- gtk_window_add_mnemonic (GTK_WINDOW (toplevel),
+ gtk_window_add_mnemonic (GTK_WINDOW (root),
priv->mnemonic_keyval,
widget);
- priv->mnemonic_window = GTK_WINDOW (toplevel);
+ priv->mnemonic_window = GTK_WINDOW (root);
}
}
@@ -1986,7 +1986,7 @@ gtk_label_root (GtkWidget *widget)
GTK_WIDGET_CLASS (gtk_label_parent_class)->root (widget);
- gtk_label_setup_mnemonic (label, gtk_widget_get_toplevel (widget), priv->mnemonic_keyval);
+ gtk_label_setup_mnemonic (label, gtk_widget_get_root (widget), priv->mnemonic_keyval);
}
static void
@@ -2321,7 +2321,7 @@ gtk_label_recalculate (GtkLabel *label)
if (keyval != priv->mnemonic_keyval)
{
- gtk_label_setup_mnemonic (label, gtk_widget_get_toplevel (GTK_WIDGET (label)), keyval);
+ gtk_label_setup_mnemonic (label, gtk_widget_get_root (GTK_WIDGET (label)), keyval);
g_object_notify_by_pspec (G_OBJECT (label), label_props[PROP_MNEMONIC_KEYVAL]);
}
[
Date Prev][
Date Next] [
Thread Prev][
Thread Next]
[
Thread Index]
[
Date Index]
[
Author Index]