summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorBeniamino Galvani <bgalvani@redhat.com>2019-01-12 22:35:10 +0100
committerBeniamino Galvani <bgalvani@redhat.com>2019-01-12 22:42:40 +0100
commit78d3c72a6aa513102efe3efbbea9926a89dad29c (patch)
tree04a2b542fa0ddb039f57f80b6036cf664ad44835
parent0b6ba856c1577d4711ebc2ac2973d1402863e954 (diff)
downloadnetwork-manager-applet-bg/rh1665653.tar.gz
wifi-dialog: fix connection combo signalsbg/rh1665653
We need to connect to "changed" signal only when there are multiple items. Also, connection_combo_init() can be called multiple times and so we need to clear previous handlers registration, or the function will be called multiple times.
-rw-r--r--src/libnma/nma-wifi-dialog.c7
1 files changed, 5 insertions, 2 deletions
diff --git a/src/libnma/nma-wifi-dialog.c b/src/libnma/nma-wifi-dialog.c
index c0f3336a..7970c15c 100644
--- a/src/libnma/nma-wifi-dialog.c
+++ b/src/libnma/nma-wifi-dialog.c
@@ -542,11 +542,14 @@ connection_combo_init (NMAWifiDialog *self)
NULL);
gtk_combo_box_set_active (GTK_COMBO_BOX (widget), 0);
- g_signal_connect (G_OBJECT (widget), "changed",
- G_CALLBACK (connection_combo_changed), self);
+
if (priv->specific_connection || !num_added) {
gtk_widget_hide (GTK_WIDGET (gtk_builder_get_object (priv->builder, "connection_label")));
gtk_widget_hide (widget);
+ } else {
+ g_signal_handlers_disconnect_by_func (widget, connection_combo_changed, self);
+ g_signal_connect (widget, "changed",
+ G_CALLBACK (connection_combo_changed), self);
}
if (gtk_tree_model_get_iter_first (priv->connection_model, &tree_iter))
gtk_tree_model_get (priv->connection_model, &tree_iter, C_CON_COLUMN, &priv->connection, -1);