#ifndef SPROUT_OPERATION_FIXED_RESIZE_HPP #define SPROUT_OPERATION_FIXED_RESIZE_HPP #include #include #include #include #include namespace sprout { namespace fixed { namespace result_of { // // resize // template struct resize { public: typedef typename sprout::rebind_fixed_size< Container >::template apply< N >::type type; }; } // namespace result_of namespace detail { template SPROUT_CONSTEXPR inline Result resize_impl( Container const& cont, sprout::index_tuple, typename sprout::fixed_container_traits::difference_type size, T const& v ) { return sprout::make_clone( (Indexes < size ? *(sprout::begin(cont) + Indexes) : v )... ); } } // namespace detail // // resize // template SPROUT_CONSTEXPR inline typename sprout::fixed::result_of::resize::type resize( Container const& cont, T const& v ) { return sprout::fixed::detail::resize_impl::type>( cont, typename sprout::index_range<0, sprout::fixed_container_traits::type>::fixed_size>::type(), sprout::size(cont), v ); } namespace detail { template SPROUT_CONSTEXPR inline Result resize_impl( Container const& cont, sprout::index_tuple, typename sprout::fixed_container_traits::difference_type size ) { return sprout::make_clone( (Indexes < size ? *(sprout::begin(cont) + Indexes) : typename sprout::fixed_container_traits::value_type() )... ); } } // namespace detail // // resize // template SPROUT_CONSTEXPR inline typename sprout::fixed::result_of::resize::type resize( Container const& cont ) { return sprout::fixed::detail::resize_impl::type>( cont, typename sprout::index_range<0, sprout::fixed_container_traits::type>::fixed_size>::type(), sprout::size(cont) ); } } // namespace fixed namespace result_of { using sprout::fixed::result_of::resize; } // namespace result_of using sprout::fixed::resize; } // namespace sprout #endif // #ifndef SPROUT_OPERATION_FIXED_RESIZE_HPP