]> git.ipfire.org Git - thirdparty/gcc.git/commitdiff
[multiple changes]
authorBenjamin Kosnik <bkoz@gcc.gnu.org>
Fri, 24 May 2002 16:15:27 +0000 (16:15 +0000)
committerBenjamin Kosnik <bkoz@gcc.gnu.org>
Fri, 24 May 2002 16:15:27 +0000 (16:15 +0000)
2002-05-24  Benjamin Kosnik  <bkoz@redhat.com>

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 <dale@peakall.net>

PR libstdc++/6701
* config/locale/gnu/ctype_members.cc (ctype<wchar_t>::do_narrow): Fix.
* config/locale/generic/ctype_members.cc: Same.

From-SVN: r53843

libstdc++-v3/ChangeLog
libstdc++-v3/config/locale/generic/ctype_members.cc
libstdc++-v3/config/locale/gnu/ctype_members.cc
libstdc++-v3/testsuite/22_locale/ctype_members_char.cc
libstdc++-v3/testsuite/22_locale/ctype_members_wchar_t.cc
libstdc++-v3/testsuite/22_locale/ctype_scan_wchar_t.cc

index b2d841071525e13f7ff2e7e6f6e738dfd2ef7728..e33faef1a21e83d44f977d515800e223cd49f3b8 100644 (file)
@@ -1,3 +1,25 @@
+2002-05-24  Benjamin Kosnik  <bkoz@redhat.com>
+
+       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 <dale@peakall.net>
+
+       PR libstdc++/6701
+       * config/locale/gnu/ctype_members.cc (ctype<wchar_t>::do_narrow): Fix.
+       * config/locale/generic/ctype_members.cc: Same.
+       
 2002-05-24  Benjamin Kosnik  <bkoz@redhat.com>
 
        PR libstdc++/6750
index 5a66484f199a49187c238c23891e2cafd16f698b..f147983c6a2a33d4218dfff02b143efb30f8ac04 100644 (file)
@@ -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<void*>(&__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<void*>(&__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
index 090738bf5b614072144df22d2768df953e6924e9..de83683934a5dc745f3ba07428beaa7121587101 100644 (file)
@@ -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<void*>(&__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<void*>(&__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
index b61dabf56e35ab24aaebbcd09105987a43fb1776..54fc5d3e91dfd97f94cb6e0920d0363c0f1fe452 100644 (file)
 // 22.2.1.3.2 ctype<char> members
 
 #include <locale>
-#include <vector>
 #include <testsuite_hooks.h>
 
-// XXX This test (test02) is not working for non-glibc locale models.
-// { dg-do run { xfail *-*-* } }
-
-class gnu_ctype: public std::ctype<char> { };
-
-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<char>::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<std::ctype_base::mask>(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<bool>(m02[6] & std::ctype_base::alnum) );
-  VERIFY( static_cast<bool>(m02[6] & std::ctype_base::upper) );
-  VERIFY( static_cast<bool>(m02[6] & std::ctype_base::alpha) );
-  VERIFY( static_cast<bool>(m02[7] & std::ctype_base::punct) );
-  VERIFY( static_cast<bool>(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<char>::copy(c_array, strlit02, len + 1);
-  gctype.toupper(c_array, c_array + len);
-  VERIFY( !std::char_traits<char>::compare(c_array, strlit01, len - 1) );
-
-  // char tolower(char* low, const char* hi) const
-  std::char_traits<char>::copy(c_array, strlit01, len + 1);
-  gctype.tolower(c_array, c_array + len);
-  VERIFY( !std::char_traits<char>::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<mask>                 vector_type;
-
-  bool test = true;
-
-  //  const int max = numeric_limits<char>::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<char>& ctype_c = use_facet<ctype<char> >(loc_c); 
-  for (int i = 0; i < max; ++i)
-    {
-      char c = static_cast<char>(i);
-      mask mask_test = static_cast<mask>(0);
-      mask mask_is = static_cast<mask>(0);
-      for (int j = 0; j <= ctype_mask_max; ++j)
-       {
-         mask_test = static_cast<mask>(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<char>& ctype_de = use_facet<ctype<char> >(loc_de); 
-  for (int i = 0; i < max; ++i)
-    {
-      char c = static_cast<char>(i);
-      mask mask_test = static_cast<mask>(0);
-      mask mask_is = static_cast<mask>(0);
-      for (int j = 0; j <= ctype_mask_max; ++j)
-       {
-         mask_test = static_cast<mask>(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<char>(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<char>
 {
@@ -243,66 +41,7 @@ public:
   { classic_table(); }
 };
 
-// Per Liboriussen <liborius@stofanet.dk>
-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<char>* f = new std::ctype<char>(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;
 }
index 405cddc4eb3bc7d139093bc4b1f7c2c5e3ccd149..31b1bcbf1608b8c4a28d68bacf8ab31c323bdc64 100644 (file)
 // 22.2.1.3.2 ctype<char> members
 
 #include <locale>
-// NB: Don't include any other headers in this file.
 #include <testsuite_hooks.h>
 
 #if _GLIBCPP_USE_WCHAR_T
-class gnu_ctype: public std::ctype<wchar_t> {};
-
 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<char_type>::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<char_type>::copy(c_array, strlit02, len + 1);
-  gctype.toupper(c_array, c_array + len);
-  VERIFY( !std::char_traits<char_type>::compare(c_array, strlit01, len - 1) );
-
-  // char_type tolower(char_type* low, const char_type* hi) const
-  std::char_traits<char_type>::copy(c_array, strlit01, len + 1);
-  gctype.tolower(c_array, c_array + len);
-  VERIFY( !std::char_traits<char_type>::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;
index 96ee9ae6d4ce32fca15ffb8cfcf28aba6b19773f..7af4fae26b2fad997407c1e7969877581f8af9d8 100644 (file)
@@ -32,9 +32,6 @@
 #include <locale>
 #include <testsuite_hooks.h>
 
-// XXX This test is not working for non-glibc locale models.
-// { dg-do run { xfail *-*-* } }
-
 typedef wchar_t char_type;
 typedef std::char_traits<char_type> traits_type;
 class gnu_ctype: public std::ctype<char_type> { };