mirror of
https://sourceware.org/git/glibc.git
synced 2025-07-30 22:43:12 +03:00
Make fwrite return 0 on EOF
This commit is contained in:
@ -1,3 +1,11 @@
|
|||||||
|
2012-11-27 Siddhesh Poyarekar <siddhesh@redhat.com>
|
||||||
|
|
||||||
|
[BZ #11741]
|
||||||
|
* libio/Makefile (tests): Add test case tst-fwrite-error.
|
||||||
|
* libio/iofwrite.c (_IO_fwrite): Return 0 on EOF.
|
||||||
|
* libio/iofwrite_u.c (fwrite_unlocked): Likewise.
|
||||||
|
* libio/tst-fwrite-error.c: New test case.
|
||||||
|
|
||||||
2012-11-26 H.J. Lu <hongjiu.lu@intel.com>
|
2012-11-26 H.J. Lu <hongjiu.lu@intel.com>
|
||||||
|
|
||||||
* elf/dl-load.c (_dl_map_object_from_fd): Cast to uintptr_t
|
* elf/dl-load.c (_dl_map_object_from_fd): Cast to uintptr_t
|
||||||
|
@ -59,7 +59,8 @@ tests = tst_swprintf tst_wprintf tst_swscanf tst_wscanf tst_getwc tst_putwc \
|
|||||||
tst-memstream1 tst-memstream2 \
|
tst-memstream1 tst-memstream2 \
|
||||||
tst-wmemstream1 tst-wmemstream2 \
|
tst-wmemstream1 tst-wmemstream2 \
|
||||||
bug-memstream1 bug-wmemstream1 \
|
bug-memstream1 bug-wmemstream1 \
|
||||||
tst-setvbuf1 tst-popen1 tst-fgetwc bug-wsetpos bug-fclose1 tst-fseek
|
tst-setvbuf1 tst-popen1 tst-fgetwc bug-wsetpos bug-fclose1 tst-fseek \
|
||||||
|
tst-fwrite-error
|
||||||
ifeq (yes,$(build-shared))
|
ifeq (yes,$(build-shared))
|
||||||
# Add test-fopenloc only if shared library is enabled since it depends on
|
# Add test-fopenloc only if shared library is enabled since it depends on
|
||||||
# shared localedata objects.
|
# shared localedata objects.
|
||||||
|
@ -42,12 +42,12 @@ _IO_fwrite (buf, size, count, fp)
|
|||||||
if (_IO_vtable_offset (fp) != 0 || _IO_fwide (fp, -1) == -1)
|
if (_IO_vtable_offset (fp) != 0 || _IO_fwide (fp, -1) == -1)
|
||||||
written = _IO_sputn (fp, (const char *) buf, request);
|
written = _IO_sputn (fp, (const char *) buf, request);
|
||||||
_IO_release_lock (fp);
|
_IO_release_lock (fp);
|
||||||
/* We have written all of the input in case the return value indicates
|
/* We are guaranteed to have written all of the input, none of it, or
|
||||||
this or EOF is returned. The latter is a special case where we
|
some of it. */
|
||||||
simply did not manage to flush the buffer. But the data is in the
|
if (written == request)
|
||||||
buffer and therefore written as far as fwrite is concerned. */
|
|
||||||
if (written == request || written == EOF)
|
|
||||||
return count;
|
return count;
|
||||||
|
else if (written == EOF)
|
||||||
|
return 0;
|
||||||
else
|
else
|
||||||
return written / size;
|
return written / size;
|
||||||
}
|
}
|
||||||
|
@ -44,12 +44,12 @@ fwrite_unlocked (buf, size, count, fp)
|
|||||||
if (_IO_fwide (fp, -1) == -1)
|
if (_IO_fwide (fp, -1) == -1)
|
||||||
{
|
{
|
||||||
written = _IO_sputn (fp, (const char *) buf, request);
|
written = _IO_sputn (fp, (const char *) buf, request);
|
||||||
/* We have written all of the input in case the return value indicates
|
/* We are guaranteed to have written all of the input, none of it, or
|
||||||
this or EOF is returned. The latter is a special case where we
|
some of it. */
|
||||||
simply did not manage to flush the buffer. But the data is in the
|
if (written == request)
|
||||||
buffer and therefore written as far as fwrite is concerned. */
|
|
||||||
if (written == request || written == EOF)
|
|
||||||
return count;
|
return count;
|
||||||
|
else if (written == EOF)
|
||||||
|
return 0;
|
||||||
}
|
}
|
||||||
|
|
||||||
return written / size;
|
return written / size;
|
||||||
|
66
libio/tst-fwrite-error.c
Normal file
66
libio/tst-fwrite-error.c
Normal file
@ -0,0 +1,66 @@
|
|||||||
|
/* Test of fwrite() function, adapted from gnulib-tests in grep.
|
||||||
|
Copyright (C) 2011-2012 Free Software Foundation, Inc.
|
||||||
|
|
||||||
|
This program is free software; you can redistribute it and/or modify
|
||||||
|
it under the terms of the GNU General Public License as published by
|
||||||
|
the Free Software Foundation; either version 3, or (at your option)
|
||||||
|
any later version.
|
||||||
|
|
||||||
|
This program is distributed in the hope that it will be useful,
|
||||||
|
but WITHOUT ANY WARRANTY; without even the implied warranty of
|
||||||
|
MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
|
||||||
|
GNU General Public License for more details.
|
||||||
|
|
||||||
|
You should have received a copy of the GNU General Public License
|
||||||
|
along with this program; if not, see <http://www.gnu.org/licenses/>. */
|
||||||
|
|
||||||
|
#include <errno.h>
|
||||||
|
#include <fcntl.h>
|
||||||
|
#include <unistd.h>
|
||||||
|
#include <stdio.h>
|
||||||
|
|
||||||
|
static int
|
||||||
|
do_test (void)
|
||||||
|
{
|
||||||
|
char tmpl[] = "/tmp/tst-fwrite-error.XXXXXX";
|
||||||
|
int fd = mkstemp (tmpl);
|
||||||
|
if (fd == -1)
|
||||||
|
{
|
||||||
|
printf ("mkstemp failed with errno %d\n", errno);
|
||||||
|
return 1;
|
||||||
|
}
|
||||||
|
FILE *fp = fdopen (fd, "w");
|
||||||
|
if (fp == NULL)
|
||||||
|
{
|
||||||
|
printf ("fdopen failed with errno %d\n", errno);
|
||||||
|
return 1;
|
||||||
|
}
|
||||||
|
|
||||||
|
char buf[5] = "world";
|
||||||
|
setvbuf (fp, NULL, _IONBF, 0);
|
||||||
|
close (fd);
|
||||||
|
unlink (tmpl);
|
||||||
|
errno = 0;
|
||||||
|
|
||||||
|
int ret = fwrite (buf, 1, sizeof (buf), fp);
|
||||||
|
if (ret != 0)
|
||||||
|
{
|
||||||
|
printf ("fwrite returned %d\n", ret);
|
||||||
|
return 1;
|
||||||
|
}
|
||||||
|
if (errno != EBADF)
|
||||||
|
{
|
||||||
|
printf ("Errno is not EBADF: %d\n", errno);
|
||||||
|
return 1;
|
||||||
|
}
|
||||||
|
if (ferror (fp) == 0)
|
||||||
|
{
|
||||||
|
printf ("ferror not set\n");
|
||||||
|
return 1;
|
||||||
|
}
|
||||||
|
|
||||||
|
return 0;
|
||||||
|
}
|
||||||
|
|
||||||
|
#define TEST_FUNCTION do_test ()
|
||||||
|
#include "../test-skeleton.c"
|
Reference in New Issue
Block a user