1 | Base T_BASE |
1 | Signal T_SIGNAL |
2 | Event T_EVENT |
|
|
3 | |
2 | |
4 | /* for 5.6 compatibility */ |
3 | struct ev_watcher * T_WATCHER |
|
|
4 | struct ev_io * T_WATCHER |
|
|
5 | struct ev_time * T_WATCHER |
|
|
6 | struct ev_timer * T_WATCHER |
|
|
7 | struct ev_periodic * T_WATCHER |
|
|
8 | struct ev_signal * T_WATCHER |
|
|
9 | struct ev_idle * T_WATCHER |
|
|
10 | struct ev_prepare * T_WATCHER |
|
|
11 | struct ev_check * T_WATCHER |
|
|
12 | |
|
|
13 | char * T_PVbyte |
5 | const char * T_PV |
14 | const char * T_PVbyte |
6 | |
15 | |
7 | INPUT |
16 | INPUT |
8 | |
17 | |
9 | T_BASE |
18 | T_SIGNAL |
|
|
19 | if (($var = sv_signum ($arg)) <= 0) |
|
|
20 | croak (\"'%s' is not a valid signal number or name\", SvPV_nolen ($arg)); |
|
|
21 | |
|
|
22 | T_PVbyte |
|
|
23 | $var = ($type)SvPVbyte_nolen ($arg) |
|
|
24 | |
|
|
25 | T_WATCHER |
10 | if (!(SvROK ($arg) && SvOBJECT (SvRV ($arg)) |
26 | if (!(SvROK ($arg) && SvOBJECT (SvRV ($arg)) |
11 | && SvSTASH (SvRV ($arg)) == stash_base)) |
27 | && (SvSTASH (SvRV ($arg)) == stash_" . ($type =~ /ev_(\S+)/, "$1") . " |
12 | croak (\"object is not of type EV::Base\"); |
28 | || sv_derived_from ($arg, \"EV::" . ($type =~ /ev_(\S+)/, ucfirst "$1") . "\")))) |
13 | $var = (Base)SvIV (SvRV ($arg)); |
29 | croak (\"object is not of type EV::" . ($type =~ /ev_(\S+)/, ucfirst "$1") . "\"); |
14 | |
|
|
15 | T_EVENT |
|
|
16 | if (!(SvROK ($arg) && SvOBJECT (SvRV ($arg)) |
|
|
17 | && SvSTASH (SvRV ($arg)) == stash_event)) |
|
|
18 | croak (\"object is not of type EV::Event\"); |
|
|
19 | $var = (Event)SvPVX (SvRV ($arg)); |
30 | $var = ($type)SvPVX (SvRV ($arg)); |
20 | |
31 | |
21 | OUTPUT |
32 | OUTPUT |
22 | |
33 | |
23 | T_BASE |
34 | T_PVbyte |
24 | sv_setref_iv ($arg, "EV::Base", (IV)$var); |
35 | sv_setpv ((SV *)$arg, $var); |
25 | |
36 | |
26 | T_EVENT |
37 | T_WATCHER |
27 | $arg = e_self ($var); |
38 | $arg = e_bless ((struct ev_watcher *)$var, stash_${ ($type =~ /ev_(\S+)/, \"$1") }); |
28 | |
39 | |
|
|
40 | |