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