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