istream.cc (basic_istream<char>::ignore(streamsize), [...]): Revert 2005-01-05 change...
authorPaolo Carlini <pcarlini@suse.de>
Tue, 11 Jan 2005 16:48:14 +0000 (16:48 +0000)
committerPaolo Carlini <paolo@gcc.gnu.org>
Tue, 11 Jan 2005 16:48:14 +0000 (16:48 +0000)
2005-01-11  Paolo Carlini  <pcarlini@suse.de>

* src/istream.cc (basic_istream<char>::ignore(streamsize),
basic_istream<char>::ignore(streamsize, int_type),
basic_istream<wchar_t>::ignore(streamsize),
basic_istream<wchar_t>::ignore(streamsize, int_type)): Revert
2005-01-05 change: actually, the previous behavior is conforming
and consistent with that of get(char_type*, streamsize, char_type),
albeit slightly different from that of 3.3/3.4 in a corner case
due to the use of snextc.
* include/bits/istream.tcc (ignore(streamsize), ignore(streamsize,
int_type)): Likewise.
* testsuite/27_io/basic_istream/ignore/char/4.cc: Remove.
* testsuite/27_io/basic_istream/ignore/wchar_t/4.cc: Likewise.

From-SVN: r93189

libstdc++-v3/ChangeLog
libstdc++-v3/include/bits/istream.tcc
libstdc++-v3/src/istream.cc
libstdc++-v3/testsuite/27_io/basic_istream/ignore/char/4.cc [deleted file]
libstdc++-v3/testsuite/27_io/basic_istream/ignore/wchar_t/4.cc [deleted file]

index bb1599cae1e062ab05490fab087991f4a3e19487..434f487d8ff2c230b7fa4cefd07c6783307854c0 100644 (file)
@@ -1,3 +1,18 @@
+2005-01-11  Paolo Carlini  <pcarlini@suse.de>
+
+       * src/istream.cc (basic_istream<char>::ignore(streamsize),
+       basic_istream<char>::ignore(streamsize, int_type),
+       basic_istream<wchar_t>::ignore(streamsize),
+       basic_istream<wchar_t>::ignore(streamsize, int_type)): Revert
+       2005-01-05 change: actually, the previous behavior is conforming
+       and consistent with that of get(char_type*, streamsize, char_type),
+       albeit slightly different from that of 3.3/3.4 in a corner case
+       due to the use of snextc.
+       * include/bits/istream.tcc (ignore(streamsize), ignore(streamsize,
+       int_type)): Likewise.
+       * testsuite/27_io/basic_istream/ignore/char/4.cc: Remove.
+       * testsuite/27_io/basic_istream/ignore/wchar_t/4.cc: Likewise.
+
 2005-01-11  Paolo Carlini  <pcarlini@suse.de>
 
        * include/tr1/type_traits: Implement alignment_of and aligned_storage.
index 876f626acfcf5066e1a02a27224b318219fd2e6f..1cb88cad114161f0bcede4687a18d4fcb54defc2 100644 (file)
@@ -707,7 +707,7 @@ namespace std
                    break;
                }
 
-             if (_M_gcount < __n)
+             if (traits_type::eq_int_type(__c, __eof))
                 __err |= ios_base::eofbit;
             }
           catch(...)
@@ -755,11 +755,9 @@ namespace std
                    break;
                }
 
-             if (_M_gcount == __n)
-               ;
-              else if (traits_type::eq_int_type(__c, __eof))
+              if (traits_type::eq_int_type(__c, __eof))
                 __err |= ios_base::eofbit;
-             else
+             else if (traits_type::eq_int_type(__c, __delim))
                {
                  ++_M_gcount;
                  __sb->sbumpc();
index dc99051a022eb69607e90f61d75a4dc0052c1dec..e3a364902836b4bc305fc82bf516fc1aa4f312be 100644 (file)
@@ -152,7 +152,7 @@ namespace std
                    break;
                }
 
-             if (_M_gcount < __n)
+             if (traits_type::eq_int_type(__c, __eof))
                __err |= ios_base::eofbit;
            }
          catch(...)
@@ -217,11 +217,9 @@ namespace std
                    break;
                }
 
