diff options
author | Clint Adams <clint@users.sourceforge.net> | 2001-09-27 15:36:41 +0000 |
---|---|---|
committer | Clint Adams <clint@users.sourceforge.net> | 2001-09-27 15:36:41 +0000 |
commit | 8c05772007d403450624056cd24f8d53efa2da70 (patch) | |
tree | 9cdb8dd31808c57b67386996436903aea6cfb166 /Src/Modules/tcp.c | |
parent | 4f1d07bb8622f27135b90c5622a032a4d2fbdee3 (diff) | |
download | zsh-8c05772007d403450624056cd24f8d53efa2da70.tar.gz zsh-8c05772007d403450624056cd24f8d53efa2da70.tar.xz zsh-8c05772007d403450624056cd24f8d53efa2da70.zip |
15886: use select if poll is not available, or complain if neither are available
Diffstat (limited to 'Src/Modules/tcp.c')
-rw-r--r-- | Src/Modules/tcp.c | 27 |
1 files changed, 25 insertions, 2 deletions
diff --git a/Src/Modules/tcp.c b/Src/Modules/tcp.c index cde2c2374..ae1b21912 100644 --- a/Src/Modules/tcp.c +++ b/Src/Modules/tcp.c @@ -538,6 +538,8 @@ bin_ztcp(char *nam, char **args, char *ops, int func) } if(test) { +#if defined(HAVE_POLL) || defined(HAVE_SELECT) +# ifdef HAVE_POLL struct pollfd pfd; int ret; @@ -549,7 +551,29 @@ bin_ztcp(char *nam, char **args, char *ops, int func) zwarnnam(nam, "poll error: %e", NULL, errno); return 1; } - +# else + fd_set rfds; + struct timeval tv; + int ret; + + FD_ZERO(&rfds); + FD_SET(lfd, &rfds); + tv.tv_sec = 0; + tv.tv_usec = 0; + + if(ret = select(lfd+1, &rfds, NULL, NULL, &tv)) return 1; + else if (ret == -1) + { + zwarnnam(nam, "select error: %e", NULL, errno); + return 1; + } + +# endif + +#else + zwarnnam(nam, "not currently supported", NULL, 0); + return 1; +#endif } sess = zts_alloc(ZTCP_INBOUND); @@ -572,7 +596,6 @@ bin_ztcp(char *nam, char **args, char *ops, int func) if(verbose) fprintf(shout, "%d is on fd %d\n", ntohs(sess->peer.in.sin_port), sess->fd); - } else { |