141 lines
		
	
	
		
			5.1 KiB
		
	
	
	
		
			Plaintext
		
	
	
	
	
	
			
		
		
	
	
			141 lines
		
	
	
		
			5.1 KiB
		
	
	
	
		
			Plaintext
		
	
	
	
	
	
/*=============================================================================
 | 
						|
    Copyright (c) 2001-2011 Joel de Guzman
 | 
						|
 | 
						|
    Distributed under 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)
 | 
						|
==============================================================================*/
 | 
						|
#if !defined(FUSION_ERASE_07232005_0534)
 | 
						|
#define FUSION_ERASE_07232005_0534
 | 
						|
 | 
						|
#include <boost/fusion/support/config.hpp>
 | 
						|
#include <boost/fusion/iterator/equal_to.hpp>
 | 
						|
#include <boost/fusion/iterator/mpl/convert_iterator.hpp>
 | 
						|
#include <boost/fusion/view/joint_view/joint_view.hpp>
 | 
						|
#include <boost/fusion/view/iterator_range/iterator_range.hpp>
 | 
						|
#include <boost/fusion/support/detail/as_fusion_element.hpp>
 | 
						|
#include <boost/fusion/sequence/intrinsic/begin.hpp>
 | 
						|
#include <boost/fusion/sequence/intrinsic/end.hpp>
 | 
						|
#include <boost/fusion/adapted/mpl/mpl_iterator.hpp>
 | 
						|
#include <boost/fusion/support/is_sequence.hpp>
 | 
						|
#include <boost/utility/enable_if.hpp>
 | 
						|
#include <boost/mpl/if.hpp>
 | 
						|
 | 
						|
namespace boost { namespace fusion
 | 
						|
{
 | 
						|
    namespace result_of
 | 
						|
    {
 | 
						|
        template <typename Sequence, typename First>
 | 
						|
        struct compute_erase_last // put this in detail!!!
 | 
						|
        {
 | 
						|
            typedef typename result_of::end<Sequence>::type seq_last_type;
 | 
						|
            typedef typename convert_iterator<First>::type first_type;
 | 
						|
            typedef typename
 | 
						|
                mpl::if_<
 | 
						|
                    result_of::equal_to<first_type, seq_last_type>
 | 
						|
                  , first_type
 | 
						|
                  , typename result_of::next<first_type>::type
 | 
						|
                >::type
 | 
						|
            type;
 | 
						|
 | 
						|
            BOOST_CONSTEXPR BOOST_FUSION_GPU_ENABLED
 | 
						|
            static type
 | 
						|
            call(First const& first, mpl::false_)
 | 
						|
            {
 | 
						|
                return fusion::next(convert_iterator<First>::call(first));
 | 
						|
            }
 | 
						|
 | 
						|
            BOOST_CONSTEXPR BOOST_FUSION_GPU_ENABLED
 | 
						|
            static type
 | 
						|
            call(First const& first, mpl::true_)
 | 
						|
            {
 | 
						|
                return convert_iterator<First>::call(first);
 | 
						|
            }
 | 
						|
 | 
						|
            BOOST_CONSTEXPR BOOST_FUSION_GPU_ENABLED
 | 
						|
            static type
 | 
						|
            call(First const& first)
 | 
						|
            {
 | 
						|
                return call(first, result_of::equal_to<first_type, seq_last_type>());
 | 
						|
            }
 | 
						|
        };
 | 
						|
 | 
						|
        struct use_default;
 | 
						|
 | 
						|
        template <class T, class Default>
 | 
						|
        struct fusion_default_help
 | 
						|
          : mpl::if_<
 | 
						|
                is_same<T, use_default>
 | 
						|
              , Default
 | 
						|
              , T
 | 
						|
            >
 | 
						|
        {
 | 
						|
        };
 | 
						|
 | 
						|
        template <
 | 
						|
            typename Sequence
 | 
						|
          , typename First
 | 
						|
          , typename Last = use_default>
 | 
						|
        struct erase
 | 
						|
        {
 | 
						|
            typedef typename result_of::begin<Sequence>::type seq_first_type;
 | 
						|
            typedef typename result_of::end<Sequence>::type seq_last_type;
 | 
						|
            BOOST_STATIC_ASSERT((!result_of::equal_to<seq_first_type, seq_last_type>::value));
 | 
						|
 | 
						|
            typedef First FirstType;
 | 
						|
            typedef typename 
 | 
						|
                fusion_default_help<
 | 
						|
                    Last 
 | 
						|
                  , typename compute_erase_last<Sequence, First>::type
 | 
						|
                >::type
 | 
						|
            LastType;
 | 
						|
 | 
						|
            typedef typename convert_iterator<FirstType>::type first_type;
 | 
						|
            typedef typename convert_iterator<LastType>::type last_type;
 | 
						|
            typedef iterator_range<seq_first_type, first_type> left_type;
 | 
						|
            typedef iterator_range<last_type, seq_last_type> right_type;
 | 
						|
            typedef joint_view<left_type, right_type> type;
 | 
						|
        };
 | 
						|
    }
 | 
						|
 | 
						|
    template <typename Sequence, typename First>
 | 
						|
    BOOST_CXX14_CONSTEXPR BOOST_FUSION_GPU_ENABLED
 | 
						|
    inline typename
 | 
						|
        lazy_enable_if<
 | 
						|
            traits::is_sequence<Sequence>
 | 
						|
          , typename result_of::erase<Sequence const, First> 
 | 
						|
        >::type
 | 
						|
    erase(Sequence const& seq, First const& first)
 | 
						|
    {
 | 
						|
        typedef result_of::erase<Sequence const, First> result_of;
 | 
						|
        typedef typename result_of::left_type left_type;
 | 
						|
        typedef typename result_of::right_type right_type;
 | 
						|
        typedef typename result_of::type result_type;
 | 
						|
 | 
						|
        left_type left(
 | 
						|
            fusion::begin(seq)
 | 
						|
          , convert_iterator<First>::call(first));
 | 
						|
        right_type right(
 | 
						|
            fusion::result_of::compute_erase_last<Sequence const, First>::call(first)
 | 
						|
          , fusion::end(seq));
 | 
						|
        return result_type(left, right);
 | 
						|
    }
 | 
						|
 | 
						|
    template <typename Sequence, typename First, typename Last>
 | 
						|
    BOOST_CXX14_CONSTEXPR BOOST_FUSION_GPU_ENABLED
 | 
						|
    inline typename result_of::erase<Sequence const, First, Last>::type
 | 
						|
    erase(Sequence const& seq, First const& first, Last const& last)
 | 
						|
    {
 | 
						|
        typedef result_of::erase<Sequence const, First, Last> result_of;
 | 
						|
        typedef typename result_of::left_type left_type;
 | 
						|
        typedef typename result_of::right_type right_type;
 | 
						|
        typedef typename result_of::type result_type;
 | 
						|
 | 
						|
        left_type left(fusion::begin(seq), first);
 | 
						|
        right_type right(last, fusion::end(seq));
 | 
						|
        return result_type(left, right);
 | 
						|
    }
 | 
						|
}}
 | 
						|
 | 
						|
#endif
 | 
						|
 |