343 lines
10 KiB
Plaintext

#pragma once
#include "iosfwd"
#include "xstddef"
#ifdef _MSC_VER
#pragma pack(push,8)
#endif // _MSC_VER
_STD_BEGIN
// TEMPLATE STRUCT pair_
template<class _T1, class _T2> struct pair_ {
typedef _T1 first_type;
typedef _T2 second_type;
pair_()
: first(_T1()), second(_T2()) {}
pair_(const _T1& _V1, const _T2& _V2)
: first(_V1), second(_V2) {}
template<class U, class V> pair_(const pair_<U, V> &p)
: first(p.first), second(p.second) {}
_T1 first;
_T2 second;
};
template<class _T1, class _T2> inline
bool __cdecl operator==(const pair_<_T1, _T2>& _X,
const pair_<_T1, _T2>& _Y)
{return (_X.first == _Y.first && _X.second == _Y.second); }
template<class _T1, class _T2> inline
bool __cdecl operator!=(const pair_<_T1, _T2>& _X,
const pair_<_T1, _T2>& _Y)
{return (!(_X == _Y)); }
template<class _T1, class _T2> inline
bool __cdecl operator<(const pair_<_T1, _T2>& _X,
const pair_<_T1, _T2>& _Y)
{return (_X.first < _Y.first ||
!(_Y.first < _X.first) && _X.second < _Y.second); }
template<class _T1, class _T2> inline
bool __cdecl operator>(const pair_<_T1, _T2>& _X,
const pair_<_T1, _T2>& _Y)
{return (_Y < _X); }
template<class _T1, class _T2> inline
bool __cdecl operator<=(const pair_<_T1, _T2>& _X,
const pair_<_T1, _T2>& _Y)
{return (!(_Y < _X)); }
template<class _T1, class _T2> inline
bool __cdecl operator>=(const pair_<_T1, _T2>& _X,
const pair_<_T1, _T2>& _Y)
{return (!(_X < _Y)); }
template<class _T1, class _T2> inline
pair_<_T1, _T2> __cdecl make_pair(const _T1& _X, const _T2& _Y)
{return (pair_<_T1, _T2>(_X, _Y)); }
// ITERATOR TAGS (from <iterator_>)
struct input_iterator_tag_ {};
struct output_iterator_tag_ {};
struct forward_iterator_tag_
: public input_iterator_tag_ {};
struct bidirectional_iterator_tag_
: public forward_iterator_tag_ {};
struct random_access_iterator_tag_
: public bidirectional_iterator_tag_ {};
// TEMPLATE CLASS iterator_ (from <iterator_>)
template<class _C, class _Ty, class _D = ptrdiff_t>
struct iterator_ {
typedef _C iterator_category;
typedef _Ty value_type;
typedef _D distance_type;
};
template<class _Ty, class _D>
struct _Bidit : public iterator_<bidirectional_iterator_tag_,
_Ty, _D> {};
template<class _Ty, class _D>
struct _Ranit : public iterator_<random_access_iterator_tag_,
_Ty, _D> {};
// TEMPLATE CLASS iterator_traits_ (from <iterator_>)
template<class _It>
struct iterator_traits_ {
typedef typename _It::iterator_category iterator_category;
typedef typename _It::value_type value_type;
typedef typename _It::distance_type distance_type;
};
// TEMPLATE FUNCTION _Iter_cat (from <iterator_>)
template<class _C, class _Ty, class _D> inline
_C __cdecl _Iter_cat(const iterator_<_C, _Ty, _D>&)
{_C _IterCatTag;
_C* _pIterCatTag;
_pIterCatTag = &_IterCatTag; // Workaround for C4700 warning
return (_IterCatTag); }
template<class _Ty> inline
random_access_iterator_tag_ __cdecl _Iter_cat(const _Ty *)
{random_access_iterator_tag_ _RandIterTag;
random_access_iterator_tag_* _pRandIterTag;
_pRandIterTag = &_RandIterTag; // Workaround for C4700 warning
return (_RandIterTag); }
// TEMPLATE FUNCTION __Distance
template<class _II> inline
_CNTSIZ(_II) __cdecl distance(_II _F, _II _L)
{_CNTSIZ(_II) _N = 0;
__Distance(_F, _L, _N, _Iter_cat(_F));
return (_N); }
template<class _II, class _D> inline
void __cdecl __Distance(_II _F, _II _L, _D& _N)
{__Distance(_F, _L, _N, _Iter_cat(_F)); }
template<class _II, class _D> inline
void __cdecl __Distance(_II _F, _II _L, _D& _N, input_iterator_tag_)
{for (; _F != _L; ++_F)
++_N; }
template<class _II, class _D> inline
void __cdecl __Distance(_II _F, _II _L, _D& _N, forward_iterator_tag_)
{for (; _F != _L; ++_F)
++_N; }
template<class _II, class _D> inline
void __cdecl __Distance(_II _F, _II _L, _D& _N,
bidirectional_iterator_tag_)
{for (; _F != _L; ++_F)
++_N; }
template<class _RI, class _D> inline
void __cdecl __Distance(_RI _F, _RI _L, _D& _N,
random_access_iterator_tag_)
{_N += _L - _F; }
// TEMPLATE CLASS reverse_iterator_ (from <iterator_>)
template<class _RI,
class _Ty,
class _Rt = _Ty&,
class _Pt = _Ty *,
class _D = ptrdiff_t>
class reverse_iterator_ : public _Ranit<_Ty, _D> {
public:
typedef reverse_iterator_<_RI, _Ty, _Rt, _Pt, _D> _Myt;
typedef _RI iter_type;
typedef _Rt reference_type;
typedef _Pt pointer_type;
reverse_iterator_()
{}
explicit reverse_iterator_(_RI _X)
: current(_X) {}
_RI base() const
{return (current); }
_Rt operator*() const
{return (*(current - 1)); }
_Pt operator->() const
{return (&**this); }
_Myt& operator++()
{--current;
return (*this); }
_Myt operator++(int)
{_Myt _Tmp = *this;
--current;
return (_Tmp); }
_Myt& operator--()
{++current;
return (*this); }
_Myt operator--(int)
{_Myt _Tmp = *this;
++current;
return (_Tmp); }
_Myt& operator+=(_D _N)
{current -= _N;
return (*this); }
_Myt operator+(_D _N) const
{return (_Myt(current - _N)); }
_Myt& operator-=(_D _N)
{current += _N;
return (*this); }
_Myt operator-(_D _N) const
{return (_Myt(current + _N)); }
_Rt operator[](_D _N) const
{return (*(*this + _N)); }
protected:
_RI current;
};
template<class _RI, class _Ty, class _Rt, class _Pt,
class _D> inline
bool __cdecl operator==(
const reverse_iterator_<_RI, _Ty, _Rt, _Pt, _D>& _X,
const reverse_iterator_<_RI, _Ty, _Rt, _Pt, _D>& _Y)
{return (_X.base() == _Y.base()); }
template<class _RI, class _Ty, class _Rt, class _Pt,
class _D> inline
bool __cdecl operator!=(
const reverse_iterator_<_RI, _Ty, _Rt, _Pt, _D>& _X,
const reverse_iterator_<_RI, _Ty, _Rt, _Pt, _D>& _Y)
{return (!(_X == _Y)); }
template<class _RI, class _Ty, class _Rt, class _Pt,
class _D> inline
bool __cdecl operator<(
const reverse_iterator_<_RI, _Ty, _Rt, _Pt, _D>& _X,
const reverse_iterator_<_RI, _Ty, _Rt, _Pt, _D>& _Y)
{return (_Y.base() < _X.base()); }
template<class _RI, class _Ty, class _Rt, class _Pt,
class _D> inline
bool __cdecl operator>(
const reverse_iterator_<_RI, _Ty, _Rt, _Pt, _D>& _X,
const reverse_iterator_<_RI, _Ty, _Rt, _Pt, _D>& _Y)
{return (_Y < _X); }
template<class _RI, class _Ty, class _Rt, class _Pt,
class _D> inline
bool __cdecl operator<=(
const reverse_iterator_<_RI, _Ty, _Rt, _Pt, _D>& _X,
const reverse_iterator_<_RI, _Ty, _Rt, _Pt, _D>& _Y)
{return (!(_Y < _X)); }
template<class _RI, class _Ty, class _Rt, class _Pt,
class _D> inline
bool __cdecl operator>=(
const reverse_iterator_<_RI, _Ty, _Rt, _Pt, _D>& _X,
const reverse_iterator_<_RI, _Ty, _Rt, _Pt, _D>& _Y)
{return (!(_X < _Y)); }
template<class _RI, class _Ty, class _Rt, class _Pt,
class _D> inline
_D __cdecl operator-(
const reverse_iterator_<_RI, _Ty, _Rt, _Pt, _D>& _X,
const reverse_iterator_<_RI, _Ty, _Rt, _Pt, _D>& _Y)
{return (_Y.base() - _X.base()); }
template<class _RI, class _Ty, class _Rt, class _Pt,
class _D> inline
reverse_iterator_<_RI, _Ty, _Rt, _Pt, _D> __cdecl operator+(_D _N,
const reverse_iterator_<_RI, _Ty, _Rt, _Pt, _D>& _Y)
{return (reverse_iterator_<_RI, _Ty, _Rt, _Pt, _D>(
_Y.base() - _N)); }
// TEMPLATE CLASS istreambuf_iterator_ (from <iterator_>)
template<class _E, class _Tr>
class istreambuf_iterator_
: public iterator_<input_iterator_tag_, _E, typename _Tr::off_type> {
public:
typedef istreambuf_iterator_<_E, _Tr> _Myt;
typedef _E char_type;
typedef _Tr traits_type;
typedef typename _Tr::int_type int_type;
typedef basic_streambuf<_E, _Tr> streambuf_type;
typedef basic_istream<_E, _Tr> istream_type;
istreambuf_iterator_(streambuf_type *_Sb = 0) _THROW0()
: _Sbuf(_Sb), _Got(_Sb == 0) {}
istreambuf_iterator_(istream_type& _I) _THROW0()
: _Sbuf(_I.rdbuf()), _Got(_I.rdbuf() == 0) {}
const _E& operator*() const
{if (!_Got)
((_Myt *)this)->_Peek();
return (_Val); }
const _E *operator->() const
{return (&**this); }
_Myt& operator++()
{_Inc();
return (*this); }
_Myt operator++(int)
{if (!_Got)
_Peek();
_Myt _Tmp = *this;
_Inc();
return (_Tmp); }
bool equal(const _Myt& _X) const
{if (!_Got)
((_Myt *)this)->_Peek();
if (!_X._Got)
((_Myt *)&_X)->_Peek();
return (_Sbuf == 0 && _X._Sbuf == 0
|| _Sbuf != 0 && _X._Sbuf != 0); }
private:
void _Inc()
{if (_Sbuf == 0
|| _Tr::eq_int_type(_Tr::eof(), _Sbuf->sbumpc()))
_Sbuf = 0, _Got = true;
else
_Got = false; }
_E _Peek()
{int_type _C;
if (_Sbuf == 0
|| _Tr::eq_int_type(_Tr::eof(), _C = _Sbuf->sgetc()))
_Sbuf = 0;
else
_Val = _Tr::to_char_type(_C);
_Got = true;
return (_Val); }
streambuf_type *_Sbuf;
bool _Got;
_E _Val;
};
template<class _E, class _Tr> inline
bool __cdecl operator==(const istreambuf_iterator_<_E, _Tr>& _X,
const istreambuf_iterator_<_E, _Tr>& _Y)
{return (_X.equal(_Y)); }
template<class _E, class _Tr> inline
bool __cdecl operator!=(const istreambuf_iterator_<_E, _Tr>& _X,
const istreambuf_iterator_<_E, _Tr>& _Y)
{return (!(_X == _Y)); }
// TEMPLATE CLASS ostreambuf_iterator_ (from <iterator_>)
template<class _E, class _Tr>
class ostreambuf_iterator_
: public iterator_<output_iterator_tag_, void, void> {
typedef ostreambuf_iterator_<_E, _Tr> _Myt;
public:
typedef _E char_type;
typedef _Tr traits_type;
typedef basic_streambuf<_E, _Tr> streambuf_type;
typedef basic_ostream<_E, _Tr> ostream_type;
ostreambuf_iterator_(streambuf_type *_Sb) _THROW0()
: _Failed(false), _Sbuf(_Sb) {}
ostreambuf_iterator_(ostream_type& _O) _THROW0()
: _Failed(false), _Sbuf(_O.rdbuf()) {}
_Myt& operator=(_E _X)
{if (_Sbuf == 0
|| _Tr::eq_int_type(_Tr::eof(), _Sbuf->sputc(_X)))
_Failed = true;
return (*this); }
_Myt& operator*()
{return (*this); }
_Myt& operator++()
{return (*this); }
_Myt& operator++(int)
{return (*this); }
bool failed() const _THROW0()
{return (_Failed); }
private:
bool _Failed;
streambuf_type *_Sbuf;
};
// TEMPLATE OPERATORS
namespace rel_ops_ {
template<class _Ty> inline
bool __cdecl operator!=(const _Ty& _X, const _Ty& _Y)
{return (!(_X == _Y)); }
template<class _Ty> inline
bool __cdecl operator>(const _Ty& _X, const _Ty& _Y)
{return (_Y < _X); }
template<class _Ty> inline
bool __cdecl operator<=(const _Ty& _X, const _Ty& _Y)
{return (!(_Y < _X)); }
template<class _Ty> inline
bool __cdecl operator>=(const _Ty& _X, const _Ty& _Y)
{return (!(_X < _Y)); }
_STD_END
_STD_END
#ifdef _MSC_VER
#pragma pack(pop)
#endif // _MSC_VER