epoc32/include/stdapis/stlportv5/stl/_limits.h
author William Roberts <williamr@symbian.org>
Wed, 31 Mar 2010 12:33:34 +0100
branchSymbian3
changeset 4 837f303aceeb
permissions -rw-r--r--
Current Symbian^3 public API header files (from PDK 3.0.h)
This is the epoc32/include tree with the "platform" subtrees removed, and
all but a selected few mbg and rsg files removed.
williamr@4
     1
/*
williamr@4
     2
 * Copyright (c) 1997
williamr@4
     3
 * Silicon Graphics Computer Systems, Inc.
williamr@4
     4
 *
williamr@4
     5
 * Copyright (c) 1999
williamr@4
     6
 * Boris Fomitchev
williamr@4
     7
 *
williamr@4
     8
 * This material is provided "as is", with absolutely no warranty expressed
williamr@4
     9
 * or implied. Any use is at your own risk.
williamr@4
    10
 *
williamr@4
    11
 * Permission to use or copy this software for any purpose is hereby granted
williamr@4
    12
 * without fee, provided the above notices are retained on all copies.
williamr@4
    13
 * Permission to modify the code and to distribute modified code is granted,
williamr@4
    14
 * provided the above notices are retained, and a notice that the code was
williamr@4
    15
 * modified is included with the above copyright notice.
williamr@4
    16
 *
williamr@4
    17
 */
williamr@4
    18
williamr@4
    19
/* NOTE: This may be not portable code. Parts of numeric_limits<> are
williamr@4
    20
 * inherently machine-dependent.  At present this file is suitable
williamr@4
    21
 * for the MIPS, SPARC, Alpha and ia32 architectures.
williamr@4
    22
 */
williamr@4
    23
williamr@4
    24
#ifndef _STLP_INTERNAL_LIMITS
williamr@4
    25
#define _STLP_INTERNAL_LIMITS
williamr@4
    26
williamr@4
    27
#ifndef _STLP_CLIMITS
williamr@4
    28
#  include <climits>
williamr@4
    29
#endif
williamr@4
    30
williamr@4
    31
#ifndef _STLP_CFLOAT
williamr@4
    32
#  include <cfloat>
williamr@4
    33
#endif
williamr@4
    34
williamr@4
    35
#if defined (_STLP_HAS_WCHAR_T) && !defined (_STLP_INTERNAL_CWCHAR)
williamr@4
    36
#  include <stl/_cwchar.h>
williamr@4
    37
#endif
williamr@4
    38
williamr@4
    39
_STLP_BEGIN_NAMESPACE
williamr@4
    40
williamr@4
    41
enum float_round_style {
williamr@4
    42
  round_indeterminate       = -1,
williamr@4
    43
  round_toward_zero         =  0,
williamr@4
    44
  round_to_nearest          =  1,
williamr@4
    45
  round_toward_infinity     =  2,
williamr@4
    46
  round_toward_neg_infinity =  3
williamr@4
    47
};
williamr@4
    48
williamr@4
    49
enum float_denorm_style {
williamr@4
    50
  denorm_indeterminate = -1,
williamr@4
    51
  denorm_absent        =  0,
williamr@4
    52
  denorm_present       =  1
williamr@4
    53
};
williamr@4
    54
williamr@4
    55
_STLP_MOVE_TO_PRIV_NAMESPACE
williamr@4
    56
williamr@4
    57
// Base class for all specializations of numeric_limits.
williamr@4
    58
template <class __number>
williamr@4
    59
