2012-02-09 16:04:43 +00:00
|
|
|
/****************************************************************************
|
|
|
|
**
|
2016-01-19 11:23:05 +00:00
|
|
|
** Copyright (C) 2016 The Qt Company Ltd.
|
|
|
|
** Contact: https://www.qt.io/licensing/
|
2012-02-09 16:04:43 +00:00
|
|
|
**
|
2012-02-16 04:43:03 +00:00
|
|
|
** This file is part of the QtQml module of the Qt Toolkit.
|
2012-02-09 16:04:43 +00:00
|
|
|
**
|
2016-01-19 11:23:05 +00:00
|
|
|
** $QT_BEGIN_LICENSE:GPL-EXCEPT$
|
2012-09-20 05:21:40 +00:00
|
|
|
** Commercial License Usage
|
|
|
|
** Licensees holding valid commercial Qt licenses may use this file in
|
|
|
|
** accordance with the commercial license agreement provided with the
|
|
|
|
** Software or, alternatively, in accordance with the terms contained in
|
2015-01-28 11:55:39 +00:00
|
|
|
** a written agreement between you and The Qt Company. For licensing terms
|
2016-01-19 11:23:05 +00:00
|
|
|
** and conditions see https://www.qt.io/terms-conditions. For further
|
|
|
|
** information use the contact form at https://www.qt.io/contact-us.
|
2012-09-20 05:21:40 +00:00
|
|
|
**
|
2016-01-19 11:23:05 +00:00
|
|
|
** GNU General Public License Usage
|
|
|
|
** Alternatively, this file may be used under the terms of the GNU
|
|
|
|
** General Public License version 3 as published by the Free Software
|
|
|
|
** Foundation with exceptions as appearing in the file LICENSE.GPL3-EXCEPT
|
|
|
|
** included in the packaging of this file. Please review the following
|
|
|
|
** information to ensure the GNU General Public License requirements will
|
|
|
|
** be met: https://www.gnu.org/licenses/gpl-3.0.html.
|
2012-02-09 16:04:43 +00:00
|
|
|
**
|
|
|
|
** $QT_END_LICENSE$
|
|
|
|
**
|
|
|
|
****************************************************************************/
|
|
|
|
|
2012-03-08 15:50:14 +00:00
|
|
|
#include "qmlprofilerclient.h"
|
2015-09-17 11:39:00 +00:00
|
|
|
#include "qmlprofilerdata.h"
|
|
|
|
|
|
|
|
#include <private/qqmlprofilerclient_p_p.h>
|
2012-02-09 16:04:43 +00:00
|
|
|
|
|
|
|
#include <QtCore/QStack>
|
|
|
|
#include <QtCore/QStringList>
|
|
|
|
|
2015-07-28 13:58:07 +00:00
|
|
|
#include <limits>
|
|
|
|
|
2015-09-17 11:39:00 +00:00
|
|
|
class QmlProfilerClientPrivate : public QQmlProfilerClientPrivate
|
2012-02-09 16:04:43 +00:00
|
|
|
{
|
2015-09-17 11:39:00 +00:00
|
|
|
Q_DECLARE_PUBLIC(QmlProfilerClient)
|
2012-02-09 16:04:43 +00:00
|
|
|
public:
|
2015-09-17 11:39:00 +00:00
|
|
|
QmlProfilerClientPrivate(QQmlDebugConnection *connection, QmlProfilerData *data);
|
|
|
|
|
|
|
|
QmlProfilerData *data;
|
2012-02-09 16:04:43 +00:00
|
|
|
|
|
|
|
qint64 inProgressRanges;
|
2015-07-08 14:03:51 +00:00
|
|
|
QStack<qint64> rangeStartTimes[QQmlProfilerDefinitions::MaximumRangeType];
|
|
|
|
QStack<QStringList> rangeDatas[QQmlProfilerDefinitions::MaximumRangeType];
|
2015-09-17 11:39:00 +00:00
|
|
|
QStack<QQmlEventLocation> rangeLocations[QQmlProfilerDefinitions::MaximumRangeType];
|
2015-07-08 14:03:51 +00:00
|
|
|
int rangeCount[QQmlProfilerDefinitions::MaximumRangeType];
|
2015-05-21 08:35:42 +00:00
|
|
|
|
2015-09-15 13:14:40 +00:00
|
|
|
bool enabled;
|
2012-02-09 16:04:43 +00:00
|
|
|
};
|
|
|
|
|
2015-09-17 11:39:00 +00:00
|
|
|
QmlProfilerClientPrivate::QmlProfilerClientPrivate(QQmlDebugConnection *connection,
|
|
|
|
QmlProfilerData *data) :
|
|
|
|
QQmlProfilerClientPrivate(connection), data(data), inProgressRanges(0), enabled(false)
|
2012-02-09 16:04:43 +00:00
|
|
|
{
|
2015-09-17 11:39:00 +00:00
|
|
|
::memset(rangeCount, 0, QQmlProfilerDefinitions::MaximumRangeType * sizeof(int));
|
2012-02-09 16:04:43 +00:00
|
|
|
}
|
|
|
|
|
2015-09-17 11:39:00 +00:00
|
|
|
QmlProfilerClient::QmlProfilerClient(QQmlDebugConnection *connection, QmlProfilerData *data) :
|
|
|
|
QQmlProfilerClient(*(new QmlProfilerClientPrivate(connection, data)))
|
2012-02-09 16:04:43 +00:00
|
|
|
{
|
|
|
|
}
|
|
|
|
|
2015-09-17 11:39:00 +00:00
|
|
|
void QmlProfilerClient::clearPendingData()
|
2012-02-09 16:04:43 +00:00
|
|
|
{
|
2015-09-17 11:39:00 +00:00
|
|
|
Q_D(QmlProfilerClient);
|
2015-09-15 13:14:40 +00:00
|
|
|
for (int i = 0; i < QQmlProfilerDefinitions::MaximumRangeType; ++i) {
|
|
|
|
d->rangeCount[i] = 0;
|
|
|
|
d->rangeDatas[i].clear();
|
|
|
|
d->rangeLocations[i].clear();
|
|
|
|
}
|
2012-02-09 16:04:43 +00:00
|
|
|
}
|
|
|
|
|
2015-09-15 13:14:40 +00:00
|
|
|
void QmlProfilerClient::stateChanged(State state)
|
|
|
|
{
|
2015-09-17 11:39:00 +00:00
|
|
|
Q_D(QmlProfilerClient);
|
2015-09-15 13:14:40 +00:00
|
|
|
if ((d->enabled && state != Enabled) || (!d->enabled && state == Enabled)) {
|
|
|
|
d->enabled = (state == Enabled);
|
|
|
|
emit enabledChanged(d->enabled);
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2015-09-17 11:39:00 +00:00
|
|
|
void QmlProfilerClient::traceStarted(qint64 time, int engineId)
|
2012-02-09 16:04:43 +00:00
|
|
|
{
|
2015-09-17 11:39:00 +00:00
|
|
|
Q_UNUSED(engineId);
|
|
|
|
Q_D(QmlProfilerClient);
|
|
|
|
d->data->setTraceStartTime(time);
|
|
|
|
emit recordingStarted();
|
|
|
|
}
|
2015-09-17 11:34:38 +00:00
|
|
|
|
2015-09-17 11:39:00 +00:00
|
|
|
void QmlProfilerClient::traceFinished(qint64 time, int engineId)
|
|
|
|
{
|
|
|
|
Q_UNUSED(engineId);
|
|
|
|
Q_D(QmlProfilerClient);
|
|
|
|
d->data->setTraceEndTime(time);
|
|
|
|
}
|
2015-09-17 11:34:38 +00:00
|
|
|
|
2015-09-17 11:39:00 +00:00
|
|
|
void QmlProfilerClient::rangeStart(QQmlProfilerDefinitions::RangeType type, qint64 startTime)
|
|
|
|
{
|
|
|
|
Q_D(QmlProfilerClient);
|
|
|
|
d->rangeStartTimes[type].push(startTime);
|
|
|
|
d->inProgressRanges |= (static_cast<qint64>(1) << type);
|
|
|
|
++d->rangeCount[type];
|
|
|
|
}
|
2015-09-17 11:34:38 +00:00
|
|
|
|
2015-09-17 11:39:00 +00:00
|
|
|
void QmlProfilerClient::rangeData(QQmlProfilerDefinitions::RangeType type, qint64 time,
|
|
|
|
const QString &data)
|
|
|
|
{
|
|
|
|
Q_UNUSED(time);
|
|
|
|
Q_D(QmlProfilerClient);
|
|
|
|
int count = d->rangeCount[type];
|
|
|
|
if (count > 0) {
|
|
|
|
while (d->rangeDatas[type].count() < count)
|
|
|
|
d->rangeDatas[type].push(QStringList());
|
|
|
|
d->rangeDatas[type][count - 1] << data;
|
|
|
|
}
|
|
|
|
}
|
2014-02-19 17:11:41 +00:00
|
|
|
|
2015-09-17 11:39:00 +00:00
|
|
|
void QmlProfilerClient::rangeLocation(QQmlProfilerDefinitions::RangeType type, qint64 time,
|
|
|
|
const QQmlEventLocation &location)
|
|
|
|
{
|
|
|
|
Q_UNUSED(time);
|
|
|
|
Q_D(QmlProfilerClient);
|
|
|
|
if (d->rangeCount[type] > 0)
|
|
|
|
d->rangeLocations[type].push(location);
|
|
|
|
}
|
2012-02-09 16:04:43 +00:00
|
|
|
|
2015-09-17 11:39:00 +00:00
|
|
|
void QmlProfilerClient::rangeEnd(QQmlProfilerDefinitions::RangeType type, qint64 endTime)
|
|
|
|
{
|
|
|
|
Q_D(QmlProfilerClient);
|
2012-02-09 16:04:43 +00:00
|
|
|
|
2015-09-17 11:39:00 +00:00
|
|
|
if (d->rangeCount[type] == 0) {
|
|
|
|
emit error(tr("Spurious range end detected."));
|
|
|
|
return;
|
|
|
|
}
|
2015-05-21 08:35:42 +00:00
|
|
|
|
2015-09-17 11:39:00 +00:00
|
|
|
--d->rangeCount[type];
|
|
|
|
if (d->inProgressRanges & (static_cast<qint64>(1) << type))
|
|
|
|
d->inProgressRanges &= ~(static_cast<qint64>(1) << type);
|
|
|
|
QStringList data = d->rangeDatas[type].count() ? d->rangeDatas[type].pop() : QStringList();
|
|
|
|
QQmlEventLocation location = d->rangeLocations[type].count() ? d->rangeLocations[type].pop() :
|
|
|
|
QQmlEventLocation();
|
|
|
|
qint64 startTime = d->rangeStartTimes[type].pop();
|
|
|
|
|
|
|
|
if (d->rangeCount[type] == 0 && d->rangeDatas[type].count() + d->rangeStartTimes[type].count()
|
|
|
|
+ d->rangeLocations[type].count() != 0) {
|
|
|
|
emit error(tr("Incorrectly nested range data"));
|
|
|
|
return;
|
|
|
|
}
|
2012-05-02 15:32:57 +00:00
|
|
|
|
2015-09-17 11:39:00 +00:00
|
|
|
d->data->addQmlEvent(type, QQmlProfilerDefinitions::QmlBinding, startTime, endTime - startTime,
|
|
|
|
data, location);
|
|
|
|
}
|
2012-02-09 16:04:43 +00:00
|
|
|
|
2015-09-17 11:39:00 +00:00
|
|
|
void QmlProfilerClient::animationFrame(qint64 time, int frameRate, int animationCount, int threadId)
|
|
|
|
{
|
|
|
|
Q_D(QmlProfilerClient);
|
|
|
|
d->data->addFrameEvent(time, frameRate, animationCount, threadId);
|
|
|
|
}
|
2012-02-09 16:04:43 +00:00
|
|
|
|
2015-09-17 11:39:00 +00:00
|
|
|
void QmlProfilerClient::sceneGraphEvent(QQmlProfilerDefinitions::SceneGraphFrameType type,
|
|
|
|
qint64 time, qint64 numericData1, qint64 numericData2,
|
|
|
|
qint64 numericData3, qint64 numericData4,
|
|
|
|
qint64 numericData5)
|
|
|
|
{
|
|
|
|
Q_D(QmlProfilerClient);
|
|
|
|
d->data->addSceneGraphFrameEvent(type, time, numericData1, numericData2, numericData3,
|
|
|
|
numericData4, numericData5);
|
|
|
|
}
|
2012-02-09 16:04:43 +00:00
|
|
|
|
2015-09-17 11:39:00 +00:00
|
|
|
void QmlProfilerClient::pixmapCacheEvent(QQmlProfilerDefinitions::PixmapEventType type, qint64 time,
|
|
|
|
const QString &url, int numericData1, int numericData2)
|
|
|
|
{
|
|
|
|
Q_D(QmlProfilerClient);
|
|
|
|
d->data->addPixmapCacheEvent(type, time, url, numericData1, numericData2);
|
|
|
|
}
|
2012-02-09 16:04:43 +00:00
|
|
|
|
2015-09-17 11:39:00 +00:00
|
|
|
void QmlProfilerClient::memoryAllocation(QQmlProfilerDefinitions::MemoryType type, qint64 time,
|
|
|
|
qint64 amount)
|
|
|
|
{
|
|
|
|
Q_D(QmlProfilerClient);
|
|
|
|
d->data->addMemoryEvent(type, time, amount);
|
|
|
|
}
|
2012-02-09 16:04:43 +00:00
|
|
|
|
2015-09-17 11:39:00 +00:00
|
|
|
void QmlProfilerClient::inputEvent(QQmlProfilerDefinitions::InputEventType type, qint64 time,
|
|
|
|
int a, int b)
|
|
|
|
{
|
|
|
|
Q_D(QmlProfilerClient);
|
|
|
|
d->data->addInputEvent(type, time, a, b);
|
|
|
|
}
|
2012-02-09 16:04:43 +00:00
|
|
|
|
2015-09-17 11:39:00 +00:00
|
|
|
void QmlProfilerClient::complete()
|
|
|
|
{
|
|
|
|
Q_D(QmlProfilerClient);
|
|
|
|
d->data->complete();
|
2012-02-09 16:04:43 +00:00
|
|
|
}
|
2017-04-25 21:08:46 +00:00
|
|
|
|
|
|
|
#include "moc_qmlprofilerclient.cpp"
|