summaryrefslogtreecommitdiff
path: root/Source/JavaScriptCore/runtime/ClassInfo.h
diff options
context:
space:
mode:
Diffstat (limited to 'Source/JavaScriptCore/runtime/ClassInfo.h')
-rw-r--r--Source/JavaScriptCore/runtime/ClassInfo.h45
1 files changed, 20 insertions, 25 deletions
diff --git a/Source/JavaScriptCore/runtime/ClassInfo.h b/Source/JavaScriptCore/runtime/ClassInfo.h
index 8ff75f4eb..84fc11a3c 100644
--- a/Source/JavaScriptCore/runtime/ClassInfo.h
+++ b/Source/JavaScriptCore/runtime/ClassInfo.h
@@ -30,7 +30,6 @@
namespace JSC {
-class HashEntry;
class JSArrayBufferView;
struct HashTable;
@@ -83,6 +82,12 @@ struct MethodTable {
typedef void (*GetPropertyNamesFunctionPtr)(JSObject*, ExecState*, PropertyNameArray&, EnumerationMode);
GetPropertyNamesFunctionPtr getPropertyNames;
+ typedef uint32_t (*GetEnumerableLengthFunctionPtr)(ExecState*, JSObject*);
+ GetEnumerableLengthFunctionPtr getEnumerableLength;
+
+ GetPropertyNamesFunctionPtr getStructurePropertyNames;
+ GetPropertyNamesFunctionPtr getGenericPropertyNames;
+
typedef String (*ClassNameFunctionPtr)(const JSObject*);
ClassNameFunctionPtr className;
@@ -97,6 +102,12 @@ struct MethodTable {
typedef PassRefPtr<ArrayBufferView> (*GetTypedArrayImpl)(JSArrayBufferView*);
GetTypedArrayImpl getTypedArrayImpl;
+
+ typedef void (*DumpToStreamFunctionPtr)(const JSCell*, PrintStream&);
+ DumpToStreamFunctionPtr dumpToStream;
+
+ typedef size_t (*EstimatedSizeFunctionPtr)(JSCell*);
+ EstimatedSizeFunctionPtr estimatedSize;
};
#define CREATE_MEMBER_CHECKER(member) \
@@ -135,11 +146,16 @@ struct MethodTable {
&ClassName::getOwnPropertyNames, \
&ClassName::getOwnNonIndexPropertyNames, \
&ClassName::getPropertyNames, \
+ &ClassName::getEnumerableLength, \
+ &ClassName::getStructurePropertyNames, \
+ &ClassName::getGenericPropertyNames, \
&ClassName::className, \
&ClassName::customHasInstance, \
&ClassName::defineOwnProperty, \
&ClassName::slowDownAndWasteMemory, \
- &ClassName::getTypedArrayImpl \
+ &ClassName::getTypedArrayImpl, \
+ &ClassName::dumpToStream, \
+ &ClassName::estimatedSize \
}, \
ClassName::TypedArrayStorageType
@@ -151,25 +167,6 @@ struct ClassInfo {
// nullptrif there is none.
const ClassInfo* parentClass;
- // Static hash-table of properties.
- // For classes that can be used from multiple threads, it is accessed via a getter function
- // that would typically return a pointer to a thread-specific value.
- const HashTable* propHashTable(ExecState* exec) const
- {
- if (classPropHashTableGetterFunction)
- return &classPropHashTableGetterFunction(exec->vm());
-
- return staticPropHashTable;
- }
-
- const HashTable* propHashTable(VM& vm) const
- {
- if (classPropHashTableGetterFunction)
- return &classPropHashTableGetterFunction(vm);
-
- return staticPropHashTable;
- }
-
bool isSubClassOf(const ClassInfo* other) const
{
for (const ClassInfo* ci = this; ci; ci = ci->parentClass) {
@@ -182,17 +179,15 @@ struct ClassInfo {
bool hasStaticProperties() const
{
for (const ClassInfo* ci = this; ci; ci = ci->parentClass) {
- if (ci->staticPropHashTable || ci->classPropHashTableGetterFunction)
+ if (ci->staticPropHashTable)
return true;
}
return false;
}
- bool hasStaticSetterOrReadonlyProperties(VM&) const;
+ JS_EXPORT_PRIVATE bool hasStaticSetterOrReadonlyProperties() const;
const HashTable* staticPropHashTable;
- typedef const HashTable& (*ClassPropHashTableGetterFunction)(VM&);
- const ClassPropHashTableGetterFunction classPropHashTableGetterFunction;
MethodTable methodTable;