/*============================================================================= Copyright (c) 2003 Joel de Guzman Copyright (c) 2004 Peder Holt 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) ==============================================================================*/ #if !defined(FUSION_ALGORITHM_ERASE_HPP) #define FUSION_ALGORITHM_ERASE_HPP #include #include #include #include #include #include #include namespace boost { namespace fusion { namespace meta { template struct erase { typedef typename meta::begin::type first_type; typedef typename meta::end::type last_type; #if! BOOST_WORKAROUND(BOOST_MSVC,<=1300) BOOST_STATIC_ASSERT((!meta::equal_to::value)); #endif typedef typename meta::next::type next_type; typedef range left_type; typedef range right_type; typedef joint_view type; }; } namespace function { struct erase { template struct apply : meta::erase {}; template typename apply::type operator()(Sequence const& seq, Position const& pos) const { typedef apply meta_type; typedef typename meta_type::left_type left_type; typedef typename meta_type::right_type right_type; typedef typename meta_type::type result_type; left_type left(fusion::begin(seq), pos); right_type right(fusion::next(pos), fusion::end(seq)); return result_type(left, right); } // template // typename apply::type // operator()(Sequence& seq, Position const& pos) const // { // typedef apply meta; // typedef typename meta::left_type left_type; // typedef typename meta::right_type right_type; // typedef typename meta::type result_type; // // left_type left(fusion::begin(seq), pos); // right_type right(fusion::next(pos), fusion::end(seq)); // return result_type(left, right); // } }; } function::erase const erase = function::erase(); }} #endif