class _Numeric_limits_base {
williamr@4
    60
public:
williamr@4
    61
williamr@4
    62
  static __number (_STLP_CALL min)() _STLP_NOTHROW { return __number(); }
williamr@4
    63
  static __number (_STLP_CALL max)() _STLP_NOTHROW { return __number(); }
williamr@4
    64
williamr@4
    65
#if defined ( _STLP_STATIC_CONST_INIT_BUG)
williamr@4
    66
  enum {
williamr@4
    67
#else
williamr@4
    68
  static const int
williamr@4
    69
#endif
williamr@4
    70
williamr@4
    71
  digits = 0,
williamr@4
    72
  digits10 = 0,
williamr@4
    73
  radix = 0,
williamr@4
    74
  min_exponent = 0,
williamr@4
    75
  min_exponent10 = 0,
williamr@4
    76
  max_exponent = 0,
williamr@4
    77
  max_exponent10 = 0
williamr@4
    78
williamr@4
    79
#if defined ( _STLP_STATIC_CONST_INIT_BUG)
williamr@4
    80
  ,
williamr@4
    81
  has_denorm = denorm_absent,
williamr@4
    82
  round_style = round_toward_zero,
williamr@4
    83
#else
williamr@4
    84
  ;
williamr@4
    85
  static const float_denorm_style has_denorm =  denorm_absent;
williamr@4
    86
  static const float_round_style round_style = round_toward_zero;
williamr@4
    87
  static const bool
williamr@4
    88
#endif
williamr@4
    89
williamr@4
    90
    is_specialized = false,
williamr@4
    91
    is_signed  = false,
williamr@4
    92
    is_integer = false,
williamr@4
    93
    is_exact = false,
williamr@4
    94
    has_infinity = false,
williamr@4
    95
    has_quiet_NaN = false,
williamr@4
    96
    has_signaling_NaN = false,
williamr@4
    97
    has_denorm_loss = false,
williamr@4
    98
    is_iec559 = false,
williamr@4
    99
    is_bounded = false,
williamr@4
   100
    is_modulo = false,
williamr@4
   101
    traps = false,
williamr@4
   102
    tinyness_before = false
williamr@4
   103
#if defined ( _STLP_STATIC_CONST_INIT_BUG)
williamr@4
   104
  }
williamr@4
   105
#endif
williamr@4
   106
  ;
williamr@4
   107
williamr@4
   108
  static __number _STLP_CALL epsilon() _STLP_NOTHROW     { return __number(); }
williamr@4
   109
  static __number _STLP_CALL round_error() _STLP_NOTHROW { return __number(); }
williamr@4
   110
williamr@4
   111
  static __number _STLP_CALL infinity() _STLP_NOTHROW      { return __number(); }
williamr@4
   112
  static __number _STLP_CALL quiet_NaN() _STLP_NOTHROW     { return __number(); }
williamr@4
   113
  static __number _STLP_CALL signaling_NaN() _STLP_NOTHROW { return __number(); }
williamr@4
   114
  static __number _STLP_CALL denorm_min() _STLP_NOTHROW    { return __number(); }
williamr@4
   115
};
williamr@4
   116
williamr@4
   117
// Base class for integers.
williamr@4
   118
williamr@4
   119
#ifdef _STLP_LIMITED_DEFAULT_TEMPLATES
williamr@4
   120
#  ifdef _STLP_LONG_LONG
williamr@4
   121
#    define _STLP_LIMITS_MIN_TYPE _STLP_LONG_LONG
williamr@4
   122
#    define _STLP_LIMITS_MAX_TYPE unsigned _STLP_LONG_LONG
williamr@4
   123
#  else
williamr@4
   124
#    define _STLP_LIMITS_MIN_TYPE long
williamr@4
   125
#    define _STLP_LIMITS_MAX_TYPE unsigned long
williamr@4
   126
#  endif
williamr@4
   127
#else
williamr@4
   128
#  define _STLP_LIMITS_MIN_TYPE _Int
williamr@4
   129
#  define _STLP_LIMITS_MAX_TYPE _Int
williamr@4
   130
#endif /* _STLP_LIMITED_DEFAULT_TEMPLATES */
williamr@4
   131
williamr@4
   132
template <class _Int,
williamr@4
   133
          _STLP_LIMITS_MIN_TYPE __imin,
williamr@4
   134
          _STLP_LIMITS_MAX_TYPE __imax,
williamr@4
   135
          int __idigits, bool __ismod>
williamr@4
   136
