Implement a read/write operator[] for SmallBitVector with a proxy class.

llvm-svn: 102709
This commit is contained in:
Benjamin Kramer 2010-04-30 12:29:39 +00:00
parent 120e6b748b
commit e2a98b1e90
2 changed files with 43 additions and 3 deletions

View File

@ -52,6 +52,34 @@ class SmallBitVector {
SmallNumDataBits = SmallNumRawBits - SmallNumSizeBits
};
public:
// Encapsulation of a single bit.
class reference {
SmallBitVector &TheVector;
unsigned BitPos;
public:
reference(SmallBitVector &b, unsigned Idx) : TheVector(b), BitPos(Idx) {}
reference& operator=(reference t) {
*this = bool(t);
return *this;
}
reference& operator=(bool t) {
if (t)
TheVector.set(BitPos);
else
TheVector.reset(BitPos);
return *this;
}
operator bool() const {
return const_cast<const SmallBitVector &>(TheVector).operator[](BitPos);
}
};
private:
bool isSmall() const {
return X & uintptr_t(1);
}
@ -81,7 +109,7 @@ class SmallBitVector {
void setSmallRawBits(uintptr_t NewRawBits) {
assert(isSmall());
X = NewRawBits << 1 | uintptr_t(1);
X = (NewRawBits << 1) | uintptr_t(1);
}
// Return the size.
@ -99,7 +127,7 @@ class SmallBitVector {
}
void setSmallBits(uintptr_t NewBits) {
setSmallRawBits(NewBits & ~(~uintptr_t(0) << getSmallSize()) |
setSmallRawBits((NewBits & ~(~uintptr_t(0) << getSmallSize())) |
(getSmallSize() << SmallNumDataBits));
}
@ -298,7 +326,11 @@ public:
}
// Indexing.
// TODO: Add an index operator which returns a "reference" (proxy class).
reference operator[](unsigned Idx) {
assert(Idx < size() && "Out-of-bounds Bit access.");
return reference(*this, Idx);
}
bool operator[](unsigned Idx) const {
assert(Idx < size() && "Out-of-bounds Bit access.");
if (isSmall())

View File

@ -176,4 +176,12 @@ TEST(SmallBitVectorTest, CompoundAssignment) {
EXPECT_EQ(100U, A.size());
}
TEST(SmallBitVectorTest, ProxyIndex) {
SmallBitVector Vec(3);
EXPECT_TRUE(Vec.none());
Vec[0] = Vec[1] = Vec[2] = true;
EXPECT_EQ(Vec.size(), Vec.count());
Vec[2] = Vec[1] = Vec[0] = false;
EXPECT_TRUE(Vec.none());
}
}