istream.tcc (ignore): Correctly deal with n == numeric_limits<streamsize>::max().
authorPaolo Carlini <pcarlini@suse.de>
Mon, 24 May 2004 09:40:56 +0000 (09:40 +0000)
committerPaolo Carlini <paolo@gcc.gnu.org>
Mon, 24 May 2004 09:40:56 +0000 (09:40 +0000)
2004-05-24  Paolo Carlini  <pcarlini@suse.de>

* include/bits/istream.tcc (ignore): Correctly deal with
n == numeric_limits<streamsize>::max().
* testsuite/27_io/basic_istream/ignore/char/2.cc: New.

* include/bits/istream.tcc (basic_istream<>::getline): Prefer
'_M_gcount + 1 < __n' to '--__n; _M_gcount < __n', just in case
__n == numeric_limits<>::min().

* include/bits/istream.tcc: Minor tweaks.

* testsuite/21_strings/basic_string/inserters_extractors/char/10.cc:
Tighten.
* testsuite/21_strings/basic_string/inserters_extractors/char/11.cc:
Likewise.
* testsuite/21_strings/basic_string/inserters_extractors/wchar_t/10.cc:
Likewise.
* testsuite/21_strings/basic_string/inserters_extractors/wchar_t/11.cc:
Likewise.
* testsuite/27_io/basic_istream/getline/char/5.cc: Likewise.

From-SVN: r82198

libstdc++-v3/ChangeLog
libstdc++-v3/include/bits/istream.tcc
libstdc++-v3/testsuite/21_strings/basic_string/inserters_extractors/char/10.cc
libstdc++-v3/testsuite/21_strings/basic_string/inserters_extractors/char/11.cc
libstdc++-v3/testsuite/21_strings/basic_string/inserters_extractors/wchar_t/10.cc
libstdc++-v3/testsuite/21_strings/basic_string/inserters_extractors/wchar_t/11.cc
libstdc++-v3/testsuite/27_io/basic_istream/getline/char/5.cc
libstdc++-v3/testsuite/27_io/basic_istream/ignore/char/2.cc [new file with mode: 0644]

index 9f31df188075dd4b235cdb30abb6a71e8ffcd249..8673f258a6502bef6e73dda9689cefcdbbf6604d 100644 (file)
@@ -1,3 +1,25 @@
+2004-05-24  Paolo Carlini  <pcarlini@suse.de>
+
+       * include/bits/istream.tcc (ignore): Correctly deal with
+       n == numeric_limits<streamsize>::max().
+       * testsuite/27_io/basic_istream/ignore/char/2.cc: New.
+
+       * include/bits/istream.tcc (basic_istream<>::getline): Prefer
+       '_M_gcount + 1 < __n' to '--__n; _M_gcount < __n', just in case
+       __n == numeric_limits<>::min().
+
+       * include/bits/istream.tcc: Minor tweaks.
+
+       * testsuite/21_strings/basic_string/inserters_extractors/char/10.cc:
+       Tighten.
+       * testsuite/21_strings/basic_string/inserters_extractors/char/11.cc:
+       Likewise.
+       * testsuite/21_strings/basic_string/inserters_extractors/wchar_t/10.cc:
+       Likewise.
+       * testsuite/21_strings/basic_string/inserters_extractors/wchar_t/11.cc:
+       Likewise.
+       * testsuite/27_io/basic_istream/getline/char/5.cc: Likewise.
+
 2004-05-22  Benjamin Kosnik  <bkoz@redhat.com>
 
        PR libstdc++/12854
index 52deb6eda4f6eb4603b06570511fd773117b9d5c..6417e951f03a0e0fee5609749103cddc4550275d 100644 (file)
@@ -519,8 +519,8 @@ namespace std
                     && !traits_type::eq_int_type(__c, __idelim))
                {
                  *__s++ = traits_type::to_char_type(__c);
-                 __c = __sb->snextc();
                  ++_M_gcount;
+                 __c = __sb->snextc();
                }
              if (traits_type::eq_int_type(__c, __eof))
                __err |= ios_base::eofbit;
