#ifndef SPROUT_ALGORITHM_FIXED_FILL_HPP #define SPROUT_ALGORITHM_FIXED_FILL_HPP #include #include #include #include #include #include #include #include namespace sprout { namespace fixed { namespace detail { template inline SPROUT_CONSTEXPR typename sprout::fixed::result_of::algorithm::type fill_impl( Container const& cont, T const& value, sprout::index_tuple, typename sprout::container_traits::difference_type offset, typename sprout::container_traits::size_type size ) { return sprout::remake( cont, sprout::size(cont), (Indexes >= offset && Indexes < offset + size ? value : *sprout::next(sprout::internal_begin(cont), Indexes) )... ); } template inline SPROUT_CONSTEXPR typename std::enable_if< sprout::is_fixed_container::value, typename sprout::fixed::result_of::algorithm::type >::type fill(Container const& cont, T const& value) { return sprout::fixed::detail::fill_impl( cont, value, sprout::container_indexes::make(), sprout::internal_begin_offset(cont), sprout::size(cont) ); } template inline SPROUT_CONSTEXPR typename std::enable_if< !sprout::is_fixed_container::value, typename sprout::fixed::result_of::algorithm::type >::type fill(Container const& cont, T const& value) { return sprout::remake( cont, sprout::size(cont), sprout::value_iterator(value, sprout::size(cont)), sprout::value_iterator(value, 0) ); } } // namespace detail // // fill // template inline SPROUT_CONSTEXPR typename sprout::fixed::result_of::algorithm::type fill(Container const& cont, T const& value) { return sprout::fixed::detail::fill(cont, value); } template inline SPROUT_CONSTEXPR typename sprout::fixed::result_of::algorithm::type fill(T const& value) { return sprout::fixed::fill(sprout::pit(), value); } } // namespace fixed using sprout::fixed::fill; } // namespace sprout #endif // #ifndef SPROUT_ALGORITHM_FIXED_FILL_HPP