[svn] gpgme - r1187 - trunk/gpgme
svn author marcus
cvs at cvs.gnupg.org
Wed Nov 29 16:44:31 CET 2006
Author: marcus
Date: 2006-11-29 16:44:29 +0100 (Wed, 29 Nov 2006)
New Revision: 1187
Modified:
trunk/gpgme/ChangeLog
trunk/gpgme/rungpg.c
Log:
2006-11-29 Marcus Brinkmann <marcus at g10code.de>
* rungpg.c: Include <unistd.h>.
(gpg_new): Support --display, --ttyname, --ttytype, --lc-ctype and
--lc-messages. Fixes issue 734.
Modified: trunk/gpgme/ChangeLog
===================================================================
--- trunk/gpgme/ChangeLog 2006-11-01 10:02:12 UTC (rev 1186)
+++ trunk/gpgme/ChangeLog 2006-11-29 15:44:29 UTC (rev 1187)
@@ -1,3 +1,9 @@
+2006-11-29 Marcus Brinkmann <marcus at g10code.de>
+
+ * rungpg.c: Include <unistd.h>.
+ (gpg_new): Support --display, --ttyname, --ttytype, --lc-ctype and
+ --lc-messages. Fixes issue 734.
+
2006-10-24 Marcus Brinkmann <marcus at g10code.de>
* trustlist.c (gpgme_op_trustlist_next): Return error if OPD is
Modified: trunk/gpgme/rungpg.c
===================================================================
--- trunk/gpgme/rungpg.c 2006-11-01 10:02:12 UTC (rev 1186)
+++ trunk/gpgme/rungpg.c 2006-11-29 15:44:29 UTC (rev 1187)
@@ -27,6 +27,7 @@
#include <string.h>
#include <assert.h>
#include <errno.h>
+#include <unistd.h>
#include "gpgme.h"
#include "util.h"
@@ -344,6 +345,9 @@
{
engine_gpg_t gpg;
gpgme_error_t rc = 0;
+ char *dft_display = NULL;
+ char dft_ttyname[64];
+ char *dft_ttytype = NULL;
gpg = calloc (1, sizeof *gpg);
if (!gpg)
@@ -423,7 +427,65 @@
rc = add_arg (gpg, "utf8");
if (!rc)
rc = add_arg (gpg, "--enable-progress-filter");
+ if (rc)
+ goto leave;
+ rc = _gpgme_getenv ("DISPLAY", &dft_display);
+ if (dft_display)
+ {
+ rc = add_arg (gpg, "--display");
+ if (!rc)
+ rc = add_arg (gpg, dft_display);
+
+ free (dft_display);
+ }
+ if (rc)
+ goto leave;
+
+ if (isatty (1))
+ {
+ if (ttyname_r (1, dft_ttyname, sizeof (dft_ttyname)))
+ rc = gpg_error_from_errno (errno);
+ else
+ {
+ rc = add_arg (gpg, "--ttyname");
+ if (!rc)
+ rc = add_arg (gpg, dft_ttyname);
+ if (!rc)
+ {
+ rc = _gpgme_getenv ("TERM", &dft_ttytype);
+ if (!rc)
+ goto leave;
+
+ rc = add_arg (gpg, "--ttytype");
+ if (!rc)
+ rc = add_arg (gpg, dft_ttytype);
+
+ free (dft_ttytype);
+ }
+ }
+ if (rc)
+ goto leave;
+ }
+
+ if (lc_ctype)
+ {
+ rc = add_arg (gpg, "--lc-ctype");
+ if (!rc)
+ rc = add_arg (gpg, lc_ctype);
+ if (rc)
+ goto leave;
+ }
+
+ if (lc_messages)
+ {
+ rc = add_arg (gpg, "--lc-messages");
+ if (!rc)
+ rc = add_arg (gpg, lc_messages);
+ if (rc)
+ goto leave;
+ }
+
leave:
if (rc)
gpg_release (gpg);
More information about the Gnupg-commits
mailing list