epoc32/include/stdapis/boost/detail/dynamic_bitset.hpp
author William Roberts <williamr@symbian.org>
Wed, 31 Mar 2010 12:33:34 +0100
branchSymbian3
changeset 4 837f303aceeb
parent 3 e1b950c65cb4
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@2
     1
// --------------------------------------------------
williamr@2
     2
//
williamr@2
     3
// (C) Copyright Chuck Allison and Jeremy Siek 2001 - 2002.
williamr@2
     4
// (C) Copyright Gennaro Prota                 2003 - 2004.
williamr@2
     5
//
williamr@2
     6
// Distributed under the Boost Software License, Version 1.0.
williamr@2
     7
//    (See accompanying file LICENSE_1_0.txt or copy at
williamr@2
     8
//          http://www.boost.org/LICENSE_1_0.txt)
williamr@2
     9
//
williamr@2
    10
// -----------------------------------------------------------
williamr@2
    11
williamr@2
    12
//  See http://www.boost.org/libs/dynamic_bitset for documentation.
williamr@2
    13
williamr@2
    14
williamr@4
    15
#ifndef BOOST_DETAIL_DYNAMIC_BITSET_HPP
williamr@4
    16
#define BOOST_DETAIL_DYNAMIC_BITSET_HPP
williamr@2
    17
williamr@4
    18
#include <cstddef> // for std::size_t
williamr@4
    19
#include "boost/config.hpp"
williamr@4
    20
#include "boost/detail/workaround.hpp"
williamr@4
    21
//#include "boost/static_assert.hpp" // gps
williamr@2
    22
williamr@2
    23
williamr@2
    24
