39 #ifdef _GLIBCXX_SYSHDR 40 #pragma GCC system_header 52 #if __cplusplus >= 201103L 56 #if __cplusplus > 201703L 60 namespace __gnu_cxx _GLIBCXX_VISIBILITY(default)
62 _GLIBCXX_BEGIN_NAMESPACE_VERSION
75 template<
typename _Tp>
80 typedef _Tp element_type;
89 set(element_type* __arg)
95 {
return (_M_value < __rarg._M_value); }
99 {
return (_M_value == __rarg._M_value); }
102 element_type* _M_value;
118 template<
typename _Tp>
122 typedef _Tp element_type;
130 return reinterpret_cast<_Tp*
>(
reinterpret_cast<uintptr_t
>(
this)
140 _M_diff =
reinterpret_cast<uintptr_t
>(__arg)
141 - reinterpret_cast<uintptr_t>(
this);
147 {
return (reinterpret_cast<uintptr_t>(this->
get())
148 < reinterpret_cast<uintptr_t>(__rarg.get())); }
152 {
return (reinterpret_cast<uintptr_t>(this->
get())
153 == reinterpret_cast<uintptr_t>(__rarg.get())); }
156 typedef __UINTPTR_TYPE__ uintptr_t;
164 template<
typename _Tp>
168 typedef const _Tp element_type;
176 return reinterpret_cast<const _Tp*
> 177 (
reinterpret_cast<uintptr_t
>(
this) + _M_diff);
181 set(
const _Tp* __arg)
186 _M_diff =
reinterpret_cast<uintptr_t
>(__arg)
187 - reinterpret_cast<uintptr_t>(
this);
193 {
return (reinterpret_cast<uintptr_t>(this->
get())
194 < reinterpret_cast<uintptr_t>(__rarg.get())); }
198 {
return (reinterpret_cast<uintptr_t>(this->
get())
199 == reinterpret_cast<uintptr_t>(__rarg.get())); }
202 typedef __UINTPTR_TYPE__ uintptr_t;
213 template<
typename _Tp>
214 struct _Reference_type
215 {
typedef _Tp& reference; };
218 struct _Reference_type<void>
222 struct _Reference_type<const void>
226 struct _Reference_type<volatile void>
230 struct _Reference_type<volatile const void>
238 template<
typename _Tp>
240 {
typedef _Tp type; };
242 template<
typename _Tp>
244 {
typedef _Tp type; };
278 template<
typename _Storage_policy>
282 typedef typename _Storage_policy::element_type element_type;
286 typedef typename _Unqualified_type<element_type>::type value_type;
287 typedef std::ptrdiff_t difference_type;
289 typedef typename _Reference_type<element_type>::reference reference;
297 { _Storage_policy::set(__arg); }
301 { _Storage_policy::set(__arg.get()); }
304 template<
typename _Up>
306 { _Storage_policy::set(__arg); }
310 template<
typename _Up>
312 { _Storage_policy::set(__arg.get()); }
321 _Storage_policy::set(__arg.get());
325 template<
typename _Up>
329 _Storage_policy::set(__arg.get());
333 template<
typename _Up>
335 operator=(_Up* __arg)
337 _Storage_policy::set(__arg);
344 {
return *(_Storage_policy::get()); }
349 {
return _Storage_policy::get(); }
353 operator[](std::ptrdiff_t __index)
const 354 {
return _Storage_policy::get()[__index]; }
357 #if __cplusplus >= 201103L 358 explicit operator bool()
const {
return _Storage_policy::get() != 0; }
364 operator __unspecified_bool_type()
const 366 return _Storage_policy::get() == 0 ? 0 :
367 &_Pointer_adapter::operator->;
373 {
return (_Storage_policy::get() == 0); }
377 inline friend std::ptrdiff_t
379 {
return (__lhs.get() - __rhs); }
381 inline friend std::ptrdiff_t
383 {
return (__lhs - __rhs.get()); }
385 template<
typename _Up>
386 inline friend std::ptrdiff_t
388 {
return (__lhs.get() - __rhs); }
390 template<
typename _Up>
391 inline friend std::ptrdiff_t
393 {
return (__lhs - __rhs.get()); }
395 template<
typename _Up>
396 inline std::ptrdiff_t
398 {
return (_Storage_policy::get() - __rhs.get()); }
407 #define _CXX_POINTER_ARITH_OPERATOR_SET(INT_TYPE) \ 408 inline friend _Pointer_adapter \ 409 operator+(const _Pointer_adapter& __lhs, INT_TYPE __offset) \ 410 { return _Pointer_adapter(__lhs.get() + __offset); } \ 412 inline friend _Pointer_adapter \ 413 operator+(INT_TYPE __offset, const _Pointer_adapter& __rhs) \ 414 { return _Pointer_adapter(__rhs.get() + __offset); } \ 416 inline friend _Pointer_adapter \ 417 operator-(const _Pointer_adapter& __lhs, INT_TYPE __offset) \ 418 { return _Pointer_adapter(__lhs.get() - __offset); } \ 420 inline _Pointer_adapter& \ 421 operator+=(INT_TYPE __offset) \ 423 _Storage_policy::set(_Storage_policy::get() + __offset); \ 427 inline _Pointer_adapter& \ 428 operator-=(INT_TYPE __offset) \ 430 _Storage_policy::set(_Storage_policy::get() - __offset); \ 433 // END of _CXX_POINTER_ARITH_OPERATOR_SET macro 436 _CXX_POINTER_ARITH_OPERATOR_SET(
short);
437 _CXX_POINTER_ARITH_OPERATOR_SET(
unsigned short);
438 _CXX_POINTER_ARITH_OPERATOR_SET(
int);
439 _CXX_POINTER_ARITH_OPERATOR_SET(
unsigned int);
440 _CXX_POINTER_ARITH_OPERATOR_SET(
long);
441 _CXX_POINTER_ARITH_OPERATOR_SET(
unsigned long);
442 #ifdef _GLIBCXX_USE_LONG_LONG 443 #pragma GCC diagnostic push 444 #pragma GCC diagnostic ignored "-Wlong-long" 445 _CXX_POINTER_ARITH_OPERATOR_SET(
long long);
446 _CXX_POINTER_ARITH_OPERATOR_SET(
unsigned long long);
447 #pragma GCC diagnostic pop 454 _Storage_policy::set(_Storage_policy::get() + 1);
462 _Storage_policy::set(_Storage_policy::get() + 1);
469 _Storage_policy::set(_Storage_policy::get() - 1);
477 _Storage_policy::set(_Storage_policy::get() - 1);
481 #if __cpp_lib_three_way_comparison 482 friend std::strong_ordering
485 {
return __lhs.get() <=> __rhs.get(); }
490 #define _GCC_CXX_POINTER_COMPARISON_OPERATION_SET(OPERATOR) \ 491 template<typename _Tp1, typename _Tp2> \ 493 operator OPERATOR(const _Pointer_adapter<_Tp1>& __lhs, _Tp2 __rhs) \ 494 { return __lhs.get() OPERATOR __rhs; } \ 496 template<typename _Tp1, typename _Tp2> \ 498 operator OPERATOR(_Tp1 __lhs, const _Pointer_adapter<_Tp2>& __rhs) \ 499 { return __lhs OPERATOR __rhs.get(); } \ 501 template<typename _Tp1, typename _Tp2> \ 503 operator OPERATOR(const _Pointer_adapter<_Tp1>& __lhs, \ 504 const _Pointer_adapter<_Tp2>& __rhs) \ 505 { return __lhs.get() OPERATOR __rhs.get(); } \ 507 // End GCC_CXX_POINTER_COMPARISON_OPERATION_SET Macro 510 _GCC_CXX_POINTER_COMPARISON_OPERATION_SET(==)
511 _GCC_CXX_POINTER_COMPARISON_OPERATION_SET(!=)
512 _GCC_CXX_POINTER_COMPARISON_OPERATION_SET(<)
513 _GCC_CXX_POINTER_COMPARISON_OPERATION_SET(<=)
514 _GCC_CXX_POINTER_COMPARISON_OPERATION_SET(>)
515 _GCC_CXX_POINTER_COMPARISON_OPERATION_SET(>=)
518 template<
typename _Tp>
521 {
return __lhs.get() ==
reinterpret_cast<void*
>(__rhs); }
523 template<
typename _Tp>
526 {
return __rhs.get() ==
reinterpret_cast<void*
>(__lhs); }
528 template<
typename _Tp>
531 {
return __lhs.get() !=
reinterpret_cast<void*
>(__rhs); }
533 template<
typename _Tp>
536 {
return __rhs.get() !=
reinterpret_cast<void*
>(__lhs); }
542 template<
typename _Tp>
546 {
return __lhs._Tp::operator==(__rhs); }
548 template<
typename _Tp>
550 operator<=(const _Pointer_adapter<_Tp>& __lhs,
552 {
return __lhs._Tp::operator<(__rhs) || __lhs._Tp::operator==(__rhs); }
554 template<
typename _Tp>
558 {
return !(__lhs._Tp::operator==(__rhs)); }
560 template<
typename _Tp>
564 {
return !(__lhs._Tp::operator<(__rhs) || __lhs._Tp::operator==(__rhs)); }
566 template<
typename _Tp>
570 {
return !(__lhs._Tp::operator<(__rhs)); }
573 template<
typename _CharT,
typename _Traits,
typename _StoreT>
575 operator<<(std::basic_ostream<_CharT, _Traits>& __os,
577 {
return (__os << __p.get()); }
580 _GLIBCXX_END_NAMESPACE_VERSION
583 #if __cplusplus >= 201103L 584 namespace std _GLIBCXX_VISIBILITY(default)
586 _GLIBCXX_BEGIN_NAMESPACE_VERSION
588 template<
typename _Storage_policy>
594 typedef typename pointer::element_type element_type;
596 typedef typename pointer::difference_type difference_type;
598 template<
typename _Up>
600 typename pointer_traits<_Storage_policy>::template rebind<_Up>>;
602 static pointer pointer_to(
typename pointer::reference __r) noexcept
606 #if __cpp_lib_concepts 607 template<
typename _Policy>
611 =
typename __gnu_cxx::_Pointer_adapter<_Policy>::value_type;
614 _GLIBCXX_END_NAMESPACE_VERSION
A storage policy for use with _Pointer_adapter<> which stores the pointer's address as an offset valu...
GNU extensions for public use.
A storage policy for use with _Pointer_adapter<> which yields a standard pointer. ...
Template class basic_ostream.
ISO C++ entities toplevel namespace is std.
Random-access iterators support a superset of bidirectional iterator operations.
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...