diff options
Diffstat (limited to 'upstream/fedora-rawhide/man1/perlapio.1')
-rw-r--r-- | upstream/fedora-rawhide/man1/perlapio.1 | 548 |
1 files changed, 548 insertions, 0 deletions
diff --git a/upstream/fedora-rawhide/man1/perlapio.1 b/upstream/fedora-rawhide/man1/perlapio.1 new file mode 100644 index 00000000..0a2c60f4 --- /dev/null +++ b/upstream/fedora-rawhide/man1/perlapio.1 @@ -0,0 +1,548 @@ +.\" -*- mode: troff; coding: utf-8 -*- +.\" Automatically generated by Pod::Man 5.01 (Pod::Simple 3.43) +.\" +.\" Standard preamble: +.\" ======================================================================== +.de Sp \" Vertical space (when we can't use .PP) +.if t .sp .5v +.if n .sp +.. +.de Vb \" Begin verbatim text +.ft CW +.nf +.ne \\$1 +.. +.de Ve \" End verbatim text +.ft R +.fi +.. +.\" \*(C` and \*(C' are quotes in nroff, nothing in troff, for use with C<>. +.ie n \{\ +. ds C` "" +. ds C' "" +'br\} +.el\{\ +. ds C` +. ds C' +'br\} +.\" +.\" Escape single quotes in literal strings from groff's Unicode transform. +.ie \n(.g .ds Aq \(aq +.el .ds Aq ' +.\" +.\" If the F register is >0, we'll generate index entries on stderr for +.\" titles (.TH), headers (.SH), subsections (.SS), items (.Ip), and index +.\" entries marked with X<> in POD. Of course, you'll have to process the +.\" output yourself in some meaningful fashion. +.\" +.\" Avoid warning from groff about undefined register 'F'. +.de IX +.. +.nr rF 0 +.if \n(.g .if rF .nr rF 1 +.if (\n(rF:(\n(.g==0)) \{\ +. if \nF \{\ +. de IX +. tm Index:\\$1\t\\n%\t"\\$2" +.. +. if !\nF==2 \{\ +. nr % 0 +. nr F 2 +. \} +. \} +.\} +.rr rF +.\" ======================================================================== +.\" +.IX Title "PERLAPIO 1" +.TH PERLAPIO 1 2024-01-25 "perl v5.38.2" "Perl Programmers Reference Guide" +.\" For nroff, turn off justification. Always turn off hyphenation; it makes +.\" way too many mistakes in technical documents. +.if n .ad l +.nh +.SH NAME +perlapio \- perl's IO abstraction interface. +.SH SYNOPSIS +.IX Header "SYNOPSIS" +.Vb 2 +\& #define PERLIO_NOT_STDIO 0 /* For co\-existence with stdio only */ +\& #include <perlio.h> /* Usually via #include <perl.h> */ +\& +\& PerlIO *PerlIO_stdin(void); +\& PerlIO *PerlIO_stdout(void); +\& PerlIO *PerlIO_stderr(void); +\& +\& PerlIO *PerlIO_open(const char *path,const char *mode); +\& PerlIO *PerlIO_fdopen(int fd, const char *mode); +\& PerlIO *PerlIO_reopen(const char *path, /* deprecated */ +\& const char *mode, PerlIO *old); +\& int PerlIO_close(PerlIO *f); +\& +\& int PerlIO_stdoutf(const char *fmt,...) +\& int PerlIO_puts(PerlIO *f,const char *string); +\& int PerlIO_putc(PerlIO *f,int ch); +\& SSize_t PerlIO_write(PerlIO *f,const void *buf,size_t numbytes); +\& int PerlIO_printf(PerlIO *f, const char *fmt,...); +\& int PerlIO_vprintf(PerlIO *f, const char *fmt, va_list args); +\& int PerlIO_flush(PerlIO *f); +\& +\& int PerlIO_fill(PerlIO *f); +\& int PerlIO_eof(PerlIO *f); +\& int PerlIO_error(PerlIO *f); +\& void PerlIO_clearerr(PerlIO *f); +\& +\& int PerlIO_getc(PerlIO *d); +\& int PerlIO_ungetc(PerlIO *f,int ch); +\& SSize_t PerlIO_read(PerlIO *f, void *buf, size_t numbytes); +\& Size_t PerlIO_unread(PerlIO *f,const void *vbuf, size_t count +\& +\& int PerlIO_fileno(PerlIO *f); +\& +\& void PerlIO_setlinebuf(PerlIO *f); +\& +\& Off_t PerlIO_tell(PerlIO *f); +\& int PerlIO_seek(PerlIO *f, Off_t offset, int whence); +\& void PerlIO_rewind(PerlIO *f); +\& +\& int PerlIO_getpos(PerlIO *f, SV *save); /* prototype changed */ +\& int PerlIO_setpos(PerlIO *f, SV *saved); /* prototype changed */ +\& +\& int PerlIO_fast_gets(PerlIO *f); +\& int PerlIO_has_cntptr(PerlIO *f); +\& SSize_t PerlIO_get_cnt(PerlIO *f); +\& char *PerlIO_get_ptr(PerlIO *f); +\& void PerlIO_set_ptrcnt(PerlIO *f, char *ptr, SSize_t count); +\& +\& int PerlIO_canset_cnt(PerlIO *f); /* deprecated */ +\& void PerlIO_set_cnt(PerlIO *f, int count); /* deprecated */ +\& +\& int PerlIO_has_base(PerlIO *f); +\& char *PerlIO_get_base(PerlIO *f); +\& SSize_t PerlIO_get_bufsiz(PerlIO *f); +\& +\& PerlIO *PerlIO_importFILE(FILE *stdio, const char *mode); +\& FILE *PerlIO_exportFILE(PerlIO *f, const char *mode); +\& FILE *PerlIO_findFILE(PerlIO *f); +\& void PerlIO_releaseFILE(PerlIO *f,FILE *stdio); +\& +\& int PerlIO_apply_layers(pTHX_ PerlIO *f, const char *mode, +\& const char *layers); +\& int PerlIO_binmode(pTHX_ PerlIO *f, int ptype, int imode, +\& const char *layers); +\& void PerlIO_debug(const char *fmt,...); +.Ve +.SH DESCRIPTION +.IX Header "DESCRIPTION" +Perl's source code, and extensions that want maximum portability, +should use the above functions instead of those defined in ANSI C's +\&\fIstdio.h\fR. The perl headers (in particular "perlio.h") will +\&\f(CW\*(C`#define\*(C'\fR them to the I/O mechanism selected at Configure time. +.PP +The functions are modeled on those in \fIstdio.h\fR, but parameter order +has been "tidied up a little". +.PP +\&\f(CW\*(C`PerlIO *\*(C'\fR takes the place of FILE *. Like FILE * it should be +treated as opaque (it is probably safe to assume it is a pointer to +something). +.PP +There are currently two implementations: +.IP "1. USE_STDIO" 4 +.IX Item "1. USE_STDIO" +All above are #define'd to stdio functions or are trivial wrapper +functions which call stdio. In this case \fIonly\fR PerlIO * is a FILE *. +This has been the default implementation since the abstraction was +introduced in perl5.003_02. +.IP "2. USE_PERLIO" 4 +.IX Item "2. USE_PERLIO" +Introduced just after perl5.7.0, this is a re-implementation of the +above abstraction which allows perl more control over how IO is done +as it decouples IO from the way the operating system and C library +choose to do things. For USE_PERLIO PerlIO * has an extra layer of +indirection \- it is a pointer-to-a-pointer. This allows the PerlIO * +to remain with a known value while swapping the implementation around +underneath \fIat run time\fR. In this case all the above are true (but +very simple) functions which call the underlying implementation. +.Sp +This is the only implementation for which \f(CWPerlIO_apply_layers()\fR +does anything "interesting". +.Sp +The USE_PERLIO implementation is described in perliol. +.PP +Because "perlio.h" is a thin layer (for efficiency) the semantics of +these functions are somewhat dependent on the underlying implementation. +Where these variations are understood they are noted below. +.PP +Unless otherwise noted, functions return 0 on success, or a negative +value (usually \f(CW\*(C`EOF\*(C'\fR which is usually \-1) and set \f(CW\*(C`errno\*(C'\fR on error. +.IP "\fBPerlIO_stdin()\fR, \fBPerlIO_stdout()\fR, \fBPerlIO_stderr()\fR" 4 +.IX Item "PerlIO_stdin(), PerlIO_stdout(), PerlIO_stderr()" +Use these rather than \f(CW\*(C`stdin\*(C'\fR, \f(CW\*(C`stdout\*(C'\fR, \f(CW\*(C`stderr\*(C'\fR. They are written +to look like "function calls" rather than variables because this makes +it easier to \fImake them\fR function calls if platform cannot export data +to loaded modules, or if (say) different "threads" might have different +values. +.IP "\fBPerlIO_open(path, mode)\fR, \fBPerlIO_fdopen(fd,mode)\fR" 4 +.IX Item "PerlIO_open(path, mode), PerlIO_fdopen(fd,mode)" +These correspond to \fBfopen()\fR/\fBfdopen()\fR and the arguments are the same. +Return \f(CW\*(C`NULL\*(C'\fR and set \f(CW\*(C`errno\*(C'\fR if there is an error. There may be an +implementation limit on the number of open handles, which may be lower +than the limit on the number of open files \- \f(CW\*(C`errno\*(C'\fR may not be set +when \f(CW\*(C`NULL\*(C'\fR is returned if this limit is exceeded. +.IP \fBPerlIO_reopen(path,mode,f)\fR 4 +.IX Item "PerlIO_reopen(path,mode,f)" +While this currently exists in both implementations, perl itself +does not use it. \fIAs perl does not use it, it is not well tested.\fR +.Sp +Perl prefers to \f(CW\*(C`dup\*(C'\fR the new low-level descriptor to the descriptor +used by the existing PerlIO. This may become the behaviour of this +function in the future. +.IP "\fBPerlIO_printf(f,fmt,...)\fR, \fBPerlIO_vprintf(f,fmt,a)\fR" 4 +.IX Item "PerlIO_printf(f,fmt,...), PerlIO_vprintf(f,fmt,a)" +These are \fBfprintf()\fR/\fBvfprintf()\fR equivalents. +.IP \fBPerlIO_stdoutf(fmt,...)\fR 4 +.IX Item "PerlIO_stdoutf(fmt,...)" +This is \fBprintf()\fR equivalent. printf is #defined to this function, +so it is (currently) legal to use \f(CW\*(C`printf(fmt,...)\*(C'\fR in perl sources. +.IP "\fBPerlIO_read(f,buf,count)\fR, \fBPerlIO_write(f,buf,count)\fR" 4 +.IX Item "PerlIO_read(f,buf,count), PerlIO_write(f,buf,count)" +These correspond functionally to \fBfread()\fR and \fBfwrite()\fR but the +arguments and return values are different. The \fBPerlIO_read()\fR and +\&\fBPerlIO_write()\fR signatures have been modeled on the more sane low level +\&\fBread()\fR and \fBwrite()\fR functions instead: The "file" argument is passed +first, there is only one "count", and the return value can distinguish +between error and \f(CW\*(C`EOF\*(C'\fR. +.Sp +Returns a byte count if successful (which may be zero or +positive), returns negative value and sets \f(CW\*(C`errno\*(C'\fR on error. +Depending on implementation \f(CW\*(C`errno\*(C'\fR may be \f(CW\*(C`EINTR\*(C'\fR if operation was +interrupted by a signal. +.IP \fBPerlIO_fill(f)\fR 4 +.IX Item "PerlIO_fill(f)" +Fills the buffer associated with \f(CW\*(C`f\*(C'\fR with data from the layer below. +\&\f(CW\*(C`PerlIO_read\*(C'\fR calls this as part of its normal operation. Returns 0 +upon success; \-1 on failure. +.IP \fBPerlIO_close(f)\fR 4 +.IX Item "PerlIO_close(f)" +Depending on implementation \f(CW\*(C`errno\*(C'\fR may be \f(CW\*(C`EINTR\*(C'\fR if operation was +interrupted by a signal. +.IP "\fBPerlIO_puts(f,s)\fR, \fBPerlIO_putc(f,c)\fR" 4 +.IX Item "PerlIO_puts(f,s), PerlIO_putc(f,c)" +These correspond to \fBfputs()\fR and \fBfputc()\fR. +Note that arguments have been revised to have "file" first. +.IP \fBPerlIO_ungetc(f,c)\fR 4 +.IX Item "PerlIO_ungetc(f,c)" +This corresponds to \fBungetc()\fR. Note that arguments have been revised +to have "file" first. Arranges that next read operation will return +the byte \fBc\fR. Despite the implied "character" in the name only +values in the range 0..0xFF are defined. Returns the byte \fBc\fR on +success or \-1 (\f(CW\*(C`EOF\*(C'\fR) on error. The number of bytes that can be +"pushed back" may vary, only 1 character is certain, and then only if +it is the last character that was read from the handle. +.IP \fBPerlIO_unread(f,buf,count)\fR 4 +.IX Item "PerlIO_unread(f,buf,count)" +This allows one to unget more than a single byte. +It effectively unshifts \f(CW\*(C`count\*(C'\fR bytes onto the beginning of the buffer +\&\f(CW\*(C`buf\*(C'\fR, so that the next read operation(s) will return them before +anything else that was in the buffer. +.Sp +Returns the number of unread bytes. +.IP \fBPerlIO_getc(f)\fR 4 +.IX Item "PerlIO_getc(f)" +This corresponds to \fBgetc()\fR. +Despite the c in the name only byte range 0..0xFF is supported. +Returns the character read or \-1 (\f(CW\*(C`EOF\*(C'\fR) on error. +.IP \fBPerlIO_eof(f)\fR 4 +.IX Item "PerlIO_eof(f)" +This corresponds to \fBfeof()\fR. Returns a true/false indication of +whether the handle is at end of file. For terminal devices this may +or may not be "sticky" depending on the implementation. The flag is +cleared by \fBPerlIO_seek()\fR, or \fBPerlIO_rewind()\fR. +.IP \fBPerlIO_error(f)\fR 4 +.IX Item "PerlIO_error(f)" +This corresponds to \fBferror()\fR. Returns a true/false indication of +whether there has been an IO error on the handle. +.IP \fBPerlIO_fileno(f)\fR 4 +.IX Item "PerlIO_fileno(f)" +This corresponds to \fBfileno()\fR, note that on some platforms, the meaning +of "fileno" may not match Unix. Returns \-1 if the handle has no open +descriptor associated with it. +.IP \fBPerlIO_clearerr(f)\fR 4 +.IX Item "PerlIO_clearerr(f)" +This corresponds to \fBclearerr()\fR, i.e., clears 'error' and (usually) +\&'eof' flags for the "stream". Does not return a value. +.IP \fBPerlIO_flush(f)\fR 4 +.IX Item "PerlIO_flush(f)" +This corresponds to \fBfflush()\fR. Sends any buffered write data to the +underlying file. If called with \f(CW\*(C`NULL\*(C'\fR this may flush all open +streams (or core dump with some USE_STDIO implementations). Calling +on a handle open for read only, or on which last operation was a read +of some kind may lead to undefined behaviour on some USE_STDIO +implementations. The USE_PERLIO (layers) implementation tries to +behave better: it flushes all open streams when passed \f(CW\*(C`NULL\*(C'\fR, and +attempts to retain data on read streams either in the buffer or by +seeking the handle to the current logical position. +.IP \fBPerlIO_seek(f,offset,whence)\fR 4 +.IX Item "PerlIO_seek(f,offset,whence)" +This corresponds to \fBfseek()\fR. Sends buffered write data to the +underlying file, or discards any buffered read data, then positions +the file descriptor as specified by \fBoffset\fR and \fBwhence\fR (sic). +This is the correct thing to do when switching between read and write +on the same handle (see issues with \fBPerlIO_flush()\fR above). Offset is +of type \f(CW\*(C`Off_t\*(C'\fR which is a perl Configure value which may not be same +as stdio's \f(CW\*(C`off_t\*(C'\fR. +.IP \fBPerlIO_tell(f)\fR 4 +.IX Item "PerlIO_tell(f)" +This corresponds to \fBftell()\fR. Returns the current file position, or +(Off_t) \-1 on error. May just return value system "knows" without +making a system call or checking the underlying file descriptor (so +use on shared file descriptors is not safe without a +\&\fBPerlIO_seek()\fR). Return value is of type \f(CW\*(C`Off_t\*(C'\fR which is a perl +Configure value which may not be same as stdio's \f(CW\*(C`off_t\*(C'\fR. +.IP "\fBPerlIO_getpos(f,p)\fR, \fBPerlIO_setpos(f,p)\fR" 4 +.IX Item "PerlIO_getpos(f,p), PerlIO_setpos(f,p)" +These correspond (loosely) to \fBfgetpos()\fR and \fBfsetpos()\fR. Rather than +stdio's Fpos_t they expect a "Perl Scalar Value" to be passed. What is +stored there should be considered opaque. The layout of the data may +vary from handle to handle. When not using stdio or if platform does +not have the stdio calls then they are implemented in terms of +\&\fBPerlIO_tell()\fR and \fBPerlIO_seek()\fR. +.IP \fBPerlIO_rewind(f)\fR 4 +.IX Item "PerlIO_rewind(f)" +This corresponds to \fBrewind()\fR. It is usually defined as being +.Sp +.Vb 2 +\& PerlIO_seek(f,(Off_t)0L, SEEK_SET); +\& PerlIO_clearerr(f); +.Ve +.IP \fBPerlIO_tmpfile()\fR 4 +.IX Item "PerlIO_tmpfile()" +This corresponds to \fBtmpfile()\fR, i.e., returns an anonymous PerlIO or +NULL on error. The system will attempt to automatically delete the +file when closed. On Unix the file is usually \f(CW\*(C`unlink\*(C'\fR\-ed just after +it is created so it does not matter how it gets closed. On other +systems the file may only be deleted if closed via \fBPerlIO_close()\fR +and/or the program exits via \f(CW\*(C`exit\*(C'\fR. Depending on the implementation +there may be "race conditions" which allow other processes access to +the file, though in general it will be safer in this regard than +ad. hoc. schemes. +.IP \fBPerlIO_setlinebuf(f)\fR 4 +.IX Item "PerlIO_setlinebuf(f)" +This corresponds to \fBsetlinebuf()\fR. Does not return a value. What +constitutes a "line" is implementation dependent but usually means +that writing "\en" flushes the buffer. What happens with things like +"this\enthat" is uncertain. (Perl core uses it \fIonly\fR when "dumping"; +it has nothing to do with $| auto-flush.) +.SS "Co-existence with stdio" +.IX Subsection "Co-existence with stdio" +There is outline support for co-existence of PerlIO with stdio. +Obviously if PerlIO is implemented in terms of stdio there is no +problem. However in other cases then mechanisms must exist to create a +FILE * which can be passed to library code which is going to use stdio +calls. +.PP +The first step is to add this line: +.PP +.Vb 1 +\& #define PERLIO_NOT_STDIO 0 +.Ve +.PP +\&\fIbefore\fR including any perl header files. (This will probably become +the default at some point). That prevents "perlio.h" from attempting +to #define stdio functions onto PerlIO functions. +.PP +XS code is probably better using "typemap" if it expects FILE * +arguments. The standard typemap will be adjusted to comprehend any +changes in this area. +.IP \fBPerlIO_importFILE(f,mode)\fR 4 +.IX Item "PerlIO_importFILE(f,mode)" +Used to get a PerlIO * from a FILE *. +.Sp +The mode argument should be a string as would be passed to +fopen/PerlIO_open. If it is NULL then \- for legacy support \- the code +will (depending upon the platform and the implementation) either +attempt to empirically determine the mode in which \fIf\fR is open, or +use "r+" to indicate a read/write stream. +.Sp +Once called the FILE * should \fIONLY\fR be closed by calling +\&\f(CWPerlIO_close()\fR on the returned PerlIO *. +.Sp +The PerlIO is set to textmode. Use PerlIO_binmode if this is +not the desired mode. +.Sp +This is \fBnot\fR the reverse of \fBPerlIO_exportFILE()\fR. +.IP \fBPerlIO_exportFILE(f,mode)\fR 4 +.IX Item "PerlIO_exportFILE(f,mode)" +Given a PerlIO * create a 'native' FILE * suitable for passing to code +expecting to be compiled and linked with ANSI C \fIstdio.h\fR. The mode +argument should be a string as would be passed to fopen/PerlIO_open. +If it is NULL then \- for legacy support \- the FILE * is opened in same +mode as the PerlIO *. +.Sp +The fact that such a FILE * has been 'exported' is recorded, (normally +by pushing a new :stdio "layer" onto the PerlIO *), which may affect +future PerlIO operations on the original PerlIO *. You should not +call \f(CWfclose()\fR on the file unless you call \f(CWPerlIO_releaseFILE()\fR +to disassociate it from the PerlIO *. (Do not use \fBPerlIO_importFILE()\fR +for doing the disassociation.) +.Sp +Calling this function repeatedly will create a FILE * on each call +(and will push an :stdio layer each time as well). +.IP \fBPerlIO_releaseFILE(p,f)\fR 4 +.IX Item "PerlIO_releaseFILE(p,f)" +Calling PerlIO_releaseFILE informs PerlIO that all use of FILE * is +complete. It is removed from the list of 'exported' FILE *s, and the +associated PerlIO * should revert to its original behaviour. +.Sp +Use this to disassociate a file from a PerlIO * that was associated +using \fBPerlIO_exportFILE()\fR. +.IP \fBPerlIO_findFILE(f)\fR 4 +.IX Item "PerlIO_findFILE(f)" +Returns a native FILE * used by a stdio layer. If there is none, it +will create one with PerlIO_exportFILE. In either case the FILE * +should be considered as belonging to PerlIO subsystem and should +only be closed by calling \f(CWPerlIO_close()\fR. +.SS """Fast gets"" Functions" +.IX Subsection """Fast gets"" Functions" +In addition to standard-like API defined so far above there is an +"implementation" interface which allows perl to get at internals of +PerlIO. The following calls correspond to the various FILE_xxx macros +determined by Configure \- or their equivalent in other +implementations. This section is really of interest to only those +concerned with detailed perl-core behaviour, implementing a PerlIO +mapping or writing code which can make use of the "read ahead" that +has been done by the IO system in the same way perl does. Note that +any code that uses these interfaces must be prepared to do things the +traditional way if a handle does not support them. +.IP \fBPerlIO_fast_gets(f)\fR 4 +.IX Item "PerlIO_fast_gets(f)" +Returns true if implementation has all the interfaces required to +allow perl's \f(CW\*(C`sv_gets\*(C'\fR to "bypass" normal IO mechanism. This can +vary from handle to handle. +.Sp +.Vb 3 +\& PerlIO_fast_gets(f) = PerlIO_has_cntptr(f) && \e +\& PerlIO_canset_cnt(f) && \e +\& \*(AqCan set pointer into buffer\*(Aq +.Ve +.IP \fBPerlIO_has_cntptr(f)\fR 4 +.IX Item "PerlIO_has_cntptr(f)" +Implementation can return pointer to current position in the "buffer" +and a count of bytes available in the buffer. Do not use this \- use +PerlIO_fast_gets. +.IP \fBPerlIO_get_cnt(f)\fR 4 +.IX Item "PerlIO_get_cnt(f)" +Return count of readable bytes in the buffer. Zero or negative return +means no more bytes available. +.IP \fBPerlIO_get_ptr(f)\fR 4 +.IX Item "PerlIO_get_ptr(f)" +Return pointer to next readable byte in buffer, accessing via the +pointer (dereferencing) is only safe if \fBPerlIO_get_cnt()\fR has returned +a positive value. Only positive offsets up to value returned by +\&\fBPerlIO_get_cnt()\fR are allowed. +.IP \fBPerlIO_set_ptrcnt(f,p,c)\fR 4 +.IX Item "PerlIO_set_ptrcnt(f,p,c)" +Set pointer into buffer, and a count of bytes still in the +buffer. Should be used only to set pointer to within range implied by +previous calls to \f(CW\*(C`PerlIO_get_ptr\*(C'\fR and \f(CW\*(C`PerlIO_get_cnt\*(C'\fR. The two +values \fImust\fR be consistent with each other (implementation may only +use one or the other or may require both). +.IP \fBPerlIO_canset_cnt(f)\fR 4 +.IX Item "PerlIO_canset_cnt(f)" +Implementation can adjust its idea of number of bytes in the buffer. +Do not use this \- use PerlIO_fast_gets. +.IP \fBPerlIO_set_cnt(f,c)\fR 4 +.IX Item "PerlIO_set_cnt(f,c)" +Obscure \- set count of bytes in the buffer. Deprecated. Only usable +if \fBPerlIO_canset_cnt()\fR returns true. Currently used in only doio.c to +force count less than \-1 to \-1. Perhaps should be PerlIO_set_empty or +similar. This call may actually do nothing if "count" is deduced from +pointer and a "limit". Do not use this \- use \fBPerlIO_set_ptrcnt()\fR. +.IP \fBPerlIO_has_base(f)\fR 4 +.IX Item "PerlIO_has_base(f)" +Returns true if implementation has a buffer, and can return pointer +to whole buffer and its size. Used by perl for \fB\-T\fR / \fB\-B\fR tests. +Other uses would be very obscure... +.IP \fBPerlIO_get_base(f)\fR 4 +.IX Item "PerlIO_get_base(f)" +Return \fIstart\fR of buffer. Access only positive offsets in the buffer +up to the value returned by \fBPerlIO_get_bufsiz()\fR. +.IP \fBPerlIO_get_bufsiz(f)\fR 4 +.IX Item "PerlIO_get_bufsiz(f)" +Return the \fItotal number of bytes\fR in the buffer, this is neither the +number that can be read, nor the amount of memory allocated to the +buffer. Rather it is what the operating system and/or implementation +happened to \f(CWread()\fR (or whatever) last time IO was requested. +.SS "Other Functions" +.IX Subsection "Other Functions" +.IP "PerlIO_apply_layers(aTHX_ f,mode,layers)" 4 +.IX Item "PerlIO_apply_layers(aTHX_ f,mode,layers)" +The new interface to the USE_PERLIO implementation. The layers ":crlf" +and ":raw" are the only ones allowed for other implementations and those +are silently ignored. (As of perl5.8 ":raw" is deprecated.) Use +\&\fBPerlIO_binmode()\fR below for the portable case. +.IP "PerlIO_binmode(aTHX_ f,ptype,imode,layers)" 4 +.IX Item "PerlIO_binmode(aTHX_ f,ptype,imode,layers)" +The hook used by perl's \f(CW\*(C`binmode\*(C'\fR operator. +\&\fBptype\fR is perl's character for the kind of IO: +.RS 4 +.IP "'<' read" 8 +.IX Item "'<' read" +.PD 0 +.IP "'>' write" 8 +.IX Item "'>' write" +.IP "'+' read/write" 8 +.IX Item "'+' read/write" +.RE +.RS 4 +.PD +.Sp +\&\fBimode\fR is \f(CW\*(C`O_BINARY\*(C'\fR or \f(CW\*(C`O_TEXT\*(C'\fR. +.Sp +\&\fBlayers\fR is a string of layers to apply; only ":crlf" makes sense in +the non\-USE_PERLIO case. (As of perl5.8 ":raw" is deprecated in favour +of passing NULL.) +.Sp +Portable cases are: +.Sp +.Vb 3 +\& PerlIO_binmode(aTHX_ f,ptype,O_BINARY,NULL); +\&and +\& PerlIO_binmode(aTHX_ f,ptype,O_TEXT,":crlf"); +.Ve +.Sp +On Unix these calls probably have no effect whatsoever. Elsewhere +they alter "\en" to CR,LF translation and possibly cause a special text +"end of file" indicator to be written or honoured on read. The effect +of making the call after doing any IO to the handle depends on the +implementation. (It may be ignored, affect any data which is already +buffered as well, or only apply to subsequent data.) +.RE +.IP PerlIO_debug(fmt,...) 4 +.IX Item "PerlIO_debug(fmt,...)" +PerlIO_debug is a \fBprintf()\fR\-like function which can be used for +debugging. No return value. Its main use is inside PerlIO where using +real printf, \fBwarn()\fR etc. would recursively call PerlIO and be a +problem. +.Sp +PerlIO_debug writes to the file named by \f(CW$ENV\fR{'PERLIO_DEBUG'} or defaults +to stderr if the environment variable is not defined. Typical +use might be +.Sp +.Vb 2 +\& Bourne shells (sh, ksh, bash, zsh, ash, ...): +\& PERLIO_DEBUG=/tmp/perliodebug.log ./perl \-Di somescript some args +\& +\& Csh/Tcsh: +\& setenv PERLIO_DEBUG /tmp/perliodebug.log +\& ./perl \-Di somescript some args +\& +\& If you have the "env" utility: +\& env PERLIO_DEBUG=/tmp/perliodebug.log ./perl \-Di somescript args +\& +\& Win32: +\& set PERLIO_DEBUG=perliodebug.log +\& perl \-Di somescript some args +.Ve +.Sp +On a Perl built without \f(CW\*(C`\-DDEBUGGING\*(C'\fR, or when the \f(CW\*(C`\-Di\*(C'\fR command-line switch +is not specified, or under taint, \fBPerlIO_debug()\fR is a no-op. |