2007-12-06 [colin] 3.1.0cvs62
[claws.git] / src / prefs_account.c
index d601b4ae715b9e655c3ed6ecc3df0772f067992d..9def1b443310186b6f038da64a7861e8f73b1c5c 100644 (file)
@@ -4,7 +4,7 @@
  *
  * 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., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301, USA.
+ * along with this program. If not, see <http://www.gnu.org/licenses/>.
+ * 
  */
 
 #ifdef HAVE_CONFIG_H
@@ -129,6 +129,7 @@ typedef struct ReceivePage
        GtkWidget *local_inbox_btn;
 
        GtkWidget *filter_on_recv_checkbtn;
+       GtkWidget *filterhook_on_recv_checkbtn;
        GtkWidget *recvatgetall_checkbtn;
        
        GtkWidget *imap_frame;
@@ -178,11 +179,11 @@ typedef struct ComposePage
        GtkWidget *autobcc_entry;
        GtkWidget *autoreplyto_checkbtn;
        GtkWidget *autoreplyto_entry;
-#ifdef USE_ASPELL
+#if USE_ASPELL
        GtkWidget *checkbtn_enable_default_dictionary;
-       GtkWidget *optmenu_default_dictionary;
+       GtkWidget *combo_default_dictionary;
        GtkWidget *checkbtn_enable_default_alt_dictionary;
-       GtkWidget *optmenu_default_alt_dictionary;
+       GtkWidget *combo_default_alt_dictionary;
 #endif
 } ComposePage;
 
@@ -267,8 +268,10 @@ typedef struct AdvancedPage
        GtkWidget *crosspost_checkbtn;
        GtkWidget *crosspost_colormenu;
 
+#ifndef G_OS_WIN32
        GtkWidget *tunnelcmd_checkbtn;
        GtkWidget *tunnelcmd_entry;
+#endif
 
        GtkWidget *sent_folder_checkbtn;
        GtkWidget *sent_folder_entry;
@@ -286,7 +289,7 @@ static SendPage send_page;
 static ComposePage compose_page;
 static TemplatesPage templates_page;
 static PrivacyPage privacy_page;
-#if USE_OPENSSL
+#if (defined(USE_OPENSSL) || defined (USE_GNUTLS))
 static SSLPage ssl_page;
 #endif
 static AdvancedPage advanced_page;
@@ -314,8 +317,8 @@ static void prefs_account_protocol_set_optmenu              (PrefParam *pparam);
 static void prefs_account_protocol_changed             (GtkComboBox *combobox,
                                                        gpointer data);
 
-static void prefs_account_set_string_from_optmenu      (PrefParam *pparam);
-static void prefs_account_set_optmenu_from_string      (PrefParam *pparam);
+static void prefs_account_set_string_from_combobox (PrefParam *pparam);
+static void prefs_account_set_privacy_combobox_from_string (PrefParam *pparam);
 
 static void prefs_account_imap_auth_type_set_data_from_optmenu
                                                        (PrefParam *pparam);
@@ -335,6 +338,8 @@ static void prefs_account_nntpauth_toggled(GtkToggleButton *button,
                                           gpointer user_data);
 static void prefs_account_mailcmd_toggled(GtkToggleButton *button,
                                          gpointer user_data);
+static void prefs_account_filter_on_recv_toggled(GtkToggleButton *button,
+                                         gpointer user_data);
 
 #if USE_ASPELL
 static void prefs_account_compose_default_dictionary_set_string_from_optmenu
@@ -432,6 +437,10 @@ static PrefParam receive_param[] = {
         &receive_page.filter_on_recv_checkbtn,
         prefs_set_data_from_toggle, prefs_set_toggle},
 
