summaryrefslogtreecommitdiff
path: root/libio/iofwrite.c
diff options
context:
space:
mode:
authorSiddhesh Poyarekar <siddhesh@redhat.com>2012-11-28 00:59:27 +0530
committerSiddhesh Poyarekar <siddhesh@redhat.com>2012-11-28 01:00:50 +0530
commitde2fd463b1c0310d75084b6d774fb974075a4ad9 (patch)
treed51bae43dd28baf8aa9dd591e5195bd938f89482 /libio/iofwrite.c
parentc515fb5148f1d81d5f7736825e14c7502c15432a (diff)
Make fwrite return 0 on EOF
Diffstat (limited to 'libio/iofwrite.c')
-rw-r--r--libio/iofwrite.c10
1 files changed, 5 insertions, 5 deletions
diff --git a/libio/iofwrite.c b/libio/iofwrite.c
index d4610f78ca..2fff72b408 100644
--- a/libio/iofwrite.c
+++ b/libio/iofwrite.c
@@ -42,12 +42,12 @@ _IO_fwrite (buf, size, count, fp)
if (_IO_vtable_offset (fp) != 0 || _IO_fwide (fp, -1) == -1)
written = _IO_sputn (fp, (const char *) buf, request);
_IO_release_lock (fp);
- /* We have written all of the input in case the return value indicates
- this or EOF is returned. The latter is a special case where we
- simply did not manage to flush the buffer. But the data is in the
- buffer and therefore written as far as fwrite is concerned. */
- if (written == request || written == EOF)
+ /* We are guaranteed to have written all of the input, none of it, or
+ some of it. */
+ if (written == request)
return count;
+ else if (written == EOF)
+ return 0;
else
return written / size;
}