@@ -591,15 +591,14 @@ namespace std
              const int_type __eof = traits_type::eof();
              __streambuf_type* __sb = this->rdbuf();
              int_type __c = __sb->sgetc();
-             --__n;
              
-             while (_M_gcount < __n
+             while (_M_gcount + 1 < __n
                     && !traits_type::eq_int_type(__c, __eof)
                     && !traits_type::eq_int_type(__c, __idelim))
                {
                  streamsize __size = std::min(streamsize(__sb->egptr()
                                                          - __sb->gptr()),
-                                              __n - _M_gcount);
+                                              __n - _M_gcount - 1);
                  if (__size > 1)
                    {
                      const char_type* __p = traits_type::find(__sb->gptr(),
@@ -616,8 +615,8 @@ namespace std
                  else
                    {
                      *__s++ = traits_type::to_char_type(__c);
-                     __c = __sb->snextc();
                      ++_M_gcount;
+                     __c = __sb->snextc();
                    }
                }
 
@@ -625,8 +624,8 @@ namespace std
                __err |= ios_base::eofbit;
              else if (traits_type::eq_int_type(__c, __idelim))
                {
+                 ++_M_gcount;            
                  __sb->sbumpc();
-                 ++_M_gcount;
                }
              else
                __err |= ios_base::failbit;
@@ -658,7 +657,9 @@ namespace std
              __streambuf_type* __sb = this->rdbuf();
              int_type __c;
 
-             while (_M_gcount < __n
+             if (__n != numeric_limits<streamsize>::max())
+               --__n;
+             while (_M_gcount <= __n
                     && !traits_type::eq_int_type(__c = __sb->sbumpc(), __eof))
                {
                  ++_M_gcount;
@@ -1101,7 +1102,6 @@ namespace std
 
       __size_type __extracted = 0;
       const __size_type __n = __str.max_size();
-      bool __testdelim = false;
       ios_base::iostate __err = ios_base::iostate(ios_base::goodbit);
       typename __istream_type::sentry __cerb(__in, true);
       if (__cerb)
@@ -1136,8 +1136,8 @@ namespace std
                __err |= ios_base::eofbit;
              else if (_Traits::eq_int_type(__c, __idelim))
                {
+                 ++__extracted;                  
                  __sb->sbumpc();
-                 ++__extracted;
                }
              else
                __err |= ios_base::failbit;
index 75b7e89d2a57e35031bd1cb60523e4c05cd878be..4822b6b2916a5c65f80d08f76836c06d41f702ca 100644 (file)
@@ -38,20 +38,23 @@ string prepare(string::size_type len, unsigned nchunks, char delim)
   return ret;
 }
 
-void check(istream& stream, const string& str, char delim)
+void check(istream& stream, const string& str, unsigned nchunks, char delim)
 {
   bool test __attribute__((unused)) = true;
 
   string chunk;
   string::size_type index = 0, index_new = 0;
+  unsigned n = 0;
 
   while (getline(stream, chunk, delim))
     {
       index_new = str.find(delim, index);
       VERIFY( !str.compare(index, index_new - index, chunk) );
       index = index_new + 1;
+      ++n;
     }
   VERIFY( stream.eof() );
+  VERIFY( n == nchunks );
 }
 
 // istream& getline(istream&, string&, char)
@@ -60,7 +63,8 @@ void test01()
   const char filename[] = "inserters_extractors-2.txt";
 
   const char delim = '|';
-  const string data = prepare(777, 10, delim);
+  const unsigned nchunks = 10;
+  const string data = prepare(777, nchunks, delim);
 
   ofstream ofstrm;
   ofstrm.open(filename);
@@ -69,7 +73,7 @@ void test01()
 
   ifstream ifstrm;
   ifstrm.open(filename);
-  check(ifstrm, data, delim);
+  check(ifstrm, data, nchunks, delim);
   ifstrm.close();
 }
 
index cee596e5b99ce3d88cf064198fb8be5b6e4d040f..e60c441110ba302f7f943e254d02f35274027ff1 100644 (file)
@@ -38,20 +38,23 @@ string prepare(string::size_type len, unsigned nchunks)
   return ret;
 }
 
-void check(istream& stream, const string& str)
+void check(istream& stream, const string& str, unsigned nchunks)
 {
   bool test __attribute__((unused)) = true;
 
   string chunk;
   string::size_type index = 0, index_new = 0;
+  unsigned n = 0;
 
   while (stream >> chunk)
     {
       index_new = str.find(' ', index);
       VERIFY( !str.compare(index, index_new - index, chunk) );
       index = index_new + 1;
+      ++n;
     }
   VERIFY( stream.eof() );
+  VERIFY( n == nchunks );  
 }
 
 // istream& operator>>(istream&, string&)
@@ -59,7 +62,8 @@ void test01()
 {
   const char filename[] = "inserters_extractors-3.txt";
 
-  const string data = prepare(666, 10);
+  const unsigned nchunks = 10;
+  const string data = prepare(666, nchunks);
 
   ofstream ofstrm;
   ofstrm.open(filename);
@@ -68,7 +72,7 @@ void test01()
 
   ifstream ifstrm;
   ifstrm.open(filename);
-  check(ifstrm, data);
+  check(ifstrm, data, nchunks);
   ifstrm.close();
 }
 
index 5f1e1d77d9e57738d2d052e9859c45e35ced67ee..ba6bbaf31fa4b7a20c01b00576f99fe21a5dee69 100644 (file)
@@ -38,20 +38,23 @@ wstring prepare(wstring::size_type len, unsigned nchunks, wchar_t delim)
   return ret;
 }
 
