]> git.proxmox.com Git - ceph.git/blob - ceph/src/boost/boost/type_traits/is_unsigned.hpp
update sources to v12.2.3
[ceph.git] / ceph / src / boost / boost / type_traits / is_unsigned.hpp
1
2 // (C) Copyright John Maddock 2005.
3 // Use, modification and distribution are subject to the Boost Software License,
4 // Version 1.0. (See accompanying file LICENSE_1_0.txt or copy at
5 // http://www.boost.org/LICENSE_1_0.txt).
6 //
7 // See http://www.boost.org/libs/type_traits for most recent version including documentation.
8
9
10 #ifndef BOOST_TT_IS_UNSIGNED_HPP_INCLUDED
11 #define BOOST_TT_IS_UNSIGNED_HPP_INCLUDED
12
13 #include <boost/type_traits/is_integral.hpp>
14 #include <boost/type_traits/is_enum.hpp>
15 #include <boost/type_traits/remove_cv.hpp>
16
17 #include <climits>
18
19 namespace boost {
20
21 #if !defined( __CODEGEARC__ )
22
23 #if !(defined(BOOST_MSVC) && BOOST_MSVC <= 1310) &&\
24 !(defined(__EDG_VERSION__) && __EDG_VERSION__ <= 238) &&\
25 !defined(BOOST_NO_INCLASS_MEMBER_INITIALIZATION)
26
27 namespace detail{
28
29 template <class T>
30 struct is_unsigned_values
31 {
32 //
33 // Note that we cannot use BOOST_STATIC_CONSTANT here, using enum's
34 // rather than "real" static constants simply doesn't work or give
35 // the correct answer.
36 //
37 typedef typename remove_cv<T>::type no_cv_t;
38 static const no_cv_t minus_one = (static_cast<no_cv_t>(-1));
39 static const no_cv_t zero = (static_cast<no_cv_t>(0));
40 };
41
42 template <class T>
43 struct is_ununsigned_helper
44 {
45 BOOST_STATIC_CONSTANT(bool, value = (::boost::detail::is_unsigned_values<T>::minus_one > ::boost::detail::is_unsigned_values<T>::zero));
46 };
47
48 template <bool integral_type>
49 struct is_unsigned_select_helper
50 {
51 template <class T>
52 struct rebind
53 {
54 typedef is_ununsigned_helper<T> type;
55 };
56 };
57
58 template <>
59 struct is_unsigned_select_helper<false>
60 {
61 template <class T>
62 struct rebind
63 {
64 typedef false_type type;
65 };
66 };
67
68 template <class T>
69 struct is_unsigned
70 {
71 typedef ::boost::detail::is_unsigned_select_helper< ::boost::is_integral<T>::value || ::boost::is_enum<T>::value > selector;
72 typedef typename selector::template rebind<T> binder;
73 typedef typename binder::type type;
74 BOOST_STATIC_CONSTANT(bool, value = type::value);
75 };
76
77 } // namespace detail
78
79 template <class T> struct is_unsigned : public integral_constant<bool, boost::detail::is_unsigned<T>::value> {};
80
81 #else
82
83 template <class T> struct is_unsigned : public false_type{};
84
85 #endif
86
87 #else // defined( __CODEGEARC__ )
88 template <class T> struct is_unsigned : public integral_constant<bool, __is_unsigned(T)> {};
89 #endif
90
91 template <> struct is_unsigned<unsigned char> : public true_type{};
92 template <> struct is_unsigned<const unsigned char> : public true_type{};
93 template <> struct is_unsigned<volatile unsigned char> : public true_type{};
94 template <> struct is_unsigned<const volatile unsigned char> : public true_type{};
95 template <> struct is_unsigned<unsigned short> : public true_type{};
96 template <> struct is_unsigned<const unsigned short> : public true_type{};
97 template <> struct is_unsigned<volatile unsigned short> : public true_type{};
98 template <> struct is_unsigned<const volatile unsigned short> : public true_type{};
99 template <> struct is_unsigned<unsigned int> : public true_type{};
100 template <> struct is_unsigned<const unsigned int> : public true_type{};
101 template <> struct is_unsigned<volatile unsigned int> : public true_type{};
102 template <> struct is_unsigned<const volatile unsigned int> : public true_type{};
103 template <> struct is_unsigned<unsigned long> : public true_type{};
104 template <> struct is_unsigned<const unsigned long> : public true_type{};
105 template <> struct is_unsigned<volatile unsigned long> : public true_type{};
106 template <> struct is_unsigned<const volatile unsigned long> : public true_type{};
107
108 template <> struct is_unsigned<signed char> : public false_type{};
109 template <> struct is_unsigned<const signed char> : public false_type{};
110 template <> struct is_unsigned<volatile signed char> : public false_type{};
111 template <> struct is_unsigned<const volatile signed char> : public false_type{};
112 template <> struct is_unsigned< short> : public false_type{};
113 template <> struct is_unsigned<const short> : public false_type{};
114 template <> struct is_unsigned<volatile short> : public false_type{};
115 template <> struct is_unsigned<const volatile short> : public false_type{};
116 template <> struct is_unsigned< int> : public false_type{};
117 template <> struct is_unsigned<const int> : public false_type{};
118 template <> struct is_unsigned<volatile int> : public false_type{};
119 template <> struct is_unsigned<const volatile int> : public false_type{};
120 template <> struct is_unsigned< long> : public false_type{};
121 template <> struct is_unsigned<const long> : public false_type{};
122 template <> struct is_unsigned<volatile long> : public false_type{};
123 template <> struct is_unsigned<const volatile long> : public false_type{};
124 #ifdef BOOST_HAS_LONG_LONG
125 template <> struct is_unsigned< ::boost::ulong_long_type> : public true_type{};
126 template <> struct is_unsigned<const ::boost::ulong_long_type> : public true_type{};
127 template <> struct is_unsigned<volatile ::boost::ulong_long_type> : public true_type{};
128 template <> struct is_unsigned<const volatile ::boost::ulong_long_type> : public true_type{};
129
130 template <> struct is_unsigned< ::boost::long_long_type> : public false_type{};
131 template <> struct is_unsigned<const ::boost::long_long_type> : public false_type{};
132 template <> struct is_unsigned<volatile ::boost::long_long_type> : public false_type{};
133 template <> struct is_unsigned<const volatile ::boost::long_long_type> : public false_type{};
134 #endif
135 #if defined(CHAR_MIN)
136 #if CHAR_MIN == 0
137 template <> struct is_unsigned<char> : public true_type{};
138 template <> struct is_unsigned<const char> : public true_type{};
139 template <> struct is_unsigned<volatile char> : public true_type{};
140 template <> struct is_unsigned<const volatile char> : public true_type{};
141 #else
142 template <> struct is_unsigned<char> : public false_type{};
143 template <> struct is_unsigned<const char> : public false_type{};
144 template <> struct is_unsigned<volatile char> : public false_type{};
145 template <> struct is_unsigned<const volatile char> : public false_type{};
146 #endif
147 #endif
148 #if !defined(BOOST_NO_INTRINSIC_WCHAR_T) && defined(WCHAR_MIN)
149 #if WCHAR_MIN == 0
150 template <> struct is_unsigned<wchar_t> : public true_type{};
151 template <> struct is_unsigned<const wchar_t> : public true_type{};
152 template <> struct is_unsigned<volatile wchar_t> : public true_type{};
153 template <> struct is_unsigned<const volatile wchar_t> : public true_type{};
154 #else
155 template <> struct is_unsigned<wchar_t> : public false_type{};
156 template <> struct is_unsigned<const wchar_t> : public false_type{};
157 template <> struct is_unsigned<volatile wchar_t> : public false_type{};
158 template <> struct is_unsigned<const volatile wchar_t> : public false_type{};
159 #endif
160 #endif
161 } // namespace boost
162
163 #endif // BOOST_TT_IS_MEMBER_FUNCTION_POINTER_HPP_INCLUDED