re PR libstdc++/38399 (money_get<> read decimal point when frac_digits() <= 0)
authorPaolo Carlini <paolo.carlini@oracle.com>
Fri, 5 Dec 2008 18:23:39 +0000 (18:23 +0000)
committerPaolo Carlini <paolo@gcc.gnu.org>
Fri, 5 Dec 2008 18:23:39 +0000 (18:23 +0000)
2008-12-05  Paolo Carlini  <paolo.carlini@oracle.com>

PR libstdc++/38399
* include/bits/locale_facets_nonio.tcc (money_get<>::
_M_extract(iter_type, iter_type, ios_base&, ios_base::iostate&,
string&)): Fix, reject decimal point when frac_digits <= 0.
* testsuite/22_locale/money_get/get/char/38399.cc: New.
* testsuite/22_locale/money_get/get/wchar_t/38399.cc: Likewise.
* testsuite/22_locale/money_get/get/char/5.cc: Adjust.
* testsuite/22_locale/money_get/get/wchar_t/5.cc: Likewise.

From-SVN: r142487

libstdc++-v3/ChangeLog
libstdc++-v3/include/bits/locale_facets_nonio.tcc
libstdc++-v3/testsuite/22_locale/money_get/get/char/38399.cc [new file with mode: 0644]
libstdc++-v3/testsuite/22_locale/money_get/get/char/5.cc
libstdc++-v3/testsuite/22_locale/money_get/get/wchar_t/38399.cc [new file with mode: 0644]
libstdc++-v3/testsuite/22_locale/money_get/get/wchar_t/5.cc

index f2820d9..d9023b8 100644 (file)
@@ -1,5 +1,16 @@
 2008-12-05  Paolo Carlini  <paolo.carlini@oracle.com>
 
+       PR libstdc++/38399
+       * include/bits/locale_facets_nonio.tcc (money_get<>::
+       _M_extract(iter_type, iter_type, ios_base&, ios_base::iostate&,
+       string&)): Fix, reject decimal point when frac_digits <= 0.
+       * testsuite/22_locale/money_get/get/char/38399.cc: New.
+       * testsuite/22_locale/money_get/get/wchar_t/38399.cc: Likewise.
+       * testsuite/22_locale/money_get/get/char/5.cc: Adjust.
+       * testsuite/22_locale/money_get/get/wchar_t/5.cc: Likewise.
+
+2008-12-05  Paolo Carlini  <paolo.carlini@oracle.com>
+
        PR libstdc++/38411
        * testsuite/22_locale/numpunct/members/char/2.cc: Use is_IS instead
        of fr_FR.
index 1c569ba..ba75d3a 100644 (file)
@@ -1,6 +1,6 @@
 // Locale support -*- C++ -*-
 
-// Copyright (C) 2007 Free Software Foundation, Inc.
+// Copyright (C) 2007, 2008 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
@@ -229,6 +229,9 @@ _GLIBCXX_BEGIN_LDBL_NAMESPACE
                    else if (__c == __lc->_M_decimal_point 
                             && !__testdecfound)
                      {
+                       if (__lc->_M_frac_digits <= 0)
+                         break;
+
                        __last_pos = __n;
                        __n = 0;
                        __testdecfound = true;
@@ -311,11 +314,10 @@ _GLIBCXX_BEGIN_LDBL_NAMESPACE
              }
            
            // Iff not enough digits were supplied after the decimal-point.
-           if (__testdecfound && __lc->_M_frac_digits > 0
-               && __n != __lc->_M_frac_digits)
+           if (__testdecfound && __n != __lc->_M_frac_digits)
              __testvalid = false;
          }
-       
+
        // Iff valid sequence is not recognized.
        if (!__testvalid)
          __err |= ios_base::failbit;
