proxy_dns_old: use pipe2 if available, else O_CLOEXEC

make the old code a little less lame
This commit is contained in:
rofl0r 2020-09-21 10:46:38 +01:00
parent 2ab631918d
commit e6c4764660

View File

@ -756,7 +756,7 @@ struct hostent* proxy_gethostbyname_old(const char *name)
char buff[256];
in_addr_t addr;
pid_t pid;
int status;
int status, ret;
size_t l;
struct hostent* hp;
@ -775,8 +775,17 @@ struct hostent* proxy_gethostbyname_old(const char *name)
while ((hp=gethostent()))
if (!strcmp(hp->h_name,name))
return hp;
#ifdef HAVE_PIPE2
ret = pipe2(pipe_fd, O_CLOEXEC);
#else
ret = pipe(pipe_fd);
if(ret == 0) {
fcntl(pipe_fd[0], F_SETFD, FD_CLOEXEC);
fcntl(pipe_fd[1], F_SETFD, FD_CLOEXEC);
}
#endif
if(pipe(pipe_fd))
if(ret)
goto err;
pid = fork();
switch(pid) {