[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