mirror of
https://github.com/llvm-mirror/libcxx.git
synced 2025-10-24 20:29:39 +08:00
Implement P0025R0: 'An algorithm to clamp a value between a pair of boundary values' for C++17
git-svn-id: https://llvm.org/svn/llvm-project/libcxx/trunk@262871 91177308-0d34-0410-b5e6-96231b3b80d8
This commit is contained in:
@@ -543,6 +543,12 @@ template<class T, class Compare>
|
|||||||
T
|
T
|
||||||
min(initializer_list<T> t, Compare comp); // constexpr in C++14
|
min(initializer_list<T> t, Compare comp); // constexpr in C++14
|
||||||
|
|
||||||
|
template<class T>
|
||||||
|
constexpr const T& clamp( const T& v, const T& lo, const T& hi ); // C++17
|
||||||
|
|
||||||
|
template<class T, class Compare>
|
||||||
|
constexpr const T& clamp( const T& v, const T& lo, const T& hi, Compare comp ); // C++17
|
||||||
|
|
||||||
template <class ForwardIterator>
|
template <class ForwardIterator>
|
||||||
ForwardIterator
|
ForwardIterator
|
||||||
max_element(ForwardIterator first, ForwardIterator last); // constexpr in C++14
|
max_element(ForwardIterator first, ForwardIterator last); // constexpr in C++14
|
||||||
@@ -2657,6 +2663,27 @@ max(initializer_list<_Tp> __t)
|
|||||||
|
|
||||||
#endif // _LIBCPP_HAS_NO_GENERALIZED_INITIALIZERS
|
#endif // _LIBCPP_HAS_NO_GENERALIZED_INITIALIZERS
|
||||||
|
|
||||||
|
#if _LIBCPP_STD_VER > 14
|
||||||
|
// clamp
|
||||||
|
template<class _Tp, class _Compare>
|
||||||
|
inline _LIBCPP_INLINE_VISIBILITY _LIBCPP_CONSTEXPR
|
||||||
|
const _Tp&
|
||||||
|
clamp(const _Tp& __v, const _Tp& __lo, const _Tp& __hi, _Compare __comp)
|
||||||
|
{
|
||||||
|
_LIBCPP_ASSERT(!__comp(__hi, __lo), "Bad bounds passed to std::clamp");
|
||||||
|
return __comp(__v, __lo) ? __lo : __comp(__hi, __v) ? __hi : __v;
|
||||||
|
|
||||||
|
}
|
||||||
|
|
||||||
|
template<class _Tp>
|
||||||
|
inline _LIBCPP_INLINE_VISIBILITY _LIBCPP_CONSTEXPR
|
||||||
|
const _Tp&
|
||||||
|
clamp(const _Tp& __v, const _Tp& __lo, const _Tp& __hi)
|
||||||
|
{
|
||||||
|
return _VSTD::clamp(__v, __lo, __hi, __less<_Tp>());
|
||||||
|
}
|
||||||
|
#endif
|
||||||
|
|
||||||
// minmax_element
|
// minmax_element
|
||||||
|
|
||||||
template <class _ForwardIterator, class _Compare>
|
template <class _ForwardIterator, class _Compare>
|
||||||
|
@@ -0,0 +1,61 @@
|
|||||||
|
//===----------------------------------------------------------------------===//
|
||||||
|
//
|
||||||
|
// The LLVM Compiler Infrastructure
|
||||||
|
//
|
||||||
|
// This file is dual licensed under the MIT and the University of Illinois Open
|
||||||
|
// Source Licenses. See LICENSE.TXT for details.
|
||||||
|
//
|
||||||
|
//===----------------------------------------------------------------------===//
|
||||||
|
|
||||||
|
// <algorithm>
|
||||||
|
// XFAIL: c++03, c++11, c++14
|
||||||
|
|
||||||
|
// template<class T, class Compare>
|
||||||
|
// const T&
|
||||||
|
// clamp(const T& v, const T& lo, const T& hi, Compare comp);
|
||||||
|
|
||||||
|
#include <algorithm>
|
||||||
|
#include <functional>
|
||||||
|
#include <cassert>
|
||||||
|
|
||||||
|
template <class T, class C>
|
||||||
|
void
|
||||||
|
test(const T& v, const T& lo, const T& hi, C c, const T& x)
|
||||||
|
{
|
||||||
|
assert(&std::clamp(v, lo, hi, c) == &x);
|
||||||
|
}
|
||||||
|
|
||||||
|
int main()
|
||||||
|
{
|
||||||
|
{
|
||||||
|
int x = 0;
|
||||||
|
int y = 0;
|
||||||
|
int z = 0;
|
||||||
|
test(x, y, z, std::greater<int>(), x);
|
||||||
|
test(y, x, z, std::greater<int>(), y);
|
||||||
|
}
|
||||||
|
{
|
||||||
|
int x = 0;
|
||||||
|
int y = 1;
|
||||||
|
int z = -1;
|
||||||
|
test(x, y, z, std::greater<int>(), x);
|
||||||
|
test(y, x, z, std::greater<int>(), x);
|
||||||
|
}
|
||||||
|
{
|
||||||
|
int x = 1;
|
||||||
|
int y = 0;
|
||||||
|
int z = 0;
|
||||||
|
test(x, y, z, std::greater<int>(), y);
|
||||||
|
test(y, x, z, std::greater<int>(), y);
|
||||||
|
}
|
||||||
|
#if _LIBCPP_STD_VER > 11
|
||||||
|
{
|
||||||
|
typedef int T;
|
||||||
|
constexpr T x = 1;
|
||||||
|
constexpr T y = 0;
|
||||||
|
constexpr T z = 0;
|
||||||
|
static_assert(std::clamp(x, y, z, std::greater<T>()) == y, "" );
|
||||||
|
static_assert(std::clamp(y, x, z, std::greater<T>()) == y, "" );
|
||||||
|
}
|
||||||
|
#endif
|
||||||
|
}
|
60
test/std/algorithms/alg.sorting/alg.clamp/clamp.pass.cpp
Normal file
60
test/std/algorithms/alg.sorting/alg.clamp/clamp.pass.cpp
Normal file
@@ -0,0 +1,60 @@
|
|||||||
|
//===----------------------------------------------------------------------===//
|
||||||
|
//
|
||||||
|
// The LLVM Compiler Infrastructure
|
||||||
|
//
|
||||||
|
// This file is dual licensed under the MIT and the University of Illinois Open
|
||||||
|
// Source Licenses. See LICENSE.TXT for details.
|
||||||
|
//
|
||||||
|
//===----------------------------------------------------------------------===//
|
||||||
|
|
||||||
|
// <algorithm>
|
||||||
|
// XFAIL: c++03, c++11, c++14
|
||||||
|
|
||||||
|
// template<class T>
|
||||||
|
// const T&
|
||||||
|
// clamp(const T& v, const T& lo, const T& hi);
|
||||||
|
|
||||||
|
#include <algorithm>
|
||||||
|
#include <cassert>
|
||||||
|
|
||||||
|
template <class T>
|
||||||
|
void
|
||||||
|
test(const T& a, const T& lo, const T& hi, const T& x)
|
||||||
|
{
|
||||||
|
assert(&std::clamp(a, lo, hi) == &x);
|
||||||
|
}
|
||||||
|
|
||||||
|
int main()
|
||||||
|
{
|
||||||
|
{
|
||||||
|
int x = 0;
|
||||||
|
int y = 0;
|
||||||
|
int z = 0;
|
||||||
|
test(x, y, z, x);
|
||||||
|
test(y, x, z, y);
|
||||||
|
}
|
||||||
|
{
|
||||||
|
int x = 0;
|
||||||
|
int y = 1;
|
||||||
|
int z = 2;
|
||||||
|
test(x, y, z, y);
|
||||||
|
test(y, x, z, y);
|
||||||
|
}
|
||||||
|
{
|
||||||
|
int x = 1;
|
||||||
|
int y = 0;
|
||||||
|
int z = 1;
|
||||||
|
test(x, y, z, x);
|
||||||
|
test(y, x, z, x);
|
||||||
|
}
|
||||||
|
#if _LIBCPP_STD_VER > 11
|
||||||
|
{
|
||||||
|
typedef int T;
|
||||||
|
constexpr T x = 1;
|
||||||
|
constexpr T y = 0;
|
||||||
|
constexpr T z = 1;
|
||||||
|
static_assert(std::clamp(x, y, z) == x, "" );
|
||||||
|
static_assert(std::clamp(y, x, z) == x, "" );
|
||||||
|
}
|
||||||
|
#endif
|
||||||
|
}
|
@@ -87,7 +87,7 @@
|
|||||||
<tr><td><a href="http://wg21.link/P0152R1">P0152R1</a></td><td>LWG</td><td>constexpr atomic::is_always_lock_free</td><td>Jacksonville</td><td></td><td></td></tr>
|
<tr><td><a href="http://wg21.link/P0152R1">P0152R1</a></td><td>LWG</td><td>constexpr atomic::is_always_lock_free</td><td>Jacksonville</td><td></td><td></td></tr>
|
||||||
<tr><td><a href="http://wg21.link/P0185R1">P0185R1</a></td><td>LWG</td><td>Adding [nothrow-]swappable traits</td><td>Jacksonville</td><td></td><td></td></tr>
|
<tr><td><a href="http://wg21.link/P0185R1">P0185R1</a></td><td>LWG</td><td>Adding [nothrow-]swappable traits</td><td>Jacksonville</td><td></td><td></td></tr>
|
||||||
<tr><td><a href="http://wg21.link/P0253R1">P0253R1</a></td><td>LWG</td><td>Fixing a design mistake in the searchers interface</td><td>Jacksonville</td><td></td><td></td></tr>
|
<tr><td><a href="http://wg21.link/P0253R1">P0253R1</a></td><td>LWG</td><td>Fixing a design mistake in the searchers interface</td><td>Jacksonville</td><td></td><td></td></tr>
|
||||||
<tr><td><a href="http://wg21.link/P0025R0">P0025R0</a></td><td>LWG</td><td>An algorithm to "clamp" a value between a pair of boundary values</td><td>Jacksonville</td><td></td><td></td></tr>
|
<tr><td><a href="http://wg21.link/P0025R0">P0025R0</a></td><td>LWG</td><td>An algorithm to "clamp" a value between a pair of boundary values</td><td>Jacksonville</td><td>Complete</td><td>3.9</td></tr>
|
||||||
<tr><td><a href="http://wg21.link/P0154R1">P0154R1</a></td><td>LWG</td><td>constexpr std::hardware_{constructive,destructive}_interference_size</td><td>Jacksonville</td><td></td><td></td></tr>
|
<tr><td><a href="http://wg21.link/P0154R1">P0154R1</a></td><td>LWG</td><td>constexpr std::hardware_{constructive,destructive}_interference_size</td><td>Jacksonville</td><td></td><td></td></tr>
|
||||||
<tr><td><a href="http://wg21.link/P0030R1">P0030R1</a></td><td>LWG</td><td>Proposal to Introduce a 3-Argument Overload to std::hypot</td><td>Jacksonville</td><td></td><td></td></tr>
|
<tr><td><a href="http://wg21.link/P0030R1">P0030R1</a></td><td>LWG</td><td>Proposal to Introduce a 3-Argument Overload to std::hypot</td><td>Jacksonville</td><td></td><td></td></tr>
|
||||||
<tr><td><a href="http://wg21.link/P0031R0">P0031R0</a></td><td>LWG</td><td>A Proposal to Add Constexpr Modifiers to reverse_iterator, move_iterator, array and Range Access</td><td>Jacksonville</td><td></td><td></td></tr>
|
<tr><td><a href="http://wg21.link/P0031R0">P0031R0</a></td><td>LWG</td><td>A Proposal to Add Constexpr Modifiers to reverse_iterator, move_iterator, array and Range Access</td><td>Jacksonville</td><td></td><td></td></tr>
|
||||||
@@ -238,7 +238,7 @@
|
|||||||
<!-- <tr><td></td><td></td><td></td><td></td></tr> -->
|
<!-- <tr><td></td><td></td><td></td><td></td></tr> -->
|
||||||
</table>
|
</table>
|
||||||
|
|
||||||
<p>Last Updated: 6-Mar-2016</p>
|
<p>Last Updated: 7-Mar-2016</p>
|
||||||
</div>
|
</div>
|
||||||
</body>
|
</body>
|
||||||
</html>
|
</html>
|
||||||
|
Reference in New Issue
Block a user