empathy r1906 - trunk/src
- From: xclaesse svn gnome org
- To: svn-commits-list gnome org
- Subject: empathy r1906 - trunk/src
- Date: Fri, 21 Nov 2008 16:24:44 +0000 (UTC)
Author: xclaesse
Date: Fri Nov 21 16:24:44 2008
New Revision: 1906
URL: http://svn.gnome.org/viewvc/empathy?rev=1906&view=rev
Log:
Update the selection only if we are removing the selected row.
Modified:
trunk/src/empathy-ft-manager.c
Modified: trunk/src/empathy-ft-manager.c
==============================================================================
--- trunk/src/empathy-ft-manager.c (original)
+++ trunk/src/empathy-ft-manager.c Fri Nov 21 16:24:44 2008
@@ -448,7 +448,7 @@
GtkTreeSelection *selection;
GtkTreePath *path = NULL;
GtkTreeIter iter;
- gboolean empty = FALSE;
+ gboolean update_selection;
row_ref = ft_manager_get_row_from_tp_file (ft_manager, tp_file);
g_return_if_fail (row_ref);
@@ -457,10 +457,16 @@
empathy_contact_get_name (empathy_tp_file_get_contact (tp_file)),
empathy_tp_file_get_filename (tp_file));
- /* Remove tp_file's row. After that iter points to the new row to select */
+ /* Get the iter from the row_ref */
path = gtk_tree_row_reference_get_path (row_ref);
gtk_tree_model_get_iter (ft_manager->priv->model, &iter, path);
gtk_tree_path_free (path);
+
+ /* We have to update the selection only if we are removing the selected row */
+ selection = gtk_tree_view_get_selection (GTK_TREE_VIEW (ft_manager->priv->treeview));
+ update_selection = gtk_tree_selection_iter_is_selected (selection, &iter);
+
+ /* Remove tp_file's row. After that iter points to the next row */
if (!gtk_list_store_remove (GTK_LIST_STORE (ft_manager->priv->model), &iter))
{
gint n_row;
@@ -471,15 +477,11 @@
gtk_tree_model_iter_nth_child (ft_manager->priv->model, &iter, NULL,
n_row - 1);
else
- empty = TRUE;
+ update_selection = FALSE;
}
- /* Select the next row */
- if (!empty)
- {
- selection = gtk_tree_view_get_selection (GTK_TREE_VIEW (ft_manager->priv->treeview));
- gtk_tree_selection_select_iter (selection, &iter);
- }
+ if (update_selection)
+ gtk_tree_selection_select_iter (selection, &iter);
}
static gboolean
[
Date Prev][
Date Next] [
Thread Prev][
Thread Next]
[
Thread Index]
[
Date Index]
[
Author Index]