aboutsummaryrefslogtreecommitdiff
path: root/libdbusmenu-gtk
diff options
context:
space:
mode:
authorTed Gould <ted@gould.cx>2012-03-09 09:10:02 -0600
committerTed Gould <ted@gould.cx>2012-03-09 09:10:02 -0600
commit4bd8e21dee661f26f8e1b4522cd3f955b5080e29 (patch)
tree832da04fed4ddfcc3b7198e44800c3562b63a7e8 /libdbusmenu-gtk
parentfb882190fdbbb108b101795fedc7bc22dfa65e99 (diff)
downloadlibdbusmenu-4bd8e21dee661f26f8e1b4522cd3f955b5080e29.tar.gz
libdbusmenu-4bd8e21dee661f26f8e1b4522cd3f955b5080e29.tar.bz2
libdbusmenu-4bd8e21dee661f26f8e1b4522cd3f955b5080e29.zip
Missing a couple of cases of removing the signal handler and clearing the stored value
Diffstat (limited to 'libdbusmenu-gtk')
-rw-r--r--libdbusmenu-gtk/parser.c16
1 files changed, 12 insertions, 4 deletions
diff --git a/libdbusmenu-gtk/parser.c b/libdbusmenu-gtk/parser.c
index 70ffcea..da1c8fa 100644
--- a/libdbusmenu-gtk/parser.c
+++ b/libdbusmenu-gtk/parser.c
@@ -229,7 +229,12 @@ parse_data_free (gpointer data)
static void
widget_freed (gpointer data, GObject * obj)
{
- g_signal_handlers_disconnect_by_func(gtk_icon_theme_get_default(), G_CALLBACK(theme_changed_cb), obj);
+ ParserData * pdata = (ParserData *)data;
+
+ if (pdata->theme_changed_sig != 0) {
+ g_signal_handler_disconnect(gtk_icon_theme_get_default(), pdata->theme_changed_sig);
+ pdata->theme_changed_sig = 0;
+ }
return;
}
@@ -242,9 +247,12 @@ dbusmenu_item_freed (gpointer data, GObject * obj)
ParserData *pdata = (ParserData *)g_object_get_data(G_OBJECT(obj), PARSER_DATA);
if (pdata != NULL && pdata->widget != NULL) {
- g_signal_handlers_disconnect_by_func(gtk_icon_theme_get_default(), G_CALLBACK(theme_changed_cb), pdata->widget);
+ if (pdata->theme_changed_sig != 0) {
+ g_signal_handler_disconnect(gtk_icon_theme_get_default(), pdata->theme_changed_sig);
+ pdata->theme_changed_sig = 0;
+ }
g_object_steal_data(G_OBJECT(pdata->widget), CACHED_MENUITEM);
- g_object_weak_unref(G_OBJECT(pdata->widget), widget_freed, NULL);
+ g_object_weak_unref(G_OBJECT(pdata->widget), widget_freed, pdata);
}
}
@@ -286,7 +294,7 @@ new_menuitem (GtkWidget * widget)
g_object_set_data_full(G_OBJECT(item), PARSER_DATA, pdata, parse_data_free);
g_object_weak_ref(G_OBJECT(item), dbusmenu_item_freed, NULL);
- g_object_weak_ref(G_OBJECT(widget), widget_freed, NULL);
+ g_object_weak_ref(G_OBJECT(widget), widget_freed, pdata);
pdata->widget = widget;
g_object_add_weak_pointer(G_OBJECT (widget), (gpointer*)&pdata->widget);