diff options
-rw-r--r-- | ChangeLog | 9 | ||||
-rw-r--r-- | libio/fmemopen.c | 10 | ||||
-rw-r--r-- | libio/iofopncook.c | 3 | ||||
-rw-r--r-- | localedata/ChangeLog | 65 | ||||
-rw-r--r-- | stdio-common/tst-fmemopen.c | 111 |
5 files changed, 194 insertions, 4 deletions
diff --git a/ChangeLog b/ChangeLog index a9c9b69eca..78e5d31bb2 100644 --- a/ChangeLog +++ b/ChangeLog @@ -1,5 +1,14 @@ 2000-10-30 Ulrich Drepper <drepper@redhat.com> + * stdio-common/Makefile (tests): Add tst-fmemopen. + * stdio-common/tst-fmemopen.c: New file. + Test case by Ben Collins <bcollins@debian.org>. + + * libio/iofopncook.c (_IO_cookie_seek): Correct test for error. + + * libio/fmemopen.c (fmemopen_read): Return 0 at end of buffer. + (fmemopen_write): Set errno at end of buffer. + * posix/runtests.c (main): Don't use exit() to avoid warning with broken compilers. diff --git a/libio/fmemopen.c b/libio/fmemopen.c index 92df2e4424..99670b5c58 100644 --- a/libio/fmemopen.c +++ b/libio/fmemopen.c @@ -69,6 +69,7 @@ * so I don't need the stream to add null characters on its own.) */ +#include <errno.h> #include <libio.h> #include <stdio.h> #include <stdlib.h> @@ -96,7 +97,7 @@ fmemopen_read (void *cookie, char *b, size_t s) if (c->pos + s > c->size) { if (c->pos == c->size) - return -1; + return 0; s = c->size - c->pos; } @@ -123,7 +124,10 @@ fmemopen_write (void *cookie, const char *b, size_t s) if (c->pos + s + addnullc > c->size) { if (c->pos + addnullc == c->size) - return -1; + { + __set_errno (ENOSPC); + return -1; + } s = c->size - c->pos - addnullc; } @@ -142,7 +146,7 @@ fmemopen_write (void *cookie, const char *b, size_t s) int -fmemopen_seek (void *cookie, _IO_off64_t * p, int w) +fmemopen_seek (void *cookie, _IO_off64_t *p, int w) { _IO_off64_t np; fmemopen_cookie_t *c; diff --git a/libio/iofopncook.c b/libio/iofopncook.c index c016cfb1d5..52e025b4c9 100644 --- a/libio/iofopncook.c +++ b/libio/iofopncook.c @@ -76,7 +76,8 @@ _IO_cookie_seek (fp, offset, dir) return ((cfile->__io_functions.seek == NULL || (cfile->__io_functions.seek (cfile->__cookie, &offset, dir) - == (_IO_off64_t) -1)) + == -1) + || offset == (_IO_off64_t) -1) ? _IO_pos_BAD : offset); } diff --git a/localedata/ChangeLog b/localedata/ChangeLog index ed2fe80e99..e420ad0bde 100644 --- a/localedata/ChangeLog +++ b/localedata/ChangeLog @@ -1,3 +1,68 @@ +2000-10-29 Bruno Haible <haible@clisp.cons.org> + + * locales/translit_hangul: New file. + * locales/ko_KR (LC_CTYPE): Include it. + +2000-10-29 Bruno Haible <haible@clisp.cons.org> + + * locales/translit_cjk_variants: New file. + * locales/ja_JP (LC_CTYPE): Include it. + +2000-10-29 Bruno Haible <haible@clisp.cons.org> + + * locales/da_DK (LC_CTYPE): Include translit_combining, add A-ring + transliteration rules. + +2000-10-29 Bruno Haible <haible@clisp.cons.org> + + * locales/de_DE (LC_CTYPE): Include translit_combining, add umlaut + transliteration rules. + * locales/de_AT (LC_CTYPE): Include de_DE instead of i18n. + * locales/de_BE (LC_CTYPE): Likewise. + * locales/de_CH (LC_CTYPE): Likewise. + * locales/de_LU (LC_CTYPE): Likewise. + * locales/de_DE@euro (LC_CTYPE): Include de_DE instead of i18n. + * locales/de_AT@euro (LC_CTYPE): Include de_AT instead of i18n. + * locales/de_BE@euro (LC_CTYPE): Include de_BE instead of i18n. + * locales/de_LU@euro (LC_CTYPE): Include de_LU instead of i18n. + +2000-10-29 Bruno Haible <haible@clisp.cons.org> + + * locales/translit_combining: New file. + * locales/fr_FR (LC_CTYPE): Include it. + * locales/fr_BE (LC_CTYPE): Include fr_FR instead of i18n. + * locales/fr_CA (LC_CTYPE): Likewise. + * locales/fr_CH (LC_CTYPE): Likewise. + * locales/fr_LU (LC_CTYPE): Likewise. + * locales/fr_FR@euro (LC_CTYPE): Include fr_FR instead of i18n. + * locales/fr_BE@euro (LC_CTYPE): Include fr_BE instead of i18n. + * locales/fr_LU@euro (LC_CTYPE): Include fr_LU instead of i18n. + +2000-10-29 Bruno Haible <haible@clisp.cons.org> + + * locales/translit_wide: New file. + * locales/translit_narrow: New file. + * locales/translit_font: New file. + * locales/translit_circle: New file. + * locales/translit_small: New file. + * locales/translit_fraction: New file. + * locales/translit_compat: New file. + * locales/translit_cjk_compat: New file. + * locales/translit_neutral: New file. Include all of the above. + * locales/i18n (LC_CTYPE): Include translit_neutral. Remove a few + German and Danish specific rules. + +2000-10-29 Bruno Haible <haible@clisp.cons.org> + + * locales/ja_JP (LC_CTYPE): Refer to "i18n" instead of duplicating it. + * locales/zh_CN (LC_CTYPE): Likewise. + * locales/ko_KR (LC_CTYPE): Likewise. + +2000-10-29 Bruno Haible <haible@clisp.cons.org> + + * charmaps/UTF-8: Set width of U200B to 0. + * charmaps/GB18030: Likewise. + 2000-10-29 Ulrich Drepper <drepper@redhat.com> * charmaps/BIG5: Update. diff --git a/stdio-common/tst-fmemopen.c b/stdio-common/tst-fmemopen.c new file mode 100644 index 0000000000..f22ebd52fe --- /dev/null +++ b/stdio-common/tst-fmemopen.c @@ -0,0 +1,111 @@ +#include <errno.h> +#include <fcntl.h> +#include <stdio.h> +#include <stdlib.h> +#include <string.h> +#include <unistd.h> +#include <sys/mman.h> +#include <sys/stat.h> +#include <sys/types.h> + +#define TEST_FILE "test-1" + +int +main (void) +{ + const char blah[] = "BLAH"; + FILE *fp; + char *mmap_data; + int ch, fd; + struct stat fs; + const char *cp; + + /* setup the physical file, and use it */ + if ((fp = fopen (TEST_FILE, "w+")) == NULL) + exit (1); + if (fwrite (blah, 1, strlen (blah), fp) != strlen (blah)) + exit (2); + + rewind (fp); + printf ("file: "); + cp = blah; + while ((ch = getc (fp)) != EOF) + { + fputc (ch, stdout); + if (ch != *cp) + { + printf ("\ncharacter %d: '%c' instead of '%c'\n", + cp - blah, ch, *cp); + exit (1); + } + ++cp; + } + fputc ('\n', stdout); + if (ferror (fp)) + { + puts ("fp: error"); + exit (1); + } + if (feof (fp)) + printf ("fp: EOF\n"); + else + { + puts ("not EOF"); + exit (1); + } + fclose (fp); + + /* Now, mmap the file into a buffer, and do that too */ + if ((fd = open (TEST_FILE, O_RDONLY)) == -1) + exit (3); + if (fstat (fd, &fs) == -1) + exit (4); + + if ((mmap_data = (char *) mmap (NULL, fs.st_size, PROT_READ, + MAP_SHARED, fd, 0)) == NULL) + { + if (errno == ENOSYS) + exit (0); + exit (5); + } + + if ((fp = fmemopen (mmap_data, fs.st_size, "r")) == NULL) + exit (1); + + printf ("mem: "); + cp = blah; + while ((ch = getc (fp)) != EOF) + { + fputc (ch, stdout); + if (ch != *cp) + { + printf ("%d character: '%c' instead of '%c'\n", + cp - blah, ch, *cp); + exit (1); + } + ++cp; + } + + fputc ('\n', stdout); + + if (ferror (fp)) + { + puts ("fp: error"); + exit (1); + } + if (feof (fp)) + printf ("fp: EOF\n"); + else + { + puts ("not EOF"); + exit (1); + } + + fclose (fp); + + munmap (mmap_data, fs.st_size); + + unlink (TEST_FILE); + + return 0; +} |