Use OrderedHashTables as the backing store of JSSet and JSMap
This also deletes ObjectHashSet as it's no longer used. BUG=v8:1793 LOG=N R=mstarzinger@chromium.org Review URL: https://codereview.chromium.org/225183009 git-svn-id: http://v8.googlecode.com/svn/branches/bleeding_edge@20585 ce2b1a6d-e550-0410-aec6-3dcde31c8c00
This commit is contained in:
parent
60422b4541
commit
902ad4a17a
@ -5604,7 +5604,7 @@ class Internals {
|
|||||||
static const int kNullValueRootIndex = 7;
|
static const int kNullValueRootIndex = 7;
|
||||||
static const int kTrueValueRootIndex = 8;
|
static const int kTrueValueRootIndex = 8;
|
||||||
static const int kFalseValueRootIndex = 9;
|
static const int kFalseValueRootIndex = 9;
|
||||||
static const int kEmptyStringRootIndex = 159;
|
static const int kEmptyStringRootIndex = 160;
|
||||||
|
|
||||||
static const int kNodeClassIdOffset = 1 * kApiPointerSize;
|
static const int kNodeClassIdOffset = 1 * kApiPointerSize;
|
||||||
static const int kNodeFlagsOffset = 1 * kApiPointerSize + 3;
|
static const int kNodeFlagsOffset = 1 * kApiPointerSize + 3;
|
||||||
|
@ -99,15 +99,6 @@ Handle<UnseededNumberDictionary> Factory::NewUnseededNumberDictionary(
|
|||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
Handle<ObjectHashSet> Factory::NewObjectHashSet(int at_least_space_for) {
|
|
||||||
ASSERT(0 <= at_least_space_for);
|
|
||||||
CALL_HEAP_FUNCTION(isolate(),
|
|
||||||
ObjectHashSet::Allocate(isolate()->heap(),
|
|
||||||
at_least_space_for),
|
|
||||||
ObjectHashSet);
|
|
||||||
}
|
|
||||||
|
|
||||||
|
|
||||||
Handle<OrderedHashSet> Factory::NewOrderedHashSet() {
|
Handle<OrderedHashSet> Factory::NewOrderedHashSet() {
|
||||||
return OrderedHashSet::Allocate(isolate(), 4);
|
return OrderedHashSet::Allocate(isolate(), 4);
|
||||||
}
|
}
|
||||||
|
@ -46,8 +46,6 @@ class Factory V8_FINAL {
|
|||||||
|
|
||||||
Handle<NameDictionary> NewNameDictionary(int at_least_space_for);
|
Handle<NameDictionary> NewNameDictionary(int at_least_space_for);
|
||||||
|
|
||||||
Handle<ObjectHashSet> NewObjectHashSet(int at_least_space_for);
|
|
||||||
|
|
||||||
Handle<ObjectHashTable> NewObjectHashTable(
|
Handle<ObjectHashTable> NewObjectHashTable(
|
||||||
int at_least_space_for,
|
int at_least_space_for,
|
||||||
MinimumCapacity capacity_option = USE_DEFAULT_MINIMUM_CAPACITY);
|
MinimumCapacity capacity_option = USE_DEFAULT_MINIMUM_CAPACITY);
|
||||||
|
@ -2901,6 +2901,7 @@ bool Heap::CreateInitialMaps() {
|
|||||||
}
|
}
|
||||||
|
|
||||||
ALLOCATE_VARSIZE_MAP(FIXED_ARRAY_TYPE, hash_table)
|
ALLOCATE_VARSIZE_MAP(FIXED_ARRAY_TYPE, hash_table)
|
||||||
|
ALLOCATE_VARSIZE_MAP(FIXED_ARRAY_TYPE, ordered_hash_table)
|
||||||
|
|
||||||
ALLOCATE_VARSIZE_MAP(FIXED_ARRAY_TYPE, function_context)
|
ALLOCATE_VARSIZE_MAP(FIXED_ARRAY_TYPE, function_context)
|
||||||
ALLOCATE_VARSIZE_MAP(FIXED_ARRAY_TYPE, catch_context)
|
ALLOCATE_VARSIZE_MAP(FIXED_ARRAY_TYPE, catch_context)
|
||||||
|
@ -74,6 +74,7 @@ namespace internal {
|
|||||||
V(Map, constant_pool_array_map, ConstantPoolArrayMap) \
|
V(Map, constant_pool_array_map, ConstantPoolArrayMap) \
|
||||||
V(Oddball, no_interceptor_result_sentinel, NoInterceptorResultSentinel) \
|
V(Oddball, no_interceptor_result_sentinel, NoInterceptorResultSentinel) \
|
||||||
V(Map, hash_table_map, HashTableMap) \
|
V(Map, hash_table_map, HashTableMap) \
|
||||||
|
V(Map, ordered_hash_table_map, OrderedHashTableMap) \
|
||||||
V(FixedArray, empty_fixed_array, EmptyFixedArray) \
|
V(FixedArray, empty_fixed_array, EmptyFixedArray) \
|
||||||
V(ByteArray, empty_byte_array, EmptyByteArray) \
|
V(ByteArray, empty_byte_array, EmptyByteArray) \
|
||||||
V(DescriptorArray, empty_descriptor_array, EmptyDescriptorArray) \
|
V(DescriptorArray, empty_descriptor_array, EmptyDescriptorArray) \
|
||||||
@ -260,6 +261,7 @@ namespace internal {
|
|||||||
V(constant_pool_array_map) \
|
V(constant_pool_array_map) \
|
||||||
V(no_interceptor_result_sentinel) \
|
V(no_interceptor_result_sentinel) \
|
||||||
V(hash_table_map) \
|
V(hash_table_map) \
|
||||||
|
V(ordered_hash_table_map) \
|
||||||
V(empty_fixed_array) \
|
V(empty_fixed_array) \
|
||||||
V(empty_byte_array) \
|
V(empty_byte_array) \
|
||||||
V(empty_descriptor_array) \
|
V(empty_descriptor_array) \
|
||||||
|
@ -699,7 +699,7 @@ void JSSet::JSSetVerify() {
|
|||||||
CHECK(IsJSSet());
|
CHECK(IsJSSet());
|
||||||
JSObjectVerify();
|
JSObjectVerify();
|
||||||
VerifyHeapPointer(table());
|
VerifyHeapPointer(table());
|
||||||
CHECK(table()->IsHashTable() || table()->IsUndefined());
|
CHECK(table()->IsOrderedHashTable() || table()->IsUndefined());
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
@ -707,7 +707,7 @@ void JSMap::JSMapVerify() {
|
|||||||
CHECK(IsJSMap());
|
CHECK(IsJSMap());
|
||||||
JSObjectVerify();
|
JSObjectVerify();
|
||||||
VerifyHeapPointer(table());
|
VerifyHeapPointer(table());
|
||||||
CHECK(table()->IsHashTable() || table()->IsUndefined());
|
CHECK(table()->IsOrderedHashTable() || table()->IsUndefined());
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
|
@ -928,6 +928,13 @@ bool Object::IsObjectHashTable() {
|
|||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
|
bool Object::IsOrderedHashTable() {
|
||||||
|
return IsHeapObject() &&
|
||||||
|
HeapObject::cast(this)->map() ==
|
||||||
|
HeapObject::cast(this)->GetHeap()->ordered_hash_table_map();
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
bool Object::IsPrimitive() {
|
bool Object::IsPrimitive() {
|
||||||
return IsOddball() || IsNumber() || IsString();
|
return IsOddball() || IsNumber() || IsString();
|
||||||
}
|
}
|
||||||
@ -6754,28 +6761,22 @@ MaybeObject* NameDictionaryShape::AsObject(Heap* heap, Name* key) {
|
|||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
template <int entrysize>
|
bool ObjectHashTableShape::IsMatch(Object* key, Object* other) {
|
||||||
bool ObjectHashTableShape<entrysize>::IsMatch(Object* key, Object* other) {
|
|
||||||
return key->SameValue(other);
|
return key->SameValue(other);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
template <int entrysize>
|
uint32_t ObjectHashTableShape::Hash(Object* key) {
|
||||||
uint32_t ObjectHashTableShape<entrysize>::Hash(Object* key) {
|
|
||||||
return Smi::cast(key->GetHash())->value();
|
return Smi::cast(key->GetHash())->value();
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
template <int entrysize>
|
uint32_t ObjectHashTableShape::HashForObject(Object* key, Object* other) {
|
||||||
uint32_t ObjectHashTableShape<entrysize>::HashForObject(Object* key,
|
|
||||||
Object* other) {
|
|
||||||
return Smi::cast(other->GetHash())->value();
|
return Smi::cast(other->GetHash())->value();
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
template <int entrysize>
|
MaybeObject* ObjectHashTableShape::AsObject(Heap* heap, Object* key) {
|
||||||
MaybeObject* ObjectHashTableShape<entrysize>::AsObject(Heap* heap,
|
|
||||||
Object* key) {
|
|
||||||
return key;
|
return key;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -14251,9 +14251,7 @@ template class HashTable<CompilationCacheShape, HashTableKey*>;
|
|||||||
|
|
||||||
template class HashTable<MapCacheShape, HashTableKey*>;
|
template class HashTable<MapCacheShape, HashTableKey*>;
|
||||||
|
|
||||||
template class HashTable<ObjectHashTableShape<1>, Object*>;
|
template class HashTable<ObjectHashTableShape, Object*>;
|
||||||
|
|
||||||
template class HashTable<ObjectHashTableShape<2>, Object*>;
|
|
||||||
|
|
||||||
template class HashTable<WeakHashTableShape<2>, Object*>;
|
template class HashTable<WeakHashTableShape<2>, Object*>;
|
||||||
|
|
||||||
@ -15775,87 +15773,12 @@ MaybeObject* NameDictionary::TransformPropertiesToFastFor(
|
|||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
Handle<ObjectHashSet> ObjectHashSet::EnsureCapacity(
|
|
||||||
Handle<ObjectHashSet> table,
|
|
||||||
int n,
|
|
||||||
Handle<Object> key,
|
|
||||||
PretenureFlag pretenure) {
|
|
||||||
Handle<HashTable<ObjectHashTableShape<1>, Object*> > table_base = table;
|
|
||||||
CALL_HEAP_FUNCTION(table_base->GetIsolate(),
|
|
||||||
table_base->EnsureCapacity(n, *key, pretenure),
|
|
||||||
ObjectHashSet);
|
|
||||||
}
|
|
||||||
|
|
||||||
|
|
||||||
Handle<ObjectHashSet> ObjectHashSet::Shrink(Handle<ObjectHashSet> table,
|
|
||||||
Handle<Object> key) {
|
|
||||||
Handle<HashTable<ObjectHashTableShape<1>, Object*> > table_base = table;
|
|
||||||
CALL_HEAP_FUNCTION(table_base->GetIsolate(),
|
|
||||||
table_base->Shrink(*key),
|
|
||||||
ObjectHashSet);
|
|
||||||
}
|
|
||||||
|
|
||||||
|
|
||||||
bool ObjectHashSet::Contains(Object* key) {
|
|
||||||
ASSERT(IsKey(key));
|
|
||||||
|
|
||||||
// If the object does not have an identity hash, it was never used as a key.
|
|
||||||
Object* hash = key->GetHash();
|
|
||||||
if (hash->IsUndefined()) return false;
|
|
||||||
|
|
||||||
return (FindEntry(key) != kNotFound);
|
|
||||||
}
|
|
||||||
|
|
||||||
|
|
||||||
Handle<ObjectHashSet> ObjectHashSet::Add(Handle<ObjectHashSet> table,
|
|
||||||
Handle<Object> key) {
|
|
||||||
ASSERT(table->IsKey(*key));
|
|
||||||
|
|
||||||
// Make sure the key object has an identity hash code.
|
|
||||||
Handle<Object> object_hash = Object::GetOrCreateHash(key,
|
|
||||||
table->GetIsolate());
|
|
||||||
|
|
||||||
int entry = table->FindEntry(*key);
|
|
||||||
|
|
||||||
// Check whether key is already present.
|
|
||||||
if (entry != kNotFound) return table;
|
|
||||||
|
|
||||||
// Check whether the hash set should be extended and add entry.
|
|
||||||
Handle<ObjectHashSet> new_table =
|
|
||||||
ObjectHashSet::EnsureCapacity(table, 1, key);
|
|
||||||
entry = new_table->FindInsertionEntry(Smi::cast(*object_hash)->value());
|
|
||||||
new_table->set(EntryToIndex(entry), *key);
|
|
||||||
new_table->ElementAdded();
|
|
||||||
return new_table;
|
|
||||||
}
|
|
||||||
|
|
||||||
|
|
||||||
Handle<ObjectHashSet> ObjectHashSet::Remove(Handle<ObjectHashSet> table,
|
|
||||||
Handle<Object> key) {
|
|
||||||
ASSERT(table->IsKey(*key));
|
|
||||||
|
|
||||||
// If the object does not have an identity hash, it was never used as a key.
|
|
||||||
if (key->GetHash()->IsUndefined()) return table;
|
|
||||||
|
|
||||||
int entry = table->FindEntry(*key);
|
|
||||||
|
|
||||||
// Check whether key is actually present.
|
|
||||||
if (entry == kNotFound) return table;
|
|
||||||
|
|
||||||
// Remove entry and try to shrink this hash set.
|
|
||||||
table->set_the_hole(EntryToIndex(entry));
|
|
||||||
table->ElementRemoved();
|
|
||||||
|
|
||||||
return ObjectHashSet::Shrink(table, key);
|
|
||||||
}
|
|
||||||
|
|
||||||
|
|
||||||
Handle<ObjectHashTable> ObjectHashTable::EnsureCapacity(
|
Handle<ObjectHashTable> ObjectHashTable::EnsureCapacity(
|
||||||
Handle<ObjectHashTable> table,
|
Handle<ObjectHashTable> table,
|
||||||
int n,
|
int n,
|
||||||
Handle<Object> key,
|
Handle<Object> key,
|
||||||
PretenureFlag pretenure) {
|
PretenureFlag pretenure) {
|
||||||
Handle<HashTable<ObjectHashTableShape<2>, Object*> > table_base = table;
|
Handle<HashTable<ObjectHashTableShape, Object*> > table_base = table;
|
||||||
CALL_HEAP_FUNCTION(table_base->GetIsolate(),
|
CALL_HEAP_FUNCTION(table_base->GetIsolate(),
|
||||||
table_base->EnsureCapacity(n, *key, pretenure),
|
table_base->EnsureCapacity(n, *key, pretenure),
|
||||||
ObjectHashTable);
|
ObjectHashTable);
|
||||||
@ -15864,7 +15787,7 @@ Handle<ObjectHashTable> ObjectHashTable::EnsureCapacity(
|
|||||||
|
|
||||||
Handle<ObjectHashTable> ObjectHashTable::Shrink(
|
Handle<ObjectHashTable> ObjectHashTable::Shrink(
|
||||||
Handle<ObjectHashTable> table, Handle<Object> key) {
|
Handle<ObjectHashTable> table, Handle<Object> key) {
|
||||||
Handle<HashTable<ObjectHashTableShape<2>, Object*> > table_base = table;
|
Handle<HashTable<ObjectHashTableShape, Object*> > table_base = table;
|
||||||
CALL_HEAP_FUNCTION(table_base->GetIsolate(),
|
CALL_HEAP_FUNCTION(table_base->GetIsolate(),
|
||||||
table_base->Shrink(*key),
|
table_base->Shrink(*key),
|
||||||
ObjectHashTable);
|
ObjectHashTable);
|
||||||
@ -15982,11 +15905,11 @@ Handle<Derived> OrderedHashTable<Derived, entrysize>::Allocate(
|
|||||||
v8::internal::Heap::FatalProcessOutOfMemory("invalid table size", true);
|
v8::internal::Heap::FatalProcessOutOfMemory("invalid table size", true);
|
||||||
}
|
}
|
||||||
int num_buckets = capacity / kLoadFactor;
|
int num_buckets = capacity / kLoadFactor;
|
||||||
Handle<Derived> table =
|
Handle<FixedArray> backing_store = isolate->factory()->NewFixedArray(
|
||||||
Handle<Derived>::cast(
|
kHashTableStartIndex + num_buckets + (capacity * kEntrySize), pretenure);
|
||||||
isolate->factory()->NewFixedArray(
|
backing_store->set_map_no_write_barrier(
|
||||||
kHashTableStartIndex + num_buckets + (capacity * kEntrySize),
|
isolate->heap()->ordered_hash_table_map());
|
||||||
pretenure));
|
Handle<Derived> table = Handle<Derived>::cast(backing_store);
|
||||||
for (int i = 0; i < num_buckets; ++i) {
|
for (int i = 0; i < num_buckets; ++i) {
|
||||||
table->set(kHashTableStartIndex + i, Smi::FromInt(kNotFound));
|
table->set(kHashTableStartIndex + i, Smi::FromInt(kNotFound));
|
||||||
}
|
}
|
||||||
|
@ -1076,7 +1076,8 @@ class MaybeObject BASE_EMBEDDED {
|
|||||||
V(Cell) \
|
V(Cell) \
|
||||||
V(PropertyCell) \
|
V(PropertyCell) \
|
||||||
V(ObjectHashTable) \
|
V(ObjectHashTable) \
|
||||||
V(WeakHashTable)
|
V(WeakHashTable) \
|
||||||
|
V(OrderedHashTable)
|
||||||
|
|
||||||
|
|
||||||
#define ERROR_MESSAGES_LIST(V) \
|
#define ERROR_MESSAGES_LIST(V) \
|
||||||
@ -3779,7 +3780,6 @@ class HashTable: public FixedArray {
|
|||||||
void Rehash(Key key);
|
void Rehash(Key key);
|
||||||
|
|
||||||
protected:
|
protected:
|
||||||
friend class ObjectHashSet;
|
|
||||||
friend class ObjectHashTable;
|
friend class ObjectHashTable;
|
||||||
|
|
||||||
// Find the entry at which to insert element with the given key that
|
// Find the entry at which to insert element with the given key that
|
||||||
@ -4210,7 +4210,6 @@ class UnseededNumberDictionary
|
|||||||
};
|
};
|
||||||
|
|
||||||
|
|
||||||
template <int entrysize>
|
|
||||||
class ObjectHashTableShape : public BaseShape<Object*> {
|
class ObjectHashTableShape : public BaseShape<Object*> {
|
||||||
public:
|
public:
|
||||||
static inline bool IsMatch(Object* key, Object* other);
|
static inline bool IsMatch(Object* key, Object* other);
|
||||||
@ -4219,45 +4218,13 @@ class ObjectHashTableShape : public BaseShape<Object*> {
|
|||||||
MUST_USE_RESULT static inline MaybeObject* AsObject(Heap* heap,
|
MUST_USE_RESULT static inline MaybeObject* AsObject(Heap* heap,
|
||||||
Object* key);
|
Object* key);
|
||||||
static const int kPrefixSize = 0;
|
static const int kPrefixSize = 0;
|
||||||
static const int kEntrySize = entrysize;
|
static const int kEntrySize = 2;
|
||||||
};
|
|
||||||
|
|
||||||
|
|
||||||
// ObjectHashSet holds keys that are arbitrary objects by using the identity
|
|
||||||
// hash of the key for hashing purposes.
|
|
||||||
class ObjectHashSet: public HashTable<ObjectHashTableShape<1>, Object*> {
|
|
||||||
public:
|
|
||||||
static inline ObjectHashSet* cast(Object* obj) {
|
|
||||||
ASSERT(obj->IsHashTable());
|
|
||||||
return reinterpret_cast<ObjectHashSet*>(obj);
|
|
||||||
}
|
|
||||||
|
|
||||||
// Looks up whether the given key is part of this hash set.
|
|
||||||
bool Contains(Object* key);
|
|
||||||
|
|
||||||
static Handle<ObjectHashSet> EnsureCapacity(
|
|
||||||
Handle<ObjectHashSet> table,
|
|
||||||
int n,
|
|
||||||
Handle<Object> key,
|
|
||||||
PretenureFlag pretenure = NOT_TENURED);
|
|
||||||
|
|
||||||
// Attempt to shrink hash table after removal of key.
|
|
||||||
static Handle<ObjectHashSet> Shrink(Handle<ObjectHashSet> table,
|
|
||||||
Handle<Object> key);
|
|
||||||
|
|
||||||
// Adds the given key to this hash set.
|
|
||||||
static Handle<ObjectHashSet> Add(Handle<ObjectHashSet> table,
|
|
||||||
Handle<Object> key);
|
|
||||||
|
|
||||||
// Removes the given key from this hash set.
|
|
||||||
static Handle<ObjectHashSet> Remove(Handle<ObjectHashSet> table,
|
|
||||||
Handle<Object> key);
|
|
||||||
};
|
};
|
||||||
|
|
||||||
|
|
||||||
// ObjectHashTable maps keys that are arbitrary objects to object values by
|
// ObjectHashTable maps keys that are arbitrary objects to object values by
|
||||||
// using the identity hash of the key for hashing purposes.
|
// using the identity hash of the key for hashing purposes.
|
||||||
class ObjectHashTable: public HashTable<ObjectHashTableShape<2>, Object*> {
|
class ObjectHashTable: public HashTable<ObjectHashTableShape, Object*> {
|
||||||
public:
|
public:
|
||||||
static inline ObjectHashTable* cast(Object* obj) {
|
static inline ObjectHashTable* cast(Object* obj) {
|
||||||
ASSERT(obj->IsHashTable());
|
ASSERT(obj->IsHashTable());
|
||||||
@ -4329,7 +4296,7 @@ class OrderedHashTable: public FixedArray {
|
|||||||
Isolate* isolate, int capacity, PretenureFlag pretenure = NOT_TENURED);
|
Isolate* isolate, int capacity, PretenureFlag pretenure = NOT_TENURED);
|
||||||
|
|
||||||
// Returns an OrderedHashTable (possibly |table|) with enough space
|
// Returns an OrderedHashTable (possibly |table|) with enough space
|
||||||
// to add at least one new element, or returns a Failure if a GC occurs.
|
// to add at least one new element.
|
||||||
static Handle<Derived> EnsureGrowable(Handle<Derived> table);
|
static Handle<Derived> EnsureGrowable(Handle<Derived> table);
|
||||||
|
|
||||||
// Returns an OrderedHashTable (possibly |table|) that's shrunken
|
// Returns an OrderedHashTable (possibly |table|) that's shrunken
|
||||||
@ -4420,7 +4387,7 @@ class OrderedHashTable: public FixedArray {
|
|||||||
class OrderedHashSet: public OrderedHashTable<OrderedHashSet, 1> {
|
class OrderedHashSet: public OrderedHashTable<OrderedHashSet, 1> {
|
||||||
public:
|
public:
|
||||||
static OrderedHashSet* cast(Object* obj) {
|
static OrderedHashSet* cast(Object* obj) {
|
||||||
ASSERT(obj->IsFixedArray()); // TODO(adamk): Make a map for this
|
ASSERT(obj->IsOrderedHashTable());
|
||||||
return reinterpret_cast<OrderedHashSet*>(obj);
|
return reinterpret_cast<OrderedHashSet*>(obj);
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -4435,7 +4402,7 @@ class OrderedHashSet: public OrderedHashTable<OrderedHashSet, 1> {
|
|||||||
class OrderedHashMap: public OrderedHashTable<OrderedHashMap, 2> {
|
class OrderedHashMap: public OrderedHashTable<OrderedHashMap, 2> {
|
||||||
public:
|
public:
|
||||||
static OrderedHashMap* cast(Object* obj) {
|
static OrderedHashMap* cast(Object* obj) {
|
||||||
ASSERT(obj->IsFixedArray()); // TODO(adamk): Make a map for this
|
ASSERT(obj->IsOrderedHashTable());
|
||||||
return reinterpret_cast<OrderedHashMap*>(obj);
|
return reinterpret_cast<OrderedHashMap*>(obj);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -1507,7 +1507,7 @@ RUNTIME_FUNCTION(MaybeObject*, Runtime_SetInitialize) {
|
|||||||
HandleScope scope(isolate);
|
HandleScope scope(isolate);
|
||||||
ASSERT(args.length() == 1);
|
ASSERT(args.length() == 1);
|
||||||
CONVERT_ARG_HANDLE_CHECKED(JSSet, holder, 0);
|
CONVERT_ARG_HANDLE_CHECKED(JSSet, holder, 0);
|
||||||
Handle<ObjectHashSet> table = isolate->factory()->NewObjectHashSet(0);
|
Handle<OrderedHashSet> table = isolate->factory()->NewOrderedHashSet();
|
||||||
holder->set_table(*table);
|
holder->set_table(*table);
|
||||||
return *holder;
|
return *holder;
|
||||||
}
|
}
|
||||||
@ -1518,8 +1518,8 @@ RUNTIME_FUNCTION(MaybeObject*, Runtime_SetAdd) {
|
|||||||
ASSERT(args.length() == 2);
|
ASSERT(args.length() == 2);
|
||||||
CONVERT_ARG_HANDLE_CHECKED(JSSet, holder, 0);
|
CONVERT_ARG_HANDLE_CHECKED(JSSet, holder, 0);
|
||||||
Handle<Object> key(args[1], isolate);
|
Handle<Object> key(args[1], isolate);
|
||||||
Handle<ObjectHashSet> table(ObjectHashSet::cast(holder->table()));
|
Handle<OrderedHashSet> table(OrderedHashSet::cast(holder->table()));
|
||||||
table = ObjectHashSet::Add(table, key);
|
table = OrderedHashSet::Add(table, key);
|
||||||
holder->set_table(*table);
|
holder->set_table(*table);
|
||||||
return isolate->heap()->undefined_value();
|
return isolate->heap()->undefined_value();
|
||||||
}
|
}
|
||||||
@ -1530,7 +1530,7 @@ RUNTIME_FUNCTION(MaybeObject*, Runtime_SetHas) {
|
|||||||
ASSERT(args.length() == 2);
|
ASSERT(args.length() == 2);
|
||||||
CONVERT_ARG_HANDLE_CHECKED(JSSet, holder, 0);
|
CONVERT_ARG_HANDLE_CHECKED(JSSet, holder, 0);
|
||||||
Handle<Object> key(args[1], isolate);
|
Handle<Object> key(args[1], isolate);
|
||||||
Handle<ObjectHashSet> table(ObjectHashSet::cast(holder->table()));
|
Handle<OrderedHashSet> table(OrderedHashSet::cast(holder->table()));
|
||||||
return isolate->heap()->ToBoolean(table->Contains(*key));
|
return isolate->heap()->ToBoolean(table->Contains(*key));
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -1540,8 +1540,8 @@ RUNTIME_FUNCTION(MaybeObject*, Runtime_SetDelete) {
|
|||||||
ASSERT(args.length() == 2);
|
ASSERT(args.length() == 2);
|
||||||
CONVERT_ARG_HANDLE_CHECKED(JSSet, holder, 0);
|
CONVERT_ARG_HANDLE_CHECKED(JSSet, holder, 0);
|
||||||
Handle<Object> key(args[1], isolate);
|
Handle<Object> key(args[1], isolate);
|
||||||
Handle<ObjectHashSet> table(ObjectHashSet::cast(holder->table()));
|
Handle<OrderedHashSet> table(OrderedHashSet::cast(holder->table()));
|
||||||
table = ObjectHashSet::Remove(table, key);
|
table = OrderedHashSet::Remove(table, key);
|
||||||
holder->set_table(*table);
|
holder->set_table(*table);
|
||||||
return isolate->heap()->undefined_value();
|
return isolate->heap()->undefined_value();
|
||||||
}
|
}
|
||||||
@ -1551,7 +1551,7 @@ RUNTIME_FUNCTION(MaybeObject*, Runtime_SetGetSize) {
|
|||||||
HandleScope scope(isolate);
|
HandleScope scope(isolate);
|
||||||
ASSERT(args.length() == 1);
|
ASSERT(args.length() == 1);
|
||||||
CONVERT_ARG_HANDLE_CHECKED(JSSet, holder, 0);
|
CONVERT_ARG_HANDLE_CHECKED(JSSet, holder, 0);
|
||||||
Handle<ObjectHashSet> table(ObjectHashSet::cast(holder->table()));
|
Handle<OrderedHashSet> table(OrderedHashSet::cast(holder->table()));
|
||||||
return Smi::FromInt(table->NumberOfElements());
|
return Smi::FromInt(table->NumberOfElements());
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -1560,7 +1560,7 @@ RUNTIME_FUNCTION(MaybeObject*, Runtime_MapInitialize) {
|
|||||||
HandleScope scope(isolate);
|
HandleScope scope(isolate);
|
||||||
ASSERT(args.length() == 1);
|
ASSERT(args.length() == 1);
|
||||||
CONVERT_ARG_HANDLE_CHECKED(JSMap, holder, 0);
|
CONVERT_ARG_HANDLE_CHECKED(JSMap, holder, 0);
|
||||||
Handle<ObjectHashTable> table = isolate->factory()->NewObjectHashTable(0);
|
Handle<OrderedHashMap> table = isolate->factory()->NewOrderedHashMap();
|
||||||
holder->set_table(*table);
|
holder->set_table(*table);
|
||||||
return *holder;
|
return *holder;
|
||||||
}
|
}
|
||||||
@ -1571,7 +1571,7 @@ RUNTIME_FUNCTION(MaybeObject*, Runtime_MapGet) {
|
|||||||
ASSERT(args.length() == 2);
|
ASSERT(args.length() == 2);
|
||||||
CONVERT_ARG_HANDLE_CHECKED(JSMap, holder, 0);
|
CONVERT_ARG_HANDLE_CHECKED(JSMap, holder, 0);
|
||||||
CONVERT_ARG_HANDLE_CHECKED(Object, key, 1);
|
CONVERT_ARG_HANDLE_CHECKED(Object, key, 1);
|
||||||
Handle<ObjectHashTable> table(ObjectHashTable::cast(holder->table()));
|
Handle<OrderedHashMap> table(OrderedHashMap::cast(holder->table()));
|
||||||
Handle<Object> lookup(table->Lookup(*key), isolate);
|
Handle<Object> lookup(table->Lookup(*key), isolate);
|
||||||
return lookup->IsTheHole() ? isolate->heap()->undefined_value() : *lookup;
|
return lookup->IsTheHole() ? isolate->heap()->undefined_value() : *lookup;
|
||||||
}
|
}
|
||||||
@ -1582,7 +1582,7 @@ RUNTIME_FUNCTION(MaybeObject*, Runtime_MapHas) {
|
|||||||
ASSERT(args.length() == 2);
|
ASSERT(args.length() == 2);
|
||||||
CONVERT_ARG_HANDLE_CHECKED(JSMap, holder, 0);
|
CONVERT_ARG_HANDLE_CHECKED(JSMap, holder, 0);
|
||||||
CONVERT_ARG_HANDLE_CHECKED(Object, key, 1);
|
CONVERT_ARG_HANDLE_CHECKED(Object, key, 1);
|
||||||
Handle<ObjectHashTable> table(ObjectHashTable::cast(holder->table()));
|
Handle<OrderedHashMap> table(OrderedHashMap::cast(holder->table()));
|
||||||
Handle<Object> lookup(table->Lookup(*key), isolate);
|
Handle<Object> lookup(table->Lookup(*key), isolate);
|
||||||
return isolate->heap()->ToBoolean(!lookup->IsTheHole());
|
return isolate->heap()->ToBoolean(!lookup->IsTheHole());
|
||||||
}
|
}
|
||||||
@ -1593,10 +1593,10 @@ RUNTIME_FUNCTION(MaybeObject*, Runtime_MapDelete) {
|
|||||||
ASSERT(args.length() == 2);
|
ASSERT(args.length() == 2);
|
||||||
CONVERT_ARG_HANDLE_CHECKED(JSMap, holder, 0);
|
CONVERT_ARG_HANDLE_CHECKED(JSMap, holder, 0);
|
||||||
CONVERT_ARG_HANDLE_CHECKED(Object, key, 1);
|
CONVERT_ARG_HANDLE_CHECKED(Object, key, 1);
|
||||||
Handle<ObjectHashTable> table(ObjectHashTable::cast(holder->table()));
|
Handle<OrderedHashMap> table(OrderedHashMap::cast(holder->table()));
|
||||||
Handle<Object> lookup(table->Lookup(*key), isolate);
|
Handle<Object> lookup(table->Lookup(*key), isolate);
|
||||||
Handle<ObjectHashTable> new_table =
|
Handle<OrderedHashMap> new_table =
|
||||||
ObjectHashTable::Put(table, key, isolate->factory()->the_hole_value());
|
OrderedHashMap::Put(table, key, isolate->factory()->the_hole_value());
|
||||||
holder->set_table(*new_table);
|
holder->set_table(*new_table);
|
||||||
return isolate->heap()->ToBoolean(!lookup->IsTheHole());
|
return isolate->heap()->ToBoolean(!lookup->IsTheHole());
|
||||||
}
|
}
|
||||||
@ -1608,8 +1608,8 @@ RUNTIME_FUNCTION(MaybeObject*, Runtime_MapSet) {
|
|||||||
CONVERT_ARG_HANDLE_CHECKED(JSMap, holder, 0);
|
CONVERT_ARG_HANDLE_CHECKED(JSMap, holder, 0);
|
||||||
CONVERT_ARG_HANDLE_CHECKED(Object, key, 1);
|
CONVERT_ARG_HANDLE_CHECKED(Object, key, 1);
|
||||||
CONVERT_ARG_HANDLE_CHECKED(Object, value, 2);
|
CONVERT_ARG_HANDLE_CHECKED(Object, value, 2);
|
||||||
Handle<ObjectHashTable> table(ObjectHashTable::cast(holder->table()));
|
Handle<OrderedHashMap> table(OrderedHashMap::cast(holder->table()));
|
||||||
Handle<ObjectHashTable> new_table = ObjectHashTable::Put(table, key, value);
|
Handle<OrderedHashMap> new_table = OrderedHashMap::Put(table, key, value);
|
||||||
holder->set_table(*new_table);
|
holder->set_table(*new_table);
|
||||||
return isolate->heap()->undefined_value();
|
return isolate->heap()->undefined_value();
|
||||||
}
|
}
|
||||||
@ -1619,7 +1619,7 @@ RUNTIME_FUNCTION(MaybeObject*, Runtime_MapGetSize) {
|
|||||||
HandleScope scope(isolate);
|
HandleScope scope(isolate);
|
||||||
ASSERT(args.length() == 1);
|
ASSERT(args.length() == 1);
|
||||||
CONVERT_ARG_HANDLE_CHECKED(JSMap, holder, 0);
|
CONVERT_ARG_HANDLE_CHECKED(JSMap, holder, 0);
|
||||||
Handle<ObjectHashTable> table(ObjectHashTable::cast(holder->table()));
|
Handle<OrderedHashMap> table(OrderedHashMap::cast(holder->table()));
|
||||||
return Smi::FromInt(table->NumberOfElements());
|
return Smi::FromInt(table->NumberOfElements());
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -201,7 +201,6 @@ TEST(ObjectHashSetCausesGC) {
|
|||||||
LocalContext context;
|
LocalContext context;
|
||||||
v8::HandleScope scope(context->GetIsolate());
|
v8::HandleScope scope(context->GetIsolate());
|
||||||
Isolate* isolate = CcTest::i_isolate();
|
Isolate* isolate = CcTest::i_isolate();
|
||||||
TestHashSetCausesGC(isolate->factory()->NewObjectHashSet(1));
|
|
||||||
TestHashSetCausesGC(isolate->factory()->NewOrderedHashSet());
|
TestHashSetCausesGC(isolate->factory()->NewOrderedHashSet());
|
||||||
}
|
}
|
||||||
#endif
|
#endif
|
||||||
|
Loading…
Reference in New Issue
Block a user