[PATCH] D18281: [SetVector] Add erase() method
Jun Bum Lim via llvm-commits
llvm-commits at lists.llvm.org
Fri Mar 25 09:09:57 PDT 2016
This revision was automatically updated to reflect the committed changes.
Closed by commit rL264414: [SetVector] Add erase() method (authored by junbuml).
Changed prior to commit:
http://reviews.llvm.org/D18281?vs=51634&id=51641#toc
Repository:
rL LLVM
http://reviews.llvm.org/D18281
Files:
llvm/trunk/include/llvm/ADT/SetVector.h
llvm/trunk/unittests/ADT/CMakeLists.txt
llvm/trunk/unittests/ADT/SetVectorTest.cpp
Index: llvm/trunk/unittests/ADT/SetVectorTest.cpp
===================================================================
--- llvm/trunk/unittests/ADT/SetVectorTest.cpp
+++ llvm/trunk/unittests/ADT/SetVectorTest.cpp
@@ -0,0 +1,34 @@
+//===- llvm/unittest/ADT/SetVector.cpp ------------------------------===//
+//
+// The LLVM Compiler Infrastructure
+//
+// This file is distributed under the University of Illinois Open Source
+// License. See LICENSE.TXT for details.
+//
+//===----------------------------------------------------------------------===//
+//
+// SetVector unit tests.
+//
+//===----------------------------------------------------------------------===//
+
+#include "llvm/ADT/SetVector.h"
+#include "gtest/gtest.h"
+
+using namespace llvm;
+
+TEST(SetVector, EraseTest) {
+ SetVector<int> S;
+ S.insert(0);
+ S.insert(1);
+ S.insert(2);
+
+ auto I = S.erase(std::next(S.begin()));
+
+ // Test that the returned iterator is the expected one-after-erase
+ // and the size/contents is the expected sequence {0, 2}.
+ EXPECT_EQ(std::next(S.begin()), I);
+ EXPECT_EQ(2u, S.size());
+ EXPECT_EQ(0, *S.begin());
+ EXPECT_EQ(2, *std::next(S.begin()));
+}
+
Index: llvm/trunk/unittests/ADT/CMakeLists.txt
===================================================================
--- llvm/trunk/unittests/ADT/CMakeLists.txt
+++ llvm/trunk/unittests/ADT/CMakeLists.txt
@@ -32,6 +32,7 @@
PostOrderIteratorTest.cpp
RangeAdapterTest.cpp
SCCIteratorTest.cpp
+ SetVectorTest.cpp
SmallPtrSetTest.cpp
SmallStringTest.cpp
SmallVectorTest.cpp
Index: llvm/trunk/include/llvm/ADT/SetVector.h
===================================================================
--- llvm/trunk/include/llvm/ADT/SetVector.h
+++ llvm/trunk/include/llvm/ADT/SetVector.h
@@ -151,6 +151,17 @@
return false;
}
+ /// Erase a single element from the set vector.
+ /// \returns an iterator pointing to the next element that followed the
+ /// element erased. This is the end of the SetVector if the last element is
+ /// erased.
+ iterator erase(iterator I) {
+ const key_type &V = *I;
+ assert(set_.count(V) && "Corrupted SetVector instances!");
+ set_.erase(V);
+ return vector_.erase(I);
+ }
+
/// \brief Remove items from the set vector based on a predicate function.
///
/// This is intended to be equivalent to the following code, if we could
-------------- next part --------------
A non-text attachment was scrubbed...
Name: D18281.51641.patch
Type: text/x-patch
Size: 2394 bytes
Desc: not available
URL: <http://lists.llvm.org/pipermail/llvm-commits/attachments/20160325/0aac9324/attachment.bin>
More information about the llvm-commits
mailing list