From bd92446184fe692e0ceda700945c588ae56cc6cd Mon Sep 17 00:00:00 2001 From: rofl0r Date: Tue, 15 Sep 2020 20:01:01 +0100 Subject: [PATCH] use poll() where available --- configure.ac | 2 +- src/mypoll.c | 14 ++++++++++---- src/mypoll.h | 11 +++++++++-- 3 files changed, 20 insertions(+), 7 deletions(-) diff --git a/configure.ac b/configure.ac index 7de6087..cf2f19c 100644 --- a/configure.ac +++ b/configure.ac @@ -141,7 +141,7 @@ AC_HEADER_STDC AC_HEADER_TIME AC_HEADER_SYS_WAIT AC_CHECK_HEADERS([sys/ioctl.h alloca.h memory.h malloc.h sysexits.h \ - values.h]) + values.h poll.h]) dnl Checks for libary functions AC_FUNC_LSTAT_FOLLOWS_SLASHED_SYMLINK diff --git a/src/mypoll.c b/src/mypoll.c index 0e06805..495e2c3 100644 --- a/src/mypoll.c +++ b/src/mypoll.c @@ -1,8 +1,14 @@ #include "mypoll.h" -#define MYPOLL_READ (1<<1) -#define MYPOLL_WRITE (1<<2) - +#ifdef HAVE_POLL_H +int mypoll(pollfd_struct* fds, int nfds, int timeout) { + int i, ret; + for(i=0; i +#include "config.h" #ifdef HAVE_POLL_H + #include typedef struct pollfd pollfd_struct; + +#define MYPOLL_READ POLLIN +#define MYPOLL_WRITE POLLOUT + #else + +#include typedef struct mypollfd { int fd; short events; short revents; } pollfd_struct; -#endif #define MYPOLL_READ (1<<1) #define MYPOLL_WRITE (1<<2) +#endif int mypoll(pollfd_struct* fds, int nfds, int timeout);