… | |
… | |
104 | static void |
104 | static void |
105 | e_cb (struct ev_watcher *w, int revents) |
105 | e_cb (struct ev_watcher *w, int revents) |
106 | { |
106 | { |
107 | dSP; |
107 | dSP; |
108 | I32 mark = SP - PL_stack_base; |
108 | I32 mark = SP - PL_stack_base; |
109 | SV *sv_self, *sv_events; |
109 | SV *sv_self, *sv_events, *sv_status = 0; |
110 | static SV *sv_events_cache; |
110 | static SV *sv_events_cache; |
111 | |
111 | |
112 | sv_self = newRV_inc (w->self); /* w->self MUST be blessed by now */ |
112 | sv_self = newRV_inc (w->self); /* w->self MUST be blessed by now */ |
113 | |
113 | |
114 | if (sv_events_cache) |
114 | if (sv_events_cache) |
… | |
… | |
121 | |
121 | |
122 | PUSHMARK (SP); |
122 | PUSHMARK (SP); |
123 | EXTEND (SP, 2); |
123 | EXTEND (SP, 2); |
124 | PUSHs (sv_self); |
124 | PUSHs (sv_self); |
125 | PUSHs (sv_events); |
125 | PUSHs (sv_events); |
|
|
126 | |
|
|
127 | if (revents & EV_CHILD) |
|
|
128 | XPUSHs (sv_status = newSViv (((struct ev_child *)w)->status)); |
|
|
129 | |
126 | PUTBACK; |
130 | PUTBACK; |
127 | call_sv (w->cb_sv, G_DISCARD | G_VOID | G_EVAL); |
131 | call_sv (w->cb_sv, G_DISCARD | G_VOID | G_EVAL); |
128 | SP = PL_stack_base + mark; PUTBACK; |
132 | SP = PL_stack_base + mark; PUTBACK; |
129 | |
133 | |
130 | SvREFCNT_dec (sv_self); |
134 | SvREFCNT_dec (sv_self); |
|
|
135 | SvREFCNT_dec (sv_status); |
131 | |
136 | |
132 | if (sv_events_cache) |
137 | if (sv_events_cache) |
133 | SvREFCNT_dec (sv_events); |
138 | SvREFCNT_dec (sv_events); |
134 | else |
139 | else |
135 | sv_events_cache = sv_events; |
140 | sv_events_cache = sv_events; |
… | |
… | |
277 | evapi.idle_stop = evidle_stop; |
282 | evapi.idle_stop = evidle_stop; |
278 | evapi.prepare_start = evprepare_start; |
283 | evapi.prepare_start = evprepare_start; |
279 | evapi.prepare_stop = evprepare_stop; |
284 | evapi.prepare_stop = evprepare_stop; |
280 | evapi.check_start = evcheck_start; |
285 | evapi.check_start = evcheck_start; |
281 | evapi.check_stop = evcheck_stop; |
286 | evapi.check_stop = evcheck_stop; |
|
|
287 | evapi.child_start = evchild_start; |
|
|
288 | evapi.child_stop = evchild_stop; |
282 | |
289 | |
283 | sv_setiv (sv, (IV)&evapi); |
290 | sv_setiv (sv, (IV)&evapi); |
284 | SvREADONLY_on (sv); |
291 | SvREADONLY_on (sv); |
285 | } |
292 | } |
286 | } |
293 | } |
… | |
… | |
380 | evcheck_set (RETVAL); |
387 | evcheck_set (RETVAL); |
381 | if (!ix) evcheck_start (RETVAL); |
388 | if (!ix) evcheck_start (RETVAL); |
382 | OUTPUT: |
389 | OUTPUT: |
383 | RETVAL |
390 | RETVAL |
384 | |
391 | |
385 | struct ev_child *child (SV *cb, int pid) |
392 | struct ev_child *child (int pid, SV *cb) |
386 | ALIAS: |
393 | ALIAS: |
387 | check_ns = 1 |
394 | check_ns = 1 |
388 | CODE: |
395 | CODE: |
389 | RETVAL = e_new (sizeof (struct ev_check), cb); |
396 | RETVAL = e_new (sizeof (struct ev_check), cb); |
390 | evchild (RETVAL, pid); |
397 | evchild_set (RETVAL, pid); |
391 | if (!ix) evchild_start (RETVAL); |
398 | if (!ix) evchild_start (RETVAL); |
392 | OUTPUT: |
399 | OUTPUT: |
393 | RETVAL |
400 | RETVAL |
394 | |
401 | |
395 | |
402 | |
… | |
… | |
556 | int active = w->active; |
563 | int active = w->active; |
557 | if (active) evchild_stop (w); |
564 | if (active) evchild_stop (w); |
558 | evchild_set (w, pid); |
565 | evchild_set (w, pid); |
559 | if (active) evchild_start (w); |
566 | if (active) evchild_start (w); |
560 | } |
567 | } |
|
|
568 | |
|
|
569 | int status (struct ev_child *w) |
|
|
570 | CODE: |
|
|
571 | RETVAL = w->status; |
|
|
572 | OUTPUT: |
|
|
573 | RETVAL |
561 | |
574 | |
562 | #if 0 |
575 | #if 0 |
563 | |
576 | |
564 | MODULE = EV PACKAGE = EV::DNS PREFIX = evdns_ |
577 | MODULE = EV PACKAGE = EV::DNS PREFIX = evdns_ |
565 | |
578 | |