-             if (_M_gcount == __n)
-               ;
-             else if (traits_type::eq_int_type(__c, __eof))
+             if (traits_type::eq_int_type(__c, __eof))
                __err |= ios_base::eofbit;
-             else
+             else if (traits_type::eq_int_type(__c, __delim))
                {
                  ++_M_gcount;
                  __sb->sbumpc();
@@ -432,7 +430,7 @@ namespace std
                    break;
                }
 
-             if (_M_gcount < __n)
+             if (traits_type::eq_int_type(__c, __eof))
                __err |= ios_base::eofbit;
            }
          catch(...)
@@ -497,11 +495,9 @@ namespace std
                    break;
                }
 
-             if (_M_gcount == __n)
-               ;
-             else if (traits_type::eq_int_type(__c, __eof))
+             if (traits_type::eq_int_type(__c, __eof))
                __err |= ios_base::eofbit;
-             else
+             else if (traits_type::eq_int_type(__c, __delim))
                {
                  ++_M_gcount;
                  __sb->sbumpc();
diff --git a/libstdc++-v3/testsuite/27_io/basic_istream/ignore/char/4.cc b/libstdc++-v3/testsuite/27_io/basic_istream/ignore/char/4.cc
deleted file mode 100644 (file)
index 474f6a9..0000000
+++ /dev/null
@@ -1,59 +0,0 @@
-// 2005-01-05  Paolo Carlini  <pcarlini@suse.de>
-
-// Copyright (C) 2005 Free Software Foundation
-//
-// 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.
-
-// 27.6.1.3 unformatted input functions
-
-#include <istream>
-#include <sstream>
-#include <testsuite_hooks.h>
-
-void
-test01()
-{
-  using namespace std;
-  bool test __attribute__((unused)) = true;
-
-  const string str_01("Gesang der junglinge");
-  ios_base::iostate state1, state2;
-
-  stringbuf isbuf_01(str_01, ios_base::in);
-  istream is_01(&isbuf_01);
-
-  state1 = is_01.rdstate();
-  VERIFY( state1 == ios_base::goodbit );
-
-  is_01.ignore(11, 'j');
-  VERIFY( is_01.gcount() == 11 );
-  state2 = is_01.rdstate();
-  VERIFY( state2 == state1 );
-  VERIFY( is_01.peek() == 'j' );
-
-  is_01.ignore(9);
-  VERIFY( is_01.gcount() == 9 );
-  state2 = is_01.rdstate();
-  VERIFY( state2 == state1 );
-}
-
-int 
-main()
-{
-  test01();
-  return 0;
-}
diff --git a/libstdc++-v3/testsuite/27_io/basic_istream/ignore/wchar_t/4.cc b/libstdc++-v3/testsuite/27_io/basic_istream/ignore/wchar_t/4.cc
deleted file mode 100644 (file)
index 3618117..0000000
+++ /dev/null
@@ -1,59 +0,0 @@
-// 2005-01-05  Paolo Carlini  <pcarlini@suse.de>
-
-// Copyright (C) 2005 Free Software Foundation
-//
-// 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.
-
-// 27.6.1.3 unformatted input functions
-
-#include <istream>
-#include <sstream>
-#include <testsuite_hooks.h>
-
-void
-test01()
-{
-  using namespace std;
-  bool test __attribute__((unused)) = true;
-
-  const wstring str_01(L"Gesang der junglinge");
-  ios_base::iostate state1, state2;
-
-  wstringbuf isbuf_01(str_01, ios_base::in);
-  wistream is_01(&isbuf_01);
-
-  state1 = is_01.rdstate();
-  VERIFY( state1 == ios_base::goodbit );
-
-  is_01.ignore(11, L'j');
-  VERIFY( is_01.gcount() == 11 );
-  state2 = is_01.rdstate();
-  VERIFY( state2 == state1 );
-  VERIFY( is_01.peek() == L'j' );
-
-  is_01.ignore(9);
-  VERIFY( is_01.gcount() == 9 );
-  state2 = is_01.rdstate();
-  VERIFY( state2 == state1 );
-}
-
-int 
-main()
-{
-  test01();
-  return 0;
-}