aboutsummaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
authorWerner Koch <[email protected]>2002-05-03 18:19:44 +0000
committerWerner Koch <[email protected]>2002-05-03 18:19:44 +0000
commit0d3ffd103d24f878887802742d10beba4b53b479 (patch)
tree70c39e40b3aafdffb6cf005ac653cbc38e038e67
parent* gpg/t-verify.c (validity_string): New. (diff)
downloadgpgme-0d3ffd103d24f878887802742d10beba4b53b479.tar.gz
gpgme-0d3ffd103d24f878887802742d10beba4b53b479.zip
* assuan-pipe-connect.c (assuan_pipe_connect2): New to extend
assuan_pipe_connect with some flags. Implemented a bitbucket for stderr.
Diffstat (limited to '')
-rw-r--r--assuan/ChangeLog6
-rw-r--r--assuan/assuan-pipe-connect.c33
-rw-r--r--assuan/assuan.h4
3 files changed, 41 insertions, 2 deletions
diff --git a/assuan/ChangeLog b/assuan/ChangeLog
index 0ddf65cc..0cf53b89 100644
--- a/assuan/ChangeLog
+++ b/assuan/ChangeLog
@@ -1,3 +1,9 @@
+2002-05-03 Werner Koch <[email protected]>
+
+ * assuan-pipe-connect.c (assuan_pipe_connect2): New to extend
+ assuan_pipe_connect with some flags. Implemented a bitbucket for
+ stderr.
+
2002-04-26 Werner Koch <[email protected]>
* Makefile.am: Create libtool libraries
diff --git a/assuan/assuan-pipe-connect.c b/assuan/assuan-pipe-connect.c
index ccfc1f01..6614dab9 100644
--- a/assuan/assuan-pipe-connect.c
+++ b/assuan/assuan-pipe-connect.c
@@ -30,6 +30,8 @@
#include <errno.h>
#include <sys/types.h>
#include <sys/wait.h>
+#include <sys/stat.h>
+#include <fcntl.h>
#include "assuan-defs.h"
@@ -102,8 +104,9 @@ do_deinit (ASSUAN_CONTEXT ctx)
vector in ARGV. FD_CHILD_LIST is a -1 terminated list of file
descriptors not to close in the child. */
AssuanError
-assuan_pipe_connect (ASSUAN_CONTEXT *ctx, const char *name, char *const argv[],
- int *fd_child_list)
+assuan_pipe_connect2 (ASSUAN_CONTEXT *ctx, const char *name,
+ char *const argv[], int *fd_child_list,
+ unsigned int connect_flags)
{
static int fixed_signals = 0;
AssuanError err;
@@ -217,6 +220,23 @@ assuan_pipe_connect (ASSUAN_CONTEXT *ctx, const char *name, char *const argv[],
close (wp[0]);
}
+ if ((connect_flags & 1))
+ { /* dup stderr to /dev/null so that the application output
+ won't get clobbered with output from the backend */
+ int fdzero = open ("/dev/null", O_WRONLY);
+ if (fdzero == -1)
+ {
+ LOGERROR1 ("can't open `/dev/null': %s\n", strerror (errno));
+ _exit (4);
+ }
+ if (dup2 (fdzero, 2) == -1)
+ {
+ LOGERROR1 ("dup2(dev/null, 2) failed: %s\n", strerror (errno));
+ _exit (4);
+ }
+ close (fdzero);
+ }
+
execv (name, argv);
/* oops - use the pipe to tell the parent about it */
snprintf (errbuf, sizeof(errbuf)-1, "ERR %d can't exec `%s': %.50s\n",
@@ -254,6 +274,15 @@ assuan_pipe_connect (ASSUAN_CONTEXT *ctx, const char *name, char *const argv[],
return err;
}
+AssuanError
+assuan_pipe_connect (ASSUAN_CONTEXT *ctx, const char *name, char *const argv[],
+ int *fd_child_list)
+{
+ return assuan_pipe_connect2 (ctx, name, argv, fd_child_list, 0);
+}
+
+
+
diff --git a/assuan/assuan.h b/assuan/assuan.h
index a9340019..e18c46e6 100644
--- a/assuan/assuan.h
+++ b/assuan/assuan.h
@@ -175,6 +175,10 @@ int assuan_init_socket_server (ASSUAN_CONTEXT *r_ctx, int listen_fd);
/*-- assuan-pipe-connect.c --*/
AssuanError assuan_pipe_connect (ASSUAN_CONTEXT *ctx, const char *name,
char *const argv[], int *fd_child_list);
+AssuanError assuan_pipe_connect2 (ASSUAN_CONTEXT *ctx, const char *name,
+ char *const argv[], int *fd_child_list,
+ unsigned int connect_flags);
+
/*-- assuan-socket-connect.c --*/
AssuanError assuan_socket_connect (ASSUAN_CONTEXT *ctx, const char *name,
pid_t server_pid);