summaryrefslogtreecommitdiff
path: root/src/libstddjb/child_spawn1_internal.c
diff options
context:
space:
mode:
authorLaurent Bercot <ska-skaware@skarnet.org>2019-06-16 09:01:54 +0000
committerLaurent Bercot <ska-skaware@skarnet.org>2019-06-16 09:01:54 +0000
commitda84f235ef985883c79066204ee838717aacd41a (patch)
treeb7a8dd8931814b9ad9a02bf848020645c0146cc1 /src/libstddjb/child_spawn1_internal.c
parentdae816d196ca006cb0e820de1d468e551129f220 (diff)
downloadskalibs-da84f235ef985883c79066204ee838717aacd41a.tar.xz
child_spawn*: make sure posix_spawn() doesn't clobber pipes with dup2+close
Diffstat (limited to 'src/libstddjb/child_spawn1_internal.c')
-rw-r--r--src/libstddjb/child_spawn1_internal.c11
1 files changed, 7 insertions, 4 deletions
diff --git a/src/libstddjb/child_spawn1_internal.c b/src/libstddjb/child_spawn1_internal.c
index 0f9cb16..116a65e 100644
--- a/src/libstddjb/child_spawn1_internal.c
+++ b/src/libstddjb/child_spawn1_internal.c
@@ -32,10 +32,13 @@ pid_t child_spawn1_internal (char const *prog, char const *const *argv, char con
}
e = posix_spawn_file_actions_init(&actions) ;
if (e) goto errattr ;
- e = posix_spawn_file_actions_adddup2(&actions, p[to & 1], to & 1) ;
- if (e) goto erractions ;
- e = posix_spawn_file_actions_addclose(&actions, p[to & 1]) ;
- if (e) goto erractions ;
+ if (p[to & 1] != to & 1)
+ {
+ e = posix_spawn_file_actions_adddup2(&actions, p[to & 1], to & 1) ;
+ if (e) goto erractions ;
+ e = posix_spawn_file_actions_addclose(&actions, p[to & 1]) ;
+ if (e) goto erractions ;
+ }
if (to & 2)
{
e = posix_spawn_file_actions_adddup2(&actions, to & 1, !(to & 1)) ;