From c3396d5ff89901a744224fed45fdb6d612e96d22 Mon Sep 17 00:00:00 2001 From: Chris Lattner Date: Sun, 11 Feb 2007 08:12:13 +0000 Subject: [PATCH] add iterator support, plus support for size() and empty(). llvm-svn: 34178 --- include/llvm/ADT/StringMap.h | 76 +++++++++++++++++++++++++++++++++++- 1 file changed, 75 insertions(+), 1 deletion(-) diff --git a/include/llvm/ADT/StringMap.h b/include/llvm/ADT/StringMap.h index c47d9ae4fc5..1865e7f48a3 100644 --- a/include/llvm/ADT/StringMap.h +++ b/include/llvm/ADT/StringMap.h @@ -18,6 +18,11 @@ #include namespace llvm { + template + class StringMapConstIterator; + template + class StringMapIterator; + /// StringMapEntryBase - Shared base class of StringMapEntry instances. class StringMapEntryBase { @@ -39,7 +44,7 @@ public: /// StringMapImpl - This is the base class of StringMap that is shared among /// all of its instantiations. class StringMapImpl { -protected: +public: /// ItemBucket - The hash table consists of an array of these. If Item is /// non-null, this is an extant entry, otherwise, it is a hole. struct ItemBucket { @@ -51,6 +56,7 @@ protected: StringMapEntryBase *Item; }; +protected: ItemBucket *TheTable; unsigned NumBuckets; unsigned NumItems; @@ -67,9 +73,16 @@ protected: unsigned LookupBucketFor(const char *KeyStart, const char *KeyEnd); public: + static StringMapEntryBase *getTombstoneVal() { + return (StringMapEntryBase*)-1; + } + unsigned getNumBuckets() const { return NumBuckets; } unsigned getNumItems() const { return NumItems; } + bool empty() const { return NumItems == 0; } + unsigned size() const { return NumItems; } + void VisitEntries(const StringMapVisitor &Visitor) const; }; @@ -164,6 +177,14 @@ public: AllocatorTy &getAllocator() { return Allocator; } const AllocatorTy &getAllocator() const { return Allocator; } + typedef StringMapConstIterator const_iterator; + typedef StringMapIterator iterator; + + iterator begin() { return iterator(TheTable); } + iterator end() { return iterator(TheTable+NumBuckets); } + const_iterator begin() const { return const_iterator(TheTable); } + const_iterator end() const { return const_iterator(TheTable+NumBuckets); } + /// FindValue - Look up the specified key in the map. If it exists, return a /// pointer to the element, otherwise return null. MapEntryTy *FindValue(const char *KeyStart, const char *KeyEnd) { @@ -203,6 +224,59 @@ public: } }; + +template +class StringMapConstIterator { + StringMapImpl::ItemBucket *Ptr; +public: + StringMapConstIterator(StringMapImpl::ItemBucket *Bucket) : Ptr(Bucket) { + AdvancePastEmptyBuckets(); + } + + const StringMapEntry &operator*() const { + return *static_cast*>(Ptr->Item); + } + const StringMapEntry *operator->() const { + return static_cast*>(Ptr->Item); + } + + bool operator==(const StringMapConstIterator &RHS) const { + return Ptr == RHS.Ptr; + } + bool operator!=(const StringMapConstIterator &RHS) const { + return Ptr != RHS.Ptr; + } + + inline StringMapConstIterator& operator++() { // Preincrement + ++Ptr; + AdvancePastEmptyBuckets(); + return *this; + } + StringMapConstIterator operator++(int) { // Postincrement + StringMapConstIterator tmp = *this; ++*this; return tmp; + } + +private: + void AdvancePastEmptyBuckets() { + while (Ptr->Item == 0 || Ptr->Item == StringMapImpl::getTombstoneVal()) + ++Ptr; + } +}; + +template +class StringMapIterator : public StringMapConstIterator { +public: + StringMapIterator(StringMapImpl::ItemBucket *Bucket) + : StringMapConstIterator(Bucket) { + } + StringMapEntry &operator*() const { + return *static_cast*>(this->Ptr->Item); + } + StringMapEntry *operator->() const { + return static_cast*>(this->Ptr->Item); + } +}; + } #endif