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
This commit is contained in:
Chris Lattner 2006-07-27 03:38:08 +00:00
parent ea348585c8
commit 825405c0c1

View File

@ -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.