| 
									
										
										
										
											2012-10-02 09:12:39 +02:00
										 |  |  | /****************************************************************************
 | 
					
						
							| 
									
										
										
										
											2012-02-24 10:47:17 +01:00
										 |  |  | ** | 
					
						
							| 
									
										
										
										
											2014-01-07 13:27:11 +01:00
										 |  |  | ** Copyright (C) 2014 Digia Plc and/or its subsidiary(-ies). | 
					
						
							| 
									
										
										
										
											2012-10-02 09:12:39 +02:00
										 |  |  | ** Contact: http://www.qt-project.org/legal
 | 
					
						
							| 
									
										
										
										
											2012-02-24 10:47:17 +01:00
										 |  |  | ** | 
					
						
							| 
									
										
										
										
											2012-10-02 09:12:39 +02:00
										 |  |  | ** This file is part of Qt Creator. | 
					
						
							| 
									
										
										
										
											2012-02-24 10:47:17 +01:00
										 |  |  | ** | 
					
						
							| 
									
										
										
										
											2012-10-02 09:12:39 +02: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 | 
					
						
							|  |  |  | ** a written agreement between you and Digia.  For licensing terms and | 
					
						
							|  |  |  | ** conditions see http://qt.digia.com/licensing.  For further information
 | 
					
						
							|  |  |  | ** use the contact form at http://qt.digia.com/contact-us.
 | 
					
						
							| 
									
										
										
										
											2012-02-24 10:47:17 +01:00
										 |  |  | ** | 
					
						
							|  |  |  | ** GNU Lesser General Public License Usage | 
					
						
							| 
									
										
										
										
											2012-10-02 09:12:39 +02:00
										 |  |  | ** Alternatively, 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.
 | 
					
						
							|  |  |  | ** | 
					
						
							|  |  |  | ** In addition, as a special exception, Digia gives you certain additional | 
					
						
							|  |  |  | ** rights.  These rights are described in the Digia Qt LGPL Exception | 
					
						
							| 
									
										
										
										
											2012-02-24 10:47:17 +01:00
										 |  |  | ** version 1.1, included in the file LGPL_EXCEPTION.txt in this package. | 
					
						
							|  |  |  | ** | 
					
						
							| 
									
										
										
										
											2012-10-02 09:12:39 +02:00
										 |  |  | ****************************************************************************/ | 
					
						
							| 
									
										
										
										
											2012-02-24 10:47:17 +01:00
										 |  |  | 
 | 
					
						
							|  |  |  | #include "qmlprofilerclientmanager.h"
 | 
					
						
							|  |  |  | #include "qmlprofilertool.h"
 | 
					
						
							|  |  |  | #include "qmlprofilerplugin.h"
 | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2012-04-18 12:06:10 +02:00
										 |  |  | #include <qmldebug/qmldebugclient.h>
 | 
					
						
							|  |  |  | #include <qmldebug/qmlprofilertraceclient.h>
 | 
					
						
							|  |  |  | #include <qmldebug/qv8profilerclient.h>
 | 
					
						
							| 
									
										
										
										
											2012-02-24 10:47:17 +01:00
										 |  |  | 
 | 
					
						
							|  |  |  | #include <utils/qtcassert.h>
 | 
					
						
							| 
									
										
										
										
											2012-09-24 13:48:18 +02:00
										 |  |  | #include <QPointer>
 | 
					
						
							| 
									
										
										
										
											2012-02-24 10:47:17 +01:00
										 |  |  | #include <QTimer>
 | 
					
						
							|  |  |  | #include <QMessageBox>
 | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2013-08-08 13:28:08 +02:00
										 |  |  | #include "qmlprofilermodelmanager.h"
 | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2012-04-18 12:06:10 +02:00
										 |  |  | using namespace QmlDebug; | 
					
						
							| 
									
										
										
										
											2012-02-24 10:47:17 +01:00
										 |  |  | using namespace Core; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | namespace QmlProfiler { | 
					
						
							|  |  |  | namespace Internal { | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2013-08-29 19:04:29 +02:00
										 |  |  | class QmlProfilerClientManager::QmlProfilerClientManagerPrivate | 
					
						
							|  |  |  | { | 
					
						
							| 
									
										
										
										
											2012-02-24 10:47:17 +01:00
										 |  |  | public: | 
					
						
							| 
									
										
										
										
											2013-08-29 19:04:29 +02:00
										 |  |  |     QmlProfilerStateManager *profilerState; | 
					
						
							| 
									
										
										
										
											2012-02-24 10:47:17 +01:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2012-04-18 12:06:10 +02:00
										 |  |  |     QmlDebugConnection *connection; | 
					
						
							| 
									
										
										
										
											2012-09-24 13:48:18 +02:00
										 |  |  |     QPointer<QmlProfilerTraceClient> qmlclientplugin; | 
					
						
							|  |  |  |     QPointer<QV8ProfilerClient> v8clientplugin; | 
					
						
							| 
									
										
										
										
											2012-02-24 10:47:17 +01:00
										 |  |  | 
 | 
					
						
							|  |  |  |     QTimer connectionTimer; | 
					
						
							|  |  |  |     int connectionAttempts; | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2013-08-08 13:28:08 +02:00
										 |  |  |     enum ConnectMode { | 
					
						
							|  |  |  |         TcpConnection, OstConnection | 
					
						
							|  |  |  |     }; | 
					
						
							| 
									
										
										
										
											2012-02-24 10:47:17 +01:00
										 |  |  |     ConnectMode connectMode; | 
					
						
							|  |  |  |     QString tcpHost; | 
					
						
							|  |  |  |     quint64 tcpPort; | 
					
						
							|  |  |  |     QString ostDevice; | 
					
						
							|  |  |  |     QString sysroot; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     bool v8DataReady; | 
					
						
							|  |  |  |     bool qmlDataReady; | 
					
						
							| 
									
										
										
										
											2013-08-08 13:28:08 +02:00
										 |  |  | 
 | 
					
						
							|  |  |  |     QmlProfilerModelManager *modelManager; | 
					
						
							| 
									
										
										
										
											2012-02-24 10:47:17 +01:00
										 |  |  | }; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | QmlProfilerClientManager::QmlProfilerClientManager(QObject *parent) : | 
					
						
							| 
									
										
										
										
											2013-08-29 19:04:29 +02:00
										 |  |  |     QObject(parent), d(new QmlProfilerClientManagerPrivate) | 
					
						
							| 
									
										
										
										
											2012-02-24 10:47:17 +01:00
										 |  |  | { | 
					
						
							| 
									
										
										
										
											2012-11-26 21:18:13 +02:00
										 |  |  |     setObjectName(QLatin1String("QML Profiler Connections")); | 
					
						
							| 
									
										
										
										
											2012-02-24 10:47:17 +01:00
										 |  |  | 
 | 
					
						
							|  |  |  |     d->profilerState = 0; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     d->connection = 0; | 
					
						
							|  |  |  |     d->connectionAttempts = 0; | 
					
						
							|  |  |  |     d->v8DataReady = false; | 
					
						
							|  |  |  |     d->qmlDataReady = false; | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2013-08-08 13:28:08 +02:00
										 |  |  |     d->modelManager = 0; | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2012-02-24 10:47:17 +01:00
										 |  |  |     d->connectionTimer.setInterval(200); | 
					
						
							|  |  |  |     connect(&d->connectionTimer, SIGNAL(timeout()), SLOT(tryToConnect())); | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | QmlProfilerClientManager::~QmlProfilerClientManager() | 
					
						
							|  |  |  | { | 
					
						
							|  |  |  |     delete d->connection; | 
					
						
							|  |  |  |     delete d->qmlclientplugin.data(); | 
					
						
							|  |  |  |     delete d->v8clientplugin.data(); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     delete d; | 
					
						
							|  |  |  | } | 
					
						
							| 
									
										
										
										
											2013-07-30 18:35:51 +02:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2013-08-08 13:28:08 +02:00
										 |  |  | void QmlProfilerClientManager::setModelManager(QmlProfilerModelManager *m) | 
					
						
							|  |  |  | { | 
					
						
							| 
									
										
										
										
											2013-11-11 22:20:47 +02:00
										 |  |  |     if (d->modelManager) | 
					
						
							| 
									
										
										
										
											2013-08-08 13:28:08 +02:00
										 |  |  |         disconnect(this,SIGNAL(dataReadyForProcessing()), d->modelManager, SLOT(complete())); | 
					
						
							|  |  |  |     d->modelManager = m; | 
					
						
							| 
									
										
										
										
											2013-11-11 22:20:47 +02:00
										 |  |  |     if (d->modelManager) | 
					
						
							| 
									
										
										
										
											2013-08-08 13:28:08 +02:00
										 |  |  |         connect(this,SIGNAL(dataReadyForProcessing()), d->modelManager, SLOT(complete())); | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2012-02-24 10:47:17 +01:00
										 |  |  | ////////////////////////////////////////////////////////////////
 | 
					
						
							|  |  |  | // Interface
 | 
					
						
							|  |  |  | void QmlProfilerClientManager::setTcpConnection(QString host, quint64 port) | 
					
						
							|  |  |  | { | 
					
						
							|  |  |  |     d->connectMode = QmlProfilerClientManagerPrivate::TcpConnection; | 
					
						
							|  |  |  |     d->tcpHost = host; | 
					
						
							|  |  |  |     d->tcpPort = port; | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | void QmlProfilerClientManager::setOstConnection(QString ostDevice) | 
					
						
							|  |  |  | { | 
					
						
							|  |  |  |     d->connectMode = QmlProfilerClientManagerPrivate::OstConnection; | 
					
						
							|  |  |  |     d->ostDevice = ostDevice; | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | void QmlProfilerClientManager::clearBufferedData() | 
					
						
							|  |  |  | { | 
					
						
							|  |  |  |     if (d->qmlclientplugin) | 
					
						
							|  |  |  |         d->qmlclientplugin.data()->clearData(); | 
					
						
							|  |  |  |     if (d->v8clientplugin) | 
					
						
							|  |  |  |         d->v8clientplugin.data()->clearData(); | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2012-03-26 16:20:09 +02:00
										 |  |  | void QmlProfilerClientManager::discardPendingData() | 
					
						
							|  |  |  | { | 
					
						
							|  |  |  |     if (d->connection) | 
					
						
							|  |  |  |         d->connection->flush(); | 
					
						
							|  |  |  |     clearBufferedData(); | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2012-02-24 10:47:17 +01:00
										 |  |  | ////////////////////////////////////////////////////////////////
 | 
					
						
							|  |  |  | // Internal
 | 
					
						
							|  |  |  | void QmlProfilerClientManager::connectClient(quint16 port) | 
					
						
							|  |  |  | { | 
					
						
							|  |  |  |     if (d->connection) | 
					
						
							|  |  |  |         delete d->connection; | 
					
						
							| 
									
										
										
										
											2012-04-18 12:06:10 +02:00
										 |  |  |     d->connection = new QmlDebugConnection; | 
					
						
							| 
									
										
										
										
											2012-02-24 10:47:17 +01:00
										 |  |  |     enableServices(); | 
					
						
							| 
									
										
										
										
											2014-05-05 16:11:43 +02:00
										 |  |  |     connect(d->connection, SIGNAL(socketStateChanged(QAbstractSocket::SocketState)), | 
					
						
							| 
									
										
										
										
											2012-02-24 10:47:17 +01:00
										 |  |  |             this, SLOT(connectionStateChanged())); | 
					
						
							|  |  |  |     d->connectionTimer.start(); | 
					
						
							|  |  |  |     d->tcpPort = port; | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | void QmlProfilerClientManager::enableServices() | 
					
						
							|  |  |  | { | 
					
						
							|  |  |  |     QTC_ASSERT(d->profilerState, return); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     disconnectClientSignals(); | 
					
						
							|  |  |  |     d->profilerState->setServerRecording(false); // false by default (will be set to true when connected)
 | 
					
						
							|  |  |  |     delete d->qmlclientplugin.data(); | 
					
						
							|  |  |  |     d->qmlclientplugin = new QmlProfilerTraceClient(d->connection); | 
					
						
							|  |  |  |     delete d->v8clientplugin.data(); | 
					
						
							|  |  |  |     d->v8clientplugin = new QV8ProfilerClient(d->connection); | 
					
						
							|  |  |  |     connectClientSignals(); | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | void QmlProfilerClientManager::connectClientSignals() | 
					
						
							|  |  |  | { | 
					
						
							|  |  |  |     QTC_ASSERT(d->profilerState, return); | 
					
						
							|  |  |  |     if (d->qmlclientplugin) { | 
					
						
							| 
									
										
										
										
											2014-04-03 12:33:14 +02:00
										 |  |  |         connect(d->qmlclientplugin.data(), SIGNAL(complete(qint64)), | 
					
						
							|  |  |  |                 this, SLOT(qmlComplete(qint64))); | 
					
						
							| 
									
										
										
										
											2012-02-24 10:47:17 +01:00
										 |  |  |         connect(d->qmlclientplugin.data(), | 
					
						
							| 
									
										
										
										
											2013-08-08 13:28:08 +02:00
										 |  |  |                 SIGNAL(rangedEvent(int,int,qint64,qint64,QStringList,QmlDebug::QmlEventLocation, | 
					
						
							|  |  |  |                              qint64,qint64,qint64,qint64,qint64)), | 
					
						
							|  |  |  |                 d->modelManager, | 
					
						
							|  |  |  |                 SLOT(addQmlEvent(int,int,qint64,qint64,QStringList,QmlDebug::QmlEventLocation, | 
					
						
							|  |  |  |                              qint64,qint64,qint64,qint64,qint64))); | 
					
						
							| 
									
										
										
										
											2012-02-24 10:47:17 +01:00
										 |  |  |         connect(d->qmlclientplugin.data(), SIGNAL(traceFinished(qint64)), | 
					
						
							| 
									
										
										
										
											2013-08-08 13:28:08 +02:00
										 |  |  |                 d->modelManager->traceTime(), SLOT(setEndTime(qint64))); | 
					
						
							| 
									
										
										
										
											2012-02-24 10:47:17 +01:00
										 |  |  |         connect(d->qmlclientplugin.data(), SIGNAL(traceStarted(qint64)), | 
					
						
							| 
									
										
										
										
											2013-08-08 13:28:08 +02:00
										 |  |  |                 d->modelManager->traceTime(), SLOT(setStartTime(qint64))); | 
					
						
							| 
									
										
										
										
											2012-02-24 10:47:17 +01:00
										 |  |  |         connect(d->qmlclientplugin.data(), SIGNAL(enabledChanged()), | 
					
						
							|  |  |  |                 d->qmlclientplugin.data(), SLOT(sendRecordingStatus())); | 
					
						
							|  |  |  |         // fixme: this should be unified for both clients
 | 
					
						
							|  |  |  |         connect(d->qmlclientplugin.data(), SIGNAL(recordingChanged(bool)), | 
					
						
							|  |  |  |                 d->profilerState, SLOT(setServerRecording(bool))); | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  |     if (d->v8clientplugin) { | 
					
						
							|  |  |  |         connect(d->v8clientplugin.data(), SIGNAL(complete()), this, SLOT(v8Complete())); | 
					
						
							|  |  |  |         connect(d->v8clientplugin.data(), | 
					
						
							|  |  |  |                 SIGNAL(v8range(int,QString,QString,int,double,double)), | 
					
						
							| 
									
										
										
										
											2013-08-08 13:28:08 +02:00
										 |  |  |                 d->modelManager, | 
					
						
							|  |  |  |                 SLOT(addV8Event(int,QString,QString,int,double,double))); | 
					
						
							| 
									
										
										
										
											2012-02-24 10:47:17 +01:00
										 |  |  |         connect(d->v8clientplugin.data(), SIGNAL(enabledChanged()), | 
					
						
							|  |  |  |                 d->v8clientplugin.data(), SLOT(sendRecordingStatus())); | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | void QmlProfilerClientManager::disconnectClientSignals() | 
					
						
							|  |  |  | { | 
					
						
							|  |  |  |     if (d->qmlclientplugin) { | 
					
						
							|  |  |  |         disconnect(d->qmlclientplugin.data(), SIGNAL(complete()), | 
					
						
							|  |  |  |                    this, SLOT(qmlComplete())); | 
					
						
							|  |  |  |         disconnect(d->qmlclientplugin.data(), | 
					
						
							| 
									
										
										
										
											2013-08-08 13:28:08 +02:00
										 |  |  |                    SIGNAL(rangedEvent(int,int,qint64,qint64,QStringList,QmlDebug::QmlEventLocation, | 
					
						
							|  |  |  |                                 qint64,qint64,qint64,qint64,qint64)), | 
					
						
							|  |  |  |                    d->modelManager, | 
					
						
							|  |  |  |                    SLOT(addQmlEvent(int,int,qint64,qint64,QStringList,QmlDebug::QmlEventLocation, | 
					
						
							|  |  |  |                                     qint64,qint64,qint64,qint64,qint64))); | 
					
						
							| 
									
										
										
										
											2012-02-24 10:47:17 +01:00
										 |  |  |         disconnect(d->qmlclientplugin.data(), SIGNAL(traceFinished(qint64)), | 
					
						
							| 
									
										
										
										
											2013-08-08 13:28:08 +02:00
										 |  |  |                 d->modelManager->traceTime(), SLOT(setEndTime(qint64))); | 
					
						
							| 
									
										
										
										
											2012-02-24 10:47:17 +01:00
										 |  |  |         disconnect(d->qmlclientplugin.data(), SIGNAL(traceStarted(qint64)), | 
					
						
							| 
									
										
										
										
											2013-08-08 13:28:08 +02:00
										 |  |  |                 d->modelManager->traceTime(), SLOT(setStartTime(qint64))); | 
					
						
							| 
									
										
										
										
											2012-02-24 10:47:17 +01:00
										 |  |  |         disconnect(d->qmlclientplugin.data(), SIGNAL(frame(qint64,int,int)), | 
					
						
							| 
									
										
										
										
											2013-08-08 13:28:08 +02:00
										 |  |  |                    d->modelManager, SLOT(addFrameEvent(qint64,int,int))); | 
					
						
							| 
									
										
										
										
											2012-02-24 10:47:17 +01:00
										 |  |  |         disconnect(d->qmlclientplugin.data(), SIGNAL(enabledChanged()), | 
					
						
							|  |  |  |                    d->qmlclientplugin.data(), SLOT(sendRecordingStatus())); | 
					
						
							|  |  |  |         // fixme: this should be unified for both clients
 | 
					
						
							|  |  |  |         disconnect(d->qmlclientplugin.data(), SIGNAL(recordingChanged(bool)), | 
					
						
							|  |  |  |                    d->profilerState, SLOT(setServerRecording(bool))); | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  |     if (d->v8clientplugin) { | 
					
						
							|  |  |  |         disconnect(d->v8clientplugin.data(), SIGNAL(complete()), this, SLOT(v8Complete())); | 
					
						
							|  |  |  |         disconnect(d->v8clientplugin.data(), | 
					
						
							|  |  |  |                    SIGNAL(v8range(int,QString,QString,int,double,double)), | 
					
						
							| 
									
										
										
										
											2013-08-08 13:28:08 +02:00
										 |  |  |                    d->modelManager, | 
					
						
							|  |  |  |                    SLOT(addV8Event(int,QString,QString,int,double,double))); | 
					
						
							| 
									
										
										
										
											2012-02-24 10:47:17 +01:00
										 |  |  |         disconnect(d->v8clientplugin.data(), SIGNAL(enabledChanged()), | 
					
						
							|  |  |  |                    d->v8clientplugin.data(), SLOT(sendRecordingStatus())); | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | void QmlProfilerClientManager::connectToClient() | 
					
						
							|  |  |  | { | 
					
						
							| 
									
										
										
										
											2014-05-05 16:11:43 +02:00
										 |  |  |     if (!d->connection || d->connection->socketState() != QAbstractSocket::UnconnectedState) | 
					
						
							| 
									
										
										
										
											2012-02-24 10:47:17 +01:00
										 |  |  |         return; | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2012-08-22 13:27:25 +02:00
										 |  |  |     d->connection->connectToHost(d->tcpHost, d->tcpPort); | 
					
						
							| 
									
										
										
										
											2012-02-24 10:47:17 +01:00
										 |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2012-05-11 17:19:15 +02:00
										 |  |  | bool QmlProfilerClientManager::isConnected() const | 
					
						
							|  |  |  | { | 
					
						
							|  |  |  |     return d->connection && d->connection->isConnected(); | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2012-02-24 10:47:17 +01:00
										 |  |  | void QmlProfilerClientManager::disconnectClient() | 
					
						
							|  |  |  | { | 
					
						
							|  |  |  |     // this might be actually be called indirectly by QDDConnectionPrivate::readyRead(), therefore allow
 | 
					
						
							| 
									
										
										
										
											2013-10-07 13:34:40 +02:00
										 |  |  |     // function to complete before deleting object
 | 
					
						
							| 
									
										
										
										
											2012-02-24 10:47:17 +01:00
										 |  |  |     if (d->connection) { | 
					
						
							|  |  |  |         d->connection->deleteLater(); | 
					
						
							|  |  |  |         d->connection = 0; | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | void QmlProfilerClientManager::tryToConnect() | 
					
						
							|  |  |  | { | 
					
						
							|  |  |  |     ++d->connectionAttempts; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     if (d->connection && d->connection->isConnected()) { | 
					
						
							|  |  |  |         d->connectionTimer.stop(); | 
					
						
							|  |  |  |         d->connectionAttempts = 0; | 
					
						
							|  |  |  |     } else if (d->connectionAttempts == 50) { | 
					
						
							|  |  |  |         d->connectionTimer.stop(); | 
					
						
							|  |  |  |         d->connectionAttempts = 0; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |         QMessageBox *infoBox = QmlProfilerTool::requestMessageBox(); | 
					
						
							|  |  |  |         infoBox->setIcon(QMessageBox::Critical); | 
					
						
							|  |  |  |         infoBox->setWindowTitle(tr("Qt Creator")); | 
					
						
							|  |  |  |         infoBox->setText(tr("Could not connect to the in-process QML profiler.\n" | 
					
						
							|  |  |  |                             "Do you want to retry?")); | 
					
						
							|  |  |  |         infoBox->setStandardButtons(QMessageBox::Retry | | 
					
						
							|  |  |  |                                     QMessageBox::Cancel | | 
					
						
							|  |  |  |                                     QMessageBox::Help); | 
					
						
							|  |  |  |         infoBox->setDefaultButton(QMessageBox::Retry); | 
					
						
							|  |  |  |         infoBox->setModal(true); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |         connect(infoBox, SIGNAL(finished(int)), | 
					
						
							|  |  |  |                 this, SLOT(retryMessageBoxFinished(int))); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |         infoBox->show(); | 
					
						
							|  |  |  |     } else { | 
					
						
							|  |  |  |         connectToClient(); | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | void QmlProfilerClientManager::connectionStateChanged() | 
					
						
							|  |  |  | { | 
					
						
							|  |  |  |     if (!d->connection) | 
					
						
							|  |  |  |         return; | 
					
						
							| 
									
										
										
										
											2014-05-05 16:11:43 +02:00
										 |  |  |     switch (d->connection->socketState()) { | 
					
						
							| 
									
										
										
										
											2012-02-24 10:47:17 +01:00
										 |  |  |     case QAbstractSocket::UnconnectedState: | 
					
						
							|  |  |  |     { | 
					
						
							|  |  |  |         if (QmlProfilerPlugin::debugOutput) | 
					
						
							|  |  |  |             qWarning("QML Profiler: disconnected"); | 
					
						
							| 
									
										
										
										
											2012-05-08 15:14:11 +02:00
										 |  |  |         disconnectClient(); | 
					
						
							|  |  |  |         emit connectionClosed(); | 
					
						
							| 
									
										
										
										
											2012-02-24 10:47:17 +01:00
										 |  |  |         break; | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  |     case QAbstractSocket::HostLookupState: | 
					
						
							|  |  |  |         break; | 
					
						
							|  |  |  |     case QAbstractSocket::ConnectingState: { | 
					
						
							|  |  |  |         if (QmlProfilerPlugin::debugOutput) | 
					
						
							|  |  |  |             qWarning("QML Profiler: Connecting to debug server ..."); | 
					
						
							| 
									
										
										
										
											2014-03-14 15:39:02 +01:00
										 |  |  |         QmlProfilerTool::logStatus(tr("QML Profiler: Connecting to %1:%2 ...") | 
					
						
							|  |  |  |             .arg(d->tcpHost, QString::number(d->tcpPort))); | 
					
						
							| 
									
										
										
										
											2012-02-24 10:47:17 +01:00
										 |  |  |         break; | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  |     case QAbstractSocket::ConnectedState: | 
					
						
							|  |  |  |     { | 
					
						
							|  |  |  |         if (QmlProfilerPlugin::debugOutput) | 
					
						
							|  |  |  |             qWarning("QML Profiler: connected and running"); | 
					
						
							| 
									
										
										
										
											2014-03-14 15:39:02 +01:00
										 |  |  |         // notify the client recording status
 | 
					
						
							|  |  |  |         clientRecordingChanged(); | 
					
						
							|  |  |  |         QmlProfilerTool::logStatus(tr("QML Profiler: connected and running")); | 
					
						
							| 
									
										
										
										
											2012-02-24 10:47:17 +01:00
										 |  |  |         break; | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  |     case QAbstractSocket::ClosingState: | 
					
						
							|  |  |  |         if (QmlProfilerPlugin::debugOutput) | 
					
						
							|  |  |  |             qWarning("QML Profiler: closing ..."); | 
					
						
							|  |  |  |         break; | 
					
						
							|  |  |  |     case QAbstractSocket::BoundState: | 
					
						
							|  |  |  |     case QAbstractSocket::ListeningState: | 
					
						
							|  |  |  |         break; | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | void QmlProfilerClientManager::retryMessageBoxFinished(int result) | 
					
						
							|  |  |  | { | 
					
						
							|  |  |  |     switch (result) { | 
					
						
							|  |  |  |     case QMessageBox::Retry: { | 
					
						
							|  |  |  |         d->connectionAttempts = 0; | 
					
						
							|  |  |  |         d->connectionTimer.start(); | 
					
						
							|  |  |  |         break; | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  |     case QMessageBox::Help: { | 
					
						
							| 
									
										
										
										
											2013-01-29 15:29:55 +01:00
										 |  |  |         QmlProfilerTool::handleHelpRequest(QLatin1String("qthelp://org.qt-project.qtcreator/doc/creator-debugging-qml.html")); | 
					
						
							| 
									
										
										
										
											2012-02-24 10:47:17 +01:00
										 |  |  |         // fall through
 | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  |     default: { | 
					
						
							| 
									
										
										
											
												Remove braces for single lines of conditions
#!/usr/bin/env ruby
Dir.glob('**/*.cpp') { |file|
  # skip ast (excluding paste, astpath, and canv'ast'imer)
  next if file =~ /ast[^eip]|keywords\.|qualifiers|preprocessor|names.cpp/i
  s = File.read(file)
  next if s.include?('qlalr')
  orig = s.dup
  s.gsub!(/\n *if [^\n]*{\n[^\n]*\n\s+}(\s+else if [^\n]* {\n[^\n]*\n\s+})*(\s+else {\n[^\n]*\n\s+})?\n/m) { |m|
    res = $&
    if res =~ /^\s*(\/\/|[A-Z_]{3,})/ # C++ comment or macro (Q_UNUSED, SDEBUG), do not touch braces
      res
    else
      res.gsub!('} else', 'else')
      res.gsub!(/\n +} *\n/m, "\n")
      res.gsub(/ *{$/, '')
    end
  }
  s.gsub!(/ *$/, '')
  File.open(file, 'wb').write(s) if s != orig
}
Change-Id: I3b30ee60df0986f66c02132c65fc38a3fbb6bbdc
Reviewed-by: hjk <qthjk@ovi.com>
											
										 
											2013-01-08 03:32:53 +02:00
										 |  |  |         if (d->connection) | 
					
						
							| 
									
										
										
										
											2012-11-26 21:18:13 +02:00
										 |  |  |             QmlProfilerTool::logStatus(QLatin1String("QML Profiler: Failed to connect! ") + d->connection->errorString()); | 
					
						
							| 
									
										
										
											
												Remove braces for single lines of conditions
#!/usr/bin/env ruby
Dir.glob('**/*.cpp') { |file|
  # skip ast (excluding paste, astpath, and canv'ast'imer)
  next if file =~ /ast[^eip]|keywords\.|qualifiers|preprocessor|names.cpp/i
  s = File.read(file)
  next if s.include?('qlalr')
  orig = s.dup
  s.gsub!(/\n *if [^\n]*{\n[^\n]*\n\s+}(\s+else if [^\n]* {\n[^\n]*\n\s+})*(\s+else {\n[^\n]*\n\s+})?\n/m) { |m|
    res = $&
    if res =~ /^\s*(\/\/|[A-Z_]{3,})/ # C++ comment or macro (Q_UNUSED, SDEBUG), do not touch braces
      res
    else
      res.gsub!('} else', 'else')
      res.gsub!(/\n +} *\n/m, "\n")
      res.gsub(/ *{$/, '')
    end
  }
  s.gsub!(/ *$/, '')
  File.open(file, 'wb').write(s) if s != orig
}
Change-Id: I3b30ee60df0986f66c02132c65fc38a3fbb6bbdc
Reviewed-by: hjk <qthjk@ovi.com>
											
										 
											2013-01-08 03:32:53 +02:00
										 |  |  |         else | 
					
						
							| 
									
										
										
										
											2012-11-26 21:18:13 +02:00
										 |  |  |             QmlProfilerTool::logStatus(QLatin1String("QML Profiler: Failed to connect!")); | 
					
						
							| 
									
										
										
										
											2012-02-24 10:47:17 +01:00
										 |  |  | 
 | 
					
						
							|  |  |  |         emit connectionFailed(); | 
					
						
							|  |  |  |         break; | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2014-04-03 12:33:14 +02:00
										 |  |  | void QmlProfilerClientManager::qmlComplete(qint64 maximumTime) | 
					
						
							| 
									
										
										
										
											2012-02-24 10:47:17 +01:00
										 |  |  | { | 
					
						
							| 
									
										
										
										
											2014-04-03 12:33:14 +02:00
										 |  |  |     if (maximumTime > d->modelManager->traceTime()->endTime()) | 
					
						
							|  |  |  |         d->modelManager->traceTime()->setEndTime(maximumTime); | 
					
						
							| 
									
										
										
										
											2012-02-24 10:47:17 +01:00
										 |  |  |     d->qmlDataReady = true; | 
					
						
							| 
									
										
										
										
											2014-05-05 16:11:43 +02:00
										 |  |  |     if (!d->v8clientplugin || | 
					
						
							|  |  |  |             d->v8clientplugin.data()->state() != QmlDebug::QmlDebugClient::Enabled || | 
					
						
							|  |  |  |             d->v8DataReady) { | 
					
						
							| 
									
										
										
										
											2012-02-24 10:47:17 +01:00
										 |  |  |         emit dataReadyForProcessing(); | 
					
						
							|  |  |  |         // once complete is sent, reset the flags
 | 
					
						
							|  |  |  |         d->qmlDataReady = false; | 
					
						
							|  |  |  |         d->v8DataReady = false; | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | void QmlProfilerClientManager::v8Complete() | 
					
						
							|  |  |  | { | 
					
						
							|  |  |  |     d->v8DataReady = true; | 
					
						
							| 
									
										
										
										
											2014-05-05 16:11:43 +02:00
										 |  |  |     if (!d->qmlclientplugin || | 
					
						
							|  |  |  |             d->qmlclientplugin.data()->state() != QmlDebug::QmlDebugClient::Enabled || | 
					
						
							|  |  |  |             d->qmlDataReady) { | 
					
						
							| 
									
										
										
										
											2012-02-24 10:47:17 +01:00
										 |  |  |         emit dataReadyForProcessing(); | 
					
						
							|  |  |  |         // once complete is sent, reset the flags
 | 
					
						
							|  |  |  |         d->v8DataReady = false; | 
					
						
							|  |  |  |         d->qmlDataReady = false; | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | void QmlProfilerClientManager::stopClientsRecording() | 
					
						
							|  |  |  | { | 
					
						
							|  |  |  |     if (d->qmlclientplugin) | 
					
						
							|  |  |  |         d->qmlclientplugin.data()->setRecording(false); | 
					
						
							|  |  |  |     if (d->v8clientplugin) | 
					
						
							|  |  |  |         d->v8clientplugin.data()->setRecording(false); | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | ////////////////////////////////////////////////////////////////
 | 
					
						
							|  |  |  | // Profiler State
 | 
					
						
							|  |  |  | void QmlProfilerClientManager::registerProfilerStateManager( QmlProfilerStateManager *profilerState ) | 
					
						
							|  |  |  | { | 
					
						
							|  |  |  |     if (d->profilerState) { | 
					
						
							|  |  |  |         disconnect(d->profilerState, SIGNAL(stateChanged()), | 
					
						
							|  |  |  |                    this, SLOT(profilerStateChanged())); | 
					
						
							|  |  |  |         disconnect(d->profilerState, SIGNAL(clientRecordingChanged()), | 
					
						
							|  |  |  |                    this, SLOT(clientRecordingChanged())); | 
					
						
							|  |  |  |         disconnect(d->profilerState, SIGNAL(serverRecordingChanged()), | 
					
						
							|  |  |  |                    this, SLOT(serverRecordingChanged())); | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     d->profilerState = profilerState; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     // connect
 | 
					
						
							|  |  |  |     if (d->profilerState) { | 
					
						
							|  |  |  |         connect(d->profilerState, SIGNAL(stateChanged()), | 
					
						
							|  |  |  |                 this, SLOT(profilerStateChanged())); | 
					
						
							|  |  |  |         connect(d->profilerState, SIGNAL(clientRecordingChanged()), | 
					
						
							|  |  |  |                 this, SLOT(clientRecordingChanged())); | 
					
						
							|  |  |  |         connect(d->profilerState, SIGNAL(serverRecordingChanged()), | 
					
						
							|  |  |  |                 this, SLOT(serverRecordingChanged())); | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | void QmlProfilerClientManager::profilerStateChanged() | 
					
						
							|  |  |  | { | 
					
						
							|  |  |  |     QTC_ASSERT(d->profilerState, return); | 
					
						
							|  |  |  |     switch (d->profilerState->currentState()) { | 
					
						
							|  |  |  |     case QmlProfilerStateManager::AppStopRequested : | 
					
						
							| 
									
										
										
											
												Remove braces for single lines of conditions
#!/usr/bin/env ruby
Dir.glob('**/*.cpp') { |file|
  # skip ast (excluding paste, astpath, and canv'ast'imer)
  next if file =~ /ast[^eip]|keywords\.|qualifiers|preprocessor|names.cpp/i
  s = File.read(file)
  next if s.include?('qlalr')
  orig = s.dup
  s.gsub!(/\n *if [^\n]*{\n[^\n]*\n\s+}(\s+else if [^\n]* {\n[^\n]*\n\s+})*(\s+else {\n[^\n]*\n\s+})?\n/m) { |m|
    res = $&
    if res =~ /^\s*(\/\/|[A-Z_]{3,})/ # C++ comment or macro (Q_UNUSED, SDEBUG), do not touch braces
      res
    else
      res.gsub!('} else', 'else')
      res.gsub!(/\n +} *\n/m, "\n")
      res.gsub(/ *{$/, '')
    end
  }
  s.gsub!(/ *$/, '')
  File.open(file, 'wb').write(s) if s != orig
}
Change-Id: I3b30ee60df0986f66c02132c65fc38a3fbb6bbdc
Reviewed-by: hjk <qthjk@ovi.com>
											
										 
											2013-01-08 03:32:53 +02:00
										 |  |  |         if (d->profilerState->serverRecording()) | 
					
						
							| 
									
										
										
										
											2012-02-24 10:47:17 +01:00
										 |  |  |             stopClientsRecording(); | 
					
						
							|  |  |  |         else | 
					
						
							|  |  |  |             d->profilerState->setCurrentState(QmlProfilerStateManager::AppReadyToStop); | 
					
						
							|  |  |  |         break; | 
					
						
							|  |  |  |     default: | 
					
						
							|  |  |  |         break; | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | void QmlProfilerClientManager::clientRecordingChanged() | 
					
						
							|  |  |  | { | 
					
						
							|  |  |  |     QTC_ASSERT(d->profilerState, return); | 
					
						
							|  |  |  |     if (d->profilerState->currentState() == QmlProfilerStateManager::AppRunning) { | 
					
						
							|  |  |  |         if (d->qmlclientplugin) | 
					
						
							|  |  |  |             d->qmlclientplugin.data()->setRecording(d->profilerState->clientRecording()); | 
					
						
							|  |  |  |         if (d->v8clientplugin) | 
					
						
							|  |  |  |             d->v8clientplugin.data()->setRecording(d->profilerState->clientRecording()); | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | void QmlProfilerClientManager::serverRecordingChanged() | 
					
						
							|  |  |  | { | 
					
						
							|  |  |  |     if (d->profilerState->serverRecording()) { | 
					
						
							|  |  |  |         d->v8DataReady = false; | 
					
						
							|  |  |  |         d->qmlDataReady = false; | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | } // namespace Internal
 | 
					
						
							|  |  |  | } // namespace QmlProfiler
 |