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 Dionnereplace(_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