2007-08-11 [paul] 2.10.0cvs113
[claws.git] / src / addrgather.c
index ab4f764060e587a3036cdac87734fe5fb935d6a0..a941ad8698faa18e7b9b25a2c4962d5498632652 100644 (file)
@@ -1,10 +1,10 @@
 /*
  * Sylpheed -- a GTK+ based, lightweight, and fast e-mail client
- * Copyright (C) 2002 Match Grun
+ * Copyright (C) 2002-2007 Match Grun and the Claws Mail team
  *
  * 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
- * the Free Software Foundation; either version 2 of the License, or
+ * the Free Software Foundation; either version 3 of the License, or
  * (at your option) any later version.
  *
  * This program is distributed in the hope that it will be useful,
@@ -13,8 +13,8 @@
  * GNU General Public License for more details.
  *
  * 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.
+ * along with this program. If not, see <http://www.gnu.org/licenses/>.
+ * 
  */
 
 /*
@@ -28,6 +28,7 @@
 #include "defs.h"
 
 #include <glib.h>
+#include <glib/gi18n.h>
 #include <gdk/gdkkeysyms.h>
 #include <gtk/gtkmain.h>
 #include <gtk/gtkwidget.h>
@@ -41,7 +42,6 @@
 #include <gtk/gtkfilesel.h>
 #include <gtk/gtksignal.h>
 
-#include "intl.h"
 #include "main.h"
 #include "inc.h"
 #include "mbox.h"
@@ -91,6 +91,7 @@ static struct _AddrHarvest {
        GtkWidget *statusbar;
        gint      status_cid;
        gboolean  cancelled;
+       gboolean  done;
        gchar     *folderPath;
        GtkWidget *clistCount;
 } addrgather_dlg;
@@ -107,7 +108,7 @@ static gchar *_harv_headerNames_[] = {
 };
 static GList *_harv_messageList_;
 
-void addrgather_dlg_status_show( gchar *msg ) {
+static void addrgather_dlg_status_show( gchar *msg ) {
        if( addrgather_dlg.statusbar != NULL ) {
                gtk_statusbar_pop( GTK_STATUSBAR(addrgather_dlg.statusbar),
                        addrgather_dlg.status_cid );
@@ -127,13 +128,14 @@ static gint addrgather_dlg_delete_event(
        return TRUE;
 }
 
-static void addrgather_dlg_key_pressed(
+static gboolean addrgather_dlg_key_pressed(
        GtkWidget *widget, GdkEventKey *event, gpointer data )
 {
        if( event && event->keyval == GDK_Escape ) {
                addrgather_dlg.cancelled = TRUE;
                gtk_main_quit();
        }
+       return FALSE;
 }
 
 #define FMT_BUFSIZE 32
@@ -175,11 +177,13 @@ static gboolean addrgather_dlg_harvest() {
                addrgather_dlg_status_show(
                        _( "Please select the mail headers to search." ) );
                addrharvest_free( harvester );
+               g_free( name );
                return FALSE;
        }
 
        /* Go fer it */
-       addrgather_dlg_status_show( _( "Busy harvesting addresses..." ) );
+       addrgather_dlg_status_show( _( "Harvesting addresses..." ) );
+       GTK_EVENTS_FLUSH();
        sz = gtk_spin_button_get_value_as_int(
                GTK_SPIN_BUTTON( addrgather_dlg.spinbtnFolder ) );
        addrharvest_set_folder_size( harvester, sz );