class _Integer_limits : public _Numeric_limits_base<_Int> {
williamr@4
   137
public:
williamr@4
   138
williamr@4
   139
  static _Int (_STLP_CALL min) () _STLP_NOTHROW { return (_Int)__imin; }
williamr@4
   140
  static _Int (_STLP_CALL max) () _STLP_NOTHROW { return (_Int)__imax; }
williamr@4
   141
williamr@4
   142
#if defined (_STLP_STATIC_CONST_INIT_BUG)
williamr@4
   143
  enum {
williamr@4
   144
#else
williamr@4
   145
  static const int
williamr@4
   146
#endif
williamr@4
   147
  digits = (__idigits < 0) ?
williamr@4
   148
  ((int)((sizeof(_Int) * (CHAR_BIT))) - ((__imin == 0) ? 0 : 1))
williamr@4
   149
  : (__idigits),
williamr@4
   150
  digits10 = (digits * 301UL) / 1000,
williamr@4
   151
  radix = 2
williamr@4
   152
#if !defined (_STLP_STATIC_CONST_INIT_BUG)
williamr@4
   153
  ;
williamr@4
   154
  static const bool
williamr@4
   155
#else
williamr@4
   156
  ,
williamr@4
   157
#endif
williamr@4
   158
  is_specialized = true,
williamr@4
   159
  is_signed = (__imin != 0),
williamr@4
   160
  is_integer = true,
williamr@4
   161
  is_exact = true,
williamr@4
   162
  is_bounded = true,
williamr@4
   163
  is_modulo = __ismod
williamr@4
   164
#if defined ( _STLP_STATIC_CONST_INIT_BUG)
williamr@4
   165
  }
williamr@4
   166
#endif
williamr@4
   167
  ;
williamr@4
   168
};
williamr@4
   169
williamr@4
   170
// Base class for floating-point numbers.
williamr@4
   171
template <class __number,
williamr@4
   172
         int __Digits, int __Digits10,
williamr@4
   173
         int __MinExp, int __MaxExp,
williamr@4
   174
         int __MinExp10, int __MaxExp10,
williamr@4
   175
         bool __IsIEC559,
williamr@4
   176
         float_round_style __RoundStyle>
williamr@4
   177
class _Floating_limits : public _Numeric_limits_base<__number> {
williamr@4
   178
public:
williamr@4
   179
williamr@4
   180
#if defined (_STLP_STATIC_CONST_INIT_BUG)
williamr@4
   181
  enum {
williamr@4
   182
#else
williamr@4
   183
  static const int
williamr@4
   184
#endif
williamr@4
   185
williamr@4
   186
  digits = __Digits,
williamr@4
   187
  digits10 = __Digits10,
williamr@4
   188
williamr@4
   189
  radix = (  FLT_RADIX /* 2 */ ),
williamr@4
   190
  min_exponent = __MinExp,
williamr@4
   191
  max_exponent = __MaxExp,
williamr@4
   192
  min_exponent10 = __MinExp10,
williamr@4
   193
  max_exponent10 = __MaxExp10
williamr@4
   194
williamr@4
   195
#if defined (_STLP_STATIC_CONST_INIT_BUG)
williamr@4
   196
  ,
williamr@4
   197
  has_denorm = denorm_indeterminate,
williamr@4
   198
  round_style = __RoundStyle,
williamr@4
   199
#else
williamr@4
   200
  ;
williamr@4
   201
  static const float_denorm_style has_denorm = denorm_indeterminate;
williamr@4
   202
  static const float_round_style round_style = __RoundStyle;
williamr@4
   203
  static const bool
williamr@4
   204
#endif
williamr@4
   205
williamr@4
   206
  is_specialized = true,
williamr@4
   207
  is_signed = true,
williamr@4
   208
williamr@4
   209
  //IEC 559 specify the floating point representation of
williamr@4
   210
  //infinity, quiet and signaling Not a Number. Not supporting
williamr@4
   211
  //it is consider as not being able to grant those values.
williamr@4
   212
#if (defined (_STLP_MSVC) && (_STLP_MSVC < 1300))
williamr@4
   213
  //MSVC 6 do not fully support IEC 599 but grant a good infinity value.
williamr@4
   214
  has_infinity      = true,
williamr@4
   215
#else
williamr@4
   216
  has_infinity      = __IsIEC559,
williamr@4
   217
#endif
williamr@4
   218
  has_quiet_NaN     = __IsIEC559,
williamr@4
   219
  has_signaling_NaN = __IsIEC559,
williamr@4
   220
williamr@4
   221
  has_denorm_loss   =  false,
williamr@4
   222
  is_iec559      =  __IsIEC559,
williamr@4
   223
  is_bounded     =  true,
williamr@4
   224
  traps          =  true,
williamr@4
   225
  tinyness_before=  false
williamr@4
   226
williamr@4
   227
#if defined (_STLP_STATIC_CONST_INIT_BUG)
williamr@4
   228
  }
williamr@4
   229
#endif
williamr@4
   230
  ;
williamr@4
   231
};
williamr@4
   232
