2011-05-03 08:23:58 +00:00
|
|
|
// Copyright 2011 the V8 project authors. All rights reserved.
|
2008-07-03 15:10:15 +00:00
|
|
|
// Redistribution and use in source and binary forms, with or without
|
|
|
|
// modification, are permitted provided that the following conditions are
|
|
|
|
// met:
|
|
|
|
//
|
|
|
|
// * Redistributions of source code must retain the above copyright
|
|
|
|
// notice, this list of conditions and the following disclaimer.
|
|
|
|
// * Redistributions in binary form must reproduce the above
|
|
|
|
// copyright notice, this list of conditions and the following
|
|
|
|
// disclaimer in the documentation and/or other materials provided
|
|
|
|
// with the distribution.
|
|
|
|
// * Neither the name of Google Inc. nor the names of its
|
|
|
|
// contributors may be used to endorse or promote products derived
|
|
|
|
// from this software without specific prior written permission.
|
|
|
|
//
|
|
|
|
// THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS
|
|
|
|
// "AS IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT
|
|
|
|
// LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR
|
|
|
|
// A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT
|
|
|
|
// OWNER OR CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL,
|
|
|
|
// SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT
|
|
|
|
// LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE,
|
|
|
|
// DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY
|
|
|
|
// THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT
|
|
|
|
// (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE
|
|
|
|
// OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
|
|
|
|
|
|
|
|
#ifndef V8_GLOBAL_HANDLES_H_
|
|
|
|
#define V8_GLOBAL_HANDLES_H_
|
|
|
|
|
2013-04-24 15:59:23 +00:00
|
|
|
#include "../include/v8.h"
|
2011-04-12 05:08:13 +00:00
|
|
|
#include "../include/v8-profiler.h"
|
|
|
|
|
2011-05-03 08:23:58 +00:00
|
|
|
#include "list.h"
|
2013-04-12 09:54:51 +00:00
|
|
|
#include "v8utils.h"
|
2008-07-03 15:10:15 +00:00
|
|
|
|
2009-05-25 10:05:56 +00:00
|
|
|
namespace v8 {
|
|
|
|
namespace internal {
|
2008-07-03 15:10:15 +00:00
|
|
|
|
2013-04-12 09:54:51 +00:00
|
|
|
class GCTracer;
|
|
|
|
class HeapStats;
|
|
|
|
class ObjectVisitor;
|
|
|
|
|
2008-07-03 15:10:15 +00:00
|
|
|
// Structure for tracking global handles.
|
|
|
|
// A single list keeps all the allocated global handles.
|
|
|
|
// Destroyed handles stay in the list but is added to the free list.
|
|
|
|
// At GC the destroyed global handles are removed from the free list
|
|
|
|
// and deallocated.
|
|
|
|
|
2013-04-24 15:59:23 +00:00
|
|
|
// Data structures for tracking object groups and implicit references.
|
|
|
|
|
2008-12-11 11:20:04 +00:00
|
|
|
// An object group is treated like a single JS object: if one of object in
|
|
|
|
// the group is alive, all objects in the same group are considered alive.
|
2008-07-03 15:10:15 +00:00
|
|
|
// An object group is used to simulate object relationship in a DOM tree.
|
2013-04-24 15:59:23 +00:00
|
|
|
|
|
|
|
// An implicit references group consists of two parts: a parent object and a
|
|
|
|
// list of children objects. If the parent is alive, all the children are alive
|
|
|
|
// too.
|
|
|
|
|
|
|
|
struct ObjectGroup {
|
|
|
|
explicit ObjectGroup(size_t length)
|
|
|
|
: info(NULL), length(length) {
|
2013-04-16 16:37:04 +00:00
|
|
|
ASSERT(length > 0);
|
2013-04-24 15:59:23 +00:00
|
|
|
objects = new Object**[length];
|
2011-04-06 19:17:54 +00:00
|
|
|
}
|
2013-04-24 15:59:23 +00:00
|
|
|
~ObjectGroup();
|
2011-04-06 19:17:54 +00:00
|
|
|
|
2013-04-24 15:59:23 +00:00
|
|
|
v8::RetainedObjectInfo* info;
|
|
|
|
Object*** objects;
|
|
|
|
size_t length;
|
|
|
|
};
|
2008-07-03 15:10:15 +00:00
|
|
|
|
2013-04-10 14:53:03 +00:00
|
|
|
|
2013-04-24 15:59:23 +00:00
|
|
|
struct ImplicitRefGroup {
|
|
|
|
ImplicitRefGroup(HeapObject** parent, size_t length)
|
|
|
|
: parent(parent), length(length) {
|
|
|
|
ASSERT(length > 0);
|
|
|
|
children = new Object**[length];
|
|
|
|
}
|
|
|
|
~ImplicitRefGroup();
|
|
|
|
|
|
|
|
HeapObject** parent;
|
|
|
|
Object*** children;
|
|
|
|
size_t length;
|
2008-07-03 15:10:15 +00:00
|
|
|
};
|
|
|
|
|
|
|
|
|
2013-04-24 15:59:23 +00:00
|
|
|
// For internal bookkeeping.
|
|
|
|
struct ObjectGroupConnection {
|
|
|
|
ObjectGroupConnection(UniqueId id, Object** object)
|
|
|
|
: id(id), object(object) {}
|
|
|
|
|
|
|
|
bool operator==(const ObjectGroupConnection& other) const {
|
|
|
|
return id == other.id;
|
2011-04-06 19:17:54 +00:00
|
|
|
}
|
2011-03-16 12:02:28 +00:00
|
|
|
|
2013-04-24 15:59:23 +00:00
|
|
|
bool operator<(const ObjectGroupConnection& other) const {
|
|
|
|
return id < other.id;
|
2013-04-16 12:57:01 +00:00
|
|
|
}
|
2011-03-16 12:02:28 +00:00
|
|
|
|
2013-04-24 15:59:23 +00:00
|
|
|
UniqueId id;
|
|
|
|
Object** object;
|
|
|
|
};
|
2013-04-16 16:37:04 +00:00
|
|
|
|
2013-04-24 15:59:23 +00:00
|
|
|
|
|
|
|
struct ObjectGroupRetainerInfo {
|
|
|
|
ObjectGroupRetainerInfo(UniqueId id, RetainedObjectInfo* info)
|
|
|
|
: id(id), info(info) {}
|
|
|
|
|
|
|
|
bool operator==(const ObjectGroupRetainerInfo& other) const {
|
|
|
|
return id == other.id;
|
|
|
|
}
|
|
|
|
|
|
|
|
bool operator<(const ObjectGroupRetainerInfo& other) const {
|
|
|
|
return id < other.id;
|
|
|
|
}
|
|
|
|
|
|
|
|
UniqueId id;
|
|
|
|
RetainedObjectInfo* info;
|
2011-03-16 12:02:28 +00:00
|
|
|
};
|
|
|
|
|
|
|
|
|
2011-03-18 20:35:07 +00:00
|
|
|
class GlobalHandles {
|
2008-07-03 15:10:15 +00:00
|
|
|
public:
|
2011-03-18 20:35:07 +00:00
|
|
|
~GlobalHandles();
|
|
|
|
|
2008-07-03 15:10:15 +00:00
|
|
|
// Creates a new global handle that is alive until Destroy is called.
|
2011-03-18 20:35:07 +00:00
|
|
|
Handle<Object> Create(Object* value);
|
2008-07-03 15:10:15 +00:00
|
|
|
|
|
|
|
// Destroy a global handle.
|
2013-05-23 08:19:27 +00:00
|
|
|
static void Destroy(Object** location);
|
2008-07-03 15:10:15 +00:00
|
|
|
|
2013-05-07 10:44:30 +00:00
|
|
|
typedef WeakReferenceCallbacks<v8::Value, void>::Revivable RevivableCallback;
|
|
|
|
|
2008-07-03 15:10:15 +00:00
|
|
|
// Make the global handle weak and set the callback parameter for the
|
|
|
|
// handle. When the garbage collector recognizes that only weak global
|
|
|
|
// handles point to an object the handles are cleared and the callback
|
|
|
|
// function is invoked (for each handle) with the handle and corresponding
|
|
|
|
// parameter as arguments. Note: cleared means set to Smi::FromInt(0). The
|
|
|
|
// reason is that Smi::FromInt(0) does not change during garage collection.
|
2013-05-29 08:32:45 +00:00
|
|
|
static void MakeWeak(Object** location,
|
|
|
|
void* parameter,
|
2013-06-03 08:17:04 +00:00
|
|
|
RevivableCallback weak_reference_callback);
|
2008-07-03 15:10:15 +00:00
|
|
|
|
2011-03-18 20:35:07 +00:00
|
|
|
void RecordStats(HeapStats* stats);
|
2009-12-03 10:16:37 +00:00
|
|
|
|
2013-01-21 12:15:31 +00:00
|
|
|
// Returns the current number of weak handles.
|
|
|
|
int NumberOfWeakHandles();
|
|
|
|
|
2008-07-03 15:10:15 +00:00
|
|
|
// Returns the current number of weak handles to global objects.
|
|
|
|
// These handles are also included in NumberOfWeakHandles().
|
2013-01-21 12:15:31 +00:00
|
|
|
int NumberOfGlobalObjectWeakHandles();
|
2008-07-03 15:10:15 +00:00
|
|
|
|
2012-03-07 17:38:50 +00:00
|
|
|
// Returns the current number of handles to global objects.
|
2013-06-21 07:56:22 +00:00
|
|
|
int global_handles_count() const {
|
2012-03-07 17:38:50 +00:00
|
|
|
return number_of_global_handles_;
|
|
|
|
}
|
|
|
|
|
2013-08-05 07:34:29 +00:00
|
|
|
// Returns the current number of allocated blocks
|
|
|
|
int block_count() const { return number_of_blocks_; }
|
|
|
|
|
2008-07-03 15:10:15 +00:00
|
|
|
// Clear the weakness of a global handle.
|
2013-05-29 08:32:45 +00:00
|
|
|
static void ClearWeakness(Object** location);
|
2008-07-03 15:10:15 +00:00
|
|
|
|
2011-05-17 12:18:19 +00:00
|
|
|
// Clear the weakness of a global handle.
|
2013-05-29 08:32:45 +00:00
|
|
|
static void MarkIndependent(Object** location);
|
2012-10-18 06:52:37 +00:00
|
|
|
|
2012-11-06 17:32:15 +00:00
|
|
|
// Mark the reference to this object externaly unreachable.
|
2013-05-29 08:32:45 +00:00
|
|
|
static void MarkPartiallyDependent(Object** location);
|
2012-11-06 17:32:15 +00:00
|
|
|
|
2012-10-18 06:52:37 +00:00
|
|
|
static bool IsIndependent(Object** location);
|
2011-05-17 12:18:19 +00:00
|
|
|
|
2008-07-03 15:10:15 +00:00
|
|
|
// Tells whether global handle is near death.
|
|
|
|
static bool IsNearDeath(Object** location);
|
|
|
|
|
|
|
|
// Tells whether global handle is weak.
|
|
|
|
static bool IsWeak(Object** location);
|
|
|
|
|
2010-10-21 06:16:52 +00:00
|
|
|
// Process pending weak handles.
|
2010-11-03 13:00:28 +00:00
|
|
|
// Returns true if next major GC is likely to collect more garbage.
|
2012-12-07 09:44:10 +00:00
|
|
|
bool PostGarbageCollectionProcessing(GarbageCollector collector,
|
|
|
|
GCTracer* tracer);
|
2008-07-03 15:10:15 +00:00
|
|
|
|
2009-11-05 15:12:36 +00:00
|
|
|
// Iterates over all strong handles.
|
2011-03-18 20:35:07 +00:00
|
|
|
void IterateStrongRoots(ObjectVisitor* v);
|
2009-11-05 15:12:36 +00:00
|
|
|
|
2008-07-03 15:10:15 +00:00
|
|
|
// Iterates over all handles.
|
2011-03-18 20:35:07 +00:00
|
|
|
void IterateAllRoots(ObjectVisitor* v);
|
2008-07-03 15:10:15 +00:00
|
|
|
|
2011-03-10 12:05:31 +00:00
|
|
|
// Iterates over all handles that have embedder-assigned class ID.
|
2011-03-18 20:35:07 +00:00
|
|
|
void IterateAllRootsWithClassIds(ObjectVisitor* v);
|
2011-03-10 12:05:31 +00:00
|
|
|
|
2013-01-24 15:53:16 +00:00
|
|
|
// Iterates over all handles in the new space that have embedder-assigned
|
|
|
|
// class ID.
|
|
|
|
void IterateAllRootsInNewSpaceWithClassIds(ObjectVisitor* v);
|
|
|
|
|
2008-07-03 15:10:15 +00:00
|
|
|
// Iterates over all weak roots in heap.
|
2011-03-18 20:35:07 +00:00
|
|
|
void IterateWeakRoots(ObjectVisitor* v);
|
2008-07-03 15:10:15 +00:00
|
|
|
|
2009-05-05 09:26:06 +00:00
|
|
|
// Find all weak handles satisfying the callback predicate, mark
|
|
|
|
// them as pending.
|
2011-03-18 20:35:07 +00:00
|
|
|
void IdentifyWeakHandles(WeakSlotCallback f);
|
2008-07-03 15:10:15 +00:00
|
|
|
|
2011-06-06 16:18:59 +00:00
|
|
|
// NOTE: Three ...NewSpace... functions below are used during
|
|
|
|
// scavenge collections and iterate over sets of handles that are
|
|
|
|
// guaranteed to contain all handles holding new space objects (but
|
|
|
|
// may also include old space objects).
|
|
|
|
|
|
|
|
// Iterates over strong and dependent handles. See the node above.
|
|
|
|
void IterateNewSpaceStrongAndDependentRoots(ObjectVisitor* v);
|
|
|
|
|
2012-11-06 17:32:15 +00:00
|
|
|
// Finds weak independent or partially independent handles satisfying
|
|
|
|
// the callback predicate and marks them as pending. See the note above.
|
2011-06-06 15:23:04 +00:00
|
|
|
void IdentifyNewSpaceWeakIndependentHandles(WeakSlotCallbackWithHeap f);
|
2011-05-17 12:18:19 +00:00
|
|
|
|
2012-11-06 17:32:15 +00:00
|
|
|
// Iterates over weak independent or partially independent handles.
|
|
|
|
// See the note above.
|
2011-06-06 16:18:59 +00:00
|
|
|
void IterateNewSpaceWeakIndependentRoots(ObjectVisitor* v);
|
|
|
|
|
2012-12-04 10:23:43 +00:00
|
|
|
// Iterate over objects in object groups that have at least one object
|
|
|
|
// which requires visiting. The callback has to return true if objects
|
|
|
|
// can be skipped and false otherwise.
|
|
|
|
bool IterateObjectGroups(ObjectVisitor* v, WeakSlotCallbackWithHeap can_skip);
|
|
|
|
|
2008-12-11 11:20:04 +00:00
|
|
|
// Add an object group.
|
2011-03-16 12:02:28 +00:00
|
|
|
// Should be only used in GC callback function before a collection.
|
2012-11-06 17:32:15 +00:00
|
|
|
// All groups are destroyed after a garbage collection.
|
2011-03-18 20:35:07 +00:00
|
|
|
void AddObjectGroup(Object*** handles,
|
|
|
|
size_t length,
|
|
|
|
v8::RetainedObjectInfo* info);
|
2011-03-16 12:02:28 +00:00
|
|
|
|
2013-04-24 15:59:23 +00:00
|
|
|
// Associates handle with the object group represented by id.
|
|
|
|
// Should be only used in GC callback function before a collection.
|
|
|
|
// All groups are destroyed after a garbage collection.
|
|
|
|
void SetObjectGroupId(Object** handle, UniqueId id);
|
|
|
|
|
|
|
|
// Set RetainedObjectInfo for an object group. Should not be called more than
|
|
|
|
// once for a group. Should not be called for a group which contains no
|
|
|
|
// handles.
|
|
|
|
void SetRetainedObjectInfo(UniqueId id, RetainedObjectInfo* info);
|
|
|
|
|
2011-03-16 12:02:28 +00:00
|
|
|
// Add an implicit references' group.
|
|
|
|
// Should be only used in GC callback function before a collection.
|
|
|
|
// All groups are destroyed after a mark-compact collection.
|
2011-04-06 19:17:54 +00:00
|
|
|
void AddImplicitReferences(HeapObject** parent,
|
2011-03-18 20:35:07 +00:00
|
|
|
Object*** children,
|
|
|
|
size_t length);
|
2008-07-03 15:10:15 +00:00
|
|
|
|
2013-04-24 15:59:23 +00:00
|
|
|
// Adds an implicit reference from a group to an object. Should be only used
|
|
|
|
// in GC callback function before a collection. All implicit references are
|
|
|
|
// destroyed after a mark-compact collection.
|
|
|
|
void SetReferenceFromGroup(UniqueId id, Object** child);
|
|
|
|
|
|
|
|
// Adds an implicit reference from a parent object to a child object. Should
|
|
|
|
// be only used in GC callback function before a collection. All implicit
|
|
|
|
// references are destroyed after a mark-compact collection.
|
|
|
|
void SetReference(HeapObject** parent, Object** child);
|
|
|
|
|
|
|
|
List<ObjectGroup*>* object_groups() {
|
|
|
|
ComputeObjectGroupsAndImplicitReferences();
|
|
|
|
return &object_groups_;
|
|
|
|
}
|
2013-04-16 12:57:01 +00:00
|
|
|
|
2013-04-16 16:37:04 +00:00
|
|
|
List<ImplicitRefGroup*>* implicit_ref_groups() {
|
2013-04-24 15:59:23 +00:00
|
|
|
ComputeObjectGroupsAndImplicitReferences();
|
2011-03-18 20:35:07 +00:00
|
|
|
return &implicit_ref_groups_;
|
|
|
|
}
|
2011-03-16 12:02:28 +00:00
|
|
|
|
2008-07-03 15:10:15 +00:00
|
|
|
// Remove bags, this should only happen after GC.
|
2011-03-18 20:35:07 +00:00
|
|
|
void RemoveObjectGroups();
|
|
|
|
void RemoveImplicitRefGroups();
|
2008-07-03 15:10:15 +00:00
|
|
|
|
|
|
|
// Tear down the global handle structure.
|
2011-03-18 20:35:07 +00:00
|
|
|
void TearDown();
|
|
|
|
|
|
|
|
Isolate* isolate() { return isolate_; }
|
2008-07-03 15:10:15 +00:00
|
|
|
|
|
|
|
#ifdef DEBUG
|
2011-03-18 20:35:07 +00:00
|
|
|
void PrintStats();
|
|
|
|
void Print();
|
2013-08-05 07:34:29 +00:00
|
|
|
void VerifyBlockInvariants();
|
2008-07-03 15:10:15 +00:00
|
|
|
#endif
|
2011-06-06 15:23:04 +00:00
|
|
|
|
2008-07-03 15:10:15 +00:00
|
|
|
private:
|
2011-03-18 20:35:07 +00:00
|
|
|
explicit GlobalHandles(Isolate* isolate);
|
|
|
|
|
2013-08-05 07:34:29 +00:00
|
|
|
void SortBlocks(bool shouldPrune);
|
|
|
|
|
2013-04-24 15:59:23 +00:00
|
|
|
// Migrates data from the internal representation (object_group_connections_,
|
|
|
|
// retainer_infos_ and implicit_ref_connections_) to the public and more
|
|
|
|
// efficient representation (object_groups_ and implicit_ref_groups_).
|
|
|
|
void ComputeObjectGroupsAndImplicitReferences();
|
|
|
|
|
|
|
|
// v8::internal::List is inefficient even for small number of elements, if we
|
|
|
|
// don't assign any initial capacity.
|
|
|
|
static const int kObjectGroupConnectionsCapacity = 20;
|
|
|
|
|
2011-06-06 15:23:04 +00:00
|
|
|
// Internal node structures.
|
2008-07-03 15:10:15 +00:00
|
|
|
class Node;
|
2011-06-06 15:23:04 +00:00
|
|
|
class NodeBlock;
|
|
|
|
class NodeIterator;
|
2013-08-05 07:34:29 +00:00
|
|
|
class BlockListIterator;
|
|
|
|
// Base class for NodeBlock
|
|
|
|
class BlockList {
|
|
|
|
public:
|
|
|
|
BlockList();
|
|
|
|
~BlockList() { ASSERT(IsDetached()); }
|
|
|
|
void Detach();
|
|
|
|
void InsertAsHead(BlockList* block) {
|
|
|
|
ASSERT(IsAnchor());
|
|
|
|
InsertAsNext(block);
|
|
|
|
}
|
|
|
|
void InsertAsTail(BlockList* block) {
|
|
|
|
ASSERT(IsAnchor());
|
|
|
|
prev_block_->InsertAsNext(block);
|
|
|
|
}
|
|
|
|
inline bool IsAnchor() { return first_free_ == NULL && used_nodes_ == 0; }
|
|
|
|
inline bool IsDetached() {
|
|
|
|
ASSERT_EQ(prev_block_ == this, next_block_ == this);
|
|
|
|
return prev_block_ == this;
|
|
|
|
}
|
|
|
|
bool HasAtLeastLength(int length);
|
|
|
|
bool IsUnused() { return used_nodes_ == 0; }
|
|
|
|
int used_nodes() const { return used_nodes_; }
|
|
|
|
BlockList* next() { return next_block_; }
|
|
|
|
BlockList* prev() { return prev_block_; }
|
|
|
|
#ifdef DEBUG
|
|
|
|
int LengthOfFreeList();
|
|
|
|
#endif
|
|
|
|
static void SortBlocks(GlobalHandles* global_handles, bool prune);
|
|
|
|
|
|
|
|
protected:
|
|
|
|
BlockList* prev_block_;
|
|
|
|
BlockList* next_block_;
|
|
|
|
Node* first_free_;
|
|
|
|
int used_nodes_;
|
|
|
|
|
|
|
|
private:
|
|
|
|
// Needed for quicksort
|
|
|
|
static int CompareBlocks(const void* a, const void* b);
|
|
|
|
void InsertAsNext(BlockList* block);
|
|
|
|
DISALLOW_COPY_AND_ASSIGN(BlockList);
|
|
|
|
};
|
2008-07-03 15:10:15 +00:00
|
|
|
|
2011-03-18 20:35:07 +00:00
|
|
|
Isolate* isolate_;
|
|
|
|
|
2013-08-05 07:34:29 +00:00
|
|
|
// Field always containing the number of blocks allocated.
|
|
|
|
int number_of_blocks_;
|
2012-03-07 17:38:50 +00:00
|
|
|
// Field always containing the number of handles to global objects.
|
|
|
|
int number_of_global_handles_;
|
|
|
|
|
2013-08-05 07:34:29 +00:00
|
|
|
// Anchors for doubly linked lists of blocks
|
|
|
|
BlockList full_blocks_;
|
|
|
|
BlockList non_full_blocks_;
|
2008-07-03 15:10:15 +00:00
|
|
|
|
2013-08-05 07:34:29 +00:00
|
|
|
// An array of all the anchors held by GlobalHandles.
|
|
|
|
// This simplifies iteration across all blocks.
|
|
|
|
static const int kAllAnchorsSize = 2;
|
|
|
|
BlockList* all_anchors_[kAllAnchorsSize];
|
2011-03-18 20:35:07 +00:00
|
|
|
|
2011-06-06 15:23:04 +00:00
|
|
|
// Contains all nodes holding new space objects. Note: when the list
|
|
|
|
// is accessed, some of the objects may have been promoted already.
|
|
|
|
List<Node*> new_space_nodes_;
|
|
|
|
|
2011-03-18 20:35:07 +00:00
|
|
|
int post_gc_processing_count_;
|
2011-06-06 15:23:04 +00:00
|
|
|
|
2013-04-24 15:59:23 +00:00
|
|
|
// Object groups and implicit references, public and more efficient
|
|
|
|
// representation.
|
2013-04-16 16:37:04 +00:00
|
|
|
List<ObjectGroup*> object_groups_;
|
|
|
|
List<ImplicitRefGroup*> implicit_ref_groups_;
|
2011-03-18 20:35:07 +00:00
|
|
|
|
2013-04-24 15:59:23 +00:00
|
|
|
// Object groups and implicit references, temporary representation while
|
|
|
|
// constructing the groups.
|
|
|
|
List<ObjectGroupConnection> object_group_connections_;
|
|
|
|
List<ObjectGroupRetainerInfo> retainer_infos_;
|
|
|
|
List<ObjectGroupConnection> implicit_ref_connections_;
|
|
|
|
|
2011-03-18 20:35:07 +00:00
|
|
|
friend class Isolate;
|
|
|
|
|
|
|
|
DISALLOW_COPY_AND_ASSIGN(GlobalHandles);
|
2008-07-03 15:10:15 +00:00
|
|
|
};
|
|
|
|
|
|
|
|
|
|
|
|
} } // namespace v8::internal
|
|
|
|
|
|
|
|
#endif // V8_GLOBAL_HANDLES_H_
|