diff options
author | Paolo Carlini <paolo@gcc.gnu.org> | 2005-04-17 14:30:37 +0000 |
---|---|---|
committer | Paolo Carlini <paolo@gcc.gnu.org> | 2005-04-17 14:30:37 +0000 |
commit | 101c5bc507e0067fe0c97a2eefd0192d5092b0d0 (patch) | |
tree | 1a3e207094215de0d9c31617713705d0d5ce8bb7 /gcc/tree-vrp.c | |
parent | a34938bea3d8eeb9bc673b39e6c140825e1cbecf (diff) | |
download | gcc-101c5bc507e0067fe0c97a2eefd0192d5092b0d0.zip gcc-101c5bc507e0067fe0c97a2eefd0192d5092b0d0.tar.gz gcc-101c5bc507e0067fe0c97a2eefd0192d5092b0d0.tar.bz2 |
re PR libstdc++/20914 (Another grouping trouble)
2005-04-17 Paolo Carlini <pcarlini@suse.de>
PR libstdc++/20914
* include/bits/locale_facets.tcc (__int_to_char(_CharT*, _ValueT,
const _CharT*, ios_base::fmtflags, bool)): Don't deal with numeric
base or sign here, instead...
(_M_insert_int(_OutIter, ios_base&, _CharT, _ValueT)): ... here,
after adding the grouping. This fixes the bug and also allows to
clean-up the code dealing with integer types.
(_M_group_int(const char*, size_t, _CharT, ios_base&, _CharT*,
_CharT*, int&)): Simplify, remove bits dealing with numeric base.
(__int_to_char(_CharT*, unsigned long, const _CharT*,
ios_base::fmtflags), __int_to_char(_CharT*, unsigned long long,
const _CharT*, ios_base::fmtflags)): Remove hackish fix for
libstdc++/15565.
(__int_to_char(_CharT*, long, const _CharT*, ios_base::fmtflags),
__int_to_char(_CharT*, long long, const _CharT*, ios_base::fmtflags)):
Simplify, don't pass the sign.
(_M_insert_float(_OutIter, ios_base&, _CharT, char, _ValueT)):
Deal with a sign at the beginning of __cs; robustify the grouping
check.
* testsuite/22_locale/num_put/put/char/20914.cc: New.
* testsuite/22_locale/num_put/put/wchar_t/20914.cc: Likewise.
From-SVN: r98271
Diffstat (limited to 'gcc/tree-vrp.c')
0 files changed, 0 insertions, 0 deletions