diff options
author | Doug MacEachern <dougm@opengroup.org> | 1997-04-05 10:24:43 -0500 |
---|---|---|
committer | Chip Salzenberg <chip@atlantic.net> | 1997-04-04 00:00:00 +0000 |
commit | 8f1832628ef5654922d1b8e5959e65894d09ac5d (patch) | |
tree | 5279d6d295501d071358b8ab9116e38d808b8dc4 | |
parent | ed5c9e5071c7b22c1c8d5ca4426c026435a9f731 (diff) | |
download | perl-8f1832628ef5654922d1b8e5959e65894d09ac5d.tar.gz |
Document sample function perl_eval()
Tim, your comments have changed perl_eval() from a quick & dirty
example to something I'd like to see part of the Perl API, maybe
called perl_eval_pv though.
p5p-msgid: 199704051524.KAA06090@postman.osf.org
-rw-r--r-- | pod/perlcall.pod | 38 | ||||
-rw-r--r-- | pod/perlembed.pod | 30 |
2 files changed, 68 insertions, 0 deletions
diff --git a/pod/perlcall.pod b/pod/perlcall.pod index 0bfd142cb3..85e0237827 100644 --- a/pod/perlcall.pod +++ b/pod/perlcall.pod @@ -1915,6 +1915,44 @@ refers to the last. =back +=head2 Creating and calling an anonymous subroutine in C + +As we've already shown, L<perl_call_sv> can be used to invoke an +anonymous subroutine. However, our example showed how Perl script +invoking an XSUB to preform this operation. Let's see how it can be +done inside our C code: + + SV *perl_eval(char *string, int croak_on_error) + { + dSP; + SV *sv = newSVpv(string,0); + + PUSHMARK(sp); + perl_eval_sv(sv, G_SCALAR); + SvREFCNT_dec(sv); + + SPAGAIN; + sv = POPs; + PUTBACK; + + if (croak_on_error && SvTRUE(GvSV(errgv))) + croak(SvPV(GvSV(errgv),na)); + + return sv; + } + + ... + + SV *cvrv = perl_eval("sub { print 'You will not find me cluttering any namespace!' }", TRUE); + + ... + + perl_call_sv(cvrv, G_VOID|G_NOARGS); + +L<perl_eval_sv> is used to compile the anonymous subroutine, which can +then be POPed off the stack. Once this code reference is in hand, it +can be mixed in with all the previous examples we've shown. + =head1 SEE ALSO L<perlxs>, L<perlguts>, L<perlembed> diff --git a/pod/perlembed.pod b/pod/perlembed.pod index 9111be1253..9e3fb5250a 100644 --- a/pod/perlembed.pod +++ b/pod/perlembed.pod @@ -326,6 +326,36 @@ I<SvPV()> to create a string: a = 9.859600 a = Just Another Perl Hacker +In the example above, we've created a global variable to temporarily +store the computed value of our eval'd expression. It is also +possible and in most cases a better strategy to fetch the return value +from L<perl_eval_sv> instead. Example: + + SV *perl_eval(char *string, int croak_on_error) + { + dSP; + SV *sv = newSVpv(string,0); + + PUSHMARK(sp); + perl_eval_sv(sv, G_SCALAR); + SvREFCNT_dec(sv); + + SPAGAIN; + sv = POPs; + PUTBACK; + + if (croak_on_error && SvTRUE(GvSV(errgv))) + croak(SvPV(GvSV(errgv),na)); + + return sv; + } + ... + SV *val = perl_eval("reverse 'rekcaH lreP rehtonA tsuJ'", TRUE); + printf("%s\n", SvPV(val,na)); + ... + +This way, we avoid namespace pollution by not creating global +variables and we've simplified our code as well. =head2 Performing Perl pattern matches and substitutions from your C program |