diff options
-rw-r--r-- | composer/ChangeLog | 8 | ||||
-rw-r--r-- | composer/e-msg-composer.c | 84 |
2 files changed, 80 insertions, 12 deletions
diff --git a/composer/ChangeLog b/composer/ChangeLog index c9b084d7f3..33761d7e2e 100644 --- a/composer/ChangeLog +++ b/composer/ChangeLog @@ -1,3 +1,11 @@ +2002-07-31 Jeffrey Stedfast <fejj@ximian.com> + + * e-msg-composer.c (e_msg_composer_new_with_message): Parse the + auto-cc/bcc recipients and then later when parsing the cc/bcc + recipients into EDestination objects, if the address is an + auto-*cc address, then set auto_recipient to TRUE on that + EDestination. This fixes bug #28339. + 2002-07-29 Radek Doulik <rodo@ximian.com> * e-msg-composer.c (encode_signature_name): new helper function diff --git a/composer/e-msg-composer.c b/composer/e-msg-composer.c index 76981765a8..f8c3b7ff12 100644 --- a/composer/e-msg-composer.c +++ b/composer/e-msg-composer.c @@ -3348,6 +3348,12 @@ set_signature_gui (EMsgComposer *composer) } +static void +auto_recip_free (gpointer key, gpointer value, gpointer user_data) +{ + g_free (key); +} + /** * e_msg_composer_new_with_message: * @message: The message to use as the source @@ -3363,14 +3369,17 @@ e_msg_composer_new_with_message (CamelMimeMessage *message) { const CamelInternetAddress *to, *cc, *bcc; GList *To = NULL, *Cc = NULL, *Bcc = NULL; + const MailConfigAccount *account = NULL; EDestination **Tov, **Ccv, **Bccv; - const char *format, *subject, *account_name; + GHashTable *auto_cc, *auto_bcc; CamelContentType *content_type; + const char *format, *subject; struct _header_raw *headers; CamelDataWrapper *content; + char *account_name; EMsgComposer *new; XEvolution *xev; - guint len, i; + int len, i; g_return_val_if_fail (gtk_main_level () > 0, NULL); @@ -3378,6 +3387,53 @@ e_msg_composer_new_with_message (CamelMimeMessage *message) if (!new) return NULL; + /* Restore the Account preference */ + account_name = (char *) camel_medium_get_header (CAMEL_MEDIUM (message), "X-Evolution-Account"); + if (account_name) { + account_name = g_strdup (account_name); + g_strstrip (account_name); + + account = mail_config_get_account_by_name (account_name); + } + + auto_cc = g_hash_table_new (g_strcase_hash, g_strcase_equal); + auto_bcc = g_hash_table_new (g_strcase_hash, g_strcase_equal); + + if (account) { + CamelInternetAddress *iaddr; + + /* hash our auto-recipients for this account */ + if (account->always_cc) { + iaddr = camel_internet_address_new (); + if (camel_address_decode (CAMEL_ADDRESS (iaddr), account->cc_addrs) != -1) { + for (i = 0; i < camel_address_length (CAMEL_ADDRESS (iaddr)); i++) { + const char *name, *addr; + + if (!camel_internet_address_get (iaddr, i, &name, &addr)) + continue; + + g_hash_table_insert (auto_cc, g_strdup (addr), GINT_TO_POINTER (TRUE)); + } + } + camel_object_unref (iaddr); + } + + if (account->always_bcc) { + iaddr = camel_internet_address_new (); + if (camel_address_decode (CAMEL_ADDRESS (iaddr), account->bcc_addrs) != -1) { + for (i = 0; i < camel_address_length (CAMEL_ADDRESS (iaddr)); i++) { + const char *name, *addr; + + if (!camel_internet_address_get (iaddr, i, &name, &addr)) + continue; + + g_hash_table_insert (auto_bcc, g_strdup (addr), GINT_TO_POINTER (TRUE)); + } + } + camel_object_unref (iaddr); + } + } + subject = camel_mime_message_get_subject (message); to = camel_mime_message_get_recipients (message, CAMEL_RECIPIENT_TYPE_TO); @@ -3406,10 +3462,17 @@ e_msg_composer_new_with_message (CamelMimeMessage *message) EDestination *dest = e_destination_new (); e_destination_set_name (dest, name); e_destination_set_email (dest, addr); + + if (g_hash_table_lookup (auto_cc, addr)) + e_destination_set_auto_recipient (dest, TRUE); + Cc = g_list_append (Cc, dest); } } + Ccv = e_destination_list_to_vector (Cc); + g_hash_table_foreach (auto_cc, auto_recip_free, NULL); + g_hash_table_destroy (auto_cc); g_list_free (Cc); len = CAMEL_ADDRESS (bcc)->addresses->len; @@ -3420,25 +3483,22 @@ e_msg_composer_new_with_message (CamelMimeMessage *message) EDestination *dest = e_destination_new (); e_destination_set_name (dest, name); e_destination_set_email (dest, addr); + + if (g_hash_table_lookup (auto_bcc, addr)) + e_destination_set_auto_recipient (dest, TRUE); + Bcc = g_list_append (Bcc, dest); } } Bccv = e_destination_list_to_vector (Bcc); + g_hash_table_foreach (auto_bcc, auto_recip_free, NULL); + g_hash_table_destroy (auto_bcc); g_list_free (Bcc); - /* Restore the Account preference */ - account_name = camel_medium_get_header (CAMEL_MEDIUM (message), "X-Evolution-Account"); - if (account_name) { - while (*account_name && isspace ((unsigned) *account_name)) - account_name++; - } - if (account_name == NULL) { - account_name = camel_medium_get_header (CAMEL_MEDIUM (message), "From"); - } - e_msg_composer_set_headers (new, account_name, Tov, Ccv, Bccv, subject); + g_free (account_name); e_destination_freev (Tov); e_destination_freev (Ccv); e_destination_freev (Bccv); |