diff options
author | Ulrich Drepper <drepper@redhat.com> | 2006-12-13 23:17:54 +0000 |
---|---|---|
committer | Ulrich Drepper <drepper@redhat.com> | 2006-12-13 23:17:54 +0000 |
commit | 1e88bd0f1b62bd58f283241877a0b3e66e199e76 (patch) | |
tree | 5c7c36e5188e78363b6fb79df0b6b7a843511dbd /libio/tst-setvbuf1.c | |
parent | f72386ad7c5009995612b4117a34de8c96d1509c (diff) | |
download | glibc-1e88bd0f1b62bd58f283241877a0b3e66e199e76.zip glibc-1e88bd0f1b62bd58f283241877a0b3e66e199e76.tar.gz glibc-1e88bd0f1b62bd58f283241877a0b3e66e199e76.tar.bz2 |
[BZ #2337]
2006-12-13 Ulrich Drepper <drepper@redhat.com>
[BZ #2337]
* libio/Makefile (tests): Add tst-setvbuf1.
* libio/tst-setvbuf1.c: New file.
2006-12-08 Jakub Jelinek <jakub@redhat.com>
[BZ #2337]
* libio/genops.c (__uflow): Fix a typo.
* libio/wfiledoalloc.c (_IO_wfile_doallocate): Don't stat
nor set _IO_LINE_BUF bit here. Size the wide buffer based on
the narrow buffer size.
2006-11-24 Jakub Jelinek <jakub@redhat.com>
[BZ #2337]
* libio/libio.h (_IO_FLAGS2_USER_WBUF): Define.
* libio/wgenops.c (_IO_wsetb, _IO_wdefault_finish): Test and set
_IO_FLAGS2_USER_WBUF bit in _flags2 instead of _IO_USER_BUF bit
in _flags.
* libio/wstrops.c (_IO_wstr_overflow, enlarge_userbuf,
_IO_wstr_finish): Likewise.
* libio/wmemstream.c (open_wmemstream): Likewise.
* libio/fileops.c (_IO_new_file_close_it): Call _IO_set[bgp]
even for wide streams.
Diffstat (limited to 'libio/tst-setvbuf1.c')
-rw-r--r-- | libio/tst-setvbuf1.c | 39 |
1 files changed, 39 insertions, 0 deletions
diff --git a/libio/tst-setvbuf1.c b/libio/tst-setvbuf1.c new file mode 100644 index 0000000..9222d40 --- /dev/null +++ b/libio/tst-setvbuf1.c @@ -0,0 +1,39 @@ +/* Dereived from the test case in BZ #2337. */ +#include <errno.h> +#include <error.h> +#include <fcntl.h> +#include <locale.h> +#include <stdio.h> +#include <stdlib.h> +#include <string.h> +#include <unistd.h> +#include <wchar.h> + + +static char buf[512] __attribute__ ((aligned (4096))); + + +static int +do_test (void) +{ + setlocale (LC_ALL, "de_DE.UTF-8"); + + FILE *fp = fdopen (dup (STDOUT_FILENO), "a"); + if (fp == NULL) + error (EXIT_FAILURE, errno, "fdopen(,\"a\")"); + + setvbuf (fp, buf, _IOFBF, sizeof (buf)); + + /* fwprintf to unbuffered stream. */ + fwprintf (fp, L"hello.\n"); + + fclose (fp); + + /* touch my buffer */ + buf[45] = 'a'; + + return 0; +} + +#define TEST_FUNCTION do_test () +#include "../test-skeleton.c" |