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_SIGNED_HPP_INCLUDED |
11 | #define BOOST_TT_IS_SIGNED_HPP_INCLUDED |
12 | |
13 | #include <boost/type_traits/is_integral.hpp> |
14 | #include <boost/type_traits/remove_cv.hpp> |
15 | #include <boost/type_traits/is_enum.hpp> |
16 | #include <climits> |
17 | |
18 | namespace boost { |
19 | |
20 | #if !defined( BOOST_CODEGEARC ) |
21 | |
22 | #if !(defined(BOOST_MSVC) && BOOST_MSVC <= 1310) && \ |
23 | !(defined(__EDG_VERSION__) && __EDG_VERSION__ <= 238) &&\ |
24 | !defined(BOOST_NO_INCLASS_MEMBER_INITIALIZATION) |
25 | |
26 | namespace detail{ |
27 | |
28 | template <class T> |
29 | struct is_signed_values |
30 | { |
31 | // |
32 | // Note that we cannot use BOOST_STATIC_CONSTANT here, using enum's |
33 | // rather than "real" static constants simply doesn't work or give |
34 | // the correct answer. |
35 | // |
36 | typedef typename remove_cv<T>::type no_cv_t; |
37 | static const no_cv_t minus_one = (static_cast<no_cv_t>(-1)); |
38 | static const no_cv_t zero = (static_cast<no_cv_t>(0)); |
39 | }; |
40 | |
41 | template <class T> |
42 | struct is_signed_helper |
43 | { |
44 | typedef typename remove_cv<T>::type no_cv_t; |
45 | BOOST_STATIC_CONSTANT(bool, value = (!(::boost::detail::is_signed_values<T>::minus_one > boost::detail::is_signed_values<T>::zero))); |
46 | }; |
47 | |
48 | template <bool integral_type> |
49 | struct is_signed_select_helper |
50 | { |
51 | template <class T> |
52 | struct rebind |
53 | { |
54 | typedef is_signed_helper<T> type; |
55 | }; |
56 | }; |
57 | |
58 | template <> |
59 | struct is_signed_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_signed_impl |
70 | { |
71 | typedef ::boost::detail::is_signed_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 | } |
78 | |
79 | template <class T> struct is_signed : public integral_constant<bool, boost::detail::is_signed_impl<T>::value> {}; |
80 | |
81 | #else |
82 | |
83 | template <class T> struct is_signed : public false_type{}; |
84 | |
85 | #endif |
86 | |
87 | #else //defined( BOOST_CODEGEARC ) |
88 | template <class T> struct is_signed : public integral_constant<bool, __is_signed(T)>{}; |
89 | #endif |
90 | |
91 | template <> struct is_signed<signed char> : public true_type{}; |
92 | template <> struct is_signed<const signed char> : public true_type{}; |
93 | template <> struct is_signed<volatile signed char> : public true_type{}; |
94 | template <> struct is_signed<const volatile signed char> : public true_type{}; |
95 | template <> struct is_signed<short> : public true_type{}; |
96 | template <> struct is_signed<const short> : public true_type{}; |
97 | template <> struct is_signed<volatile short> : public true_type{}; |
98 | template <> struct is_signed<const volatile short> : public true_type{}; |
99 | template <> struct is_signed<int> : public true_type{}; |
100 | template <> struct is_signed<const int> : public true_type{}; |
101 | template <> struct is_signed<volatile int> : public true_type{}; |
102 | template <> struct is_signed<const volatile int> : public true_type{}; |
103 | template <> struct is_signed<long> : public true_type{}; |
104 | template <> struct is_signed<const long> : public true_type{}; |
105 | template <> struct is_signed<volatile long> : public true_type{}; |
106 | template <> struct is_signed<const volatile long> : public true_type{}; |
107 | |
108 | template <> struct is_signed<unsigned char> : public false_type{}; |
109 | template <> struct is_signed<const unsigned char> : public false_type{}; |
110 | template <> struct is_signed<volatile unsigned char> : public false_type{}; |
111 | template <> struct is_signed<const volatile unsigned char> : public false_type{}; |
112 | template <> struct is_signed<unsigned short> : public false_type{}; |
113 | template <> struct is_signed<const unsigned short> : public false_type{}; |
114 | template <> struct is_signed<volatile unsigned short> : public false_type{}; |
115 | template <> struct is_signed<const volatile unsigned short> : public false_type{}; |
116 | template <> struct is_signed<unsigned int> : public false_type{}; |
117 | template <> struct is_signed<const unsigned int> : public false_type{}; |
118 | template <> struct is_signed<volatile unsigned int> : public false_type{}; |
119 | template <> struct is_signed<const volatile unsigned int> : public false_type{}; |
120 | template <> struct is_signed<unsigned long> : public false_type{}; |
121 | template <> struct is_signed<const unsigned long> : public false_type{}; |
122 | template <> struct is_signed<volatile unsigned long> : public false_type{}; |
123 | template <> struct is_signed<const volatile unsigned long> : public false_type{}; |
124 | #ifdef BOOST_HAS_LONG_LONG |
125 | template <> struct is_signed< ::boost::long_long_type> : public true_type{}; |
126 | template <> struct is_signed<const ::boost::long_long_type> : public true_type{}; |
127 | template <> struct is_signed<volatile ::boost::long_long_type> : public true_type{}; |
128 | template <> struct is_signed<const volatile ::boost::long_long_type> : public true_type{}; |
129 | |
130 | template <> struct is_signed< ::boost::ulong_long_type> : public false_type{}; |
131 | template <> struct is_signed<const ::boost::ulong_long_type> : public false_type{}; |
132 | template <> struct is_signed<volatile ::boost::ulong_long_type> : public false_type{}; |
133 | template <> struct is_signed<const volatile ::boost::ulong_long_type> : public false_type{}; |
134 | #endif |
135 | #if defined(CHAR_MIN) |
136 | #if CHAR_MIN != 0 |
137 | template <> struct is_signed<char> : public true_type{}; |
138 | template <> struct is_signed<const char> : public true_type{}; |
139 | template <> struct is_signed<volatile char> : public true_type{}; |
140 | template <> struct is_signed<const volatile char> : public true_type{}; |
141 | #else |
142 | template <> struct is_signed<char> : public false_type{}; |
143 | template <> struct is_signed<const char> : public false_type{}; |
144 | template <> struct is_signed<volatile char> : public false_type{}; |
145 | template <> struct is_signed<const volatile char> : public false_type{}; |
146 | #endif |
147 | #endif |
148 | #if defined(WCHAR_MIN) && !defined(BOOST_NO_INTRINSIC_WCHAR_T) |
149 | #if WCHAR_MIN != 0 |
150 | template <> struct is_signed<wchar_t> : public true_type{}; |
151 | template <> struct is_signed<const wchar_t> : public true_type{}; |
152 | template <> struct is_signed<volatile wchar_t> : public true_type{}; |
153 | template <> struct is_signed<const volatile wchar_t> : public true_type{}; |
154 | #else |
155 | template <> struct is_signed<wchar_t> : public false_type{}; |
156 | template <> struct is_signed<const wchar_t> : public false_type{}; |
157 | template <> struct is_signed<volatile wchar_t> : public false_type{}; |
158 | template <> struct is_signed<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 |
164 |