The following is meant as a quick-and-dirty “cheat sheet” reference for XSUB authors.
Many of the “translations” below can take multiple forms; the below is not a substitute for
reading and digesting the relevant Perl documentation: perlxs
, perlxstut
, perlapi
, perlguts
, etc.
The following assumes knowledge of C, including use of pointers.
Perl |
XS |
my $v |
SV *mysv = newSV(0) |
$v = undef |
sv_set_undef(mysv) |
my $v = 1 |
SV *mysv = newSVuv(1) |
$v = 1 |
sv_setuv(mysv, 1) |
$v = -1 |
sv_setiv(mysv, -1) |
$v = 'literal' |
sv_setpvs(mysv, "literal") |
$v = $other_str |
sv_setpvn(mysv, otherstr, length_of_otherstr) |
Perl |
XS |
$v .= 'literal' |
sv_catpvs(mysv, "literal") |
$v .= $other_str |
sv_catpvn(mysv, otherstr, length_of_otherstr) |
Perl |
XS |
length $a |
sv_len_utf8(mysv) |
Perl |
XS |
my @a |
AV *myav = newAV() |
@a = () |
av_clear(myav) |
push @a, $foo |
av_push(myav, foo) |
$foo = pop @a |
SV *foo = av_pop(myav) |
$foo = shift @a |
SV *foo = av_shift(myav) |
($old) = splice(@a, 2, 1, $foo) |
SV **old = av_store(myav, 2, foo) |
my ($el) = splice(@, 2, 1) |
SV *myel = av_delete(myav, 2, 0) |
() = splice(@, 2, 1) |
av_delete(myav, 2, G_DISCARD) |
@INC |
get_av("main::INC") or (GvAV(PL_incgv)) |
Perl |
XS |
__PACKAGE__ |
HvNAME( (HV*)CopSTASH(PL_curcop) ) |
Perl |
XS |
${^GLOBAL_PHASE} |
PL_phase / PL_dirty |