diff options
author | Jonny Lamb <jonny.lamb@collabora.co.uk> | 2009-04-20 22:44:02 +0800 |
---|---|---|
committer | Jonny Lamb <jonny.lamb@collabora.co.uk> | 2009-04-24 08:52:48 +0800 |
commit | 4db501d37a674c4ec696a6d0fbe30272f0e5acd6 (patch) | |
tree | 37e4dfc40aec7030a8b8be5916e4a184c39fb1f9 | |
parent | 9de1a3a667851d39f82a5b2aa21af6620750a10d (diff) | |
download | gsoc2013-empathy-4db501d37a674c4ec696a6d0fbe30272f0e5acd6.tar.gz gsoc2013-empathy-4db501d37a674c4ec696a6d0fbe30272f0e5acd6.tar.zst gsoc2013-empathy-4db501d37a674c4ec696a6d0fbe30272f0e5acd6.zip |
Changed account chooser to CM chooser.
Signed-off-by: Jonny Lamb <jonny.lamb@collabora.co.uk>
-rw-r--r-- | src/empathy-debug-dialog.c | 115 |
1 files changed, 78 insertions, 37 deletions
diff --git a/src/empathy-debug-dialog.c b/src/empathy-debug-dialog.c index a7db82b57..6ca1f1e89 100644 --- a/src/empathy-debug-dialog.c +++ b/src/empathy-debug-dialog.c @@ -61,7 +61,7 @@ typedef struct GtkWidget *filter; GtkWindow *parent; GtkWidget *view; - GtkWidget *account_chooser; + GtkWidget *cm_chooser; GtkListStore *store; TpProxy *proxy; TpProxySignalConnection *signal_connection; @@ -203,44 +203,49 @@ debug_dialog_get_messages_cb (TpProxy *proxy, } static void -debug_dialog_account_chooser_changed_cb (GtkComboBox *account_chooser, - EmpathyDebugDialog *debug_dialog) +debug_dialog_cm_chooser_changed_cb (GtkComboBox *cm_chooser, + EmpathyDebugDialog *debug_dialog) { EmpathyDebugDialogPriv *priv = GET_PRIV (debug_dialog); - McAccount *account; - TpConnection *connection; + gchar *cm; MissionControl *mc; TpDBusDaemon *dbus; GError *error = NULL; - const gchar *bus_name; + gchar *bus_name; + TpConnection *connection; mc = empathy_mission_control_dup_singleton (); - account = empathy_account_chooser_get_account (EMPATHY_ACCOUNT_CHOOSER (account_chooser)); - connection = mission_control_get_tpconnection (mc, account, &error); + cm = gtk_combo_box_get_active_text (cm_chooser); - if (error != NULL) + if (cm == NULL) { - DEBUG ("Getting the account's TpConnection failed: %s", error->message); - g_error_free (error); - g_object_unref (account); + DEBUG ("No CM is selected"); g_object_unref (mc); return; } - dbus = tp_proxy_get_dbus_daemon (connection); - bus_name = tp_proxy_get_bus_name (connection); - g_object_unref (connection); + dbus = tp_dbus_daemon_dup (&error); + + if (error != NULL) + { + DEBUG ("Failed at duping the dbus daemon: %s", error->message); + g_free (cm); + g_object_unref (mc); + } /* TODO: Fix this. */ + bus_name = g_strdup_printf ("org.freedesktop.Telepathy.ConnectionManager.%s", cm); + g_free (cm); + connection = tp_connection_new (dbus, bus_name, "/org/freedesktop/Telepathy/debug", &error); + g_free (bus_name); if (error != NULL) { DEBUG ("Getting a new TpConnection failed: %s", error->message); g_error_free (error); g_object_unref (dbus); - g_object_unref (account); g_object_unref (mc); return; } @@ -265,11 +270,59 @@ debug_dialog_account_chooser_changed_cb (GtkComboBox *account_chooser, debug_dialog_get_messages_cb, debug_dialog, NULL, NULL); g_object_unref (dbus); - g_object_unref (account); g_object_unref (mc); } static void +debug_dialog_list_connection_names_cb (const gchar * const *names, + gsize n, + const gchar * const *cms, + const gchar * const *protocols, + const GError *error, + gpointer user_data, + GObject *weak_object) +{ + EmpathyDebugDialog *debug_dialog = (EmpathyDebugDialog *) user_data; + EmpathyDebugDialogPriv *priv = GET_PRIV (debug_dialog); + int i; + + if (error != NULL) + { + DEBUG ("list_connection_names failed: %s", error->message); + return; + } + + for (i = 0; cms[i] != NULL; i++) + gtk_combo_box_append_text (GTK_COMBO_BOX (priv->cm_chooser), cms[i]); + + gtk_combo_box_set_active (GTK_COMBO_BOX (priv->cm_chooser), 0); + + /* Fill treeview */ + debug_dialog_cm_chooser_changed_cb (GTK_COMBO_BOX (priv->cm_chooser), debug_dialog); +} + +static void +debug_dialog_fill_cm_chooser (EmpathyDebugDialog *debug_dialog) +{ + TpDBusDaemon *dbus; + GError *error = NULL; + + dbus = tp_dbus_daemon_dup (&error); + + if (error != NULL) + { + DEBUG ("Failed to dup dbus daemon: %s", error->message); + g_error_free (error); + return; + } + + tp_list_connection_names (dbus, debug_dialog_list_connection_names_cb, + debug_dialog, NULL, NULL); + + g_object_unref (dbus); +} + +static void debug_dialog_pause_toggled_cb (GtkToggleToolButton *pause, EmpathyDebugDialog *debug_dialog) { @@ -313,25 +366,18 @@ debug_dialog_constructor (GType type, gtk_box_pack_start (GTK_BOX (vbox), toolbar, FALSE, FALSE, 0); - /* Account */ - item = gtk_tool_item_new (); - gtk_widget_show (GTK_WIDGET (item)); - label = gtk_label_new (_("Account ")); - gtk_widget_show (label); - gtk_container_add (GTK_CONTAINER (item), label); - gtk_toolbar_insert (GTK_TOOLBAR (toolbar), item, -1); - - priv->account_chooser = empathy_account_chooser_new (); - empathy_account_chooser_set_filter (EMPATHY_ACCOUNT_CHOOSER (priv->account_chooser), - (EmpathyAccountChooserFilterFunc) mc_account_is_enabled, NULL); - g_signal_connect (priv->account_chooser, "changed", - G_CALLBACK (debug_dialog_account_chooser_changed_cb), object); - gtk_widget_show (priv->account_chooser); + /* CM */ + priv->cm_chooser = gtk_combo_box_new_text (); + gtk_widget_show (priv->cm_chooser); item = gtk_tool_item_new (); gtk_widget_show (GTK_WIDGET (item)); - gtk_container_add (GTK_CONTAINER (item), priv->account_chooser); + gtk_container_add (GTK_CONTAINER (item), priv->cm_chooser); gtk_toolbar_insert (GTK_TOOLBAR (toolbar), item, -1); + debug_dialog_fill_cm_chooser (EMPATHY_DEBUG_DIALOG (object)); + g_signal_connect (priv->cm_chooser, "changed", + G_CALLBACK (debug_dialog_cm_chooser_changed_cb), object); + gtk_widget_show (GTK_WIDGET (priv->cm_chooser)); item = gtk_separator_tool_item_new (); gtk_widget_show (GTK_WIDGET (item)); @@ -416,11 +462,6 @@ debug_dialog_constructor (GType type, priv->store = gtk_list_store_new (NUM_COLS, G_TYPE_DOUBLE, G_TYPE_STRING, G_TYPE_STRING, G_TYPE_STRING, G_TYPE_STRING); - - /* Fill treeview */ - debug_dialog_account_chooser_changed_cb (GTK_COMBO_BOX (priv->account_chooser), - EMPATHY_DEBUG_DIALOG (object)); - gtk_tree_view_set_model (GTK_TREE_VIEW (priv->view), GTK_TREE_MODEL (priv->store)); |