xref: /llvm-project/libcxx/include/__algorithm/partition_copy.h (revision 9783f28cbb155e4a8d49c12e1c60ce14dcfaf0c7)
1134723edSLouis Dionne //===----------------------------------------------------------------------===//
2134723edSLouis Dionne //
3134723edSLouis Dionne // Part of the LLVM Project, under the Apache License v2.0 with LLVM Exceptions.
4134723edSLouis Dionne // See https://llvm.org/LICENSE.txt for license information.
5134723edSLouis Dionne // SPDX-License-Identifier: Apache-2.0 WITH LLVM-exception
6134723edSLouis Dionne //
7134723edSLouis Dionne //===----------------------------------------------------------------------===//
8134723edSLouis Dionne 
9134723edSLouis Dionne #ifndef _LIBCPP___ALGORITHM_PARTITION_COPY_H
10134723edSLouis Dionne #define _LIBCPP___ALGORITHM_PARTITION_COPY_H
11134723edSLouis Dionne 
12134723edSLouis Dionne #include <__config>
13134723edSLouis Dionne #include <__iterator/iterator_traits.h>
14ea2206d7SArthur O'Dwyer #include <__utility/pair.h>
15134723edSLouis Dionne 
16134723edSLouis Dionne #if !defined(_LIBCPP_HAS_NO_PRAGMA_SYSTEM_HEADER)
17134723edSLouis Dionne #  pragma GCC system_header
18134723edSLouis Dionne #endif
19134723edSLouis Dionne 
20134723edSLouis Dionne _LIBCPP_BEGIN_NAMESPACE_STD
21134723edSLouis Dionne 
22*9783f28cSLouis Dionne template <class _InputIterator, class _OutputIterator1, class _OutputIterator2, class _Predicate>
partition_copy(_InputIterator __first,_InputIterator __last,_OutputIterator1 __out_true,_OutputIterator2 __out_false,_Predicate __pred)23*9783f28cSLouis Dionne _LIBCPP_HIDE_FROM_ABI _LIBCPP_CONSTEXPR_SINCE_CXX20 pair<_OutputIterator1, _OutputIterator2> partition_copy(
24*9783f28cSLouis Dionne     _InputIterator __first,
25*9783f28cSLouis Dionne     _InputIterator __last,
26*9783f28cSLouis Dionne     _OutputIterator1 __out_true,
27*9783f28cSLouis Dionne     _OutputIterator2 __out_false,
28*9783f28cSLouis Dionne     _Predicate __pred) {
29*9783f28cSLouis Dionne   for (; __first != __last; ++__first) {
30*9783f28cSLouis Dionne     if (__pred(*__first)) {
31134723edSLouis Dionne       *__out_true = *__first;
32134723edSLouis Dionne       ++__out_true;
33*9783f28cSLouis Dionne     } else {
34134723edSLouis Dionne       *__out_false = *__first;
35134723edSLouis Dionne       ++__out_false;
36134723edSLouis Dionne     }
37134723edSLouis Dionne   }
38134723edSLouis Dionne   return pair<_OutputIterator1, _OutputIterator2>(__out_true, __out_false);
39134723edSLouis Dionne }
40134723edSLouis Dionne 
41134723edSLouis Dionne _LIBCPP_END_NAMESPACE_STD
42134723edSLouis Dionne 
43134723edSLouis Dionne #endif // _LIBCPP___ALGORITHM_PARTITION_COPY_H
44