aboutsummaryrefslogtreecommitdiff
path: root/include/llvm/ADT
diff options
context:
space:
mode:
authorRyan Govostes <rzg@apple.com>2013-02-13 21:38:22 +0000
committerRyan Govostes <rzg@apple.com>2013-02-13 21:38:22 +0000
commit3df02ac9d46f7ce8f0f10bc693dfc3c6c5aa2863 (patch)
tree8ca665e0a72ccb82e708bcb1e2a8b1d9bb4ae3c8 /include/llvm/ADT
parent7b0bc3fe3e8210ec7fffb311443a07d81cbe1308 (diff)
Add iterator_traits to ImmutableMap and ImmutableSet.
git-svn-id: https://llvm.org/svn/llvm-project/llvm/trunk@175085 91177308-0d34-0410-b5e6-96231b3b80d8
Diffstat (limited to 'include/llvm/ADT')
-rw-r--r--include/llvm/ADT/ImmutableMap.h5
-rw-r--r--include/llvm/ADT/ImmutableSet.h5
2 files changed, 10 insertions, 0 deletions
diff --git a/include/llvm/ADT/ImmutableMap.h b/include/llvm/ADT/ImmutableMap.h
index a4232f0da9..a84ad25bee 100644
--- a/include/llvm/ADT/ImmutableMap.h
+++ b/include/llvm/ADT/ImmutableMap.h
@@ -224,6 +224,11 @@ public:
iterator operator--(int) { iterator tmp(*this); --itr; return tmp; }
bool operator==(const iterator& RHS) const { return RHS.itr == itr; }
bool operator!=(const iterator& RHS) const { return RHS.itr != itr; }
+
+ typedef ImmutableMap<KeyT,ValT,ValInfo>::value_type value_type;
+ typedef value_type *pointer;
+ typedef value_type &reference;
+ typedef std::bidirectional_iterator_tag iterator_category;
};
iterator begin() const { return iterator(Root); }
diff --git a/include/llvm/ADT/ImmutableSet.h b/include/llvm/ADT/ImmutableSet.h
index 21b325e907..247b544660 100644
--- a/include/llvm/ADT/ImmutableSet.h
+++ b/include/llvm/ADT/ImmutableSet.h
@@ -1066,6 +1066,11 @@ public:
inline bool operator==(const iterator& RHS) const { return RHS.itr == itr; }
inline bool operator!=(const iterator& RHS) const { return RHS.itr != itr; }
inline value_type *operator->() const { return &(operator*()); }
+
+ typedef ImmutableSet<ValT,ValInfo>::value_type value_type;
+ typedef value_type *pointer;
+ typedef value_type &reference;
+ typedef std::bidirectional_iterator_tag iterator_category;
};
iterator begin() const { return iterator(Root); }