From f2a8406a4f5974230d33995105160a8bacbce500 Mon Sep 17 00:00:00 2001 From: Ulrich Drepper Date: Thu, 8 Nov 2007 00:04:24 +0000 Subject: [BZ #5277] 2007-11-07 Ulrich Drepper [BZ #5277] * iconv/loop.c (STANDARD_TO_LOOP_ERR_HANDLER): If conversion failed because output buffer is too small break, don't loop. * iconvdata/Makefile (tests): Add bug-iconv6. * iconvdata/bug-iconv6.c: New file. --- ChangeLog | 8 ++++++++ iconv/loop.c | 7 ++++++- iconvdata/Makefile | 2 +- iconvdata/bug-iconv6.c | 52 ++++++++++++++++++++++++++++++++++++++++++++++++ localedata/ChangeLog | 5 +++++ localedata/locales/lo_LA | 8 ++++---- 6 files changed, 76 insertions(+), 6 deletions(-) create mode 100644 iconvdata/bug-iconv6.c diff --git a/ChangeLog b/ChangeLog index 6ec0b86..1717871 100644 --- a/ChangeLog +++ b/ChangeLog @@ -1,3 +1,11 @@ +2007-11-07 Ulrich Drepper + + [BZ #5277] + * iconv/loop.c (STANDARD_TO_LOOP_ERR_HANDLER): If conversion failed + because output buffer is too small break, don't loop. + * iconvdata/Makefile (tests): Add bug-iconv6. + * iconvdata/bug-iconv6.c: New file. + 2007-11-06 Ulrich Drepper * stdio-common/vfprintf.c (vfprintf): Compute necessary buffer size diff --git a/iconv/loop.c b/iconv/loop.c index 9785bf8..df8c8dc 100644 --- a/iconv/loop.c +++ b/iconv/loop.c @@ -225,7 +225,12 @@ } \ /* If any of them recognized the input continue with the loop. */ \ if (result != __GCONV_ILLEGAL_INPUT) \ - continue; \ + { \ + if (__builtin_expect (result == __GCONV_FULL_OUTPUT, 0)) \ + break; \ + \ + continue; \ + } \ \ /* Next see whether we have to ignore the error. If not, stop. */ \ if (! ignore_errors_p ()) \ diff --git a/iconvdata/Makefile b/iconvdata/Makefile index bf52d52..ca4c713 100644 --- a/iconvdata/Makefile +++ b/iconvdata/Makefile @@ -67,7 +67,7 @@ include ../Makeconfig ifeq (yes,$(build-shared)) tests = bug-iconv1 bug-iconv2 tst-loading tst-e2big tst-iconv4 bug-iconv4 \ - tst-iconv6 bug-iconv5 + tst-iconv6 bug-iconv5 bug-iconv6 ifeq ($(have-thread-library),yes) tests += bug-iconv3 endif diff --git a/iconvdata/bug-iconv6.c b/iconvdata/bug-iconv6.c new file mode 100644 index 0000000..f920954 --- /dev/null +++ b/iconvdata/bug-iconv6.c @@ -0,0 +1,52 @@ +#include +#include +#include +#include +#include +#include + +static const char testbuf[] = { + 0xEF, 0xBE, 0x9F, 0xD0, 0xB4, 0xEF, 0xBE, 0x9F, 0x29, 0xEF, 0xBE, 0x8E, + 0xEF, 0xBE, 0x9F, 0xEF, 0xBD, 0xB6, 0xEF, 0xBD, 0xB0, 0xEF, 0xBE, 0x9D +}; + +static int +do_test (void) +{ + setlocale (LC_ALL, "en_US.UTF-8"); + iconv_t ic = iconv_open ("ISO-2022-JP//TRANSLIT", "UTF-8"); + if (ic == (iconv_t) -1) + { + puts ("iconv_open failed"); + return 1; + } + size_t outremain = sizeof testbuf; + char outbuf[outremain]; + char *inp = (char *) testbuf; + char *outp = outbuf; + size_t inremain = sizeof testbuf; + + int ret = iconv (ic, &inp, &inremain, &outp, &outremain); + + int result = 0; + if (ret == (size_t) -1) + { + if (errno == E2BIG) + puts ("buffer too small reported. OK"); + else + { + printf ("iconv failed with %d (%m)\n", errno); + result = 0; + } + } + else + { + printf ("iconv returned %d\n", ret); + result = 1; + } + + return result; +} + +#define TEST_FUNCTION do_test () +#include "../test-skeleton.c" diff --git a/localedata/ChangeLog b/localedata/ChangeLog index 507a679..f7c6c08 100644 --- a/localedata/ChangeLog +++ b/localedata/ChangeLog @@ -1,3 +1,8 @@ +2007-11-07 Ulrich Drepper + + [BZ #5237] + * locales/lo_LA: Fix typos in collation symbols. + 2007-11-06 Ulrich Drepper * locales/dz_BT: Fix representation of data. diff --git a/localedata/locales/lo_LA b/localedata/locales/lo_LA index cc764e1..29ab3f3 100644 --- a/localedata/locales/lo_LA +++ b/localedata/locales/lo_LA @@ -602,10 +602,10 @@ UNDEFINED IGNORE;IGNORE;IGNORE;IGNORE ;;; % Lao CHARACTER HHOr "";;; - "";;; - "";;; - "";;; - "";;; + "";;; + "";;; + "";;; + "";;; % order of Lao vowels -- cgit v1.1