aboutsummaryrefslogtreecommitdiff
diff options
context:
space:
mode:
-rw-r--r--ChangeLog7
-rw-r--r--libsylph/mbox.c6
-rw-r--r--src/export.c140
-rw-r--r--src/export.h4
-rw-r--r--src/import.c3
-rw-r--r--src/import.h4
-rw-r--r--src/mainwindow.c20
7 files changed, 134 insertions, 50 deletions
diff --git a/ChangeLog b/ChangeLog
index 2ee59e61..2cb9434e 100644
--- a/ChangeLog
+++ b/ChangeLog
@@ -1,5 +1,12 @@
2009-08-11
+ * libsylph/mbox.c
+ src/export.[ch]: show progress bar on export.
+ * src/mainwindow.c
+ src/import.c: modified menu label and function names.
+
+2009-08-11
+
* src/import.c: implemented eml file import (with folder).
2009-08-10
diff --git a/libsylph/mbox.c b/libsylph/mbox.c
index cbc461d1..7ecae25c 100644
--- a/libsylph/mbox.c
+++ b/libsylph/mbox.c
@@ -448,6 +448,7 @@ gint export_to_mbox(FolderItem *src, const gchar *mbox)
FILE *mbox_fp;
gchar buf[BUFFSIZE];
PrefsAccount *cur_ac;
+ gint count = 0, length;
g_return_val_if_fail(src != NULL, -1);
g_return_val_if_fail(src->folder != NULL, -1);
@@ -464,10 +465,15 @@ gint export_to_mbox(FolderItem *src, const gchar *mbox)
cur_ac = account_get_current_account();
mlist = folder_item_get_msg_list(src, TRUE);
+ length = g_slist_length(mlist);
for (cur = mlist; cur != NULL; cur = cur->next) {
msginfo = (MsgInfo *)cur->data;
+ count++;
+ if (src->folder->ui_func)
+ src->folder->ui_func(src->folder, src, src->folder->ui_func_data ? src->folder->ui_func_data : GINT_TO_POINTER(count));
+
msg_fp = procmsg_open_message(msginfo);
if (!msg_fp) {
procmsg_msginfo_free(msginfo);
diff --git a/src/export.c b/src/export.c
index 246684d2..d58c8805 100644
--- a/src/export.c
+++ b/src/export.c
@@ -1,6 +1,6 @@
/*
* Sylpheed -- a GTK+ based, lightweight, and fast e-mail client
- * Copyright (C) 1999-2006 Hiroyuki Yamamoto
+ * Copyright (C) 1999-2009 Hiroyuki Yamamoto
*
* This program is free software; you can redistribute it and/or modify
* it under the terms of the GNU General Public License as published by
@@ -35,7 +35,7 @@
#include <gtk/gtkentry.h>
#include <gtk/gtkhbbox.h>
#include <gtk/gtkbutton.h>
-#include <gtk/gtksignal.h>
+#include <gtk/gtkprogressbar.h>
#include "main.h"
#include "inc.h"
@@ -46,6 +46,8 @@
#include "manage_window.h"
#include "folder.h"
#include "utils.h"
+#include "progressdialog.h"
+#include "alertpanel.h"
static GtkWidget *window;
static GtkWidget *src_entry;
@@ -56,8 +58,10 @@ static GtkWidget *ok_button;
static GtkWidget *cancel_button;
static gboolean export_finished;
static gboolean export_ack;
+static ProgressDialog *progress;
static void export_create (void);
+static gint export_do (void);
static void export_ok_cb (GtkWidget *widget,
gpointer data);
static void export_cancel_cb (GtkWidget *widget,
@@ -73,7 +77,34 @@ static gboolean key_pressed (GtkWidget *widget,
GdkEventKey *event,
gpointer data);
-gint export_mbox(FolderItem *default_src)
+
+static void export_mbox_func(Folder *folder, FolderItem *item, gpointer data)
+{
+ gchar str[64];
+ gint count = GPOINTER_TO_INT(data);
+ static GTimeVal tv_prev = {0, 0};
+ GTimeVal tv_cur;
+
+ g_get_current_time(&tv_cur);
+ if (item->total > 0)
+ g_snprintf(str, sizeof(str), "%d / %d", count, item->total);
+ else
+ g_snprintf(str, sizeof(str), "%d", count);
+ gtk_progress_bar_set_text(GTK_PROGRESS_BAR(progress->progressbar), str);
+
+ if (tv_prev.tv_sec == 0 ||
+ (tv_cur.tv_sec - tv_prev.tv_sec) * G_USEC_PER_SEC +
+ tv_cur.tv_usec - tv_prev.tv_usec > 100 * 1000) {
+ if (item->total > 0)
+ gtk_progress_bar_set_fraction(GTK_PROGRESS_BAR(progress->progressbar), (gdouble)count / item->total);
+ else
+ gtk_progress_bar_pulse(GTK_PROGRESS_BAR(progress->progressbar));
+ ui_update();
+ tv_prev = tv_cur;
+ }
+}
+
+gint export_mail(FolderItem *default_src)
{
gint ok = 0;
gchar *src_id = NULL;
@@ -96,40 +127,75 @@ gint export_mbox(FolderItem *default_src)
export_finished = FALSE;
export_ack = FALSE;
+ inc_lock();
+
while (!export_finished)
gtk_main_iteration();
- if (export_ack) {
- const gchar *srcdir, *utf8mbox;
- FolderItem *src;
+ if (export_ack)
+ ok = export_do();
+
+ gtk_widget_destroy(window);
+ window = NULL;
+ src_entry = file_entry = NULL;
+ src_button = file_button = ok_button = cancel_button = NULL;
+
+ inc_unlock();
+
+ return ok;
+}
- srcdir = gtk_entry_get_text(GTK_ENTRY(src_entry));
- utf8mbox = gtk_entry_get_text(GTK_ENTRY(file_entry));
+static gint export_do(void)
+{
+ gint ok = 0;
+ const gchar *srcdir, *utf8mbox;
+ FolderItem *src;
+ gchar *mbox;
+ gchar *msg;
- if (utf8mbox && *utf8mbox) {
- gchar *mbox;
+ srcdir = gtk_entry_get_text(GTK_ENTRY(src_entry));
+ utf8mbox = gtk_entry_get_text(GTK_ENTRY(file_entry));
- mbox = g_filename_from_utf8
- (utf8mbox, -1, NULL, NULL, NULL);
- if (!mbox) {
- g_warning("faild to convert character set\n");
- mbox = g_strdup(utf8mbox);
- }
+ if (!utf8mbox || !*utf8mbox)
+ return -1;
- src = folder_find_item_from_identifier(srcdir);
- if (!src)
- g_warning("Can't find the folder.\n");
- else
- ok = export_to_mbox(src, mbox);
+ mbox = g_filename_from_utf8(utf8mbox, -1, NULL, NULL, NULL);
+ if (!mbox) {
+ g_warning("failed to convert character set.");
+ mbox = g_strdup(utf8mbox);
+ }
- g_free(mbox);
- }
+ src = folder_find_item_from_identifier(srcdir);
+ if (!src) {
+ g_warning("Can't find the folder.");
+ g_free(mbox);
+ return -1;
}
- gtk_widget_destroy(window);
- window = NULL;
- src_entry = file_entry = NULL;
- src_button = file_button = ok_button = cancel_button = NULL;
+ msg = g_strdup_printf(_("Exporting %s ..."), g_basename(srcdir));
+ progress = progress_dialog_simple_create();
+ gtk_window_set_title(GTK_WINDOW(progress->window), _("Exporting"));
+ progress_dialog_set_label(progress, msg);
+ g_free(msg);
+ gtk_window_set_modal(GTK_WINDOW(progress->window), TRUE);
+ manage_window_set_transient(GTK_WINDOW(progress->window));
+ gtk_widget_hide(progress->cancel_btn);
+ g_signal_connect(G_OBJECT(progress->window), "delete_event",
+ G_CALLBACK(gtk_true), NULL);
+ gtk_widget_show(progress->window);
+ ui_update();
+
+ folder_set_ui_func(src->folder, export_mbox_func, NULL);
+ ok = export_to_mbox(src, mbox);
+ folder_set_ui_func(src->folder, NULL, NULL);
+
+ progress_dialog_destroy(progress);
+ progress = NULL;
+
+ g_free(mbox);
+
+ if (ok < 0)
+ alertpanel_error(_("Error occurred on export."));
return ok;
}
@@ -164,7 +230,7 @@ static void export_create(void)
gtk_container_set_border_width(GTK_CONTAINER(hbox), 4);
desc_label = gtk_label_new
- (_("Specify target folder and mbox file."));
+ (_("Specify source folder and destination file."));
gtk_box_pack_start(GTK_BOX(hbox), desc_label, FALSE, FALSE, 0);
table = gtk_table_new(2, 3, FALSE);
@@ -174,12 +240,12 @@ static void export_create(void)
gtk_table_set_col_spacings(GTK_TABLE(table), 8);
gtk_widget_set_size_request(table, 420, -1);
- src_label = gtk_label_new(_("Source dir:"));
+ src_label = gtk_label_new(_("Source folder:"));
gtk_table_attach(GTK_TABLE(table), src_label, 0, 1, 0, 1,
GTK_FILL, GTK_EXPAND|GTK_FILL, 0, 0);
gtk_misc_set_alignment(GTK_MISC(src_label), 1, 0.5);
- file_label = gtk_label_new(_("Exporting file:"));
+ file_label = gtk_label_new(_("Destination file:"));
gtk_table_attach(GTK_TABLE(table), file_label, 0, 1, 1, 2,
GTK_FILL, GTK_EXPAND|GTK_FILL, 0, 0);
gtk_misc_set_alignment(GTK_MISC(file_label), 1, 0.5);
@@ -236,13 +302,13 @@ static void export_filesel_cb(GtkWidget *widget, gpointer data)
gchar *filename;
gchar *utf8_filename;
- filename = filesel_select_file(_("Select exporting file"), NULL,
+ filename = filesel_select_file(_("Select destination file"), NULL,
GTK_FILE_CHOOSER_ACTION_SAVE);
if (!filename) return;
utf8_filename = g_filename_to_utf8(filename, -1, NULL, NULL, NULL);
if (!utf8_filename) {
- g_warning("export_filesel_cb(): faild to convert character set.\n");
+ g_warning("export_filesel_cb(): failed to convert character set.");
utf8_filename = g_strdup(filename);
}
gtk_entry_set_text(GTK_ENTRY(file_entry), utf8_filename);
@@ -254,10 +320,16 @@ static void export_filesel_cb(GtkWidget *widget, gpointer data)
static void export_srcsel_cb(GtkWidget *widget, gpointer data)
{
FolderItem *src;
+ gchar *src_id;
src = foldersel_folder_sel(NULL, FOLDER_SEL_ALL, NULL);
- if (src && src->path)
- gtk_entry_set_text(GTK_ENTRY(src_entry), src->path);
+ if (src && src->path) {
+ src_id = folder_item_get_identifier(src);
+ if (src_id) {
+ gtk_entry_set_text(GTK_ENTRY(src_entry), src_id);
+ g_free(src_id);
+ }
+ }
}
static gint delete_event(GtkWidget *widget, GdkEventAny *event, gpointer data)
diff --git a/src/export.h b/src/export.h
index 34d73a06..db16466e 100644
--- a/src/export.h
+++ b/src/export.h
@@ -1,6 +1,6 @@
/*
* Sylpheed -- a GTK+ based, lightweight, and fast e-mail client
- * Copyright (C) 1999-2001 Hiroyuki Yamamoto
+ * Copyright (C) 1999-2009 Hiroyuki Yamamoto
*
* This program is free software; you can redistribute it and/or modify
* it under the terms of the GNU General Public License as published by
@@ -24,6 +24,6 @@
#include "folder.h"
-gint export_mbox(FolderItem *default_src);
+gint export_mail(FolderItem *default_src);
#endif /* __EXPORT_H__ */
diff --git a/src/import.c b/src/import.c
index 8fbbabad..9a483749 100644
--- a/src/import.c
+++ b/src/import.c
@@ -37,7 +37,6 @@
#include <gtk/gtkentry.h>
#include <gtk/gtkhbbox.h>
#include <gtk/gtkbutton.h>
-#include <gtk/gtksignal.h>
#include <gtk/gtkstock.h>
#include <gtk/gtkprogressbar.h>
#include <gtk/gtkmenu.h>
@@ -115,7 +114,7 @@ static void proc_mbox_func(Folder *folder, FolderItem *item, gpointer data)
}
}
-gint import_mbox(FolderItem *default_dest)
+gint import_mail(FolderItem *default_dest)
{
gint ok = 0;
gchar *dest_id = NULL;
diff --git a/src/import.h b/src/import.h
index 64d8421f..ea121c86 100644
--- a/src/import.h
+++ b/src/import.h
@@ -1,6 +1,6 @@
/*
* Sylpheed -- a GTK+ based, lightweight, and fast e-mail client
- * Copyright (C) 1999-2001 Hiroyuki Yamamoto
+ * Copyright (C) 1999-2009 Hiroyuki Yamamoto
*
* This program is free software; you can redistribute it and/or modify
* it under the terms of the GNU General Public License as published by
@@ -24,6 +24,6 @@
#include "folder.h"
-gint import_mbox(FolderItem *default_dest);
+gint import_mail(FolderItem *default_dest);
#endif /* __IMPORT_H__ */
diff --git a/src/mainwindow.c b/src/mainwindow.c
index 7d9736c7..8fe78cea 100644
--- a/src/mainwindow.c
+++ b/src/mainwindow.c
@@ -252,10 +252,10 @@ static void rebuild_tree_cb (MainWindow *mainwin,
guint action,
GtkWidget *widget);
-static void import_mbox_cb (MainWindow *mainwin,
+static void import_mail_cb (MainWindow *mainwin,
guint action,
GtkWidget *widget);
-static void export_mbox_cb (MainWindow *mainwin,
+static void export_mail_cb (MainWindow *mainwin,
guint action,
GtkWidget *widget);
static void empty_trash_cb (MainWindow *mainwin,
@@ -556,8 +556,8 @@ static GtkItemFactoryEntry mainwin_entries[] =
{N_("/_File/_Mailbox/R_ebuild folder tree"),
NULL, rebuild_tree_cb, 0, NULL},
{N_("/_File/---"), NULL, NULL, 0, "<Separator>"},
- {N_("/_File/_Import mbox file..."), NULL, import_mbox_cb, 0, NULL},
- {N_("/_File/_Export to mbox file..."), NULL, export_mbox_cb, 0, NULL},
+ {N_("/_File/_Import mail data..."), NULL, import_mail_cb, 0, NULL},
+ {N_("/_File/_Export mail data..."), NULL, export_mail_cb, 0, NULL},
{N_("/_File/---"), NULL, NULL, 0, "<Separator>"},
{N_("/_File/Empty all _trash"), NULL, empty_trash_cb, 0, NULL},
{N_("/_File/---"), NULL, NULL, 0, "<Separator>"},
@@ -2083,8 +2083,8 @@ void main_window_set_menu_sensitive(MainWindow *mainwin)
{"/File/Mailbox/Check for new messages in all mailboxes"
, M_UNLOCKED|M_MBOX_CHKALLOK},
{"/File/Mailbox/Rebuild folder tree", M_UNLOCKED|M_MBOX_REBUILDOK},
- {"/File/Import mbox file..." , M_UNLOCKED},
- {"/File/Export to mbox file..." , M_UNLOCKED},
+ {"/File/Import mail data..." , M_UNLOCKED},
+ {"/File/Export mail data..." , M_UNLOCKED},
{"/File/Empty all trash" , M_UNLOCKED},
{"/File/Save as..." , M_SINGLE_TARGET_EXIST},
@@ -3273,17 +3273,17 @@ static void rebuild_tree_cb(MainWindow *mainwin, guint action,
folderview_rebuild_tree(mainwin->folderview);
}
-static void import_mbox_cb(MainWindow *mainwin, guint action,
+static void import_mail_cb(MainWindow *mainwin, guint action,
GtkWidget *widget)
{
- import_mbox(mainwin->summaryview->folder_item);
+ import_mail(mainwin->summaryview->folder_item);
main_window_popup(mainwin);
}
-static void export_mbox_cb(MainWindow *mainwin, guint action,
+static void export_mail_cb(MainWindow *mainwin, guint action,
GtkWidget *widget)
{
- export_mbox(mainwin->summaryview->folder_item);
+ export_mail(mainwin->summaryview->folder_item);
main_window_popup(mainwin);
}