39 #pragma GCC system_header 49 #if __cplusplus >= 201103L 53 #if __cplusplus > 201703L 57 namespace __gnu_cxx _GLIBCXX_VISIBILITY(default)
59 _GLIBCXX_BEGIN_NAMESPACE_VERSION
72 template<
typename _Tp>
77 typedef _Tp element_type;
86 set(element_type* __arg)
92 {
return (_M_value < __rarg._M_value); }
96 {
return (_M_value == __rarg._M_value); }
99 element_type* _M_value;
115 template<
typename _Tp>
119 typedef _Tp element_type;
127 return reinterpret_cast<_Tp*
>(
reinterpret_cast<uintptr_t
>(
this)
137 _M_diff =
reinterpret_cast<uintptr_t
>(__arg)
138 - reinterpret_cast<uintptr_t>(
this);
144 {
return (reinterpret_cast<uintptr_t>(this->
get())
145 < reinterpret_cast<uintptr_t>(__rarg.get())); }
149 {
return (reinterpret_cast<uintptr_t>(this->
get())
150 == reinterpret_cast<uintptr_t>(__rarg.get())); }
153 typedef __UINTPTR_TYPE__ uintptr_t;
161 template<
typename _Tp>
165 typedef const _Tp element_type;
173 return reinterpret_cast<const _Tp*
> 174 (
reinterpret_cast<uintptr_t
>(
this) + _M_diff);
178 set(
const _Tp* __arg)
183 _M_diff =
reinterpret_cast<uintptr_t
>(__arg)
184 - reinterpret_cast<uintptr_t>(
this);
190 {
return (reinterpret_cast<uintptr_t>(this->
get())
191 < reinterpret_cast<uintptr_t>(__rarg.get())); }
195 {
return (reinterpret_cast<uintptr_t>(this->
get())
196 == reinterpret_cast<uintptr_t>(__rarg.get())); }
199 typedef __UINTPTR_TYPE__ uintptr_t;
210 template<
typename _Tp>
211 struct _Reference_type
212 {
typedef _Tp& reference; };
215 struct _Reference_type<void>
219 struct _Reference_type<const void>
223 struct _Reference_type<volatile void>
227 struct _Reference_type<volatile const void>
235 template<
typename _Tp>
237 {
typedef _Tp type; };
239 template<
typename _Tp>
241 {
typedef _Tp type; };
275 template<
typename _Storage_policy>
279 typedef typename _Storage_policy::element_type element_type;
283 typedef typename _Unqualified_type<element_type>::type value_type;
284 typedef std::ptrdiff_t difference_type;
286 typedef typename _Reference_type<element_type>::reference reference;
294 { _Storage_policy::set(__arg); }
298 { _Storage_policy::set(__arg.get()); }
301 template<
typename _Up>
303 { _Storage_policy::set(__arg); }
307 template<
typename _Up>
309 { _Storage_policy::set(__arg.get()); }
318 _Storage_policy::set(__arg.get());
322 template<
typename _Up>
326 _Storage_policy::set(__arg.get());
330 template<
typename _Up>
332 operator=(_Up* __arg)
334 _Storage_policy::set(__arg);
341 {
return *(_Storage_policy::get()); }
346 {
return _Storage_policy::get(); }
350 operator[](std::ptrdiff_t __index)
const 351 {
return _Storage_policy::get()[__index]; }
354 #if __cplusplus >= 201103L 355 explicit operator bool()
const {
return _Storage_policy::get() != 0; }
361 operator __unspecified_bool_type()
const 363 return _Storage_policy::get() == 0 ? 0 :
364 &_Pointer_adapter::operator->;
370 {
return (_Storage_policy::get() == 0); }
374 inline friend std::ptrdiff_t
376 {
return (__lhs.get() - __rhs); }
378 inline friend std::ptrdiff_t
380 {
return (__lhs - __rhs.get()); }
382 template<
typename _Up>
383 inline friend std::ptrdiff_t
385 {
return (__lhs.get() - __rhs); }
387 template<
typename _Up>
388 inline friend std::ptrdiff_t
390 {
return (__lhs - __rhs.get()); }
392 template<
typename _Up>
393 inline std::ptrdiff_t
395 {
return (_Storage_policy::get() - __rhs.get()); }
404 #define _CXX_POINTER_ARITH_OPERATOR_SET(INT_TYPE) \ 405 inline friend _Pointer_adapter \ 406 operator+(const _Pointer_adapter& __lhs, INT_TYPE __offset) \ 407 { return _Pointer_adapter(__lhs.get() + __offset); } \ 409 inline friend _Pointer_adapter \ 410 operator+(INT_TYPE __offset, const _Pointer_adapter& __rhs) \ 411 { return _Pointer_adapter(__rhs.get() + __offset); } \ 413 inline friend _Pointer_adapter \ 414 operator-(const _Pointer_adapter& __lhs, INT_TYPE __offset) \ 415 { return _Pointer_adapter(__lhs.get() - __offset); } \ 417 inline _Pointer_adapter& \ 418 operator+=(INT_TYPE __offset) \ 420 _Storage_policy::set(_Storage_policy::get() + __offset); \ 424 inline _Pointer_adapter& \ 425 operator-=(INT_TYPE __offset) \ 427 _Storage_policy::set(_Storage_policy::get() - __offset); \ 430 // END of _CXX_POINTER_ARITH_OPERATOR_SET macro 433 _CXX_POINTER_ARITH_OPERATOR_SET(
short);
434 _CXX_POINTER_ARITH_OPERATOR_SET(
unsigned short);
435 _CXX_POINTER_ARITH_OPERATOR_SET(
int);
436 _CXX_POINTER_ARITH_OPERATOR_SET(
unsigned int);
437 _CXX_POINTER_ARITH_OPERATOR_SET(
long);
438 _CXX_POINTER_ARITH_OPERATOR_SET(
unsigned long);
439 #ifdef _GLIBCXX_USE_LONG_LONG 440 #pragma GCC diagnostic push 441 #pragma GCC diagnostic ignored "-Wlong-long" 442 _CXX_POINTER_ARITH_OPERATOR_SET(
long long);
443 _CXX_POINTER_ARITH_OPERATOR_SET(
unsigned long long);
444 #pragma GCC diagnostic pop 451 _Storage_policy::set(_Storage_policy::get() + 1);
459 _Storage_policy::set(_Storage_policy::get() + 1);
466 _Storage_policy::set(_Storage_policy::get() - 1);
474 _Storage_policy::set(_Storage_policy::get() - 1);
478 #if __cpp_lib_three_way_comparison 479 friend std::strong_ordering
482 {
return __lhs.get() <=> __rhs.get(); }
487 #define _GCC_CXX_POINTER_COMPARISON_OPERATION_SET(OPERATOR) \ 488 template<typename _Tp1, typename _Tp2> \ 490 operator OPERATOR(const _Pointer_adapter<_Tp1>& __lhs, _Tp2 __rhs) \ 491 { return __lhs.get() OPERATOR __rhs; } \ 493 template<typename _Tp1, typename _Tp2> \ 495 operator OPERATOR(_Tp1 __lhs, const _Pointer_adapter<_Tp2>& __rhs) \ 496 { return __lhs OPERATOR __rhs.get(); } \ 498 template<typename _Tp1, typename _Tp2> \ 500 operator OPERATOR(const _Pointer_adapter<_Tp1>& __lhs, \ 501 const _Pointer_adapter<_Tp2>& __rhs) \ 502 { return __lhs.get() OPERATOR __rhs.get(); } \ 504 // End GCC_CXX_POINTER_COMPARISON_OPERATION_SET Macro 507 _GCC_CXX_POINTER_COMPARISON_OPERATION_SET(==)
508 _GCC_CXX_POINTER_COMPARISON_OPERATION_SET(!=)
509 _GCC_CXX_POINTER_COMPARISON_OPERATION_SET(<)
510 _GCC_CXX_POINTER_COMPARISON_OPERATION_SET(<=)
511 _GCC_CXX_POINTER_COMPARISON_OPERATION_SET(>)
512 _GCC_CXX_POINTER_COMPARISON_OPERATION_SET(>=)
515 template<
typename _Tp>
518 {
return __lhs.get() ==
reinterpret_cast<void*
>(__rhs); }
520 template<
typename _Tp>
523 {
return __rhs.get() ==
reinterpret_cast<void*
>(__lhs); }
525 template<
typename _Tp>
528 {
return __lhs.get() !=
reinterpret_cast<void*
>(__rhs); }
530 template<
typename _Tp>
533 {
return __rhs.get() !=
reinterpret_cast<void*
>(__lhs); }
539 template<
typename _Tp>
543 {
return __lhs._Tp::operator==(__rhs); }
545 template<
typename _Tp>
547 operator<=(const _Pointer_adapter<_Tp>& __lhs,
549 {
return __lhs._Tp::operator<(__rhs) || __lhs._Tp::operator==(__rhs); }
551 template<
typename _Tp>
555 {
return !(__lhs._Tp::operator==(__rhs)); }
557 template<
typename _Tp>
561 {
return !(__lhs._Tp::operator<(__rhs) || __lhs._Tp::operator==(__rhs)); }
563 template<
typename _Tp>
567 {
return !(__lhs._Tp::operator<(__rhs)); }
570 template<
typename _CharT,
typename _Traits,
typename _StoreT>
572 operator<<(std::basic_ostream<_CharT, _Traits>& __os,
574 {
return (__os << __p.get()); }
577 _GLIBCXX_END_NAMESPACE_VERSION
580 #if __cplusplus >= 201103L 581 namespace std _GLIBCXX_VISIBILITY(default)
583 _GLIBCXX_BEGIN_NAMESPACE_VERSION
585 template<
typename _Storage_policy>
591 typedef typename pointer::element_type element_type;
593 typedef typename pointer::difference_type difference_type;
595 template<
typename _Up>
597 typename pointer_traits<_Storage_policy>::template rebind<_Up>>;
599 static pointer pointer_to(
typename pointer::reference __r) noexcept
603 #if __cpp_lib_concepts 604 template<
typename _Policy>
608 =
typename __gnu_cxx::_Pointer_adapter<_Policy>::value_type;
611 _GLIBCXX_END_NAMESPACE_VERSION
A storage policy for use with _Pointer_adapter<> which stores the pointer's address as an offset valu...
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.
Template class basic_ostream.
Random-access iterators support a superset of bidirectional iterator operations.
A storage policy for use with _Pointer_adapter<> which yields a standard pointer. ...
GNU extensions for public use.