aboutsummaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorhiro <hiro@ee746299-78ed-0310-b773-934348b2243d>2009-08-11 05:38:00 +0000
committerhiro <hiro@ee746299-78ed-0310-b773-934348b2243d>2009-08-11 05:38:00 +0000
commitd74842968bf33f5de49413bacdaa6ff7ecce2966 (patch)
treef3ee8dbcb5c093426dabfe00c7f8738512f01392
parent36e9b9dd2e3da9326aa38ceba4ac15d5051921b7 (diff)
implemented eml file import (with folder)
git-svn-id: svn://sylpheed.sraoss.jp/sylpheed/trunk@2204 ee746299-78ed-0310-b773-934348b2243d
-rw-r--r--ChangeLog4
-rw-r--r--src/import.c55
2 files changed, 57 insertions, 2 deletions
diff --git a/ChangeLog b/ChangeLog
index 1e2dbc6e..2ee59e61 100644
--- a/ChangeLog
+++ b/ChangeLog
@@ -1,3 +1,7 @@
+2009-08-11
+
+ * src/import.c: implemented eml file import (with folder).
+
2009-08-10
* src/import.c: added eml file import (one file).
diff --git a/src/import.c b/src/import.c
index c5b95d06..8fbbabad 100644
--- a/src/import.c
+++ b/src/import.c
@@ -77,6 +77,8 @@ static ProgressDialog *progress;
static void import_create (void);
static gint import_do (void);
+static gint import_eml_folder (FolderItem *dest,
+ const gchar *path);
static void import_ok_cb (GtkWidget *widget,
gpointer data);
static void import_cancel_cb (GtkWidget *widget,
@@ -134,6 +136,8 @@ gint import_mbox(FolderItem *default_dest)
import_finished = FALSE;
import_ack = FALSE;
+ inc_lock();
+
while (!import_finished)
gtk_main_iteration();
@@ -147,6 +151,8 @@ gint import_mbox(FolderItem *default_dest)
file_entry = dest_entry = NULL;
file_button = dest_button = ok_button = cancel_button = NULL;
+ inc_unlock();
+
return ok;
}
@@ -169,7 +175,7 @@ static gint import_do(void)
filename = g_filename_from_utf8(utf8filename, -1, NULL, NULL, NULL);
if (!filename) {
- g_warning("faild to convert character set\n");
+ g_warning("faild to convert character set.");
filename = g_strdup(utf8filename);
}
if (!g_file_test(filename, G_FILE_TEST_EXISTS)) {
@@ -208,8 +214,9 @@ static gint import_do(void)
folder_set_ui_func(dest->folder, NULL, NULL);
} else if (type == IMPORT_EML_FILE) {
MsgFlags flags = { MSG_NEW|MSG_UNREAD, MSG_RECEIVED };
- folder_item_add_msg(dest, filename, &flags, FALSE);
+ ok = folder_item_add_msg(dest, filename, &flags, FALSE);
} else if (type == IMPORT_EML_FOLDER) {
+ ok = import_eml_folder(dest, filename);
}
progress_dialog_set_label(progress, _("Scanning folder..."));
@@ -228,6 +235,50 @@ static gint import_do(void)
return ok;
}
+static gint import_eml_folder(FolderItem *dest, const gchar *path)
+{
+ GDir *dir;
+ const gchar *dir_name, *p;
+ gchar *file;
+ gint count = 0;
+ gint ok = 0;
+
+ g_return_val_if_fail(dest != NULL, -1);
+ g_return_val_if_fail(path != NULL, -1);
+
+ if ((dir = g_dir_open(path, 0, NULL)) == NULL) {
+ g_warning("failed to open directory: %s", path);
+ return -1;
+ }
+
+ while ((dir_name = g_dir_read_name(dir)) != NULL) {
+ if (((p = strrchr(dir_name, '.')) &&
+ !g_ascii_strcasecmp(p + 1, "eml")) ||
+ to_number(dir_name) > 0) {
+ file = g_strconcat(path, G_DIR_SEPARATOR_S, dir_name,
+ NULL);
+ if (!g_file_test(file, G_FILE_TEST_IS_REGULAR)) {
+ g_free(file);
+ continue;
+ }
+
+ count++;
+ proc_mbox_func(dest->folder, dest,
+ GINT_TO_POINTER(count));
+ ok = folder_item_add_msg(dest, file, NULL, FALSE);
+ g_free(file);
+ if (ok < 0) {
+ g_warning("import_eml_folder(): folder_item_add_msg() failed.");
+ break;
+ }
+ }
+ }
+
+ g_dir_close(dir);
+
+ return ok;
+}
+
static void import_create(void)
{
GtkWidget *vbox;