locale_facets.tcc (num_get::_M_extract_int): Admit grouping for octals and hexadecima...
authorPaolo Carlini <pcarlini@unitus.it>
Thu, 28 Feb 2002 21:16:45 +0000 (22:16 +0100)
committerPaolo Carlini <paolo@gcc.gnu.org>
Thu, 28 Feb 2002 21:16:45 +0000 (21:16 +0000)
2002-02-28  Paolo Carlini  <pcarlini@unitus.it>

        * include/bits/locale_facets.tcc (num_get::_M_extract_int):
        Admit grouping for octals and hexadecimals too.
        * testsuite/22_locale/num_get_members_char.cc: Add test04.
        (test01): Tweak "." -> "," in void* test.
        * testsuite/22_locale/num_get_members_wchar_t.cc: Ditto.

        * testsuite/27_io/ios_manip_basefield.cc: Remove static keyword.
        * testsuite/27_io/ios_manip_fmtflags.cc: Remove two of them.

From-SVN: r50162

libstdc++-v3/ChangeLog
libstdc++-v3/include/bits/locale_facets.tcc
libstdc++-v3/testsuite/22_locale/num_get_members_char.cc
libstdc++-v3/testsuite/22_locale/num_get_members_wchar_t.cc
libstdc++-v3/testsuite/27_io/ios_manip_basefield.cc
libstdc++-v3/testsuite/27_io/ios_manip_fmtflags.cc

index a65ae409a7f8f77be53b8115dc51bc7dae5026a2..d1b2116b28993dc1fd7b2ff7cb62bc6d3d1e194d 100644 (file)
@@ -1,3 +1,14 @@
+2002-02-28  Paolo Carlini  <pcarlini@unitus.it>
+
+       * include/bits/locale_facets.tcc (num_get::_M_extract_int):
+       Admit grouping for octals and hexadecimals too.
+       * testsuite/22_locale/num_get_members_char.cc: Add test04.
+       (test01): Tweak "." -> "," in void* test.
+       * testsuite/22_locale/num_get_members_wchar_t.cc: Ditto.
+
+       * testsuite/27_io/ios_manip_basefield.cc: Remove static keyword.
+       * testsuite/27_io/ios_manip_fmtflags.cc: Remove two of them.
+
 2002-02-27  Paolo Carlini  <pcarlini@unitus.it>
 
        * testsuite/27_io/ios_manip_basefield.cc (test01):
index 4f4cb11ea636d3e6ba78e8e90cd3c857d3a3d7bb..4f31bd6e0c97efb2ad123a3aa1996aa2592d51a0 100644 (file)
@@ -310,7 +310,7 @@ namespace std
       __ctype.widen(_S_atoms, _S_atoms + __len, __watoms);
       string __found_grouping;
       const string __grouping = __np.grouping();
-      bool __check_grouping = __grouping.size() && __base == 10;
+      bool __check_grouping = __grouping.size();
       int __sep_pos = 0;
       const char_type __sep = __np.thousands_sep();
       while (__beg != __end)
index 1c9d8f08996726c5131474f08e91d5a918197e63..8907d08ba220b0109e63128fc1526a00a2ce57f9 100644 (file)
@@ -213,7 +213,7 @@ void test01()
   VERIFY( err == goodbit );
 
   // const void
-  iss.str("0xbffff74c.");
+  iss.str("0xbffff74c,");
   iss.clear();
   err = goodbit;
   ng.get(iss.rdbuf(), 0, iss, err, v);
@@ -332,11 +332,76 @@ void test03()
 #endif
 }
 
+struct MyNP : std::numpunct<char>
+{
+  std::string do_grouping() const;
+  char   do_thousands_sep() const;
+};
+
+std::string MyNP::do_grouping() const { std::string s("\3"); return s; }
+char   MyNP::do_thousands_sep() const { return ' '; }
+
+// Testing the correct parsing of grouped hexadecimals and octals.
+void test04()
+{
+  using namespace std;
+
+  bool test = true;
+  unsigned long ul;
+
+  istringstream iss;
+  iss.imbue(locale(locale(), new MyNP));
+
+  const num_get<char>& ng = use_facet<num_get<char> >(iss.getloc()); 
+  const ios_base::iostate goodbit = ios_base::goodbit;
+  ios_base::iostate err = ios_base::goodbit;
+
+  iss.setf(ios::hex, ios::basefield);
+  iss.str("0xbf fff 74c.");
+  err = goodbit;
+  ng.get(iss.rdbuf(), 0, iss, err, ul);
+  VERIFY( err == goodbit );
+  VERIFY( ul == 0xbffff74c );
+
+  iss.str("0Xf fff.");
+  err = goodbit;
+  ng.get(iss.rdbuf(), 0, iss, err, ul);
+  VERIFY( err == goodbit );
+  VERIFY( ul == 0xffff );
+
+  iss.str("f ffe.");
+  err = goodbit;
+  ng.get(iss.rdbuf(), 0, iss, err, ul);
+  VERIFY( err == goodbit );
+  VERIFY( ul == 0xfffe );
+
+  iss.setf(ios::oct, ios::basefield);
+  iss.str("07 654 321.");
+  err = goodbit;
+  ng.get(iss.rdbuf(), 0, iss, err, ul);
+  VERIFY( err == goodbit );
+  VERIFY( ul == 07654321 );
+
+  iss.str("07 777.");
+  err = goodbit;
+  ng.get(iss.rdbuf(), 0, iss, err, ul);
+  VERIFY( err == goodbit );
+  VERIFY( ul == 07777 );
+
+  iss.str("7 776.");
+  err = goodbit;
+  ng.get(iss.rdbuf(), 0, iss, err, ul);
+  VERIFY( err == goodbit );
+  VERIFY( ul == 07776 );
+}
+
 int main()
 {
   test01();
   test02();
   test03();
+  test04();
   return 0;
 }
 
