/*============================================================================= 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 #include #include #include #include #include #include #include #include #include #include #include #include namespace boost { namespace fusion { namespace result_of { template struct compute_erase_last // put this in detail!!! { typedef typename result_of::end::type seq_last_type; typedef typename convert_iterator::type first_type; typedef typename mpl::if_< result_of::equal_to , first_type , typename result_of::next::type >::type type; BOOST_FUSION_GPU_ENABLED static type call(First const& first, mpl::false_) { return fusion::next(convert_iterator::call(first)); } BOOST_FUSION_GPU_ENABLED static type call(First const& first, mpl::true_) { return convert_iterator::call(first); } BOOST_FUSION_GPU_ENABLED static type call(First const& first) { return call(first, result_of::equal_to()); } }; struct use_default; template struct fusion_default_help : mpl::if_< is_same , Default , T > { }; template < typename Sequence , typename First , typename Last = use_default> struct erase { typedef typename result_of::begin::type seq_first_type; typedef typename result_of::end::type seq_last_type; BOOST_STATIC_ASSERT((!result_of::equal_to::value)); typedef First FirstType; typedef typename fusion_default_help< Last , typename compute_erase_last::type >::type LastType; typedef typename convert_iterator::type first_type; typedef typename convert_iterator::type last_type; typedef iterator_range left_type; typedef iterator_range right_type; typedef joint_view type; }; } template BOOST_FUSION_GPU_ENABLED typename lazy_enable_if< traits::is_sequence , typename result_of::erase >::type erase(Sequence const& seq, First const& first) { typedef result_of::erase 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::call(first)); right_type right( fusion::result_of::compute_erase_last::call(first) , fusion::end(seq)); return result_type(left, right); } template BOOST_FUSION_GPU_ENABLED typename result_of::erase::type erase(Sequence const& seq, First const& first, Last const& last) { typedef result_of::erase 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