From: Lupe Christoph Date: Thu, 9 May 2002 09:42:02 +0000 (+0200) Subject: [Patch] perlxstut.pod X-Git-Url: http://git.shadowcat.co.uk/gitweb/gitweb.cgi?a=commitdiff_plain;h=e8a52a58035b5a0e5584519ecc319d579c024d85;p=p5sagit%2Fp5-mst-13.2.git [Patch] perlxstut.pod Message-Id: <20020509074202.GJ1087@lupe-christoph.de> (Applied with tweaks.) p4raw-id: //depot/perl@16514 --- diff --git a/pod/perlxstut.pod b/pod/perlxstut.pod index c7723af..420e989 100644 --- a/pod/perlxstut.pod +++ b/pod/perlxstut.pod @@ -1229,15 +1229,20 @@ The real work is done in the standard typemap. B you loose all the fine stuff done by the perlio layers. This calls the stdio function C, which knows nothing about them. -For PerlIO *'s, there considered to be three kinds in the -standard typemap C (T_IN), C (T_INOUT) and -C (T_OUT), a bare C is considered a T_INOUT. -If it matters in your code (see below for why it might) #define or typedef -one of the specific names and use that as the type in your XS file. +The standard typemap offers three variants of PerlIO *: +C (T_IN), C (T_INOUT) and C +(T_OUT). A bare C is considered a T_INOUT. If it matters +in your code (see below for why it might) #define or typedef +one of the specific names and use that as the argument or result +type in your XS file. + +The standard typemap does not contain PerlIO * before perl 5.7, +but it has the three stream variants. Using a PerlIO * directly +is not backwards compatible unless you provide your own typemap. For streams coming I perl the main difference is that C will get the output PerlIO * - which may make -a difference on a socket. +a difference on a socket. Like in our example... For streams being handed I perl a new file handle is created (i.e. a reference to a new glob) and associated with the PerlIO * @@ -1272,13 +1277,13 @@ We have to use a C section because C has the arguments reversed compared to C, and we want to keep the arguments the same. Wanting to explore this thoroughly, we want to use the stdio C -on an explicit PerlIO *. This means we have to ask the perlio system -for a stdio C: +on a PerlIO *. This means we have to ask the perlio system for a stdio +C: int perliofputs(s, stream) char * s - PerlIO * stream + OutputStream stream PREINIT: FILE *fp = PerlIO_findFILE(stream); CODE: @@ -1290,10 +1295,6 @@ for a stdio C: OUTPUT: RETVAL -(We also using bare PerlIO * as the type - so we get the I -PerlIO * of a socket - if this is undesirable use typedef or #define -as above.) - Note: C will search the layers for a stdio layer. If it can't find one, it will call C to generate a new stdio C. Please only call C if