Index: runtime/vm/raw_object_snapshot.cc |
=================================================================== |
--- runtime/vm/raw_object_snapshot.cc (revision 12790) |
+++ runtime/vm/raw_object_snapshot.cc (working copy) |
@@ -513,6 +513,54 @@ |
} |
+RawRedirectionData* RedirectionData::ReadFrom(SnapshotReader* reader, |
+ intptr_t object_id, |
+ intptr_t tags, |
+ Snapshot::Kind kind) { |
+ ASSERT(reader != NULL); |
+ ASSERT((kind != Snapshot::kMessage) && |
+ !RawObject::IsCreatedFromSnapshot(tags)); |
+ |
+ // Allocate redirection data object. |
+ RedirectionData& data = RedirectionData::ZoneHandle( |
+ reader->isolate(), NEW_OBJECT(RedirectionData)); |
+ reader->AddBackRef(object_id, &data, kIsDeserialized); |
+ |
+ // Set the object tags. |
+ data.set_tags(tags); |
+ |
+ // Set all the object fields. |
+ // TODO(5411462): Need to assert No GC can happen here, even though |
+ // allocations may happen. |
+ intptr_t num_flds = (data.raw()->to() - data.raw()->from()); |
+ for (intptr_t i = 0; i <= num_flds; i++) { |
+ *(data.raw()->from() + i) = reader->ReadObjectRef(); |
+ } |
+ |
+ return data.raw(); |
+} |
+ |
+ |
+void RawRedirectionData::WriteTo(SnapshotWriter* writer, |
+ intptr_t object_id, |
+ Snapshot::Kind kind) { |
+ ASSERT(writer != NULL); |
+ ASSERT((kind != Snapshot::kMessage) && |
+ !RawObject::IsCreatedFromSnapshot(writer->GetObjectTags(this))); |
+ |
+ // Write out the serialization header value for this object. |
+ writer->WriteInlinedObjectHeader(object_id); |
+ |
+ // Write out the class and tags information. |
+ writer->WriteVMIsolateObject(kRedirectionDataCid); |
+ writer->WriteIntptrValue(writer->GetObjectTags(this)); |
+ |
+ // Write out all the object pointer fields. |
+ SnapshotWriterVisitor visitor(writer); |
+ visitor.VisitPointers(from(), to()); |
+} |
+ |
+ |
RawFunction* Function::ReadFrom(SnapshotReader* reader, |
intptr_t object_id, |
intptr_t tags, |