X-Git-Url: http://git.indexdata.com/?p=yaz-moved-to-github.git;a=blobdiff_plain;f=src%2Fpoll.c;h=f3584d70a086eb9bfb2ad95d6178a19efcf82367;hp=a2f2c901610e61117a936457ae20446a5f022479;hb=15aeea31b59ead99109571dcf67a5f3b78fd5585;hpb=3576736bac485d8f04b2fc4f6b5cfcef7576d741;ds=sidebyside diff --git a/src/poll.c b/src/poll.c index a2f2c90..f3584d7 100644 --- a/src/poll.c +++ b/src/poll.c @@ -1,13 +1,14 @@ -/* - * Copyright (C) 1995-2007, Index Data ApS +/* This file is part of the YAZ toolkit. + * Copyright (C) 1995-2011 Index Data * See the file LICENSE for details. - * - * $Id: poll.c,v 1.4 2007-11-30 11:44:47 adam Exp $ */ /** * \file * \brief Select, poll wrapper */ +#if HAVE_CONFIG_H +#include +#endif #include #include @@ -65,6 +66,10 @@ int yaz_poll_select(struct yaz_poll_fd *fds, int num_fds, int sec, int nsec) enum yaz_poll_mask mask = fds[i].input_mask; int fd = fds[i].fd; + /* Timeout events */ + if (fd < 0) + continue; + if (mask & yaz_poll_read) FD_SET(fd, &input); if (mask & yaz_poll_write) @@ -86,8 +91,7 @@ int yaz_poll_select(struct yaz_poll_fd *fds, int num_fds, int sec, int nsec) int fd = fds[i].fd; if (!r) yaz_poll_add(mask, yaz_poll_timeout); - else - { + else if (fd >= 0) { if (FD_ISSET(fd, &input)) yaz_poll_add(mask, yaz_poll_read); if (FD_ISSET(fd, &output)) @@ -140,8 +144,10 @@ int yaz_poll_poll(struct yaz_poll_fd *fds, int num_fds, int sec, int nsec) yaz_poll_add(mask, yaz_poll_read); if (pollfds[i].revents & POLLOUT) yaz_poll_add(mask, yaz_poll_write); - if (pollfds[i].revents & POLLERR) + if (pollfds[i].revents & ~(POLLIN | POLLOUT)) + { yaz_poll_add(mask, yaz_poll_except); + } } fds[i].output_mask = mask; } @@ -153,7 +159,7 @@ int yaz_poll_poll(struct yaz_poll_fd *fds, int num_fds, int sec, int nsec) int yaz_poll(struct yaz_poll_fd *fds, int num_fds, int sec, int nsec) { -#if YAZ_HAVE_SYS_POLL_H +#if HAVE_SYS_POLL_H return yaz_poll_poll(fds, num_fds, sec, nsec); #else return yaz_poll_select(fds, num_fds, sec, nsec); @@ -163,6 +169,7 @@ int yaz_poll(struct yaz_poll_fd *fds, int num_fds, int sec, int nsec) /* * Local variables: * c-basic-offset: 4 + * c-file-style: "Stroustrup" * indent-tabs-mode: nil * End: * vim: shiftwidth=4 tabstop=8 expandtab