diff options
-rw-r--r-- | mail/ChangeLog | 22 | ||||
-rw-r--r-- | mail/em-folder-browser.c | 6 | ||||
-rw-r--r-- | mail/em-folder-view.c | 2 | ||||
-rw-r--r-- | mail/message-list.c | 45 | ||||
-rw-r--r-- | mail/message-list.h | 10 |
5 files changed, 74 insertions, 11 deletions
diff --git a/mail/ChangeLog b/mail/ChangeLog index b210c34123..aba87e47a2 100644 --- a/mail/ChangeLog +++ b/mail/ChangeLog @@ -1,5 +1,27 @@ 2004-04-14 Not Zed <NotZed@Ximian.com> + * em-folder-view.c (emfv_set_folder_uri): ugh, use the queued + thread to get the folder, otherwise we can get folders set on the + display out of order. + + * message-list.c (message_list_set_search): if we set this while + frozen, save the search elsewhere. + (message_list_thaw): if we had a frozen-time search, use it when + we regenerate. + + * em-folder-browser.c (emfb_set_folder): freeze/thaw the + messagelist around changes so we don't have multiple updates fire + off changing folders. + (emfb_activate): remove an unused variable i never used. + + * message-list.c (message_list_freeze, message_list_thaw): lock + some updates to the ui, so you can do things like set folder and + search atomically. + (message_list_set_threaded, message_list_set_hidedeleted) + (message_list_set_search, message_list_hide_uids) + (message_list_hide_clear, message_list_set_folder): dont refresh + the list if we're frozen. + * mail-component.c (impl_createControls): remove debug comment. ** See #56641. diff --git a/mail/em-folder-browser.c b/mail/em-folder-browser.c index 38eece3e5d..3da05dd3da 100644 --- a/mail/em-folder-browser.c +++ b/mail/em-folder-browser.c @@ -916,6 +916,8 @@ emfb_set_folder(EMFolderView *emfv, CamelFolder *folder, const char *uri) EMFolderBrowser *emfb = (EMFolderBrowser *) emfv; struct _EMFolderBrowserPrivate *p = emfb->priv; + message_list_freeze(emfv->list); + emfb_parent->set_folder(emfv, folder, uri); /* This is required since we get activated the first time @@ -968,6 +970,8 @@ emfb_set_folder(EMFolderView *emfv, CamelFolder *folder, const char *uri) if (emfv->uic) emfb_create_view_menus (emfb, emfv->uic); } + + message_list_thaw(emfv->list); } /* TODO: All this mess should sit directly on MessageList, but it would @@ -1012,7 +1016,7 @@ emfb_activate(EMFolderView *emfv, BonoboUIComponent *uic, int act) if (act) { GConfClient *gconf; - gboolean state, newstate; + gboolean state; char *sstate; gconf = mail_config_get_gconf_client (); diff --git a/mail/em-folder-view.c b/mail/em-folder-view.c index 83523b0782..f2be4ea56d 100644 --- a/mail/em-folder-view.c +++ b/mail/em-folder-view.c @@ -418,7 +418,7 @@ emfv_got_folder(char *uri, CamelFolder *folder, void *data) static void emfv_set_folder_uri(EMFolderView *emfv, const char *uri) { - mail_get_folder(uri, 0, emfv_got_folder, emfv, mail_thread_new); + mail_get_folder(uri, 0, emfv_got_folder, emfv, mail_thread_queued); } static void diff --git a/mail/message-list.c b/mail/message-list.c index 645c16933a..a8e2e85d58 100644 --- a/mail/message-list.c +++ b/mail/message-list.c @@ -1686,6 +1686,7 @@ message_list_finalise (GObject *object) message_list->hidden_pool = NULL; } + g_free(message_list->frozen_search); g_free(message_list->cursor_uid); g_mutex_free(message_list->hide_lock); @@ -2592,7 +2593,8 @@ message_list_set_folder (MessageList *message_list, CamelFolder *folder, const c message_list->hidejunk = junk_folder && !(folder->folder_flags & CAMEL_FOLDER_IS_JUNK) && !(folder->folder_flags & CAMEL_FOLDER_IS_TRASH); load_hide_state (message_list); - mail_regen_list (message_list, message_list->search, NULL, NULL); + if (message_list->frozen == 0) + mail_regen_list (message_list, message_list->search, NULL, NULL); } } @@ -2771,6 +2773,25 @@ message_list_get_selected(MessageList *ml) return data.uids; } +void +message_list_freeze(MessageList *ml) +{ + ml->frozen++; +} + +void +message_list_thaw(MessageList *ml) +{ + g_assert(ml->frozen != 0); + + ml->frozen--; + if (ml->frozen == 0) { + mail_regen_list(ml, ml->frozen_search?ml->frozen_search:ml->search, NULL, NULL); + g_free(ml->frozen_search); + ml->frozen_search = NULL; + } +} + void message_list_free_uids(MessageList *ml, GPtrArray *uids) { int i; @@ -2787,7 +2808,8 @@ message_list_set_threaded (MessageList *ml, gboolean threaded) if (ml->threaded != threaded) { ml->threaded = threaded; - mail_regen_list (ml, ml->search, NULL, NULL); + if (ml->frozen == 0) + mail_regen_list (ml, ml->search, NULL, NULL); } } @@ -2797,7 +2819,8 @@ message_list_set_hidedeleted (MessageList *ml, gboolean hidedeleted) if (ml->hidedeleted != hidedeleted) { ml->hidedeleted = hidedeleted; - mail_regen_list (ml, ml->search, NULL, NULL); + if (ml->frozen == 0) + mail_regen_list (ml, ml->search, NULL, NULL); } } @@ -2815,8 +2838,13 @@ message_list_set_search (MessageList *ml, const char *search) camel_folder_thread_messages_unref(ml->thread_tree); ml->thread_tree = NULL; } - - mail_regen_list (ml, search, NULL, NULL); + + if (ml->frozen == 0) + mail_regen_list (ml, search, NULL, NULL); + else { + g_free(ml->frozen_search); + ml->frozen_search = g_strdup(search); + } } /* returns the number of messages displayable *after* expression hiding has taken place */ @@ -2862,7 +2890,6 @@ message_list_hidden(MessageList *ml) return hidden; } - /* add a new expression to hide, or set the range. @expr: A new search expression - all matching messages will be hidden. May be %NULL. @lower: Use ML_HIDE_NONE_START to specify no messages hidden from the start of the list. @@ -2918,7 +2945,8 @@ message_list_hide_uids (MessageList *ml, GPtrArray *uids) MESSAGE_LIST_UNLOCK (ml, hide_lock); /* save this here incase the user pops up another window, so they are consistent */ save_hide_state(ml); - mail_regen_list (ml, ml->search, NULL, NULL); + if (ml->frozen == 0) + mail_regen_list (ml, ml->search, NULL, NULL); break; } } @@ -2946,7 +2974,8 @@ message_list_hide_clear (MessageList *ml) /* save this here incase the user pops up another window, so they are consistent */ save_hide_state(ml); - mail_regen_list (ml, ml->search, NULL, NULL); + if (ml->frozen == 0) + mail_regen_list (ml, ml->search, NULL, NULL); } #define HIDE_STATE_VERSION (1) diff --git a/mail/message-list.h b/mail/message-list.h index 5d88d28692..8c47a12ab2 100644 --- a/mail/message-list.h +++ b/mail/message-list.h @@ -119,7 +119,10 @@ struct _MessageList { /* is the message-list object in a destroyed state? */ guint destroyed : 1; - + + /* frozen count */ + guint frozen:16; + /* Where the ETree cursor is. */ int cursor_row; char *cursor_uid; @@ -134,6 +137,8 @@ struct _MessageList { GList *regen; char *pending_select_uid; /* set if we were busy regnerating while we had a select come in */ + char *frozen_search; /* to save search took place while we were frozen */ + /* the current camel folder thread tree, if any */ struct _CamelFolderThread *thread_tree; @@ -166,6 +171,9 @@ void message_list_foreach (MessageList *message_list, MessageListForeachFunc callback, gpointer user_data); +void message_list_freeze(MessageList *ml); +void message_list_thaw(MessageList *ml); + GPtrArray *message_list_get_selected(MessageList *ml); void message_list_free_uids(MessageList *ml, GPtrArray *uids); |