/// \file
// Range v3 library
//
// Copyright Eric Niebler 2014-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_ALGORITHM_REMOVE_COPY_HPP
#define RANGES_V3_ALGORITHM_REMOVE_COPY_HPP
#include
#include
#include
#include
#include
#include
#include
#include
#include
#include
#include
#include
namespace ranges
{
/// \addtogroup group-algorithms
/// @{
template
using remove_copy_result = detail::in_out_result;
RANGES_BEGIN_NIEBLOID(remove_copy)
/// \brief function template \c remove_copy
template
auto RANGES_FUN_NIEBLOID(remove_copy)(
I first, S last, O out, T const & val, P proj = P{}) //
->CPP_ret(remove_copy_result)( //
requires input_iterator && sentinel_for &&
weakly_incrementable &&
indirect_relation, T const *> &&
indirectly_copyable)
{
for(; first != last; ++first)
{
auto && x = *first;
if(!(invoke(proj, x) == val))
{
*out = (decltype(x) &&)x;
++out;
}
}
return {first, out};
}
/// \overload
template
auto RANGES_FUN_NIEBLOID(remove_copy)(
Rng && rng, O out, T const & val, P proj = P{}) //
->CPP_ret(remove_copy_result, O>)( //
requires input_range && weakly_incrementable &&
indirect_relation, P>, T const *> &&
indirectly_copyable, O>)
{
return (*this)(begin(rng), end(rng), std::move(out), val, std::move(proj));
}
RANGES_END_NIEBLOID(remove_copy)
namespace cpp20
{
using ranges::remove_copy;
using ranges::remove_copy_result;
} // namespace cpp20
/// @}
} // namespace ranges
#endif // include guard