+       {"filterhook_on_receive", "TRUE", &tmp_ac_prefs.filterhook_on_recv, P_BOOL,
+        &receive_page.filterhook_on_recv_checkbtn,
+        prefs_set_data_from_toggle, prefs_set_toggle},
+
        {"imap_auth_method", "0", &tmp_ac_prefs.imap_auth_type, P_ENUM,
         &receive_page.imap_auth_type_optmenu,
         prefs_account_imap_auth_type_set_data_from_optmenu,
@@ -458,7 +467,7 @@ static PrefParam receive_param[] = {
         &receive_page.subsonly_checkbtn,
         prefs_set_data_from_toggle, prefs_set_toggle},
 
-       {"low_bandwidth", "TRUE", &tmp_ac_prefs.low_bandwidth, P_BOOL,
+       {"low_bandwidth", "FALSE", &tmp_ac_prefs.low_bandwidth, P_BOOL,
         &receive_page.low_bandwidth_checkbtn,
         prefs_set_data_from_toggle, prefs_set_toggle},
 
@@ -546,7 +555,7 @@ static PrefParam compose_param[] = {
         prefs_set_data_from_toggle, prefs_set_toggle},
 
        {"default_dictionary", NULL, &tmp_ac_prefs.default_dictionary, P_STRING,
-        &compose_page.optmenu_default_dictionary,
+        &compose_page.combo_default_dictionary,
         prefs_account_compose_default_dictionary_set_string_from_optmenu,
         prefs_account_compose_default_dictionary_set_optmenu_from_string},
 
@@ -555,7 +564,7 @@ static PrefParam compose_param[] = {
         prefs_set_data_from_toggle, prefs_set_toggle},
 
        {"default_alt_dictionary", NULL, &tmp_ac_prefs.default_alt_dictionary, P_STRING,
-        &compose_page.optmenu_default_alt_dictionary,
+        &compose_page.combo_default_alt_dictionary,
         prefs_account_compose_default_dictionary_set_string_from_optmenu,
         prefs_account_compose_default_dictionary_set_optmenu_from_string},
 #else
@@ -618,7 +627,8 @@ static PrefParam templates_param[] = {
 static PrefParam privacy_param[] = {
        {"default_privacy_system", "", &tmp_ac_prefs.default_privacy_system, P_STRING,
         &privacy_page.default_privacy_system,
-        prefs_account_set_string_from_optmenu, prefs_account_set_optmenu_from_string},
+        prefs_account_set_string_from_combobox,
+        prefs_account_set_privacy_combobox_from_string},
 
        {"default_encrypt", "FALSE", &tmp_ac_prefs.default_encrypt, P_BOOL,
         &privacy_page.default_encrypt_checkbtn,
@@ -647,7 +657,7 @@ static PrefParam privacy_param[] = {
 };
 
 static PrefParam ssl_param[] = {
-#if USE_OPENSSL
+#if (defined(USE_OPENSSL) || defined (USE_GNUTLS))
        {"ssl_pop", "0", &tmp_ac_prefs.ssl_pop, P_ENUM,
         &ssl_page.pop_nossl_radiobtn,
         prefs_account_enum_set_data_from_radiobtn,
@@ -731,7 +741,7 @@ static PrefParam advanced_param[] = {
        {"domain", NULL, &tmp_ac_prefs.domain, P_STRING,
         &advanced_page.domain_entry,
         prefs_set_data_from_entry, prefs_set_entry},
-
+#ifndef G_OS_WIN32
        {"set_tunnelcmd", "FALSE", &tmp_ac_prefs.set_tunnelcmd, P_BOOL,
         &advanced_page.tunnelcmd_checkbtn,
         prefs_set_data_from_toggle, prefs_set_toggle},
@@ -739,7 +749,7 @@ static PrefParam advanced_param[] = {
        {"tunnelcmd", NULL, &tmp_ac_prefs.tunnelcmd, P_STRING,
         &advanced_page.tunnelcmd_entry,
         prefs_set_data_from_entry, prefs_set_entry},
-
+#endif
        {"mark_crosspost_read", "FALSE", &tmp_ac_prefs.mark_crosspost_read, P_BOOL,
         &advanced_page.crosspost_checkbtn,
         prefs_set_data_from_toggle, prefs_set_toggle},
@@ -802,66 +812,79 @@ static void pop_bfr_smtp_tm_set_sens              (GtkWidget      *widget,
 
 static void prefs_account_edit_custom_header   (void);
 
-static void privacy_system_activated(GtkMenuItem *menuitem)
+
+#define COMBOBOX_PRIVACY_PLUGIN_ID 3
+
+/* Enable/disable necessary preference widgets based on current privacy
+ * system choice. */
+static void privacy_system_activated(GtkWidget *combobox)
 {
-       const gcharsystem_id;
+       const gchar *system_id;
        gboolean privacy_enabled = FALSE;
-       
-       system_id = g_object_get_data(G_OBJECT(menuitem), MENU_VAL_ID);
+       gint privacy_enabled_int;
+       GtkTreeIter iter;
+       GtkListStore *menu = GTK_LIST_STORE(gtk_combo_box_get_model(
+                               GTK_COMBO_BOX(combobox)));
+
+       gtk_combo_box_get_active_iter(GTK_COMBO_BOX(combobox), &iter);
+
+       gtk_tree_model_get(GTK_TREE_MODEL(menu), &iter,
+                       COMBOBOX_PRIVACY_PLUGIN_ID, &system_id,
+                       COMBOBOX_DATA, &privacy_enabled_int,
+                       -1);
        
        privacy_enabled = strcmp(system_id, "");
 
-       if (g_object_get_data(G_OBJECT(menuitem), MENU_VAL_DATA) == NULL ||
-           GPOINTER_TO_INT(g_object_get_data(G_OBJECT(menuitem), MENU_VAL_DATA)) == FALSE)
+       if( privacy_enabled_int == 0 )
                privacy_enabled = FALSE;
 
-       gtk_widget_set_sensitive (privacy_page.default_encrypt_checkbtn, privacy_enabled);
-       gtk_widget_set_sensitive (privacy_page.default_encrypt_reply_checkbtn, privacy_enabled);
-       gtk_widget_set_sensitive (privacy_page.default_sign_checkbtn, privacy_enabled);
-       gtk_widget_set_sensitive (privacy_page.encrypt_to_self_checkbtn, privacy_enabled);
+       gtk_widget_set_sensitive (privacy_page.default_encrypt_checkbtn,
+                       privacy_enabled);
+       gtk_widget_set_sensitive (privacy_page.default_encrypt_reply_checkbtn,
+                       privacy_enabled);
+       gtk_widget_set_sensitive (privacy_page.default_sign_checkbtn,
+                       privacy_enabled);
+       gtk_widget_set_sensitive (privacy_page.encrypt_to_self_checkbtn,
+                       privacy_enabled);
        gtk_widget_set_sensitive (privacy_page.save_clear_text_checkbtn, 
                privacy_enabled && !gtk_toggle_button_get_active(
                                        GTK_TOGGLE_BUTTON(privacy_page.encrypt_to_self_checkbtn)));
 }
 
+/* Populate the privacy system choice combobox with valid choices */
 static void update_privacy_system_menu() {
-       GtkWidget *menu;
-       GtkWidget *menuitem;
+       GtkListStore *menu;
+       GtkTreeIter iter;
        GSList *system_ids, *cur;
 
-       menu = gtk_menu_new();
-
-       menuitem = gtk_menu_item_new_with_label(_("None"));
-       gtk_widget_show(menuitem);
-       g_object_set_data(G_OBJECT(menuitem), MENU_VAL_ID, "");
-       g_object_set_data(G_OBJECT(menuitem), MENU_VAL_DATA, GINT_TO_POINTER(FALSE));
-       gtk_menu_append(GTK_MENU(menu), menuitem);
+       menu = GTK_LIST_STORE(gtk_combo_box_get_model(
+                       GTK_COMBO_BOX(privacy_page.default_privacy_system)));
 
-       g_signal_connect(G_OBJECT(menuitem), "activate",
-                        G_CALLBACK(privacy_system_activated),
-                        NULL);
+       /* First add "None", as that one is always available. :) */
+       gtk_list_store_append(menu, &iter);
+       gtk_list_store_set(menu, &iter,
+                       COMBOBOX_TEXT, _("None"),
+                       COMBOBOX_DATA, 0,
+                       COMBOBOX_SENS, TRUE,
+                       COMBOBOX_PRIVACY_PLUGIN_ID, "",
+                       -1);
 
+       /* Now go through list of available privacy systems and add an entry
+        * for each. */
        system_ids = privacy_get_system_ids();
        for (cur = system_ids; cur != NULL; cur = g_slist_next(cur)) {
                gchar *id = (gchar *) cur->data;
                const gchar *name;
                
                name = privacy_system_get_name(id);
-               menuitem = gtk_menu_item_new_with_label(name);
-               gtk_widget_show(menuitem);
-               g_object_set_data_full(G_OBJECT(menuitem), MENU_VAL_ID, id, g_free);
-               g_object_set_data(G_OBJECT(menuitem), MENU_VAL_DATA, GINT_TO_POINTER(TRUE));
-
-               gtk_menu_append(GTK_MENU(menu), menuitem);
-
-               g_signal_connect(G_OBJECT(menuitem), "activate",
-                                G_CALLBACK(privacy_system_activated),
-                                NULL);
-
-               
+               gtk_list_store_append(menu, &iter);
+               gtk_list_store_set(menu, &iter,
+                               COMBOBOX_TEXT, name,
+                               COMBOBOX_DATA, 1,
+                               COMBOBOX_SENS, TRUE,
+                               COMBOBOX_PRIVACY_PLUGIN_ID, id,
+                               -1);
        }
-
-       gtk_option_menu_set_menu(GTK_OPTION_MENU(privacy_page.default_privacy_system), menu);
 }
 
 #define TABLE_YPAD 2
@@ -1021,7 +1044,7 @@ static void basic_create_widget_func(PrefsPage * _page,
        no_imap_warn_icon = gtk_image_new_from_stock
                         (GTK_STOCK_DIALOG_WARNING, GTK_ICON_SIZE_SMALL_TOOLBAR);
        no_imap_warn_label = gtk_label_new(_("<span weight=\"bold\">Warning: this version of Claws Mail\n"
-                         "has been built without IMAP support.</span>"));
+                         "has been built without IMAP and News support.</span>"));
        gtk_label_set_use_markup(GTK_LABEL(no_imap_warn_label), TRUE);
 
        gtk_box_pack_start(GTK_BOX (optmenubox), no_imap_warn_icon, FALSE, FALSE, 0);
@@ -1265,6 +1288,7 @@ static void receive_create_widget_func(PrefsPage * _page,
        GtkTooltips *size_limit_tooltip;
        GtkWidget *label;
        GtkWidget *filter_on_recv_checkbtn;
+       GtkWidget *filterhook_on_recv_checkbtn;
        GtkWidget *vbox3;
        GtkWidget *inbox_label;
        GtkWidget *inbox_entry;
@@ -1283,8 +1307,8 @@ static void receive_create_widget_func(PrefsPage * _page,
        GtkWidget *local_inbox_btn;
 
        GtkWidget *optmenu;
-       GtkWidget *optmenu_menu;
-       GtkWidget *menuitem;
+       GtkListStore *menu;
+       GtkTreeIter iter;
        GtkWidget *recvatgetall_checkbtn;
 
        GtkWidget *hbox2;
@@ -1307,7 +1331,7 @@ static void receive_create_widget_func(PrefsPage * _page,
        gtk_widget_show (local_hbox);
        gtk_box_pack_start (GTK_BOX (local_vbox), local_hbox, FALSE, FALSE, 0);
 
-       local_inbox_label = gtk_label_new (_("Default inbox"));
+       local_inbox_label = gtk_label_new (_("Default Inbox"));
        gtk_widget_show (local_inbox_label);
        gtk_box_pack_start (GTK_BOX (local_hbox), local_inbox_label, FALSE, FALSE, 0);
 
@@ -1393,7 +1417,7 @@ static void receive_create_widget_func(PrefsPage * _page,
        gtk_widget_show (hbox1);
        gtk_box_pack_start (GTK_BOX (vbox2), hbox1, FALSE, FALSE, 0);
 
-       inbox_label = gtk_label_new (_("Default inbox"));
+       inbox_label = gtk_label_new (_("Default Inbox"));
        gtk_widget_show (inbox_label);
        gtk_box_pack_start (GTK_BOX (hbox1), inbox_label, FALSE, FALSE, 0);
 
@@ -1451,19 +1475,17 @@ static void receive_create_widget_func(PrefsPage * _page,
        gtk_widget_show (label);
        gtk_box_pack_start (GTK_BOX (hbox1), label, FALSE, FALSE, 0);
 
-       optmenu = gtk_option_menu_new ();
+
+       optmenu = gtkut_sc_combobox_create(NULL, FALSE);
+       menu = GTK_LIST_STORE(gtk_combo_box_get_model(GTK_COMBO_BOX(optmenu)));
        gtk_widget_show (optmenu);
        gtk_box_pack_start (GTK_BOX (hbox1), optmenu, FALSE, FALSE, 0);
 
-       optmenu_menu = gtk_menu_new ();
-
-       MENUITEM_ADD (optmenu_menu, menuitem, _("Automatic"), 0);
-       MENUITEM_ADD (optmenu_menu, menuitem, "LOGIN", IMAP_AUTH_LOGIN);
-       MENUITEM_ADD (optmenu_menu, menuitem, "CRAM-MD5", IMAP_AUTH_CRAM_MD5);
-       MENUITEM_ADD (optmenu_menu, menuitem, "ANONYMOUS", IMAP_AUTH_ANON);
-       MENUITEM_ADD (optmenu_menu, menuitem, "GSSAPI", IMAP_AUTH_GSSAPI);
-
-       gtk_option_menu_set_menu (GTK_OPTION_MENU (optmenu), optmenu_menu);
+       COMBOBOX_ADD (menu, _("Automatic"), 0);
+       COMBOBOX_ADD (menu, "LOGIN", IMAP_AUTH_LOGIN);
+       COMBOBOX_ADD (menu, "CRAM-MD5", IMAP_AUTH_CRAM_MD5);
+       COMBOBOX_ADD (menu, "ANONYMOUS", IMAP_AUTH_ANON);
+       COMBOBOX_ADD (menu, "GSSAPI", IMAP_AUTH_GSSAPI);
 
        hbox1 = gtk_hbox_new (FALSE, 8);
        gtk_widget_show (hbox1);
@@ -1494,7 +1516,7 @@ static void receive_create_widget_func(PrefsPage * _page,
        gtk_box_pack_start (GTK_BOX (vbox2), hbox1, FALSE, FALSE, 4);
 
        PACK_CHECK_BUTTON (hbox1, low_bandwidth_checkbtn,
-                          _("Bandwidth-efficient mode"));
+                          _("Bandwidth-efficient mode (prevents retrieving remote tags)"));
        gtk_tooltips_set_tip(GTK_TOOLTIPS(inbox_tooltip), low_bandwidth_checkbtn,
                             _("This mode uses less bandwidth, but can be slower with some servers."),
                             NULL);
@@ -1502,6 +1524,13 @@ static void receive_create_widget_func(PrefsPage * _page,
        PACK_CHECK_BUTTON (vbox1, filter_on_recv_checkbtn,
                           _("Filter messages on receiving"));
 
+       g_signal_connect(G_OBJECT(filter_on_recv_checkbtn), "toggled",
+                        G_CALLBACK(prefs_account_filter_on_recv_toggled),
+                        NULL);
+
+       PACK_CHECK_BUTTON (vbox1, filterhook_on_recv_checkbtn,
+                          _("Allow filtering using plugins on receiving"));
+
        PACK_CHECK_BUTTON
                (vbox1, recvatgetall_checkbtn,
                 _("'Get Mail' checks for new messages on this account"));
@@ -1513,6 +1542,7 @@ static void receive_create_widget_func(PrefsPage * _page,
        page->size_limit_checkbtn        = size_limit_checkbtn;
        page->size_limit_entry         = size_limit_entry;
        page->filter_on_recv_checkbtn    = filter_on_recv_checkbtn;
+       page->filterhook_on_recv_checkbtn = filterhook_on_recv_checkbtn;
        page->inbox_label              = inbox_label;
        page->inbox_entry              = inbox_entry;
        page->inbox_btn                = inbox_btn;
@@ -1564,8 +1594,8 @@ static void send_create_widget_func(PrefsPage * _page,
        GtkWidget *vbox3;
        GtkWidget *smtp_auth_checkbtn;
        GtkWidget *optmenu;
-       GtkWidget *optmenu_menu;
-       GtkWidget *menuitem;
+       GtkListStore *menu;
+       GtkTreeIter iter;
        GtkWidget *vbox4;
        GtkWidget *hbox_spc;
        GtkWidget *label;
@@ -1624,20 +1654,17 @@ static void send_create_widget_func(PrefsPage * _page,
        gtk_widget_show (label);
        gtk_box_pack_start (GTK_BOX (hbox), label, FALSE, FALSE, 0);
 
-       optmenu = gtk_option_menu_new ();
+       optmenu = gtkut_sc_combobox_create(NULL, FALSE);
+       menu = GTK_LIST_STORE(gtk_combo_box_get_model(GTK_COMBO_BOX(optmenu)));
        gtk_widget_show (optmenu);
        gtk_box_pack_start (GTK_BOX (hbox), optmenu, FALSE, FALSE, 0);
 
-       optmenu_menu = gtk_menu_new ();
-
-       MENUITEM_ADD (optmenu_menu, menuitem, _("Automatic"), 0);
-       MENUITEM_ADD (optmenu_menu, menuitem, "PLAIN", SMTPAUTH_PLAIN);
-       MENUITEM_ADD (optmenu_menu, menuitem, "LOGIN", SMTPAUTH_LOGIN);
-       MENUITEM_ADD (optmenu_menu, menuitem, "CRAM-MD5", SMTPAUTH_CRAM_MD5);
-       MENUITEM_ADD (optmenu_menu, menuitem, "DIGEST-MD5", SMTPAUTH_DIGEST_MD5);
-       gtk_widget_set_sensitive (menuitem, FALSE);
-
-       gtk_option_menu_set_menu (GTK_OPTION_MENU (optmenu), optmenu_menu);
+       COMBOBOX_ADD (menu, _("Automatic"), 0);
+       COMBOBOX_ADD (menu, "PLAIN", SMTPAUTH_PLAIN);
+       COMBOBOX_ADD (menu, "LOGIN", SMTPAUTH_LOGIN);
+       COMBOBOX_ADD (menu, "CRAM-MD5", SMTPAUTH_CRAM_MD5);
+       COMBOBOX_ADD (menu, "DIGEST-MD5", SMTPAUTH_DIGEST_MD5);
+       gtk_list_store_set(menu, &iter, COMBOBOX_SENS, FALSE, -1);
 
        PACK_VSPACER(vbox4, vbox_spc, VSPACING_NARROW_2);
 
@@ -1786,9 +1813,9 @@ static void compose_create_widget_func(PrefsPage * _page,
        GtkWidget *frame_dict;
        GtkWidget *table_dict;
        GtkWidget *checkbtn_enable_default_dictionary = NULL;
-       GtkWidget *optmenu_default_dictionary = NULL;
+       GtkWidget *combo_default_dictionary = NULL;
        GtkWidget *checkbtn_enable_default_alt_dictionary = NULL;
-       GtkWidget *optmenu_default_alt_dictionary = NULL;
+       GtkWidget *combo_default_alt_dictionary = NULL;
 #endif
 
        vbox1 = gtk_vbox_new (FALSE, VSPACING);
@@ -1926,15 +1953,12 @@ static void compose_create_widget_func(PrefsPage * _page,
        gtk_toggle_button_set_active(GTK_TOGGLE_BUTTON(checkbtn_enable_default_dictionary),
                        tmp_ac_prefs.enable_default_dictionary);
 
-       optmenu_default_dictionary = gtk_option_menu_new();
-       gtk_table_attach(GTK_TABLE(table_dict), optmenu_default_dictionary, 1, 2,
+       combo_default_dictionary = gtkaspell_dictionary_combo_new(
+                                               prefs_common.aspell_path, TRUE);
+       gtk_table_attach(GTK_TABLE(table_dict), combo_default_dictionary, 1, 2,
                        0, 1, GTK_EXPAND | GTK_FILL, GTK_SHRINK, 0, 0);
 
-       gtk_option_menu_set_menu(GTK_OPTION_MENU(optmenu_default_dictionary), 
-                       gtkaspell_dictionary_option_menu_new(
-                       prefs_common.aspell_path));
-
-       SET_TOGGLE_SENSITIVITY(checkbtn_enable_default_dictionary, optmenu_default_dictionary);
+       SET_TOGGLE_SENSITIVITY(checkbtn_enable_default_dictionary, combo_default_dictionary);
 
        /* Default dictionary */
        checkbtn_enable_default_alt_dictionary = gtk_check_button_new_with_label(_("Default alternate dictionary"));
@@ -1943,15 +1967,12 @@ static void compose_create_widget_func(PrefsPage * _page,
        gtk_toggle_button_set_active(GTK_TOGGLE_BUTTON(checkbtn_enable_default_alt_dictionary),
                        tmp_ac_prefs.enable_default_alt_dictionary);
 
-       optmenu_default_alt_dictionary = gtk_option_menu_new();
-       gtk_table_attach(GTK_TABLE(table_dict), optmenu_default_alt_dictionary, 1, 2,
+       combo_default_alt_dictionary = gtkaspell_dictionary_combo_new(
+                                               prefs_common.aspell_path, FALSE);
+       gtk_table_attach(GTK_TABLE(table_dict), combo_default_alt_dictionary, 1, 2,
                        1, 2, GTK_EXPAND | GTK_FILL, GTK_SHRINK, 0, 0);
 
-       gtk_option_menu_set_menu(GTK_OPTION_MENU(optmenu_default_alt_dictionary), 
-                       gtkaspell_dictionary_option_menu_new_with_refresh(
-                       prefs_common.aspell_path, FALSE));
-
-       SET_TOGGLE_SENSITIVITY(checkbtn_enable_default_alt_dictionary, optmenu_default_alt_dictionary);
+       SET_TOGGLE_SENSITIVITY(checkbtn_enable_default_alt_dictionary, combo_default_alt_dictionary);
 
        gtk_widget_show_all(table_dict);
 #endif
@@ -1969,22 +1990,19 @@ static void compose_create_widget_func(PrefsPage * _page,
        page->autoreplyto_entry  = autoreplyto_entry;
 #ifdef USE_ASPELL
        page->checkbtn_enable_default_dictionary = checkbtn_enable_default_dictionary;
-       page->optmenu_default_dictionary = optmenu_default_dictionary;
+       page->combo_default_dictionary = combo_default_dictionary;
        page->checkbtn_enable_default_alt_dictionary = checkbtn_enable_default_alt_dictionary;
-       page->optmenu_default_alt_dictionary = optmenu_default_alt_dictionary;
+       page->combo_default_alt_dictionary = combo_default_alt_dictionary;
 #endif
 
 #ifdef USE_ASPELL
        /* reset gtkaspell menus */
-       if (compose_page.optmenu_default_dictionary != NULL) {
-               gtk_option_menu_remove_menu(GTK_OPTION_MENU(compose_page.optmenu_default_dictionary));
-               gtk_option_menu_set_menu(GTK_OPTION_MENU(compose_page.optmenu_default_dictionary), 
-                               gtkaspell_dictionary_option_menu_new(
-                               prefs_common.aspell_path));
-               gtk_option_menu_remove_menu(GTK_OPTION_MENU(compose_page.optmenu_default_alt_dictionary));
-               gtk_option_menu_set_menu(GTK_OPTION_MENU(compose_page.optmenu_default_alt_dictionary), 
-                               gtkaspell_dictionary_option_menu_new_with_refresh(
-                               prefs_common.aspell_path, FALSE));
+       if (compose_page.combo_default_dictionary != NULL) {
+               gtk_combo_box_set_model(GTK_COMBO_BOX(compose_page.combo_default_dictionary),
+                                       gtkaspell_dictionary_store_new(prefs_common.aspell_path));
+               gtk_combo_box_set_model(GTK_COMBO_BOX(compose_page.combo_default_alt_dictionary),
+                                       gtkaspell_dictionary_store_new_with_refresh(
+                                               prefs_common.aspell_path, FALSE));
        }
 #endif
 
@@ -2007,36 +2025,59 @@ static void templates_create_widget_func(PrefsPage * _page,
        TemplatesPage *page = (TemplatesPage *) _page;
        PrefsAccount *ac_prefs = (PrefsAccount *) data;
        GtkWidget *vbox;
+       GtkWidget *vbox2;
+       GtkWidget *notebook;
 
-       vbox = gtk_vbox_new(FALSE, VSPACING);
+       vbox = gtk_vbox_new(FALSE, 0);
        gtk_widget_show(vbox);
-       gtk_container_set_border_width (GTK_CONTAINER (vbox), VBOX_BORDER);
+       
+       notebook = gtk_notebook_new();
+       gtk_widget_show(notebook);
+       gtk_notebook_set_homogeneous_tabs(GTK_NOTEBOOK(notebook), TRUE);
+       gtk_box_pack_start(GTK_BOX(vbox), notebook, TRUE, TRUE, 0);
+
+       /* compose format */
+       vbox2 = gtk_vbox_new (FALSE, VSPACING);
+       gtk_widget_show (vbox2);
+       gtk_container_set_border_width (GTK_CONTAINER (vbox2), VBOX_BORDER);
 
-       /* compose/reply/forward formats */
        quotefmt_create_new_msg_fmt_widgets(
                                window,
-                               vbox,
+                               vbox2,
                                &page->checkbtn_compose_with_format,
-                               _("Use a specific format for new messages"),
                                &page->compose_subject_format,
                                &page->compose_body_format,
                                FALSE);
+       gtk_notebook_append_page(GTK_NOTEBOOK(notebook), vbox2, gtk_label_new(_("Compose")));
+
+       /* reply format */      
+       vbox2 = gtk_vbox_new (FALSE, VSPACING);
+       gtk_widget_show (vbox2);
+       gtk_container_set_border_width (GTK_CONTAINER (vbox2), VBOX_BORDER);
+       
        quotefmt_create_reply_fmt_widgets(
                                window,
-                               vbox,
+                               vbox2,
                                &page->checkbtn_reply_with_format,
-                               _("Use a specific reply quote format"),
                                &page->reply_quotemark,
                                &page->reply_body_format,
                                FALSE);
+       gtk_notebook_append_page(GTK_NOTEBOOK(notebook), vbox2, gtk_label_new(_("Reply")));
+
+       /* forward format */    
+       vbox2 = gtk_vbox_new (FALSE, VSPACING);
+       gtk_widget_show (vbox2);
+       gtk_container_set_border_width (GTK_CONTAINER (vbox2), VBOX_BORDER);
+
        quotefmt_create_forward_fmt_widgets(
                                window,
-                               vbox,
+                               vbox2,
                                &page->checkbtn_forward_with_format,
-                               _("Use a specific forward quote format"),
                                &page->forward_quotemark,
                                &page->forward_body_format,
                                FALSE);
+       gtk_notebook_append_page(GTK_NOTEBOOK(notebook), vbox2, gtk_label_new(_("Forward")));
+
        quotefmt_add_info_button(window, vbox);
 
        tmp_ac_prefs = *ac_prefs;
@@ -2063,6 +2104,8 @@ static void privacy_create_widget_func(PrefsPage * _page,
        GtkWidget *hbox1;
        GtkWidget *label;
        GtkWidget *default_privacy_system;
+       GtkListStore *menu;
+       GtkCellRenderer *rend;
        GtkWidget *default_encrypt_checkbtn;
        GtkWidget *default_encrypt_reply_checkbtn;
        GtkWidget *default_sign_checkbtn;
@@ -2085,10 +2128,30 @@ static void privacy_create_widget_func(PrefsPage * _page,
        gtk_widget_show(label);
        gtk_box_pack_start (GTK_BOX (hbox1), label, FALSE, FALSE, 0);
 
-       default_privacy_system = gtk_option_menu_new();
+       /* Can't use gtkut_sc_combobox_create() here, because model for this
+        * combobox needs an extra string column to store privacy plugin id. */
+       menu = gtk_list_store_new(4,
+                       G_TYPE_STRING,
+                       G_TYPE_INT,
+                       G_TYPE_BOOLEAN,
+                       G_TYPE_STRING); /* This is where we store the privacy plugin id. */
+       default_privacy_system = gtk_combo_box_new_with_model(GTK_TREE_MODEL(menu));
+
+       rend = gtk_cell_renderer_text_new();
+       gtk_cell_layout_pack_start(GTK_CELL_LAYOUT(default_privacy_system), rend, TRUE);
+       gtk_cell_layout_set_attributes(GTK_CELL_LAYOUT(default_privacy_system), rend,
+                       "text", COMBOBOX_TEXT,
+                       "sensitive", COMBOBOX_SENS,
+                       NULL);
+       gtk_combo_box_set_focus_on_click(GTK_COMBO_BOX(default_privacy_system), FALSE);
+
        gtk_widget_show (default_privacy_system);
        gtk_box_pack_start (GTK_BOX(hbox1), default_privacy_system, FALSE, TRUE, 0);
 
+       g_signal_connect(G_OBJECT(default_privacy_system), "changed",
+                        G_CALLBACK(privacy_system_activated),
+                        NULL);
+
        PACK_CHECK_BUTTON (vbox2, default_sign_checkbtn,
                           _("Always sign messages"));
        PACK_CHECK_BUTTON (vbox2, default_encrypt_checkbtn,
@@ -2125,7 +2188,7 @@ static void privacy_create_widget_func(PrefsPage * _page,
        page->page.widget = vbox1;
 }
        
-#if USE_OPENSSL
+#if (defined(USE_OPENSSL) || defined (USE_GNUTLS))
 
 #define CREATE_RADIO_BUTTON(box, btn, btn_p, label, data)              \
 {                                                                      \
@@ -2334,8 +2397,10 @@ static void advanced_create_widget_func(PrefsPage * _page,
        GtkWidget *checkbtn_crosspost;
        GtkWidget *colormenu_crosspost;
        GtkWidget *menu;
+#ifndef G_OS_WIN32
        GtkWidget *checkbtn_tunnelcmd;
        GtkWidget *entry_tunnelcmd;
+#endif
        GtkWidget *folder_frame;
        GtkWidget *vbox3;
        GtkWidget *table;
@@ -2347,7 +2412,7 @@ static void advanced_create_widget_func(PrefsPage * _page,
        GtkWidget *draft_folder_entry;
        GtkWidget *trash_folder_checkbtn;
        GtkWidget *trash_folder_entry;
-
+       GtkTooltips *tips = gtk_tooltips_new();
 #define PACK_HBOX(hbox) \
        { \
        hbox = gtk_hbox_new (FALSE, 8); \
@@ -2397,13 +2462,25 @@ static void advanced_create_widget_func(PrefsPage * _page,
 
        PACK_HBOX (hbox1);
        PACK_CHECK_BUTTON (hbox1, checkbtn_domain, _("Domain name"));
+       
+       gtk_tooltips_set_tip(GTK_TOOLTIPS(tips), checkbtn_domain,
+                            _("The domain name will be used in the right part of "
+                              "the generated Message-Ids, and when connecting to "
+                              "SMTP servers."),
+                            NULL);
 
        entry_domain = gtk_entry_new ();
        gtk_widget_show (entry_domain);
        gtk_box_pack_start (GTK_BOX (hbox1), entry_domain, TRUE, TRUE, 0);
        SET_TOGGLE_SENSITIVITY (checkbtn_domain, entry_domain);
+       gtk_tooltips_set_tip(GTK_TOOLTIPS(tips), entry_domain,
+                            _("The domain name will be used in the right part of "
+                              "the generated Message-Ids, and when connecting to "
+                              "SMTP servers."),
+                            NULL);
 
-       
+
+#ifndef G_OS_WIN32     
        PACK_HBOX (hbox1);
        PACK_CHECK_BUTTON (hbox1, checkbtn_tunnelcmd,
                           _("Use command to communicate with server"));
@@ -2411,7 +2488,7 @@ static void advanced_create_widget_func(PrefsPage * _page,
        gtk_widget_show (entry_tunnelcmd);
        gtk_box_pack_start (GTK_BOX (hbox1), entry_tunnelcmd, TRUE, TRUE, 0);
        SET_TOGGLE_SENSITIVITY (checkbtn_tunnelcmd, entry_tunnelcmd);
-
+#endif
        PACK_HBOX (hbox1);
        PACK_CHECK_BUTTON (hbox1, checkbtn_crosspost, 
                           _("Mark cross-posted messages as read and color:"));
@@ -2494,9 +2571,10 @@ static void advanced_create_widget_func(PrefsPage * _page,
        page->crosspost_checkbtn        = checkbtn_crosspost;
        page->crosspost_colormenu       = colormenu_crosspost;
 
+#ifndef G_OS_WIN32
        page->tunnelcmd_checkbtn        = checkbtn_tunnelcmd;
        page->tunnelcmd_entry   = entry_tunnelcmd;
-
+#endif
        page->sent_folder_checkbtn  = sent_folder_checkbtn;
        page->sent_folder_entry   = sent_folder_entry;
        page->queue_folder_checkbtn  = queue_folder_checkbtn;
@@ -2571,7 +2649,7 @@ static gint prefs_basic_apply(void)
                        inbox =  folder_find_item_from_identifier(mailbox);
                }
                if (inbox == NULL) {
-                       alertpanel_error(_("The default inbox folder doesn't exist."));
+                       alertpanel_error(_("The default Inbox folder doesn't exist."));
                        return -1;
                }
        }
@@ -2648,7 +2726,7 @@ static gint prefs_privacy_apply(void)
        return 0;
 }
 
-#if USE_OPENSSL
+#if (defined(USE_OPENSSL) || defined (USE_GNUTLS))
 static gint prefs_ssl_apply(void)
 {
        prefs_set_data_from_dialog(ssl_param);
@@ -2692,7 +2770,7 @@ static void privacy_destroy_widget_func(PrefsPage *_page)
        /* PrivacyPage *page = (PrivacyPage *) _page; */
 }
 
-#if USE_OPENSSL
+#if (defined(USE_OPENSSL) || defined (USE_GNUTLS))
 static void ssl_destroy_widget_func(PrefsPage *_page)
 {
        /* SSLPage *page = (SSLPage *) _page; */
@@ -2764,7 +2842,7 @@ static gboolean privacy_can_close_func(PrefsPage *_page)
        return prefs_privacy_apply() >= 0;
 }
 
-#if USE_OPENSSL
+#if (defined(USE_OPENSSL) || defined (USE_GNUTLS))
 static gboolean ssl_can_close_func(PrefsPage *_page)
 {
        SSLPage *page = (SSLPage *) _page;
@@ -2841,8 +2919,10 @@ static void templates_save_func(PrefsPage *_page)
                                                                        tmp_ac_prefs.compose_subject_format,
                                                                        tmp_ac_prefs.compose_body_format);
        quotefmt_check_reply_formats(tmp_ac_prefs.reply_with_format,
+                                                                       tmp_ac_prefs.reply_quotemark,
                                                                        tmp_ac_prefs.reply_body_format);
        quotefmt_check_forward_formats(tmp_ac_prefs.forward_with_format,
+                                                                       tmp_ac_prefs.forward_quotemark,
                                                                        tmp_ac_prefs.forward_body_format);
        if (prefs_templates_apply() >= 0)
                cancelled = FALSE;
@@ -2859,7 +2939,7 @@ static void privacy_save_func(PrefsPage *_page)
                cancelled = FALSE;
 }
 
-#if USE_OPENSSL
+#if (defined(USE_OPENSSL) || defined (USE_GNUTLS))
 static void ssl_save_func(PrefsPage *_page)
 {
        SSLPage *page = (SSLPage *) _page;
@@ -2991,7 +3071,7 @@ static void register_privacy_page(void)
        prefs_account_register_page((PrefsPage *) &privacy_page);
 }
 
-#if USE_OPENSSL
+#if (defined(USE_OPENSSL) || defined (USE_GNUTLS))
 static void register_ssl_page(void)
 {
        static gchar *path[3];
@@ -3037,7 +3117,7 @@ void prefs_account_init()
        register_compose_page();
        register_templates_page();
        register_privacy_page();
-#if USE_OPENSSL
+#if (defined(USE_OPENSSL) || defined (USE_GNUTLS))
        register_ssl_page();
 #endif
        register_advanced_page();
@@ -3309,7 +3389,7 @@ PrefsAccount *prefs_account_open(PrefsAccount *ac_prefs, gboolean *dirty)
 
        prefswindow_open_full(title, prefs_pages, ac_prefs, destroy_dialog,
                        &prefs_common.editaccountwin_width, &prefs_common.editaccountwin_height,
-                       TRUE);
+                       TRUE, TRUE);
        g_free(title);
        gtk_main();
 
@@ -3416,7 +3496,7 @@ static void prefs_account_signature_edit_cb(GtkWidget *widget, gpointer data)
        const gchar *sigpath = gtk_entry_get_text(GTK_ENTRY(data));
        if (!is_file_exist(sigpath))
                str_write_to_file(sigpath, "");
-       open_txt_editor(sigpath, prefs_common.ext_editor_cmd);
+       open_txt_editor(sigpath, prefs_common_get_ext_editor_cmd());
 }
 
 static void prefs_account_edit_custom_header(void)
@@ -3501,7 +3581,7 @@ static void prefs_account_protocol_set_optmenu(PrefParam *pparam)
                gtk_widget_hide(optmenu);
                gtk_widget_show(optlabel);
 #ifndef HAVE_LIBETPAN
-               if (protocol == A_IMAP4) {
+               if (protocol == A_IMAP4 || protocol == A_NNTP) {
                        gtk_widget_show(protocol_optmenu->no_imap_warn_icon);
                        gtk_widget_show(protocol_optmenu->no_imap_warn_label);
                } else {
@@ -3509,117 +3589,105 @@ static void prefs_account_protocol_set_optmenu(PrefParam *pparam)
                        gtk_widget_hide(protocol_optmenu->no_imap_warn_label);
                }
 #endif
+               if (protocol == A_IMAP4) {
+                       if (new_account)
+                               gtk_toggle_button_set_active(
+                                       GTK_TOGGLE_BUTTON(send_page.msgid_checkbtn), 
+                                       TRUE);
+                       gtk_widget_hide(send_page.msgid_checkbtn);
+               } else {
+                       gtk_widget_show(send_page.msgid_checkbtn);
+               }
        }
 }
 
 static void prefs_account_imap_auth_type_set_data_from_optmenu(PrefParam *pparam)
 {
-       GtkWidget *menu;
-       GtkWidget *menuitem;
-
-       menu = gtk_option_menu_get_menu(GTK_OPTION_MENU(*pparam->widget));
-       menuitem = gtk_menu_get_active(GTK_MENU(menu));
-       *((RecvProtocol *)pparam->data) = GPOINTER_TO_INT
-               (g_object_get_data(G_OBJECT(menuitem), MENU_VAL_ID));
+       *((RecvProtocol *)pparam->data) =
+                       combobox_get_active_data(GTK_COMBO_BOX(*pparam->widget));
 }
 
 static void prefs_account_imap_auth_type_set_optmenu(PrefParam *pparam)
 {
        IMAPAuthType type = *((IMAPAuthType *)pparam->data);
-       GtkOptionMenu *optmenu = GTK_OPTION_MENU(*pparam->widget);
-       GtkWidget *menu;
-       GtkWidget *menuitem;
+       GtkComboBox *optmenu = GTK_COMBO_BOX(*pparam->widget);
 
-       switch (type) {
-       case IMAP_AUTH_LOGIN:
-               gtk_option_menu_set_history(optmenu, 1);
-               break;
-       case IMAP_AUTH_CRAM_MD5:
-               gtk_option_menu_set_history(optmenu, 2);
-               break;
-       case IMAP_AUTH_ANON:
-               gtk_option_menu_set_history(optmenu, 3);
-               break;
-       case IMAP_AUTH_GSSAPI:
-               gtk_option_menu_set_history(optmenu, 4);
-               break;
-       case 0:
-       default:
-               gtk_option_menu_set_history(optmenu, 0);
-       }
-
-       menu = gtk_option_menu_get_menu(optmenu);
-       menuitem = gtk_menu_get_active(GTK_MENU(menu));
-       gtk_menu_item_activate(GTK_MENU_ITEM(menuitem));
+       combobox_select_by_data(optmenu, type);
 }
 
 static void prefs_account_smtp_auth_type_set_data_from_optmenu(PrefParam *pparam)
 {
-       GtkWidget *menu;
-       GtkWidget *menuitem;
-
-       menu = gtk_option_menu_get_menu(GTK_OPTION_MENU(*pparam->widget));
-       menuitem = gtk_menu_get_active(GTK_MENU(menu));
-       *((RecvProtocol *)pparam->data) = GPOINTER_TO_INT
-               (g_object_get_data(G_OBJECT(menuitem), MENU_VAL_ID));
+       *((RecvProtocol *)pparam->data) =
+               combobox_get_active_data(GTK_COMBO_BOX(*pparam->widget));
 }
 
 static void prefs_account_smtp_auth_type_set_optmenu(PrefParam *pparam)
 {
        SMTPAuthType type = *((SMTPAuthType *)pparam->data);
-       GtkOptionMenu *optmenu = GTK_OPTION_MENU(*pparam->widget);
-       GtkWidget *menu;
-       GtkWidget *menuitem;
+       GtkComboBox *optmenu = GTK_COMBO_BOX(*pparam->widget);
 
-       switch (type) {
-       case SMTPAUTH_PLAIN:
-               gtk_option_menu_set_history(optmenu, 1);
-               break;
-       case SMTPAUTH_LOGIN:
-               gtk_option_menu_set_history(optmenu, 2);
-               break;
-       case SMTPAUTH_CRAM_MD5:
-               gtk_option_menu_set_history(optmenu, 3);
-               break;
-       case SMTPAUTH_DIGEST_MD5:
-               gtk_option_menu_set_history(optmenu, 4);
-               break;
-       case 0:
-       default:
-               gtk_option_menu_set_history(optmenu, 0);
-       }
-
-       menu = gtk_option_menu_get_menu(optmenu);
-       menuitem = gtk_menu_get_active(GTK_MENU(menu));
-       gtk_menu_item_activate(GTK_MENU_ITEM(menuitem));
+       combobox_select_by_data(optmenu, type);
 }
 
-static void prefs_account_set_string_from_optmenu(PrefParam *pparam)
+static void prefs_account_set_string_from_combobox(PrefParam *pparam)
 {
-       GtkWidget *menu;
-       GtkWidget *menuitem;
+       GtkWidget *combobox;
+       GtkListStore *menu;
+       GtkTreeIter iter;
        gchar **str;
 
        g_return_if_fail(*pparam->widget != NULL);
 
-       menu = gtk_option_menu_get_menu(GTK_OPTION_MENU(*pparam->widget));
-       menuitem = gtk_menu_get_active(GTK_MENU(menu));
-       if (menuitem == NULL)
-               return;
+       combobox = *pparam->widget;
+       g_return_if_fail(gtk_combo_box_get_active_iter(
+                               GTK_COMBO_BOX(combobox), &iter));
 
-       str = (gchar **) pparam->data;
-        g_free(*str);
-       *str = g_strdup(g_object_get_data(G_OBJECT(menuitem), MENU_VAL_ID));
+       str = (gchar **)pparam->data;
+       g_free(*str);
+       menu = GTK_LIST_STORE(gtk_combo_box_get_model(GTK_COMBO_BOX(combobox)));
+       gtk_tree_model_get(GTK_TREE_MODEL(menu), &iter,
+                       COMBOBOX_PRIVACY_PLUGIN_ID, &(*str),
+                       -1);
 }
 
-static void prefs_account_set_optmenu_from_string(PrefParam *pparam)
+/* Context struct and internal function called by gtk_tree_model_foreach().
+ * This is used in prefs_account_set_privacy_combobox_from_string() to find
+ * correct combobox entry to activate when account preferences are displayed
+ * and their values are set according to preferences. */
+typedef struct _privacy_system_set_ctx {
+       GtkWidget *combobox;
+       gchar *prefsid;
+       gboolean found;
+} PrivacySystemSetCtx;
+
+static gboolean _privacy_system_set_func(GtkTreeModel *model, GtkTreePath *path,
+               GtkTreeIter *iter, PrivacySystemSetCtx *ctx)
+{
+       GtkWidget *combobox = ctx->combobox;
+       gchar *prefsid = ctx->prefsid;
+       gchar *curid;
+
+       /* We're searching for correct privacy plugin ID. */
+       gtk_tree_model_get(model, iter, COMBOBOX_PRIVACY_PLUGIN_ID, &curid, -1);
+       if( strcmp(prefsid, curid) == 0 ) {
+               gtk_combo_box_set_active_iter(GTK_COMBO_BOX(combobox), iter);
+               g_free(curid);
+               ctx->found = TRUE;
+               return TRUE;
+       }
+
+       g_free(curid);
+       return FALSE;
+}
+
+static void prefs_account_set_privacy_combobox_from_string(PrefParam *pparam)
 {
        GtkWidget *optionmenu;
-       GtkWidget *menu;
+       GtkListStore *menu;
+       GtkTreeIter iter;
        gboolean found = FALSE;
-       GList *children, *cur;
        gchar *prefsid;
-       guint i = 0;
+       PrivacySystemSetCtx *ctx = NULL;
 
        g_return_if_fail(*pparam->widget != NULL);
 
@@ -3628,41 +3696,35 @@ static void prefs_account_set_optmenu_from_string(PrefParam *pparam)
                return;
 
        optionmenu = *pparam->widget;
-       menu = gtk_option_menu_get_menu(GTK_OPTION_MENU(optionmenu));
-       children = gtk_container_children(GTK_CONTAINER(menu));
-       for (cur = children; cur != NULL; cur = g_list_next(cur)) {
-               GtkWidget *item = (GtkWidget *) cur->data;
-               gchar *id;
-
-               id = g_object_get_data(G_OBJECT(item), MENU_VAL_ID);
-               if (id != NULL && strcmp(id, prefsid) == 0) {
-                       found = TRUE;
-                       gtk_option_menu_set_history(GTK_OPTION_MENU(optionmenu), i);
-                       privacy_system_activated(GTK_MENU_ITEM(item));
-               }
-               i++;
-       }
+       menu = GTK_LIST_STORE(gtk_combo_box_get_model(GTK_COMBO_BOX(optionmenu)));
 
+       ctx = g_new(PrivacySystemSetCtx, sizeof(PrivacySystemSetCtx));
+       ctx->combobox = optionmenu;
+       ctx->prefsid = prefsid;
+       ctx->found = FALSE;
+
+       gtk_tree_model_foreach(GTK_TREE_MODEL(menu),
+                       (GtkTreeModelForeachFunc)_privacy_system_set_func, ctx);
+       found = ctx->found;
+       g_free(ctx);
+
+       /* If chosen privacy system is not available, add a dummy entry with
+        * "not loaded" note and make it active. */
        if (!found) {
                gchar *name;
-               GtkWidget *menuitem;
 
                name = g_strdup_printf(_("%s (plugin not loaded)"), prefsid);
-               menuitem = gtk_menu_item_new_with_label(name);
-               gtk_widget_show(menuitem);
-               g_object_set_data(G_OBJECT(menuitem), MENU_VAL_ID, prefsid);
-               g_object_set_data(G_OBJECT(menuitem), MENU_VAL_DATA, GINT_TO_POINTER(FALSE));
-               gtk_menu_append(GTK_MENU(menu), menuitem);
+               gtk_list_store_append(menu, &iter);
+               gtk_list_store_set(menu, &iter,
+                               COMBOBOX_TEXT, name,
+                               COMBOBOX_DATA, 0,
+                               COMBOBOX_SENS, TRUE,
+                               COMBOBOX_PRIVACY_PLUGIN_ID, prefsid,
+                               -1);
                g_free(name);
 
-               gtk_option_menu_set_history(GTK_OPTION_MENU(optionmenu), i);
-               privacy_system_activated(GTK_MENU_ITEM(menuitem));
-               g_signal_connect(G_OBJECT(menuitem), "activate",
-                                G_CALLBACK(privacy_system_activated),
-                                NULL);
+               gtk_combo_box_set_active_iter(GTK_COMBO_BOX(optionmenu), &iter);
        }
-
-       g_list_free(children);
 }
 
 static void prefs_account_protocol_changed(GtkComboBox *combobox, gpointer data)
@@ -3676,8 +3738,14 @@ static void prefs_account_protocol_changed(GtkComboBox *combobox, gpointer data)
        gtk_widget_hide(protocol_optmenu->no_imap_warn_label);
        switch(protocol) {
        case A_NNTP:
+#ifndef HAVE_LIBETPAN
+               gtk_widget_show(protocol_optmenu->no_imap_warn_icon);
+               gtk_widget_show(protocol_optmenu->no_imap_warn_label);
+#else
                gtk_widget_hide(protocol_optmenu->no_imap_warn_icon);
                gtk_widget_hide(protocol_optmenu->no_imap_warn_label);
+#endif
+               gtk_widget_show(send_page.msgid_checkbtn);
                gtk_widget_show(basic_page.nntpserv_label);
                gtk_widget_show(basic_page.nntpserv_entry);
                gtk_table_set_row_spacing (GTK_TABLE (basic_page.serv_table),
@@ -3731,6 +3799,8 @@ static void prefs_account_protocol_changed(GtkComboBox *combobox, gpointer data)
                gtk_widget_hide(receive_page.local_frame);
                gtk_widget_show(receive_page.frame_maxarticle);
                gtk_widget_set_sensitive(receive_page.filter_on_recv_checkbtn, TRUE);
+               prefs_account_filter_on_recv_toggled
+                       (GTK_TOGGLE_BUTTON(receive_page.filter_on_recv_checkbtn), NULL);
                gtk_widget_set_sensitive(receive_page.recvatgetall_checkbtn, TRUE);
                /* update pop_before_smtp sensitivity */
                gtk_toggle_button_set_active
@@ -3742,12 +3812,15 @@ static void prefs_account_protocol_changed(GtkComboBox *combobox, gpointer data)
                        gtk_toggle_button_set_active
                                (GTK_TOGGLE_BUTTON(receive_page.filter_on_recv_checkbtn), 
                                TRUE);
+                       gtk_toggle_button_set_active
+                               (GTK_TOGGLE_BUTTON(receive_page.filterhook_on_recv_checkbtn), 
+                               TRUE);
                        gtk_toggle_button_set_active
                                (GTK_TOGGLE_BUTTON(receive_page.recvatgetall_checkbtn),
                                 FALSE);
                }
 
-#if USE_OPENSSL
+#if (defined(USE_OPENSSL) || defined (USE_GNUTLS))
                gtk_widget_hide(ssl_page.pop_frame);
                gtk_widget_hide(ssl_page.imap_frame);
                gtk_widget_show(ssl_page.nntp_frame);
@@ -3758,14 +3831,17 @@ static void prefs_account_protocol_changed(GtkComboBox *combobox, gpointer data)
                gtk_widget_show(advanced_page.nntpport_hbox);
                gtk_widget_show(advanced_page.crosspost_checkbtn);
                gtk_widget_show(advanced_page.crosspost_colormenu);
+#ifndef G_OS_WIN32
                gtk_widget_hide(advanced_page.tunnelcmd_checkbtn);
                gtk_widget_hide(advanced_page.tunnelcmd_entry);
+#endif
                gtk_widget_hide(receive_page.imapdir_label);
                gtk_widget_hide(receive_page.imapdir_entry);
                gtk_widget_hide(receive_page.subsonly_checkbtn);
                gtk_widget_hide(receive_page.low_bandwidth_checkbtn);
                break;
        case A_LOCAL:
+               gtk_widget_show(send_page.msgid_checkbtn);
                gtk_widget_hide(protocol_optmenu->no_imap_warn_icon);
                gtk_widget_hide(protocol_optmenu->no_imap_warn_label);
                gtk_widget_hide(basic_page.nntpserv_label);
@@ -3814,6 +3890,8 @@ static void prefs_account_protocol_changed(GtkComboBox *combobox, gpointer data)
                gtk_widget_show(receive_page.local_frame);
                gtk_widget_hide(receive_page.frame_maxarticle);
                gtk_widget_set_sensitive(receive_page.filter_on_recv_checkbtn, TRUE);
+               prefs_account_filter_on_recv_toggled
+                       (GTK_TOGGLE_BUTTON(receive_page.filter_on_recv_checkbtn), NULL);
                gtk_widget_set_sensitive(receive_page.recvatgetall_checkbtn, TRUE);
                prefs_account_mailcmd_toggled
                        (GTK_TOGGLE_BUTTON(basic_page.mailcmd_checkbtn), NULL);
@@ -3828,12 +3906,15 @@ static void prefs_account_protocol_changed(GtkComboBox *combobox, gpointer data)
                        gtk_toggle_button_set_active
                                (GTK_TOGGLE_BUTTON(receive_page.filter_on_recv_checkbtn), 
                                TRUE);
+                       gtk_toggle_button_set_active
+                               (GTK_TOGGLE_BUTTON(receive_page.filterhook_on_recv_checkbtn), 
+                               TRUE);
                        gtk_toggle_button_set_active
                                (GTK_TOGGLE_BUTTON(receive_page.recvatgetall_checkbtn),
                                 TRUE);
                }
 
-#if USE_OPENSSL
+#if (defined(USE_OPENSSL) || defined (USE_GNUTLS))
                gtk_widget_hide(ssl_page.pop_frame);
                gtk_widget_hide(ssl_page.imap_frame);
                gtk_widget_hide(ssl_page.nntp_frame);
@@ -3844,8 +3925,10 @@ static void prefs_account_protocol_changed(GtkComboBox *combobox, gpointer data)
                gtk_widget_hide(advanced_page.nntpport_hbox);
                gtk_widget_hide(advanced_page.crosspost_checkbtn);
                gtk_widget_hide(advanced_page.crosspost_colormenu);
+#ifndef G_OS_WIN32
                gtk_widget_hide(advanced_page.tunnelcmd_checkbtn);
                gtk_widget_hide(advanced_page.tunnelcmd_entry);
+#endif
                gtk_widget_hide(receive_page.imapdir_label);
                gtk_widget_hide(receive_page.imapdir_entry);
                gtk_widget_hide(receive_page.subsonly_checkbtn);
@@ -3856,6 +3939,11 @@ static void prefs_account_protocol_changed(GtkComboBox *combobox, gpointer data)
                gtk_widget_show(protocol_optmenu->no_imap_warn_icon);
                gtk_widget_show(protocol_optmenu->no_imap_warn_label);
 #endif
+               if (new_account)
+                       gtk_toggle_button_set_active(
+                               GTK_TOGGLE_BUTTON(send_page.msgid_checkbtn), 
+                               TRUE);
+               gtk_widget_hide(send_page.msgid_checkbtn);
                gtk_widget_hide(basic_page.nntpserv_label);
                gtk_widget_hide(basic_page.nntpserv_entry);
                gtk_table_set_row_spacing (GTK_TABLE (basic_page.serv_table),
@@ -3905,6 +3993,8 @@ static void prefs_account_protocol_changed(GtkComboBox *combobox, gpointer data)
                gtk_widget_hide(receive_page.local_frame);
                gtk_widget_hide(receive_page.frame_maxarticle);
                gtk_widget_set_sensitive(receive_page.filter_on_recv_checkbtn, TRUE);
+               prefs_account_filter_on_recv_toggled
+                       (GTK_TOGGLE_BUTTON(receive_page.filter_on_recv_checkbtn), NULL);
                gtk_widget_set_sensitive(receive_page.recvatgetall_checkbtn, TRUE);
                gtk_widget_set_sensitive(basic_page.smtpserv_entry, TRUE);
                gtk_widget_set_sensitive(basic_page.smtpserv_label, TRUE);
@@ -3919,12 +4009,15 @@ static void prefs_account_protocol_changed(GtkComboBox *combobox, gpointer data)
                        gtk_toggle_button_set_active
                                (GTK_TOGGLE_BUTTON(receive_page.filter_on_recv_checkbtn), 
                                TRUE);
+                       gtk_toggle_button_set_active
+                               (GTK_TOGGLE_BUTTON(receive_page.filterhook_on_recv_checkbtn), 
+                               TRUE);
                        gtk_toggle_button_set_active
                                (GTK_TOGGLE_BUTTON(receive_page.recvatgetall_checkbtn),
                                 FALSE);
                }
 
-#if USE_OPENSSL
+#if (defined(USE_OPENSSL) || defined (USE_GNUTLS))
                gtk_widget_hide(ssl_page.pop_frame);
                gtk_widget_show(ssl_page.imap_frame);
                gtk_widget_hide(ssl_page.nntp_frame);
@@ -3935,14 +4028,17 @@ static void prefs_account_protocol_changed(GtkComboBox *combobox, gpointer data)
                gtk_widget_hide(advanced_page.nntpport_hbox);
                gtk_widget_hide(advanced_page.crosspost_checkbtn);
                gtk_widget_hide(advanced_page.crosspost_colormenu);
+#ifndef G_OS_WIN32
                gtk_widget_show(advanced_page.tunnelcmd_checkbtn);
                gtk_widget_show(advanced_page.tunnelcmd_entry);
+#endif
                gtk_widget_show(receive_page.imapdir_label);
                gtk_widget_show(receive_page.imapdir_entry);
                gtk_widget_show(receive_page.subsonly_checkbtn);
                gtk_widget_show(receive_page.low_bandwidth_checkbtn);
                break;
        case A_NONE:
+               gtk_widget_show(send_page.msgid_checkbtn);
                gtk_widget_hide(protocol_optmenu->no_imap_warn_icon);
                gtk_widget_hide(protocol_optmenu->no_imap_warn_label);
                gtk_widget_hide(basic_page.nntpserv_label);
@@ -3995,6 +4091,8 @@ static void prefs_account_protocol_changed(GtkComboBox *combobox, gpointer data)
                gtk_widget_hide(receive_page.local_frame);
                gtk_widget_hide(receive_page.frame_maxarticle);
                gtk_widget_set_sensitive(receive_page.filter_on_recv_checkbtn, FALSE);
+               prefs_account_filter_on_recv_toggled
+                       (GTK_TOGGLE_BUTTON(receive_page.filter_on_recv_checkbtn), NULL);
                gtk_widget_set_sensitive(receive_page.recvatgetall_checkbtn, FALSE);
 
                gtk_widget_set_sensitive(basic_page.smtpserv_entry, TRUE);
@@ -4006,10 +4104,12 @@ static void prefs_account_protocol_changed(GtkComboBox *combobox, gpointer data)
        
                gtk_toggle_button_set_active
                        (GTK_TOGGLE_BUTTON(receive_page.filter_on_recv_checkbtn), FALSE);
+               gtk_toggle_button_set_active
+                       (GTK_TOGGLE_BUTTON(receive_page.filterhook_on_recv_checkbtn), FALSE);
                gtk_toggle_button_set_active
                        (GTK_TOGGLE_BUTTON(receive_page.recvatgetall_checkbtn), FALSE);
 
-#if USE_OPENSSL
+#if (defined(USE_OPENSSL) || defined (USE_GNUTLS))
                gtk_widget_hide(ssl_page.pop_frame);
                gtk_widget_hide(ssl_page.imap_frame);
                gtk_widget_hide(ssl_page.nntp_frame);
@@ -4020,8 +4120,10 @@ static void prefs_account_protocol_changed(GtkComboBox *combobox, gpointer data)
                gtk_widget_hide(advanced_page.nntpport_hbox);
                gtk_widget_hide(advanced_page.crosspost_checkbtn);
                gtk_widget_hide(advanced_page.crosspost_colormenu);
+#ifndef G_OS_WIN32
                gtk_widget_hide(advanced_page.tunnelcmd_checkbtn);
                gtk_widget_hide(advanced_page.tunnelcmd_entry);
+#endif
                gtk_widget_hide(receive_page.imapdir_label);
                gtk_widget_hide(receive_page.imapdir_entry);
                gtk_widget_hide(receive_page.subsonly_checkbtn);
@@ -4029,6 +4131,7 @@ static void prefs_account_protocol_changed(GtkComboBox *combobox, gpointer data)
                break;
        case A_POP3:
        default:
+               gtk_widget_show(send_page.msgid_checkbtn);
                gtk_widget_hide(protocol_optmenu->no_imap_warn_icon);
                gtk_widget_hide(protocol_optmenu->no_imap_warn_label);
                gtk_widget_hide(basic_page.nntpserv_label);
@@ -4081,6 +4184,8 @@ static void prefs_account_protocol_changed(GtkComboBox *combobox, gpointer data)
                gtk_widget_hide(receive_page.local_frame);
                gtk_widget_hide(receive_page.frame_maxarticle);
                gtk_widget_set_sensitive(receive_page.filter_on_recv_checkbtn, TRUE);
+               prefs_account_filter_on_recv_toggled
+                       (GTK_TOGGLE_BUTTON(receive_page.filter_on_recv_checkbtn), NULL);
                gtk_widget_set_sensitive(receive_page.recvatgetall_checkbtn, TRUE);
 
                gtk_widget_set_sensitive(basic_page.smtpserv_entry, TRUE);
@@ -4094,12 +4199,15 @@ static void prefs_account_protocol_changed(GtkComboBox *combobox, gpointer data)
                        gtk_toggle_button_set_active
                                (GTK_TOGGLE_BUTTON(receive_page.filter_on_recv_checkbtn), 
                                TRUE);
+                       gtk_toggle_button_set_active
+                               (GTK_TOGGLE_BUTTON(receive_page.filterhook_on_recv_checkbtn), 
+                               TRUE);
                        gtk_toggle_button_set_active
                                (GTK_TOGGLE_BUTTON(receive_page.recvatgetall_checkbtn),
                                 TRUE);
                }
 
-#if USE_OPENSSL
+#if (defined(USE_OPENSSL) || defined (USE_GNUTLS))
                gtk_widget_show(ssl_page.pop_frame);
                gtk_widget_hide(ssl_page.imap_frame);
                gtk_widget_hide(ssl_page.nntp_frame);
@@ -4110,8 +4218,10 @@ static void prefs_account_protocol_changed(GtkComboBox *combobox, gpointer data)
                gtk_widget_hide(advanced_page.nntpport_hbox);
                gtk_widget_hide(advanced_page.crosspost_checkbtn);
                gtk_widget_hide(advanced_page.crosspost_colormenu);
+#ifndef G_OS_WIN32
                gtk_widget_hide(advanced_page.tunnelcmd_checkbtn);
                gtk_widget_hide(advanced_page.tunnelcmd_entry);
+#endif
                gtk_widget_hide(receive_page.imapdir_label);
                gtk_widget_hide(receive_page.imapdir_entry);
                gtk_widget_hide(receive_page.subsonly_checkbtn);
@@ -4152,32 +4262,35 @@ static void prefs_account_mailcmd_toggled(GtkToggleButton *button,
        gtk_widget_set_sensitive(basic_page.pass_entry, !use_mailcmd);
 }
 
+static void prefs_account_filter_on_recv_toggled(GtkToggleButton *button,
+                                         gpointer user_data)
+{
+       gboolean do_filter;
+
+       do_filter = gtk_toggle_button_get_active (button);
+       gtk_widget_set_sensitive(receive_page.filterhook_on_recv_checkbtn, do_filter);
+}
+
 #if USE_ASPELL
 static void prefs_account_compose_default_dictionary_set_string_from_optmenu
                                                        (PrefParam *pparam)
 {
-       GtkWidget *menu;
-       GtkWidget *menuitem;
+       GtkWidget *combo;
        gchar **str;
 
        g_return_if_fail(*pparam->widget != NULL);
 
-       menu = gtk_option_menu_get_menu(GTK_OPTION_MENU(*pparam->widget));
-       menuitem = gtk_menu_get_active(GTK_MENU(menu));
-       if (menuitem == NULL)
-               return;
-
+       combo = *pparam->widget;
        str = (gchar **) pparam->data;
+
        g_free(*str);
-       *str = gtkaspell_get_dictionary_menu_active_item(menu);
+       *str = gtkaspell_get_dictionary_menu_active_item(GTK_COMBO_BOX(combo));
 }
 
 static void prefs_account_compose_default_dictionary_set_optmenu_from_string
                                                        (PrefParam *pparam)
 {
-       GtkWidget *optionmenu;
-       GtkWidget *menu;
-       GtkWidget *menuitem;
+       GtkWidget *combo;
        gchar *dictionary;
 
        g_return_if_fail(*pparam->widget != NULL);
@@ -4186,12 +4299,10 @@ static void prefs_account_compose_default_dictionary_set_optmenu_from_string
        if (dictionary == NULL)
                return;
 
-       optionmenu = *pparam->widget;
-       menu = gtk_option_menu_get_menu(GTK_OPTION_MENU(optionmenu));
+       combo = *pparam->widget;
        if (dictionary)
-               gtkaspell_set_dictionary_menu_active_item(optionmenu, dictionary);
-       menuitem = gtk_menu_get_active(GTK_MENU(menu));
-       gtk_menu_item_activate(GTK_MENU_ITEM(menuitem));
+               gtkaspell_set_dictionary_menu_active_item(GTK_COMBO_BOX(combo), 
+                                                         dictionary);
 }
 #endif