diff --git a/libstdc++-v3/testsuite/22_locale/money_get/get/char/38399.cc b/libstdc++-v3/testsuite/22_locale/money_get/get/char/38399.cc
new file mode 100644 (file)
index 0000000..3283f34
--- /dev/null
@@ -0,0 +1,55 @@
+// Copyright (C) 2008 Free Software Foundation
+//
+// 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
+// terms of the GNU General Public License as published by the
+// Free Software Foundation; either version 2, or (at your option)
+// any later version.
+
+// This library is distributed in the hope that it will be useful,
+// but WITHOUT ANY WARRANTY; without even the implied warranty of
+// MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
+// GNU General Public License for more details.
+
+// You should have received a copy of the GNU General Public License along
+// with this library; see the file COPYING.  If not, write to the Free
+// Software Foundation, 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301,
+// USA.
+
+// 22.2.6.1.1 money_get members
+
+#include <locale>
+#include <sstream>
+#include <testsuite_hooks.h>
+
+class my_moneypunct : public std::moneypunct<char>
+{
+protected:
+  //this should disable fraction part of monetary value
+  int do_frac_digits() const { return 0; }
+};
+
+// libstdc++/38399
+void test01()
+{
+  using namespace std;
+  bool test __attribute__((unused)) = true;
+
+  locale loc(locale(), new my_moneypunct());
+  stringstream ss("123.455");
+  ss.imbue(loc);
+  string digits;
+  ios_base::iostate err;
+  istreambuf_iterator<char> iter = 
+    use_facet<money_get<char> >(loc).get(ss, 0, false, ss, err, digits);
+  
+  string rest = string(iter, istreambuf_iterator<char>());
+  VERIFY( digits == "123" );
+  VERIFY( rest == ".455" );
+}
+
+int main()
+{
+  test01();
+  return 0;
+}
index b1d735b..9c6cb1d 100644 (file)
@@ -1,6 +1,7 @@
 // 2001-09-12 Benjamin Kosnik  <bkoz@redhat.com>
 
-// Copyright (C) 2001, 2002, 2003 Free Software Foundation
+// Copyright (C) 2001, 2002, 2003, 2004, 2005, 2006, 2007, 2008
+// Free Software Foundation
 //
 // 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
@@ -36,7 +37,7 @@ void test05()
   const ios_base::iostate goodbit = ios_base::goodbit;
   ios_base::iostate err = goodbit;
   const locale loc_c = locale::classic();
-  const string str = "0.01Eleanor Roosevelt";
+  const string str = "1Eleanor Roosevelt";
 
   istringstream iss; 
   iss.imbue(locale(loc_c, new mon_get_type));
diff --git a/libstdc++-v3/testsuite/22_locale/money_get/get/wchar_t/38399.cc b/libstdc++-v3/testsuite/22_locale/money_get/get/wchar_t/38399.cc
new file mode 100644 (file)
index 0000000..bca8ab0
--- /dev/null
@@ -0,0 +1,55 @@
+// Copyright (C) 2008 Free Software Foundation
+//
+// 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
+// terms of the GNU General Public License as published by the
+// Free Software Foundation; either version 2, or (at your option)
+// any later version.
+
+// This library is distributed in the hope that it will be useful,
+// but WITHOUT ANY WARRANTY; without even the implied warranty of
+// MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
+// GNU General Public License for more details.
+
+// You should have received a copy of the GNU General Public License along
+// with this library; see the file COPYING.  If not, write to the Free
+// Software Foundation, 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301,
+// USA.
+
+// 22.2.6.1.1 money_get members
+
+#include <locale>
+#include <sstream>
+#include <testsuite_hooks.h>
+
+class my_moneypunct : public std::moneypunct<wchar_t>
+{
+protected:
+  //this should disable fraction part of monetary value
+  int do_frac_digits() const { return 0; }
+};
+
+// libstdc++/38399
+void test01()
+{
+  using namespace std;
+  bool test __attribute__((unused)) = true;
+
+  locale loc(locale(), new my_moneypunct());
+  wstringstream ss(L"123.455");
+  ss.imbue(loc);
+  wstring digits;
+  ios_base::iostate err;
+  istreambuf_iterator<wchar_t> iter = 
+    use_facet<money_get<wchar_t> >(loc).get(ss, 0, false, ss, err, digits);
+  
+  wstring rest = wstring(iter, istreambuf_iterator<wchar_t>());
+  VERIFY( digits == L"123" );
+  VERIFY( rest == L".455" );
+}
+
+int main()
+{
+  test01();
+  return 0;
+}
index 70c3cec..afbd1ec 100644 (file)
@@ -1,6 +1,7 @@
 // 2001-09-12 Benjamin Kosnik  <bkoz@redhat.com>
 
-// Copyright (C) 2001, 2002, 2003 Free Software Foundation
+// Copyright (C) 2001, 2002, 2003, 2004, 2005, 2006, 2007, 2008
+// Free Software Foundation
 //
 // 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
@@ -36,7 +37,7 @@ void test05()
   const ios_base::iostate goodbit = ios_base::goodbit;
   ios_base::iostate err = goodbit;
   const locale loc_c = locale::classic();
-  const wstring str = L"0.01Eleanor Roosevelt";
+  const wstring str = L"1Eleanor Roosevelt";
 
   wistringstream iss; 
   iss.imbue(locale(loc_c, new mon_get_type));