16 struct _PerlIO_funcs {
20 IV (*Pushed) (PerlIO *f, const char *mode, SV *arg);
21 IV (*Popped) (PerlIO *f);
22 PerlIO *(*Open) (pTHX_ PerlIO_funcs *tab,
23 PerlIO_list_t *layers, IV n,
25 int fd, int imode, int perm,
26 PerlIO *old, int narg, SV **args);
27 SV *(*Getarg) (pTHX_ PerlIO *f, CLONE_PARAMS *param, int flags);
28 IV (*Fileno) (PerlIO *f);
29 PerlIO *(*Dup) (pTHX_ PerlIO *f, PerlIO *o, CLONE_PARAMS *param, int flags);
30 /* Unix-like functions - cf sfio line disciplines */
31 SSize_t(*Read) (PerlIO *f, void *vbuf, Size_t count);
32 SSize_t(*Unread) (PerlIO *f, const void *vbuf, Size_t count);
33 SSize_t(*Write) (PerlIO *f, const void *vbuf, Size_t count);
34 IV (*Seek) (PerlIO *f, Off_t offset, int whence);
35 Off_t(*Tell) (PerlIO *f);
36 IV (*Close) (PerlIO *f);
37 /* Stdio-like buffered IO functions */
38 IV (*Flush) (PerlIO *f);
39 IV (*Fill) (PerlIO *f);
40 IV (*Eof) (PerlIO *f);
41 IV (*Error) (PerlIO *f);
42 void (*Clearerr) (PerlIO *f);
43 void (*Setlinebuf) (PerlIO *f);
44 /* Perl's snooping functions */
45 STDCHAR *(*Get_base) (PerlIO *f);
46 Size_t(*Get_bufsiz) (PerlIO *f);
47 STDCHAR *(*Get_ptr) (PerlIO *f);
48 SSize_t(*Get_cnt) (PerlIO *f);
49 void (*Set_ptrcnt) (PerlIO *f, STDCHAR * ptr, SSize_t cnt);
52 /*--------------------------------------------------------------------------------------*/
54 #define PERLIO_K_RAW 0x00000001
55 #define PERLIO_K_BUFFERED 0x00000002
56 #define PERLIO_K_CANCRLF 0x00000004
57 #define PERLIO_K_FASTGETS 0x00000008
58 #define PERLIO_K_DUMMY 0x00000010
59 #define PERLIO_K_UTF8 0x00008000
60 #define PERLIO_K_DESTRUCT 0x00010000
62 /*--------------------------------------------------------------------------------------*/
64 PerlIOl *next; /* Lower layer */
65 PerlIO_funcs *tab; /* Functions for this layer */
66 IV flags; /* Various flags for state */
69 /*--------------------------------------------------------------------------------------*/
72 #define PERLIO_F_EOF 0x00000100
73 #define PERLIO_F_CANWRITE 0x00000200
74 #define PERLIO_F_CANREAD 0x00000400
75 #define PERLIO_F_ERROR 0x00000800
76 #define PERLIO_F_TRUNCATE 0x00001000
77 #define PERLIO_F_APPEND 0x00002000
78 #define PERLIO_F_CRLF 0x00004000
79 #define PERLIO_F_UTF8 0x00008000
80 #define PERLIO_F_UNBUF 0x00010000
81 #define PERLIO_F_WRBUF 0x00020000
82 #define PERLIO_F_RDBUF 0x00040000
83 #define PERLIO_F_LINEBUF 0x00080000
84 #define PERLIO_F_TEMP 0x00100000
85 #define PERLIO_F_OPEN 0x00200000
86 #define PERLIO_F_FASTGETS 0x00400000
87 #define PERLIO_F_TTY 0x00800000
89 #define PerlIOBase(f) (*(f))
90 #define PerlIOSelf(f,type) ((type *)PerlIOBase(f))
91 #define PerlIONext(f) (&(PerlIOBase(f)->next))
93 /*--------------------------------------------------------------------------------------*/
94 /* Data exports - EXT rather than extern is needed for Cygwin */
95 EXT PerlIO_funcs PerlIO_unix;
96 EXT PerlIO_funcs PerlIO_perlio;
97 EXT PerlIO_funcs PerlIO_stdio;
98 EXT PerlIO_funcs PerlIO_crlf;
99 EXT PerlIO_funcs PerlIO_utf8;
100 EXT PerlIO_funcs PerlIO_byte;
101 EXT PerlIO_funcs PerlIO_raw;
102 EXT PerlIO_funcs PerlIO_pending;
104 EXT PerlIO_funcs PerlIO_mmap;
107 EXT PerlIO_funcs PerlIO_win32;
109 extern PerlIO *PerlIO_allocate(pTHX);
110 extern SV *PerlIO_arg_fetch(PerlIO_list_t *av, IV n);
111 #define PerlIOArg PerlIO_arg_fetch(layers,n)
113 #if O_BINARY != O_TEXT
114 #define PERLIO_STDTEXT "t"
116 #define PERLIO_STDTEXT ""
119 /*--------------------------------------------------------------------------------------*/
120 /* Generic, or stub layer functions */
122 extern IV PerlIOBase_fileno(PerlIO *f);
123 extern PerlIO *PerlIOBase_dup(pTHX_ PerlIO *f, PerlIO *o, CLONE_PARAMS *param, int flags);
124 extern IV PerlIOBase_pushed(PerlIO *f, const char *mode, SV *arg);
125 extern IV PerlIOBase_popped(PerlIO *f);
126 extern SSize_t PerlIOBase_read(PerlIO *f, void *vbuf, Size_t count);
127 extern SSize_t PerlIOBase_unread(PerlIO *f, const void *vbuf,
129 extern IV PerlIOBase_eof(PerlIO *f);
130 extern IV PerlIOBase_error(PerlIO *f);
131 extern void PerlIOBase_clearerr(PerlIO *f);
132 extern IV PerlIOBase_close(PerlIO *f);
133 extern void PerlIOBase_setlinebuf(PerlIO *f);
134 extern void PerlIOBase_flush_linebuf(void);
136 extern IV PerlIOBase_noop_ok(PerlIO *f);
137 extern IV PerlIOBase_noop_fail(PerlIO *f);
139 /*--------------------------------------------------------------------------------------*/
140 /* perlio buffer layer
141 As this is reasonably generic its struct and "methods" are declared here
142 so they can be used to "inherit" from it.
146 struct _PerlIO base; /* Base "class" info */
147 STDCHAR *buf; /* Start of buffer */
148 STDCHAR *end; /* End of valid part of buffer */
149 STDCHAR *ptr; /* Current position in buffer */
150 Off_t posn; /* Offset of buf into the file */
151 Size_t bufsiz; /* Real size of buffer */
152 IV oneword; /* Emergency buffer */
155 extern SV *PerlIO_sv_dup(pTHX_ SV *arg, CLONE_PARAMS *param);
156 extern PerlIO *PerlIOBuf_open(pTHX_ PerlIO_funcs *self,
157 PerlIO_list_t *layers, IV n,
158 const char *mode, int fd, int imode,
159 int perm, PerlIO *old, int narg, SV **args);
160 extern IV PerlIOBuf_pushed(PerlIO *f, const char *mode, SV *arg);
161 extern PerlIO *PerlIOBuf_dup(pTHX_ PerlIO *f, PerlIO *o, CLONE_PARAMS *param, int flags);
162 extern SSize_t PerlIOBuf_read(PerlIO *f, void *vbuf, Size_t count);
163 extern SSize_t PerlIOBuf_unread(PerlIO *f, const void *vbuf, Size_t count);
164 extern SSize_t PerlIOBuf_write(PerlIO *f, const void *vbuf, Size_t count);
165 extern IV PerlIOBuf_seek(PerlIO *f, Off_t offset, int whence);
166 extern Off_t PerlIOBuf_tell(PerlIO *f);
167 extern IV PerlIOBuf_close(PerlIO *f);
168 extern IV PerlIOBuf_flush(PerlIO *f);
169 extern IV PerlIOBuf_fill(PerlIO *f);
170 extern STDCHAR *PerlIOBuf_get_base(PerlIO *f);
171 extern Size_t PerlIOBuf_bufsiz(PerlIO *f);
172 extern STDCHAR *PerlIOBuf_get_ptr(PerlIO *f);
173 extern SSize_t PerlIOBuf_get_cnt(PerlIO *f);
174 extern void PerlIOBuf_set_ptrcnt(PerlIO *f, STDCHAR * ptr, SSize_t cnt);
176 extern int PerlIOUnix_oflags(const char *mode);
178 /*--------------------------------------------------------------------------------------*/
180 #endif /* _PERLIOL_H */