From: Paolo Carlini Date: Mon, 17 Feb 2003 21:48:49 +0000 (+0100) Subject: re PR libstdc++/9169 (filebuf output fails if codecvt<>::out returns noconv) X-Git-Tag: releases/gcc-3.2.3~191 X-Git-Url: http://git.ipfire.org/cgi-bin/gitweb.cgi?a=commitdiff_plain;h=3f7d3354440dea4a3d65f1558e7d9cc42f404b96;p=thirdparty%2Fgcc.git re PR libstdc++/9169 (filebuf output fails if codecvt<>::out returns noconv) 2003-02-17 Paolo Carlini PR libstdc++/9169 * include/bits/fstream.tcc (_M_convert_to_external): Deal correctly with noconv, as prescribed by 27.8.1.4,p8. * testsuite/27_io/filebuf_virtuals.cc (test09): Add. From-SVN: r63011 --- diff --git a/libstdc++-v3/ChangeLog b/libstdc++-v3/ChangeLog index 5c6a9d743ead..12e8c605f314 100644 --- a/libstdc++-v3/ChangeLog +++ b/libstdc++-v3/ChangeLog @@ -1,4 +1,11 @@ -003-02-07 Paolo Carlini +2003-02-17 Paolo Carlini + + PR libstdc++/9169 + * include/bits/fstream.tcc (_M_convert_to_external): + Deal correctly with noconv, as prescribed by 27.8.1.4,p8. + * testsuite/27_io/filebuf_virtuals.cc (test09): Add. + +2003-02-07 Paolo Carlini * testsuite/27_io/filebuf_virtuals.cc (test08): Fix for unsigned char platforms. diff --git a/libstdc++-v3/include/bits/fstream.tcc b/libstdc++-v3/include/bits/fstream.tcc index e9919896914d..bbcde48e7985 100644 --- a/libstdc++-v3/include/bits/fstream.tcc +++ b/libstdc++-v3/include/bits/fstream.tcc @@ -275,9 +275,15 @@ namespace std const char_type* __iend; __res_type __r = __cvt.out(_M_state_cur, __ibuf, __ibuf + __ilen, __iend, __buf, __buf + __blen, __bend); - // Result == ok, partial, noconv - if (__r != codecvt_base::error) - __blen = __bend - __buf; + + if (__r == codecvt_base::ok || __r == codecvt_base::partial) + __blen = __bend - __buf; + // Similarly to the always_noconv case above. + else if (__r == codecvt_base::noconv) + { + __buf = reinterpret_cast(__ibuf); + __blen = __ilen; + } // Result == error else __blen = 0; diff --git a/libstdc++-v3/testsuite/27_io/filebuf_virtuals.cc b/libstdc++-v3/testsuite/27_io/filebuf_virtuals.cc index 8bfeb2eb1db2..4e88e36b8831 100644 --- a/libstdc++-v3/testsuite/27_io/filebuf_virtuals.cc +++ b/libstdc++-v3/testsuite/27_io/filebuf_virtuals.cc @@ -570,6 +570,46 @@ void test08() mb.sputbackc('a'); } +class Cvt_to_upper : public std::codecvt +{ + bool do_always_noconv() const throw() + { + return false; + } +}; + +// libstdc++/9169 +void test09() +{ + using namespace std; + bool test = true; + + locale c_loc; + locale loc(c_loc, new Cvt_to_upper); + + string str("abcdefghijklmnopqrstuvwxyz"); + string tmp; + + { + ofstream out; + out.imbue(loc); + out.open("filebuf_virtuals-4.txt"); + copy(str.begin(), str.end(), + ostreambuf_iterator(out)); + } + + { + ifstream in; + in.open("filebuf_virtuals-4.txt"); + copy(istreambuf_iterator(in), + istreambuf_iterator(), + back_inserter(tmp)); + } + + VERIFY( tmp.size() == str.size() ); + VERIFY( tmp == str ); +} + main() { test01(); @@ -582,5 +622,6 @@ main() test07(); test08(); + test09(); return 0; }