Chromium Code Reviews| Index: src/profile-generator-inl.h |
| diff --git a/src/profile-generator-inl.h b/src/profile-generator-inl.h |
| index 284e2dfa361af19df6f6f8cf159dbb977d612922..70b9ef30c9e6d2b1ad8a8d0827d2d97c47cae0bc 100644 |
| --- a/src/profile-generator-inl.h |
| +++ b/src/profile-generator-inl.h |
| @@ -96,8 +96,35 @@ CodeEntry* ProfileGenerator::EntryForVMState(StateTag tag) { |
| HeapEntry* HeapGraphEdge::from() const { |
| - return const_cast<HeapEntry*>( |
| - reinterpret_cast<const HeapEntry*>(this - child_index_) - 1); |
| + return &snapshot()->entries()[from_]; |
| +} |
| + |
| + |
| +HeapSnapshot* HeapGraphEdge::snapshot() const { |
| + return to_entry_->snapshot(); |
| +} |
| + |
| + |
| +int HeapEntry::index() const { |
| + return this - &snapshot_->entries().first(); |
|
mnaganov (inactive)
2012/05/03 15:44:31
I'm not sure this will compile on all platforms. H
alexeif
2012/05/07 11:04:35
I'm not sure, as I don't have a Windows machine. I
|
| +} |
| + |
| + |
| +HeapGraphEdge** HeapEntry::children_arr() { |
| + ASSERT(children_index_ >= 0); |
| + return &snapshot_->children()[children_index_]; |
| +} |
| + |
| + |
| +HeapGraphEdge** HeapEntry::retainers_arr() { |
| + ASSERT(retainers_index_ >= 0); |
| + return &snapshot_->retainers()[retainers_index_]; |
| +} |
| + |
| + |
| +HeapEntry* HeapEntry::dominator() const { |
| + ASSERT(dominator_ >= 0); |
| + return &snapshot_->entries()[dominator_]; |
| } |