2004-03-05 00:29:44 +01:00
|
|
|
// { dg-options "-mieee" { target alpha*-*-* } }
|
2002-09-18 20:06:13 +02:00
|
|
|
|
2000-04-21 22:33:34 +02:00
|
|
|
// 1999-08-23 bkoz
|
|
|
|
|
2004-03-05 00:29:44 +01:00
|
|
|
// Copyright (C) 1999, 2001, 2002, 2003, 2004 Free Software Foundation
|
2000-04-21 22:33:34 +02:00
|
|
|
//
|
|
|
|
// This file is part of the GNU ISO C++ Library. This library is free
|
|
|
|
// software; you can redistribute it and/or modify it under the
|
|
|
|
// terms of the GNU General Public License as published by the
|
|
|
|
// Free Software Foundation; either version 2, or (at your option)
|
|
|
|
// any later version.
|
|
|
|
|
|
|
|
// This library is distributed in the hope that it will be useful,
|
|
|
|
// but WITHOUT ANY WARRANTY; without even the implied warranty of
|
|
|
|
// MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
|
|
|
|
// GNU General Public License for more details.
|
|
|
|
|
|
|
|
// You should have received a copy of the GNU General Public License along
|
|
|
|
// with this library; see the file COPYING. If not, write to the Free
|
|
|
|
// Software Foundation, 59 Temple Place - Suite 330, Boston, MA 02111-1307,
|
|
|
|
// USA.
|
|
|
|
|
|
|
|
// 18.2.1.1 template class numeric_limits
|
|
|
|
|
|
|
|
#include <limits>
|
2001-08-15 01:34:04 +02:00
|
|
|
#include <limits.h>
|
|
|
|
#include <float.h>
|
2002-09-25 21:37:04 +02:00
|
|
|
#include <cwchar>
|
2001-08-07 05:38:33 +02:00
|
|
|
#include <testsuite_hooks.h>
|
2000-04-21 22:33:34 +02:00
|
|
|
|
2001-08-15 01:34:04 +02:00
|
|
|
template<typename T>
|
|
|
|
struct extrema {
|
|
|
|
static T min;
|
|
|
|
static T max;
|
|
|
|
};
|
|
|
|
|
|
|
|
|
|
|
|
#define DEFINE_EXTREMA(T, m, M) \
|
|
|
|
template<> T extrema<T>::min = m; \
|
|
|
|
template<> T extrema<T>::max = M
|
|
|
|
|
|
|
|
DEFINE_EXTREMA(char, CHAR_MIN, CHAR_MAX);
|
|
|
|
DEFINE_EXTREMA(signed char, SCHAR_MIN, SCHAR_MAX);
|
|
|
|
DEFINE_EXTREMA(unsigned char, 0, UCHAR_MAX);
|
|
|
|
DEFINE_EXTREMA(short, SHRT_MIN, SHRT_MAX);
|
|
|
|
DEFINE_EXTREMA(unsigned short, 0, USHRT_MAX);
|
|
|
|
DEFINE_EXTREMA(int, INT_MIN, INT_MAX);
|
|
|
|
DEFINE_EXTREMA(unsigned, 0U, UINT_MAX);
|
|
|
|
DEFINE_EXTREMA(long, LONG_MIN, LONG_MAX);
|
|
|
|
DEFINE_EXTREMA(unsigned long, 0UL, ULONG_MAX);
|
|
|
|
|
2003-07-05 06:05:45 +02:00
|
|
|
#if _GLIBCXX_USE_WCHAR_T
|
2002-09-25 21:37:04 +02:00
|
|
|
DEFINE_EXTREMA(wchar_t, WCHAR_MIN, WCHAR_MAX);
|
2003-07-05 06:05:45 +02:00
|
|
|
#endif //_GLIBCXX_USE_WCHAR_T
|
2002-09-25 21:37:04 +02:00
|
|
|
|
2001-08-15 01:34:04 +02:00
|
|
|
DEFINE_EXTREMA(float, FLT_MIN, FLT_MAX);
|
|
|
|
DEFINE_EXTREMA(double, DBL_MIN, DBL_MAX);
|
|
|
|
DEFINE_EXTREMA(long double, LDBL_MIN, LDBL_MAX);
|
|
|
|
|
|
|
|
#undef DEFINE_EXTREMA
|
|
|
|
|
|
|
|
template<typename T>
|
|
|
|
void test_extrema()
|
|
|
|
{
|
2003-09-23 22:03:30 +02:00
|
|
|
bool test __attribute__((unused)) = true;
|
2002-03-28 04:15:08 +01:00
|
|
|
T limits_min = std::numeric_limits<T>::min();
|
|
|
|
T limits_max = std::numeric_limits<T>::max();
|
|
|
|
T extrema_min = extrema<T>::min;
|
|
|
|
T extrema_max = extrema<T>::max;
|
|
|
|
VERIFY( extrema_min == limits_min );
|
|
|
|
VERIFY( extrema_max == limits_max );
|
2001-08-15 01:34:04 +02:00
|
|
|
}
|
|
|
|
|
2002-09-19 06:26:25 +02:00
|
|
|
template<typename T>
|
|
|
|
void test_epsilon()
|
|
|
|
{
|
2003-09-23 22:03:30 +02:00
|
|
|
bool test __attribute__((unused)) = true;
|
2002-09-19 06:26:25 +02:00
|
|
|
T epsilon = std::numeric_limits<T>::epsilon();
|
|
|
|
T one = 1;
|
|
|
|
|
|
|
|
VERIFY( one != (one + epsilon) );
|
|
|
|
}
|
|
|
|
|
2001-08-15 01:34:04 +02:00
|
|
|
#ifdef __CHAR_UNSIGNED__
|
|
|
|
#define char_is_signed false
|
|
|
|
#else
|
|
|
|
#define char_is_signed true
|
|
|
|
#endif
|
|
|
|
|
|
|
|
void test_sign()
|
|
|
|
{
|
2003-09-23 22:03:30 +02:00
|
|
|
bool test __attribute__((unused)) = true;
|
2001-08-15 01:34:04 +02:00
|
|
|
VERIFY( std::numeric_limits<char>::is_signed == char_is_signed );
|
|
|
|
VERIFY( std::numeric_limits<signed char>::is_signed == true );
|
|
|
|
VERIFY( std::numeric_limits<unsigned char>::is_signed == false );
|
|
|
|
VERIFY( std::numeric_limits<short>::is_signed == true );
|
|
|
|
VERIFY( std::numeric_limits<unsigned short>::is_signed == false );
|
|
|
|
VERIFY( std::numeric_limits<int>::is_signed == true );
|
|
|
|
VERIFY( std::numeric_limits<unsigned>::is_signed == false );
|
|
|
|
VERIFY( std::numeric_limits<long>::is_signed == true );
|
|
|
|
VERIFY( std::numeric_limits<unsigned long>::is_signed == false );
|
|
|
|
VERIFY( std::numeric_limits<float>::is_signed == true );
|
|
|
|
VERIFY( std::numeric_limits<double>::is_signed == true );
|
|
|
|
VERIFY( std::numeric_limits<long double>::is_signed == true );
|
|
|
|
}
|
|
|
|
|
2000-04-21 22:33:34 +02:00
|
|
|
|
builtin-types.def (BT_FN_FLOAT_CONST_STRING): New.
gcc/
* builtin-types.def (BT_FN_FLOAT_CONST_STRING): New.
(BT_FN_DOUBLE_CONST_STRING, BT_FN_LONG_DOUBLE_CONST_STRING): New.
* builtins.def (__builtin_nan, __builtin_nanf, __builtin_nanl): New.
(__builtin_nans, __builtin_nansf, __builtin_nansl): New.
* builtins.c (fold_builtin_nan): New.
(fold_builtin): Call it.
* real.c (real_nan): Parse a non-empty string.
(round_for_format): Fix NaN significand truncation.
* real.h (real_nan): Return bool.
* doc/extend.texi: Document new builtins.
libstdc++/
* include/std/std_limits.h (__glibcpp_f32_QNaN_bytes,
__glibcpp_f32_has_QNaN, __glibcpp_f32_SNaN_bytes,
__glibcpp_f32_has_SNaN, __glibcpp_f64_QNaN_bytes,
__glibcpp_f64_has_QNaN, __glibcpp_f64_SNaN_bytes,
__glibcpp_f64_has_SNaN, __glibcpp_f80_QNaN_bytes,
__glibcpp_f80_has_QNaN, __glibcpp_f80_SNaN_bytes,
__glibcpp_f80_has_SNaN, __glibcpp_f96_QNaN_bytes,
__glibcpp_f96_has_QNaN, __glibcpp_f96_SNaN_bytes,
__glibcpp_f96_has_SNaN, __glibcpp_f128_QNaN_bytes,
__glibcpp_f128_has_QNaN, __glibcpp_f128_SNaN_bytes,
__glibcpp_f128_has_SNaN, __glibcpp_float_QNaN_bytes,
__glibcpp_float_has_QNaN, __glibcpp_float_SNaN_bytes,
__glibcpp_float_has_SNaN, __glibcpp_double_QNaN_bytes,
__glibcpp_double_has_QNaN, __glibcpp_double_SNaN_bytes,
__glibcpp_double_has_SNaN, __glibcpp_long_double_QNaN_bytes,
__glibcpp_long_double_has_QNaN, __glibcpp_long_double_SNaN_bytes,
__glibcpp_long_double_has_SNaN): Remove.
(__glibcpp_f128_is_iec559): True if IEEE.
(__glibcpp_float_QNaN, __glibcpp_float_SNaN): Remove.
(__glibcpp_double_QNaN, __glibcpp_double_SNaN): Remove.
(__glibcpp_long_double_QNaN, __glibcpp_long_double_SNaN): Remove.
(std::numeric_limits<float>::has_quiet_NaN): Use __builtin_nanf.
(std::numeric_limits<float>::has_signaling_NaN): Mirror has_quiet_NaN.
(std::numeric_limits<float>::quiet_NaN): Use __builtin_nanf.
(std::numeric_limits<float>::signaling_NaN): Use __builtin_nansf.
(std::numeric_limits<double>): Similarly.
(std::numeric_limits<long double>): Similarly.
* src/limits.cc (__glibcpp_float_QNaN, __glibcpp_float_SNaN): Remove.
(__glibcpp_double_QNaN, __glibcpp_double_SNaN): Remove.
(__glibcpp_long_double_QNaN, __glibcpp_long_double_SNaN): Remove.
* testsuite/18_support/numeric_limits.cc (test_infinity): New.
(test_denorm_min, test_qnan, test_is_iec559): New.
From-SVN: r57221
2002-09-17 03:28:50 +02:00
|
|
|
template<typename T>
|
|
|
|
void
|
|
|
|
test_infinity()
|
|
|
|
{
|
|
|
|
bool test;
|
|
|
|
|
|
|
|
if (std::numeric_limits<T>::has_infinity)
|
|
|
|
{
|
|
|
|
T inf = std::numeric_limits<T>::infinity();
|
|
|
|
test = (inf + inf == inf);
|
|
|
|
}
|
|
|
|
else
|
|
|
|
test = true;
|
|
|
|
|
|
|
|
VERIFY (test);
|
|
|
|
}
|
|
|
|
|
|
|
|
template<typename T>
|
|
|
|
void
|
|
|
|
test_denorm_min()
|
|
|
|
{
|
|
|
|
bool test;
|
|
|
|
|
|
|
|
if (std::numeric_limits<T>::has_denorm == std::denorm_present)
|
|
|
|
{
|
|
|
|
T denorm = std::numeric_limits<T>::denorm_min();
|
|
|
|
test = (denorm > 0);
|
|
|
|
}
|
|
|
|
else
|
|
|
|
test = true;
|
|
|
|
|
|
|
|
VERIFY (test);
|
|
|
|
}
|
|
|
|
|
|
|
|
template<typename T>
|
|
|
|
void
|
|
|
|
test_qnan()
|
|
|
|
{
|
|
|
|
bool test;
|
|
|
|
|
|
|
|
if (std::numeric_limits<T>::has_quiet_NaN)
|
|
|
|
{
|
|
|
|
T nan = std::numeric_limits<T>::quiet_NaN();
|
|
|
|
test = (nan != nan);
|
|
|
|
}
|
|
|
|
else
|
|
|
|
test = true;
|
|
|
|
|
|
|
|
VERIFY (test);
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
template<typename T>
|
|
|
|
void
|
|
|
|
test_is_iec559()
|
|
|
|
{
|
|
|
|
bool test;
|
|
|
|
|
|
|
|
if (std::numeric_limits<T>::is_iec559)
|
|
|
|
{
|
|
|
|
// IEC 559 requires all of the following.
|
|
|
|
test = (std::numeric_limits<T>::has_infinity
|
|
|
|
&& std::numeric_limits<T>::has_quiet_NaN
|
|
|
|
&& std::numeric_limits<T>::has_signaling_NaN);
|
|
|
|
}
|
|
|
|
else
|
|
|
|
{
|
|
|
|
// If we had all of the following, why didn't we set IEC 559?
|
|
|
|
test = (!std::numeric_limits<T>::has_infinity
|
|
|
|
|| !std::numeric_limits<T>::has_quiet_NaN
|
|
|
|
|| !std::numeric_limits<T>::has_signaling_NaN);
|
|
|
|
}
|
|
|
|
|
|
|
|
VERIFY (test);
|
|
|
|
}
|
|
|
|
|
|
|
|
|
2000-04-21 22:33:34 +02:00
|
|
|
template<typename T>
|
|
|
|
struct A
|
|
|
|
{
|
|
|
|
int key;
|
|
|
|
public:
|
|
|
|
A(int i = 0): key(i) { }
|
|
|
|
bool
|
|
|
|
operator==(int i) { return i == key; }
|
|
|
|
};
|
|
|
|
|
2001-12-04 21:13:41 +01:00
|
|
|
struct B
|
|
|
|
{
|
|
|
|
B(int i = 0) { }
|
|
|
|
};
|
2000-04-21 22:33:34 +02:00
|
|
|
|
|
|
|
|
|
|
|
bool test01()
|
|
|
|
{
|
2003-09-23 22:03:30 +02:00
|
|
|
bool test __attribute__((unused)) = true;
|
2000-04-21 22:33:34 +02:00
|
|
|
std::numeric_limits< A<B> > obj;
|
|
|
|
|
2000-08-14 21:59:26 +02:00
|
|
|
VERIFY( !obj.is_specialized );
|
|
|
|
VERIFY( obj.min() == 0 );
|
|
|
|
VERIFY( obj.max() == 0 );
|
|
|
|
VERIFY( obj.digits == 0 );
|
|
|
|
VERIFY( obj.digits10 == 0 );
|
|
|
|
VERIFY( !obj.is_signed );
|
|
|
|
VERIFY( !obj.is_integer );
|
|
|
|
VERIFY( !obj.is_exact );
|
|
|
|
VERIFY( obj.radix == 0 );
|
|
|
|
VERIFY( obj.epsilon() == 0 );
|
|
|
|
VERIFY( obj.round_error() == 0 );
|
|
|
|
VERIFY( obj.min_exponent == 0 );
|
|
|
|
VERIFY( obj.min_exponent10 == 0 );
|
|
|
|
VERIFY( obj.max_exponent == 0 );
|
|
|
|
VERIFY( obj.max_exponent10 == 0 );
|
|
|
|
VERIFY( !obj.has_infinity );
|
|
|
|
VERIFY( !obj.has_quiet_NaN );
|
|
|
|
VERIFY( !obj.has_signaling_NaN );
|
|
|
|
VERIFY( !obj.has_denorm );
|
|
|
|
VERIFY( !obj.has_denorm_loss );
|
|
|
|
VERIFY( obj.infinity() == 0 );
|
|
|
|
VERIFY( obj.quiet_NaN() == 0 );
|
|
|
|
VERIFY( obj.signaling_NaN() == 0 );
|
|
|
|
VERIFY( obj.denorm_min() == 0 );
|
|
|
|
VERIFY( !obj.is_iec559 );
|
|
|
|
VERIFY( !obj.is_bounded );
|
|
|
|
VERIFY( !obj.is_modulo );
|
|
|
|
VERIFY( !obj.traps );
|
|
|
|
VERIFY( !obj.tinyness_before );
|
|
|
|
VERIFY( obj.round_style == std::round_toward_zero );
|
2000-04-21 22:33:34 +02:00
|
|
|
return test;
|
|
|
|
}
|
|
|
|
|
2001-06-20 05:05:31 +02:00
|
|
|
// test linkage of the generic bits
|
2001-12-04 21:13:41 +01:00
|
|
|
template struct std::numeric_limits<B>;
|
|
|
|
|
2001-06-20 05:05:31 +02:00
|
|
|
void test02()
|
|
|
|
{
|
|
|
|
typedef std::numeric_limits<B> b_nl_type;
|
|
|
|
|
|
|
|
// Should probably do all of them...
|
2003-09-23 22:03:30 +02:00
|
|
|
const int* __attribute__((unused)) pi1 = &b_nl_type::digits;
|
|
|
|
const int* __attribute__((unused)) pi2 = &b_nl_type::digits10;
|
|
|
|
const int* __attribute__((unused)) pi3 = &b_nl_type::max_exponent10;
|
|
|
|
const bool* __attribute__((unused)) pb1 = &b_nl_type::traps;
|
2001-06-20 05:05:31 +02:00
|
|
|
}
|
|
|
|
|
2001-12-12 21:23:30 +01:00
|
|
|
// libstdc++/5045
|
|
|
|
bool test03()
|
|
|
|
{
|
2003-09-23 22:03:30 +02:00
|
|
|
bool test __attribute__((unused)) = true;
|
2001-12-12 21:23:30 +01:00
|
|
|
|
|
|
|
VERIFY( std::numeric_limits<bool>::digits10 == 0 );
|
std_limits.h (__glibcpp_plain_char_is_signed, [...]): Remove.
* include/std/std_limits.h (__glibcpp_plain_char_is_signed,
__glibcpp_wchar_t_is_signed, __glibcpp_s8_max, __glibcpp_s8_min,
__glibcpp_s8_digits, __glibcpp_s8_digits10, __glibcpp_u8_min,
__glibcpp_u8_max, __glibcpp_u8_digits, __glibcpp_u8_digits10,
__glibcpp_s16_max, __glibcpp_s16_min, __glibcpp_s16_digits,
__glibcpp_s16_digits10, __glibcpp_u16_min, __glibcpp_u16_max,
__glibcpp_u16_digits, __glibcpp_u16_digits10, __glibcpp_s32_max,
__glibcpp_s32_min, __glibcpp_s32_digits, __glibcpp_s32_digits10,
__glibcpp_u32_min, __glibcpp_u32_max, __glibcpp_u32_digits,
__glibcpp_u32_digits10, __glibcpp_s64_max, __glibcpp_s64_min,
__glibcpp_s64_digits, __glibcpp_s64_digits10, __glibcpp_u64_min,
__glibcpp_u64_max, __glibcpp_u64_digits, __glibcpp_u64_digits10,
__glibcpp_bool_digits, __glibcpp_signed_char_min,
__glibcpp_signed_char_max, __glibcpp_signed_char_digits,
__glibcpp_signed_char_digits10, __glibcpp_unsigned_char_min,
__glibcpp_unsigned_char_max, __glibcpp_unsigned_char_digits,
__glibcpp_unsigned_char_digits10, __glibcpp_char_min,
__glibcpp_char_max, __glibcpp_char_digits, __glibcpp_char_digits10,
__glibcpp_signed_short_min, __glibcpp_signed_short_max,
__glibcpp_signed_short_digits, __glibcpp_signed_short_digits10,
__glibcpp_unsigned_short_min, __glibcpp_unsigned_short_max,
__glibcpp_unsigned_short_digits, __glibcpp_unsigned_short_digits10,
__glibcpp_signed_int_min, __glibcpp_signed_int_max,
__glibcpp_signed_int_digits, __glibcpp_signed_int_digits10,
__glibcpp_unsigned_int_min, __glibcpp_unsigned_int_max,
__glibcpp_unsigned_int_digits, __glibcpp_unsigned_int_digits10,
__glibcpp_signed_long_min, __glibcpp_signed_long_max,
__glibcpp_unsigned_long_digits, __glibcpp_unsigned_long_digits10,
__glibcpp_signed_long_long_min, __glibcpp_signed_long_long_max,
__glibcpp_signed_long_long_digits, __glibcpp_signed_long_long_digits10,
__glibcpp_wchar_t_min, __glibcpp_wchar_t_max, __glibcpp_wchar_t_digits,
__glibcpp_wchar_t_digits10): Remove.
(__glibcpp_byte, __glibcpp_word_bits, __glibcpp_word): Remove.
(__float_storage, __double_storage, __long_double_storage): Remove.
(__glibcpp_signed, __glibcpp_min, __glibcpp_max): New.
(__glibcpp_digits, __glibcpp_digits10): New.
(numeric_limits<T>::min): Use __glibcpp_min or limits.h builtins.
(numeric_limits<T>::max): Use __glibcpp_max or limits.h builtins.
(numeric_limits<T>::is_signed, T=char,wchar_t): Use __glibcpp_signed.
(numeric_limits<T>::digits): Use __glibcpp_digits.
(numeric_limits<T>::digits10): Use __glibcpp_digits10.
* testsuite/18_support/numeric_limits.cc (test03): Don't use
__glibcpp_s8_digits10 et al; check vs the installed versions
of digits10 for particular sizes.
* include/std/std_limits.h (__glibcpp_float_is_modulo,
__glibcpp_double_is_modulo, __glibcpp_long_double_is_modulo): Kill.
(numeric_limits<T>::is_modulo, T floating): Use false.
From-SVN: r57434
2002-09-23 13:24:57 +02:00
|
|
|
if (__CHAR_BIT__ == 8)
|
|
|
|
{
|
|
|
|
VERIFY( std::numeric_limits<signed char>::digits10 == 2 );
|
|
|
|
VERIFY( std::numeric_limits<unsigned char>::digits10 == 2 );
|
|
|
|
}
|
|
|
|
if (__CHAR_BIT__ * sizeof(short) == 16)
|
|
|
|
{
|
|
|
|
VERIFY( std::numeric_limits<signed short>::digits10 == 4 );
|
|
|
|
VERIFY( std::numeric_limits<unsigned short>::digits10 == 4 );
|
|
|
|
}
|
|
|
|
if (__CHAR_BIT__ * sizeof(int) == 32)
|
|
|
|
{
|
|
|
|
VERIFY( std::numeric_limits<signed int>::digits10 == 9 );
|
|
|
|
VERIFY( std::numeric_limits<unsigned int>::digits10 == 9 );
|
|
|
|
}
|
|
|
|
if (__CHAR_BIT__ * sizeof(long long) == 64)
|
|
|
|
{
|
|
|
|
VERIFY( std::numeric_limits<signed long long>::digits10 == 18 );
|
|
|
|
VERIFY( std::numeric_limits<unsigned long long>::digits10 == 19 );
|
|
|
|
}
|
2001-12-12 21:23:30 +01:00
|
|
|
return test;
|
|
|
|
}
|
|
|
|
|
2002-12-16 20:52:37 +01:00
|
|
|
// libstdc++/8949
|
|
|
|
bool test04()
|
|
|
|
{
|
2003-09-23 22:03:30 +02:00
|
|
|
bool test __attribute__((unused)) = true;
|
2002-12-16 20:52:37 +01:00
|
|
|
|
|
|
|
VERIFY( !std::numeric_limits<short>::is_iec559 );
|
|
|
|
VERIFY( !std::numeric_limits<unsigned short>::is_iec559 );
|
|
|
|
VERIFY( !std::numeric_limits<int>::is_iec559 );
|
|
|
|
VERIFY( !std::numeric_limits<unsigned int>::is_iec559 );
|
|
|
|
VERIFY( !std::numeric_limits<long>::is_iec559 );
|
|
|
|
VERIFY( !std::numeric_limits<unsigned long>::is_iec559 );
|
|
|
|
VERIFY( !std::numeric_limits<long long>::is_iec559 );
|
|
|
|
VERIFY( !std::numeric_limits<unsigned long long>::is_iec559 );
|
|
|
|
return test;
|
|
|
|
}
|
2001-12-12 21:23:30 +01:00
|
|
|
|
2000-04-21 22:33:34 +02:00
|
|
|
int main()
|
|
|
|
{
|
|
|
|
test01();
|
2001-06-20 05:05:31 +02:00
|
|
|
test02();
|
2001-12-12 21:23:30 +01:00
|
|
|
test03();
|
2002-12-16 20:52:37 +01:00
|
|
|
test04();
|
2001-08-15 01:34:04 +02:00
|
|
|
|
|
|
|
test_extrema<char>();
|
|
|
|
test_extrema<signed char>();
|
|
|
|
test_extrema<unsigned char>();
|
|
|
|
|
|
|
|
test_extrema<short>();
|
|
|
|
test_extrema<unsigned short>();
|
|
|
|
|
|
|
|
test_extrema<int>();
|
|
|
|
test_extrema<unsigned>();
|
|
|
|
|
|
|
|
test_extrema<long>();
|
|
|
|
test_extrema<unsigned long>();
|
|
|
|
|
|
|
|
test_extrema<float>();
|
|
|
|
test_extrema<double>();
|
|
|
|
test_extrema<long double>();
|
|
|
|
|
2002-09-19 06:26:25 +02:00
|
|
|
test_epsilon<float>();
|
|
|
|
test_epsilon<double>();
|
|
|
|
test_epsilon<long double>();
|
|
|
|
|
2001-08-15 01:34:04 +02:00
|
|
|
test_sign();
|
|
|
|
|
builtin-types.def (BT_FN_FLOAT_CONST_STRING): New.
gcc/
* builtin-types.def (BT_FN_FLOAT_CONST_STRING): New.
(BT_FN_DOUBLE_CONST_STRING, BT_FN_LONG_DOUBLE_CONST_STRING): New.
* builtins.def (__builtin_nan, __builtin_nanf, __builtin_nanl): New.
(__builtin_nans, __builtin_nansf, __builtin_nansl): New.
* builtins.c (fold_builtin_nan): New.
(fold_builtin): Call it.
* real.c (real_nan): Parse a non-empty string.
(round_for_format): Fix NaN significand truncation.
* real.h (real_nan): Return bool.
* doc/extend.texi: Document new builtins.
libstdc++/
* include/std/std_limits.h (__glibcpp_f32_QNaN_bytes,
__glibcpp_f32_has_QNaN, __glibcpp_f32_SNaN_bytes,
__glibcpp_f32_has_SNaN, __glibcpp_f64_QNaN_bytes,
__glibcpp_f64_has_QNaN, __glibcpp_f64_SNaN_bytes,
__glibcpp_f64_has_SNaN, __glibcpp_f80_QNaN_bytes,
__glibcpp_f80_has_QNaN, __glibcpp_f80_SNaN_bytes,
__glibcpp_f80_has_SNaN, __glibcpp_f96_QNaN_bytes,
__glibcpp_f96_has_QNaN, __glibcpp_f96_SNaN_bytes,
__glibcpp_f96_has_SNaN, __glibcpp_f128_QNaN_bytes,
__glibcpp_f128_has_QNaN, __glibcpp_f128_SNaN_bytes,
__glibcpp_f128_has_SNaN, __glibcpp_float_QNaN_bytes,
__glibcpp_float_has_QNaN, __glibcpp_float_SNaN_bytes,
__glibcpp_float_has_SNaN, __glibcpp_double_QNaN_bytes,
__glibcpp_double_has_QNaN, __glibcpp_double_SNaN_bytes,
__glibcpp_double_has_SNaN, __glibcpp_long_double_QNaN_bytes,
__glibcpp_long_double_has_QNaN, __glibcpp_long_double_SNaN_bytes,
__glibcpp_long_double_has_SNaN): Remove.
(__glibcpp_f128_is_iec559): True if IEEE.
(__glibcpp_float_QNaN, __glibcpp_float_SNaN): Remove.
(__glibcpp_double_QNaN, __glibcpp_double_SNaN): Remove.
(__glibcpp_long_double_QNaN, __glibcpp_long_double_SNaN): Remove.
(std::numeric_limits<float>::has_quiet_NaN): Use __builtin_nanf.
(std::numeric_limits<float>::has_signaling_NaN): Mirror has_quiet_NaN.
(std::numeric_limits<float>::quiet_NaN): Use __builtin_nanf.
(std::numeric_limits<float>::signaling_NaN): Use __builtin_nansf.
(std::numeric_limits<double>): Similarly.
(std::numeric_limits<long double>): Similarly.
* src/limits.cc (__glibcpp_float_QNaN, __glibcpp_float_SNaN): Remove.
(__glibcpp_double_QNaN, __glibcpp_double_SNaN): Remove.
(__glibcpp_long_double_QNaN, __glibcpp_long_double_SNaN): Remove.
* testsuite/18_support/numeric_limits.cc (test_infinity): New.
(test_denorm_min, test_qnan, test_is_iec559): New.
From-SVN: r57221
2002-09-17 03:28:50 +02:00
|
|
|
test_infinity<float>();
|
|
|
|
test_infinity<double>();
|
|
|
|
test_infinity<long double>();
|
|
|
|
|
|
|
|
test_denorm_min<float>();
|
|
|
|
test_denorm_min<double>();
|
|
|
|
test_denorm_min<long double>();
|
|
|
|
|
|
|
|
test_qnan<float>();
|
|
|
|
test_qnan<double>();
|
|
|
|
test_qnan<long double>();
|
|
|
|
|
|
|
|
// ??? How to test SNaN? We'd perhaps have to be prepared
|
|
|
|
// to catch SIGFPE. Can't rely on a signal getting through
|
|
|
|
// since the exception can be disabled in the FPU.
|
|
|
|
|
|
|
|
test_is_iec559<float>();
|
|
|
|
test_is_iec559<double>();
|
|
|
|
test_is_iec559<long double>();
|
|
|
|
|
|
|
|
return 0;
|
2000-04-21 22:33:34 +02:00
|
|
|
}
|