annotate DEPENDENCIES/generic/include/boost/units/limits.hpp @ 16:2665513ce2d3

Add boost headers
author Chris Cannam
date Tue, 05 Aug 2014 11:11:38 +0100
parents
children c530137014c0
rev   line source
Chris@16 1 // Boost.Units - A C++ library for zero-overhead dimensional analysis and
Chris@16 2 // unit/quantity manipulation and conversion
Chris@16 3 //
Chris@16 4 // Copyright (C) 2003-2008 Matthias Christian Schabel
Chris@16 5 // Copyright (C) 2007-2008 Steven Watanabe
Chris@16 6 //
Chris@16 7 // Distributed under the Boost Software License, Version 1.0. (See
Chris@16 8 // accompanying file LICENSE_1_0.txt or copy at
Chris@16 9 // http://www.boost.org/LICENSE_1_0.txt)
Chris@16 10
Chris@16 11 #ifndef BOOST_UNITS_LIMITS_HPP
Chris@16 12 #define BOOST_UNITS_LIMITS_HPP
Chris@16 13
Chris@16 14 ///
Chris@16 15 /// \file
Chris@16 16 /// \brief specialize std::numeric_limits for units.
Chris@16 17 ///
Chris@16 18
Chris@16 19 #include <limits>
Chris@16 20
Chris@16 21 #include <boost/units/units_fwd.hpp>
Chris@16 22
Chris@16 23 namespace std {
Chris@16 24
Chris@16 25 template<class Unit, class T>
Chris@16 26 class numeric_limits< ::boost::units::quantity<Unit, T> >
Chris@16 27 {
Chris@16 28 public:
Chris@16 29 typedef ::boost::units::quantity<Unit, T> quantity_type;
Chris@16 30 static const bool is_specialized = std::numeric_limits<T>::is_specialized;
Chris@16 31 static quantity_type (min)() { return(quantity_type::from_value((std::numeric_limits<T>::min)())); }
Chris@16 32 static quantity_type (max)() { return(quantity_type::from_value((std::numeric_limits<T>::max)())); }
Chris@16 33 static const int digits = std::numeric_limits<T>::digits;
Chris@16 34 static const int digits10 = std::numeric_limits<T>::digits10;
Chris@16 35 static const bool is_signed = std::numeric_limits<T>::is_signed;
Chris@16 36 static const bool is_integer = std::numeric_limits<T>::is_integer;
Chris@16 37 static const bool is_exact = std::numeric_limits<T>::is_exact;
Chris@16 38 static const int radix = std::numeric_limits<T>::radix;
Chris@16 39 static quantity_type epsilon() { return(quantity_type::from_value(std::numeric_limits<T>::epsilon())); }
Chris@16 40 static quantity_type round_error() { return(quantity_type::from_value(std::numeric_limits<T>::round_error())); }
Chris@16 41 static const int min_exponent = std::numeric_limits<T>::min_exponent;
Chris@16 42 static const int min_exponent10 = std::numeric_limits<T>::min_exponent10;
Chris@16 43 static const int max_exponent = std::numeric_limits<T>::max_exponent;
Chris@16 44 static const int max_exponent10 = std::numeric_limits<T>::max_exponent10;
Chris@16 45 static const bool has_infinity = std::numeric_limits<T>::has_infinity;
Chris@16 46 static const bool has_quiet_NaN = std::numeric_limits<T>::has_quiet_NaN;
Chris@16 47 static const bool has_signaling_NaN = std::numeric_limits<T>::has_signaling_NaN;
Chris@16 48 static const bool has_denorm_loss = std::numeric_limits<T>::has_denorm_loss;
Chris@16 49 static quantity_type infinity() { return(quantity_type::from_value(std::numeric_limits<T>::infinity())); }
Chris@16 50 static quantity_type quiet_NaN() { return(quantity_type::from_value(std::numeric_limits<T>::quiet_NaN())); }
Chris@16 51 static quantity_type signaling_NaN() { return(quantity_type::from_value(std::numeric_limits<T>::signaling_NaN())); }
Chris@16 52 static quantity_type denorm_min() { return(quantity_type::from_value(std::numeric_limits<T>::denorm_min())); }
Chris@16 53 static const bool is_iec559 = std::numeric_limits<T>::is_iec559;
Chris@16 54 static const bool is_bounded = std::numeric_limits<T>::is_bounded;
Chris@16 55 static const bool is_modulo = std::numeric_limits<T>::is_modulo;
Chris@16 56 static const bool traps = std::numeric_limits<T>::traps;
Chris@16 57 static const bool tinyness_before = std::numeric_limits<T>::tinyness_before;
Chris@16 58 #if defined(_STLP_STATIC_CONST_INIT_BUG)
Chris@16 59 static const int has_denorm = std::numeric_limits<T>::has_denorm;
Chris@16 60 static const int round_style = std::numeric_limits<T>::round_style;
Chris@16 61 #else
Chris@16 62 static const float_denorm_style has_denorm = std::numeric_limits<T>::has_denorm;
Chris@16 63 static const float_round_style round_style = std::numeric_limits<T>::round_style;
Chris@16 64 #endif
Chris@16 65 };
Chris@16 66
Chris@16 67 }
Chris@16 68
Chris@16 69 #endif // BOOST_UNITS_LIMITS_HPP