diff options
-rw-r--r-- | mail/ChangeLog | 5 | ||||
-rw-r--r-- | mail/mail-ops.c | 24 |
2 files changed, 23 insertions, 6 deletions
diff --git a/mail/ChangeLog b/mail/ChangeLog index 4d675d9e7b..497b1f8fc5 100644 --- a/mail/ChangeLog +++ b/mail/ChangeLog @@ -1,3 +1,8 @@ +2001-06-21 Jeffrey Stedfast <fejj@ximian.com> + + * mail-ops.c (mail_send_message): Temporarily remove the Bcc + header before sending the message. + 2001-06-21 Jon Trowbridge <trow@ximian.com> * mail-display.c (html_button_press_event): Remove empty "name" diff --git a/mail/mail-ops.c b/mail/mail-ops.c index f79857de69..acf5bbbd1b 100644 --- a/mail/mail-ops.c +++ b/mail/mail-ops.c @@ -420,7 +420,8 @@ struct _update_info { void *data; }; -static void do_update_subfolders_rec(CamelStore *store, CamelFolderInfo *info, EvolutionStorage *storage, const char *prefix) +static void +do_update_subfolders_rec (CamelStore *store, CamelFolderInfo *info, EvolutionStorage *storage, const char *prefix) { char *path, *name; @@ -439,7 +440,8 @@ static void do_update_subfolders_rec(CamelStore *store, CamelFolderInfo *info, E g_free(path); } -static void do_update_subfolders(CamelStore *store, CamelFolderInfo *info, void *data) +static void +do_update_subfolders (CamelStore *store, CamelFolderInfo *info, void *data) { struct _update_info *uinfo = data; @@ -455,8 +457,9 @@ static void do_update_subfolders(CamelStore *store, CamelFolderInfo *info, void } /* this interface is a little icky */ -int mail_update_subfolders(CamelStore *store, EvolutionStorage *storage, - void (*done)(CamelStore *, void *data), void *data) +int +mail_update_subfolders (CamelStore *store, EvolutionStorage *storage, + void (*done)(CamelStore *, void *data), void *data) { struct _update_info *info; @@ -485,7 +488,7 @@ mail_send_message(CamelMimeMessage *message, const char *destination, CamelFilte CamelTransport *xport = NULL; CamelFolder *folder; const char *version, *header; - gchar *acct_header; + gchar *acct_header, *bcc_header; char *transport_url = NULL, *sent_folder_uri = NULL; if (SUB_VERSION[0] == '\0') @@ -530,6 +533,9 @@ mail_send_message(CamelMimeMessage *message, const char *destination, CamelFilte } } + bcc_header = g_strdup (camel_medium_get_header (CAMEL_MEDIUM (message), "Bcc")); + camel_medium_remove_header (CAMEL_MEDIUM (message), "Bcc"); + xport = camel_session_get_transport (session, transport_url ? transport_url : destination, ex); g_free (transport_url); if (!xport) { @@ -547,13 +553,19 @@ mail_send_message(CamelMimeMessage *message, const char *destination, CamelFilte /* post-process */ info = camel_message_info_new (); info->flags = CAMEL_MESSAGE_SEEN; - + /* Re-attach account header */ if (acct_header) { camel_medium_add_header (CAMEL_MEDIUM (message), "X-Evolution-Account", acct_header); g_free (acct_header); } + /* Re-attach the Bcc header */ + if (bcc_header) { + camel_medium_add_header (CAMEL_MEDIUM (message), "Bcc", bcc_header); + g_free (bcc_header); + } + if (driver) camel_filter_driver_filter_message (driver, message, info, NULL, NULL, NULL, "", ex); |