/*============================================================================= 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_REPLACE_HPP) #define FUSION_ALGORITHM_REPLACE_HPP #include #include #include #include #include #include namespace boost { namespace fusion { namespace meta { template struct replace { typedef typename meta::begin::type first_type; typedef typename meta::end::type last_type; typedef typename meta::next::type next_type; #if! BOOST_WORKAROUND(BOOST_MSVC,<=1300) BOOST_STATIC_ASSERT((!meta::equal_to::value)); #endif typedef single_view insert_type; typedef range left_type; typedef range right_type; typedef joint_view left_replace_type; typedef joint_view type; }; } namespace function { struct replace { template struct apply : meta::replace {}; template typename apply::type operator()(Sequence const& seq, Position const& pos, T const& x) const { typedef apply replacer; typedef typename replacer::left_type left_type; typedef typename replacer::right_type right_type; typedef typename replacer::left_replace_type left_replace_type; typedef typename replacer::insert_type insert_type; typedef typename replacer::type result; left_type left(fusion::begin(seq), pos); right_type right(fusion::next(pos), fusion::end(seq)); insert_type ins(x); left_replace_type left_replace(left, ins); return result(left_replace, right); } template typename apply::type operator()(Sequence& seq, Position const& pos, T const& x) const { typedef apply replacer; typedef typename replacer::left_type left_type; typedef typename replacer::right_type right_type; typedef typename replacer::left_replace_type left_replace_type; typedef typename replacer::insert_type insert_type; typedef typename replacer::type result; left_type left(fusion::begin(seq), pos); right_type right(fusion::next(pos), fusion::end(seq)); insert_type ins(x); left_replace_type left_replace(left, ins); return result(left_replace, right); } }; } function::replace const replace = function::replace(); }} #endif