/// \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_VIEW_REPLACE_IF_HPP #define RANGES_V3_VIEW_REPLACE_IF_HPP #include #include #include #include #include #include #include #include #include #include #include #include #include RANGES_DISABLE_WARNINGS namespace ranges { /// \cond namespace detail { template struct replacer_if_fn : compressed_pair, Val> { private: using base_t = compressed_pair, Val>; using base_t::first; using base_t::second; public: replacer_if_fn() = default; constexpr replacer_if_fn(Pred pred, Val new_value) : base_t{std::move(pred), std::move(new_value)} {} template [[noreturn]] common_type_t>, iter_value_t> & operator()(copy_tag, I const &) const { RANGES_EXPECT(false); } template auto operator()(I const & i) -> CPP_ret(common_reference_t, iter_reference_t>)( // requires(!invocable>)) { auto && x = *i; if(invoke(first(), (decltype(x) &&)x)) return unwrap_reference(second()); return (decltype(x) &&)x; } template auto operator()(I const & i) const -> CPP_ret(common_reference_t, iter_reference_t>)( // requires invocable>) { auto && x = *i; if(invoke(first(), (decltype(x) &&)x)) return unwrap_reference(second()); return (decltype(x) &&)x; } template auto operator()(move_tag, I const & i) -> CPP_ret(common_reference_t, iter_rvalue_reference_t>)( // requires(!invocable>)) { auto && x = iter_move(i); if(invoke(first(), (decltype(x) &&)x)) return unwrap_reference(second()); return (decltype(x) &&)x; } template auto operator()(move_tag, I const & i) const -> CPP_ret(common_reference_t, iter_rvalue_reference_t>)( // requires invocable>) { auto && x = iter_move(i); if(invoke(first(), (decltype(x) &&)x)) return unwrap_reference(second()); return (decltype(x) &&)x; } }; } // namespace detail /// \endcond /// \addtogroup group-views /// @{ namespace views { struct replace_if_fn { private: friend view_access; template static constexpr auto bind(replace_if_fn replace_if, Pred pred, Val new_value) { return make_pipeable( bind_back(replace_if, std::move(pred), std::move(new_value))); } public: template constexpr auto operator()(Rng && rng, Pred pred, Val new_value) const -> CPP_ret(replace_if_view, Pred, Val>)( // requires viewable_range && input_range && indirect_unary_predicate> && common_with>, range_value_t> && common_reference_with, range_reference_t> && common_reference_with, range_rvalue_reference_t>) { return {all(static_cast(rng)), {std::move(pred), std::move(new_value)}}; } }; /// \relates replace_if_fn /// \ingroup group-views RANGES_INLINE_VARIABLE(view, replace_if) } // namespace views /// @} } // namespace ranges RANGES_RE_ENABLE_WARNINGS #endif