1 | JSON * T_JSON |
1 | Signal T_SIGNAL |
|
|
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_check * T_WATCHER |
|
|
11 | |
|
|
12 | char * T_PVbyte |
|
|
13 | const char * T_PVbyte |
2 | |
14 | |
3 | INPUT |
15 | INPUT |
4 | |
16 | |
5 | T_JSON |
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 |
6 | if (!(SvROK ($arg) && SvOBJECT (SvRV ($arg)) |
25 | if (!(SvROK ($arg) && SvOBJECT (SvRV ($arg)) |
7 | && SvSTASH (SvRV ($arg)) == JSON_STASH)) |
26 | && (SvSTASH (SvRV ($arg)) == stash_" . ($type =~ /ev_(\S+)/, "$1") . " |
8 | croak (\"object is not of type JSON::XS\"); |
27 | || sv_derived_from ($arg, \"EV::" . ($type =~ /ev_(\S+)/, ucfirst "$1") . "\")))) |
9 | $var = (JSON *)SvPVX (SvRV ($arg)); |
28 | croak (\"object is not of type EV::" . ($type =~ /ev_(\S+)/, ucfirst "$1") . "\"); |
|
|
29 | $var = ($type)SvPVX (SvRV ($arg)); |
|
|
30 | |
|
|
31 | OUTPUT |
|
|
32 | |
|
|
33 | T_PVbyte |
|
|
34 | sv_setpv ((SV *)$arg, $var); |
|
|
35 | |
|
|
36 | T_WATCHER |
|
|
37 | $arg = e_bless ((struct ev_watcher *)$var, stash_${ ($type =~ /ev_(\S+)/, \"$1") }); |
10 | |
38 | |
11 | |
39 | |