Some checks failed
Docker. / Ubuntu (push) Has been cancelled
User-agent updater. / User-agent (push) Failing after 15s
Lock Threads / lock (push) Failing after 10s
Waiting for answer. / waiting-for-answer (push) Failing after 22s
Needs user action. / needs-user-action (push) Failing after 8s
Can't reproduce. / cant-reproduce (push) Failing after 8s
Close stale issues and PRs / stale (push) Has been cancelled
150 lines
4.7 KiB
C++
150 lines
4.7 KiB
C++
/// \file
|
|
// Range v3 library
|
|
//
|
|
// Copyright Eric Niebler 2013-present
|
|
//
|
|
// Use, modification and distribution is subject to the
|
|
// Boost Software License, Version 1.0. (See accompanying
|
|
// file LICENSE_1_0.txt or copy at
|
|
// http://www.boost.org/LICENSE_1_0.txt)
|
|
//
|
|
// Project home: https://github.com/ericniebler/range-v3
|
|
//
|
|
|
|
#ifndef RANGES_V3_ACTION_PUSH_BACK_HPP
|
|
#define RANGES_V3_ACTION_PUSH_BACK_HPP
|
|
|
|
#include <utility>
|
|
|
|
#include <meta/meta.hpp>
|
|
|
|
#include <range/v3/range_fwd.hpp>
|
|
|
|
#include <range/v3/action/action.hpp>
|
|
#include <range/v3/action/insert.hpp>
|
|
#include <range/v3/detail/with_braced_init_args.hpp>
|
|
#include <range/v3/functional/bind_back.hpp>
|
|
#include <range/v3/utility/static_const.hpp>
|
|
|
|
#include <range/v3/detail/prologue.hpp>
|
|
|
|
namespace ranges
|
|
{
|
|
/// \addtogroup group-actions
|
|
/// @{
|
|
|
|
/// \cond
|
|
namespace adl_push_back_detail
|
|
{
|
|
/// \endcond
|
|
template<typename Cont, typename T>
|
|
using push_back_t = decltype(static_cast<void>(
|
|
unwrap_reference(std::declval<Cont &>()).push_back(std::declval<T>())));
|
|
|
|
template<typename Cont, typename Rng>
|
|
using insert_t = decltype(static_cast<void>(
|
|
ranges::insert(std::declval<Cont &>(), std::declval<sentinel_t<Cont>>(),
|
|
std::declval<Rng>())));
|
|
|
|
template(typename Cont, typename T)(
|
|
requires lvalue_container_like<Cont> AND
|
|
(!range<T>) AND constructible_from<range_value_t<Cont>, T>)
|
|
push_back_t<Cont, T> push_back(Cont && cont, T && t)
|
|
{
|
|
unwrap_reference(cont).push_back(static_cast<T &&>(t));
|
|
}
|
|
|
|
template(typename Cont, typename Rng)(
|
|
requires lvalue_container_like<Cont> AND range<Rng>)
|
|
insert_t<Cont, Rng> push_back(Cont && cont, Rng && rng)
|
|
{
|
|
ranges::insert(cont, end(cont), static_cast<Rng &&>(rng));
|
|
}
|
|
|
|
/// \cond
|
|
// clang-format off
|
|
/// \concept can_push_back_frag_
|
|
/// \brief The \c can_push_back_frag_ concept
|
|
template<typename Rng, typename T>
|
|
CPP_requires(can_push_back_frag_,
|
|
requires(Rng && rng, T && t) //
|
|
(
|
|
push_back(rng, (T &&) t)
|
|
));
|
|
/// \concept can_push_back_
|
|
/// \brief The \c can_push_back_ concept
|
|
template<typename Rng, typename T>
|
|
CPP_concept can_push_back_ =
|
|
CPP_requires_ref(adl_push_back_detail::can_push_back_frag_, Rng, T);
|
|
// clang-format on
|
|
/// \endcond
|
|
|
|
struct push_back_fn
|
|
{
|
|
template<typename T>
|
|
constexpr auto operator()(T && val) const
|
|
{
|
|
return make_action_closure(
|
|
bind_back(push_back_fn{}, static_cast<T &&>(val)));
|
|
}
|
|
|
|
template(typename T)(
|
|
requires range<T &>)
|
|
constexpr auto operator()(T & t) const
|
|
{
|
|
return make_action_closure(
|
|
bind_back(push_back_fn{}, detail::reference_wrapper_<T>(t)));
|
|
}
|
|
|
|
template<typename T>
|
|
constexpr auto operator()(std::initializer_list<T> val) const
|
|
{
|
|
return make_action_closure(bind_back(push_back_fn{}, val));
|
|
}
|
|
|
|
template(typename Rng, typename T)(
|
|
requires input_range<Rng> AND can_push_back_<Rng, T> AND
|
|
(range<T> || constructible_from<range_value_t<Rng>, T>)) //
|
|
Rng operator()(Rng && rng, T && t) const //
|
|
{
|
|
push_back(rng, static_cast<T &&>(t));
|
|
return static_cast<Rng &&>(rng);
|
|
}
|
|
|
|
template(typename Rng, typename T)(
|
|
requires input_range<Rng> AND
|
|
can_push_back_<Rng, std::initializer_list<T>> AND
|
|
constructible_from<range_value_t<Rng>, T const &>)
|
|
Rng operator()(Rng && rng, std::initializer_list<T> t) const //
|
|
{
|
|
push_back(rng, t);
|
|
return static_cast<Rng &&>(rng);
|
|
}
|
|
|
|
/// \cond
|
|
template<typename Rng, typename T>
|
|
invoke_result_t<push_back_fn, Rng, T &> //
|
|
operator()(Rng && rng, detail::reference_wrapper_<T> r) const
|
|
{
|
|
return (*this)(static_cast<Rng &&>(rng), r.get());
|
|
}
|
|
/// \endcond
|
|
};
|
|
/// \cond
|
|
} // namespace adl_push_back_detail
|
|
/// \endcond
|
|
|
|
namespace actions
|
|
{
|
|
RANGES_INLINE_VARIABLE(adl_push_back_detail::push_back_fn, push_back)
|
|
} // namespace actions
|
|
|
|
using actions::push_back;
|
|
|
|
/// @}
|
|
} // namespace ranges
|
|
|
|
#include <range/v3/detail/epilogue.hpp>
|
|
|
|
#endif
|