2004-06-29 02:50:07 +00:00
|
|
|
// Boost.Range library
|
|
|
|
//
|
|
|
|
// Copyright Thorsten Ottosen 2003-2004. Use, modification and
|
|
|
|
// distribution is subject to the Boost Software License, Version
|
|
|
|
// 1.0. (See accompanying file LICENSE_1_0.txt or copy at
|
|
|
|
// http://www.boost.org/LICENSE_1_0.txt)
|
|
|
|
//
|
|
|
|
// For more information, see http://www.boost.org/libs/range/
|
|
|
|
//
|
|
|
|
|
|
|
|
#ifndef BOOST_RANGE_SUB_RANGE_HPP
|
|
|
|
#define BOOST_RANGE_SUB_RANGE_HPP
|
|
|
|
|
|
|
|
#include <boost/range/config.hpp>
|
|
|
|
#include <boost/range/iterator_range.hpp>
|
2004-08-13 07:24:13 +00:00
|
|
|
#include <boost/range/value_type.hpp>
|
2004-06-29 02:50:07 +00:00
|
|
|
#include <boost/range/result_iterator.hpp>
|
|
|
|
#include <boost/range/size_type.hpp>
|
|
|
|
#include <boost/range/difference_type.hpp>
|
2005-02-02 03:42:25 +00:00
|
|
|
#include <boost/assert.hpp>
|
2004-06-29 02:50:07 +00:00
|
|
|
|
|
|
|
namespace boost
|
|
|
|
{
|
|
|
|
|
2004-08-10 16:09:30 +00:00
|
|
|
template< class ForwardRange >
|
2004-08-16 22:07:07 +00:00
|
|
|
class sub_range : public iterator_range< BOOST_DEDUCED_TYPENAME range_result_iterator<ForwardRange>::type >
|
2004-06-29 02:50:07 +00:00
|
|
|
{
|
2004-08-16 22:07:07 +00:00
|
|
|
typedef BOOST_DEDUCED_TYPENAME range_result_iterator<ForwardRange>::type iterator_t;
|
2004-06-29 02:50:07 +00:00
|
|
|
typedef iterator_range< iterator_t > base;
|
2005-02-09 17:41:28 +00:00
|
|
|
|
|
|
|
typedef BOOST_DEDUCED_TYPENAME base::impl impl;
|
2004-06-29 02:50:07 +00:00
|
|
|
public:
|
2004-08-16 22:07:07 +00:00
|
|
|
typedef BOOST_DEDUCED_TYPENAME range_value<ForwardRange>::type value_type;
|
|
|
|
typedef BOOST_DEDUCED_TYPENAME range_result_iterator<ForwardRange>::type iterator;
|
|
|
|
typedef BOOST_DEDUCED_TYPENAME range_const_iterator<ForwardRange>::type const_iterator;
|
|
|
|
typedef BOOST_DEDUCED_TYPENAME range_difference<ForwardRange>::type difference_type;
|
|
|
|
typedef BOOST_DEDUCED_TYPENAME range_size<ForwardRange>::type size_type;
|
2004-06-29 02:50:07 +00:00
|
|
|
|
|
|
|
public:
|
2004-08-21 21:18:00 +00:00
|
|
|
sub_range() : base()
|
|
|
|
{ }
|
|
|
|
|
2004-08-10 16:09:30 +00:00
|
|
|
template< class ForwardRange2 >
|
2004-08-24 12:59:10 +00:00
|
|
|
sub_range( ForwardRange2& r ) :
|
|
|
|
|
|
|
|
#if BOOST_WORKAROUND(BOOST_INTEL_CXX_VERSION, <= 800 )
|
2005-02-09 17:41:28 +00:00
|
|
|
base( impl::adl_begin( r ), impl::adl_end( r ) )
|
2004-08-24 12:59:10 +00:00
|
|
|
#else
|
|
|
|
base( r )
|
|
|
|
#endif
|
2004-06-29 02:50:07 +00:00
|
|
|
{ }
|
|
|
|
|
2004-08-10 16:09:30 +00:00
|
|
|
template< class ForwardRange2 >
|
2004-08-24 12:59:10 +00:00
|
|
|
sub_range( const ForwardRange2& r ) :
|
|
|
|
|
|
|
|
#if BOOST_WORKAROUND(BOOST_INTEL_CXX_VERSION, <= 800 )
|
2005-02-09 17:41:28 +00:00
|
|
|
base( impl::adl_begin( r ), impl::adl_end( r ) )
|
2004-08-24 12:59:10 +00:00
|
|
|
#else
|
|
|
|
base( r )
|
|
|
|
#endif
|
2004-06-29 02:50:07 +00:00
|
|
|
{ }
|
|
|
|
|
|
|
|
template< class Iter >
|
|
|
|
sub_range( Iter first, Iter last ) :
|
|
|
|
base( first, last )
|
|
|
|
{ }
|
|
|
|
|
2004-08-10 16:09:30 +00:00
|
|
|
template< class ForwardRange2 >
|
|
|
|
sub_range& operator=( ForwardRange2& r )
|
2004-06-29 02:50:07 +00:00
|
|
|
{
|
|
|
|
base::operator=( r );
|
|
|
|
return *this;
|
|
|
|
}
|
|
|
|
|
2004-08-10 16:09:30 +00:00
|
|
|
template< class ForwardRange2 >
|
|
|
|
sub_range& operator=( const ForwardRange2& r )
|
2004-06-29 02:50:07 +00:00
|
|
|
{
|
|
|
|
base::operator=( r );
|
|
|
|
return *this;
|
|
|
|
}
|
|
|
|
|
2004-08-12 10:58:13 +00:00
|
|
|
public:
|
|
|
|
|
|
|
|
iterator begin() { return base::begin(); }
|
|
|
|
const_iterator begin() const { return base::begin(); }
|
|
|
|
iterator end() { return base::end(); }
|
|
|
|
const_iterator end() const { return base::end(); }
|
2004-08-21 21:18:00 +00:00
|
|
|
size_type size() const { return base::size(); }
|
2004-06-29 02:50:07 +00:00
|
|
|
|
2005-01-05 18:19:31 +00:00
|
|
|
|
|
|
|
public: // convenience
|
|
|
|
value_type& front()
|
|
|
|
{
|
2005-02-05 20:07:02 +00:00
|
|
|
return base::front();
|
2005-01-05 18:19:31 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
const value_type& front() const
|
|
|
|
{
|
2005-02-05 20:07:02 +00:00
|
|
|
return base::front();
|
2005-01-05 18:19:31 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
value_type& back()
|
|
|
|
{
|
2005-02-05 20:07:02 +00:00
|
|
|
return base::back();
|
2005-01-05 18:19:31 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
const value_type& back() const
|
|
|
|
{
|
2005-02-05 20:07:02 +00:00
|
|
|
return base::back();
|
2005-01-05 18:19:31 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
value_type& operator[]( size_type sz )
|
|
|
|
{
|
2005-02-05 20:07:02 +00:00
|
|
|
return base::operator[](sz);
|
2005-01-05 18:19:31 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
const value_type& operator[]( size_type sz ) const
|
|
|
|
{
|
2005-02-05 20:07:02 +00:00
|
|
|
return base::operator[](sz);
|
2005-01-05 18:19:31 +00:00
|
|
|
}
|
|
|
|
|
2004-06-29 02:50:07 +00:00
|
|
|
};
|
2004-09-10 11:48:58 +00:00
|
|
|
|
|
|
|
template< class ForwardRange, class ForwardRange2 >
|
|
|
|
inline bool operator==( const sub_range<ForwardRange>& l,
|
|
|
|
const sub_range<ForwardRange2>& r )
|
|
|
|
{
|
2005-02-05 20:07:02 +00:00
|
|
|
return iterator_range_detail::equal( l, r );
|
2004-09-10 11:48:58 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
template< class ForwardRange, class ForwardRange2 >
|
|
|
|
inline bool operator!=( const sub_range<ForwardRange>& l,
|
|
|
|
const sub_range<ForwardRange2>& r )
|
|
|
|
{
|
2005-02-05 20:07:02 +00:00
|
|
|
return !iterator_range_detail::equal( l, r );
|
2004-09-10 11:48:58 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
template< class ForwardRange, class ForwardRange2 >
|
|
|
|
inline bool operator<( const sub_range<ForwardRange>& l,
|
|
|
|
const sub_range<ForwardRange2>& r )
|
|
|
|
{
|
2005-02-05 20:07:02 +00:00
|
|
|
return iterator_range_detail::less_than( l, r );
|
2004-09-10 11:48:58 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
|
2004-06-29 02:50:07 +00:00
|
|
|
} // namespace 'boost'
|
|
|
|
|
|
|
|
#endif
|