diff options
author | Paolo Carlini <pcarlini@suse.de> | 2006-10-14 10:25:35 +0000 |
---|---|---|
committer | Paolo Carlini <paolo@gcc.gnu.org> | 2006-10-14 10:25:35 +0000 |
commit | 4fb1953207c64de93583e332e0af475bfdb46b98 (patch) | |
tree | 0ba3394e251b0d22898853dfd6d65d16551152dc | |
parent | 78a438f161f869b2ac34c9904b0a2a0cad12127c (diff) | |
download | gcc-4fb1953207c64de93583e332e0af475bfdb46b98.zip gcc-4fb1953207c64de93583e332e0af475bfdb46b98.tar.gz gcc-4fb1953207c64de93583e332e0af475bfdb46b98.tar.bz2 |
ostream.tcc (operator<<(basic_ostream<>&, const char*)): Further fix for throwing widen.
2006-10-14 Paolo Carlini <pcarlini@suse.de>
* include/bits/ostream.tcc (operator<<(basic_ostream<>&,
const char*)): Further fix for throwing widen.
From-SVN: r117730
-rw-r--r-- | libstdc++-v3/ChangeLog | 5 | ||||
-rw-r--r-- | libstdc++-v3/include/bits/ostream.tcc | 9 |
2 files changed, 11 insertions, 3 deletions
diff --git a/libstdc++-v3/ChangeLog b/libstdc++-v3/ChangeLog index f286f68..0609457 100644 --- a/libstdc++-v3/ChangeLog +++ b/libstdc++-v3/ChangeLog @@ -1,6 +1,11 @@ 2006-10-14 Paolo Carlini <pcarlini@suse.de> * include/bits/ostream.tcc (operator<<(basic_ostream<>&, + const char*)): Further fix for throwing widen. + +2006-10-14 Paolo Carlini <pcarlini@suse.de> + + * include/bits/ostream.tcc (operator<<(basic_ostream<>&, const char*)): Fix thinko in change for libstdc++/28277, avoid memory leaks. diff --git a/libstdc++-v3/include/bits/ostream.tcc b/libstdc++-v3/include/bits/ostream.tcc index 125e0fe..db09d0a 100644 --- a/libstdc++-v3/include/bits/ostream.tcc +++ b/libstdc++-v3/include/bits/ostream.tcc @@ -325,17 +325,20 @@ _GLIBCXX_BEGIN_NAMESPACE(std) const size_t __clen = char_traits<char>::length(__s); _CharT* __ws = 0; try - { __ws = new _CharT[__clen]; } + { + __ws = new _CharT[__clen]; + for (size_t __i = 0; __i < __clen; ++__i) + __ws[__i] = __out.widen(__s[__i]); + } catch(...) { + delete [] __ws; __out._M_setstate(ios_base::badbit); return __out; } try { - for (size_t __i = 0; __i < __clen; ++__i) - __ws[__i] = __out.widen(__s[__i]); __out._M_insert(__ws, __clen); delete [] __ws; } |