2005-10-13 [paul] 1.9.15cvs34
[claws.git] / src / import.c
index 63395b72b01f0d6f5bce96a236809a9146b25c1b..72b4ad3c0af42330be4aa8b75fef7fbe2486645b 100644 (file)
@@ -1,6 +1,6 @@
 /*
  * Sylpheed -- a GTK+ based, lightweight, and fast e-mail client
- * Copyright (C) 1999-2002 Hiroyuki Yamamoto
+ * Copyright (C) 1999-2005 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
@@ -14,7 +14,7 @@
  *
  * You should have received a copy of the GNU General Public License
  * along with this program; if not, write to the Free Software
- * Foundation, Inc., 59 Temple Place - Suite 330, Boston, MA 02111-1307, USA.
+ * Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301, USA.
  */
 
 #ifdef HAVE_CONFIG_H
@@ -24,6 +24,7 @@
 #include "defs.h"
 
 #include <glib.h>
+#include <glib/gi18n.h>
 #include <gdk/gdkkeysyms.h>
 #include <gtk/gtkmain.h>
 #include <gtk/gtkwidget.h>
@@ -37,7 +38,7 @@
 #include <gtk/gtkfilesel.h>
 #include <gtk/gtksignal.h>
 
-#include "intl.h"
+#include "sylpheed.h"
 #include "main.h"
 #include "inc.h"
 #include "mbox.h"
@@ -71,20 +72,26 @@ gint import_mbox(FolderItem *default_dest)
        gint ok = 0;
        gchar *dest_id = NULL;
 
-       if (!window)
+       if (!window) {
                import_create();
-       else
+       }
+       else {
                gtk_widget_show(window);
+       }
 
-       gtk_entry_set_text(GTK_ENTRY(file_entry), "");
-       if (default_dest && default_dest->path)
+       change_dir(sylpheed_get_startup_dir());
+
+       if (default_dest && default_dest->path) {
                dest_id = folder_item_get_identifier(default_dest);
+       }
 
        if (dest_id) {
                gtk_entry_set_text(GTK_ENTRY(dest_entry), dest_id);
                g_free(dest_id);
-       } else
+       } else {
                gtk_entry_set_text(GTK_ENTRY(dest_entry), "");
+       }
+       gtk_entry_set_text(GTK_ENTRY(file_entry), "");
        gtk_widget_grab_focus(file_entry);
 
        manage_window_set_transient(GTK_WINDOW(window));
