aboutsummaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
-rw-r--r--mail/ChangeLog10
-rw-r--r--mail/em-folder-view.c51
-rw-r--r--mail/em-folder-view.h2
-rw-r--r--mail/message-list.c1
4 files changed, 55 insertions, 9 deletions
diff --git a/mail/ChangeLog b/mail/ChangeLog
index ba8f027510..5be75e2f93 100644
--- a/mail/ChangeLog
+++ b/mail/ChangeLog
@@ -1,3 +1,13 @@
+2003-09-19 Jeffrey Stedfast <fejj@ximian.com>
+
+ Fix for bug #48618.
+
+ * em-folder-view.c (emfv_list_message_selected): See if we have
+ already loaded the message uid that has just been selected, if so
+ - don't bother re-loading it.
+ (emfv_list_done_message_selected): Update loaded_uid and
+ loading_uid.
+
2003-09-18 Radek Doulik <rodo@ximian.com>
* em-format-html.c (efh_init): use gtkhtml's blocking
diff --git a/mail/em-folder-view.c b/mail/em-folder-view.c
index d2e6ba629f..c30632cfc7 100644
--- a/mail/em-folder-view.c
+++ b/mail/em-folder-view.c
@@ -106,7 +106,10 @@ static const EMFolderViewEnable emfv_enable_map[];
struct _EMFolderViewPrivate {
guint seen_id;
guint setting_notify_id;
-
+
+ char *loaded_uid;
+ char *loading_uid;
+
CamelObjectHookID folder_changed_id;
GtkWidget *invisible;
@@ -176,7 +179,10 @@ emfv_finalise(GObject *o)
g_slist_free(emfv->ui_files);
g_slist_free(emfv->enable_map);
-
+
+ g_free (p->loaded_uid);
+ g_free (p->loading_uid);
+
g_free(p);
((GObjectClass *)emfv_parent)->finalize(o);
@@ -1583,6 +1589,14 @@ emfv_list_done_message_selected(CamelFolder *folder, const char *uid, CamelMimeM
{
EMFolderView *emfv = data;
+ g_free (emfv->priv->loaded_uid);
+ if (emfv->priv->loading_uid && !strcmp (emfv->priv->loading_uid, uid)) {
+ emfv->priv->loaded_uid = emfv->priv->loading_uid;
+ emfv->priv->loading_uid = NULL;
+ } else {
+ emfv->priv->loaded_uid = g_strdup (uid);
+ }
+
em_format_format((EMFormat *) emfv->preview, (struct _CamelMedium *)msg);
if (emfv->priv->seen_id)
@@ -1591,11 +1605,11 @@ emfv_list_done_message_selected(CamelFolder *folder, const char *uid, CamelMimeM
if (msg && emfv->mark_seen) {
if (emfv->mark_seen_timeout > 0) {
struct mst_t *mst;
-
+
mst = g_new (struct mst_t, 1);
mst->emfv = emfv;
mst->uid = g_strdup (uid);
-
+
emfv->priv->seen_id = g_timeout_add_full(G_PRIORITY_DEFAULT_IDLE, emfv->mark_seen_timeout,
(GSourceFunc)do_mark_seen, mst, (GDestroyNotify)mst_free);
} else {
@@ -1608,12 +1622,35 @@ static void
emfv_list_message_selected(MessageList *ml, const char *uid, EMFolderView *emfv)
{
/* FIXME: ui stuff based on messageinfo, if available */
-
if (emfv->preview_active) {
- if (uid)
+ if (uid != NULL) {
+ if (emfv->priv->loading_uid != NULL) {
+ if (!strcmp (emfv->priv->loading_uid, uid))
+ return;
+ } else if (emfv->priv->loaded_uid != NULL) {
+ if (!strcmp (emfv->priv->loaded_uid, uid))
+ return;
+ }
+
+ g_free (emfv->priv->loading_uid);
+ emfv->priv->loading_uid = g_strdup (uid);
+
mail_get_message(emfv->folder, uid, emfv_list_done_message_selected, emfv, mail_thread_new);
- else
+ } else {
+ g_free (emfv->priv->loaded_uid);
+ emfv->priv->loaded_uid = NULL;
+
+ g_free (emfv->priv->loading_uid);
+ emfv->priv->loading_uid = NULL;
+
em_format_format((EMFormat *)emfv->preview, NULL);
+ }
+ } else {
+ g_free (emfv->priv->loaded_uid);
+ emfv->priv->loaded_uid = NULL;
+
+ g_free (emfv->priv->loading_uid);
+ emfv->priv->loading_uid = NULL;
}
emfv_enable_menus(emfv);
diff --git a/mail/em-folder-view.h b/mail/em-folder-view.h
index 284de69c1b..080b19eb6a 100644
--- a/mail/em-folder-view.h
+++ b/mail/em-folder-view.h
@@ -74,7 +74,7 @@ struct _EMFolderView {
struct _BonoboUIComponent *uic; /* if we're active, this will be set */
GSList *enable_map; /* bonobo menu enable map, entries are 0-terminated EMFolderViewEnable arryas
TODO: should this be on class? */
-
+
int mark_seen_timeout; /* local copy of gconf stuff */
int mark_seen:1;
int preview_active:1; /* is preview being used */
diff --git a/mail/message-list.c b/mail/message-list.c
index a462f412fb..8398518810 100644
--- a/mail/message-list.c
+++ b/mail/message-list.c
@@ -2658,7 +2658,6 @@ on_selection_changed_cmd(ETree *tree, MessageList *ml)
message_list_free_uids(ml, uids);
gtk_selection_owner_set(NULL, GDK_SELECTION_PRIMARY, gtk_get_current_event_time());
}
-
}
static gint