X-Git-Url: https://pd.if.org/git/?a=blobdiff_plain;f=internals%2F_PDCLIB_int.h;h=02e122eb3ada87dfa4f09e2a21712370a72bcadb;hb=0d54a75af25ca44411e7c4190cc2a93a390e61a2;hp=496f0e6e99c1f677600cbf8fcc905539bdcd3684;hpb=0cc720d139ca1d0b59e92f9b12f6c87c07980279;p=pdclib.old diff --git a/internals/_PDCLIB_int.h b/internals/_PDCLIB_int.h index 496f0e6..02e122e 100644 --- a/internals/_PDCLIB_int.h +++ b/internals/_PDCLIB_int.h @@ -251,7 +251,7 @@ typedef unsigned _PDCLIB_intmax _PDCLIB_uintmax_t; /* Flags for representing mode (see fopen()). Note these must fit the same status field as the _IO?BF flags in and the internal flags below. */ -#define _PDCLIB_FREAD 8u +#define _PDCLIB_FREAD 8u #define _PDCLIB_FWRITE 16u #define _PDCLIB_FAPPEND 32u #define _PDCLIB_FRW 64u @@ -259,22 +259,33 @@ typedef unsigned _PDCLIB_intmax _PDCLIB_uintmax_t; /* Internal flags, made to fit the same status field as the flags above. */ #define _PDCLIB_LIBBUFFER 512u -#define _PDCLIB_VIRGINSTR 1024u -#define _PDCLIB_ERRORFLAG 2048u -#define _PDCLIB_EOFFLAG 4096u -#define _PDCLIB_WIDESTREAM 8192u -#define _PDCLIB_BYTESTREAM 16384u +#define _PDCLIB_ERRORFLAG 1024u +#define _PDCLIB_EOFFLAG 2048u +#define _PDCLIB_WIDESTREAM 4096u +#define _PDCLIB_BYTESTREAM 8192u +/* Position / status structure for getpos() / fsetpos(). */ +struct _PDCLIB_fpos_t +{ + _PDCLIB_uint64_t offset; /* File position offset */ + int status; /* Multibyte parsing state (unused, reserved) */ +}; + +/* FILE structure */ struct _PDCLIB_file_t { - _PDCLIB_fd_t handle; /* OS-specific file descriptor */ - _PDCLIB_fpos_t position; /* file position indicator */ - char * buffer; /* file buffer */ - _PDCLIB_size_t bufsize; /* size of buffer */ - _PDCLIB_size_t bufidx; /* index to point of action in buffer */ - _PDCLIB_size_t bufend; /* index to end of pre-read buffer */ - unsigned int status; /* misc. status bits */ - struct _PDCLIB_file_t * next; /* provisions for linked list handling */ + _PDCLIB_fd_t handle; /* OS file handle */ + char * buffer; /* Pointer to buffer memory */ + _PDCLIB_size_t bufsize; /* Size of buffer */ + _PDCLIB_size_t bufidx; /* Index of current position in buffer */ + _PDCLIB_size_t bufend; /* Index of last pre-read character in buffer */ + struct _PDCLIB_fpos_t pos; /* Offset and multibyte parsing state */ + _PDCLIB_size_t ungetidx; /* Number of ungetc()'ed characters */ + unsigned char * ungetbuf; /* ungetc() buffer */ + unsigned int status; /* Status flags; see above */ + /* multibyte parsing status to be added later */ + char * filename; /* Name the current stream has been opened with */ + struct _PDCLIB_file_t * next; /* Pointer to next struct (internal) */ }; /* -------------------------------------------------------------------------- */ @@ -325,7 +336,7 @@ _PDCLIB_intmax_t _PDCLIB_atomax( const char * s ); /* Two helper functions used by strtol(), strtoul() and long long variants. */ const char * _PDCLIB_strtox_prelim( const char * p, char * sign, int * base ); -_PDCLIB_uintmax_t _PDCLIB_strtox_main( const char ** p, unsigned int base, _PDCLIB_uintmax_t error, _PDCLIB_uintmax_t limval, _PDCLIB_uintmax_t limdigit, char * sign ); +_PDCLIB_uintmax_t _PDCLIB_strtox_main( const char ** p, unsigned int base, _PDCLIB_uintmax_t error, _PDCLIB_uintmax_t limval, int limdigit, char * sign ); /* Digits arrays used by various integer conversion functions */ extern char _PDCLIB_digits[]; @@ -343,7 +354,36 @@ const char * _PDCLIB_print( const char * spec, struct _PDCLIB_status_t * status /* Parsing any fopen() style filemode string into a number of flags. */ unsigned int _PDCLIB_filemode( const char * mode ); -/* Writing out unwritten buffers to file. Returns 0 if successful, EOF if error - occured. Sets error flag of stream in case of error. - */ -int _PDCLIB_fflush( struct _PDCLIB_file_t * stream ); +/* Sanity checking and preparing of read buffer, should be called first thing + by any stdio read-data function. + Returns 0 on success, EOF on error. + On error, EOF / error flags and errno are set appropriately. +*/ +int _PDCLIB_prepread( struct _PDCLIB_file_t * stream ); + +/* Sanity checking, should be called first thing by any stdio write-data + function. + Returns 0 on success, EOF on error. + On error, error flags and errno are set appropriately. +*/ +int _PDCLIB_prepwrite( struct _PDCLIB_file_t * stream ); + +/* -------------------------------------------------------------------------- */ +/* errno */ +/* -------------------------------------------------------------------------- */ + +extern int _PDCLIB_errno; +int * _PDCLIB_errno_func( void ); + +/* ERANGE and EDOM are specified by the standard. */ +#define _PDCLIB_ERANGE 1 +#define _PDCLIB_EDOM 2 +/* Used in the example implementation for any kind of I/O error. */ +#define _PDCLIB_EIO 3 +/* Used in the example implementation for "unknown error". */ +#define _PDCLIB_EUNKNOWN 4 +/* Used in the example implementation for "invalid parameter value". */ +#define _PDCLIB_EINVAL 5 +/* Used in the example implementation for "I/O retries exceeded". */ +#define _PDCLIB_ERETRY 6 +