summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorRay Strode <rstrode@redhat.com>2011-05-06 16:05:44 -0400
committerRay Strode <rstrode@redhat.com>2011-05-10 11:24:59 -0400
commit052fb4689d4ba431cab1d743f6c8ea0820da8341 (patch)
tree22672aab74a79ef616015337e113dc6a65fc70e4
parent6d640147656fdaaa93d540b6a0c4b0e58aefe3f5 (diff)
downloadgdm-052fb4689d4ba431cab1d743f6c8ea0820da8341.tar.gz
greeter: disconnect from user manager on tear down
We don't want any signal handlers to run after the widgets they are meant for are destroyed.
-rw-r--r--gui/simple-greeter/gdm-user-chooser-widget.c16
1 files changed, 16 insertions, 0 deletions
diff --git a/gui/simple-greeter/gdm-user-chooser-widget.c b/gui/simple-greeter/gdm-user-chooser-widget.c
index 84c95864..0f73cc5a 100644
--- a/gui/simple-greeter/gdm-user-chooser-widget.c
+++ b/gui/simple-greeter/gdm-user-chooser-widget.c
@@ -1063,6 +1063,22 @@ gdm_user_chooser_widget_dispose (GObject *object)
}
if (widget->priv->manager != NULL) {
+ g_signal_handlers_disconnect_by_func (widget->priv->manager,
+ G_CALLBACK (on_user_added),
+ widget);
+ g_signal_handlers_disconnect_by_func (widget->priv->manager,
+ G_CALLBACK (on_user_removed),
+ widget);
+ g_signal_handlers_disconnect_by_func (widget->priv->manager,
+ G_CALLBACK (on_is_loaded_changed),
+ widget);
+ g_signal_handlers_disconnect_by_func (widget->priv->manager,
+ G_CALLBACK (on_user_is_logged_in_changed),
+ widget);
+ g_signal_handlers_disconnect_by_func (widget->priv->manager,
+ G_CALLBACK (on_user_changed),
+ widget);
+
g_object_unref (widget->priv->manager);
widget->priv->manager = NULL;
}