williamr@4
   233
_STLP_MOVE_TO_STD_NAMESPACE
williamr@4
   234
williamr@4
   235
// Class numeric_limits
williamr@4
   236
williamr@4
   237
// The unspecialized class.
williamr@4
   238
williamr@4
   239
template<class _Tp>
williamr@4
   240
class numeric_limits : public _STLP_PRIV _Numeric_limits_base<_Tp> {};
williamr@4
   241
williamr@4
   242
// Specializations for all built-in integral types.
williamr@4
   243
williamr@4
   244
#if !defined (_STLP_NO_BOOL)
williamr@4
   245
_STLP_TEMPLATE_NULL
williamr@4
   246
class numeric_limits<bool>
williamr@4
   247
  : public _STLP_PRIV _Integer_limits<bool, false, true, 1, false>
williamr@4
   248
{};
williamr@4
   249
#endif /* _STLP_NO_BOOL */
williamr@4
   250
williamr@4
   251
_STLP_TEMPLATE_NULL
williamr@4
   252
class numeric_limits<char>
williamr@4
   253
  : public _STLP_PRIV _Integer_limits<char, CHAR_MIN, CHAR_MAX, -1, true>
williamr@4
   254
{};
williamr@4
   255
williamr@4
   256
#if !defined (_STLP_NO_SIGNED_BUILTINS)
williamr@4
   257
_STLP_TEMPLATE_NULL
williamr@4
   258
class numeric_limits<signed char>
williamr@4
   259
  : public _STLP_PRIV _Integer_limits<signed char, SCHAR_MIN, SCHAR_MAX, -1, true>
williamr@4
   260
{};
williamr@4
   261
#endif
williamr@4
   262
williamr@4
   263
_STLP_TEMPLATE_NULL
williamr@4
   264
class numeric_limits<unsigned char>
williamr@4
   265
  : public _STLP_PRIV _Integer_limits<unsigned char, 0, UCHAR_MAX, -1, true>
williamr@4
   266
{};
williamr@4
   267
williamr@4
   268
#if !(defined (_STLP_NO_WCHAR_T) || defined (_STLP_WCHAR_T_IS_USHORT))
williamr@4
   269
williamr@4
   270
_STLP_TEMPLATE_NULL
williamr@4
   271
class numeric_limits<wchar_t>
williamr@4
   272
  : public _STLP_PRIV _Integer_limits<wchar_t, WCHAR_MIN, WCHAR_MAX, -1, true>
williamr@4
   273
{};
williamr@4
   274
williamr@4
   275
#endif
williamr@4
   276
williamr@4
   277
_STLP_TEMPLATE_NULL
williamr@4
   278
class numeric_limits<short>
williamr@4
   279
  : public _STLP_PRIV _Integer_limits<short, SHRT_MIN, SHRT_MAX, -1, true>
williamr@4
   280
{};
williamr@4
   281
williamr@4
   282
_STLP_TEMPLATE_NULL
williamr@4
   283
class numeric_limits<unsigned short>
williamr@4
   284
  : public _STLP_PRIV _Integer_limits<unsigned short, 0, USHRT_MAX, -1, true>
williamr@4
   285
{};
williamr@4
   286
williamr@4
   287
#if defined (__xlC__) && (__xlC__ == 0x500)
williamr@4
   288
#  undef INT_MIN
williamr@4
   289
#  define INT_MIN -2147483648
williamr@4
   290
#endif
williamr@4
   291
williamr@4
   292
_STLP_TEMPLATE_NULL
williamr@4
   293
class numeric_limits<int>
williamr@4
   294
  : public _STLP_PRIV _Integer_limits<int, INT_MIN, INT_MAX, -1, true>
williamr@4
   295
{};
williamr@4
   296
williamr@4
   297
_STLP_TEMPLATE_NULL
williamr@4
   298
