summaryrefslogtreecommitdiffstats
path: root/tests/benchmarks/declarative/qmltime/qmltime.cpp
diff options
context:
space:
mode:
Diffstat (limited to 'tests/benchmarks/declarative/qmltime/qmltime.cpp')
-rw-r--r--tests/benchmarks/declarative/qmltime/qmltime.cpp40
1 files changed, 37 insertions, 3 deletions
diff --git a/tests/benchmarks/declarative/qmltime/qmltime.cpp b/tests/benchmarks/declarative/qmltime/qmltime.cpp
index f065444..8da0f17 100644
--- a/tests/benchmarks/declarative/qmltime/qmltime.cpp
+++ b/tests/benchmarks/declarative/qmltime/qmltime.cpp
@@ -4,6 +4,8 @@
#include <QApplication>
#include <QTime>
#include <QmlContext>
+#include <QGraphicsScene>
+#include <QGraphicsRectItem>
class Timer : public QObject
{
@@ -20,11 +22,18 @@ public:
void run(uint);
+ bool willParent() const;
+ void setWillParent(bool p);
+
private:
void runTest(QmlContext *, uint);
QmlComponent *m_component;
static Timer *m_timer;
+
+ bool m_willparent;
+ QGraphicsScene m_scene;
+ QGraphicsRectItem m_item;
};
QML_DECLARE_TYPE(Timer);
QML_DEFINE_TYPE(QmlTime, 1, 0, Timer, Timer);
@@ -32,11 +41,13 @@ QML_DEFINE_TYPE(QmlTime, 1, 0, Timer, Timer);
Timer *Timer::m_timer = 0;
Timer::Timer()
-: m_component(0)
+: m_component(0), m_willparent(false)
{
if (m_timer)
qWarning("Timer: Timer already registered");
m_timer = this;
+
+ m_scene.addItem(&m_item);
}
QmlComponent *Timer::component() const
@@ -59,18 +70,33 @@ void Timer::run(uint iterations)
QmlContext context(qmlContext(this));
QObject *o = m_component->create(&context);
+ QGraphicsObject *go = qobject_cast<QGraphicsObject *>(o);
+ if (m_willparent && go)
+ go->setParentItem(&m_item);
delete o;
-
runTest(&context, iterations);
}
+bool Timer::willParent() const
+{
+ return m_willparent;
+}
+
+void Timer::setWillParent(bool p)
+{
+ m_willparent = p;
+}
+
void Timer::runTest(QmlContext *context, uint iterations)
{
QTime t;
t.start();
for (uint ii = 0; ii < iterations; ++ii) {
QObject *o = m_component->create(context);
+ QGraphicsObject *go = qobject_cast<QGraphicsObject *>(o);
+ if (m_willparent && go)
+ go->setParentItem(&m_item);
delete o;
}
@@ -82,7 +108,7 @@ void Timer::runTest(QmlContext *context, uint iterations)
void usage(const char *name)
{
- qWarning("Usage: %s [-iterations <count>] <qml file>", name);
+ qWarning("Usage: %s [-iterations <count>] [-parent] <qml file>", name);
exit(-1);
}
@@ -92,6 +118,7 @@ int main(int argc, char ** argv)
uint iterations = 1024;
QString filename;
+ bool willParent = false;
for (int ii = 1; ii < argc; ++ii) {
QByteArray arg(argv[ii]);
@@ -107,11 +134,16 @@ int main(int argc, char ** argv)
} else {
usage(argv[0]);
}
+ } else if (arg == "-parent") {
+ willParent = true;
} else {
filename = QLatin1String(argv[ii]);
}
}
+ if (filename.isEmpty())
+ usage(argv[0]);
+
QmlEngine engine;
QmlComponent component(&engine, filename);
if (component.isError()) {
@@ -131,6 +163,8 @@ int main(int argc, char ** argv)
return -1;
}
+ timer->setWillParent(willParent);
+
if (!timer->component()) {
qWarning() << "The timer has no component";
return -1;