summaryrefslogtreecommitdiffstats
path: root/src/script
diff options
context:
space:
mode:
authorBenjamin Poulain <benjamin.poulain@nokia.com>2009-08-03 14:12:10 (GMT)
committerBenjamin Poulain <benjamin.poulain@nokia.com>2009-08-03 14:18:09 (GMT)
commite520df1f8678bd59adb341fb586f008a7de17fe8 (patch)
treec8cfbf8e651c1e8aa5f9e0f305757b254e9ab6c4 /src/script
parentecb53d192b4a56cd71c251621bec15a509307b23 (diff)
downloadQt-e520df1f8678bd59adb341fb586f008a7de17fe8.zip
Qt-e520df1f8678bd59adb341fb586f008a7de17fe8.tar.gz
Qt-e520df1f8678bd59adb341fb586f008a7de17fe8.tar.bz2
Complete the implementation of QScriptValueIterator with JSCore
This new implementation of QScriptValueIterator passes all the tests. QScriptValueIterator uses an linked list instead of JSC::PropertyNameArray so the list can be modified by ::remove() and to be able to add internal properties for the strings and arrays. Structure::getPropertyNames() has been modified to not show the property from the prototype. Reviewed-by: Kent Hansen
Diffstat (limited to 'src/script')
-rw-r--r--src/script/api/qscriptvalueiterator.cpp67
1 files changed, 43 insertions, 24 deletions
diff --git a/src/script/api/qscriptvalueiterator.cpp b/src/script/api/qscriptvalueiterator.cpp
index eaa84a4..0092fbd 100644
--- a/src/script/api/qscriptvalueiterator.cpp
+++ b/src/script/api/qscriptvalueiterator.cpp
@@ -47,9 +47,13 @@
#include "qscriptengine.h"
#include "qscriptengine_p.h"
#include "qscriptvalue_p.h"
+#include "qlinkedlist.h"
+
#include "JSObject.h"
#include "PropertyNameArray.h"
+#include "JSArray.h"
+#include "JSFunction.h"
QT_BEGIN_NAMESPACE
@@ -97,27 +101,42 @@ class QScriptValueIteratorPrivate
{
public:
QScriptValueIteratorPrivate()
- : propertyNames(0), it(0), current(0)
+ : initialized(false)
{}
- ~QScriptValueIteratorPrivate()
- {
- delete propertyNames;
- }
void ensureInitialized()
{
- if (propertyNames != 0)
+ if (initialized)
return;
QScriptEnginePrivate *eng_p = QScriptEnginePrivate::get(object.engine());
JSC::ExecState *exec = eng_p->globalExec();
- propertyNames = new JSC::PropertyNameArray(exec);
- JSC::asObject(QScriptValuePrivate::get(object)->jscValue)->getPropertyNames(exec, *propertyNames, true);
- it = propertyNames->begin();
+ JSC::PropertyNameArray propertyNamesArray(exec);
+ propertyNamesArray.setShouldCache(false);
+ JSC::asObject(QScriptValuePrivate::get(object)->jscValue)->getPropertyNames(exec, propertyNamesArray, JSC::Structure::NonEnumerable);
+
+ JSC::PropertyNameArray::const_iterator propertyNamesIt = propertyNamesArray.begin();
+ for(; propertyNamesIt != propertyNamesArray.end(); ++propertyNamesIt) {
+ propertyNames.append(propertyNamesIt->ustring());
+ }
+ if (object.isArray() || (QScriptValuePrivate::get(object)->jscValue.isObject(&JSC::JSArray::info))) {
+ const JSC::JSArray *array = JSC::asArray(QScriptValuePrivate::get(object)->jscValue);
+ const int length = array->length();
+ for (int i = 0; i < length; ++i)
+ propertyNames.append(JSC::UString::from(i));
+ } else if (object.isString() || (QScriptValuePrivate::get(object)->jscValue.isObject(&JSC::StringObject::info))) {
+ const JSC::UString string = QScriptValuePrivate::get(object)->jscValue.toString(exec);
+ const int length = string.size();
+ for (int i = 0; i < length; ++i)
+ propertyNames.append(JSC::UString::from(i));
+ }
+ it = propertyNames.begin();
+ initialized = true;
}
QScriptValue object;
- JSC::PropertyNameArray *propertyNames;
- JSC::PropertyNameArray::const_iterator it;
- const JSC::Identifier *current;
+ QLinkedList<JSC::UString> propertyNames;
+ QLinkedList<JSC::UString>::iterator it;
+ QLinkedList<JSC::UString>::iterator current;
+ bool initialized;
};
/*!
@@ -160,7 +179,7 @@ bool QScriptValueIterator::hasNext() const
return false;
const_cast<QScriptValueIteratorPrivate*>(d)->ensureInitialized();
- return d->it != d->propertyNames->end();
+ return d->it != d->propertyNames.end();
}
/*!
@@ -196,7 +215,7 @@ bool QScriptValueIterator::hasPrevious() const
return false;
const_cast<QScriptValueIteratorPrivate*>(d)->ensureInitialized();
- return d->it != d->propertyNames->begin();
+ return d->it != d->propertyNames.begin();
}
/*!
@@ -229,7 +248,7 @@ void QScriptValueIterator::toFront()
if (!d)
return;
d->ensureInitialized();
- d->it = d->propertyNames->begin();
+ d->it = d->propertyNames.begin();
}
/*!
@@ -244,7 +263,7 @@ void QScriptValueIterator::toBack()
if (!d)
return;
d->ensureInitialized();
- d->it = d->propertyNames->end();
+ d->it = d->propertyNames.end();
}
/*!
@@ -256,9 +275,9 @@ void QScriptValueIterator::toBack()
QString QScriptValueIterator::name() const
{
Q_D(const QScriptValueIterator);
- if (!d || !d->it)
+ if (!d || !d->initialized)
return QString();
- return QScript::qtStringFromJSCUString(d->current->ustring());
+ return QScript::qtStringFromJSCUString(*d->current);
}
/*!
@@ -270,7 +289,7 @@ QString QScriptValueIterator::name() const
QScriptString QScriptValueIterator::scriptName() const
{
Q_D(const QScriptValueIterator);
- if (!d || !d->it)
+ if (!d || !d->initialized)
return QScriptString();
return d->object.engine()->toStringHandle(name());
}
@@ -284,7 +303,7 @@ QScriptString QScriptValueIterator::scriptName() const
QScriptValue QScriptValueIterator::value() const
{
Q_D(const QScriptValueIterator);
- if (!d || !d->it)
+ if (!d || !d->initialized)
return QScriptValue();
return d->object.property(name());
}
@@ -298,7 +317,7 @@ QScriptValue QScriptValueIterator::value() const
void QScriptValueIterator::setValue(const QScriptValue &value)
{
Q_D(QScriptValueIterator);
- if (!d || !d->it)
+ if (!d || !d->initialized)
return;
d->object.setProperty(name(), value);
}
@@ -312,7 +331,7 @@ void QScriptValueIterator::setValue(const QScriptValue &value)
QScriptValue::PropertyFlags QScriptValueIterator::flags() const
{
Q_D(const QScriptValueIterator);
- if (!d || !d->it)
+ if (!d || !d->initialized)
return 0;
return d->object.propertyFlags(name());
}
@@ -326,10 +345,10 @@ QScriptValue::PropertyFlags QScriptValueIterator::flags() const
void QScriptValueIterator::remove()
{
Q_D(QScriptValueIterator);
- if (!d || !d->it)
+ if (!d || !d->initialized)
return;
d->object.setProperty(name(), QScriptValue());
- d->current = 0;
+ d->propertyNames.erase(d->current);
}
/*!