[PATCH] D90576: [ADT] Add SmallVector::pop_back_n

Nathan James via Phabricator via llvm-commits llvm-commits at lists.llvm.org
Sun Nov 1 17:28:09 PST 2020


njames93 created this revision.
njames93 added a reviewer: dblaikie.
Herald added subscribers: llvm-commits, dexonsmith.
Herald added a project: LLVM.
njames93 requested review of this revision.

Adds a pop_back_n, this is more expressive than using Vec.resize(Vec.size() - N) or a chain or loop of calls to pop_back.


Repository:
  rG LLVM Github Monorepo

https://reviews.llvm.org/D90576

Files:
  llvm/include/llvm/ADT/SmallVector.h
  llvm/unittests/ADT/SmallVectorTest.cpp


Index: llvm/unittests/ADT/SmallVectorTest.cpp
===================================================================
--- llvm/unittests/ADT/SmallVectorTest.cpp
+++ llvm/unittests/ADT/SmallVectorTest.cpp
@@ -261,8 +261,7 @@
   this->assertValuesInOrder(this->theVector, 2u, 2, 1);
 
   // Pop remaining elements
-  this->theVector.pop_back();
-  this->theVector.pop_back();
+  this->theVector.pop_back_n(2);
   this->assertEmpty(this->theVector);
 
   // Check number of constructor calls. Should be 2 for each list element,
Index: llvm/include/llvm/ADT/SmallVector.h
===================================================================
--- llvm/include/llvm/ADT/SmallVector.h
+++ llvm/include/llvm/ADT/SmallVector.h
@@ -424,6 +424,12 @@
       this->grow(N);
   }
 
+  void pop_back_n(size_type NumItems) {
+    assert(this->size() >= NumItems);
+    this->destroy_range(this->end() - NumItems, this->end());
+    this->set_size(this->size() - NumItems);
+  }
+
   LLVM_NODISCARD T pop_back_val() {
     T Result = ::std::move(this->back());
     this->pop_back();


-------------- next part --------------
A non-text attachment was scrubbed...
Name: D90576.302193.patch
Type: text/x-patch
Size: 1061 bytes
Desc: not available
URL: <http://lists.llvm.org/pipermail/llvm-commits/attachments/20201102/f93ae028/attachment.bin>


More information about the llvm-commits mailing list