mirror of
https://github.com/llvm-mirror/libcxx.git
synced 2025-10-24 03:32:35 +08:00
Add additional constraints on midpoint(pointer, pointer). Fixes PR#42037.
git-svn-id: https://llvm.org/svn/llvm-project/libcxx/trunk@361970 91177308-0d34-0410-b5e6-96231b3b80d8
This commit is contained in:
@@ -527,7 +527,7 @@ lcm(_Tp __m, _Up __n)
|
|||||||
#if _LIBCPP_STD_VER > 17
|
#if _LIBCPP_STD_VER > 17
|
||||||
template <class _Tp>
|
template <class _Tp>
|
||||||
_LIBCPP_INLINE_VISIBILITY constexpr
|
_LIBCPP_INLINE_VISIBILITY constexpr
|
||||||
enable_if_t<is_integral_v<_Tp> && !is_same_v<bool, _Tp>, _Tp>
|
enable_if_t<is_integral_v<_Tp> && !is_same_v<bool, _Tp> && !is_null_pointer_v<_Tp>, _Tp>
|
||||||
midpoint(_Tp __a, _Tp __b) noexcept
|
midpoint(_Tp __a, _Tp __b) noexcept
|
||||||
_LIBCPP_DISABLE_UBSAN_UNSIGNED_INTEGER_CHECK
|
_LIBCPP_DISABLE_UBSAN_UNSIGNED_INTEGER_CHECK
|
||||||
{
|
{
|
||||||
@@ -548,7 +548,10 @@ _LIBCPP_DISABLE_UBSAN_UNSIGNED_INTEGER_CHECK
|
|||||||
|
|
||||||
template <class _TPtr>
|
template <class _TPtr>
|
||||||
_LIBCPP_INLINE_VISIBILITY constexpr
|
_LIBCPP_INLINE_VISIBILITY constexpr
|
||||||
enable_if_t<is_pointer_v<_TPtr>, _TPtr>
|
enable_if_t<is_pointer_v<_TPtr>
|
||||||
|
&& is_object_v<remove_pointer_t<_TPtr>>
|
||||||
|
&& ! is_void_v<remove_pointer_t<_TPtr>>
|
||||||
|
&& (sizeof(remove_pointer_t<_TPtr>) > 0), _TPtr>
|
||||||
midpoint(_TPtr __a, _TPtr __b) noexcept
|
midpoint(_TPtr __a, _TPtr __b) noexcept
|
||||||
{
|
{
|
||||||
return __a + _VSTD::midpoint(ptrdiff_t(0), __b - __a);
|
return __a + _VSTD::midpoint(ptrdiff_t(0), __b - __a);
|
||||||
|
@@ -18,13 +18,22 @@
|
|||||||
|
|
||||||
#include "test_macros.h"
|
#include "test_macros.h"
|
||||||
|
|
||||||
|
int func1 () { return 1; }
|
||||||
|
int func2 () { return 2; }
|
||||||
|
|
||||||
|
struct Incomplete;
|
||||||
|
Incomplete *ip = nullptr;
|
||||||
|
void *vp = nullptr;
|
||||||
|
|
||||||
int main(int, char**)
|
int main(int, char**)
|
||||||
{
|
{
|
||||||
(void) std::midpoint(false, true); // expected-error {{no matching function for call to 'midpoint'}}
|
(void) std::midpoint(false, true); // expected-error {{no matching function for call to 'midpoint'}}
|
||||||
|
|
||||||
// A couple of odd pointer types that should fail
|
// A couple of odd pointer types that should fail
|
||||||
(void) std::midpoint(nullptr, nullptr); // expected-error {{no matching function for call to 'midpoint'}}
|
(void) std::midpoint(nullptr, nullptr); // expected-error {{no matching function for call to 'midpoint'}}
|
||||||
(void) std::midpoint((void *)0, (void *)0); // expected-error@numeric:* {{arithmetic on pointers to void}}
|
(void) std::midpoint(func1, func2); // expected-error {{no matching function for call to 'midpoint'}}
|
||||||
|
(void) std::midpoint(ip, ip); // expected-error {{no matching function for call to 'midpoint'}}
|
||||||
|
(void) std::midpoint(vp, vp); // expected-error {{no matching function for call to 'midpoint'}}
|
||||||
|
|
||||||
return 0;
|
return 0;
|
||||||
}
|
}
|
||||||
|
Reference in New Issue
Block a user