aboutsummaryrefslogtreecommitdiffstats
path: root/mail/mail-ops.c
diff options
context:
space:
mode:
Diffstat (limited to 'mail/mail-ops.c')
-rw-r--r--mail/mail-ops.c95
1 files changed, 76 insertions, 19 deletions
diff --git a/mail/mail-ops.c b/mail/mail-ops.c
index b0b6b4cb89..169566cd99 100644
--- a/mail/mail-ops.c
+++ b/mail/mail-ops.c
@@ -38,6 +38,8 @@
#include "Evolution.h"
#include "evolution-storage.h"
+#include "evolution-shell-client.h"
+
#ifndef HAVE_MKSTEMP
#include <fcntl.h>
#include <sys/stat.h>
@@ -65,9 +67,6 @@ typedef struct rsm_s {
} rsm_t;
static void
-real_delete_msg( int model_row, gpointer user_data );
-
-static void
real_fetch_mail( gpointer user_data );
static void
@@ -614,29 +613,78 @@ forward_msg (GtkWidget *button, gpointer user_data)
gtk_widget_show (GTK_WIDGET (composer));
}
+struct refile_data {
+ CamelFolder *source, *dest;
+ CamelException *ex;
+};
+
static void
-real_delete_msg (int model_row, gpointer user_data)
+real_refile_msg (MessageList *ml, const char *uid, gpointer user_data)
+{
+ struct refile_data *rfd = user_data;
+
+ if (camel_exception_is_set (rfd->ex))
+ return;
+
+ camel_folder_move_message_to (rfd->source, uid, rfd->dest, rfd->ex);
+}
+
+void
+refile_msg (GtkWidget *button, gpointer user_data)
{
FolderBrowser *fb = user_data;
MessageList *ml = fb->message_list;
- CamelMessageInfo *info;
- CamelException ex;
+ char *uri, *physical, *path;
+ struct refile_data rfd;
- camel_exception_init (&ex);
-
- g_assert (model_row < ml->summary_table->len);
- info = ml->summary_table->pdata[model_row];
-
- /* Toggle the deleted flag without touching other flags. */
- camel_folder_set_message_flags (fb->folder, info->uid,
- CAMEL_MESSAGE_DELETED,
- ~(info->flags), &ex);
+ extern EvolutionShellClient *global_shell_client;
+ static char *last;
- if (camel_exception_is_set (&ex)) {
- mail_exception_dialog ("Could not toggle deleted flag", &ex, fb);
- camel_exception_clear (&ex);
+ if (last == NULL)
+ last = g_strdup ("");
+
+ evolution_shell_client_user_select_folder (global_shell_client,
+ _("Refile message(s) to"),
+ last, &uri, &physical);
+ if (!uri)
return;
+
+ path = strchr (uri, '/');
+ if (path && strcmp (last, path) != 0) {
+ g_free (last);
+ last = g_strdup (path);
}
+ g_free (uri);
+
+ rfd.source = ml->folder;
+ rfd.dest = mail_uri_to_folder (physical);
+ g_free (physical);
+ if (!rfd.dest)
+ return;
+ rfd.ex = camel_exception_new ();
+
+ message_list_foreach (ml, real_refile_msg, &rfd);
+ gtk_object_unref (GTK_OBJECT (rfd.dest));
+
+ if (camel_exception_is_set (rfd.ex))
+ mail_exception_dialog ("Could not move message", rfd.ex, fb);
+ camel_exception_free (rfd.ex);
+}
+
+static void
+real_delete_msg (MessageList *ml, const char *uid, gpointer user_data)
+{
+ CamelException *ex = user_data;
+ guint32 flags;
+
+ if (camel_exception_is_set (ex))
+ return;
+
+ /* Toggle the deleted flag without touching other flags. */
+ flags = camel_folder_get_message_flags (ml->folder, uid, ex);
+ camel_folder_set_message_flags (ml->folder, uid,
+ CAMEL_MESSAGE_DELETED,
+ ~flags, ex);
}
void
@@ -645,8 +693,17 @@ delete_msg (GtkWidget *button, gpointer user_data)
FolderBrowser *fb = user_data;
MessageList *ml = fb->message_list;
int cursor = e_table_get_cursor_row (E_TABLE (ml->etable));
+ CamelException ex;
+
+ camel_exception_init (&ex);
+ message_list_foreach (ml, real_delete_msg, &ex);
+ if (camel_exception_is_set (&ex)) {
+ mail_exception_dialog ("Could not toggle deleted flag",
+ &ex, fb);
+ camel_exception_clear (&ex);
+ return;
+ }
- e_table_selected_row_foreach (E_TABLE (ml->etable), real_delete_msg, fb);
/* Move the cursor down a row... FIXME: should skip other
* deleted messages. FIXME: this implementation is a bit
* questionable