Usefully convert from QtScript object/array to QVariant
authorKent Hansen <kent.hansen@nokia.com>
Thu, 17 Jun 2010 10:27:43 +0000 (12:27 +0200)
committerKent Hansen <kent.hansen@nokia.com>
Thu, 17 Jun 2010 13:01:56 +0000 (15:01 +0200)
commitd8d547b92e02546cb030ac9d4a45fe0d89e0e7f6
treedd95bb2244e0c44d66f1bb0cebd38fc71b5da140
parent458a18284406dedcf0628c651fb3511553dbcb58
Usefully convert from QtScript object/array to QVariant

For arrays, the conversion would crash if the array was cyclic.
Introduce a set that keeps track of which objects are being
converted, and return an empty list when a cycle is detected.

For other types of objects, the object was previously attempted
to be converted to a primitive, which typically meant you would
get the string representation ("[object Object]"), since most
(practically all) objects can be converted to a string -- not
useful at all.

Change the conversion so it converts the object to a QVariantMap
instead. This was already done for slots that took a QVariantMap
as argument, but only one level deep. Make the conversion recursive,
using the same mechanism as for arrays to detect cycles.

This change also means that you get a meaningful
JS object => QVariant => JS object roundtrip.
It also aligns the behavior with the Qt WebKit bridge.

Update the documentation to describe the new behavior.
The 4.7 changelog will also be updated under "important behavioral
changes".

This change exposed an issue with one of the QML autotests: A JS
object was assigned to a QVariant property, which caused it to be
converted to a string (rather than a QVariantMap) -- just shows
that the previous behavior was unintuitive). Later, this variant
property is compared to another object, the intention being to
compare the _properties_ of the two objects; but because the variant
property contained a string, this would cause the other operand
(object) to be converted to a string as well ("[object Object]"),
causing a meaningless test pass.

Change the test to deserialize both objects using JSON.stringify,
and compare the resulting strings, so that actual
JS object => QVariant(Map) => JS object roundtrip is tested (the
intention).

Task-number: QTBUG-3511
Reviewed-by: Olivier Goffart
src/script/api/qscriptengine.cpp
src/script/api/qscriptengine_p.h
src/script/api/qscriptvalue.cpp
tests/auto/declarative/qdeclarativeworkerscript/data/BaseWorker.qml
tests/auto/declarative/qdeclarativeworkerscript/tst_qdeclarativeworkerscript.cpp
tests/auto/qscriptextqobject/tst_qscriptextqobject.cpp
tests/auto/qscriptvalue/tst_qscriptvalue.cpp
tests/auto/qscriptvalue/tst_qscriptvalue.h