File indexing completed on 2026-05-03 08:13:23
0001
0002
0003
0004
0005
0006
0007
0008
0009 #ifndef _LIBCPP___CXX03___BIT_ROTATE_H
0010 #define _LIBCPP___CXX03___BIT_ROTATE_H
0011
0012 #include <__cxx03/__concepts/arithmetic.h>
0013 #include <__cxx03/__config>
0014 #include <__cxx03/__type_traits/is_unsigned_integer.h>
0015 #include <__cxx03/limits>
0016
0017 #if !defined(_LIBCPP_HAS_NO_PRAGMA_SYSTEM_HEADER)
0018 # pragma GCC system_header
0019 #endif
0020
0021 _LIBCPP_BEGIN_NAMESPACE_STD
0022
0023
0024
0025
0026 template <class _Tp>
0027 _LIBCPP_HIDE_FROM_ABI _LIBCPP_CONSTEXPR_SINCE_CXX14 _Tp __rotl(_Tp __x, int __s) _NOEXCEPT {
0028 static_assert(__libcpp_is_unsigned_integer<_Tp>::value, "__rotl requires an unsigned integer type");
0029 const int __N = numeric_limits<_Tp>::digits;
0030 int __r = __s % __N;
0031
0032 if (__r == 0)
0033 return __x;
0034
0035 if (__r > 0)
0036 return (__x << __r) | (__x >> (__N - __r));
0037
0038 return (__x >> -__r) | (__x << (__N + __r));
0039 }
0040
0041 template <class _Tp>
0042 _LIBCPP_HIDE_FROM_ABI _LIBCPP_CONSTEXPR_SINCE_CXX14 _Tp __rotr(_Tp __x, int __s) _NOEXCEPT {
0043 static_assert(__libcpp_is_unsigned_integer<_Tp>::value, "__rotr requires an unsigned integer type");
0044 const int __N = numeric_limits<_Tp>::digits;
0045 int __r = __s % __N;
0046
0047 if (__r == 0)
0048 return __x;
0049
0050 if (__r > 0)
0051 return (__x >> __r) | (__x << (__N - __r));
0052
0053 return (__x << -__r) | (__x >> (__N + __r));
0054 }
0055
0056 #if _LIBCPP_STD_VER >= 20
0057
0058 template <__libcpp_unsigned_integer _Tp>
0059 [[nodiscard]] _LIBCPP_HIDE_FROM_ABI constexpr _Tp rotl(_Tp __t, int __cnt) noexcept {
0060 return std::__rotl(__t, __cnt);
0061 }
0062
0063 template <__libcpp_unsigned_integer _Tp>
0064 [[nodiscard]] _LIBCPP_HIDE_FROM_ABI constexpr _Tp rotr(_Tp __t, int __cnt) noexcept {
0065 return std::__rotr(__t, __cnt);
0066 }
0067
0068 #endif
0069
0070 _LIBCPP_END_NAMESPACE_STD
0071
0072 #endif