xref: /llvm-project/libcxx/include/__algorithm/remove.h (revision 17e0686ab1107a1a675d8783383dedf70fa24033)
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_REMOVE_H
10134723edSLouis Dionne #define _LIBCPP___ALGORITHM_REMOVE_H
11134723edSLouis Dionne 
12134723edSLouis Dionne #include <__algorithm/find.h>
136adbc83eSChristopher Di Bella #include <__algorithm/find_if.h>
144d81a46fSArthur O'Dwyer #include <__config>
156adbc83eSChristopher Di Bella #include <__utility/move.h>
16134723edSLouis Dionne 
17134723edSLouis Dionne #if !defined(_LIBCPP_HAS_NO_PRAGMA_SYSTEM_HEADER)
18134723edSLouis Dionne #  pragma GCC system_header
19134723edSLouis Dionne #endif
20134723edSLouis Dionne 
217b462251SLouis Dionne _LIBCPP_PUSH_MACROS
227b462251SLouis Dionne #include <__undef_macros>
237b462251SLouis Dionne 
24134723edSLouis Dionne _LIBCPP_BEGIN_NAMESPACE_STD
25134723edSLouis Dionne 
26134723edSLouis Dionne template <class _ForwardIterator, class _Tp>
27*17e0686aSNikolas Klauser [[__nodiscard__]] _LIBCPP_HIDE_FROM_ABI _LIBCPP_CONSTEXPR_SINCE_CXX20 _ForwardIterator
289783f28cSLouis Dionne remove(_ForwardIterator __first, _ForwardIterator __last, const _Tp& __value) {
2977a00c0dSLouis Dionne   __first = std::find(__first, __last, __value);
309783f28cSLouis Dionne   if (__first != __last) {
31134723edSLouis Dionne     _ForwardIterator __i = __first;
329783f28cSLouis Dionne     while (++__i != __last) {
339783f28cSLouis Dionne       if (!(*__i == __value)) {
3477a00c0dSLouis Dionne         *__first = std::move(*__i);
35134723edSLouis Dionne         ++__first;
36134723edSLouis Dionne       }
37134723edSLouis Dionne     }
38134723edSLouis Dionne   }
39134723edSLouis Dionne   return __first;
40134723edSLouis Dionne }
41134723edSLouis Dionne 
42134723edSLouis Dionne _LIBCPP_END_NAMESPACE_STD
43134723edSLouis Dionne 
447b462251SLouis Dionne _LIBCPP_POP_MACROS
457b462251SLouis Dionne 
46134723edSLouis Dionne #endif // _LIBCPP___ALGORITHM_REMOVE_H
47