$include_dir="/home/hyper-archives/boost-commit/include"; include("$include_dir/msg-header.inc") ?>
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;
   };