diff options
author | Chris Lattner <sabre@nondot.org> | 2006-07-27 03:38:08 +0000 |
---|---|---|
committer | Chris Lattner <sabre@nondot.org> | 2006-07-27 03:38:08 +0000 |
commit | 825405c0c1b92c69cea283f97ee829ea3f23e3a4 (patch) | |
tree | 0c4a6736b561b9fb4f805885f8c5f57148fdde88 | |
parent | ea348585c80f5b1f51776dd850ecbdce034f2f19 (diff) |
Use std::copy instead of custom loops to take advantage of STL optimizations.
Add a new append method for appending a range.
git-svn-id: https://llvm.org/svn/llvm-project/llvm/trunk@29323 91177308-0d34-0410-b5e6-96231b3b80d8
-rw-r--r-- | include/llvm/ADT/SmallVector.h | 24 |
1 files changed, 19 insertions, 5 deletions
diff --git a/include/llvm/ADT/SmallVector.h b/include/llvm/ADT/SmallVector.h index c75453fb25..e542f4cd2c 100644 --- a/include/llvm/ADT/SmallVector.h +++ b/include/llvm/ADT/SmallVector.h @@ -14,7 +14,9 @@ #ifndef LLVM_ADT_SMALLVECTOR_H #define LLVM_ADT_SMALLVECTOR_H +#include <algorithm> #include <cassert> +#include <iterator> #include <memory> namespace llvm { @@ -113,6 +115,20 @@ public: goto Retry; } + /// append - Add the specified range to the end of the SmallVector. + /// + template<typename in_iter> + void append(in_iter in_start, in_iter in_end) { + unsigned NumInputs = std::distance(in_start, in_end); + // Grow allocated space if needed. + if (End+NumInputs > Capacity) + grow(size()+NumInputs); + + // Copy the new elements over. + std::uninitialized_copy(in_start, in_end, End); + End += NumInputs; + } + const SmallVector &operator=(const SmallVector &RHS) { // Avoid self-assignment. if (this == &RHS) return *this; @@ -123,8 +139,7 @@ public: unsigned CurSize = size(); if (CurSize >= RHSSize) { // Assign common elements. - for (unsigned i = 0; i != RHSSize; ++i) - Begin[i] = RHS.Begin[i]; + std::copy(RHS.Begin, RHS.Begin+RHSSize, Begin); // Destroy excess elements. for (unsigned i = RHSSize; i != CurSize; ++i) @@ -144,10 +159,9 @@ public: End = Begin; CurSize = 0; grow(RHSSize); - } else { + } else if (CurSize) { // Otherwise, use assignment for the already-constructed elements. - for (unsigned i = 0; i != CurSize; ++i) - Begin[i] = RHS.Begin[i]; + std::copy(RHS.Begin, RHS.Begin+CurSize, Begin); } // Copy construct the new elements in place. |