#ifndef BOOST_MPL_AUX_INSERT_RANGE_IMPL_HPP_INCLUDED #define BOOST_MPL_AUX_INSERT_RANGE_IMPL_HPP_INCLUDED // Copyright Aleksey Gurtovoy 2000-2004 // // 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) // // See http://www.boost.org/libs/mpl for documentation. // $Id$ // $Date$ // $Revision$ #include #include #include #include #include #include #include #include #include #include #include namespace boost { namespace mpl { // default implementation; conrete sequences might override it by // specializing either the 'insert_range_impl' or the primary // 'insert_range' template template< typename Tag > struct insert_range_impl { template< typename Sequence , typename Pos , typename Range > struct apply #if !defined(BOOST_MPL_CFG_NO_NESTED_FORWARDING) : reverse_fold< joint_view< iterator_range::type,Pos> , joint_view< Range , iterator_range::type> > > , typename clear::type , insert<_1, begin<_1>, _2> > { #else { typedef typename reverse_fold< joint_view< iterator_range::type,Pos> , joint_view< Range , iterator_range::type> > > , typename clear::type , insert<_1, begin<_1>, _2> >::type type; #endif }; }; BOOST_MPL_ALGORITM_TRAITS_LAMBDA_SPEC(3,insert_range_impl) }} #endif // BOOST_MPL_AUX_INSERT_RANGE_IMPL_HPP_INCLUDED