@@ -220,15 +224,21 @@ static gboolean addrgather_dlg_harvest() {
        addrgather_dlg_status_show( _("Addresses gathered successfully.") );
 
        /* Display summary page */
-       gtk_notebook_set_page(
+       gtk_notebook_set_current_page(
                GTK_NOTEBOOK(addrgather_dlg.notebook), PAGE_FINISH );
-       gtk_widget_set_sensitive( addrgather_dlg.btnOk, FALSE );
-       gtk_widget_grab_default( addrgather_dlg.btnCancel );
+       addrgather_dlg.done = TRUE;
+       gtk_widget_set_sensitive( addrgather_dlg.btnCancel, FALSE );
+       gtk_widget_grab_default( addrgather_dlg.btnOk );
 
        return TRUE;
 }
 
 static void addrgather_dlg_ok( GtkWidget *widget, gpointer data ) {
+       if(addrgather_dlg.done) {
+               addrgather_dlg.done = FALSE;
+               gtk_main_quit();
+               return;
+       }
        if( addrgather_dlg_harvest() ) {
                addrgather_dlg.cancelled = FALSE;
        }
@@ -238,11 +248,11 @@ static void addrgather_dlg_cancel( GtkWidget *widget, gpointer data ) {
        gtk_main_quit();
 }
 
-#define PACK_CHECK_BUTTON(box, chkbtn, label) \
+#define PACK_CHECK_BUTTON(box, checkbtn, label) \
 { \
-       chkbtn = gtk_check_button_new_with_label(label); \
-       gtk_widget_show(chkbtn); \
-       gtk_box_pack_start(GTK_BOX(box), chkbtn, FALSE, TRUE, 0); \
+       checkbtn = gtk_check_button_new_with_label(label); \
+       gtk_widget_show(checkbtn); \
+       gtk_box_pack_start(GTK_BOX(box), checkbtn, FALSE, TRUE, 0); \
 }
 
 /*
@@ -275,7 +285,7 @@ static void addrgather_page_warning( gint pageNum, gchar *pageLbl ) {
 
        /* First row */
        top = 0;
-       label = gtk_label_new(_(""));
+       label = gtk_label_new("");
        gtk_table_attach(GTK_TABLE(table), label, 0, 1, top, (top + 1), GTK_FILL, 0, 0, 0);
        gtk_misc_set_alignment(GTK_MISC(label), 0, 0.5);
 
@@ -371,7 +381,7 @@ static void addrgather_page_fields( gint pageNum, gchar *pageLbl ) {
                gtk_adjustment_new( DFL_FOLDER_SIZE, MIN_FOLDER_SIZE, G_MAXINT, 1, 10, 100 );
        spinbtnFolder = gtk_spin_button_new( GTK_ADJUSTMENT(adjFolder), 1, 0 );
        gtk_box_pack_start( GTK_BOX(hboxs), spinbtnFolder, FALSE, FALSE, 0);
-       gtk_widget_set_usize( spinbtnFolder, 100, -1);
+       gtk_widget_set_size_request( spinbtnFolder, 100, -1);
        gtk_spin_button_set_numeric( GTK_SPIN_BUTTON(spinbtnFolder), TRUE );
        gtk_table_attach( GTK_TABLE(table), hboxs, 1, 2, top, (top + 1), GTK_FILL, 0, 0, 0 );
 
@@ -395,7 +405,7 @@ static void addrgather_page_fields( gint pageNum, gchar *pageLbl ) {
 
        /* Recurse folders */
        top += 4;
-       checkRecurse = gtk_check_button_new_with_label( _("Include sub-folders" ) );
+       checkRecurse = gtk_check_button_new_with_label( _("Include subfolders" ) );
        gtk_table_attach( GTK_TABLE(table), checkRecurse, 0, 2, top, (top + 1),
                        GTK_EXPAND|GTK_SHRINK|GTK_FILL, 0, 0, 0 );
 
@@ -437,7 +447,7 @@ static void addrgather_page_finish( gint pageNum, gchar *pageLbl ) {
        gtk_container_add( GTK_CONTAINER(vbox), clistSWin );
        gtk_scrolled_window_set_policy(GTK_SCROLLED_WINDOW(clistSWin),
                                       GTK_POLICY_AUTOMATIC,
-                                      GTK_POLICY_ALWAYS);
+                                      GTK_POLICY_AUTOMATIC);
 
        clistCount = gtk_clist_new_with_titles( FIELDS_N_COLS, titles );
        gtk_container_add( GTK_CONTAINER(clistSWin), clistCount );
@@ -469,15 +479,15 @@ static void addrgather_dlg_create( void ) {
        GtkWidget *hbbox;
        GtkWidget *hsbox;
 
-       window = gtk_window_new( GTK_WINDOW_DIALOG );
-       gtk_widget_set_usize( window, 380, -1 );
+       window = gtkut_window_new(GTK_WINDOW_TOPLEVEL, "addrgather" );
+       gtk_widget_set_size_request( window, 380, -1 );
        gtk_container_set_border_width(GTK_CONTAINER(window), 0);
        gtk_window_set_position( GTK_WINDOW(window), GTK_WIN_POS_CENTER );
        gtk_window_set_modal( GTK_WINDOW(window), TRUE );       
-       gtk_signal_connect( GTK_OBJECT(window), "delete_event",
-               GTK_SIGNAL_FUNC( addrgather_dlg_delete_event ), NULL );
-       gtk_signal_connect( GTK_OBJECT(window), "key_press_event",
-               GTK_SIGNAL_FUNC( addrgather_dlg_key_pressed ), NULL );
+       g_signal_connect(G_OBJECT(window), "delete_event",
+                        G_CALLBACK(addrgather_dlg_delete_event), NULL);
+       g_signal_connect(G_OBJECT(window), "key_press_event",
+                        G_CALLBACK(addrgather_dlg_key_pressed), NULL);
 
        vbox = gtk_vbox_new( FALSE, 8 );
        gtk_container_add( GTK_CONTAINER(window), vbox );
@@ -502,16 +512,17 @@ static void addrgather_dlg_create( void ) {
        gtk_box_pack_start( GTK_BOX(hsbox), statusbar, TRUE, TRUE, BORDER_WIDTH );
 
        /* Button panel */
-       gtkut_button_set_create( &hbbox, &btnOk, _("OK"),
-               &btnCancel, _("Cancel"), NULL, NULL );
+       gtkut_stock_button_set_create(&hbbox, &btnOk, GTK_STOCK_OK,
+                                     &btnCancel, GTK_STOCK_CANCEL,
+                                     NULL, NULL );
        gtk_box_pack_end( GTK_BOX(vbox), hbbox, FALSE, FALSE, 0 );
-       gtk_container_set_border_width( GTK_CONTAINER(hbbox), 0 );
+       gtk_container_set_border_width( GTK_CONTAINER(hbbox), 10 );
 
        /* Signal handlers */
-       gtk_signal_connect( GTK_OBJECT(btnOk), "clicked",
-               GTK_SIGNAL_FUNC(addrgather_dlg_ok), NULL );
-       gtk_signal_connect( GTK_OBJECT(btnCancel), "clicked",
-               GTK_SIGNAL_FUNC(addrgather_dlg_cancel), NULL );
+       g_signal_connect(G_OBJECT(btnOk), "clicked",
+                        G_CALLBACK(addrgather_dlg_ok), NULL);
+       g_signal_connect(G_OBJECT(btnCancel), "clicked",
+                        G_CALLBACK(addrgather_dlg_cancel), NULL);
 
        gtk_widget_show_all( vbox );
        addrgather_dlg.window     = window;
@@ -520,7 +531,7 @@ static void addrgather_dlg_create( void ) {
        addrgather_dlg.btnCancel  = btnCancel;
        addrgather_dlg.statusbar  = statusbar;
        addrgather_dlg.status_cid = gtk_statusbar_get_context_id(
-               GTK_STATUSBAR(statusbar), "Harvest E-Mail Address Dialog" );
+               GTK_STATUSBAR(statusbar), "Harvest Email Address Dialog" );
 
        /* Create notebook pages */
        addrgather_page_warning( PAGE_WARNING, _( "Warning" ) );
@@ -552,10 +563,12 @@ AddressBookFile *addrgather_dlg_execute(
        if( ! addrgather_dlg.window ) {
                addrgather_dlg_create();
        }
+       
+       addrgather_dlg.done = FALSE;
 
        errFlag = TRUE;
        if( folderItem && folderItem->path ) {
-               gtk_notebook_set_page(
+               gtk_notebook_set_current_page(
                        GTK_NOTEBOOK(addrgather_dlg.notebook), PAGE_FIELDS );
                addrgather_dlg.folderPath = folder_item_get_path( folderItem );
 
@@ -569,7 +582,7 @@ AddressBookFile *addrgather_dlg_execute(
                        gtk_toggle_button_set_active(
                                GTK_TOGGLE_BUTTON(addrgather_dlg.checkHeader[i]),
                                FALSE );
-                       if( g_strcasecmp( _harv_headerNames_[i], HEADER_FROM ) == 0 ) {
+                       if( g_utf8_collate( _harv_headerNames_[i], HEADER_FROM ) == 0 ) {
                                gtk_toggle_button_set_active(
                                        GTK_TOGGLE_BUTTON(addrgather_dlg.checkHeader[i]),
                                        TRUE );
@@ -584,7 +597,7 @@ AddressBookFile *addrgather_dlg_execute(
        /* Apply window title */
        if( sourceInd ) {
                gtk_window_set_title( GTK_WINDOW(addrgather_dlg.window),
-                       _("Harvest E-Mail Addresses - from Selected Messages") );
+                       _("Harvest Email Addresses - from Selected Messages") );
                gtk_widget_set_sensitive( addrgather_dlg.checkRecurse, FALSE );
                if( msgList == NULL ) {
                        errFlag = TRUE;
@@ -592,7 +605,7 @@ AddressBookFile *addrgather_dlg_execute(
        }
        else {
                gtk_window_set_title( GTK_WINDOW(addrgather_dlg.window),
-                       _("Harvest E-Mail Addresses - from Folder") );
+                       _("Harvest Email Addresses - from Folder") );
                gtk_widget_set_sensitive( addrgather_dlg.checkRecurse, TRUE );
        }
        gtk_toggle_button_set_active(
@@ -602,7 +615,7 @@ AddressBookFile *addrgather_dlg_execute(
        gtk_widget_show( addrgather_dlg.window );
 
        if( errFlag ) {
-               gtk_notebook_set_page(
+               gtk_notebook_set_current_page(
                        GTK_NOTEBOOK(addrgather_dlg.notebook), PAGE_WARNING );
                gtk_widget_set_sensitive( addrgather_dlg.btnOk, FALSE );
                gtk_widget_grab_default( addrgather_dlg.btnCancel );