[gmime] Force use of our own poll() on MacOS
- From: Jeffrey Stedfast <fejj src gnome org>
- To: commits-list gnome org
- Cc:
- Subject: [gmime] Force use of our own poll() on MacOS
- Date: Wed, 8 Jun 2011 15:42:42 +0000 (UTC)
commit a7b66dcdcf52ef61d025f7ec5a97fddf21c301c0
Author: Jeffrey Stedfast <fejj gnome org>
Date: Wed Jun 8 11:42:22 2011 -0400
Force use of our own poll() on MacOS
2011-06-08 Jeffrey Stedfast <fejj gnome org>
* gmime/gmime-gpg-context.c: If building on Apple, force the use
of our own implementation of poll() because Apple's poll() is
broken on some versions of MacOS.
ChangeLog | 6 ++++++
gmime/gmime-gpg-context.c | 19 +++++++++++++++----
2 files changed, 21 insertions(+), 4 deletions(-)
---
diff --git a/ChangeLog b/ChangeLog
index d5f2c0e..563af08 100644
--- a/ChangeLog
+++ b/ChangeLog
@@ -1,3 +1,9 @@
+2011-06-08 Jeffrey Stedfast <fejj gnome org>
+
+ * gmime/gmime-gpg-context.c: If building on Apple, force the use
+ of our own implementation of poll() because Apple's poll() is
+ broken on some versions of MacOS.
+
2011-03-18 Jeffrey Stedfast <fejj novell com>
* README: Bumped version
diff --git a/gmime/gmime-gpg-context.c b/gmime/gmime-gpg-context.c
index cf6fdc0..7fed007 100644
--- a/gmime/gmime-gpg-context.c
+++ b/gmime/gmime-gpg-context.c
@@ -23,6 +23,11 @@
#include <config.h>
#endif
+#ifdef __APPLE__
+#undef HAVE_POLL_H
+#undef HAVE_POLL
+#endif
+
#include <stdio.h>
#include <stdlib.h>
#include <string.h>
@@ -1412,15 +1417,18 @@ poll (struct pollfd *pfds, nfds_t nfds, int timeout)
FD_ZERO (&xset);
for (i = 0; i < nfds; i++) {
+ pfds[i].revents = 0;
+ if (pfds[i].fd < 0)
+ continue;
+
if (pfds[i].events & POLLIN)
FD_SET (pfds[i].fd, &rset);
if (pfds[i].events & POLLOUT)
FD_SET (pfds[i].fd, &wset);
- if (pfds[i].events & POLLPRI)
+ if (pfds[i].events != 0)
FD_SET (pfds[i].fd, &xset);
- if (pfds[i].fd > maxfd && (pfds[i].events & (POLLIN | POLLOUT | POLLPRI)))
+ if (pfds[i].fd > maxfd)
maxfd = pfds[i].fd;
- pfds[i].revents = 0;
}
/* poll our fds... */
@@ -1428,12 +1436,15 @@ poll (struct pollfd *pfds, nfds_t nfds, int timeout)
ready = 0;
for (i = 0; i < nfds; i++) {
+ if (pfds[i].fd < 0)
+ continue;
+
if (FD_ISSET (pfds[i].fd, &rset))
pfds[i].revents |= POLLIN;
if (FD_ISSET (pfds[i].fd, &wset))
pfds[i].revents |= POLLOUT;
if (FD_ISSET (pfds[i].fd, &xset))
- pfds[i].revents |= POLLPRI;
+ pfds[i].revents |= POLLERR | POLLHUP;
if (pfds[i].revents != 0)
ready++;
[
Date Prev][
Date Next] [
Thread Prev][
Thread Next]
[
Thread Index]
[
Date Index]
[
Author Index]