diff options
author | Lars Knoll <lars.knoll@theqtcompany.com> | 2014-11-01 21:44:57 +0100 |
---|---|---|
committer | Simon Hausmann <simon.hausmann@digia.com> | 2014-11-07 02:00:05 +0100 |
commit | b340caa0d3ebf7f76c0445b2cdd4032d8e3bf8d5 (patch) | |
tree | e475eae0dc4a6c68ca3ee41132b573fc76d2dc10 /src/qml/jsruntime/qv4lookup.cpp | |
parent | e22fc141c3fc5362f9b906c43a1b7c0dbc1f85a3 (diff) |
Get rid of Members and directly store MemberData::Data pointers
And do the same change for ArrayData.
Change-Id: Ia1ae56bd0ff586c9b987e15af7a53f395a37054a
Reviewed-by: Simon Hausmann <simon.hausmann@digia.com>
Diffstat (limited to 'src/qml/jsruntime/qv4lookup.cpp')
-rw-r--r-- | src/qml/jsruntime/qv4lookup.cpp | 56 |
1 files changed, 28 insertions, 28 deletions
diff --git a/src/qml/jsruntime/qv4lookup.cpp b/src/qml/jsruntime/qv4lookup.cpp index f7ebb62b8d..9d4649b287 100644 --- a/src/qml/jsruntime/qv4lookup.cpp +++ b/src/qml/jsruntime/qv4lookup.cpp @@ -49,7 +49,7 @@ ReturnedValue Lookup::lookup(ValueRef thisObject, Object *obj, PropertyAttribute if (index != UINT_MAX) { level = i; *attrs = obj->internalClass()->propertyData.at(index); - return !attrs->isAccessor() ? obj->memberData()[index].asReturnedValue() : obj->getValue(thisObject, obj->propertyAt(index), *attrs); + return !attrs->isAccessor() ? obj->memberData()->data()[index].asReturnedValue() : obj->getValue(thisObject, obj->propertyAt(index), *attrs); } obj = obj->prototype(); @@ -61,7 +61,7 @@ ReturnedValue Lookup::lookup(ValueRef thisObject, Object *obj, PropertyAttribute index = obj->internalClass()->find(name); if (index != UINT_MAX) { *attrs = obj->internalClass()->propertyData.at(index); - return !attrs->isAccessor() ? obj->memberData()[index].asReturnedValue() : obj->getValue(thisObject, obj->propertyAt(index), *attrs); + return !attrs->isAccessor() ? obj->memberData()->data()[index].asReturnedValue() : obj->getValue(thisObject, obj->propertyAt(index), *attrs); } obj = obj->prototype(); @@ -80,7 +80,7 @@ ReturnedValue Lookup::lookup(Object *obj, PropertyAttributes *attrs) if (index != UINT_MAX) { level = i; *attrs = obj->internalClass()->propertyData.at(index); - return !attrs->isAccessor() ? obj->memberData()[index].asReturnedValue() : thisObject->getValue(obj->propertyAt(index), *attrs); + return !attrs->isAccessor() ? obj->memberData()->data()[index].asReturnedValue() : thisObject->getValue(obj->propertyAt(index), *attrs); } obj = obj->prototype(); @@ -92,7 +92,7 @@ ReturnedValue Lookup::lookup(Object *obj, PropertyAttributes *attrs) index = obj->internalClass()->find(name); if (index != UINT_MAX) { *attrs = obj->internalClass()->propertyData.at(index); - return !attrs->isAccessor() ? obj->memberData()[index].asReturnedValue() : thisObject->getValue(obj->propertyAt(index), *attrs); + return !attrs->isAccessor() ? obj->memberData()->data()[index].asReturnedValue() : thisObject->getValue(obj->propertyAt(index), *attrs); } obj = obj->prototype(); @@ -334,7 +334,7 @@ ReturnedValue Lookup::getter0(Lookup *l, const ValueRef object) // the internal class won't match Object *o = object->objectValue(); if (l->classList[0] == o->internalClass()) - return o->memberData()[l->index].asReturnedValue(); + return o->memberData()->data()[l->index].asReturnedValue(); } return getterTwoClasses(l, object); } @@ -347,7 +347,7 @@ ReturnedValue Lookup::getter1(Lookup *l, const ValueRef object) Object *o = object->objectValue(); if (l->classList[0] == o->internalClass() && l->classList[1] == o->prototype()->internalClass()) - return o->prototype()->memberData()[l->index].asReturnedValue(); + return o->prototype()->memberData()->data()[l->index].asReturnedValue(); } return getterTwoClasses(l, object); } @@ -363,7 +363,7 @@ ReturnedValue Lookup::getter2(Lookup *l, const ValueRef object) if (l->classList[1] == o->internalClass()) { o = o->prototype(); if (l->classList[2] == o->internalClass()) - return o->memberData()[l->index].asReturnedValue(); + return o->memberData()->data()[l->index].asReturnedValue(); } } } @@ -378,9 +378,9 @@ ReturnedValue Lookup::getter0getter0(Lookup *l, const ValueRef object) // the internal class won't match Object *o = object->objectValue(); if (l->classList[0] == o->internalClass()) - return o->memberData()[l->index].asReturnedValue(); + return o->memberData()->data()[l->index].asReturnedValue(); if (l->classList[2] == o->internalClass()) - return o->memberData()[l->index2].asReturnedValue(); + return o->memberData()->data()[l->index2].asReturnedValue(); } l->getter = getterFallback; return getterFallback(l, object); @@ -393,10 +393,10 @@ ReturnedValue Lookup::getter0getter1(Lookup *l, const ValueRef object) // the internal class won't match Object *o = object->objectValue(); if (l->classList[0] == o->internalClass()) - return o->memberData()[l->index].asReturnedValue(); + return o->memberData()->data()[l->index].asReturnedValue(); if (l->classList[2] == o->internalClass() && l->classList[3] == o->prototype()->internalClass()) - return o->prototype()->memberData()[l->index2].asReturnedValue(); + return o->prototype()->memberData()->data()[l->index2].asReturnedValue(); } l->getter = getterFallback; return getterFallback(l, object); @@ -410,10 +410,10 @@ ReturnedValue Lookup::getter1getter1(Lookup *l, const ValueRef object) Object *o = object->objectValue(); if (l->classList[0] == o->internalClass() && l->classList[1] == o->prototype()->internalClass()) - return o->prototype()->memberData()[l->index].asReturnedValue(); + return o->prototype()->memberData()->data()[l->index].asReturnedValue(); if (l->classList[2] == o->internalClass() && l->classList[3] == o->prototype()->internalClass()) - return o->prototype()->memberData()[l->index2].asReturnedValue(); + return o->prototype()->memberData()->data()[l->index2].asReturnedValue(); return getterFallback(l, object); } l->getter = getterFallback; @@ -496,7 +496,7 @@ ReturnedValue Lookup::primitiveGetter0(Lookup *l, const ValueRef object) if (object->type() == l->type) { Object *o = l->proto; if (l->classList[0] == o->internalClass()) - return o->memberData()[l->index].asReturnedValue(); + return o->memberData()->data()[l->index].asReturnedValue(); } l->getter = getterGeneric; return getterGeneric(l, object); @@ -508,7 +508,7 @@ ReturnedValue Lookup::primitiveGetter1(Lookup *l, const ValueRef object) Object *o = l->proto; if (l->classList[0] == o->internalClass() && l->classList[1] == o->prototype()->internalClass()) - return o->prototype()->memberData()[l->index].asReturnedValue(); + return o->prototype()->memberData()->data()[l->index].asReturnedValue(); } l->getter = getterGeneric; return getterGeneric(l, object); @@ -565,7 +565,7 @@ ReturnedValue Lookup::stringLengthGetter(Lookup *l, const ValueRef object) ReturnedValue Lookup::arrayLengthGetter(Lookup *l, const ValueRef object) { if (ArrayObject *a = object->asArrayObject()) - return a->memberData()[ArrayObject::LengthPropertyIndex].asReturnedValue(); + return a->memberData()->data()[ArrayObject::LengthPropertyIndex].asReturnedValue(); l->getter = getterGeneric; return getterGeneric(l, object); @@ -605,7 +605,7 @@ ReturnedValue Lookup::globalGetter0(Lookup *l, ExecutionContext *ctx) { Object *o = ctx->d()->engine->globalObject; if (l->classList[0] == o->internalClass()) - return o->memberData()[l->index].asReturnedValue(); + return o->memberData()->data()[l->index].asReturnedValue(); l->globalGetter = globalGetterGeneric; return globalGetterGeneric(l, ctx); @@ -616,7 +616,7 @@ ReturnedValue Lookup::globalGetter1(Lookup *l, ExecutionContext *ctx) Object *o = ctx->d()->engine->globalObject; if (l->classList[0] == o->internalClass() && l->classList[1] == o->prototype()->internalClass()) - return o->prototype()->memberData()[l->index].asReturnedValue(); + return o->prototype()->memberData()->data()[l->index].asReturnedValue(); l->globalGetter = globalGetterGeneric; return globalGetterGeneric(l, ctx); @@ -630,7 +630,7 @@ ReturnedValue Lookup::globalGetter2(Lookup *l, ExecutionContext *ctx) if (l->classList[1] == o->internalClass()) { o = o->prototype(); if (l->classList[2] == o->internalClass()) { - return o->prototype()->memberData()[l->index].asReturnedValue(); + return o->prototype()->memberData()->data()[l->index].asReturnedValue(); } } } @@ -744,7 +744,7 @@ void Lookup::setter0(Lookup *l, const ValueRef object, const ValueRef value) { Object *o = static_cast<Object *>(object->asManaged()); if (o && o->internalClass() == l->classList[0]) { - o->memberData()[l->index] = *value; + o->memberData()->data()[l->index] = *value; return; } @@ -756,9 +756,9 @@ void Lookup::setterInsert0(Lookup *l, const ValueRef object, const ValueRef valu Object *o = static_cast<Object *>(object->asManaged()); if (o && o->internalClass() == l->classList[0]) { if (!o->prototype()) { - if (l->index >= o->memberData().size()) + if (!o->memberData() || l->index >= o->memberData()->size()) o->ensureMemberIndex(l->index); - o->memberData()[l->index] = *value; + o->memberData()->data()[l->index] = *value; o->setInternalClass(l->classList[3]); return; } @@ -774,9 +774,9 @@ void Lookup::setterInsert1(Lookup *l, const ValueRef object, const ValueRef valu if (o && o->internalClass() == l->classList[0]) { Object *p = o->prototype(); if (p && p->internalClass() == l->classList[1]) { - if (l->index >= o->memberData().size()) + if (!o->memberData() || l->index >= o->memberData()->size()) o->ensureMemberIndex(l->index); - o->memberData()[l->index] = *value; + o->memberData()->data()[l->index] = *value; o->setInternalClass(l->classList[3]); return; } @@ -794,9 +794,9 @@ void Lookup::setterInsert2(Lookup *l, const ValueRef object, const ValueRef valu if (p && p->internalClass() == l->classList[1]) { p = p->prototype(); if (p && p->internalClass() == l->classList[2]) { - if (l->index >= o->memberData().size()) + if (!o->memberData() || l->index >= o->memberData()->size()) o->ensureMemberIndex(l->index); - o->memberData()[l->index] = *value; + o->memberData()->data()[l->index] = *value; o->setInternalClass(l->classList[3]); return; } @@ -812,11 +812,11 @@ void Lookup::setter0setter0(Lookup *l, const ValueRef object, const ValueRef val Object *o = static_cast<Object *>(object->asManaged()); if (o) { if (o->internalClass() == l->classList[0]) { - o->memberData()[l->index] = *value; + o->memberData()->data()[l->index] = *value; return; } if (o->internalClass() == l->classList[1]) { - o->memberData()[l->index2] = *value; + o->memberData()->data()[l->index2] = *value; return; } } |