mirror of
https://github.com/c64scene-ar/llvm-6502.git
synced 2025-06-18 11:24:01 +00:00
Added special treatment of serializing NULL pointers.
git-svn-id: https://llvm.org/svn/llvm-project/llvm/trunk@43357 91177308-0d34-0410-b5e6-96231b3b80d8
This commit is contained in:
@ -86,6 +86,10 @@ public:
|
|||||||
template <typename T>
|
template <typename T>
|
||||||
inline T* ReadOwnedPtr() {
|
inline T* ReadOwnedPtr() {
|
||||||
unsigned PtrId = ReadInt();
|
unsigned PtrId = ReadInt();
|
||||||
|
|
||||||
|
if (PtrId == 0)
|
||||||
|
return NULL;
|
||||||
|
|
||||||
T* x = SerializeTrait<T>::Materialize(*this);
|
T* x = SerializeTrait<T>::Materialize(*this);
|
||||||
RegisterPtr(PtrId,x);
|
RegisterPtr(PtrId,x);
|
||||||
return x;
|
return x;
|
||||||
|
@ -47,7 +47,7 @@ public:
|
|||||||
template <typename T>
|
template <typename T>
|
||||||
void EmitOwnedPtr(T* ptr) {
|
void EmitOwnedPtr(T* ptr) {
|
||||||
EmitPtr(ptr);
|
EmitPtr(ptr);
|
||||||
SerializeTrait<T>::Emit(*this,*ptr);
|
if (ptr) SerializeTrait<T>::Emit(*this,*ptr);
|
||||||
}
|
}
|
||||||
|
|
||||||
void Flush() { if (inRecord()) EmitRecord(); }
|
void Flush() { if (inRecord()) EmitRecord(); }
|
||||||
|
@ -103,6 +103,11 @@ void Deserializer::RegisterPtr(unsigned PtrId,void* Ptr) {
|
|||||||
void Deserializer::ReadPtr(void*& PtrRef) {
|
void Deserializer::ReadPtr(void*& PtrRef) {
|
||||||
unsigned PtrId = ReadInt();
|
unsigned PtrId = ReadInt();
|
||||||
|
|
||||||
|
if (PtrId == 0) {
|
||||||
|
PtrRef = NULL;
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
|
||||||
BPatchEntry& E = BPatchMap[PtrId];
|
BPatchEntry& E = BPatchMap[PtrId];
|
||||||
|
|
||||||
if (E.Ptr == NULL) {
|
if (E.Ptr == NULL) {
|
||||||
|
@ -58,10 +58,13 @@ void Serializer::EmitCStr(const char* s) {
|
|||||||
}
|
}
|
||||||
|
|
||||||
unsigned Serializer::getPtrId(void* ptr) {
|
unsigned Serializer::getPtrId(void* ptr) {
|
||||||
|
if (!ptr)
|
||||||
|
return 0;
|
||||||
|
|
||||||
MapTy::iterator I = PtrMap.find(ptr);
|
MapTy::iterator I = PtrMap.find(ptr);
|
||||||
|
|
||||||
if (I == PtrMap.end()) {
|
if (I == PtrMap.end()) {
|
||||||
unsigned id = PtrMap.size();
|
unsigned id = PtrMap.size()+1;
|
||||||
PtrMap[ptr] = id;
|
PtrMap[ptr] = id;
|
||||||
return id;
|
return id;
|
||||||
}
|
}
|
||||||
|
Reference in New Issue
Block a user