#ifndef SPROUT_OPERATION_FIXED_ERASE_N_HPP #define SPROUT_OPERATION_FIXED_ERASE_N_HPP #include #include #include #include #include #include HDR_ITERATOR_SSCRISK_CEL_OR_SPROUT_DETAIL namespace sprout { namespace fixed { namespace result_of { // // erase_n // template struct erase_n { static_assert(sprout::fixed_container_traits::fixed_size >= N, "fixed_size >= N"); public: typedef typename sprout::rebind_fixed_size< typename sprout::fixed_container_traits::fixed_container_type >::template apply< sprout::fixed_container_traits::fixed_size - N >::type type; }; } // namespace result_of namespace detail { template SPROUT_CONSTEXPR inline Result erase_n_impl( Container const& cont, sprout::index_tuple, typename sprout::fixed_container_traits::difference_type pos ) { return Result{ (Indexes < sprout::fixed_container_traits::fixed_size - N ? (Indexes < pos ? *(sprout::fixed_begin(cont) + Indexes) : *(sprout::fixed_begin(cont) + Indexes + N) ) : typename sprout::fixed_container_traits::value_type{} )... }; } } // namespace detail // // erase_n // template SPROUT_CONSTEXPR inline typename sprout::fixed::result_of::erase_n::type erase_n( Container const& cont, typename sprout::fixed_container_traits::const_iterator pos ) { return sprout::fixed::detail::erase_n_impl::type>( cont, typename sprout::index_range<0, sprout::fixed_container_traits::type>::fixed_size>::type(), NS_SSCRISK_CEL_OR_SPROUT_DETAIL::distance(sprout::fixed_begin(cont), pos) ); } // // erase_n // template SPROUT_CONSTEXPR inline typename sprout::fixed::result_of::erase_n::type erase_n( Container const& cont, typename sprout::fixed_container_traits::difference_type pos ) { return sprout::fixed::detail::erase_n_impl::type>( cont, typename sprout::index_range<0, sprout::fixed_container_traits::type>::fixed_size>::type(), NS_SSCRISK_CEL_OR_SPROUT_DETAIL::distance(sprout::fixed_begin(cont), sprout::begin(cont) + pos) ); } } // namespace fixed } // namespace sprout #endif // #ifndef SPROUT_OPERATION_FIXED_ERASE_N_HPP