• Home
  • Line#
  • Scopes#
  • Navigate#
  • Raw
  • Download
1 
2 /*
3  * Copyright 2011 Google Inc.
4  *
5  * Use of this source code is governed by a BSD-style license that can be
6  * found in the LICENSE file.
7  */
8 
9 
10 #ifndef SkBitSet_DEFINED
11 #define SkBitSet_DEFINED
12 
13 #include "SkTypes.h"
14 #include "SkTDArray.h"
15 
16 class SkBitSet {
17 public:
18     /** NumberOfBits must be greater than zero.
19      */
20     explicit SkBitSet(int numberOfBits);
21     explicit SkBitSet(const SkBitSet& source);
22 
23     SkBitSet& operator=(const SkBitSet& rhs);
24     bool operator==(const SkBitSet& rhs);
25     bool operator!=(const SkBitSet& rhs);
26 
27     /** Clear all data.
28      */
29     void clearAll();
30 
31     /** Set the value of the index-th bit.
32      */
33     void setBit(int index, bool value);
34 
35     /** Test if bit index is set.
36      */
37     bool isBitSet(int index) const;
38 
39     /** Or bits from source.  false is returned if this doesn't have the same
40      *  bit count as source.
41      */
42     bool orBits(const SkBitSet& source);
43 
44     /** Export indices of set bits to T array.
45      */
46     template<typename T>
exportTo(SkTDArray<T> * array)47     void exportTo(SkTDArray<T>* array) const {
48         SkASSERT(array);
49         uint32_t* data = reinterpret_cast<uint32_t*>(fBitData.get());
50         for (unsigned int i = 0; i < fDwordCount; ++i) {
51             uint32_t value = data[i];
52             if (value) {  // There are set bits
53                 unsigned int index = i * 32;
54                 for (unsigned int j = 0; j < 32; ++j) {
55                     if (0x1 & (value >> j)) {
56                         array->push(index + j);
57                     }
58                 }
59             }
60         }
61     }
62 
63 private:
64     SkAutoFree fBitData;
65     // Dword (32-bit) count of the bitset.
66     size_t fDwordCount;
67     size_t fBitCount;
68 
internalGet(int index)69     uint32_t* internalGet(int index) const {
70         SkASSERT((size_t)index < fBitCount);
71         size_t internalIndex = index / 32;
72         SkASSERT(internalIndex < fDwordCount);
73         return reinterpret_cast<uint32_t*>(fBitData.get()) + internalIndex;
74     }
75 };
76 
77 
78 #endif
79