aboutsummaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorPaolo Carlini <pcarlini@unitus.it>2003-04-26 10:13:35 +0200
committerPaolo Carlini <paolo@gcc.gnu.org>2003-04-26 08:13:35 +0000
commitac5b7972ab74cf9c49c95ae311321e4b407313cd (patch)
tree3b3a0afc5646c0de8c5b8ddd4583848213227e34
parent04ab0b3e0989aa8f142f3cdb6402724f5d13ab55 (diff)
downloadgcc-ac5b7972ab74cf9c49c95ae311321e4b407313cd.zip
gcc-ac5b7972ab74cf9c49c95ae311321e4b407313cd.tar.gz
gcc-ac5b7972ab74cf9c49c95ae311321e4b407313cd.tar.bz2
streambuf.tcc (__copy_streambufs): Don't use in_avail(), simplify.
2003-04-26 Paolo Carlini <pcarlini@unitus.it> * include/bits/streambuf.tcc (__copy_streambufs): Don't use in_avail(), simplify. 2003-04-26 Paolo Carlini <pcarlini@unitus.it> * include/std/std_sstream.h (setbuf): don't set _M_buf_size, in basic_stringbuf it's unused. * include/std/std_sstream.h (underflow): consistently use _M_in_cur, not gptr(). From-SVN: r66100
-rw-r--r--libstdc++-v3/ChangeLog13
-rw-r--r--libstdc++-v3/include/bits/streambuf.tcc22
-rw-r--r--libstdc++-v3/include/std/std_sstream.h3
3 files changed, 24 insertions, 14 deletions
diff --git a/libstdc++-v3/ChangeLog b/libstdc++-v3/ChangeLog
index cfbb11a..b788831 100644
--- a/libstdc++-v3/ChangeLog
+++ b/libstdc++-v3/ChangeLog
@@ -1,3 +1,16 @@
+2003-04-26 Paolo Carlini <pcarlini@unitus.it>
+
+ * include/bits/streambuf.tcc (__copy_streambufs): Don't
+ use in_avail(), simplify.
+
+2003-04-26 Paolo Carlini <pcarlini@unitus.it>
+
+ * include/std/std_sstream.h (setbuf): don't set _M_buf_size,
+ in basic_stringbuf it's unused.
+
+ * include/std/std_sstream.h (underflow): consistently use
+ _M_in_cur, not gptr().
+
2003-04-25 Ranjit Mathew <rmathew@hotmail.com>
Phil Edwards <pme@gcc.gnu.org>
diff --git a/libstdc++-v3/include/bits/streambuf.tcc b/libstdc++-v3/include/bits/streambuf.tcc
index dff48d2..8623d25 100644
--- a/libstdc++-v3/include/bits/streambuf.tcc
+++ b/libstdc++-v3/include/bits/streambuf.tcc
@@ -188,30 +188,29 @@ namespace std
typedef typename _Traits::off_type off_type;
streamsize __ret = 0;
- streamsize __in_avail = __sbin->in_avail();
- streamsize __xtrct;
const off_type __buf_size =
__sbin->_M_buf_size > 0 ? __sbin->_M_buf_size : 1;
-
try
{
- while (__in_avail != -1)
+ for (;;)
{
- if (__in_avail != 0 && __sbin->_M_in_cur
- && __sbin->_M_in_cur + __in_avail <= __sbin->_M_in_end)
+ streamsize __xtrct;
+ const off_type __avail = __sbin->_M_in_end
+ - __sbin->_M_in_cur;
+ if (__avail)
{
- __xtrct = __sbout->sputn(__sbin->_M_in_cur, __in_avail);
+ __xtrct = __sbout->sputn(__sbin->_M_in_cur, __avail);
__ret += __xtrct;
__sbin->_M_in_cur_move(__xtrct);
- if (__xtrct != __in_avail)
+ if (__xtrct != __avail)
break;
}
else
{
streamsize __charsread;
- const streamsize __size =
- std::min(__buf_size, off_type(__sbout->_M_out_end -
- __sbout->_M_out_cur));
+ const off_type __size = std::min(__buf_size,
+ off_type(__sbout->_M_out_end
+ - __sbout->_M_out_cur));
if (__size > 1)
{
_CharT* __buf =
@@ -242,7 +241,6 @@ namespace std
}
if (_Traits::eq_int_type(__sbin->sgetc(), _Traits::eof()))
break;
- __in_avail = __sbin->in_avail();
}
}
catch(exception& __fail)
diff --git a/libstdc++-v3/include/std/std_sstream.h b/libstdc++-v3/include/std/std_sstream.h
index 48b81cd..6dc47e5 100644
--- a/libstdc++-v3/include/std/std_sstream.h
+++ b/libstdc++-v3/include/std/std_sstream.h
@@ -191,7 +191,7 @@ namespace std
underflow()
{
if (this->_M_in_cur < this->_M_in_end)
- return traits_type::to_int_type(*gptr());
+ return traits_type::to_int_type(*this->_M_in_cur);
else
return traits_type::eof();
}
@@ -230,7 +230,6 @@ namespace std
// Step 2: Use the external array.
this->_M_buf = __s;
- this->_M_buf_size = __n;
_M_really_sync(__s, 0, 0);
}
return this;