diff options
author | Paolo Carlini <pcarlini@suse.de> | 2004-02-28 20:37:54 +0000 |
---|---|---|
committer | Paolo Carlini <paolo@gcc.gnu.org> | 2004-02-28 20:37:54 +0000 |
commit | 0e1b98ccccb889ca74e5ecd39dc5bd9f1f442fb1 (patch) | |
tree | 55b6e5d30dfd53ce1497385626f8d3aa5c0d4ef4 /libstdc++-v3 | |
parent | 757f9053a2dc9988345ba87829c2a9220c9a4ef2 (diff) | |
download | gcc-0e1b98ccccb889ca74e5ecd39dc5bd9f1f442fb1.tar.gz |
locale_facets.tcc (num_get<>::_M_extract_float): According to 22.2.3.1...
2004-02-28 Paolo Carlini <pcarlini@suse.de>
* include/bits/locale_facets.tcc (num_get<>::_M_extract_float):
According to 22.2.3.1, p2, 'units' may be followed by 'e' with
no 'decimal-point' in the middle: in this case too we must fix
up __found_grouping; slightly tweak.
* testsuite/22_locale/num_get/get/char/14.cc: New.
* testsuite/22_locale/num_get/get/wchar_t/14.cc: New.
From-SVN: r78625
Diffstat (limited to 'libstdc++-v3')
-rw-r--r-- | libstdc++-v3/ChangeLog | 9 | ||||
-rw-r--r-- | libstdc++-v3/include/bits/locale_facets.tcc | 19 | ||||
-rw-r--r-- | libstdc++-v3/testsuite/22_locale/num_get/get/char/14.cc | 59 | ||||
-rw-r--r-- | libstdc++-v3/testsuite/22_locale/num_get/get/wchar_t/14.cc | 59 |
4 files changed, 137 insertions, 9 deletions
diff --git a/libstdc++-v3/ChangeLog b/libstdc++-v3/ChangeLog index a2a9d4ea577..9af9d868cd0 100644 --- a/libstdc++-v3/ChangeLog +++ b/libstdc++-v3/ChangeLog @@ -1,3 +1,12 @@ +2004-02-28 Paolo Carlini <pcarlini@suse.de> + + * include/bits/locale_facets.tcc (num_get<>::_M_extract_float): + According to 22.2.3.1, p2, 'units' may be followed by 'e' with + no 'decimal-point' in the middle: in this case too we must fix + up __found_grouping; slightly tweak. + * testsuite/22_locale/num_get/get/char/14.cc: New. + * testsuite/22_locale/num_get/get/wchar_t/14.cc: New. + 2004-02-27 Eric Christopher <echristo@redhat.com> Phil Edwards <phil@codesourcery.com> diff --git a/libstdc++-v3/include/bits/locale_facets.tcc b/libstdc++-v3/include/bits/locale_facets.tcc index 353d601ca04..ae824b5c29b 100644 --- a/libstdc++-v3/include/bits/locale_facets.tcc +++ b/libstdc++-v3/include/bits/locale_facets.tcc @@ -188,8 +188,7 @@ namespace std && (!__lc->_M_use_grouping || !__traits_type::eq(__c, __lc->_M_thousands_sep))) { - __xtrc += __plus ? _S_atoms_in[_S_iplus] - : _S_atoms_in[_S_iminus]; + __xtrc += __plus ? '+' : '-'; ++__beg; } } @@ -206,7 +205,7 @@ namespace std { if (!__found_mantissa) { - __xtrc += _S_atoms_in[_S_izero]; + __xtrc += '0'; __found_mantissa = true; } ++__beg; @@ -223,6 +222,7 @@ namespace std __found_grouping.reserve(32); int __sep_pos = 0; bool __e; + const char_type* __lit_zero = __lit + _S_izero; const char_type* __q; while (__beg != __end) { @@ -267,7 +267,7 @@ namespace std else break; } - else if (__q = __traits_type::find(__lit + _S_izero, 10, __c)) + else if (__q = __traits_type::find(__lit_zero, 10, __c)) { __xtrc += _S_atoms_in[__q - __lit]; __found_mantissa = true; @@ -279,7 +279,9 @@ namespace std && __found_mantissa && !__found_sci) { // Scientific notation. - __xtrc += __e ? _S_atoms_in[_S_ie] : _S_atoms_in[_S_iE]; + if (__found_grouping.size() && !__found_dec) + __found_grouping += static_cast<char>(__sep_pos); + __xtrc += __e ? 'e' : 'E'; __found_sci = true; // Remove optional plus or minus sign, if they exist. @@ -289,8 +291,7 @@ namespace std __lit[_S_iplus]); if (__plus || __traits_type::eq(*__beg, __lit[_S_iminus])) { - __xtrc += __plus ? _S_atoms_in[_S_iplus] - : _S_atoms_in[_S_iminus]; + __xtrc += __plus ? '+' : '-'; ++__beg; } } @@ -304,8 +305,8 @@ namespace std // match, then get very very upset, and set failbit. if (__found_grouping.size()) { - // Add the ending grouping if a decimal wasn't found. - if (!__found_dec) + // Add the ending grouping if a decimal or 'e'/'E' wasn't found. + if (!__found_dec && !__found_sci) __found_grouping += static_cast<char>(__sep_pos); if (!std::__verify_grouping(__lc->_M_grouping, __lc->_M_grouping_size, diff --git a/libstdc++-v3/testsuite/22_locale/num_get/get/char/14.cc b/libstdc++-v3/testsuite/22_locale/num_get/get/char/14.cc new file mode 100644 index 00000000000..e2ce6daa5e8 --- /dev/null +++ b/libstdc++-v3/testsuite/22_locale/num_get/get/char/14.cc @@ -0,0 +1,59 @@ +// 2004-02-28 Paolo Carlini <pcarlini@suse.de> + +// Copyright (C) 2004 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, 59 Temple Place - Suite 330, Boston, MA 02111-1307, +// USA. + +// 22.2.2.1.1 num_get members + +#include <locale> +#include <sstream> +#include <testsuite_hooks.h> + +struct Punct: std::numpunct<char> +{ + std::string do_grouping() const { return "\1"; } +}; + +void test01() +{ + using namespace std; + typedef istreambuf_iterator<char> iterator_type; + + bool test __attribute__((unused)) = true; + + istringstream iss; + iss.imbue(locale(iss.getloc(), static_cast<numpunct<char>*>(new Punct))); + const num_get<char>& ng = use_facet<num_get<char> >(iss.getloc()); + + ios_base::iostate err = ios_base::goodbit; + iterator_type end; + double d = 0.0; + double d1 = 1000.0; + + iss.str("1,0e2"); + err = ios_base::goodbit; + end = ng.get(iss.rdbuf(), 0, iss, err, d); + VERIFY( err == ios_base::eofbit ); + VERIFY( d == d1 ); +} + +int main() +{ + test01(); + return 0; +} diff --git a/libstdc++-v3/testsuite/22_locale/num_get/get/wchar_t/14.cc b/libstdc++-v3/testsuite/22_locale/num_get/get/wchar_t/14.cc new file mode 100644 index 00000000000..fd5e55e2a9f --- /dev/null +++ b/libstdc++-v3/testsuite/22_locale/num_get/get/wchar_t/14.cc @@ -0,0 +1,59 @@ +// 2004-02-28 Paolo Carlini <pcarlini@suse.de> + +// Copyright (C) 2004 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, 59 Temple Place - Suite 330, Boston, MA 02111-1307, +// USA. + +// 22.2.2.1.1 num_get members + +#include <locale> +#include <sstream> +#include <testsuite_hooks.h> + +struct Punct: std::numpunct<wchar_t> +{ + std::string do_grouping() const { return "\1"; } +}; + +void test01() +{ + using namespace std; + typedef istreambuf_iterator<wchar_t> iterator_type; + + bool test __attribute__((unused)) = true; + + wistringstream iss; + iss.imbue(locale(iss.getloc(), static_cast<numpunct<wchar_t>*>(new Punct))); + const num_get<wchar_t>& ng = use_facet<num_get<wchar_t> >(iss.getloc()); + + ios_base::iostate err = ios_base::goodbit; + iterator_type end; + double d = 0.0; + double d1 = 1000.0; + + iss.str(L"1,0e2"); + err = ios_base::goodbit; + end = ng.get(iss.rdbuf(), 0, iss, err, d); + VERIFY( err == ios_base::eofbit ); + VERIFY( d == d1 ); +} + +int main() +{ + test01(); + return 0; +} |