This is a live mirror of the Perl 5 development currently hosted at https://github.com/perl/perl5
Save state when auto-generating #ifdef PERL_CORE and PERL_CORE/PERL_EXT
[perl5.git] / perliol.h
1 #ifndef _PERLIOL_H
2 #define _PERLIOL_H
3
4 typedef struct {
5     PerlIO_funcs *funcs;
6     SV *arg;
7 } PerlIO_pair_t;
8
9 struct PerlIO_list_s {
10     IV refcnt;
11     IV cur;
12     IV len;
13     PerlIO_pair_t *array;
14 };
15
16 struct _PerlIO_funcs {
17     Size_t fsize;
18     const char *name;
19     Size_t size;
20     U32 kind;
21     IV (*Pushed) (pTHX_ PerlIO *f, const char *mode, SV *arg, PerlIO_funcs *tab);
22     IV (*Popped) (pTHX_ PerlIO *f);
23     PerlIO *(*Open) (pTHX_ PerlIO_funcs *tab,
24                      PerlIO_list_t *layers, IV n,
25                      const char *mode,
26                      int fd, int imode, int perm,
27                      PerlIO *old, int narg, SV **args);
28     IV (*Binmode)(pTHX_ PerlIO *f);
29     SV *(*Getarg) (pTHX_ PerlIO *f, CLONE_PARAMS *param, int flags);
30     IV (*Fileno) (pTHX_ PerlIO *f);
31     PerlIO *(*Dup) (pTHX_ PerlIO *f, PerlIO *o, CLONE_PARAMS *param, int flags);
32     /* Unix-like functions - cf sfio line disciplines */
33      SSize_t(*Read) (pTHX_ PerlIO *f, void *vbuf, Size_t count);
34      SSize_t(*Unread) (pTHX_ PerlIO *f, const void *vbuf, Size_t count);
35      SSize_t(*Write) (pTHX_ PerlIO *f, const void *vbuf, Size_t count);
36     IV (*Seek) (pTHX_ PerlIO *f, Off_t offset, int whence);
37      Off_t(*Tell) (pTHX_ PerlIO *f);
38     IV (*Close) (pTHX_ PerlIO *f);
39     /* Stdio-like buffered IO functions */
40     IV (*Flush) (pTHX_ PerlIO *f);
41     IV (*Fill) (pTHX_ PerlIO *f);
42     IV (*Eof) (pTHX_ PerlIO *f);
43     IV (*Error) (pTHX_ PerlIO *f);
44     void (*Clearerr) (pTHX_ PerlIO *f);
45     void (*Setlinebuf) (pTHX_ PerlIO *f);
46     /* Perl's snooping functions */
47     STDCHAR *(*Get_base) (pTHX_ PerlIO *f);
48      Size_t(*Get_bufsiz) (pTHX_ PerlIO *f);
49     STDCHAR *(*Get_ptr) (pTHX_ PerlIO *f);
50      SSize_t(*Get_cnt) (pTHX_ PerlIO *f);
51     void (*Set_ptrcnt) (pTHX_ PerlIO *f, STDCHAR * ptr, SSize_t cnt);
52 };
53
54 /*--------------------------------------------------------------------------------------*/
55 /* Kind values */
56 #define PERLIO_K_RAW            0x00000001
57 #define PERLIO_K_BUFFERED       0x00000002
58 #define PERLIO_K_CANCRLF        0x00000004
59 #define PERLIO_K_FASTGETS       0x00000008
60 #define PERLIO_K_DUMMY          0x00000010
61 #define PERLIO_K_UTF8           0x00008000
62 #define PERLIO_K_DESTRUCT       0x00010000
63 #define PERLIO_K_MULTIARG       0x00020000
64
65 /*--------------------------------------------------------------------------------------*/
66 struct _PerlIO {
67     PerlIOl *next;              /* Lower layer */
68     PerlIO_funcs *tab;          /* Functions for this layer */
69     U32 flags;                  /* Various flags for state */
70 };
71
72 /*--------------------------------------------------------------------------------------*/
73
74 /* Flag values */
75 #define PERLIO_F_EOF            0x00000100
76 #define PERLIO_F_CANWRITE       0x00000200
77 #define PERLIO_F_CANREAD        0x00000400
78 #define PERLIO_F_ERROR          0x00000800
79 #define PERLIO_F_TRUNCATE       0x00001000
80 #define PERLIO_F_APPEND         0x00002000
81 #define PERLIO_F_CRLF           0x00004000
82 #define PERLIO_F_UTF8           0x00008000
83 #define PERLIO_F_UNBUF          0x00010000
84 #define PERLIO_F_WRBUF          0x00020000
85 #define PERLIO_F_RDBUF          0x00040000
86 #define PERLIO_F_LINEBUF        0x00080000
87 #define PERLIO_F_TEMP           0x00100000
88 #define PERLIO_F_OPEN           0x00200000
89 #define PERLIO_F_FASTGETS       0x00400000
90 #define PERLIO_F_TTY            0x00800000
91 #define PERLIO_F_NOTREG         0x01000000   
92
93 #define PerlIOBase(f)      (*(f))
94 #define PerlIOSelf(f,type) ((type *)PerlIOBase(f))
95 #define PerlIONext(f)      (&(PerlIOBase(f)->next))
96 #define PerlIOValid(f)     ((f) && *(f))
97
98 /*--------------------------------------------------------------------------------------*/
99 /* Data exports - EXTCONST rather than extern is needed for Cygwin */
100 #undef EXTPERLIO 
101 #ifdef PERLIO_FUNCS_CONST
102 #define EXTPERLIO EXTCONST
103 #else
104 #define EXTPERLIO EXT
105 #endif
106 EXTPERLIO PerlIO_funcs PerlIO_unix;
107 EXTPERLIO PerlIO_funcs PerlIO_perlio;
108 EXTPERLIO PerlIO_funcs PerlIO_stdio;
109 EXTPERLIO PerlIO_funcs PerlIO_crlf;
110 EXTPERLIO PerlIO_funcs PerlIO_utf8;
111 EXTPERLIO PerlIO_funcs PerlIO_byte;
112 EXTPERLIO PerlIO_funcs PerlIO_raw;
113 EXTPERLIO PerlIO_funcs PerlIO_pending;
114 #ifdef HAS_MMAP
115 EXTPERLIO PerlIO_funcs PerlIO_mmap;
116 #endif
117 #ifdef WIN32
118 EXTPERLIO PerlIO_funcs PerlIO_win32;
119 #endif
120 PERL_EXPORT_C PerlIO *PerlIO_allocate(pTHX);
121 PERL_EXPORT_C SV *PerlIO_arg_fetch(PerlIO_list_t *av, IV n);
122 #define PerlIOArg PerlIO_arg_fetch(layers,n)
123
124 #ifdef PERLIO_USING_CRLF
125 #define PERLIO_STDTEXT "t"
126 #else
127 #define PERLIO_STDTEXT ""
128 #endif
129
130 /*--------------------------------------------------------------------------------------*/
131 /* Generic, or stub layer functions */
132
133 PERL_EXPORT_C IV PerlIOBase_fileno(pTHX_ PerlIO *f);
134 PERL_EXPORT_C PerlIO *PerlIOBase_dup(pTHX_ PerlIO *f, PerlIO *o, CLONE_PARAMS *param, int flags);
135 PERL_EXPORT_C IV PerlIOBase_pushed(pTHX_ PerlIO *f, const char *mode, SV *arg, PerlIO_funcs *tab);
136 PERL_EXPORT_C IV PerlIOBase_popped(pTHX_ PerlIO *f);
137 PERL_EXPORT_C IV PerlIOBase_binmode(pTHX_ PerlIO *f);
138 PERL_EXPORT_C SSize_t PerlIOBase_read(pTHX_ PerlIO *f,
139                                       void *vbuf, Size_t count);
140 PERL_EXPORT_C SSize_t PerlIOBase_unread(pTHX_ PerlIO *f,
141                                         const void *vbuf, Size_t count);
142 PERL_EXPORT_C IV PerlIOBase_eof(pTHX_ PerlIO *f);
143 PERL_EXPORT_C IV PerlIOBase_error(pTHX_ PerlIO *f);
144 PERL_EXPORT_C void PerlIOBase_clearerr(pTHX_ PerlIO *f);
145 PERL_EXPORT_C IV PerlIOBase_close(pTHX_ PerlIO *f);
146 PERL_EXPORT_C void PerlIOBase_setlinebuf(pTHX_ PerlIO *f);
147 PERL_EXPORT_C void PerlIOBase_flush_linebuf(pTHX);
148
149 PERL_EXPORT_C IV PerlIOBase_noop_ok(pTHX_ PerlIO *f);
150 PERL_EXPORT_C IV PerlIOBase_noop_fail(pTHX_ PerlIO *f);
151
152 /*--------------------------------------------------------------------------------------*/
153 /* perlio buffer layer
154    As this is reasonably generic its struct and "methods" are declared here
155    so they can be used to "inherit" from it.
156 */
157
158 typedef struct {
159     struct _PerlIO base;        /* Base "class" info */
160     STDCHAR *buf;               /* Start of buffer */
161     STDCHAR *end;               /* End of valid part of buffer */
162     STDCHAR *ptr;               /* Current position in buffer */
163     Off_t posn;                 /* Offset of buf into the file */
164     Size_t bufsiz;              /* Real size of buffer */
165     IV oneword;                 /* Emergency buffer */
166 } PerlIOBuf;
167
168 PERL_EXPORT_C int PerlIO_apply_layera(pTHX_ PerlIO *f, const char *mode,
169                     PerlIO_list_t *layers, IV n, IV max);
170 PERL_EXPORT_C int PerlIO_parse_layers(pTHX_ PerlIO_list_t *av, const char *names);
171 PERL_EXPORT_C void PerlIO_list_free(pTHX_ PerlIO_list_t *list);
172 PERL_EXPORT_C PerlIO_funcs *PerlIO_layer_fetch(pTHX_ PerlIO_list_t *av, IV n, PerlIO_funcs *def);
173
174
175 PERL_EXPORT_C SV *PerlIO_sv_dup(pTHX_ SV *arg, CLONE_PARAMS *param);
176 PERL_EXPORT_C PerlIO *PerlIOBuf_open(pTHX_ PerlIO_funcs *self,
177                               PerlIO_list_t *layers, IV n,
178                               const char *mode, int fd, int imode,
179                               int perm, PerlIO *old, int narg, SV **args);
180 PERL_EXPORT_C IV PerlIOBuf_pushed(pTHX_ PerlIO *f, const char *mode, SV *arg, PerlIO_funcs *tab);
181 PERL_EXPORT_C IV PerlIOBuf_popped(pTHX_ PerlIO *f);
182 PERL_EXPORT_C PerlIO *PerlIOBuf_dup(pTHX_ PerlIO *f, PerlIO *o, CLONE_PARAMS *param, int flags);
183 PERL_EXPORT_C SSize_t PerlIOBuf_read(pTHX_ PerlIO *f, void *vbuf, Size_t count);
184 PERL_EXPORT_C SSize_t PerlIOBuf_unread(pTHX_ PerlIO *f, const void *vbuf, Size_t count);
185 PERL_EXPORT_C SSize_t PerlIOBuf_write(pTHX_ PerlIO *f, const void *vbuf, Size_t count);
186 PERL_EXPORT_C IV PerlIOBuf_seek(pTHX_ PerlIO *f, Off_t offset, int whence);
187 PERL_EXPORT_C Off_t PerlIOBuf_tell(pTHX_ PerlIO *f);
188 PERL_EXPORT_C IV PerlIOBuf_close(pTHX_ PerlIO *f);
189 PERL_EXPORT_C IV PerlIOBuf_flush(pTHX_ PerlIO *f);
190 PERL_EXPORT_C IV PerlIOBuf_fill(pTHX_ PerlIO *f);
191 PERL_EXPORT_C STDCHAR *PerlIOBuf_get_base(pTHX_ PerlIO *f);
192 PERL_EXPORT_C Size_t PerlIOBuf_bufsiz(pTHX_ PerlIO *f);
193 PERL_EXPORT_C STDCHAR *PerlIOBuf_get_ptr(pTHX_ PerlIO *f);
194 PERL_EXPORT_C SSize_t PerlIOBuf_get_cnt(pTHX_ PerlIO *f);
195 PERL_EXPORT_C void PerlIOBuf_set_ptrcnt(pTHX_ PerlIO *f, STDCHAR * ptr, SSize_t cnt);
196
197 PERL_EXPORT_C int PerlIOUnix_oflags(const char *mode);
198
199 /*--------------------------------------------------------------------------------------*/
200
201 #endif                          /* _PERLIOL_H */