-void check(wistream& stream, const wstring& str, wchar_t delim)
+void check(wistream& stream, const wstring& str, unsigned nchunks, wchar_t delim)
 {
   bool test __attribute__((unused)) = true;
 
   wstring chunk;
   wstring::size_type index = 0, index_new = 0;
+  unsigned n = 0;
 
   while (getline(stream, chunk, delim))
     {
       index_new = str.find(delim, index);
       VERIFY( !str.compare(index, index_new - index, chunk) );
       index = index_new + 1;
+      ++n;
     }
   VERIFY( stream.eof() );
+  VERIFY( n == nchunks );
 }
 
 // istream& getline(istream&, string&, char)
@@ -60,7 +63,8 @@ void test01()
   const char filename[] = "inserters_extractors-2.txt";
 
   const wchar_t delim = L'|';
-  const wstring data = prepare(777, 10, delim);
+  const unsigned nchunks = 10;
+  const wstring data = prepare(777, nchunks, delim);
 
   wofstream ofstrm;
   ofstrm.open(filename);
@@ -69,7 +73,7 @@ void test01()
 
   wifstream ifstrm;
   ifstrm.open(filename);
-  check(ifstrm, data, delim);
+  check(ifstrm, data, nchunks, delim);
   ifstrm.close();
 }
 
index ac2e8c3a0e2c3beb6e5100c9f975b30b0915468e..66fae676d7a0b6b8f8fdd65f5ec97400b3907d7a 100644 (file)
@@ -38,20 +38,23 @@ wstring prepare(wstring::size_type len, unsigned nchunks)
   return ret;
 }
 
-void check(wistream& stream, const wstring& str)
+void check(wistream& stream, const wstring& str, unsigned nchunks)
 {
   bool test __attribute__((unused)) = true;
 
   wstring chunk;
   wstring::size_type index = 0, index_new = 0;
+  unsigned n = 0;
 
   while (stream >> chunk)
     {
       index_new = str.find(L' ', index);
       VERIFY( !str.compare(index, index_new - index, chunk) );
       index = index_new + 1;
+      ++n;
     }
   VERIFY( stream.eof() );
+  VERIFY( n == nchunks );
 }
 
 // istream& operator>>(istream&, string&)
