[Commits] [SCM] claws branch, master, updated. 3.12.0-64-ge39993c

claws at claws-mail.org claws at claws-mail.org
Thu Aug 27 10:37:09 CEST 2015


The branch, master has been updated
       via  e39993c0edeb43edc55f9458f2db4f6d17121e4f (commit)
      from  e111f1299dd471b9e7890c538e434bf2cbae49c9 (commit)

Summary of changes:
 src/plugins/pgpcore/prefs_gpg.c |   51 ++++++++++++++++++++++++++++++++++++---
 src/plugins/pgpcore/prefs_gpg.h |    3 ++-
 src/plugins/pgpcore/sgpgme.c    |    5 ++++
 3 files changed, 54 insertions(+), 5 deletions(-)


- Log -----------------------------------------------------------------
commit e39993c0edeb43edc55f9458f2db4f6d17121e4f
Author: Paul <paul at claws-mail.org>
Date:   Thu Aug 27 09:37:04 2015 +0100

    add option to specify location of GnuPG executable
    
    This allows the user to choose to use gpg rather than be forced to use
    gpg2

diff --git a/src/plugins/pgpcore/prefs_gpg.c b/src/plugins/pgpcore/prefs_gpg.c
index 7afc8ed..80522d1 100644
--- a/src/plugins/pgpcore/prefs_gpg.c
+++ b/src/plugins/pgpcore/prefs_gpg.c
@@ -1,6 +1,6 @@
 /*
  * Claws Mail -- a GTK+ based, lightweight, and fast e-mail client
- * Copyright (C) 2004-2012 the Claws Mail team
+ * Copyright (C) 2004-2015 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
@@ -26,10 +26,13 @@
 #include <glib.h>
 #include <glib/gi18n.h>
 
+#include <gtk/filesel.h>
+
 #include "defs.h"
 #include "gtk/gtkutils.h"
 #include "utils.h" 
 #include "prefs.h"
+#include "prefs_common.h"
 #include "prefs_gtk.h"
 #include "prefs_gpg.h"
 #include "sgpgme.h"
@@ -59,11 +62,14 @@ static PrefParam param[] = {
 	 NULL, NULL, NULL},
 	{"skip_encryption_warning", "", &prefs_gpg.skip_encryption_warning, P_STRING,
 	 NULL, NULL, NULL},
+	{"gpg_path", "", &prefs_gpg.gpg_path, P_STRING,
+	 NULL, NULL, NULL},
 
 	{NULL, NULL, NULL, P_OTHER, NULL, NULL, NULL}
 };
 
 static gchar *saved_gpg_agent_info = NULL;
+static void gpg_path_browse_cb(GtkWidget *widget, gpointer data);
 
 struct GPGPage
 {
@@ -76,6 +82,7 @@ struct GPGPage
         GtkWidget *spinbtn_store_passphrase;  
         GtkWidget *checkbtn_passphrase_grab;  
         GtkWidget *checkbtn_gpg_warning;
+	GtkWidget *gpg_path;
 };
 
 static void prefs_gpg_create_widget_func(PrefsPage *_page,
@@ -91,13 +98,15 @@ static void prefs_gpg_create_widget_func(PrefsPage *_page,
 	GtkWidget *checkbtn_auto_check_signatures;
 	GtkWidget *checkbtn_autocompletion;
 	GtkWidget *checkbtn_gpg_warning;
-	GtkWidget *hbox1;
+	GtkWidget *hbox1, *hbox2;
 	GtkWidget *vbox1, *vbox2;
+	GtkWidget *label_gpg_path;
 	GtkWidget *label_expire1;
 	GtkAdjustment *spinbtn_store_passphrase_adj;
 	GtkWidget *spinbtn_store_passphrase;
 	GtkWidget *label_expire2;
 	GtkWidget *frame_passphrase;
+	GtkWidget *gpg_path, *gpg_path_btn;
 
 	vbox1 = gtk_vbox_new (FALSE, VSPACING);
 	gtk_widget_show (vbox1);
@@ -145,8 +154,7 @@ static void prefs_gpg_create_widget_func(PrefsPage *_page,
 			   FALSE, 0);
 	gtk_widget_set_size_request(spinbtn_store_passphrase, 64, -1);
 	CLAWS_SET_TIP(spinbtn_store_passphrase,
-			     _
-			     ("Setting to '0' will store the passphrase for the whole session"));
+		      _("Setting to '0' will store the passphrase for the whole session"));
 	gtk_spin_button_set_numeric(GTK_SPIN_BUTTON
 				    (spinbtn_store_passphrase), TRUE);
 
@@ -169,6 +177,22 @@ static void prefs_gpg_create_widget_func(PrefsPage *_page,
 	PACK_CHECK_BUTTON (vbox2, checkbtn_gpg_warning,
 			_("Display warning on start-up if GnuPG doesn't work"));
 
+	hbox2 = gtk_hbox_new(FALSE, 6);
+	label_gpg_path = gtk_label_new(_("Path to GnuPG executable"));
+	gtk_box_pack_start(GTK_BOX(hbox2), label_gpg_path, FALSE, FALSE, 0);
+	gpg_path = gtk_entry_new();
+	gtk_box_pack_start(GTK_BOX(hbox2), gpg_path, TRUE, TRUE, 0);
+	CLAWS_SET_TIP(gpg_path,
+		      _("If left blank the location of the GnuPG executable will be automatically determined."));
+	gpg_path_btn = gtkut_get_browse_file_btn(_("Bro_wse"));
+	gtk_box_pack_start(GTK_BOX(hbox2), gpg_path_btn, FALSE, FALSE, 0);
+	g_signal_connect(G_OBJECT(gpg_path_btn), "clicked",
+			 G_CALLBACK(gpg_path_browse_cb), gpg_path);
+	pref_set_entry_from_pref(GTK_ENTRY(gpg_path), prefs_gpg.gpg_path);
+
+	gtk_box_pack_start(GTK_BOX(vbox2), hbox2, FALSE, FALSE, 0);
+	gtk_widget_show_all(vbox1);
+
 	config = prefs_gpg_get_config();
 
 	gtk_toggle_button_set_active(GTK_TOGGLE_BUTTON(checkbtn_auto_check_signatures), config->auto_check_signatures);
@@ -182,6 +206,7 @@ static void prefs_gpg_create_widget_func(PrefsPage *_page,
 	gtk_spin_button_set_value(GTK_SPIN_BUTTON(spinbtn_store_passphrase), (float) config->store_passphrase_timeout);
 	gtk_toggle_button_set_active(GTK_TOGGLE_BUTTON(checkbtn_passphrase_grab), config->passphrase_grab);
 	gtk_toggle_button_set_active(GTK_TOGGLE_BUTTON(checkbtn_gpg_warning), config->gpg_warning);
+	gtk_entry_set_text(GTK_ENTRY(gpg_path), config->gpg_path);
 
 	page->checkbtn_auto_check_signatures = checkbtn_auto_check_signatures;
 	page->checkbtn_autocompletion = checkbtn_autocompletion;
@@ -190,9 +215,23 @@ static void prefs_gpg_create_widget_func(PrefsPage *_page,
 	page->checkbtn_passphrase_grab = checkbtn_passphrase_grab;
 	page->checkbtn_gpg_warning = checkbtn_gpg_warning;
 	page->checkbtn_use_gpg_agent = checkbtn_use_gpg_agent;
+	page->gpg_path = gpg_path;
 	page->page.widget = vbox1;
 }
 
+static void gpg_path_browse_cb(GtkWidget* widget, gpointer data)
+{
+	gchar *filename;
+	GtkEntry *dest = GTK_ENTRY(data);
+
+	filename = filesel_select_file_open(_("Select GnuPG executable"), NULL);
+	if (!filename)
+		return;
+
+	gtk_entry_set_text(GTK_ENTRY(dest), filename);
+	g_free(filename);
+}
+
 static void prefs_gpg_destroy_widget_func(PrefsPage *_page)
 {
 }
@@ -216,6 +255,10 @@ static void prefs_gpg_save_func(PrefsPage *_page)
 		gtk_toggle_button_get_active(GTK_TOGGLE_BUTTON(page->checkbtn_passphrase_grab));
 	config->gpg_warning = 
 		gtk_toggle_button_get_active(GTK_TOGGLE_BUTTON(page->checkbtn_gpg_warning));
+	g_free(config->gpg_path);
+	config->gpg_path = g_strdup(gtk_entry_get_text(GTK_ENTRY(page->gpg_path)));
+	if (strcmp(config->gpg_path, "") != 0 && access(config->gpg_path, X_OK) != -1)
+		gpgme_set_engine_info(GPGME_PROTOCOL_OpenPGP, config->gpg_path, NULL);
 
 	prefs_gpg_enable_agent(config->use_gpg_agent);
 
diff --git a/src/plugins/pgpcore/prefs_gpg.h b/src/plugins/pgpcore/prefs_gpg.h
index 059e385..28dec3f 100644
--- a/src/plugins/pgpcore/prefs_gpg.h
+++ b/src/plugins/pgpcore/prefs_gpg.h
@@ -1,6 +1,6 @@
 /*
  * Claws Mail -- a GTK+ based, lightweight, and fast e-mail client
- * Copyright (C) 2004-2012 the Claws Mail team
+ * Copyright (C) 2004-2015 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
@@ -42,6 +42,7 @@ struct GPGConfig
 	gboolean	 gpg_warning;
 	gboolean	 gpg_ask_create_key;
 	gchar		*skip_encryption_warning;
+	gchar		*gpg_path;
 };
 
 struct GPGAccountConfig
diff --git a/src/plugins/pgpcore/sgpgme.c b/src/plugins/pgpcore/sgpgme.c
index 7778cc8..cbbfcc4 100644
--- a/src/plugins/pgpcore/sgpgme.c
+++ b/src/plugins/pgpcore/sgpgme.c
@@ -648,6 +648,11 @@ void sgpgme_init()
 	gchar *ctype_utf8_locale = NULL, *messages_utf8_locale = NULL;
 
 	gpgme_engine_info_t engineInfo;
+
+	if (strcmp(prefs_gpg_get_config()->gpg_path, "") != 0 &&
+	    access(prefs_gpg_get_config()->gpg_path, X_OK) != -1)
+		gpgme_set_engine_info(GPGME_PROTOCOL_OpenPGP,prefs_gpg_get_config()->gpg_path, NULL);
+
 	if (gpgme_check_version("1.0.0")) {
 #ifdef LC_CTYPE
 		debug_print("setting gpgme CTYPE locale\n");

-----------------------------------------------------------------------


hooks/post-receive
-- 
Claws Mail


More information about the Commits mailing list