diff options
author | Jonny Lamb <jonny.lamb@collabora.co.uk> | 2009-04-21 05:15:36 +0800 |
---|---|---|
committer | Jonny Lamb <jonny.lamb@collabora.co.uk> | 2009-04-24 08:52:49 +0800 |
commit | 37b7480c83cae6bc8bb818c1a0d6ba77ead968eb (patch) | |
tree | 1c871c746448931737907203a6e4721e0ef3f4be | |
parent | 989e03b5f67ce060f5f96a5bc8c1d6b176e5bc4b (diff) | |
download | gsoc2013-empathy-37b7480c83cae6bc8bb818c1a0d6ba77ead968eb.tar gsoc2013-empathy-37b7480c83cae6bc8bb818c1a0d6ba77ead968eb.tar.gz gsoc2013-empathy-37b7480c83cae6bc8bb818c1a0d6ba77ead968eb.tar.bz2 gsoc2013-empathy-37b7480c83cae6bc8bb818c1a0d6ba77ead968eb.tar.lz gsoc2013-empathy-37b7480c83cae6bc8bb818c1a0d6ba77ead968eb.tar.xz gsoc2013-empathy-37b7480c83cae6bc8bb818c1a0d6ba77ead968eb.tar.zst gsoc2013-empathy-37b7480c83cae6bc8bb818c1a0d6ba77ead968eb.zip |
Store the bus name of CMs in an the combo box's tree model instead of two different lists.
Signed-off-by: Jonny Lamb <jonny.lamb@collabora.co.uk>
-rw-r--r-- | src/empathy-debug-dialog.c | 40 |
1 files changed, 27 insertions, 13 deletions
diff --git a/src/empathy-debug-dialog.c b/src/empathy-debug-dialog.c index ae8cd7ce7..b700be73a 100644 --- a/src/empathy-debug-dialog.c +++ b/src/empathy-debug-dialog.c @@ -56,6 +56,13 @@ enum NUM_COLS }; +enum +{ + COL_CM_NAME = 0, + COL_CM_BUS, + NUM_COLS_CM +}; + #define GET_PRIV(obj) EMPATHY_GET_PRIV (obj, EmpathyDebugDialog) typedef struct { @@ -67,7 +74,7 @@ typedef struct TpProxy *proxy; TpProxySignalConnection *signal_connection; gboolean paused; - GList *bus_names; + GtkListStore *cms; gboolean dispose_run; } EmpathyDebugDialogPriv; @@ -212,10 +219,11 @@ debug_dialog_cm_chooser_changed_cb (GtkComboBox *cm_chooser, MissionControl *mc; TpDBusDaemon *dbus; GError *error = NULL; - const gchar *bus_name; + gchar *bus_name; TpConnection *connection; + GtkTreeIter iter; - if (gtk_combo_box_get_active (cm_chooser) == -1) + if (!gtk_combo_box_get_active_iter (cm_chooser, &iter)) { DEBUG ("No CM is selected"); return; @@ -230,8 +238,10 @@ debug_dialog_cm_chooser_changed_cb (GtkComboBox *cm_chooser, g_object_unref (mc); } - bus_name = g_list_nth_data (priv->bus_names, gtk_combo_box_get_active (cm_chooser)); + gtk_tree_model_get (GTK_TREE_MODEL (priv->cms), &iter, + COL_CM_BUS, &bus_name, -1); connection = tp_connection_new (dbus, bus_name, DEBUG_OBJECT_PATH, &error); + g_free (bus_name); if (error != NULL) { @@ -287,10 +297,14 @@ debug_dialog_list_connection_names_cb (const gchar * const *names, } for (i = 0; cms[i] != NULL; i++) - gtk_combo_box_append_text (GTK_COMBO_BOX (priv->cm_chooser), cms[i]); - - for (i = 0; names[i] != NULL; i++) - priv->bus_names = g_list_append (priv->bus_names, g_strdup (names[i])); + { + GtkTreeIter iter; + gtk_list_store_append (priv->cms, &iter); + gtk_list_store_set (priv->cms, &iter, + COL_CM_NAME, cms[i], + COL_CM_BUS, names[i], + -1); + } gtk_combo_box_set_active (GTK_COMBO_BOX (priv->cm_chooser), 0); @@ -365,6 +379,9 @@ debug_dialog_constructor (GType type, /* CM */ priv->cm_chooser = gtk_combo_box_new_text (); + priv->cms = gtk_list_store_new (NUM_COLS_CM, G_TYPE_STRING, G_TYPE_STRING); + gtk_combo_box_set_model (GTK_COMBO_BOX (priv->cm_chooser), + GTK_TREE_MODEL (priv->cms)); gtk_widget_show (priv->cm_chooser); item = gtk_tool_item_new (); @@ -555,11 +572,8 @@ debug_dialog_dispose (GObject *object) if (priv->signal_connection) tp_proxy_signal_connection_disconnect (priv->signal_connection); - if (priv->bus_names) - { - g_list_foreach (priv->bus_names, (GFunc) g_free, NULL); - g_list_free (priv->bus_names); - } + if (priv->cms) + g_object_unref (priv->cms); (G_OBJECT_CLASS (empathy_debug_dialog_parent_class)->dispose) (object); } |