aboutsummaryrefslogtreecommitdiffstats
path: root/mail/em-composer-utils.c
diff options
context:
space:
mode:
Diffstat (limited to 'mail/em-composer-utils.c')
-rw-r--r--mail/em-composer-utils.c258
1 files changed, 175 insertions, 83 deletions
diff --git a/mail/em-composer-utils.c b/mail/em-composer-utils.c
index 72225c7d55..994fbda4bb 100644
--- a/mail/em-composer-utils.c
+++ b/mail/em-composer-utils.c
@@ -79,6 +79,9 @@ struct _AsyncContext {
CamelMimeMessage *message;
EMsgComposer *composer;
EActivity *activity;
+ EMailReader *reader;
+ GPtrArray *ptr_array;
+ EMailForwardStyle style;
gchar *folder_uri;
gchar *message_uid;
};
@@ -102,6 +105,12 @@ async_context_free (AsyncContext *context)
if (context->activity != NULL)
g_object_unref (context->activity);
+ if (context->reader != NULL)
+ g_object_unref (context->reader);
+
+ if (context->ptr_array != NULL)
+ g_ptr_array_unref (context->ptr_array);
+
g_free (context->folder_uri);
g_free (context->message_uid);
@@ -1390,7 +1399,6 @@ static EMsgComposer *
forward_attached (EShell *shell,
CamelFolder *folder,
GPtrArray *uids,
- GPtrArray *messages,
CamelMimePart *part,
gchar *subject)
{
@@ -1412,81 +1420,114 @@ forward_attached (EShell *shell,
static void
forward_attached_cb (CamelFolder *folder,
- GPtrArray *messages,
- CamelMimePart *part,
- gchar *subject,
- gpointer user_data)
+ GAsyncResult *result,
+ AsyncContext *context)
{
- ForwardData *data = user_data;
+ EShell *shell;
+ EMailBackend *backend;
+ EAlertSink *alert_sink;
+ CamelMimePart *part;
+ gchar *subject = NULL;
+ GError *error = NULL;
+
+ alert_sink = e_mail_reader_get_alert_sink (context->reader);
+
+ part = e_mail_folder_build_attachment_finish (
+ folder, result, &subject, &error);
+
+ /* Ignore cancellations. */
+ if (g_error_matches (error, G_IO_ERROR, G_IO_ERROR_CANCELLED)) {
+ g_warn_if_fail (part == NULL);
+ g_warn_if_fail (subject == NULL);
+ e_activity_set_state (context->activity, E_ACTIVITY_CANCELLED);
+ async_context_free (context);
+ g_error_free (error);
+ return;
+
+ } else if (error != NULL) {
+ g_warn_if_fail (part == NULL);
+ g_warn_if_fail (subject == NULL);
+ e_alert_submit (
+ alert_sink,
+ "mail:get-multiple-messages",
+ error->message, NULL);
+ async_context_free (context);
+ g_error_free (error);
+ return;
+ }
- if (part)
- forward_attached (
- data->shell, folder, data->uids,
- messages, part, subject);
+ g_return_if_fail (CAMEL_IS_MIME_PART (part));
- forward_data_free (data);
+ backend = e_mail_reader_get_backend (context->reader);
+ shell = e_shell_backend_get_shell (E_SHELL_BACKEND (backend));
+
+ forward_attached (shell, folder, context->ptr_array, part, subject);
+
+ e_activity_set_state (context->activity, E_ACTIVITY_COMPLETED);
+
+ g_object_unref (part);
+ g_free (subject);
+
+ async_context_free (context);
}
static EMsgComposer *
forward_non_attached (EShell *shell,
CamelFolder *folder,
- GPtrArray *uids,
- GPtrArray *messages,
+ const gchar *uid,
+ CamelMimeMessage *message,
EMailForwardStyle style)
{
- CamelMimeMessage *message;
EMsgComposer *composer = NULL;
- gchar *folder_uri;
- gchar *subject, *text, *forward;
- gint i;
+ gchar *text, *forward;
+ guint32 validity_found = 0;
guint32 flags;
- if (messages->len == 0)
- return NULL;
-
- folder_uri = e_mail_folder_uri_from_folder (folder);
-
flags = EM_FORMAT_QUOTE_HEADERS | EM_FORMAT_QUOTE_KEEP_SIG;
if (style == E_MAIL_FORWARD_STYLE_QUOTED)
flags |= EM_FORMAT_QUOTE_CITE;
- for (i = 0; i < messages->len; i++) {
- guint32 validity_found = 0;
+ forward = quoting_text (QUOTING_FORWARD);
+ text = em_utils_message_to_html (
+ message, forward, flags, NULL, NULL, &validity_found);
+
+ if (text != NULL) {
+ CamelDataWrapper *content;
+ gchar *subject;
- message = messages->pdata[i];
subject = mail_tool_generate_forward_subject (message);
+ composer = create_new_composer (shell, subject, folder);
+ g_free (subject);
- forward = quoting_text (QUOTING_FORWARD);
- text = em_utils_message_to_html (
- message, forward, flags, NULL, NULL, &validity_found);
+ content = camel_medium_get_content (CAMEL_MEDIUM (message));
- if (text) {
- composer = create_new_composer (shell, subject, folder);
+ if (CAMEL_IS_MULTIPART (content))
+ e_msg_composer_add_message_attachments (
+ composer, message, FALSE);
- if (composer) {
- if (CAMEL_IS_MULTIPART (camel_medium_get_content ((CamelMedium *) message)))
- e_msg_composer_add_message_attachments (composer, message, FALSE);
+ e_msg_composer_set_body_text (composer, text, TRUE);
- e_msg_composer_set_body_text (composer, text, TRUE);
+ if (uid != NULL) {
+ gchar *folder_uri;
- if (uids && uids->pdata[i])
- e_msg_composer_set_source_headers (
- composer, folder_uri,
- uids->pdata[i],
- CAMEL_MESSAGE_FORWARDED);
+ folder_uri = e_mail_folder_uri_from_folder (folder);
- emu_update_composers_security (composer, validity_found);
- composer_set_no_change (composer);
- gtk_widget_show (GTK_WIDGET (composer));
- }
- g_free (text);
+ e_msg_composer_set_source_headers (
+ composer, folder_uri, uid,
+ CAMEL_MESSAGE_FORWARDED);
+
+ g_free (folder_uri);
}
- g_free (forward);
- g_free (subject);
+ emu_update_composers_security (
+ composer, validity_found);
+ composer_set_no_change (composer);
+ gtk_widget_show (GTK_WIDGET (composer));
+
+ g_free (text);
}
- g_free (folder_uri);
+ g_free (forward);
return composer;
}
@@ -1494,9 +1535,10 @@ forward_non_attached (EShell *shell,
/**
* em_utils_forward_message:
* @shell: an #EShell
- * @message: message to be forwarded
- * @folder: a #CamelFolder, or %NULL
+ * @message: a #CamelMimeMessage to forward
* @style: the forward style to use
+ * @folder: a #CamelFolder, or %NULL
+ * @uid: the UID of %message, or %NULL
*
* Forwards a message in the given style. See em_utils_forward_messages()
* for more details about forwarding styles.
@@ -1504,10 +1546,10 @@ forward_non_attached (EShell *shell,
EMsgComposer *
em_utils_forward_message (EShell *shell,
CamelMimeMessage *message,
+ EMailForwardStyle style,
CamelFolder *folder,
- EMailForwardStyle style)
+ const gchar *uid)
{
- GPtrArray *messages;
CamelMimePart *part;
gchar *subject;
EMsgComposer *composer = NULL;
@@ -1515,9 +1557,6 @@ em_utils_forward_message (EShell *shell,
g_return_val_if_fail (E_IS_SHELL (shell), NULL);
g_return_val_if_fail (CAMEL_IS_MIME_MESSAGE (message), NULL);
- messages = g_ptr_array_new ();
- g_ptr_array_add (messages, message);
-
switch (style) {
case E_MAIL_FORWARD_STYLE_ATTACHED:
default:
@@ -1525,42 +1564,77 @@ em_utils_forward_message (EShell *shell,
subject = mail_tool_generate_forward_subject (message);
composer = forward_attached (
- shell, NULL, NULL, messages, part, subject);
+ shell, NULL, NULL, part, subject);
g_object_unref (part);
g_free (subject);
break;
case E_MAIL_FORWARD_STYLE_INLINE:
- composer = forward_non_attached (
- shell, NULL, NULL, messages,
- E_MAIL_FORWARD_STYLE_INLINE);
- break;
-
case E_MAIL_FORWARD_STYLE_QUOTED:
composer = forward_non_attached (
- shell, NULL, NULL, messages,
- E_MAIL_FORWARD_STYLE_QUOTED);
+ shell, folder, uid, message, style);
break;
}
- g_ptr_array_free (messages, TRUE);
-
return composer;
}
static void
forward_got_messages_cb (CamelFolder *folder,
- GPtrArray *uids,
- GPtrArray *messages,
- gpointer user_data)
+ GAsyncResult *result,
+ AsyncContext *context)
{
- ForwardData *data = user_data;
+ EShell *shell;
+ EMailBackend *backend;
+ EAlertSink *alert_sink;
+ GHashTable *hash_table;
+ GHashTableIter iter;
+ gpointer key, value;
+ GError *error = NULL;
+
+ alert_sink = e_mail_reader_get_alert_sink (context->reader);
+
+ hash_table = e_mail_folder_get_multiple_messages_finish (
+ folder, result, &error);
+
+ /* Ignore cancellations. */
+ if (g_error_matches (error, G_IO_ERROR, G_IO_ERROR_CANCELLED)) {
+ g_warn_if_fail (hash_table == NULL);
+ e_activity_set_state (context->activity, E_ACTIVITY_CANCELLED);
+ async_context_free (context);
+ g_error_free (error);
+ return;
+
+ } else if (error != NULL) {
+ g_warn_if_fail (hash_table == NULL);
+ e_alert_submit (
+ alert_sink,
+ "mail:get-multiple-messages",
+ error->message, NULL);
+ async_context_free (context);
+ g_error_free (error);
+ return;
+ }
+
+ g_return_if_fail (hash_table != NULL);
+
+ backend = e_mail_reader_get_backend (context->reader);
+ shell = e_shell_backend_get_shell (E_SHELL_BACKEND (backend));
- forward_non_attached (
- data->shell, folder, uids, messages, data->style);
+ /* Create a new composer window for each message. */
- forward_data_free (data);
+ g_hash_table_iter_init (&iter, hash_table);
+
+ while (g_hash_table_iter_next (&iter, &key, &value))
+ em_utils_forward_message (
+ shell, value, context->style, folder, key);
+
+ g_hash_table_unref (hash_table);
+
+ e_activity_set_state (context->activity, E_ACTIVITY_COMPLETED);
+
+ async_context_free (context);
}
/**
@@ -1587,35 +1661,53 @@ forward_got_messages_cb (CamelFolder *folder,
* a "> ").
**/
void
-em_utils_forward_messages (EShell *shell,
+em_utils_forward_messages (EMailReader *reader,
CamelFolder *folder,
GPtrArray *uids,
EMailForwardStyle style)
{
- ForwardData *data;
+ AsyncContext *context;
+ GCancellable *cancellable;
+ EMailBackend *backend;
- g_return_if_fail (E_IS_SHELL (shell));
+ g_return_if_fail (E_IS_MAIL_READER (reader));
+ g_return_if_fail (CAMEL_IS_FOLDER (folder));
+ g_return_if_fail (uids != NULL);
- data = g_slice_new0 (ForwardData);
- data->shell = g_object_ref (shell);
- data->uids = em_utils_uids_copy (uids);
- data->style = style;
+ context = g_slice_new0 (AsyncContext);
+ context->activity = e_activity_new ();
+ context->reader = g_object_ref (reader);
+ context->ptr_array = g_ptr_array_ref (uids);
+ context->style = style;
+
+ cancellable = camel_operation_new ();
+ e_activity_set_cancellable (context->activity, cancellable);
+
+ backend = e_mail_reader_get_backend (reader);
+ e_shell_backend_add_activity (
+ E_SHELL_BACKEND (backend), context->activity);
switch (style) {
case E_MAIL_FORWARD_STYLE_ATTACHED:
- mail_build_attachment (
- folder, uids, forward_attached_cb, data);
+ e_mail_folder_build_attachment (
+ folder, uids, G_PRIORITY_DEFAULT,
+ cancellable, (GAsyncReadyCallback)
+ forward_attached_cb, context);
break;
case E_MAIL_FORWARD_STYLE_INLINE:
case E_MAIL_FORWARD_STYLE_QUOTED:
- mail_get_messages (
- folder, uids, forward_got_messages_cb, data);
+ e_mail_folder_get_multiple_messages (
+ folder, uids, G_PRIORITY_DEFAULT,
+ cancellable, (GAsyncReadyCallback)
+ forward_got_messages_cb, context);
break;
default:
- g_return_if_reached ();
+ g_warn_if_reached ();
}
+
+ g_object_unref (cancellable);
}
/* Redirecting messages... */