williamr@2: /* williamr@2: * Copyright (c) 1998,1999 williamr@2: * Silicon Graphics Computer Systems, Inc. williamr@2: * williamr@2: * Copyright (c) 1999 williamr@2: * Boris Fomitchev williamr@2: * williamr@2: * This material is provided "as is", with absolutely no warranty expressed williamr@2: * or implied. Any use is at your own risk. williamr@2: * williamr@2: * Permission to use or copy this software for any purpose is hereby granted williamr@2: * without fee, provided the above notices are retained on all copies. williamr@2: * Permission to modify the code and to distribute modified code is granted, williamr@2: * provided the above notices are retained, and a notice that the code was williamr@2: * modified is included with the above copyright notice. williamr@2: * williamr@2: */ williamr@2: williamr@2: # if !defined (_STLP_LIMITS_C) williamr@2: # define _STLP_LIMITS_C williamr@2: williamr@2: #ifndef _STLP_INTERNAL_LIMITS_H williamr@2: # include williamr@2: #endif williamr@2: williamr@2: //========================================================== williamr@2: // numeric_limits static members williamr@2: //========================================================== williamr@2: williamr@2: _STLP_BEGIN_NAMESPACE williamr@2: williamr@2: # if ! defined ( _STLP_STATIC_CONST_INIT_BUG) williamr@2: williamr@2: # define __declare_numeric_base_member(__type, __mem, _Init) \ williamr@2: template \ williamr@2: const __type _Numeric_limits_base<__number>:: __mem williamr@2: williamr@2: __declare_numeric_base_member(bool, is_specialized, false); williamr@2: __declare_numeric_base_member(int, digits, 0); williamr@2: __declare_numeric_base_member(int, digits10, 0); williamr@2: __declare_numeric_base_member(bool, is_signed, false); williamr@2: __declare_numeric_base_member(bool, is_integer, false); williamr@2: __declare_numeric_base_member(bool, is_exact, false); williamr@2: __declare_numeric_base_member(int, radix, 0); williamr@2: __declare_numeric_base_member(int, min_exponent, 0); williamr@2: __declare_numeric_base_member(int, max_exponent, 0); williamr@2: __declare_numeric_base_member(int, min_exponent10, 0); williamr@2: __declare_numeric_base_member(int, max_exponent10, 0); williamr@2: __declare_numeric_base_member(bool, has_infinity, false); williamr@2: __declare_numeric_base_member(bool, has_quiet_NaN, false); williamr@2: __declare_numeric_base_member(bool, has_signaling_NaN, false); williamr@2: __declare_numeric_base_member(float_denorm_style, has_denorm, denorm_absent); williamr@2: __declare_numeric_base_member(bool, has_denorm_loss, false); williamr@2: __declare_numeric_base_member(bool, is_iec559, false); williamr@2: __declare_numeric_base_member(bool, is_bounded, false); williamr@2: __declare_numeric_base_member(bool, is_modulo, false); williamr@2: __declare_numeric_base_member(bool, traps, false); williamr@2: __declare_numeric_base_member(bool, tinyness_before, false); williamr@2: __declare_numeric_base_member(float_round_style, round_style, round_toward_zero); williamr@2: williamr@2: # undef __declare_numeric_base_member williamr@2: williamr@2: # define __declare_integer_limits_member(__type, __mem, _Init) \ williamr@2: template \ williamr@2: const __type _Integer_limits<_Int, __imin, __imax, __idigits, __ismod>:: __mem williamr@2: williamr@2: __declare_integer_limits_member(bool, is_specialized, true); williamr@2: __declare_integer_limits_member(int, digits, (__idigits < 0) ? \ williamr@2: ((int)((sizeof(_Int) * (CHAR_BIT))) - ((__imin == 0) ? 0 : 1)) \ williamr@2: : (__idigits) ); williamr@2: __declare_integer_limits_member(int, digits10, (int)(301UL * digits) /1000); williamr@2: __declare_integer_limits_member(bool, is_signed, __imin != 0); williamr@2: __declare_integer_limits_member(bool, is_integer, true); williamr@2: __declare_integer_limits_member(bool, is_exact, true); williamr@2: __declare_integer_limits_member(int, radix, 2); williamr@2: __declare_integer_limits_member(bool, is_bounded, true); williamr@2: __declare_integer_limits_member(bool, is_modulo, true); williamr@2: williamr@2: # define __declare_float_limits_member(__type, __mem, _Init) \ williamr@2: template \ williamr@2: const __type _Floating_limits< __number, __Digits, __Digits10, \ williamr@2: __MinExp, __MaxExp, __MinExp10, __MaxExp10, \ williamr@2: __IsIEC559, __RoundStyle>::\ williamr@2: __mem williamr@2: williamr@2: __declare_float_limits_member(bool, is_specialized, true); williamr@2: __declare_float_limits_member(int, digits, __Digits); williamr@2: __declare_float_limits_member(int, digits10, __Digits10); williamr@2: __declare_float_limits_member(bool, is_signed, true); williamr@2: __declare_float_limits_member(int, radix, FLT_RADIX); williamr@2: __declare_float_limits_member(int, min_exponent, __MinExp); williamr@2: __declare_float_limits_member(int, max_exponent, __MaxExp); williamr@2: __declare_float_limits_member(int, min_exponent10, __MinExp10); williamr@2: __declare_float_limits_member(int, max_exponent10, __MaxExp10); williamr@2: __declare_float_limits_member(bool, has_infinity, true); williamr@2: __declare_float_limits_member(bool, has_quiet_NaN, true); williamr@2: __declare_float_limits_member(bool, has_signaling_NaN, true); williamr@2: __declare_float_limits_member(float_denorm_style, has_denorm, denorm_indeterminate); williamr@2: __declare_float_limits_member(bool, has_denorm_loss, false); williamr@2: __declare_float_limits_member(bool, is_iec559, __IsIEC559); williamr@2: __declare_float_limits_member(bool, is_bounded, true); williamr@2: __declare_float_limits_member(bool, traps, true); williamr@2: __declare_float_limits_member(bool, tinyness_before, false); williamr@2: __declare_float_limits_member(float_round_style, round_style, __RoundStyle); williamr@2: williamr@2: # endif /* _STLP_STATIC_CONST_INIT_BUG */ williamr@2: williamr@2: williamr@2: # ifdef _STLP_EXPOSE_GLOBALS_IMPLEMENTATION williamr@2: williamr@2: # if defined(_STLP_BIG_ENDIAN) williamr@2: # if defined(__OS400__) williamr@2: # define _STLP_FLOAT_INF_REP { 0x7f80, 0 } williamr@2: # define _STLP_FLOAT_QNAN_REP { 0xffc0, 0 } williamr@2: # define _STLP_FLOAT_SNAN_REP { 0xff80, 0 } williamr@2: # define _STLP_DOUBLE_INF_REP { 0x7ff0, 0, 0, 0 } williamr@2: # define _STLP_DOUBLE_QNAN_REP { 0xfff8, 0, 0, 0 } williamr@2: # define _STLP_DOUBLE_SNAN_REP { 0xfff0, 0, 0, 0 } williamr@2: # define _STLP_LDOUBLE_INF_REP { 0x7ff0, 0, 0, 0, 0, 0, 0, 0 } williamr@2: # define _STLP_LDOUBLE_QNAN_REP { 0xfff8, 0, 0, 0, 0, 0, 0, 0 } williamr@2: # define _STLP_LDOUBLE_SNAN_REP { 0xfff0, 0, 0, 0, 0, 0, 0, 0 } williamr@2: # else williamr@2: # define _STLP_FLOAT_INF_REP { 0x7f80, 0 } williamr@2: # define _STLP_FLOAT_SNAN_REP { 0x7f81, 0 } williamr@2: # define _STLP_FLOAT_QNAN_REP { 0x7fc1, 0 } williamr@2: # define _STLP_DOUBLE_INF_REP { 0x7ff0, 0, 0, 0 } williamr@2: # define _STLP_DOUBLE_QNAN_REP { 0x7ff1, 0, 0, 0 } williamr@2: # define _STLP_DOUBLE_SNAN_REP { 0x7ff9, 0, 0, 0 } williamr@2: # define _STLP_LDOUBLE_INF_REP { 0x7ff0, 0, 0, 0, 0, 0, 0, 0 } williamr@2: # define _STLP_LDOUBLE_SNAN_REP { 0x7ff1, 0, 0, 0, 0, 0, 0, 0 } williamr@2: # define _STLP_LDOUBLE_QNAN_REP { 0x7ff9, 0, 0, 0, 0, 0, 0, 0 } williamr@2: # endif williamr@2: williamr@2: # elif defined (_STLP_LITTLE_ENDIAN) williamr@2: williamr@2: # if 0 /* defined(_STLP_MSVC) || defined(__linux__) */ williamr@2: // some IA-32 platform ?? williamr@2: # define _STLP_FLOAT_INF_REP { 0, 0x7f80 } williamr@2: # define _STLP_FLOAT_QNAN_REP { 0, 0xffc0 } williamr@2: # define _STLP_FLOAT_SNAN_REP { 0, 0xff80 } williamr@2: williamr@2: # define _STLP_DOUBLE_INF_REP { 0, 0, 0, 0x7ff0 } williamr@2: # define _STLP_DOUBLE_QNAN_REP { 0, 0, 0, 0xfff8 } williamr@2: # define _STLP_DOUBLE_SNAN_REP { 0, 0, 0, 0xfff0 } williamr@2: # define _STLP_LDOUBLE_INF_REP { 0, 0, 0, 0x7FF0, 0 } // ???? williamr@2: # define _STLP_LDOUBLE_QNAN_REP { 0, 0, 0, 0xFFF8, 0 } // ???? williamr@2: # define _STLP_LDOUBLE_SNAN_REP { 0, 0, 0, 0xFFF0, 0 } // ???? williamr@2: williamr@2: # elif defined(__DECCXX) williamr@2: williamr@2: # define _STLP_FLOAT_INF_REP { 0, 0x7f80 } williamr@2: # define _STLP_FLOAT_QNAN_REP { 0, 0xffc0 } williamr@2: # define _STLP_FLOAT_SNAN_REP { 0x5555, 0x7f85 } williamr@2: williamr@2: # define _STLP_DOUBLE_INF_REP { 0, 0, 0, 0x7ff0 } williamr@2: # define _STLP_DOUBLE_QNAN_REP { 0, 0, 0, 0xfff8 } williamr@2: # define _STLP_DOUBLE_SNAN_REP { 0x5555, 0x5555, 0x5555, 0x7ff5 } williamr@2: williamr@2: # define _STLP_LDOUBLE_INF_REP { 0, 0, 0, 0, 0, 0, 0, 0x7fff } williamr@2: # define _STLP_LDOUBLE_QNAN_REP { 0, 0, 0, 0, 0, 0, 0x8000, 0xffff } williamr@2: # define _STLP_LDOUBLE_SNAN_REP { 0x5555, 0x5555, 0x5555, 0x5555, 0x5555, 0x5555, 0x5555, 0x7fff} williamr@2: # else williamr@2: # define _STLP_FLOAT_INF_REP { 0, 0x7f80 } williamr@2: # define _STLP_FLOAT_QNAN_REP { 0, 0x7fa0 } williamr@2: # define _STLP_FLOAT_SNAN_REP { 0, 0x7fc0 } williamr@2: # define _STLP_DOUBLE_INF_REP { 0, 0, 0, 0x7ff0 } williamr@2: # define _STLP_DOUBLE_QNAN_REP { 0, 0, 0, 0x7ff4 } williamr@2: # define _STLP_DOUBLE_SNAN_REP { 0, 0, 0, 0x7ff8 } williamr@2: # if defined (_STLP_MSVC) || defined (__ICL) || defined (__BORLANDC__) williamr@2: # define _STLP_LDOUBLE_INF_REP { 0, 0, 0, 0x7FF0, 0 } // ???? williamr@2: # define _STLP_LDOUBLE_QNAN_REP { 0, 0, 0, 0xFFF8, 0 } // ???? williamr@2: # define _STLP_LDOUBLE_SNAN_REP { 0, 0, 0, 0xFFF8, 0 } williamr@2: # else williamr@2: # define _STLP_LDOUBLE_INF_REP { 0, 0, 0, 0x8000, 0x7fff } williamr@2: # define _STLP_LDOUBLE_QNAN_REP { 0, 0, 0, 0xa000, 0x7fff } williamr@2: # define _STLP_LDOUBLE_SNAN_REP { 0, 0, 0, 0xc000, 0x7fff } williamr@2: # endif williamr@2: # endif williamr@2: #else williamr@2: /* This is an architecture we don't know how to handle. Return some williamr@2: obviously wrong values. */ williamr@2: # define _STLP_FLOAT_INF_REP { 0, 0 } williamr@2: # define _STLP_FLOAT_QNAN_REP { 0, 0 } williamr@2: # define _STLP_FLOAT_SNAN_REP { 0, 0 } williamr@2: # define _STLP_DOUBLE_INF_REP { 0, 0 } williamr@2: # define _STLP_DOUBLE_QNAN_REP { 0, 0 } williamr@2: # define _STLP_DOUBLE_SNAN_REP { 0, 0 } williamr@2: # define _STLP_LDOUBLE_INF_REP { 0 } williamr@2: # define _STLP_LDOUBLE_QNAN_REP { 0 } williamr@2: # define _STLP_LDOUBLE_SNAN_REP { 0 } williamr@2: williamr@2: #endif williamr@2: williamr@2: #if ( _STLP_STATIC_TEMPLATE_DATA > 0 ) williamr@2: # ifndef _STLP_NO_LONG_DOUBLE williamr@2: template williamr@2: const _L_rep _LimG<__dummy>::_L_inf = {_STLP_LDOUBLE_INF_REP}; williamr@2: template williamr@2: const _L_rep _LimG<__dummy>::_L_qNaN = {_STLP_LDOUBLE_QNAN_REP}; williamr@2: template williamr@2: const _L_rep _LimG<__dummy>::_L_sNaN = {_STLP_LDOUBLE_SNAN_REP}; williamr@2: # endif williamr@2: template williamr@2: const _D_rep _LimG<__dummy>::_D_inf = {_STLP_DOUBLE_INF_REP}; williamr@2: template williamr@2: const _D_rep _LimG<__dummy>::_D_qNaN = {_STLP_DOUBLE_QNAN_REP}; williamr@2: template williamr@2: const _D_rep _LimG<__dummy>::_D_sNaN = {_STLP_DOUBLE_SNAN_REP}; williamr@2: template williamr@2: const _F_rep _LimG<__dummy>::_F_inf = {_STLP_FLOAT_INF_REP}; williamr@2: template williamr@2: const _F_rep _LimG<__dummy>::_F_qNaN = {_STLP_FLOAT_QNAN_REP}; williamr@2: template williamr@2: const _F_rep _LimG<__dummy>::_F_sNaN = {_STLP_FLOAT_SNAN_REP}; williamr@2: williamr@2: #else williamr@2: williamr@2: __DECLARE_INSTANCE( const _F_rep, williamr@2: _LimG::_F_inf, = _STLP_FLOAT_INF_REP); williamr@2: __DECLARE_INSTANCE( const _F_rep, williamr@2: _LimG::_F_qNaN, = _STLP_FLOAT_QNAN_REP); williamr@2: __DECLARE_INSTANCE( const _F_rep, williamr@2: _LimG::_F_sNaN, = _STLP_FLOAT_SNAN_REP); williamr@2: __DECLARE_INSTANCE( const _D_rep, williamr@2: _LimG::_D_inf, = _STLP_DOUBLE_INF_REP); williamr@2: __DECLARE_INSTANCE( const _D_rep, williamr@2: _LimG::_D_qNaN, = _STLP_DOUBLE_QNAN_REP); williamr@2: __DECLARE_INSTANCE( const _D_rep, williamr@2: _LimG::_D_sNaN, = _STLP_DOUBLE_SNAN_REP); williamr@2: # ifndef _STLP_NO_LONG_DOUBLE williamr@2: __DECLARE_INSTANCE( const _L_rep, williamr@2: _LimG::_L_inf, = _STLP_LDOUBLE_INF_REP); williamr@2: __DECLARE_INSTANCE( const _L_rep, williamr@2: _LimG::_L_qNaN, = _STLP_LDOUBLE_QNAN_REP); williamr@2: __DECLARE_INSTANCE( const _L_rep, williamr@2: _LimG::_L_sNaN, = _STLP_LDOUBLE_SNAN_REP); williamr@2: # endif williamr@2: williamr@2: #endif /* STATIC_DATA */ williamr@2: williamr@2: # endif /* _STLP_EXPOSE_GLOBALS_IMPLEMENTATION */ williamr@2: williamr@2: # undef __declare_integer_limits_member williamr@2: # undef __declare_float_limits_member williamr@2: # undef __HACK_ILIMITS williamr@2: # undef __HACK_NOTHING williamr@2: # undef __declare_int_members williamr@2: # undef __declare_float_members williamr@2: # undef _STLP_LIMITS_MIN_TYPE williamr@2: # undef _STLP_LIMITS_MAX_TYPE williamr@2: williamr@2: # undef _STLP_FLOAT_INF_REP williamr@2: # undef _STLP_FLOAT_QNAN_REP williamr@2: # undef _STLP_FLOAT_SNAN_REP williamr@2: # undef _STLP_DOUBLE_INF_REP williamr@2: # undef _STLP_DOUBLE_QNAN_REP williamr@2: # undef _STLP_DOUBLE_SNAN_REP williamr@2: # undef _STLP_LDOUBLE_INF_REP williamr@2: # undef _STLP_LDOUBLE_QNAN_REP williamr@2: # undef _STLP_LDOUBLE_SNAN_REP williamr@2: williamr@2: _STLP_END_NAMESPACE williamr@2: williamr@2: williamr@2: #endif /* _STLP_LIMITS_C_INCLUDED */