Add default constructors for iterators.

These iterators don't point anywhere, and they can't be compared to anything.
They are only good for assigning to.

llvm-svn: 120239
This commit is contained in:
Jakob Stoklund Olesen 2010-11-28 07:21:48 +00:00
parent 7e1fd053d5
commit 8710e4f1ef
2 changed files with 14 additions and 0 deletions

View File

@ -1397,6 +1397,9 @@ protected:
void treeAdvanceTo(KeyT x);
public:
/// const_iterator - Create an iterator that isn't pointing anywhere.
const_iterator() : map(0) {}
/// valid - Return true if the current position is valid, false for end().
bool valid() const { return path.valid(); }
@ -1583,6 +1586,9 @@ class IntervalMap<KeyT, ValT, N, Traits>::iterator : public const_iterator {
void eraseNode(unsigned Level);
void treeErase(bool UpdateRoot = true);
public:
/// iterator - Create null iterator.
iterator() {}
/// insert - Insert mapping [a;b] -> y before the current position.
void insert(KeyT a, KeyT b, ValT y);

View File

@ -41,6 +41,14 @@ TEST(IntervalMapTest, EmptyMap) {
UUMap::iterator I = map.begin();
EXPECT_FALSE(I.valid());
EXPECT_TRUE(I == map.end());
// Default constructor and cross-constness compares.
UUMap::const_iterator CI;
CI = map.begin();
EXPECT_TRUE(CI == I);
UUMap::iterator I2;
I2 = map.end();
EXPECT_TRUE(I2 == CI);
}
// Single entry map tests