aboutsummaryrefslogtreecommitdiffstats
path: root/composer/e-msg-composer.c
diff options
context:
space:
mode:
authorJeffrey Stedfast <fejj@ximian.com>2002-10-02 05:21:03 +0800
committerJeffrey Stedfast <fejj@src.gnome.org>2002-10-02 05:21:03 +0800
commit8427b2c852ed5200e28aaee5f8a74c678d931b25 (patch)
treea91bbd393709c01b1cd770b044b759e846b1ee20 /composer/e-msg-composer.c
parentc0edd5dede35f46b26984b4b14af1e0e592f4dd8 (diff)
downloadgsoc2013-evolution-8427b2c852ed5200e28aaee5f8a74c678d931b25.tar
gsoc2013-evolution-8427b2c852ed5200e28aaee5f8a74c678d931b25.tar.gz
gsoc2013-evolution-8427b2c852ed5200e28aaee5f8a74c678d931b25.tar.bz2
gsoc2013-evolution-8427b2c852ed5200e28aaee5f8a74c678d931b25.tar.lz
gsoc2013-evolution-8427b2c852ed5200e28aaee5f8a74c678d931b25.tar.xz
gsoc2013-evolution-8427b2c852ed5200e28aaee5f8a74c678d931b25.tar.zst
gsoc2013-evolution-8427b2c852ed5200e28aaee5f8a74c678d931b25.zip
When signing/encrypting a part, if a USER_CANCEL occurs, re-use the part
2002-10-01 Jeffrey Stedfast <fejj@ximian.com> * e-msg-composer.c (build_message): When signing/encrypting a part, if a USER_CANCEL occurs, re-use the part otherwise unref it and replace it with the new part. svn path=/trunk/; revision=18290
Diffstat (limited to 'composer/e-msg-composer.c')
-rw-r--r--composer/e-msg-composer.c6
1 files changed, 4 insertions, 2 deletions
diff --git a/composer/e-msg-composer.c b/composer/e-msg-composer.c
index 1dfe6667fe..383f8e5475 100644
--- a/composer/e-msg-composer.c
+++ b/composer/e-msg-composer.c
@@ -526,7 +526,6 @@ build_message (EMsgComposer *composer, gboolean save_html_object_data)
mps = camel_multipart_signed_new ();
camel_multipart_signed_sign (mps, cipher, part, userid, CAMEL_CIPHER_HASH_SHA1, &ex);
camel_object_unref (cipher);
- camel_object_unref (part);
if (from)
camel_object_unref (from);
@@ -536,10 +535,12 @@ build_message (EMsgComposer *composer, gboolean save_html_object_data)
if (camel_exception_get_id (&ex) == CAMEL_EXCEPTION_USER_CANCEL) {
camel_exception_clear (&ex);
} else {
+ camel_object_unref (part);
camel_object_unref (mps);
goto exception;
}
} else {
+ camel_object_unref (part);
part = camel_mime_part_new ();
camel_multipart_set_boundary (CAMEL_MULTIPART (mps), NULL);
camel_medium_set_content_object (CAMEL_MEDIUM (part), (CamelDataWrapper *) mps);
@@ -602,7 +603,6 @@ build_message (EMsgComposer *composer, gboolean save_html_object_data)
camel_multipart_encrypted_encrypt (mpe, part, cipher, userid, recipients, &ex);
camel_object_unref (cipher);
- camel_object_unref (part);
if (from)
camel_object_unref (from);
@@ -617,9 +617,11 @@ build_message (EMsgComposer *composer, gboolean save_html_object_data)
camel_exception_clear (&ex);
} else {
camel_object_unref (mpe);
+ camel_object_unref (part);
goto exception;
}
} else {
+ camel_object_unref (part);
part = camel_mime_part_new ();
camel_multipart_set_boundary (CAMEL_MULTIPART (mpe), NULL);
camel_medium_set_content_object (CAMEL_MEDIUM (part), (CamelDataWrapper *) mpe);