[clang][modules] Don't prevent translation of FW_Private includes when explicitly...
[llvm-project.git] / libcxx / include / experimental / propagate_const
blob4fc8286465d971f6be8aa4c451c808ee079431af
1 // -*- C++ -*-
2 //===----------------------------------------------------------------------===//
3 //
4 // Part of the LLVM Project, under the Apache License v2.0 with LLVM Exceptions.
5 // See https://llvm.org/LICENSE.txt for license information.
6 // SPDX-License-Identifier: Apache-2.0 WITH LLVM-exception
7 //
8 //===----------------------------------------------------------------------===//
10 #ifndef _LIBCPP_EXPERIMENTAL_PROPAGATE_CONST
11 #define _LIBCPP_EXPERIMENTAL_PROPAGATE_CONST
14     propagate_const synopsis
16     namespace std { namespace experimental { inline namespace fundamentals_v2 {
18     // [propagate_const]
19     template <class T> class propagate_const;
21     // [propagate_const.underlying], underlying pointer access
22     constexpr const _Tp& _VSTD_LFTS_V2::get_underlying(const propagate_const<T>& pt) noexcept;
23     constexpr T& _VSTD_LFTS_V2::get_underlying(propagate_const<T>& pt) noexcept;
25     // [propagate_const.relational], relational operators
26     template <class T> constexpr bool operator==(const propagate_const<T>& pt, nullptr_t);
27     template <class T> constexpr bool operator==(nullptr_t, const propagate_const<T>& pu);
28     template <class T> constexpr bool operator!=(const propagate_const<T>& pt, nullptr_t);
29     template <class T> constexpr bool operator!=(nullptr_t, const propagate_const<T>& pu);
30     template <class T, class U> constexpr bool operator==(const propagate_const<T>& pt, const propagate_const<_Up>& pu);
31     template <class T, class U> constexpr bool operator!=(const propagate_const<T>& pt, const propagate_const<_Up>& pu);
32     template <class T, class U> constexpr bool operator<(const propagate_const<T>& pt, const propagate_const<_Up>& pu);
33     template <class T, class U> constexpr bool operator>(const propagate_const<T>& pt, const propagate_const<_Up>& pu);
34     template <class T, class U> constexpr bool operator<=(const propagate_const<T>& pt, const propagate_const<_Up>& pu);
35     template <class T, class U> constexpr bool operator>=(const propagate_const<T>& pt, const propagate_const<_Up>& pu);
36     template <class T, class U> constexpr bool operator==(const propagate_const<T>& pt, const _Up& u);
37     template <class T, class U> constexpr bool operator!=(const propagate_const<T>& pt, const _Up& u);
38     template <class T, class U> constexpr bool operator<(const propagate_const<T>& pt, const _Up& u);
39     template <class T, class U> constexpr bool operator>(const propagate_const<T>& pt, const _Up& u);
40     template <class T, class U> constexpr bool operator<=(const propagate_const<T>& pt, const _Up& u);
41     template <class T, class U> constexpr bool operator>=(const propagate_const<T>& pt, const _Up& u);
42     template <class T, class U> constexpr bool operator==(const _Tp& t, const propagate_const<_Up>& pu);
43     template <class T, class U> constexpr bool operator!=(const _Tp& t, const propagate_const<_Up>& pu);
44     template <class T, class U> constexpr bool operator<(const _Tp& t, const propagate_const<_Up>& pu);
45     template <class T, class U> constexpr bool operator>(const _Tp& t, const propagate_const<_Up>& pu);
46     template <class T, class U> constexpr bool operator<=(const _Tp& t, const propagate_const<_Up>& pu);
47     template <class T, class U> constexpr bool operator>=(const _Tp& t, const propagate_const<_Up>& pu);
49     // [propagate_const.algorithms], specialized algorithms
50     template <class T> constexpr void swap(propagate_const<T>& pt, propagate_const<T>& pu) noexcept(see below);
52     template <class T>
53     class propagate_const
54     {
56     public:
57       typedef remove_reference_t<decltype(*declval<T&>())> element_type;
59       // [propagate_const.ctor], constructors
60       constexpr propagate_const() = default;
61       propagate_const(const propagate_const& p) = delete;
62       constexpr propagate_const(propagate_const&& p) = default;
63       template <class U> EXPLICIT constexpr propagate_const(propagate_const<_Up>&& pu); // see below
64       template <class U> EXPLICIT constexpr propagate_const(U&& u); // see below
66       // [propagate_const.assignment], assignment
67       propagate_const& operator=(const propagate_const& p) = delete;
68       constexpr propagate_const& operator=(propagate_const&& p) = default;
69       template <class U> constexpr propagate_const& operator=(propagate_const<_Up>&& pu);
70       template <class U> constexpr propagate_const& operator=(U&& u); // see below
72       // [propagate_const.const_observers], const observers
73       explicit constexpr operator bool() const;
74       constexpr const element_type* operator->() const;
75       constexpr operator const element_type*() const; // Not always defined
76       constexpr const element_type& operator*() const;
77       constexpr const element_type* get() const;
79       // [propagate_const.non_const_observers], non-const observers
80       constexpr element_type* operator->();
81       constexpr operator element_type*(); // Not always defined
82       constexpr element_type& operator*();
83       constexpr element_type* get();
85       // [propagate_const.modifiers], modifiers
86       constexpr void swap(propagate_const& pt) noexcept(see below)
88     private:
89       T t_; // exposition only
90     };
92   } // namespace fundamentals_v2
93   } // namespace experimental
95   // [propagate_const.hash], hash support
96   template <class T> struct hash<experimental::fundamentals_v2::propagate_const<T>>;
98   // [propagate_const.comparison_function_objects], comparison function objects
99   template <class T> struct equal_to<experimental::fundamentals_v2::propagate_const<T>>;
100   template <class T> struct not_equal_to<experimental::fundamentals_v2::propagate_const<T>>;
101   template <class T> struct less<experimental::fundamentals_v2::propagate_const<T>>;
102   template <class T> struct greater<experimental::fundamentals_v2::propagate_const<T>>;
103   template <class T> struct less_equal<experimental::fundamentals_v2::propagate_const<T>>;
104   template <class T> struct greater_equal<experimental::fundamentals_v2::propagate_const<T>>;
106 } // namespace std
110 #include <__assert> // all public C++ headers provide the assertion handler
111 #include <__functional/operations.h>
112 #include <__fwd/hash.h>
113 #include <__type_traits/conditional.h>
114 #include <__type_traits/decay.h>
115 #include <__type_traits/enable_if.h>
116 #include <__type_traits/is_array.h>
117 #include <__type_traits/is_constructible.h>
118 #include <__type_traits/is_convertible.h>
119 #include <__type_traits/is_function.h>
120 #include <__type_traits/is_pointer.h>
121 #include <__type_traits/is_reference.h>
122 #include <__type_traits/is_same.h>
123 #include <__type_traits/is_swappable.h>
124 #include <__type_traits/remove_cv.h>
125 #include <__type_traits/remove_pointer.h>
126 #include <__type_traits/remove_reference.h>
127 #include <__utility/declval.h>
128 #include <__utility/forward.h>
129 #include <__utility/move.h>
130 #include <__utility/swap.h>
131 #include <cstddef>
132 #include <experimental/__config>
134 #if !defined(_LIBCPP_HAS_NO_PRAGMA_SYSTEM_HEADER)
135 #  pragma GCC system_header
136 #endif
138 _LIBCPP_PUSH_MACROS
139 #include <__undef_macros>
141 #if _LIBCPP_STD_VER >= 14
143 _LIBCPP_BEGIN_NAMESPACE_LFTS_V2
145 template <class _Tp>
146 class propagate_const;
148 template <class _Up>
149 inline _LIBCPP_INLINE_VISIBILITY _LIBCPP_CONSTEXPR
150 const _Up& get_underlying(const propagate_const<_Up>& __pu) _NOEXCEPT;
152 template <class _Up>
153 inline _LIBCPP_INLINE_VISIBILITY _LIBCPP_CONSTEXPR
154 _Up& get_underlying(propagate_const<_Up>& __pu) _NOEXCEPT;
156 template <class _Tp>
157 class propagate_const
159 public:
160   typedef remove_reference_t<decltype(*std::declval<_Tp&>())> element_type;
162   static_assert(!is_array<_Tp>::value,
163       "Instantiation of propagate_const with an array type is ill-formed.");
164   static_assert(!is_reference<_Tp>::value,
165       "Instantiation of propagate_const with a reference type is ill-formed.");
166   static_assert(!(is_pointer<_Tp>::value && is_function<__remove_pointer_t<_Tp> >::value),
167       "Instantiation of propagate_const with a function-pointer type is ill-formed.");
168   static_assert(!(is_pointer<_Tp>::value && is_same<__remove_cv_t<__remove_pointer_t<_Tp> >, void>::value),
169       "Instantiation of propagate_const with a pointer to (possibly cv-qualified) void is ill-formed.");
171 private:
172   template <class _Up>
173   static _LIBCPP_HIDE_FROM_ABI _LIBCPP_CONSTEXPR element_type* __get_pointer(_Up* __u)
174   {
175     return __u;
176   }
178   template <class _Up>
179   static _LIBCPP_HIDE_FROM_ABI _LIBCPP_CONSTEXPR element_type* __get_pointer(_Up& __u)
180   {
181     return __get_pointer(__u.get());
182   }
184   template <class _Up>
185   static _LIBCPP_HIDE_FROM_ABI _LIBCPP_CONSTEXPR const element_type* __get_pointer(const _Up* __u)
186   {
187     return __u;
188   }
190   template <class _Up>
191   static _LIBCPP_HIDE_FROM_ABI _LIBCPP_CONSTEXPR const element_type* __get_pointer(const _Up& __u)
192   {
193     return __get_pointer(__u.get());
194   }
196   template <class _Up>
197   struct __is_propagate_const : false_type
198   {
199   };
201   template <class _Up>
202   struct __is_propagate_const<propagate_const<_Up>> : true_type
203   {
204   };
206   _Tp __t_;
208 public:
210   template <class _Up> friend _LIBCPP_CONSTEXPR const _Up& ::_VSTD_LFTS_V2::get_underlying(const propagate_const<_Up>& __pu) _NOEXCEPT;
211   template <class _Up> friend _LIBCPP_CONSTEXPR _Up& ::_VSTD_LFTS_V2::get_underlying(propagate_const<_Up>& __pu) _NOEXCEPT;
213   _LIBCPP_HIDE_FROM_ABI _LIBCPP_CONSTEXPR propagate_const() = default;
215   propagate_const(const propagate_const&) = delete;
217   _LIBCPP_HIDE_FROM_ABI _LIBCPP_CONSTEXPR propagate_const(propagate_const&&) = default;
219   template <class _Up, enable_if_t<!is_convertible<_Up, _Tp>::value &&
220                                  is_constructible<_Tp, _Up&&>::value,bool> = true>
221   explicit _LIBCPP_HIDE_FROM_ABI _LIBCPP_CONSTEXPR propagate_const(propagate_const<_Up>&& __pu)
222       : __t_(std::move(_VSTD_LFTS_V2::get_underlying(__pu)))
223   {
224   }
226   template <class _Up, enable_if_t<is_convertible<_Up&&, _Tp>::value &&
227                                  is_constructible<_Tp, _Up&&>::value,bool> = false>
228   _LIBCPP_HIDE_FROM_ABI _LIBCPP_CONSTEXPR propagate_const(propagate_const<_Up>&& __pu)
229       : __t_(std::move(_VSTD_LFTS_V2::get_underlying(__pu)))
230   {
231   }
233   template <class _Up, enable_if_t<!is_convertible<_Up&&, _Tp>::value &&
234                                  is_constructible<_Tp, _Up&&>::value &&
235                                  !__is_propagate_const<decay_t<_Up>>::value,bool> = true>
236   explicit _LIBCPP_HIDE_FROM_ABI _LIBCPP_CONSTEXPR propagate_const(_Up&& __u)
237       : __t_(std::forward<_Up>(__u))
238   {
239   }
241   template <class _Up, enable_if_t<is_convertible<_Up&&, _Tp>::value &&
242                                  is_constructible<_Tp, _Up&&>::value &&
243                                  !__is_propagate_const<decay_t<_Up>>::value,bool> = false>
244   _LIBCPP_HIDE_FROM_ABI _LIBCPP_CONSTEXPR propagate_const(_Up&& __u)
245       : __t_(std::forward<_Up>(__u))
246   {
247   }
249   propagate_const& operator=(const propagate_const&) = delete;
251   _LIBCPP_HIDE_FROM_ABI _LIBCPP_CONSTEXPR propagate_const& operator=(propagate_const&&) = default;
253   template <class _Up>
254   _LIBCPP_HIDE_FROM_ABI _LIBCPP_CONSTEXPR propagate_const& operator=(propagate_const<_Up>&& __pu)
255   {
256     __t_ = std::move(_VSTD_LFTS_V2::get_underlying(__pu));
257     return *this;
258   }
260   template <class _Up, class _Vp = enable_if_t<!__is_propagate_const<decay_t<_Up>>::value>>
261   _LIBCPP_HIDE_FROM_ABI _LIBCPP_CONSTEXPR propagate_const& operator=(_Up&& __u)
262   {
263     __t_ = std::forward<_Up>(__u);
264     return *this;
265   }
267   _LIBCPP_HIDE_FROM_ABI _LIBCPP_CONSTEXPR const element_type* get() const
268   {
269     return __get_pointer(__t_);
270   }
272   _LIBCPP_HIDE_FROM_ABI _LIBCPP_CONSTEXPR element_type* get()
273   {
274     return __get_pointer(__t_);
275   }
277   _LIBCPP_HIDE_FROM_ABI explicit _LIBCPP_CONSTEXPR operator bool() const
278   {
279     return get() != nullptr;
280   }
282   _LIBCPP_HIDE_FROM_ABI _LIBCPP_CONSTEXPR const element_type* operator->() const
283   {
284     return get();
285   }
287   template <class _Dummy = _Tp, class _Up = enable_if_t<is_convertible<
288                                   const _Dummy, const element_type *>::value>>
289   _LIBCPP_HIDE_FROM_ABI _LIBCPP_CONSTEXPR operator const element_type *() const {
290     return get();
291   }
293   _LIBCPP_HIDE_FROM_ABI _LIBCPP_CONSTEXPR const element_type& operator*() const
294   {
295     return *get();
296   }
298   _LIBCPP_HIDE_FROM_ABI _LIBCPP_CONSTEXPR element_type* operator->()
299   {
300     return get();
301   }
303   template <class _Dummy = _Tp, class _Up = enable_if_t<
304                                   is_convertible<_Dummy, element_type *>::value>>
305   _LIBCPP_HIDE_FROM_ABI _LIBCPP_CONSTEXPR operator element_type *() {
306     return get();
307   }
309   _LIBCPP_HIDE_FROM_ABI _LIBCPP_CONSTEXPR element_type& operator*()
310   {
311     return *get();
312   }
314   _LIBCPP_HIDE_FROM_ABI _LIBCPP_CONSTEXPR void swap(propagate_const& __pt)
315       _NOEXCEPT_(__is_nothrow_swappable<_Tp>::value) {
316     using _VSTD::swap;
317     swap(__t_, __pt.__t_);
318   }
322 template <class _Tp>
323 _LIBCPP_INLINE_VISIBILITY
324 _LIBCPP_CONSTEXPR bool operator==(const propagate_const<_Tp>& __pt, nullptr_t)
326   return _VSTD_LFTS_V2::get_underlying(__pt) == nullptr;
329 template <class _Tp>
330 _LIBCPP_INLINE_VISIBILITY
331 _LIBCPP_CONSTEXPR bool operator==(nullptr_t, const propagate_const<_Tp>& __pt)
333   return nullptr == _VSTD_LFTS_V2::get_underlying(__pt);
336 template <class _Tp>
337 _LIBCPP_INLINE_VISIBILITY
338 _LIBCPP_CONSTEXPR bool operator!=(const propagate_const<_Tp>& __pt, nullptr_t)
340   return _VSTD_LFTS_V2::get_underlying(__pt) != nullptr;
343 template <class _Tp>
344 _LIBCPP_INLINE_VISIBILITY
345 _LIBCPP_CONSTEXPR bool operator!=(nullptr_t, const propagate_const<_Tp>& __pt)
347   return nullptr != _VSTD_LFTS_V2::get_underlying(__pt);
350 template <class _Tp, class _Up>
351 _LIBCPP_INLINE_VISIBILITY
352 _LIBCPP_CONSTEXPR bool operator==(const propagate_const<_Tp>& __pt,
353                           const propagate_const<_Up>& __pu)
355   return _VSTD_LFTS_V2::get_underlying(__pt) == _VSTD_LFTS_V2::get_underlying(__pu);
358 template <class _Tp, class _Up>
359 _LIBCPP_INLINE_VISIBILITY
360 _LIBCPP_CONSTEXPR bool operator!=(const propagate_const<_Tp>& __pt,
361                           const propagate_const<_Up>& __pu)
363   return _VSTD_LFTS_V2::get_underlying(__pt) != _VSTD_LFTS_V2::get_underlying(__pu);
366 template <class _Tp, class _Up>
367 _LIBCPP_INLINE_VISIBILITY
368 _LIBCPP_CONSTEXPR bool operator<(const propagate_const<_Tp>& __pt,
369                          const propagate_const<_Up>& __pu)
371   return _VSTD_LFTS_V2::get_underlying(__pt) < _VSTD_LFTS_V2::get_underlying(__pu);
374 template <class _Tp, class _Up>
375 _LIBCPP_INLINE_VISIBILITY
376 _LIBCPP_CONSTEXPR bool operator>(const propagate_const<_Tp>& __pt,
377                          const propagate_const<_Up>& __pu)
379   return _VSTD_LFTS_V2::get_underlying(__pt) > _VSTD_LFTS_V2::get_underlying(__pu);
382 template <class _Tp, class _Up>
383 _LIBCPP_INLINE_VISIBILITY
384 _LIBCPP_CONSTEXPR bool operator<=(const propagate_const<_Tp>& __pt,
385                           const propagate_const<_Up>& __pu)
387   return _VSTD_LFTS_V2::get_underlying(__pt) <= _VSTD_LFTS_V2::get_underlying(__pu);
390 template <class _Tp, class _Up>
391 _LIBCPP_INLINE_VISIBILITY
392 _LIBCPP_CONSTEXPR bool operator>=(const propagate_const<_Tp>& __pt,
393                           const propagate_const<_Up>& __pu)
395   return _VSTD_LFTS_V2::get_underlying(__pt) >= _VSTD_LFTS_V2::get_underlying(__pu);
398 template <class _Tp, class _Up>
399 _LIBCPP_INLINE_VISIBILITY
400 _LIBCPP_CONSTEXPR bool operator==(const propagate_const<_Tp>& __pt, const _Up& __u)
402   return _VSTD_LFTS_V2::get_underlying(__pt) == __u;
405 template <class _Tp, class _Up>
406 _LIBCPP_INLINE_VISIBILITY
407 _LIBCPP_CONSTEXPR bool operator!=(const propagate_const<_Tp>& __pt, const _Up& __u)
409   return _VSTD_LFTS_V2::get_underlying(__pt) != __u;
412 template <class _Tp, class _Up>
413 _LIBCPP_INLINE_VISIBILITY
414 _LIBCPP_CONSTEXPR bool operator<(const propagate_const<_Tp>& __pt, const _Up& __u)
416   return _VSTD_LFTS_V2::get_underlying(__pt) < __u;
419 template <class _Tp, class _Up>
420 _LIBCPP_INLINE_VISIBILITY
421 _LIBCPP_CONSTEXPR bool operator>(const propagate_const<_Tp>& __pt, const _Up& __u)
423   return _VSTD_LFTS_V2::get_underlying(__pt) > __u;
426 template <class _Tp, class _Up>
427 _LIBCPP_INLINE_VISIBILITY
428 _LIBCPP_CONSTEXPR bool operator<=(const propagate_const<_Tp>& __pt, const _Up& __u)
430   return _VSTD_LFTS_V2::get_underlying(__pt) <= __u;
433 template <class _Tp, class _Up>
434 _LIBCPP_INLINE_VISIBILITY
435 _LIBCPP_CONSTEXPR bool operator>=(const propagate_const<_Tp>& __pt, const _Up& __u)
437   return _VSTD_LFTS_V2::get_underlying(__pt) >= __u;
441 template <class _Tp, class _Up>
442 _LIBCPP_INLINE_VISIBILITY
443 _LIBCPP_CONSTEXPR bool operator==(const _Tp& __t, const propagate_const<_Up>& __pu)
445   return __t == _VSTD_LFTS_V2::get_underlying(__pu);
448 template <class _Tp, class _Up>
449 _LIBCPP_INLINE_VISIBILITY
450 _LIBCPP_CONSTEXPR bool operator!=(const _Tp& __t, const propagate_const<_Up>& __pu)
452   return __t != _VSTD_LFTS_V2::get_underlying(__pu);
455 template <class _Tp, class _Up>
456 _LIBCPP_INLINE_VISIBILITY
457 _LIBCPP_CONSTEXPR bool operator<(const _Tp& __t, const propagate_const<_Up>& __pu)
459   return __t < _VSTD_LFTS_V2::get_underlying(__pu);
462 template <class _Tp, class _Up>
463 _LIBCPP_INLINE_VISIBILITY
464 _LIBCPP_CONSTEXPR bool operator>(const _Tp& __t, const propagate_const<_Up>& __pu)
466   return __t > _VSTD_LFTS_V2::get_underlying(__pu);
469 template <class _Tp, class _Up>
470 _LIBCPP_INLINE_VISIBILITY
471 _LIBCPP_CONSTEXPR bool operator<=(const _Tp& __t, const propagate_const<_Up>& __pu)
473   return __t <= _VSTD_LFTS_V2::get_underlying(__pu);
476 template <class _Tp, class _Up>
477 _LIBCPP_INLINE_VISIBILITY
478 _LIBCPP_CONSTEXPR bool operator>=(const _Tp& __t, const propagate_const<_Up>& __pu)
480   return __t >= _VSTD_LFTS_V2::get_underlying(__pu);
483 template <class _Tp>
484 _LIBCPP_INLINE_VISIBILITY
485 _LIBCPP_CONSTEXPR void swap(propagate_const<_Tp>& __pc1, propagate_const<_Tp>& __pc2) _NOEXCEPT_(__is_nothrow_swappable<_Tp>::value)
487   __pc1.swap(__pc2);
490 template <class _Tp>
491 _LIBCPP_CONSTEXPR const _Tp& get_underlying(const propagate_const<_Tp>& __pt) _NOEXCEPT
493   return __pt.__t_;
496 template <class _Tp>
497 _LIBCPP_CONSTEXPR _Tp& get_underlying(propagate_const<_Tp>& __pt) _NOEXCEPT
499   return __pt.__t_;
502 _LIBCPP_END_NAMESPACE_LFTS_V2
504 _LIBCPP_BEGIN_NAMESPACE_STD
506 template <class _Tp>
507 struct hash<experimental::fundamentals_v2::propagate_const<_Tp>>
509   typedef size_t result_type;
510   typedef experimental::fundamentals_v2::propagate_const<_Tp> argument_type;
512   _LIBCPP_HIDE_FROM_ABI size_t operator()(const experimental::fundamentals_v2::propagate_const<_Tp>& __pc1) const
513   {
514     return std::hash<_Tp>()(_VSTD_LFTS_V2::get_underlying(__pc1));
515   }
518 template <class _Tp>
519 struct equal_to<experimental::fundamentals_v2::propagate_const<_Tp>>
521   typedef experimental::fundamentals_v2::propagate_const<_Tp> first_argument_type;
522   typedef experimental::fundamentals_v2::propagate_const<_Tp> second_argument_type;
524   _LIBCPP_HIDE_FROM_ABI bool operator()(const experimental::fundamentals_v2::propagate_const<_Tp>& __pc1,
525       const experimental::fundamentals_v2::propagate_const<_Tp>& __pc2) const
526   {
527     return std::equal_to<_Tp>()(_VSTD_LFTS_V2::get_underlying(__pc1), _VSTD_LFTS_V2::get_underlying(__pc2));
528   }
531 template <class _Tp>
532 struct not_equal_to<experimental::fundamentals_v2::propagate_const<_Tp>>
534   typedef experimental::fundamentals_v2::propagate_const<_Tp> first_argument_type;
535   typedef experimental::fundamentals_v2::propagate_const<_Tp> second_argument_type;
537   _LIBCPP_HIDE_FROM_ABI bool operator()(const experimental::fundamentals_v2::propagate_const<_Tp>& __pc1,
538       const experimental::fundamentals_v2::propagate_const<_Tp>& __pc2) const
539   {
540     return std::not_equal_to<_Tp>()(_VSTD_LFTS_V2::get_underlying(__pc1), _VSTD_LFTS_V2::get_underlying(__pc2));
541   }
544 template <class _Tp>
545 struct less<experimental::fundamentals_v2::propagate_const<_Tp>>
547   typedef experimental::fundamentals_v2::propagate_const<_Tp> first_argument_type;
548   typedef experimental::fundamentals_v2::propagate_const<_Tp> second_argument_type;
550   _LIBCPP_HIDE_FROM_ABI bool operator()(const experimental::fundamentals_v2::propagate_const<_Tp>& __pc1,
551       const experimental::fundamentals_v2::propagate_const<_Tp>& __pc2) const
552   {
553     return std::less<_Tp>()(_VSTD_LFTS_V2::get_underlying(__pc1), _VSTD_LFTS_V2::get_underlying(__pc2));
554   }
557 template <class _Tp>
558 struct greater<experimental::fundamentals_v2::propagate_const<_Tp>>
560   typedef experimental::fundamentals_v2::propagate_const<_Tp> first_argument_type;
561   typedef experimental::fundamentals_v2::propagate_const<_Tp> second_argument_type;
563   _LIBCPP_HIDE_FROM_ABI bool operator()(const experimental::fundamentals_v2::propagate_const<_Tp>& __pc1,
564       const experimental::fundamentals_v2::propagate_const<_Tp>& __pc2) const
565   {
566     return std::greater<_Tp>()(_VSTD_LFTS_V2::get_underlying(__pc1), _VSTD_LFTS_V2::get_underlying(__pc2));
567   }
570 template <class _Tp>
571 struct less_equal<experimental::fundamentals_v2::propagate_const<_Tp>>
573   typedef experimental::fundamentals_v2::propagate_const<_Tp> first_argument_type;
574   typedef experimental::fundamentals_v2::propagate_const<_Tp> second_argument_type;
576   _LIBCPP_HIDE_FROM_ABI bool operator()(const experimental::fundamentals_v2::propagate_const<_Tp>& __pc1,
577       const experimental::fundamentals_v2::propagate_const<_Tp>& __pc2) const
578   {
579     return std::less_equal<_Tp>()(_VSTD_LFTS_V2::get_underlying(__pc1), _VSTD_LFTS_V2::get_underlying(__pc2));
580   }
583 template <class _Tp>
584 struct greater_equal<experimental::fundamentals_v2::propagate_const<_Tp>>
586   typedef experimental::fundamentals_v2::propagate_const<_Tp> first_argument_type;
587   typedef experimental::fundamentals_v2::propagate_const<_Tp> second_argument_type;
589   _LIBCPP_HIDE_FROM_ABI bool operator()(const experimental::fundamentals_v2::propagate_const<_Tp>& __pc1,
590       const experimental::fundamentals_v2::propagate_const<_Tp>& __pc2) const
591   {
592     return std::greater_equal<_Tp>()(_VSTD_LFTS_V2::get_underlying(__pc1), _VSTD_LFTS_V2::get_underlying(__pc2));
593   }
596 _LIBCPP_END_NAMESPACE_STD
598 #endif // _LIBCPP_STD_VER >= 14
600 _LIBCPP_POP_MACROS
602 #if !defined(_LIBCPP_REMOVE_TRANSITIVE_INCLUDES) && _LIBCPP_STD_VER <= 20
603 #  include <type_traits>
604 #endif
606 #endif // _LIBCPP_EXPERIMENTAL_PROPAGATE_CONST