@@ -92,38 +99,34 @@ gint import_mbox(FolderItem *default_dest)
        gtk_main();
 
        if (import_ack) {
-               const gchar *utf8filename, *destdir;
+               const gchar *utf8mbox, *destdir;
                FolderItem *dest;
 
-               utf8filename = gtk_entry_get_text(GTK_ENTRY(file_entry));
+               utf8mbox = gtk_entry_get_text(GTK_ENTRY(file_entry));
                destdir = gtk_entry_get_text(GTK_ENTRY(dest_entry));
-               if (utf8filename && *utf8filename) {
-                       const gchar *src_codeset = CS_UTF_8;
-                       const gchar *dest_codeset = conv_get_current_charset_str();
-                       gchar *filename;
-
-#warning FIXME_GTK2 /* should we use g_filename_from_utf8? */
-                       filename = conv_codeset_strdup(utf8filename,
-                                                      src_codeset,
-                                                      dest_codeset);
-                       if (!filename) {
-                               g_warning("faild to convert character set\n");
-                               filename = g_strdup(utf8filename);
+               if (utf8mbox && *utf8mbox) {
+                       gchar *mbox;
+
+                       mbox = g_filename_from_utf8(utf8mbox, -1, NULL, NULL, NULL);
+                       if (!mbox) {
+                               g_warning("Failed to convert character set.\n");
+                               mbox = g_strdup(utf8mbox);
                        }
 
                        if (!destdir || !*destdir) {
                                dest = folder_find_item_from_path(INBOX_DIR);
-                       } else
+                       } else {
                                dest = folder_find_item_from_identifier
                                        (destdir);
+                       }
 
                        if (!dest) {
                                g_warning("Can't find the folder.\n");
                        } else {
-                               ok = proc_mbox(dest, filename, FALSE);
+                               ok = proc_mbox(dest, mbox, FALSE);
                        }
 
-                       g_free(filename);
+                       g_free(mbox);
                }
        }
 
@@ -147,7 +150,7 @@ static void import_create(void)
        gtk_container_set_border_width(GTK_CONTAINER(window), 5);
        gtk_window_set_position(GTK_WINDOW(window), GTK_WIN_POS_CENTER);
        gtk_window_set_modal(GTK_WINDOW(window), TRUE);
-       gtk_window_set_policy(GTK_WINDOW(window), FALSE, TRUE, FALSE);
+       gtk_window_set_resizable(GTK_WINDOW(window), TRUE);
        g_signal_connect(G_OBJECT(window), "delete_event",
                         G_CALLBACK(delete_event), NULL);
        g_signal_connect(G_OBJECT(window), "key_press_event",
@@ -190,22 +193,34 @@ static void import_create(void)
        gtk_table_attach(GTK_TABLE(table), dest_entry, 1, 2, 1, 2,
                         GTK_EXPAND|GTK_SHRINK|GTK_FILL, 0, 0, 0);
 
-       file_button = gtk_button_new_with_label(_(" Select... "));
+#if GTK_CHECK_VERSION(2, 6, 0)
+       file_button = gtk_button_new_with_mnemonic(_("_Browse"));
+       gtk_button_set_image((GtkButton*)file_button,
+               gtk_image_new_from_stock(GTK_STOCK_OPEN, GTK_ICON_SIZE_BUTTON));
+#else
+       file_button = gtk_button_new_from_stock(GTK_STOCK_OPEN);
+#endif
        gtk_table_attach(GTK_TABLE(table), file_button, 2, 3, 0, 1,
                         0, 0, 0, 0);
        g_signal_connect(G_OBJECT(file_button), "clicked",
                         G_CALLBACK(import_filesel_cb), NULL);
 
-       dest_button = gtk_button_new_with_label(_(" Select... "));
+#if GTK_CHECK_VERSION(2, 6, 0)
+       dest_button = gtk_button_new_with_mnemonic(_("B_rowse"));
+       gtk_button_set_image((GtkButton*)dest_button,
+               gtk_image_new_from_stock(GTK_STOCK_DIRECTORY, GTK_ICON_SIZE_BUTTON));
+#else
+       dest_button = gtk_button_new_from_stock(GTK_STOCK_OPEN);
+#endif
        gtk_table_attach(GTK_TABLE(table), dest_button, 2, 3, 1, 2,
                         0, 0, 0, 0);
        g_signal_connect(G_OBJECT(dest_button), "clicked",
                         G_CALLBACK(import_destsel_cb), NULL);
 
-       gtkut_button_set_create(&confirm_area,
-                               &ok_button,     _("OK"),
-                               &cancel_button, _("Cancel"),
-                               NULL, NULL);
+       gtkut_stock_button_set_create(&confirm_area,
+                                     &ok_button, GTK_STOCK_OK,
+                                     &cancel_button, GTK_STOCK_CANCEL,
+                                     NULL, NULL);
        gtk_box_pack_end(GTK_BOX(vbox), confirm_area, FALSE, FALSE, 0);
        gtk_widget_grab_default(ok_button);
 
@@ -234,23 +249,18 @@ static void import_cancel_cb(GtkWidget *widget, gpointer data)
 static void import_filesel_cb(GtkWidget *widget, gpointer data)
 {
        gchar *filename;
+       gchar *utf8_filename;
 
        filename = filesel_select_file_open(_("Select importing file"), NULL);
        if (!filename) return;
 
-       if (g_getenv ("G_BROKEN_FILENAMES")) {
-               const gchar *oldstr = filename;
-               filename = conv_codeset_strdup (filename,
-                                               conv_get_current_charset_str(),
-                                               CS_UTF_8);
-               if (!filename) {
-                       g_warning("import_filesel_cb(): faild to convert character set.");
-                       filename = g_strdup(oldstr);
-               }
-               gtk_entry_set_text(GTK_ENTRY(file_entry), filename);
-               g_free(filename);
-       } else
-               gtk_entry_set_text(GTK_ENTRY(file_entry), filename);
+       utf8_filename = g_filename_to_utf8(filename, -1, NULL, NULL, NULL);
+       if (!utf8_filename) {
+               g_warning("import_filesel_cb(): failed to convert character set.");
+               utf8_filename = g_strdup(filename);
+       }
+       gtk_entry_set_text(GTK_ENTRY(file_entry), utf8_filename);
+       g_free(utf8_filename);
 }
 
 static void import_destsel_cb(GtkWidget *widget, gpointer data)