1*134723edSLouis Dionne //===----------------------------------------------------------------------===//
2*134723edSLouis Dionne //
3*134723edSLouis Dionne // Part of the LLVM Project, under the Apache License v2.0 with LLVM Exceptions.
4*134723edSLouis Dionne // See https://llvm.org/LICENSE.txt for license information.
5*134723edSLouis Dionne // SPDX-License-Identifier: Apache-2.0 WITH LLVM-exception
6*134723edSLouis Dionne //
7*134723edSLouis Dionne //===----------------------------------------------------------------------===//
8*134723edSLouis Dionne 
9*134723edSLouis Dionne #ifndef _LIBCPP___ALGORITHM_REPLACE_H
10*134723edSLouis Dionne #define _LIBCPP___ALGORITHM_REPLACE_H
11*134723edSLouis Dionne 
12*134723edSLouis Dionne #include <__config>
13*134723edSLouis Dionne 
14*134723edSLouis Dionne #if !defined(_LIBCPP_HAS_NO_PRAGMA_SYSTEM_HEADER)
15*134723edSLouis Dionne #  pragma GCC system_header
16*134723edSLouis Dionne #endif
17*134723edSLouis Dionne 
18*134723edSLouis Dionne _LIBCPP_BEGIN_NAMESPACE_STD
19*134723edSLouis Dionne 
20*134723edSLouis Dionne template <class _ForwardIterator, class _Tp>
21*134723edSLouis Dionne inline _LIBCPP_INLINE_VISIBILITY _LIBCPP_CONSTEXPR_AFTER_CXX17
22*134723edSLouis Dionne void
replace(_ForwardIterator __first,_ForwardIterator __last,const _Tp & __old_value,const _Tp & __new_value)23*134723edSLouis Dionne replace(_ForwardIterator __first, _ForwardIterator __last, const _Tp& __old_value, const _Tp& __new_value)
24*134723edSLouis Dionne {
25*134723edSLouis Dionne     for (; __first != __last; ++__first)
26*134723edSLouis Dionne         if (*__first == __old_value)
27*134723edSLouis Dionne             *__first = __new_value;
28*134723edSLouis Dionne }
29*134723edSLouis Dionne 
30*134723edSLouis Dionne _LIBCPP_END_NAMESPACE_STD
31*134723edSLouis Dionne 
32*134723edSLouis Dionne #endif // _LIBCPP___ALGORITHM_REPLACE_H
33