Header file range/v3/algorithm/move_backward.hpp

#include <range/v3/range_fwd.hpp>

#include <range/v3/begin_end.hpp>

#include <range/v3/range_concepts.hpp>

#include <range/v3/range_traits.hpp>

#include <range/v3/utility/iterator.hpp>

#include <range/v3/utility/iterator_concepts.hpp>

#include <range/v3/utility/iterator_traits.hpp>

#include <range/v3/utility/functional.hpp>

#include <range/v3/utility/static_const.hpp>

#include <range/v3/utility/tagged_pair.hpp>

#include <range/v3/algorithm/tagspec.hpp>

namespace ranges
{
    inline namespace v3
    {
        struct move_backward_fn;
        
        inline namespace 
        {
            constexpr auto& move_backward = static_const<with_braced_init_args<move_backward_fn>>::value;
        }
    }
}

Class ranges::v3::move_backward_fn

struct move_backward_fn
{
    template <typename I, typename S, typename O, int _concept_requires_38 = 42, typename std::enable_if<(_concept_requires_38==43)||(BidirectionalIterator<I>()&&Sentinel<S, I>()&&BidirectionalIterator<O>()&&IndirectlyMovable<I, O>()), int>::type=0>
    tagged_pair<tag::in(I), tag::out(O)> operator()(I, O, I begin, S end_, O out) const;
    
    template <typename Rng, typename O, typename I = range_iterator_t<Rng>, int _concept_requires_50 = 42, typename std::enable_if<(_concept_requires_50==43)||(BidirectionalRange<Rng>()&&BidirectionalIterator<O>()&&IndirectlyMovable<I, O>()), int>::type=0>
    tagged_pair<tag::in(range_safe_iterator_t<Rng>), tag::out(O)> operator()(range_safe_iterator_t<Rng>, O, Rng&& rng, O out) const;
};

@{


Variable ranges::v3::move_backward

constexpr auto& move_backward = static_const<with_braced_init_args<move_backward_fn>>::value;

move_backward_fn