Boost logo

Boost-Commit :

From: dwalker07_at_[hidden]
Date: 2008-07-13 19:30:18


Author: dlwalker
Date: 2008-07-13 19:30:18 EDT (Sun, 13 Jul 2008)
New Revision: 47408
URL: http://svn.boost.org/trac/boost/changeset/47408

Log:
Re-did implementation
Text files modified:
   trunk/boost/integer.hpp | 148 +++++++++++++++++++++++++++------------
   1 files changed, 102 insertions(+), 46 deletions(-)

Modified: trunk/boost/integer.hpp
==============================================================================
--- trunk/boost/integer.hpp (original)
+++ trunk/boost/integer.hpp 2008-07-13 19:30:18 EDT (Sun, 13 Jul 2008)
@@ -7,6 +7,7 @@
 // See http://www.boost.org/libs/integer for documentation.
 
 // Revision History
+// 13 Jul 08 Redid implmentation. (Daryle Walker)
 // 22 Sep 01 Added value-based integer templates. (Daryle Walker)
 // 01 Apr 01 Modified to use new <boost/limits.hpp> header. (John Maddock)
 // 30 Jul 00 Add typename syntax fix (Jens Maurer)
@@ -17,33 +18,105 @@
 
 #include <boost/integer_fwd.hpp> // self include
 
