diff options
author | Jedrzej Nowacki <jedrzej.nowacki@nokia.com> | 2011-08-02 13:14:26 +0200 |
---|---|---|
committer | Qt by Nokia <qt-info@nokia.com> | 2011-08-03 14:13:00 +0200 |
commit | b9fd1367ab71813e15a7b25733bd9fdb0ca6d7aa (patch) | |
tree | 146af254dc78d6a76ad85429c26d2d031a77d3c5 /src/declarative/qml/v8/qjsvalueiterator_p.h | |
parent | a61f3725d0e92459eb6f1fe7ee4e817c68d25ccf (diff) |
Improve QJSValueIterator implementation.
The old implementation was a hack, it had some memory leak (in case of
deleted engine) and performance problems (for example all names were
copied to separate QList instance instead of reusing v8::Array).
Change-Id: Ic70ad511127a8c05df3c627e4496083004c6452a
Reviewed-on: http://codereview.qt.nokia.com/2512
Reviewed-by: Qt Sanity Bot <qt_sanity_bot@ovi.com>
Reviewed-by: Kent Hansen <kent.hansen@nokia.com>
Diffstat (limited to 'src/declarative/qml/v8/qjsvalueiterator_p.h')
-rw-r--r-- | src/declarative/qml/v8/qjsvalueiterator_p.h | 64 |
1 files changed, 64 insertions, 0 deletions
diff --git a/src/declarative/qml/v8/qjsvalueiterator_p.h b/src/declarative/qml/v8/qjsvalueiterator_p.h new file mode 100644 index 0000000000..d3033d496b --- /dev/null +++ b/src/declarative/qml/v8/qjsvalueiterator_p.h @@ -0,0 +1,64 @@ +/**************************************************************************** +** +** Copyright (C) 2011 Nokia Corporation and/or its subsidiary(-ies). +** All rights reserved. +** Contact: Nokia Corporation (qt-info@nokia.com) +** +** This file is part of the QtDeclarative module of the Qt Toolkit. +** +** $QT_BEGIN_LICENSE:LGPL-ONLY$ +** GNU Lesser General Public License Usage +** This file may be used under the terms of the GNU Lesser +** General Public License version 2.1 as published by the Free Software +** Foundation and appearing in the file LICENSE.LGPL included in the +** packaging of this file. Please review the following information to +** ensure the GNU Lesser General Public License version 2.1 requirements +** will be met: http://www.gnu.org/licenses/old-licenses/lgpl-2.1.html. +** +** If you have questions regarding the use of this file, please contact +** Nokia at qt-info@nokia.com. +** $QT_END_LICENSE$ +** +****************************************************************************/ + +#ifndef QJSVALUEITERATOR_P_H +#define QJSVALUEITERATOR_P_H + +#include <qscripttools_p.h> +#include <qjsvalue_p.h> + +#include <qv8_p.h> + +QT_BEGIN_NAMESPACE + +class QV8Engine; + +class QJSValueIteratorPrivate : public QScriptLinkedNode { +public: + inline QJSValueIteratorPrivate(const QJSValuePrivate* value); + inline ~QJSValueIteratorPrivate(); + + inline bool hasNext() const; + inline bool next(); + + inline QString name() const; + + inline QScriptPassPointer<QJSValuePrivate> value() const; + + inline bool isValid() const; + inline QV8Engine* engine() const; + + inline void invalidate(); +private: + Q_DISABLE_COPY(QJSValueIteratorPrivate) + + QScriptSharedDataPointer<QJSValuePrivate> m_object; + v8::Persistent<v8::Array> m_names; + uint32_t m_index; + uint32_t m_count; +}; + + +QT_END_NAMESPACE + +#endif // QJSVALUEITERATOR_P_H |