summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorroot <root>2007-11-09 15:15:20 +0000
committerroot <root>2007-11-09 15:15:20 +0000
commit7eebd23082204e2dce00017f483f1e876ba3079a (patch)
treee28142555430b2906ba02cd180170f089224d5c3
parent93de14fb2ac9996d3330d1fce388e75b3b2fb91a (diff)
*** empty log message ***
-rw-r--r--ev.c37
-rw-r--r--ev.h2
2 files changed, 30 insertions, 9 deletions
diff --git a/ev.c b/ev.c
index 8a32229..c6ed4b3 100644
--- a/ev.c
+++ b/ev.c
@@ -344,21 +344,27 @@ queue_events (EV_P_ W *events, int eventcnt, int type)
ev_feed_event (EV_A_ events [i], type);
}
-static void
-fd_event (EV_P_ int fd, int events)
+inline void
+fd_event (EV_P_ int fd, int revents)
{
ANFD *anfd = anfds + fd;
struct ev_io *w;
for (w = (struct ev_io *)anfd->head; w; w = (struct ev_io *)((WL)w)->next)
{
- int ev = w->events & events;
+ int ev = w->events & revents;
if (ev)
ev_feed_event (EV_A_ (W)w, ev);
}
}
+void
+ev_feed_fd_event (EV_P_ int fd, int revents)
+{
+ fd_event (EV_A_ fd, revents);
+}
+
/*****************************************************************************/
static void
@@ -554,6 +560,24 @@ sighandler (int signum)
}
}
+void
+ev_feed_signal_event (EV_P_ int signum)
+{
+#if EV_MULTIPLICITY
+ assert (("feeding signal events is only supported in the default loop", loop == default_loop));
+#endif
+
+ --signum;
+
+ if (signum < 0 || signum >= signalmax)
+ return;
+
+ signals [signum].gotsig = 0;
+
+ for (w = signals [signum].head; w; w = w->next)
+ ev_feed_event (EV_A_ (W)w, EV_SIGNAL);
+}
+
static void
sigcb (EV_P_ struct ev_io *iow, int revents)
{
@@ -569,12 +593,7 @@ sigcb (EV_P_ struct ev_io *iow, int revents)
for (signum = signalmax; signum--; )
if (signals [signum].gotsig)
- {
- signals [signum].gotsig = 0;
-
- for (w = signals [signum].head; w; w = w->next)
- ev_feed_event (EV_A_ (W)w, EV_SIGNAL);
- }
+ sigevent (EV_A_ signum + 1);
}
static void
diff --git a/ev.h b/ev.h
index c49a4dd..dc82720 100644
--- a/ev.h
+++ b/ev.h
@@ -331,6 +331,8 @@ void ev_once (EV_P_ int fd, int events, ev_tstamp timeout, void (*cb)(int revent
/* feeds an event into a watcher as if the event actually occured */
/* accepts any ev_watcher type */
void ev_feed_event (EV_P_ void *w, int revents);
+void ev_feed_fd_event (EV_P_ int fd, int revents);
+void ev_feed_signal_event (EV_P_ int signum);
void ev_io_start (EV_P_ struct ev_io *w);
void ev_io_stop (EV_P_ struct ev_io *w);