aboutsummaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorPaolo Carlini <pcarlini@suse.de>2006-10-14 09:51:32 +0000
committerPaolo Carlini <paolo@gcc.gnu.org>2006-10-14 09:51:32 +0000
commit78a438f161f869b2ac34c9904b0a2a0cad12127c (patch)
tree3fde7073366376d3c67f4d33fbc0f044357fdba6
parent14ba83a988ed858bab0dfe631f24ed87e0d9cbf5 (diff)
downloadgcc-78a438f161f869b2ac34c9904b0a2a0cad12127c.zip
gcc-78a438f161f869b2ac34c9904b0a2a0cad12127c.tar.gz
gcc-78a438f161f869b2ac34c9904b0a2a0cad12127c.tar.bz2
ostream.tcc (operator<<(basic_ostream<>&, const char*)): Fix thinko in change for libstdc++/28277, avoid memory leaks.
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. From-SVN: r117729
-rw-r--r--libstdc++-v3/ChangeLog6
-rw-r--r--libstdc++-v3/include/bits/ostream.tcc21
2 files changed, 22 insertions, 5 deletions
diff --git a/libstdc++-v3/ChangeLog b/libstdc++-v3/ChangeLog
index 9df1661..f286f68 100644
--- a/libstdc++-v3/ChangeLog
+++ b/libstdc++-v3/ChangeLog
@@ -1,3 +1,9 @@
+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.
+
2006-10-13 Paolo Carlini <pcarlini@suse.de>
* include/bits/istream.tcc (operator>>(__istream_type&
diff --git a/libstdc++-v3/include/bits/ostream.tcc b/libstdc++-v3/include/bits/ostream.tcc
index 5bfde44..125e0fe 100644
--- a/libstdc++-v3/include/bits/ostream.tcc
+++ b/libstdc++-v3/include/bits/ostream.tcc
@@ -320,19 +320,30 @@ _GLIBCXX_BEGIN_NAMESPACE(std)
__out.setstate(ios_base::badbit);
else
{
+ // _GLIBCXX_RESOLVE_LIB_DEFECTS
+ // 167. Improper use of traits_type::length()
+ const size_t __clen = char_traits<char>::length(__s);
+ _CharT* __ws = 0;
+ try
+ { __ws = new _CharT[__clen]; }
+ catch(...)
+ {
+ __out._M_setstate(ios_base::badbit);
+ return __out;
+ }
+
try
{
- // _GLIBCXX_RESOLVE_LIB_DEFECTS
- // 167. Improper use of traits_type::length()
- const size_t __clen = char_traits<char>::length(__s);
- _CharT* __ws = new _CharT[__clen];
for (size_t __i = 0; __i < __clen; ++__i)
__ws[__i] = __out.widen(__s[__i]);
__out._M_insert(__ws, __clen);
delete [] __ws;
}
catch(...)
- { __out._M_setstate(ios_base::badbit); }
+ {
+ delete [] __ws;
+ __throw_exception_again;
+ }
}
return __out;
}