aboutsummaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
-rw-r--r--mail/message-list.c98
1 files changed, 53 insertions, 45 deletions
diff --git a/mail/message-list.c b/mail/message-list.c
index 03a371c677..ffa20e166f 100644
--- a/mail/message-list.c
+++ b/mail/message-list.c
@@ -174,6 +174,9 @@ static void message_list_selectable_init
(ESelectableInterface *interface);
static void message_list_tree_model_init
(ETreeModelInterface *interface);
+static gboolean message_list_get_hide_deleted
+ (MessageList *message_list,
+ CamelFolder *folder);
G_DEFINE_TYPE_WITH_CODE (
MessageList,
@@ -340,6 +343,7 @@ regen_data_new (MessageList *message_list,
RegenData *regen_data;
EActivity *activity;
EMailSession *session;
+ gboolean searching;
activity = e_activity_new ();
e_activity_set_cancellable (activity, cancellable);
@@ -352,12 +356,60 @@ regen_data_new (MessageList *message_list,
regen_data->last_row = -1;
/* Capture MessageList state to use for this regen. */
- regen_data->folder = message_list_ref_folder (message_list);
+
+ regen_data->folder =
+ message_list_ref_folder (message_list);
regen_data->group_by_threads =
message_list_get_group_by_threads (message_list);
regen_data->thread_subject =
message_list_get_thread_subject (message_list);
+ if (message_list->thread_tree != NULL) {
+ CamelFolderThread *thread_tree;
+ gboolean hide_deleted;
+
+ thread_tree = message_list->thread_tree;
+ hide_deleted = message_list_get_hide_deleted (
+ message_list, regen_data->folder);
+
+ if (regen_data->group_by_threads && hide_deleted) {
+ regen_data->tree = thread_tree;
+ camel_folder_thread_messages_ref (thread_tree);
+ } else {
+ camel_folder_thread_messages_unref (thread_tree);
+ message_list->thread_tree = NULL;
+ }
+ }
+
+ searching = (g_strcmp0 (message_list->search, " ") != 0);
+
+ if (e_tree_row_count (E_TREE (message_list)) <= 0) {
+ if (gtk_widget_get_visible (GTK_WIDGET (message_list))) {
+ gchar *txt;
+
+ txt = g_strdup_printf (
+ "%s...", _("Generating message list"));
+ e_tree_set_info_message (E_TREE (message_list), txt);
+ g_free (txt);
+ }
+
+ } else if (regen_data->group_by_threads &&
+ !message_list->just_set_folder &&
+ !searching) {
+
+ if (message_list->priv->any_row_changed) {
+ /* Something changed. If it was an expand
+ * state change, then save the expand state. */
+ message_list_save_state (message_list);
+ } else {
+ /* Remember the expand state and restore it
+ * after regen. */
+ regen_data->expand_state =
+ e_tree_save_expanded_state_xml (
+ E_TREE (message_list));
+ }
+ }
+
g_mutex_init (&regen_data->select_lock);
session = message_list_get_session (message_list);
@@ -5507,7 +5559,6 @@ mail_regen_list (MessageList *message_list,
GCancellable *cancellable;
RegenData *new_regen_data;
RegenData *old_regen_data;
- gboolean searching;
/* Report empty search as NULL, not as one/two-space string. */
if (search && (strcmp (search, " ") == 0 || strcmp (search, " ") == 0))
@@ -5526,49 +5577,6 @@ mail_regen_list (MessageList *message_list,
new_regen_data->search = g_strdup (search);
new_regen_data->folder_changed = folder_changed;
- if (message_list->thread_tree != NULL) {
- CamelFolderThread *thread_tree;
- gboolean hide_deleted;
-
- thread_tree = message_list->thread_tree;
- hide_deleted = message_list_get_hide_deleted (
- message_list, new_regen_data->folder);
-
- if (new_regen_data->group_by_threads && hide_deleted) {
- new_regen_data->tree = thread_tree;
- camel_folder_thread_messages_ref (thread_tree);
- } else {
- camel_folder_thread_messages_unref (thread_tree);
- message_list->thread_tree = NULL;
- }
- }
-
- searching = (g_strcmp0 (message_list->search, " ") != 0);
-
- if (e_tree_row_count (E_TREE (message_list)) <= 0) {
- if (gtk_widget_get_visible (GTK_WIDGET (message_list))) {
- gchar *txt;
-
- txt = g_strdup_printf (
- "%s...", _("Generating message list"));
- e_tree_set_info_message (E_TREE (message_list), txt);
- g_free (txt);
- }
- } else if (message_list->priv->any_row_changed &&
- new_regen_data->group_by_threads &&
- !message_list->just_set_folder &&
- !searching) {
- /* Something changed. If it was an expand
- * state change, then save the expand state. */
- message_list_save_state (message_list);
- } else if (new_regen_data->group_by_threads &&
- !message_list->just_set_folder &&
- !searching) {
- /* Remember the expand state and restore it after regen. */
- new_regen_data->expand_state =
- e_tree_save_expanded_state_xml (E_TREE (message_list));
- }
-
/* We generate the message list content in a worker thread, and
* then supply our own GAsyncReadyCallback to redraw the widget. */