![]() |
v8
3.14.5(node0.10.28)
V8 is Google's open source JavaScript engine
|
#include <objects.h>


Public Types | |
| enum | SortMode { UNSORTED, SORTED } |
Public Types inherited from HashTable< Shape, Key > | |
| enum | MinimumCapacity { USE_DEFAULT_MINIMUM_CAPACITY, USE_CUSTOM_MINIMUM_CAPACITY } |
Public Member Functions | |
| Object * | ValueAt (int entry) |
| void | ValueAtPut (int entry, Object *value) |
| PropertyDetails | DetailsAt (int entry) |
| void | DetailsAtPut (int entry, PropertyDetails value) |
| void | CopyValuesTo (FixedArray *elements) |
| Object * | DeleteProperty (int entry, JSObject::DeleteMode mode) |
| MUST_USE_RESULT MaybeObject * | Shrink (Key key) |
| int | NumberOfElementsFilterAttributes (PropertyAttributes filter) |
| int | NumberOfEnumElements () |
| void | CopyKeysTo (FixedArray *storage, PropertyAttributes filter, SortMode sort_mode) |
| void | CopyKeysTo (FixedArray *storage, int index, SortMode sort_mode) |
| void | SetNextEnumerationIndex (int index) |
| int | NextEnumerationIndex () |
| MUST_USE_RESULT MaybeObject * | EnsureCapacity (int n, Key key) |
| Object * | SlowReverseLookup (Object *value) |
| void | SetEntry (int entry, Object *key, Object *value) |
| void | SetEntry (int entry, Object *key, Object *value, PropertyDetails details) |
| MUST_USE_RESULT MaybeObject * | Add (Key key, Object *value, PropertyDetails details) |
Public Member Functions inherited from HashTable< Shape, Key > | |
| uint32_t | Hash (Key key) |
| uint32_t | HashForObject (Key key, Object *object) |
| int | NumberOfElements () |
| int | NumberOfDeletedElements () |
| int | Capacity () |
| void | ElementAdded () |
| void | ElementRemoved () |
| void | ElementsRemoved (int n) |
| Object * | KeyAt (int entry) |
| bool | IsKey (Object *k) |
| void | IteratePrefix (ObjectVisitor *visitor) |
| void | IterateElements (ObjectVisitor *visitor) |
| INLINE (static uint32_t GetProbeOffset(uint32_t n)) | |
| int | FindEntry (Key key) |
| int | FindEntry (Isolate *isolate, Key key) |
Public Member Functions inherited from FixedArray | |
| Object * | get (int index) |
| void | set (int index, Object *value) |
| bool | is_the_hole (int index) |
| void | set (int index, Smi *value) |
| void | set (int index, Object *value, WriteBarrierMode mode) |
| void | set_undefined (int index) |
| void | set_undefined (Heap *heap, int index) |
| void | set_null (int index) |
| void | set_null (Heap *heap, int index) |
| void | set_the_hole (int index) |
| void | set_unchecked (int index, Smi *value) |
| void | set_null_unchecked (Heap *heap, int index) |
| void | set_unchecked (Heap *heap, int index, Object *value, WriteBarrierMode mode) |
| Object ** | data_start () |
| Object ** | GetFirstElementAddress () |
| bool | ContainsOnlySmisOrHoles () |
| MUST_USE_RESULT MaybeObject * | Copy () |
| MUST_USE_RESULT MaybeObject * | CopySize (int new_length) |
| MUST_USE_RESULT MaybeObject * | AddKeysFromJSArray (JSArray *array) |
| MUST_USE_RESULT MaybeObject * | UnionOfKeys (FixedArray *other) |
| void | CopyTo (int pos, FixedArray *dest, int dest_pos, int len) |
| void | SwapPairs (FixedArray *numbers, int i, int j) |
| void | SortPairs (FixedArray *numbers, uint32_t len) |
Public Member Functions inherited from FixedArrayBase | |
| int | length () |
| void | set_length (int value) |
Public Member Functions inherited from HeapObject | |
| Map * | map () |
| void | set_map (Map *value) |
| void | set_map_no_write_barrier (Map *value) |
| MapWord | map_word () |
| void | set_map_word (MapWord map_word) |
| Heap * | GetHeap () |
| Isolate * | GetIsolate () |
| Address | address () |
| void | Iterate (ObjectVisitor *v) |
| void | IterateBody (InstanceType type, int object_size, ObjectVisitor *v) |
| int | Size () |
| int | SizeFromMap (Map *map) |
| WriteBarrierMode | GetWriteBarrierMode (const AssertNoAllocation &) |
| void | HeapObjectShortPrint (StringStream *accumulator) |
| STATIC_CHECK (kMapOffset==Internals::kHeapObjectMapOffset) | |
Public Member Functions inherited from Object | |
| bool | IsObject () |
| bool | IsFixedArrayBase () |
| bool | IsInstanceOf (FunctionTemplateInfo *type) |
| bool | IsStruct () |
| INLINE (bool IsSpecObject()) | |
| INLINE (bool IsSpecFunction()) | |
| INLINE (bool IsUndefined()) | |
| INLINE (bool IsNull()) | |
| INLINE (bool IsTheHole()) | |
| INLINE (bool IsTrue()) | |
| INLINE (bool IsFalse()) | |
| bool | IsArgumentsMarker () |
| bool | NonFailureIsHeapObject () |
| bool | IsFiller () |
| double | Number () |
| bool | IsNaN () |
| bool | HasValidElements () |
| bool | HasSpecificClassOf (String *name) |
| MUST_USE_RESULT MaybeObject * | ToObject () |
| Object * | ToBoolean () |
| MUST_USE_RESULT MaybeObject * | ToObject (Context *native_context) |
| MUST_USE_RESULT MaybeObject * | ToSmi () |
| void | Lookup (String *name, LookupResult *result) |
| MUST_USE_RESULT MaybeObject * | GetProperty (String *key) |
| MUST_USE_RESULT MaybeObject * | GetProperty (String *key, PropertyAttributes *attributes) |
| MUST_USE_RESULT MaybeObject * | GetPropertyWithReceiver (Object *receiver, String *key, PropertyAttributes *attributes) |
| MUST_USE_RESULT MaybeObject * | GetProperty (Object *receiver, LookupResult *result, String *key, PropertyAttributes *attributes) |
| MUST_USE_RESULT MaybeObject * | GetPropertyWithDefinedGetter (Object *receiver, JSReceiver *getter) |
| MUST_USE_RESULT MaybeObject * | GetElement (uint32_t index) |
| Object * | GetElementNoExceptionThrown (uint32_t index) |
| MUST_USE_RESULT MaybeObject * | GetElementWithReceiver (Object *receiver, uint32_t index) |
| Object * | GetPrototype () |
| MUST_USE_RESULT MaybeObject * | GetHash (CreationFlag flag) |
| bool | SameValue (Object *other) |
| bool | ToArrayIndex (uint32_t *index) |
| bool | IsStringObjectWithCharacterAt (uint32_t index) |
| void | VerifyApiCallResultType () |
| void | ShortPrint () |
| void | ShortPrint (FILE *out) |
| void | ShortPrint (StringStream *accumulator) |
Static Public Member Functions | |
| static Dictionary< Shape, Key > * | cast (Object *obj) |
| static MUST_USE_RESULT MaybeObject * | Allocate (int at_least_space_for) |
Static Public Member Functions inherited from HashTable< Shape, Key > | |
| static MUST_USE_RESULT MaybeObject * | Allocate (int at_least_space_for, MinimumCapacity capacity_option=USE_DEFAULT_MINIMUM_CAPACITY, PretenureFlag pretenure=NOT_TENURED) |
| static int | ComputeCapacity (int at_least_space_for) |
| static HashTable * | cast (Object *obj) |
Static Public Member Functions inherited from FixedArray | |
| static int | SizeFor (int length) |
| static int | OffsetOfElementAt (int index) |
| static FixedArray * | cast (Object *obj) |
Static Public Member Functions inherited from FixedArrayBase | |
| static FixedArrayBase * | cast (Object *object) |
Static Public Member Functions inherited from HeapObject | |
| static HeapObject * | FromAddress (Address address) |
| static Object ** | RawField (HeapObject *obj, int offset) |
| static HeapObject * | cast (Object *obj) |
Static Public Member Functions inherited from Object | |
| static Handle< Object > | GetProperty (Handle< Object > object, Handle< Object > receiver, LookupResult *result, Handle< String > key, PropertyAttributes *attributes) |
| static Handle< Object > | GetElement (Handle< Object > object, uint32_t index) |
| static Object * | cast (Object *value) |
Protected Member Functions | |
| MUST_USE_RESULT MaybeObject * | AtPut (Key key, Object *value) |
| MUST_USE_RESULT MaybeObject * | AddEntry (Key key, Object *value, PropertyDetails details, uint32_t hash) |
| MUST_USE_RESULT MaybeObject * | GenerateNewEnumerationIndices () |
Protected Member Functions inherited from HashTable< Shape, Key > | |
| uint32_t | FindInsertionEntry (uint32_t hash) |
| void | SetNumberOfElements (int nof) |
| void | SetNumberOfDeletedElements (int nod) |
| void | SetCapacity (int capacity) |
| MUST_USE_RESULT MaybeObject * | Rehash (HashTable *new_table, Key key) |
| MUST_USE_RESULT MaybeObject * | Shrink (Key key) |
| MUST_USE_RESULT MaybeObject * | EnsureCapacity (int n, Key key) |
Protected Member Functions inherited from HeapObject | |
| void | IteratePointers (ObjectVisitor *v, int start, int end) |
| void | IteratePointer (ObjectVisitor *v, int offset) |
Static Protected Attributes | |
| static const int | kMaxNumberKeyIndex |
| static const int | kNextEnumerationIndexIndex = kMaxNumberKeyIndex + 1 |
Additional Inherited Members | |
Static Public Attributes inherited from HashTable< Shape, Key > | |
| static const int | kNumberOfElementsIndex = 0 |
| static const int | kNumberOfDeletedElementsIndex = 1 |
| static const int | kCapacityIndex = 2 |
| static const int | kPrefixStartIndex = 3 |
| static const int | kElementsStartIndex |
| static const int | kEntrySize = Shape::kEntrySize |
| static const int | kElementsStartOffset |
| static const int | kCapacityOffset |
| static const int | kNotFound = -1 |
| static const int | kMaxCapacity |
Static Public Attributes inherited from FixedArray | |
| static const int | kMaxSize = 128 * MB * kPointerSize |
| static const int | kMaxLength = (kMaxSize - kHeaderSize) / kPointerSize |
Static Public Attributes inherited from FixedArrayBase | |
| static const int | kLengthOffset = HeapObject::kHeaderSize |
| static const int | kHeaderSize = kLengthOffset + kPointerSize |
Static Public Attributes inherited from HeapObject | |
| static const int | kMapOffset = Object::kHeaderSize |
| static const int | kHeaderSize = kMapOffset + kPointerSize |
Static Public Attributes inherited from Object | |
| static const int | kHeaderSize = 0 |
Static Protected Member Functions inherited from HashTable< Shape, Key > | |
| static int | EntryToIndex (int entry) |
| static uint32_t | GetProbe (uint32_t hash, uint32_t number, uint32_t size) |
| static uint32_t | FirstProbe (uint32_t hash, uint32_t size) |
| static uint32_t | NextProbe (uint32_t last, uint32_t number, uint32_t size) |
Static Protected Member Functions inherited from FixedArray | |
| static void | NoWriteBarrierSet (FixedArray *array, int index, Object *value) |
| static void | NoIncrementalWriteBarrierSet (FixedArray *array, int index, Object *value) |
| MaybeObject * Add | ( | Key | key, |
| Object * | value, | ||
| PropertyDetails | details | ||
| ) |
Definition at line 12556 of file objects.cc.
References ASSERT, Dictionary< Shape, Key >::cast(), and SLOW_ASSERT.
Referenced by JSObject::AddSlowProperty(), Heap::AllocateGlobalObject(), GlobalObject::EnsurePropertyCell(), Runtime::InitializeIntrinsicFunctionNames(), JSObject::NormalizeProperties(), and JSObject::SetNormalizedProperty().
|
protected |
Definition at line 12576 of file objects.cc.
References ASSERT, HashTable< Shape, Key >::ElementAdded(), and HashTable< Shape, Key >::FindInsertionEntry().
|
static |
Definition at line 12414 of file objects.cc.
References HashTable< Shape, Key >::Allocate(), and Dictionary< Shape, Key >::cast().
|
protected |
Definition at line 12529 of file objects.cc.
References Dictionary< Shape, Key >::cast(), NONE, and v8::internal::NORMAL.
|
inlinestatic |
Definition at line 3062 of file objects.h.
Referenced by Dictionary< Shape, Key >::Add(), Dictionary< Shape, Key >::Allocate(), and Dictionary< Shape, Key >::AtPut().
| void CopyKeysTo | ( | FixedArray * | storage, |
| PropertyAttributes | filter, | ||
| SortMode | sort_mode | ||
| ) |
Referenced by JSObject::GetLocalElementKeys(), and JSObject::GetLocalPropertyNames().
| void CopyKeysTo | ( | FixedArray * | storage, |
| int | index, | ||
| SortMode | sort_mode | ||
| ) |
| void CopyValuesTo | ( | FixedArray * | elements | ) |
Definition at line 10415 of file objects.cc.
References ASSERT, HashTable< Shape, Key >::Capacity(), HeapObject::GetWriteBarrierMode(), HashTable< Shape, Key >::KeyAt(), FixedArrayBase::length(), and FixedArray::set().
Referenced by JSObject::PrepareElementsForSort().
| Object * DeleteProperty | ( | int | entry, |
| JSObject::DeleteMode | mode | ||
| ) |
Definition at line 12508 of file objects.cc.
References HashTable< Shape, Key >::ElementRemoved(), JSReceiver::FORCE_DELETION, and HeapObject::GetHeap().
Referenced by DictionaryElementsAccessor::DeleteCommon(), and JSObject::DeleteNormalizedProperty().
|
inline |
Definition at line 3077 of file objects.h.
Referenced by JSObject::DeleteNormalizedProperty(), BASE_EMBEDDED< Visitor >::DictionaryResult(), DictionaryElementsAccessor::GetImpl(), JSObject::LocalLookupRealNamedProperty(), JSObject::LookupAccessor(), JSObject::PrepareSlowElementsForSort(), JSObject::ReplaceSlowProperty(), v8::internal::RUNTIME_FUNCTION(), JSObject::SetDictionaryElement(), JSObject::SetElementWithCallbackSetterInPrototypes(), DictionaryElementsAccessor::SetLengthWithoutNormalize(), and JSObject::SetNormalizedProperty().
|
inline |
Definition at line 3084 of file objects.h.
Referenced by JSObject::DeleteNormalizedProperty(), JSObject::SetDictionaryElement(), and JSObject::SetNormalizedProperty().
| MaybeObject * EnsureCapacity | ( | int | n, |
| Key | key | ||
| ) |
Definition at line 12493 of file objects.cc.
References HashTable< Shape, Key >::EnsureCapacity().
|
protected |
Definition at line 12434 of file objects.cc.
References Heap::AllocateFixedArray(), HashTable< Shape, Key >::Capacity(), Smi::cast(), FixedArray::cast(), Smi::FromInt(), FixedArray::get(), HeapObject::GetHeap(), FixedArrayBase::length(), HashTable< Shape, Key >::NumberOfElements(), FixedArray::set(), and FixedArray::SortPairs().
|
inline |
Definition at line 3118 of file objects.h.
Referenced by JSObject::AddSlowProperty(), and JSObject::SetNormalizedProperty().
| int NumberOfElementsFilterAttributes | ( | PropertyAttributes | filter | ) |
Definition at line 12704 of file objects.cc.
References HashTable< Shape, Key >::Capacity(), and HashTable< Shape, Key >::KeyAt().
Referenced by JSObject::GetLocalElementKeys(), and JSObject::NumberOfLocalProperties().
| int NumberOfEnumElements | ( | ) |
Definition at line 12722 of file objects.cc.
References DONT_ENUM.
Definition at line 5143 of file objects-inl.h.
References Smi::FromInt().
Referenced by JSObject::AddSlowProperty(), DictionaryElementsAccessor::SetLengthWithoutNormalize(), and JSObject::SetNormalizedProperty().
Definition at line 5151 of file objects-inl.h.
References ASSERT, HashTable< Shape, Key >::EntryToIndex(), HeapObject::GetWriteBarrierMode(), and FixedArray::set().
|
inline |
Definition at line 3113 of file objects.h.
Referenced by JSObject::AddSlowProperty(), JSObject::NormalizeProperties(), and JSObject::SetNormalizedProperty().
| MaybeObject * Shrink | ( | Key | key | ) |
Definition at line 12523 of file objects.cc.
References HashTable< Shape, Key >::Shrink().
Referenced by DictionaryElementsAccessor::DeleteCommon(), and JSObject::DeleteNormalizedProperty().
Definition at line 12819 of file objects.cc.
References HashTable< Shape, Key >::Capacity(), JSGlobalPropertyCell::cast(), HeapObject::GetHeap(), and HashTable< Shape, Key >::KeyAt().
Referenced by JSObject::SlowReverseLookup().
|
inline |
Definition at line 3067 of file objects.h.
Referenced by JSObject::AddSlowProperty(), JSObject::DeleteNormalizedProperty(), GlobalObject::EnsurePropertyCell(), StubCache::FindCallInitialize(), DictionaryElementsAccessor::GetImpl(), JSObject::GetNormalizedProperty(), GlobalObject::GetPropertyCell(), JSObject::LocalLookupRealNamedProperty(), JSObject::LookupAccessor(), JSObject::PrepareSlowElementsForSort(), v8::internal::RUNTIME_FUNCTION(), JSObject::SetDictionaryElement(), JSObject::SetElementWithCallbackSetterInPrototypes(), and JSObject::ShouldConvertToFastDoubleElements().
|
inline |
Definition at line 3072 of file objects.h.
Referenced by JSObject::SetDictionaryElement(), and JSObject::SetNormalizedProperty().
|
staticprotected |
|
staticprotected |