ViewVC Help
View File | Revision Log | Show Annotations | Download File
/cvs/EV/EV.xs
(Generate patch)

Comparing EV/EV.xs (file contents):
Revision 1.58 by root, Wed Nov 7 13:27:56 2007 UTC vs.
Revision 1.64 by root, Mon Nov 12 00:31:08 2007 UTC

9 9
10/* fix perl api breakage */ 10/* fix perl api breakage */
11#undef signal 11#undef signal
12#undef sigaction 12#undef sigaction
13 13
14#define EV_SELECT_USE_WIN32_HANDLES 0 14#define EV_SELECT_IS_WINSOCKET 0
15#ifdef _WIN32
15#define EV_SELECT_USE_FD_SET 0 16# define EV_SELECT_USE_FD_SET 0
17# define NFDBITS PERL_NFDBITS
18# define fd_mask Perl_fd_mask
19#endif
16/* due to bugs in OS X we have to use libev/ explicitly here */ 20/* due to bugs in OS X we have to use libev/ explicitly here */
17#include "libev/ev.c" 21#include "libev/ev.c"
18#include "event.c" 22#include "event.c"
19 23
20#ifndef WIN32 24#ifndef _WIN32
21#define DNS_USE_GETTIMEOFDAY_FOR_ID 1 25#define DNS_USE_GETTIMEOFDAY_FOR_ID 1
22#if !defined (WIN32) && !defined(__CYGWIN__) 26#if !defined (WIN32) && !defined(__CYGWIN__)
23# define HAVE_STRUCT_IN6_ADDR 1 27# define HAVE_STRUCT_IN6_ADDR 1
24#endif 28#endif
25#undef HAVE_STRTOK_R 29#undef HAVE_STRTOK_R
26#undef strtok_r 30#undef strtok_r
27#define strtok_r fake_strtok_r 31#define strtok_r fake_strtok_r
32#include "evdns.h"
28#include "evdns.c" 33#include "evdns.c"
29#endif 34#endif
30 35
31#ifndef WIN32 36#ifndef _WIN32
32# include <pthread.h> 37# include <pthread.h>
33#endif 38#endif
34 39
35typedef int Signal; 40typedef int Signal;
36 41
100 SvPOK_only (self); 105 SvPOK_only (self);
101 SvCUR_set (self, size); 106 SvCUR_set (self, size);
102 107
103 w = (struct ev_watcher *)SvPVX (self); 108 w = (struct ev_watcher *)SvPVX (self);
104 109
105 ev_watcher_init (w, e_cb); 110 ev_init (w, e_cb);
106 111
112 w->data = 0;
107 w->fh = 0; 113 w->fh = 0;
108 w->cb_sv = newSVsv (cb_sv); 114 w->cb_sv = newSVsv (cb_sv);
109 w->self = self; 115 w->self = self;
110 116
111 return (void *)w; 117 return (void *)w;
116{ 122{
117 struct ev_watcher *w = (struct ev_watcher *)w_; 123 struct ev_watcher *w = (struct ev_watcher *)w_;
118 124
119 SvREFCNT_dec (w->fh ); w->fh = 0; 125 SvREFCNT_dec (w->fh ); w->fh = 0;
120 SvREFCNT_dec (w->cb_sv); w->cb_sv = 0; 126 SvREFCNT_dec (w->cb_sv); w->cb_sv = 0;
127 SvREFCNT_dec (w->data ); w->data = 0;
121} 128}
122 129
123static SV * 130static SV *
124e_bless (struct ev_watcher *w, HV *stash) 131e_bless (struct ev_watcher *w, HV *stash)
125{ 132{
179 call_sv (get_sv ("EV::DIED", 1), G_DISCARD | G_VOID | G_EVAL | G_KEEPERR); 186 call_sv (get_sv ("EV::DIED", 1), G_DISCARD | G_VOID | G_EVAL | G_KEEPERR);
180 SP = PL_stack_base + mark; PUTBACK; 187 SP = PL_stack_base + mark; PUTBACK;
181 } 188 }
182} 189}
183 190
191static ev_tstamp
192e_periodic_cb (struct ev_periodic *w, ev_tstamp now)
193{
194 ev_tstamp retval;
195 int count;
196 dSP;
197
198 ENTER;
199 SAVETMPS;
200
201 PUSHMARK (SP);
202 EXTEND (SP, 2);
203 PUSHs (newRV_inc (w->self)); /* w->self MUST be blessed by now */
204 PUSHs (newSVnv (now));
205
206 PUTBACK;
207 count = call_sv (w->fh, G_SCALAR | G_EVAL);
208 SPAGAIN;
209
210 if (SvTRUE (ERRSV))
211 {
212 PUSHMARK (SP);
213 PUTBACK;
214 call_sv (get_sv ("EV::DIED", 1), G_DISCARD | G_VOID | G_EVAL | G_KEEPERR);
215 SPAGAIN;
216 }
217
218 if (count > 0)
219 {
220 retval = SvNV (TOPs);
221
222 if (retval < now)
223 retval = now;
224 }
225 else
226 retval = now;
227
228 FREETMPS;
229 LEAVE;
230
231 return retval;
232}
233
184///////////////////////////////////////////////////////////////////////////// 234/////////////////////////////////////////////////////////////////////////////
185// DNS 235// DNS
186 236
187#ifndef WIN32 237#ifndef _WIN32
188static void 238static void
189dns_cb (int result, char type, int count, int ttl, void *addresses, void *arg) 239dns_cb (int result, char type, int count, int ttl, void *addresses, void *arg)
190{ 240{
191 dSP; 241 dSP;
192 SV *cb = (SV *)arg; 242 SV *cb = (SV *)arg;
330 evapi.child_stop = ev_child_stop; 380 evapi.child_stop = ev_child_stop;
331 381
332 sv_setiv (sv, (IV)&evapi); 382 sv_setiv (sv, (IV)&evapi);
333 SvREADONLY_on (sv); 383 SvREADONLY_on (sv);
334 } 384 }
335#ifndef WIN32 385#ifndef _WIN32
336 pthread_atfork (0, 0, ev_default_fork); 386 pthread_atfork (0, 0, ev_default_fork);
337#endif 387#endif
338} 388}
339 389
340NV ev_now () 390NV ev_now ()
375 ev_timer_set (RETVAL, after, repeat); 425 ev_timer_set (RETVAL, after, repeat);
376 if (!ix) ev_timer_start (RETVAL); 426 if (!ix) ev_timer_start (RETVAL);
377 OUTPUT: 427 OUTPUT:
378 RETVAL 428 RETVAL
379 429
380struct ev_periodic *periodic (NV at, NV interval, SV *cb) 430SV *periodic (NV at, NV interval, SV *reschedule_cb, SV *cb)
381 ALIAS: 431 ALIAS:
382 periodic_ns = 1 432 periodic_ns = 1
383 INIT: 433 INIT:
384 CHECK_REPEAT (interval); 434 CHECK_REPEAT (interval);
385 CODE: 435 CODE:
436{
437 struct ev_periodic *w;
386 RETVAL = e_new (sizeof (struct ev_periodic), cb); 438 w = e_new (sizeof (struct ev_periodic), cb);
387 ev_periodic_set (RETVAL, at, interval); 439 w->fh = SvTRUE (reschedule_cb) ? newSVsv (reschedule_cb) : 0;
440 ev_periodic_set (w, at, interval, w->fh ? e_periodic_cb : 0);
441 RETVAL = e_bless ((struct ev_watcher *)w, stash_periodic);
388 if (!ix) ev_periodic_start (RETVAL); 442 if (!ix) ev_periodic_start (w);
443}
389 OUTPUT: 444 OUTPUT:
390 RETVAL 445 RETVAL
391 446
392struct ev_signal *signal (Signal signum, SV *cb) 447struct ev_signal *signal (Signal signum, SV *cb)
393 ALIAS: 448 ALIAS:
451{ 506{
452 RETVAL = newSVsv (w->cb_sv); 507 RETVAL = newSVsv (w->cb_sv);
453 508
454 if (items > 1) 509 if (items > 1)
455 sv_setsv (w->cb_sv, new_cb); 510 sv_setsv (w->cb_sv, new_cb);
511}
512 OUTPUT:
513 RETVAL
514
515SV *data (struct ev_watcher *w, SV *new_data = 0)
516 CODE:
517{
518 RETVAL = w->data ? newSVsv (w->data) : &PL_sv_undef;
456} 519}
457 OUTPUT: 520 OUTPUT:
458 RETVAL 521 RETVAL
459 522
460void trigger (struct ev_watcher *w, int revents = EV_NONE) 523void trigger (struct ev_watcher *w, int revents = EV_NONE)
634 INIT: 697 INIT:
635 CHECK_REPEAT (w->interval); 698 CHECK_REPEAT (w->interval);
636 699
637void ev_periodic_stop (struct ev_periodic *w) 700void ev_periodic_stop (struct ev_periodic *w)
638 701
702void ev_periodic_again (struct ev_periodic *w)
703
639void DESTROY (struct ev_periodic *w) 704void DESTROY (struct ev_periodic *w)
640 CODE: 705 CODE:
641 ev_periodic_stop (w); 706 ev_periodic_stop (w);
642 e_destroy (w); 707 e_destroy (w);
643 708
644void set (struct ev_periodic *w, NV at, NV interval = 0.) 709void set (struct ev_periodic *w, NV at, NV interval = 0., SV *reschedule_cb = &PL_sv_undef)
645 INIT: 710 INIT:
646 CHECK_REPEAT (interval); 711 CHECK_REPEAT (interval);
647 CODE: 712 CODE:
648{ 713{
649 int active = ev_is_active (w); 714 int active = ev_is_active (w);
650 if (active) ev_periodic_stop (w); 715 if (active) ev_periodic_stop (w);
651 716
717 SvREFCNT_dec (w->fh);
718 w->fh = SvTRUE (reschedule_cb) ? newSVsv (reschedule_cb) : 0;
652 ev_periodic_set (w, at, interval); 719 ev_periodic_set (w, at, interval, w->fh ? e_periodic_cb : 0);
653 720
654 if (active) ev_periodic_start (w); 721 if (active) ev_periodic_start (w);
655} 722}
656 723
657MODULE = EV PACKAGE = EV::Idle PREFIX = ev_idle_ 724MODULE = EV PACKAGE = EV::Idle PREFIX = ev_idle_
734 CODE: 801 CODE:
735 RETVAL = ix ? w->rpid : w->rstatus; 802 RETVAL = ix ? w->rpid : w->rstatus;
736 OUTPUT: 803 OUTPUT:
737 RETVAL 804 RETVAL
738 805
739#ifndef WIN32 806#ifndef _WIN32
740 807
741MODULE = EV PACKAGE = EV::DNS PREFIX = evdns_ 808MODULE = EV PACKAGE = EV::DNS PREFIX = evdns_
742 809
743BOOT: 810BOOT:
744{ 811{
815 882
816int evdns_set_option (char *option, char *val, int flags) 883int evdns_set_option (char *option, char *val, int flags)
817 884
818int evdns_resolv_conf_parse (int flags, const char *filename) 885int evdns_resolv_conf_parse (int flags, const char *filename)
819 886
820#ifdef MS_WINDOWS 887#ifdef _WIN32
821 888
822int evdns_config_windows_nameservers () 889int evdns_config_windows_nameservers ()
823 890
824#endif 891#endif
825 892

Diff Legend

Removed lines
+ Added lines
< Changed lines
> Changed lines