aboutsummaryrefslogtreecommitdiffstats
path: root/src
diff options
context:
space:
mode:
authorChandni Verma <chandniverma2112@gmail.com>2011-11-08 09:05:06 +0800
committerChandni Verma <chandniverma2112@gmail.com>2012-01-28 14:33:23 +0800
commit7a6a03aff158ddc47c1f70093b1f903be2d44181 (patch)
treec28a7e3f533b3b5443ce6c3873c1452e6f6790ef /src
parent52715c3cb3697474e48d4f73d9d432d6b69871a1 (diff)
downloadgsoc2013-empathy-7a6a03aff158ddc47c1f70093b1f903be2d44181.tar.gz
gsoc2013-empathy-7a6a03aff158ddc47c1f70093b1f903be2d44181.tar.zst
gsoc2013-empathy-7a6a03aff158ddc47c1f70093b1f903be2d44181.zip
Preparing for adding "All" option to service_chooser
-Store associations to proxies while creating them -Find service_store iter to store useful proxies https://bugzilla.gnome.org/show_bug.cgi?id=592994
Diffstat (limited to 'src')
-rw-r--r--src/empathy-debug-window.c73
1 files changed, 60 insertions, 13 deletions
diff --git a/src/empathy-debug-window.c b/src/empathy-debug-window.c
index ca7f7c828..75cb6df19 100644
--- a/src/empathy-debug-window.c
+++ b/src/empathy-debug-window.c
@@ -316,6 +316,36 @@ debug_window_set_toolbar_sensitivity (EmpathyDebugWindow *debug_window,
}
}
+static gboolean
+debug_window_get_iter_for_active_buffer (GtkListStore *active_buffer,
+ GtkTreeIter *iter,
+ EmpathyDebugWindow *debug_window)
+{
+ EmpathyDebugWindowPriv *priv = GET_PRIV (debug_window);
+ gboolean valid_iter;
+ GtkTreeModel *model = GTK_TREE_MODEL (priv->service_store);
+
+ gtk_tree_model_get_iter_first (model, iter);
+ for (valid_iter = gtk_tree_model_iter_next (model, iter);
+ valid_iter;
+ valid_iter = gtk_tree_model_iter_next (model, iter))
+ {
+ GtkListStore *stored_active_buffer;
+
+ gtk_tree_model_get (model, iter,
+ COL_ACTIVE_BUFFER, &stored_active_buffer,
+ -1);
+ if (active_buffer == stored_active_buffer)
+ {
+ g_object_unref (stored_active_buffer);
+ return valid_iter;
+ }
+ g_object_unref (stored_active_buffer);
+ }
+
+ return valid_iter;
+}
+
static void
proxy_invalidated_cb (TpProxy *proxy,
guint domain,
@@ -338,8 +368,13 @@ debug_window_get_messages_cb (TpProxy *proxy,
EmpathyDebugWindowPriv *priv = GET_PRIV (debug_window);
gchar *name;
guint i;
+ GtkListStore *active_buffer;
+ gboolean valid_iter;
GtkTreeIter iter;
- GtkTreeModel *pause_buffer, *active_buffer;
+
+ active_buffer = g_object_get_data (G_OBJECT (proxy), "active-buffer");
+ valid_iter = debug_window_get_iter_for_active_buffer (active_buffer, &iter,
+ debug_window);
if (error != NULL)
{
@@ -355,17 +390,6 @@ debug_window_get_messages_cb (TpProxy *proxy,
DEBUG ("Retrieved debug messages for %s", name);
g_free (name);
- gtk_combo_box_get_active_iter (GTK_COMBO_BOX (priv->chooser), &iter);
- gtk_tree_model_get (GTK_TREE_MODEL (priv->service_store), &iter,
- COL_ACTIVE_BUFFER, &active_buffer,
- COL_PAUSE_BUFFER, &pause_buffer,
- -1);
-
- g_object_set_data (G_OBJECT (proxy), "active-buffer", active_buffer);
- g_object_set_data (G_OBJECT (proxy), "pause-buffer", pause_buffer);
- g_object_unref (active_buffer);
- g_object_unref (pause_buffer);
-
for (i = 0; i < messages->len; i++)
{
GValueArray *values = g_ptr_array_index (messages, i);
@@ -378,7 +402,22 @@ debug_window_get_messages_cb (TpProxy *proxy,
}
/* Now we save this precious proxy in the service_store along its service */
- gtk_list_store_set (priv->service_store, &iter, COL_PROXY, proxy, -1);
+ if (valid_iter)
+ {
+ gchar *proxy_service_name;
+
+ gtk_tree_model_get (GTK_TREE_MODEL (priv->service_store), &iter,
+ COL_NAME, &proxy_service_name,
+ -1);
+
+ DEBUG ("Proxy for service: %s was successful in fetching debug"
+ " messages. Saving it.", proxy_service_name);
+ g_free (proxy_service_name);
+
+ gtk_list_store_set (priv->service_store, &iter,
+ COL_PROXY, proxy,
+ -1);
+ }
/* Connect to "invalidated" signal */
g_signal_connect (proxy, "invalidated",
@@ -405,11 +444,14 @@ create_proxy_to_get_messages (EmpathyDebugWindow *debug_window,
EmpathyDebugWindowPriv *priv = GET_PRIV (debug_window);
gchar *bus_name, *name = NULL;
TpProxy *new_proxy, *stored_proxy = NULL;
+ GtkTreeModel *pause_buffer, *active_buffer;
gboolean gone;
gtk_tree_model_get (GTK_TREE_MODEL (priv->service_store), iter,
COL_NAME, &name,
COL_GONE, &gone,
+ COL_ACTIVE_BUFFER, &active_buffer,
+ COL_PAUSE_BUFFER, &pause_buffer,
COL_PROXY, &stored_proxy,
-1);
@@ -435,6 +477,9 @@ create_proxy_to_get_messages (EmpathyDebugWindow *debug_window,
NULL);
g_free (bus_name);
+ g_object_set_data (G_OBJECT (new_proxy), "active-buffer", active_buffer);
+ g_object_set_data (G_OBJECT (new_proxy), "pause-buffer", pause_buffer);
+
/* Now we call GetMessages with fresh proxy.
* The old proxy is NULL due to one of the following -
* * Wasn't saved as last GetMessages call failed
@@ -448,6 +493,8 @@ create_proxy_to_get_messages (EmpathyDebugWindow *debug_window,
finally:
g_free (name);
tp_clear_object (&stored_proxy);
+ g_object_unref (active_buffer);
+ g_object_unref (pause_buffer);
}
static gboolean