ViewVC Help
View File | Revision Log | Show Annotations | Download File
/cvs/libev/event.c
(Generate patch)

Comparing libev/event.c (file contents):
Revision 1.30 by root, Mon Nov 12 21:51:14 2007 UTC vs.
Revision 1.32 by root, Thu Nov 29 12:21:06 2007 UTC

158static void 158static void
159x_cb_io (EV_P_ struct ev_io *w, int revents) 159x_cb_io (EV_P_ struct ev_io *w, int revents)
160{ 160{
161 struct event *ev = (struct event *)(((char *)w) - offsetof (struct event, iosig.io)); 161 struct event *ev = (struct event *)(((char *)w) - offsetof (struct event, iosig.io));
162 162
163 if (revents & EV_ERROR) 163 if ((revents & EV_ERROR) || !(ev->ev_events & EV_PERSIST))
164 event_del (ev); 164 event_del (ev);
165 else if (!(ev->ev_events & EV_PERSIST) && ev_is_active (w))
166 {
167 ev_io_stop (EV_A_ w);
168 ev->ev_flags &= ~EVLIST_INSERTED;
169 }
170 165
171 x_cb (ev, revents); 166 x_cb (ev, revents);
172} 167}
173 168
174static void 169static void
207 202
208int event_add (struct event *ev, struct timeval *tv) 203int event_add (struct event *ev, struct timeval *tv)
209{ 204{
210 dLOOPev; 205 dLOOPev;
211 206
212 /* disable all watchers */
213 event_del (ev);
214
215 if (ev->ev_events & EV_SIGNAL) 207 if (ev->ev_events & EV_SIGNAL)
216 { 208 {
209 if (!ev_is_active (&ev->iosig.sig))
210 {
217 ev_signal_set (&ev->iosig.sig, ev->ev_fd); 211 ev_signal_set (&ev->iosig.sig, ev->ev_fd);
218 ev_signal_start (EV_A_ &ev->iosig.sig); 212 ev_signal_start (EV_A_ &ev->iosig.sig);
219 213
220 ev->ev_flags |= EVLIST_SIGNAL; 214 ev->ev_flags |= EVLIST_SIGNAL;
215 }
221 } 216 }
222 else if (ev->ev_events & (EV_READ | EV_WRITE)) 217 else if (ev->ev_events & (EV_READ | EV_WRITE))
223 { 218 {
219 if (!ev_is_active (&ev->iosig.io))
220 {
224 ev_io_set (&ev->iosig.io, ev->ev_fd, ev->ev_events & (EV_READ | EV_WRITE)); 221 ev_io_set (&ev->iosig.io, ev->ev_fd, ev->ev_events & (EV_READ | EV_WRITE));
225 ev_io_start (EV_A_ &ev->iosig.io); 222 ev_io_start (EV_A_ &ev->iosig.io);
226 223
227 ev->ev_flags |= EVLIST_INSERTED; 224 ev->ev_flags |= EVLIST_INSERTED;
225 }
228 } 226 }
229 227
230 if (tv) 228 if (tv)
231 { 229 {
232 ev_timer_set (&ev->to, tv_get (tv), 0.); 230 ev->to.repeat = tv_get (tv);
233 ev_timer_start (EV_A_ &ev->to); 231 ev_timer_again (EV_A_ &ev->to);
234
235 ev->ev_flags |= EVLIST_TIMEOUT; 232 ev->ev_flags |= EVLIST_TIMEOUT;
236 } 233 }
234 else
235 {
236 ev_timer_stop (EV_A_ &ev->to);
237 ev->ev_flags &= ~EVLIST_TIMEOUT;
238 }
237 239
238 ev->ev_flags |= EVLIST_ACTIVE; 240 ev->ev_flags |= EVLIST_ACTIVE;
239 241
240 return 0; 242 return 0;
241} 243}
243int event_del (struct event *ev) 245int event_del (struct event *ev)
244{ 246{
245 dLOOPev; 247 dLOOPev;
246 248
247 if (ev->ev_events & EV_SIGNAL) 249 if (ev->ev_events & EV_SIGNAL)
248 {
249 /* sig */
250 if (ev_is_active (&ev->iosig.sig))
251 ev_signal_stop (EV_A_ &ev->iosig.sig); 250 ev_signal_stop (EV_A_ &ev->iosig.sig);
252 }
253 else if (ev->ev_events & (EV_READ | EV_WRITE)) 251 else if (ev->ev_events & (EV_READ | EV_WRITE))
254 {
255 /* io */
256 if (ev_is_active (&ev->iosig.io))
257 ev_io_stop (EV_A_ &ev->iosig.io); 252 ev_io_stop (EV_A_ &ev->iosig.io);
258 }
259 253
260 if (ev_is_active (&ev->to)) 254 if (ev_is_active (&ev->to))
261 ev_timer_stop (EV_A_ &ev->to); 255 ev_timer_stop (EV_A_ &ev->to);
262 256
263 ev->ev_flags = EVLIST_INIT; 257 ev->ev_flags = EVLIST_INIT;

Diff Legend

Removed lines
+ Added lines
< Changed lines
> Changed lines