From: Benjamin Kosnik Date: Fri, 24 May 2002 16:15:27 +0000 (+0000) Subject: [multiple changes] X-Git-Tag: releases/gcc-3.1.1~277 X-Git-Url: http://git.ipfire.org/cgi-bin/gitweb.cgi?a=commitdiff_plain;h=fb4386599d52976fc7b5fa55fde3b7250fe92f75;p=thirdparty%2Fgcc.git [multiple changes] 2002-05-24 Benjamin Kosnik PR libstdc++/6701 * testsuite/22_locale/ctype_narrow_char.cc: New. * testsuite/22_locale/ctype_narrow_wchar_t.cc: New. * testsuite/22_locale/ctype_widen_char.cc: New. * testsuite/22_locale/ctype_widen_wchar_t.cc: New. * testsuite/22_locale/ctype_members_char.cc: Move some bits into... * testsuite/22_locale/ctype_is_char.cc: ...this. * testsuite/22_locale/ctype_to_char.cc: ...and this. * testsuite/22_locale/ctype_members_wchar_t.cc: Move some bits into... * testsuite/22_locale/ctype_is_wchar_t.cc: ...this. * testsuite/22_locale/ctype_to_wchar_t.cc: ...and this. * testsuite/22_locale/ctype_scan_wchar_t.cc: Should pass. 2002-05-24 Dale Peakall PR libstdc++/6701 * config/locale/gnu/ctype_members.cc (ctype::do_narrow): Fix. * config/locale/generic/ctype_members.cc: Same. From-SVN: r53843 --- diff --git a/libstdc++-v3/ChangeLog b/libstdc++-v3/ChangeLog index b2d841071525..e33faef1a21e 100644 --- a/libstdc++-v3/ChangeLog +++ b/libstdc++-v3/ChangeLog @@ -1,3 +1,25 @@ +2002-05-24 Benjamin Kosnik + + PR libstdc++/6701 + * testsuite/22_locale/ctype_narrow_char.cc: New. + * testsuite/22_locale/ctype_narrow_wchar_t.cc: New. + * testsuite/22_locale/ctype_widen_char.cc: New. + * testsuite/22_locale/ctype_widen_wchar_t.cc: New. + * testsuite/22_locale/ctype_members_char.cc: Move some bits into... + * testsuite/22_locale/ctype_is_char.cc: ...this. + * testsuite/22_locale/ctype_to_char.cc: ...and this. + * testsuite/22_locale/ctype_members_wchar_t.cc: Move some bits into... + * testsuite/22_locale/ctype_is_wchar_t.cc: ...this. + * testsuite/22_locale/ctype_to_wchar_t.cc: ...and this. + + * testsuite/22_locale/ctype_scan_wchar_t.cc: Should pass. + +2002-05-24 Dale Peakall + + PR libstdc++/6701 + * config/locale/gnu/ctype_members.cc (ctype::do_narrow): Fix. + * config/locale/generic/ctype_members.cc: Same. + 2002-05-24 Benjamin Kosnik PR libstdc++/6750 diff --git a/libstdc++-v3/config/locale/generic/ctype_members.cc b/libstdc++-v3/config/locale/generic/ctype_members.cc index 5a66484f199a..f147983c6a2a 100644 --- a/libstdc++-v3/config/locale/generic/ctype_members.cc +++ b/libstdc++-v3/config/locale/generic/ctype_members.cc @@ -1,6 +1,6 @@ // std::ctype implementation details, generic version -*- C++ -*- -// Copyright (C) 2001 Free Software Foundation, Inc. +// Copyright (C) 2001, 2002 Free Software Foundation, Inc. // // This file is part of the GNU ISO C++ Library. This library is free // software; you can redistribute it and/or modify it under the @@ -183,12 +183,23 @@ namespace std do_narrow(const wchar_t* __lo, const wchar_t* __hi, char __dfault, char* __dest) const { - mbstate_t __state; - memset(static_cast(&__state), 0, sizeof(mbstate_t)); - size_t __len = __hi - __lo; - size_t __conv = wcsrtombs(__dest, &__lo, __len, &__state); - if (__conv == __len) - *__dest = __dfault; + size_t __offset = 0; + while (true) + { + const wchar_t* __start = __lo + __offset; + size_t __len = __hi - __start; + + mbstate_t __state; + memset(static_cast(&__state), 0, sizeof(mbstate_t)); + size_t __con = wcsrtombs(__dest + __offset, &__start, __len, &__state); + if (__con != __len && __start != 0) + { + __offset = __start - __lo; + __dest[__offset++] = __dfault; + } + else + break; + } return __hi; } #endif // _GLIBCPP_USE_WCHAR_T diff --git a/libstdc++-v3/config/locale/gnu/ctype_members.cc b/libstdc++-v3/config/locale/gnu/ctype_members.cc index 090738bf5b61..de83683934a5 100644 --- a/libstdc++-v3/config/locale/gnu/ctype_members.cc +++ b/libstdc++-v3/config/locale/gnu/ctype_members.cc @@ -190,12 +190,23 @@ namespace std do_narrow(const wchar_t* __lo, const wchar_t* __hi, char __dfault, char* __dest) const { - mbstate_t __state; - memset(static_cast(&__state), 0, sizeof(mbstate_t)); - size_t __len = __hi - __lo; - size_t __conv = wcsrtombs(__dest, &__lo, __len, &__state); - if (__conv == __len) - *__dest = __dfault; + size_t __offset = 0; + while (true) + { + const wchar_t* __start = __lo + __offset; + size_t __len = __hi - __start; + + mbstate_t __state; + memset(static_cast(&__state), 0, sizeof(mbstate_t)); + size_t __con = wcsrtombs(__dest + __offset, &__start, __len, &__state); + if (__con != __len && __start != 0) + { + __offset = __start - __lo; + __dest[__offset++] = __dfault; + } + else + break; + } return __hi; } #endif // _GLIBCPP_USE_WCHAR_T diff --git a/libstdc++-v3/testsuite/22_locale/ctype_members_char.cc b/libstdc++-v3/testsuite/22_locale/ctype_members_char.cc index b61dabf56e35..54fc5d3e91df 100644 --- a/libstdc++-v3/testsuite/22_locale/ctype_members_char.cc +++ b/libstdc++-v3/testsuite/22_locale/ctype_members_char.cc @@ -30,210 +30,8 @@ // 22.2.1.3.2 ctype members #include -#include #include -// XXX This test (test02) is not working for non-glibc locale models. -// { dg-do run { xfail *-*-* } } - -class gnu_ctype: public std::ctype { }; - -void test01() -{ - bool test = true; - const char strlit00[] = "manilla, cebu, tandag PHILIPPINES"; - const char strlit01[] = "MANILLA, CEBU, TANDAG PHILIPPINES"; - const char strlit02[] = "manilla, cebu, tandag philippines"; - const char c00 = 'S'; - const char c10 = 's'; - const char c20 = '9'; - const char c30 = ' '; - const char c40 = '!'; - const char c50 = 'F'; - const char c60 = 'f'; - const char c70 = 'X'; - const char c80 = 'x'; - - gnu_ctype gctype; - char c100; - int len = std::char_traits::length(strlit00); - char c_array[len + 1]; - - // sanity check ctype_base::mask members - int i01 = std::ctype_base::space; - int i02 = std::ctype_base::upper; - int i03 = std::ctype_base::lower; - int i04 = std::ctype_base::digit; - int i05 = std::ctype_base::punct; - int i06 = std::ctype_base::alpha; - int i07 = std::ctype_base::xdigit; - int i08 = std::ctype_base::alnum; - int i09 = std::ctype_base::graph; - int i10 = std::ctype_base::print; - int i11 = std::ctype_base::cntrl; - int i12 = sizeof(std::ctype_base::mask); - VERIFY ( i01 != i02); - VERIFY ( i02 != i03); - VERIFY ( i03 != i04); - VERIFY ( i04 != i05); - VERIFY ( i05 != i06); - VERIFY ( i06 != i07); - VERIFY ( i07 != i08); - VERIFY ( i08 != i09); - VERIFY ( i09 != i10); - VERIFY ( i10 != i11); - VERIFY ( i11 != i01); - - // bool is(mask m, char c) const; - VERIFY( gctype.is(std::ctype_base::space, c30) ); - VERIFY( gctype.is(std::ctype_base::upper, c00) ); - VERIFY( gctype.is(std::ctype_base::lower, c10) ); - VERIFY( gctype.is(std::ctype_base::digit, c20) ); - VERIFY( gctype.is(std::ctype_base::punct, c40) ); - VERIFY( gctype.is(std::ctype_base::alpha, c50) ); - VERIFY( gctype.is(std::ctype_base::alpha, c60) ); - VERIFY( gctype.is(std::ctype_base::xdigit, c20) ); - VERIFY( !gctype.is(std::ctype_base::xdigit, c80) ); - VERIFY( gctype.is(std::ctype_base::alnum, c50) ); - VERIFY( gctype.is(std::ctype_base::alnum, c20) ); - VERIFY( gctype.is(std::ctype_base::graph, c40) ); - VERIFY( gctype.is(std::ctype_base::graph, c20) ); - - // const char* is(const char* low, const char* high, mask* vec) const - std::ctype_base::mask m00 = static_cast(0); - std::ctype_base::mask m01[3]; - std::ctype_base::mask m02[13]; - const char* cc0 = strlit00; - const char* cc1 = NULL; - const char* cc2 = NULL; - - cc0 = strlit00; - m01[0] = m00; - m01[1] = m00; - m01[2] = m00; - cc1 = gctype.is(cc0, cc0, m01); - VERIFY( cc1 == strlit00 ); - VERIFY( m01[0] == m00 ); - VERIFY( m01[1] == m00 ); - VERIFY( m01[2] == m00 ); - - cc0 = strlit00; - m01[0] = m00; - m01[1] = m00; - m01[2] = m00; - cc2 = gctype.is(cc0, cc0 + 3, m01); - VERIFY( cc2 == strlit00 + 3); - VERIFY( m01[0] != m00 ); - VERIFY( m01[1] != m00 ); - VERIFY( m01[2] != m00 ); - VERIFY( gctype.is(m01[0], cc0[0]) ); - VERIFY( gctype.is(m01[1], cc0[1]) ); - VERIFY( gctype.is(m01[2], cc0[2]) ); - - cc0 = strlit01; - cc1 = gctype.is(cc0, cc0 + 13, m02); - VERIFY( cc1 == strlit01 + 13); - VERIFY( m02[6] != m00 ); - VERIFY( m02[7] != m00 ); - VERIFY( m02[8] != m00 ); - VERIFY( m02[8] != m02[6] ); - VERIFY( m02[6] != m02[7] ); - VERIFY( static_cast(m02[6] & std::ctype_base::alnum) ); - VERIFY( static_cast(m02[6] & std::ctype_base::upper) ); - VERIFY( static_cast(m02[6] & std::ctype_base::alpha) ); - VERIFY( static_cast(m02[7] & std::ctype_base::punct) ); - VERIFY( static_cast(m02[8] & std::ctype_base::space) ); - VERIFY( gctype.is(m02[6], cc0[6]) ); - VERIFY( gctype.is(m02[7], cc0[7]) ); - VERIFY( gctype.is(m02[8], cc0[8]) ); - - // char toupper(char c) const - c100 = gctype.toupper(c10); - VERIFY( c100 == c00 ); - - // char tolower(char c) const - c100 = gctype.tolower(c00); - VERIFY( c100 == c10 ); - - // char toupper(char* low, const char* hi) const - std::char_traits::copy(c_array, strlit02, len + 1); - gctype.toupper(c_array, c_array + len); - VERIFY( !std::char_traits::compare(c_array, strlit01, len - 1) ); - - // char tolower(char* low, const char* hi) const - std::char_traits::copy(c_array, strlit01, len + 1); - gctype.tolower(c_array, c_array + len); - VERIFY( !std::char_traits::compare(c_array, strlit02, len - 1) ); - - -#ifdef DEBUG_ASSERT - assert(test); -#endif -} - -// libstdc++/4456, libstdc++/4457, libstdc++/4458 -void test02() -{ - using namespace std; - typedef ctype_base::mask mask; - typedef vector vector_type; - - bool test = true; - - // const int max = numeric_limits::max(); - const int max = 255; - const int ctype_mask_max = 10; - vector_type v_c(max); - vector_type v_de(max); - - // "C" - locale loc_c = locale::classic(); - const ctype& ctype_c = use_facet >(loc_c); - for (int i = 0; i < max; ++i) - { - char c = static_cast(i); - mask mask_test = static_cast(0); - mask mask_is = static_cast(0); - for (int j = 0; j <= ctype_mask_max; ++j) - { - mask_test = static_cast(1 << j); - if (ctype_c.is(mask_test, c)) - mask_is |= mask_test; - } - v_c[i] = mask_is; - } - - // "de_DE" - locale loc_de("de_DE"); - const ctype& ctype_de = use_facet >(loc_de); - for (int i = 0; i < max; ++i) - { - char c = static_cast(i); - mask mask_test = static_cast(0); - mask mask_is = static_cast(0); - for (int j = 0; j <= ctype_mask_max; ++j) - { - mask_test = static_cast(1 << j); - if (ctype_de.is(mask_test, c)) - mask_is |= mask_test; - } - v_de[i] = mask_is; - } - -#if QUANNUM_VERBOSE_LYRICALLY_ADEPT_BAY_AREA_MCS_MODE - for (int i = 0; i < max; ++i) - { - char mark = v_c[i] == v_de[i] ? ' ' : '-'; - cout << i << ' ' << mark << ' ' << static_cast(i) << '\t' ; - cout << "v_c: " << setw(4) << v_c[i] << '\t'; - cout << "v_de: " << setw(4) << v_de[i] << endl; - } - cout << (v_c == v_de) << endl; -#endif - - VERIFY( v_c != v_de ); -} - // Dietmar Kühl via Peter Schmid class comma_ctype: public std::ctype { @@ -243,66 +41,7 @@ public: { classic_table(); } }; -// Per Liboriussen -void test03() -{ - bool test = true; - std::ctype_base::mask maskdata[256]; - for (int i = 0; i < 256; ++i) - maskdata[i] = std::ctype_base::alpha; - std::ctype* f = new std::ctype(maskdata); - std::locale global; - std::locale loc(global, f); - for (int i = 0; i < 256; ++i) - { - char ch = i; - VERIFY( std::isalpha(ch, loc) ); - } -} - -// libstdc++/5280 -void test04() -{ -#ifdef _GLIBCPP_HAVE_SETENV - // Set the global locale to non-"C". - std::locale loc_de("de_DE"); - std::locale::global(loc_de); - - // Set LANG environment variable to de_DE. - const char* oldLANG = getenv("LANG"); - if (!setenv("LANG", "de_DE", 1)) - { - test01(); - test02(); - test03(); - setenv("LANG", oldLANG ? oldLANG : "", 1); - } -#endif -} - -// http://gcc.gnu.org/ml/libstdc++/2002-05/msg00038.html -void test05() -{ - bool test = true; - - const char* tentLANG = setlocale(LC_ALL, "ja_JP.eucjp"); - if (tentLANG != NULL) - { - std::string preLANG = tentLANG; - test01(); - test02(); - test03(); - std::string postLANG = setlocale(LC_ALL, NULL); - VERIFY( preLANG == postLANG ); - } -} - int main() { - test01(); - test02(); - test03(); - test04(); - test05(); return 0; } diff --git a/libstdc++-v3/testsuite/22_locale/ctype_members_wchar_t.cc b/libstdc++-v3/testsuite/22_locale/ctype_members_wchar_t.cc index 405cddc4eb3b..31b1bcbf1608 100644 --- a/libstdc++-v3/testsuite/22_locale/ctype_members_wchar_t.cc +++ b/libstdc++-v3/testsuite/22_locale/ctype_members_wchar_t.cc @@ -30,104 +30,12 @@ // 22.2.1.3.2 ctype members #include -// NB: Don't include any other headers in this file. #include #if _GLIBCPP_USE_WCHAR_T -class gnu_ctype: public std::ctype {}; - void test01() { - bool test = true; - typedef wchar_t char_type; - - const char_type strlit00[] = L"manilla, cebu, tandag PHILIPPINES"; - const char_type strlit01[] = L"MANILLA, CEBU, TANDAG PHILIPPINES"; - const char_type strlit02[] = L"manilla, cebu, tandag philippines"; - const char_type c00 = L'S'; - const char_type c10 = L's'; - const char_type c20 = L'9'; - const char_type c30 = L' '; - const char_type c40 = L'!'; - const char_type c50 = L'F'; - const char_type c60 = L'f'; - const char_type c70 = L'X'; - const char_type c80 = L'x'; - - gnu_ctype gctype; - char_type c100; - int len = std::char_traits::length(strlit00); - char_type c_array[len + 1]; - - // bool is(mask m, char_type c) const; - VERIFY( gctype.is(std::ctype_base::space, c30) ); - VERIFY( gctype.is(std::ctype_base::upper, c00) ); - VERIFY( gctype.is(std::ctype_base::lower, c10) ); - VERIFY( gctype.is(std::ctype_base::digit, c20) ); - VERIFY( gctype.is(std::ctype_base::punct, c40) ); - VERIFY( gctype.is(std::ctype_base::alpha, c50) ); - VERIFY( gctype.is(std::ctype_base::alpha, c60) ); - VERIFY( gctype.is(std::ctype_base::xdigit, c20) ); - VERIFY( !gctype.is(std::ctype_base::xdigit, c80) ); - VERIFY( gctype.is(std::ctype_base::alnum, c50) ); - VERIFY( gctype.is(std::ctype_base::alnum, c20) ); - VERIFY( gctype.is(std::ctype_base::graph, c40) ); - VERIFY( gctype.is(std::ctype_base::graph, c20) ); - - // char_type toupper(char_type c) const - c100 = gctype.toupper(c10); - VERIFY( c100 == c00 ); - - // char_type tolower(char_type c) const - c100 = gctype.tolower(c00); - VERIFY( c100 == c10 ); - - // char_type toupper(char_type* low, const char_type* hi) const - std::char_traits::copy(c_array, strlit02, len + 1); - gctype.toupper(c_array, c_array + len); - VERIFY( !std::char_traits::compare(c_array, strlit01, len - 1) ); - - // char_type tolower(char_type* low, const char_type* hi) const - std::char_traits::copy(c_array, strlit01, len + 1); - gctype.tolower(c_array, c_array + len); - VERIFY( !std::char_traits::compare(c_array, strlit02, len - 1) ); - -#ifdef DEBUG_ASSERT - assert(test); -#endif -} - -// libstdc++/5280 -void test03() -{ -#ifdef _GLIBCPP_HAVE_SETENV - // Set the global locale to non-"C". - std::locale loc_de("de_DE"); - std::locale::global(loc_de); - - // Set LANG environment variable to de_DE. - const char* oldLANG = getenv("LANG"); - if (!setenv("LANG", "de_DE", 1)) - { - test01(); - setenv("LANG", oldLANG ? oldLANG : "", 1); - } -#endif -} - -// http://gcc.gnu.org/ml/libstdc++/2002-05/msg00038.html -void test04() -{ - bool test = true; - - const char* tentLANG = setlocale(LC_ALL, "ja_JP.eucjp"); - if (tentLANG != NULL) - { - std::string preLANG = tentLANG; - test01(); - std::string postLANG = setlocale(LC_ALL, NULL); - VERIFY( preLANG == postLANG ); - } + // Nothing, right now. } #endif /* !defined(_GLIBCPP_USE_WCHAR_T) */ @@ -135,8 +43,6 @@ int main() { #if _GLIBCPP_USE_WCHAR_T test01(); - test03(); - test04(); #endif return 0; diff --git a/libstdc++-v3/testsuite/22_locale/ctype_scan_wchar_t.cc b/libstdc++-v3/testsuite/22_locale/ctype_scan_wchar_t.cc index 96ee9ae6d4ce..7af4fae26b2f 100644 --- a/libstdc++-v3/testsuite/22_locale/ctype_scan_wchar_t.cc +++ b/libstdc++-v3/testsuite/22_locale/ctype_scan_wchar_t.cc @@ -32,9 +32,6 @@ #include #include -// XXX This test is not working for non-glibc locale models. -// { dg-do run { xfail *-*-* } } - typedef wchar_t char_type; typedef std::char_traits traits_type; class gnu_ctype: public std::ctype { };