From 347d200c0b02fd27ae23f2953806adc8b0b88d32 Mon Sep 17 00:00:00 2001 From: Guillaume Desmottes Date: Mon, 7 Mar 2011 11:03:33 +0100 Subject: factor out select_and_scroll_to_iter() --- src/empathy-accounts-dialog.c | 37 +++++++++++++++++++++++-------------- 1 file changed, 23 insertions(+), 14 deletions(-) diff --git a/src/empathy-accounts-dialog.c b/src/empathy-accounts-dialog.c index d7039bcb3..964b9dd58 100644 --- a/src/empathy-accounts-dialog.c +++ b/src/empathy-accounts-dialog.c @@ -1609,6 +1609,28 @@ accounts_dialog_get_account_iter (EmpathyAccountsDialog *dialog, return FALSE; } +static void +select_and_scroll_to_iter (EmpathyAccountsDialog *dialog, + GtkTreeIter *iter) +{ + EmpathyAccountsDialogPriv *priv = GET_PRIV (dialog); + GtkTreeSelection *selection; + GtkTreePath *path; + GtkTreeModel *model; + + selection = gtk_tree_view_get_selection (GTK_TREE_VIEW (priv->treeview)); + + gtk_tree_selection_select_iter (selection, iter); + + model = gtk_tree_view_get_model (GTK_TREE_VIEW (priv->treeview)); + path = gtk_tree_model_get_path (model, iter); + + gtk_tree_view_scroll_to_cell (GTK_TREE_VIEW (priv->treeview), path, NULL, + TRUE, 0, 0.5); + + gtk_tree_path_free (path); +} + static void accounts_dialog_model_set_selected (EmpathyAccountsDialog *dialog, EmpathyAccountSettings *settings) @@ -1957,20 +1979,7 @@ accounts_dialog_set_selected_account (EmpathyAccountsDialog *dialog, selection = gtk_tree_view_get_selection (GTK_TREE_VIEW (priv->treeview)); if (accounts_dialog_get_account_iter (dialog, account, &iter)) - { - GtkTreePath *path; - GtkTreeModel *model; - - gtk_tree_selection_select_iter (selection, &iter); - - model = gtk_tree_view_get_model (GTK_TREE_VIEW (priv->treeview)); - path = gtk_tree_model_get_path (model, &iter); - - gtk_tree_view_scroll_to_cell (GTK_TREE_VIEW (priv->treeview), path, NULL, - TRUE, 0, 0.5); - - gtk_tree_path_free (path); - } + select_and_scroll_to_iter (dialog, &iter); } static void -- cgit v1.2.3