diff options
Diffstat (limited to 'src/common/bit_set.h')
| -rw-r--r-- | src/common/bit_set.h | 33 |
1 files changed, 19 insertions, 14 deletions
diff --git a/src/common/bit_set.h b/src/common/bit_set.h index 3059d0cb0..9c2e6b28c 100644 --- a/src/common/bit_set.h +++ b/src/common/bit_set.h | |||
| @@ -121,22 +121,19 @@ public: | |||
| 121 | class Iterator { | 121 | class Iterator { |
| 122 | public: | 122 | public: |
| 123 | Iterator(const Iterator& other) : m_val(other.m_val), m_bit(other.m_bit) {} | 123 | Iterator(const Iterator& other) : m_val(other.m_val), m_bit(other.m_bit) {} |
| 124 | Iterator(IntTy val, int bit) : m_val(val), m_bit(bit) {} | 124 | Iterator(IntTy val) : m_val(val), m_bit(0) {} |
| 125 | Iterator& operator=(Iterator other) { | 125 | Iterator& operator=(Iterator other) { |
| 126 | new (this) Iterator(other); | 126 | new (this) Iterator(other); |
| 127 | return *this; | 127 | return *this; |
| 128 | } | 128 | } |
| 129 | int operator*() { | 129 | int operator*() { |
| 130 | return m_bit; | 130 | return m_bit + ComputeLsb(); |
| 131 | } | 131 | } |
| 132 | Iterator& operator++() { | 132 | Iterator& operator++() { |
| 133 | if (m_val == 0) { | 133 | int lsb = ComputeLsb(); |
| 134 | m_bit = -1; | 134 | m_val >>= lsb + 1; |
| 135 | } else { | 135 | m_bit += lsb + 1; |
| 136 | int bit = LeastSignificantSetBit(m_val); | 136 | m_has_lsb = false; |
| 137 | m_val &= ~(1 << bit); | ||
| 138 | m_bit = bit; | ||
| 139 | } | ||
| 140 | return *this; | 137 | return *this; |
| 141 | } | 138 | } |
| 142 | Iterator operator++(int _) { | 139 | Iterator operator++(int _) { |
| @@ -145,15 +142,24 @@ public: | |||
| 145 | return other; | 142 | return other; |
| 146 | } | 143 | } |
| 147 | bool operator==(Iterator other) const { | 144 | bool operator==(Iterator other) const { |
| 148 | return m_bit == other.m_bit; | 145 | return m_val == other.m_val; |
| 149 | } | 146 | } |
| 150 | bool operator!=(Iterator other) const { | 147 | bool operator!=(Iterator other) const { |
| 151 | return m_bit != other.m_bit; | 148 | return m_val != other.m_val; |
| 152 | } | 149 | } |
| 153 | 150 | ||
| 154 | private: | 151 | private: |
| 152 | int ComputeLsb() { | ||
| 153 | if (!m_has_lsb) { | ||
| 154 | m_lsb = LeastSignificantSetBit(m_val); | ||
| 155 | m_has_lsb = true; | ||
| 156 | } | ||
| 157 | return m_lsb; | ||
| 158 | } | ||
| 155 | IntTy m_val; | 159 | IntTy m_val; |
| 156 | int m_bit; | 160 | int m_bit; |
| 161 | int m_lsb = -1; | ||
| 162 | bool m_has_lsb = false; | ||
| 157 | }; | 163 | }; |
| 158 | 164 | ||
| 159 | BitSet() : m_val(0) {} | 165 | BitSet() : m_val(0) {} |
| @@ -221,11 +227,10 @@ public: | |||
| 221 | } | 227 | } |
| 222 | 228 | ||
| 223 | Iterator begin() const { | 229 | Iterator begin() const { |
| 224 | Iterator it(m_val, 0); | 230 | return Iterator(m_val); |
| 225 | return ++it; | ||
| 226 | } | 231 | } |
| 227 | Iterator end() const { | 232 | Iterator end() const { |
| 228 | return Iterator(m_val, -1); | 233 | return Iterator(0); |
| 229 | } | 234 | } |
| 230 | 235 | ||
| 231 | IntTy m_val; | 236 | IntTy m_val; |