From: Benjamin Kosnik Date: Mon, 11 Jun 2001 19:20:20 +0000 (+0000) Subject: ostream.tcc (ostream::seekp): Add error checking as per DR 129. X-Git-Url: https://git.libre-soc.org/?a=commitdiff_plain;h=d52a9847833019e4d61a4b2ed2c3dcb144a615b1;p=gcc.git ostream.tcc (ostream::seekp): Add error checking as per DR 129. 2001-06-11 Benjamin Kosnik libstdc++/3114 * include/bits/ostream.tcc (ostream::seekp): Add error checking as per DR 129. * include/bits/istream.tcc (istream::seekg): Same. * testsuite/27_io/istream_seeks.cc: Fix. libstdc++/3113 * include/bits/stl_function.h (binder2nd): Fix as per DR 109. (binder1st): Same. * include/bits/std_queue.h: Add c++config.h. * testsuite/20_util/binders.cc: New test. From-SVN: r43201 --- diff --git a/libstdc++-v3/ChangeLog b/libstdc++-v3/ChangeLog index 6a6991b8df1..d21f28fba96 100644 --- a/libstdc++-v3/ChangeLog +++ b/libstdc++-v3/ChangeLog @@ -1,3 +1,17 @@ +2001-06-11 Benjamin Kosnik + + libstdc++/3114 + * include/bits/ostream.tcc (ostream::seekp): Add error checking as + per DR 129. + * include/bits/istream.tcc (istream::seekg): Same. + * testsuite/27_io/istream_seeks.cc: Fix. + + libstdc++/3113 + * include/bits/stl_function.h (binder2nd): Fix as per DR 109. + (binder1st): Same. + * include/bits/std_queue.h: Add c++config.h. + * testsuite/20_util/binders.cc: New test. + 2001-06-11 Matthias Klose Phil Edwards diff --git a/libstdc++-v3/include/bits/istream.tcc b/libstdc++-v3/include/bits/istream.tcc index 813284047e8..e794fe33060 100644 --- a/libstdc++-v3/include/bits/istream.tcc +++ b/libstdc++-v3/include/bits/istream.tcc @@ -959,7 +959,11 @@ namespace std { #ifdef _GLIBCPP_RESOLVE_LIB_DEFECTS // 136. seekp, seekg setting wrong streams? - this->rdbuf()->pubseekpos(__pos, ios_base::in); + pos_type __err = this->rdbuf()->pubseekpos(__pos, ios_base::in); + +// 129. Need error indication from seekp() and seekg() + if (__err == pos_type(off_type(-1))) + this->setstate(failbit); #endif } catch(exception& __fail) @@ -987,7 +991,12 @@ namespace std { #ifdef _GLIBCPP_RESOLVE_LIB_DEFECTS // 136. seekp, seekg setting wrong streams? - this->rdbuf()->pubseekoff(__off, __dir, ios_base::in); + pos_type __err = this->rdbuf()->pubseekoff(__off, __dir, + ios_base::in); + +// 129. Need error indication from seekp() and seekg() + if (__err == pos_type(off_type(-1))) + this->setstate(failbit); #endif } catch(exception& __fail) diff --git a/libstdc++-v3/include/bits/ostream.tcc b/libstdc++-v3/include/bits/ostream.tcc index 60294c308fc..c3cb5d2dced 100644 --- a/libstdc++-v3/include/bits/ostream.tcc +++ b/libstdc++-v3/include/bits/ostream.tcc @@ -411,10 +411,16 @@ namespace std bool __testok = this->fail() != true; if (__testok) + { #ifdef _GLIBCPP_RESOLVE_LIB_DEFECTS // 136. seekp, seekg setting wrong streams? - this->rdbuf()->pubseekpos(__pos, ios_base::out); + pos_type __err = this->rdbuf()->pubseekpos(__pos, ios_base::out); + +// 129. Need error indication from seekp() and seekg() + if (__err == pos_type(off_type(-1))) + this->setstate(failbit); #endif + } return *this; } @@ -426,9 +432,16 @@ namespace std bool __testok = this->fail() != true; if (__testok) + { #ifdef _GLIBCPP_RESOLVE_LIB_DEFECTS // 136. seekp, seekg setting wrong streams? - this->rdbuf()->pubseekoff(__off, __d, ios_base::out); + pos_type __err = this->rdbuf()->pubseekoff(__off, __d, + ios_base::out); + +// 129. Need error indication from seekp() and seekg() + if (__err == pos_type(off_type(-1))) + this->setstate(failbit); + } #endif return *this; } diff --git a/libstdc++-v3/include/bits/std_queue.h b/libstdc++-v3/include/bits/std_queue.h index d7264793643..b3b80abd724 100644 --- a/libstdc++-v3/include/bits/std_queue.h +++ b/libstdc++-v3/include/bits/std_queue.h @@ -28,7 +28,7 @@ #define _CPP_QUEUE 1 #pragma GCC system_header - +#include #include #include #include diff --git a/libstdc++-v3/include/bits/stl_function.h b/libstdc++-v3/include/bits/stl_function.h index 6c26193dd81..43bf93296b6 100644 --- a/libstdc++-v3/include/bits/stl_function.h +++ b/libstdc++-v3/include/bits/stl_function.h @@ -199,6 +199,13 @@ public: operator()(const typename _Operation::second_argument_type& __x) const { return op(value, __x); } +#ifdef _GLIBCPP_RESOLVE_LIB_DEFECTS + // 109. Missing binders for non-const sequence elements + typename _Operation::result_type + operator()(typename _Operation::second_argument_type& __x) const { + return op(value, __x); + } +#endif }; template @@ -224,6 +231,13 @@ public: operator()(const typename _Operation::first_argument_type& __x) const { return op(__x, value); } +#ifdef _GLIBCPP_RESOLVE_LIB_DEFECTS + // 109. Missing binders for non-const sequence elements + typename _Operation::result_type + operator()(typename _Operation::first_argument_type& __x) const { + return op(__x, value); + } +#endif }; template diff --git a/libstdc++-v3/testsuite/20_util/binders.cc b/libstdc++-v3/testsuite/20_util/binders.cc new file mode 100644 index 00000000000..6dd45e3ff96 --- /dev/null +++ b/libstdc++-v3/testsuite/20_util/binders.cc @@ -0,0 +1,51 @@ +// 2001-06-11 Benjamin Kosnik + +// Copyright (C) 2001 Free Software Foundation, Inc. +// +// 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. + +// 20.3.6 Binders + +#include +#include // for_each +#include + +class Elem +{ +public: + void print(int i) const { } + void modify(int i) { } +}; + +// libstdc++/3113 +void test01() +{ + std::vector coll(2); + // OK + std::for_each(coll.begin(), coll.end(), + std::bind2nd(std::mem_fun_ref(&Elem::print), 42)); + // OK + std::for_each(coll.begin(), coll.end(), + std::bind2nd(std::mem_fun_ref(&Elem::modify), 42)); +} + + +int main() +{ + test01(); + return 0; +} diff --git a/libstdc++-v3/testsuite/27_io/istream_seeks.cc b/libstdc++-v3/testsuite/27_io/istream_seeks.cc index 7b3b8910f03..97ef01b121c 100644 --- a/libstdc++-v3/testsuite/27_io/istream_seeks.cc +++ b/libstdc++-v3/testsuite/27_io/istream_seeks.cc @@ -249,7 +249,7 @@ void test05(void) state02 = is03.rdstate(); pos05 = is03.tellg(); VERIFY( pos05 == pos06 ); // as only out buffer - VERIFY( state01 == state02 ); + VERIFY( state01 != state02 ); pos06 = is03.tellg(); VERIFY( pos05 == pos06 );