namespace boost {
williamr@2
    25
williamr@4
    26
  namespace detail {
williamr@2
    27
williamr@4
    28
    // Gives (read-)access to the object representation
williamr@4
    29
    // of an object of type T (3.9p4). CANNOT be used
williamr@4
    30
    // on a base sub-object
williamr@4
    31
    //
williamr@4
    32
    template <typename T>
williamr@4
    33
    inline const unsigned char * object_representation (T* p)
williamr@4
    34
    {
williamr@4
    35
        return static_cast<const unsigned char *>(static_cast<const void *>(p));
williamr@4
    36
    }
williamr@2
    37
williamr@2
    38
williamr@4
    39
    // ------- count function implementation --------------
williamr@2
    40
williamr@4
    41
    namespace dynamic_bitset_count_impl {
williamr@2
    42
williamr@4
    43
    typedef unsigned char byte_type;
williamr@2
    44
williamr@4
    45
    enum mode { access_by_bytes, access_by_blocks };
williamr@2
    46
williamr@4
    47
    template <mode> struct mode_to_type {};
williamr@2
    48
williamr@4
    49
    // the table: wrapped in a class template, so
williamr@4
    50
    // that it is only instantiated if/when needed
williamr@2
    51
    //
williamr@4
    52
    template <bool dummy_name = true>
williamr@4
    53
    struct count_table { static const byte_type table[]; };
williamr@2
    54
williamr@4
    55
    template <>
williamr@4
    56
    struct count_table<false> { /* no table */ };
williamr@2
    57
williamr@2
    58
williamr@4
    59
     const unsigned int table_width = 8;
williamr@4
    60
     template <bool b>
williamr@4
    61
     const byte_type count_table<b>::table[] =
williamr@4
    62
     {
williamr@4
    63
       // Automatically generated by GPTableGen.exe v.1.0
williamr@4
    64
       //
williamr@4
    65
     0, 1, 1, 2, 1, 2, 2, 3, 1, 2, 2, 3, 2, 3, 3, 4, 1, 2, 2, 3, 2, 3, 3, 4, 2, 3, 3, 4, 3, 4, 4, 5,
williamr@4
    66
     1, 2, 2, 3, 2, 3, 3, 4, 2, 3, 3, 4, 3, 4, 4, 5, 2, 3, 3, 4, 3, 4, 4, 5, 3, 4, 4, 5, 4, 5, 5, 6,
williamr@4
    67
     1, 2, 2, 3, 2, 3, 3, 4, 2, 3, 3, 4, 3, 4, 4, 5, 2, 3, 3, 4, 3, 4, 4, 5, 3, 4, 4, 5, 4, 5, 5, 6,
williamr@4
    68
     2, 3, 3, 4, 3, 4, 4, 5, 3, 4, 4, 5, 4, 5, 5, 6, 3, 4, 4, 5, 4, 5, 5, 6, 4, 5, 5, 6, 5, 6, 6, 7,
williamr@4
    69
     1, 2, 2, 3, 2, 3, 3, 4, 2, 3, 3, 4, 3, 4, 4, 5, 2, 3, 3, 4, 3, 4, 4, 5, 3, 4, 4, 5, 4, 5, 5, 6,
williamr@4
    70
     2, 3, 3, 4, 3, 4, 4, 5, 3, 4, 4, 5, 4, 5, 5, 6, 3, 4, 4, 5, 4, 5, 5, 6, 4, 5, 5, 6, 5, 6, 6, 7,
williamr@4
    71
     2, 3, 3, 4, 3, 4, 4, 5, 3, 4, 4, 5, 4, 5, 5, 6, 3, 4, 4, 5, 4, 5, 5, 6, 4, 5, 5, 6, 5, 6, 6, 7,
williamr@4
    72
     3, 4, 4, 5, 4, 5, 5, 6, 4, 5, 5, 6, 5, 6, 6, 7, 4, 5, 5, 6, 5, 6, 6, 7, 5, 6, 6, 7, 6, 7, 7, 8
williamr@4
    73
     };
williamr@2
    74
williamr@2
    75
williamr@4
    76
     // overload for access by bytes
williamr@4
    77
     //
williamr@2
    78
williamr@4
    79
     template <typename Iterator>
williamr@4
    80
     inline std::size_t do_count(Iterator first, std::size_t length,
williamr@4
    81
                                 int /*dummy param*/,
williamr@4
    82
                                 mode_to_type<access_by_bytes>* )
williamr@4
    83
     {
williamr@4
    84
         std::size_t num = 0;
williamr@4
    85
         if (length)
williamr@4
    86
         {
williamr@4
    87
             const byte_type * p = object_representation(&*first);
williamr@4
    88
             length *= sizeof(*first);
williamr@2
    89
williamr@4
    90
              do {
williamr@4
    91
                 num += count_table<>::table[*p];
williamr@4
    92
                 ++p;
williamr@4
    93
                 --length;
williamr@2
    94
williamr@4
    95
             } while (length);
williamr@4
    96
         }
williamr@2
    97
williamr@4
    98
         return num;
williamr@4
    99
     }
williamr@2
   100
williamr@2
   101
williamr@4
   102
     // overload for access by blocks
williamr@4
   103
     //
williamr@4
   104
     template <typename Iterator, typename ValueType>
williamr@4
   105
     inline std::size_t do_count(Iterator first, std::size_t length, ValueType,
williamr@4
   106
                                 mode_to_type<access_by_blocks>*)
williamr@4
   107
     {
williamr@4
   108
         std::size_t num = 0;
williamr@4
   109
         while (length){
williamr@4
   110
williamr@4
   111
             ValueType value = *first;
williamr@4
   112
             while (value) {
williamr@4
   113
                 num += count_table<>::table[value & ((1u<<table_width) - 1)];
williamr@4
   114
                 value >>= table_width;
williamr@4
   115
             }
williamr@4
   116
williamr@4
   117
             ++first;
williamr@4
   118
             --length;
williamr@4
   119
         }
williamr@4
   120
williamr@4
   121
         return num;
williamr@4
   122
     }
williamr@4
   123
williamr@4
   124
williamr@4
   125
    } // dynamic_bitset_count_impl
williamr@4
   126
    // -------------------------------------------------------
williamr@4
   127
williamr@4
   128
williamr@4
   129
    // Some library implementations simply return a dummy
williamr@4
   130
    // value such as
williamr@4
   131
    //
williamr@4
   132
    //   size_type(-1) / sizeof(T)
williamr@4
   133
    //
williamr@4
   134
    // from vector<>::max_size. This tries to get out more
williamr@4
   135
    // meaningful info.
williamr@4
   136
    //
williamr@4
   137
    template <typename T>
williamr@4
   138
    typename T::size_type vector_max_size_workaround(const T & v) {
williamr@4
   139
williamr@4
   140
      typedef typename T::allocator_type allocator_type;
williamr@4
   141
williamr@4
   142
      const typename allocator_type::size_type alloc_max =
williamr@4
   143
                                                  v.get_allocator().max_size();
williamr@4
   144
      const typename T::size_type container_max = v.max_size();
williamr@4
   145
williamr@4
   146
      return alloc_max < container_max?
williamr@4
   147
                    alloc_max :
williamr@4
   148
                    container_max;
williamr@4
   149
    }
williamr@4
   150
williamr@4
   151
    // for static_asserts
williamr@4
   152
    template <typename T>
williamr@4
   153
    struct dynamic_bitset_allowed_block_type {
williamr@4
   154
        enum { value = (T(-1) > 0) }; // ensure T has no sign
williamr@2
   155
    };
williamr@2
   156
williamr@4
   157
    template <>
williamr@4
   158
    struct dynamic_bitset_allowed_block_type<bool> {
williamr@4
   159
        enum { value = false };
williamr@2
   160
    };
williamr@2
   161
williamr@2
   162
williamr@4
   163
  } // namespace detail
williamr@2
   164
williamr@2
   165
} // namespace boost
williamr@2
   166
williamr@2
   167
#endif // include guard
williamr@2
   168