[evolution] Require a CamelMimeMessage in em_utils_handle_receipt().
- From: Matthew Barnes <mbarnes src gnome org>
- To: commits-list gnome org
- Cc:
- Subject: [evolution] Require a CamelMimeMessage in em_utils_handle_receipt().
- Date: Sun, 31 Oct 2010 02:09:21 +0000 (UTC)
commit b9acd9446511a8989a752e114e32a3494cbdc9ef
Author: Matthew Barnes <mbarnes redhat com>
Date: Sat Oct 30 21:54:16 2010 -0400
Require a CamelMimeMessage in em_utils_handle_receipt().
Eliminates one of the two remaining calls to mail_get_messagex().
mail/em-composer-utils.c | 73 ++++++++++++++++++++++++----------------------
mail/em-composer-utils.h | 4 +-
2 files changed, 40 insertions(+), 37 deletions(-)
---
diff --git a/mail/em-composer-utils.c b/mail/em-composer-utils.c
index 91480a3..6aebe52 100644
--- a/mail/em-composer-utils.c
+++ b/mail/em-composer-utils.c
@@ -1607,61 +1607,44 @@ em_utils_redirect_message_by_uid (EShell *shell,
g_object_ref (shell), mail_msg_unordered_push);
}
-static void
-emu_handle_receipt_message (CamelFolder *folder,
- const gchar *uid,
- CamelMimeMessage *msg,
- gpointer data,
- GError **error)
-{
- EMailSession *session = E_MAIL_SESSION (data);
-
- if (msg)
- em_utils_handle_receipt (session, folder, uid, msg);
-
- /* we dont care really if we can't get the message */
- g_clear_error (error);
-}
-
/* Message disposition notifications, rfc 2298 */
void
em_utils_handle_receipt (EMailSession *session,
CamelFolder *folder,
- const gchar *uid,
- CamelMimeMessage *msg)
+ const gchar *message_uid,
+ CamelMimeMessage *message)
{
EAccount *account;
const gchar *addr;
CamelMessageInfo *info;
- info = camel_folder_get_message_info (folder, uid);
- if (info == NULL)
- return;
+ g_return_if_fail (E_IS_MAIL_SESSION (session));
+ g_return_if_fail (CAMEL_IS_FOLDER (folder));
+ g_return_if_fail (CAMEL_IS_MIME_MESSAGE (message));
- if (camel_message_info_user_flag(info, "receipt-handled")) {
- camel_folder_free_message_info (folder, info);
+ info = camel_folder_get_message_info (folder, message_uid);
+ if (info == NULL)
return;
- }
- if (msg == NULL) {
- mail_get_messagex (
- folder, uid, emu_handle_receipt_message,
- session, mail_msg_unordered_push);
+ if (camel_message_info_user_flag (info, "receipt-handled")) {
camel_folder_free_message_info (folder, info);
return;
}
- if ((addr = camel_medium_get_header((CamelMedium *)msg, "Disposition-Notification-To")) == NULL) {
+ addr = camel_medium_get_header (
+ CAMEL_MEDIUM (message), "Disposition-Notification-To");
+ if (addr == NULL) {
camel_folder_free_message_info (folder, info);
return;
}
- camel_message_info_set_user_flag(info, "receipt-handled", TRUE);
+ camel_message_info_set_user_flag (info, "receipt-handled", TRUE);
camel_folder_free_message_info (folder, info);
- account = em_utils_guess_account_with_recipients (msg, folder);
+ account = em_utils_guess_account_with_recipients (message, folder);
- /* TODO: should probably decode/format the address, it could be in rfc2047 format */
+ /* TODO Should probably decode/format the address,
+ * since it could be in rfc2047 format. */
if (addr == NULL) {
addr = "";
} else {
@@ -1669,9 +1652,29 @@ em_utils_handle_receipt (EMailSession *session,
addr++;
}
- if (account && (account->receipt_policy == E_ACCOUNT_RECEIPT_ALWAYS || account->receipt_policy == E_ACCOUNT_RECEIPT_ASK)
- && e_alert_run_dialog_for_args (e_shell_get_active_window (NULL), "mail:ask-receipt", addr, camel_mime_message_get_subject(msg), NULL) == GTK_RESPONSE_YES)
- em_utils_send_receipt (session, folder, msg);
+ if (account == NULL)
+ return;
+
+ if (account->receipt_policy == E_ACCOUNT_RECEIPT_NEVER)
+ return;
+
+ if (account->receipt_policy == E_ACCOUNT_RECEIPT_ASK) {
+ GtkWindow *window;
+ const gchar *subject;
+ gint response;
+
+ /* FIXME Parent window should be passed in. */
+ window = e_shell_get_active_window (NULL);
+ subject = camel_mime_message_get_subject (message);
+
+ response = e_alert_run_dialog_for_args (
+ window, "mail:ask-receipt", addr, subject, NULL);
+
+ if (response != GTK_RESPONSE_YES)
+ return;
+ }
+
+ em_utils_send_receipt (session, folder, message);
}
static void
diff --git a/mail/em-composer-utils.h b/mail/em-composer-utils.h
index 5dbd8e1..bab32c4 100644
--- a/mail/em-composer-utils.h
+++ b/mail/em-composer-utils.h
@@ -60,8 +60,8 @@ void em_utils_redirect_message_by_uid (EShell *shell,
const gchar *uid);
void em_utils_handle_receipt (EMailSession *session,
CamelFolder *folder,
- const gchar *uid,
- CamelMimeMessage *msg);
+ const gchar *message_uid,
+ CamelMimeMessage *message);
void em_utils_send_receipt (EMailSession *session,
CamelFolder *folder,
CamelMimeMessage *message);
[
Date Prev][
Date Next] [
Thread Prev][
Thread Next]
[
Thread Index]
[
Date Index]
[
Author Index]