class numeric_limits<unsigned int>
williamr@4
   299
  : public _STLP_PRIV _Integer_limits<unsigned int, 0, UINT_MAX, -1, true>
williamr@4
   300
{};
williamr@4
   301
williamr@4
   302
_STLP_TEMPLATE_NULL
williamr@4
   303
class numeric_limits<long>
williamr@4
   304
  : public _STLP_PRIV _Integer_limits<long, LONG_MIN, LONG_MAX, -1, true>
williamr@4
   305
{};
williamr@4
   306
williamr@4
   307
_STLP_TEMPLATE_NULL
williamr@4
   308
class numeric_limits<unsigned long>
williamr@4
   309
  : public _STLP_PRIV _Integer_limits<unsigned long, 0, ULONG_MAX, -1, true>
williamr@4
   310
{};
williamr@4
   311
williamr@4
   312
#if defined (_STLP_LONG_LONG)
williamr@4
   313
williamr@4
   314
#  if defined (_STLP_MSVC) || defined (__BORLANDC__)
williamr@4
   315
#    define LONGLONG_MAX     0x7fffffffffffffffi64
williamr@4
   316
#    define LONGLONG_MIN     (-LONGLONG_MAX-1i64)
williamr@4
   317
#    define ULONGLONG_MAX    0xffffffffffffffffUi64
williamr@4
   318
#  else
williamr@4
   319
#    ifndef LONGLONG_MAX
williamr@4
   320
#      define LONGLONG_MAX   0x7fffffffffffffffLL
williamr@4
   321
#    endif
williamr@4
   322
#    ifndef LONGLONG_MIN
williamr@4
   323
#      define LONGLONG_MIN   (-LONGLONG_MAX-1LL)
williamr@4
   324
#    endif
williamr@4
   325
#    ifndef ULONGLONG_MAX
williamr@4
   326
#      define ULONGLONG_MAX  0xffffffffffffffffULL
williamr@4
   327
#    endif
williamr@4
   328
#  endif
williamr@4
   329
williamr@4
   330
#  if !defined(__GNUC__) || (__GNUC__ == 2 && __GNUC_MINOR__ <= 96)
williamr@4
   331
williamr@4
   332
_STLP_TEMPLATE_NULL
williamr@4
   333
class numeric_limits<_STLP_LONG_LONG>
williamr@4
   334
  : public _STLP_PRIV _Integer_limits<_STLP_LONG_LONG, LONGLONG_MIN, LONGLONG_MAX, -1, true>
williamr@4
   335
{};
williamr@4
   336
williamr@4
   337
_STLP_TEMPLATE_NULL
williamr@4
   338
class numeric_limits<unsigned _STLP_LONG_LONG>
williamr@4
   339
  : public _STLP_PRIV _Integer_limits<unsigned _STLP_LONG_LONG, 0, ULONGLONG_MAX, -1, true>
williamr@4
   340
{};
williamr@4
   341
#  else /* gcc 2.97 (after 2000-11-01), 2.98, 3.0 */
williamr@4
   342
/*
williamr@4
   343
 newest gcc has new mangling scheme, that has problem
williamr@4
   344
 with generating name [instantiated] of template specialization like
williamr@4
   345
 _Integer_limits<_STLP_LONG_LONG, LONGLONG_MIN, LONGLONG_MAX, -1, true>
williamr@4
   346
                                  ~~~~~~~~~~~~  ~~~~~~~~~~~~
williamr@4
   347
 Below is code that solve this problem.
williamr@4
   348
   - ptr
williamr@4
   349
 */
williamr@4
   350
_STLP_TEMPLATE_NULL
williamr@4
   351
