aboutsummaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
-rw-r--r--mail/ChangeLog9
-rw-r--r--mail/em-html-stream.c3
-rw-r--r--mail/em-sync-stream.c7
3 files changed, 19 insertions, 0 deletions
diff --git a/mail/ChangeLog b/mail/ChangeLog
index 5622614a23..750355286a 100644
--- a/mail/ChangeLog
+++ b/mail/ChangeLog
@@ -1,3 +1,12 @@
+2008-06-24 Milan Crha <mcrha@redhat.com>
+
+ ** Fix for bug #537275
+
+ * em-html-stream.c: (emhs_cleanup): Close GtkHTMLStream on cancel.
+ * em-html-stream.c: (emhs_gtkhtml_destroy): Set the cancel.
+ * em-sync-stream.c: (emss_process_message):
+ Do not pass data to the child structure if we were canceled.
+
2008-06-21 Paul Bolle <pebolle@tiscali.nl>
** Fix for bug #539268
diff --git a/mail/em-html-stream.c b/mail/em-html-stream.c
index 656f736969..2644afcf3d 100644
--- a/mail/em-html-stream.c
+++ b/mail/em-html-stream.c
@@ -80,6 +80,8 @@ em_html_stream_init (CamelObject *object)
static void
emhs_cleanup(EMHTMLStream *emhs)
{
+ if (emhs->sync.cancel && emhs->html_stream)
+ gtk_html_stream_close (emhs->html_stream, GTK_HTML_STREAM_ERROR);
emhs->html_stream = NULL;
emhs->sync.cancel = TRUE;
g_signal_handler_disconnect(emhs->html, emhs->destroy_id);
@@ -147,6 +149,7 @@ static void
emhs_gtkhtml_destroy(struct _GtkHTML *html, EMHTMLStream *emhs)
{
d(printf("%p: emhs gtkhtml destroy\n", emhs));
+ emhs->sync.cancel = TRUE;
emhs_cleanup(emhs);
}
diff --git a/mail/em-sync-stream.c b/mail/em-sync-stream.c
index e8aad7f31c..82c8b20aeb 100644
--- a/mail/em-sync-stream.c
+++ b/mail/em-sync-stream.c
@@ -59,6 +59,13 @@ emss_process_message (struct _write_msg *msg)
{
struct _EMSyncStream *emss = msg->emss;
+ if (emss->cancel) {
+ /* Do not pass data to the child if we are canceled. */
+ e_flag_set (msg->done);
+
+ return FALSE;
+ }
+
/* Force out any pending data before doing anything else. */
if (emss->buffer != NULL && emss->buffer->len > 0) {
EMSS_CLASS (emss)->sync_write (