Header file range/v3/algorithm/merge.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/functional.hpp>

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

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

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

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

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

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

Class ranges::v3::merge_fn

struct merge_fn
{
    template <typename I0, typename S0, typename I1, typename S1, typename O, typename C = ordered_less, typename P0 = ident, typename P1 = ident, int _concept_requires_53 = 42, typename std::enable_if<(_concept_requires_53==43)||(Sentinel<S0, I0>()&&Sentinel<S1, I1>()&&Mergeable<I0, I1, O, C, P0, P1>()), int>::type=0>
    tagged_tuple<tag::in1(I0), tag::in2(I1), tag::out(O)> operator()(I0, I1, O, I0 begin0, S0 end0, I1 begin1, S1 end1, O out, C pred_ = C{}, P0 proj0_ = P0{}, P1 proj1_ = P1{}) const;
    
    template <typename Rng0, typename Rng1, typename O, typename C = ordered_less, typename P0 = ident, typename P1 = ident, typename I0 = range_iterator_t<Rng0>, typename I1 = range_iterator_t<Rng1>, int _concept_requires_87 = 42, typename std::enable_if<(_concept_requires_87==43)||(Range<Rng0>()&&Range<Rng1>()&&Mergeable<I0, I1, O, C, P0, P1>()), int>::type=0>
    tagged_tuple<tag::in1(range_safe_iterator_t<Rng0>), tag::in2(range_safe_iterator_t<Rng1>), tag::out(O)> operator()(range_safe_iterator_t<Rng0>, range_safe_iterator_t<Rng1>, O, Rng0&& rng0, Rng1&& rng1, O out, C pred = C{}, P0 proj0 = P0{}, P1 proj1 = P1{}) const;
};

@{


Variable ranges::v3::merge

constexpr auto& merge = static_const<with_braced_init_args<merge_fn>>::value;

merge_fn