181715861SNikolas Klauser //===----------------------------------------------------------------------===// 281715861SNikolas Klauser // 381715861SNikolas Klauser // Part of the LLVM Project, under the Apache License v2.0 with LLVM Exceptions. 481715861SNikolas Klauser // See https://llvm.org/LICENSE.txt for license information. 581715861SNikolas Klauser // SPDX-License-Identifier: Apache-2.0 WITH LLVM-exception 681715861SNikolas Klauser // 781715861SNikolas Klauser //===----------------------------------------------------------------------===// 881715861SNikolas Klauser 981715861SNikolas Klauser #ifndef _LIBCPP___ALGORITHM_RANGES_BINARY_SEARCH_H 1081715861SNikolas Klauser #define _LIBCPP___ALGORITHM_RANGES_BINARY_SEARCH_H 1181715861SNikolas Klauser 12988682a3SNikolas Klauser #include <__algorithm/iterator_operations.h> 1381715861SNikolas Klauser #include <__algorithm/lower_bound.h> 1481715861SNikolas Klauser #include <__config> 1581715861SNikolas Klauser #include <__functional/identity.h> 1681715861SNikolas Klauser #include <__functional/invoke.h> 1781715861SNikolas Klauser #include <__functional/ranges_operations.h> 1881715861SNikolas Klauser #include <__iterator/concepts.h> 1981715861SNikolas Klauser #include <__iterator/projected.h> 2081715861SNikolas Klauser #include <__ranges/access.h> 2181715861SNikolas Klauser #include <__ranges/concepts.h> 2281715861SNikolas Klauser 2381715861SNikolas Klauser #if !defined(_LIBCPP_HAS_NO_PRAGMA_SYSTEM_HEADER) 2481715861SNikolas Klauser # pragma GCC system_header 2581715861SNikolas Klauser #endif 2681715861SNikolas Klauser 2781715861SNikolas Klauser #if _LIBCPP_STD_VER > 17 && !defined(_LIBCPP_HAS_NO_INCOMPLETE_RANGES) 2881715861SNikolas Klauser 2981715861SNikolas Klauser _LIBCPP_BEGIN_NAMESPACE_STD 3081715861SNikolas Klauser 3181715861SNikolas Klauser namespace ranges { 3281715861SNikolas Klauser namespace __binary_search { 3381715861SNikolas Klauser struct __fn { 3481715861SNikolas Klauser template <forward_iterator _Iter, sentinel_for<_Iter> _Sent, class _Type, class _Proj = identity, 3581715861SNikolas Klauser indirect_strict_weak_order<const _Type*, projected<_Iter, _Proj>> _Comp = ranges::less> 3681715861SNikolas Klauser _LIBCPP_HIDE_FROM_ABI constexpr operator__fn3781715861SNikolas Klauser bool operator()(_Iter __first, _Sent __last, const _Type& __value, _Comp __comp = {}, _Proj __proj = {}) const { 38*295b951eSKonstantin Varlamov auto __ret = std::__lower_bound_impl<_RangeAlgPolicy>(__first, __last, __value, __comp, __proj); 3981715861SNikolas Klauser return __ret != __last && !std::invoke(__comp, __value, std::invoke(__proj, *__first)); 4081715861SNikolas Klauser } 4181715861SNikolas Klauser 4281715861SNikolas Klauser template <forward_range _Range, class _Type, class _Proj = identity, 4381715861SNikolas Klauser indirect_strict_weak_order<const _Type*, projected<iterator_t<_Range>, _Proj>> _Comp = ranges::less> 4481715861SNikolas Klauser _LIBCPP_HIDE_FROM_ABI constexpr operator__fn4581715861SNikolas Klauser bool operator()(_Range&& __r, const _Type& __value, _Comp __comp = {}, _Proj __proj = {}) const { 4681715861SNikolas Klauser auto __first = ranges::begin(__r); 4781715861SNikolas Klauser auto __last = ranges::end(__r); 48*295b951eSKonstantin Varlamov auto __ret = std::__lower_bound_impl<_RangeAlgPolicy>(__first, __last, __value, __comp, __proj); 4981715861SNikolas Klauser return __ret != __last && !std::invoke(__comp, __value, std::invoke(__proj, *__first)); 5081715861SNikolas Klauser } 5181715861SNikolas Klauser }; 5281715861SNikolas Klauser } // namespace __binary_search 5381715861SNikolas Klauser 5481715861SNikolas Klauser inline namespace __cpo { 5581715861SNikolas Klauser inline constexpr auto binary_search = __binary_search::__fn{}; 5681715861SNikolas Klauser } // namespace __cpo 5781715861SNikolas Klauser } // namespace ranges 5881715861SNikolas Klauser 5981715861SNikolas Klauser _LIBCPP_END_NAMESPACE_STD 6081715861SNikolas Klauser 6181715861SNikolas Klauser #endif // _LIBCPP_STD_VER > 17 && !defined(_LIBCPP_HAS_NO_INCOMPLETE_RANGES) 6281715861SNikolas Klauser 6381715861SNikolas Klauser #endif // _LIBCPP___ALGORITHM_RANGES_BINARY_SEARCH_H 64