class numeric_limits<_STLP_LONG_LONG>
williamr@4
   352
  : public _STLP_PRIV _Numeric_limits_base<_STLP_LONG_LONG> {
williamr@4
   353
public:
williamr@4
   354
williamr@4
   355
  static _STLP_LONG_LONG (_STLP_CALL min) () _STLP_NOTHROW { return LONGLONG_MIN; }
williamr@4
   356
  static _STLP_LONG_LONG (_STLP_CALL max) () _STLP_NOTHROW { return LONGLONG_MAX; }
williamr@4
   357
williamr@4
   358
#    if defined ( _STLP_STATIC_CONST_INIT_BUG)
williamr@4
   359
  enum {
williamr@4
   360
#    else
williamr@4
   361
  static const int
williamr@4
   362
#    endif
williamr@4
   363
  digits = ((int)((sizeof(_STLP_LONG_LONG) * (CHAR_BIT))) - 1),
williamr@4
   364
  digits10 = (digits * 301UL) / 1000,
williamr@4
   365
  radix = 2
williamr@4
   366
#    if ! defined (_STLP_STATIC_CONST_INIT_BUG)
williamr@4
   367
  ;
williamr@4
   368
  static const bool
williamr@4
   369
#    else
williamr@4
   370
  ,
williamr@4
   371
#    endif
williamr@4
   372
  is_specialized = true,
williamr@4
   373
  is_signed = true,
williamr@4
   374
  is_integer = true,
williamr@4
   375
  is_exact = true,
williamr@4
   376
  is_bounded = true,
williamr@4
   377
  is_modulo = true
williamr@4
   378
#    if defined (_STLP_STATIC_CONST_INIT_BUG)
williamr@4
   379
  }
williamr@4
   380
#    endif
williamr@4
   381
  ;
williamr@4
   382
};
williamr@4
   383
williamr@4
   384
_STLP_TEMPLATE_NULL
williamr@4
   385
class numeric_limits<unsigned _STLP_LONG_LONG>
williamr@4
   386
  : public _STLP_PRIV _Numeric_limits_base<unsigned _STLP_LONG_LONG> {
williamr@4
   387
public:
williamr@4
   388
williamr@4
   389
  static unsigned _STLP_LONG_LONG (_STLP_CALL min) () _STLP_NOTHROW { return 0ULL; }
williamr@4
   390
  static unsigned _STLP_LONG_LONG (_STLP_CALL max) () _STLP_NOTHROW { return ULONGLONG_MAX; }
williamr@4
   391
williamr@4
   392
#    if defined (_STLP_STATIC_CONST_INIT_BUG)
williamr@4
   393
  enum {
williamr@4
   394
#    else
williamr@4
   395
  static const int
williamr@4
   396
#    endif
williamr@4
   397
  digits = ((int)((sizeof(unsigned _STLP_LONG_LONG) * (CHAR_BIT)))),
williamr@4
   398
  digits10 = (digits * 301UL) / 1000,
williamr@4
   399
  radix = 2
williamr@4
   400
#    if ! defined (_STLP_STATIC_CONST_INIT_BUG)
williamr@4
   401
  ;
williamr@4
   402
  static const bool
williamr@4
   403
#    else
williamr@4
   404
  ,
williamr@4
   405
#    endif
williamr@4
   406
  is_specialized = true,
williamr@4
   407
  is_signed = false,
williamr@4
   408
  is_integer = true,
williamr@4
   409
  is_exact = true,
williamr@4
   410
  is_bounded = true,
williamr@4
   411
  is_modulo = true
williamr@4
   412
#    if defined ( _STLP_STATIC_CONST_INIT_BUG)
williamr@4
   413
  }
williamr@4
   414
#    endif
williamr@4
   415
  ;
williamr@4
   416
};
williamr@4
   417
williamr@4
   418
#  endif /* __GNUC__ > 2000-11-01 */
williamr@4
   419
williamr@4
   420
#endif /* _STLP_LONG_LONG */
williamr@4
   421
williamr@4
   422
_STLP_MOVE_TO_PRIV_NAMESPACE
williamr@4
   423
williamr@4
   424
// Specializations for all built-in floating-point types.
williamr@4
   425
template <class __dummy>
williamr@4
   426
class _LimG {
williamr@4
   427
public:
williamr@4
   428
  static float _STLP_CALL get_F_inf();
williamr@4
   429
  static float _STLP_CALL get_F_qNaN();
williamr@4
   430
  static float _STLP_CALL get_F_sNaN();
williamr@4
   431
  static double _STLP_CALL get_D_inf();
williamr@4
   432
  static double _STLP_CALL get_D_qNaN();
williamr@4
   433
  static double _STLP_CALL get_D_sNaN();
williamr@4
   434
williamr@4
   435
#if !defined (_STLP_NO_LONG_DOUBLE)
williamr@4
   436
  static long double _STLP_CALL get_LD_inf();
williamr@4
   437
  static long double _STLP_CALL get_LD_qNaN();
williamr@4
   438
  static long double _STLP_CALL get_LD_sNaN();
williamr@4
   439
#endif
williamr@4
   440
};
williamr@4
   441
