aboutsummaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
authorMilan Crha <mcrha@redhat.com>2013-11-20 23:31:15 +0800
committerMilan Crha <mcrha@redhat.com>2013-11-20 23:32:29 +0800
commit76c77aaebccbf5df6ee4206705ceb24858e1cb41 (patch)
tree12fbfbd03d33060870ca367cbb396c57649874c1
parentaf3f22dba8f4402ea45060eb041f61af7f598c29 (diff)
downloadgsoc2013-evolution-76c77aaebccbf5df6ee4206705ceb24858e1cb41.tar
gsoc2013-evolution-76c77aaebccbf5df6ee4206705ceb24858e1cb41.tar.gz
gsoc2013-evolution-76c77aaebccbf5df6ee4206705ceb24858e1cb41.tar.bz2
gsoc2013-evolution-76c77aaebccbf5df6ee4206705ceb24858e1cb41.tar.lz
gsoc2013-evolution-76c77aaebccbf5df6ee4206705ceb24858e1cb41.tar.xz
gsoc2013-evolution-76c77aaebccbf5df6ee4206705ceb24858e1cb41.tar.zst
gsoc2013-evolution-76c77aaebccbf5df6ee4206705ceb24858e1cb41.zip
Bug #712738 - Recovered message doesn't restore options
-rw-r--r--composer/e-msg-composer.c49
1 files changed, 40 insertions, 9 deletions
diff --git a/composer/e-msg-composer.c b/composer/e-msg-composer.c
index 502f098d87..eeff715787 100644
--- a/composer/e-msg-composer.c
+++ b/composer/e-msg-composer.c
@@ -80,7 +80,8 @@ typedef enum {
COMPOSER_FLAG_PGP_SIGN = 1 << 4,
COMPOSER_FLAG_PGP_ENCRYPT = 1 << 5,
COMPOSER_FLAG_SMIME_SIGN = 1 << 6,
- COMPOSER_FLAG_SMIME_ENCRYPT = 1 << 7
+ COMPOSER_FLAG_SMIME_ENCRYPT = 1 << 7,
+ COMPOSER_FLAG_DRAFT = 1 << 8
} ComposerFlags;
enum {
@@ -1119,16 +1120,16 @@ composer_build_message (EMsgComposer *composer,
context->session = e_msg_composer_ref_session (composer);
context->from = e_msg_composer_get_from (composer);
- if (flags & COMPOSER_FLAG_PGP_SIGN)
+ if ((flags & COMPOSER_FLAG_PGP_SIGN) != 0 && (flags & COMPOSER_FLAG_DRAFT) == 0)
context->pgp_sign = TRUE;
- if (flags & COMPOSER_FLAG_PGP_ENCRYPT)
+ if ((flags & COMPOSER_FLAG_PGP_ENCRYPT) != 0 && (flags & COMPOSER_FLAG_DRAFT) == 0)
context->pgp_encrypt = TRUE;
- if (flags & COMPOSER_FLAG_SMIME_SIGN)
+ if ((flags & COMPOSER_FLAG_SMIME_SIGN) != 0 && (flags & COMPOSER_FLAG_DRAFT) == 0)
context->smime_sign = TRUE;
- if (flags & COMPOSER_FLAG_SMIME_ENCRYPT)
+ if ((flags & COMPOSER_FLAG_SMIME_ENCRYPT) != 0 && (flags & COMPOSER_FLAG_DRAFT) == 0)
context->smime_encrypt = TRUE;
context->need_thread =
@@ -1614,13 +1615,16 @@ msg_composer_mail_identity_changed_cb (EMsgComposer *composer)
(g_ascii_strncasecmp (p->mime_type, "text/calendar", 13) != 0);
action = GTK_TOGGLE_ACTION (ACTION (PGP_SIGN));
- gtk_toggle_action_set_active (action, can_sign && pgp_sign);
+ gtk_toggle_action_set_active (action, (can_sign && pgp_sign) ||
+ (p->is_from_message && gtk_toggle_action_get_active (action)));
action = GTK_TOGGLE_ACTION (ACTION (SMIME_SIGN));
- gtk_toggle_action_set_active (action, can_sign && smime_sign);
+ gtk_toggle_action_set_active (action, (can_sign && smime_sign) ||
+ (p->is_from_message && gtk_toggle_action_get_active (action)));
action = GTK_TOGGLE_ACTION (ACTION (SMIME_ENCRYPT));
- gtk_toggle_action_set_active (action, smime_encrypt);
+ gtk_toggle_action_set_active (action, smime_encrypt ||
+ (p->is_from_message && gtk_toggle_action_get_active (action)));
combo_box = e_composer_header_table_get_signature_combo_box (table);
e_mail_signature_combo_box_set_identity_uid (combo_box, uid);
@@ -4717,7 +4721,8 @@ e_msg_composer_get_message_draft (EMsgComposer *composer,
gpointer user_data)
{
GSimpleAsyncResult *simple;
- ComposerFlags flags = 0;
+ ComposerFlags flags = COMPOSER_FLAG_DRAFT;
+ GtkAction *action;
g_return_if_fail (E_IS_MSG_COMPOSER (composer));
@@ -4730,6 +4735,32 @@ e_msg_composer_get_message_draft (EMsgComposer *composer,
if (gtkhtml_editor_get_html_mode (GTKHTML_EDITOR (composer)))
flags |= COMPOSER_FLAG_HTML_CONTENT;
+ action = ACTION (PRIORITIZE_MESSAGE);
+ if (gtk_toggle_action_get_active (GTK_TOGGLE_ACTION (action)))
+ flags |= COMPOSER_FLAG_PRIORITIZE_MESSAGE;
+
+ action = ACTION (REQUEST_READ_RECEIPT);
+ if (gtk_toggle_action_get_active (GTK_TOGGLE_ACTION (action)))
+ flags |= COMPOSER_FLAG_REQUEST_READ_RECEIPT;
+
+ action = ACTION (PGP_SIGN);
+ if (gtk_toggle_action_get_active (GTK_TOGGLE_ACTION (action)))
+ flags |= COMPOSER_FLAG_PGP_SIGN;
+
+ action = ACTION (PGP_ENCRYPT);
+ if (gtk_toggle_action_get_active (GTK_TOGGLE_ACTION (action)))
+ flags |= COMPOSER_FLAG_PGP_ENCRYPT;
+
+#ifdef HAVE_NSS
+ action = ACTION (SMIME_SIGN);
+ if (gtk_toggle_action_get_active (GTK_TOGGLE_ACTION (action)))
+ flags |= COMPOSER_FLAG_SMIME_SIGN;
+
+ action = ACTION (SMIME_ENCRYPT);
+ if (gtk_toggle_action_get_active (GTK_TOGGLE_ACTION (action)))
+ flags |= COMPOSER_FLAG_SMIME_ENCRYPT;
+#endif
+
composer_build_message (
composer, flags, io_priority,
cancellable, (GAsyncReadyCallback)