summaryrefslogtreecommitdiff
path: root/libstdc++-v3/include/bits/istream.tcc
diff options
context:
space:
mode:
authorbkoz <bkoz@138bc75d-0d04-0410-961f-82ee72b054a4>2003-12-02 02:48:51 +0000
committerbkoz <bkoz@138bc75d-0d04-0410-961f-82ee72b054a4>2003-12-02 02:48:51 +0000
commitbd6d5c37a0f4593df4a58545941bcb36e387284e (patch)
tree9b335f851086008d0a8540b39ef385da68b2f5fd /libstdc++-v3/include/bits/istream.tcc
parentdde7f1b5a18d23100b72eacf8099b7fc62c3ea7e (diff)
downloadgcc-bd6d5c37a0f4593df4a58545941bcb36e387284e.tar.gz
2003-12-01 Benjamin Kosnik <bkoz@redhat.com>
* include/bits/basic_ios.h (basic_ios::setstate): Revert. * include/bits/istream.tcc: Only call setstate if __err != goodbit. * include/bits/ostream.tcc: Same. * testsuite/27_io/basic_ios/exceptions/char/2.cc: New. * testsuite/testsuite_io.h (__gnu_test::fail_streambuf): Make internal buffer non-static. git-svn-id: svn+ssh://gcc.gnu.org/svn/gcc/trunk@74151 138bc75d-0d04-0410-961f-82ee72b054a4
Diffstat (limited to 'libstdc++-v3/include/bits/istream.tcc')
-rw-r--r--libstdc++-v3/include/bits/istream.tcc98
1 files changed, 65 insertions, 33 deletions
diff --git a/libstdc++-v3/include/bits/istream.tcc b/libstdc++-v3/include/bits/istream.tcc
index 0d85cc1bda1..abe795031df 100644
--- a/libstdc++-v3/include/bits/istream.tcc
+++ b/libstdc++-v3/include/bits/istream.tcc
@@ -77,8 +77,8 @@ namespace std
{
_M_ok = false;
__err |= ios_base::failbit;
+ __in.setstate(__err);
}
- __in.setstate(__err);
}
template<typename _CharT, typename _Traits>
@@ -121,7 +121,8 @@ namespace std
}
catch(...)
{ this->_M_setstate(ios_base::badbit); }
- this->setstate(__err);
+ if (__err)
+ this->setstate(__err);
}
return *this;
}
@@ -151,7 +152,8 @@ namespace std
}
catch(...)
{ this->_M_setstate(ios_base::badbit); }
- this->setstate(__err);
+ if (__err)
+ this->setstate(__err);
}
return *this;
}
@@ -172,7 +174,8 @@ namespace std
}
catch(...)
{ this->_M_setstate(ios_base::badbit); }
- this->setstate(__err);
+ if (__err)
+ this->setstate(__err);
}
return *this;
}
@@ -202,7 +205,8 @@ namespace std
}
catch(...)
{ this->_M_setstate(ios_base::badbit); }
- this->setstate(__err);
+ if (__err)
+ this->setstate(__err);
}
return *this;
}
@@ -223,7 +227,8 @@ namespace std
}
catch(...)
{ this->_M_setstate(ios_base::badbit); }
- this->setstate(__err);
+ if (__err)
+ this->setstate(__err);
}
return *this;
}
@@ -244,7 +249,8 @@ namespace std
}
catch(...)
{ this->_M_setstate(ios_base::badbit); }
- this->setstate(__err);
+ if (__err)
+ this->setstate(__err);
}
return *this;
}
@@ -265,7 +271,8 @@ namespace std
}
catch(...)
{ this->_M_setstate(ios_base::badbit); }
- this->setstate(__err);
+ if (__err)
+ this->setstate(__err);
}
return *this;
}
@@ -287,7 +294,8 @@ namespace std
}
catch(...)
{ this->_M_setstate(ios_base::badbit); }
- this->setstate(__err);
+ if (__err)
+ this->setstate(__err);
}
return *this;
}
@@ -308,7 +316,8 @@ namespace std
}
catch(...)
{ this->_M_setstate(ios_base::badbit); }
- this->setstate(__err);
+ if (__err)
+ this->setstate(__err);
}
return *this;
}
@@ -330,7 +339,8 @@ namespace std
}
catch(...)
{ this->_M_setstate(ios_base::badbit); }
- this->setstate(__err);
+ if (__err)
+ this->setstate(__err);
}
return *this;
}
@@ -351,7 +361,8 @@ namespace std
}
catch(...)
{ this->_M_setstate(ios_base::badbit); }
- this->setstate(__err);
+ if (__err)
+ this->setstate(__err);
}
return *this;
}
@@ -372,7 +383,8 @@ namespace std
}
catch(...)
{ this->_M_setstate(ios_base::badbit); }
- this->setstate(__err);
+ if (__err)
+ this->setstate(__err);
}
return *this;
}
@@ -393,7 +405,8 @@ namespace std
}
catch(...)
{ this->_M_setstate(ios_base::badbit); }
- this->setstate(__err);
+ if (__err)
+ this->setstate(__err);
}
return *this;
}
@@ -417,7 +430,8 @@ namespace std
}
else if (!__sbout)
__err |= ios_base::failbit;
- this->setstate(__err);
+ if (__err)
+ this->setstate(__err);
return *this;
}
@@ -447,7 +461,8 @@ namespace std
}
if (!_M_gcount)
__err |= ios_base::failbit;
- this->setstate(__err);
+ if (__err)
+ this->setstate(__err);
return __c;
}
@@ -478,7 +493,8 @@ namespace std
}
if (!_M_gcount)
__err |= ios_base::failbit;
- this->setstate(__err);
+ if (__err)
+ this->setstate(__err);
return *this;
}
@@ -516,7 +532,8 @@ namespace std
*__s = char_type();
if (!_M_gcount)
__err |= ios_base::failbit;
- this->setstate(__err);
+ if (__err)
+ this->setstate(__err);
return *this;
}
@@ -554,7 +571,8 @@ namespace std
}
if (!_M_gcount)
__err |= ios_base::failbit;
- this->setstate(__err);
+ if (__err)
+ this->setstate(__err);
return *this;
}
@@ -602,7 +620,8 @@ namespace std
*__s = char_type();
if (!_M_gcount)
__err |= ios_base::failbit;
- this->setstate(__err);
+ if (__err)
+ this->setstate(__err);
return *this;
}
@@ -635,7 +654,8 @@ namespace std
}
catch(...)
{ this->_M_setstate(ios_base::badbit); }
- this->setstate(__err);
+ if (__err)
+ this->setstate(__err);
}
return *this;
}
@@ -659,7 +679,8 @@ namespace std
}
catch(...)
{ this->_M_setstate(ios_base::badbit); }
- this->setstate(__err);
+ if (__err)
+ this->setstate(__err);
}
return __c;
}
@@ -682,7 +703,8 @@ namespace std
}
catch(...)
{ this->_M_setstate(ios_base::badbit); }
- this->setstate(__err);
+ if (__err)
+ this->setstate(__err);
}
return *this;
}
@@ -712,7 +734,8 @@ namespace std
}
catch(...)
{ this->_M_setstate(ios_base::badbit); }
- this->setstate(__err);
+ if (__err)
+ this->setstate(__err);
}
return _M_gcount;
}
@@ -739,7 +762,8 @@ namespace std
}
catch(...)
{ this->_M_setstate(ios_base::badbit); }
- this->setstate(__err);
+ if (__err)
+ this->setstate(__err);
}
return *this;
}
@@ -766,7 +790,8 @@ namespace std
}
catch(...)
{ this->_M_setstate(ios_base::badbit); }
- this->setstate(__err);
+ if (__err)
+ this->setstate(__err);
}
return *this;
}
@@ -796,7 +821,8 @@ namespace std
}
catch(...)
{ this->_M_setstate(ios_base::badbit); }
- this->setstate(__err);
+ if (__err)
+ this->setstate(__err);
}
return __ret;
}
@@ -841,7 +867,8 @@ namespace std
}
catch(...)
{ this->_M_setstate(ios_base::badbit); }
- this->setstate(__err);
+ if (__err)
+ this->setstate(__err);
return *this;
}
@@ -868,7 +895,8 @@ namespace std
}
catch(...)
{ this->_M_setstate(ios_base::badbit); }
- this->setstate(__err);
+ if (__err)
+ this->setstate(__err);
return *this;
}
@@ -892,7 +920,8 @@ namespace std
}
catch(...)
{ __in._M_setstate(ios_base::badbit); }
- __in.setstate(__err);
+ if (__err)
+ __in.setstate(__err);
}
return __in;
}
@@ -947,7 +976,8 @@ namespace std
}
if (!__extracted)
__err |= ios_base::failbit;
- __in.setstate(__err);
+ if (__err)
+ __in.setstate(__err);
return __in;
}
@@ -1028,7 +1058,8 @@ namespace std
// 211. operator>>(istream&, string&) doesn't set failbit
if (!__extracted)
__err |= ios_base::failbit;
- __in.setstate(__err);
+ if (__err)
+ __in.setstate(__err);
return __in;
}
@@ -1081,7 +1112,8 @@ namespace std
}
if ((!__extracted && !__testdelim) || __extracted == __n)
__err |= ios_base::failbit;
- __in.setstate(__err);
+ if (__err)
+ __in.setstate(__err);
return __in;
}