index 53fb9c9df77966d498e2f51ceaccc250456889a9..cbd39aefd9d762cf6212d175be003c0c0ca0917d 100644 (file)
@@ -214,7 +214,7 @@ void test01()
   VERIFY( err == goodbit );
 
   // const void
-  iss.str(L"0xbffff74c.");
+  iss.str(L"0xbffff74c,");
   iss.clear();
   err = goodbit;
   ng.get(iss.rdbuf(), 0, iss, err, v);
@@ -333,6 +333,70 @@ void test03()
     }
 #endif
 }
+
+struct MyNP : std::numpunct<wchar_t>
+{
+  std::string do_grouping() const;
+  wchar_t   do_thousands_sep() const;
+};
+
+std::string MyNP::do_grouping() const { std::string s("\3"); return s; }
+wchar_t   MyNP::do_thousands_sep() const { return L' '; }
+
+// Testing the correct parsing of grouped hexadecimals and octals.
+void test04()
+{
+  using namespace std;
+
+  bool test = true;
+  unsigned long ul;
+
+  wistringstream iss;
+  iss.imbue(locale(locale(), new MyNP));
+
+  const num_get<wchar_t>& ng = use_facet<num_get<wchar_t> >(iss.getloc()); 
+  const ios_base::iostate goodbit = ios_base::goodbit;
+  ios_base::iostate err = ios_base::goodbit;
+
+  iss.setf(ios::hex, ios::basefield);
+  iss.str(L"0xbf fff 74c.");
+  err = goodbit;
+  ng.get(iss.rdbuf(), 0, iss, err, ul);
+  VERIFY( err == goodbit );
+  VERIFY( ul == 0xbffff74c );
+
+  iss.str(L"0Xf fff.");
+  err = goodbit;
+  ng.get(iss.rdbuf(), 0, iss, err, ul);
+  VERIFY( err == goodbit );
+  VERIFY( ul == 0xffff );
+
+  iss.str(L"f ffe.");
+  err = goodbit;
+  ng.get(iss.rdbuf(), 0, iss, err, ul);
+  VERIFY( err == goodbit );
+  VERIFY( ul == 0xfffe );
+
+  iss.setf(ios::oct, ios::basefield);
+  iss.str(L"07 654 321.");
+  err = goodbit;
+  ng.get(iss.rdbuf(), 0, iss, err, ul);
+  VERIFY( err == goodbit );
+  VERIFY( ul == 07654321 );
+
+  iss.str(L"07 777.");
+  err = goodbit;
+  ng.get(iss.rdbuf(), 0, iss, err, ul);
+  VERIFY( err == goodbit );
+  VERIFY( ul == 07777 );
+
+  iss.str(L"7 776.");
+  err = goodbit;
+  ng.get(iss.rdbuf(), 0, iss, err, ul);
+  VERIFY( err == goodbit );
+  VERIFY( ul == 07776 );
+}
 #endif
 
 int main()
@@ -341,6 +405,7 @@ int main()
   test01();
   test02();
   test03();
+  test04();
 #endif
   return 0;
 }
index 9a196993f5d4f1e537ad01595d6408fb60c75f86..1ce1d087f10b2560a36fe87973cb189e6ae71264 100644 (file)
@@ -38,7 +38,7 @@ struct MyNP : std::numpunct<char>
   char   do_thousands_sep() const;
 };
 
-std::string MyNP::do_grouping() const { static std::string s("\3"); return s; }
+std::string MyNP::do_grouping() const { std::string s("\3"); return s; }
 char   MyNP::do_thousands_sep() const { return ' '; }
 
 int
index 64b1b85f6d26ce804a09d4d6fb689d509641f6a0..3173dc3a54cb9876159abbeb0bebbbf2d64d18d0 100644 (file)
@@ -41,13 +41,13 @@ struct MyNP : std::numpunct<char>
 
 std::string MyNP::do_truename()  const 
 { 
-  static std::string s("yea"); 
+  std::string s("yea"); 
   return s; 
 }
 
 std::string MyNP::do_falsename() const 
 { 
-  static std::string s("nay"); 
+  std::string s("nay"); 
   return s; 
 }