<div dir="ltr">Looks like this was missing test coverage for the default ctors.<br><br>(also, think it's probably best to implement those op==/op!= as non-members - rather than the odd asymmetry of members with a ConstIterator parameter for the non-const Iterator operators, etc - you can still implement them in the class if that's more convenient by using an inline friend definition: friend bool operator==(const foo& a, const foo& b) { return a.x == b.x; } or similar)</div><br><div class="gmail_quote"><div dir="ltr">On Mon, Jan 23, 2017 at 8:22 PM Dean Michael Berris via Phabricator <<a href="mailto:reviews@reviews.llvm.org">reviews@reviews.llvm.org</a>> wrote:<br></div><blockquote class="gmail_quote" style="margin:0 0 0 .8ex;border-left:1px #ccc solid;padding-left:1ex">This revision was automatically updated to reflect the committed changes.<br class="gmail_msg">
Closed by commit rL292879: Allow DenseSet::iterators to be conveted to and compared with const_iterator (authored by dberris).<br class="gmail_msg">
<br class="gmail_msg">
Changed prior to commit:<br class="gmail_msg">
  <a href="https://reviews.llvm.org/D28999?vs=85323&id=85522#toc" rel="noreferrer" class="gmail_msg" target="_blank">https://reviews.llvm.org/D28999?vs=85323&id=85522#toc</a><br class="gmail_msg">
<br class="gmail_msg">
Repository:<br class="gmail_msg">
  rL LLVM<br class="gmail_msg">
<br class="gmail_msg">
<a href="https://reviews.llvm.org/D28999" rel="noreferrer" class="gmail_msg" target="_blank">https://reviews.llvm.org/D28999</a><br class="gmail_msg">
<br class="gmail_msg">
Files:<br class="gmail_msg">
  llvm/trunk/include/llvm/ADT/DenseSet.h<br class="gmail_msg">
  llvm/trunk/unittests/ADT/DenseSetTest.cpp<br class="gmail_msg">
<br class="gmail_msg">
<br class="gmail_msg">
Index: llvm/trunk/unittests/ADT/DenseSetTest.cpp<br class="gmail_msg">
===================================================================<br class="gmail_msg">
--- llvm/trunk/unittests/ADT/DenseSetTest.cpp<br class="gmail_msg">
+++ llvm/trunk/unittests/ADT/DenseSetTest.cpp<br class="gmail_msg">
@@ -73,6 +73,15 @@<br class="gmail_msg">
   EXPECT_EQ(0u, set.count(3));<br class="gmail_msg">
 }<br class="gmail_msg">
<br class="gmail_msg">
+TYPED_TEST(DenseSetTest, ConstIteratorComparison){<br class="gmail_msg">
+  TypeParam set({1});<br class="gmail_msg">
+  const TypeParam &cset = set;<br class="gmail_msg">
+  EXPECT_EQ(set.begin(), cset.begin());<br class="gmail_msg">
+  EXPECT_EQ(set.end(), cset.end());<br class="gmail_msg">
+  EXPECT_NE(set.end(), cset.begin());<br class="gmail_msg">
+  EXPECT_NE(set.begin(), cset.end());<br class="gmail_msg">
+}<br class="gmail_msg">
+<br class="gmail_msg">
 TYPED_TEST(DenseSetTest, EmptyInitializerList) {<br class="gmail_msg">
   TypeParam set({});<br class="gmail_msg">
   EXPECT_EQ(0u, set.size());<br class="gmail_msg">
Index: llvm/trunk/include/llvm/ADT/DenseSet.h<br class="gmail_msg">
===================================================================<br class="gmail_msg">
--- llvm/trunk/include/llvm/ADT/DenseSet.h<br class="gmail_msg">
+++ llvm/trunk/include/llvm/ADT/DenseSet.h<br class="gmail_msg">
@@ -90,17 +90,21 @@<br class="gmail_msg">
<br class="gmail_msg">
   // Iterators.<br class="gmail_msg">
<br class="gmail_msg">
+  class ConstIterator;<br class="gmail_msg">
+<br class="gmail_msg">
   class Iterator {<br class="gmail_msg">
     typename MapTy::iterator I;<br class="gmail_msg">
     friend class DenseSetImpl;<br class="gmail_msg">
+    friend class ConstIterator;<br class="gmail_msg">
<br class="gmail_msg">
   public:<br class="gmail_msg">
     typedef typename MapTy::iterator::difference_type difference_type;<br class="gmail_msg">
     typedef ValueT value_type;<br class="gmail_msg">
     typedef value_type *pointer;<br class="gmail_msg">
     typedef value_type &reference;<br class="gmail_msg">
     typedef std::forward_iterator_tag iterator_category;<br class="gmail_msg">
<br class="gmail_msg">
+    Iterator() = default;<br class="gmail_msg">
     Iterator(const typename MapTy::iterator &i) : I(i) {}<br class="gmail_msg">
<br class="gmail_msg">
     ValueT &operator*() { return I->getFirst(); }<br class="gmail_msg">
@@ -110,21 +114,26 @@<br class="gmail_msg">
<br class="gmail_msg">
     Iterator& operator++() { ++I; return *this; }<br class="gmail_msg">
     Iterator operator++(int) { auto T = *this; ++I; return T; }<br class="gmail_msg">
-    bool operator==(const Iterator& X) const { return I == X.I; }<br class="gmail_msg">
-    bool operator!=(const Iterator& X) const { return I != X.I; }<br class="gmail_msg">
+    bool operator==(const ConstIterator& X) const { return I == X.I; }<br class="gmail_msg">
+    bool operator!=(const ConstIterator& X) const { return I != X.I; }<br class="gmail_msg">
   };<br class="gmail_msg">
<br class="gmail_msg">
   class ConstIterator {<br class="gmail_msg">
     typename MapTy::const_iterator I;<br class="gmail_msg">
     friend class DenseSet;<br class="gmail_msg">
+    friend class Iterator;<br class="gmail_msg">
<br class="gmail_msg">
   public:<br class="gmail_msg">
     typedef typename MapTy::const_iterator::difference_type difference_type;<br class="gmail_msg">
     typedef ValueT value_type;<br class="gmail_msg">
     typedef value_type *pointer;<br class="gmail_msg">
     typedef value_type &reference;<br class="gmail_msg">
     typedef std::forward_iterator_tag iterator_category;<br class="gmail_msg">
<br class="gmail_msg">
+    ConstIterator(const Iterator &B) : I(B.I) {}<br class="gmail_msg">
+<br class="gmail_msg">
+    ConstIterator() = default;<br class="gmail_msg">
+<br class="gmail_msg">
     ConstIterator(const typename MapTy::const_iterator &i) : I(i) {}<br class="gmail_msg">
<br class="gmail_msg">
     const ValueT &operator*() const { return I->getFirst(); }<br class="gmail_msg">
<br class="gmail_msg">
<br class="gmail_msg">
</blockquote></div>