31#define _PTR_TRAITS_H 1
33#if __cplusplus >= 201103L
38#if __cplusplus > 202002L && defined(__cpp_constexpr_dynamic_alloc)
39# define __cpp_lib_constexpr_memory 202202L
40#elif __cplusplus > 201703L
41# define __cpp_lib_constexpr_memory 201811L
44#if __cplusplus > 201703L
46namespace __gnu_debug {
struct _Safe_iterator_base; }
49namespace std _GLIBCXX_VISIBILITY(default)
51_GLIBCXX_BEGIN_NAMESPACE_VERSION
59 template<
typename _Tp>
60 struct __get_first_arg
61 {
using type = __undefined; };
63 template<
template<
typename,
typename...>
class _SomeTemplate,
typename _Tp,
65 struct __get_first_arg<_SomeTemplate<_Tp, _Types...>>
66 {
using type = _Tp; };
70 template<
typename _Tp,
typename _Up>
71 struct __replace_first_arg
74 template<
template<
typename,
typename...>
class _SomeTemplate,
typename _Up,
75 typename _Tp,
typename... _Types>
76 struct __replace_first_arg<_SomeTemplate<_Tp, _Types...>, _Up>
77 {
using type = _SomeTemplate<_Up, _Types...>; };
80 template<
typename _Ptr,
typename =
void>
81 struct __ptr_traits_elem : __get_first_arg<_Ptr>
86 template<
typename _Ptr>
requires requires {
typename _Ptr::element_type; }
87 struct __ptr_traits_elem<_Ptr, void>
88 {
using type =
typename _Ptr::element_type; };
90 template<
typename _Ptr>
91 struct __ptr_traits_elem<_Ptr, __void_t<typename _Ptr::element_type>>
92 {
using type =
typename _Ptr::element_type; };
95 template<
typename _Ptr>
96 using __ptr_traits_elem_t =
typename __ptr_traits_elem<_Ptr>::type;
101 template<typename _Ptr, typename _Elt, bool = is_void<_Elt>::value>
102 struct __ptr_traits_ptr_to
104 using pointer = _Ptr;
105 using element_type = _Elt;
114 pointer_to(element_type& __r)
115#if __cpp_lib_concepts
117 { pointer::pointer_to(__r) } -> convertible_to<pointer>;
120 {
return pointer::pointer_to(__r); }
124 template<
typename _Ptr,
typename _Elt>
125 struct __ptr_traits_ptr_to<_Ptr, _Elt, true>
129 template<
typename _Tp>
130 struct __ptr_traits_ptr_to<_Tp*, _Tp,
false>
132 using pointer = _Tp*;
133 using element_type = _Tp;
140 static _GLIBCXX20_CONSTEXPR pointer
141 pointer_to(element_type& __r)
noexcept
145 template<
typename _Ptr,
typename _Elt>
146 struct __ptr_traits_impl : __ptr_traits_ptr_to<_Ptr, _Elt>
149 template<
typename _Tp>
150 using __diff_t =
typename _Tp::difference_type;
152 template<
typename _Tp,
typename _Up>
153 using __rebind = __type_identity<typename _Tp::template rebind<_Up>>;
157 using pointer = _Ptr;
160 using element_type = _Elt;
163 using difference_type = __detected_or_t<ptrdiff_t, __diff_t, _Ptr>;
166 template<
typename _Up>
167 using rebind =
typename __detected_or_t<__replace_first_arg<_Ptr, _Up>,
168 __rebind, _Ptr, _Up>::type;
173 template<
typename _Ptr>
174 struct __ptr_traits_impl<_Ptr, __undefined>
183 template<
typename _Ptr>
193 template<
typename _Tp>
203 template<
typename _Up>
using rebind = _Up*;
207 template<
typename _Ptr,
typename _Tp>
210 template<
typename _Tp>
212 __to_address(_Tp* __ptr)
noexcept
218#if __cplusplus <= 201703L
219 template<
typename _Ptr>
220 constexpr typename std::pointer_traits<_Ptr>::element_type*
221 __to_address(
const _Ptr& __ptr)
222 {
return std::__to_address(__ptr.operator->()); }
224 template<
typename _Ptr>
226 __to_address(
const _Ptr& __ptr)
noexcept
230 template<
typename _Ptr,
typename... _None>
232 __to_address(
const _Ptr& __ptr, _None...) noexcept
234 if constexpr (is_base_of_v<__gnu_debug::_Safe_iterator_base, _Ptr>)
235 return std::__to_address(__ptr.base().operator->());
237 return std::__to_address(__ptr.operator->());
240#define __cpp_lib_to_address 201711L
248 template<
typename _Tp>
251 {
return std::__to_address(__ptr); }
260 template<
typename _Ptr>
263 {
return std::__to_address(__ptr); }
266_GLIBCXX_END_NAMESPACE_VERSION
constexpr _Tp * to_address(_Tp *__ptr) noexcept
Obtain address referenced by a pointer to an object.
constexpr _Tp * addressof(_Tp &__r) noexcept
Returns the actual address of the object or function referenced by r, even in the presence of an over...
ISO C++ entities toplevel namespace is std.
typename pointer_traits< _Ptr >::template rebind< _Tp > __ptr_rebind
Convenience alias for rebinding pointers.
GNU debug classes for public use.
Uniform interface to all pointer-like types.
_Tp * pointer
The pointer type.
ptrdiff_t difference_type
Type used to represent the difference between two pointers.
_Tp element_type
The type pointed to.
_Up * rebind
A pointer to a different type.