|
|
b1a0e4 |
diff -up evolution-3.8.5/mail/e-mail-browser.c.evo-browser-filtered-1090629 evolution-3.8.5/mail/e-mail-browser.c
|
|
|
b1a0e4 |
--- evolution-3.8.5/mail/e-mail-browser.c.evo-browser-filtered-1090629 2013-07-23 14:51:50.000000000 +0200
|
|
|
b1a0e4 |
+++ evolution-3.8.5/mail/e-mail-browser.c 2014-05-13 14:52:16.545888674 +0200
|
|
|
b1a0e4 |
@@ -1014,8 +1014,6 @@ e_mail_browser_init (EMailBrowser *brows
|
|
|
b1a0e4 |
|
|
|
b1a0e4 |
GtkWidget *
|
|
|
b1a0e4 |
e_mail_browser_new (EMailBackend *backend,
|
|
|
b1a0e4 |
- CamelFolder *folder,
|
|
|
b1a0e4 |
- const gchar *msg_uid,
|
|
|
b1a0e4 |
EMailFormatterMode display_mode)
|
|
|
b1a0e4 |
{
|
|
|
b1a0e4 |
g_return_val_if_fail (E_IS_MAIL_BACKEND (backend), NULL);
|
|
|
b1a0e4 |
diff -up evolution-3.8.5/mail/e-mail-browser.h.evo-browser-filtered-1090629 evolution-3.8.5/mail/e-mail-browser.h
|
|
|
b1a0e4 |
--- evolution-3.8.5/mail/e-mail-browser.h.evo-browser-filtered-1090629 2013-07-23 14:51:53.000000000 +0200
|
|
|
b1a0e4 |
+++ evolution-3.8.5/mail/e-mail-browser.h 2014-05-13 14:52:16.545888674 +0200
|
|
|
b1a0e4 |
@@ -62,8 +62,6 @@ struct _EMailBrowserClass {
|
|
|
b1a0e4 |
|
|
|
b1a0e4 |
GType e_mail_browser_get_type (void);
|
|
|
b1a0e4 |
GtkWidget * e_mail_browser_new (EMailBackend *backend,
|
|
|
b1a0e4 |
- CamelFolder *folder,
|
|
|
b1a0e4 |
- const gchar *message_uid,
|
|
|
b1a0e4 |
EMailFormatterMode display_mode);
|
|
|
b1a0e4 |
void e_mail_browser_close (EMailBrowser *browser);
|
|
|
b1a0e4 |
EMailFormatterMode
|
|
|
b1a0e4 |
diff -up evolution-3.8.5/mail/e-mail-reader-utils.c.evo-browser-filtered-1090629 evolution-3.8.5/mail/e-mail-reader-utils.c
|
|
|
b1a0e4 |
--- evolution-3.8.5/mail/e-mail-reader-utils.c.evo-browser-filtered-1090629 2013-07-23 14:51:51.000000000 +0200
|
|
|
b1a0e4 |
+++ evolution-3.8.5/mail/e-mail-reader-utils.c 2014-05-13 14:52:16.546888674 +0200
|
|
|
b1a0e4 |
@@ -875,17 +875,15 @@ e_mail_reader_open_selected (EMailReader
|
|
|
b1a0e4 |
GtkWidget *browser;
|
|
|
b1a0e4 |
MessageList *ml;
|
|
|
b1a0e4 |
|
|
|
b1a0e4 |
- browser = e_mail_browser_new (
|
|
|
b1a0e4 |
- backend, folder, uid,
|
|
|
b1a0e4 |
- E_MAIL_FORMATTER_MODE_NORMAL);
|
|
|
b1a0e4 |
-
|
|
|
b1a0e4 |
- e_mail_reader_set_folder (E_MAIL_READER (browser), folder);
|
|
|
b1a0e4 |
- e_mail_reader_set_message (E_MAIL_READER (browser), uid);
|
|
|
b1a0e4 |
+ browser = e_mail_browser_new (backend, E_MAIL_FORMATTER_MODE_NORMAL);
|
|
|
b1a0e4 |
|
|
|
b1a0e4 |
ml = MESSAGE_LIST (e_mail_reader_get_message_list (
|
|
|
b1a0e4 |
E_MAIL_READER (browser)));
|
|
|
b1a0e4 |
message_list_freeze (ml);
|
|
|
b1a0e4 |
|
|
|
b1a0e4 |
+ e_mail_reader_set_folder (E_MAIL_READER (browser), folder);
|
|
|
b1a0e4 |
+ e_mail_reader_set_message (E_MAIL_READER (browser), uid);
|
|
|
b1a0e4 |
+
|
|
|
b1a0e4 |
copy_tree_state (reader, E_MAIL_READER (browser));
|
|
|
b1a0e4 |
e_mail_reader_set_group_by_threads (
|
|
|
b1a0e4 |
E_MAIL_READER (browser),
|
|
|
b1a0e4 |
diff -up evolution-3.8.5/mail/e-mail-reader.c.evo-browser-filtered-1090629 evolution-3.8.5/mail/e-mail-reader.c
|
|
|
b1a0e4 |
--- evolution-3.8.5/mail/e-mail-reader.c.evo-browser-filtered-1090629 2014-05-13 14:52:16.534888675 +0200
|
|
|
b1a0e4 |
+++ evolution-3.8.5/mail/e-mail-reader.c 2014-05-13 14:52:16.546888674 +0200
|
|
|
b1a0e4 |
@@ -1772,6 +1772,7 @@ action_mail_show_source_cb (GtkAction *a
|
|
|
b1a0e4 |
EActivity *activity;
|
|
|
b1a0e4 |
GCancellable *cancellable;
|
|
|
b1a0e4 |
EMailReaderClosure *closure;
|
|
|
b1a0e4 |
+ MessageList *ml;
|
|
|
b1a0e4 |
|
|
|
b1a0e4 |
backend = e_mail_reader_get_backend (reader);
|
|
|
b1a0e4 |
folder = e_mail_reader_get_folder (reader);
|
|
|
b1a0e4 |
@@ -1779,10 +1780,14 @@ action_mail_show_source_cb (GtkAction *a
|
|
|
b1a0e4 |
g_return_if_fail (uids != NULL && uids->len == 1);
|
|
|
b1a0e4 |
message_uid = g_ptr_array_index (uids, 0);
|
|
|
b1a0e4 |
|
|
|
b1a0e4 |
- browser = e_mail_browser_new (
|
|
|
b1a0e4 |
- backend, NULL, NULL, E_MAIL_FORMATTER_MODE_SOURCE);
|
|
|
b1a0e4 |
+ browser = e_mail_browser_new (backend, E_MAIL_FORMATTER_MODE_SOURCE);
|
|
|
b1a0e4 |
+ ml = MESSAGE_LIST (e_mail_reader_get_message_list (E_MAIL_READER (browser)));
|
|
|
b1a0e4 |
+
|
|
|
b1a0e4 |
+ message_list_freeze (ml);
|
|
|
b1a0e4 |
e_mail_reader_set_folder (E_MAIL_READER (browser), folder);
|
|
|
b1a0e4 |
e_mail_reader_set_message (E_MAIL_READER (browser), message_uid);
|
|
|
b1a0e4 |
+ message_list_thaw (ml);
|
|
|
b1a0e4 |
+
|
|
|
b1a0e4 |
display = e_mail_reader_get_mail_display (E_MAIL_READER (browser));
|
|
|
b1a0e4 |
|
|
|
b1a0e4 |
string = g_strdup_printf (_("Retrieving message '%s'"), message_uid);
|
|
|
b1a0e4 |
diff -up evolution-3.8.5/mail/message-list.c.evo-browser-filtered-1090629 evolution-3.8.5/mail/message-list.c
|
|
|
b1a0e4 |
--- evolution-3.8.5/mail/message-list.c.evo-browser-filtered-1090629 2014-05-13 14:52:16.543888674 +0200
|
|
|
b1a0e4 |
+++ evolution-3.8.5/mail/message-list.c 2014-05-13 14:52:16.547888674 +0200
|
|
|
b1a0e4 |
@@ -750,6 +750,12 @@ message_list_select_uid (MessageList *me
|
|
|
b1a0e4 |
message_list,
|
|
|
b1a0e4 |
message_list_signals[MESSAGE_SELECTED],
|
|
|
b1a0e4 |
0, message_list->cursor_uid);
|
|
|
b1a0e4 |
+ } else if (message_list->just_set_folder) {
|
|
|
b1a0e4 |
+ g_free (message_list->cursor_uid);
|
|
|
b1a0e4 |
+ message_list->cursor_uid = g_strdup (uid);
|
|
|
b1a0e4 |
+ g_signal_emit (
|
|
|
b1a0e4 |
+ message_list,
|
|
|
b1a0e4 |
+ message_list_signals[MESSAGE_SELECTED], 0, message_list->cursor_uid);
|
|
|
b1a0e4 |
} else {
|
|
|
b1a0e4 |
g_free (message_list->cursor_uid);
|
|
|
b1a0e4 |
message_list->cursor_uid = NULL;
|
|
|
b1a0e4 |
@@ -4903,6 +4909,13 @@ regen_list_done (struct _regen_list_msg
|
|
|
b1a0e4 |
with_fallback = m->ml->pending_select_fallback;
|
|
|
b1a0e4 |
message_list_select_uid (m->ml, uid, with_fallback);
|
|
|
b1a0e4 |
g_free (uid);
|
|
|
b1a0e4 |
+ } else if (m->ml->regen == NULL && m->ml->ensure_uid) {
|
|
|
b1a0e4 |
+ gchar *uid;
|
|
|
b1a0e4 |
+
|
|
|
b1a0e4 |
+ uid = m->ml->ensure_uid;
|
|
|
b1a0e4 |
+ m->ml->ensure_uid = NULL;
|
|
|
b1a0e4 |
+ message_list_select_uid (m->ml, uid, FALSE);
|
|
|
b1a0e4 |
+ g_free (uid);
|
|
|
b1a0e4 |
} else if (m->ml->regen == NULL && m->ml->cursor_uid == NULL && m->last_row != -1) {
|
|
|
b1a0e4 |
ETreeTableAdapter *etta = e_tree_get_table_adapter (tree);
|
|
|
b1a0e4 |
|
|
|
b1a0e4 |
@@ -4918,6 +4931,8 @@ regen_list_done (struct _regen_list_msg
|
|
|
b1a0e4 |
}
|
|
|
b1a0e4 |
}
|
|
|
b1a0e4 |
|
|
|
b1a0e4 |
+ message_list_ensure_message (m->ml, NULL);
|
|
|
b1a0e4 |
+
|
|
|
b1a0e4 |
if (gtk_widget_get_visible (GTK_WIDGET (m->ml))) {
|
|
|
b1a0e4 |
if (e_tree_row_count (E_TREE (m->ml)) <= 0) {
|
|
|
b1a0e4 |
/* space is used to indicate no search too */
|
|
|
b1a0e4 |
@@ -5079,6 +5094,9 @@ mail_regen_list (MessageList *ml,
|
|
|
b1a0e4 |
m->last_row = -1;
|
|
|
b1a0e4 |
m->expand_state = NULL;
|
|
|
b1a0e4 |
|
|
|
b1a0e4 |
+ if (ml->just_set_folder && ml->cursor_uid)
|
|
|
b1a0e4 |
+ message_list_ensure_message (ml, ml->cursor_uid);
|
|
|
b1a0e4 |
+
|
|
|
b1a0e4 |
if ((!m->hidedel || !m->dotree) && ml->thread_tree) {
|
|
|
b1a0e4 |
camel_folder_thread_messages_unref (ml->thread_tree);
|
|
|
b1a0e4 |
ml->thread_tree = NULL;
|