X-Git-Url: http://erislabs.net/gitweb/?a=blobdiff_plain;f=lib%2Ffseterr.c;h=69fcd32f1e41bf518f8c4735317a0f1347af64b9;hb=7080851f5a8270aee50e8545d28c48c6c75decc1;hp=7b0c68b9f072c93731eeea105cd16ee9de33240b;hpb=b0db05957a20f6506b0de6b499468baf73ae5121;p=gnulib.git diff --git a/lib/fseterr.c b/lib/fseterr.c index 7b0c68b9f..69fcd32f1 100644 --- a/lib/fseterr.c +++ b/lib/fseterr.c @@ -21,32 +21,22 @@ #include +#include "stdio-impl.h" + void fseterr (FILE *fp) { /* Most systems provide FILE as a struct and the necessary bitmask in , because they need it for implementing getc() and putc() as fast macros. */ -#if defined _IO_ferror_unlocked /* GNU libc, BeOS */ +#if defined _IO_ferror_unlocked || __GNU_LIBRARY__ == 1 /* GNU libc, BeOS, Linux libc5 */ fp->_flags |= _IO_ERR_SEEN; -#elif defined __sferror /* FreeBSD, NetBSD, OpenBSD, MacOS X, Cygwin */ - fp->_flags |= __SERR; +#elif defined __sferror || defined __DragonFly__ /* FreeBSD, NetBSD, OpenBSD, DragonFly, MacOS X, Cygwin */ + fp_->_flags |= __SERR; +#elif defined __EMX__ /* emx+gcc */ + fp->_flags |= _IOERR; #elif defined _IOERR /* AIX, HP-UX, IRIX, OSF/1, Solaris, OpenServer, mingw */ -# if defined __sun && defined _LP64 /* Solaris/{SPARC,AMD64} 64-bit */ -# define fp_ ((struct { unsigned char *_ptr; \ - unsigned char *_base; \ - unsigned char *_end; \ - long _cnt; \ - int _file; \ - unsigned int _flag; \ - } *) fp) fp_->_flag |= _IOERR; -# else -# if defined _SCO_DS /* OpenServer */ -# define _flag __flag -# endif - fp->_flag |= _IOERR; -# endif #elif defined __UCLIBC__ /* uClibc */ fp->__modeflags |= __FLAG_ERROR; #elif defined __QNX__ /* QNX */