[llvm-commits] [llvm] r39926 - in /llvm/trunk: include/llvm/ADT/SmallPtrSet.h lib/Support/SmallPtrSet.cpp
Owen Anderson
resistor at mac.com
Mon Jul 16 14:27:44 PDT 2007
Author: resistor
Date: Mon Jul 16 16:27:44 2007
New Revision: 39926
URL: http://llvm.org/viewvc/llvm-project?rev=39926&view=rev
Log:
Use realloc() to (potentially) resize the contents of SmallPtrSet in place.
Modified:
llvm/trunk/include/llvm/ADT/SmallPtrSet.h
llvm/trunk/lib/Support/SmallPtrSet.cpp
Modified: llvm/trunk/include/llvm/ADT/SmallPtrSet.h
URL: http://llvm.org/viewvc/llvm-project/llvm/trunk/include/llvm/ADT/SmallPtrSet.h?rev=39926&r1=39925&r2=39926&view=diff
==============================================================================
--- llvm/trunk/include/llvm/ADT/SmallPtrSet.h (original)
+++ llvm/trunk/include/llvm/ADT/SmallPtrSet.h Mon Jul 16 16:27:44 2007
@@ -69,7 +69,7 @@
}
~SmallPtrSetImpl() {
if (!isSmall())
- delete[] CurArray;
+ free(CurArray);
}
bool empty() const { return size() == 0; }
Modified: llvm/trunk/lib/Support/SmallPtrSet.cpp
URL: http://llvm.org/viewvc/llvm-project/llvm/trunk/lib/Support/SmallPtrSet.cpp?rev=39926&r1=39925&r2=39926&view=diff
==============================================================================
--- llvm/trunk/lib/Support/SmallPtrSet.cpp (original)
+++ llvm/trunk/lib/Support/SmallPtrSet.cpp Mon Jul 16 16:27:44 2007
@@ -114,7 +114,8 @@
bool WasSmall = isSmall();
// Install the new array. Clear all the buckets to empty.
- CurArray = new void*[NewSize+1];
+ CurArray = (void**)malloc(sizeof(void*) * (NewSize+1));
+ assert(CurArray && "Failed to allocate memory?");
CurArraySize = NewSize;
memset(CurArray, -1, NewSize*sizeof(void*));
@@ -140,7 +141,7 @@
*const_cast<void**>(FindBucketFor(Elt)) = Elt;
}
- delete [] OldBuckets;
+ free(OldBuckets);
NumTombstones = 0;
}
}
@@ -156,7 +157,8 @@
memcpy(CurArray, that.CurArray, sizeof(void*)*(CurArraySize+1));
} else {
CurArraySize = that.NumElements < 64 ? 128 : that.CurArraySize*2;
- CurArray = new void*[CurArraySize+1];
+ CurArray = (void**)malloc(sizeof(void*) * (CurArraySize+1));
+ assert(CurArray && "Failed to allocate memory?");
memset(CurArray, -1, CurArraySize*sizeof(void*));
// The end pointer, always valid, is set to a valid element to help the
@@ -183,17 +185,14 @@
NumElements = RHS.NumElements;
NumTombstones = RHS.NumTombstones;
- // If we're not currently small, and we don't have the same heap size,
- // free our heap allocated storage
- if (!isSmall() && CurArraySize != RHS.CurArraySize)
- delete [] CurArray;
-
// If we're becoming small, prepare to insert into our stack space
if (RHS.isSmall())
CurArray = &SmallArray[0];
// Otherwise, allocate new heap space (unless we were the same size)
- else if (CurArraySize != RHS.CurArraySize)
- CurArray = new void*[RHS.CurArraySize+1];
+ else if (CurArraySize != RHS.CurArraySize) {
+ CurArray = (void**)realloc(CurArray, sizeof(void*)*(RHS.CurArraySize+1));
+ assert(CurArray && "Failed to allocate memory?");
+ }
// Copy over the new array size
CurArraySize = RHS.CurArraySize;
More information about the llvm-commits
mailing list