MEDIUM: kqueue: take care of EV_EOF to improve polling status accuracy

kevent() always sets EV_EOF with EVFILT_READ to notify of a read shutdown
and EV_EOF with EVFILT_WRITE to notify of a write error. Let's check this
flag to properly update the FD's polled status (FD_POLL_HUP and FD_POLL_ERR
respectively).

It's worth noting that this one can be coupled with a regular read event
to notify about a pending read followed by a shutdown, but for now we only
use this to set the relevant flags (HUP and ERR).

The poller now exhibits the flag HAP_POLL_F_RDHUP to indicate this new
capability.

An improvement may consist in not setting FD_POLL_IN when the "data"
field is null since it normally only reflects the amount of pending
data.
diff --git a/src/ev_kqueue.c b/src/ev_kqueue.c
index e6338e6..6f41c73 100644
--- a/src/ev_kqueue.c
+++ b/src/ev_kqueue.c
@@ -126,9 +126,13 @@
 
 		if (kev[count].filter ==  EVFILT_READ) {
 			fdtab[fd].ev |= FD_POLL_IN;
+			if (kev[count].flags & EV_EOF)
+				fdtab[fd].ev |= FD_POLL_HUP;
 		}
 		else if (kev[count].filter ==  EVFILT_WRITE) {
 			fdtab[fd].ev |= FD_POLL_OUT;
+			if (kev[count].flags & EV_EOF)
+				fdtab[fd].ev |= FD_POLL_ERR;
 		}
 
 		if (fdtab[fd].ev & (FD_POLL_IN | FD_POLL_HUP | FD_POLL_ERR))
@@ -232,7 +236,7 @@
 
 	p->name = "kqueue";
 	p->pref = 300;
-	p->flags = 0;
+	p->flags = HAP_POLL_F_RDHUP;
 	p->private = NULL;
 
 	p->clo  = NULL;