williamr@4
   442
#if defined (_STLP_USE_TEMPLATE_EXPORT)
williamr@4
   443
_STLP_EXPORT_TEMPLATE_CLASS _LimG<bool>;
williamr@4
   444
#endif
williamr@4
   445
williamr@4
   446
_STLP_MOVE_TO_STD_NAMESPACE
williamr@4
   447
williamr@4
   448
_STLP_TEMPLATE_NULL
williamr@4
   449
class numeric_limits<float>
williamr@4
   450
  : public _STLP_PRIV _Floating_limits<float,
williamr@4
   451
                                        FLT_MANT_DIG,   // Binary digits of precision
williamr@4
   452
                                        FLT_DIG,        // Decimal digits of precision
williamr@4
   453
                                        FLT_MIN_EXP,    // Minimum exponent
williamr@4
   454
                                        FLT_MAX_EXP,    // Maximum exponent
williamr@4
   455
                                        FLT_MIN_10_EXP, // Minimum base 10 exponent
williamr@4
   456
                                        FLT_MAX_10_EXP, // Maximum base 10 exponent
williamr@4
   457
#if defined (_STLP_NO_IEC559_SUPPORT)
williamr@4
   458
                                        false,          // do not conform to iec559
williamr@4
   459
#else
williamr@4
   460
                                        true,           // conforms to iec559
williamr@4
   461
#endif
williamr@4
   462
                                        round_to_nearest> {
williamr@4
   463
public:
williamr@4
   464
  static float (_STLP_CALL min) () _STLP_NOTHROW { return FLT_MIN; }
williamr@4
   465
  static float _STLP_CALL denorm_min() _STLP_NOTHROW { return FLT_MIN; }
williamr@4
   466
  static float (_STLP_CALL max) () _STLP_NOTHROW { _STLP_USING_VENDOR_CSTD return FLT_MAX; }
williamr@4
   467
  static float _STLP_CALL epsilon() _STLP_NOTHROW { return FLT_EPSILON; }
williamr@4
   468
  static float _STLP_CALL round_error() _STLP_NOTHROW { return 0.5f; } // Units: ulps.
williamr@4
   469
  static  float _STLP_CALL infinity() _STLP_NOTHROW { return _STLP_PRIV _LimG<bool>::get_F_inf(); }
williamr@4
   470
  static  float _STLP_CALL quiet_NaN() _STLP_NOTHROW { return _STLP_PRIV _LimG<bool>::get_F_qNaN(); }
williamr@4
   471
  static  float _STLP_CALL signaling_NaN() _STLP_NOTHROW { return _STLP_PRIV _LimG<bool>::get_F_sNaN(); }
williamr@4
   472
};
williamr@4
   473
williamr@4
   474
_STLP_TEMPLATE_NULL
williamr@4
   475
class numeric_limits<double>
williamr@4
   476
  : public _STLP_PRIV _Floating_limits<double,
williamr@4
   477
                                        DBL_MANT_DIG,   // Binary digits of precision
williamr@4
   478
                                        DBL_DIG,        // Decimal digits of precision
williamr@4
   479
                                        DBL_MIN_EXP,    // Minimum exponent
williamr@4
   480
                                        DBL_MAX_EXP,    // Maximum exponent
williamr@4
   481
                                        DBL_MIN_10_EXP, // Minimum base 10 exponent
williamr@4
   482
                                        DBL_MAX_10_EXP, // Maximum base 10 exponent
williamr@4
   483
#if defined (_STLP_NO_IEC559_SUPPORT)
williamr@4
   484
                                        false,          // do not conform to iec559
williamr@4
   485
#else
williamr@4
   486
                                        true,           // conforms to iec559
williamr@4
   487