+#include <boost/config.hpp> // for BOOST_STATIC_CONSTANT
 #include <boost/integer_traits.hpp> // for boost::integer_traits
 #include <boost/limits.hpp> // for std::numeric_limits
 
 namespace boost
 {
 
- // Helper templates ------------------------------------------------------//
+ // integer template mapping a type to its processor-optimized analog -----//
 
   // fast integers from least integers
   // int_fast_t<> works correctly for unsigned too, in spite of the name.
   template< typename LeastInt >
   struct int_fast_t { typedef LeastInt fast; }; // imps may specialize
 
- // convert category to type
- template< int Category > struct int_least_helper {}; // default is empty
+namespace detail
+{
+
+ // Helper templates ------------------------------------------------------//
+
+ // convert integer category to type ; default is empty
+ template< int Rank, typename Signedness > struct int_least_helper {};
+
+ // specializatons: 1=(unsigned) long, 2=unsigned/int, 3=(unsigned) short,
+ // 4=(un)signed char
+ // no specializations for 0: requests for a type > (unsigned) long are in
+ // error
+ template<> struct int_least_helper<1, signed> { typedef long least; };
+ template<> struct int_least_helper<1, unsigned>
+ { typedef unsigned long least; };
+ template<> struct int_least_helper<2, signed> { typedef int least; };
+ template<> struct int_least_helper<2, unsigned>
+ { typedef unsigned int least; };
+ template<> struct int_least_helper<3, signed> { typedef short least; };
+ template<> struct int_least_helper<3, unsigned>
+ { typedef unsigned short least; };
+ template<> struct int_least_helper<4, signed> { typedef signed char least; };
+ template<> struct int_least_helper<4, unsigned>
+ { typedef unsigned char least; };
+
+ // category bounds
+ enum
+ {
+ lowest_integral_rank = 1,
+ highest_integral_rank = 4
+ };
+
+ // map a bit count to a category
+ template < int BitsIncludingSign >
+ struct int_rank_helper
+ {
+ BOOST_STATIC_CONSTANT( int, rank =
+ (BitsIncludingSign - 1 <= std::numeric_limits< long >::digits) +
+ (BitsIncludingSign - 1 <= std::numeric_limits< int >::digits) +
+ (BitsIncludingSign - 1 <= std::numeric_limits< short >::digits) +
+ (BitsIncludingSign - 1 <= std::numeric_limits< signed char >::digits) );
+ };
+
+ template < int Bits >
+ struct uint_rank_helper
+ {
+ BOOST_STATIC_CONSTANT( int, rank =
+ (Bits <= std::numeric_limits< unsigned long >::digits) +
+ (Bits <= std::numeric_limits< unsigned int >::digits) +
+ (Bits <= std::numeric_limits< unsigned short >::digits) +
+ (Bits <= std::numeric_limits< unsigned char >::digits) );
+ };
+
+ // map an extreme value to a category
+ template < long MaxValue >
+ struct int_max_rank_helper
+ {
+ BOOST_STATIC_CONSTANT( int, rank =
+ (MaxValue <= integer_traits< long >::const_max) +
+ (MaxValue <= integer_traits< int >::const_max) +
+ (MaxValue <= integer_traits< short >::const_max) +
+ (MaxValue <= integer_traits< signed char >::const_max) );
+ };
+
+ template < long MinValue >
+ struct int_min_rank_helper
+ {
+ BOOST_STATIC_CONSTANT( int, rank =
+ (MinValue >= integer_traits< long >::const_min) +
+ (MinValue >= integer_traits< int >::const_min) +
+ (MinValue >= integer_traits< short >::const_min) +
+ (MinValue >= integer_traits< signed char >::const_min) );
+ };
+
+ template < unsigned long Value >
+ struct uint_max_rank_helper
+ {
+ BOOST_STATIC_CONSTANT( int, rank =
+ (Value <= integer_traits< unsigned long >::const_max) +
+ (Value <= integer_traits< unsigned int >::const_max) +
+ (Value <= integer_traits< unsigned short >::const_max) +
+ (Value <= integer_traits< unsigned char >::const_max) );
+ };
 
- // specializatons: 1=long, 2=int, 3=short, 4=signed char,
- // 6=unsigned long, 7=unsigned int, 8=unsigned short, 9=unsigned char
- // no specializations for 0 and 5: requests for a type > long are in error
- template<> struct int_least_helper<1> { typedef long least; };
- template<> struct int_least_helper<2> { typedef int least; };
- template<> struct int_least_helper<3> { typedef short least; };
- template<> struct int_least_helper<4> { typedef signed char least; };
- template<> struct int_least_helper<6> { typedef unsigned long least; };
- template<> struct int_least_helper<7> { typedef unsigned int least; };
- template<> struct int_least_helper<8> { typedef unsigned short least; };
- template<> struct int_least_helper<9> { typedef unsigned char least; };
+} // namespace detail
 
   // integer templates specifying number of bits ---------------------------//
 
@@ -51,13 +124,10 @@
   template< int Bits > // bits (including sign) required
   struct int_t
   {
- typedef typename int_least_helper
+ typedef typename detail::int_least_helper
         <
- (Bits-1 <= std::numeric_limits<long>::digits) +
- (Bits-1 <= std::numeric_limits<int>::digits) +
- (Bits-1 <= std::numeric_limits<short>::digits) +
- (Bits-1 <= std::numeric_limits<signed char>::digits)
- >::least least;
+ detail::int_rank_helper<Bits>::rank,
+ signed>::least least;
       typedef typename int_fast_t<least>::fast fast;
   };
 
@@ -65,14 +135,10 @@
   template< int Bits > // bits required
   struct uint_t
   {
- typedef typename int_least_helper
+ typedef typename detail::int_least_helper
         <
- 5 +
- (Bits <= std::numeric_limits<unsigned long>::digits) +
- (Bits <= std::numeric_limits<unsigned int>::digits) +
- (Bits <= std::numeric_limits<unsigned short>::digits) +
- (Bits <= std::numeric_limits<unsigned char>::digits)
- >::least least;
+ detail::uint_rank_helper<Bits>::rank,
+ unsigned>::least least;
       typedef typename int_fast_t<least>::fast fast;
       // int_fast_t<> works correctly for unsigned too, in spite of the name.
   };
@@ -83,26 +149,20 @@
   template< long MaxValue > // maximum value to require support
   struct int_max_value_t
   {
- typedef typename int_least_helper
+ typedef typename detail::int_least_helper
         <
- (MaxValue <= integer_traits<long>::const_max) +
- (MaxValue <= integer_traits<int>::const_max) +
- (MaxValue <= integer_traits<short>::const_max) +
- (MaxValue <= integer_traits<signed char>::const_max)
- >::least least;
+ detail::int_max_rank_helper<MaxValue>::rank,
+ signed>::least least;
       typedef typename int_fast_t<least>::fast fast;
   };
 
   template< long MinValue > // minimum value to require support
   struct int_min_value_t
   {
- typedef typename int_least_helper
+ typedef typename detail::int_least_helper
         <
- (MinValue >= integer_traits<long>::const_min) +
- (MinValue >= integer_traits<int>::const_min) +
- (MinValue >= integer_traits<short>::const_min) +
- (MinValue >= integer_traits<signed char>::const_min)
- >::least least;
+ detail::int_min_rank_helper<MinValue>::rank,
+ signed>::least least;
       typedef typename int_fast_t<least>::fast fast;
   };
 
@@ -110,14 +170,10 @@
   template< unsigned long Value > // maximum value to require support
   struct uint_value_t
   {
- typedef typename int_least_helper
+ typedef typename detail::int_least_helper
         <
- 5 +
- (Value <= integer_traits<unsigned long>::const_max) +
- (Value <= integer_traits<unsigned int>::const_max) +
- (Value <= integer_traits<unsigned short>::const_max) +
- (Value <= integer_traits<unsigned char>::const_max)
- >::least least;
+ detail::uint_max_rank_helper<Value>::rank,
+ unsigned>::least least;
       typedef typename int_fast_t<least>::fast fast;
   };
 


Boost-Commit list run by bdawes at acm.org, david.abrahams at rcn.com, gregod at cs.rpi.edu, cpdaniel at pacbell.net, john at johnmaddock.co.uk