xref: /llvm-project/libcxx/include/__algorithm/count_if.h (revision eab7be5d42ad30c9992ff72c3be9298702001dc8)
1134723edSLouis Dionne // -*- C++ -*-
2134723edSLouis Dionne //===----------------------------------------------------------------------===//
3134723edSLouis Dionne //
4134723edSLouis Dionne // Part of the LLVM Project, under the Apache License v2.0 with LLVM Exceptions.
5134723edSLouis Dionne // See https://llvm.org/LICENSE.txt for license information.
6134723edSLouis Dionne // SPDX-License-Identifier: Apache-2.0 WITH LLVM-exception
7134723edSLouis Dionne //
8134723edSLouis Dionne //===----------------------------------------------------------------------===//
9134723edSLouis Dionne 
10134723edSLouis Dionne #ifndef _LIBCPP___ALGORITHM_COUNT_IF_H
11134723edSLouis Dionne #define _LIBCPP___ALGORITHM_COUNT_IF_H
12134723edSLouis Dionne 
13*eab7be5dSNikolas Klauser #include <__algorithm/iterator_operations.h>
14134723edSLouis Dionne #include <__config>
15*eab7be5dSNikolas Klauser #include <__functional/identity.h>
16134723edSLouis Dionne #include <__iterator/iterator_traits.h>
17*eab7be5dSNikolas Klauser #include <__type_traits/invoke.h>
18134723edSLouis Dionne 
19134723edSLouis Dionne #if !defined(_LIBCPP_HAS_NO_PRAGMA_SYSTEM_HEADER)
20134723edSLouis Dionne #  pragma GCC system_header
21134723edSLouis Dionne #endif
22134723edSLouis Dionne 
23134723edSLouis Dionne _LIBCPP_BEGIN_NAMESPACE_STD
24134723edSLouis Dionne 
25*eab7be5dSNikolas Klauser template <class _AlgPolicy, class _Iter, class _Sent, class _Proj, class _Pred>
26*eab7be5dSNikolas Klauser _LIBCPP_HIDE_FROM_ABI _LIBCPP_CONSTEXPR_SINCE_CXX14 __policy_iter_diff_t<_AlgPolicy, _Iter>
27*eab7be5dSNikolas Klauser __count_if(_Iter __first, _Sent __last, _Pred& __pred, _Proj& __proj) {
28*eab7be5dSNikolas Klauser   __policy_iter_diff_t<_AlgPolicy, _Iter> __counter(0);
29*eab7be5dSNikolas Klauser   for (; __first != __last; ++__first) {
30*eab7be5dSNikolas Klauser     if (std::__invoke(__pred, std::__invoke(__proj, *__first)))
31*eab7be5dSNikolas Klauser       ++__counter;
32*eab7be5dSNikolas Klauser   }
33*eab7be5dSNikolas Klauser   return __counter;
34*eab7be5dSNikolas Klauser }
35*eab7be5dSNikolas Klauser 
36134723edSLouis Dionne template <class _InputIterator, class _Predicate>
3717e0686aSNikolas Klauser [[__nodiscard__]] inline _LIBCPP_HIDE_FROM_ABI _LIBCPP_CONSTEXPR_SINCE_CXX20
38134723edSLouis Dionne typename iterator_traits<_InputIterator>::difference_type
39134723edSLouis Dionne count_if(_InputIterator __first, _InputIterator __last, _Predicate __pred) {
40*eab7be5dSNikolas Klauser   __identity __proj;
41*eab7be5dSNikolas Klauser   return std::__count_if<_ClassicAlgPolicy>(__first, __last, __pred, __proj);
42134723edSLouis Dionne }
43134723edSLouis Dionne 
44134723edSLouis Dionne _LIBCPP_END_NAMESPACE_STD
45134723edSLouis Dionne 
46134723edSLouis Dionne #endif // _LIBCPP___ALGORITHM_COUNT_IF_H
47