#ifndef SPROUT_OPERATION_FIXED_REALIGN_HPP #define SPROUT_OPERATION_FIXED_REALIGN_HPP #include #include #include #include #include namespace sprout { namespace fixed { namespace result_of { // // realign // template struct realign { public: typedef typename sprout::container_construct_traits::copied_type type; }; } // namespace result_of namespace detail { template inline SPROUT_CONSTEXPR Result realign_impl( Container const& cont, sprout::index_tuple, typename sprout::container_traits::difference_type size, T const& v ) { return sprout::make( (Indexes < size ? *sprout::next(sprout::begin(cont), Indexes) : v )... ); } } // namespace detail // // realign // template inline SPROUT_CONSTEXPR typename sprout::fixed::result_of::realign::type realign(Container const& cont, T const& v) { return sprout::fixed::detail::realign_impl::type>( cont, sprout::index_range< 0, sprout::container_traits::type>::static_size >::make(), sprout::size(cont), v ); } namespace detail { template inline SPROUT_CONSTEXPR Result realign_impl( Container const& cont, sprout::index_tuple, typename sprout::container_traits::difference_type size ) { return sprout::make( (Indexes < size ? *sprout::next(sprout::begin(cont), Indexes) : typename sprout::container_traits::value_type() )... ); } } // namespace detail // // realign // template inline SPROUT_CONSTEXPR typename sprout::fixed::result_of::realign::type realign(Container const& cont) { return sprout::fixed::detail::realign_impl::type>( cont, sprout::index_range< 0, sprout::container_traits::type>::static_size >::make(), sprout::size(cont) ); } } // namespace fixed namespace result_of { using sprout::fixed::result_of::realign; } // namespace result_of using sprout::fixed::realign; } // namespace sprout #endif // #ifndef SPROUT_OPERATION_FIXED_REALIGN_HPP