#ifndef SPROUT_OPERATION_FIXED_ERASE_N_HPP #define SPROUT_OPERATION_FIXED_ERASE_N_HPP #include #include #include #include #include #include namespace sprout { namespace fixed { namespace result_of { // // erase_n // template struct erase_n { static_assert(sprout::container_traits::static_size >= N, "static_size >= N"); public: typedef typename sprout::container_transform_traits< Container >::template rebind_size< sprout::container_traits::static_size - N >::type type; }; } // namespace result_of namespace detail { template inline SPROUT_CONSTEXPR Result erase_n_impl( Container const& cont, sprout::index_tuple, typename sprout::container_traits::difference_type pos ) { return sprout::remake( cont, sprout::size(cont) - N, (Indexes < sprout::container_traits::static_size - N ? (Indexes < pos ? *sprout::next(sprout::internal_begin(cont), Indexes) : *sprout::next(sprout::internal_begin(cont), Indexes + N) ) : typename sprout::container_traits::value_type() )... ); } } // namespace detail // // erase_n // template inline SPROUT_CONSTEXPR typename sprout::fixed::result_of::erase_n::type erase_n(Container const& cont, typename sprout::container_traits::const_iterator pos) { return sprout::fixed::detail::erase_n_impl::type>( cont, sprout::index_range< 0, sprout::container_traits::type>::static_size >::make(), sprout::distance(sprout::internal_begin(cont), pos) ); } template inline SPROUT_CONSTEXPR typename sprout::fixed::result_of::erase_n::type erase_n(Container const& cont, typename sprout::container_traits::difference_type pos) { return sprout::fixed::detail::erase_n_impl::type>( cont, sprout::index_range< 0, sprout::container_traits::type>::static_size >::make(), sprout::distance(sprout::internal_begin(cont), sprout::next(sprout::begin(cont), pos)) ); } } // namespace fixed namespace result_of { using sprout::fixed::result_of::erase_n; } // namespace result_of using sprout::fixed::erase_n; } // namespace sprout #endif // #ifndef SPROUT_OPERATION_FIXED_ERASE_N_HPP