aboutsummaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
authorDan Winship <danw@src.gnome.org>2000-04-27 06:46:52 +0800
committerDan Winship <danw@src.gnome.org>2000-04-27 06:46:52 +0800
commite71125295c1a0d0566b9819bc6a02cd4c141376c (patch)
tree0d0038524591c44d1ff03e78d332c556bd06a634
parent434cc3df82352563a7df783cf1e14a9b0b75ab2d (diff)
downloadgsoc2013-evolution-e71125295c1a0d0566b9819bc6a02cd4c141376c.tar.gz
gsoc2013-evolution-e71125295c1a0d0566b9819bc6a02cd4c141376c.tar.zst
gsoc2013-evolution-e71125295c1a0d0566b9819bc6a02cd4c141376c.zip
Oops. Fix previous commit so we don't get a mime part nested directly
inside a mime part svn path=/trunk/; revision=2651
-rw-r--r--composer/e-msg-composer.c20
1 files changed, 15 insertions, 5 deletions
diff --git a/composer/e-msg-composer.c b/composer/e-msg-composer.c
index d404146351..a4866711e3 100644
--- a/composer/e-msg-composer.c
+++ b/composer/e-msg-composer.c
@@ -135,7 +135,6 @@ static CamelMimeMessage *
build_message (EMsgComposer *composer)
{
CamelMimeMessage *new;
- CamelMimePart *part;
char *text;
int i;
@@ -149,14 +148,15 @@ build_message (EMsgComposer *composer)
composer->extra_hdr_values->pdata[i]);
}
- part = camel_mime_part_new ();
text = get_editor_text (BONOBO_WIDGET (composer->editor));
- camel_mime_part_set_content (part, text, strlen (text), "text/html");
- g_free (text);
if (e_msg_composer_attachment_bar_get_num_attachments (E_MSG_COMPOSER_ATTACHMENT_BAR (composer->attachment_bar))) {
CamelMultipart *multipart = camel_multipart_new ();
+ CamelMimePart *part;
+ part = camel_mime_part_new ();
+ camel_mime_part_set_content (part, text,
+ strlen (text), "text/html");
camel_multipart_add_part (multipart, part);
e_msg_composer_attachment_bar_to_multipart (E_MSG_COMPOSER_ATTACHMENT_BAR (composer->attachment_bar), multipart);
@@ -164,9 +164,19 @@ build_message (EMsgComposer *composer)
camel_medium_set_content_object (CAMEL_MEDIUM (new),
CAMEL_DATA_WRAPPER (multipart));
} else {
+ CamelDataWrapper *cdw;
+ CamelStream *stream;
+
+ stream = camel_stream_mem_new_with_buffer (text,
+ strlen (text));
+ cdw = camel_data_wrapper_new ();
+ camel_data_wrapper_construct_from_stream (cdw, stream);
+ camel_data_wrapper_set_mime_type (cdw, "text/html");
+
camel_medium_set_content_object (CAMEL_MEDIUM (new),
- CAMEL_DATA_WRAPPER (part));
+ CAMEL_DATA_WRAPPER (cdw));
}
+ g_free (text);
/* FIXME refcounting is most certainly wrong. We want all the stuff to
be destroyed when we unref() the message. */