29 #ifndef _EXT_NUMERIC_TRAITS 30 #define _EXT_NUMERIC_TRAITS 1 32 #ifdef _GLIBCXX_SYSHDR 33 #pragma GCC system_header 39 namespace __gnu_cxx _GLIBCXX_VISIBILITY(default)
41 _GLIBCXX_BEGIN_NAMESPACE_VERSION
52 template<
typename _Tp>
53 struct __is_integer_nonstrict
54 :
public std::__is_integer<_Tp>
56 using std::__is_integer<_Tp>::__value;
59 enum { __width = __value ?
sizeof(_Tp) * __CHAR_BIT__ : 0 };
62 template<
typename _Value>
63 struct __numeric_traits_integer
65 #if __cplusplus >= 201103L 66 static_assert(__is_integer_nonstrict<_Value>::__value,
67 "invalid specialization");
72 static const bool __is_signed = (_Value)(-1) < 0;
73 static const int __digits
74 = __is_integer_nonstrict<_Value>::__width - __is_signed;
77 static const _Value __max = __is_signed
78 ? (((((_Value)1 << (__digits - 1)) - 1) << 1) + 1)
80 static const _Value __min = __is_signed ? -__max - 1 : (_Value)0;
83 template<
typename _Value>
84 const _Value __numeric_traits_integer<_Value>::__min;
86 template<
typename _Value>
87 const _Value __numeric_traits_integer<_Value>::__max;
89 template<
typename _Value>
90 const bool __numeric_traits_integer<_Value>::__is_signed;
92 template<
typename _Value>
93 const int __numeric_traits_integer<_Value>::__digits;
97 #define _GLIBCXX_INT_N_TRAITS(T, WIDTH) \ 99 template<> struct __is_integer_nonstrict<T> \ 101 enum { __value = 1 }; \ 102 typedef std::__true_type __type; \ 103 enum { __width = WIDTH }; \ 106 template<> struct __is_integer_nonstrict<unsigned T> \ 108 enum { __value = 1 }; \ 109 typedef std::__true_type __type; \ 110 enum { __width = WIDTH }; \ 116 #if defined __GLIBCXX_TYPE_INT_N_0 && __GLIBCXX_BITSIZE_INT_N_0 % __CHAR_BIT__ 117 _GLIBCXX_INT_N_TRAITS(__GLIBCXX_TYPE_INT_N_0, __GLIBCXX_BITSIZE_INT_N_0)
119 #if defined __GLIBCXX_TYPE_INT_N_1 && __GLIBCXX_BITSIZE_INT_N_1 % __CHAR_BIT__ 120 _GLIBCXX_INT_N_TRAITS(__GLIBCXX_TYPE_INT_N_1, __GLIBCXX_BITSIZE_INT_N_1)
122 #if defined __GLIBCXX_TYPE_INT_N_2 && __GLIBCXX_BITSIZE_INT_N_2 % __CHAR_BIT__ 123 _GLIBCXX_INT_N_TRAITS(__GLIBCXX_TYPE_INT_N_2, __GLIBCXX_BITSIZE_INT_N_2)
125 #if defined __GLIBCXX_TYPE_INT_N_3 && __GLIBCXX_BITSIZE_INT_N_3 % __CHAR_BIT__ 126 _GLIBCXX_INT_N_TRAITS(__GLIBCXX_TYPE_INT_N_3, __GLIBCXX_BITSIZE_INT_N_3)
129 #undef _GLIBCXX_INT_N_TRAITS 131 #if __cplusplus >= 201103L 133 template<
typename _Tp>
137 #define __glibcxx_floating(_Tp, _Fval, _Dval, _LDval) \ 138 (std::__are_same<_Tp, float>::__value ? _Fval \ 139 : std::__are_same<_Tp, double>::__value ? _Dval : _LDval) 141 #define __glibcxx_max_digits10(_Tp) \ 142 (2 + __glibcxx_floating(_Tp, __FLT_MANT_DIG__, __DBL_MANT_DIG__, \ 143 __LDBL_MANT_DIG__) * 643L / 2136) 145 #define __glibcxx_digits10(_Tp) \ 146 __glibcxx_floating(_Tp, __FLT_DIG__, __DBL_DIG__, __LDBL_DIG__) 148 #define __glibcxx_max_exponent10(_Tp) \ 149 __glibcxx_floating(_Tp, __FLT_MAX_10_EXP__, __DBL_MAX_10_EXP__, \ 153 template<
typename _Value>
154 struct __numeric_traits_floating
157 static const int __max_digits10 = __glibcxx_max_digits10(_Value);
160 static const bool __is_signed =
true;
161 static const int __digits10 = __glibcxx_digits10(_Value);
162 static const int __max_exponent10 = __glibcxx_max_exponent10(_Value);
165 template<
typename _Value>
166 const int __numeric_traits_floating<_Value>::__max_digits10;
168 template<
typename _Value>
169 const bool __numeric_traits_floating<_Value>::__is_signed;
171 template<
typename _Value>
172 const int __numeric_traits_floating<_Value>::__digits10;
174 template<
typename _Value>
175 const int __numeric_traits_floating<_Value>::__max_exponent10;
177 #undef __glibcxx_floating 178 #undef __glibcxx_max_digits10 179 #undef __glibcxx_digits10 180 #undef __glibcxx_max_exponent10 182 template<
typename _Value>
183 struct __numeric_traits
184 :
public __numeric_traits_integer<_Value>
188 struct __numeric_traits<float>
189 :
public __numeric_traits_floating<float>
193 struct __numeric_traits<double>
194 :
public __numeric_traits_floating<double>
198 struct __numeric_traits<long double>
199 :
public __numeric_traits_floating<long double>
202 #ifdef _GLIBCXX_LONG_DOUBLE_ALT128_COMPAT 203 # if defined __LONG_DOUBLE_IEEE128__ 206 struct __numeric_traits_floating<__ibm128>
208 static const int __max_digits10 = 33;
209 static const bool __is_signed =
true;
210 static const int __digits10 = 31;
211 static const int __max_exponent10 = 308;
214 struct __numeric_traits<__ibm128>
215 :
public __numeric_traits_floating<__ibm128>
217 # elif defined __LONG_DOUBLE_IBM128__ 220 struct __numeric_traits_floating<__ieee128>
222 static const int __max_digits10 = 36;
223 static const bool __is_signed =
true;
224 static const int __digits10 = 33;
225 static const int __max_exponent10 = 4932;
228 struct __numeric_traits<__ieee128>
229 :
public __numeric_traits_floating<__ieee128>
234 _GLIBCXX_END_NAMESPACE_VERSION
GNU extensions for public use.
__numeric_traits_integer< _Tp > __int_traits
Convenience alias for __numeric_traits<integer-type>.