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