[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