Fixed hack in BatchReadOwnedPtrs to no longer use the array of pointers passed in for

deserialization as a temporary location for storing serialized pointer identifiers. The
definition of SerializedPtrID will likely change significantly in the future, and the
current implementation caused compilation errors on some 64-bit machines.


git-svn-id: https://llvm.org/svn/llvm-project/llvm/trunk@43983 91177308-0d34-0410-b5e6-96231b3b80d8
This commit is contained in:
Ted Kremenek 2007-11-10 19:28:49 +00:00
parent 5d1f2cc644
commit 303f7fe149

View File

@ -126,6 +126,7 @@ private:
unsigned AbbrevNo;
unsigned RecordCode;
Location StreamStart;
std::vector<SerializedPtrID> BatchIDVec;
//===----------------------------------------------------------===//
// Public Interface.
@ -213,10 +214,11 @@ public:
template <typename T>
void BatchReadOwnedPtrs(unsigned NumPtrs, T** Ptrs, bool AutoRegister=true) {
for (unsigned i = 0; i < NumPtrs; ++i)
reinterpret_cast<SerializedPtrID&>(Ptrs[i]) = ReadPtrID();
BatchIDVec.push_back(ReadPtrID());
for (unsigned i = 0; i < NumPtrs; ++i) {
SerializedPtrID PtrID = reinterpret_cast<SerializedPtrID>(Ptrs[i]);
SerializedPtrID& PtrID = BatchIDVec[i];
T* p = PtrID ? SerializeTrait<T>::Materialize(*this) : NULL;
if (PtrID && AutoRegister)