Fix an off by 1 bug that prevented SmallPtrSet from using all of its 'small' capacity. Then fix the early return in the move constructor that prevented 'small' moves from clearing the NumElements in the moved from object. The directed test missed this because it was always testing large moves due to the off by 1 bug.

git-svn-id: https://llvm.org/svn/llvm-project/llvm/trunk@216044 91177308-0d34-0410-b5e6-96231b3b80d8
This commit is contained in:
Craig Topper 2014-08-20 04:41:36 +00:00
parent ae8d297579
commit 78832c6e7d

View File

@ -43,7 +43,7 @@ bool SmallPtrSetImplBase::insert_imp(const void * Ptr) {
return false; return false;
// Nope, there isn't. If we stay small, just 'pushback' now. // Nope, there isn't. If we stay small, just 'pushback' now.
if (NumElements < CurArraySize-1) { if (NumElements < CurArraySize) {
SmallArray[NumElements++] = Ptr; SmallArray[NumElements++] = Ptr;
return true; return true;
} }
@ -200,13 +200,12 @@ SmallPtrSetImplBase::SmallPtrSetImplBase(const void **SmallStorage,
if (that.isSmall()) { if (that.isSmall()) {
CurArray = SmallArray; CurArray = SmallArray;
memcpy(CurArray, that.CurArray, sizeof(void *) * CurArraySize); memcpy(CurArray, that.CurArray, sizeof(void *) * CurArraySize);
return; } else {
// Otherwise, we steal the large memory allocation and no copy is needed.
CurArray = that.CurArray;
that.CurArray = that.SmallArray;
} }
// Otherwise, we steal the large memory allocation and no copy is needed.
CurArray = that.CurArray;
that.CurArray = that.SmallArray;
// Make the "that" object small and empty. // Make the "that" object small and empty.
that.CurArraySize = SmallSize; that.CurArraySize = SmallSize;
assert(that.CurArray == that.SmallArray); assert(that.CurArray == that.SmallArray);