xref: /openbsd-src/gnu/llvm/libcxx/include/__algorithm/equal.h (revision 4bdff4bed0e3d54e55670334c7d0077db4170f86)
176d0caaeSpatrick // -*- C++ -*-
276d0caaeSpatrick //===----------------------------------------------------------------------===//
376d0caaeSpatrick //
476d0caaeSpatrick // Part of the LLVM Project, under the Apache License v2.0 with LLVM Exceptions.
576d0caaeSpatrick // See https://llvm.org/LICENSE.txt for license information.
676d0caaeSpatrick // SPDX-License-Identifier: Apache-2.0 WITH LLVM-exception
776d0caaeSpatrick //
876d0caaeSpatrick //===----------------------------------------------------------------------===//
976d0caaeSpatrick 
1076d0caaeSpatrick #ifndef _LIBCPP___ALGORITHM_EQUAL_H
1176d0caaeSpatrick #define _LIBCPP___ALGORITHM_EQUAL_H
1276d0caaeSpatrick 
1376d0caaeSpatrick #include <__algorithm/comp.h>
14*4bdff4beSrobert #include <__config>
15*4bdff4beSrobert #include <__iterator/distance.h>
1676d0caaeSpatrick #include <__iterator/iterator_traits.h>
1776d0caaeSpatrick 
1876d0caaeSpatrick #if !defined(_LIBCPP_HAS_NO_PRAGMA_SYSTEM_HEADER)
1976d0caaeSpatrick #  pragma GCC system_header
2076d0caaeSpatrick #endif
2176d0caaeSpatrick 
2276d0caaeSpatrick _LIBCPP_BEGIN_NAMESPACE_STD
2376d0caaeSpatrick 
2476d0caaeSpatrick template <class _InputIterator1, class _InputIterator2, class _BinaryPredicate>
25*4bdff4beSrobert _LIBCPP_NODISCARD_EXT inline _LIBCPP_INLINE_VISIBILITY _LIBCPP_CONSTEXPR_SINCE_CXX20 bool
equal(_InputIterator1 __first1,_InputIterator1 __last1,_InputIterator2 __first2,_BinaryPredicate __pred)2676d0caaeSpatrick equal(_InputIterator1 __first1, _InputIterator1 __last1, _InputIterator2 __first2, _BinaryPredicate __pred) {
2776d0caaeSpatrick   for (; __first1 != __last1; ++__first1, (void)++__first2)
2876d0caaeSpatrick     if (!__pred(*__first1, *__first2))
2976d0caaeSpatrick       return false;
3076d0caaeSpatrick   return true;
3176d0caaeSpatrick }
3276d0caaeSpatrick 
3376d0caaeSpatrick template <class _InputIterator1, class _InputIterator2>
34*4bdff4beSrobert _LIBCPP_NODISCARD_EXT inline _LIBCPP_INLINE_VISIBILITY _LIBCPP_CONSTEXPR_SINCE_CXX20 bool
equal(_InputIterator1 __first1,_InputIterator1 __last1,_InputIterator2 __first2)3576d0caaeSpatrick equal(_InputIterator1 __first1, _InputIterator1 __last1, _InputIterator2 __first2) {
36*4bdff4beSrobert   return std::equal(__first1, __last1, __first2, __equal_to());
3776d0caaeSpatrick }
3876d0caaeSpatrick 
3976d0caaeSpatrick #if _LIBCPP_STD_VER > 11
4076d0caaeSpatrick template <class _BinaryPredicate, class _InputIterator1, class _InputIterator2>
41*4bdff4beSrobert inline _LIBCPP_INLINE_VISIBILITY _LIBCPP_CONSTEXPR_SINCE_CXX20 bool
__equal(_InputIterator1 __first1,_InputIterator1 __last1,_InputIterator2 __first2,_InputIterator2 __last2,_BinaryPredicate __pred,input_iterator_tag,input_iterator_tag)4276d0caaeSpatrick __equal(_InputIterator1 __first1, _InputIterator1 __last1, _InputIterator2 __first2, _InputIterator2 __last2,
4376d0caaeSpatrick         _BinaryPredicate __pred, input_iterator_tag, input_iterator_tag) {
4476d0caaeSpatrick   for (; __first1 != __last1 && __first2 != __last2; ++__first1, (void)++__first2)
4576d0caaeSpatrick     if (!__pred(*__first1, *__first2))
4676d0caaeSpatrick       return false;
4776d0caaeSpatrick   return __first1 == __last1 && __first2 == __last2;
4876d0caaeSpatrick }
4976d0caaeSpatrick 
5076d0caaeSpatrick template <class _BinaryPredicate, class _RandomAccessIterator1, class _RandomAccessIterator2>
51*4bdff4beSrobert inline _LIBCPP_INLINE_VISIBILITY _LIBCPP_CONSTEXPR_SINCE_CXX20 bool
__equal(_RandomAccessIterator1 __first1,_RandomAccessIterator1 __last1,_RandomAccessIterator2 __first2,_RandomAccessIterator2 __last2,_BinaryPredicate __pred,random_access_iterator_tag,random_access_iterator_tag)5276d0caaeSpatrick __equal(_RandomAccessIterator1 __first1, _RandomAccessIterator1 __last1, _RandomAccessIterator2 __first2,
5376d0caaeSpatrick         _RandomAccessIterator2 __last2, _BinaryPredicate __pred, random_access_iterator_tag,
5476d0caaeSpatrick         random_access_iterator_tag) {
5576d0caaeSpatrick   if (_VSTD::distance(__first1, __last1) != _VSTD::distance(__first2, __last2))
5676d0caaeSpatrick     return false;
5776d0caaeSpatrick   return _VSTD::equal<_RandomAccessIterator1, _RandomAccessIterator2,
58*4bdff4beSrobert                       _BinaryPredicate&>(__first1, __last1, __first2, __pred);
5976d0caaeSpatrick }
6076d0caaeSpatrick 
6176d0caaeSpatrick template <class _InputIterator1, class _InputIterator2, class _BinaryPredicate>
62*4bdff4beSrobert _LIBCPP_NODISCARD_EXT inline _LIBCPP_INLINE_VISIBILITY _LIBCPP_CONSTEXPR_SINCE_CXX20 bool
equal(_InputIterator1 __first1,_InputIterator1 __last1,_InputIterator2 __first2,_InputIterator2 __last2,_BinaryPredicate __pred)6376d0caaeSpatrick equal(_InputIterator1 __first1, _InputIterator1 __last1, _InputIterator2 __first2, _InputIterator2 __last2,
6476d0caaeSpatrick       _BinaryPredicate __pred) {
65*4bdff4beSrobert   return _VSTD::__equal<_BinaryPredicate&>(
6676d0caaeSpatrick       __first1, __last1, __first2, __last2, __pred, typename iterator_traits<_InputIterator1>::iterator_category(),
6776d0caaeSpatrick       typename iterator_traits<_InputIterator2>::iterator_category());
6876d0caaeSpatrick }
6976d0caaeSpatrick 
7076d0caaeSpatrick template <class _InputIterator1, class _InputIterator2>
71*4bdff4beSrobert _LIBCPP_NODISCARD_EXT inline _LIBCPP_INLINE_VISIBILITY _LIBCPP_CONSTEXPR_SINCE_CXX20 bool
equal(_InputIterator1 __first1,_InputIterator1 __last1,_InputIterator2 __first2,_InputIterator2 __last2)7276d0caaeSpatrick equal(_InputIterator1 __first1, _InputIterator1 __last1, _InputIterator2 __first2, _InputIterator2 __last2) {
73*4bdff4beSrobert   return std::__equal(
74*4bdff4beSrobert       __first1,
75*4bdff4beSrobert       __last1,
76*4bdff4beSrobert       __first2,
77*4bdff4beSrobert       __last2,
78*4bdff4beSrobert       __equal_to(),
7976d0caaeSpatrick       typename iterator_traits<_InputIterator1>::iterator_category(),
8076d0caaeSpatrick       typename iterator_traits<_InputIterator2>::iterator_category());
8176d0caaeSpatrick }
8276d0caaeSpatrick #endif
8376d0caaeSpatrick 
8476d0caaeSpatrick _LIBCPP_END_NAMESPACE_STD
8576d0caaeSpatrick 
8676d0caaeSpatrick #endif // _LIBCPP___ALGORITHM_EQUAL_H
87