Loading...
stdio/FreeBSD/fflush.c Libc-1725.40.4 Libc-320
--- Libc/Libc-1725.40.4/stdio/FreeBSD/fflush.c
+++ Libc/Libc-320/stdio/FreeBSD/fflush.c
@@ -13,6 +13,10 @@
  * 2. Redistributions in binary form must reproduce the above copyright
  *    notice, this list of conditions and the following disclaimer in the
  *    documentation and/or other materials provided with the distribution.
+ * 3. All advertising materials mentioning features or use of this software
+ *    must display the following acknowledgement:
+ *	This product includes software developed by the University of
+ *	California, Berkeley and its contributors.
  * 4. Neither the name of the University nor the names of its contributors
  *    may be used to endorse or promote products derived from this software
  *    without specific prior written permission.
@@ -34,16 +38,14 @@
 static char sccsid[] = "@(#)fflush.c	8.1 (Berkeley) 6/4/93";
 #endif /* LIBC_SCCS and not lint */
 #include <sys/cdefs.h>
-__FBSDID("$FreeBSD: src/lib/libc/stdio/fflush.c,v 1.14 2007/01/09 00:28:06 imp Exp $");
+__FBSDID("$FreeBSD: src/lib/libc/stdio/fflush.c,v 1.12 2002/03/22 21:53:04 obrien Exp $");
 
 #include "namespace.h"
 #include <errno.h>
 #include <stdio.h>
-#include <string.h>
 #include "un-namespace.h"
 #include "libc_private.h"
 #include "local.h"
-#include "libc_hooks_impl.h"
 
 static int	sflush_locked(FILE *);
 
@@ -54,16 +56,16 @@
 int
 fflush(FILE *fp)
 {
-	int retval = 0;
+	int retval;
 
-	if (fp == NULL) {
+	if (fp == NULL)
 		return (_fwalk(sflush_locked));
-	}
-
-	libc_hooks_will_write(fp, sizeof(*fp));
-
 	FLOCKFILE(fp);
-	retval = __sflush(fp);
+	if ((fp->_flags & (__SWR | __SRW)) == 0) {
+		errno = EBADF;
+		retval = EOF;
+	} else
+		retval = __sflush(fp);
 	FUNLOCKFILE(fp);
 	return (retval);
 }
@@ -80,7 +82,8 @@
 	if (fp == NULL)
 		return (_fwalk(sflush_locked));
 	if ((fp->_flags & (__SWR | __SRW)) == 0) {
-		retval = 0;
+		errno = EBADF;
+		retval = EOF;
 	} else
 		retval = __sflush(fp);
 	return (retval);
@@ -90,76 +93,29 @@
 __sflush(FILE *fp)
 {
 	unsigned char *p;
-	int f, n, t;
+	int n, t;
 
-	f = fp->_flags;
+	t = fp->_flags;
+	if ((t & __SWR) == 0)
+		return (0);
 
 	if ((p = fp->_bf._base) == NULL)
 		return (0);
 
+	n = fp->_p - p;		/* write this much */
+
 	/*
-	 * SUSv3 requires that fflush() on a seekable input stream updates the file
-	 * position indicator with the underlying seek function.  Use a dumb fseek
-	 * for this (don't attempt to preserve the buffers).
+	 * Set these immediately to avoid problems with longjmp and to allow
+	 * exchange buffering (via setvbuf) in user write function.
 	 */
-	if ((f & __SRD) != 0) {
-		if (fp->_seek == NULL) {
-			/*
-			 * No way to seek this file -- just return "success."
-			 */
-			return (0);
-		}
+	fp->_p = p;
+	fp->_w = t & (__SLBF|__SNBF) ? 0 : fp->_bf._size;
 
-		n = fp->_r;
-
-		if (n > 0) {
-			/*
-			 * See _fseeko's dumb path.
-			 */
-			if (_sseek(fp, (fpos_t)-n, SEEK_CUR) == -1) {
-				if (errno == ESPIPE) {
-					/*
-					 * Ignore ESPIPE errors, since there's no way to put the bytes
-					 * back into the pipe.
-					 */
-					return (0);
-				}
-				return (EOF);
-			}
-
-			if (HASUB(fp)) {
-				FREEUB(fp);
-			}
-			fp->_p = fp->_bf._base;
-			fp->_r = 0;
-			fp->_flags &= ~__SEOF;
-			memset(&fp->_mbstate, 0, sizeof(mbstate_t));
-		}
-		return (0);
-	}
-
-	if ((f & __SWR) != 0) {
-		n = fp->_p - p;		/* write this much */
-
-		/*
-		 * Set these immediately to avoid problems with longjmp and to allow
-		 * exchange buffering (via setvbuf) in user write function.
-		 */
-		fp->_p = p;
-		fp->_w = f & (__SLBF|__SNBF) ? 0 : fp->_bf._size;
-
-		for (; n > 0; n -= t, p += t) {
-			t = _swrite(fp, (char *)p, n);
-			if (t <= 0) {
-				if (p > fp->_p)
-					/* some was written */
-					memmove(fp->_p, p, n);
-				fp->_p += n;
-				if ((fp->_flags & __SNBF) == 0)
-					fp->_w -= n;
-				fp->_flags |= __SERR;
-				return (EOF);
-			}
+	for (; n > 0; n -= t, p += t) {
+		t = _swrite(fp, (char *)p, n);
+		if (t <= 0) {
+			fp->_flags |= __SERR;
+			return (EOF);
 		}
 	}
 	return (0);