home *** CD-ROM | disk | FTP | other *** search
Text File | 2000-03-23 | 67.7 KB | 1,744 lines |
- <HTML>
- <HEAD>
- <TITLE>perlcall - Perl calling conventions from C</TITLE>
- <LINK REL="stylesheet" HREF="../../Active.css" TYPE="text/css">
- <LINK REV="made" HREF="mailto:">
- </HEAD>
-
- <BODY>
- <TABLE BORDER=0 CELLPADDING=0 CELLSPACING=0 WIDTH=100%>
- <TR><TD CLASS=block VALIGN=MIDDLE WIDTH=100% BGCOLOR="#cccccc">
- <STRONG><P CLASS=block> perlcall - Perl calling conventions from C</P></STRONG>
- </TD></TR>
- </TABLE>
-
- <A NAME="__index__"></A>
- <!-- INDEX BEGIN -->
-
- <UL>
-
- <LI><A HREF="#name">NAME</A></LI>
- <LI><A HREF="#description">DESCRIPTION</A></LI>
- <LI><A HREF="#the call_ functions">THE CALL_ FUNCTIONS</A></LI>
- <LI><A HREF="#flag values">FLAG VALUES</A></LI>
- <UL>
-
- <LI><A HREF="#g_void">G_VOID</A></LI>
- <LI><A HREF="#g_scalar">G_SCALAR</A></LI>
- <LI><A HREF="#g_array">G_ARRAY</A></LI>
- <LI><A HREF="#g_discard">G_DISCARD</A></LI>
- <LI><A HREF="#g_noargs">G_NOARGS</A></LI>
- <LI><A HREF="#g_eval">G_EVAL</A></LI>
- <LI><A HREF="#g_keeperr">G_KEEPERR</A></LI>
- <LI><A HREF="#determining the context">Determining the Context</A></LI>
- </UL>
-
- <LI><A HREF="#known problems">KNOWN PROBLEMS</A></LI>
- <LI><A HREF="#examples">EXAMPLES</A></LI>
- <UL>
-
- <LI><A HREF="#no parameters, nothing returned">No Parameters, Nothing returned</A></LI>
- <LI><A HREF="#passing parameters">Passing Parameters</A></LI>
- <LI><A HREF="#returning a scalar">Returning a Scalar</A></LI>
- <LI><A HREF="#returning a list of values">Returning a list of values</A></LI>
- <LI><A HREF="#returning a list in a scalar context">Returning a list in a scalar context</A></LI>
- <LI><A HREF="#returning data from perl via the parameter list">Returning Data from Perl via the parameter list</A></LI>
- <LI><A HREF="#using g_eval">Using G_EVAL</A></LI>
- <LI><A HREF="#using g_keeperr">Using G_KEEPERR</A></LI>
- <LI><A HREF="#using call_sv">Using call_sv</A></LI>
- <LI><A HREF="#using call_argv">Using call_argv</A></LI>
- <LI><A HREF="#using call_method">Using call_method</A></LI>
- <LI><A HREF="#using gimme_v">Using GIMME_V</A></LI>
- <LI><A HREF="#using perl to dispose of temporaries">Using Perl to dispose of temporaries</A></LI>
- <LI><A HREF="#strategies for storing callback context information">Strategies for storing Callback Context Information</A></LI>
- <LI><A HREF="#alternate stack manipulation">Alternate Stack Manipulation</A></LI>
- <LI><A HREF="#creating and calling an anonymous subroutine in c">Creating and calling an anonymous subroutine in C</A></LI>
- </UL>
-
- <LI><A HREF="#see also">SEE ALSO</A></LI>
- <LI><A HREF="#author">AUTHOR</A></LI>
- <LI><A HREF="#date">DATE</A></LI>
- </UL>
- <!-- INDEX END -->
-
- <HR>
- <P>
- <H1><A NAME="name">NAME</A></H1>
- <P>perlcall - Perl calling conventions from C</P>
- <P>
- <HR>
- <H1><A NAME="description">DESCRIPTION</A></H1>
- <P>The purpose of this document is to show you how to call Perl subroutines
- directly from C, i.e., how to write <EM>callbacks</EM>.</P>
- <P>Apart from discussing the C interface provided by Perl for writing
- callbacks the document uses a series of examples to show how the
- interface actually works in practice. In addition some techniques for
- coding callbacks are covered.</P>
- <P>Examples where callbacks are necessary include</P>
- <UL>
- <LI><STRONG><A NAME="item_An_Error_Handler">An Error Handler</A></STRONG><BR>
-
- You have created an XSUB interface to an application's C API.
- <P>A fairly common feature in applications is to allow you to define a C
- function that will be called whenever something nasty occurs. What we
- would like is to be able to specify a Perl subroutine that will be
- called instead.</P>
- <P></P>
- <LI><STRONG><A NAME="item_An_Event_Driven_Program">An Event Driven Program</A></STRONG><BR>
-
- The classic example of where callbacks are used is when writing an
- event driven program like for an X windows application. In this case
- you register functions to be called whenever specific events occur,
- e.g., a mouse button is pressed, the cursor moves into a window or a
- menu item is selected.
- <P></P></UL>
- <P>Although the techniques described here are applicable when embedding
- Perl in a C program, this is not the primary goal of this document.
- There are other details that must be considered and are specific to
- embedding Perl. For details on embedding Perl in C refer to
- <A HREF="../../lib/Pod/perlembed.html">the perlembed manpage</A>.</P>
- <P>Before you launch yourself head first into the rest of this document,
- it would be a good idea to have read the following two documents -
- <A HREF="../../lib/Pod/perlxs.html">the perlxs manpage</A> and <A HREF="../../lib/Pod/perlguts.html">the perlguts manpage</A>.</P>
- <P>
- <HR>
- <H1><A NAME="the call_ functions">THE CALL_ FUNCTIONS</A></H1>
- <P>Although this stuff is easier to explain using examples, you first need
- be aware of a few important definitions.</P>
- <P>Perl has a number of C functions that allow you to call Perl
- subroutines. They are</P>
- <PRE>
- I32 call_sv(SV* sv, I32 flags) ;
- I32 call_pv(char *subname, I32 flags) ;
- I32 call_method(char *methname, I32 flags) ;
- I32 call_argv(char *subname, I32 flags, register char **argv) ;</PRE>
- <P>The key function is <EM>call_sv</EM>. All the other functions are
- fairly simple wrappers which make it easier to call Perl subroutines in
- special cases. At the end of the day they will all call <EM>call_sv</EM>
- to invoke the Perl subroutine.</P>
- <P>All the <EM>call_*</EM> functions have a <CODE>flags</CODE> parameter which is
- used to pass a bit mask of options to Perl. This bit mask operates
- identically for each of the functions. The settings available in the
- bit mask are discussed in <A HREF="#flag values">FLAG VALUES</A>.</P>
- <P>Each of the functions will now be discussed in turn.</P>
- <DL>
- <DT><STRONG><A NAME="item_call_sv">call_sv</A></STRONG><BR>
- <DD>
- <EM>call_sv</EM> takes two parameters, the first, <CODE>sv</CODE>, is an SV*.
- This allows you to specify the Perl subroutine to be called either as a
- C string (which has first been converted to an SV) or a reference to a
- subroutine. The section, <EM>Using call_sv</EM>, shows how you can make
- use of <EM>call_sv</EM>.
- <P></P>
- <DT><STRONG><A NAME="item_call_pv">call_pv</A></STRONG><BR>
- <DD>
- The function, <EM>call_pv</EM>, is similar to <EM>call_sv</EM> except it
- expects its first parameter to be a C char* which identifies the Perl
- subroutine you want to call, e.g., <A HREF="#item_call_pv"><CODE>call_pv("fred", 0)</CODE></A>. If the
- subroutine you want to call is in another package, just include the
- package name in the string, e.g., <CODE>"pkg::fred"</CODE>.
- <P></P>
- <DT><STRONG><A NAME="item_call_method">call_method</A></STRONG><BR>
- <DD>
- The function <EM>call_method</EM> is used to call a method from a Perl
- class. The parameter <CODE>methname</CODE> corresponds to the name of the method
- to be called. Note that the class that the method belongs to is passed
- on the Perl stack rather than in the parameter list. This class can be
- either the name of the class (for a static method) or a reference to an
- object (for a virtual method). See <A HREF="../../lib/Pod/perlobj.html">the perlobj manpage</A> for more information on
- static and virtual methods and <A HREF="#using call_method">Using call_method</A> for an example
- of using <EM>call_method</EM>.
- <P></P>
- <DT><STRONG><A NAME="item_call_argv">call_argv</A></STRONG><BR>
- <DD>
- <EM>call_argv</EM> calls the Perl subroutine specified by the C string
- stored in the <CODE>subname</CODE> parameter. It also takes the usual <CODE>flags</CODE>
- parameter. The final parameter, <CODE>argv</CODE>, consists of a NULL terminated
- list of C strings to be passed as parameters to the Perl subroutine.
- See <EM>Using call_argv</EM>.
- <P></P></DL>
- <P>All the functions return an integer. This is a count of the number of
- items returned by the Perl subroutine. The actual items returned by the
- subroutine are stored on the Perl stack.</P>
- <P>As a general rule you should <EM>always</EM> check the return value from
- these functions. Even if you are expecting only a particular number of
- values to be returned from the Perl subroutine, there is nothing to
- stop someone from doing something unexpected--don't say you haven't
- been warned.</P>
- <P>
- <HR>
- <H1><A NAME="flag values">FLAG VALUES</A></H1>
- <P>The <CODE>flags</CODE> parameter in all the <EM>call_*</EM> functions is a bit mask
- which can consist of any combination of the symbols defined below,
- OR'ed together.</P>
- <P>
- <H2><A NAME="g_void">G_VOID</A></H2>
- <P>Calls the Perl subroutine in a void context.</P>
- <P>This flag has 2 effects:</P>
- <OL>
- <LI>
- It indicates to the subroutine being called that it is executing in
- a void context (if it executes <EM>wantarray</EM> the result will be the
- undefined value).
- <P></P>
- <LI>
- It ensures that nothing is actually returned from the subroutine.
- <P></P></OL>
- <P>The value returned by the <EM>call_*</EM> function indicates how many
- items have been returned by the Perl subroutine - in this case it will
- be 0.</P>
- <P>
- <H2><A NAME="g_scalar">G_SCALAR</A></H2>
- <P>Calls the Perl subroutine in a scalar context. This is the default
- context flag setting for all the <EM>call_*</EM> functions.</P>
- <P>This flag has 2 effects:</P>
- <OL>
- <LI>
- It indicates to the subroutine being called that it is executing in a
- scalar context (if it executes <EM>wantarray</EM> the result will be false).
- <P></P>
- <LI>
- It ensures that only a scalar is actually returned from the subroutine.
- The subroutine can, of course, ignore the <EM>wantarray</EM> and return a
- list anyway. If so, then only the last element of the list will be
- returned.
- <P></P></OL>
- <P>The value returned by the <EM>call_*</EM> function indicates how many
- items have been returned by the Perl subroutine - in this case it will
- be either 0 or 1.</P>
- <P>If 0, then you have specified the G_DISCARD flag.</P>
- <P>If 1, then the item actually returned by the Perl subroutine will be
- stored on the Perl stack - the section <EM>Returning a Scalar</EM> shows how
- to access this value on the stack. Remember that regardless of how
- many items the Perl subroutine returns, only the last one will be
- accessible from the stack - think of the case where only one value is
- returned as being a list with only one element. Any other items that
- were returned will not exist by the time control returns from the
- <EM>call_*</EM> function. The section <EM>Returning a list in a scalar
- context</EM> shows an example of this behavior.</P>
- <P>
- <H2><A NAME="g_array">G_ARRAY</A></H2>
- <P>Calls the Perl subroutine in a list context.</P>
- <P>As with G_SCALAR, this flag has 2 effects:</P>
- <OL>
- <LI>
- It indicates to the subroutine being called that it is executing in an
- array context (if it executes <EM>wantarray</EM> the result will be true).
- <P></P>
- <LI>
- It ensures that all items returned from the subroutine will be
- accessible when control returns from the <EM>call_*</EM> function.
- <P></P></OL>
- <P>The value returned by the <EM>call_*</EM> function indicates how many
- items have been returned by the Perl subroutine.</P>
- <P>If 0, then you have specified the G_DISCARD flag.</P>
- <P>If not 0, then it will be a count of the number of items returned by
- the subroutine. These items will be stored on the Perl stack. The
- section <EM>Returning a list of values</EM> gives an example of using the
- G_ARRAY flag and the mechanics of accessing the returned items from the
- Perl stack.</P>
- <P>
- <H2><A NAME="g_discard">G_DISCARD</A></H2>
- <P>By default, the <EM>call_*</EM> functions place the items returned from
- by the Perl subroutine on the stack. If you are not interested in
- these items, then setting this flag will make Perl get rid of them
- automatically for you. Note that it is still possible to indicate a
- context to the Perl subroutine by using either G_SCALAR or G_ARRAY.</P>
- <P>If you do not set this flag then it is <EM>very</EM> important that you make
- sure that any temporaries (i.e., parameters passed to the Perl
- subroutine and values returned from the subroutine) are disposed of
- yourself. The section <EM>Returning a Scalar</EM> gives details of how to
- dispose of these temporaries explicitly and the section <EM>Using Perl to
- dispose of temporaries</EM> discusses the specific circumstances where you
- can ignore the problem and let Perl deal with it for you.</P>
- <P>
- <H2><A NAME="g_noargs">G_NOARGS</A></H2>
- <P>Whenever a Perl subroutine is called using one of the <EM>call_*</EM>
- functions, it is assumed by default that parameters are to be passed to
- the subroutine. If you are not passing any parameters to the Perl
- subroutine, you can save a bit of time by setting this flag. It has
- the effect of not creating the <CODE>@_</CODE> array for the Perl subroutine.</P>
- <P>Although the functionality provided by this flag may seem
- straightforward, it should be used only if there is a good reason to do
- so. The reason for being cautious is that even if you have specified
- the G_NOARGS flag, it is still possible for the Perl subroutine that
- has been called to think that you have passed it parameters.</P>
- <P>In fact, what can happen is that the Perl subroutine you have called
- can access the <CODE>@_</CODE> array from a previous Perl subroutine. This will
- occur when the code that is executing the <EM>call_*</EM> function has
- itself been called from another Perl subroutine. The code below
- illustrates this</P>
- <PRE>
- sub fred
- { print "@_\n" }</PRE>
- <PRE>
- sub joe
- { &fred }</PRE>
- <PRE>
- &joe(1,2,3) ;</PRE>
- <P>This will print</P>
- <PRE>
- 1 2 3</PRE>
- <P>What has happened is that <CODE>fred</CODE> accesses the <CODE>@_</CODE> array which
- belongs to <CODE>joe</CODE>.</P>
- <P>
- <H2><A NAME="g_eval">G_EVAL</A></H2>
- <P>It is possible for the Perl subroutine you are calling to terminate
- abnormally, e.g., by calling <EM>die</EM> explicitly or by not actually
- existing. By default, when either of these events occurs, the
- process will terminate immediately. If you want to trap this
- type of event, specify the G_EVAL flag. It will put an <EM>eval { }</EM>
- around the subroutine call.</P>
- <P>Whenever control returns from the <EM>call_*</EM> function you need to
- check the <CODE>$@</CODE> variable as you would in a normal Perl script.</P>
- <P>The value returned from the <EM>call_*</EM> function is dependent on
- what other flags have been specified and whether an error has
- occurred. Here are all the different cases that can occur:</P>
- <UL>
- <LI>
- If the <EM>call_*</EM> function returns normally, then the value
- returned is as specified in the previous sections.
- <P></P>
- <LI>
- If G_DISCARD is specified, the return value will always be 0.
- <P></P>
- <LI>
- If G_ARRAY is specified <EM>and</EM> an error has occurred, the return value
- will always be 0.
- <P></P>
- <LI>
- If G_SCALAR is specified <EM>and</EM> an error has occurred, the return value
- will be 1 and the value on the top of the stack will be <EM>undef</EM>. This
- means that if you have already detected the error by checking <CODE>$@</CODE> and
- you want the program to continue, you must remember to pop the <EM>undef</EM>
- from the stack.
- <P></P></UL>
- <P>See <EM>Using G_EVAL</EM> for details on using G_EVAL.</P>
- <P>
- <H2><A NAME="g_keeperr">G_KEEPERR</A></H2>
- <P>You may have noticed that using the G_EVAL flag described above will
- <STRONG>always</STRONG> clear the <CODE>$@</CODE> variable and set it to a string describing
- the error iff there was an error in the called code. This unqualified
- resetting of <CODE>$@</CODE> can be problematic in the reliable identification of
- errors using the <A HREF="../../lib/Pod/perlfunc.html#item_eval"><CODE>eval {}</CODE></A> mechanism, because the possibility exists
- that perl will call other code (end of block processing code, for
- example) between the time the error causes <CODE>$@</CODE> to be set within
- <A HREF="../../lib/Pod/perlfunc.html#item_eval"><CODE>eval {}</CODE></A>, and the subsequent statement which checks for the value of
- <CODE>$@</CODE> gets executed in the user's script.</P>
- <P>This scenario will mostly be applicable to code that is meant to be
- called from within destructors, asynchronous callbacks, signal
- handlers, <CODE>__DIE__</CODE> or <CODE>__WARN__</CODE> hooks, and <A HREF="../../lib/Pod/perlfunc.html#item_tie"><CODE>tie</CODE></A> functions. In
- such situations, you will not want to clear <CODE>$@</CODE> at all, but simply to
- append any new errors to any existing value of <CODE>$@</CODE>.</P>
- <P>The G_KEEPERR flag is meant to be used in conjunction with G_EVAL in
- <EM>call_*</EM> functions that are used to implement such code. This flag
- has no effect when G_EVAL is not used.</P>
- <P>When G_KEEPERR is used, any errors in the called code will be prefixed
- with the string ``\t(in cleanup)'', and appended to the current value
- of <CODE>$@</CODE>.</P>
- <P>The G_KEEPERR flag was introduced in Perl version 5.002.</P>
- <P>See <EM>Using G_KEEPERR</EM> for an example of a situation that warrants the
- use of this flag.</P>
- <P>
- <H2><A NAME="determining the context">Determining the Context</A></H2>
- <P>As mentioned above, you can determine the context of the currently
- executing subroutine in Perl with <EM>wantarray</EM>. The equivalent test
- can be made in C by using the <CODE>GIMME_V</CODE> macro, which returns
- <CODE>G_ARRAY</CODE> if you have been called in an array context, <CODE>G_SCALAR</CODE> if
- in a scalar context, or <CODE>G_VOID</CODE> if in a void context (i.e. the
- return value will not be used). An older version of this macro is
- called <CODE>GIMME</CODE>; in a void context it returns <CODE>G_SCALAR</CODE> instead of
- <CODE>G_VOID</CODE>. An example of using the <CODE>GIMME_V</CODE> macro is shown in
- section <EM>Using GIMME_V</EM>.</P>
- <P>
- <HR>
- <H1><A NAME="known problems">KNOWN PROBLEMS</A></H1>
- <P>This section outlines all known problems that exist in the
- <EM>call_*</EM> functions.</P>
- <OL>
- <LI>
- If you are intending to make use of both the G_EVAL and G_SCALAR flags
- in your code, use a version of Perl greater than 5.000. There is a bug
- in version 5.000 of Perl which means that the combination of these two
- flags will not work as described in the section <EM>FLAG VALUES</EM>.
- <P>Specifically, if the two flags are used when calling a subroutine and
- that subroutine does not call <EM>die</EM>, the value returned by
- <EM>call_*</EM> will be wrong.</P>
- <P></P>
- <LI>
- In Perl 5.000 and 5.001 there is a problem with using <EM>call_*</EM> if
- the Perl sub you are calling attempts to trap a <EM>die</EM>.
- <P>The symptom of this problem is that the called Perl sub will continue
- to completion, but whenever it attempts to pass control back to the
- XSUB, the program will immediately terminate.</P>
- <P>For example, say you want to call this Perl sub</P>
- <PRE>
- sub fred
- {
- eval { die "Fatal Error" ; }
- print "Trapped error: $@\n"
- if $@ ;
- }</PRE>
- <P>via this XSUB</P>
- <PRE>
- void
- Call_fred()
- CODE:
- PUSHMARK(SP) ;
- call_pv("fred", G_DISCARD|G_NOARGS) ;
- fprintf(stderr, "back in Call_fred\n") ;</PRE>
- <P>When <CODE>Call_fred</CODE> is executed it will print</P>
- <PRE>
- Trapped error: Fatal Error</PRE>
- <P>As control never returns to <CODE>Call_fred</CODE>, the <CODE>"back in Call_fred"</CODE>
- string will not get printed.</P>
- <P>To work around this problem, you can either upgrade to Perl 5.002 or
- higher, or use the G_EVAL flag with <EM>call_*</EM> as shown below</P>
- <PRE>
- void
- Call_fred()
- CODE:
- PUSHMARK(SP) ;
- call_pv("fred", G_EVAL|G_DISCARD|G_NOARGS) ;
- fprintf(stderr, "back in Call_fred\n") ;</PRE>
- <P></P></OL>
- <P>
- <HR>
- <H1><A NAME="examples">EXAMPLES</A></H1>
- <P>Enough of the definition talk, let's have a few examples.</P>
- <P>Perl provides many macros to assist in accessing the Perl stack.
- Wherever possible, these macros should always be used when interfacing
- to Perl internals. We hope this should make the code less vulnerable
- to any changes made to Perl in the future.</P>
- <P>Another point worth noting is that in the first series of examples I
- have made use of only the <EM>call_pv</EM> function. This has been done
- to keep the code simpler and ease you into the topic. Wherever
- possible, if the choice is between using <EM>call_pv</EM> and
- <EM>call_sv</EM>, you should always try to use <EM>call_sv</EM>. See
- <EM>Using call_sv</EM> for details.</P>
- <P>
- <H2><A NAME="no parameters, nothing returned">No Parameters, Nothing returned</A></H2>
- <P>This first trivial example will call a Perl subroutine, <EM>PrintUID</EM>, to
- print out the UID of the process.</P>
- <PRE>
- sub PrintUID
- {
- print "UID is $<\n" ;
- }</PRE>
- <P>and here is a C function to call it</P>
- <PRE>
- static void
- call_PrintUID()
- {
- dSP ;</PRE>
- <PRE>
- PUSHMARK(SP) ;
- call_pv("PrintUID", G_DISCARD|G_NOARGS) ;
- }</PRE>
- <P>Simple, eh.</P>
- <P>A few points to note about this example.</P>
- <OL>
- <LI>
- Ignore <CODE>dSP</CODE> and <CODE>PUSHMARK(SP)</CODE> for now. They will be discussed in
- the next example.
- <P></P>
- <LI>
- We aren't passing any parameters to <EM>PrintUID</EM> so G_NOARGS can be
- specified.
- <P></P>
- <LI>
- We aren't interested in anything returned from <EM>PrintUID</EM>, so
- G_DISCARD is specified. Even if <EM>PrintUID</EM> was changed to
- return some value(s), having specified G_DISCARD will mean that they
- will be wiped by the time control returns from <EM>call_pv</EM>.
- <P></P>
- <LI>
- As <EM>call_pv</EM> is being used, the Perl subroutine is specified as a
- C string. In this case the subroutine name has been 'hard-wired' into the
- code.
- <P></P>
- <LI>
- Because we specified G_DISCARD, it is not necessary to check the value
- returned from <EM>call_pv</EM>. It will always be 0.
- <P></P></OL>
- <P>
- <H2><A NAME="passing parameters">Passing Parameters</A></H2>
- <P>Now let's make a slightly more complex example. This time we want to
- call a Perl subroutine, <CODE>LeftString</CODE>, which will take 2 parameters--a
- string ($s) and an integer ($n). The subroutine will simply
- print the first $n characters of the string.</P>
- <P>So the Perl subroutine would look like this</P>
- <PRE>
- sub LeftString
- {
- my($s, $n) = @_ ;
- print substr($s, 0, $n), "\n" ;
- }</PRE>
- <P>The C function required to call <EM>LeftString</EM> would look like this.</P>
- <PRE>
- static void
- call_LeftString(a, b)
- char * a ;
- int b ;
- {
- dSP ;</PRE>
- <PRE>
- ENTER ;
- SAVETMPS ;</PRE>
- <PRE>
- PUSHMARK(SP) ;
- XPUSHs(sv_2mortal(newSVpv(a, 0)));
- XPUSHs(sv_2mortal(newSViv(b)));
- PUTBACK ;</PRE>
- <PRE>
- call_pv("LeftString", G_DISCARD);</PRE>
- <PRE>
- FREETMPS ;
- LEAVE ;
- }</PRE>
- <P>Here are a few notes on the C function <EM>call_LeftString</EM>.</P>
- <OL>
- <LI>
- Parameters are passed to the Perl subroutine using the Perl stack.
- This is the purpose of the code beginning with the line <CODE>dSP</CODE> and
- ending with the line <CODE>PUTBACK</CODE>. The <CODE>dSP</CODE> declares a local copy
- of the stack pointer. This local copy should <STRONG>always</STRONG> be accessed
- as <CODE>SP</CODE>.
- <P></P>
- <LI>
- If you are going to put something onto the Perl stack, you need to know
- where to put it. This is the purpose of the macro <CODE>dSP</CODE>--it declares
- and initializes a <EM>local</EM> copy of the Perl stack pointer.
- <P>All the other macros which will be used in this example require you to
- have used this macro.</P>
- <P>The exception to this rule is if you are calling a Perl subroutine
- directly from an XSUB function. In this case it is not necessary to
- use the <CODE>dSP</CODE> macro explicitly--it will be declared for you
- automatically.</P>
- <P></P>
- <LI>
- Any parameters to be pushed onto the stack should be bracketed by the
- <CODE>PUSHMARK</CODE> and <CODE>PUTBACK</CODE> macros. The purpose of these two macros, in
- this context, is to count the number of parameters you are
- pushing automatically. Then whenever Perl is creating the <CODE>@_</CODE> array for the
- subroutine, it knows how big to make it.
- <P>The <CODE>PUSHMARK</CODE> macro tells Perl to make a mental note of the current
- stack pointer. Even if you aren't passing any parameters (like the
- example shown in the section <EM>No Parameters, Nothing returned</EM>) you
- must still call the <CODE>PUSHMARK</CODE> macro before you can call any of the
- <EM>call_*</EM> functions--Perl still needs to know that there are no
- parameters.</P>
- <P>The <CODE>PUTBACK</CODE> macro sets the global copy of the stack pointer to be
- the same as our local copy. If we didn't do this <EM>call_pv</EM>
- wouldn't know where the two parameters we pushed were--remember that
- up to now all the stack pointer manipulation we have done is with our
- local copy, <EM>not</EM> the global copy.</P>
- <P></P>
- <LI>
- The only flag specified this time is G_DISCARD. Because we are passing 2
- parameters to the Perl subroutine this time, we have not specified
- G_NOARGS.
- <P></P>
- <LI>
- Next, we come to XPUSHs. This is where the parameters actually get
- pushed onto the stack. In this case we are pushing a string and an
- integer.
- <P>See <A HREF="../../lib/Pod/perlguts.html#xsubs and the argument stack">XSUBs and the Argument Stack in the perlguts manpage</A> for details
- on how the XPUSH macros work.</P>
- <P></P>
- <LI>
- Because we created temporary values (by means of <CODE>sv_2mortal()</CODE> calls)
- we will have to tidy up the Perl stack and dispose of mortal SVs.
- <P>This is the purpose of</P>
- <PRE>
- ENTER ;
- SAVETMPS ;</PRE>
- <P>at the start of the function, and</P>
- <PRE>
- FREETMPS ;
- LEAVE ;</PRE>
- <P>at the end. The <CODE>ENTER</CODE>/<CODE>SAVETMPS</CODE> pair creates a boundary for any
- temporaries we create. This means that the temporaries we get rid of
- will be limited to those which were created after these calls.</P>
- <P>The <CODE>FREETMPS</CODE>/<CODE>LEAVE</CODE> pair will get rid of any values returned by
- the Perl subroutine (see next example), plus it will also dump the
- mortal SVs we have created. Having <CODE>ENTER</CODE>/<CODE>SAVETMPS</CODE> at the
- beginning of the code makes sure that no other mortals are destroyed.</P>
- <P>Think of these macros as working a bit like using <CODE>{</CODE> and <CODE>}</CODE> in Perl
- to limit the scope of local variables.</P>
- <P>See the section <EM>Using Perl to dispose of temporaries</EM> for details of
- an alternative to using these macros.</P>
- <P></P>
- <LI>
- Finally, <EM>LeftString</EM> can now be called via the <EM>call_pv</EM>
- function.
- <P></P></OL>
- <P>
- <H2><A NAME="returning a scalar">Returning a Scalar</A></H2>
- <P>Now for an example of dealing with the items returned from a Perl
- subroutine.</P>
- <P>Here is a Perl subroutine, <EM>Adder</EM>, that takes 2 integer parameters
- and simply returns their sum.</P>
- <PRE>
- sub Adder
- {
- my($a, $b) = @_ ;
- $a + $b ;
- }</PRE>
- <P>Because we are now concerned with the return value from <EM>Adder</EM>, the C
- function required to call it is now a bit more complex.</P>
- <PRE>
- static void
- call_Adder(a, b)
- int a ;
- int b ;
- {
- dSP ;
- int count ;</PRE>
- <PRE>
- ENTER ;
- SAVETMPS;</PRE>
- <PRE>
- PUSHMARK(SP) ;
- XPUSHs(sv_2mortal(newSViv(a)));
- XPUSHs(sv_2mortal(newSViv(b)));
- PUTBACK ;</PRE>
- <PRE>
- count = call_pv("Adder", G_SCALAR);</PRE>
- <PRE>
- SPAGAIN ;</PRE>
- <PRE>
- if (count != 1)
- croak("Big trouble\n") ;</PRE>
- <PRE>
- printf ("The sum of %d and %d is %d\n", a, b, POPi) ;</PRE>
- <PRE>
- PUTBACK ;
- FREETMPS ;
- LEAVE ;
- }</PRE>
- <P>Points to note this time are</P>
- <OL>
- <LI>
- The only flag specified this time was G_SCALAR. That means the <CODE>@_</CODE>
- array will be created and that the value returned by <EM>Adder</EM> will
- still exist after the call to <EM>call_pv</EM>.
- <P></P>
- <LI>
- The purpose of the macro <CODE>SPAGAIN</CODE> is to refresh the local copy of the
- stack pointer. This is necessary because it is possible that the memory
- allocated to the Perl stack has been reallocated whilst in the
- <EM>call_pv</EM> call.
- <P>If you are making use of the Perl stack pointer in your code you must
- always refresh the local copy using SPAGAIN whenever you make use
- of the <EM>call_*</EM> functions or any other Perl internal function.</P>
- <P></P>
- <LI>
- Although only a single value was expected to be returned from <EM>Adder</EM>,
- it is still good practice to check the return code from <EM>call_pv</EM>
- anyway.
- <P>Expecting a single value is not quite the same as knowing that there
- will be one. If someone modified <EM>Adder</EM> to return a list and we
- didn't check for that possibility and take appropriate action the Perl
- stack would end up in an inconsistent state. That is something you
- <EM>really</EM> don't want to happen ever.</P>
- <P></P>
- <LI>
- The <CODE>POPi</CODE> macro is used here to pop the return value from the stack.
- In this case we wanted an integer, so <CODE>POPi</CODE> was used.
- <P>Here is the complete list of POP macros available, along with the types
- they return.</P>
- <PRE>
- POPs SV
- POPp pointer
- POPn double
- POPi integer
- POPl long</PRE>
- <P></P>
- <LI>
- The final <CODE>PUTBACK</CODE> is used to leave the Perl stack in a consistent
- state before exiting the function. This is necessary because when we
- popped the return value from the stack with <CODE>POPi</CODE> it updated only our
- local copy of the stack pointer. Remember, <CODE>PUTBACK</CODE> sets the global
- stack pointer to be the same as our local copy.
- <P></P></OL>
- <P>
- <H2><A NAME="returning a list of values">Returning a list of values</A></H2>
- <P>Now, let's extend the previous example to return both the sum of the
- parameters and the difference.</P>
- <P>Here is the Perl subroutine</P>
- <PRE>
- sub AddSubtract
- {
- my($a, $b) = @_ ;
- ($a+$b, $a-$b) ;
- }</PRE>
- <P>and this is the C function</P>
- <PRE>
- static void
- call_AddSubtract(a, b)
- int a ;
- int b ;
- {
- dSP ;
- int count ;</PRE>
- <PRE>
- ENTER ;
- SAVETMPS;</PRE>
- <PRE>
- PUSHMARK(SP) ;
- XPUSHs(sv_2mortal(newSViv(a)));
- XPUSHs(sv_2mortal(newSViv(b)));
- PUTBACK ;</PRE>
- <PRE>
- count = call_pv("AddSubtract", G_ARRAY);</PRE>
- <PRE>
- SPAGAIN ;</PRE>
- <PRE>
- if (count != 2)
- croak("Big trouble\n") ;</PRE>
- <PRE>
- printf ("%d - %d = %d\n", a, b, POPi) ;
- printf ("%d + %d = %d\n", a, b, POPi) ;</PRE>
- <PRE>
- PUTBACK ;
- FREETMPS ;
- LEAVE ;
- }</PRE>
- <P>If <EM>call_AddSubtract</EM> is called like this</P>
- <PRE>
- call_AddSubtract(7, 4) ;</PRE>
- <P>then here is the output</P>
- <PRE>
- 7 - 4 = 3
- 7 + 4 = 11</PRE>
- <P>Notes</P>
- <OL>
- <LI>
- We wanted array context, so G_ARRAY was used.
- <P></P>
- <LI>
- Not surprisingly <CODE>POPi</CODE> is used twice this time because we were
- retrieving 2 values from the stack. The important thing to note is that
- when using the <CODE>POP*</CODE> macros they come off the stack in <EM>reverse</EM>
- order.
- <P></P></OL>
- <P>
- <H2><A NAME="returning a list in a scalar context">Returning a list in a scalar context</A></H2>
- <P>Say the Perl subroutine in the previous section was called in a scalar
- context, like this</P>
- <PRE>
- static void
- call_AddSubScalar(a, b)
- int a ;
- int b ;
- {
- dSP ;
- int count ;
- int i ;</PRE>
- <PRE>
- ENTER ;
- SAVETMPS;</PRE>
- <PRE>
- PUSHMARK(SP) ;
- XPUSHs(sv_2mortal(newSViv(a)));
- XPUSHs(sv_2mortal(newSViv(b)));
- PUTBACK ;</PRE>
- <PRE>
- count = call_pv("AddSubtract", G_SCALAR);</PRE>
- <PRE>
- SPAGAIN ;</PRE>
- <PRE>
- printf ("Items Returned = %d\n", count) ;</PRE>
- <PRE>
- for (i = 1 ; i <= count ; ++i)
- printf ("Value %d = %d\n", i, POPi) ;</PRE>
- <PRE>
- PUTBACK ;
- FREETMPS ;
- LEAVE ;
- }</PRE>
- <P>The other modification made is that <EM>call_AddSubScalar</EM> will print the
- number of items returned from the Perl subroutine and their value (for
- simplicity it assumes that they are integer). So if
- <EM>call_AddSubScalar</EM> is called</P>
- <PRE>
- call_AddSubScalar(7, 4) ;</PRE>
- <P>then the output will be</P>
- <PRE>
- Items Returned = 1
- Value 1 = 3</PRE>
- <P>In this case the main point to note is that only the last item in the
- list is returned from the subroutine, <EM>AddSubtract</EM> actually made it back to
- <EM>call_AddSubScalar</EM>.</P>
- <P>
- <H2><A NAME="returning data from perl via the parameter list">Returning Data from Perl via the parameter list</A></H2>
- <P>It is also possible to return values directly via the parameter list -
- whether it is actually desirable to do it is another matter entirely.</P>
- <P>The Perl subroutine, <EM>Inc</EM>, below takes 2 parameters and increments
- each directly.</P>
- <PRE>
- sub Inc
- {
- ++ $_[0] ;
- ++ $_[1] ;
- }</PRE>
- <P>and here is a C function to call it.</P>
- <PRE>
- static void
- call_Inc(a, b)
- int a ;
- int b ;
- {
- dSP ;
- int count ;
- SV * sva ;
- SV * svb ;</PRE>
- <PRE>
- ENTER ;
- SAVETMPS;</PRE>
- <PRE>
- sva = sv_2mortal(newSViv(a)) ;
- svb = sv_2mortal(newSViv(b)) ;</PRE>
- <PRE>
- PUSHMARK(SP) ;
- XPUSHs(sva);
- XPUSHs(svb);
- PUTBACK ;</PRE>
- <PRE>
- count = call_pv("Inc", G_DISCARD);</PRE>
- <PRE>
- if (count != 0)
- croak ("call_Inc: expected 0 values from 'Inc', got %d\n",
- count) ;</PRE>
- <PRE>
- printf ("%d + 1 = %d\n", a, SvIV(sva)) ;
- printf ("%d + 1 = %d\n", b, SvIV(svb)) ;</PRE>
- <PRE>
- FREETMPS ;
- LEAVE ;
- }</PRE>
- <P>To be able to access the two parameters that were pushed onto the stack
- after they return from <EM>call_pv</EM> it is necessary to make a note
- of their addresses--thus the two variables <CODE>sva</CODE> and <CODE>svb</CODE>.</P>
- <P>The reason this is necessary is that the area of the Perl stack which
- held them will very likely have been overwritten by something else by
- the time control returns from <EM>call_pv</EM>.</P>
- <P>
- <H2><A NAME="using g_eval">Using G_EVAL</A></H2>
- <P>Now an example using G_EVAL. Below is a Perl subroutine which computes
- the difference of its 2 parameters. If this would result in a negative
- result, the subroutine calls <EM>die</EM>.</P>
- <PRE>
- sub Subtract
- {
- my ($a, $b) = @_ ;</PRE>
- <PRE>
- die "death can be fatal\n" if $a < $b ;</PRE>
- <PRE>
- $a - $b ;
- }</PRE>
- <P>and some C to call it</P>
- <PRE>
- static void
- call_Subtract(a, b)
- int a ;
- int b ;
- {
- dSP ;
- int count ;</PRE>
- <PRE>
- ENTER ;
- SAVETMPS;</PRE>
- <PRE>
- PUSHMARK(SP) ;
- XPUSHs(sv_2mortal(newSViv(a)));
- XPUSHs(sv_2mortal(newSViv(b)));
- PUTBACK ;</PRE>
- <PRE>
- count = call_pv("Subtract", G_EVAL|G_SCALAR);</PRE>
- <PRE>
- SPAGAIN ;</PRE>
- <PRE>
- /* Check the eval first */
- if (SvTRUE(ERRSV))
- {
- STRLEN n_a;
- printf ("Uh oh - %s\n", SvPV(ERRSV, n_a)) ;
- POPs ;
- }
- else
- {
- if (count != 1)
- croak("call_Subtract: wanted 1 value from 'Subtract', got %d\n",
- count) ;</PRE>
- <PRE>
- printf ("%d - %d = %d\n", a, b, POPi) ;
- }</PRE>
- <PRE>
- PUTBACK ;
- FREETMPS ;
- LEAVE ;
- }</PRE>
- <P>If <EM>call_Subtract</EM> is called thus</P>
- <PRE>
- call_Subtract(4, 5)</PRE>
- <P>the following will be printed</P>
- <PRE>
- Uh oh - death can be fatal</PRE>
- <P>Notes</P>
- <OL>
- <LI>
- We want to be able to catch the <EM>die</EM> so we have used the G_EVAL
- flag. Not specifying this flag would mean that the program would
- terminate immediately at the <EM>die</EM> statement in the subroutine
- <EM>Subtract</EM>.
- <P></P>
- <LI>
- The code
- <PRE>
- if (SvTRUE(ERRSV))
- {
- STRLEN n_a;
- printf ("Uh oh - %s\n", SvPV(ERRSV, n_a)) ;
- POPs ;
- }</PRE>
- <P>is the direct equivalent of this bit of Perl</P>
- <PRE>
- print "Uh oh - $@\n" if $@ ;</PRE>
- <P><CODE>PL_errgv</CODE> is a perl global of type <CODE>GV *</CODE> that points to the
- symbol table entry containing the error. <CODE>ERRSV</CODE> therefore
- refers to the C equivalent of <CODE>$@</CODE>.</P>
- <P></P>
- <LI>
- Note that the stack is popped using <CODE>POPs</CODE> in the block where
- <CODE>SvTRUE(ERRSV)</CODE> is true. This is necessary because whenever a
- <EM>call_*</EM> function invoked with G_EVAL|G_SCALAR returns an error,
- the top of the stack holds the value <EM>undef</EM>. Because we want the
- program to continue after detecting this error, it is essential that
- the stack is tidied up by removing the <EM>undef</EM>.
- <P></P></OL>
- <P>
- <H2><A NAME="using g_keeperr">Using G_KEEPERR</A></H2>
- <P>Consider this rather facetious example, where we have used an XS
- version of the call_Subtract example above inside a destructor:</P>
- <PRE>
- package Foo;
- sub new { bless {}, $_[0] }
- sub Subtract {
- my($a,$b) = @_;
- die "death can be fatal" if $a < $b ;
- $a - $b;
- }
- sub DESTROY { call_Subtract(5, 4); }
- sub foo { die "foo dies"; }</PRE>
- <PRE>
- package main;
- eval { Foo->new->foo };
- print "Saw: $@" if $@; # should be, but isn't</PRE>
- <P>This example will fail to recognize that an error occurred inside the
- <A HREF="../../lib/Pod/perlfunc.html#item_eval"><CODE>eval {}</CODE></A>. Here's why: the call_Subtract code got executed while perl
- was cleaning up temporaries when exiting the eval block, and because
- call_Subtract is implemented with <EM>call_pv</EM> using the G_EVAL
- flag, it promptly reset <CODE>$@</CODE>. This results in the failure of the
- outermost test for <CODE>$@</CODE>, and thereby the failure of the error trap.</P>
- <P>Appending the G_KEEPERR flag, so that the <EM>call_pv</EM> call in
- call_Subtract reads:</P>
- <PRE>
- count = call_pv("Subtract", G_EVAL|G_SCALAR|G_KEEPERR);</PRE>
- <P>will preserve the error and restore reliable error handling.</P>
- <P>
- <H2><A NAME="using call_sv">Using call_sv</A></H2>
- <P>In all the previous examples I have 'hard-wired' the name of the Perl
- subroutine to be called from C. Most of the time though, it is more
- convenient to be able to specify the name of the Perl subroutine from
- within the Perl script.</P>
- <P>Consider the Perl code below</P>
- <PRE>
- sub fred
- {
- print "Hello there\n" ;
- }</PRE>
- <PRE>
- CallSubPV("fred") ;</PRE>
- <P>Here is a snippet of XSUB which defines <EM>CallSubPV</EM>.</P>
- <PRE>
- void
- CallSubPV(name)
- char * name
- CODE:
- PUSHMARK(SP) ;
- call_pv(name, G_DISCARD|G_NOARGS) ;</PRE>
- <P>That is fine as far as it goes. The thing is, the Perl subroutine
- can be specified as only a string. For Perl 4 this was adequate,
- but Perl 5 allows references to subroutines and anonymous subroutines.
- This is where <EM>call_sv</EM> is useful.</P>
- <P>The code below for <EM>CallSubSV</EM> is identical to <EM>CallSubPV</EM> except
- that the <CODE>name</CODE> parameter is now defined as an SV* and we use
- <EM>call_sv</EM> instead of <EM>call_pv</EM>.</P>
- <PRE>
- void
- CallSubSV(name)
- SV * name
- CODE:
- PUSHMARK(SP) ;
- call_sv(name, G_DISCARD|G_NOARGS) ;</PRE>
- <P>Because we are using an SV to call <EM>fred</EM> the following can all be used</P>
- <PRE>
- CallSubSV("fred") ;
- CallSubSV(\&fred) ;
- $ref = \&fred ;
- CallSubSV($ref) ;
- CallSubSV( sub { print "Hello there\n" } ) ;</PRE>
- <P>As you can see, <EM>call_sv</EM> gives you much greater flexibility in
- how you can specify the Perl subroutine.</P>
- <P>You should note that if it is necessary to store the SV (<CODE>name</CODE> in the
- example above) which corresponds to the Perl subroutine so that it can
- be used later in the program, it not enough just to store a copy of the
- pointer to the SV. Say the code above had been like this</P>
- <PRE>
- static SV * rememberSub ;</PRE>
- <PRE>
- void
- SaveSub1(name)
- SV * name
- CODE:
- rememberSub = name ;</PRE>
- <PRE>
- void
- CallSavedSub1()
- CODE:
- PUSHMARK(SP) ;
- call_sv(rememberSub, G_DISCARD|G_NOARGS) ;</PRE>
- <P>The reason this is wrong is that by the time you come to use the
- pointer <CODE>rememberSub</CODE> in <CODE>CallSavedSub1</CODE>, it may or may not still refer
- to the Perl subroutine that was recorded in <CODE>SaveSub1</CODE>. This is
- particularly true for these cases</P>
- <PRE>
- SaveSub1(\&fred) ;
- CallSavedSub1() ;</PRE>
- <PRE>
- SaveSub1( sub { print "Hello there\n" } ) ;
- CallSavedSub1() ;</PRE>
- <P>By the time each of the <CODE>SaveSub1</CODE> statements above have been executed,
- the SV*s which corresponded to the parameters will no longer exist.
- Expect an error message from Perl of the form</P>
- <PRE>
- Can't use an undefined value as a subroutine reference at ...</PRE>
- <P>for each of the <CODE>CallSavedSub1</CODE> lines.</P>
- <P>Similarly, with this code</P>
- <PRE>
- $ref = \&fred ;
- SaveSub1($ref) ;
- $ref = 47 ;
- CallSavedSub1() ;</PRE>
- <P>you can expect one of these messages (which you actually get is dependent on
- the version of Perl you are using)</P>
- <PRE>
- Not a CODE reference at ...
- Undefined subroutine &main::47 called ...</PRE>
- <P>The variable $ref may have referred to the subroutine <CODE>fred</CODE>
- whenever the call to <CODE>SaveSub1</CODE> was made but by the time
- <CODE>CallSavedSub1</CODE> gets called it now holds the number <CODE>47</CODE>. Because we
- saved only a pointer to the original SV in <CODE>SaveSub1</CODE>, any changes to
- $ref will be tracked by the pointer <CODE>rememberSub</CODE>. This means that
- whenever <CODE>CallSavedSub1</CODE> gets called, it will attempt to execute the
- code which is referenced by the SV* <CODE>rememberSub</CODE>. In this case
- though, it now refers to the integer <CODE>47</CODE>, so expect Perl to complain
- loudly.</P>
- <P>A similar but more subtle problem is illustrated with this code</P>
- <PRE>
- $ref = \&fred ;
- SaveSub1($ref) ;
- $ref = \&joe ;
- CallSavedSub1() ;</PRE>
- <P>This time whenever <CODE>CallSavedSub1</CODE> get called it will execute the Perl
- subroutine <CODE>joe</CODE> (assuming it exists) rather than <CODE>fred</CODE> as was
- originally requested in the call to <CODE>SaveSub1</CODE>.</P>
- <P>To get around these problems it is necessary to take a full copy of the
- SV. The code below shows <CODE>SaveSub2</CODE> modified to do that</P>
- <PRE>
- static SV * keepSub = (SV*)NULL ;</PRE>
- <PRE>
- void
- SaveSub2(name)
- SV * name
- CODE:
- /* Take a copy of the callback */
- if (keepSub == (SV*)NULL)
- /* First time, so create a new SV */
- keepSub = newSVsv(name) ;
- else
- /* Been here before, so overwrite */
- SvSetSV(keepSub, name) ;</PRE>
- <PRE>
- void
- CallSavedSub2()
- CODE:
- PUSHMARK(SP) ;
- call_sv(keepSub, G_DISCARD|G_NOARGS) ;</PRE>
- <P>To avoid creating a new SV every time <CODE>SaveSub2</CODE> is called,
- the function first checks to see if it has been called before. If not,
- then space for a new SV is allocated and the reference to the Perl
- subroutine, <CODE>name</CODE> is copied to the variable <CODE>keepSub</CODE> in one
- operation using <CODE>newSVsv</CODE>. Thereafter, whenever <CODE>SaveSub2</CODE> is called
- the existing SV, <CODE>keepSub</CODE>, is overwritten with the new value using
- <CODE>SvSetSV</CODE>.</P>
- <P>
- <H2><A NAME="using call_argv">Using call_argv</A></H2>
- <P>Here is a Perl subroutine which prints whatever parameters are passed
- to it.</P>
- <PRE>
- sub PrintList
- {
- my(@list) = @_ ;</PRE>
- <PRE>
- foreach (@list) { print "$_\n" }
- }</PRE>
- <P>and here is an example of <EM>call_argv</EM> which will call
- <EM>PrintList</EM>.</P>
- <PRE>
- static char * words[] = {"alpha", "beta", "gamma", "delta", NULL} ;</PRE>
- <PRE>
- static void
- call_PrintList()
- {
- dSP ;</PRE>
- <PRE>
- call_argv("PrintList", G_DISCARD, words) ;
- }</PRE>
- <P>Note that it is not necessary to call <CODE>PUSHMARK</CODE> in this instance.
- This is because <EM>call_argv</EM> will do it for you.</P>
- <P>
- <H2><A NAME="using call_method">Using call_method</A></H2>
- <P>Consider the following Perl code</P>
- <PRE>
- {
- package Mine ;</PRE>
- <PRE>
- sub new
- {
- my($type) = shift ;
- bless [@_]
- }</PRE>
- <PRE>
- sub Display
- {
- my ($self, $index) = @_ ;
- print "$index: $$self[$index]\n" ;
- }</PRE>
- <PRE>
- sub PrintID
- {
- my($class) = @_ ;
- print "This is Class $class version 1.0\n" ;
- }
- }</PRE>
- <P>It implements just a very simple class to manage an array. Apart from
- the constructor, <CODE>new</CODE>, it declares methods, one static and one
- virtual. The static method, <CODE>PrintID</CODE>, prints out simply the class
- name and a version number. The virtual method, <CODE>Display</CODE>, prints out a
- single element of the array. Here is an all Perl example of using it.</P>
- <PRE>
- $a = new Mine ('red', 'green', 'blue') ;
- $a->Display(1) ;
- PrintID Mine;</PRE>
- <P>will print</P>
- <PRE>
- 1: green
- This is Class Mine version 1.0</PRE>
- <P>Calling a Perl method from C is fairly straightforward. The following
- things are required</P>
- <UL>
- <LI>
- a reference to the object for a virtual method or the name of the class
- for a static method.
- <P></P>
- <LI>
- the name of the method.
- <P></P>
- <LI>
- any other parameters specific to the method.
- <P></P></UL>
- <P>Here is a simple XSUB which illustrates the mechanics of calling both
- the <CODE>PrintID</CODE> and <CODE>Display</CODE> methods from C.</P>
- <PRE>
- void
- call_Method(ref, method, index)
- SV * ref
- char * method
- int index
- CODE:
- PUSHMARK(SP);
- XPUSHs(ref);
- XPUSHs(sv_2mortal(newSViv(index))) ;
- PUTBACK;</PRE>
- <PRE>
- call_method(method, G_DISCARD) ;</PRE>
- <PRE>
- void
- call_PrintID(class, method)
- char * class
- char * method
- CODE:
- PUSHMARK(SP);
- XPUSHs(sv_2mortal(newSVpv(class, 0))) ;
- PUTBACK;</PRE>
- <PRE>
- call_method(method, G_DISCARD) ;</PRE>
- <P>So the methods <CODE>PrintID</CODE> and <CODE>Display</CODE> can be invoked like this</P>
- <PRE>
- $a = new Mine ('red', 'green', 'blue') ;
- call_Method($a, 'Display', 1) ;
- call_PrintID('Mine', 'PrintID') ;</PRE>
- <P>The only thing to note is that in both the static and virtual methods,
- the method name is not passed via the stack--it is used as the first
- parameter to <EM>call_method</EM>.</P>
- <P>
- <H2><A NAME="using gimme_v">Using GIMME_V</A></H2>
- <P>Here is a trivial XSUB which prints the context in which it is
- currently executing.</P>
- <PRE>
- void
- PrintContext()
- CODE:
- I32 gimme = GIMME_V;
- if (gimme == G_VOID)
- printf ("Context is Void\n") ;
- else if (gimme == G_SCALAR)
- printf ("Context is Scalar\n") ;
- else
- printf ("Context is Array\n") ;</PRE>
- <P>and here is some Perl to test it</P>
- <PRE>
- PrintContext ;
- $a = PrintContext ;
- @a = PrintContext ;</PRE>
- <P>The output from that will be</P>
- <PRE>
- Context is Void
- Context is Scalar
- Context is Array</PRE>
- <P>
- <H2><A NAME="using perl to dispose of temporaries">Using Perl to dispose of temporaries</A></H2>
- <P>In the examples given to date, any temporaries created in the callback
- (i.e., parameters passed on the stack to the <EM>call_*</EM> function or
- values returned via the stack) have been freed by one of these methods</P>
- <UL>
- <LI>
- specifying the G_DISCARD flag with <EM>call_*</EM>.
- <P></P>
- <LI>
- explicitly disposed of using the <CODE>ENTER</CODE>/<CODE>SAVETMPS</CODE> -
- <CODE>FREETMPS</CODE>/<CODE>LEAVE</CODE> pairing.
- <P></P></UL>
- <P>There is another method which can be used, namely letting Perl do it
- for you automatically whenever it regains control after the callback
- has terminated. This is done by simply not using the</P>
- <PRE>
- ENTER ;
- SAVETMPS ;
- ...
- FREETMPS ;
- LEAVE ;</PRE>
- <P>sequence in the callback (and not, of course, specifying the G_DISCARD
- flag).</P>
- <P>If you are going to use this method you have to be aware of a possible
- memory leak which can arise under very specific circumstances. To
- explain these circumstances you need to know a bit about the flow of
- control between Perl and the callback routine.</P>
- <P>The examples given at the start of the document (an error handler and
- an event driven program) are typical of the two main sorts of flow
- control that you are likely to encounter with callbacks. There is a
- very important distinction between them, so pay attention.</P>
- <P>In the first example, an error handler, the flow of control could be as
- follows. You have created an interface to an external library.
- Control can reach the external library like this</P>
- <PRE>
- perl --> XSUB --> external library</PRE>
- <P>Whilst control is in the library, an error condition occurs. You have
- previously set up a Perl callback to handle this situation, so it will
- get executed. Once the callback has finished, control will drop back to
- Perl again. Here is what the flow of control will be like in that
- situation</P>
- <PRE>
- perl --> XSUB --> external library
- ...
- error occurs
- ...
- external library --> call_* --> perl
- |
- perl <-- XSUB <-- external library <-- call_* <----+</PRE>
- <P>After processing of the error using <EM>call_*</EM> is completed,
- control reverts back to Perl more or less immediately.</P>
- <P>In the diagram, the further right you go the more deeply nested the
- scope is. It is only when control is back with perl on the extreme
- left of the diagram that you will have dropped back to the enclosing
- scope and any temporaries you have left hanging around will be freed.</P>
- <P>In the second example, an event driven program, the flow of control
- will be more like this</P>
- <PRE>
- perl --> XSUB --> event handler
- ...
- event handler --> call_* --> perl
- |
- event handler <-- call_* <----+
- ...
- event handler --> call_* --> perl
- |
- event handler <-- call_* <----+
- ...
- event handler --> call_* --> perl
- |
- event handler <-- call_* <----+</PRE>
- <P>In this case the flow of control can consist of only the repeated
- sequence</P>
- <PRE>
- event handler --> call_* --> perl</PRE>
- <P>for practically the complete duration of the program. This means that
- control may <EM>never</EM> drop back to the surrounding scope in Perl at the
- extreme left.</P>
- <P>So what is the big problem? Well, if you are expecting Perl to tidy up
- those temporaries for you, you might be in for a long wait. For Perl
- to dispose of your temporaries, control must drop back to the
- enclosing scope at some stage. In the event driven scenario that may
- never happen. This means that as time goes on, your program will
- create more and more temporaries, none of which will ever be freed. As
- each of these temporaries consumes some memory your program will
- eventually consume all the available memory in your system--kapow!</P>
- <P>So here is the bottom line--if you are sure that control will revert
- back to the enclosing Perl scope fairly quickly after the end of your
- callback, then it isn't absolutely necessary to dispose explicitly of
- any temporaries you may have created. Mind you, if you are at all
- uncertain about what to do, it doesn't do any harm to tidy up anyway.</P>
- <P>
- <H2><A NAME="strategies for storing callback context information">Strategies for storing Callback Context Information</A></H2>
- <P>Potentially one of the trickiest problems to overcome when designing a
- callback interface can be figuring out how to store the mapping between
- the C callback function and the Perl equivalent.</P>
- <P>To help understand why this can be a real problem first consider how a
- callback is set up in an all C environment. Typically a C API will
- provide a function to register a callback. This will expect a pointer
- to a function as one of its parameters. Below is a call to a
- hypothetical function <CODE>register_fatal</CODE> which registers the C function
- to get called when a fatal error occurs.</P>
- <PRE>
- register_fatal(cb1) ;</PRE>
- <P>The single parameter <CODE>cb1</CODE> is a pointer to a function, so you must
- have defined <CODE>cb1</CODE> in your code, say something like this</P>
- <PRE>
- static void
- cb1()
- {
- printf ("Fatal Error\n") ;
- exit(1) ;
- }</PRE>
- <P>Now change that to call a Perl subroutine instead</P>
- <PRE>
- static SV * callback = (SV*)NULL;</PRE>
- <PRE>
- static void
- cb1()
- {
- dSP ;</PRE>
- <PRE>
- PUSHMARK(SP) ;</PRE>
- <PRE>
- /* Call the Perl sub to process the callback */
- call_sv(callback, G_DISCARD) ;
- }</PRE>
- <PRE>
- void
- register_fatal(fn)
- SV * fn
- CODE:
- /* Remember the Perl sub */
- if (callback == (SV*)NULL)
- callback = newSVsv(fn) ;
- else
- SvSetSV(callback, fn) ;</PRE>
- <PRE>
- /* register the callback with the external library */
- register_fatal(cb1) ;</PRE>
- <P>where the Perl equivalent of <CODE>register_fatal</CODE> and the callback it
- registers, <CODE>pcb1</CODE>, might look like this</P>
- <PRE>
- # Register the sub pcb1
- register_fatal(\&pcb1) ;</PRE>
- <PRE>
- sub pcb1
- {
- die "I'm dying...\n" ;
- }</PRE>
- <P>The mapping between the C callback and the Perl equivalent is stored in
- the global variable <CODE>callback</CODE>.</P>
- <P>This will be adequate if you ever need to have only one callback
- registered at any time. An example could be an error handler like the
- code sketched out above. Remember though, repeated calls to
- <CODE>register_fatal</CODE> will replace the previously registered callback
- function with the new one.</P>
- <P>Say for example you want to interface to a library which allows asynchronous
- file i/o. In this case you may be able to register a callback whenever
- a read operation has completed. To be of any use we want to be able to
- call separate Perl subroutines for each file that is opened. As it
- stands, the error handler example above would not be adequate as it
- allows only a single callback to be defined at any time. What we
- require is a means of storing the mapping between the opened file and
- the Perl subroutine we want to be called for that file.</P>
- <P>Say the i/o library has a function <CODE>asynch_read</CODE> which associates a C
- function <CODE>ProcessRead</CODE> with a file handle <CODE>fh</CODE>--this assumes that it
- has also provided some routine to open the file and so obtain the file
- handle.</P>
- <PRE>
- asynch_read(fh, ProcessRead)</PRE>
- <P>This may expect the C <EM>ProcessRead</EM> function of this form</P>
- <PRE>
- void
- ProcessRead(fh, buffer)
- int fh ;
- char * buffer ;
- {
- ...
- }</PRE>
- <P>To provide a Perl interface to this library we need to be able to map
- between the <CODE>fh</CODE> parameter and the Perl subroutine we want called. A
- hash is a convenient mechanism for storing this mapping. The code
- below shows a possible implementation</P>
- <PRE>
- static HV * Mapping = (HV*)NULL ;</PRE>
- <PRE>
- void
- asynch_read(fh, callback)
- int fh
- SV * callback
- CODE:
- /* If the hash doesn't already exist, create it */
- if (Mapping == (HV*)NULL)
- Mapping = newHV() ;</PRE>
- <PRE>
- /* Save the fh -> callback mapping */
- hv_store(Mapping, (char*)&fh, sizeof(fh), newSVsv(callback), 0) ;</PRE>
- <PRE>
- /* Register with the C Library */
- asynch_read(fh, asynch_read_if) ;</PRE>
- <P>and <CODE>asynch_read_if</CODE> could look like this</P>
- <PRE>
- static void
- asynch_read_if(fh, buffer)
- int fh ;
- char * buffer ;
- {
- dSP ;
- SV ** sv ;</PRE>
- <PRE>
- /* Get the callback associated with fh */
- sv = hv_fetch(Mapping, (char*)&fh , sizeof(fh), FALSE) ;
- if (sv == (SV**)NULL)
- croak("Internal error...\n") ;</PRE>
- <PRE>
- PUSHMARK(SP) ;
- XPUSHs(sv_2mortal(newSViv(fh))) ;
- XPUSHs(sv_2mortal(newSVpv(buffer, 0))) ;
- PUTBACK ;</PRE>
- <PRE>
- /* Call the Perl sub */
- call_sv(*sv, G_DISCARD) ;
- }</PRE>
- <P>For completeness, here is <CODE>asynch_close</CODE>. This shows how to remove
- the entry from the hash <CODE>Mapping</CODE>.</P>
- <PRE>
- void
- asynch_close(fh)
- int fh
- CODE:
- /* Remove the entry from the hash */
- (void) hv_delete(Mapping, (char*)&fh, sizeof(fh), G_DISCARD) ;</PRE>
- <PRE>
- /* Now call the real asynch_close */
- asynch_close(fh) ;</PRE>
- <P>So the Perl interface would look like this</P>
- <PRE>
- sub callback1
- {
- my($handle, $buffer) = @_ ;
- }</PRE>
- <PRE>
- # Register the Perl callback
- asynch_read($fh, \&callback1) ;</PRE>
- <PRE>
- asynch_close($fh) ;</PRE>
- <P>The mapping between the C callback and Perl is stored in the global
- hash <CODE>Mapping</CODE> this time. Using a hash has the distinct advantage that
- it allows an unlimited number of callbacks to be registered.</P>
- <P>What if the interface provided by the C callback doesn't contain a
- parameter which allows the file handle to Perl subroutine mapping? Say
- in the asynchronous i/o package, the callback function gets passed only
- the <CODE>buffer</CODE> parameter like this</P>
- <PRE>
- void
- ProcessRead(buffer)
- char * buffer ;
- {
- ...
- }</PRE>
- <P>Without the file handle there is no straightforward way to map from the
- C callback to the Perl subroutine.</P>
- <P>In this case a possible way around this problem is to predefine a
- series of C functions to act as the interface to Perl, thus</P>
- <PRE>
- #define MAX_CB 3
- #define NULL_HANDLE -1
- typedef void (*FnMap)() ;</PRE>
- <PRE>
- struct MapStruct {
- FnMap Function ;
- SV * PerlSub ;
- int Handle ;
- } ;</PRE>
- <PRE>
- static void fn1() ;
- static void fn2() ;
- static void fn3() ;</PRE>
- <PRE>
- static struct MapStruct Map [MAX_CB] =
- {
- { fn1, NULL, NULL_HANDLE },
- { fn2, NULL, NULL_HANDLE },
- { fn3, NULL, NULL_HANDLE }
- } ;</PRE>
- <PRE>
- static void
- Pcb(index, buffer)
- int index ;
- char * buffer ;
- {
- dSP ;</PRE>
- <PRE>
- PUSHMARK(SP) ;
- XPUSHs(sv_2mortal(newSVpv(buffer, 0))) ;
- PUTBACK ;</PRE>
- <PRE>
- /* Call the Perl sub */
- call_sv(Map[index].PerlSub, G_DISCARD) ;
- }</PRE>
- <PRE>
- static void
- fn1(buffer)
- char * buffer ;
- {
- Pcb(0, buffer) ;
- }</PRE>
- <PRE>
- static void
- fn2(buffer)
- char * buffer ;
- {
- Pcb(1, buffer) ;
- }</PRE>
- <PRE>
- static void
- fn3(buffer)
- char * buffer ;
- {
- Pcb(2, buffer) ;
- }</PRE>
- <PRE>
- void
- array_asynch_read(fh, callback)
- int fh
- SV * callback
- CODE:
- int index ;
- int null_index = MAX_CB ;</PRE>
- <PRE>
- /* Find the same handle or an empty entry */
- for (index = 0 ; index < MAX_CB ; ++index)
- {
- if (Map[index].Handle == fh)
- break ;</PRE>
- <PRE>
- if (Map[index].Handle == NULL_HANDLE)
- null_index = index ;
- }</PRE>
- <PRE>
- if (index == MAX_CB && null_index == MAX_CB)
- croak ("Too many callback functions registered\n") ;</PRE>
- <PRE>
- if (index == MAX_CB)
- index = null_index ;</PRE>
- <PRE>
- /* Save the file handle */
- Map[index].Handle = fh ;</PRE>
- <PRE>
- /* Remember the Perl sub */
- if (Map[index].PerlSub == (SV*)NULL)
- Map[index].PerlSub = newSVsv(callback) ;
- else
- SvSetSV(Map[index].PerlSub, callback) ;</PRE>
- <PRE>
- asynch_read(fh, Map[index].Function) ;</PRE>
- <PRE>
- void
- array_asynch_close(fh)
- int fh
- CODE:
- int index ;</PRE>
- <PRE>
- /* Find the file handle */
- for (index = 0; index < MAX_CB ; ++ index)
- if (Map[index].Handle == fh)
- break ;</PRE>
- <PRE>
- if (index == MAX_CB)
- croak ("could not close fh %d\n", fh) ;</PRE>
- <PRE>
- Map[index].Handle = NULL_HANDLE ;
- SvREFCNT_dec(Map[index].PerlSub) ;
- Map[index].PerlSub = (SV*)NULL ;</PRE>
- <PRE>
- asynch_close(fh) ;</PRE>
- <P>In this case the functions <CODE>fn1</CODE>, <CODE>fn2</CODE>, and <CODE>fn3</CODE> are used to
- remember the Perl subroutine to be called. Each of the functions holds
- a separate hard-wired index which is used in the function <CODE>Pcb</CODE> to
- access the <CODE>Map</CODE> array and actually call the Perl subroutine.</P>
- <P>There are some obvious disadvantages with this technique.</P>
- <P>Firstly, the code is considerably more complex than with the previous
- example.</P>
- <P>Secondly, there is a hard-wired limit (in this case 3) to the number of
- callbacks that can exist simultaneously. The only way to increase the
- limit is by modifying the code to add more functions and then
- recompiling. None the less, as long as the number of functions is
- chosen with some care, it is still a workable solution and in some
- cases is the only one available.</P>
- <P>To summarize, here are a number of possible methods for you to consider
- for storing the mapping between C and the Perl callback</P>
- <OL>
- <LI><STRONG><A NAME="item_Ignore_the_problem_%2D_Allow_only_1_callback">Ignore the problem - Allow only 1 callback</A></STRONG><BR>
-
- For a lot of situations, like interfacing to an error handler, this may
- be a perfectly adequate solution.
- <P></P>
- <LI><STRONG><A NAME="item_Create_a_sequence_of_callbacks_%2D_hard_wired_limi">Create a sequence of callbacks - hard wired limit</A></STRONG><BR>
-
- If it is impossible to tell from the parameters passed back from the C
- callback what the context is, then you may need to create a sequence of C
- callback interface functions, and store pointers to each in an array.
- <P></P>
- <LI><STRONG><A NAME="item_Use_a_parameter_to_map_to_the_Perl_callback">Use a parameter to map to the Perl callback</A></STRONG><BR>
-
- A hash is an ideal mechanism to store the mapping between C and Perl.
- <P></P></OL>
- <P>
- <H2><A NAME="alternate stack manipulation">Alternate Stack Manipulation</A></H2>
- <P>Although I have made use of only the <CODE>POP*</CODE> macros to access values
- returned from Perl subroutines, it is also possible to bypass these
- macros and read the stack using the <CODE>ST</CODE> macro (See <A HREF="../../lib/Pod/perlxs.html">the perlxs manpage</A> for a
- full description of the <CODE>ST</CODE> macro).</P>
- <P>Most of the time the <CODE>POP*</CODE> macros should be adequate, the main
- problem with them is that they force you to process the returned values
- in sequence. This may not be the most suitable way to process the
- values in some cases. What we want is to be able to access the stack in
- a random order. The <CODE>ST</CODE> macro as used when coding an XSUB is ideal
- for this purpose.</P>
- <P>The code below is the example given in the section <EM>Returning a list
- of values</EM> recoded to use <CODE>ST</CODE> instead of <CODE>POP*</CODE>.</P>
- <PRE>
- static void
- call_AddSubtract2(a, b)
- int a ;
- int b ;
- {
- dSP ;
- I32 ax ;
- int count ;</PRE>
- <PRE>
- ENTER ;
- SAVETMPS;</PRE>
- <PRE>
- PUSHMARK(SP) ;
- XPUSHs(sv_2mortal(newSViv(a)));
- XPUSHs(sv_2mortal(newSViv(b)));
- PUTBACK ;</PRE>
- <PRE>
- count = call_pv("AddSubtract", G_ARRAY);</PRE>
- <PRE>
- SPAGAIN ;
- SP -= count ;
- ax = (SP - PL_stack_base) + 1 ;</PRE>
- <PRE>
- if (count != 2)
- croak("Big trouble\n") ;</PRE>
- <PRE>
- printf ("%d + %d = %d\n", a, b, SvIV(ST(0))) ;
- printf ("%d - %d = %d\n", a, b, SvIV(ST(1))) ;</PRE>
- <PRE>
- PUTBACK ;
- FREETMPS ;
- LEAVE ;
- }</PRE>
- <P>Notes</P>
- <OL>
- <LI>
- Notice that it was necessary to define the variable <CODE>ax</CODE>. This is
- because the <CODE>ST</CODE> macro expects it to exist. If we were in an XSUB it
- would not be necessary to define <CODE>ax</CODE> as it is already defined for
- you.
- <P></P>
- <LI>
- The code
- <PRE>
- SPAGAIN ;
- SP -= count ;
- ax = (SP - PL_stack_base) + 1 ;</PRE>
- <P>sets the stack up so that we can use the <CODE>ST</CODE> macro.</P>
- <P></P>
- <LI>
- Unlike the original coding of this example, the returned
- values are not accessed in reverse order. So <CODE>ST(0)</CODE> refers to the
- first value returned by the Perl subroutine and <CODE>ST(count-1)</CODE>
- refers to the last.
- <P></P></OL>
- <P>
- <H2><A NAME="creating and calling an anonymous subroutine in c">Creating and calling an anonymous subroutine in C</A></H2>
- <P>As we've already shown, <A HREF="#item_call_sv"><CODE>call_sv</CODE></A> can be used to invoke an
- anonymous subroutine. However, our example showed a Perl script
- invoking an XSUB to perform this operation. Let's see how it can be
- done inside our C code:</P>
- <PRE>
- ...</PRE>
- <PRE>
- SV *cvrv = eval_pv("sub { print 'You will not find me cluttering any namespace!' }", TRUE);</PRE>
- <PRE>
- ...</PRE>
- <PRE>
- call_sv(cvrv, G_VOID|G_NOARGS);</PRE>
- <P><CODE>eval_pv</CODE> is used to compile the anonymous subroutine, which
- will be the return value as well (read more about <CODE>eval_pv</CODE> in
- <A HREF="../../lib/Pod/perlapi.html#eval_pv">eval_pv in the perlapi manpage</A>). Once this code reference is in hand, it
- can be mixed in with all the previous examples we've shown.</P>
- <P>
- <HR>
- <H1><A NAME="see also">SEE ALSO</A></H1>
- <P><A HREF="../../lib/Pod/perlxs.html">the perlxs manpage</A>, <A HREF="../../lib/Pod/perlguts.html">the perlguts manpage</A>, <A HREF="../../lib/Pod/perlembed.html">the perlembed manpage</A></P>
- <P>
- <HR>
- <H1><A NAME="author">AUTHOR</A></H1>
- <P>Paul Marquess</P>
- <P>Special thanks to the following people who assisted in the creation of
- the document.</P>
- <P>Jeff Okamoto, Tim Bunce, Nick Gianniotis, Steve Kelem, Gurusamy Sarathy
- and Larry Wall.</P>
- <P>
- <HR>
- <H1><A NAME="date">DATE</A></H1>
- <P>Version 1.3, 14th Apr 1997</P>
- <TABLE BORDER=0 CELLPADDING=0 CELLSPACING=0 WIDTH=100%>
- <TR><TD CLASS=block VALIGN=MIDDLE WIDTH=100% BGCOLOR="#cccccc">
- <STRONG><P CLASS=block> perlcall - Perl calling conventions from C</P></STRONG>
- </TD></TR>
- </TABLE>
-
- </BODY>
-
- </HTML>
-