mirror of
https://sourceware.org/git/glibc.git
synced 2025-01-03 08:11:08 +00:00
Update.
* libio/bug-ungetwc1.c: New file. * libio/Makefile (tests): Add bug-ungetwc1. * libio/fileops.c (_IO_new_file_close_it): Only call _IO_do_flush if stream was last used for writing.
This commit is contained in:
parent
7a73a7e685
commit
3384a8d67c
@ -1,5 +1,11 @@
|
|||||||
2002-04-02 Ulrich Drepper <drepper@redhat.com>
|
2002-04-02 Ulrich Drepper <drepper@redhat.com>
|
||||||
|
|
||||||
|
* libio/bug-ungetwc1.c: New file.
|
||||||
|
* libio/Makefile (tests): Add bug-ungetwc1.
|
||||||
|
|
||||||
|
* libio/fileops.c (_IO_new_file_close_it): Only call _IO_do_flush
|
||||||
|
if stream was last used for writing.
|
||||||
|
|
||||||
* elf/do-lookup.h (do_lookup): 2 is the first user-defined version
|
* elf/do-lookup.h (do_lookup): 2 is the first user-defined version
|
||||||
number [PR libc/3111].
|
number [PR libc/3111].
|
||||||
|
|
||||||
|
@ -48,7 +48,8 @@ routines := \
|
|||||||
|
|
||||||
tests = tst_swprintf tst_wprintf tst_swscanf tst_wscanf tst_getwc tst_putwc \
|
tests = tst_swprintf tst_wprintf tst_swscanf tst_wscanf tst_getwc tst_putwc \
|
||||||
tst_wprintf2 tst-widetext test-fmemopen tst-ext tst-fopenloc \
|
tst_wprintf2 tst-widetext test-fmemopen tst-ext tst-fopenloc \
|
||||||
tst-fgetws tst-ungetwc1 tst-ungetwc2 tst-swscanf tst-sscanf
|
tst-fgetws tst-ungetwc1 tst-ungetwc2 tst-swscanf tst-sscanf \
|
||||||
|
bug-ungetwc1
|
||||||
test-srcs = test-freopen
|
test-srcs = test-freopen
|
||||||
|
|
||||||
all: # Make this the default target; it will be defined in Rules.
|
all: # Make this the default target; it will be defined in Rules.
|
||||||
|
74
libio/bug-ungetwc1.c
Normal file
74
libio/bug-ungetwc1.c
Normal file
@ -0,0 +1,74 @@
|
|||||||
|
#define _XOPEN_SOURCE 500
|
||||||
|
#include <stdio.h>
|
||||||
|
#include <stdlib.h>
|
||||||
|
#include <locale.h>
|
||||||
|
#include <wchar.h>
|
||||||
|
|
||||||
|
const char write_chars[] = "ABC"; /* Characters on testfile. */
|
||||||
|
const wint_t unget_wchar = L'A'; /* Ungotten wide character. */
|
||||||
|
|
||||||
|
char *fname;
|
||||||
|
|
||||||
|
|
||||||
|
static int do_test (void);
|
||||||
|
#define TEST_FUNCTION do_test ()
|
||||||
|
|
||||||
|
#include "../test-skeleton.c"
|
||||||
|
|
||||||
|
|
||||||
|
static int
|
||||||
|
do_test (void)
|
||||||
|
{
|
||||||
|
wint_t wc;
|
||||||
|
FILE *fp;
|
||||||
|
int fd;
|
||||||
|
|
||||||
|
fname = (char *) malloc (strlen (test_dir) + sizeof "/bug-ungetwc1.XXXXXX");
|
||||||
|
if (fname == NULL)
|
||||||
|
{
|
||||||
|
puts ("no memory");
|
||||||
|
return 1;
|
||||||
|
}
|
||||||
|
strcpy (stpcpy (fname, test_dir), "/bug-ungetwc1.XXXXXX");
|
||||||
|
fd = mkstemp (fname);
|
||||||
|
if (fd == -1)
|
||||||
|
{
|
||||||
|
printf ("cannot open temporary file: %m\n");
|
||||||
|
return 1;
|
||||||
|
}
|
||||||
|
|
||||||
|
setlocale(LC_ALL, "");
|
||||||
|
|
||||||
|
/* Output to the file. */
|
||||||
|
if ((fp = fdopen (fd, "w")) == NULL)
|
||||||
|
{
|
||||||
|
fprintf (stderr, "Cannot make `%s' file\n", fname);
|
||||||
|
exit (EXIT_FAILURE);
|
||||||
|
}
|
||||||
|
add_temp_file (fname);
|
||||||
|
|
||||||
|
fprintf (fp, "%s", write_chars);
|
||||||
|
fclose (fp);
|
||||||
|
|
||||||
|
/* Read from the file. */
|
||||||
|
fp = fopen (fname, "r");
|
||||||
|
|
||||||
|
while (!feof (fp))
|
||||||
|
wc = getwc (fp);
|
||||||
|
printf ("\nThe end-of-file indicator is set.\n");
|
||||||
|
|
||||||
|
/* Unget a wide character. */
|
||||||
|
ungetwc (unget_wchar, fp);
|
||||||
|
printf ("< `%lc' is ungotten.\n", unget_wchar);
|
||||||
|
|
||||||
|
/* Check the end-of-file indicator. */
|
||||||
|
if (feof (fp))
|
||||||
|
printf ("The end-of-file indicator is still set.\n");
|
||||||
|
else
|
||||||
|
printf ("The end-of-file flag is cleared.\n");
|
||||||
|
|
||||||
|
fflush (stdout);
|
||||||
|
fclose (fp);
|
||||||
|
|
||||||
|
return 0;
|
||||||
|
}
|
@ -161,7 +161,11 @@ _IO_new_file_close_it (fp)
|
|||||||
if (!_IO_file_is_open (fp))
|
if (!_IO_file_is_open (fp))
|
||||||
return EOF;
|
return EOF;
|
||||||
|
|
||||||
write_status = _IO_do_flush (fp);
|
if ((fp->_flags & _IO_NO_WRITES) == 0
|
||||||
|
&& (fp->_flags & _IO_CURRENTLY_PUTTING) != 0)
|
||||||
|
write_status = _IO_do_flush (fp);
|
||||||
|
else
|
||||||
|
write_status = 0;
|
||||||
|
|
||||||
INTUSE(_IO_unsave_markers) (fp);
|
INTUSE(_IO_unsave_markers) (fp);
|
||||||
|
|
||||||
|
Loading…
Reference in New Issue
Block a user