Files
boost_range/include/boost/range/sub_range.hpp

183 lines
5.4 KiB
C++
Raw Normal View History

2004-06-29 02:50:07 +00:00
// Boost.Range library
//
// Copyright Neil Groves 2009.
2004-06-29 02:50:07 +00:00
// 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/detail/workaround.hpp>
2008-02-08 15:25:01 +00:00
#if BOOST_WORKAROUND(BOOST_MSVC, BOOST_TESTED_AT(1500))
#pragma warning( push )
#pragma warning( disable : 4996 )
#endif
2004-06-29 02:50:07 +00:00
#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/size_type.hpp>
#include <boost/range/difference_type.hpp>
#include <boost/range/algorithm/equal.hpp>
#include <boost/assert.hpp>
#include <boost/type_traits/is_reference.hpp>
#include <boost/type_traits/remove_reference.hpp>
2004-06-29 02:50:07 +00:00
namespace boost
{
2004-08-10 16:09:30 +00:00
template< class ForwardRange >
2006-05-18 20:52:17 +00:00
class sub_range : public iterator_range< BOOST_DEDUCED_TYPENAME range_iterator<ForwardRange>::type >
2004-06-29 02:50:07 +00:00
{
2006-05-18 20:52:17 +00:00
typedef BOOST_DEDUCED_TYPENAME range_iterator<ForwardRange>::type iterator_t;
2004-06-29 02:50:07 +00:00
typedef iterator_range< iterator_t > base;
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;
2006-05-18 20:52:17 +00:00
typedef BOOST_DEDUCED_TYPENAME range_iterator<ForwardRange>::type iterator;
typedef BOOST_DEDUCED_TYPENAME range_iterator<const ForwardRange>::type const_iterator;
2004-08-16 22:07:07 +00:00
typedef BOOST_DEDUCED_TYPENAME range_difference<ForwardRange>::type difference_type;
typedef BOOST_DEDUCED_TYPENAME range_size<ForwardRange>::type size_type;
typedef BOOST_DEDUCED_TYPENAME base::reference reference;
public: // for return value of front/back
typedef BOOST_DEDUCED_TYPENAME
boost::mpl::if_< boost::is_reference<reference>,
const BOOST_DEDUCED_TYPENAME boost::remove_reference<reference>::type&,
reference >::type const_reference;
2004-06-29 02:50:07 +00:00
public:
2004-08-21 21:18:00 +00:00
sub_range() : base()
{ }
#if BOOST_WORKAROUND(BOOST_MSVC, BOOST_TESTED_AT(1500) )
sub_range( const sub_range& r )
: base( static_cast<const base&>( r ) )
{ }
#endif
2006-02-20 21:15:05 +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 )
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 )
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;
}
sub_range& operator=( const sub_range& r )
2006-02-20 21:15:05 +00:00
{
base::operator=( static_cast<const base&>(r) );
2006-02-20 21:15:05 +00:00
return *this;
}
2004-06-29 02:50:07 +00:00
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(); }
difference_type size() const { return base::size(); }
2004-06-29 02:50:07 +00:00
2005-01-05 18:19:31 +00:00
public: // convenience
reference front()
2005-01-05 18:19:31 +00:00
{
2005-02-05 20:07:02 +00:00
return base::front();
2005-01-05 18:19:31 +00:00
}
const_reference front() const
2005-01-05 18:19:31 +00:00
{
2005-02-05 20:07:02 +00:00
return base::front();
2005-01-05 18:19:31 +00:00
}
reference back()
2005-01-05 18:19:31 +00:00
{
2005-02-05 20:07:02 +00:00
return base::back();
2005-01-05 18:19:31 +00:00
}
const_reference back() const
2005-01-05 18:19:31 +00:00
{
2005-02-05 20:07:02 +00:00
return base::back();
2005-01-05 18:19:31 +00:00
}
reference operator[]( difference_type sz )
2005-01-05 18:19:31 +00:00
{
2005-02-05 20:07:02 +00:00
return base::operator[](sz);
2005-01-05 18:19:31 +00:00
}
const_reference operator[]( difference_type sz ) const
2005-01-05 18:19:31 +00:00
{
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 )
{
return boost::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 )
{
return !boost::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'
2008-02-08 15:25:01 +00:00
#if BOOST_WORKAROUND(BOOST_MSVC, BOOST_TESTED_AT(1500))
#pragma warning( pop )
#endif
2004-06-29 02:50:07 +00:00
#endif
2006-05-18 20:52:17 +00:00