13e12c5d1SDavid du Colombier /* 23e12c5d1SDavid du Colombier * pANS stdio.h 33e12c5d1SDavid du Colombier */ 43e12c5d1SDavid du Colombier /* 53e12c5d1SDavid du Colombier * According to X3J11, there is only one i/o buffer 63e12c5d1SDavid du Colombier * and it must not be occupied by both input and output data. 73e12c5d1SDavid du Colombier * If rp<wp, we must have state==RD and 83e12c5d1SDavid du Colombier * if wp<rp, we must have state==WR, so that getc and putc work correctly. 93e12c5d1SDavid du Colombier * On open, rp, wp and buf are set to 0, so first getc or putc will call _IO_getc 103e12c5d1SDavid du Colombier * or _IO_putc, which will allocate the buffer. 113e12c5d1SDavid du Colombier * If setvbuf(., ., _IONBF, .) is called, bufl is set to 0 and 123e12c5d1SDavid du Colombier * buf, rp and wp are pointed at unbuf. 133e12c5d1SDavid du Colombier * If setvbuf(., ., _IOLBF, .) is called, _IO_putc leaves wp and rp pointed at the 143e12c5d1SDavid du Colombier * end of the buffer so that it can be called on each putc to check whether it's got 153e12c5d1SDavid du Colombier * a newline. This nonsense is in order to avoid impacting performance of the other 163e12c5d1SDavid du Colombier * buffering modes more than necessary -- putting the test in putc adds many 173e12c5d1SDavid du Colombier * instructions that are wasted in non-_IOLBF mode: 183e12c5d1SDavid du Colombier * #define putc(c, f) (_IO_ctmp=(c),\ 193e12c5d1SDavid du Colombier * (f)->wp>=(f)->rp || (f)->flags&LINEBUF && _IO_ctmp=='\n'\ 203e12c5d1SDavid du Colombier * ?_IO_putc(_IO_ctmp, f)\ 213e12c5d1SDavid du Colombier * :*(f)->wp++=_IO_ctmp) 223e12c5d1SDavid du Colombier * 233e12c5d1SDavid du Colombier */ 243e12c5d1SDavid du Colombier typedef struct{ 253e12c5d1SDavid du Colombier int fd; /* UNIX file pointer */ 263e12c5d1SDavid du Colombier char flags; /* bits for must free buffer on close, line-buffered */ 273e12c5d1SDavid du Colombier char state; /* last operation was read, write, position, error, eof */ 283e12c5d1SDavid du Colombier char *buf; /* pointer to i/o buffer */ 293e12c5d1SDavid du Colombier char *rp; /* read pointer (or write end-of-buffer) */ 303e12c5d1SDavid du Colombier char *wp; /* write pointer (or read end-of-buffer) */ 313e12c5d1SDavid du Colombier char *lp; /* actual write pointer used when line-buffering */ 323e12c5d1SDavid du Colombier long bufl; /* actual length of buffer */ 333e12c5d1SDavid du Colombier char unbuf[1]; /* tiny buffer for unbuffered io (used for ungetc?) */ 343e12c5d1SDavid du Colombier }FILE; 353e12c5d1SDavid du Colombier typedef long fpos_t; 363e12c5d1SDavid du Colombier #ifndef NULL 373e12c5d1SDavid du Colombier #define NULL 0 383e12c5d1SDavid du Colombier #endif 393e12c5d1SDavid du Colombier /* 403e12c5d1SDavid du Colombier * Third arg of setvbuf 413e12c5d1SDavid du Colombier */ 423e12c5d1SDavid du Colombier #define _IOFBF 1 /* block-buffered */ 433e12c5d1SDavid du Colombier #define _IOLBF 2 /* line-buffered */ 443e12c5d1SDavid du Colombier #define _IONBF 3 /* unbuffered */ 453e12c5d1SDavid du Colombier #define BUFSIZ 4096 /* size of setbuf buffer */ 463e12c5d1SDavid du Colombier #define EOF (-1) /* returned on end of file */ 473e12c5d1SDavid du Colombier #define FOPEN_MAX 128 /* max files open */ 483e12c5d1SDavid du Colombier #define FILENAME_MAX BUFSIZ /* silly filename length */ 493e12c5d1SDavid du Colombier #define L_tmpnam 20 /* sizeof "/tmp/abcdefghij9999 */ 503e12c5d1SDavid du Colombier #define SEEK_CUR 1 513e12c5d1SDavid du Colombier #define SEEK_END 2 523e12c5d1SDavid du Colombier #define SEEK_SET 0 533e12c5d1SDavid du Colombier #define TMP_MAX 64 /* very hard to set correctly */ 543e12c5d1SDavid du Colombier #define stderr (&_IO_stream[2]) 553e12c5d1SDavid du Colombier #define stdin (&_IO_stream[0]) 563e12c5d1SDavid du Colombier #define stdout (&_IO_stream[1]) 573e12c5d1SDavid du Colombier #define _IO_CHMASK 0377 /* mask for 8 bit characters */ 583e12c5d1SDavid du Colombier FILE *tmpfile(void); 593e12c5d1SDavid du Colombier char *tmpnam(char *); 603e12c5d1SDavid du Colombier int fclose(FILE *); 613e12c5d1SDavid du Colombier int fflush(FILE *); 623e12c5d1SDavid du Colombier FILE *fopen(const char *, const char *); 633e12c5d1SDavid du Colombier FILE *freopen(const char *, const char *, FILE *); 643e12c5d1SDavid du Colombier void setbuf(FILE *, char *); 653e12c5d1SDavid du Colombier int setvbuf(FILE *, char *, int, long); 663e12c5d1SDavid du Colombier int fprintf(FILE *, const char *, ...); 673e12c5d1SDavid du Colombier int fscanf(FILE *, const char *, ...); 683e12c5d1SDavid du Colombier int printf(const char *, ...); 693e12c5d1SDavid du Colombier int scanf(const char *, ...); 703e12c5d1SDavid du Colombier int sprintf(char *, const char *, ...); 713e12c5d1SDavid du Colombier int sscanf(const char *, const char *, ...); 723e12c5d1SDavid du Colombier int vfprintf(FILE *, const char *, va_list); 733e12c5d1SDavid du Colombier int vprintf(const char *, va_list); 743e12c5d1SDavid du Colombier int vsprintf(char *, const char *, va_list); 753e12c5d1SDavid du Colombier int vfscanf(FILE *, const char *, va_list); 763e12c5d1SDavid du Colombier int fgetc(FILE *); 773e12c5d1SDavid du Colombier char *fgets(char *, int, FILE *); 783e12c5d1SDavid du Colombier int fputc(int, FILE *); 793e12c5d1SDavid du Colombier int fputs(const char *, FILE *); 803e12c5d1SDavid du Colombier int getc(FILE *); 813e12c5d1SDavid du Colombier #define getc(f) ((f)->rp>=(f)->wp?_IO_getc(f):*(f)->rp++&_IO_CHMASK) 823e12c5d1SDavid du Colombier int _IO_getc(FILE *f); 833e12c5d1SDavid du Colombier int getchar(void); 843e12c5d1SDavid du Colombier #define getchar() getc(stdin) 853e12c5d1SDavid du Colombier char *gets(char *); 863e12c5d1SDavid du Colombier int putc(int, FILE *); 873e12c5d1SDavid du Colombier #define putc(c, f) ((f)->wp>=(f)->rp?_IO_putc(c, f):(*(f)->wp++=c)&_IO_CHMASK) 883e12c5d1SDavid du Colombier int _IO_putc(int, FILE *); 893e12c5d1SDavid du Colombier int putchar(int); 903e12c5d1SDavid du Colombier #define putchar(c) putc(c, stdout) 913e12c5d1SDavid du Colombier int puts(const char *); 923e12c5d1SDavid du Colombier int ungetc(int, FILE *); 933e12c5d1SDavid du Colombier long fread(void *, long, long, FILE *); 943e12c5d1SDavid du Colombier long fwrite(const void *, long, long, FILE *); 953e12c5d1SDavid du Colombier int fgetpos(FILE *, fpos_t *); 963e12c5d1SDavid du Colombier int fseek(FILE *, long int, int); 973e12c5d1SDavid du Colombier int fsetpos(FILE *, const fpos_t *); 983e12c5d1SDavid du Colombier long int ftell(FILE *); 993e12c5d1SDavid du Colombier void rewind(FILE *); 1003e12c5d1SDavid du Colombier void clearerr(FILE *); 1013e12c5d1SDavid du Colombier int feof(FILE *); 1023e12c5d1SDavid du Colombier int ferror(FILE *); 1033e12c5d1SDavid du Colombier void perror(const char *); 1043e12c5d1SDavid du Colombier extern FILE _IO_stream[FOPEN_MAX]; 1053e12c5d1SDavid du Colombier FILE *sopenr(const char *); 1063e12c5d1SDavid du Colombier FILE *sopenw(void); 1073e12c5d1SDavid du Colombier char *sclose(FILE *); 108*9a747e4fSDavid du Colombier char *dtoa(double, int, int, int*, int*, char**); 109*9a747e4fSDavid du Colombier void freedtoa(char*); 110