diff options
author | Lars Knoll <lars.knoll@digia.com> | 2013-09-25 15:24:50 +0200 |
---|---|---|
committer | The Qt Project <gerrit-noreply@qt-project.org> | 2013-09-28 13:33:39 +0200 |
commit | 150731fc68bcf823bec40729285813d902990cb7 (patch) | |
tree | 7af619f4bc8fac030bc162ce6ead2e2a7be86783 /src/qml/qml/qqmllistwrapper.cpp | |
parent | c79cc3f30d395c94d4f14b978903d7db4ad871dc (diff) |
Remove more direct QV4::Value usage
Remove Value::fromString(String *), and make
Encode safe against encoding raw Managed * pointers.
Change-Id: Ibca4668e1cbeaf85c78169d14386281659d33ef6
Reviewed-by: Simon Hausmann <simon.hausmann@digia.com>
Diffstat (limited to 'src/qml/qml/qqmllistwrapper.cpp')
-rw-r--r-- | src/qml/qml/qqmllistwrapper.cpp | 10 |
1 files changed, 6 insertions, 4 deletions
diff --git a/src/qml/qml/qqmllistwrapper.cpp b/src/qml/qml/qqmllistwrapper.cpp index 5f4e92fa4e..3746d58d77 100644 --- a/src/qml/qml/qqmllistwrapper.cpp +++ b/src/qml/qml/qqmllistwrapper.cpp @@ -69,24 +69,26 @@ ReturnedValue QmlListWrapper::create(QV8Engine *v8, QObject *object, int propId, return Encode::null(); ExecutionEngine *v4 = QV8Engine::getV4(v8); + Scope scope(v4); - QmlListWrapper *r = new (v4->memoryManager) QmlListWrapper(v8); + Scoped<QmlListWrapper> r(scope, new (v4->memoryManager) QmlListWrapper(v8)); r->object = object; r->propertyType = propType; void *args[] = { &r->property, 0 }; QMetaObject::metacall(object, QMetaObject::ReadProperty, propId, args); - return Value::fromObject(r).asReturnedValue(); + return r.asReturnedValue(); } ReturnedValue QmlListWrapper::create(QV8Engine *v8, const QQmlListProperty<QObject> &prop, int propType) { ExecutionEngine *v4 = QV8Engine::getV4(v8); + Scope scope(v4); - QmlListWrapper *r = new (v4->memoryManager) QmlListWrapper(v8); + Scoped<QmlListWrapper> r(scope, new (v4->memoryManager) QmlListWrapper(v8)); r->object = prop.object; r->property = prop; r->propertyType = propType; - return Value::fromObject(r).asReturnedValue(); + return r.asReturnedValue(); } QVariant QmlListWrapper::toVariant() const |