aboutsummaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorTed Gould <ted@gould.cx>2011-03-22 17:04:45 -0500
committerTed Gould <ted@gould.cx>2011-03-22 17:04:45 -0500
commitaebf305c5893813f577378a105f12ab8f86ca17b (patch)
tree5bf3cdbe66bca0e95db54ce8d5958bf19c0cc1b0
parent746a792ef912c5160fed15bf817df5124f6610b0 (diff)
parent6249256f1d55968f054e0dcbac01591c0fa01da1 (diff)
downloadlibdbusmenu-aebf305c5893813f577378a105f12ab8f86ca17b.tar.gz
libdbusmenu-aebf305c5893813f577378a105f12ab8f86ca17b.tar.bz2
libdbusmenu-aebf305c5893813f577378a105f12ab8f86ca17b.zip
Look everywhere for accel closures
-rw-r--r--libdbusmenu-gtk/menuitem.c11
1 files changed, 9 insertions, 2 deletions
diff --git a/libdbusmenu-gtk/menuitem.c b/libdbusmenu-gtk/menuitem.c
index b3358fe..ca2bc3e 100644
--- a/libdbusmenu-gtk/menuitem.c
+++ b/libdbusmenu-gtk/menuitem.c
@@ -236,8 +236,15 @@ dbusmenu_menuitem_property_set_shortcut_menuitem (DbusmenuMenuitem * menuitem, c
NULL);
}
- if (closure == NULL)
- return FALSE;
+ if (closure == NULL) {
+ /* As a fallback, check for a closure in the related menu item. This
+ actually happens with SWT menu items. */
+ GList * closures = gtk_widget_list_accel_closures (GTK_WIDGET (gmi));
+ if (closures == NULL)
+ return FALSE;
+ closure = closures->data;
+ g_list_free (closures);
+ }
GtkAccelGroup * group = gtk_accel_group_from_accel_closure(closure);