#endif
williamr@4
   488
                                        round_to_nearest> {
williamr@4
   489
public:
williamr@4
   490
  static double (_STLP_CALL min)() _STLP_NOTHROW { return DBL_MIN; }
williamr@4
   491
  static double _STLP_CALL denorm_min() _STLP_NOTHROW { return DBL_MIN; }
williamr@4
   492
  static double (_STLP_CALL max)() _STLP_NOTHROW { _STLP_USING_VENDOR_CSTD return DBL_MAX; }
williamr@4
   493
  static double _STLP_CALL epsilon() _STLP_NOTHROW { return DBL_EPSILON; }
williamr@4
   494
  static double _STLP_CALL round_error() _STLP_NOTHROW { return 0.5; } // Units: ulps.
williamr@4
   495
  static  double _STLP_CALL infinity() _STLP_NOTHROW { return _STLP_PRIV _LimG<bool>::get_D_inf(); }
williamr@4
   496
  static  double _STLP_CALL quiet_NaN() _STLP_NOTHROW { return _STLP_PRIV _LimG<bool>::get_D_qNaN(); }
williamr@4
   497
  static  double _STLP_CALL signaling_NaN() _STLP_NOTHROW { return _STLP_PRIV _LimG<bool>::get_D_sNaN(); }
williamr@4
   498
};
williamr@4
   499
williamr@4
   500
#if !defined (_STLP_NO_LONG_DOUBLE)
williamr@4
   501
williamr@4
   502
_STLP_TEMPLATE_NULL
williamr@4
   503
class numeric_limits<long double>
williamr@4
   504
  : public _STLP_PRIV _Floating_limits<long double,
williamr@4
   505
                                        LDBL_MANT_DIG,  // Binary digits of precision
williamr@4
   506
                                        LDBL_DIG,       // Decimal digits of precision
williamr@4
   507
                                        LDBL_MIN_EXP,   // Minimum exponent
williamr@4
   508
                                        LDBL_MAX_EXP,   // Maximum exponent
williamr@4
   509
                                        LDBL_MIN_10_EXP,// Minimum base 10 exponent
williamr@4
   510
                                        LDBL_MAX_10_EXP,// Maximum base 10 exponent
williamr@4
   511
                                        false,          // do not conform to iec559
williamr@4
   512
                                        round_to_nearest> {
williamr@4
   513
public:
williamr@4
   514
  static long double (_STLP_CALL min) () _STLP_NOTHROW { _STLP_USING_VENDOR_CSTD return LDBL_MIN; }
williamr@4
   515
  static long double _STLP_CALL denorm_min() _STLP_NOTHROW { _STLP_USING_VENDOR_CSTD return LDBL_MIN; }
williamr@4
   516
  static long double (_STLP_CALL max) () _STLP_NOTHROW { _STLP_USING_VENDOR_CSTD return LDBL_MAX; }
williamr@4
   517
  static long double _STLP_CALL epsilon() _STLP_NOTHROW { return LDBL_EPSILON; }
williamr@4
   518
  static long double _STLP_CALL round_error() _STLP_NOTHROW { return 4; } // Units: ulps.
williamr@4
   519
  static long double _STLP_CALL infinity() _STLP_NOTHROW { return _STLP_PRIV _LimG<bool>::get_LD_inf(); }
williamr@4
   520
  static long double _STLP_CALL quiet_NaN() _STLP_NOTHROW { return _STLP_PRIV _LimG<bool>::get_LD_qNaN(); }
williamr@4
   521
  static long double _STLP_CALL signaling_NaN() _STLP_NOTHROW { return _STLP_PRIV _LimG<bool>::get_LD_sNaN(); }
williamr@4
   522
};
williamr@4
   523
williamr@4
   524
#endif
williamr@4
   525
williamr@4
   526
// We write special values (Inf and NaN) as bit patterns and
williamr@4
   527
// cast the the appropriate floating-point types.
williamr@4
   528
_STLP_END_NAMESPACE
williamr@4
   529
williamr@4
   530
#if !defined (_STLP_LINK_TIME_INSTANTIATION)
williamr@4
   531
#  include <stl/_limits.c>
williamr@4
   532
#endif
williamr@4
   533
williamr@4
   534
#endif
williamr@4
   535
williamr@4
   536
// Local Variables:
williamr@4
   537
// mode:C++
williamr@4
   538
// End: