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