1 | JSON * T_JSON |
1 | Signal T_SIGNAL |
|
|
2 | |
|
|
3 | struct ev_loop * T_LOOP |
|
|
4 | |
|
|
5 | ev_watcher * T_WATCHER |
|
|
6 | ev_io * T_WATCHER |
|
|
7 | ev_timer * T_WATCHER |
|
|
8 | ev_periodic * T_WATCHER |
|
|
9 | ev_signal * T_WATCHER |
|
|
10 | ev_idle * T_WATCHER |
|
|
11 | ev_prepare * T_WATCHER |
|
|
12 | ev_check * T_WATCHER |
|
|
13 | ev_child * T_WATCHER |
|
|
14 | ev_embed * T_WATCHER |
|
|
15 | ev_stat * T_WATCHER |
|
|
16 | ev_fork * T_WATCHER |
|
|
17 | ev_async * T_WATCHER |
|
|
18 | |
|
|
19 | char * T_PVbyte |
|
|
20 | const char * T_PVbyte |
2 | |
21 | |
3 | INPUT |
22 | INPUT |
4 | |
23 | |
5 | T_JSON |
24 | T_SIGNAL |
|
|
25 | if (($var = s_signum_croak ($arg)) <= 0) |
|
|
26 | croak (\"'%s' is not a valid signal number or name\", SvPV_nolen ($arg)); |
|
|
27 | |
|
|
28 | T_PVbyte |
|
|
29 | $var = ($type)SvPVbyte_nolen ($arg) |
|
|
30 | |
|
|
31 | T_LOOP |
6 | if (!(SvROK ($arg) && SvOBJECT (SvRV ($arg)) |
32 | if (!(SvROK ($arg) && SvOBJECT (SvRV ($arg)) |
7 | && SvSTASH (SvRV ($arg)) == JSON_STASH)) |
33 | && (SvSTASH (SvRV ($arg)) == stash_loop || sv_derived_from ($arg, \"EV::Loop\")))) |
8 | croak (\"object is not of type JSON::XS\"); |
34 | croak (\"object is not of type EV::Loop\"); |
9 | $var = (JSON *)SvPVX (SvRV ($arg)); |
35 | $var = ($type)SvIVX (SvRV ($arg)); |
|
|
36 | |
|
|
37 | T_WATCHER |
|
|
38 | if (!(SvROK ($arg) && SvOBJECT (SvRV ($arg)) |
|
|
39 | && (SvSTASH (SvRV ($arg)) == stash_" . ($type =~ /ev_(\S+)/, "$1") . " |
|
|
40 | || sv_derived_from ($arg, \"EV::" . ($type =~ /ev_(\S+)/, ucfirst "$1") . "\")))) |
|
|
41 | croak (\"object is not of type EV::" . ($type =~ /ev_(\S+)/, ucfirst "$1") . "\"); |
|
|
42 | $var = ($type)SvPVX (SvRV ($arg)); |
|
|
43 | |
|
|
44 | OUTPUT |
|
|
45 | |
|
|
46 | T_PVbyte |
|
|
47 | sv_setpv ((SV *)$arg, $var); |
|
|
48 | |
|
|
49 | T_WATCHER |
|
|
50 | $arg = e_bless ((struct ev_watcher *)$var, stash_${ ($type =~ /ev_(\S+)/, \"$1") }); |
10 | |
51 | |
11 | |
52 | |