diff options
author | Chris Coulson <chrisccoulson@ubuntu.com> | 2011-03-30 13:20:52 +0100 |
---|---|---|
committer | Chris Coulson <chrisccoulson@ubuntu.com> | 2011-03-30 13:20:52 +0100 |
commit | ccf2e684c6a2f8115dbe9544f43412986acaee79 (patch) | |
tree | fc7a7ebfcfb98e3e539fec188684f77c748638f0 /libdbusmenu-gtk | |
parent | 5c87bba0ab605353ca44063b30765470b069c599 (diff) | |
download | libdbusmenu-ccf2e684c6a2f8115dbe9544f43412986acaee79.tar.gz libdbusmenu-ccf2e684c6a2f8115dbe9544f43412986acaee79.tar.bz2 libdbusmenu-ccf2e684c6a2f8115dbe9544f43412986acaee79.zip |
Revert the last commit and handle the same problem in the parser instead
Diffstat (limited to 'libdbusmenu-gtk')
-rw-r--r-- | libdbusmenu-gtk/parser.c | 22 |
1 files changed, 21 insertions, 1 deletions
diff --git a/libdbusmenu-gtk/parser.c b/libdbusmenu-gtk/parser.c index a7f90a2..9fc8f53 100644 --- a/libdbusmenu-gtk/parser.c +++ b/libdbusmenu-gtk/parser.c @@ -454,7 +454,7 @@ construct_dbusmenu_for_widget (GtkWidget * widget) gboolean visible = FALSE; gboolean sensitive = FALSE; - if (GTK_IS_SEPARATOR_MENU_ITEM (widget)) + if (GTK_IS_SEPARATOR_MENU_ITEM (widget) || !find_menu_label (widget)) { dbusmenu_menuitem_property_set (mi, "type", @@ -891,6 +891,26 @@ widget_notify_cb (GtkWidget *widget, } else if (pspec->name == g_intern_static_string ("label")) { + if (!g_strcmp0 (dbusmenu_menuitem_property_get (child, DBUSMENU_MENUITEM_PROP_TYPE), "separator")) + { + /* GtkMenuItem's can start life as a separator if they have no child + * GtkLabel. In this case, we need to convert the DbusmenuMenuitem from + * a separator to a normal menuitem if the application adds a label + */ + GtkWidget *label = find_menu_label (widget); + /* This should never fail */ + g_return_if_fail (label != NULL); + + dbusmenu_menuitem_property_remove (child, DBUSMENU_MENUITEM_PROP_TYPE); + ParserData *pdata = g_object_get_data (G_OBJECT (widget), PARSER_DATA); + pdata->label = label; + g_signal_connect (G_OBJECT (label), + "notify", + G_CALLBACK (label_notify_cb), + child); + g_object_add_weak_pointer(G_OBJECT (label), (gpointer*)&pdata->label); + } + dbusmenu_menuitem_property_set (child, DBUSMENU_MENUITEM_PROP_LABEL, g_value_get_string (&prop_value)); |