aboutsummaryrefslogtreecommitdiffstats
path: root/mail/folder-browser.c
diff options
context:
space:
mode:
Diffstat (limited to 'mail/folder-browser.c')
-rw-r--r--mail/folder-browser.c91
1 files changed, 43 insertions, 48 deletions
diff --git a/mail/folder-browser.c b/mail/folder-browser.c
index ce419004a0..e9ce4df109 100644
--- a/mail/folder-browser.c
+++ b/mail/folder-browser.c
@@ -46,6 +46,8 @@
#include "mail-config.h"
#include <camel/camel-vtrash-folder.h>
+#include <camel/camel-mime-message.h>
+#include <camel/camel-stream-mem.h>
#define d(x) x
@@ -53,19 +55,16 @@
enum DndTargetType {
- DND_TARGET_TYPE_X_EVOLUTION_DND,
+ DND_TARGET_TYPE_X_EVOLUTION_MESSAGE,
DND_TARGET_TYPE_MESSAGE_RFC822,
- DND_TARGET_TYPE_URI_LIST,
};
-#define X_EVOLUTION_DND_TYPE "x-evolution-dnd"
-#define MESSAGE_RFC822_TYPE "message/rfc822"
-#define URI_LIST_TYPE "text/uri-list"
+#define X_EVOLUTION_MESSAGE_TYPE "x-evolution-message"
+#define MESSAGE_RFC822_TYPE "message/rfc822"
static GtkTargetEntry drag_types[] = {
- { X_EVOLUTION_DND_TYPE, 0, DND_TARGET_TYPE_X_EVOLUTION_DND },
+ { X_EVOLUTION_MESSAGE_TYPE, 0, DND_TARGET_TYPE_X_EVOLUTION_MESSAGE },
{ MESSAGE_RFC822_TYPE, 0, DND_TARGET_TYPE_MESSAGE_RFC822 },
- { URI_LIST_TYPE, 0, DND_TARGET_TYPE_URI_LIST },
};
static const int num_drag_types = sizeof (drag_types) / sizeof (drag_types[0]);
@@ -219,66 +218,58 @@ message_list_drag_data_get (ETree *tree,
{
FolderBrowser *fb = FOLDER_BROWSER (user_data);
GPtrArray *uids = NULL;
+ int i;
+
+ uids = g_ptr_array_new ();
+ message_list_foreach (fb->message_list, add_uid, uids);
switch (info) {
- case DND_TARGET_TYPE_URI_LIST:
+ case DND_TARGET_TYPE_MESSAGE_RFC822:
{
- char *tmpl, *tmpdir, *filename, *subject;
- CamelMessageInfo *minfo;
-
- /* drag & drop into nautilus */
- tmpl = g_strdup ("/tmp/evolution.XXXXXX");
-#ifdef HAVE_MKDTEMP
- tmpdir = mkdtemp (tmpl);
-#else
- tmpdir = mktemp (tmpl);
- if (tmpdir) {
- if (mkdir (tmpdir, S_IRWXU) == -1)
- tmpdir = NULL;
- }
-#endif
- if (!tmpdir) {
- g_free (tmpl);
- return;
- }
- g_free (tmpl);
+ /* FIXME: this'll be fucking slow for the user... pthread this? */
+ CamelStream *stream;
+ GByteArray *bytes;
- uids = g_ptr_array_new ();
- message_list_foreach (fb->message_list, add_uid, uids);
+ bytes = g_byte_array_new ();
+ stream = camel_stream_mem_new ();
+ camel_stream_mem_set_byte_array (CAMEL_STREAM_MEM (stream), bytes);
- minfo = camel_folder_get_message_info (fb->folder, uids->pdata[0]);
-
- subject = g_strdup (camel_message_info_subject (minfo));
- e_filename_make_safe (subject);
- filename = g_strdup_printf ("%s/%s.eml", tmpdir, subject);
- g_free (subject);
+ for (i = 0; i < uids->len; i++) {
+ CamelMimeMessage *message;
+
+ message = camel_folder_get_message (fb->folder, uids->pdata[i], NULL);
+ g_free (uids->pdata[i]);
+
+ if (message) {
+ camel_stream_write (stream, "From - \n", 8);
+ camel_data_wrapper_write_to_stream (CAMEL_DATA_WRAPPER (message), stream);
+ camel_object_unref (CAMEL_OBJECT (message));
+ }
+ }
- mail_msg_wait (mail_save_messages (fb->folder, uids, filename, NULL, NULL));
+ g_ptr_array_free (uids, TRUE);
+ camel_object_unref (CAMEL_OBJECT (stream));
gtk_selection_data_set (selection_data, selection_data->target, 8,
- (guchar *) filename, strlen (filename));
+ bytes->data, bytes->len);
+
+ g_byte_array_free (bytes, FALSE);
}
break;
- case DND_TARGET_TYPE_MESSAGE_RFC822:
- break;
- case DND_TARGET_TYPE_X_EVOLUTION_DND:
+ case DND_TARGET_TYPE_X_EVOLUTION_MESSAGE:
{
GByteArray *array;
- char *uri;
- int i;
+ char *url;
/* format: "url folder_name uid1\0uid2\0uid3\0...\0uidn" */
- uids = g_ptr_array_new ();
- message_list_foreach (fb->message_list, add_uid, uids);
-
- uri = camel_url_to_string (CAMEL_SERVICE (camel_folder_get_parent_store (fb->folder))->url, 0);
+ url = camel_url_to_string (CAMEL_SERVICE (camel_folder_get_parent_store (fb->folder))->url, 0);
/* write the url portion */
array = g_byte_array_new ();
- g_byte_array_append (array, uri, strlen (uri));
+ g_byte_array_append (array, url, strlen (url));
g_byte_array_append (array, " ", 1);
- g_free (uri);
+ g_free (url);
/* write the folder_name portion */
g_byte_array_append (array, fb->folder->name, strlen (fb->folder->name));
@@ -302,6 +293,10 @@ message_list_drag_data_get (ETree *tree,
}
break;
default:
+ for (i = 0; i < uids->len; i++)
+ g_free (uids->pdata[i]);
+
+ g_ptr_array_free (uids, TRUE);
break;
}
}