almost all recent changes to libc++ and libcxxrt. MFC r256642: Since C++ typeinfo objects are currently not guaranteed to be merged at runtime by the dynamic linker, check for their equality in libcxxrt by not only comparing the typeinfo's name pointers, but also comparing the full names, if necessary. (This is similar to what GNU libstdc++ does in its default configuration.) The 'deep' check can be turned off again by defining LIBCXXRT_MERGED_TYPEINFO, and recompiling libcxxrt. Reviewed by: theraven MFC r270522 (by rdivacky): The standard we compile libc++ with is called c++11 not c++0x. MFC r273066 (by bapt): Import patch from libc++ r197313 which allows using libc++ headers with gcc Differential Revision: https://reviews.freebsd.org/D942 Reviewed by: imp MFC r273381 (by bapt): Add support for __cxa_throw_bad_array_new_length in libcxxrt It is required for use with newer g++49 Differential Revision: https://reviews.freebsd.org/D982 Reviewed by: theraven Approved by: theraven MFC r273382 (by bapt): Fix build by marking the new functions as weak This is a temporary fix MFC r273407 (by bapt): When using an external gcc 4.8+ and not building libstdc++ then create in the objectdir a fake libstdc++.so and libstdc++.a which is a symlink on libc++ that allow g++ to satisfy its links dependencies in the least hackish way. Please note that this hacky libstds++ never get installed on the final system Reviewed by: imp MFC r273434 (by bapt): Do not define bad_array_new_length::bad_array_new_length in libc++ anymore when used in combinaison with libcxxrt since it is now defined there already. This fixes building world MFC r276417: Import libcxxrt master 00bc29eb6513624824a6d7db2ebc768a4216a604. Interesting fixes: 76584a0 Reorganize code to use only 32bit atomic ops for 32bit platforms 30d2ae5 Implement __cxa_throw_bad_array_new_length Reviewed by: bapt Differential Revision: https://reviews.freebsd.org/D1390 MFC r277217: Import libc++ trunk r224926. This fixes a number of bugs, completes C++14 support[1], adds more C++1z features[2], and fixes the following LWG issues[3]: 1450: Contradiction in regex_constants 2003: String exception inconsistency in erase. 2075: Progress guarantees, lock-free property, and scheduling assumptions 2104: unique_lock move-assignment should not be noexcept 2112: User-defined classes that cannot be derived from 2132: std::function ambiguity 2135: Unclear requirement for exceptions thrown in condition_variable::wait() 2142: packaged_task::operator() synchronization too broad? 2182: Container::[const_]reference types are misleadingly specified 2186: Incomplete action on async/launch::deferred 2188: Reverse iterator does not fully support targets that overload operator& 2193: Default constructors for standard library containers are explicit 2205: Problematic postconditions of regex_match and regex_search 2213: Return value of std::regex_replace 2240: Probable misuse of term "function scope" in [thread.condition] 2252: Strong guarantee on vector::push_back() still broken with C++11? 2257: Simplify container requirements with the new algorithms 2258: a.erase(q1, q2) unable to directly return q2 2263: Comparing iterators and allocator pointers with different const-character 2268: Setting a default argument in the declaration of a member function assign of std::basic_string 2271: regex_traits::lookup_classname specification unclear 2272: quoted should use char_traits::eq for character comparison 2278: User-defined literals for Standard Library types 2280: begin / end for arrays should be constexpr and noexcept 2285: make_reverse_iterator 2288: Inconsistent requirements for shared mutexes 2291: std::hash is vulnerable to collision DoS attack 2293: Wrong facet used by num_put::do_put 2299: Effects of inaccessible key_compare::is_transparent type are not clear 2301: Why is std::tie not constexpr? 2304: Complexity of count in unordered associative containers 2306: match_results::reference should be value_type&, not const value_type& 2308: Clarify container destructor requirements w.r.t. std::array 2313: tuple_size should always derive from integral_constant<size_t, N> 2314: apply() should return decltype(auto) and use decay_t before tuple_size 2315: weak_ptr should be movable 2316: weak_ptr::lock() should be atomic 2317: The type property queries should be UnaryTypeTraits returning size_t 2320: select_on_container_copy_construction() takes allocators, not containers 2322: Associative(initializer_list, stuff) constructors are underspecified 2323: vector::resize(n, t)'s specification should be simplified 2324: Insert iterator constructors should use addressof() 2329: regex_match()/regex_search() with match_results should forbid temporary strings 2330: regex("meow", regex::icase) is technically forbidden but should be permitted 2332: regex_iterator/regex_token_iterator should forbid temporary regexes 2339: Wording issue in nth_element 2341: Inconsistency between basic_ostream::seekp(pos) and basic_ostream::seekp(off, dir) 2344: quoted()'s interaction with padding is unclear 2346: integral_constant's member functions should be marked noexcept 2350: min, max, and minmax should be constexpr 2356: Stability of erasure in unordered associative containers 2357: Remaining "Assignable" requirement 2359: How does regex_constants::nosubs affect basic_regex::mark_count()? 2360: reverse_iterator::operator*() is unimplementable [1] http://libcxx.llvm.org/cxx1y_status.html [2] http://libcxx.llvm.org/cxx1z_status.html [3] http://www.open-std.org/jtc1/sc22/wg21/docs/lwg-defects.html Exp-run: antoine MFC r277944: Partially revert r273382, to reduce diffs against upstream. This was a temporary fix to solve a conflict with an older version of libc++, and it is no longer relevant. MFC r278010: Revert r256642, not only to reduce diffs against upstream libcxxrt, but also because it is the wrong approach: comparing typeinfo names deeply causes trouble if two loaded DSOs use independent types of the same name. In addition, this particular change was never merged to FreeBSD 10.x and 9.x, so let's get rid of it before it ends up in an 11.x release. Discussed with: theraven, joerg@netbsd MFC r278016: Import libcxxrt master 1cb607e89f6135bbc10f3d3b6fba1f983e258dcc. Interesting fixes: 1cb607e Correct gcc version check for __cxa_begin_catch() declaration with or without throw()
814 lines
40 KiB
C++
814 lines
40 KiB
C++
// -*- C++ -*-
|
|
//===---------------------------- limits ----------------------------------===//
|
|
//
|
|
// The LLVM Compiler Infrastructure
|
|
//
|
|
// This file is dual licensed under the MIT and the University of Illinois Open
|
|
// Source Licenses. See LICENSE.TXT for details.
|
|
//
|
|
//===----------------------------------------------------------------------===//
|
|
|
|
#ifndef _LIBCPP_LIMITS
|
|
#define _LIBCPP_LIMITS
|
|
|
|
/*
|
|
limits synopsis
|
|
|
|
namespace std
|
|
{
|
|
|
|
template<class T>
|
|
class numeric_limits
|
|
{
|
|
public:
|
|
static constexpr bool is_specialized = false;
|
|
static constexpr T min() noexcept;
|
|
static constexpr T max() noexcept;
|
|
static constexpr T lowest() noexcept;
|
|
|
|
static constexpr int digits = 0;
|
|
static constexpr int digits10 = 0;
|
|
static constexpr int max_digits10 = 0;
|
|
static constexpr bool is_signed = false;
|
|
static constexpr bool is_integer = false;
|
|
static constexpr bool is_exact = false;
|
|
static constexpr int radix = 0;
|
|
static constexpr T epsilon() noexcept;
|
|
static constexpr T round_error() noexcept;
|
|
|
|
static constexpr int min_exponent = 0;
|
|
static constexpr int min_exponent10 = 0;
|
|
static constexpr int max_exponent = 0;
|
|
static constexpr int max_exponent10 = 0;
|
|
|
|
static constexpr bool has_infinity = false;
|
|
static constexpr bool has_quiet_NaN = false;
|
|
static constexpr bool has_signaling_NaN = false;
|
|
static constexpr float_denorm_style has_denorm = denorm_absent;
|
|
static constexpr bool has_denorm_loss = false;
|
|
static constexpr T infinity() noexcept;
|
|
static constexpr T quiet_NaN() noexcept;
|
|
static constexpr T signaling_NaN() noexcept;
|
|
static constexpr T denorm_min() noexcept;
|
|
|
|
static constexpr bool is_iec559 = false;
|
|
static constexpr bool is_bounded = false;
|
|
static constexpr bool is_modulo = false;
|
|
|
|
static constexpr bool traps = false;
|
|
static constexpr bool tinyness_before = false;
|
|
static constexpr float_round_style round_style = round_toward_zero;
|
|
};
|
|
|
|
enum float_round_style
|
|
{
|
|
round_indeterminate = -1,
|
|
round_toward_zero = 0,
|
|
round_to_nearest = 1,
|
|
round_toward_infinity = 2,
|
|
round_toward_neg_infinity = 3
|
|
};
|
|
|
|
enum float_denorm_style
|
|
{
|
|
denorm_indeterminate = -1,
|
|
denorm_absent = 0,
|
|
denorm_present = 1
|
|
};
|
|
|
|
template<> class numeric_limits<cv bool>;
|
|
|
|
template<> class numeric_limits<cv char>;
|
|
template<> class numeric_limits<cv signed char>;
|
|
template<> class numeric_limits<cv unsigned char>;
|
|
template<> class numeric_limits<cv wchar_t>;
|
|
template<> class numeric_limits<cv char16_t>;
|
|
template<> class numeric_limits<cv char32_t>;
|
|
|
|
template<> class numeric_limits<cv short>;
|
|
template<> class numeric_limits<cv int>;
|
|
template<> class numeric_limits<cv long>;
|
|
template<> class numeric_limits<cv long long>;
|
|
template<> class numeric_limits<cv unsigned short>;
|
|
template<> class numeric_limits<cv unsigned int>;
|
|
template<> class numeric_limits<cv unsigned long>;
|
|
template<> class numeric_limits<cv unsigned long long>;
|
|
|
|
template<> class numeric_limits<cv float>;
|
|
template<> class numeric_limits<cv double>;
|
|
template<> class numeric_limits<cv long double>;
|
|
|
|
} // std
|
|
|
|
*/
|
|
|
|
#if !defined(_LIBCPP_HAS_NO_PRAGMA_SYSTEM_HEADER)
|
|
#pragma GCC system_header
|
|
#endif
|
|
|
|
#include <__config>
|
|
#include <type_traits>
|
|
|
|
#include <__undef_min_max>
|
|
|
|
#if defined(_LIBCPP_MSVCRT)
|
|
#include "support/win32/limits_win32.h"
|
|
#endif // _LIBCPP_MSVCRT
|
|
|
|
#if defined(__IBMCPP__)
|
|
#include "support/ibm/limits.h"
|
|
#endif // __IBMCPP__
|
|
|
|
_LIBCPP_BEGIN_NAMESPACE_STD
|
|
|
|
enum float_round_style
|
|
{
|
|
round_indeterminate = -1,
|
|
round_toward_zero = 0,
|
|
round_to_nearest = 1,
|
|
round_toward_infinity = 2,
|
|
round_toward_neg_infinity = 3
|
|
};
|
|
|
|
enum float_denorm_style
|
|
{
|
|
denorm_indeterminate = -1,
|
|
denorm_absent = 0,
|
|
denorm_present = 1
|
|
};
|
|
|
|
template <class _Tp, bool = is_arithmetic<_Tp>::value>
|
|
class __libcpp_numeric_limits
|
|
{
|
|
protected:
|
|
typedef _Tp type;
|
|
|
|
static _LIBCPP_CONSTEXPR const bool is_specialized = false;
|
|
_LIBCPP_INLINE_VISIBILITY static _LIBCPP_CONSTEXPR type min() _NOEXCEPT {return type();}
|
|
_LIBCPP_INLINE_VISIBILITY static _LIBCPP_CONSTEXPR type max() _NOEXCEPT {return type();}
|
|
_LIBCPP_INLINE_VISIBILITY static _LIBCPP_CONSTEXPR type lowest() _NOEXCEPT {return type();}
|
|
|
|
static _LIBCPP_CONSTEXPR const int digits = 0;
|
|
static _LIBCPP_CONSTEXPR const int digits10 = 0;
|
|
static _LIBCPP_CONSTEXPR const int max_digits10 = 0;
|
|
static _LIBCPP_CONSTEXPR const bool is_signed = false;
|
|
static _LIBCPP_CONSTEXPR const bool is_integer = false;
|
|
static _LIBCPP_CONSTEXPR const bool is_exact = false;
|
|
static _LIBCPP_CONSTEXPR const int radix = 0;
|
|
_LIBCPP_INLINE_VISIBILITY static _LIBCPP_CONSTEXPR type epsilon() _NOEXCEPT {return type();}
|
|
_LIBCPP_INLINE_VISIBILITY static _LIBCPP_CONSTEXPR type round_error() _NOEXCEPT {return type();}
|
|
|
|
static _LIBCPP_CONSTEXPR const int min_exponent = 0;
|
|
static _LIBCPP_CONSTEXPR const int min_exponent10 = 0;
|
|
static _LIBCPP_CONSTEXPR const int max_exponent = 0;
|
|
static _LIBCPP_CONSTEXPR const int max_exponent10 = 0;
|
|
|
|
static _LIBCPP_CONSTEXPR const bool has_infinity = false;
|
|
static _LIBCPP_CONSTEXPR const bool has_quiet_NaN = false;
|
|
static _LIBCPP_CONSTEXPR const bool has_signaling_NaN = false;
|
|
static _LIBCPP_CONSTEXPR const float_denorm_style has_denorm = denorm_absent;
|
|
static _LIBCPP_CONSTEXPR const bool has_denorm_loss = false;
|
|
_LIBCPP_INLINE_VISIBILITY static _LIBCPP_CONSTEXPR type infinity() _NOEXCEPT {return type();}
|
|
_LIBCPP_INLINE_VISIBILITY static _LIBCPP_CONSTEXPR type quiet_NaN() _NOEXCEPT {return type();}
|
|
_LIBCPP_INLINE_VISIBILITY static _LIBCPP_CONSTEXPR type signaling_NaN() _NOEXCEPT {return type();}
|
|
_LIBCPP_INLINE_VISIBILITY static _LIBCPP_CONSTEXPR type denorm_min() _NOEXCEPT {return type();}
|
|
|
|
static _LIBCPP_CONSTEXPR const bool is_iec559 = false;
|
|
static _LIBCPP_CONSTEXPR const bool is_bounded = false;
|
|
static _LIBCPP_CONSTEXPR const bool is_modulo = false;
|
|
|
|
static _LIBCPP_CONSTEXPR const bool traps = false;
|
|
static _LIBCPP_CONSTEXPR const bool tinyness_before = false;
|
|
static _LIBCPP_CONSTEXPR const float_round_style round_style = round_toward_zero;
|
|
};
|
|
|
|
template <class _Tp, int digits, bool is_signed>
|
|
struct __libcpp_compute_min
|
|
{
|
|
static _LIBCPP_CONSTEXPR const _Tp value = _Tp(_Tp(1) << digits);
|
|
};
|
|
|
|
template <class _Tp, int digits>
|
|
struct __libcpp_compute_min<_Tp, digits, false>
|
|
{
|
|
static _LIBCPP_CONSTEXPR const _Tp value = _Tp(0);
|
|
};
|
|
|
|
template <class _Tp>
|
|
class __libcpp_numeric_limits<_Tp, true>
|
|
{
|
|
protected:
|
|
typedef _Tp type;
|
|
|
|
static _LIBCPP_CONSTEXPR const bool is_specialized = true;
|
|
|
|
static _LIBCPP_CONSTEXPR const bool is_signed = type(-1) < type(0);
|
|
static _LIBCPP_CONSTEXPR const int digits = static_cast<int>(sizeof(type) * __CHAR_BIT__ - is_signed);
|
|
static _LIBCPP_CONSTEXPR const int digits10 = digits * 3 / 10;
|
|
static _LIBCPP_CONSTEXPR const int max_digits10 = 0;
|
|
static _LIBCPP_CONSTEXPR const type __min = __libcpp_compute_min<type, digits, is_signed>::value;
|
|
static _LIBCPP_CONSTEXPR const type __max = is_signed ? type(type(~0) ^ __min) : type(~0);
|
|
_LIBCPP_INLINE_VISIBILITY static _LIBCPP_CONSTEXPR type min() _NOEXCEPT {return __min;}
|
|
_LIBCPP_INLINE_VISIBILITY static _LIBCPP_CONSTEXPR type max() _NOEXCEPT {return __max;}
|
|
_LIBCPP_INLINE_VISIBILITY static _LIBCPP_CONSTEXPR type lowest() _NOEXCEPT {return min();}
|
|
|
|
static _LIBCPP_CONSTEXPR const bool is_integer = true;
|
|
static _LIBCPP_CONSTEXPR const bool is_exact = true;
|
|
static _LIBCPP_CONSTEXPR const int radix = 2;
|
|
_LIBCPP_INLINE_VISIBILITY static _LIBCPP_CONSTEXPR type epsilon() _NOEXCEPT {return type(0);}
|
|
_LIBCPP_INLINE_VISIBILITY static _LIBCPP_CONSTEXPR type round_error() _NOEXCEPT {return type(0);}
|
|
|
|
static _LIBCPP_CONSTEXPR const int min_exponent = 0;
|
|
static _LIBCPP_CONSTEXPR const int min_exponent10 = 0;
|
|
static _LIBCPP_CONSTEXPR const int max_exponent = 0;
|
|
static _LIBCPP_CONSTEXPR const int max_exponent10 = 0;
|
|
|
|
static _LIBCPP_CONSTEXPR const bool has_infinity = false;
|
|
static _LIBCPP_CONSTEXPR const bool has_quiet_NaN = false;
|
|
static _LIBCPP_CONSTEXPR const bool has_signaling_NaN = false;
|
|
static _LIBCPP_CONSTEXPR const float_denorm_style has_denorm = denorm_absent;
|
|
static _LIBCPP_CONSTEXPR const bool has_denorm_loss = false;
|
|
_LIBCPP_INLINE_VISIBILITY static _LIBCPP_CONSTEXPR type infinity() _NOEXCEPT {return type(0);}
|
|
_LIBCPP_INLINE_VISIBILITY static _LIBCPP_CONSTEXPR type quiet_NaN() _NOEXCEPT {return type(0);}
|
|
_LIBCPP_INLINE_VISIBILITY static _LIBCPP_CONSTEXPR type signaling_NaN() _NOEXCEPT {return type(0);}
|
|
_LIBCPP_INLINE_VISIBILITY static _LIBCPP_CONSTEXPR type denorm_min() _NOEXCEPT {return type(0);}
|
|
|
|
static _LIBCPP_CONSTEXPR const bool is_iec559 = false;
|
|
static _LIBCPP_CONSTEXPR const bool is_bounded = true;
|
|
static _LIBCPP_CONSTEXPR const bool is_modulo = !_VSTD::is_signed<_Tp>::value;
|
|
|
|
#if defined(__i386__) || defined(__x86_64__) || defined(__pnacl__)
|
|
static _LIBCPP_CONSTEXPR const bool traps = true;
|
|
#else
|
|
static _LIBCPP_CONSTEXPR const bool traps = false;
|
|
#endif
|
|
static _LIBCPP_CONSTEXPR const bool tinyness_before = false;
|
|
static _LIBCPP_CONSTEXPR const float_round_style round_style = round_toward_zero;
|
|
};
|
|
|
|
template <>
|
|
class __libcpp_numeric_limits<bool, true>
|
|
{
|
|
protected:
|
|
typedef bool type;
|
|
|
|
static _LIBCPP_CONSTEXPR const bool is_specialized = true;
|
|
|
|
static _LIBCPP_CONSTEXPR const bool is_signed = false;
|
|
static _LIBCPP_CONSTEXPR const int digits = 1;
|
|
static _LIBCPP_CONSTEXPR const int digits10 = 0;
|
|
static _LIBCPP_CONSTEXPR const int max_digits10 = 0;
|
|
static _LIBCPP_CONSTEXPR const type __min = false;
|
|
static _LIBCPP_CONSTEXPR const type __max = true;
|
|
_LIBCPP_INLINE_VISIBILITY static _LIBCPP_CONSTEXPR type min() _NOEXCEPT {return __min;}
|
|
_LIBCPP_INLINE_VISIBILITY static _LIBCPP_CONSTEXPR type max() _NOEXCEPT {return __max;}
|
|
_LIBCPP_INLINE_VISIBILITY static _LIBCPP_CONSTEXPR type lowest() _NOEXCEPT {return min();}
|
|
|
|
static _LIBCPP_CONSTEXPR const bool is_integer = true;
|
|
static _LIBCPP_CONSTEXPR const bool is_exact = true;
|
|
static _LIBCPP_CONSTEXPR const int radix = 2;
|
|
_LIBCPP_INLINE_VISIBILITY static _LIBCPP_CONSTEXPR type epsilon() _NOEXCEPT {return type(0);}
|
|
_LIBCPP_INLINE_VISIBILITY static _LIBCPP_CONSTEXPR type round_error() _NOEXCEPT {return type(0);}
|
|
|
|
static _LIBCPP_CONSTEXPR const int min_exponent = 0;
|
|
static _LIBCPP_CONSTEXPR const int min_exponent10 = 0;
|
|
static _LIBCPP_CONSTEXPR const int max_exponent = 0;
|
|
static _LIBCPP_CONSTEXPR const int max_exponent10 = 0;
|
|
|
|
static _LIBCPP_CONSTEXPR const bool has_infinity = false;
|
|
static _LIBCPP_CONSTEXPR const bool has_quiet_NaN = false;
|
|
static _LIBCPP_CONSTEXPR const bool has_signaling_NaN = false;
|
|
static _LIBCPP_CONSTEXPR const float_denorm_style has_denorm = denorm_absent;
|
|
static _LIBCPP_CONSTEXPR const bool has_denorm_loss = false;
|
|
_LIBCPP_INLINE_VISIBILITY static _LIBCPP_CONSTEXPR type infinity() _NOEXCEPT {return type(0);}
|
|
_LIBCPP_INLINE_VISIBILITY static _LIBCPP_CONSTEXPR type quiet_NaN() _NOEXCEPT {return type(0);}
|
|
_LIBCPP_INLINE_VISIBILITY static _LIBCPP_CONSTEXPR type signaling_NaN() _NOEXCEPT {return type(0);}
|
|
_LIBCPP_INLINE_VISIBILITY static _LIBCPP_CONSTEXPR type denorm_min() _NOEXCEPT {return type(0);}
|
|
|
|
static _LIBCPP_CONSTEXPR const bool is_iec559 = false;
|
|
static _LIBCPP_CONSTEXPR const bool is_bounded = true;
|
|
static _LIBCPP_CONSTEXPR const bool is_modulo = false;
|
|
|
|
static _LIBCPP_CONSTEXPR const bool traps = false;
|
|
static _LIBCPP_CONSTEXPR const bool tinyness_before = false;
|
|
static _LIBCPP_CONSTEXPR const float_round_style round_style = round_toward_zero;
|
|
};
|
|
|
|
template <>
|
|
class __libcpp_numeric_limits<float, true>
|
|
{
|
|
protected:
|
|
typedef float type;
|
|
|
|
static _LIBCPP_CONSTEXPR const bool is_specialized = true;
|
|
|
|
static _LIBCPP_CONSTEXPR const bool is_signed = true;
|
|
static _LIBCPP_CONSTEXPR const int digits = __FLT_MANT_DIG__;
|
|
static _LIBCPP_CONSTEXPR const int digits10 = __FLT_DIG__;
|
|
static _LIBCPP_CONSTEXPR const int max_digits10 = 2+(digits * 30103)/100000;
|
|
_LIBCPP_INLINE_VISIBILITY static _LIBCPP_CONSTEXPR type min() _NOEXCEPT {return __FLT_MIN__;}
|
|
_LIBCPP_INLINE_VISIBILITY static _LIBCPP_CONSTEXPR type max() _NOEXCEPT {return __FLT_MAX__;}
|
|
_LIBCPP_INLINE_VISIBILITY static _LIBCPP_CONSTEXPR type lowest() _NOEXCEPT {return -max();}
|
|
|
|
static _LIBCPP_CONSTEXPR const bool is_integer = false;
|
|
static _LIBCPP_CONSTEXPR const bool is_exact = false;
|
|
static _LIBCPP_CONSTEXPR const int radix = __FLT_RADIX__;
|
|
_LIBCPP_INLINE_VISIBILITY static _LIBCPP_CONSTEXPR type epsilon() _NOEXCEPT {return __FLT_EPSILON__;}
|
|
_LIBCPP_INLINE_VISIBILITY static _LIBCPP_CONSTEXPR type round_error() _NOEXCEPT {return 0.5F;}
|
|
|
|
static _LIBCPP_CONSTEXPR const int min_exponent = __FLT_MIN_EXP__;
|
|
static _LIBCPP_CONSTEXPR const int min_exponent10 = __FLT_MIN_10_EXP__;
|
|
static _LIBCPP_CONSTEXPR const int max_exponent = __FLT_MAX_EXP__;
|
|
static _LIBCPP_CONSTEXPR const int max_exponent10 = __FLT_MAX_10_EXP__;
|
|
|
|
static _LIBCPP_CONSTEXPR const bool has_infinity = true;
|
|
static _LIBCPP_CONSTEXPR const bool has_quiet_NaN = true;
|
|
static _LIBCPP_CONSTEXPR const bool has_signaling_NaN = true;
|
|
static _LIBCPP_CONSTEXPR const float_denorm_style has_denorm = denorm_present;
|
|
static _LIBCPP_CONSTEXPR const bool has_denorm_loss = false;
|
|
_LIBCPP_INLINE_VISIBILITY static _LIBCPP_CONSTEXPR type infinity() _NOEXCEPT {return __builtin_huge_valf();}
|
|
_LIBCPP_INLINE_VISIBILITY static _LIBCPP_CONSTEXPR type quiet_NaN() _NOEXCEPT {return __builtin_nanf("");}
|
|
_LIBCPP_INLINE_VISIBILITY static _LIBCPP_CONSTEXPR type signaling_NaN() _NOEXCEPT {return __builtin_nansf("");}
|
|
_LIBCPP_INLINE_VISIBILITY static _LIBCPP_CONSTEXPR type denorm_min() _NOEXCEPT {return __FLT_DENORM_MIN__;}
|
|
|
|
static _LIBCPP_CONSTEXPR const bool is_iec559 = true;
|
|
static _LIBCPP_CONSTEXPR const bool is_bounded = true;
|
|
static _LIBCPP_CONSTEXPR const bool is_modulo = false;
|
|
|
|
static _LIBCPP_CONSTEXPR const bool traps = false;
|
|
static _LIBCPP_CONSTEXPR const bool tinyness_before = false;
|
|
static _LIBCPP_CONSTEXPR const float_round_style round_style = round_to_nearest;
|
|
};
|
|
|
|
template <>
|
|
class __libcpp_numeric_limits<double, true>
|
|
{
|
|
protected:
|
|
typedef double type;
|
|
|
|
static _LIBCPP_CONSTEXPR const bool is_specialized = true;
|
|
|
|
static _LIBCPP_CONSTEXPR const bool is_signed = true;
|
|
static _LIBCPP_CONSTEXPR const int digits = __DBL_MANT_DIG__;
|
|
static _LIBCPP_CONSTEXPR const int digits10 = __DBL_DIG__;
|
|
static _LIBCPP_CONSTEXPR const int max_digits10 = 2+(digits * 30103)/100000;
|
|
_LIBCPP_INLINE_VISIBILITY static _LIBCPP_CONSTEXPR type min() _NOEXCEPT {return __DBL_MIN__;}
|
|
_LIBCPP_INLINE_VISIBILITY static _LIBCPP_CONSTEXPR type max() _NOEXCEPT {return __DBL_MAX__;}
|
|
_LIBCPP_INLINE_VISIBILITY static _LIBCPP_CONSTEXPR type lowest() _NOEXCEPT {return -max();}
|
|
|
|
static _LIBCPP_CONSTEXPR const bool is_integer = false;
|
|
static _LIBCPP_CONSTEXPR const bool is_exact = false;
|
|
static _LIBCPP_CONSTEXPR const int radix = __FLT_RADIX__;
|
|
_LIBCPP_INLINE_VISIBILITY static _LIBCPP_CONSTEXPR type epsilon() _NOEXCEPT {return __DBL_EPSILON__;}
|
|
_LIBCPP_INLINE_VISIBILITY static _LIBCPP_CONSTEXPR type round_error() _NOEXCEPT {return 0.5;}
|
|
|
|
static _LIBCPP_CONSTEXPR const int min_exponent = __DBL_MIN_EXP__;
|
|
static _LIBCPP_CONSTEXPR const int min_exponent10 = __DBL_MIN_10_EXP__;
|
|
static _LIBCPP_CONSTEXPR const int max_exponent = __DBL_MAX_EXP__;
|
|
static _LIBCPP_CONSTEXPR const int max_exponent10 = __DBL_MAX_10_EXP__;
|
|
|
|
static _LIBCPP_CONSTEXPR const bool has_infinity = true;
|
|
static _LIBCPP_CONSTEXPR const bool has_quiet_NaN = true;
|
|
static _LIBCPP_CONSTEXPR const bool has_signaling_NaN = true;
|
|
static _LIBCPP_CONSTEXPR const float_denorm_style has_denorm = denorm_present;
|
|
static _LIBCPP_CONSTEXPR const bool has_denorm_loss = false;
|
|
_LIBCPP_INLINE_VISIBILITY static _LIBCPP_CONSTEXPR type infinity() _NOEXCEPT {return __builtin_huge_val();}
|
|
_LIBCPP_INLINE_VISIBILITY static _LIBCPP_CONSTEXPR type quiet_NaN() _NOEXCEPT {return __builtin_nan("");}
|
|
_LIBCPP_INLINE_VISIBILITY static _LIBCPP_CONSTEXPR type signaling_NaN() _NOEXCEPT {return __builtin_nans("");}
|
|
_LIBCPP_INLINE_VISIBILITY static _LIBCPP_CONSTEXPR type denorm_min() _NOEXCEPT {return __DBL_DENORM_MIN__;}
|
|
|
|
static _LIBCPP_CONSTEXPR const bool is_iec559 = true;
|
|
static _LIBCPP_CONSTEXPR const bool is_bounded = true;
|
|
static _LIBCPP_CONSTEXPR const bool is_modulo = false;
|
|
|
|
static _LIBCPP_CONSTEXPR const bool traps = false;
|
|
static _LIBCPP_CONSTEXPR const bool tinyness_before = false;
|
|
static _LIBCPP_CONSTEXPR const float_round_style round_style = round_to_nearest;
|
|
};
|
|
|
|
template <>
|
|
class __libcpp_numeric_limits<long double, true>
|
|
{
|
|
protected:
|
|
typedef long double type;
|
|
|
|
static _LIBCPP_CONSTEXPR const bool is_specialized = true;
|
|
|
|
static _LIBCPP_CONSTEXPR const bool is_signed = true;
|
|
static _LIBCPP_CONSTEXPR const int digits = __LDBL_MANT_DIG__;
|
|
static _LIBCPP_CONSTEXPR const int digits10 = __LDBL_DIG__;
|
|
static _LIBCPP_CONSTEXPR const int max_digits10 = 2+(digits * 30103)/100000;
|
|
_LIBCPP_INLINE_VISIBILITY static _LIBCPP_CONSTEXPR type min() _NOEXCEPT {return __LDBL_MIN__;}
|
|
_LIBCPP_INLINE_VISIBILITY static _LIBCPP_CONSTEXPR type max() _NOEXCEPT {return __LDBL_MAX__;}
|
|
_LIBCPP_INLINE_VISIBILITY static _LIBCPP_CONSTEXPR type lowest() _NOEXCEPT {return -max();}
|
|
|
|
static _LIBCPP_CONSTEXPR const bool is_integer = false;
|
|
static _LIBCPP_CONSTEXPR const bool is_exact = false;
|
|
static _LIBCPP_CONSTEXPR const int radix = __FLT_RADIX__;
|
|
_LIBCPP_INLINE_VISIBILITY static _LIBCPP_CONSTEXPR type epsilon() _NOEXCEPT {return __LDBL_EPSILON__;}
|
|
_LIBCPP_INLINE_VISIBILITY static _LIBCPP_CONSTEXPR type round_error() _NOEXCEPT {return 0.5;}
|
|
|
|
static _LIBCPP_CONSTEXPR const int min_exponent = __LDBL_MIN_EXP__;
|
|
static _LIBCPP_CONSTEXPR const int min_exponent10 = __LDBL_MIN_10_EXP__;
|
|
static _LIBCPP_CONSTEXPR const int max_exponent = __LDBL_MAX_EXP__;
|
|
static _LIBCPP_CONSTEXPR const int max_exponent10 = __LDBL_MAX_10_EXP__;
|
|
|
|
static _LIBCPP_CONSTEXPR const bool has_infinity = true;
|
|
static _LIBCPP_CONSTEXPR const bool has_quiet_NaN = true;
|
|
static _LIBCPP_CONSTEXPR const bool has_signaling_NaN = true;
|
|
static _LIBCPP_CONSTEXPR const float_denorm_style has_denorm = denorm_present;
|
|
static _LIBCPP_CONSTEXPR const bool has_denorm_loss = false;
|
|
_LIBCPP_INLINE_VISIBILITY static _LIBCPP_CONSTEXPR type infinity() _NOEXCEPT {return __builtin_huge_vall();}
|
|
_LIBCPP_INLINE_VISIBILITY static _LIBCPP_CONSTEXPR type quiet_NaN() _NOEXCEPT {return __builtin_nanl("");}
|
|
_LIBCPP_INLINE_VISIBILITY static _LIBCPP_CONSTEXPR type signaling_NaN() _NOEXCEPT {return __builtin_nansl("");}
|
|
_LIBCPP_INLINE_VISIBILITY static _LIBCPP_CONSTEXPR type denorm_min() _NOEXCEPT {return __LDBL_DENORM_MIN__;}
|
|
|
|
#if (defined(__ppc__) || defined(__ppc64__))
|
|
static _LIBCPP_CONSTEXPR const bool is_iec559 = false;
|
|
#else
|
|
static _LIBCPP_CONSTEXPR const bool is_iec559 = true;
|
|
#endif
|
|
static _LIBCPP_CONSTEXPR const bool is_bounded = true;
|
|
static _LIBCPP_CONSTEXPR const bool is_modulo = false;
|
|
|
|
static _LIBCPP_CONSTEXPR const bool traps = false;
|
|
static _LIBCPP_CONSTEXPR const bool tinyness_before = false;
|
|
static _LIBCPP_CONSTEXPR const float_round_style round_style = round_to_nearest;
|
|
};
|
|
|
|
template <class _Tp>
|
|
class _LIBCPP_TYPE_VIS_ONLY numeric_limits
|
|
: private __libcpp_numeric_limits<typename remove_cv<_Tp>::type>
|
|
{
|
|
typedef __libcpp_numeric_limits<typename remove_cv<_Tp>::type> __base;
|
|
typedef typename __base::type type;
|
|
public:
|
|
static _LIBCPP_CONSTEXPR const bool is_specialized = __base::is_specialized;
|
|
_LIBCPP_INLINE_VISIBILITY static _LIBCPP_CONSTEXPR type min() _NOEXCEPT {return __base::min();}
|
|
_LIBCPP_INLINE_VISIBILITY static _LIBCPP_CONSTEXPR type max() _NOEXCEPT {return __base::max();}
|
|
_LIBCPP_INLINE_VISIBILITY static _LIBCPP_CONSTEXPR type lowest() _NOEXCEPT {return __base::lowest();}
|
|
|
|
static _LIBCPP_CONSTEXPR const int digits = __base::digits;
|
|
static _LIBCPP_CONSTEXPR const int digits10 = __base::digits10;
|
|
static _LIBCPP_CONSTEXPR const int max_digits10 = __base::max_digits10;
|
|
static _LIBCPP_CONSTEXPR const bool is_signed = __base::is_signed;
|
|
static _LIBCPP_CONSTEXPR const bool is_integer = __base::is_integer;
|
|
static _LIBCPP_CONSTEXPR const bool is_exact = __base::is_exact;
|
|
static _LIBCPP_CONSTEXPR const int radix = __base::radix;
|
|
_LIBCPP_INLINE_VISIBILITY static _LIBCPP_CONSTEXPR type epsilon() _NOEXCEPT {return __base::epsilon();}
|
|
_LIBCPP_INLINE_VISIBILITY static _LIBCPP_CONSTEXPR type round_error() _NOEXCEPT {return __base::round_error();}
|
|
|
|
static _LIBCPP_CONSTEXPR const int min_exponent = __base::min_exponent;
|
|
static _LIBCPP_CONSTEXPR const int min_exponent10 = __base::min_exponent10;
|
|
static _LIBCPP_CONSTEXPR const int max_exponent = __base::max_exponent;
|
|
static _LIBCPP_CONSTEXPR const int max_exponent10 = __base::max_exponent10;
|
|
|
|
static _LIBCPP_CONSTEXPR const bool has_infinity = __base::has_infinity;
|
|
static _LIBCPP_CONSTEXPR const bool has_quiet_NaN = __base::has_quiet_NaN;
|
|
static _LIBCPP_CONSTEXPR const bool has_signaling_NaN = __base::has_signaling_NaN;
|
|
static _LIBCPP_CONSTEXPR const float_denorm_style has_denorm = __base::has_denorm;
|
|
static _LIBCPP_CONSTEXPR const bool has_denorm_loss = __base::has_denorm_loss;
|
|
_LIBCPP_INLINE_VISIBILITY static _LIBCPP_CONSTEXPR type infinity() _NOEXCEPT {return __base::infinity();}
|
|
_LIBCPP_INLINE_VISIBILITY static _LIBCPP_CONSTEXPR type quiet_NaN() _NOEXCEPT {return __base::quiet_NaN();}
|
|
_LIBCPP_INLINE_VISIBILITY static _LIBCPP_CONSTEXPR type signaling_NaN() _NOEXCEPT {return __base::signaling_NaN();}
|
|
_LIBCPP_INLINE_VISIBILITY static _LIBCPP_CONSTEXPR type denorm_min() _NOEXCEPT {return __base::denorm_min();}
|
|
|
|
static _LIBCPP_CONSTEXPR const bool is_iec559 = __base::is_iec559;
|
|
static _LIBCPP_CONSTEXPR const bool is_bounded = __base::is_bounded;
|
|
static _LIBCPP_CONSTEXPR const bool is_modulo = __base::is_modulo;
|
|
|
|
static _LIBCPP_CONSTEXPR const bool traps = __base::traps;
|
|
static _LIBCPP_CONSTEXPR const bool tinyness_before = __base::tinyness_before;
|
|
static _LIBCPP_CONSTEXPR const float_round_style round_style = __base::round_style;
|
|
};
|
|
|
|
template <class _Tp>
|
|
_LIBCPP_CONSTEXPR const bool numeric_limits<_Tp>::is_specialized;
|
|
template <class _Tp>
|
|
_LIBCPP_CONSTEXPR const int numeric_limits<_Tp>::digits;
|
|
template <class _Tp>
|
|
_LIBCPP_CONSTEXPR const int numeric_limits<_Tp>::digits10;
|
|
template <class _Tp>
|
|
_LIBCPP_CONSTEXPR const int numeric_limits<_Tp>::max_digits10;
|
|
template <class _Tp>
|
|
_LIBCPP_CONSTEXPR const bool numeric_limits<_Tp>::is_signed;
|
|
template <class _Tp>
|
|
_LIBCPP_CONSTEXPR const bool numeric_limits<_Tp>::is_integer;
|
|
template <class _Tp>
|
|
_LIBCPP_CONSTEXPR const bool numeric_limits<_Tp>::is_exact;
|
|
template <class _Tp>
|
|
_LIBCPP_CONSTEXPR const int numeric_limits<_Tp>::radix;
|
|
template <class _Tp>
|
|
_LIBCPP_CONSTEXPR const int numeric_limits<_Tp>::min_exponent;
|
|
template <class _Tp>
|
|
_LIBCPP_CONSTEXPR const int numeric_limits<_Tp>::min_exponent10;
|
|
template <class _Tp>
|
|
_LIBCPP_CONSTEXPR const int numeric_limits<_Tp>::max_exponent;
|
|
template <class _Tp>
|
|
_LIBCPP_CONSTEXPR const int numeric_limits<_Tp>::max_exponent10;
|
|
template <class _Tp>
|
|
_LIBCPP_CONSTEXPR const bool numeric_limits<_Tp>::has_infinity;
|
|
template <class _Tp>
|
|
_LIBCPP_CONSTEXPR const bool numeric_limits<_Tp>::has_quiet_NaN;
|
|
template <class _Tp>
|
|
_LIBCPP_CONSTEXPR const bool numeric_limits<_Tp>::has_signaling_NaN;
|
|
template <class _Tp>
|
|
_LIBCPP_CONSTEXPR const float_denorm_style numeric_limits<_Tp>::has_denorm;
|
|
template <class _Tp>
|
|
_LIBCPP_CONSTEXPR const bool numeric_limits<_Tp>::has_denorm_loss;
|
|
template <class _Tp>
|
|
_LIBCPP_CONSTEXPR const bool numeric_limits<_Tp>::is_iec559;
|
|
template <class _Tp>
|
|
_LIBCPP_CONSTEXPR const bool numeric_limits<_Tp>::is_bounded;
|
|
template <class _Tp>
|
|
_LIBCPP_CONSTEXPR const bool numeric_limits<_Tp>::is_modulo;
|
|
template <class _Tp>
|
|
_LIBCPP_CONSTEXPR const bool numeric_limits<_Tp>::traps;
|
|
template <class _Tp>
|
|
_LIBCPP_CONSTEXPR const bool numeric_limits<_Tp>::tinyness_before;
|
|
template <class _Tp>
|
|
_LIBCPP_CONSTEXPR const float_round_style numeric_limits<_Tp>::round_style;
|
|
|
|
template <class _Tp>
|
|
class _LIBCPP_TYPE_VIS_ONLY numeric_limits<const _Tp>
|
|
: private numeric_limits<_Tp>
|
|
{
|
|
typedef numeric_limits<_Tp> __base;
|
|
typedef _Tp type;
|
|
public:
|
|
static _LIBCPP_CONSTEXPR const bool is_specialized = __base::is_specialized;
|
|
_LIBCPP_INLINE_VISIBILITY static _LIBCPP_CONSTEXPR type min() _NOEXCEPT {return __base::min();}
|
|
_LIBCPP_INLINE_VISIBILITY static _LIBCPP_CONSTEXPR type max() _NOEXCEPT {return __base::max();}
|
|
_LIBCPP_INLINE_VISIBILITY static _LIBCPP_CONSTEXPR type lowest() _NOEXCEPT {return __base::lowest();}
|
|
|
|
static _LIBCPP_CONSTEXPR const int digits = __base::digits;
|
|
static _LIBCPP_CONSTEXPR const int digits10 = __base::digits10;
|
|
static _LIBCPP_CONSTEXPR const int max_digits10 = __base::max_digits10;
|
|
static _LIBCPP_CONSTEXPR const bool is_signed = __base::is_signed;
|
|
static _LIBCPP_CONSTEXPR const bool is_integer = __base::is_integer;
|
|
static _LIBCPP_CONSTEXPR const bool is_exact = __base::is_exact;
|
|
static _LIBCPP_CONSTEXPR const int radix = __base::radix;
|
|
_LIBCPP_INLINE_VISIBILITY static _LIBCPP_CONSTEXPR type epsilon() _NOEXCEPT {return __base::epsilon();}
|
|
_LIBCPP_INLINE_VISIBILITY static _LIBCPP_CONSTEXPR type round_error() _NOEXCEPT {return __base::round_error();}
|
|
|
|
static _LIBCPP_CONSTEXPR const int min_exponent = __base::min_exponent;
|
|
static _LIBCPP_CONSTEXPR const int min_exponent10 = __base::min_exponent10;
|
|
static _LIBCPP_CONSTEXPR const int max_exponent = __base::max_exponent;
|
|
static _LIBCPP_CONSTEXPR const int max_exponent10 = __base::max_exponent10;
|
|
|
|
static _LIBCPP_CONSTEXPR const bool has_infinity = __base::has_infinity;
|
|
static _LIBCPP_CONSTEXPR const bool has_quiet_NaN = __base::has_quiet_NaN;
|
|
static _LIBCPP_CONSTEXPR const bool has_signaling_NaN = __base::has_signaling_NaN;
|
|
static _LIBCPP_CONSTEXPR const float_denorm_style has_denorm = __base::has_denorm;
|
|
static _LIBCPP_CONSTEXPR const bool has_denorm_loss = __base::has_denorm_loss;
|
|
_LIBCPP_INLINE_VISIBILITY static _LIBCPP_CONSTEXPR type infinity() _NOEXCEPT {return __base::infinity();}
|
|
_LIBCPP_INLINE_VISIBILITY static _LIBCPP_CONSTEXPR type quiet_NaN() _NOEXCEPT {return __base::quiet_NaN();}
|
|
_LIBCPP_INLINE_VISIBILITY static _LIBCPP_CONSTEXPR type signaling_NaN() _NOEXCEPT {return __base::signaling_NaN();}
|
|
_LIBCPP_INLINE_VISIBILITY static _LIBCPP_CONSTEXPR type denorm_min() _NOEXCEPT {return __base::denorm_min();}
|
|
|
|
static _LIBCPP_CONSTEXPR const bool is_iec559 = __base::is_iec559;
|
|
static _LIBCPP_CONSTEXPR const bool is_bounded = __base::is_bounded;
|
|
static _LIBCPP_CONSTEXPR const bool is_modulo = __base::is_modulo;
|
|
|
|
static _LIBCPP_CONSTEXPR const bool traps = __base::traps;
|
|
static _LIBCPP_CONSTEXPR const bool tinyness_before = __base::tinyness_before;
|
|
static _LIBCPP_CONSTEXPR const float_round_style round_style = __base::round_style;
|
|
};
|
|
|
|
template <class _Tp>
|
|
_LIBCPP_CONSTEXPR const bool numeric_limits<const _Tp>::is_specialized;
|
|
template <class _Tp>
|
|
_LIBCPP_CONSTEXPR const int numeric_limits<const _Tp>::digits;
|
|
template <class _Tp>
|
|
_LIBCPP_CONSTEXPR const int numeric_limits<const _Tp>::digits10;
|
|
template <class _Tp>
|
|
_LIBCPP_CONSTEXPR const int numeric_limits<const _Tp>::max_digits10;
|
|
template <class _Tp>
|
|
_LIBCPP_CONSTEXPR const bool numeric_limits<const _Tp>::is_signed;
|
|
template <class _Tp>
|
|
_LIBCPP_CONSTEXPR const bool numeric_limits<const _Tp>::is_integer;
|
|
template <class _Tp>
|
|
_LIBCPP_CONSTEXPR const bool numeric_limits<const _Tp>::is_exact;
|
|
template <class _Tp>
|
|
_LIBCPP_CONSTEXPR const int numeric_limits<const _Tp>::radix;
|
|
template <class _Tp>
|
|
_LIBCPP_CONSTEXPR const int numeric_limits<const _Tp>::min_exponent;
|
|
template <class _Tp>
|
|
_LIBCPP_CONSTEXPR const int numeric_limits<const _Tp>::min_exponent10;
|
|
template <class _Tp>
|
|
_LIBCPP_CONSTEXPR const int numeric_limits<const _Tp>::max_exponent;
|
|
template <class _Tp>
|
|
_LIBCPP_CONSTEXPR const int numeric_limits<const _Tp>::max_exponent10;
|
|
template <class _Tp>
|
|
_LIBCPP_CONSTEXPR const bool numeric_limits<const _Tp>::has_infinity;
|
|
template <class _Tp>
|
|
_LIBCPP_CONSTEXPR const bool numeric_limits<const _Tp>::has_quiet_NaN;
|
|
template <class _Tp>
|
|
_LIBCPP_CONSTEXPR const bool numeric_limits<const _Tp>::has_signaling_NaN;
|
|
template <class _Tp>
|
|
_LIBCPP_CONSTEXPR const float_denorm_style numeric_limits<const _Tp>::has_denorm;
|
|
template <class _Tp>
|
|
_LIBCPP_CONSTEXPR const bool numeric_limits<const _Tp>::has_denorm_loss;
|
|
template <class _Tp>
|
|
_LIBCPP_CONSTEXPR const bool numeric_limits<const _Tp>::is_iec559;
|
|
template <class _Tp>
|
|
_LIBCPP_CONSTEXPR const bool numeric_limits<const _Tp>::is_bounded;
|
|
template <class _Tp>
|
|
_LIBCPP_CONSTEXPR const bool numeric_limits<const _Tp>::is_modulo;
|
|
template <class _Tp>
|
|
_LIBCPP_CONSTEXPR const bool numeric_limits<const _Tp>::traps;
|
|
template <class _Tp>
|
|
_LIBCPP_CONSTEXPR const bool numeric_limits<const _Tp>::tinyness_before;
|
|
template <class _Tp>
|
|
_LIBCPP_CONSTEXPR const float_round_style numeric_limits<const _Tp>::round_style;
|
|
|
|
template <class _Tp>
|
|
class _LIBCPP_TYPE_VIS_ONLY numeric_limits<volatile _Tp>
|
|
: private numeric_limits<_Tp>
|
|
{
|
|
typedef numeric_limits<_Tp> __base;
|
|
typedef _Tp type;
|
|
public:
|
|
static _LIBCPP_CONSTEXPR const bool is_specialized = __base::is_specialized;
|
|
_LIBCPP_INLINE_VISIBILITY static _LIBCPP_CONSTEXPR type min() _NOEXCEPT {return __base::min();}
|
|
_LIBCPP_INLINE_VISIBILITY static _LIBCPP_CONSTEXPR type max() _NOEXCEPT {return __base::max();}
|
|
_LIBCPP_INLINE_VISIBILITY static _LIBCPP_CONSTEXPR type lowest() _NOEXCEPT {return __base::lowest();}
|
|
|
|
static _LIBCPP_CONSTEXPR const int digits = __base::digits;
|
|
static _LIBCPP_CONSTEXPR const int digits10 = __base::digits10;
|
|
static _LIBCPP_CONSTEXPR const int max_digits10 = __base::max_digits10;
|
|
static _LIBCPP_CONSTEXPR const bool is_signed = __base::is_signed;
|
|
static _LIBCPP_CONSTEXPR const bool is_integer = __base::is_integer;
|
|
static _LIBCPP_CONSTEXPR const bool is_exact = __base::is_exact;
|
|
static _LIBCPP_CONSTEXPR const int radix = __base::radix;
|
|
_LIBCPP_INLINE_VISIBILITY static _LIBCPP_CONSTEXPR type epsilon() _NOEXCEPT {return __base::epsilon();}
|
|
_LIBCPP_INLINE_VISIBILITY static _LIBCPP_CONSTEXPR type round_error() _NOEXCEPT {return __base::round_error();}
|
|
|
|
static _LIBCPP_CONSTEXPR const int min_exponent = __base::min_exponent;
|
|
static _LIBCPP_CONSTEXPR const int min_exponent10 = __base::min_exponent10;
|
|
static _LIBCPP_CONSTEXPR const int max_exponent = __base::max_exponent;
|
|
static _LIBCPP_CONSTEXPR const int max_exponent10 = __base::max_exponent10;
|
|
|
|
static _LIBCPP_CONSTEXPR const bool has_infinity = __base::has_infinity;
|
|
static _LIBCPP_CONSTEXPR const bool has_quiet_NaN = __base::has_quiet_NaN;
|
|
static _LIBCPP_CONSTEXPR const bool has_signaling_NaN = __base::has_signaling_NaN;
|
|
static _LIBCPP_CONSTEXPR const float_denorm_style has_denorm = __base::has_denorm;
|
|
static _LIBCPP_CONSTEXPR const bool has_denorm_loss = __base::has_denorm_loss;
|
|
_LIBCPP_INLINE_VISIBILITY static _LIBCPP_CONSTEXPR type infinity() _NOEXCEPT {return __base::infinity();}
|
|
_LIBCPP_INLINE_VISIBILITY static _LIBCPP_CONSTEXPR type quiet_NaN() _NOEXCEPT {return __base::quiet_NaN();}
|
|
_LIBCPP_INLINE_VISIBILITY static _LIBCPP_CONSTEXPR type signaling_NaN() _NOEXCEPT {return __base::signaling_NaN();}
|
|
_LIBCPP_INLINE_VISIBILITY static _LIBCPP_CONSTEXPR type denorm_min() _NOEXCEPT {return __base::denorm_min();}
|
|
|
|
static _LIBCPP_CONSTEXPR const bool is_iec559 = __base::is_iec559;
|
|
static _LIBCPP_CONSTEXPR const bool is_bounded = __base::is_bounded;
|
|
static _LIBCPP_CONSTEXPR const bool is_modulo = __base::is_modulo;
|
|
|
|
static _LIBCPP_CONSTEXPR const bool traps = __base::traps;
|
|
static _LIBCPP_CONSTEXPR const bool tinyness_before = __base::tinyness_before;
|
|
static _LIBCPP_CONSTEXPR const float_round_style round_style = __base::round_style;
|
|
};
|
|
|
|
template <class _Tp>
|
|
_LIBCPP_CONSTEXPR const bool numeric_limits<volatile _Tp>::is_specialized;
|
|
template <class _Tp>
|
|
_LIBCPP_CONSTEXPR const int numeric_limits<volatile _Tp>::digits;
|
|
template <class _Tp>
|
|
_LIBCPP_CONSTEXPR const int numeric_limits<volatile _Tp>::digits10;
|
|
template <class _Tp>
|
|
_LIBCPP_CONSTEXPR const int numeric_limits<volatile _Tp>::max_digits10;
|
|
template <class _Tp>
|
|
_LIBCPP_CONSTEXPR const bool numeric_limits<volatile _Tp>::is_signed;
|
|
template <class _Tp>
|
|
_LIBCPP_CONSTEXPR const bool numeric_limits<volatile _Tp>::is_integer;
|
|
template <class _Tp>
|
|
_LIBCPP_CONSTEXPR const bool numeric_limits<volatile _Tp>::is_exact;
|
|
template <class _Tp>
|
|
_LIBCPP_CONSTEXPR const int numeric_limits<volatile _Tp>::radix;
|
|
template <class _Tp>
|
|
_LIBCPP_CONSTEXPR const int numeric_limits<volatile _Tp>::min_exponent;
|
|
template <class _Tp>
|
|
_LIBCPP_CONSTEXPR const int numeric_limits<volatile _Tp>::min_exponent10;
|
|
template <class _Tp>
|
|
_LIBCPP_CONSTEXPR const int numeric_limits<volatile _Tp>::max_exponent;
|
|
template <class _Tp>
|
|
_LIBCPP_CONSTEXPR const int numeric_limits<volatile _Tp>::max_exponent10;
|
|
template <class _Tp>
|
|
_LIBCPP_CONSTEXPR const bool numeric_limits<volatile _Tp>::has_infinity;
|
|
template <class _Tp>
|
|
_LIBCPP_CONSTEXPR const bool numeric_limits<volatile _Tp>::has_quiet_NaN;
|
|
template <class _Tp>
|
|
_LIBCPP_CONSTEXPR const bool numeric_limits<volatile _Tp>::has_signaling_NaN;
|
|
template <class _Tp>
|
|
_LIBCPP_CONSTEXPR const float_denorm_style numeric_limits<volatile _Tp>::has_denorm;
|
|
template <class _Tp>
|
|
_LIBCPP_CONSTEXPR const bool numeric_limits<volatile _Tp>::has_denorm_loss;
|
|
template <class _Tp>
|
|
_LIBCPP_CONSTEXPR const bool numeric_limits<volatile _Tp>::is_iec559;
|
|
template <class _Tp>
|
|
_LIBCPP_CONSTEXPR const bool numeric_limits<volatile _Tp>::is_bounded;
|
|
template <class _Tp>
|
|
_LIBCPP_CONSTEXPR const bool numeric_limits<volatile _Tp>::is_modulo;
|
|
template <class _Tp>
|
|
_LIBCPP_CONSTEXPR const bool numeric_limits<volatile _Tp>::traps;
|
|
template <class _Tp>
|
|
_LIBCPP_CONSTEXPR const bool numeric_limits<volatile _Tp>::tinyness_before;
|
|
template <class _Tp>
|
|
_LIBCPP_CONSTEXPR const float_round_style numeric_limits<volatile _Tp>::round_style;
|
|
|
|
template <class _Tp>
|
|
class _LIBCPP_TYPE_VIS_ONLY numeric_limits<const volatile _Tp>
|
|
: private numeric_limits<_Tp>
|
|
{
|
|
typedef numeric_limits<_Tp> __base;
|
|
typedef _Tp type;
|
|
public:
|
|
static _LIBCPP_CONSTEXPR const bool is_specialized = __base::is_specialized;
|
|
_LIBCPP_INLINE_VISIBILITY static _LIBCPP_CONSTEXPR type min() _NOEXCEPT {return __base::min();}
|
|
_LIBCPP_INLINE_VISIBILITY static _LIBCPP_CONSTEXPR type max() _NOEXCEPT {return __base::max();}
|
|
_LIBCPP_INLINE_VISIBILITY static _LIBCPP_CONSTEXPR type lowest() _NOEXCEPT {return __base::lowest();}
|
|
|
|
static _LIBCPP_CONSTEXPR const int digits = __base::digits;
|
|
static _LIBCPP_CONSTEXPR const int digits10 = __base::digits10;
|
|
static _LIBCPP_CONSTEXPR const int max_digits10 = __base::max_digits10;
|
|
static _LIBCPP_CONSTEXPR const bool is_signed = __base::is_signed;
|
|
static _LIBCPP_CONSTEXPR const bool is_integer = __base::is_integer;
|
|
static _LIBCPP_CONSTEXPR const bool is_exact = __base::is_exact;
|
|
static _LIBCPP_CONSTEXPR const int radix = __base::radix;
|
|
_LIBCPP_INLINE_VISIBILITY static _LIBCPP_CONSTEXPR type epsilon() _NOEXCEPT {return __base::epsilon();}
|
|
_LIBCPP_INLINE_VISIBILITY static _LIBCPP_CONSTEXPR type round_error() _NOEXCEPT {return __base::round_error();}
|
|
|
|
static _LIBCPP_CONSTEXPR const int min_exponent = __base::min_exponent;
|
|
static _LIBCPP_CONSTEXPR const int min_exponent10 = __base::min_exponent10;
|
|
static _LIBCPP_CONSTEXPR const int max_exponent = __base::max_exponent;
|
|
static _LIBCPP_CONSTEXPR const int max_exponent10 = __base::max_exponent10;
|
|
|
|
static _LIBCPP_CONSTEXPR const bool has_infinity = __base::has_infinity;
|
|
static _LIBCPP_CONSTEXPR const bool has_quiet_NaN = __base::has_quiet_NaN;
|
|
static _LIBCPP_CONSTEXPR const bool has_signaling_NaN = __base::has_signaling_NaN;
|
|
static _LIBCPP_CONSTEXPR const float_denorm_style has_denorm = __base::has_denorm;
|
|
static _LIBCPP_CONSTEXPR const bool has_denorm_loss = __base::has_denorm_loss;
|
|
_LIBCPP_INLINE_VISIBILITY static _LIBCPP_CONSTEXPR type infinity() _NOEXCEPT {return __base::infinity();}
|
|
_LIBCPP_INLINE_VISIBILITY static _LIBCPP_CONSTEXPR type quiet_NaN() _NOEXCEPT {return __base::quiet_NaN();}
|
|
_LIBCPP_INLINE_VISIBILITY static _LIBCPP_CONSTEXPR type signaling_NaN() _NOEXCEPT {return __base::signaling_NaN();}
|
|
_LIBCPP_INLINE_VISIBILITY static _LIBCPP_CONSTEXPR type denorm_min() _NOEXCEPT {return __base::denorm_min();}
|
|
|
|
static _LIBCPP_CONSTEXPR const bool is_iec559 = __base::is_iec559;
|
|
static _LIBCPP_CONSTEXPR const bool is_bounded = __base::is_bounded;
|
|
static _LIBCPP_CONSTEXPR const bool is_modulo = __base::is_modulo;
|
|
|
|
static _LIBCPP_CONSTEXPR const bool traps = __base::traps;
|
|
static _LIBCPP_CONSTEXPR const bool tinyness_before = __base::tinyness_before;
|
|
static _LIBCPP_CONSTEXPR const float_round_style round_style = __base::round_style;
|
|
};
|
|
|
|
template <class _Tp>
|
|
_LIBCPP_CONSTEXPR const bool numeric_limits<const volatile _Tp>::is_specialized;
|
|
template <class _Tp>
|
|
_LIBCPP_CONSTEXPR const int numeric_limits<const volatile _Tp>::digits;
|
|
template <class _Tp>
|
|
_LIBCPP_CONSTEXPR const int numeric_limits<const volatile _Tp>::digits10;
|
|
template <class _Tp>
|
|
_LIBCPP_CONSTEXPR const int numeric_limits<const volatile _Tp>::max_digits10;
|
|
template <class _Tp>
|
|
_LIBCPP_CONSTEXPR const bool numeric_limits<const volatile _Tp>::is_signed;
|
|
template <class _Tp>
|
|
_LIBCPP_CONSTEXPR const bool numeric_limits<const volatile _Tp>::is_integer;
|
|
template <class _Tp>
|
|
_LIBCPP_CONSTEXPR const bool numeric_limits<const volatile _Tp>::is_exact;
|
|
template <class _Tp>
|
|
_LIBCPP_CONSTEXPR const int numeric_limits<const volatile _Tp>::radix;
|
|
template <class _Tp>
|
|
_LIBCPP_CONSTEXPR const int numeric_limits<const volatile _Tp>::min_exponent;
|
|
template <class _Tp>
|
|
_LIBCPP_CONSTEXPR const int numeric_limits<const volatile _Tp>::min_exponent10;
|
|
template <class _Tp>
|
|
_LIBCPP_CONSTEXPR const int numeric_limits<const volatile _Tp>::max_exponent;
|
|
template <class _Tp>
|
|
_LIBCPP_CONSTEXPR const int numeric_limits<const volatile _Tp>::max_exponent10;
|
|
template <class _Tp>
|
|
_LIBCPP_CONSTEXPR const bool numeric_limits<const volatile _Tp>::has_infinity;
|
|
template <class _Tp>
|
|
_LIBCPP_CONSTEXPR const bool numeric_limits<const volatile _Tp>::has_quiet_NaN;
|
|
template <class _Tp>
|
|
_LIBCPP_CONSTEXPR const bool numeric_limits<const volatile _Tp>::has_signaling_NaN;
|
|
template <class _Tp>
|
|
_LIBCPP_CONSTEXPR const float_denorm_style numeric_limits<const volatile _Tp>::has_denorm;
|
|
template <class _Tp>
|
|
_LIBCPP_CONSTEXPR const bool numeric_limits<const volatile _Tp>::has_denorm_loss;
|
|
template <class _Tp>
|
|
_LIBCPP_CONSTEXPR const bool numeric_limits<const volatile _Tp>::is_iec559;
|
|
template <class _Tp>
|
|
_LIBCPP_CONSTEXPR const bool numeric_limits<const volatile _Tp>::is_bounded;
|
|
template <class _Tp>
|
|
_LIBCPP_CONSTEXPR const bool numeric_limits<const volatile _Tp>::is_modulo;
|
|
template <class _Tp>
|
|
_LIBCPP_CONSTEXPR const bool numeric_limits<const volatile _Tp>::traps;
|
|
template <class _Tp>
|
|
_LIBCPP_CONSTEXPR const bool numeric_limits<const volatile _Tp>::tinyness_before;
|
|
template <class _Tp>
|
|
_LIBCPP_CONSTEXPR const float_round_style numeric_limits<const volatile _Tp>::round_style;
|
|
|
|
_LIBCPP_END_NAMESPACE_STD
|
|
|
|
#endif // _LIBCPP_LIMITS
|