[gnome-software] Disconnect GNetworkMonitor::network-changed handlers when objects disposed.
- From: Robert Ancell <rancell src gnome org>
- To: commits-list gnome org
- Cc:
- Subject: [gnome-software] Disconnect GNetworkMonitor::network-changed handlers when objects disposed.
- Date: Thu, 3 Mar 2016 21:46:31 +0000 (UTC)
commit 29e4d86d598c2fc3a4136743b7da664058eb7009
Author: Robert Ancell <robert ancell canonical com>
Date: Fri Mar 4 10:42:50 2016 +1300
Disconnect GNetworkMonitor::network-changed handlers when objects disposed.
Since GNOME Software can run in the background and GNetworkMonitor is a
singleton this can cause the handlers to run on destroyed objects.
src/gs-application.c | 9 +++++++--
src/gs-shell-updates.c | 11 ++++++++---
2 files changed, 15 insertions(+), 5 deletions(-)
---
diff --git a/src/gs-application.c b/src/gs-application.c
index e811a15..9768c57 100644
--- a/src/gs-application.c
+++ b/src/gs-application.c
@@ -62,6 +62,7 @@ struct _GsApplication {
#endif
GsShellSearchProvider *search_provider;
GNetworkMonitor *network_monitor;
+ gulong network_changed_handler;
GSettings *settings;
};
@@ -181,8 +182,8 @@ gs_application_monitor_network (GsApplication *app)
return;
app->network_monitor = g_object_ref (network_monitor);
- g_signal_connect (app->network_monitor, "network-changed",
- G_CALLBACK (network_changed_cb), app);
+ app->network_changed_handler = g_signal_connect (app->network_monitor, "network-changed",
+ G_CALLBACK (network_changed_cb), app);
network_changed_cb (app->network_monitor,
g_network_monitor_get_network_available (app->network_monitor),
@@ -698,6 +699,10 @@ gs_application_dispose (GObject *object)
g_clear_object (&app->provider);
g_clear_object (&app->update_monitor);
g_clear_object (&app->profile);
+ if (app->network_changed_handler != 0) {
+ g_signal_handler_disconnect (app->network_monitor, app->network_changed_handler);
+ app->network_changed_handler = 0;
+ }
g_clear_object (&app->network_monitor);
#ifdef HAVE_PACKAGEKIT
g_clear_object (&app->dbus_helper);
diff --git a/src/gs-shell-updates.c b/src/gs-shell-updates.c
index eb877a0..ba186c7 100644
--- a/src/gs-shell-updates.c
+++ b/src/gs-shell-updates.c
@@ -65,6 +65,7 @@ struct _GsShellUpdates
gboolean in_progress;
GsShell *shell;
GNetworkMonitor *network_monitor;
+ gulong network_changed_handler;
GsPluginStatus last_status;
GsShellUpdatesState state;
GtkWidget *button_refresh;
@@ -1188,9 +1189,9 @@ gs_shell_updates_setup (GsShellUpdates *self,
gs_shell_updates_monitor_permission (self);
if (self->network_monitor != NULL) {
- g_signal_connect (self->network_monitor, "network-changed",
- G_CALLBACK (gs_shell_updates_notify_network_state_cb),
- self);
+ self->network_changed_handler = g_signal_connect (self->network_monitor, "network-changed",
+ G_CALLBACK (gs_shell_updates_notify_network_state_cb),
+ self);
}
/* chain up */
@@ -1208,6 +1209,10 @@ gs_shell_updates_dispose (GObject *object)
{
GsShellUpdates *self = GS_SHELL_UPDATES (object);
+ if (self->network_changed_handler != 0) {
+ g_signal_handler_disconnect (self->network_monitor, self->network_changed_handler);
+ self->network_changed_handler = 0;
+ }
if (self->cancellable_refresh != NULL) {
g_cancellable_cancel (self->cancellable_refresh);
g_clear_object (&self->cancellable_refresh);
[
Date Prev][
Date Next] [
Thread Prev][
Thread Next]
[
Thread Index]
[
Date Index]
[
Author Index]