1ee0f8c40SNikolas Klauser //===----------------------------------------------------------------------===// 2ee0f8c40SNikolas Klauser // 3ee0f8c40SNikolas Klauser // Part of the LLVM Project, under the Apache License v2.0 with LLVM Exceptions. 4ee0f8c40SNikolas Klauser // See https://llvm.org/LICENSE.txt for license information. 5ee0f8c40SNikolas Klauser // SPDX-License-Identifier: Apache-2.0 WITH LLVM-exception 6ee0f8c40SNikolas Klauser // 7ee0f8c40SNikolas Klauser //===----------------------------------------------------------------------===// 8ee0f8c40SNikolas Klauser 9ee0f8c40SNikolas Klauser #ifndef _LIBCPP___ALGORITHM_RANGES_FIND_H 10ee0f8c40SNikolas Klauser #define _LIBCPP___ALGORITHM_RANGES_FIND_H 11ee0f8c40SNikolas Klauser 121fd08eddSNikolas Klauser #include <__algorithm/find.h> 13ee0f8c40SNikolas Klauser #include <__algorithm/ranges_find_if.h> 141fd08eddSNikolas Klauser #include <__algorithm/unwrap_range.h> 15ee0f8c40SNikolas Klauser #include <__config> 16ee0f8c40SNikolas Klauser #include <__functional/identity.h> 17ee0f8c40SNikolas Klauser #include <__functional/invoke.h> 18ee0f8c40SNikolas Klauser #include <__functional/ranges_operations.h> 19ee0f8c40SNikolas Klauser #include <__iterator/concepts.h> 20ee0f8c40SNikolas Klauser #include <__iterator/projected.h> 21ee0f8c40SNikolas Klauser #include <__ranges/access.h> 22ee0f8c40SNikolas Klauser #include <__ranges/concepts.h> 23ee0f8c40SNikolas Klauser #include <__ranges/dangling.h> 24ee0f8c40SNikolas Klauser #include <__utility/forward.h> 25ee0f8c40SNikolas Klauser #include <__utility/move.h> 26ee0f8c40SNikolas Klauser 27ee0f8c40SNikolas Klauser #if !defined(_LIBCPP_HAS_NO_PRAGMA_SYSTEM_HEADER) 28ee0f8c40SNikolas Klauser # pragma GCC system_header 29ee0f8c40SNikolas Klauser #endif 30ee0f8c40SNikolas Klauser 317b462251SLouis Dionne _LIBCPP_PUSH_MACROS 327b462251SLouis Dionne #include <__undef_macros> 337b462251SLouis Dionne 344f15267dSNikolas Klauser #if _LIBCPP_STD_VER >= 20 35ee0f8c40SNikolas Klauser 36ee0f8c40SNikolas Klauser _LIBCPP_BEGIN_NAMESPACE_STD 37ee0f8c40SNikolas Klauser 38ee0f8c40SNikolas Klauser namespace ranges { 39*d10dc5a0SChristopher Di Bella struct __find { 401fd08eddSNikolas Klauser template <class _Iter, class _Sent, class _Tp, class _Proj> 411fd08eddSNikolas Klauser _LIBCPP_HIDE_FROM_ABI static constexpr _Iter 421fd08eddSNikolas Klauser __find_unwrap(_Iter __first, _Sent __last, const _Tp& __value, _Proj& __proj) { 431fd08eddSNikolas Klauser if constexpr (forward_iterator<_Iter>) { 441fd08eddSNikolas Klauser auto [__first_un, __last_un] = std::__unwrap_range(__first, std::move(__last)); 451fd08eddSNikolas Klauser return std::__rewrap_range<_Sent>( 4684003241SNikolas Klauser std::move(__first), std::__find(std::move(__first_un), std::move(__last_un), __value, __proj)); 471fd08eddSNikolas Klauser } else { 4884003241SNikolas Klauser return std::__find(std::move(__first), std::move(__last), __value, __proj); 491fd08eddSNikolas Klauser } 501fd08eddSNikolas Klauser } 511fd08eddSNikolas Klauser 52ee0f8c40SNikolas Klauser template <input_iterator _Ip, sentinel_for<_Ip> _Sp, class _Tp, class _Proj = identity> 53ee0f8c40SNikolas Klauser requires indirect_binary_predicate<ranges::equal_to, projected<_Ip, _Proj>, const _Tp*> 5483bc7b57SNikolas Klauser [[nodiscard]] _LIBCPP_HIDE_FROM_ABI constexpr _Ip 555aa03b64SLouis Dionne operator()(_Ip __first, _Sp __last, const _Tp& __value, _Proj __proj = {}) const { 561fd08eddSNikolas Klauser return __find_unwrap(std::move(__first), std::move(__last), __value, __proj); 57ee0f8c40SNikolas Klauser } 58ee0f8c40SNikolas Klauser 59ee0f8c40SNikolas Klauser template <input_range _Rp, class _Tp, class _Proj = identity> 60ee0f8c40SNikolas Klauser requires indirect_binary_predicate<ranges::equal_to, projected<iterator_t<_Rp>, _Proj>, const _Tp*> 6183bc7b57SNikolas Klauser [[nodiscard]] _LIBCPP_HIDE_FROM_ABI constexpr borrowed_iterator_t<_Rp> 625aa03b64SLouis Dionne operator()(_Rp&& __r, const _Tp& __value, _Proj __proj = {}) const { 631fd08eddSNikolas Klauser return __find_unwrap(ranges::begin(__r), ranges::end(__r), __value, __proj); 64ee0f8c40SNikolas Klauser } 65ee0f8c40SNikolas Klauser }; 66ee0f8c40SNikolas Klauser 67ee0f8c40SNikolas Klauser inline namespace __cpo { 68*d10dc5a0SChristopher Di Bella inline constexpr auto find = __find{}; 69ee0f8c40SNikolas Klauser } // namespace __cpo 70ee0f8c40SNikolas Klauser } // namespace ranges 71ee0f8c40SNikolas Klauser 72ee0f8c40SNikolas Klauser _LIBCPP_END_NAMESPACE_STD 73ee0f8c40SNikolas Klauser 744f15267dSNikolas Klauser #endif // _LIBCPP_STD_VER >= 20 75ee0f8c40SNikolas Klauser 767b462251SLouis Dionne _LIBCPP_POP_MACROS 777b462251SLouis Dionne 78ee0f8c40SNikolas Klauser #endif // _LIBCPP___ALGORITHM_RANGES_FIND_H 79