@@ -59,7 +62,8 @@ void test01()
 {
   const char filename[] = "inserters_extractors-3.txt";
 
-  const wstring data = prepare(666, 10);
+  const unsigned nchunks = 10;
+  const wstring data = prepare(666, nchunks);
 
   wofstream ofstrm;
   ofstrm.open(filename);
@@ -68,7 +72,7 @@ void test01()
 
   wifstream ifstrm;
   ifstrm.open(filename);
-  check(ifstrm, data);
+  check(ifstrm, data, nchunks);
   ifstrm.close();
 }
 
index b2f07725c6448d2f35f55a991cf4840bd4afce18..9001f52367cde0b18b3f5910b3876f9b01a7897c 100644 (file)
@@ -38,12 +38,13 @@ string prepare(string::size_type len, unsigned nchunks, char delim)
   return ret;
 }
 
-void check(istream& stream, const string& str, char delim)
+void check(istream& stream, const string& str, unsigned nchunks, char delim)
 {
   bool test __attribute__((unused)) = true;
 
   char buf[1000000];
   string::size_type index = 0, index_new = 0;
+  unsigned n = 0;
 
   while (stream.getline(buf, sizeof(buf), delim))
     {
@@ -51,9 +52,11 @@ void check(istream& stream, const string& str, char delim)
       VERIFY( stream.gcount() == index_new - index + 1 );
       VERIFY( !str.compare(index, index_new - index, buf) );
       index = index_new + 1;
+      ++n;
     }
   VERIFY( stream.gcount() == 0 );
   VERIFY( stream.eof() );
+  VERIFY( n == nchunks );
 }
 
 void test01()
@@ -61,7 +64,8 @@ void test01()
   const char filename[] = "istream_getline.txt";
 
   const char delim = '|';
-  const string data = prepare(777, 10, delim);
+  const unsigned nchunks = 10;
+  const string data = prepare(777, nchunks, delim);
 
   ofstream ofstrm;
   ofstrm.open(filename);
@@ -70,7 +74,7 @@ void test01()
 
   ifstream ifstrm;
   ifstrm.open(filename);
-  check(ifstrm, data, delim);
+  check(ifstrm, data, nchunks, delim);
   ifstrm.close();
 }
 
diff --git a/libstdc++-v3/testsuite/27_io/basic_istream/ignore/char/2.cc b/libstdc++-v3/testsuite/27_io/basic_istream/ignore/char/2.cc
new file mode 100644 (file)
index 0000000..85bdbfc
--- /dev/null
@@ -0,0 +1,84 @@
+// Copyright (C) 2004 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 <string>
+#include <fstream>
+#include <limits>
+#include <testsuite_hooks.h>
+
+using namespace std;
+
+string prepare(string::size_type len, unsigned nchunks, char delim)
+{
+  string ret;
+  for (unsigned i = 0; i < nchunks; ++i)
+    {
+      for (string::size_type j = 0; j < len; ++j)
+       ret.push_back('a' + rand() % 26);
+      len *= 2;
+      ret.push_back(delim);
+    }
+  return ret;
+}
+
+void check(istream& stream, const string& str, unsigned nchunks, char delim)
+{
+  bool test __attribute__((unused)) = true;
+
+  string::size_type index = 0, index_new = 0;
+  unsigned n = 0;
+
+  while (stream.ignore(numeric_limits<streamsize>::max(), delim).good())
+    {
+      index_new = str.find(delim, index);
+      VERIFY( stream.gcount() == index_new - index + 1 );
+      index = index_new + 1;
+      ++n;
+    }
+  VERIFY( stream.gcount() == 0 );
+  VERIFY( !stream.fail() );
+  VERIFY( n == nchunks );
+}
+
+void test01()
+{
+  const char filename[] = "istream_ignore.txt";
+
+  const char delim = '|';
+  const unsigned nchunks = 10;
+  const string data = prepare(555, nchunks, delim);
+
+  ofstream ofstrm;
+  ofstrm.open(filename);
+  ofstrm.write(data.data(), data.size());
+  ofstrm.close();
+
+  ifstream ifstrm;
+  ifstrm.open(filename);
+  check(ifstrm, data, nchunks, delim);
+  ifstrm.close();
+}
+
+int main()
+{
+  test01();
+  return 0;
+}