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 
21134723edSLouis Dionne _LIBCPP_BEGIN_NAMESPACE_STD
22134723edSLouis Dionne 
23134723edSLouis Dionne template <class _ForwardIterator, class _Tp>
24134723edSLouis Dionne _LIBCPP_NODISCARD_EXT _LIBCPP_CONSTEXPR_AFTER_CXX17 _ForwardIterator
remove(_ForwardIterator __first,_ForwardIterator __last,const _Tp & __value)25*b48c5010SNikolas Klauser remove(_ForwardIterator __first, _ForwardIterator __last, const _Tp& __value)
26134723edSLouis Dionne {
27*b48c5010SNikolas Klauser     __first = _VSTD::find(__first, __last, __value);
28134723edSLouis Dionne     if (__first != __last)
29134723edSLouis Dionne     {
30134723edSLouis Dionne         _ForwardIterator __i = __first;
31134723edSLouis Dionne         while (++__i != __last)
32134723edSLouis Dionne         {
33*b48c5010SNikolas Klauser             if (!(*__i == __value))
34134723edSLouis Dionne             {
35134723edSLouis Dionne                 *__first = _VSTD::move(*__i);
36134723edSLouis Dionne                 ++__first;
37134723edSLouis Dionne             }
38134723edSLouis Dionne         }
39134723edSLouis Dionne     }
40134723edSLouis Dionne     return __first;
41134723edSLouis Dionne }
42134723edSLouis Dionne 
43134723edSLouis Dionne _LIBCPP_END_NAMESPACE_STD
44134723edSLouis Dionne 
45134723edSLouis Dionne #endif // _LIBCPP___ALGORITHM_REMOVE_H
46